diff --git a/lib/tests/modules/submoduleFiles.nix b/lib/tests/modules/submoduleFiles.nix index c0d9b2cef3e8d3..b7ce6828cf5c4e 100644 --- a/lib/tests/modules/submoduleFiles.nix +++ b/lib/tests/modules/submoduleFiles.nix @@ -1,14 +1,20 @@ -{ lib, ... }: { +{ lib, ... }: +{ options.submodule = lib.mkOption { - default = {}; + default = { }; type = lib.types.submoduleWith { - modules = [ ({ options, ... }: { - options.value = lib.mkOption {}; + modules = [ + ( + { options, ... }: + { + options.value = lib.mkOption { }; - options.internalFiles = lib.mkOption { - default = options.value.files; - }; - })]; + options.internalFiles = lib.mkOption { + default = options.value.files; + }; + } + ) + ]; }; }; diff --git a/lib/tests/modules/test-mergeAttrDefinitionsWithPrio.nix b/lib/tests/modules/test-mergeAttrDefinitionsWithPrio.nix index 3233f415136879..0086ce9fda103f 100644 --- a/lib/tests/modules/test-mergeAttrDefinitionsWithPrio.nix +++ b/lib/tests/modules/test-mergeAttrDefinitionsWithPrio.nix @@ -2,7 +2,9 @@ let defs = lib.modules.mergeAttrDefinitionsWithPrio options._module.args; - assertLazy = pos: throw "${pos.file}:${toString pos.line}:${toString pos.column}: The test must not evaluate this the assertLazy thunk, but it did. Unexpected strictness leads to unexpected errors and performance problems."; + assertLazy = + pos: + throw "${pos.file}:${toString pos.line}:${toString pos.column}: The test must not evaluate this the assertLazy thunk, but it did. Unexpected strictness leads to unexpected errors and performance problems."; in { diff --git a/lib/tests/modules/types-anything/attrs-coercible.nix b/lib/tests/modules/types-anything/attrs-coercible.nix index 085cbd638f17f1..75bc2121a22a3d 100644 --- a/lib/tests/modules/types-anything/attrs-coercible.nix +++ b/lib/tests/modules/types-anything/attrs-coercible.nix @@ -1,4 +1,5 @@ -{ lib, ... }: { +{ lib, ... }: +{ options.value = lib.mkOption { type = lib.types.anything; diff --git a/lib/tests/modules/types-anything/equal-atoms.nix b/lib/tests/modules/types-anything/equal-atoms.nix index 28d2b53ceee34d..66d1779d1ffbf1 100644 --- a/lib/tests/modules/types-anything/equal-atoms.nix +++ b/lib/tests/modules/types-anything/equal-atoms.nix @@ -1,4 +1,5 @@ -{ lib, ... }: { +{ lib, ... }: +{ options.value = lib.mkOption { type = lib.types.anything; @@ -12,7 +13,11 @@ value.path = ./.; value.null = null; value.float = 0.1; - value.list = [1 "a" {x=null;}]; + value.list = [ + 1 + "a" + { x = null; } + ]; } { value.int = 0; @@ -21,7 +26,11 @@ value.path = ./.; value.null = null; value.float = 0.1; - value.list = [1 "a" {x=null;}]; + value.list = [ + 1 + "a" + { x = null; } + ]; } ]; diff --git a/lib/tests/modules/types-anything/functions.nix b/lib/tests/modules/types-anything/functions.nix index 3288b64f9b7eb8..c29e3a1c5d8c1d 100644 --- a/lib/tests/modules/types-anything/functions.nix +++ b/lib/tests/modules/types-anything/functions.nix @@ -1,4 +1,5 @@ -{ lib, config, ... }: { +{ lib, config, ... }: +{ options.valueIsFunction = lib.mkOption { default = lib.mapAttrs (name: lib.isFunction) config.value; diff --git a/lib/tests/modules/types-anything/lists.nix b/lib/tests/modules/types-anything/lists.nix index 21ca9d24f7a855..de647cd8d1a491 100644 --- a/lib/tests/modules/types-anything/lists.nix +++ b/lib/tests/modules/types-anything/lists.nix @@ -1,4 +1,5 @@ -{ lib, ... }: { +{ lib, ... }: +{ options.value = lib.mkOption { type = lib.types.anything; diff --git a/lib/tests/modules/types-anything/mk-mods.nix b/lib/tests/modules/types-anything/mk-mods.nix index f84ad01df01747..36f73ce1123667 100644 --- a/lib/tests/modules/types-anything/mk-mods.nix +++ b/lib/tests/modules/types-anything/mk-mods.nix @@ -1,4 +1,5 @@ -{ lib, ... }: { +{ lib, ... }: +{ options.value = lib.mkOption { type = lib.types.anything; @@ -6,10 +7,10 @@ config = lib.mkMerge [ { - value.mkiffalse = lib.mkIf false {}; + value.mkiffalse = lib.mkIf false { }; } { - value.mkiftrue = lib.mkIf true {}; + value.mkiftrue = lib.mkIf true { }; } { value.mkdefault = lib.mkDefault 0; @@ -19,7 +20,7 @@ } { value.mkmerge = lib.mkMerge [ - {} + { } ]; } { diff --git a/lib/tests/modules/types-anything/nested-attrs.nix b/lib/tests/modules/types-anything/nested-attrs.nix index e57d33ef8717ef..9754aa1fdc9d82 100644 --- a/lib/tests/modules/types-anything/nested-attrs.nix +++ b/lib/tests/modules/types-anything/nested-attrs.nix @@ -1,4 +1,5 @@ -{ lib, ... }: { +{ lib, ... }: +{ options.value = lib.mkOption { type = lib.types.anything; diff --git a/lib/tests/modules/types-attrTag-wrong-decl.nix b/lib/tests/modules/types-attrTag-wrong-decl.nix index d03370bc10da41..7e529235e0263a 100644 --- a/lib/tests/modules/types-attrTag-wrong-decl.nix +++ b/lib/tests/modules/types-attrTag-wrong-decl.nix @@ -8,7 +8,9 @@ in type = types.attrTag { int = types.int; }; - default = { int = 1; }; + default = { + int = 1; + }; }; }; } diff --git a/lib/tests/modules/types-attrTag.nix b/lib/tests/modules/types-attrTag.nix index b2e5158bb44b61..82d6e3c175906b 100644 --- a/lib/tests/modules/types-attrTag.nix +++ b/lib/tests/modules/types-attrTag.nix @@ -1,4 +1,9 @@ -{ lib, config, options, ... }: +{ + lib, + config, + options, + ... +}: let inherit (lib) mkOption types; forceDeep = x: builtins.deepSeq x x; @@ -7,15 +12,16 @@ in { options = { intStrings = mkOption { - type = types.attrsOf - (types.attrTag { + type = types.attrsOf ( + types.attrTag { left = mkOption { type = types.int; }; right = mkOption { type = types.str; }; - }); + } + ); }; nested = mkOption { type = types.attrTag { @@ -65,7 +71,7 @@ in } ); }; - okChecks = mkOption {}; + okChecks = mkOption { }; }; imports = [ ./docs.nix @@ -86,10 +92,19 @@ in ]; config = { intStrings.syntaxError = 1; - intStrings.syntaxError2 = {}; - intStrings.syntaxError3 = { a = true; b = true; }; - intStrings.syntaxError4 = lib.mkMerge [ { a = true; } { b = true; } ]; - intStrings.mergeError = lib.mkMerge [ { int = throw "do not eval"; } { string = throw "do not eval"; } ]; + intStrings.syntaxError2 = { }; + intStrings.syntaxError3 = { + a = true; + b = true; + }; + intStrings.syntaxError4 = lib.mkMerge [ + { a = true; } + { b = true; } + ]; + intStrings.mergeError = lib.mkMerge [ + { int = throw "do not eval"; } + { string = throw "do not eval"; } + ]; intStrings.badTagError.rite = throw "do not eval"; intStrings.badTagTypeError.left = "bad"; intStrings.numberOne.left = 1; @@ -109,7 +124,12 @@ in assert config.docs."submodules..foo.bar".type == "signed integer"; assert config.docs."submodules..qux".type == "string"; assert config.docs."submodules..qux".declarations == [ __curPos.file ]; - assert config.docs."submodules..qux".loc == [ "submodules" "" "qux" ]; + assert + config.docs."submodules..qux".loc == [ + "submodules" + "" + "qux" + ]; assert config.docs."submodules..qux".name == "submodules..qux"; assert config.docs."submodules..qux".description == "A qux for when you don't want a foo"; assert config.docs."submodules..qux".readOnly == false; @@ -119,17 +139,30 @@ in assert options.submodules.declarations == [ __curPos.file ]; assert lib.length options.submodules.declarationPositions == 1; assert (lib.head options.submodules.declarationPositions).file == __curPos.file; - assert options.merged.declarations == [ __curPos.file __curPos.file ]; + assert + options.merged.declarations == [ + __curPos.file + __curPos.file + ]; assert lib.length options.merged.declarationPositions == 2; assert (lib.elemAt options.merged.declarationPositions 0).file == __curPos.file; assert (lib.elemAt options.merged.declarationPositions 1).file == __curPos.file; - assert (lib.elemAt options.merged.declarationPositions 0).line != (lib.elemAt options.merged.declarationPositions 1).line; - assert mergedSubOption.declarations == [ __curPos.file __curPos.file ]; + assert + (lib.elemAt options.merged.declarationPositions 0).line + != (lib.elemAt options.merged.declarationPositions 1).line; + assert + mergedSubOption.declarations == [ + __curPos.file + __curPos.file + ]; assert lib.length mergedSubOption.declarationPositions == 2; assert (lib.elemAt mergedSubOption.declarationPositions 0).file == __curPos.file; assert (lib.elemAt mergedSubOption.declarationPositions 1).file == __curPos.file; - assert (lib.elemAt mergedSubOption.declarationPositions 0).line != (lib.elemAt mergedSubOption.declarationPositions 1).line; + assert + (lib.elemAt mergedSubOption.declarationPositions 0).line + != (lib.elemAt mergedSubOption.declarationPositions 1).line; assert lib.length config.docs."merged..extensible".declarations == 2; - true); + true + ); }; } diff --git a/lib/tests/modules/types-unique.nix b/lib/tests/modules/types-unique.nix index 115be01269759a..83efcbbb159521 100644 --- a/lib/tests/modules/types-unique.nix +++ b/lib/tests/modules/types-unique.nix @@ -4,13 +4,18 @@ let in { options.examples = mkOption { - type = types.lazyAttrsOf - (types.unique - { message = "We require a single definition, because seeing the whole value at once helps us maintain critical invariants of our system."; } - (types.attrsOf types.str)); + type = types.lazyAttrsOf ( + types.unique { + message = "We require a single definition, because seeing the whole value at once helps us maintain critical invariants of our system."; + } (types.attrsOf types.str) + ); }; imports = [ - { examples.merged = { b = "bee"; }; } + { + examples.merged = { + b = "bee"; + }; + } { examples.override = lib.mkForce { b = "bee"; }; } ]; config.examples = { diff --git a/lib/tests/nix-for-tests.nix b/lib/tests/nix-for-tests.nix index 69dedece387408..56263feea0e6c2 100644 --- a/lib/tests/nix-for-tests.nix +++ b/lib/tests/nix-for-tests.nix @@ -1,4 +1,5 @@ -{ pkgs +{ + pkgs, }: # The aws-sdk-cpp tests are flaky. Since pull requests to staging @@ -10,8 +11,6 @@ # # See also: https://github.com/NixOS/nix/issues/7582 -builtins.mapAttrs (_: pkg: - if builtins.isAttrs pkg - then pkg.override { withAWS = false; } - else pkg) - pkgs.nixVersions +builtins.mapAttrs ( + _: pkg: if builtins.isAttrs pkg then pkg.override { withAWS = false; } else pkg +) pkgs.nixVersions diff --git a/lib/tests/packages-from-directory/a.nix b/lib/tests/packages-from-directory/a.nix index 54f9eafd8e8782..0ba3be1fa5a5c8 100644 --- a/lib/tests/packages-from-directory/a.nix +++ b/lib/tests/packages-from-directory/a.nix @@ -1,2 +1 @@ -{ }: -"a" +{ }: "a" diff --git a/lib/tests/packages-from-directory/b.nix b/lib/tests/packages-from-directory/b.nix index 345b3c25fa2a92..37d4cc1dffcf57 100644 --- a/lib/tests/packages-from-directory/b.nix +++ b/lib/tests/packages-from-directory/b.nix @@ -1,2 +1 @@ -{ }: -"b" +{ }: "b" diff --git a/lib/tests/packages-from-directory/c/package.nix b/lib/tests/packages-from-directory/c/package.nix index c1203cdde96023..33caddbec88088 100644 --- a/lib/tests/packages-from-directory/c/package.nix +++ b/lib/tests/packages-from-directory/c/package.nix @@ -1,2 +1 @@ -{ }: -"c" +{ }: "c" diff --git a/lib/tests/packages-from-directory/my-namespace/d.nix b/lib/tests/packages-from-directory/my-namespace/d.nix index 6e5eaa09e99568..20596bd6a97c65 100644 --- a/lib/tests/packages-from-directory/my-namespace/d.nix +++ b/lib/tests/packages-from-directory/my-namespace/d.nix @@ -1,2 +1 @@ -{ }: -"d" +{ }: "d" diff --git a/lib/tests/packages-from-directory/my-namespace/e.nix b/lib/tests/packages-from-directory/my-namespace/e.nix index 50bd742f800cb6..9e7f6951f5211c 100644 --- a/lib/tests/packages-from-directory/my-namespace/e.nix +++ b/lib/tests/packages-from-directory/my-namespace/e.nix @@ -1,2 +1 @@ -{ }: -"e" +{ }: "e" diff --git a/lib/tests/packages-from-directory/my-namespace/f/package.nix b/lib/tests/packages-from-directory/my-namespace/f/package.nix index c9a66c2eb1208f..d58cfe01d606b4 100644 --- a/lib/tests/packages-from-directory/my-namespace/f/package.nix +++ b/lib/tests/packages-from-directory/my-namespace/f/package.nix @@ -1,2 +1 @@ -{ }: -"f" +{ }: "f" diff --git a/lib/tests/packages-from-directory/my-namespace/my-sub-namespace/g.nix b/lib/tests/packages-from-directory/my-namespace/my-sub-namespace/g.nix index 4ecaffbf1dc731..e8f6b37f3468e8 100644 --- a/lib/tests/packages-from-directory/my-namespace/my-sub-namespace/g.nix +++ b/lib/tests/packages-from-directory/my-namespace/my-sub-namespace/g.nix @@ -1,2 +1 @@ -{ }: -"g" +{ }: "g" diff --git a/lib/tests/packages-from-directory/my-namespace/my-sub-namespace/h.nix b/lib/tests/packages-from-directory/my-namespace/my-sub-namespace/h.nix index 3756275ba75249..34a0416e957723 100644 --- a/lib/tests/packages-from-directory/my-namespace/my-sub-namespace/h.nix +++ b/lib/tests/packages-from-directory/my-namespace/my-sub-namespace/h.nix @@ -1,2 +1 @@ -{ }: -"h" +{ }: "h" diff --git a/lib/tests/teams.nix b/lib/tests/teams.nix index 8a0a5d272634bc..6cf3aa0ef27c1f 100644 --- a/lib/tests/teams.nix +++ b/lib/tests/teams.nix @@ -1,50 +1,61 @@ # to run these tests: # nix-build nixpkgs/lib/tests/teams.nix # If it builds, all tests passed -{ pkgs ? import ../.. {}, lib ? pkgs.lib }: +{ + pkgs ? import ../.. { }, + lib ? pkgs.lib, +}: let inherit (lib) types; - teamModule = { config, ... }: { - options = { - shortName = lib.mkOption { - type = types.str; - }; - scope = lib.mkOption { - type = types.str; - }; - enableFeatureFreezePing = lib.mkOption { - type = types.bool; - default = false; - }; - members = lib.mkOption { - type = types.listOf (types.submodule - (import ./maintainer-module.nix { inherit lib; }) - ); - default = []; - }; - githubTeams = lib.mkOption { - type = types.listOf types.str; - default = []; + teamModule = + { config, ... }: + { + options = { + shortName = lib.mkOption { + type = types.str; + }; + scope = lib.mkOption { + type = types.str; + }; + enableFeatureFreezePing = lib.mkOption { + type = types.bool; + default = false; + }; + members = lib.mkOption { + type = types.listOf (types.submodule (import ./maintainer-module.nix { inherit lib; })); + default = [ ]; + }; + githubTeams = lib.mkOption { + type = types.listOf types.str; + default = [ ]; + }; }; }; - }; - checkTeam = team: uncheckedAttrs: - let - prefix = [ "lib" "maintainer-team" team ]; - checkedAttrs = (lib.modules.evalModules { - inherit prefix; - modules = [ - teamModule - { - _file = toString ../../maintainers/team-list.nix; - config = uncheckedAttrs; - } - ]; - }).config; - in checkedAttrs; + checkTeam = + team: uncheckedAttrs: + let + prefix = [ + "lib" + "maintainer-team" + team + ]; + checkedAttrs = + (lib.modules.evalModules { + inherit prefix; + modules = [ + teamModule + { + _file = toString ../../maintainers/team-list.nix; + config = uncheckedAttrs; + } + ]; + }).config; + in + checkedAttrs; checkedTeams = lib.mapAttrs checkTeam lib.teams; -in pkgs.writeTextDir "maintainer-teams.json" (builtins.toJSON checkedTeams) +in +pkgs.writeTextDir "maintainer-teams.json" (builtins.toJSON checkedTeams) diff --git a/lib/tests/test-with-nix.nix b/lib/tests/test-with-nix.nix index a6aee9859428ac..0be65a743f00f7 100644 --- a/lib/tests/test-with-nix.nix +++ b/lib/tests/test-with-nix.nix @@ -1,12 +1,12 @@ /** - * Instantiate the library tests for a given Nix version. - * - * IMPORTANT: - * This is used by the github.com/NixOS/nix CI. - * - * Try not to change the interface of this file, or if you need to, ping the - * Nix maintainers for help. Thank you! - */ + Instantiate the library tests for a given Nix version. + + IMPORTANT: + This is used by the github.com/NixOS/nix CI. + + Try not to change the interface of this file, or if you need to, ping the + Nix maintainers for help. Thank you! +*/ { pkgs, lib, @@ -14,67 +14,69 @@ nix, }: -pkgs.runCommand "nixpkgs-lib-tests-nix-${nix.version}" { - buildInputs = [ - (import ./check-eval.nix) - (import ./fetchers.nix) - (import ./maintainers.nix { - inherit pkgs; - lib = import ../.; - }) - (import ./teams.nix { - inherit pkgs; - lib = import ../.; - }) - (import ../path/tests { - inherit pkgs; - }) - ]; - nativeBuildInputs = [ - nix - pkgs.gitMinimal - ] ++ lib.optional pkgs.stdenv.hostPlatform.isLinux pkgs.inotify-tools; - strictDeps = true; -} '' - datadir="${nix}/share" - export TEST_ROOT=$(pwd)/test-tmp - export HOME=$(mktemp -d) - export NIX_BUILD_HOOK= - export NIX_CONF_DIR=$TEST_ROOT/etc - export NIX_LOCALSTATE_DIR=$TEST_ROOT/var - export NIX_LOG_DIR=$TEST_ROOT/var/log/nix - export NIX_STATE_DIR=$TEST_ROOT/var/nix - export NIX_STORE_DIR=$TEST_ROOT/store - export PAGER=cat - cacheDir=$TEST_ROOT/binary-cache +pkgs.runCommand "nixpkgs-lib-tests-nix-${nix.version}" + { + buildInputs = [ + (import ./check-eval.nix) + (import ./fetchers.nix) + (import ./maintainers.nix { + inherit pkgs; + lib = import ../.; + }) + (import ./teams.nix { + inherit pkgs; + lib = import ../.; + }) + (import ../path/tests { + inherit pkgs; + }) + ]; + nativeBuildInputs = [ + nix + pkgs.gitMinimal + ] ++ lib.optional pkgs.stdenv.hostPlatform.isLinux pkgs.inotify-tools; + strictDeps = true; + } + '' + datadir="${nix}/share" + export TEST_ROOT=$(pwd)/test-tmp + export HOME=$(mktemp -d) + export NIX_BUILD_HOOK= + export NIX_CONF_DIR=$TEST_ROOT/etc + export NIX_LOCALSTATE_DIR=$TEST_ROOT/var + export NIX_LOG_DIR=$TEST_ROOT/var/log/nix + export NIX_STATE_DIR=$TEST_ROOT/var/nix + export NIX_STORE_DIR=$TEST_ROOT/store + export PAGER=cat + cacheDir=$TEST_ROOT/binary-cache - nix-store --init + nix-store --init - cp -r ${../.} lib - echo "Running lib/tests/modules.sh" - bash lib/tests/modules.sh + cp -r ${../.} lib + echo "Running lib/tests/modules.sh" + bash lib/tests/modules.sh - echo "Checking lib.version" - nix-instantiate lib -A version --eval || { - echo "lib.version does not evaluate when lib is isolated from the rest of the nixpkgs tree" - exit 1 - } + echo "Checking lib.version" + nix-instantiate lib -A version --eval || { + echo "lib.version does not evaluate when lib is isolated from the rest of the nixpkgs tree" + exit 1 + } - echo "Running lib/tests/filesystem.sh" - TEST_LIB=$PWD/lib bash lib/tests/filesystem.sh + echo "Running lib/tests/filesystem.sh" + TEST_LIB=$PWD/lib bash lib/tests/filesystem.sh - echo "Running lib/tests/sources.sh" - TEST_LIB=$PWD/lib bash lib/tests/sources.sh + echo "Running lib/tests/sources.sh" + TEST_LIB=$PWD/lib bash lib/tests/sources.sh - echo "Running lib/tests/network.sh" - TEST_LIB=$PWD/lib bash lib/tests/network.sh + echo "Running lib/tests/network.sh" + TEST_LIB=$PWD/lib bash lib/tests/network.sh - echo "Running lib/fileset/tests.sh" - TEST_LIB=$PWD/lib bash lib/fileset/tests.sh + echo "Running lib/fileset/tests.sh" + TEST_LIB=$PWD/lib bash lib/fileset/tests.sh - echo "Running lib/tests/systems.nix" - [[ $(nix-instantiate --eval --strict lib/tests/systems.nix | tee /dev/stderr) == '[ ]' ]]; + echo "Running lib/tests/systems.nix" + [[ $(nix-instantiate --eval --strict lib/tests/systems.nix | tee /dev/stderr) == '[ ]' ]]; - mkdir $out - echo success > $out/${nix.version} -'' + mkdir $out + echo success > $out/${nix.version} + '' diff --git a/lib/versions.nix b/lib/versions.nix index 720d19e8ca29fc..32b4b5fbf945da 100644 --- a/lib/versions.nix +++ b/lib/versions.nix @@ -1,17 +1,19 @@ -/* Version string functions. */ +# Version string functions. { lib }: rec { - /* Break a version string into its component parts. + /* + Break a version string into its component parts. - Example: - splitVersion "1.2.3" - => ["1" "2" "3"] + Example: + splitVersion "1.2.3" + => ["1" "2" "3"] */ splitVersion = builtins.splitVersion; - /* Get the major version string from a string. + /* + Get the major version string from a string. Example: major "1.2.3" @@ -19,7 +21,8 @@ rec { */ major = v: builtins.elemAt (splitVersion v) 0; - /* Get the minor version string from a string. + /* + Get the minor version string from a string. Example: minor "1.2.3" @@ -27,7 +30,8 @@ rec { */ minor = v: builtins.elemAt (splitVersion v) 1; - /* Get the patch version string from a string. + /* + Get the patch version string from a string. Example: patch "1.2.3" @@ -35,30 +39,34 @@ rec { */ patch = v: builtins.elemAt (splitVersion v) 2; - /* Get string of the first two parts (major and minor) - of a version string. + /* + Get string of the first two parts (major and minor) + of a version string. - Example: - majorMinor "1.2.3" - => "1.2" + Example: + majorMinor "1.2.3" + => "1.2" */ - majorMinor = v: - builtins.concatStringsSep "." - (lib.take 2 (splitVersion v)); + majorMinor = v: builtins.concatStringsSep "." (lib.take 2 (splitVersion v)); - /* Pad a version string with zeros to match the given number of components. + /* + Pad a version string with zeros to match the given number of components. - Example: - pad 3 "1.2" - => "1.2.0" - pad 3 "1.3-rc1" - => "1.3.0-rc1" - pad 3 "1.2.3.4" - => "1.2.3" + Example: + pad 3 "1.2" + => "1.2.0" + pad 3 "1.3-rc1" + => "1.3.0-rc1" + pad 3 "1.2.3.4" + => "1.2.3" */ - pad = n: version: let - numericVersion = lib.head (lib.splitString "-" version); - versionSuffix = lib.removePrefix numericVersion version; - in lib.concatStringsSep "." (lib.take n (lib.splitVersion numericVersion ++ lib.genList (_: "0") n)) + versionSuffix; + pad = + n: version: + let + numericVersion = lib.head (lib.splitString "-" version); + versionSuffix = lib.removePrefix numericVersion version; + in + lib.concatStringsSep "." (lib.take n (lib.splitVersion numericVersion ++ lib.genList (_: "0") n)) + + versionSuffix; } diff --git a/maintainers/scripts/all-tarballs.nix b/maintainers/scripts/all-tarballs.nix index 83236e6fa91e98..df89012c603010 100644 --- a/maintainers/scripts/all-tarballs.nix +++ b/maintainers/scripts/all-tarballs.nix @@ -1,16 +1,17 @@ -/* Helper expression for copy-tarballs. This returns (nearly) all - tarballs used the free packages in Nixpkgs. +/* + Helper expression for copy-tarballs. This returns (nearly) all + tarballs used the free packages in Nixpkgs. - Typical usage: + Typical usage: - $ copy-tarballs.pl --expr 'import ' + $ copy-tarballs.pl --expr 'import ' */ -import ../../pkgs/top-level/release.nix - { # Don't apply ‘hydraJob’ to jobs, because then we can't get to the - # dependency graph. - scrubJobs = false; - # No need to evaluate on i686. - supportedSystems = [ "x86_64-linux" ]; - bootstrapConfigs = []; - } +import ../../pkgs/top-level/release.nix { + # Don't apply ‘hydraJob’ to jobs, because then we can't get to the + # dependency graph. + scrubJobs = false; + # No need to evaluate on i686. + supportedSystems = [ "x86_64-linux" ]; + bootstrapConfigs = [ ]; +} diff --git a/maintainers/scripts/build.nix b/maintainers/scripts/build.nix index 0783651df8f41b..969b72f6d80347 100644 --- a/maintainers/scripts/build.nix +++ b/maintainers/scripts/build.nix @@ -1,8 +1,11 @@ -{ maintainer -, localSystem ? { system = args.system or builtins.currentSystem; } -, system ? localSystem.system -, crossSystem ? localSystem -, ... +{ + maintainer, + localSystem ? { + system = args.system or builtins.currentSystem; + }, + system ? localSystem.system, + crossSystem ? localSystem, + ... }@args: # based on update.nix @@ -27,49 +30,51 @@ let file: if builtins.pathExists file then super._internalCallByNamePackageFile file else null; }; - nixpkgsArgs = removeAttrs args [ "maintainer" "overlays" ] // { - overlays = args.overlays or [] ++ [ overlay ]; - }; + nixpkgsArgs = + removeAttrs args [ + "maintainer" + "overlays" + ] + // { + overlays = args.overlays or [ ] ++ [ overlay ]; + }; pkgs = import ./../../default.nix nixpkgsArgs; maintainer_ = pkgs.lib.maintainers.${maintainer}; - packagesWith = cond: return: set: - (pkgs.lib.flatten - (pkgs.lib.mapAttrsToList - (name: pkg: - let - result = builtins.tryEval - ( - if pkgs.lib.isDerivation pkg && cond name pkg then - # Skip packages whose closure fails on evaluation. - # This happens for pkgs like `python27Packages.djangoql` - # that have disabled Python pkgs as dependencies. - builtins.seq pkg.outPath - [ (return name pkg) ] - else if pkg.recurseForDerivations or false || pkg.recurseForRelease or false - then packagesWith cond return pkg - else [ ] - ); - in - if result.success then result.value - else [ ] - ) - set - ) - ); + packagesWith = + cond: return: set: + (pkgs.lib.flatten ( + pkgs.lib.mapAttrsToList ( + name: pkg: + let + result = builtins.tryEval ( + if pkgs.lib.isDerivation pkg && cond name pkg then + # Skip packages whose closure fails on evaluation. + # This happens for pkgs like `python27Packages.djangoql` + # that have disabled Python pkgs as dependencies. + builtins.seq pkg.outPath [ (return name pkg) ] + else if pkg.recurseForDerivations or false || pkg.recurseForRelease or false then + packagesWith cond return pkg + else + [ ] + ); + in + if result.success then result.value else [ ] + ) set + )); in -packagesWith - (name: pkg: - ( - if builtins.hasAttr "meta" pkg && builtins.hasAttr "maintainers" pkg.meta - then ( - if builtins.isList pkg.meta.maintainers - then builtins.elem maintainer_ pkg.meta.maintainers - else maintainer_ == pkg.meta.maintainers +packagesWith ( + name: pkg: + ( + if builtins.hasAttr "meta" pkg && builtins.hasAttr "maintainers" pkg.meta then + ( + if builtins.isList pkg.meta.maintainers then + builtins.elem maintainer_ pkg.meta.maintainers + else + maintainer_ == pkg.meta.maintainers ) - else false - ) + else + false ) - (name: pkg: pkg) - pkgs +) (name: pkg: pkg) pkgs diff --git a/maintainers/scripts/check-hydra-by-maintainer.nix b/maintainers/scripts/check-hydra-by-maintainer.nix index c40729a3974ed5..21d5de48f9701e 100644 --- a/maintainers/scripts/check-hydra-by-maintainer.nix +++ b/maintainers/scripts/check-hydra-by-maintainer.nix @@ -5,48 +5,45 @@ let }; inherit (pkgs) lib; maintainer_ = pkgs.lib.maintainers.${maintainer}; - packagesWith = cond: return: prefix: set: - (lib.flatten - (lib.mapAttrsToList - (name: pkg: - let - result = builtins.tryEval - ( - if lib.isDerivation pkg && cond name pkg then - # Skip packages whose closure fails on evaluation. - # This happens for pkgs like `python27Packages.djangoql` - # that have disabled Python pkgs as dependencies. - builtins.seq pkg.outPath - [ (return "${prefix}${name}") ] - else if pkg.recurseForDerivations or false || pkg.recurseForRelease or false - # then packagesWith cond return pkg - then packagesWith cond return "${name}." pkg - else [ ] - ); - in - if result.success then result.value - else [ ] - ) - set - ) - ); + packagesWith = + cond: return: prefix: set: + (lib.flatten ( + lib.mapAttrsToList ( + name: pkg: + let + result = builtins.tryEval ( + if lib.isDerivation pkg && cond name pkg then + # Skip packages whose closure fails on evaluation. + # This happens for pkgs like `python27Packages.djangoql` + # that have disabled Python pkgs as dependencies. + builtins.seq pkg.outPath [ (return "${prefix}${name}") ] + else if + pkg.recurseForDerivations or false || pkg.recurseForRelease or false + # then packagesWith cond return pkg + then + packagesWith cond return "${name}." pkg + else + [ ] + ); + in + if result.success then result.value else [ ] + ) set + )); - packages = packagesWith - (name: pkg: - ( - if builtins.hasAttr "meta" pkg && builtins.hasAttr "maintainers" pkg.meta - then - ( - if builtins.isList pkg.meta.maintainers - then builtins.elem maintainer_ pkg.meta.maintainers - else maintainer_ == pkg.meta.maintainers - ) - else false - ) + packages = packagesWith ( + name: pkg: + ( + if builtins.hasAttr "meta" pkg && builtins.hasAttr "maintainers" pkg.meta then + ( + if builtins.isList pkg.meta.maintainers then + builtins.elem maintainer_ pkg.meta.maintainers + else + maintainer_ == pkg.meta.maintainers + ) + else + false ) - (name: name) - "" - pkgs; + ) (name: name) "" pkgs; in pkgs.stdenv.mkDerivation { diff --git a/maintainers/scripts/check-maintainers-sorted.nix b/maintainers/scripts/check-maintainers-sorted.nix index 3de4e07550c42e..606a72c0aa9bba 100644 --- a/maintainers/scripts/check-maintainers-sorted.nix +++ b/maintainers/scripts/check-maintainers-sorted.nix @@ -1,38 +1,68 @@ let lib = import ../../lib; inherit (lib) - add attrNames elemAt foldl' genList length replaceStrings sort toLower trace; + add + attrNames + elemAt + foldl' + genList + length + replaceStrings + sort + toLower + trace + ; maintainers = import ../maintainer-list.nix; simplify = replaceStrings [ "-" "_" ] [ "" "" ]; compare = a: b: simplify (toLower a) < simplify (toLower b); - namesSorted = - sort - (a: b: a.key < b.key) - (map - (n: let pos = builtins.unsafeGetAttrPos n maintainers; - in assert pos == null -> throw "maintainers entry ${n} is malformed"; - { name = n; line = pos.line; key = toLower (simplify n); }) - (attrNames maintainers)); - before = { name, line, key }: - foldl' - (acc: n: if n.key < key && (acc == null || n.key > acc.key) then n else acc) - null - namesSorted; - errors = foldl' add 0 - (map - (i: let a = elemAt namesSorted i; - b = elemAt namesSorted (i + 1); - lim = let t = before a; in if t == null then "the initial {" else t.name; - in if a.line >= b.line - then trace - ("maintainer ${a.name} (line ${toString a.line}) should be listed " - + "after ${lim}, not after ${b.name} (line ${toString b.line})") - 1 - else 0) - (genList (i: i) (length namesSorted - 1))); + namesSorted = sort (a: b: a.key < b.key) ( + map ( + n: + let + pos = builtins.unsafeGetAttrPos n maintainers; + in + assert pos == null -> throw "maintainers entry ${n} is malformed"; + { + name = n; + line = pos.line; + key = toLower (simplify n); + } + ) (attrNames maintainers) + ); + before = + { + name, + line, + key, + }: + foldl' ( + acc: n: if n.key < key && (acc == null || n.key > acc.key) then n else acc + ) null namesSorted; + errors = foldl' add 0 ( + map ( + i: + let + a = elemAt namesSorted i; + b = elemAt namesSorted (i + 1); + lim = + let + t = before a; + in + if t == null then "the initial {" else t.name; + in + if a.line >= b.line then + trace ( + "maintainer ${a.name} (line ${toString a.line}) should be listed " + + "after ${lim}, not after ${b.name} (line ${toString b.line})" + ) 1 + else + 0 + ) (genList (i: i) (length namesSorted - 1)) + ); in -assert errors == 0; "all good!" +assert errors == 0; +"all good!" # generate edit commands to sort the list. # may everything following the last current entry (closing } ff) in the wrong place diff --git a/maintainers/scripts/convert-to-import-cargo-lock/default.nix b/maintainers/scripts/convert-to-import-cargo-lock/default.nix index f4c1f553d64f9f..954ab840a6548a 100644 --- a/maintainers/scripts/convert-to-import-cargo-lock/default.nix +++ b/maintainers/scripts/convert-to-import-cargo-lock/default.nix @@ -5,7 +5,8 @@ rustPlatform.buildRustPackage { src = lib.cleanSourceWith { src = ./.; - filter = name: type: + filter = + name: type: let name' = builtins.baseNameOf name; in diff --git a/maintainers/scripts/eval-release.nix b/maintainers/scripts/eval-release.nix index fb830981683f3e..ad8baafd4b0d40 100644 --- a/maintainers/scripts/eval-release.nix +++ b/maintainers/scripts/eval-release.nix @@ -5,20 +5,36 @@ let trace = if builtins.getEnv "VERBOSE" == "1" then builtins.trace else (x: y: y); - rel = removeAttrs (import ../../pkgs/top-level/release.nix { }) [ "tarball" "unstable" ]; + rel = removeAttrs (import ../../pkgs/top-level/release.nix { }) [ + "tarball" + "unstable" + ]; # Add the ‘recurseForDerivations’ attribute to ensure that # nix-instantiate recurses into nested attribute sets. - recurse = path: attrs: + recurse = + path: attrs: if (builtins.tryEval attrs).success then - if isDerivation attrs - then - if (builtins.tryEval attrs.drvPath).success - then { inherit (attrs) name drvPath; } - else { failed = true; } - else if attrs == null then {} - else { recurseForDerivations = true; } // - mapAttrs (n: v: let path' = path ++ [n]; in trace path' (recurse path' v)) attrs - else { }; + if isDerivation attrs then + if (builtins.tryEval attrs.drvPath).success then + { inherit (attrs) name drvPath; } + else + { failed = true; } + else if attrs == null then + { } + else + { + recurseForDerivations = true; + } + // mapAttrs ( + n: v: + let + path' = path ++ [ n ]; + in + trace path' (recurse path' v) + ) attrs + else + { }; -in recurse [] rel +in +recurse [ ] rel diff --git a/maintainers/scripts/find-tarballs.nix b/maintainers/scripts/find-tarballs.nix index cae4bec201ce08..2de3cd1a093bd6 100644 --- a/maintainers/scripts/find-tarballs.nix +++ b/maintainers/scripts/find-tarballs.nix @@ -1,6 +1,9 @@ # This expression returns a list of all fetchurl calls used by ‘expr’. -{ expr, lib ? import ../../lib }: +{ + expr, + lib ? import ../../lib, +}: let inherit (lib) @@ -21,41 +24,82 @@ let root = expr; uniqueFiles = map (x: x.file) (genericClosure { - startSet = map (file: { key = with file; (if type == null then "" else type + "+") + hash; inherit file; }) files; + startSet = map (file: { + key = with file; (if type == null then "" else type + "+") + hash; + inherit file; + }) files; operator = const [ ]; }); - files = map (drv: { urls = drv.urls or [ drv.url ]; hash = drv.outputHash; isPatch = (drv?postFetch && drv.postFetch != ""); type = drv.outputHashAlgo; name = drv.name; }) fetchurlDependencies; + files = map (drv: { + urls = drv.urls or [ drv.url ]; + hash = drv.outputHash; + isPatch = (drv ? postFetch && drv.postFetch != ""); + type = drv.outputHashAlgo; + name = drv.name; + }) fetchurlDependencies; - fetchurlDependencies = - filter - (drv: drv.outputHash or "" != "" && drv.outputHashMode or "flat" == "flat" - && (drv ? url || drv ? urls)) - dependencies; + fetchurlDependencies = filter ( + drv: + drv.outputHash or "" != "" && drv.outputHashMode or "flat" == "flat" && (drv ? url || drv ? urls) + ) dependencies; dependencies = map (x: x.value) (genericClosure { startSet = map keyDrv (derivationsIn' root); operator = { key, value }: map keyDrv (immediateDependenciesOf value); }); - derivationsIn' = x: - if !canEval x then [] - else if isDerivation x then optional (canEval x.drvPath) x - else if isList x then concatLists (map derivationsIn' x) - else if isAttrs x then concatLists (mapAttrsToList (n: v: addErrorContext "while finding tarballs in '${n}':" (derivationsIn' v)) x) - else [ ]; + derivationsIn' = + x: + if !canEval x then + [ ] + else if isDerivation x then + optional (canEval x.drvPath) x + else if isList x then + concatLists (map derivationsIn' x) + else if isAttrs x then + concatLists ( + mapAttrsToList (n: v: addErrorContext "while finding tarballs in '${n}':" (derivationsIn' v)) x + ) + else + [ ]; - keyDrv = drv: if canEval drv.drvPath then { key = drv.drvPath; value = drv; } else { }; + keyDrv = + drv: + if canEval drv.drvPath then + { + key = drv.drvPath; + value = drv; + } + else + { }; - immediateDependenciesOf = drv: - concatLists (mapAttrsToList (n: v: derivationsIn v) (removeAttrs drv (["meta" "passthru"] ++ optionals (drv?passthru) (attrNames drv.passthru)))); + immediateDependenciesOf = + drv: + concatLists ( + mapAttrsToList (n: v: derivationsIn v) ( + removeAttrs drv ( + [ + "meta" + "passthru" + ] + ++ optionals (drv ? passthru) (attrNames drv.passthru) + ) + ) + ); - derivationsIn = x: - if !canEval x then [] - else if isDerivation x then optional (canEval x.drvPath) x - else if isList x then concatLists (map derivationsIn x) - else [ ]; + derivationsIn = + x: + if !canEval x then + [ ] + else if isDerivation x then + optional (canEval x.drvPath) x + else if isList x then + concatLists (map derivationsIn x) + else + [ ]; canEval = val: (builtins.tryEval val).success; -in uniqueFiles +in +uniqueFiles diff --git a/maintainers/scripts/haskell/dependencies.nix b/maintainers/scripts/haskell/dependencies.nix index 5965b1ba182847..718e626f786006 100644 --- a/maintainers/scripts/haskell/dependencies.nix +++ b/maintainers/scripts/haskell/dependencies.nix @@ -1,12 +1,17 @@ # Nix script to calculate the Haskell dependencies of every haskellPackage. Used by ./hydra-report.hs. let - pkgs = import ../../.. {}; + pkgs = import ../../.. { }; inherit (pkgs) lib; - getDeps = _: pkg: let - pname = pkg.pname or null; - in { - deps = builtins.filter (x: x != null && x != pname) (map (x: x.pname or null) (pkg.propagatedBuildInputs or [])); - broken = (pkg.meta.hydraPlatforms or [null]) == []; - }; + getDeps = + _: pkg: + let + pname = pkg.pname or null; + in + { + deps = builtins.filter (x: x != null && x != pname) ( + map (x: x.pname or null) (pkg.propagatedBuildInputs or [ ]) + ); + broken = (pkg.meta.hydraPlatforms or [ null ]) == [ ]; + }; in - lib.mapAttrs getDeps pkgs.haskellPackages +lib.mapAttrs getDeps pkgs.haskellPackages diff --git a/maintainers/scripts/haskell/maintained-broken-pkgs.nix b/maintainers/scripts/haskell/maintained-broken-pkgs.nix index 7416bfa46ee0de..b4ee9420ee8828 100644 --- a/maintainers/scripts/haskell/maintained-broken-pkgs.nix +++ b/maintainers/scripts/haskell/maintained-broken-pkgs.nix @@ -1,15 +1,20 @@ let nixpkgs = import ../../..; - inherit (nixpkgs {}) haskellPackages lib; + inherit (nixpkgs { }) haskellPackages lib; maintainedPkgs = lib.filterAttrs ( - _: v: builtins.length (v.meta.maintainers or []) > 0 + _: v: builtins.length (v.meta.maintainers or [ ]) > 0 ) haskellPackages; brokenPkgs = lib.filterAttrs (_: v: v.meta.broken) maintainedPkgs; - transitiveBrokenPkgs = lib.filterAttrs - (_: v: !(builtins.tryEval (v.outPath or null)).success && !v.meta.broken) - maintainedPkgs; - infoList = pkgs: lib.concatStringsSep "\n" (lib.mapAttrsToList (name: drv: "${name} ${(builtins.elemAt drv.meta.maintainers 0).github}") pkgs); -in { + transitiveBrokenPkgs = lib.filterAttrs ( + _: v: !(builtins.tryEval (v.outPath or null)).success && !v.meta.broken + ) maintainedPkgs; + infoList = + pkgs: + lib.concatStringsSep "\n" ( + lib.mapAttrsToList (name: drv: "${name} ${(builtins.elemAt drv.meta.maintainers 0).github}") pkgs + ); +in +{ report = '' BROKEN: ${infoList brokenPkgs} @@ -17,6 +22,5 @@ in { TRANSITIVE BROKEN: ${infoList transitiveBrokenPkgs} ''; - transitiveErrors = - builtins.attrValues transitiveBrokenPkgs; + transitiveErrors = builtins.attrValues transitiveBrokenPkgs; } diff --git a/maintainers/scripts/haskell/maintainer-handles.nix b/maintainers/scripts/haskell/maintainer-handles.nix index d650e82f8b0c1e..ced93a1233be18 100644 --- a/maintainers/scripts/haskell/maintainer-handles.nix +++ b/maintainers/scripts/haskell/maintainer-handles.nix @@ -10,12 +10,14 @@ # This mapping contains all maintainers in ../../mainatainer-list.nix, but it # ignores maintainers who don't have a GitHub account or an email address. let - pkgs = import ../../.. {}; + pkgs = import ../../.. { }; maintainers = import ../../maintainer-list.nix; inherit (pkgs) lib; - mkMailGithubPair = _: maintainer: + mkMailGithubPair = + _: maintainer: if (maintainer ? email) && (maintainer ? github) then { "${maintainer.email}" = maintainer.github; } else - {}; -in lib.zipAttrsWith (_: builtins.head) (lib.mapAttrsToList mkMailGithubPair maintainers) + { }; +in +lib.zipAttrsWith (_: builtins.head) (lib.mapAttrsToList mkMailGithubPair maintainers) diff --git a/maintainers/scripts/haskell/test-configurations.nix b/maintainers/scripts/haskell/test-configurations.nix index 8473ed4db8a2c1..94fb4c1e950e6e 100644 --- a/maintainers/scripts/haskell/test-configurations.nix +++ b/maintainers/scripts/haskell/test-configurations.nix @@ -1,60 +1,63 @@ -/* Nix expression to test for regressions in the Haskell configuration overlays. +/* + Nix expression to test for regressions in the Haskell configuration overlays. - test-configurations.nix determines all attributes touched by given Haskell - configuration overlays (i. e. pkgs/development/haskell-modules/configuration-*.nix) - and builds all derivations (or at least a reasonable subset) affected by - these overrides. + test-configurations.nix determines all attributes touched by given Haskell + configuration overlays (i. e. pkgs/development/haskell-modules/configuration-*.nix) + and builds all derivations (or at least a reasonable subset) affected by + these overrides. - By default, it checks `configuration-{common,nix,ghc-8.10.x}.nix`. You can - invoke it like this: + By default, it checks `configuration-{common,nix,ghc-8.10.x}.nix`. You can + invoke it like this: - nix-build maintainers/scripts/haskell/test-configurations.nix --keep-going + nix-build maintainers/scripts/haskell/test-configurations.nix --keep-going - It is possible to specify other configurations: + It is possible to specify other configurations: - nix-build maintainers/scripts/haskell/test-configurations.nix \ - --arg files '[ "configuration-ghc-9.0.x.nix" "configuration-ghc-9.2.x.nix" ]' \ - --keep-going + nix-build maintainers/scripts/haskell/test-configurations.nix \ + --arg files '[ "configuration-ghc-9.0.x.nix" "configuration-ghc-9.2.x.nix" ]' \ + --keep-going - You can also just supply a single string: + You can also just supply a single string: - nix-build maintainers/scripts/haskell/test-configurations.nix \ - --argstr files "configuration-arm.nix" --keep-going + nix-build maintainers/scripts/haskell/test-configurations.nix \ + --argstr files "configuration-arm.nix" --keep-going - You can even supply full paths which is handy, as it allows for tab-completing - the configurations: + You can even supply full paths which is handy, as it allows for tab-completing + the configurations: - nix-build maintainers/scripts/haskell/test-configurations.nix \ - --argstr files pkgs/development/haskell-modules/configuration-arm.nix \ - --keep-going + nix-build maintainers/scripts/haskell/test-configurations.nix \ + --argstr files pkgs/development/haskell-modules/configuration-arm.nix \ + --keep-going - By default, derivation that fail to evaluate are skipped, unless they are - “just” marked as broken. You can check for other eval errors like this: + By default, derivation that fail to evaluate are skipped, unless they are + “just” marked as broken. You can check for other eval errors like this: - nix-build maintainers/scripts/haskell/test-configurations.nix \ - --arg skipEvalErrors false --keep-going + nix-build maintainers/scripts/haskell/test-configurations.nix \ + --arg skipEvalErrors false --keep-going - You can also disable checking broken packages by passing a nixpkgs config: + You can also disable checking broken packages by passing a nixpkgs config: - nix-build maintainers/scripts/haskell/test-configurations.nix \ - --arg config '{ allowBroken = false; }' --keep-going + nix-build maintainers/scripts/haskell/test-configurations.nix \ + --arg config '{ allowBroken = false; }' --keep-going - By default the haskell.packages.ghc*Binary sets used for bootstrapping GHC - are _not_ tested. You can change this using: - - nix-build maintainers/scripts/haskell/test-configurations.nix \ - --arg skipBinaryGHCs false --keep-going + By default the haskell.packages.ghc*Binary sets used for bootstrapping GHC + are _not_ tested. You can change this using: + nix-build maintainers/scripts/haskell/test-configurations.nix \ + --arg skipBinaryGHCs false --keep-going */ -{ files ? [ +{ + files ? [ "configuration-common.nix" "configuration-nix.nix" "configuration-ghc-8.10.x.nix" - ] -, nixpkgsPath ? ../../.. -, config ? { allowBroken = true; } -, skipEvalErrors ? true -, skipBinaryGHCs ? true + ], + nixpkgsPath ? ../../.., + config ? { + allowBroken = true; + }, + skipEvalErrors ? true, + skipBinaryGHCs ? true, }: let @@ -62,97 +65,99 @@ let inherit (pkgs) lib; # see usage explanation for the input format `files` allows - files' = builtins.map builtins.baseNameOf ( - if !builtins.isList files then [ files ] else files - ); + files' = builtins.map builtins.baseNameOf (if !builtins.isList files then [ files ] else files); - packageSetsWithVersionedHead = pkgs.haskell.packages // ( - let - headSet = pkgs.haskell.packages.ghcHEAD; - # Determine the next GHC release version following GHC HEAD. - # GHC HEAD always has an uneven, tentative version number, e.g. 9.7. - # GHC releases always have even numbers, i.e. GHC 9.8 is branched off from - # GHC HEAD 9.7. Since we use the to be release number for GHC HEAD's - # configuration file, we need to calculate this here. - headVersion = lib.pipe headSet.ghc.version [ - lib.versions.splitVersion - (lib.take 2) - lib.concatStrings - lib.strings.toInt - (builtins.add 1) - toString - ]; - in - { - "ghc${headVersion}" = headSet; - } - ); + packageSetsWithVersionedHead = + pkgs.haskell.packages + // ( + let + headSet = pkgs.haskell.packages.ghcHEAD; + # Determine the next GHC release version following GHC HEAD. + # GHC HEAD always has an uneven, tentative version number, e.g. 9.7. + # GHC releases always have even numbers, i.e. GHC 9.8 is branched off from + # GHC HEAD 9.7. Since we use the to be release number for GHC HEAD's + # configuration file, we need to calculate this here. + headVersion = lib.pipe headSet.ghc.version [ + lib.versions.splitVersion + (lib.take 2) + lib.concatStrings + lib.strings.toInt + (builtins.add 1) + toString + ]; + in + { + "ghc${headVersion}" = headSet; + } + ); - setsForFile = fileName: + setsForFile = + fileName: let # extract the unique part of the config's file name - configName = builtins.head ( - builtins.match "configuration-(.+).nix" fileName - ); + configName = builtins.head (builtins.match "configuration-(.+).nix" fileName); # match the major and minor version of the GHC the config is intended for, if any - configVersion = lib.concatStrings ( - builtins.match "ghc-([0-9]+).([0-9]+).x" configName - ); + configVersion = lib.concatStrings (builtins.match "ghc-([0-9]+).([0-9]+).x" configName); # return all package sets under haskell.packages matching the version components - setsForVersion = builtins.map (name: packageSetsWithVersionedHead.${name}) ( - builtins.filter (setName: - lib.hasPrefix "ghc${configVersion}" setName - && (skipBinaryGHCs -> !(lib.hasInfix "Binary" setName)) - ) ( - builtins.attrNames packageSetsWithVersionedHead - ) + setsForVersion = builtins.map (name: packageSetsWithVersionedHead.${name}) ( + builtins.filter ( + setName: + lib.hasPrefix "ghc${configVersion}" setName && (skipBinaryGHCs -> !(lib.hasInfix "Binary" setName)) + ) (builtins.attrNames packageSetsWithVersionedHead) ); defaultSets = [ pkgs.haskellPackages ]; - in { + in + { # use plain haskellPackages for the version-agnostic files # TODO(@sternenseemann): also consider currently selected versioned sets "common" = defaultSets; "nix" = defaultSets; "arm" = defaultSets; "darwin" = defaultSets; - }.${configName} or setsForVersion; + } + .${configName} or setsForVersion; # attribute set that has all the attributes of haskellPackages set to null availableHaskellPackages = builtins.listToAttrs ( - builtins.map (attr: lib.nameValuePair attr null) ( - builtins.attrNames pkgs.haskellPackages - ) + builtins.map (attr: lib.nameValuePair attr null) (builtins.attrNames pkgs.haskellPackages) ); # evaluate a configuration and only return the attributes changed by it, # pass availableHaskellPackages as super in case intersectAttrs is used - overriddenAttrs = fileName: builtins.attrNames ( - lib.fix (self: - import (nixpkgsPath + "/pkgs/development/haskell-modules/${fileName}") { - haskellLib = pkgs.haskell.lib.compose; - inherit pkgs; - } self availableHaskellPackages - ) - ); + overriddenAttrs = + fileName: + builtins.attrNames ( + lib.fix ( + self: + import (nixpkgsPath + "/pkgs/development/haskell-modules/${fileName}") { + haskellLib = pkgs.haskell.lib.compose; + inherit pkgs; + } self availableHaskellPackages + ) + ); # list of derivations that are affected by overrides in the given configuration # overlays. For common, nix, darwin etc. only the derivation from the default # package set will be emitted. - packages = builtins.filter (v: - lib.warnIf (v.meta.broken or false) "${v.pname} is marked as broken" ( - v != null - && (skipEvalErrors -> (builtins.tryEval (v.outPath or v)).success) - ) - ) ( - lib.concatMap (fileName: - let - sets = setsForFile fileName; - attrs = overriddenAttrs fileName; - in - lib.concatMap (set: builtins.map (attr: set.${attr}) attrs) sets - ) files' - ); + packages = + builtins.filter + ( + v: + lib.warnIf (v.meta.broken or false) "${v.pname} is marked as broken" ( + v != null && (skipEvalErrors -> (builtins.tryEval (v.outPath or v)).success) + ) + ) + ( + lib.concatMap ( + fileName: + let + sets = setsForFile fileName; + attrs = overriddenAttrs fileName; + in + lib.concatMap (set: builtins.map (attr: set.${attr}) attrs) sets + ) files' + ); in packages diff --git a/maintainers/scripts/haskell/transitive-broken-packages.nix b/maintainers/scripts/haskell/transitive-broken-packages.nix index 50ccb14577bc16..f4a69e6e69a276 100644 --- a/maintainers/scripts/haskell/transitive-broken-packages.nix +++ b/maintainers/scripts/haskell/transitive-broken-packages.nix @@ -1,15 +1,16 @@ let nixpkgs = import ../../..; - inherit (nixpkgs {}) pkgs lib; - getEvaluating = x: + inherit (nixpkgs { }) pkgs lib; + getEvaluating = + x: builtins.attrNames ( lib.filterAttrs ( _: v: (builtins.tryEval (v.outPath or null)).success && lib.isDerivation v && !v.meta.broken ) x ); - brokenDeps = lib.subtractLists - (getEvaluating pkgs.haskellPackages) - (getEvaluating (nixpkgs { config.allowBroken = true; }).haskellPackages); + brokenDeps = lib.subtractLists (getEvaluating pkgs.haskellPackages) ( + getEvaluating (nixpkgs { config.allowBroken = true; }).haskellPackages + ); in '' ${lib.concatMapStringsSep "\n" (x: " - ${x}") brokenDeps} diff --git a/maintainers/scripts/nix-generate-from-cpan.nix b/maintainers/scripts/nix-generate-from-cpan.nix index a8135f4b304a89..c05dedc205df43 100644 --- a/maintainers/scripts/nix-generate-from-cpan.nix +++ b/maintainers/scripts/nix-generate-from-cpan.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, makeWrapper, perl, perlPackages }: +{ + stdenv, + lib, + makeWrapper, + perl, + perlPackages, +}: stdenv.mkDerivation { name = "nix-generate-from-cpan-3"; @@ -6,7 +12,11 @@ stdenv.mkDerivation { nativeBuildInputs = [ makeWrapper ]; buildInputs = with perlPackages; [ - perl GetoptLongDescriptive CPANPLUS Readonly LogLog4perl + perl + GetoptLongDescriptive + CPANPLUS + Readonly + LogLog4perl ]; dontUnpack = true; diff --git a/maintainers/scripts/nixpkgs-lint.nix b/maintainers/scripts/nixpkgs-lint.nix index 979ec286d8090c..8c67c4b6edb188 100644 --- a/maintainers/scripts/nixpkgs-lint.nix +++ b/maintainers/scripts/nixpkgs-lint.nix @@ -1,24 +1,32 @@ -{ stdenv, lib, makeWrapper, perl, perlPackages }: +{ + stdenv, + lib, + makeWrapper, + perl, + perlPackages, +}: stdenv.mkDerivation { pname = "nixpkgs-lint"; version = "1"; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ perl perlPackages.XMLSimple ]; + buildInputs = [ + perl + perlPackages.XMLSimple + ]; dontUnpack = true; dontBuild = true; - installPhase = - '' - mkdir -p $out/bin - cp ${./nixpkgs-lint.pl} $out/bin/nixpkgs-lint - # make the built version hermetic - substituteInPlace $out/bin/nixpkgs-lint \ - --replace-fail "#! /usr/bin/env nix-shell" "#! ${lib.getExe perl}" - wrapProgram $out/bin/nixpkgs-lint --set PERL5LIB $PERL5LIB - ''; + installPhase = '' + mkdir -p $out/bin + cp ${./nixpkgs-lint.pl} $out/bin/nixpkgs-lint + # make the built version hermetic + substituteInPlace $out/bin/nixpkgs-lint \ + --replace-fail "#! /usr/bin/env nix-shell" "#! ${lib.getExe perl}" + wrapProgram $out/bin/nixpkgs-lint --set PERL5LIB $PERL5LIB + ''; meta = with lib; { maintainers = [ maintainers.eelco ]; diff --git a/maintainers/scripts/update-octave-shell.nix b/maintainers/scripts/update-octave-shell.nix index 51d4844c79f342..e7b6332dfb1e00 100644 --- a/maintainers/scripts/update-octave-shell.nix +++ b/maintainers/scripts/update-octave-shell.nix @@ -1,8 +1,16 @@ -{ nixpkgs ? import ../.. { } +{ + nixpkgs ? import ../.. { }, }: with nixpkgs; let - pyEnv = python3.withPackages(ps: with ps; [ packaging requests toolz pyyaml ]); + pyEnv = python3.withPackages ( + ps: with ps; [ + packaging + requests + toolz + pyyaml + ] + ); in mkShell { packages = [ diff --git a/maintainers/scripts/update.nix b/maintainers/scripts/update.nix index 3af728d46ea481..05fcd6f12d2e29 100644 --- a/maintainers/scripts/update.nix +++ b/maintainers/scripts/update.nix @@ -5,42 +5,50 @@ See https://nixos.org/manual/nixpkgs/unstable/#var-passthru-updateScript */ -{ package ? null -, maintainer ? null -, predicate ? null -, get-script ? pkg: pkg.updateScript or null -, path ? null -, max-workers ? null -, include-overlays ? false -, keep-going ? null -, commit ? null -, skip-prompt ? null +{ + package ? null, + maintainer ? null, + predicate ? null, + get-script ? pkg: pkg.updateScript or null, + path ? null, + max-workers ? null, + include-overlays ? false, + keep-going ? null, + commit ? null, + skip-prompt ? null, }: let - pkgs = import ./../../default.nix (( - if include-overlays == false then - { overlays = []; } - else if include-overlays == true then - { } # Let Nixpkgs include overlays impurely. - else { overlays = include-overlays; } - ) // { config.allowAliases = false; }); + pkgs = import ./../../default.nix ( + ( + if include-overlays == false then + { overlays = [ ]; } + else if include-overlays == true then + { } # Let Nixpkgs include overlays impurely. + else + { overlays = include-overlays; } + ) + // { + config.allowAliases = false; + } + ); inherit (pkgs) lib; - /* Remove duplicate elements from the list based on some extracted value. O(n^2) complexity. - */ - nubOn = f: list: - if list == [] then - [] + # Remove duplicate elements from the list based on some extracted value. O(n^2) complexity. + nubOn = + f: list: + if list == [ ] then + [ ] else let x = lib.head list; xs = lib.filter (p: f x != f p) (lib.drop 1 list); in - [x] ++ nubOn f xs; + [ x ] ++ nubOn f xs; - /* Recursively find all packages (derivations) in `pkgs` matching `cond` predicate. + /* + Recursively find all packages (derivations) in `pkgs` matching `cond` predicate. Type: packagesWithPath :: AttrPath → (AttrPath → derivation → bool) → AttrSet → List AttrPath :: [str] @@ -48,15 +56,18 @@ let The packages will be returned as a list of named pairs comprising of: - attrPath: stringified attribute path (based on `rootPath`) - package: corresponding derivation - */ - packagesWithPath = rootPath: cond: pkgs: + */ + packagesWithPath = + rootPath: cond: pkgs: let - packagesWithPathInner = path: pathContent: + packagesWithPathInner = + path: pathContent: let result = builtins.tryEval pathContent; somewhatUniqueRepresentant = - { package, attrPath }: { + { package, attrPath }: + { updateScript = (get-script package); # Some updaters use the same `updateScript` value for all packages. # Also compare `meta.description`. @@ -67,79 +78,95 @@ let dedupResults = lst: nubOn somewhatUniqueRepresentant (lib.concatLists lst); in - if result.success then - let - evaluatedPathContent = result.value; - in - if lib.isDerivation evaluatedPathContent then - lib.optional (cond path evaluatedPathContent) { attrPath = lib.concatStringsSep "." path; package = evaluatedPathContent; } - else if lib.isAttrs evaluatedPathContent then - # If user explicitly points to an attrSet or it is marked for recursion, we recur. - if path == rootPath || evaluatedPathContent.recurseForDerivations or false || evaluatedPathContent.recurseForRelease or false then - dedupResults (lib.mapAttrsToList (name: elem: packagesWithPathInner (path ++ [name]) elem) evaluatedPathContent) - else [] - else [] - else []; + if result.success then + let + evaluatedPathContent = result.value; + in + if lib.isDerivation evaluatedPathContent then + lib.optional (cond path evaluatedPathContent) { + attrPath = lib.concatStringsSep "." path; + package = evaluatedPathContent; + } + else if lib.isAttrs evaluatedPathContent then + # If user explicitly points to an attrSet or it is marked for recursion, we recur. + if + path == rootPath + || evaluatedPathContent.recurseForDerivations or false + || evaluatedPathContent.recurseForRelease or false + then + dedupResults ( + lib.mapAttrsToList (name: elem: packagesWithPathInner (path ++ [ name ]) elem) evaluatedPathContent + ) + else + [ ] + else + [ ] + else + [ ]; in - packagesWithPathInner rootPath pkgs; + packagesWithPathInner rootPath pkgs; - /* Recursively find all packages (derivations) in `pkgs` matching `cond` predicate. - */ - packagesWith = packagesWithPath []; + # Recursively find all packages (derivations) in `pkgs` matching `cond` predicate. + packagesWith = packagesWithPath [ ]; - /* Recursively find all packages in `pkgs` with updateScript matching given predicate. - */ - packagesWithUpdateScriptMatchingPredicate = cond: - packagesWith (path: pkg: (get-script pkg != null) && cond path pkg); + # Recursively find all packages in `pkgs` with updateScript matching given predicate. + packagesWithUpdateScriptMatchingPredicate = + cond: packagesWith (path: pkg: (get-script pkg != null) && cond path pkg); - /* Recursively find all packages in `pkgs` with updateScript by given maintainer. - */ - packagesWithUpdateScriptAndMaintainer = maintainer': + # Recursively find all packages in `pkgs` with updateScript by given maintainer. + packagesWithUpdateScriptAndMaintainer = + maintainer': let maintainer = - if ! builtins.hasAttr maintainer' lib.maintainers then + if !builtins.hasAttr maintainer' lib.maintainers then builtins.throw "Maintainer with name `${maintainer'} does not exist in `maintainers/maintainer-list.nix`." else builtins.getAttr maintainer' lib.maintainers; in - packagesWithUpdateScriptMatchingPredicate (path: pkg: - (if builtins.hasAttr "maintainers" pkg.meta - then (if builtins.isList pkg.meta.maintainers - then builtins.elem maintainer pkg.meta.maintainers - else maintainer == pkg.meta.maintainers - ) - else false - ) - ); - - /* Recursively find all packages under `path` in `pkgs` with updateScript. - */ - packagesWithUpdateScript = path: pkgs: + packagesWithUpdateScriptMatchingPredicate ( + path: pkg: + ( + if builtins.hasAttr "maintainers" pkg.meta then + ( + if builtins.isList pkg.meta.maintainers then + builtins.elem maintainer pkg.meta.maintainers + else + maintainer == pkg.meta.maintainers + ) + else + false + ) + ); + + # Recursively find all packages under `path` in `pkgs` with updateScript. + packagesWithUpdateScript = + path: pkgs: let prefix = lib.splitString "." path; pathContent = lib.attrByPath prefix null pkgs; in - if pathContent == null then - builtins.throw "Attribute path `${path}` does not exist." - else - packagesWithPath prefix (path: pkg: (get-script pkg != null)) - pathContent; + if pathContent == null then + builtins.throw "Attribute path `${path}` does not exist." + else + packagesWithPath prefix (path: pkg: (get-script pkg != null)) pathContent; - /* Find a package under `path` in `pkgs` and require that it has an updateScript. - */ - packageByName = path: pkgs: + # Find a package under `path` in `pkgs` and require that it has an updateScript. + packageByName = + path: pkgs: let - package = lib.attrByPath (lib.splitString "." path) null pkgs; + package = lib.attrByPath (lib.splitString "." path) null pkgs; in - if package == null then - builtins.throw "Package with an attribute name `${path}` does not exist." - else if get-script package == null then - builtins.throw "Package with an attribute name `${path}` does not have a `passthru.updateScript` attribute defined." - else - { attrPath = path; inherit package; }; + if package == null then + builtins.throw "Package with an attribute name `${path}` does not exist." + else if get-script package == null then + builtins.throw "Package with an attribute name `${path}` does not have a `passthru.updateScript` attribute defined." + else + { + attrPath = path; + inherit package; + }; - /* List of packages matched based on the CLI arguments. - */ + # List of packages matched based on the CLI arguments. packages = if package != null then [ (packageByName package pkgs) ] @@ -192,19 +219,22 @@ let --argstr skip-prompt true ''; - /* Transform a matched package into an object for update.py. - */ - packageData = { package, attrPath }: let updateScript = get-script package; in { - name = package.name; - pname = lib.getName package; - oldVersion = lib.getVersion package; - updateScript = map builtins.toString (lib.toList (updateScript.command or updateScript)); - supportedFeatures = updateScript.supportedFeatures or []; - attrPath = updateScript.attrPath or attrPath; - }; - - /* JSON file with data for update.py. - */ + # Transform a matched package into an object for update.py. + packageData = + { package, attrPath }: + let + updateScript = get-script package; + in + { + name = package.name; + pname = lib.getName package; + oldVersion = lib.getVersion package; + updateScript = map builtins.toString (lib.toList (updateScript.command or updateScript)); + supportedFeatures = updateScript.supportedFeatures or [ ]; + attrPath = updateScript.attrPath or attrPath; + }; + + # JSON file with data for update.py. packagesJson = pkgs.writeText "packages.json" (builtins.toJSON (map packageData packages)); optionalArgs = @@ -215,7 +245,8 @@ let args = [ packagesJson ] ++ optionalArgs; -in pkgs.stdenv.mkDerivation { +in +pkgs.stdenv.mkDerivation { name = "nixpkgs-update-script"; buildCommand = '' echo "" @@ -231,5 +262,9 @@ in pkgs.stdenv.mkDerivation { unset shellHook # do not contaminate nested shells exec ${pkgs.python3.interpreter} ${./update.py} ${builtins.concatStringsSep " " args} ''; - nativeBuildInputs = [ pkgs.git pkgs.nix pkgs.cacert ]; + nativeBuildInputs = [ + pkgs.git + pkgs.nix + pkgs.cacert + ]; } diff --git a/nixos/default.nix b/nixos/default.nix index 6beb4cd3a7df7c..f338e13fadb052 100644 --- a/nixos/default.nix +++ b/nixos/default.nix @@ -1,5 +1,6 @@ -{ configuration ? import ./lib/from-env.nix "NIXOS_CONFIG" -, system ? builtins.currentSystem +{ + configuration ? import ./lib/from-env.nix "NIXOS_CONFIG" , + system ? builtins.currentSystem, }: let diff --git a/nixos/lib/default.nix b/nixos/lib/default.nix index 65d91342d4d158..c6970b05514e68 100644 --- a/nixos/lib/default.nix +++ b/nixos/lib/default.nix @@ -4,12 +4,13 @@ let inherit (nonExtendedLib) warn; nonExtendedLib = import ../../lib; in -{ # Optional. Allows an extended `lib` to be used instead of the regular Nixpkgs lib. +{ + # Optional. Allows an extended `lib` to be used instead of the regular Nixpkgs lib. lib ? nonExtendedLib, # Feature flags allow you to opt in to unfinished code. These may change some # behavior or disable warnings. - featureFlags ? {}, + featureFlags ? { }, # This file itself is rather new, so we accept unknown parameters to be forward # compatible. This is generally not recommended, because typos go undetected. @@ -29,7 +30,7 @@ in using a binding like `nixosLib = import (nixpkgs + "/nixos/lib") { }`. */ { - inherit (seqAttrsIf (!featureFlags?minimalModules) minimalModulesWarning eval-config-minimal) + inherit (seqAttrsIf (!featureFlags ? minimalModules) minimalModulesWarning eval-config-minimal) evalModules ; diff --git a/nixos/lib/eval-cacheable-options.nix b/nixos/lib/eval-cacheable-options.nix index d26967ebe09b8f..73cf5eda32ec06 100644 --- a/nixos/lib/eval-cacheable-options.nix +++ b/nixos/lib/eval-cacheable-options.nix @@ -1,9 +1,10 @@ -{ libPath -, pkgsLibPath -, nixosPath -, modules -, stateVersion -, release +{ + libPath, + pkgsLibPath, + nixosPath, + modules, + stateVersion, + release, }: let @@ -24,7 +25,7 @@ let # unusable. this causes documentation attributes depending on `config` to fail. config = { _module.check = false; - _module.args = {}; + _module.args = { }; system.stateVersion = stateVersion; }; eval = lib.evalModules { @@ -40,9 +41,8 @@ let pkgs = pkgs // { inherit lib; # duplicate of the declaration in all-packages.nix - buildPackages.nixosOptionsDoc = attrs: - (import "${nixosPath}/lib/make-options-doc") - ({ inherit pkgs lib; } // attrs); + buildPackages.nixosOptionsDoc = + attrs: (import "${nixosPath}/lib/make-options-doc") ({ inherit pkgs lib; } // attrs); }; config = config.config; options = eval.options; @@ -51,4 +51,4 @@ let prefix = modulesPath; }; in - docs.optionsNix +docs.optionsNix diff --git a/nixos/lib/eval-config-minimal.nix b/nixos/lib/eval-config-minimal.nix index 036389121973d4..63c2aedc87a978 100644 --- a/nixos/lib/eval-config-minimal.nix +++ b/nixos/lib/eval-config-minimal.nix @@ -1,4 +1,3 @@ - # DO NOT IMPORT. Use nixpkgsFlake.lib.nixos, or import (nixpkgs + "/nixos/lib") { lib }: # read -^ @@ -25,24 +24,24 @@ let An attribute set containing `config.system.build.toplevel` among other attributes. See `lib.evalModules` in the Nixpkgs library. - - */ - evalModules = { - prefix ? [], - modules ? [], - specialArgs ? {}, - }: - # NOTE: Regular NixOS currently does use this function! Don't break it! - # Ideally we don't diverge, unless we learn that we should. - # In other words, only the public interface of nixos.evalModules - # is experimental. - lib.evalModules { - inherit prefix modules; - class = "nixos"; - specialArgs = { - modulesPath = builtins.toString ../modules; - } // specialArgs; - }; + */ + evalModules = + { + prefix ? [ ], + modules ? [ ], + specialArgs ? { }, + }: + # NOTE: Regular NixOS currently does use this function! Don't break it! + # Ideally we don't diverge, unless we learn that we should. + # In other words, only the public interface of nixos.evalModules + # is experimental. + lib.evalModules { + inherit prefix modules; + class = "nixos"; + specialArgs = { + modulesPath = builtins.toString ../modules; + } // specialArgs; + }; in { diff --git a/nixos/lib/from-env.nix b/nixos/lib/from-env.nix index 6bd71e40e9a1ab..8afca8468058ba 100644 --- a/nixos/lib/from-env.nix +++ b/nixos/lib/from-env.nix @@ -1,4 +1,6 @@ # TODO: remove this file. There is lib.maybeEnv now name: default: -let value = builtins.getEnv name; in +let + value = builtins.getEnv name; +in if value == "" then default else value diff --git a/nixos/lib/make-channel.nix b/nixos/lib/make-channel.nix index 0a511468fb2db7..e366006e908ca6 100644 --- a/nixos/lib/make-channel.nix +++ b/nixos/lib/make-channel.nix @@ -1,8 +1,14 @@ -/* Build a channel tarball. These contain, in addition to the nixpkgs - * expressions themselves, files that indicate the version of nixpkgs - * that they represent. - */ -{ pkgs, nixpkgs, version, versionSuffix }: +/* + Build a channel tarball. These contain, in addition to the nixpkgs + expressions themselves, files that indicate the version of nixpkgs + that they represent. +*/ +{ + pkgs, + nixpkgs, + version, + versionSuffix, +}: pkgs.releaseTools.makeSourceTarball { name = "nixos-channel"; diff --git a/nixos/lib/make-ext4-fs.nix b/nixos/lib/make-ext4-fs.nix index 8afc5555ced465..5aa90aacf72e13 100644 --- a/nixos/lib/make-ext4-fs.nix +++ b/nixos/lib/make-ext4-fs.nix @@ -3,21 +3,23 @@ # contents of a directory that can be populated with commands. The # generated image is sized to only fit its contents, with the expectation # that a script resizes the filesystem at boot time. -{ pkgs -, lib -# List of derivations to be included -, storePaths -# Whether or not to compress the resulting image with zstd -, compressImage ? false, zstd -# Shell commands to populate the ./files directory. -# All files in that directory are copied to the root of the FS. -, populateImageCommands ? "" -, volumeLabel -, uuid ? "44444444-4444-4444-8888-888888888888" -, e2fsprogs -, libfaketime -, perl -, fakeroot +{ + pkgs, + lib, + # List of derivations to be included + storePaths, + # Whether or not to compress the resulting image with zstd + compressImage ? false, + zstd, + # Shell commands to populate the ./files directory. + # All files in that directory are copied to the root of the FS. + populateImageCommands ? "", + volumeLabel, + uuid ? "44444444-4444-4444-8888-888888888888", + e2fsprogs, + libfaketime, + perl, + fakeroot, }: let @@ -26,78 +28,81 @@ in pkgs.stdenv.mkDerivation { name = "ext4-fs.img${lib.optionalString compressImage ".zst"}"; - nativeBuildInputs = [ e2fsprogs.bin libfaketime perl fakeroot ] - ++ lib.optional compressImage zstd; - - buildCommand = - '' - ${if compressImage then "img=temp.img" else "img=$out"} - ( - mkdir -p ./files - ${populateImageCommands} - ) - - echo "Preparing store paths for image..." - - # Create nix/store before copying path - mkdir -p ./rootImage/nix/store - - xargs -I % cp -a --reflink=auto % -t ./rootImage/nix/store/ < ${sdClosureInfo}/store-paths - ( - GLOBIGNORE=".:.." - shopt -u dotglob - - for f in ./files/*; do - cp -a --reflink=auto -t ./rootImage/ "$f" - done - ) - - # Also include a manifest of the closures in a format suitable for nix-store --load-db - cp ${sdClosureInfo}/registration ./rootImage/nix-path-registration - - # Make a crude approximation of the size of the target image. - # If the script starts failing, increase the fudge factors here. - numInodes=$(find ./rootImage | wc -l) - numDataBlocks=$(du -s -c -B 4096 --apparent-size ./rootImage | tail -1 | awk '{ print int($1 * 1.20) }') - bytes=$((2 * 4096 * $numInodes + 4096 * $numDataBlocks)) - echo "Creating an EXT4 image of $bytes bytes (numInodes=$numInodes, numDataBlocks=$numDataBlocks)" - - mebibyte=$(( 1024 * 1024 )) - # Round up to the nearest mebibyte. - # This ensures whole 512 bytes sector sizes in the disk image - # and helps towards aligning partitions optimally. - if (( bytes % mebibyte )); then - bytes=$(( ( bytes / mebibyte + 1) * mebibyte )) - fi - - truncate -s $bytes $img - - faketime -f "1970-01-01 00:00:01" fakeroot mkfs.ext4 -L ${volumeLabel} -U ${uuid} -d ./rootImage $img - - export EXT2FS_NO_MTAB_OK=yes - # I have ended up with corrupted images sometimes, I suspect that happens when the build machine's disk gets full during the build. - if ! fsck.ext4 -n -f $img; then - echo "--- Fsck failed for EXT4 image of $bytes bytes (numInodes=$numInodes, numDataBlocks=$numDataBlocks) ---" - cat errorlog - return 1 - fi - - # We may want to shrink the file system and resize the image to - # get rid of the unnecessary slack here--but see - # https://github.com/NixOS/nixpkgs/issues/125121 for caveats. - - # shrink to fit - resize2fs -M $img - - # Add 16 MebiByte to the current_size - new_size=$(dumpe2fs -h $img | awk -F: \ - '/Block count/{count=$2} /Block size/{size=$2} END{print (count*size+16*2**20)/size}') - - resize2fs $img $new_size - - if [ ${builtins.toString compressImage} ]; then - echo "Compressing image" - zstd -v --no-progress ./$img -o $out - fi - ''; + nativeBuildInputs = [ + e2fsprogs.bin + libfaketime + perl + fakeroot + ] ++ lib.optional compressImage zstd; + + buildCommand = '' + ${if compressImage then "img=temp.img" else "img=$out"} + ( + mkdir -p ./files + ${populateImageCommands} + ) + + echo "Preparing store paths for image..." + + # Create nix/store before copying path + mkdir -p ./rootImage/nix/store + + xargs -I % cp -a --reflink=auto % -t ./rootImage/nix/store/ < ${sdClosureInfo}/store-paths + ( + GLOBIGNORE=".:.." + shopt -u dotglob + + for f in ./files/*; do + cp -a --reflink=auto -t ./rootImage/ "$f" + done + ) + + # Also include a manifest of the closures in a format suitable for nix-store --load-db + cp ${sdClosureInfo}/registration ./rootImage/nix-path-registration + + # Make a crude approximation of the size of the target image. + # If the script starts failing, increase the fudge factors here. + numInodes=$(find ./rootImage | wc -l) + numDataBlocks=$(du -s -c -B 4096 --apparent-size ./rootImage | tail -1 | awk '{ print int($1 * 1.20) }') + bytes=$((2 * 4096 * $numInodes + 4096 * $numDataBlocks)) + echo "Creating an EXT4 image of $bytes bytes (numInodes=$numInodes, numDataBlocks=$numDataBlocks)" + + mebibyte=$(( 1024 * 1024 )) + # Round up to the nearest mebibyte. + # This ensures whole 512 bytes sector sizes in the disk image + # and helps towards aligning partitions optimally. + if (( bytes % mebibyte )); then + bytes=$(( ( bytes / mebibyte + 1) * mebibyte )) + fi + + truncate -s $bytes $img + + faketime -f "1970-01-01 00:00:01" fakeroot mkfs.ext4 -L ${volumeLabel} -U ${uuid} -d ./rootImage $img + + export EXT2FS_NO_MTAB_OK=yes + # I have ended up with corrupted images sometimes, I suspect that happens when the build machine's disk gets full during the build. + if ! fsck.ext4 -n -f $img; then + echo "--- Fsck failed for EXT4 image of $bytes bytes (numInodes=$numInodes, numDataBlocks=$numDataBlocks) ---" + cat errorlog + return 1 + fi + + # We may want to shrink the file system and resize the image to + # get rid of the unnecessary slack here--but see + # https://github.com/NixOS/nixpkgs/issues/125121 for caveats. + + # shrink to fit + resize2fs -M $img + + # Add 16 MebiByte to the current_size + new_size=$(dumpe2fs -h $img | awk -F: \ + '/Block count/{count=$2} /Block size/{size=$2} END{print (count*size+16*2**20)/size}') + + resize2fs $img $new_size + + if [ ${builtins.toString compressImage} ]; then + echo "Compressing image" + zstd -v --no-progress ./$img -o $out + fi + ''; } diff --git a/nixos/lib/make-iso9660-image.nix b/nixos/lib/make-iso9660-image.nix index ec520f5706822b..daf2d14a9ebf54 100644 --- a/nixos/lib/make-iso9660-image.nix +++ b/nixos/lib/make-iso9660-image.nix @@ -1,55 +1,64 @@ -{ lib, stdenv, callPackage, closureInfo, xorriso, syslinux, libossp_uuid, squashfsTools - -, # The file name of the resulting ISO image. - isoName ? "cd.iso" - -, # The files and directories to be placed in the ISO file system. +{ + lib, + stdenv, + callPackage, + closureInfo, + xorriso, + syslinux, + libossp_uuid, + squashfsTools, + + # The file name of the resulting ISO image. + isoName ? "cd.iso", + + # The files and directories to be placed in the ISO file system. # This is a list of attribute sets {source, target} where `source' # is the file system object (regular file or directory) to be # grafted in the file system at path `target'. - contents + contents, -, # In addition to `contents', the closure of the store paths listed + # In addition to `contents', the closure of the store paths listed # in `storeContents' are also placed in the Nix store of the CD. # This is a list of attribute sets {object, symlink} where `object' # is a store path whose closure will be copied, and `symlink' is a # symlink to `object' that will be added to the CD. - storeContents ? [] + storeContents ? [ ], -, # In addition to `contents', the closure of the store paths listed + # In addition to `contents', the closure of the store paths listed # in `squashfsContents' is compressed as squashfs and the result is # placed in /nix-store.squashfs on the CD. # FIXME: This is a performance optimization to avoid Hydra copying # the squashfs between builders and should be removed when Hydra # is smarter about scheduling. - squashfsContents ? [] + squashfsContents ? [ ], -, # Compression settings for squashfs - squashfsCompression ? "xz -Xdict-size 100%" + # Compression settings for squashfs + squashfsCompression ? "xz -Xdict-size 100%", -, # Whether this should be an El-Torito bootable CD. - bootable ? false + # Whether this should be an El-Torito bootable CD. + bootable ? false, -, # Whether this should be an efi-bootable El-Torito CD. - efiBootable ? false + # Whether this should be an efi-bootable El-Torito CD. + efiBootable ? false, -, # Whether this should be an hybrid CD (bootable from USB as well as CD). - usbBootable ? false + # Whether this should be an hybrid CD (bootable from USB as well as CD). + usbBootable ? false, -, # The path (in the ISO file system) of the boot image. - bootImage ? "" + # The path (in the ISO file system) of the boot image. + bootImage ? "", -, # The path (in the ISO file system) of the efi boot image. - efiBootImage ? "" + # The path (in the ISO file system) of the efi boot image. + efiBootImage ? "", -, # The path (outside the ISO file system) of the isohybrid-mbr image. - isohybridMbrImage ? "" + # The path (outside the ISO file system) of the isohybrid-mbr image. + isohybridMbrImage ? "", -, # Whether to compress the resulting ISO image with zstd. - compressImage ? false, zstd + # Whether to compress the resulting ISO image with zstd. + compressImage ? false, + zstd, -, # The volume ID. - volumeID ? "" + # The volume ID. + volumeID ? "", }: assert bootable -> bootImage != ""; @@ -57,7 +66,7 @@ assert efiBootable -> efiBootImage != ""; assert usbBootable -> isohybridMbrImage != ""; let - needSquashfs = squashfsContents != []; + needSquashfs = squashfsContents != [ ]; makeSquashfsDrv = callPackage ./make-squashfs.nix { storeContents = squashfsContents; comp = squashfsCompression; @@ -68,10 +77,24 @@ stdenv.mkDerivation { __structuredAttrs = true; buildCommandPath = ./make-iso9660-image.sh; - nativeBuildInputs = [ xorriso syslinux zstd libossp_uuid ] - ++ lib.optionals needSquashfs makeSquashfsDrv.nativeBuildInputs; - - inherit isoName bootable bootImage compressImage volumeID efiBootImage efiBootable isohybridMbrImage usbBootable; + nativeBuildInputs = [ + xorriso + syslinux + zstd + libossp_uuid + ] ++ lib.optionals needSquashfs makeSquashfsDrv.nativeBuildInputs; + + inherit + isoName + bootable + bootImage + compressImage + volumeID + efiBootImage + efiBootable + isohybridMbrImage + usbBootable + ; sources = map (x: x.source) contents; targets = map (x: x.target) contents; diff --git a/nixos/lib/make-multi-disk-zfs-image.nix b/nixos/lib/make-multi-disk-zfs-image.nix index b2489989092a7e..c4d6d69fae14a4 100644 --- a/nixos/lib/make-multi-disk-zfs-image.nix +++ b/nixos/lib/make-multi-disk-zfs-image.nix @@ -24,77 +24,81 @@ # presumably because zed doesn’t get an event saying it’s partition grew, # whereas it can and does get an event saying the whole disk it is on is # now larger. -{ lib -, pkgs -, # The NixOS configuration to be installed onto the disk image. - config +{ + lib, + pkgs, + # The NixOS configuration to be installed onto the disk image. + config, -, # size of the FAT boot disk, in megabytes. - bootSize ? 1024 + # size of the FAT boot disk, in megabytes. + bootSize ? 1024, -, # The size of the root disk, in megabytes. - rootSize ? 2048 + # The size of the root disk, in megabytes. + rootSize ? 2048, -, # The name of the ZFS pool - rootPoolName ? "tank" + # The name of the ZFS pool + rootPoolName ? "tank", -, # zpool properties + # zpool properties rootPoolProperties ? { autoexpand = "on"; - } -, # pool-wide filesystem properties + }, + # pool-wide filesystem properties rootPoolFilesystemProperties ? { acltype = "posixacl"; atime = "off"; compression = "on"; mountpoint = "legacy"; xattr = "sa"; - } + }, -, # datasets, with per-attribute options: + # datasets, with per-attribute options: # mount: (optional) mount point in the VM # properties: (optional) ZFS properties on the dataset, like filesystemProperties # Notes: # 1. datasets will be created from shorter to longer names as a simple topo-sort # 2. you should define a root's dataset's mount for `/` - datasets ? { } + datasets ? { }, -, # The files and directories to be placed in the target file system. + # The files and directories to be placed in the target file system. # This is a list of attribute sets {source, target} where `source' # is the file system object (regular file or directory) to be # grafted in the file system at path `target'. - contents ? [] + contents ? [ ], -, # The initial NixOS configuration file to be copied to + # The initial NixOS configuration file to be copied to # /etc/nixos/configuration.nix. This configuration will be embedded # inside a configuration which includes the described ZFS fileSystems. - configFile ? null + configFile ? null, -, # Shell code executed after the VM has finished. - postVM ? "" + # Shell code executed after the VM has finished. + postVM ? "", -, # Guest memory size - memSize ? 1024 + # Guest memory size + memSize ? 1024, -, name ? "nixos-disk-image" + name ? "nixos-disk-image", -, # Disk image format, one of qcow2, qcow2-compressed, vdi, vpc, raw. - format ? "raw" + # Disk image format, one of qcow2, qcow2-compressed, vdi, vpc, raw. + format ? "raw", -, # Include a copy of Nixpkgs in the disk image - includeChannel ? true + # Include a copy of Nixpkgs in the disk image + includeChannel ? true, }: let formatOpt = if format == "qcow2-compressed" then "qcow2" else format; compress = lib.optionalString (format == "qcow2-compressed") "-c"; - filenameSuffix = "." + { - qcow2 = "qcow2"; - vdi = "vdi"; - vpc = "vhd"; - raw = "img"; - }.${formatOpt} or formatOpt; + filenameSuffix = + "." + + { + qcow2 = "qcow2"; + vdi = "vdi"; + vpc = "vhd"; + raw = "img"; + } + .${formatOpt} or formatOpt; bootFilename = "nixos.boot${filenameSuffix}"; rootFilename = "nixos.root${filenameSuffix}"; @@ -103,27 +107,32 @@ let let nixpkgs = lib.cleanSource pkgs.path; in - pkgs.runCommand "nixos-${config.system.nixos.version}" {} '' - mkdir -p $out - cp -prd ${nixpkgs.outPath} $out/nixos - chmod -R u+w $out/nixos - if [ ! -e $out/nixos/nixpkgs ]; then - ln -s . $out/nixos/nixpkgs - fi - rm -rf $out/nixos/.git - echo -n ${config.system.nixos.versionSuffix} > $out/nixos/.version-suffix - ''; + pkgs.runCommand "nixos-${config.system.nixos.version}" { } '' + mkdir -p $out + cp -prd ${nixpkgs.outPath} $out/nixos + chmod -R u+w $out/nixos + if [ ! -e $out/nixos/nixpkgs ]; then + ln -s . $out/nixos/nixpkgs + fi + rm -rf $out/nixos/.git + echo -n ${config.system.nixos.versionSuffix} > $out/nixos/.version-suffix + ''; closureInfo = pkgs.closureInfo { - rootPaths = [ config.system.build.toplevel ] - ++ (lib.optional includeChannel channelSources); + rootPaths = [ config.system.build.toplevel ] ++ (lib.optional includeChannel channelSources); }; - modulesTree = pkgs.aggregateModules - (with config.boot.kernelPackages; [ kernel zfs ]); + modulesTree = pkgs.aggregateModules ( + with config.boot.kernelPackages; + [ + kernel + zfs + ] + ); tools = lib.makeBinPath ( - with pkgs; [ + with pkgs; + [ nixos-enter config.system.build.nixos-install dosfstools @@ -136,92 +145,101 @@ let ] ); - hasDefinedMount = disk: ((disk.mount or null) != null); + hasDefinedMount = disk: ((disk.mount or null) != null); - stringifyProperties = prefix: properties: lib.concatStringsSep " \\\n" ( - lib.mapAttrsToList - ( + stringifyProperties = + prefix: properties: + lib.concatStringsSep " \\\n" ( + lib.mapAttrsToList ( property: value: "${prefix} ${lib.escapeShellArg property}=${lib.escapeShellArg value}" - ) - properties - ); + ) properties + ); createDatasets = let datasetlist = lib.mapAttrsToList lib.nameValuePair datasets; - sorted = lib.sort (left: right: (lib.stringLength left.name) < (lib.stringLength right.name)) datasetlist; - cmd = { name, value }: + sorted = lib.sort ( + left: right: (lib.stringLength left.name) < (lib.stringLength right.name) + ) datasetlist; + cmd = + { name, value }: let - properties = stringifyProperties "-o" (value.properties or {}); + properties = stringifyProperties "-o" (value.properties or { }); in - "zfs create -p ${properties} ${name}"; + "zfs create -p ${properties} ${name}"; in - lib.concatMapStringsSep "\n" cmd sorted; + lib.concatMapStringsSep "\n" cmd sorted; mountDatasets = let datasetlist = lib.mapAttrsToList lib.nameValuePair datasets; mounts = lib.filter ({ value, ... }: hasDefinedMount value) datasetlist; - sorted = lib.sort (left: right: (lib.stringLength left.value.mount) < (lib.stringLength right.value.mount)) mounts; - cmd = { name, value }: + sorted = lib.sort ( + left: right: (lib.stringLength left.value.mount) < (lib.stringLength right.value.mount) + ) mounts; + cmd = + { name, value }: '' mkdir -p /mnt${lib.escapeShellArg value.mount} mount -t zfs ${name} /mnt${lib.escapeShellArg value.mount} ''; in - lib.concatMapStringsSep "\n" cmd sorted; + lib.concatMapStringsSep "\n" cmd sorted; unmountDatasets = let datasetlist = lib.mapAttrsToList lib.nameValuePair datasets; mounts = lib.filter ({ value, ... }: hasDefinedMount value) datasetlist; - sorted = lib.sort (left: right: (lib.stringLength left.value.mount) > (lib.stringLength right.value.mount)) mounts; - cmd = { name, value }: + sorted = lib.sort ( + left: right: (lib.stringLength left.value.mount) > (lib.stringLength right.value.mount) + ) mounts; + cmd = + { name, value }: '' umount /mnt${lib.escapeShellArg value.mount} ''; in - lib.concatMapStringsSep "\n" cmd sorted; - + lib.concatMapStringsSep "\n" cmd sorted; fileSystemsCfgFile = let mountable = lib.filterAttrs (_: value: hasDefinedMount value) datasets; in - pkgs.runCommand "filesystem-config.nix" { - buildInputs = with pkgs; [ jq nixpkgs-fmt ]; + pkgs.runCommand "filesystem-config.nix" + { + buildInputs = with pkgs; [ + jq + nixpkgs-fmt + ]; filesystems = builtins.toJSON { - fileSystems = lib.mapAttrs' - ( - dataset: attrs: - { - name = attrs.mount; - value = { - fsType = "zfs"; - device = "${dataset}"; - }; - } - ) - mountable; + fileSystems = lib.mapAttrs' (dataset: attrs: { + name = attrs.mount; + value = { + fsType = "zfs"; + device = "${dataset}"; + }; + }) mountable; }; passAsFile = [ "filesystems" ]; - } '' - ( - echo "builtins.fromJSON '''" - jq . < "$filesystemsPath" - echo "'''" - ) > $out - - nixpkgs-fmt $out - ''; + } + '' + ( + echo "builtins.fromJSON '''" + jq . < "$filesystemsPath" + echo "'''" + ) > $out + + nixpkgs-fmt $out + ''; mergedConfig = - if configFile == null - then fileSystemsCfgFile + if configFile == null then + fileSystemsCfgFile else - pkgs.runCommand "configuration.nix" { - buildInputs = with pkgs; [ nixpkgs-fmt ]; - } + pkgs.runCommand "configuration.nix" + { + buildInputs = with pkgs; [ nixpkgs-fmt ]; + } '' ( echo '{ imports = [' @@ -233,97 +251,109 @@ let nixpkgs-fmt $out ''; - image = ( - pkgs.vmTools.override { - rootModules = - [ "zfs" "9p" "9pnet_virtio" "virtio_pci" "virtio_blk" ]; + image = + (pkgs.vmTools.override { + rootModules = [ + "zfs" + "9p" + "9pnet_virtio" + "virtio_pci" + "virtio_blk" + ]; kernel = modulesTree; - } - ).runInLinuxVM ( - pkgs.runCommand name - { - QEMU_OPTS = "-drive file=$bootDiskImage,if=virtio,cache=unsafe,werror=report" - + " -drive file=$rootDiskImage,if=virtio,cache=unsafe,werror=report"; - inherit memSize; - preVM = '' - PATH=$PATH:${pkgs.qemu_kvm}/bin - mkdir $out - bootDiskImage=boot.raw - qemu-img create -f raw $bootDiskImage ${toString bootSize}M - - rootDiskImage=root.raw - qemu-img create -f raw $rootDiskImage ${toString rootSize}M - ''; - - postVM = '' - ${if formatOpt == "raw" then '' - mv $bootDiskImage $out/${bootFilename} - mv $rootDiskImage $out/${rootFilename} - '' else '' - ${pkgs.qemu_kvm}/bin/qemu-img convert -f raw -O ${formatOpt} ${compress} $bootDiskImage $out/${bootFilename} - ${pkgs.qemu_kvm}/bin/qemu-img convert -f raw -O ${formatOpt} ${compress} $rootDiskImage $out/${rootFilename} - ''} - bootDiskImage=$out/${bootFilename} - rootDiskImage=$out/${rootFilename} - set -x - ${postVM} - ''; - } '' - export PATH=${tools}:$PATH - set -x - - cp -sv /dev/vda /dev/sda - cp -sv /dev/vda /dev/xvda - - parted --script /dev/vda -- \ - mklabel gpt \ - mkpart no-fs 1MiB 2MiB \ - set 1 bios_grub on \ - align-check optimal 1 \ - mkpart ESP fat32 2MiB -1MiB \ - align-check optimal 2 \ - print - - sfdisk --dump /dev/vda - - - zpool create \ - ${stringifyProperties " -o" rootPoolProperties} \ - ${stringifyProperties " -O" rootPoolFilesystemProperties} \ - ${rootPoolName} /dev/vdb - parted --script /dev/vdb -- print - - ${createDatasets} - ${mountDatasets} - - mkdir -p /mnt/boot - mkfs.vfat -n ESP /dev/vda2 - mount /dev/vda2 /mnt/boot - - mount - - # Install a configuration.nix - mkdir -p /mnt/etc/nixos - # `cat` so it is mutable on the fs - cat ${mergedConfig} > /mnt/etc/nixos/configuration.nix - - export NIX_STATE_DIR=$TMPDIR/state - nix-store --load-db < ${closureInfo}/registration - - nixos-install \ - --root /mnt \ - --no-root-passwd \ - --system ${config.system.build.toplevel} \ - --substituters "" \ - ${lib.optionalString includeChannel ''--channel ${channelSources}''} - - df -h - - umount /mnt/boot - ${unmountDatasets} - - zpool export ${rootPoolName} - '' - ); + }).runInLinuxVM + ( + pkgs.runCommand name + { + QEMU_OPTS = + "-drive file=$bootDiskImage,if=virtio,cache=unsafe,werror=report" + + " -drive file=$rootDiskImage,if=virtio,cache=unsafe,werror=report"; + inherit memSize; + preVM = '' + PATH=$PATH:${pkgs.qemu_kvm}/bin + mkdir $out + bootDiskImage=boot.raw + qemu-img create -f raw $bootDiskImage ${toString bootSize}M + + rootDiskImage=root.raw + qemu-img create -f raw $rootDiskImage ${toString rootSize}M + ''; + + postVM = '' + ${ + if formatOpt == "raw" then + '' + mv $bootDiskImage $out/${bootFilename} + mv $rootDiskImage $out/${rootFilename} + '' + else + '' + ${pkgs.qemu_kvm}/bin/qemu-img convert -f raw -O ${formatOpt} ${compress} $bootDiskImage $out/${bootFilename} + ${pkgs.qemu_kvm}/bin/qemu-img convert -f raw -O ${formatOpt} ${compress} $rootDiskImage $out/${rootFilename} + '' + } + bootDiskImage=$out/${bootFilename} + rootDiskImage=$out/${rootFilename} + set -x + ${postVM} + ''; + } + '' + export PATH=${tools}:$PATH + set -x + + cp -sv /dev/vda /dev/sda + cp -sv /dev/vda /dev/xvda + + parted --script /dev/vda -- \ + mklabel gpt \ + mkpart no-fs 1MiB 2MiB \ + set 1 bios_grub on \ + align-check optimal 1 \ + mkpart ESP fat32 2MiB -1MiB \ + align-check optimal 2 \ + print + + sfdisk --dump /dev/vda + + + zpool create \ + ${stringifyProperties " -o" rootPoolProperties} \ + ${stringifyProperties " -O" rootPoolFilesystemProperties} \ + ${rootPoolName} /dev/vdb + parted --script /dev/vdb -- print + + ${createDatasets} + ${mountDatasets} + + mkdir -p /mnt/boot + mkfs.vfat -n ESP /dev/vda2 + mount /dev/vda2 /mnt/boot + + mount + + # Install a configuration.nix + mkdir -p /mnt/etc/nixos + # `cat` so it is mutable on the fs + cat ${mergedConfig} > /mnt/etc/nixos/configuration.nix + + export NIX_STATE_DIR=$TMPDIR/state + nix-store --load-db < ${closureInfo}/registration + + nixos-install \ + --root /mnt \ + --no-root-passwd \ + --system ${config.system.build.toplevel} \ + --substituters "" \ + ${lib.optionalString includeChannel ''--channel ${channelSources}''} + + df -h + + umount /mnt/boot + ${unmountDatasets} + + zpool export ${rootPoolName} + '' + ); in image diff --git a/nixos/lib/make-options-doc/default.nix b/nixos/lib/make-options-doc/default.nix index f19847e706d5ab..a6ff4be92c8029 100644 --- a/nixos/lib/make-options-doc/default.nix +++ b/nixos/lib/make-options-doc/default.nix @@ -87,36 +87,41 @@ } ``` */ -{ pkgs -, lib -, options -, transformOptions ? lib.id # function for additional transformations of the options -, documentType ? "appendix" # TODO deprecate "appendix" in favor of "none" - # and/or rename function to moduleOptionDoc for clean slate +{ + pkgs, + lib, + options, + transformOptions ? lib.id, # function for additional transformations of the options + documentType ? "appendix", + # TODO deprecate "appendix" in favor of "none" + # and/or rename function to moduleOptionDoc for clean slate # If you include more than one option list into a document, you need to # provide different ids. -, variablelistId ? "configuration-variable-list" + variablelistId ? "configuration-variable-list", # String to prefix to the option XML/HTML id attributes. -, optionIdPrefix ? "opt-" -, revision ? "" # Specify revision for the options -# a set of options the docs we are generating will be merged into, as if by recursiveUpdate. -# used to split the options doc build into a static part (nixos/modules) and a dynamic part -# (non-nixos modules imported via configuration.nix, other module sources). -, baseOptionsJSON ? null -# instead of printing warnings for eg options with missing descriptions (which may be lost -# by nix build unless -L is given), emit errors instead and fail the build -, warningsAreErrors ? true + optionIdPrefix ? "opt-", + revision ? "", # Specify revision for the options + # a set of options the docs we are generating will be merged into, as if by recursiveUpdate. + # used to split the options doc build into a static part (nixos/modules) and a dynamic part + # (non-nixos modules imported via configuration.nix, other module sources). + baseOptionsJSON ? null, + # instead of printing warnings for eg options with missing descriptions (which may be lost + # by nix build unless -L is given), emit errors instead and fail the build + warningsAreErrors ? true, }: let rawOpts = lib.optionAttrSetToDocList options; transformedOpts = map transformOptions rawOpts; filteredOpts = lib.filter (opt: opt.visible && !opt.internal) transformedOpts; - optionsList = lib.flip map filteredOpts - (opt: opt - // lib.optionalAttrs (opt ? relatedPackages && opt.relatedPackages != []) { relatedPackages = genRelatedPackages opt.relatedPackages opt.name; } - ); + optionsList = lib.flip map filteredOpts ( + opt: + opt + // lib.optionalAttrs (opt ? relatedPackages && opt.relatedPackages != [ ]) { + relatedPackages = genRelatedPackages opt.relatedPackages opt.name; + } + ); # Generate DocBook documentation for a list of packages. This is # what `relatedPackages` option of `mkOption` from @@ -132,87 +137,110 @@ let # # NOTE: No checks against `pkgs` are made to ensure that the referenced package actually exists. # Such checks are not compatible with option docs caching. - genRelatedPackages = packages: optName: + genRelatedPackages = + packages: optName: let - unpack = p: if lib.isString p then { name = p; } - else if lib.isList p then { path = p; } - else p; - describe = args: + unpack = + p: + if lib.isString p then + { name = p; } + else if lib.isList p then + { path = p; } + else + p; + describe = + args: let title = args.title or null; name = args.name or (lib.concatStringsSep "." args.path); - in '' + in + '' - [${lib.optionalString (title != null) "${title} aka "}`pkgs.${name}`]( https://search.nixos.org/packages?show=${name}&sort=relevance&query=${name} - )${ - lib.optionalString (args ? comment) "\n\n ${args.comment}" - } + )${lib.optionalString (args ? comment) "\n\n ${args.comment}"} ''; - in lib.concatMapStrings (p: describe (unpack p)) packages; - - optionsNix = builtins.listToAttrs (map (o: { name = o.name; value = removeAttrs o ["name" "visible" "internal"]; }) optionsList); + in + lib.concatMapStrings (p: describe (unpack p)) packages; + + optionsNix = builtins.listToAttrs ( + map (o: { + name = o.name; + value = removeAttrs o [ + "name" + "visible" + "internal" + ]; + }) optionsList + ); -in rec { +in +rec { inherit optionsNix; - optionsAsciiDoc = pkgs.runCommand "options.adoc" { - nativeBuildInputs = [ pkgs.nixos-render-docs ]; - } '' - nixos-render-docs -j $NIX_BUILD_CORES options asciidoc \ - --manpage-urls ${pkgs.path + "/doc/manpage-urls.json"} \ - --revision ${lib.escapeShellArg revision} \ - ${optionsJSON}/share/doc/nixos/options.json \ - $out - ''; - - optionsCommonMark = pkgs.runCommand "options.md" { - nativeBuildInputs = [ pkgs.nixos-render-docs ]; - } '' - nixos-render-docs -j $NIX_BUILD_CORES options commonmark \ - --manpage-urls ${pkgs.path + "/doc/manpage-urls.json"} \ - --revision ${lib.escapeShellArg revision} \ - ${optionsJSON}/share/doc/nixos/options.json \ - $out - ''; - - optionsJSON = pkgs.runCommand "options.json" - { meta.description = "List of NixOS options in JSON format"; - nativeBuildInputs = [ - pkgs.brotli - pkgs.python3 - ]; - options = builtins.toFile "options.json" - (builtins.unsafeDiscardStringContext (builtins.toJSON optionsNix)); - # merge with an empty set if baseOptionsJSON is null to run markdown - # processing on the input options - baseJSON = - if baseOptionsJSON == null - then builtins.toFile "base.json" "{}" - else baseOptionsJSON; - } - '' - # Export list of options in different format. - dst=$out/share/doc/nixos - mkdir -p $dst - - TOUCH_IF_DB=$dst/.used-docbook \ - python ${./mergeJSON.py} \ - ${lib.optionalString warningsAreErrors "--warnings-are-errors"} \ - $baseJSON $options \ - > $dst/options.json - - if grep /nixpkgs/nixos/modules $dst/options.json; then - echo "The manual appears to depend on the location of Nixpkgs, which is bad" - echo "since this prevents sharing via the NixOS channel. This is typically" - echo "caused by an option default that refers to a relative path (see above" - echo "for hints about the offending path)." - exit 1 - fi - - brotli -9 < $dst/options.json > $dst/options.json.br - - mkdir -p $out/nix-support - echo "file json $dst/options.json" >> $out/nix-support/hydra-build-products - echo "file json-br $dst/options.json.br" >> $out/nix-support/hydra-build-products - ''; + optionsAsciiDoc = + pkgs.runCommand "options.adoc" + { + nativeBuildInputs = [ pkgs.nixos-render-docs ]; + } + '' + nixos-render-docs -j $NIX_BUILD_CORES options asciidoc \ + --manpage-urls ${pkgs.path + "/doc/manpage-urls.json"} \ + --revision ${lib.escapeShellArg revision} \ + ${optionsJSON}/share/doc/nixos/options.json \ + $out + ''; + + optionsCommonMark = + pkgs.runCommand "options.md" + { + nativeBuildInputs = [ pkgs.nixos-render-docs ]; + } + '' + nixos-render-docs -j $NIX_BUILD_CORES options commonmark \ + --manpage-urls ${pkgs.path + "/doc/manpage-urls.json"} \ + --revision ${lib.escapeShellArg revision} \ + ${optionsJSON}/share/doc/nixos/options.json \ + $out + ''; + + optionsJSON = + pkgs.runCommand "options.json" + { + meta.description = "List of NixOS options in JSON format"; + nativeBuildInputs = [ + pkgs.brotli + pkgs.python3 + ]; + options = builtins.toFile "options.json" ( + builtins.unsafeDiscardStringContext (builtins.toJSON optionsNix) + ); + # merge with an empty set if baseOptionsJSON is null to run markdown + # processing on the input options + baseJSON = if baseOptionsJSON == null then builtins.toFile "base.json" "{}" else baseOptionsJSON; + } + '' + # Export list of options in different format. + dst=$out/share/doc/nixos + mkdir -p $dst + + TOUCH_IF_DB=$dst/.used-docbook \ + python ${./mergeJSON.py} \ + ${lib.optionalString warningsAreErrors "--warnings-are-errors"} \ + $baseJSON $options \ + > $dst/options.json + + if grep /nixpkgs/nixos/modules $dst/options.json; then + echo "The manual appears to depend on the location of Nixpkgs, which is bad" + echo "since this prevents sharing via the NixOS channel. This is typically" + echo "caused by an option default that refers to a relative path (see above" + echo "for hints about the offending path)." + exit 1 + fi + + brotli -9 < $dst/options.json > $dst/options.json.br + + mkdir -p $out/nix-support + echo "file json $dst/options.json" >> $out/nix-support/hydra-build-products + echo "file json-br $dst/options.json.br" >> $out/nix-support/hydra-build-products + ''; } diff --git a/nixos/lib/make-single-disk-zfs-image.nix b/nixos/lib/make-single-disk-zfs-image.nix index cd65d596e05112..1641a7f799e2a3 100644 --- a/nixos/lib/make-single-disk-zfs-image.nix +++ b/nixos/lib/make-single-disk-zfs-image.nix @@ -13,77 +13,81 @@ # This single-disk approach does not satisfy ZFS's requirements for autoexpand, # however automation can expand it anyway. For example, with # `services.zfs.expandOnBoot`. -{ lib -, pkgs -, # The NixOS configuration to be installed onto the disk image. - config +{ + lib, + pkgs, + # The NixOS configuration to be installed onto the disk image. + config, -, # size of the FAT partition, in megabytes. + # size of the FAT partition, in megabytes. bootSize ? 1024 , # memory allocated for virtualized build instance - memSize ? 1024 + memSize ? 1024, -, # The size of the root partition, in megabytes. - rootSize ? 2048 + # The size of the root partition, in megabytes. + rootSize ? 2048, -, # The name of the ZFS pool - rootPoolName ? "tank" + # The name of the ZFS pool + rootPoolName ? "tank", -, # zpool properties + # zpool properties rootPoolProperties ? { autoexpand = "on"; - } -, # pool-wide filesystem properties + }, + # pool-wide filesystem properties rootPoolFilesystemProperties ? { acltype = "posixacl"; atime = "off"; compression = "on"; mountpoint = "legacy"; xattr = "sa"; - } + }, -, # datasets, with per-attribute options: + # datasets, with per-attribute options: # mount: (optional) mount point in the VM # properties: (optional) ZFS properties on the dataset, like filesystemProperties # Notes: # 1. datasets will be created from shorter to longer names as a simple topo-sort # 2. you should define a root's dataset's mount for `/` - datasets ? { } + datasets ? { }, -, # The files and directories to be placed in the target file system. + # The files and directories to be placed in the target file system. # This is a list of attribute sets {source, target} where `source' # is the file system object (regular file or directory) to be # grafted in the file system at path `target'. - contents ? [ ] + contents ? [ ], -, # The initial NixOS configuration file to be copied to + # The initial NixOS configuration file to be copied to # /etc/nixos/configuration.nix. This configuration will be embedded # inside a configuration which includes the described ZFS fileSystems. - configFile ? null + configFile ? null, -, # Shell code executed after the VM has finished. - postVM ? "" + # Shell code executed after the VM has finished. + postVM ? "", -, name ? "nixos-disk-image" + name ? "nixos-disk-image", -, # Disk image format, one of qcow2, qcow2-compressed, vdi, vpc, raw. - format ? "raw" + # Disk image format, one of qcow2, qcow2-compressed, vdi, vpc, raw. + format ? "raw", -, # Include a copy of Nixpkgs in the disk image - includeChannel ? true + # Include a copy of Nixpkgs in the disk image + includeChannel ? true, }: let formatOpt = if format == "qcow2-compressed" then "qcow2" else format; compress = lib.optionalString (format == "qcow2-compressed") "-c"; - filenameSuffix = "." + { - qcow2 = "qcow2"; - vdi = "vdi"; - vpc = "vhd"; - raw = "img"; - }.${formatOpt} or formatOpt; + filenameSuffix = + "." + + { + qcow2 = "qcow2"; + vdi = "vdi"; + vpc = "vhd"; + raw = "img"; + } + .${formatOpt} or formatOpt; rootFilename = "nixos.root${filenameSuffix}"; # FIXME: merge with channel.nix / make-channel.nix. @@ -103,15 +107,20 @@ let ''; closureInfo = pkgs.closureInfo { - rootPaths = [ config.system.build.toplevel ] - ++ (lib.optional includeChannel channelSources); + rootPaths = [ config.system.build.toplevel ] ++ (lib.optional includeChannel channelSources); }; - modulesTree = pkgs.aggregateModules - (with config.boot.kernelPackages; [ kernel zfs ]); + modulesTree = pkgs.aggregateModules ( + with config.boot.kernelPackages; + [ + kernel + zfs + ] + ); tools = lib.makeBinPath ( - with pkgs; [ + with pkgs; + [ nixos-enter config.system.build.nixos-install dosfstools @@ -126,19 +135,22 @@ let hasDefinedMount = disk: ((disk.mount or null) != null); - stringifyProperties = prefix: properties: lib.concatStringsSep " \\\n" ( - lib.mapAttrsToList - ( + stringifyProperties = + prefix: properties: + lib.concatStringsSep " \\\n" ( + lib.mapAttrsToList ( property: value: "${prefix} ${lib.escapeShellArg property}=${lib.escapeShellArg value}" - ) - properties - ); + ) properties + ); createDatasets = let datasetlist = lib.mapAttrsToList lib.nameValuePair datasets; - sorted = lib.sort (left: right: (lib.stringLength left.name) < (lib.stringLength right.name)) datasetlist; - cmd = { name, value }: + sorted = lib.sort ( + left: right: (lib.stringLength left.name) < (lib.stringLength right.name) + ) datasetlist; + cmd = + { name, value }: let properties = stringifyProperties "-o" (value.properties or { }); in @@ -150,8 +162,11 @@ let let datasetlist = lib.mapAttrsToList lib.nameValuePair datasets; mounts = lib.filter ({ value, ... }: hasDefinedMount value) datasetlist; - sorted = lib.sort (left: right: (lib.stringLength left.value.mount) < (lib.stringLength right.value.mount)) mounts; - cmd = { name, value }: + sorted = lib.sort ( + left: right: (lib.stringLength left.value.mount) < (lib.stringLength right.value.mount) + ) mounts; + cmd = + { name, value }: '' mkdir -p /mnt${lib.escapeShellArg value.mount} mount -t zfs ${name} /mnt${lib.escapeShellArg value.mount} @@ -163,50 +178,51 @@ let let datasetlist = lib.mapAttrsToList lib.nameValuePair datasets; mounts = lib.filter ({ value, ... }: hasDefinedMount value) datasetlist; - sorted = lib.sort (left: right: (lib.stringLength left.value.mount) > (lib.stringLength right.value.mount)) mounts; - cmd = { name, value }: + sorted = lib.sort ( + left: right: (lib.stringLength left.value.mount) > (lib.stringLength right.value.mount) + ) mounts; + cmd = + { name, value }: '' umount /mnt${lib.escapeShellArg value.mount} ''; in lib.concatMapStringsSep "\n" cmd sorted; - fileSystemsCfgFile = let mountable = lib.filterAttrs (_: value: hasDefinedMount value) datasets; in pkgs.runCommand "filesystem-config.nix" { - buildInputs = with pkgs; [ jq nixpkgs-fmt ]; + buildInputs = with pkgs; [ + jq + nixpkgs-fmt + ]; filesystems = builtins.toJSON { - fileSystems = lib.mapAttrs' - ( - dataset: attrs: - { - name = attrs.mount; - value = { - fsType = "zfs"; - device = "${dataset}"; - }; - } - ) - mountable; + fileSystems = lib.mapAttrs' (dataset: attrs: { + name = attrs.mount; + value = { + fsType = "zfs"; + device = "${dataset}"; + }; + }) mountable; }; passAsFile = [ "filesystems" ]; - } '' - ( - echo "builtins.fromJSON '''" - jq . < "$filesystemsPath" - echo "'''" - ) > $out + } + '' + ( + echo "builtins.fromJSON '''" + jq . < "$filesystemsPath" + echo "'''" + ) > $out - nixpkgs-fmt $out - ''; + nixpkgs-fmt $out + ''; mergedConfig = - if configFile == null - then fileSystemsCfgFile + if configFile == null then + fileSystemsCfgFile else pkgs.runCommand "configuration.nix" { @@ -223,93 +239,104 @@ let nixpkgs-fmt $out ''; - image = ( - pkgs.vmTools.override { - rootModules = - [ "zfs" "9p" "9pnet_virtio" "virtio_pci" "virtio_blk" ]; + image = + (pkgs.vmTools.override { + rootModules = [ + "zfs" + "9p" + "9pnet_virtio" + "virtio_pci" + "virtio_blk" + ]; kernel = modulesTree; - } - ).runInLinuxVM ( - pkgs.runCommand name - { - inherit memSize; - QEMU_OPTS = "-drive file=$rootDiskImage,if=virtio,cache=unsafe,werror=report"; - preVM = '' - PATH=$PATH:${pkgs.qemu_kvm}/bin - mkdir $out - - rootDiskImage=root.raw - qemu-img create -f raw $rootDiskImage ${toString (bootSize + rootSize)}M - ''; - - postVM = '' - ${if formatOpt == "raw" then '' - mv $rootDiskImage $out/${rootFilename} - '' else '' - ${pkgs.qemu_kvm}/bin/qemu-img convert -f raw -O ${formatOpt} ${compress} $rootDiskImage $out/${rootFilename} - ''} - rootDiskImage=$out/${rootFilename} + }).runInLinuxVM + ( + pkgs.runCommand name + { + inherit memSize; + QEMU_OPTS = "-drive file=$rootDiskImage,if=virtio,cache=unsafe,werror=report"; + preVM = '' + PATH=$PATH:${pkgs.qemu_kvm}/bin + mkdir $out + + rootDiskImage=root.raw + qemu-img create -f raw $rootDiskImage ${toString (bootSize + rootSize)}M + ''; + + postVM = '' + ${ + if formatOpt == "raw" then + '' + mv $rootDiskImage $out/${rootFilename} + '' + else + '' + ${pkgs.qemu_kvm}/bin/qemu-img convert -f raw -O ${formatOpt} ${compress} $rootDiskImage $out/${rootFilename} + '' + } + rootDiskImage=$out/${rootFilename} + set -x + ${postVM} + ''; + } + '' + export PATH=${tools}:$PATH set -x - ${postVM} - ''; - } '' - export PATH=${tools}:$PATH - set -x - cp -sv /dev/vda /dev/sda - cp -sv /dev/vda /dev/xvda + cp -sv /dev/vda /dev/sda + cp -sv /dev/vda /dev/xvda - parted --script /dev/vda -- \ - mklabel gpt \ - mkpart no-fs 1MiB 2MiB \ - set 1 bios_grub on \ - align-check optimal 1 \ - mkpart primary fat32 2MiB ${toString bootSize}MiB \ - align-check optimal 2 \ - mkpart primary fat32 ${toString bootSize}MiB -1MiB \ - align-check optimal 3 \ - print + parted --script /dev/vda -- \ + mklabel gpt \ + mkpart no-fs 1MiB 2MiB \ + set 1 bios_grub on \ + align-check optimal 1 \ + mkpart primary fat32 2MiB ${toString bootSize}MiB \ + align-check optimal 2 \ + mkpart primary fat32 ${toString bootSize}MiB -1MiB \ + align-check optimal 3 \ + print - sfdisk --dump /dev/vda + sfdisk --dump /dev/vda - zpool create \ - ${stringifyProperties " -o" rootPoolProperties} \ - ${stringifyProperties " -O" rootPoolFilesystemProperties} \ - ${rootPoolName} /dev/vda3 - parted --script /dev/vda -- print + zpool create \ + ${stringifyProperties " -o" rootPoolProperties} \ + ${stringifyProperties " -O" rootPoolFilesystemProperties} \ + ${rootPoolName} /dev/vda3 + parted --script /dev/vda -- print - ${createDatasets} - ${mountDatasets} + ${createDatasets} + ${mountDatasets} - mkdir -p /mnt/boot - mkfs.vfat -n ESP /dev/vda2 - mount /dev/vda2 /mnt/boot + mkdir -p /mnt/boot + mkfs.vfat -n ESP /dev/vda2 + mount /dev/vda2 /mnt/boot - mount + mount - # Install a configuration.nix - mkdir -p /mnt/etc/nixos - # `cat` so it is mutable on the fs - cat ${mergedConfig} > /mnt/etc/nixos/configuration.nix + # Install a configuration.nix + mkdir -p /mnt/etc/nixos + # `cat` so it is mutable on the fs + cat ${mergedConfig} > /mnt/etc/nixos/configuration.nix - export NIX_STATE_DIR=$TMPDIR/state - nix-store --load-db < ${closureInfo}/registration + export NIX_STATE_DIR=$TMPDIR/state + nix-store --load-db < ${closureInfo}/registration - nixos-install \ - --root /mnt \ - --no-root-passwd \ - --system ${config.system.build.toplevel} \ - --substituters "" \ - ${lib.optionalString includeChannel ''--channel ${channelSources}''} + nixos-install \ + --root /mnt \ + --no-root-passwd \ + --system ${config.system.build.toplevel} \ + --substituters "" \ + ${lib.optionalString includeChannel ''--channel ${channelSources}''} - df -h + df -h - umount /mnt/boot - ${unmountDatasets} + umount /mnt/boot + ${unmountDatasets} - zpool export ${rootPoolName} - '' - ); + zpool export ${rootPoolName} + '' + ); in image diff --git a/nixos/lib/make-system-tarball.nix b/nixos/lib/make-system-tarball.nix index 325792f97e8f3f..9fb77230cf6366 100644 --- a/nixos/lib/make-system-tarball.nix +++ b/nixos/lib/make-system-tarball.nix @@ -1,32 +1,35 @@ -{ stdenv, closureInfo, pixz +{ + stdenv, + closureInfo, + pixz, -, # The file name of the resulting tarball - fileName ? "nixos-system-${stdenv.hostPlatform.system}" + # The file name of the resulting tarball + fileName ? "nixos-system-${stdenv.hostPlatform.system}", -, # The files and directories to be placed in the tarball. + # The files and directories to be placed in the tarball. # This is a list of attribute sets {source, target} where `source' # is the file system object (regular file or directory) to be # grafted in the file system at path `target'. - contents + contents, -, # In addition to `contents', the closure of the store paths listed + # In addition to `contents', the closure of the store paths listed # in `packages' are also placed in the Nix store of the tarball. This is # a list of attribute sets {object, symlink} where `object' if a # store path whose closure will be copied, and `symlink' is a # symlink to `object' that will be added to the tarball. - storeContents ? [] + storeContents ? [ ], # Extra commands to be executed before archiving files -, extraCommands ? "" + extraCommands ? "", # Extra tar arguments -, extraArgs ? "" + extraArgs ? "", # Command used for compression -, compressCommand ? "pixz -t" + compressCommand ? "pixz -t", # Extension for the compressed tarball -, compressionExtension ? ".xz" + compressionExtension ? ".xz", # extra inputs, like the compressor to use -, extraInputs ? [ pixz ] + extraInputs ? [ pixz ], }: let @@ -39,7 +42,12 @@ stdenv.mkDerivation { builder = ./make-system-tarball.sh; nativeBuildInputs = extraInputs; - inherit fileName extraArgs extraCommands compressCommand; + inherit + fileName + extraArgs + extraCommands + compressCommand + ; # !!! should use XML. sources = map (x: x.source) contents; diff --git a/nixos/lib/qemu-common.nix b/nixos/lib/qemu-common.nix index 5dcdc1c46c8a7d..5629b0b81d20f0 100644 --- a/nixos/lib/qemu-common.nix +++ b/nixos/lib/qemu-common.nix @@ -2,28 +2,30 @@ { lib, pkgs }: let - zeroPad = n: - lib.optionalString (n < 16) "0" + - (if n > 255 - then throw "Can't have more than 255 nets or nodes!" - else lib.toHexString n); + zeroPad = + n: + lib.optionalString (n < 16) "0" + + (if n > 255 then throw "Can't have more than 255 nets or nodes!" else lib.toHexString n); in rec { qemuNicMac = net: machine: "52:54:00:12:${zeroPad net}:${zeroPad machine}"; - qemuNICFlags = nic: net: machine: - [ - "-device virtio-net-pci,netdev=vlan${toString nic},mac=${qemuNicMac net machine}" - ''-netdev vde,id=vlan${toString nic},sock="$QEMU_VDE_SOCKET_${toString net}"'' - ]; + qemuNICFlags = nic: net: machine: [ + "-device virtio-net-pci,netdev=vlan${toString nic},mac=${qemuNicMac net machine}" + ''-netdev vde,id=vlan${toString nic},sock="$QEMU_VDE_SOCKET_${toString net}"'' + ]; qemuSerialDevice = - if with pkgs.stdenv.hostPlatform; isx86 || isLoongArch64 || isMips64 || isRiscV then "ttyS0" - else if (with pkgs.stdenv.hostPlatform; isAarch || isPower) then "ttyAMA0" - else throw "Unknown QEMU serial device for system '${pkgs.stdenv.hostPlatform.system}'"; + if with pkgs.stdenv.hostPlatform; isx86 || isLoongArch64 || isMips64 || isRiscV then + "ttyS0" + else if (with pkgs.stdenv.hostPlatform; isAarch || isPower) then + "ttyAMA0" + else + throw "Unknown QEMU serial device for system '${pkgs.stdenv.hostPlatform.system}'"; - qemuBinary = qemuPkg: + qemuBinary = + qemuPkg: let hostStdenv = qemuPkg.stdenv; hostSystem = hostStdenv.system; @@ -54,7 +56,8 @@ rec { supportedSystems = [ "linux" ] ++ (lib.attrNames otherHostGuestMatrix); in throw "Unsupported host system ${hostSystem}, supported: ${lib.concatStringsSep ", " supportedSystems}"; - throwUnsupportedGuestSystem = guestMap: + throwUnsupportedGuestSystem = + guestMap: throw "Unsupported guest system ${guestSystem} for host ${hostSystem}, supported: ${lib.concatStringsSep ", " (lib.attrNames guestMap)}"; in if hostStdenv.hostPlatform.isLinux then diff --git a/nixos/lib/systemd-network-units.nix b/nixos/lib/systemd-network-units.nix index c35309a6d2628c..ffaefa972767f4 100644 --- a/nixos/lib/systemd-network-units.nix +++ b/nixos/lib/systemd-network-units.nix @@ -9,252 +9,343 @@ let ; attrsToSection = systemdUtils.lib.attrsToSection; - commonMatchText = def: + commonMatchText = + def: optionalString (def.matchConfig != { }) '' [Match] ${attrsToSection def.matchConfig} ''; -in { - linkToUnit = def: - commonMatchText def + '' +in +{ + linkToUnit = + def: + commonMatchText def + + '' [Link] ${attrsToSection def.linkConfig} - '' + def.extraConfig; + '' + + def.extraConfig; - netdevToUnit = def: - commonMatchText def + '' + netdevToUnit = + def: + commonMatchText def + + '' [NetDev] ${attrsToSection def.netdevConfig} - '' + optionalString (def.bridgeConfig != { }) '' + '' + + optionalString (def.bridgeConfig != { }) '' [Bridge] ${attrsToSection def.bridgeConfig} - '' + optionalString (def.vlanConfig != { }) '' + '' + + optionalString (def.vlanConfig != { }) '' [VLAN] ${attrsToSection def.vlanConfig} - '' + optionalString (def.ipvlanConfig != { }) '' + '' + + optionalString (def.ipvlanConfig != { }) '' [IPVLAN] ${attrsToSection def.ipvlanConfig} - '' + optionalString (def.ipvtapConfig != { }) '' + '' + + optionalString (def.ipvtapConfig != { }) '' [IPVTAP] ${attrsToSection def.ipvtapConfig} - '' + optionalString (def.macvlanConfig != { }) '' + '' + + optionalString (def.macvlanConfig != { }) '' [MACVLAN] ${attrsToSection def.macvlanConfig} - '' + optionalString (def.vxlanConfig != { }) '' + '' + + optionalString (def.vxlanConfig != { }) '' [VXLAN] ${attrsToSection def.vxlanConfig} - '' + optionalString (def.tunnelConfig != { }) '' + '' + + optionalString (def.tunnelConfig != { }) '' [Tunnel] ${attrsToSection def.tunnelConfig} - '' + optionalString (def.fooOverUDPConfig != { }) '' + '' + + optionalString (def.fooOverUDPConfig != { }) '' [FooOverUDP] ${attrsToSection def.fooOverUDPConfig} - '' + optionalString (def.peerConfig != { }) '' + '' + + optionalString (def.peerConfig != { }) '' [Peer] ${attrsToSection def.peerConfig} - '' + optionalString (def.tunConfig != { }) '' + '' + + optionalString (def.tunConfig != { }) '' [Tun] ${attrsToSection def.tunConfig} - '' + optionalString (def.tapConfig != { }) '' + '' + + optionalString (def.tapConfig != { }) '' [Tap] ${attrsToSection def.tapConfig} - '' + optionalString (def.l2tpConfig != { }) '' + '' + + optionalString (def.l2tpConfig != { }) '' [L2TP] ${attrsToSection def.l2tpConfig} - '' + flip concatMapStrings def.l2tpSessions (x: '' + '' + + flip concatMapStrings def.l2tpSessions (x: '' [L2TPSession] ${attrsToSection x} - '') + optionalString (def.wireguardConfig != { }) '' + '') + + optionalString (def.wireguardConfig != { }) '' [WireGuard] ${attrsToSection def.wireguardConfig} - '' + flip concatMapStrings def.wireguardPeers (x: '' + '' + + flip concatMapStrings def.wireguardPeers (x: '' [WireGuardPeer] ${attrsToSection x} - '') + optionalString (def.bondConfig != { }) '' + '') + + optionalString (def.bondConfig != { }) '' [Bond] ${attrsToSection def.bondConfig} - '' + optionalString (def.xfrmConfig != { }) '' + '' + + optionalString (def.xfrmConfig != { }) '' [Xfrm] ${attrsToSection def.xfrmConfig} - '' + optionalString (def.vrfConfig != { }) '' + '' + + optionalString (def.vrfConfig != { }) '' [VRF] ${attrsToSection def.vrfConfig} - '' + optionalString (def.wlanConfig != { }) '' + '' + + optionalString (def.wlanConfig != { }) '' [WLAN] ${attrsToSection def.wlanConfig} - '' + optionalString (def.batmanAdvancedConfig != { }) '' + '' + + optionalString (def.batmanAdvancedConfig != { }) '' [BatmanAdvanced] ${attrsToSection def.batmanAdvancedConfig} - '' + def.extraConfig; + '' + + def.extraConfig; - networkToUnit = def: - commonMatchText def + optionalString (def.linkConfig != { }) '' + networkToUnit = + def: + commonMatchText def + + optionalString (def.linkConfig != { }) '' [Link] ${attrsToSection def.linkConfig} - '' + '' + '' + + '' [Network] - '' + attrsToSection def.networkConfig + '' + + attrsToSection def.networkConfig + optionalString (def.address != [ ]) '' ${concatStringsSep "\n" (map (s: "Address=${s}") def.address)} - '' + optionalString (def.gateway != [ ]) '' + '' + + optionalString (def.gateway != [ ]) '' ${concatStringsSep "\n" (map (s: "Gateway=${s}") def.gateway)} - '' + optionalString (def.dns != [ ]) '' + '' + + optionalString (def.dns != [ ]) '' ${concatStringsSep "\n" (map (s: "DNS=${s}") def.dns)} - '' + optionalString (def.ntp != [ ]) '' + '' + + optionalString (def.ntp != [ ]) '' ${concatStringsSep "\n" (map (s: "NTP=${s}") def.ntp)} - '' + optionalString (def.bridge != [ ]) '' + '' + + optionalString (def.bridge != [ ]) '' ${concatStringsSep "\n" (map (s: "Bridge=${s}") def.bridge)} - '' + optionalString (def.bond != [ ]) '' + '' + + optionalString (def.bond != [ ]) '' ${concatStringsSep "\n" (map (s: "Bond=${s}") def.bond)} - '' + optionalString (def.vrf != [ ]) '' + '' + + optionalString (def.vrf != [ ]) '' ${concatStringsSep "\n" (map (s: "VRF=${s}") def.vrf)} - '' + optionalString (def.vlan != [ ]) '' + '' + + optionalString (def.vlan != [ ]) '' ${concatStringsSep "\n" (map (s: "VLAN=${s}") def.vlan)} - '' + optionalString (def.macvlan != [ ]) '' + '' + + optionalString (def.macvlan != [ ]) '' ${concatStringsSep "\n" (map (s: "MACVLAN=${s}") def.macvlan)} - '' + optionalString (def.macvtap != [ ]) '' + '' + + optionalString (def.macvtap != [ ]) '' ${concatStringsSep "\n" (map (s: "MACVTAP=${s}") def.macvtap)} - '' + optionalString (def.vxlan != [ ]) '' + '' + + optionalString (def.vxlan != [ ]) '' ${concatStringsSep "\n" (map (s: "VXLAN=${s}") def.vxlan)} - '' + optionalString (def.tunnel != [ ]) '' + '' + + optionalString (def.tunnel != [ ]) '' ${concatStringsSep "\n" (map (s: "Tunnel=${s}") def.tunnel)} - '' + optionalString (def.xfrm != [ ]) '' + '' + + optionalString (def.xfrm != [ ]) '' ${concatStringsSep "\n" (map (s: "Xfrm=${s}") def.xfrm)} - '' + "\n" + flip concatMapStrings def.addresses (x: '' + '' + + "\n" + + flip concatMapStrings def.addresses (x: '' [Address] ${attrsToSection x} - '') + flip concatMapStrings def.routingPolicyRules (x: '' + '') + + flip concatMapStrings def.routingPolicyRules (x: '' [RoutingPolicyRule] ${attrsToSection x} - '') + flip concatMapStrings def.routes (x: '' + '') + + flip concatMapStrings def.routes (x: '' [Route] ${attrsToSection x} - '') + optionalString (def.dhcpV4Config != { }) '' + '') + + optionalString (def.dhcpV4Config != { }) '' [DHCPv4] ${attrsToSection def.dhcpV4Config} - '' + optionalString (def.dhcpV6Config != { }) '' + '' + + optionalString (def.dhcpV6Config != { }) '' [DHCPv6] ${attrsToSection def.dhcpV6Config} - '' + optionalString (def.dhcpPrefixDelegationConfig != { }) '' + '' + + optionalString (def.dhcpPrefixDelegationConfig != { }) '' [DHCPPrefixDelegation] ${attrsToSection def.dhcpPrefixDelegationConfig} - '' + optionalString (def.ipv6AcceptRAConfig != { }) '' + '' + + optionalString (def.ipv6AcceptRAConfig != { }) '' [IPv6AcceptRA] ${attrsToSection def.ipv6AcceptRAConfig} - '' + optionalString (def.dhcpServerConfig != { }) '' + '' + + optionalString (def.dhcpServerConfig != { }) '' [DHCPServer] ${attrsToSection def.dhcpServerConfig} - '' + optionalString (def.ipv6SendRAConfig != { }) '' + '' + + optionalString (def.ipv6SendRAConfig != { }) '' [IPv6SendRA] ${attrsToSection def.ipv6SendRAConfig} - '' + flip concatMapStrings def.ipv6PREF64Prefixes (x: '' + '' + + flip concatMapStrings def.ipv6PREF64Prefixes (x: '' [IPv6PREF64Prefix] ${attrsToSection x} - '') + flip concatMapStrings def.ipv6Prefixes (x: '' + '') + + flip concatMapStrings def.ipv6Prefixes (x: '' [IPv6Prefix] ${attrsToSection x} - '') + flip concatMapStrings def.ipv6RoutePrefixes (x: '' + '') + + flip concatMapStrings def.ipv6RoutePrefixes (x: '' [IPv6RoutePrefix] ${attrsToSection x} - '') + flip concatMapStrings def.dhcpServerStaticLeases (x: '' + '') + + flip concatMapStrings def.dhcpServerStaticLeases (x: '' [DHCPServerStaticLease] ${attrsToSection x} - '') + optionalString (def.bridgeConfig != { }) '' + '') + + optionalString (def.bridgeConfig != { }) '' [Bridge] ${attrsToSection def.bridgeConfig} - '' + flip concatMapStrings def.bridgeFDBs (x: '' + '' + + flip concatMapStrings def.bridgeFDBs (x: '' [BridgeFDB] ${attrsToSection x} - '') + flip concatMapStrings def.bridgeMDBs (x: '' + '') + + flip concatMapStrings def.bridgeMDBs (x: '' [BridgeMDB] ${attrsToSection x} - '') + optionalString (def.lldpConfig != { }) '' + '') + + optionalString (def.lldpConfig != { }) '' [LLDP] ${attrsToSection def.lldpConfig} - '' + optionalString (def.canConfig != { }) '' + '' + + optionalString (def.canConfig != { }) '' [CAN] ${attrsToSection def.canConfig} - '' + optionalString (def.ipoIBConfig != { }) '' + '' + + optionalString (def.ipoIBConfig != { }) '' [IPoIB] ${attrsToSection def.ipoIBConfig} - '' + optionalString (def.qdiscConfig != { }) '' + '' + + optionalString (def.qdiscConfig != { }) '' [QDisc] ${attrsToSection def.qdiscConfig} - '' + optionalString (def.networkEmulatorConfig != { }) '' + '' + + optionalString (def.networkEmulatorConfig != { }) '' [NetworkEmulator] ${attrsToSection def.networkEmulatorConfig} - '' + optionalString (def.tokenBucketFilterConfig != { }) '' + '' + + optionalString (def.tokenBucketFilterConfig != { }) '' [TokenBucketFilter] ${attrsToSection def.tokenBucketFilterConfig} - '' + optionalString (def.pieConfig != { }) '' + '' + + optionalString (def.pieConfig != { }) '' [PIE] ${attrsToSection def.pieConfig} - '' + optionalString (def.flowQueuePIEConfig != { }) '' + '' + + optionalString (def.flowQueuePIEConfig != { }) '' [FlowQueuePIE] ${attrsToSection def.flowQueuePIEConfig} - '' + optionalString (def.stochasticFairBlueConfig != { }) '' + '' + + optionalString (def.stochasticFairBlueConfig != { }) '' [StochasticFairBlue] ${attrsToSection def.stochasticFairBlueConfig} - '' + optionalString (def.stochasticFairnessQueueingConfig != { }) '' + '' + + optionalString (def.stochasticFairnessQueueingConfig != { }) '' [StochasticFairnessQueueing] ${attrsToSection def.stochasticFairnessQueueingConfig} - '' + optionalString (def.bfifoConfig != { }) '' + '' + + optionalString (def.bfifoConfig != { }) '' [BFIFO] ${attrsToSection def.bfifoConfig} - '' + optionalString (def.pfifoConfig != { }) '' + '' + + optionalString (def.pfifoConfig != { }) '' [PFIFO] ${attrsToSection def.pfifoConfig} - '' + optionalString (def.pfifoHeadDropConfig != { }) '' + '' + + optionalString (def.pfifoHeadDropConfig != { }) '' [PFIFOHeadDrop] ${attrsToSection def.pfifoHeadDropConfig} - '' + optionalString (def.pfifoFastConfig != { }) '' + '' + + optionalString (def.pfifoFastConfig != { }) '' [PFIFOFast] ${attrsToSection def.pfifoFastConfig} - '' + optionalString (def.cakeConfig != { }) '' + '' + + optionalString (def.cakeConfig != { }) '' [CAKE] ${attrsToSection def.cakeConfig} - '' + optionalString (def.controlledDelayConfig != { }) '' + '' + + optionalString (def.controlledDelayConfig != { }) '' [ControlledDelay] ${attrsToSection def.controlledDelayConfig} - '' + optionalString (def.deficitRoundRobinSchedulerConfig != { }) '' + '' + + optionalString (def.deficitRoundRobinSchedulerConfig != { }) '' [DeficitRoundRobinScheduler] ${attrsToSection def.deficitRoundRobinSchedulerConfig} - '' + optionalString (def.deficitRoundRobinSchedulerClassConfig != { }) '' + '' + + optionalString (def.deficitRoundRobinSchedulerClassConfig != { }) '' [DeficitRoundRobinSchedulerClass] ${attrsToSection def.deficitRoundRobinSchedulerClassConfig} - '' + optionalString (def.enhancedTransmissionSelectionConfig != { }) '' + '' + + optionalString (def.enhancedTransmissionSelectionConfig != { }) '' [EnhancedTransmissionSelection] ${attrsToSection def.enhancedTransmissionSelectionConfig} - '' + optionalString (def.genericRandomEarlyDetectionConfig != { }) '' + '' + + optionalString (def.genericRandomEarlyDetectionConfig != { }) '' [GenericRandomEarlyDetection] ${attrsToSection def.genericRandomEarlyDetectionConfig} - '' + optionalString (def.fairQueueingControlledDelayConfig != { }) '' + '' + + optionalString (def.fairQueueingControlledDelayConfig != { }) '' [FairQueueingControlledDelay] ${attrsToSection def.fairQueueingControlledDelayConfig} - '' + optionalString (def.fairQueueingConfig != { }) '' + '' + + optionalString (def.fairQueueingConfig != { }) '' [FairQueueing] ${attrsToSection def.fairQueueingConfig} - '' + optionalString (def.trivialLinkEqualizerConfig != { }) '' + '' + + optionalString (def.trivialLinkEqualizerConfig != { }) '' [TrivialLinkEqualizer] ${attrsToSection def.trivialLinkEqualizerConfig} - '' + optionalString (def.hierarchyTokenBucketConfig != { }) '' + '' + + optionalString (def.hierarchyTokenBucketConfig != { }) '' [HierarchyTokenBucket] ${attrsToSection def.hierarchyTokenBucketConfig} - '' + optionalString (def.hierarchyTokenBucketClassConfig != { }) '' + '' + + optionalString (def.hierarchyTokenBucketClassConfig != { }) '' [HierarchyTokenBucketClass] ${attrsToSection def.hierarchyTokenBucketClassConfig} - '' + optionalString (def.heavyHitterFilterConfig != { }) '' + '' + + optionalString (def.heavyHitterFilterConfig != { }) '' [HeavyHitterFilter] ${attrsToSection def.heavyHitterFilterConfig} - '' + optionalString (def.quickFairQueueingConfig != { }) '' + '' + + optionalString (def.quickFairQueueingConfig != { }) '' [QuickFairQueueing] ${attrsToSection def.quickFairQueueingConfig} - '' + optionalString (def.quickFairQueueingConfigClass != { }) '' + '' + + optionalString (def.quickFairQueueingConfigClass != { }) '' [QuickFairQueueingClass] ${attrsToSection def.quickFairQueueingConfigClass} - '' + flip concatMapStrings def.bridgeVLANs (x: '' + '' + + flip concatMapStrings def.bridgeVLANs (x: '' [BridgeVLAN] ${attrsToSection x} - '') + def.extraConfig; + '') + + def.extraConfig; } diff --git a/nixos/lib/systemd-types.nix b/nixos/lib/systemd-types.nix index 65ddb2458627c8..e3926c14252fcc 100644 --- a/nixos/lib/systemd-types.nix +++ b/nixos/lib/systemd-types.nix @@ -1,4 +1,8 @@ -{ lib, systemdUtils, pkgs }: +{ + lib, + systemdUtils, + pkgs, +}: let inherit (systemdUtils.lib) @@ -57,105 +61,196 @@ let submodule ; - initrdStorePathModule = { config, ... }: { - options = { - enable = (mkEnableOption "copying of this file and symlinking it") // { default = true; }; - - target = mkOption { - type = nullOr path; - description = '' - Path of the symlink. - ''; - default = null; - }; - - source = mkOption { - type = path; - description = "Path of the source file."; - }; + initrdStorePathModule = + { config, ... }: + { + options = { + enable = (mkEnableOption "copying of this file and symlinking it") // { + default = true; + }; - dlopen = { - usePriority = mkOption { - type = enum [ "required" "recommended" "suggested" ]; - default = "recommended"; + target = mkOption { + type = nullOr path; description = '' - Priority of dlopen ELF notes to include. "required" is - minimal, "recommended" includes "required", and - "suggested" includes "recommended". - - See: https://systemd.io/ELF_DLOPEN_METADATA/ + Path of the symlink. ''; + default = null; }; - features = mkOption { - type = listOf singleLineStr; - default = [ ]; - description = '' - Features to enable via dlopen ELF notes. These will be in - addition to anything included via 'usePriority', - regardless of their priority. - ''; + source = mkOption { + type = path; + description = "Path of the source file."; + }; + + dlopen = { + usePriority = mkOption { + type = enum [ + "required" + "recommended" + "suggested" + ]; + default = "recommended"; + description = '' + Priority of dlopen ELF notes to include. "required" is + minimal, "recommended" includes "required", and + "suggested" includes "recommended". + + See: https://systemd.io/ELF_DLOPEN_METADATA/ + ''; + }; + + features = mkOption { + type = listOf singleLineStr; + default = [ ]; + description = '' + Features to enable via dlopen ELF notes. These will be in + addition to anything included via 'usePriority', + regardless of their priority. + ''; + }; }; }; }; - }; in { - units = attrsOf (submodule ({ name, config, ... }: { - options = concreteUnitOptions; - config = { - name = mkDefault name; - unit = mkDefault (makeUnit name config); - }; - })); + units = attrsOf ( + submodule ( + { name, config, ... }: + { + options = concreteUnitOptions; + config = { + name = mkDefault name; + unit = mkDefault (makeUnit name config); + }; + } + ) + ); - services = attrsOf (submodule [ stage2ServiceOptions unitConfig stage2ServiceConfig ]); - initrdServices = attrsOf (submodule [ stage1ServiceOptions unitConfig stage1ServiceConfig ]); + services = attrsOf (submodule [ + stage2ServiceOptions + unitConfig + stage2ServiceConfig + ]); + initrdServices = attrsOf (submodule [ + stage1ServiceOptions + unitConfig + stage1ServiceConfig + ]); - targets = attrsOf (submodule [ stage2CommonUnitOptions unitConfig targetConfig ]); - initrdTargets = attrsOf (submodule [ stage1CommonUnitOptions unitConfig targetConfig ]); + targets = attrsOf (submodule [ + stage2CommonUnitOptions + unitConfig + targetConfig + ]); + initrdTargets = attrsOf (submodule [ + stage1CommonUnitOptions + unitConfig + targetConfig + ]); - sockets = attrsOf (submodule [ stage2SocketOptions unitConfig socketConfig]); - initrdSockets = attrsOf (submodule [ stage1SocketOptions unitConfig socketConfig ]); + sockets = attrsOf (submodule [ + stage2SocketOptions + unitConfig + socketConfig + ]); + initrdSockets = attrsOf (submodule [ + stage1SocketOptions + unitConfig + socketConfig + ]); - timers = attrsOf (submodule [ stage2TimerOptions unitConfig timerConfig ]); - initrdTimers = attrsOf (submodule [ stage1TimerOptions unitConfig timerConfig ]); + timers = attrsOf (submodule [ + stage2TimerOptions + unitConfig + timerConfig + ]); + initrdTimers = attrsOf (submodule [ + stage1TimerOptions + unitConfig + timerConfig + ]); - paths = attrsOf (submodule [ stage2PathOptions unitConfig pathConfig ]); - initrdPaths = attrsOf (submodule [ stage1PathOptions unitConfig pathConfig ]); + paths = attrsOf (submodule [ + stage2PathOptions + unitConfig + pathConfig + ]); + initrdPaths = attrsOf (submodule [ + stage1PathOptions + unitConfig + pathConfig + ]); - slices = attrsOf (submodule [ stage2SliceOptions unitConfig sliceConfig ]); - initrdSlices = attrsOf (submodule [ stage1SliceOptions unitConfig sliceConfig ]); + slices = attrsOf (submodule [ + stage2SliceOptions + unitConfig + sliceConfig + ]); + initrdSlices = attrsOf (submodule [ + stage1SliceOptions + unitConfig + sliceConfig + ]); - mounts = listOf (submodule [ stage2MountOptions unitConfig mountConfig ]); - initrdMounts = listOf (submodule [ stage1MountOptions unitConfig mountConfig ]); + mounts = listOf (submodule [ + stage2MountOptions + unitConfig + mountConfig + ]); + initrdMounts = listOf (submodule [ + stage1MountOptions + unitConfig + mountConfig + ]); - automounts = listOf (submodule [ stage2AutomountOptions unitConfig automountConfig ]); - initrdAutomounts = attrsOf (submodule [ stage1AutomountOptions unitConfig automountConfig ]); + automounts = listOf (submodule [ + stage2AutomountOptions + unitConfig + automountConfig + ]); + initrdAutomounts = attrsOf (submodule [ + stage1AutomountOptions + unitConfig + automountConfig + ]); - initrdStorePath = listOf (coercedTo - (oneOf [ singleLineStr package ]) - (source: { inherit source; }) - (submodule initrdStorePathModule)); + initrdStorePath = listOf ( + coercedTo (oneOf [ + singleLineStr + package + ]) (source: { inherit source; }) (submodule initrdStorePathModule) + ); - initrdContents = attrsOf (submodule ({ config, options, name, ... }: { - imports = [ initrdStorePathModule ]; - options = { - text = mkOption { - default = null; - type = nullOr lines; - description = "Text of the file."; - }; - }; + initrdContents = attrsOf ( + submodule ( + { + config, + options, + name, + ... + }: + { + imports = [ initrdStorePathModule ]; + options = { + text = mkOption { + default = null; + type = nullOr lines; + description = "Text of the file."; + }; + }; - config = { - target = mkDefault name; - source = mkIf (config.text != null) ( - let name' = "initrd-" + baseNameOf name; - in mkDerivedConfig options.text (pkgs.writeText name') - ); - }; - })); + config = { + target = mkDefault name; + source = mkIf (config.text != null) ( + let + name' = "initrd-" + baseNameOf name; + in + mkDerivedConfig options.text (pkgs.writeText name') + ); + }; + } + ) + ); } diff --git a/nixos/lib/test-driver/nixos-test-driver-docstrings.nix b/nixos/lib/test-driver/nixos-test-driver-docstrings.nix index a3ef50e4e82050..b76da9ac5fb21a 100644 --- a/nixos/lib/test-driver/nixos-test-driver-docstrings.nix +++ b/nixos/lib/test-driver/nixos-test-driver-docstrings.nix @@ -1,9 +1,12 @@ -{ runCommand -, python3 +{ + runCommand, + python3, }: let - env = { nativeBuildInputs = [ python3 ]; }; + env = { + nativeBuildInputs = [ python3 ]; + }; in runCommand "nixos-test-driver-docstrings" env '' diff --git a/nixos/lib/testing-python.nix b/nixos/lib/testing-python.nix index f5222351518b51..d01c1d9b5e0959 100644 --- a/nixos/lib/testing-python.nix +++ b/nixos/lib/testing-python.nix @@ -1,78 +1,101 @@ -args@ -{ system -, pkgs ? import ../.. { inherit system config; } +args@{ + system, + pkgs ? import ../.. { inherit system config; }, # Use a minimal kernel? -, minimal ? false + minimal ? false, # Ignored -, config ? { } + config ? { }, # !!! See comment about args in lib/modules.nix -, specialArgs ? throw "legacy - do not use, see error below" + specialArgs ? throw "legacy - do not use, see error below", # Modules to add to each VM -, extraConfigurations ? [ ] + extraConfigurations ? [ ], }: let nixos-lib = import ./default.nix { inherit (pkgs) lib; }; in -pkgs.lib.throwIf (args?specialArgs) '' - testing-python.nix: `specialArgs` is not supported anymore. If you're looking - for the public interface to the NixOS test framework, use `runTest`, and - `node.specialArgs`. - See https://nixos.org/manual/nixos/unstable/index.html#sec-calling-nixos-tests - and https://nixos.org/manual/nixos/unstable/index.html#test-opt-node.specialArgs -'' -rec { +pkgs.lib.throwIf (args ? specialArgs) + '' + testing-python.nix: `specialArgs` is not supported anymore. If you're looking + for the public interface to the NixOS test framework, use `runTest`, and + `node.specialArgs`. + See https://nixos.org/manual/nixos/unstable/index.html#sec-calling-nixos-tests + and https://nixos.org/manual/nixos/unstable/index.html#test-opt-node.specialArgs + '' + rec { - inherit pkgs; + inherit pkgs; - evalTest = module: nixos-lib.evalTest { imports = [ extraTestModule module ]; }; - runTest = module: nixos-lib.runTest { imports = [ extraTestModule module ]; }; + evalTest = + module: + nixos-lib.evalTest { + imports = [ + extraTestModule + module + ]; + }; + runTest = + module: + nixos-lib.runTest { + imports = [ + extraTestModule + module + ]; + }; - extraTestModule = { - config = { - hostPkgs = pkgs; + extraTestModule = { + config = { + hostPkgs = pkgs; + }; }; - }; - # Make a full-blown test (legacy) - # For an official public interface to the tests, see - # https://nixos.org/manual/nixos/unstable/index.html#sec-calling-nixos-tests - makeTest = - { machine ? null - , nodes ? {} - , testScript - , enableOCR ? false - , globalTimeout ? (60 * 60) - , name ? "unnamed" - , skipTypeCheck ? false - # Skip linting (mainly intended for faster dev cycles) - , skipLint ? false - , passthru ? {} - , meta ? {} - , # For meta.position - pos ? # position used in error messages and for meta.position - (if meta.description or null != null - then builtins.unsafeGetAttrPos "description" meta - else builtins.unsafeGetAttrPos "testScript" t) - , extraPythonPackages ? (_ : []) - , interactive ? {} - } @ t: let - testConfig = - (evalTest { - imports = [ - { _file = "makeTest parameters"; config = t; } - { - defaults = { - _file = "makeTest: extraConfigurations"; - imports = extraConfigurations; - }; - } - ]; - }).config; - in - testConfig.test # For nix-build - // testConfig; # For all-tests.nix + # Make a full-blown test (legacy) + # For an official public interface to the tests, see + # https://nixos.org/manual/nixos/unstable/index.html#sec-calling-nixos-tests + makeTest = + { + machine ? null, + nodes ? { }, + testScript, + enableOCR ? false, + globalTimeout ? (60 * 60), + name ? "unnamed", + skipTypeCheck ? false, + # Skip linting (mainly intended for faster dev cycles) + skipLint ? false, + passthru ? { }, + meta ? { }, + # For meta.position + pos ? # position used in error messages and for meta.position + ( + if meta.description or null != null then + builtins.unsafeGetAttrPos "description" meta + else + builtins.unsafeGetAttrPos "testScript" t + ), + extraPythonPackages ? (_: [ ]), + interactive ? { }, + }@t: + let + testConfig = + (evalTest { + imports = [ + { + _file = "makeTest parameters"; + config = t; + } + { + defaults = { + _file = "makeTest: extraConfigurations"; + imports = extraConfigurations; + }; + } + ]; + }).config; + in + testConfig.test # For nix-build + // testConfig; # For all-tests.nix - simpleTest = as: (makeTest as).test; + simpleTest = as: (makeTest as).test; -} + } diff --git a/nixos/lib/testing/default.nix b/nixos/lib/testing/default.nix index a89f734b1e6450..7fdd454c22b8d1 100644 --- a/nixos/lib/testing/default.nix +++ b/nixos/lib/testing/default.nix @@ -1,11 +1,21 @@ { lib }: let - evalTest = module: lib.evalModules { - modules = testModules ++ [ module ]; - class = "nixosTest"; - }; - runTest = module: (evalTest ({ config, ... }: { imports = [ module ]; result = config.test; })).config.result; + evalTest = + module: + lib.evalModules { + modules = testModules ++ [ module ]; + class = "nixosTest"; + }; + runTest = + module: + (evalTest ( + { config, ... }: + { + imports = [ module ]; + result = config.test; + } + )).config.result; testModules = [ ./call-test.nix diff --git a/nixos/lib/testing/interactive.nix b/nixos/lib/testing/interactive.nix index 0b12096692828d..959cf463160c3a 100644 --- a/nixos/lib/testing/interactive.nix +++ b/nixos/lib/testing/interactive.nix @@ -1,4 +1,10 @@ -{ config, lib, moduleType, hostPkgs, ... }: +{ + config, + lib, + moduleType, + hostPkgs, + ... +}: let inherit (lib) mkOption types; in diff --git a/nixos/lib/testing/legacy.nix b/nixos/lib/testing/legacy.nix index b3105755660159..9c901ce061470f 100644 --- a/nixos/lib/testing/legacy.nix +++ b/nixos/lib/testing/legacy.nix @@ -1,4 +1,9 @@ -{ config, options, lib, ... }: +{ + config, + options, + lib, + ... +}: let inherit (lib) mkIf mkOption types; in diff --git a/nixos/lib/testing/meta.nix b/nixos/lib/testing/meta.nix index bdf313e5b119ff..0a4c89ed4b0639 100644 --- a/nixos/lib/testing/meta.nix +++ b/nixos/lib/testing/meta.nix @@ -15,14 +15,14 @@ in options = { maintainers = lib.mkOption { type = types.listOf types.raw; - default = []; + default = [ ]; description = '' The [list of maintainers](https://nixos.org/manual/nixpkgs/stable/#var-meta-maintainers) for this test. ''; }; timeout = lib.mkOption { type = types.nullOr types.int; - default = 3600; # 1 hour + default = 3600; # 1 hour description = '' The [{option}`test`](#test-opt-test)'s [`meta.timeout`](https://nixos.org/manual/nixpkgs/stable/#var-meta-timeout) in seconds. ''; @@ -43,7 +43,7 @@ in }; }; }; - default = {}; + default = { }; }; }; } diff --git a/nixos/lib/testing/network.nix b/nixos/lib/testing/network.nix index 8e6d383e6257f1..c393056009d830 100644 --- a/nixos/lib/testing/network.nix +++ b/nixos/lib/testing/network.nix @@ -2,20 +2,33 @@ let inherit (lib) - attrNames concatMap concatMapStrings flip forEach head - listToAttrs mkDefault mkOption nameValuePair optionalString - range toLower types zipListsWith zipLists + attrNames + concatMap + concatMapStrings + flip + forEach + head + listToAttrs + mkDefault + mkOption + nameValuePair + optionalString + range + toLower + types + zipListsWith + zipLists ; - nodeNumbers = - listToAttrs - (zipListsWith - nameValuePair - (attrNames nodes) - (range 1 254) - ); + nodeNumbers = listToAttrs (zipListsWith nameValuePair (attrNames nodes) (range 1 254)); - networkModule = { config, nodes, pkgs, ... }: + networkModule = + { + config, + nodes, + pkgs, + ... + }: let qemu-common = import ../qemu-common.nix { inherit lib pkgs; }; @@ -31,7 +44,8 @@ let # Automatically assign IP addresses to requested interfaces. assignIPs = lib.filter (i: i.assignIP) interfaces; - ipInterfaces = forEach assignIPs (i: + ipInterfaces = forEach assignIPs ( + i: nameValuePair i.name { ipv4.addresses = [ { @@ -45,47 +59,59 @@ let prefixLength = 64; } ]; - }); + } + ); - qemuOptions = lib.flatten (forEach interfacesNumbered ({ fst, snd }: - qemu-common.qemuNICFlags snd fst.vlan config.virtualisation.test.nodeNumber)); - udevRules = forEach interfacesNumbered ({ fst, snd }: + qemuOptions = lib.flatten ( + forEach interfacesNumbered ( + { fst, snd }: qemu-common.qemuNICFlags snd fst.vlan config.virtualisation.test.nodeNumber + ) + ); + udevRules = forEach interfacesNumbered ( + { fst, snd }: # MAC Addresses for QEMU network devices are lowercase, and udev string comparison is case-sensitive. - ''SUBSYSTEM=="net",ACTION=="add",ATTR{address}=="${toLower(qemu-common.qemuNicMac fst.vlan config.virtualisation.test.nodeNumber)}",NAME="${fst.name}"''); - - networkConfig = - { - networking.hostName = mkDefault config.virtualisation.test.nodeName; - - networking.interfaces = listToAttrs ipInterfaces; - - networking.primaryIPAddress = - optionalString (ipInterfaces != [ ]) (head (head ipInterfaces).value.ipv4.addresses).address; - - networking.primaryIPv6Address = - optionalString (ipInterfaces != [ ]) (head (head ipInterfaces).value.ipv6.addresses).address; - - # Put the IP addresses of all VMs in this machine's - # /etc/hosts file. If a machine has multiple - # interfaces, use the IP address corresponding to - # the first interface (i.e. the first network in its - # virtualisation.vlans option). - networking.extraHosts = flip concatMapStrings (attrNames nodes) - (m': - let - config = nodes.${m'}; - hostnames = - optionalString (config.networking.domain != null) "${config.networking.hostName}.${config.networking.domain} " + - "${config.networking.hostName}\n"; - in - optionalString (config.networking.primaryIPAddress != "") - "${config.networking.primaryIPAddress} ${hostnames}" + - optionalString (config.networking.primaryIPv6Address != "") - ("${config.networking.primaryIPv6Address} ${hostnames}")); - - virtualisation.qemu.options = qemuOptions; - boot.initrd.services.udev.rules = concatMapStrings (x: x + "\n") udevRules; - }; + ''SUBSYSTEM=="net",ACTION=="add",ATTR{address}=="${toLower (qemu-common.qemuNicMac fst.vlan config.virtualisation.test.nodeNumber)}",NAME="${fst.name}"'' + ); + + networkConfig = { + networking.hostName = mkDefault config.virtualisation.test.nodeName; + + networking.interfaces = listToAttrs ipInterfaces; + + networking.primaryIPAddress = + optionalString (ipInterfaces != [ ]) + (head (head ipInterfaces).value.ipv4.addresses).address; + + networking.primaryIPv6Address = + optionalString (ipInterfaces != [ ]) + (head (head ipInterfaces).value.ipv6.addresses).address; + + # Put the IP addresses of all VMs in this machine's + # /etc/hosts file. If a machine has multiple + # interfaces, use the IP address corresponding to + # the first interface (i.e. the first network in its + # virtualisation.vlans option). + networking.extraHosts = flip concatMapStrings (attrNames nodes) ( + m': + let + config = nodes.${m'}; + hostnames = + optionalString ( + config.networking.domain != null + ) "${config.networking.hostName}.${config.networking.domain} " + + "${config.networking.hostName}\n"; + in + optionalString ( + config.networking.primaryIPAddress != "" + ) "${config.networking.primaryIPAddress} ${hostnames}" + + optionalString (config.networking.primaryIPv6Address != "") ( + "${config.networking.primaryIPv6Address} ${hostnames}" + ) + ); + + virtualisation.qemu.options = qemuOptions; + boot.initrd.services.udev.rules = concatMapStrings (x: x + "\n") udevRules; + }; in { @@ -97,50 +123,60 @@ let }; }; - nodeNumberModule = (regular@{ config, name, ... }: { - options = { - virtualisation.test.nodeName = mkOption { - internal = true; - default = name; - # We need to force this in specilisations, otherwise it'd be - # readOnly = true; - description = '' - The `name` in `nodes.`; stable across `specialisations`. - ''; - }; - virtualisation.test.nodeNumber = mkOption { - internal = true; - type = types.int; - readOnly = true; - default = nodeNumbers.${config.virtualisation.test.nodeName}; - description = '' - A unique number assigned for each node in `nodes`. - ''; - }; + nodeNumberModule = ( + regular@{ config, name, ... }: + { + options = { + virtualisation.test.nodeName = mkOption { + internal = true; + default = name; + # We need to force this in specilisations, otherwise it'd be + # readOnly = true; + description = '' + The `name` in `nodes.`; stable across `specialisations`. + ''; + }; + virtualisation.test.nodeNumber = mkOption { + internal = true; + type = types.int; + readOnly = true; + default = nodeNumbers.${config.virtualisation.test.nodeName}; + description = '' + A unique number assigned for each node in `nodes`. + ''; + }; - # specialisations override the `name` module argument, - # so we push the real `virtualisation.test.nodeName`. - specialisation = mkOption { - type = types.attrsOf (types.submodule { - options.configuration = mkOption { - type = types.submoduleWith { - modules = [ - { - config.virtualisation.test.nodeName = - # assert regular.config.virtualisation.test.nodeName != "configuration"; - regular.config.virtualisation.test.nodeName; - } - ]; - }; - }; - }); + # specialisations override the `name` module argument, + # so we push the real `virtualisation.test.nodeName`. + specialisation = mkOption { + type = types.attrsOf ( + types.submodule { + options.configuration = mkOption { + type = types.submoduleWith { + modules = [ + { + config.virtualisation.test.nodeName = + # assert regular.config.virtualisation.test.nodeName != "configuration"; + regular.config.virtualisation.test.nodeName; + } + ]; + }; + }; + } + ); + }; }; - }; - }); + } + ); in { config = { - extraBaseModules = { imports = [ networkModule nodeNumberModule ]; }; + extraBaseModules = { + imports = [ + networkModule + nodeNumberModule + ]; + }; }; } diff --git a/nixos/lib/testing/nixos-test-base.nix b/nixos/lib/testing/nixos-test-base.nix index c8b15a0ecce4cc..23358f2185b1f0 100644 --- a/nixos/lib/testing/nixos-test-base.nix +++ b/nixos/lib/testing/nixos-test-base.nix @@ -9,7 +9,10 @@ in imports = [ ../../modules/virtualisation/qemu-vm.nix ../../modules/testing/test-instrumentation.nix # !!! should only get added for automated test runs - { key = "no-manual"; documentation.nixos.enable = false; } + { + key = "no-manual"; + documentation.nixos.enable = false; + } { key = "no-revision"; # Make the revision metadata constant, in order to avoid needless retesting. @@ -22,11 +25,16 @@ in label = mkForce "test"; }; } - ({ config, ... }: { - # Don't pull in switch-to-configuration by default, except when specialisations or early boot shenanigans are involved. - # This is mostly a Hydra optimization, so we don't rebuild all the tests every time switch-to-configuration-ng changes. - key = "no-switch-to-configuration"; - system.switch.enable = mkDefault (config.isSpecialisation || config.specialisation != {} || config.virtualisation.installBootLoader); - }) + ( + { config, ... }: + { + # Don't pull in switch-to-configuration by default, except when specialisations or early boot shenanigans are involved. + # This is mostly a Hydra optimization, so we don't rebuild all the tests every time switch-to-configuration-ng changes. + key = "no-switch-to-configuration"; + system.switch.enable = mkDefault ( + config.isSpecialisation || config.specialisation != { } || config.virtualisation.installBootLoader + ); + } + ) ]; } diff --git a/nixos/lib/testing/nodes.nix b/nixos/lib/testing/nodes.nix index 4c528609fb4e99..caefac6c748cac 100644 --- a/nixos/lib/testing/nodes.nix +++ b/nixos/lib/testing/nodes.nix @@ -1,4 +1,10 @@ -testModuleArgs@{ config, lib, hostPkgs, nodes, ... }: +testModuleArgs@{ + config, + lib, + hostPkgs, + nodes, + ... +}: let inherit (lib) @@ -7,7 +13,8 @@ let mapAttrs mkDefault mkIf - mkOption mkForce + mkOption + mkForce optional optionalAttrs types @@ -16,8 +23,8 @@ let inherit (hostPkgs.stdenv) hostPlatform; guestSystem = - if hostPlatform.isLinux - then hostPlatform.system + if hostPlatform.isLinux then + hostPlatform.system else let hostToGuest = { @@ -27,39 +34,43 @@ let supportedHosts = lib.concatStringsSep ", " (lib.attrNames hostToGuest); - message = - "NixOS Test: don't know which VM guest system to pair with VM host system: ${hostPlatform.system}. Perhaps you intended to run the tests on a Linux host, or one of the following systems that may run NixOS tests: ${supportedHosts}"; + message = "NixOS Test: don't know which VM guest system to pair with VM host system: ${hostPlatform.system}. Perhaps you intended to run the tests on a Linux host, or one of the following systems that may run NixOS tests: ${supportedHosts}"; in - hostToGuest.${hostPlatform.system} or (throw message); - - baseOS = - import ../eval-config.nix { - inherit lib; - system = null; # use modularly defined system - inherit (config.node) specialArgs; - modules = [ config.defaults ]; - baseModules = (import ../../modules/module-list.nix) ++ - [ - ./nixos-test-base.nix - { key = "nodes"; _module.args.nodes = config.nodesCompat; } - ({ config, ... }: - { - virtualisation.qemu.package = testModuleArgs.config.qemu.package; - virtualisation.host.pkgs = hostPkgs; - }) - ({ options, ... }: { - key = "nodes.nix-pkgs"; - config = optionalAttrs (!config.node.pkgsReadOnly) ( - mkIf (!options.nixpkgs.pkgs.isDefined) { - # TODO: switch to nixpkgs.hostPlatform and make sure containers-imperative test still evaluates. - nixpkgs.system = guestSystem; - } - ); - }) - testModuleArgs.config.extraBaseModules - ]; - }; - + hostToGuest.${hostPlatform.system} or (throw message); + + baseOS = import ../eval-config.nix { + inherit lib; + system = null; # use modularly defined system + inherit (config.node) specialArgs; + modules = [ config.defaults ]; + baseModules = (import ../../modules/module-list.nix) ++ [ + ./nixos-test-base.nix + { + key = "nodes"; + _module.args.nodes = config.nodesCompat; + } + ( + { config, ... }: + { + virtualisation.qemu.package = testModuleArgs.config.qemu.package; + virtualisation.host.pkgs = hostPkgs; + } + ) + ( + { options, ... }: + { + key = "nodes.nix-pkgs"; + config = optionalAttrs (!config.node.pkgsReadOnly) ( + mkIf (!options.nixpkgs.pkgs.isDefined) { + # TODO: switch to nixpkgs.hostPlatform and make sure containers-imperative test still evaluates. + nixpkgs.system = guestSystem; + } + ); + } + ) + testModuleArgs.config.extraBaseModules + ]; + }; in @@ -148,14 +159,16 @@ in config = { _module.args.nodes = config.nodesCompat; - nodesCompat = - mapAttrs - (name: config: config // { - config = lib.warnIf (lib.oldestSupportedReleaseIsAtLeast 2211) + nodesCompat = mapAttrs ( + name: config: + config + // { + config = + lib.warnIf (lib.oldestSupportedReleaseIsAtLeast 2211) "Module argument `nodes.${name}.config` is deprecated. Use `nodes.${name}` instead." config; - }) - config.nodes; + } + ) config.nodes; passthru.nodes = config.nodesCompat; diff --git a/nixos/lib/testing/pkgs.nix b/nixos/lib/testing/pkgs.nix index 46d82c65d26a31..8dae2bbb27d903 100644 --- a/nixos/lib/testing/pkgs.nix +++ b/nixos/lib/testing/pkgs.nix @@ -1,4 +1,9 @@ -{ config, lib, hostPkgs, ... }: +{ + config, + lib, + hostPkgs, + ... +}: { config = { # default pkgs for use in VMs diff --git a/nixos/lib/testing/run.nix b/nixos/lib/testing/run.nix index 218292121ee770..4ea0b1e9a0348e 100644 --- a/nixos/lib/testing/run.nix +++ b/nixos/lib/testing/run.nix @@ -1,4 +1,9 @@ -{ config, hostPkgs, lib, ... }: +{ + config, + hostPkgs, + lib, + ... +}: let inherit (lib) types mkOption; in @@ -41,7 +46,8 @@ in rawTestDerivation = hostPkgs.stdenv.mkDerivation { name = "vm-test-run-${config.name}"; - requiredSystemFeatures = [ "nixos-test" ] + requiredSystemFeatures = + [ "nixos-test" ] ++ lib.optionals hostPkgs.stdenv.hostPlatform.isLinux [ "kvm" ] ++ lib.optionals hostPkgs.stdenv.hostPlatform.isDarwin [ "apple-virt" ]; @@ -58,7 +64,8 @@ in meta = config.meta; }; - test = lib.lazyDerivation { # lazyDerivation improves performance when only passthru items and/or meta are used. + test = lib.lazyDerivation { + # lazyDerivation improves performance when only passthru items and/or meta are used. derivation = config.rawTestDerivation; inherit (config) passthru meta; }; diff --git a/nixos/lib/testing/testScript.nix b/nixos/lib/testing/testScript.nix index 09964777bd924f..bde7b78607b470 100644 --- a/nixos/lib/testing/testScript.nix +++ b/nixos/lib/testing/testScript.nix @@ -1,4 +1,11 @@ -testModuleArgs@{ config, lib, hostPkgs, nodes, moduleType, ... }: +testModuleArgs@{ + config, + lib, + hostPkgs, + nodes, + moduleType, + ... +}: let inherit (lib) mkOption types; inherit (types) either str functionTo; @@ -37,48 +44,50 @@ in withoutTestScriptReferences.testScript = lib.mkForce "testscript omitted"; testScriptString = - if lib.isFunction config.testScript - then - config.testScript - { - nodes = - lib.mapAttrs - (k: v: - if v.virtualisation.useNixStoreImage - then - # prevent infinite recursion when testScript would - # reference v's toplevel - config.withoutTestScriptReferences.nodesCompat.${k} - else - # reuse memoized config - v - ) - config.nodesCompat; - } - else config.testScript; + if lib.isFunction config.testScript then + config.testScript { + nodes = lib.mapAttrs ( + k: v: + if v.virtualisation.useNixStoreImage then + # prevent infinite recursion when testScript would + # reference v's toplevel + config.withoutTestScriptReferences.nodesCompat.${k} + else + # reuse memoized config + v + ) config.nodesCompat; + } + else + config.testScript; - defaults = { config, name, ... }: { - # Make sure all derivations referenced by the test - # script are available on the nodes. When the store is - # accessed through 9p, this isn't important, since - # everything in the store is available to the guest, - # but when building a root image it is, as all paths - # that should be available to the guest has to be - # copied to the image. - virtualisation.additionalPaths = - lib.optional - # A testScript may evaluate nodes, which has caused - # infinite recursions. The demand cycle involves: - # testScript --> - # nodes --> - # toplevel --> - # additionalPaths --> - # hasContext testScript' --> - # testScript (ad infinitum) - # If we don't need to build an image, we can break this - # cycle by short-circuiting when useNixStoreImage is false. - (config.virtualisation.useNixStoreImage && builtins.hasContext testModuleArgs.config.testScriptString && testModuleArgs.config.includeTestScriptReferences) - (hostPkgs.writeStringReferencesToFile testModuleArgs.config.testScriptString); - }; + defaults = + { config, name, ... }: + { + # Make sure all derivations referenced by the test + # script are available on the nodes. When the store is + # accessed through 9p, this isn't important, since + # everything in the store is available to the guest, + # but when building a root image it is, as all paths + # that should be available to the guest has to be + # copied to the image. + virtualisation.additionalPaths = + lib.optional + # A testScript may evaluate nodes, which has caused + # infinite recursions. The demand cycle involves: + # testScript --> + # nodes --> + # toplevel --> + # additionalPaths --> + # hasContext testScript' --> + # testScript (ad infinitum) + # If we don't need to build an image, we can break this + # cycle by short-circuiting when useNixStoreImage is false. + ( + config.virtualisation.useNixStoreImage + && builtins.hasContext testModuleArgs.config.testScriptString + && testModuleArgs.config.includeTestScriptReferences + ) + (hostPkgs.writeStringReferencesToFile testModuleArgs.config.testScriptString); + }; }; } diff --git a/nixos/lib/utils.nix b/nixos/lib/utils.nix index a0518660a51120..d0279083bcd71f 100644 --- a/nixos/lib/utils.nix +++ b/nixos/lib/utils.nix @@ -1,4 +1,8 @@ -{ lib, config, pkgs }: +{ + lib, + config, + pkgs, +}: let inherit (lib) @@ -37,338 +41,399 @@ let in let -utils = rec { - - # Copy configuration files to avoid having the entire sources in the system closure - copyFile = filePath: pkgs.runCommand (builtins.unsafeDiscardStringContext (baseNameOf filePath)) {} '' - cp ${filePath} $out - ''; - - # Check whenever fileSystem is needed for boot. NOTE: Make sure - # pathsNeededForBoot is closed under the parent relationship, i.e. if /a/b/c - # is in the list, put /a and /a/b in as well. - pathsNeededForBoot = [ "/" "/nix" "/nix/store" "/var" "/var/log" "/var/lib" "/var/lib/nixos" "/etc" "/usr" ]; - fsNeededForBoot = fs: fs.neededForBoot || elem fs.mountPoint pathsNeededForBoot; - - # Check whenever `b` depends on `a` as a fileSystem - fsBefore = a: b: - let - # normalisePath adds a slash at the end of the path if it didn't already - # have one. - # - # The reason slashes are added at the end of each path is to prevent `b` - # from accidentally depending on `a` in cases like - # a = { mountPoint = "/aaa"; ... } - # b = { device = "/aaaa"; ... } - # Here a.mountPoint *is* a prefix of b.device even though a.mountPoint is - # *not* a parent of b.device. If we add a slash at the end of each string, - # though, this is not a problem: "/aaa/" is not a prefix of "/aaaa/". - normalisePath = path: "${path}${optionalString (!(hasSuffix "/" path)) "/"}"; - normalise = mount: mount // { device = normalisePath (toString mount.device); - mountPoint = normalisePath mount.mountPoint; - depends = map normalisePath mount.depends; - }; - - a' = normalise a; - b' = normalise b; - - in hasPrefix a'.mountPoint b'.device - || hasPrefix a'.mountPoint b'.mountPoint - || any (hasPrefix a'.mountPoint) b'.depends; - - # Escape a path according to the systemd rules. FIXME: slow - # The rules are described in systemd.unit(5) as follows: - # The escaping algorithm operates as follows: given a string, any "/" character is replaced by "-", and all other characters which are not ASCII alphanumerics, ":", "_" or "." are replaced by C-style "\x2d" escapes. In addition, "." is replaced with such a C-style escape when it would appear as the first character in the escaped string. - # When the input qualifies as absolute file system path, this algorithm is extended slightly: the path to the root directory "/" is encoded as single dash "-". In addition, any leading, trailing or duplicate "/" characters are removed from the string before transformation. Example: /foo//bar/baz/ becomes "foo-bar-baz". - escapeSystemdPath = s: let - replacePrefix = p: r: s: (if (hasPrefix p s) then r + (removePrefix p s) else s); - trim = s: removeSuffix "/" (removePrefix "/" s); - normalizedPath = normalizePath s; - in - replaceStrings ["/"] ["-"] - (replacePrefix "." (escapeC ["."] ".") - (escapeC (stringToCharacters " !\"#$%&'()*+,;<=>=@[\\]^`{|}~-") - (if normalizedPath == "/" then normalizedPath else trim normalizedPath))); - - # Quotes an argument for use in Exec* service lines. - # systemd accepts "-quoted strings with escape sequences, toJSON produces - # a subset of these. - # Additionally we escape % to disallow expansion of % specifiers. Any lone ; - # in the input will be turned it ";" and thus lose its special meaning. - # Every $ is escaped to $$, this makes it unnecessary to disable environment - # substitution for the directive. - escapeSystemdExecArg = arg: - let - s = if isPath arg then "${arg}" - else if isString arg then arg - else if isInt arg || isFloat arg || isDerivation arg then toString arg - else throw "escapeSystemdExecArg only allows strings, paths, numbers and derivations"; - in + utils = rec { + + # Copy configuration files to avoid having the entire sources in the system closure + copyFile = + filePath: + pkgs.runCommand (builtins.unsafeDiscardStringContext (baseNameOf filePath)) { } '' + cp ${filePath} $out + ''; + + # Check whenever fileSystem is needed for boot. NOTE: Make sure + # pathsNeededForBoot is closed under the parent relationship, i.e. if /a/b/c + # is in the list, put /a and /a/b in as well. + pathsNeededForBoot = [ + "/" + "/nix" + "/nix/store" + "/var" + "/var/log" + "/var/lib" + "/var/lib/nixos" + "/etc" + "/usr" + ]; + fsNeededForBoot = fs: fs.neededForBoot || elem fs.mountPoint pathsNeededForBoot; + + # Check whenever `b` depends on `a` as a fileSystem + fsBefore = + a: b: + let + # normalisePath adds a slash at the end of the path if it didn't already + # have one. + # + # The reason slashes are added at the end of each path is to prevent `b` + # from accidentally depending on `a` in cases like + # a = { mountPoint = "/aaa"; ... } + # b = { device = "/aaaa"; ... } + # Here a.mountPoint *is* a prefix of b.device even though a.mountPoint is + # *not* a parent of b.device. If we add a slash at the end of each string, + # though, this is not a problem: "/aaa/" is not a prefix of "/aaaa/". + normalisePath = path: "${path}${optionalString (!(hasSuffix "/" path)) "/"}"; + normalise = + mount: + mount + // { + device = normalisePath (toString mount.device); + mountPoint = normalisePath mount.mountPoint; + depends = map normalisePath mount.depends; + }; + + a' = normalise a; + b' = normalise b; + + in + hasPrefix a'.mountPoint b'.device + || hasPrefix a'.mountPoint b'.mountPoint + || any (hasPrefix a'.mountPoint) b'.depends; + + # Escape a path according to the systemd rules. FIXME: slow + # The rules are described in systemd.unit(5) as follows: + # The escaping algorithm operates as follows: given a string, any "/" character is replaced by "-", and all other characters which are not ASCII alphanumerics, ":", "_" or "." are replaced by C-style "\x2d" escapes. In addition, "." is replaced with such a C-style escape when it would appear as the first character in the escaped string. + # When the input qualifies as absolute file system path, this algorithm is extended slightly: the path to the root directory "/" is encoded as single dash "-". In addition, any leading, trailing or duplicate "/" characters are removed from the string before transformation. Example: /foo//bar/baz/ becomes "foo-bar-baz". + escapeSystemdPath = + s: + let + replacePrefix = + p: r: s: + (if (hasPrefix p s) then r + (removePrefix p s) else s); + trim = s: removeSuffix "/" (removePrefix "/" s); + normalizedPath = normalizePath s; + in + replaceStrings [ "/" ] [ "-" ] ( + replacePrefix "." (escapeC [ "." ] ".") ( + escapeC (stringToCharacters " !\"#$%&'()*+,;<=>=@[\\]^`{|}~-") ( + if normalizedPath == "/" then normalizedPath else trim normalizedPath + ) + ) + ); + + # Quotes an argument for use in Exec* service lines. + # systemd accepts "-quoted strings with escape sequences, toJSON produces + # a subset of these. + # Additionally we escape % to disallow expansion of % specifiers. Any lone ; + # in the input will be turned it ";" and thus lose its special meaning. + # Every $ is escaped to $$, this makes it unnecessary to disable environment + # substitution for the directive. + escapeSystemdExecArg = + arg: + let + s = + if isPath arg then + "${arg}" + else if isString arg then + arg + else if isInt arg || isFloat arg || isDerivation arg then + toString arg + else + throw "escapeSystemdExecArg only allows strings, paths, numbers and derivations"; + in replaceStrings [ "%" "$" ] [ "%%" "$$" ] (toJSON s); - # Quotes a list of arguments into a single string for use in a Exec* - # line. - escapeSystemdExecArgs = concatMapStringsSep " " escapeSystemdExecArg; - - # Returns a system path for a given shell package - toShellPath = shell: - if types.shellPackage.check shell then - "/run/current-system/sw${shell.shellPath}" - else if types.package.check shell then - throw "${shell} is not a shell package" - else - shell; - - /* Recurse into a list or an attrset, searching for attrs named like - the value of the "attr" parameter, and return an attrset where the - names are the corresponding jq path where the attrs were found and - the values are the values of the attrs. - - Example: - recursiveGetAttrWithJqPrefix { - example = [ - { - irrelevant = "not interesting"; - } - { - ignored = "ignored attr"; - relevant = { - secret = { - _secret = "/path/to/secret"; - }; - }; - } - ]; - } "_secret" -> { ".example[1].relevant.secret" = "/path/to/secret"; } - */ - recursiveGetAttrWithJqPrefix = item: attr: mapAttrs (_name: set: set.${attr}) (recursiveGetAttrsetWithJqPrefix item attr); - - /* Similar to `recursiveGetAttrWithJqPrefix`, but returns the whole - attribute set containing `attr` instead of the value of `attr` in - the set. - - Example: - recursiveGetAttrsetWithJqPrefix { - example = [ - { - irrelevant = "not interesting"; - } - { - ignored = "ignored attr"; - relevant = { - secret = { - _secret = "/path/to/secret"; - quote = true; - }; - }; - } - ]; - } "_secret" -> { ".example[1].relevant.secret" = { _secret = "/path/to/secret"; quote = true; }; } - */ - recursiveGetAttrsetWithJqPrefix = item: attr: - let - recurse = prefix: item: - if item ? ${attr} then - nameValuePair prefix item - else if isDerivation item then [] - else if isAttrs item then - map (name: - let - escapedName = ''"${replaceStrings [''"'' "\\"] [''\"'' "\\\\"] name}"''; - in - recurse (prefix + "." + escapedName) item.${name}) (attrNames item) - else if isList item then - imap0 (index: item: recurse (prefix + "[${toString index}]") item) item - else - []; - in listToAttrs (flatten (recurse "" item)); - - /* Takes an attrset and a file path and generates a bash snippet that - outputs a JSON file at the file path with all instances of - - { _secret = "/path/to/secret" } - - in the attrset replaced with the contents of the file - "/path/to/secret" in the output JSON. - - When a configuration option accepts an attrset that is finally - converted to JSON, this makes it possible to let the user define - arbitrary secret values. - - Example: - If the file "/path/to/secret" contains the string - "topsecretpassword1234", - - genJqSecretsReplacementSnippet { - example = [ - { - irrelevant = "not interesting"; - } - { - ignored = "ignored attr"; - relevant = { - secret = { - _secret = "/path/to/secret"; - }; - }; - } - ]; - } "/path/to/output.json" - - would generate a snippet that, when run, outputs the following - JSON file at "/path/to/output.json": - - { - "example": [ - { - "irrelevant": "not interesting" - }, - { - "ignored": "ignored attr", - "relevant": { - "secret": "topsecretpassword1234" - } - } - ] - } - - The attribute set { _secret = "/path/to/secret"; } can contain extra - options, currently it accepts the `quote = true|false` option. - - If `quote = true` (default behavior), the content of the secret file will - be quoted as a string and embedded. Otherwise, if `quote = false`, the - content of the secret file will be parsed to JSON and then embedded. - - Example: - If the file "/path/to/secret" contains the JSON document: - - [ - { "a": "topsecretpassword1234" }, - { "b": "topsecretpassword5678" } - ] - - genJqSecretsReplacementSnippet { - example = [ - { - irrelevant = "not interesting"; - } - { - ignored = "ignored attr"; - relevant = { - secret = { - _secret = "/path/to/secret"; - quote = false; - }; - }; - } - ]; - } "/path/to/output.json" - - would generate a snippet that, when run, outputs the following - JSON file at "/path/to/output.json": - - { - "example": [ - { - "irrelevant": "not interesting" - }, - { - "ignored": "ignored attr", - "relevant": { - "secret": [ - { "a": "topsecretpassword1234" }, - { "b": "topsecretpassword5678" } - ] - } - } - ] - } - */ - genJqSecretsReplacementSnippet = genJqSecretsReplacementSnippet' "_secret"; - - # Like genJqSecretsReplacementSnippet, but allows the name of the - # attr which identifies the secret to be changed. - genJqSecretsReplacementSnippet' = attr: set: output: - let - secretsRaw = recursiveGetAttrsetWithJqPrefix set attr; - # Set default option values - secrets = mapAttrs (_name: set: { - quote = true; - } // set) secretsRaw; - stringOrDefault = str: def: if str == "" then def else str; - in '' - if [[ -h '${output}' ]]; then - rm '${output}' - fi - - inherit_errexit_enabled=0 - shopt -pq inherit_errexit && inherit_errexit_enabled=1 - shopt -s inherit_errexit - '' - + concatStringsSep - "\n" - (imap1 (index: name: '' - secret${toString index}=$(<'${secrets.${name}.${attr}}') - export secret${toString index} - '') - (attrNames secrets)) - + "\n" - + "${pkgs.jq}/bin/jq >'${output}' " - + escapeShellArg (stringOrDefault - (concatStringsSep - " | " - (imap1 (index: name: ''${name} = ($ENV.secret${toString index}${optionalString (!secrets.${name}.quote) " | fromjson"})'') - (attrNames secrets))) - ".") - + '' - <<'EOF' - ${toJSON set} - EOF - (( ! $inherit_errexit_enabled )) && shopt -u inherit_errexit - ''; - - /* Remove packages of packagesToRemove from packages, based on their names. - Relies on package names and has quadratic complexity so use with caution! - - Type: - removePackagesByName :: [package] -> [package] -> [package] - - Example: - removePackagesByName [ nautilus file-roller ] [ file-roller totem ] - => [ nautilus ] - */ - removePackagesByName = packages: packagesToRemove: - let - namesToRemove = map getName packagesToRemove; - in + # Quotes a list of arguments into a single string for use in a Exec* + # line. + escapeSystemdExecArgs = concatMapStringsSep " " escapeSystemdExecArg; + + # Returns a system path for a given shell package + toShellPath = + shell: + if types.shellPackage.check shell then + "/run/current-system/sw${shell.shellPath}" + else if types.package.check shell then + throw "${shell} is not a shell package" + else + shell; + + /* + Recurse into a list or an attrset, searching for attrs named like + the value of the "attr" parameter, and return an attrset where the + names are the corresponding jq path where the attrs were found and + the values are the values of the attrs. + + Example: + recursiveGetAttrWithJqPrefix { + example = [ + { + irrelevant = "not interesting"; + } + { + ignored = "ignored attr"; + relevant = { + secret = { + _secret = "/path/to/secret"; + }; + }; + } + ]; + } "_secret" -> { ".example[1].relevant.secret" = "/path/to/secret"; } + */ + recursiveGetAttrWithJqPrefix = + item: attr: mapAttrs (_name: set: set.${attr}) (recursiveGetAttrsetWithJqPrefix item attr); + + /* + Similar to `recursiveGetAttrWithJqPrefix`, but returns the whole + attribute set containing `attr` instead of the value of `attr` in + the set. + + Example: + recursiveGetAttrsetWithJqPrefix { + example = [ + { + irrelevant = "not interesting"; + } + { + ignored = "ignored attr"; + relevant = { + secret = { + _secret = "/path/to/secret"; + quote = true; + }; + }; + } + ]; + } "_secret" -> { ".example[1].relevant.secret" = { _secret = "/path/to/secret"; quote = true; }; } + */ + recursiveGetAttrsetWithJqPrefix = + item: attr: + let + recurse = + prefix: item: + if item ? ${attr} then + nameValuePair prefix item + else if isDerivation item then + [ ] + else if isAttrs item then + map ( + name: + let + escapedName = ''"${replaceStrings [ ''"'' "\\" ] [ ''\"'' "\\\\" ] name}"''; + in + recurse (prefix + "." + escapedName) item.${name} + ) (attrNames item) + else if isList item then + imap0 (index: item: recurse (prefix + "[${toString index}]") item) item + else + [ ]; + in + listToAttrs (flatten (recurse "" item)); + + /* + Takes an attrset and a file path and generates a bash snippet that + outputs a JSON file at the file path with all instances of + + { _secret = "/path/to/secret" } + + in the attrset replaced with the contents of the file + "/path/to/secret" in the output JSON. + + When a configuration option accepts an attrset that is finally + converted to JSON, this makes it possible to let the user define + arbitrary secret values. + + Example: + If the file "/path/to/secret" contains the string + "topsecretpassword1234", + + genJqSecretsReplacementSnippet { + example = [ + { + irrelevant = "not interesting"; + } + { + ignored = "ignored attr"; + relevant = { + secret = { + _secret = "/path/to/secret"; + }; + }; + } + ]; + } "/path/to/output.json" + + would generate a snippet that, when run, outputs the following + JSON file at "/path/to/output.json": + + { + "example": [ + { + "irrelevant": "not interesting" + }, + { + "ignored": "ignored attr", + "relevant": { + "secret": "topsecretpassword1234" + } + } + ] + } + + The attribute set { _secret = "/path/to/secret"; } can contain extra + options, currently it accepts the `quote = true|false` option. + + If `quote = true` (default behavior), the content of the secret file will + be quoted as a string and embedded. Otherwise, if `quote = false`, the + content of the secret file will be parsed to JSON and then embedded. + + Example: + If the file "/path/to/secret" contains the JSON document: + + [ + { "a": "topsecretpassword1234" }, + { "b": "topsecretpassword5678" } + ] + + genJqSecretsReplacementSnippet { + example = [ + { + irrelevant = "not interesting"; + } + { + ignored = "ignored attr"; + relevant = { + secret = { + _secret = "/path/to/secret"; + quote = false; + }; + }; + } + ]; + } "/path/to/output.json" + + would generate a snippet that, when run, outputs the following + JSON file at "/path/to/output.json": + + { + "example": [ + { + "irrelevant": "not interesting" + }, + { + "ignored": "ignored attr", + "relevant": { + "secret": [ + { "a": "topsecretpassword1234" }, + { "b": "topsecretpassword5678" } + ] + } + } + ] + } + */ + genJqSecretsReplacementSnippet = genJqSecretsReplacementSnippet' "_secret"; + + # Like genJqSecretsReplacementSnippet, but allows the name of the + # attr which identifies the secret to be changed. + genJqSecretsReplacementSnippet' = + attr: set: output: + let + secretsRaw = recursiveGetAttrsetWithJqPrefix set attr; + # Set default option values + secrets = mapAttrs ( + _name: set: + { + quote = true; + } + // set + ) secretsRaw; + stringOrDefault = str: def: if str == "" then def else str; + in + '' + if [[ -h '${output}' ]]; then + rm '${output}' + fi + + inherit_errexit_enabled=0 + shopt -pq inherit_errexit && inherit_errexit_enabled=1 + shopt -s inherit_errexit + '' + + concatStringsSep "\n" ( + imap1 (index: name: '' + secret${toString index}=$(<'${secrets.${name}.${attr}}') + export secret${toString index} + '') (attrNames secrets) + ) + + "\n" + + "${pkgs.jq}/bin/jq >'${output}' " + + escapeShellArg ( + stringOrDefault (concatStringsSep " | " ( + imap1 ( + index: name: + ''${name} = ($ENV.secret${toString index}${optionalString (!secrets.${name}.quote) " | fromjson"})'' + ) (attrNames secrets) + )) "." + ) + + '' + <<'EOF' + ${toJSON set} + EOF + (( ! $inherit_errexit_enabled )) && shopt -u inherit_errexit + ''; + + /* + Remove packages of packagesToRemove from packages, based on their names. + Relies on package names and has quadratic complexity so use with caution! + + Type: + removePackagesByName :: [package] -> [package] -> [package] + + Example: + removePackagesByName [ nautilus file-roller ] [ file-roller totem ] + => [ nautilus ] + */ + removePackagesByName = + packages: packagesToRemove: + let + namesToRemove = map getName packagesToRemove; + in filter (x: !(elem (getName x) namesToRemove)) packages; - /* Returns false if a package with the same name as the `package` is present in `packagesToDisable`. - - Type: - disablePackageByName :: package -> [package] -> bool - - Example: - disablePackageByName file-roller [ file-roller totem ] - => false - - Example: - disablePackageByName nautilus [ file-roller totem ] - => true - */ - disablePackageByName = package: packagesToDisable: - let - namesToDisable = map getName packagesToDisable; - in + /* + Returns false if a package with the same name as the `package` is present in `packagesToDisable`. + + Type: + disablePackageByName :: package -> [package] -> bool + + Example: + disablePackageByName file-roller [ file-roller totem ] + => false + + Example: + disablePackageByName nautilus [ file-roller totem ] + => true + */ + disablePackageByName = + package: packagesToDisable: + let + namesToDisable = map getName packagesToDisable; + in !elem (getName package) namesToDisable; - systemdUtils = { - lib = import ./systemd-lib.nix { inherit lib config pkgs utils; }; - unitOptions = import ./systemd-unit-options.nix { inherit lib systemdUtils; }; - types = import ./systemd-types.nix { inherit lib systemdUtils pkgs; }; - network = { - units = import ./systemd-network-units.nix { inherit lib systemdUtils; }; + systemdUtils = { + lib = import ./systemd-lib.nix { + inherit + lib + config + pkgs + utils + ; + }; + unitOptions = import ./systemd-unit-options.nix { inherit lib systemdUtils; }; + types = import ./systemd-types.nix { inherit lib systemdUtils pkgs; }; + network = { + units = import ./systemd-network-units.nix { inherit lib systemdUtils; }; + }; }; }; -}; -in utils +in +utils diff --git a/nixos/maintainers/option-usages.nix b/nixos/maintainers/option-usages.nix index e9bafa21a58ae0..f53e5272e42374 100644 --- a/nixos/maintainers/option-usages.nix +++ b/nixos/maintainers/option-usages.nix @@ -1,10 +1,11 @@ -{ configuration ? import ../lib/from-env.nix "NIXOS_CONFIG" +{ + configuration ? import ../lib/from-env.nix "NIXOS_CONFIG" , -# provide an option name, as a string literal. -, testOption ? null + # provide an option name, as a string literal. + testOption ? null, -# provide a list of option names, as string literals. -, testOptions ? [ ] + # provide a list of option names, as string literals. + testOptions ? [ ], }: # This file is made to be used as follow: @@ -46,14 +47,16 @@ with import ../../lib; let - evalFun = { - specialArgs ? {} - }: import ../lib/eval-config.nix { - modules = [ configuration ]; - inherit specialArgs; - }; + evalFun = + { + specialArgs ? { }, + }: + import ../lib/eval-config.nix { + modules = [ configuration ]; + inherit specialArgs; + }; - eval = evalFun {}; + eval = evalFun { }; inherit (eval) pkgs; excludedTestOptions = [ @@ -79,21 +82,18 @@ let "systemd.services" "kde.extraPackages" ]; - excludeOptions = list: - filter (opt: !(elem (showOption opt.loc) excludedOptions)) list; + excludeOptions = list: filter (opt: !(elem (showOption opt.loc) excludedOptions)) list; - - reportNewFailures = old: new: + reportNewFailures = + old: new: let - filterChanges = - filter ({fst, snd}: - !(fst.success -> snd.success) - ); + filterChanges = filter ({ fst, snd }: !(fst.success -> snd.success)); - keepNames = - map ({fst, snd}: - /* assert fst.name == snd.name; */ snd.name - ); + keepNames = map ( + { fst, snd }: + # assert fst.name == snd.name; + snd.name + ); # Use tryEval (strict ...) to know if there is any failure while # evaluating the option value. @@ -101,16 +101,13 @@ let # Note, the `strict` function is not strict enough, but using toXML # builtins multiply by 4 the memory usage and the time used to compute # each options. - tryCollectOptions = moduleResult: - forEach (excludeOptions (collect isOption moduleResult)) (opt: - { name = showOption opt.loc; } // builtins.tryEval (strict opt.value)); - in - keepNames ( - filterChanges ( - zipLists (tryCollectOptions old) (tryCollectOptions new) - ) - ); - + tryCollectOptions = + moduleResult: + forEach (excludeOptions (collect isOption moduleResult)) ( + opt: { name = showOption opt.loc; } // builtins.tryEval (strict opt.value) + ); + in + keepNames (filterChanges (zipLists (tryCollectOptions old) (tryCollectOptions new))); # Create a list of modules where each module contains only one failling # options. @@ -119,57 +116,55 @@ let setIntrospection = opt: rec { name = showOption opt.loc; path = opt.loc; - config = setAttrByPath path - (throw "Usage introspection of '${name}' by forced failure."); + config = setAttrByPath path (throw "Usage introspection of '${name}' by forced failure."); }; in - map setIntrospection (collect isOption eval.options); + map setIntrospection (collect isOption eval.options); - overrideConfig = thrower: - recursiveUpdateUntil (path: old: new: + overrideConfig = + thrower: + recursiveUpdateUntil ( + path: old: new: path == thrower.path ) eval.config thrower.config; - - graph = - map (thrower: { - option = thrower.name; - usedBy = assert __trace "Investigate ${thrower.name}" true; - reportNewFailures eval.options (evalFun { + graph = map (thrower: { + option = thrower.name; + usedBy = + assert __trace "Investigate ${thrower.name}" true; + reportNewFailures eval.options + (evalFun { specialArgs = { config = overrideConfig thrower; }; }).options; - }) introspectionModules; + }) introspectionModules; displayOptionsGraph = - let - checkList = - if testOption != null then [ testOption ] - else testOptions; - checkAll = checkList == []; - in - flip filter graph ({option, ...}: - (checkAll || elem option checkList) - && !(elem option excludedTestOptions) - ); + let + checkList = if testOption != null then [ testOption ] else testOptions; + checkAll = checkList == [ ]; + in + flip filter graph ( + { option, ... }: (checkAll || elem option checkList) && !(elem option excludedTestOptions) + ); graphToDot = graph: '' digraph "Option Usages" { - ${concatMapStrings ({option, usedBy}: - concatMapStrings (user: '' - "${option}" -> "${user}"'' - ) usedBy - ) displayOptionsGraph} + ${concatMapStrings ( + { option, usedBy }: concatMapStrings (user: ''"${option}" -> "${user}"'') usedBy + ) displayOptionsGraph} } ''; - graphToText = graph: - concatMapStrings ({usedBy, ...}: - concatMapStrings (user: '' - ${user} - '') usedBy - ) displayOptionsGraph; + graphToText = + graph: + concatMapStrings ( + { usedBy, ... }: + concatMapStrings (user: '' + ${user} + '') usedBy + ) displayOptionsGraph; in diff --git a/nixos/maintainers/scripts/azure-new/examples/basic/image.nix b/nixos/maintainers/scripts/azure-new/examples/basic/image.nix index 310eba3621a641..3f94d09b764b82 100644 --- a/nixos/maintainers/scripts/azure-new/examples/basic/image.nix +++ b/nixos/maintainers/scripts/azure-new/examples/basic/image.nix @@ -1,10 +1,15 @@ let - pkgs = (import ../../../../../../default.nix {}); + pkgs = (import ../../../../../../default.nix { }); machine = import (pkgs.path + "/nixos/lib/eval-config.nix") { system = "x86_64-linux"; modules = [ - ({config, ...}: { imports = [ ./system.nix ]; }) + ( + { config, ... }: + { + imports = [ ./system.nix ]; + } + ) ]; }; in - machine.config.system.build.azureImage +machine.config.system.build.azureImage diff --git a/nixos/maintainers/scripts/azure-new/examples/basic/system.nix b/nixos/maintainers/scripts/azure-new/examples/basic/system.nix index d1044802e1f090..5276e4be388ba7 100644 --- a/nixos/maintainers/scripts/azure-new/examples/basic/system.nix +++ b/nixos/maintainers/scripts/azure-new/examples/basic/system.nix @@ -1,6 +1,7 @@ { pkgs, modulesPath, ... }: -let username = "azurenixosuser"; +let + username = "azurenixosuser"; in { imports = [ @@ -28,6 +29,10 @@ in security.sudo.wheelNeedsPassword = false; environment.systemPackages = with pkgs; [ - git file htop wget curl + git + file + htop + wget + curl ]; } diff --git a/nixos/maintainers/scripts/cloudstack/cloudstack-image.nix b/nixos/maintainers/scripts/cloudstack/cloudstack-image.nix index b66ee5d7b9bc96..724c220abaf8b4 100644 --- a/nixos/maintainers/scripts/cloudstack/cloudstack-image.nix +++ b/nixos/maintainers/scripts/cloudstack/cloudstack-image.nix @@ -1,20 +1,23 @@ # nix-build '' -A config.system.build.cloudstackImage --arg configuration "{ imports = [ ./nixos/maintainers/scripts/cloudstack/cloudstack-image.nix ]; }" -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { - imports = - [ ../../../modules/virtualisation/cloudstack-config.nix ]; + imports = [ ../../../modules/virtualisation/cloudstack-config.nix ]; system.build.cloudstackImage = import ../../../lib/make-disk-image.nix { inherit lib config pkgs; format = "qcow2"; - configFile = pkgs.writeText "configuration.nix" - '' - { - imports = [ ]; - } - ''; + configFile = pkgs.writeText "configuration.nix" '' + { + imports = [ ]; + } + ''; }; } diff --git a/nixos/maintainers/scripts/lxd/lxd-container-image-inner.nix b/nixos/maintainers/scripts/lxd/lxd-container-image-inner.nix index 5468488fafedc5..8c643898b89bda 100644 --- a/nixos/maintainers/scripts/lxd/lxd-container-image-inner.nix +++ b/nixos/maintainers/scripts/lxd/lxd-container-image-inner.nix @@ -5,13 +5,12 @@ { modulesPath, ... }: { - imports = - [ - # Include the default lxd configuration. - "${modulesPath}/virtualisation/lxc-container.nix" - # Include the container-specific autogenerated configuration. - ./lxd.nix - ]; + imports = [ + # Include the default lxd configuration. + "${modulesPath}/virtualisation/lxc-container.nix" + # Include the container-specific autogenerated configuration. + ./lxd.nix + ]; networking = { dhcpcd.enable = false; diff --git a/nixos/maintainers/scripts/lxd/lxd-container-image.nix b/nixos/maintainers/scripts/lxd/lxd-container-image.nix index 8c0e75e84f753f..5913ed69a6dbdf 100644 --- a/nixos/maintainers/scripts/lxd/lxd-container-image.nix +++ b/nixos/maintainers/scripts/lxd/lxd-container-image.nix @@ -9,20 +9,25 @@ enable = true; target = "/etc/nixos/lxd.nix"; template = ./nix.tpl; - when = [ "create" "copy" ]; + when = [ + "create" + "copy" + ]; }; # copy the config for nixos-rebuild - system.activationScripts.config = let - config = pkgs.substituteAll { - src = ./lxd-container-image-inner.nix; - stateVersion = lib.trivial.release; - }; - in '' - if [ ! -e /etc/nixos/configuration.nix ]; then - install -m 0644 -D ${config} /etc/nixos/configuration.nix - fi - ''; + system.activationScripts.config = + let + config = pkgs.substituteAll { + src = ./lxd-container-image-inner.nix; + stateVersion = lib.trivial.release; + }; + in + '' + if [ ! -e /etc/nixos/configuration.nix ]; then + install -m 0644 -D ${config} /etc/nixos/configuration.nix + fi + ''; networking = { dhcpcd.enable = false; diff --git a/nixos/maintainers/scripts/lxd/lxd-virtual-machine-image-inner.nix b/nixos/maintainers/scripts/lxd/lxd-virtual-machine-image-inner.nix index 5931a561b31cc2..845838d3249d59 100644 --- a/nixos/maintainers/scripts/lxd/lxd-virtual-machine-image-inner.nix +++ b/nixos/maintainers/scripts/lxd/lxd-virtual-machine-image-inner.nix @@ -5,13 +5,12 @@ { modulesPath, ... }: { - imports = - [ - # Include the default lxd configuration. - "${modulesPath}/virtualisation/lxd-virtual-machine.nix" - # Include the container-specific autogenerated configuration. - ./lxd.nix - ]; + imports = [ + # Include the default lxd configuration. + "${modulesPath}/virtualisation/lxd-virtual-machine.nix" + # Include the container-specific autogenerated configuration. + ./lxd.nix + ]; networking = { dhcpcd.enable = false; diff --git a/nixos/maintainers/scripts/lxd/lxd-virtual-machine-image.nix b/nixos/maintainers/scripts/lxd/lxd-virtual-machine-image.nix index 8a1c9b0d634cd7..1ccecc4c351d36 100644 --- a/nixos/maintainers/scripts/lxd/lxd-virtual-machine-image.nix +++ b/nixos/maintainers/scripts/lxd/lxd-virtual-machine-image.nix @@ -9,20 +9,25 @@ enable = true; target = "/etc/nixos/lxd.nix"; template = ./nix.tpl; - when = ["create" "copy"]; + when = [ + "create" + "copy" + ]; }; # copy the config for nixos-rebuild - system.activationScripts.config = let - config = pkgs.substituteAll { - src = ./lxd-virtual-machine-image-inner.nix; - stateVersion = lib.trivial.release; - }; - in '' - if [ ! -e /etc/nixos/configuration.nix ]; then - install -m 0644 -D ${config} /etc/nixos/configuration.nix - fi - ''; + system.activationScripts.config = + let + config = pkgs.substituteAll { + src = ./lxd-virtual-machine-image-inner.nix; + stateVersion = lib.trivial.release; + }; + in + '' + if [ ! -e /etc/nixos/configuration.nix ]; then + install -m 0644 -D ${config} /etc/nixos/configuration.nix + fi + ''; # Network networking = { diff --git a/nixos/modules/config/debug-info.nix b/nixos/modules/config/debug-info.nix index 9bf3d82ace2a46..1a2bbd319e5786 100644 --- a/nixos/modules/config/debug-info.nix +++ b/nixos/modules/config/debug-info.nix @@ -25,7 +25,6 @@ }; - config = lib.mkIf config.environment.enableDebugInfo { # FIXME: currently disabled because /lib is already in diff --git a/nixos/modules/config/fanout.nix b/nixos/modules/config/fanout.nix index f775d2e9f22d77..1a63ac0705f65a 100644 --- a/nixos/modules/config/fanout.nix +++ b/nixos/modules/config/fanout.nix @@ -1,9 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.fanout; - mknodCmds = n: lib.lists.imap0 (i: s: - "mknod /dev/fanout${builtins.toString i} c $MAJOR ${builtins.toString i}" - ) (lib.lists.replicate n ""); + mknodCmds = + n: + lib.lists.imap0 (i: s: "mknod /dev/fanout${builtins.toString i} c $MAJOR ${builtins.toString i}") ( + lib.lists.replicate n "" + ); in { options.services.fanout = { diff --git a/nixos/modules/config/fonts/fontconfig.nix b/nixos/modules/config/fonts/fontconfig.nix index 205fd1fa7b960c..984daec204315d 100644 --- a/nixos/modules/config/fonts/fontconfig.nix +++ b/nixos/modules/config/fonts/fontconfig.nix @@ -1,28 +1,31 @@ /* + Configuration files are linked to /etc/fonts/conf.d/ -Configuration files are linked to /etc/fonts/conf.d/ + This module generates a package containing configuration files and link it in /etc/fonts. -This module generates a package containing configuration files and link it in /etc/fonts. + Fontconfig reads files in folder name / file name order, so the number prepended to the configuration file name decide the order of parsing. + Low number means high priority. -Fontconfig reads files in folder name / file name order, so the number prepended to the configuration file name decide the order of parsing. -Low number means high priority. + NOTE: Please take extreme care when adjusting the default settings of this module. + People care a lot, and I mean A LOT, about their font rendering, and you will be + The Person That Broke It if it changes in a way people don't like. -NOTE: Please take extreme care when adjusting the default settings of this module. -People care a lot, and I mean A LOT, about their font rendering, and you will be -The Person That Broke It if it changes in a way people don't like. + See prior art: + - https://github.com/NixOS/nixpkgs/pull/194594 + - https://github.com/NixOS/nixpkgs/pull/222236 + - https://github.com/NixOS/nixpkgs/pull/222689 -See prior art: -- https://github.com/NixOS/nixpkgs/pull/194594 -- https://github.com/NixOS/nixpkgs/pull/222236 -- https://github.com/NixOS/nixpkgs/pull/222689 - -And do not repeat our mistakes. - -- @K900, March 2023 + And do not repeat our mistakes. + - @K900, March 2023 */ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.fonts.fontconfig; @@ -31,17 +34,23 @@ let # configuration file to read fontconfig cache # priority 0 - cacheConf = makeCacheConf {}; + cacheConf = makeCacheConf { }; # generate the font cache setting file # When cross-compiling, we can’t generate the cache, so we skip the # part. fontconfig still works but is a little slower in # looking things up. - makeCacheConf = { }: + makeCacheConf = + { }: let - makeCache = fontconfig: pkgs.makeFontsCache { inherit fontconfig; fontDirectories = config.fonts.packages; }; - cache = makeCache pkgs.fontconfig; - cache32 = makeCache pkgs.pkgsi686Linux.fontconfig; + makeCache = + fontconfig: + pkgs.makeFontsCache { + inherit fontconfig; + fontDirectories = config.fonts.packages; + }; + cache = makeCache pkgs.fontconfig; + cache32 = makeCache pkgs.pkgsi686Linux.fontconfig; in pkgs.writeText "fc-00-nixos-cache.conf" '' @@ -50,11 +59,11 @@ let ${lib.concatStringsSep "\n" (map (font: "${font}") config.fonts.packages)} ${lib.optionalString (pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform) '' - - ${cache} - ${lib.optionalString (pkgs.stdenv.hostPlatform.isx86_64 && cfg.cache32Bit) '' - ${cache32} - ''} + + ${cache} + ${lib.optionalString (pkgs.stdenv.hostPlatform.isx86_64 && cfg.cache32Bit) '' + ${cache32} + ''} ''} ''; @@ -85,35 +94,38 @@ let # default fonts configuration file # priority 52 defaultFontsConf = - let genDefault = fonts: name: - lib.optionalString (fonts != []) '' - - ${name} - - ${lib.concatStringsSep "" - (map (font: '' - ${font} - '') fonts)} - - - ''; + let + genDefault = + fonts: name: + lib.optionalString (fonts != [ ]) '' + + ${name} + + ${lib.concatStringsSep "" ( + map (font: '' + ${font} + '') fonts + )} + + + ''; in pkgs.writeText "fc-52-nixos-default-fonts.conf" '' - - - + + + - - ${genDefault cfg.defaultFonts.sansSerif "sans-serif"} + + ${genDefault cfg.defaultFonts.sansSerif "sans-serif"} - ${genDefault cfg.defaultFonts.serif "serif"} + ${genDefault cfg.defaultFonts.serif "serif"} - ${genDefault cfg.defaultFonts.monospace "monospace"} + ${genDefault cfg.defaultFonts.monospace "monospace"} - ${genDefault cfg.defaultFonts.emoji "emoji"} + ${genDefault cfg.defaultFonts.emoji "emoji"} - - ''; + + ''; # bitmap font options # priority 53 @@ -123,14 +135,14 @@ let ${lib.optionalString (!cfg.allowBitmaps) '' - - - - - false - - - + + + + + false + + + ''} @@ -170,76 +182,75 @@ let ''; # fontconfig configuration package - confPkg = pkgs.runCommand "fontconfig-conf" { - preferLocalBuild = true; - } '' - dst=$out/etc/fonts/conf.d - mkdir -p $dst - - # fonts.conf - ln -s ${pkg.out}/etc/fonts/fonts.conf \ - $dst/../fonts.conf - # TODO: remove this legacy symlink once people stop using packages built before #95358 was merged - mkdir -p $out/etc/fonts/2.11 - ln -s /etc/fonts/fonts.conf \ - $out/etc/fonts/2.11/fonts.conf - - # fontconfig default config files - ln -s ${pkg.out}/etc/fonts/conf.d/*.conf \ - $dst/ + confPkg = + pkgs.runCommand "fontconfig-conf" + { + preferLocalBuild = true; + } + '' + dst=$out/etc/fonts/conf.d + mkdir -p $dst - ${lib.optionalString (!cfg.antialias) - (replaceDefaultConfig "10-yes-antialias.conf" - "10-no-antialias.conf") - } + # fonts.conf + ln -s ${pkg.out}/etc/fonts/fonts.conf \ + $dst/../fonts.conf + # TODO: remove this legacy symlink once people stop using packages built before #95358 was merged + mkdir -p $out/etc/fonts/2.11 + ln -s /etc/fonts/fonts.conf \ + $out/etc/fonts/2.11/fonts.conf - ${lib.optionalString (cfg.hinting.style != "slight") - (replaceDefaultConfig "10-hinting-slight.conf" - "10-hinting-${cfg.hinting.style}.conf") - } + # fontconfig default config files + ln -s ${pkg.out}/etc/fonts/conf.d/*.conf \ + $dst/ - ${lib.optionalString (cfg.subpixel.rgba != "none") - (replaceDefaultConfig "10-sub-pixel-none.conf" - "10-sub-pixel-${cfg.subpixel.rgba}.conf") - } + ${lib.optionalString (!cfg.antialias) ( + replaceDefaultConfig "10-yes-antialias.conf" "10-no-antialias.conf" + )} - ${lib.optionalString (cfg.subpixel.lcdfilter != "default") - (replaceDefaultConfig "11-lcdfilter-default.conf" - "11-lcdfilter-${cfg.subpixel.lcdfilter}.conf") - } + ${lib.optionalString (cfg.hinting.style != "slight") ( + replaceDefaultConfig "10-hinting-slight.conf" "10-hinting-${cfg.hinting.style}.conf" + )} - # 00-nixos-cache.conf - ln -s ${cacheConf} $dst/00-nixos-cache.conf + ${lib.optionalString (cfg.subpixel.rgba != "none") ( + replaceDefaultConfig "10-sub-pixel-none.conf" "10-sub-pixel-${cfg.subpixel.rgba}.conf" + )} - # 10-nixos-rendering.conf - ln -s ${renderConf} $dst/10-nixos-rendering.conf + ${lib.optionalString (cfg.subpixel.lcdfilter != "default") ( + replaceDefaultConfig "11-lcdfilter-default.conf" "11-lcdfilter-${cfg.subpixel.lcdfilter}.conf" + )} - # 50-user.conf - ${lib.optionalString (!cfg.includeUserConf) '' - rm $dst/50-user.conf - ''} + # 00-nixos-cache.conf + ln -s ${cacheConf} $dst/00-nixos-cache.conf - # local.conf (indirect priority 51) - ${lib.optionalString (cfg.localConf != "") '' - ln -s ${localConf} $dst/../local.conf - ''} + # 10-nixos-rendering.conf + ln -s ${renderConf} $dst/10-nixos-rendering.conf + + # 50-user.conf + ${lib.optionalString (!cfg.includeUserConf) '' + rm $dst/50-user.conf + ''} - # 52-nixos-default-fonts.conf - ln -s ${defaultFontsConf} $dst/52-nixos-default-fonts.conf + # local.conf (indirect priority 51) + ${lib.optionalString (cfg.localConf != "") '' + ln -s ${localConf} $dst/../local.conf + ''} - # 53-no-bitmaps.conf - ln -s ${rejectBitmaps} $dst/53-no-bitmaps.conf + # 52-nixos-default-fonts.conf + ln -s ${defaultFontsConf} $dst/52-nixos-default-fonts.conf - ${lib.optionalString (!cfg.allowType1) '' - # 53-nixos-reject-type1.conf - ln -s ${rejectType1} $dst/53-nixos-reject-type1.conf - ''} - ''; + # 53-no-bitmaps.conf + ln -s ${rejectBitmaps} $dst/53-no-bitmaps.conf + + ${lib.optionalString (!cfg.allowType1) '' + # 53-nixos-reject-type1.conf + ln -s ${rejectType1} $dst/53-nixos-reject-type1.conf + ''} + ''; # Package with configuration files # this merge all the packages in the fonts.fontconfig.confPackages list fontconfigEtc = pkgs.buildEnv { - name = "fontconfig-etc"; + name = "fontconfig-etc"; paths = cfg.confPackages; ignoreCollisions = true; }; @@ -247,25 +258,44 @@ let fontconfigNote = "Consider manually configuring fonts.fontconfig according to personal preference."; in { - imports = [ - (lib.mkRenamedOptionModule [ "fonts" "fontconfig" "ultimate" "allowBitmaps" ] [ "fonts" "fontconfig" "allowBitmaps" ]) - (lib.mkRenamedOptionModule [ "fonts" "fontconfig" "ultimate" "allowType1" ] [ "fonts" "fontconfig" "allowType1" ]) - (lib.mkRenamedOptionModule [ "fonts" "fontconfig" "ultimate" "useEmbeddedBitmaps" ] [ "fonts" "fontconfig" "useEmbeddedBitmaps" ]) - (lib.mkRenamedOptionModule [ "fonts" "fontconfig" "ultimate" "forceAutohint" ] [ "fonts" "fontconfig" "forceAutohint" ]) - (lib.mkRenamedOptionModule [ "fonts" "fontconfig" "ultimate" "renderMonoTTFAsBitmap" ] [ "fonts" "fontconfig" "renderMonoTTFAsBitmap" ]) - (lib.mkRemovedOptionModule [ "fonts" "fontconfig" "forceAutohint" ] "") - (lib.mkRemovedOptionModule [ "fonts" "fontconfig" "renderMonoTTFAsBitmap" ] "") - (lib.mkRemovedOptionModule [ "fonts" "fontconfig" "dpi" ] "Use display server-specific options") - (lib.mkRemovedOptionModule [ "hardware" "video" "hidpi" "enable" ] fontconfigNote) - (lib.mkRemovedOptionModule [ "fonts" "optimizeForVeryHighDPI" ] fontconfigNote) - ] ++ lib.forEach [ "enable" "substitutions" "preset" ] - (opt: lib.mkRemovedOptionModule [ "fonts" "fontconfig" "ultimate" "${opt}" ] '' - The fonts.fontconfig.ultimate module and configuration is obsolete. - The repository has since been archived and activity has ceased. - https://github.com/bohoomil/fontconfig-ultimate/issues/171. - No action should be needed for font configuration, as the fonts.fontconfig - module is already used by default. - ''); + imports = + [ + (lib.mkRenamedOptionModule + [ "fonts" "fontconfig" "ultimate" "allowBitmaps" ] + [ "fonts" "fontconfig" "allowBitmaps" ] + ) + (lib.mkRenamedOptionModule + [ "fonts" "fontconfig" "ultimate" "allowType1" ] + [ "fonts" "fontconfig" "allowType1" ] + ) + (lib.mkRenamedOptionModule + [ "fonts" "fontconfig" "ultimate" "useEmbeddedBitmaps" ] + [ "fonts" "fontconfig" "useEmbeddedBitmaps" ] + ) + (lib.mkRenamedOptionModule + [ "fonts" "fontconfig" "ultimate" "forceAutohint" ] + [ "fonts" "fontconfig" "forceAutohint" ] + ) + (lib.mkRenamedOptionModule + [ "fonts" "fontconfig" "ultimate" "renderMonoTTFAsBitmap" ] + [ "fonts" "fontconfig" "renderMonoTTFAsBitmap" ] + ) + (lib.mkRemovedOptionModule [ "fonts" "fontconfig" "forceAutohint" ] "") + (lib.mkRemovedOptionModule [ "fonts" "fontconfig" "renderMonoTTFAsBitmap" ] "") + (lib.mkRemovedOptionModule [ "fonts" "fontconfig" "dpi" ] "Use display server-specific options") + (lib.mkRemovedOptionModule [ "hardware" "video" "hidpi" "enable" ] fontconfigNote) + (lib.mkRemovedOptionModule [ "fonts" "optimizeForVeryHighDPI" ] fontconfigNote) + ] + ++ lib.forEach [ "enable" "substitutions" "preset" ] ( + opt: + lib.mkRemovedOptionModule [ "fonts" "fontconfig" "ultimate" "${opt}" ] '' + The fonts.fontconfig.ultimate module and configuration is obsolete. + The repository has since been archived and activity has ceased. + https://github.com/bohoomil/fontconfig-ultimate/issues/171. + No action should be needed for font configuration, as the fonts.fontconfig + module is already used by default. + '' + ); options = { @@ -286,8 +316,8 @@ in confPackages = lib.mkOption { internal = true; - type = with lib.types; listOf path; - default = [ ]; + type = with lib.types; listOf path; + default = [ ]; description = '' Fontconfig configuration packages. ''; @@ -315,7 +345,7 @@ in defaultFonts = { monospace = lib.mkOption { type = lib.types.listOf lib.types.str; - default = ["DejaVu Sans Mono"]; + default = [ "DejaVu Sans Mono" ]; description = '' System-wide default monospace font(s). Multiple fonts may be listed in case multiple languages must be supported. @@ -324,7 +354,7 @@ in sansSerif = lib.mkOption { type = lib.types.listOf lib.types.str; - default = ["DejaVu Sans"]; + default = [ "DejaVu Sans" ]; description = '' System-wide default sans serif font(s). Multiple fonts may be listed in case multiple languages must be supported. @@ -333,7 +363,7 @@ in serif = lib.mkOption { type = lib.types.listOf lib.types.str; - default = ["DejaVu Serif"]; + default = [ "DejaVu Serif" ]; description = '' System-wide default serif font(s). Multiple fonts may be listed in case multiple languages must be supported. @@ -342,7 +372,7 @@ in emoji = lib.mkOption { type = lib.types.listOf lib.types.str; - default = ["Noto Color Emoji"]; + default = [ "Noto Color Emoji" ]; description = '' System-wide default emoji font(s). Multiple fonts may be listed in case a font does not support all emoji. @@ -379,7 +409,12 @@ in }; style = lib.mkOption { - type = lib.types.enum ["none" "slight" "medium" "full"]; + type = lib.types.enum [ + "none" + "slight" + "medium" + "full" + ]; default = "slight"; description = '' Hintstyle is the amount of font reshaping done to line up @@ -415,7 +450,13 @@ in rgba = lib.mkOption { default = "none"; - type = lib.types.enum ["rgb" "bgr" "vrgb" "vbgr" "none"]; + type = lib.types.enum [ + "rgb" + "bgr" + "vrgb" + "vbgr" + "none" + ]; description = '' Subpixel order. The overwhelming majority of displays are `rgb` in their normal orientation. Select @@ -431,7 +472,12 @@ in lcdfilter = lib.mkOption { default = "default"; - type = lib.types.enum ["none" "default" "light" "legacy"]; + type = lib.types.enum [ + "none" + "default" + "light" + "legacy" + ]; description = '' FreeType LCD filter. At high resolution (> 200 DPI), LCD filtering has no visible effect; users of such displays may want to select @@ -480,8 +526,8 @@ in }; config = lib.mkMerge [ (lib.mkIf cfg.enable { - environment.systemPackages = [ pkgs.fontconfig ]; - environment.etc.fonts.source = "${fontconfigEtc}/etc/fonts/"; + environment.systemPackages = [ pkgs.fontconfig ]; + environment.etc.fonts.source = "${fontconfigEtc}/etc/fonts/"; security.apparmor.includes."abstractions/fonts" = '' # fonts.conf r ${pkg.out}/etc/fonts/fonts.conf, @@ -497,12 +543,12 @@ in # 50-user.conf ${lib.optionalString cfg.includeUserConf '' - r ${pkg.out}/etc/fonts/conf.d.bak/50-user.conf, + r ${pkg.out}/etc/fonts/conf.d.bak/50-user.conf, ''} # local.conf (indirect priority 51) ${lib.optionalString (cfg.localConf != "") '' - r ${localConf}, + r ${localConf}, ''} # 52-nixos-default-fonts.conf @@ -512,8 +558,8 @@ in r ${rejectBitmaps}, ${lib.optionalString (!cfg.allowType1) '' - # 53-nixos-reject-type1.conf - r ${rejectType1}, + # 53-nixos-reject-type1.conf + r ${rejectType1}, ''} ''; }) diff --git a/nixos/modules/config/fonts/fontdir.nix b/nixos/modules/config/fonts/fontdir.nix index 0181883d6c5c80..1d47970d131d99 100644 --- a/nixos/modules/config/fonts/fontdir.nix +++ b/nixos/modules/config/fonts/fontdir.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.fonts.fontDir; diff --git a/nixos/modules/config/fonts/ghostscript.nix b/nixos/modules/config/fonts/ghostscript.nix index dd28c72bba76e7..cbef4b4d470bd3 100644 --- a/nixos/modules/config/fonts/ghostscript.nix +++ b/nixos/modules/config/fonts/ghostscript.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { options = { fonts.enableGhostscriptFonts = lib.mkOption { diff --git a/nixos/modules/config/fonts/packages.nix b/nixos/modules/config/fonts/packages.nix index 36eaa5791d6777..0e4bf4a886a146 100644 --- a/nixos/modules/config/fonts/packages.nix +++ b/nixos/modules/config/fonts/packages.nix @@ -1,11 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.fonts; in { imports = [ - (lib.mkRemovedOptionModule [ "fonts" "enableCoreFonts" ] "Use fonts.packages = [ pkgs.corefonts ]; instead.") + (lib.mkRemovedOptionModule [ + "fonts" + "enableCoreFonts" + ] "Use fonts.packages = [ pkgs.corefonts ]; instead.") (lib.mkRenamedOptionModule [ "fonts" "enableDefaultFonts" ] [ "fonts" "enableDefaultPackages" ]) (lib.mkRenamedOptionModule [ "fonts" "fonts" ] [ "fonts" "packages" ]) ]; @@ -14,7 +22,7 @@ in fonts = { packages = lib.mkOption { type = with lib.types; listOf path; - default = []; + default = [ ]; example = lib.literalExpression "[ pkgs.dejavu_fonts ]"; description = "List of primary font packages."; }; @@ -31,13 +39,16 @@ in }; config = { - fonts.packages = lib.mkIf cfg.enableDefaultPackages (with pkgs; [ - dejavu_fonts - freefont_ttf - gyre-fonts # TrueType substitutes for standard PostScript fonts - liberation_ttf - unifont - noto-fonts-color-emoji - ]); + fonts.packages = lib.mkIf cfg.enableDefaultPackages ( + with pkgs; + [ + dejavu_fonts + freefont_ttf + gyre-fonts # TrueType substitutes for standard PostScript fonts + liberation_ttf + unifont + noto-fonts-color-emoji + ] + ); }; } diff --git a/nixos/modules/config/gtk/gtk-icon-cache.nix b/nixos/modules/config/gtk/gtk-icon-cache.nix index d9d6031956a6ad..5b43417ef6ed4f 100644 --- a/nixos/modules/config/gtk/gtk-icon-cache.nix +++ b/nixos/modules/config/gtk/gtk-icon-cache.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { options = { gtk.iconCache.enable = lib.mkOption { diff --git a/nixos/modules/config/iproute2.nix b/nixos/modules/config/iproute2.nix index 1fa28a7a4c641b..cef2a652b94e67 100644 --- a/nixos/modules/config/iproute2.nix +++ b/nixos/modules/config/iproute2.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.networking.iproute2; in diff --git a/nixos/modules/config/ldap.nix b/nixos/modules/config/ldap.nix index fd26750c273bc6..3a63b6d5ca2c7e 100644 --- a/nixos/modules/config/ldap.nix +++ b/nixos/modules/config/ldap.nix @@ -1,7 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkIf mkMerge mkOption mkRenamedOptionModule types; + inherit (lib) + mkEnableOption + mkIf + mkMerge + mkOption + mkRenamedOptionModule + types + ; cfg = config.users.ldap; @@ -21,7 +33,7 @@ let ${lib.optionalString (config.users.ldap.bind.distinguishedName != "") '' binddn ${config.users.ldap.bind.distinguishedName} ''} - ${lib.optionalString (cfg.extraConfig != "") cfg.extraConfig } + ${lib.optionalString (cfg.extraConfig != "") cfg.extraConfig} ''; }; @@ -30,11 +42,9 @@ let base ${cfg.base} timelimit ${toString cfg.timeLimit} bind_timelimit ${toString cfg.bind.timeLimit} - ${lib.optionalString (cfg.bind.distinguishedName != "") - "binddn ${cfg.bind.distinguishedName}" } - ${lib.optionalString (cfg.daemon.rootpwmoddn != "") - "rootpwmoddn ${cfg.daemon.rootpwmoddn}" } - ${lib.optionalString (cfg.daemon.extraConfig != "") cfg.daemon.extraConfig } + ${lib.optionalString (cfg.bind.distinguishedName != "") "binddn ${cfg.bind.distinguishedName}"} + ${lib.optionalString (cfg.daemon.rootpwmoddn != "") "rootpwmoddn ${cfg.daemon.rootpwmoddn}"} + ${lib.optionalString (cfg.daemon.extraConfig != "") cfg.daemon.extraConfig} ''; # nslcd normally reads configuration from /etc/nslcd.conf. @@ -121,13 +131,13 @@ in }; extraConfig = mkOption { - default = ""; + default = ""; type = types.lines; - description = '' + description = '' Extra configuration options that will be added verbatim at the end of the nslcd configuration file (`nslcd.conf(5)`). ''; - } ; + }; rootpwmoddn = mkOption { default = ""; @@ -183,7 +193,11 @@ in policy = mkOption { default = "hard_open"; - type = types.enum [ "hard_open" "hard_init" "soft" ]; + type = types.enum [ + "hard_open" + "hard_init" + "soft" + ]; description = '' Specifies the policy to use for reconnecting to an unavailable LDAP server. The default is `hard_open`, which @@ -203,7 +217,7 @@ in extraConfig = mkOption { default = ""; type = types.lines; - description = '' + description = '' Extra configuration options that will be added verbatim at the end of the ldap configuration file (`ldap.conf(5)`). If {option}`users.ldap.daemon` is enabled, this @@ -224,9 +238,9 @@ in "ldap.conf" = ldapConfig; }; - system.nssModules = mkIf cfg.nsswitch (lib.singleton ( - if cfg.daemon.enable then pkgs.nss_pam_ldapd else pkgs.nss_ldap - )); + system.nssModules = mkIf cfg.nsswitch ( + lib.singleton (if cfg.daemon.enable then pkgs.nss_pam_ldapd else pkgs.nss_ldap) + ); system.nssDatabases.group = lib.optional cfg.nsswitch "ldap"; system.nssDatabases.passwd = lib.optional cfg.nsswitch "ldap"; @@ -248,7 +262,10 @@ in (mkIf (!cfg.daemon.enable) { ldap-password = { wantedBy = [ "sysinit.target" ]; - before = [ "sysinit.target" "shutdown.target" ]; + before = [ + "sysinit.target" + "shutdown.target" + ]; conflicts = [ "shutdown.target" ]; unitConfig.DefaultDependencies = false; serviceConfig.Type = "oneshot"; @@ -304,7 +321,10 @@ in }; - imports = - [ (mkRenamedOptionModule [ "users" "ldap" "bind" "password"] [ "users" "ldap" "bind" "passwordFile"]) - ]; + imports = [ + (mkRenamedOptionModule + [ "users" "ldap" "bind" "password" ] + [ "users" "ldap" "bind" "passwordFile" ] + ) + ]; } diff --git a/nixos/modules/config/ldso.nix b/nixos/modules/config/ldso.nix index f8d89db0220e34..5ea3842b6e041e 100644 --- a/nixos/modules/config/ldso.nix +++ b/nixos/modules/config/ldso.nix @@ -1,15 +1,29 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) last splitString mkOption types optionals; + inherit (lib) + last + splitString + mkOption + types + optionals + ; libDir = pkgs.stdenv.hostPlatform.libDir; - ldsoBasename = builtins.unsafeDiscardStringContext (last (splitString "/" pkgs.stdenv.cc.bintools.dynamicLinker)); + ldsoBasename = builtins.unsafeDiscardStringContext ( + last (splitString "/" pkgs.stdenv.cc.bintools.dynamicLinker) + ); # Hard-code to avoid creating another instance of nixpkgs. Also avoids eval errors in some cases. libDir32 = "lib"; # pkgs.pkgsi686Linux.stdenv.hostPlatform.libDir ldsoBasename32 = "ld-linux.so.2"; # last (splitString "/" pkgs.pkgsi686Linux.stdenv.cc.bintools.dynamicLinker) -in { +in +{ options = { environment.ldso = mkOption { type = types.nullOr types.path; @@ -32,26 +46,35 @@ in { config = { assertions = [ - { assertion = isNull config.environment.ldso32 || pkgs.stdenv.hostPlatform.isx86_64; + { + assertion = isNull config.environment.ldso32 || pkgs.stdenv.hostPlatform.isx86_64; message = "Option environment.ldso32 currently only works on x86_64."; } ]; - systemd.tmpfiles.rules = ( - if isNull config.environment.ldso then [ - "r /${libDir}/${ldsoBasename} - - - - -" - ] else [ - "d /${libDir} 0755 root root - -" - "L+ /${libDir}/${ldsoBasename} - - - - ${config.environment.ldso}" - ] - ) ++ optionals pkgs.stdenv.hostPlatform.isx86_64 ( - if isNull config.environment.ldso32 then [ - "r /${libDir32}/${ldsoBasename32} - - - - -" - ] else [ - "d /${libDir32} 0755 root root - -" - "L+ /${libDir32}/${ldsoBasename32} - - - - ${config.environment.ldso32}" - ] - ); + systemd.tmpfiles.rules = + ( + if isNull config.environment.ldso then + [ + "r /${libDir}/${ldsoBasename} - - - - -" + ] + else + [ + "d /${libDir} 0755 root root - -" + "L+ /${libDir}/${ldsoBasename} - - - - ${config.environment.ldso}" + ] + ) + ++ optionals pkgs.stdenv.hostPlatform.isx86_64 ( + if isNull config.environment.ldso32 then + [ + "r /${libDir32}/${ldsoBasename32} - - - - -" + ] + else + [ + "d /${libDir32} 0755 root root - -" + "L+ /${libDir32}/${ldsoBasename32} - - - - ${config.environment.ldso32}" + ] + ); }; meta.maintainers = with lib.maintainers; [ tejing ]; diff --git a/nixos/modules/config/locale.nix b/nixos/modules/config/locale.nix index 2d64f1bce4bc2b..cb4115a57e8619 100644 --- a/nixos/modules/config/locale.nix +++ b/nixos/modules/config/locale.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let tzdir = "${pkgs.tzdata}/share/zoneinfo"; - nospace = str: lib.filter (c: c == " ") (lib.stringToCharacters str) == []; - timezone = lib.types.nullOr (lib.types.addCheck lib.types.str nospace) - // { description = "null or string without spaces"; }; + nospace = str: lib.filter (c: c == " ") (lib.stringToCharacters str) == [ ]; + timezone = lib.types.nullOr (lib.types.addCheck lib.types.str nospace) // { + description = "null or string without spaces"; + }; lcfg = config.location; @@ -57,7 +63,10 @@ in }; provider = lib.mkOption { - type = lib.types.enum [ "manual" "geoclue2" ]; + type = lib.types.enum [ + "manual" + "geoclue2" + ]; default = "manual"; description = '' The location provider to use for determining your location. If set to @@ -77,11 +86,15 @@ in # This way services are restarted when tzdata changes. systemd.globalEnvironment.TZDIR = tzdir; - systemd.services.systemd-timedated.environment = lib.optionalAttrs (config.time.timeZone != null) { NIXOS_STATIC_TIMEZONE = "1"; }; + systemd.services.systemd-timedated.environment = lib.optionalAttrs (config.time.timeZone != null) { + NIXOS_STATIC_TIMEZONE = "1"; + }; - environment.etc = { - zoneinfo.source = tzdir; - } // lib.optionalAttrs (config.time.timeZone != null) { + environment.etc = + { + zoneinfo.source = tzdir; + } + // lib.optionalAttrs (config.time.timeZone != null) { localtime.source = "/etc/zoneinfo/${config.time.timeZone}"; localtime.mode = "direct-symlink"; }; diff --git a/nixos/modules/config/malloc.nix b/nixos/modules/config/malloc.nix index 665cbdd27874c0..dfcc6c8159e53a 100644 --- a/nixos/modules/config/malloc.nix +++ b/nixos/modules/config/malloc.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.environment.memoryAllocator; @@ -35,21 +40,25 @@ let ''; }; - scudo = let - platformMap = { - aarch64-linux = "aarch64"; - x86_64-linux = "x86_64"; - }; + scudo = + let + platformMap = { + aarch64-linux = "aarch64"; + x86_64-linux = "x86_64"; + }; - systemPlatform = platformMap.${pkgs.stdenv.hostPlatform.system} or (throw "scudo not supported on ${pkgs.stdenv.hostPlatform.system}"); - in { - libPath = "${pkgs.llvmPackages_14.compiler-rt}/lib/linux/libclang_rt.scudo-${systemPlatform}.so"; - description = '' - A user-mode allocator based on LLVM Sanitizer’s CombinedAllocator, - which aims at providing additional mitigations against heap based - vulnerabilities, while maintaining good performance. - ''; - }; + systemPlatform = + platformMap.${pkgs.stdenv.hostPlatform.system} + or (throw "scudo not supported on ${pkgs.stdenv.hostPlatform.system}"); + in + { + libPath = "${pkgs.llvmPackages_14.compiler-rt}/lib/linux/libclang_rt.scudo-${systemPlatform}.so"; + description = '' + A user-mode allocator based on LLVM Sanitizer’s CombinedAllocator, + which aims at providing additional mitigations against heap based + vulnerabilities, while maintaining good performance. + ''; + }; mimalloc = { libPath = "${pkgs.mimalloc}/lib/libmimalloc.so"; @@ -65,17 +74,18 @@ let # An output that contains only the shared library, to avoid # needlessly bloating the system closure - mallocLib = pkgs.runCommand "malloc-provider-${cfg.provider}" - rec { - preferLocalBuild = true; - allowSubstitutes = false; - origLibPath = providerConf.libPath; - libName = baseNameOf origLibPath; - } - '' - mkdir -p $out/lib - cp -L $origLibPath $out/lib/$libName - ''; + mallocLib = + pkgs.runCommand "malloc-provider-${cfg.provider}" + rec { + preferLocalBuild = true; + allowSubstitutes = false; + origLibPath = providerConf.libPath; + libName = baseNameOf origLibPath; + } + '' + mkdir -p $out/lib + cp -L $origLibPath $out/lib/$libName + ''; # The full path to the selected provider shlib. providerLibPath = "${mallocLib}/lib/${mallocLib.libName}"; @@ -96,9 +106,11 @@ in Briefly, the system-wide memory allocator providers are: - `libc`: the standard allocator provided by libc - ${lib.concatStringsSep "\n" (lib.mapAttrsToList - (name: value: "- `${name}`: ${lib.replaceStrings [ "\n" ] [ " " ] value.description}") - providers)} + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList ( + name: value: "- `${name}`: ${lib.replaceStrings [ "\n" ] [ " " ] value.description}" + ) providers + )} ::: {.warning} Selecting an alternative allocator (i.e., anything other than @@ -117,10 +129,12 @@ in "abstractions/base" = '' r /etc/ld-nix.so.preload, r ${config.environment.etc."ld-nix.so.preload".source}, - include "${pkgs.apparmorRulesFromClosure { + include "${ + pkgs.apparmorRulesFromClosure { name = "mallocLib"; - baseRules = ["mr $path/lib/**.so*"]; - } [ mallocLib ] }" + baseRules = [ "mr $path/lib/**.so*" ]; + } [ mallocLib ] + }" ''; }; }; diff --git a/nixos/modules/config/mysql.nix b/nixos/modules/config/mysql.nix index 6b82603aa455d2..610b03c5e37255 100644 --- a/nixos/modules/config/mysql.nix +++ b/nixos/modules/config/mysql.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.users.mysql; in @@ -79,16 +84,26 @@ in passwordCrypt = lib.mkOption { example = "2"; type = lib.types.enum [ - "0" "plain" - "1" "Y" - "2" "mysql" - "3" "md5" - "4" "sha1" - "5" "drupal7" - "6" "joomla15" - "7" "ssha" - "8" "sha512" - "9" "sha256" + "0" + "plain" + "1" + "Y" + "2" + "mysql" + "3" + "md5" + "4" + "sha1" + "5" + "drupal7" + "6" + "joomla15" + "7" + "ssha" + "8" + "sha512" + "9" + "sha256" ]; description = '' The method to encrypt the user's password: @@ -119,7 +134,14 @@ in ''; }; cryptDefault = lib.mkOption { - type = lib.types.nullOr (lib.types.enum [ "md5" "sha256" "sha512" "blowfish" ]); + type = lib.types.nullOr ( + lib.types.enum [ + "md5" + "sha256" + "sha512" + "blowfish" + ] + ); default = null; example = "blowfish"; description = "The default encryption method to use for `passwordCrypt = 1`."; @@ -358,64 +380,81 @@ in group = "root"; mode = "0600"; # password will be added from password file in systemd oneshot - text = '' - users.host=${cfg.host} - users.db_user=${cfg.user} - users.database=${cfg.database} - users.table=${cfg.pam.table} - users.user_column=${cfg.pam.userColumn} - users.password_column=${cfg.pam.passwordColumn} - users.password_crypt=${cfg.pam.passwordCrypt} - users.disconnect_every_operation=${if cfg.pam.disconnectEveryOperation then "1" else "0"} - verbose=${if cfg.pam.verbose then "1" else "0"} - '' + lib.optionalString (cfg.pam.cryptDefault != null) '' - users.use_${cfg.pam.cryptDefault}=1 - '' + lib.optionalString (cfg.pam.where != null) '' - users.where_clause=${cfg.pam.where} - '' + lib.optionalString (cfg.pam.statusColumn != null) '' - users.status_column=${cfg.pam.statusColumn} - '' + lib.optionalString (cfg.pam.updateTable != null) '' - users.update_table=${cfg.pam.updateTable} - '' + lib.optionalString cfg.pam.logging.enable '' - log.enabled=true - log.table=${cfg.pam.logging.table} - log.message_column=${cfg.pam.logging.msgColumn} - log.pid_column=${cfg.pam.logging.pidColumn} - log.user_column=${cfg.pam.logging.userColumn} - log.host_column=${cfg.pam.logging.hostColumn} - log.rhost_column=${cfg.pam.logging.rHostColumn} - log.time_column=${cfg.pam.logging.timeColumn} - ''; + text = + '' + users.host=${cfg.host} + users.db_user=${cfg.user} + users.database=${cfg.database} + users.table=${cfg.pam.table} + users.user_column=${cfg.pam.userColumn} + users.password_column=${cfg.pam.passwordColumn} + users.password_crypt=${cfg.pam.passwordCrypt} + users.disconnect_every_operation=${if cfg.pam.disconnectEveryOperation then "1" else "0"} + verbose=${if cfg.pam.verbose then "1" else "0"} + '' + + lib.optionalString (cfg.pam.cryptDefault != null) '' + users.use_${cfg.pam.cryptDefault}=1 + '' + + lib.optionalString (cfg.pam.where != null) '' + users.where_clause=${cfg.pam.where} + '' + + lib.optionalString (cfg.pam.statusColumn != null) '' + users.status_column=${cfg.pam.statusColumn} + '' + + lib.optionalString (cfg.pam.updateTable != null) '' + users.update_table=${cfg.pam.updateTable} + '' + + lib.optionalString cfg.pam.logging.enable '' + log.enabled=true + log.table=${cfg.pam.logging.table} + log.message_column=${cfg.pam.logging.msgColumn} + log.pid_column=${cfg.pam.logging.pidColumn} + log.user_column=${cfg.pam.logging.userColumn} + log.host_column=${cfg.pam.logging.hostColumn} + log.rhost_column=${cfg.pam.logging.rHostColumn} + log.time_column=${cfg.pam.logging.timeColumn} + ''; }; environment.etc."libnss-mysql.cfg" = { mode = "0600"; user = config.services.nscd.user; group = config.services.nscd.group; - text = lib.optionalString (cfg.nss.getpwnam != null) '' - getpwnam ${cfg.nss.getpwnam} - '' + lib.optionalString (cfg.nss.getpwuid != null) '' - getpwuid ${cfg.nss.getpwuid} - '' + lib.optionalString (cfg.nss.getspnam != null) '' - getspnam ${cfg.nss.getspnam} - '' + lib.optionalString (cfg.nss.getpwent != null) '' - getpwent ${cfg.nss.getpwent} - '' + lib.optionalString (cfg.nss.getspent != null) '' - getspent ${cfg.nss.getspent} - '' + lib.optionalString (cfg.nss.getgrnam != null) '' - getgrnam ${cfg.nss.getgrnam} - '' + lib.optionalString (cfg.nss.getgrgid != null) '' - getgrgid ${cfg.nss.getgrgid} - '' + lib.optionalString (cfg.nss.getgrent != null) '' - getgrent ${cfg.nss.getgrent} - '' + lib.optionalString (cfg.nss.memsbygid != null) '' - memsbygid ${cfg.nss.memsbygid} - '' + lib.optionalString (cfg.nss.gidsbymem != null) '' - gidsbymem ${cfg.nss.gidsbymem} - '' + '' - host ${cfg.host} - database ${cfg.database} - ''; + text = + lib.optionalString (cfg.nss.getpwnam != null) '' + getpwnam ${cfg.nss.getpwnam} + '' + + lib.optionalString (cfg.nss.getpwuid != null) '' + getpwuid ${cfg.nss.getpwuid} + '' + + lib.optionalString (cfg.nss.getspnam != null) '' + getspnam ${cfg.nss.getspnam} + '' + + lib.optionalString (cfg.nss.getpwent != null) '' + getpwent ${cfg.nss.getpwent} + '' + + lib.optionalString (cfg.nss.getspent != null) '' + getspent ${cfg.nss.getspent} + '' + + lib.optionalString (cfg.nss.getgrnam != null) '' + getgrnam ${cfg.nss.getgrnam} + '' + + lib.optionalString (cfg.nss.getgrgid != null) '' + getgrgid ${cfg.nss.getgrgid} + '' + + lib.optionalString (cfg.nss.getgrent != null) '' + getgrent ${cfg.nss.getgrent} + '' + + lib.optionalString (cfg.nss.memsbygid != null) '' + memsbygid ${cfg.nss.memsbygid} + '' + + lib.optionalString (cfg.nss.gidsbymem != null) '' + gidsbymem ${cfg.nss.gidsbymem} + '' + + '' + host ${cfg.host} + database ${cfg.database} + ''; }; environment.etc."libnss-mysql-root.cfg" = { diff --git a/nixos/modules/config/nix-flakes.nix b/nixos/modules/config/nix-flakes.nix index 90e207fd4a61ee..69388e791154fc 100644 --- a/nixos/modules/config/nix-flakes.nix +++ b/nixos/modules/config/nix-flakes.nix @@ -4,7 +4,7 @@ See also - ./nix.nix - ./nix-channel.nix - */ +*/ { config, lib, ... }: let inherit (lib) @@ -24,60 +24,75 @@ in options = { nix = { registry = mkOption { - type = types.attrsOf (types.submodule ( - let - referenceAttrs = with types; attrsOf (oneOf [ - str - int - bool - path - package - ]); - in - { config, name, ... }: - { - options = { - from = mkOption { - type = referenceAttrs; - example = { type = "indirect"; id = "nixpkgs"; }; - description = "The flake reference to be rewritten."; + type = types.attrsOf ( + types.submodule ( + let + referenceAttrs = + with types; + attrsOf (oneOf [ + str + int + bool + path + package + ]); + in + { config, name, ... }: + { + options = { + from = mkOption { + type = referenceAttrs; + example = { + type = "indirect"; + id = "nixpkgs"; + }; + description = "The flake reference to be rewritten."; + }; + to = mkOption { + type = referenceAttrs; + example = { + type = "github"; + owner = "my-org"; + repo = "my-nixpkgs"; + }; + description = "The flake reference {option}`from` is rewritten to."; + }; + flake = mkOption { + type = types.nullOr types.attrs; + default = null; + example = literalExpression "nixpkgs"; + description = '' + The flake input {option}`from` is rewritten to. + ''; + }; + exact = mkOption { + type = types.bool; + default = true; + description = '' + Whether the {option}`from` reference needs to match exactly. If set, + a {option}`from` reference like `nixpkgs` does not + match with a reference like `nixpkgs/nixos-20.03`. + ''; + }; }; - to = mkOption { - type = referenceAttrs; - example = { type = "github"; owner = "my-org"; repo = "my-nixpkgs"; }; - description = "The flake reference {option}`from` is rewritten to."; + config = { + from = mkDefault { + type = "indirect"; + id = name; + }; + to = mkIf (config.flake != null) ( + mkDefault ( + { + type = "path"; + path = config.flake.outPath; + } + // filterAttrs (n: _: n == "lastModified" || n == "rev" || n == "narHash") config.flake + ) + ); }; - flake = mkOption { - type = types.nullOr types.attrs; - default = null; - example = literalExpression "nixpkgs"; - description = '' - The flake input {option}`from` is rewritten to. - ''; - }; - exact = mkOption { - type = types.bool; - default = true; - description = '' - Whether the {option}`from` reference needs to match exactly. If set, - a {option}`from` reference like `nixpkgs` does not - match with a reference like `nixpkgs/nixos-20.03`. - ''; - }; - }; - config = { - from = mkDefault { type = "indirect"; id = name; }; - to = mkIf (config.flake != null) (mkDefault ( - { - type = "path"; - path = config.flake.outPath; - } // filterAttrs - (n: _: n == "lastModified" || n == "rev" || n == "narHash") - config.flake - )); - }; - } - )); + } + ) + ); default = { }; description = '' A system-wide flake registry. diff --git a/nixos/modules/config/nix-remote-build.nix b/nixos/modules/config/nix-remote-build.nix index e8aa438a262d01..11fcec30ff640a 100644 --- a/nixos/modules/config/nix-remote-build.nix +++ b/nixos/modules/config/nix-remote-build.nix @@ -4,7 +4,7 @@ See also - ./nix.nix - nixos/modules/services/system/nix-daemon.nix - */ +*/ { config, lib, ... }: let @@ -29,150 +29,181 @@ let isNixAtLeast = versionAtLeast (getVersion nixPackage); - buildMachinesText = - concatMapStrings - (machine: - (concatStringsSep " " ([ - "${optionalString (machine.protocol != null) "${machine.protocol}://"}${optionalString (machine.sshUser != null) "${machine.sshUser}@"}${machine.hostName}" - (if machine.system != null then machine.system else if machine.systems != [ ] then concatStringsSep "," machine.systems else "-") - (if machine.sshKey != null then machine.sshKey else "-") - (toString machine.maxJobs) - (toString machine.speedFactor) - (let res = (machine.supportedFeatures ++ machine.mandatoryFeatures); - in if (res == []) then "-" else (concatStringsSep "," res)) - (let res = machine.mandatoryFeatures; - in if (res == []) then "-" else (concatStringsSep "," machine.mandatoryFeatures)) - ] - ++ optional (isNixAtLeast "2.4pre") (if machine.publicHostKey != null then machine.publicHostKey else "-"))) - + "\n" + buildMachinesText = concatMapStrings ( + machine: + (concatStringsSep " " ( + [ + "${optionalString (machine.protocol != null) "${machine.protocol}://"}${ + optionalString (machine.sshUser != null) "${machine.sshUser}@" + }${machine.hostName}" + ( + if machine.system != null then + machine.system + else if machine.systems != [ ] then + concatStringsSep "," machine.systems + else + "-" + ) + (if machine.sshKey != null then machine.sshKey else "-") + (toString machine.maxJobs) + (toString machine.speedFactor) + ( + let + res = (machine.supportedFeatures ++ machine.mandatoryFeatures); + in + if (res == [ ]) then "-" else (concatStringsSep "," res) + ) + ( + let + res = machine.mandatoryFeatures; + in + if (res == [ ]) then "-" else (concatStringsSep "," machine.mandatoryFeatures) + ) + ] + ++ optional (isNixAtLeast "2.4pre") ( + if machine.publicHostKey != null then machine.publicHostKey else "-" ) - cfg.buildMachines; + )) + + "\n" + ) cfg.buildMachines; in { options = { nix = { buildMachines = mkOption { - type = types.listOf (types.submodule { - options = { - hostName = mkOption { - type = types.str; - example = "nixbuilder.example.org"; - description = '' - The hostname of the build machine. - ''; - }; - protocol = mkOption { - type = types.enum [ null "ssh" "ssh-ng" ]; - default = "ssh"; - example = "ssh-ng"; - description = '' - The protocol used for communicating with the build machine. - Use `ssh-ng` if your remote builder and your - local Nix version support that improved protocol. + type = types.listOf ( + types.submodule { + options = { + hostName = mkOption { + type = types.str; + example = "nixbuilder.example.org"; + description = '' + The hostname of the build machine. + ''; + }; + protocol = mkOption { + type = types.enum [ + null + "ssh" + "ssh-ng" + ]; + default = "ssh"; + example = "ssh-ng"; + description = '' + The protocol used for communicating with the build machine. + Use `ssh-ng` if your remote builder and your + local Nix version support that improved protocol. - Use `null` when trying to change the special localhost builder - without a protocol which is for example used by hydra. - ''; - }; - system = mkOption { - type = types.nullOr types.str; - default = null; - example = "x86_64-linux"; - description = '' - The system type the build machine can execute derivations on. - Either this attribute or {var}`systems` must be - present, where {var}`system` takes precedence if - both are set. - ''; - }; - systems = mkOption { - type = types.listOf types.str; - default = [ ]; - example = [ "x86_64-linux" "aarch64-linux" ]; - description = '' - The system types the build machine can execute derivations on. - Either this attribute or {var}`system` must be - present, where {var}`system` takes precedence if - both are set. - ''; - }; - sshUser = mkOption { - type = types.nullOr types.str; - default = null; - example = "builder"; - description = '' - The username to log in as on the remote host. This user must be - able to log in and run nix commands non-interactively. It must - also be privileged to build derivations, so must be included in - {option}`nix.settings.trusted-users`. - ''; - }; - sshKey = mkOption { - type = types.nullOr types.str; - default = null; - example = "/root/.ssh/id_buildhost_builduser"; - description = '' - The path to the SSH private key with which to authenticate on - the build machine. The private key must not have a passphrase. - If null, the building user (root on NixOS machines) must have an - appropriate ssh configuration to log in non-interactively. + Use `null` when trying to change the special localhost builder + without a protocol which is for example used by hydra. + ''; + }; + system = mkOption { + type = types.nullOr types.str; + default = null; + example = "x86_64-linux"; + description = '' + The system type the build machine can execute derivations on. + Either this attribute or {var}`systems` must be + present, where {var}`system` takes precedence if + both are set. + ''; + }; + systems = mkOption { + type = types.listOf types.str; + default = [ ]; + example = [ + "x86_64-linux" + "aarch64-linux" + ]; + description = '' + The system types the build machine can execute derivations on. + Either this attribute or {var}`system` must be + present, where {var}`system` takes precedence if + both are set. + ''; + }; + sshUser = mkOption { + type = types.nullOr types.str; + default = null; + example = "builder"; + description = '' + The username to log in as on the remote host. This user must be + able to log in and run nix commands non-interactively. It must + also be privileged to build derivations, so must be included in + {option}`nix.settings.trusted-users`. + ''; + }; + sshKey = mkOption { + type = types.nullOr types.str; + default = null; + example = "/root/.ssh/id_buildhost_builduser"; + description = '' + The path to the SSH private key with which to authenticate on + the build machine. The private key must not have a passphrase. + If null, the building user (root on NixOS machines) must have an + appropriate ssh configuration to log in non-interactively. - Note that for security reasons, this path must point to a file - in the local filesystem, *not* to the nix store. - ''; + Note that for security reasons, this path must point to a file + in the local filesystem, *not* to the nix store. + ''; + }; + maxJobs = mkOption { + type = types.int; + default = 1; + description = '' + The number of concurrent jobs the build machine supports. The + build machine will enforce its own limits, but this allows hydra + to schedule better since there is no work-stealing between build + machines. + ''; + }; + speedFactor = mkOption { + type = types.int; + default = 1; + description = '' + The relative speed of this builder. This is an arbitrary integer + that indicates the speed of this builder, relative to other + builders. Higher is faster. + ''; + }; + mandatoryFeatures = mkOption { + type = types.listOf types.str; + default = [ ]; + example = [ "big-parallel" ]; + description = '' + A list of features mandatory for this builder. The builder will + be ignored for derivations that don't require all features in + this list. All mandatory features are automatically included in + {var}`supportedFeatures`. + ''; + }; + supportedFeatures = mkOption { + type = types.listOf types.str; + default = [ ]; + example = [ + "kvm" + "big-parallel" + ]; + description = '' + A list of features supported by this builder. The builder will + be ignored for derivations that require features not in this + list. + ''; + }; + publicHostKey = mkOption { + type = types.nullOr types.str; + default = null; + description = '' + The (base64-encoded) public host key of this builder. The field + is calculated via {command}`base64 -w0 /etc/ssh/ssh_host_type_key.pub`. + If null, SSH will use its regular known-hosts file when connecting. + ''; + }; }; - maxJobs = mkOption { - type = types.int; - default = 1; - description = '' - The number of concurrent jobs the build machine supports. The - build machine will enforce its own limits, but this allows hydra - to schedule better since there is no work-stealing between build - machines. - ''; - }; - speedFactor = mkOption { - type = types.int; - default = 1; - description = '' - The relative speed of this builder. This is an arbitrary integer - that indicates the speed of this builder, relative to other - builders. Higher is faster. - ''; - }; - mandatoryFeatures = mkOption { - type = types.listOf types.str; - default = [ ]; - example = [ "big-parallel" ]; - description = '' - A list of features mandatory for this builder. The builder will - be ignored for derivations that don't require all features in - this list. All mandatory features are automatically included in - {var}`supportedFeatures`. - ''; - }; - supportedFeatures = mkOption { - type = types.listOf types.str; - default = [ ]; - example = [ "kvm" "big-parallel" ]; - description = '' - A list of features supported by this builder. The builder will - be ignored for derivations that require features not in this - list. - ''; - }; - publicHostKey = mkOption { - type = types.nullOr types.str; - default = null; - description = '' - The (base64-encoded) public host key of this builder. The field - is calculated via {command}`base64 -w0 /etc/ssh/ssh_host_type_key.pub`. - If null, SSH will use its regular known-hosts file when connecting. - ''; - }; - }; - }); + } + ); default = [ ]; description = '' This option lists the machines to be used if distributed builds are @@ -198,27 +229,27 @@ in # override that nix option. config = mkIf cfg.enable { assertions = - let badMachine = m: m.system == null && m.systems == [ ]; + let + badMachine = m: m.system == null && m.systems == [ ]; in [ { assertion = !(any badMachine cfg.buildMachines); - message = '' - At least one system type (via system or - systems) must be set for every build machine. - Invalid machine specifications: - '' + " " + - (concatStringsSep "\n " - (map (m: m.hostName) - (filter (badMachine) cfg.buildMachines))); + message = + '' + At least one system type (via system or + systems) must be set for every build machine. + Invalid machine specifications: + '' + + " " + + (concatStringsSep "\n " (map (m: m.hostName) (filter (badMachine) cfg.buildMachines))); } ]; # List of machines for distributed Nix builds - environment.etc."nix/machines" = - mkIf (cfg.buildMachines != [ ]) { - text = buildMachinesText; - }; + environment.etc."nix/machines" = mkIf (cfg.buildMachines != [ ]) { + text = buildMachinesText; + }; # Legacy configuration conversion. nix.settings = mkIf (!cfg.distributedBuilds) { builders = null; }; diff --git a/nixos/modules/config/nsswitch.nix b/nixos/modules/config/nsswitch.nix index 71c79eafeb0947..354c506e0ae897 100644 --- a/nixos/modules/config/nsswitch.nix +++ b/nixos/modules/config/nsswitch.nix @@ -1,5 +1,10 @@ # Configuration for the Name Service Switch (/etc/nsswitch.conf). -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { options = { @@ -14,11 +19,10 @@ several DNS resolution methods to be specified via {file}`/etc/nsswitch.conf`. ''; - apply = list: - { - inherit list; - path = lib.makeLibraryPath list; - }; + apply = list: { + inherit list; + path = lib.makeLibraryPath list; + }; }; system.nssDatabases = { diff --git a/nixos/modules/config/power-management.nix b/nixos/modules/config/power-management.nix index 524a23edab64e7..6b2253068c0b47 100644 --- a/nixos/modules/config/power-management.nix +++ b/nixos/modules/config/power-management.nix @@ -17,9 +17,9 @@ in type = lib.types.bool; default = true; description = '' - Whether to enable power management. This includes support - for suspend-to-RAM and powersave features on laptops. - ''; + Whether to enable power management. This includes support + for suspend-to-RAM and powersave features on laptops. + ''; }; resumeCommands = lib.mkOption { @@ -35,10 +35,10 @@ in "''${pkgs.hdparm}/sbin/hdparm -B 255 /dev/sda" ''; description = '' - Commands executed when the machine powers up. That is, - they're executed both when the system first boots and when - it resumes from suspend or hibernation. - ''; + Commands executed when the machine powers up. That is, + they're executed both when the system first boots and when + it resumes from suspend or hibernation. + ''; }; powerDownCommands = lib.mkOption { @@ -48,17 +48,16 @@ in "''${pkgs.hdparm}/sbin/hdparm -B 255 /dev/sda" ''; description = '' - Commands executed when the machine powers down. That is, - they're executed both when the system shuts down and when - it goes to suspend or hibernation. - ''; + Commands executed when the machine powers down. That is, + they're executed both when the system shuts down and when + it goes to suspend or hibernation. + ''; }; }; }; - ###### implementation config = lib.mkIf cfg.enable { @@ -72,28 +71,31 @@ in }; # Service executed before suspending/hibernating. - systemd.services.pre-sleep = - { description = "Pre-Sleep Actions"; - wantedBy = [ "sleep.target" ]; - before = [ "sleep.target" ]; - script = - '' - ${cfg.powerDownCommands} - ''; - serviceConfig.Type = "oneshot"; - }; + systemd.services.pre-sleep = { + description = "Pre-Sleep Actions"; + wantedBy = [ "sleep.target" ]; + before = [ "sleep.target" ]; + script = '' + ${cfg.powerDownCommands} + ''; + serviceConfig.Type = "oneshot"; + }; - systemd.services.post-resume = - { description = "Post-Resume Actions"; - after = [ "suspend.target" "hibernate.target" "hybrid-sleep.target" "suspend-then-hibernate.target" ]; - script = - '' - /run/current-system/systemd/bin/systemctl try-restart --no-block post-resume.target - ${cfg.resumeCommands} - ${cfg.powerUpCommands} - ''; - serviceConfig.Type = "oneshot"; - }; + systemd.services.post-resume = { + description = "Post-Resume Actions"; + after = [ + "suspend.target" + "hibernate.target" + "hybrid-sleep.target" + "suspend-then-hibernate.target" + ]; + script = '' + /run/current-system/systemd/bin/systemctl try-restart --no-block post-resume.target + ${cfg.resumeCommands} + ${cfg.powerUpCommands} + ''; + serviceConfig.Type = "oneshot"; + }; }; diff --git a/nixos/modules/config/pulseaudio.nix b/nixos/modules/config/pulseaudio.nix index 6e6e577e6e2046..2a28f26eb2c056 100644 --- a/nixos/modules/config/pulseaudio.nix +++ b/nixos/modules/config/pulseaudio.nix @@ -1,34 +1,51 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.pulseaudio; - hasZeroconf = let z = cfg.zeroconf; in z.publish.enable || z.discovery.enable; + hasZeroconf = + let + z = cfg.zeroconf; + in + z.publish.enable || z.discovery.enable; - overriddenPackage = cfg.package.override - (lib.optionalAttrs hasZeroconf { zeroconfSupport = true; }); + overriddenPackage = cfg.package.override ( + lib.optionalAttrs hasZeroconf { zeroconfSupport = true; } + ); binary = "${lib.getBin overriddenPackage}/bin/pulseaudio"; binaryNoDaemon = "${binary} --daemonize=no"; # Forces 32bit pulseaudio and alsa-plugins to be built/supported for apps # using 32bit alsa on 64bit linux. - enable32BitAlsaPlugins = cfg.support32Bit && pkgs.stdenv.hostPlatform.isx86_64 && (pkgs.pkgsi686Linux.alsa-lib != null && pkgs.pkgsi686Linux.libpulseaudio != null); - + enable32BitAlsaPlugins = + cfg.support32Bit + && pkgs.stdenv.hostPlatform.isx86_64 + && (pkgs.pkgsi686Linux.alsa-lib != null && pkgs.pkgsi686Linux.libpulseaudio != null); myConfigFile = let addModuleIf = cond: mod: lib.optionalString cond "load-module ${mod}"; allAnon = lib.optional cfg.tcp.anonymousClients.allowAll "auth-anonymous=1"; - ipAnon = let a = cfg.tcp.anonymousClients.allowedIpRanges; - in lib.optional (a != []) ''auth-ip-acl=${lib.concatStringsSep ";" a}''; - in pkgs.writeTextFile { + ipAnon = + let + a = cfg.tcp.anonymousClients.allowedIpRanges; + in + lib.optional (a != [ ]) ''auth-ip-acl=${lib.concatStringsSep ";" a}''; + in + pkgs.writeTextFile { name = "default.pa"; - text = '' + text = '' .include ${cfg.configFile} ${addModuleIf cfg.zeroconf.publish.enable "module-zeroconf-publish"} ${addModuleIf cfg.zeroconf.discovery.enable "module-zeroconf-discover"} - ${addModuleIf cfg.tcp.enable (lib.concatStringsSep " " - ([ "module-native-protocol-tcp" ] ++ allAnon ++ ipAnon))} + ${addModuleIf cfg.tcp.enable ( + lib.concatStringsSep " " ([ "module-native-protocol-tcp" ] ++ allAnon ++ ipAnon) + )} ${addModuleIf config.services.jack.jackd.enable "module-jack-sink"} ${addModuleIf config.services.jack.jackd.enable "module-jack-source"} ${cfg.extraConfig} @@ -56,8 +73,7 @@ let alsaConf = '' pcm_type.pulse { libs.native = ${pkgs.alsa-plugins}/lib/alsa-lib/libasound_module_pcm_pulse.so ; - ${lib.optionalString enable32BitAlsaPlugins - "libs.32Bit = ${pkgs.pkgsi686Linux.alsa-plugins}/lib/alsa-lib/libasound_module_pcm_pulse.so ;"} + ${lib.optionalString enable32BitAlsaPlugins "libs.32Bit = ${pkgs.pkgsi686Linux.alsa-plugins}/lib/alsa-lib/libasound_module_pcm_pulse.so ;"} } pcm.!default { type pulse @@ -65,15 +81,15 @@ let } ctl_type.pulse { libs.native = ${pkgs.alsa-plugins}/lib/alsa-lib/libasound_module_ctl_pulse.so ; - ${lib.optionalString enable32BitAlsaPlugins - "libs.32Bit = ${pkgs.pkgsi686Linux.alsa-plugins}/lib/alsa-lib/libasound_module_ctl_pulse.so ;"} + ${lib.optionalString enable32BitAlsaPlugins "libs.32Bit = ${pkgs.pkgsi686Linux.alsa-plugins}/lib/alsa-lib/libasound_module_ctl_pulse.so ;"} } ctl.!default { type pulse } ''; -in { +in +{ options = { @@ -138,9 +154,7 @@ in { package = lib.mkOption { type = lib.types.package; - default = if config.services.jack.jackd.enable - then pkgs.pulseaudioFull - else pkgs.pulseaudio; + default = if config.services.jack.jackd.enable then pkgs.pulseaudioFull else pkgs.pulseaudio; defaultText = lib.literalExpression "pkgs.pulseaudio"; example = lib.literalExpression "pkgs.pulseaudioFull"; description = '' @@ -152,7 +166,7 @@ in { extraModules = lib.mkOption { type = lib.types.listOf lib.types.package; - default = []; + default = [ ]; example = lib.literalExpression "[ pkgs.pulseaudio-modules-bt ]"; description = '' Extra pulseaudio modules to use. This is intended for out-of-tree @@ -174,17 +188,15 @@ in { config = lib.mkOption { type = lib.types.attrsOf lib.types.unspecified; - default = {}; + default = { }; description = "Config of the pulse daemon. See `man pulse-daemon.conf`."; example = lib.literalExpression ''{ realtime-scheduling = "yes"; }''; }; }; zeroconf = { - discovery.enable = - lib.mkEnableOption "discovery of pulseaudio sinks in the local network"; - publish.enable = - lib.mkEnableOption "publishing the pulseaudio sink in the local network"; + discovery.enable = lib.mkEnableOption "discovery of pulseaudio sinks in the local network"; + publish.enable = lib.mkEnableOption "publishing the pulseaudio sink in the local network"; }; # TODO: enable by default? @@ -195,7 +207,7 @@ in { allowAll = lib.mkEnableOption "all anonymous clients to stream to the server"; allowedIpRanges = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = lib.literalExpression ''[ "127.0.0.1" "192.168.1.0/24" ]''; description = '' A list of IP subnets that are allowed to stream to the server. @@ -208,112 +220,120 @@ in { }; + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + { + environment.etc."pulse/client.conf".source = clientConf; - config = lib.mkIf cfg.enable (lib.mkMerge [ - { - environment.etc."pulse/client.conf".source = clientConf; - - environment.systemPackages = [ overriddenPackage ]; + environment.systemPackages = [ overriddenPackage ]; - environment.etc = { - "alsa/conf.d/99-pulseaudio.conf".text = alsaConf; + environment.etc = { + "alsa/conf.d/99-pulseaudio.conf".text = alsaConf; - "pulse/daemon.conf".source = pkgs.writeText "daemon.conf" - (lib.generators.toKeyValue {} cfg.daemon.config); - - "openal/alsoft.conf".source = pkgs.writeText "alsoft.conf" "drivers=pulse"; - - "libao.conf".source = pkgs.writeText "libao.conf" "default_driver=pulse"; - }; + "pulse/daemon.conf".source = pkgs.writeText "daemon.conf" ( + lib.generators.toKeyValue { } cfg.daemon.config + ); - hardware.pulseaudio.configFile = lib.mkDefault "${lib.getBin overriddenPackage}/etc/pulse/default.pa"; + "openal/alsoft.conf".source = pkgs.writeText "alsoft.conf" "drivers=pulse"; - # Disable flat volumes to enable relative ones - hardware.pulseaudio.daemon.config.flat-volumes = lib.mkDefault "no"; - - # Upstream defaults to speex-float-1 which results in audible artifacts - hardware.pulseaudio.daemon.config.resample-method = lib.mkDefault "speex-float-5"; - - # Allow PulseAudio to get realtime priority using rtkit. - security.rtkit.enable = true; + "libao.conf".source = pkgs.writeText "libao.conf" "default_driver=pulse"; + }; - systemd.packages = [ overriddenPackage ]; + hardware.pulseaudio.configFile = lib.mkDefault "${lib.getBin overriddenPackage}/etc/pulse/default.pa"; + + # Disable flat volumes to enable relative ones + hardware.pulseaudio.daemon.config.flat-volumes = lib.mkDefault "no"; + + # Upstream defaults to speex-float-1 which results in audible artifacts + hardware.pulseaudio.daemon.config.resample-method = lib.mkDefault "speex-float-5"; + + # Allow PulseAudio to get realtime priority using rtkit. + security.rtkit.enable = true; + + systemd.packages = [ overriddenPackage ]; + + # PulseAudio is packaged with udev rules to handle various audio device quirks + services.udev.packages = [ overriddenPackage ]; + } + + (lib.mkIf (cfg.extraModules != [ ]) { + hardware.pulseaudio.daemon.config.dl-search-path = + let + overriddenModules = builtins.map ( + drv: drv.override { pulseaudio = overriddenPackage; } + ) cfg.extraModules; + modulePaths = + builtins.map (drv: "${drv}/lib/pulseaudio/modules") + # User-provided extra modules take precedence + (overriddenModules ++ [ overriddenPackage ]); + in + lib.concatStringsSep ":" modulePaths; + }) + + (lib.mkIf hasZeroconf { + services.avahi.enable = true; + }) + (lib.mkIf cfg.zeroconf.publish.enable { + services.avahi.publish.enable = true; + services.avahi.publish.userServices = true; + }) + + (lib.mkIf (!cfg.systemWide) { + environment.etc = { + "pulse/default.pa".source = myConfigFile; + }; + systemd.user = { + services.pulseaudio = + { + restartIfChanged = true; + serviceConfig = { + RestartSec = "500ms"; + PassEnvironment = "DISPLAY"; + }; + } + // lib.optionalAttrs config.services.jack.jackd.enable { + environment.JACK_PROMISCUOUS_SERVER = "jackaudio"; + }; + sockets.pulseaudio = { + wantedBy = [ "sockets.target" ]; + }; + }; + }) + + (lib.mkIf cfg.systemWide { + users.users.pulse = { + # For some reason, PulseAudio wants UID == GID. + uid = + assert uid == gid; + uid; + group = "pulse"; + extraGroups = [ "audio" ]; + description = "PulseAudio system service user"; + home = stateDir; + homeMode = "755"; + createHome = true; + isSystemUser = true; + }; - # PulseAudio is packaged with udev rules to handle various audio device quirks - services.udev.packages = [ overriddenPackage ]; - } + users.groups.pulse.gid = gid; + users.groups.pulse-access = { }; - (lib.mkIf (cfg.extraModules != []) { - hardware.pulseaudio.daemon.config.dl-search-path = let - overriddenModules = builtins.map - (drv: drv.override { pulseaudio = overriddenPackage; }) - cfg.extraModules; - modulePaths = builtins.map - (drv: "${drv}/lib/pulseaudio/modules") - # User-provided extra modules take precedence - (overriddenModules ++ [ overriddenPackage ]); - in lib.concatStringsSep ":" modulePaths; - }) - - (lib.mkIf hasZeroconf { - services.avahi.enable = true; - }) - (lib.mkIf cfg.zeroconf.publish.enable { - services.avahi.publish.enable = true; - services.avahi.publish.userServices = true; - }) - - (lib.mkIf (!cfg.systemWide) { - environment.etc = { - "pulse/default.pa".source = myConfigFile; - }; - systemd.user = { - services.pulseaudio = { - restartIfChanged = true; + systemd.services.pulseaudio = { + description = "PulseAudio System-Wide Server"; + wantedBy = [ "sound.target" ]; + before = [ "sound.target" ]; + environment.PULSE_RUNTIME_PATH = stateDir; serviceConfig = { + Type = "notify"; + ExecStart = "${binaryNoDaemon} --log-level=${cfg.daemon.logLevel} --system -n --file=${myConfigFile}"; + Restart = "on-failure"; RestartSec = "500ms"; - PassEnvironment = "DISPLAY"; }; - } // lib.optionalAttrs config.services.jack.jackd.enable { - environment.JACK_PROMISCUOUS_SERVER = "jackaudio"; - }; - sockets.pulseaudio = { - wantedBy = [ "sockets.target" ]; }; - }; - }) - - (lib.mkIf cfg.systemWide { - users.users.pulse = { - # For some reason, PulseAudio wants UID == GID. - uid = assert uid == gid; uid; - group = "pulse"; - extraGroups = [ "audio" ]; - description = "PulseAudio system service user"; - home = stateDir; - homeMode = "755"; - createHome = true; - isSystemUser = true; - }; - - users.groups.pulse.gid = gid; - users.groups.pulse-access = {}; - - systemd.services.pulseaudio = { - description = "PulseAudio System-Wide Server"; - wantedBy = [ "sound.target" ]; - before = [ "sound.target" ]; - environment.PULSE_RUNTIME_PATH = stateDir; - serviceConfig = { - Type = "notify"; - ExecStart = "${binaryNoDaemon} --log-level=${cfg.daemon.logLevel} --system -n --file=${myConfigFile}"; - Restart = "on-failure"; - RestartSec = "500ms"; - }; - }; - environment.variables.PULSE_COOKIE = "${stateDir}/.config/pulse/cookie"; - }) - ]); + environment.variables.PULSE_COOKIE = "${stateDir}/.config/pulse/cookie"; + }) + ] + ); } diff --git a/nixos/modules/config/qt.nix b/nixos/modules/config/qt.nix index bf050f17620c47..fb10ef5c323874 100644 --- a/nixos/modules/config/qt.nix +++ b/nixos/modules/config/qt.nix @@ -1,14 +1,34 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.qt; platformPackages = with pkgs; { - gnome = [ qgnomeplatform qgnomeplatform-qt6 ]; - gtk2 = [ libsForQt5.qtstyleplugins qt6Packages.qt6gtk2 ]; - kde = [ libsForQt5.plasma-integration libsForQt5.systemsettings ]; - lxqt = [ lxqt.lxqt-qtplugin lxqt.lxqt-config ]; - qt5ct = [ libsForQt5.qt5ct qt6Packages.qt6ct ]; + gnome = [ + qgnomeplatform + qgnomeplatform-qt6 + ]; + gtk2 = [ + libsForQt5.qtstyleplugins + qt6Packages.qt6gtk2 + ]; + kde = [ + libsForQt5.plasma-integration + libsForQt5.systemsettings + ]; + lxqt = [ + lxqt.lxqt-qtplugin + lxqt.lxqt-config + ]; + qt5ct = [ + libsForQt5.qt5ct + qt6Packages.qt6ct + ]; }; stylePackages = with pkgs; { @@ -16,22 +36,43 @@ let bb10dark = [ libsForQt5.qtstyleplugins ]; cde = [ libsForQt5.qtstyleplugins ]; cleanlooks = [ libsForQt5.qtstyleplugins ]; - gtk2 = [ libsForQt5.qtstyleplugins qt6Packages.qt6gtk2 ]; + gtk2 = [ + libsForQt5.qtstyleplugins + qt6Packages.qt6gtk2 + ]; motif = [ libsForQt5.qtstyleplugins ]; plastique = [ libsForQt5.qtstyleplugins ]; - adwaita = [ adwaita-qt adwaita-qt6 ]; - adwaita-dark = [ adwaita-qt adwaita-qt6 ]; - adwaita-highcontrast = [ adwaita-qt adwaita-qt6 ]; - adwaita-highcontrastinverse = [ adwaita-qt adwaita-qt6 ]; + adwaita = [ + adwaita-qt + adwaita-qt6 + ]; + adwaita-dark = [ + adwaita-qt + adwaita-qt6 + ]; + adwaita-highcontrast = [ + adwaita-qt + adwaita-qt6 + ]; + adwaita-highcontrastinverse = [ + adwaita-qt + adwaita-qt6 + ]; breeze = [ libsForQt5.breeze-qt5 ]; - kvantum = [ libsForQt5.qtstyleplugin-kvantum qt6Packages.qtstyleplugin-kvantum ]; + kvantum = [ + libsForQt5.qtstyleplugin-kvantum + qt6Packages.qtstyleplugin-kvantum + ]; }; in { - meta.maintainers = with lib.maintainers; [ romildo thiagokokada ]; + meta.maintainers = with lib.maintainers; [ + romildo + thiagokokada + ]; imports = [ (lib.mkRenamedOptionModule [ "qt5" "enable" ] [ "qt" "enable" ]) @@ -57,14 +98,38 @@ in relatedPackages = [ "qgnomeplatform" "qgnomeplatform-qt6" - [ "libsForQt5" "plasma-integration" ] - [ "libsForQt5" "qt5ct" ] - [ "libsForQt5" "qtstyleplugins" ] - [ "libsForQt5" "systemsettings" ] - [ "lxqt" "lxqt-config" ] - [ "lxqt" "lxqt-qtplugin" ] - [ "qt6Packages" "qt6ct" ] - [ "qt6Packages" "qt6gtk2" ] + [ + "libsForQt5" + "plasma-integration" + ] + [ + "libsForQt5" + "qt5ct" + ] + [ + "libsForQt5" + "qtstyleplugins" + ] + [ + "libsForQt5" + "systemsettings" + ] + [ + "lxqt" + "lxqt-config" + ] + [ + "lxqt" + "lxqt-qtplugin" + ] + [ + "qt6Packages" + "qt6ct" + ] + [ + "qt6Packages" + "qt6gtk2" + ] ]; description = '' Selects the platform theme to use for Qt applications. @@ -87,11 +152,26 @@ in relatedPackages = [ "adwaita-qt" "adwaita-qt6" - [ "libsForQt5" "breeze-qt5" ] - [ "libsForQt5" "qtstyleplugin-kvantum" ] - [ "libsForQt5" "qtstyleplugins" ] - [ "qt6Packages" "qt6gtk2" ] - [ "qt6Packages" "qtstyleplugin-kvantum" ] + [ + "libsForQt5" + "breeze-qt5" + ] + [ + "libsForQt5" + "qtstyleplugin-kvantum" + ] + [ + "libsForQt5" + "qtstyleplugins" + ] + [ + "qt6Packages" + "qt6gtk2" + ] + [ + "qt6Packages" + "qtstyleplugin-kvantum" + ] ]; description = '' Selects the style to use for Qt applications. @@ -140,7 +220,10 @@ in environment.profileRelativeSessionVariables = let - qtVersions = with pkgs; [ qt5 qt6 ]; + qtVersions = with pkgs; [ + qt5 + qt6 + ]; in { QT_PLUGIN_PATH = map (qt: "/${qt.qtbase.qtPluginPrefix}") qtVersions; diff --git a/nixos/modules/config/resolvconf.nix b/nixos/modules/config/resolvconf.nix index 70ee02421cc344..f9c9d04b3fbea0 100644 --- a/nixos/modules/config/resolvconf.nix +++ b/nixos/modules/config/resolvconf.nix @@ -1,10 +1,16 @@ # /etc files related to networking, such as /etc/services. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.networking.resolvconf; - resolvconfOptions = cfg.extraOptions + resolvconfOptions = + cfg.extraOptions ++ lib.optional cfg.dnsSingleRequest "single-request" ++ lib.optional cfg.dnsExtensionMechanism "edns0" ++ lib.optional cfg.useLocalResolver "trust-ad"; @@ -15,27 +21,47 @@ let # a collision with an apparently unrelated environment # variable with the same name exported by dhcpcd. interface_order='lo lo[0-9]*' - '' + lib.optionalString config.services.nscd.enable '' + '' + + lib.optionalString config.services.nscd.enable '' # Invalidate the nscd cache whenever resolv.conf is # regenerated. libc_restart='/run/current-system/systemd/bin/systemctl try-restart --no-block nscd.service 2> /dev/null' - '' + lib.optionalString (lib.length resolvconfOptions > 0) '' + '' + + lib.optionalString (lib.length resolvconfOptions > 0) '' # Options as described in resolv.conf(5) resolv_conf_options='${lib.concatStringsSep " " resolvconfOptions}' - '' + lib.optionalString cfg.useLocalResolver '' + '' + + lib.optionalString cfg.useLocalResolver '' # This hosts runs a full-blown DNS resolver. name_servers='127.0.0.1${lib.optionalString config.networking.enableIPv6 " ::1"}' - '' + cfg.extraConfig; + '' + + cfg.extraConfig; in { imports = [ - (lib.mkRenamedOptionModule [ "networking" "dnsSingleRequest" ] [ "networking" "resolvconf" "dnsSingleRequest" ]) - (lib.mkRenamedOptionModule [ "networking" "dnsExtensionMechanism" ] [ "networking" "resolvconf" "dnsExtensionMechanism" ]) - (lib.mkRenamedOptionModule [ "networking" "extraResolvconfConf" ] [ "networking" "resolvconf" "extraConfig" ]) - (lib.mkRenamedOptionModule [ "networking" "resolvconfOptions" ] [ "networking" "resolvconf" "extraOptions" ]) - (lib.mkRemovedOptionModule [ "networking" "resolvconf" "useHostResolvConf" ] "This option was never used for anything anyways") + (lib.mkRenamedOptionModule + [ "networking" "dnsSingleRequest" ] + [ "networking" "resolvconf" "dnsSingleRequest" ] + ) + (lib.mkRenamedOptionModule + [ "networking" "dnsExtensionMechanism" ] + [ "networking" "resolvconf" "dnsExtensionMechanism" ] + ) + (lib.mkRenamedOptionModule + [ "networking" "extraResolvconfConf" ] + [ "networking" "resolvconf" "extraConfig" ] + ) + (lib.mkRenamedOptionModule + [ "networking" "resolvconfOptions" ] + [ "networking" "resolvconf" "extraOptions" ] + ) + (lib.mkRemovedOptionModule [ + "networking" + "resolvconf" + "useHostResolvConf" + ] "This option was never used for anything anyways") ]; options = { @@ -99,8 +125,11 @@ in extraOptions = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; - example = [ "ndots:1" "rotate" ]; + default = [ ]; + example = [ + "ndots:1" + "rotate" + ]; description = '' Set the options in {file}`/etc/resolv.conf`. ''; @@ -116,7 +145,7 @@ in subscriberFiles = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; description = '' Files written by resolvconf updates ''; @@ -137,11 +166,12 @@ in echo "$0 $*" >&2 exit 1 '' - else configText; + else + configText; } (lib.mkIf cfg.enable { - users.groups.resolvconf = {}; + users.groups.resolvconf = { }; networking.resolvconf.subscriberFiles = [ "/etc/resolv.conf" ]; diff --git a/nixos/modules/config/stub-ld.nix b/nixos/modules/config/stub-ld.nix index 05945852ee45c5..836cd129e22f5b 100644 --- a/nixos/modules/config/stub-ld.nix +++ b/nixos/modules/config/stub-ld.nix @@ -1,7 +1,18 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) optionalString mkOption types mkIf mkDefault; + inherit (lib) + optionalString + mkOption + types + mkIf + mkDefault + ; cfg = config.environment.stub-ld; @@ -11,27 +22,32 @@ let https://nix.dev/permalink/stub-ld ''; - stub-ld-for = pkgsArg: messageArg: pkgsArg.pkgsStatic.runCommandCC "stub-ld" { - nativeBuildInputs = [ pkgsArg.unixtools.xxd ]; - inherit messageArg; - } '' - printf "%s" "$messageArg" | xxd -i -n message >main.c - cat <>main.c - #include - int main(int argc, char * argv[]) { - fprintf(stderr, "Could not start dynamically linked executable: %s\n", argv[0]); - fwrite(message, sizeof(unsigned char), message_len, stderr); - return 127; // matches behavior of bash and zsh without a loader. fish uses 139 - } - EOF - $CC -Os main.c -o $out - ''; + stub-ld-for = + pkgsArg: messageArg: + pkgsArg.pkgsStatic.runCommandCC "stub-ld" + { + nativeBuildInputs = [ pkgsArg.unixtools.xxd ]; + inherit messageArg; + } + '' + printf "%s" "$messageArg" | xxd -i -n message >main.c + cat <>main.c + #include + int main(int argc, char * argv[]) { + fprintf(stderr, "Could not start dynamically linked executable: %s\n", argv[0]); + fwrite(message, sizeof(unsigned char), message_len, stderr); + return 127; // matches behavior of bash and zsh without a loader. fish uses 139 + } + EOF + $CC -Os main.c -o $out + ''; pkgs32 = pkgs.pkgsi686Linux; stub-ld = stub-ld-for pkgs message; stub-ld32 = stub-ld-for pkgs32 message; -in { +in +{ options = { environment.stub-ld = { enable = mkOption { diff --git a/nixos/modules/config/sysctl.nix b/nixos/modules/config/sysctl.nix index 1495215db9029f..45f25180e07bde 100644 --- a/nixos/modules/config/sysctl.nix +++ b/nixos/modules/config/sysctl.nix @@ -3,11 +3,12 @@ let sysctlOption = lib.mkOptionType { name = "sysctl option value"; - check = val: + check = + val: let checkType = x: lib.isBool x || lib.isString x || lib.isInt x || x == null; in - checkType val || (val._type or "" == "override" && checkType val.content); + checkType val || (val._type or "" == "override" && checkType val.content); merge = loc: defs: lib.mergeOneOption loc (lib.filterOverrides defs); }; @@ -18,31 +19,31 @@ in options = { boot.kernel.sysctl = lib.mkOption { - type = let - highestValueType = lib.types.ints.unsigned // { - merge = loc: defs: - lib.foldl - (a: b: if b.value == null then null else lib.max a b.value) - 0 - (lib.filterOverrides defs); - }; - in lib.types.submodule { - freeformType = lib.types.attrsOf sysctlOption; - options = { - "net.core.rmem_max" = lib.mkOption { - type = lib.types.nullOr highestValueType; - default = null; - description = "The maximum receive socket buffer size in bytes. In case of conflicting values, the highest will be used."; + type = + let + highestValueType = lib.types.ints.unsigned // { + merge = + loc: defs: + lib.foldl (a: b: if b.value == null then null else lib.max a b.value) 0 (lib.filterOverrides defs); }; + in + lib.types.submodule { + freeformType = lib.types.attrsOf sysctlOption; + options = { + "net.core.rmem_max" = lib.mkOption { + type = lib.types.nullOr highestValueType; + default = null; + description = "The maximum receive socket buffer size in bytes. In case of conflicting values, the highest will be used."; + }; - "net.core.wmem_max" = lib.mkOption { - type = lib.types.nullOr highestValueType; - default = null; - description = "The maximum send socket buffer size in bytes. In case of conflicting values, the highest will be used."; + "net.core.wmem_max" = lib.mkOption { + type = lib.types.nullOr highestValueType; + default = null; + description = "The maximum send socket buffer size in bytes. In case of conflicting values, the highest will be used."; + }; }; }; - }; - default = {}; + default = { }; example = lib.literalExpression '' { "net.ipv4.tcp_syncookies" = false; "vm.swappiness" = 60; } ''; @@ -62,15 +63,16 @@ in config = { - environment.etc."sysctl.d/60-nixos.conf".text = - lib.concatStrings (lib.mapAttrsToList (n: v: - lib.optionalString (v != null) "${n}=${if v == false then "0" else toString v}\n" - ) config.boot.kernel.sysctl); + environment.etc."sysctl.d/60-nixos.conf".text = lib.concatStrings ( + lib.mapAttrsToList ( + n: v: lib.optionalString (v != null) "${n}=${if v == false then "0" else toString v}\n" + ) config.boot.kernel.sysctl + ); - systemd.services.systemd-sysctl = - { wantedBy = [ "multi-user.target" ]; - restartTriggers = [ config.environment.etc."sysctl.d/60-nixos.conf".source ]; - }; + systemd.services.systemd-sysctl = { + wantedBy = [ "multi-user.target" ]; + restartTriggers = [ config.environment.etc."sysctl.d/60-nixos.conf".source ]; + }; # Hide kernel pointers (e.g. in /proc/modules) for unprivileged # users as these make it easier to exploit kernel vulnerabilities. diff --git a/nixos/modules/config/system-path.nix b/nixos/modules/config/system-path.nix index 6757078dbd9fca..42e40e2af5e442 100644 --- a/nixos/modules/config/system-path.nix +++ b/nixos/modules/config/system-path.nix @@ -1,52 +1,62 @@ # This module defines the packages that appear in # /run/current-system/sw. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - requiredPackages = map (pkg: lib.setPrio ((pkg.meta.priority or lib.meta.defaultPriority) + 3) pkg) - [ pkgs.acl - pkgs.attr - pkgs.bashInteractive # bash with ncurses support - pkgs.bzip2 - pkgs.coreutils-full - pkgs.cpio - pkgs.curl - pkgs.diffutils - pkgs.findutils - pkgs.gawk - pkgs.stdenv.cc.libc - pkgs.getent - pkgs.getconf - pkgs.gnugrep - pkgs.gnupatch - pkgs.gnused - pkgs.gnutar - pkgs.gzip - pkgs.xz - pkgs.less - pkgs.libcap - pkgs.ncurses - pkgs.netcat - config.programs.ssh.package - pkgs.mkpasswd - pkgs.procps - pkgs.su - pkgs.time - pkgs.util-linux - pkgs.which - pkgs.zstd - ]; + requiredPackages = + map (pkg: lib.setPrio ((pkg.meta.priority or lib.meta.defaultPriority) + 3) pkg) + [ + pkgs.acl + pkgs.attr + pkgs.bashInteractive # bash with ncurses support + pkgs.bzip2 + pkgs.coreutils-full + pkgs.cpio + pkgs.curl + pkgs.diffutils + pkgs.findutils + pkgs.gawk + pkgs.stdenv.cc.libc + pkgs.getent + pkgs.getconf + pkgs.gnugrep + pkgs.gnupatch + pkgs.gnused + pkgs.gnutar + pkgs.gzip + pkgs.xz + pkgs.less + pkgs.libcap + pkgs.ncurses + pkgs.netcat + config.programs.ssh.package + pkgs.mkpasswd + pkgs.procps + pkgs.su + pkgs.time + pkgs.util-linux + pkgs.which + pkgs.zstd + ]; - defaultPackageNames = - [ "perl" - "rsync" - "strace" - ]; - defaultPackages = - map - (n: let pkg = pkgs.${n};in lib.setPrio ((pkg.meta.priority or lib.meta.defaultPriority) + 3) pkg) - defaultPackageNames; - defaultPackagesText = "[ ${lib.concatMapStringsSep " " (n: "pkgs.${n}") defaultPackageNames } ]"; + defaultPackageNames = [ + "perl" + "rsync" + "strace" + ]; + defaultPackages = map ( + n: + let + pkg = pkgs.${n}; + in + lib.setPrio ((pkg.meta.priority or lib.meta.defaultPriority) + 3) pkg + ) defaultPackageNames; + defaultPackagesText = "[ ${lib.concatMapStringsSep " " (n: "pkgs.${n}") defaultPackageNames} ]"; in @@ -57,7 +67,7 @@ in systemPackages = lib.mkOption { type = lib.types.listOf lib.types.package; - default = []; + default = [ ]; example = lib.literalExpression "[ pkgs.firefox pkgs.thunderbird ]"; description = '' The set of packages that appear in @@ -79,7 +89,7 @@ in ${defaultPackagesText} ''; - example = []; + example = [ ]; description = '' Set of default packages that aren't strictly necessary for a running system, entries can be removed for a more @@ -97,15 +107,18 @@ in type = lib.types.listOf lib.types.str; # Note: We need `/lib' to be among `pathsToLink' for NSS modules # to work. - default = []; - example = ["/"]; + default = [ ]; + example = [ "/" ]; description = "List of directories to be symlinked in {file}`/run/current-system/sw`."; }; extraOutputsToInstall = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "dev" "info" ]; + example = [ + "dev" + "info" + ]; description = '' Entries listed here will be appended to the `meta.outputsToInstall` attribute for each package in `environment.systemPackages`, and the files from the corresponding derivation outputs symlinked into {file}`/run/current-system/sw`. @@ -140,24 +153,24 @@ in environment.systemPackages = requiredPackages ++ config.environment.defaultPackages; - environment.pathsToLink = - [ "/bin" - "/etc/xdg" - "/etc/gtk-2.0" - "/etc/gtk-3.0" - "/lib" # FIXME: remove and update debug-info.nix - "/sbin" - "/share/emacs" - "/share/hunspell" - "/share/org" - "/share/themes" - "/share/vulkan" - "/share/kservices5" - "/share/kservicetypes5" - "/share/kxmlgui5" - "/share/systemd" - "/share/thumbnailers" - ]; + environment.pathsToLink = [ + "/bin" + "/etc/xdg" + "/etc/gtk-2.0" + "/etc/gtk-3.0" + "/lib" # FIXME: remove and update debug-info.nix + "/sbin" + "/share/emacs" + "/share/hunspell" + "/share/org" + "/share/themes" + "/share/vulkan" + "/share/kservices5" + "/share/kservicetypes5" + "/share/kxmlgui5" + "/share/systemd" + "/share/thumbnailers" + ]; system.path = pkgs.buildEnv { name = "system-path"; @@ -166,17 +179,16 @@ in ignoreCollisions = true; # !!! Hacky, should modularise. # outputs TODO: note that the tools will often not be linked by default - postBuild = - '' - # Remove wrapped binaries, they shouldn't be accessible via PATH. - find $out/bin -maxdepth 1 -name ".*-wrapped" -type l -delete + postBuild = '' + # Remove wrapped binaries, they shouldn't be accessible via PATH. + find $out/bin -maxdepth 1 -name ".*-wrapped" -type l -delete - if [ -x $out/bin/glib-compile-schemas -a -w $out/share/glib-2.0/schemas ]; then - $out/bin/glib-compile-schemas $out/share/glib-2.0/schemas - fi + if [ -x $out/bin/glib-compile-schemas -a -w $out/share/glib-2.0/schemas ]; then + $out/bin/glib-compile-schemas $out/share/glib-2.0/schemas + fi - ${config.environment.extraSetup} - ''; + ${config.environment.extraSetup} + ''; }; }; diff --git a/nixos/modules/config/terminfo.nix b/nixos/modules/config/terminfo.nix index 53ae04f236ab2d..e61f10d4ec215f 100644 --- a/nixos/modules/config/terminfo.nix +++ b/nixos/modules/config/terminfo.nix @@ -1,6 +1,11 @@ # This module manages the terminfo database # and its integration in the system. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { options = with lib; { diff --git a/nixos/modules/config/unix-odbc-drivers.nix b/nixos/modules/config/unix-odbc-drivers.nix index 8bf7f3b28af6d0..ea0ab2785e8eb6 100644 --- a/nixos/modules/config/unix-odbc-drivers.nix +++ b/nixos/modules/config/unix-odbc-drivers.nix @@ -9,13 +9,14 @@ let Driver = ${pkg}/${pkg.driver} ''; -in { +in +{ ###### interface options = { environment.unixODBCDrivers = lib.mkOption { type = lib.types.listOf lib.types.package; - default = []; + default = [ ]; example = lib.literalExpression "with pkgs.unixODBCDrivers; [ sqlite psql ]"; description = '' Specifies Unix ODBC drivers to be registered in @@ -28,8 +29,10 @@ in { ###### implementation - config = lib.mkIf (config.environment.unixODBCDrivers != []) { - environment.etc."odbcinst.ini".text = lib.concatMapStringsSep "\n" iniDescription config.environment.unixODBCDrivers; + config = lib.mkIf (config.environment.unixODBCDrivers != [ ]) { + environment.etc."odbcinst.ini".text = + lib.concatMapStringsSep "\n" iniDescription + config.environment.unixODBCDrivers; }; } diff --git a/nixos/modules/config/vte.nix b/nixos/modules/config/vte.nix index a86a148b54f982..f7c639b627a02d 100644 --- a/nixos/modules/config/vte.nix +++ b/nixos/modules/config/vte.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let vteInitSnippet = '' diff --git a/nixos/modules/config/xdg/icons.nix b/nixos/modules/config/xdg/icons.nix index 5fc7b3506a1d09..0deb5fbb80aaf4 100644 --- a/nixos/modules/config/xdg/icons.nix +++ b/nixos/modules/config/xdg/icons.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { meta = { maintainers = lib.teams.freedesktop.members; @@ -15,7 +20,7 @@ }; xdg.icons.fallbackCursorThemes = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Names of the fallback cursor themes, in order of preference, to be used when no other icon source can be found. Set to `[]` to disable the fallback entirely. @@ -29,20 +34,22 @@ "/share/pixmaps" ]; - environment.systemPackages = [ - # Empty icon theme that contains index.theme file describing directories - # where toolkits should look for icons installed by apps. - pkgs.hicolor-icon-theme - ] ++ lib.optionals (config.xdg.icons.fallbackCursorThemes != []) [ - (pkgs.writeTextFile { - name = "fallback-cursor-theme"; - text = '' - [Icon Theme] - Inherits=${lib.concatStringsSep "," config.xdg.icons.fallbackCursorThemes} - ''; - destination = "/share/icons/default/index.theme"; - }) - ]; + environment.systemPackages = + [ + # Empty icon theme that contains index.theme file describing directories + # where toolkits should look for icons installed by apps. + pkgs.hicolor-icon-theme + ] + ++ lib.optionals (config.xdg.icons.fallbackCursorThemes != [ ]) [ + (pkgs.writeTextFile { + name = "fallback-cursor-theme"; + text = '' + [Icon Theme] + Inherits=${lib.concatStringsSep "," config.xdg.icons.fallbackCursorThemes} + ''; + destination = "/share/icons/default/index.theme"; + }) + ]; # libXcursor looks for cursors in XCURSOR_PATH # it mostly follows the spec for icons diff --git a/nixos/modules/config/xdg/portal.nix b/nixos/modules/config/xdg/portal.nix index 7e66a32c7db20d..617a342c1a70eb 100644 --- a/nixos/modules/config/xdg/portal.nix +++ b/nixos/modules/config/xdg/portal.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let inherit (lib) @@ -8,17 +13,22 @@ let mkRenamedOptionModule mkRemovedOptionModule teams - types; + types + ; - associationOptions = with types; attrsOf ( - coercedTo (either (listOf str) str) (x: lib.concatStringsSep ";" (lib.toList x)) str - ); + associationOptions = + with types; + attrsOf (coercedTo (either (listOf str) str) (x: lib.concatStringsSep ";" (lib.toList x)) str); in { imports = [ (mkRenamedOptionModule [ "services" "flatpak" "extraPortals" ] [ "xdg" "portal" "extraPortals" ]) - (mkRemovedOptionModule [ "xdg" "portal" "gtkUsePortal" ] "This option has been removed due to being unsupported and discouraged by the GTK developers.") + (mkRemovedOptionModule [ + "xdg" + "portal" + "gtkUsePortal" + ] "This option has been removed due to being unsupported and discouraged by the GTK developers.") ]; meta = { @@ -27,7 +37,8 @@ in options.xdg.portal = { enable = - mkEnableOption ''[xdg desktop integration](https://github.com/flatpak/xdg-desktop-portal)'' // { + mkEnableOption ''[xdg desktop integration](https://github.com/flatpak/xdg-desktop-portal)'' + // { default = false; }; @@ -60,10 +71,16 @@ in default = { }; example = { x-cinnamon = { - default = [ "xapp" "gtk" ]; + default = [ + "xapp" + "gtk" + ]; }; pantheon = { - default = [ "pantheon" "gtk" ]; + default = [ + "pantheon" + "gtk" + ]; "org.freedesktop.impl.portal.Secret" = [ "gnome-keyring" ]; }; common = { @@ -136,11 +153,15 @@ in NIX_XDG_DESKTOP_PORTAL_DIR = "/run/current-system/sw/share/xdg-desktop-portal/portals"; }; - etc = lib.concatMapAttrs - (desktop: conf: lib.optionalAttrs (conf != { }) { - "xdg/xdg-desktop-portal/${lib.optionalString (desktop != "common") "${desktop}-"}portals.conf".text = + etc = lib.concatMapAttrs ( + desktop: conf: + lib.optionalAttrs (conf != { }) { + "xdg/xdg-desktop-portal/${ + lib.optionalString (desktop != "common") "${desktop}-" + }portals.conf".text = lib.generators.toINI { } { preferred = conf; }; - }) cfg.config; + } + ) cfg.config; }; }; } diff --git a/nixos/modules/config/xdg/portals/lxqt.nix b/nixos/modules/config/xdg/portals/lxqt.nix index 846c9b1994371a..7549666cb733e6 100644 --- a/nixos/modules/config/xdg/portals/lxqt.nix +++ b/nixos/modules/config/xdg/portals/lxqt.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.xdg.portal.lxqt; @@ -19,12 +24,13 @@ in styles = lib.mkOption { type = lib.types.listOf lib.types.package; - default = []; - example = lib.literalExpression ''[ - pkgs.libsForQt5.qtstyleplugin-kvantum - pkgs.breeze-qt5 - pkgs.qtcurve - ]; + default = [ ]; + example = lib.literalExpression '' + [ + pkgs.libsForQt5.qtstyleplugin-kvantum + pkgs.breeze-qt5 + pkgs.qtcurve + ]; ''; description = '' Extra Qt styles that will be available to the diff --git a/nixos/modules/config/xdg/portals/wlr.nix b/nixos/modules/config/xdg/portals/wlr.nix index ed09a31a86d76e..1dd1cf6c76886b 100644 --- a/nixos/modules/config/xdg/portals/wlr.nix +++ b/nixos/modules/config/xdg/portals/wlr.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.xdg.portal.wlr; package = pkgs.xdg-desktop-portal-wlr; diff --git a/nixos/modules/config/xdg/sounds.nix b/nixos/modules/config/xdg/sounds.nix index e19e23d72a476e..8b5bb67e4109f9 100644 --- a/nixos/modules/config/xdg/sounds.nix +++ b/nixos/modules/config/xdg/sounds.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { meta = { maintainers = lib.teams.freedesktop.members; diff --git a/nixos/modules/config/xdg/terminal-exec.nix b/nixos/modules/config/xdg/terminal-exec.nix index daf2055d2e9066..0c8381bc2cde99 100644 --- a/nixos/modules/config/xdg/terminal-exec.nix +++ b/nixos/modules/config/xdg/terminal-exec.nix @@ -7,7 +7,13 @@ let cfg = config.xdg.terminal-exec; - inherit (lib) mkIf mkEnableOption mkOption mkPackageOption types; + inherit (lib) + mkIf + mkEnableOption + mkOption + mkPackageOption + types + ; in { meta.maintainers = with lib.maintainers; [ Cryolitia ]; @@ -30,7 +36,10 @@ in ''; example = { default = [ "kitty.desktop" ]; - GNOME = [ "com.raggesilver.BlackBox.desktop" "org.gnome.Terminal.desktop" ]; + GNOME = [ + "com.raggesilver.BlackBox.desktop" + "org.gnome.Terminal.desktop" + ]; }; }; }; diff --git a/nixos/modules/hardware/acpilight.nix b/nixos/modules/hardware/acpilight.nix index 211d18ceb11a8b..1b0f73d33a5a54 100644 --- a/nixos/modules/hardware/acpilight.nix +++ b/nixos/modules/hardware/acpilight.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.acpilight; in diff --git a/nixos/modules/hardware/all-firmware.nix b/nixos/modules/hardware/all-firmware.nix index 6475cfc843d2a7..0b946052b9d3f4 100644 --- a/nixos/modules/hardware/all-firmware.nix +++ b/nixos/modules/hardware/all-firmware.nix @@ -1,14 +1,35 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware; -in { +in +{ imports = [ - (lib.mkRenamedOptionModule [ "networking" "enableRT73Firmware" ] [ "hardware" "enableRedistributableFirmware" ]) - (lib.mkRenamedOptionModule [ "networking" "enableIntel3945ABGFirmware" ] [ "hardware" "enableRedistributableFirmware" ]) - (lib.mkRenamedOptionModule [ "networking" "enableIntel2100BGFirmware" ] [ "hardware" "enableRedistributableFirmware" ]) - (lib.mkRenamedOptionModule [ "networking" "enableRalinkFirmware" ] [ "hardware" "enableRedistributableFirmware" ]) - (lib.mkRenamedOptionModule [ "networking" "enableRTL8192cFirmware" ] [ "hardware" "enableRedistributableFirmware" ]) + (lib.mkRenamedOptionModule + [ "networking" "enableRT73Firmware" ] + [ "hardware" "enableRedistributableFirmware" ] + ) + (lib.mkRenamedOptionModule + [ "networking" "enableIntel3945ABGFirmware" ] + [ "hardware" "enableRedistributableFirmware" ] + ) + (lib.mkRenamedOptionModule + [ "networking" "enableIntel2100BGFirmware" ] + [ "hardware" "enableRedistributableFirmware" ] + ) + (lib.mkRenamedOptionModule + [ "networking" "enableRalinkFirmware" ] + [ "hardware" "enableRedistributableFirmware" ] + ) + (lib.mkRenamedOptionModule + [ "networking" "enableRTL8192cFirmware" ] + [ "hardware" "enableRedistributableFirmware" ] + ) ]; ###### interface @@ -17,53 +38,64 @@ in { hardware.enableAllFirmware = lib.mkEnableOption "all firmware regardless of license"; - hardware.enableRedistributableFirmware = lib.mkEnableOption "firmware with a license allowing redistribution" // { - default = config.hardware.enableAllFirmware; - defaultText = lib.literalExpression "config.hardware.enableAllFirmware"; - }; + hardware.enableRedistributableFirmware = + lib.mkEnableOption "firmware with a license allowing redistribution" + // { + default = config.hardware.enableAllFirmware; + defaultText = lib.literalExpression "config.hardware.enableAllFirmware"; + }; - hardware.wirelessRegulatoryDatabase = lib.mkEnableOption "loading the wireless regulatory database at boot" // { - default = cfg.enableRedistributableFirmware || cfg.enableAllFirmware; - defaultText = lib.literalMD "Enabled if proprietary firmware is allowed via {option}`enableRedistributableFirmware` or {option}`enableAllFirmware`."; - }; + hardware.wirelessRegulatoryDatabase = + lib.mkEnableOption "loading the wireless regulatory database at boot" + // { + default = cfg.enableRedistributableFirmware || cfg.enableAllFirmware; + defaultText = lib.literalMD "Enabled if proprietary firmware is allowed via {option}`enableRedistributableFirmware` or {option}`enableAllFirmware`."; + }; }; - ###### implementation config = lib.mkMerge [ (lib.mkIf (cfg.enableAllFirmware || cfg.enableRedistributableFirmware) { - hardware.firmware = with pkgs; [ - linux-firmware - intel2200BGFirmware - rtl8192su-firmware - rt5677-firmware - rtl8761b-firmware - zd1211fw - alsa-firmware - sof-firmware - libreelec-dvb-firmware - ] ++ lib.optional pkgs.stdenv.hostPlatform.isAarch raspberrypiWirelessFirmware; + hardware.firmware = + with pkgs; + [ + linux-firmware + intel2200BGFirmware + rtl8192su-firmware + rt5677-firmware + rtl8761b-firmware + zd1211fw + alsa-firmware + sof-firmware + libreelec-dvb-firmware + ] + ++ lib.optional pkgs.stdenv.hostPlatform.isAarch raspberrypiWirelessFirmware; }) (lib.mkIf cfg.enableAllFirmware { - assertions = [{ - assertion = !cfg.enableAllFirmware || pkgs.config.allowUnfree; - message = '' - the list of hardware.enableAllFirmware contains non-redistributable licensed firmware files. - This requires nixpkgs.config.allowUnfree to be true. - An alternative is to use the hardware.enableRedistributableFirmware option. - ''; - }]; - hardware.firmware = with pkgs; [ - broadcom-bt-firmware - b43Firmware_5_1_138 - b43Firmware_6_30_163_46 - xow_dongle-firmware - ] ++ lib.optionals pkgs.stdenv.hostPlatform.isx86 [ - facetimehd-calibration - facetimehd-firmware + assertions = [ + { + assertion = !cfg.enableAllFirmware || pkgs.config.allowUnfree; + message = '' + the list of hardware.enableAllFirmware contains non-redistributable licensed firmware files. + This requires nixpkgs.config.allowUnfree to be true. + An alternative is to use the hardware.enableRedistributableFirmware option. + ''; + } ]; + hardware.firmware = + with pkgs; + [ + broadcom-bt-firmware + b43Firmware_5_1_138 + b43Firmware_6_30_163_46 + xow_dongle-firmware + ] + ++ lib.optionals pkgs.stdenv.hostPlatform.isx86 [ + facetimehd-calibration + facetimehd-firmware + ]; }) (lib.mkIf cfg.wirelessRegulatoryDatabase { hardware.firmware = [ pkgs.wireless-regdb ]; diff --git a/nixos/modules/hardware/bladeRF.nix b/nixos/modules/hardware/bladeRF.nix index 877acbbf598c13..15bd99bc0cdbb2 100644 --- a/nixos/modules/hardware/bladeRF.nix +++ b/nixos/modules/hardware/bladeRF.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.bladeRF; @@ -20,6 +25,6 @@ in config = lib.mkIf cfg.enable { services.udev.packages = [ pkgs.libbladeRF ]; - users.groups.bladerf = {}; + users.groups.bladerf = { }; }; } diff --git a/nixos/modules/hardware/brillo.nix b/nixos/modules/hardware/brillo.nix index 915801c137be99..afc31981a36482 100644 --- a/nixos/modules/hardware/brillo.nix +++ b/nixos/modules/hardware/brillo.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.brillo; in diff --git a/nixos/modules/hardware/ckb-next.nix b/nixos/modules/hardware/ckb-next.nix index 5de5666d20c962..c65055d8369e6a 100644 --- a/nixos/modules/hardware/ckb-next.nix +++ b/nixos/modules/hardware/ckb-next.nix @@ -1,43 +1,50 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.ckb-next; in - { - imports = [ - (lib.mkRenamedOptionModule [ "hardware" "ckb" "enable" ] [ "hardware" "ckb-next" "enable" ]) - (lib.mkRenamedOptionModule [ "hardware" "ckb" "package" ] [ "hardware" "ckb-next" "package" ]) - ]; +{ + imports = [ + (lib.mkRenamedOptionModule [ "hardware" "ckb" "enable" ] [ "hardware" "ckb-next" "enable" ]) + (lib.mkRenamedOptionModule [ "hardware" "ckb" "package" ] [ "hardware" "ckb-next" "package" ]) + ]; - options.hardware.ckb-next = { - enable = lib.mkEnableOption "the Corsair keyboard/mouse driver"; + options.hardware.ckb-next = { + enable = lib.mkEnableOption "the Corsair keyboard/mouse driver"; - gid = lib.mkOption { - type = lib.types.nullOr lib.types.int; - default = null; - example = 100; - description = '' - Limit access to the ckb daemon to a particular group. - ''; - }; - - package = lib.mkPackageOption pkgs "ckb-next" { }; + gid = lib.mkOption { + type = lib.types.nullOr lib.types.int; + default = null; + example = 100; + description = '' + Limit access to the ckb daemon to a particular group. + ''; }; - config = lib.mkIf cfg.enable { - environment.systemPackages = [ cfg.package ]; + package = lib.mkPackageOption pkgs "ckb-next" { }; + }; - systemd.services.ckb-next = { - description = "Corsair Keyboards and Mice Daemon"; - wantedBy = ["multi-user.target"]; - serviceConfig = { - ExecStart = "${cfg.package}/bin/ckb-next-daemon ${lib.optionalString (cfg.gid != null) "--gid=${builtins.toString cfg.gid}"}"; - Restart = "on-failure"; - }; + config = lib.mkIf cfg.enable { + environment.systemPackages = [ cfg.package ]; + + systemd.services.ckb-next = { + description = "Corsair Keyboards and Mice Daemon"; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + ExecStart = "${cfg.package}/bin/ckb-next-daemon ${ + lib.optionalString (cfg.gid != null) "--gid=${builtins.toString cfg.gid}" + }"; + Restart = "on-failure"; }; }; + }; - meta = { - maintainers = [ ]; - }; - } + meta = { + maintainers = [ ]; + }; +} diff --git a/nixos/modules/hardware/cpu/amd-microcode.nix b/nixos/modules/hardware/cpu/amd-microcode.nix index 25ce70a5811dd4..1b95373b0b44bb 100644 --- a/nixos/modules/hardware/cpu/amd-microcode.nix +++ b/nixos/modules/hardware/cpu/amd-microcode.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { ###### interface options = { diff --git a/nixos/modules/hardware/cpu/amd-ryzen-smu.nix b/nixos/modules/hardware/cpu/amd-ryzen-smu.nix index b1a5895aaa24af..c87805b18a7501 100644 --- a/nixos/modules/hardware/cpu/amd-ryzen-smu.nix +++ b/nixos/modules/hardware/cpu/amd-ryzen-smu.nix @@ -1,6 +1,7 @@ -{ config -, lib -, ... +{ + config, + lib, + ... }: let inherit (lib) mkEnableOption mkIf; @@ -10,10 +11,10 @@ in { options.hardware.cpu.amd.ryzen-smu = { enable = mkEnableOption '' - ryzen_smu, a linux kernel driver that exposes access to the SMU (System Management Unit) for certain AMD Ryzen Processors. + ryzen_smu, a linux kernel driver that exposes access to the SMU (System Management Unit) for certain AMD Ryzen Processors. - WARNING: Damage cause by use of your AMD processor outside of official AMD specifications or outside of factory settings are not covered under any AMD product warranty and may not be covered by your board or system manufacturer's warranty - ''; + WARNING: Damage cause by use of your AMD processor outside of official AMD specifications or outside of factory settings are not covered under any AMD product warranty and may not be covered by your board or system manufacturer's warranty + ''; }; config = mkIf cfg.enable { @@ -22,5 +23,8 @@ in environment.systemPackages = [ ryzen-smu ]; }; - meta.maintainers = with lib.maintainers; [ Cryolitia phdyellow ]; + meta.maintainers = with lib.maintainers; [ + Cryolitia + phdyellow + ]; } diff --git a/nixos/modules/hardware/cpu/amd-sev.nix b/nixos/modules/hardware/cpu/amd-sev.nix index 8dae958bf344ab..4bf43f70c70c17 100644 --- a/nixos/modules/hardware/cpu/amd-sev.nix +++ b/nixos/modules/hardware/cpu/amd-sev.nix @@ -1,4 +1,9 @@ -{ config, options, lib, ... }: +{ + config, + options, + lib, + ... +}: let cfgSev = config.hardware.cpu.amd.sev; cfgSevGuest = config.hardware.cpu.amd.sevGuest; @@ -22,7 +27,8 @@ let }; }; in -with lib; { +with lib; +{ options.hardware.cpu.amd.sev = optionsFor "SEV" "sev"; options.hardware.cpu.amd.sevGuest = optionsFor "SEV guest" "sev-guest"; @@ -36,7 +42,9 @@ with lib; { message = "Given user does not exist"; } { - assertion = (cfgSev.group == options.hardware.cpu.amd.sev.group.default) || (lib.hasAttr cfgSev.group config.users.groups); + assertion = + (cfgSev.group == options.hardware.cpu.amd.sev.group.default) + || (lib.hasAttr cfgSev.group config.users.groups); message = "Given group does not exist"; } ]; @@ -62,14 +70,18 @@ with lib; { message = "Given user does not exist"; } { - assertion = (cfgSevGuest.group == options.hardware.cpu.amd.sevGuest.group.default) || (lib.hasAttr cfgSevGuest.group config.users.groups); + assertion = + (cfgSevGuest.group == options.hardware.cpu.amd.sevGuest.group.default) + || (lib.hasAttr cfgSevGuest.group config.users.groups); message = "Given group does not exist"; } ]; - users.groups = lib.optionalAttrs (cfgSevGuest.group == options.hardware.cpu.amd.sevGuest.group.default) { - "${cfgSevGuest.group}" = { }; - }; + users.groups = + lib.optionalAttrs (cfgSevGuest.group == options.hardware.cpu.amd.sevGuest.group.default) + { + "${cfgSevGuest.group}" = { }; + }; services.udev.extraRules = with cfgSevGuest; '' KERNEL=="sev-guest", OWNER="${user}", GROUP="${group}", MODE="${mode}" diff --git a/nixos/modules/hardware/cpu/intel-microcode.nix b/nixos/modules/hardware/cpu/intel-microcode.nix index e708d447910e9d..02eeed7695b824 100644 --- a/nixos/modules/hardware/cpu/intel-microcode.nix +++ b/nixos/modules/hardware/cpu/intel-microcode.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { ###### interface options = { diff --git a/nixos/modules/hardware/cpu/intel-sgx.nix b/nixos/modules/hardware/cpu/intel-sgx.nix index 79d0bc1599eeef..60f0bc8d8a569d 100644 --- a/nixos/modules/hardware/cpu/intel-sgx.nix +++ b/nixos/modules/hardware/cpu/intel-sgx.nix @@ -45,7 +45,8 @@ in message = "Given user does not exist"; } { - assertion = (cfg.provision.group == defaultPrvGroup) || (lib.hasAttr cfg.provision.group config.users.groups); + assertion = + (cfg.provision.group == defaultPrvGroup) || (lib.hasAttr cfg.provision.group config.users.groups); message = "Given group does not exist"; } ]; diff --git a/nixos/modules/hardware/cpu/x86-msr.nix b/nixos/modules/hardware/cpu/x86-msr.nix index 95e1be23cd9561..56f6e23812abce 100644 --- a/nixos/modules/hardware/cpu/x86-msr.nix +++ b/nixos/modules/hardware/cpu/x86-msr.nix @@ -1,7 +1,8 @@ -{ lib -, config -, options -, ... +{ + lib, + config, + options, + ... }: let inherit (builtins) hasAttr; @@ -15,51 +16,70 @@ let # Generates `foo=bar` parameters to pass to the kernel. # If `module = baz` is passed, generates `baz.foo=bar`. # Adds double quotes on demand to handle `foo="bar baz"`. - kernelParam = { module ? null }: name: value: - assert lib.asserts.assertMsg (!lib.strings.hasInfix "=" name) "kernel parameter cannot have '=' in name"; + kernelParam = + { + module ? null, + }: + name: value: + assert lib.asserts.assertMsg ( + !lib.strings.hasInfix "=" name + ) "kernel parameter cannot have '=' in name"; let key = (if module == null then "" else module + ".") + name; - valueString = lib.generators.mkValueStringDefault {} value; - quotedValueString = if lib.strings.hasInfix " " valueString - then lib.strings.escape ["\""] valueString - else valueString; - in "${key}=${quotedValueString}"; + valueString = lib.generators.mkValueStringDefault { } value; + quotedValueString = + if lib.strings.hasInfix " " valueString then + lib.strings.escape [ "\"" ] valueString + else + valueString; + in + "${key}=${quotedValueString}"; msrKernelParam = kernelParam { module = "msr"; }; in { - options.hardware.cpu.x86.msr = with lib.options; with lib.types; { - enable = mkEnableOption "the `msr` (Model-Specific Registers) kernel module and configure `udev` rules for its devices (usually `/dev/cpu/*/msr`)"; - owner = mkOption { - type = str; - default = "root"; - example = "nobody"; - description = "Owner ${set}"; - }; - group = mkOption { - type = str; - default = defaultGroup; - example = "nobody"; - description = "Group ${set}"; - }; - mode = mkOption { - type = str; - default = "0640"; - example = "0660"; - description = "Mode ${set}"; - }; - settings = mkOption { - type = submodule { - freeformType = attrsOf (oneOf [ bool int str ]); - options.allow-writes = mkOption { - type = nullOr (enum ["on" "off"]); - default = null; - description = "Whether to allow writes to MSRs (`\"on\"`) or not (`\"off\"`)."; + options.hardware.cpu.x86.msr = + with lib.options; + with lib.types; + { + enable = mkEnableOption "the `msr` (Model-Specific Registers) kernel module and configure `udev` rules for its devices (usually `/dev/cpu/*/msr`)"; + owner = mkOption { + type = str; + default = "root"; + example = "nobody"; + description = "Owner ${set}"; + }; + group = mkOption { + type = str; + default = defaultGroup; + example = "nobody"; + description = "Group ${set}"; + }; + mode = mkOption { + type = str; + default = "0640"; + example = "0660"; + description = "Mode ${set}"; + }; + settings = mkOption { + type = submodule { + freeformType = attrsOf (oneOf [ + bool + int + str + ]); + options.allow-writes = mkOption { + type = nullOr (enum [ + "on" + "off" + ]); + default = null; + description = "Whether to allow writes to MSRs (`\"on\"`) or not (`\"off\"`)."; + }; }; + default = { }; + description = "Parameters for the `msr` kernel module."; }; - default = {}; - description = "Parameters for the `msr` kernel module."; }; - }; config = mkIf cfg.enable { assertions = [ @@ -75,7 +95,9 @@ in boot = { kernelModules = [ "msr" ]; - kernelParams = lib.attrsets.mapAttrsToList msrKernelParam (lib.attrsets.filterAttrs (_: value: value != null) cfg.settings); + kernelParams = lib.attrsets.mapAttrsToList msrKernelParam ( + lib.attrsets.filterAttrs (_: value: value != null) cfg.settings + ); }; users.groups.${cfg.group} = mkIf isDefaultGroup { }; diff --git a/nixos/modules/hardware/decklink.nix b/nixos/modules/hardware/decklink.nix index ca0ed389f8cc4f..a0e05072c64683 100644 --- a/nixos/modules/hardware/decklink.nix +++ b/nixos/modules/hardware/decklink.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.decklink; @@ -10,7 +15,10 @@ in config = lib.mkIf cfg.enable { # snd_blackmagic-io can cause issues with pipewire, # so we do not enable it by default - boot.kernelModules = [ "blackmagic" "blackmagic-io" ]; + boot.kernelModules = [ + "blackmagic" + "blackmagic-io" + ]; boot.extraModulePackages = [ kernelPackages.decklink ]; systemd.packages = [ pkgs.blackmagic-desktop-video ]; systemd.services.DesktopVideoHelper.wantedBy = [ "multi-user.target" ]; diff --git a/nixos/modules/hardware/digitalbitbox.nix b/nixos/modules/hardware/digitalbitbox.nix index c5c8204e321ab6..e34dcbe9fe2dea 100644 --- a/nixos/modules/hardware/digitalbitbox.nix +++ b/nixos/modules/hardware/digitalbitbox.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.digitalbitbox; in diff --git a/nixos/modules/hardware/flipperzero.nix b/nixos/modules/hardware/flipperzero.nix index bda2e2c8e0a565..85cf9e10f0dd3d 100644 --- a/nixos/modules/hardware/flipperzero.nix +++ b/nixos/modules/hardware/flipperzero.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.flipperzero; diff --git a/nixos/modules/hardware/flirc.nix b/nixos/modules/hardware/flirc.nix index 94ec715b9fa51b..a31791743eaa22 100644 --- a/nixos/modules/hardware/flirc.nix +++ b/nixos/modules/hardware/flirc.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.flirc; in diff --git a/nixos/modules/hardware/glasgow.nix b/nixos/modules/hardware/glasgow.nix index e63aa8bdb4bd75..9f67937c5f86a5 100644 --- a/nixos/modules/hardware/glasgow.nix +++ b/nixos/modules/hardware/glasgow.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.glasgow; diff --git a/nixos/modules/hardware/gpgsmartcards.nix b/nixos/modules/hardware/gpgsmartcards.nix index 3940efd09e2217..6b15cc50068e85 100644 --- a/nixos/modules/hardware/gpgsmartcards.nix +++ b/nixos/modules/hardware/gpgsmartcards.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let # gnupg's manual describes how to setup ccid udev rules: # https://www.gnupg.org/howtos/card-howto/en/ch02s03.html @@ -17,14 +22,15 @@ let # per debian's udev deb hook (https://man7.org/linux/man-pages/man1/dh_installudev.1.html) destination = "60-scdaemon.rules"; - scdaemonUdevRulesPkg = pkgs.runCommand "scdaemon-udev-rules" {} '' + scdaemonUdevRulesPkg = pkgs.runCommand "scdaemon-udev-rules" { } '' loc="$out/lib/udev/rules.d/" mkdir -p "''${loc}" cp "${scdaemonRules}" "''${loc}/${destination}" ''; cfg = config.hardware.gpgSmartcards; -in { +in +{ options.hardware.gpgSmartcards = { enable = lib.mkEnableOption "udev rules for gnupg smart cards"; }; diff --git a/nixos/modules/hardware/hackrf.nix b/nixos/modules/hardware/hackrf.nix index 467fd71ff1b068..ceb560ebea23fb 100644 --- a/nixos/modules/hardware/hackrf.nix +++ b/nixos/modules/hardware/hackrf.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.hackrf; diff --git a/nixos/modules/hardware/i2c.nix b/nixos/modules/hardware/i2c.nix index 4dd7a8ccc53102..badb5fbee4b086 100644 --- a/nixos/modules/hardware/i2c.nix +++ b/nixos/modules/hardware/i2c.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.i2c; in @@ -28,14 +33,16 @@ in i2c = { }; }; - services.udev.packages = lib.singleton (pkgs.writeTextFile - { name = "i2c-udev-rules"; + services.udev.packages = lib.singleton ( + pkgs.writeTextFile { + name = "i2c-udev-rules"; text = '' # allow group ${cfg.group} and users with a seat use of i2c devices ACTION=="add", KERNEL=="i2c-[0-9]*", TAG+="uaccess", GROUP="${cfg.group}", MODE="660" ''; destination = "/etc/udev/rules.d/70-i2c.rules"; - }); + } + ); }; diff --git a/nixos/modules/hardware/infiniband.nix b/nixos/modules/hardware/infiniband.nix index b09453116cf970..311b91c5c5b2de 100644 --- a/nixos/modules/hardware/infiniband.nix +++ b/nixos/modules/hardware/infiniband.nix @@ -1,28 +1,37 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.infiniband; - opensm-services = { - "opensm@" = { - enable = true; - description = "Starts OpenSM Infiniband fabric Subnet Managers"; - before = [ "network.target"]; - unitConfig = { - ConditionPathExists = "/sys/class/infiniband_mad/abi_version"; - }; - serviceConfig = { - Type = "simple"; - ExecStart = "${pkgs.opensm}/bin/opensm --guid %I --log_file /var/log/opensm.%I.log"; + opensm-services = + { + "opensm@" = { + enable = true; + description = "Starts OpenSM Infiniband fabric Subnet Managers"; + before = [ "network.target" ]; + unitConfig = { + ConditionPathExists = "/sys/class/infiniband_mad/abi_version"; + }; + serviceConfig = { + Type = "simple"; + ExecStart = "${pkgs.opensm}/bin/opensm --guid %I --log_file /var/log/opensm.%I.log"; + }; }; - }; - } // (builtins.listToAttrs (map (guid: { - name = "opensm@${guid}"; - value = { - enable = true; - wantedBy = [ "machines.target" ]; - overrideStrategy = "asDropin"; - }; - } ) cfg.guids)); + } + // (builtins.listToAttrs ( + map (guid: { + name = "opensm@${guid}"; + value = { + enable = true; + wantedBy = [ "machines.target" ]; + overrideStrategy = "asDropin"; + }; + }) cfg.guids + )); in @@ -31,7 +40,7 @@ in enable = lib.mkEnableOption "Infiniband support"; guids = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; example = [ "0xe8ebd30000eee2e1" ]; description = '' A list of infiniband port guids on the system. This is discoverable using `ibstat -p` @@ -41,14 +50,23 @@ in config = lib.mkIf cfg.enable { boot.initrd.kernelModules = [ - "mlx5_core" "mlx5_ib" "ib_cm" - "rdma_cm" "rdma_ucm" "rpcrdma" - "ib_ipoib" "ib_isert" "ib_umad" "ib_uverbs" + "mlx5_core" + "mlx5_ib" + "ib_cm" + "rdma_cm" + "rdma_ucm" + "rpcrdma" + "ib_ipoib" + "ib_isert" + "ib_umad" + "ib_uverbs" ]; # rdma-core exposes ibstat, mstflint exposes mstconfig (which can be needed for # setting link configurations), qperf needed to affirm link speeds environment.systemPackages = with pkgs; [ - rdma-core mstflint qperf + rdma-core + mstflint + qperf ]; systemd.services = opensm-services; }; diff --git a/nixos/modules/hardware/keyboard/qmk.nix b/nixos/modules/hardware/keyboard/qmk.nix index b3e752ad66c5da..6690deca35062b 100644 --- a/nixos/modules/hardware/keyboard/qmk.nix +++ b/nixos/modules/hardware/keyboard/qmk.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.keyboard.qmk; @@ -12,6 +17,6 @@ in config = mkIf cfg.enable { services.udev.packages = [ pkgs.qmk-udev-rules ]; - users.groups.plugdev = {}; + users.groups.plugdev = { }; }; } diff --git a/nixos/modules/hardware/keyboard/teck.nix b/nixos/modules/hardware/keyboard/teck.nix index 8cb736dedac45d..ed1c8abd00777b 100644 --- a/nixos/modules/hardware/keyboard/teck.nix +++ b/nixos/modules/hardware/keyboard/teck.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.keyboard.teck; diff --git a/nixos/modules/hardware/keyboard/uhk.nix b/nixos/modules/hardware/keyboard/uhk.nix index a5bd35c2a5502a..4332cefe3f9e79 100644 --- a/nixos/modules/hardware/keyboard/uhk.nix +++ b/nixos/modules/hardware/keyboard/uhk.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.keyboard.uhk; diff --git a/nixos/modules/hardware/keyboard/zsa.nix b/nixos/modules/hardware/keyboard/zsa.nix index 42fac3b45bb937..607d1a5dfec0c8 100644 --- a/nixos/modules/hardware/keyboard/zsa.nix +++ b/nixos/modules/hardware/keyboard/zsa.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.keyboard.zsa; diff --git a/nixos/modules/hardware/ksm.nix b/nixos/modules/hardware/ksm.nix index 41d61e04697cb7..26b6e6049b97fc 100644 --- a/nixos/modules/hardware/ksm.nix +++ b/nixos/modules/hardware/ksm.nix @@ -2,7 +2,8 @@ let cfg = config.hardware.ksm; -in { +in +{ imports = [ (lib.mkRenamedOptionModule [ "hardware" "enableKSM" ] [ "hardware" "ksm" "enable" ]) ]; @@ -26,8 +27,8 @@ in { script = '' echo 1 > /sys/kernel/mm/ksm/run - '' + lib.optionalString (cfg.sleep != null) '' + + lib.optionalString (cfg.sleep != null) '' echo ${toString cfg.sleep} > /sys/kernel/mm/ksm/sleep_millisecs ''; }; diff --git a/nixos/modules/hardware/ledger.nix b/nixos/modules/hardware/ledger.nix index 8510c97c5e3891..738a367717c5a9 100644 --- a/nixos/modules/hardware/ledger.nix +++ b/nixos/modules/hardware/ledger.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.ledger; -in { +in +{ options.hardware.ledger.enable = lib.mkEnableOption "udev rules for Ledger devices"; config = lib.mkIf cfg.enable { diff --git a/nixos/modules/hardware/logitech.nix b/nixos/modules/hardware/logitech.nix index aeb97a2f9d9444..d52236e56f8273 100644 --- a/nixos/modules/hardware/logitech.nix +++ b/nixos/modules/hardware/logitech.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.logitech; @@ -9,8 +14,14 @@ let in { imports = [ - (lib.mkRenamedOptionModule [ "hardware" "logitech" "enable" ] [ "hardware" "logitech" "wireless" "enable" ]) - (lib.mkRenamedOptionModule [ "hardware" "logitech" "enableGraphical" ] [ "hardware" "logitech" "wireless" "enableGraphical" ]) + (lib.mkRenamedOptionModule + [ "hardware" "logitech" "enable" ] + [ "hardware" "logitech" "wireless" "enable" ] + ) + (lib.mkRenamedOptionModule + [ "hardware" "logitech" "enableGraphical" ] + [ "hardware" "logitech" "wireless" "enableGraphical" ] + ) ]; options.hardware.logitech = { @@ -28,7 +39,13 @@ in devices = lib.mkOption { type = lib.types.listOf lib.types.str; - default = [ "0a07" "c222" "c225" "c227" "c251" ]; + default = [ + "0a07" + "c222" + "c225" + "c227" + "c251" + ]; description = '' List of USB device ids supported by g15daemon. @@ -49,7 +66,8 @@ in }; config = lib.mkIf (cfg.wireless.enable || cfg.lcd.enable) { - environment.systemPackages = [] + environment.systemPackages = + [ ] ++ lib.optional cfg.wireless.enable pkgs.ltunify ++ lib.optional cfg.wireless.enableGraphical pkgs.solaar; @@ -57,22 +75,25 @@ in # ltunifi and solaar both provide udev rules but the most up-to-date have been split # out into a dedicated derivation - packages = [] - ++ lib.optional cfg.wireless.enable pkgs.logitech-udev-rules - ++ lib.optional cfg.lcd.enable pkgs.g15daemon; - - extraRules = '' - # nixos: hardware.logitech.lcd - '' + lib.concatMapStringsSep "\n" ( - dev: + packages = + [ ] + ++ lib.optional cfg.wireless.enable pkgs.logitech-udev-rules + ++ lib.optional cfg.lcd.enable pkgs.g15daemon; + + extraRules = + '' + # nixos: hardware.logitech.lcd + '' + + lib.concatMapStringsSep "\n" ( + dev: ''ACTION=="add", SUBSYSTEMS=="usb", ATTRS{idVendor}=="${vendor}", ATTRS{idProduct}=="${dev}", TAG+="systemd", ENV{SYSTEMD_WANTS}+="${daemon}.service"'' - ) cfg.lcd.devices; + ) cfg.lcd.devices; }; systemd.services."${daemon}" = lib.mkIf cfg.lcd.enable { description = "Logitech LCD Support Daemon"; documentation = [ "man:g15daemon(1)" ]; - wantedBy = lib.mkIf (! cfg.lcd.startWhenNeeded) "multi-user.target"; + wantedBy = lib.mkIf (!cfg.lcd.startWhenNeeded) "multi-user.target"; serviceConfig = { Type = "forking"; diff --git a/nixos/modules/hardware/mcelog.nix b/nixos/modules/hardware/mcelog.nix index 38629c4ba9452a..65d9ad3835f7a8 100644 --- a/nixos/modules/hardware/mcelog.nix +++ b/nixos/modules/hardware/mcelog.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { meta.maintainers = with lib.maintainers; [ grahamc ]; options = { diff --git a/nixos/modules/hardware/network/ath-user-regd.nix b/nixos/modules/hardware/network/ath-user-regd.nix index 4cd3fb69604bd2..af484fabb05d6e 100644 --- a/nixos/modules/hardware/network/ath-user-regd.nix +++ b/nixos/modules/hardware/network/ath-user-regd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let kernelVersion = config.boot.kernelPackages.kernel.version; linuxKernelMinVersion = "5.8"; diff --git a/nixos/modules/hardware/network/b43.nix b/nixos/modules/hardware/network/b43.nix index fc4020c09a5dac..4ced90c29772a4 100644 --- a/nixos/modules/hardware/network/b43.nix +++ b/nixos/modules/hardware/network/b43.nix @@ -1,5 +1,12 @@ -{ config, lib, pkgs, ... }: -let kernelVersion = config.boot.kernelPackages.kernel.version; in +{ + config, + lib, + pkgs, + ... +}: +let + kernelVersion = config.boot.kernelPackages.kernel.version; +in { @@ -17,7 +24,6 @@ let kernelVersion = config.boot.kernelPackages.kernel.version; in }; - ###### implementation config = lib.mkIf config.networking.enableB43Firmware { diff --git a/nixos/modules/hardware/network/intel-2200bg.nix b/nixos/modules/hardware/network/intel-2200bg.nix index 17b973474c93bc..7a46469033f343 100644 --- a/nixos/modules/hardware/network/intel-2200bg.nix +++ b/nixos/modules/hardware/network/intel-2200bg.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { @@ -18,7 +23,6 @@ }; - ###### implementation config = lib.mkIf config.networking.enableIntel2200BGFirmware { diff --git a/nixos/modules/hardware/network/smc-2632w/default.nix b/nixos/modules/hardware/network/smc-2632w/default.nix index b00286464f348e..e26b02fd1ef6e6 100644 --- a/nixos/modules/hardware/network/smc-2632w/default.nix +++ b/nixos/modules/hardware/network/smc-2632w/default.nix @@ -1,4 +1,4 @@ -{lib, ...}: +{ lib, ... }: { hardware = { diff --git a/nixos/modules/hardware/network/zydas-zd1211.nix b/nixos/modules/hardware/network/zydas-zd1211.nix index 5dd7f30ed82b18..3c43ccd331170f 100644 --- a/nixos/modules/hardware/network/zydas-zd1211.nix +++ b/nixos/modules/hardware/network/zydas-zd1211.nix @@ -1,4 +1,4 @@ -{pkgs, ...}: +{ pkgs, ... }: { hardware.firmware = [ pkgs.zd1211fw ]; diff --git a/nixos/modules/hardware/new-lg4ff.nix b/nixos/modules/hardware/new-lg4ff.nix index ac5d3e77df0b19..acb02d02f3d357 100644 --- a/nixos/modules/hardware/new-lg4ff.nix +++ b/nixos/modules/hardware/new-lg4ff.nix @@ -1,8 +1,14 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: let cfg = config.hardware.new-lg4ff; kernelPackages = config.boot.kernelPackages; -in { +in +{ options.hardware.new-lg4ff = { enable = lib.mkOption { type = lib.types.bool; diff --git a/nixos/modules/hardware/nitrokey.nix b/nixos/modules/hardware/nitrokey.nix index 6a11ba0891d7ba..9207bd2c41862e 100644 --- a/nixos/modules/hardware/nitrokey.nix +++ b/nixos/modules/hardware/nitrokey.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.nitrokey; diff --git a/nixos/modules/hardware/onlykey/default.nix b/nixos/modules/hardware/onlykey/default.nix index 9bf167ba5341c0..686d3d270a2511 100644 --- a/nixos/modules/hardware/onlykey/default.nix +++ b/nixos/modules/hardware/onlykey/default.nix @@ -26,5 +26,4 @@ services.udev.extraRules = builtins.readFile ./onlykey.udev; }; - } diff --git a/nixos/modules/hardware/openrazer.nix b/nixos/modules/hardware/openrazer.nix index c4a60c619f1789..470d451439d4b7 100644 --- a/nixos/modules/hardware/openrazer.nix +++ b/nixos/modules/hardware/openrazer.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.hardware.openrazer; kernelPackages = config.boot.kernelPackages; @@ -81,7 +86,7 @@ in description = '' Settings for device battery notifications. ''; - default = {}; + default = { }; type = lib.types.submodule { options = { enable = lib.mkOption { @@ -123,7 +128,7 @@ in users = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; description = '' Usernames to be added to the "openrazer" group, so that they can start and interact with the OpenRazer userspace daemon. @@ -133,7 +138,10 @@ in }; imports = [ - (lib.mkRenamedOptionModule [ "hardware" "openrazer" "mouseBatteryNotifier" ] [ "hardware" "openrazer" "batteryNotifier" "enable" ]) + (lib.mkRenamedOptionModule + [ "hardware" "openrazer" "mouseBatteryNotifier" ] + [ "hardware" "openrazer" "batteryNotifier" "enable" ] + ) ]; config = lib.mkIf cfg.enable { diff --git a/nixos/modules/hardware/opentabletdriver.nix b/nixos/modules/hardware/opentabletdriver.nix index 993d51d8798685..d74e9b8e4dce69 100644 --- a/nixos/modules/hardware/opentabletdriver.nix +++ b/nixos/modules/hardware/opentabletdriver.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.opentabletdriver; in @@ -18,7 +23,10 @@ in blacklistedKernelModules = lib.mkOption { type = lib.types.listOf lib.types.str; - default = [ "hid-uclogic" "wacom" ]; + default = [ + "hid-uclogic" + "wacom" + ]; description = '' Blacklist of kernel modules known to conflict with OpenTabletDriver. ''; @@ -45,16 +53,18 @@ in boot.blacklistedKernelModules = cfg.blacklistedKernelModules; - systemd.user.services.opentabletdriver = with pkgs; lib.mkIf cfg.daemon.enable { - description = "Open source, cross-platform, user-mode tablet driver"; - wantedBy = [ "graphical-session.target" ]; - partOf = [ "graphical-session.target" ]; + systemd.user.services.opentabletdriver = + with pkgs; + lib.mkIf cfg.daemon.enable { + description = "Open source, cross-platform, user-mode tablet driver"; + wantedBy = [ "graphical-session.target" ]; + partOf = [ "graphical-session.target" ]; - serviceConfig = { - Type = "simple"; - ExecStart = "${cfg.package}/bin/otd-daemon"; - Restart = "on-failure"; + serviceConfig = { + Type = "simple"; + ExecStart = "${cfg.package}/bin/otd-daemon"; + Restart = "on-failure"; + }; }; - }; }; } diff --git a/nixos/modules/hardware/pcmcia.nix b/nixos/modules/hardware/pcmcia.nix index 557925018d6874..45022f6c124bb2 100644 --- a/nixos/modules/hardware/pcmcia.nix +++ b/nixos/modules/hardware/pcmcia.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let pcmciaUtils = pkgs.pcmciaUtils.passthru.function { inherit (config.hardware.pcmcia) firmware config; @@ -20,7 +25,7 @@ in firmware = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; description = '' List of firmware used to handle specific PCMCIA card. ''; diff --git a/nixos/modules/hardware/printers.nix b/nixos/modules/hardware/printers.nix index a40822df11f5c6..6dc8ceec45dbab 100644 --- a/nixos/modules/hardware/printers.nix +++ b/nixos/modules/hardware/printers.nix @@ -1,22 +1,35 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.printers; - ensurePrinter = p: let - args = lib.cli.toGNUCommandLineShell {} ({ - p = p.name; - v = p.deviceUri; - m = p.model; - } // lib.optionalAttrs (p.location != null) { - L = p.location; - } // lib.optionalAttrs (p.description != null) { - D = p.description; - } // lib.optionalAttrs (p.ppdOptions != {}) { - o = lib.mapAttrsToList (name: value: "${name}=${value}") p.ppdOptions; - }); - in '' - ${pkgs.cups}/bin/lpadmin ${args} -E - ''; + ensurePrinter = + p: + let + args = lib.cli.toGNUCommandLineShell { } ( + { + p = p.name; + v = p.deviceUri; + m = p.model; + } + // lib.optionalAttrs (p.location != null) { + L = p.location; + } + // lib.optionalAttrs (p.description != null) { + D = p.description; + } + // lib.optionalAttrs (p.ppdOptions != { }) { + o = lib.mapAttrsToList (name: value: "${name}=${value}") p.ppdOptions; + } + ); + in + '' + ${pkgs.cups}/bin/lpadmin ${args} -E + ''; ensureDefaultPrinter = name: '' ${pkgs.cups}/bin/lpadmin -d '${name}' @@ -24,11 +37,12 @@ let # "graph but not # or /" can't be implemented as regex alone due to missing lookahead support noInvalidChars = str: lib.all (c: c != "#" && c != "/") (lib.stringToCharacters str); - printerName = (lib.types.addCheck (lib.types.strMatching "[[:graph:]]+") noInvalidChars) - // { description = "printable string without spaces, # and /"; }; - + printerName = (lib.types.addCheck (lib.types.strMatching "[[:graph:]]+") noInvalidChars) // { + description = "printable string without spaces, # and /"; + }; -in { +in +{ options = { hardware.printers = { ensureDefaultPrinter = lib.mkOption { @@ -47,73 +61,75 @@ in { and remove printers with {command}`lpadmin -x `. Printers not listed here can still be manually configured. ''; - default = []; - type = lib.types.listOf (lib.types.submodule { - options = { - name = lib.mkOption { - type = printerName; - example = "BrotherHL_Workroom"; - description = '' - Name of the printer / printer queue. - May contain any printable characters except "/", "#", and space. - ''; - }; - location = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - example = "Workroom"; - description = '' - Optional human-readable location. - ''; - }; - description = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - example = "Brother HL-5140"; - description = '' - Optional human-readable description. - ''; - }; - deviceUri = lib.mkOption { - type = lib.types.str; - example = lib.literalExpression '' - "ipp://printserver.local/printers/BrotherHL_Workroom" - "usb://HP/DESKJET%20940C?serial=CN16E6C364BH" - ''; - description = '' - How to reach the printer. - {command}`lpinfo -v` shows a list of supported device URIs and schemes. - ''; - }; - model = lib.mkOption { - type = lib.types.str; - example = lib.literalExpression '' - "gutenprint.''${lib.versions.majorMinor (lib.getVersion pkgs.gutenprint)}://brother-hl-5140/expert" - ''; - description = '' - Location of the ppd driver file for the printer. - {command}`lpinfo -m` shows a list of supported models. - ''; - }; - ppdOptions = lib.mkOption { - type = lib.types.attrsOf lib.types.str; - example = { - PageSize = "A4"; - Duplex = "DuplexNoTumble"; + default = [ ]; + type = lib.types.listOf ( + lib.types.submodule { + options = { + name = lib.mkOption { + type = printerName; + example = "BrotherHL_Workroom"; + description = '' + Name of the printer / printer queue. + May contain any printable characters except "/", "#", and space. + ''; + }; + location = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = null; + example = "Workroom"; + description = '' + Optional human-readable location. + ''; + }; + description = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = null; + example = "Brother HL-5140"; + description = '' + Optional human-readable description. + ''; + }; + deviceUri = lib.mkOption { + type = lib.types.str; + example = lib.literalExpression '' + "ipp://printserver.local/printers/BrotherHL_Workroom" + "usb://HP/DESKJET%20940C?serial=CN16E6C364BH" + ''; + description = '' + How to reach the printer. + {command}`lpinfo -v` shows a list of supported device URIs and schemes. + ''; + }; + model = lib.mkOption { + type = lib.types.str; + example = lib.literalExpression '' + "gutenprint.''${lib.versions.majorMinor (lib.getVersion pkgs.gutenprint)}://brother-hl-5140/expert" + ''; + description = '' + Location of the ppd driver file for the printer. + {command}`lpinfo -m` shows a list of supported models. + ''; + }; + ppdOptions = lib.mkOption { + type = lib.types.attrsOf lib.types.str; + example = { + PageSize = "A4"; + Duplex = "DuplexNoTumble"; + }; + default = { }; + description = '' + Sets PPD options for the printer. + {command}`lpoptions [-p printername] -l` shows supported PPD options for the given printer. + ''; }; - default = {}; - description = '' - Sets PPD options for the printer. - {command}`lpoptions [-p printername] -l` shows supported PPD options for the given printer. - ''; }; - }; - }); + } + ); }; }; }; - config = lib.mkIf (cfg.ensurePrinters != [] && config.services.printing.enable) { + config = lib.mkIf (cfg.ensurePrinters != [ ] && config.services.printing.enable) { systemd.services.ensure-printers = { description = "Ensure NixOS-configured CUPS printers"; wantedBy = [ "multi-user.target" ]; @@ -127,12 +143,14 @@ in { script = lib.concatStringsSep "\n" [ (lib.concatMapStrings ensurePrinter cfg.ensurePrinters) - (lib.optionalString (cfg.ensureDefaultPrinter != null) - (ensureDefaultPrinter cfg.ensureDefaultPrinter)) + (lib.optionalString (cfg.ensureDefaultPrinter != null) ( + ensureDefaultPrinter cfg.ensureDefaultPrinter + )) # Note: if cupsd is "stateless" the service can't be stopped, # otherwise the configuration will be wiped on the next start. - (lib.optionalString (with config.services.printing; startWhenNeeded && !stateless) - "systemctl stop cups.service") + (lib.optionalString ( + with config.services.printing; startWhenNeeded && !stateless + ) "systemctl stop cups.service") ]; }; }; diff --git a/nixos/modules/hardware/raid/hpsa.nix b/nixos/modules/hardware/raid/hpsa.nix index 2ec2398760b6c7..effac77bdd5aa9 100644 --- a/nixos/modules/hardware/raid/hpsa.nix +++ b/nixos/modules/hardware/raid/hpsa.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let hpssacli = pkgs.stdenv.mkDerivation rec { pname = "hpssacli"; @@ -40,7 +45,8 @@ let maintainers = [ ]; }; }; -in { +in +{ ###### interface options = { @@ -53,7 +59,7 @@ in { config = lib.mkIf config.hardware.raid.HPSmartArray.enable { - boot.initrd.kernelModules = [ "sg" ]; /* hpssacli wants it */ + boot.initrd.kernelModules = [ "sg" ]; # hpssacli wants it boot.initrd.availableKernelModules = [ "hpsa" ]; environment.systemPackages = [ hpssacli ]; diff --git a/nixos/modules/hardware/rtl-sdr.nix b/nixos/modules/hardware/rtl-sdr.nix index e85fc04e29bb6e..05a3b54124127e 100644 --- a/nixos/modules/hardware/rtl-sdr.nix +++ b/nixos/modules/hardware/rtl-sdr.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.rtl-sdr; -in { +in +{ options.hardware.rtl-sdr = { enable = lib.mkOption { type = lib.types.bool; @@ -11,13 +17,17 @@ in { description = '' Enables rtl-sdr udev rules, ensures 'plugdev' group exists, and blacklists DVB kernel modules. This is a prerequisite to using devices supported by rtl-sdr without being root, since rtl-sdr USB descriptors will be owned by plugdev through udev. - ''; + ''; }; }; config = lib.mkIf cfg.enable { - boot.blacklistedKernelModules = [ "dvb_usb_rtl28xxu" "e4000" "rtl2832" ]; + boot.blacklistedKernelModules = [ + "dvb_usb_rtl28xxu" + "e4000" + "rtl2832" + ]; services.udev.packages = [ pkgs.rtl-sdr ]; - users.groups.plugdev = {}; + users.groups.plugdev = { }; }; } diff --git a/nixos/modules/hardware/saleae-logic.nix b/nixos/modules/hardware/saleae-logic.nix index a3810d640c4839..dbfdf64fc2c100 100644 --- a/nixos/modules/hardware/saleae-logic.nix +++ b/nixos/modules/hardware/saleae-logic.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.saleae-logic; diff --git a/nixos/modules/hardware/sata.nix b/nixos/modules/hardware/sata.nix index 81592997d6e3dd..752a1a4de8ff3b 100644 --- a/nixos/modules/hardware/sata.nix +++ b/nixos/modules/hardware/sata.nix @@ -1,10 +1,21 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkIf mkOption types; + inherit (lib) + mkEnableOption + mkIf + mkOption + types + ; cfg = config.hardware.sata.timeout; - buildRule = d: + buildRule = + d: lib.concatStringsSep ", " [ ''ACTION=="add"'' ''SUBSYSTEM=="block"'' @@ -13,23 +24,20 @@ let ''ENV{SYSTEMD_WANTS}="${unitName d}"'' ]; - devicePath = device: - "/dev/disk/by-${device.idBy}/${device.name}"; + devicePath = device: "/dev/disk/by-${device.idBy}/${device.name}"; - unitName = device: - "sata-timeout-${lib.strings.sanitizeDerivationName device.name}"; + unitName = device: "sata-timeout-${lib.strings.sanitizeDerivationName device.name}"; - startScript = - pkgs.writeShellScript "sata-timeout.sh" '' - set -eEuo pipefail + startScript = pkgs.writeShellScript "sata-timeout.sh" '' + set -eEuo pipefail - device="$1" + device="$1" - ${pkgs.smartmontools}/bin/smartctl \ - -l scterc,${toString cfg.deciSeconds},${toString cfg.deciSeconds} \ - --quietmode errorsonly \ - "$device" - ''; + ${pkgs.smartmontools}/bin/smartctl \ + -l scterc,${toString cfg.deciSeconds},${toString cfg.deciSeconds} \ + --quietmode errorsonly \ + "$device" + ''; in { @@ -54,8 +62,8 @@ in drives = mkOption { description = "List of drives for which to configure the timeout."; - type = types.listOf - (types.submodule { + type = types.listOf ( + types.submodule { options = { name = mkOption { description = "Drive name without the full path."; @@ -64,19 +72,24 @@ in idBy = mkOption { description = "The method to identify the drive."; - type = types.enum [ "path" "wwn" ]; + type = types.enum [ + "path" + "wwn" + ]; default = "path"; }; }; - }); + } + ); }; }; config = mkIf cfg.enable { services.udev.extraRules = lib.concatMapStringsSep "\n" buildRule cfg.drives; - systemd.services = lib.listToAttrs (map - (e: + systemd.services = lib.listToAttrs ( + map ( + e: lib.nameValuePair (unitName e) { description = "SATA timeout for ${e.name}"; wantedBy = [ "sata-timeout.target" ]; @@ -89,8 +102,8 @@ in ProtectSystem = "strict"; }; } - ) - cfg.drives); + ) cfg.drives + ); systemd.targets.sata-timeout = { description = "SATA timeout"; diff --git a/nixos/modules/hardware/sensor/hddtemp.nix b/nixos/modules/hardware/sensor/hddtemp.nix index 8ee60dc4d6ddeb..8a8a3ad838c314 100644 --- a/nixos/modules/hardware/sensor/hddtemp.nix +++ b/nixos/modules/hardware/sensor/hddtemp.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) mkIf mkOption types; @@ -44,7 +49,10 @@ in unit = mkOption { description = "Celsius or Fahrenheit"; - type = types.enum [ "C" "F" ]; + type = types.enum [ + "C" + "F" + ]; default = "C"; }; diff --git a/nixos/modules/hardware/sensor/iio.nix b/nixos/modules/hardware/sensor/iio.nix index fbdc929390f2a4..0f7450cf164926 100644 --- a/nixos/modules/hardware/sensor/iio.nix +++ b/nixos/modules/hardware/sensor/iio.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { ###### interface diff --git a/nixos/modules/hardware/system-76.nix b/nixos/modules/hardware/system-76.nix index d81c59fbc92402..4dc71b9a509886 100644 --- a/nixos/modules/hardware/system-76.nix +++ b/nixos/modules/hardware/system-76.nix @@ -1,12 +1,30 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let - inherit (lib) literalExpression mkOption mkEnableOption types mkIf mkMerge optional versionOlder; + inherit (lib) + literalExpression + mkOption + mkEnableOption + types + mkIf + mkMerge + optional + versionOlder + ; cfg = config.hardware.system76; opt = options.hardware.system76; kpkgs = config.boot.kernelPackages; - modules = [ "system76" "system76-io" ] ++ (optional (versionOlder kpkgs.kernel.version "5.5") "system76-acpi"); + modules = [ + "system76" + "system76-io" + ] ++ (optional (versionOlder kpkgs.kernel.version "5.5") "system76-acpi"); modulePackages = map (m: kpkgs.${m}) modules; moduleConfig = mkIf cfg.kernel-modules.enable { boot.extraModulePackages = modulePackages; @@ -54,7 +72,8 @@ let wantedBy = [ "multi-user.target" ]; }; }; -in { +in +{ options = { hardware.system76 = { enableAll = mkEnableOption "all recommended configuration for system76 systems"; @@ -85,5 +104,9 @@ in { }; }; - config = mkMerge [ moduleConfig firmwareConfig powerConfig ]; + config = mkMerge [ + moduleConfig + firmwareConfig + powerConfig + ]; } diff --git a/nixos/modules/hardware/ubertooth.nix b/nixos/modules/hardware/ubertooth.nix index 98cd0a0fb047c6..0d89f7aa8a4c40 100644 --- a/nixos/modules/hardware/ubertooth.nix +++ b/nixos/modules/hardware/ubertooth.nix @@ -1,11 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.ubertooth; ubertoothPkg = pkgs.ubertooth.override { udevGroup = cfg.group; }; -in { +in +{ options.hardware.ubertooth = { enable = lib.mkEnableOption "Ubertooth software and its udev rules"; @@ -21,6 +27,6 @@ in { environment.systemPackages = [ ubertoothPkg ]; services.udev.packages = [ ubertoothPkg ]; - users.groups.${cfg.group} = {}; + users.groups.${cfg.group} = { }; }; } diff --git a/nixos/modules/hardware/uni-sync.nix b/nixos/modules/hardware/uni-sync.nix index dd230ae419a155..2fc93772562d6f 100644 --- a/nixos/modules/hardware/uni-sync.nix +++ b/nixos/modules/hardware/uni-sync.nix @@ -1,9 +1,11 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: -with lib; let +with lib; +let cfg = config.hardware.uni-sync; in { @@ -51,65 +53,74 @@ in ] ''; description = "List of controllers with their configurations."; - type = types.listOf (types.submodule { - options = { - device_id = mkOption { - type = types.str; - example = "VID:1111/PID:11111/SN:1111111111"; - description = "Unique device ID displayed at each startup."; - }; - sync_rgb = mkOption { - type = types.bool; - default = false; - example = true; - description = "Enable ARGB header sync."; - }; - channels = mkOption { - default = [ ]; - example = literalExpression '' - [ - { - mode = "PWM"; - } - { - mode = "Manual"; - speed = 100; - } - { - mode = "Manual"; - speed = 54; - } - { - mode = "Manual"; - speed = 0; + type = types.listOf ( + types.submodule { + options = { + device_id = mkOption { + type = types.str; + example = "VID:1111/PID:11111/SN:1111111111"; + description = "Unique device ID displayed at each startup."; + }; + sync_rgb = mkOption { + type = types.bool; + default = false; + example = true; + description = "Enable ARGB header sync."; + }; + channels = mkOption { + default = [ ]; + example = literalExpression '' + [ + { + mode = "PWM"; + } + { + mode = "Manual"; + speed = 100; + } + { + mode = "Manual"; + speed = 54; + } + { + mode = "Manual"; + speed = 0; + } + ] + ''; + description = "List of channels connected to the controller."; + type = types.listOf ( + types.submodule { + options = { + mode = mkOption { + type = types.enum [ + "Manual" + "PWM" + ]; + default = "Manual"; + example = "PWM"; + description = "\"PWM\" to enable PWM sync. \"Manual\" to set speed."; + }; + speed = mkOption { + type = types.int; + default = "50"; + example = "100"; + description = "Fan speed as percentage (clamped between 0 and 100)."; + }; + }; } - ] - ''; - description = "List of channels connected to the controller."; - type = types.listOf (types.submodule { - options = { - mode = mkOption { - type = types.enum [ "Manual" "PWM" ]; - default = "Manual"; - example = "PWM"; - description = "\"PWM\" to enable PWM sync. \"Manual\" to set speed."; - }; - speed = mkOption { - type = types.int; - default = "50"; - example = "100"; - description = "Fan speed as percentage (clamped between 0 and 100)."; - }; - }; - }); + ); + }; }; - }; - }); + } + ); }; }; config = mkIf cfg.enable { - environment.etc."uni-sync/uni-sync.json".text = mkIf (cfg.devices != [ ]) (builtins.toJSON { configs = cfg.devices; }); + environment.etc."uni-sync/uni-sync.json".text = mkIf (cfg.devices != [ ]) ( + builtins.toJSON { configs = cfg.devices; } + ); environment.systemPackages = [ cfg.package ]; services.udev.packages = [ cfg.package ]; diff --git a/nixos/modules/hardware/usb-modeswitch.nix b/nixos/modules/hardware/usb-modeswitch.nix index cbce5daa840d31..203e86bd2655cf 100644 --- a/nixos/modules/hardware/usb-modeswitch.nix +++ b/nixos/modules/hardware/usb-modeswitch.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { ###### interface @@ -21,7 +26,7 @@ ###### implementation imports = [ - (lib.mkRenamedOptionModule ["hardware" "usbWwan" ] ["hardware" "usb-modeswitch" ]) + (lib.mkRenamedOptionModule [ "hardware" "usbWwan" ] [ "hardware" "usb-modeswitch" ]) ]; config = lib.mkIf config.hardware.usb-modeswitch.enable { diff --git a/nixos/modules/hardware/usb-storage.nix b/nixos/modules/hardware/usb-storage.nix index 32c1707b271688..8cc34e78fdd401 100644 --- a/nixos/modules/hardware/usb-storage.nix +++ b/nixos/modules/hardware/usb-storage.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { options.hardware.usbStorage.manageShutdown = lib.mkOption { @@ -17,5 +22,10 @@ ''; }; - imports = [(lib.mkRenamedOptionModule [ "hardware" "usbStorage" "manageStartStop" ] [ "hardware" "usbStorage" "manageShutdown" ])]; + imports = [ + (lib.mkRenamedOptionModule + [ "hardware" "usbStorage" "manageStartStop" ] + [ "hardware" "usbStorage" "manageShutdown" ] + ) + ]; } diff --git a/nixos/modules/hardware/video/bumblebee.nix b/nixos/modules/hardware/video/bumblebee.nix index b5339f0dda53ee..4300130442518a 100644 --- a/nixos/modules/hardware/video/bumblebee.nix +++ b/nixos/modules/hardware/video/bumblebee.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.bumblebee; @@ -55,7 +60,10 @@ in driver = lib.mkOption { default = "nvidia"; - type = lib.types.enum [ "nvidia" "nouveau" ]; + type = lib.types.enum [ + "nvidia" + "nouveau" + ]; description = '' Set driver used by bumblebeed. Supported are nouveau and nvidia. ''; @@ -63,7 +71,12 @@ in pmMethod = lib.mkOption { default = "auto"; - type = lib.types.enum [ "auto" "bbswitch" "switcheroo" "none" ]; + type = lib.types.enum [ + "auto" + "bbswitch" + "switcheroo" + "none" + ]; description = '' Set preferred power management method for unused card. ''; @@ -73,11 +86,20 @@ in }; config = lib.mkIf cfg.enable { - boot.blacklistedKernelModules = [ "nvidia-drm" "nvidia" "nouveau" ]; + boot.blacklistedKernelModules = [ + "nvidia-drm" + "nvidia" + "nouveau" + ]; boot.kernelModules = lib.optional useBbswitch "bbswitch"; - boot.extraModulePackages = lib.optional useBbswitch kernel.bbswitch ++ lib.optional useNvidia kernel.nvidia_x11.bin; - - environment.systemPackages = [ bumblebee primus ]; + boot.extraModulePackages = + lib.optional useBbswitch kernel.bbswitch + ++ lib.optional useNvidia kernel.nvidia_x11.bin; + + environment.systemPackages = [ + bumblebee + primus + ]; systemd.services.bumblebeed = { description = "Bumblebee Hybrid Graphics Switcher"; diff --git a/nixos/modules/hardware/video/displaylink.nix b/nixos/modules/hardware/video/displaylink.nix index 32e5eaf2b978d8..9433be89b5d546 100644 --- a/nixos/modules/hardware/video/displaylink.nix +++ b/nixos/modules/hardware/video/displaylink.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let enabled = lib.elem "displaylink" config.services.xserver.videoDrivers; diff --git a/nixos/modules/hardware/video/intel-gpu-tools.nix b/nixos/modules/hardware/video/intel-gpu-tools.nix index b69fefcae1184f..691e17be66f3b9 100644 --- a/nixos/modules/hardware/video/intel-gpu-tools.nix +++ b/nixos/modules/hardware/video/intel-gpu-tools.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.intel-gpu-tools; diff --git a/nixos/modules/hardware/video/switcheroo-control.nix b/nixos/modules/hardware/video/switcheroo-control.nix index 967120d6744a1b..7cc54c032dc3fb 100644 --- a/nixos/modules/hardware/video/switcheroo-control.nix +++ b/nixos/modules/hardware/video/switcheroo-control.nix @@ -1,8 +1,14 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.switcherooControl; -in { +in +{ options.services.switcherooControl = { enable = lib.mkEnableOption "switcheroo-control, a D-Bus service to check the availability of dual-GPU"; package = lib.mkPackageOption pkgs "switcheroo-control" { }; diff --git a/nixos/modules/hardware/video/uvcvideo/default.nix b/nixos/modules/hardware/video/uvcvideo/default.nix index 8b9f1244e5b538..0b8d70dcbc0b1a 100644 --- a/nixos/modules/hardware/video/uvcvideo/default.nix +++ b/nixos/modules/hardware/video/uvcvideo/default.nix @@ -1,12 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.uvcvideo; - uvcdynctrl-udev-rules = packages: pkgs.callPackage ./uvcdynctrl-udev-rules.nix { - drivers = packages; - udevDebug = false; - }; + uvcdynctrl-udev-rules = + packages: + pkgs.callPackage ./uvcdynctrl-udev-rules.nix { + drivers = packages; + udevDebug = false; + }; in diff --git a/nixos/modules/hardware/video/uvcvideo/uvcdynctrl-udev-rules.nix b/nixos/modules/hardware/video/uvcvideo/uvcdynctrl-udev-rules.nix index 8dadbd53b98918..c1f1c3e15a0413 100644 --- a/nixos/modules/hardware/video/uvcvideo/uvcdynctrl-udev-rules.nix +++ b/nixos/modules/hardware/video/uvcvideo/uvcdynctrl-udev-rules.nix @@ -1,9 +1,10 @@ -{ buildEnv -, libwebcam -, makeWrapper -, runCommand -, drivers ? [] -, udevDebug ? false +{ + buildEnv, + libwebcam, + makeWrapper, + runCommand, + drivers ? [ ], + udevDebug ? false, }: let @@ -21,27 +22,26 @@ let in runCommand "uvcdynctrl-udev-rules-${version}" -{ - inherit dataPath; - nativeBuildInputs = [ - makeWrapper - ]; - buildInputs = [ - libwebcam - ]; - dontPatchELF = true; - dontStrip = true; - preferLocalBuild = true; -} -'' - mkdir -p "$out/lib/udev" - makeWrapper "${libwebcam}/lib/udev/uvcdynctrl" "$out/lib/udev/uvcdynctrl" \ - --set NIX_UVCDYNCTRL_DATA_DIR "${dataDir}" \ - --set NIX_UVCDYNCTRL_UDEV_DEBUG "${udevDebugVarValue}" - - mkdir -p "$out/lib/udev/rules.d" - cat "${libwebcam}/lib/udev/rules.d/80-uvcdynctrl.rules" | \ - sed -r "s#RUN\+\=\"([^\"]+)\"#RUN\+\=\"$out/lib/udev/uvcdynctrl\"#g" > \ - "$out/lib/udev/rules.d/80-uvcdynctrl.rules" -'' + { + inherit dataPath; + nativeBuildInputs = [ + makeWrapper + ]; + buildInputs = [ + libwebcam + ]; + dontPatchELF = true; + dontStrip = true; + preferLocalBuild = true; + } + '' + mkdir -p "$out/lib/udev" + makeWrapper "${libwebcam}/lib/udev/uvcdynctrl" "$out/lib/udev/uvcdynctrl" \ + --set NIX_UVCDYNCTRL_DATA_DIR "${dataDir}" \ + --set NIX_UVCDYNCTRL_UDEV_DEBUG "${udevDebugVarValue}" + mkdir -p "$out/lib/udev/rules.d" + cat "${libwebcam}/lib/udev/rules.d/80-uvcdynctrl.rules" | \ + sed -r "s#RUN\+\=\"([^\"]+)\"#RUN\+\=\"$out/lib/udev/uvcdynctrl\"#g" > \ + "$out/lib/udev/rules.d/80-uvcdynctrl.rules" + '' diff --git a/nixos/modules/hardware/video/virtualbox.nix b/nixos/modules/hardware/video/virtualbox.nix index 31ed92b7d148e9..e7e557e9c32790 100644 --- a/nixos/modules/hardware/video/virtualbox.nix +++ b/nixos/modules/hardware/video/virtualbox.nix @@ -2,6 +2,9 @@ let inherit (config.boot) kernelPackages; inherit (config.services.xserver) videoDrivers; -in { - boot.extraModulePackages = lib.mkIf (lib.elem "virtualbox" videoDrivers) [ kernelPackages.virtualboxGuestAdditions ]; +in +{ + boot.extraModulePackages = lib.mkIf (lib.elem "virtualbox" videoDrivers) [ + kernelPackages.virtualboxGuestAdditions + ]; } diff --git a/nixos/modules/hardware/video/webcam/facetimehd.nix b/nixos/modules/hardware/video/webcam/facetimehd.nix index 06391ea5425e83..1b666ed9557736 100644 --- a/nixos/modules/hardware/video/webcam/facetimehd.nix +++ b/nixos/modules/hardware/video/webcam/facetimehd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.facetimehd; @@ -31,8 +36,9 @@ in boot.extraModulePackages = [ kernelPackages.facetimehd ]; - hardware.firmware = [ pkgs.facetimehd-firmware ] - ++ lib.optional cfg.withCalibration pkgs.facetimehd-calibration; + hardware.firmware = [ + pkgs.facetimehd-firmware + ] ++ lib.optional cfg.withCalibration pkgs.facetimehd-calibration; # unload module during suspend/hibernate as it crashes the whole system powerManagement.powerDownCommands = '' diff --git a/nixos/modules/hardware/video/webcam/ipu6.nix b/nixos/modules/hardware/video/webcam/ipu6.nix index 803902530dd925..aab986251d75d2 100644 --- a/nixos/modules/hardware/video/webcam/ipu6.nix +++ b/nixos/modules/hardware/video/webcam/ipu6.nix @@ -1,7 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkDefault mkEnableOption mkIf mkOption optional types; + inherit (lib) + mkDefault + mkEnableOption + mkIf + mkOption + optional + types + ; cfg = config.hardware.ipu6; @@ -13,7 +25,11 @@ in enable = mkEnableOption "support for Intel IPU6/MIPI cameras"; platform = mkOption { - type = types.enum [ "ipu6" "ipu6ep" "ipu6epmtl" ]; + type = types.enum [ + "ipu6" + "ipu6ep" + "ipu6epmtl" + ]; description = '' Choose the version for your hardware platform. @@ -44,7 +60,9 @@ in cardLabel = mkDefault "Intel MIPI Camera"; - extraPackages = with pkgs.gst_all_1; [ ] + extraPackages = + with pkgs.gst_all_1; + [ ] ++ optional (cfg.platform == "ipu6") icamerasrc-ipu6 ++ optional (cfg.platform == "ipu6ep") icamerasrc-ipu6ep ++ optional (cfg.platform == "ipu6epmtl") icamerasrc-ipu6epmtl; diff --git a/nixos/modules/hardware/xone.nix b/nixos/modules/hardware/xone.nix index 4a8e692001e437..04216e8260a7bf 100644 --- a/nixos/modules/hardware/xone.nix +++ b/nixos/modules/hardware/xone.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.xone; in @@ -9,7 +14,10 @@ in config = lib.mkIf cfg.enable { boot = { - blacklistedKernelModules = [ "xpad" "mt76x2u" ]; + blacklistedKernelModules = [ + "xpad" + "mt76x2u" + ]; extraModulePackages = with config.boot.kernelPackages; [ xone ]; }; hardware.firmware = [ pkgs.xow_dongle-firmware ]; diff --git a/nixos/modules/hardware/xpadneo.nix b/nixos/modules/hardware/xpadneo.nix index d42164060e8374..796aa9fc8d4aa2 100644 --- a/nixos/modules/hardware/xpadneo.nix +++ b/nixos/modules/hardware/xpadneo.nix @@ -11,11 +11,10 @@ in boot = { # Must disable Enhanced Retransmission Mode to support bluetooth pairing # https://wiki.archlinux.org/index.php/Gamepad#Connect_Xbox_Wireless_Controller_with_Bluetooth - extraModprobeConfig = - lib.mkIf - (config.hardware.bluetooth.enable && - (lib.versionOlder config.boot.kernelPackages.kernel.version "5.12")) - "options bluetooth disable_ertm=1"; + extraModprobeConfig = lib.mkIf ( + config.hardware.bluetooth.enable + && (lib.versionOlder config.boot.kernelPackages.kernel.version "5.12") + ) "options bluetooth disable_ertm=1"; extraModulePackages = with config.boot.kernelPackages; [ xpadneo ]; kernelModules = [ "hid_xpadneo" ]; diff --git a/nixos/modules/i18n/input-method/default.nix b/nixos/modules/i18n/input-method/default.nix index a706b045e377bc..d84be512b39f84 100644 --- a/nixos/modules/i18n/input-method/default.nix +++ b/nixos/modules/i18n/input-method/default.nix @@ -1,28 +1,50 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.i18n.inputMethod; - allowedTypes = lib.types.enum [ "ibus" "fcitx5" "nabi" "uim" "hime" "kime" ]; + allowedTypes = lib.types.enum [ + "ibus" + "fcitx5" + "nabi" + "uim" + "hime" + "kime" + ]; - gtk2_cache = pkgs.runCommand "gtk2-immodule.cache" - { preferLocalBuild = true; - allowSubstitutes = false; - buildInputs = [ pkgs.gtk2 cfg.package ]; - } - '' - mkdir -p $out/etc/gtk-2.0/ - GTK_PATH=${cfg.package}/lib/gtk-2.0/ gtk-query-immodules-2.0 > $out/etc/gtk-2.0/immodules.cache - ''; + gtk2_cache = + pkgs.runCommand "gtk2-immodule.cache" + { + preferLocalBuild = true; + allowSubstitutes = false; + buildInputs = [ + pkgs.gtk2 + cfg.package + ]; + } + '' + mkdir -p $out/etc/gtk-2.0/ + GTK_PATH=${cfg.package}/lib/gtk-2.0/ gtk-query-immodules-2.0 > $out/etc/gtk-2.0/immodules.cache + ''; - gtk3_cache = pkgs.runCommand "gtk3-immodule.cache" - { preferLocalBuild = true; - allowSubstitutes = false; - buildInputs = [ pkgs.gtk3 cfg.package ]; - } - '' - mkdir -p $out/etc/gtk-3.0/ - GTK_PATH=${cfg.package}/lib/gtk-3.0/ gtk-query-immodules-3.0 > $out/etc/gtk-3.0/immodules.cache - ''; + gtk3_cache = + pkgs.runCommand "gtk3-immodule.cache" + { + preferLocalBuild = true; + allowSubstitutes = false; + buildInputs = [ + pkgs.gtk3 + cfg.package + ]; + } + '' + mkdir -p $out/etc/gtk-3.0/ + GTK_PATH=${cfg.package}/lib/gtk-3.0/ gtk-query-immodules-3.0 > $out/etc/gtk-3.0/immodules.cache + ''; in { @@ -34,14 +56,14 @@ in }; enabled = lib.mkOption { - type = lib.types.nullOr allowedTypes; + type = lib.types.nullOr allowedTypes; default = null; example = "fcitx5"; description = "Deprecated - use `type` and `enable = true` instead"; }; type = lib.mkOption { - type = lib.types.nullOr allowedTypes; + type = lib.types.nullOr allowedTypes; default = cfg.enabled; defaultText = lib.literalMD "The value of the deprecated option `enabled`, defaulting to null"; example = "fcitx5"; @@ -63,8 +85,8 @@ in package = lib.mkOption { internal = true; - type = lib.types.nullOr lib.types.path; - default = null; + type = lib.types.nullOr lib.types.path; + default = null; description = '' The input method method package. ''; @@ -73,8 +95,14 @@ in }; config = lib.mkIf cfg.enable { - warnings = lib.optional (cfg.enabled != null) "i18n.inputMethod.enabled will be removed in a future release. Please use .type, and .enable = true instead"; - environment.systemPackages = [ cfg.package gtk2_cache gtk3_cache ]; + warnings = + lib.optional (cfg.enabled != null) + "i18n.inputMethod.enabled will be removed in a future release. Please use .type, and .enable = true instead"; + environment.systemPackages = [ + cfg.package + gtk2_cache + gtk3_cache + ]; }; meta = { diff --git a/nixos/modules/i18n/input-method/hime.nix b/nixos/modules/i18n/input-method/hime.nix index b3f49c0e305771..40349972bccb79 100644 --- a/nixos/modules/i18n/input-method/hime.nix +++ b/nixos/modules/i18n/input-method/hime.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let imcfg = config.i18n.inputMethod; in @@ -7,8 +12,8 @@ in i18n.inputMethod.package = pkgs.hime; environment.variables = { GTK_IM_MODULE = "hime"; - QT_IM_MODULE = "hime"; - XMODIFIERS = "@im=hime"; + QT_IM_MODULE = "hime"; + XMODIFIERS = "@im=hime"; }; services.xserver.displayManager.sessionCommands = "${pkgs.hime}/bin/hime &"; }; diff --git a/nixos/modules/i18n/input-method/kime.nix b/nixos/modules/i18n/input-method/kime.nix index 78f5698a80545a..92dfe4abba7640 100644 --- a/nixos/modules/i18n/input-method/kime.nix +++ b/nixos/modules/i18n/input-method/kime.nix @@ -1,22 +1,50 @@ -{ config, pkgs, lib, generators, ... }: +{ + config, + pkgs, + lib, + generators, + ... +}: let imcfg = config.i18n.inputMethod; -in { +in +{ imports = [ - (lib.mkRemovedOptionModule [ "i18n" "inputMethod" "kime" "config" ] "Use i18n.inputMethod.kime.* instead") + (lib.mkRemovedOptionModule [ + "i18n" + "inputMethod" + "kime" + "config" + ] "Use i18n.inputMethod.kime.* instead") ]; options.i18n.inputMethod.kime = { daemonModules = lib.mkOption { - type = lib.types.listOf (lib.types.enum [ "Xim" "Wayland" "Indicator" ]); - default = [ "Xim" "Wayland" "Indicator" ]; - example = [ "Xim" "Indicator" ]; + type = lib.types.listOf ( + lib.types.enum [ + "Xim" + "Wayland" + "Indicator" + ] + ); + default = [ + "Xim" + "Wayland" + "Indicator" + ]; + example = [ + "Xim" + "Indicator" + ]; description = '' List of enabled daemon modules ''; }; iconColor = lib.mkOption { - type = lib.types.enum [ "Black" "White" ]; + type = lib.types.enum [ + "Black" + "White" + ]; default = "Black"; example = "White"; description = '' @@ -37,16 +65,18 @@ in { environment.variables = { GTK_IM_MODULE = "kime"; - QT_IM_MODULE = "kime"; - XMODIFIERS = "@im=kime"; + QT_IM_MODULE = "kime"; + XMODIFIERS = "@im=kime"; }; - environment.etc."xdg/kime/config.yaml".text = '' - daemon: - modules: [${lib.concatStringsSep "," imcfg.kime.daemonModules}] - indicator: - icon_color: ${imcfg.kime.iconColor} - '' + imcfg.kime.extraConfig; + environment.etc."xdg/kime/config.yaml".text = + '' + daemon: + modules: [${lib.concatStringsSep "," imcfg.kime.daemonModules}] + indicator: + icon_color: ${imcfg.kime.iconColor} + '' + + imcfg.kime.extraConfig; }; # uses attributes of the linked package diff --git a/nixos/modules/i18n/input-method/nabi.nix b/nixos/modules/i18n/input-method/nabi.nix index af01d1b0676d39..b620c3c297d15c 100644 --- a/nixos/modules/i18n/input-method/nabi.nix +++ b/nixos/modules/i18n/input-method/nabi.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let imcfg = config.i18n.inputMethod; in @@ -8,8 +13,8 @@ in environment.variables = { GTK_IM_MODULE = "nabi"; - QT_IM_MODULE = "nabi"; - XMODIFIERS = "@im=nabi"; + QT_IM_MODULE = "nabi"; + XMODIFIERS = "@im=nabi"; }; services.xserver.displayManager.sessionCommands = "${pkgs.nabi}/bin/nabi &"; diff --git a/nixos/modules/i18n/input-method/uim.nix b/nixos/modules/i18n/input-method/uim.nix index 4edc121b2ccdfb..2f40a94da6a192 100644 --- a/nixos/modules/i18n/input-method/uim.nix +++ b/nixos/modules/i18n/input-method/uim.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let imcfg = config.i18n.inputMethod; cfg = imcfg.uim; @@ -8,7 +13,13 @@ in i18n.inputMethod.uim = { toolbar = lib.mkOption { - type = lib.types.enum [ "gtk" "gtk3" "gtk-systray" "gtk3-systray" "qt5" ]; + type = lib.types.enum [ + "gtk" + "gtk3" + "gtk-systray" + "gtk3-systray" + "qt5" + ]; default = "gtk"; example = "gtk-systray"; description = '' @@ -24,8 +35,8 @@ in environment.variables = { GTK_IM_MODULE = "uim"; - QT_IM_MODULE = "uim"; - XMODIFIERS = "@im=uim"; + QT_IM_MODULE = "uim"; + XMODIFIERS = "@im=uim"; }; services.xserver.displayManager.sessionCommands = '' ${pkgs.uim}/bin/uim-xim & diff --git a/nixos/modules/image/repart-verity-store.nix b/nixos/modules/image/repart-verity-store.nix index d270dc069f343e..953a5997c5fdd7 100644 --- a/nixos/modules/image/repart-verity-store.nix +++ b/nixos/modules/image/repart-verity-store.nix @@ -34,9 +34,12 @@ let flakeIgnore = [ "E501" ]; # ignores PEP8's line length limit of 79 (black defaults to 88 characters) } ( - builtins.replaceStrings [ "@NIX_STORE_VERITY@" ] [ - partitionTypes.usr-verity - ] (builtins.readFile ./assert_uki_repart_match.py) + builtins.replaceStrings + [ "@NIX_STORE_VERITY@" ] + [ + partitionTypes.usr-verity + ] + (builtins.readFile ./assert_uki_repart_match.py) ); in { diff --git a/nixos/modules/installer/cd-dvd/channel.nix b/nixos/modules/installer/cd-dvd/channel.nix index bc70dc985fe005..e5fa5db420be88 100644 --- a/nixos/modules/installer/cd-dvd/channel.nix +++ b/nixos/modules/installer/cd-dvd/channel.nix @@ -1,7 +1,12 @@ # Provide an initial copy of the NixOS channel so that the user # doesn't need to run "nix-channel --update" first. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let # This is copied into the installer image, so it's important that it is filtered @@ -16,25 +21,29 @@ let # CD. These are installed into the "nixos" channel of the root # user, as expected by nixos-rebuild/nixos-install. FIXME: merge # with make-channel.nix. - channelSources = pkgs.runCommand "nixos-${config.system.nixos.version}" - { preferLocalBuild = true; } - '' - mkdir -p $out - cp -prd ${nixpkgs.outPath} $out/nixos - chmod -R u+w $out/nixos - if [ ! -e $out/nixos/nixpkgs ]; then - ln -s . $out/nixos/nixpkgs - fi - ${lib.optionalString (config.system.nixos.revision != null) '' - echo -n ${config.system.nixos.revision} > $out/nixos/.git-revision - ''} - echo -n ${config.system.nixos.versionSuffix} > $out/nixos/.version-suffix - echo ${config.system.nixos.versionSuffix} | sed -e s/pre// > $out/nixos/svn-revision - ''; + channelSources = + pkgs.runCommand "nixos-${config.system.nixos.version}" { preferLocalBuild = true; } + '' + mkdir -p $out + cp -prd ${nixpkgs.outPath} $out/nixos + chmod -R u+w $out/nixos + if [ ! -e $out/nixos/nixpkgs ]; then + ln -s . $out/nixos/nixpkgs + fi + ${lib.optionalString (config.system.nixos.revision != null) '' + echo -n ${config.system.nixos.revision} > $out/nixos/.git-revision + ''} + echo -n ${config.system.nixos.versionSuffix} > $out/nixos/.version-suffix + echo ${config.system.nixos.versionSuffix} | sed -e s/pre// > $out/nixos/svn-revision + ''; in { - options.system.installer.channel.enable = (lib.mkEnableOption "bundling NixOS/Nixpkgs channel in the installer") // { default = true; }; + options.system.installer.channel.enable = + (lib.mkEnableOption "bundling NixOS/Nixpkgs channel in the installer") + // { + default = true; + }; config = lib.mkIf config.system.installer.channel.enable { # Pin the nixpkgs flake in the installer to our cleaned up nixpkgs source. # FIXME: this might be surprising and is really only needed for offline installations, @@ -46,19 +55,18 @@ in # Provide the NixOS/Nixpkgs sources in /etc/nixos. This is required # for nixos-install. - boot.postBootCommands = lib.mkAfter - '' - if ! [ -e /var/lib/nixos/did-channel-init ]; then - echo "unpacking the NixOS/Nixpkgs sources..." - mkdir -p /nix/var/nix/profiles/per-user/root - ${config.nix.package.out}/bin/nix-env -p /nix/var/nix/profiles/per-user/root/channels \ - -i ${channelSources} --quiet --option build-use-substitutes false \ - ${lib.optionalString config.boot.initrd.systemd.enable "--option sandbox false"} # There's an issue with pivot_root - mkdir -m 0700 -p /root/.nix-defexpr - ln -s /nix/var/nix/profiles/per-user/root/channels /root/.nix-defexpr/channels - mkdir -m 0755 -p /var/lib/nixos - touch /var/lib/nixos/did-channel-init - fi - ''; + boot.postBootCommands = lib.mkAfter '' + if ! [ -e /var/lib/nixos/did-channel-init ]; then + echo "unpacking the NixOS/Nixpkgs sources..." + mkdir -p /nix/var/nix/profiles/per-user/root + ${config.nix.package.out}/bin/nix-env -p /nix/var/nix/profiles/per-user/root/channels \ + -i ${channelSources} --quiet --option build-use-substitutes false \ + ${lib.optionalString config.boot.initrd.systemd.enable "--option sandbox false"} # There's an issue with pivot_root + mkdir -m 0700 -p /root/.nix-defexpr + ln -s /nix/var/nix/profiles/per-user/root/channels /root/.nix-defexpr/channels + mkdir -m 0755 -p /var/lib/nixos + touch /var/lib/nixos/did-channel-init + fi + ''; }; } diff --git a/nixos/modules/installer/cd-dvd/installation-cd-graphical-calamares-plasma5.nix b/nixos/modules/installer/cd-dvd/installation-cd-graphical-calamares-plasma5.nix index d1a42fc7a713bb..c322efb683d6f7 100644 --- a/nixos/modules/installer/cd-dvd/installation-cd-graphical-calamares-plasma5.nix +++ b/nixos/modules/installer/cd-dvd/installation-cd-graphical-calamares-plasma5.nix @@ -26,22 +26,28 @@ plasma5Packages.kate ]; - system.activationScripts.installerDesktop = let - - # Comes from documentation.nix when xserver and nixos.enable are true. - manualDesktopFile = "/run/current-system/sw/share/applications/nixos-manual.desktop"; - - homeDir = "/home/nixos/"; - desktopDir = homeDir + "Desktop/"; - - in '' - mkdir -p ${desktopDir} - chown nixos ${homeDir} ${desktopDir} - - ln -sfT ${manualDesktopFile} ${desktopDir + "nixos-manual.desktop"} - ln -sfT ${pkgs.gparted}/share/applications/gparted.desktop ${desktopDir + "gparted.desktop"} - ln -sfT ${pkgs.plasma5Packages.konsole}/share/applications/org.kde.konsole.desktop ${desktopDir + "org.kde.konsole.desktop"} - ln -sfT ${pkgs.calamares-nixos}/share/applications/io.calamares.calamares.desktop ${desktopDir + "io.calamares.calamares.desktop"} - ''; + system.activationScripts.installerDesktop = + let + + # Comes from documentation.nix when xserver and nixos.enable are true. + manualDesktopFile = "/run/current-system/sw/share/applications/nixos-manual.desktop"; + + homeDir = "/home/nixos/"; + desktopDir = homeDir + "Desktop/"; + + in + '' + mkdir -p ${desktopDir} + chown nixos ${homeDir} ${desktopDir} + + ln -sfT ${manualDesktopFile} ${desktopDir + "nixos-manual.desktop"} + ln -sfT ${pkgs.gparted}/share/applications/gparted.desktop ${desktopDir + "gparted.desktop"} + ln -sfT ${pkgs.plasma5Packages.konsole}/share/applications/org.kde.konsole.desktop ${ + desktopDir + "org.kde.konsole.desktop" + } + ln -sfT ${pkgs.calamares-nixos}/share/applications/io.calamares.calamares.desktop ${ + desktopDir + "io.calamares.calamares.desktop" + } + ''; } diff --git a/nixos/modules/installer/cd-dvd/installation-cd-graphical-calamares-plasma6.nix b/nixos/modules/installer/cd-dvd/installation-cd-graphical-calamares-plasma6.nix index bdcf751bf6290c..e420300e4166e9 100644 --- a/nixos/modules/installer/cd-dvd/installation-cd-graphical-calamares-plasma6.nix +++ b/nixos/modules/installer/cd-dvd/installation-cd-graphical-calamares-plasma6.nix @@ -24,21 +24,25 @@ pkgs.maliit-keyboard ]; - system.activationScripts.installerDesktop = let - - # Comes from documentation.nix when xserver and nixos.enable are true. - manualDesktopFile = "/run/current-system/sw/share/applications/nixos-manual.desktop"; - - homeDir = "/home/nixos/"; - desktopDir = homeDir + "Desktop/"; - - in '' - mkdir -p ${desktopDir} - chown nixos ${homeDir} ${desktopDir} - - ln -sfT ${manualDesktopFile} ${desktopDir + "nixos-manual.desktop"} - ln -sfT ${pkgs.gparted}/share/applications/gparted.desktop ${desktopDir + "gparted.desktop"} - ln -sfT ${pkgs.calamares-nixos}/share/applications/io.calamares.calamares.desktop ${desktopDir + "io.calamares.calamares.desktop"} - ''; + system.activationScripts.installerDesktop = + let + + # Comes from documentation.nix when xserver and nixos.enable are true. + manualDesktopFile = "/run/current-system/sw/share/applications/nixos-manual.desktop"; + + homeDir = "/home/nixos/"; + desktopDir = homeDir + "Desktop/"; + + in + '' + mkdir -p ${desktopDir} + chown nixos ${homeDir} ${desktopDir} + + ln -sfT ${manualDesktopFile} ${desktopDir + "nixos-manual.desktop"} + ln -sfT ${pkgs.gparted}/share/applications/gparted.desktop ${desktopDir + "gparted.desktop"} + ln -sfT ${pkgs.calamares-nixos}/share/applications/io.calamares.calamares.desktop ${ + desktopDir + "io.calamares.calamares.desktop" + } + ''; } diff --git a/nixos/modules/installer/cd-dvd/installation-cd-graphical-calamares.nix b/nixos/modules/installer/cd-dvd/installation-cd-graphical-calamares.nix index 3f3571d253825f..631342d51ea79d 100644 --- a/nixos/modules/installer/cd-dvd/installation-cd-graphical-calamares.nix +++ b/nixos/modules/installer/cd-dvd/installation-cd-graphical-calamares.nix @@ -3,7 +3,10 @@ { pkgs, ... }: let - calamares-nixos-autostart = pkgs.makeAutostartItem { name = "io.calamares.calamares"; package = pkgs.calamares-nixos; }; + calamares-nixos-autostart = pkgs.makeAutostartItem { + name = "io.calamares.calamares"; + package = pkgs.calamares-nixos; + }; in { imports = [ ./installation-cd-graphical-base.nix ]; diff --git a/nixos/modules/installer/cd-dvd/installation-cd-graphical-plasma5.nix b/nixos/modules/installer/cd-dvd/installation-cd-graphical-plasma5.nix index 770df5bb997b9e..4f7b7d4b2bf9d4 100644 --- a/nixos/modules/installer/cd-dvd/installation-cd-graphical-plasma5.nix +++ b/nixos/modules/installer/cd-dvd/installation-cd-graphical-plasma5.nix @@ -26,21 +26,25 @@ plasma5Packages.kate ]; - system.activationScripts.installerDesktop = let - - # Comes from documentation.nix when xserver and nixos.enable are true. - manualDesktopFile = "/run/current-system/sw/share/applications/nixos-manual.desktop"; - - homeDir = "/home/nixos/"; - desktopDir = homeDir + "Desktop/"; - - in '' - mkdir -p ${desktopDir} - chown nixos ${homeDir} ${desktopDir} - - ln -sfT ${manualDesktopFile} ${desktopDir + "nixos-manual.desktop"} - ln -sfT ${pkgs.gparted}/share/applications/gparted.desktop ${desktopDir + "gparted.desktop"} - ln -sfT ${pkgs.plasma5Packages.konsole}/share/applications/org.kde.konsole.desktop ${desktopDir + "org.kde.konsole.desktop"} - ''; + system.activationScripts.installerDesktop = + let + + # Comes from documentation.nix when xserver and nixos.enable are true. + manualDesktopFile = "/run/current-system/sw/share/applications/nixos-manual.desktop"; + + homeDir = "/home/nixos/"; + desktopDir = homeDir + "Desktop/"; + + in + '' + mkdir -p ${desktopDir} + chown nixos ${homeDir} ${desktopDir} + + ln -sfT ${manualDesktopFile} ${desktopDir + "nixos-manual.desktop"} + ln -sfT ${pkgs.gparted}/share/applications/gparted.desktop ${desktopDir + "gparted.desktop"} + ln -sfT ${pkgs.plasma5Packages.konsole}/share/applications/org.kde.konsole.desktop ${ + desktopDir + "org.kde.konsole.desktop" + } + ''; } diff --git a/nixos/modules/installer/cd-dvd/sd-image-aarch64-new-kernel.nix b/nixos/modules/installer/cd-dvd/sd-image-aarch64-new-kernel.nix index a669d61571fef4..997423e4525722 100644 --- a/nixos/modules/installer/cd-dvd/sd-image-aarch64-new-kernel.nix +++ b/nixos/modules/installer/cd-dvd/sd-image-aarch64-new-kernel.nix @@ -6,8 +6,8 @@ config = { warnings = [ '' - .../cd-dvd/sd-image-aarch64-new-kernel.nix is deprecated and will eventually be removed. - Please switch to .../sd-card/sd-image-aarch64-new-kernel-installer.nix, instead. + .../cd-dvd/sd-image-aarch64-new-kernel.nix is deprecated and will eventually be removed. + Please switch to .../sd-card/sd-image-aarch64-new-kernel-installer.nix, instead. '' ]; }; diff --git a/nixos/modules/installer/cd-dvd/sd-image-aarch64.nix b/nixos/modules/installer/cd-dvd/sd-image-aarch64.nix index 76c1509b8f7e01..e7afffb81a5a38 100644 --- a/nixos/modules/installer/cd-dvd/sd-image-aarch64.nix +++ b/nixos/modules/installer/cd-dvd/sd-image-aarch64.nix @@ -6,8 +6,8 @@ config = { warnings = [ '' - .../cd-dvd/sd-image-aarch64.nix is deprecated and will eventually be removed. - Please switch to .../sd-card/sd-image-aarch64-installer.nix, instead. + .../cd-dvd/sd-image-aarch64.nix is deprecated and will eventually be removed. + Please switch to .../sd-card/sd-image-aarch64-installer.nix, instead. '' ]; }; diff --git a/nixos/modules/installer/cd-dvd/sd-image-armv7l-multiplatform.nix b/nixos/modules/installer/cd-dvd/sd-image-armv7l-multiplatform.nix index 6ee0eb9e9b8dbb..c16b82256b4f84 100644 --- a/nixos/modules/installer/cd-dvd/sd-image-armv7l-multiplatform.nix +++ b/nixos/modules/installer/cd-dvd/sd-image-armv7l-multiplatform.nix @@ -6,8 +6,8 @@ config = { warnings = [ '' - .../cd-dvd/sd-image-armv7l-multiplatform.nix is deprecated and will eventually be removed. - Please switch to .../sd-card/sd-image-armv7l-multiplatform-installer.nix, instead. + .../cd-dvd/sd-image-armv7l-multiplatform.nix is deprecated and will eventually be removed. + Please switch to .../sd-card/sd-image-armv7l-multiplatform-installer.nix, instead. '' ]; }; diff --git a/nixos/modules/installer/cd-dvd/sd-image-raspberrypi.nix b/nixos/modules/installer/cd-dvd/sd-image-raspberrypi.nix index 747440ba9c619b..b870d3a8b24e1d 100644 --- a/nixos/modules/installer/cd-dvd/sd-image-raspberrypi.nix +++ b/nixos/modules/installer/cd-dvd/sd-image-raspberrypi.nix @@ -6,8 +6,8 @@ config = { warnings = [ '' - .../cd-dvd/sd-image-raspberrypi.nix is deprecated and will eventually be removed. - Please switch to .../sd-card/sd-image-raspberrypi-installer.nix, instead. + .../cd-dvd/sd-image-raspberrypi.nix is deprecated and will eventually be removed. + Please switch to .../sd-card/sd-image-raspberrypi-installer.nix, instead. '' ]; }; diff --git a/nixos/modules/installer/cd-dvd/sd-image.nix b/nixos/modules/installer/cd-dvd/sd-image.nix index e2d6dcb3fe3ad7..8f8efff4d41dc7 100644 --- a/nixos/modules/installer/cd-dvd/sd-image.nix +++ b/nixos/modules/installer/cd-dvd/sd-image.nix @@ -6,8 +6,8 @@ config = { warnings = [ '' - .../cd-dvd/sd-image.nix is deprecated and will eventually be removed. - Please switch to .../sd-card/sd-image.nix, instead. + .../cd-dvd/sd-image.nix is deprecated and will eventually be removed. + Please switch to .../sd-card/sd-image.nix, instead. '' ]; }; diff --git a/nixos/modules/installer/netboot/netboot-base.nix b/nixos/modules/installer/netboot/netboot-base.nix index 7e66a49c739194..b969d2de6b675a 100644 --- a/nixos/modules/installer/netboot/netboot-base.nix +++ b/nixos/modules/installer/netboot/netboot-base.nix @@ -6,12 +6,12 @@ with lib; { - imports = - [ ./netboot.nix + imports = [ + ./netboot.nix - # Profiles of this basic netboot media - ../../profiles/all-hardware.nix - ../../profiles/base.nix - ../../profiles/installation-device.nix - ]; + # Profiles of this basic netboot media + ../../profiles/all-hardware.nix + ../../profiles/base.nix + ../../profiles/installation-device.nix + ]; } diff --git a/nixos/modules/installer/netboot/netboot-minimal.nix b/nixos/modules/installer/netboot/netboot-minimal.nix index 5ca255acf35f48..dc881a3369973f 100644 --- a/nixos/modules/installer/netboot/netboot-minimal.nix +++ b/nixos/modules/installer/netboot/netboot-minimal.nix @@ -10,6 +10,6 @@ documentation.man.enable = lib.mkOverride 500 true; hardware.enableRedistributableFirmware = lib.mkOverride 70 false; - system.extraDependencies = lib.mkOverride 70 []; + system.extraDependencies = lib.mkOverride 70 [ ]; networking.wireless.enable = lib.mkOverride 500 false; } diff --git a/nixos/modules/installer/sd-card/sd-image-armv7l-multiplatform.nix b/nixos/modules/installer/sd-card/sd-image-armv7l-multiplatform.nix index 23ed928512966a..1fa88ad280efd7 100644 --- a/nixos/modules/installer/sd-card/sd-image-armv7l-multiplatform.nix +++ b/nixos/modules/installer/sd-card/sd-image-armv7l-multiplatform.nix @@ -1,6 +1,11 @@ # To build, use: # nix-build nixos -I nixos-config=nixos/modules/installer/sd-card/sd-image-armv7l-multiplatform.nix -A config.system.build.sdImage -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { imports = [ @@ -19,26 +24,35 @@ # - ttyAMA0: for Allwinner (pcDuino3 Nano) and QEMU's -machine virt # - ttyO0: for OMAP (BeagleBone Black) # - ttySAC2: for Exynos (ODROID-XU3) - boot.kernelParams = ["console=ttyS0,115200n8" "console=ttymxc0,115200n8" "console=ttyAMA0,115200n8" "console=ttyO0,115200n8" "console=ttySAC2,115200n8" "console=tty0"]; + boot.kernelParams = [ + "console=ttyS0,115200n8" + "console=ttymxc0,115200n8" + "console=ttyAMA0,115200n8" + "console=ttyO0,115200n8" + "console=ttySAC2,115200n8" + "console=tty0" + ]; sdImage = { - populateFirmwareCommands = let - configTxt = pkgs.writeText "config.txt" '' - # Prevent the firmware from smashing the framebuffer setup done by the mainline kernel - # when attempting to show low-voltage or overtemperature warnings. - avoid_warnings=1 + populateFirmwareCommands = + let + configTxt = pkgs.writeText "config.txt" '' + # Prevent the firmware from smashing the framebuffer setup done by the mainline kernel + # when attempting to show low-voltage or overtemperature warnings. + avoid_warnings=1 - [pi2] - kernel=u-boot-rpi2.bin + [pi2] + kernel=u-boot-rpi2.bin - [pi3] - kernel=u-boot-rpi3.bin + [pi3] + kernel=u-boot-rpi3.bin - # U-Boot used to need this to work, regardless of whether UART is actually used or not. - # TODO: check when/if this can be removed. - enable_uart=1 - ''; - in '' + # U-Boot used to need this to work, regardless of whether UART is actually used or not. + # TODO: check when/if this can be removed. + enable_uart=1 + ''; + in + '' (cd ${pkgs.raspberrypifw}/share/raspberrypi/boot && cp bootcode.bin fixup*.dat start*.elf $NIX_BUILD_TOP/firmware/) cp ${pkgs.ubootRaspberryPi2}/u-boot.bin firmware/u-boot-rpi2.bin cp ${pkgs.ubootRaspberryPi3_32bit}/u-boot.bin firmware/u-boot-rpi3.bin diff --git a/nixos/modules/installer/sd-card/sd-image-powerpc64le.nix b/nixos/modules/installer/sd-card/sd-image-powerpc64le.nix index 143c678e43fbc7..549bd21f6b08fb 100644 --- a/nixos/modules/installer/sd-card/sd-image-powerpc64le.nix +++ b/nixos/modules/installer/sd-card/sd-image-powerpc64le.nix @@ -1,6 +1,11 @@ # To build, use: # nix-build nixos -I nixos-config=nixos/modules/installer/sd-card/sd-image-powerpc64le.nix -A config.system.build.sdImage -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { imports = [ @@ -25,25 +30,26 @@ sdImage = { populateFirmwareCommands = ""; - populateRootCommands = '' - mkdir -p ./files/boot - ${config.boot.loader.generic-extlinux-compatible.populateCmd} \ - -c ${config.system.build.toplevel} \ - -d ./files/boot - '' - # https://github.com/open-power/petitboot/blob/master/discover/syslinux-parser.c - # petitboot will look in these paths (plus all-caps versions of them): - # /boot/syslinux/syslinux.cfg - # /syslinux/syslinux.cfg - # /syslinux.cfg - + '' - mv ./files/boot/extlinux ./files/boot/syslinux - mv ./files/boot/syslinux/extlinux.conf ./files/boot/syslinux/syslinux.cfg - '' - # petitboot does not support relative paths for LINUX or INITRD; it prepends - # a `/` when parsing these fields - + '' - sed -i 's_^\(\W\W*\(INITRD\|initrd\|LINUX\|linux\)\W\)\.\./_\1/boot/_' ./files/boot/syslinux/syslinux.cfg - ''; + populateRootCommands = + '' + mkdir -p ./files/boot + ${config.boot.loader.generic-extlinux-compatible.populateCmd} \ + -c ${config.system.build.toplevel} \ + -d ./files/boot + '' + # https://github.com/open-power/petitboot/blob/master/discover/syslinux-parser.c + # petitboot will look in these paths (plus all-caps versions of them): + # /boot/syslinux/syslinux.cfg + # /syslinux/syslinux.cfg + # /syslinux.cfg + + '' + mv ./files/boot/extlinux ./files/boot/syslinux + mv ./files/boot/syslinux/extlinux.conf ./files/boot/syslinux/syslinux.cfg + '' + # petitboot does not support relative paths for LINUX or INITRD; it prepends + # a `/` when parsing these fields + + '' + sed -i 's_^\(\W\W*\(INITRD\|initrd\|LINUX\|linux\)\W\)\.\./_\1/boot/_' ./files/boot/syslinux/syslinux.cfg + ''; }; } diff --git a/nixos/modules/installer/sd-card/sd-image-raspberrypi.nix b/nixos/modules/installer/sd-card/sd-image-raspberrypi.nix index 0e6eb251091c0b..dcb3fcf79ba718 100644 --- a/nixos/modules/installer/sd-card/sd-image-raspberrypi.nix +++ b/nixos/modules/installer/sd-card/sd-image-raspberrypi.nix @@ -1,6 +1,11 @@ # To build, use: # nix-build nixos -I nixos-config=nixos/modules/installer/sd-card/sd-image-raspberrypi.nix -A config.system.build.sdImage -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { imports = [ @@ -15,23 +20,25 @@ boot.kernelPackages = pkgs.linuxKernel.packages.linux_rpi1; sdImage = { - populateFirmwareCommands = let - configTxt = pkgs.writeText "config.txt" '' - # u-boot refuses to start (gets stuck at rainbow polygon) without this, - # at least on Raspberry Pi 0. - enable_uart=1 + populateFirmwareCommands = + let + configTxt = pkgs.writeText "config.txt" '' + # u-boot refuses to start (gets stuck at rainbow polygon) without this, + # at least on Raspberry Pi 0. + enable_uart=1 - # Prevent the firmware from smashing the framebuffer setup done by the mainline kernel - # when attempting to show low-voltage or overtemperature warnings. - avoid_warnings=1 + # Prevent the firmware from smashing the framebuffer setup done by the mainline kernel + # when attempting to show low-voltage or overtemperature warnings. + avoid_warnings=1 - [pi0] - kernel=u-boot-rpi0.bin + [pi0] + kernel=u-boot-rpi0.bin - [pi1] - kernel=u-boot-rpi1.bin - ''; - in '' + [pi1] + kernel=u-boot-rpi1.bin + ''; + in + '' (cd ${pkgs.raspberrypifw}/share/raspberrypi/boot && cp bootcode.bin fixup*.dat start*.elf *.dtb $NIX_BUILD_TOP/firmware/) cp ${pkgs.ubootRaspberryPiZero}/u-boot.bin firmware/u-boot-rpi0.bin cp ${pkgs.ubootRaspberryPi}/u-boot.bin firmware/u-boot-rpi1.bin diff --git a/nixos/modules/installer/sd-card/sd-image-riscv64-qemu.nix b/nixos/modules/installer/sd-card/sd-image-riscv64-qemu.nix index a3e30768da4564..e4bfa7591b6295 100644 --- a/nixos/modules/installer/sd-card/sd-image-riscv64-qemu.nix +++ b/nixos/modules/installer/sd-card/sd-image-riscv64-qemu.nix @@ -1,6 +1,11 @@ # To build, use: # nix-build nixos -I nixos-config=nixos/modules/installer/sd-card/sd-image-riscv64-qemu.nix -A config.system.build.sdImage -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { imports = [ @@ -20,7 +25,10 @@ }; boot.consoleLogLevel = lib.mkDefault 7; - boot.kernelParams = [ "console=tty0" "console=ttyS0,115200n8" ]; + boot.kernelParams = [ + "console=tty0" + "console=ttyS0,115200n8" + ]; sdImage = { populateFirmwareCommands = ""; diff --git a/nixos/modules/installer/sd-card/sd-image-x86_64.nix b/nixos/modules/installer/sd-card/sd-image-x86_64.nix index b44c0a4eeca5ee..731ab0fa88a423 100644 --- a/nixos/modules/installer/sd-card/sd-image-x86_64.nix +++ b/nixos/modules/installer/sd-card/sd-image-x86_64.nix @@ -2,7 +2,12 @@ # nix-build nixos -I nixos-config=nixos/modules/installer/sd-card/sd-image-x86_64.nix -A config.system.build.sdImage # This image is primarily used in NixOS tests (boot.nix) to test `boot.loader.generic-extlinux-compatible`. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { imports = [ diff --git a/nixos/modules/misc/assertions.nix b/nixos/modules/misc/assertions.nix index 489a2b8085aef8..5853f64329c1e4 100644 --- a/nixos/modules/misc/assertions.nix +++ b/nixos/modules/misc/assertions.nix @@ -6,8 +6,13 @@ assertions = lib.mkOption { type = lib.types.listOf lib.types.unspecified; internal = true; - default = []; - example = [ { assertion = false; message = "you can't enable this for that reason"; } ]; + default = [ ]; + example = [ + { + assertion = false; + message = "you can't enable this for that reason"; + } + ]; description = '' This option allows modules to express conditions that must hold for the evaluation of the system configuration to @@ -17,7 +22,7 @@ warnings = lib.mkOption { internal = true; - default = []; + default = [ ]; type = lib.types.listOf lib.types.str; example = [ "The `foo' service is deprecated and will go away soon!" ]; description = '' diff --git a/nixos/modules/misc/crashdump.nix b/nixos/modules/misc/crashdump.nix index 28e764bffc7918..2582fde5246c69 100644 --- a/nixos/modules/misc/crashdump.nix +++ b/nixos/modules/misc/crashdump.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let crashdump = config.boot.crashDump; @@ -32,7 +37,10 @@ in }; kernelParams = lib.mkOption { type = lib.types.listOf lib.types.str; - default = [ "1" "boot.shell_on_fail" ]; + default = [ + "1" + "boot.shell_on_fail" + ]; description = '' Parameters that will be passed to the kernel kexec-ed on crash. ''; @@ -41,7 +49,7 @@ in }; }; -###### implementation + ###### implementation config = lib.mkIf crashdump.enable { boot = { @@ -53,9 +61,9 @@ in --command-line="init=$(readlink -f /run/current-system/init) irqpoll maxcpus=1 reset_devices ${kernelParams}" ''; kernelParams = [ - "crashkernel=${crashdump.reservedMemory}" - "nmi_watchdog=panic" - "softlockup_panic=1" + "crashkernel=${crashdump.reservedMemory}" + "nmi_watchdog=panic" + "softlockup_panic=1" ]; }; }; diff --git a/nixos/modules/misc/documentation/test.nix b/nixos/modules/misc/documentation/test.nix index 1eaa63b1fb6ca1..dcbbdcb54e818b 100644 --- a/nixos/modules/misc/documentation/test.nix +++ b/nixos/modules/misc/documentation/test.nix @@ -1,4 +1,8 @@ -{ nixosLib, pkgsModule, runCommand }: +{ + nixosLib, + pkgsModule, + runCommand, +}: let sys = nixosLib.evalModules rec { @@ -7,13 +11,16 @@ let ../documentation.nix ../version.nix - ({ lib, someArg, ... }: { - # Make sure imports from specialArgs are respected - imports = [ someArg.myModule ]; + ( + { lib, someArg, ... }: + { + # Make sure imports from specialArgs are respected + imports = [ someArg.myModule ]; - # TODO test this - meta.doc = ./test-dummy.chapter.xml; - }) + # TODO test this + meta.doc = ./test-dummy.chapter.xml; + } + ) { _module.args = { @@ -27,23 +34,26 @@ let documentation.nixos.includeAllModules = true; } ]; - specialArgs.someArg.myModule = { lib, ... }: { - options.foobar = lib.mkOption { - type = lib.types.str; - description = "The foobar option was added via specialArgs"; - default = "qux"; + specialArgs.someArg.myModule = + { lib, ... }: + { + options.foobar = lib.mkOption { + type = lib.types.str; + description = "The foobar option was added via specialArgs"; + default = "qux"; + }; }; - }; }; in runCommand "documentation-check" -{ - inherit (sys.config.system.build.manual) optionsJSON; -} '' - json="$optionsJSON/share/doc/nixos/options.json" - echo checking $json + { + inherit (sys.config.system.build.manual) optionsJSON; + } + '' + json="$optionsJSON/share/doc/nixos/options.json" + echo checking $json - grep 'The foobar option was added via specialArgs' <"$json" >/dev/null - touch $out -'' + grep 'The foobar option was added via specialArgs' <"$json" >/dev/null + touch $out + '' diff --git a/nixos/modules/misc/extra-arguments.nix b/nixos/modules/misc/extra-arguments.nix index 48891b4404986a..a64b885185385e 100644 --- a/nixos/modules/misc/extra-arguments.nix +++ b/nixos/modules/misc/extra-arguments.nix @@ -1,4 +1,9 @@ -{ lib, config, pkgs, ... }: +{ + lib, + config, + pkgs, + ... +}: { _module.args = { diff --git a/nixos/modules/misc/label.nix b/nixos/modules/misc/label.nix index aba5ae23dc3951..3c4c84057dcd46 100644 --- a/nixos/modules/misc/label.nix +++ b/nixos/modules/misc/label.nix @@ -42,7 +42,7 @@ in nixos.tags = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = [ "with-xen" ]; description = '' Strings to prefix to the default @@ -65,9 +65,13 @@ in config = { # This is set here rather than up there so that changing it would # not rebuild the manual - system.nixos.label = lib.mkDefault (lib.maybeEnv "NIXOS_LABEL" - (lib.concatStringsSep "-" ((lib.sort (x: y: x < y) cfg.tags) - ++ [ (lib.maybeEnv "NIXOS_LABEL_VERSION" cfg.version) ]))); + system.nixos.label = lib.mkDefault ( + lib.maybeEnv "NIXOS_LABEL" ( + lib.concatStringsSep "-" ( + (lib.sort (x: y: x < y) cfg.tags) ++ [ (lib.maybeEnv "NIXOS_LABEL_VERSION" cfg.version) ] + ) + ) + ); }; } diff --git a/nixos/modules/misc/lib.nix b/nixos/modules/misc/lib.nix index 121f396701eae5..e50794ccc5ac6c 100644 --- a/nixos/modules/misc/lib.nix +++ b/nixos/modules/misc/lib.nix @@ -3,7 +3,7 @@ { options = { lib = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.attrs; diff --git a/nixos/modules/misc/locate.nix b/nixos/modules/misc/locate.nix index 0d731dfbaebc60..5b57463bff6e45 100644 --- a/nixos/modules/misc/locate.nix +++ b/nixos/modules/misc/locate.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.locate; @@ -175,7 +180,13 @@ in pruneNames = lib.mkOption { type = lib.types.listOf lib.types.str; - default = lib.optionals (!isFindutils) [ ".bzr" ".cache" ".git" ".hg" ".svn" ]; + default = lib.optionals (!isFindutils) [ + ".bzr" + ".cache" + ".git" + ".hg" + ".svn" + ]; defaultText = lib.literalMD '' `[ ".bzr" ".cache" ".git" ".hg" ".svn" ]`, if supported by the locate implementation (i.e. mlocate or plocate). @@ -219,8 +230,17 @@ in }; in lib.mkIf isMorPLocate { - locate = lib.mkMerge [ common mlocate plocate ]; - plocate = lib.mkIf isPLocate (lib.mkMerge [ common plocate ]); + locate = lib.mkMerge [ + common + mlocate + plocate + ]; + plocate = lib.mkIf isPLocate ( + lib.mkMerge [ + common + plocate + ] + ); }; environment = { @@ -239,12 +259,15 @@ in }; }; - warnings = lib.optional (isMorPLocate && cfg.localuser != null) - "mlocate and plocate do not support the services.locate.localuser option. updatedb will run as root. Silence this warning by setting services.locate.localuser = null." - ++ lib.optional (isFindutils && cfg.pruneNames != [ ]) - "findutils locate does not support pruning by directory component" - ++ lib.optional (isFindutils && cfg.pruneBindMounts) - "findutils locate does not support skipping bind mounts"; + warnings = + lib.optional (isMorPLocate && cfg.localuser != null) + "mlocate and plocate do not support the services.locate.localuser option. updatedb will run as root. Silence this warning by setting services.locate.localuser = null." + ++ lib.optional ( + isFindutils && cfg.pruneNames != [ ] + ) "findutils locate does not support pruning by directory component" + ++ lib.optional ( + isFindutils && cfg.pruneBindMounts + ) "findutils locate does not support skipping bind mounts"; systemd.services.update-locatedb = { description = "Update Locate Database"; @@ -255,10 +278,15 @@ in script = if isMorPLocate then let - toFlags = x: - lib.optional (cfg.${x} != [ ]) - "--${lib.toLower x} '${lib.concatStringsSep " " cfg.${x}}'"; - args = lib.concatLists (map toFlags [ "pruneFS" "pruneNames" "prunePaths" ]); + toFlags = + x: lib.optional (cfg.${x} != [ ]) "--${lib.toLower x} '${lib.concatStringsSep " " cfg.${x}}'"; + args = lib.concatLists ( + map toFlags [ + "pruneFS" + "pruneNames" + "prunePaths" + ] + ); in '' exec ${cfg.package}/bin/updatedb \ @@ -266,11 +294,12 @@ in --prune-bind-mounts ${if cfg.pruneBindMounts then "yes" else "no"} \ ${lib.concatStringsSep " " cfg.extraFlags} '' - else '' - exec ${cfg.package}/bin/updatedb \ - ${lib.optionalString (cfg.localuser != null && !isMorPLocate) "--localuser=${cfg.localuser}"} \ - --output=${toString cfg.output} ${lib.concatStringsSep " " cfg.extraFlags} - ''; + else + '' + exec ${cfg.package}/bin/updatedb \ + ${lib.optionalString (cfg.localuser != null && !isMorPLocate) "--localuser=${cfg.localuser}"} \ + --output=${toString cfg.output} ${lib.concatStringsSep " " cfg.extraFlags} + ''; environment = lib.optionalAttrs (!isMorPLocate) { PRUNEFS = lib.concatStringsSep " " cfg.pruneFS; PRUNEPATHS = lib.concatStringsSep " " cfg.prunePaths; diff --git a/nixos/modules/misc/man-db.nix b/nixos/modules/misc/man-db.nix index d557b5e20b0f27..56b935c975976e 100644 --- a/nixos/modules/misc/man-db.nix +++ b/nixos/modules/misc/man-db.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.documentation.man.man-db; @@ -15,7 +20,7 @@ in skipPackages = lib.mkOption { type = lib.types.listOf lib.types.package; - default = []; + default = [ ]; internal = true; description = '' Packages to *not* include in the man-db. @@ -29,8 +34,7 @@ in name = "man-paths"; paths = lib.subtractLists cfg.skipPackages config.environment.systemPackages; pathsToLink = [ "/share/man" ]; - extraOutputsToInstall = [ "man" ] - ++ lib.optionals config.documentation.dev.enable [ "devman" ]; + extraOutputsToInstall = [ "man" ] ++ lib.optionals config.documentation.dev.enable [ "devman" ]; ignoreCollisions = true; }; defaultText = lib.literalMD "all man pages in {option}`config.environment.systemPackages`"; @@ -55,19 +59,25 @@ in }; imports = [ - (lib.mkRenamedOptionModule [ "documentation" "man" "manualPages" ] [ "documentation" "man" "man-db" "manualPages" ]) + (lib.mkRenamedOptionModule + [ "documentation" "man" "manualPages" ] + [ "documentation" "man" "man-db" "manualPages" ] + ) ]; config = lib.mkIf cfg.enable { environment.systemPackages = [ cfg.package ]; environment.etc."man_db.conf".text = let - manualCache = pkgs.runCommand "man-cache" { - nativeBuildInputs = [ cfg.package ]; - } '' - echo "MANDB_MAP ${cfg.manualPages}/share/man $out" > man.conf - mandb -C man.conf -psc >/dev/null 2>&1 - ''; + manualCache = + pkgs.runCommand "man-cache" + { + nativeBuildInputs = [ cfg.package ]; + } + '' + echo "MANDB_MAP ${cfg.manualPages}/share/man $out" > man.conf + mandb -C man.conf -psc >/dev/null 2>&1 + ''; in '' # Manual pages paths for NixOS @@ -75,8 +85,8 @@ in MANPATH_MAP /run/wrappers/bin /run/current-system/sw/share/man ${lib.optionalString config.documentation.man.generateCaches '' - # Generated manual pages cache for NixOS (immutable) - MANDB_MAP /run/current-system/sw/share/man ${manualCache} + # Generated manual pages cache for NixOS (immutable) + MANDB_MAP /run/current-system/sw/share/man ${manualCache} ''} # Manual pages caches for NixOS MANDB_MAP /run/current-system/sw/share/man /var/cache/man/nixos diff --git a/nixos/modules/misc/mandoc.nix b/nixos/modules/misc/mandoc.nix index 166693930b5c7c..b459b28dad4980 100644 --- a/nixos/modules/misc/mandoc.nix +++ b/nixos/modules/misc/mandoc.nix @@ -1,22 +1,30 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let makewhatis = "${lib.getBin cfg.package}/bin/makewhatis"; cfg = config.documentation.man.mandoc; - toMandocOutput = output: ( - lib.mapAttrsToList - ( - name: value: - if lib.isString value || lib.isPath value then "output ${name} ${value}" - else if lib.isInt value then "output ${name} ${builtins.toString value}" - else if lib.isBool value then lib.optionalString value "output ${name}" - else if value == null then "" - else throw "Unrecognized value type ${builtins.typeOf value} of key ${name} in mandoc output settings" - ) - output - ); + toMandocOutput = + output: + (lib.mapAttrsToList ( + name: value: + if lib.isString value || lib.isPath value then + "output ${name} ${value}" + else if lib.isInt value then + "output ${name} ${builtins.toString value}" + else if lib.isBool value then + lib.optionalString value "output ${name}" + else if value == null then + "" + else + throw "Unrecognized value type ${builtins.typeOf value} of key ${name} in mandoc output settings" + ) output); makeLeadingSlashes = map (path: if builtins.substring 0 1 path != "/" then "/${path}" else path); in @@ -208,7 +216,9 @@ in # TODO(@sternenseemman): fix symlinked directories not getting indexed, # see: https://inbox.vuxu.org/mandoc-tech/20210906171231.GF83680@athene.usta.de/T/#e85f773c1781e3fef85562b2794f9cad7b2909a3c extraSetup = lib.mkIf config.documentation.man.generateCaches '' - for man_path in ${lib.concatMapStringsSep " " (path: "$out" + lib.escapeShellArg path) cfg.cachePath} + for man_path in ${ + lib.concatMapStringsSep " " (path: "$out" + lib.escapeShellArg path) cfg.cachePath + } do [[ -d "$man_path" ]] && ${makewhatis} -T utf8 $man_path done diff --git a/nixos/modules/misc/meta.nix b/nixos/modules/misc/meta.nix index 1569662b403cf8..1e75a84452f812 100644 --- a/nixos/modules/misc/meta.nix +++ b/nixos/modules/misc/meta.nix @@ -3,7 +3,9 @@ let maintainer = lib.mkOptionType { name = "maintainer"; check = email: lib.elem email (lib.attrValues lib.maintainers); - merge = loc: defs: lib.listToAttrs (lib.singleton (lib.nameValuePair (lib.last defs).file (lib.last defs).value)); + merge = + loc: defs: + lib.listToAttrs (lib.singleton (lib.nameValuePair (lib.last defs).file (lib.last defs).value)); }; listOfMaintainers = lib.types.listOf maintainer // { @@ -12,11 +14,24 @@ let # "maintainer1 " # "maintainer2 " ]; # } - merge = loc: defs: - lib.zipAttrs - (lib.flatten (lib.imap1 (n: def: lib.imap1 (m: def': - maintainer.merge (loc ++ ["[${toString n}-${toString m}]"]) - [{ inherit (def) file; value = def'; }]) def.value) defs)); + merge = + loc: defs: + lib.zipAttrs ( + lib.flatten ( + lib.imap1 ( + n: def: + lib.imap1 ( + m: def': + maintainer.merge (loc ++ [ "[${toString n}-${toString m}]" ]) [ + { + inherit (def) file; + value = def'; + } + ] + ) def.value + ) defs + ) + ); }; docFile = lib.types.path // { @@ -33,7 +48,7 @@ in maintainers = lib.mkOption { type = listOfMaintainers; internal = true; - default = []; + default = [ ]; example = lib.literalExpression ''[ lib.maintainers.all ]''; description = '' List of maintainers of each module. This option should be defined at diff --git a/nixos/modules/misc/nixops-autoluks.nix b/nixos/modules/misc/nixops-autoluks.nix index 9b5a376027f52d..953fea7f38bca7 100644 --- a/nixos/modules/misc/nixops-autoluks.nix +++ b/nixos/modules/misc/nixops-autoluks.nix @@ -1,10 +1,19 @@ -{ config, options, lib, ... }: +{ + config, + options, + lib, + ... +}: let - path = [ "deployment" "autoLuks" ]; - hasAutoLuksConfig = lib.hasAttrByPath path config && (lib.attrByPath path {} config) != {}; + path = [ + "deployment" + "autoLuks" + ]; + hasAutoLuksConfig = lib.hasAttrByPath path config && (lib.attrByPath path { } config) != { }; inherit (config.nixops) enableDeprecatedAutoLuks; -in { +in +{ options.nixops.enableDeprecatedAutoLuks = lib.mkEnableOption "the deprecated NixOps AutoLuks module"; config = { diff --git a/nixos/modules/misc/nixpkgs-flake.nix b/nixos/modules/misc/nixpkgs-flake.nix index 4c91d5e604f260..912f7a11fa3678 100644 --- a/nixos/modules/misc/nixpkgs-flake.nix +++ b/nixos/modules/misc/nixpkgs-flake.nix @@ -1,4 +1,10 @@ -{ config, options, lib, pkgs, ... }: +{ + config, + options, + lib, + pkgs, + ... +}: let cfg = config.nixpkgs.flake; in @@ -72,31 +78,35 @@ in }; }; - config = lib.mkIf (cfg.source != null) (lib.mkMerge [ - { - assertions = [ - { - assertion = cfg.setNixPath -> cfg.setFlakeRegistry; - message = '' - Setting `nixpkgs.flake.setNixPath` requires that `nixpkgs.flake.setFlakeRegistry` also - be set, since it is implemented in terms of indirection through the flake registry. - ''; - } - ]; - } - (lib.mkIf cfg.setFlakeRegistry { - nix.registry.nixpkgs.to = lib.mkDefault { - type = "path"; - path = cfg.source; - }; - }) - (lib.mkIf cfg.setNixPath { - # N.B. This does not include nixos-config in NIX_PATH unlike modules/config/nix-channel.nix - # because we would need some kind of evil shim taking the *calling* flake's self path, - # perhaps, to ever make that work (in order to know where the Nix expr for the system came - # from and how to call it). - nix.nixPath = lib.mkDefault ([ "nixpkgs=flake:nixpkgs" ] - ++ lib.optional config.nix.channel.enable "/nix/var/nix/profiles/per-user/root/channels"); - }) - ]); + config = lib.mkIf (cfg.source != null) ( + lib.mkMerge [ + { + assertions = [ + { + assertion = cfg.setNixPath -> cfg.setFlakeRegistry; + message = '' + Setting `nixpkgs.flake.setNixPath` requires that `nixpkgs.flake.setFlakeRegistry` also + be set, since it is implemented in terms of indirection through the flake registry. + ''; + } + ]; + } + (lib.mkIf cfg.setFlakeRegistry { + nix.registry.nixpkgs.to = lib.mkDefault { + type = "path"; + path = cfg.source; + }; + }) + (lib.mkIf cfg.setNixPath { + # N.B. This does not include nixos-config in NIX_PATH unlike modules/config/nix-channel.nix + # because we would need some kind of evil shim taking the *calling* flake's self path, + # perhaps, to ever make that work (in order to know where the Nix expr for the system came + # from and how to call it). + nix.nixPath = lib.mkDefault ( + [ "nixpkgs=flake:nixpkgs" ] + ++ lib.optional config.nix.channel.enable "/nix/var/nix/profiles/per-user/root/channels" + ); + }) + ] + ); } diff --git a/nixos/modules/misc/nixpkgs.nix b/nixos/modules/misc/nixpkgs.nix index 4048fd68573780..e1c705eef3b5a2 100644 --- a/nixos/modules/misc/nixpkgs.nix +++ b/nixos/modules/misc/nixpkgs.nix @@ -1,42 +1,47 @@ -{ config, options, lib, pkgs, ... }: +{ + config, + options, + lib, + pkgs, + ... +}: let cfg = config.nixpkgs; opt = options.nixpkgs; - isConfig = x: - builtins.isAttrs x || lib.isFunction x; + isConfig = x: builtins.isAttrs x || lib.isFunction x; - optCall = f: x: - if lib.isFunction f - then f x - else f; + optCall = f: x: if lib.isFunction f then f x else f; - mergeConfig = lhs_: rhs_: + mergeConfig = + lhs_: rhs_: let lhs = optCall lhs_ { inherit pkgs; }; rhs = optCall rhs_ { inherit pkgs; }; in - lib.recursiveUpdate lhs rhs // - lib.optionalAttrs (lhs ? packageOverrides) { - packageOverrides = pkgs: - optCall lhs.packageOverrides pkgs // - optCall (lib.attrByPath [ "packageOverrides" ] { } rhs) pkgs; - } // - lib.optionalAttrs (lhs ? perlPackageOverrides) { - perlPackageOverrides = pkgs: - optCall lhs.perlPackageOverrides pkgs // - optCall (lib.attrByPath [ "perlPackageOverrides" ] { } rhs) pkgs; + lib.recursiveUpdate lhs rhs + // lib.optionalAttrs (lhs ? packageOverrides) { + packageOverrides = + pkgs: + optCall lhs.packageOverrides pkgs // optCall (lib.attrByPath [ "packageOverrides" ] { } rhs) pkgs; + } + // lib.optionalAttrs (lhs ? perlPackageOverrides) { + perlPackageOverrides = + pkgs: + optCall lhs.perlPackageOverrides pkgs + // optCall (lib.attrByPath [ "perlPackageOverrides" ] { } rhs) pkgs; }; configType = lib.mkOptionType { name = "nixpkgs-config"; description = "nixpkgs config"; - check = x: - let traceXIfNot = c: - if c x then true - else lib.traceSeqN 1 x false; - in traceXIfNot isConfig; - merge = args: lib.foldr (def: mergeConfig def.value) {}; + check = + x: + let + traceXIfNot = c: if c x then true else lib.traceSeqN 1 x false; + in + traceXIfNot isConfig; + merge = args: lib.foldr (def: mergeConfig def.value) { }; }; overlayType = lib.mkOptionType { @@ -52,7 +57,7 @@ let description = "An evaluation of Nixpkgs; the top level attribute set of packages"; }; - hasBuildPlatform = opt.buildPlatform.highestPrio < (lib.mkOptionDefault {}).priority; + hasBuildPlatform = opt.buildPlatform.highestPrio < (lib.mkOptionDefault { }).priority; hasHostPlatform = opt.hostPlatform.isDefined; hasPlatform = hasHostPlatform || hasBuildPlatform; @@ -61,31 +66,39 @@ let buildPlatformLine = lib.optionalString hasBuildPlatform "${lib.showOptionWithDefLocs opt.buildPlatform}"; legacyOptionsDefined = - lib.optional (opt.localSystem.highestPrio < (lib.mkDefault {}).priority) opt.system - ++ lib.optional (opt.localSystem.highestPrio < (lib.mkOptionDefault {}).priority) opt.localSystem - ++ lib.optional (opt.crossSystem.highestPrio < (lib.mkOptionDefault {}).priority) opt.crossSystem - ; + lib.optional (opt.localSystem.highestPrio < (lib.mkDefault { }).priority) opt.system + ++ lib.optional (opt.localSystem.highestPrio < (lib.mkOptionDefault { }).priority) opt.localSystem + ++ lib.optional (opt.crossSystem.highestPrio < (lib.mkOptionDefault { }).priority) opt.crossSystem; defaultPkgs = - if opt.hostPlatform.isDefined - then - let isCross = cfg.buildPlatform != cfg.hostPlatform; - systemArgs = - if isCross - then { + if opt.hostPlatform.isDefined then + let + isCross = cfg.buildPlatform != cfg.hostPlatform; + systemArgs = + if isCross then + { localSystem = cfg.buildPlatform; crossSystem = cfg.hostPlatform; } - else { + else + { localSystem = cfg.hostPlatform; }; in - import ../../.. ({ - inherit (cfg) config overlays; - } // systemArgs) + import ../../.. ( + { + inherit (cfg) config overlays; + } + // systemArgs + ) else import ../../.. { - inherit (cfg) config overlays localSystem crossSystem; + inherit (cfg) + config + overlays + localSystem + crossSystem + ; }; finalPkgs = if opt.pkgs.isDefined then cfg.pkgs.appendOverlays cfg.overlays else defaultPkgs; @@ -96,7 +109,9 @@ in imports = [ ./assertions.nix ./meta.nix - (lib.mkRemovedOptionModule [ "nixpkgs" "initialSystem" ] "The NixOS options `nesting.clone` and `nesting.children` have been deleted, and replaced with named specialisation. Therefore `nixpgks.initialSystem` has no effect anymore.") + (lib.mkRemovedOptionModule [ "nixpkgs" "initialSystem" ] + "The NixOS options `nesting.clone` and `nesting.children` have been deleted, and replaced with named specialisation. Therefore `nixpgks.initialSystem` has no effect anymore." + ) ]; options.nixpkgs = { @@ -143,11 +158,10 @@ in }; config = lib.mkOption { - default = {}; - example = lib.literalExpression - '' - { allowBroken = true; allowUnfree = true; } - ''; + default = { }; + example = lib.literalExpression '' + { allowBroken = true; allowUnfree = true; } + ''; type = configType; description = '' Global configuration for Nixpkgs. @@ -158,18 +172,17 @@ in }; overlays = lib.mkOption { - default = []; - example = lib.literalExpression - '' - [ - (self: super: { - openssh = super.openssh.override { - hpnSupport = true; - kerberos = self.libkrb5; - }; - }) - ] - ''; + default = [ ]; + example = lib.literalExpression '' + [ + (self: super: { + openssh = super.openssh.override { + hpnSupport = true; + kerberos = self.libkrb5; + }; + }) + ] + ''; type = lib.types.listOf overlayType; description = '' List of overlays to apply to Nixpkgs. @@ -183,12 +196,13 @@ in hostPlatform = lib.mkOption { type = lib.types.either lib.types.str lib.types.attrs; # TODO utilize lib.systems.parsedPlatform - example = { system = "aarch64-linux"; }; + example = { + system = "aarch64-linux"; + }; # Make sure that the final value has all fields for sake of other modules # referring to this. TODO make `lib.systems` itself use the module system. apply = lib.systems.elaborate; - defaultText = lib.literalExpression - ''(import "''${nixos}/../lib").lib.systems.examples.aarch64-multiplatform''; + defaultText = lib.literalExpression ''(import "''${nixos}/../lib").lib.systems.examples.aarch64-multiplatform''; description = '' Specifies the platform where the NixOS configuration will run. @@ -201,16 +215,21 @@ in buildPlatform = lib.mkOption { type = lib.types.either lib.types.str lib.types.attrs; # TODO utilize lib.systems.parsedPlatform default = cfg.hostPlatform; - example = { system = "x86_64-linux"; }; + example = { + system = "x86_64-linux"; + }; # Make sure that the final value has all fields for sake of other modules # referring to this. - apply = inputBuildPlatform: - let elaborated = lib.systems.elaborate inputBuildPlatform; - in if lib.systems.equals elaborated cfg.hostPlatform - then cfg.hostPlatform # make identical, so that `==` equality works; see https://github.com/NixOS/nixpkgs/issues/278001 - else elaborated; - defaultText = lib.literalExpression - ''config.nixpkgs.hostPlatform''; + apply = + inputBuildPlatform: + let + elaborated = lib.systems.elaborate inputBuildPlatform; + in + if lib.systems.equals elaborated cfg.hostPlatform then + cfg.hostPlatform # make identical, so that `==` equality works; see https://github.com/NixOS/nixpkgs/issues/278001 + else + elaborated; + defaultText = lib.literalExpression ''config.nixpkgs.hostPlatform''; description = '' Specifies the platform on which NixOS should be built. By default, NixOS is built on the system where it runs, but you can @@ -228,12 +247,13 @@ in localSystem = lib.mkOption { type = lib.types.attrs; # TODO utilize lib.systems.parsedPlatform default = { inherit (cfg) system; }; - example = { system = "aarch64-linux"; }; + example = { + system = "aarch64-linux"; + }; # Make sure that the final value has all fields for sake of other modules # referring to this. TODO make `lib.systems` itself use the module system. apply = lib.systems.elaborate; - defaultText = lib.literalExpression - ''(import "''${nixos}/../lib").lib.systems.examples.aarch64-multiplatform''; + defaultText = lib.literalExpression ''(import "''${nixos}/../lib").lib.systems.examples.aarch64-multiplatform''; description = '' Systems with a recently generated `hardware-configuration.nix` do not need to specify this option, unless cross-compiling, in which case @@ -262,7 +282,9 @@ in crossSystem = lib.mkOption { type = lib.types.nullOr lib.types.attrs; # TODO utilize lib.systems.parsedPlatform default = null; - example = { system = "aarch64-linux"; }; + example = { + system = "aarch64-linux"; + }; description = '' Systems with a recently generated `hardware-configuration.nix` may instead specify *only* {option}`nixpkgs.buildPlatform`, @@ -284,8 +306,7 @@ in type = lib.types.str; example = "i686-linux"; default = - if opt.hostPlatform.isDefined - then + if opt.hostPlatform.isDefined then throw '' Neither ${opt.system} nor any other option in nixpkgs.* is meant to be read by modules and configurations. @@ -335,64 +356,67 @@ in # which is somewhat costly for Nixpkgs. With an explicit priority, we only # evaluate the wrapper to find out that the priority is lower, and then we # don't need to evaluate `finalPkgs`. - lib.mkOverride lib.modules.defaultOverridePriority - finalPkgs.__splicedPackages; + lib.mkOverride lib.modules.defaultOverridePriority finalPkgs.__splicedPackages; }; - assertions = let - # Whether `pkgs` was constructed by this module. This is false when any of - # nixpkgs.pkgs or _module.args.pkgs is set. - constructedByMe = - # We set it with default priority and it can not be merged, so if the - # pkgs module argument has that priority, it's from us. - (lib.modules.mergeAttrDefinitionsWithPrio options._module.args).pkgs.highestPrio + assertions = + let + # Whether `pkgs` was constructed by this module. This is false when any of + # nixpkgs.pkgs or _module.args.pkgs is set. + constructedByMe = + # We set it with default priority and it can not be merged, so if the + # pkgs module argument has that priority, it's from us. + (lib.modules.mergeAttrDefinitionsWithPrio options._module.args).pkgs.highestPrio == lib.modules.defaultOverridePriority - # Although, if nixpkgs.pkgs is set, we did forward it, but we did not construct it. + # Although, if nixpkgs.pkgs is set, we did forward it, but we did not construct it. && !opt.pkgs.isDefined; - in [ - ( - let - nixosExpectedSystem = - if config.nixpkgs.crossSystem != null - then config.nixpkgs.crossSystem.system or (lib.systems.parse.doubleFromSystem (lib.systems.parse.mkSystemFromString config.nixpkgs.crossSystem.config)) - else config.nixpkgs.localSystem.system or (lib.systems.parse.doubleFromSystem (lib.systems.parse.mkSystemFromString config.nixpkgs.localSystem.config)); - nixosOption = - if config.nixpkgs.crossSystem != null - then "nixpkgs.crossSystem" - else "nixpkgs.localSystem"; - pkgsSystem = finalPkgs.stdenv.targetPlatform.system; - in { - assertion = constructedByMe -> !hasPlatform -> nixosExpectedSystem == pkgsSystem; - message = "The NixOS nixpkgs.pkgs option was set to a Nixpkgs invocation that compiles to target system ${pkgsSystem} but NixOS was configured for system ${nixosExpectedSystem} via NixOS option ${nixosOption}. The NixOS system settings must match the Nixpkgs target system."; - } - ) - { - assertion = constructedByMe -> hasPlatform -> legacyOptionsDefined == []; - message = '' - Your system configures nixpkgs with the platform parameter${lib.optionalString hasBuildPlatform "s"}: - ${hostPlatformLine - }${buildPlatformLine + in + [ + ( + let + nixosExpectedSystem = + if config.nixpkgs.crossSystem != null then + config.nixpkgs.crossSystem.system or (lib.systems.parse.doubleFromSystem ( + lib.systems.parse.mkSystemFromString config.nixpkgs.crossSystem.config + )) + else + config.nixpkgs.localSystem.system or (lib.systems.parse.doubleFromSystem ( + lib.systems.parse.mkSystemFromString config.nixpkgs.localSystem.config + )); + nixosOption = + if config.nixpkgs.crossSystem != null then "nixpkgs.crossSystem" else "nixpkgs.localSystem"; + pkgsSystem = finalPkgs.stdenv.targetPlatform.system; + in + { + assertion = constructedByMe -> !hasPlatform -> nixosExpectedSystem == pkgsSystem; + message = "The NixOS nixpkgs.pkgs option was set to a Nixpkgs invocation that compiles to target system ${pkgsSystem} but NixOS was configured for system ${nixosExpectedSystem} via NixOS option ${nixosOption}. The NixOS system settings must match the Nixpkgs target system."; } - However, it also defines the legacy options: - ${lib.concatMapStrings lib.showOptionWithDefLocs legacyOptionsDefined} - For a future proof system configuration, we recommend to remove - the legacy definitions. - ''; - } - { - assertion = opt.pkgs.isDefined -> cfg.config == {}; - message = '' - Your system configures nixpkgs with an externally created instance. - `nixpkgs.config` options should be passed when creating the instance instead. - - Current value: - ${lib.generators.toPretty { multiline = true; } cfg.config} - - Defined in: - ${lib.concatMapStringsSep "\n" (file: " - ${file}") opt.config.files} - ''; - } - ]; + ) + { + assertion = constructedByMe -> hasPlatform -> legacyOptionsDefined == [ ]; + message = '' + Your system configures nixpkgs with the platform parameter${lib.optionalString hasBuildPlatform "s"}: + ${hostPlatformLine}${buildPlatformLine} + However, it also defines the legacy options: + ${lib.concatMapStrings lib.showOptionWithDefLocs legacyOptionsDefined} + For a future proof system configuration, we recommend to remove + the legacy definitions. + ''; + } + { + assertion = opt.pkgs.isDefined -> cfg.config == { }; + message = '' + Your system configures nixpkgs with an externally created instance. + `nixpkgs.config` options should be passed when creating the instance instead. + + Current value: + ${lib.generators.toPretty { multiline = true; } cfg.config} + + Defined in: + ${lib.concatMapStringsSep "\n" (file: " - ${file}") opt.config.files} + ''; + } + ]; }; # needs a full nixpkgs path to import nixpkgs diff --git a/nixos/modules/misc/nixpkgs/read-only.nix b/nixos/modules/misc/nixpkgs/read-only.nix index e3c4525e7db3c1..fa372d13e545c5 100644 --- a/nixos/modules/misc/nixpkgs/read-only.nix +++ b/nixos/modules/misc/nixpkgs/read-only.nix @@ -61,11 +61,9 @@ in config = { _module.args.pkgs = # find mistaken definitions - builtins.seq cfg.config - builtins.seq cfg.overlays - builtins.seq cfg.hostPlatform - builtins.seq cfg.buildPlatform - cfg.pkgs; + builtins.seq cfg.config builtins.seq cfg.overlays builtins.seq cfg.hostPlatform builtins.seq + cfg.buildPlatform + cfg.pkgs; nixpkgs.config = cfg.pkgs.config; nixpkgs.overlays = cfg.pkgs.overlays; nixpkgs.hostPlatform = cfg.pkgs.stdenv.hostPlatform; diff --git a/nixos/modules/misc/nixpkgs/test.nix b/nixos/modules/misc/nixpkgs/test.nix index e70b7a12e8dd75..1d4eff6a72cdb9 100644 --- a/nixos/modules/misc/nixpkgs/test.nix +++ b/nixos/modules/misc/nixpkgs/test.nix @@ -1,10 +1,20 @@ # [nixpkgs]$ nix-build -A nixosTests.nixpkgs --show-trace -{ evalMinimalConfig, pkgs, lib, stdenv }: +{ + evalMinimalConfig, + pkgs, + lib, + stdenv, +}: let - eval = mod: evalMinimalConfig { - imports = [ ../nixpkgs.nix mod ]; - }; + eval = + mod: + evalMinimalConfig { + imports = [ + ../nixpkgs.nix + mod + ]; + }; withHost = eval { nixpkgs.hostPlatform = "aarch64-linux"; }; @@ -29,15 +39,23 @@ let nixpkgs.localSystem.system = "x86_64-darwin"; nixpkgs.crossSystem.system = "i686-linux"; imports = [ - { _file = "repeat.nix"; + { + _file = "repeat.nix"; nixpkgs.hostPlatform = "aarch64-linux"; } ]; }; - getErrors = module: + getErrors = + module: let - uncheckedEval = lib.evalModules { modules = [ ../nixpkgs.nix module ]; }; - in map (ass: ass.message) (lib.filter (ass: !ass.assertion) uncheckedEval.config.assertions); + uncheckedEval = lib.evalModules { + modules = [ + ../nixpkgs.nix + module + ]; + }; + in + map (ass: ass.message) (lib.filter (ass: !ass.assertion) uncheckedEval.config.assertions); readOnlyUndefined = evalMinimalConfig { imports = [ ./read-only.nix ]; @@ -62,7 +80,7 @@ let readOnlyBadOverlays = evalMinimalConfig { imports = [ ./read-only.nix ]; nixpkgs.pkgs = pkgs; - nixpkgs.overlays = [ (_: _: {}) ]; # do in pkgs instead! + nixpkgs.overlays = [ (_: _: { }) ]; # do in pkgs instead! }; readOnlyBadHostPlatform = evalMinimalConfig { @@ -77,7 +95,7 @@ let nixpkgs.buildPlatform = "foo-linux"; # do in pkgs instead! }; - throws = x: ! (builtins.tryEval x).success; + throws = x: !(builtins.tryEval x).success; in lib.recurseIntoAttrs { @@ -90,11 +108,15 @@ lib.recurseIntoAttrs { assert withHost._module.args.pkgs.stdenv.buildPlatform.system == "aarch64-linux"; assert withHostAndBuild._module.args.pkgs.stdenv.hostPlatform.system == "aarch64-linux"; assert withHostAndBuild._module.args.pkgs.stdenv.buildPlatform.system == "aarch64-darwin"; - assert withSameHostAndBuild.config.nixpkgs.buildPlatform == withSameHostAndBuild.config.nixpkgs.hostPlatform; - assert withSameHostAndBuild._module.args.pkgs.stdenv.buildPlatform == withSameHostAndBuild._module.args.pkgs.stdenv.hostPlatform; - assert builtins.trace (lib.head (getErrors ambiguous)) - getErrors ambiguous == - ['' + assert + withSameHostAndBuild.config.nixpkgs.buildPlatform + == withSameHostAndBuild.config.nixpkgs.hostPlatform; + assert + withSameHostAndBuild._module.args.pkgs.stdenv.buildPlatform + == withSameHostAndBuild._module.args.pkgs.stdenv.hostPlatform; + assert + builtins.trace (lib.head (getErrors ambiguous)) getErrors ambiguous == [ + '' Your system configures nixpkgs with the platform parameters: nixpkgs.hostPlatform, with values defined in: - repeat.nix @@ -112,10 +134,11 @@ lib.recurseIntoAttrs { For a future proof system configuration, we recommend to remove the legacy definitions. - '']; - assert builtins.trace (lib.head (getErrors externalPkgsWithConfig)) - getErrors externalPkgsWithConfig == - ['' + '' + ]; + assert + builtins.trace (lib.head (getErrors externalPkgsWithConfig)) getErrors externalPkgsWithConfig == [ + '' Your system configures nixpkgs with an externally created instance. `nixpkgs.config` options should be passed when creating the instance instead. @@ -126,13 +149,14 @@ lib.recurseIntoAttrs { Defined in: - ext-pkgs-config.nix - '']; - assert getErrors { + '' + ]; + assert + getErrors { nixpkgs.localSystem = pkgs.stdenv.hostPlatform; nixpkgs.hostPlatform = pkgs.stdenv.hostPlatform; nixpkgs.pkgs = pkgs; - } == []; - + } == [ ]; # Tests for the read-only.nix module assert readOnly._module.args.pkgs.stdenv.hostPlatform.system == pkgs.stdenv.hostPlatform.system; @@ -145,9 +169,9 @@ lib.recurseIntoAttrs { # read-only.nix does not provide legacy options, for the sake of simplicity # If you're bothered by this, upgrade your configs to use the new *Platform # options. - assert !readOnly.options.nixpkgs?system; - assert !readOnly.options.nixpkgs?localSystem; - assert !readOnly.options.nixpkgs?crossSystem; + assert !readOnly.options.nixpkgs ? system; + assert !readOnly.options.nixpkgs ? localSystem; + assert !readOnly.options.nixpkgs ? crossSystem; pkgs.emptyFile; } diff --git a/nixos/modules/misc/version.nix b/nixos/modules/misc/version.nix index 2a982b254def10..6688ab9d1ca918 100644 --- a/nixos/modules/misc/version.nix +++ b/nixos/modules/misc/version.nix @@ -1,18 +1,33 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.system.nixos; opt = options.system.nixos; inherit (lib) - concatStringsSep mapAttrsToList toLower optionalString - literalExpression mkRenamedOptionModule mkDefault mkOption trivial types; + concatStringsSep + mapAttrsToList + toLower + optionalString + literalExpression + mkRenamedOptionModule + mkDefault + mkOption + trivial + types + ; needsEscaping = s: null != builtins.match "[a-zA-Z0-9]+" s; escapeIfNecessary = s: if needsEscaping s then s else ''"${lib.escape [ "\$" "\"" "\\" "\`" ] s}"''; - attrsToText = attrs: - concatStringsSep "\n" - (mapAttrsToList (n: v: ''${n}=${escapeIfNecessary (toString v)}'') attrs) + attrsToText = + attrs: + concatStringsSep "\n" (mapAttrsToList (n: v: ''${n}=${escapeIfNecessary (toString v)}'') attrs) + "\n"; osReleaseContents = @@ -42,7 +57,8 @@ let VARIANT = optionalString (cfg.variantName != null) cfg.variantName; VARIANT_ID = optionalString (cfg.variant_id != null) cfg.variant_id; DEFAULT_HOSTNAME = config.system.nixos.distroId; - } // cfg.extraOSReleaseArgs; + } + // cfg.extraOSReleaseArgs; initrdReleaseContents = (removeAttrs osReleaseContents [ "BUILD_ID" ]) // { PRETTY_NAME = "${osReleaseContents.PRETTY_NAME} (Initrd)"; @@ -200,7 +216,8 @@ in type = types.str; # TODO Remove this and drop the default of the option so people are forced to set it. # Doing this also means fixing the comment in nixos/modules/testing/test-instrumentation.nix - apply = v: + apply = + v: lib.warnIf (options.system.stateVersion.highestPrio == (lib.mkOptionDefault { }).priority) "system.stateVersion is not set, defaulting to ${v}. Read why this matters on https://nixos.org/manual/nixos/stable/options.html#opt-system.stateVersion." v; @@ -256,13 +273,16 @@ in # https://www.freedesktop.org/software/systemd/man/os-release.html for the # format. environment.etc = { - "lsb-release".text = attrsToText ({ - LSB_VERSION = "${cfg.release} (${cfg.codeName})"; - DISTRIB_ID = "${cfg.distroId}"; - DISTRIB_RELEASE = cfg.release; - DISTRIB_CODENAME = toLower cfg.codeName; - DISTRIB_DESCRIPTION = "${cfg.distroName} ${cfg.release} (${cfg.codeName})"; - } // cfg.extraLSBReleaseArgs); + "lsb-release".text = attrsToText ( + { + LSB_VERSION = "${cfg.release} (${cfg.codeName})"; + DISTRIB_ID = "${cfg.distroId}"; + DISTRIB_RELEASE = cfg.release; + DISTRIB_CODENAME = toLower cfg.codeName; + DISTRIB_DESCRIPTION = "${cfg.distroName} ${cfg.release} (${cfg.codeName})"; + } + // cfg.extraLSBReleaseArgs + ); "os-release".text = attrsToText osReleaseContents; }; diff --git a/nixos/modules/misc/wordlist.nix b/nixos/modules/misc/wordlist.nix index 67c83ff2baaae0..0bd1072baa2283 100644 --- a/nixos/modules/misc/wordlist.nix +++ b/nixos/modules/misc/wordlist.nix @@ -1,8 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - concatAndSort = name: files: pkgs.runCommand name {} '' - awk 1 ${lib.escapeShellArgs files} | sed '{ /^\s*$/d; s/^\s\+//; s/\s\+$// }' | sort | uniq > $out - ''; + concatAndSort = + name: files: + pkgs.runCommand name { } '' + awk 1 ${lib.escapeShellArgs files} | sed '{ /^\s*$/d; s/^\s\+//; s/\s\+$// }' | sort | uniq > $out + ''; in { options = { @@ -50,9 +57,8 @@ in }; config = lib.mkIf config.environment.wordlist.enable { - environment.variables = - lib.mapAttrs - (name: value: "${concatAndSort "wordlist-${name}" value}") - config.environment.wordlist.lists; + environment.variables = lib.mapAttrs ( + name: value: "${concatAndSort "wordlist-${name}" value}" + ) config.environment.wordlist.lists; }; } diff --git a/nixos/modules/profiles/clone-config.nix b/nixos/modules/profiles/clone-config.nix index 3f669ba7d2e167..2c6377e65c8836 100644 --- a/nixos/modules/profiles/clone-config.nix +++ b/nixos/modules/profiles/clone-config.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, modules, ... }: +{ + config, + lib, + pkgs, + modules, + ... +}: with lib; @@ -8,9 +14,12 @@ let nixosPath = toString ../..; # Check if the path is from the NixOS repository - isNixOSFile = path: - let s = toString path; in - removePrefix nixosPath s != s; + isNixOSFile = + path: + let + s = toString path; + in + removePrefix nixosPath s != s; # Copy modules given as extra configuration files. Unfortunately, we # cannot serialized attribute set given in the list of modules (that's why @@ -22,19 +31,24 @@ let # Partition module files because between NixOS and non-NixOS files. NixOS # files may change if the repository is updated. partitionedModuleFiles = - let p = partition isNixOSFile moduleFiles; in - { nixos = p.right; others = p.wrong; }; + let + p = partition isNixOSFile moduleFiles; + in + { + nixos = p.right; + others = p.wrong; + }; # Path transformed to be valid on the installation device. Thus the # device configuration could be rebuild. relocatedModuleFiles = let - relocateNixOS = path: - ""; + relocateNixOS = path: ""; in - { nixos = map relocateNixOS partitionedModuleFiles.nixos; - others = []; # TODO: copy the modules to the install-device repository. - }; + { + nixos = map relocateNixOS partitionedModuleFiles.nixos; + others = [ ]; # TODO: copy the modules to the install-device repository. + }; # A dummy /etc/nixos/configuration.nix in the booted CD that # rebuilds the CD's configuration (and allows the configuration to @@ -42,16 +56,15 @@ let # that we don't really know how the CD was built - the Nix # expression language doesn't allow us to query the expression being # evaluated. So we'll just hope for the best. - configClone = pkgs.writeText "configuration.nix" - '' - { config, pkgs, ... }: + configClone = pkgs.writeText "configuration.nix" '' + { config, pkgs, ... }: - { - imports = [ ${toString config.installer.cloneConfigIncludes} ]; + { + imports = [ ${toString config.installer.cloneConfigIncludes} ]; - ${config.installer.cloneConfigExtra} - } - ''; + ${config.installer.cloneConfigExtra} + } + ''; in @@ -68,7 +81,7 @@ in }; installer.cloneConfigIncludes = mkOption { - default = []; + default = [ ]; example = [ "./nixos/modules/hardware/network/rt73.nix" ]; description = '' List of modules used to re-build this installation device profile. @@ -86,23 +99,21 @@ in config = { - installer.cloneConfigIncludes = - relocatedModuleFiles.nixos ++ relocatedModuleFiles.others; - - boot.postBootCommands = - '' - # Provide a mount point for nixos-install. - mkdir -p /mnt - - ${optionalString config.installer.cloneConfig '' - # Provide a configuration for the CD/DVD itself, to allow users - # to run nixos-rebuild to change the configuration of the - # running system on the CD/DVD. - if ! [ -e /etc/nixos/configuration.nix ]; then - cp ${configClone} /etc/nixos/configuration.nix - fi - ''} - ''; + installer.cloneConfigIncludes = relocatedModuleFiles.nixos ++ relocatedModuleFiles.others; + + boot.postBootCommands = '' + # Provide a mount point for nixos-install. + mkdir -p /mnt + + ${optionalString config.installer.cloneConfig '' + # Provide a configuration for the CD/DVD itself, to allow users + # to run nixos-rebuild to change the configuration of the + # running system on the CD/DVD. + if ! [ -e /etc/nixos/configuration.nix ]; then + cp ${configClone} /etc/nixos/configuration.nix + fi + ''} + ''; }; diff --git a/nixos/modules/profiles/docker-container.nix b/nixos/modules/profiles/docker-container.nix index 199156edfdc60d..66d69361d5841c 100644 --- a/nixos/modules/profiles/docker-container.nix +++ b/nixos/modules/profiles/docker-container.nix @@ -3,7 +3,10 @@ let inherit (pkgs) writeScript; - pkgs2storeContents = map (x: { object = x; symlink = "none"; }); + pkgs2storeContents = map (x: { + object = x; + symlink = "none"; + }); in { @@ -32,26 +35,27 @@ in # Some container managers like lxc need these extraCommands = - let script = writeScript "extra-commands.sh" '' - rm etc - mkdir -p proc sys dev etc - ''; - in script; + let + script = writeScript "extra-commands.sh" '' + rm etc + mkdir -p proc sys dev etc + ''; + in + script; }; boot.isContainer = true; - boot.postBootCommands = - '' - # After booting, register the contents of the Nix store in the Nix - # database. - if [ -f /nix-path-registration ]; then - ${config.nix.package.out}/bin/nix-store --load-db < /nix-path-registration && - rm /nix-path-registration - fi - - # nixos-rebuild also requires a "system" profile - ${config.nix.package.out}/bin/nix-env -p /nix/var/nix/profiles/system --set /run/current-system - ''; + boot.postBootCommands = '' + # After booting, register the contents of the Nix store in the Nix + # database. + if [ -f /nix-path-registration ]; then + ${config.nix.package.out}/bin/nix-store --load-db < /nix-path-registration && + rm /nix-path-registration + fi + + # nixos-rebuild also requires a "system" profile + ${config.nix.package.out}/bin/nix-env -p /nix/var/nix/profiles/system --set /run/current-system + ''; # Install new init script system.activationScripts.installInitScript = '' diff --git a/nixos/modules/profiles/graphical.nix b/nixos/modules/profiles/graphical.nix index f96b11b3536723..82ddc50e423ca3 100644 --- a/nixos/modules/profiles/graphical.nix +++ b/nixos/modules/profiles/graphical.nix @@ -14,5 +14,8 @@ libinput.enable = true; # for touchpad support on many laptops }; - environment.systemPackages = [ pkgs.mesa-demos pkgs.firefox ]; + environment.systemPackages = [ + pkgs.mesa-demos + pkgs.firefox + ]; } diff --git a/nixos/modules/profiles/hardened.nix b/nixos/modules/profiles/hardened.nix index b85a2ac7e69d20..62a9bb90e747cf 100644 --- a/nixos/modules/profiles/hardened.nix +++ b/nixos/modules/profiles/hardened.nix @@ -6,13 +6,21 @@ # profile, try disabling it. If you report an issue and use this # profile, always mention that you do. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; { meta = { - maintainers = [ maintainers.joachifm maintainers.emily ]; + maintainers = [ + maintainers.joachifm + maintainers.emily + ]; }; boot.kernelPackages = mkDefault pkgs.linuxPackages_hardened; diff --git a/nixos/modules/profiles/headless.nix b/nixos/modules/profiles/headless.nix index eb29f3d65106cd..d6d754462c14f2 100644 --- a/nixos/modules/profiles/headless.nix +++ b/nixos/modules/profiles/headless.nix @@ -13,7 +13,12 @@ with lib; systemd.services."autovt@".enable = false; # Since we can't manually respond to a panic, just reboot. - boot.kernelParams = [ "panic=1" "boot.panic_on_fail" "vga=0x317" "nomodeset" ]; + boot.kernelParams = [ + "panic=1" + "boot.panic_on_fail" + "vga=0x317" + "nomodeset" + ]; # Don't allow emergency mode, because we don't have a console. systemd.enableEmergencyMode = false; diff --git a/nixos/modules/profiles/macos-builder.nix b/nixos/modules/profiles/macos-builder.nix index 896bb6bc9fbdf8..841c00dc69228a 100644 --- a/nixos/modules/profiles/macos-builder.nix +++ b/nixos/modules/profiles/macos-builder.nix @@ -1,5 +1,6 @@ -let lib = import ../../../lib; +let + lib = import ../../../lib; in - lib.warnIf (lib.isInOldestRelease 2411) - "nixos/modules/profiles/macos-builder.nix has moved to nixos/modules/profiles/nix-builder-vm.nix; please update your NixOS imports." - ./nix-builder-vm.nix +lib.warnIf (lib.isInOldestRelease 2411) + "nixos/modules/profiles/macos-builder.nix has moved to nixos/modules/profiles/nix-builder-vm.nix; please update your NixOS imports." + ./nix-builder-vm.nix diff --git a/nixos/modules/profiles/perlless.nix b/nixos/modules/profiles/perlless.nix index c331a90882676d..852875e7446225 100644 --- a/nixos/modules/profiles/perlless.nix +++ b/nixos/modules/profiles/perlless.nix @@ -18,10 +18,10 @@ # Check that the system does not contain a Nix store path that contains the # string "perl". - system.forbiddenDependenciesRegexes = ["perl"]; + system.forbiddenDependenciesRegexes = [ "perl" ]; # Re-add nixos-rebuild to the systemPackages that was removed by the # `system.disableInstallerTools` option. - environment.systemPackages = [pkgs.nixos-rebuild]; + environment.systemPackages = [ pkgs.nixos-rebuild ]; } diff --git a/nixos/modules/profiles/qemu-guest.nix b/nixos/modules/profiles/qemu-guest.nix index 3dbbbbea182e1e..d0290d661cce31 100644 --- a/nixos/modules/profiles/qemu-guest.nix +++ b/nixos/modules/profiles/qemu-guest.nix @@ -4,6 +4,19 @@ { ... }: { - boot.initrd.availableKernelModules = [ "virtio_net" "virtio_pci" "virtio_mmio" "virtio_blk" "virtio_scsi" "9p" "9pnet_virtio" ]; - boot.initrd.kernelModules = [ "virtio_balloon" "virtio_console" "virtio_rng" "virtio_gpu" ]; + boot.initrd.availableKernelModules = [ + "virtio_net" + "virtio_pci" + "virtio_mmio" + "virtio_blk" + "virtio_scsi" + "9p" + "9pnet_virtio" + ]; + boot.initrd.kernelModules = [ + "virtio_balloon" + "virtio_console" + "virtio_rng" + "virtio_gpu" + ]; } diff --git a/nixos/modules/programs/_1password-gui.nix b/nixos/modules/programs/_1password-gui.nix index 04f36cf0237ab8..f840dbbe8a73fe 100644 --- a/nixos/modules/programs/_1password-gui.nix +++ b/nixos/modules/programs/_1password-gui.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let diff --git a/nixos/modules/programs/_1password.nix b/nixos/modules/programs/_1password.nix index 28ddb3b1a43eee..2e08520c90ba9a 100644 --- a/nixos/modules/programs/_1password.nix +++ b/nixos/modules/programs/_1password.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let diff --git a/nixos/modules/programs/adb.nix b/nixos/modules/programs/adb.nix index 62ab6ab4137a16..28182df9cc230f 100644 --- a/nixos/modules/programs/adb.nix +++ b/nixos/modules/programs/adb.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { meta.maintainers = [ lib.maintainers.mic92 ]; @@ -22,6 +27,6 @@ config = lib.mkIf config.programs.adb.enable { services.udev.packages = [ pkgs.android-udev-rules ]; environment.systemPackages = [ pkgs.android-tools ]; - users.groups.adbusers = {}; + users.groups.adbusers = { }; }; } diff --git a/nixos/modules/programs/alvr.nix b/nixos/modules/programs/alvr.nix index da66200cf075b0..4cf78a7490b5f6 100644 --- a/nixos/modules/programs/alvr.nix +++ b/nixos/modules/programs/alvr.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.alvr; @@ -24,8 +29,14 @@ in environment.systemPackages = [ cfg.package ]; networking.firewall = lib.mkIf cfg.openFirewall { - allowedTCPPorts = [ 9943 9944 ]; - allowedUDPPorts = [ 9943 9944 ]; + allowedTCPPorts = [ + 9943 + 9944 + ]; + allowedUDPPorts = [ + 9943 + 9944 + ]; }; }; diff --git a/nixos/modules/programs/appgate-sdp.nix b/nixos/modules/programs/appgate-sdp.nix index f4d4140571a64a..87b5118adb7a7c 100644 --- a/nixos/modules/programs/appgate-sdp.nix +++ b/nixos/modules/programs/appgate-sdp.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { options = { @@ -16,7 +21,10 @@ # https://github.com/NixOS/nixpkgs/issues/81138 services.appgatedriver.wantedBy = [ "multi-user.target" ]; services.appgate-dumb-resolver.path = [ pkgs.e2fsprogs ]; - services.appgate-resolver.path = [ pkgs.procps pkgs.e2fsprogs ]; + services.appgate-resolver.path = [ + pkgs.procps + pkgs.e2fsprogs + ]; services.appgatedriver.path = [ pkgs.e2fsprogs ]; }; }; diff --git a/nixos/modules/programs/atop.nix b/nixos/modules/programs/atop.nix index 3738f926ca3d85..ca662d03213d3f 100644 --- a/nixos/modules/programs/atop.nix +++ b/nixos/modules/programs/atop.nix @@ -1,8 +1,14 @@ # Global configuration for atop. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: -let cfg = config.programs.atop; +let + cfg = config.programs.atop; in { @@ -95,40 +101,49 @@ in config = lib.mkIf cfg.enable ( let - atop = - if cfg.atopgpu.enable then - (cfg.package.override { withAtopgpu = true; }) - else - cfg.package; + atop = if cfg.atopgpu.enable then (cfg.package.override { withAtopgpu = true; }) else cfg.package; in { environment.etc = lib.mkIf (cfg.settings != { }) { - atoprc.text = lib.concatStrings - (lib.mapAttrsToList - (n: v: '' - ${n} ${builtins.toString v} - '') - cfg.settings); + atoprc.text = lib.concatStrings ( + lib.mapAttrsToList (n: v: '' + ${n} ${builtins.toString v} + '') cfg.settings + ); }; - environment.systemPackages = [ atop (lib.mkIf cfg.netatop.enable cfg.netatop.package) ]; + environment.systemPackages = [ + atop + (lib.mkIf cfg.netatop.enable cfg.netatop.package) + ]; boot.extraModulePackages = [ (lib.mkIf cfg.netatop.enable cfg.netatop.package) ]; systemd = let mkSystemd = type: name: restartTriggers: { ${name} = { inherit restartTriggers; - wantedBy = [ (if type == "services" then "multi-user.target" else if type == "timers" then "timers.target" else null) ]; + wantedBy = [ + ( + if type == "services" then + "multi-user.target" + else if type == "timers" then + "timers.target" + else + null + ) + ]; }; }; mkService = mkSystemd "services"; mkTimer = mkSystemd "timers"; in { - packages = [ atop (lib.mkIf cfg.netatop.enable cfg.netatop.package) ]; + packages = [ + atop + (lib.mkIf cfg.netatop.enable cfg.netatop.package) + ]; services = lib.mkMerge [ - (lib.mkIf cfg.atopService.enable (lib.recursiveUpdate - (mkService "atop" [ atop ]) - { + (lib.mkIf cfg.atopService.enable ( + lib.recursiveUpdate (mkService "atop" [ atop ]) { # always convert logs to newer version first # XXX might trigger TimeoutStart but restarting atop.service will # convert remainings logs and start eventually @@ -149,7 +164,8 @@ in fi done ''; - })) + } + )) (lib.mkIf cfg.atopacctService.enable (mkService "atopacct" [ atop ])) (lib.mkIf cfg.netatop.enable (mkService "netatop" [ cfg.netatop.package ])) (lib.mkIf cfg.atopgpu.enable (mkService "atopgpu" [ atop ])) diff --git a/nixos/modules/programs/ausweisapp.nix b/nixos/modules/programs/ausweisapp.nix index ebd6a3e13bf66f..23b2cb98fa3b1a 100644 --- a/nixos/modules/programs/ausweisapp.nix +++ b/nixos/modules/programs/ausweisapp.nix @@ -1,7 +1,12 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - cfg = config.programs.ausweisapp; + cfg = config.programs.ausweisapp; in { options.programs.ausweisapp = { diff --git a/nixos/modules/programs/autojump.nix b/nixos/modules/programs/autojump.nix index 5011d7e142375c..309bf6185242dc 100644 --- a/nixos/modules/programs/autojump.nix +++ b/nixos/modules/programs/autojump.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.autojump; diff --git a/nixos/modules/programs/bandwhich.nix b/nixos/modules/programs/bandwhich.nix index e2c55ca5bea4a1..2136a84c3209de 100644 --- a/nixos/modules/programs/bandwhich.nix +++ b/nixos/modules/programs/bandwhich.nix @@ -1,7 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: -let cfg = config.programs.bandwhich; -in { +let + cfg = config.programs.bandwhich; +in +{ meta.maintainers = with lib.maintainers; [ Br1ght0ne ]; options = { diff --git a/nixos/modules/programs/bash-my-aws.nix b/nixos/modules/programs/bash-my-aws.nix index 85618ad98f080a..bd4685d275526d 100644 --- a/nixos/modules/programs/bash-my-aws.nix +++ b/nixos/modules/programs/bash-my-aws.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let prg = config.programs; @@ -8,16 +13,16 @@ let eval $(${pkgs.bash-my-aws}/bin/bma-init) ''; in - { - options = { - programs.bash-my-aws = { - enable = lib.mkEnableOption "bash-my-aws"; - }; +{ + options = { + programs.bash-my-aws = { + enable = lib.mkEnableOption "bash-my-aws"; }; + }; - config = lib.mkIf cfg.enable { - environment.systemPackages = with pkgs; [ bash-my-aws ]; + config = lib.mkIf cfg.enable { + environment.systemPackages = with pkgs; [ bash-my-aws ]; - programs.bash.interactiveShellInit = initScript; - }; - } + programs.bash.interactiveShellInit = initScript; + }; +} diff --git a/nixos/modules/programs/bash/bash-completion.nix b/nixos/modules/programs/bash/bash-completion.nix index f143361bc93313..cfc59d108d3b56 100644 --- a/nixos/modules/programs/bash/bash-completion.nix +++ b/nixos/modules/programs/bash/bash-completion.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.bash; @@ -13,7 +18,10 @@ in }; imports = [ - (lib.mkRenamedOptionModule [ "programs" "bash" "enableCompletion" ] [ "programs" "bash" "completion" "enable" ]) + (lib.mkRenamedOptionModule + [ "programs" "bash" "enableCompletion" ] + [ "programs" "bash" "completion" "enable" ] + ) ]; config = lib.mkIf cfg.completion.enable { diff --git a/nixos/modules/programs/bash/bash.nix b/nixos/modules/programs/bash/bash.nix index 1ffa7fe5610939..213f0d2698ae8f 100644 --- a/nixos/modules/programs/bash/bash.nix +++ b/nixos/modules/programs/bash/bash.nix @@ -1,7 +1,12 @@ # This module defines global configuration for the Bash shell, in # particular /etc/bashrc and /etc/profile. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let @@ -10,8 +15,9 @@ let cfg = config.programs.bash; bashAliases = builtins.concatStringsSep "\n" ( - lib.mapAttrsToList (k: v: "alias -- ${k}=${lib.escapeShellArg v}") - (lib.filterAttrs (k: v: v != null) cfg.shellAliases) + lib.mapAttrsToList (k: v: "alias -- ${k}=${lib.escapeShellArg v}") ( + lib.filterAttrs (k: v: v != null) cfg.shellAliases + ) ); in @@ -26,22 +32,22 @@ in programs.bash = { /* - enable = lib.mkOption { - default = true; - description = '' - Whenever to configure Bash as an interactive shell. - Note that this tries to make Bash the default - {option}`users.defaultUserShell`, - which in turn means that you might need to explicitly - set this variable if you have another shell configured - with NixOS. - ''; - type = lib.types.bool; - }; + enable = lib.mkOption { + default = true; + description = '' + Whenever to configure Bash as an interactive shell. + Note that this tries to make Bash the default + {option}`users.defaultUserShell`, + which in turn means that you might need to explicitly + set this variable if you have another shell configured + with NixOS. + ''; + type = lib.types.bool; + }; */ shellAliases = lib.mkOption { - default = {}; + default = { }; description = '' Set of aliases for bash shell, which overrides {option}`environment.shellAliases`. See {option}`environment.shellAliases` for an option format description. @@ -109,40 +115,40 @@ in }; - config = /* lib.mkIf cfg.enable */ { + config = # lib.mkIf cfg.enable + { - programs.bash = { + programs.bash = { - shellAliases = builtins.mapAttrs (name: lib.mkDefault) cfge.shellAliases; + shellAliases = builtins.mapAttrs (name: lib.mkDefault) cfge.shellAliases; - shellInit = '' - if [ -z "$__NIXOS_SET_ENVIRONMENT_DONE" ]; then - . ${config.system.build.setEnvironment} - fi + shellInit = '' + if [ -z "$__NIXOS_SET_ENVIRONMENT_DONE" ]; then + . ${config.system.build.setEnvironment} + fi - ${cfge.shellInit} - ''; + ${cfge.shellInit} + ''; - loginShellInit = cfge.loginShellInit; + loginShellInit = cfge.loginShellInit; - interactiveShellInit = '' - # Check the window size after every command. - shopt -s checkwinsize + interactiveShellInit = '' + # Check the window size after every command. + shopt -s checkwinsize - # Disable hashing (i.e. caching) of command lookups. - set +h + # Disable hashing (i.e. caching) of command lookups. + set +h - ${cfg.promptInit} - ${cfg.promptPluginInit} - ${bashAliases} + ${cfg.promptInit} + ${cfg.promptPluginInit} + ${bashAliases} - ${cfge.interactiveShellInit} - ''; + ${cfge.interactiveShellInit} + ''; - }; + }; - environment.etc.profile.text = - '' + environment.etc.profile.text = '' # /etc/profile: DO NOT EDIT -- this file has been generated automatically. # This file is read for login shells. @@ -166,8 +172,7 @@ in fi ''; - environment.etc.bashrc.text = - '' + environment.etc.bashrc.text = '' # /etc/bashrc: DO NOT EDIT -- this file has been generated automatically. # Only execute this file once per shell. @@ -192,24 +197,24 @@ in fi ''; - # Configuration for readline in bash. We use "option default" - # priority to allow user override using both .text and .source. - environment.etc.inputrc.source = lib.mkOptionDefault ./inputrc; + # Configuration for readline in bash. We use "option default" + # priority to allow user override using both .text and .source. + environment.etc.inputrc.source = lib.mkOptionDefault ./inputrc; - users.defaultUserShell = lib.mkDefault pkgs.bashInteractive; + users.defaultUserShell = lib.mkDefault pkgs.bashInteractive; - environment.pathsToLink = lib.optionals cfg.completion.enable [ - "/etc/bash_completion.d" - "/share/bash-completion" - ]; + environment.pathsToLink = lib.optionals cfg.completion.enable [ + "/etc/bash_completion.d" + "/share/bash-completion" + ]; - environment.shells = - [ "/run/current-system/sw/bin/bash" + environment.shells = [ + "/run/current-system/sw/bin/bash" "/run/current-system/sw/bin/sh" "${pkgs.bashInteractive}/bin/bash" "${pkgs.bashInteractive}/bin/sh" ]; - }; + }; } diff --git a/nixos/modules/programs/bash/blesh.nix b/nixos/modules/programs/bash/blesh.nix index b5ca83a883bb0b..233918f480604b 100644 --- a/nixos/modules/programs/bash/blesh.nix +++ b/nixos/modules/programs/bash/blesh.nix @@ -1,7 +1,13 @@ -{ lib, config, pkgs, ... }: +{ + lib, + config, + pkgs, + ... +}: let cfg = config.programs.bash.blesh; -in { +in +{ options = { programs.bash.blesh.enable = lib.mkEnableOption "blesh, a full-featured line editor written in pure Bash"; }; diff --git a/nixos/modules/programs/bash/ls-colors.nix b/nixos/modules/programs/bash/ls-colors.nix index 3ee00e93d4dae9..ea0ac0d392afe2 100644 --- a/nixos/modules/programs/bash/ls-colors.nix +++ b/nixos/modules/programs/bash/ls-colors.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let enable = config.programs.bash.enableLsColors; diff --git a/nixos/modules/programs/bash/undistract-me.nix b/nixos/modules/programs/bash/undistract-me.nix index af4f3a737dabd0..a68738512efb8e 100644 --- a/nixos/modules/programs/bash/undistract-me.nix +++ b/nixos/modules/programs/bash/undistract-me.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.bash.undistractMe; diff --git a/nixos/modules/programs/bcc.nix b/nixos/modules/programs/bcc.nix index f799524b9c0747..d7b7d4596773be 100644 --- a/nixos/modules/programs/bcc.nix +++ b/nixos/modules/programs/bcc.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { options.programs.bcc.enable = lib.mkEnableOption "bcc, tools for BPF-based Linux IO analysis, networking, monitoring, and more"; diff --git a/nixos/modules/programs/benchexec.nix b/nixos/modules/programs/benchexec.nix index 08ee67ca90ae55..339953c1737aec 100644 --- a/nixos/modules/programs/benchexec.nix +++ b/nixos/modules/programs/benchexec.nix @@ -1,22 +1,31 @@ -{ lib -, pkgs -, config -, options -, ... +{ + lib, + pkgs, + config, + options, + ... }: let cfg = config.programs.benchexec; opt = options.programs.benchexec; - filterUsers = x: - if builtins.isString x then config.users.users ? ${x} else - if builtins.isInt x then x else - throw "filterUsers expects string (username) or int (UID)"; + filterUsers = + x: + if builtins.isString x then + config.users.users ? ${x} + else if builtins.isInt x then + x + else + throw "filterUsers expects string (username) or int (UID)"; - uid = x: - if builtins.isString x then config.users.users.${x}.uid else - if builtins.isInt x then x else - throw "uid expects string (username) or int (UID)"; + uid = + x: + if builtins.isString x then + config.users.users.${x}.uid + else if builtins.isInt x then + x + else + throw "uid expects string (username) or int (UID)"; in { options.programs.benchexec = { @@ -43,36 +52,32 @@ in }; config = lib.mkIf cfg.enable { - assertions = (map - (user: { + assertions = + (map (user: { assertion = config.users.users ? ${user}; message = '' The user '${user}' intends to use BenchExec (via `${opt.users}`), but is not configured via `${options.users.users}`. ''; - }) - (builtins.filter builtins.isString cfg.users) - ) ++ (map - (id: { + }) (builtins.filter builtins.isString cfg.users)) + ++ (map (id: { assertion = config.users.mutableUsers; message = '' The user with UID '${id}' intends to use BenchExec (via `${opt.users}`), but mutable users are disabled via `${options.users.mutableUsers}`. ''; - }) - (builtins.filter builtins.isInt cfg.users) - ); + }) (builtins.filter builtins.isInt cfg.users)); environment.systemPackages = [ cfg.package ]; # See . - systemd.services = builtins.listToAttrs (map - (user: { + systemd.services = builtins.listToAttrs ( + map (user: { name = "user@${builtins.toString (uid user)}"; value = { serviceConfig.Delegate = "yes"; overrideStrategy = "asDropin"; }; - }) - (builtins.filter filterUsers cfg.users)); + }) (builtins.filter filterUsers cfg.users) + ); # See . virtualisation.lxc.lxcfs.enable = lib.mkDefault true; diff --git a/nixos/modules/programs/browserpass.nix b/nixos/modules/programs/browserpass.nix index ab6be266ea8d6b..7053117e914c17 100644 --- a/nixos/modules/programs/browserpass.nix +++ b/nixos/modules/programs/browserpass.nix @@ -1,30 +1,37 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { options.programs.browserpass.enable = lib.mkEnableOption "Browserpass native messaging host"; config = lib.mkIf config.programs.browserpass.enable { - environment.etc = let - appId = "com.github.browserpass.native.json"; - source = part: "${pkgs.browserpass}/lib/browserpass/${part}/${appId}"; - in { - # chromium - "chromium/native-messaging-hosts/${appId}".source = source "hosts/chromium"; - "chromium/policies/managed/${appId}".source = source "policies/chromium"; + environment.etc = + let + appId = "com.github.browserpass.native.json"; + source = part: "${pkgs.browserpass}/lib/browserpass/${part}/${appId}"; + in + { + # chromium + "chromium/native-messaging-hosts/${appId}".source = source "hosts/chromium"; + "chromium/policies/managed/${appId}".source = source "policies/chromium"; - # chrome - "opt/chrome/native-messaging-hosts/${appId}".source = source "hosts/chromium"; - "opt/chrome/policies/managed/${appId}".source = source "policies/chromium"; + # chrome + "opt/chrome/native-messaging-hosts/${appId}".source = source "hosts/chromium"; + "opt/chrome/policies/managed/${appId}".source = source "policies/chromium"; - # vivaldi - "opt/vivaldi/native-messaging-hosts/${appId}".source = source "hosts/chromium"; - "opt/vivaldi/policies/managed/${appId}".source = source "policies/chromium"; + # vivaldi + "opt/vivaldi/native-messaging-hosts/${appId}".source = source "hosts/chromium"; + "opt/vivaldi/policies/managed/${appId}".source = source "policies/chromium"; - # brave - "opt/brave/native-messaging-hosts/${appId}".source = source "hosts/chromium"; - "opt/brave/policies/managed/${appId}".source = source "policies/chromium"; - }; + # brave + "opt/brave/native-messaging-hosts/${appId}".source = source "hosts/chromium"; + "opt/brave/policies/managed/${appId}".source = source "policies/chromium"; + }; programs.firefox.nativeMessagingHosts.packages = [ pkgs.browserpass ]; }; } diff --git a/nixos/modules/programs/calls.nix b/nixos/modules/programs/calls.nix index 36a4c51ddf438b..17ab06f959ef2b 100644 --- a/nixos/modules/programs/calls.nix +++ b/nixos/modules/programs/calls.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.calls; -in { +in +{ options = { programs.calls = { enable = lib.mkEnableOption '' diff --git a/nixos/modules/programs/captive-browser.nix b/nixos/modules/programs/captive-browser.nix index 8f0aa2fe1e6a0c..84eff22a4d3463 100644 --- a/nixos/modules/programs/captive-browser.nix +++ b/nixos/modules/programs/captive-browser.nix @@ -1,27 +1,42 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.captive-browser; inherit (lib) - concatStringsSep escapeShellArgs optionalString - literalExpression mkEnableOption mkPackageOption mkIf mkOption - mkOptionDefault types; + concatStringsSep + escapeShellArgs + optionalString + literalExpression + mkEnableOption + mkPackageOption + mkIf + mkOption + mkOptionDefault + types + ; requiresSetcapWrapper = config.boot.kernelPackages.kernelOlder "5.7" && cfg.bindInterface; - browserDefault = chromium: concatStringsSep " " [ - ''env XDG_CONFIG_HOME="$PREV_CONFIG_HOME"'' - ''${chromium}/bin/chromium'' - ''--user-data-dir=''${XDG_DATA_HOME:-$HOME/.local/share}/chromium-captive'' - ''--proxy-server="socks5://$PROXY"'' - ''--host-resolver-rules="MAP * ~NOTFOUND , EXCLUDE localhost"'' - ''--no-first-run'' - ''--new-window'' - ''--incognito'' - ''-no-default-browser-check'' - ''http://cache.nixos.org/'' - ]; + browserDefault = + chromium: + concatStringsSep " " [ + ''env XDG_CONFIG_HOME="$PREV_CONFIG_HOME"'' + ''${chromium}/bin/chromium'' + ''--user-data-dir=''${XDG_DATA_HOME:-$HOME/.local/share}/chromium-captive'' + ''--proxy-server="socks5://$PROXY"'' + ''--host-resolver-rules="MAP * ~NOTFOUND , EXCLUDE localhost"'' + ''--no-first-run'' + ''--new-window'' + ''--incognito'' + ''-no-default-browser-check'' + ''http://cache.nixos.org/'' + ]; desktopItem = pkgs.makeDesktopItem { name = "captive-browser"; @@ -116,19 +131,18 @@ in programs.captive-browser.dhcp-dns = let - iface = prefixes: - optionalString cfg.bindInterface (escapeShellArgs (prefixes ++ [ cfg.interface ])); + iface = + prefixes: optionalString cfg.bindInterface (escapeShellArgs (prefixes ++ [ cfg.interface ])); in mkOptionDefault ( if config.networking.networkmanager.enable then - "${pkgs.networkmanager}/bin/nmcli dev show ${iface []} | ${pkgs.gnugrep}/bin/fgrep IP4.DNS" + "${pkgs.networkmanager}/bin/nmcli dev show ${iface [ ]} | ${pkgs.gnugrep}/bin/fgrep IP4.DNS" else if config.networking.dhcpcd.enable then - "${pkgs.dhcpcd}/bin/dhcpcd ${iface ["-U"]} | ${pkgs.gnugrep}/bin/fgrep domain_name_servers" + "${pkgs.dhcpcd}/bin/dhcpcd ${iface [ "-U" ]} | ${pkgs.gnugrep}/bin/fgrep domain_name_servers" else if config.networking.useNetworkd then - "${cfg.package}/bin/systemd-networkd-dns ${iface []}" + "${cfg.package}/bin/systemd-networkd-dns ${iface [ ]}" else - "${config.security.wrapperDir}/udhcpc --quit --now -f ${iface ["-i"]} -O dns --script ${ - pkgs.writeShellScript "udhcp-script" '' + "${config.security.wrapperDir}/udhcpc --quit --now -f ${iface [ "-i" ]} -O dns --script ${pkgs.writeShellScript "udhcp-script" '' if [ "$1" = bound ]; then echo "$dns" fi diff --git a/nixos/modules/programs/ccache.nix b/nixos/modules/programs/ccache.nix index bfcbe39b3ff01f..99702f955162e9 100644 --- a/nixos/modules/programs/ccache.nix +++ b/nixos/modules/programs/ccache.nix @@ -1,8 +1,14 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.ccache; -in { +in +{ options.programs.ccache = { # host configuration enable = lib.mkEnableOption "CCache, a compiler cache for fast recompilation of C/C++ code"; @@ -15,8 +21,12 @@ in { packageNames = lib.mkOption { type = lib.types.listOf lib.types.str; description = "Nix top-level packages to be compiled using CCache"; - default = []; - example = [ "wxGTK32" "ffmpeg" "libav_all" ]; + default = [ ]; + example = [ + "wxGTK32" + "ffmpeg" + "libav_all" + ]; }; owner = lib.mkOption { type = lib.types.str; @@ -58,9 +68,14 @@ in { }) # target configuration - (lib.mkIf (cfg.packageNames != []) { + (lib.mkIf (cfg.packageNames != [ ]) { nixpkgs.overlays = [ - (self: super: lib.genAttrs cfg.packageNames (pn: super.${pn}.override { stdenv = builtins.trace "with ccache: ${pn}" self.ccacheStdenv; })) + ( + self: super: + lib.genAttrs cfg.packageNames ( + pn: super.${pn}.override { stdenv = builtins.trace "with ccache: ${pn}" self.ccacheStdenv; } + ) + ) (self: super: { ccacheWrapper = super.ccacheWrapper.override { diff --git a/nixos/modules/programs/cdemu.nix b/nixos/modules/programs/cdemu.nix index cdfab3ee9f398f..5496f06de2a194 100644 --- a/nixos/modules/programs/cdemu.nix +++ b/nixos/modules/programs/cdemu.nix @@ -1,7 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: -let cfg = config.programs.cdemu; -in { +let + cfg = config.programs.cdemu; +in +{ options = { programs.cdemu = { @@ -51,7 +58,7 @@ in { dbus.packages = [ pkgs.cdemu-daemon ]; }; - users.groups.${config.programs.cdemu.group} = {}; + users.groups.${config.programs.cdemu.group} = { }; # Systemd User service # manually adapted from example in source package: @@ -65,7 +72,10 @@ in { }; environment.systemPackages = - [ pkgs.cdemu-daemon pkgs.cdemu-client ] + [ + pkgs.cdemu-daemon + pkgs.cdemu-client + ] ++ lib.optional cfg.gui pkgs.gcdemu ++ lib.optional cfg.image-analyzer pkgs.image-analyzer; }; diff --git a/nixos/modules/programs/cfs-zen-tweaks.nix b/nixos/modules/programs/cfs-zen-tweaks.nix index bc162640393527..190b586aba0364 100644 --- a/nixos/modules/programs/cfs-zen-tweaks.nix +++ b/nixos/modules/programs/cfs-zen-tweaks.nix @@ -1,6 +1,11 @@ # CFS Zen Tweaks -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let diff --git a/nixos/modules/programs/chromium.nix b/nixos/modules/programs/chromium.nix index 4d248dbe0945f6..290808b7bdbe48 100644 --- a/nixos/modules/programs/chromium.nix +++ b/nixos/modules/programs/chromium.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.chromium; @@ -21,7 +26,10 @@ in enablePlasmaBrowserIntegration = lib.mkEnableOption "Native Messaging Host for Plasma Browser Integration"; - plasmaBrowserIntegrationPackage = lib.mkPackageOption pkgs [ "plasma5Packages" "plasma-browser-integration" ] { }; + plasmaBrowserIntegrationPackage = lib.mkPackageOption pkgs [ + "plasma5Packages" + "plasma-browser-integration" + ] { }; extensions = lib.mkOption { type = with lib.types; nullOr (listOf str); @@ -82,7 +90,7 @@ in Make sure the selected policy is supported on Linux and your browser version. ''; - default = {}; + default = { }; example = lib.literalExpression '' { "BrowserSignin" = 0; @@ -105,7 +113,7 @@ in More information can be found in the Chromium documentation: ''; - default = {}; + default = { }; example = lib.literalExpression '' { "first_run_tabs" = [ @@ -122,19 +130,39 @@ in config = { environment.etc = lib.mkIf cfg.enable { # for chromium - "chromium/native-messaging-hosts/org.kde.plasma.browser_integration.json" = lib.mkIf cfg.enablePlasmaBrowserIntegration - { source = "${cfg.plasmaBrowserIntegrationPackage}/etc/chromium/native-messaging-hosts/org.kde.plasma.browser_integration.json"; }; - "chromium/policies/managed/default.json" = lib.mkIf (defaultProfile != {}) { text = builtins.toJSON defaultProfile; }; - "chromium/policies/managed/extra.json" = lib.mkIf (cfg.extraOpts != {}) { text = builtins.toJSON cfg.extraOpts; }; - "chromium/initial_preferences" = lib.mkIf (cfg.initialPrefs != {}) { text = builtins.toJSON cfg.initialPrefs; }; + "chromium/native-messaging-hosts/org.kde.plasma.browser_integration.json" = + lib.mkIf cfg.enablePlasmaBrowserIntegration + { + source = "${cfg.plasmaBrowserIntegrationPackage}/etc/chromium/native-messaging-hosts/org.kde.plasma.browser_integration.json"; + }; + "chromium/policies/managed/default.json" = lib.mkIf (defaultProfile != { }) { + text = builtins.toJSON defaultProfile; + }; + "chromium/policies/managed/extra.json" = lib.mkIf (cfg.extraOpts != { }) { + text = builtins.toJSON cfg.extraOpts; + }; + "chromium/initial_preferences" = lib.mkIf (cfg.initialPrefs != { }) { + text = builtins.toJSON cfg.initialPrefs; + }; # for google-chrome https://www.chromium.org/administrators/linux-quick-start - "opt/chrome/native-messaging-hosts/org.kde.plasma.browser_integration.json" = lib.mkIf cfg.enablePlasmaBrowserIntegration - { source = "${cfg.plasmaBrowserIntegrationPackage}/etc/opt/chrome/native-messaging-hosts/org.kde.plasma.browser_integration.json"; }; - "opt/chrome/policies/managed/default.json" = lib.mkIf (defaultProfile != {}) { text = builtins.toJSON defaultProfile; }; - "opt/chrome/policies/managed/extra.json" = lib.mkIf (cfg.extraOpts != {}) { text = builtins.toJSON cfg.extraOpts; }; + "opt/chrome/native-messaging-hosts/org.kde.plasma.browser_integration.json" = + lib.mkIf cfg.enablePlasmaBrowserIntegration + { + source = "${cfg.plasmaBrowserIntegrationPackage}/etc/opt/chrome/native-messaging-hosts/org.kde.plasma.browser_integration.json"; + }; + "opt/chrome/policies/managed/default.json" = lib.mkIf (defaultProfile != { }) { + text = builtins.toJSON defaultProfile; + }; + "opt/chrome/policies/managed/extra.json" = lib.mkIf (cfg.extraOpts != { }) { + text = builtins.toJSON cfg.extraOpts; + }; # for brave - "brave/policies/managed/default.json" = lib.mkIf (defaultProfile != {}) { text = builtins.toJSON defaultProfile; }; - "brave/policies/managed/extra.json" = lib.mkIf (cfg.extraOpts != {}) { text = builtins.toJSON cfg.extraOpts; }; + "brave/policies/managed/default.json" = lib.mkIf (defaultProfile != { }) { + text = builtins.toJSON defaultProfile; + }; + "brave/policies/managed/extra.json" = lib.mkIf (cfg.extraOpts != { }) { + text = builtins.toJSON cfg.extraOpts; + }; }; }; } diff --git a/nixos/modules/programs/cnping.nix b/nixos/modules/programs/cnping.nix index f4b5aa845b5f2e..92e033d0b7dc92 100644 --- a/nixos/modules/programs/cnping.nix +++ b/nixos/modules/programs/cnping.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.cnping; diff --git a/nixos/modules/programs/command-not-found/command-not-found.nix b/nixos/modules/programs/command-not-found/command-not-found.nix index a223e811728dce..8d501f68666023 100644 --- a/nixos/modules/programs/command-not-found/command-not-found.nix +++ b/nixos/modules/programs/command-not-found/command-not-found.nix @@ -3,7 +3,12 @@ # SQLite database that maps program names to Nix package names (e.g., # "pdflatex" is mapped to "tetex"). -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.command-not-found; @@ -13,7 +18,10 @@ let src = ./command-not-found.pl; isExecutable = true; inherit (cfg) dbPath; - perl = pkgs.perl.withPackages (p: [ p.DBDSQLite p.StringShellQuote ]); + perl = pkgs.perl.withPackages (p: [ + p.DBDSQLite + p.StringShellQuote + ]); }; in @@ -31,7 +39,7 @@ in }; dbPath = lib.mkOption { - default = "/nix/var/nix/profiles/per-user/root/channels/nixos/programs.sqlite" ; + default = "/nix/var/nix/profiles/per-user/root/channels/nixos/programs.sqlite"; description = '' Absolute path to programs.sqlite. @@ -43,49 +51,47 @@ in }; config = lib.mkIf cfg.enable { - programs.bash.interactiveShellInit = - '' - # This function is called whenever a command is not found. - command_not_found_handle() { - local p='${commandNotFound}/bin/command-not-found' - if [ -x "$p" ] && [ -f '${cfg.dbPath}' ]; then - # Run the helper program. - "$p" "$@" - # Retry the command if we just installed it. - if [ $? = 126 ]; then - "$@" - else - return 127 - fi + programs.bash.interactiveShellInit = '' + # This function is called whenever a command is not found. + command_not_found_handle() { + local p='${commandNotFound}/bin/command-not-found' + if [ -x "$p" ] && [ -f '${cfg.dbPath}' ]; then + # Run the helper program. + "$p" "$@" + # Retry the command if we just installed it. + if [ $? = 126 ]; then + "$@" else - echo "$1: command not found" >&2 return 127 fi - } - ''; + else + echo "$1: command not found" >&2 + return 127 + fi + } + ''; - programs.zsh.interactiveShellInit = - '' - # This function is called whenever a command is not found. - command_not_found_handler() { - local p='${commandNotFound}/bin/command-not-found' - if [ -x "$p" ] && [ -f '${cfg.dbPath}' ]; then - # Run the helper program. - "$p" "$@" + programs.zsh.interactiveShellInit = '' + # This function is called whenever a command is not found. + command_not_found_handler() { + local p='${commandNotFound}/bin/command-not-found' + if [ -x "$p" ] && [ -f '${cfg.dbPath}' ]; then + # Run the helper program. + "$p" "$@" - # Retry the command if we just installed it. - if [ $? = 126 ]; then - "$@" - else - return 127 - fi + # Retry the command if we just installed it. + if [ $? = 126 ]; then + "$@" else - # Indicate than there was an error so ZSH falls back to its default handler - echo "$1: command not found" >&2 return 127 fi - } - ''; + else + # Indicate than there was an error so ZSH falls back to its default handler + echo "$1: command not found" >&2 + return 127 + fi + } + ''; environment.systemPackages = [ commandNotFound ]; }; diff --git a/nixos/modules/programs/coolercontrol.nix b/nixos/modules/programs/coolercontrol.nix index 1c64d46ae2b903..a8861185686068 100644 --- a/nixos/modules/programs/coolercontrol.nix +++ b/nixos/modules/programs/coolercontrol.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let @@ -25,37 +26,44 @@ in }; ##### implementation - config = lib.mkIf cfg.enable (lib.mkMerge [ - # Common - ({ - environment.systemPackages = with pkgs.coolercontrol; [ - coolercontrol-gui - ]; - - systemd = { - packages = with pkgs.coolercontrol; [ - coolercontrol-liqctld - coolercontrold + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + # Common + ({ + environment.systemPackages = with pkgs.coolercontrol; [ + coolercontrol-gui ]; - # https://github.com/NixOS/nixpkgs/issues/81138 - services = { - coolercontrol-liqctld.wantedBy = [ "multi-user.target" ]; - coolercontrold.wantedBy = [ "multi-user.target" ]; + systemd = { + packages = with pkgs.coolercontrol; [ + coolercontrol-liqctld + coolercontrold + ]; + + # https://github.com/NixOS/nixpkgs/issues/81138 + services = { + coolercontrol-liqctld.wantedBy = [ "multi-user.target" ]; + coolercontrold.wantedBy = [ "multi-user.target" ]; + }; }; - }; - }) + }) - # Nvidia support - (lib.mkIf cfg.nvidiaSupport { - systemd.services.coolercontrold.path = let - nvidiaPkg = config.hardware.nvidia.package; - in [ - nvidiaPkg # nvidia-smi - nvidiaPkg.settings # nvidia-settings - ]; - }) - ]); + # Nvidia support + (lib.mkIf cfg.nvidiaSupport { + systemd.services.coolercontrold.path = + let + nvidiaPkg = config.hardware.nvidia.package; + in + [ + nvidiaPkg # nvidia-smi + nvidiaPkg.settings # nvidia-settings + ]; + }) + ] + ); - meta.maintainers = with lib.maintainers; [ OPNA2608 codifryed ]; + meta.maintainers = with lib.maintainers; [ + OPNA2608 + codifryed + ]; } diff --git a/nixos/modules/programs/cpu-energy-meter.nix b/nixos/modules/programs/cpu-energy-meter.nix index 653ec067492d7c..a54519ac8ef16c 100644 --- a/nixos/modules/programs/cpu-energy-meter.nix +++ b/nixos/modules/programs/cpu-energy-meter.nix @@ -1,8 +1,10 @@ -{ config -, lib -, pkgs -, ... -}: { +{ + config, + lib, + pkgs, + ... +}: +{ options.programs.cpu-energy-meter = { enable = lib.mkEnableOption "CPU Energy Meter"; package = lib.mkPackageOption pkgs "cpu-energy-meter" { }; diff --git a/nixos/modules/programs/criu.nix b/nixos/modules/programs/criu.nix index 492a158923cb21..8d5d2eb64f2e91 100644 --- a/nixos/modules/programs/criu.nix +++ b/nixos/modules/programs/criu.nix @@ -1,7 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: -let cfg = config.programs.criu; -in { +let + cfg = config.programs.criu; +in +{ options = { programs.criu = { diff --git a/nixos/modules/programs/darling.nix b/nixos/modules/programs/darling.nix index 194b1648b78f0a..fc9a56e1165bee 100644 --- a/nixos/modules/programs/darling.nix +++ b/nixos/modules/programs/darling.nix @@ -1,12 +1,18 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.darling; -in { +in +{ options = { programs.darling = { enable = lib.mkEnableOption "Darling, a Darwin/macOS compatibility layer for Linux"; - package = lib.mkPackageOption pkgs "darling" {}; + package = lib.mkPackageOption pkgs "darling" { }; }; }; diff --git a/nixos/modules/programs/dconf.nix b/nixos/modules/programs/dconf.nix index e6738617c8e35d..4eaa61051e7887 100644 --- a/nixos/modules/programs/dconf.nix +++ b/nixos/modules/programs/dconf.nix @@ -1,69 +1,87 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.dconf; # Compile keyfiles to dconf DB - compileDconfDb = dir: pkgs.runCommand "dconf-db" - { + compileDconfDb = + dir: + pkgs.runCommand "dconf-db" { nativeBuildInputs = [ (lib.getBin pkgs.dconf) ]; } "dconf compile $out ${dir}"; # Check if dconf keyfiles are valid - checkDconfKeyfiles = dir: pkgs.runCommand "check-dconf-keyfiles" - { - nativeBuildInputs = [ (lib.getBin pkgs.dconf) ]; - } '' - if [[ -f ${dir} ]]; then - echo "dconf keyfiles should be a directory but a file is provided: ${dir}" - exit 1 - fi - - dconf compile db ${dir} || ( - echo "The dconf keyfiles are invalid: ${dir}" - exit 1 - ) - cp -R ${dir} $out - ''; - - mkAllLocks = settings: lib.flatten ( - lib.mapAttrsToList (k: v: lib.mapAttrsToList (k': _: "/${k}/${k'}") v) settings); + checkDconfKeyfiles = + dir: + pkgs.runCommand "check-dconf-keyfiles" + { + nativeBuildInputs = [ (lib.getBin pkgs.dconf) ]; + } + '' + if [[ -f ${dir} ]]; then + echo "dconf keyfiles should be a directory but a file is provided: ${dir}" + exit 1 + fi + + dconf compile db ${dir} || ( + echo "The dconf keyfiles are invalid: ${dir}" + exit 1 + ) + cp -R ${dir} $out + ''; + + mkAllLocks = + settings: + lib.flatten (lib.mapAttrsToList (k: v: lib.mapAttrsToList (k': _: "/${k}/${k'}") v) settings); # Generate dconf DB from dconfDatabase and keyfiles - mkDconfDb = val: compileDconfDb (pkgs.symlinkJoin { - name = "nixos-generated-dconf-keyfiles"; - paths = [ - (pkgs.writeTextDir "nixos-generated-dconf-keyfiles" (lib.generators.toDconfINI val.settings)) - (pkgs.writeTextDir "locks/nixos-generated-dconf-locks" (lib.concatStringsSep "\n" - (if val.lockAll then mkAllLocks val.settings else val.locks) - )) - ] ++ (map checkDconfKeyfiles val.keyfiles); - }); + mkDconfDb = + val: + compileDconfDb ( + pkgs.symlinkJoin { + name = "nixos-generated-dconf-keyfiles"; + paths = [ + (pkgs.writeTextDir "nixos-generated-dconf-keyfiles" (lib.generators.toDconfINI val.settings)) + (pkgs.writeTextDir "locks/nixos-generated-dconf-locks" ( + lib.concatStringsSep "\n" (if val.lockAll then mkAllLocks val.settings else val.locks) + )) + ] ++ (map checkDconfKeyfiles val.keyfiles); + } + ); # Check if a dconf DB file is valid. The dconf cli doesn't return 1 when it can't # open the database file so we have to check if the output is empty. - checkDconfDb = file: pkgs.runCommand "check-dconf-db" - { - nativeBuildInputs = [ (lib.getBin pkgs.dconf) ]; - } '' - if [[ -d ${file} ]]; then - echo "dconf DB should be a file but a directory is provided: ${file}" - exit 1 - fi - - echo "file-db:${file}" > profile - DCONF_PROFILE=$(pwd)/profile dconf dump / > output 2> error - if [[ ! -s output ]] && [[ -s error ]]; then - cat error - echo "The dconf DB file is invalid: ${file}" - exit 1 - fi - - cp ${file} $out - ''; + checkDconfDb = + file: + pkgs.runCommand "check-dconf-db" + { + nativeBuildInputs = [ (lib.getBin pkgs.dconf) ]; + } + '' + if [[ -d ${file} ]]; then + echo "dconf DB should be a file but a directory is provided: ${file}" + exit 1 + fi + + echo "file-db:${file}" > profile + DCONF_PROFILE=$(pwd)/profile dconf dump / > output 2> error + if [[ ! -s output ]] && [[ -s error ]]; then + cat error + echo "The dconf DB file is invalid: ${file}" + exit 1 + fi + + cp ${file} $out + ''; # Generate dconf profile - mkDconfProfile = name: value: + mkDconfProfile = + name: value: if lib.isDerivation value || lib.isPath value then pkgs.runCommand "dconf-profile" { } '' if [[ -d ${value} ]]; then @@ -75,87 +93,95 @@ let '' else pkgs.writeTextDir "etc/dconf/profile/${name}" ( - lib.concatMapStrings (x: "${x}\n") (( - lib.optional value.enableUserDb "user-db:user" - ) ++ ( - map - (value: - let - db = if lib.isAttrs value && !lib.isDerivation value then mkDconfDb value else checkDconfDb value; - in - "file-db:${db}") - value.databases - )) + lib.concatMapStrings (x: "${x}\n") ( + (lib.optional value.enableUserDb "user-db:user") + ++ (map ( + value: + let + db = if lib.isAttrs value && !lib.isDerivation value then mkDconfDb value else checkDconfDb value; + in + "file-db:${db}" + ) value.databases) + ) ); - dconfDatabase = with lib.types; submodule { - options = { - keyfiles = lib.mkOption { - type = listOf (oneOf [ path package ]); - default = [ ]; - description = "A list of dconf keyfile directories."; - }; - settings = lib.mkOption { - type = attrs; - default = { }; - description = "An attrset used to generate dconf keyfile."; - example = literalExpression '' - with lib.gvariant; - { - "com/raggesilver/BlackBox" = { - scrollback-lines = mkUint32 10000; - theme-dark = "Tommorow Night"; - }; - } - ''; - }; - locks = lib.mkOption { - type = with lib.types; listOf str; - default = [ ]; - description = '' - A list of dconf keys to be lockdown. This doesn't take effect if `lockAll` - is set. - ''; - example = literalExpression '' - [ "/org/gnome/desktop/background/picture-uri" ] - ''; - }; - lockAll = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Lockdown all dconf keys in `settings`."; + dconfDatabase = + with lib.types; + submodule { + options = { + keyfiles = lib.mkOption { + type = listOf (oneOf [ + path + package + ]); + default = [ ]; + description = "A list of dconf keyfile directories."; + }; + settings = lib.mkOption { + type = attrs; + default = { }; + description = "An attrset used to generate dconf keyfile."; + example = literalExpression '' + with lib.gvariant; + { + "com/raggesilver/BlackBox" = { + scrollback-lines = mkUint32 10000; + theme-dark = "Tommorow Night"; + }; + } + ''; + }; + locks = lib.mkOption { + type = with lib.types; listOf str; + default = [ ]; + description = '' + A list of dconf keys to be lockdown. This doesn't take effect if `lockAll` + is set. + ''; + example = literalExpression '' + [ "/org/gnome/desktop/background/picture-uri" ] + ''; + }; + lockAll = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Lockdown all dconf keys in `settings`."; + }; }; }; - }; - dconfProfile = with lib.types; submodule { - options = { - enableUserDb = lib.mkOption { - type = bool; - default = true; - description = "Add `user-db:user` at the beginning of the profile."; - }; + dconfProfile = + with lib.types; + submodule { + options = { + enableUserDb = lib.mkOption { + type = bool; + default = true; + description = "Add `user-db:user` at the beginning of the profile."; + }; - databases = lib.mkOption { - type = with lib.types; listOf (oneOf [ - path - package - dconfDatabase - ]); - default = [ ]; - description = '' - List of data sources for the profile. An element can be an attrset, - or the path of an already compiled database. Each element is converted - to a file-db. - - A key is searched from up to down and the first result takes the - priority. If a lock for a particular key is installed then the value from - the last database in the profile where the key is locked will be used. - This can be used to enforce mandatory settings. - ''; + databases = lib.mkOption { + type = + with lib.types; + listOf (oneOf [ + path + package + dconfDatabase + ]); + default = [ ]; + description = '' + List of data sources for the profile. An element can be an attrset, + or the path of an already compiled database. Each element is converted + to a file-db. + + A key is searched from up to down and the first result takes the + priority. If a lock for a particular key is installed then the value from + the last database in the profile where the key is locked will be used. + This can be used to enforce mandatory settings. + ''; + }; }; }; - }; in { @@ -164,11 +190,13 @@ in enable = lib.mkEnableOption "dconf"; profiles = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ - path - package - dconfProfile - ]); + type = + with lib.types; + attrsOf (oneOf [ + path + package + dconfProfile + ]); default = { }; description = '' Attrset of dconf profiles. By default the `user` profile is used which diff --git a/nixos/modules/programs/digitalbitbox/default.nix b/nixos/modules/programs/digitalbitbox/default.nix index 06d33966b4a071..73cce23bbaed6f 100644 --- a/nixos/modules/programs/digitalbitbox/default.nix +++ b/nixos/modules/programs/digitalbitbox/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.digitalbitbox; diff --git a/nixos/modules/programs/dmrconfig.nix b/nixos/modules/programs/dmrconfig.nix index e2136765093aad..9f9246a51957f0 100644 --- a/nixos/modules/programs/dmrconfig.nix +++ b/nixos/modules/programs/dmrconfig.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.dmrconfig; -in { +in +{ meta.maintainers = [ ]; ###### interface diff --git a/nixos/modules/programs/droidcam.nix b/nixos/modules/programs/droidcam.nix index eef3997e6b8094..029ca34c8056fd 100644 --- a/nixos/modules/programs/droidcam.nix +++ b/nixos/modules/programs/droidcam.nix @@ -1,4 +1,9 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: { options.programs.droidcam = { @@ -9,6 +14,9 @@ environment.systemPackages = [ pkgs.droidcam ]; boot.extraModulePackages = [ config.boot.kernelPackages.v4l2loopback ]; - boot.kernelModules = [ "v4l2loopback" "snd-aloop" ]; + boot.kernelModules = [ + "v4l2loopback" + "snd-aloop" + ]; }; } diff --git a/nixos/modules/programs/dublin-traceroute.nix b/nixos/modules/programs/dublin-traceroute.nix index c764352843e789..7ba85207c2e73d 100644 --- a/nixos/modules/programs/dublin-traceroute.nix +++ b/nixos/modules/programs/dublin-traceroute.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.dublin-traceroute; -in { +in +{ meta.maintainers = pkgs.dublin-traceroute.meta.maintainers; options = { diff --git a/nixos/modules/programs/ecryptfs.nix b/nixos/modules/programs/ecryptfs.nix index 8674f7ec80e0a2..37b3699c20a869 100644 --- a/nixos/modules/programs/ecryptfs.nix +++ b/nixos/modules/programs/ecryptfs.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.ecryptfs; -in { +in +{ options.programs.ecryptfs = { enable = lib.mkEnableOption "ecryptfs setuid mount wrappers"; }; diff --git a/nixos/modules/programs/environment.nix b/nixos/modules/programs/environment.nix index 8a565b7bcac46a..698c61764f4f7f 100644 --- a/nixos/modules/programs/environment.nix +++ b/nixos/modules/programs/environment.nix @@ -14,45 +14,54 @@ in config = { - environment.variables = - { NIXPKGS_CONFIG = "/etc/nix/nixpkgs-config.nix"; - # note: many programs exec() this directly, so default options for less must not - # be specified here; do so in the default value of programs.less.envVariables instead - PAGER = lib.mkDefault "less"; - EDITOR = lib.mkDefault "nano"; - }; + environment.variables = { + NIXPKGS_CONFIG = "/etc/nix/nixpkgs-config.nix"; + # note: many programs exec() this directly, so default options for less must not + # be specified here; do so in the default value of programs.less.envVariables instead + PAGER = lib.mkDefault "less"; + EDITOR = lib.mkDefault "nano"; + }; # since we set PAGER to this above, make sure it's installed programs.less.enable = true; - environment.profiles = lib.mkAfter - [ "/nix/var/nix/profiles/default" - "/run/current-system/sw" - ]; + environment.profiles = lib.mkAfter [ + "/nix/var/nix/profiles/default" + "/run/current-system/sw" + ]; - environment.sessionVariables = - { - XDG_CONFIG_DIRS = [ "/etc/xdg" ]; # needs to be before profile-relative paths to allow changes through environment.etc - }; + environment.sessionVariables = { + XDG_CONFIG_DIRS = [ "/etc/xdg" ]; # needs to be before profile-relative paths to allow changes through environment.etc + }; # TODO: move most of these elsewhere - environment.profileRelativeSessionVariables = - { PATH = [ "/bin" ]; - INFOPATH = [ "/info" "/share/info" ]; - QTWEBKIT_PLUGIN_PATH = [ "/lib/mozilla/plugins/" ]; - GTK_PATH = [ "/lib/gtk-2.0" "/lib/gtk-3.0" "/lib/gtk-4.0" ]; - XDG_CONFIG_DIRS = [ "/etc/xdg" ]; - XDG_DATA_DIRS = [ "/share" ]; - LIBEXEC_PATH = [ "/libexec" ]; - }; - - environment.pathsToLink = [ "/lib/gtk-2.0" "/lib/gtk-3.0" "/lib/gtk-4.0" ]; - - environment.extraInit = - '' - export NIX_USER_PROFILE_DIR="/nix/var/nix/profiles/per-user/$USER" - export NIX_PROFILES="${builtins.concatStringsSep " " (lib.reverseList cfg.profiles)}" - ''; + environment.profileRelativeSessionVariables = { + PATH = [ "/bin" ]; + INFOPATH = [ + "/info" + "/share/info" + ]; + QTWEBKIT_PLUGIN_PATH = [ "/lib/mozilla/plugins/" ]; + GTK_PATH = [ + "/lib/gtk-2.0" + "/lib/gtk-3.0" + "/lib/gtk-4.0" + ]; + XDG_CONFIG_DIRS = [ "/etc/xdg" ]; + XDG_DATA_DIRS = [ "/share" ]; + LIBEXEC_PATH = [ "/libexec" ]; + }; + + environment.pathsToLink = [ + "/lib/gtk-2.0" + "/lib/gtk-3.0" + "/lib/gtk-4.0" + ]; + + environment.extraInit = '' + export NIX_USER_PROFILE_DIR="/nix/var/nix/profiles/per-user/$USER" + export NIX_PROFILES="${builtins.concatStringsSep " " (lib.reverseList cfg.profiles)}" + ''; }; diff --git a/nixos/modules/programs/envision.nix b/nixos/modules/programs/envision.nix index 56acd83d7daf8a..02f7ba5fdbebc9 100644 --- a/nixos/modules/programs/envision.nix +++ b/nixos/modules/programs/envision.nix @@ -14,7 +14,7 @@ in programs.envision = { enable = lib.mkEnableOption "envision"; - package = lib.mkPackageOption pkgs "envision" {}; + package = lib.mkPackageOption pkgs "envision" { }; openFirewall = lib.mkEnableOption "the default ports in the firewall for the WiVRn server" // { default = true; diff --git a/nixos/modules/programs/evince.nix b/nixos/modules/programs/evince.nix index a27e75e6626de5..d648c3cb16ef55 100644 --- a/nixos/modules/programs/evince.nix +++ b/nixos/modules/programs/evince.nix @@ -1,10 +1,17 @@ # Evince. -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: -let cfg = config.programs.evince; +let + cfg = config.programs.evince; -in { +in +{ ###### interface @@ -20,7 +27,6 @@ in { }; - ###### implementation config = lib.mkIf config.programs.evince.enable { diff --git a/nixos/modules/programs/extra-container.nix b/nixos/modules/programs/extra-container.nix index 6dcfba7971da24..30b0785ad47f2d 100644 --- a/nixos/modules/programs/extra-container.nix +++ b/nixos/modules/programs/extra-container.nix @@ -1,8 +1,14 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.extra-container; -in { +in +{ options = { programs.extra-container.enable = lib.mkEnableOption '' extra-container, a tool for running declarative NixOS containers diff --git a/nixos/modules/programs/fcast-receiver.nix b/nixos/modules/programs/fcast-receiver.nix index 73e13cd1bc8dcd..1ed44bce2b3402 100644 --- a/nixos/modules/programs/fcast-receiver.nix +++ b/nixos/modules/programs/fcast-receiver.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.fcast-receiver; in diff --git a/nixos/modules/programs/feedbackd.nix b/nixos/modules/programs/feedbackd.nix index 0c82c7840c8f14..e114520c48255b 100644 --- a/nixos/modules/programs/feedbackd.nix +++ b/nixos/modules/programs/feedbackd.nix @@ -1,8 +1,14 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: let cfg = config.programs.feedbackd; -in { +in +{ options = { programs.feedbackd = { enable = lib.mkEnableOption '' @@ -19,6 +25,6 @@ in { services.dbus.packages = [ cfg.package ]; services.udev.packages = [ cfg.package ]; - users.groups.feedbackd = {}; + users.groups.feedbackd = { }; }; } diff --git a/nixos/modules/programs/file-roller.nix b/nixos/modules/programs/file-roller.nix index d58af9cd59a586..d37825558e4af2 100644 --- a/nixos/modules/programs/file-roller.nix +++ b/nixos/modules/programs/file-roller.nix @@ -1,10 +1,17 @@ # File Roller. -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: -let cfg = config.programs.file-roller; +let + cfg = config.programs.file-roller; -in { +in +{ ###### interface @@ -20,7 +27,6 @@ in { }; - ###### implementation config = lib.mkIf cfg.enable { diff --git a/nixos/modules/programs/firejail.nix b/nixos/modules/programs/firejail.nix index 90da9381827486..8276f2394fd9fb 100644 --- a/nixos/modules/programs/firejail.nix +++ b/nixos/modules/programs/firejail.nix @@ -1,74 +1,97 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.firejail; - wrappedBins = pkgs.runCommand "firejail-wrapped-binaries" - { preferLocalBuild = true; - allowSubstitutes = false; - # take precedence over non-firejailed versions - meta.priority = -1; - } - '' - mkdir -p $out/bin - mkdir -p $out/share/applications - ${lib.concatStringsSep "\n" (lib.mapAttrsToList (command: value: - let - opts = if builtins.isAttrs value - then value - else { executable = value; desktop = null; profile = null; extraArgs = []; }; - args = lib.escapeShellArgs ( - opts.extraArgs - ++ (lib.optional (opts.profile != null) "--profile=${builtins.toString opts.profile}") - ); - in + wrappedBins = + pkgs.runCommand "firejail-wrapped-binaries" + { + preferLocalBuild = true; + allowSubstitutes = false; + # take precedence over non-firejailed versions + meta.priority = -1; + } '' - cat <<_EOF >$out/bin/${command} - #! ${pkgs.runtimeShell} -e - exec /run/wrappers/bin/firejail ${args} -- ${builtins.toString opts.executable} "\$@" - _EOF - chmod 0755 $out/bin/${command} + mkdir -p $out/bin + mkdir -p $out/share/applications + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList ( + command: value: + let + opts = + if builtins.isAttrs value then + value + else + { + executable = value; + desktop = null; + profile = null; + extraArgs = [ ]; + }; + args = lib.escapeShellArgs ( + opts.extraArgs + ++ (lib.optional (opts.profile != null) "--profile=${builtins.toString opts.profile}") + ); + in + '' + cat <<_EOF >$out/bin/${command} + #! ${pkgs.runtimeShell} -e + exec /run/wrappers/bin/firejail ${args} -- ${builtins.toString opts.executable} "\$@" + _EOF + chmod 0755 $out/bin/${command} - ${lib.optionalString (opts.desktop != null) '' - substitute ${opts.desktop} $out/share/applications/$(basename ${opts.desktop}) \ - --replace ${opts.executable} $out/bin/${command} - ''} - '') cfg.wrappedBinaries)} - ''; + ${lib.optionalString (opts.desktop != null) '' + substitute ${opts.desktop} $out/share/applications/$(basename ${opts.desktop}) \ + --replace ${opts.executable} $out/bin/${command} + ''} + '' + ) cfg.wrappedBinaries + )} + ''; -in { +in +{ options.programs.firejail = { enable = lib.mkEnableOption "firejail, a sandboxing tool for Linux"; wrappedBinaries = lib.mkOption { - type = lib.types.attrsOf (lib.types.either lib.types.path (lib.types.submodule { - options = { - executable = lib.mkOption { - type = lib.types.path; - description = "Executable to run sandboxed"; - example = lib.literalExpression ''"''${lib.getBin pkgs.firefox}/bin/firefox"''; - }; - desktop = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; - description = ".desktop file to modify. Only necessary if it uses the absolute path to the executable."; - example = lib.literalExpression ''"''${pkgs.firefox}/share/applications/firefox.desktop"''; - }; - profile = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; - description = "Profile to use"; - example = lib.literalExpression ''"''${pkgs.firejail}/etc/firejail/firefox.profile"''; - }; - extraArgs = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - description = "Extra arguments to pass to firejail"; - example = [ "--private=~/.firejail_home" ]; - }; - }; - })); - default = {}; + type = lib.types.attrsOf ( + lib.types.either lib.types.path ( + lib.types.submodule { + options = { + executable = lib.mkOption { + type = lib.types.path; + description = "Executable to run sandboxed"; + example = lib.literalExpression ''"''${lib.getBin pkgs.firefox}/bin/firefox"''; + }; + desktop = lib.mkOption { + type = lib.types.nullOr lib.types.path; + default = null; + description = ".desktop file to modify. Only necessary if it uses the absolute path to the executable."; + example = lib.literalExpression ''"''${pkgs.firefox}/share/applications/firefox.desktop"''; + }; + profile = lib.mkOption { + type = lib.types.nullOr lib.types.path; + default = null; + description = "Profile to use"; + example = lib.literalExpression ''"''${pkgs.firejail}/etc/firejail/firefox.profile"''; + }; + extraArgs = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + description = "Extra arguments to pass to firejail"; + example = [ "--private=~/.firejail_home" ]; + }; + }; + } + ) + ); + default = { }; example = lib.literalExpression '' { firefox = { @@ -88,12 +111,12 @@ in { }; config = lib.mkIf cfg.enable { - security.wrappers.firejail = - { setuid = true; - owner = "root"; - group = "root"; - source = "${lib.getBin pkgs.firejail}/bin/firejail"; - }; + security.wrappers.firejail = { + setuid = true; + owner = "root"; + group = "root"; + source = "${lib.getBin pkgs.firejail}/bin/firejail"; + }; environment.systemPackages = [ pkgs.firejail ] ++ [ wrappedBins ]; }; diff --git a/nixos/modules/programs/flashrom.nix b/nixos/modules/programs/flashrom.nix index dd398497c2d0d1..394b4d040a2d83 100644 --- a/nixos/modules/programs/flashrom.nix +++ b/nixos/modules/programs/flashrom.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.flashrom; diff --git a/nixos/modules/programs/flexoptix-app.nix b/nixos/modules/programs/flexoptix-app.nix index baa9e33882cae6..33801547bd7db0 100644 --- a/nixos/modules/programs/flexoptix-app.nix +++ b/nixos/modules/programs/flexoptix-app.nix @@ -1,8 +1,14 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.flexoptix-app; -in { +in +{ options = { programs.flexoptix-app = { enable = lib.mkEnableOption "FLEXOPTIX app + udev rules"; diff --git a/nixos/modules/programs/freetds.nix b/nixos/modules/programs/freetds.nix index 77daaa8fd39850..9bcae0068919bc 100644 --- a/nixos/modules/programs/freetds.nix +++ b/nixos/modules/programs/freetds.nix @@ -1,6 +1,11 @@ # Global configuration for freetds environment. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let @@ -14,7 +19,7 @@ in environment.freetds = lib.mkOption { type = lib.types.attrsOf lib.types.str; - default = {}; + default = { }; example = lib.literalExpression '' { MYDATABASE = ''' host = 10.0.2.100 @@ -30,7 +35,7 @@ in the global environment variables FREETDSCONF, FREETDS and SYBASE will be configured to allow the programs that use freetds to find the library and config. - ''; + ''; }; @@ -44,13 +49,15 @@ in environment.variables.FREETDS = "/etc/freetds.conf"; environment.variables.SYBASE = "${pkgs.freetds}"; - environment.etc."freetds.conf" = { text = - (lib.concatStrings (lib.mapAttrsToList (name: value: - '' - [${name}] - ${value} - '' - ) cfg)); + environment.etc."freetds.conf" = { + text = ( + lib.concatStrings ( + lib.mapAttrsToList (name: value: '' + [${name}] + ${value} + '') cfg + ) + ); }; }; diff --git a/nixos/modules/programs/fuse.nix b/nixos/modules/programs/fuse.nix index 7083194bd98943..1f5de484914bac 100644 --- a/nixos/modules/programs/fuse.nix +++ b/nixos/modules/programs/fuse.nix @@ -2,7 +2,8 @@ let cfg = config.programs.fuse; -in { +in +{ meta.maintainers = with lib.maintainers; [ primeos ]; options.programs.fuse = { @@ -26,7 +27,7 @@ in { }; }; - config = { + config = { environment.etc."fuse.conf".text = '' ${lib.optionalString (!cfg.userAllowOther) "#"}user_allow_other mount_max = ${builtins.toString cfg.mountMax} diff --git a/nixos/modules/programs/gamemode.nix b/nixos/modules/programs/gamemode.nix index bd3248c1c5a249..d70419c32023bc 100644 --- a/nixos/modules/programs/gamemode.nix +++ b/nixos/modules/programs/gamemode.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.gamemode; @@ -10,9 +15,11 @@ in programs.gamemode = { enable = lib.mkEnableOption "GameMode to optimise system performance on demand"; - enableRenice = lib.mkEnableOption "CAP_SYS_NICE on gamemoded to support lowering process niceness" // { - default = true; - }; + enableRenice = + lib.mkEnableOption "CAP_SYS_NICE on gamemoded to support lowering process niceness" + // { + default = true; + }; settings = lib.mkOption { type = settingsFormat.type; @@ -75,12 +82,14 @@ in # # This uses a link farm to make sure other wrapped executables # aren't included in PATH. - environment.PATH = lib.mkForce (pkgs.linkFarm "pkexec" [ - { - name = "pkexec"; - path = "${config.security.wrapperDir}/pkexec"; - } - ]); + environment.PATH = lib.mkForce ( + pkgs.linkFarm "pkexec" [ + { + name = "pkexec"; + path = "${config.security.wrapperDir}/pkexec"; + } + ] + ); serviceConfig.ExecStart = lib.mkIf cfg.enableRenice [ "" # Tell systemd to clear the existing ExecStart list, to prevent appending to it. diff --git a/nixos/modules/programs/gamescope.nix b/nixos/modules/programs/gamescope.nix index ccd4fd448a8f21..f3659ff20a40ce 100644 --- a/nixos/modules/programs/gamescope.nix +++ b/nixos/modules/programs/gamescope.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let cfg = config.programs.gamescope; @@ -9,8 +10,7 @@ let gamescope = let wrapperArgs = - lib.optional (cfg.args != [ ]) - ''--add-flags "${builtins.toString cfg.args}"'' + lib.optional (cfg.args != [ ]) ''--add-flags "${builtins.toString cfg.args}"'' ++ builtins.attrValues (builtins.mapAttrs (var: val: "--set-default ${var} ${val}") cfg.env); in pkgs.runCommand "gamescope" { nativeBuildInputs = [ pkgs.makeBinaryWrapper ]; } '' @@ -38,7 +38,10 @@ in args = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "--rt" "--prefer-vk-device 8086:9bc4" ]; + example = [ + "--rt" + "--prefer-vk-device 8086:9bc4" + ]; description = '' Arguments passed to GameScope on startup. ''; diff --git a/nixos/modules/programs/gdk-pixbuf.nix b/nixos/modules/programs/gdk-pixbuf.nix index f96259ccd2c783..9f141b61c2945f 100644 --- a/nixos/modules/programs/gdk-pixbuf.nix +++ b/nixos/modules/programs/gdk-pixbuf.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.gdk-pixbuf; @@ -24,7 +29,7 @@ in # If there is any package configured in modulePackages, we generate the # loaders.cache based on that and set the environment variable # GDK_PIXBUF_MODULE_FILE to point to it. - config = lib.mkIf (cfg.modulePackages != []) { + config = lib.mkIf (cfg.modulePackages != [ ]) { environment.sessionVariables = { GDK_PIXBUF_MODULE_FILE = loadersCache; }; diff --git a/nixos/modules/programs/geary.nix b/nixos/modules/programs/geary.nix index 7c22d88a9ad55d..0cbfe5b0605ca8 100644 --- a/nixos/modules/programs/geary.nix +++ b/nixos/modules/programs/geary.nix @@ -1,9 +1,15 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.geary; -in { +in +{ meta = { maintainers = lib.teams.gnome.members; }; @@ -19,4 +25,3 @@ in { services.gnome.gnome-online-accounts.enable = true; }; } - diff --git a/nixos/modules/programs/gnome-disks.nix b/nixos/modules/programs/gnome-disks.nix index 8c0cee906c5646..e6f93c6fdfe6d7 100644 --- a/nixos/modules/programs/gnome-disks.nix +++ b/nixos/modules/programs/gnome-disks.nix @@ -1,6 +1,11 @@ # GNOME Disks. -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { @@ -27,7 +32,6 @@ }; - ###### implementation config = lib.mkIf config.programs.gnome-disks.enable { diff --git a/nixos/modules/programs/gnome-terminal.nix b/nixos/modules/programs/gnome-terminal.nix index a065adfe61c4ff..aea0e97c36340b 100644 --- a/nixos/modules/programs/gnome-terminal.nix +++ b/nixos/modules/programs/gnome-terminal.nix @@ -1,6 +1,11 @@ # GNOME Terminal. -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let diff --git a/nixos/modules/programs/gnupg.nix b/nixos/modules/programs/gnupg.nix index 97cd47ba3eb8a1..a6fbd081f44a7b 100644 --- a/nixos/modules/programs/gnupg.nix +++ b/nixos/modules/programs/gnupg.nix @@ -1,7 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkRemovedOptionModule mkOption mkPackageOption types mkIf optionalString; + inherit (lib) + mkRemovedOptionModule + mkOption + mkPackageOption + types + mkIf + optionalString + ; cfg = config.programs.gnupg; @@ -11,7 +23,12 @@ let in { imports = [ - (mkRemovedOptionModule [ "programs" "gnupg" "agent" "pinentryFlavor" ] "Use programs.gnupg.agent.pinentryPackage instead") + (mkRemovedOptionModule [ + "programs" + "gnupg" + "agent" + "pinentryFlavor" + ] "Use programs.gnupg.agent.pinentryPackage instead") ]; options.programs.gnupg = { @@ -191,7 +208,9 @@ in wantedBy = [ "sockets.target" ]; }; - services.dbus.packages = mkIf (lib.elem "gnome3" (cfg.agent.pinentryPackage.flavors or [])) [ pkgs.gcr ]; + services.dbus.packages = mkIf (lib.elem "gnome3" (cfg.agent.pinentryPackage.flavors or [ ])) [ + pkgs.gcr + ]; environment.systemPackages = [ cfg.package ]; diff --git a/nixos/modules/programs/goldwarden.nix b/nixos/modules/programs/goldwarden.nix index 26f9a87c1986f1..f7f1ece28e9df9 100644 --- a/nixos/modules/programs/goldwarden.nix +++ b/nixos/modules/programs/goldwarden.nix @@ -1,24 +1,35 @@ -{ lib, config, pkgs, ... }: +{ + lib, + config, + pkgs, + ... +}: let cfg = config.programs.goldwarden; in { options.programs.goldwarden = { enable = lib.mkEnableOption "Goldwarden"; - package = lib.mkPackageOption pkgs "goldwarden" {}; - useSshAgent = lib.mkEnableOption "Goldwarden's SSH Agent" // { default = true; }; + package = lib.mkPackageOption pkgs "goldwarden" { }; + useSshAgent = lib.mkEnableOption "Goldwarden's SSH Agent" // { + default = true; + }; }; config = lib.mkIf cfg.enable { - assertions = [{ - assertion = cfg.useSshAgent -> !config.programs.ssh.startAgent; - message = "Only one ssh-agent can be used at a time."; - }]; + assertions = [ + { + assertion = cfg.useSshAgent -> !config.programs.ssh.startAgent; + message = "Only one ssh-agent can be used at a time."; + } + ]; environment = { etc = lib.mkIf config.programs.chromium.enable { - "chromium/native-messaging-hosts/com.8bit.bitwarden.json".source = "${cfg.package}/etc/chromium/native-messaging-hosts/com.8bit.bitwarden.json"; - "opt/chrome/native-messaging-hosts/com.8bit.bitwarden.json".source = "${cfg.package}/etc/chrome/native-messaging-hosts/com.8bit.bitwarden.json"; + "chromium/native-messaging-hosts/com.8bit.bitwarden.json".source = + "${cfg.package}/etc/chromium/native-messaging-hosts/com.8bit.bitwarden.json"; + "opt/chrome/native-messaging-hosts/com.8bit.bitwarden.json".source = + "${cfg.package}/etc/chrome/native-messaging-hosts/com.8bit.bitwarden.json"; }; extraInit = lib.mkIf cfg.useSshAgent '' diff --git a/nixos/modules/programs/gpaste.nix b/nixos/modules/programs/gpaste.nix index f0c3baf10da031..042bd812cca79a 100644 --- a/nixos/modules/programs/gpaste.nix +++ b/nixos/modules/programs/gpaste.nix @@ -1,11 +1,16 @@ # GPaste. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { ###### interface options = { - programs.gpaste = { + programs.gpaste = { enable = lib.mkOption { type = lib.types.bool; default = false; diff --git a/nixos/modules/programs/haguichi.nix b/nixos/modules/programs/haguichi.nix index fd769ac8d0a032..39b28cc7f04722 100644 --- a/nixos/modules/programs/haguichi.nix +++ b/nixos/modules/programs/haguichi.nix @@ -1,4 +1,9 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: { options.programs.haguichi = { diff --git a/nixos/modules/programs/hamster.nix b/nixos/modules/programs/hamster.nix index 90cfc0f86a246a..d21ca4825a4663 100644 --- a/nixos/modules/programs/hamster.nix +++ b/nixos/modules/programs/hamster.nix @@ -1,10 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { meta.maintainers = pkgs.hamster.meta.maintainers; - options.programs.hamster.enable = - lib.mkEnableOption "hamster, a time tracking program"; + options.programs.hamster.enable = lib.mkEnableOption "hamster, a time tracking program"; config = lib.mkIf config.programs.hamster.enable { environment.systemPackages = [ pkgs.hamster ]; diff --git a/nixos/modules/programs/htop.nix b/nixos/modules/programs/htop.nix index 1252b41e8b8513..62fb4a4fe57bd8 100644 --- a/nixos/modules/programs/htop.nix +++ b/nixos/modules/programs/htop.nix @@ -1,15 +1,26 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.htop; - fmt = value: - if builtins.isList value then builtins.concatStringsSep " " (builtins.map fmt value) else - if builtins.isString value then value else - if builtins.isBool value then if value then "1" else "0" else - if builtins.isInt value then builtins.toString value else - throw "Unrecognized type ${builtins.typeOf value} in htop settings"; + fmt = + value: + if builtins.isList value then + builtins.concatStringsSep " " (builtins.map fmt value) + else if builtins.isString value then + value + else if builtins.isBool value then + if value then "1" else "0" + else if builtins.isInt value then + builtins.toString value + else + throw "Unrecognized type ${builtins.typeOf value} in htop settings"; in @@ -21,8 +32,19 @@ in enable = lib.mkEnableOption "htop process monitor"; settings = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ str int bool (listOf (oneOf [ str int bool ])) ]); - default = {}; + type = + with lib.types; + attrsOf (oneOf [ + str + int + bool + (listOf (oneOf [ + str + int + bool + ])) + ]); + default = { }; example = { hide_kernel_threads = true; hide_userland_threads = true; @@ -41,10 +63,14 @@ in cfg.package ]; - environment.etc."htoprc".text = '' - # Global htop configuration - # To change set: programs.htop.settings.KEY = VALUE; - '' + builtins.concatStringsSep "\n" (lib.mapAttrsToList (key: value: "${key}=${fmt value}") cfg.settings); + environment.etc."htoprc".text = + '' + # Global htop configuration + # To change set: programs.htop.settings.KEY = VALUE; + '' + + builtins.concatStringsSep "\n" ( + lib.mapAttrsToList (key: value: "${key}=${fmt value}") cfg.settings + ); }; } diff --git a/nixos/modules/programs/i3lock.nix b/nixos/modules/programs/i3lock.nix index ff616144e28348..1b4091abaac3f5 100644 --- a/nixos/modules/programs/i3lock.nix +++ b/nixos/modules/programs/i3lock.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.i3lock; -in { +in +{ ###### interface @@ -20,9 +26,9 @@ in { ''; }; u2fSupport = lib.mkOption { - type = lib.types.bool; - default = false; - example = true; + type = lib.types.bool; + default = false; + example = true; description = '' Whether to enable U2F support in the i3lock program. U2F enables authentication using a hardware device, such as a security key. diff --git a/nixos/modules/programs/iay.nix b/nixos/modules/programs/iay.nix index bbd401144311c1..adc8014fbfa295 100644 --- a/nixos/modules/programs/iay.nix +++ b/nixos/modules/programs/iay.nix @@ -1,12 +1,25 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.iay; - inherit (lib) mkEnableOption mkIf mkOption mkPackageOption optionalString types; -in { + inherit (lib) + mkEnableOption + mkIf + mkOption + mkPackageOption + optionalString + types + ; +in +{ options.programs.iay = { enable = mkEnableOption "iay, a minimalistic shell prompt"; - package = mkPackageOption pkgs "iay" {}; + package = mkPackageOption pkgs "iay" { }; minimalPrompt = mkOption { type = types.bool; diff --git a/nixos/modules/programs/joycond-cemuhook.nix b/nixos/modules/programs/joycond-cemuhook.nix index c01a00478113a3..d26aad543c4128 100644 --- a/nixos/modules/programs/joycond-cemuhook.nix +++ b/nixos/modules/programs/joycond-cemuhook.nix @@ -1,4 +1,9 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: { options.programs.joycond-cemuhook = { enable = lib.mkEnableOption "joycond-cemuhook, a program to enable support for cemuhook's UDP protocol for joycond devices"; diff --git a/nixos/modules/programs/k40-whisperer.nix b/nixos/modules/programs/k40-whisperer.nix index 0f29c476cbb792..cd9159d62bdf3e 100644 --- a/nixos/modules/programs/k40-whisperer.nix +++ b/nixos/modules/programs/k40-whisperer.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.k40-whisperer; @@ -22,7 +27,7 @@ in }; config = lib.mkIf cfg.enable { - users.groups.${cfg.group} = {}; + users.groups.${cfg.group} = { }; environment.systemPackages = [ pkg ]; services.udev.packages = [ pkg ]; diff --git a/nixos/modules/programs/kbdlight.nix b/nixos/modules/programs/kbdlight.nix index 934bb214c11661..567f76bdeedad3 100644 --- a/nixos/modules/programs/kbdlight.nix +++ b/nixos/modules/programs/kbdlight.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.kbdlight; @@ -9,11 +14,11 @@ in config = lib.mkIf cfg.enable { environment.systemPackages = [ pkgs.kbdlight ]; - security.wrappers.kbdlight = - { setuid = true; - owner = "root"; - group = "root"; - source = "${pkgs.kbdlight.out}/bin/kbdlight"; - }; + security.wrappers.kbdlight = { + setuid = true; + owner = "root"; + group = "root"; + source = "${pkgs.kbdlight.out}/bin/kbdlight"; + }; }; } diff --git a/nixos/modules/programs/kclock.nix b/nixos/modules/programs/kclock.nix index b69f358ec1ff94..9f40d71a905549 100644 --- a/nixos/modules/programs/kclock.nix +++ b/nixos/modules/programs/kclock.nix @@ -1,9 +1,17 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: let cfg = config.programs.kclock; kclockPkg = pkgs.libsForQt5.kclock; -in { - options.programs.kclock = { enable = lib.mkEnableOption "KClock"; }; +in +{ + options.programs.kclock = { + enable = lib.mkEnableOption "KClock"; + }; config = lib.mkIf cfg.enable { services.dbus.packages = [ kclockPkg ]; diff --git a/nixos/modules/programs/kde-pim.nix b/nixos/modules/programs/kde-pim.nix index af3c45b690c201..d0acaddd4b8748 100644 --- a/nixos/modules/programs/kde-pim.nix +++ b/nixos/modules/programs/kde-pim.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.kde-pim; @@ -12,19 +17,24 @@ in }; config = lib.mkIf cfg.enable { - environment.systemPackages = with pkgs.kdePackages; [ - # core packages - akonadi - kdepim-runtime - ] ++ lib.optionals cfg.kmail [ - akonadiconsole - akonadi-search - kmail - kmail-account-wizard - ] ++ lib.optionals cfg.kontact [ - kontact - ] ++ lib.optionals cfg.merkuro [ - merkuro - ]; + environment.systemPackages = + with pkgs.kdePackages; + [ + # core packages + akonadi + kdepim-runtime + ] + ++ lib.optionals cfg.kmail [ + akonadiconsole + akonadi-search + kmail + kmail-account-wizard + ] + ++ lib.optionals cfg.kontact [ + kontact + ] + ++ lib.optionals cfg.merkuro [ + merkuro + ]; }; } diff --git a/nixos/modules/programs/kdeconnect.nix b/nixos/modules/programs/kdeconnect.nix index 76bba40103084a..17bb384a9fea63 100644 --- a/nixos/modules/programs/kdeconnect.nix +++ b/nixos/modules/programs/kdeconnect.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { options.programs.kdeconnect = { enable = lib.mkEnableOption '' @@ -18,13 +23,18 @@ let cfg = config.programs.kdeconnect; in - lib.mkIf cfg.enable { - environment.systemPackages = [ - cfg.package + lib.mkIf cfg.enable { + environment.systemPackages = [ + cfg.package + ]; + networking.firewall = rec { + allowedTCPPortRanges = [ + { + from = 1714; + to = 1764; + } ]; - networking.firewall = rec { - allowedTCPPortRanges = [ { from = 1714; to = 1764; } ]; - allowedUDPPortRanges = allowedTCPPortRanges; - }; + allowedUDPPortRanges = allowedTCPPortRanges; }; + }; } diff --git a/nixos/modules/programs/kubeswitch.nix b/nixos/modules/programs/kubeswitch.nix index 9348540022f23f..4a86f68a0d0b9a 100644 --- a/nixos/modules/programs/kubeswitch.nix +++ b/nixos/modules/programs/kubeswitch.nix @@ -29,7 +29,7 @@ in config = let - shell_files = pkgs.runCommand "kubeswitch-shell-files" {} '' + shell_files = pkgs.runCommand "kubeswitch-shell-files" { } '' mkdir -p $out/share for shell in bash zsh; do ${cfg.package}/bin/switcher init $shell | sed 's/switch(/${cfg.commandName}(/' > $out/share/${cfg.commandName}_init.$shell diff --git a/nixos/modules/programs/ladybird.nix b/nixos/modules/programs/ladybird.nix index 43bfe445ef58e3..20183f55c9820c 100644 --- a/nixos/modules/programs/ladybird.nix +++ b/nixos/modules/programs/ladybird.nix @@ -1,8 +1,14 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.ladybird; -in { +in +{ options = { programs.ladybird.enable = lib.mkEnableOption "the Ladybird web browser"; }; diff --git a/nixos/modules/programs/lazygit.nix b/nixos/modules/programs/lazygit.nix index 3e36a0e0c4a8f1..06252f1f1ef51f 100644 --- a/nixos/modules/programs/lazygit.nix +++ b/nixos/modules/programs/lazygit.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.lazygit; diff --git a/nixos/modules/programs/less.nix b/nixos/modules/programs/less.nix index 50ea1586f6880c..e0da6bb52bc81c 100644 --- a/nixos/modules/programs/less.nix +++ b/nixos/modules/programs/less.nix @@ -1,26 +1,35 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.less; - configText = if (cfg.configFile != null) then (builtins.readFile cfg.configFile) else '' - #command - ${builtins.concatStringsSep "\n" - (lib.mapAttrsToList (command: action: "${command} ${action}") cfg.commands) - } - ${lib.optionalString cfg.clearDefaultCommands "#stop"} - - #line-edit - ${builtins.concatStringsSep "\n" - (lib.mapAttrsToList (command: action: "${command} ${action}") cfg.lineEditingKeys) - } - - #env - ${builtins.concatStringsSep "\n" - (lib.mapAttrsToList (variable: values: "${variable}=${values}") cfg.envVariables) - } - ''; + configText = + if (cfg.configFile != null) then + (builtins.readFile cfg.configFile) + else + '' + #command + ${builtins.concatStringsSep "\n" ( + lib.mapAttrsToList (command: action: "${command} ${action}") cfg.commands + )} + ${lib.optionalString cfg.clearDefaultCommands "#stop"} + + #line-edit + ${builtins.concatStringsSep "\n" ( + lib.mapAttrsToList (command: action: "${command} ${action}") cfg.lineEditingKeys + )} + + #env + ${builtins.concatStringsSep "\n" ( + lib.mapAttrsToList (variable: values: "${variable}=${values}") cfg.envVariables + )} + ''; lessKey = pkgs.writeText "lessconfig" configText; @@ -52,7 +61,7 @@ in commands = lib.mkOption { type = lib.types.attrsOf lib.types.str; - default = {}; + default = { }; example = { h = "noaction 5\\e("; l = "noaction 5\\e)"; @@ -72,7 +81,7 @@ in lineEditingKeys = lib.mkOption { type = lib.types.attrsOf lib.types.str; - default = {}; + default = { }; example = { e = "abort"; }; @@ -114,20 +123,24 @@ in environment.systemPackages = [ cfg.package ]; - environment.variables = { - LESSKEYIN_SYSTEM = builtins.toString lessKey; - } // lib.optionalAttrs (cfg.lessopen != null) { - LESSOPEN = cfg.lessopen; - } // lib.optionalAttrs (cfg.lessclose != null) { - LESSCLOSE = cfg.lessclose; - }; + environment.variables = + { + LESSKEYIN_SYSTEM = builtins.toString lessKey; + } + // lib.optionalAttrs (cfg.lessopen != null) { + LESSOPEN = cfg.lessopen; + } + // lib.optionalAttrs (cfg.lessclose != null) { + LESSCLOSE = cfg.lessclose; + }; - warnings = lib.optional ( - cfg.clearDefaultCommands && (builtins.all (x: x != "quit") (builtins.attrValues cfg.commands)) - ) '' - config.programs.less.clearDefaultCommands clears all default commands of less but there is no alternative binding for exiting. - Consider adding a binding for 'quit'. - ''; + warnings = + lib.optional + (cfg.clearDefaultCommands && (builtins.all (x: x != "quit") (builtins.attrValues cfg.commands))) + '' + config.programs.less.clearDefaultCommands clears all default commands of less but there is no alternative binding for exiting. + Consider adding a binding for 'quit'. + ''; }; meta.maintainers = with lib.maintainers; [ johnazoidberg ]; diff --git a/nixos/modules/programs/liboping.nix b/nixos/modules/programs/liboping.nix index 5ff9ad74b15843..1bab0dcda5b209 100644 --- a/nixos/modules/programs/liboping.nix +++ b/nixos/modules/programs/liboping.nix @@ -1,22 +1,33 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.liboping; -in { +in +{ options.programs.liboping = { enable = lib.mkEnableOption "liboping"; }; config = lib.mkIf cfg.enable { environment.systemPackages = with pkgs; [ liboping ]; - security.wrappers = lib.mkMerge (builtins.map ( - exec: { - "${exec}" = { - owner = "root"; - group = "root"; - capabilities = "cap_net_raw+p"; - source = "${pkgs.liboping}/bin/${exec}"; - }; - } - ) [ "oping" "noping" ]); + security.wrappers = lib.mkMerge ( + builtins.map + (exec: { + "${exec}" = { + owner = "root"; + group = "root"; + capabilities = "cap_net_raw+p"; + source = "${pkgs.liboping}/bin/${exec}"; + }; + }) + [ + "oping" + "noping" + ] + ); }; } diff --git a/nixos/modules/programs/light.nix b/nixos/modules/programs/light.nix index 29fcc98a8e0ada..f86aeeb390a74e 100644 --- a/nixos/modules/programs/light.nix +++ b/nixos/modules/programs/light.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.light; @@ -54,22 +59,24 @@ in services.udev.packages = [ pkgs.light ]; services.actkbd = lib.mkIf cfg.brightnessKeys.enable { enable = true; - bindings = let - light = "${pkgs.light}/bin/light"; - step = builtins.toString cfg.brightnessKeys.step; - in [ - { - keys = [ 224 ]; - events = [ "key" ]; - # Use minimum brightness 0.1 so the display won't go totally black. - command = "${light} -N 0.1 && ${light} -U ${step}"; - } - { - keys = [ 225 ]; - events = [ "key" ]; - command = "${light} -A ${step}"; - } - ]; + bindings = + let + light = "${pkgs.light}/bin/light"; + step = builtins.toString cfg.brightnessKeys.step; + in + [ + { + keys = [ 224 ]; + events = [ "key" ]; + # Use minimum brightness 0.1 so the display won't go totally black. + command = "${light} -N 0.1 && ${light} -U ${step}"; + } + { + keys = [ 225 ]; + events = [ "key" ]; + command = "${light} -A ${step}"; + } + ]; }; }; } diff --git a/nixos/modules/programs/mdevctl.nix b/nixos/modules/programs/mdevctl.nix index a7e7d01dffdfc4..f967b7487b2ab0 100644 --- a/nixos/modules/programs/mdevctl.nix +++ b/nixos/modules/programs/mdevctl.nix @@ -1,8 +1,14 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.mdevctl; -in { +in +{ options.programs.mdevctl = { enable = lib.mkEnableOption "Mediated Device Management"; }; diff --git a/nixos/modules/programs/mepo.nix b/nixos/modules/programs/mepo.nix index 783d2ad1496266..d28e1941fd5676 100644 --- a/nixos/modules/programs/mepo.nix +++ b/nixos/modules/programs/mepo.nix @@ -1,4 +1,9 @@ -{ pkgs, config, lib, ...}: +{ + pkgs, + config, + lib, + ... +}: let cfg = config.programs.mepo; in @@ -25,10 +30,13 @@ in }; config = lib.mkIf cfg.enable { - environment.systemPackages = with pkgs; [ - mepo - ] ++ lib.optional cfg.locationBackends.geoclue geoclue2-with-demo-agent - ++ lib.optional cfg.locationBackends.gpsd gpsd; + environment.systemPackages = + with pkgs; + [ + mepo + ] + ++ lib.optional cfg.locationBackends.geoclue geoclue2-with-demo-agent + ++ lib.optional cfg.locationBackends.gpsd gpsd; services.geoclue2 = lib.mkIf cfg.locationBackends.geoclue { enable = true; diff --git a/nixos/modules/programs/mininet.nix b/nixos/modules/programs/mininet.nix index ab862b21fe0213..e68000f57c9997 100644 --- a/nixos/modules/programs/mininet.nix +++ b/nixos/modules/programs/mininet.nix @@ -1,6 +1,11 @@ # Global configuration for mininet # kernel must have NETNS/VETH/SCHED -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.mininet; diff --git a/nixos/modules/programs/minipro.nix b/nixos/modules/programs/minipro.nix index e5846d13fa40f8..8b994226e9a010 100644 --- a/nixos/modules/programs/minipro.nix +++ b/nixos/modules/programs/minipro.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.minipro; diff --git a/nixos/modules/programs/miriway.nix b/nixos/modules/programs/miriway.nix index b3d103f8a89d8e..ab7bccad18eabc 100644 --- a/nixos/modules/programs/miriway.nix +++ b/nixos/modules/programs/miriway.nix @@ -1,8 +1,14 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.miriway; -in { +in +{ options.programs.miriway = { enable = lib.mkEnableOption '' Miriway, a Mir based Wayland compositor. You can manually launch Miriway by diff --git a/nixos/modules/programs/mosh.nix b/nixos/modules/programs/mosh.nix index 897bcf941a5d09..44d990c3a59767 100644 --- a/nixos/modules/programs/mosh.nix +++ b/nixos/modules/programs/mosh.nix @@ -1,8 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - cfg = config.programs.mosh; + cfg = config.programs.mosh; in { @@ -25,7 +30,10 @@ in config = lib.mkIf cfg.enable { environment.systemPackages = [ pkgs.mosh ]; - networking.firewall.allowedUDPPortRanges = lib.optional cfg.openFirewall { from = 60000; to = 61000; }; + networking.firewall.allowedUDPPortRanges = lib.optional cfg.openFirewall { + from = 60000; + to = 61000; + }; security.wrappers = lib.mkIf cfg.withUtempter { utempter = { source = "${pkgs.libutempter}/lib/utempter/utempter"; diff --git a/nixos/modules/programs/mouse-actions.nix b/nixos/modules/programs/mouse-actions.nix index 297cc4d3bfe798..3022a1059b1f9c 100644 --- a/nixos/modules/programs/mouse-actions.nix +++ b/nixos/modules/programs/mouse-actions.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.mouse-actions; @@ -26,7 +31,7 @@ in config = lib.mkIf cfg.enable { environment.systemPackages = [ cfg.package ]; services.udev.packages = [ cfg.package ]; - systemd.user.services.mouse-actions = lib.mkIf cfg.autorun { + systemd.user.services.mouse-actions = lib.mkIf cfg.autorun { description = "mouse-actions launcher"; wantedBy = [ "graphical-session.target" ]; bindsTo = [ "graphical-session.target" ]; diff --git a/nixos/modules/programs/msmtp.nix b/nixos/modules/programs/msmtp.nix index 8a04acb3b7ea6f..b68f1cbeb9cca7 100644 --- a/nixos/modules/programs/msmtp.nix +++ b/nixos/modules/programs/msmtp.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.msmtp; -in { +in +{ meta.maintainers = with lib.maintainers; [ pacien ]; options = { @@ -20,7 +26,7 @@ in { defaults = lib.mkOption { type = lib.types.attrs; - default = {}; + default = { }; example = { aliases = "/etc/aliases"; port = 587; @@ -34,7 +40,7 @@ in { accounts = lib.mkOption { type = with lib.types; attrsOf attrs; - default = {}; + default = { }; example = { "default" = { host = "smtp.example"; @@ -80,25 +86,31 @@ in { group = "root"; }; - environment.etc."msmtprc".text = let - mkValueString = v: - if v == true then "on" - else if v == false then "off" - else lib.generators.mkValueStringDefault {} v; - mkKeyValueString = k: v: "${k} ${mkValueString v}"; - mkInnerSectionString = - attrs: builtins.concatStringsSep "\n" (lib.mapAttrsToList mkKeyValueString attrs); - mkAccountString = name: attrs: '' - account ${name} - ${mkInnerSectionString attrs} - ''; - in '' - defaults - ${mkInnerSectionString cfg.defaults} + environment.etc."msmtprc".text = + let + mkValueString = + v: + if v == true then + "on" + else if v == false then + "off" + else + lib.generators.mkValueStringDefault { } v; + mkKeyValueString = k: v: "${k} ${mkValueString v}"; + mkInnerSectionString = + attrs: builtins.concatStringsSep "\n" (lib.mapAttrsToList mkKeyValueString attrs); + mkAccountString = name: attrs: '' + account ${name} + ${mkInnerSectionString attrs} + ''; + in + '' + defaults + ${mkInnerSectionString cfg.defaults} - ${builtins.concatStringsSep "\n" (lib.mapAttrsToList mkAccountString cfg.accounts)} + ${builtins.concatStringsSep "\n" (lib.mapAttrsToList mkAccountString cfg.accounts)} - ${cfg.extraConfig} - ''; + ${cfg.extraConfig} + ''; }; } diff --git a/nixos/modules/programs/mtr.nix b/nixos/modules/programs/mtr.nix index 1a9deba9896632..a9bdffd9f39d4e 100644 --- a/nixos/modules/programs/mtr.nix +++ b/nixos/modules/programs/mtr.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.mtr; -in { +in +{ options = { programs.mtr = { enable = lib.mkOption { diff --git a/nixos/modules/programs/nbd.nix b/nixos/modules/programs/nbd.nix index 1e319f02734550..caf26469ca6029 100644 --- a/nixos/modules/programs/nbd.nix +++ b/nixos/modules/programs/nbd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.nbd; diff --git a/nixos/modules/programs/neovim.nix b/nixos/modules/programs/neovim.nix index 142cca9f322a3f..9a3e47fb11d666 100644 --- a/nixos/modules/programs/neovim.nix +++ b/nixos/modules/programs/neovim.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.neovim; @@ -102,45 +107,49 @@ in Set of files that have to be linked in {file}`runtime`. ''; - type = with lib.types; attrsOf (submodule ( - { name, config, ... }: - { - options = { - - enable = lib.mkOption { - type = lib.types.bool; - default = true; - description = '' - Whether this runtime directory should be generated. This - option allows specific runtime files to be disabled. - ''; - }; - - target = lib.mkOption { - type = lib.types.str; - description = '' - Name of symlink. Defaults to the attribute - name. - ''; - }; - - text = lib.mkOption { - default = null; - type = lib.types.nullOr lib.types.lines; - description = "Text of the file."; - }; - - source = lib.mkOption { - default = null; - type = lib.types.nullOr lib.types.path; - description = "Path of the source file."; - }; - - }; - - config.target = lib.mkDefault name; - } - )); + type = + with lib.types; + attrsOf ( + submodule ( + { name, config, ... }: + { + options = { + + enable = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Whether this runtime directory should be generated. This + option allows specific runtime files to be disabled. + ''; + }; + + target = lib.mkOption { + type = lib.types.str; + description = '' + Name of symlink. Defaults to the attribute + name. + ''; + }; + + text = lib.mkOption { + default = null; + type = lib.types.nullOr lib.types.lines; + description = "Text of the file."; + }; + + source = lib.mkOption { + default = null; + type = lib.types.nullOr lib.types.path; + description = "Path of the source file."; + }; + + }; + + config.target = lib.mkDefault name; + } + ) + ); }; }; @@ -155,19 +164,29 @@ in # from other packages will be used by neovim. environment.pathsToLink = [ "/share/nvim" ]; - environment.etc = builtins.listToAttrs (builtins.attrValues (builtins.mapAttrs - (name: value: { - name = "xdg/nvim/${name}"; - value = builtins.removeAttrs - (value // { - target = "xdg/nvim/${value.target}"; - }) - (lib.optionals (builtins.isNull value.source) [ "source" ]); - }) - cfg.runtime)); + environment.etc = builtins.listToAttrs ( + builtins.attrValues ( + builtins.mapAttrs (name: value: { + name = "xdg/nvim/${name}"; + value = builtins.removeAttrs ( + value + // { + target = "xdg/nvim/${value.target}"; + } + ) (lib.optionals (builtins.isNull value.source) [ "source" ]); + }) cfg.runtime + ) + ); programs.neovim.finalPackage = pkgs.wrapNeovim cfg.package { - inherit (cfg) viAlias vimAlias withPython3 withNodeJs withRuby configure; + inherit (cfg) + viAlias + vimAlias + withPython3 + withNodeJs + withRuby + configure + ; }; }; } diff --git a/nixos/modules/programs/nethoscope.nix b/nixos/modules/programs/nethoscope.nix index 7bc1f61b31eae5..f73d7320819e9c 100644 --- a/nixos/modules/programs/nethoscope.nix +++ b/nixos/modules/programs/nethoscope.nix @@ -1,6 +1,12 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: -let cfg = config.programs.nethoscope; +let + cfg = config.programs.nethoscope; in { meta.maintainers = with lib.maintainers; [ _0x4A6F ]; diff --git a/nixos/modules/programs/nexttrace.nix b/nixos/modules/programs/nexttrace.nix index 9380a988088bf3..b7e5a8838f451f 100644 --- a/nixos/modules/programs/nexttrace.nix +++ b/nixos/modules/programs/nexttrace.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.nexttrace; diff --git a/nixos/modules/programs/nh.nix b/nixos/modules/programs/nh.nix index c42fb2fc724a75..21ffa5cc17d2c9 100644 --- a/nixos/modules/programs/nh.nix +++ b/nixos/modules/programs/nh.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let cfg = config.programs.nh; @@ -53,9 +54,12 @@ in config = { warnings = - if (!(cfg.clean.enable -> !config.nix.gc.automatic)) then [ - "programs.nh.clean.enable and nix.gc.automatic are both enabled. Please use one or the other to avoid conflict." - ] else [ ]; + if (!(cfg.clean.enable -> !config.nix.gc.automatic)) then + [ + "programs.nh.clean.enable and nix.gc.automatic are both enabled. Please use one or the other to avoid conflict." + ] + else + [ ]; assertions = [ # Not strictly required but probably a good assertion to have diff --git a/nixos/modules/programs/nix-index.nix b/nixos/modules/programs/nix-index.nix index 76d7c3d8c532a8..21e9eb9e176567 100644 --- a/nixos/modules/programs/nix-index.nix +++ b/nixos/modules/programs/nix-index.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.nix-index; -in { +in +{ options.programs.nix-index = with lib; { enable = mkEnableOption "nix-index, a file database for nixpkgs"; @@ -21,15 +27,20 @@ in { }; config = lib.mkIf cfg.enable { - assertions = let - checkOpt = name: { - assertion = cfg.${name} -> !config.programs.command-not-found.enable; - message = '' - The 'programs.command-not-found.enable' option is mutually exclusive - with the 'programs.nix-index.${name}' option. - ''; - }; - in [ (checkOpt "enableBashIntegration") (checkOpt "enableZshIntegration") ]; + assertions = + let + checkOpt = name: { + assertion = cfg.${name} -> !config.programs.command-not-found.enable; + message = '' + The 'programs.command-not-found.enable' option is mutually exclusive + with the 'programs.nix-index.${name}' option. + ''; + }; + in + [ + (checkOpt "enableBashIntegration") + (checkOpt "enableZshIntegration") + ]; environment.systemPackages = [ cfg.package ]; @@ -42,16 +53,18 @@ in { ''; # See https://github.com/bennofs/nix-index/issues/126 - programs.fish.interactiveShellInit = let - wrapper = pkgs.writeScript "command-not-found" '' - #!${pkgs.bash}/bin/bash - source ${cfg.package}/etc/profile.d/command-not-found.sh - command_not_found_handle "$@" + programs.fish.interactiveShellInit = + let + wrapper = pkgs.writeScript "command-not-found" '' + #!${pkgs.bash}/bin/bash + source ${cfg.package}/etc/profile.d/command-not-found.sh + command_not_found_handle "$@" + ''; + in + lib.mkIf cfg.enableFishIntegration '' + function __fish_command_not_found_handler --on-event fish_command_not_found + ${wrapper} $argv + end ''; - in lib.mkIf cfg.enableFishIntegration '' - function __fish_command_not_found_handler --on-event fish_command_not_found - ${wrapper} $argv - end - ''; }; } diff --git a/nixos/modules/programs/nix-ld.nix b/nixos/modules/programs/nix-ld.nix index edfe7f1f6a3e10..84e17c65db8253 100644 --- a/nixos/modules/programs/nix-ld.nix +++ b/nixos/modules/programs/nix-ld.nix @@ -1,4 +1,9 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: let cfg = config.programs.nix-ld; diff --git a/nixos/modules/programs/nm-applet.nix b/nixos/modules/programs/nm-applet.nix index ed048192e2e039..27a95dea57e2a8 100644 --- a/nixos/modules/programs/nm-applet.nix +++ b/nixos/modules/programs/nm-applet.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { meta = { diff --git a/nixos/modules/programs/nncp.nix b/nixos/modules/programs/nncp.nix index 08485f0dfc8706..dfb4499a615fba 100644 --- a/nixos/modules/programs/nncp.nix +++ b/nixos/modules/programs/nncp.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let nncpCfgFile = "/run/nncp.hjson"; @@ -6,11 +11,11 @@ let settingsFormat = pkgs.formats.json { }; jsonCfgFile = settingsFormat.generate "nncp.json" programCfg.settings; pkg = programCfg.package; -in { +in +{ options.programs.nncp = { - enable = - lib.mkEnableOption "NNCP (Node to Node copy) utilities and configuration"; + enable = lib.mkEnableOption "NNCP (Node to Node copy) utilities and configuration"; group = lib.mkOption { type = lib.types.str; diff --git a/nixos/modules/programs/noisetorch.nix b/nixos/modules/programs/noisetorch.nix index 5e37061d9a1d47..ede9e1518e0f82 100644 --- a/nixos/modules/programs/noisetorch.nix +++ b/nixos/modules/programs/noisetorch.nix @@ -1,6 +1,12 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: -let cfg = config.programs.noisetorch; +let + cfg = config.programs.noisetorch; in { options.programs.noisetorch = { diff --git a/nixos/modules/programs/npm.nix b/nixos/modules/programs/npm.nix index 470188b879b6ac..2f3a4064ef056e 100644 --- a/nixos/modules/programs/npm.nix +++ b/nixos/modules/programs/npm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.npm; diff --git a/nixos/modules/programs/ns-usbloader.nix b/nixos/modules/programs/ns-usbloader.nix index 1f4b931e1cc111..e26f7e5691a682 100644 --- a/nixos/modules/programs/ns-usbloader.nix +++ b/nixos/modules/programs/ns-usbloader.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.ns-usbloader; in diff --git a/nixos/modules/programs/oblogout.nix b/nixos/modules/programs/oblogout.nix index f09fbdc0624239..6c83e97ea66b12 100644 --- a/nixos/modules/programs/oblogout.nix +++ b/nixos/modules/programs/oblogout.nix @@ -1,9 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { imports = [ - (lib.mkRemovedOptionModule [ "programs" "oblogout" ] "programs.oblogout has been removed from NixOS. This is because the oblogout repository has been archived upstream.") + (lib.mkRemovedOptionModule [ "programs" "oblogout" ] + "programs.oblogout has been removed from NixOS. This is because the oblogout repository has been archived upstream." + ) ]; } diff --git a/nixos/modules/programs/oddjobd.nix b/nixos/modules/programs/oddjobd.nix index 019ca58a6048eb..7eb4f20a3839da 100644 --- a/nixos/modules/programs/oddjobd.nix +++ b/nixos/modules/programs/oddjobd.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.oddjobd; @@ -7,17 +12,23 @@ in options = { programs.oddjobd = { enable = lib.mkEnableOption "oddjob, a D-Bus service which runs odd jobs on behalf of client applications"; - package = lib.mkPackageOption pkgs "oddjob" {}; + package = lib.mkPackageOption pkgs "oddjob" { }; }; }; config = lib.mkIf cfg.enable { systemd.services.oddjobd = { wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "dbus.service" ]; + after = [ + "network.target" + "dbus.service" + ]; description = "DBUS Odd-job Daemon"; enable = true; - documentation = [ "man:oddjobd(8)" "man:oddjobd.conf(5)" ]; + documentation = [ + "man:oddjobd(8)" + "man:oddjobd.conf(5)" + ]; serviceConfig = { Type = "simple"; PIDFile = "/run/oddjobd.pid"; diff --git a/nixos/modules/programs/openvpn3.nix b/nixos/modules/programs/openvpn3.nix index 085775af173b79..2ab5fbfc908392 100644 --- a/nixos/modules/programs/openvpn3.nix +++ b/nixos/modules/programs/openvpn3.nix @@ -1,12 +1,26 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let json = pkgs.formats.json { }; cfg = config.programs.openvpn3; - inherit (lib) mkEnableOption mkPackageOption mkOption literalExpression max options lists; + inherit (lib) + mkEnableOption + mkPackageOption + mkOption + literalExpression + max + options + lists + ; inherit (lib.types) bool submodule ints; -in { +in +{ options.programs.openvpn3 = { enable = mkEnableOption "the openvpn3 client"; package = mkPackageOption pkgs "openvpn3" { }; @@ -60,8 +74,7 @@ in { log_level = mkOption { description = "How verbose should the logging be"; type = (ints.between 0 7) // { - merge = _loc: defs: - lists.foldl max 0 (options.getValues defs); + merge = _loc: defs: lists.foldl max 0 (options.getValues defs); }; default = 3; example = 6; @@ -89,15 +102,15 @@ in { group = "openvpn"; }; - users.groups.openvpn = { gid = config.ids.gids.openvpn; }; + users.groups.openvpn = { + gid = config.ids.gids.openvpn; + }; environment = { systemPackages = [ cfg.package ]; etc = { - "openvpn3/netcfg.json".source = - json.generate "netcfg.json" cfg.netcfg.settings; - "openvpn3/log-service.json".source = - json.generate "log-service.json" cfg.log-service.settings; + "openvpn3/netcfg.json".source = json.generate "netcfg.json" cfg.netcfg.settings; + "openvpn3/log-service.json".source = json.generate "log-service.json" cfg.log-service.settings; }; }; @@ -109,5 +122,8 @@ in { }; }; - meta.maintainers = with lib.maintainers; [ shamilton progrm_jarvis ]; + meta.maintainers = with lib.maintainers; [ + shamilton + progrm_jarvis + ]; } diff --git a/nixos/modules/programs/partition-manager.nix b/nixos/modules/programs/partition-manager.nix index 1a66a3f04c41a1..9a4650269e55f9 100644 --- a/nixos/modules/programs/partition-manager.nix +++ b/nixos/modules/programs/partition-manager.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.partition-manager; -in { +in +{ meta.maintainers = [ lib.maintainers.oxalica ]; options = { @@ -16,6 +22,9 @@ in { config = lib.mkIf config.programs.partition-manager.enable { services.dbus.packages = [ cfg.package.kpmcore ]; # `kpmcore` need to be installed to pull in polkit actions. - environment.systemPackages = [ cfg.package.kpmcore cfg.package ]; + environment.systemPackages = [ + cfg.package.kpmcore + cfg.package + ]; }; } diff --git a/nixos/modules/programs/plotinus.nix b/nixos/modules/programs/plotinus.nix index 835db049d86280..4867b2f963bdb3 100644 --- a/nixos/modules/programs/plotinus.nix +++ b/nixos/modules/programs/plotinus.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.plotinus; @@ -28,7 +33,9 @@ in ###### implementation config = lib.mkIf cfg.enable { - environment.sessionVariables.XDG_DATA_DIRS = [ "${pkgs.plotinus}/share/gsettings-schemas/${pkgs.plotinus.name}" ]; + environment.sessionVariables.XDG_DATA_DIRS = [ + "${pkgs.plotinus}/share/gsettings-schemas/${pkgs.plotinus.name}" + ]; environment.variables.GTK3_MODULES = [ "${pkgs.plotinus}/lib/libplotinus.so" ]; }; } diff --git a/nixos/modules/programs/pqos-wrapper.nix b/nixos/modules/programs/pqos-wrapper.nix index 82023e67a2ae2f..06fe81c0b1b209 100644 --- a/nixos/modules/programs/pqos-wrapper.nix +++ b/nixos/modules/programs/pqos-wrapper.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let cfg = config.programs.pqos-wrapper; diff --git a/nixos/modules/programs/projecteur.nix b/nixos/modules/programs/projecteur.nix index af186e3d250bca..7c96403a1f2905 100644 --- a/nixos/modules/programs/projecteur.nix +++ b/nixos/modules/programs/projecteur.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.projecteur; @@ -15,6 +20,9 @@ in }; meta = { - maintainers = with lib.maintainers; [ benneti drupol ]; + maintainers = with lib.maintainers; [ + benneti + drupol + ]; }; } diff --git a/nixos/modules/programs/proxychains.nix b/nixos/modules/programs/proxychains.nix index 86bbf16a64ce14..6a3e29487be0d2 100644 --- a/nixos/modules/programs/proxychains.nix +++ b/nixos/modules/programs/proxychains.nix @@ -1,12 +1,18 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.proxychains; configFile = '' ${cfg.chain.type}_chain - ${lib.optionalString (cfg.chain.type == "random") - "chain_len = ${builtins.toString cfg.chain.length}"} + ${lib.optionalString ( + cfg.chain.type == "random" + ) "chain_len = ${builtins.toString cfg.chain.length}"} ${lib.optionalString cfg.proxyDNS "proxy_dns"} ${lib.optionalString cfg.quietMode "quiet_mode"} remote_dns_subnet ${builtins.toString cfg.remoteDNSSubnet} @@ -14,9 +20,11 @@ let tcp_connect_time_out ${builtins.toString cfg.tcpConnectTimeOut} localnet ${cfg.localnet} [ProxyList] - ${builtins.concatStringsSep "\n" - (lib.mapAttrsToList (k: v: "${v.type} ${v.host} ${builtins.toString v.port}") - (lib.filterAttrs (k: v: v.enable) cfg.proxies))} + ${builtins.concatStringsSep "\n" ( + lib.mapAttrsToList (k: v: "${v.type} ${v.host} ${builtins.toString v.port}") ( + lib.filterAttrs (k: v: v.enable) cfg.proxies + ) + )} ''; proxyOptions = { @@ -24,7 +32,11 @@ let enable = lib.mkEnableOption "this proxy"; type = lib.mkOption { - type = lib.types.enum [ "http" "socks4" "socks5" ]; + type = lib.types.enum [ + "http" + "socks4" + "socks5" + ]; description = "Proxy type."; }; @@ -40,7 +52,8 @@ let }; }; -in { +in +{ ###### interface @@ -56,7 +69,11 @@ in { chain = { type = lib.mkOption { - type = lib.types.enum [ "dynamic" "strict" "random" ]; + type = lib.types.enum [ + "dynamic" + "strict" + "random" + ]; default = "strict"; description = '' `dynamic` - Each connection will be done via chained proxies @@ -92,7 +109,11 @@ in { quietMode = lib.mkEnableOption "Quiet mode (no output from the library)"; remoteDNSSubnet = lib.mkOption { - type = lib.types.enum [ 10 127 224 ]; + type = lib.types.enum [ + 10 + 127 + 224 + ]; default = 224; description = '' Set the class A subnet number to use for the internal remote DNS mapping, uses the reserved 224.x.x.x range by default. @@ -151,15 +172,14 @@ in { ''; }; - programs.proxychains.proxies = lib.mkIf config.services.tor.client.enable - { - torproxy = lib.mkDefault { - enable = true; - type = "socks4"; - host = "127.0.0.1"; - port = 9050; - }; + programs.proxychains.proxies = lib.mkIf config.services.tor.client.enable { + torproxy = lib.mkDefault { + enable = true; + type = "socks4"; + host = "127.0.0.1"; + port = 9050; }; + }; environment.etc."proxychains.conf".text = configFile; environment.systemPackages = [ cfg.package ]; diff --git a/nixos/modules/programs/qdmr.nix b/nixos/modules/programs/qdmr.nix index 1444be9c6923a7..2d1e990f7f6c41 100644 --- a/nixos/modules/programs/qdmr.nix +++ b/nixos/modules/programs/qdmr.nix @@ -7,7 +7,8 @@ let cfg = config.programs.qdmr; -in { +in +{ meta.maintainers = [ ]; options = { @@ -20,6 +21,6 @@ in { config = lib.mkIf cfg.enable { environment.systemPackages = [ cfg.package ]; services.udev.packages = [ cfg.package ]; - users.groups.dialout = {}; + users.groups.dialout = { }; }; } diff --git a/nixos/modules/programs/qt5ct.nix b/nixos/modules/programs/qt5ct.nix index bc7b28b9c6e924..6410638a3f9094 100644 --- a/nixos/modules/programs/qt5ct.nix +++ b/nixos/modules/programs/qt5ct.nix @@ -2,6 +2,10 @@ { imports = [ - (lib.mkRemovedOptionModule [ "programs" "qt5ct" "enable" ] "Use qt5.platformTheme = \"qt5ct\" instead.") + (lib.mkRemovedOptionModule [ + "programs" + "qt5ct" + "enable" + ] "Use qt5.platformTheme = \"qt5ct\" instead.") ]; } diff --git a/nixos/modules/programs/quark-goldleaf.nix b/nixos/modules/programs/quark-goldleaf.nix index 71aadc8c594e19..a7534368f1ca5c 100644 --- a/nixos/modules/programs/quark-goldleaf.nix +++ b/nixos/modules/programs/quark-goldleaf.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.quark-goldleaf; in diff --git a/nixos/modules/programs/regreet.nix b/nixos/modules/programs/regreet.nix index 1f83f610dbf1ef..3c8e588359b5a6 100644 --- a/nixos/modules/programs/regreet.nix +++ b/nixos/modules/programs/regreet.nix @@ -1,7 +1,8 @@ -{ lib -, pkgs -, config -, ... +{ + lib, + pkgs, + config, + ... }: let cfg = config.programs.regreet; @@ -39,10 +40,9 @@ in cageArgs = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ "-s" ]; - example = lib.literalExpression - '' - [ "-s" "-m" "last" ] - ''; + example = lib.literalExpression '' + [ "-s" "-m" "last" ] + ''; description = '' Additional arguments to be passed to [cage](https://github.com/cage-kiosk/cage). @@ -155,23 +155,22 @@ in environment.etc = { "greetd/regreet.css" = - if lib.isPath cfg.extraCss - then {source = cfg.extraCss;} - else {text = cfg.extraCss;}; + if lib.isPath cfg.extraCss then { source = cfg.extraCss; } else { text = cfg.extraCss; }; - "greetd/regreet.toml".source = - settingsFormat.generate "regreet.toml" cfg.settings; + "greetd/regreet.toml".source = settingsFormat.generate "regreet.toml" cfg.settings; }; - systemd.tmpfiles.settings."10-regreet" = let - defaultConfig = { - user = "greeter"; - group = config.users.users.${config.services.greetd.settings.default_session.user}.group; - mode = "0755"; + systemd.tmpfiles.settings."10-regreet" = + let + defaultConfig = { + user = "greeter"; + group = config.users.users.${config.services.greetd.settings.default_session.user}.group; + mode = "0755"; + }; + in + { + "/var/log/regreet".d = defaultConfig; + "/var/cache/regreet".d = defaultConfig; }; - in { - "/var/log/regreet".d = defaultConfig; - "/var/cache/regreet".d = defaultConfig; - }; }; } diff --git a/nixos/modules/programs/rog-control-center.nix b/nixos/modules/programs/rog-control-center.nix index 7413ca3daf05d8..60d3a84cbc457d 100644 --- a/nixos/modules/programs/rog-control-center.nix +++ b/nixos/modules/programs/rog-control-center.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.rog-control-center; @@ -19,7 +24,12 @@ in config = lib.mkIf cfg.enable { environment.systemPackages = [ pkgs.asusctl - (lib.mkIf cfg.autoStart (pkgs.makeAutostartItem { name = "rog-control-center"; package = pkgs.asusctl; })) + (lib.mkIf cfg.autoStart ( + pkgs.makeAutostartItem { + name = "rog-control-center"; + package = pkgs.asusctl; + } + )) ]; services.asusd.enable = true; diff --git a/nixos/modules/programs/rust-motd.nix b/nixos/modules/programs/rust-motd.nix index 19f98868ee344f..ba080aa037e06a 100644 --- a/nixos/modules/programs/rust-motd.nix +++ b/nixos/modules/programs/rust-motd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.rust-motd; @@ -6,21 +11,26 @@ let # Order the sections in the TOML according to the order of sections # in `cfg.order`. - motdConf = pkgs.runCommand "motd.conf" - { - __structuredAttrs = true; - inherit (cfg) order settings; - nativeBuildInputs = [ pkgs.remarshal pkgs.jq ]; - } - '' - cat "$NIX_ATTRS_JSON_FILE" \ - | jq '.settings as $settings - | .order - | map({ key: ., value: $settings."\(.)" }) - | from_entries' -r \ - | json2toml /dev/stdin "$out" - ''; -in { + motdConf = + pkgs.runCommand "motd.conf" + { + __structuredAttrs = true; + inherit (cfg) order settings; + nativeBuildInputs = [ + pkgs.remarshal + pkgs.jq + ]; + } + '' + cat "$NIX_ATTRS_JSON_FILE" \ + | jq '.settings as $settings + | .order + | map({ key: ., value: $settings."\(.)" }) + | from_entries' -r \ + | json2toml /dev/stdin "$out" + ''; +in +{ options.programs.rust-motd = { enable = lib.mkEnableOption "rust-motd, a Message Of The Day (MOTD) generator"; enableMotdInSSHD = lib.mkOption { @@ -88,12 +98,14 @@ in { }; config = lib.mkIf cfg.enable { assertions = [ - { assertion = config.users.motd == ""; + { + assertion = config.users.motd == ""; message = '' `programs.rust-motd` is incompatible with `users.motd`! ''; } - { assertion = builtins.sort (a: b: a < b) cfg.order == builtins.attrNames cfg.settings; + { + assertion = builtins.sort (a: b: a < b) cfg.order == builtins.attrNames cfg.settings; message = '' Please ensure that every section from `programs.rust-motd.settings` is present in `programs.rust-motd.order`. @@ -102,7 +114,9 @@ in { ]; systemd.services.rust-motd = { path = with pkgs; [ bash ]; - documentation = [ "https://github.com/rust-motd/rust-motd/blob/v${pkgs.rust-motd.version}/README.md" ]; + documentation = [ + "https://github.com/rust-motd/rust-motd/blob/v${pkgs.rust-motd.version}/README.md" + ]; description = "motd generator"; wantedBy = [ "multi-user.target" ]; serviceConfig = { @@ -136,12 +150,18 @@ in { wantedBy = [ "timers.target" ]; timerConfig.OnCalendar = cfg.refreshInterval; }; - security.pam.services.sshd.text = lib.mkIf cfg.enableMotdInSSHD (lib.mkDefault (lib.mkAfter '' - session optional ${pkgs.pam}/lib/security/pam_motd.so motd=/var/lib/rust-motd/motd - '')); - services.openssh.extraConfig = lib.mkIf (cfg.settings ? last_login && cfg.settings.last_login != {}) '' - PrintLastLog no - ''; + security.pam.services.sshd.text = lib.mkIf cfg.enableMotdInSSHD ( + lib.mkDefault ( + lib.mkAfter '' + session optional ${pkgs.pam}/lib/security/pam_motd.so motd=/var/lib/rust-motd/motd + '' + ) + ); + services.openssh.extraConfig = + lib.mkIf (cfg.settings ? last_login && cfg.settings.last_login != { }) + '' + PrintLastLog no + ''; }; meta.maintainers = with lib.maintainers; [ ma27 ]; } diff --git a/nixos/modules/programs/ryzen-monitor-ng.nix b/nixos/modules/programs/ryzen-monitor-ng.nix index cb0c391ce6b155..8d9e75928404e9 100644 --- a/nixos/modules/programs/ryzen-monitor-ng.nix +++ b/nixos/modules/programs/ryzen-monitor-ng.nix @@ -1,7 +1,8 @@ -{ pkgs -, config -, lib -, ... +{ + pkgs, + config, + lib, + ... }: let inherit (lib) mkEnableOption mkPackageOption mkIf; @@ -10,7 +11,7 @@ in { options = { programs.ryzen-monitor-ng = { - enable = mkEnableOption '' + enable = mkEnableOption '' ryzen_monitor_ng, a userspace application for setting and getting Ryzen SMU (System Management Unit) parameters via the ryzen_smu kernel driver. Monitor power information of Ryzen processors via the PM table of the SMU. @@ -22,7 +23,7 @@ in WARNING: Damage cause by use of your AMD processor outside of official AMD specifications or outside of factory settings are not covered under any AMD product warranty and may not be covered by your board or system manufacturer's warranty ''; - package = mkPackageOption pkgs "ryzen-monitor-ng" {}; + package = mkPackageOption pkgs "ryzen-monitor-ng" { }; }; }; @@ -31,5 +32,8 @@ in hardware.cpu.amd.ryzen-smu.enable = true; }; - meta.maintainers = with lib.maintainers; [ Cryolitia phdyellow ]; + meta.maintainers = with lib.maintainers; [ + Cryolitia + phdyellow + ]; } diff --git a/nixos/modules/programs/screen.nix b/nixos/modules/programs/screen.nix index 7c92500f5a1fd2..d6041ea1fe39f9 100644 --- a/nixos/modules/programs/screen.nix +++ b/nixos/modules/programs/screen.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.screen; @@ -29,7 +34,7 @@ in text = cfg.screenrc; }; environment.systemPackages = [ cfg.package ]; - security.pam.services.screen = {}; + security.pam.services.screen = { }; }) ]; } diff --git a/nixos/modules/programs/seahorse.nix b/nixos/modules/programs/seahorse.nix index 3f6ec8c1a6a6dc..b508c7d66a0655 100644 --- a/nixos/modules/programs/seahorse.nix +++ b/nixos/modules/programs/seahorse.nix @@ -1,6 +1,11 @@ # Seahorse. -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { @@ -16,7 +21,6 @@ }; - ###### implementation config = lib.mkIf config.programs.seahorse.enable { diff --git a/nixos/modules/programs/sedutil.nix b/nixos/modules/programs/sedutil.nix index 978aaa5c82d5a9..14926aefbd2ccd 100644 --- a/nixos/modules/programs/sedutil.nix +++ b/nixos/modules/programs/sedutil.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.sedutil; -in { +in +{ options.programs.sedutil.enable = lib.mkEnableOption "sedutil, to manage self encrypting drives that conform to the Trusted Computing Group OPAL 2.0 SSC specification"; config = lib.mkIf cfg.enable { diff --git a/nixos/modules/programs/sharing.nix b/nixos/modules/programs/sharing.nix index 0fe8100bbc569b..f427c8a62d9795 100644 --- a/nixos/modules/programs/sharing.nix +++ b/nixos/modules/programs/sharing.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { options.programs.sharing = { enable = lib.mkEnableOption '' @@ -11,8 +16,8 @@ let cfg = config.programs.sharing; in - lib.mkIf cfg.enable { - environment.systemPackages = [ pkgs.sharing ]; - networking.firewall.allowedTCPPorts = [ 7478 ]; - }; + lib.mkIf cfg.enable { + environment.systemPackages = [ pkgs.sharing ]; + networking.firewall.allowedTCPPorts = [ 7478 ]; + }; } diff --git a/nixos/modules/programs/skim.nix b/nixos/modules/programs/skim.nix index 9c573b39bbbc70..67d7396d034418 100644 --- a/nixos/modules/programs/skim.nix +++ b/nixos/modules/programs/skim.nix @@ -1,6 +1,16 @@ -{ pkgs, config, lib, ... }: +{ + pkgs, + config, + lib, + ... +}: let - inherit (lib) mkEnableOption mkPackageOption optional optionalString; + inherit (lib) + mkEnableOption + mkPackageOption + optional + optionalString + ; cfg = config.programs.skim; in { @@ -8,24 +18,28 @@ in programs.skim = { fuzzyCompletion = mkEnableOption "fuzzy completion with skim"; keybindings = mkEnableOption "skim keybindings"; - package = mkPackageOption pkgs "skim" {}; + package = mkPackageOption pkgs "skim" { }; }; }; config = { environment.systemPackages = optional (cfg.keybindings || cfg.fuzzyCompletion) cfg.package; - programs.bash.interactiveShellInit = optionalString cfg.fuzzyCompletion '' - source ${cfg.package}/share/skim/completion.bash - '' + optionalString cfg.keybindings '' - source ${cfg.package}/share/skim/key-bindings.bash - ''; + programs.bash.interactiveShellInit = + optionalString cfg.fuzzyCompletion '' + source ${cfg.package}/share/skim/completion.bash + '' + + optionalString cfg.keybindings '' + source ${cfg.package}/share/skim/key-bindings.bash + ''; - programs.zsh.interactiveShellInit = optionalString cfg.fuzzyCompletion '' - source ${cfg.package}/share/skim/completion.zsh - '' + optionalString cfg.keybindings '' - source ${cfg.package}/share/skim/key-bindings.zsh - ''; + programs.zsh.interactiveShellInit = + optionalString cfg.fuzzyCompletion '' + source ${cfg.package}/share/skim/completion.zsh + '' + + optionalString cfg.keybindings '' + source ${cfg.package}/share/skim/key-bindings.zsh + ''; programs.fish.interactiveShellInit = optionalString cfg.keybindings '' source ${cfg.package}/share/skim/key-bindings.fish && skim_key_bindings diff --git a/nixos/modules/programs/slock.nix b/nixos/modules/programs/slock.nix index ce24f662f218ca..c4aa6cd16c4217 100644 --- a/nixos/modules/programs/slock.nix +++ b/nixos/modules/programs/slock.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.slock; @@ -14,17 +19,17 @@ in Whether to install slock screen locker with setuid wrapper. ''; }; - package = lib.mkPackageOption pkgs "slock" {}; + package = lib.mkPackageOption pkgs "slock" { }; }; }; config = lib.mkIf cfg.enable { environment.systemPackages = [ cfg.package ]; - security.wrappers.slock = - { setuid = true; - owner = "root"; - group = "root"; - source = lib.getExe cfg.package; - }; + security.wrappers.slock = { + setuid = true; + owner = "root"; + group = "root"; + source = lib.getExe cfg.package; + }; }; } diff --git a/nixos/modules/programs/sniffnet.nix b/nixos/modules/programs/sniffnet.nix index 631a155e35b56e..36c298b84e72e1 100644 --- a/nixos/modules/programs/sniffnet.nix +++ b/nixos/modules/programs/sniffnet.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.sniffnet; diff --git a/nixos/modules/programs/soundmodem.nix b/nixos/modules/programs/soundmodem.nix index 5f57e24a4524a6..a077867a767536 100644 --- a/nixos/modules/programs/soundmodem.nix +++ b/nixos/modules/programs/soundmodem.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.soundmodem; diff --git a/nixos/modules/programs/spacefm.nix b/nixos/modules/programs/spacefm.nix index 73d48cf6a3a836..47f0d602290267 100644 --- a/nixos/modules/programs/spacefm.nix +++ b/nixos/modules/programs/spacefm.nix @@ -1,8 +1,14 @@ # Global configuration for spacefm. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: -let cfg = config.programs.spacefm; +let + cfg = config.programs.spacefm; in { @@ -47,7 +53,8 @@ in config = lib.mkIf cfg.enable { environment.systemPackages = [ pkgs.spaceFM ]; - environment.etc."spacefm/spacefm.conf".text = - lib.concatStrings (lib.mapAttrsToList (n: v: "${n}=${builtins.toString v}\n") cfg.settings); + environment.etc."spacefm/spacefm.conf".text = lib.concatStrings ( + lib.mapAttrsToList (n: v: "${n}=${builtins.toString v}\n") cfg.settings + ); }; } diff --git a/nixos/modules/programs/ssh.nix b/nixos/modules/programs/ssh.nix index f2ef248d786660..1ae2653ed3e908 100644 --- a/nixos/modules/programs/ssh.nix +++ b/nixos/modules/programs/ssh.nix @@ -1,30 +1,40 @@ # Global configuration for the SSH client. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - cfg = config.programs.ssh; + cfg = config.programs.ssh; - askPasswordWrapper = pkgs.writeScript "ssh-askpass-wrapper" - '' - #! ${pkgs.runtimeShell} -e - export DISPLAY="$(systemctl --user show-environment | ${pkgs.gnused}/bin/sed 's/^DISPLAY=\(.*\)/\1/; t; d')" - export XAUTHORITY="$(systemctl --user show-environment | ${pkgs.gnused}/bin/sed 's/^XAUTHORITY=\(.*\)/\1/; t; d')" - export WAYLAND_DISPLAY="$(systemctl --user show-environment | ${pkgs.gnused}/bin/sed 's/^WAYLAND_DISPLAY=\(.*\)/\1/; t; d')" - exec ${cfg.askPassword} "$@" - ''; + askPasswordWrapper = pkgs.writeScript "ssh-askpass-wrapper" '' + #! ${pkgs.runtimeShell} -e + export DISPLAY="$(systemctl --user show-environment | ${pkgs.gnused}/bin/sed 's/^DISPLAY=\(.*\)/\1/; t; d')" + export XAUTHORITY="$(systemctl --user show-environment | ${pkgs.gnused}/bin/sed 's/^XAUTHORITY=\(.*\)/\1/; t; d')" + export WAYLAND_DISPLAY="$(systemctl --user show-environment | ${pkgs.gnused}/bin/sed 's/^WAYLAND_DISPLAY=\(.*\)/\1/; t; d')" + exec ${cfg.askPassword} "$@" + ''; knownHosts = builtins.attrValues cfg.knownHosts; - knownHostsText = (lib.flip (lib.concatMapStringsSep "\n") knownHosts - (h: assert h.hostNames != []; - lib.optionalString h.certAuthority "@cert-authority " + builtins.concatStringsSep "," h.hostNames + " " + knownHostsText = + (lib.flip (lib.concatMapStringsSep "\n") knownHosts ( + h: + assert h.hostNames != [ ]; + lib.optionalString h.certAuthority "@cert-authority " + + builtins.concatStringsSep "," h.hostNames + + " " + (if h.publicKey != null then h.publicKey else builtins.readFile h.publicKeyFile) - )) + "\n"; + )) + + "\n"; - knownHostsFiles = [ "/etc/ssh/ssh_known_hosts" ] - ++ builtins.map pkgs.copyPathToStore cfg.knownHostsFiles; + knownHostsFiles = [ + "/etc/ssh/ssh_known_hosts" + ] ++ builtins.map pkgs.copyPathToStore cfg.knownHostsFiles; in { @@ -73,8 +83,11 @@ in pubkeyAcceptedKeyTypes = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; - example = [ "ssh-ed25519" "ssh-rsa" ]; + default = [ ]; + example = [ + "ssh-ed25519" + "ssh-rsa" + ]; description = '' Specifies the key lib.types that will be used for public key authentication. ''; @@ -82,8 +95,11 @@ in hostKeyAlgorithms = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; - example = [ "ssh-ed25519" "ssh-rsa" ]; + default = [ ]; + example = [ + "ssh-ed25519" + "ssh-rsa" + ]; description = '' Specifies the host key algorithms that the client wants to use in order of preference. ''; @@ -133,67 +149,77 @@ in package = lib.mkPackageOption pkgs "openssh" { }; knownHosts = lib.mkOption { - default = {}; - type = lib.types.attrsOf (lib.types.submodule ({ name, config, options, ... }: { - options = { - certAuthority = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - This public key is an SSH certificate authority, rather than an - individual host's key. - ''; - }; - hostNames = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = [ name ] ++ config.extraHostNames; - defaultText = lib.literalExpression "[ ${name} ] ++ config.${options.extraHostNames}"; - description = '' - A list of host names and/or IP numbers used for accessing - the host's ssh service. This list includes the name of the - containing `knownHosts` attribute by default - for convenience. If you wish to configure multiple host keys - for the same host use multiple `knownHosts` - entries with different attribute names and the same - `hostNames` list. - ''; - }; - extraHostNames = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - description = '' - A list of additional host names and/or IP numbers used for - accessing the host's ssh service. This list is ignored if - `hostNames` is set explicitly. - ''; - }; - publicKey = lib.mkOption { - default = null; - type = lib.types.nullOr lib.types.str; - example = "ecdsa-sha2-nistp521 AAAAE2VjZHN...UEPg=="; - description = '' - The public key data for the host. You can fetch a public key - from a running SSH server with the {command}`ssh-keyscan` - command. The public key should not include any host names, only - the key type and the key itself. - ''; - }; - publicKeyFile = lib.mkOption { - default = null; - type = lib.types.nullOr lib.types.path; - description = '' - The path to the public key file for the host. The public - key file is read at build time and saved in the Nix store. - You can fetch a public key file from a running SSH server - with the {command}`ssh-keyscan` command. The content - of the file should follow the same format as described for - the `publicKey` option. Only a single key - is supported. If a host has multiple keys, use - {option}`programs.ssh.knownHostsFiles` instead. - ''; - }; - }; - })); + default = { }; + type = lib.types.attrsOf ( + lib.types.submodule ( + { + name, + config, + options, + ... + }: + { + options = { + certAuthority = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + This public key is an SSH certificate authority, rather than an + individual host's key. + ''; + }; + hostNames = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ name ] ++ config.extraHostNames; + defaultText = lib.literalExpression "[ ${name} ] ++ config.${options.extraHostNames}"; + description = '' + A list of host names and/or IP numbers used for accessing + the host's ssh service. This list includes the name of the + containing `knownHosts` attribute by default + for convenience. If you wish to configure multiple host keys + for the same host use multiple `knownHosts` + entries with different attribute names and the same + `hostNames` list. + ''; + }; + extraHostNames = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + description = '' + A list of additional host names and/or IP numbers used for + accessing the host's ssh service. This list is ignored if + `hostNames` is set explicitly. + ''; + }; + publicKey = lib.mkOption { + default = null; + type = lib.types.nullOr lib.types.str; + example = "ecdsa-sha2-nistp521 AAAAE2VjZHN...UEPg=="; + description = '' + The public key data for the host. You can fetch a public key + from a running SSH server with the {command}`ssh-keyscan` + command. The public key should not include any host names, only + the key type and the key itself. + ''; + }; + publicKeyFile = lib.mkOption { + default = null; + type = lib.types.nullOr lib.types.path; + description = '' + The path to the public key file for the host. The public + key file is read at build time and saved in the Nix store. + You can fetch a public key file from a running SSH server + with the {command}`ssh-keyscan` command. The content + of the file should follow the same format as described for + the `publicKey` option. Only a single key + is supported. If a host has multiple keys, use + {option}`programs.ssh.knownHostsFiles` instead. + ''; + }; + }; + } + ) + ); description = '' The set of system-wide known SSH hosts. To make simple setups more convenient the name of an attribute in this set is used as a host name @@ -218,7 +244,7 @@ in }; knownHostsFiles = lib.mkOption { - default = []; + default = [ ]; type = with lib.types; listOf path; description = '' Files containing SSH host keys to set as global known hosts. @@ -241,7 +267,10 @@ in kexAlgorithms = lib.mkOption { type = lib.types.nullOr (lib.types.listOf lib.types.str); default = null; - example = [ "curve25519-sha256@libssh.org" "diffie-hellman-group-exchange-sha256" ]; + example = [ + "curve25519-sha256@libssh.org" + "diffie-hellman-group-exchange-sha256" + ]; description = '' Specifies the available KEX (Key Exchange) algorithms. ''; @@ -250,7 +279,10 @@ in ciphers = lib.mkOption { type = lib.types.nullOr (lib.types.listOf lib.types.str); default = null; - example = [ "chacha20-poly1305@openssh.com" "aes256-gcm@openssh.com" ]; + example = [ + "chacha20-poly1305@openssh.com" + "aes256-gcm@openssh.com" + ]; description = '' Specifies the ciphers allowed and their order of preference. ''; @@ -259,7 +291,10 @@ in macs = lib.mkOption { type = lib.types.nullOr (lib.types.listOf lib.types.str); default = null; - example = [ "hmac-sha2-512-etm@openssh.com" "hmac-sha1" ]; + example = [ + "hmac-sha2-512-etm@openssh.com" + "hmac-sha1" + ]; description = '' Specifies the MAC (message authentication code) algorithms in order of preference. The MAC algorithm is used for data integrity protection. @@ -271,73 +306,88 @@ in config = { - programs.ssh.setXAuthLocation = - lib.mkDefault (config.services.xserver.enable || config.programs.ssh.forwardX11 == true || config.services.openssh.settings.X11Forwarding); + programs.ssh.setXAuthLocation = lib.mkDefault ( + config.services.xserver.enable + || config.programs.ssh.forwardX11 == true + || config.services.openssh.settings.X11Forwarding + ); assertions = - [ { assertion = cfg.forwardX11 == true -> cfg.setXAuthLocation; + [ + { + assertion = cfg.forwardX11 == true -> cfg.setXAuthLocation; message = "cannot enable X11 forwarding without setting XAuth location"; } - ] ++ lib.flip lib.mapAttrsToList cfg.knownHosts (name: data: { - assertion = (data.publicKey == null && data.publicKeyFile != null) || - (data.publicKey != null && data.publicKeyFile == null); - message = "knownHost ${name} must contain either a publicKey or publicKeyFile"; - }); + ] + ++ lib.flip lib.mapAttrsToList cfg.knownHosts ( + name: data: { + assertion = + (data.publicKey == null && data.publicKeyFile != null) + || (data.publicKey != null && data.publicKeyFile == null); + message = "knownHost ${name} must contain either a publicKey or publicKeyFile"; + } + ); # SSH configuration. Slight duplication of the sshd_config # generation in the sshd service. - environment.etc."ssh/ssh_config".text = - '' - # Custom options from `extraConfig`, to override generated options - ${cfg.extraConfig} - - # Generated options from other settings - Host * - GlobalKnownHostsFile ${builtins.concatStringsSep " " knownHostsFiles} - - ${lib.optionalString (!config.networking.enableIPv6) "AddressFamily inet"} - ${lib.optionalString cfg.setXAuthLocation "XAuthLocation ${pkgs.xorg.xauth}/bin/xauth"} - ${lib.optionalString (cfg.forwardX11 != null) "ForwardX11 ${if cfg.forwardX11 then "yes" else "no"}"} - - ${lib.optionalString (cfg.pubkeyAcceptedKeyTypes != []) "PubkeyAcceptedKeyTypes ${builtins.concatStringsSep "," cfg.pubkeyAcceptedKeyTypes}"} - ${lib.optionalString (cfg.hostKeyAlgorithms != []) "HostKeyAlgorithms ${builtins.concatStringsSep "," cfg.hostKeyAlgorithms}"} - ${lib.optionalString (cfg.kexAlgorithms != null) "KexAlgorithms ${builtins.concatStringsSep "," cfg.kexAlgorithms}"} - ${lib.optionalString (cfg.ciphers != null) "Ciphers ${builtins.concatStringsSep "," cfg.ciphers}"} - ${lib.optionalString (cfg.macs != null) "MACs ${builtins.concatStringsSep "," cfg.macs}"} - ''; + environment.etc."ssh/ssh_config".text = '' + # Custom options from `extraConfig`, to override generated options + ${cfg.extraConfig} + + # Generated options from other settings + Host * + GlobalKnownHostsFile ${builtins.concatStringsSep " " knownHostsFiles} + + ${lib.optionalString (!config.networking.enableIPv6) "AddressFamily inet"} + ${lib.optionalString cfg.setXAuthLocation "XAuthLocation ${pkgs.xorg.xauth}/bin/xauth"} + ${lib.optionalString (cfg.forwardX11 != null) + "ForwardX11 ${if cfg.forwardX11 then "yes" else "no"}" + } + + ${lib.optionalString ( + cfg.pubkeyAcceptedKeyTypes != [ ] + ) "PubkeyAcceptedKeyTypes ${builtins.concatStringsSep "," cfg.pubkeyAcceptedKeyTypes}"} + ${lib.optionalString ( + cfg.hostKeyAlgorithms != [ ] + ) "HostKeyAlgorithms ${builtins.concatStringsSep "," cfg.hostKeyAlgorithms}"} + ${lib.optionalString ( + cfg.kexAlgorithms != null + ) "KexAlgorithms ${builtins.concatStringsSep "," cfg.kexAlgorithms}"} + ${lib.optionalString (cfg.ciphers != null) "Ciphers ${builtins.concatStringsSep "," cfg.ciphers}"} + ${lib.optionalString (cfg.macs != null) "MACs ${builtins.concatStringsSep "," cfg.macs}"} + ''; environment.etc."ssh/ssh_known_hosts".text = knownHostsText; # FIXME: this should really be socket-activated for über-awesomeness. - systemd.user.services.ssh-agent = lib.mkIf cfg.startAgent - { description = "SSH Agent"; - wantedBy = [ "default.target" ]; - unitConfig.ConditionUser = "!@system"; - serviceConfig = - { ExecStartPre = "${pkgs.coreutils}/bin/rm -f %t/ssh-agent"; - ExecStart = - "${cfg.package}/bin/ssh-agent " + - lib.optionalString (cfg.agentTimeout != null) ("-t ${cfg.agentTimeout} ") + - lib.optionalString (cfg.agentPKCS11Whitelist != null) ("-P ${cfg.agentPKCS11Whitelist} ") + - "-a %t/ssh-agent"; - StandardOutput = "null"; - Type = "forking"; - Restart = "on-failure"; - SuccessExitStatus = "0 2"; - }; - # Allow ssh-agent to ask for confirmation. This requires the - # unit to know about the user's $DISPLAY (via ‘systemctl - # import-environment’). - environment.SSH_ASKPASS = lib.optionalString cfg.enableAskPassword askPasswordWrapper; - environment.DISPLAY = "fake"; # required to make ssh-agent start $SSH_ASKPASS + systemd.user.services.ssh-agent = lib.mkIf cfg.startAgent { + description = "SSH Agent"; + wantedBy = [ "default.target" ]; + unitConfig.ConditionUser = "!@system"; + serviceConfig = { + ExecStartPre = "${pkgs.coreutils}/bin/rm -f %t/ssh-agent"; + ExecStart = + "${cfg.package}/bin/ssh-agent " + + lib.optionalString (cfg.agentTimeout != null) ("-t ${cfg.agentTimeout} ") + + lib.optionalString (cfg.agentPKCS11Whitelist != null) ("-P ${cfg.agentPKCS11Whitelist} ") + + "-a %t/ssh-agent"; + StandardOutput = "null"; + Type = "forking"; + Restart = "on-failure"; + SuccessExitStatus = "0 2"; }; + # Allow ssh-agent to ask for confirmation. This requires the + # unit to know about the user's $DISPLAY (via ‘systemctl + # import-environment’). + environment.SSH_ASKPASS = lib.optionalString cfg.enableAskPassword askPasswordWrapper; + environment.DISPLAY = "fake"; # required to make ssh-agent start $SSH_ASKPASS + }; - environment.extraInit = lib.optionalString cfg.startAgent - '' - if [ -z "$SSH_AUTH_SOCK" -a -n "$XDG_RUNTIME_DIR" ]; then - export SSH_AUTH_SOCK="$XDG_RUNTIME_DIR/ssh-agent" - fi - ''; + environment.extraInit = lib.optionalString cfg.startAgent '' + if [ -z "$SSH_AUTH_SOCK" -a -n "$XDG_RUNTIME_DIR" ]; then + export SSH_AUTH_SOCK="$XDG_RUNTIME_DIR/ssh-agent" + fi + ''; environment.variables.SSH_ASKPASS = lib.optionalString cfg.enableAskPassword cfg.askPassword; diff --git a/nixos/modules/programs/starship.nix b/nixos/modules/programs/starship.nix index 7f8d9eb3363d73..17a2cf9b866658 100644 --- a/nixos/modules/programs/starship.nix +++ b/nixos/modules/programs/starship.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.starship; @@ -7,21 +12,24 @@ let userSettingsFile = settingsFormat.generate "starship.toml" cfg.settings; - settingsFile = if cfg.presets == [] then userSettingsFile else pkgs.runCommand "starship.toml" - { - nativeBuildInputs = [ pkgs.yq ]; - } '' - tomlq -s -t 'reduce .[] as $item ({}; . * $item)' \ - ${lib.concatStringsSep " " (map (f: "${cfg.package}/share/starship/presets/${f}.toml") cfg.presets)} \ - ${userSettingsFile} \ - > $out - ''; - - initOption = - if cfg.interactiveOnly then - "promptInit" + settingsFile = + if cfg.presets == [ ] then + userSettingsFile else - "shellInit"; + pkgs.runCommand "starship.toml" + { + nativeBuildInputs = [ pkgs.yq ]; + } + '' + tomlq -s -t 'reduce .[] as $item ({}; . * $item)' \ + ${ + lib.concatStringsSep " " (map (f: "${cfg.package}/share/starship/presets/${f}.toml") cfg.presets) + } \ + ${userSettingsFile} \ + > $out + ''; + + initOption = if cfg.interactiveOnly then "promptInit" else "shellInit"; in { @@ -30,10 +38,14 @@ in package = lib.mkPackageOption pkgs "starship" { }; - interactiveOnly = lib.mkEnableOption '' - starship only when the shell is interactive. - Some plugins require this to be set to false to function correctly - '' // { default = true; }; + interactiveOnly = + lib.mkEnableOption '' + starship only when the shell is interactive. + Some plugins require this to be set to false to function correctly + '' + // { + default = true; + }; presets = lib.mkOption { default = [ ]; diff --git a/nixos/modules/programs/streamdeck-ui.nix b/nixos/modules/programs/streamdeck-ui.nix index a1366c42181c26..fc1754a519700a 100644 --- a/nixos/modules/programs/streamdeck-ui.nix +++ b/nixos/modules/programs/streamdeck-ui.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.streamdeck-ui; @@ -22,7 +27,12 @@ in config = lib.mkIf cfg.enable { environment.systemPackages = [ cfg.package - (lib.mkIf cfg.autoStart (pkgs.makeAutostartItem { name = "streamdeck-ui-noui"; package = cfg.package; })) + (lib.mkIf cfg.autoStart ( + pkgs.makeAutostartItem { + name = "streamdeck-ui-noui"; + package = cfg.package; + } + )) ]; services.udev.packages = [ cfg.package ]; diff --git a/nixos/modules/programs/sysdig.nix b/nixos/modules/programs/sysdig.nix index 47b95ef64e97f2..8bb851c17e40e7 100644 --- a/nixos/modules/programs/sysdig.nix +++ b/nixos/modules/programs/sysdig.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.sysdig; -in { +in +{ options.programs.sysdig.enable = lib.mkEnableOption "sysdig, a tracing tool"; config = lib.mkIf cfg.enable { diff --git a/nixos/modules/programs/system-config-printer.nix b/nixos/modules/programs/system-config-printer.nix index 68b7897d64c249..bb2b805fb87108 100644 --- a/nixos/modules/programs/system-config-printer.nix +++ b/nixos/modules/programs/system-config-printer.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { @@ -14,7 +19,6 @@ }; - ###### implementation config = lib.mkIf config.programs.system-config-printer.enable { diff --git a/nixos/modules/programs/systemtap.nix b/nixos/modules/programs/systemtap.nix index e61e255e522175..b5a9d5dffc9881 100644 --- a/nixos/modules/programs/systemtap.nix +++ b/nixos/modules/programs/systemtap.nix @@ -1,7 +1,9 @@ { config, lib, ... }: -let cfg = config.programs.systemtap; -in { +let + cfg = config.programs.systemtap; +in +{ options = { programs.systemtap = { diff --git a/nixos/modules/programs/thefuck.nix b/nixos/modules/programs/thefuck.nix index 0e65352a1f2165..dccc3079d31f45 100644 --- a/nixos/modules/programs/thefuck.nix +++ b/nixos/modules/programs/thefuck.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let prg = config.programs; @@ -11,28 +16,28 @@ let ${pkgs.thefuck}/bin/thefuck --alias ${cfg.alias} | source ''; in - { - options = { - programs.thefuck = { - enable = lib.mkEnableOption "thefuck, an app which corrects your previous console command"; +{ + options = { + programs.thefuck = { + enable = lib.mkEnableOption "thefuck, an app which corrects your previous console command"; - alias = lib.mkOption { - default = "fuck"; - type = lib.types.str; + alias = lib.mkOption { + default = "fuck"; + type = lib.types.str; - description = '' - `thefuck` needs an alias to be configured. - The default value is `fuck`, but you can use anything else as well. - ''; - }; + description = '' + `thefuck` needs an alias to be configured. + The default value is `fuck`, but you can use anything else as well. + ''; }; }; + }; - config = lib.mkIf cfg.enable { - environment.systemPackages = with pkgs; [ thefuck ]; + config = lib.mkIf cfg.enable { + environment.systemPackages = with pkgs; [ thefuck ]; - programs.bash.interactiveShellInit = bashAndZshInitScript; - programs.zsh.interactiveShellInit = lib.mkIf prg.zsh.enable bashAndZshInitScript; - programs.fish.interactiveShellInit = lib.mkIf prg.fish.enable fishInitScript; - }; - } + programs.bash.interactiveShellInit = bashAndZshInitScript; + programs.zsh.interactiveShellInit = lib.mkIf prg.zsh.enable bashAndZshInitScript; + programs.fish.interactiveShellInit = lib.mkIf prg.fish.enable fishInitScript; + }; +} diff --git a/nixos/modules/programs/thunar.nix b/nixos/modules/programs/thunar.nix index 76fcc9d8298f48..57ce59f4e7a55c 100644 --- a/nixos/modules/programs/thunar.nix +++ b/nixos/modules/programs/thunar.nix @@ -1,8 +1,15 @@ -{ config, lib, pkgs, ... }: - -let cfg = config.programs.thunar; - -in { +{ + config, + lib, + pkgs, + ... +}: + +let + cfg = config.programs.thunar; + +in +{ meta = { maintainers = lib.teams.xfce.members; }; @@ -12,7 +19,7 @@ in { enable = lib.mkEnableOption "Thunar, the Xfce file manager"; plugins = lib.mkOption { - default = []; + default = [ ]; type = lib.types.listOf lib.types.package; description = "List of thunar plugins to install."; example = lib.literalExpression "with pkgs.xfce; [ thunar-archive-plugin thunar-volman ]"; @@ -22,9 +29,11 @@ in { }; config = lib.mkIf cfg.enable ( - let package = pkgs.xfce.thunar.override { thunarPlugins = cfg.plugins; }; + let + package = pkgs.xfce.thunar.override { thunarPlugins = cfg.plugins; }; - in { + in + { environment.systemPackages = [ package ]; diff --git a/nixos/modules/programs/tmux.nix b/nixos/modules/programs/tmux.nix index a157bedc8aae68..fe7a2789f71b8f 100644 --- a/nixos/modules/programs/tmux.nix +++ b/nixos/modules/programs/tmux.nix @@ -1,12 +1,22 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let - inherit (lib) mkOption mkIf types optionalString; + inherit (lib) + mkOption + mkIf + types + optionalString + ; cfg = config.programs.tmux; - defaultKeyMode = "emacs"; - defaultResize = 5; + defaultKeyMode = "emacs"; + defaultResize = 5; defaultShortcut = "b"; defaultTerminal = "screen"; @@ -21,31 +31,31 @@ let ${optionalString cfg.newSession "new-session"} ${optionalString cfg.reverseSplit '' - bind v split-window -h - bind s split-window -v + bind v split-window -h + bind s split-window -v ''} set -g status-keys ${cfg.keyMode} set -g mode-keys ${cfg.keyMode} ${optionalString (cfg.keyMode == "vi" && cfg.customPaneNavigationAndResize) '' - bind h select-pane -L - bind j select-pane -D - bind k select-pane -U - bind l select-pane -R - - bind -r H resize-pane -L ${toString cfg.resizeAmount} - bind -r J resize-pane -D ${toString cfg.resizeAmount} - bind -r K resize-pane -U ${toString cfg.resizeAmount} - bind -r L resize-pane -R ${toString cfg.resizeAmount} + bind h select-pane -L + bind j select-pane -D + bind k select-pane -U + bind l select-pane -R + + bind -r H resize-pane -L ${toString cfg.resizeAmount} + bind -r J resize-pane -D ${toString cfg.resizeAmount} + bind -r K resize-pane -U ${toString cfg.resizeAmount} + bind -r L resize-pane -R ${toString cfg.resizeAmount} ''} ${optionalString (cfg.shortcut != defaultShortcut) '' - # rebind main key: C-${cfg.shortcut} - unbind C-${defaultShortcut} - set -g prefix C-${cfg.shortcut} - bind ${cfg.shortcut} send-prefix - bind C-${cfg.shortcut} last-window + # rebind main key: C-${cfg.shortcut} + unbind C-${defaultShortcut} + set -g prefix C-${cfg.shortcut} + bind ${cfg.shortcut} send-prefix + bind C-${cfg.shortcut} last-window ''} setw -g aggressive-resize ${boolToStr cfg.aggressiveResize} @@ -54,16 +64,17 @@ let ${cfg.extraConfigBeforePlugins} - ${lib.optionalString (cfg.plugins != []) '' - # Run plugins - ${lib.concatMapStringsSep "\n" (x: "run-shell ${x.rtp}") cfg.plugins} + ${lib.optionalString (cfg.plugins != [ ]) '' + # Run plugins + ${lib.concatMapStringsSep "\n" (x: "run-shell ${x.rtp}") cfg.plugins} ''} ${cfg.extraConfig} ''; -in { +in +{ ###### interface options = { @@ -136,7 +147,10 @@ in { keyMode = mkOption { default = defaultKeyMode; example = "vi"; - type = types.enum [ "emacs" "vi" ]; + type = types.enum [ + "emacs" + "vi" + ]; description = "VI or Emacs style shortcuts."; }; @@ -186,7 +200,7 @@ in { }; plugins = mkOption { - default = []; + default = [ ]; type = types.listOf types.package; description = "List of plugins to install."; example = lib.literalExpression "[ pkgs.tmuxPlugins.nord ]"; @@ -228,7 +242,10 @@ in { }; imports = [ - (lib.mkRenamedOptionModule [ "programs" "tmux" "extraTmuxConf" ] [ "programs" "tmux" "extraConfig" ]) + (lib.mkRenamedOptionModule + [ "programs" "tmux" "extraTmuxConf" ] + [ "programs" "tmux" "extraConfig" ] + ) ]; meta.maintainers = with lib.maintainers; [ hxtmdev ]; diff --git a/nixos/modules/programs/trippy.nix b/nixos/modules/programs/trippy.nix index 707370fb31a515..6b906cb58f52ef 100644 --- a/nixos/modules/programs/trippy.nix +++ b/nixos/modules/programs/trippy.nix @@ -1,4 +1,9 @@ -{ lib, config, pkgs, ... }: +{ + lib, + config, + pkgs, + ... +}: let cfg = config.programs.trippy; diff --git a/nixos/modules/programs/tsm-client.nix b/nixos/modules/programs/tsm-client.nix index 1795db5c2470e0..9e50e38acc9242 100644 --- a/nixos/modules/programs/tsm-client.nix +++ b/nixos/modules/programs/tsm-client.nix @@ -1,115 +1,177 @@ -{ config, lib, options, pkgs, ... }: # XXX migration code for freeform settings: `options` can be removed in 2025 -let optionsGlobal = options; in +{ + config, + lib, + options, + pkgs, + ... +}: # XXX migration code for freeform settings: `options` can be removed in 2025 +let + optionsGlobal = options; +in let - inherit (lib.attrsets) attrNames attrValues mapAttrsToList removeAttrs; - inherit (lib.lists) all allUnique concatLists concatMap elem isList map; + inherit (lib.attrsets) + attrNames + attrValues + mapAttrsToList + removeAttrs + ; + inherit (lib.lists) + all + allUnique + concatLists + concatMap + elem + isList + map + ; inherit (lib.modules) mkDefault mkIf; inherit (lib.options) mkEnableOption mkOption mkPackageOption; - inherit (lib.strings) concatLines match optionalString toLower; + inherit (lib.strings) + concatLines + match + optionalString + toLower + ; inherit (lib.trivial) isInt; - inherit (lib.types) addCheck attrsOf coercedTo either enum int lines listOf nonEmptyStr nullOr oneOf path port singleLineStr strMatching submodule; + inherit (lib.types) + addCheck + attrsOf + coercedTo + either + enum + int + lines + listOf + nonEmptyStr + nullOr + oneOf + path + port + singleLineStr + strMatching + submodule + ; scalarType = # see the option's description below for the # handling/transformation of each possible type - oneOf [ (enum [ true null ]) int path singleLineStr ]; + oneOf [ + (enum [ + true + null + ]) + int + path + singleLineStr + ]; # TSM rejects servername strings longer than 64 chars. servernameType = strMatching "[^[:space:]]{1,64}"; - serverOptions = { name, config, ... }: { - freeformType = attrsOf (either scalarType (listOf scalarType)); - # Client system-options file directives are explained here: - # https://www.ibm.com/docs/en/storage-protect/8.1.24?topic=commands-processing-options - options.servername = mkOption { - type = servernameType; - default = name; - example = "mainTsmServer"; - description = '' - Local name of the IBM TSM server, - must not contain space or more than 64 chars. - ''; - }; - options.tcpserveraddress = mkOption { - type = nonEmptyStr; - example = "tsmserver.company.com"; - description = '' - Host/domain name or IP address of the IBM TSM server. - ''; - }; - options.tcpport = mkOption { - type = addCheck port (p: p<=32767); - default = 1500; # official default - description = '' - TCP port of the IBM TSM server. - TSM does not support ports above 32767. - ''; - }; - options.nodename = mkOption { - type = nonEmptyStr; - example = "MY-TSM-NODE"; - description = '' - Target node name on the IBM TSM server. - ''; - }; - options.genPasswd = mkEnableOption '' - automatic client password generation. - This option does *not* cause a line in - {file}`dsm.sys` by itself, but generates a - corresponding `passwordaccess` directive. - The password will be stored in the directory - given by the option {option}`passworddir`. - *Caution*: - If this option is enabled and the server forces - to renew the password (e.g. on first connection), - a random password will be generated and stored - ''; - options.passwordaccess = mkOption { - type = enum [ "generate" "prompt" ]; - visible = false; - }; - options.passworddir = mkOption { - type = nullOr path; - default = null; - example = "/home/alice/tsm-password"; - description = '' - Directory that holds the TSM - node's password information. - ''; - }; - options.inclexcl = mkOption { - type = coercedTo lines - (pkgs.writeText "inclexcl.dsm.sys") - (nullOr path); - default = null; - example = '' - exclude.dir /nix/store - include.encrypt /home/.../* - ''; - description = '' - Text lines with `include.*` and `exclude.*` directives - to be used when sending files to the IBM TSM server, - or an absolute path pointing to a file with such lines. + serverOptions = + { name, config, ... }: + { + freeformType = attrsOf (either scalarType (listOf scalarType)); + # Client system-options file directives are explained here: + # https://www.ibm.com/docs/en/storage-protect/8.1.24?topic=commands-processing-options + options.servername = mkOption { + type = servernameType; + default = name; + example = "mainTsmServer"; + description = '' + Local name of the IBM TSM server, + must not contain space or more than 64 chars. + ''; + }; + options.tcpserveraddress = mkOption { + type = nonEmptyStr; + example = "tsmserver.company.com"; + description = '' + Host/domain name or IP address of the IBM TSM server. + ''; + }; + options.tcpport = mkOption { + type = addCheck port (p: p <= 32767); + default = 1500; # official default + description = '' + TCP port of the IBM TSM server. + TSM does not support ports above 32767. + ''; + }; + options.nodename = mkOption { + type = nonEmptyStr; + example = "MY-TSM-NODE"; + description = '' + Target node name on the IBM TSM server. + ''; + }; + options.genPasswd = mkEnableOption '' + automatic client password generation. + This option does *not* cause a line in + {file}`dsm.sys` by itself, but generates a + corresponding `passwordaccess` directive. + The password will be stored in the directory + given by the option {option}`passworddir`. + *Caution*: + If this option is enabled and the server forces + to renew the password (e.g. on first connection), + a random password will be generated and stored ''; + options.passwordaccess = mkOption { + type = enum [ + "generate" + "prompt" + ]; + visible = false; + }; + options.passworddir = mkOption { + type = nullOr path; + default = null; + example = "/home/alice/tsm-password"; + description = '' + Directory that holds the TSM + node's password information. + ''; + }; + options.inclexcl = mkOption { + type = coercedTo lines (pkgs.writeText "inclexcl.dsm.sys") (nullOr path); + default = null; + example = '' + exclude.dir /nix/store + include.encrypt /home/.../* + ''; + description = '' + Text lines with `include.*` and `exclude.*` directives + to be used when sending files to the IBM TSM server, + or an absolute path pointing to a file with such lines. + ''; + }; + config.commmethod = mkDefault "v6tcpip"; # uses v4 or v6, based on dns lookup result + config.passwordaccess = if config.genPasswd then "generate" else "prompt"; + # XXX migration code for freeform settings, these can be removed in 2025: + options.warnings = optionsGlobal.warnings; + options.assertions = optionsGlobal.assertions; + imports = + let + inherit (lib.modules) mkRemovedOptionModule mkRenamedOptionModule; + in + [ + (mkRemovedOptionModule [ "extraConfig" ] + "Please just add options directly to the server attribute set, cf. the description of `programs.tsmClient.servers`." + ) + (mkRemovedOptionModule [ "text" ] + "Please just add options directly to the server attribute set, cf. the description of `programs.tsmClient.servers`." + ) + (mkRenamedOptionModule [ "name" ] [ "servername" ]) + (mkRenamedOptionModule [ "server" ] [ "tcpserveraddress" ]) + (mkRenamedOptionModule [ "port" ] [ "tcpport" ]) + (mkRenamedOptionModule [ "node" ] [ "nodename" ]) + (mkRenamedOptionModule [ "passwdDir" ] [ "passworddir" ]) + (mkRenamedOptionModule [ "includeExclude" ] [ "inclexcl" ]) + ]; }; - config.commmethod = mkDefault "v6tcpip"; # uses v4 or v6, based on dns lookup result - config.passwordaccess = if config.genPasswd then "generate" else "prompt"; - # XXX migration code for freeform settings, these can be removed in 2025: - options.warnings = optionsGlobal.warnings; - options.assertions = optionsGlobal.assertions; - imports = let inherit (lib.modules) mkRemovedOptionModule mkRenamedOptionModule; in [ - (mkRemovedOptionModule [ "extraConfig" ] "Please just add options directly to the server attribute set, cf. the description of `programs.tsmClient.servers`.") - (mkRemovedOptionModule [ "text" ] "Please just add options directly to the server attribute set, cf. the description of `programs.tsmClient.servers`.") - (mkRenamedOptionModule [ "name" ] [ "servername" ]) - (mkRenamedOptionModule [ "server" ] [ "tcpserveraddress" ]) - (mkRenamedOptionModule [ "port" ] [ "tcpport" ]) - (mkRenamedOptionModule [ "node" ] [ "nodename" ]) - (mkRenamedOptionModule [ "passwdDir" ] [ "passworddir" ]) - (mkRenamedOptionModule [ "includeExclude" ] [ "inclexcl" ]) - ]; - }; options.programs.tsmClient = { enable = mkEnableOption '' @@ -119,7 +181,7 @@ let ''; servers = mkOption { type = attrsOf (submodule serverOptions); - default = {}; + default = { }; example.mainTsmServer = { tcpserveraddress = "tsmserver.company.com"; nodename = "MY-TSM-NODE"; @@ -173,16 +235,20 @@ let to add paths to the client system-options file. ''; }; - wrappedPackage = mkPackageOption pkgs "tsm-client" { - default = null; - extraDescription = '' - This option is to provide the effective derivation, - wrapped with the path to the - client system-options file "dsm.sys". - It should not be changed, but exists - for other modules that want to call TSM executables. - ''; - } // { readOnly = true; }; + wrappedPackage = + mkPackageOption pkgs "tsm-client" { + default = null; + extraDescription = '' + This option is to provide the effective derivation, + wrapped with the path to the + client system-options file "dsm.sys". + It should not be changed, but exists + for other modules that want to call TSM executables. + ''; + } + // { + readOnly = true; + }; }; cfg = config.programs.tsmClient; @@ -200,7 +266,7 @@ let ''; } { - assertion = (cfg.defaultServername!=null)->(elem cfg.defaultServername servernames); + assertion = (cfg.defaultServername != null) -> (elem cfg.defaultServername servernames); message = '' TSM default server name `programs.tsmClient.defaultServername="${cfg.defaultServername}"` @@ -208,14 +274,16 @@ let `programs.tsmClient.servers`. ''; } - ] ++ (mapAttrsToList (name: serverCfg: { + ] + ++ (mapAttrsToList (name: serverCfg: { assertion = all (key: null != match "[^[:space:]]+" key) (attrNames serverCfg); message = '' TSM server setting names in `programs.tsmClient.servers.${name}.*` contain spaces, but that's not allowed. ''; - }) cfg.servers) ++ (mapAttrsToList (name: serverCfg: { + }) cfg.servers) + ++ (mapAttrsToList (name: serverCfg: { assertion = allUnique (map toLower (attrNames serverCfg)); message = '' TSM server setting names in @@ -225,36 +293,70 @@ let ''; }) cfg.servers) # XXX migration code for freeform settings, this can be removed in 2025: - ++ (enrichMigrationInfos "assertions" (addText: { assertion, message }: { inherit assertion; message = addText message; })); + ++ (enrichMigrationInfos "assertions" ( + addText: + { assertion, message }: + { + inherit assertion; + message = addText message; + } + )); - makeDsmSysLines = key: value: + makeDsmSysLines = + key: value: # Turn a key-value pair from the server options attrset # into zero (value==null), one (scalar value) or # more (value is list) configuration stanza lines. - if isList value then concatMap (makeDsmSysLines key) value else # recurse into list - if value == null then [ ] else # skip `null` value - [ (" ${key}${ - if value == true then "" else # just output key if value is `true` - if isInt value then " ${builtins.toString value}" else - if path.check value then " \"${value}\"" else # enclose path in ".." - if singleLineStr.check value then " ${value}" else - throw "assertion failed: cannot convert type" # should never happen - }") ]; + if isList value then + concatMap (makeDsmSysLines key) value + # recurse into list + else if value == null then + [ ] + # skip `null` value + else + [ + ( + " ${key}${ + if value == true then + "" + # just output key if value is `true` + else if isInt value then + " ${builtins.toString value}" + else if path.check value then + " \"${value}\"" + # enclose path in ".." + else if singleLineStr.check value then + " ${value}" + else + throw "assertion failed: cannot convert type" # should never happen + }" + ) + ]; - makeDsmSysStanza = {servername, ... }@serverCfg: + makeDsmSysStanza = + { servername, ... }@serverCfg: let # drop special values that should not go into server config block - attrs = removeAttrs serverCfg [ "servername" "genPasswd" + attrs = removeAttrs serverCfg [ + "servername" + "genPasswd" # XXX migration code for freeform settings, these can be removed in 2025: - "assertions" "warnings" - "extraConfig" "text" - "name" "server" "port" "node" "passwdDir" "includeExclude" + "assertions" + "warnings" + "extraConfig" + "text" + "name" + "server" + "port" + "node" + "passwdDir" + "includeExclude" ]; in - '' - servername ${servername} - ${concatLines (concatLists (mapAttrsToList makeDsmSysLines attrs))} - ''; + '' + servername ${servername} + ${concatLines (concatLists (mapAttrsToList makeDsmSysLines attrs))} + ''; dsmSysText = '' **** IBM Storage Protect (Tivoli Storage Manager) @@ -262,17 +364,20 @@ let **** Do not edit! **** This file is generated by NixOS configuration. - ${optionalString (cfg.defaultServername!=null) "defaultserver ${cfg.defaultServername}"} + ${optionalString (cfg.defaultServername != null) "defaultserver ${cfg.defaultServername}"} ${concatLines (map makeDsmSysStanza (attrValues cfg.servers))} ''; # XXX migration code for freeform settings, this can be removed in 2025: - enrichMigrationInfos = what: how: concatLists ( - mapAttrsToList - (name: serverCfg: map (how (text: "In `programs.tsmClient.servers.${name}`: ${text}")) serverCfg."${what}") - cfg.servers - ); + enrichMigrationInfos = + what: how: + concatLists ( + mapAttrsToList ( + name: serverCfg: + map (how (text: "In `programs.tsmClient.servers.${name}`: ${text}")) serverCfg."${what}" + ) cfg.servers + ); in diff --git a/nixos/modules/programs/turbovnc.nix b/nixos/modules/programs/turbovnc.nix index c7ab18a2e2886d..51550476cc352d 100644 --- a/nixos/modules/programs/turbovnc.nix +++ b/nixos/modules/programs/turbovnc.nix @@ -1,6 +1,11 @@ # Global configuration for the SSH client. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.turbovnc; diff --git a/nixos/modules/programs/udevil.nix b/nixos/modules/programs/udevil.nix index e4c0daea72c1b3..09d8ca4b288b2d 100644 --- a/nixos/modules/programs/udevil.nix +++ b/nixos/modules/programs/udevil.nix @@ -1,17 +1,23 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.udevil; -in { +in +{ options.programs.udevil.enable = lib.mkEnableOption "udevil, to mount filesystems without password"; config = lib.mkIf cfg.enable { - security.wrappers.udevil = - { setuid = true; - owner = "root"; - group = "root"; - source = "${lib.getBin pkgs.udevil}/bin/udevil"; - }; + security.wrappers.udevil = { + setuid = true; + owner = "root"; + group = "root"; + source = "${lib.getBin pkgs.udevil}/bin/udevil"; + }; }; } diff --git a/nixos/modules/programs/usbtop.nix b/nixos/modules/programs/usbtop.nix index 8b77b2bf51c43c..6edb8d57b54c36 100644 --- a/nixos/modules/programs/usbtop.nix +++ b/nixos/modules/programs/usbtop.nix @@ -1,8 +1,14 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.usbtop; -in { +in +{ options = { programs.usbtop.enable = lib.mkEnableOption "usbtop and required kernel module, to show estimated USB bandwidth"; }; diff --git a/nixos/modules/programs/virt-manager.nix b/nixos/modules/programs/virt-manager.nix index 9b5fa22268ae9b..f0972ab6111c7b 100644 --- a/nixos/modules/programs/virt-manager.nix +++ b/nixos/modules/programs/virt-manager.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.virt-manager; diff --git a/nixos/modules/programs/virtualbox.nix b/nixos/modules/programs/virtualbox.nix index be96cf23b39698..e57b4078bfd4b5 100644 --- a/nixos/modules/programs/virtualbox.nix +++ b/nixos/modules/programs/virtualbox.nix @@ -1,8 +1,10 @@ let - msg = "Importing is " - + "deprecated, please use `virtualisation.virtualbox.host.enable = true' " - + "instead."; -in { + msg = + "Importing is " + + "deprecated, please use `virtualisation.virtualbox.host.enable = true' " + + "instead."; +in +{ config.warnings = [ msg ]; config.virtualisation.virtualbox.host.enable = true; } diff --git a/nixos/modules/programs/wavemon.nix b/nixos/modules/programs/wavemon.nix index 86bc7cc0979546..2d3e53401897a8 100644 --- a/nixos/modules/programs/wavemon.nix +++ b/nixos/modules/programs/wavemon.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.wavemon; -in { +in +{ options = { programs.wavemon = { enable = lib.mkOption { diff --git a/nixos/modules/programs/wayland/cardboard.nix b/nixos/modules/programs/wayland/cardboard.nix index 96089bdf94edb4..5d05fc3d96bcc0 100644 --- a/nixos/modules/programs/wayland/cardboard.nix +++ b/nixos/modules/programs/wayland/cardboard.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.cardboard; @@ -12,13 +17,15 @@ in package = lib.mkPackageOption pkgs "cardboard" { }; }; - config = lib.mkIf cfg.enable (lib.mkMerge [ - { - environment.systemPackages = [ cfg.package ]; + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + { + environment.systemPackages = [ cfg.package ]; - # To make a cardboard session available for certain DMs like SDDM - services.displayManager.sessionPackages = [ cfg.package ]; - } - (import ./wayland-session.nix { inherit lib pkgs; }) - ]); + # To make a cardboard session available for certain DMs like SDDM + services.displayManager.sessionPackages = [ cfg.package ]; + } + (import ./wayland-session.nix { inherit lib pkgs; }) + ] + ); } diff --git a/nixos/modules/programs/wayland/hyprlock.nix b/nixos/modules/programs/wayland/hyprlock.nix index 6c60765e80cc7a..1b55c75f085297 100644 --- a/nixos/modules/programs/wayland/hyprlock.nix +++ b/nixos/modules/programs/wayland/hyprlock.nix @@ -1,4 +1,9 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: let cfg = config.programs.hyprlock; @@ -18,7 +23,7 @@ in services.hypridle.enable = true; # Hyprlock needs PAM access to authenticate, else it fallbacks to su - security.pam.services.hyprlock = {}; + security.pam.services.hyprlock = { }; }; meta.maintainers = with lib.maintainers; [ johnrtitor ]; diff --git a/nixos/modules/programs/wayland/labwc.nix b/nixos/modules/programs/wayland/labwc.nix index c09ab8240d9f2e..247b6b43a73f73 100644 --- a/nixos/modules/programs/wayland/labwc.nix +++ b/nixos/modules/programs/wayland/labwc.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.labwc; @@ -11,15 +16,20 @@ in package = lib.mkPackageOption pkgs "labwc" { }; }; - config = lib.mkIf cfg.enable (lib.mkMerge [ - { - environment.systemPackages = [ cfg.package ]; + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + { + environment.systemPackages = [ cfg.package ]; - xdg.portal.config.wlroots.default = lib.mkDefault [ "wlr" "gtk" ]; + xdg.portal.config.wlroots.default = lib.mkDefault [ + "wlr" + "gtk" + ]; - # To make a labwc session available for certain DMs like SDDM - services.displayManager.sessionPackages = [ cfg.package ]; - } - (import ./wayland-session.nix { inherit lib pkgs; }) - ]); + # To make a labwc session available for certain DMs like SDDM + services.displayManager.sessionPackages = [ cfg.package ]; + } + (import ./wayland-session.nix { inherit lib pkgs; }) + ] + ); } diff --git a/nixos/modules/programs/wayland/lib.nix b/nixos/modules/programs/wayland/lib.nix index 0f275d3f18c565..bc639dc6d0e0cc 100644 --- a/nixos/modules/programs/wayland/lib.nix +++ b/nixos/modules/programs/wayland/lib.nix @@ -1,12 +1,13 @@ { lib }: { - genFinalPackage = pkg: args: + genFinalPackage = + pkg: args: let - expectedArgs = with lib; - lib.naturalSort (lib.attrNames args); - existingArgs = with lib; + expectedArgs = with lib; lib.naturalSort (lib.attrNames args); + existingArgs = + with lib; naturalSort (intersectLists expectedArgs (attrNames (functionArgs pkg.override))); in - if existingArgs != expectedArgs then pkg else pkg.override args; + if existingArgs != expectedArgs then pkg else pkg.override args; } diff --git a/nixos/modules/programs/wayland/river.nix b/nixos/modules/programs/wayland/river.nix index 6391f00e2f6261..c1e62938f2e005 100644 --- a/nixos/modules/programs/wayland/river.nix +++ b/nixos/modules/programs/wayland/river.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.river; @@ -9,27 +14,39 @@ in options.programs.river = { enable = lib.mkEnableOption "river, a dynamic tiling Wayland compositor"; - package = lib.mkPackageOption pkgs "river" { - nullable = true; - extraDescription = '' - If the package is not overridable with `xwaylandSupport`, then the module option - {option}`xwayland` will have no effect. + package = + lib.mkPackageOption pkgs "river" { + nullable = true; + extraDescription = '' + If the package is not overridable with `xwaylandSupport`, then the module option + {option}`xwayland` will have no effect. - Set to `null` to not add any River package to your path. - This should be done if you want to use the Home Manager River module to install River. - ''; - } // { - apply = p: if p == null then null else - wayland-lib.genFinalPackage p { - xwaylandSupport = cfg.xwayland.enable; - }; - }; + Set to `null` to not add any River package to your path. + This should be done if you want to use the Home Manager River module to install River. + ''; + } + // { + apply = + p: + if p == null then + null + else + wayland-lib.genFinalPackage p { + xwaylandSupport = cfg.xwayland.enable; + }; + }; - xwayland.enable = lib.mkEnableOption "XWayland" // { default = true; }; + xwayland.enable = lib.mkEnableOption "XWayland" // { + default = true; + }; extraPackages = lib.mkOption { type = with lib.types; listOf package; - default = with pkgs; [ swaylock foot dmenu ]; + default = with pkgs; [ + swaylock + foot + dmenu + ]; defaultText = lib.literalExpression '' with pkgs; [ swaylock foot dmenu ]; ''; @@ -44,22 +61,27 @@ in }; }; - config = lib.mkIf cfg.enable (lib.mkMerge [ - { - environment.systemPackages = lib.optional (cfg.package != null) cfg.package ++ cfg.extraPackages; + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + { + environment.systemPackages = lib.optional (cfg.package != null) cfg.package ++ cfg.extraPackages; - # To make a river session available if a display manager like SDDM is enabled: - services.displayManager.sessionPackages = lib.optional (cfg.package != null) cfg.package; + # To make a river session available if a display manager like SDDM is enabled: + services.displayManager.sessionPackages = lib.optional (cfg.package != null) cfg.package; - # https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=1050913 - xdg.portal.config.river.default = lib.mkDefault [ "wlr" "gtk" ]; - } + # https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=1050913 + xdg.portal.config.river.default = lib.mkDefault [ + "wlr" + "gtk" + ]; + } - (import ./wayland-session.nix { - inherit lib pkgs; - enableXWayland = cfg.xwayland.enable; - }) - ]); + (import ./wayland-session.nix { + inherit lib pkgs; + enableXWayland = cfg.xwayland.enable; + }) + ] + ); meta.maintainers = with lib.maintainers; [ GaetanLepage ]; } diff --git a/nixos/modules/programs/wayland/wayland-session.nix b/nixos/modules/programs/wayland/wayland-session.nix index 1f5dc413d377bc..de24bf73e63045 100644 --- a/nixos/modules/programs/wayland/wayland-session.nix +++ b/nixos/modules/programs/wayland/wayland-session.nix @@ -9,7 +9,7 @@ { security = { polkit.enable = true; - pam.services.swaylock = {}; + pam.services.swaylock = { }; }; programs = { diff --git a/nixos/modules/programs/weylus.nix b/nixos/modules/programs/weylus.nix index d76e2f81b2c947..b9b23f84e2836e 100644 --- a/nixos/modules/programs/weylus.nix +++ b/nixos/modules/programs/weylus.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.weylus; @@ -15,7 +20,7 @@ in ''; }; - users = lib.mkOption { + users = lib.mkOption { type = listOf str; default = [ ]; description = '' @@ -28,7 +33,10 @@ in }; config = lib.mkIf cfg.enable { networking.firewall = lib.mkIf cfg.openFirewall { - allowedTCPPorts = [ 1701 9001 ]; + allowedTCPPorts = [ + 1701 + 9001 + ]; }; hardware.uinput.enable = true; diff --git a/nixos/modules/programs/winbox.nix b/nixos/modules/programs/winbox.nix index 1337f57839b02e..d4be0a08d87163 100644 --- a/nixos/modules/programs/winbox.nix +++ b/nixos/modules/programs/winbox.nix @@ -1,7 +1,12 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - cfg = config.programs.winbox; + cfg = config.programs.winbox; in { options.programs.winbox = { diff --git a/nixos/modules/programs/wireshark.nix b/nixos/modules/programs/wireshark.nix index f5673e5940feac..a804385b834c61 100644 --- a/nixos/modules/programs/wireshark.nix +++ b/nixos/modules/programs/wireshark.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.wireshark; wireshark = cfg.package; -in { +in +{ options = { programs.wireshark = { enable = lib.mkOption { @@ -22,7 +28,7 @@ in { config = lib.mkIf cfg.enable { environment.systemPackages = [ wireshark ]; - users.groups.wireshark = {}; + users.groups.wireshark = { }; security.wrappers.dumpcap = { source = "${wireshark}/bin/dumpcap"; diff --git a/nixos/modules/programs/xastir.nix b/nixos/modules/programs/xastir.nix index 96201eb5455d04..9f6b68b33f993b 100644 --- a/nixos/modules/programs/xastir.nix +++ b/nixos/modules/programs/xastir.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.xastir; -in { +in +{ meta.maintainers = with lib.maintainers; [ melling ]; options.programs.xastir = { diff --git a/nixos/modules/programs/xfconf.nix b/nixos/modules/programs/xfconf.nix index f2fda3b692d37c..1788b220439ca4 100644 --- a/nixos/modules/programs/xfconf.nix +++ b/nixos/modules/programs/xfconf.nix @@ -1,8 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: -let cfg = config.programs.xfconf; +let + cfg = config.programs.xfconf; -in { +in +{ meta = { maintainers = lib.teams.xfce.members; }; diff --git a/nixos/modules/programs/xfs_quota.nix b/nixos/modules/programs/xfs_quota.nix index 5ca05f4dc297e2..b8f284e4ea1dcd 100644 --- a/nixos/modules/programs/xfs_quota.nix +++ b/nixos/modules/programs/xfs_quota.nix @@ -1,15 +1,22 @@ # Configuration for the xfs_quota command -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.xfs_quota; - limitOptions = opts: builtins.concatStringsSep " " [ - (lib.optionalString (opts.sizeSoftLimit != null) "bsoft=${opts.sizeSoftLimit}") - (lib.optionalString (opts.sizeHardLimit != null) "bhard=${opts.sizeHardLimit}") - ]; + limitOptions = + opts: + builtins.concatStringsSep " " [ + (lib.optionalString (opts.sizeSoftLimit != null) "bsoft=${opts.sizeSoftLimit}") + (lib.optionalString (opts.sizeHardLimit != null) "bhard=${opts.sizeHardLimit}") + ]; in @@ -21,40 +28,42 @@ in programs.xfs_quota = { projects = lib.mkOption { - default = {}; - type = lib.types.attrsOf (lib.types.submodule { - options = { - id = lib.mkOption { - type = lib.types.int; - description = "Project ID."; - }; - - fileSystem = lib.mkOption { - type = lib.types.str; - description = "XFS filesystem hosting the xfs_quota project."; - default = "/"; + default = { }; + type = lib.types.attrsOf ( + lib.types.submodule { + options = { + id = lib.mkOption { + type = lib.types.int; + description = "Project ID."; + }; + + fileSystem = lib.mkOption { + type = lib.types.str; + description = "XFS filesystem hosting the xfs_quota project."; + default = "/"; + }; + + path = lib.mkOption { + type = lib.types.str; + description = "Project directory."; + }; + + sizeSoftLimit = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = null; + example = "30g"; + description = "Soft limit of the project size"; + }; + + sizeHardLimit = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = null; + example = "50g"; + description = "Hard limit of the project size."; + }; }; - - path = lib.mkOption { - type = lib.types.str; - description = "Project directory."; - }; - - sizeSoftLimit = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - example = "30g"; - description = "Soft limit of the project size"; - }; - - sizeHardLimit = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - example = "50g"; - description = "Hard limit of the project size."; - }; - }; - }); + } + ); description = "Setup of xfs_quota projects. Make sure the filesystem is mounted with the pquota option."; @@ -70,20 +79,24 @@ in }; - ###### implementation - config = lib.mkIf (cfg.projects != {}) { + config = lib.mkIf (cfg.projects != { }) { - environment.etc.projects.source = pkgs.writeText "etc-project" - (builtins.concatStringsSep "\n" (lib.mapAttrsToList - (name: opts: "${builtins.toString opts.id}:${opts.path}") cfg.projects)); + environment.etc.projects.source = pkgs.writeText "etc-project" ( + builtins.concatStringsSep "\n" ( + lib.mapAttrsToList (name: opts: "${builtins.toString opts.id}:${opts.path}") cfg.projects + ) + ); - environment.etc.projid.source = pkgs.writeText "etc-projid" - (builtins.concatStringsSep "\n" (lib.mapAttrsToList - (name: opts: "${name}:${builtins.toString opts.id}") cfg.projects)); + environment.etc.projid.source = pkgs.writeText "etc-projid" ( + builtins.concatStringsSep "\n" ( + lib.mapAttrsToList (name: opts: "${name}:${builtins.toString opts.id}") cfg.projects + ) + ); - systemd.services = lib.mapAttrs' (name: opts: + systemd.services = lib.mapAttrs' ( + name: opts: lib.nameValuePair "xfs_quota-${name}" { description = "Setup xfs_quota for project ${name}"; script = '' diff --git a/nixos/modules/programs/xss-lock.nix b/nixos/modules/programs/xss-lock.nix index b818c52e1442db..537bf60594e656 100644 --- a/nixos/modules/programs/xss-lock.nix +++ b/nixos/modules/programs/xss-lock.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.xss-lock; @@ -31,13 +36,17 @@ in description = "XSS Lock Daemon"; wantedBy = [ "graphical-session.target" ]; partOf = [ "graphical-session.target" ]; - serviceConfig.ExecStart = - builtins.concatStringsSep " " ([ - "${pkgs.xss-lock}/bin/xss-lock" "--session \${XDG_SESSION_ID}" - ] ++ (builtins.map lib.escapeShellArg cfg.extraOptions) ++ [ - "--" - cfg.lockerCommand - ]); + serviceConfig.ExecStart = builtins.concatStringsSep " " ( + [ + "${pkgs.xss-lock}/bin/xss-lock" + "--session \${XDG_SESSION_ID}" + ] + ++ (builtins.map lib.escapeShellArg cfg.extraOptions) + ++ [ + "--" + cfg.lockerCommand + ] + ); serviceConfig.Restart = "always"; }; diff --git a/nixos/modules/programs/xwayland.nix b/nixos/modules/programs/xwayland.nix index 3df3dbf3783f32..6d00d6fe27edd1 100644 --- a/nixos/modules/programs/xwayland.nix +++ b/nixos/modules/programs/xwayland.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.xwayland; @@ -12,8 +17,7 @@ in defaultFontPath = lib.mkOption { type = lib.types.str; - default = lib.optionalString config.fonts.fontDir.enable - "/run/current-system/sw/share/X11/fonts"; + default = lib.optionalString config.fonts.fontDir.enable "/run/current-system/sw/share/X11/fonts"; defaultText = lib.literalExpression '' optionalString config.fonts.fontDir.enable "/run/current-system/sw/share/X11/fonts" ''; diff --git a/nixos/modules/programs/yabar.nix b/nixos/modules/programs/yabar.nix index e7168f85f41e01..c9275889927bc8 100644 --- a/nixos/modules/programs/yabar.nix +++ b/nixos/modules/programs/yabar.nix @@ -1,17 +1,27 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: let cfg = config.programs.yabar; - mapExtra = v: lib.concatStringsSep "\n" (lib.mapAttrsToList ( - key: val: "${key} = ${if (builtins.isString val) then "\"${val}\"" else "${builtins.toString val}"};" - ) v); + mapExtra = + v: + lib.concatStringsSep "\n" ( + lib.mapAttrsToList ( + key: val: + "${key} = ${if (builtins.isString val) then "\"${val}\"" else "${builtins.toString val}"};" + ) v + ); listKeys = r: builtins.concatStringsSep "," (builtins.map (n: "\"${n}\"") (builtins.attrNames r)); - configFile = let - bars = lib.mapAttrsToList ( - name: cfg: '' + configFile = + let + bars = lib.mapAttrsToList (name: cfg: '' ${name}: { font: "${cfg.font}"; position: "${cfg.position}"; @@ -20,58 +30,64 @@ let block-list: [${listKeys cfg.indicators}] - ${builtins.concatStringsSep "\n" (lib.mapAttrsToList ( - name: cfg: '' + ${builtins.concatStringsSep "\n" ( + lib.mapAttrsToList (name: cfg: '' ${name}: { exec: "${cfg.exec}"; align: "${cfg.align}"; ${mapExtra cfg.extra} }; - '' - ) cfg.indicators)} + '') cfg.indicators + )} }; - '' - ) cfg.bars; - in pkgs.writeText "yabar.conf" '' - bar-list = [${listKeys cfg.bars}]; - ${builtins.concatStringsSep "\n" bars} - ''; + '') cfg.bars; + in + pkgs.writeText "yabar.conf" '' + bar-list = [${listKeys cfg.bars}]; + ${builtins.concatStringsSep "\n" bars} + ''; in - { - options.programs.yabar = { - enable = lib.mkEnableOption "yabar, a status bar for X window managers"; - - package = lib.mkOption { - default = pkgs.yabar-unstable; - defaultText = lib.literalExpression "pkgs.yabar-unstable"; - example = lib.literalExpression "pkgs.yabar"; - type = lib.types.package; - - # `yabar-stable` segfaults under certain conditions. - # remember to update yabar.passthru.tests if nixos switches back to it! - apply = x: if x == pkgs.yabar-unstable then x else lib.flip lib.warn x '' - It's not recommended to use `yabar' with `programs.yabar', the (old) stable release - tends to segfault under certain circumstances: - - * https://github.com/geommer/yabar/issues/86 - * https://github.com/geommer/yabar/issues/68 - * https://github.com/geommer/yabar/issues/143 - - Most of them don't occur on master anymore, until a new release is published, it's recommended - to use `yabar-unstable'. - ''; - - description = '' - The package which contains the `yabar` binary. - - Nixpkgs provides the `yabar` and `yabar-unstable`, - so it's possible to choose. - ''; - }; - - bars = lib.mkOption { - default = {}; - type = lib.types.attrsOf(lib.types.submodule { +{ + options.programs.yabar = { + enable = lib.mkEnableOption "yabar, a status bar for X window managers"; + + package = lib.mkOption { + default = pkgs.yabar-unstable; + defaultText = lib.literalExpression "pkgs.yabar-unstable"; + example = lib.literalExpression "pkgs.yabar"; + type = lib.types.package; + + # `yabar-stable` segfaults under certain conditions. + # remember to update yabar.passthru.tests if nixos switches back to it! + apply = + x: + if x == pkgs.yabar-unstable then + x + else + lib.flip lib.warn x '' + It's not recommended to use `yabar' with `programs.yabar', the (old) stable release + tends to segfault under certain circumstances: + + * https://github.com/geommer/yabar/issues/86 + * https://github.com/geommer/yabar/issues/68 + * https://github.com/geommer/yabar/issues/143 + + Most of them don't occur on master anymore, until a new release is published, it's recommended + to use `yabar-unstable'. + ''; + + description = '' + The package which contains the `yabar` binary. + + Nixpkgs provides the `yabar` and `yabar-unstable`, + so it's possible to choose. + ''; + }; + + bars = lib.mkOption { + default = { }; + type = lib.types.attrsOf ( + lib.types.submodule { options = { font = lib.mkOption { default = "sans bold 9"; @@ -86,7 +102,10 @@ in position = lib.mkOption { default = "top"; example = "bottom"; - type = lib.types.enum [ "top" "bottom" ]; + type = lib.types.enum [ + "top" + "bottom" + ]; description = '' The position where the bar will be rendered. @@ -94,7 +113,7 @@ in }; extra = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.str; description = '' @@ -103,60 +122,67 @@ in }; indicators = lib.mkOption { - default = {}; - type = lib.types.attrsOf(lib.types.submodule { - options.exec = lib.mkOption { - example = "YABAR_DATE"; - type = lib.types.str; - description = '' - The type of the indicator to be executed. - ''; - }; - - options.align = lib.mkOption { - default = "left"; - example = "right"; - type = lib.types.enum [ "left" "center" "right" ]; - - description = '' - Whether to align the indicator at the left or right of the bar. - ''; - }; - - options.extra = lib.mkOption { - default = {}; - type = lib.types.attrsOf (lib.types.either lib.types.str lib.types.int); - - description = '' - An attribute set which contains further attributes of a indicator. - ''; - }; - }); + default = { }; + type = lib.types.attrsOf ( + lib.types.submodule { + options.exec = lib.mkOption { + example = "YABAR_DATE"; + type = lib.types.str; + description = '' + The type of the indicator to be executed. + ''; + }; + + options.align = lib.mkOption { + default = "left"; + example = "right"; + type = lib.types.enum [ + "left" + "center" + "right" + ]; + + description = '' + Whether to align the indicator at the left or right of the bar. + ''; + }; + + options.extra = lib.mkOption { + default = { }; + type = lib.types.attrsOf (lib.types.either lib.types.str lib.types.int); + + description = '' + An attribute set which contains further attributes of a indicator. + ''; + }; + } + ); description = '' Indicators that should be rendered by yabar. ''; }; }; - }); + } + ); - description = '' - List of bars that should be rendered by yabar. - ''; - }; + description = '' + List of bars that should be rendered by yabar. + ''; }; + }; - config = lib.mkIf cfg.enable { - systemd.user.services.yabar = { - description = "yabar service"; - wantedBy = [ "graphical-session.target" ]; - partOf = [ "graphical-session.target" ]; + config = lib.mkIf cfg.enable { + systemd.user.services.yabar = { + description = "yabar service"; + wantedBy = [ "graphical-session.target" ]; + partOf = [ "graphical-session.target" ]; - script = '' - ${cfg.package}/bin/yabar -c ${configFile} - ''; + script = '' + ${cfg.package}/bin/yabar -c ${configFile} + ''; - serviceConfig.Restart = "always"; - }; + serviceConfig.Restart = "always"; }; - } + }; +} diff --git a/nixos/modules/programs/yazi.nix b/nixos/modules/programs/yazi.nix index d9f38d8d81185a..b7e56cf630774e 100644 --- a/nixos/modules/programs/yazi.nix +++ b/nixos/modules/programs/yazi.nix @@ -1,11 +1,20 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.yazi; settingsFormat = pkgs.formats.toml { }; - files = [ "yazi" "theme" "keymap" ]; + files = [ + "yazi" + "theme" + "keymap" + ]; in { options.programs.yazi = { @@ -14,19 +23,28 @@ in package = lib.mkPackageOption pkgs "yazi" { }; settings = lib.mkOption { - type = with lib.types; submodule { - options = (lib.listToAttrs (map - (name: lib.nameValuePair name (lib.mkOption { - inherit (settingsFormat) type; - default = { }; - description = '' - Configuration included in `${name}.toml`. + type = + with lib.types; + submodule { + options = ( + lib.listToAttrs ( + map ( + name: + lib.nameValuePair name ( + lib.mkOption { + inherit (settingsFormat) type; + default = { }; + description = '' + Configuration included in `${name}.toml`. - See https://yazi-rs.github.io/docs/configuration/${name}/ for documentation. - ''; - })) - files)); - }; + See https://yazi-rs.github.io/docs/configuration/${name}/ for documentation. + ''; + } + ) + ) files + ) + ); + }; default = { }; description = '' Configuration included in `$YAZI_CONFIG_HOME`. @@ -43,7 +61,12 @@ in }; plugins = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ path package ]); + type = + with lib.types; + attrsOf (oneOf [ + path + package + ]); default = { }; description = '' Lua plugins. @@ -59,7 +82,12 @@ in }; flavors = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ path package ]); + type = + with lib.types; + attrsOf (oneOf [ + path + package + ]); default = { }; description = '' Pre-made themes. @@ -79,7 +107,12 @@ in config = lib.mkIf cfg.enable { environment.systemPackages = [ (cfg.package.override { - inherit (cfg) settings initLua plugins flavors; + inherit (cfg) + settings + initLua + plugins + flavors + ; }) ]; }; diff --git a/nixos/modules/programs/ydotool.nix b/nixos/modules/programs/ydotool.nix index 3377ae4262610a..61322cf3fce515 100644 --- a/nixos/modules/programs/ydotool.nix +++ b/nixos/modules/programs/ydotool.nix @@ -26,66 +26,68 @@ in }; }; - config = let - runtimeDirectory = "ydotoold"; - in lib.mkIf cfg.enable { - users.groups."${config.programs.ydotool.group}" = { }; + config = + let + runtimeDirectory = "ydotoold"; + in + lib.mkIf cfg.enable { + users.groups."${config.programs.ydotool.group}" = { }; - systemd.services.ydotoold = { - description = "ydotoold - backend for ydotool"; - wantedBy = [ "multi-user.target" ]; - partOf = [ "multi-user.target" ]; - serviceConfig = { - Group = config.programs.ydotool.group; - RuntimeDirectory = runtimeDirectory; - RuntimeDirectoryMode = "0750"; - ExecStart = "${lib.getExe' pkgs.ydotool "ydotoold"} --socket-path=${config.environment.variables.YDOTOOL_SOCKET} --socket-perm=0660"; + systemd.services.ydotoold = { + description = "ydotoold - backend for ydotool"; + wantedBy = [ "multi-user.target" ]; + partOf = [ "multi-user.target" ]; + serviceConfig = { + Group = config.programs.ydotool.group; + RuntimeDirectory = runtimeDirectory; + RuntimeDirectoryMode = "0750"; + ExecStart = "${lib.getExe' pkgs.ydotool "ydotoold"} --socket-path=${config.environment.variables.YDOTOOL_SOCKET} --socket-perm=0660"; - # hardening + # hardening - ## allow access to uinput - DeviceAllow = [ "/dev/uinput" ]; - DevicePolicy = "closed"; + ## allow access to uinput + DeviceAllow = [ "/dev/uinput" ]; + DevicePolicy = "closed"; - ## allow creation of unix sockets - RestrictAddressFamilies = [ "AF_UNIX" ]; + ## allow creation of unix sockets + RestrictAddressFamilies = [ "AF_UNIX" ]; - CapabilityBoundingSet = ""; - IPAddressDeny = "any"; - LockPersonality = true; - MemoryDenyWriteExecute = true; - NoNewPrivileges = true; - PrivateNetwork = true; - PrivateTmp = true; - PrivateUsers = true; - ProcSubset = "pid"; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - ProtectSystem = "strict"; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ - "@system-service" - "~@privileged" - "~@resources" - ]; - UMask = "0077"; + CapabilityBoundingSet = ""; + IPAddressDeny = "any"; + LockPersonality = true; + MemoryDenyWriteExecute = true; + NoNewPrivileges = true; + PrivateNetwork = true; + PrivateTmp = true; + PrivateUsers = true; + ProcSubset = "pid"; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + ProtectSystem = "strict"; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "~@resources" + ]; + UMask = "0077"; - # -> systemd-analyze security score 0.7 SAFE 😀 + # -> systemd-analyze security score 0.7 SAFE 😀 + }; }; - }; - environment.variables = { - YDOTOOL_SOCKET = "/run/${runtimeDirectory}/socket"; + environment.variables = { + YDOTOOL_SOCKET = "/run/${runtimeDirectory}/socket"; + }; + environment.systemPackages = with pkgs; [ ydotool ]; }; - environment.systemPackages = with pkgs; [ ydotool ]; - }; } diff --git a/nixos/modules/programs/zmap.nix b/nixos/modules/programs/zmap.nix index 4f31d42c4add7f..a1ce43fe62359d 100644 --- a/nixos/modules/programs/zmap.nix +++ b/nixos/modules/programs/zmap.nix @@ -1,8 +1,14 @@ -{ pkgs, config, lib, ... }: +{ + pkgs, + config, + lib, + ... +}: let cfg = config.programs.zmap; -in { +in +{ options.programs.zmap = { enable = lib.mkEnableOption "ZMap, a network scanner designed for Internet-wide network surveys"; }; diff --git a/nixos/modules/programs/zsh/oh-my-zsh.nix b/nixos/modules/programs/zsh/oh-my-zsh.nix index f1ed26ddb569f4..a0351d688911b5 100644 --- a/nixos/modules/programs/zsh/oh-my-zsh.nix +++ b/nixos/modules/programs/zsh/oh-my-zsh.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.zsh.ohMyZsh; - mkLinkFarmEntry = name: dir: + mkLinkFarmEntry = + name: dir: let env = pkgs.buildEnv { name = "zsh-${name}-env"; @@ -12,135 +18,149 @@ let pathsToLink = "/share/zsh/${dir}"; }; in - { inherit name; path = "${env}/share/zsh/${dir}"; }; + { + inherit name; + path = "${env}/share/zsh/${dir}"; + }; mkLinkFarmEntry' = name: mkLinkFarmEntry name name; custom = - if cfg.custom != null then cfg.custom - else if builtins.length cfg.customPkgs == 0 then null - else pkgs.linkFarm "oh-my-zsh-custom" [ - (mkLinkFarmEntry' "themes") - (mkLinkFarmEntry "completions" "site-functions") - (mkLinkFarmEntry' "plugins") - ]; + if cfg.custom != null then + cfg.custom + else if builtins.length cfg.customPkgs == 0 then + null + else + pkgs.linkFarm "oh-my-zsh-custom" [ + (mkLinkFarmEntry' "themes") + (mkLinkFarmEntry "completions" "site-functions") + (mkLinkFarmEntry' "plugins") + ]; in - { - imports = [ - (lib.mkRenamedOptionModule [ "programs" "zsh" "oh-my-zsh" "enable" ] [ "programs" "zsh" "ohMyZsh" "enable" ]) - (lib.mkRenamedOptionModule [ "programs" "zsh" "oh-my-zsh" "theme" ] [ "programs" "zsh" "ohMyZsh" "theme" ]) - (lib.mkRenamedOptionModule [ "programs" "zsh" "oh-my-zsh" "custom" ] [ "programs" "zsh" "ohMyZsh" "custom" ]) - (lib.mkRenamedOptionModule [ "programs" "zsh" "oh-my-zsh" "plugins" ] [ "programs" "zsh" "ohMyZsh" "plugins" ]) - ]; +{ + imports = [ + (lib.mkRenamedOptionModule + [ "programs" "zsh" "oh-my-zsh" "enable" ] + [ "programs" "zsh" "ohMyZsh" "enable" ] + ) + (lib.mkRenamedOptionModule + [ "programs" "zsh" "oh-my-zsh" "theme" ] + [ "programs" "zsh" "ohMyZsh" "theme" ] + ) + (lib.mkRenamedOptionModule + [ "programs" "zsh" "oh-my-zsh" "custom" ] + [ "programs" "zsh" "ohMyZsh" "custom" ] + ) + (lib.mkRenamedOptionModule + [ "programs" "zsh" "oh-my-zsh" "plugins" ] + [ "programs" "zsh" "ohMyZsh" "plugins" ] + ) + ]; + + options = { + programs.zsh.ohMyZsh = { + enable = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Enable oh-my-zsh. + ''; + }; + + package = lib.mkPackageOption pkgs "oh-my-zsh" { }; + + plugins = lib.mkOption { + default = [ ]; + type = lib.types.listOf (lib.types.str); + description = '' + List of oh-my-zsh plugins + ''; + }; + + custom = lib.mkOption { + default = null; + type = with lib.types; nullOr str; + description = '' + Path to a custom oh-my-zsh package to override config of oh-my-zsh. + (Can't be used along with `customPkgs`). + ''; + }; - options = { - programs.zsh.ohMyZsh = { - enable = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Enable oh-my-zsh. - ''; - }; - - package = lib.mkPackageOption pkgs "oh-my-zsh" { }; - - plugins = lib.mkOption { - default = []; - type = lib.types.listOf(lib.types.str); - description = '' - List of oh-my-zsh plugins - ''; - }; - - custom = lib.mkOption { - default = null; - type = with lib.types; nullOr str; - description = '' - Path to a custom oh-my-zsh package to override config of oh-my-zsh. - (Can't be used along with `customPkgs`). - ''; - }; - - customPkgs = lib.mkOption { - default = []; - type = lib.types.listOf lib.types.package; - description = '' - List of custom packages that should be loaded into `oh-my-zsh`. - ''; - }; - - theme = lib.mkOption { - default = ""; - type = lib.types.str; - description = '' - Name of the theme to be used by oh-my-zsh. - ''; - }; - - cacheDir = lib.mkOption { - default = "$HOME/.cache/oh-my-zsh"; - type = lib.types.str; - description = '' - Cache directory to be used by `oh-my-zsh`. - Without this option it would default to the read-only nix store. - ''; - }; - - preLoaded = lib.mkOption { - type = lib.types.lines; - default = ""; - description = '' - Shell commands executed before the `oh-my-zsh` is loaded. - For example, to disable async git prompt write `zstyle ':omz:alpha:lib:git' async-prompt no` (more information https://github.com/ohmyzsh/ohmyzsh?tab=readme-ov-file#async-git-prompt) - ''; - }; + customPkgs = lib.mkOption { + default = [ ]; + type = lib.types.listOf lib.types.package; + description = '' + List of custom packages that should be loaded into `oh-my-zsh`. + ''; + }; + + theme = lib.mkOption { + default = ""; + type = lib.types.str; + description = '' + Name of the theme to be used by oh-my-zsh. + ''; + }; + + cacheDir = lib.mkOption { + default = "$HOME/.cache/oh-my-zsh"; + type = lib.types.str; + description = '' + Cache directory to be used by `oh-my-zsh`. + Without this option it would default to the read-only nix store. + ''; + }; + + preLoaded = lib.mkOption { + type = lib.types.lines; + default = ""; + description = '' + Shell commands executed before the `oh-my-zsh` is loaded. + For example, to disable async git prompt write `zstyle ':omz:alpha:lib:git' async-prompt no` (more information https://github.com/ohmyzsh/ohmyzsh?tab=readme-ov-file#async-git-prompt) + ''; }; }; + }; - config = lib.mkIf cfg.enable { + config = lib.mkIf cfg.enable { - # Prevent zsh from overwriting oh-my-zsh's prompt - programs.zsh.promptInit = lib.mkDefault ""; + # Prevent zsh from overwriting oh-my-zsh's prompt + programs.zsh.promptInit = lib.mkDefault ""; - environment.systemPackages = [ cfg.package ]; + environment.systemPackages = [ cfg.package ]; - programs.zsh.interactiveShellInit = '' - # oh-my-zsh configuration generated by NixOS - export ZSH=${cfg.package}/share/oh-my-zsh + programs.zsh.interactiveShellInit = '' + # oh-my-zsh configuration generated by NixOS + export ZSH=${cfg.package}/share/oh-my-zsh - ${lib.optionalString (builtins.length(cfg.plugins) > 0) - "plugins=(${builtins.concatStringsSep " " cfg.plugins})" - } + ${lib.optionalString ( + builtins.length (cfg.plugins) > 0 + ) "plugins=(${builtins.concatStringsSep " " cfg.plugins})"} - ${lib.optionalString (custom != null) - "ZSH_CUSTOM=\"${custom}\"" - } + ${lib.optionalString (custom != null) "ZSH_CUSTOM=\"${custom}\""} - ${lib.optionalString (builtins.stringLength(cfg.theme) > 0) - "ZSH_THEME=\"${cfg.theme}\"" - } + ${lib.optionalString (builtins.stringLength (cfg.theme) > 0) "ZSH_THEME=\"${cfg.theme}\""} - ${lib.optionalString (cfg.cacheDir != null) '' - if [[ ! -d "${cfg.cacheDir}" ]]; then - mkdir -p "${cfg.cacheDir}" - fi - ZSH_CACHE_DIR=${cfg.cacheDir} - ''} + ${lib.optionalString (cfg.cacheDir != null) '' + if [[ ! -d "${cfg.cacheDir}" ]]; then + mkdir -p "${cfg.cacheDir}" + fi + ZSH_CACHE_DIR=${cfg.cacheDir} + ''} - ${cfg.preLoaded} - source $ZSH/oh-my-zsh.sh - ''; + ${cfg.preLoaded} + source $ZSH/oh-my-zsh.sh + ''; - assertions = [ - { - assertion = cfg.custom != null -> cfg.customPkgs == []; - message = "If `cfg.custom` is set for `ZSH_CUSTOM`, `customPkgs` can't be used!"; - } - ]; + assertions = [ + { + assertion = cfg.custom != null -> cfg.customPkgs == [ ]; + message = "If `cfg.custom` is set for `ZSH_CUSTOM`, `customPkgs` can't be used!"; + } + ]; - }; + }; - meta.doc = ./oh-my-zsh.md; - } + meta.doc = ./oh-my-zsh.md; +} diff --git a/nixos/modules/programs/zsh/zsh-autoenv.nix b/nixos/modules/programs/zsh/zsh-autoenv.nix index 8e0c19f1afea04..7a5d20b92212bf 100644 --- a/nixos/modules/programs/zsh/zsh-autoenv.nix +++ b/nixos/modules/programs/zsh/zsh-autoenv.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.zsh.zsh-autoenv; -in { +in +{ options = { programs.zsh.zsh-autoenv = { enable = lib.mkEnableOption "zsh-autoenv"; diff --git a/nixos/modules/programs/zsh/zsh-autosuggestions.nix b/nixos/modules/programs/zsh/zsh-autosuggestions.nix index e046c21025002c..531a9bfadc902c 100644 --- a/nixos/modules/programs/zsh/zsh-autosuggestions.nix +++ b/nixos/modules/programs/zsh/zsh-autosuggestions.nix @@ -1,11 +1,19 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.zsh.autosuggestions; in { imports = [ - (lib.mkRenamedOptionModule [ "programs" "zsh" "enableAutosuggestions" ] [ "programs" "zsh" "autosuggestions" "enable" ]) + (lib.mkRenamedOptionModule + [ "programs" "zsh" "enableAutosuggestions" ] + [ "programs" "zsh" "autosuggestions" "enable" ] + ) ]; options.programs.zsh.autosuggestions = { @@ -20,7 +28,13 @@ in }; strategy = lib.mkOption { - type = lib.types.listOf (lib.types.enum [ "history" "completion" "match_prev_cmd" ]); + type = lib.types.listOf ( + lib.types.enum [ + "history" + "completion" + "match_prev_cmd" + ] + ); default = [ "history" ]; description = '' `ZSH_AUTOSUGGEST_STRATEGY` is an array that specifies how suggestions should be generated. @@ -44,7 +58,7 @@ in extraConfig = lib.mkOption { type = lib.types.attrsOf lib.types.str; - default = {}; + default = { }; description = "Attribute set with additional configuration values"; example = lib.literalExpression '' { @@ -64,7 +78,9 @@ in export ZSH_AUTOSUGGEST_STRATEGY=(${builtins.concatStringsSep " " cfg.strategy}) ${lib.optionalString (!cfg.async) "unset ZSH_AUTOSUGGEST_USE_ASYNC"} - ${builtins.concatStringsSep "\n" (lib.mapAttrsToList (key: value: ''export ${key}="${value}"'') cfg.extraConfig)} + ${builtins.concatStringsSep "\n" ( + lib.mapAttrsToList (key: value: ''export ${key}="${value}"'') cfg.extraConfig + )} ''; }; diff --git a/nixos/modules/programs/zsh/zsh-syntax-highlighting.nix b/nixos/modules/programs/zsh/zsh-syntax-highlighting.nix index 3f70c14048c756..07b4633bccd243 100644 --- a/nixos/modules/programs/zsh/zsh-syntax-highlighting.nix +++ b/nixos/modules/programs/zsh/zsh-syntax-highlighting.nix @@ -1,14 +1,31 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.programs.zsh.syntaxHighlighting; in { imports = [ - (lib.mkRenamedOptionModule [ "programs" "zsh" "enableSyntaxHighlighting" ] [ "programs" "zsh" "syntaxHighlighting" "enable" ]) - (lib.mkRenamedOptionModule [ "programs" "zsh" "syntax-highlighting" "enable" ] [ "programs" "zsh" "syntaxHighlighting" "enable" ]) - (lib.mkRenamedOptionModule [ "programs" "zsh" "syntax-highlighting" "highlighters" ] [ "programs" "zsh" "syntaxHighlighting" "highlighters" ]) - (lib.mkRenamedOptionModule [ "programs" "zsh" "syntax-highlighting" "patterns" ] [ "programs" "zsh" "syntaxHighlighting" "patterns" ]) + (lib.mkRenamedOptionModule + [ "programs" "zsh" "enableSyntaxHighlighting" ] + [ "programs" "zsh" "syntaxHighlighting" "enable" ] + ) + (lib.mkRenamedOptionModule + [ "programs" "zsh" "syntax-highlighting" "enable" ] + [ "programs" "zsh" "syntaxHighlighting" "enable" ] + ) + (lib.mkRenamedOptionModule + [ "programs" "zsh" "syntax-highlighting" "highlighters" ] + [ "programs" "zsh" "syntaxHighlighting" "highlighters" ] + ) + (lib.mkRenamedOptionModule + [ "programs" "zsh" "syntax-highlighting" "patterns" ] + [ "programs" "zsh" "syntaxHighlighting" "patterns" ] + ) ]; options = { @@ -19,15 +36,17 @@ in default = [ "main" ]; # https://github.com/zsh-users/zsh-syntax-highlighting/blob/master/docs/highlighters.md - type = lib.types.listOf(lib.types.enum([ - "main" - "brackets" - "pattern" - "cursor" - "regexp" - "root" - "line" - ])); + type = lib.types.listOf ( + lib.types.enum ([ + "main" + "brackets" + "pattern" + "cursor" + "regexp" + "root" + "line" + ]) + ); description = '' Specifies the highlighters to be used by zsh-syntax-highlighting. @@ -38,7 +57,7 @@ in }; patterns = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.str; example = lib.literalExpression '' @@ -55,7 +74,7 @@ in ''; }; styles = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.str; example = lib.literalExpression '' @@ -79,28 +98,31 @@ in assertions = [ { - assertion = builtins.length(builtins.attrNames cfg.patterns) > 0 -> builtins.elem "pattern" cfg.highlighters; + assertion = + builtins.length (builtins.attrNames cfg.patterns) > 0 -> builtins.elem "pattern" cfg.highlighters; message = '' When highlighting patterns, "pattern" needs to be included in the list of highlighters. ''; } ]; - programs.zsh.interactiveShellInit = - lib.mkAfter (lib.concatStringsSep "\n" ([ - "source ${pkgs.zsh-syntax-highlighting}/share/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh" - ] ++ lib.optional (builtins.length(cfg.highlighters) > 0) - "ZSH_HIGHLIGHT_HIGHLIGHTERS=(${builtins.concatStringsSep " " cfg.highlighters})" - ++ lib.optionals (builtins.length(builtins.attrNames cfg.patterns) > 0) - (lib.mapAttrsToList ( - pattern: design: - "ZSH_HIGHLIGHT_PATTERNS+=('${pattern}' '${design}')" - ) cfg.patterns) - ++ lib.optionals (builtins.length(builtins.attrNames cfg.styles) > 0) - (lib.mapAttrsToList ( - styles: design: - "ZSH_HIGHLIGHT_STYLES[${styles}]='${design}'" - ) cfg.styles) - )); + programs.zsh.interactiveShellInit = lib.mkAfter ( + lib.concatStringsSep "\n" ( + [ + "source ${pkgs.zsh-syntax-highlighting}/share/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh" + ] + ++ lib.optional ( + builtins.length (cfg.highlighters) > 0 + ) "ZSH_HIGHLIGHT_HIGHLIGHTERS=(${builtins.concatStringsSep " " cfg.highlighters})" + ++ lib.optionals (builtins.length (builtins.attrNames cfg.patterns) > 0) ( + lib.mapAttrsToList ( + pattern: design: "ZSH_HIGHLIGHT_PATTERNS+=('${pattern}' '${design}')" + ) cfg.patterns + ) + ++ lib.optionals (builtins.length (builtins.attrNames cfg.styles) > 0) ( + lib.mapAttrsToList (styles: design: "ZSH_HIGHLIGHT_STYLES[${styles}]='${design}'") cfg.styles + ) + ) + ); }; } diff --git a/nixos/modules/rename.nix b/nixos/modules/rename.nix index e932353f89718e..ec22be89f19215 100644 --- a/nixos/modules/rename.nix +++ b/nixos/modules/rename.nix @@ -3,16 +3,17 @@ let inherit (lib) mkAliasOptionModuleMD - mkRemovedOptionModule; + mkRemovedOptionModule + ; in { imports = [ /* - This file defines some renaming/removing options for backwards compatibility + This file defines some renaming/removing options for backwards compatibility - It should ONLY be used when the relevant module can't define these imports - itself, such as when the module was removed completely. - See https://github.com/NixOS/nixpkgs/pull/61570 for explanation + It should ONLY be used when the relevant module can't define these imports + itself, such as when the module was removed completely. + See https://github.com/NixOS/nixpkgs/pull/61570 for explanation */ # This alias module can't be where _module.check is defined because it would @@ -20,13 +21,19 @@ in (mkAliasOptionModuleMD [ "environment" "checkConfigurationOptions" ] [ "_module" "check" ]) # Completely removed modules - (mkRemovedOptionModule [ "boot" "loader" "raspberryPi" ] "The raspberryPi boot loader has been removed. See https://github.com/NixOS/nixpkgs/pull/241534 for what to use instead.") + (mkRemovedOptionModule [ "boot" "loader" "raspberryPi" ] + "The raspberryPi boot loader has been removed. See https://github.com/NixOS/nixpkgs/pull/241534 for what to use instead." + ) (mkRemovedOptionModule [ "environment" "blcr" "enable" ] "The BLCR module has been removed") (mkRemovedOptionModule [ "environment" "noXlibs" ] '' The environment.noXlibs option was removed, as it often caused surprising breakages for new users. If you need its functionality, you can apply similar overlays in your own config. '') - (mkRemovedOptionModule [ "fonts" "fontconfig" "penultimate" ] "The corresponding package has removed from nixpkgs.") + (mkRemovedOptionModule [ + "fonts" + "fontconfig" + "penultimate" + ] "The corresponding package has removed from nixpkgs.") (mkRemovedOptionModule [ "hardware" "brightnessctl" ] '' The brightnessctl module was removed because newer versions of brightnessctl don't require the udev rules anymore (they can use the @@ -47,30 +54,64 @@ in the project and users are urged to switch to xone. '') (mkRemovedOptionModule [ "networking" "vpnc" ] "Use environment.etc.\"vpnc/service.conf\" instead.") - (mkRemovedOptionModule [ "networking" "wicd" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "programs" "gnome-documents" ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "networking" + "wicd" + ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "programs" + "gnome-documents" + ] "The corresponding package was removed from nixpkgs.") (mkRemovedOptionModule [ "programs" "pantheon-tweaks" ] '' pantheon-tweaks is no longer a switchboard plugin but an independent app, adding the package to environment.systemPackages is sufficient. '') (mkRemovedOptionModule [ "programs" "tilp2" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "programs" "way-cooler" ] ("way-cooler is abandoned by its author: " + - "https://way-cooler.org/blog/2020/01/09/way-cooler-post-mortem.html")) + (mkRemovedOptionModule [ "programs" "way-cooler" ] ( + "way-cooler is abandoned by its author: " + + "https://way-cooler.org/blog/2020/01/09/way-cooler-post-mortem.html" + )) (mkRemovedOptionModule [ "security" "hideProcessInformation" ] '' The hidepid module was removed, since the underlying machinery is broken when using cgroups-v2. '') - (mkRemovedOptionModule [ "services" "antennas" ] "The antennas package and the corresponding module have been removed as they only work with tvheadend, which nobody was willing to maintain and was stuck on an unmaintained version that required FFmpeg 4; please see https://github.com/NixOS/nixpkgs/pull/332259 if you are interested in maintaining a newer version.") - (mkRemovedOptionModule [ "services" "ankisyncd" ] "`services.ankisyncd` has been replaced by `services.anki-sync-server`.") - (mkRemovedOptionModule [ "services" "baget" "enable" ] "The baget module was removed due to the upstream package being unmaintained.") + (mkRemovedOptionModule [ "services" "antennas" ] + "The antennas package and the corresponding module have been removed as they only work with tvheadend, which nobody was willing to maintain and was stuck on an unmaintained version that required FFmpeg 4; please see https://github.com/NixOS/nixpkgs/pull/332259 if you are interested in maintaining a newer version." + ) + (mkRemovedOptionModule [ + "services" + "ankisyncd" + ] "`services.ankisyncd` has been replaced by `services.anki-sync-server`.") + (mkRemovedOptionModule [ + "services" + "baget" + "enable" + ] "The baget module was removed due to the upstream package being unmaintained.") (mkRemovedOptionModule [ "services" "beegfs" ] "The BeeGFS module has been removed") (mkRemovedOptionModule [ "services" "beegfsEnable" ] "The BeeGFS module has been removed") - (mkRemovedOptionModule [ "services" "cgmanager" "enable"] "cgmanager was deprecated by lxc and therefore removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "chronos" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "confluence" ] "Atlassian software has been removed, as support for the Atlassian Server products ended in February 2024 and there was insufficient interest in maintaining the Atlassian Data Center replacements") - (mkRemovedOptionModule [ "services" "couchpotato" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "crowd" ] "Atlassian software has been removed, as support for the Atlassian Server products ended in February 2024 and there was insufficient interest in maintaining the Atlassian Data Center replacements") - (mkRemovedOptionModule [ "services" "dd-agent" ] "dd-agent was removed from nixpkgs in favor of the newer datadog-agent.") + (mkRemovedOptionModule [ + "services" + "cgmanager" + "enable" + ] "cgmanager was deprecated by lxc and therefore removed from nixpkgs.") + (mkRemovedOptionModule [ + "services" + "chronos" + ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ "services" "confluence" ] + "Atlassian software has been removed, as support for the Atlassian Server products ended in February 2024 and there was insufficient interest in maintaining the Atlassian Data Center replacements" + ) + (mkRemovedOptionModule [ + "services" + "couchpotato" + ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ "services" "crowd" ] + "Atlassian software has been removed, as support for the Atlassian Server products ended in February 2024 and there was insufficient interest in maintaining the Atlassian Data Center replacements" + ) + (mkRemovedOptionModule [ + "services" + "dd-agent" + ] "dd-agent was removed from nixpkgs in favor of the newer datadog-agent.") (mkRemovedOptionModule [ "services" "dnscrypt-proxy" ] "Use services.dnscrypt-proxy2 instead") (mkRemovedOptionModule [ "services" "dnscrypt-wrapper" ] '' The dnscrypt-wrapper module was removed since the project has been effectively unmaintained since 2018; @@ -78,27 +119,65 @@ in To wrap a resolver with DNSCrypt you can instead use dnsdist. See options `services.dnsdist.dnscrypt.*` '') - (mkRemovedOptionModule [ "services" "exhibitor" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "firefox" "syncserver" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "flashpolicyd" ] "The flashpolicyd module has been removed. Adobe Flash Player is deprecated.") + (mkRemovedOptionModule [ + "services" + "exhibitor" + ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "services" + "firefox" + "syncserver" + ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "services" + "flashpolicyd" + ] "The flashpolicyd module has been removed. Adobe Flash Player is deprecated.") (mkRemovedOptionModule [ "services" "fourStore" ] "The fourStore module has been removed") - (mkRemovedOptionModule [ "services" "fourStoreEndpoint" ] "The fourStoreEndpoint module has been removed") + (mkRemovedOptionModule [ + "services" + "fourStoreEndpoint" + ] "The fourStoreEndpoint module has been removed") (mkRemovedOptionModule [ "services" "fprot" ] "The corresponding package was removed from nixpkgs.") (mkRemovedOptionModule [ "services" "frab" ] "The frab module has been removed") - (mkRemovedOptionModule [ "services" "homeassistant-satellite"] "The `services.homeassistant-satellite` module has been replaced by `services.wyoming-satellite`.") - (mkRemovedOptionModule [ "services" "hydron" ] "The `services.hydron` module has been removed as the project has been archived upstream since 2022 and is affected by a severe remote code execution vulnerability.") - (mkRemovedOptionModule [ "services" "ihatemoney" ] "The ihatemoney module has been removed for lack of downstream maintainer") - (mkRemovedOptionModule [ "services" "jira" ] "Atlassian software has been removed, as support for the Atlassian Server products ended in February 2024 and there was insufficient interest in maintaining the Atlassian Data Center replacements") + (mkRemovedOptionModule [ "services" "homeassistant-satellite" ] + "The `services.homeassistant-satellite` module has been replaced by `services.wyoming-satellite`." + ) + (mkRemovedOptionModule [ "services" "hydron" ] + "The `services.hydron` module has been removed as the project has been archived upstream since 2022 and is affected by a severe remote code execution vulnerability." + ) + (mkRemovedOptionModule [ + "services" + "ihatemoney" + ] "The ihatemoney module has been removed for lack of downstream maintainer") + (mkRemovedOptionModule [ "services" "jira" ] + "Atlassian software has been removed, as support for the Atlassian Server products ended in February 2024 and there was insufficient interest in maintaining the Atlassian Data Center replacements" + ) (mkRemovedOptionModule [ "services" "kippo" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "lshd" ] "The corresponding package was removed from nixpkgs as it had no maintainer in Nixpkgs and hasn't seen an upstream release in over a decades.") - (mkRemovedOptionModule [ "services" "mailpile" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "marathon" ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ "services" "lshd" ] + "The corresponding package was removed from nixpkgs as it had no maintainer in Nixpkgs and hasn't seen an upstream release in over a decades." + ) + (mkRemovedOptionModule [ + "services" + "mailpile" + ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "services" + "marathon" + ] "The corresponding package was removed from nixpkgs.") (mkRemovedOptionModule [ "services" "mathics" ] "The Mathics module has been removed") - (mkRemovedOptionModule [ "services" "matrix-sliding-sync" ] "The matrix-sliding-sync package has been removed, since matrix-synapse incorporated its functionality. Remove `services.sliding-sync` from your NixOS Configuration, and the `.well-known` record for `org.matrix.msc3575.proxy` from your webserver") + (mkRemovedOptionModule [ "services" "matrix-sliding-sync" ] + "The matrix-sliding-sync package has been removed, since matrix-synapse incorporated its functionality. Remove `services.sliding-sync` from your NixOS Configuration, and the `.well-known` record for `org.matrix.msc3575.proxy` from your webserver" + ) (mkRemovedOptionModule [ "services" "meguca" ] "Use meguca has been removed from nixpkgs") (mkRemovedOptionModule [ "services" "mesos" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "mxisd" ] "The mxisd module has been removed as both mxisd and ma1sd got removed.") - (mkRemovedOptionModule [ "services" "moinmoin" ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "services" + "mxisd" + ] "The mxisd module has been removed as both mxisd and ma1sd got removed.") + (mkRemovedOptionModule [ + "services" + "moinmoin" + ] "The corresponding package was removed from nixpkgs.") (mkRemovedOptionModule [ "services" "mwlib" ] "The corresponding package was removed from nixpkgs.") (mkRemovedOptionModule [ "services" "pantheon" "files" ] '' This module was removed, please add pkgs.pantheon.elementary-files to environment.systemPackages directly. @@ -106,21 +185,42 @@ in (mkRemovedOptionModule [ "services" "prey" ] '' prey-bash-client is deprecated upstream '') - (mkRemovedOptionModule [ "services" "quagga" ] "the corresponding package has been removed from nixpkgs") - (mkRemovedOptionModule [ "services" "railcar" ] "the corresponding package has been removed from nixpkgs") - (mkRemovedOptionModule [ "services" "replay-sorcery" ] "the corresponding package has been removed from nixpkgs as it is unmaintained upstream. Consider using `gpu-screen-recorder` or `obs-studio` instead.") + (mkRemovedOptionModule [ + "services" + "quagga" + ] "the corresponding package has been removed from nixpkgs") + (mkRemovedOptionModule [ + "services" + "railcar" + ] "the corresponding package has been removed from nixpkgs") + (mkRemovedOptionModule [ "services" "replay-sorcery" ] + "the corresponding package has been removed from nixpkgs as it is unmaintained upstream. Consider using `gpu-screen-recorder` or `obs-studio` instead." + ) (mkRemovedOptionModule [ "services" "seeks" ] "") - (mkRemovedOptionModule [ "services" "shout" ] "shout was removed because it was deprecated upstream in favor of thelounge.") + (mkRemovedOptionModule [ + "services" + "shout" + ] "shout was removed because it was deprecated upstream in favor of thelounge.") (mkRemovedOptionModule [ "services" "ssmtp" ] '' The ssmtp package and the corresponding module have been removed due to the program being unmaintained. The options `programs.msmtp.*` can be used instead. '') - (mkRemovedOptionModule [ "services" "tvheadend" ] "The tvheadend package and the corresponding module have been removed as nobody was willing to maintain them and they were stuck on an unmaintained version that required FFmpeg 4; please see https://github.com/NixOS/nixpkgs/pull/332259 if you are interested in maintaining a newer version.") - (mkRemovedOptionModule [ "services" "unifi-video" ] "The unifi-video package and the corresponding module have been removed as the software has been unsupported since 2021 and requires a MongoDB version that has reached end of life.") + (mkRemovedOptionModule [ "services" "tvheadend" ] + "The tvheadend package and the corresponding module have been removed as nobody was willing to maintain them and they were stuck on an unmaintained version that required FFmpeg 4; please see https://github.com/NixOS/nixpkgs/pull/332259 if you are interested in maintaining a newer version." + ) + (mkRemovedOptionModule [ "services" "unifi-video" ] + "The unifi-video package and the corresponding module have been removed as the software has been unsupported since 2021 and requires a MongoDB version that has reached end of life." + ) (mkRemovedOptionModule [ "services" "venus" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "wakeonlan"] "This module was removed in favor of enabling it with networking.interfaces..wakeOnLan") - (mkRemovedOptionModule [ "services" "winstone" ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "services" + "wakeonlan" + ] "This module was removed in favor of enabling it with networking.interfaces..wakeOnLan") + (mkRemovedOptionModule [ + "services" + "winstone" + ] "The corresponding package was removed from nixpkgs.") (mkRemovedOptionModule [ "services" "xserver" "displayManager" "auto" ] '' The services.xserver.displayManager.auto module has been removed because it was only intended for use in internal NixOS tests, and gave the @@ -133,21 +233,51 @@ in as the underlying package isn't being maintained. Working alternatives are libinput and synaptics. '') - (mkRemovedOptionModule [ "services" "xmr-stak" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "virtualisation" "rkt" ] "The rkt module has been removed, it was archived by upstream") + (mkRemovedOptionModule [ + "services" + "xmr-stak" + ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "virtualisation" + "rkt" + ] "The rkt module has been removed, it was archived by upstream") (mkRemovedOptionModule [ "services" "racoon" ] '' The racoon module has been removed, because the software project was abandoned upstream. '') - (mkRemovedOptionModule [ "services" "shellinabox" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "gogoclient" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "virtuoso" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "openfire" ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "services" + "shellinabox" + ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "services" + "gogoclient" + ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "services" + "virtuoso" + ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "services" + "openfire" + ] "The corresponding package was removed from nixpkgs.") (mkRemovedOptionModule [ "services" "riak" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "rtsp-simple-server" ] "Package has been completely rebranded by upstream as mediamtx, and thus the service and the package were renamed in NixOS as well.") - (mkRemovedOptionModule [ "services" "prayer" ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "services" "restya-board" ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ "services" "rtsp-simple-server" ] + "Package has been completely rebranded by upstream as mediamtx, and thus the service and the package were renamed in NixOS as well." + ) + (mkRemovedOptionModule [ + "services" + "prayer" + ] "The corresponding package was removed from nixpkgs.") + (mkRemovedOptionModule [ + "services" + "restya-board" + ] "The corresponding package was removed from nixpkgs.") - (mkRemovedOptionModule [ "i18n" "inputMethod" "fcitx" ] "The fcitx module has been removed. Please use fcitx5 instead") + (mkRemovedOptionModule [ + "i18n" + "inputMethod" + "fcitx" + ] "The fcitx module has been removed. Please use fcitx5 instead") (mkRemovedOptionModule [ "services" "dhcpd4" ] '' The dhcpd4 module has been removed because ISC DHCP reached its end of life. See https://www.isc.org/blogs/isc-dhcp-eol/ for details. diff --git a/nixos/modules/security/apparmor/includes.nix b/nixos/modules/security/apparmor/includes.nix index 88051de484c500..ddf6f3a1a77826 100644 --- a/nixos/modules/security/apparmor/includes.nix +++ b/nixos/modules/security/apparmor/includes.nix @@ -1,322 +1,556 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (builtins) attrNames hasAttr isAttrs; inherit (lib) getLib; inherit (config.environment) etc; # Utility to generate an AppArmor rule # only when the given path exists in config.environment.etc - etcRule = arg: - let go = { path ? null, mode ? "r", trail ? "" }: - lib.optionalString (hasAttr path etc) - "${mode} ${config.environment.etc.${path}.source}${trail},"; - in if isAttrs arg - then go arg - else go { path = arg; }; + etcRule = + arg: + let + go = + { + path ? null, + mode ? "r", + trail ? "", + }: + lib.optionalString (hasAttr path etc) "${mode} ${config.environment.etc.${path}.source}${trail},"; + in + if isAttrs arg then go arg else go { path = arg; }; in { -# FIXME: most of the etcRule calls below have been -# written systematically by converting from apparmor-profiles's profiles -# without testing nor deep understanding of their uses, -# and thus may need more rules or can have less rules; -# this remains to be determined case by case, -# some may even be completely useless. -config.security.apparmor.includes = { - # This one is included by - # which is usually included before any profile. - "abstractions/tunables/alias" = '' - alias /bin -> /run/current-system/sw/bin, - alias /lib/modules -> /run/current-system/kernel/lib/modules, - alias /sbin -> /run/current-system/sw/sbin, - alias /usr -> /run/current-system/sw, - ''; - "abstractions/audio" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/audio" - '' + lib.concatMapStringsSep "\n" etcRule [ - "asound.conf" - "esound/esd.conf" - "libao.conf" - { path = "pulse"; trail = "/"; } - { path = "pulse"; trail = "/**"; } - { path = "sound"; trail = "/"; } - { path = "sound"; trail = "/**"; } - { path = "alsa/conf.d"; trail = "/"; } - { path = "alsa/conf.d"; trail = "/*"; } - "openal/alsoft.conf" - "wildmidi/wildmidi.conf" - ]; - "abstractions/authentication" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/authentication" - # Defined in security.pam - include - '' + lib.concatMapStringsSep "\n" etcRule [ - "nologin" - "securetty" - { path = "security"; trail = "/*"; } - "shadow" - "gshadow" - "pwdb.conf" - "default/passwd" - "login.defs" - ]; - "abstractions/base" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/base" - r ${pkgs.stdenv.cc.libc}/share/locale/**, - r ${pkgs.stdenv.cc.libc}/share/locale.alias, - r ${config.i18n.glibcLocales}/lib/locale/locale-archive, - ${etcRule "localtime"} - r ${pkgs.tzdata}/share/zoneinfo/**, - r ${pkgs.stdenv.cc.libc}/share/i18n/**, - ''; - "abstractions/bash" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/bash" + # FIXME: most of the etcRule calls below have been + # written systematically by converting from apparmor-profiles's profiles + # without testing nor deep understanding of their uses, + # and thus may need more rules or can have less rules; + # this remains to be determined case by case, + # some may even be completely useless. + config.security.apparmor.includes = { + # This one is included by + # which is usually included before any profile. + "abstractions/tunables/alias" = '' + alias /bin -> /run/current-system/sw/bin, + alias /lib/modules -> /run/current-system/kernel/lib/modules, + alias /sbin -> /run/current-system/sw/sbin, + alias /usr -> /run/current-system/sw, + ''; + "abstractions/audio" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/audio" + '' + + lib.concatMapStringsSep "\n" etcRule [ + "asound.conf" + "esound/esd.conf" + "libao.conf" + { + path = "pulse"; + trail = "/"; + } + { + path = "pulse"; + trail = "/**"; + } + { + path = "sound"; + trail = "/"; + } + { + path = "sound"; + trail = "/**"; + } + { + path = "alsa/conf.d"; + trail = "/"; + } + { + path = "alsa/conf.d"; + trail = "/*"; + } + "openal/alsoft.conf" + "wildmidi/wildmidi.conf" + ]; + "abstractions/authentication" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/authentication" + # Defined in security.pam + include + '' + + lib.concatMapStringsSep "\n" etcRule [ + "nologin" + "securetty" + { + path = "security"; + trail = "/*"; + } + "shadow" + "gshadow" + "pwdb.conf" + "default/passwd" + "login.defs" + ]; + "abstractions/base" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/base" + r ${pkgs.stdenv.cc.libc}/share/locale/**, + r ${pkgs.stdenv.cc.libc}/share/locale.alias, + r ${config.i18n.glibcLocales}/lib/locale/locale-archive, + ${etcRule "localtime"} + r ${pkgs.tzdata}/share/zoneinfo/**, + r ${pkgs.stdenv.cc.libc}/share/i18n/**, + ''; + "abstractions/bash" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/bash" - # bash inspects filesystems at startup - # and /etc/mtab is linked to /proc/mounts - r @{PROC}/mounts, + # bash inspects filesystems at startup + # and /etc/mtab is linked to /proc/mounts + r @{PROC}/mounts, - # system-wide bash configuration - '' + lib.concatMapStringsSep "\n" etcRule [ - "profile.dos" - "profile" - "profile.d" - { path = "profile.d"; trail = "/*"; } - "bashrc" - "bash.bashrc" - "bash.bashrc.local" - "bash_completion" - "bash_completion.d" - { path = "bash_completion.d"; trail = "/*"; } - # bash relies on system-wide readline configuration - "inputrc" - # run out of /etc/bash.bashrc - "DIR_COLORS" - ]; - "abstractions/consoles" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/consoles" - ''; - "abstractions/cups-client" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/cups-client" - ${etcRule "cups/cups-client.conf"} - ''; - "abstractions/dbus-session-strict" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/dbus-session-strict" - ${etcRule "machine-id"} - ''; - "abstractions/dconf" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/dconf" - ${etcRule { path = "dconf"; trail = "/**"; }} - ''; - "abstractions/dri-common" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/dri-common" - ${etcRule "drirc"} - ''; - # The config.fonts.fontconfig NixOS module adds many files to /etc/fonts/ - # by symlinking them but without exporting them outside of its NixOS module, - # those are therefore added there to this "abstractions/fonts". - "abstractions/fonts" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/fonts" - ${etcRule { path = "fonts"; trail = "/**"; }} - ''; - "abstractions/gnome" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/gnome" - include - '' + lib.concatMapStringsSep "\n" etcRule [ - { path = "gnome"; trail = "/gtkrc*"; } - { path = "gtk"; trail = "/*"; } - { path = "gtk-2.0"; trail = "/*"; } - { path = "gtk-3.0"; trail = "/*"; } - "orbitrc" - { path = "pango"; trail = "/*"; } - { path = "/etc/gnome-vfs-2.0"; trail = "/modules/"; } - { path = "/etc/gnome-vfs-2.0"; trail = "/modules/*"; } - "papersize" - { path = "cups"; trail = "/lpoptions"; } - { path = "gnome"; trail = "/defaults.list"; } - { path = "xdg"; trail = "/{,*-}mimeapps.list"; } - "xdg/mimeapps.list" - ]; - "abstractions/kde" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/kde" - '' + lib.concatMapStringsSep "\n" etcRule [ - { path = "qt3"; trail = "/kstylerc"; } - { path = "qt3"; trail = "/qt_plugins_3.3rc"; } - { path = "qt3"; trail = "/qtrc"; } - "kderc" - { path = "kde3"; trail = "/*"; } - "kde4rc" - { path = "xdg"; trail = "/kdeglobals"; } - { path = "xdg"; trail = "/Trolltech.conf"; } - ]; - "abstractions/kerberosclient" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/kerberosclient" - '' + lib.concatMapStringsSep "\n" etcRule [ - { path = "krb5.keytab"; mode="rk"; } - "krb5.conf" - "krb5.conf.d" - { path = "krb5.conf.d"; trail = "/*"; } + # system-wide bash configuration + '' + + lib.concatMapStringsSep "\n" etcRule [ + "profile.dos" + "profile" + "profile.d" + { + path = "profile.d"; + trail = "/*"; + } + "bashrc" + "bash.bashrc" + "bash.bashrc.local" + "bash_completion" + "bash_completion.d" + { + path = "bash_completion.d"; + trail = "/*"; + } + # bash relies on system-wide readline configuration + "inputrc" + # run out of /etc/bash.bashrc + "DIR_COLORS" + ]; + "abstractions/consoles" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/consoles" + ''; + "abstractions/cups-client" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/cups-client" + ${etcRule "cups/cups-client.conf"} + ''; + "abstractions/dbus-session-strict" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/dbus-session-strict" + ${etcRule "machine-id"} + ''; + "abstractions/dconf" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/dconf" + ${etcRule { + path = "dconf"; + trail = "/**"; + }} + ''; + "abstractions/dri-common" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/dri-common" + ${etcRule "drirc"} + ''; + # The config.fonts.fontconfig NixOS module adds many files to /etc/fonts/ + # by symlinking them but without exporting them outside of its NixOS module, + # those are therefore added there to this "abstractions/fonts". + "abstractions/fonts" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/fonts" + ${etcRule { + path = "fonts"; + trail = "/**"; + }} + ''; + "abstractions/gnome" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/gnome" + include + '' + + lib.concatMapStringsSep "\n" etcRule [ + { + path = "gnome"; + trail = "/gtkrc*"; + } + { + path = "gtk"; + trail = "/*"; + } + { + path = "gtk-2.0"; + trail = "/*"; + } + { + path = "gtk-3.0"; + trail = "/*"; + } + "orbitrc" + { + path = "pango"; + trail = "/*"; + } + { + path = "/etc/gnome-vfs-2.0"; + trail = "/modules/"; + } + { + path = "/etc/gnome-vfs-2.0"; + trail = "/modules/*"; + } + "papersize" + { + path = "cups"; + trail = "/lpoptions"; + } + { + path = "gnome"; + trail = "/defaults.list"; + } + { + path = "xdg"; + trail = "/{,*-}mimeapps.list"; + } + "xdg/mimeapps.list" + ]; + "abstractions/kde" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/kde" + '' + + lib.concatMapStringsSep "\n" etcRule [ + { + path = "qt3"; + trail = "/kstylerc"; + } + { + path = "qt3"; + trail = "/qt_plugins_3.3rc"; + } + { + path = "qt3"; + trail = "/qtrc"; + } + "kderc" + { + path = "kde3"; + trail = "/*"; + } + "kde4rc" + { + path = "xdg"; + trail = "/kdeglobals"; + } + { + path = "xdg"; + trail = "/Trolltech.conf"; + } + ]; + "abstractions/kerberosclient" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/kerberosclient" + '' + + lib.concatMapStringsSep "\n" etcRule [ + { + path = "krb5.keytab"; + mode = "rk"; + } + "krb5.conf" + "krb5.conf.d" + { + path = "krb5.conf.d"; + trail = "/*"; + } - # config files found via strings on libs - "krb.conf" - "krb.realms" - "srvtab" - ]; - "abstractions/ldapclient" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/ldapclient" - '' + lib.concatMapStringsSep "\n" etcRule [ - "ldap.conf" - "ldap.secret" - { path = "openldap"; trail = "/*"; } - { path = "openldap"; trail = "/cacerts/*"; } - { path = "sasl2"; trail = "/*"; } - ]; - "abstractions/likewise" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/likewise" - ''; - "abstractions/mdns" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/mdns" - ${etcRule "nss_mdns.conf"} - ''; - "abstractions/nameservice" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/nameservice" + # config files found via strings on libs + "krb.conf" + "krb.realms" + "srvtab" + ]; + "abstractions/ldapclient" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/ldapclient" + '' + + lib.concatMapStringsSep "\n" etcRule [ + "ldap.conf" + "ldap.secret" + { + path = "openldap"; + trail = "/*"; + } + { + path = "openldap"; + trail = "/cacerts/*"; + } + { + path = "sasl2"; + trail = "/*"; + } + ]; + "abstractions/likewise" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/likewise" + ''; + "abstractions/mdns" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/mdns" + ${etcRule "nss_mdns.conf"} + ''; + "abstractions/nameservice" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/nameservice" - # Many programs wish to perform nameservice-like operations, such as - # looking up users by name or id, groups by name or id, hosts by name - # or IP, etc. These operations may be performed through files, dns, - # NIS, NIS+, LDAP, hesiod, wins, etc. Allow them all here. - mr ${getLib pkgs.nss}/lib/libnss_*.so*, - mr ${getLib pkgs.nss}/lib64/libnss_*.so*, - '' + lib.concatMapStringsSep "\n" etcRule [ - "group" - "host.conf" - "hosts" - "nsswitch.conf" - "gai.conf" - "passwd" - "protocols" + # Many programs wish to perform nameservice-like operations, such as + # looking up users by name or id, groups by name or id, hosts by name + # or IP, etc. These operations may be performed through files, dns, + # NIS, NIS+, LDAP, hesiod, wins, etc. Allow them all here. + mr ${getLib pkgs.nss}/lib/libnss_*.so*, + mr ${getLib pkgs.nss}/lib64/libnss_*.so*, + '' + + lib.concatMapStringsSep "\n" etcRule [ + "group" + "host.conf" + "hosts" + "nsswitch.conf" + "gai.conf" + "passwd" + "protocols" - # libtirpc (used for NIS/YP login) needs this - "netconfig" + # libtirpc (used for NIS/YP login) needs this + "netconfig" - "resolv.conf" + "resolv.conf" - { path = "samba"; trail = "/lmhosts"; } - "services" + { + path = "samba"; + trail = "/lmhosts"; + } + "services" - "default/nss" + "default/nss" - # libnl-3-200 via libnss-gw-name - { path = "libnl"; trail = "/classid"; } - { path = "libnl-3"; trail = "/classid"; } - ]; - "abstractions/nis" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/nis" - ''; - "abstractions/nss-systemd" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/nss-systemd" - ''; - "abstractions/nvidia" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/nvidia" - ${etcRule "vdpau_wrapper.cfg"} - ''; - "abstractions/opencl-common" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/opencl-common" - ${etcRule { path = "OpenCL"; trail = "/**"; }} - ''; - "abstractions/opencl-mesa" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/opencl-mesa" - ${etcRule "default/drirc"} - ''; - "abstractions/openssl" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/openssl" - ${etcRule { path = "ssl"; trail = "/openssl.cnf"; }} - ''; - "abstractions/p11-kit" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/p11-kit" - '' + lib.concatMapStringsSep "\n" etcRule [ - { path = "pkcs11"; trail = "/"; } - { path = "pkcs11"; trail = "/pkcs11.conf"; } - { path = "pkcs11"; trail = "/modules/"; } - { path = "pkcs11"; trail = "/modules/*"; } - ]; - "abstractions/perl" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/perl" - ${etcRule { path = "perl"; trail = "/**"; }} - ''; - "abstractions/php" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/php" - '' + lib.concatMapStringsSep "\n" etcRule [ - { path = "php"; trail = "/**/"; } - { path = "php5"; trail = "/**/"; } - { path = "php7"; trail = "/**/"; } - { path = "php"; trail = "/**.ini"; } - { path = "php5"; trail = "/**.ini"; } - { path = "php7"; trail = "/**.ini"; } - ]; - "abstractions/postfix-common" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/postfix-common" - '' + lib.concatMapStringsSep "\n" etcRule [ - "mailname" - { path = "postfix"; trail = "/*.cf"; } - "postfix/main.cf" - "postfix/master.cf" - ]; - "abstractions/python" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/python" - ''; - "abstractions/qt5" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/qt5" - '' + lib.concatMapStringsSep "\n" etcRule [ - { path = "xdg"; trail = "/QtProject/qtlogging.ini"; } - { path = "xdg/QtProject"; trail = "/qtlogging.ini"; } - "xdg/QtProject/qtlogging.ini" - ]; - "abstractions/samba" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/samba" - ${etcRule { path = "samba"; trail = "/*"; }} - ''; - "abstractions/ssl_certs" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/ssl_certs" + # libnl-3-200 via libnss-gw-name + { + path = "libnl"; + trail = "/classid"; + } + { + path = "libnl-3"; + trail = "/classid"; + } + ]; + "abstractions/nis" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/nis" + ''; + "abstractions/nss-systemd" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/nss-systemd" + ''; + "abstractions/nvidia" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/nvidia" + ${etcRule "vdpau_wrapper.cfg"} + ''; + "abstractions/opencl-common" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/opencl-common" + ${etcRule { + path = "OpenCL"; + trail = "/**"; + }} + ''; + "abstractions/opencl-mesa" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/opencl-mesa" + ${etcRule "default/drirc"} + ''; + "abstractions/openssl" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/openssl" + ${etcRule { + path = "ssl"; + trail = "/openssl.cnf"; + }} + ''; + "abstractions/p11-kit" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/p11-kit" + '' + + lib.concatMapStringsSep "\n" etcRule [ + { + path = "pkcs11"; + trail = "/"; + } + { + path = "pkcs11"; + trail = "/pkcs11.conf"; + } + { + path = "pkcs11"; + trail = "/modules/"; + } + { + path = "pkcs11"; + trail = "/modules/*"; + } + ]; + "abstractions/perl" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/perl" + ${etcRule { + path = "perl"; + trail = "/**"; + }} + ''; + "abstractions/php" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/php" + '' + + lib.concatMapStringsSep "\n" etcRule [ + { + path = "php"; + trail = "/**/"; + } + { + path = "php5"; + trail = "/**/"; + } + { + path = "php7"; + trail = "/**/"; + } + { + path = "php"; + trail = "/**.ini"; + } + { + path = "php5"; + trail = "/**.ini"; + } + { + path = "php7"; + trail = "/**.ini"; + } + ]; + "abstractions/postfix-common" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/postfix-common" + '' + + lib.concatMapStringsSep "\n" etcRule [ + "mailname" + { + path = "postfix"; + trail = "/*.cf"; + } + "postfix/main.cf" + "postfix/master.cf" + ]; + "abstractions/python" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/python" + ''; + "abstractions/qt5" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/qt5" + '' + + lib.concatMapStringsSep "\n" etcRule [ + { + path = "xdg"; + trail = "/QtProject/qtlogging.ini"; + } + { + path = "xdg/QtProject"; + trail = "/qtlogging.ini"; + } + "xdg/QtProject/qtlogging.ini" + ]; + "abstractions/samba" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/samba" + ${etcRule { + path = "samba"; + trail = "/*"; + }} + ''; + "abstractions/ssl_certs" = + '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/ssl_certs" - # For the NixOS module: security.acme - r /var/lib/acme/*/cert.pem, - r /var/lib/acme/*/chain.pem, - r /var/lib/acme/*/fullchain.pem, + # For the NixOS module: security.acme + r /var/lib/acme/*/cert.pem, + r /var/lib/acme/*/chain.pem, + r /var/lib/acme/*/fullchain.pem, - r /etc/pki/tls/certs/, + r /etc/pki/tls/certs/, - '' + lib.concatMapStringsSep "\n" etcRule [ - "ssl/certs/ca-certificates.crt" - "ssl/certs/ca-bundle.crt" - "pki/tls/certs/ca-bundle.crt" + '' + + lib.concatMapStringsSep "\n" etcRule [ + "ssl/certs/ca-certificates.crt" + "ssl/certs/ca-bundle.crt" + "pki/tls/certs/ca-bundle.crt" - { path = "ssl/trust"; trail = "/"; } - { path = "ssl/trust"; trail = "/*"; } - { path = "ssl/trust/anchors"; trail = "/"; } - { path = "ssl/trust/anchors"; trail = "/**"; } - { path = "pki/trust"; trail = "/"; } - { path = "pki/trust"; trail = "/*"; } - { path = "pki/trust/anchors"; trail = "/"; } - { path = "pki/trust/anchors"; trail = "/**"; } - ]; - "abstractions/ssl_keys" = '' - # security.acme NixOS module - r /var/lib/acme/*/full.pem, - r /var/lib/acme/*/key.pem, - ''; - "abstractions/vulkan" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/vulkan" - ${etcRule { path = "vulkan/icd.d"; trail = "/"; }} - ${etcRule { path = "vulkan/icd.d"; trail = "/*.json"; }} - ''; - "abstractions/winbind" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/winbind" - ${etcRule { path = "samba"; trail = "/smb.conf"; }} - ${etcRule { path = "samba"; trail = "/dhcp.conf"; }} - ''; - "abstractions/X" = '' - include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/X" - ${etcRule { path = "X11/cursors"; trail = "/"; }} - ${etcRule { path = "X11/cursors"; trail = "/**"; }} - ''; -}; + { + path = "ssl/trust"; + trail = "/"; + } + { + path = "ssl/trust"; + trail = "/*"; + } + { + path = "ssl/trust/anchors"; + trail = "/"; + } + { + path = "ssl/trust/anchors"; + trail = "/**"; + } + { + path = "pki/trust"; + trail = "/"; + } + { + path = "pki/trust"; + trail = "/*"; + } + { + path = "pki/trust/anchors"; + trail = "/"; + } + { + path = "pki/trust/anchors"; + trail = "/**"; + } + ]; + "abstractions/ssl_keys" = '' + # security.acme NixOS module + r /var/lib/acme/*/full.pem, + r /var/lib/acme/*/key.pem, + ''; + "abstractions/vulkan" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/vulkan" + ${etcRule { + path = "vulkan/icd.d"; + trail = "/"; + }} + ${etcRule { + path = "vulkan/icd.d"; + trail = "/*.json"; + }} + ''; + "abstractions/winbind" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/winbind" + ${etcRule { + path = "samba"; + trail = "/smb.conf"; + }} + ${etcRule { + path = "samba"; + trail = "/dhcp.conf"; + }} + ''; + "abstractions/X" = '' + include "${pkgs.apparmor-profiles}/etc/apparmor.d/abstractions/X" + ${etcRule { + path = "X11/cursors"; + trail = "/"; + }} + ${etcRule { + path = "X11/cursors"; + trail = "/**"; + }} + ''; + }; } diff --git a/nixos/modules/security/apparmor/profiles.nix b/nixos/modules/security/apparmor/profiles.nix index 46af0f15f761b5..8df70dfaa456f1 100644 --- a/nixos/modules/security/apparmor/profiles.nix +++ b/nixos/modules/security/apparmor/profiles.nix @@ -1,5 +1,7 @@ { config, pkgs, ... }: -let apparmor = config.security.apparmor; in +let + apparmor = config.security.apparmor; +in { -config.security.apparmor.packages = [ pkgs.apparmor-profiles ]; + config.security.apparmor.packages = [ pkgs.apparmor-profiles ]; } diff --git a/nixos/modules/security/audit.nix b/nixos/modules/security/audit.nix index f7dde61f8d4b8d..16d750c8fbed40 100644 --- a/nixos/modules/security/audit.nix +++ b/nixos/modules/security/audit.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.security.audit; enabled = cfg.enable == "lock" || cfg.enable; @@ -6,7 +11,7 @@ let failureModes = { silent = 0; printk = 1; - panic = 2; + panic = 2; }; disableScript = pkgs.writeScript "audit-disable" '' @@ -47,12 +52,17 @@ let # Disable auditing auditctl -e 0 ''; -in { +in +{ options = { security.audit = { enable = lib.mkOption { - type = lib.types.enum [ false true "lock" ]; - default = false; + type = lib.types.enum [ + false + true + "lock" + ]; + default = false; description = '' Whether to enable the Linux audit system. The special `lock` value can be used to enable auditing and prevent disabling it until a restart. Be careful about locking @@ -62,14 +72,18 @@ in { }; failureMode = lib.mkOption { - type = lib.types.enum [ "silent" "printk" "panic" ]; - default = "printk"; + type = lib.types.enum [ + "silent" + "printk" + "panic" + ]; + default = "printk"; description = "How to handle critical errors in the auditing system"; }; backlogLimit = lib.mkOption { - type = lib.types.int; - default = 64; # Apparently the kernel default + type = lib.types.int; + default = 64; # Apparently the kernel default description = '' The maximum number of outstanding audit buffers allowed; exceeding this is considered a failure and handled in a manner specified by failureMode. @@ -77,8 +91,8 @@ in { }; rateLimit = lib.mkOption { - type = lib.types.int; - default = 0; + type = lib.types.int; + default = 0; description = '' The maximum messages per second permitted before triggering a failure as specified by failureMode. Setting it to zero disables the limit. @@ -86,9 +100,9 @@ in { }; rules = lib.mkOption { - type = lib.types.listOf lib.types.str; # (types.either types.str (types.submodule rule)); - default = []; - example = [ "-a exit,always -F arch=b64 -S execve" ]; + type = lib.types.listOf lib.types.str; # (types.either types.str (types.submodule rule)); + default = [ ]; + example = [ "-a exit,always -F arch=b64 -S execve" ]; description = '' The ordered audit rules, with each string appearing as one line of the audit.rules file. ''; @@ -106,14 +120,13 @@ in { ConditionSecurity = [ "audit" ]; }; - path = [ pkgs.audit ]; serviceConfig = { Type = "oneshot"; RemainAfterExit = true; ExecStart = "@${if enabled then startScript else disableScript} audit-start"; - ExecStop = "@${stopScript} audit-stop"; + ExecStop = "@${stopScript} audit-stop"; }; }; }; diff --git a/nixos/modules/security/ca.nix b/nixos/modules/security/ca.nix index 9e5ad9fcf3a83a..5e85fe902de628 100644 --- a/nixos/modules/security/ca.nix +++ b/nixos/modules/security/ca.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.security.pki; @@ -35,7 +40,7 @@ in security.pki.certificateFiles = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; example = lib.literalExpression ''[ "''${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt" ]''; description = '' A list of files containing trusted root certificates in PEM @@ -48,7 +53,7 @@ in security.pki.certificates = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = lib.literalExpression '' [ ''' NixOS.org @@ -68,9 +73,10 @@ in security.pki.caCertificateBlacklist = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = [ - "WoSign" "WoSign China" + "WoSign" + "WoSign China" "CA WoSign ECC Root" "Certification Authority of WoSign G2" ]; diff --git a/nixos/modules/security/chromium-suid-sandbox.nix b/nixos/modules/security/chromium-suid-sandbox.nix index 146696b05de9ac..5d7bc3269b68c1 100644 --- a/nixos/modules/security/chromium-suid-sandbox.nix +++ b/nixos/modules/security/chromium-suid-sandbox.nix @@ -1,11 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - cfg = config.security.chromiumSuidSandbox; + cfg = config.security.chromiumSuidSandbox; sandbox = pkgs.chromium.sandbox; in { imports = [ - (lib.mkRenamedOptionModule [ "programs" "unity3d" "enable" ] [ "security" "chromiumSuidSandbox" "enable" ]) + (lib.mkRenamedOptionModule + [ "programs" "unity3d" "enable" ] + [ "security" "chromiumSuidSandbox" "enable" ] + ) ]; options.security.chromiumSuidSandbox.enable = lib.mkOption { @@ -25,11 +33,11 @@ in config = lib.mkIf cfg.enable { environment.systemPackages = [ sandbox ]; - security.wrappers.${sandbox.passthru.sandboxExecutableName} = - { setuid = true; - owner = "root"; - group = "root"; - source = "${sandbox}/bin/${sandbox.passthru.sandboxExecutableName}"; - }; + security.wrappers.${sandbox.passthru.sandboxExecutableName} = { + setuid = true; + owner = "root"; + group = "root"; + source = "${sandbox}/bin/${sandbox.passthru.sandboxExecutableName}"; + }; }; } diff --git a/nixos/modules/security/dhparams.nix b/nixos/modules/security/dhparams.nix index c501ea70d05ce6..36bb8398f5423e 100644 --- a/nixos/modules/security/dhparams.nix +++ b/nixos/modules/security/dhparams.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let inherit (lib) literalExpression mkOption types; @@ -10,36 +16,41 @@ let description = "integer of at least 16 bits"; }; - paramsSubmodule = { name, config, ... }: { - options.bits = mkOption { - type = bitType; - default = cfg.defaultBitSize; - defaultText = literalExpression "config.${opt.defaultBitSize}"; - description = '' - The bit size for the prime that is used during a Diffie-Hellman - key exchange. - ''; - }; + paramsSubmodule = + { name, config, ... }: + { + options.bits = mkOption { + type = bitType; + default = cfg.defaultBitSize; + defaultText = literalExpression "config.${opt.defaultBitSize}"; + description = '' + The bit size for the prime that is used during a Diffie-Hellman + key exchange. + ''; + }; - options.path = mkOption { - type = types.path; - readOnly = true; - description = '' - The resulting path of the generated Diffie-Hellman parameters - file for other services to reference. This could be either a - store path or a file inside the directory specified by - {option}`security.dhparams.path`. - ''; - }; + options.path = mkOption { + type = types.path; + readOnly = true; + description = '' + The resulting path of the generated Diffie-Hellman parameters + file for other services to reference. This could be either a + store path or a file inside the directory specified by + {option}`security.dhparams.path`. + ''; + }; - config.path = let - generated = pkgs.runCommand "dhparams-${name}.pem" { - nativeBuildInputs = [ pkgs.openssl ]; - } "openssl dhparam -out \"$out\" ${toString config.bits}"; - in if cfg.stateful then "${cfg.path}/${name}.pem" else generated; - }; + config.path = + let + generated = pkgs.runCommand "dhparams-${name}.pem" { + nativeBuildInputs = [ pkgs.openssl ]; + } "openssl dhparam -out \"$out\" ${toString config.bits}"; + in + if cfg.stateful then "${cfg.path}/${name}.pem" else generated; + }; -in { +in +{ options = { security.dhparams = { enable = mkOption { @@ -51,10 +62,13 @@ in { }; params = mkOption { - type = with types; let - coerce = bits: { inherit bits; }; - in attrsOf (coercedTo int coerce (submodule paramsSubmodule)); - default = {}; + type = + with types; + let + coerce = bits: { inherit bits; }; + in + attrsOf (coercedTo int coerce (submodule paramsSubmodule)); + default = { }; example = lib.literalExpression "{ nginx.bits = 3072; }"; description = '' Diffie-Hellman parameters to generate. @@ -130,55 +144,67 @@ in { }; config = lib.mkIf (cfg.enable && cfg.stateful) { - systemd.services = { - dhparams-init = { - description = "Clean Up Old Diffie-Hellman Parameters"; - - # Clean up even when no DH params is set - wantedBy = [ "multi-user.target" ]; + systemd.services = + { + dhparams-init = { + description = "Clean Up Old Diffie-Hellman Parameters"; - serviceConfig.RemainAfterExit = true; - serviceConfig.Type = "oneshot"; + # Clean up even when no DH params is set + wantedBy = [ "multi-user.target" ]; - script = '' - if [ ! -d ${cfg.path} ]; then - mkdir -p ${cfg.path} - fi + serviceConfig.RemainAfterExit = true; + serviceConfig.Type = "oneshot"; - # Remove old dhparams - for file in ${cfg.path}/*; do - if [ ! -f "$file" ]; then - continue + script = '' + if [ ! -d ${cfg.path} ]; then + mkdir -p ${cfg.path} fi - ${lib.concatStrings (lib.mapAttrsToList (name: { bits, path, ... }: '' - if [ "$file" = ${lib.escapeShellArg path} ] && \ - ${pkgs.openssl}/bin/openssl dhparam -in "$file" -text \ - | head -n 1 | grep "(${toString bits} bit)" > /dev/null; then + + # Remove old dhparams + for file in ${cfg.path}/*; do + if [ ! -f "$file" ]; then continue fi - '') cfg.params)} - rm "$file" - done - - # TODO: Ideally this would be removing the *former* cfg.path, though - # this does not seem really important as changes to it are quite - # unlikely - rmdir --ignore-fail-on-non-empty ${cfg.path} - ''; - }; - } // lib.mapAttrs' (name: { bits, path, ... }: lib.nameValuePair "dhparams-gen-${name}" { - description = "Generate Diffie-Hellman Parameters for ${name}"; - after = [ "dhparams-init.service" ]; - before = [ "${name}.service" ]; - wantedBy = [ "multi-user.target" ]; - unitConfig.ConditionPathExists = "!${path}"; - serviceConfig.Type = "oneshot"; - script = '' - mkdir -p ${lib.escapeShellArg cfg.path} - ${pkgs.openssl}/bin/openssl dhparam -out ${lib.escapeShellArg path} \ - ${toString bits} - ''; - }) cfg.params; + ${lib.concatStrings ( + lib.mapAttrsToList ( + name: + { bits, path, ... }: + '' + if [ "$file" = ${lib.escapeShellArg path} ] && \ + ${pkgs.openssl}/bin/openssl dhparam -in "$file" -text \ + | head -n 1 | grep "(${toString bits} bit)" > /dev/null; then + continue + fi + '' + ) cfg.params + )} + rm "$file" + done + + # TODO: Ideally this would be removing the *former* cfg.path, though + # this does not seem really important as changes to it are quite + # unlikely + rmdir --ignore-fail-on-non-empty ${cfg.path} + ''; + }; + } + // lib.mapAttrs' ( + name: + { bits, path, ... }: + lib.nameValuePair "dhparams-gen-${name}" { + description = "Generate Diffie-Hellman Parameters for ${name}"; + after = [ "dhparams-init.service" ]; + before = [ "${name}.service" ]; + wantedBy = [ "multi-user.target" ]; + unitConfig.ConditionPathExists = "!${path}"; + serviceConfig.Type = "oneshot"; + script = '' + mkdir -p ${lib.escapeShellArg cfg.path} + ${pkgs.openssl}/bin/openssl dhparam -out ${lib.escapeShellArg path} \ + ${toString bits} + ''; + } + ) cfg.params; }; meta.maintainers = with lib.maintainers; [ ekleog ]; diff --git a/nixos/modules/security/doas.nix b/nixos/modules/security/doas.nix index f73477e5c66426..659499a2425811 100644 --- a/nixos/modules/security/doas.nix +++ b/nixos/modules/security/doas.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.security.doas; @@ -8,20 +13,27 @@ let mkGrpString = group: ":${toString group}"; - mkOpts = rule: lib.concatStringsSep " " [ - (lib.optionalString rule.noPass "nopass") - (lib.optionalString rule.noLog "nolog") - (lib.optionalString rule.persist "persist") - (lib.optionalString rule.keepEnv "keepenv") - "setenv { SSH_AUTH_SOCK TERMINFO TERMINFO_DIRS ${lib.concatStringsSep " " rule.setEnv} }" - ]; - - mkArgs = rule: - if (rule.args == null) then "" - else if (lib.length rule.args == 0) then "args" - else "args ${lib.concatStringsSep " " rule.args}"; + mkOpts = + rule: + lib.concatStringsSep " " [ + (lib.optionalString rule.noPass "nopass") + (lib.optionalString rule.noLog "nolog") + (lib.optionalString rule.persist "persist") + (lib.optionalString rule.keepEnv "keepenv") + "setenv { SSH_AUTH_SOCK TERMINFO TERMINFO_DIRS ${lib.concatStringsSep " " rule.setEnv} }" + ]; - mkRule = rule: + mkArgs = + rule: + if (rule.args == null) then + "" + else if (lib.length rule.args == 0) then + "args" + else + "args ${lib.concatStringsSep " " rule.args}"; + + mkRule = + rule: let opts = mkOpts rule; @@ -32,14 +44,12 @@ let args = mkArgs rule; in lib.optionals (lib.length cfg.extraRules > 0) [ - ( - lib.optionalString (lib.length rule.users > 0) - (map (usr: "permit ${opts} ${mkUsrString usr} ${as} ${cmd} ${args}") rule.users) - ) - ( - lib.optionalString (lib.length rule.groups > 0) - (map (grp: "permit ${opts} ${mkGrpString grp} ${as} ${cmd} ${args}") rule.groups) - ) + (lib.optionalString (lib.length rule.users > 0) ( + map (usr: "permit ${opts} ${mkUsrString usr} ${as} ${cmd} ${args}") rule.users + )) + (lib.optionalString (lib.length rule.groups > 0) ( + map (grp: "permit ${opts} ${mkGrpString grp} ${as} ${cmd} ${args}") rule.groups + )) ]; in { @@ -67,7 +77,7 @@ in }; extraRules = lib.mkOption { - default = []; + default = [ ]; description = '' Define specific rules to be set in the {file}`/etc/doas.conf` file. More specific rules should @@ -106,8 +116,9 @@ in setEnv = [ "-SSH_AUTH_SOCK" "ALPHA=1" "BETA" ]; } ] ''; - type = with lib.types; listOf ( - submodule { + type = + with lib.types; + listOf (submodule { options = { noPass = lib.mkOption { @@ -151,7 +162,7 @@ in setEnv = lib.mkOption { type = with types; listOf str; - default = []; + default = [ ]; description = '' Keep or set the specified variables. Variables may also be removed with a leading '-' or set using @@ -170,13 +181,13 @@ in users = lib.mkOption { type = with types; listOf (either str int); - default = []; + default = [ ]; description = "The usernames / UIDs this rule should apply for."; }; groups = lib.mkOption { type = with types; listOf (either str int); - default = []; + default = [ ]; description = "The groups / GIDs this rule should apply for."; }; @@ -216,8 +227,7 @@ in ''; }; }; - } - ); + }); }; extraConfig = lib.mkOption { @@ -231,7 +241,6 @@ in }; }; - ###### implementation config = lib.mkIf cfg.enable { @@ -243,12 +252,12 @@ in } ]; - security.wrappers.doas = - { setuid = true; - owner = "root"; - group = "root"; - source = "${doas}/bin/doas"; - }; + security.wrappers.doas = { + setuid = true; + owner = "root"; + group = "root"; + source = "${doas}/bin/doas"; + }; environment.systemPackages = [ doas @@ -260,27 +269,28 @@ in }; environment.etc."doas.conf" = { - source = pkgs.runCommand "doas-conf" - { - src = pkgs.writeText "doas-conf-in" '' - # To modify this file, set the NixOS options - # `security.doas.extraRules` or `security.doas.extraConfig`. To - # completely replace the contents of this file, use - # `environment.etc."doas.conf"`. - - # extraRules - ${lib.concatStringsSep "\n" (lib.lists.flatten (map mkRule cfg.extraRules))} - - # extraConfig - ${cfg.extraConfig} - - # "root" is allowed to do anything. - permit nopass keepenv root - ''; - preferLocalBuild = true; - } - # Make sure that the doas.conf file is syntactically valid. - "${pkgs.buildPackages.doas}/bin/doas -C $src && cp $src $out"; + source = + pkgs.runCommand "doas-conf" + { + src = pkgs.writeText "doas-conf-in" '' + # To modify this file, set the NixOS options + # `security.doas.extraRules` or `security.doas.extraConfig`. To + # completely replace the contents of this file, use + # `environment.etc."doas.conf"`. + + # extraRules + ${lib.concatStringsSep "\n" (lib.lists.flatten (map mkRule cfg.extraRules))} + + # extraConfig + ${cfg.extraConfig} + + # "root" is allowed to do anything. + permit nopass keepenv root + ''; + preferLocalBuild = true; + } + # Make sure that the doas.conf file is syntactically valid. + "${pkgs.buildPackages.doas}/bin/doas -C $src && cp $src $out"; mode = "0440"; }; diff --git a/nixos/modules/security/duosec.nix b/nixos/modules/security/duosec.nix index 7543179b7fbebb..c1699f0cf30836 100644 --- a/nixos/modules/security/duosec.nix +++ b/nixos/modules/security/duosec.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.security.duosec; @@ -8,7 +13,7 @@ let [duo] ikey=${cfg.integrationKey} host=${cfg.host} - ${lib.optionalString (cfg.groups != "") ("groups="+cfg.groups)} + ${lib.optionalString (cfg.groups != "") ("groups=" + cfg.groups)} failmode=${cfg.failmode} pushinfo=${boolToStr cfg.pushinfo} autopush=${boolToStr cfg.autopush} @@ -16,16 +21,20 @@ let fallback_local_ip=${boolToStr cfg.fallbackLocalIP} ''; - configFileLogin = configFilePam + '' - motd=${boolToStr cfg.motd} - accept_env_factor=${boolToStr cfg.acceptEnvFactor} - ''; + configFileLogin = + configFilePam + + '' + motd=${boolToStr cfg.motd} + accept_env_factor=${boolToStr cfg.acceptEnvFactor} + ''; in { imports = [ (lib.mkRenamedOptionModule [ "security" "duosec" "group" ] [ "security" "duosec" "groups" ]) (lib.mkRenamedOptionModule [ "security" "duosec" "ikey" ] [ "security" "duosec" "integrationKey" ]) - (lib.mkRemovedOptionModule [ "security" "duosec" "skey" ] "The insecure security.duosec.skey option has been replaced by a new security.duosec.secretKeyFile option. Use this new option to store a secure copy of your key instead.") + (lib.mkRemovedOptionModule [ "security" "duosec" "skey" ] + "The insecure security.duosec.skey option has been replaced by a new security.duosec.secretKeyFile option. Use this new option to store a secure copy of your key instead." + ) ]; options = { @@ -74,7 +83,10 @@ in }; failmode = lib.mkOption { - type = lib.types.enum [ "safe" "secure" ]; + type = lib.types.enum [ + "safe" + "secure" + ]; default = "safe"; description = '' On service or configuration errors that prevent Duo @@ -116,7 +128,11 @@ in }; prompts = lib.mkOption { - type = lib.types.enum [ 1 2 3 ]; + type = lib.types.enum [ + 1 + 2 + 3 + ]; default = 3; description = '' If a user fails to authenticate with a second factor, Duo @@ -183,16 +199,19 @@ in config = lib.mkIf (cfg.ssh.enable || cfg.pam.enable) { environment.systemPackages = [ pkgs.duo-unix ]; - security.wrappers.login_duo = - { setuid = true; - owner = "root"; - group = "root"; - source = "${pkgs.duo-unix.out}/bin/login_duo"; - }; + security.wrappers.login_duo = { + setuid = true; + owner = "root"; + group = "root"; + source = "${pkgs.duo-unix.out}/bin/login_duo"; + }; systemd.services.login-duo = lib.mkIf cfg.ssh.enable { wantedBy = [ "sysinit.target" ]; - before = [ "sysinit.target" "shutdown.target" ]; + before = [ + "sysinit.target" + "shutdown.target" + ]; conflicts = [ "shutdown.target" ]; unitConfig.DefaultDependencies = false; script = '' @@ -215,7 +234,10 @@ in systemd.services.pam-duo = lib.mkIf cfg.ssh.enable { wantedBy = [ "sysinit.target" ]; - before = [ "sysinit.target" "shutdown.target" ]; + before = [ + "sysinit.target" + "shutdown.target" + ]; conflicts = [ "shutdown.target" ]; unitConfig.DefaultDependencies = false; script = '' @@ -235,16 +257,22 @@ in ''; }; - /* If PAM *and* SSH are enabled, then don't do anything special. - If PAM isn't used, set the default SSH-only options. */ + /* + If PAM *and* SSH are enabled, then don't do anything special. + If PAM isn't used, set the default SSH-only options. + */ services.openssh.extraConfig = lib.mkIf (cfg.ssh.enable || cfg.pam.enable) ( - if cfg.pam.enable then "UseDNS no" else '' - # Duo Security configuration - ForceCommand ${config.security.wrapperDir}/login_duo - PermitTunnel no - ${lib.optionalString (!cfg.allowTcpForwarding) '' - AllowTcpForwarding no - ''} - ''); + if cfg.pam.enable then + "UseDNS no" + else + '' + # Duo Security configuration + ForceCommand ${config.security.wrapperDir}/login_duo + PermitTunnel no + ${lib.optionalString (!cfg.allowTcpForwarding) '' + AllowTcpForwarding no + ''} + '' + ); }; } diff --git a/nixos/modules/security/google_oslogin.nix b/nixos/modules/security/google_oslogin.nix index 42dd3b22a00593..61e62b47a7d479 100644 --- a/nixos/modules/security/google_oslogin.nix +++ b/nixos/modules/security/google_oslogin.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.security.googleOsLogin; @@ -53,8 +58,14 @@ in # enable the nss module, so user lookups etc. work system.nssModules = [ package ]; - system.nssDatabases.passwd = [ "cache_oslogin" "oslogin" ]; - system.nssDatabases.group = [ "cache_oslogin" "oslogin" ]; + system.nssDatabases.passwd = [ + "cache_oslogin" + "oslogin" + ]; + system.nssDatabases.group = [ + "cache_oslogin" + "oslogin" + ]; # Ugly: sshd refuses to start if a store path is given because /nix/store is group-writable. # So indirect by a symlink. diff --git a/nixos/modules/security/isolate.nix b/nixos/modules/security/isolate.nix index 11a6af588b5b42..74274d04c6b837 100644 --- a/nixos/modules/security/isolate.nix +++ b/nixos/modules/security/isolate.nix @@ -1,7 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkPackageOption mkOption types mkIf maintainers; + inherit (lib) + mkEnableOption + mkPackageOption + mkOption + types + mkIf + maintainers + ; cfg = config.security.isolate; configFile = pkgs.writeText "isolate-config.cf" '' diff --git a/nixos/modules/security/krb5/default.nix b/nixos/modules/security/krb5/default.nix index 6714c41d8a07cc..fa7895f4a0a95b 100644 --- a/nixos/modules/security/krb5/default.nix +++ b/nixos/modules/security/krb5/default.nix @@ -1,17 +1,30 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkIf mkOption mkPackageOption mkRemovedOptionModule; + inherit (lib) + mkIf + mkOption + mkPackageOption + mkRemovedOptionModule + ; inherit (lib.types) bool; - mkRemovedOptionModule' = name: reason: mkRemovedOptionModule ["krb5" name] reason; - mkRemovedOptionModuleCfg = name: mkRemovedOptionModule' name '' - The option `krb5.${name}' has been removed. Use - `security.krb5.settings.${name}' for structured configuration. - ''; + mkRemovedOptionModule' = name: reason: mkRemovedOptionModule [ "krb5" name ] reason; + mkRemovedOptionModuleCfg = + name: + mkRemovedOptionModule' name '' + The option `krb5.${name}' has been removed. Use + `security.krb5.settings.${name}' for structured configuration. + ''; cfg = config.security.krb5; format = import ./krb5-conf-format.nix { inherit pkgs lib; } { }; -in { +in +{ imports = [ (mkRemovedOptionModuleCfg "libdefaults") (mkRemovedOptionModuleCfg "realms") @@ -78,19 +91,27 @@ in { }; config = { - assertions = mkIf (cfg.enable || config.services.kerberos_server.enable) [(let - implementation = cfg.package.passthru.implementation or ""; - in { - assertion = lib.elem implementation [ "krb5" "heimdal" ]; - message = '' - `security.krb5.package` must be one of: + assertions = mkIf (cfg.enable || config.services.kerberos_server.enable) [ + ( + let + implementation = cfg.package.passthru.implementation or ""; + in + { + assertion = lib.elem implementation [ + "krb5" + "heimdal" + ]; + message = '' + `security.krb5.package` must be one of: - - krb5 - - heimdal + - krb5 + - heimdal - Currently chosen implementation: ${implementation} - ''; - })]; + Currently chosen implementation: ${implementation} + ''; + } + ) + ]; environment = mkIf cfg.enable { systemPackages = [ cfg.package ]; diff --git a/nixos/modules/security/krb5/krb5-conf-format.nix b/nixos/modules/security/krb5/krb5-conf-format.nix index 3e5e64ae0cb049..274e1024209da5 100644 --- a/nixos/modules/security/krb5/krb5-conf-format.nix +++ b/nixos/modules/security/krb5/krb5-conf-format.nix @@ -5,141 +5,200 @@ # - https://manpages.debian.org/unstable/heimdal-docs/krb5.conf.5heimdal.en.html let - inherit (lib) boolToString concatMapStringsSep concatStringsSep filter - isAttrs isBool isList mapAttrsToList mkOption singleton splitString; - inherit (lib.types) attrsOf bool coercedTo either enum int listOf oneOf - path str submodule; + inherit (lib) + boolToString + concatMapStringsSep + concatStringsSep + filter + isAttrs + isBool + isList + mapAttrsToList + mkOption + singleton + splitString + ; + inherit (lib.types) + attrsOf + bool + coercedTo + either + enum + int + listOf + oneOf + path + str + submodule + ; in { - enableKdcACLEntries ? false -}: rec { - sectionType = let - relation = oneOf [ - (listOf (attrsOf value)) - (attrsOf value) - value - ]; - value = either (listOf atom) atom; - atom = oneOf [int str bool]; - in attrsOf relation; + enableKdcACLEntries ? false, +}: +rec { + sectionType = + let + relation = oneOf [ + (listOf (attrsOf value)) + (attrsOf value) + value + ]; + value = either (listOf atom) atom; + atom = oneOf [ + int + str + bool + ]; + in + attrsOf relation; - type = let - aclEntry = submodule { - options = { - principal = mkOption { - type = str; - description = "Which principal the rule applies to"; - }; - access = mkOption { - type = either - (listOf (enum ["add" "cpw" "delete" "get" "list" "modify"])) - (enum ["all"]); - default = "all"; - description = "The changes the principal is allowed to make."; - }; - target = mkOption { - type = str; - default = "*"; - description = "The principals that 'access' applies to."; + type = + let + aclEntry = submodule { + options = { + principal = mkOption { + type = str; + description = "Which principal the rule applies to"; + }; + access = mkOption { + type = either (listOf (enum [ + "add" + "cpw" + "delete" + "get" + "list" + "modify" + ])) (enum [ "all" ]); + default = "all"; + description = "The changes the principal is allowed to make."; + }; + target = mkOption { + type = str; + default = "*"; + description = "The principals that 'access' applies to."; + }; }; }; - }; - realm = submodule ({ name, ... }: { - freeformType = sectionType; - options = { - acl = mkOption { - type = listOf aclEntry; - default = [ - { principal = "*/admin"; access = "all"; } - { principal = "admin"; access = "all"; } - ]; - description = '' - The privileges granted to a user. - ''; - }; - }; - }); - in submodule { - freeformType = attrsOf sectionType; - options = { - include = mkOption { - default = [ ]; - description = '' - Files to include in the Kerberos configuration. - ''; - type = coercedTo path singleton (listOf path); - }; - includedir = mkOption { - default = [ ]; - description = '' - Directories containing files to include in the Kerberos configuration. - ''; - type = coercedTo path singleton (listOf path); - }; - module = mkOption { - default = [ ]; - description = '' - Modules to obtain Kerberos configuration from. - ''; - type = coercedTo path singleton (listOf path); - }; + realm = submodule ( + { name, ... }: + { + freeformType = sectionType; + options = { + acl = mkOption { + type = listOf aclEntry; + default = [ + { + principal = "*/admin"; + access = "all"; + } + { + principal = "admin"; + access = "all"; + } + ]; + description = '' + The privileges granted to a user. + ''; + }; + }; + } + ); + in + submodule { + freeformType = attrsOf sectionType; + options = + { + include = mkOption { + default = [ ]; + description = '' + Files to include in the Kerberos configuration. + ''; + type = coercedTo path singleton (listOf path); + }; + includedir = mkOption { + default = [ ]; + description = '' + Directories containing files to include in the Kerberos configuration. + ''; + type = coercedTo path singleton (listOf path); + }; + module = mkOption { + default = [ ]; + description = '' + Modules to obtain Kerberos configuration from. + ''; + type = coercedTo path singleton (listOf path); + }; - } - // - (lib.optionalAttrs enableKdcACLEntries { - realms = mkOption { - type = attrsOf realm; - description = '' - The realm(s) to serve keys for. - ''; - }; - }); - }; + } + // (lib.optionalAttrs enableKdcACLEntries { + realms = mkOption { + type = attrsOf realm; + description = '' + The realm(s) to serve keys for. + ''; + }; + }); + }; - generate = let - indent = str: concatMapStringsSep "\n" (line: " " + line) (splitString "\n" str); + generate = + let + indent = str: concatMapStringsSep "\n" (line: " " + line) (splitString "\n" str); - formatToplevel = args @ { - include ? [ ], - includedir ? [ ], - module ? [ ], - ... - }: let - sections = removeAttrs args [ "include" "includedir" "module" ]; - in concatStringsSep "\n" (filter (x: x != "") [ - (concatStringsSep "\n" (mapAttrsToList formatSection sections)) - (concatMapStringsSep "\n" (m: "module ${m}") module) - (concatMapStringsSep "\n" (i: "include ${i}") include) - (concatMapStringsSep "\n" (i: "includedir ${i}") includedir) - ]); + formatToplevel = + args@{ + include ? [ ], + includedir ? [ ], + module ? [ ], + ... + }: + let + sections = removeAttrs args [ + "include" + "includedir" + "module" + ]; + in + concatStringsSep "\n" ( + filter (x: x != "") [ + (concatStringsSep "\n" (mapAttrsToList formatSection sections)) + (concatMapStringsSep "\n" (m: "module ${m}") module) + (concatMapStringsSep "\n" (i: "include ${i}") include) + (concatMapStringsSep "\n" (i: "includedir ${i}") includedir) + ] + ); - formatSection = name: section: '' - [${name}] - ${indent (concatStringsSep "\n" (mapAttrsToList formatRelation section))} - ''; + formatSection = name: section: '' + [${name}] + ${indent (concatStringsSep "\n" (mapAttrsToList formatRelation section))} + ''; - formatRelation = name: relation: - if isAttrs relation - then '' - ${name} = { - ${indent (concatStringsSep "\n" (mapAttrsToList formatValue relation))} - }'' - else if isList relation - then - concatMapStringsSep "\n" (formatRelation name) relation - else formatValue name relation; + formatRelation = + name: relation: + if isAttrs relation then + '' + ${name} = { + ${indent (concatStringsSep "\n" (mapAttrsToList formatValue relation))} + }'' + else if isList relation then + concatMapStringsSep "\n" (formatRelation name) relation + else + formatValue name relation; - formatValue = name: value: - if isList value - then concatMapStringsSep "\n" (formatAtom name) value - else formatAtom name value; + formatValue = + name: value: + if isList value then concatMapStringsSep "\n" (formatAtom name) value else formatAtom name value; - formatAtom = name: atom: let - v = if isBool atom then boolToString atom else toString atom; - in "${name} = ${v}"; - in - name: value: pkgs.writeText name '' + formatAtom = + name: atom: + let + v = if isBool atom then boolToString atom else toString atom; + in + "${name} = ${v}"; + in + name: value: + pkgs.writeText name '' ${formatToplevel value} ''; } diff --git a/nixos/modules/security/lock-kernel-modules.nix b/nixos/modules/security/lock-kernel-modules.nix index fac7ab87cb98f8..6ad2c76785d568 100644 --- a/nixos/modules/security/lock-kernel-modules.nix +++ b/nixos/modules/security/lock-kernel-modules.nix @@ -18,12 +18,19 @@ }; config = lib.mkIf config.security.lockKernelModules { - boot.kernelModules = lib.concatMap (x: + boot.kernelModules = lib.concatMap ( + x: lib.optionals (x.device != null) ( - if x.fsType == "vfat" - then [ "vfat" "nls-cp437" "nls-iso8859-1" ] - else [ x.fsType ]) - ) config.system.build.fileSystems; + if x.fsType == "vfat" then + [ + "vfat" + "nls-cp437" + "nls-iso8859-1" + ] + else + [ x.fsType ] + ) + ) config.system.build.fileSystems; systemd.services.disable-kernel-module-loading = { description = "Disable kernel module loading"; @@ -31,19 +38,19 @@ wants = [ "systemd-udevd.service" ]; wantedBy = [ config.systemd.defaultUnit ]; - after = - [ "firewall.service" - "systemd-modules-load.service" - config.systemd.defaultUnit - ]; + after = [ + "firewall.service" + "systemd-modules-load.service" + config.systemd.defaultUnit + ]; unitConfig.ConditionPathIsReadWrite = "/proc/sys/kernel"; - serviceConfig = - { Type = "oneshot"; - RemainAfterExit = true; - TimeoutSec = 180; - }; + serviceConfig = { + Type = "oneshot"; + RemainAfterExit = true; + TimeoutSec = 180; + }; script = '' ${config.systemd.package}/bin/udevadm settle diff --git a/nixos/modules/security/misc.nix b/nixos/modules/security/misc.nix index d3ffefe46fc6fc..dc90d60386ebf9 100644 --- a/nixos/modules/security/misc.nix +++ b/nixos/modules/security/misc.nix @@ -5,7 +5,10 @@ }; imports = [ - (lib.mkRenamedOptionModule [ "security" "virtualization" "flushL1DataCache" ] [ "security" "virtualisation" "flushL1DataCache" ]) + (lib.mkRenamedOptionModule + [ "security" "virtualization" "flushL1DataCache" ] + [ "security" "virtualisation" "flushL1DataCache" ] + ) ]; options = { @@ -78,7 +81,13 @@ }; security.virtualisation.flushL1DataCache = lib.mkOption { - type = lib.types.nullOr (lib.types.enum [ "never" "cond" "always" ]); + type = lib.types.nullOr ( + lib.types.enum [ + "never" + "cond" + "always" + ] + ); default = null; description = '' Whether the hypervisor should flush the L1 data cache before @@ -105,7 +114,8 @@ boot.kernel.sysctl."user.max_user_namespaces" = 0; assertions = [ - { assertion = config.nix.settings.sandbox -> config.security.allowUserNamespaces; + { + assertion = config.nix.settings.sandbox -> config.security.allowUserNamespaces; message = "`nix.settings.sandbox = true` conflicts with `!security.allowUserNamespaces`."; } ]; @@ -131,7 +141,9 @@ }) (lib.mkIf (config.security.virtualisation.flushL1DataCache != null) { - boot.kernelParams = [ "kvm-intel.vmentry_l1d_flush=${config.security.virtualisation.flushL1DataCache}" ]; + boot.kernelParams = [ + "kvm-intel.vmentry_l1d_flush=${config.security.virtualisation.flushL1DataCache}" + ]; }) ]; } diff --git a/nixos/modules/security/oath.nix b/nixos/modules/security/oath.nix index acf9440b9b92c4..0b29c1b9ae8994 100644 --- a/nixos/modules/security/oath.nix +++ b/nixos/modules/security/oath.nix @@ -13,7 +13,11 @@ }; digits = lib.mkOption { - type = lib.types.enum [ 6 7 8 ]; + type = lib.types.enum [ + 6 + 7 + 8 + ]; default = 6; description = '' Specify the lib.length of the one-time password in number of diff --git a/nixos/modules/security/pam_mount.nix b/nixos/modules/security/pam_mount.nix index 2915118eb7b48a..d47f2ec0552111 100644 --- a/nixos/modules/security/pam_mount.nix +++ b/nixos/modules/security/pam_mount.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.security.pam.mount; @@ -10,7 +15,9 @@ let ${pkgs.lsof}/bin/lsof | ${pkgs.gnugrep}/bin/grep $MNTPT | ${pkgs.gawk}/bin/awk '{print $2}' | ${pkgs.findutils}/bin/xargs ${pkgs.util-linux}/bin/kill -$SIGNAL ''; - anyPamMount = lib.any (lib.attrByPath ["pamMount"] false) (lib.attrValues config.security.pam.services); + anyPamMount = lib.any (lib.attrByPath [ "pamMount" ] false) ( + lib.attrValues config.security.pam.services + ); in { @@ -27,7 +34,7 @@ in extraVolumes = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' List of volume definitions for pam_mount. For more information, visit . @@ -36,7 +43,7 @@ in additionalSearchPaths = lib.mkOption { type = lib.types.listOf lib.types.package; - default = []; + default = [ ]; example = lib.literalExpression "[ pkgs.bindfs ]"; description = '' Additional programs to include in the search path of pam_mount. @@ -46,7 +53,7 @@ in cryptMountOptions = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = lib.literalExpression '' [ "allow_discard" ] ''; @@ -58,7 +65,7 @@ in fuseMountOptions = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = lib.literalExpression '' [ "nodev" "nosuid" "force-user=%(USER)" "gid=%(USERGID)" "perms=0700" "chmod-deny" "chown-deny" "chgrp-deny" ] ''; @@ -140,42 +147,54 @@ in environment.etc."security/pam_mount.conf.xml" = { source = let - extraUserVolumes = lib.filterAttrs (n: u: u.cryptHomeLuks != null || u.pamMount != {}) config.users.users; + extraUserVolumes = lib.filterAttrs ( + n: u: u.cryptHomeLuks != null || u.pamMount != { } + ) config.users.users; mkAttr = k: v: ''${k}="${v}"''; - userVolumeEntry = user: let - attrs = { - user = user.name; - path = user.cryptHomeLuks; - mountpoint = user.home; - } // user.pamMount; - in + userVolumeEntry = + user: + let + attrs = { + user = user.name; + path = user.cryptHomeLuks; + mountpoint = user.home; + } // user.pamMount; + in "\n"; in - pkgs.writeText "pam_mount.conf.xml" '' + pkgs.writeText "pam_mount.conf.xml" '' - + ${lib.makeBinPath ([ pkgs.util-linux ] ++ cfg.additionalSearchPaths)} - + - ${pkgs.fuse}/bin/mount.fuse %(VOLUME) %(MNTPT) -o ,${lib.concatStringsSep "," (cfg.fuseMountOptions ++ [ "%(OPTIONS)" ])}' + ${pkgs.fuse}/bin/mount.fuse %(VOLUME) %(MNTPT) -o ,${ + lib.concatStringsSep "," (cfg.fuseMountOptions ++ [ "%(OPTIONS)" ]) + }' ${pkgs.fuse}/bin/fusermount -u %(MNTPT) - ${pkgs.pam_mount}/bin/mount.crypt -o ,${lib.concatStringsSep "," (cfg.cryptMountOptions ++ [ "%(OPTIONS)" ])} %(VOLUME) %(MNTPT) + ${pkgs.pam_mount}/bin/mount.crypt -o ,${ + lib.concatStringsSep "," (cfg.cryptMountOptions ++ [ "%(OPTIONS)" ]) + } %(VOLUME) %(MNTPT) ${pkgs.pam_mount}/bin/umount.crypt %(MNTPT) ${pkgs.pam_mount}/bin/pmvarrun -u %(USER) -o %(OPERATION) ${lib.optionalString oflRequired "${fake_ofl}/bin/fake_ofl %(SIGNAL) %(MNTPT)"} ${lib.concatStrings (map userVolumeEntry (lib.attrValues extraUserVolumes))} ${lib.concatStringsSep "\n" cfg.extraVolumes} - ''; + ''; }; }; diff --git a/nixos/modules/security/please.nix b/nixos/modules/security/please.nix index 05a189dfbaaaa2..9c3b6c4bca6a97 100644 --- a/nixos/modules/security/please.nix +++ b/nixos/modules/security/please.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.security.please; ini = pkgs.formats.ini { }; @@ -79,15 +84,20 @@ in rule = ".*"; require_pass = cfg.wheelNeedsPassword; }; - wheel_edit_as_any = wheel_run_as_any // { type = "edit"; }; - wheel_list_as_any = wheel_run_as_any // { type = "list"; }; + wheel_edit_as_any = wheel_run_as_any // { + type = "edit"; + }; + wheel_list_as_any = wheel_run_as_any // { + type = "list"; + }; }; environment = { systemPackages = [ cfg.package ]; - etc."please.ini".source = ini.generate "please.ini" - (cfg.settings // (rec { + etc."please.ini".source = ini.generate "please.ini" ( + cfg.settings + // (rec { # The "root" user is allowed to do anything by default and this cannot # be overridden. root_run_as_any = { @@ -97,9 +107,14 @@ in rule = ".*"; require_pass = false; }; - root_edit_as_any = root_run_as_any // { type = "edit"; }; - root_list_as_any = root_run_as_any // { type = "list"; }; - })); + root_edit_as_any = root_run_as_any // { + type = "edit"; + }; + root_list_as_any = root_run_as_any // { + type = "list"; + }; + }) + ); }; security.pam.services.please = { diff --git a/nixos/modules/security/polkit.nix b/nixos/modules/security/polkit.nix index eb783179af553a..5d37cdf6511511 100644 --- a/nixos/modules/security/polkit.nix +++ b/nixos/modules/security/polkit.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.security.polkit; @@ -18,45 +23,47 @@ in security.polkit.extraConfig = lib.mkOption { type = lib.types.lines; default = ""; - example = - '' - /* Log authorization checks. */ - polkit.addRule(function(action, subject) { - // Make sure to set { security.polkit.debug = true; } in configuration.nix - polkit.log("user " + subject.user + " is attempting action " + action.id + " from PID " + subject.pid); - }); - - /* Allow any local user to do anything (dangerous!). */ - polkit.addRule(function(action, subject) { - if (subject.local) return "yes"; - }); - ''; - description = - '' - Any polkit rules to be added to config (in JavaScript ;-). See: - - ''; + example = '' + /* Log authorization checks. */ + polkit.addRule(function(action, subject) { + // Make sure to set { security.polkit.debug = true; } in configuration.nix + polkit.log("user " + subject.user + " is attempting action " + action.id + " from PID " + subject.pid); + }); + + /* Allow any local user to do anything (dangerous!). */ + polkit.addRule(function(action, subject) { + if (subject.local) return "yes"; + }); + ''; + description = '' + Any polkit rules to be added to config (in JavaScript ;-). See: + + ''; }; security.polkit.adminIdentities = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ "unix-group:wheel" ]; - example = [ "unix-user:alice" "unix-group:admin" ]; - description = - '' - Specifies which users are considered “administrators”, for those - actions that require the user to authenticate as an - administrator (i.e. have an `auth_admin` - value). By default, this is all users in the `wheel` group. - ''; + example = [ + "unix-user:alice" + "unix-group:admin" + ]; + description = '' + Specifies which users are considered “administrators”, for those + actions that require the user to authenticate as an + administrator (i.e. have an `auth_admin` + value). By default, this is all users in the `wheel` group. + ''; }; }; - config = lib.mkIf cfg.enable { - environment.systemPackages = [ cfg.package.bin cfg.package.out ]; + environment.systemPackages = [ + cfg.package.bin + cfg.package.out + ]; systemd.packages = [ cfg.package.out ]; @@ -72,32 +79,31 @@ in environment.pathsToLink = [ "/share/polkit-1" ]; # PolKit rules for NixOS. - environment.etc."polkit-1/rules.d/10-nixos.rules".text = - '' - polkit.addAdminRule(function(action, subject) { - return [${lib.concatStringsSep ", " (map (i: "\"${i}\"") cfg.adminIdentities)}]; - }); + environment.etc."polkit-1/rules.d/10-nixos.rules".text = '' + polkit.addAdminRule(function(action, subject) { + return [${lib.concatStringsSep ", " (map (i: "\"${i}\"") cfg.adminIdentities)}]; + }); - ${cfg.extraConfig} - ''; #TODO: validation on compilation (at least against typos) + ${cfg.extraConfig} + ''; # TODO: validation on compilation (at least against typos) services.dbus.packages = [ cfg.package.out ]; - security.pam.services.polkit-1 = {}; + security.pam.services.polkit-1 = { }; security.wrappers = { - pkexec = - { setuid = true; - owner = "root"; - group = "root"; - source = "${cfg.package.bin}/bin/pkexec"; - }; - polkit-agent-helper-1 = - { setuid = true; - owner = "root"; - group = "root"; - source = "${cfg.package.out}/lib/polkit-1/polkit-agent-helper-1"; - }; + pkexec = { + setuid = true; + owner = "root"; + group = "root"; + source = "${cfg.package.bin}/bin/pkexec"; + }; + polkit-agent-helper-1 = { + setuid = true; + owner = "root"; + group = "root"; + source = "${cfg.package.out}/lib/polkit-1/polkit-agent-helper-1"; + }; }; systemd.tmpfiles.rules = [ @@ -112,7 +118,7 @@ in group = "polkituser"; }; - users.groups.polkituser = {}; + users.groups.polkituser = { }; }; } diff --git a/nixos/modules/security/rngd.nix b/nixos/modules/security/rngd.nix index 8cca1c26d683a2..63636da4b290ad 100644 --- a/nixos/modules/security/rngd.nix +++ b/nixos/modules/security/rngd.nix @@ -1,16 +1,21 @@ { lib, ... }: let - removed = k: lib.mkRemovedOptionModule [ "security" "rngd" k ]; + removed = + k: + lib.mkRemovedOptionModule [ + "security" + "rngd" + k + ]; in { imports = [ (removed "enable" '' - rngd is not necessary for any device that the kernel recognises - as an hardware RNG, as it will automatically run the krngd task - to periodically collect random data from the device and mix it - into the kernel's RNG. + rngd is not necessary for any device that the kernel recognises + as an hardware RNG, as it will automatically run the krngd task + to periodically collect random data from the device and mix it + into the kernel's RNG. '') - (removed "debug" - "The rngd module was removed, so its debug option does nothing.") + (removed "debug" "The rngd module was removed, so its debug option does nothing.") ]; } diff --git a/nixos/modules/security/sudo-rs.nix b/nixos/modules/security/sudo-rs.nix index b920015c491134..342669b4300bd3 100644 --- a/nixos/modules/security/sudo-rs.nix +++ b/nixos/modules/security/sudo-rs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.security.sudo-rs; @@ -6,12 +11,14 @@ let toUserString = user: if (lib.isInt user) then "#${toString user}" else "${user}"; toGroupString = group: if (lib.isInt group) then "%#${toString group}" else "%${group}"; - toCommandOptionsString = options: - "${lib.concatStringsSep ":" options}${lib.optionalString (lib.length options != 0) ":"} "; + toCommandOptionsString = + options: "${lib.concatStringsSep ":" options}${lib.optionalString (lib.length options != 0) ":"} "; - toCommandsString = commands: + toCommandsString = + commands: lib.concatStringsSep ", " ( - map (command: + map ( + command: if (lib.isString command) then command else @@ -29,7 +36,7 @@ in defaultOptions = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; description = '' Options used for the default rules, granting `root` and the `wheel` group permission to run any command as any user. @@ -50,7 +57,7 @@ in Whether users of the `wheel` group must provide a password to run commands as super user via {command}`sudo`. ''; - }; + }; execWheelOnly = lib.mkOption { type = lib.types.bool; @@ -80,7 +87,7 @@ in yield the expected behavior. You can use `lib.mkBefore`/`lib.mkAfter` to ensure this is the case when configuration options are merged. ''; - default = []; + default = [ ]; example = lib.literalExpression '' [ # Allow execution of any command by all users in group sudo, @@ -100,73 +107,92 @@ in { command = '''/home/baz/cmd2.sh ""'''; options = [ "SETENV" ]; } ]; } ] ''; - type = with lib.types; listOf (submodule { - options = { - users = lib.mkOption { - type = with lib.types; listOf (either str int); - description = '' - The usernames / UIDs this rule should apply for. - ''; - default = []; - }; - - groups = lib.mkOption { - type = with lib.types; listOf (either str int); - description = '' - The groups / GIDs this rule should apply for. - ''; - default = []; - }; - - host = lib.mkOption { - type = lib.types.str; - default = "ALL"; - description = '' - For what host this rule should apply. - ''; + type = + with lib.types; + listOf (submodule { + options = { + users = lib.mkOption { + type = with lib.types; listOf (either str int); + description = '' + The usernames / UIDs this rule should apply for. + ''; + default = [ ]; + }; + + groups = lib.mkOption { + type = with lib.types; listOf (either str int); + description = '' + The groups / GIDs this rule should apply for. + ''; + default = [ ]; + }; + + host = lib.mkOption { + type = lib.types.str; + default = "ALL"; + description = '' + For what host this rule should apply. + ''; + }; + + runAs = lib.mkOption { + type = with lib.types; str; + default = "ALL:ALL"; + description = '' + Under which user/group the specified command is allowed to run. + + A user can be specified using just the username: `"foo"`. + It is also possible to specify a user/group combination using `"foo:bar"` + or to only allow running as a specific group with `":bar"`. + ''; + }; + + commands = lib.mkOption { + description = '' + The commands for which the rule should apply. + ''; + type = + with lib.types; + listOf ( + either str (submodule { + + options = { + command = lib.mkOption { + type = with lib.types; str; + description = '' + A command being either just a path to a binary to allow any arguments, + the full command with arguments pre-set or with `""` used as the argument, + not allowing arguments to the command at all. + ''; + }; + + options = lib.mkOption { + type = + with lib.types; + listOf (enum [ + "NOPASSWD" + "PASSWD" + "NOEXEC" + "EXEC" + "SETENV" + "NOSETENV" + "LOG_INPUT" + "NOLOG_INPUT" + "LOG_OUTPUT" + "NOLOG_OUTPUT" + ]); + description = '' + Options for running the command. Refer to the [sudo manual](https://www.sudo.ws/man/1.7.10/sudoers.man.html). + ''; + default = [ ]; + }; + }; + + }) + ); + }; }; - - runAs = lib.mkOption { - type = with lib.types; str; - default = "ALL:ALL"; - description = '' - Under which user/group the specified command is allowed to run. - - A user can be specified using just the username: `"foo"`. - It is also possible to specify a user/group combination using `"foo:bar"` - or to only allow running as a specific group with `":bar"`. - ''; - }; - - commands = lib.mkOption { - description = '' - The commands for which the rule should apply. - ''; - type = with lib.types; listOf (either str (submodule { - - options = { - command = lib.mkOption { - type = with lib.types; str; - description = '' - A command being either just a path to a binary to allow any arguments, - the full command with arguments pre-set or with `""` used as the argument, - not allowing arguments to the command at all. - ''; - }; - - options = lib.mkOption { - type = with lib.types; listOf (enum [ "NOPASSWD" "PASSWD" "NOEXEC" "EXEC" "SETENV" "NOSETENV" "LOG_INPUT" "NOLOG_INPUT" "LOG_OUTPUT" "NOLOG_OUTPUT" ]); - description = '' - Options for running the command. Refer to the [sudo manual](https://www.sudo.ws/man/1.7.10/sudoers.man.html). - ''; - default = []; - }; - }; - - })); - }; - }; - }); + }); }; extraConfig = lib.mkOption { @@ -178,29 +204,43 @@ in }; }; - ###### implementation config = lib.mkIf cfg.enable { - assertions = [ { - assertion = ! config.security.sudo.enable; - message = "`security.sudo` and `security.sudo-rs` cannot both be enabled"; - }]; + assertions = [ + { + assertion = !config.security.sudo.enable; + message = "`security.sudo` and `security.sudo-rs` cannot both be enabled"; + } + ]; security.sudo.enable = lib.mkDefault false; security.sudo-rs.extraRules = let - defaultRule = { users ? [], groups ? [], opts ? [] }: [ { - inherit users groups; - commands = [ { - command = "ALL"; - options = opts ++ cfg.defaultOptions; - } ]; - } ]; - in lib.mkMerge [ + defaultRule = + { + users ? [ ], + groups ? [ ], + opts ? [ ], + }: + [ + { + inherit users groups; + commands = [ + { + command = "ALL"; + options = opts ++ cfg.defaultOptions; + } + ]; + } + ]; + in + lib.mkMerge [ # This is ordered before users' `lib.mkBefore` rules, # so as not to introduce unexpected changes. - (lib.mkOrder 400 (defaultRule { users = [ "root" ]; })) + (lib.mkOrder 400 (defaultRule { + users = [ "root" ]; + })) # This is ordered to show before (most) other rules, but # late-enough for a user to `lib.mkBefore` it. @@ -210,54 +250,70 @@ in })) ]; - security.sudo-rs.configFile = lib.concatStringsSep "\n" (lib.filter (s: s != "") [ - '' - # Don't edit this file. Set the NixOS options ‘security.sudo-rs.configFile’ - # or ‘security.sudo-rs.extraRules’ instead. - '' - (lib.pipe cfg.extraRules [ - (lib.filter (rule: lib.length rule.commands != 0)) - (map (rule: [ - (map (user: "${toUserString user} ${rule.host}=(${rule.runAs}) ${toCommandsString rule.commands}") rule.users) - (map (group: "${toGroupString group} ${rule.host}=(${rule.runAs}) ${toCommandsString rule.commands}") rule.groups) - ])) - lib.flatten - (lib.concatStringsSep "\n") - ]) - "\n" - (lib.optionalString (cfg.extraConfig != "") '' - # extraConfig - ${cfg.extraConfig} - '') - ]); - - security.wrappers = let - owner = "root"; - group = if cfg.execWheelOnly then "wheel" else "root"; - setuid = true; - permissions = if cfg.execWheelOnly then "u+rx,g+x" else "u+rx,g+x,o+x"; - in { - sudo = { - source = "${cfg.package.out}/bin/sudo"; - inherit owner group setuid permissions; + security.sudo-rs.configFile = lib.concatStringsSep "\n" ( + lib.filter (s: s != "") [ + '' + # Don't edit this file. Set the NixOS options ‘security.sudo-rs.configFile’ + # or ‘security.sudo-rs.extraRules’ instead. + '' + (lib.pipe cfg.extraRules [ + (lib.filter (rule: lib.length rule.commands != 0)) + (map (rule: [ + (map ( + user: "${toUserString user} ${rule.host}=(${rule.runAs}) ${toCommandsString rule.commands}" + ) rule.users) + (map ( + group: "${toGroupString group} ${rule.host}=(${rule.runAs}) ${toCommandsString rule.commands}" + ) rule.groups) + ])) + lib.flatten + (lib.concatStringsSep "\n") + ]) + "\n" + (lib.optionalString (cfg.extraConfig != "") '' + # extraConfig + ${cfg.extraConfig} + '') + ] + ); + + security.wrappers = + let + owner = "root"; + group = if cfg.execWheelOnly then "wheel" else "root"; + setuid = true; + permissions = if cfg.execWheelOnly then "u+rx,g+x" else "u+rx,g+x,o+x"; + in + { + sudo = { + source = "${cfg.package.out}/bin/sudo"; + inherit + owner + group + setuid + permissions + ; + }; }; - }; environment.systemPackages = [ cfg.package ]; - security.pam.services.sudo = { sshAgentAuth = true; usshAuth = true; }; - security.pam.services.sudo-i = { sshAgentAuth = true; usshAuth = true; }; + security.pam.services.sudo = { + sshAgentAuth = true; + usshAuth = true; + }; + security.pam.services.sudo-i = { + sshAgentAuth = true; + usshAuth = true; + }; - environment.etc.sudoers = - { source = - pkgs.runCommand "sudoers" - { - src = pkgs.writeText "sudoers-in" cfg.configFile; - preferLocalBuild = true; - } - "${pkgs.buildPackages.sudo-rs}/bin/visudo -f $src -c && cp $src $out"; - mode = "0440"; - }; + environment.etc.sudoers = { + source = pkgs.runCommand "sudoers" { + src = pkgs.writeText "sudoers-in" cfg.configFile; + preferLocalBuild = true; + } "${pkgs.buildPackages.sudo-rs}/bin/visudo -f $src -c && cp $src $out"; + mode = "0440"; + }; }; diff --git a/nixos/modules/security/sudo.nix b/nixos/modules/security/sudo.nix index 57d1e42ca80c9c..f68d31c5a577b7 100644 --- a/nixos/modules/security/sudo.nix +++ b/nixos/modules/security/sudo.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.security.sudo; @@ -6,12 +11,14 @@ let toUserString = user: if (lib.isInt user) then "#${toString user}" else "${user}"; toGroupString = group: if (lib.isInt group) then "%#${toString group}" else "%${group}"; - toCommandOptionsString = options: - "${lib.concatStringsSep ":" options}${lib.optionalString (lib.length options != 0) ":"} "; + toCommandOptionsString = + options: "${lib.concatStringsSep ":" options}${lib.optionalString (lib.length options != 0) ":"} "; - toCommandsString = commands: + toCommandsString = + commands: lib.concatStringsSep ", " ( - map (command: + map ( + command: if (lib.isString command) then command else @@ -40,9 +47,9 @@ in type = lib.types.bool; default = true; description = '' - Whether to enable the {command}`sudo` command, which - allows non-root users to execute commands as root. - ''; + Whether to enable the {command}`sudo` command, which + allows non-root users to execute commands as root. + ''; }; package = lib.mkPackageOption pkgs "sudo" { }; @@ -54,7 +61,7 @@ in Whether users of the `wheel` group must provide a password to run commands as super user via {command}`sudo`. ''; - }; + }; execWheelOnly = lib.mkOption { type = lib.types.bool; @@ -84,7 +91,7 @@ in yield the expected behavior. You can use mkBefore/mkAfter to ensure this is the case when configuration options are merged. ''; - default = []; + default = [ ]; example = lib.literalExpression '' [ # Allow execution of any command by all users in group sudo, @@ -104,73 +111,98 @@ in { command = '''/home/baz/cmd2.sh ""'''; options = [ "SETENV" ]; } ]; } ] ''; - type = with lib.types; listOf (submodule { - options = { - users = lib.mkOption { - type = with types; listOf (either str int); - description = '' - The usernames / UIDs this rule should apply for. - ''; - default = []; - }; - - groups = lib.mkOption { - type = with types; listOf (either str int); - description = '' - The groups / GIDs this rule should apply for. - ''; - default = []; + type = + with lib.types; + listOf (submodule { + options = { + users = lib.mkOption { + type = with types; listOf (either str int); + description = '' + The usernames / UIDs this rule should apply for. + ''; + default = [ ]; + }; + + groups = lib.mkOption { + type = with types; listOf (either str int); + description = '' + The groups / GIDs this rule should apply for. + ''; + default = [ ]; + }; + + host = lib.mkOption { + type = types.str; + default = "ALL"; + description = '' + For what host this rule should apply. + ''; + }; + + runAs = lib.mkOption { + type = with types; str; + default = "ALL:ALL"; + description = '' + Under which user/group the specified command is allowed to run. + + A user can be specified using just the username: `"foo"`. + It is also possible to specify a user/group combination using `"foo:bar"` + or to only allow running as a specific group with `":bar"`. + ''; + }; + + commands = lib.mkOption { + description = '' + The commands for which the rule should apply. + ''; + type = + with types; + listOf ( + either str (submodule { + + options = { + command = lib.mkOption { + type = with types; str; + description = '' + A command being either just a path to a binary to allow any arguments, + the full command with arguments pre-set or with `""` used as the argument, + not allowing arguments to the command at all. + ''; + }; + + options = lib.mkOption { + type = + with types; + listOf (enum [ + "NOPASSWD" + "PASSWD" + "NOEXEC" + "EXEC" + "SETENV" + "NOSETENV" + "LOG_INPUT" + "NOLOG_INPUT" + "LOG_OUTPUT" + "NOLOG_OUTPUT" + "MAIL" + "NOMAIL" + "FOLLOW" + "NOFLLOW" + "INTERCEPT" + "NOINTERCEPT" + ]); + description = '' + Options for running the command. Refer to the [sudo manual](https://www.sudo.ws/docs/man/1.9.15/sudoers.man/#Tag_Spec). + ''; + default = [ ]; + }; + }; + + }) + ); + }; }; - - host = lib.mkOption { - type = types.str; - default = "ALL"; - description = '' - For what host this rule should apply. - ''; - }; - - runAs = lib.mkOption { - type = with types; str; - default = "ALL:ALL"; - description = '' - Under which user/group the specified command is allowed to run. - - A user can be specified using just the username: `"foo"`. - It is also possible to specify a user/group combination using `"foo:bar"` - or to only allow running as a specific group with `":bar"`. - ''; - }; - - commands = lib.mkOption { - description = '' - The commands for which the rule should apply. - ''; - type = with types; listOf (either str (submodule { - - options = { - command = lib.mkOption { - type = with types; str; - description = '' - A command being either just a path to a binary to allow any arguments, - the full command with arguments pre-set or with `""` used as the argument, - not allowing arguments to the command at all. - ''; - }; - - options = lib.mkOption { - type = with types; listOf (enum [ "NOPASSWD" "PASSWD" "NOEXEC" "EXEC" "SETENV" "NOSETENV" "LOG_INPUT" "NOLOG_INPUT" "LOG_OUTPUT" "NOLOG_OUTPUT" "MAIL" "NOMAIL" "FOLLOW" "NOFLLOW" "INTERCEPT" "NOINTERCEPT"]); - description = '' - Options for running the command. Refer to the [sudo manual](https://www.sudo.ws/docs/man/1.9.15/sudoers.man/#Tag_Spec). - ''; - default = []; - }; - }; - - })); - }; - }; - }); + }); }; extraConfig = lib.mkOption { @@ -182,30 +214,44 @@ in }; }; - ###### implementation config = lib.mkIf cfg.enable { - assertions = [ { - assertion = cfg.package.pname != "sudo-rs"; - message = '' - NixOS' `sudo` module does not support `sudo-rs`; see `security.sudo-rs` instead. - ''; - } ]; + assertions = [ + { + assertion = cfg.package.pname != "sudo-rs"; + message = '' + NixOS' `sudo` module does not support `sudo-rs`; see `security.sudo-rs` instead. + ''; + } + ]; security.sudo.extraRules = let - defaultRule = { users ? [], groups ? [], opts ? [] }: [ { - inherit users groups; - commands = [ { - command = "ALL"; - options = opts ++ cfg.defaultOptions; - } ]; - } ]; - in lib.mkMerge [ + defaultRule = + { + users ? [ ], + groups ? [ ], + opts ? [ ], + }: + [ + { + inherit users groups; + commands = [ + { + command = "ALL"; + options = opts ++ cfg.defaultOptions; + } + ]; + } + ]; + in + lib.mkMerge [ # This is ordered before users' `mkBefore` rules, # so as not to introduce unexpected changes. - (lib.mkOrder 400 (defaultRule { users = [ "root" ]; })) + (lib.mkOrder 400 (defaultRule { + users = [ "root" ]; + })) # This is ordered to show before (most) other rules, but # late-enough for a user to `mkBefore` it. @@ -215,50 +261,71 @@ in })) ]; - security.sudo.configFile = lib.concatStringsSep "\n" (lib.filter (s: s != "") [ - '' - # Don't edit this file. Set the NixOS options ‘security.sudo.configFile’ - # or ‘security.sudo.extraRules’ instead. - '' - (lib.pipe cfg.extraRules [ - (lib.filter (rule: lib.length rule.commands != 0)) - (map (rule: [ - (map (user: "${toUserString user} ${rule.host}=(${rule.runAs}) ${toCommandsString rule.commands}") rule.users) - (map (group: "${toGroupString group} ${rule.host}=(${rule.runAs}) ${toCommandsString rule.commands}") rule.groups) - ])) - lib.flatten - (lib.concatStringsSep "\n") - ]) - "\n" - (lib.optionalString (cfg.extraConfig != "") '' - # extraConfig - ${cfg.extraConfig} - '') - ]); - - security.wrappers = let - owner = "root"; - group = if cfg.execWheelOnly then "wheel" else "root"; - setuid = true; - permissions = if cfg.execWheelOnly then "u+rx,g+x" else "u+rx,g+x,o+x"; - in { - sudo = { - source = "${cfg.package.out}/bin/sudo"; - inherit owner group setuid permissions; - }; - sudoedit = { - source = "${cfg.package.out}/bin/sudoedit"; - inherit owner group setuid permissions; + security.sudo.configFile = lib.concatStringsSep "\n" ( + lib.filter (s: s != "") [ + '' + # Don't edit this file. Set the NixOS options ‘security.sudo.configFile’ + # or ‘security.sudo.extraRules’ instead. + '' + (lib.pipe cfg.extraRules [ + (lib.filter (rule: lib.length rule.commands != 0)) + (map (rule: [ + (map ( + user: "${toUserString user} ${rule.host}=(${rule.runAs}) ${toCommandsString rule.commands}" + ) rule.users) + (map ( + group: "${toGroupString group} ${rule.host}=(${rule.runAs}) ${toCommandsString rule.commands}" + ) rule.groups) + ])) + lib.flatten + (lib.concatStringsSep "\n") + ]) + "\n" + (lib.optionalString (cfg.extraConfig != "") '' + # extraConfig + ${cfg.extraConfig} + '') + ] + ); + + security.wrappers = + let + owner = "root"; + group = if cfg.execWheelOnly then "wheel" else "root"; + setuid = true; + permissions = if cfg.execWheelOnly then "u+rx,g+x" else "u+rx,g+x,o+x"; + in + { + sudo = { + source = "${cfg.package.out}/bin/sudo"; + inherit + owner + group + setuid + permissions + ; + }; + sudoedit = { + source = "${cfg.package.out}/bin/sudoedit"; + inherit + owner + group + setuid + permissions + ; + }; }; - }; environment.systemPackages = [ cfg.package ]; - security.pam.services.sudo = { sshAgentAuth = true; usshAuth = true; }; + security.pam.services.sudo = { + sshAgentAuth = true; + usshAuth = true; + }; - environment.etc.sudoers = - { source = - pkgs.runCommand "sudoers" + environment.etc.sudoers = { + source = + pkgs.runCommand "sudoers" { src = pkgs.writeText "sudoers-in" cfg.configFile; preferLocalBuild = true; @@ -266,8 +333,8 @@ in # Make sure that the sudoers file is syntactically valid. # (currently disabled - NIXOS-66) "${pkgs.buildPackages.sudo}/sbin/visudo -f $src -c && cp $src $out"; - mode = "0440"; - }; + mode = "0440"; + }; }; diff --git a/nixos/modules/security/systemd-confinement.nix b/nixos/modules/security/systemd-confinement.nix index 041c900338864a..c3c0a1a4975d65 100644 --- a/nixos/modules/security/systemd-confinement.nix +++ b/nixos/modules/security/systemd-confinement.nix @@ -1,205 +1,260 @@ -{ config, pkgs, lib, utils, ... }: +{ + config, + pkgs, + lib, + utils, + ... +}: let toplevelConfig = config; inherit (lib) types; inherit (utils.systemdUtils.lib) mkPathSafeName; -in { +in +{ options.systemd.services = lib.mkOption { - type = types.attrsOf (types.submodule ({ name, config, ... }: { - options.confinement.enable = lib.mkOption { - type = types.bool; - default = false; - description = '' - If set, all the required runtime store paths for this service are - bind-mounted into a `tmpfs`-based - {manpage}`chroot(2)`. - ''; - }; - - options.confinement.fullUnit = lib.mkOption { - type = types.bool; - default = false; - description = '' - Whether to include the full closure of the systemd unit file into the - chroot, instead of just the dependencies for the executables. - - ::: {.warning} - While it may be tempting to just enable this option to - make things work quickly, please be aware that this might add paths - to the closure of the chroot that you didn't anticipate. It's better - to use {option}`confinement.packages` to **explicitly** add additional store paths to the - chroot. - ::: - ''; - }; - - options.confinement.packages = lib.mkOption { - type = types.listOf (types.either types.str types.package); - default = []; - description = let - mkScOption = optName: "{option}`serviceConfig.${optName}`"; - in '' - Additional packages or strings with context to add to the closure of - the chroot. By default, this includes all the packages from the - ${lib.concatMapStringsSep ", " mkScOption [ - "ExecReload" "ExecStartPost" "ExecStartPre" "ExecStop" - "ExecStopPost" - ]} and ${mkScOption "ExecStart"} options. If you want to have all the - dependencies of this systemd unit, you can use - {option}`confinement.fullUnit`. - - ::: {.note} - The store paths listed in {option}`path` are - **not** included in the closure as - well as paths from other options except those listed - above. - ::: - ''; - }; - - options.confinement.binSh = lib.mkOption { - type = types.nullOr types.path; - default = toplevelConfig.environment.binsh; - defaultText = lib.literalExpression "config.environment.binsh"; - example = lib.literalExpression ''"''${pkgs.dash}/bin/dash"''; - description = '' - The program to make available as {file}`/bin/sh` inside - the chroot. If this is set to `null`, no - {file}`/bin/sh` is provided at all. - - This is useful for some applications, which for example use the - {manpage}`system(3)` library function to execute commands. - ''; - }; - - options.confinement.mode = lib.mkOption { - type = types.enum [ "full-apivfs" "chroot-only" ]; - default = "full-apivfs"; - description = '' - The value `full-apivfs` (the default) sets up - private {file}`/dev`, {file}`/proc`, - {file}`/sys`, {file}`/tmp` and {file}`/var/tmp` file systems - in a separate user name space. - - If this is set to `chroot-only`, only the file - system name space is set up along with the call to - {manpage}`chroot(2)`. - - In all cases, unless `serviceConfig.PrivateTmp=true` is set, - both {file}`/tmp` and {file}`/var/tmp` paths are added to `InaccessiblePaths=`. - This is to overcome options like `DynamicUser=true` - implying `PrivateTmp=true` without letting it being turned off. - Beware however that giving processes the `CAP_SYS_ADMIN` and `@mount` privileges - can let them undo the effects of `InaccessiblePaths=`. - - ::: {.note} - This doesn't cover network namespaces and is solely for - file system level isolation. - ::: - ''; - }; - - config = let - inherit (config.confinement) binSh fullUnit; - wantsAPIVFS = lib.mkDefault (config.confinement.mode == "full-apivfs"); - in lib.mkIf config.confinement.enable { - serviceConfig = { - ReadOnlyPaths = [ "+/" ]; - RuntimeDirectory = [ "confinement/${mkPathSafeName name}" ]; - RootDirectory = "/run/confinement/${mkPathSafeName name}"; - InaccessiblePaths = [ - "-+/run/confinement/${mkPathSafeName name}" - ]; - PrivateMounts = lib.mkDefault true; - - # https://github.com/NixOS/nixpkgs/issues/14645 is a future attempt - # to change some of these to default to true. - # - # If we run in chroot-only mode, having something like PrivateDevices - # set to true by default will mount /dev within the chroot, whereas - # with "chroot-only" it's expected that there are no /dev, /proc and - # /sys file systems available. - # - # However, if this suddenly becomes true, the attack surface will - # increase, so let's explicitly set these options to true/false - # depending on the mode. - MountAPIVFS = wantsAPIVFS; - PrivateDevices = wantsAPIVFS; - PrivateTmp = wantsAPIVFS; - PrivateUsers = wantsAPIVFS; - ProtectControlGroups = wantsAPIVFS; - ProtectKernelModules = wantsAPIVFS; - ProtectKernelTunables = wantsAPIVFS; - }; - confinement.packages = let - execOpts = [ - "ExecReload" "ExecStart" "ExecStartPost" "ExecStartPre" "ExecStop" - "ExecStopPost" - ]; - execPkgs = lib.concatMap (opt: let - isSet = config.serviceConfig ? ${opt}; - in lib.flatten (lib.optional isSet config.serviceConfig.${opt})) execOpts; - unitAttrs = toplevelConfig.systemd.units."${name}.service"; - allPkgs = lib.singleton (builtins.toJSON unitAttrs); - unitPkgs = if fullUnit then allPkgs else execPkgs; - in unitPkgs ++ lib.optional (binSh != null) binSh; - }; - })); + type = types.attrsOf ( + types.submodule ( + { name, config, ... }: + { + options.confinement.enable = lib.mkOption { + type = types.bool; + default = false; + description = '' + If set, all the required runtime store paths for this service are + bind-mounted into a `tmpfs`-based + {manpage}`chroot(2)`. + ''; + }; + + options.confinement.fullUnit = lib.mkOption { + type = types.bool; + default = false; + description = '' + Whether to include the full closure of the systemd unit file into the + chroot, instead of just the dependencies for the executables. + + ::: {.warning} + While it may be tempting to just enable this option to + make things work quickly, please be aware that this might add paths + to the closure of the chroot that you didn't anticipate. It's better + to use {option}`confinement.packages` to **explicitly** add additional store paths to the + chroot. + ::: + ''; + }; + + options.confinement.packages = lib.mkOption { + type = types.listOf (types.either types.str types.package); + default = [ ]; + description = + let + mkScOption = optName: "{option}`serviceConfig.${optName}`"; + in + '' + Additional packages or strings with context to add to the closure of + the chroot. By default, this includes all the packages from the + ${ + lib.concatMapStringsSep ", " mkScOption [ + "ExecReload" + "ExecStartPost" + "ExecStartPre" + "ExecStop" + "ExecStopPost" + ] + } and ${mkScOption "ExecStart"} options. If you want to have all the + dependencies of this systemd unit, you can use + {option}`confinement.fullUnit`. + + ::: {.note} + The store paths listed in {option}`path` are + **not** included in the closure as + well as paths from other options except those listed + above. + ::: + ''; + }; + + options.confinement.binSh = lib.mkOption { + type = types.nullOr types.path; + default = toplevelConfig.environment.binsh; + defaultText = lib.literalExpression "config.environment.binsh"; + example = lib.literalExpression ''"''${pkgs.dash}/bin/dash"''; + description = '' + The program to make available as {file}`/bin/sh` inside + the chroot. If this is set to `null`, no + {file}`/bin/sh` is provided at all. + + This is useful for some applications, which for example use the + {manpage}`system(3)` library function to execute commands. + ''; + }; + + options.confinement.mode = lib.mkOption { + type = types.enum [ + "full-apivfs" + "chroot-only" + ]; + default = "full-apivfs"; + description = '' + The value `full-apivfs` (the default) sets up + private {file}`/dev`, {file}`/proc`, + {file}`/sys`, {file}`/tmp` and {file}`/var/tmp` file systems + in a separate user name space. + + If this is set to `chroot-only`, only the file + system name space is set up along with the call to + {manpage}`chroot(2)`. + + In all cases, unless `serviceConfig.PrivateTmp=true` is set, + both {file}`/tmp` and {file}`/var/tmp` paths are added to `InaccessiblePaths=`. + This is to overcome options like `DynamicUser=true` + implying `PrivateTmp=true` without letting it being turned off. + Beware however that giving processes the `CAP_SYS_ADMIN` and `@mount` privileges + can let them undo the effects of `InaccessiblePaths=`. + + ::: {.note} + This doesn't cover network namespaces and is solely for + file system level isolation. + ::: + ''; + }; + + config = + let + inherit (config.confinement) binSh fullUnit; + wantsAPIVFS = lib.mkDefault (config.confinement.mode == "full-apivfs"); + in + lib.mkIf config.confinement.enable { + serviceConfig = { + ReadOnlyPaths = [ "+/" ]; + RuntimeDirectory = [ "confinement/${mkPathSafeName name}" ]; + RootDirectory = "/run/confinement/${mkPathSafeName name}"; + InaccessiblePaths = [ + "-+/run/confinement/${mkPathSafeName name}" + ]; + PrivateMounts = lib.mkDefault true; + + # https://github.com/NixOS/nixpkgs/issues/14645 is a future attempt + # to change some of these to default to true. + # + # If we run in chroot-only mode, having something like PrivateDevices + # set to true by default will mount /dev within the chroot, whereas + # with "chroot-only" it's expected that there are no /dev, /proc and + # /sys file systems available. + # + # However, if this suddenly becomes true, the attack surface will + # increase, so let's explicitly set these options to true/false + # depending on the mode. + MountAPIVFS = wantsAPIVFS; + PrivateDevices = wantsAPIVFS; + PrivateTmp = wantsAPIVFS; + PrivateUsers = wantsAPIVFS; + ProtectControlGroups = wantsAPIVFS; + ProtectKernelModules = wantsAPIVFS; + ProtectKernelTunables = wantsAPIVFS; + }; + confinement.packages = + let + execOpts = [ + "ExecReload" + "ExecStart" + "ExecStartPost" + "ExecStartPre" + "ExecStop" + "ExecStopPost" + ]; + execPkgs = lib.concatMap ( + opt: + let + isSet = config.serviceConfig ? ${opt}; + in + lib.flatten (lib.optional isSet config.serviceConfig.${opt}) + ) execOpts; + unitAttrs = toplevelConfig.systemd.units."${name}.service"; + allPkgs = lib.singleton (builtins.toJSON unitAttrs); + unitPkgs = if fullUnit then allPkgs else execPkgs; + in + unitPkgs ++ lib.optional (binSh != null) binSh; + }; + } + ) + ); }; - config.assertions = lib.concatLists (lib.mapAttrsToList (name: cfg: let - whatOpt = optName: "The 'serviceConfig' option '${optName}' for" - + " service '${name}' is enabled in conjunction with" - + " 'confinement.enable'"; - in lib.optionals cfg.confinement.enable [ - { assertion = !cfg.serviceConfig.RootDirectoryStartOnly or false; - message = "${whatOpt "RootDirectoryStartOnly"}, but right now systemd" - + " doesn't support restricting bind-mounts to 'ExecStart'." - + " Please either define a separate service or find a way to run" - + " commands other than ExecStart within the chroot."; - } - ]) config.systemd.services); - - config.systemd.packages = lib.concatLists (lib.mapAttrsToList (name: cfg: let - rootPaths = let - contents = lib.concatStringsSep "\n" cfg.confinement.packages; - in pkgs.writeText "${mkPathSafeName name}-string-contexts.txt" contents; - - chrootPaths = pkgs.runCommand "${mkPathSafeName name}-chroot-paths" { - closureInfo = pkgs.closureInfo { inherit rootPaths; }; - serviceName = "${name}.service"; - excludedPath = rootPaths; - } '' - mkdir -p "$out/lib/systemd/system/$serviceName.d" - serviceFile="$out/lib/systemd/system/$serviceName.d/confinement.conf" - - echo '[Service]' > "$serviceFile" - - # /bin/sh is special here, because the option value could contain a - # symlink and we need to properly resolve it. - ${lib.optionalString (cfg.confinement.binSh != null) '' - binsh=${lib.escapeShellArg cfg.confinement.binSh} - realprog="$(readlink -e "$binsh")" - echo "BindReadOnlyPaths=$realprog:/bin/sh" >> "$serviceFile" - ''} - - # If DynamicUser= is enabled, PrivateTmp=true is implied (and cannot be turned off). - # so disable them unless PrivateTmp=true is explicitely set. - ${lib.optionalString (!cfg.serviceConfig.PrivateTmp) '' - echo "InaccessiblePaths=-+/tmp" >> "$serviceFile" - echo "InaccessiblePaths=-+/var/tmp" >> "$serviceFile" - ''} - - while read storePath; do - if [ -L "$storePath" ]; then - # Currently, systemd can't cope with symlinks in Bind(ReadOnly)Paths, - # so let's just bind-mount the target to that location. - echo "BindReadOnlyPaths=$(readlink -e "$storePath"):$storePath" - elif [ "$storePath" != "$excludedPath" ]; then - echo "BindReadOnlyPaths=$storePath" - fi - done < "$closureInfo/store-paths" >> "$serviceFile" - ''; - in lib.optional cfg.confinement.enable chrootPaths) config.systemd.services); + config.assertions = lib.concatLists ( + lib.mapAttrsToList ( + name: cfg: + let + whatOpt = + optName: + "The 'serviceConfig' option '${optName}' for" + + " service '${name}' is enabled in conjunction with" + + " 'confinement.enable'"; + in + lib.optionals cfg.confinement.enable [ + { + assertion = !cfg.serviceConfig.RootDirectoryStartOnly or false; + message = + "${whatOpt "RootDirectoryStartOnly"}, but right now systemd" + + " doesn't support restricting bind-mounts to 'ExecStart'." + + " Please either define a separate service or find a way to run" + + " commands other than ExecStart within the chroot."; + } + ] + ) config.systemd.services + ); + + config.systemd.packages = lib.concatLists ( + lib.mapAttrsToList ( + name: cfg: + let + rootPaths = + let + contents = lib.concatStringsSep "\n" cfg.confinement.packages; + in + pkgs.writeText "${mkPathSafeName name}-string-contexts.txt" contents; + + chrootPaths = + pkgs.runCommand "${mkPathSafeName name}-chroot-paths" + { + closureInfo = pkgs.closureInfo { inherit rootPaths; }; + serviceName = "${name}.service"; + excludedPath = rootPaths; + } + '' + mkdir -p "$out/lib/systemd/system/$serviceName.d" + serviceFile="$out/lib/systemd/system/$serviceName.d/confinement.conf" + + echo '[Service]' > "$serviceFile" + + # /bin/sh is special here, because the option value could contain a + # symlink and we need to properly resolve it. + ${lib.optionalString (cfg.confinement.binSh != null) '' + binsh=${lib.escapeShellArg cfg.confinement.binSh} + realprog="$(readlink -e "$binsh")" + echo "BindReadOnlyPaths=$realprog:/bin/sh" >> "$serviceFile" + ''} + + # If DynamicUser= is enabled, PrivateTmp=true is implied (and cannot be turned off). + # so disable them unless PrivateTmp=true is explicitely set. + ${lib.optionalString (!cfg.serviceConfig.PrivateTmp) '' + echo "InaccessiblePaths=-+/tmp" >> "$serviceFile" + echo "InaccessiblePaths=-+/var/tmp" >> "$serviceFile" + ''} + + while read storePath; do + if [ -L "$storePath" ]; then + # Currently, systemd can't cope with symlinks in Bind(ReadOnly)Paths, + # so let's just bind-mount the target to that location. + echo "BindReadOnlyPaths=$(readlink -e "$storePath"):$storePath" + elif [ "$storePath" != "$excludedPath" ]; then + echo "BindReadOnlyPaths=$storePath" + fi + done < "$closureInfo/store-paths" >> "$serviceFile" + ''; + in + lib.optional cfg.confinement.enable chrootPaths + ) config.systemd.services + ); } diff --git a/nixos/modules/security/tpm2.nix b/nixos/modules/security/tpm2.nix index bd3c8a5b0c4356..f60adb24cdbee3 100644 --- a/nixos/modules/security/tpm2.nix +++ b/nixos/modules/security/tpm2.nix @@ -1,4 +1,9 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: let cfg = config.security.tpm2; @@ -8,14 +13,15 @@ let # Therefore, if either of the two are null, the respective part isn't generated udevRules = tssUser: tssGroup: '' ${lib.optionalString (tssUser != null) ''KERNEL=="tpm[0-9]*", MODE="0660", OWNER="${tssUser}"''} - ${lib.optionalString (tssUser != null || tssGroup != null) - ''KERNEL=="tpmrm[0-9]*", MODE="0660"'' + ${ + lib.optionalString (tssUser != null || tssGroup != null) ''KERNEL=="tpmrm[0-9]*", MODE="0660"'' + lib.optionalString (tssUser != null) '', OWNER="${tssUser}"'' + lib.optionalString (tssGroup != null) '', GROUP="${tssGroup}"'' - } + } ''; -in { +in +{ options.security.tpm2 = { enable = lib.mkEnableOption "Trusted Platform Module 2 support"; @@ -91,7 +97,10 @@ in { The name of the TPM command transmission interface (TCTI) library to use. ''; - type = lib.types.enum [ "tabrmd" "device" ]; + type = lib.types.enum [ + "tabrmd" + "device" + ]; default = "device"; }; @@ -121,54 +130,60 @@ in { }; }; - config = lib.mkIf cfg.enable (lib.mkMerge [ - { - # PKCS11 tools and library - environment.systemPackages = lib.mkIf cfg.pkcs11.enable [ - (lib.getBin cfg.pkcs11.package) - (lib.getLib cfg.pkcs11.package) - ]; - - services.udev.extraRules = lib.mkIf cfg.applyUdevRules - (udevRules cfg.tssUser cfg.tssGroup); - - # Create the tss user and group only if the default value is used - users.users.${cfg.tssUser} = lib.mkIf (cfg.tssUser == "tss") { - isSystemUser = true; - group = "tss"; - }; - users.groups.${cfg.tssGroup} = lib.mkIf (cfg.tssGroup == "tss") {}; - - environment.variables = lib.mkIf cfg.tctiEnvironment.enable ( - lib.attrsets.genAttrs [ - "TPM2TOOLS_TCTI" - "TPM2_PKCS11_TCTI" - ] (_: ''${cfg.tctiEnvironment.interface}:${ - if cfg.tctiEnvironment.interface == "tabrmd" then - cfg.tctiEnvironment.tabrmdConf - else - cfg.tctiEnvironment.deviceConf - }'') - ); - } - - (lib.mkIf cfg.abrmd.enable { - systemd.services."tpm2-abrmd" = { - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - Type = "dbus"; - Restart = "always"; - RestartSec = 30; - BusName = "com.intel.tss2.Tabrmd"; - ExecStart = "${cfg.abrmd.package}/bin/tpm2-abrmd"; - User = "tss"; - Group = "tss"; + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + { + # PKCS11 tools and library + environment.systemPackages = lib.mkIf cfg.pkcs11.enable [ + (lib.getBin cfg.pkcs11.package) + (lib.getLib cfg.pkcs11.package) + ]; + + services.udev.extraRules = lib.mkIf cfg.applyUdevRules (udevRules cfg.tssUser cfg.tssGroup); + + # Create the tss user and group only if the default value is used + users.users.${cfg.tssUser} = lib.mkIf (cfg.tssUser == "tss") { + isSystemUser = true; + group = "tss"; + }; + users.groups.${cfg.tssGroup} = lib.mkIf (cfg.tssGroup == "tss") { }; + + environment.variables = lib.mkIf cfg.tctiEnvironment.enable ( + lib.attrsets.genAttrs + [ + "TPM2TOOLS_TCTI" + "TPM2_PKCS11_TCTI" + ] + ( + _: + ''${cfg.tctiEnvironment.interface}:${ + if cfg.tctiEnvironment.interface == "tabrmd" then + cfg.tctiEnvironment.tabrmdConf + else + cfg.tctiEnvironment.deviceConf + }'' + ) + ); + } + + (lib.mkIf cfg.abrmd.enable { + systemd.services."tpm2-abrmd" = { + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + Type = "dbus"; + Restart = "always"; + RestartSec = 30; + BusName = "com.intel.tss2.Tabrmd"; + ExecStart = "${cfg.abrmd.package}/bin/tpm2-abrmd"; + User = "tss"; + Group = "tss"; + }; }; - }; - services.dbus.packages = lib.singleton cfg.abrmd.package; - }) - ]); + services.dbus.packages = lib.singleton cfg.abrmd.package; + }) + ] + ); meta.maintainers = with lib.maintainers; [ lschuermann ]; } diff --git a/nixos/modules/security/wrappers/wrapper.nix b/nixos/modules/security/wrappers/wrapper.nix index ca4b27bff18018..13e328ffcc3785 100644 --- a/nixos/modules/security/wrappers/wrapper.nix +++ b/nixos/modules/security/wrappers/wrapper.nix @@ -1,17 +1,33 @@ -{ stdenv, unsecvars, linuxHeaders, sourceProg, debug ? false }: +{ + stdenv, + unsecvars, + linuxHeaders, + sourceProg, + debug ? false, +}: # For testing: # $ nix-build -E 'with import {}; pkgs.callPackage ./wrapper.nix { sourceProg = "${pkgs.hello}/bin/hello"; debug = true; }' stdenv.mkDerivation { name = "security-wrapper-${baseNameOf sourceProg}"; buildInputs = [ linuxHeaders ]; dontUnpack = true; - CFLAGS = [ - ''-DSOURCE_PROG="${sourceProg}"'' - ] ++ (if debug then [ - "-Werror" "-Og" "-g" - ] else [ - "-Wall" "-O2" - ]); + CFLAGS = + [ + ''-DSOURCE_PROG="${sourceProg}"'' + ] + ++ ( + if debug then + [ + "-Werror" + "-Og" + "-g" + ] + else + [ + "-Wall" + "-O2" + ] + ); dontStrip = debug; installPhase = '' mkdir -p $out/bin diff --git a/nixos/modules/services/admin/docuum.nix b/nixos/modules/services/admin/docuum.nix index 51a21740b276a7..a2516cf9eb94e4 100644 --- a/nixos/modules/services/admin/docuum.nix +++ b/nixos/modules/services/admin/docuum.nix @@ -1,8 +1,22 @@ -{ config, pkgs, lib, utils, ... }: +{ + config, + pkgs, + lib, + utils, + ... +}: let cfg = config.services.docuum; - inherit (lib) mkIf mkEnableOption mkOption getExe types optionals concatMap; + inherit (lib) + mkIf + mkEnableOption + mkOption + getExe + types + optionals + concatMap + ; in { options.services.docuum = { @@ -25,7 +39,7 @@ in keep = mkOption { description = "Prevents deletion of images for which repository:tag matches the specified regex."; type = types.listOf types.str; - default = []; + default = [ ]; example = [ "^my-image" ]; }; @@ -56,12 +70,22 @@ in DynamicUser = true; StateDirectory = "docuum"; SupplementaryGroups = [ "docker" ]; - ExecStart = utils.escapeSystemdExecArgs ([ - (getExe pkgs.docuum) - "--threshold" cfg.threshold - "--deletion-chunk-size" cfg.deletionChunkSize - ] ++ (concatMap (keep: [ "--keep" keep ]) cfg.keep) - ++ (optionals (cfg.minAge != null) [ "--min-age" cfg.minAge ]) + ExecStart = utils.escapeSystemdExecArgs ( + [ + (getExe pkgs.docuum) + "--threshold" + cfg.threshold + "--deletion-chunk-size" + cfg.deletionChunkSize + ] + ++ (concatMap (keep: [ + "--keep" + keep + ]) cfg.keep) + ++ (optionals (cfg.minAge != null) [ + "--min-age" + cfg.minAge + ]) ); }; }; diff --git a/nixos/modules/services/admin/meshcentral.nix b/nixos/modules/services/admin/meshcentral.nix index 6e0801e1c08946..6d8be447645d85 100644 --- a/nixos/modules/services/admin/meshcentral.nix +++ b/nixos/modules/services/admin/meshcentral.nix @@ -1,9 +1,16 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.meshcentral; - configFormat = pkgs.formats.json {}; + configFormat = pkgs.formats.json { }; configFile = configFormat.generate "meshcentral-config.json" cfg.settings; -in with lib; { +in +with lib; +{ options.services.meshcentral = with types; { enable = mkEnableOption "MeshCentral computer management server"; package = mkPackageOption pkgs "meshcentral" { }; @@ -31,9 +38,10 @@ in with lib; { }; }; config = mkIf cfg.enable { - services.meshcentral.settings.settings.autoBackup.backupPath = lib.mkDefault "/var/lib/meshcentral/backups"; + services.meshcentral.settings.settings.autoBackup.backupPath = + lib.mkDefault "/var/lib/meshcentral/backups"; systemd.services.meshcentral = { - wantedBy = ["multi-user.target"]; + wantedBy = [ "multi-user.target" ]; serviceConfig = { ExecStart = "${cfg.package}/bin/meshcentral --datapath /var/lib/meshcentral --configfile ${configFile}"; DynamicUser = true; diff --git a/nixos/modules/services/admin/oxidized.nix b/nixos/modules/services/admin/oxidized.nix index e209940674483b..ad151c57666c7e 100644 --- a/nixos/modules/services/admin/oxidized.nix +++ b/nixos/modules/services/admin/oxidized.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.oxidized; in @@ -105,7 +110,7 @@ in Group = cfg.group; UMask = "0077"; NoNewPrivileges = true; - Restart = "always"; + Restart = "always"; WorkingDirectory = cfg.dataDir; KillSignal = "SIGKILL"; PIDFile = "${cfg.dataDir}/.config/oxidized/pid"; diff --git a/nixos/modules/services/admin/pgadmin.nix b/nixos/modules/services/admin/pgadmin.nix index c9da556b763df3..79cc14b828ec5c 100644 --- a/nixos/modules/services/admin/pgadmin.nix +++ b/nixos/modules/services/admin/pgadmin.nix @@ -1,26 +1,65 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.pgadmin; - _base = with lib.types; [ int bool str ]; - base = with lib.types; oneOf ([ (listOf (oneOf _base)) (attrsOf (oneOf _base)) ] ++ _base); - - formatAttrset = attr: - "{${lib.concatStringsSep "\n" (lib.mapAttrsToList (key: value: "${builtins.toJSON key}: ${formatPyValue value},") attr)}}"; - - formatPyValue = value: - if builtins.isString value then builtins.toJSON value - else if value ? _expr then value._expr - else if builtins.isInt value then toString value - else if builtins.isBool value then (if value then "True" else "False") - else if builtins.isAttrs value then (formatAttrset value) - else if builtins.isList value then "[${lib.concatStringsSep "\n" (map (v: "${formatPyValue v},") value)}]" - else throw "Unrecognized type"; - - formatPy = attrs: - lib.concatStringsSep "\n" (lib.mapAttrsToList (key: value: "${key} = ${formatPyValue value}") attrs); - - pyType = with lib.types; attrsOf (oneOf [ (attrsOf base) (listOf base) base ]); + _base = with lib.types; [ + int + bool + str + ]; + base = + with lib.types; + oneOf ( + [ + (listOf (oneOf _base)) + (attrsOf (oneOf _base)) + ] + ++ _base + ); + + formatAttrset = + attr: + "{${ + lib.concatStringsSep "\n" ( + lib.mapAttrsToList (key: value: "${builtins.toJSON key}: ${formatPyValue value},") attr + ) + }}"; + + formatPyValue = + value: + if builtins.isString value then + builtins.toJSON value + else if value ? _expr then + value._expr + else if builtins.isInt value then + toString value + else if builtins.isBool value then + (if value then "True" else "False") + else if builtins.isAttrs value then + (formatAttrset value) + else if builtins.isList value then + "[${lib.concatStringsSep "\n" (map (v: "${formatPyValue v},") value)}]" + else + throw "Unrecognized type"; + + formatPy = + attrs: + lib.concatStringsSep "\n" ( + lib.mapAttrsToList (key: value: "${key} = ${formatPyValue value}") attrs + ); + + pyType = + with lib.types; + attrsOf (oneOf [ + (attrsOf base) + (listOf base) + base + ]); in { options.services.pgadmin = { @@ -118,21 +157,24 @@ in config = lib.mkIf (cfg.enable) { networking.firewall.allowedTCPPorts = lib.mkIf (cfg.openFirewall) [ cfg.port ]; - services.pgadmin.settings = { - DEFAULT_SERVER_PORT = cfg.port; - PASSWORD_LENGTH_MIN = cfg.minimumPasswordLength; - SERVER_MODE = true; - UPGRADE_CHECK_ENABLED = false; - } // (lib.optionalAttrs cfg.openFirewall { - DEFAULT_SERVER = lib.mkDefault "::"; - }) // (lib.optionalAttrs cfg.emailServer.enable { - MAIL_SERVER = cfg.emailServer.address; - MAIL_PORT = cfg.emailServer.port; - MAIL_USE_SSL = cfg.emailServer.useSSL; - MAIL_USE_TLS = cfg.emailServer.useTLS; - MAIL_USERNAME = cfg.emailServer.username; - SECURITY_EMAIL_SENDER = cfg.emailServer.sender; - }); + services.pgadmin.settings = + { + DEFAULT_SERVER_PORT = cfg.port; + PASSWORD_LENGTH_MIN = cfg.minimumPasswordLength; + SERVER_MODE = true; + UPGRADE_CHECK_ENABLED = false; + } + // (lib.optionalAttrs cfg.openFirewall { + DEFAULT_SERVER = lib.mkDefault "::"; + }) + // (lib.optionalAttrs cfg.emailServer.enable { + MAIL_SERVER = cfg.emailServer.address; + MAIL_PORT = cfg.emailServer.port; + MAIL_USE_SSL = cfg.emailServer.useSSL; + MAIL_USE_TLS = cfg.emailServer.useTLS; + MAIL_USERNAME = cfg.emailServer.username; + SECURITY_EMAIL_SENDER = cfg.emailServer.sender; + }); systemd.services.pgadmin = { wantedBy = [ "multi-user.target" ]; @@ -142,7 +184,11 @@ in # in case postgres doesn't start, pgadmin will just start normally wants = [ "postgresql.service" ]; - path = [ config.services.postgresql.package pkgs.coreutils pkgs.bash ]; + path = [ + config.services.postgresql.package + pkgs.coreutils + pkgs.bash + ]; preStart = '' # NOTE: this is idempotent (aka running it twice has no effect) @@ -179,8 +225,9 @@ in LogsDirectory = "pgadmin"; StateDirectory = "pgadmin"; ExecStart = "${cfg.package}/bin/pgadmin4"; - LoadCredential = [ "initial_password:${cfg.initialPasswordFile}" ] - ++ lib.optional cfg.emailServer.enable "email_password:${cfg.emailServer.passwordFile}"; + LoadCredential = [ + "initial_password:${cfg.initialPasswordFile}" + ] ++ lib.optional cfg.emailServer.enable "email_password:${cfg.emailServer.passwordFile}"; }; }; @@ -192,12 +239,14 @@ in users.groups.pgadmin = { }; environment.etc."pgadmin/config_system.py" = { - text = lib.optionalString cfg.emailServer.enable '' - import os - with open(os.path.join(os.environ['CREDENTIALS_DIRECTORY'], 'email_password')) as f: - pw = f.read() - MAIL_PASSWORD = pw - '' + formatPy cfg.settings; + text = + lib.optionalString cfg.emailServer.enable '' + import os + with open(os.path.join(os.environ['CREDENTIALS_DIRECTORY'], 'email_password')) as f: + pw = f.read() + MAIL_PASSWORD = pw + '' + + formatPy cfg.settings; mode = "0600"; user = "pgadmin"; group = "pgadmin"; diff --git a/nixos/modules/services/admin/salt/master.nix b/nixos/modules/services/admin/salt/master.nix index 1ffe6b6cb27aa9..9f9eac11eb7a45 100644 --- a/nixos/modules/services/admin/salt/master.nix +++ b/nixos/modules/services/admin/salt/master.nix @@ -1,7 +1,12 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let - cfg = config.services.salt.master; + cfg = config.services.salt.master; fullConfig = lib.recursiveUpdate { # Provide defaults for some directories to allow an immutable config dir @@ -20,7 +25,7 @@ in enable = lib.mkEnableOption "Salt configuration management system master service"; configuration = lib.mkOption { type = lib.types.attrs; - default = {}; + default = { }; description = "Salt master configuration as Nix attribute set."; }; }; @@ -32,9 +37,7 @@ in # The alternatives are # - passing --config-dir to all salt commands, not just the master unit, # - setting a global environment variable, - etc."salt/master".source = pkgs.writeText "master" ( - builtins.toJSON fullConfig - ); + etc."salt/master".source = pkgs.writeText "master" (builtins.toJSON fullConfig); systemPackages = with pkgs; [ salt ]; }; systemd.services.salt-master = { @@ -42,7 +45,7 @@ in wantedBy = [ "multi-user.target" ]; after = [ "network.target" ]; path = with pkgs; [ - util-linux # for dmesg + util-linux # for dmesg ]; serviceConfig = { ExecStart = "${pkgs.salt}/bin/salt-master"; diff --git a/nixos/modules/services/admin/salt/minion.nix b/nixos/modules/services/admin/salt/minion.nix index fde51a06769a9f..55a6bacad81458 100644 --- a/nixos/modules/services/admin/salt/minion.nix +++ b/nixos/modules/services/admin/salt/minion.nix @@ -1,7 +1,12 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let - cfg = config.services.salt.minion; + cfg = config.services.salt.minion; fullConfig = lib.recursiveUpdate { # Provide defaults for some directories to allow an immutable config dir @@ -21,7 +26,7 @@ in enable = lib.mkEnableOption "Salt configuration management system minion service"; configuration = lib.mkOption { type = lib.types.attrs; - default = {}; + default = { }; description = '' Salt minion configuration as Nix attribute set. See @@ -37,9 +42,7 @@ in # The alternatives are # - passing --config-dir to all salt commands, not just the minion unit, # - setting aglobal environment variable. - etc."salt/minion".source = pkgs.writeText "minion" ( - builtins.toJSON fullConfig - ); + etc."salt/minion".source = pkgs.writeText "minion" (builtins.toJSON fullConfig); systemPackages = with pkgs; [ salt ]; }; systemd.services.salt-minion = { @@ -61,4 +64,3 @@ in }; }; } - diff --git a/nixos/modules/services/amqp/activemq/default.nix b/nixos/modules/services/amqp/activemq/default.nix index 53814d71a5ac4c..c59cd65fab5c0a 100644 --- a/nixos/modules/services/amqp/activemq/default.nix +++ b/nixos/modules/services/amqp/activemq/default.nix @@ -1,18 +1,25 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.activemq; - activemqBroker = pkgs.runCommand "activemq-broker" - { - nativeBuildInputs = [ pkgs.jdk ]; - } '' - mkdir -p $out/lib - source ${pkgs.activemq}/lib/classpath.env - export CLASSPATH - ln -s "${./ActiveMQBroker.java}" ActiveMQBroker.java - javac -d $out/lib ActiveMQBroker.java - ''; + activemqBroker = + pkgs.runCommand "activemq-broker" + { + nativeBuildInputs = [ pkgs.jdk ]; + } + '' + mkdir -p $out/lib + source ${pkgs.activemq}/lib/classpath.env + export CLASSPATH + ln -s "${./ActiveMQBroker.java}" ActiveMQBroker.java + javac -d $out/lib ActiveMQBroker.java + ''; in { @@ -65,12 +72,15 @@ in "java.net.preferIPv4Stack" = "true"; } ''; - apply = attrs: { - "activemq.base" = "${cfg.baseDir}"; - "activemq.data" = "${cfg.baseDir}/data"; - "activemq.conf" = "${cfg.configurationDir}"; - "activemq.home" = "${pkgs.activemq}"; - } // attrs; + apply = + attrs: + { + "activemq.base" = "${cfg.baseDir}"; + "activemq.data" = "${cfg.baseDir}/data"; + "activemq.conf" = "${cfg.configurationDir}"; + "activemq.home" = "${pkgs.activemq}"; + } + // attrs; description = '' Specifies Java properties that are sent to the ActiveMQ broker service with the "-D" option. You can set properties @@ -120,7 +130,11 @@ in source ${pkgs.activemq}/lib/classpath.env export CLASSPATH=${activemqBroker}/lib:${cfg.configurationDir}:$CLASSPATH exec java \ - ${lib.concatStringsSep " \\\n" (lib.mapAttrsToList (name: value: "-D${name}=${value}") cfg.javaProperties)} \ + ${ + lib.concatStringsSep " \\\n" ( + lib.mapAttrsToList (name: value: "-D${name}=${value}") cfg.javaProperties + ) + } \ ${cfg.extraJavaOptions} ActiveMQBroker "${cfg.configurationURI}" ''; }; diff --git a/nixos/modules/services/amqp/rabbitmq.nix b/nixos/modules/services/amqp/rabbitmq.nix index fba26591e0baef..39ff594c9f0880 100644 --- a/nixos/modules/services/amqp/rabbitmq.nix +++ b/nixos/modules/services/amqp/rabbitmq.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.rabbitmq; @@ -152,7 +157,6 @@ in }; }; - ###### implementation config = lib.mkIf cfg.enable { @@ -171,12 +175,14 @@ in users.groups.rabbitmq.gid = config.ids.gids.rabbitmq; - services.rabbitmq.configItems = { - "listeners.tcp.1" = lib.mkDefault "${cfg.listenAddress}:${toString cfg.port}"; - } // lib.optionalAttrs cfg.managementPlugin.enable { - "management.tcp.port" = toString cfg.managementPlugin.port; - "management.tcp.ip" = cfg.listenAddress; - }; + services.rabbitmq.configItems = + { + "listeners.tcp.1" = lib.mkDefault "${cfg.listenAddress}:${toString cfg.port}"; + } + // lib.optionalAttrs cfg.managementPlugin.enable { + "management.tcp.port" = toString cfg.managementPlugin.port; + "management.tcp.ip" = cfg.listenAddress; + }; services.rabbitmq.plugins = lib.optional cfg.managementPlugin.enable "rabbitmq_management"; @@ -184,8 +190,14 @@ in description = "RabbitMQ Server"; wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "epmd.socket" ]; - wants = [ "network.target" "epmd.socket" ]; + after = [ + "network.target" + "epmd.socket" + ]; + wants = [ + "network.target" + "epmd.socket" + ]; path = [ cfg.package diff --git a/nixos/modules/services/audio/botamusique.nix b/nixos/modules/services/audio/botamusique.nix index 88ab232efae597..0ee641dd0df05c 100644 --- a/nixos/modules/services/audio/botamusique.nix +++ b/nixos/modules/services/audio/botamusique.nix @@ -1,8 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.botamusique; - format = pkgs.formats.ini {}; + format = pkgs.formats.ini { }; configFile = format.generate "botamusique.ini" cfg.settings; in { @@ -14,36 +19,38 @@ in package = lib.mkPackageOption pkgs "botamusique" { }; settings = lib.mkOption { - type = with lib.types; submodule { - freeformType = format.type; - options = { - server.host = lib.mkOption { - type = types.str; - default = "localhost"; - example = "mumble.example.com"; - description = "Hostname of the mumble server to connect to."; - }; + type = + with lib.types; + submodule { + freeformType = format.type; + options = { + server.host = lib.mkOption { + type = types.str; + default = "localhost"; + example = "mumble.example.com"; + description = "Hostname of the mumble server to connect to."; + }; - server.port = lib.mkOption { - type = types.port; - default = 64738; - description = "Port of the mumble server to connect to."; - }; + server.port = lib.mkOption { + type = types.port; + default = 64738; + description = "Port of the mumble server to connect to."; + }; - bot.username = lib.mkOption { - type = types.str; - default = "botamusique"; - description = "Name the bot should appear with."; - }; + bot.username = lib.mkOption { + type = types.str; + default = "botamusique"; + description = "Name the bot should appear with."; + }; - bot.comment = lib.mkOption { - type = types.str; - default = "Hi, I'm here to play radio, local music or youtube/soundcloud music. Have fun!"; - description = "Comment displayed for the bot."; + bot.comment = lib.mkOption { + type = types.str; + default = "Hi, I'm here to play radio, local music or youtube/soundcloud music. Have fun!"; + description = "Comment displayed for the bot."; + }; }; }; - }; - default = {}; + default = { }; description = '' Your {file}`configuration.ini` as a Nix attribute set. Look up possible options in the [configuration.example.ini](https://github.com/azlux/botamusique/blob/master/configuration.example.ini). diff --git a/nixos/modules/services/audio/gmediarender.nix b/nixos/modules/services/audio/gmediarender.nix index ee16400d48d4a4..ce4223880086b7 100644 --- a/nixos/modules/services/audio/gmediarender.nix +++ b/nixos/modules/services/audio/gmediarender.nix @@ -1,4 +1,10 @@ -{ pkgs, lib, config, utils, ... }: +{ + pkgs, + lib, + config, + utils, + ... +}: let cfg = config.services.gmediarender; in @@ -74,13 +80,19 @@ in Group = "gmediarender"; SupplementaryGroups = [ "audio" ]; ExecStart = - "${cfg.package}/bin/gmediarender " + - lib.optionalString (cfg.audioDevice != null) ("--gstout-audiodevice=${utils.escapeSystemdExecArg cfg.audioDevice} ") + - lib.optionalString (cfg.audioSink != null) ("--gstout-audiosink=${utils.escapeSystemdExecArg cfg.audioSink} ") + - lib.optionalString (cfg.friendlyName != null) ("--friendly-name=${utils.escapeSystemdExecArg cfg.friendlyName} ") + - lib.optionalString (cfg.initialVolume != 0) ("--initial-volume=${toString cfg.initialVolume} ") + - lib.optionalString (cfg.port != null) ("--port=${toString cfg.port} ") + - lib.optionalString (cfg.uuid != null) ("--uuid=${utils.escapeSystemdExecArg cfg.uuid} "); + "${cfg.package}/bin/gmediarender " + + lib.optionalString (cfg.audioDevice != null) ( + "--gstout-audiodevice=${utils.escapeSystemdExecArg cfg.audioDevice} " + ) + + lib.optionalString (cfg.audioSink != null) ( + "--gstout-audiosink=${utils.escapeSystemdExecArg cfg.audioSink} " + ) + + lib.optionalString (cfg.friendlyName != null) ( + "--friendly-name=${utils.escapeSystemdExecArg cfg.friendlyName} " + ) + + lib.optionalString (cfg.initialVolume != 0) ("--initial-volume=${toString cfg.initialVolume} ") + + lib.optionalString (cfg.port != null) ("--port=${toString cfg.port} ") + + lib.optionalString (cfg.uuid != null) ("--uuid=${utils.escapeSystemdExecArg cfg.uuid} "); Restart = "always"; RuntimeDirectory = "gmediarender"; @@ -105,8 +117,11 @@ in RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" ]; - UMask = 066; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; + UMask = 66; }; }; }; diff --git a/nixos/modules/services/audio/goxlr-utility.nix b/nixos/modules/services/audio/goxlr-utility.nix index bd8f285d673930..f277c343e661d0 100644 --- a/nixos/modules/services/audio/goxlr-utility.nix +++ b/nixos/modules/services/audio/goxlr-utility.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.goxlr-utility; in @@ -45,11 +50,10 @@ in services.udev.packages = [ cfg.package ]; xdg.autostart.enable = lib.mkIf cfg.autoStart.xdg true; - environment.systemPackages = lib.mkIf cfg.autoStart.xdg - [ - cfg.package - goxlr-autostart - ]; + environment.systemPackages = lib.mkIf cfg.autoStart.xdg [ + cfg.package + goxlr-autostart + ]; }; meta.maintainers = with lib.maintainers; [ errnoh ]; diff --git a/nixos/modules/services/audio/hqplayerd.nix b/nixos/modules/services/audio/hqplayerd.nix index 85e633b64457b9..9eb09e86bb76d5 100644 --- a/nixos/modules/services/audio/hqplayerd.nix +++ b/nixos/modules/services/audio/hqplayerd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hqplayerd; pkg = pkgs.hqplayerd; @@ -69,22 +74,28 @@ in config = lib.mkIf cfg.enable { assertions = [ { - assertion = (cfg.auth.username != null -> cfg.auth.password != null) - && (cfg.auth.password != null -> cfg.auth.username != null); + assertion = + (cfg.auth.username != null -> cfg.auth.password != null) + && (cfg.auth.password != null -> cfg.auth.username != null); message = "You must set either both services.hqplayer.auth.username and password, or neither."; } ]; environment = { etc = { - "hqplayer/hqplayerd.xml" = lib.mkIf (cfg.config != null) { source = pkgs.writeText "hqplayerd.xml" cfg.config; }; + "hqplayer/hqplayerd.xml" = lib.mkIf (cfg.config != null) { + source = pkgs.writeText "hqplayerd.xml" cfg.config; + }; "hqplayer/hqplayerd4-key.xml" = lib.mkIf (cfg.licenseFile != null) { source = cfg.licenseFile; }; }; systemPackages = [ pkg ]; }; networking.firewall = lib.mkIf cfg.openFirewall { - allowedTCPPorts = [ 8088 4321 ]; + allowedTCPPorts = [ + 8088 + 4321 + ]; }; systemd = { @@ -102,21 +113,28 @@ in environment.HOME = "${stateDir}/home"; - unitConfig.ConditionPathExists = [ configDir stateDir ]; - - restartTriggers = lib.optionals (cfg.config != null) [ config.environment.etc."hqplayer/hqplayerd.xml".source ]; - - preStart = '' - cp -r "${pkg}/var/lib/hqplayer/web" "${stateDir}" - chmod -R u+wX "${stateDir}/web" - - if [ ! -f "${configDir}/hqplayerd.xml" ]; then - echo "creating initial config file" - install -m 0644 "${pkg}/etc/hqplayer/hqplayerd.xml" "${configDir}/hqplayerd.xml" - fi - '' + lib.optionalString (cfg.auth.username != null && cfg.auth.password != null) '' - ${pkg}/bin/hqplayerd -s ${cfg.auth.username} ${cfg.auth.password} - ''; + unitConfig.ConditionPathExists = [ + configDir + stateDir + ]; + + restartTriggers = lib.optionals (cfg.config != null) [ + config.environment.etc."hqplayer/hqplayerd.xml".source + ]; + + preStart = + '' + cp -r "${pkg}/var/lib/hqplayer/web" "${stateDir}" + chmod -R u+wX "${stateDir}/web" + + if [ ! -f "${configDir}/hqplayerd.xml" ]; then + echo "creating initial config file" + install -m 0644 "${pkg}/etc/hqplayer/hqplayerd.xml" "${configDir}/hqplayerd.xml" + fi + '' + + lib.optionalString (cfg.auth.username != null && cfg.auth.password != null) '' + ${pkg}/bin/hqplayerd -s ${cfg.auth.username} ${cfg.auth.password} + ''; }; }; @@ -127,7 +145,10 @@ in users.users = { hqplayer = { description = "hqplayer daemon user"; - extraGroups = [ "audio" "video" ]; + extraGroups = [ + "audio" + "video" + ]; group = "hqplayer"; uid = config.ids.uids.hqplayer; }; diff --git a/nixos/modules/services/audio/icecast.nix b/nixos/modules/services/audio/icecast.nix index 820674c4341dcf..930b6af004a259 100644 --- a/nixos/modules/services/audio/icecast.nix +++ b/nixos/modules/services/audio/icecast.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.icecast; configFile = pkgs.writeText "icecast.xml" '' @@ -33,7 +38,8 @@ let ${cfg.extraConf} ''; -in { +in +{ ###### interface @@ -105,7 +111,6 @@ in { }; - ###### implementation config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/audio/jack.nix b/nixos/modules/services/audio/jack.nix index c71b8ff13fa6b5..476bd40c10e18e 100644 --- a/nixos/modules/services/audio/jack.nix +++ b/nixos/modules/services/audio/jack.nix @@ -1,15 +1,22 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.jack; pcmPlugin = cfg.jackd.enable && cfg.alsa.enable; loopback = cfg.jackd.enable && cfg.loopback.enable; - enable32BitAlsaPlugins = cfg.alsa.support32Bit && pkgs.stdenv.hostPlatform.isx86_64 && pkgs.pkgsi686Linux.alsa-lib != null; + enable32BitAlsaPlugins = + cfg.alsa.support32Bit && pkgs.stdenv.hostPlatform.isx86_64 && pkgs.pkgsi686Linux.alsa-lib != null; umaskNeeded = lib.versionOlder cfg.jackd.package.version "1.9.12"; bridgeNeeded = lib.versionAtLeast cfg.jackd.package.version "1.9.12"; -in { +in +{ options = { services.jack = { jackd = { @@ -17,12 +24,14 @@ in { JACK Audio Connection Kit. You need to add yourself to the "jackaudio" group ''; - package = lib.mkPackageOption pkgs "jack2" { - example = "jack1"; - } // { - # until jack1 promiscuous mode is fixed - internal = true; - }; + package = + lib.mkPackageOption pkgs "jack2" { + example = "jack1"; + } + // { + # until jack1 promiscuous mode is fixed + internal = true; + }; extraOptions = lib.mkOption { type = lib.types.listOf lib.types.str; @@ -122,8 +131,7 @@ in { environment.etc."alsa/conf.d/98-jack.conf".text = '' pcm_type.jack { libs.native = ${pkgs.alsa-plugins}/lib/alsa-lib/libasound_module_pcm_jack.so ; - ${lib.optionalString enable32BitAlsaPlugins - "libs.32Bit = ${pkgs.pkgsi686Linux.alsa-plugins}/lib/alsa-lib/libasound_module_pcm_jack.so ;"} + ${lib.optionalString enable32BitAlsaPlugins "libs.32Bit = ${pkgs.pkgsi686Linux.alsa-plugins}/lib/alsa-lib/libasound_module_pcm_jack.so ;"} } pcm.!default { @func getenv @@ -219,10 +227,20 @@ in { }; # https://jackaudio.org/faq/linux_rt_config.html security.pam.loginLimits = [ - { domain = "@jackaudio"; type = "-"; item = "rtprio"; value = "99"; } - { domain = "@jackaudio"; type = "-"; item = "memlock"; value = "unlimited"; } + { + domain = "@jackaudio"; + type = "-"; + item = "rtprio"; + value = "99"; + } + { + domain = "@jackaudio"; + type = "-"; + item = "memlock"; + value = "unlimited"; + } ]; - users.groups.jackaudio = {}; + users.groups.jackaudio = { }; environment = { systemPackages = [ cfg.jackd.package ]; @@ -236,17 +254,19 @@ in { systemd.services.jack = { description = "JACK Audio Connection Kit"; - serviceConfig = { - User = "jackaudio"; - SupplementaryGroups = lib.optional - (config.hardware.pulseaudio.enable - && !config.hardware.pulseaudio.systemWide) "users"; - ExecStart = "${cfg.jackd.package}/bin/jackd ${lib.escapeShellArgs cfg.jackd.extraOptions}"; - LimitRTPRIO = 99; - LimitMEMLOCK = "infinity"; - } // lib.optionalAttrs umaskNeeded { - UMask = "007"; - }; + serviceConfig = + { + User = "jackaudio"; + SupplementaryGroups = lib.optional ( + config.hardware.pulseaudio.enable && !config.hardware.pulseaudio.systemWide + ) "users"; + ExecStart = "${cfg.jackd.package}/bin/jackd ${lib.escapeShellArgs cfg.jackd.extraOptions}"; + LimitRTPRIO = 99; + LimitMEMLOCK = "infinity"; + } + // lib.optionalAttrs umaskNeeded { + UMask = "007"; + }; path = [ cfg.jackd.package ]; environment = { JACK_PROMISCUOUS_SERVER = "jackaudio"; diff --git a/nixos/modules/services/audio/jmusicbot.nix b/nixos/modules/services/audio/jmusicbot.nix index 6cd348e68e4543..e8aae5484aa696 100644 --- a/nixos/modules/services/audio/jmusicbot.nix +++ b/nixos/modules/services/audio/jmusicbot.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.jmusicbot; in @@ -27,14 +32,16 @@ in wants = [ "network-online.target" ]; after = [ "network-online.target" ]; description = "Discord music bot that's easy to set up and run yourself!"; - serviceConfig = lib.mkMerge [{ - ExecStart = "${cfg.package}/bin/JMusicBot"; - WorkingDirectory = cfg.stateDir; - Restart = "always"; - RestartSec = 20; - DynamicUser = true; - } - (lib.mkIf (cfg.stateDir == "/var/lib/jmusicbot") { StateDirectory = "jmusicbot"; })]; + serviceConfig = lib.mkMerge [ + { + ExecStart = "${cfg.package}/bin/JMusicBot"; + WorkingDirectory = cfg.stateDir; + Restart = "always"; + RestartSec = 20; + DynamicUser = true; + } + (lib.mkIf (cfg.stateDir == "/var/lib/jmusicbot") { StateDirectory = "jmusicbot"; }) + ]; }; }; diff --git a/nixos/modules/services/audio/liquidsoap.nix b/nixos/modules/services/audio/liquidsoap.nix index ece282f0568ff3..5a070a9b2116b9 100644 --- a/nixos/modules/services/audio/liquidsoap.nix +++ b/nixos/modules/services/audio/liquidsoap.nix @@ -1,13 +1,24 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let streams = builtins.attrNames config.services.liquidsoap.streams; streamService = name: - let stream = builtins.getAttr name config.services.liquidsoap.streams; in - { inherit name; + let + stream = builtins.getAttr name config.services.liquidsoap.streams; + in + { + inherit name; value = { - after = [ "network-online.target" "sound.target" ]; + after = [ + "network-online.target" + "sound.target" + ]; description = "${name} liquidsoap stream"; wantedBy = [ "multi-user.target" ]; path = [ pkgs.wget ]; @@ -29,11 +40,11 @@ in services.liquidsoap.streams = lib.mkOption { description = '' - Set of Liquidsoap streams to start, - one systemd service per stream. - ''; + Set of Liquidsoap streams to start, + one systemd service per stream. + ''; - default = {}; + default = { }; example = lib.literalExpression '' { @@ -62,7 +73,7 @@ in users.groups.liquidsoap.gid = config.ids.gids.liquidsoap; - systemd.services = builtins.listToAttrs ( map streamService streams ); + systemd.services = builtins.listToAttrs (map streamService streams); }; } diff --git a/nixos/modules/services/audio/mopidy.nix b/nixos/modules/services/audio/mopidy.nix index 235a5a896e05b1..51065c0bf0bfe8 100644 --- a/nixos/modules/services/audio/mopidy.nix +++ b/nixos/modules/services/audio/mopidy.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let uid = config.ids.uids.mopidy; gid = config.ids.gids.mopidy; @@ -17,7 +22,8 @@ let --prefix PYTHONPATH : $out/${pkgs.mopidyPackages.python.sitePackages} ''; }; -in { +in +{ options = { @@ -34,7 +40,7 @@ in { }; extensionPackages = lib.mkOption { - default = []; + default = [ ]; type = lib.types.listOf lib.types.package; example = lib.literalExpression "[ pkgs.mopidy-spotify ]"; description = '' @@ -51,7 +57,7 @@ in { }; extraConfigFiles = lib.mkOption { - default = []; + default = [ ]; type = lib.types.listOf lib.types.str; description = '' Extra config file read by Mopidy when the service starts. @@ -72,11 +78,16 @@ in { systemd.services.mopidy = { wantedBy = [ "multi-user.target" ]; - after = [ "network-online.target" "sound.target" ]; + after = [ + "network-online.target" + "sound.target" + ]; wants = [ "network-online.target" ]; description = "mopidy music player daemon"; serviceConfig = { - ExecStart = "${mopidyEnv}/bin/mopidy --config ${lib.concatStringsSep ":" ([mopidyConf] ++ cfg.extraConfigFiles)}"; + ExecStart = "${mopidyEnv}/bin/mopidy --config ${ + lib.concatStringsSep ":" ([ mopidyConf ] ++ cfg.extraConfigFiles) + }"; Restart = "on-failure"; User = "mopidy"; }; @@ -85,7 +96,9 @@ in { systemd.services.mopidy-scan = { description = "mopidy local files scanner"; serviceConfig = { - ExecStart = "${mopidyEnv}/bin/mopidy --config ${lib.concatStringsSep ":" ([mopidyConf] ++ cfg.extraConfigFiles)} local scan"; + ExecStart = "${mopidyEnv}/bin/mopidy --config ${ + lib.concatStringsSep ":" ([ mopidyConf ] ++ cfg.extraConfigFiles) + } local scan"; User = "mopidy"; Type = "oneshot"; }; diff --git a/nixos/modules/services/audio/mpdscribble.nix b/nixos/modules/services/audio/mpdscribble.nix index 9e1f2c50a924eb..967853ffc85c06 100644 --- a/nixos/modules/services/audio/mpdscribble.nix +++ b/nixos/modules/services/audio/mpdscribble.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.mpdscribble; mpdCfg = config.services.mpd; @@ -55,21 +61,26 @@ let cfgFile = "/run/mpdscribble/mpdscribble.conf"; - replaceSecret = secretFile: placeholder: targetFile: - lib.optionalString (secretFile != null) '' - ${pkgs.replace-secret}/bin/replace-secret '${placeholder}' '${secretFile}' '${targetFile}' ''; + replaceSecret = + secretFile: placeholder: targetFile: + lib.optionalString ( + secretFile != null + ) ''${pkgs.replace-secret}/bin/replace-secret '${placeholder}' '${secretFile}' '${targetFile}' ''; preStart = pkgs.writeShellScript "mpdscribble-pre-start" '' cp -f "${cfgTemplate}" "${cfgFile}" ${replaceSecret cfg.passwordFile "{{MPD_PASSWORD}}" cfgFile} - ${lib.concatStringsSep "\n" (lib.mapAttrsToList (secname: cfg: - replaceSecret cfg.passwordFile "{{${secname}_PASSWORD}}" cfgFile) - cfg.endpoints)} + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList ( + secname: cfg: replaceSecret cfg.passwordFile "{{${secname}_PASSWORD}}" cfgFile + ) cfg.endpoints + )} ''; localMpd = (cfg.host == "localhost" || cfg.host == "127.0.0.1"); -in { +in +{ ###### interface options.services.mpdscribble = { @@ -102,10 +113,9 @@ in { }; host = lib.mkOption { - default = (if mpdCfg.network.listenAddress != "any" then - mpdCfg.network.listenAddress - else - "localhost"); + default = ( + if mpdCfg.network.listenAddress != "any" then mpdCfg.network.listenAddress else "localhost" + ); defaultText = lib.literalExpression '' if config.${mpdOpt.network.listenAddress} != "any" then config.${mpdOpt.network.listenAddress} @@ -118,13 +128,13 @@ in { }; passwordFile = lib.mkOption { - default = if localMpd then - (lib.findFirst - (c: lib.any (x: x == "read") c.permissions) - { passwordFile = null; } - mpdCfg.credentials).passwordFile - else - null; + default = + if localMpd then + (lib.findFirst (c: lib.any (x: x == "read") c.permissions) { + passwordFile = null; + } mpdCfg.credentials).passwordFile + else + null; defaultText = lib.literalMD '' The first password file with read access configured for MPD when using a local instance, otherwise `null`. @@ -147,27 +157,32 @@ in { }; endpoints = lib.mkOption { - type = (let - endpoint = { name, ... }: { - options = { - url = lib.mkOption { - type = lib.types.str; - default = endpointUrls.${name} or ""; - description = "The url endpoint where the scrobble API is listening."; + type = ( + let + endpoint = + { name, ... }: + { + options = { + url = lib.mkOption { + type = lib.types.str; + default = endpointUrls.${name} or ""; + description = "The url endpoint where the scrobble API is listening."; + }; + username = lib.mkOption { + type = lib.types.str; + description = '' + Username for the scrobble service. + ''; + }; + passwordFile = lib.mkOption { + type = lib.types.nullOr lib.types.str; + description = "File containing the password, either as MD5SUM or cleartext."; + }; + }; }; - username = lib.mkOption { - type = lib.types.str; - description = '' - Username for the scrobble service. - ''; - }; - passwordFile = lib.mkOption { - type = lib.types.nullOr lib.types.str; - description = "File containing the password, either as MD5SUM or cleartext."; - }; - }; - }; - in lib.types.attrsOf (lib.types.submodule endpoint)); + in + lib.types.attrsOf (lib.types.submodule endpoint) + ); default = { }; example = { "last.fm" = { @@ -177,9 +192,7 @@ in { }; description = '' Endpoints to scrobble to. - If the endpoint is one of "${ - lib.concatStringsSep "\", \"" (lib.attrNames endpointUrls) - }" the url is set automatically. + If the endpoint is one of "${lib.concatStringsSep "\", \"" (lib.attrNames endpointUrls)}" the url is set automatically. ''; }; @@ -199,8 +212,7 @@ in { RuntimeDirectoryMode = "700"; # TODO use LoadCredential= instead of running preStart with full privileges? ExecStartPre = "+${preStart}"; - ExecStart = - "${pkgs.mpdscribble}/bin/mpdscribble --no-daemon --conf ${cfgFile}"; + ExecStart = "${pkgs.mpdscribble}/bin/mpdscribble --no-daemon --conf ${cfgFile}"; }; }; }; diff --git a/nixos/modules/services/audio/music-assistant.nix b/nixos/modules/services/audio/music-assistant.nix index 90c0b41fc587fb..aaabe5c3ac4c33 100644 --- a/nixos/modules/services/audio/music-assistant.nix +++ b/nixos/modules/services/audio/music-assistant.nix @@ -13,13 +13,13 @@ let mkOption mkPackageOption types - ; + ; inherit (types) listOf enum str - ; + ; cfg = config.services.music-assistant; @@ -38,7 +38,10 @@ in extraOptions = mkOption { type = listOf str; - default = [ "--config" "/var/lib/music-assistant" ]; + default = [ + "--config" + "/var/lib/music-assistant" + ]; example = [ "--log-level" "DEBUG" @@ -50,7 +53,7 @@ in providers = mkOption { type = listOf (enum cfg.package.providerNames); - default = []; + default = [ ]; example = [ "opensubsonic" "snapcast" @@ -74,9 +77,12 @@ in }; serviceConfig = { - ExecStart = utils.escapeSystemdExecArgs ([ - (lib.getExe cfg.package) - ] ++ cfg.extraOptions); + ExecStart = utils.escapeSystemdExecArgs ( + [ + (lib.getExe cfg.package) + ] + ++ cfg.extraOptions + ); DynamicUser = true; StateDirectory = "music-assistant"; AmbientCapabilities = ""; diff --git a/nixos/modules/services/audio/mympd.nix b/nixos/modules/services/audio/mympd.nix index cb1357b61a80a5..d6507133366dac 100644 --- a/nixos/modules/services/audio/mympd.nix +++ b/nixos/modules/services/audio/mympd.nix @@ -1,15 +1,21 @@ -{ pkgs, config, lib, ... }: +{ + pkgs, + config, + lib, + ... +}: let cfg = config.services.mympd; -in { +in +{ options = { services.mympd = { enable = lib.mkEnableOption "MyMPD server"; - package = lib.mkPackageOption pkgs "mympd" {}; + package = lib.mkPackageOption pkgs "mympd" { }; openFirewall = lib.mkOption { type = lib.types.bool; @@ -30,7 +36,15 @@ in { settings = lib.mkOption { type = lib.types.submodule { - freeformType = with lib.types; attrsOf (nullOr (oneOf [ str bool int ])); + freeformType = + with lib.types; + attrsOf ( + nullOr (oneOf [ + str + bool + int + ]) + ); options = { http_port = lib.mkOption { type = lib.types.port; @@ -76,9 +90,11 @@ in { mkdir -p "$config_dir" ${pipe cfg.settings [ - (mapAttrsToList (name: value: '' - echo -n "${if isBool value then boolToString value else toString value}" > "$config_dir/${name}" - '')) + (mapAttrsToList ( + name: value: '' + echo -n "${if isBool value then boolToString value else toString value}" > "$config_dir/${name}" + '' + )) (concatStringsSep "\n") ]} ''; diff --git a/nixos/modules/services/audio/networkaudiod.nix b/nixos/modules/services/audio/networkaudiod.nix index 09e8fdcaacc329..3f2842f63ceb98 100644 --- a/nixos/modules/services/audio/networkaudiod.nix +++ b/nixos/modules/services/audio/networkaudiod.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let name = "networkaudiod"; cfg = config.services.networkaudiod; -in { +in +{ options = { services.networkaudiod = { enable = lib.mkEnableOption "Networkaudiod (NAA)"; diff --git a/nixos/modules/services/audio/roon-bridge.nix b/nixos/modules/services/audio/roon-bridge.nix index 049e84f02f0c2f..8abd3dd7482da4 100644 --- a/nixos/modules/services/audio/roon-bridge.nix +++ b/nixos/modules/services/audio/roon-bridge.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let name = "roon-bridge"; cfg = config.services.roon-bridge; -in { +in +{ options = { services.roon-bridge = { enable = lib.mkEnableOption "Roon Bridge"; @@ -48,7 +54,12 @@ in { }; networking.firewall = lib.mkIf cfg.openFirewall { - allowedTCPPortRanges = [{ from = 9100; to = 9200; }]; + allowedTCPPortRanges = [ + { + from = 9100; + to = 9200; + } + ]; allowedUDPPorts = [ 9003 ]; extraCommands = lib.optionalString (!config.networking.nftables.enable) '' iptables -A INPUT -s 224.0.0.0/4 -j ACCEPT @@ -64,14 +75,12 @@ in { ''; }; - - users.groups.${cfg.group} = {}; - users.users.${cfg.user} = - lib.optionalAttrs (cfg.user == "roon-bridge") { - isSystemUser = true; - description = "Roon Bridge user"; - group = cfg.group; - extraGroups = [ "audio" ]; - }; + users.groups.${cfg.group} = { }; + users.users.${cfg.user} = lib.optionalAttrs (cfg.user == "roon-bridge") { + isSystemUser = true; + description = "Roon Bridge user"; + group = cfg.group; + extraGroups = [ "audio" ]; + }; }; } diff --git a/nixos/modules/services/audio/roon-server.nix b/nixos/modules/services/audio/roon-server.nix index 58763f5ceeeb59..00034827424859 100644 --- a/nixos/modules/services/audio/roon-server.nix +++ b/nixos/modules/services/audio/roon-server.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let name = "roon-server"; cfg = config.services.roon-server; -in { +in +{ options = { services.roon-server = { enable = lib.mkEnableOption "Roon Server"; @@ -51,9 +57,18 @@ in { networking.firewall = lib.mkIf cfg.openFirewall { allowedTCPPortRanges = [ - { from = 9100; to = 9200; } - { from = 9330; to = 9339; } - { from = 30000; to = 30010; } + { + from = 9100; + to = 9200; + } + { + from = 9330; + to = 9339; + } + { + from = 30000; + to = 30010; + } ]; allowedUDPPorts = [ 9003 ]; extraCommands = lib.optionalString (!config.networking.nftables.enable) '' @@ -71,14 +86,12 @@ in { ''; }; - - users.groups.${cfg.group} = {}; - users.users.${cfg.user} = - lib.optionalAttrs (cfg.user == "roon-server") { - isSystemUser = true; - description = "Roon Server user"; - group = cfg.group; - extraGroups = [ "audio" ]; - }; + users.groups.${cfg.group} = { }; + users.users.${cfg.user} = lib.optionalAttrs (cfg.user == "roon-server") { + isSystemUser = true; + description = "Roon Server user"; + group = cfg.group; + extraGroups = [ "audio" ]; + }; }; } diff --git a/nixos/modules/services/audio/slimserver.nix b/nixos/modules/services/audio/slimserver.nix index a9b5ed6bac00af..0f124505addfc0 100644 --- a/nixos/modules/services/audio/slimserver.nix +++ b/nixos/modules/services/audio/slimserver.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.slimserver; -in { +in +{ options = { services.slimserver = { @@ -29,7 +35,6 @@ in { }; }; - ###### implementation config = lib.mkIf cfg.enable { @@ -57,9 +62,8 @@ in { group = "slimserver"; isSystemUser = true; }; - groups.slimserver = {}; + groups.slimserver = { }; }; }; } - diff --git a/nixos/modules/services/audio/snapserver.nix b/nixos/modules/services/audio/snapserver.nix index 678a916f2d3a39..86ba7ec7183d81 100644 --- a/nixos/modules/services/audio/snapserver.nix +++ b/nixos/modules/services/audio/snapserver.nix @@ -1,4 +1,10 @@ -{ config, options, lib, pkgs, ... }: +{ + config, + options, + lib, + pkgs, + ... +}: let name = "snapserver"; @@ -24,23 +30,26 @@ let example = "flac"; }; - streamToOption = name: opt: + streamToOption = + name: opt: let - os = val: - lib.optionalString (val != null) "${val}"; - os' = prefix: val: - lib.optionalString (val != null) (prefix + "${val}"); - toQueryString = key: value: - "&${key}=${value}"; + os = val: lib.optionalString (val != null) "${val}"; + os' = prefix: val: lib.optionalString (val != null) (prefix + "${val}"); + toQueryString = key: value: "&${key}=${value}"; in - "--stream.stream=\"${opt.type}://" + os opt.location + "?" + os' "name=" name - + os' "&sampleformat=" opt.sampleFormat + os' "&codec=" opt.codec - + lib.concatStrings (lib.mapAttrsToList toQueryString opt.query) + "\""; - - optionalNull = val: ret: - lib.optional (val != null) ret; - - optionString = lib.concatStringsSep " " (lib.mapAttrsToList streamToOption cfg.streams + "--stream.stream=\"${opt.type}://" + + os opt.location + + "?" + + os' "name=" name + + os' "&sampleformat=" opt.sampleFormat + + os' "&codec=" opt.codec + + lib.concatStrings (lib.mapAttrsToList toQueryString opt.query) + + "\""; + + optionalNull = val: ret: lib.optional (val != null) ret; + + optionString = lib.concatStringsSep " " ( + lib.mapAttrsToList streamToOption cfg.streams # global options ++ [ "--stream.bind_to_address=${cfg.listenAddress}" ] ++ [ "--stream.port=${toString cfg.port}" ] @@ -53,17 +62,24 @@ let ++ [ "--tcp.enabled=${toString cfg.tcp.enable}" ] ++ lib.optionals cfg.tcp.enable [ "--tcp.bind_to_address=${cfg.tcp.listenAddress}" - "--tcp.port=${toString cfg.tcp.port}" ] - # http json rpc + "--tcp.port=${toString cfg.tcp.port}" + ] + # http json rpc ++ [ "--http.enabled=${toString cfg.http.enable}" ] ++ lib.optionals cfg.http.enable [ "--http.bind_to_address=${cfg.http.listenAddress}" "--http.port=${toString cfg.http.port}" - ] ++ lib.optional (cfg.http.docRoot != null) "--http.doc_root=\"${toString cfg.http.docRoot}\""); + ] + ++ lib.optional (cfg.http.docRoot != null) "--http.doc_root=\"${toString cfg.http.docRoot}\"" + ); -in { +in +{ imports = [ - (lib.mkRenamedOptionModule [ "services" "snapserver" "controlPort" ] [ "services" "snapserver" "tcp" "port" ]) + (lib.mkRenamedOptionModule + [ "services" "snapserver" "controlPort" ] + [ "services" "snapserver" "tcp" "port" ] + ) ]; ###### interface @@ -196,62 +212,79 @@ in { }; streams = lib.mkOption { - type = with lib.types; attrsOf (submodule { - options = { - location = lib.mkOption { - type = lib.types.oneOf [ lib.types.path lib.types.str ]; - description = '' - For type `pipe` or `file`, the path to the pipe or file. - For type `librespot`, `airplay` or `process`, the path to the corresponding binary. - For type `tcp`, the `host:port` address to connect to or listen on. - For type `meta`, a list of stream names in the form `/one/two/...`. Don't forget the leading slash. - For type `alsa`, use an empty string. - ''; - example = lib.literalExpression '' - "/path/to/pipe" - "/path/to/librespot" - "192.168.1.2:4444" - "/MyTCP/Spotify/MyPipe" - ''; - }; - type = lib.mkOption { - type = lib.types.enum [ "pipe" "librespot" "airplay" "file" "process" "tcp" "alsa" "spotify" "meta" ]; - default = "pipe"; - description = '' - The type of input stream. - ''; + type = + with lib.types; + attrsOf (submodule { + options = { + location = lib.mkOption { + type = lib.types.oneOf [ + lib.types.path + lib.types.str + ]; + description = '' + For type `pipe` or `file`, the path to the pipe or file. + For type `librespot`, `airplay` or `process`, the path to the corresponding binary. + For type `tcp`, the `host:port` address to connect to or listen on. + For type `meta`, a list of stream names in the form `/one/two/...`. Don't forget the leading slash. + For type `alsa`, use an empty string. + ''; + example = lib.literalExpression '' + "/path/to/pipe" + "/path/to/librespot" + "192.168.1.2:4444" + "/MyTCP/Spotify/MyPipe" + ''; + }; + type = lib.mkOption { + type = lib.types.enum [ + "pipe" + "librespot" + "airplay" + "file" + "process" + "tcp" + "alsa" + "spotify" + "meta" + ]; + default = "pipe"; + description = '' + The type of input stream. + ''; + }; + query = lib.mkOption { + type = attrsOf str; + default = { }; + description = '' + Key-value pairs that convey additional parameters about a stream. + ''; + example = lib.literalExpression '' + # for type == "pipe": + { + mode = "create"; + }; + # for type == "process": + { + params = "--param1 --param2"; + logStderr = "true"; + }; + # for type == "tcp": + { + mode = "client"; + } + # for type == "alsa": + { + device = "hw:0,0"; + } + ''; + }; + inherit sampleFormat; + inherit codec; }; - query = lib.mkOption { - type = attrsOf str; - default = {}; - description = '' - Key-value pairs that convey additional parameters about a stream. - ''; - example = lib.literalExpression '' - # for type == "pipe": - { - mode = "create"; - }; - # for type == "process": - { - params = "--param1 --param2"; - logStderr = "true"; - }; - # for type == "tcp": - { - mode = "client"; - } - # for type == "alsa": - { - device = "hw:0,0"; - } - ''; - }; - inherit sampleFormat; - inherit codec; - }; - }); - default = { default = {}; }; + }); + default = { + default = { }; + }; description = '' The definition for an input source. ''; @@ -269,22 +302,32 @@ in { }; }; - ###### implementation config = lib.mkIf cfg.enable { warnings = # https://github.com/badaix/snapcast/blob/98ac8b2fb7305084376607b59173ce4097c620d8/server/streamreader/stream_manager.cpp#L85 - lib.filter (w: w != "") (lib.mapAttrsToList (k: v: lib.optionalString (v.type == "spotify") '' - services.snapserver.streams.${k}.type = "spotify" is deprecated, use services.snapserver.streams.${k}.type = "librespot" instead. - '') cfg.streams); + lib.filter (w: w != "") ( + lib.mapAttrsToList ( + k: v: + lib.optionalString (v.type == "spotify") '' + services.snapserver.streams.${k}.type = "spotify" is deprecated, use services.snapserver.streams.${k}.type = "librespot" instead. + '' + ) cfg.streams + ); systemd.services.snapserver = { - after = [ "network.target" "nss-lookup.target" ]; + after = [ + "network.target" + "nss-lookup.target" + ]; description = "Snapserver"; wantedBy = [ "multi-user.target" ]; - before = [ "mpd.service" "mopidy.service" ]; + before = [ + "mpd.service" + "mopidy.service" + ]; serviceConfig = { DynamicUser = true; diff --git a/nixos/modules/services/audio/spotifyd.nix b/nixos/modules/services/audio/spotifyd.nix index c44617a7d6d7be..1f6ab0b5f75bd7 100644 --- a/nixos/modules/services/audio/spotifyd.nix +++ b/nixos/modules/services/audio/spotifyd.nix @@ -1,15 +1,22 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.spotifyd; - toml = pkgs.formats.toml {}; + toml = pkgs.formats.toml { }; warnConfig = - if cfg.config != "" - then lib.trace "Using the stringly typed .config attribute is discouraged. Use the TOML typed .settings attribute instead." - else lib.id; + if cfg.config != "" then + lib.trace "Using the stringly typed .config attribute is discouraged. Use the TOML typed .settings attribute instead." + else + lib.id; spotifydConf = - if cfg.settings != {} - then toml.generate "spotify.conf" cfg.settings - else warnConfig (pkgs.writeText "spotifyd.conf" cfg.config); + if cfg.settings != { } then + toml.generate "spotify.conf" cfg.settings + else + warnConfig (pkgs.writeText "spotifyd.conf" cfg.config); in { options = { @@ -26,9 +33,11 @@ in }; settings = lib.mkOption { - default = {}; + default = { }; type = toml.type; - example = { global.bitrate = 320; }; + example = { + global.bitrate = 320; + }; description = '' Configuration for Spotifyd. For syntax and directives, see . @@ -40,7 +49,7 @@ in config = lib.mkIf cfg.enable { assertions = [ { - assertion = cfg.config == "" || cfg.settings == {}; + assertion = cfg.config == "" || cfg.settings == { }; message = "At most one of the .config attribute and the .settings attribute may be set"; } ]; @@ -48,7 +57,10 @@ in systemd.services.spotifyd = { wantedBy = [ "multi-user.target" ]; wants = [ "network-online.target" ]; - after = [ "network-online.target" "sound.target" ]; + after = [ + "network-online.target" + "sound.target" + ]; description = "spotifyd, a Spotify playing daemon"; environment.SHELL = "/bin/sh"; serviceConfig = { @@ -57,7 +69,7 @@ in RestartSec = 12; DynamicUser = true; CacheDirectory = "spotifyd"; - SupplementaryGroups = ["audio"]; + SupplementaryGroups = [ "audio" ]; }; }; }; diff --git a/nixos/modules/services/audio/squeezelite.nix b/nixos/modules/services/audio/squeezelite.nix index 36295e21c60f99..525285d00ca506 100644 --- a/nixos/modules/services/audio/squeezelite.nix +++ b/nixos/modules/services/audio/squeezelite.nix @@ -1,7 +1,18 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkIf mkOption optionalString types; + inherit (lib) + mkEnableOption + mkIf + mkOption + optionalString + types + ; dataDir = "/var/lib/squeezelite"; cfg = config.services.squeezelite; @@ -27,13 +38,15 @@ in }; }; - ###### implementation config = mkIf cfg.enable { systemd.services.squeezelite = { wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "sound.target" ]; + after = [ + "network.target" + "sound.target" + ]; description = "Software Squeezebox emulator"; serviceConfig = { DynamicUser = true; diff --git a/nixos/modules/services/audio/tts.nix b/nixos/modules/services/audio/tts.nix index 4db624229aa845..590bdab2f40aed 100644 --- a/nixos/modules/services/audio/tts.nix +++ b/nixos/modules/services/audio/tts.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let @@ -9,144 +10,170 @@ let in { - options.services.tts = let - inherit (lib) literalExpression mkOption mkEnableOption types; - in { - servers = mkOption { - type = types.attrsOf (types.submodule ( - { ... }: { - options = { - enable = mkEnableOption "Coqui TTS server"; + options.services.tts = + let + inherit (lib) + literalExpression + mkOption + mkEnableOption + types + ; + in + { + servers = mkOption { + type = types.attrsOf ( + types.submodule ( + { ... }: + { + options = { + enable = mkEnableOption "Coqui TTS server"; - port = mkOption { - type = types.port; - example = 5000; - description = '' - Port to bind the TTS server to. - ''; - }; + port = mkOption { + type = types.port; + example = 5000; + description = '' + Port to bind the TTS server to. + ''; + }; - model = mkOption { - type = types.nullOr types.str; - default = "tts_models/en/ljspeech/tacotron2-DDC"; - example = null; - description = '' - Name of the model to download and use for speech synthesis. + model = mkOption { + type = types.nullOr types.str; + default = "tts_models/en/ljspeech/tacotron2-DDC"; + example = null; + description = '' + Name of the model to download and use for speech synthesis. - Check `tts-server --list_models` for possible values. + Check `tts-server --list_models` for possible values. - Set to `null` to use a custom model. - ''; - }; + Set to `null` to use a custom model. + ''; + }; - useCuda = mkOption { - type = types.bool; - default = false; - example = true; - description = '' - Whether to offload computation onto a CUDA compatible GPU. - ''; - }; + useCuda = mkOption { + type = types.bool; + default = false; + example = true; + description = '' + Whether to offload computation onto a CUDA compatible GPU. + ''; + }; - extraArgs = mkOption { - type = types.listOf types.str; - default = []; - description = '' - Extra arguments to pass to the server commandline. - ''; + extraArgs = mkOption { + type = types.listOf types.str; + default = [ ]; + description = '' + Extra arguments to pass to the server commandline. + ''; + }; + }; + } + ) + ); + default = { }; + example = literalExpression '' + { + english = { + port = 5300; + model = "tts_models/en/ljspeech/tacotron2-DDC"; }; - }; - } - )); - default = {}; - example = literalExpression '' - { - english = { - port = 5300; - model = "tts_models/en/ljspeech/tacotron2-DDC"; - }; - german = { - port = 5301; - model = "tts_models/de/thorsten/tacotron2-DDC"; - }; - dutch = { - port = 5302; - model = "tts_models/nl/mai/tacotron2-DDC"; - }; - } - ''; - description = '' - TTS server instances. - ''; + german = { + port = 5301; + model = "tts_models/de/thorsten/tacotron2-DDC"; + }; + dutch = { + port = 5302; + model = "tts_models/nl/mai/tacotron2-DDC"; + }; + } + ''; + description = '' + TTS server instances. + ''; + }; }; - }; - config = let - inherit (lib) mkIf mapAttrs' nameValuePair optionalString concatMapStringsSep escapeShellArgs; - in mkIf (cfg.servers != {}) { - systemd.services = mapAttrs' (server: options: - nameValuePair "tts-${server}" { - description = "Coqui TTS server instance ${server}"; - after = [ - "network-online.target" - ]; - wantedBy = [ - "multi-user.target" - ]; - path = with pkgs; [ - espeak-ng - ]; - environment.HOME = "/var/lib/tts"; - serviceConfig = { - DynamicUser = true; - User = "tts"; - StateDirectory = "tts"; - ExecStart = "${pkgs.tts}/bin/tts-server --port ${toString options.port}" - + optionalString (options.model != null) " --model_name ${options.model}" - + optionalString (options.useCuda) " --use_cuda" - + (concatMapStringsSep " " escapeShellArgs options.extraArgs); - CapabilityBoundingSet = ""; - DeviceAllow = if options.useCuda then [ - # https://docs.nvidia.com/dgx/pdf/dgx-os-5-user-guide.pdf - "/dev/nvidia1" - "/dev/nvidia2" - "/dev/nvidia3" - "/dev/nvidia4" - "/dev/nvidia-caps/nvidia-cap1" - "/dev/nvidia-caps/nvidia-cap2" - "/dev/nvidiactl" - "/dev/nvidia-modeset" - "/dev/nvidia-uvm" - "/dev/nvidia-uvm-tools" - ] else ""; - DevicePolicy = "closed"; - LockPersonality = true; - # jit via numba->llvmpipe - MemoryDenyWriteExecute = false; - PrivateDevices = true; - PrivateUsers = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectControlGroups = true; - ProtectProc = "invisible"; - ProcSubset = "pid"; - RestrictAddressFamilies = [ - "AF_UNIX" - "AF_INET" - "AF_INET6" + config = + let + inherit (lib) + mkIf + mapAttrs' + nameValuePair + optionalString + concatMapStringsSep + escapeShellArgs + ; + in + mkIf (cfg.servers != { }) { + systemd.services = mapAttrs' ( + server: options: + nameValuePair "tts-${server}" { + description = "Coqui TTS server instance ${server}"; + after = [ + "network-online.target" ]; - RestrictNamespaces = true; - RestrictRealtime = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ - "@system-service" - "~@privileged" + wantedBy = [ + "multi-user.target" ]; - UMask = "0077"; - }; - }) cfg.servers; - }; + path = with pkgs; [ + espeak-ng + ]; + environment.HOME = "/var/lib/tts"; + serviceConfig = { + DynamicUser = true; + User = "tts"; + StateDirectory = "tts"; + ExecStart = + "${pkgs.tts}/bin/tts-server --port ${toString options.port}" + + optionalString (options.model != null) " --model_name ${options.model}" + + optionalString (options.useCuda) " --use_cuda" + + (concatMapStringsSep " " escapeShellArgs options.extraArgs); + CapabilityBoundingSet = ""; + DeviceAllow = + if options.useCuda then + [ + # https://docs.nvidia.com/dgx/pdf/dgx-os-5-user-guide.pdf + "/dev/nvidia1" + "/dev/nvidia2" + "/dev/nvidia3" + "/dev/nvidia4" + "/dev/nvidia-caps/nvidia-cap1" + "/dev/nvidia-caps/nvidia-cap2" + "/dev/nvidiactl" + "/dev/nvidia-modeset" + "/dev/nvidia-uvm" + "/dev/nvidia-uvm-tools" + ] + else + ""; + DevicePolicy = "closed"; + LockPersonality = true; + # jit via numba->llvmpipe + MemoryDenyWriteExecute = false; + PrivateDevices = true; + PrivateUsers = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectControlGroups = true; + ProtectProc = "invisible"; + ProcSubset = "pid"; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; + UMask = "0077"; + }; + } + ) cfg.servers; + }; } diff --git a/nixos/modules/services/audio/ympd.nix b/nixos/modules/services/audio/ympd.nix index 96977581a24539..12672eb935f1e9 100644 --- a/nixos/modules/services/audio/ympd.nix +++ b/nixos/modules/services/audio/ympd.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.ympd; -in { +in +{ ###### interface @@ -38,7 +44,6 @@ in { }; - ###### implementation config = lib.mkIf cfg.enable { @@ -76,7 +81,10 @@ in { ProtectKernelLogs = true; ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictRealtime = true; RestrictSUIDSGID = true; diff --git a/nixos/modules/services/backup/automysqlbackup.nix b/nixos/modules/services/backup/automysqlbackup.nix index d5efda74f26f97..83518f994aebc9 100644 --- a/nixos/modules/services/backup/automysqlbackup.nix +++ b/nixos/modules/services/backup/automysqlbackup.nix @@ -1,21 +1,48 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) concatMapStringsSep concatStringsSep isInt isList literalExpression; - inherit (lib) mapAttrs mapAttrsToList mkDefault mkEnableOption mkIf mkOption mkRenamedOptionModule optional types; + inherit (lib) + concatMapStringsSep + concatStringsSep + isInt + isList + literalExpression + ; + inherit (lib) + mapAttrs + mapAttrsToList + mkDefault + mkEnableOption + mkIf + mkOption + mkRenamedOptionModule + optional + types + ; cfg = config.services.automysqlbackup; pkg = pkgs.automysqlbackup; user = "automysqlbackup"; group = "automysqlbackup"; - toStr = val: - if isList val then "( ${concatMapStringsSep " " (val: "'${val}'") val} )" - else if isInt val then toString val - else if true == val then "'yes'" - else if false == val then "'no'" - else "'${toString val}'"; + toStr = + val: + if isList val then + "( ${concatMapStringsSep " " (val: "'${val}'") val} )" + else if isInt val then + toString val + else if true == val then + "'yes'" + else if false == val then + "'no'" + else + "'${toString val}'"; configFile = pkgs.writeText "automysqlbackup.conf" '' #version=${pkg.version} @@ -27,7 +54,10 @@ let in { imports = [ - (mkRenamedOptionModule [ "services" "automysqlbackup" "config" ] [ "services" "automysqlbackup" "settings" ]) + (mkRenamedOptionModule + [ "services" "automysqlbackup" "config" ] + [ "services" "automysqlbackup" "settings" ] + ) ]; # interface @@ -45,8 +75,15 @@ in }; settings = mkOption { - type = with types; attrsOf (oneOf [ str int bool (listOf str) ]); - default = {}; + type = + with types; + attrsOf (oneOf [ + str + int + bool + (listOf str) + ]); + default = { }; description = '' automysqlbackup configuration. Refer to {file}`''${pkgs.automysqlbackup}/etc/automysqlbackup.conf` @@ -69,7 +106,8 @@ in config = mkIf cfg.enable { assertions = [ - { assertion = !config.services.mysqlBackup.enable; + { + assertion = !config.services.mysqlBackup.enable; message = "Please choose one of services.mysqlBackup or services.automysqlbackup."; } ]; @@ -79,7 +117,10 @@ in mysql_dump_host = "localhost"; mysql_dump_socket = "/run/mysqld/mysqld.sock"; backup_dir = "/var/backup/mysql"; - db_exclude = [ "information_schema" "performance_schema" ]; + db_exclude = [ + "information_schema" + "performance_schema" + ]; mailcontent = "stdout"; mysql_dump_single_transaction = true; }; @@ -114,12 +155,14 @@ in "d '${cfg.config.backup_dir}' 0750 ${user} ${group} - -" ]; - services.mysql.ensureUsers = optional (config.services.mysql.enable && cfg.config.mysql_dump_host == "localhost") { - name = user; - ensurePermissions = { - "*.*" = "SELECT, SHOW VIEW, TRIGGER, LOCK TABLES, EVENT"; - }; - }; + services.mysql.ensureUsers = + optional (config.services.mysql.enable && cfg.config.mysql_dump_host == "localhost") + { + name = user; + ensurePermissions = { + "*.*" = "SELECT, SHOW VIEW, TRIGGER, LOCK TABLES, EVENT"; + }; + }; }; } diff --git a/nixos/modules/services/backup/bacula.nix b/nixos/modules/services/backup/bacula.nix index 0851b5b0bf14f6..a35350646c9be2 100644 --- a/nixos/modules/services/backup/bacula.nix +++ b/nixos/modules/services/backup/bacula.nix @@ -1,10 +1,13 @@ -{ config, lib, pkgs, ... }: - +{ + config, + lib, + pkgs, + ... +}: # TODO: test configuration when building nixexpr (use -t parameter) # TODO: support sqlite3 (it's deprecate?) and mysql - let inherit (lib) concatStringsSep @@ -19,98 +22,107 @@ let libDir = "/var/lib/bacula"; yes_no = bool: if bool then "yes" else "no"; - tls_conf = tls_cfg: optionalString tls_cfg.enable ( - concatStringsSep - "\n" - ( - ["TLS Enable = yes;"] - ++ optional (tls_cfg.require != null) "TLS Require = ${yes_no tls_cfg.require};" - ++ optional (tls_cfg.certificate != null) ''TLS Certificate = "${tls_cfg.certificate}";'' - ++ [''TLS Key = "${tls_cfg.key}";''] - ++ optional (tls_cfg.verifyPeer != null) "TLS Verify Peer = ${yes_no tls_cfg.verifyPeer};" - ++ optional (tls_cfg.allowedCN != [ ]) "TLS Allowed CN = ${concatStringsSep " " (tls_cfg.allowedCN)};" - ++ optional (tls_cfg.caCertificateFile != null) ''TLS CA Certificate File = "${tls_cfg.caCertificateFile}";'' + tls_conf = + tls_cfg: + optionalString tls_cfg.enable ( + concatStringsSep "\n" ( + [ "TLS Enable = yes;" ] + ++ optional (tls_cfg.require != null) "TLS Require = ${yes_no tls_cfg.require};" + ++ optional (tls_cfg.certificate != null) ''TLS Certificate = "${tls_cfg.certificate}";'' + ++ [ ''TLS Key = "${tls_cfg.key}";'' ] + ++ optional (tls_cfg.verifyPeer != null) "TLS Verify Peer = ${yes_no tls_cfg.verifyPeer};" + ++ optional ( + tls_cfg.allowedCN != [ ] + ) "TLS Allowed CN = ${concatStringsSep " " (tls_cfg.allowedCN)};" + ++ optional ( + tls_cfg.caCertificateFile != null + ) ''TLS CA Certificate File = "${tls_cfg.caCertificateFile}";'' ) - ); + ); fd_cfg = config.services.bacula-fd; - fd_conf = pkgs.writeText "bacula-fd.conf" - '' - Client { - Name = "${fd_cfg.name}"; - FDPort = ${toString fd_cfg.port}; - WorkingDirectory = ${libDir}; - Pid Directory = /run; - ${fd_cfg.extraClientConfig} - ${tls_conf fd_cfg.tls} - } - - ${concatStringsSep "\n" (mapAttrsToList (name: value: '' - Director { - Name = "${name}"; - Password = ${value.password}; - Monitor = ${value.monitor}; - ${tls_conf value.tls} - } - '') fd_cfg.director)} - - Messages { - Name = Standard; - syslog = all, !skipped, !restored - ${fd_cfg.extraMessagesConfig} - } - ''; + fd_conf = pkgs.writeText "bacula-fd.conf" '' + Client { + Name = "${fd_cfg.name}"; + FDPort = ${toString fd_cfg.port}; + WorkingDirectory = ${libDir}; + Pid Directory = /run; + ${fd_cfg.extraClientConfig} + ${tls_conf fd_cfg.tls} + } + + ${concatStringsSep "\n" ( + mapAttrsToList (name: value: '' + Director { + Name = "${name}"; + Password = ${value.password}; + Monitor = ${value.monitor}; + ${tls_conf value.tls} + } + '') fd_cfg.director + )} + + Messages { + Name = Standard; + syslog = all, !skipped, !restored + ${fd_cfg.extraMessagesConfig} + } + ''; sd_cfg = config.services.bacula-sd; - sd_conf = pkgs.writeText "bacula-sd.conf" - '' - Storage { - Name = "${sd_cfg.name}"; - SDPort = ${toString sd_cfg.port}; - WorkingDirectory = ${libDir}; - Pid Directory = /run; - ${sd_cfg.extraStorageConfig} - ${tls_conf sd_cfg.tls} - } - - ${concatStringsSep "\n" (mapAttrsToList (name: value: '' - Autochanger { - Name = "${name}"; - Device = ${concatStringsSep ", " (map (a: "\"${a}\"") value.devices)}; - Changer Device = ${value.changerDevice}; - Changer Command = ${value.changerCommand}; - ${value.extraAutochangerConfig} - } - '') sd_cfg.autochanger)} - - ${concatStringsSep "\n" (mapAttrsToList (name: value: '' - Device { - Name = "${name}"; - Archive Device = ${value.archiveDevice}; - Media Type = ${value.mediaType}; - ${value.extraDeviceConfig} - } - '') sd_cfg.device)} - - ${concatStringsSep "\n" (mapAttrsToList (name: value: '' - Director { - Name = "${name}"; - Password = ${value.password}; - Monitor = ${value.monitor}; - ${tls_conf value.tls} - } - '') sd_cfg.director)} - - Messages { - Name = Standard; - syslog = all, !skipped, !restored - ${sd_cfg.extraMessagesConfig} - } - ''; + sd_conf = pkgs.writeText "bacula-sd.conf" '' + Storage { + Name = "${sd_cfg.name}"; + SDPort = ${toString sd_cfg.port}; + WorkingDirectory = ${libDir}; + Pid Directory = /run; + ${sd_cfg.extraStorageConfig} + ${tls_conf sd_cfg.tls} + } + + ${concatStringsSep "\n" ( + mapAttrsToList (name: value: '' + Autochanger { + Name = "${name}"; + Device = ${concatStringsSep ", " (map (a: "\"${a}\"") value.devices)}; + Changer Device = ${value.changerDevice}; + Changer Command = ${value.changerCommand}; + ${value.extraAutochangerConfig} + } + '') sd_cfg.autochanger + )} + + ${concatStringsSep "\n" ( + mapAttrsToList (name: value: '' + Device { + Name = "${name}"; + Archive Device = ${value.archiveDevice}; + Media Type = ${value.mediaType}; + ${value.extraDeviceConfig} + } + '') sd_cfg.device + )} + + ${concatStringsSep "\n" ( + mapAttrsToList (name: value: '' + Director { + Name = "${name}"; + Password = ${value.password}; + Monitor = ${value.monitor}; + ${tls_conf value.tls} + } + '') sd_cfg.director + )} + + Messages { + Name = Standard; + syslog = all, !skipped, !restored + ${sd_cfg.extraMessagesConfig} + } + ''; dir_cfg = config.services.bacula-dir; - dir_conf = pkgs.writeText "bacula-dir.conf" - '' + dir_conf = pkgs.writeText "bacula-dir.conf" '' Director { Name = "${dir_cfg.name}"; Password = ${dir_cfg.password}; @@ -135,283 +147,295 @@ let } ${dir_cfg.extraConfig} - ''; - - linkOption = name: destination: "[${name}](#opt-${builtins.replaceStrings [ "<" ">"] ["_" "_"] destination})"; - tlsLink = destination: submodulePath: linkOption "${submodulePath}.${destination}" "${submodulePath}.${destination}"; - - tlsOptions = submodulePath: {...}: - { - options = { - enable = mkOption { - type = types.bool; - default = false; - description = '' - Specifies if TLS should be enabled. - If this set to `false` TLS will be completely disabled, even if ${tlsLink "tls.require" submodulePath} is true. - ''; - }; - require = mkOption { - type = types.nullOr types.bool; - default = null; - description = '' - Require TLS or TLS-PSK encryption. - This directive is ignored unless one of ${tlsLink "tls.enable" submodulePath} is true or TLS PSK Enable is set to `yes`. - If TLS is not required while TLS or TLS-PSK are enabled, then the Bacula component - will connect with other components either with or without TLS or TLS-PSK - - If ${tlsLink "tls.enable" submodulePath} or TLS-PSK is enabled and TLS is required, then the Bacula - component will refuse any connection request that does not use TLS. - ''; - }; - certificate = mkOption { - type = types.nullOr types.path; - default = null; - description = '' - The full path to the PEM encoded TLS certificate. - It will be used as either a client or server certificate, - depending on the connection direction. - This directive is required in a server context, but it may - not be specified in a client context if ${tlsLink "tls.verifyPeer" submodulePath} is - `false` in the corresponding server context. - ''; - }; - key = mkOption { - type = types.path; - description = '' - The path of a PEM encoded TLS private key. - It must correspond to the TLS certificate. - ''; - }; - verifyPeer = mkOption { - type = types.nullOr types.bool; - default = null; - description = '' - Verify peer certificate. - Instructs server to request and verify the client's X.509 certificate. - Any client certificate signed by a known-CA will be accepted. - Additionally, the client's X509 certificate Common Name must meet the value of the Address directive. - If ${tlsLink "tls.allowedCN" submodulePath} is used, - the client's x509 certificate Common Name must also correspond to - one of the CN specified in the ${tlsLink "tls.allowedCN" submodulePath} directive. - This directive is valid only for a server and not in client context. - - Standard from Bacula is `true`. - ''; - }; - allowedCN = mkOption { - type = types.listOf types.str; - default = [ ]; - description = '' - Common name attribute of allowed peer certificates. - This directive is valid for a server and in a client context. - If this directive is specified, the peer certificate will be verified against this list. - In the case this directive is configured on a server side, the allowed - CN list will not be checked if ${tlsLink "tls.verifyPeer" submodulePath} is false. - ''; - }; - caCertificateFile = mkOption { - type = types.nullOr types.path; - default = null; - description = '' - The path specifying a PEM encoded TLS CA certificate(s). - Multiple certificates are permitted in the file. - One of TLS CA Certificate File or TLS CA Certificate Dir are required in a server context, unless - ${tlsLink "tls.verifyPeer" submodulePath} is false, and are always required in a client context. - ''; + ''; + + linkOption = + name: destination: "[${name}](#opt-${builtins.replaceStrings [ "<" ">" ] [ "_" "_" ] destination})"; + tlsLink = + destination: submodulePath: + linkOption "${submodulePath}.${destination}" "${submodulePath}.${destination}"; + + tlsOptions = + submodulePath: + { ... }: + { + options = { + enable = mkOption { + type = types.bool; + default = false; + description = '' + Specifies if TLS should be enabled. + If this set to `false` TLS will be completely disabled, even if ${tlsLink "tls.require" submodulePath} is true. + ''; + }; + require = mkOption { + type = types.nullOr types.bool; + default = null; + description = '' + Require TLS or TLS-PSK encryption. + This directive is ignored unless one of ${tlsLink "tls.enable" submodulePath} is true or TLS PSK Enable is set to `yes`. + If TLS is not required while TLS or TLS-PSK are enabled, then the Bacula component + will connect with other components either with or without TLS or TLS-PSK + + If ${tlsLink "tls.enable" submodulePath} or TLS-PSK is enabled and TLS is required, then the Bacula + component will refuse any connection request that does not use TLS. + ''; + }; + certificate = mkOption { + type = types.nullOr types.path; + default = null; + description = '' + The full path to the PEM encoded TLS certificate. + It will be used as either a client or server certificate, + depending on the connection direction. + This directive is required in a server context, but it may + not be specified in a client context if ${tlsLink "tls.verifyPeer" submodulePath} is + `false` in the corresponding server context. + ''; + }; + key = mkOption { + type = types.path; + description = '' + The path of a PEM encoded TLS private key. + It must correspond to the TLS certificate. + ''; + }; + verifyPeer = mkOption { + type = types.nullOr types.bool; + default = null; + description = '' + Verify peer certificate. + Instructs server to request and verify the client's X.509 certificate. + Any client certificate signed by a known-CA will be accepted. + Additionally, the client's X509 certificate Common Name must meet the value of the Address directive. + If ${tlsLink "tls.allowedCN" submodulePath} is used, + the client's x509 certificate Common Name must also correspond to + one of the CN specified in the ${tlsLink "tls.allowedCN" submodulePath} directive. + This directive is valid only for a server and not in client context. + + Standard from Bacula is `true`. + ''; + }; + allowedCN = mkOption { + type = types.listOf types.str; + default = [ ]; + description = '' + Common name attribute of allowed peer certificates. + This directive is valid for a server and in a client context. + If this directive is specified, the peer certificate will be verified against this list. + In the case this directive is configured on a server side, the allowed + CN list will not be checked if ${tlsLink "tls.verifyPeer" submodulePath} is false. + ''; + }; + caCertificateFile = mkOption { + type = types.nullOr types.path; + default = null; + description = '' + The path specifying a PEM encoded TLS CA certificate(s). + Multiple certificates are permitted in the file. + One of TLS CA Certificate File or TLS CA Certificate Dir are required in a server context, unless + ${tlsLink "tls.verifyPeer" submodulePath} is false, and are always required in a client context. + ''; + }; }; }; - }; - - directorOptions = submodulePath:{...}: - { - options = { - password = mkOption { - type = types.str; - # TODO: required? - description = '' - Specifies the password that must be supplied for the default Bacula - Console to be authorized. The same password must appear in the - Director resource of the Console configuration file. For added - security, the password is never passed across the network but instead - a challenge response hash code created with the password. This - directive is required. If you have either /dev/random or bc on your - machine, Bacula will generate a random password during the - configuration process, otherwise it will be left blank and you must - manually supply it. - - The password is plain text. It is not generated through any special - process but as noted above, it is better to use random text for - security reasons. - ''; - }; - monitor = mkOption { - type = types.enum [ "no" "yes" ]; - default = "no"; - example = "yes"; - description = '' - If Monitor is set to `no`, this director will have - full access to this Storage daemon. If Monitor is set to - `yes`, this director will only be able to fetch the - current status of this Storage daemon. - - Please note that if this director is being used by a Monitor, we - highly recommend to set this directive to yes to avoid serious - security problems. - ''; - }; + directorOptions = + submodulePath: + { ... }: + { + options = { + password = mkOption { + type = types.str; + # TODO: required? + description = '' + Specifies the password that must be supplied for the default Bacula + Console to be authorized. The same password must appear in the + Director resource of the Console configuration file. For added + security, the password is never passed across the network but instead + a challenge response hash code created with the password. This + directive is required. If you have either /dev/random or bc on your + machine, Bacula will generate a random password during the + configuration process, otherwise it will be left blank and you must + manually supply it. + + The password is plain text. It is not generated through any special + process but as noted above, it is better to use random text for + security reasons. + ''; + }; + + monitor = mkOption { + type = types.enum [ + "no" + "yes" + ]; + default = "no"; + example = "yes"; + description = '' + If Monitor is set to `no`, this director will have + full access to this Storage daemon. If Monitor is set to + `yes`, this director will only be able to fetch the + current status of this Storage daemon. + + Please note that if this director is being used by a Monitor, we + highly recommend to set this directive to yes to avoid serious + security problems. + ''; + }; - tls = mkOption { - type = types.submodule (tlsOptions "${submodulePath}.director."); - description = '' - TLS Options for the Director in this Configuration. - ''; + tls = mkOption { + type = types.submodule (tlsOptions "${submodulePath}.director."); + description = '' + TLS Options for the Director in this Configuration. + ''; + }; }; }; - }; - autochangerOptions = {...}: - { - options = { - changerDevice = mkOption { - type = types.str; - description = '' - The specified name-string must be the generic SCSI device name of the - autochanger that corresponds to the normal read/write Archive Device - specified in the Device resource. This generic SCSI device name - should be specified if you have an autochanger or if you have a - standard tape drive and want to use the Alert Command (see below). - For example, on Linux systems, for an Archive Device name of - `/dev/nst0`, you would specify - `/dev/sg0` for the Changer Device name. Depending - on your exact configuration, and the number of autochangers or the - type of autochanger, what you specify here can vary. This directive - is optional. See the Using AutochangersAutochangersChapter chapter of - this manual for more details of using this and the following - autochanger directives. + autochangerOptions = + { ... }: + { + options = { + changerDevice = mkOption { + type = types.str; + description = '' + The specified name-string must be the generic SCSI device name of the + autochanger that corresponds to the normal read/write Archive Device + specified in the Device resource. This generic SCSI device name + should be specified if you have an autochanger or if you have a + standard tape drive and want to use the Alert Command (see below). + For example, on Linux systems, for an Archive Device name of + `/dev/nst0`, you would specify + `/dev/sg0` for the Changer Device name. Depending + on your exact configuration, and the number of autochangers or the + type of autochanger, what you specify here can vary. This directive + is optional. See the Using AutochangersAutochangersChapter chapter of + this manual for more details of using this and the following + autochanger directives. ''; - }; - - changerCommand = mkOption { - type = types.str; - description = '' - The name-string specifies an external program to be called that will - automatically change volumes as required by Bacula. Normally, this - directive will be specified only in the AutoChanger resource, which - is then used for all devices. However, you may also specify the - different Changer Command in each Device resource. Most frequently, - you will specify the Bacula supplied mtx-changer script as follows: - - `"/path/mtx-changer %c %o %S %a %d"` - - and you will install the mtx on your system (found in the depkgs - release). An example of this command is in the default bacula-sd.conf - file. For more details on the substitution characters that may be - specified to configure your autochanger please see the - AutochangersAutochangersChapter chapter of this manual. For FreeBSD - users, you might want to see one of the several chio scripts in - examples/autochangers. + }; + + changerCommand = mkOption { + type = types.str; + description = '' + The name-string specifies an external program to be called that will + automatically change volumes as required by Bacula. Normally, this + directive will be specified only in the AutoChanger resource, which + is then used for all devices. However, you may also specify the + different Changer Command in each Device resource. Most frequently, + you will specify the Bacula supplied mtx-changer script as follows: + + `"/path/mtx-changer %c %o %S %a %d"` + + and you will install the mtx on your system (found in the depkgs + release). An example of this command is in the default bacula-sd.conf + file. For more details on the substitution characters that may be + specified to configure your autochanger please see the + AutochangersAutochangersChapter chapter of this manual. For FreeBSD + users, you might want to see one of the several chio scripts in + examples/autochangers. ''; - default = "/etc/bacula/mtx-changer %c %o %S %a %d"; - }; - - devices = mkOption { - description = ""; - type = types.listOf types.str; - }; - - extraAutochangerConfig = mkOption { - default = ""; - type = types.lines; - description = '' - Extra configuration to be passed in Autochanger directive. - ''; - example = '' + default = "/etc/bacula/mtx-changer %c %o %S %a %d"; + }; + + devices = mkOption { + description = ""; + type = types.listOf types.str; + }; + + extraAutochangerConfig = mkOption { + default = ""; + type = types.lines; + description = '' + Extra configuration to be passed in Autochanger directive. + ''; + example = '' - ''; + ''; + }; }; }; - }; - - deviceOptions = {...}: - { - options = { - archiveDevice = mkOption { - # TODO: required? - type = types.str; - description = '' - The specified name-string gives the system file name of the storage - device managed by this storage daemon. This will usually be the - device file name of a removable storage device (tape drive), for - example `/dev/nst0` or - `/dev/rmt/0mbn`. For a DVD-writer, it will be for - example `/dev/hdc`. It may also be a directory name - if you are archiving to disk storage. In this case, you must supply - the full absolute path to the directory. When specifying a tape - device, it is preferable that the "non-rewind" variant of the device - file name be given. - ''; - }; - - mediaType = mkOption { - # TODO: required? - type = types.str; - description = '' - The specified name-string names the type of media supported by this - device, for example, `DLT7000`. Media type names are - arbitrary in that you set them to anything you want, but they must be - known to the volume database to keep track of which storage daemons - can read which volumes. In general, each different storage type - should have a unique Media Type associated with it. The same - name-string must appear in the appropriate Storage resource - definition in the Director's configuration file. - - Even though the names you assign are arbitrary (i.e. you choose the - name you want), you should take care in specifying them because the - Media Type is used to determine which storage device Bacula will - select during restore. Thus you should probably use the same Media - Type specification for all drives where the Media can be freely - interchanged. This is not generally an issue if you have a single - Storage daemon, but it is with multiple Storage daemons, especially - if they have incompatible media. - - For example, if you specify a Media Type of `DDS-4` - then during the restore, Bacula will be able to choose any Storage - Daemon that handles `DDS-4`. If you have an - autochanger, you might want to name the Media Type in a way that is - unique to the autochanger, unless you wish to possibly use the - Volumes in other drives. You should also ensure to have unique Media - Type names if the Media is not compatible between drives. This - specification is required for all devices. - - In addition, if you are using disk storage, each Device resource will - generally have a different mount point or directory. In order for - Bacula to select the correct Device resource, each one must have a - unique Media Type. - ''; - }; + deviceOptions = + { ... }: + { + options = { + archiveDevice = mkOption { + # TODO: required? + type = types.str; + description = '' + The specified name-string gives the system file name of the storage + device managed by this storage daemon. This will usually be the + device file name of a removable storage device (tape drive), for + example `/dev/nst0` or + `/dev/rmt/0mbn`. For a DVD-writer, it will be for + example `/dev/hdc`. It may also be a directory name + if you are archiving to disk storage. In this case, you must supply + the full absolute path to the directory. When specifying a tape + device, it is preferable that the "non-rewind" variant of the device + file name be given. + ''; + }; + + mediaType = mkOption { + # TODO: required? + type = types.str; + description = '' + The specified name-string names the type of media supported by this + device, for example, `DLT7000`. Media type names are + arbitrary in that you set them to anything you want, but they must be + known to the volume database to keep track of which storage daemons + can read which volumes. In general, each different storage type + should have a unique Media Type associated with it. The same + name-string must appear in the appropriate Storage resource + definition in the Director's configuration file. + + Even though the names you assign are arbitrary (i.e. you choose the + name you want), you should take care in specifying them because the + Media Type is used to determine which storage device Bacula will + select during restore. Thus you should probably use the same Media + Type specification for all drives where the Media can be freely + interchanged. This is not generally an issue if you have a single + Storage daemon, but it is with multiple Storage daemons, especially + if they have incompatible media. + + For example, if you specify a Media Type of `DDS-4` + then during the restore, Bacula will be able to choose any Storage + Daemon that handles `DDS-4`. If you have an + autochanger, you might want to name the Media Type in a way that is + unique to the autochanger, unless you wish to possibly use the + Volumes in other drives. You should also ensure to have unique Media + Type names if the Media is not compatible between drives. This + specification is required for all devices. + + In addition, if you are using disk storage, each Device resource will + generally have a different mount point or directory. In order for + Bacula to select the correct Device resource, each one must have a + unique Media Type. + ''; + }; - extraDeviceConfig = mkOption { - default = ""; - type = types.lines; - description = '' - Extra configuration to be passed in Device directive. - ''; - example = '' - LabelMedia = yes - Random Access = no - AutomaticMount = no - RemovableMedia = no - MaximumOpenWait = 60 - AlwaysOpen = no - ''; + extraDeviceConfig = mkOption { + default = ""; + type = types.lines; + description = '' + Extra configuration to be passed in Device directive. + ''; + example = '' + LabelMedia = yes + Random Access = no + AutomaticMount = no + RemovableMedia = no + MaximumOpenWait = 60 + AlwaysOpen = no + ''; + }; }; }; - }; -in { +in +{ options = { services.bacula-fd = { enable = mkOption { @@ -445,14 +469,13 @@ in { }; director = mkOption { - default = {}; + default = { }; description = '' This option defines director resources in Bacula File Daemon. ''; type = types.attrsOf (types.submodule (directorOptions "services.bacula-fd")); }; - tls = mkOption { type = types.submodule (tlsOptions "services.bacula-fd"); default = { }; @@ -460,7 +483,7 @@ in { TLS Options for the File Daemon. Important notice: The backup won't be encrypted. ''; - }; + }; extraClientConfig = mkOption { default = ""; @@ -514,7 +537,7 @@ in { }; director = mkOption { - default = {}; + default = { }; description = '' This option defines Director resources in Bacula Storage Daemon. ''; @@ -522,7 +545,7 @@ in { }; device = mkOption { - default = {}; + default = { }; description = '' This option defines Device resources in Bacula Storage Daemon. ''; @@ -530,7 +553,7 @@ in { }; autochanger = mkOption { - default = {}; + default = { }; description = '' This option defines Autochanger resources in Bacula Storage Daemon. ''; @@ -566,7 +589,7 @@ in { TLS Options for the Storage Daemon. Important notice: The backup won't be encrypted. ''; - }; + }; }; @@ -606,7 +629,7 @@ in { # TODO: required? type = types.str; description = '' - Specifies the password that must be supplied for a Director. + Specifies the password that must be supplied for a Director. ''; }; @@ -651,14 +674,17 @@ in { TLS Options for the Director. Important notice: The backup won't be encrypted. ''; - }; + }; }; }; config = mkIf (fd_cfg.enable || sd_cfg.enable || dir_cfg.enable) { systemd.slices.system-bacula = { description = "Bacula Backup System Slice"; - documentation = [ "man:bacula(8)" "https://www.bacula.org/" ]; + documentation = [ + "man:bacula(8)" + "https://www.bacula.org/" + ]; }; systemd.services.bacula-fd = mkIf fd_cfg.enable { @@ -692,7 +718,10 @@ in { services.postgresql.enable = lib.mkIf dir_cfg.enable true; systemd.services.bacula-dir = mkIf dir_cfg.enable { - after = [ "network.target" "postgresql.service" ]; + after = [ + "network.target" + "postgresql.service" + ]; description = "Bacula Director Daemon"; wantedBy = [ "multi-user.target" ]; path = [ pkgs.bacula ]; diff --git a/nixos/modules/services/backup/borgmatic.nix b/nixos/modules/services/backup/borgmatic.nix index 1112182e8d2314..c05fe208acb30c 100644 --- a/nixos/modules/services/backup/borgmatic.nix +++ b/nixos/modules/services/backup/borgmatic.nix @@ -1,56 +1,76 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.borgmatic; settingsFormat = pkgs.formats.yaml { }; - repository = with lib.types; submodule { - options = { - path = lib.mkOption { - type = str; - description = '' - Path to the repository - ''; - }; - label = lib.mkOption { - type = str; - description = '' - Label to the repository - ''; + repository = + with lib.types; + submodule { + options = { + path = lib.mkOption { + type = str; + description = '' + Path to the repository + ''; + }; + label = lib.mkOption { + type = str; + description = '' + Label to the repository + ''; + }; }; }; - }; - cfgType = with lib.types; submodule { - freeformType = settingsFormat.type; - options = { - source_directories = lib.mkOption { - type = listOf str; - default = []; - description = '' - List of source directories and files to backup. Globs and tildes are - expanded. Do not backslash spaces in path names. - ''; - example = [ "/home" "/etc" "/var/log/syslog*" "/home/user/path with spaces" ]; - }; - repositories = lib.mkOption { - type = listOf repository; - default = []; - description = '' - A required list of local or remote repositories with paths and - optional labels (which can be used with the --repository flag to - select a repository). Tildes are expanded. Multiple repositories are - backed up to in sequence. Borg placeholders can be used. See the - output of "borg help placeholders" for details. See ssh_command for - SSH options like identity file or port. If systemd service is used, - then add local repository paths in the systemd service file to the - ReadWritePaths list. - ''; - example = [ - { path="ssh://user@backupserver/./sourcehostname.borg"; label="backupserver"; } - { path="/mnt/backup"; label="local"; } - ]; + cfgType = + with lib.types; + submodule { + freeformType = settingsFormat.type; + options = { + source_directories = lib.mkOption { + type = listOf str; + default = [ ]; + description = '' + List of source directories and files to backup. Globs and tildes are + expanded. Do not backslash spaces in path names. + ''; + example = [ + "/home" + "/etc" + "/var/log/syslog*" + "/home/user/path with spaces" + ]; + }; + repositories = lib.mkOption { + type = listOf repository; + default = [ ]; + description = '' + A required list of local or remote repositories with paths and + optional labels (which can be used with the --repository flag to + select a repository). Tildes are expanded. Multiple repositories are + backed up to in sequence. Borg placeholders can be used. See the + output of "borg help placeholders" for details. See ssh_command for + SSH options like identity file or port. If systemd service is used, + then add local repository paths in the systemd service file to the + ReadWritePaths list. + ''; + example = [ + { + path = "ssh://user@backupserver/./sourcehostname.borg"; + label = "backupserver"; + } + { + path = "/mnt/backup"; + label = "local"; + } + ]; + }; }; }; - }; cfgfile = settingsFormat.generate "config.yaml" cfg.settings; in @@ -74,41 +94,48 @@ in type = lib.types.attrsOf cfgType; }; - enableConfigCheck = lib.mkEnableOption "checking all configurations during build time" // { default = true; }; + enableConfigCheck = lib.mkEnableOption "checking all configurations during build time" // { + default = true; + }; }; config = let configFiles = - (lib.optionalAttrs (cfg.settings != null) { "borgmatic/config.yaml".source = cfgfile; }) // - lib.mapAttrs' - (name: value: lib.nameValuePair - "borgmatic.d/${name}.yaml" - { source = settingsFormat.generate "${name}.yaml" value; }) - cfg.configurations; - borgmaticCheck = name: f: pkgs.runCommandCC "${name} validation" { } '' - ${pkgs.borgmatic}/bin/borgmatic -c ${f.source} config validate - touch $out - ''; + (lib.optionalAttrs (cfg.settings != null) { "borgmatic/config.yaml".source = cfgfile; }) + // lib.mapAttrs' ( + name: value: + lib.nameValuePair "borgmatic.d/${name}.yaml" { + source = settingsFormat.generate "${name}.yaml" value; + } + ) cfg.configurations; + borgmaticCheck = + name: f: + pkgs.runCommandCC "${name} validation" { } '' + ${pkgs.borgmatic}/bin/borgmatic -c ${f.source} config validate + touch $out + ''; in - lib.mkIf cfg.enable { + lib.mkIf cfg.enable { - warnings = [] - ++ lib.optional (cfg.settings != null && cfg.settings ? location) + warnings = + [ ] + ++ + lib.optional (cfg.settings != null && cfg.settings ? location) "`services.borgmatic.settings.location` is deprecated, please move your options out of sections to the global scope" - ++ lib.optional (lib.catAttrs "location" (lib.attrValues cfg.configurations) != []) - "`services.borgmatic.configurations..location` is deprecated, please move your options out of sections to the global scope" - ; + ++ + lib.optional (lib.catAttrs "location" (lib.attrValues cfg.configurations) != [ ]) + "`services.borgmatic.configurations..location` is deprecated, please move your options out of sections to the global scope"; - environment.systemPackages = [ pkgs.borgmatic ]; + environment.systemPackages = [ pkgs.borgmatic ]; - environment.etc = configFiles; + environment.etc = configFiles; - systemd.packages = [ pkgs.borgmatic ]; + systemd.packages = [ pkgs.borgmatic ]; - # Workaround: https://github.com/NixOS/nixpkgs/issues/81138 - systemd.timers.borgmatic.wantedBy = [ "timers.target" ]; + # Workaround: https://github.com/NixOS/nixpkgs/issues/81138 + systemd.timers.borgmatic.wantedBy = [ "timers.target" ]; - system.checks = lib.mkIf cfg.enableConfigCheck (lib.mapAttrsToList borgmaticCheck configFiles); - }; + system.checks = lib.mkIf cfg.enableConfigCheck (lib.mapAttrsToList borgmaticCheck configFiles); + }; } diff --git a/nixos/modules/services/backup/btrbk.nix b/nixos/modules/services/backup/btrbk.nix index fa6c67ff7cbfaa..a3745e3e6f716c 100644 --- a/nixos/modules/services/backup/btrbk.nix +++ b/nixos/modules/services/backup/btrbk.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let inherit (lib) concatLists @@ -28,64 +33,95 @@ let # 2. Sections that may contain (1). # 3. Sections that may contain (1) or (2). # 4. Etc. - prioOf = { name, value }: - if !isAttrs value then 0 # Leaf options. - else { - target = 1; # Contains: options. - subvolume = 2; # Contains: options, target. - volume = 3; # Contains: options, target, subvolume. - }.${name} or (throw "Unknow section '${name}'"); + prioOf = + { name, value }: + if !isAttrs value then + 0 # Leaf options. + else + { + target = 1; # Contains: options. + subvolume = 2; # Contains: options, target. + volume = 3; # Contains: options, target, subvolume. + } + .${name} or (throw "Unknow section '${name}'"); genConfig' = set: concatStringsSep "\n" (genConfig set); - genConfig = set: + genConfig = + set: let pairs = mapAttrsToList (name: value: { inherit name value; }) set; sortedPairs = sortOn prioOf pairs; in - concatMap genPair sortedPairs; - genSection = sec: secName: value: + concatMap genPair sortedPairs; + genSection = + sec: secName: value: [ "${sec} ${secName}" ] ++ map (x: " " + x) (genConfig value); - genPair = { name, value }: - if !isAttrs value - then [ "${name} ${value}" ] - else concatLists (mapAttrsToList (genSection name) value); + genPair = + { name, value }: + if !isAttrs value then + [ "${name} ${value}" ] + else + concatLists (mapAttrsToList (genSection name) value); sudoRule = { users = [ "btrbk" ]; commands = [ - { command = "${pkgs.btrfs-progs}/bin/btrfs"; options = [ "NOPASSWD" ]; } - { command = "${pkgs.coreutils}/bin/mkdir"; options = [ "NOPASSWD" ]; } - { command = "${pkgs.coreutils}/bin/readlink"; options = [ "NOPASSWD" ]; } + { + command = "${pkgs.btrfs-progs}/bin/btrfs"; + options = [ "NOPASSWD" ]; + } + { + command = "${pkgs.coreutils}/bin/mkdir"; + options = [ "NOPASSWD" ]; + } + { + command = "${pkgs.coreutils}/bin/readlink"; + options = [ "NOPASSWD" ]; + } # for ssh, they are not the same than the one hard coded in ${pkgs.btrbk} - { command = "/run/current-system/sw/bin/btrfs"; options = [ "NOPASSWD" ]; } - { command = "/run/current-system/sw/bin/mkdir"; options = [ "NOPASSWD" ]; } - { command = "/run/current-system/sw/bin/readlink"; options = [ "NOPASSWD" ]; } + { + command = "/run/current-system/sw/bin/btrfs"; + options = [ "NOPASSWD" ]; + } + { + command = "/run/current-system/sw/bin/mkdir"; + options = [ "NOPASSWD" ]; + } + { + command = "/run/current-system/sw/bin/readlink"; + options = [ "NOPASSWD" ]; + } ]; }; sudo_doas = - if config.security.sudo.enable || config.security.sudo-rs.enable then "sudo" - else if config.security.doas.enable then "doas" - else throw "The btrbk nixos module needs either sudo or doas enabled in the configuration"; + if config.security.sudo.enable || config.security.sudo-rs.enable then + "sudo" + else if config.security.doas.enable then + "doas" + else + throw "The btrbk nixos module needs either sudo or doas enabled in the configuration"; addDefaults = settings: { backend = "btrfs-progs-${sudo_doas}"; } // settings; - mkConfigFile = name: settings: pkgs.writeTextFile { - name = "btrbk-${name}.conf"; - text = genConfig' (addDefaults settings); - checkPhase = '' - set +e - ${pkgs.btrbk}/bin/btrbk -c $out dryrun - # According to btrbk(1), exit status 2 means parse error - # for CLI options or the config file. - if [[ $? == 2 ]]; then - echo "Btrbk configuration is invalid:" - cat $out - exit 1 - fi - set -e - ''; - }; + mkConfigFile = + name: settings: + pkgs.writeTextFile { + name = "btrbk-${name}.conf"; + text = genConfig' (addDefaults settings); + checkPhase = '' + set +e + ${pkgs.btrbk}/bin/btrbk -c $out dryrun + # According to btrbk(1), exit status 2 means parse error + # for CLI options or the config file. + if [[ $? == 2 ]]; then + echo "Btrbk configuration is invalid:" + cat $out + exit 1 + fi + set -e + ''; + }; streamCompressMap = { gzip = pkgs.gzip; @@ -128,75 +164,109 @@ in }; ioSchedulingClass = mkOption { description = "IO scheduling class for btrbk (see ionice(1) for a quick description). Applies to local instances, and remote ones connecting by ssh if set to idle."; - type = types.enum [ "idle" "best-effort" "realtime" ]; + type = types.enum [ + "idle" + "best-effort" + "realtime" + ]; default = "best-effort"; }; instances = mkOption { description = "Set of btrbk instances. The instance named `btrbk` is the default one."; - type = with types; - attrsOf ( - submodule { - options = { - onCalendar = mkOption { - type = types.nullOr types.str; - default = "daily"; - description = '' - How often this btrbk instance is started. See systemd.time(7) for more information about the format. - Setting it to null disables the timer, thus this instance can only be started manually. - ''; - }; - settings = mkOption { - type = types.submodule { - freeformType = let t = types.attrsOf (types.either types.str (t // { description = "instances of this type recursively"; })); in t; - options = { - stream_compress = mkOption { - description = '' - Compress the btrfs send stream before transferring it from/to remote locations using a - compression command. - ''; - type = types.enum ["gzip" "pigz" "bzip2" "pbzip2" "bzip3" "xz" "lzo" "lz4" "zstd" "no"]; - default = "no"; - }; + type = + with types; + attrsOf (submodule { + options = { + onCalendar = mkOption { + type = types.nullOr types.str; + default = "daily"; + description = '' + How often this btrbk instance is started. See systemd.time(7) for more information about the format. + Setting it to null disables the timer, thus this instance can only be started manually. + ''; + }; + settings = mkOption { + type = types.submodule { + freeformType = + let + t = types.attrsOf ( + types.either types.str (t // { description = "instances of this type recursively"; }) + ); + in + t; + options = { + stream_compress = mkOption { + description = '' + Compress the btrfs send stream before transferring it from/to remote locations using a + compression command. + ''; + type = types.enum [ + "gzip" + "pigz" + "bzip2" + "pbzip2" + "bzip3" + "xz" + "lzo" + "lz4" + "zstd" + "no" + ]; + default = "no"; }; }; - default = { }; - example = { - snapshot_preserve_min = "2d"; - snapshot_preserve = "14d"; - volume = { - "/mnt/btr_pool" = { - target = "/mnt/btr_backup/mylaptop"; - subvolume = { - "rootfs" = { }; - "home" = { snapshot_create = "always"; }; + }; + default = { }; + example = { + snapshot_preserve_min = "2d"; + snapshot_preserve = "14d"; + volume = { + "/mnt/btr_pool" = { + target = "/mnt/btr_backup/mylaptop"; + subvolume = { + "rootfs" = { }; + "home" = { + snapshot_create = "always"; }; }; }; }; - description = "configuration options for btrbk. Nested attrsets translate to subsections."; }; + description = "configuration options for btrbk. Nested attrsets translate to subsections."; }; - } - ); + }; + }); default = { }; }; sshAccess = mkOption { description = "SSH keys that should be able to make or push snapshots on this system remotely with btrbk"; - type = with types; listOf ( - submodule { + type = + with types; + listOf (submodule { options = { key = mkOption { type = str; description = "SSH public key allowed to login as user `btrbk` to run remote backups."; }; roles = mkOption { - type = listOf (enum [ "info" "source" "target" "delete" "snapshot" "send" "receive" ]); - example = [ "source" "info" "send" ]; + type = listOf (enum [ + "info" + "source" + "target" + "delete" + "snapshot" + "send" + "receive" + ]); + example = [ + "source" + "info" + "send" + ]; description = "What actions can be performed with this SSH key. See ssh_filter_btrbk(1) for details"; }; }; - } - ); + }); default = [ ]; }; }; @@ -210,22 +280,27 @@ in security.sudo-rs.extraRules = mkIf (sudo_doas == "sudo") [ sudoRule ]; security.doas = mkIf (sudo_doas == "doas") { - extraRules = let - doasCmdNoPass = cmd: { users = [ "btrbk" ]; cmd = cmd; noPass = true; }; - in + extraRules = + let + doasCmdNoPass = cmd: { + users = [ "btrbk" ]; + cmd = cmd; + noPass = true; + }; + in [ - (doasCmdNoPass "${pkgs.btrfs-progs}/bin/btrfs") - (doasCmdNoPass "${pkgs.coreutils}/bin/mkdir") - (doasCmdNoPass "${pkgs.coreutils}/bin/readlink") - # for ssh, they are not the same than the one hard coded in ${pkgs.btrbk} - (doasCmdNoPass "/run/current-system/sw/bin/btrfs") - (doasCmdNoPass "/run/current-system/sw/bin/mkdir") - (doasCmdNoPass "/run/current-system/sw/bin/readlink") + (doasCmdNoPass "${pkgs.btrfs-progs}/bin/btrfs") + (doasCmdNoPass "${pkgs.coreutils}/bin/mkdir") + (doasCmdNoPass "${pkgs.coreutils}/bin/readlink") + # for ssh, they are not the same than the one hard coded in ${pkgs.btrbk} + (doasCmdNoPass "/run/current-system/sw/bin/btrfs") + (doasCmdNoPass "/run/current-system/sw/bin/mkdir") + (doasCmdNoPass "/run/current-system/sw/bin/readlink") - # doas matches command, not binary - (doasCmdNoPass "btrfs") - (doasCmdNoPass "mkdir") - (doasCmdNoPass "readlink") + # doas matches command, not binary + (doasCmdNoPass "btrfs") + (doasCmdNoPass "mkdir") + (doasCmdNoPass "readlink") ]; }; users.users.btrbk = { @@ -235,21 +310,23 @@ in createHome = true; shell = "${pkgs.bash}/bin/bash"; group = "btrbk"; - openssh.authorizedKeys.keys = map - ( - v: - let - options = concatMapStringsSep " " (x: "--" + x) v.roles; - ioniceClass = { + openssh.authorizedKeys.keys = map ( + v: + let + options = concatMapStringsSep " " (x: "--" + x) v.roles; + ioniceClass = + { "idle" = 3; "best-effort" = 2; "realtime" = 1; - }.${cfg.ioSchedulingClass}; - sudo_doas_flag = "--${sudo_doas}"; - in - ''command="${pkgs.util-linux}/bin/ionice -t -c ${toString ioniceClass} ${optionalString (cfg.niceness >= 1) "${pkgs.coreutils}/bin/nice -n ${toString cfg.niceness}"} ${pkgs.btrbk}/share/btrbk/scripts/ssh_filter_btrbk.sh ${sudo_doas_flag} ${options}" ${v.key}'' - ) - cfg.sshAccess; + } + .${cfg.ioSchedulingClass}; + sudo_doas_flag = "--${sudo_doas}"; + in + ''command="${pkgs.util-linux}/bin/ionice -t -c ${toString ioniceClass} ${ + optionalString (cfg.niceness >= 1) "${pkgs.coreutils}/bin/nice -n ${toString cfg.niceness}" + } ${pkgs.btrbk}/share/btrbk/scripts/ssh_filter_btrbk.sh ${sudo_doas_flag} ${options}" ${v.key}'' + ) cfg.sshAccess; }; users.groups.btrbk = { }; systemd.tmpfiles.rules = [ @@ -257,56 +334,45 @@ in "d /var/lib/btrbk/.ssh 0700 btrbk btrbk" "f /var/lib/btrbk/.ssh/config 0700 btrbk btrbk - StrictHostKeyChecking=accept-new" ]; - environment.etc = mapAttrs' - ( - name: instance: { - name = "btrbk/${name}.conf"; - value.source = mkConfigFile name instance.settings; - } - ) - cfg.instances; - systemd.services = mapAttrs' - ( - name: instance: { - name = "btrbk-${name}"; - value = { - description = "Takes BTRFS snapshots and maintains retention policies."; - unitConfig.Documentation = "man:btrbk(1)"; - path = [ "/run/wrappers" ] - ++ cfg.extraPackages - ++ optional (instance.settings.stream_compress != "no") - (getAttr instance.settings.stream_compress streamCompressMap); - serviceConfig = { - User = "btrbk"; - Group = "btrbk"; - Type = "oneshot"; - ExecStart = "${pkgs.btrbk}/bin/btrbk -c /etc/btrbk/${name}.conf run"; - Nice = cfg.niceness; - IOSchedulingClass = cfg.ioSchedulingClass; - StateDirectory = "btrbk"; - }; - }; - } - ) - cfg.instances; + environment.etc = mapAttrs' (name: instance: { + name = "btrbk/${name}.conf"; + value.source = mkConfigFile name instance.settings; + }) cfg.instances; + systemd.services = mapAttrs' (name: instance: { + name = "btrbk-${name}"; + value = { + description = "Takes BTRFS snapshots and maintains retention policies."; + unitConfig.Documentation = "man:btrbk(1)"; + path = + [ "/run/wrappers" ] + ++ cfg.extraPackages + ++ optional (instance.settings.stream_compress != "no") ( + getAttr instance.settings.stream_compress streamCompressMap + ); + serviceConfig = { + User = "btrbk"; + Group = "btrbk"; + Type = "oneshot"; + ExecStart = "${pkgs.btrbk}/bin/btrbk -c /etc/btrbk/${name}.conf run"; + Nice = cfg.niceness; + IOSchedulingClass = cfg.ioSchedulingClass; + StateDirectory = "btrbk"; + }; + }; + }) cfg.instances; - systemd.timers = mapAttrs' - ( - name: instance: { - name = "btrbk-${name}"; - value = { - description = "Timer to take BTRFS snapshots and maintain retention policies."; - wantedBy = [ "timers.target" ]; - timerConfig = { - OnCalendar = instance.onCalendar; - AccuracySec = "10min"; - Persistent = true; - }; - }; - } - ) - (filterAttrs (name: instance: instance.onCalendar != null) - cfg.instances); + systemd.timers = mapAttrs' (name: instance: { + name = "btrbk-${name}"; + value = { + description = "Timer to take BTRFS snapshots and maintain retention policies."; + wantedBy = [ "timers.target" ]; + timerConfig = { + OnCalendar = instance.onCalendar; + AccuracySec = "10min"; + Persistent = true; + }; + }; + }) (filterAttrs (name: instance: instance.onCalendar != null) cfg.instances); }; } diff --git a/nixos/modules/services/backup/duplicati.nix b/nixos/modules/services/backup/duplicati.nix index 85f508141ba770..bb205d2ac0ddd6 100644 --- a/nixos/modules/services/backup/duplicati.nix +++ b/nixos/modules/services/backup/duplicati.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.duplicati; in diff --git a/nixos/modules/services/backup/duplicity.nix b/nixos/modules/services/backup/duplicity.nix index d6927d63ca7ad5..22b43c5e131f70 100644 --- a/nixos/modules/services/backup/duplicity.nix +++ b/nixos/modules/services/backup/duplicity.nix @@ -1,12 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.duplicity; stateDirectory = "/var/lib/duplicity"; localTarget = - if lib.hasPrefix "file://" cfg.targetUrl - then lib.removePrefix "file://" cfg.targetUrl else null; + if lib.hasPrefix "file://" cfg.targetUrl then lib.removePrefix "file://" cfg.targetUrl else null; in { @@ -99,7 +103,10 @@ in extraFlags = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "--backend-retry-delay" "100" ]; + example = [ + "--backend-retry-delay" + "100" + ]; description = '' Extra command-line flags passed to duplicity. See {manpage}`duplicity(1)`. @@ -155,45 +162,82 @@ in config = lib.mkIf cfg.enable { systemd = { - services.duplicity = { - description = "backup files with duplicity"; - - environment.HOME = stateDirectory; - - script = - let - target = lib.escapeShellArg cfg.targetUrl; - extra = lib.escapeShellArgs ([ "--archive-dir" stateDirectory ] ++ cfg.extraFlags); - dup = "${pkgs.duplicity}/bin/duplicity"; - in - '' - set -x - ${dup} cleanup ${target} --force ${extra} - ${lib.optionalString (cfg.cleanup.maxAge != null) "${dup} remove-older-than ${lib.escapeShellArg cfg.cleanup.maxAge} ${target} --force ${extra}"} - ${lib.optionalString (cfg.cleanup.maxFull != null) "${dup} remove-all-but-n-full ${toString cfg.cleanup.maxFull} ${target} --force ${extra}"} - ${lib.optionalString (cfg.cleanup.maxIncr != null) "${dup} remove-all-inc-of-but-n-full ${toString cfg.cleanup.maxIncr} ${target} --force ${extra}"} - exec ${dup} ${if cfg.fullIfOlderThan == "always" then "full" else "incr"} ${lib.escapeShellArgs ( - [ cfg.root cfg.targetUrl ] - ++ lib.optionals (cfg.includeFileList != null) [ "--include-filelist" cfg.includeFileList ] - ++ lib.optionals (cfg.excludeFileList != null) [ "--exclude-filelist" cfg.excludeFileList ] - ++ lib.concatMap (p: [ "--include" p ]) cfg.include - ++ lib.concatMap (p: [ "--exclude" p ]) cfg.exclude - ++ (lib.optionals (cfg.fullIfOlderThan != "never" && cfg.fullIfOlderThan != "always") [ "--full-if-older-than" cfg.fullIfOlderThan ]) - )} ${extra} - ''; - serviceConfig = { - PrivateTmp = true; - ProtectSystem = "strict"; - ProtectHome = "read-only"; - StateDirectory = baseNameOf stateDirectory; - } // lib.optionalAttrs (localTarget != null) { - ReadWritePaths = localTarget; - } // lib.optionalAttrs (cfg.secretFile != null) { - EnvironmentFile = cfg.secretFile; + services.duplicity = + { + description = "backup files with duplicity"; + + environment.HOME = stateDirectory; + + script = + let + target = lib.escapeShellArg cfg.targetUrl; + extra = lib.escapeShellArgs ( + [ + "--archive-dir" + stateDirectory + ] + ++ cfg.extraFlags + ); + dup = "${pkgs.duplicity}/bin/duplicity"; + in + '' + set -x + ${dup} cleanup ${target} --force ${extra} + ${lib.optionalString ( + cfg.cleanup.maxAge != null + ) "${dup} remove-older-than ${lib.escapeShellArg cfg.cleanup.maxAge} ${target} --force ${extra}"} + ${lib.optionalString ( + cfg.cleanup.maxFull != null + ) "${dup} remove-all-but-n-full ${toString cfg.cleanup.maxFull} ${target} --force ${extra}"} + ${lib.optionalString ( + cfg.cleanup.maxIncr != null + ) "${dup} remove-all-inc-of-but-n-full ${toString cfg.cleanup.maxIncr} ${target} --force ${extra}"} + exec ${dup} ${if cfg.fullIfOlderThan == "always" then "full" else "incr"} ${ + lib.escapeShellArgs ( + [ + cfg.root + cfg.targetUrl + ] + ++ lib.optionals (cfg.includeFileList != null) [ + "--include-filelist" + cfg.includeFileList + ] + ++ lib.optionals (cfg.excludeFileList != null) [ + "--exclude-filelist" + cfg.excludeFileList + ] + ++ lib.concatMap (p: [ + "--include" + p + ]) cfg.include + ++ lib.concatMap (p: [ + "--exclude" + p + ]) cfg.exclude + ++ (lib.optionals (cfg.fullIfOlderThan != "never" && cfg.fullIfOlderThan != "always") [ + "--full-if-older-than" + cfg.fullIfOlderThan + ]) + ) + } ${extra} + ''; + serviceConfig = + { + PrivateTmp = true; + ProtectSystem = "strict"; + ProtectHome = "read-only"; + StateDirectory = baseNameOf stateDirectory; + } + // lib.optionalAttrs (localTarget != null) { + ReadWritePaths = localTarget; + } + // lib.optionalAttrs (cfg.secretFile != null) { + EnvironmentFile = cfg.secretFile; + }; + } + // lib.optionalAttrs (cfg.frequency != null) { + startAt = cfg.frequency; }; - } // lib.optionalAttrs (cfg.frequency != null) { - startAt = cfg.frequency; - }; tmpfiles.rules = lib.optional (localTarget != null) "d ${localTarget} 0700 root root -"; }; diff --git a/nixos/modules/services/backup/mysql-backup.nix b/nixos/modules/services/backup/mysql-backup.nix index 8ad4f98dce8a37..b30579103699e4 100644 --- a/nixos/modules/services/backup/mysql-backup.nix +++ b/nixos/modules/services/backup/mysql-backup.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (pkgs) mariadb gzip; @@ -53,7 +58,7 @@ in }; databases = lib.mkOption { - default = []; + default = [ ]; type = lib.types.listOf lib.types.str; description = '' List of database names to dump. @@ -97,15 +102,18 @@ in }; }; - services.mysql.ensureUsers = [{ - name = cfg.user; - ensurePermissions = with lib; - let - privs = "SELECT, SHOW VIEW, TRIGGER, LOCK TABLES"; - grant = db: lib.nameValuePair "${db}.*" privs; - in + services.mysql.ensureUsers = [ + { + name = cfg.user; + ensurePermissions = + with lib; + let + privs = "SELECT, SHOW VIEW, TRIGGER, LOCK TABLES"; + grant = db: lib.nameValuePair "${db}.*" privs; + in lib.listToAttrs (map grant cfg.databases); - }]; + } + ]; systemd = { timers.mysql-backup = { diff --git a/nixos/modules/services/backup/postgresql-backup.nix b/nixos/modules/services/backup/postgresql-backup.nix index 3302375c78899d..8a3a8173354ed8 100644 --- a/nixos/modules/services/backup/postgresql-backup.nix +++ b/nixos/modules/services/backup/postgresql-backup.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.postgresqlBackup; - postgresqlBackupService = db: dumpCmd: + postgresqlBackupService = + db: dumpCmd: let compressSuffixes = { "none" = ""; @@ -23,14 +29,18 @@ let prevFile = mkSqlPath ".prev" compressSuffix; prevFiles = map (mkSqlPath ".prev") (lib.attrValues compressSuffixes); inProgressFile = mkSqlPath ".in-progress" compressSuffix; - in { + in + { enable = true; description = "Backup of ${db} database(s)"; requires = [ "postgresql.service" ]; - path = [ pkgs.coreutils config.services.postgresql.package ]; + path = [ + pkgs.coreutils + config.services.postgresql.package + ]; script = '' set -e -o pipefail @@ -57,12 +67,13 @@ let startAt = cfg.startAt; }; -in { +in +{ imports = [ (lib.mkRemovedOptionModule [ "services" "postgresqlBackup" "period" ] '' - A systemd timer is now used instead of cron. - The starting time can be configured via services.postgresqlBackup.startAt. + A systemd timer is now used instead of cron. + The starting time can be configured via services.postgresqlBackup.startAt. '') ]; @@ -81,7 +92,7 @@ in { }; backupAll = lib.mkOption { - default = cfg.databases == []; + default = cfg.databases == [ ]; defaultText = lib.literalExpression "services.postgresqlBackup.databases == []"; type = lib.types.bool; description = '' @@ -94,7 +105,7 @@ in { }; databases = lib.mkOption { - default = []; + default = [ ]; type = lib.types.listOf lib.types.str; description = '' List of database names to dump. @@ -121,7 +132,11 @@ in { }; compression = lib.mkOption { - type = lib.types.enum ["none" "gzip" "zstd"]; + type = lib.types.enum [ + "none" + "gzip" + "zstd" + ]; default = "gzip"; description = '' The type of compression to use on the generated database dump. @@ -144,13 +159,14 @@ in { { assertions = [ { - assertion = cfg.backupAll -> cfg.databases == []; + assertion = cfg.backupAll -> cfg.databases == [ ]; message = "config.services.postgresqlBackup.backupAll cannot be used together with config.services.postgresqlBackup.databases"; } { - assertion = cfg.compression == "none" || - (cfg.compression == "gzip" && cfg.compressionLevel >= 1 && cfg.compressionLevel <= 9) || - (cfg.compression == "zstd" && cfg.compressionLevel >= 1 && cfg.compressionLevel <= 19); + assertion = + cfg.compression == "none" + || (cfg.compression == "gzip" && cfg.compressionLevel >= 1 && cfg.compressionLevel <= 9) + || (cfg.compression == "zstd" && cfg.compressionLevel >= 1 && cfg.compressionLevel <= 19); message = "config.services.postgresqlBackup.compressionLevel must be set between 1 and 9 for gzip and 1 and 19 for zstd"; } ]; @@ -161,17 +177,21 @@ in { ]; }) (lib.mkIf (cfg.enable && cfg.backupAll) { - systemd.services.postgresqlBackup = - postgresqlBackupService "all" "pg_dumpall"; + systemd.services.postgresqlBackup = postgresqlBackupService "all" "pg_dumpall"; }) (lib.mkIf (cfg.enable && !cfg.backupAll) { - systemd.services = lib.listToAttrs (map (db: - let - cmd = "pg_dump ${cfg.pgdumpOptions} ${db}"; - in { - name = "postgresqlBackup-${db}"; - value = postgresqlBackupService db cmd; - }) cfg.databases); + systemd.services = lib.listToAttrs ( + map ( + db: + let + cmd = "pg_dump ${cfg.pgdumpOptions} ${db}"; + in + { + name = "postgresqlBackup-${db}"; + value = postgresqlBackupService db cmd; + } + ) cfg.databases + ); }) ]; diff --git a/nixos/modules/services/backup/postgresql-wal-receiver.nix b/nixos/modules/services/backup/postgresql-wal-receiver.nix index b355637ff5a038..361f572d61d6da 100644 --- a/nixos/modules/services/backup/postgresql-wal-receiver.nix +++ b/nixos/modules/services/backup/postgresql-wal-receiver.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let receiverSubmodule = { options = { @@ -108,7 +113,8 @@ let }; }; -in { +in +{ options = { services.postgresqlWalReceiver = { receivers = lib.mkOption { @@ -133,65 +139,76 @@ in { }; }; - config = let - receivers = config.services.postgresqlWalReceiver.receivers; - in lib.mkIf (receivers != { }) { - users = { - users.postgres = { - uid = config.ids.uids.postgres; - group = "postgres"; - description = "PostgreSQL server user"; + config = + let + receivers = config.services.postgresqlWalReceiver.receivers; + in + lib.mkIf (receivers != { }) { + users = { + users.postgres = { + uid = config.ids.uids.postgres; + group = "postgres"; + description = "PostgreSQL server user"; + }; + + groups.postgres = { + gid = config.ids.gids.postgres; + }; }; - groups.postgres = { - gid = config.ids.gids.postgres; - }; + assertions = lib.concatLists ( + lib.attrsets.mapAttrsToList (name: config: [ + { + assertion = config.compress > 0 -> lib.versionAtLeast config.postgresqlPackage.version "10"; + message = "Invalid configuration for WAL receiver \"${name}\": compress requires PostgreSQL version >= 10."; + } + ]) receivers + ); + + systemd.tmpfiles.rules = lib.mapAttrsToList (name: config: '' + d ${lib.escapeShellArg config.directory} 0750 postgres postgres - - + '') receivers; + + systemd.services = lib.mapAttrs' ( + name: config: + lib.nameValuePair "postgresql-wal-receiver-${name}" { + description = "PostgreSQL WAL receiver (${name})"; + wantedBy = [ "multi-user.target" ]; + startLimitIntervalSec = 0; # retry forever, useful in case of network disruption + + serviceConfig = { + User = "postgres"; + Group = "postgres"; + KillSignal = "SIGINT"; + Restart = "always"; + RestartSec = 60; + }; + + inherit (config) environment; + + script = + let + receiverCommand = + postgresqlPackage: + if (lib.versionAtLeast postgresqlPackage.version "10") then + "${postgresqlPackage}/bin/pg_receivewal" + else + "${postgresqlPackage}/bin/pg_receivexlog"; + in + '' + ${receiverCommand config.postgresqlPackage} \ + --no-password \ + --directory=${lib.escapeShellArg config.directory} \ + --status-interval=${toString config.statusInterval} \ + --dbname=${lib.escapeShellArg config.connection} \ + ${lib.optionalString (config.compress > 0) "--compress=${toString config.compress}"} \ + ${lib.optionalString (config.slot != "") "--slot=${lib.escapeShellArg config.slot}"} \ + ${lib.optionalString config.synchronous "--synchronous"} \ + ${lib.concatStringsSep " " config.extraArgs} + ''; + } + ) receivers; }; - assertions = lib.concatLists (lib.attrsets.mapAttrsToList (name: config: [ - { - assertion = config.compress > 0 -> lib.versionAtLeast config.postgresqlPackage.version "10"; - message = "Invalid configuration for WAL receiver \"${name}\": compress requires PostgreSQL version >= 10."; - } - ]) receivers); - - systemd.tmpfiles.rules = lib.mapAttrsToList (name: config: '' - d ${lib.escapeShellArg config.directory} 0750 postgres postgres - - - '') receivers; - - systemd.services = lib.mapAttrs' (name: config: lib.nameValuePair "postgresql-wal-receiver-${name}" { - description = "PostgreSQL WAL receiver (${name})"; - wantedBy = [ "multi-user.target" ]; - startLimitIntervalSec = 0; # retry forever, useful in case of network disruption - - serviceConfig = { - User = "postgres"; - Group = "postgres"; - KillSignal = "SIGINT"; - Restart = "always"; - RestartSec = 60; - }; - - inherit (config) environment; - - script = let - receiverCommand = postgresqlPackage: - if (lib.versionAtLeast postgresqlPackage.version "10") - then "${postgresqlPackage}/bin/pg_receivewal" - else "${postgresqlPackage}/bin/pg_receivexlog"; - in '' - ${receiverCommand config.postgresqlPackage} \ - --no-password \ - --directory=${lib.escapeShellArg config.directory} \ - --status-interval=${toString config.statusInterval} \ - --dbname=${lib.escapeShellArg config.connection} \ - ${lib.optionalString (config.compress > 0) "--compress=${toString config.compress}"} \ - ${lib.optionalString (config.slot != "") "--slot=${lib.escapeShellArg config.slot}"} \ - ${lib.optionalString config.synchronous "--synchronous"} \ - ${lib.concatStringsSep " " config.extraArgs} - ''; - }) receivers; - }; - meta.maintainers = with lib.maintainers; [ pacien ]; } diff --git a/nixos/modules/services/backup/restic-rest-server.nix b/nixos/modules/services/backup/restic-rest-server.nix index 333609444da2af..5850b17e9cb742 100644 --- a/nixos/modules/services/backup/restic-rest-server.nix +++ b/nixos/modules/services/backup/restic-rest-server.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.restic.server; in @@ -48,7 +53,7 @@ in extraFlags = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Extra commandline options to pass to Restic REST server. ''; @@ -58,14 +63,21 @@ in }; config = lib.mkIf cfg.enable { - assertions = [{ - assertion = lib.substring 0 1 cfg.listenAddress != ":"; - message = "The restic-rest-server now uses systemd socket activation, which expects only the Port number: services.restic.server.listenAddress = \"${lib.substring 1 6 cfg.listenAddress}\";"; - }]; + assertions = [ + { + assertion = lib.substring 0 1 cfg.listenAddress != ":"; + message = "The restic-rest-server now uses systemd socket activation, which expects only the Port number: services.restic.server.listenAddress = \"${ + lib.substring 1 6 cfg.listenAddress + }\";"; + } + ]; systemd.services.restic-rest-server = { description = "Restic REST Server"; - after = [ "network.target" "restic-rest-server.socket" ]; + after = [ + "network.target" + "restic-rest-server.socket" + ]; requires = [ "restic-rest-server.socket" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { @@ -107,7 +119,7 @@ in RestrictSUIDSGID = true; SystemCallArchitectures = "native"; SystemCallFilter = "@system-service"; - UMask = 027; + UMask = 27; }; }; @@ -117,7 +129,7 @@ in }; systemd.tmpfiles.rules = lib.mkIf cfg.privateRepos [ - "f ${cfg.dataDir}/.htpasswd 0700 restic restic -" + "f ${cfg.dataDir}/.htpasswd 0700 restic restic -" ]; users.users.restic = { diff --git a/nixos/modules/services/backup/rsnapshot.nix b/nixos/modules/services/backup/rsnapshot.nix index aedb8acd60ac13..280c5f7f6184d3 100644 --- a/nixos/modules/services/backup/rsnapshot.nix +++ b/nixos/modules/services/backup/rsnapshot.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.rsnapshot; cfgfile = pkgs.writeText "rsnapshot.conf" '' @@ -47,8 +52,11 @@ in }; cronIntervals = lib.mkOption { - default = {}; - example = { hourly = "0 * * * *"; daily = "50 21 * * *"; }; + default = { }; + example = { + hourly = "0 * * * *"; + daily = "50 21 * * *"; + }; type = lib.types.attrsOf lib.types.str; description = '' Periodicity at which intervals should be run by cron. @@ -59,14 +67,17 @@ in }; }; - config = lib.mkIf cfg.enable (lib.mkMerge [ - { - services.cron.systemCronJobs = - lib.mapAttrsToList (interval: time: "${time} root ${pkgs.rsnapshot}/bin/rsnapshot -c ${cfgfile} ${interval}") cfg.cronIntervals; - } - (lib.mkIf cfg.enableManualRsnapshot { - environment.systemPackages = [ pkgs.rsnapshot ]; - environment.etc."rsnapshot.conf".source = cfgfile; - }) - ]); + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + { + services.cron.systemCronJobs = lib.mapAttrsToList ( + interval: time: "${time} root ${pkgs.rsnapshot}/bin/rsnapshot -c ${cfgfile} ${interval}" + ) cfg.cronIntervals; + } + (lib.mkIf cfg.enableManualRsnapshot { + environment.systemPackages = [ pkgs.rsnapshot ]; + environment.etc."rsnapshot.conf".source = cfgfile; + }) + ] + ); } diff --git a/nixos/modules/services/backup/snapraid.nix b/nixos/modules/services/backup/snapraid.nix index 72b4d9caef3c3a..32e5cf630ffd01 100644 --- a/nixos/modules/services/backup/snapraid.nix +++ b/nixos/modules/services/backup/snapraid.nix @@ -1,5 +1,11 @@ -{ config, lib, pkgs, ... }: -let cfg = config.services.snapraid; +{ + config, + lib, + pkgs, + ... +}: +let + cfg = config.services.snapraid; in { imports = [ @@ -44,15 +50,18 @@ in }; exclude = lib.mkOption { default = [ ]; - example = [ "*.unrecoverable" "/tmp/" "/lost+found/" ]; + example = [ + "*.unrecoverable" + "/tmp/" + "/lost+found/" + ]; description = "SnapRAID exclude directives."; type = listOf str; }; touchBeforeSync = lib.mkOption { default = true; example = false; - description = - "Whether {command}`snapraid touch` should be run before {command}`snapraid sync`."; + description = "Whether {command}`snapraid touch` should be run before {command}`snapraid sync`."; type = bool; }; sync.interval = lib.mkOption { @@ -71,15 +80,13 @@ in plan = lib.mkOption { default = 8; example = 5; - description = - "Percent of the array that should be checked by {command}`snapraid scrub`."; + description = "Percent of the array that should be checked by {command}`snapraid scrub`."; type = int; }; olderThan = lib.mkOption { default = 10; example = 20; - description = - "Number of days since data was last scrubbed before it can be scrubbed again."; + description = "Number of days since data was last scrubbed before it can be scrubbed again."; type = int; }; }; @@ -110,8 +117,7 @@ in } { assertion = builtins.length cfg.contentFiles >= nParity + 1; - message = - "There must be at least one SnapRAID content file for each SnapRAID parity file plus one."; + message = "There must be at least one SnapRAID content file for each SnapRAID parity file plus one."; } ]; @@ -119,19 +125,23 @@ in systemPackages = with pkgs; [ snapraid ]; etc."snapraid.conf" = { - text = with cfg; + text = + with cfg; let prependData = mkPrepend "data "; prependContent = mkPrepend "content "; prependExclude = mkPrepend "exclude "; in - lib.concatStringsSep "\n" - (map prependData - ((lib.mapAttrsToList (name: value: name + " " + value)) dataDisks) - ++ lib.zipListsWith (a: b: a + b) - ([ "parity " ] ++ map (i: toString i + "-parity ") (lib.range 2 6)) - parityFiles ++ map prependContent contentFiles - ++ map prependExclude exclude) + "\n" + extraConfig; + lib.concatStringsSep "\n" ( + map prependData ((lib.mapAttrsToList (name: value: name + " " + value)) dataDisks) + ++ lib.zipListsWith (a: b: a + b) ( + [ "parity " ] ++ map (i: toString i + "-parity ") (lib.range 2 6) + ) parityFiles + ++ map prependContent contentFiles + ++ map prependExclude exclude + ) + + "\n" + + extraConfig; }; }; @@ -141,9 +151,7 @@ in startAt = scrub.interval; serviceConfig = { Type = "oneshot"; - ExecStart = "${pkgs.snapraid}/bin/snapraid scrub -p ${ - toString scrub.plan - } -o ${toString scrub.olderThan}"; + ExecStart = "${pkgs.snapraid}/bin/snapraid scrub -p ${toString scrub.plan} -o ${toString scrub.olderThan}"; Nice = 19; IOSchedulingPriority = 7; CPUSchedulingPolicy = "batch"; @@ -176,60 +184,57 @@ in let contentDirs = map dirOf contentFiles; in - lib.unique ( - lib.attrValues dataDisks ++ contentDirs - ); + lib.unique (lib.attrValues dataDisks ++ contentDirs); }; unitConfig.After = "snapraid-sync.service"; }; snapraid-sync = { description = "Synchronize the state of the SnapRAID array"; startAt = sync.interval; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${pkgs.snapraid}/bin/snapraid sync"; - Nice = 19; - IOSchedulingPriority = 7; - CPUSchedulingPolicy = "batch"; + serviceConfig = + { + Type = "oneshot"; + ExecStart = "${pkgs.snapraid}/bin/snapraid sync"; + Nice = 19; + IOSchedulingPriority = 7; + CPUSchedulingPolicy = "batch"; - LockPersonality = true; - MemoryDenyWriteExecute = true; - NoNewPrivileges = true; - PrivateTmp = true; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - RestrictAddressFamilies = "none"; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallFilter = "@system-service"; - SystemCallErrorNumber = "EPERM"; - CapabilityBoundingSet = "CAP_DAC_OVERRIDE" + - lib.optionalString cfg.touchBeforeSync " CAP_FOWNER"; + LockPersonality = true; + MemoryDenyWriteExecute = true; + NoNewPrivileges = true; + PrivateTmp = true; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + RestrictAddressFamilies = "none"; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallFilter = "@system-service"; + SystemCallErrorNumber = "EPERM"; + CapabilityBoundingSet = "CAP_DAC_OVERRIDE" + lib.optionalString cfg.touchBeforeSync " CAP_FOWNER"; - ProtectSystem = "strict"; - ProtectHome = "read-only"; - ReadWritePaths = - # sync requires access to directories containing content files - # to remove them if they are stale - let - contentDirs = map dirOf contentFiles; - # Multiple "split" parity files can be specified in a single - # "parityFile", separated by a comma. - # https://www.snapraid.it/manual#7.1 - splitParityFiles = map (s: lib.splitString "," s) parityFiles; - in - lib.unique ( - lib.attrValues dataDisks ++ splitParityFiles ++ contentDirs - ); - } // lib.optionalAttrs touchBeforeSync { - ExecStartPre = "${pkgs.snapraid}/bin/snapraid touch"; - }; + ProtectSystem = "strict"; + ProtectHome = "read-only"; + ReadWritePaths = + # sync requires access to directories containing content files + # to remove them if they are stale + let + contentDirs = map dirOf contentFiles; + # Multiple "split" parity files can be specified in a single + # "parityFile", separated by a comma. + # https://www.snapraid.it/manual#7.1 + splitParityFiles = map (s: lib.splitString "," s) parityFiles; + in + lib.unique (lib.attrValues dataDisks ++ splitParityFiles ++ contentDirs); + } + // lib.optionalAttrs touchBeforeSync { + ExecStartPre = "${pkgs.snapraid}/bin/snapraid touch"; + }; }; }; }; diff --git a/nixos/modules/services/backup/tarsnap.nix b/nixos/modules/services/backup/tarsnap.nix index 43493997931c16..235042a143e6d8 100644 --- a/nixos/modules/services/backup/tarsnap.nix +++ b/nixos/modules/services/backup/tarsnap.nix @@ -1,4 +1,11 @@ -{ config, lib, options, pkgs, utils, ... }: +{ + config, + lib, + options, + pkgs, + utils, + ... +}: let gcfg = config.services.tarsnap; opt = options.services.tarsnap; @@ -9,7 +16,7 @@ let ${lib.optionalString cfg.nodump "nodump"} ${lib.optionalString cfg.printStats "print-stats"} ${lib.optionalString cfg.printStats "humanize-numbers"} - ${lib.optionalString (cfg.checkpointBytes != null) ("checkpoint-bytes "+cfg.checkpointBytes)} + ${lib.optionalString (cfg.checkpointBytes != null) ("checkpoint-bytes " + cfg.checkpointBytes)} ${lib.optionalString cfg.aggressiveNetworking "aggressive-networking"} ${lib.concatStringsSep "\n" (map (v: "exclude ${v}") cfg.excludes)} ${lib.concatStringsSep "\n" (map (v: "include ${v}") cfg.includes)} @@ -22,7 +29,11 @@ let in { imports = [ - (lib.mkRemovedOptionModule [ "services" "tarsnap" "cachedir" ] "Use services.tarsnap.archives..cachedir") + (lib.mkRemovedOptionModule [ + "services" + "tarsnap" + "cachedir" + ] "Use services.tarsnap.archives..cachedir") ]; options = { @@ -59,205 +70,208 @@ in }; archives = lib.mkOption { - type = lib.types.attrsOf (lib.types.submodule ({ config, options, ... }: - { - options = { - keyfile = lib.mkOption { - type = lib.types.str; - default = gcfg.keyfile; - defaultText = lib.literalExpression "config.${opt.keyfile}"; - description = '' - Set a specific keyfile for this archive. This defaults to - `"/root/tarsnap.key"` if left unspecified. - - Use this option if you want to run multiple backups - concurrently - each archive must have a unique key. You can - generate a write-only key derived from your master key (which - is recommended) using `tarsnap-keymgmt(1)`. - - Note: every archive must have an individual master key. You - must generate multiple keys with - `tarsnap-keygen(1)`, and then generate write - only keys from those. - - The keyfile name should be given as a string and not a path, to - avoid the key being copied into the Nix store. - ''; - }; - - cachedir = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = "/var/cache/tarsnap/${utils.escapeSystemdPath config.keyfile}"; - defaultText = lib.literalExpression '' - "/var/cache/tarsnap/''${utils.escapeSystemdPath config.${options.keyfile}}" - ''; - description = '' - The cache allows tarsnap to identify previously stored data - blocks, reducing archival time and bandwidth usage. - - Should the cache become desynchronized or corrupted, tarsnap - will refuse to run until you manually rebuild the cache with - {command}`tarsnap --fsck`. - - Set to `null` to disable caching. - ''; - }; - - nodump = lib.mkOption { - type = lib.types.bool; - default = true; - description = '' - Exclude files with the `nodump` flag. - ''; - }; - - printStats = lib.mkOption { - type = lib.types.bool; - default = true; - description = '' - Print global archive statistics upon completion. - The output is available via - {command}`systemctl status tarsnap-archive-name`. - ''; - }; - - checkpointBytes = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = "1GB"; - description = '' - Create a checkpoint every `checkpointBytes` - of uploaded data (optionally specified using an SI prefix). - - 1GB is the minimum value. A higher value is recommended, - as checkpointing is expensive. - - Set to `null` to disable checkpointing. - ''; + type = lib.types.attrsOf ( + lib.types.submodule ( + { config, options, ... }: + { + options = { + keyfile = lib.mkOption { + type = lib.types.str; + default = gcfg.keyfile; + defaultText = lib.literalExpression "config.${opt.keyfile}"; + description = '' + Set a specific keyfile for this archive. This defaults to + `"/root/tarsnap.key"` if left unspecified. + + Use this option if you want to run multiple backups + concurrently - each archive must have a unique key. You can + generate a write-only key derived from your master key (which + is recommended) using `tarsnap-keymgmt(1)`. + + Note: every archive must have an individual master key. You + must generate multiple keys with + `tarsnap-keygen(1)`, and then generate write + only keys from those. + + The keyfile name should be given as a string and not a path, to + avoid the key being copied into the Nix store. + ''; + }; + + cachedir = lib.mkOption { + type = lib.types.nullOr lib.types.path; + default = "/var/cache/tarsnap/${utils.escapeSystemdPath config.keyfile}"; + defaultText = lib.literalExpression '' + "/var/cache/tarsnap/''${utils.escapeSystemdPath config.${options.keyfile}}" + ''; + description = '' + The cache allows tarsnap to identify previously stored data + blocks, reducing archival time and bandwidth usage. + + Should the cache become desynchronized or corrupted, tarsnap + will refuse to run until you manually rebuild the cache with + {command}`tarsnap --fsck`. + + Set to `null` to disable caching. + ''; + }; + + nodump = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Exclude files with the `nodump` flag. + ''; + }; + + printStats = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Print global archive statistics upon completion. + The output is available via + {command}`systemctl status tarsnap-archive-name`. + ''; + }; + + checkpointBytes = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = "1GB"; + description = '' + Create a checkpoint every `checkpointBytes` + of uploaded data (optionally specified using an SI prefix). + + 1GB is the minimum value. A higher value is recommended, + as checkpointing is expensive. + + Set to `null` to disable checkpointing. + ''; + }; + + period = lib.mkOption { + type = lib.types.str; + default = "01:15"; + example = "hourly"; + description = '' + Create archive at this interval. + + The format is described in + {manpage}`systemd.time(7)`. + ''; + }; + + aggressiveNetworking = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Upload data over multiple TCP connections, potentially + increasing tarsnap's bandwidth utilisation at the cost + of slowing down all other network traffic. Not + recommended unless TCP congestion is the dominant + limiting factor. + ''; + }; + + directories = lib.mkOption { + type = lib.types.listOf lib.types.path; + default = [ ]; + description = "List of filesystem paths to archive."; + }; + + excludes = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + description = '' + Exclude files and directories matching these patterns. + ''; + }; + + includes = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + description = '' + Include only files and directories matching these + patterns (the empty list includes everything). + + Exclusions have precedence over inclusions. + ''; + }; + + lowmem = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Reduce memory consumption by not caching small files. + Possibly beneficial if the average file size is smaller + than 1 MB and the number of files is lower than the + total amount of RAM in KB. + ''; + }; + + verylowmem = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Reduce memory consumption by a factor of 2 beyond what + `lowmem` does, at the cost of significantly + slowing down the archiving process. + ''; + }; + + maxbw = lib.mkOption { + type = lib.types.nullOr lib.types.int; + default = null; + description = '' + Abort archival if upstream bandwidth usage in bytes + exceeds this threshold. + ''; + }; + + maxbwRateUp = lib.mkOption { + type = lib.types.nullOr lib.types.int; + default = null; + example = lib.literalExpression "25 * 1000"; + description = '' + Upload bandwidth rate limit in bytes. + ''; + }; + + maxbwRateDown = lib.mkOption { + type = lib.types.nullOr lib.types.int; + default = null; + example = lib.literalExpression "50 * 1000"; + description = '' + Download bandwidth rate limit in bytes. + ''; + }; + + verbose = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Whether to produce verbose logging output. + ''; + }; + explicitSymlinks = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Whether to follow symlinks specified as archives. + ''; + }; + followSymlinks = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Whether to follow all symlinks in archive trees. + ''; + }; }; + } + ) + ); - period = lib.mkOption { - type = lib.types.str; - default = "01:15"; - example = "hourly"; - description = '' - Create archive at this interval. - - The format is described in - {manpage}`systemd.time(7)`. - ''; - }; - - aggressiveNetworking = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Upload data over multiple TCP connections, potentially - increasing tarsnap's bandwidth utilisation at the cost - of slowing down all other network traffic. Not - recommended unless TCP congestion is the dominant - limiting factor. - ''; - }; - - directories = lib.mkOption { - type = lib.types.listOf lib.types.path; - default = []; - description = "List of filesystem paths to archive."; - }; - - excludes = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - description = '' - Exclude files and directories matching these patterns. - ''; - }; - - includes = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - description = '' - Include only files and directories matching these - patterns (the empty list includes everything). - - Exclusions have precedence over inclusions. - ''; - }; - - lowmem = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Reduce memory consumption by not caching small files. - Possibly beneficial if the average file size is smaller - than 1 MB and the number of files is lower than the - total amount of RAM in KB. - ''; - }; - - verylowmem = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Reduce memory consumption by a factor of 2 beyond what - `lowmem` does, at the cost of significantly - slowing down the archiving process. - ''; - }; - - maxbw = lib.mkOption { - type = lib.types.nullOr lib.types.int; - default = null; - description = '' - Abort archival if upstream bandwidth usage in bytes - exceeds this threshold. - ''; - }; - - maxbwRateUp = lib.mkOption { - type = lib.types.nullOr lib.types.int; - default = null; - example = lib.literalExpression "25 * 1000"; - description = '' - Upload bandwidth rate limit in bytes. - ''; - }; - - maxbwRateDown = lib.mkOption { - type = lib.types.nullOr lib.types.int; - default = null; - example = lib.literalExpression "50 * 1000"; - description = '' - Download bandwidth rate limit in bytes. - ''; - }; - - verbose = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Whether to produce verbose logging output. - ''; - }; - explicitSymlinks = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Whether to follow symlinks specified as archives. - ''; - }; - followSymlinks = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Whether to follow all symlinks in archive trees. - ''; - }; - }; - } - )); - - default = {}; + default = { }; example = lib.literalExpression '' { @@ -291,115 +305,146 @@ in config = lib.mkIf gcfg.enable { assertions = - (lib.mapAttrsToList (name: cfg: - { assertion = cfg.directories != []; - message = "Must specify paths for tarsnap to back up"; - }) gcfg.archives) ++ - (lib.mapAttrsToList (name: cfg: - { assertion = !(cfg.lowmem && cfg.verylowmem); - message = "You cannot set both lowmem and verylowmem"; - }) gcfg.archives); + (lib.mapAttrsToList (name: cfg: { + assertion = cfg.directories != [ ]; + message = "Must specify paths for tarsnap to back up"; + }) gcfg.archives) + ++ (lib.mapAttrsToList (name: cfg: { + assertion = !(cfg.lowmem && cfg.verylowmem); + message = "You cannot set both lowmem and verylowmem"; + }) gcfg.archives); systemd.services = - (lib.mapAttrs' (name: cfg: lib.nameValuePair "tarsnap-${name}" { - description = "Tarsnap archive '${name}'"; - requires = [ "network-online.target" ]; - after = [ "network-online.target" ]; - - path = with pkgs; [ iputils gcfg.package util-linux ]; - - # In order for the persistent tarsnap timer to work reliably, we have to - # make sure that the tarsnap server is reachable after systemd starts up - # the service - therefore we sleep in a loop until we can ping the - # endpoint. - preStart = '' - while ! ping -4 -q -c 1 v1-0-0-server.tarsnap.com &> /dev/null; do sleep 3; done - ''; - - script = let - tarsnap = ''${lib.getExe gcfg.package} --configfile "/etc/tarsnap/${name}.conf"''; - run = ''${tarsnap} -c -f "${name}-$(date +"%Y%m%d%H%M%S")" \ - ${lib.optionalString cfg.verbose "-v"} \ - ${lib.optionalString cfg.explicitSymlinks "-H"} \ - ${lib.optionalString cfg.followSymlinks "-L"} \ - ${lib.concatStringsSep " " cfg.directories}''; - cachedir = lib.escapeShellArg cfg.cachedir; - in if (cfg.cachedir != null) then '' - mkdir -p ${cachedir} - chmod 0700 ${cachedir} - - ( flock 9 - if [ ! -e ${cachedir}/firstrun ]; then - ( flock 10 - flock -u 9 - ${tarsnap} --fsck - flock 9 - ) 10>${cachedir}/firstrun - fi - ) 9>${cachedir}/lockf - - exec flock ${cachedir}/firstrun ${run} - '' else "exec ${run}"; - - serviceConfig = { - Type = "oneshot"; - IOSchedulingClass = "idle"; - NoNewPrivileges = "true"; - CapabilityBoundingSet = [ "CAP_DAC_READ_SEARCH" ]; - PermissionsStartOnly = "true"; - }; - }) gcfg.archives) // - - (lib.mapAttrs' (name: cfg: lib.nameValuePair "tarsnap-restore-${name}"{ - description = "Tarsnap restore '${name}'"; - requires = [ "network-online.target" ]; - - path = with pkgs; [ iputils gcfg.package util-linux ]; - - script = let - tarsnap = ''${lib.getExe gcfg.package} --configfile "/etc/tarsnap/${name}.conf"''; - lastArchive = "$(${tarsnap} --list-archives | sort | tail -1)"; - run = ''${tarsnap} -x -f "${lastArchive}" ${lib.optionalString cfg.verbose "-v"}''; - cachedir = lib.escapeShellArg cfg.cachedir; - - in if (cfg.cachedir != null) then '' - mkdir -p ${cachedir} - chmod 0700 ${cachedir} - - ( flock 9 - if [ ! -e ${cachedir}/firstrun ]; then - ( flock 10 - flock -u 9 - ${tarsnap} --fsck - flock 9 - ) 10>${cachedir}/firstrun - fi - ) 9>${cachedir}/lockf - - exec flock ${cachedir}/firstrun ${run} - '' else "exec ${run}"; - - serviceConfig = { - Type = "oneshot"; - IOSchedulingClass = "idle"; - NoNewPrivileges = "true"; - CapabilityBoundingSet = [ "CAP_DAC_READ_SEARCH" ]; - PermissionsStartOnly = "true"; - }; - }) gcfg.archives); + (lib.mapAttrs' ( + name: cfg: + lib.nameValuePair "tarsnap-${name}" { + description = "Tarsnap archive '${name}'"; + requires = [ "network-online.target" ]; + after = [ "network-online.target" ]; + + path = with pkgs; [ + iputils + gcfg.package + util-linux + ]; + + # In order for the persistent tarsnap timer to work reliably, we have to + # make sure that the tarsnap server is reachable after systemd starts up + # the service - therefore we sleep in a loop until we can ping the + # endpoint. + preStart = '' + while ! ping -4 -q -c 1 v1-0-0-server.tarsnap.com &> /dev/null; do sleep 3; done + ''; + + script = + let + tarsnap = ''${lib.getExe gcfg.package} --configfile "/etc/tarsnap/${name}.conf"''; + run = '' + ${tarsnap} -c -f "${name}-$(date +"%Y%m%d%H%M%S")" \ + ${lib.optionalString cfg.verbose "-v"} \ + ${lib.optionalString cfg.explicitSymlinks "-H"} \ + ${lib.optionalString cfg.followSymlinks "-L"} \ + ${lib.concatStringsSep " " cfg.directories}''; + cachedir = lib.escapeShellArg cfg.cachedir; + in + if (cfg.cachedir != null) then + '' + mkdir -p ${cachedir} + chmod 0700 ${cachedir} + + ( flock 9 + if [ ! -e ${cachedir}/firstrun ]; then + ( flock 10 + flock -u 9 + ${tarsnap} --fsck + flock 9 + ) 10>${cachedir}/firstrun + fi + ) 9>${cachedir}/lockf + + exec flock ${cachedir}/firstrun ${run} + '' + else + "exec ${run}"; + + serviceConfig = { + Type = "oneshot"; + IOSchedulingClass = "idle"; + NoNewPrivileges = "true"; + CapabilityBoundingSet = [ "CAP_DAC_READ_SEARCH" ]; + PermissionsStartOnly = "true"; + }; + } + ) gcfg.archives) + // + + (lib.mapAttrs' ( + name: cfg: + lib.nameValuePair "tarsnap-restore-${name}" { + description = "Tarsnap restore '${name}'"; + requires = [ "network-online.target" ]; + + path = with pkgs; [ + iputils + gcfg.package + util-linux + ]; + + script = + let + tarsnap = ''${lib.getExe gcfg.package} --configfile "/etc/tarsnap/${name}.conf"''; + lastArchive = "$(${tarsnap} --list-archives | sort | tail -1)"; + run = ''${tarsnap} -x -f "${lastArchive}" ${lib.optionalString cfg.verbose "-v"}''; + cachedir = lib.escapeShellArg cfg.cachedir; + + in + if (cfg.cachedir != null) then + '' + mkdir -p ${cachedir} + chmod 0700 ${cachedir} + + ( flock 9 + if [ ! -e ${cachedir}/firstrun ]; then + ( flock 10 + flock -u 9 + ${tarsnap} --fsck + flock 9 + ) 10>${cachedir}/firstrun + fi + ) 9>${cachedir}/lockf + + exec flock ${cachedir}/firstrun ${run} + '' + else + "exec ${run}"; + + serviceConfig = { + Type = "oneshot"; + IOSchedulingClass = "idle"; + NoNewPrivileges = "true"; + CapabilityBoundingSet = [ "CAP_DAC_READ_SEARCH" ]; + PermissionsStartOnly = "true"; + }; + } + ) gcfg.archives); # Note: the timer must be Persistent=true, so that systemd will start it even # if e.g. your laptop was asleep while the latest interval occurred. - systemd.timers = lib.mapAttrs' (name: cfg: lib.nameValuePair "tarsnap-${name}" - { timerConfig.OnCalendar = cfg.period; + systemd.timers = lib.mapAttrs' ( + name: cfg: + lib.nameValuePair "tarsnap-${name}" { + timerConfig.OnCalendar = cfg.period; timerConfig.Persistent = "true"; wantedBy = [ "timers.target" ]; - }) gcfg.archives; - - environment.etc = - lib.mapAttrs' (name: cfg: lib.nameValuePair "tarsnap/${name}.conf" - { text = configFile name cfg; - }) gcfg.archives; + } + ) gcfg.archives; + + environment.etc = lib.mapAttrs' ( + name: cfg: + lib.nameValuePair "tarsnap/${name}.conf" { + text = configFile name cfg; + } + ) gcfg.archives; environment.systemPackages = [ gcfg.package ]; }; diff --git a/nixos/modules/services/backup/tsm.nix b/nixos/modules/services/backup/tsm.nix index 6589fcd9466c11..8dd27ccd234249 100644 --- a/nixos/modules/services/backup/tsm.nix +++ b/nixos/modules/services/backup/tsm.nix @@ -79,8 +79,7 @@ in config = mkIf cfg.enable { inherit assertions; programs.tsmClient.enable = true; - programs.tsmClient.servers.${cfg.servername}.passworddir = - mkDefault "/var/lib/tsm-backup/password"; + programs.tsmClient.servers.${cfg.servername}.passworddir = mkDefault "/var/lib/tsm-backup/password"; systemd.services.tsm-backup = { description = "IBM Storage Protect (Tivoli Storage Manager) Backup"; # DSM_LOG needs a trailing slash to have it treated as a directory. @@ -94,8 +93,7 @@ in SuccessExitStatus = "4 8"; # The `-se` option must come after the command. # The `-optfile` option suppresses a `dsm.opt`-not-found warning. - ExecStart = - "${getExe' cfgPrg.wrappedPackage "dsmc"} ${cfg.command} -se='${cfg.servername}' -optfile=/dev/null"; + ExecStart = "${getExe' cfgPrg.wrappedPackage "dsmc"} ${cfg.command} -se='${cfg.servername}' -optfile=/dev/null"; LogsDirectory = "tsm-backup"; StateDirectory = "tsm-backup"; StateDirectoryMode = "0750"; @@ -117,7 +115,7 @@ in RestrictNamespaces = true; RestrictSUIDSGID = true; }; - startAt = mkIf (cfg.autoTime!=null) cfg.autoTime; + startAt = mkIf (cfg.autoTime != null) cfg.autoTime; }; }; diff --git a/nixos/modules/services/backup/zfs-replication.nix b/nixos/modules/services/backup/zfs-replication.nix index 5aefaa35df5091..9f048ffdfb1ed3 100644 --- a/nixos/modules/services/backup/zfs-replication.nix +++ b/nixos/modules/services/backup/zfs-replication.nix @@ -1,9 +1,15 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: let cfg = config.services.zfs.autoReplication; recursive = lib.optionalString cfg.recursive " --recursive"; followDelete = lib.optionalString cfg.followDelete " --follow-delete"; -in { +in +{ options = { services.zfs.autoReplication = { enable = lib.mkEnableOption "ZFS snapshot replication"; diff --git a/nixos/modules/services/backup/znapzend.nix b/nixos/modules/services/backup/znapzend.nix index a3ea8b209bb66b..a49ff9fa5d6642 100644 --- a/nixos/modules/services/backup/znapzend.nix +++ b/nixos/modules/services/backup/znapzend.nix @@ -1,26 +1,31 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let planDescription = '' - The znapzend backup plan to use for the source. + The znapzend backup plan to use for the source. - The plan specifies how often to backup and for how long to keep the - backups. It consists of a series of retention periods to interval - associations: + The plan specifies how often to backup and for how long to keep the + backups. It consists of a series of retention periods to interval + associations: - ``` - retA=>intA,retB=>intB,... - ``` + ``` + retA=>intA,retB=>intB,... + ``` - Both intervals and retention periods are expressed in standard units - of time or multiples of them. You can use both the full name or a - shortcut according to the following listing: + Both intervals and retention periods are expressed in standard units + of time or multiples of them. You can use both the full name or a + shortcut according to the following listing: - ``` - second|sec|s, minute|min, hour|h, day|d, week|w, month|mon|m, year|y - ``` + ``` + second|sec|s, minute|min, hour|h, day|d, week|w, month|mon|m, year|y + ``` - See {manpage}`znapzendzetup(1)` for more info. + See {manpage}`znapzendzetup(1)` for more info. ''; planExample = "1h=>10min,1d=>1h,1w=>1d,1m=>1w,1y=>1m"; @@ -30,107 +35,125 @@ let description = "string of the form number{b|k|M|G}"; }; - enabledFeatures = lib.concatLists (lib.mapAttrsToList (name: enabled: lib.optional enabled name) cfg.features); + enabledFeatures = lib.concatLists ( + lib.mapAttrsToList (name: enabled: lib.optional enabled name) cfg.features + ); # Type for a string that must contain certain other strings (the list parameter). # Note that these would need regex escaping. - stringContainingStrings = list: let - matching = s: map (str: builtins.match ".*${str}.*" s) list; - in lib.types.str // { - check = x: lib.types.str.check x && lib.all lib.isList (matching x); - description = "string containing all of the characters ${lib.concatStringsSep ", " list}"; - }; - - timestampType = stringContainingStrings [ "%Y" "%m" "%d" "%H" "%M" "%S" ]; - - destType = srcConfig: lib.types.submodule ({ name, ... }: { - options = { - - label = lib.mkOption { - type = lib.types.str; - description = "Label for this destination. Defaults to the attribute name."; - }; - - plan = lib.mkOption { - type = lib.types.str; - description = planDescription; - example = planExample; - }; - - dataset = lib.mkOption { - type = lib.types.str; - description = "Dataset name to send snapshots to."; - example = "tank/main"; - }; - - host = lib.mkOption { - type = lib.types.nullOr lib.types.str; - description = '' - Host to use for the destination dataset. Can be prefixed with - `user@` to specify the ssh user. - ''; - default = null; - example = "john@example.com"; - }; + stringContainingStrings = + list: + let + matching = s: map (str: builtins.match ".*${str}.*" s) list; + in + lib.types.str + // { + check = x: lib.types.str.check x && lib.all lib.isList (matching x); + description = "string containing all of the characters ${lib.concatStringsSep ", " list}"; + }; - presend = lib.mkOption { - type = lib.types.nullOr lib.types.str; - description = '' - Command to run before sending the snapshot to the destination. - Intended to run a remote script via {command}`ssh` on the - destination, e.g. to bring up a backup disk or server or to put a - zpool online/offline. See also {option}`postsend`. - ''; - default = null; - example = "ssh root@bserv zpool import -Nf tank"; - }; + timestampType = stringContainingStrings [ + "%Y" + "%m" + "%d" + "%H" + "%M" + "%S" + ]; + + destType = + srcConfig: + lib.types.submodule ( + { name, ... }: + { + options = { + + label = lib.mkOption { + type = lib.types.str; + description = "Label for this destination. Defaults to the attribute name."; + }; - postsend = lib.mkOption { - type = lib.types.nullOr lib.types.str; - description = '' - Command to run after sending the snapshot to the destination. - Intended to run a remote script via {command}`ssh` on the - destination, e.g. to bring up a backup disk or server or to put a - zpool online/offline. See also {option}`presend`. - ''; - default = null; - example = "ssh root@bserv zpool export tank"; - }; - }; + plan = lib.mkOption { + type = lib.types.str; + description = planDescription; + example = planExample; + }; - config = { - label = lib.mkDefault name; - plan = lib.mkDefault srcConfig.plan; - }; - }); + dataset = lib.mkOption { + type = lib.types.str; + description = "Dataset name to send snapshots to."; + example = "tank/main"; + }; + host = lib.mkOption { + type = lib.types.nullOr lib.types.str; + description = '' + Host to use for the destination dataset. Can be prefixed with + `user@` to specify the ssh user. + ''; + default = null; + example = "john@example.com"; + }; + presend = lib.mkOption { + type = lib.types.nullOr lib.types.str; + description = '' + Command to run before sending the snapshot to the destination. + Intended to run a remote script via {command}`ssh` on the + destination, e.g. to bring up a backup disk or server or to put a + zpool online/offline. See also {option}`postsend`. + ''; + default = null; + example = "ssh root@bserv zpool import -Nf tank"; + }; - srcType = lib.types.submodule ({ name, config, ... }: { - options = { + postsend = lib.mkOption { + type = lib.types.nullOr lib.types.str; + description = '' + Command to run after sending the snapshot to the destination. + Intended to run a remote script via {command}`ssh` on the + destination, e.g. to bring up a backup disk or server or to put a + zpool online/offline. See also {option}`presend`. + ''; + default = null; + example = "ssh root@bserv zpool export tank"; + }; + }; - enable = lib.mkOption { - type = lib.types.bool; - description = "Whether to enable this source."; - default = true; - }; + config = { + label = lib.mkDefault name; + plan = lib.mkDefault srcConfig.plan; + }; + } + ); - recursive = lib.mkOption { - type = lib.types.bool; - description = "Whether to do recursive snapshots."; - default = false; - }; + srcType = lib.types.submodule ( + { name, config, ... }: + { + options = { - mbuffer = { enable = lib.mkOption { type = lib.types.bool; - description = "Whether to use {command}`mbuffer`."; + description = "Whether to enable this source."; + default = true; + }; + + recursive = lib.mkOption { + type = lib.types.bool; + description = "Whether to do recursive snapshots."; default = false; }; - port = lib.mkOption { - type = lib.types.nullOr lib.types.ints.u16; - description = '' + mbuffer = { + enable = lib.mkOption { + type = lib.types.bool; + description = "Whether to use {command}`mbuffer`."; + default = false; + }; + + port = lib.mkOption { + type = lib.types.nullOr lib.types.ints.u16; + description = '' Port to use for {command}`mbuffer`. If this is null, it will run {command}`mbuffer` through @@ -139,107 +162,108 @@ let If this is not null, it will run {command}`mbuffer` directly through TCP, which is not encrypted but faster. In that case the given port needs to be open on the destination host. + ''; + default = null; + }; + + size = lib.mkOption { + type = mbufferSizeType; + description = '' + The size for {command}`mbuffer`. + Supports the units b, k, M, G. + ''; + default = "1G"; + example = "128M"; + }; + }; + + presnap = lib.mkOption { + type = lib.types.nullOr lib.types.str; + description = '' + Command to run before snapshots are taken on the source dataset, + e.g. for database locking/flushing. See also + {option}`postsnap`. ''; default = null; + example = lib.literalExpression '' + '''''${pkgs.mariadb}/bin/mysql -e "set autocommit=0;flush tables with read lock;\\! ''${pkgs.coreutils}/bin/sleep 600" & ''${pkgs.coreutils}/bin/echo $! > /tmp/mariadblock.pid ; sleep 10''' + ''; }; - size = lib.mkOption { - type = mbufferSizeType; + postsnap = lib.mkOption { + type = lib.types.nullOr lib.types.str; description = '' - The size for {command}`mbuffer`. - Supports the units b, k, M, G. + Command to run after snapshots are taken on the source dataset, + e.g. for database unlocking. See also {option}`presnap`. + ''; + default = null; + example = lib.literalExpression '' + "''${pkgs.coreutils}/bin/kill `''${pkgs.coreutils}/bin/cat /tmp/mariadblock.pid`;''${pkgs.coreutils}/bin/rm /tmp/mariadblock.pid" ''; - default = "1G"; - example = "128M"; }; - }; - - presnap = lib.mkOption { - type = lib.types.nullOr lib.types.str; - description = '' - Command to run before snapshots are taken on the source dataset, - e.g. for database locking/flushing. See also - {option}`postsnap`. - ''; - default = null; - example = lib.literalExpression '' - '''''${pkgs.mariadb}/bin/mysql -e "set autocommit=0;flush tables with read lock;\\! ''${pkgs.coreutils}/bin/sleep 600" & ''${pkgs.coreutils}/bin/echo $! > /tmp/mariadblock.pid ; sleep 10''' - ''; - }; - - postsnap = lib.mkOption { - type = lib.types.nullOr lib.types.str; - description = '' - Command to run after snapshots are taken on the source dataset, - e.g. for database unlocking. See also {option}`presnap`. - ''; - default = null; - example = lib.literalExpression '' - "''${pkgs.coreutils}/bin/kill `''${pkgs.coreutils}/bin/cat /tmp/mariadblock.pid`;''${pkgs.coreutils}/bin/rm /tmp/mariadblock.pid" - ''; - }; - timestampFormat = lib.mkOption { - type = timestampType; - description = '' - The timestamp format to use for constructing snapshot names. - The syntax is `strftime`-like. The string must - consist of the mandatory `%Y %m %d %H %M %S`. - Optionally `- _ . :` characters as well as any - alphanumeric character are allowed. If suffixed by a - `Z`, times will be in UTC. - ''; - default = "%Y-%m-%d-%H%M%S"; - example = "znapzend-%m.%d.%Y-%H%M%SZ"; - }; + timestampFormat = lib.mkOption { + type = timestampType; + description = '' + The timestamp format to use for constructing snapshot names. + The syntax is `strftime`-like. The string must + consist of the mandatory `%Y %m %d %H %M %S`. + Optionally `- _ . :` characters as well as any + alphanumeric character are allowed. If suffixed by a + `Z`, times will be in UTC. + ''; + default = "%Y-%m-%d-%H%M%S"; + example = "znapzend-%m.%d.%Y-%H%M%SZ"; + }; - sendDelay = lib.mkOption { - type = lib.types.int; - description = '' - Specify delay (in seconds) before sending snaps to the destination. - May be useful if you want to control sending time. - ''; - default = 0; - example = 60; - }; + sendDelay = lib.mkOption { + type = lib.types.int; + description = '' + Specify delay (in seconds) before sending snaps to the destination. + May be useful if you want to control sending time. + ''; + default = 0; + example = 60; + }; - plan = lib.mkOption { - type = lib.types.str; - description = planDescription; - example = planExample; - }; + plan = lib.mkOption { + type = lib.types.str; + description = planDescription; + example = planExample; + }; - dataset = lib.mkOption { - type = lib.types.str; - description = "The dataset to use for this source."; - example = "tank/home"; - }; + dataset = lib.mkOption { + type = lib.types.str; + description = "The dataset to use for this source."; + example = "tank/home"; + }; - destinations = lib.mkOption { - type = lib.types.attrsOf (destType config); - description = "Additional destinations."; - default = {}; - example = lib.literalExpression '' - { - local = { - dataset = "btank/backup"; - presend = "zpool import -N btank"; - postsend = "zpool export btank"; - }; - remote = { - host = "john@example.com"; - dataset = "tank/john"; + destinations = lib.mkOption { + type = lib.types.attrsOf (destType config); + description = "Additional destinations."; + default = { }; + example = lib.literalExpression '' + { + local = { + dataset = "btank/backup"; + presend = "zpool import -N btank"; + postsend = "zpool export btank"; + }; + remote = { + host = "john@example.com"; + dataset = "tank/john"; + }; }; - }; - ''; + ''; + }; }; - }; - config = { - dataset = lib.mkDefault name; - }; + config = { + dataset = lib.mkDefault name; + }; - }); + } + ); ### Generating the configuration from here @@ -249,42 +273,55 @@ let nullOff = b: if b == null then "off" else toString b; stripSlashes = lib.replaceStrings [ "/" ] [ "." ]; - attrsToFile = config: lib.concatStringsSep "\n" (builtins.attrValues ( - lib.mapAttrs (n: v: "${n}=${v}") config)); - - mkDestAttrs = dst: with dst; - lib.mapAttrs' (n: v: lib.nameValuePair "dst_${label}${n}" v) ({ - "" = lib.optionalString (host != null) "${host}:" + dataset; - _plan = plan; - } // lib.optionalAttrs (presend != null) { - _precmd = presend; - } // lib.optionalAttrs (postsend != null) { - _pstcmd = postsend; - }); - - mkSrcAttrs = srcCfg: with srcCfg; { - enabled = onOff enable; - # mbuffer is not referenced by its full path to accommodate non-NixOS systems or differing mbuffer versions between source and target - mbuffer = with mbuffer; if enable then "mbuffer" - + lib.optionalString (port != null) ":${toString port}" else "off"; - mbuffer_size = mbuffer.size; - post_znap_cmd = nullOff postsnap; - pre_znap_cmd = nullOff presnap; - recursive = onOff recursive; - src = dataset; - src_plan = plan; - tsformat = timestampFormat; - zend_delay = toString sendDelay; - } // lib.foldr (a: b: a // b) {} ( - map mkDestAttrs (builtins.attrValues destinations) - ); - - files = lib.mapAttrs' (n: srcCfg: let - fileText = attrsToFile (mkSrcAttrs srcCfg); - in { - name = srcCfg.dataset; - value = pkgs.writeText (stripSlashes srcCfg.dataset) fileText; - }) cfg.zetup; + attrsToFile = + config: lib.concatStringsSep "\n" (builtins.attrValues (lib.mapAttrs (n: v: "${n}=${v}") config)); + + mkDestAttrs = + dst: + with dst; + lib.mapAttrs' (n: v: lib.nameValuePair "dst_${label}${n}" v) ( + { + "" = lib.optionalString (host != null) "${host}:" + dataset; + _plan = plan; + } + // lib.optionalAttrs (presend != null) { + _precmd = presend; + } + // lib.optionalAttrs (postsend != null) { + _pstcmd = postsend; + } + ); + + mkSrcAttrs = + srcCfg: + with srcCfg; + { + enabled = onOff enable; + # mbuffer is not referenced by its full path to accommodate non-NixOS systems or differing mbuffer versions between source and target + mbuffer = + with mbuffer; + if enable then "mbuffer" + lib.optionalString (port != null) ":${toString port}" else "off"; + mbuffer_size = mbuffer.size; + post_znap_cmd = nullOff postsnap; + pre_znap_cmd = nullOff presnap; + recursive = onOff recursive; + src = dataset; + src_plan = plan; + tsformat = timestampFormat; + zend_delay = toString sendDelay; + } + // lib.foldr (a: b: a // b) { } (map mkDestAttrs (builtins.attrValues destinations)); + + files = lib.mapAttrs' ( + n: srcCfg: + let + fileText = attrsToFile (mkSrcAttrs srcCfg); + in + { + name = srcCfg.dataset; + value = pkgs.writeText (stripSlashes srcCfg.dataset) fileText; + } + ) cfg.zetup; in { @@ -295,7 +332,13 @@ in logLevel = lib.mkOption { default = "debug"; example = "warning"; - type = lib.types.enum ["debug" "info" "warning" "err" "alert"]; + type = lib.types.enum [ + "debug" + "info" + "warning" + "err" + "alert" + ]; description = '' The log level when logging to file. Any of debug, info, warning, err, alert. Default in daemonized form is debug. @@ -334,7 +377,7 @@ in zetup = lib.mkOption { type = lib.types.attrsOf srcType; description = "Znapzend configuration."; - default = {}; + default = { }; example = lib.literalExpression '' { "tank/home" = { @@ -427,22 +470,31 @@ in systemd.services = { znapzend = { description = "ZnapZend - ZFS Backup System"; - wantedBy = [ "zfs.target" ]; - after = [ "zfs.target" ]; - - path = with pkgs; [ zfs mbuffer openssh ]; - - preStart = lib.optionalString cfg.pure '' - echo Resetting znapzend zetups - ${pkgs.znapzend}/bin/znapzendzetup list \ - | grep -oP '(?<=\*\*\* backup plan: ).*(?= \*\*\*)' \ - | xargs -I{} ${pkgs.znapzend}/bin/znapzendzetup delete "{}" - '' + lib.concatStringsSep "\n" (lib.mapAttrsToList (dataset: config: '' - echo Importing znapzend zetup ${config} for dataset ${dataset} - ${pkgs.znapzend}/bin/znapzendzetup import --write ${dataset} ${config} & - '') files) + '' - wait - ''; + wantedBy = [ "zfs.target" ]; + after = [ "zfs.target" ]; + + path = with pkgs; [ + zfs + mbuffer + openssh + ]; + + preStart = + lib.optionalString cfg.pure '' + echo Resetting znapzend zetups + ${pkgs.znapzend}/bin/znapzendzetup list \ + | grep -oP '(?<=\*\*\* backup plan: ).*(?= \*\*\*)' \ + | xargs -I{} ${pkgs.znapzend}/bin/znapzendzetup delete "{}" + '' + + lib.concatStringsSep "\n" ( + lib.mapAttrsToList (dataset: config: '' + echo Importing znapzend zetup ${config} for dataset ${dataset} + ${pkgs.znapzend}/bin/znapzendzetup import --write ${dataset} ${config} & + '') files + ) + + '' + wait + ''; serviceConfig = { # znapzendzetup --import apparently tries to connect to the backup @@ -453,17 +505,20 @@ in TimeoutStartSec = 180; # Needs to have write access to ZFS User = "root"; - ExecStart = let - args = lib.concatStringsSep " " [ - "--logto=${cfg.logTo}" - "--loglevel=${cfg.logLevel}" - (lib.optionalString cfg.noDestroy "--nodestroy") - (lib.optionalString cfg.autoCreation "--autoCreation") - (lib.optionalString (cfg.mailErrorSummaryTo != "") - "--mailErrorSummaryTo=${cfg.mailErrorSummaryTo}") - (lib.optionalString (enabledFeatures != []) - "--features=${lib.concatStringsSep "," enabledFeatures}") - ]; in "${pkgs.znapzend}/bin/znapzend ${args}"; + ExecStart = + let + args = lib.concatStringsSep " " [ + "--logto=${cfg.logTo}" + "--loglevel=${cfg.logLevel}" + (lib.optionalString cfg.noDestroy "--nodestroy") + (lib.optionalString cfg.autoCreation "--autoCreation") + (lib.optionalString (cfg.mailErrorSummaryTo != "") "--mailErrorSummaryTo=${cfg.mailErrorSummaryTo}") + (lib.optionalString ( + enabledFeatures != [ ] + ) "--features=${lib.concatStringsSep "," enabledFeatures}") + ]; + in + "${pkgs.znapzend}/bin/znapzend ${args}"; ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; Restart = "on-failure"; }; diff --git a/nixos/modules/services/backup/zrepl.nix b/nixos/modules/services/backup/zrepl.nix index d46823adbadbdc..4e8df0ace9fb36 100644 --- a/nixos/modules/services/backup/zrepl.nix +++ b/nixos/modules/services/backup/zrepl.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.zrepl; format = pkgs.formats.yaml { }; diff --git a/nixos/modules/services/blockchain/ethereum/erigon.nix b/nixos/modules/services/blockchain/ethereum/erigon.nix index 5ac95233915197..3d80f33ff21486 100644 --- a/nixos/modules/services/blockchain/ethereum/erigon.nix +++ b/nixos/modules/services/blockchain/ethereum/erigon.nix @@ -1,11 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.erigon; settingsFormat = pkgs.formats.toml { }; configFile = settingsFormat.generate "config.toml" cfg.settings; -in { +in +{ options = { services.erigon = { @@ -41,7 +47,14 @@ in { chain = "mainnet"; http = true; "http.port" = 8545; - "http.api" = ["eth" "debug" "net" "trace" "web3" "erigon"]; + "http.api" = [ + "eth" + "debug" + "net" + "trace" + "web3" + "erigon" + ]; ws = true; port = 30303; "authrpc.port" = 8551; @@ -76,7 +89,14 @@ in { chain = lib.mkDefault "mainnet"; http = lib.mkDefault true; "http.port" = lib.mkDefault 8545; - "http.api" = lib.mkDefault ["eth" "debug" "net" "trace" "web3" "erigon"]; + "http.api" = lib.mkDefault [ + "eth" + "debug" + "net" + "trace" + "web3" + "erigon" + ]; ws = lib.mkDefault true; port = lib.mkDefault 30303; "authrpc.port" = lib.mkDefault 8551; @@ -113,7 +133,10 @@ in { RestrictNamespaces = true; LockPersonality = true; RemoveIPC = true; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; }; }; }; diff --git a/nixos/modules/services/blockchain/ethereum/geth.nix b/nixos/modules/services/blockchain/ethereum/geth.nix index 52040f2b9ec575..0c406c595a749f 100644 --- a/nixos/modules/services/blockchain/ethereum/geth.nix +++ b/nixos/modules/services/blockchain/ethereum/geth.nix @@ -1,140 +1,177 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let eachGeth = config.services.geth; - gethOpts = { config, lib, name, ...}: { - - options = { + gethOpts = + { + config, + lib, + name, + ... + }: + { - enable = lib.mkEnableOption "Go Ethereum Node"; - - port = lib.mkOption { - type = lib.types.port; - default = 30303; - description = "Port number Go Ethereum will be listening on, both TCP and UDP."; - }; + options = { - http = { - enable = lib.mkEnableOption "Go Ethereum HTTP API"; - address = lib.mkOption { - type = lib.types.str; - default = "127.0.0.1"; - description = "Listen address of Go Ethereum HTTP API."; - }; + enable = lib.mkEnableOption "Go Ethereum Node"; port = lib.mkOption { type = lib.types.port; - default = 8545; - description = "Port number of Go Ethereum HTTP API."; - }; - - apis = lib.mkOption { - type = lib.types.nullOr (lib.types.listOf lib.types.str); - default = null; - description = "APIs to enable over WebSocket"; - example = ["net" "eth"]; + default = 30303; + description = "Port number Go Ethereum will be listening on, both TCP and UDP."; }; - }; - websocket = { - enable = lib.mkEnableOption "Go Ethereum WebSocket API"; - address = lib.mkOption { - type = lib.types.str; - default = "127.0.0.1"; - description = "Listen address of Go Ethereum WebSocket API."; + http = { + enable = lib.mkEnableOption "Go Ethereum HTTP API"; + address = lib.mkOption { + type = lib.types.str; + default = "127.0.0.1"; + description = "Listen address of Go Ethereum HTTP API."; + }; + + port = lib.mkOption { + type = lib.types.port; + default = 8545; + description = "Port number of Go Ethereum HTTP API."; + }; + + apis = lib.mkOption { + type = lib.types.nullOr (lib.types.listOf lib.types.str); + default = null; + description = "APIs to enable over WebSocket"; + example = [ + "net" + "eth" + ]; + }; }; - port = lib.mkOption { - type = lib.types.port; - default = 8546; - description = "Port number of Go Ethereum WebSocket API."; + websocket = { + enable = lib.mkEnableOption "Go Ethereum WebSocket API"; + address = lib.mkOption { + type = lib.types.str; + default = "127.0.0.1"; + description = "Listen address of Go Ethereum WebSocket API."; + }; + + port = lib.mkOption { + type = lib.types.port; + default = 8546; + description = "Port number of Go Ethereum WebSocket API."; + }; + + apis = lib.mkOption { + type = lib.types.nullOr (lib.types.listOf lib.types.str); + default = null; + description = "APIs to enable over WebSocket"; + example = [ + "net" + "eth" + ]; + }; }; - apis = lib.mkOption { - type = lib.types.nullOr (lib.types.listOf lib.types.str); - default = null; - description = "APIs to enable over WebSocket"; - example = ["net" "eth"]; + authrpc = { + enable = lib.mkEnableOption "Go Ethereum Auth RPC API"; + address = lib.mkOption { + type = lib.types.str; + default = "127.0.0.1"; + description = "Listen address of Go Ethereum Auth RPC API."; + }; + + port = lib.mkOption { + type = lib.types.port; + default = 8551; + description = "Port number of Go Ethereum Auth RPC API."; + }; + + vhosts = lib.mkOption { + type = lib.types.nullOr (lib.types.listOf lib.types.str); + default = [ "localhost" ]; + description = "List of virtual hostnames from which to accept requests."; + example = [ + "localhost" + "geth.example.org" + ]; + }; + + jwtsecret = lib.mkOption { + type = lib.types.str; + default = ""; + description = "Path to a JWT secret for authenticated RPC endpoint."; + example = "/var/run/geth/jwtsecret"; + }; }; - }; - authrpc = { - enable = lib.mkEnableOption "Go Ethereum Auth RPC API"; - address = lib.mkOption { - type = lib.types.str; - default = "127.0.0.1"; - description = "Listen address of Go Ethereum Auth RPC API."; + metrics = { + enable = lib.mkEnableOption "Go Ethereum prometheus metrics"; + address = lib.mkOption { + type = lib.types.str; + default = "127.0.0.1"; + description = "Listen address of Go Ethereum metrics service."; + }; + + port = lib.mkOption { + type = lib.types.port; + default = 6060; + description = "Port number of Go Ethereum metrics service."; + }; }; - port = lib.mkOption { - type = lib.types.port; - default = 8551; - description = "Port number of Go Ethereum Auth RPC API."; + network = lib.mkOption { + type = lib.types.nullOr ( + lib.types.enum [ + "goerli" + "holesky" + "rinkeby" + "yolov2" + "ropsten" + ] + ); + default = null; + description = "The network to connect to. Mainnet (null) is the default ethereum network."; }; - vhosts = lib.mkOption { - type = lib.types.nullOr (lib.types.listOf lib.types.str); - default = ["localhost"]; - description = "List of virtual hostnames from which to accept requests."; - example = ["localhost" "geth.example.org"]; + syncmode = lib.mkOption { + type = lib.types.enum [ + "snap" + "fast" + "full" + "light" + ]; + default = "snap"; + description = "Blockchain sync mode."; }; - jwtsecret = lib.mkOption { - type = lib.types.str; - default = ""; - description = "Path to a JWT secret for authenticated RPC endpoint."; - example = "/var/run/geth/jwtsecret"; + gcmode = lib.mkOption { + type = lib.types.enum [ + "full" + "archive" + ]; + default = "full"; + description = "Blockchain garbage collection mode."; }; - }; - metrics = { - enable = lib.mkEnableOption "Go Ethereum prometheus metrics"; - address = lib.mkOption { - type = lib.types.str; - default = "127.0.0.1"; - description = "Listen address of Go Ethereum metrics service."; + maxpeers = lib.mkOption { + type = lib.types.int; + default = 50; + description = "Maximum peers to connect to."; }; - port = lib.mkOption { - type = lib.types.port; - default = 6060; - description = "Port number of Go Ethereum metrics service."; + extraArgs = lib.mkOption { + type = lib.types.listOf lib.types.str; + description = "Additional arguments passed to Go Ethereum."; + default = [ ]; }; - }; - - network = lib.mkOption { - type = lib.types.nullOr (lib.types.enum [ "goerli" "holesky" "rinkeby" "yolov2" "ropsten" ]); - default = null; - description = "The network to connect to. Mainnet (null) is the default ethereum network."; - }; - - syncmode = lib.mkOption { - type = lib.types.enum [ "snap" "fast" "full" "light" ]; - default = "snap"; - description = "Blockchain sync mode."; - }; - gcmode = lib.mkOption { - type = lib.types.enum [ "full" "archive" ]; - default = "full"; - description = "Blockchain garbage collection mode."; + package = lib.mkPackageOption pkgs [ "go-ethereum" "geth" ] { }; }; - - maxpeers = lib.mkOption { - type = lib.types.int; - default = 50; - description = "Maximum peers to connect to."; - }; - - extraArgs = lib.mkOption { - type = lib.types.listOf lib.types.str; - description = "Additional arguments passed to Go Ethereum."; - default = []; - }; - - package = lib.mkPackageOption pkgs [ "go-ethereum" "geth" ] { }; }; - }; in { @@ -144,61 +181,79 @@ in options = { services.geth = lib.mkOption { type = lib.types.attrsOf (lib.types.submodule gethOpts); - default = {}; + default = { }; description = "Specification of one or more geth instances."; }; }; ###### implementation - config = lib.mkIf (eachGeth != {}) { - - environment.systemPackages = lib.flatten (lib.mapAttrsToList (gethName: cfg: [ - cfg.package - ]) eachGeth); - - systemd.services = lib.mapAttrs' (gethName: cfg: let - stateDir = "goethereum/${gethName}/${if (cfg.network == null) then "mainnet" else cfg.network}"; - dataDir = "/var/lib/${stateDir}"; - in ( - lib.nameValuePair "geth-${gethName}" (lib.mkIf cfg.enable { - description = "Go Ethereum node (${gethName})"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - - serviceConfig = { - DynamicUser = true; - Restart = "always"; - StateDirectory = stateDir; - - # Hardening measures - PrivateTmp = "true"; - ProtectSystem = "full"; - NoNewPrivileges = "true"; - PrivateDevices = "true"; - MemoryDenyWriteExecute = "true"; - }; - - script = '' - ${cfg.package}/bin/geth \ - --nousb \ - --ipcdisable \ - ${lib.optionalString (cfg.network != null) ''--${cfg.network}''} \ - --syncmode ${cfg.syncmode} \ - --gcmode ${cfg.gcmode} \ - --port ${toString cfg.port} \ - --maxpeers ${toString cfg.maxpeers} \ - ${lib.optionalString cfg.http.enable ''--http --http.addr ${cfg.http.address} --http.port ${toString cfg.http.port}''} \ - ${lib.optionalString (cfg.http.apis != null) ''--http.api ${lib.concatStringsSep "," cfg.http.apis}''} \ - ${lib.optionalString cfg.websocket.enable ''--ws --ws.addr ${cfg.websocket.address} --ws.port ${toString cfg.websocket.port}''} \ - ${lib.optionalString (cfg.websocket.apis != null) ''--ws.api ${lib.concatStringsSep "," cfg.websocket.apis}''} \ - ${lib.optionalString cfg.metrics.enable ''--metrics --metrics.addr ${cfg.metrics.address} --metrics.port ${toString cfg.metrics.port}''} \ - --authrpc.addr ${cfg.authrpc.address} --authrpc.port ${toString cfg.authrpc.port} --authrpc.vhosts ${lib.concatStringsSep "," cfg.authrpc.vhosts} \ - ${if (cfg.authrpc.jwtsecret != "") then ''--authrpc.jwtsecret ${cfg.authrpc.jwtsecret}'' else ''--authrpc.jwtsecret ${dataDir}/geth/jwtsecret''} \ - ${lib.escapeShellArgs cfg.extraArgs} \ - --datadir ${dataDir} - ''; - }))) eachGeth; + config = lib.mkIf (eachGeth != { }) { + + environment.systemPackages = lib.flatten ( + lib.mapAttrsToList (gethName: cfg: [ + cfg.package + ]) eachGeth + ); + + systemd.services = lib.mapAttrs' ( + gethName: cfg: + let + stateDir = "goethereum/${gethName}/${if (cfg.network == null) then "mainnet" else cfg.network}"; + dataDir = "/var/lib/${stateDir}"; + in + (lib.nameValuePair "geth-${gethName}" ( + lib.mkIf cfg.enable { + description = "Go Ethereum node (${gethName})"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + + serviceConfig = { + DynamicUser = true; + Restart = "always"; + StateDirectory = stateDir; + + # Hardening measures + PrivateTmp = "true"; + ProtectSystem = "full"; + NoNewPrivileges = "true"; + PrivateDevices = "true"; + MemoryDenyWriteExecute = "true"; + }; + + script = '' + ${cfg.package}/bin/geth \ + --nousb \ + --ipcdisable \ + ${lib.optionalString (cfg.network != null) ''--${cfg.network}''} \ + --syncmode ${cfg.syncmode} \ + --gcmode ${cfg.gcmode} \ + --port ${toString cfg.port} \ + --maxpeers ${toString cfg.maxpeers} \ + ${lib.optionalString cfg.http.enable ''--http --http.addr ${cfg.http.address} --http.port ${toString cfg.http.port}''} \ + ${ + lib.optionalString (cfg.http.apis != null) ''--http.api ${lib.concatStringsSep "," cfg.http.apis}'' + } \ + ${lib.optionalString cfg.websocket.enable ''--ws --ws.addr ${cfg.websocket.address} --ws.port ${toString cfg.websocket.port}''} \ + ${ + lib.optionalString ( + cfg.websocket.apis != null + ) ''--ws.api ${lib.concatStringsSep "," cfg.websocket.apis}'' + } \ + ${lib.optionalString cfg.metrics.enable ''--metrics --metrics.addr ${cfg.metrics.address} --metrics.port ${toString cfg.metrics.port}''} \ + --authrpc.addr ${cfg.authrpc.address} --authrpc.port ${toString cfg.authrpc.port} --authrpc.vhosts ${lib.concatStringsSep "," cfg.authrpc.vhosts} \ + ${ + if (cfg.authrpc.jwtsecret != "") then + ''--authrpc.jwtsecret ${cfg.authrpc.jwtsecret}'' + else + ''--authrpc.jwtsecret ${dataDir}/geth/jwtsecret'' + } \ + ${lib.escapeShellArgs cfg.extraArgs} \ + --datadir ${dataDir} + ''; + } + )) + ) eachGeth; }; diff --git a/nixos/modules/services/cluster/corosync/default.nix b/nixos/modules/services/cluster/corosync/default.nix index d79ee832ff7394..ae63b4370cb478 100644 --- a/nixos/modules/services/cluster/corosync/default.nix +++ b/nixos/modules/services/cluster/corosync/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.corosync; in @@ -17,29 +22,31 @@ in extraOptions = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; description = "Additional options with which to start corosync."; }; nodelist = lib.mkOption { description = "Corosync nodelist: all cluster members."; - default = []; - type = with lib.types; listOf (submodule { - options = { - nodeid = lib.mkOption { - type = int; - description = "Node ID number"; - }; - name = lib.mkOption { - type = str; - description = "Node name"; - }; - ring_addrs = lib.mkOption { - type = listOf str; - description = "List of addresses, one for each ring."; + default = [ ]; + type = + with lib.types; + listOf (submodule { + options = { + nodeid = lib.mkOption { + type = int; + description = "Node ID number"; + }; + name = lib.mkOption { + type = str; + description = "Node name"; + }; + ring_addrs = lib.mkOption { + type = listOf str; + description = "List of addresses, one for each ring."; + }; }; - }; - }); + }); }; }; @@ -56,15 +63,24 @@ in } nodelist { - ${lib.concatMapStrings ({ nodeid, name, ring_addrs }: '' - node { - nodeid: ${toString nodeid} - name: ${name} - ${lib.concatStrings (lib.imap0 (i: addr: '' - ring${toString i}_addr: ${addr} - '') ring_addrs)} - } - '') cfg.nodelist} + ${lib.concatMapStrings ( + { + nodeid, + name, + ring_addrs, + }: + '' + node { + nodeid: ${toString nodeid} + name: ${name} + ${lib.concatStrings ( + lib.imap0 (i: addr: '' + ring${toString i}_addr: ${addr} + '') ring_addrs + )} + } + '' + ) cfg.nodelist} } quorum { @@ -98,7 +114,7 @@ in }; }; - environment.etc."sysconfig/corosync".text = lib.optionalString (cfg.extraOptions != []) '' + environment.etc."sysconfig/corosync".text = lib.optionalString (cfg.extraOptions != [ ]) '' COROSYNC_OPTIONS="${lib.escapeShellArgs cfg.extraOptions}" ''; }; diff --git a/nixos/modules/services/cluster/druid/default.nix b/nixos/modules/services/cluster/druid/default.nix index f28e5c90270cf4..d22a3f2236787a 100644 --- a/nixos/modules/services/cluster/druid/default.nix +++ b/nixos/modules/services/cluster/druid/default.nix @@ -257,7 +257,8 @@ in allowedTCPPorts = [ (attrByPath [ "druid.plaintextPort" ] 8083 cfg."${name}".config) ]; - extraConfig.services.druid.historical.internalConfig."druid.segmentCache.locations" = builtins.toJSON cfg.historical.segmentLocations; + extraConfig.services.druid.historical.internalConfig."druid.segmentCache.locations" = + builtins.toJSON cfg.historical.segmentLocations; }) (druidServiceConfig rec { diff --git a/nixos/modules/services/cluster/hadoop/conf.nix b/nixos/modules/services/cluster/hadoop/conf.nix index 388eaafcc3621f..54524e5ccccac7 100644 --- a/nixos/modules/services/cluster/hadoop/conf.nix +++ b/nixos/modules/services/cluster/hadoop/conf.nix @@ -1,25 +1,35 @@ -{ cfg, pkgs, lib }: +{ + cfg, + pkgs, + lib, +}: let - propertyXml = name: value: lib.optionalString (value != null) '' - - ${name} - ${builtins.toString value} - - ''; - siteXml = fileName: properties: pkgs.writeTextDir fileName '' - - - - ${builtins.concatStringsSep "\n" (pkgs.lib.mapAttrsToList propertyXml properties)} - - ''; + propertyXml = + name: value: + lib.optionalString (value != null) '' + + ${name} + ${builtins.toString value} + + ''; + siteXml = + fileName: properties: + pkgs.writeTextDir fileName '' + + + + ${builtins.concatStringsSep "\n" (pkgs.lib.mapAttrsToList propertyXml properties)} + + ''; cfgLine = name: value: '' ${name}=${builtins.toString value} ''; - cfgFile = fileName: properties: pkgs.writeTextDir fileName '' - # generated by NixOS - ${builtins.concatStringsSep "" (pkgs.lib.mapAttrsToList cfgLine properties)} - ''; + cfgFile = + fileName: properties: + pkgs.writeTextDir fileName '' + # generated by NixOS + ${builtins.concatStringsSep "" (pkgs.lib.mapAttrsToList cfgLine properties)} + ''; userFunctions = '' hadoop_verify_logdir() { echo Skipping verification of log directory @@ -29,17 +39,20 @@ let export HADOOP_LOG_DIR=/tmp/hadoop/$USER ''; in -pkgs.runCommand "hadoop-conf" {} (with cfg; '' - mkdir -p $out/ - cp ${siteXml "core-site.xml" (coreSite // coreSiteInternal)}/* $out/ - cp ${siteXml "hdfs-site.xml" (hdfsSiteDefault // hdfsSite // hdfsSiteInternal)}/* $out/ - cp ${siteXml "hbase-site.xml" (hbaseSiteDefault // hbaseSite // hbaseSiteInternal)}/* $out/ - cp ${siteXml "mapred-site.xml" (mapredSiteDefault // mapredSite)}/* $out/ - cp ${siteXml "yarn-site.xml" (yarnSiteDefault // yarnSite // yarnSiteInternal)}/* $out/ - cp ${siteXml "httpfs-site.xml" httpfsSite}/* $out/ - cp ${cfgFile "container-executor.cfg" containerExecutorCfg}/* $out/ - cp ${pkgs.writeTextDir "hadoop-user-functions.sh" userFunctions}/* $out/ - cp ${pkgs.writeTextDir "hadoop-env.sh" hadoopEnv}/* $out/ - cp ${log4jProperties} $out/log4j.properties - ${lib.concatMapStringsSep "\n" (dir: "cp -f -r ${dir}/* $out/") extraConfDirs} -'') +pkgs.runCommand "hadoop-conf" { } ( + with cfg; + '' + mkdir -p $out/ + cp ${siteXml "core-site.xml" (coreSite // coreSiteInternal)}/* $out/ + cp ${siteXml "hdfs-site.xml" (hdfsSiteDefault // hdfsSite // hdfsSiteInternal)}/* $out/ + cp ${siteXml "hbase-site.xml" (hbaseSiteDefault // hbaseSite // hbaseSiteInternal)}/* $out/ + cp ${siteXml "mapred-site.xml" (mapredSiteDefault // mapredSite)}/* $out/ + cp ${siteXml "yarn-site.xml" (yarnSiteDefault // yarnSite // yarnSiteInternal)}/* $out/ + cp ${siteXml "httpfs-site.xml" httpfsSite}/* $out/ + cp ${cfgFile "container-executor.cfg" containerExecutorCfg}/* $out/ + cp ${pkgs.writeTextDir "hadoop-user-functions.sh" userFunctions}/* $out/ + cp ${pkgs.writeTextDir "hadoop-env.sh" hadoopEnv}/* $out/ + cp ${log4jProperties} $out/log4j.properties + ${lib.concatMapStringsSep "\n" (dir: "cp -f -r ${dir}/* $out/") extraConfDirs} + '' +) diff --git a/nixos/modules/services/cluster/hadoop/default.nix b/nixos/modules/services/cluster/hadoop/default.nix index b4f89366d5bd34..5ec3fc948d6588 100644 --- a/nixos/modules/services/cluster/hadoop/default.nix +++ b/nixos/modules/services/cluster/hadoop/default.nix @@ -1,14 +1,24 @@ -{ config, lib, options, pkgs, ...}: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.hadoop; opt = options.services.hadoop; in { - imports = [ ./yarn.nix ./hdfs.nix ./hbase.nix ]; + imports = [ + ./yarn.nix + ./hdfs.nix + ./hbase.nix + ]; options.services.hadoop = { coreSite = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.anything; example = lib.literalExpression '' { @@ -21,7 +31,7 @@ in ''; }; coreSiteInternal = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.anything; internal = true; description = '' @@ -42,7 +52,7 @@ in ''; }; hdfsSite = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.anything; example = lib.literalExpression '' { @@ -55,7 +65,7 @@ in ''; }; hdfsSiteInternal = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.anything; internal = true; description = '' @@ -84,7 +94,7 @@ in ''; }; mapredSite = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.anything; example = lib.literalExpression '' { @@ -103,13 +113,17 @@ in "yarn.nodemanager.aux-services" = "mapreduce_shuffle"; "yarn.nodemanager.aux-services.mapreduce_shuffle.class" = "org.apache.hadoop.mapred.ShuffleHandler"; "yarn.nodemanager.bind-host" = "0.0.0.0"; - "yarn.nodemanager.container-executor.class" = "org.apache.hadoop.yarn.server.nodemanager.LinuxContainerExecutor"; - "yarn.nodemanager.env-whitelist" = "JAVA_HOME,HADOOP_COMMON_HOME,HADOOP_HDFS_HOME,HADOOP_CONF_DIR,CLASSPATH_PREPEND_DISTCACHE,HADOOP_YARN_HOME,HADOOP_HOME,LANG,TZ"; + "yarn.nodemanager.container-executor.class" = + "org.apache.hadoop.yarn.server.nodemanager.LinuxContainerExecutor"; + "yarn.nodemanager.env-whitelist" = + "JAVA_HOME,HADOOP_COMMON_HOME,HADOOP_HDFS_HOME,HADOOP_CONF_DIR,CLASSPATH_PREPEND_DISTCACHE,HADOOP_YARN_HOME,HADOOP_HOME,LANG,TZ"; "yarn.nodemanager.linux-container-executor.group" = "hadoop"; - "yarn.nodemanager.linux-container-executor.path" = "/run/wrappers/yarn-nodemanager/bin/container-executor"; + "yarn.nodemanager.linux-container-executor.path" = + "/run/wrappers/yarn-nodemanager/bin/container-executor"; "yarn.nodemanager.log-dirs" = "/var/log/hadoop/yarn/nodemanager"; "yarn.resourcemanager.bind-host" = "0.0.0.0"; - "yarn.resourcemanager.scheduler.class" = "org.apache.hadoop.yarn.server.resourcemanager.scheduler.fair.FairScheduler"; + "yarn.resourcemanager.scheduler.class" = + "org.apache.hadoop.yarn.server.resourcemanager.scheduler.fair.FairScheduler"; }; type = lib.types.attrsOf lib.types.anything; description = '' @@ -117,7 +131,7 @@ in ''; }; yarnSite = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.anything; example = lib.literalExpression '' { @@ -130,7 +144,7 @@ in ''; }; yarnSiteInternal = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.anything; internal = true; description = '' @@ -167,9 +181,9 @@ in containerExecutorCfg = lib.mkOption { default = { # must be the same as yarn.nodemanager.linux-container-executor.group in yarnSite - "yarn.nodemanager.linux-container-executor.group"="hadoop"; - "min.user.id"=1000; - "feature.terminal.enabled"=1; + "yarn.nodemanager.linux-container-executor.group" = "hadoop"; + "min.user.id" = 1000; + "feature.terminal.enabled" = 1; "feature.mount-cgroup.enabled" = 1; }; type = lib.types.attrsOf lib.types.anything; @@ -185,7 +199,7 @@ in }; extraConfDirs = lib.mkOption { - default = []; + default = [ ]; type = lib.types.listOf lib.types.path; example = lib.literalExpression '' [ @@ -201,16 +215,17 @@ in package = lib.mkPackageOption pkgs "hadoop" { }; }; - config = lib.mkIf cfg.gatewayRole.enable { users.groups.hadoop = { gid = config.ids.gids.hadoop; }; environment = { systemPackages = [ cfg.package ]; - etc."hadoop-conf".source = let - hadoopConf = "${import ./conf.nix { inherit cfg pkgs lib; }}/"; - in "${hadoopConf}"; + etc."hadoop-conf".source = + let + hadoopConf = "${import ./conf.nix { inherit cfg pkgs lib; }}/"; + in + "${hadoopConf}"; variables.HADOOP_CONF_DIR = "/etc/hadoop-conf/"; }; }; diff --git a/nixos/modules/services/cluster/hadoop/hbase.nix b/nixos/modules/services/cluster/hadoop/hbase.nix index b6b45d57032f74..43b8ff79168d7e 100644 --- a/nixos/modules/services/cluster/hadoop/hbase.nix +++ b/nixos/modules/services/cluster/hadoop/hbase.nix @@ -1,92 +1,106 @@ -{ config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hadoop; hadoopConf = "${import ./conf.nix { inherit cfg pkgs lib; }}/"; mkIfNotNull = x: lib.mkIf (x != null) x; # generic hbase role options - hbaseRoleOption = name: extraOpts: { - enable = lib.mkEnableOption "HBase ${name}"; + hbaseRoleOption = + name: extraOpts: + { + enable = lib.mkEnableOption "HBase ${name}"; - openFirewall = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Open firewall ports for HBase ${name}."; - }; + openFirewall = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Open firewall ports for HBase ${name}."; + }; - restartIfChanged = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Restart ${name} con config change."; - }; + restartIfChanged = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Restart ${name} con config change."; + }; - extraFlags = lib.mkOption { - type = with lib.types; listOf str; - default = []; - example = lib.literalExpression ''[ "--backup" ]''; - description = "Extra flags for the ${name} service."; - }; + extraFlags = lib.mkOption { + type = with lib.types; listOf str; + default = [ ]; + example = lib.literalExpression ''[ "--backup" ]''; + description = "Extra flags for the ${name} service."; + }; - environment = lib.mkOption { - type = with lib.types; attrsOf str; - default = {}; - example = lib.literalExpression '' - { - HBASE_MASTER_OPTS = "-Dcom.sun.management.jmxremote.ssl=true"; - } - ''; - description = "Environment variables passed to ${name}."; - }; - } // extraOpts; + environment = lib.mkOption { + type = with lib.types; attrsOf str; + default = { }; + example = lib.literalExpression '' + { + HBASE_MASTER_OPTS = "-Dcom.sun.management.jmxremote.ssl=true"; + } + ''; + description = "Environment variables passed to ${name}."; + }; + } + // extraOpts; # generic hbase role configs - hbaseRoleConfig = name: ports: (lib.mkIf cfg.hbase."${name}".enable { - services.hadoop.gatewayRole = { - enable = true; - enableHbaseCli = lib.mkDefault true; - }; + hbaseRoleConfig = + name: ports: + (lib.mkIf cfg.hbase."${name}".enable { + services.hadoop.gatewayRole = { + enable = true; + enableHbaseCli = lib.mkDefault true; + }; - systemd.services."hbase-${lib.toLower name}" = { - description = "HBase ${name}"; - wantedBy = [ "multi-user.target" ]; - path = with cfg; [ hbase.package ] ++ optional - (with cfg.hbase.master; enable && initHDFS) package; - preStart = lib.mkIf (with cfg.hbase.master; enable && initHDFS) - (lib.concatStringsSep "\n" ( - map (x: "HADOOP_USER_NAME=hdfs hdfs --config /etc/hadoop-conf ${x}")[ - "dfsadmin -safemode wait" - "dfs -mkdir -p ${cfg.hbase.rootdir}" - "dfs -chown hbase ${cfg.hbase.rootdir}" + systemd.services."hbase-${lib.toLower name}" = { + description = "HBase ${name}"; + wantedBy = [ "multi-user.target" ]; + path = with cfg; [ hbase.package ] ++ optional (with cfg.hbase.master; enable && initHDFS) package; + preStart = lib.mkIf (with cfg.hbase.master; enable && initHDFS) ( + lib.concatStringsSep "\n" ( + map (x: "HADOOP_USER_NAME=hdfs hdfs --config /etc/hadoop-conf ${x}") [ + "dfsadmin -safemode wait" + "dfs -mkdir -p ${cfg.hbase.rootdir}" + "dfs -chown hbase ${cfg.hbase.rootdir}" + ] + ) + ); + + inherit (cfg.hbase."${name}") environment; + script = lib.concatStringsSep " " ( + [ + "hbase --config /etc/hadoop-conf/" + "${lib.toLower name} start" ] - )); - - inherit (cfg.hbase."${name}") environment; - script = lib.concatStringsSep " " ( - [ - "hbase --config /etc/hadoop-conf/" - "${lib.toLower name} start" - ] - ++ cfg.hbase."${name}".extraFlags - ++ map (x: "--${lib.toLower x} ${toString cfg.hbase.${name}.${x}}") - (lib.filter (x: lib.hasAttr x cfg.hbase.${name}) ["port" "infoPort"]) - ); - - serviceConfig = { - User = "hbase"; - SyslogIdentifier = "hbase-${lib.toLower name}"; - Restart = "always"; + ++ cfg.hbase."${name}".extraFlags + ++ map (x: "--${lib.toLower x} ${toString cfg.hbase.${name}.${x}}") ( + lib.filter (x: lib.hasAttr x cfg.hbase.${name}) [ + "port" + "infoPort" + ] + ) + ); + + serviceConfig = { + User = "hbase"; + SyslogIdentifier = "hbase-${lib.toLower name}"; + Restart = "always"; + }; }; - }; - services.hadoop.hbaseSiteInternal."hbase.rootdir" = cfg.hbase.rootdir; + services.hadoop.hbaseSiteInternal."hbase.rootdir" = cfg.hbase.rootdir; - networking = { - firewall.allowedTCPPorts = lib.mkIf cfg.hbase."${name}".openFirewall ports; - hosts = lib.mkIf (with cfg.hbase.regionServer; enable && overrideHosts) { - "127.0.0.2" = lib.mkForce [ ]; - "::1" = lib.mkForce [ ]; + networking = { + firewall.allowedTCPPorts = lib.mkIf cfg.hbase."${name}".openFirewall ports; + hosts = lib.mkIf (with cfg.hbase.regionServer; enable && overrideHosts) { + "127.0.0.2" = lib.mkForce [ ]; + "::1" = lib.mkForce [ ]; + }; }; - }; - }); + }); in { options.services.hadoop = { @@ -108,7 +122,7 @@ in ''; }; hbaseSite = lib.mkOption { - default = {}; + default = { }; type = with lib.types; attrsOf anything; example = lib.literalExpression '' { @@ -122,7 +136,7 @@ in ''; }; hbaseSiteInternal = lib.mkOption { - default = {}; + default = { }; type = with lib.types; attrsOf anything; internal = true; description = '' @@ -130,82 +144,102 @@ in ''; }; - hbase = { + hbase = + { - package = lib.mkPackageOption pkgs "hbase" { }; + package = lib.mkPackageOption pkgs "hbase" { }; - rootdir = lib.mkOption { - description = '' - This option will set "hbase.rootdir" in hbase-site.xml and determine - the directory shared by region servers and into which HBase persists. - The URL should be 'fully-qualified' to include the filesystem scheme. - If a core-site.xml is provided, the FS scheme defaults to the value - of "fs.defaultFS". + rootdir = lib.mkOption { + description = '' + This option will set "hbase.rootdir" in hbase-site.xml and determine + the directory shared by region servers and into which HBase persists. + The URL should be 'fully-qualified' to include the filesystem scheme. + If a core-site.xml is provided, the FS scheme defaults to the value + of "fs.defaultFS". - Filesystems other than HDFS (like S3, QFS, Swift) are also supported. - ''; - type = lib.types.str; - example = "hdfs://nameservice1/hbase"; - default = "/hbase"; - }; - zookeeperQuorum = lib.mkOption { - description = '' - This option will set "hbase.zookeeper.quorum" in hbase-site.xml. - Comma separated list of servers in the ZooKeeper ensemble. - ''; - type = with lib.types; nullOr commas; - example = "zk1.internal,zk2.internal,zk3.internal"; - default = null; - }; - } // (let - ports = port: infoPort: { - port = lib.mkOption { - type = lib.types.int; - default = port; - description = "RPC port"; + Filesystems other than HDFS (like S3, QFS, Swift) are also supported. + ''; + type = lib.types.str; + example = "hdfs://nameservice1/hbase"; + default = "/hbase"; }; - infoPort = lib.mkOption { - type = lib.types.int; - default = infoPort; - description = "web UI port"; + zookeeperQuorum = lib.mkOption { + description = '' + This option will set "hbase.zookeeper.quorum" in hbase-site.xml. + Comma separated list of servers in the ZooKeeper ensemble. + ''; + type = with lib.types; nullOr commas; + example = "zk1.internal,zk2.internal,zk3.internal"; + default = null; }; - }; - in lib.mapAttrs hbaseRoleOption { - master.initHDFS = lib.mkEnableOption "initialization of the hbase directory on HDFS"; - regionServer.overrideHosts = lib.mkOption { - type = lib.types.bool; - default = true; - description = '' - Remove /etc/hosts entries for "127.0.0.2" and "::1" defined in nixos/modules/config/networking.nix - Regionservers must be able to resolve their hostnames to their IP addresses, through PTR records - or /etc/hosts entries. - ''; - }; - thrift = ports 9090 9095; - rest = ports 8080 8085; - }); + } + // ( + let + ports = port: infoPort: { + port = lib.mkOption { + type = lib.types.int; + default = port; + description = "RPC port"; + }; + infoPort = lib.mkOption { + type = lib.types.int; + default = infoPort; + description = "web UI port"; + }; + }; + in + lib.mapAttrs hbaseRoleOption { + master.initHDFS = lib.mkEnableOption "initialization of the hbase directory on HDFS"; + regionServer.overrideHosts = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Remove /etc/hosts entries for "127.0.0.2" and "::1" defined in nixos/modules/config/networking.nix + Regionservers must be able to resolve their hostnames to their IP addresses, through PTR records + or /etc/hosts entries. + ''; + }; + thrift = ports 9090 9095; + rest = ports 8080 8085; + } + ); }; - config = lib.mkMerge ([ + config = lib.mkMerge ( + [ - (lib.mkIf cfg.gatewayRole.enable { + (lib.mkIf cfg.gatewayRole.enable { - environment.systemPackages = lib.mkIf cfg.gatewayRole.enableHbaseCli [ cfg.hbase.package ]; + environment.systemPackages = lib.mkIf cfg.gatewayRole.enableHbaseCli [ cfg.hbase.package ]; - services.hadoop.hbaseSiteInternal = with cfg.hbase; { - "hbase.zookeeper.quorum" = mkIfNotNull zookeeperQuorum; - }; + services.hadoop.hbaseSiteInternal = with cfg.hbase; { + "hbase.zookeeper.quorum" = mkIfNotNull zookeeperQuorum; + }; - users.users.hbase = { - description = "Hadoop HBase user"; - group = "hadoop"; - isSystemUser = true; - }; + users.users.hbase = { + description = "Hadoop HBase user"; + group = "hadoop"; + isSystemUser = true; + }; + }) + ] + ++ (lib.mapAttrsToList hbaseRoleConfig { + master = [ + 16000 + 16010 + ]; + regionServer = [ + 16020 + 16030 + ]; + thrift = with cfg.hbase.thrift; [ + port + infoPort + ]; + rest = with cfg.hbase.rest; [ + port + infoPort + ]; }) - ] ++ (lib.mapAttrsToList hbaseRoleConfig { - master = [ 16000 16010 ]; - regionServer = [ 16020 16030 ]; - thrift = with cfg.hbase.thrift; [ port infoPort ]; - rest = with cfg.hbase.rest; [ port infoPort ]; - })); + ); } diff --git a/nixos/modules/services/cluster/hadoop/hdfs.nix b/nixos/modules/services/cluster/hadoop/hdfs.nix index 5ca12f4b4c8b8b..34370307fd3cd7 100644 --- a/nixos/modules/services/cluster/hadoop/hdfs.nix +++ b/nixos/modules/services/cluster/hadoop/hdfs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hadoop; @@ -6,72 +11,87 @@ let hadoopConf = "${import ./conf.nix { inherit cfg pkgs lib; }}/"; # Generator for HDFS service options - hadoopServiceOption = { serviceName, firewallOption ? true, extraOpts ? null }: { - enable = lib.mkEnableOption serviceName; - restartIfChanged = lib.mkOption { - type = lib.types.bool; - description = '' - Automatically restart the service on config change. - This can be set to false to defer restarts on clusters running critical applications. - Please consider the security implications of inadvertently running an older version, - and the possibility of unexpected behavior caused by inconsistent versions across a cluster when disabling this option. - ''; - default = false; - }; - extraFlags = lib.mkOption{ - type = with lib.types; listOf str; - default = []; - description = "Extra command line flags to pass to ${serviceName}"; - example = [ - "-Dcom.sun.management.jmxremote" - "-Dcom.sun.management.jmxremote.port=8010" - ]; - }; - extraEnv = lib.mkOption{ - type = with lib.types; attrsOf str; - default = {}; - description = "Extra environment variables for ${serviceName}"; - }; - } // (lib.optionalAttrs firewallOption { - openFirewall = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Open firewall ports for ${serviceName}."; - }; - }) // (lib.optionalAttrs (extraOpts != null) extraOpts); + hadoopServiceOption = + { + serviceName, + firewallOption ? true, + extraOpts ? null, + }: + { + enable = lib.mkEnableOption serviceName; + restartIfChanged = lib.mkOption { + type = lib.types.bool; + description = '' + Automatically restart the service on config change. + This can be set to false to defer restarts on clusters running critical applications. + Please consider the security implications of inadvertently running an older version, + and the possibility of unexpected behavior caused by inconsistent versions across a cluster when disabling this option. + ''; + default = false; + }; + extraFlags = lib.mkOption { + type = with lib.types; listOf str; + default = [ ]; + description = "Extra command line flags to pass to ${serviceName}"; + example = [ + "-Dcom.sun.management.jmxremote" + "-Dcom.sun.management.jmxremote.port=8010" + ]; + }; + extraEnv = lib.mkOption { + type = with lib.types; attrsOf str; + default = { }; + description = "Extra environment variables for ${serviceName}"; + }; + } + // (lib.optionalAttrs firewallOption { + openFirewall = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Open firewall ports for ${serviceName}."; + }; + }) + // (lib.optionalAttrs (extraOpts != null) extraOpts); # Generator for HDFS service configs hadoopServiceConfig = - { name - , serviceOptions ? cfg.hdfs."${lib.toLower name}" - , description ? "Hadoop HDFS ${name}" - , User ? "hdfs" - , allowedTCPPorts ? [ ] - , preStart ? "" - , environment ? { } - , extraConfig ? { } - }: ( - - lib.mkIf serviceOptions.enable ( lib.mkMerge [{ - systemd.services."hdfs-${lib.toLower name}" = { - inherit description preStart; - environment = environment // serviceOptions.extraEnv; - wantedBy = [ "multi-user.target" ]; - inherit (serviceOptions) restartIfChanged; - serviceConfig = { - inherit User; - SyslogIdentifier = "hdfs-${lib.toLower name}"; - ExecStart = "${cfg.package}/bin/hdfs --config ${hadoopConf} ${lib.toLower name} ${lib.escapeShellArgs serviceOptions.extraFlags}"; - Restart = "always"; - }; - }; - - services.hadoop.gatewayRole.enable = true; - - networking.firewall.allowedTCPPorts = lib.mkIf - ((builtins.hasAttr "openFirewall" serviceOptions) && serviceOptions.openFirewall) - allowedTCPPorts; - } extraConfig]) + { + name, + serviceOptions ? cfg.hdfs."${lib.toLower name}", + description ? "Hadoop HDFS ${name}", + User ? "hdfs", + allowedTCPPorts ? [ ], + preStart ? "", + environment ? { }, + extraConfig ? { }, + }: + ( + + lib.mkIf serviceOptions.enable ( + lib.mkMerge [ + { + systemd.services."hdfs-${lib.toLower name}" = { + inherit description preStart; + environment = environment // serviceOptions.extraEnv; + wantedBy = [ "multi-user.target" ]; + inherit (serviceOptions) restartIfChanged; + serviceConfig = { + inherit User; + SyslogIdentifier = "hdfs-${lib.toLower name}"; + ExecStart = "${cfg.package}/bin/hdfs --config ${hadoopConf} ${lib.toLower name} ${lib.escapeShellArgs serviceOptions.extraFlags}"; + Restart = "always"; + }; + }; + + services.hadoop.gatewayRole.enable = true; + + networking.firewall.allowedTCPPorts = lib.mkIf ( + (builtins.hasAttr "openFirewall" serviceOptions) && serviceOptions.openFirewall + ) allowedTCPPorts; + } + extraConfig + ] + ) ); in @@ -96,21 +116,30 @@ in dataDirs = lib.mkOption { default = null; description = "Tier and path definitions for datanode storage."; - type = with lib.types; nullOr (listOf (submodule { - options = { - type = lib.mkOption { - type = enum [ "SSD" "DISK" "ARCHIVE" "RAM_DISK" ]; - description = '' - Storage types ([SSD]/[DISK]/[ARCHIVE]/[RAM_DISK]) for HDFS storage policies. - ''; - }; - path = lib.mkOption { - type = path; - example = [ "/var/lib/hadoop/hdfs/dn" ]; - description = "Determines where on the local filesystem a data node should store its blocks."; - }; - }; - })); + type = + with lib.types; + nullOr ( + listOf (submodule { + options = { + type = lib.mkOption { + type = enum [ + "SSD" + "DISK" + "ARCHIVE" + "RAM_DISK" + ]; + description = '' + Storage types ([SSD]/[DISK]/[ARCHIVE]/[RAM_DISK]) for HDFS storage policies. + ''; + }; + path = lib.mkOption { + type = path; + example = [ "/var/lib/hadoop/hdfs/dn" ]; + description = "Determines where on the local filesystem a data node should store its blocks."; + }; + }; + }) + ); }; }; @@ -140,25 +169,30 @@ in 8022 # namenode.servicerpc-address 8019 # dfs.ha.zkfc.port ]; - preStart = (lib.mkIf cfg.hdfs.namenode.formatOnInit - "${cfg.package}/bin/hdfs --config ${hadoopConf} namenode -format -nonInteractive || true" + preStart = ( + lib.mkIf cfg.hdfs.namenode.formatOnInit "${cfg.package}/bin/hdfs --config ${hadoopConf} namenode -format -nonInteractive || true" ); }) (hadoopServiceConfig { name = "DataNode"; # port numbers for datanode changed between hadoop 2 and 3 - allowedTCPPorts = if lib.versionAtLeast cfg.package.version "3" then [ - 9864 # datanode.http.address - 9866 # datanode.address - 9867 # datanode.ipc.address - ] else [ - 50075 # datanode.http.address - 50010 # datanode.address - 50020 # datanode.ipc.address - ]; - extraConfig.services.hadoop.hdfsSiteInternal."dfs.datanode.data.dir" = lib.mkIf (cfg.hdfs.datanode.dataDirs!= null) - (lib.concatMapStringsSep "," (x: "["+x.type+"]file://"+x.path) cfg.hdfs.datanode.dataDirs); + allowedTCPPorts = + if lib.versionAtLeast cfg.package.version "3" then + [ + 9864 # datanode.http.address + 9866 # datanode.address + 9867 # datanode.ipc.address + ] + else + [ + 50075 # datanode.http.address + 50010 # datanode.address + 50020 # datanode.ipc.address + ]; + extraConfig.services.hadoop.hdfsSiteInternal."dfs.datanode.data.dir" = lib.mkIf ( + cfg.hdfs.datanode.dataDirs != null + ) (lib.concatMapStringsSep "," (x: "[" + x.type + "]file://" + x.path) cfg.hdfs.datanode.dataDirs); }) (hadoopServiceConfig { diff --git a/nixos/modules/services/cluster/hadoop/yarn.nix b/nixos/modules/services/cluster/hadoop/yarn.nix index 77eb996360735a..7c0bc8e972d960 100644 --- a/nixos/modules/services/cluster/hadoop/yarn.nix +++ b/nixos/modules/services/cluster/hadoop/yarn.nix @@ -1,8 +1,13 @@ -{ config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hadoop; hadoopConf = "${import ./conf.nix { inherit cfg pkgs lib; }}/"; - restartIfChanged = lib.mkOption { + restartIfChanged = lib.mkOption { type = lib.types.bool; description = '' Automatically restart the service on config change. @@ -12,18 +17,18 @@ let ''; default = false; }; - extraFlags = lib.mkOption{ + extraFlags = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; description = "Extra command line flags to pass to the service"; example = [ "-Dcom.sun.management.jmxremote" "-Dcom.sun.management.jmxremote.port=8010" ]; }; - extraEnv = lib.mkOption{ + extraEnv = lib.mkOption { type = with lib.types; attrsOf str; - default = {}; + default = { }; description = "Extra environment variables"; }; in @@ -120,21 +125,24 @@ in serviceConfig = { User = "yarn"; SyslogIdentifier = "yarn-resourcemanager"; - ExecStart = "${cfg.package}/bin/yarn --config ${hadoopConf} " + - " resourcemanager ${lib.escapeShellArgs cfg.yarn.resourcemanager.extraFlags}"; + ExecStart = + "${cfg.package}/bin/yarn --config ${hadoopConf} " + + " resourcemanager ${lib.escapeShellArgs cfg.yarn.resourcemanager.extraFlags}"; Restart = "always"; }; }; services.hadoop.gatewayRole.enable = true; - networking.firewall.allowedTCPPorts = (lib.mkIf cfg.yarn.resourcemanager.openFirewall [ - 8088 # resourcemanager.webapp.address - 8030 # resourcemanager.scheduler.address - 8031 # resourcemanager.resource-tracker.address - 8032 # resourcemanager.address - 8033 # resourcemanager.admin.address - ]); + networking.firewall.allowedTCPPorts = ( + lib.mkIf cfg.yarn.resourcemanager.openFirewall [ + 8088 # resourcemanager.webapp.address + 8030 # resourcemanager.scheduler.address + 8031 # resourcemanager.resource-tracker.address + 8032 # resourcemanager.address + 8033 # resourcemanager.admin.address + ] + ); }) (lib.mkIf cfg.yarn.nodemanager.enable { @@ -169,29 +177,40 @@ in User = "yarn"; SyslogIdentifier = "yarn-nodemanager"; PermissionsStartOnly = true; - ExecStart = "${cfg.package}/bin/yarn --config ${hadoopConf} " + - " nodemanager ${lib.escapeShellArgs cfg.yarn.nodemanager.extraFlags}"; + ExecStart = + "${cfg.package}/bin/yarn --config ${hadoopConf} " + + " nodemanager ${lib.escapeShellArgs cfg.yarn.nodemanager.extraFlags}"; Restart = "always"; }; }; services.hadoop.gatewayRole.enable = true; - services.hadoop.yarnSiteInternal = with cfg.yarn.nodemanager; mkMerge [ ({ - "yarn.nodemanager.local-dirs" = mkIf (localDir!= null) (concatStringsSep "," localDir); - "yarn.scheduler.maximum-allocation-vcores" = resource.maximumAllocationVCores; - "yarn.scheduler.maximum-allocation-mb" = resource.maximumAllocationMB; - "yarn.nodemanager.resource.cpu-vcores" = resource.cpuVCores; - "yarn.nodemanager.resource.memory-mb" = resource.memoryMB; - }) (mkIf useCGroups { - "yarn.nodemanager.linux-container-executor.cgroups.hierarchy" = "/hadoop-yarn"; - "yarn.nodemanager.linux-container-executor.resources-handler.class" = "org.apache.hadoop.yarn.server.nodemanager.util.CgroupsLCEResourcesHandler"; - "yarn.nodemanager.linux-container-executor.cgroups.mount" = "true"; - "yarn.nodemanager.linux-container-executor.cgroups.mount-path" = "/run/wrappers/yarn-nodemanager/cgroup"; - })]; + services.hadoop.yarnSiteInternal = + with cfg.yarn.nodemanager; + mkMerge [ + ({ + "yarn.nodemanager.local-dirs" = mkIf (localDir != null) (concatStringsSep "," localDir); + "yarn.scheduler.maximum-allocation-vcores" = resource.maximumAllocationVCores; + "yarn.scheduler.maximum-allocation-mb" = resource.maximumAllocationMB; + "yarn.nodemanager.resource.cpu-vcores" = resource.cpuVCores; + "yarn.nodemanager.resource.memory-mb" = resource.memoryMB; + }) + (mkIf useCGroups { + "yarn.nodemanager.linux-container-executor.cgroups.hierarchy" = "/hadoop-yarn"; + "yarn.nodemanager.linux-container-executor.resources-handler.class" = + "org.apache.hadoop.yarn.server.nodemanager.util.CgroupsLCEResourcesHandler"; + "yarn.nodemanager.linux-container-executor.cgroups.mount" = "true"; + "yarn.nodemanager.linux-container-executor.cgroups.mount-path" = + "/run/wrappers/yarn-nodemanager/cgroup"; + }) + ]; networking.firewall.allowedTCPPortRanges = [ - (lib.mkIf (cfg.yarn.nodemanager.openFirewall) {from = 1024; to = 65535;}) + (lib.mkIf (cfg.yarn.nodemanager.openFirewall) { + from = 1024; + to = 65535; + }) ]; }) diff --git a/nixos/modules/services/cluster/kubernetes/addon-manager.nix b/nixos/modules/services/cluster/kubernetes/addon-manager.nix index af4346d3c3ce95..38080b6dd20d74 100644 --- a/nixos/modules/services/cluster/kubernetes/addon-manager.nix +++ b/nixos/modules/services/cluster/kubernetes/addon-manager.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let top = config.services.kubernetes; cfg = top.addonManager; @@ -8,9 +13,11 @@ let addons = pkgs.runCommand "kubernetes-addons" { } '' mkdir -p $out # since we are mounting the addons to the addon manager, they need to be copied - ${lib.concatMapStringsSep ";" (a: "cp -v ${a}/* $out/") (lib.mapAttrsToList (name: addon: - pkgs.writeTextDir "${name}.json" (builtins.toJSON addon) - ) (cfg.addons))} + ${lib.concatMapStringsSep ";" (a: "cp -v ${a}/* $out/") ( + lib.mapAttrsToList (name: addon: pkgs.writeTextDir "${name}.json" (builtins.toJSON addon)) ( + cfg.addons + ) + )} ''; in { @@ -86,74 +93,83 @@ in }; }; - services.kubernetes.addonManager.bootstrapAddons = lib.mkIf isRBACEnabled - (let - name = "system:kube-addon-manager"; - namespace = "kube-system"; - in - { + services.kubernetes.addonManager.bootstrapAddons = lib.mkIf isRBACEnabled ( + let + name = "system:kube-addon-manager"; + namespace = "kube-system"; + in + { - kube-addon-manager-r = { - apiVersion = "rbac.authorization.k8s.io/v1"; - kind = "Role"; - metadata = { - inherit name namespace; - }; - rules = [{ - apiGroups = ["*"]; - resources = ["*"]; - verbs = ["*"]; - }]; - }; - - kube-addon-manager-rb = { - apiVersion = "rbac.authorization.k8s.io/v1"; - kind = "RoleBinding"; - metadata = { - inherit name namespace; - }; - roleRef = { - apiGroup = "rbac.authorization.k8s.io"; + kube-addon-manager-r = { + apiVersion = "rbac.authorization.k8s.io/v1"; kind = "Role"; - inherit name; + metadata = { + inherit name namespace; + }; + rules = [ + { + apiGroups = [ "*" ]; + resources = [ "*" ]; + verbs = [ "*" ]; + } + ]; }; - subjects = [{ - apiGroup = "rbac.authorization.k8s.io"; - kind = "User"; - inherit name; - }]; - }; - kube-addon-manager-cluster-lister-cr = { - apiVersion = "rbac.authorization.k8s.io/v1"; - kind = "ClusterRole"; - metadata = { - name = "${name}:cluster-lister"; + kube-addon-manager-rb = { + apiVersion = "rbac.authorization.k8s.io/v1"; + kind = "RoleBinding"; + metadata = { + inherit name namespace; + }; + roleRef = { + apiGroup = "rbac.authorization.k8s.io"; + kind = "Role"; + inherit name; + }; + subjects = [ + { + apiGroup = "rbac.authorization.k8s.io"; + kind = "User"; + inherit name; + } + ]; }; - rules = [{ - apiGroups = ["*"]; - resources = ["*"]; - verbs = ["list"]; - }]; - }; - kube-addon-manager-cluster-lister-crb = { - apiVersion = "rbac.authorization.k8s.io/v1"; - kind = "ClusterRoleBinding"; - metadata = { - name = "${name}:cluster-lister"; - }; - roleRef = { - apiGroup = "rbac.authorization.k8s.io"; + kube-addon-manager-cluster-lister-cr = { + apiVersion = "rbac.authorization.k8s.io/v1"; kind = "ClusterRole"; - name = "${name}:cluster-lister"; + metadata = { + name = "${name}:cluster-lister"; + }; + rules = [ + { + apiGroups = [ "*" ]; + resources = [ "*" ]; + verbs = [ "list" ]; + } + ]; }; - subjects = [{ - kind = "User"; - inherit name; - }]; - }; - }); + + kube-addon-manager-cluster-lister-crb = { + apiVersion = "rbac.authorization.k8s.io/v1"; + kind = "ClusterRoleBinding"; + metadata = { + name = "${name}:cluster-lister"; + }; + roleRef = { + apiGroup = "rbac.authorization.k8s.io"; + kind = "ClusterRole"; + name = "${name}:cluster-lister"; + }; + subjects = [ + { + kind = "User"; + inherit name; + } + ]; + }; + } + ); services.kubernetes.pki.certs = { addonManager = top.lib.mkCert { diff --git a/nixos/modules/services/cluster/kubernetes/controller-manager.nix b/nixos/modules/services/cluster/kubernetes/controller-manager.nix index 044ae8e42153aa..788749cd43304b 100644 --- a/nixos/modules/services/cluster/kubernetes/controller-manager.nix +++ b/nixos/modules/services/cluster/kubernetes/controller-manager.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let top = config.services.kubernetes; otop = options.services.kubernetes; @@ -6,7 +12,10 @@ let in { imports = [ - (lib.mkRenamedOptionModule [ "services" "kubernetes" "controllerManager" "address" ] ["services" "kubernetes" "controllerManager" "bindAddress"]) + (lib.mkRenamedOptionModule + [ "services" "kubernetes" "controllerManager" "address" ] + [ "services" "kubernetes" "controllerManager" "bindAddress" ] + ) (lib.mkRemovedOptionModule [ "services" "kubernetes" "controllerManager" "insecurePort" ] "") ]; @@ -113,28 +122,35 @@ in RestartSec = "30s"; Restart = "on-failure"; Slice = "kubernetes.slice"; - ExecStart = ''${top.package}/bin/kube-controller-manager \ - --allocate-node-cidrs=${lib.boolToString cfg.allocateNodeCIDRs} \ - --bind-address=${cfg.bindAddress} \ - ${lib.optionalString (cfg.clusterCidr!=null) - "--cluster-cidr=${cfg.clusterCidr}"} \ - ${lib.optionalString (cfg.featureGates != {}) - "--feature-gates=${lib.concatStringsSep "," (builtins.attrValues (lib.mapAttrs (n: v: "${n}=${lib.trivial.boolToString v}") cfg.featureGates))}"} \ - --kubeconfig=${top.lib.mkKubeConfig "kube-controller-manager" cfg.kubeconfig} \ - --leader-elect=${lib.boolToString cfg.leaderElect} \ - ${lib.optionalString (cfg.rootCaFile!=null) - "--root-ca-file=${cfg.rootCaFile}"} \ - --secure-port=${toString cfg.securePort} \ - ${lib.optionalString (cfg.serviceAccountKeyFile!=null) - "--service-account-private-key-file=${cfg.serviceAccountKeyFile}"} \ - ${lib.optionalString (cfg.tlsCertFile!=null) - "--tls-cert-file=${cfg.tlsCertFile}"} \ - ${lib.optionalString (cfg.tlsKeyFile!=null) - "--tls-private-key-file=${cfg.tlsKeyFile}"} \ - ${lib.optionalString (lib.elem "RBAC" top.apiserver.authorizationMode) - "--use-service-account-credentials"} \ - ${lib.optionalString (cfg.verbosity != null) "--v=${toString cfg.verbosity}"} \ - ${cfg.extraOpts} + ExecStart = '' + ${top.package}/bin/kube-controller-manager \ + --allocate-node-cidrs=${lib.boolToString cfg.allocateNodeCIDRs} \ + --bind-address=${cfg.bindAddress} \ + ${lib.optionalString (cfg.clusterCidr != null) "--cluster-cidr=${cfg.clusterCidr}"} \ + ${ + lib.optionalString (cfg.featureGates != { }) + "--feature-gates=${ + lib.concatStringsSep "," ( + builtins.attrValues (lib.mapAttrs (n: v: "${n}=${lib.trivial.boolToString v}") cfg.featureGates) + ) + }" + } \ + --kubeconfig=${top.lib.mkKubeConfig "kube-controller-manager" cfg.kubeconfig} \ + --leader-elect=${lib.boolToString cfg.leaderElect} \ + ${lib.optionalString (cfg.rootCaFile != null) "--root-ca-file=${cfg.rootCaFile}"} \ + --secure-port=${toString cfg.securePort} \ + ${ + lib.optionalString ( + cfg.serviceAccountKeyFile != null + ) "--service-account-private-key-file=${cfg.serviceAccountKeyFile}" + } \ + ${lib.optionalString (cfg.tlsCertFile != null) "--tls-cert-file=${cfg.tlsCertFile}"} \ + ${ + lib.optionalString (cfg.tlsKeyFile != null) "--tls-private-key-file=${cfg.tlsKeyFile}" + } \ + ${lib.optionalString (lib.elem "RBAC" top.apiserver.authorizationMode) "--use-service-account-credentials"} \ + ${lib.optionalString (cfg.verbosity != null) "--v=${toString cfg.verbosity}"} \ + ${cfg.extraOpts} ''; WorkingDirectory = top.dataDir; User = "kubernetes"; diff --git a/nixos/modules/services/cluster/kubernetes/default.nix b/nixos/modules/services/cluster/kubernetes/default.nix index dea16f2d319bbb..86e5e072aa0612 100644 --- a/nixos/modules/services/cluster/kubernetes/default.nix +++ b/nixos/modules/services/cluster/kubernetes/default.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.kubernetes; opt = options.services.kubernetes; @@ -28,47 +34,73 @@ let }; }; - mkKubeConfig = name: conf: pkgs.writeText "${name}-kubeconfig" (builtins.toJSON { - apiVersion = "v1"; - kind = "Config"; - clusters = [{ - name = "local"; - cluster.certificate-authority = conf.caFile or cfg.caFile; - cluster.server = conf.server; - }]; - users = [{ - inherit name; - user = { - client-certificate = conf.certFile; - client-key = conf.keyFile; - }; - }]; - contexts = [{ - context = { - cluster = "local"; - user = name; - }; - name = "local"; - }]; - current-context = "local"; - }); + mkKubeConfig = + name: conf: + pkgs.writeText "${name}-kubeconfig" ( + builtins.toJSON { + apiVersion = "v1"; + kind = "Config"; + clusters = [ + { + name = "local"; + cluster.certificate-authority = conf.caFile or cfg.caFile; + cluster.server = conf.server; + } + ]; + users = [ + { + inherit name; + user = { + client-certificate = conf.certFile; + client-key = conf.keyFile; + }; + } + ]; + contexts = [ + { + context = { + cluster = "local"; + user = name; + }; + name = "local"; + } + ]; + current-context = "local"; + } + ); caCert = secret "ca"; - etcdEndpoints = ["https://${cfg.masterAddress}:2379"]; - - mkCert = { name, CN, hosts ? [], fields ? {}, action ? "", - privateKeyOwner ? "kubernetes", privateKeyGroup ? "kubernetes" }: rec { - inherit name caCert CN hosts fields action; - cert = secret name; - key = secret "${name}-key"; - privateKeyOptions = { - owner = privateKeyOwner; - group = privateKeyGroup; - mode = "0600"; - path = key; + etcdEndpoints = [ "https://${cfg.masterAddress}:2379" ]; + + mkCert = + { + name, + CN, + hosts ? [ ], + fields ? { }, + action ? "", + privateKeyOwner ? "kubernetes", + privateKeyGroup ? "kubernetes", + }: + rec { + inherit + name + caCert + CN + hosts + fields + action + ; + cert = secret name; + key = secret "${name}-key"; + privateKeyOptions = { + owner = privateKeyOwner; + group = privateKeyGroup; + mode = "0600"; + path = key; + }; }; - }; secret = name: "${cfg.secretsPath}/${name}.pem"; @@ -97,10 +129,16 @@ let default = null; }; }; -in { +in +{ imports = [ - (lib.mkRemovedOptionModule [ "services" "kubernetes" "addons" "dashboard" ] "Removed due to it being an outdated version") + (lib.mkRemovedOptionModule [ + "services" + "kubernetes" + "addons" + "dashboard" + ] "Removed due to it being an outdated version") (lib.mkRemovedOptionModule [ "services" "kubernetes" "verbose" ] "") ]; @@ -115,8 +153,13 @@ in { addon manager, flannel and proxy services. Node role will enable flannel, docker, kubelet and proxy services. ''; - default = []; - type = lib.types.listOf (lib.types.enum ["master" "node"]); + default = [ ]; + type = lib.types.listOf ( + lib.types.enum [ + "master" + "node" + ] + ); }; package = lib.mkPackageOption pkgs "kubernetes" { }; @@ -152,7 +195,7 @@ in { featureGates = lib.mkOption { description = "List set of feature gates."; - default = {}; + default = { }; type = lib.types.attrsOf lib.types.bool; }; @@ -165,7 +208,7 @@ in { path = lib.mkOption { description = "Packages added to the services' PATH environment variable. Both the bin and sbin subdirectories of each package are added."; type = lib.types.listOf lib.types.package; - default = []; + default = [ ]; }; clusterCidr = lib.mkOption { @@ -222,7 +265,6 @@ in { }; }) - (lib.mkIf (lib.all (el: el == "master") cfg.roles) { # if this node is only a master make it unschedulable by default services.kubernetes.kubelet.unschedulable = lib.mkDefault true; @@ -234,7 +276,7 @@ in { }) # Using "services.kubernetes.roles" will automatically enable easyCerts and flannel - (lib.mkIf (cfg.roles != []) { + (lib.mkIf (cfg.roles != [ ]) { services.kubernetes.flannel.enable = lib.mkDefault true; services.flannel.etcd.endpoints = lib.mkDefault etcdEndpoints; services.kubernetes.easyCerts = lib.mkDefault true; @@ -266,42 +308,50 @@ in { }; }) - (lib.mkIf ( - cfg.apiserver.enable || - cfg.scheduler.enable || - cfg.controllerManager.enable || - cfg.kubelet.enable || - cfg.proxy.enable || - cfg.addonManager.enable - ) { - systemd.targets.kubernetes = { - description = "Kubernetes"; - wantedBy = [ "multi-user.target" ]; - }; - - systemd.tmpfiles.rules = [ - "d /opt/cni/bin 0755 root root -" - "d /run/kubernetes 0755 kubernetes kubernetes -" - "d ${cfg.dataDir} 0755 kubernetes kubernetes -" - ]; - - users.users.kubernetes = { - uid = config.ids.uids.kubernetes; - description = "Kubernetes user"; - group = "kubernetes"; - home = cfg.dataDir; - createHome = true; - homeMode = "755"; - }; - users.groups.kubernetes.gid = config.ids.gids.kubernetes; - - # dns addon is enabled by default - services.kubernetes.addons.dns.enable = lib.mkDefault true; + (lib.mkIf + ( + cfg.apiserver.enable + || cfg.scheduler.enable + || cfg.controllerManager.enable + || cfg.kubelet.enable + || cfg.proxy.enable + || cfg.addonManager.enable + ) + { + systemd.targets.kubernetes = { + description = "Kubernetes"; + wantedBy = [ "multi-user.target" ]; + }; - services.kubernetes.apiserverAddress = lib.mkDefault ("https://${if cfg.apiserver.advertiseAddress != null - then cfg.apiserver.advertiseAddress - else "${cfg.masterAddress}:${toString cfg.apiserver.securePort}"}"); - }) + systemd.tmpfiles.rules = [ + "d /opt/cni/bin 0755 root root -" + "d /run/kubernetes 0755 kubernetes kubernetes -" + "d ${cfg.dataDir} 0755 kubernetes kubernetes -" + ]; + + users.users.kubernetes = { + uid = config.ids.uids.kubernetes; + description = "Kubernetes user"; + group = "kubernetes"; + home = cfg.dataDir; + createHome = true; + homeMode = "755"; + }; + users.groups.kubernetes.gid = config.ids.gids.kubernetes; + + # dns addon is enabled by default + services.kubernetes.addons.dns.enable = lib.mkDefault true; + + services.kubernetes.apiserverAddress = lib.mkDefault ( + "https://${ + if cfg.apiserver.advertiseAddress != null then + cfg.apiserver.advertiseAddress + else + "${cfg.masterAddress}:${toString cfg.apiserver.securePort}" + }" + ); + } + ) ]; meta.buildDocsInSandbox = false; diff --git a/nixos/modules/services/cluster/kubernetes/flannel.nix b/nixos/modules/services/cluster/kubernetes/flannel.nix index f0269cd0bc21ed..7bbb55ba0724e4 100644 --- a/nixos/modules/services/cluster/kubernetes/flannel.nix +++ b/nixos/modules/services/cluster/kubernetes/flannel.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let top = config.services.kubernetes; cfg = top.flannel; @@ -12,8 +17,7 @@ in enable = lib.mkEnableOption "flannel networking"; openFirewallPorts = lib.mkOption { - description = '' - Whether to open the Flannel UDP ports in the firewall on all interfaces.''; + description = ''Whether to open the Flannel UDP ports in the firewall on all interfaces.''; type = lib.types.bool; default = true; }; @@ -30,23 +34,28 @@ in }; services.kubernetes.kubelet = { - cni.config = lib.mkDefault [{ - name = "mynet"; - type = "flannel"; - cniVersion = "0.3.1"; - delegate = { - isDefaultGateway = true; - bridge = "mynet"; - }; - }]; + cni.config = lib.mkDefault [ + { + name = "mynet"; + type = "flannel"; + cniVersion = "0.3.1"; + delegate = { + isDefaultGateway = true; + bridge = "mynet"; + }; + } + ]; }; networking = { firewall.allowedUDPPorts = lib.mkIf cfg.openFirewallPorts [ - 8285 # flannel udp - 8472 # flannel vxlan + 8285 # flannel udp + 8472 # flannel vxlan + ]; + dhcpcd.denyInterfaces = [ + "mynet*" + "flannel*" ]; - dhcpcd.denyInterfaces = [ "mynet*" "flannel*" ]; }; services.kubernetes.pki.certs = { @@ -58,45 +67,58 @@ in }; # give flannel some kubernetes rbac permissions if applicable - services.kubernetes.addonManager.bootstrapAddons = lib.mkIf ((storageBackend == "kubernetes") && (lib.elem "RBAC" top.apiserver.authorizationMode)) { - - flannel-cr = { - apiVersion = "rbac.authorization.k8s.io/v1"; - kind = "ClusterRole"; - metadata = { name = "flannel"; }; - rules = [{ - apiGroups = [ "" ]; - resources = [ "pods" ]; - verbs = [ "get" ]; - } + services.kubernetes.addonManager.bootstrapAddons = + lib.mkIf ((storageBackend == "kubernetes") && (lib.elem "RBAC" top.apiserver.authorizationMode)) { - apiGroups = [ "" ]; - resources = [ "nodes" ]; - verbs = [ "list" "watch" ]; - } - { - apiGroups = [ "" ]; - resources = [ "nodes/status" ]; - verbs = [ "patch" ]; - }]; - }; - flannel-crb = { - apiVersion = "rbac.authorization.k8s.io/v1"; - kind = "ClusterRoleBinding"; - metadata = { name = "flannel"; }; - roleRef = { - apiGroup = "rbac.authorization.k8s.io"; - kind = "ClusterRole"; - name = "flannel"; - }; - subjects = [{ - kind = "User"; - name = "flannel-client"; - }]; - }; + flannel-cr = { + apiVersion = "rbac.authorization.k8s.io/v1"; + kind = "ClusterRole"; + metadata = { + name = "flannel"; + }; + rules = [ + { + apiGroups = [ "" ]; + resources = [ "pods" ]; + verbs = [ "get" ]; + } + { + apiGroups = [ "" ]; + resources = [ "nodes" ]; + verbs = [ + "list" + "watch" + ]; + } + { + apiGroups = [ "" ]; + resources = [ "nodes/status" ]; + verbs = [ "patch" ]; + } + ]; + }; - }; + flannel-crb = { + apiVersion = "rbac.authorization.k8s.io/v1"; + kind = "ClusterRoleBinding"; + metadata = { + name = "flannel"; + }; + roleRef = { + apiGroup = "rbac.authorization.k8s.io"; + kind = "ClusterRole"; + name = "flannel"; + }; + subjects = [ + { + kind = "User"; + name = "flannel-client"; + } + ]; + }; + + }; }; meta.buildDocsInSandbox = false; diff --git a/nixos/modules/services/cluster/kubernetes/kubelet.nix b/nixos/modules/services/cluster/kubernetes/kubelet.nix index 8fa820ac44e9e7..f481f70b84c3d9 100644 --- a/nixos/modules/services/cluster/kubernetes/kubelet.nix +++ b/nixos/modules/services/cluster/kubernetes/kubelet.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with lib; @@ -8,15 +14,15 @@ let cfg = top.kubelet; cniConfig = - if cfg.cni.config != [] && cfg.cni.configDir != null then + if cfg.cni.config != [ ] && cfg.cni.configDir != null then throw "Verbatim CNI-config and CNI configDir cannot both be set." else if cfg.cni.configDir != null then cfg.cni.configDir else (pkgs.buildEnv { name = "kubernetes-cni-config"; - paths = imap (i: entry: - pkgs.writeTextDir "${toString (10+i)}-${entry.type}.conf" (builtins.toJSON entry) + paths = imap ( + i: entry: pkgs.writeTextDir "${toString (10 + i)}-${entry.type}.conf" (builtins.toJSON entry) ) cfg.cni.config; }); @@ -28,7 +34,7 @@ let pathsToLink = [ "/bin" ]; paths = [ top.package.pause ]; }; - config.Cmd = ["/bin/pause"]; + config.Cmd = [ "/bin/pause" ]; }; kubeconfig = top.lib.mkKubeConfig "kubelet" cfg.kubeconfig; @@ -40,58 +46,71 @@ let # NOTE: registerWithTaints requires a []core/v1.Taint, therefore requires # additional work to be put in config format. # - kubeletConfig = pkgs.writeText "kubelet-config" (builtins.toJSON ({ - apiVersion = "kubelet.config.k8s.io/v1beta1"; - kind = "KubeletConfiguration"; - address = cfg.address; - port = cfg.port; - authentication = { - x509 = lib.optionalAttrs (cfg.clientCaFile != null) { clientCAFile = cfg.clientCaFile; }; - webhook = { - enabled = true; - cacheTTL = "10s"; - }; - }; - authorization = { - mode = "Webhook"; - }; - cgroupDriver = "systemd"; - hairpinMode = "hairpin-veth"; - registerNode = cfg.registerNode; - containerRuntimeEndpoint = cfg.containerRuntimeEndpoint; - healthzPort = cfg.healthz.port; - healthzBindAddress = cfg.healthz.bind; - } // lib.optionalAttrs (cfg.tlsCertFile != null) { tlsCertFile = cfg.tlsCertFile; } - // lib.optionalAttrs (cfg.tlsKeyFile != null) { tlsPrivateKeyFile = cfg.tlsKeyFile; } - // lib.optionalAttrs (cfg.clusterDomain != "") { clusterDomain = cfg.clusterDomain; } - // lib.optionalAttrs (cfg.clusterDns != []) { clusterDNS = cfg.clusterDns; } - // lib.optionalAttrs (cfg.featureGates != {}) { featureGates = cfg.featureGates; } - // lib.optionalAttrs (cfg.extraConfig != {}) cfg.extraConfig - )); + kubeletConfig = pkgs.writeText "kubelet-config" ( + builtins.toJSON ( + { + apiVersion = "kubelet.config.k8s.io/v1beta1"; + kind = "KubeletConfiguration"; + address = cfg.address; + port = cfg.port; + authentication = { + x509 = lib.optionalAttrs (cfg.clientCaFile != null) { clientCAFile = cfg.clientCaFile; }; + webhook = { + enabled = true; + cacheTTL = "10s"; + }; + }; + authorization = { + mode = "Webhook"; + }; + cgroupDriver = "systemd"; + hairpinMode = "hairpin-veth"; + registerNode = cfg.registerNode; + containerRuntimeEndpoint = cfg.containerRuntimeEndpoint; + healthzPort = cfg.healthz.port; + healthzBindAddress = cfg.healthz.bind; + } + // lib.optionalAttrs (cfg.tlsCertFile != null) { tlsCertFile = cfg.tlsCertFile; } + // lib.optionalAttrs (cfg.tlsKeyFile != null) { tlsPrivateKeyFile = cfg.tlsKeyFile; } + // lib.optionalAttrs (cfg.clusterDomain != "") { clusterDomain = cfg.clusterDomain; } + // lib.optionalAttrs (cfg.clusterDns != [ ]) { clusterDNS = cfg.clusterDns; } + // lib.optionalAttrs (cfg.featureGates != { }) { featureGates = cfg.featureGates; } + // lib.optionalAttrs (cfg.extraConfig != { }) cfg.extraConfig + ) + ); manifestPath = "kubernetes/manifests"; - taintOptions = with lib.types; { name, ... }: { - options = { - key = mkOption { - description = "Key of taint."; - default = name; - defaultText = literalMD "Name of this submodule."; - type = str; - }; - value = mkOption { - description = "Value of taint."; - type = str; - }; - effect = mkOption { - description = "Effect of taint."; - example = "NoSchedule"; - type = enum ["NoSchedule" "PreferNoSchedule" "NoExecute"]; + taintOptions = + with lib.types; + { name, ... }: + { + options = { + key = mkOption { + description = "Key of taint."; + default = name; + defaultText = literalMD "Name of this submodule."; + type = str; + }; + value = mkOption { + description = "Value of taint."; + type = str; + }; + effect = mkOption { + description = "Effect of taint."; + example = "NoSchedule"; + type = enum [ + "NoSchedule" + "PreferNoSchedule" + "NoExecute" + ]; + }; }; }; - }; - taints = concatMapStringsSep "," (v: "${v.key}=${v.value}:${v.effect}") (mapAttrsToList (n: v: v) cfg.taints); + taints = concatMapStringsSep "," (v: "${v.key}=${v.value}:${v.effect}") ( + mapAttrsToList (n: v: v) cfg.taints + ); in { imports = [ @@ -135,13 +154,13 @@ in packages = mkOption { description = "List of network plugin packages to install."; type = listOf package; - default = []; + default = [ ]; }; config = mkOption { description = "Kubernetes CNI configuration."; type = listOf attrs; - default = []; + default = [ ]; example = literalExpression '' [{ "cniVersion": "0.3.1", @@ -187,7 +206,7 @@ in extraConfig = mkOption { description = "Kubernetes kubelet extra configuration file entries."; - default = {}; + default = { }; type = attrsOf attrs; }; @@ -223,7 +242,7 @@ in manifests = mkOption { description = "List of manifests to bootstrap with kubelet (only pods can be created as manifest entry)"; type = attrsOf attrs; - default = {}; + default = { }; }; nodeIp = mkOption { @@ -246,13 +265,13 @@ in seedDockerImages = mkOption { description = "List of docker images to preload on system"; - default = []; + default = [ ]; type = listOf package; }; taints = mkOption { description = "Node taints (https://kubernetes.io/docs/concepts/configuration/assign-pod-node/)."; - default = {}; + default = { }; type = attrsOf (submodule [ taintOptions ]); }; @@ -291,35 +310,44 @@ in environment.etc."cni/net.d".source = cniConfig; - services.kubernetes.kubelet.seedDockerImages = [infraContainer]; + services.kubernetes.kubelet.seedDockerImages = [ infraContainer ]; boot.kernel.sysctl = { - "net.bridge.bridge-nf-call-iptables" = 1; - "net.ipv4.ip_forward" = 1; + "net.bridge.bridge-nf-call-iptables" = 1; + "net.ipv4.ip_forward" = 1; "net.bridge.bridge-nf-call-ip6tables" = 1; }; systemd.services.kubelet = { description = "Kubernetes Kubelet Service"; wantedBy = [ "kubernetes.target" ]; - after = [ "containerd.service" "network.target" "kube-apiserver.service" ]; - path = with pkgs; [ - gitMinimal - openssh - util-linux - iproute2 - ethtool - thin-provisioning-tools - iptables - socat - ] ++ lib.optional config.boot.zfs.enabled config.boot.zfs.package ++ top.path; + after = [ + "containerd.service" + "network.target" + "kube-apiserver.service" + ]; + path = + with pkgs; + [ + gitMinimal + openssh + util-linux + iproute2 + ethtool + thin-provisioning-tools + iptables + socat + ] + ++ lib.optional config.boot.zfs.enabled config.boot.zfs.package + ++ top.path; preStart = '' ${concatMapStrings (img: '' echo "Seeding container image: ${img}" - ${if (lib.hasSuffix "gz" img) then - ''${pkgs.gzip}/bin/zcat "${img}" | ${pkgs.containerd}/bin/ctr -n k8s.io image import --all-platforms -'' - else - ''${pkgs.coreutils}/bin/cat "${img}" | ${pkgs.containerd}/bin/ctr -n k8s.io image import --all-platforms -'' + ${ + if (lib.hasSuffix "gz" img) then + ''${pkgs.gzip}/bin/zcat "${img}" | ${pkgs.containerd}/bin/ctr -n k8s.io image import --all-platforms -'' + else + ''${pkgs.coreutils}/bin/cat "${img}" | ${pkgs.containerd}/bin/ctr -n k8s.io image import --all-platforms -'' } '') cfg.seedDockerImages} @@ -335,20 +363,18 @@ in MemoryAccounting = true; Restart = "on-failure"; RestartSec = "1000ms"; - ExecStart = ''${top.package}/bin/kubelet \ - --config=${kubeletConfig} \ - --hostname-override=${cfg.hostname} \ - --kubeconfig=${kubeconfig} \ - ${optionalString (cfg.nodeIp != null) - "--node-ip=${cfg.nodeIp}"} \ - --pod-infra-container-image=pause \ - ${optionalString (cfg.manifests != {}) - "--pod-manifest-path=/etc/${manifestPath}"} \ - ${optionalString (taints != "") - "--register-with-taints=${taints}"} \ - --root-dir=${top.dataDir} \ - ${optionalString (cfg.verbosity != null) "--v=${toString cfg.verbosity}"} \ - ${cfg.extraOpts} + ExecStart = '' + ${top.package}/bin/kubelet \ + --config=${kubeletConfig} \ + --hostname-override=${cfg.hostname} \ + --kubeconfig=${kubeconfig} \ + ${optionalString (cfg.nodeIp != null) "--node-ip=${cfg.nodeIp}"} \ + --pod-infra-container-image=pause \ + ${optionalString (cfg.manifests != { }) "--pod-manifest-path=/etc/${manifestPath}"} \ + ${optionalString (taints != "") "--register-with-taints=${taints}"} \ + --root-dir=${top.dataDir} \ + ${optionalString (cfg.verbosity != null) "--v=${toString cfg.verbosity}"} \ + ${cfg.extraOpts} ''; WorkingDirectory = top.dataDir; }; @@ -358,12 +384,17 @@ in }; # Always include cni plugins - services.kubernetes.kubelet.cni.packages = [pkgs.cni-plugins pkgs.cni-plugin-flannel]; + services.kubernetes.kubelet.cni.packages = [ + pkgs.cni-plugins + pkgs.cni-plugin-flannel + ]; - boot.kernelModules = ["br_netfilter" "overlay"]; + boot.kernelModules = [ + "br_netfilter" + "overlay" + ]; - services.kubernetes.kubelet.hostname = - mkDefault (lib.toLower config.networking.fqdnOrHostName); + services.kubernetes.kubelet.hostname = mkDefault (lib.toLower config.networking.fqdnOrHostName); services.kubernetes.pki.certs = with top.lib; { kubelet = mkCert { @@ -385,8 +416,9 @@ in services.kubernetes.kubelet.kubeconfig.server = mkDefault top.apiserverAddress; }) - (mkIf (cfg.enable && cfg.manifests != {}) { - environment.etc = mapAttrs' (name: manifest: + (mkIf (cfg.enable && cfg.manifests != { }) { + environment.etc = mapAttrs' ( + name: manifest: nameValuePair "${manifestPath}/${name}.json" { text = builtins.toJSON manifest; mode = "0755"; diff --git a/nixos/modules/services/cluster/kubernetes/pki.nix b/nixos/modules/services/cluster/kubernetes/pki.nix index 5e725df41f438d..e4f8cf44e70335 100644 --- a/nixos/modules/services/cluster/kubernetes/pki.nix +++ b/nixos/modules/services/cluster/kubernetes/pki.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,33 +11,38 @@ let top = config.services.kubernetes; cfg = top.pki; - csrCA = pkgs.writeText "kube-pki-cacert-csr.json" (builtins.toJSON { - key = { + csrCA = pkgs.writeText "kube-pki-cacert-csr.json" ( + builtins.toJSON { + key = { algo = "rsa"; size = 2048; - }; - names = singleton cfg.caSpec; - }); + }; + names = singleton cfg.caSpec; + } + ); - csrCfssl = pkgs.writeText "kube-pki-cfssl-csr.json" (builtins.toJSON { - key = { + csrCfssl = pkgs.writeText "kube-pki-cfssl-csr.json" ( + builtins.toJSON { + key = { algo = "rsa"; size = 2048; - }; - CN = top.masterAddress; - hosts = [top.masterAddress] ++ cfg.cfsslAPIExtraSANs; - }); + }; + CN = top.masterAddress; + hosts = [ top.masterAddress ] ++ cfg.cfsslAPIExtraSANs; + } + ); cfsslAPITokenBaseName = "apitoken.secret"; cfsslAPITokenPath = "${config.services.cfssl.dataDir}/${cfsslAPITokenBaseName}"; certmgrAPITokenPath = "${top.secretsPath}/${cfsslAPITokenBaseName}"; cfsslAPITokenLength = 32; - clusterAdminKubeconfig = with cfg.certs.clusterAdmin; + clusterAdminKubeconfig = + with cfg.certs.clusterAdmin; top.lib.mkKubeConfig "cluster-admin" { - server = top.apiserverAddress; - certFile = cert; - keyFile = key; + server = top.apiserverAddress; + certFile = cert; + keyFile = key; }; remote = with config.services; "https://${kubernetes.masterAddress}:${toString cfssl.port}"; @@ -45,7 +55,7 @@ in certs = mkOption { description = "List of certificate specs to feed to cert generator."; - default = {}; + default = { }; type = attrs; }; @@ -71,7 +81,7 @@ in description = '' Extra x509 Subject Alternative Names to be added to the cfssl API webserver TLS cert. ''; - default = []; + default = [ ]; example = [ "subdomain.example.com" ]; type = listOf str; }; @@ -125,120 +135,132 @@ in }; ###### implementation - config = mkIf cfg.enable - (let - cfsslCertPathPrefix = "${config.services.cfssl.dataDir}/cfssl"; - cfsslCert = "${cfsslCertPathPrefix}.pem"; - cfsslKey = "${cfsslCertPathPrefix}-key.pem"; - in - { - - services.cfssl = mkIf (top.apiserver.enable) { - enable = true; - address = "0.0.0.0"; - tlsCert = cfsslCert; - tlsKey = cfsslKey; - configFile = toString (pkgs.writeText "cfssl-config.json" (builtins.toJSON { - signing = { - profiles = { - default = { - usages = ["digital signature"]; - auth_key = "default"; - expiry = "720h"; - }; - }; - }; - auth_keys = { - default = { - type = "standard"; - key = "file:${cfsslAPITokenPath}"; - }; - }; - })); - }; + config = mkIf cfg.enable ( + let + cfsslCertPathPrefix = "${config.services.cfssl.dataDir}/cfssl"; + cfsslCert = "${cfsslCertPathPrefix}.pem"; + cfsslKey = "${cfsslCertPathPrefix}-key.pem"; + in + { + + services.cfssl = mkIf (top.apiserver.enable) { + enable = true; + address = "0.0.0.0"; + tlsCert = cfsslCert; + tlsKey = cfsslKey; + configFile = toString ( + pkgs.writeText "cfssl-config.json" ( + builtins.toJSON { + signing = { + profiles = { + default = { + usages = [ "digital signature" ]; + auth_key = "default"; + expiry = "720h"; + }; + }; + }; + auth_keys = { + default = { + type = "standard"; + key = "file:${cfsslAPITokenPath}"; + }; + }; + } + ) + ); + }; - systemd.services.cfssl.preStart = with pkgs; with config.services.cfssl; mkIf (top.apiserver.enable) - (concatStringsSep "\n" [ - "set -e" - (optionalString cfg.genCfsslCACert '' - if [ ! -f "${cfg.caCertPathPrefix}.pem" ]; then - ${cfssl}/bin/cfssl genkey -initca ${csrCA} | \ - ${cfssl}/bin/cfssljson -bare ${cfg.caCertPathPrefix} - fi - '') - (optionalString cfg.genCfsslAPICerts '' - if [ ! -f "${dataDir}/cfssl.pem" ]; then - ${cfssl}/bin/cfssl gencert -ca "${cfg.caCertPathPrefix}.pem" -ca-key "${cfg.caCertPathPrefix}-key.pem" ${csrCfssl} | \ - ${cfssl}/bin/cfssljson -bare ${cfsslCertPathPrefix} - fi - '') - (optionalString cfg.genCfsslAPIToken '' - if [ ! -f "${cfsslAPITokenPath}" ]; then - install -o cfssl -m 400 <(head -c ${toString (cfsslAPITokenLength / 2)} /dev/urandom | od -An -t x | tr -d ' ') "${cfsslAPITokenPath}" - fi - '')]); - - systemd.services.kube-certmgr-bootstrap = { - description = "Kubernetes certmgr bootstrapper"; - wantedBy = [ "certmgr.service" ]; - after = [ "cfssl.target" ]; - script = concatStringsSep "\n" ['' - set -e - - # If there's a cfssl (cert issuer) running locally, then don't rely on user to - # manually paste it in place. Just symlink. - # otherwise, create the target file, ready for users to insert the token - - mkdir -p "$(dirname "${certmgrAPITokenPath}")" - if [ -f "${cfsslAPITokenPath}" ]; then - ln -fs "${cfsslAPITokenPath}" "${certmgrAPITokenPath}" - elif [ ! -f "${certmgrAPITokenPath}" ]; then - # Don't remove the token if it already exists - install -m 600 /dev/null "${certmgrAPITokenPath}" - fi - '' - (optionalString (cfg.pkiTrustOnBootstrap) '' - if [ ! -f "${top.caFile}" ] || [ $(cat "${top.caFile}" | wc -c) -lt 1 ]; then - ${pkgs.curl}/bin/curl --fail-early -f -kd '{}' ${remote}/api/v1/cfssl/info | \ - ${pkgs.cfssl}/bin/cfssljson -stdout >${top.caFile} - fi - '') - ]; - serviceConfig = { - RestartSec = "10s"; - Restart = "on-failure"; + systemd.services.cfssl.preStart = + with pkgs; + with config.services.cfssl; + mkIf (top.apiserver.enable) ( + concatStringsSep "\n" [ + "set -e" + (optionalString cfg.genCfsslCACert '' + if [ ! -f "${cfg.caCertPathPrefix}.pem" ]; then + ${cfssl}/bin/cfssl genkey -initca ${csrCA} | \ + ${cfssl}/bin/cfssljson -bare ${cfg.caCertPathPrefix} + fi + '') + (optionalString cfg.genCfsslAPICerts '' + if [ ! -f "${dataDir}/cfssl.pem" ]; then + ${cfssl}/bin/cfssl gencert -ca "${cfg.caCertPathPrefix}.pem" -ca-key "${cfg.caCertPathPrefix}-key.pem" ${csrCfssl} | \ + ${cfssl}/bin/cfssljson -bare ${cfsslCertPathPrefix} + fi + '') + (optionalString cfg.genCfsslAPIToken '' + if [ ! -f "${cfsslAPITokenPath}" ]; then + install -o cfssl -m 400 <(head -c ${ + toString (cfsslAPITokenLength / 2) + } /dev/urandom | od -An -t x | tr -d ' ') "${cfsslAPITokenPath}" + fi + '') + ] + ); + + systemd.services.kube-certmgr-bootstrap = { + description = "Kubernetes certmgr bootstrapper"; + wantedBy = [ "certmgr.service" ]; + after = [ "cfssl.target" ]; + script = concatStringsSep "\n" [ + '' + set -e + + # If there's a cfssl (cert issuer) running locally, then don't rely on user to + # manually paste it in place. Just symlink. + # otherwise, create the target file, ready for users to insert the token + + mkdir -p "$(dirname "${certmgrAPITokenPath}")" + if [ -f "${cfsslAPITokenPath}" ]; then + ln -fs "${cfsslAPITokenPath}" "${certmgrAPITokenPath}" + elif [ ! -f "${certmgrAPITokenPath}" ]; then + # Don't remove the token if it already exists + install -m 600 /dev/null "${certmgrAPITokenPath}" + fi + '' + (optionalString (cfg.pkiTrustOnBootstrap) '' + if [ ! -f "${top.caFile}" ] || [ $(cat "${top.caFile}" | wc -c) -lt 1 ]; then + ${pkgs.curl}/bin/curl --fail-early -f -kd '{}' ${remote}/api/v1/cfssl/info | \ + ${pkgs.cfssl}/bin/cfssljson -stdout >${top.caFile} + fi + '') + ]; + serviceConfig = { + RestartSec = "10s"; + Restart = "on-failure"; + }; }; - }; - services.certmgr = { - enable = true; - package = pkgs.certmgr; - svcManager = "command"; - specs = - let - mkSpec = _: cert: { - inherit (cert) action; - authority = { - inherit remote; - root_ca = cert.caCert; - profile = "default"; - auth_key_file = certmgrAPITokenPath; - }; - certificate = { - path = cert.cert; - }; - private_key = cert.privateKeyOptions; - request = { - hosts = [cert.CN] ++ cert.hosts; - inherit (cert) CN; - key = { - algo = "rsa"; - size = 2048; + services.certmgr = { + enable = true; + package = pkgs.certmgr; + svcManager = "command"; + specs = + let + mkSpec = _: cert: { + inherit (cert) action; + authority = { + inherit remote; + root_ca = cert.caCert; + profile = "default"; + auth_key_file = certmgrAPITokenPath; + }; + certificate = { + path = cert.cert; + }; + private_key = cert.privateKeyOptions; + request = { + hosts = [ cert.CN ] ++ cert.hosts; + inherit (cert) CN; + key = { + algo = "rsa"; + size = 2048; + }; + names = [ cert.fields ]; }; - names = [ cert.fields ]; }; - }; - in + in mapAttrs mkSpec cfg.certs; }; @@ -247,91 +269,98 @@ in # - it assumes that it is clusterAdmin or can gain clusterAdmin rights through serviceAccount # - it is designed to be used with k8s system components only # - it would be better with a more Nix-oriented way of managing addons - systemd.services.kube-addon-manager = mkIf top.addonManager.enable (mkMerge [{ - environment.KUBECONFIG = with cfg.certs.addonManager; - top.lib.mkKubeConfig "addon-manager" { - server = top.apiserverAddress; - certFile = cert; - keyFile = key; - }; + systemd.services.kube-addon-manager = mkIf top.addonManager.enable (mkMerge [ + { + environment.KUBECONFIG = + with cfg.certs.addonManager; + top.lib.mkKubeConfig "addon-manager" { + server = top.apiserverAddress; + certFile = cert; + keyFile = key; + }; } - (optionalAttrs (top.addonManager.bootstrapAddons != {}) { + (optionalAttrs (top.addonManager.bootstrapAddons != { }) { serviceConfig.PermissionsStartOnly = true; - preStart = with pkgs; - let - files = mapAttrsToList (n: v: writeText "${n}.json" (builtins.toJSON v)) - top.addonManager.bootstrapAddons; - in - '' - export KUBECONFIG=${clusterAdminKubeconfig} - ${top.package}/bin/kubectl apply -f ${concatStringsSep " \\\n -f " files} - ''; - })]); - - environment.etc.${cfg.etcClusterAdminKubeconfig}.source = mkIf (cfg.etcClusterAdminKubeconfig != null) - clusterAdminKubeconfig; + preStart = + with pkgs; + let + files = mapAttrsToList ( + n: v: writeText "${n}.json" (builtins.toJSON v) + ) top.addonManager.bootstrapAddons; + in + '' + export KUBECONFIG=${clusterAdminKubeconfig} + ${top.package}/bin/kubectl apply -f ${concatStringsSep " \\\n -f " files} + ''; + }) + ]); + + environment.etc.${cfg.etcClusterAdminKubeconfig}.source = mkIf ( + cfg.etcClusterAdminKubeconfig != null + ) clusterAdminKubeconfig; environment.systemPackages = mkIf (top.kubelet.enable || top.proxy.enable) [ - (pkgs.writeScriptBin "nixos-kubernetes-node-join" '' - set -e - exec 1>&2 - - if [ $# -gt 0 ]; then - echo "Usage: $(basename $0)" - echo "" - echo "No args. Apitoken must be provided on stdin." - echo "To get the apitoken, execute: 'sudo cat ${certmgrAPITokenPath}' on the master node." - exit 1 - fi - - if [ $(id -u) != 0 ]; then - echo "Run as root please." - exit 1 - fi - - read -r token - if [ ''${#token} != ${toString cfsslAPITokenLength} ]; then - echo "Token must be of length ${toString cfsslAPITokenLength}." - exit 1 - fi - - install -m 0600 <(echo $token) ${certmgrAPITokenPath} - - echo "Restarting certmgr..." >&1 - systemctl restart certmgr - - echo "Waiting for certs to appear..." >&1 - - ${optionalString top.kubelet.enable '' - while [ ! -f ${cfg.certs.kubelet.cert} ]; do sleep 1; done - echo "Restarting kubelet..." >&1 - systemctl restart kubelet - ''} - - ${optionalString top.proxy.enable '' - while [ ! -f ${cfg.certs.kubeProxyClient.cert} ]; do sleep 1; done - echo "Restarting kube-proxy..." >&1 - systemctl restart kube-proxy - ''} - - ${optionalString top.flannel.enable '' - while [ ! -f ${cfg.certs.flannelClient.cert} ]; do sleep 1; done - echo "Restarting flannel..." >&1 - systemctl restart flannel - ''} - - echo "Node joined successfully" - '')]; + (pkgs.writeScriptBin "nixos-kubernetes-node-join" '' + set -e + exec 1>&2 + + if [ $# -gt 0 ]; then + echo "Usage: $(basename $0)" + echo "" + echo "No args. Apitoken must be provided on stdin." + echo "To get the apitoken, execute: 'sudo cat ${certmgrAPITokenPath}' on the master node." + exit 1 + fi + + if [ $(id -u) != 0 ]; then + echo "Run as root please." + exit 1 + fi + + read -r token + if [ ''${#token} != ${toString cfsslAPITokenLength} ]; then + echo "Token must be of length ${toString cfsslAPITokenLength}." + exit 1 + fi + + install -m 0600 <(echo $token) ${certmgrAPITokenPath} + + echo "Restarting certmgr..." >&1 + systemctl restart certmgr + + echo "Waiting for certs to appear..." >&1 + + ${optionalString top.kubelet.enable '' + while [ ! -f ${cfg.certs.kubelet.cert} ]; do sleep 1; done + echo "Restarting kubelet..." >&1 + systemctl restart kubelet + ''} + + ${optionalString top.proxy.enable '' + while [ ! -f ${cfg.certs.kubeProxyClient.cert} ]; do sleep 1; done + echo "Restarting kube-proxy..." >&1 + systemctl restart kube-proxy + ''} + + ${optionalString top.flannel.enable '' + while [ ! -f ${cfg.certs.flannelClient.cert} ]; do sleep 1; done + echo "Restarting flannel..." >&1 + systemctl restart flannel + ''} + + echo "Node joined successfully" + '') + ]; # isolate etcd on loopback at the master node # easyCerts doesn't support multimaster clusters anyway atm. services.etcd = with cfg.certs.etcd; { - listenClientUrls = ["https://127.0.0.1:2379"]; - listenPeerUrls = ["https://127.0.0.1:2380"]; - advertiseClientUrls = ["https://etcd.local:2379"]; - initialCluster = ["${top.masterAddress}=https://etcd.local:2380"]; - initialAdvertisePeerUrls = ["https://etcd.local:2380"]; + listenClientUrls = [ "https://127.0.0.1:2379" ]; + listenPeerUrls = [ "https://127.0.0.1:2380" ]; + advertiseClientUrls = [ "https://etcd.local:2379" ]; + initialCluster = [ "${top.masterAddress}=https://etcd.local:2380" ]; + initialAdvertisePeerUrls = [ "https://etcd.local:2380" ]; certFile = mkDefault cert; keyFile = mkDefault key; trustedCaFile = mkDefault caCert; @@ -350,24 +379,27 @@ in services.kubernetes = { - apiserver = mkIf top.apiserver.enable (with cfg.certs.apiServer; { - etcd = with cfg.certs.apiserverEtcdClient; { - servers = ["https://etcd.local:2379"]; - certFile = mkDefault cert; - keyFile = mkDefault key; - caFile = mkDefault caCert; - }; - clientCaFile = mkDefault caCert; - tlsCertFile = mkDefault cert; - tlsKeyFile = mkDefault key; - serviceAccountKeyFile = mkDefault cfg.certs.serviceAccount.cert; - serviceAccountSigningKeyFile = mkDefault cfg.certs.serviceAccount.key; - kubeletClientCaFile = mkDefault caCert; - kubeletClientCertFile = mkDefault cfg.certs.apiserverKubeletClient.cert; - kubeletClientKeyFile = mkDefault cfg.certs.apiserverKubeletClient.key; - proxyClientCertFile = mkDefault cfg.certs.apiserverProxyClient.cert; - proxyClientKeyFile = mkDefault cfg.certs.apiserverProxyClient.key; - }); + apiserver = mkIf top.apiserver.enable ( + with cfg.certs.apiServer; + { + etcd = with cfg.certs.apiserverEtcdClient; { + servers = [ "https://etcd.local:2379" ]; + certFile = mkDefault cert; + keyFile = mkDefault key; + caFile = mkDefault caCert; + }; + clientCaFile = mkDefault caCert; + tlsCertFile = mkDefault cert; + tlsKeyFile = mkDefault key; + serviceAccountKeyFile = mkDefault cfg.certs.serviceAccount.cert; + serviceAccountSigningKeyFile = mkDefault cfg.certs.serviceAccount.key; + kubeletClientCaFile = mkDefault caCert; + kubeletClientCertFile = mkDefault cfg.certs.apiserverKubeletClient.cert; + kubeletClientKeyFile = mkDefault cfg.certs.apiserverKubeletClient.key; + proxyClientCertFile = mkDefault cfg.certs.apiserverProxyClient.cert; + proxyClientKeyFile = mkDefault cfg.certs.apiserverProxyClient.key; + } + ); controllerManager = mkIf top.controllerManager.enable { serviceAccountKeyFile = mkDefault cfg.certs.serviceAccount.key; rootCaFile = cfg.certs.controllerManagerClient.caCert; @@ -398,7 +430,8 @@ in }; }; }; - }); + } + ); meta.buildDocsInSandbox = false; } diff --git a/nixos/modules/services/cluster/kubernetes/scheduler.nix b/nixos/modules/services/cluster/kubernetes/scheduler.nix index 05205a529f8d91..3cab4ce492b246 100644 --- a/nixos/modules/services/cluster/kubernetes/scheduler.nix +++ b/nixos/modules/services/cluster/kubernetes/scheduler.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let top = config.services.kubernetes; otop = options.services.kubernetes; @@ -62,15 +68,22 @@ in after = [ "kube-apiserver.service" ]; serviceConfig = { Slice = "kubernetes.slice"; - ExecStart = ''${top.package}/bin/kube-scheduler \ - --bind-address=${cfg.address} \ - ${lib.optionalString (cfg.featureGates != {}) - "--feature-gates=${lib.concatStringsSep "," (builtins.attrValues (lib.mapAttrs (n: v: "${n}=${lib.trivial.boolToString v}") cfg.featureGates))}"} \ - --kubeconfig=${top.lib.mkKubeConfig "kube-scheduler" cfg.kubeconfig} \ - --leader-elect=${lib.boolToString cfg.leaderElect} \ - --secure-port=${toString cfg.port} \ - ${lib.optionalString (cfg.verbosity != null) "--v=${toString cfg.verbosity}"} \ - ${cfg.extraOpts} + ExecStart = '' + ${top.package}/bin/kube-scheduler \ + --bind-address=${cfg.address} \ + ${ + lib.optionalString (cfg.featureGates != { }) + "--feature-gates=${ + lib.concatStringsSep "," ( + builtins.attrValues (lib.mapAttrs (n: v: "${n}=${lib.trivial.boolToString v}") cfg.featureGates) + ) + }" + } \ + --kubeconfig=${top.lib.mkKubeConfig "kube-scheduler" cfg.kubeconfig} \ + --leader-elect=${lib.boolToString cfg.leaderElect} \ + --secure-port=${toString cfg.port} \ + ${lib.optionalString (cfg.verbosity != null) "--v=${toString cfg.verbosity}"} \ + ${cfg.extraOpts} ''; WorkingDirectory = top.dataDir; User = "kubernetes"; diff --git a/nixos/modules/services/cluster/pacemaker/default.nix b/nixos/modules/services/cluster/pacemaker/default.nix index 92cd9311eb7d55..2a0866e1363bac 100644 --- a/nixos/modules/services/cluster/pacemaker/default.nix +++ b/nixos/modules/services/cluster/pacemaker/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.pacemaker; in @@ -12,12 +17,14 @@ in # implementation config = lib.mkIf cfg.enable { - assertions = [ { - assertion = config.services.corosync.enable; - message = '' - Enabling services.pacemaker requires a services.corosync configuration. - ''; - } ]; + assertions = [ + { + assertion = config.services.corosync.enable; + message = '' + Enabling services.pacemaker requires a services.corosync configuration. + ''; + } + ]; environment.systemPackages = [ cfg.package ]; @@ -27,7 +34,7 @@ in group = "pacemaker"; home = "/var/lib/pacemaker"; }; - users.groups.pacemaker = {}; + users.groups.pacemaker = { }; systemd.tmpfiles.rules = [ "d /var/log/pacemaker 0700 hacluster pacemaker -" diff --git a/nixos/modules/services/cluster/patroni/default.nix b/nixos/modules/services/cluster/patroni/default.nix index 91eb9214a60e4b..bcddcd23a6b53f 100644 --- a/nixos/modules/services/cluster/patroni/default.nix +++ b/nixos/modules/services/cluster/patroni/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.patroni; defaultUser = "patroni"; @@ -114,7 +119,10 @@ in otherNodesIps = lib.mkOption { type = lib.types.listOf lib.types.str; - example = [ "192.168.1.2" "192.168.1.3" ]; + example = [ + "192.168.1.2" + "192.168.1.3" + ]; description = '' IP addresses of the other nodes. ''; @@ -148,7 +156,15 @@ in }; environmentFiles = lib.mkOption { - type = with lib.types; attrsOf (nullOr (oneOf [ str path package ])); + type = + with lib.types; + attrsOf ( + nullOr (oneOf [ + str + path + package + ]) + ); default = { }; example = { PATRONI_REPLICATION_PASSWORD = "/secret/file"; @@ -185,7 +201,6 @@ in }; }; - users = { users = lib.mkIf (cfg.user == defaultUser) { patroni = { @@ -206,7 +221,11 @@ in after = [ "network.target" ]; script = '' - ${lib.concatStringsSep "\n" (lib.attrValues (lib.mapAttrs (name: path: ''export ${name}="$(< ${lib.escapeShellArg path})"'') cfg.environmentFiles))} + ${lib.concatStringsSep "\n" ( + lib.attrValues ( + lib.mapAttrs (name: path: ''export ${name}="$(< ${lib.escapeShellArg path})"'') cfg.environmentFiles + ) + )} exec ${pkgs.patroni}/bin/patroni ${configFile} ''; @@ -220,10 +239,16 @@ in ExecReload = "${pkgs.coreutils}/bin/kill -s HUP $MAINPID"; KillMode = "process"; } - (lib.mkIf (cfg.postgresqlDataDir == "/var/lib/postgresql/${cfg.postgresqlPackage.psqlSchema}" && cfg.dataDir == "/var/lib/patroni") { - StateDirectory = "patroni postgresql postgresql/${cfg.postgresqlPackage.psqlSchema}"; - StateDirectoryMode = "0750"; - }) + (lib.mkIf + ( + cfg.postgresqlDataDir == "/var/lib/postgresql/${cfg.postgresqlPackage.psqlSchema}" + && cfg.dataDir == "/var/lib/patroni" + ) + { + StateDirectory = "patroni postgresql postgresql/${cfg.postgresqlPackage.psqlSchema}"; + StateDirectoryMode = "0750"; + } + ) ]; }; }; diff --git a/nixos/modules/services/cluster/rke2/default.nix b/nixos/modules/services/cluster/rke2/default.nix index 2e6816f43374fe..1c7ef3af1c8ae2 100644 --- a/nixos/modules/services/cluster/rke2/default.nix +++ b/nixos/modules/services/cluster/rke2/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.rke2; in @@ -11,7 +16,10 @@ in package = lib.mkPackageOption pkgs "rke2" { }; role = lib.mkOption { - type = lib.types.enum [ "server" "agent" ]; + type = lib.types.enum [ + "server" + "agent" + ]; description = '' Whether rke2 should run as a server or agent. @@ -125,7 +133,13 @@ in }; cni = lib.mkOption { - type = lib.types.enum [ "none" "canal" "cilium" "calico" "flannel" ]; + type = lib.types.enum [ + "none" + "canal" + "cilium" + "calico" + "flannel" + ]; description = '' CNI Plugins to deploy, one of `none`, `calico`, `canal`, `cilium` or `flannel`. @@ -170,7 +184,10 @@ in - [Server Configuration Reference](https://docs.rke2.io/reference/server_config) - [Agent Configuration Reference](https://docs.rke2.io/reference/linux_agent_config) ''; - example = [ "--disable-kube-proxy" "--cluster-cidr=10.24.0.0/16" ]; + example = [ + "--disable-kube-proxy" + "--cluster-cidr=10.24.0.0/16" + ]; default = [ ]; }; @@ -204,19 +221,21 @@ in message = "serverAddr or configPath (with 'server' key) should be set if role is 'agent'"; } { - assertion = cfg.role == "agent" -> (builtins.pathExists cfg.configPath || cfg.tokenFile != null || cfg.token != ""); + assertion = + cfg.role == "agent" + -> (builtins.pathExists cfg.configPath || cfg.tokenFile != null || cfg.token != ""); message = "token or tokenFile or configPath (with 'token' or 'token-file' keys) should be set if role is 'agent'"; } { - assertion = cfg.role == "agent" -> ! (cfg.agentTokenFile != null || cfg.agentToken != ""); + assertion = cfg.role == "agent" -> !(cfg.agentTokenFile != null || cfg.agentToken != ""); message = "agentToken or agentTokenFile should be set if role is 'agent'"; } { - assertion = cfg.role == "agent" -> ! (cfg.disable != [ ]); + assertion = cfg.role == "agent" -> !(cfg.disable != [ ]); message = "disable should not be set if role is 'agent'"; } { - assertion = cfg.role == "agent" -> ! (cfg.cni != "canal"); + assertion = cfg.role == "agent" -> !(cfg.cni != "canal"); message = "cni should not be set if role is 'agent'"; } ]; @@ -275,34 +294,44 @@ in "-${pkgs.kmod}/bin/modprobe br_netfilter" "-${pkgs.kmod}/bin/modprobe overlay" ]; - ExecStart = "${cfg.package}/bin/rke2 '${cfg.role}' ${lib.escapeShellArgs ( - (lib.optional (cfg.configPath != "/etc/rancher/rke2/config.yaml") "--config=${cfg.configPath}") - ++ (lib.optional cfg.debug "--debug") - ++ (lib.optional (cfg.dataDir != "/var/lib/rancher/rke2") "--data-dir=${cfg.dataDir}") - ++ (lib.optional (cfg.token != "") "--token=${cfg.token}") - ++ (lib.optional (cfg.tokenFile != null) "--token-file=${cfg.tokenFile}") - ++ (lib.optionals (cfg.role == "server" && cfg.disable != [ ]) (map (d: "--disable=${d}") cfg.disable)) - ++ (lib.optional (cfg.nodeName != null) "--node-name=${cfg.nodeName}") - ++ (lib.optionals (cfg.nodeLabel != [ ]) (map (l: "--node-label=${l}") cfg.nodeLabel)) - ++ (lib.optionals (cfg.nodeTaint != [ ]) (map (t: "--node-taint=${t}") cfg.nodeTaint)) - ++ (lib.optional (cfg.nodeIP != null) "--node-ip=${cfg.nodeIP}") - ++ (lib.optional (cfg.role == "server" && cfg.agentToken != "") "--agent-token=${cfg.agentToken}") - ++ (lib.optional (cfg.role == "server" && cfg.agentTokenFile != null) "--agent-token-file=${cfg.agentTokenFile}") - ++ (lib.optional (cfg.serverAddr != "") "--server=${cfg.serverAddr}") - ++ (lib.optional cfg.selinux "--selinux") - ++ (lib.optional (cfg.role == "server" && cfg.cni != "canal") "--cni=${cfg.cni}") - ++ (lib.optional cfg.cisHardening "--profile=${if cfg.package.version >= "1.25" then "cis-1.23" else "cis-1.6"}") - ++ cfg.extraFlags - )}"; - ExecStopPost = let - killProcess = pkgs.writeScript "kill-process.sh" '' - #! ${pkgs.runtimeShell} - /run/current-system/systemd/bin/systemd-cgls /system.slice/$1 | \ - ${pkgs.gnugrep}/bin/grep -Eo '[0-9]+ (containerd|kubelet)' | \ - ${pkgs.gawk}/bin/awk '{print $1}' | \ - ${pkgs.findutils}/bin/xargs -r ${pkgs.util-linux}/bin/kill - ''; - in "-${killProcess} %n"; + ExecStart = "${cfg.package}/bin/rke2 '${cfg.role}' ${ + lib.escapeShellArgs ( + (lib.optional (cfg.configPath != "/etc/rancher/rke2/config.yaml") "--config=${cfg.configPath}") + ++ (lib.optional cfg.debug "--debug") + ++ (lib.optional (cfg.dataDir != "/var/lib/rancher/rke2") "--data-dir=${cfg.dataDir}") + ++ (lib.optional (cfg.token != "") "--token=${cfg.token}") + ++ (lib.optional (cfg.tokenFile != null) "--token-file=${cfg.tokenFile}") + ++ (lib.optionals (cfg.role == "server" && cfg.disable != [ ]) ( + map (d: "--disable=${d}") cfg.disable + )) + ++ (lib.optional (cfg.nodeName != null) "--node-name=${cfg.nodeName}") + ++ (lib.optionals (cfg.nodeLabel != [ ]) (map (l: "--node-label=${l}") cfg.nodeLabel)) + ++ (lib.optionals (cfg.nodeTaint != [ ]) (map (t: "--node-taint=${t}") cfg.nodeTaint)) + ++ (lib.optional (cfg.nodeIP != null) "--node-ip=${cfg.nodeIP}") + ++ (lib.optional (cfg.role == "server" && cfg.agentToken != "") "--agent-token=${cfg.agentToken}") + ++ (lib.optional ( + cfg.role == "server" && cfg.agentTokenFile != null + ) "--agent-token-file=${cfg.agentTokenFile}") + ++ (lib.optional (cfg.serverAddr != "") "--server=${cfg.serverAddr}") + ++ (lib.optional cfg.selinux "--selinux") + ++ (lib.optional (cfg.role == "server" && cfg.cni != "canal") "--cni=${cfg.cni}") + ++ (lib.optional cfg.cisHardening "--profile=${ + if cfg.package.version >= "1.25" then "cis-1.23" else "cis-1.6" + }") + ++ cfg.extraFlags + ) + }"; + ExecStopPost = + let + killProcess = pkgs.writeScript "kill-process.sh" '' + #! ${pkgs.runtimeShell} + /run/current-system/systemd/bin/systemd-cgls /system.slice/$1 | \ + ${pkgs.gnugrep}/bin/grep -Eo '[0-9]+ (containerd|kubelet)' | \ + ${pkgs.gawk}/bin/awk '{print $1}' | \ + ${pkgs.findutils}/bin/xargs -r ${pkgs.util-linux}/bin/kill + ''; + in + "-${killProcess} %n"; }; }; }; diff --git a/nixos/modules/services/cluster/spark/default.nix b/nixos/modules/services/cluster/spark/default.nix index c4ebd342439284..ffec1512d42bae 100644 --- a/nixos/modules/services/cluster/spark/default.nix +++ b/nixos/modules/services/cluster/spark/default.nix @@ -1,4 +1,9 @@ -{config, pkgs, lib, ...}: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.spark; in @@ -13,7 +18,7 @@ in default = "127.0.0.1"; example = "0.0.0.0"; }; - restartIfChanged = lib.mkOption { + restartIfChanged = lib.mkOption { type = lib.types.bool; description = '' Automatically restart master service on config change. @@ -26,7 +31,7 @@ in extraEnvironment = lib.mkOption { type = lib.types.attrsOf lib.types.str; description = "Extra environment variables to pass to spark master. See spark-standalone documentation."; - default = {}; + default = { }; example = { SPARK_MASTER_WEBUI_PORT = 8181; SPARK_MASTER_OPTS = "-Dspark.deploy.defaultCores=5"; @@ -45,7 +50,7 @@ in description = "Address of the spark master."; default = "127.0.0.1:7077"; }; - restartIfChanged = lib.mkOption { + restartIfChanged = lib.mkOption { type = lib.types.bool; description = '' Automatically restart worker service on config change. @@ -58,7 +63,7 @@ in extraEnvironment = lib.mkOption { type = lib.types.attrsOf lib.types.str; description = "Extra environment variables to pass to spark worker."; - default = {}; + default = { }; example = { SPARK_WORKER_CORES = 5; SPARK_WORKER_MEMORY = "2g"; @@ -96,7 +101,11 @@ in systemd = { services = { spark-master = lib.mkIf cfg.master.enable { - path = with pkgs; [ procps openssh nettools ]; + path = with pkgs; [ + procps + openssh + nettools + ]; description = "spark master service."; after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; @@ -112,14 +121,19 @@ in Group = "spark"; WorkingDirectory = "${cfg.package}/"; ExecStart = "${cfg.package}/sbin/start-master.sh"; - ExecStop = "${cfg.package}/sbin/stop-master.sh"; + ExecStop = "${cfg.package}/sbin/stop-master.sh"; TimeoutSec = 300; - StartLimitBurst=10; + StartLimitBurst = 10; Restart = "always"; }; }; spark-worker = lib.mkIf cfg.worker.enable { - path = with pkgs; [ procps openssh nettools rsync ]; + path = with pkgs; [ + procps + openssh + nettools + rsync + ]; description = "spark master service."; after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; @@ -135,9 +149,9 @@ in User = "spark"; WorkingDirectory = "${cfg.package}/"; ExecStart = "${cfg.package}/sbin/start-worker.sh spark://${cfg.worker.master}"; - ExecStop = "${cfg.package}/sbin/stop-worker.sh"; + ExecStop = "${cfg.package}/sbin/stop-worker.sh"; TimeoutSec = 300; - StartLimitBurst=10; + StartLimitBurst = 10; Restart = "always"; }; }; diff --git a/nixos/modules/services/computing/boinc/client.nix b/nixos/modules/services/computing/boinc/client.nix index 9f01a00aad6d41..e7e13160989be8 100644 --- a/nixos/modules/services/computing/boinc/client.nix +++ b/nixos/modules/services/computing/boinc/client.nix @@ -1,4 +1,9 @@ -{config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.boinc; allowRemoteGuiRpcFlag = lib.optionalString cfg.allowRemoteGuiRpc "--allow_remote_gui_rpc"; @@ -11,100 +16,100 @@ let fhsEnvExecutable = "${fhsEnv}/bin/${fhsEnv.name}"; in - { - options.services.boinc = { - enable = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Whether to enable the BOINC distributed computing client. If this - option is set to true, the boinc_client daemon will be run as a - background service. The boinccmd command can be used to control the - daemon. - ''; - }; +{ + options.services.boinc = { + enable = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Whether to enable the BOINC distributed computing client. If this + option is set to true, the boinc_client daemon will be run as a + background service. The boinccmd command can be used to control the + daemon. + ''; + }; - package = lib.mkPackageOption pkgs "boinc" { - example = "boinc-headless"; - }; + package = lib.mkPackageOption pkgs "boinc" { + example = "boinc-headless"; + }; - dataDir = lib.mkOption { - type = lib.types.path; - default = "/var/lib/boinc"; - description = '' - The directory in which to store BOINC's configuration and data files. - ''; - }; + dataDir = lib.mkOption { + type = lib.types.path; + default = "/var/lib/boinc"; + description = '' + The directory in which to store BOINC's configuration and data files. + ''; + }; - allowRemoteGuiRpc = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - If set to true, any remote host can connect to and control this BOINC - client (subject to password authentication). If instead set to false, - only the hosts listed in {var}`dataDir`/remote_hosts.cfg will be allowed to - connect. + allowRemoteGuiRpc = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + If set to true, any remote host can connect to and control this BOINC + client (subject to password authentication). If instead set to false, + only the hosts listed in {var}`dataDir`/remote_hosts.cfg will be allowed to + connect. - See also: - ''; - }; + See also: + ''; + }; - extraEnvPackages = lib.mkOption { - type = lib.types.listOf lib.types.package; - default = []; - example = lib.literalExpression "[ pkgs.virtualbox ]"; - description = '' - Additional packages to make available in the environment in which - BOINC will run. Common choices are: + extraEnvPackages = lib.mkOption { + type = lib.types.listOf lib.types.package; + default = [ ]; + example = lib.literalExpression "[ pkgs.virtualbox ]"; + description = '' + Additional packages to make available in the environment in which + BOINC will run. Common choices are: - - {var}`pkgs.virtualbox`: - The VirtualBox virtual machine framework. Required by some BOINC - projects, such as ATLAS@home. - - {var}`pkgs.ocl-icd`: - OpenCL infrastructure library. Required by BOINC projects that - use OpenCL, in addition to a device-specific OpenCL driver. - - {var}`pkgs.linuxPackages.nvidia_x11`: - Provides CUDA libraries. Required by BOINC projects that use - CUDA. Note that this requires an NVIDIA graphics device to be - present on the system. + - {var}`pkgs.virtualbox`: + The VirtualBox virtual machine framework. Required by some BOINC + projects, such as ATLAS@home. + - {var}`pkgs.ocl-icd`: + OpenCL infrastructure library. Required by BOINC projects that + use OpenCL, in addition to a device-specific OpenCL driver. + - {var}`pkgs.linuxPackages.nvidia_x11`: + Provides CUDA libraries. Required by BOINC projects that use + CUDA. Note that this requires an NVIDIA graphics device to be + present on the system. - Also provides OpenCL drivers for NVIDIA GPUs; - {var}`pkgs.ocl-icd` is also needed in this case. - ''; - }; + Also provides OpenCL drivers for NVIDIA GPUs; + {var}`pkgs.ocl-icd` is also needed in this case. + ''; }; + }; - config = lib.mkIf cfg.enable { - environment.systemPackages = [cfg.package]; + config = lib.mkIf cfg.enable { + environment.systemPackages = [ cfg.package ]; - users.users.boinc = { - group = "boinc"; - createHome = false; - description = "BOINC Client"; - home = cfg.dataDir; - isSystemUser = true; - }; - users.groups.boinc = {}; + users.users.boinc = { + group = "boinc"; + createHome = false; + description = "BOINC Client"; + home = cfg.dataDir; + isSystemUser = true; + }; + users.groups.boinc = { }; - systemd.tmpfiles.rules = [ - "d '${cfg.dataDir}' - boinc boinc - -" - ]; + systemd.tmpfiles.rules = [ + "d '${cfg.dataDir}' - boinc boinc - -" + ]; - systemd.services.boinc = { - description = "BOINC Client"; - after = ["network.target"]; - wantedBy = ["multi-user.target"]; - script = '' - exec ${fhsEnvExecutable} --dir ${cfg.dataDir} ${allowRemoteGuiRpcFlag} - ''; - serviceConfig = { - User = "boinc"; - Nice = 10; - }; + systemd.services.boinc = { + description = "BOINC Client"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + script = '' + exec ${fhsEnvExecutable} --dir ${cfg.dataDir} ${allowRemoteGuiRpcFlag} + ''; + serviceConfig = { + User = "boinc"; + Nice = 10; }; }; + }; - meta = { - maintainers = with lib.maintainers; [ ]; - }; - } + meta = { + maintainers = with lib.maintainers; [ ]; + }; +} diff --git a/nixos/modules/services/computing/foldingathome/client.nix b/nixos/modules/services/computing/foldingathome/client.nix index 71fc58669d33bd..b1a60416215e73 100644 --- a/nixos/modules/services/computing/foldingathome/client.nix +++ b/nixos/modules/services/computing/foldingathome/client.nix @@ -1,17 +1,30 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.foldingathome; args = - ["--team" "${toString cfg.team}"] - ++ lib.optionals (cfg.user != null) ["--user" cfg.user] - ++ cfg.extraArgs - ; + [ + "--team" + "${toString cfg.team}" + ] + ++ lib.optionals (cfg.user != null) [ + "--user" + cfg.user + ] + ++ cfg.extraArgs; in { imports = [ (lib.mkRenamedOptionModule [ "services" "foldingAtHome" ] [ "services" "foldingathome" ]) - (lib.mkRenamedOptionModule [ "services" "foldingathome" "nickname" ] [ "services" "foldingathome" "user" ]) + (lib.mkRenamedOptionModule + [ "services" "foldingathome" "nickname" ] + [ "services" "foldingathome" "user" ] + ) (lib.mkRemovedOptionModule [ "services" "foldingathome" "config" ] '' Use services.foldingathome.extraArgs instead '') @@ -52,7 +65,7 @@ in extraArgs = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Extra startup options for the FAHClient. Run `fah-client --help` to find all the available options. diff --git a/nixos/modules/services/computing/torque/mom.nix b/nixos/modules/services/computing/torque/mom.nix index 8bc5fc134fcbae..78fa3bf3040136 100644 --- a/nixos/modules/services/computing/torque/mom.nix +++ b/nixos/modules/services/computing/torque/mom.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.torque.mom; @@ -29,7 +34,12 @@ in environment.systemPackages = [ pkgs.torque ]; systemd.services.torque-mom-init = { - path = with pkgs; [ torque util-linux procps inetutils ]; + path = with pkgs; [ + torque + util-linux + procps + inetutils + ]; script = '' pbs_mkdirs -v aux @@ -47,7 +57,10 @@ in wantedBy = [ "multi-user.target" ]; requires = [ "torque-mom-init.service" ]; - after = [ "torque-mom-init.service" "network.target" ]; + after = [ + "torque-mom-init.service" + "network.target" + ]; serviceConfig = { Type = "forking"; diff --git a/nixos/modules/services/computing/torque/server.nix b/nixos/modules/services/computing/torque/server.nix index 27be2c65b7e0f0..81d09a055a43c5 100644 --- a/nixos/modules/services/computing/torque/server.nix +++ b/nixos/modules/services/computing/torque/server.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.torque.server; torque = pkgs.torque; @@ -18,7 +23,12 @@ in environment.systemPackages = [ pkgs.torque ]; systemd.services.torque-server-init = { - path = with pkgs; [ torque util-linux procps inetutils ]; + path = with pkgs; [ + torque + util-linux + procps + inetutils + ]; script = '' tmpsetup=$(mktemp -t torque-XXXX) @@ -63,10 +73,16 @@ in path = [ torque ]; wantedBy = [ "multi-user.target" ]; - wants = [ "torque-scheduler.service" "trqauthd.service" ]; + wants = [ + "torque-scheduler.service" + "trqauthd.service" + ]; before = [ "trqauthd.service" ]; requires = [ "torque-server-init.service" ]; - after = [ "torque-server-init.service" "network.target" ]; + after = [ + "torque-server-init.service" + "network.target" + ]; serviceConfig = { Type = "forking"; diff --git a/nixos/modules/services/continuous-integration/buildbot/master.nix b/nixos/modules/services/continuous-integration/buildbot/master.nix index 617d5845032623..398a1c09973e63 100644 --- a/nixos/modules/services/continuous-integration/buildbot/master.nix +++ b/nixos/modules/services/continuous-integration/buildbot/master.nix @@ -1,5 +1,11 @@ # NixOS module for Buildbot continuous integration server. -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.buildbot-master; opt = options.services.buildbot-master; @@ -54,14 +60,15 @@ let m.setServiceParent(application) ''; -in { +in +{ options = { services.buildbot-master = { factorySteps = lib.mkOption { type = lib.types.listOf lib.types.str; description = "Factory Steps"; - default = []; + default = [ ]; example = [ "steps.Git(repourl='https://github.com/buildbot/pyflakes.git', mode='incremental')" "steps.ShellCommand(command=['trial', 'pyflakes'])" @@ -71,7 +78,7 @@ in { changeSource = lib.mkOption { type = lib.types.listOf lib.types.str; description = "List of Change Sources."; - default = []; + default = [ ]; example = [ "changes.GitPoller('https://github.com/buildbot/pyflakes.git', workdir='gitpoller-workdir', branch='master', pollinterval=300)" ]; @@ -80,7 +87,7 @@ in { configurators = lib.mkOption { type = lib.types.listOf lib.types.str; description = "Configurator Steps, see https://docs.buildbot.net/latest/manual/configuration/configurators.html"; - default = []; + default = [ ]; example = [ "util.JanitorConfigurator(logHorizon=timedelta(weeks=4), hour=12, dayOfWeek=6)" ]; @@ -137,7 +144,7 @@ in { }; reporters = lib.mkOption { - default = []; + default = [ ]; type = lib.types.listOf lib.types.str; description = "List of reporter objects used to present build status to various users."; }; @@ -156,7 +163,7 @@ in { extraGroups = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = "List of extra groups that the buildbot user should be a part of."; }; @@ -266,7 +273,9 @@ in { after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; path = cfg.packages ++ cfg.pythonPackages python.pkgs; - environment.PYTHONPATH = "${python.withPackages (self: cfg.pythonPackages self ++ [ package ])}/${python.sitePackages}"; + environment.PYTHONPATH = "${ + python.withPackages (self: cfg.pythonPackages self ++ [ package ]) + }/${python.sitePackages}"; preStart = '' mkdir -vp "${cfg.buildbotDir}" @@ -294,7 +303,10 @@ in { }; imports = [ - (lib.mkRenamedOptionModule [ "services" "buildbot-master" "bpPort" ] [ "services" "buildbot-master" "pbPort" ]) + (lib.mkRenamedOptionModule + [ "services" "buildbot-master" "bpPort" ] + [ "services" "buildbot-master" "pbPort" ] + ) (lib.mkRemovedOptionModule [ "services" "buildbot-master" "status" ] '' Since Buildbot 0.9.0, status targets are deprecated and ignored. Review your configuration and migrate to reporters (available at services.buildbot-master.reporters). diff --git a/nixos/modules/services/continuous-integration/buildbot/worker.nix b/nixos/modules/services/continuous-integration/buildbot/worker.nix index 62b38d2829aa41..b1e1e7e254b5d8 100644 --- a/nixos/modules/services/continuous-integration/buildbot/worker.nix +++ b/nixos/modules/services/continuous-integration/buildbot/worker.nix @@ -1,5 +1,11 @@ # NixOS module for Buildbot Worker. -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.buildbot-worker; opt = options.services.buildbot-worker; @@ -39,7 +45,8 @@ let s.setServiceParent(application) ''; -in { +in +{ options = { services.buildbot-worker = { @@ -63,7 +70,7 @@ in { extraGroups = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = "List of extra groups that the Buildbot Worker user should be a part of."; }; @@ -136,7 +143,9 @@ in { }; config = lib.mkIf cfg.enable { - services.buildbot-worker.workerPassFile = lib.mkDefault (pkgs.writeText "buildbot-worker-password" cfg.workerPass); + services.buildbot-worker.workerPassFile = lib.mkDefault ( + pkgs.writeText "buildbot-worker-password" cfg.workerPass + ); users.groups = lib.optionalAttrs (cfg.group == "bbworker") { bbworker = { }; @@ -156,7 +165,10 @@ in { systemd.services.buildbot-worker = { description = "Buildbot Worker."; - after = [ "network.target" "buildbot-master.service" ]; + after = [ + "network.target" + "buildbot-master.service" + ]; wantedBy = [ "multi-user.target" ]; path = cfg.packages; environment.PYTHONPATH = "${python.withPackages (p: [ package ])}/${python.sitePackages}"; diff --git a/nixos/modules/services/continuous-integration/gitea-actions-runner.nix b/nixos/modules/services/continuous-integration/gitea-actions-runner.nix index 30be56f8eeabef..b4bb4d6879200b 100644 --- a/nixos/modules/services/continuous-integration/gitea-actions-runner.nix +++ b/nixos/modules/services/continuous-integration/gitea-actions-runner.nix @@ -1,8 +1,9 @@ -{ config -, lib -, pkgs -, utils -, ... +{ + config, + lib, + pkgs, + utils, + ... }: let @@ -23,11 +24,11 @@ let mkIf nameValuePair types - ; + ; inherit (utils) escapeSystemdPath - ; + ; cfg = config.services.gitea-actions-runner; @@ -36,8 +37,8 @@ let # Check whether any runner instance label requires a container runtime # Empty label strings result in the upstream defined defaultLabels, which require docker # https://gitea.com/gitea/act_runner/src/tag/v0.1.5/internal/app/cmd/register.go#L93-L98 - hasDockerScheme = instance: - instance.labels == [] || any (label: hasInfix ":docker:" label) instance.labels; + hasDockerScheme = + instance: instance.labels == [ ] || any (label: hasInfix ":docker:" label) instance.labels; wantsContainerRuntime = any hasDockerScheme (attrValues cfg.instances); hasHostScheme = instance: any (label: hasSuffix ":host" label) instance.labels; @@ -46,9 +47,10 @@ let hasDocker = config.virtualisation.docker.enable; hasPodman = config.virtualisation.podman.enable; - tokenXorTokenFile = instance: - (instance.token == null && instance.tokenFile != null) || - (instance.token != null && instance.tokenFile == null); + tokenXorTokenFile = + instance: + (instance.token == null && instance.tokenFile != null) + || (instance.token != null && instance.tokenFile == null); in { meta.maintainers = with lib.maintainers; [ @@ -59,7 +61,7 @@ in package = mkPackageOption pkgs "gitea-actions-runner" { }; instances = mkOption { - default = {}; + default = { }; description = '' Gitea Actions Runner instances. ''; @@ -168,94 +170,116 @@ in }; }; - config = mkIf (cfg.instances != {}) { - assertions = [ { - assertion = any tokenXorTokenFile (attrValues cfg.instances); - message = "Instances of gitea-actions-runner can have `token` or `tokenFile`, not both."; - } { - assertion = wantsContainerRuntime -> hasDocker || hasPodman; - message = "Label configuration on gitea-actions-runner instance requires either docker or podman."; - } ]; + config = mkIf (cfg.instances != { }) { + assertions = [ + { + assertion = any tokenXorTokenFile (attrValues cfg.instances); + message = "Instances of gitea-actions-runner can have `token` or `tokenFile`, not both."; + } + { + assertion = wantsContainerRuntime -> hasDocker || hasPodman; + message = "Label configuration on gitea-actions-runner instance requires either docker or podman."; + } + ]; - systemd.services = let - mkRunnerService = name: instance: let - wantsContainerRuntime = hasDockerScheme instance; - wantsHost = hasHostScheme instance; - wantsDocker = wantsContainerRuntime && config.virtualisation.docker.enable; - wantsPodman = wantsContainerRuntime && config.virtualisation.podman.enable; - configFile = settingsFormat.generate "config.yaml" instance.settings; - in - nameValuePair "gitea-runner-${escapeSystemdPath name}" { - inherit (instance) enable; - description = "Gitea Actions Runner"; - wants = [ "network-online.target" ]; - after = [ - "network-online.target" - ] ++ optionals (wantsDocker) [ - "docker.service" - ] ++ optionals (wantsPodman) [ - "podman.service" - ]; - wantedBy = [ - "multi-user.target" - ]; - environment = optionalAttrs (instance.token != null) { - TOKEN = "${instance.token}"; - } // optionalAttrs (wantsPodman) { - DOCKER_HOST = "unix:///run/podman/podman.sock"; - } // { - HOME = "/var/lib/gitea-runner/${name}"; - }; - path = with pkgs; [ - coreutils - ] ++ lib.optionals wantsHost instance.hostPackages; - serviceConfig = { - DynamicUser = true; - User = "gitea-runner"; - StateDirectory = "gitea-runner"; - WorkingDirectory = "-/var/lib/gitea-runner/${name}"; + systemd.services = + let + mkRunnerService = + name: instance: + let + wantsContainerRuntime = hasDockerScheme instance; + wantsHost = hasHostScheme instance; + wantsDocker = wantsContainerRuntime && config.virtualisation.docker.enable; + wantsPodman = wantsContainerRuntime && config.virtualisation.podman.enable; + configFile = settingsFormat.generate "config.yaml" instance.settings; + in + nameValuePair "gitea-runner-${escapeSystemdPath name}" { + inherit (instance) enable; + description = "Gitea Actions Runner"; + wants = [ "network-online.target" ]; + after = + [ + "network-online.target" + ] + ++ optionals (wantsDocker) [ + "docker.service" + ] + ++ optionals (wantsPodman) [ + "podman.service" + ]; + wantedBy = [ + "multi-user.target" + ]; + environment = + optionalAttrs (instance.token != null) { + TOKEN = "${instance.token}"; + } + // optionalAttrs (wantsPodman) { + DOCKER_HOST = "unix:///run/podman/podman.sock"; + } + // { + HOME = "/var/lib/gitea-runner/${name}"; + }; + path = + with pkgs; + [ + coreutils + ] + ++ lib.optionals wantsHost instance.hostPackages; + serviceConfig = + { + DynamicUser = true; + User = "gitea-runner"; + StateDirectory = "gitea-runner"; + WorkingDirectory = "-/var/lib/gitea-runner/${name}"; - # gitea-runner might fail when gitea is restarted during upgrade. - Restart = "on-failure"; - RestartSec = 2; + # gitea-runner might fail when gitea is restarted during upgrade. + Restart = "on-failure"; + RestartSec = 2; - ExecStartPre = [(pkgs.writeShellScript "gitea-register-runner-${name}" '' - export INSTANCE_DIR="$STATE_DIRECTORY/${name}" - mkdir -vp "$INSTANCE_DIR" - cd "$INSTANCE_DIR" + ExecStartPre = [ + (pkgs.writeShellScript "gitea-register-runner-${name}" '' + export INSTANCE_DIR="$STATE_DIRECTORY/${name}" + mkdir -vp "$INSTANCE_DIR" + cd "$INSTANCE_DIR" - # force reregistration on changed labels - export LABELS_FILE="$INSTANCE_DIR/.labels" - export LABELS_WANTED="$(echo ${escapeShellArg (concatStringsSep "\n" instance.labels)} | sort)" - export LABELS_CURRENT="$(cat $LABELS_FILE 2>/dev/null || echo 0)" + # force reregistration on changed labels + export LABELS_FILE="$INSTANCE_DIR/.labels" + export LABELS_WANTED="$(echo ${escapeShellArg (concatStringsSep "\n" instance.labels)} | sort)" + export LABELS_CURRENT="$(cat $LABELS_FILE 2>/dev/null || echo 0)" - if [ ! -e "$INSTANCE_DIR/.runner" ] || [ "$LABELS_WANTED" != "$LABELS_CURRENT" ]; then - # remove existing registration file, so that changing the labels forces a re-registration - rm -v "$INSTANCE_DIR/.runner" || true + if [ ! -e "$INSTANCE_DIR/.runner" ] || [ "$LABELS_WANTED" != "$LABELS_CURRENT" ]; then + # remove existing registration file, so that changing the labels forces a re-registration + rm -v "$INSTANCE_DIR/.runner" || true - # perform the registration - ${cfg.package}/bin/act_runner register --no-interactive \ - --instance ${escapeShellArg instance.url} \ - --token "$TOKEN" \ - --name ${escapeShellArg instance.name} \ - --labels ${escapeShellArg (concatStringsSep "," instance.labels)} \ - --config ${configFile} + # perform the registration + ${cfg.package}/bin/act_runner register --no-interactive \ + --instance ${escapeShellArg instance.url} \ + --token "$TOKEN" \ + --name ${escapeShellArg instance.name} \ + --labels ${escapeShellArg (concatStringsSep "," instance.labels)} \ + --config ${configFile} - # and write back the configured labels - echo "$LABELS_WANTED" > "$LABELS_FILE" - fi + # and write back the configured labels + echo "$LABELS_WANTED" > "$LABELS_FILE" + fi - '')]; - ExecStart = "${cfg.package}/bin/act_runner daemon --config ${configFile}"; - SupplementaryGroups = optionals (wantsDocker) [ - "docker" - ] ++ optionals (wantsPodman) [ - "podman" - ]; - } // optionalAttrs (instance.tokenFile != null) { - EnvironmentFile = instance.tokenFile; + '') + ]; + ExecStart = "${cfg.package}/bin/act_runner daemon --config ${configFile}"; + SupplementaryGroups = + optionals (wantsDocker) [ + "docker" + ] + ++ optionals (wantsPodman) [ + "podman" + ]; + } + // optionalAttrs (instance.tokenFile != null) { + EnvironmentFile = instance.tokenFile; + }; }; - }; - in mapAttrs' mkRunnerService cfg.instances; + in + mapAttrs' mkRunnerService cfg.instances; }; } diff --git a/nixos/modules/services/continuous-integration/github-runner/options.nix b/nixos/modules/services/continuous-integration/github-runner/options.nix index db8bba499de702..e20e8c5931fb64 100644 --- a/nixos/modules/services/continuous-integration/github-runner/options.nix +++ b/nixos/modules/services/continuous-integration/github-runner/options.nix @@ -1,6 +1,7 @@ -{ lib -, pkgs -, ... +{ + lib, + pkgs, + ... }: { options.services.github-runners = lib.mkOption { @@ -23,242 +24,247 @@ }; }; default = { }; - type = lib.types.attrsOf (lib.types.submodule ({ name, ... }: { - options = { - enable = lib.mkOption { - default = false; - example = true; - description = '' - Whether to enable GitHub Actions runner. - - Note: GitHub recommends using self-hosted runners with private repositories only. Learn more here: - [About self-hosted runners](https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners). - ''; - type = lib.types.bool; - }; - - url = lib.mkOption { - type = lib.types.str; - description = '' - Repository to add the runner to. - - Changing this option triggers a new runner registration. - - IMPORTANT: If your token is org-wide (not per repository), you need to - provide a github org link, not a single repository, so do it like this - `https://github.com/nixos`, not like this - `https://github.com/nixos/nixpkgs`. - Otherwise, you are going to get a `404 NotFound` - from `POST https://api.github.com/actions/runner-registration` - in the configure script. - ''; - example = "https://github.com/nixos/nixpkgs"; - }; - - tokenFile = lib.mkOption { - type = lib.types.path; - description = '' - The full path to a file which contains either - - * a fine-grained personal access token (PAT), - * a classic PAT - * or a runner registration token - - Changing this option or the `tokenFile`’s content triggers a new runner registration. - - We suggest using the fine-grained PATs. A runner registration token is valid - only for 1 hour after creation, so the next time the runner configuration changes - this will give you hard-to-debug HTTP 404 errors in the configure step. - - The file should contain exactly one line with the token without any newline. - (Use `echo -n '…token…' > …token file…` to make sure no newlines sneak in.) - - If the file contains a PAT, the service creates a new registration token - on startup as needed. - If a registration token is given, it can be used to re-register a runner of the same - name but is time-limited as noted above. - - For fine-grained PATs: - - Give it "Read and Write access to organization/repository self hosted runners", - depending on whether it is organization wide or per-repository. You might have to - experiment a little, fine-grained PATs are a `beta` Github feature and still subject - to change; nonetheless they are the best option at the moment. - - For classic PATs: - - Make sure the PAT has a scope of `admin:org` for organization-wide registrations - or a scope of `repo` for a single repository. - - For runner registration tokens: - - Nothing special needs to be done, but updating will break after one hour, - so these are not recommended. - ''; - example = "/run/secrets/github-runner/nixos.token"; - }; - - name = lib.mkOption { - type = lib.types.nullOr lib.types.str; - description = '' - Name of the runner to configure. If null, defaults to the hostname. - - Changing this option triggers a new runner registration. - ''; - example = "nixos"; - default = name; - }; - - runnerGroup = lib.mkOption { - type = lib.types.nullOr lib.types.str; - description = '' - Name of the runner group to add this runner to (defaults to the default runner group). - - Changing this option triggers a new runner registration. - ''; - default = null; - }; - - extraLabels = lib.mkOption { - type = lib.types.listOf lib.types.str; - description = '' - Extra labels in addition to the default (unless disabled through the `noDefaultLabels` option). - - Changing this option triggers a new runner registration. - ''; - example = lib.literalExpression ''[ "nixos" ]''; - default = [ ]; - }; - - noDefaultLabels = lib.mkOption { - type = lib.types.bool; - description = '' - Disables adding the default labels. Also see the `extraLabels` option. - - Changing this option triggers a new runner registration. - ''; - default = false; - }; - - replace = lib.mkOption { - type = lib.types.bool; - description = '' - Replace any existing runner with the same name. - - Without this flag, registering a new runner with the same name fails. - ''; - default = false; - }; - - extraPackages = lib.mkOption { - type = lib.types.listOf lib.types.package; - description = '' - Extra packages to add to `PATH` of the service to make them available to workflows. - ''; - default = [ ]; - }; - - extraEnvironment = lib.mkOption { - type = lib.types.attrs; - description = '' - Extra environment variables to set for the runner, as an attrset. - ''; - example = { - GIT_CONFIG = "/path/to/git/config"; - }; - default = { }; - }; - - serviceOverrides = lib.mkOption { - type = lib.types.attrs; - description = '' - Modify the systemd service. Can be used to, e.g., adjust the sandboxing options. - See {manpage}`systemd.exec(5)` for more options. - ''; - example = { - ProtectHome = false; - RestrictAddressFamilies = [ "AF_PACKET" ]; + type = lib.types.attrsOf ( + lib.types.submodule ( + { name, ... }: + { + options = { + enable = lib.mkOption { + default = false; + example = true; + description = '' + Whether to enable GitHub Actions runner. + + Note: GitHub recommends using self-hosted runners with private repositories only. Learn more here: + [About self-hosted runners](https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners). + ''; + type = lib.types.bool; + }; + + url = lib.mkOption { + type = lib.types.str; + description = '' + Repository to add the runner to. + + Changing this option triggers a new runner registration. + + IMPORTANT: If your token is org-wide (not per repository), you need to + provide a github org link, not a single repository, so do it like this + `https://github.com/nixos`, not like this + `https://github.com/nixos/nixpkgs`. + Otherwise, you are going to get a `404 NotFound` + from `POST https://api.github.com/actions/runner-registration` + in the configure script. + ''; + example = "https://github.com/nixos/nixpkgs"; + }; + + tokenFile = lib.mkOption { + type = lib.types.path; + description = '' + The full path to a file which contains either + + * a fine-grained personal access token (PAT), + * a classic PAT + * or a runner registration token + + Changing this option or the `tokenFile`’s content triggers a new runner registration. + + We suggest using the fine-grained PATs. A runner registration token is valid + only for 1 hour after creation, so the next time the runner configuration changes + this will give you hard-to-debug HTTP 404 errors in the configure step. + + The file should contain exactly one line with the token without any newline. + (Use `echo -n '…token…' > …token file…` to make sure no newlines sneak in.) + + If the file contains a PAT, the service creates a new registration token + on startup as needed. + If a registration token is given, it can be used to re-register a runner of the same + name but is time-limited as noted above. + + For fine-grained PATs: + + Give it "Read and Write access to organization/repository self hosted runners", + depending on whether it is organization wide or per-repository. You might have to + experiment a little, fine-grained PATs are a `beta` Github feature and still subject + to change; nonetheless they are the best option at the moment. + + For classic PATs: + + Make sure the PAT has a scope of `admin:org` for organization-wide registrations + or a scope of `repo` for a single repository. + + For runner registration tokens: + + Nothing special needs to be done, but updating will break after one hour, + so these are not recommended. + ''; + example = "/run/secrets/github-runner/nixos.token"; + }; + + name = lib.mkOption { + type = lib.types.nullOr lib.types.str; + description = '' + Name of the runner to configure. If null, defaults to the hostname. + + Changing this option triggers a new runner registration. + ''; + example = "nixos"; + default = name; + }; + + runnerGroup = lib.mkOption { + type = lib.types.nullOr lib.types.str; + description = '' + Name of the runner group to add this runner to (defaults to the default runner group). + + Changing this option triggers a new runner registration. + ''; + default = null; + }; + + extraLabels = lib.mkOption { + type = lib.types.listOf lib.types.str; + description = '' + Extra labels in addition to the default (unless disabled through the `noDefaultLabels` option). + + Changing this option triggers a new runner registration. + ''; + example = lib.literalExpression ''[ "nixos" ]''; + default = [ ]; + }; + + noDefaultLabels = lib.mkOption { + type = lib.types.bool; + description = '' + Disables adding the default labels. Also see the `extraLabels` option. + + Changing this option triggers a new runner registration. + ''; + default = false; + }; + + replace = lib.mkOption { + type = lib.types.bool; + description = '' + Replace any existing runner with the same name. + + Without this flag, registering a new runner with the same name fails. + ''; + default = false; + }; + + extraPackages = lib.mkOption { + type = lib.types.listOf lib.types.package; + description = '' + Extra packages to add to `PATH` of the service to make them available to workflows. + ''; + default = [ ]; + }; + + extraEnvironment = lib.mkOption { + type = lib.types.attrs; + description = '' + Extra environment variables to set for the runner, as an attrset. + ''; + example = { + GIT_CONFIG = "/path/to/git/config"; + }; + default = { }; + }; + + serviceOverrides = lib.mkOption { + type = lib.types.attrs; + description = '' + Modify the systemd service. Can be used to, e.g., adjust the sandboxing options. + See {manpage}`systemd.exec(5)` for more options. + ''; + example = { + ProtectHome = false; + RestrictAddressFamilies = [ "AF_PACKET" ]; + }; + default = { }; + }; + + package = lib.mkPackageOption pkgs "github-runner" { }; + + ephemeral = lib.mkOption { + type = lib.types.bool; + description = '' + If enabled, causes the following behavior: + + - Passes the `--ephemeral` flag to the runner configuration script + - De-registers and stops the runner with GitHub after it has processed one job + - On stop, systemd wipes the runtime directory (this always happens, even without using the ephemeral option) + - Restarts the service after its successful exit + - On start, wipes the state directory and configures a new runner + + You should only enable this option if `tokenFile` points to a file which contains a + personal access token (PAT). If you're using the option with a registration token, restarting the + service will fail as soon as the registration token expired. + + Changing this option triggers a new runner registration. + ''; + default = false; + }; + + user = lib.mkOption { + type = lib.types.nullOr lib.types.str; + description = '' + User under which to run the service. + + If this option and the `group` option is set to `null`, + the service runs as a dynamically allocated user. + + Also see the `group` option for an overview on the effects of the `user` and `group` settings. + ''; + default = null; + defaultText = lib.literalExpression "username"; + }; + + group = lib.mkOption { + type = lib.types.nullOr lib.types.str; + description = '' + Group under which to run the service. + + The effect of this option depends on the value of the `user` option: + + - `group == null` and `user == null`: + The service runs with a dynamically allocated user and group. + - `group == null` and `user != null`: + The service runs as the given user and its default group. + - `group != null` and `user == null`: + This configuration is invalid. In this case, the service would use the given group + but run as root implicitly. If this is really what you want, set `user = "root"` explicitly. + ''; + default = null; + defaultText = lib.literalExpression "groupname"; + }; + + workDir = lib.mkOption { + type = with lib.types; nullOr str; + description = '' + Working directory, available as `$GITHUB_WORKSPACE` during workflow runs + and used as a default for [repository checkouts](https://github.com/actions/checkout). + The service cleans this directory on every service start. + + A value of `null` will default to the systemd `RuntimeDirectory`. + + Changing this option triggers a new runner registration. + ''; + default = null; + }; + + nodeRuntimes = lib.mkOption { + type = with lib.types; nonEmptyListOf (enum [ "node20" ]); + default = [ "node20" ]; + description = '' + List of Node.js runtimes the runner should support. + ''; + }; }; - default = { }; - }; - - package = lib.mkPackageOption pkgs "github-runner" { }; - - ephemeral = lib.mkOption { - type = lib.types.bool; - description = '' - If enabled, causes the following behavior: - - - Passes the `--ephemeral` flag to the runner configuration script - - De-registers and stops the runner with GitHub after it has processed one job - - On stop, systemd wipes the runtime directory (this always happens, even without using the ephemeral option) - - Restarts the service after its successful exit - - On start, wipes the state directory and configures a new runner - - You should only enable this option if `tokenFile` points to a file which contains a - personal access token (PAT). If you're using the option with a registration token, restarting the - service will fail as soon as the registration token expired. - - Changing this option triggers a new runner registration. - ''; - default = false; - }; - - user = lib.mkOption { - type = lib.types.nullOr lib.types.str; - description = '' - User under which to run the service. - - If this option and the `group` option is set to `null`, - the service runs as a dynamically allocated user. - - Also see the `group` option for an overview on the effects of the `user` and `group` settings. - ''; - default = null; - defaultText = lib.literalExpression "username"; - }; - - group = lib.mkOption { - type = lib.types.nullOr lib.types.str; - description = '' - Group under which to run the service. - - The effect of this option depends on the value of the `user` option: - - - `group == null` and `user == null`: - The service runs with a dynamically allocated user and group. - - `group == null` and `user != null`: - The service runs as the given user and its default group. - - `group != null` and `user == null`: - This configuration is invalid. In this case, the service would use the given group - but run as root implicitly. If this is really what you want, set `user = "root"` explicitly. - ''; - default = null; - defaultText = lib.literalExpression "groupname"; - }; - - workDir = lib.mkOption { - type = with lib.types; nullOr str; - description = '' - Working directory, available as `$GITHUB_WORKSPACE` during workflow runs - and used as a default for [repository checkouts](https://github.com/actions/checkout). - The service cleans this directory on every service start. - - A value of `null` will default to the systemd `RuntimeDirectory`. - - Changing this option triggers a new runner registration. - ''; - default = null; - }; - - nodeRuntimes = lib.mkOption { - type = with lib.types; nonEmptyListOf (enum [ "node20" ]); - default = [ "node20" ]; - description = '' - List of Node.js runtimes the runner should support. - ''; - }; - }; - })); + } + ) + ); }; } diff --git a/nixos/modules/services/continuous-integration/github-runner/service.nix b/nixos/modules/services/continuous-integration/github-runner/service.nix index 045ea41aa5f1a2..edf93417d20501 100644 --- a/nixos/modules/services/continuous-integration/github-runner/service.nix +++ b/nixos/modules/services/continuous-integration/github-runner/service.nix @@ -1,300 +1,336 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: { config.assertions = lib.flatten ( - lib.flip lib.mapAttrsToList config.services.github-runners (name: cfg: map (lib.mkIf cfg.enable) [ - { - assertion = !cfg.noDefaultLabels || (cfg.extraLabels != [ ]); - message = "`services.github-runners.${name}`: The `extraLabels` option is mandatory if `noDefaultLabels` is set"; - } - { - assertion = cfg.group == null || cfg.user != null; - message = ''`services.github-runners.${name}`: Setting `group` while leaving `user` unset runs the service as `root`. If this is really what you want, set `user = "root"` explicitly''; - } - ]) + lib.flip lib.mapAttrsToList config.services.github-runners ( + name: cfg: + map (lib.mkIf cfg.enable) [ + { + assertion = !cfg.noDefaultLabels || (cfg.extraLabels != [ ]); + message = "`services.github-runners.${name}`: The `extraLabels` option is mandatory if `noDefaultLabels` is set"; + } + { + assertion = cfg.group == null || cfg.user != null; + message = ''`services.github-runners.${name}`: Setting `group` while leaving `user` unset runs the service as `root`. If this is really what you want, set `user = "root"` explicitly''; + } + ] + ) ); config.systemd.services = - let enabledRunners = lib.filterAttrs (_: cfg: cfg.enable) config.services.github-runners; - in (lib.flip lib.mapAttrs' enabledRunners (name: cfg: let - svcName = "github-runner-${name}"; - systemdDir = "github-runner/${name}"; + enabledRunners = lib.filterAttrs (_: cfg: cfg.enable) config.services.github-runners; + in + (lib.flip lib.mapAttrs' enabledRunners ( + name: cfg: + let + svcName = "github-runner-${name}"; + systemdDir = "github-runner/${name}"; - # %t: Runtime directory root (usually /run); see systemd.unit(5) - runtimeDir = "%t/${systemdDir}"; - # %S: State directory root (usually /var/lib); see systemd.unit(5) - stateDir = "%S/${systemdDir}"; - # %L: Log directory root (usually /var/log); see systemd.unit(5) - logsDir = "%L/${systemdDir}"; - # Name of file stored in service state directory - currentConfigTokenFilename = ".current-token"; + # %t: Runtime directory root (usually /run); see systemd.unit(5) + runtimeDir = "%t/${systemdDir}"; + # %S: State directory root (usually /var/lib); see systemd.unit(5) + stateDir = "%S/${systemdDir}"; + # %L: Log directory root (usually /var/log); see systemd.unit(5) + logsDir = "%L/${systemdDir}"; + # Name of file stored in service state directory + currentConfigTokenFilename = ".current-token"; - workDir = if cfg.workDir == null then runtimeDir else cfg.workDir; - # Support old github-runner versions which don't have the `nodeRuntimes` arg yet. - package = cfg.package.override (old: lib.optionalAttrs (lib.hasAttr "nodeRuntimes" old) { inherit (cfg) nodeRuntimes; }); - in - lib.nameValuePair svcName { - description = "GitHub Actions runner"; + workDir = if cfg.workDir == null then runtimeDir else cfg.workDir; + # Support old github-runner versions which don't have the `nodeRuntimes` arg yet. + package = cfg.package.override ( + old: lib.optionalAttrs (lib.hasAttr "nodeRuntimes" old) { inherit (cfg) nodeRuntimes; } + ); + in + lib.nameValuePair svcName { + description = "GitHub Actions runner"; - wantedBy = [ "multi-user.target" ]; - wants = [ "network-online.target" ]; - after = [ "network.target" "network-online.target" ]; + wantedBy = [ "multi-user.target" ]; + wants = [ "network-online.target" ]; + after = [ + "network.target" + "network-online.target" + ]; - environment = { - HOME = workDir; - RUNNER_ROOT = stateDir; - } // cfg.extraEnvironment; + environment = { + HOME = workDir; + RUNNER_ROOT = stateDir; + } // cfg.extraEnvironment; - path = (with pkgs; [ - bashInteractive - coreutils - git - gnutar - gzip - ]) ++ [ - config.nix.package - ] ++ cfg.extraPackages; + path = + (with pkgs; [ + bashInteractive + coreutils + git + gnutar + gzip + ]) + ++ [ + config.nix.package + ] + ++ cfg.extraPackages; - serviceConfig = lib.mkMerge [ - { - ExecStart = "${package}/bin/Runner.Listener run --startuptype service"; + serviceConfig = lib.mkMerge [ + { + ExecStart = "${package}/bin/Runner.Listener run --startuptype service"; - # Does the following, sequentially: - # - If the module configuration or the token has changed, purge the state directory, - # and create the current and the new token file with the contents of the configured - # token. While both files have the same content, only the later is accessible by - # the service user. - # - Configure the runner using the new token file. When finished, delete it. - # - Set up the directory structure by creating the necessary symlinks. - ExecStartPre = - let - # Wrapper script which expects the full path of the state, working and logs - # directory as arguments. Overrides the respective systemd variables to provide - # unambiguous directory names. This becomes relevant, for example, if the - # caller overrides any of the StateDirectory=, RuntimeDirectory= or LogDirectory= - # to contain more than one directory. This causes systemd to set the respective - # environment variables with the path of all of the given directories, separated - # by a colon. - writeScript = name: lines: pkgs.writeShellScript "${svcName}-${name}.sh" '' - set -euo pipefail + # Does the following, sequentially: + # - If the module configuration or the token has changed, purge the state directory, + # and create the current and the new token file with the contents of the configured + # token. While both files have the same content, only the later is accessible by + # the service user. + # - Configure the runner using the new token file. When finished, delete it. + # - Set up the directory structure by creating the necessary symlinks. + ExecStartPre = + let + # Wrapper script which expects the full path of the state, working and logs + # directory as arguments. Overrides the respective systemd variables to provide + # unambiguous directory names. This becomes relevant, for example, if the + # caller overrides any of the StateDirectory=, RuntimeDirectory= or LogDirectory= + # to contain more than one directory. This causes systemd to set the respective + # environment variables with the path of all of the given directories, separated + # by a colon. + writeScript = + name: lines: + pkgs.writeShellScript "${svcName}-${name}.sh" '' + set -euo pipefail - STATE_DIRECTORY="$1" - WORK_DIRECTORY="$2" - LOGS_DIRECTORY="$3" + STATE_DIRECTORY="$1" + WORK_DIRECTORY="$2" + LOGS_DIRECTORY="$3" - ${lines} - ''; - runnerRegistrationConfig = lib.getAttrs [ - "ephemeral" - "extraLabels" - "name" - "noDefaultLabels" - "runnerGroup" - "tokenFile" - "url" - "workDir" - ] - cfg; - newConfigPath = builtins.toFile "${svcName}-config.json" (builtins.toJSON runnerRegistrationConfig); - currentConfigPath = "$STATE_DIRECTORY/.nixos-current-config.json"; - newConfigTokenPath = "$STATE_DIRECTORY/.new-token"; - currentConfigTokenPath = "$STATE_DIRECTORY/${currentConfigTokenFilename}"; + ${lines} + ''; + runnerRegistrationConfig = lib.getAttrs [ + "ephemeral" + "extraLabels" + "name" + "noDefaultLabels" + "runnerGroup" + "tokenFile" + "url" + "workDir" + ] cfg; + newConfigPath = builtins.toFile "${svcName}-config.json" (builtins.toJSON runnerRegistrationConfig); + currentConfigPath = "$STATE_DIRECTORY/.nixos-current-config.json"; + newConfigTokenPath = "$STATE_DIRECTORY/.new-token"; + currentConfigTokenPath = "$STATE_DIRECTORY/${currentConfigTokenFilename}"; - runnerCredFiles = [ - ".credentials" - ".credentials_rsaparams" - ".runner" - ]; - unconfigureRunner = writeScript "unconfigure" '' - copy_tokens() { - # Copy the configured token file to the state dir and allow the service user to read the file - install --mode=666 ${lib.escapeShellArg cfg.tokenFile} "${newConfigTokenPath}" - # Also copy current file to allow for a diff on the next start - install --mode=600 ${lib.escapeShellArg cfg.tokenFile} "${currentConfigTokenPath}" - } - clean_state() { - find "$STATE_DIRECTORY/" -mindepth 1 -delete - copy_tokens - } - diff_config() { - changed=0 - # Check for module config changes - [[ -f "${currentConfigPath}" ]] \ - && ${pkgs.diffutils}/bin/diff -q '${newConfigPath}' "${currentConfigPath}" >/dev/null 2>&1 \ - || changed=1 - # Also check the content of the token file - [[ -f "${currentConfigTokenPath}" ]] \ - && ${pkgs.diffutils}/bin/diff -q "${currentConfigTokenPath}" ${lib.escapeShellArg cfg.tokenFile} >/dev/null 2>&1 \ - || changed=1 - # If the config has changed, remove old state and copy tokens - if [[ "$changed" -eq 1 ]]; then - echo "Config has changed, removing old runner state." - echo "The old runner will still appear in the GitHub Actions UI." \ - "You have to remove it manually." + runnerCredFiles = [ + ".credentials" + ".credentials_rsaparams" + ".runner" + ]; + unconfigureRunner = writeScript "unconfigure" '' + copy_tokens() { + # Copy the configured token file to the state dir and allow the service user to read the file + install --mode=666 ${lib.escapeShellArg cfg.tokenFile} "${newConfigTokenPath}" + # Also copy current file to allow for a diff on the next start + install --mode=600 ${lib.escapeShellArg cfg.tokenFile} "${currentConfigTokenPath}" + } + clean_state() { + find "$STATE_DIRECTORY/" -mindepth 1 -delete + copy_tokens + } + diff_config() { + changed=0 + # Check for module config changes + [[ -f "${currentConfigPath}" ]] \ + && ${pkgs.diffutils}/bin/diff -q '${newConfigPath}' "${currentConfigPath}" >/dev/null 2>&1 \ + || changed=1 + # Also check the content of the token file + [[ -f "${currentConfigTokenPath}" ]] \ + && ${pkgs.diffutils}/bin/diff -q "${currentConfigTokenPath}" ${lib.escapeShellArg cfg.tokenFile} >/dev/null 2>&1 \ + || changed=1 + # If the config has changed, remove old state and copy tokens + if [[ "$changed" -eq 1 ]]; then + echo "Config has changed, removing old runner state." + echo "The old runner will still appear in the GitHub Actions UI." \ + "You have to remove it manually." + clean_state + fi + } + if [[ "${lib.optionalString cfg.ephemeral "1"}" ]]; then + # In ephemeral mode, we always want to start with a clean state clean_state - fi - } - if [[ "${lib.optionalString cfg.ephemeral "1"}" ]]; then - # In ephemeral mode, we always want to start with a clean state - clean_state - elif [[ "$(ls -A "$STATE_DIRECTORY")" ]]; then - # There are state files from a previous run; diff them to decide if we need a new registration - diff_config - else - # The state directory is entirely empty which indicates a first start - copy_tokens - fi - # Always clean workDir - find -H "$WORK_DIRECTORY" -mindepth 1 -delete - ''; - configureRunner = writeScript "configure" /*bash*/'' - if [[ -e "${newConfigTokenPath}" ]]; then - echo "Configuring GitHub Actions Runner" - # shellcheck disable=SC2054 # don't complain about commas in --labels - args=( - --unattended - --disableupdate - --work "$WORK_DIRECTORY" - --url ${lib.escapeShellArg cfg.url} - --labels ${lib.escapeShellArg (lib.concatStringsSep "," cfg.extraLabels)} - ${lib.optionalString (cfg.name != null ) "--name ${lib.escapeShellArg cfg.name}"} - ${lib.optionalString cfg.replace "--replace"} - ${lib.optionalString (cfg.runnerGroup != null) "--runnergroup ${lib.escapeShellArg cfg.runnerGroup}"} - ${lib.optionalString cfg.ephemeral "--ephemeral"} - ${lib.optionalString cfg.noDefaultLabels "--no-default-labels"} - ) - # If the token file contains a PAT (i.e., it starts with "ghp_" or "github_pat_"), we have to use the --pat option, - # if it is not a PAT, we assume it contains a registration token and use the --token option - token=$(<"${newConfigTokenPath}") - if [[ "$token" =~ ^ghp_* ]] || [[ "$token" =~ ^github_pat_* ]]; then - args+=(--pat "$token") + elif [[ "$(ls -A "$STATE_DIRECTORY")" ]]; then + # There are state files from a previous run; diff them to decide if we need a new registration + diff_config else - args+=(--token "$token") + # The state directory is entirely empty which indicates a first start + copy_tokens fi - ${package}/bin/Runner.Listener configure "''${args[@]}" - # Move the automatically created _diag dir to the logs dir - mkdir -p "$STATE_DIRECTORY/_diag" - cp -r "$STATE_DIRECTORY/_diag/." "$LOGS_DIRECTORY/" - rm -rf "$STATE_DIRECTORY/_diag/" - # Cleanup token from config - rm "${newConfigTokenPath}" - # Symlink to new config - ln -s '${newConfigPath}' "${currentConfigPath}" - fi - ''; - setupWorkDir = writeScript "setup-work-dirs" '' - # Link _diag dir - ln -s "$LOGS_DIRECTORY" "$WORK_DIRECTORY/_diag" + # Always clean workDir + find -H "$WORK_DIRECTORY" -mindepth 1 -delete + ''; + configureRunner = + writeScript "configure" # bash + '' + if [[ -e "${newConfigTokenPath}" ]]; then + echo "Configuring GitHub Actions Runner" + # shellcheck disable=SC2054 # don't complain about commas in --labels + args=( + --unattended + --disableupdate + --work "$WORK_DIRECTORY" + --url ${lib.escapeShellArg cfg.url} + --labels ${lib.escapeShellArg (lib.concatStringsSep "," cfg.extraLabels)} + ${lib.optionalString (cfg.name != null) "--name ${lib.escapeShellArg cfg.name}"} + ${lib.optionalString cfg.replace "--replace"} + ${lib.optionalString ( + cfg.runnerGroup != null + ) "--runnergroup ${lib.escapeShellArg cfg.runnerGroup}"} + ${lib.optionalString cfg.ephemeral "--ephemeral"} + ${lib.optionalString cfg.noDefaultLabels "--no-default-labels"} + ) + # If the token file contains a PAT (i.e., it starts with "ghp_" or "github_pat_"), we have to use the --pat option, + # if it is not a PAT, we assume it contains a registration token and use the --token option + token=$(<"${newConfigTokenPath}") + if [[ "$token" =~ ^ghp_* ]] || [[ "$token" =~ ^github_pat_* ]]; then + args+=(--pat "$token") + else + args+=(--token "$token") + fi + ${package}/bin/Runner.Listener configure "''${args[@]}" + # Move the automatically created _diag dir to the logs dir + mkdir -p "$STATE_DIRECTORY/_diag" + cp -r "$STATE_DIRECTORY/_diag/." "$LOGS_DIRECTORY/" + rm -rf "$STATE_DIRECTORY/_diag/" + # Cleanup token from config + rm "${newConfigTokenPath}" + # Symlink to new config + ln -s '${newConfigPath}' "${currentConfigPath}" + fi + ''; + setupWorkDir = writeScript "setup-work-dirs" '' + # Link _diag dir + ln -s "$LOGS_DIRECTORY" "$WORK_DIRECTORY/_diag" - # Link the runner credentials to the work dir - ln -s "$STATE_DIRECTORY"/{${lib.concatStringsSep "," runnerCredFiles}} "$WORK_DIRECTORY/" - ''; - in - map (x: "${x} ${lib.escapeShellArgs [ stateDir workDir logsDir ]}") [ - "+${unconfigureRunner}" # runs as root - configureRunner - setupWorkDir - ]; + # Link the runner credentials to the work dir + ln -s "$STATE_DIRECTORY"/{${lib.concatStringsSep "," runnerCredFiles}} "$WORK_DIRECTORY/" + ''; + in + map + ( + x: + "${x} ${ + lib.escapeShellArgs [ + stateDir + workDir + logsDir + ] + }" + ) + [ + "+${unconfigureRunner}" # runs as root + configureRunner + setupWorkDir + ]; - # If running in ephemeral mode, restart the service on-exit (i.e., successful de-registration of the runner) - # to trigger a fresh registration. - Restart = if cfg.ephemeral then "on-success" else "no"; - # If the runner exits with `ReturnCode.RetryableError = 2`, always restart the service: - # https://github.com/actions/runner/blob/40ed7f8/src/Runner.Common/Constants.cs#L146 - RestartForceExitStatus = [ 2 ]; + # If running in ephemeral mode, restart the service on-exit (i.e., successful de-registration of the runner) + # to trigger a fresh registration. + Restart = if cfg.ephemeral then "on-success" else "no"; + # If the runner exits with `ReturnCode.RetryableError = 2`, always restart the service: + # https://github.com/actions/runner/blob/40ed7f8/src/Runner.Common/Constants.cs#L146 + RestartForceExitStatus = [ 2 ]; - # Contains _diag - LogsDirectory = [ systemdDir ]; - # Default RUNNER_ROOT which contains ephemeral Runner data - RuntimeDirectory = [ systemdDir ]; - # Home of persistent runner data, e.g., credentials - StateDirectory = [ systemdDir ]; - StateDirectoryMode = "0700"; - WorkingDirectory = workDir; + # Contains _diag + LogsDirectory = [ systemdDir ]; + # Default RUNNER_ROOT which contains ephemeral Runner data + RuntimeDirectory = [ systemdDir ]; + # Home of persistent runner data, e.g., credentials + StateDirectory = [ systemdDir ]; + StateDirectoryMode = "0700"; + WorkingDirectory = workDir; - InaccessiblePaths = [ - # Token file path given in the configuration, if visible to the service - "-${cfg.tokenFile}" - # Token file in the state directory - "${stateDir}/${currentConfigTokenFilename}" - ]; + InaccessiblePaths = [ + # Token file path given in the configuration, if visible to the service + "-${cfg.tokenFile}" + # Token file in the state directory + "${stateDir}/${currentConfigTokenFilename}" + ]; - KillSignal = "SIGINT"; + KillSignal = "SIGINT"; - # Hardening (may overlap with DynamicUser=) - # The following options are only for optimizing: - # systemd-analyze security github-runner - AmbientCapabilities = lib.mkBefore [ "" ]; - CapabilityBoundingSet = lib.mkBefore [ "" ]; - # ProtectClock= adds DeviceAllow=char-rtc r - DeviceAllow = lib.mkBefore [ "" ]; - NoNewPrivileges = lib.mkDefault true; - PrivateDevices = lib.mkDefault true; - PrivateMounts = lib.mkDefault true; - PrivateTmp = lib.mkDefault true; - PrivateUsers = lib.mkDefault true; - ProtectClock = lib.mkDefault true; - ProtectControlGroups = lib.mkDefault true; - ProtectHome = lib.mkDefault true; - ProtectHostname = lib.mkDefault true; - ProtectKernelLogs = lib.mkDefault true; - ProtectKernelModules = lib.mkDefault true; - ProtectKernelTunables = lib.mkDefault true; - ProtectSystem = lib.mkDefault "strict"; - RemoveIPC = lib.mkDefault true; - RestrictNamespaces = lib.mkDefault true; - RestrictRealtime = lib.mkDefault true; - RestrictSUIDSGID = lib.mkDefault true; - UMask = lib.mkDefault "0066"; - ProtectProc = lib.mkDefault "invisible"; - SystemCallFilter = lib.mkBefore [ - "~@clock" - "~@cpu-emulation" - "~@module" - "~@mount" - "~@obsolete" - "~@raw-io" - "~@reboot" - "~capset" - "~setdomainname" - "~sethostname" - ]; - RestrictAddressFamilies = lib.mkBefore [ "AF_INET" "AF_INET6" "AF_UNIX" "AF_NETLINK" ]; + # Hardening (may overlap with DynamicUser=) + # The following options are only for optimizing: + # systemd-analyze security github-runner + AmbientCapabilities = lib.mkBefore [ "" ]; + CapabilityBoundingSet = lib.mkBefore [ "" ]; + # ProtectClock= adds DeviceAllow=char-rtc r + DeviceAllow = lib.mkBefore [ "" ]; + NoNewPrivileges = lib.mkDefault true; + PrivateDevices = lib.mkDefault true; + PrivateMounts = lib.mkDefault true; + PrivateTmp = lib.mkDefault true; + PrivateUsers = lib.mkDefault true; + ProtectClock = lib.mkDefault true; + ProtectControlGroups = lib.mkDefault true; + ProtectHome = lib.mkDefault true; + ProtectHostname = lib.mkDefault true; + ProtectKernelLogs = lib.mkDefault true; + ProtectKernelModules = lib.mkDefault true; + ProtectKernelTunables = lib.mkDefault true; + ProtectSystem = lib.mkDefault "strict"; + RemoveIPC = lib.mkDefault true; + RestrictNamespaces = lib.mkDefault true; + RestrictRealtime = lib.mkDefault true; + RestrictSUIDSGID = lib.mkDefault true; + UMask = lib.mkDefault "0066"; + ProtectProc = lib.mkDefault "invisible"; + SystemCallFilter = lib.mkBefore [ + "~@clock" + "~@cpu-emulation" + "~@module" + "~@mount" + "~@obsolete" + "~@raw-io" + "~@reboot" + "~capset" + "~setdomainname" + "~sethostname" + ]; + RestrictAddressFamilies = lib.mkBefore [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + "AF_NETLINK" + ]; - BindPaths = lib.optionals (cfg.workDir != null) [ cfg.workDir ]; + BindPaths = lib.optionals (cfg.workDir != null) [ cfg.workDir ]; - # Needs network access - PrivateNetwork = lib.mkDefault false; - # Cannot be true due to Node - MemoryDenyWriteExecute = lib.mkDefault false; + # Needs network access + PrivateNetwork = lib.mkDefault false; + # Cannot be true due to Node + MemoryDenyWriteExecute = lib.mkDefault false; - # The more restrictive "pid" option makes `nix` commands in CI emit - # "GC Warning: Couldn't read /proc/stat" - # You may want to set this to "pid" if not using `nix` commands - ProcSubset = lib.mkDefault "all"; - # Coverage programs for compiled code such as `cargo-tarpaulin` disable - # ASLR (address space layout randomization) which requires the - # `personality` syscall - # You may want to set this to `true` if not using coverage tooling on - # compiled code - LockPersonality = lib.mkDefault false; + # The more restrictive "pid" option makes `nix` commands in CI emit + # "GC Warning: Couldn't read /proc/stat" + # You may want to set this to "pid" if not using `nix` commands + ProcSubset = lib.mkDefault "all"; + # Coverage programs for compiled code such as `cargo-tarpaulin` disable + # ASLR (address space layout randomization) which requires the + # `personality` syscall + # You may want to set this to `true` if not using coverage tooling on + # compiled code + LockPersonality = lib.mkDefault false; - DynamicUser = lib.mkDefault true; - } - (lib.mkIf (cfg.user != null) { - DynamicUser = false; - User = cfg.user; - }) - (lib.mkIf (cfg.group != null) { - DynamicUser = false; - Group = cfg.group; - }) - cfg.serviceOverrides - ]; - } - )); + DynamicUser = lib.mkDefault true; + } + (lib.mkIf (cfg.user != null) { + DynamicUser = false; + User = cfg.user; + }) + (lib.mkIf (cfg.group != null) { + DynamicUser = false; + Group = cfg.group; + }) + cfg.serviceOverrides + ]; + } + )); } diff --git a/nixos/modules/services/continuous-integration/gitlab-runner.nix b/nixos/modules/services/continuous-integration/gitlab-runner.nix index 07f0524561b220..895ba66e7ea0c4 100644 --- a/nixos/modules/services/continuous-integration/gitlab-runner.nix +++ b/nixos/modules/services/continuous-integration/gitlab-runner.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (builtins) @@ -42,22 +47,30 @@ let hasDocker = config.virtualisation.docker.enable; hasPodman = config.virtualisation.podman.enable && config.virtualisation.podman.dockerSocket.enable; - /* The whole logic of this module is to diff the hashes of the desired vs existing runners - The hash is recorded in the runner's name because we can't do better yet - See https://gitlab.com/gitlab-org/gitlab-runner/-/issues/29350 for more details + /* + The whole logic of this module is to diff the hashes of the desired vs existing runners + The hash is recorded in the runner's name because we can't do better yet + See https://gitlab.com/gitlab-org/gitlab-runner/-/issues/29350 for more details */ - genRunnerName = name: service: let + genRunnerName = + name: service: + let hash = substring 0 12 (hashString "md5" (unsafeDiscardStringContext (toJSON service))); - in if service ? description && service.description != null - then "${hash} ${service.description}" - else "${name}_${config.networking.hostName}_${hash}"; - - hashedServices = mapAttrs' - (name: service: nameValuePair (genRunnerName name service) service) cfg.services; + in + if service ? description && service.description != null then + "${hash} ${service.description}" + else + "${name}_${config.networking.hostName}_${hash}"; + + hashedServices = mapAttrs' ( + name: service: nameValuePair (genRunnerName name service) service + ) cfg.services; configPath = ''"$HOME"/.gitlab-runner/config.toml''; configureScript = pkgs.writeShellApplication { name = "gitlab-runner-configure"; - runtimeInputs = [ cfg.package ] ++ (with pkgs; [ + runtimeInputs = + [ cfg.package ] + ++ (with pkgs; [ bash gawk jq @@ -66,133 +79,148 @@ let util-linux perl python3 - ]); - text = if (cfg.configFile != null) then '' - cp ${cfg.configFile} ${configPath} - # make config file readable by service - chown -R --reference="$HOME" "$(dirname ${configPath})" - '' else '' - export CONFIG_FILE=${configPath} - - mkdir -p "$(dirname ${configPath})" - touch ${configPath} - - # update global options - remarshal --if toml --of json --stringify ${configPath} \ - | jq -cM 'with_entries(select([.key] | inside(["runners"])))' \ - | jq -scM '.[0] + .[1]' - <(echo ${escapeShellArg (toJSON cfg.settings)}) \ - | remarshal --if json --of toml \ - | sponge ${configPath} - - # remove no longer existing services - gitlab-runner verify --delete - - ${toShellVar "NEEDED_SERVICES" (lib.mapAttrs (name: value: 1) hashedServices)} - - declare -A REGISTERED_SERVICES - - while IFS="," read -r name token; - do - REGISTERED_SERVICES["$name"]="$token" - done < <(gitlab-runner --log-format json list 2>&1 | grep Token | jq -r '.msg +"," + .Token') - - echo "NEEDED_SERVICES: " "''${!NEEDED_SERVICES[@]}" - echo "REGISTERED_SERVICES:" "''${!REGISTERED_SERVICES[@]}" - - # difference between current and desired state - declare -A NEW_SERVICES - for name in "''${!NEEDED_SERVICES[@]}"; do - if [ ! -v 'REGISTERED_SERVICES[$name]' ]; then - NEW_SERVICES[$name]=1 - fi - done - - declare -A OLD_SERVICES - # shellcheck disable=SC2034 - for name in "''${!REGISTERED_SERVICES[@]}"; do - if [ ! -v 'NEEDED_SERVICES[$name]' ]; then - OLD_SERVICES[$name]=1 - fi - done - - # register new services - ${concatStringsSep "\n" (mapAttrsToList (name: service: '' - # TODO so here we should mention NEW_SERVICES - if [ -v 'NEW_SERVICES["${name}"]' ] ; then - bash -c ${escapeShellArg (concatStringsSep " \\\n " ([ - "set -a && source ${ - if service.registrationConfigFile != null - then service.registrationConfigFile - else service.authenticationTokenConfigFile} &&" - "gitlab-runner register" - "--non-interactive" - "--name '${name}'" - "--executor ${service.executor}" - "--limit ${toString service.limit}" - "--request-concurrency ${toString service.requestConcurrency}" - ] - ++ optional (service.authenticationTokenConfigFile == null) - "--maximum-timeout ${toString service.maximumTimeout}" - ++ service.registrationFlags - ++ optional (service.buildsDir != null) - "--builds-dir ${service.buildsDir}" - ++ optional (service.cloneUrl != null) - "--clone-url ${service.cloneUrl}" - ++ optional (service.preGetSourcesScript != null) - "--pre-get-sources-script ${service.preGetSourcesScript}" - ++ optional (service.postGetSourcesScript != null) - "--post-get-sources-script ${service.postGetSourcesScript}" - ++ optional (service.preBuildScript != null) - "--pre-build-script ${service.preBuildScript}" - ++ optional (service.postBuildScript != null) - "--post-build-script ${service.postBuildScript}" - ++ optional (service.authenticationTokenConfigFile == null && service.tagList != [ ]) - "--tag-list ${concatStringsSep "," service.tagList}" - ++ optional (service.authenticationTokenConfigFile == null && service.runUntagged) - "--run-untagged" - ++ optional (service.authenticationTokenConfigFile == null && service.protected) - "--access-level ref_protected" - ++ optional service.debugTraceDisabled - "--debug-trace-disabled" - ++ map (e: "--env ${escapeShellArg e}") (mapAttrsToList (name: value: "${name}=${value}") service.environmentVariables) - ++ optionals (hasPrefix "docker" service.executor) ( - assert ( - assertMsg (service.dockerImage != null) - "dockerImage option is required for ${service.executor} executor (${name})"); - [ "--docker-image ${service.dockerImage}" ] - ++ optional service.dockerDisableCache - "--docker-disable-cache" - ++ optional service.dockerPrivileged - "--docker-privileged" - ++ map (v: "--docker-volumes ${escapeShellArg v}") service.dockerVolumes - ++ map (v: "--docker-extra-hosts ${escapeShellArg v}") service.dockerExtraHosts - ++ map (v: "--docker-allowed-images ${escapeShellArg v}") service.dockerAllowedImages - ++ map (v: "--docker-allowed-services ${escapeShellArg v}") service.dockerAllowedServices - ) - ))} && sleep 1 || exit 1 - fi - '') hashedServices)} - - # check key is in array https://stackoverflow.com/questions/30353951/how-to-check-if-dictionary-contains-a-key-in-bash - - echo "NEW_SERVICES: ''${NEW_SERVICES[*]}" - echo "OLD_SERVICES: ''${OLD_SERVICES[*]}" - # unregister old services - for NAME in "''${!OLD_SERVICES[@]}" - do - [ -n "$NAME" ] && gitlab-runner unregister \ - --name "$NAME" && sleep 1 - done - - # make config file readable by service - chown -R --reference="$HOME" "$(dirname ${configPath})" - ''; + ]); + text = + if (cfg.configFile != null) then + '' + cp ${cfg.configFile} ${configPath} + # make config file readable by service + chown -R --reference="$HOME" "$(dirname ${configPath})" + '' + else + '' + export CONFIG_FILE=${configPath} + + mkdir -p "$(dirname ${configPath})" + touch ${configPath} + + # update global options + remarshal --if toml --of json --stringify ${configPath} \ + | jq -cM 'with_entries(select([.key] | inside(["runners"])))' \ + | jq -scM '.[0] + .[1]' - <(echo ${escapeShellArg (toJSON cfg.settings)}) \ + | remarshal --if json --of toml \ + | sponge ${configPath} + + # remove no longer existing services + gitlab-runner verify --delete + + ${toShellVar "NEEDED_SERVICES" (lib.mapAttrs (name: value: 1) hashedServices)} + + declare -A REGISTERED_SERVICES + + while IFS="," read -r name token; + do + REGISTERED_SERVICES["$name"]="$token" + done < <(gitlab-runner --log-format json list 2>&1 | grep Token | jq -r '.msg +"," + .Token') + + echo "NEEDED_SERVICES: " "''${!NEEDED_SERVICES[@]}" + echo "REGISTERED_SERVICES:" "''${!REGISTERED_SERVICES[@]}" + + # difference between current and desired state + declare -A NEW_SERVICES + for name in "''${!NEEDED_SERVICES[@]}"; do + if [ ! -v 'REGISTERED_SERVICES[$name]' ]; then + NEW_SERVICES[$name]=1 + fi + done + + declare -A OLD_SERVICES + # shellcheck disable=SC2034 + for name in "''${!REGISTERED_SERVICES[@]}"; do + if [ ! -v 'NEEDED_SERVICES[$name]' ]; then + OLD_SERVICES[$name]=1 + fi + done + + # register new services + ${concatStringsSep "\n" ( + mapAttrsToList (name: service: '' + # TODO so here we should mention NEW_SERVICES + if [ -v 'NEW_SERVICES["${name}"]' ] ; then + bash -c ${ + escapeShellArg ( + concatStringsSep " \\\n " ( + [ + "set -a && source ${ + if service.registrationConfigFile != null then + service.registrationConfigFile + else + service.authenticationTokenConfigFile + } &&" + "gitlab-runner register" + "--non-interactive" + "--name '${name}'" + "--executor ${service.executor}" + "--limit ${toString service.limit}" + "--request-concurrency ${toString service.requestConcurrency}" + ] + ++ optional ( + service.authenticationTokenConfigFile == null + ) "--maximum-timeout ${toString service.maximumTimeout}" + ++ service.registrationFlags + ++ optional (service.buildsDir != null) "--builds-dir ${service.buildsDir}" + ++ optional (service.cloneUrl != null) "--clone-url ${service.cloneUrl}" + ++ optional ( + service.preGetSourcesScript != null + ) "--pre-get-sources-script ${service.preGetSourcesScript}" + ++ optional ( + service.postGetSourcesScript != null + ) "--post-get-sources-script ${service.postGetSourcesScript}" + ++ optional (service.preBuildScript != null) "--pre-build-script ${service.preBuildScript}" + ++ optional (service.postBuildScript != null) "--post-build-script ${service.postBuildScript}" + ++ optional ( + service.authenticationTokenConfigFile == null && service.tagList != [ ] + ) "--tag-list ${concatStringsSep "," service.tagList}" + ++ optional (service.authenticationTokenConfigFile == null && service.runUntagged) "--run-untagged" + ++ optional ( + service.authenticationTokenConfigFile == null && service.protected + ) "--access-level ref_protected" + ++ optional service.debugTraceDisabled "--debug-trace-disabled" + ++ map (e: "--env ${escapeShellArg e}") ( + mapAttrsToList (name: value: "${name}=${value}") service.environmentVariables + ) + ++ optionals (hasPrefix "docker" service.executor) ( + assert ( + assertMsg ( + service.dockerImage != null + ) "dockerImage option is required for ${service.executor} executor (${name})" + ); + [ "--docker-image ${service.dockerImage}" ] + ++ optional service.dockerDisableCache "--docker-disable-cache" + ++ optional service.dockerPrivileged "--docker-privileged" + ++ map (v: "--docker-volumes ${escapeShellArg v}") service.dockerVolumes + ++ map (v: "--docker-extra-hosts ${escapeShellArg v}") service.dockerExtraHosts + ++ map (v: "--docker-allowed-images ${escapeShellArg v}") service.dockerAllowedImages + ++ map (v: "--docker-allowed-services ${escapeShellArg v}") service.dockerAllowedServices + ) + ) + ) + } && sleep 1 || exit 1 + fi + '') hashedServices + )} + + # check key is in array https://stackoverflow.com/questions/30353951/how-to-check-if-dictionary-contains-a-key-in-bash + + echo "NEW_SERVICES: ''${NEW_SERVICES[*]}" + echo "OLD_SERVICES: ''${OLD_SERVICES[*]}" + # unregister old services + for NAME in "''${!OLD_SERVICES[@]}" + do + [ -n "$NAME" ] && gitlab-runner unregister \ + --name "$NAME" && sleep 1 + done + + # make config file readable by service + chown -R --reference="$HOME" "$(dirname ${configPath})" + ''; }; startScript = pkgs.writeShellScriptBin "gitlab-runner-start" '' export CONFIG_FILE=${configPath} exec gitlab-runner run --working-directory $HOME ''; -in { +in +{ options.services.gitlab-runner = { enable = mkEnableOption "Gitlab Runner"; configFile = mkOption { @@ -334,268 +362,281 @@ in { }; } ''; - type = types.attrsOf (types.submodule { - options = { - authenticationTokenConfigFile = mkOption { - type = with types; nullOr path; - default = null; - description = '' - Absolute path to a file containing environment variables used for - gitlab-runner registrations with *runner authentication tokens*. - They replace the deprecated *runner registration tokens*, as - outlined in the [GitLab documentation]. - - A list of all supported environment variables can be found with - `gitlab-runner register --help`. - - The ones you probably want to set are: - - `CI_SERVER_URL=` - - `CI_SERVER_TOKEN=` - - ::: {.warning} - Make sure to use a quoted absolute path, - or it is going to be copied to Nix Store. - ::: - - [GitLab documentation]: https://docs.gitlab.com/17.0/ee/ci/runners/new_creation_workflow.html#estimated-time-frame-for-planned-changes - ''; - }; - registrationConfigFile = mkOption { - type = with types; nullOr path; - default = null; - description = '' - Absolute path to a file with environment variables - used for gitlab-runner registration with *runner registration - tokens*. - - A list of all supported environment variables can be found in - `gitlab-runner register --help`. - - The ones you probably want to set are: - - `CI_SERVER_URL=` - - `REGISTRATION_TOKEN=` - - Support for *runner registration tokens* is deprecated since - GitLab 16.0, has been disabled by default in GitLab 17.0 and - will be removed in GitLab 18.0, as outlined in the - [GitLab documentation]. Please consider migrating to - [runner authentication tokens] and check the documentation on - {option}`services.gitlab-runner.services..authenticationTokenConfigFile`. - - ::: {.warning} - Make sure to use a quoted absolute path, - or it is going to be copied to Nix Store. - ::: - - [GitLab documentation]: https://docs.gitlab.com/17.0/ee/ci/runners/new_creation_workflow.html#estimated-time-frame-for-planned-changes - [runner authentication tokens]: https://docs.gitlab.com/17.0/ee/ci/runners/new_creation_workflow.html#the-new-runner-registration-workflow - ''; - }; - registrationFlags = mkOption { - type = types.listOf types.str; - default = [ ]; - example = [ "--docker-helper-image my/gitlab-runner-helper" ]; - description = '' - Extra command-line flags passed to - `gitlab-runner register`. - Execute `gitlab-runner register --help` - for a list of supported flags. - ''; - }; - environmentVariables = mkOption { - type = types.attrsOf types.str; - default = { }; - example = { NAME = "value"; }; - description = '' - Custom environment variables injected to build environment. - For secrets you can use {option}`registrationConfigFile` - with `RUNNER_ENV` variable set. - ''; - }; - description = mkOption { - type = types.nullOr types.str; - default = null; - description = '' - Name/description of the runner. - ''; - }; - executor = mkOption { - type = types.str; - default = "docker"; - description = '' - Select executor, eg. shell, docker, etc. - See [runner documentation](https://docs.gitlab.com/runner/executors/README.html) for more information. - ''; - }; - buildsDir = mkOption { - type = types.nullOr types.path; - default = null; - example = "/var/lib/gitlab-runner/builds"; - description = '' - Absolute path to a directory where builds will be stored - in context of selected executor (Locally, Docker, SSH). - ''; - }; - cloneUrl = mkOption { - type = types.nullOr types.str; - default = null; - example = "http://gitlab.example.local"; - description = '' - Overwrite the URL for the GitLab instance. Used if the Runner can’t connect to GitLab on the URL GitLab exposes itself. - ''; - }; - dockerImage = mkOption { - type = types.nullOr types.str; - default = null; - description = '' - Docker image to be used. - ''; - }; - dockerVolumes = mkOption { - type = types.listOf types.str; - default = [ ]; - example = [ "/var/run/docker.sock:/var/run/docker.sock" ]; - description = '' - Bind-mount a volume and create it - if it doesn't exist prior to mounting. - ''; - }; - dockerDisableCache = mkOption { - type = types.bool; - default = false; - description = '' - Disable all container caching. - ''; - }; - dockerPrivileged = mkOption { - type = types.bool; - default = false; - description = '' - Give extended privileges to container. - ''; - }; - dockerExtraHosts = mkOption { - type = types.listOf types.str; - default = [ ]; - example = [ "other-host:127.0.0.1" ]; - description = '' - Add a custom host-to-IP mapping. - ''; - }; - dockerAllowedImages = mkOption { - type = types.listOf types.str; - default = [ ]; - example = [ "ruby:*" "python:*" "php:*" "my.registry.tld:5000/*:*" ]; - description = '' - Whitelist allowed images. - ''; - }; - dockerAllowedServices = mkOption { - type = types.listOf types.str; - default = [ ]; - example = [ "postgres:9" "redis:*" "mysql:*" ]; - description = '' - Whitelist allowed services. - ''; - }; - preGetSourcesScript = mkOption { - type = types.nullOr (types.either types.str types.path); - default = null; - description = '' - Runner-specific command script executed before code is pulled. - ''; - }; - postGetSourcesScript = mkOption { - type = types.nullOr (types.either types.str types.path); - default = null; - description = '' - Runner-specific command script executed after code is pulled. - ''; - }; - preBuildScript = mkOption { - type = types.nullOr (types.either types.str types.path); - default = null; - description = '' - Runner-specific command script executed after code is pulled, - just before build executes. - ''; - }; - postBuildScript = mkOption { - type = types.nullOr (types.either types.str types.path); - default = null; - description = '' - Runner-specific command script executed after code is pulled - and just after build executes. - ''; - }; - tagList = mkOption { - type = types.listOf types.str; - default = [ ]; - description = '' - Tag list. - - This option has no effect for runners registered with an runner - authentication tokens and will be ignored. - ''; - }; - runUntagged = mkOption { - type = types.bool; - default = false; - description = '' - Register to run untagged builds; defaults to - `true` when {option}`tagList` is empty. - - This option has no effect for runners registered with an runner - authentication tokens and will be ignored. - ''; - }; - limit = mkOption { - type = types.int; - default = 0; - description = '' - Limit how many jobs can be handled concurrently by this service. - 0 (default) simply means don't limit. - ''; - }; - requestConcurrency = mkOption { - type = types.int; - default = 0; - description = '' - Limit number of concurrent requests for new jobs from GitLab. - ''; - }; - maximumTimeout = mkOption { - type = types.int; - default = 0; - description = '' - What is the maximum timeout (in seconds) that will be set for - job when using this Runner. 0 (default) simply means don't limit. - - This option has no effect for runners registered with an runner - authentication tokens and will be ignored. - ''; - }; - protected = mkOption { - type = types.bool; - default = false; - description = '' - When set to true Runner will only run on pipelines - triggered on protected branches. - - This option has no effect for runners registered with an runner - authentication tokens and will be ignored. - ''; - }; - debugTraceDisabled = mkOption { - type = types.bool; - default = false; - description = '' - When set to true Runner will disable the possibility of - using the `CI_DEBUG_TRACE` feature. - ''; + type = types.attrsOf ( + types.submodule { + options = { + authenticationTokenConfigFile = mkOption { + type = with types; nullOr path; + default = null; + description = '' + Absolute path to a file containing environment variables used for + gitlab-runner registrations with *runner authentication tokens*. + They replace the deprecated *runner registration tokens*, as + outlined in the [GitLab documentation]. + + A list of all supported environment variables can be found with + `gitlab-runner register --help`. + + The ones you probably want to set are: + - `CI_SERVER_URL=` + - `CI_SERVER_TOKEN=` + + ::: {.warning} + Make sure to use a quoted absolute path, + or it is going to be copied to Nix Store. + ::: + + [GitLab documentation]: https://docs.gitlab.com/17.0/ee/ci/runners/new_creation_workflow.html#estimated-time-frame-for-planned-changes + ''; + }; + registrationConfigFile = mkOption { + type = with types; nullOr path; + default = null; + description = '' + Absolute path to a file with environment variables + used for gitlab-runner registration with *runner registration + tokens*. + + A list of all supported environment variables can be found in + `gitlab-runner register --help`. + + The ones you probably want to set are: + - `CI_SERVER_URL=` + - `REGISTRATION_TOKEN=` + + Support for *runner registration tokens* is deprecated since + GitLab 16.0, has been disabled by default in GitLab 17.0 and + will be removed in GitLab 18.0, as outlined in the + [GitLab documentation]. Please consider migrating to + [runner authentication tokens] and check the documentation on + {option}`services.gitlab-runner.services..authenticationTokenConfigFile`. + + ::: {.warning} + Make sure to use a quoted absolute path, + or it is going to be copied to Nix Store. + ::: + + [GitLab documentation]: https://docs.gitlab.com/17.0/ee/ci/runners/new_creation_workflow.html#estimated-time-frame-for-planned-changes + [runner authentication tokens]: https://docs.gitlab.com/17.0/ee/ci/runners/new_creation_workflow.html#the-new-runner-registration-workflow + ''; + }; + registrationFlags = mkOption { + type = types.listOf types.str; + default = [ ]; + example = [ "--docker-helper-image my/gitlab-runner-helper" ]; + description = '' + Extra command-line flags passed to + `gitlab-runner register`. + Execute `gitlab-runner register --help` + for a list of supported flags. + ''; + }; + environmentVariables = mkOption { + type = types.attrsOf types.str; + default = { }; + example = { + NAME = "value"; + }; + description = '' + Custom environment variables injected to build environment. + For secrets you can use {option}`registrationConfigFile` + with `RUNNER_ENV` variable set. + ''; + }; + description = mkOption { + type = types.nullOr types.str; + default = null; + description = '' + Name/description of the runner. + ''; + }; + executor = mkOption { + type = types.str; + default = "docker"; + description = '' + Select executor, eg. shell, docker, etc. + See [runner documentation](https://docs.gitlab.com/runner/executors/README.html) for more information. + ''; + }; + buildsDir = mkOption { + type = types.nullOr types.path; + default = null; + example = "/var/lib/gitlab-runner/builds"; + description = '' + Absolute path to a directory where builds will be stored + in context of selected executor (Locally, Docker, SSH). + ''; + }; + cloneUrl = mkOption { + type = types.nullOr types.str; + default = null; + example = "http://gitlab.example.local"; + description = '' + Overwrite the URL for the GitLab instance. Used if the Runner can’t connect to GitLab on the URL GitLab exposes itself. + ''; + }; + dockerImage = mkOption { + type = types.nullOr types.str; + default = null; + description = '' + Docker image to be used. + ''; + }; + dockerVolumes = mkOption { + type = types.listOf types.str; + default = [ ]; + example = [ "/var/run/docker.sock:/var/run/docker.sock" ]; + description = '' + Bind-mount a volume and create it + if it doesn't exist prior to mounting. + ''; + }; + dockerDisableCache = mkOption { + type = types.bool; + default = false; + description = '' + Disable all container caching. + ''; + }; + dockerPrivileged = mkOption { + type = types.bool; + default = false; + description = '' + Give extended privileges to container. + ''; + }; + dockerExtraHosts = mkOption { + type = types.listOf types.str; + default = [ ]; + example = [ "other-host:127.0.0.1" ]; + description = '' + Add a custom host-to-IP mapping. + ''; + }; + dockerAllowedImages = mkOption { + type = types.listOf types.str; + default = [ ]; + example = [ + "ruby:*" + "python:*" + "php:*" + "my.registry.tld:5000/*:*" + ]; + description = '' + Whitelist allowed images. + ''; + }; + dockerAllowedServices = mkOption { + type = types.listOf types.str; + default = [ ]; + example = [ + "postgres:9" + "redis:*" + "mysql:*" + ]; + description = '' + Whitelist allowed services. + ''; + }; + preGetSourcesScript = mkOption { + type = types.nullOr (types.either types.str types.path); + default = null; + description = '' + Runner-specific command script executed before code is pulled. + ''; + }; + postGetSourcesScript = mkOption { + type = types.nullOr (types.either types.str types.path); + default = null; + description = '' + Runner-specific command script executed after code is pulled. + ''; + }; + preBuildScript = mkOption { + type = types.nullOr (types.either types.str types.path); + default = null; + description = '' + Runner-specific command script executed after code is pulled, + just before build executes. + ''; + }; + postBuildScript = mkOption { + type = types.nullOr (types.either types.str types.path); + default = null; + description = '' + Runner-specific command script executed after code is pulled + and just after build executes. + ''; + }; + tagList = mkOption { + type = types.listOf types.str; + default = [ ]; + description = '' + Tag list. + + This option has no effect for runners registered with an runner + authentication tokens and will be ignored. + ''; + }; + runUntagged = mkOption { + type = types.bool; + default = false; + description = '' + Register to run untagged builds; defaults to + `true` when {option}`tagList` is empty. + + This option has no effect for runners registered with an runner + authentication tokens and will be ignored. + ''; + }; + limit = mkOption { + type = types.int; + default = 0; + description = '' + Limit how many jobs can be handled concurrently by this service. + 0 (default) simply means don't limit. + ''; + }; + requestConcurrency = mkOption { + type = types.int; + default = 0; + description = '' + Limit number of concurrent requests for new jobs from GitLab. + ''; + }; + maximumTimeout = mkOption { + type = types.int; + default = 0; + description = '' + What is the maximum timeout (in seconds) that will be set for + job when using this Runner. 0 (default) simply means don't limit. + + This option has no effect for runners registered with an runner + authentication tokens and will be ignored. + ''; + }; + protected = mkOption { + type = types.bool; + default = false; + description = '' + When set to true Runner will only run on pipelines + triggered on protected branches. + + This option has no effect for runners registered with an runner + authentication tokens and will be ignored. + ''; + }; + debugTraceDisabled = mkOption { + type = types.bool; + default = false; + description = '' + When set to true Runner will disable the possibility of + using the `CI_DEBUG_TRACE` feature. + ''; + }; }; - }; - }); + } + ); }; clear-docker-cache = { enable = mkOption { @@ -636,78 +677,94 @@ in { }; }; config = mkIf cfg.enable { - assertions = - mapAttrsToList (name: serviceConfig: { - assertion = serviceConfig.registrationConfigFile == null || serviceConfig.authenticationTokenConfigFile == null; - message = "`services.gitlab-runner.${name}.registrationConfigFile` and `services.gitlab-runner.services.${name}.authenticationTokenConfigFile` are mutually exclusive."; - }) cfg.services; + assertions = mapAttrsToList (name: serviceConfig: { + assertion = + serviceConfig.registrationConfigFile == null || serviceConfig.authenticationTokenConfigFile == null; + message = "`services.gitlab-runner.${name}.registrationConfigFile` and `services.gitlab-runner.services.${name}.authenticationTokenConfigFile` are mutually exclusive."; + }) cfg.services; warnings = - mapAttrsToList - (name: serviceConfig: "services.gitlab-runner.services.${name}.`registrationConfigFile` points to a file in Nix Store. You should use quoted absolute path to prevent this.") - (filterAttrs (name: serviceConfig: isStorePath serviceConfig.registrationConfigFile) cfg.services) - ++ mapAttrsToList - (name: serviceConfig: "services.gitlab-runner.services.${name}.`authenticationTokenConfigFile` points to a file in Nix Store. You should use quoted absolute path to prevent this.") - (filterAttrs (name: serviceConfig: isStorePath serviceConfig.authenticationTokenConfigFile) cfg.services) - ++ mapAttrsToList - (name: serviceConfig: '' - Runner registration tokens have been deprecated and disabled by default in GitLab >= 17.0. - Consider migrating to runner authentication tokens by setting `services.gitlab-runner.services.${name}.authenticationTokenConfigFile`. - https://docs.gitlab.com/17.0/ee/ci/runners/new_creation_workflow.html'' - ) - ( - filterAttrs (name: serviceConfig: - serviceConfig.authenticationTokenConfigFile == null - ) cfg.services - ) - ++ mapAttrsToList - (name: serviceConfig: '' - `services.gitlab-runner.services.${name}.protected` with runner authentication tokens has no effect and will be ignored. Please remove it from your configuration.'' - ) - ( - filterAttrs (name: serviceConfig: - serviceConfig.authenticationTokenConfigFile != null && serviceConfig.protected == true - ) cfg.services - ) - ++ mapAttrsToList - (name: serviceConfig: '' - `services.gitlab-runner.services.${name}.runUntagged` with runner authentication tokens has no effect and will be ignored. Please remove it from your configuration.'' - ) - ( - filterAttrs (name: serviceConfig: - serviceConfig.authenticationTokenConfigFile != null && serviceConfig.runUntagged == true - ) cfg.services - ) - ++ mapAttrsToList - (name: v: '' - `services.gitlab-runner.services.${name}.maximumTimeout` with runner authentication tokens has no effect and will be ignored. Please remove it from your configuration.'' - ) - ( - filterAttrs (name: serviceConfig: - serviceConfig.authenticationTokenConfigFile != null && serviceConfig.maximumTimeout != 0 - ) cfg.services - ) - ++ mapAttrsToList - (name: v: '' - `services.gitlab-runner.services.${name}.tagList` with runner authentication tokens has no effect and will be ignored. Please remove it from your configuration.'' - ) - ( - filterAttrs (serviceName: serviceConfig: - serviceConfig.authenticationTokenConfigFile != null && serviceConfig.tagList != [ ] - ) cfg.services - ) - ; + mapAttrsToList ( + name: serviceConfig: + "services.gitlab-runner.services.${name}.`registrationConfigFile` points to a file in Nix Store. You should use quoted absolute path to prevent this." + ) (filterAttrs (name: serviceConfig: isStorePath serviceConfig.registrationConfigFile) cfg.services) + ++ + mapAttrsToList + ( + name: serviceConfig: + "services.gitlab-runner.services.${name}.`authenticationTokenConfigFile` points to a file in Nix Store. You should use quoted absolute path to prevent this." + ) + ( + filterAttrs ( + name: serviceConfig: isStorePath serviceConfig.authenticationTokenConfigFile + ) cfg.services + ) + ++ + mapAttrsToList + (name: serviceConfig: '' + Runner registration tokens have been deprecated and disabled by default in GitLab >= 17.0. + Consider migrating to runner authentication tokens by setting `services.gitlab-runner.services.${name}.authenticationTokenConfigFile`. + https://docs.gitlab.com/17.0/ee/ci/runners/new_creation_workflow.html'') + ( + filterAttrs (name: serviceConfig: serviceConfig.authenticationTokenConfigFile == null) cfg.services + ) + ++ + mapAttrsToList + ( + name: serviceConfig: + ''`services.gitlab-runner.services.${name}.protected` with runner authentication tokens has no effect and will be ignored. Please remove it from your configuration.'' + ) + ( + filterAttrs ( + name: serviceConfig: + serviceConfig.authenticationTokenConfigFile != null && serviceConfig.protected == true + ) cfg.services + ) + ++ + mapAttrsToList + ( + name: serviceConfig: + ''`services.gitlab-runner.services.${name}.runUntagged` with runner authentication tokens has no effect and will be ignored. Please remove it from your configuration.'' + ) + ( + filterAttrs ( + name: serviceConfig: + serviceConfig.authenticationTokenConfigFile != null && serviceConfig.runUntagged == true + ) cfg.services + ) + ++ + mapAttrsToList + ( + name: v: + ''`services.gitlab-runner.services.${name}.maximumTimeout` with runner authentication tokens has no effect and will be ignored. Please remove it from your configuration.'' + ) + ( + filterAttrs ( + name: serviceConfig: + serviceConfig.authenticationTokenConfigFile != null && serviceConfig.maximumTimeout != 0 + ) cfg.services + ) + ++ + mapAttrsToList + ( + name: v: + ''`services.gitlab-runner.services.${name}.tagList` with runner authentication tokens has no effect and will be ignored. Please remove it from your configuration.'' + ) + ( + filterAttrs ( + serviceName: serviceConfig: + serviceConfig.authenticationTokenConfigFile != null && serviceConfig.tagList != [ ] + ) cfg.services + ); environment.systemPackages = [ cfg.package ]; systemd.services.gitlab-runner = { description = "Gitlab Runner"; documentation = [ "https://docs.gitlab.com/runner/" ]; - after = [ "network.target" ] - ++ optional hasDocker "docker.service" - ++ optional hasPodman "podman.service"; + after = + [ "network.target" ] ++ optional hasDocker "docker.service" ++ optional hasPodman "podman.service"; - requires = optional hasDocker "docker.service" - ++ optional hasPodman "podman.service"; + requires = optional hasDocker "docker.service" ++ optional hasPodman "podman.service"; wantedBy = [ "multi-user.target" ]; environment = config.networking.proxy.envVars // { HOME = "/var/lib/gitlab-runner"; @@ -726,58 +783,96 @@ in { ++ cfg.extraPackages; reloadIfChanged = true; - serviceConfig = { - # Set `DynamicUser` under `systemd.services.gitlab-runner.serviceConfig` - # to `lib.mkForce false` in your configuration to run this service as root. - # You can also set `User` and `Group` options to run this service as desired user. - # Make sure to restart service or changes won't apply. - DynamicUser = true; - StateDirectory = "gitlab-runner"; - SupplementaryGroups = optional hasDocker "docker" - ++ optional hasPodman "podman"; - ExecStartPre = "!${configureScript}/bin/gitlab-runner-configure"; - ExecStart = "${startScript}/bin/gitlab-runner-start"; - ExecReload = "!${configureScript}/bin/gitlab-runner-configure"; - } // optionalAttrs cfg.gracefulTermination { - TimeoutStopSec = "${cfg.gracefulTimeout}"; - KillSignal = "SIGQUIT"; - KillMode = "process"; - }; + serviceConfig = + { + # Set `DynamicUser` under `systemd.services.gitlab-runner.serviceConfig` + # to `lib.mkForce false` in your configuration to run this service as root. + # You can also set `User` and `Group` options to run this service as desired user. + # Make sure to restart service or changes won't apply. + DynamicUser = true; + StateDirectory = "gitlab-runner"; + SupplementaryGroups = optional hasDocker "docker" ++ optional hasPodman "podman"; + ExecStartPre = "!${configureScript}/bin/gitlab-runner-configure"; + ExecStart = "${startScript}/bin/gitlab-runner-start"; + ExecReload = "!${configureScript}/bin/gitlab-runner-configure"; + } + // optionalAttrs cfg.gracefulTermination { + TimeoutStopSec = "${cfg.gracefulTimeout}"; + KillSignal = "SIGQUIT"; + KillMode = "process"; + }; }; # Enable periodic clear-docker-cache script - systemd.services.gitlab-runner-clear-docker-cache = mkIf (cfg.clear-docker-cache.enable && (any (s: s.executor == "docker") (attrValues cfg.services))) { - description = "Prune gitlab-runner docker resources"; - restartIfChanged = false; - unitConfig.X-StopOnRemoval = false; + systemd.services.gitlab-runner-clear-docker-cache = + mkIf (cfg.clear-docker-cache.enable && (any (s: s.executor == "docker") (attrValues cfg.services))) + { + description = "Prune gitlab-runner docker resources"; + restartIfChanged = false; + unitConfig.X-StopOnRemoval = false; - serviceConfig.Type = "oneshot"; + serviceConfig.Type = "oneshot"; - path = [ cfg.clear-docker-cache.package pkgs.gawk ]; + path = [ + cfg.clear-docker-cache.package + pkgs.gawk + ]; - script = '' - ${pkgs.gitlab-runner}/bin/clear-docker-cache ${toString cfg.clear-docker-cache.flags} - ''; + script = '' + ${pkgs.gitlab-runner}/bin/clear-docker-cache ${toString cfg.clear-docker-cache.flags} + ''; - startAt = cfg.clear-docker-cache.dates; - }; + startAt = cfg.clear-docker-cache.dates; + }; # Enable docker if `docker` executor is used in any service - virtualisation.docker.enable = mkIf ( - any (s: s.executor == "docker") (attrValues cfg.services) - ) (mkDefault true); + virtualisation.docker.enable = mkIf (any (s: s.executor == "docker") (attrValues cfg.services)) ( + mkDefault true + ); }; imports = [ - (mkRenamedOptionModule [ "services" "gitlab-runner" "packages" ] [ "services" "gitlab-runner" "extraPackages" ] ) - (mkRemovedOptionModule [ "services" "gitlab-runner" "configOptions" ] "Use services.gitlab-runner.services option instead" ) - (mkRemovedOptionModule [ "services" "gitlab-runner" "workDir" ] "You should move contents of workDir (if any) to /var/lib/gitlab-runner" ) - - (mkRenamedOptionModule [ "services" "gitlab-runner" "checkInterval" ] [ "services" "gitlab-runner" "settings" "check_interval" ] ) - (mkRenamedOptionModule [ "services" "gitlab-runner" "concurrent" ] [ "services" "gitlab-runner" "settings" "concurrent" ] ) - (mkRenamedOptionModule [ "services" "gitlab-runner" "sentryDSN" ] [ "services" "gitlab-runner" "settings" "sentry_dsn" ] ) - (mkRenamedOptionModule [ "services" "gitlab-runner" "prometheusListenAddress" ] [ "services" "gitlab-runner" "settings" "listen_address" ] ) - - (mkRenamedOptionModule [ "services" "gitlab-runner" "sessionServer" "listenAddress" ] [ "services" "gitlab-runner" "settings" "session_server" "listen_address" ] ) - (mkRenamedOptionModule [ "services" "gitlab-runner" "sessionServer" "advertiseAddress" ] [ "services" "gitlab-runner" "settings" "session_server" "advertise_address" ] ) - (mkRenamedOptionModule [ "services" "gitlab-runner" "sessionServer" "sessionTimeout" ] [ "services" "gitlab-runner" "settings" "session_server" "session_timeout" ] ) + (mkRenamedOptionModule + [ "services" "gitlab-runner" "packages" ] + [ "services" "gitlab-runner" "extraPackages" ] + ) + (mkRemovedOptionModule [ + "services" + "gitlab-runner" + "configOptions" + ] "Use services.gitlab-runner.services option instead") + (mkRemovedOptionModule [ + "services" + "gitlab-runner" + "workDir" + ] "You should move contents of workDir (if any) to /var/lib/gitlab-runner") + + (mkRenamedOptionModule + [ "services" "gitlab-runner" "checkInterval" ] + [ "services" "gitlab-runner" "settings" "check_interval" ] + ) + (mkRenamedOptionModule + [ "services" "gitlab-runner" "concurrent" ] + [ "services" "gitlab-runner" "settings" "concurrent" ] + ) + (mkRenamedOptionModule + [ "services" "gitlab-runner" "sentryDSN" ] + [ "services" "gitlab-runner" "settings" "sentry_dsn" ] + ) + (mkRenamedOptionModule + [ "services" "gitlab-runner" "prometheusListenAddress" ] + [ "services" "gitlab-runner" "settings" "listen_address" ] + ) + + (mkRenamedOptionModule + [ "services" "gitlab-runner" "sessionServer" "listenAddress" ] + [ "services" "gitlab-runner" "settings" "session_server" "listen_address" ] + ) + (mkRenamedOptionModule + [ "services" "gitlab-runner" "sessionServer" "advertiseAddress" ] + [ "services" "gitlab-runner" "settings" "session_server" "advertise_address" ] + ) + (mkRenamedOptionModule + [ "services" "gitlab-runner" "sessionServer" "sessionTimeout" ] + [ "services" "gitlab-runner" "settings" "session_server" "session_timeout" ] + ) ]; meta.maintainers = teams.gitlab.members; diff --git a/nixos/modules/services/continuous-integration/gocd-agent/default.nix b/nixos/modules/services/continuous-integration/gocd-agent/default.nix index 0846c466e22a4b..607ac0e6ce9be7 100644 --- a/nixos/modules/services/continuous-integration/gocd-agent/default.nix +++ b/nixos/modules/services/continuous-integration/gocd-agent/default.nix @@ -1,8 +1,15 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.gocd-agent; opt = options.services.gocd-agent; -in { +in +{ options = { services.gocd-agent = { enable = lib.mkEnableOption "gocd-agent"; @@ -27,14 +34,23 @@ in { extraGroups = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "wheel" "docker" ]; + example = [ + "wheel" + "docker" + ]; description = '' List of extra groups that the "gocd-agent" user should be a part of. ''; }; packages = lib.mkOption { - default = [ pkgs.stdenv pkgs.jre pkgs.git config.programs.ssh.package pkgs.nix ]; + default = [ + pkgs.stdenv + pkgs.jre + pkgs.git + config.programs.ssh.package + pkgs.nix + ]; defaultText = lib.literalExpression "[ pkgs.stdenv pkgs.jre pkgs.git config.programs.ssh.package pkgs.nix ]"; type = lib.types.listOf lib.types.package; description = '' @@ -167,19 +183,19 @@ in { environment = let - selectedSessionVars = - lib.filterAttrs (n: v: builtins.elem n [ "NIX_PATH" ]) - config.environment.sessionVariables; + selectedSessionVars = lib.filterAttrs ( + n: v: builtins.elem n [ "NIX_PATH" ] + ) config.environment.sessionVariables; in - selectedSessionVars // - { - NIX_REMOTE = "daemon"; - AGENT_WORK_DIR = cfg.workDir; - AGENT_STARTUP_ARGS = ''${lib.concatStringsSep " " cfg.startupOptions}''; - LOG_DIR = cfg.workDir; - LOG_FILE = "${cfg.workDir}/go-agent-start.log"; - } // - cfg.environment; + selectedSessionVars + // { + NIX_REMOTE = "daemon"; + AGENT_WORK_DIR = cfg.workDir; + AGENT_STARTUP_ARGS = ''${lib.concatStringsSep " " cfg.startupOptions}''; + LOG_DIR = cfg.workDir; + LOG_FILE = "${cfg.workDir}/go-agent-start.log"; + } + // cfg.environment; path = cfg.packages; diff --git a/nixos/modules/services/continuous-integration/gocd-server/default.nix b/nixos/modules/services/continuous-integration/gocd-server/default.nix index a1fb740c269d59..0997cb394cbe46 100644 --- a/nixos/modules/services/continuous-integration/gocd-server/default.nix +++ b/nixos/modules/services/continuous-integration/gocd-server/default.nix @@ -1,11 +1,18 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with lib; let cfg = config.services.gocd-server; opt = options.services.gocd-server; -in { +in +{ options = { services.gocd-server = { enable = mkEnableOption "gocd-server"; @@ -29,7 +36,10 @@ in { extraGroups = mkOption { default = [ ]; type = types.listOf types.str; - example = [ "wheel" "docker" ]; + example = [ + "wheel" + "docker" + ]; description = '' List of extra groups that the "gocd-server" user should be a part of. ''; @@ -69,7 +79,13 @@ in { }; packages = mkOption { - default = [ pkgs.stdenv pkgs.jre pkgs.git config.programs.ssh.package pkgs.nix ]; + default = [ + pkgs.stdenv + pkgs.jre + pkgs.git + config.programs.ssh.package + pkgs.nix + ]; defaultText = literalExpression "[ pkgs.stdenv pkgs.jre pkgs.git config.programs.ssh.package pkgs.nix ]"; type = types.listOf types.package; description = '' @@ -188,14 +204,15 @@ in { environment = let - selectedSessionVars = - lib.filterAttrs (n: v: builtins.elem n [ "NIX_PATH" ]) - config.environment.sessionVariables; + selectedSessionVars = lib.filterAttrs ( + n: v: builtins.elem n [ "NIX_PATH" ] + ) config.environment.sessionVariables; in - selectedSessionVars // - { NIX_REMOTE = "daemon"; - } // - cfg.environment; + selectedSessionVars + // { + NIX_REMOTE = "daemon"; + } + // cfg.environment; path = cfg.packages; diff --git a/nixos/modules/services/continuous-integration/hercules-ci-agent/common.nix b/nixos/modules/services/continuous-integration/hercules-ci-agent/common.nix index a0d4a78a5f345e..136ed5102e1a8a 100644 --- a/nixos/modules/services/continuous-integration/hercules-ci-agent/common.nix +++ b/nixos/modules/services/continuous-integration/hercules-ci-agent/common.nix @@ -1,12 +1,16 @@ /* - This file is for options that NixOS and nix-darwin have in common. Platform-specific code is in the respective default.nix files. - */ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let inherit (lib) filterAttrs @@ -26,10 +30,21 @@ let in { imports = [ - (mkRenamedOptionModule [ "services" "hercules-ci-agent" "extraOptions" ] [ "services" "hercules-ci-agent" "settings" ]) - (mkRenamedOptionModule [ "services" "hercules-ci-agent" "baseDirectory" ] [ "services" "hercules-ci-agent" "settings" "baseDirectory" ]) - (mkRenamedOptionModule [ "services" "hercules-ci-agent" "concurrentTasks" ] [ "services" "hercules-ci-agent" "settings" "concurrentTasks" ]) - (mkRemovedOptionModule [ "services" "hercules-ci-agent" "patchNix" ] "Nix versions packaged in this version of Nixpkgs don't need a patched nix-daemon to work correctly in Hercules CI Agent clusters.") + (mkRenamedOptionModule + [ "services" "hercules-ci-agent" "extraOptions" ] + [ "services" "hercules-ci-agent" "settings" ] + ) + (mkRenamedOptionModule + [ "services" "hercules-ci-agent" "baseDirectory" ] + [ "services" "hercules-ci-agent" "settings" "baseDirectory" ] + ) + (mkRenamedOptionModule + [ "services" "hercules-ci-agent" "concurrentTasks" ] + [ "services" "hercules-ci-agent" "settings" "concurrentTasks" ] + ) + (mkRemovedOptionModule [ "services" "hercules-ci-agent" "patchNix" ] + "Nix versions packaged in this version of Nixpkgs don't need a patched nix-daemon to work correctly in Hercules CI Agent clusters." + ) ]; options.services.hercules-ci-agent = { @@ -78,8 +93,8 @@ in assertions = [ { assertion = - (cfg.settings.nixUserIsTrusted or false) -> - builtins.match ".*(^|\n)[ \t]*trusted-users[ \t]*=.*" config.nix.extraOptions == null; + (cfg.settings.nixUserIsTrusted or false) + -> builtins.match ".*(^|\n)[ \t]*trusted-users[ \t]*=.*" config.nix.extraOptions == null; message = '' hercules-ci-agent: Please do not set `trusted-users` in `nix.extraOptions`. @@ -100,8 +115,7 @@ in narinfo-cache-negative-ttl = 0 ''; services.hercules-ci-agent = { - tomlFile = - format.generate "hercules-ci-agent.toml" cfg.settings; + tomlFile = format.generate "hercules-ci-agent.toml" cfg.settings; settings.config._module.args = { packageOption = options.services.hercules-ci-agent.package; inherit pkgs; diff --git a/nixos/modules/services/continuous-integration/hercules-ci-agent/default.nix b/nixos/modules/services/continuous-integration/hercules-ci-agent/default.nix index ad26b5316ddefd..20c5deb02e8ec2 100644 --- a/nixos/modules/services/continuous-integration/hercules-ci-agent/default.nix +++ b/nixos/modules/services/continuous-integration/hercules-ci-agent/default.nix @@ -1,12 +1,15 @@ /* - This file is for NixOS-specific options and configs. Code that is shared with nix-darwin goes in common.nix. - */ -{ pkgs, config, lib, ... }: +{ + pkgs, + config, + lib, + ... +}: let inherit (lib) mkIf mkDefault; @@ -19,7 +22,10 @@ in { imports = [ ./common.nix - (lib.mkRenamedOptionModule [ "services" "hercules-ci-agent" "user" ] [ "systemd" "services" "hercules-ci-agent" "serviceConfig" "User" ]) + (lib.mkRenamedOptionModule + [ "services" "hercules-ci-agent" "user" ] + [ "systemd" "services" "hercules-ci-agent" "serviceConfig" "User" ] + ) ]; config = mkIf cfg.enable { @@ -53,7 +59,10 @@ in wantedBy = [ "hercules-ci-agent.service" ]; pathConfig = { Unit = "hercules-ci-agent-restarter.service"; - PathChanged = [ cfg.settings.clusterJoinTokenPath cfg.settings.binaryCachesPath ]; + PathChanged = [ + cfg.settings.clusterJoinTokenPath + cfg.settings.binaryCachesPath + ]; }; }; systemd.services.hercules-ci-agent-restarter = { diff --git a/nixos/modules/services/continuous-integration/hercules-ci-agent/settings.nix b/nixos/modules/services/continuous-integration/hercules-ci-agent/settings.nix index e6e73090d4be66..a2e2f5d13d68ea 100644 --- a/nixos/modules/services/continuous-integration/hercules-ci-agent/settings.nix +++ b/nixos/modules/services/continuous-integration/hercules-ci-agent/settings.nix @@ -9,144 +9,152 @@ let format = pkgs.formats.toml { }; - settingsModule = { config, packageOption, pkgs, ... }: { - freeformType = format.type; - options = { - apiBaseUrl = mkOption { - description = '' - API base URL that the agent will connect to. - - When using Hercules CI Enterprise, set this to the URL where your - Hercules CI server is reachable. - ''; - type = types.str; - default = "https://hercules-ci.com"; + settingsModule = + { + config, + packageOption, + pkgs, + ... + }: + { + freeformType = format.type; + options = { + apiBaseUrl = mkOption { + description = '' + API base URL that the agent will connect to. + + When using Hercules CI Enterprise, set this to the URL where your + Hercules CI server is reachable. + ''; + type = types.str; + default = "https://hercules-ci.com"; + }; + baseDirectory = mkOption { + type = types.path; + default = "/var/lib/hercules-ci-agent"; + description = '' + State directory (secrets, work directory, etc) for agent + ''; + }; + concurrentTasks = mkOption { + description = '' + Number of tasks to perform simultaneously. + + A task is a single derivation build, an evaluation or an effect run. + At minimum, you need 2 concurrent tasks for `x86_64-linux` + in your cluster, to allow for import from derivation. + + `concurrentTasks` can be around the CPU core count or lower if memory is + the bottleneck. + + The optimal value depends on the resource consumption characteristics of your workload, + including memory usage and in-task parallelism. This is typically determined empirically. + + When scaling, it is generally better to have a double-size machine than two machines, + because each split of resources causes inefficiencies; particularly with regards + to build latency because of extra downloads. + ''; + type = types.either types.ints.positive (types.enum [ "auto" ]); + default = "auto"; + defaultText = lib.literalMD '' + `"auto"`, meaning equal to the number of CPU cores. + ''; + }; + labels = mkOption { + description = '' + A key-value map of user data. + + This data will be available to organization members in the dashboard and API. + + The values can be of any TOML type that corresponds to a JSON type, but arrays + can not contain tables/objects due to limitations of the TOML library. Values + involving arrays of non-primitive types may not be representable currently. + ''; + type = format.type; + defaultText = literalExpression '' + { + agent.source = "..."; # One of "nixpkgs", "flake", "override" + lib.version = "..."; + pkgs.version = "..."; + } + ''; + }; + workDirectory = mkOption { + description = '' + The directory in which temporary subdirectories are created for task state. This includes sources for Nix evaluation. + ''; + type = types.path; + default = config.baseDirectory + "/work"; + defaultText = literalExpression ''baseDirectory + "/work"''; + }; + staticSecretsDirectory = mkOption { + description = '' + This is the default directory to look for statically configured secrets like `cluster-join-token.key`. + + See also `clusterJoinTokenPath` and `binaryCachesPath` for fine-grained configuration. + ''; + type = types.path; + default = config.baseDirectory + "/secrets"; + defaultText = literalExpression ''baseDirectory + "/secrets"''; + }; + clusterJoinTokenPath = mkOption { + description = '' + Location of the cluster-join-token.key file. + + You can retrieve the contents of the file when creating a new agent via + . + + As this value is confidential, it should not be in the store, but + installed using other means, such as agenix, NixOps + `deployment.keys`, or manual installation. + + The contents of the file are used for authentication between the agent and the API. + ''; + type = types.path; + default = config.staticSecretsDirectory + "/cluster-join-token.key"; + defaultText = literalExpression ''staticSecretsDirectory + "/cluster-join-token.key"''; + }; + binaryCachesPath = mkOption { + description = '' + Path to a JSON file containing binary cache secret keys. + + As these values are confidential, they should not be in the store, but + copied over using other means, such as agenix, NixOps + `deployment.keys`, or manual installation. + + The format is described on . + ''; + type = types.path; + default = config.staticSecretsDirectory + "/binary-caches.json"; + defaultText = literalExpression ''staticSecretsDirectory + "/binary-caches.json"''; + }; + secretsJsonPath = mkOption { + description = '' + Path to a JSON file containing secrets for effects. + + As these values are confidential, they should not be in the store, but + copied over using other means, such as agenix, NixOps + `deployment.keys`, or manual installation. + + The format is described on . + ''; + type = types.path; + default = config.staticSecretsDirectory + "/secrets.json"; + defaultText = literalExpression ''staticSecretsDirectory + "/secrets.json"''; + }; }; - baseDirectory = mkOption { - type = types.path; - default = "/var/lib/hercules-ci-agent"; - description = '' - State directory (secrets, work directory, etc) for agent - ''; - }; - concurrentTasks = mkOption { - description = '' - Number of tasks to perform simultaneously. - - A task is a single derivation build, an evaluation or an effect run. - At minimum, you need 2 concurrent tasks for `x86_64-linux` - in your cluster, to allow for import from derivation. - - `concurrentTasks` can be around the CPU core count or lower if memory is - the bottleneck. - - The optimal value depends on the resource consumption characteristics of your workload, - including memory usage and in-task parallelism. This is typically determined empirically. - - When scaling, it is generally better to have a double-size machine than two machines, - because each split of resources causes inefficiencies; particularly with regards - to build latency because of extra downloads. - ''; - type = types.either types.ints.positive (types.enum [ "auto" ]); - default = "auto"; - defaultText = lib.literalMD '' - `"auto"`, meaning equal to the number of CPU cores. - ''; - }; - labels = mkOption { - description = '' - A key-value map of user data. - - This data will be available to organization members in the dashboard and API. - - The values can be of any TOML type that corresponds to a JSON type, but arrays - can not contain tables/objects due to limitations of the TOML library. Values - involving arrays of non-primitive types may not be representable currently. - ''; - type = format.type; - defaultText = literalExpression '' - { - agent.source = "..."; # One of "nixpkgs", "flake", "override" - lib.version = "..."; - pkgs.version = "..."; - } - ''; - }; - workDirectory = mkOption { - description = '' - The directory in which temporary subdirectories are created for task state. This includes sources for Nix evaluation. - ''; - type = types.path; - default = config.baseDirectory + "/work"; - defaultText = literalExpression ''baseDirectory + "/work"''; - }; - staticSecretsDirectory = mkOption { - description = '' - This is the default directory to look for statically configured secrets like `cluster-join-token.key`. - - See also `clusterJoinTokenPath` and `binaryCachesPath` for fine-grained configuration. - ''; - type = types.path; - default = config.baseDirectory + "/secrets"; - defaultText = literalExpression ''baseDirectory + "/secrets"''; - }; - clusterJoinTokenPath = mkOption { - description = '' - Location of the cluster-join-token.key file. - - You can retrieve the contents of the file when creating a new agent via - . - - As this value is confidential, it should not be in the store, but - installed using other means, such as agenix, NixOps - `deployment.keys`, or manual installation. - - The contents of the file are used for authentication between the agent and the API. - ''; - type = types.path; - default = config.staticSecretsDirectory + "/cluster-join-token.key"; - defaultText = literalExpression ''staticSecretsDirectory + "/cluster-join-token.key"''; - }; - binaryCachesPath = mkOption { - description = '' - Path to a JSON file containing binary cache secret keys. - - As these values are confidential, they should not be in the store, but - copied over using other means, such as agenix, NixOps - `deployment.keys`, or manual installation. - - The format is described on . - ''; - type = types.path; - default = config.staticSecretsDirectory + "/binary-caches.json"; - defaultText = literalExpression ''staticSecretsDirectory + "/binary-caches.json"''; - }; - secretsJsonPath = mkOption { - description = '' - Path to a JSON file containing secrets for effects. - - As these values are confidential, they should not be in the store, but - copied over using other means, such as agenix, NixOps - `deployment.keys`, or manual installation. - - The format is described on . - ''; - type = types.path; - default = config.staticSecretsDirectory + "/secrets.json"; - defaultText = literalExpression ''staticSecretsDirectory + "/secrets.json"''; - }; - }; - config = { - labels = { - agent.source = - if packageOption.highestPrio == (lib.modules.mkOptionDefault { }).priority - then "nixpkgs" - else lib.mkOptionDefault "override"; - pkgs.version = pkgs.lib.version; - lib.version = lib.version; + config = { + labels = { + agent.source = + if packageOption.highestPrio == (lib.modules.mkOptionDefault { }).priority then + "nixpkgs" + else + lib.mkOptionDefault "override"; + pkgs.version = pkgs.lib.version; + lib.version = lib.version; + }; }; }; - }; in { inherit format settingsModule; diff --git a/nixos/modules/services/continuous-integration/jenkins/default.nix b/nixos/modules/services/continuous-integration/jenkins/default.nix index cba1a07ed7898b..c76aac1fa7ded3 100644 --- a/nixos/modules/services/continuous-integration/jenkins/default.nix +++ b/nixos/modules/services/continuous-integration/jenkins/default.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.jenkins; jenkinsUrl = "http://${cfg.listenAddress}:${toString cfg.port}${cfg.prefix}"; -in { +in +{ options = { services.jenkins = { enable = lib.mkOption { @@ -33,7 +39,10 @@ in { extraGroups = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "wheel" "dialout" ]; + example = [ + "wheel" + "dialout" + ]; description = '' List of extra groups that the "jenkins" user should be a part of. ''; @@ -81,7 +90,13 @@ in { package = lib.mkPackageOption pkgs "jenkins" { }; packages = lib.mkOption { - default = [ pkgs.stdenv pkgs.git pkgs.jdk17 config.programs.ssh.package pkgs.nix ]; + default = [ + pkgs.stdenv + pkgs.git + pkgs.jdk17 + config.programs.ssh.package + pkgs.nix + ]; defaultText = lib.literalExpression "[ pkgs.stdenv pkgs.git pkgs.jdk17 config.programs.ssh.package pkgs.nix ]"; type = lib.types.listOf lib.types.package; description = '' @@ -158,7 +173,8 @@ in { pkgs.dejavu_fonts ] ++ lib.optional cfg.withCLI cfg.package; - variables = {} + variables = + { } // lib.optionalAttrs cfg.withCLI { # Make it more convenient to use the `jenkins-cli`. JENKINS_URL = jenkinsUrl; @@ -188,32 +204,35 @@ in { environment = let - selectedSessionVars = - lib.filterAttrs (n: v: builtins.elem n [ "NIX_PATH" ]) - config.environment.sessionVariables; + selectedSessionVars = lib.filterAttrs ( + n: v: builtins.elem n [ "NIX_PATH" ] + ) config.environment.sessionVariables; in - selectedSessionVars // - { JENKINS_HOME = cfg.home; - NIX_REMOTE = "daemon"; - } // - cfg.environment; + selectedSessionVars + // { + JENKINS_HOME = cfg.home; + NIX_REMOTE = "daemon"; + } + // cfg.environment; path = cfg.packages; # Force .war (re)extraction, or else we might run stale Jenkins. preStart = - let replacePlugins = - lib.optionalString (cfg.plugins != null) ( - let pluginCmds = lib.mapAttrsToList - (n: v: "cp ${v} ${cfg.home}/plugins/${n}.jpi") - cfg.plugins; - in '' - rm -r ${cfg.home}/plugins || true - mkdir -p ${cfg.home}/plugins - ${lib.concatStringsSep "\n" pluginCmds} - ''); - in '' + let + replacePlugins = lib.optionalString (cfg.plugins != null) ( + let + pluginCmds = lib.mapAttrsToList (n: v: "cp ${v} ${cfg.home}/plugins/${n}.jpi") cfg.plugins; + in + '' + rm -r ${cfg.home}/plugins || true + mkdir -p ${cfg.home}/plugins + ${lib.concatStringsSep "\n" pluginCmds} + '' + ); + in + '' rm -rf ${cfg.home}/war ${replacePlugins} ''; diff --git a/nixos/modules/services/continuous-integration/jenkins/job-builder.nix b/nixos/modules/services/continuous-integration/jenkins/job-builder.nix index ccad25cb92a736..12c1c886c63320 100644 --- a/nixos/modules/services/continuous-integration/jenkins/job-builder.nix +++ b/nixos/modules/services/continuous-integration/jenkins/job-builder.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let jenkinsCfg = config.services.jenkins; cfg = config.services.jenkins.jobBuilder; -in { +in +{ options = { services.jenkins.jobBuilder = { enable = lib.mkEnableOption '' @@ -109,11 +115,13 @@ in { config = lib.mkIf (jenkinsCfg.enable && cfg.enable) { assertions = [ - { assertion = - if cfg.accessUser != "" - then (cfg.accessToken != "" && cfg.accessTokenFile == "") || - (cfg.accessToken == "" && cfg.accessTokenFile != "") - else true; + { + assertion = + if cfg.accessUser != "" then + (cfg.accessToken != "" && cfg.accessTokenFile == "") + || (cfg.accessToken == "" && cfg.accessTokenFile != "") + else + true; message = '' One of accessToken and accessTokenFile options must be non-empty strings, but not both. Current values: @@ -130,7 +138,10 @@ in { after = [ "jenkins.service" ]; wantedBy = [ "multi-user.target" ]; - path = with pkgs; [ jenkins-job-builder curl ]; + path = with pkgs; [ + jenkins-job-builder + curl + ]; # Q: Why manipulate files directly instead of using "jenkins-jobs upload [...]"? # A: Because this module is for administering a local jenkins install, @@ -139,9 +150,9 @@ in { script = let yamlJobsFile = builtins.toFile "jobs.yaml" cfg.yamlJobs; - jsonJobsFiles = - map (x: (builtins.toFile "jobs.json" x)) - (cfg.jsonJobs ++ [(builtins.toJSON cfg.nixJobs)]); + jsonJobsFiles = map (x: (builtins.toFile "jobs.json" x)) ( + cfg.jsonJobs ++ [ (builtins.toJSON cfg.nixJobs) ] + ); jobBuilderOutputDir = "/run/jenkins-job-builder/output"; # Stamp file is placed in $JENKINS_HOME/jobs/$JOB_NAME/ to indicate # ownership. Enables tracking and removal of stale jobs. @@ -149,9 +160,12 @@ in { reloadScript = '' echo "Asking Jenkins to reload config" curl_opts="--silent --fail --show-error" - access_token_file=${if cfg.accessTokenFile != "" - then cfg.accessTokenFile - else "$RUNTIME_DIRECTORY/jenkins_access_token.txt"} + access_token_file=${ + if cfg.accessTokenFile != "" then + cfg.accessTokenFile + else + "$RUNTIME_DIRECTORY/jenkins_access_token.txt" + } if [ "${cfg.accessToken}" != "" ]; then (umask 0077; printf "${cfg.accessToken}" >"$access_token_file") fi @@ -167,74 +181,75 @@ in { fi ''; in - '' - joinByString() - { - local separator="$1" - shift - local first="$1" - shift - printf "%s" "$first" "''${@/#/$separator}" - } + '' + joinByString() + { + local separator="$1" + shift + local first="$1" + shift + printf "%s" "$first" "''${@/#/$separator}" + } - # Map a relative directory path in the output from - # jenkins-job-builder (jobname) to the layout expected by jenkins: - # each directory level gets prepended "jobs/". - getJenkinsJobDir() - { - IFS='/' read -ra input_dirs <<< "$1" - printf "jobs/" - joinByString "/jobs/" "''${input_dirs[@]}" - } + # Map a relative directory path in the output from + # jenkins-job-builder (jobname) to the layout expected by jenkins: + # each directory level gets prepended "jobs/". + getJenkinsJobDir() + { + IFS='/' read -ra input_dirs <<< "$1" + printf "jobs/" + joinByString "/jobs/" "''${input_dirs[@]}" + } - # The inverse of getJenkinsJobDir (remove the "jobs/" prefixes) - getJobname() - { - IFS='/' read -ra input_dirs <<< "$1" - local i=0 - local nelem=''${#input_dirs[@]} - for e in "''${input_dirs[@]}"; do - if [ $((i % 2)) -eq 1 ]; then - printf "$e" - if [ $i -lt $(( nelem - 1 )) ]; then - printf "/" - fi - fi - i=$((i + 1)) - done - } + # The inverse of getJenkinsJobDir (remove the "jobs/" prefixes) + getJobname() + { + IFS='/' read -ra input_dirs <<< "$1" + local i=0 + local nelem=''${#input_dirs[@]} + for e in "''${input_dirs[@]}"; do + if [ $((i % 2)) -eq 1 ]; then + printf "$e" + if [ $i -lt $(( nelem - 1 )) ]; then + printf "/" + fi + fi + i=$((i + 1)) + done + } + + rm -rf ${jobBuilderOutputDir} + cur_decl_jobs=/run/jenkins-job-builder/declarative-jobs + rm -f "$cur_decl_jobs" + + # Create / update jobs + mkdir -p ${jobBuilderOutputDir} + for inputFile in ${yamlJobsFile} ${lib.concatStringsSep " " jsonJobsFiles}; do + HOME="${jenkinsCfg.home}" "${pkgs.jenkins-job-builder}/bin/jenkins-jobs" --ignore-cache test --config-xml -o "${jobBuilderOutputDir}" "$inputFile" + done + + find "${jobBuilderOutputDir}" -type f -name config.xml | while read -r f; do echo "$(dirname "$f")"; done | sort | while read -r dir; do + jobname="$(realpath --relative-to="${jobBuilderOutputDir}" "$dir")" + jenkinsjobname=$(getJenkinsJobDir "$jobname") + jenkinsjobdir="${jenkinsCfg.home}/$jenkinsjobname" + echo "Creating / updating job \"$jobname\"" + mkdir -p "$jenkinsjobdir" + touch "$jenkinsjobdir/${ownerStamp}" + cp "$dir"/config.xml "$jenkinsjobdir/config.xml" + echo "$jenkinsjobname" >> "$cur_decl_jobs" + done - rm -rf ${jobBuilderOutputDir} - cur_decl_jobs=/run/jenkins-job-builder/declarative-jobs - rm -f "$cur_decl_jobs" - - # Create / update jobs - mkdir -p ${jobBuilderOutputDir} - for inputFile in ${yamlJobsFile} ${lib.concatStringsSep " " jsonJobsFiles}; do - HOME="${jenkinsCfg.home}" "${pkgs.jenkins-job-builder}/bin/jenkins-jobs" --ignore-cache test --config-xml -o "${jobBuilderOutputDir}" "$inputFile" - done - - find "${jobBuilderOutputDir}" -type f -name config.xml | while read -r f; do echo "$(dirname "$f")"; done | sort | while read -r dir; do - jobname="$(realpath --relative-to="${jobBuilderOutputDir}" "$dir")" - jenkinsjobname=$(getJenkinsJobDir "$jobname") - jenkinsjobdir="${jenkinsCfg.home}/$jenkinsjobname" - echo "Creating / updating job \"$jobname\"" - mkdir -p "$jenkinsjobdir" - touch "$jenkinsjobdir/${ownerStamp}" - cp "$dir"/config.xml "$jenkinsjobdir/config.xml" - echo "$jenkinsjobname" >> "$cur_decl_jobs" - done - - # Remove stale jobs - find "${jenkinsCfg.home}" -type f -name "${ownerStamp}" | while read -r f; do echo "$(dirname "$f")"; done | sort --reverse | while read -r dir; do - jenkinsjobname="$(realpath --relative-to="${jenkinsCfg.home}" "$dir")" - grep --quiet --line-regexp "$jenkinsjobname" "$cur_decl_jobs" 2>/dev/null && continue - jobname=$(getJobname "$jenkinsjobname") - echo "Deleting stale job \"$jobname\"" - jobdir="${jenkinsCfg.home}/$jenkinsjobname" - rm -rf "$jobdir" - done - '' + (lib.optionalString (cfg.accessUser != "") reloadScript); + # Remove stale jobs + find "${jenkinsCfg.home}" -type f -name "${ownerStamp}" | while read -r f; do echo "$(dirname "$f")"; done | sort --reverse | while read -r dir; do + jenkinsjobname="$(realpath --relative-to="${jenkinsCfg.home}" "$dir")" + grep --quiet --line-regexp "$jenkinsjobname" "$cur_decl_jobs" 2>/dev/null && continue + jobname=$(getJobname "$jenkinsjobname") + echo "Deleting stale job \"$jobname\"" + jobdir="${jenkinsCfg.home}/$jenkinsjobname" + rm -rf "$jobdir" + done + '' + + (lib.optionalString (cfg.accessUser != "") reloadScript); serviceConfig = { Type = "oneshot"; User = jenkinsCfg.user; diff --git a/nixos/modules/services/continuous-integration/jenkins/slave.nix b/nixos/modules/services/continuous-integration/jenkins/slave.nix index d5a6b93a6cf8d9..aa374834743a81 100644 --- a/nixos/modules/services/continuous-integration/jenkins/slave.nix +++ b/nixos/modules/services/continuous-integration/jenkins/slave.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) mkIf mkOption types; cfg = config.services.jenkinsSlave; masterCfg = config.services.jenkins; -in { +in +{ options = { services.jenkinsSlave = { # todo: diff --git a/nixos/modules/services/continuous-integration/woodpecker/agents.nix b/nixos/modules/services/continuous-integration/woodpecker/agents.nix index b88bc6a0ccac0f..5d18dd9c2f4bf6 100644 --- a/nixos/modules/services/continuous-integration/woodpecker/agents.nix +++ b/nixos/modules/services/continuous-integration/woodpecker/agents.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let diff --git a/nixos/modules/services/continuous-integration/woodpecker/server.nix b/nixos/modules/services/continuous-integration/woodpecker/server.nix index 6e3cfb0b0114c8..15d2d703c0d540 100644 --- a/nixos/modules/services/continuous-integration/woodpecker/server.nix +++ b/nixos/modules/services/continuous-integration/woodpecker/server.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let @@ -10,7 +11,6 @@ in { meta.maintainers = with lib.maintainers; [ ambroisie ]; - options = { services.woodpecker-server = { enable = lib.mkEnableOption "the Woodpecker-Server, a CI/CD application for automatic builds, deployments and tests"; @@ -18,16 +18,15 @@ in environment = lib.mkOption { default = { }; type = lib.types.attrsOf lib.types.str; - example = lib.literalExpression - '' - { - WOODPECKER_HOST = "https://woodpecker.example.com"; - WOODPECKER_OPEN = "true"; - WOODPECKER_GITEA = "true"; - WOODPECKER_GITEA_CLIENT = "ffffffff-ffff-ffff-ffff-ffffffffffff"; - WOODPECKER_GITEA_URL = "https://git.example.com"; - } - ''; + example = lib.literalExpression '' + { + WOODPECKER_HOST = "https://woodpecker.example.com"; + WOODPECKER_OPEN = "true"; + WOODPECKER_GITEA = "true"; + WOODPECKER_GITEA_CLIENT = "ffffffff-ffff-ffff-ffff-ffffffffffff"; + WOODPECKER_GITEA_URL = "https://git.example.com"; + } + ''; description = "woodpecker-server config environment variables, for other options read the [documentation](https://woodpecker-ci.org/docs/administration/server-config)"; }; environmentFile = lib.mkOption { @@ -95,4 +94,3 @@ in }; }; } - diff --git a/nixos/modules/services/databases/aerospike.nix b/nixos/modules/services/databases/aerospike.nix index 6608d105a339f4..3e9bb538114818 100644 --- a/nixos/modules/services/databases/aerospike.nix +++ b/nixos/modules/services/databases/aerospike.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.aerospike; @@ -92,7 +97,6 @@ in }; - ###### implementation config = lib.mkIf config.services.aerospike.enable { diff --git a/nixos/modules/services/databases/cassandra.nix b/nixos/modules/services/databases/cassandra.nix index c8fce9b939db16..0130564778e680 100644 --- a/nixos/modules/services/databases/cassandra.nix +++ b/nixos/modules/services/databases/cassandra.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) @@ -36,27 +41,34 @@ let data_file_directories = [ "${cfg.homeDir}/data" ]; commitlog_directory = "${cfg.homeDir}/commitlog"; saved_caches_directory = "${cfg.homeDir}/saved_caches"; - } // optionalAttrs (cfg.seedAddresses != [ ]) { + } + // optionalAttrs (cfg.seedAddresses != [ ]) { seed_provider = [ { class_name = "org.apache.cassandra.locator.SimpleSeedProvider"; - parameters = [{ seeds = concatStringsSep "," cfg.seedAddresses; }]; + parameters = [ { seeds = concatStringsSep "," cfg.seedAddresses; } ]; } ]; - } // optionalAttrs atLeast3 { + } + // optionalAttrs atLeast3 { hints_directory = "${cfg.homeDir}/hints"; } ); - cassandraConfigWithAddresses = cassandraConfig // ( - if cfg.listenAddress == null - then { listen_interface = cfg.listenInterface; } - else { listen_address = cfg.listenAddress; } - ) // ( - if cfg.rpcAddress == null - then { rpc_interface = cfg.rpcInterface; } - else { rpc_address = cfg.rpcAddress; } - ); + cassandraConfigWithAddresses = + cassandraConfig + // ( + if cfg.listenAddress == null then + { listen_interface = cfg.listenInterface; } + else + { listen_address = cfg.listenAddress; } + ) + // ( + if cfg.rpcAddress == null then + { rpc_interface = cfg.rpcInterface; } + else + { rpc_address = cfg.rpcAddress; } + ); cassandraEtc = pkgs.stdenv.mkDerivation { name = "cassandra-etc"; @@ -91,19 +103,20 @@ let ''; }; - defaultJmxRolesFile = - builtins.foldl' - (left: right: left + right) "" - (map (role: "${role.username} ${role.password}") cfg.jmxRoles); + defaultJmxRolesFile = builtins.foldl' (left: right: left + right) "" ( + map (role: "${role.username} ${role.password}") cfg.jmxRoles + ); fullJvmOptions = cfg.jvmOpts ++ optionals (cfg.jmxRoles != [ ]) [ "-Dcom.sun.management.jmxremote.authenticate=true" "-Dcom.sun.management.jmxremote.password.file=${cfg.jmxRolesFile}" - ] ++ optionals cfg.remoteJmx [ + ] + ++ optionals cfg.remoteJmx [ "-Djava.rmi.server.hostname=${cfg.rpcAddress}" - ] ++ optionals atLeast4 [ + ] + ++ optionals atLeast4 [ # Historically, we don't use a log dir, whereas the upstream scripts do # expect this. We override those by providing our own -Xlog:gc flag. "-Xlog:gc=warning,heap*=warning,age*=warning,safepoint=warning,promotion*=warning" @@ -280,10 +293,9 @@ in extraConfig = mkOption { type = types.attrs; default = { }; - example = - { - commitlog_sync_batch_window_in_ms = 3; - }; + example = { + commitlog_sync_batch_window_in_ms = 3; + }; description = '' Extra options to be merged into {file}`cassandra.yaml` as nix attribute set. ''; @@ -432,26 +444,25 @@ in Doesn't work in versions older than 3.11 because they don't like that it's world readable. ''; - type = types.listOf (types.submodule { - options = { - username = mkOption { - type = types.str; - description = "Username for JMX"; - }; - password = mkOption { - type = types.str; - description = "Password for JMX"; + type = types.listOf ( + types.submodule { + options = { + username = mkOption { + type = types.str; + description = "Username for JMX"; + }; + password = mkOption { + type = types.str; + description = "Password for JMX"; + }; }; - }; - }); + } + ); }; jmxRolesFile = mkOption { type = types.nullOr types.path; - default = - if atLeast3_11 - then pkgs.writeText "jmx-roles-file" defaultJmxRolesFile - else null; + default = if atLeast3_11 then pkgs.writeText "jmx-roles-file" defaultJmxRolesFile else null; defaultText = literalMD ''generated configuration file if version is at least 3.11, otherwise `null`''; example = "/var/lib/cassandra/jmx.password"; description = '' @@ -525,26 +536,26 @@ in serviceConfig = { User = cfg.user; Group = cfg.group; - ExecStart = - concatStringsSep " " - ([ - "${cfg.package}/bin/nodetool" - "repair" - "--full" - ] ++ cfg.fullRepairOptions); + ExecStart = concatStringsSep " " ( + [ + "${cfg.package}/bin/nodetool" + "repair" + "--full" + ] + ++ cfg.fullRepairOptions + ); }; }; - systemd.timers.cassandra-full-repair = - mkIf (cfg.fullRepairInterval != null) { - description = "Schedule full repairs on Cassandra"; - wantedBy = [ "timers.target" ]; - timerConfig = { - OnBootSec = cfg.fullRepairInterval; - OnUnitActiveSec = cfg.fullRepairInterval; - Persistent = true; - }; + systemd.timers.cassandra-full-repair = mkIf (cfg.fullRepairInterval != null) { + description = "Schedule full repairs on Cassandra"; + wantedBy = [ "timers.target" ]; + timerConfig = { + OnBootSec = cfg.fullRepairInterval; + OnUnitActiveSec = cfg.fullRepairInterval; + Persistent = true; }; + }; systemd.services.cassandra-incremental-repair = { description = "Perform an incremental repair on this cassandra node."; @@ -554,25 +565,25 @@ in serviceConfig = { User = cfg.user; Group = cfg.group; - ExecStart = - concatStringsSep " " - ([ - "${cfg.package}/bin/nodetool" - "repair" - ] ++ cfg.incrementalRepairOptions); + ExecStart = concatStringsSep " " ( + [ + "${cfg.package}/bin/nodetool" + "repair" + ] + ++ cfg.incrementalRepairOptions + ); }; }; - systemd.timers.cassandra-incremental-repair = - mkIf (cfg.incrementalRepairInterval != null) { - description = "Schedule incremental repairs on Cassandra"; - wantedBy = [ "timers.target" ]; - timerConfig = { - OnBootSec = cfg.incrementalRepairInterval; - OnUnitActiveSec = cfg.incrementalRepairInterval; - Persistent = true; - }; + systemd.timers.cassandra-incremental-repair = mkIf (cfg.incrementalRepairInterval != null) { + description = "Schedule incremental repairs on Cassandra"; + wantedBy = [ "timers.target" ]; + timerConfig = { + OnBootSec = cfg.incrementalRepairInterval; + OnUnitActiveSec = cfg.incrementalRepairInterval; + Persistent = true; }; + }; }; meta.maintainers = with lib.maintainers; [ roberth ]; diff --git a/nixos/modules/services/databases/clickhouse.nix b/nixos/modules/services/databases/clickhouse.nix index 9025b9a8695845..18251d2e4d77c2 100644 --- a/nixos/modules/services/databases/clickhouse.nix +++ b/nixos/modules/services/databases/clickhouse.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.clickhouse; in @@ -18,7 +23,6 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/databases/cockroachdb.nix b/nixos/modules/services/databases/cockroachdb.nix index e46a8dd600b3eb..f581d7f6d505d9 100644 --- a/nixos/modules/services/databases/cockroachdb.nix +++ b/nixos/modules/services/databases/cockroachdb.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.services.cockroachdb; crdb = cfg.package; - startupCommand = utils.escapeSystemdExecArgs - ([ + startupCommand = utils.escapeSystemdExecArgs ( + [ # Basic startup "${crdb}/bin/cockroach" "start" @@ -26,7 +32,8 @@ let ] ++ lib.optional (cfg.join != null) "--join=${cfg.join}" ++ lib.optional (cfg.locality != null) "--locality=${cfg.locality}" - ++ cfg.extraArgs); + ++ cfg.extraArgs + ); addressOption = descr: defaultPort: { address = lib.mkOption { @@ -152,8 +159,11 @@ in extraArgs = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; - example = [ "--advertise-addr" "[fe80::f6f2:::]" ]; + default = [ ]; + example = [ + "--advertise-addr" + "[fe80::f6f2:::]" + ]; description = '' Extra CLI arguments passed to {command}`cockroach start`. For the full list of supported arguments, check @@ -164,7 +174,8 @@ in config = lib.mkIf config.services.cockroachdb.enable { assertions = [ - { assertion = !cfg.insecure -> cfg.certsDir != null; + { + assertion = !cfg.insecure -> cfg.certsDir != null; message = "CockroachDB must have a set of SSL certificates (.certsDir), or run in Insecure Mode (.insecure = true)"; } ]; @@ -174,8 +185,8 @@ in users.users = lib.optionalAttrs (cfg.user == "cockroachdb") { cockroachdb = { description = "CockroachDB Server User"; - uid = config.ids.uids.cockroachdb; - group = cfg.group; + uid = config.ids.uids.cockroachdb; + group = cfg.group; }; }; @@ -183,34 +194,42 @@ in cockroachdb.gid = config.ids.gids.cockroachdb; }; - networking.firewall.allowedTCPPorts = lib.optionals cfg.openPorts - [ cfg.http.port cfg.listen.port ]; - - systemd.services.cockroachdb = - { description = "CockroachDB Server"; - documentation = [ "man:cockroach(1)" "https://www.cockroachlabs.com" ]; - - after = [ "network.target" "time-sync.target" ]; - requires = [ "time-sync.target" ]; - wantedBy = [ "multi-user.target" ]; - - unitConfig.RequiresMountsFor = "/var/lib/cockroachdb"; - - serviceConfig = - { ExecStart = startupCommand; - Type = "notify"; - User = cfg.user; - StateDirectory = "cockroachdb"; - StateDirectoryMode = "0700"; - - Restart = "always"; + networking.firewall.allowedTCPPorts = lib.optionals cfg.openPorts [ + cfg.http.port + cfg.listen.port + ]; - # A conservative-ish timeout is alright here, because for Type=notify - # cockroach will send systemd pings during startup to keep it alive - TimeoutStopSec = 60; - RestartSec = 10; - }; + systemd.services.cockroachdb = { + description = "CockroachDB Server"; + documentation = [ + "man:cockroach(1)" + "https://www.cockroachlabs.com" + ]; + + after = [ + "network.target" + "time-sync.target" + ]; + requires = [ "time-sync.target" ]; + wantedBy = [ "multi-user.target" ]; + + unitConfig.RequiresMountsFor = "/var/lib/cockroachdb"; + + serviceConfig = { + ExecStart = startupCommand; + Type = "notify"; + User = cfg.user; + StateDirectory = "cockroachdb"; + StateDirectoryMode = "0700"; + + Restart = "always"; + + # A conservative-ish timeout is alright here, because for Type=notify + # cockroach will send systemd pings during startup to keep it alive + TimeoutStopSec = 60; + RestartSec = 10; }; + }; }; meta.maintainers = with lib.maintainers; [ thoughtpolice ]; diff --git a/nixos/modules/services/databases/dgraph.nix b/nixos/modules/services/databases/dgraph.nix index 20bc56df85a488..81d160052413d7 100644 --- a/nixos/modules/services/databases/dgraph.nix +++ b/nixos/modules/services/databases/dgraph.nix @@ -1,50 +1,67 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.dgraph; - settingsFormat = pkgs.formats.json {}; + settingsFormat = pkgs.formats.json { }; configFile = settingsFormat.generate "config.json" cfg.settings; - dgraphWithNode = pkgs.runCommand "dgraph" { - nativeBuildInputs = [ pkgs.makeWrapper ]; - } - '' - mkdir -p $out/bin - makeWrapper ${cfg.package}/bin/dgraph $out/bin/dgraph \ - --prefix PATH : "${lib.makeBinPath [ pkgs.nodejs ]}" \ - ''; + dgraphWithNode = + pkgs.runCommand "dgraph" + { + nativeBuildInputs = [ pkgs.makeWrapper ]; + } + '' + mkdir -p $out/bin + makeWrapper ${cfg.package}/bin/dgraph $out/bin/dgraph \ + --prefix PATH : "${lib.makeBinPath [ pkgs.nodejs ]}" \ + ''; securityOptions = { - NoNewPrivileges = true; - - AmbientCapabilities = ""; - CapabilityBoundingSet = ""; - - DeviceAllow = ""; - - LockPersonality = true; - - PrivateTmp = true; - PrivateDevices = true; - PrivateUsers = true; - - ProtectClock = true; - ProtectControlGroups = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - - RemoveIPC = true; - - RestrictNamespaces = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; - RestrictRealtime = true; - RestrictSUIDSGID = true; - - SystemCallArchitectures = "native"; - SystemCallErrorNumber = "EPERM"; - SystemCallFilter = [ - "@system-service" - "~@cpu-emulation" "~@debug" "~@keyring" "~@memlock" "~@obsolete" "~@privileged" "~@setuid" - ]; + NoNewPrivileges = true; + + AmbientCapabilities = ""; + CapabilityBoundingSet = ""; + + DeviceAllow = ""; + + LockPersonality = true; + + PrivateTmp = true; + PrivateDevices = true; + PrivateUsers = true; + + ProtectClock = true; + ProtectControlGroups = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + + RemoveIPC = true; + + RestrictNamespaces = true; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; + RestrictRealtime = true; + RestrictSUIDSGID = true; + + SystemCallArchitectures = "native"; + SystemCallErrorNumber = "EPERM"; + SystemCallFilter = [ + "@system-service" + "~@cpu-emulation" + "~@debug" + "~@keyring" + "~@memlock" + "~@obsolete" + "~@privileged" + "~@setuid" + ]; }; in { @@ -56,7 +73,7 @@ in settings = lib.mkOption { type = settingsFormat.type; - default = {}; + default = { }; description = '' Contents of the dgraph config. For more details see https://dgraph.io/docs/deploy/config ''; @@ -121,7 +138,10 @@ in systemd.services.dgraph-alpha = { description = "Dgraph native GraphQL database with a graph backend. Alpha serves data"; - after = [ "network.target" "dgraph-zero.service" ]; + after = [ + "network.target" + "dgraph-zero.service" + ]; requires = [ "dgraph-zero.service" ]; wantedBy = [ "multi-user.target" ]; diff --git a/nixos/modules/services/databases/dragonflydb.nix b/nixos/modules/services/databases/dragonflydb.nix index 9024b584abc322..3a7f005fce4ffc 100644 --- a/nixos/modules/services/databases/dragonflydb.nix +++ b/nixos/modules/services/databases/dragonflydb.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.dragonflydb; dragonflydb = pkgs.dragonflydb; @@ -8,13 +13,13 @@ let port = cfg.port; dir = "/var/lib/dragonflydb"; keys_output_limit = cfg.keysOutputLimit; - } // - (lib.optionalAttrs (cfg.bind != null) { bind = cfg.bind; }) // - (lib.optionalAttrs (cfg.requirePass != null) { requirepass = cfg.requirePass; }) // - (lib.optionalAttrs (cfg.maxMemory != null) { maxmemory = cfg.maxMemory; }) // - (lib.optionalAttrs (cfg.memcachePort != null) { memcache_port = cfg.memcachePort; }) // - (lib.optionalAttrs (cfg.dbNum != null) { dbnum = cfg.dbNum; }) // - (lib.optionalAttrs (cfg.cacheMode != null) { cache_mode = cfg.cacheMode; }); + } + // (lib.optionalAttrs (cfg.bind != null) { bind = cfg.bind; }) + // (lib.optionalAttrs (cfg.requirePass != null) { requirepass = cfg.requirePass; }) + // (lib.optionalAttrs (cfg.maxMemory != null) { maxmemory = cfg.maxMemory; }) + // (lib.optionalAttrs (cfg.memcachePort != null) { memcache_port = cfg.memcachePort; }) + // (lib.optionalAttrs (cfg.dbNum != null) { dbnum = cfg.dbNum; }) + // (lib.optionalAttrs (cfg.cacheMode != null) { cache_mode = cfg.cacheMode; }); in { @@ -117,7 +122,9 @@ in after = [ "network.target" ]; serviceConfig = { - ExecStart = "${dragonflydb}/bin/dragonfly --alsologtostderr ${lib.concatStringsSep " " (lib.mapAttrsToList (n: v: "--${n} ${lib.escapeShellArg v}") settings)}"; + ExecStart = "${dragonflydb}/bin/dragonfly --alsologtostderr ${ + lib.concatStringsSep " " (lib.mapAttrsToList (n: v: "--${n} ${lib.escapeShellArg v}") settings) + }"; User = cfg.user; @@ -139,7 +146,10 @@ in ProtectKernelModules = true; ProtectControlGroups = true; LockPersonality = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictRealtime = true; PrivateMounts = true; MemoryDenyWriteExecute = true; diff --git a/nixos/modules/services/databases/etcd.nix b/nixos/modules/services/databases/etcd.nix index b10fdb801c501b..051547d1dd5a44 100644 --- a/nixos/modules/services/databases/etcd.nix +++ b/nixos/modules/services/databases/etcd.nix @@ -1,9 +1,16 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.etcd; opt = options.services.etcd; -in { +in +{ options.services.etcd = { enable = lib.mkOption { @@ -30,13 +37,13 @@ in { listenClientUrls = lib.mkOption { description = "Etcd list of URLs to listen on for client traffic."; - default = ["http://127.0.0.1:2379"]; + default = [ "http://127.0.0.1:2379" ]; type = lib.types.listOf lib.types.str; }; listenPeerUrls = lib.mkOption { description = "Etcd list of URLs to listen on for peer traffic."; - default = ["http://127.0.0.1:2380"]; + default = [ "http://127.0.0.1:2380" ]; type = lib.types.listOf lib.types.str; }; @@ -49,7 +56,7 @@ in { initialCluster = lib.mkOption { description = "Etcd initial cluster configuration for bootstrapping."; - default = ["${cfg.name}=http://127.0.0.1:2380"]; + default = [ "${cfg.name}=http://127.0.0.1:2380" ]; defaultText = lib.literalExpression ''["''${config.${opt.name}}=http://127.0.0.1:2380"]''; type = lib.types.listOf lib.types.str; }; @@ -57,7 +64,10 @@ in { initialClusterState = lib.mkOption { description = "Etcd initial cluster configuration for bootstrapping."; default = "new"; - type = lib.types.enum ["new" "existing"]; + type = lib.types.enum [ + "new" + "existing" + ]; }; initialClusterToken = lib.mkOption { @@ -140,7 +150,7 @@ in { ''; type = lib.types.attrsOf lib.types.str; - default = {}; + default = { }; example = lib.literalExpression '' { "CORS" = "*"; @@ -168,32 +178,37 @@ in { systemd.services.etcd = { description = "etcd key-value store"; wantedBy = [ "multi-user.target" ]; - after = [ "network-online.target" ] - ++ lib.optional config.networking.firewall.enable "firewall.service"; - wants = [ "network-online.target" ] - ++ lib.optional config.networking.firewall.enable "firewall.service"; - - environment = (lib.filterAttrs (n: v: v != null) { - ETCD_NAME = cfg.name; - ETCD_DISCOVERY = cfg.discovery; - ETCD_DATA_DIR = cfg.dataDir; - ETCD_ADVERTISE_CLIENT_URLS = lib.concatStringsSep "," cfg.advertiseClientUrls; - ETCD_LISTEN_CLIENT_URLS = lib.concatStringsSep "," cfg.listenClientUrls; - ETCD_LISTEN_PEER_URLS = lib.concatStringsSep "," cfg.listenPeerUrls; - ETCD_INITIAL_ADVERTISE_PEER_URLS = lib.concatStringsSep "," cfg.initialAdvertisePeerUrls; - ETCD_PEER_CLIENT_CERT_AUTH = toString cfg.peerClientCertAuth; - ETCD_PEER_TRUSTED_CA_FILE = cfg.peerTrustedCaFile; - ETCD_PEER_CERT_FILE = cfg.peerCertFile; - ETCD_PEER_KEY_FILE = cfg.peerKeyFile; - ETCD_CLIENT_CERT_AUTH = toString cfg.clientCertAuth; - ETCD_TRUSTED_CA_FILE = cfg.trustedCaFile; - ETCD_CERT_FILE = cfg.certFile; - ETCD_KEY_FILE = cfg.keyFile; - }) // (lib.optionalAttrs (cfg.discovery == ""){ - ETCD_INITIAL_CLUSTER = lib.concatStringsSep "," cfg.initialCluster; - ETCD_INITIAL_CLUSTER_STATE = cfg.initialClusterState; - ETCD_INITIAL_CLUSTER_TOKEN = cfg.initialClusterToken; - }) // (lib.mapAttrs' (n: v: lib.nameValuePair "ETCD_${n}" v) cfg.extraConf); + after = [ + "network-online.target" + ] ++ lib.optional config.networking.firewall.enable "firewall.service"; + wants = [ + "network-online.target" + ] ++ lib.optional config.networking.firewall.enable "firewall.service"; + + environment = + (lib.filterAttrs (n: v: v != null) { + ETCD_NAME = cfg.name; + ETCD_DISCOVERY = cfg.discovery; + ETCD_DATA_DIR = cfg.dataDir; + ETCD_ADVERTISE_CLIENT_URLS = lib.concatStringsSep "," cfg.advertiseClientUrls; + ETCD_LISTEN_CLIENT_URLS = lib.concatStringsSep "," cfg.listenClientUrls; + ETCD_LISTEN_PEER_URLS = lib.concatStringsSep "," cfg.listenPeerUrls; + ETCD_INITIAL_ADVERTISE_PEER_URLS = lib.concatStringsSep "," cfg.initialAdvertisePeerUrls; + ETCD_PEER_CLIENT_CERT_AUTH = toString cfg.peerClientCertAuth; + ETCD_PEER_TRUSTED_CA_FILE = cfg.peerTrustedCaFile; + ETCD_PEER_CERT_FILE = cfg.peerCertFile; + ETCD_PEER_KEY_FILE = cfg.peerKeyFile; + ETCD_CLIENT_CERT_AUTH = toString cfg.clientCertAuth; + ETCD_TRUSTED_CA_FILE = cfg.trustedCaFile; + ETCD_CERT_FILE = cfg.certFile; + ETCD_KEY_FILE = cfg.keyFile; + }) + // (lib.optionalAttrs (cfg.discovery == "") { + ETCD_INITIAL_CLUSTER = lib.concatStringsSep "," cfg.initialCluster; + ETCD_INITIAL_CLUSTER_STATE = cfg.initialClusterState; + ETCD_INITIAL_CLUSTER_TOKEN = cfg.initialClusterToken; + }) + // (lib.mapAttrs' (n: v: lib.nameValuePair "ETCD_${n}" v) cfg.extraConf); unitConfig = { Documentation = "https://github.com/coreos/etcd"; @@ -224,6 +239,6 @@ in { description = "Etcd daemon user"; home = cfg.dataDir; }; - users.groups.etcd = {}; + users.groups.etcd = { }; }; } diff --git a/nixos/modules/services/databases/firebird.nix b/nixos/modules/services/databases/firebird.nix index 4b2b34ae7b1de3..cd129d0aa75afc 100644 --- a/nixos/modules/services/databases/firebird.nix +++ b/nixos/modules/services/databases/firebird.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: # TODO: This may file may need additional review, eg which configurations to # expose to the user. @@ -75,49 +80,47 @@ in }; - ###### implementation config = lib.mkIf config.services.firebird.enable { - environment.systemPackages = [cfg.package]; + environment.systemPackages = [ cfg.package ]; systemd.tmpfiles.rules = [ "d '${dataDir}' 0700 ${cfg.user} - - -" "d '${systemDir}' 0700 ${cfg.user} - - -" ]; - systemd.services.firebird = - { description = "Firebird Super-Server"; + systemd.services.firebird = { + description = "Firebird Super-Server"; - wantedBy = [ "multi-user.target" ]; + wantedBy = [ "multi-user.target" ]; - # TODO: moving security2.fdb into the data directory works, maybe there - # is a better way - preStart = - '' - if ! test -e "${systemDir}/security2.fdb"; then - cp ${firebird}/security2.fdb "${systemDir}" - fi + # TODO: moving security2.fdb into the data directory works, maybe there + # is a better way + preStart = '' + if ! test -e "${systemDir}/security2.fdb"; then + cp ${firebird}/security2.fdb "${systemDir}" + fi - if ! test -e "${systemDir}/security3.fdb"; then - cp ${firebird}/security3.fdb "${systemDir}" - fi + if ! test -e "${systemDir}/security3.fdb"; then + cp ${firebird}/security3.fdb "${systemDir}" + fi - if ! test -e "${systemDir}/security4.fdb"; then - cp ${firebird}/security4.fdb "${systemDir}" - fi + if ! test -e "${systemDir}/security4.fdb"; then + cp ${firebird}/security4.fdb "${systemDir}" + fi - chmod -R 700 "${dataDir}" "${systemDir}" /var/log/firebird - ''; + chmod -R 700 "${dataDir}" "${systemDir}" /var/log/firebird + ''; - serviceConfig.User = cfg.user; - serviceConfig.LogsDirectory = "firebird"; - serviceConfig.LogsDirectoryMode = "0700"; - serviceConfig.ExecStart = "${firebird}/bin/fbserver -d"; + serviceConfig.User = cfg.user; + serviceConfig.LogsDirectory = "firebird"; + serviceConfig.LogsDirectoryMode = "0700"; + serviceConfig.ExecStart = "${firebird}/bin/fbserver -d"; - # TODO think about shutdown - }; + # TODO think about shutdown + }; environment.etc."firebird/firebird.msg".source = "${firebird}/firebird.msg"; diff --git a/nixos/modules/services/databases/foundationdb.nix b/nixos/modules/services/databases/foundationdb.nix index 8fc35474b39c55..18f197890b7902 100644 --- a/nixos/modules/services/databases/foundationdb.nix +++ b/nixos/modules/services/databases/foundationdb.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.foundationdb; pkg = cfg.package; @@ -6,11 +11,14 @@ let # used for initial cluster configuration initialIpAddr = if (cfg.publicAddress != "auto") then cfg.publicAddress else "127.0.0.1"; - fdbServers = n: - lib.concatStringsSep "\n" (map (x: "[fdbserver.${toString (x+cfg.listenPortStart)}]") (lib.range 0 (n - 1))); + fdbServers = + n: + lib.concatStringsSep "\n" ( + map (x: "[fdbserver.${toString (x + cfg.listenPortStart)}]") (lib.range 0 (n - 1)) + ); - backupAgents = n: - lib.concatStringsSep "\n" (map (x: "[backup_agent.${toString x}]") (lib.range 1 n)); + backupAgents = + n: lib.concatStringsSep "\n" (map (x: "[backup_agent.${toString x}]") (lib.range 1 n)); configFile = pkgs.writeText "foundationdb.conf" '' [general] @@ -34,7 +42,7 @@ let storage_memory = ${cfg.storageMemory} ${lib.optionalString (lib.versionAtLeast cfg.package.version "6.1") '' - trace_format = ${cfg.traceFormat} + trace_format = ${cfg.traceFormat} ''} ${lib.optionalString (cfg.tls != null) '' @@ -44,10 +52,14 @@ let tls_verify_peers = ${cfg.tls.allowedPeers} ''} - ${lib.optionalString (cfg.locality.machineId != null) "locality_machineid=${cfg.locality.machineId}"} - ${lib.optionalString (cfg.locality.zoneId != null) "locality_zoneid=${cfg.locality.zoneId}"} - ${lib.optionalString (cfg.locality.datacenterId != null) "locality_dcid=${cfg.locality.datacenterId}"} - ${lib.optionalString (cfg.locality.dataHall != null) "locality_data_hall=${cfg.locality.dataHall}"} + ${lib.optionalString ( + cfg.locality.machineId != null + ) "locality_machineid=${cfg.locality.machineId}"} + ${lib.optionalString (cfg.locality.zoneId != null) "locality_zoneid=${cfg.locality.zoneId}"} + ${lib.optionalString ( + cfg.locality.datacenterId != null + ) "locality_dcid=${cfg.locality.datacenterId}"} + ${lib.optionalString (cfg.locality.dataHall != null) "locality_data_hall=${cfg.locality.dataHall}"} ${fdbServers cfg.serverProcesses} @@ -62,7 +74,7 @@ in enable = lib.mkEnableOption "FoundationDB Server"; package = lib.mkOption { - type = lib.types.package; + type = lib.types.package; description = '' The FoundationDB package to use for this server. This must be specified by the user in order to ensure migrations and upgrades are controlled appropriately. @@ -70,21 +82,21 @@ in }; publicAddress = lib.mkOption { - type = lib.types.str; - default = "auto"; + type = lib.types.str; + default = "auto"; description = "Publicly visible IP address of the process. Port is determined by process ID"; }; listenAddress = lib.mkOption { - type = lib.types.str; - default = "public"; + type = lib.types.str; + default = "public"; description = "Publicly visible IP address of the process. Port is determined by process ID"; }; listenPortStart = lib.mkOption { - type = lib.types.int; - default = 4500; - description = '' + type = lib.types.int; + default = 4500; + description = '' Starting port number for database listening sockets. Every FDB process binds to a subsequent port, to this number reflects the start of the overall range. e.g. having 8 server processes will use all ports between 4500 and 4507. @@ -92,8 +104,8 @@ in }; openFirewall = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = '' Open the firewall ports corresponding to FoundationDB processes and coordinators using {option}`config.networking.firewall.*`. @@ -101,32 +113,38 @@ in }; dataDir = lib.mkOption { - type = lib.types.path; - default = "/var/lib/foundationdb"; + type = lib.types.path; + default = "/var/lib/foundationdb"; description = "Data directory. All cluster data will be put under here."; }; logDir = lib.mkOption { - type = lib.types.path; - default = "/var/log/foundationdb"; + type = lib.types.path; + default = "/var/log/foundationdb"; description = "Log directory."; }; user = lib.mkOption { - type = lib.types.str; - default = "foundationdb"; + type = lib.types.str; + default = "foundationdb"; description = "User account under which FoundationDB runs."; }; group = lib.mkOption { - type = lib.types.str; - default = "foundationdb"; + type = lib.types.str; + default = "foundationdb"; description = "Group account under which FoundationDB runs."; }; class = lib.mkOption { - type = lib.types.nullOr (lib.types.enum [ "storage" "transaction" "stateless" ]); - default = null; + type = lib.types.nullOr ( + lib.types.enum [ + "storage" + "transaction" + "stateless" + ] + ); + default = null; description = "Process class"; }; @@ -137,8 +155,8 @@ in }; logSize = lib.mkOption { - type = lib.types.str; - default = "10MiB"; + type = lib.types.str; + default = "10MiB"; description = '' Roll over to a new log file after the current log file reaches the specified size. @@ -146,8 +164,8 @@ in }; maxLogSize = lib.mkOption { - type = lib.types.str; - default = "100MiB"; + type = lib.types.str; + default = "100MiB"; description = '' Delete the oldest log file when the total size of all log files exceeds the specified size. If set to 0, old log files @@ -168,8 +186,8 @@ in }; memory = lib.mkOption { - type = lib.types.str; - default = "8GiB"; + type = lib.types.str; + default = "8GiB"; description = '' Maximum memory used by the process. The default value is `8GiB`. When specified without a unit, @@ -190,8 +208,8 @@ in }; storageMemory = lib.mkOption { - type = lib.types.str; - default = "1GiB"; + type = lib.types.str; + default = "1GiB"; description = '' Maximum memory used for data storage. The default value is `1GiB`. When specified without a unit, @@ -211,43 +229,45 @@ in FoundationDB Transport Security Layer (TLS) settings. ''; - type = lib.types.nullOr (lib.types.submodule ({ - options = { - certificate = lib.mkOption { - type = lib.types.str; - description = '' - Path to the TLS certificate file. This certificate will - be offered to, and may be verified by, clients. - ''; - }; - - key = lib.mkOption { - type = lib.types.str; - description = "Private key file for the certificate."; - }; - - allowedPeers = lib.mkOption { - type = lib.types.str; - default = "Check.Valid=1,Check.Unexpired=1"; - description = '' - "Peer verification string". This may be used to adjust which TLS - client certificates a server will accept, as a form of user - authorization; for example, it may only accept TLS clients who - offer a certificate abiding by some locality or organization name. - - For more information, please see the FoundationDB documentation. - ''; + type = lib.types.nullOr ( + lib.types.submodule ({ + options = { + certificate = lib.mkOption { + type = lib.types.str; + description = '' + Path to the TLS certificate file. This certificate will + be offered to, and may be verified by, clients. + ''; + }; + + key = lib.mkOption { + type = lib.types.str; + description = "Private key file for the certificate."; + }; + + allowedPeers = lib.mkOption { + type = lib.types.str; + default = "Check.Valid=1,Check.Unexpired=1"; + description = '' + "Peer verification string". This may be used to adjust which TLS + client certificates a server will accept, as a form of user + authorization; for example, it may only accept TLS clients who + offer a certificate abiding by some locality or organization name. + + For more information, please see the FoundationDB documentation. + ''; + }; }; - }; - })); + }) + ); }; locality = lib.mkOption { default = { - machineId = null; - zoneId = null; + machineId = null; + zoneId = null; datacenterId = null; - dataHall = null; + dataHall = null; }; description = '' @@ -314,13 +334,16 @@ in }; pidfile = lib.mkOption { - type = lib.types.path; - default = "/run/foundationdb.pid"; + type = lib.types.path; + default = "/run/foundationdb.pid"; description = "Path to pidfile for fdbmonitor."; }; traceFormat = lib.mkOption { - type = lib.types.enum [ "xml" "json" ]; + type = lib.types.enum [ + "xml" + "json" + ]; default = "xml"; description = "Trace logging format."; }; @@ -328,11 +351,16 @@ in config = lib.mkIf cfg.enable { assertions = [ - { assertion = lib.versionOlder cfg.package.version "6.1" -> cfg.traceFormat == "xml"; - message = '' - Versions of FoundationDB before 6.1 do not support configurable trace formats (only XML is supported). - This option has no effect for version '' + cfg.package.version + '', and enabling it is an error. - ''; + { + assertion = lib.versionOlder cfg.package.version "6.1" -> cfg.traceFormat == "xml"; + message = + '' + Versions of FoundationDB before 6.1 do not support configurable trace formats (only XML is supported). + This option has no effect for version '' + + cfg.package.version + + '' + , and enabling it is an error. + ''; } ]; @@ -341,8 +369,8 @@ in users.users = lib.optionalAttrs (cfg.user == "foundationdb") { foundationdb = { description = "FoundationDB User"; - uid = config.ids.uids.foundationdb; - group = cfg.group; + uid = config.ids.uids.foundationdb; + group = cfg.group; }; }; @@ -350,11 +378,12 @@ in foundationdb.gid = config.ids.gids.foundationdb; }; - networking.firewall.allowedTCPPortRanges = lib.mkIf cfg.openFirewall - [ { from = cfg.listenPortStart; - to = (cfg.listenPortStart + cfg.serverProcesses) - 1; - } - ]; + networking.firewall.allowedTCPPortRanges = lib.mkIf cfg.openFirewall [ + { + from = cfg.listenPortStart; + to = (cfg.listenPortStart + cfg.serverProcesses) - 1; + } + ]; systemd.tmpfiles.rules = [ "d /etc/foundationdb 0755 ${cfg.user} ${cfg.group} - -" @@ -364,40 +393,49 @@ in ]; systemd.services.foundationdb = { - description = "FoundationDB Service"; + description = "FoundationDB Service"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - unitConfig = - { RequiresMountsFor = "${cfg.dataDir} ${cfg.logDir}"; - }; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + unitConfig = { + RequiresMountsFor = "${cfg.dataDir} ${cfg.logDir}"; + }; serviceConfig = - let rwpaths = [ cfg.dataDir cfg.logDir cfg.pidfile "/etc/foundationdb" ] - ++ cfg.extraReadWritePaths; + let + rwpaths = [ + cfg.dataDir + cfg.logDir + cfg.pidfile + "/etc/foundationdb" + ] ++ cfg.extraReadWritePaths; in - { Type = "simple"; - Restart = "always"; + { + Type = "simple"; + Restart = "always"; RestartSec = 5; - User = cfg.user; - Group = cfg.group; - PIDFile = "${cfg.pidfile}"; + User = cfg.user; + Group = cfg.group; + PIDFile = "${cfg.pidfile}"; - PermissionsStartOnly = true; # setup needs root perms - TimeoutSec = 120; # give reasonable time to shut down + PermissionsStartOnly = true; # setup needs root perms + TimeoutSec = 120; # give reasonable time to shut down # Security options - NoNewPrivileges = true; - ProtectHome = true; - ProtectSystem = "strict"; + NoNewPrivileges = true; + ProtectHome = true; + ProtectSystem = "strict"; ProtectKernelTunables = true; - ProtectControlGroups = true; - PrivateTmp = true; - PrivateDevices = true; - ReadWritePaths = lib.concatStringsSep " " (map (x: "-" + x) rwpaths); + ProtectControlGroups = true; + PrivateTmp = true; + PrivateDevices = true; + ReadWritePaths = lib.concatStringsSep " " (map (x: "-" + x) rwpaths); }; - path = [ pkg pkgs.coreutils ]; + path = [ + pkg + pkgs.coreutils + ]; preStart = '' if [ ! -f /etc/foundationdb/fdb.cluster ]; then @@ -421,6 +459,6 @@ in }; }; - meta.doc = ./foundationdb.md; + meta.doc = ./foundationdb.md; meta.maintainers = with lib.maintainers; [ thoughtpolice ]; } diff --git a/nixos/modules/services/databases/hbase-standalone.nix b/nixos/modules/services/databases/hbase-standalone.nix index d3d2999eaeed50..57d5e0536bcdbb 100644 --- a/nixos/modules/services/databases/hbase-standalone.nix +++ b/nixos/modules/services/databases/hbase-standalone.nix @@ -1,33 +1,40 @@ -{ config, options, lib, pkgs, ... }: +{ + config, + options, + lib, + pkgs, + ... +}: let cfg = config.services.hbase-standalone; opt = options.services.hbase-standalone; - buildProperty = configAttr: - (builtins.concatStringsSep "\n" - (lib.mapAttrsToList - (name: value: '' - - ${name} - ${builtins.toString value} - - '') - configAttr)); - - configFile = pkgs.writeText "hbase-site.xml" - '' - ${buildProperty (opt.settings.default // cfg.settings)} - - ''; + buildProperty = + configAttr: + (builtins.concatStringsSep "\n" ( + lib.mapAttrsToList (name: value: '' + + ${name} + ${builtins.toString value} + + '') configAttr + )); + + configFile = pkgs.writeText "hbase-site.xml" '' + + ${buildProperty (opt.settings.default // cfg.settings)} + + ''; configDir = pkgs.runCommand "hbase-config-dir" { preferLocalBuild = true; } '' mkdir -p $out cp ${cfg.package}/conf/* $out/ rm $out/hbase-site.xml ln -s ${configFile} $out/hbase-site.xml - '' ; + ''; -in { +in +{ imports = [ (lib.mkRenamedOptionModule [ "services" "hbase" ] [ "services" "hbase-standalone" ]) @@ -80,7 +87,13 @@ in { }; settings = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ str int bool ]); + type = + with lib.types; + attrsOf (oneOf [ + str + int + bool + ]); default = { "hbase.rootdir" = "file://${cfg.dataDir}/hbase"; "hbase.zookeeper.property.dataDir" = "${cfg.dataDir}/zookeeper"; diff --git a/nixos/modules/services/databases/influxdb2.nix b/nixos/modules/services/databases/influxdb2.nix index 20a94c03994b82..3dea70f6b8485c 100644 --- a/nixos/modules/services/databases/influxdb2.nix +++ b/nixos/modules/services/databases/influxdb2.nix @@ -1,8 +1,12 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit - (lib) + inherit (lib) any attrNames attrValues @@ -58,21 +62,26 @@ let ]; # Determines whether at least one active api token is defined - anyAuthDefined = - flip any (attrValues cfg.provision.organizations) - (o: o.present && flip any (attrValues o.auths) - (a: a.present && a.tokenFile != null)); - - provisionState = pkgs.writeText "provision_state.json" (builtins.toJSON { - inherit (cfg.provision) organizations users; - }); - - influxHost = "http://${escapeShellArg ( - if ! hasAttr "http-bind-address" cfg.settings - || hasInfix "0.0.0.0" cfg.settings.http-bind-address - then "localhost:8086" - else cfg.settings.http-bind-address - )}"; + anyAuthDefined = flip any (attrValues cfg.provision.organizations) ( + o: o.present && flip any (attrValues o.auths) (a: a.present && a.tokenFile != null) + ); + + provisionState = pkgs.writeText "provision_state.json" ( + builtins.toJSON { + inherit (cfg.provision) organizations users; + } + ); + + influxHost = "http://${ + escapeShellArg ( + if + !hasAttr "http-bind-address" cfg.settings || hasInfix "0.0.0.0" cfg.settings.http-bind-address + then + "localhost:8086" + else + cfg.settings.http-bind-address + ) + }"; waitUntilServiceIsReady = pkgs.writeShellScript "wait-until-service-is-ready" '' set -euo pipefail @@ -129,154 +138,170 @@ let fi ''; - organizationSubmodule = types.submodule (organizationSubmod: let - org = organizationSubmod.config._module.args.name; - in { - options = { - present = mkOption { - description = "Whether to ensure that this organization is present or absent."; - type = types.bool; - default = true; - }; + organizationSubmodule = types.submodule ( + organizationSubmod: + let + org = organizationSubmod.config._module.args.name; + in + { + options = { + present = mkOption { + description = "Whether to ensure that this organization is present or absent."; + type = types.bool; + default = true; + }; - description = mkOption { - description = "Optional description for the organization."; - default = null; - type = types.nullOr types.str; - }; + description = mkOption { + description = "Optional description for the organization."; + default = null; + type = types.nullOr types.str; + }; - buckets = mkOption { - description = "Buckets to provision in this organization."; - default = {}; - type = types.attrsOf (types.submodule (bucketSubmod: let - bucket = bucketSubmod.config._module.args.name; - in { - options = { - present = mkOption { - description = "Whether to ensure that this bucket is present or absent."; - type = types.bool; - default = true; - }; - - description = mkOption { - description = "Optional description for the bucket."; - default = null; - type = types.nullOr types.str; - }; - - retention = mkOption { - type = types.ints.unsigned; - default = 0; - description = "The duration in seconds for which the bucket will retain data (0 is infinite)."; - }; - }; - })); - }; + buckets = mkOption { + description = "Buckets to provision in this organization."; + default = { }; + type = types.attrsOf ( + types.submodule ( + bucketSubmod: + let + bucket = bucketSubmod.config._module.args.name; + in + { + options = { + present = mkOption { + description = "Whether to ensure that this bucket is present or absent."; + type = types.bool; + default = true; + }; + + description = mkOption { + description = "Optional description for the bucket."; + default = null; + type = types.nullOr types.str; + }; + + retention = mkOption { + type = types.ints.unsigned; + default = 0; + description = "The duration in seconds for which the bucket will retain data (0 is infinite)."; + }; + }; + } + ) + ); + }; - auths = mkOption { - description = "API tokens to provision for the user in this organization."; - default = {}; - type = types.attrsOf (types.submodule (authSubmod: let - auth = authSubmod.config._module.args.name; - in { - options = { - id = mkOption { - description = "A unique identifier for this authentication token. Since influx doesn't store names for tokens, this will be hashed and appended to the description to identify the token."; - readOnly = true; - default = builtins.substring 0 32 (builtins.hashString "sha256" "${org}:${auth}"); - defaultText = ""; - type = types.str; - }; - - present = mkOption { - description = "Whether to ensure that this user is present or absent."; - type = types.bool; - default = true; - }; - - description = mkOption { - description = '' - Optional description for the API token. - Note that the actual token will always be created with a descriptionregardless - of whether this is given or not. The name is always added plus a unique suffix - to later identify the token to track whether it has already been created. - ''; - default = null; - type = types.nullOr types.str; - }; - - tokenFile = mkOption { - type = types.nullOr types.path; - default = null; - description = "The token value. If not given, influx will automatically generate one."; - }; - - operator = mkOption { - description = "Grants all permissions in all organizations."; - default = false; - type = types.bool; - }; - - allAccess = mkOption { - description = "Grants all permissions in the associated organization."; - default = false; - type = types.bool; - }; - - readPermissions = mkOption { - description = '' - The read permissions to include for this token. Access is usually granted only - for resources in the associated organization. - - Available permissions are `authorizations`, `buckets`, `dashboards`, - `orgs`, `tasks`, `telegrafs`, `users`, `variables`, `secrets`, `labels`, `views`, - `documents`, `notificationRules`, `notificationEndpoints`, `checks`, `dbrp`, - `annotations`, `sources`, `scrapers`, `notebooks`, `remotes`, `replications`. - - Refer to `influx auth create --help` for a full list with descriptions. - - `buckets` grants read access to all associated buckets. Use `readBuckets` to define - more granular access permissions. - ''; - default = []; - type = types.listOf (types.enum validPermissions); - }; - - writePermissions = mkOption { - description = '' - The read permissions to include for this token. Access is usually granted only - for resources in the associated organization. - - Available permissions are `authorizations`, `buckets`, `dashboards`, - `orgs`, `tasks`, `telegrafs`, `users`, `variables`, `secrets`, `labels`, `views`, - `documents`, `notificationRules`, `notificationEndpoints`, `checks`, `dbrp`, - `annotations`, `sources`, `scrapers`, `notebooks`, `remotes`, `replications`. - - Refer to `influx auth create --help` for a full list with descriptions. - - `buckets` grants write access to all associated buckets. Use `writeBuckets` to define - more granular access permissions. - ''; - default = []; - type = types.listOf (types.enum validPermissions); - }; - - readBuckets = mkOption { - description = "The organization's buckets which should be allowed to be read"; - default = []; - type = types.listOf types.str; - }; - - writeBuckets = mkOption { - description = "The organization's buckets which should be allowed to be written"; - default = []; - type = types.listOf types.str; - }; - }; - })); + auths = mkOption { + description = "API tokens to provision for the user in this organization."; + default = { }; + type = types.attrsOf ( + types.submodule ( + authSubmod: + let + auth = authSubmod.config._module.args.name; + in + { + options = { + id = mkOption { + description = "A unique identifier for this authentication token. Since influx doesn't store names for tokens, this will be hashed and appended to the description to identify the token."; + readOnly = true; + default = builtins.substring 0 32 (builtins.hashString "sha256" "${org}:${auth}"); + defaultText = ""; + type = types.str; + }; + + present = mkOption { + description = "Whether to ensure that this user is present or absent."; + type = types.bool; + default = true; + }; + + description = mkOption { + description = '' + Optional description for the API token. + Note that the actual token will always be created with a descriptionregardless + of whether this is given or not. The name is always added plus a unique suffix + to later identify the token to track whether it has already been created. + ''; + default = null; + type = types.nullOr types.str; + }; + + tokenFile = mkOption { + type = types.nullOr types.path; + default = null; + description = "The token value. If not given, influx will automatically generate one."; + }; + + operator = mkOption { + description = "Grants all permissions in all organizations."; + default = false; + type = types.bool; + }; + + allAccess = mkOption { + description = "Grants all permissions in the associated organization."; + default = false; + type = types.bool; + }; + + readPermissions = mkOption { + description = '' + The read permissions to include for this token. Access is usually granted only + for resources in the associated organization. + + Available permissions are `authorizations`, `buckets`, `dashboards`, + `orgs`, `tasks`, `telegrafs`, `users`, `variables`, `secrets`, `labels`, `views`, + `documents`, `notificationRules`, `notificationEndpoints`, `checks`, `dbrp`, + `annotations`, `sources`, `scrapers`, `notebooks`, `remotes`, `replications`. + + Refer to `influx auth create --help` for a full list with descriptions. + + `buckets` grants read access to all associated buckets. Use `readBuckets` to define + more granular access permissions. + ''; + default = [ ]; + type = types.listOf (types.enum validPermissions); + }; + + writePermissions = mkOption { + description = '' + The read permissions to include for this token. Access is usually granted only + for resources in the associated organization. + + Available permissions are `authorizations`, `buckets`, `dashboards`, + `orgs`, `tasks`, `telegrafs`, `users`, `variables`, `secrets`, `labels`, `views`, + `documents`, `notificationRules`, `notificationEndpoints`, `checks`, `dbrp`, + `annotations`, `sources`, `scrapers`, `notebooks`, `remotes`, `replications`. + + Refer to `influx auth create --help` for a full list with descriptions. + + `buckets` grants write access to all associated buckets. Use `writeBuckets` to define + more granular access permissions. + ''; + default = [ ]; + type = types.listOf (types.enum validPermissions); + }; + + readBuckets = mkOption { + description = "The organization's buckets which should be allowed to be read"; + default = [ ]; + type = types.listOf types.str; + }; + + writeBuckets = mkOption { + description = "The organization's buckets which should be allowed to be written"; + default = [ ]; + type = types.listOf types.str; + }; + }; + } + ) + ); + }; }; - }; - }); + } + ); in { options = { @@ -347,37 +372,43 @@ in }; } ''; - default = {}; + default = { }; type = types.attrsOf organizationSubmodule; }; users = mkOption { description = "Users to provision."; - default = {}; + default = { }; example = literalExpression '' { # admin = {}; /* The initialSetup.username will automatically be added. */ myuser.passwordFile = "/run/secrets/myuser_password"; } ''; - type = types.attrsOf (types.submodule (userSubmod: let - user = userSubmod.config._module.args.name; - org = userSubmod.config.org; - in { - options = { - present = mkOption { - description = "Whether to ensure that this user is present or absent."; - type = types.bool; - default = true; - }; - - passwordFile = mkOption { - description = "Password for the user. If unset, the user will not be able to log in until a password is set by an operator! Don't use a file from the nix store!"; - default = null; - type = types.nullOr types.path; - }; - }; - })); + type = types.attrsOf ( + types.submodule ( + userSubmod: + let + user = userSubmod.config._module.args.name; + org = userSubmod.config.org; + in + { + options = { + present = mkOption { + description = "Whether to ensure that this user is present or absent."; + type = types.bool; + default = true; + }; + + passwordFile = mkOption { + description = "Password for the user. If unset, the user will not be able to log in until a password is set by an operator! Don't use a file from the nix store!"; + default = null; + type = types.nullOr types.path; + }; + }; + } + ) + ); }; }; }; @@ -391,31 +422,47 @@ in message = "services.influxdb2.config: bolt-path and engine-path should not be set as they are managed by systemd"; } ] - ++ flatten (flip mapAttrsToList cfg.provision.organizations (orgName: org: - flip mapAttrsToList org.auths (authName: auth: - [ - { - assertion = 1 == count (x: x) [ - auth.operator - auth.allAccess - (auth.readPermissions != [] - || auth.writePermissions != [] - || auth.readBuckets != [] - || auth.writeBuckets != []) - ]; - message = "influxdb2: provision.organizations.${orgName}.auths.${authName}: The `operator` and `allAccess` options are mutually exclusive with each other and the granular permission settings."; - } - (let unknownBuckets = subtractLists (attrNames org.buckets) auth.readBuckets; in { - assertion = unknownBuckets == []; - message = "influxdb2: provision.organizations.${orgName}.auths.${authName}: Refers to invalid buckets in readBuckets: ${toString unknownBuckets}"; - }) - (let unknownBuckets = subtractLists (attrNames org.buckets) auth.writeBuckets; in { - assertion = unknownBuckets == []; - message = "influxdb2: provision.organizations.${orgName}.auths.${authName}: Refers to invalid buckets in writeBuckets: ${toString unknownBuckets}"; - }) - ] + ++ flatten ( + flip mapAttrsToList cfg.provision.organizations ( + orgName: org: + flip mapAttrsToList org.auths ( + authName: auth: [ + { + assertion = + 1 == count (x: x) [ + auth.operator + auth.allAccess + ( + auth.readPermissions != [ ] + || auth.writePermissions != [ ] + || auth.readBuckets != [ ] + || auth.writeBuckets != [ ] + ) + ]; + message = "influxdb2: provision.organizations.${orgName}.auths.${authName}: The `operator` and `allAccess` options are mutually exclusive with each other and the granular permission settings."; + } + ( + let + unknownBuckets = subtractLists (attrNames org.buckets) auth.readBuckets; + in + { + assertion = unknownBuckets == [ ]; + message = "influxdb2: provision.organizations.${orgName}.auths.${authName}: Refers to invalid buckets in readBuckets: ${toString unknownBuckets}"; + } + ) + ( + let + unknownBuckets = subtractLists (attrNames org.buckets) auth.writeBuckets; + in + { + assertion = unknownBuckets == [ ]; + message = "influxdb2: provision.organizations.${orgName}.auths.${authName}: Refers to invalid buckets in writeBuckets: ${toString unknownBuckets}"; + } + ) + ] + ) ) - )); + ); services.influxdb2.provision = mkIf cfg.provision.enable { organizations.${cfg.provision.initialSetup.organization} = { @@ -453,13 +500,16 @@ in "admin-token:${cfg.provision.initialSetup.tokenFile}" ]; - ExecStartPost = [ - waitUntilServiceIsReady - ] ++ (lib.optionals cfg.provision.enable ( - [provisioningScript] ++ - # Only the restarter runs with elevated privileges - optional anyAuthDefined "+${restarterScript}" - )); + ExecStartPost = + [ + waitUntilServiceIsReady + ] + ++ (lib.optionals cfg.provision.enable ( + [ provisioningScript ] + ++ + # Only the restarter runs with elevated privileges + optional anyAuthDefined "+${restarterScript}" + )); }; path = [ @@ -469,23 +519,32 @@ in # Mark if this is the first startup so postStart can do the initial setup. # Also extract any token secret mappings and apply them if this isn't the first start. - preStart = let - tokenPaths = listToAttrs (flatten - # For all organizations - (flip mapAttrsToList cfg.provision.organizations - # For each contained token that has a token file - (_: org: flip mapAttrsToList (filterAttrs (_: x: x.tokenFile != null) org.auths) - # Collect id -> tokenFile for the mapping - (_: auth: nameValuePair auth.id auth.tokenFile)))); - tokenMappings = pkgs.writeText "token_mappings.json" (builtins.toJSON tokenPaths); - in mkIf cfg.provision.enable '' - if ! test -e "$STATE_DIRECTORY/influxd.bolt"; then - touch "$STATE_DIRECTORY/.first_startup" - else - # Manipulate provisioned api tokens if necessary - ${getExe pkgs.influxdb2-token-manipulator} "$STATE_DIRECTORY/influxd.bolt" ${tokenMappings} - fi - ''; + preStart = + let + tokenPaths = listToAttrs ( + flatten + # For all organizations + ( + flip mapAttrsToList cfg.provision.organizations + # For each contained token that has a token file + ( + _: org: + flip mapAttrsToList (filterAttrs (_: x: x.tokenFile != null) org.auths) + # Collect id -> tokenFile for the mapping + (_: auth: nameValuePair auth.id auth.tokenFile) + ) + ) + ); + tokenMappings = pkgs.writeText "token_mappings.json" (builtins.toJSON tokenPaths); + in + mkIf cfg.provision.enable '' + if ! test -e "$STATE_DIRECTORY/influxd.bolt"; then + touch "$STATE_DIRECTORY/.first_startup" + else + # Manipulate provisioned api tokens if necessary + ${getExe pkgs.influxdb2-token-manipulator} "$STATE_DIRECTORY/influxd.bolt" ${tokenMappings} + fi + ''; }; users.extraUsers.influxdb2 = { @@ -493,8 +552,11 @@ in group = "influxdb2"; }; - users.extraGroups.influxdb2 = {}; + users.extraGroups.influxdb2 = { }; }; - meta.maintainers = with lib.maintainers; [ nickcao oddlama ]; + meta.maintainers = with lib.maintainers; [ + nickcao + oddlama + ]; } diff --git a/nixos/modules/services/databases/lldap.nix b/nixos/modules/services/databases/lldap.nix index e014a88b3c4fa8..a9fbe8f7e11a9d 100644 --- a/nixos/modules/services/databases/lldap.nix +++ b/nixos/modules/services/databases/lldap.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.services.lldap; @@ -111,16 +117,18 @@ in # an attacker could create a valid admin jwt access token fairly trivially. # Because there are 3 different ways `jwt_secret` can be provided, we check if any one of them is present, # and if not, bootstrap a secret in `/var/lib/lldap/jwt_secret_file` and give that to lldap. - script = lib.optionalString (!cfg.settings ? jwt_secret) '' - if [[ -z "$LLDAP_JWT_SECRET_FILE" ]] && [[ -z "$LLDAP_JWT_SECRET" ]]; then - if [[ ! -e "./jwt_secret_file" ]]; then - ${lib.getExe pkgs.openssl} rand -base64 -out ./jwt_secret_file 32 + script = + lib.optionalString (!cfg.settings ? jwt_secret) '' + if [[ -z "$LLDAP_JWT_SECRET_FILE" ]] && [[ -z "$LLDAP_JWT_SECRET" ]]; then + if [[ ! -e "./jwt_secret_file" ]]; then + ${lib.getExe pkgs.openssl} rand -base64 -out ./jwt_secret_file 32 + fi + export LLDAP_JWT_SECRET_FILE="./jwt_secret_file" fi - export LLDAP_JWT_SECRET_FILE="./jwt_secret_file" - fi - '' + '' - ${lib.getExe cfg.package} run --config-file ${format.generate "lldap_config.toml" cfg.settings} - ''; + '' + + '' + ${lib.getExe cfg.package} run --config-file ${format.generate "lldap_config.toml" cfg.settings} + ''; serviceConfig = { StateDirectory = "lldap"; StateDirectoryMode = "0750"; diff --git a/nixos/modules/services/databases/memcached.nix b/nixos/modules/services/databases/memcached.nix index 29da763e5751b6..a656bd292b4696 100644 --- a/nixos/modules/services/databases/memcached.nix +++ b/nixos/modules/services/databases/memcached.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.memcached; @@ -50,7 +55,7 @@ in extraOptions = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = "A list of extra options that will be added as a suffix when running memcached."; }; }; @@ -66,7 +71,7 @@ in memcached.isSystemUser = true; memcached.group = "memcached"; }; - users.groups = lib.optionalAttrs (cfg.user == "memcached") { memcached = {}; }; + users.groups = lib.optionalAttrs (cfg.user == "memcached") { memcached = { }; }; environment.systemPackages = [ memcached ]; @@ -78,11 +83,14 @@ in serviceConfig = { ExecStart = - let - networking = if cfg.enableUnixSocket - then "-s /run/memcached/memcached.sock" - else "-l ${cfg.listen} -p ${toString cfg.port}"; - in "${memcached}/bin/memcached ${networking} -m ${toString cfg.maxMemory} -c ${toString cfg.maxConnections} ${lib.concatStringsSep " " cfg.extraOptions}"; + let + networking = + if cfg.enableUnixSocket then + "-s /run/memcached/memcached.sock" + else + "-l ${cfg.listen} -p ${toString cfg.port}"; + in + "${memcached}/bin/memcached ${networking} -m ${toString cfg.maxMemory} -c ${toString cfg.maxConnections} ${lib.concatStringsSep " " cfg.extraOptions}"; User = cfg.user; @@ -107,7 +115,7 @@ in }; }; imports = [ - (lib.mkRemovedOptionModule ["services" "memcached" "socket"] '' + (lib.mkRemovedOptionModule [ "services" "memcached" "socket" ] '' This option was replaced by a fixed unix socket path at /run/memcached/memcached.sock enabled using services.memcached.enableUnixSocket. '') ]; diff --git a/nixos/modules/services/databases/monetdb.nix b/nixos/modules/services/databases/monetdb.nix index 42c9683fdb5e72..9fc79e495678e7 100644 --- a/nixos/modules/services/databases/monetdb.nix +++ b/nixos/modules/services/databases/monetdb.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.monetdb; -in { +in +{ meta.maintainers = with lib.maintainers; [ StillerHarpo ]; ###### interface diff --git a/nixos/modules/services/databases/mongodb.nix b/nixos/modules/services/databases/mongodb.nix index e3619ad3fe6581..90b749574bf579 100644 --- a/nixos/modules/services/databases/mongodb.nix +++ b/nixos/modules/services/databases/mongodb.nix @@ -1,20 +1,26 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.mongodb; mongodb = cfg.package; - mongoCnf = cfg: pkgs.writeText "mongodb.conf" - '' - net.bindIp: ${cfg.bind_ip} - ${lib.optionalString cfg.quiet "systemLog.quiet: true"} - systemLog.destination: syslog - storage.dbPath: ${cfg.dbpath} - ${lib.optionalString cfg.enableAuth "security.authorization: enabled"} - ${lib.optionalString (cfg.replSetName != "") "replication.replSetName: ${cfg.replSetName}"} - ${cfg.extraConfig} - ''; + mongoCnf = + cfg: + pkgs.writeText "mongodb.conf" '' + net.bindIp: ${cfg.bind_ip} + ${lib.optionalString cfg.quiet "systemLog.quiet: true"} + systemLog.destination: syslog + storage.dbPath: ${cfg.dbpath} + ${lib.optionalString cfg.enableAuth "security.authorization: enabled"} + ${lib.optionalString (cfg.replSetName != "") "replication.replSetName: ${cfg.replSetName}"} + ${cfg.extraConfig} + ''; in @@ -101,44 +107,49 @@ in }; - ###### implementation config = lib.mkIf config.services.mongodb.enable { assertions = [ - { assertion = !cfg.enableAuth || cfg.initialRootPassword != null; + { + assertion = !cfg.enableAuth || cfg.initialRootPassword != null; message = "`enableAuth` requires `initialRootPassword` to be set."; } ]; - users.users.mongodb = lib.mkIf (cfg.user == "mongodb") - { name = "mongodb"; - isSystemUser = true; - group = "mongodb"; - description = "MongoDB server user"; - }; - users.groups.mongodb = lib.mkIf (cfg.user == "mongodb") {}; + users.users.mongodb = lib.mkIf (cfg.user == "mongodb") { + name = "mongodb"; + isSystemUser = true; + group = "mongodb"; + description = "MongoDB server user"; + }; + users.groups.mongodb = lib.mkIf (cfg.user == "mongodb") { }; environment.systemPackages = [ mongodb ]; - systemd.services.mongodb = - { description = "MongoDB server"; + systemd.services.mongodb = { + description = "MongoDB server"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; - serviceConfig = { - ExecStart = "${mongodb}/bin/mongod --config ${mongoCnf cfg} --fork --pidfilepath ${cfg.pidFile}"; - User = cfg.user; - PIDFile = cfg.pidFile; - Type = "forking"; - TimeoutStartSec=120; # initial creating of journal can take some time - PermissionsStartOnly = true; - }; + serviceConfig = { + ExecStart = "${mongodb}/bin/mongod --config ${mongoCnf cfg} --fork --pidfilepath ${cfg.pidFile}"; + User = cfg.user; + PIDFile = cfg.pidFile; + Type = "forking"; + TimeoutStartSec = 120; # initial creating of journal can take some time + PermissionsStartOnly = true; + }; - preStart = let - cfg_ = cfg // { enableAuth = false; bind_ip = "127.0.0.1"; }; - in '' + preStart = + let + cfg_ = cfg // { + enableAuth = false; + bind_ip = "127.0.0.1"; + }; + in + '' rm ${cfg.dbpath}/mongod.lock || true if ! test -e ${cfg.dbpath}; then install -d -m0700 -o ${cfg.user} ${cfg.dbpath} @@ -147,7 +158,8 @@ in fi if ! test -e ${cfg.pidFile}; then install -D -o ${cfg.user} /dev/null ${cfg.pidFile} - fi '' + lib.optionalString cfg.enableAuth '' + fi '' + + lib.optionalString cfg.enableAuth '' if ! test -e "${cfg.dbpath}/.auth_setup_complete"; then systemd-run --unit=mongodb-for-setup --uid=${cfg.user} ${mongodb}/bin/mongod --config ${mongoCnf cfg_} @@ -172,15 +184,15 @@ in systemctl stop mongodb-for-setup fi ''; - postStart = '' - if test -e "${cfg.dbpath}/.first_startup"; then - ${lib.optionalString (cfg.initialScript != null) '' - ${mongodb}/bin/mongo ${lib.optionalString (cfg.enableAuth) "-u root -p ${cfg.initialRootPassword}"} admin "${cfg.initialScript}" - ''} - rm -f "${cfg.dbpath}/.first_startup" - fi - ''; - }; + postStart = '' + if test -e "${cfg.dbpath}/.first_startup"; then + ${lib.optionalString (cfg.initialScript != null) '' + ${mongodb}/bin/mongo ${lib.optionalString (cfg.enableAuth) "-u root -p ${cfg.initialRootPassword}"} admin "${cfg.initialScript}" + ''} + rm -f "${cfg.dbpath}/.first_startup" + fi + ''; + }; }; diff --git a/nixos/modules/services/databases/neo4j.nix b/nixos/modules/services/databases/neo4j.nix index c4e19a47ac7f0c..5b0106eb51d0db 100644 --- a/nixos/modules/services/databases/neo4j.nix +++ b/nixos/modules/services/databases/neo4j.nix @@ -1,34 +1,41 @@ -{ config, options, lib, pkgs, ... }: +{ + config, + options, + lib, + pkgs, + ... +}: let cfg = config.services.neo4j; opt = options.services.neo4j; certDirOpt = options.services.neo4j.directories.certificates; - isDefaultPathOption = opt: lib.isOption opt && opt.type == lib.types.path && opt.highestPrio >= 1500; - - sslPolicies = lib.mapAttrsToList ( - name: conf: '' - dbms.ssl.policy.${name}.allow_key_generation=${lib.boolToString conf.allowKeyGeneration} - dbms.ssl.policy.${name}.base_directory=${conf.baseDirectory} - ${lib.optionalString (conf.ciphers != null) '' - dbms.ssl.policy.${name}.ciphers=${lib.concatStringsSep "," conf.ciphers} - ''} - dbms.ssl.policy.${name}.client_auth=${conf.clientAuth} - ${if lib.length (lib.splitString "/" conf.privateKey) > 1 then + isDefaultPathOption = + opt: lib.isOption opt && opt.type == lib.types.path && opt.highestPrio >= 1500; + + sslPolicies = lib.mapAttrsToList (name: conf: '' + dbms.ssl.policy.${name}.allow_key_generation=${lib.boolToString conf.allowKeyGeneration} + dbms.ssl.policy.${name}.base_directory=${conf.baseDirectory} + ${lib.optionalString (conf.ciphers != null) '' + dbms.ssl.policy.${name}.ciphers=${lib.concatStringsSep "," conf.ciphers} + ''} + dbms.ssl.policy.${name}.client_auth=${conf.clientAuth} + ${ + if lib.length (lib.splitString "/" conf.privateKey) > 1 then "dbms.ssl.policy.${name}.private_key=${conf.privateKey}" else "dbms.ssl.policy.${name}.private_key=${conf.baseDirectory}/${conf.privateKey}" - } - ${if lib.length (lib.splitString "/" conf.privateKey) > 1 then + } + ${ + if lib.length (lib.splitString "/" conf.privateKey) > 1 then "dbms.ssl.policy.${name}.public_certificate=${conf.publicCertificate}" else "dbms.ssl.policy.${name}.public_certificate=${conf.baseDirectory}/${conf.publicCertificate}" - } - dbms.ssl.policy.${name}.revoked_dir=${conf.revokedDir} - dbms.ssl.policy.${name}.tls_versions=${lib.concatStringsSep "," conf.tlsVersions} - dbms.ssl.policy.${name}.trust_all=${lib.boolToString conf.trustAll} - dbms.ssl.policy.${name}.trusted_dir=${conf.trustedDir} - '' - ) cfg.ssl.policies; + } + dbms.ssl.policy.${name}.revoked_dir=${conf.revokedDir} + dbms.ssl.policy.${name}.tls_versions=${lib.concatStringsSep "," conf.tlsVersions} + dbms.ssl.policy.${name}.trust_all=${lib.boolToString conf.trustAll} + dbms.ssl.policy.${name}.trusted_dir=${conf.trustedDir} + '') cfg.ssl.policies; serverConfig = pkgs.writeText "neo4j.conf" '' # General @@ -44,7 +51,7 @@ let server.directories.lib=${cfg.package}/share/neo4j/lib ${lib.optionalString (cfg.constrainLoadCsv) '' server.directories.import=${cfg.directories.imports} - ''} + ''} # Directories (read and write) server.directories.data=${cfg.directories.data} @@ -93,20 +100,61 @@ let ${cfg.extraServerConfig} ''; -in { +in +{ imports = [ - (lib.mkRenamedOptionModule [ "services" "neo4j" "host" ] [ "services" "neo4j" "defaultListenAddress" ]) - (lib.mkRenamedOptionModule [ "services" "neo4j" "listenAddress" ] [ "services" "neo4j" "defaultListenAddress" ]) - (lib.mkRenamedOptionModule [ "services" "neo4j" "enableBolt" ] [ "services" "neo4j" "bolt" "enable" ]) - (lib.mkRenamedOptionModule [ "services" "neo4j" "enableHttps" ] [ "services" "neo4j" "https" "enable" ]) - (lib.mkRenamedOptionModule [ "services" "neo4j" "certDir" ] [ "services" "neo4j" "directories" "certificates" ]) - (lib.mkRenamedOptionModule [ "services" "neo4j" "dataDir" ] [ "services" "neo4j" "directories" "home" ]) - (lib.mkRemovedOptionModule [ "services" "neo4j" "port" ] "Use services.neo4j.http.listenAddress instead.") - (lib.mkRemovedOptionModule [ "services" "neo4j" "boltPort" ] "Use services.neo4j.bolt.listenAddress instead.") - (lib.mkRemovedOptionModule [ "services" "neo4j" "httpsPort" ] "Use services.neo4j.https.listenAddress instead.") - (lib.mkRemovedOptionModule [ "services" "neo4j" "shell" "enabled" ] "shell.enabled was removed upstream") - (lib.mkRemovedOptionModule [ "services" "neo4j" "udc" "enabled" ] "udc.enabled was removed upstream") + (lib.mkRenamedOptionModule + [ "services" "neo4j" "host" ] + [ "services" "neo4j" "defaultListenAddress" ] + ) + (lib.mkRenamedOptionModule + [ "services" "neo4j" "listenAddress" ] + [ "services" "neo4j" "defaultListenAddress" ] + ) + (lib.mkRenamedOptionModule + [ "services" "neo4j" "enableBolt" ] + [ "services" "neo4j" "bolt" "enable" ] + ) + (lib.mkRenamedOptionModule + [ "services" "neo4j" "enableHttps" ] + [ "services" "neo4j" "https" "enable" ] + ) + (lib.mkRenamedOptionModule + [ "services" "neo4j" "certDir" ] + [ "services" "neo4j" "directories" "certificates" ] + ) + (lib.mkRenamedOptionModule + [ "services" "neo4j" "dataDir" ] + [ "services" "neo4j" "directories" "home" ] + ) + (lib.mkRemovedOptionModule [ + "services" + "neo4j" + "port" + ] "Use services.neo4j.http.listenAddress instead.") + (lib.mkRemovedOptionModule [ + "services" + "neo4j" + "boltPort" + ] "Use services.neo4j.bolt.listenAddress instead.") + (lib.mkRemovedOptionModule [ + "services" + "neo4j" + "httpsPort" + ] "Use services.neo4j.https.listenAddress instead.") + (lib.mkRemovedOptionModule [ + "services" + "neo4j" + "shell" + "enabled" + ] "shell.enabled was removed upstream") + (lib.mkRemovedOptionModule [ + "services" + "neo4j" + "udc" + "enabled" + ] "udc.enabled was removed upstream") ]; ###### interface @@ -219,7 +267,11 @@ in { }; tlsLevel = lib.mkOption { - type = lib.types.enum [ "REQUIRED" "OPTIONAL" "DISABLED" ]; + type = lib.types.enum [ + "REQUIRED" + "OPTIONAL" + "DISABLED" + ]; default = "OPTIONAL"; description = '' SSL/TSL requirement level for BOLT traffic. @@ -376,163 +428,179 @@ in { }; ssl.policies = lib.mkOption { - type = with lib.types; attrsOf (submodule ({ name, config, options, ... }: { - options = { - - allowKeyGeneration = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Allows the generation of a private key and associated self-signed - certificate. Only performed when both objects cannot be found for - this policy. It is recommended to turn this off again after keys - have been generated. - - The public certificate is required to be duplicated to the - directory holding trusted certificates as defined by the - {option}`trustedDir` option. - - Keys should in general be generated and distributed offline by a - trusted certificate authority and not by utilizing this mode. - ''; - }; - - baseDirectory = lib.mkOption { - type = lib.types.path; - default = "${cfg.directories.certificates}/${name}"; - defaultText = lib.literalExpression ''"''${config.${opt.directories.certificates}}/''${name}"''; - description = '' - The mandatory base directory for cryptographic objects of this - policy. This path is only automatically generated when this - option as well as {option}`directories.certificates` are - left at their default. Ensure read/write permissions are given - to the Neo4j daemon user `neo4j`. - - It is also possible to override each individual - configuration with absolute paths. See the - {option}`privateKey` and {option}`publicCertificate` - policy options. - ''; - }; - - ciphers = lib.mkOption { - type = lib.types.nullOr (lib.types.listOf lib.types.str); - default = null; - description = '' - Restrict the allowed ciphers of this policy to those defined - here. The default ciphers are those of the JVM platform. - ''; - }; - - clientAuth = lib.mkOption { - type = lib.types.enum [ "NONE" "OPTIONAL" "REQUIRE" ]; - default = "REQUIRE"; - description = '' - The client authentication stance for this policy. - ''; - }; - - privateKey = lib.mkOption { - type = lib.types.str; - default = "private.key"; - description = '' - The name of private PKCS #8 key file for this policy to be found - in the {option}`baseDirectory`, or the absolute path to - the key file. It is mandatory that a key can be found or generated. - ''; - }; - - publicCertificate = lib.mkOption { - type = lib.types.str; - default = "public.crt"; - description = '' - The name of public X.509 certificate (chain) file in PEM format - for this policy to be found in the {option}`baseDirectory`, - or the absolute path to the certificate file. It is mandatory - that a certificate can be found or generated. - - The public certificate is required to be duplicated to the - directory holding trusted certificates as defined by the - {option}`trustedDir` option. - ''; - }; - - revokedDir = lib.mkOption { - type = lib.types.path; - default = "${config.baseDirectory}/revoked"; - defaultText = lib.literalExpression ''"''${config.${options.baseDirectory}}/revoked"''; - description = '' - Path to directory of CRLs (Certificate Revocation Lists) in - PEM format. Must be an absolute path. The existence of this - directory is mandatory and will need to be created manually when: - setting this option to something other than its default; setting - either this policy's {option}`baseDirectory` or - {option}`directories.certificates` to something other than - their default. Ensure read/write permissions are given to the - Neo4j daemon user `neo4j`. - ''; - }; - - tlsVersions = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = [ "TLSv1.2" ]; - description = '' - Restrict the TLS protocol versions of this policy to those - defined here. - ''; - }; - - trustAll = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Makes this policy trust all remote parties. Enabling this is not - recommended and the policy's trusted directory will be ignored. - Use of this mode is discouraged. It would offer encryption but - no security. - ''; - }; - - trustedDir = lib.mkOption { - type = lib.types.path; - default = "${config.baseDirectory}/trusted"; - defaultText = lib.literalExpression ''"''${config.${options.baseDirectory}}/trusted"''; - description = '' - Path to directory of X.509 certificates in PEM format for - trusted parties. Must be an absolute path. The existence of this - directory is mandatory and will need to be created manually when: - setting this option to something other than its default; setting - either this policy's {option}`baseDirectory` or - {option}`directories.certificates` to something other than - their default. Ensure read/write permissions are given to the - Neo4j daemon user `neo4j`. - - The public certificate as defined by - {option}`publicCertificate` is required to be duplicated - to this directory. - ''; - }; - - directoriesToCreate = lib.mkOption { - type = lib.types.listOf lib.types.path; - internal = true; - readOnly = true; - description = '' - Directories of this policy that will be created automatically - when the certificates directory is left at its default value. - This includes all options of type path that are left at their - default value. - ''; - }; - - }; - - config.directoriesToCreate = lib.optionals - (certDirOpt.highestPrio >= 1500 && options.baseDirectory.highestPrio >= 1500) - (map (opt: opt.value) (lib.filter isDefaultPathOption (lib.attrValues options))); - - })); - default = {}; + type = + with lib.types; + attrsOf ( + submodule ( + { + name, + config, + options, + ... + }: + { + options = { + + allowKeyGeneration = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Allows the generation of a private key and associated self-signed + certificate. Only performed when both objects cannot be found for + this policy. It is recommended to turn this off again after keys + have been generated. + + The public certificate is required to be duplicated to the + directory holding trusted certificates as defined by the + {option}`trustedDir` option. + + Keys should in general be generated and distributed offline by a + trusted certificate authority and not by utilizing this mode. + ''; + }; + + baseDirectory = lib.mkOption { + type = lib.types.path; + default = "${cfg.directories.certificates}/${name}"; + defaultText = lib.literalExpression ''"''${config.${opt.directories.certificates}}/''${name}"''; + description = '' + The mandatory base directory for cryptographic objects of this + policy. This path is only automatically generated when this + option as well as {option}`directories.certificates` are + left at their default. Ensure read/write permissions are given + to the Neo4j daemon user `neo4j`. + + It is also possible to override each individual + configuration with absolute paths. See the + {option}`privateKey` and {option}`publicCertificate` + policy options. + ''; + }; + + ciphers = lib.mkOption { + type = lib.types.nullOr (lib.types.listOf lib.types.str); + default = null; + description = '' + Restrict the allowed ciphers of this policy to those defined + here. The default ciphers are those of the JVM platform. + ''; + }; + + clientAuth = lib.mkOption { + type = lib.types.enum [ + "NONE" + "OPTIONAL" + "REQUIRE" + ]; + default = "REQUIRE"; + description = '' + The client authentication stance for this policy. + ''; + }; + + privateKey = lib.mkOption { + type = lib.types.str; + default = "private.key"; + description = '' + The name of private PKCS #8 key file for this policy to be found + in the {option}`baseDirectory`, or the absolute path to + the key file. It is mandatory that a key can be found or generated. + ''; + }; + + publicCertificate = lib.mkOption { + type = lib.types.str; + default = "public.crt"; + description = '' + The name of public X.509 certificate (chain) file in PEM format + for this policy to be found in the {option}`baseDirectory`, + or the absolute path to the certificate file. It is mandatory + that a certificate can be found or generated. + + The public certificate is required to be duplicated to the + directory holding trusted certificates as defined by the + {option}`trustedDir` option. + ''; + }; + + revokedDir = lib.mkOption { + type = lib.types.path; + default = "${config.baseDirectory}/revoked"; + defaultText = lib.literalExpression ''"''${config.${options.baseDirectory}}/revoked"''; + description = '' + Path to directory of CRLs (Certificate Revocation Lists) in + PEM format. Must be an absolute path. The existence of this + directory is mandatory and will need to be created manually when: + setting this option to something other than its default; setting + either this policy's {option}`baseDirectory` or + {option}`directories.certificates` to something other than + their default. Ensure read/write permissions are given to the + Neo4j daemon user `neo4j`. + ''; + }; + + tlsVersions = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ "TLSv1.2" ]; + description = '' + Restrict the TLS protocol versions of this policy to those + defined here. + ''; + }; + + trustAll = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Makes this policy trust all remote parties. Enabling this is not + recommended and the policy's trusted directory will be ignored. + Use of this mode is discouraged. It would offer encryption but + no security. + ''; + }; + + trustedDir = lib.mkOption { + type = lib.types.path; + default = "${config.baseDirectory}/trusted"; + defaultText = lib.literalExpression ''"''${config.${options.baseDirectory}}/trusted"''; + description = '' + Path to directory of X.509 certificates in PEM format for + trusted parties. Must be an absolute path. The existence of this + directory is mandatory and will need to be created manually when: + setting this option to something other than its default; setting + either this policy's {option}`baseDirectory` or + {option}`directories.certificates` to something other than + their default. Ensure read/write permissions are given to the + Neo4j daemon user `neo4j`. + + The public certificate as defined by + {option}`publicCertificate` is required to be duplicated + to this directory. + ''; + }; + + directoriesToCreate = lib.mkOption { + type = lib.types.listOf lib.types.path; + internal = true; + readOnly = true; + description = '' + Directories of this policy that will be created automatically + when the certificates directory is left at its default value. + This includes all options of type path that are left at their + default value. + ''; + }; + + }; + + config.directoriesToCreate = lib.optionals ( + certDirOpt.highestPrio >= 1500 && options.baseDirectory.highestPrio >= 1500 + ) (map (opt: opt.value) (lib.filter isDefaultPathOption (lib.attrValues options))); + + } + ) + ); + default = { }; description = '' Defines the SSL policies for use with Neo4j connectors. Each attribute of this set defines a policy, with the attribute name defining the name @@ -555,18 +623,28 @@ in { validPolicyNameString = lib.concatStringsSep ", " validPolicyNameList; # Capture various directories left at their default so they can be created. - defaultDirectoriesToCreate = map (opt: opt.value) (lib.filter isDefaultPathOption (lib.attrValues options.services.neo4j.directories)); - policyDirectoriesToCreate = lib.concatMap (pol: pol.directoriesToCreate) (lib.attrValues cfg.ssl.policies); + defaultDirectoriesToCreate = map (opt: opt.value) ( + lib.filter isDefaultPathOption (lib.attrValues options.services.neo4j.directories) + ); + policyDirectoriesToCreate = lib.concatMap (pol: pol.directoriesToCreate) ( + lib.attrValues cfg.ssl.policies + ); in lib.mkIf cfg.enable { assertions = [ - { assertion = !lib.elem "legacy" policyNameList; - message = "The policy 'legacy' is special to Neo4j, and its name is reserved."; } - { assertion = lib.elem cfg.bolt.sslPolicy validPolicyNameList; - message = "Invalid policy assigned: `services.neo4j.bolt.sslPolicy = \"${cfg.bolt.sslPolicy}\"`, defined policies are: ${validPolicyNameString}"; } - { assertion = lib.elem cfg.https.sslPolicy validPolicyNameList; - message = "Invalid policy assigned: `services.neo4j.https.sslPolicy = \"${cfg.https.sslPolicy}\"`, defined policies are: ${validPolicyNameString}"; } + { + assertion = !lib.elem "legacy" policyNameList; + message = "The policy 'legacy' is special to Neo4j, and its name is reserved."; + } + { + assertion = lib.elem cfg.bolt.sslPolicy validPolicyNameList; + message = "Invalid policy assigned: `services.neo4j.bolt.sslPolicy = \"${cfg.bolt.sslPolicy}\"`, defined policies are: ${validPolicyNameString}"; + } + { + assertion = lib.elem cfg.https.sslPolicy validPolicyNameList; + message = "Invalid policy assigned: `services.neo4j.https.sslPolicy = \"${cfg.https.sslPolicy}\"`, defined policies are: ${validPolicyNameString}"; + } ]; systemd.services.neo4j = { @@ -590,9 +668,8 @@ in { mkdir -m 0700 -p ${cfg.directories.home}/{conf,logs} # Create other sub-directories and policy directories that have been left at their default. - ${lib.concatMapStringsSep "\n" ( - dir: '' - mkdir -m 0700 -p ${dir} + ${lib.concatMapStringsSep "\n" (dir: '' + mkdir -m 0700 -p ${dir} '') (defaultDirectoriesToCreate ++ policyDirectoriesToCreate)} # Place the configuration where Neo4j can find it. @@ -611,7 +688,7 @@ in { description = "Neo4j daemon user"; home = cfg.directories.home; }; - users.groups.neo4j = {}; + users.groups.neo4j = { }; }; meta = { diff --git a/nixos/modules/services/databases/openldap.nix b/nixos/modules/services/databases/openldap.nix index 20b1f03021f0c4..6cf517d9dfdb8b 100644 --- a/nixos/modules/services/databases/openldap.nix +++ b/nixos/modules/services/databases/openldap.nix @@ -1,43 +1,52 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.openldap; openldap = cfg.package; configDir = if cfg.configDir != null then cfg.configDir else "/etc/openldap/slapd.d"; - ldapValueType = let - # Can't do types.either with multiple non-overlapping submodules, so define our own - singleLdapValueType = lib.mkOptionType rec { - name = "LDAP"; - # TODO: It would be nice to define a { secret = ...; } option, using - # systemd's LoadCredentials for secrets. That would remove the last - # barrier to using DynamicUser for openldap. This is blocked on - # systemd/systemd#19604 - description = '' - LDAP value - either a string, or an attrset containing - `path` or `base64` for included - values or base-64 encoded values respectively. - ''; - check = x: lib.isString x || (lib.isAttrs x && (x ? path || x ? base64)); - merge = lib.mergeEqualOption; - }; + ldapValueType = + let + # Can't do types.either with multiple non-overlapping submodules, so define our own + singleLdapValueType = lib.mkOptionType rec { + name = "LDAP"; + # TODO: It would be nice to define a { secret = ...; } option, using + # systemd's LoadCredentials for secrets. That would remove the last + # barrier to using DynamicUser for openldap. This is blocked on + # systemd/systemd#19604 + description = '' + LDAP value - either a string, or an attrset containing + `path` or `base64` for included + values or base-64 encoded values respectively. + ''; + check = x: lib.isString x || (lib.isAttrs x && (x ? path || x ? base64)); + merge = lib.mergeEqualOption; + }; + in # We don't coerce to lists of single values, as some values must be unique - in lib.types.either singleLdapValueType (lib.types.listOf singleLdapValueType); + lib.types.either singleLdapValueType (lib.types.listOf singleLdapValueType); ldapAttrsType = let options = { attrs = lib.mkOption { type = lib.types.attrsOf ldapValueType; - default = {}; + default = { }; description = "Attributes of the parent entry."; }; children = lib.mkOption { # Hide the child attributes, to avoid infinite recursion in e.g. documentation # Actual Nix evaluation is lazy, so this is not an issue there - type = let - hiddenOptions = lib.mapAttrs (name: attr: attr // { visible = false; }) options; - in lib.types.attrsOf (lib.types.submodule { options = hiddenOptions; }); - default = {}; + type = + let + hiddenOptions = lib.mapAttrs (name: attr: attr // { visible = false; }) options; + in + lib.types.attrsOf (lib.types.submodule { options = hiddenOptions; }); + default = { }; description = "Child entries of the current entry, with recursively the same structure."; example = lib.literalExpression '' { @@ -56,31 +65,46 @@ let }; includes = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; description = '' LDIF files to include after the parent's attributes but before its children. ''; }; }; - in lib.types.submodule { inherit options; }; + in + lib.types.submodule { inherit options; }; - valueToLdif = attr: values: let - listValues = if lib.isList values then values else lib.singleton values; - in map (value: - if lib.isAttrs value then - if lib.hasAttr "path" value - then "${attr}:< file://${value.path}" - else "${attr}:: ${value.base64}" - else "${attr}: ${lib.replaceStrings [ "\n" ] [ "\n " ] value}" - ) listValues; + valueToLdif = + attr: values: + let + listValues = if lib.isList values then values else lib.singleton values; + in + map ( + value: + if lib.isAttrs value then + if lib.hasAttr "path" value then "${attr}:< file://${value.path}" else "${attr}:: ${value.base64}" + else + "${attr}: ${lib.replaceStrings [ "\n" ] [ "\n " ] value}" + ) listValues; - attrsToLdif = dn: { attrs, children, includes, ... }: ['' - dn: ${dn} - ${lib.concatStringsSep "\n" (lib.flatten (lib.mapAttrsToList valueToLdif attrs))} - ''] ++ (map (path: "include: file://${path}\n") includes) ++ ( - lib.flatten (lib.mapAttrsToList (name: value: attrsToLdif "${name},${dn}" value) children) - ); -in { + attrsToLdif = + dn: + { + attrs, + children, + includes, + ... + }: + [ + '' + dn: ${dn} + ${lib.concatStringsSep "\n" (lib.flatten (lib.mapAttrsToList valueToLdif attrs))} + '' + ] + ++ (map (path: "include: file://${path}\n") includes) + ++ (lib.flatten (lib.mapAttrsToList (name: value: attrsToLdif "${name},${dn}" value) children)); +in +{ options = { services.openldap = { enable = lib.mkOption { @@ -186,7 +210,7 @@ in { declarativeContents = lib.mkOption { type = with lib.types; attrsOf lines; - default = {}; + default = { }; description = '' Declarative contents for the LDAP database, in LDIF format by suffix. @@ -222,115 +246,154 @@ in { meta.maintainers = with lib.maintainers; [ kwohlfahrt ]; - config = let - dbSettings = lib.mapAttrs' (name: { attrs, ... }: lib.nameValuePair attrs.olcSuffix attrs) - (lib.filterAttrs (name: { attrs, ... }: (lib.hasPrefix "olcDatabase=" name) && attrs ? olcSuffix) cfg.settings.children); - settingsFile = pkgs.writeText "config.ldif" (lib.concatStringsSep "\n" (attrsToLdif "cn=config" cfg.settings)); - writeConfig = pkgs.writeShellScript "openldap-config" '' - set -euo pipefail + config = + let + dbSettings = lib.mapAttrs' (name: { attrs, ... }: lib.nameValuePair attrs.olcSuffix attrs) ( + lib.filterAttrs ( + name: { attrs, ... }: (lib.hasPrefix "olcDatabase=" name) && attrs ? olcSuffix + ) cfg.settings.children + ); + settingsFile = pkgs.writeText "config.ldif" ( + lib.concatStringsSep "\n" (attrsToLdif "cn=config" cfg.settings) + ); + writeConfig = pkgs.writeShellScript "openldap-config" '' + set -euo pipefail - ${lib.optionalString (!cfg.mutableConfig) '' - chmod -R u+w ${configDir} - rm -rf ${configDir}/* - ''} - if [ ! -e "${configDir}/cn=config.ldif" ]; then - ${openldap}/bin/slapadd -F ${configDir} -bcn=config -l ${settingsFile} - fi - chmod -R ${if cfg.mutableConfig then "u+rw" else "u+r-w"} ${configDir} - ''; + ${lib.optionalString (!cfg.mutableConfig) '' + chmod -R u+w ${configDir} + rm -rf ${configDir}/* + ''} + if [ ! -e "${configDir}/cn=config.ldif" ]; then + ${openldap}/bin/slapadd -F ${configDir} -bcn=config -l ${settingsFile} + fi + chmod -R ${if cfg.mutableConfig then "u+rw" else "u+r-w"} ${configDir} + ''; - contentsFiles = lib.mapAttrs (dn: ldif: pkgs.writeText "${dn}.ldif" ldif) cfg.declarativeContents; - writeContents = pkgs.writeShellScript "openldap-load" '' - set -euo pipefail + contentsFiles = lib.mapAttrs (dn: ldif: pkgs.writeText "${dn}.ldif" ldif) cfg.declarativeContents; + writeContents = pkgs.writeShellScript "openldap-load" '' + set -euo pipefail - rm -rf $2/* - ${openldap}/bin/slapadd -F ${configDir} -b $1 -l $3 - ''; - in lib.mkIf cfg.enable { - assertions = [{ - assertion = (cfg.declarativeContents != {}) -> cfg.configDir == null; - message = '' - Declarative DB contents (${lib.attrNames cfg.declarativeContents}) are not - supported with user-managed configuration. - ''; - }] ++ (map (dn: { - assertion = (lib.getAttr dn dbSettings) ? "olcDbDirectory"; - # olcDbDirectory is necessary to prepopulate database using `slapadd`. - message = '' - Declarative DB ${dn} does not exist in `services.openldap.settings`, or does not have - `olcDbDirectory` configured. - ''; - }) (lib.attrNames cfg.declarativeContents)) ++ (lib.mapAttrsToList (dn: { olcDbDirectory ? null, ... }: { - # For forward compatibility with `DynamicUser`, and to avoid accidentally clobbering - # directories with `declarativeContents`. - assertion = (olcDbDirectory != null) -> - ((lib.hasPrefix "/var/lib/openldap/" olcDbDirectory) && (olcDbDirectory != "/var/lib/openldap/")); - message = '' - Database ${dn} has `olcDbDirectory` (${olcDbDirectory}) that is not a subdirectory of - `/var/lib/openldap/`. + rm -rf $2/* + ${openldap}/bin/slapadd -F ${configDir} -b $1 -l $3 ''; - }) dbSettings); - environment.systemPackages = [ openldap ]; + in + lib.mkIf cfg.enable { + assertions = + [ + { + assertion = (cfg.declarativeContents != { }) -> cfg.configDir == null; + message = '' + Declarative DB contents (${lib.attrNames cfg.declarativeContents}) are not + supported with user-managed configuration. + ''; + } + ] + ++ (map (dn: { + assertion = (lib.getAttr dn dbSettings) ? "olcDbDirectory"; + # olcDbDirectory is necessary to prepopulate database using `slapadd`. + message = '' + Declarative DB ${dn} does not exist in `services.openldap.settings`, or does not have + `olcDbDirectory` configured. + ''; + }) (lib.attrNames cfg.declarativeContents)) + ++ (lib.mapAttrsToList ( + dn: + { + olcDbDirectory ? null, + ... + }: + { + # For forward compatibility with `DynamicUser`, and to avoid accidentally clobbering + # directories with `declarativeContents`. + assertion = + (olcDbDirectory != null) + -> ( + (lib.hasPrefix "/var/lib/openldap/" olcDbDirectory) && (olcDbDirectory != "/var/lib/openldap/") + ); + message = '' + Database ${dn} has `olcDbDirectory` (${olcDbDirectory}) that is not a subdirectory of + `/var/lib/openldap/`. + ''; + } + ) dbSettings); + environment.systemPackages = [ openldap ]; - # Literal attributes must always be set - services.openldap.settings = { - attrs = { - objectClass = "olcGlobal"; - cn = "config"; - }; - children."cn=schema".attrs = { - cn = "schema"; - objectClass = "olcSchemaConfig"; + # Literal attributes must always be set + services.openldap.settings = { + attrs = { + objectClass = "olcGlobal"; + cn = "config"; + }; + children."cn=schema".attrs = { + cn = "schema"; + objectClass = "olcSchemaConfig"; + }; }; - }; - systemd.services.openldap = { - description = "OpenLDAP Server Daemon"; - documentation = [ - "man:slapd" - "man:slapd-config" - "man:slapd-mdb" - ]; - wantedBy = [ "multi-user.target" ]; - wants = [ "network-online.target" ]; - after = [ "network-online.target" ]; - serviceConfig = { - User = cfg.user; - Group = cfg.group; - ExecStartPre = [ - "!${pkgs.coreutils}/bin/mkdir -p ${configDir}" - "+${pkgs.coreutils}/bin/chown $USER ${configDir}" - ] ++ (lib.optional (cfg.configDir == null) writeConfig) - ++ (lib.mapAttrsToList (dn: content: lib.escapeShellArgs [ - writeContents dn (lib.getAttr dn dbSettings).olcDbDirectory content - ]) contentsFiles) - ++ [ "${openldap}/bin/slaptest -u -F ${configDir}" ]; - ExecStart = lib.escapeShellArgs ([ - "${openldap}/libexec/slapd" "-d" "0" "-F" configDir "-h" (lib.concatStringsSep " " cfg.urlList) - ]); - Type = "notify"; - # Fixes an error where openldap attempts to notify from a thread - # outside the main process: - # Got notification message from PID 6378, but reception only permitted for main PID 6377 - NotifyAccess = "all"; - RuntimeDirectory = "openldap"; - StateDirectory = ["openldap"] - ++ (map ({olcDbDirectory, ... }: lib.removePrefix "/var/lib/" olcDbDirectory) (lib.attrValues dbSettings)); - StateDirectoryMode = "700"; - AmbientCapabilities = [ "CAP_NET_BIND_SERVICE" ]; - CapabilityBoundingSet = [ "CAP_NET_BIND_SERVICE" ]; + systemd.services.openldap = { + description = "OpenLDAP Server Daemon"; + documentation = [ + "man:slapd" + "man:slapd-config" + "man:slapd-mdb" + ]; + wantedBy = [ "multi-user.target" ]; + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; + serviceConfig = { + User = cfg.user; + Group = cfg.group; + ExecStartPre = + [ + "!${pkgs.coreutils}/bin/mkdir -p ${configDir}" + "+${pkgs.coreutils}/bin/chown $USER ${configDir}" + ] + ++ (lib.optional (cfg.configDir == null) writeConfig) + ++ (lib.mapAttrsToList ( + dn: content: + lib.escapeShellArgs [ + writeContents + dn + (lib.getAttr dn dbSettings).olcDbDirectory + content + ] + ) contentsFiles) + ++ [ "${openldap}/bin/slaptest -u -F ${configDir}" ]; + ExecStart = lib.escapeShellArgs ([ + "${openldap}/libexec/slapd" + "-d" + "0" + "-F" + configDir + "-h" + (lib.concatStringsSep " " cfg.urlList) + ]); + Type = "notify"; + # Fixes an error where openldap attempts to notify from a thread + # outside the main process: + # Got notification message from PID 6378, but reception only permitted for main PID 6377 + NotifyAccess = "all"; + RuntimeDirectory = "openldap"; + StateDirectory = + [ "openldap" ] + ++ (map ({ olcDbDirectory, ... }: lib.removePrefix "/var/lib/" olcDbDirectory) ( + lib.attrValues dbSettings + )); + StateDirectoryMode = "700"; + AmbientCapabilities = [ "CAP_NET_BIND_SERVICE" ]; + CapabilityBoundingSet = [ "CAP_NET_BIND_SERVICE" ]; + }; }; - }; - users.users = lib.optionalAttrs (cfg.user == "openldap") { - openldap = { - group = cfg.group; - isSystemUser = true; + users.users = lib.optionalAttrs (cfg.user == "openldap") { + openldap = { + group = cfg.group; + isSystemUser = true; + }; }; - }; - users.groups = lib.optionalAttrs (cfg.group == "openldap") { - openldap = {}; + users.groups = lib.optionalAttrs (cfg.group == "openldap") { + openldap = { }; + }; }; - }; } diff --git a/nixos/modules/services/databases/opentsdb.nix b/nixos/modules/services/databases/opentsdb.nix index 90268daec1d70b..00a4d7f0edde69 100644 --- a/nixos/modules/services/databases/opentsdb.nix +++ b/nixos/modules/services/databases/opentsdb.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.opentsdb; configFile = pkgs.writeText "opentsdb.conf" cfg.config; -in { +in +{ ###### interface @@ -67,10 +73,9 @@ in { environment.JAVA_HOME = "${pkgs.jre}"; path = [ pkgs.gnuplot ]; - preStart = - '' + preStart = '' COMPRESSION=NONE HBASE_HOME=${config.services.hbase.package} ${cfg.package}/share/opentsdb/tools/create_table.sh - ''; + ''; serviceConfig = { PermissionsStartOnly = true; diff --git a/nixos/modules/services/databases/pgbouncer.nix b/nixos/modules/services/databases/pgbouncer.nix index 36130d66c685f0..378cbc3f81bb59 100644 --- a/nixos/modules/services/databases/pgbouncer.nix +++ b/nixos/modules/services/databases/pgbouncer.nix @@ -1,123 +1,163 @@ -{ config, lib, utils, pkgs, ... }: +{ + config, + lib, + utils, + pkgs, + ... +}: let cfg = config.services.pgbouncer; settingsFormat = pkgs.formats.ini { }; - configFile = settingsFormat.generate "pgbouncer.ini" - (lib.filterAttrsRecursive (_: v: v != null) cfg.settings); + configFile = settingsFormat.generate "pgbouncer.ini" ( + lib.filterAttrsRecursive (_: v: v != null) cfg.settings + ); configPath = "pgbouncer/pgbouncer.ini"; in { imports = [ - (lib.mkRemovedOptionModule - [ "services" "pgbouncer" "logFile" ] - '' - `services.pgbouncer.logFile` has been removed, use `services.pgbouncer.settings.pgbouncer.logfile` - instead. - Please note that the new option expects an absolute path - whereas the old option accepted paths relative to pgbouncer's home dir. - '') + (lib.mkRemovedOptionModule [ "services" "pgbouncer" "logFile" ] '' + `services.pgbouncer.logFile` has been removed, use `services.pgbouncer.settings.pgbouncer.logfile` + instead. + Please note that the new option expects an absolute path + whereas the old option accepted paths relative to pgbouncer's home dir. + '') (lib.mkRenamedOptionModule [ "services" "pgbouncer" "listenAddress" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "listen_addr" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "listen_addr" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "listenPort" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "listen_port" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "listen_port" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "poolMode" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "pool_mode" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "pool_mode" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "maxClientConn" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "max_client_conn" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "max_client_conn" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "defaultPoolSize" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "default_pool_size" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "default_pool_size" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "maxDbConnections" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "max_db_connections" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "max_db_connections" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "maxUserConnections" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "max_user_connections" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "max_user_connections" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "ignoreStartupParameters" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "ignore_startup_parameters" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "ignore_startup_parameters" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "databases" ] - [ "services" "pgbouncer" "settings" "databases" ]) + [ "services" "pgbouncer" "settings" "databases" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "users" ] - [ "services" "pgbouncer" "settings" "users" ]) + [ "services" "pgbouncer" "settings" "users" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "peers" ] - [ "services" "pgbouncer" "settings" "peers" ]) + [ "services" "pgbouncer" "settings" "peers" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "authType" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "auth_type" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "auth_type" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "authHbaFile" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "auth_hba_file" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "auth_hba_file" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "authFile" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "auth_file" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "auth_file" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "authUser" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "auth_user" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "auth_user" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "authQuery" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "auth_query" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "auth_query" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "authDbname" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "auth_dbname" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "auth_dbname" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "adminUsers" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "admin_users" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "admin_users" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "statsUsers" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "stats_users" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "stats_users" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "verbose" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "verbose" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "verbose" ] + ) (lib.mkChangedOptionModule [ "services" "pgbouncer" "syslog" "enable" ] [ "services" "pgbouncer" "settings" "pgbouncer" "syslog" ] - (config: + ( + config: let - enable = lib.getAttrFromPath - [ "services" "pgbouncer" "syslog" "enable" ] - config; + enable = lib.getAttrFromPath [ "services" "pgbouncer" "syslog" "enable" ] config; in - if enable then 1 else 0)) + if enable then 1 else 0 + ) + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "syslog" "syslogIdent" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "syslog_ident" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "syslog_ident" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "syslog" "syslogFacility" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "syslog_facility" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "syslog_facility" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "tls" "client" "sslmode" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "client_tls_sslmode" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "client_tls_sslmode" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "tls" "client" "keyFile" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "client_tls_key_file" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "client_tls_key_file" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "tls" "client" "certFile" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "client_tls_cert_file" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "client_tls_cert_file" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "tls" "client" "caFile" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "client_tls_ca_file" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "client_tls_ca_file" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "tls" "server" "sslmode" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "server_tls_sslmode" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "server_tls_sslmode" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "tls" "server" "keyFile" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "server_tls_key_file" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "server_tls_key_file" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "tls" "server" "certFile" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "server_tls_cert_file" ]) + [ "services" "pgbouncer" "settings" "pgbouncer" "server_tls_cert_file" ] + ) (lib.mkRenamedOptionModule [ "services" "pgbouncer" "tls" "server" "caFile" ] - [ "services" "pgbouncer" "settings" "pgbouncer" "server_tls_ca_file" ]) - (lib.mkRemovedOptionModule [ "services" "pgbouncer" "extraConfig" ] "Use services.pgbouncer.settings instead.") + [ "services" "pgbouncer" "settings" "pgbouncer" "server_tls_ca_file" ] + ) + (lib.mkRemovedOptionModule [ + "services" + "pgbouncer" + "extraConfig" + ] "Use services.pgbouncer.settings instead.") ]; options.services.pgbouncer = { @@ -160,7 +200,11 @@ in }; pool_mode = lib.mkOption { - type = lib.types.enum [ "session" "transaction" "statement" ]; + type = lib.types.enum [ + "session" + "transaction" + "statement" + ]; default = "session"; description = '' Specifies when a server connection can be reused by other clients. @@ -268,11 +312,11 @@ in }; databases = lib.mkOption { type = lib.types.attrsOf lib.types.str; - default = {}; + default = { }; example = { exampledb = "host=/run/postgresql/ port=5432 auth_user=exampleuser dbname=exampledb sslmode=require"; bardb = "host=localhost dbname=bazdb"; - foodb = "host=host1.example.com port=5432"; + foodb = "host=host1.example.com port=5432"; }; description = '' Detailed information about PostgreSQL database definitions: @@ -281,7 +325,7 @@ in }; users = lib.mkOption { type = lib.types.attrsOf lib.types.str; - default = {}; + default = { }; example = { user1 = "pool_mode=session"; }; @@ -295,7 +339,7 @@ in peers = lib.mkOption { type = lib.types.attrsOf lib.types.str; - default = {}; + default = { }; example = { "1" = "host=host1.example.com"; "2" = "host=/tmp/pgbouncer-2 port=5555"; diff --git a/nixos/modules/services/databases/pgmanage.nix b/nixos/modules/services/databases/pgmanage.nix index fe3d1b5bfb9dbc..472aefdaade5dc 100644 --- a/nixos/modules/services/databases/pgmanage.nix +++ b/nixos/modules/services/databases/pgmanage.nix @@ -1,10 +1,15 @@ -{ lib, pkgs, config, ... } : +{ + lib, + pkgs, + config, + ... +}: let cfg = config.services.pgmanage; confFile = pkgs.writeTextFile { name = "pgmanage.conf"; - text = '' + text = '' connection_file = ${pgmanageConnectionsFile} allow_custom_connections = ${builtins.toJSON cfg.allowCustomConnections} @@ -22,8 +27,8 @@ let sql_root = ${cfg.sqlRoot} ${lib.optionalString (cfg.tls != null) '' - tls_cert = ${cfg.tls.cert} - tls_key = ${cfg.tls.key} + tls_cert = ${cfg.tls.cert} + tls_key = ${cfg.tls.key} ''} log_level = ${cfg.logLevel} @@ -32,13 +37,15 @@ let pgmanageConnectionsFile = pkgs.writeTextFile { name = "pgmanage-connections.conf"; - text = lib.concatStringsSep "\n" - (lib.mapAttrsToList (name : conn : "${name}: ${conn}") cfg.connections); + text = lib.concatStringsSep "\n" ( + lib.mapAttrsToList (name: conn: "${name}: ${conn}") cfg.connections + ); }; pgmanage = "pgmanage"; -in { +in +{ options.services.pgmanage = { enable = lib.mkEnableOption "PostgreSQL Administration for the web"; @@ -47,9 +54,9 @@ in { connections = lib.mkOption { type = lib.types.attrsOf lib.types.str; - default = {}; + default = { }; example = { - nuc-server = "hostaddr=192.168.0.100 port=5432 dbname=postgres"; + nuc-server = "hostaddr=192.168.0.100 port=5432 dbname=postgres"; mini-server = "hostaddr=127.0.0.1 port=5432 dbname=postgres sslmode=require"; }; description = '' @@ -133,18 +140,20 @@ in { }; tls = lib.mkOption { - type = lib.types.nullOr (lib.types.submodule { - options = { - cert = lib.mkOption { - type = lib.types.str; - description = "TLS certificate"; + type = lib.types.nullOr ( + lib.types.submodule { + options = { + cert = lib.mkOption { + type = lib.types.str; + description = "TLS certificate"; + }; + key = lib.mkOption { + type = lib.types.str; + description = "TLS key"; + }; }; - key = lib.mkOption { - type = lib.types.str; - description = "TLS key"; - }; - }; - }); + } + ); default = null; description = '' These options tell pgmanage where the TLS Certificate and Key files @@ -160,7 +169,12 @@ in { }; logLevel = lib.mkOption { - type = lib.types.enum ["error" "warn" "notice" "info"]; + type = lib.types.enum [ + "error" + "warn" + "notice" + "info" + ]; default = "error"; description = '' Verbosity of logs @@ -171,21 +185,22 @@ in { config = lib.mkIf cfg.enable { systemd.services.pgmanage = { description = "pgmanage - PostgreSQL Administration for the web"; - wants = [ "postgresql.service" ]; - after = [ "postgresql.service" ]; + wants = [ "postgresql.service" ]; + after = [ "postgresql.service" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { - User = pgmanage; - Group = pgmanage; - ExecStart = "${cfg.package}/sbin/pgmanage -c ${confFile}" + - lib.optionalString cfg.localOnly " --local-only=true"; + User = pgmanage; + Group = pgmanage; + ExecStart = + "${cfg.package}/sbin/pgmanage -c ${confFile}" + + lib.optionalString cfg.localOnly " --local-only=true"; }; }; users = { users.${pgmanage} = { - name = pgmanage; + name = pgmanage; group = pgmanage; - home = cfg.sqlRoot; + home = cfg.sqlRoot; createHome = true; isSystemUser = true; }; diff --git a/nixos/modules/services/databases/postgresql.nix b/nixos/modules/services/databases/postgresql.nix index 004e8130ad6ea2..f113bf2d510ac3 100644 --- a/nixos/modules/services/databases/postgresql.nix +++ b/nixos/modules/services/databases/postgresql.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) @@ -39,24 +44,29 @@ let # package = pkgs.postgresql_; # }; # works. - basePackage = if cfg.enableJIT - then cfg.package.withJIT - else cfg.package.withoutJIT; + basePackage = if cfg.enableJIT then cfg.package.withJIT else cfg.package.withoutJIT; - postgresql = if cfg.extensions == [] - then basePackage - else basePackage.withPackages cfg.extensions; + postgresql = if cfg.extensions == [ ] then basePackage else basePackage.withPackages cfg.extensions; - toStr = value: - if true == value then "yes" - else if false == value then "no" - else if isString value then "'${lib.replaceStrings ["'"] ["''"] value}'" - else builtins.toString value; + toStr = + value: + if true == value then + "yes" + else if false == value then + "no" + else if isString value then + "'${lib.replaceStrings [ "'" ] [ "''" ] value}'" + else + builtins.toString value; # The main PostgreSQL configuration file. - configFile = pkgs.writeTextDir "postgresql.conf" (concatStringsSep "\n" (mapAttrsToList (n: v: "${n} = ${toStr v}") (filterAttrs (const (x: x != null)) cfg.settings))); + configFile = pkgs.writeTextDir "postgresql.conf" ( + concatStringsSep "\n" ( + mapAttrsToList (n: v: "${n} = ${toStr v}") (filterAttrs (const (x: x != null)) cfg.settings) + ) + ); - configFileCheck = pkgs.runCommand "postgresql-configfile-check" {} '' + configFileCheck = pkgs.runCommand "postgresql-configfile-check" { } '' ${cfg.package}/bin/postgres -D${configFile} -C config_file >/dev/null touch $out ''; @@ -69,11 +79,24 @@ in { imports = [ - (mkRemovedOptionModule [ "services" "postgresql" "extraConfig" ] "Use services.postgresql.settings instead.") - - (mkRenamedOptionModule [ "services" "postgresql" "logLinePrefix" ] [ "services" "postgresql" "settings" "log_line_prefix" ]) - (mkRenamedOptionModule [ "services" "postgresql" "port" ] [ "services" "postgresql" "settings" "port" ]) - (mkRenamedOptionModule [ "services" "postgresql" "extraPlugins" ] [ "services" "postgresql" "extensions" ]) + (mkRemovedOptionModule [ + "services" + "postgresql" + "extraConfig" + ] "Use services.postgresql.settings instead.") + + (mkRenamedOptionModule + [ "services" "postgresql" "logLinePrefix" ] + [ "services" "postgresql" "settings" "log_line_prefix" ] + ) + (mkRenamedOptionModule + [ "services" "postgresql" "port" ] + [ "services" "postgresql" "settings" "port" ] + ) + (mkRenamedOptionModule + [ "services" "postgresql" "extraPlugins" ] + [ "services" "postgresql" "extensions" ] + ) ]; ###### interface @@ -140,8 +163,11 @@ in initdbArgs = mkOption { type = with types; listOf str; - default = []; - example = [ "--data-checksums" "--allow-group-access" ]; + default = [ ]; + example = [ + "--data-checksums" + "--allow-group-access" + ]; description = '' Additional arguments passed to `initdb` during data dir initialisation. @@ -163,7 +189,7 @@ in ensureDatabases = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = '' Ensures that the specified databases exist. This option will never delete existing databases, especially not when the value of this @@ -177,175 +203,179 @@ in }; ensureUsers = mkOption { - type = types.listOf (types.submodule { - options = { - name = mkOption { - type = types.str; - description = '' - Name of the user to ensure. - ''; - }; + type = types.listOf ( + types.submodule { + options = { + name = mkOption { + type = types.str; + description = '' + Name of the user to ensure. + ''; + }; - ensureDBOwnership = mkOption { - type = types.bool; - default = false; - description = '' - Grants the user ownership to a database with the same name. - This database must be defined manually in - [](#opt-services.postgresql.ensureDatabases). - ''; - }; + ensureDBOwnership = mkOption { + type = types.bool; + default = false; + description = '' + Grants the user ownership to a database with the same name. + This database must be defined manually in + [](#opt-services.postgresql.ensureDatabases). + ''; + }; - ensureClauses = mkOption { - description = '' - An attrset of clauses to grant to the user. Under the hood this uses the - [ALTER USER syntax](https://www.postgresql.org/docs/current/sql-alteruser.html) for each attrName where - the attrValue is true in the attrSet: - `ALTER USER user.name WITH attrName` - ''; - example = literalExpression '' - { - superuser = true; - createrole = true; - createdb = true; - } - ''; - default = {}; - defaultText = lib.literalMD '' - The default, `null`, means that the user created will have the default permissions assigned by PostgreSQL. Subsequent server starts will not set or unset the clause, so imperative changes are preserved. - ''; - type = types.submodule { - options = let - defaultText = lib.literalMD '' - `null`: do not set. For newly created roles, use PostgreSQL's default. For existing roles, do not touch this clause. - ''; - in { - superuser = mkOption { - type = types.nullOr types.bool; - description = '' - Grants the user, created by the ensureUser attr, superuser permissions. From the postgres docs: - - A database superuser bypasses all permission checks, - except the right to log in. This is a dangerous privilege - and should not be used carelessly; it is best to do most - of your work as a role that is not a superuser. To create - a new database superuser, use CREATE ROLE name SUPERUSER. - You must do this as a role that is already a superuser. - - More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) - ''; - default = null; - inherit defaultText; - }; - createrole = mkOption { - type = types.nullOr types.bool; - description = '' - Grants the user, created by the ensureUser attr, createrole permissions. From the postgres docs: - - A role must be explicitly given permission to create more - roles (except for superusers, since those bypass all - permission checks). To create such a role, use CREATE - ROLE name CREATEROLE. A role with CREATEROLE privilege - can alter and drop other roles, too, as well as grant or - revoke membership in them. However, to create, alter, - drop, or change membership of a superuser role, superuser - status is required; CREATEROLE is insufficient for that. - - More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) - ''; - default = null; - inherit defaultText; - }; - createdb = mkOption { - type = types.nullOr types.bool; - description = '' - Grants the user, created by the ensureUser attr, createdb permissions. From the postgres docs: - - A role must be explicitly given permission to create - databases (except for superusers, since those bypass all - permission checks). To create such a role, use CREATE - ROLE name CREATEDB. - - More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) - ''; - default = null; - inherit defaultText; - }; - "inherit" = mkOption { - type = types.nullOr types.bool; - description = '' - Grants the user created inherit permissions. From the postgres docs: - - A role is given permission to inherit the privileges of - roles it is a member of, by default. However, to create a - role without the permission, use CREATE ROLE name - NOINHERIT. - - More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) - ''; - default = null; - inherit defaultText; - }; - login = mkOption { - type = types.nullOr types.bool; - description = '' - Grants the user, created by the ensureUser attr, login permissions. From the postgres docs: - - Only roles that have the LOGIN attribute can be used as - the initial role name for a database connection. A role - with the LOGIN attribute can be considered the same as a - “database user”. To create a role with login privilege, - use either: - - CREATE ROLE name LOGIN; CREATE USER name; - - (CREATE USER is equivalent to CREATE ROLE except that - CREATE USER includes LOGIN by default, while CREATE ROLE - does not.) - - More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) - ''; - default = null; - inherit defaultText; - }; - replication = mkOption { - type = types.nullOr types.bool; - description = '' - Grants the user, created by the ensureUser attr, replication permissions. From the postgres docs: - - A role must explicitly be given permission to initiate - streaming replication (except for superusers, since those - bypass all permission checks). A role used for streaming - replication must have LOGIN permission as well. To create - such a role, use CREATE ROLE name REPLICATION LOGIN. - - More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) - ''; - default = null; - inherit defaultText; - }; - bypassrls = mkOption { - type = types.nullOr types.bool; - description = '' - Grants the user, created by the ensureUser attr, replication permissions. From the postgres docs: - - A role must be explicitly given permission to bypass - every row-level security (RLS) policy (except for - superusers, since those bypass all permission checks). To - create such a role, use CREATE ROLE name BYPASSRLS as a - superuser. - - More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) - ''; - default = null; - inherit defaultText; - }; + ensureClauses = mkOption { + description = '' + An attrset of clauses to grant to the user. Under the hood this uses the + [ALTER USER syntax](https://www.postgresql.org/docs/current/sql-alteruser.html) for each attrName where + the attrValue is true in the attrSet: + `ALTER USER user.name WITH attrName` + ''; + example = literalExpression '' + { + superuser = true; + createrole = true; + createdb = true; + } + ''; + default = { }; + defaultText = lib.literalMD '' + The default, `null`, means that the user created will have the default permissions assigned by PostgreSQL. Subsequent server starts will not set or unset the clause, so imperative changes are preserved. + ''; + type = types.submodule { + options = + let + defaultText = lib.literalMD '' + `null`: do not set. For newly created roles, use PostgreSQL's default. For existing roles, do not touch this clause. + ''; + in + { + superuser = mkOption { + type = types.nullOr types.bool; + description = '' + Grants the user, created by the ensureUser attr, superuser permissions. From the postgres docs: + + A database superuser bypasses all permission checks, + except the right to log in. This is a dangerous privilege + and should not be used carelessly; it is best to do most + of your work as a role that is not a superuser. To create + a new database superuser, use CREATE ROLE name SUPERUSER. + You must do this as a role that is already a superuser. + + More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) + ''; + default = null; + inherit defaultText; + }; + createrole = mkOption { + type = types.nullOr types.bool; + description = '' + Grants the user, created by the ensureUser attr, createrole permissions. From the postgres docs: + + A role must be explicitly given permission to create more + roles (except for superusers, since those bypass all + permission checks). To create such a role, use CREATE + ROLE name CREATEROLE. A role with CREATEROLE privilege + can alter and drop other roles, too, as well as grant or + revoke membership in them. However, to create, alter, + drop, or change membership of a superuser role, superuser + status is required; CREATEROLE is insufficient for that. + + More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) + ''; + default = null; + inherit defaultText; + }; + createdb = mkOption { + type = types.nullOr types.bool; + description = '' + Grants the user, created by the ensureUser attr, createdb permissions. From the postgres docs: + + A role must be explicitly given permission to create + databases (except for superusers, since those bypass all + permission checks). To create such a role, use CREATE + ROLE name CREATEDB. + + More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) + ''; + default = null; + inherit defaultText; + }; + "inherit" = mkOption { + type = types.nullOr types.bool; + description = '' + Grants the user created inherit permissions. From the postgres docs: + + A role is given permission to inherit the privileges of + roles it is a member of, by default. However, to create a + role without the permission, use CREATE ROLE name + NOINHERIT. + + More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) + ''; + default = null; + inherit defaultText; + }; + login = mkOption { + type = types.nullOr types.bool; + description = '' + Grants the user, created by the ensureUser attr, login permissions. From the postgres docs: + + Only roles that have the LOGIN attribute can be used as + the initial role name for a database connection. A role + with the LOGIN attribute can be considered the same as a + “database user”. To create a role with login privilege, + use either: + + CREATE ROLE name LOGIN; CREATE USER name; + + (CREATE USER is equivalent to CREATE ROLE except that + CREATE USER includes LOGIN by default, while CREATE ROLE + does not.) + + More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) + ''; + default = null; + inherit defaultText; + }; + replication = mkOption { + type = types.nullOr types.bool; + description = '' + Grants the user, created by the ensureUser attr, replication permissions. From the postgres docs: + + A role must explicitly be given permission to initiate + streaming replication (except for superusers, since those + bypass all permission checks). A role used for streaming + replication must have LOGIN permission as well. To create + such a role, use CREATE ROLE name REPLICATION LOGIN. + + More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) + ''; + default = null; + inherit defaultText; + }; + bypassrls = mkOption { + type = types.nullOr types.bool; + description = '' + Grants the user, created by the ensureUser attr, replication permissions. From the postgres docs: + + A role must be explicitly given permission to bypass + every row-level security (RLS) policy (except for + superusers, since those bypass all permission checks). To + create such a role, use CREATE ROLE name BYPASSRLS as a + superuser. + + More information on postgres roles can be found [here](https://www.postgresql.org/docs/current/role-attributes.html) + ''; + default = null; + inherit defaultText; + }; + }; }; }; }; - }; - }); - default = []; + } + ); + default = [ ]; description = '' Ensures that the specified users exist. The PostgreSQL users will be identified using peer authentication. This authenticates the Unix user with the @@ -379,7 +409,7 @@ in extensions = mkOption { type = with types; coercedTo (listOf path) (path: _ignorePg: path) (functionTo (listOf path)); - default = _: []; + default = _: [ ]; example = literalExpression "ps: with ps; [ postgis pg_repack ]"; description = '' List of PostgreSQL extensions to install. @@ -387,39 +417,46 @@ in }; settings = mkOption { - type = with types; submodule { - freeformType = attrsOf (oneOf [ bool float int str ]); - options = { - shared_preload_libraries = mkOption { - type = nullOr (coercedTo (listOf str) (concatStringsSep ", ") str); - default = null; - example = literalExpression ''[ "auto_explain" "anon" ]''; - description = '' - List of libraries to be preloaded. - ''; - }; + type = + with types; + submodule { + freeformType = attrsOf (oneOf [ + bool + float + int + str + ]); + options = { + shared_preload_libraries = mkOption { + type = nullOr (coercedTo (listOf str) (concatStringsSep ", ") str); + default = null; + example = literalExpression ''[ "auto_explain" "anon" ]''; + description = '' + List of libraries to be preloaded. + ''; + }; - log_line_prefix = mkOption { - type = types.str; - default = "[%p] "; - example = "%m [%p] "; - description = '' - A printf-style string that is output at the beginning of each log line. - Upstream default is `'%m [%p] '`, i.e. it includes the timestamp. We do - not include the timestamp, because journal has it anyway. - ''; - }; + log_line_prefix = mkOption { + type = types.str; + default = "[%p] "; + example = "%m [%p] "; + description = '' + A printf-style string that is output at the beginning of each log line. + Upstream default is `'%m [%p] '`, i.e. it includes the timestamp. We do + not include the timestamp, because journal has it anyway. + ''; + }; - port = mkOption { - type = types.port; - default = 5432; - description = '' - The port on which PostgreSQL listens. - ''; + port = mkOption { + type = types.port; + default = 5432; + description = '' + The port on which PostgreSQL listens. + ''; + }; }; }; - }; - default = {}; + default = { }; description = '' PostgreSQL configuration. Refer to @@ -458,54 +495,66 @@ in PostgreSQL superuser account to use for various operations. Internal since changing this value would lead to breakage while setting up databases. ''; - }; + }; }; }; - ###### implementation config = mkIf cfg.enable { - assertions = map ({ name, ensureDBOwnership, ... }: { - assertion = ensureDBOwnership -> elem name cfg.ensureDatabases; - message = '' - For each database user defined with `services.postgresql.ensureUsers` and - `ensureDBOwnership = true;`, a database with the same name must be defined - in `services.postgresql.ensureDatabases`. - - Offender: ${name} has not been found among databases. - ''; - }) cfg.ensureUsers; - - services.postgresql.settings = + assertions = map ( + { name, ensureDBOwnership, ... }: { - hba_file = "${pkgs.writeText "pg_hba.conf" cfg.authentication}"; - ident_file = "${pkgs.writeText "pg_ident.conf" cfg.identMap}"; - log_destination = "stderr"; - listen_addresses = if cfg.enableTCPIP then "*" else "localhost"; - jit = mkDefault (if cfg.enableJIT then "on" else "off"); - }; + assertion = ensureDBOwnership -> elem name cfg.ensureDatabases; + message = '' + For each database user defined with `services.postgresql.ensureUsers` and + `ensureDBOwnership = true;`, a database with the same name must be defined + in `services.postgresql.ensureDatabases`. - services.postgresql.package = let - mkThrow = ver: throw "postgresql_${ver} was removed, please upgrade your postgresql version."; - mkWarn = ver: warn '' - The postgresql package is not pinned and selected automatically by - `system.stateVersion`. Right now this is `pkgs.postgresql_${ver}`, the - oldest postgresql version available and thus the next that will be - removed when EOL on the next stable cycle. - - See also https://endoflife.date/postgresql + Offender: ${name} has not been found among databases. ''; - base = if versionAtLeast config.system.stateVersion "24.11" then pkgs.postgresql_16 - else if versionAtLeast config.system.stateVersion "23.11" then pkgs.postgresql_15 - else if versionAtLeast config.system.stateVersion "22.05" then pkgs.postgresql_14 - else if versionAtLeast config.system.stateVersion "21.11" then mkWarn "13" pkgs.postgresql_13 - else if versionAtLeast config.system.stateVersion "20.03" then mkThrow "11" - else if versionAtLeast config.system.stateVersion "17.09" then mkThrow "9_6" - else mkThrow "9_5"; - in + } + ) cfg.ensureUsers; + + services.postgresql.settings = { + hba_file = "${pkgs.writeText "pg_hba.conf" cfg.authentication}"; + ident_file = "${pkgs.writeText "pg_ident.conf" cfg.identMap}"; + log_destination = "stderr"; + listen_addresses = if cfg.enableTCPIP then "*" else "localhost"; + jit = mkDefault (if cfg.enableJIT then "on" else "off"); + }; + + services.postgresql.package = + let + mkThrow = ver: throw "postgresql_${ver} was removed, please upgrade your postgresql version."; + mkWarn = + ver: + warn '' + The postgresql package is not pinned and selected automatically by + `system.stateVersion`. Right now this is `pkgs.postgresql_${ver}`, the + oldest postgresql version available and thus the next that will be + removed when EOL on the next stable cycle. + + See also https://endoflife.date/postgresql + ''; + base = + if versionAtLeast config.system.stateVersion "24.11" then + pkgs.postgresql_16 + else if versionAtLeast config.system.stateVersion "23.11" then + pkgs.postgresql_15 + else if versionAtLeast config.system.stateVersion "22.05" then + pkgs.postgresql_14 + else if versionAtLeast config.system.stateVersion "21.11" then + mkWarn "13" pkgs.postgresql_13 + else if versionAtLeast config.system.stateVersion "20.03" then + mkThrow "11" + else if versionAtLeast config.system.stateVersion "17.09" then + mkThrow "9_6" + else + mkThrow "9_5"; + in # Note: when changing the default, make it conditional on # ‘system.stateVersion’ to maintain compatibility with existing # systems! @@ -515,8 +564,7 @@ in services.postgresql.authentication = mkMerge [ (mkBefore "# Generated file; do not edit!") - (mkAfter - '' + (mkAfter '' # default value of services.postgresql.authentication local all all peer host all all 127.0.0.1/32 md5 @@ -524,172 +572,173 @@ in '') ]; - users.users.postgres = - { name = "postgres"; - uid = config.ids.uids.postgres; - group = "postgres"; - description = "PostgreSQL server user"; - home = "${cfg.dataDir}"; - useDefaultShell = true; - }; + users.users.postgres = { + name = "postgres"; + uid = config.ids.uids.postgres; + group = "postgres"; + description = "PostgreSQL server user"; + home = "${cfg.dataDir}"; + useDefaultShell = true; + }; users.groups.postgres.gid = config.ids.gids.postgres; environment.systemPackages = [ postgresql ]; environment.pathsToLink = [ - "/share/postgresql" + "/share/postgresql" ]; - system.checks = lib.optional (cfg.checkConfig && pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform) configFileCheck; + system.checks = lib.optional ( + cfg.checkConfig && pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform + ) configFileCheck; - systemd.services.postgresql = - { description = "PostgreSQL Server"; + systemd.services.postgresql = { + description = "PostgreSQL Server"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; - environment.PGDATA = cfg.dataDir; + environment.PGDATA = cfg.dataDir; - path = [ postgresql ]; + path = [ postgresql ]; - preStart = - '' - if ! test -e ${cfg.dataDir}/PG_VERSION; then - # Cleanup the data directory. - rm -f ${cfg.dataDir}/*.conf + preStart = '' + if ! test -e ${cfg.dataDir}/PG_VERSION; then + # Cleanup the data directory. + rm -f ${cfg.dataDir}/*.conf - # Initialise the database. - initdb -U ${cfg.superUser} ${escapeShellArgs cfg.initdbArgs} + # Initialise the database. + initdb -U ${cfg.superUser} ${escapeShellArgs cfg.initdbArgs} - # See postStart! - touch "${cfg.dataDir}/.first_startup" - fi + # See postStart! + touch "${cfg.dataDir}/.first_startup" + fi - ln -sfn "${configFile}/postgresql.conf" "${cfg.dataDir}/postgresql.conf" - ${optionalString (cfg.recoveryConfig != null) '' - ln -sfn "${pkgs.writeText "recovery.conf" cfg.recoveryConfig}" \ - "${cfg.dataDir}/recovery.conf" - ''} - ''; + ln -sfn "${configFile}/postgresql.conf" "${cfg.dataDir}/postgresql.conf" + ${optionalString (cfg.recoveryConfig != null) '' + ln -sfn "${pkgs.writeText "recovery.conf" cfg.recoveryConfig}" \ + "${cfg.dataDir}/recovery.conf" + ''} + ''; - # Wait for PostgreSQL to be ready to accept connections. - postStart = - '' - PSQL="psql --port=${builtins.toString cfg.settings.port}" - - while ! $PSQL -d postgres -c "" 2> /dev/null; do - if ! kill -0 "$MAINPID"; then exit 1; fi - sleep 0.1 - done - - if test -e "${cfg.dataDir}/.first_startup"; then - ${optionalString (cfg.initialScript != null) '' - $PSQL -f "${cfg.initialScript}" -d postgres - ''} - rm -f "${cfg.dataDir}/.first_startup" - fi - '' + optionalString (cfg.ensureDatabases != []) '' - ${concatMapStrings (database: '' - $PSQL -tAc "SELECT 1 FROM pg_database WHERE datname = '${database}'" | grep -q 1 || $PSQL -tAc 'CREATE DATABASE "${database}"' - '') cfg.ensureDatabases} - '' + '' - ${ - concatMapStrings - (user: - let - dbOwnershipStmt = optionalString - user.ensureDBOwnership - ''$PSQL -tAc 'ALTER DATABASE "${user.name}" OWNER TO "${user.name}";' ''; - - filteredClauses = filterAttrs (name: value: value != null) user.ensureClauses; - - clauseSqlStatements = attrValues (mapAttrs (n: v: if v then n else "no${n}") filteredClauses); - - userClauses = ''$PSQL -tAc 'ALTER ROLE "${user.name}" ${concatStringsSep " " clauseSqlStatements}' ''; - in '' - $PSQL -tAc "SELECT 1 FROM pg_roles WHERE rolname='${user.name}'" | grep -q 1 || $PSQL -tAc 'CREATE USER "${user.name}"' - ${userClauses} - - ${dbOwnershipStmt} - '' - ) - cfg.ensureUsers - } - ''; + # Wait for PostgreSQL to be ready to accept connections. + postStart = + '' + PSQL="psql --port=${builtins.toString cfg.settings.port}" - serviceConfig = mkMerge [ - { ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - User = "postgres"; - Group = "postgres"; - RuntimeDirectory = "postgresql"; - Type = if versionAtLeast cfg.package.version "9.6" - then "notify" - else "simple"; - - # Shut down Postgres using SIGINT ("Fast Shutdown mode"). See - # https://www.postgresql.org/docs/current/server-shutdown.html - KillSignal = "SIGINT"; - KillMode = "mixed"; - - # Give Postgres a decent amount of time to clean up after - # receiving systemd's SIGINT. - TimeoutSec = 120; - - ExecStart = "${postgresql}/bin/postgres"; - - # Hardening - CapabilityBoundingSet = [ "" ]; - DevicePolicy = "closed"; - PrivateTmp = true; - ProtectHome = true; - ProtectSystem = "strict"; - MemoryDenyWriteExecute = lib.mkDefault (cfg.settings.jit == "off" && (!any extensionInstalled [ "plv8" ])); - NoNewPrivileges = true; - LockPersonality = true; - PrivateDevices = true; - PrivateMounts = true; - ProcSubset = "pid"; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - RemoveIPC = true; - RestrictAddressFamilies = [ - "AF_INET" - "AF_INET6" - "AF_NETLINK" # used for network interface enumeration - "AF_UNIX" - ]; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallFilter = - [ - "@system-service" - "~@privileged @resources" - ] - ++ lib.optionals (any extensionInstalled [ "plv8" ]) [ "@pkey" ]; - UMask = if groupAccessAvailable then "0027" else "0077"; - } - (mkIf (cfg.dataDir != "/var/lib/postgresql") { - ReadWritePaths = [ cfg.dataDir ]; - }) - (mkIf (cfg.dataDir == "/var/lib/postgresql/${cfg.package.psqlSchema}") { - StateDirectory = "postgresql postgresql/${cfg.package.psqlSchema}"; - StateDirectoryMode = if groupAccessAvailable then "0750" else "0700"; - }) - ]; + while ! $PSQL -d postgres -c "" 2> /dev/null; do + if ! kill -0 "$MAINPID"; then exit 1; fi + sleep 0.1 + done - unitConfig.RequiresMountsFor = "${cfg.dataDir}"; - }; + if test -e "${cfg.dataDir}/.first_startup"; then + ${optionalString (cfg.initialScript != null) '' + $PSQL -f "${cfg.initialScript}" -d postgres + ''} + rm -f "${cfg.dataDir}/.first_startup" + fi + '' + + optionalString (cfg.ensureDatabases != [ ]) '' + ${concatMapStrings (database: '' + $PSQL -tAc "SELECT 1 FROM pg_database WHERE datname = '${database}'" | grep -q 1 || $PSQL -tAc 'CREATE DATABASE "${database}"' + '') cfg.ensureDatabases} + '' + + '' + ${concatMapStrings ( + user: + let + dbOwnershipStmt = optionalString user.ensureDBOwnership ''$PSQL -tAc 'ALTER DATABASE "${user.name}" OWNER TO "${user.name}";' ''; + + filteredClauses = filterAttrs (name: value: value != null) user.ensureClauses; + + clauseSqlStatements = attrValues (mapAttrs (n: v: if v then n else "no${n}") filteredClauses); + + userClauses = ''$PSQL -tAc 'ALTER ROLE "${user.name}" ${concatStringsSep " " clauseSqlStatements}' ''; + in + '' + $PSQL -tAc "SELECT 1 FROM pg_roles WHERE rolname='${user.name}'" | grep -q 1 || $PSQL -tAc 'CREATE USER "${user.name}"' + ${userClauses} + + ${dbOwnershipStmt} + '' + ) cfg.ensureUsers} + ''; + + serviceConfig = mkMerge [ + { + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + User = "postgres"; + Group = "postgres"; + RuntimeDirectory = "postgresql"; + Type = if versionAtLeast cfg.package.version "9.6" then "notify" else "simple"; + + # Shut down Postgres using SIGINT ("Fast Shutdown mode"). See + # https://www.postgresql.org/docs/current/server-shutdown.html + KillSignal = "SIGINT"; + KillMode = "mixed"; + + # Give Postgres a decent amount of time to clean up after + # receiving systemd's SIGINT. + TimeoutSec = 120; + + ExecStart = "${postgresql}/bin/postgres"; + + # Hardening + CapabilityBoundingSet = [ "" ]; + DevicePolicy = "closed"; + PrivateTmp = true; + ProtectHome = true; + ProtectSystem = "strict"; + MemoryDenyWriteExecute = lib.mkDefault ( + cfg.settings.jit == "off" && (!any extensionInstalled [ "plv8" ]) + ); + NoNewPrivileges = true; + LockPersonality = true; + PrivateDevices = true; + PrivateMounts = true; + ProcSubset = "pid"; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + RemoveIPC = true; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_NETLINK" # used for network interface enumeration + "AF_UNIX" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged @resources" + ] ++ lib.optionals (any extensionInstalled [ "plv8" ]) [ "@pkey" ]; + UMask = if groupAccessAvailable then "0027" else "0077"; + } + (mkIf (cfg.dataDir != "/var/lib/postgresql") { + ReadWritePaths = [ cfg.dataDir ]; + }) + (mkIf (cfg.dataDir == "/var/lib/postgresql/${cfg.package.psqlSchema}") { + StateDirectory = "postgresql postgresql/${cfg.package.psqlSchema}"; + StateDirectoryMode = if groupAccessAvailable then "0750" else "0700"; + }) + ]; + + unitConfig.RequiresMountsFor = "${cfg.dataDir}"; + }; }; meta.doc = ./postgresql.md; - meta.maintainers = with lib.maintainers; [ thoughtpolice danbst ]; + meta.maintainers = with lib.maintainers; [ + thoughtpolice + danbst + ]; } diff --git a/nixos/modules/services/databases/rethinkdb.nix b/nixos/modules/services/databases/rethinkdb.nix index 1b85fd1bb7bda2..43cfc95c58259b 100644 --- a/nixos/modules/services/databases/rethinkdb.nix +++ b/nixos/modules/services/databases/rethinkdb.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.rethinkdb; rethinkdb = cfg.package; @@ -90,15 +95,17 @@ in ''; }; - users.users.rethinkdb = lib.mkIf (cfg.user == "rethinkdb") - { name = "rethinkdb"; - description = "RethinkDB server user"; - isSystemUser = true; - }; + users.users.rethinkdb = lib.mkIf (cfg.user == "rethinkdb") { + name = "rethinkdb"; + description = "RethinkDB server user"; + isSystemUser = true; + }; - users.groups = lib.optionalAttrs (cfg.group == "rethinkdb") (lib.singleton - { name = "rethinkdb"; - }); + users.groups = lib.optionalAttrs (cfg.group == "rethinkdb") ( + lib.singleton { + name = "rethinkdb"; + } + ); }; diff --git a/nixos/modules/services/databases/surrealdb.nix b/nixos/modules/services/databases/surrealdb.nix index d38b7b311f1f8c..d5567f25b7cfdf 100644 --- a/nixos/modules/services/databases/surrealdb.nix +++ b/nixos/modules/services/databases/surrealdb.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.surrealdb; -in { +in +{ options = { services.surrealdb = { @@ -40,8 +46,14 @@ in { extraFlags = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; - example = [ "--allow-all" "--user" "root" "--pass" "root" ]; + default = [ ]; + example = [ + "--allow-all" + "--user" + "root" + "--pass" + "root" + ]; description = '' Specify a list of additional command line flags. ''; @@ -52,7 +64,7 @@ in { config = lib.mkIf cfg.enable { # Used to connect to the running service - environment.systemPackages = [ cfg.package ] ; + environment.systemPackages = [ cfg.package ]; systemd.services.surrealdb = { description = "A scalable, distributed, collaborative, document-graph database, for the realtime web"; @@ -81,7 +93,10 @@ in { RestrictNamespaces = true; LockPersonality = true; RemoveIPC = true; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; }; }; }; diff --git a/nixos/modules/services/databases/tigerbeetle.nix b/nixos/modules/services/databases/tigerbeetle.nix index 7b512055e44e57..514652a6c8d145 100644 --- a/nixos/modules/services/databases/tigerbeetle.nix +++ b/nixos/modules/services/databases/tigerbeetle.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.tigerbeetle; in @@ -76,7 +81,11 @@ in } { assertion = cfg.replicaCount == numAddresses; - message = if cfg.replicaCount < numAddresses then "TigerBeetle must not have more addresses than the configured number of replicas" else "TigerBeetle must be configured with the addresses of all replicas"; + message = + if cfg.replicaCount < numAddresses then + "TigerBeetle must not have more addresses than the configured number of replicas" + else + "TigerBeetle must be configured with the addresses of all replicas"; } ]; @@ -110,7 +119,10 @@ in ProtectKernelTunables = true; ProtectProc = "noaccess"; ProtectSystem = "strict"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; diff --git a/nixos/modules/services/databases/victoriametrics.nix b/nixos/modules/services/databases/victoriametrics.nix index ba7464ade56c03..e22b85371c3a15 100644 --- a/nixos/modules/services/databases/victoriametrics.nix +++ b/nixos/modules/services/databases/victoriametrics.nix @@ -139,7 +139,7 @@ in serviceConfig = { ExecStart = lib.escapeShellArgs ( startCLIList - ++ lib.optionals (cfg.prometheusConfig != {}) [ "-promscrape.config=${prometheusConfigYml}" ] + ++ lib.optionals (cfg.prometheusConfig != { }) [ "-promscrape.config=${prometheusConfigYml}" ] ); DynamicUser = true; diff --git a/nixos/modules/services/desktop-managers/lomiri.nix b/nixos/modules/services/desktop-managers/lomiri.nix index f48cce7ab210fb..4ddc33fd33c37a 100644 --- a/nixos/modules/services/desktop-managers/lomiri.nix +++ b/nixos/modules/services/desktop-managers/lomiri.nix @@ -29,9 +29,13 @@ in (lib.mkIf cfg.basics { environment = { # To override the default keyboard layout in Lomiri - etc.${pkgs.lomiri.lomiri.passthru.etcLayoutsFile}.text = lib.strings.replaceStrings [ "," ] [ - "\n" - ] config.services.xserver.xkb.layout; + etc.${pkgs.lomiri.lomiri.passthru.etcLayoutsFile}.text = + lib.strings.replaceStrings + [ "," ] + [ + "\n" + ] + config.services.xserver.xkb.layout; pathsToLink = [ # Data diff --git a/nixos/modules/services/desktop-managers/plasma6.nix b/nixos/modules/services/desktop-managers/plasma6.nix index a15a6ebce29106..0ba3cd5dafab9c 100644 --- a/nixos/modules/services/desktop-managers/plasma6.nix +++ b/nixos/modules/services/desktop-managers/plasma6.nix @@ -4,17 +4,26 @@ pkgs, utils, ... -}: let +}: +let cfg = config.services.desktopManager.plasma6; inherit (pkgs) kdePackages; - inherit (lib) literalExpression mkDefault mkIf mkOption mkPackageOption types; + inherit (lib) + literalExpression + mkDefault + mkIf + mkOption + mkPackageOption + types + ; activationScript = '' # will be rebuilt automatically rm -fv "$HOME/.cache/ksycoca"* ''; -in { +in +{ options = { services.desktopManager.plasma6 = { enable = mkOption { @@ -30,7 +39,7 @@ in { }; notoPackage = mkPackageOption pkgs "Noto fonts - used for UI by default" { - default = ["noto-fonts"]; + default = [ "noto-fonts" ]; example = "noto-fonts-lgc-plus"; }; }; @@ -38,15 +47,24 @@ in { environment.plasma6.excludePackages = mkOption { description = "List of default packages to exclude from the configuration"; type = types.listOf types.package; - default = []; + default = [ ]; example = literalExpression "[ pkgs.kdePackages.elisa ]"; }; }; imports = [ - (lib.mkRenamedOptionModule [ "services" "xserver" "desktopManager" "plasma6" "enable" ] [ "services" "desktopManager" "plasma6" "enable" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "desktopManager" "plasma6" "enableQt5Integration" ] [ "services" "desktopManager" "plasma6" "enableQt5Integration" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "desktopManager" "plasma6" "notoPackage" ] [ "services" "desktopManager" "plasma6" "notoPackage" ]) + (lib.mkRenamedOptionModule + [ "services" "xserver" "desktopManager" "plasma6" "enable" ] + [ "services" "desktopManager" "plasma6" "enable" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "desktopManager" "plasma6" "enableQt5Integration" ] + [ "services" "desktopManager" "plasma6" "enableQt5Integration" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "desktopManager" "plasma6" "notoPackage" ] + [ "services" "desktopManager" "plasma6" "notoPackage" ] + ) ]; config = mkIf cfg.enable { @@ -59,104 +77,108 @@ in { qt.enable = true; programs.xwayland.enable = true; - environment.systemPackages = with kdePackages; let - requiredPackages = [ - qtwayland # Hack? To make everything run on Wayland - qtsvg # Needed to render SVG icons - - # Frameworks with globally loadable bits - frameworkintegration # provides Qt plugin - kauth # provides helper service - kcoreaddons # provides extra mime type info - kded # provides helper service - kfilemetadata # provides Qt plugins - kguiaddons # provides geo URL handlers - kiconthemes # provides Qt plugins - kimageformats # provides Qt plugins - qtimageformats # provides optional image formats such as .webp and .avif - kio # provides helper service + a bunch of other stuff - kio-admin # managing files as admin - kio-extras # stuff for MTP, AFC, etc - kio-fuse # fuse interface for KIO - kpackage # provides kpackagetool tool - kservice # provides kbuildsycoca6 tool - kunifiedpush # provides a background service and a KCM - kwallet # provides helper service - kwallet-pam # provides helper service - kwalletmanager # provides KCMs and stuff - plasma-activities # provides plasma-activities-cli tool - solid # provides solid-hardware6 tool - phonon-vlc # provides Phonon plugin - - # Core Plasma parts - kwin - kscreen - libkscreen - kscreenlocker - kactivitymanagerd - kde-cli-tools - kglobalacceld # keyboard shortcut daemon - kwrited # wall message proxy, not to be confused with kwrite - baloo # system indexer - milou # search engine atop baloo - kdegraphics-thumbnailers # pdf etc thumbnailer - polkit-kde-agent-1 # polkit auth ui - plasma-desktop - plasma-workspace - drkonqi # crash handler - kde-inotify-survey # warns the user on low inotifywatch limits - - # Application integration - libplasma # provides Kirigami platform theme - plasma-integration # provides Qt platform theme - kde-gtk-config # syncs KDE settings to GTK - - # Artwork + themes - breeze - breeze-icons - breeze-gtk - ocean-sound-theme - plasma-workspace-wallpapers - pkgs.hicolor-icon-theme # fallback icons - qqc2-breeze-style - qqc2-desktop-style - - # misc Plasma extras - kdeplasma-addons - pkgs.xdg-user-dirs # recommended upstream - - # Plasma utilities - kmenuedit - kinfocenter - plasma-systemmonitor - ksystemstats - libksysguard - systemsettings - kcmutils - ]; - optionalPackages = [ - plasma-browser-integration - konsole - (lib.getBin qttools) # Expose qdbus in PATH - ark - elisa - gwenview - okular - kate - khelpcenter - dolphin - baloo-widgets # baloo information in Dolphin - dolphin-plugins - spectacle - ffmpegthumbs - krdp - xwaylandvideobridge # exposes Wayland windows to X11 screen capture - ] ++ lib.optionals config.services.flatpak.enable [ - # Since PackageKit Nix support is not there yet, - # only install discover if flatpak is enabled. - discover - ]; - in + environment.systemPackages = + with kdePackages; + let + requiredPackages = [ + qtwayland # Hack? To make everything run on Wayland + qtsvg # Needed to render SVG icons + + # Frameworks with globally loadable bits + frameworkintegration # provides Qt plugin + kauth # provides helper service + kcoreaddons # provides extra mime type info + kded # provides helper service + kfilemetadata # provides Qt plugins + kguiaddons # provides geo URL handlers + kiconthemes # provides Qt plugins + kimageformats # provides Qt plugins + qtimageformats # provides optional image formats such as .webp and .avif + kio # provides helper service + a bunch of other stuff + kio-admin # managing files as admin + kio-extras # stuff for MTP, AFC, etc + kio-fuse # fuse interface for KIO + kpackage # provides kpackagetool tool + kservice # provides kbuildsycoca6 tool + kunifiedpush # provides a background service and a KCM + kwallet # provides helper service + kwallet-pam # provides helper service + kwalletmanager # provides KCMs and stuff + plasma-activities # provides plasma-activities-cli tool + solid # provides solid-hardware6 tool + phonon-vlc # provides Phonon plugin + + # Core Plasma parts + kwin + kscreen + libkscreen + kscreenlocker + kactivitymanagerd + kde-cli-tools + kglobalacceld # keyboard shortcut daemon + kwrited # wall message proxy, not to be confused with kwrite + baloo # system indexer + milou # search engine atop baloo + kdegraphics-thumbnailers # pdf etc thumbnailer + polkit-kde-agent-1 # polkit auth ui + plasma-desktop + plasma-workspace + drkonqi # crash handler + kde-inotify-survey # warns the user on low inotifywatch limits + + # Application integration + libplasma # provides Kirigami platform theme + plasma-integration # provides Qt platform theme + kde-gtk-config # syncs KDE settings to GTK + + # Artwork + themes + breeze + breeze-icons + breeze-gtk + ocean-sound-theme + plasma-workspace-wallpapers + pkgs.hicolor-icon-theme # fallback icons + qqc2-breeze-style + qqc2-desktop-style + + # misc Plasma extras + kdeplasma-addons + pkgs.xdg-user-dirs # recommended upstream + + # Plasma utilities + kmenuedit + kinfocenter + plasma-systemmonitor + ksystemstats + libksysguard + systemsettings + kcmutils + ]; + optionalPackages = + [ + plasma-browser-integration + konsole + (lib.getBin qttools) # Expose qdbus in PATH + ark + elisa + gwenview + okular + kate + khelpcenter + dolphin + baloo-widgets # baloo information in Dolphin + dolphin-plugins + spectacle + ffmpegthumbs + krdp + xwaylandvideobridge # exposes Wayland windows to X11 screen capture + ] + ++ lib.optionals config.services.flatpak.enable [ + # Since PackageKit Nix support is not there yet, + # only install discover if flatpak is enabled. + discover + ]; + in requiredPackages ++ utils.removePackagesByName optionalPackages config.environment.plasma6.excludePackages ++ lib.optionals config.services.desktopManager.plasma6.enableQt5Integration [ @@ -169,7 +191,8 @@ in { let kioPluginPath = "${pkgs.plasma5Packages.qtbase.qtPluginPrefix}/kf5/kio"; inherit (pkgs.plasma5Packages) kio; - in pkgs.runCommand "kio5-plugins-only" {} '' + in + pkgs.runCommand "kio5-plugins-only" { } '' mkdir -p $out/${kioPluginPath} ln -s ${kio}/${kioPluginPath}/* $out/${kioPluginPath} '' @@ -177,7 +200,12 @@ in { kio-extras-kf5 ] # Optional and hardware support features - ++ lib.optionals config.hardware.bluetooth.enable [bluedevil bluez-qt pkgs.openobex pkgs.obexftp] + ++ lib.optionals config.hardware.bluetooth.enable [ + bluedevil + bluez-qt + pkgs.openobex + pkgs.obexftp + ] ++ lib.optional config.networking.networkmanager.enable plasma-nm ++ lib.optional config.hardware.pulseaudio.enable plasma-pa ++ lib.optional config.services.pipewire.pulse.enable plasma-pa @@ -199,7 +227,7 @@ in { # Add ~/.config/kdedefaults to XDG_CONFIG_DIRS for shells, since Plasma sets that. # FIXME: maybe we should append to XDG_CONFIG_DIRS in /etc/set-environment instead? - environment.sessionVariables.XDG_CONFIG_DIRS = ["$HOME/.config/kdedefaults"]; + environment.sessionVariables.XDG_CONFIG_DIRS = [ "$HOME/.config/kdedefaults" ]; # Needed for things that depend on other store.kde.org packages to install correctly, # notably Plasma look-and-feel packages (a.k.a. Global Themes) @@ -211,13 +239,19 @@ in { environment.sessionVariables.KPACKAGE_DEP_RESOLVERS_PATH = "${kdePackages.frameworkintegration.out}/libexec/kf6/kpackagehandlers"; # Enable GTK applications to load SVG icons - programs.gdk-pixbuf.modulePackages = [pkgs.librsvg]; + programs.gdk-pixbuf.modulePackages = [ pkgs.librsvg ]; - fonts.packages = [cfg.notoPackage pkgs.hack-font]; + fonts.packages = [ + cfg.notoPackage + pkgs.hack-font + ]; fonts.fontconfig.defaultFonts = { - monospace = ["Hack" "Noto Sans Mono"]; - sansSerif = ["Noto Sans"]; - serif = ["Noto Serif"]; + monospace = [ + "Hack" + "Noto Sans Mono" + ]; + sansSerif = [ "Noto Sans" ]; + serif = [ "Noto Serif" ]; }; programs.gnupg.agent.pinentryPackage = mkDefault pkgs.pinentry-qt; @@ -243,11 +277,11 @@ in { ]; # Set up Dr. Konqi as crash handler - systemd.packages = [kdePackages.drkonqi]; - systemd.services."drkonqi-coredump-processor@".wantedBy = ["systemd-coredump@.service"]; + systemd.packages = [ kdePackages.drkonqi ]; + systemd.services."drkonqi-coredump-processor@".wantedBy = [ "systemd-coredump@.service" ]; xdg.icons.enable = true; - xdg.icons.fallbackCursorThemes = mkDefault ["breeze_cursors"]; + xdg.icons.fallbackCursorThemes = mkDefault [ "breeze_cursors" ]; xdg.portal.enable = true; xdg.portal.extraPortals = [ @@ -255,14 +289,14 @@ in { kdePackages.xdg-desktop-portal-kde pkgs.xdg-desktop-portal-gtk ]; - xdg.portal.configPackages = mkDefault [kdePackages.plasma-workspace]; + xdg.portal.configPackages = mkDefault [ kdePackages.plasma-workspace ]; services.pipewire.enable = mkDefault true; # Enable screen reader by default services.orca.enable = mkDefault true; services.displayManager = { - sessionPackages = [kdePackages.plasma-workspace]; + sessionPackages = [ kdePackages.plasma-workspace ]; defaultSession = mkDefault "plasma"; }; services.displayManager.sddm = { @@ -306,7 +340,7 @@ in { programs.dconf.enable = true; - programs.firefox.nativeMessagingHosts.packages = [kdePackages.plasma-browser-integration]; + programs.firefox.nativeMessagingHosts.packages = [ kdePackages.plasma-browser-integration ]; programs.chromium = { enablePlasmaBrowserIntegration = true; diff --git a/nixos/modules/services/desktops/accountsservice.nix b/nixos/modules/services/desktops/accountsservice.nix index 4c407ca3828a20..758f7383ca634a 100644 --- a/nixos/modules/services/desktops/accountsservice.nix +++ b/nixos/modules/services/desktops/accountsservice.nix @@ -1,5 +1,10 @@ # AccountsService daemon. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { meta = { maintainers = lib.teams.freedesktop.members; @@ -35,16 +40,21 @@ systemd.packages = [ pkgs.accountsservice ]; - systemd.services.accounts-daemon = lib.recursiveUpdate { + systemd.services.accounts-daemon = + lib.recursiveUpdate + { - wantedBy = [ "graphical.target" ]; + wantedBy = [ "graphical.target" ]; - # Accounts daemon looks for dbus interfaces in $XDG_DATA_DIRS/accountsservice - environment.XDG_DATA_DIRS = "${config.system.path}/share"; + # Accounts daemon looks for dbus interfaces in $XDG_DATA_DIRS/accountsservice + environment.XDG_DATA_DIRS = "${config.system.path}/share"; - } (lib.optionalAttrs (!config.users.mutableUsers) { - environment.NIXOS_USERS_PURE = "true"; - }); + } + ( + lib.optionalAttrs (!config.users.mutableUsers) { + environment.NIXOS_USERS_PURE = "true"; + } + ); }; } diff --git a/nixos/modules/services/desktops/blueman.nix b/nixos/modules/services/desktops/blueman.nix index 4f02d288e2dfc2..2b92d226dfa489 100644 --- a/nixos/modules/services/desktops/blueman.nix +++ b/nixos/modules/services/desktops/blueman.nix @@ -1,8 +1,14 @@ # blueman service -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.blueman; -in { +in +{ ###### interface options = { services.blueman = { diff --git a/nixos/modules/services/desktops/cpupower-gui.nix b/nixos/modules/services/desktops/cpupower-gui.nix index ceed84da840eaf..1a6a371d3fada5 100644 --- a/nixos/modules/services/desktops/cpupower-gui.nix +++ b/nixos/modules/services/desktops/cpupower-gui.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.cpupower-gui; -in { +in +{ options = { services.cpupower-gui = { enable = lib.mkOption { diff --git a/nixos/modules/services/desktops/deepin/app-services.nix b/nixos/modules/services/desktops/deepin/app-services.nix index 7d99bd11802f02..270889b66f924c 100644 --- a/nixos/modules/services/desktops/deepin/app-services.nix +++ b/nixos/modules/services/desktops/deepin/app-services.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { meta = { @@ -17,7 +22,6 @@ }; - ###### implementation config = lib.mkIf config.services.deepin.app-services.enable { diff --git a/nixos/modules/services/desktops/deepin/dde-api.nix b/nixos/modules/services/desktops/deepin/dde-api.nix index 89889b3530c939..9994c4359e9a38 100644 --- a/nixos/modules/services/desktops/deepin/dde-api.nix +++ b/nixos/modules/services/desktops/deepin/dde-api.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { meta = { @@ -20,27 +25,26 @@ }; - ###### implementation config = lib.mkIf config.services.deepin.dde-api.enable { - environment.systemPackages = [ pkgs.deepin.dde-api ]; + environment.systemPackages = [ pkgs.deepin.dde-api ]; - services.dbus.packages = [ pkgs.deepin.dde-api ]; + services.dbus.packages = [ pkgs.deepin.dde-api ]; - systemd.packages = [ pkgs.deepin.dde-api ]; + systemd.packages = [ pkgs.deepin.dde-api ]; - environment.pathsToLink = [ "/lib/deepin-api" ]; + environment.pathsToLink = [ "/lib/deepin-api" ]; - users.groups.deepin-sound-player = { }; - users.users.deepin-sound-player = { - description = "Deepin sound player"; - home = "/var/lib/deepin-sound-player"; - createHome = true; - group = "deepin-sound-player"; - isSystemUser = true; - }; + users.groups.deepin-sound-player = { }; + users.users.deepin-sound-player = { + description = "Deepin sound player"; + home = "/var/lib/deepin-sound-player"; + createHome = true; + group = "deepin-sound-player"; + isSystemUser = true; + }; }; diff --git a/nixos/modules/services/desktops/deepin/dde-daemon.nix b/nixos/modules/services/desktops/deepin/dde-daemon.nix index 2188276f4b2240..809b2a3fec6db2 100644 --- a/nixos/modules/services/desktops/deepin/dde-daemon.nix +++ b/nixos/modules/services/desktops/deepin/dde-daemon.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { meta = { @@ -17,7 +22,6 @@ }; - ###### implementation config = lib.mkIf config.services.deepin.dde-daemon.enable { diff --git a/nixos/modules/services/desktops/deepin/deepin-anything.nix b/nixos/modules/services/desktops/deepin/deepin-anything.nix index 4e88a789551b93..9b69e6442edbc3 100644 --- a/nixos/modules/services/desktops/deepin/deepin-anything.nix +++ b/nixos/modules/services/desktops/deepin/deepin-anything.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { diff --git a/nixos/modules/services/desktops/dleyna-renderer.nix b/nixos/modules/services/desktops/dleyna-renderer.nix index f36f1fbb1a4ec0..78375735e6e1ca 100644 --- a/nixos/modules/services/desktops/dleyna-renderer.nix +++ b/nixos/modules/services/desktops/dleyna-renderer.nix @@ -1,5 +1,10 @@ # dleyna-renderer service. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { ###### interface options = { @@ -15,7 +20,6 @@ }; }; - ###### implementation config = lib.mkIf config.services.dleyna-renderer.enable { environment.systemPackages = [ pkgs.dleyna-renderer ]; diff --git a/nixos/modules/services/desktops/dleyna-server.nix b/nixos/modules/services/desktops/dleyna-server.nix index 812110281ae49b..e36340405790c6 100644 --- a/nixos/modules/services/desktops/dleyna-server.nix +++ b/nixos/modules/services/desktops/dleyna-server.nix @@ -1,5 +1,10 @@ # dleyna-server service. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { ###### interface options = { @@ -15,7 +20,6 @@ }; }; - ###### implementation config = lib.mkIf config.services.dleyna-server.enable { environment.systemPackages = [ pkgs.dleyna-server ]; diff --git a/nixos/modules/services/desktops/espanso.nix b/nixos/modules/services/desktops/espanso.nix index 943c6fae86d9e9..c2a783b1573102 100644 --- a/nixos/modules/services/desktops/espanso.nix +++ b/nixos/modules/services/desktops/espanso.nix @@ -1,7 +1,19 @@ -{ config, lib, pkgs, ... }: -let cfg = config.services.espanso; -in { - meta = { maintainers = with lib.maintainers; [ n8henrie numkem ]; }; +{ + config, + lib, + pkgs, + ... +}: +let + cfg = config.services.espanso; +in +{ + meta = { + maintainers = with lib.maintainers; [ + n8henrie + numkem + ]; + }; options = { services.espanso = { diff --git a/nixos/modules/services/desktops/geoclue2.nix b/nixos/modules/services/desktops/geoclue2.nix index 6d040b71bd9163..16d1cb17ca066d 100644 --- a/nixos/modules/services/desktops/geoclue2.nix +++ b/nixos/modules/services/desktops/geoclue2.nix @@ -1,53 +1,73 @@ # GeoClue 2 daemon. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.geoclue2; - defaultWhitelist = [ "gnome-shell" "io.elementary.desktop.agent-geoclue2" ]; + defaultWhitelist = [ + "gnome-shell" + "io.elementary.desktop.agent-geoclue2" + ]; + + appConfigModule = lib.types.submodule ( + { name, ... }: + { + options = { + desktopID = lib.mkOption { + type = lib.types.str; + description = "Desktop ID of the application."; + }; - appConfigModule = lib.types.submodule ({ name, ... }: { - options = { - desktopID = lib.mkOption { - type = lib.types.str; - description = "Desktop ID of the application."; - }; + isAllowed = lib.mkOption { + type = lib.types.bool; + description = '' + Whether the application will be allowed access to location information. + ''; + }; - isAllowed = lib.mkOption { - type = lib.types.bool; - description = '' - Whether the application will be allowed access to location information. - ''; - }; + isSystem = lib.mkOption { + type = lib.types.bool; + description = '' + Whether the application is a system component or not. + ''; + }; - isSystem = lib.mkOption { - type = lib.types.bool; - description = '' - Whether the application is a system component or not. - ''; + users = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + description = '' + List of UIDs of all users for which this application is allowed location + info access, Defaults to an empty string to allow it for all users. + ''; + }; }; - users = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - description = '' - List of UIDs of all users for which this application is allowed location - info access, Defaults to an empty string to allow it for all users. - ''; + config.desktopID = lib.mkDefault name; + } + ); + + appConfigToINICompatible = + _: + { + desktopID, + isAllowed, + isSystem, + users, + ... + }: + { + name = desktopID; + value = { + allowed = isAllowed; + system = isSystem; + users = lib.concatStringsSep ";" users; }; }; - config.desktopID = lib.mkDefault name; - }); - - appConfigToINICompatible = _: { desktopID, isAllowed, isSystem, users, ... }: { - name = desktopID; - value = { - allowed = isAllowed; - system = isSystem; - users = lib.concatStringsSep ";" users; - }; - }; - in { @@ -129,10 +149,12 @@ in type = lib.types.package; default = pkgs.geoclue2; defaultText = lib.literalExpression "pkgs.geoclue2"; - apply = pkg: pkg.override { - # the demo agent isn't built by default, but we need it here - withDemoAgent = cfg.enableDemoAgent; - }; + apply = + pkg: + pkg.override { + # the demo agent isn't built by default, but we need it here + withDemoAgent = cfg.enableDemoAgent; + }; description = "The geoclue2 package to use"; }; @@ -163,7 +185,7 @@ in appConfig = lib.mkOption { type = lib.types.attrsOf appConfigModule; - default = {}; + default = { }; example = lib.literalExpression '' "com.github.app" = { isAllowed = true; @@ -180,7 +202,6 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { @@ -200,7 +221,7 @@ in description = "Geoinformation service"; }; - groups.geoclue = {}; + groups.geoclue = { }; }; systemd.services.geoclue = { @@ -244,11 +265,12 @@ in isSystem = false; }; - environment.etc."geoclue/geoclue.conf".text = - lib.generators.toINI {} ({ + environment.etc."geoclue/geoclue.conf".text = lib.generators.toINI { } ( + { agent = { - whitelist = lib.concatStringsSep ";" - (lib.optional cfg.enableDemoAgent "geoclue-demo-agent" ++ defaultWhitelist); + whitelist = lib.concatStringsSep ";" ( + lib.optional cfg.enableDemoAgent "geoclue-demo-agent" ++ defaultWhitelist + ); }; network-nmea = { enable = cfg.enableNmea; @@ -269,7 +291,9 @@ in submission-url = cfg.submissionUrl; submission-nick = cfg.submissionNick; }; - } // lib.mapAttrs' appConfigToINICompatible cfg.appConfig); + } + // lib.mapAttrs' appConfigToINICompatible cfg.appConfig + ); }; meta = with lib; { diff --git a/nixos/modules/services/desktops/gnome/at-spi2-core.nix b/nixos/modules/services/desktops/gnome/at-spi2-core.nix index 6ed5b198fe4f8a..293a3166b18723 100644 --- a/nixos/modules/services/desktops/gnome/at-spi2-core.nix +++ b/nixos/modules/services/desktops/gnome/at-spi2-core.nix @@ -1,6 +1,11 @@ # at-spi2-core daemon. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { @@ -29,7 +34,6 @@ }; - ###### implementation config = lib.mkMerge [ diff --git a/nixos/modules/services/desktops/gnome/evolution-data-server.nix b/nixos/modules/services/desktops/gnome/evolution-data-server.nix index a43e8dadb42126..539fcf25342e14 100644 --- a/nixos/modules/services/desktops/gnome/evolution-data-server.nix +++ b/nixos/modules/services/desktops/gnome/evolution-data-server.nix @@ -1,6 +1,11 @@ # Evolution Data Server daemon. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { @@ -36,7 +41,9 @@ config = let - bundle = pkgs.evolutionWithPlugins.override { inherit (config.services.gnome.evolution-data-server) plugins; }; + bundle = pkgs.evolutionWithPlugins.override { + inherit (config.services.gnome.evolution-data-server) plugins; + }; in lib.mkMerge [ (lib.mkIf config.services.gnome.evolution-data-server.enable { diff --git a/nixos/modules/services/desktops/gnome/glib-networking.nix b/nixos/modules/services/desktops/gnome/glib-networking.nix index 905901f4708415..558abca0aa315f 100644 --- a/nixos/modules/services/desktops/gnome/glib-networking.nix +++ b/nixos/modules/services/desktops/gnome/glib-networking.nix @@ -1,6 +1,11 @@ # GLib Networking -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { diff --git a/nixos/modules/services/desktops/gnome/gnome-browser-connector.nix b/nixos/modules/services/desktops/gnome/gnome-browser-connector.nix index 4f0c36883a3f56..335ebc9a144d3f 100644 --- a/nixos/modules/services/desktops/gnome/gnome-browser-connector.nix +++ b/nixos/modules/services/desktops/gnome/gnome-browser-connector.nix @@ -1,7 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkIf mkRenamedOptionModule teams; + inherit (lib) + mkEnableOption + mkIf + mkRenamedOptionModule + teams + ; in { @@ -18,11 +28,15 @@ in config = mkIf config.services.gnome.gnome-browser-connector.enable { environment.etc = { - "chromium/native-messaging-hosts/org.gnome.browser_connector.json".source = "${pkgs.gnome-browser-connector}/etc/chromium/native-messaging-hosts/org.gnome.browser_connector.json"; - "opt/chrome/native-messaging-hosts/org.gnome.browser_connector.json".source = "${pkgs.gnome-browser-connector}/etc/opt/chrome/native-messaging-hosts/org.gnome.browser_connector.json"; + "chromium/native-messaging-hosts/org.gnome.browser_connector.json".source = + "${pkgs.gnome-browser-connector}/etc/chromium/native-messaging-hosts/org.gnome.browser_connector.json"; + "opt/chrome/native-messaging-hosts/org.gnome.browser_connector.json".source = + "${pkgs.gnome-browser-connector}/etc/opt/chrome/native-messaging-hosts/org.gnome.browser_connector.json"; # Legacy paths. - "chromium/native-messaging-hosts/org.gnome.chrome_gnome_shell.json".source = "${pkgs.gnome-browser-connector}/etc/chromium/native-messaging-hosts/org.gnome.chrome_gnome_shell.json"; - "opt/chrome/native-messaging-hosts/org.gnome.chrome_gnome_shell.json".source = "${pkgs.gnome-browser-connector}/etc/opt/chrome/native-messaging-hosts/org.gnome.chrome_gnome_shell.json"; + "chromium/native-messaging-hosts/org.gnome.chrome_gnome_shell.json".source = + "${pkgs.gnome-browser-connector}/etc/chromium/native-messaging-hosts/org.gnome.chrome_gnome_shell.json"; + "opt/chrome/native-messaging-hosts/org.gnome.chrome_gnome_shell.json".source = + "${pkgs.gnome-browser-connector}/etc/opt/chrome/native-messaging-hosts/org.gnome.chrome_gnome_shell.json"; }; environment.systemPackages = [ pkgs.gnome-browser-connector ]; diff --git a/nixos/modules/services/desktops/gnome/gnome-initial-setup.nix b/nixos/modules/services/desktops/gnome/gnome-initial-setup.nix index 4f1b23c8f36e72..f130b820b71670 100644 --- a/nixos/modules/services/desktops/gnome/gnome-initial-setup.nix +++ b/nixos/modules/services/desktops/gnome/gnome-initial-setup.nix @@ -1,6 +1,11 @@ # GNOME Initial Setup. -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let @@ -58,16 +63,15 @@ in }; - ###### implementation config = lib.mkIf config.services.gnome.gnome-initial-setup.enable { - environment.systemPackages = [ - pkgs.gnome-initial-setup - ] - ++ lib.optional (lib.versionOlder config.system.stateVersion "20.03") createGisStampFilesAutostart - ; + environment.systemPackages = + [ + pkgs.gnome-initial-setup + ] + ++ lib.optional (lib.versionOlder config.system.stateVersion "20.03") createGisStampFilesAutostart; systemd.packages = [ pkgs.gnome-initial-setup diff --git a/nixos/modules/services/desktops/gnome/gnome-online-accounts.nix b/nixos/modules/services/desktops/gnome/gnome-online-accounts.nix index de3c3789594a8c..920c4cf8133e50 100644 --- a/nixos/modules/services/desktops/gnome/gnome-online-accounts.nix +++ b/nixos/modules/services/desktops/gnome/gnome-online-accounts.nix @@ -1,6 +1,11 @@ # GNOME Online Accounts daemon. -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { @@ -27,7 +32,6 @@ }; - ###### implementation config = lib.mkIf config.services.gnome.gnome-online-accounts.enable { diff --git a/nixos/modules/services/desktops/gnome/gnome-online-miners.nix b/nixos/modules/services/desktops/gnome/gnome-online-miners.nix index 3882b90ad78a28..8fb1309abb6286 100644 --- a/nixos/modules/services/desktops/gnome/gnome-online-miners.nix +++ b/nixos/modules/services/desktops/gnome/gnome-online-miners.nix @@ -4,6 +4,10 @@ { imports = [ - (lib.mkRemovedOptionModule [ "services" "gnome" "gnome-online-miners" ] "It was broken for a while now.") + (lib.mkRemovedOptionModule [ + "services" + "gnome" + "gnome-online-miners" + ] "It was broken for a while now.") ]; } diff --git a/nixos/modules/services/desktops/gnome/gnome-remote-desktop.nix b/nixos/modules/services/desktops/gnome/gnome-remote-desktop.nix index 8ffb4a201e367f..6e685557ecf087 100644 --- a/nixos/modules/services/desktops/gnome/gnome-remote-desktop.nix +++ b/nixos/modules/services/desktops/gnome/gnome-remote-desktop.nix @@ -1,5 +1,10 @@ # Remote desktop daemon using Pipewire. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { meta = { diff --git a/nixos/modules/services/desktops/gnome/gnome-settings-daemon.nix b/nixos/modules/services/desktops/gnome/gnome-settings-daemon.nix index 21e7c3b587134d..06d001ab813449 100644 --- a/nixos/modules/services/desktops/gnome/gnome-settings-daemon.nix +++ b/nixos/modules/services/desktops/gnome/gnome-settings-daemon.nix @@ -1,6 +1,11 @@ # GNOME Settings Daemon -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let @@ -26,7 +31,6 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/desktops/gnome/gnome-user-share.nix b/nixos/modules/services/desktops/gnome/gnome-user-share.nix index 518beb80419a90..c6d0f723c047b5 100644 --- a/nixos/modules/services/desktops/gnome/gnome-user-share.nix +++ b/nixos/modules/services/desktops/gnome/gnome-user-share.nix @@ -1,6 +1,11 @@ # GNOME User Share daemon. -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { @@ -20,7 +25,6 @@ }; - ###### implementation config = lib.mkIf config.services.gnome.gnome-user-share.enable { diff --git a/nixos/modules/services/desktops/gnome/sushi.nix b/nixos/modules/services/desktops/gnome/sushi.nix index 7f7360488eb41b..ea99c7ce30f019 100644 --- a/nixos/modules/services/desktops/gnome/sushi.nix +++ b/nixos/modules/services/desktops/gnome/sushi.nix @@ -1,6 +1,11 @@ # GNOME Sushi daemon. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { @@ -26,7 +31,6 @@ }; - ###### implementation config = lib.mkIf config.services.gnome.sushi.enable { diff --git a/nixos/modules/services/desktops/gvfs.nix b/nixos/modules/services/desktops/gvfs.nix index 8a02cdd4a6508a..315141705546a9 100644 --- a/nixos/modules/services/desktops/gvfs.nix +++ b/nixos/modules/services/desktops/gvfs.nix @@ -1,6 +1,11 @@ # GVfs -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let @@ -29,7 +34,6 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/desktops/malcontent.nix b/nixos/modules/services/desktops/malcontent.nix index fedd84549671d1..e299ee73c85768 100644 --- a/nixos/modules/services/desktops/malcontent.nix +++ b/nixos/modules/services/desktops/malcontent.nix @@ -1,5 +1,10 @@ # Malcontent daemon. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { ###### interface @@ -14,7 +19,6 @@ }; - ###### implementation config = lib.mkIf config.services.malcontent.enable { diff --git a/nixos/modules/services/desktops/neard.nix b/nixos/modules/services/desktops/neard.nix index 21a69a34001f69..56a7578c243492 100644 --- a/nixos/modules/services/desktops/neard.nix +++ b/nixos/modules/services/desktops/neard.nix @@ -11,7 +11,7 @@ let mkIf mkOption types - ; + ; cfg = config.services.neard; format = pkgs.formats.ini { }; configFile = format.generate "neard.conf" cfg.settings; @@ -52,7 +52,7 @@ in }; }; }; - default = {}; + default = { }; description = '' Neard INI-style configuration file as a Nix attribute set. diff --git a/nixos/modules/services/desktops/pipewire/pipewire.nix b/nixos/modules/services/desktops/pipewire/pipewire.nix index 50d9d71d14ce6a..fcdcd516fadd29 100644 --- a/nixos/modules/services/desktops/pipewire/pipewire.nix +++ b/nixos/modules/services/desktops/pipewire/pipewire.nix @@ -1,71 +1,93 @@ # PipeWire service. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (builtins) attrNames concatMap length; inherit (lib) maintainers teams; - inherit (lib.attrsets) attrByPath attrsToList concatMapAttrs filterAttrs; + inherit (lib.attrsets) + attrByPath + attrsToList + concatMapAttrs + filterAttrs + ; inherit (lib.lists) flatten optional optionals; inherit (lib.modules) mkIf mkRemovedOptionModule; - inherit (lib.options) literalExpression mkEnableOption mkOption mkPackageOption; + inherit (lib.options) + literalExpression + mkEnableOption + mkOption + mkPackageOption + ; inherit (lib.strings) concatMapStringsSep hasPrefix optionalString; - inherit (lib.types) attrsOf bool listOf package; - - json = pkgs.formats.json {}; - mapToFiles = location: config: concatMapAttrs (name: value: { "share/pipewire/${location}.conf.d/${name}.conf" = json.generate "${name}" value; }) config; - extraConfigPkgFromFiles = locations: filesSet: pkgs.runCommand "pipewire-extra-config" { } '' - mkdir -p ${concatMapStringsSep " " (l: "$out/share/pipewire/${l}.conf.d") locations} - ${concatMapStringsSep ";" ({name, value}: "ln -s ${value} $out/${name}") (attrsToList filesSet)} - ''; + inherit (lib.types) + attrsOf + bool + listOf + package + ; + + json = pkgs.formats.json { }; + mapToFiles = + location: config: + concatMapAttrs (name: value: { + "share/pipewire/${location}.conf.d/${name}.conf" = json.generate "${name}" value; + }) config; + extraConfigPkgFromFiles = + locations: filesSet: + pkgs.runCommand "pipewire-extra-config" { } '' + mkdir -p ${concatMapStringsSep " " (l: "$out/share/pipewire/${l}.conf.d") locations} + ${concatMapStringsSep ";" ({ name, value }: "ln -s ${value} $out/${name}") (attrsToList filesSet)} + ''; cfg = config.services.pipewire; - enable32BitAlsaPlugins = cfg.alsa.support32Bit - && pkgs.stdenv.hostPlatform.isx86_64 - && pkgs.pkgsi686Linux.pipewire != null; + enable32BitAlsaPlugins = + cfg.alsa.support32Bit && pkgs.stdenv.hostPlatform.isx86_64 && pkgs.pkgsi686Linux.pipewire != null; # The package doesn't output to $out/lib/pipewire directly so that the # overlays can use the outputs to replace the originals in FHS environments. # # This doesn't work in general because of missing development information. - jack-libs = pkgs.runCommand "jack-libs" {} '' + jack-libs = pkgs.runCommand "jack-libs" { } '' mkdir -p "$out/lib" ln -s "${cfg.package.jack}/lib" "$out/lib/pipewire" ''; configPackages = cfg.configPackages; - extraConfigPkg = extraConfigPkgFromFiles - [ "pipewire" "client" "client-rt" "jack" "pipewire-pulse" ] - ( - mapToFiles "pipewire" cfg.extraConfig.pipewire - // mapToFiles "client" cfg.extraConfig.client - // mapToFiles "client-rt" cfg.extraConfig.client-rt - // mapToFiles "jack" cfg.extraConfig.jack - // mapToFiles "pipewire-pulse" cfg.extraConfig.pipewire-pulse - ); + extraConfigPkg = + extraConfigPkgFromFiles [ "pipewire" "client" "client-rt" "jack" "pipewire-pulse" ] + ( + mapToFiles "pipewire" cfg.extraConfig.pipewire + // mapToFiles "client" cfg.extraConfig.client + // mapToFiles "client-rt" cfg.extraConfig.client-rt + // mapToFiles "jack" cfg.extraConfig.jack + // mapToFiles "pipewire-pulse" cfg.extraConfig.pipewire-pulse + ); configs = pkgs.buildEnv { name = "pipewire-configs"; - paths = configPackages + paths = + configPackages ++ [ extraConfigPkg ] ++ optionals cfg.wireplumber.enable cfg.wireplumber.configPackages; pathsToLink = [ "/share/pipewire" ]; }; - requiredLv2Packages = flatten - ( - concatMap - (p: - attrByPath ["passthru" "requiredLv2Packages"] [] p - ) - configPackages - ); + requiredLv2Packages = flatten ( + concatMap (p: attrByPath [ "passthru" "requiredLv2Packages" ] [ ] p) configPackages + ); lv2Plugins = pkgs.buildEnv { name = "pipewire-lv2-plugins"; paths = cfg.extraLv2Packages ++ requiredLv2Packages; pathsToLink = [ "/lib/lv2" ]; }; -in { +in +{ meta.maintainers = teams.freedesktop.members ++ [ maintainers.k900 ]; ###### interface @@ -132,7 +154,7 @@ in { extraConfig = { pipewire = mkOption { type = attrsOf json.type; - default = {}; + default = { }; example = { "10-clock-rate" = { "context.properties" = { @@ -165,7 +187,7 @@ in { }; client = mkOption { type = attrsOf json.type; - default = {}; + default = { }; example = { "10-no-resample" = { "stream.properties" = { @@ -185,7 +207,7 @@ in { }; client-rt = mkOption { type = attrsOf json.type; - default = {}; + default = { }; example = { "10-alsa-linear-volume" = { "alsa.properties" = { @@ -206,7 +228,7 @@ in { }; jack = mkOption { type = attrsOf json.type; - default = {}; + default = { }; example = { "20-hide-midi" = { "jack.properties" = { @@ -226,17 +248,19 @@ in { }; pipewire-pulse = mkOption { type = attrsOf json.type; - default = {}; + default = { }; example = { "15-force-s16-info" = { - "pulse.rules" = [{ - matches = [ - { "application.process.binary" = "my-broken-app"; } - ]; - actions = { - quirks = [ "force-s16-info" ]; - }; - }]; + "pulse.rules" = [ + { + matches = [ + { "application.process.binary" = "my-broken-app"; } + ]; + actions = { + quirks = [ "force-s16-info" ]; + }; + } + ]; }; }; description = '' @@ -257,29 +281,30 @@ in { configPackages = mkOption { type = listOf package; - default = []; - example = literalExpression ''[ - (pkgs.writeTextDir "share/pipewire/pipewire.conf.d/10-loopback.conf" ''' - context.modules = [ - { name = libpipewire-module-loopback - args = { - node.description = "Scarlett Focusrite Line 1" - capture.props = { - audio.position = [ FL ] - stream.dont-remix = true - node.target = "alsa_input.usb-Focusrite_Scarlett_Solo_USB_Y7ZD17C24495BC-00.analog-stereo" - node.passive = true - } - playback.props = { - node.name = "SF_mono_in_1" - media.class = "Audio/Source" - audio.position = [ MONO ] - } - } - } - ] - ''') - ]''; + default = [ ]; + example = literalExpression '' + [ + (pkgs.writeTextDir "share/pipewire/pipewire.conf.d/10-loopback.conf" ''' + context.modules = [ + { name = libpipewire-module-loopback + args = { + node.description = "Scarlett Focusrite Line 1" + capture.props = { + audio.position = [ FL ] + stream.dont-remix = true + node.target = "alsa_input.usb-Focusrite_Scarlett_Solo_USB_Y7ZD17C24495BC-00.analog-stereo" + node.passive = true + } + playback.props = { + node.name = "SF_mono_in_1" + media.class = "Audio/Source" + audio.position = [ MONO ] + } + } + } + ] + ''') + ]''; description = '' List of packages that provide PipeWire configuration, in the form of `share/pipewire/*/*.conf` files. @@ -291,7 +316,7 @@ in { extraLv2Packages = mkOption { type = listOf package; - default = []; + default = [ ]; example = literalExpression "[ pkgs.lsp-plugins ]"; description = '' List of packages that provide LV2 plugins in `lib/lv2` that should @@ -308,11 +333,11 @@ in { }; imports = [ - (mkRemovedOptionModule ["services" "pipewire" "config"] '' + (mkRemovedOptionModule [ "services" "pipewire" "config" ] '' Overriding default PipeWire configuration through NixOS options never worked correctly and is no longer supported. Please create drop-in configuration files via `services.pipewire.extraConfig` instead. '') - (mkRemovedOptionModule ["services" "pipewire" "media-session"] '' + (mkRemovedOptionModule [ "services" "pipewire" "media-session" ] '' pipewire-media-session is no longer supported upstream and has been removed. Please switch to `services.pipewire.wireplumber` instead. '') @@ -335,21 +360,17 @@ in { message = "Using PipeWire's ALSA/PulseAudio compatibility layers requires running PipeWire as the sound server. Either set `services.pipewire.audio.enable` to true to enable audio support, or set both `services.pipewire.pulse.enable` and `services.pipewire.alsa.enable` to false to use pipewire exclusively for the compositor."; } { - assertion = length - (attrNames - ( - filterAttrs - (name: value: - hasPrefix "pipewire/" name || name == "pipewire" - ) - config.environment.etc - )) == 1; + assertion = + length ( + attrNames ( + filterAttrs (name: value: hasPrefix "pipewire/" name || name == "pipewire") config.environment.etc + ) + ) == 1; message = "Using `environment.etc.\"pipewire<...>\"` directly is no longer supported. Use `services.pipewire.extraConfig` or `services.pipewire.configPackages` instead."; } ]; - environment.systemPackages = [ cfg.package ] - ++ optional cfg.jack.enable jack-libs; + environment.systemPackages = [ cfg.package ] ++ optional cfg.jack.enable jack-libs; systemd.packages = [ cfg.package ]; @@ -366,7 +387,9 @@ in { systemd.user.services.pipewire.enable = !cfg.systemWide; systemd.services.pipewire.environment.LV2_PATH = mkIf cfg.systemWide "${lv2Plugins}/lib/lv2"; - systemd.user.services.pipewire.environment.LV2_PATH = mkIf (!cfg.systemWide) "${lv2Plugins}/lib/lv2"; + systemd.user.services.pipewire.environment.LV2_PATH = mkIf ( + !cfg.systemWide + ) "${lv2Plugins}/lib/lv2"; # Mask pw-pulse if it's not wanted systemd.user.services.pipewire-pulse.enable = cfg.pulse.enable; @@ -384,13 +407,11 @@ in { text = '' pcm_type.pipewire { libs.native = ${cfg.package}/lib/alsa-lib/libasound_module_pcm_pipewire.so ; - ${optionalString enable32BitAlsaPlugins - "libs.32Bit = ${pkgs.pkgsi686Linux.pipewire}/lib/alsa-lib/libasound_module_pcm_pipewire.so ;"} + ${optionalString enable32BitAlsaPlugins "libs.32Bit = ${pkgs.pkgsi686Linux.pipewire}/lib/alsa-lib/libasound_module_pcm_pipewire.so ;"} } ctl_type.pipewire { libs.native = ${cfg.package}/lib/alsa-lib/libasound_module_ctl_pipewire.so ; - ${optionalString enable32BitAlsaPlugins - "libs.32Bit = ${pkgs.pkgsi686Linux.pipewire}/lib/alsa-lib/libasound_module_ctl_pipewire.so ;"} + ${optionalString enable32BitAlsaPlugins "libs.32Bit = ${pkgs.pkgsi686Linux.pipewire}/lib/alsa-lib/libasound_module_ctl_pipewire.so ;"} } ''; }; @@ -405,10 +426,12 @@ in { pipewire.source = "${configs}/share/pipewire"; }; - environment.sessionVariables.LD_LIBRARY_PATH = - mkIf cfg.jack.enable [ "${cfg.package.jack}/lib" ]; + environment.sessionVariables.LD_LIBRARY_PATH = mkIf cfg.jack.enable [ "${cfg.package.jack}/lib" ]; - networking.firewall.allowedUDPPorts = mkIf cfg.raopOpenFirewall [ 6001 6002 ]; + networking.firewall.allowedUDPPorts = mkIf cfg.raopOpenFirewall [ + 6001 + 6002 + ]; # See https://gitlab.freedesktop.org/pipewire/pipewire/-/blob/master/src/modules/module-rt/25-pw-rlimits.conf.in security.pam.loginLimits = [ diff --git a/nixos/modules/services/desktops/profile-sync-daemon.nix b/nixos/modules/services/desktops/profile-sync-daemon.nix index 48b29a59135c91..17ac1df9baae67 100644 --- a/nixos/modules/services/desktops/profile-sync-daemon.nix +++ b/nixos/modules/services/desktops/profile-sync-daemon.nix @@ -1,7 +1,13 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.psd; -in { +in +{ options.services.psd = with lib.types; { enable = lib.mkOption { type = bool; @@ -33,7 +39,14 @@ in { description = "Profile Sync daemon"; wants = [ "psd-resync.service" ]; wantedBy = [ "default.target" ]; - path = with pkgs; [ rsync kmod gawk nettools util-linux profile-sync-daemon ]; + path = with pkgs; [ + rsync + kmod + gawk + nettools + util-linux + profile-sync-daemon + ]; unitConfig = { RequiresMountsFor = [ "/home/" ]; }; @@ -52,7 +65,14 @@ in { wants = [ "psd-resync.timer" ]; partOf = [ "psd.service" ]; wantedBy = [ "default.target" ]; - path = with pkgs; [ rsync kmod gawk nettools util-linux profile-sync-daemon ]; + path = with pkgs; [ + rsync + kmod + gawk + nettools + util-linux + profile-sync-daemon + ]; serviceConfig = { Type = "oneshot"; ExecStart = "${pkgs.profile-sync-daemon}/bin/profile-sync-daemon resync"; @@ -62,7 +82,10 @@ in { timers.psd-resync = { description = "Timer for profile sync daemon - ${cfg.resyncTimer}"; - partOf = [ "psd-resync.service" "psd.service" ]; + partOf = [ + "psd-resync.service" + "psd.service" + ]; timerConfig = { OnUnitActiveSec = "${cfg.resyncTimer}"; diff --git a/nixos/modules/services/desktops/seatd.nix b/nixos/modules/services/desktops/seatd.nix index fb20750f042910..bedcc9a4312041 100644 --- a/nixos/modules/services/desktops/seatd.nix +++ b/nixos/modules/services/desktops/seatd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.seatd; @@ -21,15 +26,23 @@ in description = "Group to own the seatd socket"; }; logLevel = mkOption { - type = types.enum [ "debug" "info" "error" "silent" ]; + type = types.enum [ + "debug" + "info" + "error" + "silent" + ]; default = "info"; description = "Logging verbosity"; }; }; config = lib.mkIf cfg.enable { - environment.systemPackages = with pkgs; [ seatd sdnotify-wrapper ]; - users.groups.seat = lib.mkIf (cfg.group == "seat") {}; + environment.systemPackages = with pkgs; [ + seatd + sdnotify-wrapper + ]; + users.groups.seat = lib.mkIf (cfg.group == "seat") { }; systemd.services.seatd = { description = "Seat management daemon"; diff --git a/nixos/modules/services/desktops/system-config-printer.nix b/nixos/modules/services/desktops/system-config-printer.nix index 6a8ff8dd19c60a..d4020602713cf0 100644 --- a/nixos/modules/services/desktops/system-config-printer.nix +++ b/nixos/modules/services/desktops/system-config-printer.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { ###### interface @@ -13,7 +18,6 @@ }; - ###### implementation config = lib.mkIf config.services.system-config-printer.enable { diff --git a/nixos/modules/services/desktops/system76-scheduler.nix b/nixos/modules/services/desktops/system76-scheduler.nix index b8f80276ef761c..1a8abe810cd8b1 100644 --- a/nixos/modules/services/desktops/system76-scheduler.nix +++ b/nixos/modules/services/desktops/system76-scheduler.nix @@ -1,17 +1,50 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.system76-scheduler; - inherit (builtins) concatStringsSep map toString attrNames; - inherit (lib) boolToString types mkOption literalExpression optional mkIf mkMerge; - inherit (types) nullOr listOf bool int ints float str enum; + inherit (builtins) + concatStringsSep + map + toString + attrNames + ; + inherit (lib) + boolToString + types + mkOption + literalExpression + optional + mkIf + mkMerge + ; + inherit (types) + nullOr + listOf + bool + int + ints + float + str + enum + ; - withDefaults = optionSpecs: defaults: - lib.genAttrs (attrNames optionSpecs) (name: - mkOption (optionSpecs.${name} // { - default = optionSpecs.${name}.default or defaults.${name} or null; - })); + withDefaults = + optionSpecs: defaults: + lib.genAttrs (attrNames optionSpecs) ( + name: + mkOption ( + optionSpecs.${name} + // { + default = optionSpecs.${name}.default or defaults.${name} or null; + } + ) + ); latencyProfile = withDefaults { latency = { @@ -31,7 +64,11 @@ let description = "`sched_cfs_bandwidth_slice_us`."; }; preempt = { - type = enum [ "none" "voluntary" "full" ]; + type = enum [ + "none" + "voluntary" + "full" + ]; description = "Preemption mode."; }; }; @@ -41,7 +78,13 @@ let description = "Niceness."; }; class = { - type = nullOr (enum [ "idle" "batch" "other" "rr" "fifo" ]); + type = nullOr (enum [ + "idle" + "batch" + "other" + "rr" + "fifo" + ]); example = literalExpression "\"batch\""; description = "CPU scheduler class."; }; @@ -51,7 +94,11 @@ let description = "CPU scheduler priority."; }; ioClass = { - type = nullOr (enum [ "idle" "best-effort" "realtime" ]); + type = nullOr (enum [ + "idle" + "best-effort" + "realtime" + ]); example = literalExpression "\"best-effort\""; description = "IO scheduler class."; }; @@ -62,7 +109,7 @@ let }; matchers = { type = nullOr (listOf str); - default = []; + default = [ ]; example = literalExpression '' [ "include cgroup=\"/user.slice/*.service\" parent=\"systemd\"" @@ -73,22 +120,29 @@ let }; }; - cfsProfileToString = name: let - p = cfg.settings.cfsProfiles.${name}; - in + cfsProfileToString = + name: + let + p = cfg.settings.cfsProfiles.${name}; + in "${name} latency=${toString p.latency} nr-latency=${toString p.nr-latency} wakeup-granularity=${toString p.wakeup-granularity} bandwidth-size=${toString p.bandwidth-size} preempt=\"${p.preempt}\""; prioToString = class: prio: if prio == null then "\"${class}\"" else "(${class})${toString prio}"; - schedulerProfileToString = name: a: indent: - concatStringsSep " " - (["${indent}${name}"] - ++ (optional (a.nice != null) "nice=${toString a.nice}") - ++ (optional (a.class != null) "sched=${prioToString a.class a.prio}") - ++ (optional (a.ioClass != null) "io=${prioToString a.ioClass a.ioPrio}") - ++ (optional ((builtins.length a.matchers) != 0) ("{\n${concatStringsSep "\n" (map (m: " ${indent}${m}") a.matchers)}\n${indent}}"))); + schedulerProfileToString = + name: a: indent: + concatStringsSep " " ( + [ "${indent}${name}" ] + ++ (optional (a.nice != null) "nice=${toString a.nice}") + ++ (optional (a.class != null) "sched=${prioToString a.class a.prio}") + ++ (optional (a.ioClass != null) "io=${prioToString a.ioClass a.ioPrio}") + ++ (optional ((builtins.length a.matchers) != 0) ( + "{\n${concatStringsSep "\n" (map (m: " ${indent}${m}") a.matchers)}\n${indent}}" + )) + ); -in { +in +{ options = { services.system76-scheduler = { enable = lib.mkEnableOption "system76-scheduler"; @@ -193,10 +247,12 @@ in { }; assignments = mkOption { - type = types.attrsOf (types.submodule { - options = schedulerProfile { }; - }); - default = {}; + type = types.attrsOf ( + types.submodule { + options = schedulerProfile { }; + } + ); + default = { }; example = literalExpression '' { nix-builds = { @@ -214,7 +270,7 @@ in { exceptions = mkOption { type = types.listOf str; - default = []; + default = [ ]; example = literalExpression '' [ "include descends=\"schedtool\"" @@ -241,7 +297,7 @@ in { ]; serviceConfig = { Type = "dbus"; - BusName= "com.system76.Scheduler"; + BusName = "com.system76.Scheduler"; ExecStart = "${cfg.package}/bin/system76-scheduler daemon"; ExecReload = "${cfg.package}/bin/system76-scheduler daemon reload"; }; @@ -252,39 +308,59 @@ in { # No custom settings: just use stock configuration with a fix for Pipewire "system76-scheduler/config.kdl".source = "${cfg.package}/data/config.kdl"; "system76-scheduler/process-scheduler/00-dist.kdl".source = "${cfg.package}/data/pop_os.kdl"; - "system76-scheduler/process-scheduler/01-fix-pipewire-paths.kdl".source = ../../../../pkgs/by-name/sy/system76-scheduler/01-fix-pipewire-paths.kdl; + "system76-scheduler/process-scheduler/01-fix-pipewire-paths.kdl".source = + ../../../../pkgs/by-name/sy/system76-scheduler/01-fix-pipewire-paths.kdl; }) - (let - settings = cfg.settings; - cfsp = settings.cfsProfiles; - ps = settings.processScheduler; - in mkIf (!cfg.useStockConfig) { - "system76-scheduler/config.kdl".text = '' - version "2.0" - autogroup-enabled false - cfs-profiles enable=${boolToString cfsp.enable} { - ${cfsProfileToString "default"} - ${cfsProfileToString "responsive"} - } - process-scheduler enable=${boolToString ps.enable} { - execsnoop ${boolToString ps.useExecsnoop} - refresh-rate ${toString ps.refreshInterval} - assignments { - ${if ps.foregroundBoost.enable then (schedulerProfileToString "foreground" ps.foregroundBoost.foreground " ") else ""} - ${if ps.foregroundBoost.enable then (schedulerProfileToString "background" ps.foregroundBoost.background " ") else ""} - ${if ps.pipewireBoost.enable then (schedulerProfileToString "pipewire" ps.pipewireBoost.profile " ") else ""} + ( + let + settings = cfg.settings; + cfsp = settings.cfsProfiles; + ps = settings.processScheduler; + in + mkIf (!cfg.useStockConfig) { + "system76-scheduler/config.kdl".text = '' + version "2.0" + autogroup-enabled false + cfs-profiles enable=${boolToString cfsp.enable} { + ${cfsProfileToString "default"} + ${cfsProfileToString "responsive"} } - } - ''; - }) + process-scheduler enable=${boolToString ps.enable} { + execsnoop ${boolToString ps.useExecsnoop} + refresh-rate ${toString ps.refreshInterval} + assignments { + ${ + if ps.foregroundBoost.enable then + (schedulerProfileToString "foreground" ps.foregroundBoost.foreground " ") + else + "" + } + ${ + if ps.foregroundBoost.enable then + (schedulerProfileToString "background" ps.foregroundBoost.background " ") + else + "" + } + ${ + if ps.pipewireBoost.enable then + (schedulerProfileToString "pipewire" ps.pipewireBoost.profile " ") + else + "" + } + } + } + ''; + } + ) { "system76-scheduler/process-scheduler/02-config.kdl".text = "exceptions {\n${concatStringsSep "\n" (map (e: " ${e}") cfg.exceptions)}\n}\n" + "assignments {\n" - + (concatStringsSep "\n" (map (name: schedulerProfileToString name cfg.assignments.${name} " ") - (attrNames cfg.assignments))) + + (concatStringsSep "\n" ( + map (name: schedulerProfileToString name cfg.assignments.${name} " ") (attrNames cfg.assignments) + )) + "\n}\n"; } ]; diff --git a/nixos/modules/services/desktops/telepathy.nix b/nixos/modules/services/desktops/telepathy.nix index 8f8adf7f4f83d1..d4aac1aa0c26ff 100644 --- a/nixos/modules/services/desktops/telepathy.nix +++ b/nixos/modules/services/desktops/telepathy.nix @@ -1,5 +1,10 @@ # Telepathy daemon. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { meta = { @@ -25,7 +30,6 @@ }; - ###### implementation config = lib.mkIf config.services.telepathy.enable { diff --git a/nixos/modules/services/desktops/tumbler.nix b/nixos/modules/services/desktops/tumbler.nix index a52767301949cb..521f8c0a58f13e 100644 --- a/nixos/modules/services/desktops/tumbler.nix +++ b/nixos/modules/services/desktops/tumbler.nix @@ -1,5 +1,10 @@ # Tumbler -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.tumbler; @@ -9,9 +14,7 @@ in { imports = [ - (lib.mkRemovedOptionModule - [ "services" "tumbler" "package" ] - "") + (lib.mkRemovedOptionModule [ "services" "tumbler" "package" ] "") ]; meta = with lib; { @@ -30,7 +33,6 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/desktops/zeitgeist.nix b/nixos/modules/services/desktops/zeitgeist.nix index 7ca2c6f3739a0d..5e9cba9930165b 100644 --- a/nixos/modules/services/desktops/zeitgeist.nix +++ b/nixos/modules/services/desktops/zeitgeist.nix @@ -1,5 +1,10 @@ # Zeitgeist -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { meta = with lib; { diff --git a/nixos/modules/services/development/blackfire.nix b/nixos/modules/services/development/blackfire.nix index 9b76cfbca0788f..1f804cd4d88308 100644 --- a/nixos/modules/services/development/blackfire.nix +++ b/nixos/modules/services/development/blackfire.nix @@ -1,14 +1,20 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.blackfire-agent; - agentConfigFile = lib.generators.toINI {} { - blackfire = cfg.settings; + agentConfigFile = lib.generators.toINI { } { + blackfire = cfg.settings; }; agentSock = "blackfire/agent.sock"; -in { +in +{ meta = { maintainers = pkgs.blackfire.meta.maintainers; doc = ./blackfire.md; diff --git a/nixos/modules/services/development/bloop.nix b/nixos/modules/services/development/bloop.nix index b61f543f571385..dcf94f48cf337a 100644 --- a/nixos/modules/services/development/bloop.nix +++ b/nixos/modules/services/development/bloop.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.bloop; -in { +in +{ options.services.bloop = { extraOptions = lib.mkOption { @@ -40,10 +46,10 @@ in { PATH = lib.mkForce "${lib.makeBinPath [ config.programs.java.package ]}"; }; serviceConfig = { - Type = "forking"; - ExecStart = "${pkgs.bloop}/bin/bloop start"; - ExecStop = "${pkgs.bloop}/bin/bloop exit"; - Restart = "always"; + Type = "forking"; + ExecStart = "${pkgs.bloop}/bin/bloop start"; + ExecStop = "${pkgs.bloop}/bin/bloop exit"; + Restart = "always"; }; }; diff --git a/nixos/modules/services/development/distccd.nix b/nixos/modules/services/development/distccd.nix index 7eb9789b5c38c3..46d09911e2b7b5 100644 --- a/nixos/modules/services/development/distccd.nix +++ b/nixos/modules/services/development/distccd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.distccd; in @@ -10,7 +15,11 @@ in allowedClients = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ "127.0.0.1" ]; - example = [ "127.0.0.1" "192.168.0.0/24" "10.0.0.0/24" ]; + example = [ + "127.0.0.1" + "192.168.0.0/24" + "10.0.0.0/24" + ]; description = '' Client IPs which are allowed to connect to distccd in CIDR notation. @@ -29,7 +38,16 @@ in }; logLevel = lib.mkOption { - type = lib.types.nullOr (lib.types.enum [ "critical" "error" "warning" "notice" "info" "debug" ]); + type = lib.types.nullOr ( + lib.types.enum [ + "critical" + "error" + "warning" + "notice" + "info" + "debug" + ] + ); default = "warning"; description = '' Set the minimum severity of error that will be included in the log @@ -46,7 +64,6 @@ in ''; }; - nice = lib.mkOption { type = lib.types.nullOr lib.types.int; default = null; @@ -97,8 +114,7 @@ in config = lib.mkIf cfg.enable { networking.firewall = lib.mkIf cfg.openFirewall { - allowedTCPPorts = [ cfg.port ] - ++ lib.optionals cfg.stats.enable [ cfg.stats.port ]; + allowedTCPPorts = [ cfg.port ] ++ lib.optionals cfg.stats.enable [ cfg.stats.port ]; }; systemd.services.distccd = { diff --git a/nixos/modules/services/development/gemstash.nix b/nixos/modules/services/development/gemstash.nix index 6184180552aeec..442a6630af8df9 100644 --- a/nixos/modules/services/development/gemstash.nix +++ b/nixos/modules/services/development/gemstash.nix @@ -1,19 +1,23 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: let settingsFormat = pkgs.formats.yaml { }; # gemstash uses a yaml config where the keys are ruby symbols, # which means they start with ':'. This would be annoying to use # on the nix side, so we rewrite plain names instead. - prefixColon = s: lib.listToAttrs (map - (attrName: { - name = ":${attrName}"; - value = - if lib.isAttrs s.${attrName} - then prefixColon s."${attrName}" - else s."${attrName}"; - }) - (lib.attrNames s)); + prefixColon = + s: + lib.listToAttrs ( + map (attrName: { + name = ":${attrName}"; + value = if lib.isAttrs s.${attrName} then prefixColon s."${attrName}" else s."${attrName}"; + }) (lib.attrNames s) + ); # parse the port number out of the tcp://ip:port bind setting string parseBindPort = bind: lib.strings.toInt (lib.last (lib.strings.splitString ":" bind)); @@ -33,7 +37,7 @@ in }; settings = lib.mkOption { - default = {}; + default = { }; description = '' Configuration for Gemstash. The details can be found at in [gemstash documentation](https://github.com/rubygems/gemstash/blob/master/man/gemstash-configuration.5.md). @@ -53,7 +57,14 @@ in description = "Host and port combination for the server to listen on."; }; db_adapter = lib.mkOption { - type = lib.types.nullOr (lib.types.enum [ "sqlite3" "postgres" "mysql" "mysql2" ]); + type = lib.types.nullOr ( + lib.types.enum [ + "sqlite3" + "postgres" + "mysql" + "mysql2" + ] + ); default = null; description = "Which database type to use. For choices other than sqlite3, the dbUrl has to be specified as well."; }; @@ -67,35 +78,36 @@ in }; }; - config = - lib.mkIf cfg.enable { - users = { - users.gemstash = { - group = "gemstash"; - isSystemUser = true; - }; - groups.gemstash = { }; + config = lib.mkIf cfg.enable { + users = { + users.gemstash = { + group = "gemstash"; + isSystemUser = true; }; + groups.gemstash = { }; + }; - networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall [ (parseBindPort cfg.settings.bind) ]; + networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall [ + (parseBindPort cfg.settings.bind) + ]; - systemd.services.gemstash = { - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - serviceConfig = lib.mkMerge [ - { - ExecStart = "${pkgs.gemstash}/bin/gemstash start --no-daemonize --config-file ${settingsFormat.generate "gemstash.yaml" (prefixColon cfg.settings)}"; - NoNewPrivileges = true; - User = "gemstash"; - Group = "gemstash"; - PrivateTmp = true; - RestrictSUIDSGID = true; - LockPersonality = true; - } - (lib.mkIf (cfg.settings.base_path == "/var/lib/gemstash") { - StateDirectory = "gemstash"; - }) - ]; - }; + systemd.services.gemstash = { + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + serviceConfig = lib.mkMerge [ + { + ExecStart = "${pkgs.gemstash}/bin/gemstash start --no-daemonize --config-file ${settingsFormat.generate "gemstash.yaml" (prefixColon cfg.settings)}"; + NoNewPrivileges = true; + User = "gemstash"; + Group = "gemstash"; + PrivateTmp = true; + RestrictSUIDSGID = true; + LockPersonality = true; + } + (lib.mkIf (cfg.settings.base_path == "/var/lib/gemstash") { + StateDirectory = "gemstash"; + }) + ]; }; + }; } diff --git a/nixos/modules/services/development/hoogle.nix b/nixos/modules/services/development/hoogle.nix index 0a09a339e2beee..49d7cb5c2113fc 100644 --- a/nixos/modules/services/development/hoogle.nix +++ b/nixos/modules/services/development/hoogle.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hoogle; @@ -8,7 +13,8 @@ let paths = [ (cfg.haskellPackages.ghcWithHoogle cfg.packages) ]; }; -in { +in +{ options.services.hoogle = { enable = lib.mkEnableOption "Haskell documentation server"; @@ -23,7 +29,7 @@ in { packages = lib.mkOption { type = lib.types.functionTo (lib.types.listOf lib.types.package); - default = hp: []; + default = hp: [ ]; defaultText = lib.literalExpression "hp: []"; example = lib.literalExpression "hp: with hp; [ text lens ]"; description = '' @@ -56,7 +62,7 @@ in { extraOptions = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = [ "--no-security-headers" ]; description = '' Additional command-line arguments to pass to diff --git a/nixos/modules/services/development/jupyter/default.nix b/nixos/modules/services/development/jupyter/default.nix index d9687fdbf7139e..5bcbf34548c116 100644 --- a/nixos/modules/services/development/jupyter/default.nix +++ b/nixos/modules/services/development/jupyter/default.nix @@ -1,15 +1,20 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.jupyter; package = cfg.package; - kernels = (pkgs.jupyter-kernel.create { - definitions = if cfg.kernels != null - then cfg.kernels - else pkgs.jupyter-kernel.default; - }); + kernels = ( + pkgs.jupyter-kernel.create { + definitions = if cfg.kernels != null then cfg.kernels else pkgs.jupyter-kernel.default; + } + ); notebookConfig = pkgs.writeText "jupyter_config.py" '' ${cfg.notebookConfig} @@ -17,7 +22,8 @@ let c.NotebookApp.password = ${cfg.password} ''; -in { +in +{ meta.maintainers = with lib.maintainers; [ aborsu ]; options.services.jupyter = { @@ -43,7 +49,7 @@ in { description = '' Which command the service runs. Note that not all jupyter packages have all commands, e.g. jupyter-lab isn't present in the default package. - ''; + ''; }; port = lib.mkOption { @@ -108,9 +114,15 @@ in { }; kernels = lib.mkOption { - type = lib.types.nullOr (lib.types.attrsOf(lib.types.submodule (import ./kernel-options.nix { - inherit lib pkgs; - }))); + type = lib.types.nullOr ( + lib.types.attrsOf ( + lib.types.submodule ( + import ./kernel-options.nix { + inherit lib pkgs; + } + ) + ) + ); default = null; example = lib.literalExpression '' @@ -151,7 +163,7 @@ in { }; config = lib.mkMerge [ - (lib.mkIf cfg.enable { + (lib.mkIf cfg.enable { systemd.services.jupyter = { description = "Jupyter development server"; @@ -167,12 +179,13 @@ in { serviceConfig = { Restart = "always"; - ExecStart = ''${package}/bin/${cfg.command} \ - --no-browser \ - --ip=${cfg.ip} \ - --port=${toString cfg.port} --port-retries 0 \ - --notebook-dir=${cfg.notebookDir} \ - --NotebookApp.config_file=${notebookConfig} + ExecStart = '' + ${package}/bin/${cfg.command} \ + --no-browser \ + --ip=${cfg.ip} \ + --port=${toString cfg.port} --port-retries 0 \ + --notebook-dir=${cfg.notebookDir} \ + --NotebookApp.config_file=${notebookConfig} ''; User = cfg.user; Group = cfg.group; @@ -181,7 +194,7 @@ in { }; }) (lib.mkIf (cfg.enable && (cfg.group == "jupyter")) { - users.groups.jupyter = {}; + users.groups.jupyter = { }; }) (lib.mkIf (cfg.enable && (cfg.user == "jupyter")) { users.extraUsers.jupyter = { diff --git a/nixos/modules/services/development/jupyter/kernel-options.nix b/nixos/modules/services/development/jupyter/kernel-options.nix index 421e1a0cf51dcd..12c94d5d86fdb7 100644 --- a/nixos/modules/services/development/jupyter/kernel-options.nix +++ b/nixos/modules/services/development/jupyter/kernel-options.nix @@ -42,7 +42,9 @@ env = lib.mkOption { type = lib.types.attrsOf lib.types.str; default = { }; - example = { OMP_NUM_THREADS = "1"; }; + example = { + OMP_NUM_THREADS = "1"; + }; description = '' Environment variables to set for the kernel. ''; diff --git a/nixos/modules/services/development/livebook.nix b/nixos/modules/services/development/livebook.nix index ca227e2ad22c32..7a6ba52a179cc3 100644 --- a/nixos/modules/services/development/livebook.nix +++ b/nixos/modules/services/development/livebook.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.livebook; in @@ -13,7 +18,15 @@ in package = lib.mkPackageOption pkgs "livebook" { }; environment = lib.mkOption { - type = with lib.types; attrsOf (nullOr (oneOf [ bool int str ])); + type = + with lib.types; + attrsOf ( + nullOr (oneOf [ + bool + int + str + ]) + ); default = { }; description = '' Environment variables to set. @@ -95,9 +108,9 @@ in # stuck running a `cat /dev/urandom | tr | fold` pipeline. IgnoreSIGPIPE = false; }; - environment = lib.mapAttrs (name: value: - if lib.isBool value then lib.boolToString value else toString value) - cfg.environment; + environment = lib.mapAttrs ( + name: value: if lib.isBool value then lib.boolToString value else toString value + ) cfg.environment; path = [ pkgs.bash ] ++ cfg.extraPackages; wantedBy = [ "default.target" ]; }; @@ -105,6 +118,9 @@ in meta = { doc = ./livebook.md; - maintainers = with lib.maintainers; [ munksgaard scvalex ]; + maintainers = with lib.maintainers; [ + munksgaard + scvalex + ]; }; } diff --git a/nixos/modules/services/development/lorri.nix b/nixos/modules/services/development/lorri.nix index 4aba3836e3233c..899e4f3de1917f 100644 --- a/nixos/modules/services/development/lorri.nix +++ b/nixos/modules/services/development/lorri.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.lorri; socketPath = "lorri/daemon.socket"; -in { +in +{ options = { services.lorri = { enable = lib.mkOption { @@ -40,7 +46,12 @@ in { description = "Lorri Daemon"; requires = [ "lorri.socket" ]; after = [ "lorri.socket" ]; - path = with pkgs; [ config.nix.package git gnutar gzip ]; + path = with pkgs; [ + config.nix.package + git + gnutar + gzip + ]; serviceConfig = { ExecStart = "${cfg.package}/bin/lorri daemon"; PrivateTmp = true; @@ -49,6 +60,9 @@ in { }; }; - environment.systemPackages = [ cfg.package pkgs.direnv ]; + environment.systemPackages = [ + cfg.package + pkgs.direnv + ]; }; } diff --git a/nixos/modules/services/development/nixseparatedebuginfod.nix b/nixos/modules/services/development/nixseparatedebuginfod.nix index a2ec0d2c80e1f3..63474272ccf036 100644 --- a/nixos/modules/services/development/nixseparatedebuginfod.nix +++ b/nixos/modules/services/development/nixseparatedebuginfod.nix @@ -1,4 +1,9 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: let cfg = config.services.nixseparatedebuginfod; url = "127.0.0.1:${toString cfg.port}"; @@ -30,10 +35,12 @@ in }; }; config = lib.mkIf cfg.enable { - assertions = [ { - assertion = cfg.allowOldNix || (lib.versionAtLeast cfg.nixPackage.version "2.18"); - message = "nixseparatedebuginfod works better when `services.nixseparatedebuginfod.nixPackage` is set to nix >= 2.18 (instead of ${cfg.nixPackage.name}). Set `services.nixseparatedebuginfod.allowOldNix` to bypass."; - } ]; + assertions = [ + { + assertion = cfg.allowOldNix || (lib.versionAtLeast cfg.nixPackage.version "2.18"); + message = "nixseparatedebuginfod works better when `services.nixseparatedebuginfod.nixPackage` is set to nix >= 2.18 (instead of ${cfg.nixPackage.name}). Set `services.nixseparatedebuginfod.allowOldNix` to bypass."; + } + ]; systemd.services.nixseparatedebuginfod = { wantedBy = [ "multi-user.target" ]; diff --git a/nixos/modules/services/development/rstudio-server/default.nix b/nixos/modules/services/development/rstudio-server/default.nix index 70f665b09e317e..d83029388c3ddf 100644 --- a/nixos/modules/services/development/rstudio-server/default.nix +++ b/nixos/modules/services/development/rstudio-server/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.rstudio-server; @@ -15,7 +20,10 @@ let in { - meta.maintainers = with lib.maintainers; [ jbedo cfhammill ]; + meta.maintainers = with lib.maintainers; [ + jbedo + cfhammill + ]; options.services.rstudio-server = { enable = lib.mkEnableOption "RStudio server"; @@ -58,41 +66,43 @@ in }; - config = lib.mkIf cfg.enable - { - systemd.services.rstudio-server = { - description = "Rstudio server"; - - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - restartTriggers = [ rserver-conf rsession-conf ]; - - serviceConfig = { - Restart = "on-failure"; - Type = "forking"; - ExecStart = "${cfg.package}/bin/rserver"; - StateDirectory = "rstudio-server"; - RuntimeDirectory = "rstudio-server"; - }; + config = lib.mkIf cfg.enable { + systemd.services.rstudio-server = { + description = "Rstudio server"; + + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + restartTriggers = [ + rserver-conf + rsession-conf + ]; + + serviceConfig = { + Restart = "on-failure"; + Type = "forking"; + ExecStart = "${cfg.package}/bin/rserver"; + StateDirectory = "rstudio-server"; + RuntimeDirectory = "rstudio-server"; }; + }; + + environment.etc = { + "rstudio/rserver.conf".source = rserver-conf; + "rstudio/rsession.conf".source = rsession-conf; + "pam.d/rstudio".source = "/etc/pam.d/login"; + }; + environment.systemPackages = [ cfg.package ]; - environment.etc = { - "rstudio/rserver.conf".source = rserver-conf; - "rstudio/rsession.conf".source = rsession-conf; - "pam.d/rstudio".source = "/etc/pam.d/login"; + users = { + users.rstudio-server = { + uid = config.ids.uids.rstudio-server; + description = "rstudio-server"; + group = "rstudio-server"; }; - environment.systemPackages = [ cfg.package ]; - - users = { - users.rstudio-server = { - uid = config.ids.uids.rstudio-server; - description = "rstudio-server"; - group = "rstudio-server"; - }; - groups.rstudio-server = { - gid = config.ids.gids.rstudio-server; - }; + groups.rstudio-server = { + gid = config.ids.gids.rstudio-server; }; - }; + + }; } diff --git a/nixos/modules/services/development/zammad.nix b/nixos/modules/services/development/zammad.nix index 6e0be83aa384b7..ac659e9fa52714 100644 --- a/nixos/modules/services/development/zammad.nix +++ b/nixos/modules/services/development/zammad.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.zammad; @@ -226,7 +231,8 @@ in assertions = [ { - assertion = cfg.database.createLocally -> cfg.database.user == "zammad" && cfg.database.name == "zammad"; + assertion = + cfg.database.createLocally -> cfg.database.user == "zammad" && cfg.database.name == "zammad"; message = "services.zammad.database.user must be set to \"zammad\" if services.zammad.database.createLocally is set to true"; } { @@ -263,14 +269,17 @@ in # loading all the gems takes time TimeoutStartSec = 1200; }; - after = [ - "network.target" - "systemd-tmpfiles-setup.service" - ] ++ lib.optionals (cfg.database.createLocally) [ - "postgresql.service" - ] ++ lib.optionals cfg.redis.createLocally [ - "redis-${cfg.redis.name}.service" - ]; + after = + [ + "network.target" + "systemd-tmpfiles-setup.service" + ] + ++ lib.optionals (cfg.database.createLocally) [ + "postgresql.service" + ] + ++ lib.optionals cfg.redis.createLocally [ + "redis-${cfg.redis.name}.service" + ]; requires = lib.optionals (cfg.database.createLocally) [ "postgresql.service" ]; @@ -280,17 +289,17 @@ in # config file cat ${databaseConfig} > ${cfg.dataDir}/config/database.yml ${lib.optionalString (cfg.database.passwordFile != null) '' - { - echo -n " password: " - cat ${cfg.database.passwordFile} - } >> ${cfg.dataDir}/config/database.yml + { + echo -n " password: " + cat ${cfg.database.passwordFile} + } >> ${cfg.dataDir}/config/database.yml ''} ${lib.optionalString (cfg.secretKeyBaseFile != null) '' - { - echo "production: " - echo -n " secret_key_base: " - cat ${cfg.secretKeyBaseFile} - } > ${cfg.dataDir}/config/secrets.yml + { + echo "production: " + echo -n " secret_key_base: " + cat ${cfg.secretKeyBaseFile} + } > ${cfg.dataDir}/config/secrets.yml ''} # needed for cleanup @@ -349,5 +358,8 @@ in }; }; - meta.maintainers = with lib.maintainers; [ taeer netali ]; + meta.maintainers = with lib.maintainers; [ + taeer + netali + ]; } diff --git a/nixos/modules/services/display-managers/default.nix b/nixos/modules/services/display-managers/default.nix index 81919923ded8cb..2bcef6106cc00f 100644 --- a/nixos/modules/services/display-managers/default.nix +++ b/nixos/modules/services/display-managers/default.nix @@ -1,34 +1,41 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.displayManager; - installedSessions = pkgs.runCommand "desktops" - { # trivial derivation - preferLocalBuild = true; - allowSubstitutes = false; - } - '' - mkdir -p "$out/share/"{xsessions,wayland-sessions} - - ${lib.concatMapStrings (pkg: '' - for n in ${lib.concatStringsSep " " pkg.providedSessions}; do - if ! test -f ${pkg}/share/wayland-sessions/$n.desktop -o \ - -f ${pkg}/share/xsessions/$n.desktop; then - echo "Couldn't find provided session name, $n.desktop, in session package ${pkg.name}:" - echo " ${pkg}" - return 1 + installedSessions = + pkgs.runCommand "desktops" + { + # trivial derivation + preferLocalBuild = true; + allowSubstitutes = false; + } + '' + mkdir -p "$out/share/"{xsessions,wayland-sessions} + + ${lib.concatMapStrings (pkg: '' + for n in ${lib.concatStringsSep " " pkg.providedSessions}; do + if ! test -f ${pkg}/share/wayland-sessions/$n.desktop -o \ + -f ${pkg}/share/xsessions/$n.desktop; then + echo "Couldn't find provided session name, $n.desktop, in session package ${pkg.name}:" + echo " ${pkg}" + return 1 + fi + done + + if test -d ${pkg}/share/xsessions; then + ${pkgs.buildPackages.xorg.lndir}/bin/lndir ${pkg}/share/xsessions $out/share/xsessions fi - done - - if test -d ${pkg}/share/xsessions; then - ${pkgs.buildPackages.xorg.lndir}/bin/lndir ${pkg}/share/xsessions $out/share/xsessions - fi - if test -d ${pkg}/share/wayland-sessions; then - ${pkgs.buildPackages.xorg.lndir}/bin/lndir ${pkg}/share/wayland-sessions $out/share/wayland-sessions - fi - '') cfg.sessionPackages} - ''; + if test -d ${pkg}/share/wayland-sessions; then + ${pkgs.buildPackages.xorg.lndir}/bin/lndir ${pkg}/share/wayland-sessions $out/share/wayland-sessions + fi + '') cfg.sessionPackages} + ''; in { options = { @@ -50,7 +57,7 @@ in environment = lib.mkOption { type = with lib.types; attrsOf unspecified; - default = {}; + default = { }; description = "Additional environment variables needed by the display manager."; }; @@ -82,28 +89,31 @@ in # Configuration for automatic login. Common for all DM. autoLogin = lib.mkOption { - type = lib.types.submodule ({ config, options, ... }: { - options = { - enable = lib.mkOption { - type = lib.types.bool; - default = config.user != null; - defaultText = lib.literalExpression "config.${options.user} != null"; - description = '' - Automatically log in as {option}`autoLogin.user`. - ''; - }; + type = lib.types.submodule ( + { config, options, ... }: + { + options = { + enable = lib.mkOption { + type = lib.types.bool; + default = config.user != null; + defaultText = lib.literalExpression "config.${options.user} != null"; + description = '' + Automatically log in as {option}`autoLogin.user`. + ''; + }; - user = lib.mkOption { - type = with lib.types; nullOr str; - default = null; - description = '' - User to be used for the automatic login. - ''; + user = lib.mkOption { + type = with lib.types; nullOr str; + default = null; + description = '' + User to be used for the automatic login. + ''; + }; }; - }; - }); + } + ); - default = {}; + default = { }; description = '' Auto login configuration attrset. ''; @@ -112,12 +122,13 @@ in defaultSession = lib.mkOption { type = lib.types.nullOr lib.types.str // { description = "session name"; - check = d: + check = + d: lib.assertMsg (d != null -> (lib.types.str.check d && lib.elem d cfg.sessionData.sessionNames)) '' - Default graphical session, '${d}', not found. - Valid names for 'services.displayManager.defaultSession' are: - ${lib.concatStringsSep "\n " cfg.sessionData.sessionNames} - ''; + Default graphical session, '${d}', not found. + Valid names for 'services.displayManager.defaultSession' are: + ${lib.concatStringsSep "\n " cfg.sessionData.sessionNames} + ''; }; default = null; example = "gnome"; @@ -133,25 +144,34 @@ in sessionData = lib.mkOption { description = "Data exported for display managers’ convenience"; internal = true; - default = {}; + default = { }; }; sessionPackages = lib.mkOption { - type = lib.types.listOf (lib.types.package // { - description = "package with provided sessions"; - check = p: lib.assertMsg - (lib.types.package.check p && p ? providedSessions - && p.providedSessions != [] && lib.all lib.isString p.providedSessions) - '' - Package, '${p.name}', did not specify any session names, as strings, in - 'passthru.providedSessions'. This is required when used as a session package. - - The session names can be looked up in: - ${p}/share/xsessions - ${p}/share/wayland-sessions - ''; - }); - default = []; + type = lib.types.listOf ( + lib.types.package + // { + description = "package with provided sessions"; + check = + p: + lib.assertMsg + ( + lib.types.package.check p + && p ? providedSessions + && p.providedSessions != [ ] + && lib.all lib.isString p.providedSessions + ) + '' + Package, '${p.name}', did not specify any session names, as strings, in + 'passthru.providedSessions'. This is required when used as a session package. + + The session names can be looked up in: + ${p}/share/xsessions + ${p}/share/wayland-sessions + ''; + } + ); + default = [ ]; description = '' A list of packages containing x11 or wayland session files to be passed to the display manager. ''; @@ -160,21 +180,52 @@ in }; imports = [ - (lib.mkRenamedOptionModule [ "services" "xserver" "displayManager" "autoLogin" ] [ "services" "displayManager" "autoLogin" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "displayManager" "defaultSession" ] [ "services" "displayManager" "defaultSession" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "displayManager" "hiddenUsers" ] [ "services" "displayManager" "hiddenUsers" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "displayManager" "job" "environment" ] [ "services" "displayManager" "environment" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "displayManager" "job" "execCmd" ] [ "services" "displayManager" "execCmd" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "displayManager" "job" "logToFile" ] [ "services" "displayManager" "logToFile" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "displayManager" "job" "logToJournal" ] [ "services" "displayManager" "logToJournal" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "displayManager" "job" "preStart" ] [ "services" "displayManager" "preStart" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "displayManager" "sessionData" ] [ "services" "displayManager" "sessionData" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "displayManager" "sessionPackages" ] [ "services" "displayManager" "sessionPackages" ]) + (lib.mkRenamedOptionModule + [ "services" "xserver" "displayManager" "autoLogin" ] + [ "services" "displayManager" "autoLogin" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "displayManager" "defaultSession" ] + [ "services" "displayManager" "defaultSession" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "displayManager" "hiddenUsers" ] + [ "services" "displayManager" "hiddenUsers" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "displayManager" "job" "environment" ] + [ "services" "displayManager" "environment" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "displayManager" "job" "execCmd" ] + [ "services" "displayManager" "execCmd" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "displayManager" "job" "logToFile" ] + [ "services" "displayManager" "logToFile" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "displayManager" "job" "logToJournal" ] + [ "services" "displayManager" "logToJournal" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "displayManager" "job" "preStart" ] + [ "services" "displayManager" "preStart" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sessionData" ] + [ "services" "displayManager" "sessionData" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sessionPackages" ] + [ "services" "displayManager" "sessionPackages" ] + ) ]; config = lib.mkIf cfg.enable { assertions = [ - { assertion = cfg.autoLogin.enable -> cfg.autoLogin.user != null; + { + assertion = cfg.autoLogin.enable -> cfg.autoLogin.user != null; message = '' services.displayManager.autoLogin.enable requires services.displayManager.autoLogin.user to be set ''; @@ -194,7 +245,7 @@ in autologinSession = if cfg.defaultSession != null then cfg.defaultSession - else if cfg.sessionData.sessionNames != [] then + else if cfg.sessionData.sessionNames != [ ] then lib.head cfg.sessionData.sessionNames else null; @@ -202,17 +253,22 @@ in # so that the service won't be enabled when only startx is used systemd.services.display-manager.enable = - let dmConf = config.services.xserver.displayManager; - noDmUsed = !(dmConf.gdm.enable - || cfg.sddm.enable - || dmConf.xpra.enable - || dmConf.lightdm.enable - || cfg.ly.enable); - in lib.mkIf noDmUsed (lib.mkDefault false); + let + dmConf = config.services.xserver.displayManager; + noDmUsed = + !( + dmConf.gdm.enable || cfg.sddm.enable || dmConf.xpra.enable || dmConf.lightdm.enable || cfg.ly.enable + ); + in + lib.mkIf noDmUsed (lib.mkDefault false); systemd.services.display-manager = { description = "Display Manager"; - after = [ "acpid.service" "systemd-logind.service" "systemd-user-sessions.service" ]; + after = [ + "acpid.service" + "systemd-logind.service" + "systemd-user-sessions.service" + ]; restartIfChanged = false; environment = cfg.environment; diff --git a/nixos/modules/services/display-managers/sddm.nix b/nixos/modules/services/display-managers/sddm.nix index ca46d627101ad4..9f70867be42313 100644 --- a/nixos/modules/services/display-managers/sddm.nix +++ b/nixos/modules/services/display-managers/sddm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let xcfg = config.services.xserver; @@ -15,9 +20,20 @@ let iniFmt = pkgs.formats.ini { }; inherit (lib) - concatMapStrings concatStringsSep getExe - attrNames getAttr optionalAttrs optionalString - mkRemovedOptionModule mkRenamedOptionModule mkIf mkEnableOption mkOption mkPackageOption types + concatMapStrings + concatStringsSep + getExe + attrNames + getAttr + optionalAttrs + optionalString + mkRemovedOptionModule + mkRenamedOptionModule + mkIf + mkEnableOption + mkOption + mkPackageOption + types ; xserverWrapper = pkgs.writeShellScript "xserver-wrapper" '' @@ -34,67 +50,74 @@ let ${cfg.stopScript} ''; - defaultConfig = { - General = { - HaltCommand = "/run/current-system/systemd/bin/systemctl poweroff"; - RebootCommand = "/run/current-system/systemd/bin/systemctl reboot"; - Numlock = if cfg.autoNumlock then "on" else "none"; # on, off none - - # Implementation is done via pkgs/applications/display-managers/sddm/sddm-default-session.patch - DefaultSession = optionalString (config.services.displayManager.defaultSession != null) "${config.services.displayManager.defaultSession}.desktop"; + defaultConfig = + { + General = + { + HaltCommand = "/run/current-system/systemd/bin/systemctl poweroff"; + RebootCommand = "/run/current-system/systemd/bin/systemctl reboot"; + Numlock = if cfg.autoNumlock then "on" else "none"; # on, off none + + # Implementation is done via pkgs/applications/display-managers/sddm/sddm-default-session.patch + DefaultSession = optionalString ( + config.services.displayManager.defaultSession != null + ) "${config.services.displayManager.defaultSession}.desktop"; + + DisplayServer = if cfg.wayland.enable then "wayland" else "x11"; + } + // optionalAttrs (cfg.wayland.enable && cfg.wayland.compositor == "kwin") { + GreeterEnvironment = "QT_WAYLAND_SHELL_INTEGRATION=layer-shell"; + InputMethod = ""; # needed if we are using --inputmethod with kwin + }; - DisplayServer = if cfg.wayland.enable then "wayland" else "x11"; - } // optionalAttrs (cfg.wayland.enable && cfg.wayland.compositor == "kwin") { - GreeterEnvironment = "QT_WAYLAND_SHELL_INTEGRATION=layer-shell"; - InputMethod = ""; # needed if we are using --inputmethod with kwin - }; + Theme = + { + Current = cfg.theme; + ThemeDir = "/run/current-system/sw/share/sddm/themes"; + FacesDir = "/run/current-system/sw/share/sddm/faces"; + } + // optionalAttrs (cfg.theme == "breeze") { + CursorTheme = "breeze_cursors"; + CursorSize = 24; + }; - Theme = { - Current = cfg.theme; - ThemeDir = "/run/current-system/sw/share/sddm/themes"; - FacesDir = "/run/current-system/sw/share/sddm/faces"; - } // optionalAttrs (cfg.theme == "breeze") { - CursorTheme = "breeze_cursors"; - CursorSize = 24; - }; + Users = { + MaximumUid = config.ids.uids.nixbld; + HideUsers = concatStringsSep "," dmcfg.hiddenUsers; + HideShells = "/run/current-system/sw/bin/nologin"; + }; - Users = { - MaximumUid = config.ids.uids.nixbld; - HideUsers = concatStringsSep "," dmcfg.hiddenUsers; - HideShells = "/run/current-system/sw/bin/nologin"; - }; + Wayland = { + EnableHiDPI = cfg.enableHidpi; + SessionDir = "${dmcfg.sessionData.desktops}/share/wayland-sessions"; + CompositorCommand = lib.optionalString cfg.wayland.enable cfg.wayland.compositorCommand; + }; - Wayland = { - EnableHiDPI = cfg.enableHidpi; - SessionDir = "${dmcfg.sessionData.desktops}/share/wayland-sessions"; - CompositorCommand = lib.optionalString cfg.wayland.enable cfg.wayland.compositorCommand; + } + // optionalAttrs xcfg.enable { + X11 = { + MinimumVT = if xcfg.tty != null then xcfg.tty else 7; + ServerPath = toString xserverWrapper; + XephyrPath = "${pkgs.xorg.xorgserver.out}/bin/Xephyr"; + SessionCommand = toString dmcfg.sessionData.wrapper; + SessionDir = "${dmcfg.sessionData.desktops}/share/xsessions"; + XauthPath = "${pkgs.xorg.xauth}/bin/xauth"; + DisplayCommand = toString Xsetup; + DisplayStopCommand = toString Xstop; + EnableHiDPI = cfg.enableHidpi; + }; + } + // optionalAttrs dmcfg.autoLogin.enable { + Autologin = { + User = dmcfg.autoLogin.user; + Session = autoLoginSessionName; + Relogin = cfg.autoLogin.relogin; + }; }; - } // optionalAttrs xcfg.enable { - X11 = { - MinimumVT = if xcfg.tty != null then xcfg.tty else 7; - ServerPath = toString xserverWrapper; - XephyrPath = "${pkgs.xorg.xorgserver.out}/bin/Xephyr"; - SessionCommand = toString dmcfg.sessionData.wrapper; - SessionDir = "${dmcfg.sessionData.desktops}/share/xsessions"; - XauthPath = "${pkgs.xorg.xauth}/bin/xauth"; - DisplayCommand = toString Xsetup; - DisplayStopCommand = toString Xstop; - EnableHiDPI = cfg.enableHidpi; - }; - } // optionalAttrs dmcfg.autoLogin.enable { - Autologin = { - User = dmcfg.autoLogin.user; - Session = autoLoginSessionName; - Relogin = cfg.autoLogin.relogin; - }; - }; + cfgFile = iniFmt.generate "sddm.conf" (lib.recursiveUpdate defaultConfig cfg.settings); - cfgFile = - iniFmt.generate "sddm.conf" (lib.recursiveUpdate defaultConfig cfg.settings); - - autoLoginSessionName = - "${dmcfg.sessionData.autologinSession}.desktop"; + autoLoginSessionName = "${dmcfg.sessionData.autologinSession}.desktop"; compositorCmds = { kwin = concatStringsSep " " [ @@ -127,31 +150,75 @@ let in { imports = [ - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "sddm" "autoLogin" "minimumUid" ] [ "services" "displayManager" "sddm" "autoLogin" "minimumUid" ]) - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "sddm" "autoLogin" "relogin" ] [ "services" "displayManager" "sddm" "autoLogin" "relogin" ]) - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "sddm" "autoNumlock" ] [ "services" "displayManager" "sddm" "autoNumlock" ]) - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "sddm" "enable" ] [ "services" "displayManager" "sddm" "enable" ]) - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "sddm" "enableHidpi" ] [ "services" "displayManager" "sddm" "enableHidpi" ]) - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "sddm" "extraPackages" ] [ "services" "displayManager" "sddm" "extraPackages" ]) - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "sddm" "package" ] [ "services" "displayManager" "sddm" "package" ]) - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "sddm" "settings" ] [ "services" "displayManager" "sddm" "settings" ]) - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "sddm" "setupScript" ] [ "services" "displayManager" "sddm" "setupScript" ]) - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "sddm" "stopScript" ] [ "services" "displayManager" "sddm" "stopScript" ]) - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "sddm" "theme" ] [ "services" "displayManager" "sddm" "theme" ]) - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "sddm" "wayland" "enable" ] [ "services" "displayManager" "sddm" "wayland" "enable" ]) - - (mkRemovedOptionModule - [ "services" "displayManager" "sddm" "themes" ] - "Set the option `services.displayManager.sddm.package' instead.") + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sddm" "autoLogin" "minimumUid" ] + [ "services" "displayManager" "sddm" "autoLogin" "minimumUid" ] + ) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sddm" "autoLogin" "relogin" ] + [ "services" "displayManager" "sddm" "autoLogin" "relogin" ] + ) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sddm" "autoNumlock" ] + [ "services" "displayManager" "sddm" "autoNumlock" ] + ) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sddm" "enable" ] + [ "services" "displayManager" "sddm" "enable" ] + ) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sddm" "enableHidpi" ] + [ "services" "displayManager" "sddm" "enableHidpi" ] + ) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sddm" "extraPackages" ] + [ "services" "displayManager" "sddm" "extraPackages" ] + ) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sddm" "package" ] + [ "services" "displayManager" "sddm" "package" ] + ) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sddm" "settings" ] + [ "services" "displayManager" "sddm" "settings" ] + ) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sddm" "setupScript" ] + [ "services" "displayManager" "sddm" "setupScript" ] + ) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sddm" "stopScript" ] + [ "services" "displayManager" "sddm" "stopScript" ] + ) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sddm" "theme" ] + [ "services" "displayManager" "sddm" "theme" ] + ) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "sddm" "wayland" "enable" ] + [ "services" "displayManager" "sddm" "wayland" "enable" ] + ) + + (mkRemovedOptionModule [ + "services" + "displayManager" + "sddm" + "themes" + ] "Set the option `services.displayManager.sddm.package' instead.") (mkRenamedOptionModule [ "services" "displayManager" "sddm" "autoLogin" "enable" ] - [ "services" "displayManager" "autoLogin" "enable" ]) + [ "services" "displayManager" "autoLogin" "enable" ] + ) (mkRenamedOptionModule [ "services" "displayManager" "sddm" "autoLogin" "user" ] - [ "services" "displayManager" "autoLogin" "user" ]) - (mkRemovedOptionModule - [ "services" "displayManager" "sddm" "extraConfig" ] - "Set the option `services.displayManager.sddm.settings' instead.") + [ "services" "displayManager" "autoLogin" "user" ] + ) + (mkRemovedOptionModule [ + "services" + "displayManager" + "sddm" + "extraConfig" + ] "Set the option `services.displayManager.sddm.settings' instead.") ]; options = { diff --git a/nixos/modules/services/editors/emacs.nix b/nixos/modules/services/editors/emacs.nix index ee1951e2622285..93c814acad2e3c 100644 --- a/nixos/modules/services/editors/emacs.nix +++ b/nixos/modules/services/editors/emacs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.emacs; @@ -39,7 +44,6 @@ in ''; }; - package = lib.mkPackageOption pkgs "emacs" { }; defaultEditor = lib.mkOption { @@ -62,24 +66,29 @@ in }; config = lib.mkIf (cfg.enable || cfg.install) { - systemd.user.services.emacs = { - description = "Emacs: the extensible, self-documenting text editor"; - - serviceConfig = { - Type = "notify"; - ExecStart = "${pkgs.runtimeShell} -c 'source ${config.system.build.setEnvironment}; exec ${cfg.package}/bin/emacs --fg-daemon'"; - ExecStop = "${cfg.package}/bin/emacsclient --eval (kill-emacs)"; - Restart = "always"; + systemd.user.services.emacs = + { + description = "Emacs: the extensible, self-documenting text editor"; + + serviceConfig = { + Type = "notify"; + ExecStart = "${pkgs.runtimeShell} -c 'source ${config.system.build.setEnvironment}; exec ${cfg.package}/bin/emacs --fg-daemon'"; + ExecStop = "${cfg.package}/bin/emacsclient --eval (kill-emacs)"; + Restart = "always"; + }; + + unitConfig = lib.optionalAttrs cfg.startWithGraphical { + After = "graphical-session.target"; + }; + } + // lib.optionalAttrs cfg.enable { + wantedBy = if cfg.startWithGraphical then [ "graphical-session.target" ] else [ "default.target" ]; }; - unitConfig = lib.optionalAttrs cfg.startWithGraphical { - After = "graphical-session.target"; - }; - } // lib.optionalAttrs cfg.enable { - wantedBy = if cfg.startWithGraphical then [ "graphical-session.target" ] else [ "default.target" ]; - }; - - environment.systemPackages = [ cfg.package editorScript ]; + environment.systemPackages = [ + cfg.package + editorScript + ]; environment.variables.EDITOR = lib.mkIf cfg.defaultEditor (lib.mkOverride 900 "emacseditor"); }; diff --git a/nixos/modules/services/editors/haste.nix b/nixos/modules/services/editors/haste.nix index cf5bde6a58651c..9bedb81736e540 100644 --- a/nixos/modules/services/editors/haste.nix +++ b/nixos/modules/services/editors/haste.nix @@ -1,9 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let pkg = pkgs.haste-server; cfg = config.services.haste-server; - format = pkgs.formats.json {}; + format = pkgs.formats.json { }; in { options.services.haste-server = { @@ -77,7 +82,10 @@ in ExecStart = "${pkg}/bin/haste-server ${format.generate "config.json" cfg.settings}"; }; - path = with pkgs; [ pkg coreutils ]; + path = with pkgs; [ + pkg + coreutils + ]; }; }; } diff --git a/nixos/modules/services/editors/infinoted.nix b/nixos/modules/services/editors/infinoted.nix index b6e353b637e817..fe58552369d73f 100644 --- a/nixos/modules/services/editors/infinoted.nix +++ b/nixos/modules/services/editors/infinoted.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.infinoted; -in { +in +{ options.services.infinoted = { enable = lib.mkEnableOption "infinoted"; @@ -33,7 +39,11 @@ in { }; securityPolicy = lib.mkOption { - type = lib.types.enum ["no-tls" "allow-tls" "require-tls"]; + type = lib.types.enum [ + "no-tls" + "allow-tls" + "require-tls" + ]; default = "require-tls"; description = '' How strictly to enforce clients connection with TLS. @@ -58,7 +68,12 @@ in { plugins = lib.mkOption { type = lib.types.listOf lib.types.str; - default = [ "note-text" "note-chat" "logging" "autosave" ]; + default = [ + "note-text" + "note-chat" + "logging" + "autosave" + ]; description = '' Plugins to enable ''; @@ -101,50 +116,50 @@ in { }; config = lib.mkIf (cfg.enable) { - users.users = lib.optionalAttrs (cfg.user == "infinoted") - { infinoted = { - description = "Infinoted user"; - group = cfg.group; - isSystemUser = true; - }; - }; - users.groups = lib.optionalAttrs (cfg.group == "infinoted") - { infinoted = { }; + users.users = lib.optionalAttrs (cfg.user == "infinoted") { + infinoted = { + description = "Infinoted user"; + group = cfg.group; + isSystemUser = true; }; + }; + users.groups = lib.optionalAttrs (cfg.group == "infinoted") { + infinoted = { }; + }; + + systemd.services.infinoted = { + description = "Gobby Dedicated Server"; - systemd.services.infinoted = - { description = "Gobby Dedicated Server"; - - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - - serviceConfig = { - Type = "simple"; - Restart = "always"; - ExecStart = "${cfg.package.infinoted} --config-file=/var/lib/infinoted/infinoted.conf"; - User = cfg.user; - Group = cfg.group; - PermissionsStartOnly = true; - }; - preStart = '' - mkdir -p /var/lib/infinoted - install -o ${cfg.user} -g ${cfg.group} -m 0600 /dev/null /var/lib/infinoted/infinoted.conf - cat >>/var/lib/infinoted/infinoted.conf <>/var/lib/infinoted/infinoted.conf < ''; @@ -50,113 +57,122 @@ in }; }; - config = lib.mkIf (cfg.enable) (let - cfgFile = format.generate "odoo.cfg" cfg.settings; - in { - services.nginx = lib.mkIf (cfg.domain != null) { - upstreams = { - odoo.servers = { - "127.0.0.1:8069" = {}; + config = lib.mkIf (cfg.enable) ( + let + cfgFile = format.generate "odoo.cfg" cfg.settings; + in + { + services.nginx = lib.mkIf (cfg.domain != null) { + upstreams = { + odoo.servers = { + "127.0.0.1:8069" = { }; + }; + + odoochat.servers = { + "127.0.0.1:8072" = { }; + }; }; - odoochat.servers = { - "127.0.0.1:8072" = {}; + virtualHosts."${cfg.domain}" = { + extraConfig = '' + proxy_read_timeout 720s; + proxy_connect_timeout 720s; + proxy_send_timeout 720s; + + proxy_set_header X-Forwarded-Host $host; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + proxy_set_header X-Real-IP $remote_addr; + ''; + + locations = { + "/longpolling" = { + proxyPass = "http://odoochat"; + }; + + "/" = { + proxyPass = "http://odoo"; + extraConfig = '' + proxy_redirect off; + ''; + }; + }; }; }; - virtualHosts."${cfg.domain}" = { - extraConfig = '' - proxy_read_timeout 720s; - proxy_connect_timeout 720s; - proxy_send_timeout 720s; - - proxy_set_header X-Forwarded-Host $host; - proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; - proxy_set_header X-Forwarded-Proto $scheme; - proxy_set_header X-Real-IP $remote_addr; - ''; + services.odoo.settings.options = + { + data_dir = "/var/lib/private/odoo/data"; + proxy_mode = cfg.domain != null; + } + // (lib.optionalAttrs (cfg.addons != [ ]) { + addons_path = lib.concatMapStringsSep "," lib.escapeShellArg cfg.addons; + }); + + users.users.odoo = { + isSystemUser = true; + group = "odoo"; + }; + users.groups.odoo = { }; - locations = { - "/longpolling" = { - proxyPass = "http://odoochat"; - }; + systemd.services.odoo = { + wantedBy = [ "multi-user.target" ]; + after = [ + "network.target" + "postgresql.service" + ]; - "/" = { - proxyPass = "http://odoo"; - extraConfig = '' - proxy_redirect off; - ''; - }; + # pg_dump + path = [ config.services.postgresql.package ]; + + requires = [ "postgresql.service" ]; + + serviceConfig = { + ExecStart = "${cfg.package}/bin/odoo"; + ExecStartPre = pkgs.writeShellScript "odoo-start-pre.sh" ( + '' + set -euo pipefail + + cd "$STATE_DIRECTORY" + + # Auto-migrate old deployments + if [[ -d .local/share/Odoo ]]; then + echo "pre-start: migrating state directory from $STATE_DIRECTORY/.local/share/Odoo to $STATE_DIRECTORY/data" + mv .local/share/Odoo ./data + rmdir .local/share + rmdir .local + fi + '' + + (lib.optionalString cfg.autoInit '' + echo "pre-start: auto-init" + INITIALIZED="${cfg.settings.options.data_dir}/.odoo.initialized" + if [ ! -e "$INITIALIZED" ]; then + ${cfg.package}/bin/odoo --init=INIT --database=odoo --db_user=odoo --stop-after-init ${lib.concatStringsSep " " cfg.autoInitExtraFlags} + touch "$INITIALIZED" + fi + '') + + "echo pre-start: OK" + ); + DynamicUser = true; + User = "odoo"; + StateDirectory = "odoo"; + Environment = [ + "ODOO_RC=${cfgFile}" + ]; }; }; - }; - services.odoo.settings.options = { - data_dir = "/var/lib/private/odoo/data"; - proxy_mode = cfg.domain != null; - } // (lib.optionalAttrs (cfg.addons != []) { - addons_path = lib.concatMapStringsSep "," lib.escapeShellArg cfg.addons; - }); + services.postgresql = { + enable = true; - users.users.odoo = { - isSystemUser = true; - group = "odoo"; - }; - users.groups.odoo = {}; - - systemd.services.odoo = { - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "postgresql.service" ]; - - # pg_dump - path = [ config.services.postgresql.package ]; - - requires = [ "postgresql.service" ]; - - serviceConfig = { - ExecStart = "${cfg.package}/bin/odoo"; - ExecStartPre = pkgs.writeShellScript "odoo-start-pre.sh" ( - '' - set -euo pipefail - - cd "$STATE_DIRECTORY" - - # Auto-migrate old deployments - if [[ -d .local/share/Odoo ]]; then - echo "pre-start: migrating state directory from $STATE_DIRECTORY/.local/share/Odoo to $STATE_DIRECTORY/data" - mv .local/share/Odoo ./data - rmdir .local/share - rmdir .local - fi - '' - + (lib.optionalString cfg.autoInit - '' - echo "pre-start: auto-init" - INITIALIZED="${cfg.settings.options.data_dir}/.odoo.initialized" - if [ ! -e "$INITIALIZED" ]; then - ${cfg.package}/bin/odoo --init=INIT --database=odoo --db_user=odoo --stop-after-init ${lib.concatStringsSep " " cfg.autoInitExtraFlags} - touch "$INITIALIZED" - fi - '') - + "echo pre-start: OK" - ); - DynamicUser = true; - User = "odoo"; - StateDirectory = "odoo"; - Environment = [ - "ODOO_RC=${cfgFile}" + ensureDatabases = [ "odoo" ]; + ensureUsers = [ + { + name = "odoo"; + ensureDBOwnership = true; + } ]; }; - }; - - services.postgresql = { - enable = true; - - ensureDatabases = [ "odoo" ]; - ensureUsers = [{ - name = "odoo"; - ensureDBOwnership = true; - }]; - }; - }); + } + ); } diff --git a/nixos/modules/services/games/armagetronad.nix b/nixos/modules/services/games/armagetronad.nix index dfeadb19026f77..17e449beb54777 100644 --- a/nixos/modules/services/games/armagetronad.nix +++ b/nixos/modules/services/games/armagetronad.nix @@ -1,22 +1,47 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkIf mkOption mkMerge literalExpression; - inherit (lib) mapAttrsToList filterAttrs unique recursiveUpdate types; + inherit (lib) + mkEnableOption + mkIf + mkOption + mkMerge + literalExpression + ; + inherit (lib) + mapAttrsToList + filterAttrs + unique + recursiveUpdate + types + ; - mkValueStringArmagetron = with lib; v: - if isInt v then toString v - else if isFloat v then toString v - else if isString v then v - else if true == v then "1" - else if false == v then "0" - else if null == v then "" - else throw "unsupported type: ${builtins.typeOf v}: ${(lib.generators.toPretty {} v)}"; + mkValueStringArmagetron = + with lib; + v: + if isInt v then + toString v + else if isFloat v then + toString v + else if isString v then + v + else if true == v then + "1" + else if false == v then + "0" + else if null == v then + "" + else + throw "unsupported type: ${builtins.typeOf v}: ${(lib.generators.toPretty { } v)}"; settingsFormat = pkgs.formats.keyValue { - mkKeyValue = lib.generators.mkKeyValueDefault - { - mkValueString = mkValueStringArmagetron; - } " "; + mkKeyValue = lib.generators.mkKeyValueDefault { + mkValueString = mkValueStringArmagetron; + } " "; listsAsDuplicateKeys = true; }; @@ -32,96 +57,99 @@ in servers = mkOption { description = "Armagetron server definitions."; default = { }; - type = types.attrsOf (types.submodule { - options = { - enable = mkEnableOption "armagetronad"; + type = types.attrsOf ( + types.submodule { + options = { + enable = mkEnableOption "armagetronad"; - package = lib.mkPackageOption pkgs "armagetronad-dedicated" { - example = '' - pkgs.armagetronad."0.2.9-sty+ct+ap".dedicated - ''; - extraDescription = '' - Ensure that you use a derivation which contains the path `bin/armagetronad-dedicated`. - ''; - }; + package = lib.mkPackageOption pkgs "armagetronad-dedicated" { + example = '' + pkgs.armagetronad."0.2.9-sty+ct+ap".dedicated + ''; + extraDescription = '' + Ensure that you use a derivation which contains the path `bin/armagetronad-dedicated`. + ''; + }; - host = mkOption { - type = types.str; - default = "0.0.0.0"; - description = "Host to listen on. Used for SERVER_IP."; - }; + host = mkOption { + type = types.str; + default = "0.0.0.0"; + description = "Host to listen on. Used for SERVER_IP."; + }; - port = mkOption { - type = types.port; - default = 4534; - description = "Port to listen on. Used for SERVER_PORT."; - }; + port = mkOption { + type = types.port; + default = 4534; + description = "Port to listen on. Used for SERVER_PORT."; + }; - dns = mkOption { - type = types.nullOr types.str; - default = null; - description = "DNS address to use for this server. Optional."; - }; + dns = mkOption { + type = types.nullOr types.str; + default = null; + description = "DNS address to use for this server. Optional."; + }; - openFirewall = mkOption { - type = types.bool; - default = true; - description = "Set to true to open the configured UDP port for Armagetron Advanced."; - }; + openFirewall = mkOption { + type = types.bool; + default = true; + description = "Set to true to open the configured UDP port for Armagetron Advanced."; + }; - name = mkOption { - type = types.str; - description = "The name of this server."; - }; + name = mkOption { + type = types.str; + description = "The name of this server."; + }; - settings = mkOption { - type = settingsFormat.type; - default = { }; - description = '' - Armagetron Advanced server rules configuration. Refer to: - - or `armagetronad-dedicated --doc` for a list. + settings = mkOption { + type = settingsFormat.type; + default = { }; + description = '' + Armagetron Advanced server rules configuration. Refer to: + + or `armagetronad-dedicated --doc` for a list. - This attrset is used to populate `settings_custom.cfg`; see: - - ''; - example = literalExpression '' - { - CYCLE_RUBBER = 40; - } - ''; - }; + This attrset is used to populate `settings_custom.cfg`; see: + + ''; + example = literalExpression '' + { + CYCLE_RUBBER = 40; + } + ''; + }; - roundSettings = mkOption { - type = settingsFormat.type; - default = { }; - description = '' - Armagetron Advanced server per-round configuration. Refer to: - - or `armagetronad-dedicated --doc` for a list. + roundSettings = mkOption { + type = settingsFormat.type; + default = { }; + description = '' + Armagetron Advanced server per-round configuration. Refer to: + + or `armagetronad-dedicated --doc` for a list. - This attrset is used to populate `everytime.cfg`; see: - - ''; - example = literalExpression '' - { - SAY = [ - "Hosted on NixOS" - "https://nixos.org" - "iD Tech High Rubber rul3z!! Happy New Year 2008!!1" - ]; - } - ''; + This attrset is used to populate `everytime.cfg`; see: + + ''; + example = literalExpression '' + { + SAY = [ + "Hosted on NixOS" + "https://nixos.org" + "iD Tech High Rubber rul3z!! Happy New Year 2008!!1" + ]; + } + ''; + }; }; - }; - }); + } + ); }; }; }; config = mkIf (enabledServers != { }) { - systemd.tmpfiles.settings = mkMerge (mapAttrsToList - (serverName: serverCfg: + systemd.tmpfiles.settings = mkMerge ( + mapAttrsToList ( + serverName: serverCfg: let serverId = nameToId serverName; serverRoot = getServerRoot serverName; @@ -130,7 +158,8 @@ in SERVER_IP = serverCfg.host; SERVER_PORT = serverCfg.port; SERVER_NAME = serverCfg.name; - } // (lib.optionalAttrs (serverCfg.dns != null) { SERVER_DNS = serverCfg.dns; }) + } + // (lib.optionalAttrs (serverCfg.dns != null) { SERVER_DNS = serverCfg.dns; }) ); customSettings = serverCfg.settings; everytimeSettings = serverCfg.roundSettings; @@ -193,12 +222,12 @@ in }; }; } - ) - enabledServers + ) enabledServers ); - systemd.services = mkMerge (mapAttrsToList - (serverName: serverCfg: + systemd.services = mkMerge ( + mapAttrsToList ( + serverName: serverCfg: let serverId = nameToId serverName; in @@ -206,7 +235,11 @@ in "armagetronad-${serverName}" = { description = "Armagetron Advanced Dedicated Server for ${serverName}"; wants = [ "basic.target" ]; - after = [ "basic.target" "network.target" "multi-user.target" ]; + after = [ + "basic.target" + "network.target" + "multi-user.target" + ]; wantedBy = [ "multi-user.target" ]; serviceConfig = let @@ -238,31 +271,30 @@ in Group = serverId; }; }; - }) - enabledServers + } + ) enabledServers ); - networking.firewall.allowedUDPPorts = - unique (mapAttrsToList (serverName: serverCfg: serverCfg.port) (filterAttrs (serverName: serverCfg: serverCfg.openFirewall) enabledServers)); + networking.firewall.allowedUDPPorts = unique ( + mapAttrsToList (serverName: serverCfg: serverCfg.port) ( + filterAttrs (serverName: serverCfg: serverCfg.openFirewall) enabledServers + ) + ); - users.users = mkMerge (mapAttrsToList - (serverName: serverCfg: - { - ${nameToId serverName} = { - group = nameToId serverName; - description = "Armagetron Advanced dedicated user for server ${serverName}"; - isSystemUser = true; - }; - }) - enabledServers + users.users = mkMerge ( + mapAttrsToList (serverName: serverCfg: { + ${nameToId serverName} = { + group = nameToId serverName; + description = "Armagetron Advanced dedicated user for server ${serverName}"; + isSystemUser = true; + }; + }) enabledServers ); - users.groups = mkMerge (mapAttrsToList - (serverName: serverCfg: - { - ${nameToId serverName} = { }; - }) - enabledServers + users.groups = mkMerge ( + mapAttrsToList (serverName: serverCfg: { + ${nameToId serverName} = { }; + }) enabledServers ); }; } diff --git a/nixos/modules/services/games/crossfire-server.nix b/nixos/modules/services/games/crossfire-server.nix index 91a684873c2aaa..11d572ea3db12a 100644 --- a/nixos/modules/services/games/crossfire-server.nix +++ b/nixos/modules/services/games/crossfire-server.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.crossfire-server; serverPort = 13327; -in { +in +{ options.services.crossfire-server = { enable = lib.mkOption { type = lib.types.bool; @@ -94,49 +100,62 @@ in { '''; } ''; - default = {}; + default = { }; }; }; config = lib.mkIf cfg.enable { users.users.crossfire = { - description = "Crossfire server daemon user"; - home = cfg.stateDir; - createHome = false; - isSystemUser = true; - group = "crossfire"; + description = "Crossfire server daemon user"; + home = cfg.stateDir; + createHome = false; + isSystemUser = true; + group = "crossfire"; }; - users.groups.crossfire = {}; + users.groups.crossfire = { }; # Merge the cfg.configFiles setting with the default files shipped with # Crossfire. # For most files this consists of reading ${crossfire}/etc/crossfire/${name} # and appending the user setting to it; the motd, news, and rules are handled # specially, with user-provided values completely replacing the original. - environment.etc = lib.attrsets.mapAttrs' - (name: value: lib.attrsets.nameValuePair "crossfire/${name}" { - mode = "0644"; - text = - (lib.optionalString (!lib.elem name ["motd" "news" "rules"]) - (lib.fileContents "${cfg.package}/etc/crossfire/${name}")) - + "\n${value}"; - }) ({ - ban_file = ""; - dm_file = ""; - exp_table = ""; - forbid = ""; - metaserver2 = ""; - motd = lib.fileContents "${cfg.package}/etc/crossfire/motd"; - news = lib.fileContents "${cfg.package}/etc/crossfire/news"; - rules = lib.fileContents "${cfg.package}/etc/crossfire/rules"; - settings = ""; - stat_bonus = ""; - } // cfg.configFiles); + environment.etc = + lib.attrsets.mapAttrs' + ( + name: value: + lib.attrsets.nameValuePair "crossfire/${name}" { + mode = "0644"; + text = + (lib.optionalString ( + !lib.elem name [ + "motd" + "news" + "rules" + ] + ) (lib.fileContents "${cfg.package}/etc/crossfire/${name}")) + + "\n${value}"; + } + ) + ( + { + ban_file = ""; + dm_file = ""; + exp_table = ""; + forbid = ""; + metaserver2 = ""; + motd = lib.fileContents "${cfg.package}/etc/crossfire/motd"; + news = lib.fileContents "${cfg.package}/etc/crossfire/news"; + rules = lib.fileContents "${cfg.package}/etc/crossfire/rules"; + settings = ""; + stat_bonus = ""; + } + // cfg.configFiles + ); systemd.services.crossfire-server = { - description = "Crossfire Server Daemon"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + description = "Crossfire Server Daemon"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; serviceConfig = lib.mkMerge [ { diff --git a/nixos/modules/services/games/deliantra-server.nix b/nixos/modules/services/games/deliantra-server.nix index 0bb9cea92c7e0b..4854731714f73b 100644 --- a/nixos/modules/services/games/deliantra-server.nix +++ b/nixos/modules/services/games/deliantra-server.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.deliantra-server; serverPort = 13327; -in { +in +{ options.services.deliantra-server = { enable = lib.mkOption { type = lib.types.bool; @@ -91,44 +97,53 @@ in { config = lib.mkIf cfg.enable { users.users.deliantra = { - description = "Deliantra server daemon user"; - home = cfg.stateDir; - createHome = false; - isSystemUser = true; - group = "deliantra"; + description = "Deliantra server daemon user"; + home = cfg.stateDir; + createHome = false; + isSystemUser = true; + group = "deliantra"; }; - users.groups.deliantra = {}; + users.groups.deliantra = { }; # Merge the cfg.configFiles setting with the default files shipped with # Deliantra. # For most files this consists of reading # ${deliantra}/etc/deliantra-server/${name} and appending the user setting # to it. - environment.etc = lib.attrsets.mapAttrs' - (name: value: lib.attrsets.nameValuePair "deliantra-server/${name}" { - mode = "0644"; - text = - # Deliantra doesn't come with a motd file, but respects it if present - # in /etc. - (lib.optionalString (name != "motd") - (lib.fileContents "${cfg.package}/etc/deliantra-server/${name}")) - + "\n${value}"; - }) ({ - motd = ""; - settings = ""; - config = ""; - dm_file = ""; - } // cfg.configFiles); + environment.etc = + lib.attrsets.mapAttrs' + ( + name: value: + lib.attrsets.nameValuePair "deliantra-server/${name}" { + mode = "0644"; + text = + # Deliantra doesn't come with a motd file, but respects it if present + # in /etc. + (lib.optionalString (name != "motd") ( + lib.fileContents "${cfg.package}/etc/deliantra-server/${name}" + )) + + "\n${value}"; + } + ) + ( + { + motd = ""; + settings = ""; + config = ""; + dm_file = ""; + } + // cfg.configFiles + ); systemd.services.deliantra-server = { - description = "Deliantra Server Daemon"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + description = "Deliantra Server Daemon"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; environment = { - DELIANTRA_DATADIR="${cfg.dataDir}"; - DELIANTRA_LOCALDIR="${cfg.stateDir}"; - DELIANTRA_CONFDIR="/etc/deliantra-server"; + DELIANTRA_DATADIR = "${cfg.dataDir}"; + DELIANTRA_LOCALDIR = "${cfg.stateDir}"; + DELIANTRA_CONFDIR = "/etc/deliantra-server"; }; serviceConfig = lib.mkMerge [ diff --git a/nixos/modules/services/games/freeciv.nix b/nixos/modules/services/games/freeciv.nix index fc73824e692075..ad9b9d2101d1d3 100644 --- a/nixos/modules/services/games/freeciv.nix +++ b/nixos/modules/services/games/freeciv.nix @@ -1,24 +1,47 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.freeciv; inherit (config.users) groups; rootDir = "/run/freeciv"; argsFormat = { - type = with lib.types; let - valueType = nullOr (oneOf [ - bool int float str - (listOf valueType) - ]) // { - description = "freeciv-server params"; - }; - in valueType; - generate = name: value: - let mkParam = k: v: - if v == null then [] - else if lib.isBool v then lib.optional v ("--"+k) - else [("--"+k) v]; - mkParams = k: v: map (mkParam k) (if lib.isList v then v else [v]); - in lib.escapeShellArgs (lib.concatLists (lib.concatLists (lib.mapAttrsToList mkParams value))); + type = + with lib.types; + let + valueType = + nullOr (oneOf [ + bool + int + float + str + (listOf valueType) + ]) + // { + description = "freeciv-server params"; + }; + in + valueType; + generate = + name: value: + let + mkParam = + k: v: + if v == null then + [ ] + else if lib.isBool v then + lib.optional v ("--" + k) + else + [ + ("--" + k) + v + ]; + mkParams = k: v: map (mkParam k) (if lib.isList v then v else [ v ]); + in + lib.escapeShellArgs (lib.concatLists (lib.concatLists (lib.mapAttrsToList mkParams value))); }; in { @@ -29,11 +52,15 @@ in description = '' Parameters of freeciv-server. ''; - default = {}; + default = { }; type = lib.types.submodule { freeformType = argsFormat.type; options.Announce = lib.mkOption { - type = lib.types.enum ["IPv4" "IPv6" "none"]; + type = lib.types.enum [ + "IPv4" + "IPv6" + "none" + ]; default = "none"; description = "Announce game in LAN using given protocol."; }; @@ -89,7 +116,7 @@ in }; }; config = lib.mkIf cfg.enable { - users.groups.freeciv = {}; + users.groups.freeciv = { }; # Use with: # journalctl -u freeciv.service -f -o cat & # cat >/run/freeciv.stdin @@ -114,21 +141,30 @@ in StandardInput = "fd:freeciv.socket"; StandardOutput = "journal"; StandardError = "journal"; - ExecStart = pkgs.writeShellScript "freeciv-server" ('' - set -eux - savedir=$(date +%Y-%m-%d_%H-%M-%S) - '' + "${pkgs.freeciv}/bin/freeciv-server" - + " " + lib.optionalString (cfg.settings.saves != null) - (lib.concatStringsSep " " [ "--saves" "${lib.escapeShellArg cfg.settings.saves}/$savedir" ]) - + " " + argsFormat.generate "freeciv-server" (cfg.settings // { saves = null; })); + ExecStart = pkgs.writeShellScript "freeciv-server" ( + '' + set -eux + savedir=$(date +%Y-%m-%d_%H-%M-%S) + '' + + "${pkgs.freeciv}/bin/freeciv-server" + + " " + + lib.optionalString (cfg.settings.saves != null) ( + lib.concatStringsSep " " [ + "--saves" + "${lib.escapeShellArg cfg.settings.saves}/$savedir" + ] + ) + + " " + + argsFormat.generate "freeciv-server" (cfg.settings // { saves = null; }) + ); DynamicUser = true; # Create rootDir in the host's mount namespace. - RuntimeDirectory = [(baseNameOf rootDir)]; + RuntimeDirectory = [ (baseNameOf rootDir) ]; RuntimeDirectoryMode = "755"; StateDirectory = [ "freeciv" ]; WorkingDirectory = "/var/lib/freeciv"; # Avoid mounting rootDir in the own rootDir of ExecStart='s mount namespace. - InaccessiblePaths = ["-+${rootDir}"]; + InaccessiblePaths = [ "-+${rootDir}" ]; # This is for BindPaths= and BindReadOnlyPaths= # to allow traversal of directories they create in RootDirectory=. UMask = "0066"; @@ -163,7 +199,10 @@ in ProtectKernelTunables = true; ProtectSystem = "strict"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; @@ -172,15 +211,21 @@ in # Groups in @system-service which do not contain a syscall listed by: # perf stat -x, 2>perf.log -e 'syscalls:sys_enter_*' freeciv-server # in tests, and seem likely not necessary for freeciv-server. - "~@aio" "~@chown" "~@ipc" "~@keyring" "~@memlock" - "~@resources" "~@setuid" "~@sync" "~@timer" + "~@aio" + "~@chown" + "~@ipc" + "~@keyring" + "~@memlock" + "~@resources" + "~@setuid" + "~@sync" + "~@timer" ]; SystemCallArchitectures = "native"; SystemCallErrorNumber = "EPERM"; }; }; - networking.firewall = lib.mkIf cfg.openFirewall - { allowedTCPPorts = [ cfg.settings.port ]; }; + networking.firewall = lib.mkIf cfg.openFirewall { allowedTCPPorts = [ cfg.settings.port ]; }; }; meta.maintainers = with lib.maintainers; [ julm ]; } diff --git a/nixos/modules/services/games/mchprs.nix b/nixos/modules/services/games/mchprs.nix index 169e4ba84f60e2..53d070327fd401 100644 --- a/nixos/modules/services/games/mchprs.nix +++ b/nixos/modules/services/games/mchprs.nix @@ -1,15 +1,28 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.mchprs; settingsFormat = pkgs.formats.toml { }; - whitelistFile = pkgs.writeText "whitelist.json" - (builtins.toJSON - (lib.mapAttrsToList (n: v: { name = n; uuid = v; }) cfg.whitelist.list)); + whitelistFile = pkgs.writeText "whitelist.json" ( + builtins.toJSON ( + lib.mapAttrsToList (n: v: { + name = n; + uuid = v; + }) cfg.whitelist.list + ) + ); configToml = - (removeAttrs cfg.settings [ "address" "port" ]) // - { + (removeAttrs cfg.settings [ + "address" + "port" + ]) + // { bind_address = cfg.settings.address + ":" + toString cfg.settings.port; whitelist = cfg.whitelist.enable; }; @@ -205,10 +218,11 @@ in list = lib.mkOption { type = let - minecraftUUID = lib.types.strMatching - "[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}" // { - description = "Minecraft UUID"; - }; + minecraftUUID = + lib.types.strMatching "[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}" + // { + description = "Minecraft UUID"; + }; in lib.types.attrsOf minecraftUUID; default = { }; @@ -273,7 +287,10 @@ in ProtectKernelModules = true; ProtectKernelTunables = true; ProtectProc = "invisible"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; @@ -282,45 +299,56 @@ in }; preStart = - (if cfg.declarativeSettings then '' - if [ -e .declarativeSettings ]; then - - # Settings were declarative before, no need to back up anything - cp -f ${configTomlFile} Config.toml - - else + ( + if cfg.declarativeSettings then + '' + if [ -e .declarativeSettings ]; then - # Declarative settings for the first time, backup stateful files - cp -b --suffix=.stateful ${configTomlFile} Config.toml + # Settings were declarative before, no need to back up anything + cp -f ${configTomlFile} Config.toml - echo "Autogenerated file that implies that this server configuration is managed declaratively by NixOS" \ - > .declarativeSettings + else - fi - '' else '' - if [ -e .declarativeSettings ]; then - rm .declarativeSettings - fi - '') + (if cfg.declarativeWhitelist then '' - if [ -e .declarativeWhitelist ]; then + # Declarative settings for the first time, backup stateful files + cp -b --suffix=.stateful ${configTomlFile} Config.toml - # Whitelist was declarative before, no need to back up anything - ln -sf ${whitelistFile} whitelist.json + echo "Autogenerated file that implies that this server configuration is managed declaratively by NixOS" \ + > .declarativeSettings + fi + '' else - - # Declarative whitelist for the first time, backup stateful files - ln -sb --suffix=.stateful ${whitelistFile} whitelist.json - - echo "Autogenerated file that implies that this server's whitelist is managed declaratively by NixOS" \ - > .declarativeWhitelist - - fi - '' else '' - if [ -e .declarativeWhitelist ]; then - rm .declarativeWhitelist - fi - ''); + '' + if [ -e .declarativeSettings ]; then + rm .declarativeSettings + fi + '' + ) + + ( + if cfg.declarativeWhitelist then + '' + if [ -e .declarativeWhitelist ]; then + + # Whitelist was declarative before, no need to back up anything + ln -sf ${whitelistFile} whitelist.json + + else + + # Declarative whitelist for the first time, backup stateful files + ln -sb --suffix=.stateful ${whitelistFile} whitelist.json + + echo "Autogenerated file that implies that this server's whitelist is managed declaratively by NixOS" \ + > .declarativeWhitelist + + fi + '' + else + '' + if [ -e .declarativeWhitelist ]; then + rm .declarativeWhitelist + fi + '' + ); }; networking.firewall = lib.mkIf (cfg.declarativeSettings && cfg.openFirewall) { diff --git a/nixos/modules/services/games/minetest-server.nix b/nixos/modules/services/games/minetest-server.nix index 98613e4391efe7..52a2b31fc6229b 100644 --- a/nixos/modules/services/games/minetest-server.nix +++ b/nixos/modules/services/games/minetest-server.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let CONTAINS_NEWLINE_RE = ".*\n.*"; # The following values are reserved as complete option values: @@ -10,37 +15,57 @@ let # There is no way to encode """ on its own line in a Minetest config. UNESCAPABLE_RE = ".*\n\"\"\"\n.*"; - toConfMultiline = name: value: - assert lib.assertMsg - ((builtins.match UNESCAPABLE_RE value) == null) - ''""" can't be on its own line in a minetest config.''; + toConfMultiline = + name: value: + assert lib.assertMsg ( + (builtins.match UNESCAPABLE_RE value) == null + ) ''""" can't be on its own line in a minetest config.''; "${name} = \"\"\"\n${value}\n\"\"\"\n"; - toConf = values: - lib.concatStrings - (lib.mapAttrsToList - (name: value: { + toConf = + values: + lib.concatStrings ( + lib.mapAttrsToList ( + name: value: + { bool = "${name} = ${toString value}\n"; int = "${name} = ${toString value}\n"; null = ""; set = "${name} = {\n${toConf value}}\n"; string = - if (builtins.match NEEDS_MULTILINE_RE value) != null - then toConfMultiline name value - else "${name} = ${value}\n"; - }.${builtins.typeOf value}) - values); - - cfg = config.services.minetest-server; - flag = val: name: lib.optionals (val != null) ["--${name}" "${toString val}"]; - - flags = [ - "--server" - ] + if (builtins.match NEEDS_MULTILINE_RE value) != null then + toConfMultiline name value + else + "${name} = ${value}\n"; + } + .${builtins.typeOf value} + ) values + ); + + cfg = config.services.minetest-server; + flag = + val: name: + lib.optionals (val != null) [ + "--${name}" + "${toString val}" + ]; + + flags = + [ + "--server" + ] ++ ( - if cfg.configPath != null - then ["--config" cfg.configPath] - else ["--config" (builtins.toFile "minetest.conf" (toConf cfg.config))]) + if cfg.configPath != null then + [ + "--config" + cfg.configPath + ] + else + [ + "--config" + (builtins.toFile "minetest.conf" (toConf cfg.config)) + ] + ) ++ (flag cfg.gameId "gameid") ++ (flag cfg.world "world") ++ (flag cfg.logPath "logfile") @@ -51,14 +76,14 @@ in options = { services.minetest-server = { enable = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = "If enabled, starts a Minetest Server."; }; gameId = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; + type = lib.types.nullOr lib.types.str; + default = null; description = '' Id of the game to use. To list available games run `minetestserver --gameid list`. @@ -68,8 +93,8 @@ in }; world = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; + type = lib.types.nullOr lib.types.path; + default = null; description = '' Name of the world to use. To list available worlds run `minetestserver --world list`. @@ -79,8 +104,8 @@ in }; configPath = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; + type = lib.types.nullOr lib.types.path; + default = null; description = '' Path to the config to use. @@ -91,7 +116,7 @@ in config = lib.mkOption { type = lib.types.attrsOf lib.types.anything; - default = {}; + default = { }; description = '' Settings to add to the minetest config file. @@ -100,8 +125,8 @@ in }; logPath = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; + type = lib.types.nullOr lib.types.path; + default = null; description = '' Path to logfile for logging. @@ -111,8 +136,8 @@ in }; port = lib.mkOption { - type = lib.types.nullOr lib.types.int; - default = null; + type = lib.types.nullOr lib.types.int; + default = null; description = '' Port number to bind to. @@ -122,7 +147,7 @@ in extraArgs = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Additional command line flags to pass to the minetest executable. ''; @@ -132,22 +157,22 @@ in config = lib.mkIf cfg.enable { users.users.minetest = { - description = "Minetest Server Service user"; - home = "/var/lib/minetest"; - createHome = true; - uid = config.ids.uids.minetest; - group = "minetest"; + description = "Minetest Server Service user"; + home = "/var/lib/minetest"; + createHome = true; + uid = config.ids.uids.minetest; + group = "minetest"; }; users.groups.minetest.gid = config.ids.gids.minetest; systemd.services.minetest-server = { - description = "Minetest Server Service"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + description = "Minetest Server Service"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; serviceConfig.Restart = "always"; - serviceConfig.User = "minetest"; - serviceConfig.Group = "minetest"; + serviceConfig.User = "minetest"; + serviceConfig.Group = "minetest"; script = '' cd /var/lib/minetest diff --git a/nixos/modules/services/games/openarena.nix b/nixos/modules/services/games/openarena.nix index a80c427dba5fa9..d462bff805fb77 100644 --- a/nixos/modules/services/games/openarena.nix +++ b/nixos/modules/services/games/openarena.nix @@ -1,7 +1,18 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) concatStringsSep mkEnableOption mkIf mkOption types; + inherit (lib) + concatStringsSep + mkEnableOption + mkIf + mkOption + types + ; cfg = config.services.openarena; in { @@ -18,7 +29,7 @@ in extraFlags = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = "Extra flags to pass to {command}`oa_ded`"; example = [ "+set dedicated 2" diff --git a/nixos/modules/services/games/quake3-server.nix b/nixos/modules/services/games/quake3-server.nix index 7b1a50c313f4fe..d0bc521022778c 100644 --- a/nixos/modules/services/games/quake3-server.nix +++ b/nixos/modules/services/games/quake3-server.nix @@ -1,7 +1,18 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let - inherit (lib) literalMD mkEnableOption mkIf mkOption types; + inherit (lib) + literalMD + mkEnableOption + mkIf + mkOption + types + ; cfg = config.services.quake3-server; configFile = pkgs.writeText "q3ds-extra.cfg" '' @@ -28,16 +39,17 @@ let ''; }; - home = pkgs.runCommand "quake3-home" {} '' - mkdir -p $out/.q3a/baseq3 + home = pkgs.runCommand "quake3-home" { } '' + mkdir -p $out/.q3a/baseq3 - for file in ${cfg.baseq3}/*; do - ln -s $file $out/.q3a/baseq3/$(basename $file) - done + for file in ${cfg.baseq3}/*; do + ln -s $file $out/.q3a/baseq3/$(basename $file) + done - ln -s ${configFile} $out/.q3a/baseq3/nix.cfg + ln -s ${configFile} $out/.q3a/baseq3/nix.cfg ''; -in { +in +{ options = { services.quake3-server = { enable = mkEnableOption "Quake 3 dedicated server"; @@ -86,31 +98,35 @@ in { }; }; - config = let - baseq3InStore = builtins.typeOf cfg.baseq3 == "set"; - in mkIf cfg.enable { - networking.firewall.allowedUDPPorts = mkIf cfg.openFirewall [ cfg.port ]; - - systemd.services.q3ds = { - description = "Quake 3 dedicated server"; - wantedBy = [ "multi-user.target" ]; - after = [ "networking.target" ]; - - environment.HOME = if baseq3InStore then home else cfg.baseq3; - - serviceConfig = with lib; { - Restart = "always"; - DynamicUser = true; - WorkingDirectory = home; - - # It is possible to alter configuration files via RCON. To ensure reproducibility we have to prevent this - ReadOnlyPaths = if baseq3InStore then home else cfg.baseq3; - ExecStartPre = optionalString (!baseq3InStore) "+${pkgs.coreutils}/bin/cp ${configFile} ${cfg.baseq3}/.q3a/baseq3/nix.cfg"; - - ExecStart = "${cfg.package}/bin/ioq3ded +exec nix.cfg"; + config = + let + baseq3InStore = builtins.typeOf cfg.baseq3 == "set"; + in + mkIf cfg.enable { + networking.firewall.allowedUDPPorts = mkIf cfg.openFirewall [ cfg.port ]; + + systemd.services.q3ds = { + description = "Quake 3 dedicated server"; + wantedBy = [ "multi-user.target" ]; + after = [ "networking.target" ]; + + environment.HOME = if baseq3InStore then home else cfg.baseq3; + + serviceConfig = with lib; { + Restart = "always"; + DynamicUser = true; + WorkingDirectory = home; + + # It is possible to alter configuration files via RCON. To ensure reproducibility we have to prevent this + ReadOnlyPaths = if baseq3InStore then home else cfg.baseq3; + ExecStartPre = optionalString ( + !baseq3InStore + ) "+${pkgs.coreutils}/bin/cp ${configFile} ${cfg.baseq3}/.q3a/baseq3/nix.cfg"; + + ExecStart = "${cfg.package}/bin/ioq3ded +exec nix.cfg"; + }; }; }; - }; meta.maintainers = with lib.maintainers; [ f4814n ]; } diff --git a/nixos/modules/services/games/teeworlds.nix b/nixos/modules/services/games/teeworlds.nix index f1264714957315..5f69e99ddfc458 100644 --- a/nixos/modules/services/games/teeworlds.nix +++ b/nixos/modules/services/games/teeworlds.nix @@ -1,11 +1,18 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.teeworlds; register = cfg.register; bool = b: if b != null && b then "1" else "0"; optionalSetting = s: setting: lib.optionalString (s != null) "${setting} ${s}"; - lookup = attrs: key: default: if attrs ? key then attrs."${key}" else default; + lookup = + attrs: key: default: + if attrs ? key then attrs."${key}" else default; inactivePenaltyOptions = { "spectator" = "1"; @@ -19,7 +26,7 @@ let }; tournamentModeOptions = { "disable" = "0"; - "enable" = "1"; + "enable" = "1"; "restrictSpectators" = "2"; }; @@ -151,11 +158,14 @@ in extraOptions = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Extra configuration lines for the {file}`teeworlds.cfg`. See [Teeworlds Documentation](https://www.teeworlds.com/?page=docs&wiki=server_settings). ''; - example = [ "sv_map dm1" "sv_gametype dm" ]; + example = [ + "sv_map dm1" + "sv_gametype dm" + ]; }; server = { @@ -184,7 +194,11 @@ in }; inactivePenalty = lib.mkOption { - type = lib.types.enum [ "spectator" "spectator/kick" "kick" ]; + type = lib.types.enum [ + "spectator" + "spectator/kick" + "kick" + ]; example = "spectator"; default = "spectator/kick"; description = '' @@ -231,7 +245,11 @@ in }; skillLevel = lib.mkOption { - type = lib.types.enum [ "casual" "normal" "competitive" ]; + type = lib.types.enum [ + "casual" + "normal" + "competitive" + ]; default = "normal"; description = '' The skill level shown in the server browser. @@ -336,7 +354,11 @@ in }; tournamentMode = lib.mkOption { - type = lib.types.enum [ "disable" "enable" "restrictSpectators" ]; + type = lib.types.enum [ + "disable" + "enable" + "restrictSpectators" + ]; default = "disable"; description = '' Whether to enable tournament mode. In tournament mode, players join as spectators. @@ -428,7 +450,10 @@ in ProtectKernelLogs = true; ProtectKernelModules = true; ProtectKernelTunables = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; SystemCallArchitectures = "native"; }; diff --git a/nixos/modules/services/games/terraria.nix b/nixos/modules/services/games/terraria.nix index 144186dc7701fc..60aa06f01b2d75 100644 --- a/nixos/modules/services/games/terraria.nix +++ b/nixos/modules/services/games/terraria.nix @@ -1,9 +1,21 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let - cfg = config.services.terraria; - opt = options.services.terraria; - worldSizeMap = { small = 1; medium = 2; large = 3; }; - valFlag = name: val: lib.optionalString (val != null) "-${name} \"${lib.escape ["\\" "\""] (toString val)}\""; + cfg = config.services.terraria; + opt = options.services.terraria; + worldSizeMap = { + small = 1; + medium = 2; + large = 3; + }; + valFlag = + name: val: + lib.optionalString (val != null) "-${name} \"${lib.escape [ "\\" "\"" ] (toString val)}\""; boolFlag = name: val: lib.optionalString val "-${name}"; flags = [ (valFlag "port" cfg.port) @@ -44,8 +56,8 @@ in options = { services.terraria = { enable = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = '' If enabled, starts a Terraria server. The server can be connected to via `tmux -S ''${config.${opt.dataDir}}/terraria.sock attach` for administration by users who are a part of the `terraria` group (use `C-b d` shortcut to detach again). @@ -53,40 +65,40 @@ in }; port = lib.mkOption { - type = lib.types.port; - default = 7777; + type = lib.types.port; + default = 7777; description = '' Specifies the port to listen on. ''; }; maxPlayers = lib.mkOption { - type = lib.types.ints.u8; - default = 255; + type = lib.types.ints.u8; + default = 255; description = '' Sets the max number of players (between 1 and 255). ''; }; password = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; + type = lib.types.nullOr lib.types.str; + default = null; description = '' Sets the server password. Leave `null` for no password. ''; }; messageOfTheDay = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; + type = lib.types.nullOr lib.types.str; + default = null; description = '' Set the server message of the day text. ''; }; worldPath = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; + type = lib.types.nullOr lib.types.path; + default = null; description = '' The path to the world file (`.wld`) which should be loaded. If no world exists at this path, one will be created with the size @@ -95,8 +107,12 @@ in }; autoCreatedWorldSize = lib.mkOption { - type = lib.types.enum [ "small" "medium" "large" ]; - default = "medium"; + type = lib.types.enum [ + "small" + "medium" + "large" + ]; + default = "medium"; description = '' Specifies the size of the auto-created world if `worldPath` does not point to an existing world. @@ -104,22 +120,22 @@ in }; banListPath = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; + type = lib.types.nullOr lib.types.path; + default = null; description = '' The path to the ban list. ''; }; secure = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = "Adds additional cheat protection to the server."; }; noUPnP = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = "Disables automatic Universal Plug and Play."; }; @@ -130,9 +146,9 @@ in }; dataDir = lib.mkOption { - type = lib.types.str; - default = "/var/lib/terraria"; - example = "/srv/terraria"; + type = lib.types.str; + default = "/var/lib/terraria"; + example = "/srv/terraria"; description = "Path to variable state data directory for terraria."; }; }; @@ -141,10 +157,10 @@ in config = lib.mkIf cfg.enable { users.users.terraria = { description = "Terraria server service user"; - group = "terraria"; - home = cfg.dataDir; - createHome = true; - uid = config.ids.uids.terraria; + group = "terraria"; + home = cfg.dataDir; + createHome = true; + uid = config.ids.uids.terraria; }; users.groups.terraria = { @@ -152,16 +168,16 @@ in }; systemd.services.terraria = { - description = "Terraria Server Service"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + description = "Terraria Server Service"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; serviceConfig = { - User = "terraria"; + User = "terraria"; Group = "terraria"; Type = "forking"; GuessMainPID = true; - UMask = 007; + UMask = 7; ExecStart = "${tmuxCmd} new -d ${pkgs.terraria-server}/bin/TerrariaServer ${lib.concatStringsSep " " flags}"; ExecStop = "${stopScript} $MAINPID"; }; diff --git a/nixos/modules/services/games/xonotic.nix b/nixos/modules/services/games/xonotic.nix index 2b79e11838062a..736440b5123e5e 100644 --- a/nixos/modules/services/games/xonotic.nix +++ b/nixos/modules/services/games/xonotic.nix @@ -1,7 +1,8 @@ -{ config -, pkgs -, lib -, ... +{ + config, + pkgs, + lib, + ... }: let @@ -9,28 +10,28 @@ let serverCfg = pkgs.writeText "xonotic-server.cfg" ( toString cfg.prependConfig - + "\n" - + builtins.concatStringsSep "\n" ( - lib.mapAttrsToList (key: option: - let - escape = s: lib.escape [ "\"" ] s; - quote = s: "\"${s}\""; - - toValue = x: quote (escape (toString x)); - - value = (if lib.isList option then - builtins.concatStringsSep - " " - (builtins.map (x: toValue x) option) + + "\n" + + builtins.concatStringsSep "\n" ( + lib.mapAttrsToList ( + key: option: + let + escape = s: lib.escape [ "\"" ] s; + quote = s: "\"${s}\""; + + toValue = x: quote (escape (toString x)); + + value = ( + if lib.isList option then + builtins.concatStringsSep " " (builtins.map (x: toValue x) option) else toValue option - ); - in - "${key} ${value}" - ) cfg.settings - ) - + "\n" - + toString cfg.appendConfig + ); + in + "${key} ${value}" + ) cfg.settings + ) + + "\n" + + toString cfg.appendConfig ); in @@ -38,7 +39,7 @@ in options.services.xonotic = { enable = lib.mkEnableOption "Xonotic dedicated server"; - package = lib.mkPackageOption pkgs "xonotic-dedicated" {}; + package = lib.mkPackageOption pkgs "xonotic-dedicated" { }; openFirewall = lib.mkOption { type = lib.types.bool; @@ -64,17 +65,29 @@ in [0]: https://gitlab.com/xonotic/xonotic/-/blob/master/server/server.cfg ''; - default = {}; + default = { }; type = lib.types.submodule { - freeformType = with lib.types; let - scalars = oneOf [ singleLineStr int float ]; - in - attrsOf (oneOf [ scalars (nonEmptyListOf scalars) ]); + freeformType = + with lib.types; + let + scalars = oneOf [ + singleLineStr + int + float + ]; + in + attrsOf (oneOf [ + scalars + (nonEmptyListOf scalars) + ]); options.sv_public = lib.mkOption { type = lib.types.int; default = 0; - example = [ (-1) 1 ]; + example = [ + (-1) + 1 + ]; description = '' Controls whether the server will be publicly listed. ''; diff --git a/nixos/modules/services/hardware/acpid.nix b/nixos/modules/services/hardware/acpid.nix index 357f692801b4f6..0f0b1c1410620b 100644 --- a/nixos/modules/services/hardware/acpid.nix +++ b/nixos/modules/services/hardware/acpid.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.acpid; @@ -19,21 +24,21 @@ let }; }; - acpiConfDir = pkgs.runCommand "acpi-events" { preferLocalBuild = true; } - '' - mkdir -p $out - ${ - # Generate a configuration file for each event. (You can't have - # multiple events in one config file...) - let f = name: handler: - '' - fn=$out/${name} - echo "event=${handler.event}" > $fn - echo "action=${pkgs.writeShellScriptBin "${name}.sh" handler.action }/bin/${name}.sh '%e'" >> $fn - ''; - in lib.concatStringsSep "\n" (lib.mapAttrsToList f (canonicalHandlers // cfg.handlers)) - } - ''; + acpiConfDir = pkgs.runCommand "acpi-events" { preferLocalBuild = true; } '' + mkdir -p $out + ${ + # Generate a configuration file for each event. (You can't have + # multiple events in one config file...) + let + f = name: handler: '' + fn=$out/${name} + echo "event=${handler.event}" > $fn + echo "action=${pkgs.writeShellScriptBin "${name}.sh" handler.action}/bin/${name}.sh '%e'" >> $fn + ''; + in + lib.concatStringsSep "\n" (lib.mapAttrsToList f (canonicalHandlers // cfg.handlers)) + } + ''; in @@ -54,20 +59,22 @@ in }; handlers = lib.mkOption { - type = lib.types.attrsOf (lib.types.submodule { - options = { - event = lib.mkOption { - type = lib.types.str; - example = lib.literalExpression ''"button/power.*" "button/lid.*" "ac_adapter.*" "button/mute.*" "button/volumedown.*" "cd/play.*" "cd/next.*"''; - description = "Event type."; - }; - - action = lib.mkOption { - type = lib.types.lines; - description = "Shell commands to execute when the event is triggered."; + type = lib.types.attrsOf ( + lib.types.submodule { + options = { + event = lib.mkOption { + type = lib.types.str; + example = lib.literalExpression ''"button/power.*" "button/lid.*" "ac_adapter.*" "button/mute.*" "button/volumedown.*" "cd/play.*" "cd/next.*"''; + description = "Event type."; + }; + + action = lib.mkOption { + type = lib.types.lines; + description = "Shell commands to execute when the event is triggered."; + }; }; - }; - }); + } + ); description = '' Event handlers. @@ -76,7 +83,7 @@ in Handler can be a single command. ::: ''; - default = {}; + default = { }; example = { ac-power = { event = "ac_adapter/*"; @@ -120,7 +127,6 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { @@ -132,13 +138,16 @@ in wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart = lib.escapeShellArgs - ([ "${pkgs.acpid}/bin/acpid" - "--foreground" - "--netlink" - "--confdir" "${acpiConfDir}" - ] ++ lib.optional cfg.logEvents "--logevents" - ); + ExecStart = lib.escapeShellArgs ( + [ + "${pkgs.acpid}/bin/acpid" + "--foreground" + "--netlink" + "--confdir" + "${acpiConfDir}" + ] + ++ lib.optional cfg.logEvents "--logevents" + ); }; unitConfig = { ConditionVirtualization = "!systemd-nspawn"; diff --git a/nixos/modules/services/hardware/actkbd.nix b/nixos/modules/services/hardware/actkbd.nix index 1bd8c4090d3c5e..73bc586451e671 100644 --- a/nixos/modules/services/hardware/actkbd.nix +++ b/nixos/modules/services/hardware/actkbd.nix @@ -1,45 +1,65 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.actkbd; configFile = pkgs.writeText "actkbd.conf" '' - ${lib.concatMapStringsSep "\n" - ({ keys, events, attributes, command, ... }: - ''${lib.concatMapStringsSep "+" toString keys}:${lib.concatStringsSep "," events}:${lib.concatStringsSep "," attributes}:${command}'' - ) - cfg.bindings} + ${lib.concatMapStringsSep "\n" ( + { + keys, + events, + attributes, + command, + ... + }: + ''${ + lib.concatMapStringsSep "+" toString keys + }:${lib.concatStringsSep "," events}:${lib.concatStringsSep "," attributes}:${command}'' + ) cfg.bindings} ${cfg.extraConfig} ''; - bindingCfg = { ... }: { - options = { - - keys = lib.mkOption { - type = lib.types.listOf lib.types.int; - description = "List of keycodes to match."; - }; - - events = lib.mkOption { - type = lib.types.listOf (lib.types.enum ["key" "rep" "rel"]); - default = [ "key" ]; - description = "List of events to match."; - }; - - attributes = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = [ "exec" ]; - description = "List of attributes."; - }; + bindingCfg = + { ... }: + { + options = { + + keys = lib.mkOption { + type = lib.types.listOf lib.types.int; + description = "List of keycodes to match."; + }; + + events = lib.mkOption { + type = lib.types.listOf ( + lib.types.enum [ + "key" + "rep" + "rel" + ] + ); + default = [ "key" ]; + description = "List of events to match."; + }; + + attributes = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ "exec" ]; + description = "List of attributes."; + }; + + command = lib.mkOption { + type = lib.types.str; + default = ""; + description = "What to run."; + }; - command = lib.mkOption { - type = lib.types.str; - default = ""; - description = "What to run."; }; - }; - }; in @@ -70,7 +90,7 @@ in bindings = lib.mkOption { type = lib.types.listOf (lib.types.submodule bindingCfg); - default = []; + default = [ ]; example = lib.literalExpression '' [ { keys = [ 113 ]; events = [ "key" ]; command = "''${pkgs.alsa-utils}/bin/amixer -q set Master toggle"; } ] @@ -96,18 +116,19 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { - services.udev.packages = lib.singleton (pkgs.writeTextFile { - name = "actkbd-udev-rules"; - destination = "/etc/udev/rules.d/61-actkbd.rules"; - text = '' - ACTION=="add", SUBSYSTEM=="input", KERNEL=="event[0-9]*", ENV{ID_INPUT_KEY}=="1", TAG+="systemd", ENV{SYSTEMD_WANTS}+="actkbd@$env{DEVNAME}.service" - ''; - }); + services.udev.packages = lib.singleton ( + pkgs.writeTextFile { + name = "actkbd-udev-rules"; + destination = "/etc/udev/rules.d/61-actkbd.rules"; + text = '' + ACTION=="add", SUBSYSTEM=="input", KERNEL=="event[0-9]*", ENV{ID_INPUT_KEY}=="1", TAG+="systemd", ENV{SYSTEMD_WANTS}+="actkbd@$env{DEVNAME}.service" + ''; + } + ); systemd.services."actkbd@" = { enable = true; diff --git a/nixos/modules/services/hardware/amdvlk.nix b/nixos/modules/services/hardware/amdvlk.nix index e2fd91811d01f6..295f7ed64ea2f4 100644 --- a/nixos/modules/services/hardware/amdvlk.nix +++ b/nixos/modules/services/hardware/amdvlk.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.amdgpu.amdvlk; -in { +in +{ options.hardware.amdgpu.amdvlk = { enable = lib.mkEnableOption "AMDVLK Vulkan driver"; @@ -42,12 +48,11 @@ in { }; environment.etc = lib.mkIf (cfg.settings != { }) { - "amd/amdVulkanSettings.cfg".text = lib.concatStrings - (lib.mapAttrsToList - (n: v: '' - ${n},${builtins.toString v} - '') - cfg.settings); + "amd/amdVulkanSettings.cfg".text = lib.concatStrings ( + lib.mapAttrsToList (n: v: '' + ${n},${builtins.toString v} + '') cfg.settings + ); }; }; diff --git a/nixos/modules/services/hardware/argonone.nix b/nixos/modules/services/hardware/argonone.nix index b767388128c851..bdbe27a199c874 100644 --- a/nixos/modules/services/hardware/argonone.nix +++ b/nixos/modules/services/hardware/argonone.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hardware.argonone; diff --git a/nixos/modules/services/hardware/asusd.nix b/nixos/modules/services/hardware/asusd.nix index 9a3f47dae3e485..316164562b80dd 100644 --- a/nixos/modules/services/hardware/asusd.nix +++ b/nixos/modules/services/hardware/asusd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.asusd; @@ -55,9 +60,9 @@ in }; fanCurvesConfig = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - description = '' + type = lib.types.nullOr lib.types.str; + default = null; + description = '' The content of /etc/asusd/fan_curves.ron. See https://asus-linux.org/asusctl/#fan-curves. ''; @@ -79,10 +84,12 @@ in environment.etc = let - maybeConfig = name: cfg: lib.mkIf (cfg != null) { - source = pkgs.writeText name cfg; - mode = "0644"; - }; + maybeConfig = + name: cfg: + lib.mkIf (cfg != null) { + source = pkgs.writeText name cfg; + mode = "0644"; + }; in { "asusd/anime.ron" = maybeConfig "anime.ron" cfg.animeConfig; diff --git a/nixos/modules/services/hardware/auto-cpufreq.nix b/nixos/modules/services/hardware/auto-cpufreq.nix index ed24c656c54381..e79d1542f252ce 100644 --- a/nixos/modules/services/hardware/auto-cpufreq.nix +++ b/nixos/modules/services/hardware/auto-cpufreq.nix @@ -1,11 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.auto-cpufreq; cfgFilename = "auto-cpufreq.conf"; cfgFile = format.generate cfgFilename cfg.settings; - format = pkgs.formats.ini {}; -in { + format = pkgs.formats.ini { }; +in +{ options = { services.auto-cpufreq = { enable = lib.mkEnableOption "auto-cpufreq daemon"; @@ -15,9 +21,9 @@ in { Configuration for `auto-cpufreq`. The available options can be found in [the example configuration file](https://github.com/AdnanHodzic/auto-cpufreq/blob/v${pkgs.auto-cpufreq.version}/auto-cpufreq.conf-example). - ''; + ''; - default = {}; + default = { }; type = lib.types.submodule { freeformType = format.type; }; }; }; @@ -31,7 +37,10 @@ in { services.auto-cpufreq = { # Workaround for https://github.com/NixOS/nixpkgs/issues/81138 wantedBy = [ "multi-user.target" ]; - path = with pkgs; [ bash coreutils ]; + path = with pkgs; [ + bash + coreutils + ]; serviceConfig.WorkingDirectory = ""; serviceConfig.ExecStart = [ diff --git a/nixos/modules/services/hardware/auto-epp.nix b/nixos/modules/services/hardware/auto-epp.nix index 1d939a98142e0a..88f49106a258c7 100644 --- a/nixos/modules/services/hardware/auto-epp.nix +++ b/nixos/modules/services/hardware/auto-epp.nix @@ -1,16 +1,22 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.auto-epp; - format = pkgs.formats.ini {}; + format = pkgs.formats.ini { }; inherit (lib) mkOption types; -in { +in +{ options = { services.auto-epp = { enable = lib.mkEnableOption "auto-epp for amd active pstate"; - package = lib.mkPackageOption pkgs "auto-epp" {}; + package = lib.mkPackageOption pkgs "auto-epp" { }; settings = mkOption { type = types.submodule { @@ -45,7 +51,7 @@ in { }; }; }; - default = {}; + default = { }; description = '' Settings for the auto-epp application. See upstream example: @@ -65,7 +71,7 @@ in { systemd.services.auto-epp = { after = [ "multi-user.target" ]; - wantedBy = [ "multi-user.target" ]; + wantedBy = [ "multi-user.target" ]; description = "auto-epp - Automatic EPP Changer for amd-pstate-epp"; serviceConfig = { Type = "simple"; diff --git a/nixos/modules/services/hardware/bluetooth.nix b/nixos/modules/services/hardware/bluetooth.nix index 741abfba30b6fb..e90a612700cc1b 100644 --- a/nixos/modules/services/hardware/bluetooth.nix +++ b/nixos/modules/services/hardware/bluetooth.nix @@ -1,13 +1,30 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.bluetooth; package = cfg.package; inherit (lib) - mkDefault mkEnableOption mkIf mkOption mkPackageOption - mkRenamedOptionModule mkRemovedOptionModule - concatStringsSep escapeShellArgs literalExpression - optional optionals optionalAttrs recursiveUpdate types; + mkDefault + mkEnableOption + mkIf + mkOption + mkPackageOption + mkRenamedOptionModule + mkRemovedOptionModule + concatStringsSep + escapeShellArgs + literalExpression + optional + optionals + optionalAttrs + recursiveUpdate + types + ; cfgFmt = pkgs.formats.ini { }; @@ -102,63 +119,63 @@ in ###### implementation config = mkIf cfg.enable { - environment.systemPackages = [ package ] - ++ optional cfg.hsphfpd.enable pkgs.hsphfpd; - - environment.etc."bluetooth/input.conf".source = - cfgFmt.generate "input.conf" cfg.input; - environment.etc."bluetooth/network.conf".source = - cfgFmt.generate "network.conf" cfg.network; - environment.etc."bluetooth/main.conf".source = - cfgFmt.generate "main.conf" (recursiveUpdate defaults cfg.settings); + environment.systemPackages = [ package ] ++ optional cfg.hsphfpd.enable pkgs.hsphfpd; + + environment.etc."bluetooth/input.conf".source = cfgFmt.generate "input.conf" cfg.input; + environment.etc."bluetooth/network.conf".source = cfgFmt.generate "network.conf" cfg.network; + environment.etc."bluetooth/main.conf".source = cfgFmt.generate "main.conf" ( + recursiveUpdate defaults cfg.settings + ); services.udev.packages = [ package ]; - services.dbus.packages = [ package ] - ++ optional cfg.hsphfpd.enable pkgs.hsphfpd; + services.dbus.packages = [ package ] ++ optional cfg.hsphfpd.enable pkgs.hsphfpd; systemd.packages = [ package ]; - systemd.services = { - bluetooth = - let - # `man bluetoothd` will refer to main.conf in the nix store but bluez - # will in fact load the configuration file at /etc/bluetooth/main.conf - # so force it here to avoid any ambiguity and things suddenly breaking - # if/when the bluez derivation is changed. - args = [ "-f" "/etc/bluetooth/main.conf" ] - ++ optional hasDisabledPlugins - "--noplugin=${concatStringsSep "," cfg.disabledPlugins}"; - in - { + systemd.services = + { + bluetooth = + let + # `man bluetoothd` will refer to main.conf in the nix store but bluez + # will in fact load the configuration file at /etc/bluetooth/main.conf + # so force it here to avoid any ambiguity and things suddenly breaking + # if/when the bluez derivation is changed. + args = [ + "-f" + "/etc/bluetooth/main.conf" + ] ++ optional hasDisabledPlugins "--noplugin=${concatStringsSep "," cfg.disabledPlugins}"; + in + { + wantedBy = [ "bluetooth.target" ]; + aliases = [ "dbus-org.bluez.service" ]; + serviceConfig.ExecStart = [ + "" + "${package}/libexec/bluetooth/bluetoothd ${escapeShellArgs args}" + ]; + # restarting can leave people without a mouse/keyboard + unitConfig.X-RestartIfChanged = false; + }; + } + // (optionalAttrs cfg.hsphfpd.enable { + hsphfpd = { + after = [ "bluetooth.service" ]; + requires = [ "bluetooth.service" ]; wantedBy = [ "bluetooth.target" ]; - aliases = [ "dbus-org.bluez.service" ]; - serviceConfig.ExecStart = [ - "" - "${package}/libexec/bluetooth/bluetoothd ${escapeShellArgs args}" - ]; - # restarting can leave people without a mouse/keyboard - unitConfig.X-RestartIfChanged = false; - }; - } - // (optionalAttrs cfg.hsphfpd.enable { - hsphfpd = { - after = [ "bluetooth.service" ]; - requires = [ "bluetooth.service" ]; - wantedBy = [ "bluetooth.target" ]; - - description = "A prototype implementation used for connecting HSP/HFP Bluetooth devices"; - serviceConfig.ExecStart = "${pkgs.hsphfpd}/bin/hsphfpd.pl"; - }; - }); - systemd.user.services = { - obex.aliases = [ "dbus-org.bluez.obex.service" ]; - } - // optionalAttrs cfg.hsphfpd.enable { - telephony_client = { - wantedBy = [ "default.target" ]; - - description = "telephony_client for hsphfpd"; - serviceConfig.ExecStart = "${pkgs.hsphfpd}/bin/telephony_client.pl"; + description = "A prototype implementation used for connecting HSP/HFP Bluetooth devices"; + serviceConfig.ExecStart = "${pkgs.hsphfpd}/bin/hsphfpd.pl"; + }; + }); + + systemd.user.services = + { + obex.aliases = [ "dbus-org.bluez.obex.service" ]; + } + // optionalAttrs cfg.hsphfpd.enable { + telephony_client = { + wantedBy = [ "default.target" ]; + + description = "telephony_client for hsphfpd"; + serviceConfig.ExecStart = "${pkgs.hsphfpd}/bin/telephony_client.pl"; + }; }; - }; }; } diff --git a/nixos/modules/services/hardware/bolt.nix b/nixos/modules/services/hardware/bolt.nix index f005d24e088356..3c024b02456589 100644 --- a/nixos/modules/services/hardware/bolt.nix +++ b/nixos/modules/services/hardware/bolt.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hardware.bolt; in diff --git a/nixos/modules/services/hardware/brltty.nix b/nixos/modules/services/hardware/brltty.nix index c4ded927345d1b..95245d584d1804 100644 --- a/nixos/modules/services/hardware/brltty.nix +++ b/nixos/modules/services/hardware/brltty.nix @@ -1,10 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.brltty; targets = [ - "default.target" "multi-user.target" - "rescue.target" "emergency.target" + "default.target" + "multi-user.target" + "rescue.target" + "emergency.target" ]; genApiKey = pkgs.writers.writeDash "generate-brlapi-key" '' @@ -15,7 +22,8 @@ let fi ''; -in { +in +{ options = { @@ -38,8 +46,9 @@ in { brlapi = { }; }; - systemd.services."brltty@".serviceConfig = - { ExecStartPre = "!${genApiKey}"; }; + systemd.services."brltty@".serviceConfig = { + ExecStartPre = "!${genApiKey}"; + }; # Install all upstream-provided files systemd.packages = [ pkgs.brltty ]; diff --git a/nixos/modules/services/hardware/ddccontrol.nix b/nixos/modules/services/hardware/ddccontrol.nix index f0b5a9c8196009..b9ad851333a4e2 100644 --- a/nixos/modules/services/hardware/ddccontrol.nix +++ b/nixos/modules/services/hardware/ddccontrol.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let diff --git a/nixos/modules/services/hardware/display.nix b/nixos/modules/services/hardware/display.nix index 3b3118f132e92a..9aeb9d8fab0952 100644 --- a/nixos/modules/services/hardware/display.nix +++ b/nixos/modules/services/hardware/display.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.display; in @@ -38,16 +43,20 @@ in ''') ] ''; - apply = list: - if list == [ ] then null else - (pkgs.buildEnv { - name = "firmware-edid"; - paths = list; - pathsToLink = [ "/lib/firmware/edid" ]; - ignoreCollisions = true; - }) // { - compressFirmware = false; - }; + apply = + list: + if list == [ ] then + null + else + (pkgs.buildEnv { + name = "firmware-edid"; + paths = list; + pathsToLink = [ "/lib/firmware/edid" ]; + ignoreCollisions = true; + }) + // { + compressFirmware = false; + }; }; hardware.display.edid.linuxhw = lib.mkOption { @@ -79,9 +88,9 @@ in PG278Q_2014 = [ "PG278Q" "2014" ]; } ''; - apply = displays: - if displays == { } then null else - pkgs.linuxhw-edid-fetcher.override { inherit displays; }; + apply = + displays: + if displays == { } then null else pkgs.linuxhw-edid-fetcher.override { inherit displays; }; }; hardware.display.edid.modelines = lib.mkOption { @@ -100,53 +109,60 @@ in "U2711_60" = " 241.50 2560 2600 2632 2720 1440 1443 1448 1481 -hsync +vsync"; } ''; - apply = modelines: - if modelines == { } then null else - pkgs.edid-generator.overrideAttrs { - clean = true; - passthru.config = modelines; - modelines = lib.trivial.pipe modelines [ - (lib.mapAttrsToList (name: value: - lib.throwIfNot (builtins.stringLength name <= 12) "Modeline name must be 12 characters or less" - ''Modeline "${name}" ${value}'' - )) - (builtins.map (line: "${line}\n")) - (lib.strings.concatStringsSep "") - ]; - }; + apply = + modelines: + if modelines == { } then + null + else + pkgs.edid-generator.overrideAttrs { + clean = true; + passthru.config = modelines; + modelines = lib.trivial.pipe modelines [ + (lib.mapAttrsToList ( + name: value: + lib.throwIfNot ( + builtins.stringLength name <= 12 + ) "Modeline name must be 12 characters or less" ''Modeline "${name}" ${value}'' + )) + (builtins.map (line: "${line}\n")) + (lib.strings.concatStringsSep "") + ]; + }; }; hardware.display.outputs = lib.mkOption { - type = lib.types.attrsOf (lib.types.submodule ({ - options = { - edid = lib.mkOption { - type = with lib.types; nullOr str; - default = null; - description = '' - An EDID filename to be used for configured display, as in `edid/`. - See for more information: - - `hardware.display.edid.packages` - - https://wiki.archlinux.org/title/Kernel_mode_setting#Forcing_modes_and_EDID - ''; - }; - mode = lib.mkOption { - type = with lib.types; nullOr str; - default = null; - description = '' - A `video` kernel parameter (framebuffer mode) configuration for the specific output: + type = lib.types.attrsOf ( + lib.types.submodule ({ + options = { + edid = lib.mkOption { + type = with lib.types; nullOr str; + default = null; + description = '' + An EDID filename to be used for configured display, as in `edid/`. + See for more information: + - `hardware.display.edid.packages` + - https://wiki.archlinux.org/title/Kernel_mode_setting#Forcing_modes_and_EDID + ''; + }; + mode = lib.mkOption { + type = with lib.types; nullOr str; + default = null; + description = '' + A `video` kernel parameter (framebuffer mode) configuration for the specific output: - x[M][R][-][@][i][m][eDd] + x[M][R][-][@][i][m][eDd] - See for more information: - - https://docs.kernel.org/fb/modedb.html - - https://wiki.archlinux.org/title/Kernel_mode_setting#Forcing_modes - ''; - example = lib.literalExpression '' - "e" - ''; + See for more information: + - https://docs.kernel.org/fb/modedb.html + - https://wiki.archlinux.org/title/Kernel_mode_setting#Forcing_modes + ''; + example = lib.literalExpression '' + "e" + ''; + }; }; - }; - })); + }) + ); description = '' Hardware/kernel-level configuration of specific outputs. ''; @@ -174,15 +190,13 @@ in (lib.attrsets.filterAttrs (_: spec: spec.mode != null)) (lib.mapAttrsToList (output: spec: "video=${output}:${spec.mode}")) ] - ++ # selecting EDID for displays - lib.trivial.pipe cfg.outputs [ + ++ lib.trivial.pipe cfg.outputs [ (lib.attrsets.filterAttrs (_: spec: spec.edid != null)) (lib.mapAttrsToList (output: spec: "${output}:edid/${spec.edid}")) (builtins.concatStringsSep ",") (p: lib.optional (p != "") "drm.edid_firmware=${p}") - ] - ; + ]; } (lib.mkIf (cfg.edid.packages != null) { # services.udev implements hardware.firmware option diff --git a/nixos/modules/services/hardware/fancontrol.nix b/nixos/modules/services/hardware/fancontrol.nix index 06c217b4d3c9b7..dd3cd54cc31c11 100644 --- a/nixos/modules/services/hardware/fancontrol.nix +++ b/nixos/modules/services/hardware/fancontrol.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.fancontrol; configFile = pkgs.writeText "fancontrol.conf" cfg.config; diff --git a/nixos/modules/services/hardware/freefall.nix b/nixos/modules/services/hardware/freefall.nix index fe017bb17f7e4a..53756531412b6d 100644 --- a/nixos/modules/services/hardware/freefall.nix +++ b/nixos/modules/services/hardware/freefall.nix @@ -1,9 +1,16 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.services.freefall; -in { +in +{ options.services.freefall = { @@ -27,28 +34,33 @@ in { }; - config = let - - mkService = dev: - assert dev != ""; - let dev' = utils.escapeSystemdPath dev; in - lib.nameValuePair "freefall-${dev'}" { - description = "Free-fall protection for ${dev}"; - after = [ "${dev'}.device" ]; - wantedBy = [ "${dev'}.device" ]; - serviceConfig = { - ExecStart = "${cfg.package}/bin/freefall ${dev}"; - Restart = "on-failure"; - Type = "forking"; + config = + let + + mkService = + dev: + assert dev != ""; + let + dev' = utils.escapeSystemdPath dev; + in + lib.nameValuePair "freefall-${dev'}" { + description = "Free-fall protection for ${dev}"; + after = [ "${dev'}.device" ]; + wantedBy = [ "${dev'}.device" ]; + serviceConfig = { + ExecStart = "${cfg.package}/bin/freefall ${dev}"; + Restart = "on-failure"; + Type = "forking"; + }; }; - }; - in lib.mkIf cfg.enable { + in + lib.mkIf cfg.enable { - environment.systemPackages = [ cfg.package ]; + environment.systemPackages = [ cfg.package ]; - systemd.services = builtins.listToAttrs (map mkService cfg.devices); + systemd.services = builtins.listToAttrs (map mkService cfg.devices); - }; + }; } diff --git a/nixos/modules/services/hardware/fwupd.nix b/nixos/modules/services/hardware/fwupd.nix index 09a55ad280527e..1c059bf39e641a 100644 --- a/nixos/modules/services/hardware/fwupd.nix +++ b/nixos/modules/services/hardware/fwupd.nix @@ -1,20 +1,28 @@ # fwupd daemon. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.fwupd; format = pkgs.formats.ini { - listToValue = l: lib.concatStringsSep ";" (map (s: lib.generators.mkValueStringDefault {} s) l); - mkKeyValue = lib.generators.mkKeyValueDefault {} "="; + listToValue = l: lib.concatStringsSep ";" (map (s: lib.generators.mkValueStringDefault { } s) l); + mkKeyValue = lib.generators.mkKeyValueDefault { } "="; }; customEtc = { "fwupd/fwupd.conf" = { - source = format.generate "fwupd.conf" ({ - fwupd = cfg.daemonSettings; - } // lib.optionalAttrs (lib.length (lib.attrNames cfg.uefiCapsuleSettings) != 0) { - uefi_capsule = cfg.uefiCapsuleSettings; - }); + source = format.generate "fwupd.conf" ( + { + fwupd = cfg.daemonSettings; + } + // lib.optionalAttrs (lib.length (lib.attrNames cfg.uefiCapsuleSettings) != 0) { + uefi_capsule = cfg.uefiCapsuleSettings; + } + ); # fwupd tries to chmod the file if it doesn't have the right permissions mode = "0640"; }; @@ -23,36 +31,39 @@ let originalEtc = let mkEtcFile = n: lib.nameValuePair n { source = "${cfg.package}/etc/${n}"; }; - in lib.listToAttrs (map mkEtcFile cfg.package.filesInstalledToEtc); + in + lib.listToAttrs (map mkEtcFile cfg.package.filesInstalledToEtc); extraTrustedKeys = let mkName = p: "pki/fwupd/${baseNameOf (toString p)}"; mkEtcFile = p: lib.nameValuePair (mkName p) { source = p; }; - in lib.listToAttrs (map mkEtcFile cfg.extraTrustedKeys); + in + lib.listToAttrs (map mkEtcFile cfg.extraTrustedKeys); enableRemote = base: remote: { "fwupd/remotes.d/${remote}.conf" = { - source = pkgs.runCommand "${remote}-enabled.conf" {} '' + source = pkgs.runCommand "${remote}-enabled.conf" { } '' sed "s,^Enabled=false,Enabled=true," \ "${base}/etc/fwupd/remotes.d/${remote}.conf" > "$out" ''; }; }; - remotes = (lib.foldl' - (configFiles: remote: configFiles // (enableRemote cfg.package remote)) - {} - cfg.extraRemotes - ) // ( - # We cannot include the file in $out and rely on filesInstalledToEtc - # to install it because it would create a cyclic dependency between - # the outputs. We also need to enable the remote, - # which should not be done by default. - lib.optionalAttrs - (cfg.daemonSettings.TestDevices or false) - (enableRemote cfg.package.installedTests "fwupd-tests") - ); - -in { + remotes = + (lib.foldl' ( + configFiles: remote: configFiles // (enableRemote cfg.package remote) + ) { } cfg.extraRemotes) + // ( + # We cannot include the file in $out and rely on filesInstalledToEtc + # to install it because it would create a cyclic dependency between + # the outputs. We also need to enable the remote, + # which should not be done by default. + lib.optionalAttrs (cfg.daemonSettings.TestDevices or false) ( + enableRemote cfg.package.installedTests "fwupd-tests" + ) + ); + +in +{ ###### interface options = { @@ -68,7 +79,7 @@ in { extraTrustedKeys = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; example = lib.literalExpression "[ /etc/nixos/fwupd/myfirmware.pem ]"; description = '' Installing a public key allows firmware signed with a matching private key to be recognized as trusted, which may require less authentication to install than for untrusted files. By default trusted firmware can be upgraded (but not downgraded) without the user or administrator password. Only very few keys are installed by default. @@ -77,7 +88,7 @@ in { extraRemotes = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; example = [ "lvfs-testing" ]; description = '' Enables extra remotes in fwupd. See `/etc/fwupd/remotes.d`. @@ -92,7 +103,7 @@ in { options = { DisabledDevices = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = [ "2082b5e0-7a64-478a-b1b2-e3404fab6dad" ]; description = '' List of device GUIDs to be disabled. @@ -101,7 +112,7 @@ in { DisabledPlugins = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = [ "udev" ]; description = '' List of plugins to be disabled. @@ -129,7 +140,7 @@ in { }; }; }; - default = {}; + default = { }; description = '' Configurations for the fwupd daemon. ''; @@ -139,7 +150,7 @@ in { type = lib.types.submodule { freeformType = format.type.nestedTypes.elemType; }; - default = {}; + default = { }; description = '' UEFI capsule configurations for the fwupd daemon. ''; @@ -148,11 +159,25 @@ in { }; imports = [ - (lib.mkRenamedOptionModule [ "services" "fwupd" "blacklistDevices"] [ "services" "fwupd" "daemonSettings" "DisabledDevices" ]) - (lib.mkRenamedOptionModule [ "services" "fwupd" "blacklistPlugins"] [ "services" "fwupd" "daemonSettings" "DisabledPlugins" ]) - (lib.mkRenamedOptionModule [ "services" "fwupd" "disabledDevices" ] [ "services" "fwupd" "daemonSettings" "DisabledDevices" ]) - (lib.mkRenamedOptionModule [ "services" "fwupd" "disabledPlugins" ] [ "services" "fwupd" "daemonSettings" "DisabledPlugins" ]) - (lib.mkRemovedOptionModule [ "services" "fwupd" "enableTestRemote" ] "This option was removed after being removed upstream. It only provided a method for testing fwupd functionality, and should not have been exposed for use outside of nix tests.") + (lib.mkRenamedOptionModule + [ "services" "fwupd" "blacklistDevices" ] + [ "services" "fwupd" "daemonSettings" "DisabledDevices" ] + ) + (lib.mkRenamedOptionModule + [ "services" "fwupd" "blacklistPlugins" ] + [ "services" "fwupd" "daemonSettings" "DisabledPlugins" ] + ) + (lib.mkRenamedOptionModule + [ "services" "fwupd" "disabledDevices" ] + [ "services" "fwupd" "daemonSettings" "DisabledDevices" ] + ) + (lib.mkRenamedOptionModule + [ "services" "fwupd" "disabledPlugins" ] + [ "services" "fwupd" "daemonSettings" "DisabledPlugins" ] + ) + (lib.mkRemovedOptionModule [ "services" "fwupd" "enableTestRemote" ] + "This option was removed after being removed upstream. It only provided a method for testing fwupd functionality, and should not have been exposed for use outside of nix tests." + ) ]; ###### implementation @@ -192,7 +217,7 @@ in { isSystemUser = true; group = "fwupd-refresh"; }; - users.groups.fwupd-refresh = {}; + users.groups.fwupd-refresh = { }; security.polkit.enable = true; }; diff --git a/nixos/modules/services/hardware/handheld-daemon.nix b/nixos/modules/services/hardware/handheld-daemon.nix index c1a628e1697d3e..4ea5eb79593fd0 100644 --- a/nixos/modules/services/hardware/handheld-daemon.nix +++ b/nixos/modules/services/hardware/handheld-daemon.nix @@ -1,9 +1,11 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: -with lib; let +with lib; +let cfg = config.services.handheld-daemon; in { @@ -45,7 +47,7 @@ in ]; serviceConfig = { - ExecStart = "${ lib.getExe cfg.package } --user ${ cfg.user }"; + ExecStart = "${lib.getExe cfg.package} --user ${cfg.user}"; Nice = "-12"; Restart = "on-failure"; RestartSec = "10"; diff --git a/nixos/modules/services/hardware/hddfancontrol.nix b/nixos/modules/services/hardware/hddfancontrol.nix index e8cab0e22befdc..8705109dd03596 100644 --- a/nixos/modules/services/hardware/hddfancontrol.nix +++ b/nixos/modules/services/hardware/hddfancontrol.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hddfancontrol; @@ -12,20 +17,20 @@ in services.hddfancontrol.disks = lib.mkOption { type = with types; listOf path; - default = []; + default = [ ]; description = '' Drive(s) to get temperature from ''; - example = ["/dev/sda"]; + example = [ "/dev/sda" ]; }; services.hddfancontrol.pwmPaths = lib.mkOption { type = with types; listOf path; - default = []; + default = [ ]; description = '' PWM filepath(s) to control fan speed (under /sys) ''; - example = ["/sys/class/hwmon/hwmon2/pwm1"]; + example = [ "/sys/class/hwmon/hwmon2/pwm1" ]; }; services.hddfancontrol.smartctl = lib.mkOption { @@ -38,24 +43,31 @@ in services.hddfancontrol.extraArgs = lib.mkOption { type = with types; listOf str; - default = []; + default = [ ]; description = '' Extra commandline arguments for hddfancontrol ''; - example = ["--pwm-start-value=32" - "--pwm-stop-value=0" - "--spin-down-time=900"]; + example = [ + "--pwm-start-value=32" + "--pwm-stop-value=0" + "--spin-down-time=900" + ]; }; }; config = lib.mkIf cfg.enable ( - let args = lib.concatLists [ - ["-d"] cfg.disks - ["-p"] cfg.pwmPaths - (lib.optional cfg.smartctl "--smartctl") - cfg.extraArgs - ]; in { - systemd.packages = [pkgs.hddfancontrol]; + let + args = lib.concatLists [ + [ "-d" ] + cfg.disks + [ "-p" ] + cfg.pwmPaths + (lib.optional cfg.smartctl "--smartctl") + cfg.extraArgs + ]; + in + { + systemd.packages = [ pkgs.hddfancontrol ]; systemd.services.hddfancontrol = { wantedBy = [ "multi-user.target" ]; diff --git a/nixos/modules/services/hardware/illum.nix b/nixos/modules/services/hardware/illum.nix index 61ab24a5de7c72..c36143a9975ca2 100644 --- a/nixos/modules/services/hardware/illum.nix +++ b/nixos/modules/services/hardware/illum.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.illum; -in { +in +{ options = { diff --git a/nixos/modules/services/hardware/interception-tools.nix b/nixos/modules/services/hardware/interception-tools.nix index d60e7ca5954786..9bba517ecff8db 100644 --- a/nixos/modules/services/hardware/interception-tools.nix +++ b/nixos/modules/services/hardware/interception-tools.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.interception-tools; -in { +in +{ options.services.interception-tools = { enable = lib.mkOption { type = lib.types.bool; @@ -43,13 +49,19 @@ in { config = lib.mkIf cfg.enable { systemd.services.interception-tools = { description = "Interception tools"; - path = [ pkgs.bash pkgs.interception-tools ] ++ cfg.plugins; + path = [ + pkgs.bash + pkgs.interception-tools + ] ++ cfg.plugins; serviceConfig = { ExecStart = '' ${pkgs.interception-tools}/bin/udevmon -c \ - ${if builtins.typeOf cfg.udevmonConfig == "path" - then cfg.udevmonConfig - else pkgs.writeText "udevmon.yaml" cfg.udevmonConfig} + ${ + if builtins.typeOf cfg.udevmonConfig == "path" then + cfg.udevmonConfig + else + pkgs.writeText "udevmon.yaml" cfg.udevmonConfig + } ''; Nice = -20; }; diff --git a/nixos/modules/services/hardware/iptsd.nix b/nixos/modules/services/hardware/iptsd.nix index bfd4b35227923d..cecf88ec33d8d2 100644 --- a/nixos/modules/services/hardware/iptsd.nix +++ b/nixos/modules/services/hardware/iptsd.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.iptsd; format = pkgs.formats.ini { }; configFile = format.generate "iptsd.conf" cfg.config; -in { +in +{ options.services.iptsd = { enable = lib.mkEnableOption "the userspace daemon for Intel Precise Touch & Stylus"; diff --git a/nixos/modules/services/hardware/irqbalance.nix b/nixos/modules/services/hardware/irqbalance.nix index 42878725cca3ae..56a5db930d068a 100644 --- a/nixos/modules/services/hardware/irqbalance.nix +++ b/nixos/modules/services/hardware/irqbalance.nix @@ -1,5 +1,10 @@ # -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.irqbalance; @@ -12,7 +17,7 @@ in environment.systemPackages = [ pkgs.irqbalance ]; - systemd.services.irqbalance.wantedBy = ["multi-user.target"]; + systemd.services.irqbalance.wantedBy = [ "multi-user.target" ]; systemd.packages = [ pkgs.irqbalance ]; diff --git a/nixos/modules/services/hardware/joycond.nix b/nixos/modules/services/hardware/joycond.nix index b6d2b8328af710..d380036047415a 100644 --- a/nixos/modules/services/hardware/joycond.nix +++ b/nixos/modules/services/hardware/joycond.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.joycond; in diff --git a/nixos/modules/services/hardware/kanata.nix b/nixos/modules/services/hardware/kanata.nix index 7557b1ae55f907..08829cdf0351e1 100644 --- a/nixos/modules/services/hardware/kanata.nix +++ b/nixos/modules/services/hardware/kanata.nix @@ -1,84 +1,92 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.services.kanata; upstreamDoc = "See [the upstream documentation](https://github.com/jtroo/kanata/blob/main/docs/config.adoc) and [example config files](https://github.com/jtroo/kanata/tree/main/cfg_samples) for more information."; - keyboard = { name, config, ... }: { - options = { - devices = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = [ ]; - example = [ "/dev/input/by-id/usb-0000_0000-event-kbd" ]; - description = '' - Paths to keyboard devices. - - An empty list, the default value, lets kanata detect which - input devices are keyboards and intercept them all. - ''; - }; - config = lib.mkOption { - type = lib.types.lines; - example = '' - (defsrc - caps) - - (deflayermap (default-layer) - ;; tap caps lock as caps lock, hold caps lock as left control - caps (tap-hold 100 100 caps lctl)) - ''; - description = '' - Configuration other than `defcfg`. - - ${upstreamDoc} - ''; - }; - extraDefCfg = lib.mkOption { - type = lib.types.lines; - default = ""; - example = "danger-enable-cmd yes"; - description = '' - Configuration of `defcfg` other than `linux-dev` (generated - from the devices option) and - `linux-continue-if-no-devs-found` (hardcoded to be yes). - - ${upstreamDoc} - ''; - }; - configFile = lib.mkOption { - type = lib.types.path; - default = mkConfig name config; - defaultText = - "A config file generated by values from other kanata module options."; - description = '' - The config file. - - By default, it is generated by values from other kanata - module options. - - You can also set it to your own full config file which - overrides all other kanata module options. ${upstreamDoc} - ''; - }; - extraArgs = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = [ ]; - description = "Extra command line arguments passed to kanata."; - }; - port = lib.mkOption { - type = lib.types.nullOr lib.types.port; - default = null; - example = 6666; - description = '' - Port to run the TCP server on. `null` will not run the server. - ''; + keyboard = + { name, config, ... }: + { + options = { + devices = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + example = [ "/dev/input/by-id/usb-0000_0000-event-kbd" ]; + description = '' + Paths to keyboard devices. + + An empty list, the default value, lets kanata detect which + input devices are keyboards and intercept them all. + ''; + }; + config = lib.mkOption { + type = lib.types.lines; + example = '' + (defsrc + caps) + + (deflayermap (default-layer) + ;; tap caps lock as caps lock, hold caps lock as left control + caps (tap-hold 100 100 caps lctl)) + ''; + description = '' + Configuration other than `defcfg`. + + ${upstreamDoc} + ''; + }; + extraDefCfg = lib.mkOption { + type = lib.types.lines; + default = ""; + example = "danger-enable-cmd yes"; + description = '' + Configuration of `defcfg` other than `linux-dev` (generated + from the devices option) and + `linux-continue-if-no-devs-found` (hardcoded to be yes). + + ${upstreamDoc} + ''; + }; + configFile = lib.mkOption { + type = lib.types.path; + default = mkConfig name config; + defaultText = "A config file generated by values from other kanata module options."; + description = '' + The config file. + + By default, it is generated by values from other kanata + module options. + + You can also set it to your own full config file which + overrides all other kanata module options. ${upstreamDoc} + ''; + }; + extraArgs = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + description = "Extra command line arguments passed to kanata."; + }; + port = lib.mkOption { + type = lib.types.nullOr lib.types.port; + default = null; + example = 6666; + description = '' + Port to run the TCP server on. `null` will not run the server. + ''; + }; }; }; - }; mkName = name: "kanata-${name}"; - mkDevices = devices: + mkDevices = + devices: let devicesString = lib.pipe devices [ (map (device: "\"" + device + "\"")) @@ -87,78 +95,82 @@ let in lib.optionalString ((lib.length devices) > 0) "linux-dev (${devicesString})"; - mkConfig = name: keyboard: pkgs.writeTextFile { - name = "${mkName name}-config.kdb"; - text = '' - (defcfg - ${keyboard.extraDefCfg} - ${mkDevices keyboard.devices} - linux-continue-if-no-devs-found yes) - - ${keyboard.config} - ''; - # Only the config file generated by this module is checked. A - # user-provided one is not checked because it may not be available - # at build time. I think this is a good balance between module - # complexity and functionality. - checkPhase = '' - ${lib.getExe cfg.package} --cfg "$target" --check --debug - ''; - }; - - mkService = name: keyboard: lib.nameValuePair (mkName name) { - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - Type = "notify"; - ExecStart = '' - ${lib.getExe cfg.package} \ - --cfg ${keyboard.configFile} \ - --symlink-path ''${RUNTIME_DIRECTORY}/${name} \ - ${lib.optionalString (keyboard.port != null) "--port ${toString keyboard.port}"} \ - ${utils.escapeSystemdExecArgs keyboard.extraArgs} + mkConfig = + name: keyboard: + pkgs.writeTextFile { + name = "${mkName name}-config.kdb"; + text = '' + (defcfg + ${keyboard.extraDefCfg} + ${mkDevices keyboard.devices} + linux-continue-if-no-devs-found yes) + + ${keyboard.config} + ''; + # Only the config file generated by this module is checked. A + # user-provided one is not checked because it may not be available + # at build time. I think this is a good balance between module + # complexity and functionality. + checkPhase = '' + ${lib.getExe cfg.package} --cfg "$target" --check --debug ''; + }; - DynamicUser = true; - RuntimeDirectory = mkName name; - SupplementaryGroups = with config.users.groups; [ - input.name - uinput.name - ]; + mkService = + name: keyboard: + lib.nameValuePair (mkName name) { + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + Type = "notify"; + ExecStart = '' + ${lib.getExe cfg.package} \ + --cfg ${keyboard.configFile} \ + --symlink-path ''${RUNTIME_DIRECTORY}/${name} \ + ${lib.optionalString (keyboard.port != null) "--port ${toString keyboard.port}"} \ + ${utils.escapeSystemdExecArgs keyboard.extraArgs} + ''; - # hardening - DeviceAllow = [ - "/dev/uinput rw" - "char-input r" - ]; - CapabilityBoundingSet = [ "" ]; - DevicePolicy = "closed"; - IPAddressAllow = lib.optional (keyboard.port != null) "localhost"; - IPAddressDeny = [ "any" ]; - LockPersonality = true; - MemoryDenyWriteExecute = true; - PrivateNetwork = keyboard.port == null; - PrivateUsers = true; - ProcSubset = "pid"; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - RestrictAddressFamilies = [ "AF_UNIX" ] ++ lib.optional (keyboard.port != null) "AF_INET"; - RestrictNamespaces = true; - RestrictRealtime = true; - SystemCallArchitectures = [ "native" ]; - SystemCallFilter = [ - "@system-service" - "~@privileged" - "~@resources" - ]; - UMask = "0077"; + DynamicUser = true; + RuntimeDirectory = mkName name; + SupplementaryGroups = with config.users.groups; [ + input.name + uinput.name + ]; + + # hardening + DeviceAllow = [ + "/dev/uinput rw" + "char-input r" + ]; + CapabilityBoundingSet = [ "" ]; + DevicePolicy = "closed"; + IPAddressAllow = lib.optional (keyboard.port != null) "localhost"; + IPAddressDeny = [ "any" ]; + LockPersonality = true; + MemoryDenyWriteExecute = true; + PrivateNetwork = keyboard.port == null; + PrivateUsers = true; + ProcSubset = "pid"; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + RestrictAddressFamilies = [ "AF_UNIX" ] ++ lib.optional (keyboard.port != null) "AF_INET"; + RestrictNamespaces = true; + RestrictRealtime = true; + SystemCallArchitectures = [ "native" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "~@resources" + ]; + UMask = "0077"; + }; }; - }; in { options.services.kanata = { @@ -186,7 +198,8 @@ in existEmptyDevices = lib.length (lib.attrNames keyboardsWithEmptyDevices) > 0; moreThanOneKeyboard = lib.length (lib.attrNames cfg.keyboards) > 1; in - lib.optional (existEmptyDevices && moreThanOneKeyboard) "One device can only be intercepted by one kanata instance. Setting services.kanata.keyboards.${lib.head (lib.attrNames keyboardsWithEmptyDevices)}.devices = [ ] and using more than one services.kanata.keyboards may cause a race condition."; + lib.optional (existEmptyDevices && moreThanOneKeyboard) + "One device can only be intercepted by one kanata instance. Setting services.kanata.keyboards.${lib.head (lib.attrNames keyboardsWithEmptyDevices)}.devices = [ ] and using more than one services.kanata.keyboards may cause a race condition."; hardware.uinput.enable = true; diff --git a/nixos/modules/services/hardware/keyd.nix b/nixos/modules/services/hardware/keyd.nix index 92b62fe2e9775e..795a640b791e3f 100644 --- a/nixos/modules/services/hardware/keyd.nix +++ b/nixos/modules/services/hardware/keyd.nix @@ -1,63 +1,75 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.keyd; - keyboardOptions = { ... }: { - options = { - ids = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = [ "*" ]; - example = [ "*" "-0123:0456" ]; - description = '' - Device identifiers, as shown by {manpage}`keyd(1)`. - ''; - }; + keyboardOptions = + { ... }: + { + options = { + ids = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ "*" ]; + example = [ + "*" + "-0123:0456" + ]; + description = '' + Device identifiers, as shown by {manpage}`keyd(1)`. + ''; + }; - settings = lib.mkOption { - type = (pkgs.formats.ini { }).type; - default = { }; - example = { - main = { - capslock = "overload(control, esc)"; - rightalt = "layer(rightalt)"; - }; + settings = lib.mkOption { + type = (pkgs.formats.ini { }).type; + default = { }; + example = { + main = { + capslock = "overload(control, esc)"; + rightalt = "layer(rightalt)"; + }; - rightalt = { - j = "down"; - k = "up"; - h = "left"; - l = "right"; + rightalt = { + j = "down"; + k = "up"; + h = "left"; + l = "right"; + }; }; + description = '' + Configuration, except `ids` section, that is written to {file}`/etc/keyd/.conf`. + Appropriate names can be used to write non-alpha keys, for example "equal" instead of "=" sign (see ). + See how to configure. + ''; }; - description = '' - Configuration, except `ids` section, that is written to {file}`/etc/keyd/.conf`. - Appropriate names can be used to write non-alpha keys, for example "equal" instead of "=" sign (see ). - See how to configure. - ''; - }; - extraConfig = lib.mkOption { - type = lib.types.lines; - default = ""; - example = '' - [control+shift] - h = left - ''; - description = '' - Extra configuration that is appended to the end of the file. - **Do not** write `ids` section here, use a separate option for it. - You can use this option to define compound layers that must always be defined after the layer they are comprised. - ''; + extraConfig = lib.mkOption { + type = lib.types.lines; + default = ""; + example = '' + [control+shift] + h = left + ''; + description = '' + Extra configuration that is appended to the end of the file. + **Do not** write `ids` section here, use a separate option for it. + You can use this option to define compound layers that must always be defined after the layer they are comprised. + ''; + }; }; }; - }; in { imports = [ (lib.mkRemovedOptionModule [ "services" "keyd" "ids" ] - ''Use keyboards..ids instead. If you don't need a multi-file configuration, just add keyboards.default before the ids. See https://github.com/NixOS/nixpkgs/pull/243271.'') + ''Use keyboards..ids instead. If you don't need a multi-file configuration, just add keyboards.default before the ids. See https://github.com/NixOS/nixpkgs/pull/243271.'' + ) (lib.mkRemovedOptionModule [ "services" "keyd" "settings" ] - ''Use keyboards..settings instead. If you don't need a multi-file configuration, just add keyboards.default before the settings. See https://github.com/NixOS/nixpkgs/pull/243271.'') + ''Use keyboards..settings instead. If you don't need a multi-file configuration, just add keyboards.default before the settings. See https://github.com/NixOS/nixpkgs/pull/243271.'' + ) ]; options.services.keyd = { @@ -94,18 +106,18 @@ in config = lib.mkIf cfg.enable { # Creates separate files in the `/etc/keyd/` directory for each key in the dictionary - environment.etc = lib.mapAttrs' - (name: options: - lib.nameValuePair "keyd/${name}.conf" { - text = '' - [ids] - ${lib.concatStringsSep "\n" options.ids} - - ${lib.generators.toINI {} options.settings} - ${options.extraConfig} - ''; - }) - cfg.keyboards; + environment.etc = lib.mapAttrs' ( + name: options: + lib.nameValuePair "keyd/${name}.conf" { + text = '' + [ids] + ${lib.concatStringsSep "\n" options.ids} + + ${lib.generators.toINI { } options.settings} + ${options.extraConfig} + ''; + } + ) cfg.keyboards; hardware.uinput.enable = lib.mkDefault true; @@ -115,11 +127,9 @@ in wantedBy = [ "multi-user.target" ]; - restartTriggers = lib.mapAttrsToList - (name: options: - config.environment.etc."keyd/${name}.conf".source - ) - cfg.keyboards; + restartTriggers = lib.mapAttrsToList ( + name: options: config.environment.etc."keyd/${name}.conf".source + ) cfg.keyboards; # this is configurable in 2.4.2, later versions seem to remove this option. # post-2.4.2 may need to set makeFlags in the derivation: diff --git a/nixos/modules/services/hardware/kmonad.nix b/nixos/modules/services/hardware/kmonad.nix index bc1b5409f9ddc9..fc548d51603ee8 100644 --- a/nixos/modules/services/hardware/kmonad.nix +++ b/nixos/modules/services/hardware/kmonad.nix @@ -85,12 +85,10 @@ let (defcfg input (device-file "${keyboard.device}") output (uinput-sink "kmonad-${keyboard.name}") - ${ - lib.optionalString (keyboard.defcfg.compose.key != null) '' - cmp-seq ${keyboard.defcfg.compose.key} - cmp-seq-delay ${toString keyboard.defcfg.compose.delay} - '' - } + ${lib.optionalString (keyboard.defcfg.compose.key != null) '' + cmp-seq ${keyboard.defcfg.compose.key} + cmp-seq-delay ${toString keyboard.defcfg.compose.delay} + ''} fallthrough ${lib.boolToString keyboard.defcfg.fallthrough} allow-cmd ${lib.boolToString keyboard.defcfg.allowCommands} ) @@ -122,11 +120,14 @@ let mkService = keyboard: let - cmd = [ - (lib.getExe cfg.package) - "--input" - ''device-file "${keyboard.device}"'' - ] ++ cfg.extraArgs ++ [ "${mkCfg keyboard}" ]; + cmd = + [ + (lib.getExe cfg.package) + "--input" + ''device-file "${keyboard.device}"'' + ] + ++ cfg.extraArgs + ++ [ "${mkCfg keyboard}" ]; in lib.nameValuePair "kmonad-${keyboard.name}" { description = "KMonad for ${keyboard.device}"; diff --git a/nixos/modules/services/hardware/lcd.nix b/nixos/modules/services/hardware/lcd.nix index d52d5f391911d4..0b39281667cc71 100644 --- a/nixos/modules/services/hardware/lcd.nix +++ b/nixos/modules/services/hardware/lcd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hardware.lcd; @@ -27,7 +32,9 @@ let Slice = "lcd.slice"; }; -in with lib; { +in +with lib; +{ meta.maintainers = with maintainers; [ peterhoeg ]; @@ -128,7 +135,9 @@ in with lib; { }; config = mkIf (cfg.server.enable || cfg.client.enable) { - networking.firewall.allowedTCPPorts = mkIf (cfg.server.enable && cfg.server.openPorts) [ cfg.serverPort ]; + networking.firewall.allowedTCPPorts = mkIf (cfg.server.enable && cfg.server.openPorts) [ + cfg.serverPort + ]; services.udev.extraRules = mkIf (cfg.server.enable && cfg.server.usbPermissions) '' ACTION=="add", SUBSYSTEMS=="usb", ATTRS{idVendor}=="${cfg.server.usbVid}", ATTRS{idProduct}=="${cfg.server.usbPid}", MODE="660", GROUP="${cfg.server.usbGroup}" @@ -161,7 +170,10 @@ in with lib; { systemd.targets.lcd = { description = "LCD client/server"; - after = [ "lcdd.service" "lcdproc.service" ]; + after = [ + "lcdd.service" + "lcdproc.service" + ]; wantedBy = [ "multi-user.target" ]; }; }; diff --git a/nixos/modules/services/hardware/libinput.nix b/nixos/modules/services/hardware/libinput.nix index e8169af40637f6..1ef62640ecce05 100644 --- a/nixos/modules/services/hardware/libinput.nix +++ b/nixos/modules/services/hardware/libinput.nix @@ -1,323 +1,422 @@ -{ config, lib, pkgs, ... }: -let cfg = config.services.libinput; - - xorgBool = v: if v then "on" else "off"; - - mkConfigForDevice = deviceType: { - dev = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - example = "/dev/input/event0"; - description = '' - Path for ${deviceType} device. Set to `null` to apply to any - auto-detected ${deviceType}. - ''; - }; +{ + config, + lib, + pkgs, + ... +}: +let + cfg = config.services.libinput; + + xorgBool = v: if v then "on" else "off"; + + mkConfigForDevice = deviceType: { + dev = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = null; + example = "/dev/input/event0"; + description = '' + Path for ${deviceType} device. Set to `null` to apply to any + auto-detected ${deviceType}. + ''; + }; - accelProfile = lib.mkOption { - type = lib.types.enum [ "flat" "adaptive" "custom" ]; - default = "adaptive"; - example = "flat"; - description = '' - Sets the pointer acceleration profile to the given profile. - Permitted values are `adaptive`, `flat`, `custom`. - Not all devices support this option or all profiles. - If a profile is unsupported, the default profile for this is used. - `flat`: Pointer motion is accelerated by a constant - (device-specific) factor, depending on the current speed. - `adaptive`: Pointer acceleration depends on the input speed. - This is the default profile for most devices. - `custom`: Allows the user to define a custom acceleration function. - To define custom functions use the accelPoints - and accelStep options. - ''; - }; + accelProfile = lib.mkOption { + type = lib.types.enum [ + "flat" + "adaptive" + "custom" + ]; + default = "adaptive"; + example = "flat"; + description = '' + Sets the pointer acceleration profile to the given profile. + Permitted values are `adaptive`, `flat`, `custom`. + Not all devices support this option or all profiles. + If a profile is unsupported, the default profile for this is used. + `flat`: Pointer motion is accelerated by a constant + (device-specific) factor, depending on the current speed. + `adaptive`: Pointer acceleration depends on the input speed. + This is the default profile for most devices. + `custom`: Allows the user to define a custom acceleration function. + To define custom functions use the accelPoints + and accelStep options. + ''; + }; - accelSpeed = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - example = "-0.5"; - description = '' - Cursor acceleration (how fast speed increases from minSpeed to maxSpeed). - This only applies to the flat or adaptive profile. - ''; - }; + accelSpeed = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = null; + example = "-0.5"; + description = '' + Cursor acceleration (how fast speed increases from minSpeed to maxSpeed). + This only applies to the flat or adaptive profile. + ''; + }; - accelPointsFallback = lib.mkOption { - type = lib.types.nullOr (lib.types.listOf lib.types.number); - default = null; - example = [ 0.0 1.0 2.4 2.5 ]; - description = '' - Sets the points of the fallback acceleration function. The value must be a list of - floating point non-negative numbers. This only applies to the custom profile. - ''; - }; + accelPointsFallback = lib.mkOption { + type = lib.types.nullOr (lib.types.listOf lib.types.number); + default = null; + example = [ + 0.0 + 1.0 + 2.4 + 2.5 + ]; + description = '' + Sets the points of the fallback acceleration function. The value must be a list of + floating point non-negative numbers. This only applies to the custom profile. + ''; + }; - accelPointsMotion = lib.mkOption { - type = lib.types.nullOr (lib.types.listOf lib.types.number); - default = null; - example = [ 0.0 1.0 2.4 2.5 ]; - description = '' - Sets the points of the (pointer) motion acceleration function. The value must be a - list of floating point non-negative numbers. This only applies to the custom profile. - ''; - }; + accelPointsMotion = lib.mkOption { + type = lib.types.nullOr (lib.types.listOf lib.types.number); + default = null; + example = [ + 0.0 + 1.0 + 2.4 + 2.5 + ]; + description = '' + Sets the points of the (pointer) motion acceleration function. The value must be a + list of floating point non-negative numbers. This only applies to the custom profile. + ''; + }; - accelPointsScroll = lib.mkOption { - type = lib.types.nullOr (lib.types.listOf lib.types.number); - default = null; - example = [ 0.0 1.0 2.4 2.5 ]; - description = '' - Sets the points of the scroll acceleration function. The value must be a list of - floating point non-negative numbers. This only applies to the custom profile. - ''; - }; + accelPointsScroll = lib.mkOption { + type = lib.types.nullOr (lib.types.listOf lib.types.number); + default = null; + example = [ + 0.0 + 1.0 + 2.4 + 2.5 + ]; + description = '' + Sets the points of the scroll acceleration function. The value must be a list of + floating point non-negative numbers. This only applies to the custom profile. + ''; + }; - accelStepFallback = lib.mkOption { - type = lib.types.nullOr lib.types.number; - default = null; - example = 0.1; - description = '' - Sets the step between the points of the fallback acceleration function. When a step of - 0.0 is provided, libinput's Fallback acceleration function is used. This only applies - to the custom profile. - ''; - }; + accelStepFallback = lib.mkOption { + type = lib.types.nullOr lib.types.number; + default = null; + example = 0.1; + description = '' + Sets the step between the points of the fallback acceleration function. When a step of + 0.0 is provided, libinput's Fallback acceleration function is used. This only applies + to the custom profile. + ''; + }; - accelStepMotion = lib.mkOption { - type = lib.types.nullOr lib.types.number; - default = null; - example = 0.1; - description = '' - Sets the step between the points of the (pointer) motion acceleration function. When a - step of 0.0 is provided, libinput's Fallback acceleration function is used. This only - applies to the custom profile. - ''; - }; + accelStepMotion = lib.mkOption { + type = lib.types.nullOr lib.types.number; + default = null; + example = 0.1; + description = '' + Sets the step between the points of the (pointer) motion acceleration function. When a + step of 0.0 is provided, libinput's Fallback acceleration function is used. This only + applies to the custom profile. + ''; + }; - accelStepScroll = lib.mkOption { - type = lib.types.nullOr lib.types.number; - default = null; - example = 0.1; - description = '' - Sets the step between the points of the scroll acceleration function. When a step of - 0.0 is provided, libinput's Fallback acceleration function is used. This only applies - to the custom profile. - ''; - }; + accelStepScroll = lib.mkOption { + type = lib.types.nullOr lib.types.number; + default = null; + example = 0.1; + description = '' + Sets the step between the points of the scroll acceleration function. When a step of + 0.0 is provided, libinput's Fallback acceleration function is used. This only applies + to the custom profile. + ''; + }; - buttonMapping = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - example = "1 6 3 4 5 0 7"; - description = '' - Sets the logical button mapping for this device, see XSetPointerMapping(3). The string must - be a space-separated list of button mappings in the order of the logical buttons on the - device, starting with button 1. The default mapping is "1 2 3 ... 32". A mapping of 0 deac‐ - tivates the button. Multiple buttons can have the same mapping. Invalid mapping strings are - discarded and the default mapping is used for all buttons. Buttons not specified in the - user's mapping use the default mapping. See section BUTTON MAPPING for more details. - ''; - }; + buttonMapping = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = null; + example = "1 6 3 4 5 0 7"; + description = '' + Sets the logical button mapping for this device, see XSetPointerMapping(3). The string must + be a space-separated list of button mappings in the order of the logical buttons on the + device, starting with button 1. The default mapping is "1 2 3 ... 32". A mapping of 0 deac‐ + tivates the button. Multiple buttons can have the same mapping. Invalid mapping strings are + discarded and the default mapping is used for all buttons. Buttons not specified in the + user's mapping use the default mapping. See section BUTTON MAPPING for more details. + ''; + }; - calibrationMatrix = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - example = "0.5 0 0 0 0.8 0.1 0 0 1"; - description = '' - A string of 9 space-separated floating point numbers. Sets the calibration matrix to the - 3x3 matrix where the first row is (abc), the second row is (def) and the third row is (ghi). - ''; - }; + calibrationMatrix = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = null; + example = "0.5 0 0 0 0.8 0.1 0 0 1"; + description = '' + A string of 9 space-separated floating point numbers. Sets the calibration matrix to the + 3x3 matrix where the first row is (abc), the second row is (def) and the third row is (ghi). + ''; + }; - clickMethod = lib.mkOption { - type = lib.types.nullOr (lib.types.enum [ "none" "buttonareas" "clickfinger" ]); - default = null; - example = "buttonareas"; - description = '' - Enables a click method. Permitted values are `none`, - `buttonareas`, `clickfinger`. - Not all devices support all methods, if an option is unsupported, - the default click method for this device is used. - ''; - }; + clickMethod = lib.mkOption { + type = lib.types.nullOr ( + lib.types.enum [ + "none" + "buttonareas" + "clickfinger" + ] + ); + default = null; + example = "buttonareas"; + description = '' + Enables a click method. Permitted values are `none`, + `buttonareas`, `clickfinger`. + Not all devices support all methods, if an option is unsupported, + the default click method for this device is used. + ''; + }; - leftHanded = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Enables left-handed button orientation, i.e. swapping left and right buttons."; - }; + leftHanded = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Enables left-handed button orientation, i.e. swapping left and right buttons."; + }; - middleEmulation = lib.mkOption { - type = lib.types.bool; - default = true; - description = '' - Enables middle button emulation. When enabled, pressing the left and right buttons - simultaneously produces a middle mouse button click. - ''; - }; + middleEmulation = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Enables middle button emulation. When enabled, pressing the left and right buttons + simultaneously produces a middle mouse button click. + ''; + }; - naturalScrolling = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Enables or disables natural scrolling behavior."; - }; + naturalScrolling = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Enables or disables natural scrolling behavior."; + }; - scrollButton = lib.mkOption { - type = lib.types.nullOr lib.types.int; - default = null; - example = 1; - description = '' - Designates a button as scroll button. If the ScrollMethod is button and the button is logically - held down, x/y axis movement is converted into scroll events. - ''; - }; + scrollButton = lib.mkOption { + type = lib.types.nullOr lib.types.int; + default = null; + example = 1; + description = '' + Designates a button as scroll button. If the ScrollMethod is button and the button is logically + held down, x/y axis movement is converted into scroll events. + ''; + }; - scrollMethod = lib.mkOption { - type = lib.types.enum [ "twofinger" "edge" "button" "none" ]; - default = "twofinger"; - example = "edge"; - description = '' - Specify the scrolling method: `twofinger`, `edge`, - `button`, or `none` - ''; - }; + scrollMethod = lib.mkOption { + type = lib.types.enum [ + "twofinger" + "edge" + "button" + "none" + ]; + default = "twofinger"; + example = "edge"; + description = '' + Specify the scrolling method: `twofinger`, `edge`, + `button`, or `none` + ''; + }; - horizontalScrolling = lib.mkOption { - type = lib.types.bool; - default = true; - description = '' - Enables or disables horizontal scrolling. When disabled, this driver will discard any - horizontal scroll events from libinput. This does not disable horizontal scroll events - from libinput; it merely discards the horizontal axis from any scroll events. - ''; - }; + horizontalScrolling = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Enables or disables horizontal scrolling. When disabled, this driver will discard any + horizontal scroll events from libinput. This does not disable horizontal scroll events + from libinput; it merely discards the horizontal axis from any scroll events. + ''; + }; - sendEventsMode = lib.mkOption { - type = lib.types.enum [ "disabled" "enabled" "disabled-on-external-mouse" ]; - default = "enabled"; - example = "disabled"; - description = '' - Sets the send events mode to `disabled`, `enabled`, - or `disabled-on-external-mouse` - ''; - }; + sendEventsMode = lib.mkOption { + type = lib.types.enum [ + "disabled" + "enabled" + "disabled-on-external-mouse" + ]; + default = "enabled"; + example = "disabled"; + description = '' + Sets the send events mode to `disabled`, `enabled`, + or `disabled-on-external-mouse` + ''; + }; - tapping = lib.mkOption { - type = lib.types.bool; - default = true; - description = '' - Enables or disables tap-to-click behavior. - ''; - }; + tapping = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Enables or disables tap-to-click behavior. + ''; + }; - tappingButtonMap = lib.mkOption { - type = lib.types.nullOr (lib.types.enum [ "lrm" "lmr" ]); - default = null; - description = '' - Set the button mapping for 1/2/3-finger taps to left/right/middle or left/middle/right, respectively. - ''; - }; + tappingButtonMap = lib.mkOption { + type = lib.types.nullOr ( + lib.types.enum [ + "lrm" + "lmr" + ] + ); + default = null; + description = '' + Set the button mapping for 1/2/3-finger taps to left/right/middle or left/middle/right, respectively. + ''; + }; - tappingDragLock = lib.mkOption { - type = lib.types.bool; - default = true; - description = '' - Enables or disables drag lock during tapping behavior. When enabled, a finger up during tap- - and-drag will not immediately release the button. If the finger is set down again within the - timeout, the dragging process continues. - ''; - }; + tappingDragLock = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Enables or disables drag lock during tapping behavior. When enabled, a finger up during tap- + and-drag will not immediately release the button. If the finger is set down again within the + timeout, the dragging process continues. + ''; + }; - transformationMatrix = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - example = "0.5 0 0 0 0.8 0.1 0 0 1"; - description = '' - A string of 9 space-separated floating point numbers. Sets the transformation matrix to - the 3x3 matrix where the first row is (abc), the second row is (def) and the third row is (ghi). - ''; - }; + transformationMatrix = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = null; + example = "0.5 0 0 0 0.8 0.1 0 0 1"; + description = '' + A string of 9 space-separated floating point numbers. Sets the transformation matrix to + the 3x3 matrix where the first row is (abc), the second row is (def) and the third row is (ghi). + ''; + }; - disableWhileTyping = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Disable input method while typing. - ''; - }; + disableWhileTyping = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Disable input method while typing. + ''; + }; - additionalOptions = lib.mkOption { - type = lib.types.lines; - default = ""; - example = - '' - Option "DragLockButtons" "L1 B1 L2 B2" - ''; - description = '' - Additional options for libinput ${deviceType} driver. See - {manpage}`libinput(4)` - for available options."; - ''; - }; + additionalOptions = lib.mkOption { + type = lib.types.lines; + default = ""; + example = '' + Option "DragLockButtons" "L1 B1 L2 B2" + ''; + description = '' + Additional options for libinput ${deviceType} driver. See + {manpage}`libinput(4)` + for available options."; + ''; }; + }; - mkX11ConfigForDevice = deviceType: matchIs: '' - Identifier "libinput ${deviceType} configuration" - MatchDriver "libinput" - MatchIs${matchIs} "${xorgBool true}" - ${lib.optionalString (cfg.${deviceType}.dev != null) ''MatchDevicePath "${cfg.${deviceType}.dev}"''} - Option "AccelProfile" "${cfg.${deviceType}.accelProfile}" - ${lib.optionalString (cfg.${deviceType}.accelSpeed != null) ''Option "AccelSpeed" "${cfg.${deviceType}.accelSpeed}"''} - ${lib.optionalString (cfg.${deviceType}.accelPointsFallback != null) ''Option "AccelPointsFallback" "${toString cfg.${deviceType}.accelPointsFallback}"''} - ${lib.optionalString (cfg.${deviceType}.accelPointsMotion != null) ''Option "AccelPointsMotion" "${toString cfg.${deviceType}.accelPointsMotion}"''} - ${lib.optionalString (cfg.${deviceType}.accelPointsScroll != null) ''Option "AccelPointsScroll" "${toString cfg.${deviceType}.accelPointsScroll}"''} - ${lib.optionalString (cfg.${deviceType}.accelStepFallback != null) ''Option "AccelStepFallback" "${toString cfg.${deviceType}.accelStepFallback}"''} - ${lib.optionalString (cfg.${deviceType}.accelStepMotion != null) ''Option "AccelStepMotion" "${toString cfg.${deviceType}.accelStepMotion}"''} - ${lib.optionalString (cfg.${deviceType}.accelStepScroll != null) ''Option "AccelStepScroll" "${toString cfg.${deviceType}.accelStepScroll}"''} - ${lib.optionalString (cfg.${deviceType}.buttonMapping != null) ''Option "ButtonMapping" "${cfg.${deviceType}.buttonMapping}"''} - ${lib.optionalString (cfg.${deviceType}.calibrationMatrix != null) ''Option "CalibrationMatrix" "${cfg.${deviceType}.calibrationMatrix}"''} - ${lib.optionalString (cfg.${deviceType}.transformationMatrix != null) ''Option "TransformationMatrix" "${cfg.${deviceType}.transformationMatrix}"''} - ${lib.optionalString (cfg.${deviceType}.clickMethod != null) ''Option "ClickMethod" "${cfg.${deviceType}.clickMethod}"''} - Option "LeftHanded" "${xorgBool cfg.${deviceType}.leftHanded}" - Option "MiddleEmulation" "${xorgBool cfg.${deviceType}.middleEmulation}" - Option "NaturalScrolling" "${xorgBool cfg.${deviceType}.naturalScrolling}" - ${lib.optionalString (cfg.${deviceType}.scrollButton != null) ''Option "ScrollButton" "${toString cfg.${deviceType}.scrollButton}"''} - Option "ScrollMethod" "${cfg.${deviceType}.scrollMethod}" - Option "HorizontalScrolling" "${xorgBool cfg.${deviceType}.horizontalScrolling}" - Option "SendEventsMode" "${cfg.${deviceType}.sendEventsMode}" - Option "Tapping" "${xorgBool cfg.${deviceType}.tapping}" - ${lib.optionalString (cfg.${deviceType}.tappingButtonMap != null) ''Option "TappingButtonMap" "${cfg.${deviceType}.tappingButtonMap}"''} - Option "TappingDragLock" "${xorgBool cfg.${deviceType}.tappingDragLock}" - Option "DisableWhileTyping" "${xorgBool cfg.${deviceType}.disableWhileTyping}" - ${cfg.${deviceType}.additionalOptions} - ''; -in { + mkX11ConfigForDevice = deviceType: matchIs: '' + Identifier "libinput ${deviceType} configuration" + MatchDriver "libinput" + MatchIs${matchIs} "${xorgBool true}" + ${lib.optionalString (cfg.${deviceType}.dev != null) ''MatchDevicePath "${cfg.${deviceType}.dev}"''} + Option "AccelProfile" "${cfg.${deviceType}.accelProfile}" + ${lib.optionalString ( + cfg.${deviceType}.accelSpeed != null + ) ''Option "AccelSpeed" "${cfg.${deviceType}.accelSpeed}"''} + ${lib.optionalString ( + cfg.${deviceType}.accelPointsFallback != null + ) ''Option "AccelPointsFallback" "${toString cfg.${deviceType}.accelPointsFallback}"''} + ${lib.optionalString (cfg.${deviceType}.accelPointsMotion != null) + ''Option "AccelPointsMotion" "${toString cfg.${deviceType}.accelPointsMotion}"'' + } + ${lib.optionalString (cfg.${deviceType}.accelPointsScroll != null) + ''Option "AccelPointsScroll" "${toString cfg.${deviceType}.accelPointsScroll}"'' + } + ${lib.optionalString (cfg.${deviceType}.accelStepFallback != null) + ''Option "AccelStepFallback" "${toString cfg.${deviceType}.accelStepFallback}"'' + } + ${lib.optionalString (cfg.${deviceType}.accelStepMotion != null) + ''Option "AccelStepMotion" "${toString cfg.${deviceType}.accelStepMotion}"'' + } + ${lib.optionalString (cfg.${deviceType}.accelStepScroll != null) + ''Option "AccelStepScroll" "${toString cfg.${deviceType}.accelStepScroll}"'' + } + ${lib.optionalString (cfg.${deviceType}.buttonMapping != null) + ''Option "ButtonMapping" "${cfg.${deviceType}.buttonMapping}"'' + } + ${lib.optionalString (cfg.${deviceType}.calibrationMatrix != null) + ''Option "CalibrationMatrix" "${cfg.${deviceType}.calibrationMatrix}"'' + } + ${lib.optionalString ( + cfg.${deviceType}.transformationMatrix != null + ) ''Option "TransformationMatrix" "${cfg.${deviceType}.transformationMatrix}"''} + ${lib.optionalString ( + cfg.${deviceType}.clickMethod != null + ) ''Option "ClickMethod" "${cfg.${deviceType}.clickMethod}"''} + Option "LeftHanded" "${xorgBool cfg.${deviceType}.leftHanded}" + Option "MiddleEmulation" "${xorgBool cfg.${deviceType}.middleEmulation}" + Option "NaturalScrolling" "${xorgBool cfg.${deviceType}.naturalScrolling}" + ${lib.optionalString (cfg.${deviceType}.scrollButton != null) + ''Option "ScrollButton" "${toString cfg.${deviceType}.scrollButton}"'' + } + Option "ScrollMethod" "${cfg.${deviceType}.scrollMethod}" + Option "HorizontalScrolling" "${xorgBool cfg.${deviceType}.horizontalScrolling}" + Option "SendEventsMode" "${cfg.${deviceType}.sendEventsMode}" + Option "Tapping" "${xorgBool cfg.${deviceType}.tapping}" + ${lib.optionalString (cfg.${deviceType}.tappingButtonMap != null) + ''Option "TappingButtonMap" "${cfg.${deviceType}.tappingButtonMap}"'' + } + Option "TappingDragLock" "${xorgBool cfg.${deviceType}.tappingDragLock}" + Option "DisableWhileTyping" "${xorgBool cfg.${deviceType}.disableWhileTyping}" + ${cfg.${deviceType}.additionalOptions} + ''; +in +{ imports = - (map (option: lib.mkRenamedOptionModule ([ "services" "xserver" "libinput" option ]) [ "services" "libinput" "touchpad" option ]) [ - "accelProfile" - "accelSpeed" - "buttonMapping" - "calibrationMatrix" - "clickMethod" - "leftHanded" - "middleEmulation" - "naturalScrolling" - "scrollButton" - "scrollMethod" - "horizontalScrolling" - "sendEventsMode" - "tapping" - "tappingButtonMap" - "tappingDragLock" - "transformationMatrix" - "disableWhileTyping" - "additionalOptions" - ]) ++ [ - (lib.mkRenamedOptionModule [ "services" "xserver" "libinput" "enable" ] [ "services" "libinput" "enable" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "libinput" "mouse" ] [ "services" "libinput" "mouse" ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "libinput" "touchpad" ] [ "services" "libinput" "touchpad" ]) + (map + ( + option: + lib.mkRenamedOptionModule + ([ + "services" + "xserver" + "libinput" + option + ]) + [ + "services" + "libinput" + "touchpad" + option + ] + ) + [ + "accelProfile" + "accelSpeed" + "buttonMapping" + "calibrationMatrix" + "clickMethod" + "leftHanded" + "middleEmulation" + "naturalScrolling" + "scrollButton" + "scrollMethod" + "horizontalScrolling" + "sendEventsMode" + "tapping" + "tappingButtonMap" + "tappingDragLock" + "transformationMatrix" + "disableWhileTyping" + "additionalOptions" + ] + ) + ++ [ + (lib.mkRenamedOptionModule + [ "services" "xserver" "libinput" "enable" ] + [ "services" "libinput" "enable" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "libinput" "mouse" ] + [ "services" "libinput" "mouse" ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "libinput" "touchpad" ] + [ "services" "libinput" "touchpad" ] + ) ]; options = { @@ -332,7 +431,6 @@ in { }; }; - config = lib.mkIf cfg.enable { services.xserver.modules = [ pkgs.xorg.xf86inputlibinput ]; @@ -340,8 +438,10 @@ in { environment.systemPackages = [ pkgs.xorg.xf86inputlibinput ]; environment.etc = - let cfgPath = "X11/xorg.conf.d/40-libinput.conf"; - in { + let + cfgPath = "X11/xorg.conf.d/40-libinput.conf"; + in + { ${cfgPath} = { source = pkgs.xorg.xf86inputlibinput.out + "/share/" + cfgPath; }; @@ -356,10 +456,12 @@ in { assertions = [ # already present in synaptics.nix - /* { - assertion = !config.services.xserver.synaptics.enable; - message = "Synaptics and libinput are incompatible, you cannot enable both (in services.xserver)."; - } */ + /* + { + assertion = !config.services.xserver.synaptics.enable; + message = "Synaptics and libinput are incompatible, you cannot enable both (in services.xserver)."; + } + */ ]; }; diff --git a/nixos/modules/services/hardware/lirc.nix b/nixos/modules/services/hardware/lirc.nix index 9942b9a97513a9..6cc7c4ef19044d 100644 --- a/nixos/modules/services/hardware/lirc.nix +++ b/nixos/modules/services/hardware/lirc.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.lirc; -in { +in +{ ###### interface @@ -26,7 +32,7 @@ in { extraArguments = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = "Extra arguments to lircd."; }; }; @@ -53,38 +59,43 @@ in { }; }; - systemd.services.lircd = let - configFile = pkgs.writeText "lircd.conf" (builtins.concatStringsSep "\n" cfg.configs); - in { - description = "LIRC daemon service"; - after = [ "network.target" ]; - - unitConfig.Documentation = [ "man:lircd(8)" ]; - - serviceConfig = { - RuntimeDirectory = ["lirc" "lirc/lock"]; - - # Service runtime directory and socket share same folder. - # Following hacks are necessary to get everything right: - - # 1. prevent socket deletion during stop and restart - RuntimeDirectoryPreserve = true; - - # 2. fix runtime folder owner-ship, happens when socket activation - # creates the folder - PermissionsStartOnly = true; - ExecStartPre = [ - "${pkgs.coreutils}/bin/chown lirc /run/lirc/" - ]; - - ExecStart = '' - ${pkgs.lirc}/bin/lircd --nodaemon \ - ${lib.escapeShellArgs cfg.extraArguments} \ - ${configFile} - ''; - User = "lirc"; + systemd.services.lircd = + let + configFile = pkgs.writeText "lircd.conf" (builtins.concatStringsSep "\n" cfg.configs); + in + { + description = "LIRC daemon service"; + after = [ "network.target" ]; + + unitConfig.Documentation = [ "man:lircd(8)" ]; + + serviceConfig = { + RuntimeDirectory = [ + "lirc" + "lirc/lock" + ]; + + # Service runtime directory and socket share same folder. + # Following hacks are necessary to get everything right: + + # 1. prevent socket deletion during stop and restart + RuntimeDirectoryPreserve = true; + + # 2. fix runtime folder owner-ship, happens when socket activation + # creates the folder + PermissionsStartOnly = true; + ExecStartPre = [ + "${pkgs.coreutils}/bin/chown lirc /run/lirc/" + ]; + + ExecStart = '' + ${pkgs.lirc}/bin/lircd --nodaemon \ + ${lib.escapeShellArgs cfg.extraArguments} \ + ${configFile} + ''; + User = "lirc"; + }; }; - }; users.users.lirc = { uid = config.ids.uids.lirc; diff --git a/nixos/modules/services/hardware/nvidia-container-toolkit/cdi-generate.nix b/nixos/modules/services/hardware/nvidia-container-toolkit/cdi-generate.nix index 6a04fa0ff75021..78b7ec080289ba 100644 --- a/nixos/modules/services/hardware/nvidia-container-toolkit/cdi-generate.nix +++ b/nixos/modules/services/hardware/nvidia-container-toolkit/cdi-generate.nix @@ -8,45 +8,52 @@ nvidia-driver, runtimeShell, writeScriptBin, -}: let - mkMount = {hostPath, containerPath, mountOptions}: { - inherit hostPath containerPath; - options = mountOptions; - }; - mountToCommand = mount: +}: +let + mkMount = + { + hostPath, + containerPath, + mountOptions, + }: + { + inherit hostPath containerPath; + options = mountOptions; + }; + mountToCommand = + mount: "additionalMount \"${mount.hostPath}\" \"${mount.containerPath}\" '${builtins.toJSON mount.mountOptions}'"; - mountsToCommands = mounts: + mountsToCommands = + mounts: if (builtins.length mounts) == 0 then "cat" else - (lib.strings.concatMapStringsSep " | \\\n" - mountToCommand mounts); + (lib.strings.concatMapStringsSep " | \\\n" mountToCommand mounts); in -writeScriptBin "nvidia-cdi-generator" -'' -#! ${runtimeShell} +writeScriptBin "nvidia-cdi-generator" '' + #! ${runtimeShell} -function cdiGenerate { - ${lib.getExe' nvidia-container-toolkit "nvidia-ctk"} cdi generate \ - --format json \ - --device-name-strategy ${deviceNameStrategy} \ - --ldconfig-path ${lib.getExe' glibc "ldconfig"} \ - --library-search-path ${lib.getLib nvidia-driver}/lib \ - --nvidia-ctk-path ${lib.getExe' nvidia-container-toolkit "nvidia-ctk"} -} + function cdiGenerate { + ${lib.getExe' nvidia-container-toolkit "nvidia-ctk"} cdi generate \ + --format json \ + --device-name-strategy ${deviceNameStrategy} \ + --ldconfig-path ${lib.getExe' glibc "ldconfig"} \ + --library-search-path ${lib.getLib nvidia-driver}/lib \ + --nvidia-ctk-path ${lib.getExe' nvidia-container-toolkit "nvidia-ctk"} + } -function additionalMount { - local hostPath="$1" - local containerPath="$2" - local mountOptions="$3" - if [ -e "$hostPath" ]; then - ${lib.getExe jq} ".containerEdits.mounts[.containerEdits.mounts | length] = { \"hostPath\": \"$hostPath\", \"containerPath\": \"$containerPath\", \"options\": $mountOptions }" - else - echo "Mount $hostPath ignored: could not find path in the host machine" >&2 - cat - fi -} + function additionalMount { + local hostPath="$1" + local containerPath="$2" + local mountOptions="$3" + if [ -e "$hostPath" ]; then + ${lib.getExe jq} ".containerEdits.mounts[.containerEdits.mounts | length] = { \"hostPath\": \"$hostPath\", \"containerPath\": \"$containerPath\", \"options\": $mountOptions }" + else + echo "Mount $hostPath ignored: could not find path in the host machine" >&2 + cat + fi + } -cdiGenerate | - ${mountsToCommands mounts} > $RUNTIME_DIRECTORY/nvidia-container-toolkit.json + cdiGenerate | + ${mountsToCommands mounts} > $RUNTIME_DIRECTORY/nvidia-container-toolkit.json '' diff --git a/nixos/modules/services/hardware/nvidia-optimus.nix b/nixos/modules/services/hardware/nvidia-optimus.nix index 307bc78098d14a..7c16cb9676ee9a 100644 --- a/nixos/modules/services/hardware/nvidia-optimus.nix +++ b/nixos/modules/services/hardware/nvidia-optimus.nix @@ -1,6 +1,8 @@ { config, lib, ... }: -let kernel = config.boot.kernelPackages; in +let + kernel = config.boot.kernelPackages; +in { @@ -19,11 +21,16 @@ let kernel = config.boot.kernelPackages; in }; - ###### implementation config = lib.mkIf config.hardware.nvidiaOptimus.disable { - boot.blacklistedKernelModules = ["nouveau" "nvidia" "nvidiafb" "nvidia-drm" "nvidia-modeset"]; + boot.blacklistedKernelModules = [ + "nouveau" + "nvidia" + "nvidiafb" + "nvidia-drm" + "nvidia-modeset" + ]; boot.kernelModules = [ "bbswitch" ]; boot.extraModulePackages = [ kernel.bbswitch ]; diff --git a/nixos/modules/services/hardware/openrgb.nix b/nixos/modules/services/hardware/openrgb.nix index 0e06f9720ac107..ec5750a2290424 100644 --- a/nixos/modules/services/hardware/openrgb.nix +++ b/nixos/modules/services/hardware/openrgb.nix @@ -1,17 +1,32 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: let cfg = config.services.hardware.openrgb; -in { +in +{ options.services.hardware.openrgb = { enable = lib.mkEnableOption "OpenRGB server, for RGB lighting control"; package = lib.mkPackageOption pkgs "openrgb" { }; motherboard = lib.mkOption { - type = lib.types.nullOr (lib.types.enum [ "amd" "intel" ]); - default = if config.hardware.cpu.intel.updateMicrocode then "intel" - else if config.hardware.cpu.amd.updateMicrocode then "amd" - else null; + type = lib.types.nullOr ( + lib.types.enum [ + "amd" + "intel" + ] + ); + default = + if config.hardware.cpu.intel.updateMicrocode then + "intel" + else if config.hardware.cpu.amd.updateMicrocode then + "amd" + else + null; defaultText = lib.literalMD '' if config.hardware.cpu.intel.updateMicrocode then "intel" else if config.hardware.cpu.amd.updateMicrocode then "amd" @@ -32,9 +47,10 @@ in { environment.systemPackages = [ cfg.package ]; services.udev.packages = [ cfg.package ]; - boot.kernelModules = [ "i2c-dev" ] - ++ lib.optionals (cfg.motherboard == "amd") [ "i2c-piix4" ] - ++ lib.optionals (cfg.motherboard == "intel") [ "i2c-i801" ]; + boot.kernelModules = + [ "i2c-dev" ] + ++ lib.optionals (cfg.motherboard == "amd") [ "i2c-piix4" ] + ++ lib.optionals (cfg.motherboard == "intel") [ "i2c-i801" ]; systemd.services.openrgb = { description = "OpenRGB server daemon"; diff --git a/nixos/modules/services/hardware/pommed.nix b/nixos/modules/services/hardware/pommed.nix index c5efb76d6eece0..3bb53ce4603a40 100644 --- a/nixos/modules/services/hardware/pommed.nix +++ b/nixos/modules/services/hardware/pommed.nix @@ -1,7 +1,14 @@ -{ config, lib, pkgs, ... }: -let cfg = config.services.hardware.pommed; - defaultConf = "${pkgs.pommed_light}/etc/pommed.conf.mactel"; -in { +{ + config, + lib, + pkgs, + ... +}: +let + cfg = config.services.hardware.pommed; + defaultConf = "${pkgs.pommed_light}/etc/pommed.conf.mactel"; +in +{ options = { @@ -33,7 +40,10 @@ in { }; config = lib.mkIf cfg.enable { - environment.systemPackages = [ pkgs.polkit pkgs.pommed_light ]; + environment.systemPackages = [ + pkgs.polkit + pkgs.pommed_light + ]; environment.etc."pommed.conf".source = if cfg.configFile == null then defaultConf else cfg.configFile; diff --git a/nixos/modules/services/hardware/power-profiles-daemon.nix b/nixos/modules/services/hardware/power-profiles-daemon.nix index 7651c65b9f181a..c3a9853b8c3319 100644 --- a/nixos/modules/services/hardware/power-profiles-daemon.nix +++ b/nixos/modules/services/hardware/power-profiles-daemon.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.power-profiles-daemon; @@ -27,19 +32,20 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { assertions = [ - { assertion = !config.services.tlp.enable; + { + assertion = !config.services.tlp.enable; message = '' You have set services.power-profiles-daemon.enable = true; which conflicts with services.tlp.enable = true; ''; } - { assertion = !config.services.auto-cpufreq.enable; + { + assertion = !config.services.auto-cpufreq.enable; message = '' You have set services.power-profiles-daemon.enable = true; which conflicts with services.auto-cpufreq.enable = true; diff --git a/nixos/modules/services/hardware/rasdaemon.nix b/nixos/modules/services/hardware/rasdaemon.nix index ac3c675a7fbeda..53a0780e4e341a 100644 --- a/nixos/modules/services/hardware/rasdaemon.nix +++ b/nixos/modules/services/hardware/rasdaemon.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.rasdaemon; @@ -68,7 +73,7 @@ in extraModules = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = "extra kernel modules to load"; example = [ "i7core_edac" ]; }; @@ -83,7 +88,7 @@ in enable = cfg.mainboard != ""; text = cfg.mainboard; }; - # TODO, handle multiple cfg.labels.brand = " "; + # TODO, handle multiple cfg.labels.brand = " "; "ras/dimm_labels.d/labels" = { enable = cfg.labels != ""; text = cfg.labels; @@ -93,14 +98,19 @@ in text = cfg.config; }; }; - environment.systemPackages = [ pkgs.rasdaemon ] - ++ lib.optionals (cfg.testing) (with pkgs.error-inject; [ - edac-inject - mce-inject - aer-inject - ]); - - boot.initrd.kernelModules = cfg.extraModules + environment.systemPackages = + [ pkgs.rasdaemon ] + ++ lib.optionals (cfg.testing) ( + with pkgs.error-inject; + [ + edac-inject + mce-inject + aer-inject + ] + ); + + boot.initrd.kernelModules = + cfg.extraModules ++ lib.optionals (cfg.testing) [ # edac_core and amd64_edac should get loaded automatically # i7core_edac may not be, and may not be required, but should load successfully @@ -111,18 +121,20 @@ in "aer-inject" ]; - boot.kernelPatches = lib.optionals (cfg.testing) [{ - name = "rasdaemon-tests"; - patch = null; - extraConfig = '' - EDAC_DEBUG y - X86_MCE_INJECT y - - PCIEPORTBUS y - PCIEAER y - PCIEAER_INJECT y - ''; - }]; + boot.kernelPatches = lib.optionals (cfg.testing) [ + { + name = "rasdaemon-tests"; + patch = null; + extraConfig = '' + EDAC_DEBUG y + X86_MCE_INJECT y + + PCIEPORTBUS y + PCIEAER y + PCIEAER_INJECT y + ''; + } + ]; # i tried to set up a group for this # but rasdaemon needs higher permissions? @@ -138,8 +150,8 @@ in serviceConfig = { StateDirectory = lib.optionalString (cfg.record) "rasdaemon"; - ExecStart = "${pkgs.rasdaemon}/bin/rasdaemon --foreground" - + lib.optionalString (cfg.record) " --record"; + ExecStart = + "${pkgs.rasdaemon}/bin/rasdaemon --foreground" + lib.optionalString (cfg.record) " --record"; ExecStop = "${pkgs.rasdaemon}/bin/rasdaemon --disable"; Restart = "on-abort"; diff --git a/nixos/modules/services/hardware/ratbagd.nix b/nixos/modules/services/hardware/ratbagd.nix index c7a6e9093b4788..d77a6e9f933bf8 100644 --- a/nixos/modules/services/hardware/ratbagd.nix +++ b/nixos/modules/services/hardware/ratbagd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.ratbagd; in diff --git a/nixos/modules/services/hardware/sane.nix b/nixos/modules/services/hardware/sane.nix index 98207ada78c393..7afdb630b0a736 100644 --- a/nixos/modules/services/hardware/sane.nix +++ b/nixos/modules/services/hardware/sane.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let pkg = config.hardware.sane.backends-package.override { @@ -29,8 +34,17 @@ let LD_LIBRARY_PATH = [ "/etc/sane-libs" ]; }; - backends = [ pkg netConf ] ++ lib.optional config.services.saned.enable sanedConf ++ config.hardware.sane.extraBackends; - saneConfig = pkgs.mkSaneConfig { paths = backends; inherit (config.hardware.sane) disabledDefaultBackends; }; + backends = + [ + pkg + netConf + ] + ++ lib.optional config.services.saned.enable sanedConf + ++ config.hardware.sane.extraBackends; + saneConfig = pkgs.mkSaneConfig { + paths = backends; + inherit (config.hardware.sane) disabledDefaultBackends; + }; enabled = config.hardware.sane.enable || config.services.saned.enable; @@ -69,7 +83,7 @@ in hardware.sane.extraBackends = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; description = '' Packages providing extra SANE backends to enable. @@ -84,7 +98,7 @@ in hardware.sane.disabledDefaultBackends = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = [ "v4l" ]; description = '' Names of backends which are enabled by default but should be disabled. @@ -159,7 +173,6 @@ in }; - ###### implementation config = lib.mkMerge [ @@ -196,7 +209,10 @@ in systemd.sockets.saned = { description = "saned incoming socket"; wantedBy = [ "sockets.target" ]; - listenStreams = [ "0.0.0.0:6566" "[::]:6566" ]; + listenStreams = [ + "0.0.0.0:6566" + "[::]:6566" + ]; socketConfig = { # saned needs to distinguish between IPv4 and IPv6 to open matching data sockets. BindIPv6Only = "ipv6-only"; diff --git a/nixos/modules/services/hardware/sane_extra_backends/brscan4.nix b/nixos/modules/services/hardware/sane_extra_backends/brscan4.nix index 377216d1f4313c..c9428d51676dc6 100644 --- a/nixos/modules/services/hardware/sane_extra_backends/brscan4.nix +++ b/nixos/modules/services/hardware/sane_extra_backends/brscan4.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.sane.brscan4; @@ -6,66 +11,66 @@ let etcFiles = pkgs.callPackage ./brscan4_etc_files.nix { netDevices = netDeviceList; }; - netDeviceOpts = { name, ... }: { + netDeviceOpts = + { name, ... }: + { - options = { + options = { - name = lib.mkOption { - type = lib.types.str; - description = '' - The friendly name you give to the network device. If undefined, - the name of attribute will be used. - ''; + name = lib.mkOption { + type = lib.types.str; + description = '' + The friendly name you give to the network device. If undefined, + the name of attribute will be used. + ''; - example = "office1"; - }; + example = "office1"; + }; - model = lib.mkOption { - type = lib.types.str; - description = '' - The model of the network device. - ''; + model = lib.mkOption { + type = lib.types.str; + description = '' + The model of the network device. + ''; - example = "MFC-7860DW"; - }; + example = "MFC-7860DW"; + }; - ip = lib.mkOption { - type = with lib.types; nullOr str; - default = null; - description = '' - The ip address of the device. If undefined, you will have to - provide a nodename. - ''; + ip = lib.mkOption { + type = with lib.types; nullOr str; + default = null; + description = '' + The ip address of the device. If undefined, you will have to + provide a nodename. + ''; - example = "192.168.1.2"; - }; - - nodename = lib.mkOption { - type = with lib.types; nullOr str; - default = null; - description = '' - The node name of the device. If undefined, you will have to - provide an ip. - ''; + example = "192.168.1.2"; + }; - example = "BRW0080927AFBCE"; - }; + nodename = lib.mkOption { + type = with lib.types; nullOr str; + default = null; + description = '' + The node name of the device. If undefined, you will have to + provide an ip. + ''; - }; + example = "BRW0080927AFBCE"; + }; + }; - config = - { name = lib.mkDefault name; + config = { + name = lib.mkDefault name; }; - }; + }; in { options = { - hardware.sane.brscan4.enable = - lib.mkEnableOption "Brother's brscan4 scan backend" // { + hardware.sane.brscan4.enable = lib.mkEnableOption "Brother's brscan4 scan backend" // { description = '' When enabled, will automatically register the "brscan4" sane backend and bring configuration files to their expected location. @@ -73,11 +78,17 @@ in }; hardware.sane.brscan4.netDevices = lib.mkOption { - default = {}; - example = - { office1 = { model = "MFC-7860DW"; ip = "192.168.1.2"; }; - office2 = { model = "MFC-7860DW"; nodename = "BRW0080927AFBCE"; }; + default = { }; + example = { + office1 = { + model = "MFC-7860DW"; + ip = "192.168.1.2"; + }; + office2 = { + model = "MFC-7860DW"; + nodename = "BRW0080927AFBCE"; }; + }; type = with lib.types; attrsOf (submodule netDeviceOpts); description = '' The list of network devices that will be registered against the brscan4 @@ -92,11 +103,13 @@ in pkgs.brscan4 ]; - environment.etc."opt/brother/scanner/brscan4" = - { source = "${etcFiles}/etc/opt/brother/scanner/brscan4"; }; + environment.etc."opt/brother/scanner/brscan4" = { + source = "${etcFiles}/etc/opt/brother/scanner/brscan4"; + }; assertions = [ - { assertion = lib.all (x: !(null != x.ip && null != x.nodename)) netDeviceList; + { + assertion = lib.all (x: !(null != x.ip && null != x.nodename)) netDeviceList; message = '' When describing a network device as part of the attribute list `hardware.sane.brscan4.netDevices`, only one of its `ip` or `nodename` diff --git a/nixos/modules/services/hardware/sane_extra_backends/brscan4_etc_files.nix b/nixos/modules/services/hardware/sane_extra_backends/brscan4_etc_files.nix index f76ab701c5b9b1..8ec6b72cb5ea56 100644 --- a/nixos/modules/services/hardware/sane_extra_backends/brscan4_etc_files.nix +++ b/nixos/modules/services/hardware/sane_extra_backends/brscan4_etc_files.nix @@ -1,22 +1,25 @@ -{ stdenv, lib, brscan4, netDevices ? [] }: +{ + stdenv, + lib, + brscan4, + netDevices ? [ ], +}: /* + Testing + ------- -Testing -------- + No net devices: -No net devices: + ~~~ + nix-shell -E 'with import { }; brscan4-etc-files' + ~~~ -~~~ -nix-shell -E 'with import { }; brscan4-etc-files' -~~~ - -Two net devices: - -~~~ -nix-shell -E 'with import { }; brscan4-etc-files.override{netDevices=[{name="a"; model="MFC-7860DW"; nodename="BRW0080927AFBCE";} {name="b"; model="MFC-7860DW"; ip="192.168.1.2";}];}' -~~~ + Two net devices: + ~~~ + nix-shell -E 'with import { }; brscan4-etc-files.override{netDevices=[{name="a"; model="MFC-7860DW"; nodename="BRW0080927AFBCE";} {name="b"; model="MFC-7860DW"; ip="192.168.1.2";}];}' + ~~~ */ let @@ -25,9 +28,12 @@ let brsaneconfig4 -a \ name="${nd.name}" \ model="${nd.model}" \ - ${if (lib.hasAttr "nodename" nd && nd.nodename != null) then - ''nodename="${nd.nodename}"'' else - ''ip="${nd.ip}"''}''; + ${ + if (lib.hasAttr "nodename" nd && nd.nodename != null) then + ''nodename="${nd.nodename}"'' + else + ''ip="${nd.ip}"'' + }''; addAllNetDev = xs: lib.concatStringsSep "\n" (map addNetDev xs); in diff --git a/nixos/modules/services/hardware/sane_extra_backends/brscan5.nix b/nixos/modules/services/hardware/sane_extra_backends/brscan5.nix index 38330eb6921561..99c79c0a8bd507 100644 --- a/nixos/modules/services/hardware/sane_extra_backends/brscan5.nix +++ b/nixos/modules/services/hardware/sane_extra_backends/brscan5.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.sane.brscan5; @@ -6,73 +11,79 @@ let etcFiles = pkgs.callPackage ./brscan5_etc_files.nix { netDevices = netDeviceList; }; - netDeviceOpts = { name, ... }: { + netDeviceOpts = + { name, ... }: + { - options = { + options = { - name = lib.mkOption { - type = lib.types.str; - description = '' - The friendly name you give to the network device. If undefined, - the name of attribute will be used. - ''; + name = lib.mkOption { + type = lib.types.str; + description = '' + The friendly name you give to the network device. If undefined, + the name of attribute will be used. + ''; - example = "office1"; - }; + example = "office1"; + }; - model = lib.mkOption { - type = lib.types.str; - description = '' - The model of the network device. - ''; + model = lib.mkOption { + type = lib.types.str; + description = '' + The model of the network device. + ''; - example = "ADS-1200"; - }; + example = "ADS-1200"; + }; - ip = lib.mkOption { - type = with lib.types; nullOr str; - default = null; - description = '' - The ip address of the device. If undefined, you will have to - provide a nodename. - ''; + ip = lib.mkOption { + type = with lib.types; nullOr str; + default = null; + description = '' + The ip address of the device. If undefined, you will have to + provide a nodename. + ''; - example = "192.168.1.2"; - }; - - nodename = lib.mkOption { - type = with lib.types; nullOr str; - default = null; - description = '' - The node name of the device. If undefined, you will have to - provide an ip. - ''; + example = "192.168.1.2"; + }; - example = "BRW0080927AFBCE"; - }; + nodename = lib.mkOption { + type = with lib.types; nullOr str; + default = null; + description = '' + The node name of the device. If undefined, you will have to + provide an ip. + ''; - }; + example = "BRW0080927AFBCE"; + }; + }; - config = - { name = lib.mkDefault name; + config = { + name = lib.mkDefault name; }; - }; + }; in { options = { - hardware.sane.brscan5.enable = - lib.mkEnableOption "the Brother brscan5 sane backend"; + hardware.sane.brscan5.enable = lib.mkEnableOption "the Brother brscan5 sane backend"; hardware.sane.brscan5.netDevices = lib.mkOption { - default = {}; - example = - { office1 = { model = "MFC-7860DW"; ip = "192.168.1.2"; }; - office2 = { model = "MFC-7860DW"; nodename = "BRW0080927AFBCE"; }; + default = { }; + example = { + office1 = { + model = "MFC-7860DW"; + ip = "192.168.1.2"; + }; + office2 = { + model = "MFC-7860DW"; + nodename = "BRW0080927AFBCE"; }; + }; type = with lib.types; attrsOf (submodule netDeviceOpts); description = '' The list of network devices that will be registered against the brscan5 @@ -87,14 +98,18 @@ in pkgs.brscan5 ]; - environment.etc."opt/brother/scanner/brscan5" = - { source = "${etcFiles}/etc/opt/brother/scanner/brscan5"; }; - environment.etc."opt/brother/scanner/models" = - { source = "${etcFiles}/etc/opt/brother/scanner/brscan5/models"; }; - environment.etc."sane.d/dll.d/brother5.conf".source = "${pkgs.brscan5}/etc/sane.d/dll.d/brother5.conf"; + environment.etc."opt/brother/scanner/brscan5" = { + source = "${etcFiles}/etc/opt/brother/scanner/brscan5"; + }; + environment.etc."opt/brother/scanner/models" = { + source = "${etcFiles}/etc/opt/brother/scanner/brscan5/models"; + }; + environment.etc."sane.d/dll.d/brother5.conf".source = + "${pkgs.brscan5}/etc/sane.d/dll.d/brother5.conf"; assertions = [ - { assertion = lib.all (x: !(null != x.ip && null != x.nodename)) netDeviceList; + { + assertion = lib.all (x: !(null != x.ip && null != x.nodename)) netDeviceList; message = '' When describing a network device as part of the attribute list `hardware.sane.brscan5.netDevices`, only one of its `ip` or `nodename` diff --git a/nixos/modules/services/hardware/sane_extra_backends/brscan5_etc_files.nix b/nixos/modules/services/hardware/sane_extra_backends/brscan5_etc_files.nix index 432f0316a4fa82..9ad64c41ee69d1 100644 --- a/nixos/modules/services/hardware/sane_extra_backends/brscan5_etc_files.nix +++ b/nixos/modules/services/hardware/sane_extra_backends/brscan5_etc_files.nix @@ -1,32 +1,35 @@ -{ stdenv, lib, brscan5, netDevices ? [] }: +{ + stdenv, + lib, + brscan5, + netDevices ? [ ], +}: /* - -Testing -------- -From nixpkgs repo - -No net devices: - -~~~ -nix-build -E 'let pkgs = import ./. {}; - brscan5-etc-files = pkgs.callPackage (import ./nixos/modules/services/hardware/sane_extra_backends/brscan5_etc_files.nix) {}; - in brscan5-etc-files' -~~~ - -Two net devices: - -~~~ -nix-build -E 'let pkgs = import ./. {}; - brscan5-etc-files = pkgs.callPackage (import ./nixos/modules/services/hardware/sane_extra_backends/brscan5_etc_files.nix) {}; - in brscan5-etc-files.override { - netDevices = [ - {name="a"; model="ADS-1200"; nodename="BRW0080927AFBCE";} - {name="b"; model="ADS-1200"; ip="192.168.1.2";} - ]; - }' -~~~ - + Testing + ------- + From nixpkgs repo + + No net devices: + + ~~~ + nix-build -E 'let pkgs = import ./. {}; + brscan5-etc-files = pkgs.callPackage (import ./nixos/modules/services/hardware/sane_extra_backends/brscan5_etc_files.nix) {}; + in brscan5-etc-files' + ~~~ + + Two net devices: + + ~~~ + nix-build -E 'let pkgs = import ./. {}; + brscan5-etc-files = pkgs.callPackage (import ./nixos/modules/services/hardware/sane_extra_backends/brscan5_etc_files.nix) {}; + in brscan5-etc-files.override { + netDevices = [ + {name="a"; model="ADS-1200"; nodename="BRW0080927AFBCE";} + {name="b"; model="ADS-1200"; ip="192.168.1.2";} + ]; + }' + ~~~ */ let @@ -35,9 +38,12 @@ let brsaneconfig5 -a \ name="${nd.name}" \ model="${nd.model}" \ - ${if (lib.hasAttr "nodename" nd && nd.nodename != null) then - ''nodename="${nd.nodename}"'' else - ''ip="${nd.ip}"''}''; + ${ + if (lib.hasAttr "nodename" nd && nd.nodename != null) then + ''nodename="${nd.nodename}"'' + else + ''ip="${nd.ip}"'' + }''; addAllNetDev = xs: lib.concatStringsSep "\n" (map addNetDev xs); in diff --git a/nixos/modules/services/hardware/sane_extra_backends/dsseries.nix b/nixos/modules/services/hardware/sane_extra_backends/dsseries.nix index 49de9d94b427d7..0ec2eff956bec6 100644 --- a/nixos/modules/services/hardware/sane_extra_backends/dsseries.nix +++ b/nixos/modules/services/hardware/sane_extra_backends/dsseries.nix @@ -1,9 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { options = { - hardware.sane.dsseries.enable = - lib.mkEnableOption "Brother DSSeries scan backend" // { + hardware.sane.dsseries.enable = lib.mkEnableOption "Brother DSSeries scan backend" // { description = '' When enabled, will automatically register the "dsseries" SANE backend. diff --git a/nixos/modules/services/hardware/supergfxd.nix b/nixos/modules/services/hardware/supergfxd.nix index 62296014a8dc38..dd571b4fa546b1 100644 --- a/nixos/modules/services/hardware/supergfxd.nix +++ b/nixos/modules/services/hardware/supergfxd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.supergfxd; @@ -32,7 +37,10 @@ in systemd.packages = [ pkgs.supergfxctl ]; systemd.services.supergfxd.wantedBy = [ "multi-user.target" ]; - systemd.services.supergfxd.path = [ pkgs.kmod pkgs.pciutils ]; + systemd.services.supergfxd.path = [ + pkgs.kmod + pkgs.pciutils + ]; services.dbus.packages = [ pkgs.supergfxctl ]; services.udev.packages = [ pkgs.supergfxctl ]; diff --git a/nixos/modules/services/hardware/tcsd.nix b/nixos/modules/services/hardware/tcsd.nix index 24bb20b0146dec..7451e58b016e38 100644 --- a/nixos/modules/services/hardware/tcsd.nix +++ b/nixos/modules/services/hardware/tcsd.nix @@ -1,5 +1,11 @@ # tcsd daemon. -{ config, options, pkgs, lib, ... }: +{ + config, + options, + pkgs, + lib, + ... +}: let cfg = config.services.tcsd; @@ -154,6 +160,6 @@ in }; }; - users.groups = lib.optionalAttrs (cfg.group == "tss") { tss = {}; }; + users.groups = lib.optionalAttrs (cfg.group == "tss") { tss = { }; }; }; } diff --git a/nixos/modules/services/hardware/thermald.nix b/nixos/modules/services/hardware/thermald.nix index d7f706f1ef0529..9df57e8650e11c 100644 --- a/nixos/modules/services/hardware/thermald.nix +++ b/nixos/modules/services/hardware/thermald.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.thermald; in @@ -16,7 +21,7 @@ in ''; }; - ignoreCpuidCheck = lib.mkOption { + ignoreCpuidCheck = lib.mkOption { type = lib.types.bool; default = false; description = "Whether to ignore the cpuid check to allow running on unsupported platforms"; diff --git a/nixos/modules/services/hardware/thinkfan.nix b/nixos/modules/services/hardware/thinkfan.nix index 9733fbe5aa15ec..01c61a0e814766 100644 --- a/nixos/modules/services/hardware/thinkfan.nix +++ b/nixos/modules/services/hardware/thinkfan.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.thinkfan; @@ -7,77 +12,107 @@ let thinkfan = pkgs.thinkfan.override { inherit (cfg) smartSupport; }; # fan-speed and temperature levels - levelType = with lib.types; + levelType = + with lib.types; let - tuple = ts: lib.mkOptionType { - name = "tuple"; - merge = lib.mergeOneOption; - check = xs: lib.all lib.id (lib.zipListsWith (t: x: t.check x) ts xs); - description = "tuple of" + lib.concatMapStrings (t: " (${t.description})") ts; - }; + tuple = + ts: + lib.mkOptionType { + name = "tuple"; + merge = lib.mergeOneOption; + check = xs: lib.all lib.id (lib.zipListsWith (t: x: t.check x) ts xs); + description = "tuple of" + lib.concatMapStrings (t: " (${t.description})") ts; + }; level = ints.unsigned; - special = enum [ "level auto" "level full-speed" "level disengaged" ]; + special = enum [ + "level auto" + "level full-speed" + "level disengaged" + ]; in - tuple [ (either level special) level level ]; + tuple [ + (either level special) + level + level + ]; # sensor or fan config - sensorType = name: lib.types.submodule { - freeformType = lib.types.attrsOf settingsFormat.type; - options = { - type = lib.mkOption { - type = lib.types.enum [ "hwmon" "atasmart" "tpacpi" "nvml" ]; - description = '' - The ${name} type, can be - `hwmon` for standard ${name}s, - - `atasmart` to read the temperature via - S.M.A.R.T (requires smartSupport to be enabled), - - `tpacpi` for the legacy thinkpac_acpi driver, or - - `nvml` for the (proprietary) nVidia driver. - ''; - }; - query = lib.mkOption { - type = lib.types.str; - description = '' - The query string used to match one or more ${name}s: can be - a fullpath to the temperature file (single ${name}) or a fullpath - to a driver directory (multiple ${name}s). - - ::: {.note} - When multiple ${name}s match, the query can be restricted using the - {option}`name` or {option}`indices` options. - ::: - ''; - }; - indices = lib.mkOption { - type = with lib.types; nullOr (listOf ints.unsigned); - default = null; - description = '' - A list of ${name}s to pick in case multiple ${name}s match the query. - - ::: {.note} - Indices start from 0. - ::: - ''; - }; - } // lib.optionalAttrs (name == "sensor") { - correction = lib.mkOption { - type = with lib.types; nullOr (listOf int); - default = null; - description = '' - A list of values to be added to the temperature of each sensor, - can be used to equalize small discrepancies in temperature ratings. - ''; - }; + sensorType = + name: + lib.types.submodule { + freeformType = lib.types.attrsOf settingsFormat.type; + options = + { + type = lib.mkOption { + type = lib.types.enum [ + "hwmon" + "atasmart" + "tpacpi" + "nvml" + ]; + description = '' + The ${name} type, can be + `hwmon` for standard ${name}s, + + `atasmart` to read the temperature via + S.M.A.R.T (requires smartSupport to be enabled), + + `tpacpi` for the legacy thinkpac_acpi driver, or + + `nvml` for the (proprietary) nVidia driver. + ''; + }; + query = lib.mkOption { + type = lib.types.str; + description = '' + The query string used to match one or more ${name}s: can be + a fullpath to the temperature file (single ${name}) or a fullpath + to a driver directory (multiple ${name}s). + + ::: {.note} + When multiple ${name}s match, the query can be restricted using the + {option}`name` or {option}`indices` options. + ::: + ''; + }; + indices = lib.mkOption { + type = with lib.types; nullOr (listOf ints.unsigned); + default = null; + description = '' + A list of ${name}s to pick in case multiple ${name}s match the query. + + ::: {.note} + Indices start from 0. + ::: + ''; + }; + } + // lib.optionalAttrs (name == "sensor") { + correction = lib.mkOption { + type = with lib.types; nullOr (listOf int); + default = null; + description = '' + A list of values to be added to the temperature of each sensor, + can be used to equalize small discrepancies in temperature ratings. + ''; + }; + }; }; - }; # removes NixOS special and unused attributes - sensorToConf = { type, query, ... }@args: - (lib.filterAttrs (k: v: v != null && !(lib.elem k ["type" "query"])) args) - // { "${type}" = query; }; + sensorToConf = + { type, query, ... }@args: + (lib.filterAttrs ( + k: v: + v != null + && !(lib.elem k [ + "type" + "query" + ]) + ) args) + // { + "${type}" = query; + }; syntaxNote = name: '' ::: {.note} @@ -94,7 +129,8 @@ let ::: ''; -in { +in +{ options = { @@ -126,7 +162,8 @@ in { sensors = lib.mkOption { type = lib.types.listOf (sensorType "sensor"); default = [ - { type = "tpacpi"; + { + type = "tpacpi"; query = "/proc/acpi/ibm/thermal"; } ]; @@ -140,7 +177,8 @@ in { fans = lib.mkOption { type = lib.types.listOf (sensorType "fan"); default = [ - { type = "tpacpi"; + { + type = "tpacpi"; query = "/proc/acpi/ibm/fan"; } ]; @@ -154,13 +192,41 @@ in { levels = lib.mkOption { type = lib.types.listOf levelType; default = [ - [0 0 55] - [1 48 60] - [2 50 61] - [3 52 63] - [6 56 65] - [7 60 85] - ["level auto" 80 32767] + [ + 0 + 0 + 55 + ] + [ + 1 + 48 + 60 + ] + [ + 2 + 50 + 61 + ] + [ + 3 + 52 + 63 + ] + [ + 6 + 56 + 65 + ] + [ + 7 + 60 + 85 + ] + [ + "level auto" + 80 + 32767 + ] ]; description = '' [LEVEL LOW HIGH] @@ -177,7 +243,10 @@ in { extraArgs = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "-b" "0" ]; + example = [ + "-b" + "0" + ]; description = '' A list of extra command line arguments to pass to thinkfan. Check the thinkfan(1) manpage for available arguments. @@ -206,14 +275,20 @@ in { services.thinkfan.settings = lib.mapAttrs (k: v: lib.mkDefault v) { sensors = map sensorToConf cfg.sensors; - fans = map sensorToConf cfg.fans; - levels = cfg.levels; + fans = map sensorToConf cfg.fans; + levels = cfg.levels; }; systemd.packages = [ thinkfan ]; systemd.services = { - thinkfan.environment.THINKFAN_ARGS = lib.escapeShellArgs ([ "-c" configFile ] ++ cfg.extraArgs); + thinkfan.environment.THINKFAN_ARGS = lib.escapeShellArgs ( + [ + "-c" + configFile + ] + ++ cfg.extraArgs + ); thinkfan.serviceConfig = { Restart = "on-failure"; RestartSec = "30s"; diff --git a/nixos/modules/services/hardware/throttled.nix b/nixos/modules/services/hardware/throttled.nix index 30f10b3361a601..c3f391515e5caf 100644 --- a/nixos/modules/services/hardware/throttled.nix +++ b/nixos/modules/services/hardware/throttled.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.throttled; -in { +in +{ options = { services.throttled = { enable = lib.mkEnableOption "fix for Intel CPU throttling"; @@ -20,9 +26,10 @@ in { systemd.services.throttled.wantedBy = [ "multi-user.target" ]; environment.etc."throttled.conf".source = - if cfg.extraConfig != "" - then pkgs.writeText "throttled.conf" cfg.extraConfig - else "${pkgs.throttled}/etc/throttled.conf"; + if cfg.extraConfig != "" then + pkgs.writeText "throttled.conf" cfg.extraConfig + else + "${pkgs.throttled}/etc/throttled.conf"; hardware.cpu.x86.msr.enable = true; # Kernel 5.9 spams warnings whenever userspace writes to CPU MSRs. diff --git a/nixos/modules/services/hardware/trezord.nix b/nixos/modules/services/hardware/trezord.nix index b7642e476936ac..d9f342d6ea46c1 100644 --- a/nixos/modules/services/hardware/trezord.nix +++ b/nixos/modules/services/hardware/trezord.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.trezord; -in { +in +{ ### docs @@ -26,15 +32,15 @@ in { default = false; description = '' Enable Trezor emulator support. - ''; - }; + ''; + }; emulator.port = lib.mkOption { type = lib.types.port; default = 21324; description = '' Listening port for the Trezor emulator. - ''; + ''; }; }; }; @@ -48,7 +54,7 @@ in { description = "Trezor Bridge"; after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; - path = []; + path = [ ]; serviceConfig = { Type = "simple"; ExecStart = "${pkgs.trezord}/bin/trezord-go ${lib.optionalString cfg.emulator.enable "-e ${builtins.toString cfg.emulator.port}"}"; @@ -62,7 +68,6 @@ in { isSystemUser = true; }; - users.groups.trezord = {}; + users.groups.trezord = { }; }; } - diff --git a/nixos/modules/services/hardware/tuxedo-rs.nix b/nixos/modules/services/hardware/tuxedo-rs.nix index 4ba7825ae8a53a..aa292f305151e4 100644 --- a/nixos/modules/services/hardware/tuxedo-rs.nix +++ b/nixos/modules/services/hardware/tuxedo-rs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.hardware.tuxedo-rs; @@ -12,35 +17,37 @@ in }; }; - config = lib.mkIf cfg.enable (lib.mkMerge [ - { - hardware.tuxedo-drivers.enable = true; - - systemd = { - services.tailord = { - enable = true; - description = "Tuxedo Tailor hardware control service"; - after = [ "systemd-logind.service" ]; - wantedBy = [ "multi-user.target" ]; - - serviceConfig = { - Type = "dbus"; - BusName = "com.tux.Tailor"; - ExecStart = "${pkgs.tuxedo-rs}/bin/tailord"; - Environment = "RUST_BACKTRACE=1"; - Restart = "on-failure"; + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + { + hardware.tuxedo-drivers.enable = true; + + systemd = { + services.tailord = { + enable = true; + description = "Tuxedo Tailor hardware control service"; + after = [ "systemd-logind.service" ]; + wantedBy = [ "multi-user.target" ]; + + serviceConfig = { + Type = "dbus"; + BusName = "com.tux.Tailor"; + ExecStart = "${pkgs.tuxedo-rs}/bin/tailord"; + Environment = "RUST_BACKTRACE=1"; + Restart = "on-failure"; + }; }; }; - }; - services.dbus.packages = [ pkgs.tuxedo-rs ]; + services.dbus.packages = [ pkgs.tuxedo-rs ]; - environment.systemPackages = [ pkgs.tuxedo-rs ]; - } - (lib.mkIf cfg.tailor-gui.enable { - environment.systemPackages = [ pkgs.tailor-gui ]; - }) - ]); + environment.systemPackages = [ pkgs.tuxedo-rs ]; + } + (lib.mkIf cfg.tailor-gui.enable { + environment.systemPackages = [ pkgs.tailor-gui ]; + }) + ] + ); meta.maintainers = with lib.maintainers; [ mrcjkb ]; } diff --git a/nixos/modules/services/hardware/udisks2.nix b/nixos/modules/services/hardware/udisks2.nix index 1cdb70c24ee34e..88e24fea6c72c0 100644 --- a/nixos/modules/services/hardware/udisks2.nix +++ b/nixos/modules/services/hardware/udisks2.nix @@ -1,11 +1,18 @@ # Udisks daemon. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.udisks2; settingsFormat = pkgs.formats.ini { - listToValue = lib.concatMapStringsSep "," (lib.generators.mkValueStringDefault {}); + listToValue = lib.concatMapStringsSep "," (lib.generators.mkValueStringDefault { }); }; - configFiles = lib.mapAttrs (name: value: (settingsFormat.generate name value)) (lib.mapAttrs' (name: value: lib.nameValuePair name value ) config.services.udisks2.settings); + configFiles = lib.mapAttrs (name: value: (settingsFormat.generate name value)) ( + lib.mapAttrs' (name: value: lib.nameValuePair name value) config.services.udisks2.settings + ); in { @@ -18,7 +25,7 @@ in enable = lib.mkEnableOption "udisks2, a DBus service that allows applications to query and manipulate storage devices"; - package = lib.mkPackageOption pkgs "udisks2" {}; + package = lib.mkPackageOption pkgs "udisks2" { }; mountOnMedia = lib.mkOption { type = lib.types.bool; @@ -45,13 +52,13 @@ in }; }; example = lib.literalExpression '' - { - "WDC-WD10EZEX-60M2NA0-WD-WCC3F3SJ0698.conf" = { - ATA = { - StandbyTimeout = 50; + { + "WDC-WD10EZEX-60M2NA0-WD-WCC3F3SJ0698.conf" = { + ATA = { + StandbyTimeout = 50; + }; }; }; - }; ''; description = '' Options passed to udisksd. @@ -64,30 +71,36 @@ in }; - ###### implementation config = lib.mkIf config.services.udisks2.enable { environment.systemPackages = [ cfg.package ]; - environment.etc = (lib.mapAttrs' (name: value: lib.nameValuePair "udisks2/${name}" { source = value; } ) configFiles) // ( - let - libblockdev = cfg.package.libblockdev; - majorVer = lib.versions.major libblockdev.version; - in { - # We need to make sure /etc/libblockdev/@major_ver@/conf.d is populated to avoid - # warnings - "libblockdev/${majorVer}/conf.d/00-default.cfg".source = "${libblockdev}/etc/libblockdev/${majorVer}/conf.d/00-default.cfg"; - "libblockdev/${majorVer}/conf.d/10-lvm-dbus.cfg".source = "${libblockdev}/etc/libblockdev/${majorVer}/conf.d/10-lvm-dbus.cfg"; - }); + environment.etc = + (lib.mapAttrs' (name: value: lib.nameValuePair "udisks2/${name}" { source = value; }) configFiles) + // ( + let + libblockdev = cfg.package.libblockdev; + majorVer = lib.versions.major libblockdev.version; + in + { + # We need to make sure /etc/libblockdev/@major_ver@/conf.d is populated to avoid + # warnings + "libblockdev/${majorVer}/conf.d/00-default.cfg".source = + "${libblockdev}/etc/libblockdev/${majorVer}/conf.d/00-default.cfg"; + "libblockdev/${majorVer}/conf.d/10-lvm-dbus.cfg".source = + "${libblockdev}/etc/libblockdev/${majorVer}/conf.d/10-lvm-dbus.cfg"; + } + ); security.polkit.enable = true; services.dbus.packages = [ cfg.package ]; - systemd.tmpfiles.rules = [ "d /var/lib/udisks2 0755 root root -" ] - ++ lib.optional cfg.mountOnMedia "D! /media 0755 root root -"; + systemd.tmpfiles.rules = [ + "d /var/lib/udisks2 0755 root root -" + ] ++ lib.optional cfg.mountOnMedia "D! /media 0755 root root -"; services.udev.packages = [ cfg.package ]; diff --git a/nixos/modules/services/hardware/undervolt.nix b/nixos/modules/services/hardware/undervolt.nix index 1fce225db3669f..5a8ad9806ef1d2 100644 --- a/nixos/modules/services/hardware/undervolt.nix +++ b/nixos/modules/services/hardware/undervolt.nix @@ -1,12 +1,22 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.undervolt; - mkPLimit = limit: window: - if (limit == null && window == null) then null - else assert lib.asserts.assertMsg (limit != null && window != null) "Both power limit and window must be set"; + mkPLimit = + limit: window: + if (limit == null && window == null) then + null + else + assert lib.asserts.assertMsg ( + limit != null && window != null + ) "Both power limit and window must be set"; "${toString limit} ${toString window}"; - cliArgs = lib.cli.toGNUCommandLine {} { + cliArgs = lib.cli.toGNUCommandLine { } { inherit (cfg) verbose temp @@ -33,9 +43,9 @@ in { options.services.undervolt = { enable = lib.mkEnableOption '' - Undervolting service for Intel CPUs. + Undervolting service for Intel CPUs. - Warning: This service is not endorsed by Intel and may permanently damage your hardware. Use at your own risk + Warning: This service is not endorsed by Intel and may permanently damage your hardware. Use at your own risk ''; verbose = lib.mkOption { @@ -121,7 +131,12 @@ in ''; }; p1.window = lib.mkOption { - type = with lib.types; nullOr (oneOf [ float int ]); + type = + with lib.types; + nullOr (oneOf [ + float + int + ]); default = null; description = '' The P1 Time Window in seconds. @@ -138,7 +153,12 @@ in ''; }; p2.window = lib.mkOption { - type = with lib.types; nullOr (oneOf [ float int ]); + type = + with lib.types; + nullOr (oneOf [ + float + int + ]); default = null; description = '' The P2 Time Window in seconds. @@ -167,7 +187,10 @@ in description = "Intel Undervolting Service"; # Apply undervolt on boot, nixos generation switch and resume - wantedBy = [ "multi-user.target" "post-resume.target" ]; + wantedBy = [ + "multi-user.target" + "post-resume.target" + ]; after = [ "post-resume.target" ]; # Not sure why but it won't work without this serviceConfig = { diff --git a/nixos/modules/services/hardware/usbmuxd.nix b/nixos/modules/services/hardware/usbmuxd.nix index c1b76ddce3b713..23c54bab54b007 100644 --- a/nixos/modules/services/hardware/usbmuxd.nix +++ b/nixos/modules/services/hardware/usbmuxd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let defaultUserGroup = "usbmux"; @@ -43,7 +48,10 @@ in default = pkgs.usbmuxd; defaultText = lib.literalExpression "pkgs.usbmuxd"; description = "Which package to use for the usbmuxd daemon."; - relatedPackages = [ "usbmuxd" "usbmuxd2" ]; + relatedPackages = [ + "usbmuxd" + "usbmuxd2" + ]; }; }; diff --git a/nixos/modules/services/hardware/usbrelayd.nix b/nixos/modules/services/hardware/usbrelayd.nix index 38047c4e44cabb..67c5e132e2ecee 100644 --- a/nixos/modules/services/hardware/usbrelayd.nix +++ b/nixos/modules/services/hardware/usbrelayd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.usbrelayd; in diff --git a/nixos/modules/services/hardware/vdr.nix b/nixos/modules/services/hardware/vdr.nix index 6adab680257ff5..59aaffcb126461 100644 --- a/nixos/modules/services/hardware/vdr.nix +++ b/nixos/modules/services/hardware/vdr.nix @@ -1,9 +1,20 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.vdr; inherit (lib) - mkEnableOption mkPackageOption mkOption types mkIf optional; + mkEnableOption + mkPackageOption + mkOption + types + mkIf + optional + ; in { options = { @@ -59,16 +70,16 @@ in description = "VDR"; wantedBy = [ "multi-user.target" ]; wants = optional cfg.enableLirc "lircd.service"; - after = [ "network.target" ] - ++ optional cfg.enableLirc "lircd.service"; + after = [ "network.target" ] ++ optional cfg.enableLirc "lircd.service"; serviceConfig = { ExecStart = let - args = [ - "--video=${cfg.videoDir}" - ] - ++ optional cfg.enableLirc "--lirc=${config.passthru.lirc.socket}" - ++ cfg.extraArguments; + args = + [ + "--video=${cfg.videoDir}" + ] + ++ optional cfg.enableLirc "--lirc=${config.passthru.lirc.socket}" + ++ cfg.extraArguments; in "${cfg.package}/bin/vdr ${lib.escapeShellArgs args}"; User = cfg.user; @@ -90,8 +101,7 @@ in extraGroups = [ "video" "audio" - ] - ++ optional cfg.enableLirc "lirc"; + ] ++ optional cfg.enableLirc "lirc"; }; }; diff --git a/nixos/modules/services/home-automation/ebusd.nix b/nixos/modules/services/home-automation/ebusd.nix index 0a83bed6ff0111..b04da56b6d14cb 100644 --- a/nixos/modules/services/home-automation/ebusd.nix +++ b/nixos/modules/services/home-automation/ebusd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.ebusd; in @@ -38,7 +43,7 @@ in type = lib.types.bool; default = false; description = '' - Only read from device, never write to it + Only read from device, never write to it ''; }; @@ -60,18 +65,40 @@ in ''; }; - logs = let - # "all" must come first so it can be overridden by more specific areas - areas = [ "all" "main" "network" "bus" "update" "other" ]; - levels = [ "none" "error" "notice" "info" "debug" ]; - in lib.listToAttrs (map (area: lib.nameValuePair area (lib.mkOption { - type = lib.types.enum levels; - default = "notice"; - example = "debug"; - description = '' - Only write log for matching `AREA`s (${lib.concatStringsSep "|" areas}) below or equal to `LEVEL` (${lib.concatStringsSep "|" levels}) - ''; - })) areas); + logs = + let + # "all" must come first so it can be overridden by more specific areas + areas = [ + "all" + "main" + "network" + "bus" + "update" + "other" + ]; + levels = [ + "none" + "error" + "notice" + "info" + "debug" + ]; + in + lib.listToAttrs ( + map ( + area: + lib.nameValuePair area ( + lib.mkOption { + type = lib.types.enum levels; + default = "notice"; + example = "debug"; + description = '' + Only write log for matching `AREA`s (${lib.concatStringsSep "|" areas}) below or equal to `LEVEL` (${lib.concatStringsSep "|" levels}) + ''; + } + ) + ) areas + ); mqtt = { enable = lib.mkEnableOption "support for MQTT"; @@ -119,82 +146,94 @@ in extraArguments = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Extra arguments to the ebus daemon ''; }; }; - config = let - usesDev = lib.hasPrefix "/" cfg.device; - in lib.mkIf cfg.enable { - systemd.services.ebusd = { - description = "EBUSd Service"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - serviceConfig = { - ExecStart = let - args = lib.cli.toGNUCommandLineShell { optionValueSeparator = "="; } (lib.foldr (a: b: a // b) { } [ - { - inherit (cfg) device port configpath scanconfig readonly; - foreground = true; - updatecheck = "off"; - log = lib.mapAttrsToList (name: value: "${name}:${value}") cfg.logs; - mqttretain = cfg.mqtt.retain; - } - (lib.optionalAttrs cfg.mqtt.enable { - mqtthost = cfg.mqtt.host; - mqttport = cfg.mqtt.port; - mqttuser = cfg.mqtt.user; - mqttpass = cfg.mqtt.password; - }) - (lib.optionalAttrs cfg.mqtt.home-assistant { - mqttint = "${cfg.package}/etc/ebusd/mqtt-hassio.cfg"; - mqttjson = true; - }) - ]); - in "${cfg.package}/bin/ebusd ${args} ${lib.escapeShellArgs cfg.extraArguments}"; - - DynamicUser = true; - Restart = "on-failure"; - - # Hardening - CapabilityBoundingSet = ""; - DeviceAllow = lib.optionals usesDev [ cfg.device ]; - DevicePolicy = "closed"; - LockPersonality = true; - MemoryDenyWriteExecute = false; - NoNewPrivileges = true; - PrivateDevices = usesDev; - PrivateUsers = true; - PrivateTmp = true; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - ProcSubset = "pid"; - ProtectSystem = "strict"; - RemoveIPC = true; - RestrictAddressFamilies = [ - "AF_INET" - "AF_INET6" - ]; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SupplementaryGroups = [ "dialout" ]; - SystemCallArchitectures = "native"; - SystemCallFilter = [ - "@system-service @pkey" - "~@privileged @resources" - ]; - UMask = "0077"; + config = + let + usesDev = lib.hasPrefix "/" cfg.device; + in + lib.mkIf cfg.enable { + systemd.services.ebusd = { + description = "EBUSd Service"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + serviceConfig = { + ExecStart = + let + args = lib.cli.toGNUCommandLineShell { optionValueSeparator = "="; } ( + lib.foldr (a: b: a // b) { } [ + { + inherit (cfg) + device + port + configpath + scanconfig + readonly + ; + foreground = true; + updatecheck = "off"; + log = lib.mapAttrsToList (name: value: "${name}:${value}") cfg.logs; + mqttretain = cfg.mqtt.retain; + } + (lib.optionalAttrs cfg.mqtt.enable { + mqtthost = cfg.mqtt.host; + mqttport = cfg.mqtt.port; + mqttuser = cfg.mqtt.user; + mqttpass = cfg.mqtt.password; + }) + (lib.optionalAttrs cfg.mqtt.home-assistant { + mqttint = "${cfg.package}/etc/ebusd/mqtt-hassio.cfg"; + mqttjson = true; + }) + ] + ); + in + "${cfg.package}/bin/ebusd ${args} ${lib.escapeShellArgs cfg.extraArguments}"; + + DynamicUser = true; + Restart = "on-failure"; + + # Hardening + CapabilityBoundingSet = ""; + DeviceAllow = lib.optionals usesDev [ cfg.device ]; + DevicePolicy = "closed"; + LockPersonality = true; + MemoryDenyWriteExecute = false; + NoNewPrivileges = true; + PrivateDevices = usesDev; + PrivateUsers = true; + PrivateTmp = true; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + ProcSubset = "pid"; + ProtectSystem = "strict"; + RemoveIPC = true; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SupplementaryGroups = [ "dialout" ]; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service @pkey" + "~@privileged @resources" + ]; + UMask = "0077"; + }; }; }; - }; } diff --git a/nixos/modules/services/home-automation/esphome.nix b/nixos/modules/services/home-automation/esphome.nix index faae5ec8ff45ce..0673454aab89cc 100644 --- a/nixos/modules/services/home-automation/esphome.nix +++ b/nixos/modules/services/home-automation/esphome.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) @@ -15,9 +20,10 @@ let stateDir = "/var/lib/esphome"; esphomeParams = - if cfg.enableUnixSocket - then "--socket /run/esphome/esphome.sock" - else "--address ${cfg.address} --port ${toString cfg.port}"; + if cfg.enableUnixSocket then + "--socket /run/esphome/esphome.sock" + else + "--address ${cfg.address} --port ${toString cfg.port}"; in { meta.maintainers = with maintainers; [ oddlama ]; @@ -52,8 +58,13 @@ in }; allowedDevices = mkOption { - default = ["char-ttyS" "char-ttyUSB"]; - example = ["/dev/serial/by-id/usb-Silicon_Labs_CP2102_USB_to_UART_Bridge_Controller_0001-if00-port0"]; + default = [ + "char-ttyS" + "char-ttyUSB" + ]; + example = [ + "/dev/serial/by-id/usb-Silicon_Labs_CP2102_USB_to_UART_Bridge_Controller_0001-if00-port0" + ]; description = '' A list of device nodes to which {command}`esphome` has access to. Refer to DeviceAllow in systemd.resource-control(5) for more information. @@ -71,13 +82,13 @@ in }; config = mkIf cfg.enable { - networking.firewall.allowedTCPPorts = mkIf (cfg.openFirewall && !cfg.enableUnixSocket) [cfg.port]; + networking.firewall.allowedTCPPorts = mkIf (cfg.openFirewall && !cfg.enableUnixSocket) [ cfg.port ]; systemd.services.esphome = { description = "ESPHome dashboard"; - after = ["network.target"]; - wantedBy = ["multi-user.target"]; - path = [cfg.package]; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + path = [ cfg.package ]; environment = { # platformio fails to determine the home directory when using DynamicUser @@ -102,7 +113,7 @@ in MemoryDenyWriteExecute = true; DevicePolicy = "closed"; DeviceAllow = map (d: "${d} rw") cfg.allowedDevices; - SupplementaryGroups = ["dialout"]; + SupplementaryGroups = [ "dialout" ]; #NoNewPrivileges = true; # Implied by DynamicUser PrivateUsers = true; #PrivateTmp = true; # Implied by DynamicUser diff --git a/nixos/modules/services/home-automation/evcc.nix b/nixos/modules/services/home-automation/evcc.nix index 5e97b8c90d2388..df64f99f5b0246 100644 --- a/nixos/modules/services/home-automation/evcc.nix +++ b/nixos/modules/services/home-automation/evcc.nix @@ -1,12 +1,13 @@ -{ lib -, pkgs -, config -, ... +{ + lib, + pkgs, + config, + ... }: let cfg = config.services.evcc; - format = pkgs.formats.yaml {}; + format = pkgs.formats.yaml { }; configFile = format.generate "evcc.yml" cfg.settings; package = pkgs.evcc; @@ -20,7 +21,7 @@ in extraArgs = lib.mkOption { type = listOf str; - default = []; + default = [ ]; description = '' Extra arguments to pass to the evcc executable. ''; @@ -72,7 +73,7 @@ in PrivateUsers = true; ProcSubset = "pid"; ProtectClock = true; - ProtectControlGroups= true; + ProtectControlGroups = true; ProtectHome = true; ProtectHostname = true; ProtectKernelLogs = true; diff --git a/nixos/modules/services/home-automation/govee2mqtt.nix b/nixos/modules/services/home-automation/govee2mqtt.nix index 1dee5999fa3bef..fe4063935adc4d 100644 --- a/nixos/modules/services/home-automation/govee2mqtt.nix +++ b/nixos/modules/services/home-automation/govee2mqtt.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.govee2mqtt; -in { +in +{ meta.maintainers = with lib.maintainers; [ SuperSandro2000 ]; options.services.govee2mqtt = { @@ -53,7 +59,8 @@ in { "GOVEE_CACHE_DIR=/var/cache/govee2mqtt" ]; EnvironmentFile = cfg.environmentFile; - ExecStart = "${lib.getExe cfg.package} serve --govee-iot-key=/var/lib/govee2mqtt/iot.key --govee-iot-cert=/var/lib/govee2mqtt/iot.cert" + ExecStart = + "${lib.getExe cfg.package} serve --govee-iot-key=/var/lib/govee2mqtt/iot.key --govee-iot-cert=/var/lib/govee2mqtt/iot.cert" + " --amazon-root-ca=${pkgs.cacert.unbundled}/etc/ssl/certs/Amazon_Root_CA_1:66c9fcf99bf8c0a39e2f0788a43e696365bca.crt"; Group = cfg.group; Restart = "on-failure"; diff --git a/nixos/modules/services/home-automation/matter-server.nix b/nixos/modules/services/home-automation/matter-server.nix index 8a59815eec66de..b05991148c4ee2 100644 --- a/nixos/modules/services/home-automation/matter-server.nix +++ b/nixos/modules/services/home-automation/matter-server.nix @@ -1,7 +1,8 @@ -{ lib -, pkgs -, config -, ... +{ + lib, + pkgs, + config, + ... }: let cfg = config.services.matter-server; @@ -25,14 +26,20 @@ in }; logLevel = lib.mkOption { - type = lib.types.enum [ "critical" "error" "warning" "info" "debug" ]; + type = lib.types.enum [ + "critical" + "error" + "warning" + "info" + "debug" + ]; default = "info"; description = "Verbosity of logs from the matter-server"; }; extraArgs = lib.mkOption { type = listOf str; - default = []; + default = [ ]; description = '' Extra arguments to pass to the matter-server executable. See https://github.com/home-assistant-libs/python-matter-server?tab=readme-ov-file#running-the-development-server for options. @@ -49,14 +56,20 @@ in description = "Matter Server"; environment.HOME = storagePath; serviceConfig = { - ExecStart = (lib.concatStringsSep " " [ - "${cfg.package}/bin/matter-server" - "--port" (toString cfg.port) - "--vendorid" vendorId - "--storage-path" storagePath - "--log-level" "${cfg.logLevel}" - "${lib.escapeShellArgs cfg.extraArgs}" - ]); + ExecStart = ( + lib.concatStringsSep " " [ + "${cfg.package}/bin/matter-server" + "--port" + (toString cfg.port) + "--vendorid" + vendorId + "--storage-path" + storagePath + "--log-level" + "${cfg.logLevel}" + "${lib.escapeShellArgs cfg.extraArgs}" + ] + ); # Start with a clean root filesystem, and allowlist what the container # is permitted to access. TemporaryFileSystem = "/"; @@ -119,4 +132,3 @@ in }; }; } - diff --git a/nixos/modules/services/home-automation/wyoming/faster-whisper.nix b/nixos/modules/services/home-automation/wyoming/faster-whisper.nix index 691ffab6464ad3..69407efba0c617 100644 --- a/nixos/modules/services/home-automation/wyoming/faster-whisper.nix +++ b/nixos/modules/services/home-automation/wyoming/faster-whisper.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let @@ -26,153 +27,268 @@ in package = mkPackageOption pkgs "wyoming-faster-whisper" { }; servers = mkOption { - default = {}; + default = { }; description = '' Attribute set of faster-whisper instances to spawn. ''; - type = types.attrsOf (types.submodule ( - { ... }: { - options = { - enable = mkEnableOption "Wyoming faster-whisper server"; + type = types.attrsOf ( + types.submodule ( + { ... }: + { + options = { + enable = mkEnableOption "Wyoming faster-whisper server"; - model = mkOption { - type = str; - default = "tiny-int8"; - example = "Systran/faster-distil-whisper-small.en"; - description = '' - Name of the voice model to use. + model = mkOption { + type = str; + default = "tiny-int8"; + example = "Systran/faster-distil-whisper-small.en"; + description = '' + Name of the voice model to use. - Check the [2.0.0 release notes](https://github.com/rhasspy/wyoming-faster-whisper/releases/tag/v2.0.0) for possible values. - ''; - }; + Check the [2.0.0 release notes](https://github.com/rhasspy/wyoming-faster-whisper/releases/tag/v2.0.0) for possible values. + ''; + }; - uri = mkOption { - type = strMatching "^(tcp|unix)://.*$"; - example = "tcp://0.0.0.0:10300"; - description = '' - URI to bind the wyoming server to. - ''; - }; + uri = mkOption { + type = strMatching "^(tcp|unix)://.*$"; + example = "tcp://0.0.0.0:10300"; + description = '' + URI to bind the wyoming server to. + ''; + }; - device = mkOption { - # https://opennmt.net/CTranslate2/python/ctranslate2.models.Whisper.html# - type = types.enum [ - "cpu" - "cuda" - "auto" - ]; - default = "cpu"; - description = '' - Determines the platform faster-whisper is run on. CPU works everywhere, CUDA requires a compatible NVIDIA GPU. - ''; - }; + device = mkOption { + # https://opennmt.net/CTranslate2/python/ctranslate2.models.Whisper.html# + type = types.enum [ + "cpu" + "cuda" + "auto" + ]; + default = "cpu"; + description = '' + Determines the platform faster-whisper is run on. CPU works everywhere, CUDA requires a compatible NVIDIA GPU. + ''; + }; - language = mkOption { - type = enum [ - # https://github.com/home-assistant/addons/blob/master/whisper/config.yaml#L20 - "auto" "af" "am" "ar" "as" "az" "ba" "be" "bg" "bn" "bo" "br" "bs" "ca" "cs" "cy" "da" "de" "el" "en" "es" "et" "eu" "fa" "fi" "fo" "fr" "gl" "gu" "ha" "haw" "he" "hi" "hr" "ht" "hu" "hy" "id" "is" "it" "ja" "jw" "ka" "kk" "km" "kn" "ko" "la" "lb" "ln" "lo" "lt" "lv" "mg" "mi" "mk" "ml" "mn" "mr" "ms" "mt" "my" "ne" "nl" "nn" "no" "oc" "pa" "pl" "ps" "pt" "ro" "ru" "sa" "sd" "si" "sk" "sl" "sn" "so" "sq" "sr" "su" "sv" "sw" "ta" "te" "tg" "th" "tk" "tl" "tr" "tt" "uk" "ur" "uz" "vi" "yi" "yo" "zh" - ]; - example = "en"; - description = '' - The language used to to parse words and sentences. - ''; - }; + language = mkOption { + type = enum [ + # https://github.com/home-assistant/addons/blob/master/whisper/config.yaml#L20 + "auto" + "af" + "am" + "ar" + "as" + "az" + "ba" + "be" + "bg" + "bn" + "bo" + "br" + "bs" + "ca" + "cs" + "cy" + "da" + "de" + "el" + "en" + "es" + "et" + "eu" + "fa" + "fi" + "fo" + "fr" + "gl" + "gu" + "ha" + "haw" + "he" + "hi" + "hr" + "ht" + "hu" + "hy" + "id" + "is" + "it" + "ja" + "jw" + "ka" + "kk" + "km" + "kn" + "ko" + "la" + "lb" + "ln" + "lo" + "lt" + "lv" + "mg" + "mi" + "mk" + "ml" + "mn" + "mr" + "ms" + "mt" + "my" + "ne" + "nl" + "nn" + "no" + "oc" + "pa" + "pl" + "ps" + "pt" + "ro" + "ru" + "sa" + "sd" + "si" + "sk" + "sl" + "sn" + "so" + "sq" + "sr" + "su" + "sv" + "sw" + "ta" + "te" + "tg" + "th" + "tk" + "tl" + "tr" + "tt" + "uk" + "ur" + "uz" + "vi" + "yi" + "yo" + "zh" + ]; + example = "en"; + description = '' + The language used to to parse words and sentences. + ''; + }; - beamSize = mkOption { - type = ints.unsigned; - default = 1; - example = 5; - description = '' - The number of beams to use in beam search. - ''; - apply = toString; - }; + beamSize = mkOption { + type = ints.unsigned; + default = 1; + example = 5; + description = '' + The number of beams to use in beam search. + ''; + apply = toString; + }; - extraArgs = mkOption { - type = listOf str; - default = [ ]; - description = '' - Extra arguments to pass to the server commandline. - ''; - apply = escapeShellArgs; + extraArgs = mkOption { + type = listOf str; + default = [ ]; + description = '' + Extra arguments to pass to the server commandline. + ''; + apply = escapeShellArgs; + }; }; - }; - } - )); + } + ) + ); }; }; - config = let - inherit (lib) - mapAttrs' - mkIf - nameValuePair - ; - in mkIf (cfg.servers != {}) { - systemd.services = mapAttrs' (server: options: - nameValuePair "wyoming-faster-whisper-${server}" { - inherit (options) enable; - description = "Wyoming faster-whisper server instance ${server}"; - wants = [ - "network-online.target" - ]; - after = [ - "network-online.target" - ]; - wantedBy = [ - "multi-user.target" - ]; - # https://github.com/rhasspy/wyoming-faster-whisper/issues/27 - environment."HF_HUB_CACHE" = "/tmp"; - serviceConfig = { - DynamicUser = true; - User = "wyoming-faster-whisper"; - StateDirectory = "wyoming/faster-whisper"; - # https://github.com/home-assistant/addons/blob/master/whisper/rootfs/etc/s6-overlay/s6-rc.d/whisper/run - ExecStart = '' - ${cfg.package}/bin/wyoming-faster-whisper \ - --data-dir $STATE_DIRECTORY \ - --download-dir $STATE_DIRECTORY \ - --uri ${options.uri} \ - --device ${options.device} \ - --model ${options.model} \ - --language ${options.language} \ - --beam-size ${options.beamSize} ${options.extraArgs} - ''; - CapabilityBoundingSet = ""; - DeviceAllow = if builtins.elem options.device [ "cuda" "auto" ] then [ - # https://docs.nvidia.com/dgx/pdf/dgx-os-5-user-guide.pdf - "char-nvidia-uvm" - "char-nvidia-frontend" - "char-nvidia-caps" - "char-nvidiactl" - ] else ""; - DevicePolicy = "closed"; - LockPersonality = true; - MemoryDenyWriteExecute = true; - PrivateUsers = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectControlGroups = true; - ProtectProc = "invisible"; - ProcSubset = "pid"; - RestrictAddressFamilies = [ - "AF_INET" - "AF_INET6" - "AF_UNIX" + config = + let + inherit (lib) + mapAttrs' + mkIf + nameValuePair + ; + in + mkIf (cfg.servers != { }) { + systemd.services = mapAttrs' ( + server: options: + nameValuePair "wyoming-faster-whisper-${server}" { + inherit (options) enable; + description = "Wyoming faster-whisper server instance ${server}"; + wants = [ + "network-online.target" ]; - RestrictNamespaces = true; - RestrictRealtime = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ - "@system-service" - "~@privileged" + after = [ + "network-online.target" ]; - UMask = "0077"; - }; - }) cfg.servers; - }; + wantedBy = [ + "multi-user.target" + ]; + # https://github.com/rhasspy/wyoming-faster-whisper/issues/27 + environment."HF_HUB_CACHE" = "/tmp"; + serviceConfig = { + DynamicUser = true; + User = "wyoming-faster-whisper"; + StateDirectory = "wyoming/faster-whisper"; + # https://github.com/home-assistant/addons/blob/master/whisper/rootfs/etc/s6-overlay/s6-rc.d/whisper/run + ExecStart = '' + ${cfg.package}/bin/wyoming-faster-whisper \ + --data-dir $STATE_DIRECTORY \ + --download-dir $STATE_DIRECTORY \ + --uri ${options.uri} \ + --device ${options.device} \ + --model ${options.model} \ + --language ${options.language} \ + --beam-size ${options.beamSize} ${options.extraArgs} + ''; + CapabilityBoundingSet = ""; + DeviceAllow = + if + builtins.elem options.device [ + "cuda" + "auto" + ] + then + [ + # https://docs.nvidia.com/dgx/pdf/dgx-os-5-user-guide.pdf + "char-nvidia-uvm" + "char-nvidia-frontend" + "char-nvidia-caps" + "char-nvidiactl" + ] + else + ""; + DevicePolicy = "closed"; + LockPersonality = true; + MemoryDenyWriteExecute = true; + PrivateUsers = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectControlGroups = true; + ProtectProc = "invisible"; + ProcSubset = "pid"; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; + UMask = "0077"; + }; + } + ) cfg.servers; + }; } diff --git a/nixos/modules/services/home-automation/wyoming/openwakeword.nix b/nixos/modules/services/home-automation/wyoming/openwakeword.nix index f9848970bf7345..be6c2b74e12222 100644 --- a/nixos/modules/services/home-automation/wyoming/openwakeword.nix +++ b/nixos/modules/services/home-automation/wyoming/openwakeword.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let @@ -27,7 +28,12 @@ in { imports = [ - (mkRemovedOptionModule [ "services" "wyoming" "openwakeword" "models" ] "Configuring models has been removed, they are now dynamically discovered and loaded at runtime") + (mkRemovedOptionModule [ + "services" + "wyoming" + "openwakeword" + "models" + ] "Configuring models has been removed, they are now dynamically discovered and loaded at runtime") ]; meta.buildDocsInSandbox = false; @@ -48,7 +54,7 @@ in customModelsDirectories = mkOption { type = listOf types.path; - default = []; + default = [ ]; description = '' Paths to directories with custom wake word models (*.tflite model files). ''; diff --git a/nixos/modules/services/home-automation/wyoming/piper.nix b/nixos/modules/services/home-automation/wyoming/piper.nix index a26fe8e84f609c..0f3af57e3aea8f 100644 --- a/nixos/modules/services/home-automation/wyoming/piper.nix +++ b/nixos/modules/services/home-automation/wyoming/piper.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let @@ -28,150 +29,157 @@ in package = mkPackageOption pkgs "wyoming-piper" { }; servers = mkOption { - default = {}; + default = { }; description = '' Attribute set of piper instances to spawn. ''; - type = types.attrsOf (types.submodule ( - { ... }: { - options = { - enable = mkEnableOption "Wyoming Piper server"; - - piper = mkPackageOption pkgs "piper-tts" { }; - - voice = mkOption { - type = str; - example = "en-us-ryan-medium"; - description = '' - Name of the voice model to use. See the following website for samples: - https://rhasspy.github.io/piper-samples/ - ''; - }; - - uri = mkOption { - type = strMatching "^(tcp|unix)://.*$"; - example = "tcp://0.0.0.0:10200"; - description = '' - URI to bind the wyoming server to. - ''; - }; - - speaker = mkOption { - type = ints.unsigned; - default = 0; - description = '' - ID of a specific speaker in a multi-speaker model. - ''; - apply = toString; - }; - - noiseScale = mkOption { - type = float; - default = 0.667; - description = '' - Generator noise value. - ''; - apply = toString; - }; - - noiseWidth = mkOption { - type = float; - default = 0.333; - description = '' - Phoneme width noise value. - ''; - apply = toString; - }; - - lengthScale = mkOption { - type = float; - default = 1.0; - description = '' - Phoneme length value. - ''; - apply = toString; + type = types.attrsOf ( + types.submodule ( + { ... }: + { + options = { + enable = mkEnableOption "Wyoming Piper server"; + + piper = mkPackageOption pkgs "piper-tts" { }; + + voice = mkOption { + type = str; + example = "en-us-ryan-medium"; + description = '' + Name of the voice model to use. See the following website for samples: + https://rhasspy.github.io/piper-samples/ + ''; + }; + + uri = mkOption { + type = strMatching "^(tcp|unix)://.*$"; + example = "tcp://0.0.0.0:10200"; + description = '' + URI to bind the wyoming server to. + ''; + }; + + speaker = mkOption { + type = ints.unsigned; + default = 0; + description = '' + ID of a specific speaker in a multi-speaker model. + ''; + apply = toString; + }; + + noiseScale = mkOption { + type = float; + default = 0.667; + description = '' + Generator noise value. + ''; + apply = toString; + }; + + noiseWidth = mkOption { + type = float; + default = 0.333; + description = '' + Phoneme width noise value. + ''; + apply = toString; + }; + + lengthScale = mkOption { + type = float; + default = 1.0; + description = '' + Phoneme length value. + ''; + apply = toString; + }; + + extraArgs = mkOption { + type = listOf str; + default = [ ]; + description = '' + Extra arguments to pass to the server commandline. + ''; + apply = escapeShellArgs; + }; }; - - extraArgs = mkOption { - type = listOf str; - default = [ ]; - description = '' - Extra arguments to pass to the server commandline. - ''; - apply = escapeShellArgs; - }; - }; - } - )); + } + ) + ); }; }; - config = let - inherit (lib) - mapAttrs' - mkIf - nameValuePair - ; - in mkIf (cfg.servers != {}) { - systemd.services = mapAttrs' (server: options: - nameValuePair "wyoming-piper-${server}" { - inherit (options) enable; - description = "Wyoming Piper server instance ${server}"; - wants = [ - "network-online.target" - ]; - after = [ - "network-online.target" - ]; - wantedBy = [ - "multi-user.target" - ]; - serviceConfig = { - DynamicUser = true; - User = "wyoming-piper"; - StateDirectory = "wyoming/piper"; - # https://github.com/home-assistant/addons/blob/master/piper/rootfs/etc/s6-overlay/s6-rc.d/piper/run - ExecStart = '' - ${cfg.package}/bin/wyoming-piper \ - --data-dir $STATE_DIRECTORY \ - --download-dir $STATE_DIRECTORY \ - --uri ${options.uri} \ - --piper ${options.piper}/bin/piper \ - --voice ${options.voice} \ - --speaker ${options.speaker} \ - --length-scale ${options.lengthScale} \ - --noise-scale ${options.noiseScale} \ - --noise-w ${options.noiseWidth} ${options.extraArgs} - ''; - CapabilityBoundingSet = ""; - DeviceAllow = ""; - DevicePolicy = "closed"; - LockPersonality = true; - MemoryDenyWriteExecute = true; - PrivateDevices = true; - PrivateUsers = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectControlGroups = true; - ProtectProc = "invisible"; - ProcSubset = "pid"; - RestrictAddressFamilies = [ - "AF_INET" - "AF_INET6" - "AF_UNIX" + config = + let + inherit (lib) + mapAttrs' + mkIf + nameValuePair + ; + in + mkIf (cfg.servers != { }) { + systemd.services = mapAttrs' ( + server: options: + nameValuePair "wyoming-piper-${server}" { + inherit (options) enable; + description = "Wyoming Piper server instance ${server}"; + wants = [ + "network-online.target" ]; - RestrictNamespaces = true; - RestrictRealtime = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ - "@system-service" - "~@privileged" + after = [ + "network-online.target" ]; - UMask = "0077"; - }; - }) cfg.servers; - }; + wantedBy = [ + "multi-user.target" + ]; + serviceConfig = { + DynamicUser = true; + User = "wyoming-piper"; + StateDirectory = "wyoming/piper"; + # https://github.com/home-assistant/addons/blob/master/piper/rootfs/etc/s6-overlay/s6-rc.d/piper/run + ExecStart = '' + ${cfg.package}/bin/wyoming-piper \ + --data-dir $STATE_DIRECTORY \ + --download-dir $STATE_DIRECTORY \ + --uri ${options.uri} \ + --piper ${options.piper}/bin/piper \ + --voice ${options.voice} \ + --speaker ${options.speaker} \ + --length-scale ${options.lengthScale} \ + --noise-scale ${options.noiseScale} \ + --noise-w ${options.noiseWidth} ${options.extraArgs} + ''; + CapabilityBoundingSet = ""; + DeviceAllow = ""; + DevicePolicy = "closed"; + LockPersonality = true; + MemoryDenyWriteExecute = true; + PrivateDevices = true; + PrivateUsers = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectControlGroups = true; + ProtectProc = "invisible"; + ProcSubset = "pid"; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; + UMask = "0077"; + }; + } + ) cfg.servers; + }; } diff --git a/nixos/modules/services/home-automation/wyoming/satellite.nix b/nixos/modules/services/home-automation/wyoming/satellite.nix index 531d375e703a3e..b0064569cc325e 100644 --- a/nixos/modules/services/home-automation/wyoming/satellite.nix +++ b/nixos/modules/services/home-automation/wyoming/satellite.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let @@ -19,15 +20,16 @@ let optional optionals types - ; + ; finalPackage = cfg.package.overridePythonAttrs (oldAttrs: { - propagatedBuildInputs = oldAttrs.propagatedBuildInputs + propagatedBuildInputs = + oldAttrs.propagatedBuildInputs # for audio enhancements like auto-gain, noise suppression ++ cfg.package.optional-dependencies.webrtc # vad is currently optional, because it is broken on aarch64-linux ++ optionals cfg.vad.enable cfg.package.optional-dependencies.silerovad; - }); + }); in { @@ -180,27 +182,45 @@ in path = with pkgs; [ alsa-utils ]; - script = let - optionalParam = param: argument: optionals (!elem argument [ null 0 false ]) [ - param argument - ]; - in '' - export XDG_RUNTIME_DIR=/run/user/$UID - ${escapeShellArgs ([ - (getExe finalPackage) - "--uri" cfg.uri - "--name" cfg.name - "--mic-command" cfg.microphone.command - ] - ++ optionalParam "--mic-auto-gain" cfg.microphone.autoGain - ++ optionalParam "--mic-noise-suppression" cfg.microphone.noiseSuppression - ++ optionalParam "--area" cfg.area - ++ optionalParam "--snd-command" cfg.sound.command - ++ optionalParam "--awake-wav" cfg.sounds.awake - ++ optionalParam "--done-wav" cfg.sounds.done - ++ optional cfg.vad.enable "--vad" - ++ cfg.extraArgs)} - ''; + script = + let + optionalParam = + param: argument: + optionals + ( + !elem argument [ + null + 0 + false + ] + ) + [ + param + argument + ]; + in + '' + export XDG_RUNTIME_DIR=/run/user/$UID + ${escapeShellArgs ( + [ + (getExe finalPackage) + "--uri" + cfg.uri + "--name" + cfg.name + "--mic-command" + cfg.microphone.command + ] + ++ optionalParam "--mic-auto-gain" cfg.microphone.autoGain + ++ optionalParam "--mic-noise-suppression" cfg.microphone.noiseSuppression + ++ optionalParam "--area" cfg.area + ++ optionalParam "--snd-command" cfg.sound.command + ++ optionalParam "--awake-wav" cfg.sounds.awake + ++ optionalParam "--done-wav" cfg.sounds.done + ++ optional cfg.vad.enable "--vad" + ++ cfg.extraArgs + )} + ''; serviceConfig = { User = cfg.user; Group = cfg.group; diff --git a/nixos/modules/services/home-automation/zigbee2mqtt.nix b/nixos/modules/services/home-automation/zigbee2mqtt.nix index b8be0acfda56b5..c76c1c86da755f 100644 --- a/nixos/modules/services/home-automation/zigbee2mqtt.nix +++ b/nixos/modules/services/home-automation/zigbee2mqtt.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.zigbee2mqtt; @@ -7,10 +12,17 @@ let in { - meta.maintainers = with lib.maintainers; [ sweber hexa ]; + meta.maintainers = with lib.maintainers; [ + sweber + hexa + ]; imports = [ - (lib.mkRemovedOptionModule [ "services" "zigbee2mqtt" "config" ] "The option services.zigbee2mqtt.config was renamed to services.zigbee2mqtt.settings.") + (lib.mkRemovedOptionModule [ + "services" + "zigbee2mqtt" + "config" + ] "The option services.zigbee2mqtt.config was renamed to services.zigbee2mqtt.settings.") ]; options.services.zigbee2mqtt = { @@ -75,7 +87,9 @@ in # Hardening CapabilityBoundingSet = ""; - DeviceAllow = lib.optionals (lib.hasPrefix "/" cfg.settings.serial.port) [ cfg.settings.serial.port ]; + DeviceAllow = lib.optionals (lib.hasPrefix "/" cfg.settings.serial.port) [ + cfg.settings.serial.port + ]; DevicePolicy = "closed"; LockPersonality = true; MemoryDenyWriteExecute = false; diff --git a/nixos/modules/services/home-automation/zwave-js.nix b/nixos/modules/services/home-automation/zwave-js.nix index 4ce79262426979..3d04ad7fa55897 100644 --- a/nixos/modules/services/home-automation/zwave-js.nix +++ b/nixos/modules/services/home-automation/zwave-js.nix @@ -1,9 +1,15 @@ -{config, pkgs, lib, ...}: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.zwave-js; mergedConfigFile = "/run/zwave-js/config.json"; - settingsFormat = pkgs.formats.json {}; -in { + settingsFormat = pkgs.formats.json { }; +in +{ options.services.zwave-js = { enable = lib.mkEnableOption "the zwave-js server on boot"; @@ -74,7 +80,7 @@ in { }; }; }; - default = {}; + default = { }; description = '' Configuration settings for the generated config file. @@ -92,57 +98,59 @@ in { }; config = lib.mkIf cfg.enable { - systemd.services.zwave-js = let - configFile = settingsFormat.generate "zwave-js-config.json" cfg.settings; - in { - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - description = "Z-Wave JS Server"; - serviceConfig = { - ExecStartPre = '' - /bin/sh -c "${pkgs.jq}/bin/jq -s '.[0] * .[1]' ${configFile} ${cfg.secretsConfigFile} > ${mergedConfigFile}" - ''; - ExecStart = lib.concatStringsSep " " [ - "${cfg.package}/bin/zwave-server" - "--config ${mergedConfigFile}" - "--port ${toString cfg.port}" - cfg.serialPort - (lib.escapeShellArgs cfg.extraFlags) - ]; - Restart = "on-failure"; - User = "zwave-js"; - SupplementaryGroups = [ "dialout" ]; - CacheDirectory = "zwave-js"; - RuntimeDirectory = "zwave-js"; - - # Hardening - CapabilityBoundingSet = ""; - DeviceAllow = [cfg.serialPort]; - DevicePolicy = "closed"; - DynamicUser = true; - LockPersonality = true; - MemoryDenyWriteExecute = false; - NoNewPrivileges = true; - PrivateUsers = true; - PrivateTmp = true; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - RemoveIPC = true; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ - "@system-service @pkey" - "~@privileged @resources" - ]; - UMask = "0077"; + systemd.services.zwave-js = + let + configFile = settingsFormat.generate "zwave-js-config.json" cfg.settings; + in + { + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + description = "Z-Wave JS Server"; + serviceConfig = { + ExecStartPre = '' + /bin/sh -c "${pkgs.jq}/bin/jq -s '.[0] * .[1]' ${configFile} ${cfg.secretsConfigFile} > ${mergedConfigFile}" + ''; + ExecStart = lib.concatStringsSep " " [ + "${cfg.package}/bin/zwave-server" + "--config ${mergedConfigFile}" + "--port ${toString cfg.port}" + cfg.serialPort + (lib.escapeShellArgs cfg.extraFlags) + ]; + Restart = "on-failure"; + User = "zwave-js"; + SupplementaryGroups = [ "dialout" ]; + CacheDirectory = "zwave-js"; + RuntimeDirectory = "zwave-js"; + + # Hardening + CapabilityBoundingSet = ""; + DeviceAllow = [ cfg.serialPort ]; + DevicePolicy = "closed"; + DynamicUser = true; + LockPersonality = true; + MemoryDenyWriteExecute = false; + NoNewPrivileges = true; + PrivateUsers = true; + PrivateTmp = true; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + RemoveIPC = true; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service @pkey" + "~@privileged @resources" + ]; + UMask = "0077"; + }; }; - }; }; meta.maintainers = with lib.maintainers; [ graham33 ]; diff --git a/nixos/modules/services/logging/SystemdJournal2Gelf.nix b/nixos/modules/services/logging/SystemdJournal2Gelf.nix index 5b2f05f8c0f156..dabff91691b952 100644 --- a/nixos/modules/services/logging/SystemdJournal2Gelf.nix +++ b/nixos/modules/services/logging/SystemdJournal2Gelf.nix @@ -1,8 +1,15 @@ -{ config, lib, pkgs, ... }: -let cfg = config.services.SystemdJournal2Gelf; +{ + config, + lib, + pkgs, + ... +}: +let + cfg = config.services.SystemdJournal2Gelf; in -{ options = { +{ + options = { services.SystemdJournal2Gelf = { enable = lib.mkOption { type = lib.types.bool; diff --git a/nixos/modules/services/logging/awstats.nix b/nixos/modules/services/logging/awstats.nix index d6d1fd64bd52ad..5cd2eee77d5d83 100644 --- a/nixos/modules/services/logging/awstats.nix +++ b/nixos/modules/services/logging/awstats.nix @@ -1,93 +1,113 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.awstats; package = pkgs.awstats; - configOpts = {name, config, ...}: { - options = { - type = lib.mkOption{ - type = lib.types.enum [ "mail" "web" ]; - default = "web"; - example = "mail"; - description = '' - The type of log being collected. - ''; - }; - domain = lib.mkOption { - type = lib.types.str; - default = name; - description = "The domain name to collect stats for."; - example = "example.com"; - }; + configOpts = + { name, config, ... }: + { + options = { + type = lib.mkOption { + type = lib.types.enum [ + "mail" + "web" + ]; + default = "web"; + example = "mail"; + description = '' + The type of log being collected. + ''; + }; + domain = lib.mkOption { + type = lib.types.str; + default = name; + description = "The domain name to collect stats for."; + example = "example.com"; + }; - logFile = lib.mkOption { - type = lib.types.str; - example = "/var/log/nginx/access.log"; - description = '' - The log file to be scanned. - - For mail, set this to - ``` - journalctl $OLD_CURSOR -u postfix.service | ''${pkgs.perl}/bin/perl ''${pkgs.awstats.out}/share/awstats/tools/maillogconvert.pl standard | - ``` - ''; - }; + logFile = lib.mkOption { + type = lib.types.str; + example = "/var/log/nginx/access.log"; + description = '' + The log file to be scanned. - logFormat = lib.mkOption { - type = lib.types.str; - default = "1"; - description = '' - The log format being used. - - For mail, set this to - ``` - %time2 %email %email_r %host %host_r %method %url %code %bytesd - ``` - ''; - }; + For mail, set this to + ``` + journalctl $OLD_CURSOR -u postfix.service | ''${pkgs.perl}/bin/perl ''${pkgs.awstats.out}/share/awstats/tools/maillogconvert.pl standard | + ``` + ''; + }; - hostAliases = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - example = [ "www.example.org" ]; - description = '' - List of aliases the site has. - ''; - }; + logFormat = lib.mkOption { + type = lib.types.str; + default = "1"; + description = '' + The log format being used. - extraConfig = lib.mkOption { - type = lib.types.attrsOf lib.types.str; - default = {}; - example = lib.literalExpression '' - { - "ValidHTTPCodes" = "404"; - } - ''; - description = "Extra configuration to be appended to awstats.\${name}.conf."; - }; + For mail, set this to + ``` + %time2 %email %email_r %host %host_r %method %url %code %bytesd + ``` + ''; + }; - webService = { - enable = lib.mkEnableOption "awstats web service"; + hostAliases = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + example = [ "www.example.org" ]; + description = '' + List of aliases the site has. + ''; + }; - hostname = lib.mkOption { - type = lib.types.str; - default = config.domain; - description = "The hostname the web service appears under."; + extraConfig = lib.mkOption { + type = lib.types.attrsOf lib.types.str; + default = { }; + example = lib.literalExpression '' + { + "ValidHTTPCodes" = "404"; + } + ''; + description = "Extra configuration to be appended to awstats.\${name}.conf."; }; - urlPrefix = lib.mkOption { - type = lib.types.str; - default = "/awstats"; - description = "The URL prefix under which the awstats pages appear."; + webService = { + enable = lib.mkEnableOption "awstats web service"; + + hostname = lib.mkOption { + type = lib.types.str; + default = config.domain; + description = "The hostname the web service appears under."; + }; + + urlPrefix = lib.mkOption { + type = lib.types.str; + default = "/awstats"; + description = "The URL prefix under which the awstats pages appear."; + }; }; }; }; - }; webServices = lib.filterAttrs (name: value: value.webService.enable) cfg.configs; in { imports = [ - (lib.mkRemovedOptionModule [ "services" "awstats" "service" "enable" ] "Please enable per domain with `services.awstats.configs..webService.enable`") - (lib.mkRemovedOptionModule [ "services" "awstats" "service" "urlPrefix" ] "Please set per domain with `services.awstats.configs..webService.urlPrefix`") + (lib.mkRemovedOptionModule [ + "services" + "awstats" + "service" + "enable" + ] "Please enable per domain with `services.awstats.configs..webService.enable`") + (lib.mkRemovedOptionModule [ + "services" + "awstats" + "service" + "urlPrefix" + ] "Please set per domain with `services.awstats.configs..webService.urlPrefix`") (lib.mkRenamedOptionModule [ "services" "awstats" "vardir" ] [ "services" "awstats" "dataDir" ]) ]; @@ -102,7 +122,7 @@ in configs = lib.mkOption { type = lib.types.attrsOf (lib.types.submodule configOpts); - default = {}; + default = { }; example = lib.literalExpression '' { "mysite" = { @@ -125,82 +145,83 @@ in }; }; - config = lib.mkIf cfg.enable { environment.systemPackages = [ package.bin ]; - environment.etc = lib.mapAttrs' (name: opts: - lib.nameValuePair "awstats/awstats.${name}.conf" { - source = pkgs.runCommand "awstats.${name}.conf" - { preferLocalBuild = true; } - ('' - sed \ - '' - # set up mail stats - + lib.optionalString (opts.type == "mail") - '' - -e 's|^\(LogType\)=.*$|\1=M|' \ - -e 's|^\(LevelForBrowsersDetection\)=.*$|\1=0|' \ - -e 's|^\(LevelForOSDetection\)=.*$|\1=0|' \ - -e 's|^\(LevelForRefererAnalyze\)=.*$|\1=0|' \ - -e 's|^\(LevelForRobotsDetection\)=.*$|\1=0|' \ - -e 's|^\(LevelForSearchEnginesDetection\)=.*$|\1=0|' \ - -e 's|^\(LevelForFileTypesDetection\)=.*$|\1=0|' \ - -e 's|^\(LevelForWormsDetection\)=.*$|\1=0|' \ - -e 's|^\(ShowMenu\)=.*$|\1=1|' \ - -e 's|^\(ShowSummary\)=.*$|\1=HB|' \ - -e 's|^\(ShowMonthStats\)=.*$|\1=HB|' \ - -e 's|^\(ShowDaysOfMonthStats\)=.*$|\1=HB|' \ - -e 's|^\(ShowDaysOfWeekStats\)=.*$|\1=HB|' \ - -e 's|^\(ShowHoursStats\)=.*$|\1=HB|' \ - -e 's|^\(ShowDomainsStats\)=.*$|\1=0|' \ - -e 's|^\(ShowHostsStats\)=.*$|\1=HB|' \ - -e 's|^\(ShowAuthenticatedUsers\)=.*$|\1=0|' \ - -e 's|^\(ShowRobotsStats\)=.*$|\1=0|' \ - -e 's|^\(ShowEMailSenders\)=.*$|\1=HBML|' \ - -e 's|^\(ShowEMailReceivers\)=.*$|\1=HBML|' \ - -e 's|^\(ShowSessionsStats\)=.*$|\1=0|' \ - -e 's|^\(ShowPagesStats\)=.*$|\1=0|' \ - -e 's|^\(ShowFileTypesStats\)=.*$|\1=0|' \ - -e 's|^\(ShowFileSizesStats\)=.*$|\1=0|' \ - -e 's|^\(ShowBrowsersStats\)=.*$|\1=0|' \ - -e 's|^\(ShowOSStats\)=.*$|\1=0|' \ - -e 's|^\(ShowOriginStats\)=.*$|\1=0|' \ - -e 's|^\(ShowKeyphrasesStats\)=.*$|\1=0|' \ - -e 's|^\(ShowKeywordsStats\)=.*$|\1=0|' \ - -e 's|^\(ShowMiscStats\)=.*$|\1=0|' \ - -e 's|^\(ShowHTTPErrorsStats\)=.*$|\1=0|' \ - -e 's|^\(ShowSMTPErrorsStats\)=.*$|\1=1|' \ - '' - + - # common options - '' - -e 's|^\(DirData\)=.*$|\1="${cfg.dataDir}/${name}"|' \ - -e 's|^\(DirIcons\)=.*$|\1="icons"|' \ - -e 's|^\(CreateDirDataIfNotExists\)=.*$|\1=1|' \ - -e 's|^\(SiteDomain\)=.*$|\1="${name}"|' \ - -e 's|^\(LogFile\)=.*$|\1="${opts.logFile}"|' \ - -e 's|^\(LogFormat\)=.*$|\1="${opts.logFormat}"|' \ - '' - + - # extra config - lib.concatStringsSep "\n" (lib.mapAttrsToList (n: v: '' - -e 's|^\(${n}\)=.*$|\1="${v}"|' \ - '') opts.extraConfig) - + - '' - < '${package.out}/wwwroot/cgi-bin/awstats.model.conf' > "$out" - ''); - }) cfg.configs; + environment.etc = lib.mapAttrs' ( + name: opts: + lib.nameValuePair "awstats/awstats.${name}.conf" { + source = pkgs.runCommand "awstats.${name}.conf" { preferLocalBuild = true; } ( + '' + sed \ + '' + # set up mail stats + + lib.optionalString (opts.type == "mail") '' + -e 's|^\(LogType\)=.*$|\1=M|' \ + -e 's|^\(LevelForBrowsersDetection\)=.*$|\1=0|' \ + -e 's|^\(LevelForOSDetection\)=.*$|\1=0|' \ + -e 's|^\(LevelForRefererAnalyze\)=.*$|\1=0|' \ + -e 's|^\(LevelForRobotsDetection\)=.*$|\1=0|' \ + -e 's|^\(LevelForSearchEnginesDetection\)=.*$|\1=0|' \ + -e 's|^\(LevelForFileTypesDetection\)=.*$|\1=0|' \ + -e 's|^\(LevelForWormsDetection\)=.*$|\1=0|' \ + -e 's|^\(ShowMenu\)=.*$|\1=1|' \ + -e 's|^\(ShowSummary\)=.*$|\1=HB|' \ + -e 's|^\(ShowMonthStats\)=.*$|\1=HB|' \ + -e 's|^\(ShowDaysOfMonthStats\)=.*$|\1=HB|' \ + -e 's|^\(ShowDaysOfWeekStats\)=.*$|\1=HB|' \ + -e 's|^\(ShowHoursStats\)=.*$|\1=HB|' \ + -e 's|^\(ShowDomainsStats\)=.*$|\1=0|' \ + -e 's|^\(ShowHostsStats\)=.*$|\1=HB|' \ + -e 's|^\(ShowAuthenticatedUsers\)=.*$|\1=0|' \ + -e 's|^\(ShowRobotsStats\)=.*$|\1=0|' \ + -e 's|^\(ShowEMailSenders\)=.*$|\1=HBML|' \ + -e 's|^\(ShowEMailReceivers\)=.*$|\1=HBML|' \ + -e 's|^\(ShowSessionsStats\)=.*$|\1=0|' \ + -e 's|^\(ShowPagesStats\)=.*$|\1=0|' \ + -e 's|^\(ShowFileTypesStats\)=.*$|\1=0|' \ + -e 's|^\(ShowFileSizesStats\)=.*$|\1=0|' \ + -e 's|^\(ShowBrowsersStats\)=.*$|\1=0|' \ + -e 's|^\(ShowOSStats\)=.*$|\1=0|' \ + -e 's|^\(ShowOriginStats\)=.*$|\1=0|' \ + -e 's|^\(ShowKeyphrasesStats\)=.*$|\1=0|' \ + -e 's|^\(ShowKeywordsStats\)=.*$|\1=0|' \ + -e 's|^\(ShowMiscStats\)=.*$|\1=0|' \ + -e 's|^\(ShowHTTPErrorsStats\)=.*$|\1=0|' \ + -e 's|^\(ShowSMTPErrorsStats\)=.*$|\1=1|' \ + '' + + + # common options + '' + -e 's|^\(DirData\)=.*$|\1="${cfg.dataDir}/${name}"|' \ + -e 's|^\(DirIcons\)=.*$|\1="icons"|' \ + -e 's|^\(CreateDirDataIfNotExists\)=.*$|\1=1|' \ + -e 's|^\(SiteDomain\)=.*$|\1="${name}"|' \ + -e 's|^\(LogFile\)=.*$|\1="${opts.logFile}"|' \ + -e 's|^\(LogFormat\)=.*$|\1="${opts.logFormat}"|' \ + '' + + + # extra config + lib.concatStringsSep "\n" ( + lib.mapAttrsToList (n: v: '' + -e 's|^\(${n}\)=.*$|\1="${v}"|' \ + '') opts.extraConfig + ) + + '' + < '${package.out}/wwwroot/cgi-bin/awstats.model.conf' > "$out" + '' + ); + } + ) cfg.configs; # create data directory with the correct permissions systemd.tmpfiles.rules = - [ "d '${cfg.dataDir}' 755 root root - -" ] ++ - lib.mapAttrsToList (name: opts: "d '${cfg.dataDir}/${name}' 755 root root - -") cfg.configs ++ - [ "Z '${cfg.dataDir}' 755 root root - -" ]; + [ "d '${cfg.dataDir}' 755 root root - -" ] + ++ lib.mapAttrsToList (name: opts: "d '${cfg.dataDir}/${name}' 755 root root - -") cfg.configs + ++ [ "Z '${cfg.dataDir}' 755 root root - -" ]; # nginx options - services.nginx.virtualHosts = lib.mapAttrs'(name: opts: { + services.nginx.virtualHosts = lib.mapAttrs' (name: opts: { name = opts.webService.hostname; value = { locations = { @@ -221,32 +242,36 @@ in }) webServices; # update awstats - systemd.services = lib.mkIf (cfg.updateAt != null) (lib.mapAttrs' (name: opts: - lib.nameValuePair "awstats-${name}-update" { - description = "update awstats for ${name}"; - script = lib.optionalString (opts.type == "mail") - '' - if [[ -f "${cfg.dataDir}/${name}-cursor" ]]; then - CURSOR="$(cat "${cfg.dataDir}/${name}-cursor" | tr -d '\n')" - if [[ -n "$CURSOR" ]]; then - echo "Using cursor: $CURSOR" - export OLD_CURSOR="--cursor $CURSOR" - fi - fi - NEW_CURSOR="$(journalctl $OLD_CURSOR -u postfix.service --show-cursor | tail -n 1 | tr -d '\n' | sed -e 's#^-- cursor: \(.*\)#\1#')" - echo "New cursor: $NEW_CURSOR" - ${package.bin}/bin/awstats -update -config=${name} - if [ -n "$NEW_CURSOR" ]; then - echo -n "$NEW_CURSOR" > ${cfg.dataDir}/${name}-cursor - fi - '' + '' - ${package.out}/share/awstats/tools/awstats_buildstaticpages.pl \ - -config=${name} -update -dir=${cfg.dataDir}/${name} \ - -awstatsprog=${package.bin}/bin/awstats - ''; - startAt = cfg.updateAt; - }) cfg.configs); + systemd.services = lib.mkIf (cfg.updateAt != null) ( + lib.mapAttrs' ( + name: opts: + lib.nameValuePair "awstats-${name}-update" { + description = "update awstats for ${name}"; + script = + lib.optionalString (opts.type == "mail") '' + if [[ -f "${cfg.dataDir}/${name}-cursor" ]]; then + CURSOR="$(cat "${cfg.dataDir}/${name}-cursor" | tr -d '\n')" + if [[ -n "$CURSOR" ]]; then + echo "Using cursor: $CURSOR" + export OLD_CURSOR="--cursor $CURSOR" + fi + fi + NEW_CURSOR="$(journalctl $OLD_CURSOR -u postfix.service --show-cursor | tail -n 1 | tr -d '\n' | sed -e 's#^-- cursor: \(.*\)#\1#')" + echo "New cursor: $NEW_CURSOR" + ${package.bin}/bin/awstats -update -config=${name} + if [ -n "$NEW_CURSOR" ]; then + echo -n "$NEW_CURSOR" > ${cfg.dataDir}/${name}-cursor + fi + '' + + '' + ${package.out}/share/awstats/tools/awstats_buildstaticpages.pl \ + -config=${name} -update -dir=${cfg.dataDir}/${name} \ + -awstatsprog=${package.bin}/bin/awstats + ''; + startAt = cfg.updateAt; + } + ) cfg.configs + ); }; } - diff --git a/nixos/modules/services/logging/filebeat.nix b/nixos/modules/services/logging/filebeat.nix index 57e0c60735780e..53a00be860d7e7 100644 --- a/nixos/modules/services/logging/filebeat.nix +++ b/nixos/modules/services/logging/filebeat.nix @@ -1,4 +1,10 @@ -{ config, lib, utils, pkgs, ... }: +{ + config, + lib, + utils, + pkgs, + ... +}: let inherit (lib) @@ -8,11 +14,12 @@ let mkPackageOption mkIf mkOption - types; + types + ; cfg = config.services.filebeat; - json = pkgs.formats.json {}; + json = pkgs.formats.json { }; in { options = { @@ -41,23 +48,28 @@ in See . ''; - default = {}; - type = types.attrsOf (types.submodule ({ name, ... }: { - freeformType = json.type; - options = { - type = mkOption { - type = types.str; - default = name; - description = '' - The input type. + default = { }; + type = types.attrsOf ( + types.submodule ( + { name, ... }: + { + freeformType = json.type; + options = { + type = mkOption { + type = types.str; + default = name; + description = '' + The input type. - Look for the value after `type:` on - the individual input pages linked from - . - ''; - }; - }; - })); + Look for the value after `type:` on + the individual input pages linked from + . + ''; + }; + }; + } + ) + ); example = literalExpression '' { journald.id = "everything"; # Only for filebeat7 @@ -91,23 +103,28 @@ in See . ''; - default = {}; - type = types.attrsOf (types.submodule ({ name, ... }: { - freeformType = json.type; - options = { - module = mkOption { - type = types.str; - default = name; - description = '' - The name of the module. + default = { }; + type = types.attrsOf ( + types.submodule ( + { name, ... }: + { + freeformType = json.type; + options = { + module = mkOption { + type = types.str; + default = name; + description = '' + The name of the module. - Look for the value after `module:` on - the individual input pages linked from - . - ''; - }; - }; - })); + Look for the value after `module:` on + the individual input pages linked from + . + ''; + }; + }; + } + ) + ); example = literalExpression '' { nginx = { @@ -152,7 +169,7 @@ in filebeat = { inputs = mkOption { type = types.listOf json.type; - default = []; + default = [ ]; internal = true; description = '' Inputs specify how Filebeat locates and processes @@ -163,7 +180,7 @@ in }; modules = mkOption { type = types.listOf json.type; - default = []; + default = [ ]; internal = true; description = '' Filebeat modules provide a quick way to get started @@ -180,7 +197,7 @@ in }; }; }; - default = {}; + default = { }; example = literalExpression '' { settings = { @@ -229,10 +246,7 @@ in umask u=rwx,g=,o= - ${utils.genJqSecretsReplacementSnippet - cfg.settings - "/var/lib/filebeat/filebeat.yml" - } + ${utils.genJqSecretsReplacementSnippet cfg.settings "/var/lib/filebeat/filebeat.yml"} ''; ExecStart = '' ${cfg.package}/bin/filebeat -e \ diff --git a/nixos/modules/services/logging/fluentd.nix b/nixos/modules/services/logging/fluentd.nix index fed5cacac37e37..5047a0be031e27 100644 --- a/nixos/modules/services/logging/fluentd.nix +++ b/nixos/modules/services/logging/fluentd.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.fluentd; pluginArgs = lib.concatStringsSep " " (map (x: "-p ${x}") cfg.plugins); -in { +in +{ ###### interface options = { @@ -21,7 +27,7 @@ in { plugins = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; description = '' A list of plugin paths to pass into fluentd. It will make plugins defined in ruby files there available in your config. @@ -30,7 +36,6 @@ in { }; }; - ###### implementation config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/logging/graylog.nix b/nixos/modules/services/logging/graylog.nix index ff1860e99a7575..dac7c10aa7da58 100644 --- a/nixos/modules/services/logging/graylog.nix +++ b/nixos/modules/services/logging/graylog.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.graylog; @@ -35,8 +40,14 @@ in package = lib.mkOption { type = lib.types.package; - default = if lib.versionOlder config.system.stateVersion "23.05" then pkgs.graylog-3_3 else pkgs.graylog-5_1; - defaultText = lib.literalExpression (if lib.versionOlder config.system.stateVersion "23.05" then "pkgs.graylog-3_3" else "pkgs.graylog-5_1"); + default = + if lib.versionOlder config.system.stateVersion "23.05" then pkgs.graylog-3_3 else pkgs.graylog-5_1; + defaultText = lib.literalExpression ( + if lib.versionOlder config.system.stateVersion "23.05" then + "pkgs.graylog-3_3" + else + "pkgs.graylog-5_1" + ); description = "Graylog package to use."; }; @@ -124,7 +135,6 @@ in }; }; - ###### implementation config = lib.mkIf cfg.enable { @@ -136,7 +146,7 @@ in description = "Graylog server daemon user"; }; }; - users.groups = lib.mkIf (cfg.user == "graylog") { graylog = {}; }; + users.groups = lib.mkIf (cfg.user == "graylog") { graylog = { }; }; systemd.tmpfiles.rules = [ "d '${cfg.messageJournalDir}' - ${cfg.user} - - -" @@ -148,7 +158,10 @@ in environment = { GRAYLOG_CONF = "${confFile}"; }; - path = [ pkgs.which pkgs.procps ]; + path = [ + pkgs.which + pkgs.procps + ]; preStart = '' rm -rf /var/lib/graylog/plugins || true mkdir -p /var/lib/graylog/plugins -m 755 @@ -164,7 +177,7 @@ in done ''; serviceConfig = { - User="${cfg.user}"; + User = "${cfg.user}"; StateDirectory = "graylog"; ExecStart = "${cfg.package}/bin/graylogctl run"; }; diff --git a/nixos/modules/services/logging/heartbeat.nix b/nixos/modules/services/logging/heartbeat.nix index a9fa644d550df4..e0b475e8a284fd 100644 --- a/nixos/modules/services/logging/heartbeat.nix +++ b/nixos/modules/services/logging/heartbeat.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.heartbeat; @@ -29,7 +34,7 @@ in tags = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = "Tags to place on the shipped log messages"; }; diff --git a/nixos/modules/services/logging/journalbeat.nix b/nixos/modules/services/logging/journalbeat.nix index 5c35e84f88e092..af178a3838d26b 100644 --- a/nixos/modules/services/logging/journalbeat.nix +++ b/nixos/modules/services/logging/journalbeat.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.journalbeat; @@ -27,7 +32,7 @@ in tags = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = "Tags to place on the shipped log messages"; }; @@ -56,8 +61,8 @@ in { assertion = !lib.hasPrefix "/" cfg.stateDir; message = - "The option services.journalbeat.stateDir shouldn't be an absolute directory." + - " It should be a directory relative to /var/lib/."; + "The option services.journalbeat.stateDir shouldn't be an absolute directory." + + " It should be a directory relative to /var/lib/."; } ]; diff --git a/nixos/modules/services/logging/journaldriver.nix b/nixos/modules/services/logging/journaldriver.nix index bb82f8cf30ccdd..efb53de0b4842b 100644 --- a/nixos/modules/services/logging/journaldriver.nix +++ b/nixos/modules/services/logging/journaldriver.nix @@ -9,14 +9,22 @@ # For further information please consult the documentation in the # upstream repository at: https://github.com/tazjin/journaldriver/ -{ config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: -with lib; let cfg = config.services.journaldriver; -in { +with lib; +let + cfg = config.services.journaldriver; +in +{ options.services.journaldriver = { enable = mkOption { - type = types.bool; - default = false; + type = types.bool; + default = false; description = '' Whether to enable journaldriver to forward journald logs to Stackdriver Logging. @@ -24,16 +32,16 @@ in { }; logLevel = mkOption { - type = types.str; - default = "info"; + type = types.str; + default = "info"; description = '' Log level at which journaldriver logs its own output. ''; }; logName = mkOption { - type = with types; nullOr str; - default = null; + type = with types; nullOr str; + default = null; description = '' Configures the name of the target log in Stackdriver Logging. This option can be set to, for example, the hostname of a @@ -43,8 +51,8 @@ in { }; googleCloudProject = mkOption { - type = with types; nullOr str; - default = null; + type = with types; nullOr str; + default = null; description = '' Configures the name of the Google Cloud project to which to forward journald logs. @@ -55,8 +63,8 @@ in { }; logStream = mkOption { - type = with types; nullOr str; - default = null; + type = with types; nullOr str; + default = null; description = '' Configures the name of the Stackdriver Logging log stream into which to write journald entries. @@ -67,8 +75,8 @@ in { }; applicationCredentials = mkOption { - type = with types; nullOr path; - default = null; + type = with types; nullOr path; + default = null; description = '' Path to the service account private key (in JSON-format) used to forward log entries to Stackdriver Logging on non-GCP @@ -83,14 +91,14 @@ in { config = mkIf cfg.enable { systemd.services.journaldriver = { description = "Stackdriver Logging journal forwarder"; - script = "${pkgs.journaldriver}/bin/journaldriver"; - wants = [ "network-online.target" ]; - after = [ "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; + script = "${pkgs.journaldriver}/bin/journaldriver"; + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; + wantedBy = [ "multi-user.target" ]; serviceConfig = { - Restart = "always"; - DynamicUser = true; + Restart = "always"; + DynamicUser = true; # This directive lets systemd automatically configure # permissions on /var/lib/journaldriver, the directory in @@ -102,10 +110,10 @@ in { }; environment = { - RUST_LOG = cfg.logLevel; - LOG_NAME = cfg.logName; - LOG_STREAM = cfg.logStream; - GOOGLE_CLOUD_PROJECT = cfg.googleCloudProject; + RUST_LOG = cfg.logLevel; + LOG_NAME = cfg.logName; + LOG_STREAM = cfg.logStream; + GOOGLE_CLOUD_PROJECT = cfg.googleCloudProject; GOOGLE_APPLICATION_CREDENTIALS = cfg.applicationCredentials; }; }; diff --git a/nixos/modules/services/logging/journalwatch.nix b/nixos/modules/services/logging/journalwatch.nix index ab75ed656c1902..cfecf9c2942820 100644 --- a/nixos/modules/services/logging/journalwatch.nix +++ b/nixos/modules/services/logging/journalwatch.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.journalwatch; user = "journalwatch"; @@ -6,17 +11,19 @@ let group = "systemd-journal"; dataDir = "/var/lib/${user}"; - journalwatchConfig = pkgs.writeText "config" ('' - # (File Generated by NixOS journalwatch module.) - [DEFAULT] - mail_binary = ${cfg.mailBinary} - priority = ${toString cfg.priority} - mail_from = ${cfg.mailFrom} - '' - + lib.optionalString (cfg.mailTo != null) '' - mail_to = ${cfg.mailTo} - '' - + cfg.extraConfig); + journalwatchConfig = pkgs.writeText "config" ( + '' + # (File Generated by NixOS journalwatch module.) + [DEFAULT] + mail_binary = ${cfg.mailBinary} + priority = ${toString cfg.priority} + mail_from = ${cfg.mailFrom} + '' + + lib.optionalString (cfg.mailTo != null) '' + mail_to = ${cfg.mailTo} + '' + + cfg.extraConfig + ); journalwatchPatterns = pkgs.writeText "patterns" '' # (File Generated by NixOS journalwatch module.) @@ -25,25 +32,33 @@ let ''; # empty line at the end needed to to separate the blocks - mkPatterns = filterBlocks: lib.concatStringsSep "\n" (map (block: '' - ${block.match} - ${block.filters} + mkPatterns = + filterBlocks: + lib.concatStringsSep "\n" ( + map (block: '' + ${block.match} + ${block.filters} - '') filterBlocks); + '') filterBlocks + ); # can't use joinSymlinks directly, because when we point $XDG_CONFIG_HOME # to the /nix/store path, we still need the subdirectory "journalwatch" inside that # to match journalwatch's expectations - journalwatchConfigDir = pkgs.runCommand "journalwatch-config" - { preferLocalBuild = true; allowSubstitutes = false; } - '' - mkdir -p $out/journalwatch - ln -sf ${journalwatchConfig} $out/journalwatch/config - ln -sf ${journalwatchPatterns} $out/journalwatch/patterns - ''; - - -in { + journalwatchConfigDir = + pkgs.runCommand "journalwatch-config" + { + preferLocalBuild = true; + allowSubstitutes = false; + } + '' + mkdir -p $out/journalwatch + ln -sf ${journalwatchConfig} $out/journalwatch/config + ln -sf ${journalwatchPatterns} $out/journalwatch/patterns + ''; + +in +{ options = { services.journalwatch = { enable = lib.mkOption { @@ -103,42 +118,44 @@ in { Extra lines to be added verbatim to the journalwatch/config configuration file. You can add any commandline argument to the config, without the '--'. See `journalwatch --help` for all arguments and their description. - ''; + ''; }; filterBlocks = lib.mkOption { - type = lib.types.listOf (lib.types.submodule { - options = { - match = lib.mkOption { - type = lib.types.str; - example = "SYSLOG_IDENTIFIER = systemd"; - description = '' - Syntax: `field = value` - Specifies the log entry `field` this block should apply to. - If the `field` of a message matches this `value`, - this patternBlock's {option}`filters` are applied. - If `value` starts and ends with a slash, it is interpreted as - an extended python regular expression, if not, it's an exact match. - The journal fields are explained in systemd.journal-fields(7). - ''; - }; - - filters = lib.mkOption { - type = lib.types.str; - example = '' - (Stopped|Stopping|Starting|Started) .* - (Reached target|Stopped target) .* - ''; - description = '' - The filters to apply on all messages which satisfy {option}`match`. - Any of those messages that match any specified filter will be removed from journalwatch's output. - Each filter is an extended Python regular expression. - You can specify multiple filters and separate them by newlines. - Lines starting with '#' are comments. Inline-comments are not permitted. - ''; + type = lib.types.listOf ( + lib.types.submodule { + options = { + match = lib.mkOption { + type = lib.types.str; + example = "SYSLOG_IDENTIFIER = systemd"; + description = '' + Syntax: `field = value` + Specifies the log entry `field` this block should apply to. + If the `field` of a message matches this `value`, + this patternBlock's {option}`filters` are applied. + If `value` starts and ends with a slash, it is interpreted as + an extended python regular expression, if not, it's an exact match. + The journal fields are explained in systemd.journal-fields(7). + ''; + }; + + filters = lib.mkOption { + type = lib.types.str; + example = '' + (Stopped|Stopping|Starting|Started) .* + (Reached target|Stopped target) .* + ''; + description = '' + The filters to apply on all messages which satisfy {option}`match`. + Any of those messages that match any specified filter will be removed from journalwatch's output. + Each filter is an extended Python regular expression. + You can specify multiple filters and separate them by newlines. + Lines starting with '#' are comments. Inline-comments are not permitted. + ''; + }; }; - }; - }); + } + ); example = [ # examples taken from upstream @@ -174,7 +191,6 @@ in { } ]; - description = '' filterBlocks can be defined to blacklist journal messages which are not errors. Each block matches on a log entry field, and the filters in that block then are matched @@ -242,8 +258,8 @@ in { StateDirectoryMode = "0750"; ExecStart = "${lib.getExe cfg.package} mail"; # lowest CPU and IO priority, but both still in best-effort class to prevent starvation - Nice=19; - IOSchedulingPriority=7; + Nice = 19; + IOSchedulingPriority = 7; }; }; diff --git a/nixos/modules/services/logging/logcheck.nix b/nixos/modules/services/logging/logcheck.nix index d937a523c8661a..81b8ccb3f15f14 100644 --- a/nixos/modules/services/logging/logcheck.nix +++ b/nixos/modules/services/logging/logcheck.nix @@ -1,17 +1,22 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.logcheck; defaultRules = pkgs.runCommand "logcheck-default-rules" { preferLocalBuild = true; } '' - cp -prd ${pkgs.logcheck}/etc/logcheck $out - chmod u+w $out - rm -r $out/logcheck.* - ''; - - rulesDir = pkgs.symlinkJoin - { name = "logcheck-rules-dir"; - paths = ([ defaultRules ] ++ cfg.extraRulesDirs); - }; + cp -prd ${pkgs.logcheck}/etc/logcheck $out + chmod u+w $out + rm -r $out/logcheck.* + ''; + + rulesDir = pkgs.symlinkJoin { + name = "logcheck-rules-dir"; + paths = ([ defaultRules ] ++ cfg.extraRulesDirs); + }; configFile = pkgs.writeText "logcheck.conf" cfg.config; @@ -19,31 +24,49 @@ let flags = "-r ${rulesDir} -c ${configFile} -L ${logFiles} -${levelFlag} -m ${cfg.mailTo}"; - levelFlag = lib.getAttrFromPath [cfg.level] - { paranoid = "p"; - server = "s"; - workstation = "w"; - }; + levelFlag = lib.getAttrFromPath [ cfg.level ] { + paranoid = "p"; + server = "s"; + workstation = "w"; + }; cronJob = '' @reboot logcheck env PATH=/run/wrappers/bin:$PATH nice -n10 ${pkgs.logcheck}/sbin/logcheck -R ${flags} 2 ${cfg.timeOfDay} * * * logcheck env PATH=/run/wrappers/bin:$PATH nice -n10 ${pkgs.logcheck}/sbin/logcheck ${flags} ''; - writeIgnoreRule = name: {level, regex, ...}: - pkgs.writeTextFile - { inherit name; - destination = "/ignore.d.${level}/${name}"; - text = '' - ^\w{3} [ :[:digit:]]{11} [._[:alnum:]-]+ ${regex} - ''; - }; + writeIgnoreRule = + name: + { level, regex, ... }: + pkgs.writeTextFile { + inherit name; + destination = "/ignore.d.${level}/${name}"; + text = '' + ^\w{3} [ :[:digit:]]{11} [._[:alnum:]-]+ ${regex} + ''; + }; - writeIgnoreCronRule = name: {level, user, regex, cmdline, ...}: - let escapeRegex = lib.escape (lib.stringToCharacters "\\[]{}()^$?*+|."); - cmdline_ = builtins.unsafeDiscardStringContext cmdline; - re = if regex != "" then regex else if cmdline_ == "" then ".*" else escapeRegex cmdline_; - in writeIgnoreRule "cron-${name}" { + writeIgnoreCronRule = + name: + { + level, + user, + regex, + cmdline, + ... + }: + let + escapeRegex = lib.escape (lib.stringToCharacters "\\[]{}()^$?*+|."); + cmdline_ = builtins.unsafeDiscardStringContext cmdline; + re = + if regex != "" then + regex + else if cmdline_ == "" then + ".*" + else + escapeRegex cmdline_; + in + writeIgnoreRule "cron-${name}" { inherit level; regex = '' (/usr/bin/)?cron\[[0-9]+\]: \(${user}\) CMD \(${re}\)$ @@ -52,7 +75,11 @@ let levelOption = lib.mkOption { default = "server"; - type = lib.types.enum [ "workstation" "server" "paranoid" ]; + type = lib.types.enum [ + "workstation" + "server" + "paranoid" + ]; description = '' Set the logcheck level. ''; @@ -155,14 +182,17 @@ in files = lib.mkOption { default = [ "/var/log/messages" ]; type = lib.types.listOf lib.types.path; - example = [ "/var/log/messages" "/var/log/mail" ]; + example = [ + "/var/log/messages" + "/var/log/mail" + ]; description = '' Which log files to check. ''; }; extraRulesDirs = lib.mkOption { - default = []; + default = [ ]; example = [ "/etc/logcheck" ]; type = lib.types.listOf lib.types.path; description = '' @@ -171,7 +201,7 @@ in }; ignore = lib.mkOption { - default = {}; + default = { }; description = '' This option defines extra ignore rules. ''; @@ -179,7 +209,7 @@ in }; ignoreCron = lib.mkOption { - default = {}; + default = { }; description = '' This option defines extra ignore rules for cronjobs. ''; @@ -187,9 +217,12 @@ in }; extraGroups = lib.mkOption { - default = []; + default = [ ]; type = lib.types.listOf lib.types.str; - example = [ "postdrop" "mongodb" ]; + example = [ + "postdrop" + "mongodb" + ]; description = '' Extra groups for the logcheck user, for example to be able to use sendmail, or to access certain log files. @@ -201,8 +234,8 @@ in config = lib.mkIf cfg.enable { services.logcheck.extraRulesDirs = - lib.mapAttrsToList writeIgnoreRule cfg.ignore - ++ lib.mapAttrsToList writeIgnoreCronRule cfg.ignoreCron; + lib.mapAttrsToList writeIgnoreRule cfg.ignore + ++ lib.mapAttrsToList writeIgnoreCronRule cfg.ignoreCron; users.users = lib.optionalAttrs (cfg.user == "logcheck") { logcheck = { @@ -214,7 +247,7 @@ in }; }; users.groups = lib.optionalAttrs (cfg.user == "logcheck") { - logcheck = {}; + logcheck = { }; }; systemd.tmpfiles.settings.logcheck = { @@ -229,11 +262,20 @@ in }; services.cron.systemCronJobs = - let withTime = name: {timeArgs, ...}: timeArgs != null; - mkCron = name: {user, cmdline, timeArgs, ...}: '' - ${timeArgs} ${user} ${cmdline} - ''; - in lib.mapAttrsToList mkCron (lib.filterAttrs withTime cfg.ignoreCron) - ++ [ cronJob ]; + let + withTime = name: { timeArgs, ... }: timeArgs != null; + mkCron = + name: + { + user, + cmdline, + timeArgs, + ... + }: + '' + ${timeArgs} ${user} ${cmdline} + ''; + in + lib.mapAttrsToList mkCron (lib.filterAttrs withTime cfg.ignoreCron) ++ [ cronJob ]; }; } diff --git a/nixos/modules/services/logging/logstash.nix b/nixos/modules/services/logging/logstash.nix index 31f0eef77c461b..1bf3e6f81eaabe 100644 --- a/nixos/modules/services/logging/logstash.nix +++ b/nixos/modules/services/logging/logstash.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.logstash; ops = lib.optionalString; @@ -22,21 +27,31 @@ let logstashJvmOptionsFile = pkgs.writeText "jvm.options" cfg.extraJvmOptions; - logstashSettingsDir = pkgs.runCommand "logstash-settings" { - inherit logstashJvmOptionsFile; - inherit logstashSettingsYml; - preferLocalBuild = true; - } '' - mkdir -p $out - ln -s $logstashSettingsYml $out/logstash.yml - ln -s $logstashJvmOptionsFile $out/jvm.options - ''; + logstashSettingsDir = + pkgs.runCommand "logstash-settings" + { + inherit logstashJvmOptionsFile; + inherit logstashSettingsYml; + preferLocalBuild = true; + } + '' + mkdir -p $out + ln -s $logstashSettingsYml $out/logstash.yml + ln -s $logstashJvmOptionsFile $out/jvm.options + ''; in { imports = [ - (lib.mkRenamedOptionModule [ "services" "logstash" "address" ] [ "services" "logstash" "listenAddress" ]) - (lib.mkRemovedOptionModule [ "services" "logstash" "enableWeb" ] "The web interface was removed from logstash") + (lib.mkRenamedOptionModule + [ "services" "logstash" "address" ] + [ "services" "logstash" "listenAddress" ] + ) + (lib.mkRemovedOptionModule [ + "services" + "logstash" + "enableWeb" + ] "The web interface was removed from logstash") ]; ###### interface @@ -70,7 +85,13 @@ in }; logLevel = lib.mkOption { - type = lib.types.enum [ "debug" "info" "warn" "error" "fatal" ]; + type = lib.types.enum [ + "debug" + "info" + "warn" + "error" + "fatal" + ]; default = "warn"; description = "Logging verbosity level."; }; @@ -161,7 +182,6 @@ in }; }; - ###### implementation config = lib.mkIf cfg.enable { @@ -171,15 +191,17 @@ in path = [ pkgs.bash ]; serviceConfig = { ExecStartPre = ''${pkgs.coreutils}/bin/mkdir -p "${cfg.dataDir}" ; ${pkgs.coreutils}/bin/chmod 700 "${cfg.dataDir}"''; - ExecStart = lib.concatStringsSep " " (lib.filter (s: lib.stringLength s != 0) [ - "${cfg.package}/bin/logstash" - "-w ${toString cfg.filterWorkers}" - (lib.concatMapStringsSep " " (x: "--path.plugins ${x}") cfg.plugins) - "${verbosityFlag}" - "-f ${logstashConf}" - "--path.settings ${logstashSettingsDir}" - "--path.data ${cfg.dataDir}" - ]); + ExecStart = lib.concatStringsSep " " ( + lib.filter (s: lib.stringLength s != 0) [ + "${cfg.package}/bin/logstash" + "-w ${toString cfg.filterWorkers}" + (lib.concatMapStringsSep " " (x: "--path.plugins ${x}") cfg.plugins) + "${verbosityFlag}" + "-f ${logstashConf}" + "--path.settings ${logstashSettingsDir}" + "--path.data ${cfg.dataDir}" + ] + ); }; }; }; diff --git a/nixos/modules/services/logging/rsyslogd.nix b/nixos/modules/services/logging/rsyslogd.nix index 88a8ff840682ee..01a94c549dfc81 100644 --- a/nixos/modules/services/logging/rsyslogd.nix +++ b/nixos/modules/services/logging/rsyslogd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.rsyslogd; @@ -75,27 +80,26 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { environment.systemPackages = [ pkgs.rsyslog ]; - systemd.services.syslog = - { description = "Syslog Daemon"; + systemd.services.syslog = { + description = "Syslog Daemon"; - requires = [ "syslog.socket" ]; + requires = [ "syslog.socket" ]; - wantedBy = [ "multi-user.target" ]; + wantedBy = [ "multi-user.target" ]; - serviceConfig = - { ExecStart = "${pkgs.rsyslog}/sbin/rsyslogd ${toString cfg.extraParams} -f ${syslogConf} -n"; - ExecStartPre = "${pkgs.coreutils}/bin/mkdir -p /var/spool/rsyslog"; - # Prevent syslogd output looping back through journald. - StandardOutput = "null"; - }; + serviceConfig = { + ExecStart = "${pkgs.rsyslog}/sbin/rsyslogd ${toString cfg.extraParams} -f ${syslogConf} -n"; + ExecStartPre = "${pkgs.coreutils}/bin/mkdir -p /var/spool/rsyslog"; + # Prevent syslogd output looping back through journald. + StandardOutput = "null"; }; + }; }; diff --git a/nixos/modules/services/logging/syslog-ng.nix b/nixos/modules/services/logging/syslog-ng.nix index d9d4b0cdb94a86..4c04d1f1f5ddd2 100644 --- a/nixos/modules/services/logging/syslog-ng.nix +++ b/nixos/modules/services/logging/syslog-ng.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.syslog-ng; @@ -14,14 +19,17 @@ let syslogngOptions = [ "--foreground" - "--module-path=${lib.concatStringsSep ":" (["${cfg.package}/lib/syslog-ng"] ++ cfg.extraModulePaths)}" + "--module-path=${ + lib.concatStringsSep ":" ([ "${cfg.package}/lib/syslog-ng" ] ++ cfg.extraModulePaths) + }" "--cfgfile=${syslogngConfig}" "--control=${ctrlSocket}" "--persist-file=${persistFile}" "--pidfile=${pidFile}" ]; -in { +in +{ imports = [ (lib.mkRemovedOptionModule [ "services" "syslog-ng" "serviceName" ] "") (lib.mkRemovedOptionModule [ "services" "syslog-ng" "listenToJournal" ] "") @@ -40,7 +48,7 @@ in { package = lib.mkPackageOption pkgs "syslogng" { }; extraModulePaths = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' A list of paths that should be included in syslog-ng's `--module-path` option. They should usually diff --git a/nixos/modules/services/logging/syslogd.nix b/nixos/modules/services/logging/syslogd.nix index ad2d09b5a8de6a..d1994c9f1b8e6b 100644 --- a/nixos/modules/services/logging/syslogd.nix +++ b/nixos/modules/services/logging/syslogd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.syslogd; @@ -92,35 +97,35 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { - assertions = - [ { assertion = !config.services.rsyslogd.enable; - message = "rsyslogd conflicts with syslogd"; - } - ]; + assertions = [ + { + assertion = !config.services.rsyslogd.enable; + message = "rsyslogd conflicts with syslogd"; + } + ]; environment.systemPackages = [ pkgs.sysklogd ]; services.syslogd.extraParams = lib.optional cfg.enableNetworkInput "-r"; # FIXME: restarting syslog seems to break journal logging. - systemd.services.syslog = - { description = "Syslog Daemon"; + systemd.services.syslog = { + description = "Syslog Daemon"; - requires = [ "syslog.socket" ]; + requires = [ "syslog.socket" ]; - wantedBy = [ "multi-user.target" ]; + wantedBy = [ "multi-user.target" ]; - serviceConfig = - { ExecStart = "${pkgs.sysklogd}/sbin/syslogd ${toString cfg.extraParams} -f ${syslogConf} -n"; - # Prevent syslogd output looping back through journald. - StandardOutput = "null"; - }; + serviceConfig = { + ExecStart = "${pkgs.sysklogd}/sbin/syslogd ${toString cfg.extraParams} -f ${syslogConf} -n"; + # Prevent syslogd output looping back through journald. + StandardOutput = "null"; }; + }; }; diff --git a/nixos/modules/services/logging/ulogd.nix b/nixos/modules/services/logging/ulogd.nix index 9d1d8e61231dcf..76fa40284f759e 100644 --- a/nixos/modules/services/logging/ulogd.nix +++ b/nixos/modules/services/logging/ulogd.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.ulogd; settingsFormat = pkgs.formats.ini { listsAsDuplicateKeys = true; }; settingsFile = settingsFormat.generate "ulogd.conf" cfg.settings; -in { +in +{ options = { services.ulogd = { enable = lib.mkEnableOption "ulogd, a userspace logging daemon for netfilter/iptables related logging"; @@ -29,15 +35,19 @@ in { }; type = settingsFormat.type; default = { }; - description = - "Configuration for ulogd. See {file}`/share/doc/ulogd/` in `pkgs.ulogd.doc`."; + description = "Configuration for ulogd. See {file}`/share/doc/ulogd/` in `pkgs.ulogd.doc`."; }; logLevel = lib.mkOption { - type = lib.types.enum [ 1 3 5 7 8 ]; + type = lib.types.enum [ + 1 + 3 + 5 + 7 + 8 + ]; default = 5; - description = - "Log level (1 = debug, 3 = info, 5 = notice, 7 = error, 8 = fatal)"; + description = "Log level (1 = debug, 3 = info, 5 = notice, 7 = error, 8 = fatal)"; }; }; }; @@ -50,10 +60,7 @@ in { before = [ "network-pre.target" ]; serviceConfig = { - ExecStart = - "${pkgs.ulogd}/bin/ulogd -c ${settingsFile} --verbose --loglevel ${ - toString cfg.logLevel - }"; + ExecStart = "${pkgs.ulogd}/bin/ulogd -c ${settingsFile} --verbose --loglevel ${toString cfg.logLevel}"; ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; }; }; diff --git a/nixos/modules/services/logging/vector.nix b/nixos/modules/services/logging/vector.nix index 7c69e790171f21..dd9aa769ee5925 100644 --- a/nixos/modules/services/logging/vector.nix +++ b/nixos/modules/services/logging/vector.nix @@ -1,5 +1,11 @@ -{ config, lib, pkgs, ... }: -let cfg = config.services.vector; +{ + config, + lib, + pkgs, + ... +}: +let + cfg = config.services.vector; in { @@ -38,13 +44,16 @@ in let format = pkgs.formats.toml { }; conf = format.generate "vector.toml" cfg.settings; - validateConfig = file: - pkgs.runCommand "validate-vector-conf" { - nativeBuildInputs = [ cfg.package ]; - } '' - vector validate --no-environment "${file}" - ln -s "${file}" "$out" - ''; + validateConfig = + file: + pkgs.runCommand "validate-vector-conf" + { + nativeBuildInputs = [ cfg.package ]; + } + '' + vector validate --no-environment "${file}" + ln -s "${file}" "$out" + ''; in { ExecStart = "${lib.getExe cfg.package} --config ${validateConfig conf}"; diff --git a/nixos/modules/services/mail/clamsmtp.nix b/nixos/modules/services/mail/clamsmtp.nix index d40ed7bf6e2ded..e54d8893a3b6ee 100644 --- a/nixos/modules/services/mail/clamsmtp.nix +++ b/nixos/modules/services/mail/clamsmtp.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.clamsmtp; clamdSocket = "/run/clamav/clamd.ctl"; # See services/security/clamav.nix @@ -15,155 +20,169 @@ in instances = lib.mkOption { description = "Instances of clamsmtp to run."; - type = lib.types.listOf (lib.types.submodule { options = { - action = lib.mkOption { - type = lib.types.enum [ "bounce" "drop" "pass" ]; - default = "drop"; - description = '' - Action to take when a virus is detected. - - Note that viruses often spoof sender addresses, so bouncing is - in most cases not a good idea. - ''; - }; - - header = lib.mkOption { - type = lib.types.str; - default = ""; - example = "X-Virus-Scanned: ClamAV using ClamSMTP"; - description = '' - A header to add to scanned messages. See clamsmtpd.conf(5) for - more details. Empty means no header. - ''; - }; - - keepAlives = lib.mkOption { - type = lib.types.int; - default = 0; - description = '' - Number of seconds to wait between each NOOP sent to the sending - server. 0 to disable. - - This is meant for slow servers where the sending MTA times out - waiting for clamd to scan the file. - ''; - }; - - listen = lib.mkOption { - type = lib.types.str; - example = "127.0.0.1:10025"; - description = '' - Address to wait for incoming SMTP connections on. See - clamsmtpd.conf(5) for more details. - ''; - }; - - quarantine = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Whether to quarantine files that contain viruses by leaving them - in the temporary directory. - ''; - }; - - maxConnections = lib.mkOption { - type = lib.types.int; - default = 64; - description = "Maximum number of connections to accept at once."; - }; - - outAddress = lib.mkOption { - type = lib.types.str; - description = '' - Address of the SMTP server to send email to once it has been - scanned. - ''; - }; - - tempDirectory = lib.mkOption { - type = lib.types.str; - default = "/tmp"; - description = '' - Temporary directory that needs to be accessible to both clamd - and clamsmtpd. - ''; - }; - - timeout = lib.mkOption { - type = lib.types.int; - default = 180; - description = "Time-out for network connections."; - }; - - transparentProxy = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Enable clamsmtp's transparent proxy support."; - }; - - virusAction = lib.mkOption { - type = with lib.types; nullOr path; - default = null; - description = '' - Command to run when a virus is found. Please see VIRUS ACTION in - clamsmtpd(8) for a discussion of this option and its safe use. - ''; - }; - - xClient = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Send the XCLIENT command to the receiving server, for forwarding - client addresses and connection information if the receiving - server supports this feature. - ''; - }; - };}); + type = lib.types.listOf ( + lib.types.submodule { + options = { + action = lib.mkOption { + type = lib.types.enum [ + "bounce" + "drop" + "pass" + ]; + default = "drop"; + description = '' + Action to take when a virus is detected. + + Note that viruses often spoof sender addresses, so bouncing is + in most cases not a good idea. + ''; + }; + + header = lib.mkOption { + type = lib.types.str; + default = ""; + example = "X-Virus-Scanned: ClamAV using ClamSMTP"; + description = '' + A header to add to scanned messages. See clamsmtpd.conf(5) for + more details. Empty means no header. + ''; + }; + + keepAlives = lib.mkOption { + type = lib.types.int; + default = 0; + description = '' + Number of seconds to wait between each NOOP sent to the sending + server. 0 to disable. + + This is meant for slow servers where the sending MTA times out + waiting for clamd to scan the file. + ''; + }; + + listen = lib.mkOption { + type = lib.types.str; + example = "127.0.0.1:10025"; + description = '' + Address to wait for incoming SMTP connections on. See + clamsmtpd.conf(5) for more details. + ''; + }; + + quarantine = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Whether to quarantine files that contain viruses by leaving them + in the temporary directory. + ''; + }; + + maxConnections = lib.mkOption { + type = lib.types.int; + default = 64; + description = "Maximum number of connections to accept at once."; + }; + + outAddress = lib.mkOption { + type = lib.types.str; + description = '' + Address of the SMTP server to send email to once it has been + scanned. + ''; + }; + + tempDirectory = lib.mkOption { + type = lib.types.str; + default = "/tmp"; + description = '' + Temporary directory that needs to be accessible to both clamd + and clamsmtpd. + ''; + }; + + timeout = lib.mkOption { + type = lib.types.int; + default = 180; + description = "Time-out for network connections."; + }; + + transparentProxy = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Enable clamsmtp's transparent proxy support."; + }; + + virusAction = lib.mkOption { + type = with lib.types; nullOr path; + default = null; + description = '' + Command to run when a virus is found. Please see VIRUS ACTION in + clamsmtpd(8) for a discussion of this option and its safe use. + ''; + }; + + xClient = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Send the XCLIENT command to the receiving server, for forwarding + client addresses and connection information if the receiving + server supports this feature. + ''; + }; + }; + } + ); }; }; }; ##### implementation - config = let - configfile = conf: pkgs.writeText "clamsmtpd.conf" - '' - Action: ${conf.action} - ClamAddress: ${clamdSocket} - Header: ${conf.header} - KeepAlives: ${toString conf.keepAlives} - Listen: ${conf.listen} - Quarantine: ${if conf.quarantine then "on" else "off"} - MaxConnections: ${toString conf.maxConnections} - OutAddress: ${conf.outAddress} - TempDirectory: ${conf.tempDirectory} - TimeOut: ${toString conf.timeout} - TransparentProxy: ${if conf.transparentProxy then "on" else "off"} - User: clamav - ${lib.optionalString (conf.virusAction != null) "VirusAction: ${conf.virusAction}"} - XClient: ${if conf.xClient then "on" else "off"} - ''; - in + config = + let + configfile = + conf: + pkgs.writeText "clamsmtpd.conf" '' + Action: ${conf.action} + ClamAddress: ${clamdSocket} + Header: ${conf.header} + KeepAlives: ${toString conf.keepAlives} + Listen: ${conf.listen} + Quarantine: ${if conf.quarantine then "on" else "off"} + MaxConnections: ${toString conf.maxConnections} + OutAddress: ${conf.outAddress} + TempDirectory: ${conf.tempDirectory} + TimeOut: ${toString conf.timeout} + TransparentProxy: ${if conf.transparentProxy then "on" else "off"} + User: clamav + ${lib.optionalString (conf.virusAction != null) "VirusAction: ${conf.virusAction}"} + XClient: ${if conf.xClient then "on" else "off"} + ''; + in lib.mkIf cfg.enable { assertions = [ - { assertion = config.services.clamav.daemon.enable; + { + assertion = config.services.clamav.daemon.enable; message = "clamsmtp requires clamav to be enabled"; } ]; - systemd.services = lib.listToAttrs (lib.imap1 (i: conf: - lib.nameValuePair "clamsmtp-${toString i}" { - description = "ClamSMTP instance ${toString i}"; - wantedBy = [ "multi-user.target" ]; - script = "exec ${pkgs.clamsmtp}/bin/clamsmtpd -f ${configfile conf}"; - after = [ "clamav-daemon.service" ]; - requires = [ "clamav-daemon.service" ]; - serviceConfig.Type = "forking"; - serviceConfig.PrivateTmp = "yes"; - unitConfig.JoinsNamespaceOf = "clamav-daemon.service"; - } - ) cfg.instances); + systemd.services = lib.listToAttrs ( + lib.imap1 ( + i: conf: + lib.nameValuePair "clamsmtp-${toString i}" { + description = "ClamSMTP instance ${toString i}"; + wantedBy = [ "multi-user.target" ]; + script = "exec ${pkgs.clamsmtp}/bin/clamsmtpd -f ${configfile conf}"; + after = [ "clamav-daemon.service" ]; + requires = [ "clamav-daemon.service" ]; + serviceConfig.Type = "forking"; + serviceConfig.PrivateTmp = "yes"; + unitConfig.JoinsNamespaceOf = "clamav-daemon.service"; + } + ) cfg.instances + ); }; meta.maintainers = with lib.maintainers; [ ekleog ]; diff --git a/nixos/modules/services/mail/davmail.nix b/nixos/modules/services/mail/davmail.nix index 00e1ecb3852b36..4f97e8a5966dc2 100644 --- a/nixos/modules/services/mail/davmail.nix +++ b/nixos/modules/services/mail/davmail.nix @@ -1,123 +1,147 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.davmail; - configType = with lib.types; - oneOf [ (attrsOf configType) str int bool ] // { + configType = + with lib.types; + oneOf [ + (attrsOf configType) + str + int + bool + ] + // { description = "davmail config type (str, int, bool or attribute set thereof)"; }; toStr = val: if lib.isBool val then lib.boolToString val else toString val; - linesForAttrs = attrs: lib.concatMap (name: let value = attrs.${name}; in - if lib.isAttrs value - then map (line: name + "." + line) (linesForAttrs value) - else [ "${name}=${toStr value}" ] - ) (lib.attrNames attrs); - - configFile = pkgs.writeText "davmail.properties" (lib.concatStringsSep "\n" (linesForAttrs cfg.config)); + linesForAttrs = + attrs: + lib.concatMap ( + name: + let + value = attrs.${name}; + in + if lib.isAttrs value then + map (line: name + "." + line) (linesForAttrs value) + else + [ "${name}=${toStr value}" ] + ) (lib.attrNames attrs); + + configFile = pkgs.writeText "davmail.properties" ( + lib.concatStringsSep "\n" (linesForAttrs cfg.config) + ); in - { - options.services.davmail = { - enable = lib.mkEnableOption "davmail, an MS Exchange gateway"; +{ + options.services.davmail = { + enable = lib.mkEnableOption "davmail, an MS Exchange gateway"; - url = lib.mkOption { - type = lib.types.str; - description = "Outlook Web Access URL to access the exchange server, i.e. the base webmail URL."; - example = "https://outlook.office365.com/EWS/Exchange.asmx"; - }; + url = lib.mkOption { + type = lib.types.str; + description = "Outlook Web Access URL to access the exchange server, i.e. the base webmail URL."; + example = "https://outlook.office365.com/EWS/Exchange.asmx"; + }; - config = lib.mkOption { - type = configType; - default = {}; - description = '' - Davmail configuration. Refer to - - and - for details on supported values. - ''; - example = lib.literalExpression '' - { - davmail.allowRemote = true; - davmail.imapPort = 55555; - davmail.bindAddress = "10.0.1.2"; - davmail.smtpSaveInSent = true; - davmail.folderSizeLimit = 10; - davmail.caldavAutoSchedule = false; - log4j.logger.rootLogger = "DEBUG"; - } - ''; + config = lib.mkOption { + type = configType; + default = { }; + description = '' + Davmail configuration. Refer to + + and + for details on supported values. + ''; + example = lib.literalExpression '' + { + davmail.allowRemote = true; + davmail.imapPort = 55555; + davmail.bindAddress = "10.0.1.2"; + davmail.smtpSaveInSent = true; + davmail.folderSizeLimit = 10; + davmail.caldavAutoSchedule = false; + log4j.logger.rootLogger = "DEBUG"; + } + ''; + }; + }; + + config = lib.mkIf cfg.enable { + + services.davmail.config = { + davmail = lib.mapAttrs (name: lib.mkDefault) { + server = true; + disableUpdateCheck = true; + logFilePath = "/var/log/davmail/davmail.log"; + logFileSize = "1MB"; + mode = "auto"; + url = cfg.url; + caldavPort = 1080; + imapPort = 1143; + ldapPort = 1389; + popPort = 1110; + smtpPort = 1025; + }; + log4j = { + logger.davmail = lib.mkDefault "WARN"; + logger.httpclient.wire = lib.mkDefault "WARN"; + logger.org.apache.commons.httpclient = lib.mkDefault "WARN"; + rootLogger = lib.mkDefault "WARN"; }; }; - config = lib.mkIf cfg.enable { - - services.davmail.config = { - davmail = lib.mapAttrs (name: lib.mkDefault) { - server = true; - disableUpdateCheck = true; - logFilePath = "/var/log/davmail/davmail.log"; - logFileSize = "1MB"; - mode = "auto"; - url = cfg.url; - caldavPort = 1080; - imapPort = 1143; - ldapPort = 1389; - popPort = 1110; - smtpPort = 1025; - }; - log4j = { - logger.davmail = lib.mkDefault "WARN"; - logger.httpclient.wire = lib.mkDefault "WARN"; - logger.org.apache.commons.httpclient = lib.mkDefault "WARN"; - rootLogger = lib.mkDefault "WARN"; - }; - }; + systemd.services.davmail = { + description = "DavMail POP/IMAP/SMTP Exchange Gateway"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + + serviceConfig = { + Type = "simple"; + ExecStart = "${pkgs.davmail}/bin/davmail ${configFile}"; + Restart = "on-failure"; + DynamicUser = "yes"; + LogsDirectory = "davmail"; + + CapabilityBoundingSet = [ "" ]; + DeviceAllow = [ "" ]; + LockPersonality = true; + NoNewPrivileges = true; + PrivateDevices = true; + PrivateTmp = true; + PrivateUsers = true; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectSystem = "strict"; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + RemoveIPC = true; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallFilter = "@system-service"; + SystemCallErrorNumber = "EPERM"; + UMask = "0077"; - systemd.services.davmail = { - description = "DavMail POP/IMAP/SMTP Exchange Gateway"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - - serviceConfig = { - Type = "simple"; - ExecStart = "${pkgs.davmail}/bin/davmail ${configFile}"; - Restart = "on-failure"; - DynamicUser = "yes"; - LogsDirectory = "davmail"; - - CapabilityBoundingSet = [ "" ]; - DeviceAllow = [ "" ]; - LockPersonality = true; - NoNewPrivileges = true; - PrivateDevices = true; - PrivateTmp = true; - PrivateUsers = true; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectSystem = "strict"; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallFilter = "@system-service"; - SystemCallErrorNumber = "EPERM"; - UMask = "0077"; - - }; }; - - environment.systemPackages = [ pkgs.davmail ]; }; - } + + environment.systemPackages = [ pkgs.davmail ]; + }; +} diff --git a/nixos/modules/services/mail/dkimproxy-out.nix b/nixos/modules/services/mail/dkimproxy-out.nix index 1d6a143dc83632..2fefcd6b68a26c 100644 --- a/nixos/modules/services/mail/dkimproxy-out.nix +++ b/nixos/modules/services/mail/dkimproxy-out.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.dkimproxy-out; keydir = "/var/lib/dkimproxy-out"; @@ -13,11 +18,11 @@ in type = lib.types.bool; default = false; description = '' - Whether to enable dkimproxy_out. + Whether to enable dkimproxy_out. - Note that a key will be auto-generated, and can be found in - ${keydir}. - ''; + Note that a key will be auto-generated, and can be found in + ${keydir}. + ''; }; listen = lib.mkOption { @@ -34,7 +39,10 @@ in domains = lib.mkOption { type = with lib.types; listOf str; - example = [ "example.org" "example.com" ]; + example = [ + "example.org" + "example.com" + ]; description = "List of domains DKIMproxy can sign for."; }; @@ -42,22 +50,22 @@ in type = lib.types.str; example = "selector1"; description = '' - The selector to use for DKIM key identification. + The selector to use for DKIM key identification. - For example, if 'selector1' is used here, then for each domain - 'example.org' given in `domain`, 'selector1._domainkey.example.org' - should contain the TXT record indicating the public key is the one - in ${pubkey}: "v=DKIM1; t=s; p=[THE PUBLIC KEY]". - ''; + For example, if 'selector1' is used here, then for each domain + 'example.org' given in `domain`, 'selector1._domainkey.example.org' + should contain the TXT record indicating the public key is the one + in ${pubkey}: "v=DKIM1; t=s; p=[THE PUBLIC KEY]". + ''; }; keySize = lib.mkOption { type = lib.types.int; default = 2048; description = '' - Size of the RSA key to use to sign outgoing emails. Note that the - maximum mandatorily verified as per RFC6376 is 2048. - ''; + Size of the RSA key to use to sign outgoing emails. Note that the + maximum mandatorily verified as per RFC6376 is 2048. + ''; }; # TODO: allow signature for other schemes than dkim(c=relaxed/relaxed)? @@ -67,9 +75,9 @@ in }; ##### implementation - config = let - configfile = pkgs.writeText "dkimproxy_out.conf" - '' + config = + let + configfile = pkgs.writeText "dkimproxy_out.conf" '' listen ${cfg.listen} relay ${cfg.relay} @@ -80,9 +88,9 @@ in keyfile ${privkey} ''; - in + in lib.mkIf cfg.enable { - users.groups.dkimproxy-out = {}; + users.groups.dkimproxy-out = { }; users.users.dkimproxy-out = { description = "DKIMproxy_out daemon"; group = "dkimproxy-out"; diff --git a/nixos/modules/services/mail/dovecot.nix b/nixos/modules/services/mail/dovecot.nix index 1d17dd66e07168..4388be30a9350a 100644 --- a/nixos/modules/services/mail/dovecot.nix +++ b/nixos/modules/services/mail/dovecot.nix @@ -1,11 +1,35 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) attrValues concatMapStringsSep concatStrings - concatStringsSep flatten imap1 literalExpression mapAttrsToList - mkEnableOption mkIf mkOption mkRemovedOptionModule optional optionalAttrs - optionalString singleton types mkRenamedOptionModule nameValuePair - mapAttrs' listToAttrs filter; + inherit (lib) + attrValues + concatMapStringsSep + concatStrings + concatStringsSep + flatten + imap1 + literalExpression + mapAttrsToList + mkEnableOption + mkIf + mkOption + mkRemovedOptionModule + optional + optionalAttrs + optionalString + singleton + types + mkRenamedOptionModule + nameValuePair + mapAttrs' + listToAttrs + filter + ; inherit (lib.strings) match; cfg = config.services.dovecot2; @@ -14,25 +38,36 @@ let baseDir = "/run/dovecot2"; stateDir = "/var/lib/dovecot"; - sieveScriptSettings = mapAttrs' (to: _: nameValuePair "sieve_${to}" "${stateDir}/sieve/${to}") cfg.sieve.scripts; - imapSieveMailboxSettings = listToAttrs (flatten (imap1 (idx: el: - singleton { - name = "imapsieve_mailbox${toString idx}_name"; - value = el.name; - } ++ optional (el.from != null) { - name = "imapsieve_mailbox${toString idx}_from"; - value = el.from; - } ++ optional (el.causes != []) { - name = "imapsieve_mailbox${toString idx}_causes"; - value = concatStringsSep "," el.causes; - } ++ optional (el.before != null) { - name = "imapsieve_mailbox${toString idx}_before"; - value = "file:${stateDir}/imapsieve/before/${baseNameOf el.before}"; - } ++ optional (el.after != null) { - name = "imapsieve_mailbox${toString idx}_after"; - value = "file:${stateDir}/imapsieve/after/${baseNameOf el.after}"; - } - ) cfg.imapsieve.mailbox)); + sieveScriptSettings = mapAttrs' ( + to: _: nameValuePair "sieve_${to}" "${stateDir}/sieve/${to}" + ) cfg.sieve.scripts; + imapSieveMailboxSettings = listToAttrs ( + flatten ( + imap1 ( + idx: el: + singleton { + name = "imapsieve_mailbox${toString idx}_name"; + value = el.name; + } + ++ optional (el.from != null) { + name = "imapsieve_mailbox${toString idx}_from"; + value = el.from; + } + ++ optional (el.causes != [ ]) { + name = "imapsieve_mailbox${toString idx}_causes"; + value = concatStringsSep "," el.causes; + } + ++ optional (el.before != null) { + name = "imapsieve_mailbox${toString idx}_before"; + value = "file:${stateDir}/imapsieve/before/${baseNameOf el.before}"; + } + ++ optional (el.after != null) { + name = "imapsieve_mailbox${toString idx}_after"; + value = "file:${stateDir}/imapsieve/after/${baseNameOf el.after}"; + } + ) cfg.imapsieve.mailbox + ) + ); mkExtraConfigCollisionWarning = term: '' You referred to ${term} in `services.dovecot2.extraConfig`. @@ -45,26 +80,31 @@ let # Those settings are automatically set based on other parts # of this module. - automaticallySetPluginSettings = [ - "sieve_plugins" - "sieve_extensions" - "sieve_global_extensions" - "sieve_pipe_bin_dir" - ] - ++ (builtins.attrNames sieveScriptSettings) - ++ (builtins.attrNames imapSieveMailboxSettings); + automaticallySetPluginSettings = + [ + "sieve_plugins" + "sieve_extensions" + "sieve_global_extensions" + "sieve_pipe_bin_dir" + ] + ++ (builtins.attrNames sieveScriptSettings) + ++ (builtins.attrNames imapSieveMailboxSettings); # The idea is to match everything that looks like `$term =` # but not `# $term something something` # or `# $term = some value` because those are comments. configContainsSetting = lines: term: (match "^[^#]*\b${term}\b.*=" lines) != null; - warnAboutExtraConfigCollisions = map mkExtraConfigCollisionWarning (filter (configContainsSetting cfg.extraConfig) automaticallySetPluginSettings); + warnAboutExtraConfigCollisions = map mkExtraConfigCollisionWarning ( + filter (configContainsSetting cfg.extraConfig) automaticallySetPluginSettings + ); - sievePipeBinScriptDirectory = pkgs.linkFarm "sieve-pipe-bins" (map (el: { + sievePipeBinScriptDirectory = pkgs.linkFarm "sieve-pipe-bins" ( + map (el: { name = builtins.unsafeDiscardStringContext (baseNameOf el); path = el; - }) cfg.sieve.pipeBins); + }) cfg.sieve.pipeBins + ); dovecotConf = concatStrings [ '' @@ -75,29 +115,28 @@ let mail_plugins = $mail_plugins ${concatStringsSep " " cfg.mailPlugins.globally.enable} '' - ( - concatStringsSep "\n" ( - mapAttrsToList ( - protocol: plugins: '' - protocol ${protocol} { - mail_plugins = $mail_plugins ${concatStringsSep " " plugins.enable} - } - '' - ) cfg.mailPlugins.perProtocol - ) - ) + (concatStringsSep "\n" ( + mapAttrsToList (protocol: plugins: '' + protocol ${protocol} { + mail_plugins = $mail_plugins ${concatStringsSep " " plugins.enable} + } + '') cfg.mailPlugins.perProtocol + )) ( - if cfg.sslServerCert == null then '' - ssl = no - disable_plaintext_auth = no - '' else '' - ssl_cert = <${cfg.sslServerCert} - ssl_key = <${cfg.sslServerKey} - ${optionalString (cfg.sslCACert != null) ("ssl_ca = <" + cfg.sslCACert)} - ${optionalString cfg.enableDHE ''ssl_dh = <${config.security.dhparams.params.dovecot2.path}''} - disable_plaintext_auth = yes - '' + if cfg.sslServerCert == null then + '' + ssl = no + disable_plaintext_auth = no + '' + else + '' + ssl_cert = <${cfg.sslServerCert} + ssl_key = <${cfg.sslServerKey} + ${optionalString (cfg.sslCACert != null) ("ssl_ca = <" + cfg.sslCACert)} + ${optionalString cfg.enableDHE ''ssl_dh = <${config.security.dhparams.params.dovecot2.path}''} + disable_plaintext_auth = yes + '' ) '' @@ -118,49 +157,43 @@ let } '' - ( - optionalString cfg.enablePAM '' - userdb { - driver = passwd - } + (optionalString cfg.enablePAM '' + userdb { + driver = passwd + } - passdb { - driver = pam - args = ${optionalString cfg.showPAMFailure "failure_show_msg=yes"} dovecot2 - } - '' - ) + passdb { + driver = pam + args = ${optionalString cfg.showPAMFailure "failure_show_msg=yes"} dovecot2 + } + '') - ( - optionalString (cfg.mailboxes != {}) '' - namespace inbox { - inbox=yes - ${concatStringsSep "\n" (map mailboxConfig (attrValues cfg.mailboxes))} - } - '' - ) + (optionalString (cfg.mailboxes != { }) '' + namespace inbox { + inbox=yes + ${concatStringsSep "\n" (map mailboxConfig (attrValues cfg.mailboxes))} + } + '') - ( - optionalString cfg.enableQuota '' - service quota-status { - executable = ${dovecotPkg}/libexec/dovecot/quota-status -p postfix - inet_listener { - port = ${cfg.quotaPort} - } - client_limit = 1 + (optionalString cfg.enableQuota '' + service quota-status { + executable = ${dovecotPkg}/libexec/dovecot/quota-status -p postfix + inet_listener { + port = ${cfg.quotaPort} } + client_limit = 1 + } - plugin { - quota_rule = *:storage=${cfg.quotaGlobalPerUser} - quota = count:User quota # per virtual mail user quota - quota_status_success = DUNNO - quota_status_nouser = DUNNO - quota_status_overquota = "552 5.2.2 Mailbox is full" - quota_grace = 10%% - quota_vsizes = yes - } - '' - ) + plugin { + quota_rule = *:storage=${cfg.quotaGlobalPerUser} + quota = count:User quota # per virtual mail user quota + quota_status_success = DUNNO + quota_status_nouser = DUNNO + quota_status_overquota = "552 5.2.2 Mailbox is full" + quota_grace = 10%% + quota_vsizes = yes + } + '') # General plugin settings: # - sieve is mostly generated here, refer to `pluginSettings` to follow @@ -176,55 +209,81 @@ let modulesDir = pkgs.symlinkJoin { name = "dovecot-modules"; - paths = map (pkg: "${pkg}/lib/dovecot") ([ dovecotPkg ] ++ map (module: module.override { dovecot = dovecotPkg; }) cfg.modules); + paths = map (pkg: "${pkg}/lib/dovecot") ( + [ dovecotPkg ] ++ map (module: module.override { dovecot = dovecotPkg; }) cfg.modules + ); }; - mailboxConfig = mailbox: '' - mailbox "${mailbox.name}" { - auto = ${toString mailbox.auto} - '' + optionalString (mailbox.autoexpunge != null) '' - autoexpunge = ${mailbox.autoexpunge} - '' + optionalString (mailbox.specialUse != null) '' - special_use = \${toString mailbox.specialUse} - '' + "}"; - - mailboxes = { name, ... }: { - options = { - name = mkOption { - type = types.strMatching ''[^"]+''; - example = "Spam"; - default = name; - readOnly = true; - description = "The name of the mailbox."; - }; - auto = mkOption { - type = types.enum [ "no" "create" "subscribe" ]; - default = "no"; - example = "subscribe"; - description = "Whether to automatically create or create and subscribe to the mailbox or not."; - }; - specialUse = mkOption { - type = types.nullOr (types.enum [ "All" "Archive" "Drafts" "Flagged" "Junk" "Sent" "Trash" ]); - default = null; - example = "Junk"; - description = "Null if no special use flag is set. Other than that every use flag mentioned in the RFC is valid."; - }; - autoexpunge = mkOption { - type = types.nullOr types.str; - default = null; - example = "60d"; - description = '' - To automatically remove all email from the mailbox which is older than the - specified time. - ''; + mailboxConfig = + mailbox: + '' + mailbox "${mailbox.name}" { + auto = ${toString mailbox.auto} + '' + + optionalString (mailbox.autoexpunge != null) '' + autoexpunge = ${mailbox.autoexpunge} + '' + + optionalString (mailbox.specialUse != null) '' + special_use = \${toString mailbox.specialUse} + '' + + "}"; + + mailboxes = + { name, ... }: + { + options = { + name = mkOption { + type = types.strMatching ''[^"]+''; + example = "Spam"; + default = name; + readOnly = true; + description = "The name of the mailbox."; + }; + auto = mkOption { + type = types.enum [ + "no" + "create" + "subscribe" + ]; + default = "no"; + example = "subscribe"; + description = "Whether to automatically create or create and subscribe to the mailbox or not."; + }; + specialUse = mkOption { + type = types.nullOr ( + types.enum [ + "All" + "Archive" + "Drafts" + "Flagged" + "Junk" + "Sent" + "Trash" + ] + ); + default = null; + example = "Junk"; + description = "Null if no special use flag is set. Other than that every use flag mentioned in the RFC is valid."; + }; + autoexpunge = mkOption { + type = types.nullOr types.str; + default = null; + example = "60d"; + description = '' + To automatically remove all email from the mailbox which is older than the + specified time. + ''; + }; }; }; - }; in { imports = [ (mkRemovedOptionModule [ "services" "dovecot2" "package" ] "") - (mkRenamedOptionModule [ "services" "dovecot2" "sieveScripts" ] [ "services" "dovecot2" "sieve" "scripts" ]) + (mkRenamedOptionModule + [ "services" "dovecot2" "sieveScripts" ] + [ "services" "dovecot2" "sieve" "scripts" ] + ) ]; options.services.dovecot2 = { @@ -232,13 +291,15 @@ in enablePop3 = mkEnableOption "starting the POP3 listener (when Dovecot is enabled)"; - enableImap = mkEnableOption "starting the IMAP listener (when Dovecot is enabled)" // { default = true; }; + enableImap = mkEnableOption "starting the IMAP listener (when Dovecot is enabled)" // { + default = true; + }; enableLmtp = mkEnableOption "starting the LMTP listener (when Dovecot is enabled)"; protocols = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = "Additional listeners to start when Dovecot is enabled."; }; @@ -263,40 +324,53 @@ in mailPlugins = let - plugins = hint: types.submodule { - options = { - enable = mkOption { - type = types.listOf types.str; - default = []; - description = "mail plugins to enable as a list of strings to append to the ${hint} `$mail_plugins` configuration variable"; + plugins = + hint: + types.submodule { + options = { + enable = mkOption { + type = types.listOf types.str; + default = [ ]; + description = "mail plugins to enable as a list of strings to append to the ${hint} `$mail_plugins` configuration variable"; + }; }; }; - }; in - mkOption { - type = with types; submodule { + mkOption { + type = + with types; + submodule { options = { globally = mkOption { description = "Additional entries to add to the mail_plugins variable for all protocols"; type = plugins "top-level"; - example = { enable = [ "virtual" ]; }; - default = { enable = []; }; + example = { + enable = [ "virtual" ]; + }; + default = { + enable = [ ]; + }; }; perProtocol = mkOption { description = "Additional entries to add to the mail_plugins variable, per protocol"; type = attrsOf (plugins "corresponding per-protocol"); - default = {}; - example = { imap = [ "imap_acl" ]; }; + default = { }; + example = { + imap = [ "imap_acl" ]; + }; }; }; }; - description = "Additional entries to add to the mail_plugins variable, globally and per protocol"; - example = { - globally.enable = [ "acl" ]; - perProtocol.imap.enable = [ "imap_acl" ]; - }; - default = { globally.enable = []; perProtocol = {}; }; + description = "Additional entries to add to the mail_plugins variable, globally and per protocol"; + example = { + globally.enable = [ "acl" ]; + perProtocol.imap.enable = [ "imap_acl" ]; }; + default = { + globally.enable = [ ]; + perProtocol = { }; + }; + }; configFile = mkOption { type = types.nullOr types.path; @@ -307,7 +381,7 @@ in mailLocation = mkOption { type = types.str; - default = "maildir:/var/spool/mail/%u"; /* Same as inbox, as postfix */ + default = "maildir:/var/spool/mail/%u"; # Same as inbox, as postfix example = "maildir:~/mail:INBOX=/var/spool/mail/%u"; description = '' Location that dovecot will use for mail folders. Dovecot mail_location option. @@ -326,13 +400,18 @@ in description = "Default group to store mail for virtual users."; }; - createMailUser = mkEnableOption ''automatically creating the user - given in {option}`services.dovecot.user` and the group - given in {option}`services.dovecot.group`'' // { default = true; }; + createMailUser = + mkEnableOption '' + automatically creating the user + given in {option}`services.dovecot.user` and the group + given in {option}`services.dovecot.group`'' + // { + default = true; + }; modules = mkOption { type = types.listOf types.package; - default = []; + default = [ ]; example = literalExpression "[ pkgs.dovecot_pigeonhole ]"; description = '' Symlinks the contents of lib/dovecot of every given package into @@ -359,18 +438,29 @@ in description = "Path to the server's private key."; }; - enablePAM = mkEnableOption "creating a own Dovecot PAM service and configure PAM user logins" // { default = true; }; + enablePAM = mkEnableOption "creating a own Dovecot PAM service and configure PAM user logins" // { + default = true; + }; - enableDHE = mkEnableOption "ssl_dh and generation of primes for the key exchange" // { default = true; }; + enableDHE = mkEnableOption "ssl_dh and generation of primes for the key exchange" // { + default = true; + }; showPAMFailure = mkEnableOption "showing the PAM failure message on authentication error (useful for OTPW)"; mailboxes = mkOption { - type = with types; coercedTo - (listOf unspecified) - (list: listToAttrs (map (entry: { name = entry.name; value = removeAttrs entry ["name"]; }) list)) - (attrsOf (submodule mailboxes)); - default = {}; + type = + with types; + coercedTo (listOf unspecified) ( + list: + listToAttrs ( + map (entry: { + name = entry.name; + value = removeAttrs entry [ "name" ]; + }) list + ) + ) (attrsOf (submodule mailboxes)); + default = { }; example = literalExpression '' { Spam = { specialUse = "Junk"; auto = "create"; }; @@ -396,11 +486,15 @@ in description = "Quota limit for the user in bytes. Supports suffixes b, k, M, G, T and %."; }; - pluginSettings = mkOption { # types.str does not coerce from packages, like `sievePipeBinScriptDirectory`. - type = types.attrsOf (types.oneOf [ types.str types.package ]); - default = {}; + type = types.attrsOf ( + types.oneOf [ + types.str + types.package + ] + ); + default = { }; example = literalExpression '' { sieve = "file:~/sieve;active=~/.dovecot.sieve"; @@ -417,86 +511,104 @@ in }; imapsieve.mailbox = mkOption { - default = []; + default = [ ]; description = "Configure Sieve filtering rules on IMAP actions"; - type = types.listOf (types.submodule ({ config, ... }: { - options = { - name = mkOption { - description = '' - This setting configures the name of a mailbox for which administrator scripts are configured. - - The settings defined hereafter with matching sequence numbers apply to the mailbox named by this setting. - - This setting supports wildcards with a syntax compatible with the IMAP LIST command, meaning that this setting can apply to multiple or even all ("*") mailboxes. - ''; - example = "Junk"; - type = types.str; - }; + type = types.listOf ( + types.submodule ( + { config, ... }: + { + options = { + name = mkOption { + description = '' + This setting configures the name of a mailbox for which administrator scripts are configured. - from = mkOption { - default = null; - description = '' - Only execute the administrator Sieve scripts for the mailbox configured with services.dovecot2.imapsieve.mailbox..name when the message originates from the indicated mailbox. + The settings defined hereafter with matching sequence numbers apply to the mailbox named by this setting. - This setting supports wildcards with a syntax compatible with the IMAP LIST command, meaning that this setting can apply to multiple or even all ("*") mailboxes. - ''; - example = "*"; - type = types.nullOr types.str; - }; + This setting supports wildcards with a syntax compatible with the IMAP LIST command, meaning that this setting can apply to multiple or even all ("*") mailboxes. + ''; + example = "Junk"; + type = types.str; + }; - causes = mkOption { - default = [ ]; - description = '' - Only execute the administrator Sieve scripts for the mailbox configured with services.dovecot2.imapsieve.mailbox..name when one of the listed IMAPSIEVE causes apply. + from = mkOption { + default = null; + description = '' + Only execute the administrator Sieve scripts for the mailbox configured with services.dovecot2.imapsieve.mailbox..name when the message originates from the indicated mailbox. - This has no effect on the user script, which is always executed no matter the cause. - ''; - example = [ "COPY" "APPEND" ]; - type = types.listOf (types.enum [ "APPEND" "COPY" "FLAG" ]); - }; + This setting supports wildcards with a syntax compatible with the IMAP LIST command, meaning that this setting can apply to multiple or even all ("*") mailboxes. + ''; + example = "*"; + type = types.nullOr types.str; + }; - before = mkOption { - default = null; - description = '' - When an IMAP event of interest occurs, this sieve script is executed before any user script respectively. + causes = mkOption { + default = [ ]; + description = '' + Only execute the administrator Sieve scripts for the mailbox configured with services.dovecot2.imapsieve.mailbox..name when one of the listed IMAPSIEVE causes apply. + + This has no effect on the user script, which is always executed no matter the cause. + ''; + example = [ + "COPY" + "APPEND" + ]; + type = types.listOf ( + types.enum [ + "APPEND" + "COPY" + "FLAG" + ] + ); + }; - This setting each specify the location of a single sieve script. The semantics of this setting is similar to sieve_before: the specified scripts form a sequence together with the user script in which the next script is only executed when an (implicit) keep action is executed. - ''; - example = literalExpression "./report-spam.sieve"; - type = types.nullOr types.path; - }; + before = mkOption { + default = null; + description = '' + When an IMAP event of interest occurs, this sieve script is executed before any user script respectively. - after = mkOption { - default = null; - description = '' - When an IMAP event of interest occurs, this sieve script is executed after any user script respectively. + This setting each specify the location of a single sieve script. The semantics of this setting is similar to sieve_before: the specified scripts form a sequence together with the user script in which the next script is only executed when an (implicit) keep action is executed. + ''; + example = literalExpression "./report-spam.sieve"; + type = types.nullOr types.path; + }; - This setting each specify the location of a single sieve script. The semantics of this setting is similar to sieve_after: the specified scripts form a sequence together with the user script in which the next script is only executed when an (implicit) keep action is executed. - ''; - example = literalExpression "./report-spam.sieve"; - type = types.nullOr types.path; - }; - }; - })); + after = mkOption { + default = null; + description = '' + When an IMAP event of interest occurs, this sieve script is executed after any user script respectively. + + This setting each specify the location of a single sieve script. The semantics of this setting is similar to sieve_after: the specified scripts form a sequence together with the user script in which the next script is only executed when an (implicit) keep action is executed. + ''; + example = literalExpression "./report-spam.sieve"; + type = types.nullOr types.path; + }; + }; + } + ) + ); }; sieve = { plugins = mkOption { - default = []; + default = [ ]; example = [ "sieve_extprograms" ]; description = "Sieve plugins to load"; type = types.listOf types.str; }; extensions = mkOption { - default = []; + default = [ ]; description = "Sieve extensions for use in user scripts"; - example = [ "notify" "imapflags" "vnd.dovecot.filter" ]; + example = [ + "notify" + "imapflags" + "vnd.dovecot.filter" + ]; type = types.listOf types.str; }; globalExtensions = mkOption { - default = []; + default = [ ]; example = [ "vnd.dovecot.environment" ]; description = "Sieve extensions for use in global scripts"; type = types.listOf types.str; @@ -504,12 +616,12 @@ in scripts = mkOption { type = types.attrsOf types.path; - default = {}; + default = { }; description = "Sieve scripts to be executed. Key is a sequence, e.g. 'before2', 'after' etc."; }; pipeBins = mkOption { - default = []; + default = [ ]; example = literalExpression '' map lib.getExe [ (pkgs.writeShellScriptBin "learn-ham.sh" "exec ''${pkgs.rspamd}/bin/rspamc learn_ham") @@ -523,18 +635,16 @@ in }; config = mkIf cfg.enable { - security.pam.services.dovecot2 = mkIf cfg.enablePAM {}; + security.pam.services.dovecot2 = mkIf cfg.enablePAM { }; security.dhparams = mkIf (cfg.sslServerCert != null && cfg.enableDHE) { enable = true; - params.dovecot2 = {}; + params.dovecot2 = { }; }; services.dovecot2 = { protocols = - optional cfg.enableImap "imap" - ++ optional cfg.enablePop3 "pop3" - ++ optional cfg.enableLmtp "lmtp"; + optional cfg.enableImap "imap" ++ optional cfg.enablePop3 "pop3" ++ optional cfg.enableLmtp "lmtp"; mailPlugins = mkIf cfg.enableQuota { globally.enable = [ "quota" ]; @@ -542,46 +652,55 @@ in }; sieve.plugins = - optional (cfg.imapsieve.mailbox != []) "sieve_imapsieve" - ++ optional (cfg.sieve.pipeBins != []) "sieve_extprograms"; + optional (cfg.imapsieve.mailbox != [ ]) "sieve_imapsieve" + ++ optional (cfg.sieve.pipeBins != [ ]) "sieve_extprograms"; - sieve.globalExtensions = optional (cfg.sieve.pipeBins != []) "vnd.dovecot.pipe"; + sieve.globalExtensions = optional (cfg.sieve.pipeBins != [ ]) "vnd.dovecot.pipe"; - pluginSettings = lib.mapAttrs (n: lib.mkDefault) ({ - sieve_plugins = concatStringsSep " " cfg.sieve.plugins; - sieve_extensions = concatStringsSep " " (map (el: "+${el}") cfg.sieve.extensions); - sieve_global_extensions = concatStringsSep " " (map (el: "+${el}") cfg.sieve.globalExtensions); - sieve_pipe_bin_dir = sievePipeBinScriptDirectory; - } // sieveScriptSettings // imapSieveMailboxSettings); + pluginSettings = lib.mapAttrs (n: lib.mkDefault) ( + { + sieve_plugins = concatStringsSep " " cfg.sieve.plugins; + sieve_extensions = concatStringsSep " " (map (el: "+${el}") cfg.sieve.extensions); + sieve_global_extensions = concatStringsSep " " (map (el: "+${el}") cfg.sieve.globalExtensions); + sieve_pipe_bin_dir = sievePipeBinScriptDirectory; + } + // sieveScriptSettings + // imapSieveMailboxSettings + ); }; - users.users = { - dovenull = - { + users.users = + { + dovenull = { uid = config.ids.uids.dovenull2; description = "Dovecot user for untrusted logins"; group = "dovenull"; }; - } // optionalAttrs (cfg.user == "dovecot2") { - dovecot2 = - { + } + // optionalAttrs (cfg.user == "dovecot2") { + dovecot2 = { uid = config.ids.uids.dovecot2; description = "Dovecot user"; group = cfg.group; }; - } // optionalAttrs (cfg.createMailUser && cfg.mailUser != null) { - ${cfg.mailUser} = - { description = "Virtual Mail User"; isSystemUser = true; } // optionalAttrs (cfg.mailGroup != null) - { group = cfg.mailGroup; }; - }; + } + // optionalAttrs (cfg.createMailUser && cfg.mailUser != null) { + ${cfg.mailUser} = { + description = "Virtual Mail User"; + isSystemUser = true; + } // optionalAttrs (cfg.mailGroup != null) { group = cfg.mailGroup; }; + }; - users.groups = { - dovenull.gid = config.ids.gids.dovenull2; - } // optionalAttrs (cfg.group == "dovecot2") { - dovecot2.gid = config.ids.gids.dovecot2; - } // optionalAttrs (cfg.createMailUser && cfg.mailGroup != null) { - ${cfg.mailGroup} = {}; - }; + users.groups = + { + dovenull.gid = config.ids.gids.dovenull2; + } + // optionalAttrs (cfg.group == "dovecot2") { + dovecot2.gid = config.ids.gids.dovecot2; + } + // optionalAttrs (cfg.createMailUser && cfg.mailGroup != null) { + ${cfg.mailGroup} = { }; + }; environment.etc."dovecot/modules".source = modulesDir; environment.etc."dovecot/dovecot.conf".source = cfg.configFile; @@ -591,9 +710,12 @@ in after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; - restartTriggers = [ cfg.configFile modulesDir ]; + restartTriggers = [ + cfg.configFile + modulesDir + ]; - startLimitIntervalSec = 60; # 1 min + startLimitIntervalSec = 60; # 1 min serviceConfig = { Type = "notify"; ExecStart = "${dovecotPkg}/sbin/dovecot -F"; @@ -606,48 +728,44 @@ in # When copying sieve scripts preserve the original time stamp # (should be 0) so that the compiled sieve script is newer than # the source file and Dovecot won't try to compile it. - preStart = '' - rm -rf ${stateDir}/sieve ${stateDir}/imapsieve - '' + optionalString (cfg.sieve.scripts != {}) '' - mkdir -p ${stateDir}/sieve - ${concatStringsSep "\n" ( - mapAttrsToList ( - to: from: '' - if [ -d '${from}' ]; then - mkdir '${stateDir}/sieve/${to}' - cp -p "${from}/"*.sieve '${stateDir}/sieve/${to}' - else - cp -p '${from}' '${stateDir}/sieve/${to}' - fi - ${pkgs.dovecot_pigeonhole}/bin/sievec '${stateDir}/sieve/${to}' - '' - ) cfg.sieve.scripts - )} - chown -R '${cfg.mailUser}:${cfg.mailGroup}' '${stateDir}/sieve' - '' - + optionalString (cfg.imapsieve.mailbox != []) '' - mkdir -p ${stateDir}/imapsieve/{before,after} - - ${ - concatMapStringsSep "\n" - (el: - optionalString (el.before != null) '' - cp -p ${el.before} ${stateDir}/imapsieve/before/${baseNameOf el.before} - ${pkgs.dovecot_pigeonhole}/bin/sievec '${stateDir}/imapsieve/before/${baseNameOf el.before}' - '' - + optionalString (el.after != null) '' - cp -p ${el.after} ${stateDir}/imapsieve/after/${baseNameOf el.after} - ${pkgs.dovecot_pigeonhole}/bin/sievec '${stateDir}/imapsieve/after/${baseNameOf el.after}' - '' - ) - cfg.imapsieve.mailbox - } - - ${ - optionalString (cfg.mailUser != null && cfg.mailGroup != null) - "chown -R '${cfg.mailUser}:${cfg.mailGroup}' '${stateDir}/imapsieve'" - } - ''; + preStart = + '' + rm -rf ${stateDir}/sieve ${stateDir}/imapsieve + '' + + optionalString (cfg.sieve.scripts != { }) '' + mkdir -p ${stateDir}/sieve + ${concatStringsSep "\n" ( + mapAttrsToList (to: from: '' + if [ -d '${from}' ]; then + mkdir '${stateDir}/sieve/${to}' + cp -p "${from}/"*.sieve '${stateDir}/sieve/${to}' + else + cp -p '${from}' '${stateDir}/sieve/${to}' + fi + ${pkgs.dovecot_pigeonhole}/bin/sievec '${stateDir}/sieve/${to}' + '') cfg.sieve.scripts + )} + chown -R '${cfg.mailUser}:${cfg.mailGroup}' '${stateDir}/sieve' + '' + + optionalString (cfg.imapsieve.mailbox != [ ]) '' + mkdir -p ${stateDir}/imapsieve/{before,after} + + ${concatMapStringsSep "\n" ( + el: + optionalString (el.before != null) '' + cp -p ${el.before} ${stateDir}/imapsieve/before/${baseNameOf el.before} + ${pkgs.dovecot_pigeonhole}/bin/sievec '${stateDir}/imapsieve/before/${baseNameOf el.before}' + '' + + optionalString (el.after != null) '' + cp -p ${el.after} ${stateDir}/imapsieve/after/${baseNameOf el.after} + ${pkgs.dovecot_pigeonhole}/bin/sievec '${stateDir}/imapsieve/after/${baseNameOf el.after}' + '' + ) cfg.imapsieve.mailbox} + + ${optionalString ( + cfg.mailUser != null && cfg.mailGroup != null + ) "chown -R '${cfg.mailUser}:${cfg.mailGroup}' '${stateDir}/imapsieve'"} + ''; }; environment.systemPackages = [ dovecotPkg ]; @@ -656,8 +774,9 @@ in assertions = [ { - assertion = (cfg.sslServerCert == null) == (cfg.sslServerKey == null) - && (cfg.sslCACert != null -> !(cfg.sslServerCert == null || cfg.sslServerKey == null)); + assertion = + (cfg.sslServerCert == null) == (cfg.sslServerKey == null) + && (cfg.sslCACert != null -> !(cfg.sslServerCert == null || cfg.sslServerKey == null)); message = "dovecot needs both sslServerCert and sslServerKey defined for working crypto"; } { @@ -665,7 +784,7 @@ in message = "dovecot is configured with showPAMFailure while enablePAM is disabled"; } { - assertion = cfg.sieve.scripts != {} -> (cfg.mailUser != null && cfg.mailGroup != null); + assertion = cfg.sieve.scripts != { } -> (cfg.mailUser != null && cfg.mailGroup != null); message = "dovecot requires mailUser and mailGroup to be set when `sieve.scripts` is set"; } ]; diff --git a/nixos/modules/services/mail/dspam.nix b/nixos/modules/services/mail/dspam.nix index 76bcc0af7e8b3a..7baae1f78e479c 100644 --- a/nixos/modules/services/mail/dspam.nix +++ b/nixos/modules/services/mail/dspam.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.dspam; @@ -24,7 +29,8 @@ let ${cfg.extraConfig} ''; -in { +in +{ ###### interface @@ -78,70 +84,71 @@ in { }; - ###### implementation - config = lib.mkIf cfg.enable (lib.mkMerge [ - { - users.users = lib.optionalAttrs (cfg.user == "dspam") { - dspam = { - group = cfg.group; - uid = config.ids.uids.dspam; + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + { + users.users = lib.optionalAttrs (cfg.user == "dspam") { + dspam = { + group = cfg.group; + uid = config.ids.uids.dspam; + }; }; - }; - users.groups = lib.optionalAttrs (cfg.group == "dspam") { - dspam.gid = config.ids.gids.dspam; - }; + users.groups = lib.optionalAttrs (cfg.group == "dspam") { + dspam.gid = config.ids.gids.dspam; + }; - environment.systemPackages = [ dspam ]; - - environment.etc."dspam/dspam.conf".source = cfgfile; - - systemd.services.dspam = { - description = "dspam spam filtering daemon"; - wantedBy = [ "multi-user.target" ]; - after = [ "postgresql.service" ]; - restartTriggers = [ cfgfile ]; - - serviceConfig = { - ExecStart = "${dspam}/bin/dspam --daemon --nofork"; - User = cfg.user; - Group = cfg.group; - RuntimeDirectory = lib.optional (cfg.domainSocket == defaultSock) "dspam"; - RuntimeDirectoryMode = lib.optional (cfg.domainSocket == defaultSock) "0750"; - StateDirectory = "dspam"; - StateDirectoryMode = "0750"; - LogsDirectory = "dspam"; - LogsDirectoryMode = "0750"; - # DSPAM segfaults on just about every error - Restart = "on-abort"; - RestartSec = "1s"; + environment.systemPackages = [ dspam ]; + + environment.etc."dspam/dspam.conf".source = cfgfile; + + systemd.services.dspam = { + description = "dspam spam filtering daemon"; + wantedBy = [ "multi-user.target" ]; + after = [ "postgresql.service" ]; + restartTriggers = [ cfgfile ]; + + serviceConfig = { + ExecStart = "${dspam}/bin/dspam --daemon --nofork"; + User = cfg.user; + Group = cfg.group; + RuntimeDirectory = lib.optional (cfg.domainSocket == defaultSock) "dspam"; + RuntimeDirectoryMode = lib.optional (cfg.domainSocket == defaultSock) "0750"; + StateDirectory = "dspam"; + StateDirectoryMode = "0750"; + LogsDirectory = "dspam"; + LogsDirectoryMode = "0750"; + # DSPAM segfaults on just about every error + Restart = "on-abort"; + RestartSec = "1s"; + }; }; - }; - } - - (lib.mkIf (cfg.maintenanceInterval != null) { - systemd.timers.dspam-maintenance = { - description = "Timer for dspam maintenance script"; - wantedBy = [ "timers.target" ]; - timerConfig = { - OnCalendar = cfg.maintenanceInterval; - Unit = "dspam-maintenance.service"; + } + + (lib.mkIf (cfg.maintenanceInterval != null) { + systemd.timers.dspam-maintenance = { + description = "Timer for dspam maintenance script"; + wantedBy = [ "timers.target" ]; + timerConfig = { + OnCalendar = cfg.maintenanceInterval; + Unit = "dspam-maintenance.service"; + }; }; - }; - systemd.services.dspam-maintenance = { - description = "dspam maintenance script"; - restartTriggers = [ cfgfile ]; + systemd.services.dspam-maintenance = { + description = "dspam maintenance script"; + restartTriggers = [ cfgfile ]; - serviceConfig = { - ExecStart = "${dspam}/bin/dspam_maintenance --verbose"; - Type = "oneshot"; - User = cfg.user; - Group = cfg.group; + serviceConfig = { + ExecStart = "${dspam}/bin/dspam_maintenance --verbose"; + Type = "oneshot"; + User = cfg.user; + Group = cfg.group; + }; }; - }; - }) - ]); + }) + ] + ); } diff --git a/nixos/modules/services/mail/exim.nix b/nixos/modules/services/mail/exim.nix index 0a5ba9d76d1572..77f8bd4b0dca3b 100644 --- a/nixos/modules/services/mail/exim.nix +++ b/nixos/modules/services/mail/exim.nix @@ -1,7 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) literalExpression mkIf mkOption singleton types mkPackageOption; + inherit (lib) + literalExpression + mkIf + mkOption + singleton + types + mkPackageOption + ; inherit (pkgs) coreutils; cfg = config.services.exim; in @@ -74,7 +86,6 @@ in }; - ###### implementation config = mkIf cfg.enable { @@ -100,21 +111,21 @@ in gid = config.ids.gids.exim; }; - security.wrappers.exim = - { setuid = true; - owner = "root"; - group = "root"; - source = "${cfg.package}/bin/exim"; - }; + security.wrappers.exim = { + setuid = true; + owner = "root"; + group = "root"; + source = "${cfg.package}/bin/exim"; + }; systemd.services.exim = { description = "Exim Mail Daemon"; wantedBy = [ "multi-user.target" ]; restartTriggers = [ config.environment.etc."exim.conf".source ]; serviceConfig = { - ExecStart = "!${cfg.package}/bin/exim -bdf -q${cfg.queueRunnerInterval}"; - ExecReload = "!${coreutils}/bin/kill -HUP $MAINPID"; - User = cfg.user; + ExecStart = "!${cfg.package}/bin/exim -bdf -q${cfg.queueRunnerInterval}"; + ExecReload = "!${coreutils}/bin/kill -HUP $MAINPID"; + User = cfg.user; }; preStart = '' if ! test -d ${cfg.spoolDir}; then diff --git a/nixos/modules/services/mail/goeland.nix b/nixos/modules/services/mail/goeland.nix index 42f64b3632b5e6..b6f5e8ae2fc495 100644 --- a/nixos/modules/services/mail/goeland.nix +++ b/nixos/modules/services/mail/goeland.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.goeland; tomlFormat = pkgs.formats.toml { }; @@ -37,17 +42,21 @@ in services.goeland.settings.database = "${cfg.stateDir}/goeland.db"; systemd.services.goeland = { - serviceConfig = let confFile = tomlFormat.generate "config.toml" cfg.settings; in lib.mkMerge [ - { - ExecStart = "${pkgs.goeland}/bin/goeland run -c ${confFile}"; - User = "goeland"; - Group = "goeland"; - } - (lib.mkIf (cfg.stateDir == "/var/lib/goeland") { - StateDirectory = "goeland"; - StateDirectoryMode = "0750"; - }) - ]; + serviceConfig = + let + confFile = tomlFormat.generate "config.toml" cfg.settings; + in + lib.mkMerge [ + { + ExecStart = "${pkgs.goeland}/bin/goeland run -c ${confFile}"; + User = "goeland"; + Group = "goeland"; + } + (lib.mkIf (cfg.stateDir == "/var/lib/goeland") { + StateDirectory = "goeland"; + StateDirectoryMode = "0750"; + }) + ]; startAt = cfg.schedule; }; diff --git a/nixos/modules/services/mail/listmonk.nix b/nixos/modules/services/mail/listmonk.nix index 82c94ad4bb8f35..1000bce88d61a8 100644 --- a/nixos/modules/services/mail/listmonk.nix +++ b/nixos/modules/services/mail/listmonk.nix @@ -1,33 +1,48 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.listmonk; tomlFormat = pkgs.formats.toml { }; cfgFile = tomlFormat.generate "listmonk.toml" cfg.settings; # Escaping is done according to https://www.postgresql.org/docs/current/sql-syntax-lexical.html#SQL-SYNTAX-CONSTANTS - setDatabaseOption = key: value: + setDatabaseOption = + key: value: "UPDATE settings SET value = '${ lib.replaceStrings [ "'" ] [ "''" ] (builtins.toJSON value) }' WHERE key = '${key}';"; - updateDatabaseConfigSQL = pkgs.writeText "update-database-config.sql" - (lib.concatStringsSep "\n" (lib.mapAttrsToList setDatabaseOption - (if (cfg.database.settings != null) then - cfg.database.settings + updateDatabaseConfigSQL = pkgs.writeText "update-database-config.sql" ( + lib.concatStringsSep "\n" ( + lib.mapAttrsToList setDatabaseOption ( + if (cfg.database.settings != null) then cfg.database.settings else { } + ) + ) + ); + updateDatabaseConfigScript = pkgs.writeShellScriptBin "update-database-config.sh" '' + ${ + if cfg.database.mutableSettings then + '' + if [ ! -f /var/lib/listmonk/.db_settings_initialized ]; then + ${pkgs.postgresql}/bin/psql -d listmonk -f ${updateDatabaseConfigSQL} ; + touch /var/lib/listmonk/.db_settings_initialized + fi + '' else - { }))); - updateDatabaseConfigScript = - pkgs.writeShellScriptBin "update-database-config.sh" '' - ${if cfg.database.mutableSettings then '' - if [ ! -f /var/lib/listmonk/.db_settings_initialized ]; then - ${pkgs.postgresql}/bin/psql -d listmonk -f ${updateDatabaseConfigSQL} ; - touch /var/lib/listmonk/.db_settings_initialized - fi - '' else - "${pkgs.postgresql}/bin/psql -d listmonk -f ${updateDatabaseConfigSQL}"} - ''; + "${pkgs.postgresql}/bin/psql -d listmonk -f ${updateDatabaseConfigSQL}" + } + ''; databaseSettingsOpts = with lib.types; { - freeformType = - oneOf [ (listOf str) (listOf (attrsOf anything)) str int bool ]; + freeformType = oneOf [ + (listOf str) + (listOf (attrsOf anything)) + str + int + bool + ]; options = { "app.notify_emails" = lib.mkOption { @@ -38,16 +53,19 @@ let "privacy.exportable" = lib.mkOption { type = listOf str; - default = [ "profile" "subscriptions" "campaign_views" "link_clicks" ]; - description = - "List of fields which can be exported through an automatic export request"; + default = [ + "profile" + "subscriptions" + "campaign_views" + "link_clicks" + ]; + description = "List of fields which can be exported through an automatic export request"; }; "privacy.domain_blocklist" = lib.mkOption { type = listOf str; default = [ ]; - description = - "E-mail addresses with these domains are disallowed from subscribing."; + description = "E-mail addresses with these domains are disallowed from subscribing."; }; smtp = lib.mkOption { @@ -66,12 +84,15 @@ let }; max_conns = lib.mkOption { type = lib.types.int; - description = - "Maximum number of simultaneous connections, defaults to 1"; + description = "Maximum number of simultaneous connections, defaults to 1"; default = 1; }; tls_type = lib.mkOption { - type = lib.types.enum [ "none" "STARTTLS" "TLS" ]; + type = lib.types.enum [ + "none" + "STARTTLS" + "TLS" + ]; description = "Type of TLS authentication with the SMTP server"; }; }; @@ -82,8 +103,9 @@ let # TODO: refine this type based on the smtp one. "bounce.mailboxes" = lib.mkOption { - type = listOf - (submodule { freeformType = with lib.types; listOf (attrsOf anything); }); + type = listOf (submodule { + freeformType = with lib.types; listOf (attrsOf anything); + }); default = [ ]; description = "List of bounce mailboxes"; }; @@ -91,12 +113,12 @@ let messengers = lib.mkOption { type = listOf str; default = [ ]; - description = - "List of messengers, see: for options."; + description = "List of messengers, see: for options."; }; }; }; -in { +in +{ ###### interface options = { services.listmonk = { @@ -105,15 +127,13 @@ in { createLocally = lib.mkOption { type = lib.types.bool; default = false; - description = - "Create the PostgreSQL database and database user locally."; + description = "Create the PostgreSQL database and database user locally."; }; settings = lib.mkOption { default = null; type = with lib.types; nullOr (submodule databaseSettingsOpts); - description = - "Dynamic settings in the PostgreSQL database, set by a SQL script, see for details."; + description = "Dynamic settings in the PostgreSQL database, set by a SQL script, see for details."; }; mutableSettings = lib.mkOption { type = lib.types.bool; @@ -124,7 +144,7 @@ in { ''; }; }; - package = lib.mkPackageOption pkgs "listmonk" {}; + package = lib.mkPackageOption pkgs "listmonk" { }; settings = lib.mkOption { type = lib.types.submodule { freeformType = tomlFormat.type; }; description = '' @@ -135,8 +155,7 @@ in { secretFile = lib.mkOption { type = lib.types.nullOr lib.types.str; default = null; - description = - "A file containing secrets as environment variables. See for details on supported values."; + description = "A file containing secrets as environment variables. See for details on supported values."; }; }; }; @@ -162,18 +181,19 @@ in { services.postgresql = lib.mkIf cfg.database.createLocally { enable = true; - ensureUsers = [{ - name = "listmonk"; - ensureDBOwnership = true; - }]; + ensureUsers = [ + { + name = "listmonk"; + ensureDBOwnership = true; + } + ]; ensureDatabases = [ "listmonk" ]; }; systemd.services.listmonk = { description = "Listmonk - newsletter and mailing list manager"; - after = [ "network.target" ] - ++ lib.optional cfg.database.createLocally "postgresql.service"; + after = [ "network.target" ] ++ lib.optional cfg.database.createLocally "postgresql.service"; wantedBy = [ "multi-user.target" ]; serviceConfig = { Type = "exec"; @@ -202,7 +222,10 @@ in { NoNewPrivileges = true; CapabilityBoundingSet = ""; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; PrivateDevices = true; ProtectControlGroups = true; ProtectKernelTunables = true; @@ -212,7 +235,11 @@ in { UMask = "0027"; MemoryDenyWriteExecute = true; LockPersonality = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; ProtectKernelModules = true; PrivateUsers = true; }; diff --git a/nixos/modules/services/mail/maddy.nix b/nixos/modules/services/mail/maddy.nix index ab0e1f40f5b098..41d25eaf7885fd 100644 --- a/nixos/modules/services/mail/maddy.nix +++ b/nixos/modules/services/mail/maddy.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let name = "maddy"; @@ -131,7 +136,8 @@ let } ''; -in { +in +{ options = { services.maddy = { @@ -185,7 +191,7 @@ in { localDomains = lib.mkOption { type = with lib.types; listOf str; - default = ["$(primary_domain)"]; + default = [ "$(primary_domain)" ]; example = [ "$(primary_domain)" "example.com" @@ -213,7 +219,13 @@ in { tls = { loader = lib.mkOption { - type = with lib.types; nullOr (enum [ "off" "file" "acme" ]); + type = + with lib.types; + nullOr (enum [ + "off" + "file" + "acme" + ]); default = "off"; description = '' TLS certificates are obtained by modules called "certificate @@ -235,25 +247,27 @@ in { }; certificates = lib.mkOption { - type = with lib.types; listOf (submodule { - options = { - keyPath = lib.mkOption { - type = lib.types.path; - example = "/etc/ssl/mx1.example.org.key"; - description = '' - Path to the private key used for TLS. - ''; + type = + with lib.types; + listOf (submodule { + options = { + keyPath = lib.mkOption { + type = lib.types.path; + example = "/etc/ssl/mx1.example.org.key"; + description = '' + Path to the private key used for TLS. + ''; + }; + certPath = lib.mkOption { + type = lib.types.path; + example = "/etc/ssl/mx1.example.org.crt"; + description = '' + Path to the certificate used for TLS. + ''; + }; }; - certPath = lib.mkOption { - type = lib.types.path; - example = "/etc/ssl/mx1.example.org.crt"; - description = '' - Path to the certificate used for TLS. - ''; - }; - }; - }); - default = []; + }); + default = [ ]; example = lib.literalExpression '' [{ keyPath = "/etc/ssl/mx1.example.org.key"; @@ -291,7 +305,7 @@ in { ensureAccounts = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; description = '' List of IMAP accounts which get automatically created. Note that for a complete setup, user credentials for these accounts are required @@ -305,7 +319,7 @@ in { }; ensureCredentials = lib.mkOption { - default = {}; + default = { }; description = '' List of user accounts which get automatically created if they don't exist yet. Note that for a complete setup, corresponding mail boxes @@ -316,19 +330,21 @@ in { "user1@localhost".passwordFile = /secrets/user1-localhost; "user2@localhost".passwordFile = /secrets/user2-localhost; }; - type = lib.types.attrsOf (lib.types.submodule { - options = { - passwordFile = lib.mkOption { - type = lib.types.path; - example = "/path/to/file"; - default = null; - description = '' - Specifies the path to a file containing the - clear text password for the user. - ''; + type = lib.types.attrsOf ( + lib.types.submodule { + options = { + passwordFile = lib.mkOption { + type = lib.types.path; + example = "/path/to/file"; + default = null; + description = '' + Specifies the path to a file containing the + clear text password for the user. + ''; + }; }; - }; - }); + } + ); }; secrets = lib.mkOption { @@ -348,7 +364,7 @@ in { assertions = [ { - assertion = cfg.tls.loader == "file" -> cfg.tls.certificates != []; + assertion = cfg.tls.loader == "file" -> cfg.tls.certificates != [ ]; message = '' If Maddy is configured to use TLS, tls.certificates with attribute sets of certPath and keyPath must be provided. @@ -384,24 +400,26 @@ in { }; maddy-ensure-accounts = { script = '' - ${lib.optionalString (cfg.ensureAccounts != []) '' + ${lib.optionalString (cfg.ensureAccounts != [ ]) '' ${lib.concatMapStrings (account: '' if ! ${pkgs.maddy}/bin/maddyctl imap-acct list | grep "${account}"; then ${pkgs.maddy}/bin/maddyctl imap-acct create ${account} fi '') cfg.ensureAccounts} ''} - ${lib.optionalString (cfg.ensureCredentials != {}) '' - ${lib.concatStringsSep "\n" (lib.mapAttrsToList (name: cfg: '' - if ! ${pkgs.maddy}/bin/maddyctl creds list | grep "${name}"; then - ${pkgs.maddy}/bin/maddyctl creds create --password $(cat ${lib.escapeShellArg cfg.passwordFile}) ${name} - fi - '') cfg.ensureCredentials)} + ${lib.optionalString (cfg.ensureCredentials != { }) '' + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList (name: cfg: '' + if ! ${pkgs.maddy}/bin/maddyctl creds list | grep "${name}"; then + ${pkgs.maddy}/bin/maddyctl creds create --password $(cat ${lib.escapeShellArg cfg.passwordFile}) ${name} + fi + '') cfg.ensureCredentials + )} ''} ''; serviceConfig = { Type = "oneshot"; - User= "maddy"; + User = "maddy"; }; after = [ "maddy.service" ]; wantedBy = [ "multi-user.target" ]; @@ -418,21 +436,30 @@ in { $(local_domains) = ${toString cfg.localDomains} hostname ${cfg.hostname} - ${if (cfg.tls.loader == "file") then '' - tls file ${lib.concatStringsSep " " ( - map (x: x.certPath + " " + x.keyPath - ) cfg.tls.certificates)} ${lib.optionalString (cfg.tls.extraConfig != "") '' - { ${cfg.tls.extraConfig} } - ''} - '' else if (cfg.tls.loader == "acme") then '' - tls { - loader acme { - ${cfg.tls.extraConfig} - } - } - '' else if (cfg.tls.loader == "off") then '' - tls off - '' else ""} + ${ + if (cfg.tls.loader == "file") then + '' + tls file ${lib.concatStringsSep " " (map (x: x.certPath + " " + x.keyPath) cfg.tls.certificates)} ${ + lib.optionalString (cfg.tls.extraConfig != "") '' + { ${cfg.tls.extraConfig} } + '' + } + '' + else if (cfg.tls.loader == "acme") then + '' + tls { + loader acme { + ${cfg.tls.extraConfig} + } + } + '' + else if (cfg.tls.loader == "off") then + '' + tls off + '' + else + "" + } ${cfg.config} ''; @@ -451,7 +478,11 @@ in { }; networking.firewall = lib.mkIf cfg.openFirewall { - allowedTCPPorts = [ 25 143 587 ]; + allowedTCPPorts = [ + 25 + 143 + 587 + ]; }; environment.systemPackages = [ diff --git a/nixos/modules/services/mail/mail.nix b/nixos/modules/services/mail/mail.nix index afa5b242b29886..71773e7ff7dee0 100644 --- a/nixos/modules/services/mail/mail.nix +++ b/nixos/modules/services/mail/mail.nix @@ -1,4 +1,9 @@ -{ config, options, lib, ... }: +{ + config, + options, + lib, + ... +}: { ###### interface diff --git a/nixos/modules/services/mail/mailcatcher.nix b/nixos/modules/services/mail/mailcatcher.nix index 6728bbcd3b8e25..9232e0f1d7e286 100644 --- a/nixos/modules/services/mail/mailcatcher.nix +++ b/nixos/modules/services/mail/mailcatcher.nix @@ -1,9 +1,20 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.mailcatcher; - inherit (lib) mkEnableOption mkIf mkOption types optionalString; + inherit (lib) + mkEnableOption + mkIf + mkOption + types + optionalString + ; in { # interface @@ -60,8 +71,12 @@ in serviceConfig = { DynamicUser = true; Restart = "always"; - ExecStart = "${pkgs.mailcatcher}/bin/mailcatcher --foreground --no-quit --http-ip ${cfg.http.ip} --http-port ${toString cfg.http.port} --smtp-ip ${cfg.smtp.ip} --smtp-port ${toString cfg.smtp.port}" + optionalString (cfg.http.path != null) " --http-path ${cfg.http.path}"; - AmbientCapabilities = optionalString (cfg.http.port < 1024 || cfg.smtp.port < 1024) "cap_net_bind_service"; + ExecStart = + "${pkgs.mailcatcher}/bin/mailcatcher --foreground --no-quit --http-ip ${cfg.http.ip} --http-port ${toString cfg.http.port} --smtp-ip ${cfg.smtp.ip} --smtp-port ${toString cfg.smtp.port}" + + optionalString (cfg.http.path != null) " --http-path ${cfg.http.path}"; + AmbientCapabilities = optionalString ( + cfg.http.port < 1024 || cfg.smtp.port < 1024 + ) "cap_net_bind_service"; }; }; }; diff --git a/nixos/modules/services/mail/mlmmj.nix b/nixos/modules/services/mail/mlmmj.nix index ea0a7ad3144b5c..2d0bf1291e0d71 100644 --- a/nixos/modules/services/mail/mlmmj.nix +++ b/nixos/modules/services/mail/mlmmj.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let concatMapLines = f: l: lib.concatStringsSep "\n" (map f l); @@ -22,8 +27,11 @@ let "List-Unsubscribe: " ]; footer = domain: list: "To unsubscribe send a mail to ${list}+unsubscribe@${domain}"; - createList = d: l: - let ctlDir = listCtl d l; in + createList = + d: l: + let + ctlDir = listCtl d l; + in '' for DIR in incoming queue queue/discarded archive text subconf unsubconf \ bounce control moderation subscribers.d digesters.d requeue \ @@ -76,7 +84,7 @@ in mailLists = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = "The collection of hosted maillists"; }; @@ -112,7 +120,7 @@ in services.postfix = { enable = true; - recipientDelimiter= "+"; + recipientDelimiter = "+"; masterConfig.mlmmj = { type = "unix"; private = true; diff --git a/nixos/modules/services/mail/nullmailer.nix b/nixos/modules/services/mail/nullmailer.nix index eb982ad00bd75c..6dc278f89f2907 100644 --- a/nixos/modules/services/mail/nullmailer.nix +++ b/nixos/modules/services/mail/nullmailer.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { options = { @@ -70,10 +75,10 @@ type = lib.types.nullOr lib.types.str; default = null; description = '' - The content of this attribute is appended to any host name that - does not contain a period (except localhost), including defaulthost - and idhost. Defaults to the value of the me attribute, if it exists, - otherwise the literal name defauldomain. + The content of this attribute is appended to any host name that + does not contain a period (except localhost), including defaulthost + and idhost. Defaults to the value of the me attribute, if it exists, + otherwise the literal name defauldomain. ''; }; @@ -81,9 +86,9 @@ type = lib.types.nullOr lib.types.str; default = null; description = '' - The content of this attribute is appended to any address that - is missing a host name. Defaults to the value of the me control - attribute, if it exists, otherwise the literal name defaulthost. + The content of this attribute is appended to any address that + is missing a host name. Defaults to the value of the me control + attribute, if it exists, otherwise the literal name defaulthost. ''; }; @@ -117,11 +122,16 @@ }; maxpause = lib.mkOption { - type = with lib.types; nullOr (oneOf [ str int ]); + type = + with lib.types; + nullOr (oneOf [ + str + int + ]); default = null; description = '' - The maximum time to pause between successive queue runs, in seconds. - Defaults to 24 hours (86400). + The maximum time to pause between successive queue runs, in seconds. + Defaults to 24 hours (86400). ''; }; @@ -129,13 +139,18 @@ type = lib.types.nullOr lib.types.str; default = null; description = '' - The fully-qualifiled host name of the computer running nullmailer. - Defaults to the literal name me. + The fully-qualifiled host name of the computer running nullmailer. + Defaults to the literal name me. ''; }; pausetime = lib.mkOption { - type = with lib.types; nullOr (oneOf [ str int ]); + type = + with lib.types; + nullOr (oneOf [ + str + int + ]); default = null; description = '' The minimum time to pause between successive queue runs when there @@ -165,7 +180,12 @@ }; sendtimeout = lib.mkOption { - type = with lib.types; nullOr (oneOf [ str int ]); + type = + with lib.types; + nullOr (oneOf [ + str + int + ]); default = null; description = '' The time to wait for a remote module listed above to complete sending @@ -178,66 +198,72 @@ }; }; - config = let - cfg = config.services.nullmailer; - in lib.mkIf cfg.enable { - - assertions = [ - { assertion = cfg.config.remotes == null || cfg.remotesFile == null; - message = "Only one of `remotesFile` or `config.remotes` may be used at a time."; - } - ]; - - environment = { - systemPackages = [ pkgs.nullmailer ]; - etc = let - validAttrs = lib.mapAttrs (_: toString) (lib.filterAttrs (_: value: value != null) cfg.config); - in - (lib.foldl' (as: name: as // { "nullmailer/${name}".text = validAttrs.${name}; }) {} (lib.attrNames validAttrs)) + config = + let + cfg = config.services.nullmailer; + in + lib.mkIf cfg.enable { + + assertions = [ + { + assertion = cfg.config.remotes == null || cfg.remotesFile == null; + message = "Only one of `remotesFile` or `config.remotes` may be used at a time."; + } + ]; + + environment = { + systemPackages = [ pkgs.nullmailer ]; + etc = + let + validAttrs = lib.mapAttrs (_: toString) (lib.filterAttrs (_: value: value != null) cfg.config); + in + (lib.foldl' (as: name: as // { "nullmailer/${name}".text = validAttrs.${name}; }) { } ( + lib.attrNames validAttrs + )) // lib.optionalAttrs (cfg.remotesFile != null) { "nullmailer/remotes".source = cfg.remotesFile; }; - }; + }; - users = { - users.${cfg.user} = { - description = "Nullmailer relay-only mta user"; - inherit (cfg) group; - isSystemUser = true; + users = { + users.${cfg.user} = { + description = "Nullmailer relay-only mta user"; + inherit (cfg) group; + isSystemUser = true; + }; + + groups.${cfg.group} = { }; }; - groups.${cfg.group} = { }; - }; + systemd.tmpfiles.rules = [ + "d /var/spool/nullmailer - ${cfg.user} ${cfg.group} - -" + "d /var/spool/nullmailer/failed 770 ${cfg.user} ${cfg.group} - -" + "d /var/spool/nullmailer/queue 770 ${cfg.user} ${cfg.group} - -" + "d /var/spool/nullmailer/tmp 770 ${cfg.user} ${cfg.group} - -" + ]; - systemd.tmpfiles.rules = [ - "d /var/spool/nullmailer - ${cfg.user} ${cfg.group} - -" - "d /var/spool/nullmailer/failed 770 ${cfg.user} ${cfg.group} - -" - "d /var/spool/nullmailer/queue 770 ${cfg.user} ${cfg.group} - -" - "d /var/spool/nullmailer/tmp 770 ${cfg.user} ${cfg.group} - -" - ]; - - systemd.services.nullmailer = { - description = "nullmailer"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - - preStart = '' - rm -f /var/spool/nullmailer/trigger && mkfifo -m 660 /var/spool/nullmailer/trigger - ''; - - serviceConfig = { - User = cfg.user; - Group = cfg.group; - ExecStart = "${pkgs.nullmailer}/bin/nullmailer-send"; - Restart = "always"; + systemd.services.nullmailer = { + description = "nullmailer"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + + preStart = '' + rm -f /var/spool/nullmailer/trigger && mkfifo -m 660 /var/spool/nullmailer/trigger + ''; + + serviceConfig = { + User = cfg.user; + Group = cfg.group; + ExecStart = "${pkgs.nullmailer}/bin/nullmailer-send"; + Restart = "always"; + }; }; - }; - services.mail.sendmailSetuidWrapper = lib.mkIf cfg.setSendmail { - program = "sendmail"; - source = "${pkgs.nullmailer}/bin/sendmail"; - owner = cfg.user; - inherit (cfg) group; - setuid = true; - setgid = true; + services.mail.sendmailSetuidWrapper = lib.mkIf cfg.setSendmail { + program = "sendmail"; + source = "${pkgs.nullmailer}/bin/sendmail"; + owner = cfg.user; + inherit (cfg) group; + setuid = true; + setgid = true; + }; }; - }; } diff --git a/nixos/modules/services/mail/offlineimap.nix b/nixos/modules/services/mail/offlineimap.nix index 6566a3cee11e0d..419c84739a02cd 100644 --- a/nixos/modules/services/mail/offlineimap.nix +++ b/nixos/modules/services/mail/offlineimap.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.offlineimap; -in { +in +{ options.services.offlineimap = { enable = lib.mkEnableOption "OfflineIMAP, a software to dispose your mailbox(es) as a local Maildir(s)"; @@ -23,7 +29,7 @@ in { path = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; example = lib.literalExpression "[ pkgs.pass pkgs.bash pkgs.notmuch ]"; description = "List of derivations to put in Offlineimap's path."; }; @@ -44,7 +50,7 @@ in { systemd.user.services.offlineimap = { description = "Offlineimap: a software to dispose your mailbox(es) as a local Maildir(s)"; serviceConfig = { - Type = "oneshot"; + Type = "oneshot"; ExecStart = "${cfg.package}/bin/offlineimap -u syslog -o -1"; TimeoutStartSec = cfg.timeoutStartSec; }; @@ -53,7 +59,7 @@ in { environment.systemPackages = [ cfg.package ]; systemd.user.timers.offlineimap = { description = "offlineimap timer"; - timerConfig = { + timerConfig = { Unit = "offlineimap.service"; OnCalendar = cfg.onCalendar; # start immediately after computer is started: diff --git a/nixos/modules/services/mail/opendkim.nix b/nixos/modules/services/mail/opendkim.nix index 0aed4d9bee0145..b2fbd6ce5413a3 100644 --- a/nixos/modules/services/mail/opendkim.nix +++ b/nixos/modules/services/mail/opendkim.nix @@ -1,20 +1,38 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.opendkim; defaultSock = "local:/run/opendkim/opendkim.sock"; - args = [ "-f" "-l" - "-p" cfg.socket - "-d" cfg.domains - "-k" "${cfg.keyPath}/${cfg.selector}.private" - "-s" cfg.selector - ] ++ lib.optionals (cfg.configFile != null) [ "-x" cfg.configFile ]; + args = + [ + "-f" + "-l" + "-p" + cfg.socket + "-d" + cfg.domains + "-k" + "${cfg.keyPath}/${cfg.selector}.private" + "-s" + cfg.selector + ] + ++ lib.optionals (cfg.configFile != null) [ + "-x" + cfg.configFile + ]; - configFile = pkgs.writeText "opendkim.conf" - (lib.concatStringsSep "\n" (lib.mapAttrsToList (name: value: "${name} ${value}") cfg.settings)); -in { + configFile = pkgs.writeText "opendkim.conf" ( + lib.concatStringsSep "\n" (lib.mapAttrsToList (name: value: "${name} ${value}") cfg.settings) + ); +in +{ imports = [ (lib.mkRenamedOptionModule [ "services" "opendkim" "keyFile" ] [ "services" "opendkim" "keyPath" ]) ]; @@ -74,9 +92,11 @@ in { }; settings = lib.mkOption { - type = with lib.types; submodule { - freeformType = attrsOf str; - }; + type = + with lib.types; + submodule { + freeformType = attrsOf str; + }; default = { }; description = "Additional opendkim configuration"; }; @@ -133,7 +153,7 @@ in { StateDirectoryMode = "0700"; ReadWritePaths = [ cfg.keyPath ]; - AmbientCapabilities = []; + AmbientCapabilities = [ ]; CapabilityBoundingSet = ""; DevicePolicy = "closed"; LockPersonality = true; @@ -152,12 +172,18 @@ in { ProtectKernelTunables = true; ProtectSystem = "strict"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6 AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6 AF_UNIX" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged @resources" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged @resources" + ]; UMask = "0077"; }; }; diff --git a/nixos/modules/services/mail/opensmtpd.nix b/nixos/modules/services/mail/opensmtpd.nix index 07cf189fb28e5e..1e846e6e55649b 100644 --- a/nixos/modules/services/mail/opensmtpd.nix +++ b/nixos/modules/services/mail/opensmtpd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.opensmtpd; @@ -10,12 +15,16 @@ let ln -s ${cfg.package}/sbin/smtpctl $out/bin/sendmail ''; -in { +in +{ ###### interface imports = [ - (lib.mkRenamedOptionModule [ "services" "opensmtpd" "addSendmailToSystemPath" ] [ "services" "opensmtpd" "setSendmail" ]) + (lib.mkRenamedOptionModule + [ "services" "opensmtpd" "addSendmailToSystemPath" ] + [ "services" "opensmtpd" "setSendmail" ] + ) ]; options = { @@ -38,8 +47,11 @@ in { extraServerArgs = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; - example = [ "-v" "-P mta" ]; + default = [ ]; + example = [ + "-v" + "-P mta" + ]; description = '' Extra command line arguments provided when the smtpd process is started. @@ -60,7 +72,7 @@ in { procPackages = lib.mkOption { type = lib.types.listOf lib.types.package; - default = []; + default = [ ]; description = '' Packages to search for filters, tables, queues, and schedulers. @@ -72,7 +84,6 @@ in { }; - ###### implementation config = lib.mkIf cfg.enable rec { @@ -102,8 +113,9 @@ in { source = "${cfg.package}/bin/smtpctl"; }; - services.mail.sendmailSetuidWrapper = lib.mkIf cfg.setSendmail - (security.wrappers.smtpctl // { program = "sendmail"; }); + services.mail.sendmailSetuidWrapper = lib.mkIf cfg.setSendmail ( + security.wrappers.smtpctl // { program = "sendmail"; } + ); systemd.tmpfiles.rules = [ "d /var/spool/smtpd 711 root - - -" @@ -111,17 +123,19 @@ in { "d /var/spool/smtpd/purge 700 smtpq root - -" ]; - systemd.services.opensmtpd = let - procEnv = pkgs.buildEnv { - name = "opensmtpd-procs"; - paths = [ cfg.package ] ++ cfg.procPackages; - pathsToLink = [ "/libexec/opensmtpd" ]; + systemd.services.opensmtpd = + let + procEnv = pkgs.buildEnv { + name = "opensmtpd-procs"; + paths = [ cfg.package ] ++ cfg.procPackages; + pathsToLink = [ "/libexec/opensmtpd" ]; + }; + in + { + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + serviceConfig.ExecStart = "${cfg.package}/sbin/smtpd -d -f ${conf} ${args}"; + environment.OPENSMTPD_PROC_PATH = "${procEnv}/libexec/opensmtpd"; }; - in { - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - serviceConfig.ExecStart = "${cfg.package}/sbin/smtpd -d -f ${conf} ${args}"; - environment.OPENSMTPD_PROC_PATH = "${procEnv}/libexec/opensmtpd"; - }; }; } diff --git a/nixos/modules/services/mail/pfix-srsd.nix b/nixos/modules/services/mail/pfix-srsd.nix index d4176c509d7a46..fb6a395e3ab82e 100644 --- a/nixos/modules/services/mail/pfix-srsd.nix +++ b/nixos/modules/services/mail/pfix-srsd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { ###### interface diff --git a/nixos/modules/services/mail/postfix.nix b/nixos/modules/services/mail/postfix.nix index f842a219910de1..75e8d8838a098f 100644 --- a/nixos/modules/services/mail/postfix.nix +++ b/nixos/modules/services/mail/postfix.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.postfix; @@ -6,245 +11,317 @@ let group = cfg.group; setgidGroup = cfg.setgidGroup; - haveAliases = cfg.postmasterAlias != "" || cfg.rootAlias != "" - || cfg.extraAliases != ""; + haveAliases = cfg.postmasterAlias != "" || cfg.rootAlias != "" || cfg.extraAliases != ""; haveCanonical = cfg.canonical != ""; haveTransport = cfg.transport != ""; haveVirtual = cfg.virtual != ""; haveLocalRecipients = cfg.localRecipients != null; - clientAccess = - lib.optional (cfg.dnsBlacklistOverrides != "") - "check_client_access hash:/etc/postfix/client_access"; + clientAccess = lib.optional ( + cfg.dnsBlacklistOverrides != "" + ) "check_client_access hash:/etc/postfix/client_access"; - dnsBl = - lib.optionals (cfg.dnsBlacklists != []) - (map (s: "reject_rbl_client " + s) cfg.dnsBlacklists); + dnsBl = lib.optionals (cfg.dnsBlacklists != [ ]) ( + map (s: "reject_rbl_client " + s) cfg.dnsBlacklists + ); clientRestrictions = lib.concatStringsSep ", " (clientAccess ++ dnsBl); - mainCf = let - escape = lib.replaceStrings ["$"] ["$$"]; - mkList = items: "\n " + lib.concatStringsSep ",\n " items; - mkVal = value: - if lib.isList value then mkList value - else " " + (if value == true then "yes" - else if value == false then "no" - else toString value); - mkEntry = name: value: "${escape name} =${mkVal value}"; - in - lib.concatStringsSep "\n" (lib.mapAttrsToList mkEntry cfg.config) - + "\n" + cfg.extraConfig; - - masterCfOptions = { options, config, name, ... }: { - options = { - name = lib.mkOption { - type = lib.types.str; - default = name; - example = "smtp"; - description = '' - The name of the service to run. Defaults to the attribute set key. - ''; - }; + mainCf = + let + escape = lib.replaceStrings [ "$" ] [ "$$" ]; + mkList = items: "\n " + lib.concatStringsSep ",\n " items; + mkVal = + value: + if lib.isList value then + mkList value + else + " " + + ( + if value == true then + "yes" + else if value == false then + "no" + else + toString value + ); + mkEntry = name: value: "${escape name} =${mkVal value}"; + in + lib.concatStringsSep "\n" (lib.mapAttrsToList mkEntry cfg.config) + "\n" + cfg.extraConfig; + + masterCfOptions = + { + options, + config, + name, + ... + }: + { + options = { + name = lib.mkOption { + type = lib.types.str; + default = name; + example = "smtp"; + description = '' + The name of the service to run. Defaults to the attribute set key. + ''; + }; - type = lib.mkOption { - type = lib.types.enum [ "inet" "unix" "unix-dgram" "fifo" "pass" ]; - default = "unix"; - example = "inet"; - description = "The type of the service"; - }; + type = lib.mkOption { + type = lib.types.enum [ + "inet" + "unix" + "unix-dgram" + "fifo" + "pass" + ]; + default = "unix"; + example = "inet"; + description = "The type of the service"; + }; - private = lib.mkOption { - type = lib.types.bool; - example = false; - description = '' - Whether the service's sockets and storage directory is restricted to - be only available via the mail system. If `null` is - given it uses the postfix default `true`. - ''; - }; + private = lib.mkOption { + type = lib.types.bool; + example = false; + description = '' + Whether the service's sockets and storage directory is restricted to + be only available via the mail system. If `null` is + given it uses the postfix default `true`. + ''; + }; - privileged = lib.mkOption { - type = lib.types.bool; - example = true; - description = ""; - }; + privileged = lib.mkOption { + type = lib.types.bool; + example = true; + description = ""; + }; - chroot = lib.mkOption { - type = lib.types.bool; - example = true; - description = '' - Whether the service is chrooted to have only access to the - {option}`services.postfix.queueDir` and the closure of - store paths specified by the {option}`program` option. - ''; - }; + chroot = lib.mkOption { + type = lib.types.bool; + example = true; + description = '' + Whether the service is chrooted to have only access to the + {option}`services.postfix.queueDir` and the closure of + store paths specified by the {option}`program` option. + ''; + }; - wakeup = lib.mkOption { - type = lib.types.int; - example = 60; - description = '' - Automatically wake up the service after the specified number of - seconds. If `0` is given, never wake the service - up. - ''; - }; + wakeup = lib.mkOption { + type = lib.types.int; + example = 60; + description = '' + Automatically wake up the service after the specified number of + seconds. If `0` is given, never wake the service + up. + ''; + }; - wakeupUnusedComponent = lib.mkOption { - type = lib.types.bool; - example = false; - description = '' - If set to `false` the component will only be woken - up if it is used. This is equivalent to postfix' notion of adding a - question mark behind the wakeup time in - {file}`master.cf` - ''; - }; + wakeupUnusedComponent = lib.mkOption { + type = lib.types.bool; + example = false; + description = '' + If set to `false` the component will only be woken + up if it is used. This is equivalent to postfix' notion of adding a + question mark behind the wakeup time in + {file}`master.cf` + ''; + }; - maxproc = lib.mkOption { - type = lib.types.int; - example = 1; - description = '' - The maximum number of processes to spawn for this service. If the - value is `0` it doesn't have any limit. If - `null` is given it uses the postfix default of - `100`. - ''; - }; + maxproc = lib.mkOption { + type = lib.types.int; + example = 1; + description = '' + The maximum number of processes to spawn for this service. If the + value is `0` it doesn't have any limit. If + `null` is given it uses the postfix default of + `100`. + ''; + }; - command = lib.mkOption { - type = lib.types.str; - default = name; - example = "smtpd"; - description = '' - A program name specifying a Postfix service/daemon process. - By default it's the attribute {option}`name`. - ''; - }; + command = lib.mkOption { + type = lib.types.str; + default = name; + example = "smtpd"; + description = '' + A program name specifying a Postfix service/daemon process. + By default it's the attribute {option}`name`. + ''; + }; - args = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - example = [ "-o" "smtp_helo_timeout=5" ]; - description = '' - Arguments to pass to the {option}`command`. There is no shell - processing involved and shell syntax is passed verbatim to the - process. - ''; - }; + args = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + example = [ + "-o" + "smtp_helo_timeout=5" + ]; + description = '' + Arguments to pass to the {option}`command`. There is no shell + processing involved and shell syntax is passed verbatim to the + process. + ''; + }; - rawEntry = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - internal = true; - description = '' - The raw configuration line for the {file}`master.cf`. - ''; + rawEntry = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + internal = true; + description = '' + The raw configuration line for the {file}`master.cf`. + ''; + }; }; - }; - - config.rawEntry = let - mkBool = bool: if bool then "y" else "n"; - mkArg = arg: "${lib.optionalString (lib.hasPrefix "-" arg) "\n "}${arg}"; - - maybeOption = fun: option: - if options.${option}.isDefined then fun config.${option} else "-"; - - # This is special, because we have two options for this value. - wakeup = let - wakeupDefined = options.wakeup.isDefined; - wakeupUCDefined = options.wakeupUnusedComponent.isDefined; - finalValue = toString config.wakeup - + lib.optionalString (wakeupUCDefined && !config.wakeupUnusedComponent) "?"; - in if wakeupDefined then finalValue else "-"; - - in [ - config.name - config.type - (maybeOption mkBool "private") - (maybeOption (b: mkBool (!b)) "privileged") - (maybeOption mkBool "chroot") - wakeup - (maybeOption toString "maxproc") - (config.command + " " + lib.concatMapStringsSep " " mkArg config.args) - ]; - }; - - masterCfContent = let - - labels = [ - "# service" "type" "private" "unpriv" "chroot" "wakeup" "maxproc" - "command + args" - ]; - - labelDefaults = [ - "# " "" "(yes)" "(yes)" "(no)" "(never)" "(100)" "" "" - ]; - - masterCf = lib.mapAttrsToList (lib.const (lib.getAttr "rawEntry")) cfg.masterConfig; - - # A list of the maximum width of the columns across all lines and labels - maxWidths = let - foldLine = line: acc: let - columnLengths = map lib.stringLength line; - in lib.zipListsWith lib.max acc columnLengths; - # We need to handle the last column specially here, because it's - # open-ended (command + args). - lines = [ labels labelDefaults ] ++ (map (l: lib.init l ++ [""]) masterCf); - in lib.foldr foldLine (lib.genList (lib.const 0) (lib.length labels)) lines; - # Pad a string with spaces from the right (opposite of fixedWidthString). - pad = width: str: let - padWidth = width - lib.stringLength str; - padding = lib.concatStrings (lib.genList (lib.const " ") padWidth); - in str + lib.optionalString (padWidth > 0) padding; - - # It's + 2 here, because that's the amount of spacing between columns. - fullWidth = lib.foldr (width: acc: acc + width + 2) 0 maxWidths; - - formatLine = line: lib.concatStringsSep " " (lib.zipListsWith pad maxWidths line); - - formattedLabels = let - sep = "# " + lib.concatStrings (lib.genList (lib.const "=") (fullWidth + 5)); - lines = [ sep (formatLine labels) (formatLine labelDefaults) sep ]; - in lib.concatStringsSep "\n" lines; - - in formattedLabels + "\n" + lib.concatMapStringsSep "\n" formatLine masterCf + "\n" + cfg.extraMasterConf; + config.rawEntry = + let + mkBool = bool: if bool then "y" else "n"; + mkArg = arg: "${lib.optionalString (lib.hasPrefix "-" arg) "\n "}${arg}"; + + maybeOption = fun: option: if options.${option}.isDefined then fun config.${option} else "-"; + + # This is special, because we have two options for this value. + wakeup = + let + wakeupDefined = options.wakeup.isDefined; + wakeupUCDefined = options.wakeupUnusedComponent.isDefined; + finalValue = + toString config.wakeup + lib.optionalString (wakeupUCDefined && !config.wakeupUnusedComponent) "?"; + in + if wakeupDefined then finalValue else "-"; + + in + [ + config.name + config.type + (maybeOption mkBool "private") + (maybeOption (b: mkBool (!b)) "privileged") + (maybeOption mkBool "chroot") + wakeup + (maybeOption toString "maxproc") + (config.command + " " + lib.concatMapStringsSep " " mkArg config.args) + ]; + }; - headerCheckOptions = { ... }: - { - options = { - pattern = lib.mkOption { - type = lib.types.str; - default = "/^.*/"; - example = "/^X-Mailer:/"; - description = "A regexp pattern matching the header"; - }; - action = lib.mkOption { - type = lib.types.str; - default = "DUNNO"; - example = "BCC mail@example.com"; - description = "The action to be executed when the pattern is matched"; + masterCfContent = + let + + labels = [ + "# service" + "type" + "private" + "unpriv" + "chroot" + "wakeup" + "maxproc" + "command + args" + ]; + + labelDefaults = [ + "# " + "" + "(yes)" + "(yes)" + "(no)" + "(never)" + "(100)" + "" + "" + ]; + + masterCf = lib.mapAttrsToList (lib.const (lib.getAttr "rawEntry")) cfg.masterConfig; + + # A list of the maximum width of the columns across all lines and labels + maxWidths = + let + foldLine = + line: acc: + let + columnLengths = map lib.stringLength line; + in + lib.zipListsWith lib.max acc columnLengths; + # We need to handle the last column specially here, because it's + # open-ended (command + args). + lines = [ + labels + labelDefaults + ] ++ (map (l: lib.init l ++ [ "" ]) masterCf); + in + lib.foldr foldLine (lib.genList (lib.const 0) (lib.length labels)) lines; + + # Pad a string with spaces from the right (opposite of fixedWidthString). + pad = + width: str: + let + padWidth = width - lib.stringLength str; + padding = lib.concatStrings (lib.genList (lib.const " ") padWidth); + in + str + lib.optionalString (padWidth > 0) padding; + + # It's + 2 here, because that's the amount of spacing between columns. + fullWidth = lib.foldr (width: acc: acc + width + 2) 0 maxWidths; + + formatLine = line: lib.concatStringsSep " " (lib.zipListsWith pad maxWidths line); + + formattedLabels = + let + sep = "# " + lib.concatStrings (lib.genList (lib.const "=") (fullWidth + 5)); + lines = [ + sep + (formatLine labels) + (formatLine labelDefaults) + sep + ]; + in + lib.concatStringsSep "\n" lines; + + in + formattedLabels + + "\n" + + lib.concatMapStringsSep "\n" formatLine masterCf + + "\n" + + cfg.extraMasterConf; + + headerCheckOptions = + { ... }: + { + options = { + pattern = lib.mkOption { + type = lib.types.str; + default = "/^.*/"; + example = "/^X-Mailer:/"; + description = "A regexp pattern matching the header"; + }; + action = lib.mkOption { + type = lib.types.str; + default = "DUNNO"; + example = "BCC mail@example.com"; + description = "The action to be executed when the pattern is matched"; + }; }; }; - }; - headerChecks = lib.concatStringsSep "\n" (map (x: "${x.pattern} ${x.action}") cfg.headerChecks) + cfg.extraHeaderChecks; + headerChecks = + lib.concatStringsSep "\n" (map (x: "${x.pattern} ${x.action}") cfg.headerChecks) + + cfg.extraHeaderChecks; - aliases = let separator = lib.optionalString (cfg.aliasMapType == "hash") ":"; in + aliases = + let + separator = lib.optionalString (cfg.aliasMapType == "hash") ":"; + in lib.optionalString (cfg.postmasterAlias != "") '' postmaster${separator} ${cfg.postmasterAlias} '' + lib.optionalString (cfg.rootAlias != "") '' root${separator} ${cfg.rootAlias} '' - + cfg.extraAliases - ; + + cfg.extraAliases; aliasesFile = pkgs.writeText "postfix-aliases" aliases; canonicalFile = pkgs.writeText "postfix-canonical" cfg.canonical; virtualFile = pkgs.writeText "postfix-virtual" cfg.virtual; - localRecipientMapFile = pkgs.writeText "postfix-local-recipient-map" (lib.concatMapStrings (x: x + " ACCEPT\n") cfg.localRecipients); + localRecipientMapFile = pkgs.writeText "postfix-local-recipient-map" ( + lib.concatMapStrings (x: x + " ACCEPT\n") cfg.localRecipients + ); checkClientAccessFile = pkgs.writeText "postfix-check-client-access" cfg.dnsBlacklistOverrides; mainCfFile = pkgs.writeText "postfix-main.cf" mainCf; masterCfFile = pkgs.writeText "postfix-master.cf" masterCfContent; @@ -361,7 +438,7 @@ in networks = lib.mkOption { type = lib.types.nullOr (lib.types.listOf lib.types.str); default = null; - example = ["192.168.0.1/24"]; + example = [ "192.168.0.1/24" ]; description = '' Net masks for trusted - allowed to relay mail to third parties - hosts. Leave empty to use mynetworks_style configuration or use @@ -407,7 +484,7 @@ in destination = lib.mkOption { type = lib.types.nullOr (lib.types.listOf lib.types.str); default = null; - example = ["localhost"]; + example = [ "localhost" ]; description = '' Full (!) list of domains we deliver locally. Leave blank for acceptable Postfix default. @@ -417,7 +494,7 @@ in relayDomains = lib.mkOption { type = lib.types.nullOr (lib.types.listOf lib.types.str); default = null; - example = ["localdomain"]; + example = [ "localdomain" ]; description = '' List of domains we agree to relay to. Default is empty. ''; @@ -474,14 +551,27 @@ in }; aliasMapType = lib.mkOption { - type = with lib.types; enum [ "hash" "regexp" "pcre" ]; + type = + with lib.types; + enum [ + "hash" + "regexp" + "pcre" + ]; default = "hash"; example = "regexp"; description = "The format the alias map should have. Use regexp if you want to use regular expressions."; }; config = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ bool int str (listOf str) ]); + type = + with lib.types; + attrsOf (oneOf [ + bool + int + str + (listOf str) + ]); description = '' The main.cf configuration file as key value set. ''; @@ -546,7 +636,11 @@ in }; virtualMapType = lib.mkOption { - type = lib.types.enum ["hash" "regexp" "pcre"]; + type = lib.types.enum [ + "hash" + "regexp" + "pcre" + ]; default = "hash"; description = '' What type of virtual alias map file to use. Use `"regexp"` for regular expressions. @@ -575,7 +669,7 @@ in }; dnsBlacklists = lib.mkOption { - default = []; + default = [ ]; type = with lib.types; listOf str; description = "dns blacklist servers to use with smtpd_client_restrictions"; }; @@ -588,13 +682,16 @@ in masterConfig = lib.mkOption { type = lib.types.attrsOf (lib.types.submodule masterCfOptions); - default = {}; - example = - { submission = { - type = "inet"; - args = [ "-o" "smtpd_tls_security_level=encrypt" ]; - }; + default = { }; + example = { + submission = { + type = "inet"; + args = [ + "-o" + "smtpd_tls_security_level=encrypt" + ]; }; + }; description = '' An attribute set of service options, which correspond to the service definitions usually done within the Postfix @@ -618,8 +715,13 @@ in headerChecks = lib.mkOption { type = lib.types.listOf (lib.types.submodule headerCheckOptions); - default = []; - example = [ { pattern = "/^X-Spam-Flag:/"; action = "REDIRECT spam@example.com"; } ]; + default = [ ]; + example = [ + { + pattern = "/^X-Spam-Flag:/"; + action = "REDIRECT spam@example.com"; + } + ]; description = "Postfix header checks."; }; @@ -632,13 +734,13 @@ in aliasFiles = lib.mkOption { type = lib.types.attrsOf lib.types.path; - default = {}; + default = { }; description = "Aliases' tables to be compiled and placed into /var/lib/postfix/conf."; }; mapFiles = lib.mkOption { type = lib.types.attrsOf lib.types.path; - default = {}; + default = { }; description = "Maps to be compiled and placed into /var/lib/postfix/conf."; }; @@ -652,75 +754,75 @@ in }; - ###### implementation - config = lib.mkIf config.services.postfix.enable (lib.mkMerge [ - { + config = lib.mkIf config.services.postfix.enable ( + lib.mkMerge [ + { - environment = { - etc.postfix.source = "/var/lib/postfix/conf"; + environment = { + etc.postfix.source = "/var/lib/postfix/conf"; - # This makes it comfortable to run 'postqueue/postdrop' for example. - systemPackages = [ pkgs.postfix ]; - }; + # This makes it comfortable to run 'postqueue/postdrop' for example. + systemPackages = [ pkgs.postfix ]; + }; - services.pfix-srsd.enable = config.services.postfix.useSrs; + services.pfix-srsd.enable = config.services.postfix.useSrs; - services.mail.sendmailSetuidWrapper = lib.mkIf config.services.postfix.setSendmail { - program = "sendmail"; - source = "${pkgs.postfix}/bin/sendmail"; - owner = "root"; - group = setgidGroup; - setuid = false; - setgid = true; - }; + services.mail.sendmailSetuidWrapper = lib.mkIf config.services.postfix.setSendmail { + program = "sendmail"; + source = "${pkgs.postfix}/bin/sendmail"; + owner = "root"; + group = setgidGroup; + setuid = false; + setgid = true; + }; - security.wrappers.mailq = { - program = "mailq"; - source = "${pkgs.postfix}/bin/mailq"; - owner = "root"; - group = setgidGroup; - setuid = false; - setgid = true; - }; + security.wrappers.mailq = { + program = "mailq"; + source = "${pkgs.postfix}/bin/mailq"; + owner = "root"; + group = setgidGroup; + setuid = false; + setgid = true; + }; - security.wrappers.postqueue = { - program = "postqueue"; - source = "${pkgs.postfix}/bin/postqueue"; - owner = "root"; - group = setgidGroup; - setuid = false; - setgid = true; - }; + security.wrappers.postqueue = { + program = "postqueue"; + source = "${pkgs.postfix}/bin/postqueue"; + owner = "root"; + group = setgidGroup; + setuid = false; + setgid = true; + }; - security.wrappers.postdrop = { - program = "postdrop"; - source = "${pkgs.postfix}/bin/postdrop"; - owner = "root"; - group = setgidGroup; - setuid = false; - setgid = true; - }; + security.wrappers.postdrop = { + program = "postdrop"; + source = "${pkgs.postfix}/bin/postdrop"; + owner = "root"; + group = setgidGroup; + setuid = false; + setgid = true; + }; - users.users = lib.optionalAttrs (user == "postfix") - { postfix = { + users.users = lib.optionalAttrs (user == "postfix") { + postfix = { description = "Postfix mail server user"; uid = config.ids.uids.postfix; group = group; }; }; - users.groups = - lib.optionalAttrs (group == "postfix") - { ${group}.gid = config.ids.gids.postfix; - } - // lib.optionalAttrs (setgidGroup == "postdrop") - { ${setgidGroup}.gid = config.ids.gids.postdrop; - }; + users.groups = + lib.optionalAttrs (group == "postfix") { + ${group}.gid = config.ids.gids.postfix; + } + // lib.optionalAttrs (setgidGroup == "postdrop") { + ${setgidGroup}.gid = config.ids.gids.postdrop; + }; - systemd.services.postfix-setup = - { description = "Setup for Postfix mail server"; + systemd.services.postfix-setup = { + description = "Setup for Postfix mail server"; serviceConfig.RemainAfterExit = true; serviceConfig.Type = "oneshot"; script = '' @@ -742,14 +844,18 @@ in ln -sf ${mainCfFile} /var/lib/postfix/conf/main.cf ln -sf ${masterCfFile} /var/lib/postfix/conf/master.cf - ${lib.concatStringsSep "\n" (lib.mapAttrsToList (to: from: '' - ln -sf ${from} /var/lib/postfix/conf/${to} - ${pkgs.postfix}/bin/postalias -o -p /var/lib/postfix/conf/${to} - '') cfg.aliasFiles)} - ${lib.concatStringsSep "\n" (lib.mapAttrsToList (to: from: '' - ln -sf ${from} /var/lib/postfix/conf/${to} - ${pkgs.postfix}/bin/postmap /var/lib/postfix/conf/${to} - '') cfg.mapFiles)} + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList (to: from: '' + ln -sf ${from} /var/lib/postfix/conf/${to} + ${pkgs.postfix}/bin/postalias -o -p /var/lib/postfix/conf/${to} + '') cfg.aliasFiles + )} + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList (to: from: '' + ln -sf ${from} /var/lib/postfix/conf/${to} + ${pkgs.postfix}/bin/postmap /var/lib/postfix/conf/${to} + '') cfg.mapFiles + )} mkdir -p /var/spool/mail chown root:root /var/spool/mail @@ -761,11 +867,14 @@ in ''; }; - systemd.services.postfix = - { description = "Postfix mail server"; + systemd.services.postfix = { + description = "Postfix mail server"; wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "postfix-setup.service" ]; + after = [ + "network.target" + "postfix-setup.service" + ]; requires = [ "postfix-setup.service" ]; path = [ pkgs.postfix ]; @@ -786,219 +895,264 @@ in ProtectKernelModules = true; ProtectKernelTunables = true; ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_NETLINK" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_NETLINK" + "AF_UNIX" + ]; RestrictNamespaces = true; RestrictRealtime = true; }; }; - services.postfix.config = (lib.mapAttrs (_: v: lib.mkDefault v) { - compatibility_level = pkgs.postfix.version; - mail_owner = cfg.user; - default_privs = "nobody"; - - # NixOS specific locations - data_directory = "/var/lib/postfix/data"; - queue_directory = "/var/lib/postfix/queue"; - - # Default location of everything in package - meta_directory = "${pkgs.postfix}/etc/postfix"; - command_directory = "${pkgs.postfix}/bin"; - sample_directory = "/etc/postfix"; - newaliases_path = "${pkgs.postfix}/bin/newaliases"; - mailq_path = "${pkgs.postfix}/bin/mailq"; - readme_directory = false; - sendmail_path = "${pkgs.postfix}/bin/sendmail"; - daemon_directory = "${pkgs.postfix}/libexec/postfix"; - manpage_directory = "${pkgs.postfix}/share/man"; - html_directory = "${pkgs.postfix}/share/postfix/doc/html"; - shlib_directory = false; - mail_spool_directory = "/var/spool/mail/"; - setgid_group = cfg.setgidGroup; - }) - // lib.optionalAttrs (cfg.relayHost != "") { relayhost = if cfg.lookupMX - then "${cfg.relayHost}:${toString cfg.relayPort}" - else "[${cfg.relayHost}]:${toString cfg.relayPort}"; } - // lib.optionalAttrs (!config.networking.enableIPv6) { inet_protocols = lib.mkDefault "ipv4"; } - // lib.optionalAttrs (cfg.networks != null) { mynetworks = cfg.networks; } - // lib.optionalAttrs (cfg.networksStyle != "") { mynetworks_style = cfg.networksStyle; } - // lib.optionalAttrs (cfg.hostname != "") { myhostname = cfg.hostname; } - // lib.optionalAttrs (cfg.domain != "") { mydomain = cfg.domain; } - // lib.optionalAttrs (cfg.origin != "") { myorigin = cfg.origin; } - // lib.optionalAttrs (cfg.destination != null) { mydestination = cfg.destination; } - // lib.optionalAttrs (cfg.relayDomains != null) { relay_domains = cfg.relayDomains; } - // lib.optionalAttrs (cfg.recipientDelimiter != "") { recipient_delimiter = cfg.recipientDelimiter; } - // lib.optionalAttrs haveAliases { alias_maps = [ "${cfg.aliasMapType}:/etc/postfix/aliases" ]; } - // lib.optionalAttrs haveTransport { transport_maps = [ "hash:/etc/postfix/transport" ]; } - // lib.optionalAttrs haveVirtual { virtual_alias_maps = [ "${cfg.virtualMapType}:/etc/postfix/virtual" ]; } - // lib.optionalAttrs haveLocalRecipients { local_recipient_maps = [ "hash:/etc/postfix/local_recipients" ] ++ lib.optional haveAliases "$alias_maps"; } - // lib.optionalAttrs (cfg.dnsBlacklists != []) { smtpd_client_restrictions = clientRestrictions; } - // lib.optionalAttrs cfg.useSrs { - sender_canonical_maps = [ "tcp:127.0.0.1:10001" ]; - sender_canonical_classes = [ "envelope_sender" ]; - recipient_canonical_maps = [ "tcp:127.0.0.1:10002" ]; - recipient_canonical_classes = [ "envelope_recipient" ]; - } - // lib.optionalAttrs cfg.enableHeaderChecks { header_checks = [ "regexp:/etc/postfix/header_checks" ]; } - // lib.optionalAttrs (cfg.tlsTrustedAuthorities != "") { - smtp_tls_CAfile = cfg.tlsTrustedAuthorities; - smtp_tls_security_level = lib.mkDefault "may"; - } - // lib.optionalAttrs (cfg.sslCert != "") { - smtp_tls_cert_file = cfg.sslCert; - smtp_tls_key_file = cfg.sslKey; - - smtp_tls_security_level = lib.mkDefault "may"; - - smtpd_tls_cert_file = cfg.sslCert; - smtpd_tls_key_file = cfg.sslKey; - - smtpd_tls_security_level = lib.mkDefault "may"; + services.postfix.config = + (lib.mapAttrs (_: v: lib.mkDefault v) { + compatibility_level = pkgs.postfix.version; + mail_owner = cfg.user; + default_privs = "nobody"; + + # NixOS specific locations + data_directory = "/var/lib/postfix/data"; + queue_directory = "/var/lib/postfix/queue"; + + # Default location of everything in package + meta_directory = "${pkgs.postfix}/etc/postfix"; + command_directory = "${pkgs.postfix}/bin"; + sample_directory = "/etc/postfix"; + newaliases_path = "${pkgs.postfix}/bin/newaliases"; + mailq_path = "${pkgs.postfix}/bin/mailq"; + readme_directory = false; + sendmail_path = "${pkgs.postfix}/bin/sendmail"; + daemon_directory = "${pkgs.postfix}/libexec/postfix"; + manpage_directory = "${pkgs.postfix}/share/man"; + html_directory = "${pkgs.postfix}/share/postfix/doc/html"; + shlib_directory = false; + mail_spool_directory = "/var/spool/mail/"; + setgid_group = cfg.setgidGroup; + }) + // lib.optionalAttrs (cfg.relayHost != "") { + relayhost = + if cfg.lookupMX then + "${cfg.relayHost}:${toString cfg.relayPort}" + else + "[${cfg.relayHost}]:${toString cfg.relayPort}"; + } + // lib.optionalAttrs (!config.networking.enableIPv6) { inet_protocols = lib.mkDefault "ipv4"; } + // lib.optionalAttrs (cfg.networks != null) { mynetworks = cfg.networks; } + // lib.optionalAttrs (cfg.networksStyle != "") { mynetworks_style = cfg.networksStyle; } + // lib.optionalAttrs (cfg.hostname != "") { myhostname = cfg.hostname; } + // lib.optionalAttrs (cfg.domain != "") { mydomain = cfg.domain; } + // lib.optionalAttrs (cfg.origin != "") { myorigin = cfg.origin; } + // lib.optionalAttrs (cfg.destination != null) { mydestination = cfg.destination; } + // lib.optionalAttrs (cfg.relayDomains != null) { relay_domains = cfg.relayDomains; } + // lib.optionalAttrs (cfg.recipientDelimiter != "") { + recipient_delimiter = cfg.recipientDelimiter; + } + // lib.optionalAttrs haveAliases { alias_maps = [ "${cfg.aliasMapType}:/etc/postfix/aliases" ]; } + // lib.optionalAttrs haveTransport { transport_maps = [ "hash:/etc/postfix/transport" ]; } + // lib.optionalAttrs haveVirtual { + virtual_alias_maps = [ "${cfg.virtualMapType}:/etc/postfix/virtual" ]; + } + // lib.optionalAttrs haveLocalRecipients { + local_recipient_maps = [ + "hash:/etc/postfix/local_recipients" + ] ++ lib.optional haveAliases "$alias_maps"; + } + // lib.optionalAttrs (cfg.dnsBlacklists != [ ]) { smtpd_client_restrictions = clientRestrictions; } + // lib.optionalAttrs cfg.useSrs { + sender_canonical_maps = [ "tcp:127.0.0.1:10001" ]; + sender_canonical_classes = [ "envelope_sender" ]; + recipient_canonical_maps = [ "tcp:127.0.0.1:10002" ]; + recipient_canonical_classes = [ "envelope_recipient" ]; + } + // lib.optionalAttrs cfg.enableHeaderChecks { + header_checks = [ "regexp:/etc/postfix/header_checks" ]; + } + // lib.optionalAttrs (cfg.tlsTrustedAuthorities != "") { + smtp_tls_CAfile = cfg.tlsTrustedAuthorities; + smtp_tls_security_level = lib.mkDefault "may"; + } + // lib.optionalAttrs (cfg.sslCert != "") { + smtp_tls_cert_file = cfg.sslCert; + smtp_tls_key_file = cfg.sslKey; + + smtp_tls_security_level = lib.mkDefault "may"; + + smtpd_tls_cert_file = cfg.sslCert; + smtpd_tls_key_file = cfg.sslKey; + + smtpd_tls_security_level = lib.mkDefault "may"; - }; + }; - services.postfix.masterConfig = { - pickup = { - private = false; - wakeup = 60; - maxproc = 1; - }; - cleanup = { - private = false; - maxproc = 0; - }; - qmgr = { - private = false; - wakeup = 300; - maxproc = 1; - }; - tlsmgr = { - wakeup = 1000; - wakeupUnusedComponent = false; - maxproc = 1; - }; - rewrite = { - command = "trivial-rewrite"; - }; - bounce = { - maxproc = 0; - }; - defer = { - maxproc = 0; - command = "bounce"; - }; - trace = { - maxproc = 0; - command = "bounce"; - }; - verify = { - maxproc = 1; - }; - flush = { - private = false; - wakeup = 1000; - wakeupUnusedComponent = false; - maxproc = 0; - }; - proxymap = { - command = "proxymap"; - }; - proxywrite = { - maxproc = 1; - command = "proxymap"; - }; - showq = { - private = false; - }; - error = {}; - retry = { - command = "error"; - }; - discard = {}; - local = { - privileged = true; - }; - virtual = { - privileged = true; - }; - lmtp = { - }; - anvil = { - maxproc = 1; - }; - scache = { - maxproc = 1; - }; - } // lib.optionalAttrs cfg.enableSubmission { - submission = { - type = "inet"; - private = false; - command = "smtpd"; - args = let - mkKeyVal = opt: val: [ "-o" (opt + "=" + val) ]; - in lib.concatLists (lib.mapAttrsToList mkKeyVal cfg.submissionOptions); - }; - } // lib.optionalAttrs cfg.enableSmtp { - smtp_inet = { - name = "smtp"; - type = "inet"; - private = false; - command = "smtpd"; - }; - smtp = {}; - relay = { - command = "smtp"; - args = [ "-o" "smtp_fallback_relay=" ]; - }; - } // lib.optionalAttrs cfg.enableSubmissions { - submissions = { - type = "inet"; - private = false; - command = "smtpd"; - args = let - mkKeyVal = opt: val: [ "-o" (opt + "=" + val) ]; - adjustSmtpTlsSecurityLevel = !(cfg.submissionsOptions ? smtpd_tls_security_level) || - cfg.submissionsOptions.smtpd_tls_security_level == "none" || - cfg.submissionsOptions.smtpd_tls_security_level == "may"; - submissionsOptions = cfg.submissionsOptions // { - smtpd_tls_wrappermode = "yes"; - } // lib.optionalAttrs adjustSmtpTlsSecurityLevel { - smtpd_tls_security_level = "encrypt"; + services.postfix.masterConfig = + { + pickup = { + private = false; + wakeup = 60; + maxproc = 1; }; - in lib.concatLists (lib.mapAttrsToList mkKeyVal submissionsOptions); - }; - }; - } - - (lib.mkIf haveAliases { - services.postfix.aliasFiles.aliases = aliasesFile; - }) - (lib.mkIf haveCanonical { - services.postfix.mapFiles.canonical = canonicalFile; - }) - (lib.mkIf haveTransport { - services.postfix.mapFiles.transport = transportFile; - }) - (lib.mkIf haveVirtual { - services.postfix.mapFiles.virtual = virtualFile; - }) - (lib.mkIf haveLocalRecipients { - services.postfix.mapFiles.local_recipients = localRecipientMapFile; - }) - (lib.mkIf cfg.enableHeaderChecks { - services.postfix.mapFiles.header_checks = headerChecksFile; - }) - (lib.mkIf (cfg.dnsBlacklists != []) { - services.postfix.mapFiles.client_access = checkClientAccessFile; - }) - ]); + cleanup = { + private = false; + maxproc = 0; + }; + qmgr = { + private = false; + wakeup = 300; + maxproc = 1; + }; + tlsmgr = { + wakeup = 1000; + wakeupUnusedComponent = false; + maxproc = 1; + }; + rewrite = { + command = "trivial-rewrite"; + }; + bounce = { + maxproc = 0; + }; + defer = { + maxproc = 0; + command = "bounce"; + }; + trace = { + maxproc = 0; + command = "bounce"; + }; + verify = { + maxproc = 1; + }; + flush = { + private = false; + wakeup = 1000; + wakeupUnusedComponent = false; + maxproc = 0; + }; + proxymap = { + command = "proxymap"; + }; + proxywrite = { + maxproc = 1; + command = "proxymap"; + }; + showq = { + private = false; + }; + error = { }; + retry = { + command = "error"; + }; + discard = { }; + local = { + privileged = true; + }; + virtual = { + privileged = true; + }; + lmtp = { + }; + anvil = { + maxproc = 1; + }; + scache = { + maxproc = 1; + }; + } + // lib.optionalAttrs cfg.enableSubmission { + submission = { + type = "inet"; + private = false; + command = "smtpd"; + args = + let + mkKeyVal = opt: val: [ + "-o" + (opt + "=" + val) + ]; + in + lib.concatLists (lib.mapAttrsToList mkKeyVal cfg.submissionOptions); + }; + } + // lib.optionalAttrs cfg.enableSmtp { + smtp_inet = { + name = "smtp"; + type = "inet"; + private = false; + command = "smtpd"; + }; + smtp = { }; + relay = { + command = "smtp"; + args = [ + "-o" + "smtp_fallback_relay=" + ]; + }; + } + // lib.optionalAttrs cfg.enableSubmissions { + submissions = { + type = "inet"; + private = false; + command = "smtpd"; + args = + let + mkKeyVal = opt: val: [ + "-o" + (opt + "=" + val) + ]; + adjustSmtpTlsSecurityLevel = + !(cfg.submissionsOptions ? smtpd_tls_security_level) + || cfg.submissionsOptions.smtpd_tls_security_level == "none" + || cfg.submissionsOptions.smtpd_tls_security_level == "may"; + submissionsOptions = + cfg.submissionsOptions + // { + smtpd_tls_wrappermode = "yes"; + } + // lib.optionalAttrs adjustSmtpTlsSecurityLevel { + smtpd_tls_security_level = "encrypt"; + }; + in + lib.concatLists (lib.mapAttrsToList mkKeyVal submissionsOptions); + }; + }; + } - imports = [ - (lib.mkRemovedOptionModule [ "services" "postfix" "sslCACert" ] - "services.postfix.sslCACert was replaced by services.postfix.tlsTrustedAuthorities. In case you intend that your server should validate requested client certificates use services.postfix.extraConfig.") + (lib.mkIf haveAliases { + services.postfix.aliasFiles.aliases = aliasesFile; + }) + (lib.mkIf haveCanonical { + services.postfix.mapFiles.canonical = canonicalFile; + }) + (lib.mkIf haveTransport { + services.postfix.mapFiles.transport = transportFile; + }) + (lib.mkIf haveVirtual { + services.postfix.mapFiles.virtual = virtualFile; + }) + (lib.mkIf haveLocalRecipients { + services.postfix.mapFiles.local_recipients = localRecipientMapFile; + }) + (lib.mkIf cfg.enableHeaderChecks { + services.postfix.mapFiles.header_checks = headerChecksFile; + }) + (lib.mkIf (cfg.dnsBlacklists != [ ]) { + services.postfix.mapFiles.client_access = checkClientAccessFile; + }) + ] + ); - (lib.mkChangedOptionModule [ "services" "postfix" "useDane" ] - [ "services" "postfix" "config" "smtp_tls_security_level" ] - (config: lib.mkIf config.services.postfix.useDane "dane")) + imports = [ + (lib.mkRemovedOptionModule [ "services" "postfix" "sslCACert" ] + "services.postfix.sslCACert was replaced by services.postfix.tlsTrustedAuthorities. In case you intend that your server should validate requested client certificates use services.postfix.extraConfig." + ) + + (lib.mkChangedOptionModule + [ "services" "postfix" "useDane" ] + [ "services" "postfix" "config" "smtp_tls_security_level" ] + (config: lib.mkIf config.services.postfix.useDane "dane") + ) ]; } diff --git a/nixos/modules/services/mail/postgrey.nix b/nixos/modules/services/mail/postgrey.nix index 7c206e3725e6b2..7ce9d40a912af5 100644 --- a/nixos/modules/services/mail/postgrey.nix +++ b/nixos/modules/services/mail/postgrey.nix @@ -1,13 +1,21 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: -with lib; let +with lib; +let cfg = config.services.postgrey; natural = with types; addCheck int (x: x >= 0); natural' = with types; addCheck int (x: x > 0); - socket = with types; addCheck (either (submodule unixSocket) (submodule inetSocket)) (x: x ? path || x ? port); + socket = + with types; + addCheck (either (submodule unixSocket) (submodule inetSocket)) (x: x ? path || x ? port); inetSocket = with types; { options = { @@ -41,17 +49,47 @@ with lib; let }; }; -in { +in +{ imports = [ - (mkMergedOptionModule [ [ "services" "postgrey" "inetAddr" ] [ "services" "postgrey" "inetPort" ] ] [ "services" "postgrey" "socket" ] (config: let - value = p: getAttrFromPath p config; - inetAddr = [ "services" "postgrey" "inetAddr" ]; - inetPort = [ "services" "postgrey" "inetPort" ]; - in - if value inetAddr == null - then { path = "/run/postgrey.sock"; } - else { addr = value inetAddr; port = value inetPort; } - )) + (mkMergedOptionModule + [ + [ + "services" + "postgrey" + "inetAddr" + ] + [ + "services" + "postgrey" + "inetPort" + ] + ] + [ "services" "postgrey" "socket" ] + ( + config: + let + value = p: getAttrFromPath p config; + inetAddr = [ + "services" + "postgrey" + "inetAddr" + ]; + inetPort = [ + "services" + "postgrey" + "inetPort" + ]; + in + if value inetAddr == null then + { path = "/run/postgrey.sock"; } + else + { + addr = value inetAddr; + port = value inetPort; + } + ) + ) ]; options = { @@ -131,12 +169,12 @@ in { }; whitelistClients = mkOption { type = listOf path; - default = []; + default = [ ]; description = "Client address whitelist files (see postgrey(8))"; }; whitelistRecipients = mkOption { type = listOf path; - default = []; + default = [ ]; description = "Recipient address whitelist files (see postgrey(8))"; }; }; @@ -161,44 +199,52 @@ in { }; }; - systemd.services.postgrey = let - bind-flag = if cfg.socket ? path then - "--unix=${cfg.socket.path} --socketmode=${cfg.socket.mode}" - else - ''--inet=${optionalString (cfg.socket.addr != null) (cfg.socket.addr + ":")}${toString cfg.socket.port}''; - in { - description = "Postfix Greylisting Service"; - wantedBy = [ "multi-user.target" ]; - before = [ "postfix.service" ]; - preStart = '' - mkdir -p /var/postgrey - chown postgrey:postgrey /var/postgrey - chmod 0770 /var/postgrey - ''; - serviceConfig = { - Type = "simple"; - ExecStart = ''${pkgs.postgrey}/bin/postgrey \ - ${bind-flag} \ - --group=postgrey --user=postgrey \ - --dbdir=/var/postgrey \ - --delay=${toString cfg.delay} \ - --max-age=${toString cfg.maxAge} \ - --retry-window=${toString cfg.retryWindow} \ - ${if cfg.lookupBySubnet then "--lookup-by-subnet" else "--lookup-by-host"} \ - --ipv4cidr=${toString cfg.IPv4CIDR} --ipv6cidr=${toString cfg.IPv6CIDR} \ - ${optionalString cfg.privacy "--privacy"} \ - --auto-whitelist-clients=${toString (if cfg.autoWhitelist == null then 0 else cfg.autoWhitelist)} \ - --greylist-action=${cfg.greylistAction} \ - --greylist-text="${cfg.greylistText}" \ - --x-greylist-header="${cfg.greylistHeader}" \ - ${concatMapStringsSep " " (x: "--whitelist-clients=" + x) cfg.whitelistClients} \ - ${concatMapStringsSep " " (x: "--whitelist-recipients=" + x) cfg.whitelistRecipients} + systemd.services.postgrey = + let + bind-flag = + if cfg.socket ? path then + "--unix=${cfg.socket.path} --socketmode=${cfg.socket.mode}" + else + ''--inet=${ + optionalString (cfg.socket.addr != null) (cfg.socket.addr + ":") + }${toString cfg.socket.port}''; + in + { + description = "Postfix Greylisting Service"; + wantedBy = [ "multi-user.target" ]; + before = [ "postfix.service" ]; + preStart = '' + mkdir -p /var/postgrey + chown postgrey:postgrey /var/postgrey + chmod 0770 /var/postgrey ''; - Restart = "always"; - RestartSec = 5; - TimeoutSec = 10; + serviceConfig = { + Type = "simple"; + ExecStart = '' + ${pkgs.postgrey}/bin/postgrey \ + ${bind-flag} \ + --group=postgrey --user=postgrey \ + --dbdir=/var/postgrey \ + --delay=${toString cfg.delay} \ + --max-age=${toString cfg.maxAge} \ + --retry-window=${toString cfg.retryWindow} \ + ${if cfg.lookupBySubnet then "--lookup-by-subnet" else "--lookup-by-host"} \ + --ipv4cidr=${toString cfg.IPv4CIDR} --ipv6cidr=${toString cfg.IPv6CIDR} \ + ${optionalString cfg.privacy "--privacy"} \ + --auto-whitelist-clients=${ + toString (if cfg.autoWhitelist == null then 0 else cfg.autoWhitelist) + } \ + --greylist-action=${cfg.greylistAction} \ + --greylist-text="${cfg.greylistText}" \ + --x-greylist-header="${cfg.greylistHeader}" \ + ${concatMapStringsSep " " (x: "--whitelist-clients=" + x) cfg.whitelistClients} \ + ${concatMapStringsSep " " (x: "--whitelist-recipients=" + x) cfg.whitelistRecipients} + ''; + Restart = "always"; + RestartSec = 5; + TimeoutSec = 10; + }; }; - }; }; diff --git a/nixos/modules/services/mail/postsrsd.nix b/nixos/modules/services/mail/postsrsd.nix index f94d3942b5e3ba..3f0db2d91c0005 100644 --- a/nixos/modules/services/mail/postsrsd.nix +++ b/nixos/modules/services/mail/postsrsd.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.postsrsd; -in { +in +{ ###### interface @@ -29,7 +35,11 @@ in { }; separator = lib.mkOption { - type = lib.types.enum ["-" "=" "+"]; + type = lib.types.enum [ + "-" + "=" + "+" + ]; default = "="; description = "First separator character in generated addresses"; }; @@ -60,7 +70,7 @@ in { excludeDomains = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = "Origin domains to exclude from rewriting in addition to primary domain"; }; @@ -80,7 +90,6 @@ in { }; - ###### implementation config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/mail/public-inbox.nix b/nixos/modules/services/mail/public-inbox.nix index 1f7c8c44ace159..b1e4daa9f0e419 100644 --- a/nixos/modules/services/mail/public-inbox.nix +++ b/nixos/modules/services/mail/public-inbox.nix @@ -1,4 +1,9 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: with lib; @@ -9,13 +14,14 @@ let gitIni = pkgs.formats.gitIni { listsAsDuplicateKeys = true; }; iniAtom = gitIni.lib.types.atom; - useSpamAssassin = cfg.settings.publicinboxmda.spamcheck == "spamc" || - cfg.settings.publicinboxwatch.spamcheck == "spamc"; + useSpamAssassin = + cfg.settings.publicinboxmda.spamcheck == "spamc" + || cfg.settings.publicinboxwatch.spamcheck == "spamc"; publicInboxDaemonOptions = proto: defaultPort: { args = mkOption { type = with types; listOf str; - default = []; + default = [ ]; description = "Command-line arguments to pass to {manpage}`public-inbox-${proto}d(1)`."; }; port = mkOption { @@ -42,103 +48,116 @@ let }; }; - serviceConfig = srv: - let proto = removeSuffix "d" srv; - needNetwork = builtins.hasAttr proto cfg && cfg.${proto}.port == null; - in { - serviceConfig = { - # Enable JIT-compiled C (via Inline::C) - Environment = [ "PERL_INLINE_DIRECTORY=/run/public-inbox-${srv}/perl-inline" ]; - # NonBlocking is REQUIRED to avoid a race condition - # if running simultaneous services. - NonBlocking = true; - #LimitNOFILE = 30000; - User = config.users.users."public-inbox".name; - Group = config.users.groups."public-inbox".name; - RuntimeDirectory = [ + serviceConfig = + srv: + let + proto = removeSuffix "d" srv; + needNetwork = builtins.hasAttr proto cfg && cfg.${proto}.port == null; + in + { + serviceConfig = { + # Enable JIT-compiled C (via Inline::C) + Environment = [ "PERL_INLINE_DIRECTORY=/run/public-inbox-${srv}/perl-inline" ]; + # NonBlocking is REQUIRED to avoid a race condition + # if running simultaneous services. + NonBlocking = true; + #LimitNOFILE = 30000; + User = config.users.users."public-inbox".name; + Group = config.users.groups."public-inbox".name; + RuntimeDirectory = [ "public-inbox-${srv}/perl-inline" ]; - RuntimeDirectoryMode = "700"; - # This is for BindPaths= and BindReadOnlyPaths= - # to allow traversal of directories they create inside RootDirectory= - UMask = "0066"; - StateDirectory = ["public-inbox"]; - StateDirectoryMode = "0750"; - WorkingDirectory = stateDir; - BindReadOnlyPaths = [ - "/etc" - "/run/systemd" - "${config.i18n.glibcLocales}" - ] ++ - mapAttrsToList (name: inbox: inbox.description) cfg.inboxes ++ - # Without confinement the whole Nix store - # is made available to the service - optionals (!config.systemd.services."public-inbox-${srv}".confinement.enable) [ - "${pkgs.dash}/bin/dash:/bin/sh" - builtins.storeDir + RuntimeDirectoryMode = "700"; + # This is for BindPaths= and BindReadOnlyPaths= + # to allow traversal of directories they create inside RootDirectory= + UMask = "0066"; + StateDirectory = [ "public-inbox" ]; + StateDirectoryMode = "0750"; + WorkingDirectory = stateDir; + BindReadOnlyPaths = + [ + "/etc" + "/run/systemd" + "${config.i18n.glibcLocales}" + ] + ++ mapAttrsToList (name: inbox: inbox.description) cfg.inboxes + ++ + # Without confinement the whole Nix store + # is made available to the service + optionals (!config.systemd.services."public-inbox-${srv}".confinement.enable) [ + "${pkgs.dash}/bin/dash:/bin/sh" + builtins.storeDir + ]; + # The following options are only for optimizing: + # systemd-analyze security public-inbox-'*' + AmbientCapabilities = ""; + CapabilityBoundingSet = ""; + # ProtectClock= adds DeviceAllow=char-rtc r + DeviceAllow = ""; + LockPersonality = true; + MemoryDenyWriteExecute = true; + NoNewPrivileges = true; + PrivateNetwork = mkDefault (!needNetwork); + ProcSubset = "pid"; + ProtectClock = true; + ProtectHome = "tmpfs"; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectProc = "invisible"; + #ProtectSystem = "strict"; + RemoveIPC = true; + RestrictAddressFamilies = + [ "AF_UNIX" ] + ++ optionals needNetwork [ + "AF_INET" + "AF_INET6" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallFilter = [ + "@system-service" + "~@aio" + "~@chown" + "~@keyring" + "~@memlock" + "~@resources" + # Not removing @setuid and @privileged because Inline::C needs them. + # Not removing @timer because git upload-pack needs it. ]; - # The following options are only for optimizing: - # systemd-analyze security public-inbox-'*' - AmbientCapabilities = ""; - CapabilityBoundingSet = ""; - # ProtectClock= adds DeviceAllow=char-rtc r - DeviceAllow = ""; - LockPersonality = true; - MemoryDenyWriteExecute = true; - NoNewPrivileges = true; - PrivateNetwork = mkDefault (!needNetwork); - ProcSubset = "pid"; - ProtectClock = true; - ProtectHome = "tmpfs"; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectProc = "invisible"; - #ProtectSystem = "strict"; - RemoveIPC = true; - RestrictAddressFamilies = [ "AF_UNIX" ] ++ - optionals needNetwork [ "AF_INET" "AF_INET6" ]; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallFilter = [ - "@system-service" - "~@aio" "~@chown" "~@keyring" "~@memlock" "~@resources" - # Not removing @setuid and @privileged because Inline::C needs them. - # Not removing @timer because git upload-pack needs it. - ]; - SystemCallArchitectures = "native"; + SystemCallArchitectures = "native"; - # The following options are redundant when confinement is enabled - RootDirectory = "/var/empty"; - TemporaryFileSystem = "/"; - PrivateMounts = true; - MountAPIVFS = true; - PrivateDevices = true; - PrivateTmp = true; - PrivateUsers = true; - ProtectControlGroups = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - }; - confinement = { - # Until we agree upon doing it directly here in NixOS - # https://github.com/NixOS/nixpkgs/pull/104457#issuecomment-1115768447 - # let the user choose to enable the confinement with: - # systemd.services.public-inbox-httpd.confinement.enable = true; - # systemd.services.public-inbox-imapd.confinement.enable = true; - # systemd.services.public-inbox-init.confinement.enable = true; - # systemd.services.public-inbox-nntpd.confinement.enable = true; - #enable = true; - mode = "full-apivfs"; - # Inline::C needs a /bin/sh, and dash is enough - binSh = "${pkgs.dash}/bin/dash"; - packages = [ + # The following options are redundant when confinement is enabled + RootDirectory = "/var/empty"; + TemporaryFileSystem = "/"; + PrivateMounts = true; + MountAPIVFS = true; + PrivateDevices = true; + PrivateTmp = true; + PrivateUsers = true; + ProtectControlGroups = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + }; + confinement = { + # Until we agree upon doing it directly here in NixOS + # https://github.com/NixOS/nixpkgs/pull/104457#issuecomment-1115768447 + # let the user choose to enable the confinement with: + # systemd.services.public-inbox-httpd.confinement.enable = true; + # systemd.services.public-inbox-imapd.confinement.enable = true; + # systemd.services.public-inbox-init.confinement.enable = true; + # systemd.services.public-inbox-nntpd.confinement.enable = true; + #enable = true; + mode = "full-apivfs"; + # Inline::C needs a /bin/sh, and dash is enough + binSh = "${pkgs.dash}/bin/dash"; + packages = [ pkgs.iana-etc (getLib pkgs.nss) pkgs.tzdata ]; + }; }; - }; in { @@ -147,7 +166,7 @@ in package = mkPackageOption pkgs "public-inbox" { }; path = mkOption { type = with types; listOf package; - default = []; + default = [ ]; example = literalExpression "with pkgs; [ spamassassin ]"; description = '' Additional packages to place in the path of public-inbox-mda, @@ -158,58 +177,63 @@ in description = '' Inboxes to configure, where attribute names are inbox names. ''; - default = {}; - type = types.attrsOf (types.submodule ({name, ...}: { - freeformType = types.attrsOf iniAtom; - options.inboxdir = mkOption { - type = types.str; - default = "${stateDir}/inboxes/${name}"; - description = "The absolute path to the directory which hosts the public-inbox."; - }; - options.address = mkOption { - type = with types; listOf str; - example = "example-discuss@example.org"; - description = "The email addresses of the public-inbox."; - }; - options.url = mkOption { - type = types.nonEmptyStr; - example = "https://example.org/lists/example-discuss"; - description = "URL where this inbox can be accessed over HTTP."; - }; - options.description = mkOption { - type = types.str; - example = "user/dev discussion of public-inbox itself"; - description = "User-visible description for the repository."; - apply = pkgs.writeText "public-inbox-description-${name}"; - }; - options.newsgroup = mkOption { - type = with types; nullOr str; - default = null; - description = "NNTP group name for the inbox."; - }; - options.watch = mkOption { - type = with types; listOf str; - default = []; - description = "Paths for {manpage}`public-inbox-watch(1)` to monitor for new mail."; - example = [ "maildir:/path/to/test.example.com.git" ]; - }; - options.watchheader = mkOption { - type = with types; nullOr str; - default = null; - example = "List-Id:"; - description = '' - If specified, {manpage}`public-inbox-watch(1)` will only process - mail containing a matching header. - ''; - }; - options.coderepo = mkOption { - type = (types.listOf (types.enum (attrNames cfg.settings.coderepo))) // { - description = "list of coderepo names"; - }; - default = []; - description = "Nicknames of a 'coderepo' section associated with the inbox."; - }; - })); + default = { }; + type = types.attrsOf ( + types.submodule ( + { name, ... }: + { + freeformType = types.attrsOf iniAtom; + options.inboxdir = mkOption { + type = types.str; + default = "${stateDir}/inboxes/${name}"; + description = "The absolute path to the directory which hosts the public-inbox."; + }; + options.address = mkOption { + type = with types; listOf str; + example = "example-discuss@example.org"; + description = "The email addresses of the public-inbox."; + }; + options.url = mkOption { + type = types.nonEmptyStr; + example = "https://example.org/lists/example-discuss"; + description = "URL where this inbox can be accessed over HTTP."; + }; + options.description = mkOption { + type = types.str; + example = "user/dev discussion of public-inbox itself"; + description = "User-visible description for the repository."; + apply = pkgs.writeText "public-inbox-description-${name}"; + }; + options.newsgroup = mkOption { + type = with types; nullOr str; + default = null; + description = "NNTP group name for the inbox."; + }; + options.watch = mkOption { + type = with types; listOf str; + default = [ ]; + description = "Paths for {manpage}`public-inbox-watch(1)` to monitor for new mail."; + example = [ "maildir:/path/to/test.example.com.git" ]; + }; + options.watchheader = mkOption { + type = with types; nullOr str; + default = null; + example = "List-Id:"; + description = '' + If specified, {manpage}`public-inbox-watch(1)` will only process + mail containing a matching header. + ''; + }; + options.coderepo = mkOption { + type = (types.listOf (types.enum (attrNames cfg.settings.coderepo))) // { + description = "list of coderepo names"; + }; + default = [ ]; + description = "Nicknames of a 'coderepo' section associated with the inbox."; + }; + } + ) + ); }; imap = { enable = mkEnableOption "the public-inbox IMAP server"; @@ -244,7 +268,7 @@ in enable = mkEnableOption "the public-inbox Mail Delivery Agent"; args = mkOption { type = with types; listOf str; - default = []; + default = [ ]; description = "Command-line arguments to pass to {manpage}`public-inbox-mda(1)`."; }; }; @@ -262,42 +286,56 @@ in description = '' Settings for the [public-inbox config file](https://public-inbox.org/public-inbox-config.html). ''; - default = {}; + default = { }; type = types.submodule { freeformType = gitIni.type; options.publicinbox = mkOption { - default = {}; + default = { }; description = "public inboxes"; type = types.submodule { # Support both global options like `services.public-inbox.settings.publicinbox.imapserver` # and inbox specific options like `services.public-inbox.settings.publicinbox.foo.address`. - freeformType = with types; attrsOf (oneOf [ iniAtom (attrsOf iniAtom) ]); + freeformType = + with types; + attrsOf (oneOf [ + iniAtom + (attrsOf iniAtom) + ]); options.css = mkOption { type = with types; listOf str; - default = []; + default = [ ]; description = "The local path name of a CSS file for the PSGI web interface."; }; options.imapserver = mkOption { type = with types; listOf str; - default = []; + default = [ ]; example = [ "imap.public-inbox.org" ]; description = "IMAP URLs to this public-inbox instance"; }; options.nntpserver = mkOption { type = with types; listOf str; - default = []; - example = [ "nntp://news.public-inbox.org" "nntps://news.public-inbox.org" ]; + default = [ ]; + example = [ + "nntp://news.public-inbox.org" + "nntps://news.public-inbox.org" + ]; description = "NNTP URLs to this public-inbox instance"; }; options.pop3server = mkOption { type = with types; listOf str; - default = []; + default = [ ]; example = [ "pop.public-inbox.org" ]; description = "POP3 URLs to this public-inbox instance"; }; options.wwwlisting = mkOption { - type = with types; enum [ "all" "404" "match=domain" ]; + type = + with types; + enum [ + "all" + "404" + "match=domain" + ]; default = "404"; description = '' Controls which lists (if any) are listed for when the root @@ -307,7 +345,12 @@ in }; }; options.publicinboxmda.spamcheck = mkOption { - type = with types; enum [ "spamc" "none" ]; + type = + with types; + enum [ + "spamc" + "none" + ]; default = "none"; description = '' If set to spamc, {manpage}`public-inbox-watch(1)` will filter spam @@ -315,7 +358,12 @@ in ''; }; options.publicinboxwatch.spamcheck = mkOption { - type = with types; enum [ "spamc" "none" ]; + type = + with types; + enum [ + "spamc" + "none" + ]; default = "none"; description = '' If set to spamc, {manpage}`public-inbox-watch(1)` will filter spam @@ -332,19 +380,21 @@ in ''; }; options.coderepo = mkOption { - default = {}; + default = { }; description = "code repositories"; - type = types.attrsOf (types.submodule { - freeformType = types.attrsOf iniAtom; - options.cgitUrl = mkOption { - type = types.str; - description = "URL of a cgit instance"; - }; - options.dir = mkOption { - type = types.str; - description = "Path to a git repository"; - }; - }); + type = types.attrsOf ( + types.submodule { + freeformType = types.attrsOf iniAtom; + options.cgitUrl = mkOption { + type = types.str; + description = "URL of a cgit instance"; + }; + options.dir = mkOption { + type = types.str; + description = "Path to a git repository"; + }; + } + ); }; }; }; @@ -352,7 +402,8 @@ in }; config = mkIf cfg.enable { assertions = [ - { assertion = config.services.spamassassin.enable || !useSpamAssassin; + { + assertion = config.services.spamassassin.enable || !useSpamAssassin; message = '' public-inbox is configured to use SpamAssassin, but services.spamassassin.enable is false. If you don't need @@ -360,7 +411,8 @@ in `services.public-inbox.settings.publicinboxwatch.spamcheck' to null. ''; } - { assertion = cfg.path != [] || !useSpamAssassin; + { + assertion = cfg.path != [ ] || !useSpamAssassin; message = '' public-inbox is configured to use SpamAssassin, but there is no spamc executable in services.public-inbox.path. If you @@ -370,9 +422,8 @@ in ''; } ]; - services.public-inbox.settings = - filterAttrsRecursive (n: v: v != null) { - publicinbox = mapAttrs (n: filterAttrs (n: v: n != "description")) cfg.inboxes; + services.public-inbox.settings = filterAttrsRecursive (n: v: v != null) { + publicinbox = mapAttrs (n: filterAttrs (n: v: n != "description")) cfg.inboxes; }; users = { users.public-inbox = { @@ -380,32 +431,36 @@ in group = "public-inbox"; isSystemUser = true; }; - groups.public-inbox = {}; + groups.public-inbox = { }; + }; + networking.firewall = mkIf cfg.openFirewall { + allowedTCPPorts = mkMerge ( + map + (proto: (mkIf (cfg.${proto}.enable && types.port.check cfg.${proto}.port) [ cfg.${proto}.port ])) + [ + "imap" + "http" + "nntp" + ] + ); }; - networking.firewall = mkIf cfg.openFirewall - { allowedTCPPorts = mkMerge - (map (proto: (mkIf (cfg.${proto}.enable && types.port.check cfg.${proto}.port) [ cfg.${proto}.port ])) - ["imap" "http" "nntp"]); - }; services.postfix = mkIf (cfg.postfix.enable && cfg.mda.enable) { # Not sure limiting to 1 is necessary, but better safe than sorry. config.public-inbox_destination_recipient_limit = "1"; # Register the addresses as existing - virtual = - concatStringsSep "\n" (mapAttrsToList (_: inbox: - concatMapStringsSep "\n" (address: - "${address} ${address}" - ) inbox.address - ) cfg.inboxes); + virtual = concatStringsSep "\n" ( + mapAttrsToList ( + _: inbox: concatMapStringsSep "\n" (address: "${address} ${address}") inbox.address + ) cfg.inboxes + ); # Deliver the addresses with the public-inbox transport - transport = - concatStringsSep "\n" (mapAttrsToList (_: inbox: - concatMapStringsSep "\n" (address: - "${address} public-inbox:${address}" - ) inbox.address - ) cfg.inboxes); + transport = concatStringsSep "\n" ( + mapAttrsToList ( + _: inbox: concatMapStringsSep "\n" (address: "${address} public-inbox:${address}") inbox.address + ) cfg.inboxes + ); # The public-inbox transport masterConfig.public-inbox = { @@ -427,153 +482,224 @@ in ]; }; }; - systemd.sockets = mkMerge (map (proto: - mkIf (cfg.${proto}.enable && cfg.${proto}.port != null) - { "public-inbox-${proto}d" = { - listenStreams = [ (toString cfg.${proto}.port) ]; - wantedBy = [ "sockets.target" ]; - }; - } - ) [ "imap" "http" "nntp" ]); + systemd.sockets = mkMerge ( + map + ( + proto: + mkIf (cfg.${proto}.enable && cfg.${proto}.port != null) { + "public-inbox-${proto}d" = { + listenStreams = [ (toString cfg.${proto}.port) ]; + wantedBy = [ "sockets.target" ]; + }; + } + ) + [ + "imap" + "http" + "nntp" + ] + ); systemd.services = mkMerge [ - (mkIf cfg.imap.enable - { public-inbox-imapd = mkMerge [(serviceConfig "imapd") { - after = [ "public-inbox-init.service" "public-inbox-watch.service" ]; - requires = [ "public-inbox-init.service" ]; - serviceConfig = { - ExecStart = escapeShellArgs ( - [ "${cfg.package}/bin/public-inbox-imapd" ] ++ - cfg.imap.args ++ - optionals (cfg.imap.cert != null) [ "--cert" cfg.imap.cert ] ++ - optionals (cfg.imap.key != null) [ "--key" cfg.imap.key ] - ); - }; - }]; + (mkIf cfg.imap.enable { + public-inbox-imapd = mkMerge [ + (serviceConfig "imapd") + { + after = [ + "public-inbox-init.service" + "public-inbox-watch.service" + ]; + requires = [ "public-inbox-init.service" ]; + serviceConfig = { + ExecStart = escapeShellArgs ( + [ "${cfg.package}/bin/public-inbox-imapd" ] + ++ cfg.imap.args + ++ optionals (cfg.imap.cert != null) [ + "--cert" + cfg.imap.cert + ] + ++ optionals (cfg.imap.key != null) [ + "--key" + cfg.imap.key + ] + ); + }; + } + ]; }) - (mkIf cfg.http.enable - { public-inbox-httpd = mkMerge [(serviceConfig "httpd") { - after = [ "public-inbox-init.service" "public-inbox-watch.service" ]; - requires = [ "public-inbox-init.service" ]; - serviceConfig = { - BindReadOnlyPaths = - map (c: c.dir) (lib.attrValues cfg.settings.coderepo); - ExecStart = escapeShellArgs ( - [ "${cfg.package}/bin/public-inbox-httpd" ] ++ - cfg.http.args ++ - # See https://public-inbox.org/public-inbox.git/tree/examples/public-inbox.psgi - # for upstream's example. - [ (pkgs.writeText "public-inbox.psgi" '' - #!${cfg.package.fullperl} -w - use strict; - use warnings; - use Plack::Builder; - use PublicInbox::WWW; + (mkIf cfg.http.enable { + public-inbox-httpd = mkMerge [ + (serviceConfig "httpd") + { + after = [ + "public-inbox-init.service" + "public-inbox-watch.service" + ]; + requires = [ "public-inbox-init.service" ]; + serviceConfig = { + BindReadOnlyPaths = map (c: c.dir) (lib.attrValues cfg.settings.coderepo); + ExecStart = escapeShellArgs ( + [ "${cfg.package}/bin/public-inbox-httpd" ] + ++ cfg.http.args + ++ + # See https://public-inbox.org/public-inbox.git/tree/examples/public-inbox.psgi + # for upstream's example. + [ + (pkgs.writeText "public-inbox.psgi" '' + #!${cfg.package.fullperl} -w + use strict; + use warnings; + use Plack::Builder; + use PublicInbox::WWW; - my $www = PublicInbox::WWW->new; - $www->preload; + my $www = PublicInbox::WWW->new; + $www->preload; - builder { - # If reached through a reverse proxy, - # make it transparent by resetting some HTTP headers - # used by public-inbox to generate URIs. - enable 'ReverseProxy'; + builder { + # If reached through a reverse proxy, + # make it transparent by resetting some HTTP headers + # used by public-inbox to generate URIs. + enable 'ReverseProxy'; - # No need to send a response body if it's an HTTP HEAD requests. - enable 'Head'; + # No need to send a response body if it's an HTTP HEAD requests. + enable 'Head'; - # Route according to configured domains and root paths. - ${concatMapStrings (path: '' - mount q(${path}) => sub { $www->call(@_); }; - '') cfg.http.mounts} - } - '') ] - ); - }; - }]; - }) - (mkIf cfg.nntp.enable - { public-inbox-nntpd = mkMerge [(serviceConfig "nntpd") { - after = [ "public-inbox-init.service" "public-inbox-watch.service" ]; - requires = [ "public-inbox-init.service" ]; - serviceConfig = { - ExecStart = escapeShellArgs ( - [ "${cfg.package}/bin/public-inbox-nntpd" ] ++ - cfg.nntp.args ++ - optionals (cfg.nntp.cert != null) [ "--cert" cfg.nntp.cert ] ++ - optionals (cfg.nntp.key != null) [ "--key" cfg.nntp.key ] - ); - }; - }]; + # Route according to configured domains and root paths. + ${concatMapStrings (path: '' + mount q(${path}) => sub { $www->call(@_); }; + '') cfg.http.mounts} + } + '') + ] + ); + }; + } + ]; }) - (mkIf (any (inbox: inbox.watch != []) (attrValues cfg.inboxes) - || cfg.settings.publicinboxwatch.watchspam != null) - { public-inbox-watch = mkMerge [(serviceConfig "watch") { - inherit (cfg) path; - wants = [ "public-inbox-init.service" ]; - requires = [ "public-inbox-init.service" ] ++ - optional (cfg.settings.publicinboxwatch.spamcheck == "spamc") "spamassassin.service"; - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - ExecStart = "${cfg.package}/bin/public-inbox-watch"; - ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - }; - }]; + (mkIf cfg.nntp.enable { + public-inbox-nntpd = mkMerge [ + (serviceConfig "nntpd") + { + after = [ + "public-inbox-init.service" + "public-inbox-watch.service" + ]; + requires = [ "public-inbox-init.service" ]; + serviceConfig = { + ExecStart = escapeShellArgs ( + [ "${cfg.package}/bin/public-inbox-nntpd" ] + ++ cfg.nntp.args + ++ optionals (cfg.nntp.cert != null) [ + "--cert" + cfg.nntp.cert + ] + ++ optionals (cfg.nntp.key != null) [ + "--key" + cfg.nntp.key + ] + ); + }; + } + ]; }) - ({ public-inbox-init = let - PI_CONFIG = gitIni.generate "public-inbox.ini" - (filterAttrsRecursive (n: v: v != null) cfg.settings); - in mkMerge [(serviceConfig "init") { - wantedBy = [ "multi-user.target" ]; - restartIfChanged = true; - restartTriggers = [ PI_CONFIG ]; - script = '' - set -ux - install -D -p ${PI_CONFIG} ${stateDir}/.public-inbox/config - '' + optionalString useSpamAssassin '' - install -m 0700 -o spamd -d ${stateDir}/.spamassassin - ${optionalString (cfg.spamAssassinRules != null) '' - ln -sf ${cfg.spamAssassinRules} ${stateDir}/.spamassassin/user_prefs - ''} - '' + concatStrings (mapAttrsToList (name: inbox: '' - if [ ! -e ${stateDir}/inboxes/${escapeShellArg name} ]; then - # public-inbox-init creates an inbox and adds it to a config file. - # It tries to atomically write the config file by creating - # another file in the same directory, and renaming it. - # This has the sad consequence that we can't use - # /dev/null, or it would try to create a file in /dev. - conf_dir="$(mktemp -d)" + (mkIf + ( + any (inbox: inbox.watch != [ ]) (attrValues cfg.inboxes) + || cfg.settings.publicinboxwatch.watchspam != null + ) + { + public-inbox-watch = mkMerge [ + (serviceConfig "watch") + { + inherit (cfg) path; + wants = [ "public-inbox-init.service" ]; + requires = [ + "public-inbox-init.service" + ] ++ optional (cfg.settings.publicinboxwatch.spamcheck == "spamc") "spamassassin.service"; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + ExecStart = "${cfg.package}/bin/public-inbox-watch"; + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + }; + } + ]; + } + ) + ({ + public-inbox-init = + let + PI_CONFIG = gitIni.generate "public-inbox.ini" ( + filterAttrsRecursive (n: v: v != null) cfg.settings + ); + in + mkMerge [ + (serviceConfig "init") + { + wantedBy = [ "multi-user.target" ]; + restartIfChanged = true; + restartTriggers = [ PI_CONFIG ]; + script = + '' + set -ux + install -D -p ${PI_CONFIG} ${stateDir}/.public-inbox/config + '' + + optionalString useSpamAssassin '' + install -m 0700 -o spamd -d ${stateDir}/.spamassassin + ${optionalString (cfg.spamAssassinRules != null) '' + ln -sf ${cfg.spamAssassinRules} ${stateDir}/.spamassassin/user_prefs + ''} + '' + + concatStrings ( + mapAttrsToList (name: inbox: '' + if [ ! -e ${stateDir}/inboxes/${escapeShellArg name} ]; then + # public-inbox-init creates an inbox and adds it to a config file. + # It tries to atomically write the config file by creating + # another file in the same directory, and renaming it. + # This has the sad consequence that we can't use + # /dev/null, or it would try to create a file in /dev. + conf_dir="$(mktemp -d)" - PI_CONFIG=$conf_dir/conf \ - ${cfg.package}/bin/public-inbox-init -V2 \ - ${escapeShellArgs ([ name "${stateDir}/inboxes/${name}" inbox.url ] ++ inbox.address)} + PI_CONFIG=$conf_dir/conf \ + ${cfg.package}/bin/public-inbox-init -V2 \ + ${escapeShellArgs ( + [ + name + "${stateDir}/inboxes/${name}" + inbox.url + ] + ++ inbox.address + )} - rm -rf $conf_dir - fi + rm -rf $conf_dir + fi - ln -sf ${inbox.description} \ - ${stateDir}/inboxes/${escapeShellArg name}/description + ln -sf ${inbox.description} \ + ${stateDir}/inboxes/${escapeShellArg name}/description - export GIT_DIR=${stateDir}/inboxes/${escapeShellArg name}/all.git - if test -d "$GIT_DIR"; then - # Config is inherited by each epoch repository, - # so just needs to be set for all.git. - ${pkgs.git}/bin/git config core.sharedRepository 0640 - fi - '') cfg.inboxes - ); - serviceConfig = { - Type = "oneshot"; - RemainAfterExit = true; - StateDirectory = [ - "public-inbox/.public-inbox" - "public-inbox/.public-inbox/emergency" - "public-inbox/inboxes" - ]; - }; - }]; + export GIT_DIR=${stateDir}/inboxes/${escapeShellArg name}/all.git + if test -d "$GIT_DIR"; then + # Config is inherited by each epoch repository, + # so just needs to be set for all.git. + ${pkgs.git}/bin/git config core.sharedRepository 0640 + fi + '') cfg.inboxes + ); + serviceConfig = { + Type = "oneshot"; + RemainAfterExit = true; + StateDirectory = [ + "public-inbox/.public-inbox" + "public-inbox/.public-inbox/emergency" + "public-inbox/inboxes" + ]; + }; + } + ]; }) ]; environment.systemPackages = with pkgs; [ cfg.package ]; }; - meta.maintainers = with lib.maintainers; [ julm qyliss ]; + meta.maintainers = with lib.maintainers; [ + julm + qyliss + ]; } diff --git a/nixos/modules/services/mail/roundcube.nix b/nixos/modules/services/mail/roundcube.nix index 337734488e314e..7cb723e3172c57 100644 --- a/nixos/modules/services/mail/roundcube.nix +++ b/nixos/modules/services/mail/roundcube.nix @@ -1,4 +1,9 @@ -{ lib, config, pkgs, ... }: +{ + lib, + config, + pkgs, + ... +}: let cfg = config.services.roundcube; fpm = config.services.phpfpm.pools.roundcube; @@ -77,7 +82,7 @@ in plugins = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' List of roundcube plugins to enable. Currently, only those directly shipped with Roundcube are supported. ''; @@ -85,7 +90,7 @@ in dicts = lib.mkOption { type = lib.types.listOf lib.types.package; - default = []; + default = [ ]; example = lib.literalExpression "with pkgs.aspellDicts; [ en fr de ]"; description = '' List of aspell dictionaries for spell checking. If empty, spell checking is disabled. @@ -123,8 +128,12 @@ in config = lib.mkIf cfg.enable { # backward compatibility: if password is set but not passwordFile, make one. - services.roundcube.database.passwordFile = lib.mkIf (!localDB && cfg.database.password != "") (lib.mkDefault ("${pkgs.writeText "roundcube-password" cfg.database.password}")); - warnings = lib.optional (!localDB && cfg.database.password != "") "services.roundcube.database.password is deprecated and insecure; use services.roundcube.database.passwordFile instead"; + services.roundcube.database.passwordFile = lib.mkIf (!localDB && cfg.database.password != "") ( + lib.mkDefault ("${pkgs.writeText "roundcube-password" cfg.database.password}") + ); + warnings = + lib.optional (!localDB && cfg.database.password != "") + "services.roundcube.database.password is deprecated and insecure; use services.roundcube.database.passwordFile instead"; environment.etc."roundcube/config.inc.php".text = '' '${dict.fullName}'") cfg.dicts}); + $config['spellcheck_languages'] = array(${ + lib.concatMapStringsSep ", " ( + dict: + let + p = builtins.parseDrvName dict.shortName; + in + "'${p.name}' => '${dict.fullName}'" + ) cfg.dicts + }); ${cfg.extraConfig} ''; @@ -174,12 +193,13 @@ in return 404; ''; }; - locations."~ ^/(CHANGELOG.md|INSTALL|LICENSE|README.md|SECURITY.md|UPGRADING|composer.json|composer.lock)" = { - priority = 3120; - extraConfig = '' - return 404; - ''; - }; + locations."~ ^/(CHANGELOG.md|INSTALL|LICENSE|README.md|SECURITY.md|UPGRADING|composer.json|composer.lock)" = + { + priority = 3120; + extraConfig = '' + return 404; + ''; + }; locations."~* \\.php(/|$)" = { priority = 3130; extraConfig = '' @@ -206,10 +226,12 @@ in services.postgresql = lib.mkIf localDB { enable = true; ensureDatabases = [ cfg.database.dbname ]; - ensureUsers = [ { - name = cfg.database.username; - ensureDBOwnership = true; - } ]; + ensureUsers = [ + { + name = cfg.database.username; + ensureDBOwnership = true; + } + ]; }; users.users.${user} = lib.mkIf localDB { @@ -217,7 +239,7 @@ in isSystemUser = true; createHome = false; }; - users.groups.${user} = lib.mkIf localDB {}; + users.groups.${user} = lib.mkIf localDB { }; services.phpfpm.pools.roundcube = { user = if localDB then user else "nginx"; @@ -260,24 +282,27 @@ in wantedBy = [ "multi-user.target" ]; path = [ config.services.postgresql.package ]; - script = let - psql = "${lib.optionalString (!localDB) "PGPASSFILE=${cfg.database.passwordFile}"} psql ${lib.optionalString (!localDB) "-h ${cfg.database.host} -U ${cfg.database.username} "} ${cfg.database.dbname}"; - in - '' - version="$(${psql} -t <<< "select value from system where name = 'roundcube-version';" || true)" - if ! (grep -E '[a-zA-Z0-9]' <<< "$version"); then - ${psql} -f ${cfg.package}/SQL/postgres.initial.sql - fi + script = + let + psql = "${lib.optionalString (!localDB) "PGPASSFILE=${cfg.database.passwordFile}"} psql ${ + lib.optionalString (!localDB) "-h ${cfg.database.host} -U ${cfg.database.username} " + } ${cfg.database.dbname}"; + in + '' + version="$(${psql} -t <<< "select value from system where name = 'roundcube-version';" || true)" + if ! (grep -E '[a-zA-Z0-9]' <<< "$version"); then + ${psql} -f ${cfg.package}/SQL/postgres.initial.sql + fi - if [ ! -f /var/lib/roundcube/des_key ]; then - base64 /dev/urandom | head -c 24 > /var/lib/roundcube/des_key; - # we need to log out everyone in case change the des_key - # from the default when upgrading from nixos 19.09 - ${psql} <<< 'TRUNCATE TABLE session;' - fi + if [ ! -f /var/lib/roundcube/des_key ]; then + base64 /dev/urandom | head -c 24 > /var/lib/roundcube/des_key; + # we need to log out everyone in case change the des_key + # from the default when upgrading from nixos 19.09 + ${psql} <<< 'TRUNCATE TABLE session;' + fi - ${phpWithPspell}/bin/php ${cfg.package}/bin/update.sh - ''; + ${phpWithPspell}/bin/php ${cfg.package}/bin/update.sh + ''; serviceConfig = { Type = "oneshot"; StateDirectory = "roundcube"; diff --git a/nixos/modules/services/mail/rspamd-trainer.nix b/nixos/modules/services/mail/rspamd-trainer.nix index 11c4363cc1d583..14d35e3da340ed 100644 --- a/nixos/modules/services/mail/rspamd-trainer.nix +++ b/nixos/modules/services/mail/rspamd-trainer.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.rspamd-trainer; format = pkgs.formats.toml { }; -in { +in +{ options.services.rspamd-trainer = { enable = lib.mkEnableOption "Spam/ham trainer for rspamd"; @@ -51,7 +57,7 @@ in { Type = "oneshot"; DynamicUser = true; EnvironmentFile = [ - ( format.generate "rspamd-trainer-env" cfg.settings ) + (format.generate "rspamd-trainer-env" cfg.settings) cfg.secrets ]; }; diff --git a/nixos/modules/services/mail/rspamd.nix b/nixos/modules/services/mail/rspamd.nix index c61ddcac954ad5..323339af97e92a 100644 --- a/nixos/modules/services/mail/rspamd.nix +++ b/nixos/modules/services/mail/rspamd.nix @@ -1,4 +1,10 @@ -{ config, options, pkgs, lib, ... }: +{ + config, + options, + pkgs, + lib, + ... +}: with lib; @@ -8,213 +14,285 @@ let opt = options.services.rspamd; postfixCfg = config.services.postfix; - bindSocketOpts = {options, config, ... }: { - options = { - socket = mkOption { - type = types.str; - example = "localhost:11333"; - description = '' - Socket for this worker to listen on in a format acceptable by rspamd. - ''; - }; - mode = mkOption { - type = types.str; - default = "0644"; - description = "Mode to set on unix socket"; - }; - owner = mkOption { - type = types.str; - default = "${cfg.user}"; - description = "Owner to set on unix socket"; - }; - group = mkOption { - type = types.str; - default = "${cfg.group}"; - description = "Group to set on unix socket"; - }; - rawEntry = mkOption { - type = types.str; - internal = true; + bindSocketOpts = + { options, config, ... }: + { + options = { + socket = mkOption { + type = types.str; + example = "localhost:11333"; + description = '' + Socket for this worker to listen on in a format acceptable by rspamd. + ''; + }; + mode = mkOption { + type = types.str; + default = "0644"; + description = "Mode to set on unix socket"; + }; + owner = mkOption { + type = types.str; + default = "${cfg.user}"; + description = "Owner to set on unix socket"; + }; + group = mkOption { + type = types.str; + default = "${cfg.group}"; + description = "Group to set on unix socket"; + }; + rawEntry = mkOption { + type = types.str; + internal = true; + }; }; + config.rawEntry = + let + maybeOption = option: optionalString options.${option}.isDefined " ${option}=${config.${option}}"; + in + if (!(hasPrefix "/" config.socket)) then + "${config.socket}" + else + "${config.socket}${maybeOption "mode"}${maybeOption "owner"}${maybeOption "group"}"; }; - config.rawEntry = let - maybeOption = option: - optionalString options.${option}.isDefined " ${option}=${config.${option}}"; - in - if (!(hasPrefix "/" config.socket)) then "${config.socket}" - else "${config.socket}${maybeOption "mode"}${maybeOption "owner"}${maybeOption "group"}"; - }; traceWarning = w: x: builtins.trace "warning: ${w}" x; - workerOpts = { name, options, ... }: { - options = { - enable = mkOption { - type = types.nullOr types.bool; - default = null; - description = "Whether to run the rspamd worker."; - }; - name = mkOption { - type = types.nullOr types.str; - default = name; - description = "Name of the worker"; - }; - type = mkOption { - type = types.nullOr (types.enum [ - "normal" "controller" "fuzzy" "rspamd_proxy" "lua" "proxy" - ]); - description = '' - The type of this worker. The type `proxy` is - deprecated and only kept for backwards compatibility and should be - replaced with `rspamd_proxy`. - ''; - apply = let - from = "services.rspamd.workers.\"${name}\".type"; - files = options.type.files; - warning = "The option `${from}` defined in ${showFiles files} has enum value `proxy` which has been renamed to `rspamd_proxy`"; - in x: if x == "proxy" then traceWarning warning "rspamd_proxy" else x; - }; - bindSockets = mkOption { - type = types.listOf (types.either types.str (types.submodule bindSocketOpts)); - default = []; - description = '' - List of sockets to listen, in format acceptable by rspamd - ''; - example = [{ - socket = "/run/rspamd.sock"; - mode = "0666"; - owner = "rspamd"; - } "*:11333"]; - apply = value: map (each: if (isString each) - then if (isUnixSocket each) - then {socket = each; owner = cfg.user; group = cfg.group; mode = "0644"; rawEntry = "${each}";} - else {socket = each; rawEntry = "${each}";} - else each) value; - }; - count = mkOption { - type = types.nullOr types.int; - default = null; - description = '' - Number of worker instances to run - ''; - }; - includes = mkOption { - type = types.listOf types.str; - default = []; - description = '' - List of files to include in configuration - ''; - }; - extraConfig = mkOption { - type = types.lines; - default = ""; - description = "Additional entries to put verbatim into worker section of rspamd config file."; + workerOpts = + { name, options, ... }: + { + options = { + enable = mkOption { + type = types.nullOr types.bool; + default = null; + description = "Whether to run the rspamd worker."; + }; + name = mkOption { + type = types.nullOr types.str; + default = name; + description = "Name of the worker"; + }; + type = mkOption { + type = types.nullOr ( + types.enum [ + "normal" + "controller" + "fuzzy" + "rspamd_proxy" + "lua" + "proxy" + ] + ); + description = '' + The type of this worker. The type `proxy` is + deprecated and only kept for backwards compatibility and should be + replaced with `rspamd_proxy`. + ''; + apply = + let + from = "services.rspamd.workers.\"${name}\".type"; + files = options.type.files; + warning = "The option `${from}` defined in ${showFiles files} has enum value `proxy` which has been renamed to `rspamd_proxy`"; + in + x: if x == "proxy" then traceWarning warning "rspamd_proxy" else x; + }; + bindSockets = mkOption { + type = types.listOf (types.either types.str (types.submodule bindSocketOpts)); + default = [ ]; + description = '' + List of sockets to listen, in format acceptable by rspamd + ''; + example = [ + { + socket = "/run/rspamd.sock"; + mode = "0666"; + owner = "rspamd"; + } + "*:11333" + ]; + apply = + value: + map ( + each: + if (isString each) then + if (isUnixSocket each) then + { + socket = each; + owner = cfg.user; + group = cfg.group; + mode = "0644"; + rawEntry = "${each}"; + } + else + { + socket = each; + rawEntry = "${each}"; + } + else + each + ) value; + }; + count = mkOption { + type = types.nullOr types.int; + default = null; + description = '' + Number of worker instances to run + ''; + }; + includes = mkOption { + type = types.listOf types.str; + default = [ ]; + description = '' + List of files to include in configuration + ''; + }; + extraConfig = mkOption { + type = types.lines; + default = ""; + description = "Additional entries to put verbatim into worker section of rspamd config file."; + }; }; - }; - config = mkIf (name == "normal" || name == "controller" || name == "fuzzy" || name == "rspamd_proxy") { - type = mkDefault name; - includes = mkDefault [ "$CONFDIR/worker-${if name == "rspamd_proxy" then "proxy" else name}.inc" ]; - bindSockets = - let - unixSocket = name: { - mode = "0660"; - socket = "/run/rspamd/${name}.sock"; - owner = cfg.user; - group = cfg.group; + config = + mkIf (name == "normal" || name == "controller" || name == "fuzzy" || name == "rspamd_proxy") + { + type = mkDefault name; + includes = mkDefault [ "$CONFDIR/worker-${if name == "rspamd_proxy" then "proxy" else name}.inc" ]; + bindSockets = + let + unixSocket = name: { + mode = "0660"; + socket = "/run/rspamd/${name}.sock"; + owner = cfg.user; + group = cfg.group; + }; + in + mkDefault ( + if name == "normal" then + [ (unixSocket "rspamd") ] + else if name == "controller" then + [ "localhost:11334" ] + else if name == "rspamd_proxy" then + [ (unixSocket "proxy") ] + else + [ ] + ); }; - in mkDefault (if name == "normal" then [(unixSocket "rspamd")] - else if name == "controller" then [ "localhost:11334" ] - else if name == "rspamd_proxy" then [ (unixSocket "proxy") ] - else [] ); }; - }; isUnixSocket = socket: hasPrefix "/" (if (isString socket) then socket else socket.socket); - mkBindSockets = enabled: socks: concatStringsSep "\n " - (flatten (map (each: "bind_socket = \"${each.rawEntry}\";") socks)); - - rspamdConfFile = pkgs.writeText "rspamd.conf" - '' - .include "$CONFDIR/common.conf" - - options { - pidfile = "$RUNDIR/rspamd.pid"; - .include "$CONFDIR/options.inc" - .include(try=true; priority=1,duplicate=merge) "$LOCAL_CONFDIR/local.d/options.inc" - .include(try=true; priority=10) "$LOCAL_CONFDIR/override.d/options.inc" - } - - logging { - type = "syslog"; - .include "$CONFDIR/logging.inc" - .include(try=true; priority=1,duplicate=merge) "$LOCAL_CONFDIR/local.d/logging.inc" - .include(try=true; priority=10) "$LOCAL_CONFDIR/override.d/logging.inc" - } - - ${concatStringsSep "\n" (mapAttrsToList (name: value: let + mkBindSockets = + enabled: socks: + concatStringsSep "\n " (flatten (map (each: "bind_socket = \"${each.rawEntry}\";") socks)); + + rspamdConfFile = pkgs.writeText "rspamd.conf" '' + .include "$CONFDIR/common.conf" + + options { + pidfile = "$RUNDIR/rspamd.pid"; + .include "$CONFDIR/options.inc" + .include(try=true; priority=1,duplicate=merge) "$LOCAL_CONFDIR/local.d/options.inc" + .include(try=true; priority=10) "$LOCAL_CONFDIR/override.d/options.inc" + } + + logging { + type = "syslog"; + .include "$CONFDIR/logging.inc" + .include(try=true; priority=1,duplicate=merge) "$LOCAL_CONFDIR/local.d/logging.inc" + .include(try=true; priority=10) "$LOCAL_CONFDIR/override.d/logging.inc" + } + + ${concatStringsSep "\n" ( + mapAttrsToList ( + name: value: + let includeName = if name == "rspamd_proxy" then "proxy" else name; tryOverride = boolToString (value.extraConfig == ""); - in '' - worker "${value.type}" { - type = "${value.type}"; - ${optionalString (value.enable != null) - "enabled = ${if value.enable != false then "yes" else "no"};"} - ${mkBindSockets value.enable value.bindSockets} - ${optionalString (value.count != null) "count = ${toString value.count};"} - ${concatStringsSep "\n " (map (each: ".include \"${each}\"") value.includes)} - .include(try=true; priority=1,duplicate=merge) "$LOCAL_CONFDIR/local.d/worker-${includeName}.inc" - .include(try=${tryOverride}; priority=10) "$LOCAL_CONFDIR/override.d/worker-${includeName}.inc" - } - '') cfg.workers)} - - ${optionalString (cfg.extraConfig != "") '' - .include(priority=10) "$LOCAL_CONFDIR/override.d/extra-config.inc" - ''} - ''; + in + '' + worker "${value.type}" { + type = "${value.type}"; + ${optionalString (value.enable != null) + "enabled = ${if value.enable != false then "yes" else "no"};" + } + ${mkBindSockets value.enable value.bindSockets} + ${optionalString (value.count != null) "count = ${toString value.count};"} + ${concatStringsSep "\n " (map (each: ".include \"${each}\"") value.includes)} + .include(try=true; priority=1,duplicate=merge) "$LOCAL_CONFDIR/local.d/worker-${includeName}.inc" + .include(try=${tryOverride}; priority=10) "$LOCAL_CONFDIR/override.d/worker-${includeName}.inc" + } + '' + ) cfg.workers + )} + + ${optionalString (cfg.extraConfig != "") '' + .include(priority=10) "$LOCAL_CONFDIR/override.d/extra-config.inc" + ''} + ''; filterFiles = files: filterAttrs (n: v: v.enable) files; rspamdDir = pkgs.linkFarm "etc-rspamd-dir" ( - (mapAttrsToList (name: file: { name = "local.d/${name}"; path = file.source; }) (filterFiles cfg.locals)) ++ - (mapAttrsToList (name: file: { name = "override.d/${name}"; path = file.source; }) (filterFiles cfg.overrides)) ++ - (optional (cfg.localLuaRules != null) { name = "rspamd.local.lua"; path = cfg.localLuaRules; }) ++ - [ { name = "rspamd.conf"; path = rspamdConfFile; } ] + (mapAttrsToList (name: file: { + name = "local.d/${name}"; + path = file.source; + }) (filterFiles cfg.locals)) + ++ (mapAttrsToList (name: file: { + name = "override.d/${name}"; + path = file.source; + }) (filterFiles cfg.overrides)) + ++ (optional (cfg.localLuaRules != null) { + name = "rspamd.local.lua"; + path = cfg.localLuaRules; + }) + ++ [ + { + name = "rspamd.conf"; + path = rspamdConfFile; + } + ] ); - configFileModule = prefix: { name, config, ... }: { - options = { - enable = mkOption { - type = types.bool; - default = true; - description = '' - Whether this file ${prefix} should be generated. This - option allows specific ${prefix} files to be disabled. - ''; - }; + configFileModule = + prefix: + { name, config, ... }: + { + options = { + enable = mkOption { + type = types.bool; + default = true; + description = '' + Whether this file ${prefix} should be generated. This + option allows specific ${prefix} files to be disabled. + ''; + }; - text = mkOption { - default = null; - type = types.nullOr types.lines; - description = "Text of the file."; - }; + text = mkOption { + default = null; + type = types.nullOr types.lines; + description = "Text of the file."; + }; - source = mkOption { - type = types.path; - description = "Path of the source file."; + source = mkOption { + type = types.path; + description = "Path of the source file."; + }; + }; + config = { + source = mkIf (config.text != null) ( + let + name' = "rspamd-${prefix}-" + baseNameOf name; + in + mkDefault (pkgs.writeText name' config.text) + ); }; }; - config = { - source = mkIf (config.text != null) ( - let name' = "rspamd-${prefix}-" + baseNameOf name; - in mkDefault (pkgs.writeText name' config.text)); - }; - }; configOverrides = - (mapAttrs' (n: v: nameValuePair "worker-${if n == "rspamd_proxy" then "proxy" else n}.inc" { - text = v.extraConfig; - }) - (filterAttrs (n: v: v.extraConfig != "") cfg.workers)) + (mapAttrs' ( + n: v: + nameValuePair "worker-${if n == "rspamd_proxy" then "proxy" else n}.inc" { + text = v.extraConfig; + } + ) (filterAttrs (n: v: v.extraConfig != "") cfg.workers)) // (lib.optionalAttrs (cfg.extraConfig != "") { "extra-config.inc".text = cfg.extraConfig; }); @@ -237,7 +315,7 @@ in locals = mkOption { type = with types; attrsOf (submodule (configFileModule "locals")); - default = {}; + default = { }; description = '' Local configuration files, written into {file}`/etc/rspamd/local.d/{name}`. ''; @@ -250,7 +328,7 @@ in overrides = mkOption { type = with types; attrsOf (submodule (configFileModule "overrides")); - default = {}; + default = { }; description = '' Overridden configuration files, written into {file}`/etc/rspamd/override.d/{name}`. ''; @@ -276,8 +354,8 @@ in Attribute set of workers to start. ''; default = { - normal = {}; - controller = {}; + normal = { }; + controller = { }; }; example = literalExpression '' { @@ -331,33 +409,40 @@ in }; config = mkOption { - type = with types; attrsOf (oneOf [ bool str (listOf str) ]); + type = + with types; + attrsOf (oneOf [ + bool + str + (listOf str) + ]); description = '' Addon to postfix configuration ''; default = { - smtpd_milters = ["unix:/run/rspamd/rspamd-milter.sock"]; - non_smtpd_milters = ["unix:/run/rspamd/rspamd-milter.sock"]; + smtpd_milters = [ "unix:/run/rspamd/rspamd-milter.sock" ]; + non_smtpd_milters = [ "unix:/run/rspamd/rspamd-milter.sock" ]; }; }; }; }; }; - ###### implementation config = mkIf cfg.enable { services.rspamd.overrides = configOverrides; services.rspamd.workers = mkIf cfg.postfix.enable { - controller = {}; + controller = { }; rspamd_proxy = { - bindSockets = [ { - mode = "0660"; - socket = "/run/rspamd/rspamd-milter.sock"; - owner = cfg.user; - group = postfixCfg.group; - } ]; + bindSockets = [ + { + mode = "0660"; + socket = "/run/rspamd/rspamd-milter.sock"; + owner = cfg.user; + group = postfixCfg.group; + } + ]; extraConfig = '' upstream "local" { default = yes; # Self-scan upstreams are always default @@ -407,7 +492,7 @@ in StateDirectory = "rspamd"; StateDirectoryMode = "0700"; - AmbientCapabilities = []; + AmbientCapabilities = [ ]; CapabilityBoundingSet = ""; DevicePolicy = "closed"; LockPersonality = true; @@ -426,7 +511,11 @@ in ProtectKernelTunables = true; ProtectSystem = "strict"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; @@ -437,10 +526,22 @@ in }; }; imports = [ - (mkRemovedOptionModule [ "services" "rspamd" "socketActivation" ] - "Socket activation never worked correctly and could at this time not be fixed and so was removed") - (mkRenamedOptionModule [ "services" "rspamd" "bindSocket" ] [ "services" "rspamd" "workers" "normal" "bindSockets" ]) - (mkRenamedOptionModule [ "services" "rspamd" "bindUISocket" ] [ "services" "rspamd" "workers" "controller" "bindSockets" ]) - (mkRemovedOptionModule [ "services" "rmilter" ] "Use services.rspamd.* instead to set up milter service") + (mkRemovedOptionModule [ + "services" + "rspamd" + "socketActivation" + ] "Socket activation never worked correctly and could at this time not be fixed and so was removed") + (mkRenamedOptionModule + [ "services" "rspamd" "bindSocket" ] + [ "services" "rspamd" "workers" "normal" "bindSockets" ] + ) + (mkRenamedOptionModule + [ "services" "rspamd" "bindUISocket" ] + [ "services" "rspamd" "workers" "controller" "bindSockets" ] + ) + (mkRemovedOptionModule [ + "services" + "rmilter" + ] "Use services.rspamd.* instead to set up milter service") ]; } diff --git a/nixos/modules/services/mail/rss2email.nix b/nixos/modules/services/mail/rss2email.nix index 12553b9d8919a8..e67ca27dadfe14 100644 --- a/nixos/modules/services/mail/rss2email.nix +++ b/nixos/modules/services/mail/rss2email.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.rss2email; -in { +in +{ ###### interface @@ -27,8 +33,14 @@ in { }; config = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ str int bool ]); - default = {}; + type = + with lib.types; + attrsOf (oneOf [ + str + int + bool + ]); + default = { }; description = '' The configuration to give rss2email. @@ -47,32 +59,33 @@ in { feeds = lib.mkOption { description = "The feeds to watch."; - type = lib.types.attrsOf (lib.types.submodule { - options = { - url = lib.mkOption { - type = lib.types.str; - description = "The URL at which to fetch the feed."; + type = lib.types.attrsOf ( + lib.types.submodule { + options = { + url = lib.mkOption { + type = lib.types.str; + description = "The URL at which to fetch the feed."; + }; + + to = lib.mkOption { + type = with lib.types; nullOr str; + default = null; + description = '' + Email address to which to send feed items. + + If `null`, this will not be set in the + configuration file, and rss2email will make it default to + `rss2email.to`. + ''; + }; }; - - to = lib.mkOption { - type = with lib.types; nullOr str; - default = null; - description = '' - Email address to which to send feed items. - - If `null`, this will not be set in the - configuration file, and rss2email will make it default to - `rss2email.to`. - ''; - }; - }; - }); + } + ); }; }; }; - ###### implementation config = lib.mkIf cfg.enable { @@ -98,28 +111,34 @@ in { mode = "0700"; }; - systemd.services.rss2email = let - conf = pkgs.writeText "rss2email.cfg" (lib.generators.toINI {} ({ - DEFAULT = cfg.config; - } // lib.mapAttrs' (name: feed: lib.nameValuePair "feed.${name}" ( - { inherit (feed) url; } // - lib.optionalAttrs (feed.to != null) { inherit (feed) to; } - )) cfg.feeds - )); - in - { - preStart = '' - if [ ! -f /var/rss2email/db.json ]; then - echo '{"version":2,"feeds":[]}' > /var/rss2email/db.json - fi - ''; - path = [ pkgs.system-sendmail ]; - serviceConfig = { - ExecStart = - "${pkgs.rss2email}/bin/r2e -c ${conf} -d /var/rss2email/db.json run"; - User = "rss2email"; + systemd.services.rss2email = + let + conf = pkgs.writeText "rss2email.cfg" ( + lib.generators.toINI { } ( + { + DEFAULT = cfg.config; + } + // lib.mapAttrs' ( + name: feed: + lib.nameValuePair "feed.${name}" ( + { inherit (feed) url; } // lib.optionalAttrs (feed.to != null) { inherit (feed) to; } + ) + ) cfg.feeds + ) + ); + in + { + preStart = '' + if [ ! -f /var/rss2email/db.json ]; then + echo '{"version":2,"feeds":[]}' > /var/rss2email/db.json + fi + ''; + path = [ pkgs.system-sendmail ]; + serviceConfig = { + ExecStart = "${pkgs.rss2email}/bin/r2e -c ${conf} -d /var/rss2email/db.json run"; + User = "rss2email"; + }; }; - }; systemd.timers.rss2email = { partOf = [ "rss2email.service" ]; diff --git a/nixos/modules/services/mail/schleuder.nix b/nixos/modules/services/mail/schleuder.nix index ca07b879071cad..d5dd9091e674ca 100644 --- a/nixos/modules/services/mail/schleuder.nix +++ b/nixos/modules/services/mail/schleuder.nix @@ -1,8 +1,14 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.schleuder; settingsFormat = pkgs.formats.yaml { }; - postfixMap = entries: lib.concatStringsSep "\n" (lib.mapAttrsToList (name: value: "${name} ${value}") entries); + postfixMap = + entries: lib.concatStringsSep "\n" (lib.mapAttrsToList (name: value: "${name} ${value}") entries); writePostfixMap = name: entries: pkgs.writeText name (postfixMap entries); configScript = pkgs.writeScript "schleuder-cfg" '' #!${pkgs.runtimeShell} @@ -19,7 +25,9 @@ in { options.services.schleuder = { enable = lib.mkEnableOption "Schleuder secure remailer"; - enablePostfix = lib.mkEnableOption "automatic postfix integration" // { default = true; }; + enablePostfix = lib.mkEnableOption "automatic postfix integration" // { + default = true; + }; lists = lib.mkOption { description = '' List of list addresses that should be handled by Schleuder. @@ -31,9 +39,13 @@ in ''; type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "widget-team@example.com" "security@example.com" ]; + example = [ + "widget-team@example.com" + "security@example.com" + ]; }; - /* maybe one day.... + /* + maybe one day.... domains = lib.mkOption { description = "Domains for which all mail should be handled by Schleuder."; type = lib.types.listOf lib.types.str; @@ -85,7 +97,7 @@ in ''; } { - assertion = !(lib.any (db: db ? password) (lib.attrValues cfg.settings.database or {})); + assertion = !(lib.any (db: db ? password) (lib.attrValues cfg.settings.database or { })); message = '' A password is defined for at least one database in services.schleuder.settings.database. Defining passwords via NixOS config results in them being copied to the world-readable Nix store. Please use the extraSettingsFile option to store database passwords in a non-public location. ''; @@ -93,7 +105,7 @@ in ]; users.users.schleuder.isSystemUser = true; users.users.schleuder.group = "schleuder"; - users.groups.schleuder = {}; + users.groups.schleuder = { }; environment.systemPackages = [ pkgs.schleuder-cli ]; @@ -109,15 +121,18 @@ in # review: does this make sense? localRecipients = lib.mkIf (cfg.lists != [ ]) cfg.lists; }; - systemd.services = let commonServiceConfig = { - # We would have liked to use DynamicUser, but since the default - # database is SQLite and lives in StateDirectory, and that same - # database needs to be readable from the postfix service, this - # isn't trivial to do. - User = "schleuder"; - StateDirectory = "schleuder"; - StateDirectoryMode = "0700"; - }; in + systemd.services = + let + commonServiceConfig = { + # We would have liked to use DynamicUser, but since the default + # database is SQLite and lives in StateDirectory, and that same + # database needs to be readable from the postfix service, this + # isn't trivial to do. + User = "schleuder"; + StateDirectory = "schleuder"; + StateDirectoryMode = "0700"; + }; + in { schleuder-init = { serviceConfig = commonServiceConfig // { @@ -129,7 +144,11 @@ in }; }; schleuder-api-daemon = { - after = [ "local-fs.target" "network.target" "schleuder-init.service" ]; + after = [ + "local-fs.target" + "network.target" + "schleuder-init.service" + ]; wantedBy = [ "multi-user.target" ]; requires = [ "schleuder-init.service" ]; serviceConfig = commonServiceConfig // { @@ -137,7 +156,10 @@ in }; }; schleuder-weekly-key-maintenance = { - after = [ "local-fs.target" "network.target" ]; + after = [ + "local-fs.target" + "network.target" + ]; startAt = "weekly"; serviceConfig = commonServiceConfig // { ExecStart = [ @@ -151,7 +173,8 @@ in environment.etc."schleuder/schleuder.yml" = lib.mkIf (cfg.extraSettingsFile == null) { source = settingsFormat.generate "schleuder.yml" cfg.settings; }; - environment.etc."schleuder/list-defaults.yml".source = settingsFormat.generate "list-defaults.yml" cfg.listDefaults; + environment.etc."schleuder/list-defaults.yml".source = + settingsFormat.generate "list-defaults.yml" cfg.listDefaults; services.schleuder = { #lists_dir = "/var/lib/schleuder.lists"; diff --git a/nixos/modules/services/mail/spamassassin.nix b/nixos/modules/services/mail/spamassassin.nix index fbe4cc82adb935..f34fad9b1606df 100644 --- a/nixos/modules/services/mail/spamassassin.nix +++ b/nixos/modules/services/mail/spamassassin.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.spamassassin; spamassassin-local-cf = pkgs.writeText "local.cf" cfg.config; @@ -56,8 +61,7 @@ in type = with lib.types; either str path; description = "The SpamAssassin init.pre config."; apply = val: if builtins.isPath val then val else pkgs.writeText "init.pre" val; - default = - '' + default = '' # # to update this list, run this command in the rules directory: # grep 'loadplugin.*Mail::SpamAssassin::Plugin::.*' -o -h * | sort | uniq @@ -161,8 +165,8 @@ in systemd.timers.sa-update = { description = "sa-update-service"; - partOf = [ "sa-update.service" ]; - wantedBy = [ "timers.target" ]; + partOf = [ "sa-update.service" ]; + wantedBy = [ "timers.target" ]; timerConfig = { OnCalendar = "1:*"; Persistent = true; diff --git a/nixos/modules/services/mail/stalwart-mail.nix b/nixos/modules/services/mail/stalwart-mail.nix index 9985e49067a947..46c4bd7bf68244 100644 --- a/nixos/modules/services/mail/stalwart-mail.nix +++ b/nixos/modules/services/mail/stalwart-mail.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.stalwart-mail; configFormat = pkgs.formats.toml { }; @@ -6,14 +11,17 @@ let dataDir = "/var/lib/stalwart-mail"; useLegacyStorage = lib.versionOlder config.system.stateVersion "24.11"; - parsePorts = listeners: let - parseAddresses = listeners: lib.flatten(lib.mapAttrsToList (name: value: value.bind) listeners); - splitAddress = addr: lib.splitString ":" addr; - extractPort = addr: lib.toInt(builtins.foldl' (a: b: b) "" (splitAddress addr)); - in - builtins.map(address: extractPort address) (parseAddresses listeners); - -in { + parsePorts = + listeners: + let + parseAddresses = listeners: lib.flatten (lib.mapAttrsToList (name: value: value.bind) listeners); + splitAddress = addr: lib.splitString ":" addr; + extractPort = addr: lib.toInt (builtins.foldl' (a: b: b) "" (splitAddress addr)); + in + builtins.map (address: extractPort address) (parseAddresses listeners); + +in +{ options.services.stalwart-mail = { enable = lib.mkEnableOption "the Stalwart all-in-one email server"; @@ -47,21 +55,25 @@ in { tracer.stdout = { type = lib.mkDefault "stdout"; level = lib.mkDefault "info"; - ansi = lib.mkDefault false; # no colour markers to journald + ansi = lib.mkDefault false; # no colour markers to journald enable = lib.mkDefault true; }; - store = if useLegacyStorage then { - # structured data in SQLite, blobs on filesystem - db.type = lib.mkDefault "sqlite"; - db.path = lib.mkDefault "${dataDir}/data/index.sqlite3"; - fs.type = lib.mkDefault "fs"; - fs.path = lib.mkDefault "${dataDir}/data/blobs"; - } else { - # everything in RocksDB - db.type = lib.mkDefault "rocksdb"; - db.path = lib.mkDefault "${dataDir}/db"; - db.compression = lib.mkDefault "lz4"; - }; + store = + if useLegacyStorage then + { + # structured data in SQLite, blobs on filesystem + db.type = lib.mkDefault "sqlite"; + db.path = lib.mkDefault "${dataDir}/data/index.sqlite3"; + fs.type = lib.mkDefault "fs"; + fs.path = lib.mkDefault "${dataDir}/data/blobs"; + } + else + { + # everything in RocksDB + db.type = lib.mkDefault "rocksdb"; + db.path = lib.mkDefault "${dataDir}/db"; + db.compression = lib.mkDefault "lz4"; + }; storage.data = lib.mkDefault "db"; storage.fts = lib.mkDefault "db"; storage.lookup = lib.mkDefault "db"; @@ -73,15 +85,18 @@ in { resolver.public-suffix = lib.mkDefault [ "file://${pkgs.publicsuffix-list}/share/publicsuffix/public_suffix_list.dat" ]; - config.resource = let - hasHttpListener = builtins.any (listener: listener.protocol == "http") (lib.attrValues cfg.settings.server.listener); - in { - spam-filter = lib.mkDefault "file://${cfg.package}/etc/stalwart/spamfilter.toml"; - } // lib.optionalAttrs ( - (builtins.hasAttr "listener" cfg.settings.server) && hasHttpListener - ) { - webadmin = lib.mkDefault "file://${cfg.package.webadmin}/webadmin.zip"; - }; + config.resource = + let + hasHttpListener = builtins.any (listener: listener.protocol == "http") ( + lib.attrValues cfg.settings.server.listener + ); + in + { + spam-filter = lib.mkDefault "file://${cfg.package}/etc/stalwart/spamfilter.toml"; + } + // lib.optionalAttrs ((builtins.hasAttr "listener" cfg.settings.server) && hasHttpListener) { + webadmin = lib.mkDefault "file://${cfg.package.webadmin}/webadmin.zip"; + }; webadmin.path = "/var/cache/stalwart-mail"; }; @@ -101,13 +116,20 @@ in { packages = [ cfg.package ]; services.stalwart-mail = { wantedBy = [ "multi-user.target" ]; - after = [ "local-fs.target" "network.target" ]; + after = [ + "local-fs.target" + "network.target" + ]; - preStart = if useLegacyStorage then '' - mkdir -p ${dataDir}/data/blobs - '' else '' - mkdir -p ${dataDir}/db - ''; + preStart = + if useLegacyStorage then + '' + mkdir -p ${dataDir}/data/blobs + '' + else + '' + mkdir -p ${dataDir}/db + ''; serviceConfig = { ExecStart = [ @@ -130,7 +152,7 @@ in { LockPersonality = true; MemoryDenyWriteExecute = true; PrivateDevices = true; - PrivateUsers = false; # incompatible with CAP_NET_BIND_SERVICE + PrivateUsers = false; # incompatible with CAP_NET_BIND_SERVICE ProcSubset = "pid"; PrivateTmp = true; ProtectClock = true; @@ -142,12 +164,18 @@ in { ProtectKernelTunables = true; ProtectProc = "invisible"; ProtectSystem = "strict"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; UMask = "0077"; }; unitConfig.ConditionPathExists = [ @@ -160,13 +188,18 @@ in { # Make admin commands available in the shell environment.systemPackages = [ cfg.package ]; - networking.firewall = lib.mkIf (cfg.openFirewall - && (builtins.hasAttr "listener" cfg.settings.server)) { - allowedTCPPorts = parsePorts cfg.settings.server.listener; - }; + networking.firewall = + lib.mkIf (cfg.openFirewall && (builtins.hasAttr "listener" cfg.settings.server)) + { + allowedTCPPorts = parsePorts cfg.settings.server.listener; + }; }; meta = { - maintainers = with lib.maintainers; [ happysalada pacien onny ]; + maintainers = with lib.maintainers; [ + happysalada + pacien + onny + ]; }; } diff --git a/nixos/modules/services/mail/sympa.nix b/nixos/modules/services/mail/sympa.nix index c83844516557c4..c1a833528b0fa0 100644 --- a/nixos/modules/services/mail/sympa.nix +++ b/nixos/modules/services/mail/sympa.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.sympa; dataDir = "/var/lib/sympa"; @@ -26,39 +31,48 @@ let }; # wwsympa has its own service config - sympaServiceConfig = srv: { - Type = "simple"; - Restart = "always"; - ExecStart = "${pkg}/bin/${srv}.pl --foreground"; - PIDFile = "/run/sympa/${srv}.pid"; - User = user; - Group = group; - - # avoid duplicating log messageges in journal - StandardError = "null"; - } // commonServiceConfig; - - configVal = value: - if lib.isBool value then - if value then "on" else "off" - else toString value; - configGenerator = c: lib.concatStrings (lib.flip lib.mapAttrsToList c (key: val: "${key}\t${configVal val}\n")); + sympaServiceConfig = + srv: + { + Type = "simple"; + Restart = "always"; + ExecStart = "${pkg}/bin/${srv}.pl --foreground"; + PIDFile = "/run/sympa/${srv}.pid"; + User = user; + Group = group; + + # avoid duplicating log messageges in journal + StandardError = "null"; + } + // commonServiceConfig; + + configVal = value: if lib.isBool value then if value then "on" else "off" else toString value; + configGenerator = + c: lib.concatStrings (lib.flip lib.mapAttrsToList c (key: val: "${key}\t${configVal val}\n")); mainConfig = pkgs.writeText "sympa.conf" (configGenerator cfg.settings); robotConfig = fqdn: domain: pkgs.writeText "${fqdn}-robot.conf" (configGenerator domain.settings); - transport = pkgs.writeText "transport.sympa" (lib.concatStringsSep "\n" (lib.flip map fqdns (domain: '' - ${domain} error:User unknown in recipient table - sympa@${domain} sympa:sympa@${domain} - listmaster@${domain} sympa:listmaster@${domain} - bounce@${domain} sympabounce:sympa@${domain} - abuse-feedback-report@${domain} sympabounce:sympa@${domain} - ''))); - - virtual = pkgs.writeText "virtual.sympa" (lib.concatStringsSep "\n" (lib.flip map fqdns (domain: '' - sympa-request@${domain} postmaster@localhost - sympa-owner@${domain} postmaster@localhost - ''))); + transport = pkgs.writeText "transport.sympa" ( + lib.concatStringsSep "\n" ( + lib.flip map fqdns (domain: '' + ${domain} error:User unknown in recipient table + sympa@${domain} sympa:sympa@${domain} + listmaster@${domain} sympa:listmaster@${domain} + bounce@${domain} sympabounce:sympa@${domain} + abuse-feedback-report@${domain} sympabounce:sympa@${domain} + '') + ) + ); + + virtual = pkgs.writeText "virtual.sympa" ( + lib.concatStringsSep "\n" ( + lib.flip map fqdns (domain: '' + sympa-request@${domain} postmaster@localhost + sympa-owner@${domain} postmaster@localhost + '') + ) + ); listAliases = pkgs.writeText "list_aliases.tt2" '' #--- [% list.name %]@[% list.domain %]: list transport map created at [% date %] @@ -110,41 +124,50 @@ in }; domains = lib.mkOption { - type = attrsOf (submodule ({ name, config, ... }: { - options = { - webHost = lib.mkOption { - type = nullOr str; - default = null; - example = "archive.example.org"; - description = '' - Domain part of the web interface URL (no web interface for this domain if `null`). - DNS record of type A (or AAAA or CNAME) has to exist with this value. - ''; - }; - webLocation = lib.mkOption { - type = str; - default = "/"; - example = "/sympa"; - description = "URL path part of the web interface."; - }; - settings = lib.mkOption { - type = attrsOf (oneOf [ str int bool ]); - default = {}; - example = { - default_max_list_members = 3; + type = attrsOf ( + submodule ( + { name, config, ... }: + { + options = { + webHost = lib.mkOption { + type = nullOr str; + default = null; + example = "archive.example.org"; + description = '' + Domain part of the web interface URL (no web interface for this domain if `null`). + DNS record of type A (or AAAA or CNAME) has to exist with this value. + ''; + }; + webLocation = lib.mkOption { + type = str; + default = "/"; + example = "/sympa"; + description = "URL path part of the web interface."; + }; + settings = lib.mkOption { + type = attrsOf (oneOf [ + str + int + bool + ]); + default = { }; + example = { + default_max_list_members = 3; + }; + description = '' + The {file}`robot.conf` configuration file as key value set. + See + for list of configuration parameters. + ''; + }; }; - description = '' - The {file}`robot.conf` configuration file as key value set. - See - for list of configuration parameters. - ''; - }; - }; - config.settings = lib.mkIf (cfg.web.enable && config.webHost != null) { - wwsympa_url = lib.mkDefault "https://${config.webHost}${lib.removeSuffix "/" config.webLocation}"; - }; - })); + config.settings = lib.mkIf (cfg.web.enable && config.webHost != null) { + wwsympa_url = lib.mkDefault "https://${config.webHost}${lib.removeSuffix "/" config.webLocation}"; + }; + } + ) + ); description = '' Email domains handled by this instance. There have @@ -166,7 +189,11 @@ in database = { type = lib.mkOption { - type = enum [ "SQLite" "PostgreSQL" "MySQL" ]; + type = enum [ + "SQLite" + "PostgreSQL" + "MySQL" + ]; default = "SQLite"; example = "MySQL"; description = "Database engine to use."; @@ -234,7 +261,10 @@ in }; server = lib.mkOption { - type = enum [ "nginx" "none" ]; + type = enum [ + "nginx" + "none" + ]; default = "nginx"; description = '' The webserver used for the Sympa web interface. Set it to `none` if you want to configure it yourself. @@ -261,7 +291,10 @@ in mta = { type = lib.mkOption { - type = enum [ "postfix" "none" ]; + type = enum [ + "postfix" + "none" + ]; default = "postfix"; description = '' Mail transfer agent (MTA) integration. Use `none` if you want to configure it yourself. @@ -274,8 +307,12 @@ in }; settings = lib.mkOption { - type = attrsOf (oneOf [ str int bool ]); - default = {}; + type = attrsOf (oneOf [ + str + int + bool + ]); + default = { }; example = lib.literalExpression '' { default_home = "lists"; @@ -290,27 +327,34 @@ in }; settingsFile = lib.mkOption { - type = attrsOf (submodule ({ name, config, ... }: { - options = { - enable = lib.mkOption { - type = bool; - default = true; - description = "Whether this file should be generated. This option allows specific files to be disabled."; - }; - text = lib.mkOption { - default = null; - type = nullOr lines; - description = "Text of the file."; - }; - source = lib.mkOption { - type = path; - description = "Path of the source file."; - }; - }; + type = attrsOf ( + submodule ( + { name, config, ... }: + { + options = { + enable = lib.mkOption { + type = bool; + default = true; + description = "Whether this file should be generated. This option allows specific files to be disabled."; + }; + text = lib.mkOption { + default = null; + type = nullOr lines; + description = "Text of the file."; + }; + source = lib.mkOption { + type = path; + description = "Path of the source file."; + }; + }; - config.source = lib.mkIf (config.text != null) (lib.mkDefault (pkgs.writeText "sympa-${baseNameOf name}" config.text)); - })); - default = {}; + config.source = lib.mkIf (config.text != null) ( + lib.mkDefault (pkgs.writeText "sympa-${baseNameOf name}" config.text) + ); + } + ) + ); + default = { }; example = lib.literalExpression '' { "list_data/lists.example.org/help" = { @@ -326,52 +370,57 @@ in config = lib.mkIf cfg.enable { - services.sympa.settings = (lib.mapAttrs (_: v: lib.mkDefault v) { - domain = if cfg.mainDomain != null then cfg.mainDomain else lib.head fqdns; - listmaster = lib.concatStringsSep "," cfg.listMasters; - lang = cfg.lang; + services.sympa.settings = ( + lib.mapAttrs (_: v: lib.mkDefault v) { + domain = if cfg.mainDomain != null then cfg.mainDomain else lib.head fqdns; + listmaster = lib.concatStringsSep "," cfg.listMasters; + lang = cfg.lang; - home = "${dataDir}/list_data"; - arc_path = "${dataDir}/arc"; - bounce_path = "${dataDir}/bounce"; + home = "${dataDir}/list_data"; + arc_path = "${dataDir}/arc"; + bounce_path = "${dataDir}/bounce"; - sendmail = "${pkgs.system-sendmail}/bin/sendmail"; + sendmail = "${pkgs.system-sendmail}/bin/sendmail"; - db_type = cfg.database.type; - db_name = cfg.database.name; - db_user = cfg.database.name; - } - // (lib.optionalAttrs (cfg.database.host != null) { - db_host = cfg.database.host; - }) - // (lib.optionalAttrs mysqlLocal { - db_host = "localhost"; # use unix domain socket - }) - // (lib.optionalAttrs pgsqlLocal { - db_host = "/run/postgresql"; # use unix domain socket - }) - // (lib.optionalAttrs (cfg.database.port != null) { - db_port = cfg.database.port; - }) - // (lib.optionalAttrs (cfg.mta.type == "postfix") { - sendmail_aliases = "${dataDir}/sympa_transport"; - aliases_program = "${pkgs.postfix}/bin/postmap"; - aliases_db_type = "hash"; - }) - // (lib.optionalAttrs cfg.web.enable { - static_content_path = "${dataDir}/static_content"; - css_path = "${dataDir}/static_content/css"; - pictures_path = "${dataDir}/static_content/pictures"; - mhonarc = "${pkgs.perlPackages.MHonArc}/bin/mhonarc"; - })); - - services.sympa.settingsFile = { - "virtual.sympa" = lib.mkDefault { source = virtual; }; - "transport.sympa" = lib.mkDefault { source = transport; }; - "etc/list_aliases.tt2" = lib.mkDefault { source = listAliases; }; - } - // (lib.flip lib.mapAttrs' cfg.domains (fqdn: domain: - lib.nameValuePair "etc/${fqdn}/robot.conf" (lib.mkDefault { source = robotConfig fqdn domain; }))); + db_type = cfg.database.type; + db_name = cfg.database.name; + db_user = cfg.database.name; + } + // (lib.optionalAttrs (cfg.database.host != null) { + db_host = cfg.database.host; + }) + // (lib.optionalAttrs mysqlLocal { + db_host = "localhost"; # use unix domain socket + }) + // (lib.optionalAttrs pgsqlLocal { + db_host = "/run/postgresql"; # use unix domain socket + }) + // (lib.optionalAttrs (cfg.database.port != null) { + db_port = cfg.database.port; + }) + // (lib.optionalAttrs (cfg.mta.type == "postfix") { + sendmail_aliases = "${dataDir}/sympa_transport"; + aliases_program = "${pkgs.postfix}/bin/postmap"; + aliases_db_type = "hash"; + }) + // (lib.optionalAttrs cfg.web.enable { + static_content_path = "${dataDir}/static_content"; + css_path = "${dataDir}/static_content/css"; + pictures_path = "${dataDir}/static_content/pictures"; + mhonarc = "${pkgs.perlPackages.MHonArc}/bin/mhonarc"; + }) + ); + + services.sympa.settingsFile = + { + "virtual.sympa" = lib.mkDefault { source = virtual; }; + "transport.sympa" = lib.mkDefault { source = transport; }; + "etc/list_aliases.tt2" = lib.mkDefault { source = listAliases; }; + } + // (lib.flip lib.mapAttrs' cfg.domains ( + fqdn: domain: + lib.nameValuePair "etc/${fqdn}/robot.conf" (lib.mkDefault { source = robotConfig fqdn domain; }) + )); environment = { systemPackages = [ pkg ]; @@ -385,47 +434,55 @@ in isSystemUser = true; }; - users.groups.${group} = {}; + users.groups.${group} = { }; assertions = [ - { assertion = cfg.database.createLocally -> cfg.database.user == user && cfg.database.name == cfg.database.user; + { + assertion = + cfg.database.createLocally -> cfg.database.user == user && cfg.database.name == cfg.database.user; message = "services.sympa.database.user must be set to ${user} if services.sympa.database.createLocally is set to true"; } - { assertion = cfg.database.createLocally -> cfg.database.passwordFile == null; + { + assertion = cfg.database.createLocally -> cfg.database.passwordFile == null; message = "a password cannot be specified if services.sympa.database.createLocally is set to true"; } ]; - systemd.tmpfiles.rules = [ - "d ${dataDir} 0711 ${user} ${group} - -" - "d ${dataDir}/etc 0700 ${user} ${group} - -" - "d ${dataDir}/spool 0700 ${user} ${group} - -" - "d ${dataDir}/list_data 0700 ${user} ${group} - -" - "d ${dataDir}/arc 0700 ${user} ${group} - -" - "d ${dataDir}/bounce 0700 ${user} ${group} - -" - "f ${dataDir}/sympa_transport 0600 ${user} ${group} - -" - - # force-copy static_content so it's up to date with package - # set permissions for wwsympa which needs write access (...) - "R ${dataDir}/static_content - - - - -" - "C ${dataDir}/static_content 0711 ${user} ${group} - ${pkg}/var/lib/sympa/static_content" - "e ${dataDir}/static_content/* 0711 ${user} ${group} - -" - - "d /run/sympa 0755 ${user} ${group} - -" - ] - ++ (lib.flip lib.concatMap fqdns (fqdn: [ - "d ${dataDir}/etc/${fqdn} 0700 ${user} ${group} - -" - "d ${dataDir}/list_data/${fqdn} 0700 ${user} ${group} - -" - ])) - #++ (lib.flip lib.mapAttrsToList enabledFiles (k: v: - # "L+ ${dataDir}/${k} - - - - ${v.source}" - #)) - ++ (lib.concatLists (lib.flip lib.mapAttrsToList enabledFiles (k: v: [ - # sympa doesn't handle symlinks well (e.g. fails to create locks) - # force-copy instead - "R ${dataDir}/${k} - - - - -" - "C ${dataDir}/${k} 0700 ${user} ${group} - ${v.source}" - ]))); + systemd.tmpfiles.rules = + [ + "d ${dataDir} 0711 ${user} ${group} - -" + "d ${dataDir}/etc 0700 ${user} ${group} - -" + "d ${dataDir}/spool 0700 ${user} ${group} - -" + "d ${dataDir}/list_data 0700 ${user} ${group} - -" + "d ${dataDir}/arc 0700 ${user} ${group} - -" + "d ${dataDir}/bounce 0700 ${user} ${group} - -" + "f ${dataDir}/sympa_transport 0600 ${user} ${group} - -" + + # force-copy static_content so it's up to date with package + # set permissions for wwsympa which needs write access (...) + "R ${dataDir}/static_content - - - - -" + "C ${dataDir}/static_content 0711 ${user} ${group} - ${pkg}/var/lib/sympa/static_content" + "e ${dataDir}/static_content/* 0711 ${user} ${group} - -" + + "d /run/sympa 0755 ${user} ${group} - -" + ] + ++ (lib.flip lib.concatMap fqdns (fqdn: [ + "d ${dataDir}/etc/${fqdn} 0700 ${user} ${group} - -" + "d ${dataDir}/list_data/${fqdn} 0700 ${user} ${group} - -" + ])) + #++ (lib.flip lib.mapAttrsToList enabledFiles (k: v: + # "L+ ${dataDir}/${k} - - - - ${v.source}" + #)) + ++ (lib.concatLists ( + lib.flip lib.mapAttrsToList enabledFiles ( + k: v: [ + # sympa doesn't handle symlinks well (e.g. fails to create locks) + # force-copy instead + "R ${dataDir}/${k} - - - - -" + "C ${dataDir}/${k} 0700 ${user} ${group} - ${v.source}" + ] + ) + )); systemd.services.sympa = { description = "Sympa mailing list manager"; @@ -482,37 +539,50 @@ in Type = "forking"; PIDFile = "/run/sympa/wwsympa.pid"; Restart = "always"; - ExecStart = ''${pkgs.spawn_fcgi}/bin/spawn-fcgi \ - -u ${user} \ - -g ${group} \ - -U nginx \ - -M 0600 \ - -F ${toString cfg.web.fcgiProcs} \ - -P /run/sympa/wwsympa.pid \ - -s /run/sympa/wwsympa.socket \ - -- ${pkg}/lib/sympa/cgi/wwsympa.fcgi + ExecStart = '' + ${pkgs.spawn_fcgi}/bin/spawn-fcgi \ + -u ${user} \ + -g ${group} \ + -U nginx \ + -M 0600 \ + -F ${toString cfg.web.fcgiProcs} \ + -P /run/sympa/wwsympa.pid \ + -s /run/sympa/wwsympa.socket \ + -- ${pkg}/lib/sympa/cgi/wwsympa.fcgi ''; } // commonServiceConfig; }; services.nginx.enable = lib.mkIf usingNginx true; - services.nginx.virtualHosts = lib.mkIf usingNginx (let - vHosts = lib.unique (lib.remove null (lib.mapAttrsToList (_k: v: v.webHost) cfg.domains)); - hostLocations = host: map (v: v.webLocation) (lib.filter (v: v.webHost == host) (lib.attrValues cfg.domains)); - httpsOpts = lib.optionalAttrs cfg.web.https { forceSSL = lib.mkDefault true; enableACME = lib.mkDefault true; }; - in - lib.genAttrs vHosts (host: { - locations = lib.genAttrs (hostLocations host) (loc: { - extraConfig = '' - include ${config.services.nginx.package}/conf/fastcgi_params; - - fastcgi_pass unix:/run/sympa/wwsympa.socket; - ''; - }) // { - "/static-sympa/".alias = "${dataDir}/static_content/"; - }; - } // httpsOpts)); + services.nginx.virtualHosts = lib.mkIf usingNginx ( + let + vHosts = lib.unique (lib.remove null (lib.mapAttrsToList (_k: v: v.webHost) cfg.domains)); + hostLocations = + host: map (v: v.webLocation) (lib.filter (v: v.webHost == host) (lib.attrValues cfg.domains)); + httpsOpts = lib.optionalAttrs cfg.web.https { + forceSSL = lib.mkDefault true; + enableACME = lib.mkDefault true; + }; + in + lib.genAttrs vHosts ( + host: + { + locations = + lib.genAttrs (hostLocations host) (loc: { + extraConfig = '' + include ${config.services.nginx.package}/conf/fastcgi_params; + + fastcgi_pass unix:/run/sympa/wwsympa.socket; + ''; + }) + // { + "/static-sympa/".alias = "${dataDir}/static_content/"; + }; + } + // httpsOpts + ) + ); services.postfix = lib.mkIf (cfg.mta.type == "postfix") { enable = true; @@ -563,8 +633,11 @@ in package = lib.mkDefault pkgs.mariadb; ensureDatabases = [ cfg.database.name ]; ensureUsers = [ - { name = cfg.database.user; - ensurePermissions = { "${cfg.database.name}.*" = "ALL PRIVILEGES"; }; + { + name = cfg.database.user; + ensurePermissions = { + "${cfg.database.name}.*" = "ALL PRIVILEGES"; + }; } ]; }; @@ -573,7 +646,8 @@ in enable = true; ensureDatabases = [ cfg.database.name ]; ensureUsers = [ - { name = cfg.database.user; + { + name = cfg.database.user; ensureDBOwnership = true; } ]; @@ -581,5 +655,8 @@ in }; - meta.maintainers = with lib.maintainers; [ mmilata sorki ]; + meta.maintainers = with lib.maintainers; [ + mmilata + sorki + ]; } diff --git a/nixos/modules/services/mail/zeyple.nix b/nixos/modules/services/mail/zeyple.nix index 2f9164f700fecd..dfc8d7ff3a5085 100644 --- a/nixos/modules/services/mail/zeyple.nix +++ b/nixos/modules/services/mail/zeyple.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.zeyple; ini = pkgs.formats.ini { }; @@ -12,7 +17,8 @@ let # Remove socket files rm -f $out/S.* ''; -in { +in +{ options.services.zeyple = { enable = lib.mkEnableOption "Zeyple, an utility program to automatically encrypt outgoing emails with GPG"; diff --git a/nixos/modules/services/matrix/appservice-discord.nix b/nixos/modules/services/matrix/appservice-discord.nix index cbe265d359441d..5e7930a73c4c0c 100644 --- a/nixos/modules/services/matrix/appservice-discord.nix +++ b/nixos/modules/services/matrix/appservice-discord.nix @@ -1,13 +1,22 @@ -{ config, options, pkgs, lib, ... }: +{ + config, + options, + pkgs, + lib, + ... +}: let dataDir = "/var/lib/matrix-appservice-discord"; registrationFile = "${dataDir}/discord-registration.yaml"; cfg = config.services.matrix-appservice-discord; opt = options.services.matrix-appservice-discord; # TODO: switch to configGen.json once RFC42 is implemented - settingsFile = pkgs.writeText "matrix-appservice-discord-settings.json" (builtins.toJSON cfg.settings); + settingsFile = pkgs.writeText "matrix-appservice-discord-settings.json" ( + builtins.toJSON cfg.settings + ); -in { +in +{ options = { services.matrix-appservice-discord = { enable = lib.mkEnableOption "a bridge between Matrix and Discord"; @@ -115,7 +124,9 @@ in { ${cfg.package}/bin/matrix-appservice-discord \ --generate-registration \ --url=${lib.escapeShellArg cfg.url} \ - ${lib.optionalString (cfg.localpart != null) "--localpart=${lib.escapeShellArg cfg.localpart}"} \ + ${ + lib.optionalString (cfg.localpart != null) "--localpart=${lib.escapeShellArg cfg.localpart}" + } \ --config='${settingsFile}' \ --file='${registrationFile}' fi diff --git a/nixos/modules/services/matrix/appservice-irc.nix b/nixos/modules/services/matrix/appservice-irc.nix index ac8d4250b9acf1..c7cd341a922916 100644 --- a/nixos/modules/services/matrix/appservice-irc.nix +++ b/nixos/modules/services/matrix/appservice-irc.nix @@ -1,27 +1,39 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.matrix-appservice-irc; pkg = pkgs.matrix-appservice-irc; bin = "${pkg}/bin/matrix-appservice-irc"; - jsonType = (pkgs.formats.json {}).type; + jsonType = (pkgs.formats.json { }).type; - configFile = pkgs.runCommand "matrix-appservice-irc.yml" { - # Because this program will be run at build time, we need `nativeBuildInputs` - nativeBuildInputs = [ (pkgs.python3.withPackages (ps: [ ps.jsonschema ])) pkgs.remarshal ]; - preferLocalBuild = true; + configFile = + pkgs.runCommand "matrix-appservice-irc.yml" + { + # Because this program will be run at build time, we need `nativeBuildInputs` + nativeBuildInputs = [ + (pkgs.python3.withPackages (ps: [ ps.jsonschema ])) + pkgs.remarshal + ]; + preferLocalBuild = true; - config = builtins.toJSON cfg.settings; - passAsFile = [ "config" ]; - } '' - # The schema is given as yaml, we need to convert it to json - remarshal --if yaml --of json -i ${pkg}/config.schema.yml -o config.schema.json - python -m jsonschema config.schema.json -i $configPath - cp "$configPath" "$out" - ''; + config = builtins.toJSON cfg.settings; + passAsFile = [ "config" ]; + } + '' + # The schema is given as yaml, we need to convert it to json + remarshal --if yaml --of json -i ${pkg}/config.schema.yml -o config.schema.json + python -m jsonschema config.schema.json -i $configPath + cp "$configPath" "$out" + ''; registrationFile = "/var/lib/matrix-appservice-irc/registration.yml"; -in { +in +{ options.services.matrix-appservice-irc = with lib.types; { enable = lib.mkEnableOption "the Matrix/IRC bridge"; @@ -65,14 +77,14 @@ in { for supported values ''; - default = {}; + default = { }; type = submodule { freeformType = jsonType; options = { homeserver = lib.mkOption { description = "Homeserver configuration"; - default = {}; + default = { }; type = submodule { freeformType = jsonType; @@ -94,7 +106,7 @@ in { }; database = lib.mkOption { - default = {}; + default = { }; description = "Configuration for the database"; type = submodule { freeformType = jsonType; @@ -118,7 +130,7 @@ in { }; ircService = lib.mkOption { - default = {}; + default = { }; description = "IRC bridge configuration"; type = submodule { freeformType = jsonType; @@ -259,7 +271,7 @@ in { }; }; - users.groups.matrix-appservice-irc = {}; + users.groups.matrix-appservice-irc = { }; users.users.matrix-appservice-irc = { description = "Service user for the Matrix-IRC bridge"; group = "matrix-appservice-irc"; diff --git a/nixos/modules/services/matrix/conduit.nix b/nixos/modules/services/matrix/conduit.nix index 98ed19abd36698..3d2738c4c3d81b 100644 --- a/nixos/modules/services/matrix/conduit.nix +++ b/nixos/modules/services/matrix/conduit.nix @@ -1,152 +1,165 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.matrix-conduit; - format = pkgs.formats.toml {}; + format = pkgs.formats.toml { }; configFile = format.generate "conduit.toml" cfg.settings; in - { - meta.maintainers = with lib.maintainers; [ pstn ]; - options.services.matrix-conduit = { - enable = lib.mkEnableOption "matrix-conduit"; +{ + meta.maintainers = with lib.maintainers; [ pstn ]; + options.services.matrix-conduit = { + enable = lib.mkEnableOption "matrix-conduit"; - extraEnvironment = lib.mkOption { - type = lib.types.attrsOf lib.types.str; - description = "Extra Environment variables to pass to the conduit server."; - default = {}; - example = { RUST_BACKTRACE="yes"; }; + extraEnvironment = lib.mkOption { + type = lib.types.attrsOf lib.types.str; + description = "Extra Environment variables to pass to the conduit server."; + default = { }; + example = { + RUST_BACKTRACE = "yes"; }; + }; - package = lib.mkPackageOption pkgs "matrix-conduit" { }; + package = lib.mkPackageOption pkgs "matrix-conduit" { }; - settings = lib.mkOption { - type = lib.types.submodule { - freeformType = format.type; - options = { - global.server_name = lib.mkOption { - type = lib.types.str; - example = "example.com"; - description = "The server_name is the name of this server. It is used as a suffix for user # and room ids."; - }; - global.port = lib.mkOption { - type = lib.types.port; - default = 6167; - description = "The port Conduit will be running on. You need to set up a reverse proxy in your web server (e.g. apache or nginx), so all requests to /_matrix on port 443 and 8448 will be forwarded to the Conduit instance running on this port"; - }; - global.max_request_size = lib.mkOption { - type = lib.types.ints.positive; - default = 20000000; - description = "Max request size in bytes. Don't forget to also change it in the proxy."; - }; - global.allow_registration = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Whether new users can register on this server."; - }; - global.allow_encryption = lib.mkOption { - type = lib.types.bool; - default = true; - description = "Whether new encrypted rooms can be created. Note: existing rooms will continue to work."; - }; - global.allow_federation = lib.mkOption { - type = lib.types.bool; - default = true; - description = '' - Whether this server federates with other servers. - ''; - }; - global.trusted_servers = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = [ "matrix.org" ]; - description = "Servers trusted with signing server keys."; - }; - global.address = lib.mkOption { - type = lib.types.str; - default = "::1"; - description = "Address to listen on for connections by the reverse proxy/tls terminator."; - }; - global.database_path = lib.mkOption { - type = lib.types.str; - default = "/var/lib/matrix-conduit/"; - readOnly = true; - description = '' - Path to the conduit database, the directory where conduit will save its data. - Note that due to using the DynamicUser feature of systemd, this value should not be changed - and is set to be read only. - ''; - }; - global.database_backend = lib.mkOption { - type = lib.types.enum [ "sqlite" "rocksdb" ]; - default = "sqlite"; - example = "rocksdb"; - description = '' - The database backend for the service. Switching it on an existing - instance will require manual migration of data. - ''; - }; - global.allow_check_for_updates = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Whether to allow Conduit to automatically contact - hourly to check for important Conduit news. + settings = lib.mkOption { + type = lib.types.submodule { + freeformType = format.type; + options = { + global.server_name = lib.mkOption { + type = lib.types.str; + example = "example.com"; + description = "The server_name is the name of this server. It is used as a suffix for user # and room ids."; + }; + global.port = lib.mkOption { + type = lib.types.port; + default = 6167; + description = "The port Conduit will be running on. You need to set up a reverse proxy in your web server (e.g. apache or nginx), so all requests to /_matrix on port 443 and 8448 will be forwarded to the Conduit instance running on this port"; + }; + global.max_request_size = lib.mkOption { + type = lib.types.ints.positive; + default = 20000000; + description = "Max request size in bytes. Don't forget to also change it in the proxy."; + }; + global.allow_registration = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Whether new users can register on this server."; + }; + global.allow_encryption = lib.mkOption { + type = lib.types.bool; + default = true; + description = "Whether new encrypted rooms can be created. Note: existing rooms will continue to work."; + }; + global.allow_federation = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Whether this server federates with other servers. + ''; + }; + global.trusted_servers = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ "matrix.org" ]; + description = "Servers trusted with signing server keys."; + }; + global.address = lib.mkOption { + type = lib.types.str; + default = "::1"; + description = "Address to listen on for connections by the reverse proxy/tls terminator."; + }; + global.database_path = lib.mkOption { + type = lib.types.str; + default = "/var/lib/matrix-conduit/"; + readOnly = true; + description = '' + Path to the conduit database, the directory where conduit will save its data. + Note that due to using the DynamicUser feature of systemd, this value should not be changed + and is set to be read only. + ''; + }; + global.database_backend = lib.mkOption { + type = lib.types.enum [ + "sqlite" + "rocksdb" + ]; + default = "sqlite"; + example = "rocksdb"; + description = '' + The database backend for the service. Switching it on an existing + instance will require manual migration of data. + ''; + }; + global.allow_check_for_updates = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Whether to allow Conduit to automatically contact + hourly to check for important Conduit news. - Disabled by default because nixpkgs handles updates. - ''; - }; + Disabled by default because nixpkgs handles updates. + ''; }; }; - default = {}; - description = '' - Generates the conduit.toml configuration file. Refer to - - for details on supported values. - Note that database_path can not be edited because the service's reliance on systemd StateDir. - ''; }; + default = { }; + description = '' + Generates the conduit.toml configuration file. Refer to + + for details on supported values. + Note that database_path can not be edited because the service's reliance on systemd StateDir. + ''; }; + }; - config = lib.mkIf cfg.enable { - systemd.services.conduit = { - description = "Conduit Matrix Server"; - documentation = [ "https://gitlab.com/famedly/conduit/" ]; - wantedBy = [ "multi-user.target" ]; - wants = [ "network-online.target" ]; - after = [ "network-online.target" ]; - environment = lib.mkMerge ([ - { CONDUIT_CONFIG = configFile; } - cfg.extraEnvironment - ]); - serviceConfig = { - DynamicUser = true; - User = "conduit"; - LockPersonality = true; - MemoryDenyWriteExecute = true; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - PrivateDevices = true; - PrivateMounts = true; - PrivateUsers = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; - RestrictNamespaces = true; - RestrictRealtime = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ - "@system-service" - "~@privileged" - ]; - StateDirectory = "matrix-conduit"; - StateDirectoryMode = "0700"; - ExecStart = "${cfg.package}/bin/conduit"; - Restart = "on-failure"; - RestartSec = 10; - StartLimitBurst = 5; - UMask = "077"; - }; + config = lib.mkIf cfg.enable { + systemd.services.conduit = { + description = "Conduit Matrix Server"; + documentation = [ "https://gitlab.com/famedly/conduit/" ]; + wantedBy = [ "multi-user.target" ]; + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; + environment = lib.mkMerge ([ + { CONDUIT_CONFIG = configFile; } + cfg.extraEnvironment + ]); + serviceConfig = { + DynamicUser = true; + User = "conduit"; + LockPersonality = true; + MemoryDenyWriteExecute = true; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + PrivateDevices = true; + PrivateMounts = true; + PrivateUsers = true; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; + StateDirectory = "matrix-conduit"; + StateDirectoryMode = "0700"; + ExecStart = "${cfg.package}/bin/conduit"; + Restart = "on-failure"; + RestartSec = 10; + StartLimitBurst = 5; + UMask = "077"; }; }; - } + }; +} diff --git a/nixos/modules/services/matrix/dendrite.nix b/nixos/modules/services/matrix/dendrite.nix index fdd91d77625470..2f17bb9f07276e 100644 --- a/nixos/modules/services/matrix/dendrite.nix +++ b/nixos/modules/services/matrix/dendrite.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.dendrite; settingsFormat = pkgs.formats.yaml { }; @@ -98,9 +103,7 @@ in ''; }; private_key = lib.mkOption { - type = lib.types.either - lib.types.path - (lib.types.strMatching "^\\$CREDENTIALS_DIRECTORY/.+"); + type = lib.types.either lib.types.path (lib.types.strMatching "^\\$CREDENTIALS_DIRECTORY/.+"); example = "$CREDENTIALS_DIRECTORY/private_key"; description = '' The path to the signing private key file, used to sign @@ -114,7 +117,10 @@ in trusted_third_party_id_servers = lib.mkOption { type = lib.types.listOf lib.types.str; example = [ "matrix.org" ]; - default = [ "matrix.org" "vector.im" ]; + default = [ + "matrix.org" + "vector.im" + ]; description = '' Lists of domains that the server will trust as identity servers to verify third party identifiers such as phone @@ -272,14 +278,16 @@ in }; config = lib.mkIf cfg.enable { - assertions = [{ - assertion = cfg.httpsPort != null -> (cfg.tlsCert != null && cfg.tlsKey != null); - message = '' - If Dendrite is configured to use https, tlsCert and tlsKey must be provided. + assertions = [ + { + assertion = cfg.httpsPort != null -> (cfg.tlsCert != null && cfg.tlsKey != null); + message = '' + If Dendrite is configured to use https, tlsCert and tlsKey must be provided. - nix-shell -p dendrite --command "generate-keys --tls-cert server.crt --tls-key server.key" - ''; - }]; + nix-shell -p dendrite --command "generate-keys --tls-cert server.crt --tls-key server.key" + ''; + } + ]; systemd.services.dendrite = { description = "Dendrite Matrix homeserver"; @@ -297,23 +305,30 @@ in LimitNOFILE = 65535; EnvironmentFile = lib.mkIf (cfg.environmentFile != null) cfg.environmentFile; LoadCredential = cfg.loadCredential; - ExecStartPre = ['' - ${pkgs.envsubst}/bin/envsubst \ - -i ${configurationYaml} \ - -o /run/dendrite/dendrite.yaml - '']; - ExecStart = lib.strings.concatStringsSep " " ([ - "${pkgs.dendrite}/bin/dendrite" - "--config /run/dendrite/dendrite.yaml" - ] ++ lib.optionals (cfg.httpPort != null) [ - "--http-bind-address :${builtins.toString cfg.httpPort}" - ] ++ lib.optionals (cfg.httpsPort != null) [ - "--https-bind-address :${builtins.toString cfg.httpsPort}" - "--tls-cert ${cfg.tlsCert}" - "--tls-key ${cfg.tlsKey}" - ] ++ lib.optionals cfg.openRegistration [ - "--really-enable-open-registration" - ]); + ExecStartPre = [ + '' + ${pkgs.envsubst}/bin/envsubst \ + -i ${configurationYaml} \ + -o /run/dendrite/dendrite.yaml + '' + ]; + ExecStart = lib.strings.concatStringsSep " " ( + [ + "${pkgs.dendrite}/bin/dendrite" + "--config /run/dendrite/dendrite.yaml" + ] + ++ lib.optionals (cfg.httpPort != null) [ + "--http-bind-address :${builtins.toString cfg.httpPort}" + ] + ++ lib.optionals (cfg.httpsPort != null) [ + "--https-bind-address :${builtins.toString cfg.httpsPort}" + "--tls-cert ${cfg.tlsCert}" + "--tls-key ${cfg.tlsKey}" + ] + ++ lib.optionals cfg.openRegistration [ + "--really-enable-open-registration" + ] + ); ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; Restart = "on-failure"; }; diff --git a/nixos/modules/services/matrix/maubot.nix b/nixos/modules/services/matrix/maubot.nix index 7aea88bd273d5d..6a7f36378e3d55 100644 --- a/nixos/modules/services/matrix/maubot.nix +++ b/nixos/modules/services/matrix/maubot.nix @@ -1,43 +1,45 @@ -{ lib -, config -, pkgs -, ... +{ + lib, + config, + pkgs, + ... }: let cfg = config.services.maubot; - wrapper1 = - if cfg.plugins == [ ] - then cfg.package - else cfg.package.withPlugins (_: cfg.plugins); + wrapper1 = if cfg.plugins == [ ] then cfg.package else cfg.package.withPlugins (_: cfg.plugins); wrapper2 = - if cfg.pythonPackages == [ ] - then wrapper1 - else wrapper1.withPythonPackages (_: cfg.pythonPackages); + if cfg.pythonPackages == [ ] then wrapper1 else wrapper1.withPythonPackages (_: cfg.pythonPackages); settings = lib.recursiveUpdate cfg.settings { plugin_directories.trash = - if cfg.settings.plugin_directories.trash == null - then "delete" - else cfg.settings.plugin_directories.trash; + if cfg.settings.plugin_directories.trash == null then + "delete" + else + cfg.settings.plugin_directories.trash; server.unshared_secret = "generate"; }; finalPackage = wrapper2.withBaseConfig settings; isPostgresql = db: builtins.isString db && lib.hasPrefix "postgresql://" db; - isLocalPostgresDB = db: isPostgresql db && builtins.any (x: lib.hasInfix x db) [ - "@127.0.0.1/" - "@::1/" - "@[::1]/" - "@localhost/" - ]; - parsePostgresDB = db: + isLocalPostgresDB = + db: + isPostgresql db + && builtins.any (x: lib.hasInfix x db) [ + "@127.0.0.1/" + "@::1/" + "@[::1]/" + "@localhost/" + ]; + parsePostgresDB = + db: let noSchema = lib.removePrefix "postgresql://" db; - in { + in + { username = builtins.head (lib.splitString "@" noSchema); database = lib.last (lib.splitString "/" noSchema); }; @@ -124,265 +126,274 @@ in Secrets should be passed in by using `extraConfigFile`. ''; - type = with types; submodule { - options = { - database = mkOption { - type = str; - default = "sqlite:maubot.db"; - example = "postgresql://username:password@hostname/dbname"; - description = '' - The full URI to the database. SQLite and Postgres are fully supported. - Other DBMSes supported by SQLAlchemy may or may not work. - ''; - }; + type = + with types; + submodule { + options = { + database = mkOption { + type = str; + default = "sqlite:maubot.db"; + example = "postgresql://username:password@hostname/dbname"; + description = '' + The full URI to the database. SQLite and Postgres are fully supported. + Other DBMSes supported by SQLAlchemy may or may not work. + ''; + }; - crypto_database = mkOption { - type = str; - default = "default"; - example = "postgresql://username:password@hostname/dbname"; - description = '' - Separate database URL for the crypto database. By default, the regular database is also used for crypto. - ''; - }; + crypto_database = mkOption { + type = str; + default = "default"; + example = "postgresql://username:password@hostname/dbname"; + description = '' + Separate database URL for the crypto database. By default, the regular database is also used for crypto. + ''; + }; - database_opts = mkOption { - type = types.attrs; - default = { }; - description = '' - Additional arguments for asyncpg.create_pool() or sqlite3.connect() - ''; - }; + database_opts = mkOption { + type = types.attrs; + default = { }; + description = '' + Additional arguments for asyncpg.create_pool() or sqlite3.connect() + ''; + }; - plugin_directories = mkOption { - default = { }; - description = "Plugin directory paths"; - type = submodule { - options = { - upload = mkOption { - type = types.str; - default = "./plugins"; - defaultText = literalExpression ''"''${config.services.maubot.dataDir}/plugins"''; - description = '' - The directory where uploaded new plugins should be stored. - ''; - }; - load = mkOption { - type = types.listOf types.str; - default = [ "./plugins" ]; - defaultText = literalExpression ''[ "''${config.services.maubot.dataDir}/plugins" ]''; - description = '' - The directories from which plugins should be loaded. Duplicate plugin IDs will be moved to the trash. - ''; - }; - trash = mkOption { - type = with types; nullOr str; - default = "./trash"; - defaultText = literalExpression ''"''${config.services.maubot.dataDir}/trash"''; - description = '' - The directory where old plugin versions and conflicting plugins should be moved. Set to null to delete files immediately. - ''; + plugin_directories = mkOption { + default = { }; + description = "Plugin directory paths"; + type = submodule { + options = { + upload = mkOption { + type = types.str; + default = "./plugins"; + defaultText = literalExpression ''"''${config.services.maubot.dataDir}/plugins"''; + description = '' + The directory where uploaded new plugins should be stored. + ''; + }; + load = mkOption { + type = types.listOf types.str; + default = [ "./plugins" ]; + defaultText = literalExpression ''[ "''${config.services.maubot.dataDir}/plugins" ]''; + description = '' + The directories from which plugins should be loaded. Duplicate plugin IDs will be moved to the trash. + ''; + }; + trash = mkOption { + type = with types; nullOr str; + default = "./trash"; + defaultText = literalExpression ''"''${config.services.maubot.dataDir}/trash"''; + description = '' + The directory where old plugin versions and conflicting plugins should be moved. Set to null to delete files immediately. + ''; + }; }; }; }; - }; - - plugin_databases = mkOption { - description = "Plugin database settings"; - default = { }; - type = submodule { - options = { - sqlite = mkOption { - type = types.str; - default = "./plugins"; - defaultText = literalExpression ''"''${config.services.maubot.dataDir}/plugins"''; - description = '' - The directory where SQLite plugin databases should be stored. - ''; - }; - - postgres = mkOption { - type = types.nullOr types.str; - default = if isPostgresql cfg.settings.database then "default" else null; - defaultText = literalExpression ''if isPostgresql config.services.maubot.settings.database then "default" else null''; - description = '' - The connection URL for plugin database. See [example config](https://github.com/maubot/maubot/blob/master/maubot/example-config.yaml) for exact format. - ''; - }; - - postgres_max_conns_per_plugin = mkOption { - type = types.nullOr types.int; - default = 3; - description = '' - Maximum number of connections per plugin instance. - ''; - }; - postgres_opts = mkOption { - type = types.attrs; - default = { }; - description = '' - Overrides for the default database_opts when using a non-default postgres connection URL. - ''; + plugin_databases = mkOption { + description = "Plugin database settings"; + default = { }; + type = submodule { + options = { + sqlite = mkOption { + type = types.str; + default = "./plugins"; + defaultText = literalExpression ''"''${config.services.maubot.dataDir}/plugins"''; + description = '' + The directory where SQLite plugin databases should be stored. + ''; + }; + + postgres = mkOption { + type = types.nullOr types.str; + default = if isPostgresql cfg.settings.database then "default" else null; + defaultText = literalExpression ''if isPostgresql config.services.maubot.settings.database then "default" else null''; + description = '' + The connection URL for plugin database. See [example config](https://github.com/maubot/maubot/blob/master/maubot/example-config.yaml) for exact format. + ''; + }; + + postgres_max_conns_per_plugin = mkOption { + type = types.nullOr types.int; + default = 3; + description = '' + Maximum number of connections per plugin instance. + ''; + }; + + postgres_opts = mkOption { + type = types.attrs; + default = { }; + description = '' + Overrides for the default database_opts when using a non-default postgres connection URL. + ''; + }; }; }; }; - }; - server = mkOption { - default = { }; - description = "Listener config"; - type = submodule { - options = { - hostname = mkOption { - type = types.str; - default = "127.0.0.1"; - description = '' - The IP to listen on - ''; - }; - port = mkOption { - type = types.port; - default = 29316; - description = '' - The port to listen on - ''; - }; - public_url = mkOption { - type = types.str; - default = "http://${cfg.settings.server.hostname}:${toString cfg.settings.server.port}"; - defaultText = literalExpression ''"http://''${config.services.maubot.settings.server.hostname}:''${toString config.services.maubot.settings.server.port}"''; - description = '' - Public base URL where the server is visible. - ''; - }; - ui_base_path = mkOption { - type = types.str; - default = "/_matrix/maubot"; - description = '' - The base path for the UI. - ''; - }; - plugin_base_path = mkOption { - type = types.str; - default = "${config.services.maubot.settings.server.ui_base_path}/plugin/"; - defaultText = literalExpression '' - "''${config.services.maubot.settings.server.ui_base_path}/plugin/" - ''; - description = '' - The base path for plugin endpoints. The instance ID will be appended directly. - ''; - }; - override_resource_path = mkOption { - type = types.nullOr types.str; - default = null; - description = '' - Override path from where to load UI resources. - ''; + server = mkOption { + default = { }; + description = "Listener config"; + type = submodule { + options = { + hostname = mkOption { + type = types.str; + default = "127.0.0.1"; + description = '' + The IP to listen on + ''; + }; + port = mkOption { + type = types.port; + default = 29316; + description = '' + The port to listen on + ''; + }; + public_url = mkOption { + type = types.str; + default = "http://${cfg.settings.server.hostname}:${toString cfg.settings.server.port}"; + defaultText = literalExpression ''"http://''${config.services.maubot.settings.server.hostname}:''${toString config.services.maubot.settings.server.port}"''; + description = '' + Public base URL where the server is visible. + ''; + }; + ui_base_path = mkOption { + type = types.str; + default = "/_matrix/maubot"; + description = '' + The base path for the UI. + ''; + }; + plugin_base_path = mkOption { + type = types.str; + default = "${config.services.maubot.settings.server.ui_base_path}/plugin/"; + defaultText = literalExpression '' + "''${config.services.maubot.settings.server.ui_base_path}/plugin/" + ''; + description = '' + The base path for plugin endpoints. The instance ID will be appended directly. + ''; + }; + override_resource_path = mkOption { + type = types.nullOr types.str; + default = null; + description = '' + Override path from where to load UI resources. + ''; + }; }; }; }; - }; - homeservers = mkOption { - type = types.attrsOf (types.submodule { - options = { - url = mkOption { - type = types.str; - description = '' - Client-server API URL - ''; + homeservers = mkOption { + type = types.attrsOf ( + types.submodule { + options = { + url = mkOption { + type = types.str; + description = '' + Client-server API URL + ''; + }; + }; + } + ); + default = { + "matrix.org" = { + url = "https://matrix-client.matrix.org"; }; }; - }); - default = { - "matrix.org" = { - url = "https://matrix-client.matrix.org"; - }; + description = '' + Known homeservers. This is required for the `mbc auth` command and also allows more convenient access from the management UI. + If you want to specify registration secrets, pass this via extraConfigFile instead. + ''; }; - description = '' - Known homeservers. This is required for the `mbc auth` command and also allows more convenient access from the management UI. - If you want to specify registration secrets, pass this via extraConfigFile instead. - ''; - }; - admins = mkOption { - type = types.attrsOf types.str; - default = { root = ""; }; - description = '' - List of administrator users. Plaintext passwords will be bcrypted on startup. Set empty password - to prevent normal login. Root is a special user that can't have a password and will always exist. - ''; - }; - - api_features = mkOption { - type = types.attrsOf bool; - default = { - login = true; - plugin = true; - plugin_upload = true; - instance = true; - instance_database = true; - client = true; - client_proxy = true; - client_auth = true; - dev_open = true; - log = true; + admins = mkOption { + type = types.attrsOf types.str; + default = { + root = ""; + }; + description = '' + List of administrator users. Plaintext passwords will be bcrypted on startup. Set empty password + to prevent normal login. Root is a special user that can't have a password and will always exist. + ''; }; - description = '' - API feature switches. - ''; - }; - logging = mkOption { - type = types.attrs; - description = '' - Python logging configuration. See [section 16.7.2 of the Python - documentation](https://docs.python.org/3.6/library/logging.config.html#configuration-dictionary-schema) - for more info. - ''; - default = { - version = 1; - formatters = { - colored = { - "()" = "maubot.lib.color_log.ColorFormatter"; - format = "[%(asctime)s] [%(levelname)s@%(name)s] %(message)s"; - }; - normal = { - format = "[%(asctime)s] [%(levelname)s@%(name)s] %(message)s"; - }; + api_features = mkOption { + type = types.attrsOf bool; + default = { + login = true; + plugin = true; + plugin_upload = true; + instance = true; + instance_database = true; + client = true; + client_proxy = true; + client_auth = true; + dev_open = true; + log = true; }; - handlers = { - file = { - class = "logging.handlers.RotatingFileHandler"; - formatter = "normal"; - filename = "./maubot.log"; - maxBytes = 10485760; - backupCount = 10; + description = '' + API feature switches. + ''; + }; + + logging = mkOption { + type = types.attrs; + description = '' + Python logging configuration. See [section 16.7.2 of the Python + documentation](https://docs.python.org/3.6/library/logging.config.html#configuration-dictionary-schema) + for more info. + ''; + default = { + version = 1; + formatters = { + colored = { + "()" = "maubot.lib.color_log.ColorFormatter"; + format = "[%(asctime)s] [%(levelname)s@%(name)s] %(message)s"; + }; + normal = { + format = "[%(asctime)s] [%(levelname)s@%(name)s] %(message)s"; + }; }; - console = { - class = "logging.StreamHandler"; - formatter = "colored"; + handlers = { + file = { + class = "logging.handlers.RotatingFileHandler"; + formatter = "normal"; + filename = "./maubot.log"; + maxBytes = 10485760; + backupCount = 10; + }; + console = { + class = "logging.StreamHandler"; + formatter = "colored"; + }; }; - }; - loggers = { - maubot = { - level = "DEBUG"; + loggers = { + maubot = { + level = "DEBUG"; + }; + mau = { + level = "DEBUG"; + }; + aiohttp = { + level = "INFO"; + }; }; - mau = { + root = { level = "DEBUG"; - }; - aiohttp = { - level = "INFO"; + handlers = [ + "file" + "console" + ]; }; }; - root = { - level = "DEBUG"; - handlers = [ "file" "console" ]; - }; }; }; }; - }; }; }; @@ -443,7 +454,9 @@ in ''; serviceConfig = { - ExecStart = "${finalPackage}/bin/maubot --config ${cfg.extraConfigFile}" + lib.optionalString (!cfg.configMutable) " --no-update"; + ExecStart = + "${finalPackage}/bin/maubot --config ${cfg.extraConfigFile}" + + lib.optionalString (!cfg.configMutable) " --no-update"; User = "maubot"; Group = "maubot"; Restart = "on-failure"; diff --git a/nixos/modules/services/matrix/mautrix-facebook.nix b/nixos/modules/services/matrix/mautrix-facebook.nix index 0e81b390732a9c..2368e4e39d1902 100644 --- a/nixos/modules/services/matrix/mautrix-facebook.nix +++ b/nixos/modules/services/matrix/mautrix-facebook.nix @@ -1,17 +1,19 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.mautrix-facebook; - settingsFormat = pkgs.formats.json {}; + settingsFormat = pkgs.formats.json { }; settingsFile = settingsFormat.generate "mautrix-facebook-config.json" cfg.settings; - puppetRegex = lib.concatStringsSep - ".*" - (map - lib.escapeRegex - (lib.splitString - "{userid}" - cfg.settings.bridge.username_template)); -in { + puppetRegex = lib.concatStringsSep ".*" ( + map lib.escapeRegex (lib.splitString "{userid}" cfg.settings.bridge.username_template) + ); +in +{ options = { services.mautrix-facebook = { enable = lib.mkEnableOption "Mautrix-Facebook, a Matrix-Facebook hybrid puppeting/relaybot bridge"; @@ -63,7 +65,7 @@ in { }; root = { level = "INFO"; - handlers = ["journal"]; + handlers = [ "journal" ]; }; }; }; @@ -110,7 +112,7 @@ in { registrationData = lib.mkOption { type = lib.types.attrs; - default = {}; + default = { }; description = '' Output data for appservice registration. Simply make any desired changes and serialize to JSON. Note that this data contains secrets so think twice before putting it into the nix store. @@ -121,7 +123,7 @@ in { }; config = lib.mkIf cfg.enable { - users.groups.mautrix-facebook = {}; + users.groups.mautrix-facebook = { }; users.users.mautrix-facebook = { group = "mautrix-facebook"; @@ -129,18 +131,22 @@ in { }; services.postgresql = lib.mkIf cfg.configurePostgresql { - ensureDatabases = ["mautrix-facebook"]; - ensureUsers = [{ - name = "mautrix-facebook"; - ensureDBOwnership = true; - }]; + ensureDatabases = [ "mautrix-facebook" ]; + ensureUsers = [ + { + name = "mautrix-facebook"; + ensureDBOwnership = true; + } + ]; }; systemd.services.mautrix-facebook = rec { wantedBy = [ "multi-user.target" ]; - wants = [ - "network-online.target" - ] ++ lib.optional config.services.matrix-synapse.enable config.services.matrix-synapse.serviceUnit + wants = + [ + "network-online.target" + ] + ++ lib.optional config.services.matrix-synapse.enable config.services.matrix-synapse.serviceUnit ++ lib.optional cfg.configurePostgresql "postgresql.service"; after = wants; @@ -180,7 +186,7 @@ in { regex = "@${puppetRegex}:${lib.escapeRegex cfg.settings.homeserver.domain}"; } ]; - aliases = []; + aliases = [ ]; }; url = cfg.settings.appservice.address; diff --git a/nixos/modules/services/matrix/mautrix-meta.nix b/nixos/modules/services/matrix/mautrix-meta.nix index 79f7239df9e5df..e64f1d923564ac 100644 --- a/nixos/modules/services/matrix/mautrix-meta.nix +++ b/nixos/modules/services/matrix/mautrix-meta.nix @@ -1,7 +1,12 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let - settingsFormat = pkgs.formats.yaml {}; + settingsFormat = pkgs.formats.yaml { }; upperConfig = config; cfg = config.services.mautrix-meta; @@ -14,254 +19,264 @@ let metaName = name: "mautrix-meta-${name}"; - enabledInstances = lib.filterAttrs (name: config: config.enable) config.services.mautrix-meta.instances; - registerToSynapseInstances = lib.filterAttrs (name: config: config.enable && config.registerToSynapse) config.services.mautrix-meta.instances; -in { + enabledInstances = lib.filterAttrs ( + name: config: config.enable + ) config.services.mautrix-meta.instances; + registerToSynapseInstances = lib.filterAttrs ( + name: config: config.enable && config.registerToSynapse + ) config.services.mautrix-meta.instances; +in +{ options = { services.mautrix-meta = { package = lib.mkPackageOption pkgs "mautrix-meta" { }; instances = lib.mkOption { - type = lib.types.attrsOf (lib.types.submodule ({ config, name, ... }: { - - options = { - - enable = lib.mkEnableOption "Mautrix-Meta, a Matrix <-> Facebook and Matrix <-> Instagram hybrid puppeting/relaybot bridge"; - - dataDir = lib.mkOption { - type = lib.types.str; - default = metaName name; - description = '' - Path to the directory with database, registration, and other data for the bridge service. - This path is relative to `/var/lib`, it cannot start with `../` (it cannot be outside of `/var/lib`). - ''; - }; - - registrationFile = lib.mkOption { - type = lib.types.path; - readOnly = true; - description = '' - Path to the yaml registration file of the appservice. - ''; - }; - - registerToSynapse = lib.mkOption { - type = lib.types.bool; - default = true; - description = '' - Whether to add registration file to `services.matrix-synapse.settings.app_service_config_files` and - make Synapse wait for registration service. - ''; - }; - - settings = lib.mkOption rec { - apply = lib.recursiveUpdate default; - inherit (settingsFormat) type; - default = { - homeserver = { - software = "standard"; - - domain = ""; - address = ""; + type = lib.types.attrsOf ( + lib.types.submodule ( + { config, name, ... }: + { + + options = { + + enable = lib.mkEnableOption "Mautrix-Meta, a Matrix <-> Facebook and Matrix <-> Instagram hybrid puppeting/relaybot bridge"; + + dataDir = lib.mkOption { + type = lib.types.str; + default = metaName name; + description = '' + Path to the directory with database, registration, and other data for the bridge service. + This path is relative to `/var/lib`, it cannot start with `../` (it cannot be outside of `/var/lib`). + ''; }; - appservice = { - id = ""; - - bot = { - username = ""; - }; - - hostname = "localhost"; - port = 29319; - address = "http://${config.settings.appservice.hostname}:${toString config.settings.appservice.port}"; + registrationFile = lib.mkOption { + type = lib.types.path; + readOnly = true; + description = '' + Path to the yaml registration file of the appservice. + ''; }; - bridge = { - permissions = {}; + registerToSynapse = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Whether to add registration file to `services.matrix-synapse.settings.app_service_config_files` and + make Synapse wait for registration service. + ''; }; - database = { - type = "sqlite3-fk-wal"; - uri = "file:${fullDataDir config}/mautrix-meta.db?_txlock=immediate"; - }; + settings = lib.mkOption rec { + apply = lib.recursiveUpdate default; + inherit (settingsFormat) type; + default = { + homeserver = { + software = "standard"; - # Enable encryption by default to make the bridge more secure - encryption = { - allow = true; - default = true; - require = true; - - # Recommended options from mautrix documentation - # for additional security. - delete_keys = { - dont_store_outbound = true; - ratchet_on_decrypt = true; - delete_fully_used_on_decrypt = true; - delete_prev_on_new_session = true; - delete_on_device_delete = true; - periodically_delete_expired = true; - delete_outdated_inbound = true; - }; + domain = ""; + address = ""; + }; - # TODO: This effectively disables encryption. But this is the value provided when a <0.4 config is migrated. Changing it will corrupt the database. - # https://github.com/mautrix/meta/blob/f5440b05aac125b4c95b1af85635a717cbc6dd0e/cmd/mautrix-meta/legacymigrate.go#L24 - # If you wish to encrypt the local database you should set this to an environment variable substitution and reset the bridge or somehow migrate the DB. - pickle_key = "mautrix.bridge.e2ee"; + appservice = { + id = ""; - verification_levels = { - receive = "cross-signed-tofu"; - send = "cross-signed-tofu"; - share = "cross-signed-tofu"; - }; - }; + bot = { + username = ""; + }; - logging = { - min_level = "info"; - writers = lib.singleton { - type = "stdout"; - format = "pretty-colored"; - time_format = " "; - }; - }; - - network = { - mode = ""; - }; - }; - defaultText = '' - { - homeserver = { - software = "standard"; - address = "https://''${config.settings.homeserver.domain}"; - }; + hostname = "localhost"; + port = 29319; + address = "http://${config.settings.appservice.hostname}:${toString config.settings.appservice.port}"; + }; - appservice = { - database = { - type = "sqlite3-fk-wal"; - uri = "file:''${fullDataDir config}/mautrix-meta.db?_txlock=immediate"; - }; + bridge = { + permissions = { }; + }; - hostname = "localhost"; - port = 29319; - address = "http://''${config.settings.appservice.hostname}:''${toString config.settings.appservice.port}"; - }; + database = { + type = "sqlite3-fk-wal"; + uri = "file:${fullDataDir config}/mautrix-meta.db?_txlock=immediate"; + }; - bridge = { - # Require encryption by default to make the bridge more secure - encryption = { - allow = true; - default = true; - require = true; - - # Recommended options from mautrix documentation - # for optimal security. - delete_keys = { - dont_store_outbound = true; - ratchet_on_decrypt = true; - delete_fully_used_on_decrypt = true; - delete_prev_on_new_session = true; - delete_on_device_delete = true; - periodically_delete_expired = true; - delete_outdated_inbound = true; + # Enable encryption by default to make the bridge more secure + encryption = { + allow = true; + default = true; + require = true; + + # Recommended options from mautrix documentation + # for additional security. + delete_keys = { + dont_store_outbound = true; + ratchet_on_decrypt = true; + delete_fully_used_on_decrypt = true; + delete_prev_on_new_session = true; + delete_on_device_delete = true; + periodically_delete_expired = true; + delete_outdated_inbound = true; + }; + + # TODO: This effectively disables encryption. But this is the value provided when a <0.4 config is migrated. Changing it will corrupt the database. + # https://github.com/mautrix/meta/blob/f5440b05aac125b4c95b1af85635a717cbc6dd0e/cmd/mautrix-meta/legacymigrate.go#L24 + # If you wish to encrypt the local database you should set this to an environment variable substitution and reset the bridge or somehow migrate the DB. + pickle_key = "mautrix.bridge.e2ee"; + + verification_levels = { + receive = "cross-signed-tofu"; + send = "cross-signed-tofu"; + share = "cross-signed-tofu"; + }; }; - verification_levels = { - receive = "cross-signed-tofu"; - send = "cross-signed-tofu"; - share = "cross-signed-tofu"; + logging = { + min_level = "info"; + writers = lib.singleton { + type = "stdout"; + format = "pretty-colored"; + time_format = " "; + }; }; - }; - }; - logging = { - min_level = "info"; - writers = lib.singleton { - type = "stdout"; - format = "pretty-colored"; - time_format = " "; + network = { + mode = ""; + }; }; + defaultText = '' + { + homeserver = { + software = "standard"; + address = "https://''${config.settings.homeserver.domain}"; + }; + + appservice = { + database = { + type = "sqlite3-fk-wal"; + uri = "file:''${fullDataDir config}/mautrix-meta.db?_txlock=immediate"; + }; + + hostname = "localhost"; + port = 29319; + address = "http://''${config.settings.appservice.hostname}:''${toString config.settings.appservice.port}"; + }; + + bridge = { + # Require encryption by default to make the bridge more secure + encryption = { + allow = true; + default = true; + require = true; + + # Recommended options from mautrix documentation + # for optimal security. + delete_keys = { + dont_store_outbound = true; + ratchet_on_decrypt = true; + delete_fully_used_on_decrypt = true; + delete_prev_on_new_session = true; + delete_on_device_delete = true; + periodically_delete_expired = true; + delete_outdated_inbound = true; + }; + + verification_levels = { + receive = "cross-signed-tofu"; + send = "cross-signed-tofu"; + share = "cross-signed-tofu"; + }; + }; + }; + + logging = { + min_level = "info"; + writers = lib.singleton { + type = "stdout"; + format = "pretty-colored"; + time_format = " "; + }; + }; + }; + ''; + description = '' + {file}`config.yaml` configuration as a Nix attribute set. + Configuration options should match those described in + [example-config.yaml](https://github.com/mautrix/meta/blob/main/example-config.yaml). + + Secret tokens should be specified using {option}`environmentFile` + instead + ''; }; - }; - ''; - description = '' - {file}`config.yaml` configuration as a Nix attribute set. - Configuration options should match those described in - [example-config.yaml](https://github.com/mautrix/meta/blob/main/example-config.yaml). - - Secret tokens should be specified using {option}`environmentFile` - instead - ''; - }; - environmentFile = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; - description = '' - File containing environment variables to substitute when copying the configuration - out of Nix store to the `services.mautrix-meta.dataDir`. + environmentFile = lib.mkOption { + type = lib.types.nullOr lib.types.path; + default = null; + description = '' + File containing environment variables to substitute when copying the configuration + out of Nix store to the `services.mautrix-meta.dataDir`. - Can be used for storing the secrets without making them available in the Nix store. + Can be used for storing the secrets without making them available in the Nix store. - For example, you can set `services.mautrix-meta.settings.appservice.as_token = "$MAUTRIX_META_APPSERVICE_AS_TOKEN"` - and then specify `MAUTRIX_META_APPSERVICE_AS_TOKEN="{token}"` in the environment file. - This value will get substituted into the configuration file as as token. - ''; - }; + For example, you can set `services.mautrix-meta.settings.appservice.as_token = "$MAUTRIX_META_APPSERVICE_AS_TOKEN"` + and then specify `MAUTRIX_META_APPSERVICE_AS_TOKEN="{token}"` in the environment file. + This value will get substituted into the configuration file as as token. + ''; + }; - serviceDependencies = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = - [ config.registrationServiceUnit ] ++ - (lib.lists.optional upperConfig.services.matrix-synapse.enable upperConfig.services.matrix-synapse.serviceUnit) ++ - (lib.lists.optional upperConfig.services.matrix-conduit.enable "matrix-conduit.service") ++ - (lib.lists.optional upperConfig.services.dendrite.enable "dendrite.service"); - - defaultText = '' - [ config.registrationServiceUnit ] ++ - (lib.lists.optional upperConfig.services.matrix-synapse.enable upperConfig.services.matrix-synapse.serviceUnit) ++ - (lib.lists.optional upperConfig.services.matrix-conduit.enable "matrix-conduit.service") ++ - (lib.lists.optional upperConfig.services.dendrite.enable "dendrite.service"); - ''; - description = '' - List of Systemd services to require and wait for when starting the application service. - ''; - }; + serviceDependencies = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = + [ config.registrationServiceUnit ] + ++ (lib.lists.optional upperConfig.services.matrix-synapse.enable upperConfig.services.matrix-synapse.serviceUnit) + ++ (lib.lists.optional upperConfig.services.matrix-conduit.enable "matrix-conduit.service") + ++ (lib.lists.optional upperConfig.services.dendrite.enable "dendrite.service"); + + defaultText = '' + [ config.registrationServiceUnit ] ++ + (lib.lists.optional upperConfig.services.matrix-synapse.enable upperConfig.services.matrix-synapse.serviceUnit) ++ + (lib.lists.optional upperConfig.services.matrix-conduit.enable "matrix-conduit.service") ++ + (lib.lists.optional upperConfig.services.dendrite.enable "dendrite.service"); + ''; + description = '' + List of Systemd services to require and wait for when starting the application service. + ''; + }; - serviceUnit = lib.mkOption { - type = lib.types.str; - readOnly = true; - description = '' - The systemd unit (a service or a target) for other services to depend on if they - need to be started after matrix-synapse. + serviceUnit = lib.mkOption { + type = lib.types.str; + readOnly = true; + description = '' + The systemd unit (a service or a target) for other services to depend on if they + need to be started after matrix-synapse. - This option is useful as the actual parent unit for all matrix-synapse processes - changes when configuring workers. - ''; - }; + This option is useful as the actual parent unit for all matrix-synapse processes + changes when configuring workers. + ''; + }; - registrationServiceUnit = lib.mkOption { - type = lib.types.str; - readOnly = true; - description = '' - The registration service that generates the registration file. + registrationServiceUnit = lib.mkOption { + type = lib.types.str; + readOnly = true; + description = '' + The registration service that generates the registration file. - Systemd unit (a service or a target) for other services to depend on if they - need to be started after mautrix-meta registration service. + Systemd unit (a service or a target) for other services to depend on if they + need to be started after mautrix-meta registration service. - This option is useful as the actual parent unit for all matrix-synapse processes - changes when configuring workers. - ''; - }; - }; + This option is useful as the actual parent unit for all matrix-synapse processes + changes when configuring workers. + ''; + }; + }; - config = { - serviceUnit = (metaName name) + ".service"; - registrationServiceUnit = (metaName name) + "-registration.service"; - registrationFile = (fullDataDir config) + "/meta-registration.yaml"; - }; - })); + config = { + serviceUnit = (metaName name) + ".service"; + registrationServiceUnit = (metaName name) + "-registration.service"; + registrationFile = (fullDataDir config) + "/meta-registration.yaml"; + }; + } + ) + ); description = '' Configuration of multiple `mautrix-meta` instances. @@ -307,271 +322,299 @@ in { }; config = lib.mkMerge [ - (lib.mkIf (enabledInstances != {}) { - assertions = lib.mkMerge (lib.attrValues (lib.mapAttrs (name: cfg: [ - { - assertion = cfg.settings.homeserver.domain != "" && cfg.settings.homeserver.address != ""; - message = '' - The options with information about the homeserver: - `services.mautrix-meta.instances.${name}.settings.homeserver.domain` and - `services.mautrix-meta.instances.${name}.settings.homeserver.address` have to be set. - ''; - } - { - assertion = builtins.elem cfg.settings.network.mode [ "facebook" "facebook-tor" "messenger" "instagram" ]; - message = '' - The option `services.mautrix-meta.instances.${name}.settings.network.mode` has to be set - to one of: facebook, facebook-tor, messenger, instagram. - This configures the mode of the bridge. - ''; - } - { - assertion = cfg.settings.bridge.permissions != {}; - message = '' - The option `services.mautrix-meta.instances.${name}.settings.bridge.permissions` has to be set. - ''; - } - { - assertion = cfg.settings.appservice.id != ""; - message = '' - The option `services.mautrix-meta.instances.${name}.settings.appservice.id` has to be set. - ''; - } - { - assertion = cfg.settings.appservice.bot.username != ""; - message = '' - The option `services.mautrix-meta.instances.${name}.settings.appservice.bot.username` has to be set. - ''; - } - { - assertion = !(cfg.settings ? bridge.disable_xma); - message = '' - The option `bridge.disable_xma` has been moved to `network.disable_xma_always`. Please [migrate your configuration](https://github.com/mautrix/meta/releases/tag/v0.4.0). You may wish to use [the auto-migration code](https://github.com/mautrix/meta/blob/f5440b05aac125b4c95b1af85635a717cbc6dd0e/cmd/mautrix-meta/legacymigrate.go#L23) for reference. - ''; - } - { - assertion = !(cfg.settings ? bridge.displayname_template); - message = '' - The option `bridge.displayname_template` has been moved to `network.displayname_template`. Please [migrate your configuration](https://github.com/mautrix/meta/releases/tag/v0.4.0). You may wish to use [the auto-migration code](https://github.com/mautrix/meta/blob/f5440b05aac125b4c95b1af85635a717cbc6dd0e/cmd/mautrix-meta/legacymigrate.go#L23) for reference. - ''; - } - { - assertion = !(cfg.settings ? meta); - message = '' - The options in `meta` have been moved to `network`. Please [migrate your configuration](https://github.com/mautrix/meta/releases/tag/v0.4.0). You may wish to use [the auto-migration code](https://github.com/mautrix/meta/blob/f5440b05aac125b4c95b1af85635a717cbc6dd0e/cmd/mautrix-meta/legacymigrate.go#L23) for reference. - ''; + (lib.mkIf (enabledInstances != { }) { + assertions = lib.mkMerge ( + lib.attrValues ( + lib.mapAttrs (name: cfg: [ + { + assertion = cfg.settings.homeserver.domain != "" && cfg.settings.homeserver.address != ""; + message = '' + The options with information about the homeserver: + `services.mautrix-meta.instances.${name}.settings.homeserver.domain` and + `services.mautrix-meta.instances.${name}.settings.homeserver.address` have to be set. + ''; + } + { + assertion = builtins.elem cfg.settings.network.mode [ + "facebook" + "facebook-tor" + "messenger" + "instagram" + ]; + message = '' + The option `services.mautrix-meta.instances.${name}.settings.network.mode` has to be set + to one of: facebook, facebook-tor, messenger, instagram. + This configures the mode of the bridge. + ''; + } + { + assertion = cfg.settings.bridge.permissions != { }; + message = '' + The option `services.mautrix-meta.instances.${name}.settings.bridge.permissions` has to be set. + ''; + } + { + assertion = cfg.settings.appservice.id != ""; + message = '' + The option `services.mautrix-meta.instances.${name}.settings.appservice.id` has to be set. + ''; + } + { + assertion = cfg.settings.appservice.bot.username != ""; + message = '' + The option `services.mautrix-meta.instances.${name}.settings.appservice.bot.username` has to be set. + ''; + } + { + assertion = !(cfg.settings ? bridge.disable_xma); + message = '' + The option `bridge.disable_xma` has been moved to `network.disable_xma_always`. Please [migrate your configuration](https://github.com/mautrix/meta/releases/tag/v0.4.0). You may wish to use [the auto-migration code](https://github.com/mautrix/meta/blob/f5440b05aac125b4c95b1af85635a717cbc6dd0e/cmd/mautrix-meta/legacymigrate.go#L23) for reference. + ''; + } + { + assertion = !(cfg.settings ? bridge.displayname_template); + message = '' + The option `bridge.displayname_template` has been moved to `network.displayname_template`. Please [migrate your configuration](https://github.com/mautrix/meta/releases/tag/v0.4.0). You may wish to use [the auto-migration code](https://github.com/mautrix/meta/blob/f5440b05aac125b4c95b1af85635a717cbc6dd0e/cmd/mautrix-meta/legacymigrate.go#L23) for reference. + ''; + } + { + assertion = !(cfg.settings ? meta); + message = '' + The options in `meta` have been moved to `network`. Please [migrate your configuration](https://github.com/mautrix/meta/releases/tag/v0.4.0). You may wish to use [the auto-migration code](https://github.com/mautrix/meta/blob/f5440b05aac125b4c95b1af85635a717cbc6dd0e/cmd/mautrix-meta/legacymigrate.go#L23) for reference. + ''; + } + ]) enabledInstances + ) + ); + + users.users = lib.mapAttrs' ( + name: cfg: + lib.nameValuePair "mautrix-meta-${name}" { + isSystemUser = true; + group = "mautrix-meta"; + extraGroups = [ "mautrix-meta-registration" ]; + description = "Mautrix-Meta-${name} bridge user"; } - ]) enabledInstances)); - - users.users = lib.mapAttrs' (name: cfg: lib.nameValuePair "mautrix-meta-${name}" { - isSystemUser = true; - group = "mautrix-meta"; - extraGroups = [ "mautrix-meta-registration" ]; - description = "Mautrix-Meta-${name} bridge user"; - }) enabledInstances; + ) enabledInstances; - users.groups.mautrix-meta = {}; + users.groups.mautrix-meta = { }; users.groups.mautrix-meta-registration = { members = lib.lists.optional config.services.matrix-synapse.enable "matrix-synapse"; }; - services.matrix-synapse = lib.mkIf (config.services.matrix-synapse.enable) (let - registrationFiles = lib.attrValues - (lib.mapAttrs (name: cfg: cfg.registrationFile) registerToSynapseInstances); - in { - settings.app_service_config_files = registrationFiles; - }); + services.matrix-synapse = lib.mkIf (config.services.matrix-synapse.enable) ( + let + registrationFiles = lib.attrValues ( + lib.mapAttrs (name: cfg: cfg.registrationFile) registerToSynapseInstances + ); + in + { + settings.app_service_config_files = registrationFiles; + } + ); systemd.services = lib.mkMerge [ { - matrix-synapse = lib.mkIf (config.services.matrix-synapse.enable) (let - registrationServices = lib.attrValues - (lib.mapAttrs (name: cfg: cfg.registrationServiceUnit) registerToSynapseInstances); - in { - wants = registrationServices; - after = registrationServices; - }); + matrix-synapse = lib.mkIf (config.services.matrix-synapse.enable) ( + let + registrationServices = lib.attrValues ( + lib.mapAttrs (name: cfg: cfg.registrationServiceUnit) registerToSynapseInstances + ); + in + { + wants = registrationServices; + after = registrationServices; + } + ); } - (lib.mapAttrs' (name: cfg: lib.nameValuePair "${metaName name}-registration" { - description = "Mautrix-Meta registration generation service - ${metaName name}"; - - path = [ - pkgs.yq - pkgs.envsubst - upperCfg.package - ]; - - script = '' - # substitute the settings file by environment variables - # in this case read from EnvironmentFile - rm -f '${settingsFile cfg}' - old_umask=$(umask) - umask 0177 - envsubst \ - -o '${settingsFile cfg}' \ - -i '${settingsFileUnsubstituted cfg}' - - config_has_tokens=$(yq '.appservice | has("as_token") and has("hs_token")' '${settingsFile cfg}') - registration_already_exists=$([[ -f '${cfg.registrationFile}' ]] && echo "true" || echo "false") - - echo "There are tokens in the config: $config_has_tokens" - echo "Registration already existed: $registration_already_exists" - - # tokens not configured from config/environment file, and registration file - # is already generated, override tokens in config to make sure they are not lost - if [[ $config_has_tokens == "false" && $registration_already_exists == "true" ]]; then - echo "Copying as_token, hs_token from registration into configuration" - yq -sY '.[0].appservice.as_token = .[1].as_token - | .[0].appservice.hs_token = .[1].hs_token - | .[0]' '${settingsFile cfg}' '${cfg.registrationFile}' \ - > '${settingsFile cfg}.tmp' - mv '${settingsFile cfg}.tmp' '${settingsFile cfg}' - fi - - # make sure --generate-registration does not affect config.yaml - cp '${settingsFile cfg}' '${settingsFile cfg}.tmp' - - echo "Generating registration file" - mautrix-meta \ - --generate-registration \ - --config='${settingsFile cfg}.tmp' \ - --registration='${cfg.registrationFile}' - - rm '${settingsFile cfg}.tmp' - - # no tokens configured, and new were just generated by generate registration for first time - if [[ $config_has_tokens == "false" && $registration_already_exists == "false" ]]; then - echo "Copying newly generated as_token, hs_token from registration into configuration" - yq -sY '.[0].appservice.as_token = .[1].as_token - | .[0].appservice.hs_token = .[1].hs_token - | .[0]' '${settingsFile cfg}' '${cfg.registrationFile}' \ - > '${settingsFile cfg}.tmp' - mv '${settingsFile cfg}.tmp' '${settingsFile cfg}' - fi - - # Make sure correct tokens are in the registration file - if [[ $config_has_tokens == "true" || $registration_already_exists == "true" ]]; then - echo "Copying as_token, hs_token from configuration to the registration file" - yq -sY '.[1].as_token = .[0].appservice.as_token - | .[1].hs_token = .[0].appservice.hs_token - | .[1]' '${settingsFile cfg}' '${cfg.registrationFile}' \ - > '${cfg.registrationFile}.tmp' - mv '${cfg.registrationFile}.tmp' '${cfg.registrationFile}' - fi - - umask $old_umask - - chown :mautrix-meta-registration '${cfg.registrationFile}' - chmod 640 '${cfg.registrationFile}' - ''; - - serviceConfig = { - Type = "oneshot"; - UMask = 0027; - - User = "mautrix-meta-${name}"; - Group = "mautrix-meta"; - - SystemCallFilter = [ "@system-service" ]; - - ProtectSystem = "strict"; - ProtectHome = true; - - ReadWritePaths = fullDataDir cfg; - StateDirectory = cfg.dataDir; - EnvironmentFile = cfg.environmentFile; - }; + (lib.mapAttrs' ( + name: cfg: + lib.nameValuePair "${metaName name}-registration" { + description = "Mautrix-Meta registration generation service - ${metaName name}"; - restartTriggers = [ (settingsFileUnsubstituted cfg) ]; - }) enabledInstances) - - (lib.mapAttrs' (name: cfg: lib.nameValuePair "${metaName name}" { - description = "Mautrix-Meta bridge - ${metaName name}"; - wantedBy = [ "multi-user.target" ]; - wants = [ "network-online.target" ] ++ cfg.serviceDependencies; - after = [ "network-online.target" ] ++ cfg.serviceDependencies; - - serviceConfig = { - Type = "simple"; - - User = "mautrix-meta-${name}"; - Group = "mautrix-meta"; - PrivateUsers = true; - - LockPersonality = true; - MemoryDenyWriteExecute = true; - NoNewPrivileges = true; - PrivateDevices = true; - PrivateTmp = true; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectSystem = "strict"; - Restart = "on-failure"; - RestartSec = "30s"; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallErrorNumber = "EPERM"; - SystemCallFilter = ["@system-service"]; - UMask = 0027; - - WorkingDirectory = fullDataDir cfg; - ReadWritePaths = fullDataDir cfg; - StateDirectory = cfg.dataDir; - EnvironmentFile = cfg.environmentFile; - - ExecStart = lib.escapeShellArgs [ - (lib.getExe upperCfg.package) - "--config=${settingsFile cfg}" + path = [ + pkgs.yq + pkgs.envsubst + upperCfg.package ]; - }; - restartTriggers = [ (settingsFileUnsubstituted cfg) ]; - }) enabledInstances) + + script = '' + # substitute the settings file by environment variables + # in this case read from EnvironmentFile + rm -f '${settingsFile cfg}' + old_umask=$(umask) + umask 0177 + envsubst \ + -o '${settingsFile cfg}' \ + -i '${settingsFileUnsubstituted cfg}' + + config_has_tokens=$(yq '.appservice | has("as_token") and has("hs_token")' '${settingsFile cfg}') + registration_already_exists=$([[ -f '${cfg.registrationFile}' ]] && echo "true" || echo "false") + + echo "There are tokens in the config: $config_has_tokens" + echo "Registration already existed: $registration_already_exists" + + # tokens not configured from config/environment file, and registration file + # is already generated, override tokens in config to make sure they are not lost + if [[ $config_has_tokens == "false" && $registration_already_exists == "true" ]]; then + echo "Copying as_token, hs_token from registration into configuration" + yq -sY '.[0].appservice.as_token = .[1].as_token + | .[0].appservice.hs_token = .[1].hs_token + | .[0]' '${settingsFile cfg}' '${cfg.registrationFile}' \ + > '${settingsFile cfg}.tmp' + mv '${settingsFile cfg}.tmp' '${settingsFile cfg}' + fi + + # make sure --generate-registration does not affect config.yaml + cp '${settingsFile cfg}' '${settingsFile cfg}.tmp' + + echo "Generating registration file" + mautrix-meta \ + --generate-registration \ + --config='${settingsFile cfg}.tmp' \ + --registration='${cfg.registrationFile}' + + rm '${settingsFile cfg}.tmp' + + # no tokens configured, and new were just generated by generate registration for first time + if [[ $config_has_tokens == "false" && $registration_already_exists == "false" ]]; then + echo "Copying newly generated as_token, hs_token from registration into configuration" + yq -sY '.[0].appservice.as_token = .[1].as_token + | .[0].appservice.hs_token = .[1].hs_token + | .[0]' '${settingsFile cfg}' '${cfg.registrationFile}' \ + > '${settingsFile cfg}.tmp' + mv '${settingsFile cfg}.tmp' '${settingsFile cfg}' + fi + + # Make sure correct tokens are in the registration file + if [[ $config_has_tokens == "true" || $registration_already_exists == "true" ]]; then + echo "Copying as_token, hs_token from configuration to the registration file" + yq -sY '.[1].as_token = .[0].appservice.as_token + | .[1].hs_token = .[0].appservice.hs_token + | .[1]' '${settingsFile cfg}' '${cfg.registrationFile}' \ + > '${cfg.registrationFile}.tmp' + mv '${cfg.registrationFile}.tmp' '${cfg.registrationFile}' + fi + + umask $old_umask + + chown :mautrix-meta-registration '${cfg.registrationFile}' + chmod 640 '${cfg.registrationFile}' + ''; + + serviceConfig = { + Type = "oneshot"; + UMask = 27; + + User = "mautrix-meta-${name}"; + Group = "mautrix-meta"; + + SystemCallFilter = [ "@system-service" ]; + + ProtectSystem = "strict"; + ProtectHome = true; + + ReadWritePaths = fullDataDir cfg; + StateDirectory = cfg.dataDir; + EnvironmentFile = cfg.environmentFile; + }; + + restartTriggers = [ (settingsFileUnsubstituted cfg) ]; + } + ) enabledInstances) + + (lib.mapAttrs' ( + name: cfg: + lib.nameValuePair "${metaName name}" { + description = "Mautrix-Meta bridge - ${metaName name}"; + wantedBy = [ "multi-user.target" ]; + wants = [ "network-online.target" ] ++ cfg.serviceDependencies; + after = [ "network-online.target" ] ++ cfg.serviceDependencies; + + serviceConfig = { + Type = "simple"; + + User = "mautrix-meta-${name}"; + Group = "mautrix-meta"; + PrivateUsers = true; + + LockPersonality = true; + MemoryDenyWriteExecute = true; + NoNewPrivileges = true; + PrivateDevices = true; + PrivateTmp = true; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectSystem = "strict"; + Restart = "on-failure"; + RestartSec = "30s"; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallErrorNumber = "EPERM"; + SystemCallFilter = [ "@system-service" ]; + UMask = 27; + + WorkingDirectory = fullDataDir cfg; + ReadWritePaths = fullDataDir cfg; + StateDirectory = cfg.dataDir; + EnvironmentFile = cfg.environmentFile; + + ExecStart = lib.escapeShellArgs [ + (lib.getExe upperCfg.package) + "--config=${settingsFile cfg}" + ]; + }; + restartTriggers = [ (settingsFileUnsubstituted cfg) ]; + } + ) enabledInstances) ]; }) { - services.mautrix-meta.instances = let - inherit (lib.modules) mkDefault; - in { - instagram = { - settings = { - network.mode = mkDefault "instagram"; - - appservice = { - id = mkDefault "instagram"; - port = mkDefault 29320; - bot = { - username = mkDefault "instagrambot"; - displayname = mkDefault "Instagram bridge bot"; - avatar = mkDefault "mxc://maunium.net/JxjlbZUlCPULEeHZSwleUXQv"; + services.mautrix-meta.instances = + let + inherit (lib.modules) mkDefault; + in + { + instagram = { + settings = { + network.mode = mkDefault "instagram"; + + appservice = { + id = mkDefault "instagram"; + port = mkDefault 29320; + bot = { + username = mkDefault "instagrambot"; + displayname = mkDefault "Instagram bridge bot"; + avatar = mkDefault "mxc://maunium.net/JxjlbZUlCPULEeHZSwleUXQv"; + }; + username_template = mkDefault "instagram_{{.}}"; }; - username_template = mkDefault "instagram_{{.}}"; }; }; - }; - facebook = { - settings = { - network.mode = mkDefault "facebook"; - - appservice = { - id = mkDefault "facebook"; - port = mkDefault 29321; - bot = { - username = mkDefault "facebookbot"; - displayname = mkDefault "Facebook bridge bot"; - avatar = mkDefault "mxc://maunium.net/ygtkteZsXnGJLJHRchUwYWak"; + facebook = { + settings = { + network.mode = mkDefault "facebook"; + + appservice = { + id = mkDefault "facebook"; + port = mkDefault 29321; + bot = { + username = mkDefault "facebookbot"; + displayname = mkDefault "Facebook bridge bot"; + avatar = mkDefault "mxc://maunium.net/ygtkteZsXnGJLJHRchUwYWak"; + }; + username_template = mkDefault "facebook_{{.}}"; }; - username_template = mkDefault "facebook_{{.}}"; }; }; }; - }; } ]; diff --git a/nixos/modules/services/matrix/mautrix-telegram.nix b/nixos/modules/services/matrix/mautrix-telegram.nix index 699f5dfa0a2b49..0dd0636bf6f016 100644 --- a/nixos/modules/services/matrix/mautrix-telegram.nix +++ b/nixos/modules/services/matrix/mautrix-telegram.nix @@ -1,13 +1,18 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let dataDir = "/var/lib/mautrix-telegram"; registrationFile = "${dataDir}/telegram-registration.yaml"; cfg = config.services.mautrix-telegram; - settingsFormat = pkgs.formats.json {}; - settingsFile = - settingsFormat.generate "mautrix-telegram-config.json" cfg.settings; + settingsFormat = pkgs.formats.json { }; + settingsFile = settingsFormat.generate "mautrix-telegram-config.json" cfg.settings; -in { +in +{ options = { services.mautrix-telegram = { enable = lib.mkEnableOption "Mautrix-Telegram, a Matrix-Telegram hybrid puppeting/relaybot bridge"; @@ -22,7 +27,7 @@ in { appservice = rec { database = "sqlite:///${dataDir}/mautrix-telegram.db"; - database_opts = {}; + database_opts = { }; hostname = "0.0.0.0"; port = 8080; address = "http://localhost:${toString port}"; @@ -31,8 +36,8 @@ in { bridge = { permissions."*" = "relaybot"; relaybot.whitelist = [ ]; - double_puppet_server_map = {}; - login_shared_secret_map = {}; + double_puppet_server_map = { }; + login_shared_secret_map = { }; }; logging = { @@ -137,7 +142,10 @@ in { wantedBy = [ "multi-user.target" ]; wants = [ "network-online.target" ] ++ cfg.serviceDependencies; after = [ "network-online.target" ] ++ cfg.serviceDependencies; - path = [ pkgs.lottieconverter pkgs.ffmpeg-headless ]; + path = [ + pkgs.lottieconverter + pkgs.ffmpeg-headless + ]; # mautrix-telegram tries to generate a dotfile in the home directory of # the running user if using a postgresql database: @@ -151,18 +159,20 @@ in { # RuntimeError: Could not determine home directory. environment.HOME = dataDir; - preStart = '' - # generate the appservice's registration file if absent - if [ ! -f '${registrationFile}' ]; then - ${pkgs.mautrix-telegram}/bin/mautrix-telegram \ - --generate-registration \ - --config='${settingsFile}' \ - --registration='${registrationFile}' - fi - '' + lib.optionalString (pkgs.mautrix-telegram ? alembic) '' - # run automatic database init and migration scripts - ${pkgs.mautrix-telegram.alembic}/bin/alembic -x config='${settingsFile}' upgrade head - ''; + preStart = + '' + # generate the appservice's registration file if absent + if [ ! -f '${registrationFile}' ]; then + ${pkgs.mautrix-telegram}/bin/mautrix-telegram \ + --generate-registration \ + --config='${settingsFile}' \ + --registration='${registrationFile}' + fi + '' + + lib.optionalString (pkgs.mautrix-telegram ? alembic) '' + # run automatic database init and migration scripts + ${pkgs.mautrix-telegram.alembic}/bin/alembic -x config='${settingsFile}' upgrade head + ''; serviceConfig = { Type = "simple"; @@ -189,5 +199,8 @@ in { }; }; - meta.maintainers = with lib.maintainers; [ pacien vskilet ]; + meta.maintainers = with lib.maintainers; [ + pacien + vskilet + ]; } diff --git a/nixos/modules/services/matrix/mx-puppet-discord.nix b/nixos/modules/services/matrix/mx-puppet-discord.nix index c6af1e3ff0222d..b7425350d8bf2b 100644 --- a/nixos/modules/services/matrix/mx-puppet-discord.nix +++ b/nixos/modules/services/matrix/mx-puppet-discord.nix @@ -1,12 +1,18 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let dataDir = "/var/lib/mx-puppet-discord"; registrationFile = "${dataDir}/discord-registration.yaml"; cfg = config.services.mx-puppet-discord; - settingsFormat = pkgs.formats.json {}; + settingsFormat = pkgs.formats.json { }; settingsFile = settingsFormat.generate "mx-puppet-discord-config.json" cfg.settings; -in { +in +{ options = { services.mx-puppet-discord = { enable = lib.mkEnableOption '' diff --git a/nixos/modules/services/matrix/pantalaimon-options.nix b/nixos/modules/services/matrix/pantalaimon-options.nix index b3a663f5993124..8574409d4f1148 100644 --- a/nixos/modules/services/matrix/pantalaimon-options.nix +++ b/nixos/modules/services/matrix/pantalaimon-options.nix @@ -1,4 +1,9 @@ -{ config, lib, name, ... }: +{ + config, + lib, + name, + ... +}: { options = { dataPath = lib.mkOption { @@ -10,7 +15,12 @@ }; logLevel = lib.mkOption { - type = lib.types.enum [ "info" "warning" "error" "debug" ]; + type = lib.types.enum [ + "info" + "warning" + "error" + "debug" + ]; default = "warning"; description = '' Set the log level of the daemon. diff --git a/nixos/modules/services/matrix/pantalaimon.nix b/nixos/modules/services/matrix/pantalaimon.nix index 28fcdcee973f28..120baab41fb05f 100644 --- a/nixos/modules/services/matrix/pantalaimon.nix +++ b/nixos/modules/services/matrix/pantalaimon.nix @@ -1,31 +1,38 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.pantalaimon-headless; iniFmt = pkgs.formats.ini { }; - mkConfigFile = name: instanceConfig: iniFmt.generate "pantalaimon.conf" { - Default = { - LogLevel = instanceConfig.logLevel; - Notifications = false; - }; + mkConfigFile = + name: instanceConfig: + iniFmt.generate "pantalaimon.conf" { + Default = { + LogLevel = instanceConfig.logLevel; + Notifications = false; + }; - ${name} = (lib.recursiveUpdate - { - Homeserver = instanceConfig.homeserver; - ListenAddress = instanceConfig.listenAddress; - ListenPort = instanceConfig.listenPort; - SSL = instanceConfig.ssl; + ${name} = ( + lib.recursiveUpdate { + Homeserver = instanceConfig.homeserver; + ListenAddress = instanceConfig.listenAddress; + ListenPort = instanceConfig.listenPort; + SSL = instanceConfig.ssl; - # Set some settings to prevent user interaction for headless operation - IgnoreVerification = true; - UseKeyring = false; - } - instanceConfig.extraSettings - ); - }; + # Set some settings to prevent user interaction for headless operation + IgnoreVerification = true; + UseKeyring = false; + } instanceConfig.extraSettings + ); + }; - mkPantalaimonService = name: instanceConfig: + mkPantalaimonService = + name: instanceConfig: lib.nameValuePair "pantalaimon-${name}" { description = "pantalaimon instance ${name} - E2EE aware proxy daemon for matrix clients"; wants = [ "network-online.target" ]; @@ -57,10 +64,9 @@ in ''; }; - config = lib.mkIf (config.services.pantalaimon-headless.instances != { }) - { - systemd.services = lib.mapAttrs' mkPantalaimonService config.services.pantalaimon-headless.instances; - }; + config = lib.mkIf (config.services.pantalaimon-headless.instances != { }) { + systemd.services = lib.mapAttrs' mkPantalaimonService config.services.pantalaimon-headless.instances; + }; meta = { maintainers = with lib.maintainers; [ jojosch ]; diff --git a/nixos/modules/services/matrix/synapse.nix b/nixos/modules/services/matrix/synapse.nix index 6d2e6201d66d32..2b0eb43605d8eb 100644 --- a/nixos/modules/services/matrix/synapse.nix +++ b/nixos/modules/services/matrix/synapse.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with lib; @@ -6,7 +12,8 @@ let cfg = config.services.matrix-synapse; format = pkgs.formats.yaml { }; - filterRecursiveNull = o: + filterRecursiveNull = + o: if isAttrs o then mapAttrs (_: v: filterRecursiveNull v) (filterAttrs (_: v: v != null) o) else if isList o then @@ -19,20 +26,29 @@ let configFile = format.generate "homeserver.yaml" finalSettings; usePostgresql = cfg.settings.database.name == "psycopg2"; - hasLocalPostgresDB = let args = cfg.settings.database.args; in + hasLocalPostgresDB = + let + args = cfg.settings.database.args; + in usePostgresql - && (!(args ? host) || (elem args.host [ "localhost" "127.0.0.1" "::1" ])) + && ( + !(args ? host) + || (elem args.host [ + "localhost" + "127.0.0.1" + "::1" + ]) + ) && config.services.postgresql.enable; hasWorkers = cfg.workers != { }; - listenerSupportsResource = resource: listener: - lib.any ({ names, ... }: builtins.elem resource names) listener.resources; + listenerSupportsResource = + resource: listener: lib.any ({ names, ... }: builtins.elem resource names) listener.resources; - clientListener = findFirst - (listenerSupportsResource "client") - null - (cfg.settings.listeners - ++ concatMap ({ worker_listeners, ... }: worker_listeners) (attrValues cfg.workers)); + clientListener = findFirst (listenerSupportsResource "client") null ( + cfg.settings.listeners + ++ concatMap ({ worker_listeners, ... }: worker_listeners) (attrValues cfg.workers) + ); registerNewMatrixUser = let @@ -40,20 +56,17 @@ let # add a tail, so that without any bind_addresses we still have a useable address bindAddress = head (clientListener.bind_addresses ++ [ "127.0.0.1" ]); - listenerProtocol = if clientListener.tls - then "https" - else "http"; + listenerProtocol = if clientListener.tls then "https" else "http"; in - assert assertMsg (clientListener != null) "No client listener found in synapse or one of its workers"; + assert assertMsg ( + clientListener != null + ) "No client listener found in synapse or one of its workers"; pkgs.writeShellScriptBin "matrix-synapse-register_new_matrix_user" '' exec ${cfg.package}/bin/register_new_matrix_user \ $@ \ ${lib.concatMapStringsSep " " (x: "-c ${x}") ([ configFile ] ++ cfg.extraConfigFiles)} \ "${listenerProtocol}://${ - if (isIpv6 bindAddress) then - "[${bindAddress}]" - else - "${bindAddress}" + if (isIpv6 bindAddress) then "[${bindAddress}]" else "${bindAddress}" }:${builtins.toString clientListener.port}/" ''; @@ -64,7 +77,8 @@ let "user-search" ]; - wantedExtras = cfg.extras + wantedExtras = + cfg.extras ++ lib.optional (cfg.settings ? oidc_providers) "oidc" ++ lib.optional (cfg.settings ? jwt_config) "jwt" ++ lib.optional (cfg.settings ? saml2_config) "saml2" @@ -95,7 +109,8 @@ let defaultCommonLogConfigText = generators.toPretty { } defaultCommonLogConfig; - logConfigText = logName: + logConfigText = + logName: lib.literalMD '' Path to a yaml file generated from this Nix expression: @@ -106,27 +121,28 @@ let ``` ''; - genLogConfigFile = logName: format.generate - "synapse-log-${logName}.yaml" - (cfg.log // optionalAttrs (cfg.log?handlers.journal) { - handlers.journal = cfg.log.handlers.journal // { - SYSLOG_IDENTIFIER = logName; - }; - }); + genLogConfigFile = + logName: + format.generate "synapse-log-${logName}.yaml" ( + cfg.log + // optionalAttrs (cfg.log ? handlers.journal) { + handlers.journal = cfg.log.handlers.journal // { + SYSLOG_IDENTIFIER = logName; + }; + } + ); - toIntBase8 = str: + toIntBase8 = + str: lib.pipe str [ lib.stringToCharacters (map lib.toInt) (lib.foldl (acc: digit: acc * 8 + digit) 0) ]; - toDecimalFilePermission = value: - if value == null then - null - else - toIntBase8 value; -in { + toDecimalFilePermission = value: if value == null then null else toIntBase8 value; +in +{ imports = [ @@ -147,1015 +163,1258 @@ in { '') # options that don't exist in synapse anymore - (mkRemovedOptionModule [ "services" "matrix-synapse" "bind_host" ] "Use listener settings instead." ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "bind_port" ] "Use listener settings instead." ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "expire_access_tokens" ] "" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "no_tls" ] "It is no longer supported by synapse." ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "tls_dh_param_path" ] "It was removed from synapse." ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "unsecure_port" ] "Use settings.listeners instead." ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "user_creation_max_duration" ] "It is no longer supported by synapse." ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "verbose" ] "Use a log config instead." ) + (mkRemovedOptionModule [ "services" "matrix-synapse" "bind_host" ] "Use listener settings instead.") + (mkRemovedOptionModule [ "services" "matrix-synapse" "bind_port" ] "Use listener settings instead.") + (mkRemovedOptionModule [ "services" "matrix-synapse" "expire_access_tokens" ] "") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "no_tls" + ] "It is no longer supported by synapse.") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "tls_dh_param_path" + ] "It was removed from synapse.") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "unsecure_port" + ] "Use settings.listeners instead.") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "user_creation_max_duration" + ] "It is no longer supported by synapse.") + (mkRemovedOptionModule [ "services" "matrix-synapse" "verbose" ] "Use a log config instead.") # options that were moved into rfc42 style settings - (mkRemovedOptionModule [ "services" "matrix-synapse" "app_service_config_files" ] "Use settings.app_service_config_files instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "database_args" ] "Use settings.database.args instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "database_name" ] "Use settings.database.args.database instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "database_type" ] "Use settings.database.name instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "database_user" ] "Use settings.database.args.user instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "dynamic_thumbnails" ] "Use settings.dynamic_thumbnails instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "enable_metrics" ] "Use settings.enable_metrics instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "enable_registration" ] "Use settings.enable_registration instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "extraConfig" ] "Use settings instead." ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "listeners" ] "Use settings.listeners instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "logConfig" ] "Use settings.log_config instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "max_image_pixels" ] "Use settings.max_image_pixels instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "max_upload_size" ] "Use settings.max_upload_size instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "presence" "enabled" ] "Use settings.presence.enabled instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "public_baseurl" ] "Use settings.public_baseurl instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "report_stats" ] "Use settings.report_stats instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "server_name" ] "Use settings.server_name instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "servers" ] "Use settings.trusted_key_servers instead." ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "tls_certificate_path" ] "Use settings.tls_certificate_path instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "tls_private_key_path" ] "Use settings.tls_private_key_path instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "turn_shared_secret" ] "Use settings.turn_shared_secret instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "turn_uris" ] "Use settings.turn_uris instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "turn_user_lifetime" ] "Use settings.turn_user_lifetime instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "url_preview_enabled" ] "Use settings.url_preview_enabled instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "url_preview_ip_range_blacklist" ] "Use settings.url_preview_ip_range_blacklist instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "url_preview_ip_range_whitelist" ] "Use settings.url_preview_ip_range_whitelist instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "url_preview_url_blacklist" ] "Use settings.url_preview_url_blacklist instead" ) + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "app_service_config_files" + ] "Use settings.app_service_config_files instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "database_args" + ] "Use settings.database.args instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "database_name" + ] "Use settings.database.args.database instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "database_type" + ] "Use settings.database.name instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "database_user" + ] "Use settings.database.args.user instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "dynamic_thumbnails" + ] "Use settings.dynamic_thumbnails instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "enable_metrics" + ] "Use settings.enable_metrics instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "enable_registration" + ] "Use settings.enable_registration instead") + (mkRemovedOptionModule [ "services" "matrix-synapse" "extraConfig" ] "Use settings instead.") + (mkRemovedOptionModule [ "services" "matrix-synapse" "listeners" ] "Use settings.listeners instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "logConfig" + ] "Use settings.log_config instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "max_image_pixels" + ] "Use settings.max_image_pixels instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "max_upload_size" + ] "Use settings.max_upload_size instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "presence" + "enabled" + ] "Use settings.presence.enabled instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "public_baseurl" + ] "Use settings.public_baseurl instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "report_stats" + ] "Use settings.report_stats instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "server_name" + ] "Use settings.server_name instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "servers" + ] "Use settings.trusted_key_servers instead.") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "tls_certificate_path" + ] "Use settings.tls_certificate_path instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "tls_private_key_path" + ] "Use settings.tls_private_key_path instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "turn_shared_secret" + ] "Use settings.turn_shared_secret instead") + (mkRemovedOptionModule [ "services" "matrix-synapse" "turn_uris" ] "Use settings.turn_uris instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "turn_user_lifetime" + ] "Use settings.turn_user_lifetime instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "url_preview_enabled" + ] "Use settings.url_preview_enabled instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "url_preview_ip_range_blacklist" + ] "Use settings.url_preview_ip_range_blacklist instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "url_preview_ip_range_whitelist" + ] "Use settings.url_preview_ip_range_whitelist instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "url_preview_url_blacklist" + ] "Use settings.url_preview_url_blacklist instead") # options that are too specific to mention them explicitly in settings - (mkRemovedOptionModule [ "services" "matrix-synapse" "account_threepid_delegates" "email" ] "Use settings.account_threepid_delegates.email instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "account_threepid_delegates" "msisdn" ] "Use settings.account_threepid_delegates.msisdn instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "allow_guest_access" ] "Use settings.allow_guest_access instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "bcrypt_rounds" ] "Use settings.bcrypt_rounds instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "enable_registration_captcha" ] "Use settings.enable_registration_captcha instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "event_cache_size" ] "Use settings.event_cache_size instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "federation_rc_concurrent" ] "Use settings.rc_federation.concurrent instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "federation_rc_reject_limit" ] "Use settings.rc_federation.reject_limit instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "federation_rc_sleep_delay" ] "Use settings.rc_federation.sleep_delay instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "federation_rc_sleep_limit" ] "Use settings.rc_federation.sleep_limit instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "federation_rc_window_size" ] "Use settings.rc_federation.window_size instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "key_refresh_interval" ] "Use settings.key_refresh_interval instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "rc_messages_burst_count" ] "Use settings.rc_messages.burst_count instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "rc_messages_per_second" ] "Use settings.rc_messages.per_second instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "recaptcha_private_key" ] "Use settings.recaptcha_private_key instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "recaptcha_public_key" ] "Use settings.recaptcha_public_key instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "redaction_retention_period" ] "Use settings.redaction_retention_period instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "room_prejoin_state" "additional_event_types" ] "Use settings.room_prejoin_state.additional_event_types instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "room_prejoin_state" "disable_default_event_types" ] "Use settings.room_prejoin-state.disable_default_event_types instead" ) + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "account_threepid_delegates" + "email" + ] "Use settings.account_threepid_delegates.email instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "account_threepid_delegates" + "msisdn" + ] "Use settings.account_threepid_delegates.msisdn instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "allow_guest_access" + ] "Use settings.allow_guest_access instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "bcrypt_rounds" + ] "Use settings.bcrypt_rounds instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "enable_registration_captcha" + ] "Use settings.enable_registration_captcha instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "event_cache_size" + ] "Use settings.event_cache_size instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "federation_rc_concurrent" + ] "Use settings.rc_federation.concurrent instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "federation_rc_reject_limit" + ] "Use settings.rc_federation.reject_limit instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "federation_rc_sleep_delay" + ] "Use settings.rc_federation.sleep_delay instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "federation_rc_sleep_limit" + ] "Use settings.rc_federation.sleep_limit instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "federation_rc_window_size" + ] "Use settings.rc_federation.window_size instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "key_refresh_interval" + ] "Use settings.key_refresh_interval instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "rc_messages_burst_count" + ] "Use settings.rc_messages.burst_count instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "rc_messages_per_second" + ] "Use settings.rc_messages.per_second instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "recaptcha_private_key" + ] "Use settings.recaptcha_private_key instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "recaptcha_public_key" + ] "Use settings.recaptcha_public_key instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "redaction_retention_period" + ] "Use settings.redaction_retention_period instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "room_prejoin_state" + "additional_event_types" + ] "Use settings.room_prejoin_state.additional_event_types instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "room_prejoin_state" + "disable_default_event_types" + ] "Use settings.room_prejoin-state.disable_default_event_types instead") # Options that should be passed via extraConfigFiles, so they are not persisted into the nix store - (mkRemovedOptionModule [ "services" "matrix-synapse" "macaroon_secret_key" ] "Pass this value via extraConfigFiles instead" ) - (mkRemovedOptionModule [ "services" "matrix-synapse" "registration_shared_secret" ] "Pass this value via extraConfigFiles instead" ) + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "macaroon_secret_key" + ] "Pass this value via extraConfigFiles instead") + (mkRemovedOptionModule [ + "services" + "matrix-synapse" + "registration_shared_secret" + ] "Pass this value via extraConfigFiles instead") ]; - options = let - listenerType = workerContext: types.submodule ({ config, ... }: { - options = { - port = mkOption { - type = types.nullOr types.port; - default = null; - example = 8448; - description = '' - The port to listen for HTTP(S) requests on. - ''; - }; + options = + let + listenerType = + workerContext: + types.submodule ( + { config, ... }: + { + options = { + port = mkOption { + type = types.nullOr types.port; + default = null; + example = 8448; + description = '' + The port to listen for HTTP(S) requests on. + ''; + }; - bind_addresses = mkOption { - type = types.nullOr (types.listOf types.str); - default = if config.path != null then null else [ - "::1" - "127.0.0.1" - ]; - defaultText = literalExpression '' - if path != null then - null - else - [ - "::1" - "127.0.0.1" - ] - ''; - example = literalExpression '' - [ - "::" - "0.0.0.0" - ] + bind_addresses = mkOption { + type = types.nullOr (types.listOf types.str); + default = + if config.path != null then + null + else + [ + "::1" + "127.0.0.1" + ]; + defaultText = literalExpression '' + if path != null then + null + else + [ + "::1" + "127.0.0.1" + ] + ''; + example = literalExpression '' + [ + "::" + "0.0.0.0" + ] + ''; + description = '' + IP addresses to bind the listener to. + ''; + }; + + path = mkOption { + type = types.nullOr types.path; + default = null; + description = '' + Unix domain socket path to bind this listener to. + + ::: {.note} + This option is incompatible with {option}`bind_addresses`, {option}`port`, {option}`tls` + and also does not support the `metrics` and `manhole` listener {option}`type`. + ::: + ''; + }; + + mode = mkOption { + type = types.nullOr (types.strMatching "^[0,2-7]{3,4}$"); + default = if config.path != null then "660" else null; + defaultText = literalExpression '' + if path != null then + "660" + else + null + ''; + example = "660"; + description = '' + File permissions on the UNIX domain socket. + ''; + apply = toDecimalFilePermission; + }; + + type = mkOption { + type = types.enum [ + "http" + "manhole" + "metrics" + "replication" + ]; + default = "http"; + example = "metrics"; + description = '' + The type of the listener, usually http. + ''; + }; + + tls = mkOption { + type = types.nullOr types.bool; + default = if config.path != null then null else !workerContext; + defaultText = '' + Enabled for the main instance listener, unless it is configured with a UNIX domain socket path. + ''; + example = false; + description = '' + Whether to enable TLS on the listener socket. + + ::: {.note} + This option will be ignored for UNIX domain sockets. + ::: + ''; + }; + + x_forwarded = mkOption { + type = types.bool; + default = config.path != null; + defaultText = '' + Enabled if the listener is configured with a UNIX domain socket path + ''; + example = true; + description = '' + Use the X-Forwarded-For (XFF) header as the client IP and not the + actual client IP. + ''; + }; + + resources = mkOption { + type = types.listOf ( + types.submodule { + options = { + names = mkOption { + type = types.listOf ( + types.enum [ + "client" + "consent" + "federation" + "health" + "keys" + "media" + "metrics" + "openid" + "replication" + "static" + ] + ); + description = '' + List of resources to host on this listener. + ''; + example = [ + "client" + ]; + }; + compress = mkOption { + default = false; + type = types.bool; + description = '' + Whether synapse should compress HTTP responses to clients that support it. + This should be disabled if running synapse behind a load balancer + that can do automatic compression. + ''; + }; + }; + } + ); + description = '' + List of HTTP resources to serve on this listener. + ''; + }; + }; + } + ); + in + { + services.matrix-synapse = { + enable = mkEnableOption "matrix.org synapse, the reference homeserver"; + + enableRegistrationScript = mkOption { + type = types.bool; + default = clientListener.bind_addresses != [ ]; + example = false; + defaultText = '' + Enabled if the client listener uses TCP sockets ''; description = '' - IP addresses to bind the listener to. + Whether to install the `register_new_matrix_user` script, that + allows account creation on the terminal. + + ::: {.note} + This script does not work when the client listener uses UNIX domain sockets + ::: ''; }; - path = mkOption { - type = types.nullOr types.path; - default = null; + serviceUnit = lib.mkOption { + type = lib.types.str; + readOnly = true; description = '' - Unix domain socket path to bind this listener to. + The systemd unit (a service or a target) for other services to depend on if they + need to be started after matrix-synapse. - ::: {.note} - This option is incompatible with {option}`bind_addresses`, {option}`port`, {option}`tls` - and also does not support the `metrics` and `manhole` listener {option}`type`. - ::: + This option is useful as the actual parent unit for all matrix-synapse processes + changes when configuring workers. ''; }; - mode = mkOption { - type = types.nullOr (types.strMatching "^[0,2-7]{3,4}$"); - default = if config.path != null then "660" else null; - defaultText = literalExpression '' - if path != null then - "660" - else - null - ''; - example = "660"; + configFile = mkOption { + type = types.path; + readOnly = true; description = '' - File permissions on the UNIX domain socket. + Path to the configuration file on the target system. Useful to configure e.g. workers + that also need this. ''; - apply = toDecimalFilePermission; }; - type = mkOption { - type = types.enum [ - "http" - "manhole" - "metrics" - "replication" - ]; - default = "http"; - example = "metrics"; + package = mkOption { + type = types.package; + readOnly = true; description = '' - The type of the listener, usually http. + Reference to the `matrix-synapse` wrapper with all extras + (e.g. for `oidc` or `saml2`) added to the `PYTHONPATH` of all executables. + + This option is useful to reference the "final" `matrix-synapse` package that's + actually used by `matrix-synapse.service`. For instance, when using + workers, it's possible to run + `''${config.services.matrix-synapse.package}/bin/synapse_worker` and + no additional PYTHONPATH needs to be specified for extras or plugins configured + via `services.matrix-synapse`. + + However, this means that this option is supposed to be only declared + by the `services.matrix-synapse` module itself and is thus read-only. + In order to modify `matrix-synapse` itself, use an overlay to override + `pkgs.matrix-synapse-unwrapped`. ''; }; - tls = mkOption { - type = types.nullOr types.bool; - default = if config.path != null then - null - else - !workerContext; - defaultText = '' - Enabled for the main instance listener, unless it is configured with a UNIX domain socket path. + extras = mkOption { + type = types.listOf ( + types.enum (lib.attrNames pkgs.matrix-synapse-unwrapped.optional-dependencies) + ); + default = defaultExtras; + example = literalExpression '' + [ + "cache-memory" # Provide statistics about caching memory consumption + "jwt" # JSON Web Token authentication + "oidc" # OpenID Connect authentication + "postgres" # PostgreSQL database backend + "redis" # Redis support for the replication stream between worker processes + "saml2" # SAML2 authentication + "sentry" # Error tracking and performance metrics + "systemd" # Provide the JournalHandler used in the default log_config + "url-preview" # Support for oEmbed URL previews + "user-search" # Support internationalized domain names in user-search + ] ''; - example = false; description = '' - Whether to enable TLS on the listener socket. + Explicitly install extras provided by matrix-synapse. Most + will require some additional configuration. - ::: {.note} - This option will be ignored for UNIX domain sockets. - ::: + Extras will automatically be enabled, when the relevant + configuration sections are present. + + Please note that this option is additive: i.e. when adding a new item + to this list, the defaults are still kept. To override the defaults as well, + use `lib.mkForce`. ''; }; - x_forwarded = mkOption { - type = types.bool; - default = config.path != null; - defaultText = '' - Enabled if the listener is configured with a UNIX domain socket path + plugins = mkOption { + type = types.listOf types.package; + default = [ ]; + example = literalExpression '' + with config.services.matrix-synapse.package.plugins; [ + matrix-synapse-ldap3 + matrix-synapse-pam + ]; ''; - example = true; description = '' - Use the X-Forwarded-For (XFF) header as the client IP and not the - actual client IP. + List of additional Matrix plugins to make available. ''; }; - resources = mkOption { - type = types.listOf (types.submodule { - options = { - names = mkOption { - type = types.listOf (types.enum [ - "client" - "consent" - "federation" - "health" - "keys" - "media" - "metrics" - "openid" - "replication" - "static" - ]); - description = '' - List of resources to host on this listener. - ''; - example = [ - "client" - ]; - }; - compress = mkOption { - default = false; - type = types.bool; - description = '' - Whether synapse should compress HTTP responses to clients that support it. - This should be disabled if running synapse behind a load balancer - that can do automatic compression. - ''; - }; - }; - }); + withJemalloc = mkOption { + type = types.bool; + default = false; description = '' - List of HTTP resources to serve on this listener. + Whether to preload jemalloc to reduce memory fragmentation and overall usage. ''; }; - }; - }); - in { - services.matrix-synapse = { - enable = mkEnableOption "matrix.org synapse, the reference homeserver"; - - enableRegistrationScript = mkOption { - type = types.bool; - default = clientListener.bind_addresses != []; - example = false; - defaultText = '' - Enabled if the client listener uses TCP sockets - ''; - description = '' - Whether to install the `register_new_matrix_user` script, that - allows account creation on the terminal. - ::: {.note} - This script does not work when the client listener uses UNIX domain sockets - ::: - ''; - }; - - serviceUnit = lib.mkOption { - type = lib.types.str; - readOnly = true; - description = '' - The systemd unit (a service or a target) for other services to depend on if they - need to be started after matrix-synapse. - - This option is useful as the actual parent unit for all matrix-synapse processes - changes when configuring workers. - ''; - }; - - configFile = mkOption { - type = types.path; - readOnly = true; - description = '' - Path to the configuration file on the target system. Useful to configure e.g. workers - that also need this. - ''; - }; - - package = mkOption { - type = types.package; - readOnly = true; - description = '' - Reference to the `matrix-synapse` wrapper with all extras - (e.g. for `oidc` or `saml2`) added to the `PYTHONPATH` of all executables. - - This option is useful to reference the "final" `matrix-synapse` package that's - actually used by `matrix-synapse.service`. For instance, when using - workers, it's possible to run - `''${config.services.matrix-synapse.package}/bin/synapse_worker` and - no additional PYTHONPATH needs to be specified for extras or plugins configured - via `services.matrix-synapse`. - - However, this means that this option is supposed to be only declared - by the `services.matrix-synapse` module itself and is thus read-only. - In order to modify `matrix-synapse` itself, use an overlay to override - `pkgs.matrix-synapse-unwrapped`. - ''; - }; - - extras = mkOption { - type = types.listOf (types.enum (lib.attrNames pkgs.matrix-synapse-unwrapped.optional-dependencies)); - default = defaultExtras; - example = literalExpression '' - [ - "cache-memory" # Provide statistics about caching memory consumption - "jwt" # JSON Web Token authentication - "oidc" # OpenID Connect authentication - "postgres" # PostgreSQL database backend - "redis" # Redis support for the replication stream between worker processes - "saml2" # SAML2 authentication - "sentry" # Error tracking and performance metrics - "systemd" # Provide the JournalHandler used in the default log_config - "url-preview" # Support for oEmbed URL previews - "user-search" # Support internationalized domain names in user-search - ] - ''; - description = '' - Explicitly install extras provided by matrix-synapse. Most - will require some additional configuration. - - Extras will automatically be enabled, when the relevant - configuration sections are present. - - Please note that this option is additive: i.e. when adding a new item - to this list, the defaults are still kept. To override the defaults as well, - use `lib.mkForce`. - ''; - }; + dataDir = mkOption { + type = types.str; + default = "/var/lib/matrix-synapse"; + description = '' + The directory where matrix-synapse stores its stateful data such as + certificates, media and uploads. + ''; + }; - plugins = mkOption { - type = types.listOf types.package; - default = [ ]; - example = literalExpression '' - with config.services.matrix-synapse.package.plugins; [ - matrix-synapse-ldap3 - matrix-synapse-pam - ]; - ''; - description = '' - List of additional Matrix plugins to make available. - ''; - }; + log = mkOption { + type = types.attrsOf format.type; + defaultText = literalExpression defaultCommonLogConfigText; + description = '' + Default configuration for the loggers used by `matrix-synapse` and its workers. + The defaults are added with the default priority which means that + these will be merged with additional declarations. These additional + declarations also take precedence over the defaults when declared + with at least normal priority. For instance + the log-level for synapse and its workers can be changed like this: + + ```nix + { lib, ... }: { + services.matrix-synapse.log.root.level = "WARNING"; + } + ``` + + And another field can be added like this: + + ```nix + { + services.matrix-synapse.log = { + loggers."synapse.http.matrixfederationclient".level = "DEBUG"; + }; + } + ``` - withJemalloc = mkOption { - type = types.bool; - default = false; - description = '' - Whether to preload jemalloc to reduce memory fragmentation and overall usage. - ''; - }; + Additionally, the field `handlers.journal.SYSLOG_IDENTIFIER` will be added to + each log config, i.e. + * `synapse` for `matrix-synapse.service` + * `synapse-` for `matrix-synapse-worker-.service` - dataDir = mkOption { - type = types.str; - default = "/var/lib/matrix-synapse"; - description = '' - The directory where matrix-synapse stores its stateful data such as - certificates, media and uploads. - ''; - }; + This is only done if this option has a `handlers.journal` field declared. - log = mkOption { - type = types.attrsOf format.type; - defaultText = literalExpression defaultCommonLogConfigText; - description = '' - Default configuration for the loggers used by `matrix-synapse` and its workers. - The defaults are added with the default priority which means that - these will be merged with additional declarations. These additional - declarations also take precedence over the defaults when declared - with at least normal priority. For instance - the log-level for synapse and its workers can be changed like this: - - ```nix - { lib, ... }: { - services.matrix-synapse.log.root.level = "WARNING"; - } - ``` + To discard all settings declared by this option for each worker and synapse, + `lib.mkForce` can be used. - And another field can be added like this: + To discard all settings declared by this option for a single worker or synapse only, + [](#opt-services.matrix-synapse.workers._name_.worker_log_config) or + [](#opt-services.matrix-synapse.settings.log_config) can be used. + ''; + }; - ```nix - { - services.matrix-synapse.log = { - loggers."synapse.http.matrixfederationclient".level = "DEBUG"; - }; - } - ``` + settings = mkOption { + default = { }; + description = '' + The primary synapse configuration. See the + [sample configuration](https://github.com/element-hq/synapse/blob/v${pkgs.matrix-synapse-unwrapped.version}/docs/sample_config.yaml) + for possible values. - Additionally, the field `handlers.journal.SYSLOG_IDENTIFIER` will be added to - each log config, i.e. - * `synapse` for `matrix-synapse.service` - * `synapse-` for `matrix-synapse-worker-.service` + Secrets should be passed in by using the `extraConfigFiles` option. + ''; + type = + with types; + submodule { + freeformType = format.type; + options = { + # This is a reduced set of popular options and defaults + # Do not add every available option here, they can be specified + # by the user at their own discretion. This is a freeform type! + + server_name = mkOption { + type = types.str; + example = "example.com"; + default = config.networking.hostName; + defaultText = literalExpression "config.networking.hostName"; + description = '' + The domain name of the server, with optional explicit port. + This is used by remote servers to look up the server address. + This is also the last part of your UserID. + + The server_name cannot be changed later so it is important to configure this correctly before you start Synapse. + ''; + }; - This is only done if this option has a `handlers.journal` field declared. + enable_registration = mkOption { + type = types.bool; + default = false; + description = '' + Enable registration for new users. + ''; + }; - To discard all settings declared by this option for each worker and synapse, - `lib.mkForce` can be used. + registration_shared_secret = mkOption { + type = types.nullOr types.str; + default = null; + description = '' + If set, allows registration by anyone who also has the shared + secret, even if registration is otherwise disabled. - To discard all settings declared by this option for a single worker or synapse only, - [](#opt-services.matrix-synapse.workers._name_.worker_log_config) or - [](#opt-services.matrix-synapse.settings.log_config) can be used. - ''; - }; + Secrets should be passed in via `extraConfigFiles`! + ''; + }; - settings = mkOption { - default = { }; - description = '' - The primary synapse configuration. See the - [sample configuration](https://github.com/element-hq/synapse/blob/v${pkgs.matrix-synapse-unwrapped.version}/docs/sample_config.yaml) - for possible values. + macaroon_secret_key = mkOption { + type = types.nullOr types.str; + default = null; + description = '' + Secret key for authentication tokens. If none is specified, + the registration_shared_secret is used, if one is given; otherwise, + a secret key is derived from the signing key. - Secrets should be passed in by using the `extraConfigFiles` option. - ''; - type = with types; submodule { - freeformType = format.type; - options = { - # This is a reduced set of popular options and defaults - # Do not add every available option here, they can be specified - # by the user at their own discretion. This is a freeform type! - - server_name = mkOption { - type = types.str; - example = "example.com"; - default = config.networking.hostName; - defaultText = literalExpression "config.networking.hostName"; - description = '' - The domain name of the server, with optional explicit port. - This is used by remote servers to look up the server address. - This is also the last part of your UserID. - - The server_name cannot be changed later so it is important to configure this correctly before you start Synapse. - ''; - }; + Secrets should be passed in via `extraConfigFiles`! + ''; + }; - enable_registration = mkOption { - type = types.bool; - default = false; - description = '' - Enable registration for new users. - ''; - }; + enable_metrics = mkOption { + type = types.bool; + default = false; + description = '' + Enable collection and rendering of performance metrics + ''; + }; - registration_shared_secret = mkOption { - type = types.nullOr types.str; - default = null; - description = '' - If set, allows registration by anyone who also has the shared - secret, even if registration is otherwise disabled. + report_stats = mkOption { + type = types.bool; + default = false; + description = '' + Whether or not to report anonymized homeserver usage statistics. + ''; + }; - Secrets should be passed in via `extraConfigFiles`! - ''; - }; + signing_key_path = mkOption { + type = types.path; + default = "${cfg.dataDir}/homeserver.signing.key"; + description = '' + Path to the signing key to sign messages with. + ''; + }; - macaroon_secret_key = mkOption { - type = types.nullOr types.str; - default = null; - description = '' - Secret key for authentication tokens. If none is specified, - the registration_shared_secret is used, if one is given; otherwise, - a secret key is derived from the signing key. + pid_file = mkOption { + type = types.path; + default = "/run/matrix-synapse.pid"; + readOnly = true; + description = '' + The file to store the PID in. + ''; + }; - Secrets should be passed in via `extraConfigFiles`! - ''; - }; + log_config = mkOption { + type = types.path; + default = genLogConfigFile "synapse"; + defaultText = logConfigText "synapse"; + description = '' + The file that holds the logging configuration. + ''; + }; - enable_metrics = mkOption { - type = types.bool; - default = false; - description = '' - Enable collection and rendering of performance metrics - ''; - }; + media_store_path = mkOption { + type = types.path; + default = + if lib.versionAtLeast config.system.stateVersion "22.05" then + "${cfg.dataDir}/media_store" + else + "${cfg.dataDir}/media"; + defaultText = "${cfg.dataDir}/media_store for when system.stateVersion is at least 22.05, ${cfg.dataDir}/media when lower than 22.05"; + description = '' + Directory where uploaded images and attachments are stored. + ''; + }; - report_stats = mkOption { - type = types.bool; - default = false; - description = '' - Whether or not to report anonymized homeserver usage statistics. - ''; - }; + public_baseurl = mkOption { + type = types.nullOr types.str; + default = null; + example = "https://example.com:8448/"; + description = '' + The public-facing base URL for the client API (not including _matrix/...) + ''; + }; - signing_key_path = mkOption { - type = types.path; - default = "${cfg.dataDir}/homeserver.signing.key"; - description = '' - Path to the signing key to sign messages with. - ''; - }; + tls_certificate_path = mkOption { + type = types.nullOr types.str; + default = null; + example = "/var/lib/acme/example.com/fullchain.pem"; + description = '' + PEM encoded X509 certificate for TLS. + You can replace the self-signed certificate that synapse + autogenerates on launch with your own SSL certificate + key pair + if you like. Any required intermediary certificates can be + appended after the primary certificate in hierarchical order. + ''; + }; - pid_file = mkOption { - type = types.path; - default = "/run/matrix-synapse.pid"; - readOnly = true; - description = '' - The file to store the PID in. - ''; - }; + tls_private_key_path = mkOption { + type = types.nullOr types.str; + default = null; + example = "/var/lib/acme/example.com/key.pem"; + description = '' + PEM encoded private key for TLS. Specify null if synapse is not + speaking TLS directly. + ''; + }; - log_config = mkOption { - type = types.path; - default = genLogConfigFile "synapse"; - defaultText = logConfigText "synapse"; - description = '' - The file that holds the logging configuration. - ''; - }; + presence.enabled = mkOption { + type = types.bool; + default = true; + example = false; + description = '' + Whether to enable presence tracking. - media_store_path = mkOption { - type = types.path; - default = if lib.versionAtLeast config.system.stateVersion "22.05" - then "${cfg.dataDir}/media_store" - else "${cfg.dataDir}/media"; - defaultText = "${cfg.dataDir}/media_store for when system.stateVersion is at least 22.05, ${cfg.dataDir}/media when lower than 22.05"; - description = '' - Directory where uploaded images and attachments are stored. - ''; - }; + Presence tracking allows users to see the state (e.g online/offline) + of other local and remote users. + ''; + }; - public_baseurl = mkOption { - type = types.nullOr types.str; - default = null; - example = "https://example.com:8448/"; - description = '' - The public-facing base URL for the client API (not including _matrix/...) - ''; - }; + listeners = mkOption { + type = types.listOf (listenerType false); + default = + [ + { + port = 8008; + bind_addresses = [ "127.0.0.1" ]; + type = "http"; + tls = false; + x_forwarded = true; + resources = [ + { + names = [ "client" ]; + compress = true; + } + { + names = [ "federation" ]; + compress = false; + } + ]; + } + ] + ++ lib.optional hasWorkers { + path = "/run/matrix-synapse/main_replication.sock"; + type = "http"; + resources = [ + { + names = [ "replication" ]; + compress = false; + } + ]; + }; + description = '' + List of ports that Synapse should listen on, their purpose and their configuration. + + By default, synapse will be configured for client and federation traffic on port 8008, and + use a UNIX domain socket for worker replication. See [`services.matrix-synapse.workers`](#opt-services.matrix-synapse.workers) + for more details. + ''; + }; - tls_certificate_path = mkOption { - type = types.nullOr types.str; - default = null; - example = "/var/lib/acme/example.com/fullchain.pem"; - description = '' - PEM encoded X509 certificate for TLS. - You can replace the self-signed certificate that synapse - autogenerates on launch with your own SSL certificate + key pair - if you like. Any required intermediary certificates can be - appended after the primary certificate in hierarchical order. - ''; - }; + database.name = mkOption { + type = types.enum [ + "sqlite3" + "psycopg2" + ]; + default = if versionAtLeast config.system.stateVersion "18.03" then "psycopg2" else "sqlite3"; + defaultText = literalExpression '' + if versionAtLeast config.system.stateVersion "18.03" + then "psycopg2" + else "sqlite3" + ''; + description = '' + The database engine name. Can be sqlite3 or psycopg2. + ''; + }; - tls_private_key_path = mkOption { - type = types.nullOr types.str; - default = null; - example = "/var/lib/acme/example.com/key.pem"; - description = '' - PEM encoded private key for TLS. Specify null if synapse is not - speaking TLS directly. - ''; - }; + database.args.database = mkOption { + type = types.str; + default = + { + sqlite3 = "${cfg.dataDir}/homeserver.db"; + psycopg2 = "matrix-synapse"; + } + .${cfg.settings.database.name}; + defaultText = literalExpression '' + { + sqlite3 = "''${${options.services.matrix-synapse.dataDir}}/homeserver.db"; + psycopg2 = "matrix-synapse"; + }.''${${options.services.matrix-synapse.settings}.database.name}; + ''; + description = '' + Name of the database when using the psycopg2 backend, + path to the database location when using sqlite3. + ''; + }; - presence.enabled = mkOption { - type = types.bool; - default = true; - example = false; - description = '' - Whether to enable presence tracking. + database.args.user = mkOption { + type = types.nullOr types.str; + default = + { + sqlite3 = null; + psycopg2 = "matrix-synapse"; + } + .${cfg.settings.database.name}; + defaultText = lib.literalExpression '' + { + sqlite3 = null; + psycopg2 = "matrix-synapse"; + }.''${cfg.settings.database.name}; + ''; + description = '' + Username to connect with psycopg2, set to null + when using sqlite3. + ''; + }; - Presence tracking allows users to see the state (e.g online/offline) - of other local and remote users. - ''; - }; + url_preview_enabled = mkOption { + type = types.bool; + default = true; + example = false; + description = '' + Is the preview URL API enabled? If enabled, you *must* specify an + explicit url_preview_ip_range_blacklist of IPs that the spider is + denied from accessing. + ''; + }; - listeners = mkOption { - type = types.listOf (listenerType false); - default = [{ - port = 8008; - bind_addresses = [ "127.0.0.1" ]; - type = "http"; - tls = false; - x_forwarded = true; - resources = [{ - names = [ "client" ]; - compress = true; - } { - names = [ "federation" ]; - compress = false; - }]; - }] ++ lib.optional hasWorkers { - path = "/run/matrix-synapse/main_replication.sock"; - type = "http"; - resources = [{ - names = [ "replication" ]; - compress = false; - }]; - }; - description = '' - List of ports that Synapse should listen on, their purpose and their configuration. + url_preview_ip_range_blacklist = mkOption { + type = types.listOf types.str; + default = [ + "10.0.0.0/8" + "100.64.0.0/10" + "127.0.0.0/8" + "169.254.0.0/16" + "172.16.0.0/12" + "192.0.0.0/24" + "192.0.2.0/24" + "192.168.0.0/16" + "192.88.99.0/24" + "198.18.0.0/15" + "198.51.100.0/24" + "2001:db8::/32" + "203.0.113.0/24" + "224.0.0.0/4" + "::1/128" + "fc00::/7" + "fe80::/10" + "fec0::/10" + "ff00::/8" + ]; + description = '' + List of IP address CIDR ranges that the URL preview spider is denied + from accessing. + ''; + }; - By default, synapse will be configured for client and federation traffic on port 8008, and - use a UNIX domain socket for worker replication. See [`services.matrix-synapse.workers`](#opt-services.matrix-synapse.workers) - for more details. - ''; - }; + url_preview_ip_range_whitelist = mkOption { + type = types.listOf types.str; + default = [ ]; + description = '' + List of IP address CIDR ranges that the URL preview spider is allowed + to access even if they are specified in url_preview_ip_range_blacklist. + ''; + }; - database.name = mkOption { - type = types.enum [ - "sqlite3" - "psycopg2" - ]; - default = if versionAtLeast config.system.stateVersion "18.03" - then "psycopg2" - else "sqlite3"; - defaultText = literalExpression '' - if versionAtLeast config.system.stateVersion "18.03" - then "psycopg2" - else "sqlite3" - ''; - description = '' - The database engine name. Can be sqlite3 or psycopg2. - ''; - }; + url_preview_url_blacklist = mkOption { + # FIXME revert to just `listOf (attrsOf str)` after some time(tm). + type = types.listOf ( + types.coercedTo types.str (const (throw '' + Setting `config.services.matrix-synapse.settings.url_preview_url_blacklist` + to a list of strings has never worked. Due to a bug, this was the type accepted + by the module, but in practice it broke on runtime and as a result, no URL + preview worked anywhere if this was set. + + See https://element-hq.github.io/synapse/latest/usage/configuration/config_documentation.html#url_preview_url_blacklist + on how to configure it properly. + '')) (types.attrsOf types.str) + ); + default = [ ]; + example = literalExpression '' + [ + { scheme = "http"; } # no http previews + { netloc = "www.acme.com"; path = "/foo"; } # block http(s)://www.acme.com/foo + ] + ''; + description = '' + Optional list of URL matches that the URL preview spider is + denied from accessing. + ''; + }; - database.args.database = mkOption { - type = types.str; - default = { - sqlite3 = "${cfg.dataDir}/homeserver.db"; - psycopg2 = "matrix-synapse"; - }.${cfg.settings.database.name}; - defaultText = literalExpression '' - { - sqlite3 = "''${${options.services.matrix-synapse.dataDir}}/homeserver.db"; - psycopg2 = "matrix-synapse"; - }.''${${options.services.matrix-synapse.settings}.database.name}; - ''; - description = '' - Name of the database when using the psycopg2 backend, - path to the database location when using sqlite3. - ''; - }; + max_upload_size = mkOption { + type = types.str; + default = "50M"; + example = "100M"; + description = '' + The largest allowed upload size in bytes + ''; + }; - database.args.user = mkOption { - type = types.nullOr types.str; - default = { - sqlite3 = null; - psycopg2 = "matrix-synapse"; - }.${cfg.settings.database.name}; - defaultText = lib.literalExpression '' - { - sqlite3 = null; - psycopg2 = "matrix-synapse"; - }.''${cfg.settings.database.name}; - ''; - description = '' - Username to connect with psycopg2, set to null - when using sqlite3. - ''; - }; + max_image_pixels = mkOption { + type = types.str; + default = "32M"; + example = "64M"; + description = '' + Maximum number of pixels that will be thumbnailed + ''; + }; - url_preview_enabled = mkOption { - type = types.bool; - default = true; - example = false; - description = '' - Is the preview URL API enabled? If enabled, you *must* specify an - explicit url_preview_ip_range_blacklist of IPs that the spider is - denied from accessing. - ''; - }; + dynamic_thumbnails = mkOption { + type = types.bool; + default = false; + example = true; + description = '' + Whether to generate new thumbnails on the fly to precisely match + the resolution requested by the client. If true then whenever + a new resolution is requested by the client the server will + generate a new thumbnail. If false the server will pick a thumbnail + from a precalculated list. + ''; + }; - url_preview_ip_range_blacklist = mkOption { - type = types.listOf types.str; - default = [ - "10.0.0.0/8" - "100.64.0.0/10" - "127.0.0.0/8" - "169.254.0.0/16" - "172.16.0.0/12" - "192.0.0.0/24" - "192.0.2.0/24" - "192.168.0.0/16" - "192.88.99.0/24" - "198.18.0.0/15" - "198.51.100.0/24" - "2001:db8::/32" - "203.0.113.0/24" - "224.0.0.0/4" - "::1/128" - "fc00::/7" - "fe80::/10" - "fec0::/10" - "ff00::/8" - ]; - description = '' - List of IP address CIDR ranges that the URL preview spider is denied - from accessing. - ''; - }; + turn_uris = mkOption { + type = types.listOf types.str; + default = [ ]; + example = [ + "turn:turn.example.com:3487?transport=udp" + "turn:turn.example.com:3487?transport=tcp" + "turns:turn.example.com:5349?transport=udp" + "turns:turn.example.com:5349?transport=tcp" + ]; + description = '' + The public URIs of the TURN server to give to clients + ''; + }; + turn_shared_secret = mkOption { + type = types.str; + default = ""; + example = literalExpression '' + config.services.coturn.static-auth-secret + ''; + description = '' + The shared secret used to compute passwords for the TURN server. - url_preview_ip_range_whitelist = mkOption { - type = types.listOf types.str; - default = [ ]; - description = '' - List of IP address CIDR ranges that the URL preview spider is allowed - to access even if they are specified in url_preview_ip_range_blacklist. - ''; - }; + Secrets should be passed in via `extraConfigFiles`! + ''; + }; - url_preview_url_blacklist = mkOption { - # FIXME revert to just `listOf (attrsOf str)` after some time(tm). - type = types.listOf ( - types.coercedTo - types.str - (const (throw '' - Setting `config.services.matrix-synapse.settings.url_preview_url_blacklist` - to a list of strings has never worked. Due to a bug, this was the type accepted - by the module, but in practice it broke on runtime and as a result, no URL - preview worked anywhere if this was set. - - See https://element-hq.github.io/synapse/latest/usage/configuration/config_documentation.html#url_preview_url_blacklist - on how to configure it properly. - '')) - (types.attrsOf types.str)); - default = [ ]; - example = literalExpression '' - [ - { scheme = "http"; } # no http previews - { netloc = "www.acme.com"; path = "/foo"; } # block http(s)://www.acme.com/foo - ] - ''; - description = '' - Optional list of URL matches that the URL preview spider is - denied from accessing. - ''; - }; + trusted_key_servers = mkOption { + type = types.listOf ( + types.submodule { + freeformType = format.type; + options = { + server_name = mkOption { + type = types.str; + example = "matrix.org"; + description = '' + Hostname of the trusted server. + ''; + }; + }; + } + ); + default = [ + { + server_name = "matrix.org"; + verify_keys = { + "ed25519:auto" = "Noi6WqcDj0QmPxCNQqgezwTlBKrfqehY1u2FyWP9uYw"; + }; + } + ]; + description = '' + The trusted servers to download signing keys from. + ''; + }; - max_upload_size = mkOption { - type = types.str; - default = "50M"; - example = "100M"; - description = '' - The largest allowed upload size in bytes - ''; - }; + app_service_config_files = mkOption { + type = types.listOf types.path; + default = [ ]; + description = '' + A list of application service config file to use + ''; + }; - max_image_pixels = mkOption { - type = types.str; - default = "32M"; - example = "64M"; - description = '' - Maximum number of pixels that will be thumbnailed - ''; - }; + redis = lib.mkOption { + type = types.submodule { + freeformType = format.type; + options = { + enabled = lib.mkOption { + type = types.bool; + default = false; + description = '' + Whether to use redis support + ''; + }; + }; + }; + default = { }; + description = '' + Redis configuration for synapse. - dynamic_thumbnails = mkOption { - type = types.bool; - default = false; - example = true; - description = '' - Whether to generate new thumbnails on the fly to precisely match - the resolution requested by the client. If true then whenever - a new resolution is requested by the client the server will - generate a new thumbnail. If false the server will pick a thumbnail - from a precalculated list. - ''; + See the + [upstream documentation](https://github.com/element-hq/synapse/blob/v${pkgs.matrix-synapse-unwrapped.version}/docs/usage/configuration/config_documentation.md#redis) + for available options. + ''; + }; + }; }; + }; - turn_uris = mkOption { - type = types.listOf types.str; - default = [ ]; - example = [ - "turn:turn.example.com:3487?transport=udp" - "turn:turn.example.com:3487?transport=tcp" - "turns:turn.example.com:5349?transport=udp" - "turns:turn.example.com:5349?transport=tcp" - ]; - description = '' - The public URIs of the TURN server to give to clients - ''; - }; - turn_shared_secret = mkOption { - type = types.str; - default = ""; - example = literalExpression '' - config.services.coturn.static-auth-secret - ''; - description = '' - The shared secret used to compute passwords for the TURN server. + workers = lib.mkOption { + default = { }; + description = '' + Options for configuring workers. Worker support will be enabled if at least one worker is configured here. - Secrets should be passed in via `extraConfigFiles`! - ''; - }; + See the [worker documention](https://element-hq.github.io/synapse/latest/workers.html#worker-configuration) + for possible options for each worker. Worker-specific options overriding the shared homeserver configuration can be + specified here for each worker. - trusted_key_servers = mkOption { - type = types.listOf (types.submodule { + ::: {.note} + Worker support will add a replication listener on port 9093 to the main synapse process using the default + value of [`services.matrix-synapse.settings.listeners`](#opt-services.matrix-synapse.settings.listeners) and configure that + listener as `services.matrix-synapse.settings.instance_map.main`. + If you set either of those options, make sure to configure a replication listener yourself. + + A redis server is required for running workers. A local one can be enabled + using [`services.matrix-synapse.configureRedisLocally`](#opt-services.matrix-synapse.configureRedisLocally). + + Workers also require a proper reverse proxy setup to direct incoming requests to the appropriate process. See + the [reverse proxy documentation](https://element-hq.github.io/synapse/latest/reverse_proxy.html) for a + general reverse proxying setup and + the [worker documentation](https://element-hq.github.io/synapse/latest/workers.html#available-worker-applications) + for the available endpoints per worker application. + ::: + ''; + type = types.attrsOf ( + types.submodule ( + { name, ... }: + { freeformType = format.type; options = { - server_name = mkOption { - type = types.str; - example = "matrix.org"; + worker_app = lib.mkOption { + type = types.enum [ + "synapse.app.generic_worker" + "synapse.app.media_repository" + ]; + description = "Type of this worker"; + default = "synapse.app.generic_worker"; + }; + worker_listeners = lib.mkOption { + default = [ ]; + type = types.listOf (listenerType true); description = '' - Hostname of the trusted server. + List of ports that this worker should listen on, their purpose and their configuration. ''; }; - }; - }); - default = [{ - server_name = "matrix.org"; - verify_keys = { - "ed25519:auto" = "Noi6WqcDj0QmPxCNQqgezwTlBKrfqehY1u2FyWP9uYw"; - }; - }]; - description = '' - The trusted servers to download signing keys from. - ''; - }; - - app_service_config_files = mkOption { - type = types.listOf types.path; - default = [ ]; - description = '' - A list of application service config file to use - ''; - }; - - redis = lib.mkOption { - type = types.submodule { - freeformType = format.type; - options = { - enabled = lib.mkOption { - type = types.bool; - default = false; + worker_log_config = lib.mkOption { + type = types.path; + default = genLogConfigFile "synapse-${name}"; + defaultText = logConfigText "synapse-${name}"; description = '' - Whether to use redis support + The file for log configuration. + + See the [python documentation](https://docs.python.org/3/library/logging.config.html#configuration-dictionary-schema) + for the schema and the [upstream repository](https://github.com/element-hq/synapse/blob/v${pkgs.matrix-synapse-unwrapped.version}/docs/sample_log_config.yaml) + for an example. ''; }; }; + } + ) + ); + default = { }; + example = lib.literalExpression '' + { + "federation_sender" = { }; + "federation_receiver" = { + worker_listeners = [ + { + type = "http"; + port = 8009; + bind_addresses = [ "127.0.0.1" ]; + tls = false; + x_forwarded = true; + resources = [{ + names = [ "federation" ]; + }]; + } + ]; }; - default = { }; - description = '' - Redis configuration for synapse. - - See the - [upstream documentation](https://github.com/element-hq/synapse/blob/v${pkgs.matrix-synapse-unwrapped.version}/docs/usage/configuration/config_documentation.md#redis) - for available options. - ''; - }; - }; + } + ''; }; - }; - - workers = lib.mkOption { - default = { }; - description = '' - Options for configuring workers. Worker support will be enabled if at least one worker is configured here. - - See the [worker documention](https://element-hq.github.io/synapse/latest/workers.html#worker-configuration) - for possible options for each worker. Worker-specific options overriding the shared homeserver configuration can be - specified here for each worker. - - ::: {.note} - Worker support will add a replication listener on port 9093 to the main synapse process using the default - value of [`services.matrix-synapse.settings.listeners`](#opt-services.matrix-synapse.settings.listeners) and configure that - listener as `services.matrix-synapse.settings.instance_map.main`. - If you set either of those options, make sure to configure a replication listener yourself. - - A redis server is required for running workers. A local one can be enabled - using [`services.matrix-synapse.configureRedisLocally`](#opt-services.matrix-synapse.configureRedisLocally). - - Workers also require a proper reverse proxy setup to direct incoming requests to the appropriate process. See - the [reverse proxy documentation](https://element-hq.github.io/synapse/latest/reverse_proxy.html) for a - general reverse proxying setup and - the [worker documentation](https://element-hq.github.io/synapse/latest/workers.html#available-worker-applications) - for the available endpoints per worker application. - ::: - ''; - type = types.attrsOf (types.submodule ({name, ...}: { - freeformType = format.type; - options = { - worker_app = lib.mkOption { - type = types.enum [ - "synapse.app.generic_worker" - "synapse.app.media_repository" - ]; - description = "Type of this worker"; - default = "synapse.app.generic_worker"; - }; - worker_listeners = lib.mkOption { - default = [ ]; - type = types.listOf (listenerType true); - description = '' - List of ports that this worker should listen on, their purpose and their configuration. - ''; - }; - worker_log_config = lib.mkOption { - type = types.path; - default = genLogConfigFile "synapse-${name}"; - defaultText = logConfigText "synapse-${name}"; - description = '' - The file for log configuration. - - See the [python documentation](https://docs.python.org/3/library/logging.config.html#configuration-dictionary-schema) - for the schema and the [upstream repository](https://github.com/element-hq/synapse/blob/v${pkgs.matrix-synapse-unwrapped.version}/docs/sample_log_config.yaml) - for an example. - ''; - }; - }; - })); - default = { }; - example = lib.literalExpression '' - { - "federation_sender" = { }; - "federation_receiver" = { - worker_listeners = [ - { - type = "http"; - port = 8009; - bind_addresses = [ "127.0.0.1" ]; - tls = false; - x_forwarded = true; - resources = [{ - names = [ "federation" ]; - }]; - } - ]; - }; - } - ''; - }; - extraConfigFiles = mkOption { - type = types.listOf types.path; - default = [ ]; - description = '' - Extra config files to include. + extraConfigFiles = mkOption { + type = types.listOf types.path; + default = [ ]; + description = '' + Extra config files to include. - The configuration files will be included based on the command line - argument --config-path. This allows to configure secrets without - having to go through the Nix store, e.g. based on deployment keys if - NixOps is in use. - ''; - }; + The configuration files will be included based on the command line + argument --config-path. This allows to configure secrets without + having to go through the Nix store, e.g. based on deployment keys if + NixOps is in use. + ''; + }; - configureRedisLocally = lib.mkOption { - type = types.bool; - default = false; - description = '' - Whether to automatically configure a local redis server for matrix-synapse. - ''; + configureRedisLocally = lib.mkOption { + type = types.bool; + default = false; + description = '' + Whether to automatically configure a local redis server for matrix-synapse. + ''; + }; }; }; - }; config = mkIf cfg.enable { - assertions = [ - { - assertion = clientListener != null; - message = '' - At least one listener which serves the `client` resource via HTTP is required - by synapse in `services.matrix-synapse.settings.listeners` or in one of the workers! - ''; - } - { - assertion = hasWorkers -> cfg.settings.redis.enabled; + assertions = + [ + { + assertion = clientListener != null; + message = '' + At least one listener which serves the `client` resource via HTTP is required + by synapse in `services.matrix-synapse.settings.listeners` or in one of the workers! + ''; + } + { + assertion = hasWorkers -> cfg.settings.redis.enabled; + message = '' + Workers for matrix-synapse require configuring a redis instance. This can be done + automatically by setting `services.matrix-synapse.configureRedisLocally = true`. + ''; + } + { + assertion = + let + main = cfg.settings.instance_map.main; + listener = lib.findFirst ( + listener: + ( + lib.hasAttr "port" main && listener.port or null == main.port + || lib.hasAttr "path" main && listener.path or null == main.path + ) + && listenerSupportsResource "replication" listener + && ( + lib.hasAttr "host" main + && lib.any (bind: bind == main.host || bind == "0.0.0.0" || bind == "::") listener.bind_addresses + || lib.hasAttr "path" main + ) + ) null cfg.settings.listeners; + in + hasWorkers -> (cfg.settings.instance_map ? main && listener != null); + message = '' + Workers for matrix-synapse require setting `services.matrix-synapse.settings.instance_map.main` + to any listener configured in `services.matrix-synapse.settings.listeners` with a `"replication"` + resource. + + This is done by default unless you manually configure either of those settings. + ''; + } + { + assertion = cfg.enableRegistrationScript -> clientListener.path == null; + message = '' + The client listener on matrix-synapse is configured to use UNIX domain sockets. + This configuration is incompatible with the `register_new_matrix_user` script. + + Disable `services.matrix-synapse.enableRegistrationScript` to continue. + ''; + } + ] + ++ (map (listener: { + assertion = (listener.path == null) != (listener.bind_addresses == null); message = '' - Workers for matrix-synapse require configuring a redis instance. This can be done - automatically by setting `services.matrix-synapse.configureRedisLocally = true`. + Listeners require either a UNIX domain socket `path` or `bind_addresses` for a TCP socket. ''; - } - { + }) cfg.settings.listeners) + ++ (map (listener: { assertion = + listener.path != null + -> (listener.bind_addresses == null && listener.port == null && listener.tls == null); + message = let - main = cfg.settings.instance_map.main; - listener = lib.findFirst - ( - listener: - ( - lib.hasAttr "port" main && listener.port or null == main.port - || lib.hasAttr "path" main && listener.path or null == main.path - ) - && listenerSupportsResource "replication" listener - && ( - lib.hasAttr "host" main && lib.any (bind: bind == main.host || bind == "0.0.0.0" || bind == "::") listener.bind_addresses - || lib.hasAttr "path" main - ) - ) - null - cfg.settings.listeners; + formatKeyValue = key: value: lib.optionalString (value != null) " - ${key}=${toString value}\n"; in - hasWorkers -> (cfg.settings.instance_map ? main && listener != null); - message = '' - Workers for matrix-synapse require setting `services.matrix-synapse.settings.instance_map.main` - to any listener configured in `services.matrix-synapse.settings.listeners` with a `"replication"` - resource. - - This is done by default unless you manually configure either of those settings. - ''; - } - { - assertion = cfg.enableRegistrationScript -> clientListener.path == null; + '' + Listener configured with UNIX domain socket (${toString listener.path}) ignores the following options: + ${formatKeyValue "bind_addresses" listener.bind_addresses}${formatKeyValue "port" listener.port}${formatKeyValue "tls" listener.tls} + ''; + }) cfg.settings.listeners) + ++ (map (listener: { + assertion = listener.path == null || listener.type == "http"; message = '' - The client listener on matrix-synapse is configured to use UNIX domain sockets. - This configuration is incompatible with the `register_new_matrix_user` script. - - Disable `services.matrix-synapse.enableRegistrationScript` to continue. + Listener configured with UNIX domain socket (${toString listener.path}) only supports the "http" listener type. ''; - } - ] - ++ (map (listener: { - assertion = (listener.path == null) != (listener.bind_addresses == null); - message = '' - Listeners require either a UNIX domain socket `path` or `bind_addresses` for a TCP socket. - ''; - }) cfg.settings.listeners) - ++ (map (listener: { - assertion = listener.path != null -> (listener.bind_addresses == null && listener.port == null && listener.tls == null); - message = let - formatKeyValue = key: value: lib.optionalString (value != null) " - ${key}=${toString value}\n"; - in '' - Listener configured with UNIX domain socket (${toString listener.path}) ignores the following options: - ${formatKeyValue "bind_addresses" listener.bind_addresses}${formatKeyValue "port" listener.port}${formatKeyValue "tls" listener.tls} - ''; - }) cfg.settings.listeners) - ++ (map (listener: { - assertion = listener.path == null || listener.type == "http"; - message = '' - Listener configured with UNIX domain socket (${toString listener.path}) only supports the "http" listener type. - ''; - }) cfg.settings.listeners); + }) cfg.settings.listeners); services.matrix-synapse.settings.redis = lib.mkIf cfg.configureRedisLocally { enabled = true; path = config.services.redis.servers.matrix-synapse.unixSocket; }; - services.matrix-synapse.settings.instance_map.main = lib.mkIf hasWorkers (lib.mkDefault { - path = "/run/matrix-synapse/main_replication.sock"; - }); + services.matrix-synapse.settings.instance_map.main = lib.mkIf hasWorkers ( + lib.mkDefault { + path = "/run/matrix-synapse/main_replication.sock"; + } + ); - services.matrix-synapse.serviceUnit = if hasWorkers then "matrix-synapse.target" else "matrix-synapse.service"; + services.matrix-synapse.serviceUnit = + if hasWorkers then "matrix-synapse.target" else "matrix-synapse.service"; services.matrix-synapse.configFile = configFile; services.matrix-synapse.package = wrapped; @@ -1186,19 +1445,20 @@ in { systemd.services = let targetConfig = - if hasWorkers - then { - partOf = [ "matrix-synapse.target" ]; - wantedBy = [ "matrix-synapse.target" ]; - unitConfig.ReloadPropagatedFrom = "matrix-synapse.target"; - requires = optional hasLocalPostgresDB "postgresql.service"; - } - else { - wants = [ "network-online.target" ]; - after = [ "network-online.target" ] ++ optional hasLocalPostgresDB "postgresql.service"; - requires = optional hasLocalPostgresDB "postgresql.service"; - wantedBy = [ "multi-user.target" ]; - }; + if hasWorkers then + { + partOf = [ "matrix-synapse.target" ]; + wantedBy = [ "matrix-synapse.target" ]; + unitConfig.ReloadPropagatedFrom = "matrix-synapse.target"; + requires = optional hasLocalPostgresDB "postgresql.service"; + } + else + { + wants = [ "network-online.target" ]; + after = [ "network-online.target" ] ++ optional hasLocalPostgresDB "postgresql.service"; + requires = optional hasLocalPostgresDB "postgresql.service"; + wantedBy = [ "multi-user.target" ]; + }; baseServiceConfig = { environment = optionalAttrs (cfg.withJemalloc) { LD_PRELOAD = "${pkgs.jemalloc}/lib/libjemalloc.so"; @@ -1232,21 +1492,37 @@ in { ProtectKernelTunables = true; ProtectProc = "invisible"; ProtectSystem = "strict"; - ReadWritePaths = [ cfg.dataDir cfg.settings.media_store_path ] ++ - (map (listener: dirOf listener.path) (filter (listener: listener.path != null) cfg.settings.listeners)); + ReadWritePaths = + [ + cfg.dataDir + cfg.settings.media_store_path + ] + ++ (map (listener: dirOf listener.path) ( + filter (listener: listener.path != null) cfg.settings.listeners + )); RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@resources" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@resources" + "~@privileged" + ]; }; - } - // targetConfig; - genWorkerService = name: workerCfg: + } // targetConfig; + genWorkerService = + name: workerCfg: let - finalWorkerCfg = workerCfg // { worker_name = name; }; + finalWorkerCfg = workerCfg // { + worker_name = name; + }; workerConfigFile = format.generate "worker-${name}.yaml" finalWorkerCfg; in { @@ -1261,7 +1537,13 @@ in { serviceConfig = { ExecStart = '' ${cfg.package}/bin/synapse_worker \ - ${ concatMapStringsSep "\n " (x: "--config-path ${x} \\") ([ configFile workerConfigFile ] ++ cfg.extraConfigFiles) } + ${concatMapStringsSep "\n " (x: "--config-path ${x} \\") ( + [ + configFile + workerConfigFile + ] + ++ cfg.extraConfigFiles + )} --keys-directory ${cfg.dataDir} ''; }; @@ -1282,14 +1564,19 @@ in { ''; serviceConfig = { ExecStartPre = [ - ("+" + (pkgs.writeShellScript "matrix-synapse-fix-permissions" '' - chown matrix-synapse:matrix-synapse ${cfg.settings.signing_key_path} - chmod 0600 ${cfg.settings.signing_key_path} - '')) + ( + "+" + + (pkgs.writeShellScript "matrix-synapse-fix-permissions" '' + chown matrix-synapse:matrix-synapse ${cfg.settings.signing_key_path} + chmod 0600 ${cfg.settings.signing_key_path} + '') + ) ]; ExecStart = '' ${cfg.package}/bin/synapse_homeserver \ - ${ concatMapStringsSep "\n " (x: "--config-path ${x} \\") ([ configFile ] ++ cfg.extraConfigFiles) } + ${concatMapStringsSep "\n " (x: "--config-path ${x} \\") ( + [ configFile ] ++ cfg.extraConfigFiles + )} --keys-directory ${cfg.dataDir} ''; }; diff --git a/nixos/modules/services/misc/airsonic.nix b/nixos/modules/services/misc/airsonic.nix index 3231fce35dabe5..653903933257d2 100644 --- a/nixos/modules/services/misc/airsonic.nix +++ b/nixos/modules/services/misc/airsonic.nix @@ -1,8 +1,15 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.airsonic; opt = options.services.airsonic; -in { +in +{ options = { services.airsonic = { @@ -140,8 +147,7 @@ in { -Dserver.port=${toString cfg.port} \ -Dserver.context-path=${cfg.contextPath} \ -Djava.awt.headless=true \ - ${lib.optionalString (cfg.virtualHost != null) - "-Dserver.use-forward-headers=true"} \ + ${lib.optionalString (cfg.virtualHost != null) "-Dserver.use-forward-headers=true"} \ ${toString cfg.jvmOptions} \ -verbose:gc \ -jar ${cfg.war} @@ -168,6 +174,6 @@ in { createHome = true; isSystemUser = true; }; - users.groups.airsonic = {}; + users.groups.airsonic = { }; }; } diff --git a/nixos/modules/services/misc/amazon-ssm-agent.nix b/nixos/modules/services/misc/amazon-ssm-agent.nix index 8267f9c42f8cea..e95bea72c7d777 100644 --- a/nixos/modules/services/misc/amazon-ssm-agent.nix +++ b/nixos/modules/services/misc/amazon-ssm-agent.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.amazon-ssm-agent; @@ -16,25 +21,37 @@ let sudoRule = { users = [ "ssm-user" ]; - commands = [ { command = "ALL"; options = [ "NOPASSWD" ]; } ]; + commands = [ + { + command = "ALL"; + options = [ "NOPASSWD" ]; + } + ]; }; -in { +in +{ imports = [ - (lib.mkRenamedOptionModule [ "services" "ssm-agent" "enable" ] [ "services" "amazon-ssm-agent" "enable" ]) - (lib.mkRenamedOptionModule [ "services" "ssm-agent" "package" ] [ "services" "amazon-ssm-agent" "package" ]) + (lib.mkRenamedOptionModule + [ "services" "ssm-agent" "enable" ] + [ "services" "amazon-ssm-agent" "enable" ] + ) + (lib.mkRenamedOptionModule + [ "services" "ssm-agent" "package" ] + [ "services" "amazon-ssm-agent" "package" ] + ) ]; options.services.amazon-ssm-agent = { enable = lib.mkEnableOption "Amazon SSM agent"; - package = lib.mkPackageOption pkgs "amazon-ssm-agent" {}; + package = lib.mkPackageOption pkgs "amazon-ssm-agent" { }; }; config = lib.mkIf cfg.enable { # See https://github.com/aws/amazon-ssm-agent/blob/mainline/packaging/linux/amazon-ssm-agent.service systemd.services.amazon-ssm-agent = { inherit (cfg.package.meta) description; - wants = [ "network-online.target" ]; - after = [ "network-online.target" ]; + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; wantedBy = [ "multi-user.target" ]; path = [ @@ -62,15 +79,17 @@ in { # On Amazon Linux 2 images, the ssm-user user is pretty much a # normal user with its own group. We do the same. - users.groups.ssm-user = {}; + users.groups.ssm-user = { }; users.users.ssm-user = { isNormalUser = true; group = "ssm-user"; }; - environment.etc."amazon/ssm/seelog.xml".source = "${cfg.package}/etc/amazon/ssm/seelog.xml.template"; + environment.etc."amazon/ssm/seelog.xml".source = + "${cfg.package}/etc/amazon/ssm/seelog.xml.template"; - environment.etc."amazon/ssm/amazon-ssm-agent.json".source = "${cfg.package}/etc/amazon/ssm/amazon-ssm-agent.json.template"; + environment.etc."amazon/ssm/amazon-ssm-agent.json".source = + "${cfg.package}/etc/amazon/ssm/amazon-ssm-agent.json.template"; }; } diff --git a/nixos/modules/services/misc/apache-kafka.nix b/nixos/modules/services/misc/apache-kafka.nix index 0ed20961c57bee..1937be8a26b68f 100644 --- a/nixos/modules/services/misc/apache-kafka.nix +++ b/nixos/modules/services/misc/apache-kafka.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.apache-kafka; @@ -12,21 +17,24 @@ let # Make sure every `freeformType` and any specific option type in `settings` is # supported here. - mkPropertyString = let - render = { - bool = lib.boolToString; - int = toString; - list = lib.concatMapStringsSep "," mkPropertyString; - string = lib.id; - }; - in + mkPropertyString = + let + render = { + bool = lib.boolToString; + int = toString; + list = lib.concatMapStringsSep "," mkPropertyString; + string = lib.id; + }; + in v: render.${builtins.typeOf v} v; - stringlySettings = lib.mapAttrs (_: mkPropertyString) - (lib.filterAttrs (_: v: v != null) cfg.settings); + stringlySettings = lib.mapAttrs (_: mkPropertyString) ( + lib.filterAttrs (_: v: v != null) cfg.settings + ); - generator = (pkgs.formats.javaProperties {}).generate; -in { + generator = (pkgs.formats.javaProperties { }).generate; +in +{ options.services.apache-kafka = { enable = lib.mkEnableOption "Apache Kafka event streaming broker"; @@ -40,11 +48,18 @@ in { Keys with dots are NOT represented by nested attrs in these settings, but instead as quoted strings (ie. `settings."broker.id"`, NOT `settings.broker.id`). - ''; + ''; type = lib.types.submodule { - freeformType = with lib.types; let - primitive = oneOf [bool int str]; - in lazyAttrsOf (nullOr (either primitive (listOf primitive))); + freeformType = + with lib.types; + let + primitive = oneOf [ + bool + int + str + ]; + in + lazyAttrsOf (nullOr (either primitive (listOf primitive))); options = { "broker.id" = lib.mkOption { @@ -129,7 +144,7 @@ in { jvmOptions = lib.mkOption { description = "Extra command line options for the JVM running Kafka."; - default = []; + default = [ ]; type = lib.types.listOf lib.types.str; example = [ "-Djava.net.preferIPv4Stack=true" @@ -151,22 +166,37 @@ in { imports = [ (lib.mkRenamedOptionModule [ "services" "apache-kafka" "brokerId" ] - [ "services" "apache-kafka" "settings" ''broker.id'' ]) + [ "services" "apache-kafka" "settings" ''broker.id'' ] + ) (lib.mkRenamedOptionModule [ "services" "apache-kafka" "logDirs" ] - [ "services" "apache-kafka" "settings" ''log.dirs'' ]) + [ "services" "apache-kafka" "settings" ''log.dirs'' ] + ) (lib.mkRenamedOptionModule [ "services" "apache-kafka" "zookeeper" ] - [ "services" "apache-kafka" "settings" ''zookeeper.connect'' ]) - - (lib.mkRemovedOptionModule [ "services" "apache-kafka" "port" ] - "Please see services.apache-kafka.settings.listeners and its documentation instead") - (lib.mkRemovedOptionModule [ "services" "apache-kafka" "hostname" ] - "Please see services.apache-kafka.settings.listeners and its documentation instead") - (lib.mkRemovedOptionModule [ "services" "apache-kafka" "extraProperties" ] - "Please see services.apache-kafka.settings and its documentation instead") - (lib.mkRemovedOptionModule [ "services" "apache-kafka" "serverProperties" ] - "Please see services.apache-kafka.settings and its documentation instead") + [ "services" "apache-kafka" "settings" ''zookeeper.connect'' ] + ) + + (lib.mkRemovedOptionModule [ + "services" + "apache-kafka" + "port" + ] "Please see services.apache-kafka.settings.listeners and its documentation instead") + (lib.mkRemovedOptionModule [ + "services" + "apache-kafka" + "hostname" + ] "Please see services.apache-kafka.settings.listeners and its documentation instead") + (lib.mkRemovedOptionModule [ + "services" + "apache-kafka" + "extraProperties" + ] "Please see services.apache-kafka.settings and its documentation instead") + (lib.mkRemovedOptionModule [ + "services" + "apache-kafka" + "serverProperties" + ] "Please see services.apache-kafka.settings and its documentation instead") ]; config = lib.mkIf cfg.enable { @@ -177,22 +207,30 @@ in { group = "apache-kafka"; description = "Apache Kafka daemon user"; }; - users.groups.apache-kafka = {}; + users.groups.apache-kafka = { }; - systemd.tmpfiles.rules = map (logDir: "d '${logDir}' 0700 apache-kafka - - -") cfg.settings."log.dirs"; + systemd.tmpfiles.rules = map ( + logDir: "d '${logDir}' 0700 apache-kafka - - -" + ) cfg.settings."log.dirs"; systemd.services.apache-kafka = { description = "Apache Kafka Daemon"; wantedBy = [ "multi-user.target" ]; after = [ "network.target" ]; - preStart = lib.mkIf cfg.formatLogDirs - (if cfg.formatLogDirsIgnoreFormatted then '' - ${cfg.package}/bin/kafka-storage.sh format -t "${cfg.clusterId}" -c ${cfg.configFiles.serverProperties} --ignore-formatted - '' else '' - if ${lib.concatMapStringsSep " && " (l: ''[ ! -f "${l}/meta.properties" ]'') cfg.settings."log.dirs"}; then - ${cfg.package}/bin/kafka-storage.sh format -t "${cfg.clusterId}" -c ${cfg.configFiles.serverProperties} - fi - ''); + preStart = lib.mkIf cfg.formatLogDirs ( + if cfg.formatLogDirsIgnoreFormatted then + '' + ${cfg.package}/bin/kafka-storage.sh format -t "${cfg.clusterId}" -c ${cfg.configFiles.serverProperties} --ignore-formatted + '' + else + '' + if ${ + lib.concatMapStringsSep " && " (l: ''[ ! -f "${l}/meta.properties" ]'') cfg.settings."log.dirs" + }; then + ${cfg.package}/bin/kafka-storage.sh format -t "${cfg.clusterId}" -c ${cfg.configFiles.serverProperties} + fi + '' + ); serviceConfig = { ExecStart = '' ${cfg.jre}/bin/java \ diff --git a/nixos/modules/services/misc/atuin.nix b/nixos/modules/services/misc/atuin.nix index 79c2c2a171e8d3..59bdae63887045 100644 --- a/nixos/modules/services/misc/atuin.nix +++ b/nixos/modules/services/misc/atuin.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let inherit (lib) mkOption types mkIf; cfg = config.services.atuin; @@ -76,10 +81,12 @@ in services.postgresql = mkIf cfg.database.createLocally { enable = true; - ensureUsers = [{ - name = "atuin"; - ensureDBOwnership = true; - }]; + ensureUsers = [ + { + name = "atuin"; + ensureDBOwnership = true; + } + ]; ensureDatabases = [ "atuin" ]; }; @@ -132,16 +139,18 @@ in UMask = "0077"; }; - environment = { - ATUIN_HOST = cfg.host; - ATUIN_PORT = toString cfg.port; - ATUIN_MAX_HISTORY_LENGTH = toString cfg.maxHistoryLength; - ATUIN_OPEN_REGISTRATION = lib.boolToString cfg.openRegistration; - ATUIN_PATH = cfg.path; - ATUIN_CONFIG_DIR = "/run/atuin"; # required to start, but not used as configuration is via environment variables - } // lib.optionalAttrs (cfg.database.uri != null) { - ATUIN_DB_URI = cfg.database.uri; - }; + environment = + { + ATUIN_HOST = cfg.host; + ATUIN_PORT = toString cfg.port; + ATUIN_MAX_HISTORY_LENGTH = toString cfg.maxHistoryLength; + ATUIN_OPEN_REGISTRATION = lib.boolToString cfg.openRegistration; + ATUIN_PATH = cfg.path; + ATUIN_CONFIG_DIR = "/run/atuin"; # required to start, but not used as configuration is via environment variables + } + // lib.optionalAttrs (cfg.database.uri != null) { + ATUIN_DB_URI = cfg.database.uri; + }; }; networking.firewall.allowedTCPPorts = mkIf cfg.openFirewall [ cfg.port ]; diff --git a/nixos/modules/services/misc/autofs.nix b/nixos/modules/services/misc/autofs.nix index 6c3ab8e57df904..cdb6d606d57ed9 100644 --- a/nixos/modules/services/misc/autofs.nix +++ b/nixos/modules/services/misc/autofs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.autofs; @@ -66,31 +71,35 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { boot.kernelModules = [ "autofs" ]; - systemd.services.autofs = - { description = "Automounts filesystems on demand"; - after = [ "network.target" "ypbind.service" "sssd.service" "network-online.target" ]; - wants = [ "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; - - preStart = '' - # There should be only one autofs service managed by systemd, so this should be safe. - rm -f /tmp/autofs-running - ''; - - serviceConfig = { - Type = "forking"; - PIDFile = "/run/autofs.pid"; - ExecStart = "${pkgs.autofs5}/bin/automount ${lib.optionalString cfg.debug "-d"} -p /run/autofs.pid -t ${builtins.toString cfg.timeout} ${autoMaster}"; - ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - }; + systemd.services.autofs = { + description = "Automounts filesystems on demand"; + after = [ + "network.target" + "ypbind.service" + "sssd.service" + "network-online.target" + ]; + wants = [ "network-online.target" ]; + wantedBy = [ "multi-user.target" ]; + + preStart = '' + # There should be only one autofs service managed by systemd, so this should be safe. + rm -f /tmp/autofs-running + ''; + + serviceConfig = { + Type = "forking"; + PIDFile = "/run/autofs.pid"; + ExecStart = "${pkgs.autofs5}/bin/automount ${lib.optionalString cfg.debug "-d"} -p /run/autofs.pid -t ${builtins.toString cfg.timeout} ${autoMaster}"; + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; }; + }; }; diff --git a/nixos/modules/services/misc/autorandr.nix b/nixos/modules/services/misc/autorandr.nix index f0490d63ad7fc3..4eb59340fc9c56 100644 --- a/nixos/modules/services/misc/autorandr.nix +++ b/nixos/modules/services/misc/autorandr.nix @@ -1,24 +1,41 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.autorandr; hookType = lib.types.lines; - matrixOf = n: m: elemType: - lib.mkOptionType rec { - name = "matrixOf"; - description = - "${toString n}×${toString m} matrix of ${elemType.description}s"; - check = xss: - let listOfSize = l: xs: lib.isList xs && lib.length xs == l; - in listOfSize n xss - && lib.all (xs: listOfSize m xs && lib.all elemType.check xs) xss; - merge = lib.mergeOneOption; - getSubOptions = prefix: elemType.getSubOptions (prefix ++ [ "*" "*" ]); - getSubModules = elemType.getSubModules; - substSubModules = mod: matrixOf n m (elemType.substSubModules mod); - functor = (lib.defaultFunctor name) // { wrapped = elemType; }; - }; + matrixOf = + n: m: elemType: + lib.mkOptionType rec { + name = "matrixOf"; + description = "${toString n}×${toString m} matrix of ${elemType.description}s"; + check = + xss: + let + listOfSize = l: xs: lib.isList xs && lib.length xs == l; + in + listOfSize n xss && lib.all (xs: listOfSize m xs && lib.all elemType.check xs) xss; + merge = lib.mergeOneOption; + getSubOptions = + prefix: + elemType.getSubOptions ( + prefix + ++ [ + "*" + "*" + ] + ); + getSubModules = elemType.getSubModules; + substSubModules = mod: matrixOf n m (elemType.substSubModules mod); + functor = (lib.defaultFunctor name) // { + wrapped = elemType; + }; + }; profileModule = lib.types.submodule { options = { @@ -95,7 +112,14 @@ let }; rotate = lib.mkOption { - type = lib.types.nullOr (lib.types.enum [ "normal" "left" "right" "inverted" ]); + type = lib.types.nullOr ( + lib.types.enum [ + "normal" + "left" + "right" + "inverted" + ] + ); description = "Output rotate configuration."; default = null; example = "left"; @@ -126,26 +150,31 @@ let }; scale = lib.mkOption { - type = lib.types.nullOr (lib.types.submodule { - options = { - method = lib.mkOption { - type = lib.types.enum [ "factor" "pixel" ]; - description = "Output scaling method."; - default = "factor"; - example = "pixel"; - }; + type = lib.types.nullOr ( + lib.types.submodule { + options = { + method = lib.mkOption { + type = lib.types.enum [ + "factor" + "pixel" + ]; + description = "Output scaling method."; + default = "factor"; + example = "pixel"; + }; - x = lib.mkOption { - type = lib.types.either lib.types.float lib.types.ints.positive; - description = "Horizontal scaling factor/pixels."; - }; + x = lib.mkOption { + type = lib.types.either lib.types.float lib.types.ints.positive; + description = "Horizontal scaling factor/pixels."; + }; - y = lib.mkOption { - type = lib.types.either lib.types.float lib.types.ints.positive; - description = "Vertical scaling factor/pixels."; + y = lib.mkOption { + type = lib.types.either lib.types.float lib.types.ints.positive; + description = "Vertical scaling factor/pixels."; + }; }; - }; - }); + } + ); description = '' Output scale configuration. @@ -195,27 +224,33 @@ let }; }; - hookToFile = folder: name: hook: + hookToFile = + folder: name: hook: lib.nameValuePair "xdg/autorandr/${folder}/${name}" { source = "${pkgs.writeShellScriptBin "hook" hook}/bin/hook"; }; - profileToFiles = name: profile: + profileToFiles = + name: profile: with profile; lib.mkMerge ([ { - "xdg/autorandr/${name}/setup".text = lib.concatStringsSep "\n" - (lib.mapAttrsToList fingerprintToString fingerprint); - "xdg/autorandr/${name}/config".text = - lib.concatStringsSep "\n" (lib.mapAttrsToList configToString profile.config); + "xdg/autorandr/${name}/setup".text = lib.concatStringsSep "\n" ( + lib.mapAttrsToList fingerprintToString fingerprint + ); + "xdg/autorandr/${name}/config".text = lib.concatStringsSep "\n" ( + lib.mapAttrsToList configToString profile.config + ); } (lib.mapAttrs' (hookToFile "${name}/postswitch.d") hooks.postswitch) (lib.mapAttrs' (hookToFile "${name}/preswitch.d") hooks.preswitch) (lib.mapAttrs' (hookToFile "${name}/predetect.d") hooks.predetect) ]); fingerprintToString = name: edid: "${name} ${edid}"; - configToString = name: config: + configToString = + name: config: if config.enable then - lib.concatStringsSep "\n" ([ "output ${name}" ] + lib.concatStringsSep "\n" ( + [ "output ${name}" ] ++ lib.optional (config.position != "") "pos ${config.position}" ++ lib.optional (config.crtc != null) "crtc ${toString config.crtc}" ++ lib.optional config.primary "primary" @@ -224,17 +259,22 @@ let ++ lib.optional (config.mode != "") "mode ${config.mode}" ++ lib.optional (config.rate != "") "rate ${config.rate}" ++ lib.optional (config.rotate != null) "rotate ${config.rotate}" - ++ lib.optional (config.transform != null) ("transform " - + lib.concatMapStringsSep "," toString (lib.flatten config.transform)) - ++ lib.optional (config.scale != null) - ((if config.scale.method == "factor" then "scale" else "scale-from") - + " ${toString config.scale.x}x${toString config.scale.y}")) - else '' - output ${name} - off - ''; - -in { + ++ lib.optional (config.transform != null) ( + "transform " + lib.concatMapStringsSep "," toString (lib.flatten config.transform) + ) + ++ lib.optional (config.scale != null) ( + (if config.scale.method == "factor" then "scale" else "scale-from") + + " ${toString config.scale.x}x${toString config.scale.y}" + ) + ) + else + '' + output ${name} + off + ''; + +in +{ options = { diff --git a/nixos/modules/services/misc/autosuspend.nix b/nixos/modules/services/misc/autosuspend.nix index a41ad43c44297e..53f872d3e040fb 100644 --- a/nixos/modules/services/misc/autosuspend.nix +++ b/nixos/modules/services/misc/autosuspend.nix @@ -1,66 +1,85 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let - inherit (lib) mapAttrs' nameValuePair filterAttrs types mkEnableOption - mkPackageOption mkOption literalExpression mkIf flatten - maintainers attrValues; + inherit (lib) + mapAttrs' + nameValuePair + filterAttrs + types + mkEnableOption + mkPackageOption + mkOption + literalExpression + mkIf + flatten + maintainers + attrValues + ; cfg = config.services.autosuspend; settingsFormat = pkgs.formats.ini { }; - checks = - mapAttrs' - (n: v: nameValuePair "check.${n}" (filterAttrs (_: v: v != null) v)) - cfg.checks; - wakeups = - mapAttrs' - (n: v: nameValuePair "wakeup.${n}" (filterAttrs (_: v: v != null) v)) - cfg.wakeups; + checks = mapAttrs' (n: v: nameValuePair "check.${n}" (filterAttrs (_: v: v != null) v)) cfg.checks; + wakeups = mapAttrs' ( + n: v: nameValuePair "wakeup.${n}" (filterAttrs (_: v: v != null) v) + ) cfg.wakeups; # Whether the given check is enabled - hasCheck = class: - (filterAttrs - (n: v: v.enabled && (if v.class == null then n else v.class) == class) - cfg.checks) + hasCheck = + class: + (filterAttrs (n: v: v.enabled && (if v.class == null then n else v.class) == class) cfg.checks) != { }; # Dependencies needed by specific checks dependenciesForChecks = { "Smb" = pkgs.samba; - "XIdleTime" = [ pkgs.xprintidle pkgs.sudo ]; + "XIdleTime" = [ + pkgs.xprintidle + pkgs.sudo + ]; }; - autosuspend-conf = - settingsFormat.generate "autosuspend.conf" ({ general = cfg.settings; } // checks // wakeups); + autosuspend-conf = settingsFormat.generate "autosuspend.conf" ( + { general = cfg.settings; } // checks // wakeups + ); autosuspend = cfg.package; checkType = types.submodule { freeformType = settingsFormat.type.nestedTypes.elemType; - options.enabled = mkEnableOption "this activity check" // { default = true; }; + options.enabled = mkEnableOption "this activity check" // { + default = true; + }; options.class = mkOption { default = null; - type = with types; nullOr (enum [ - "ActiveCalendarEvent" - "ActiveConnection" - "ExternalCommand" - "JsonPath" - "Kodi" - "KodiIdleTime" - "LastLogActivity" - "Load" - "LogindSessionsIdle" - "Mpd" - "NetworkBandwidth" - "Ping" - "Processes" - "Smb" - "Users" - "XIdleTime" - "XPath" - ]); + type = + with types; + nullOr (enum [ + "ActiveCalendarEvent" + "ActiveConnection" + "ExternalCommand" + "JsonPath" + "Kodi" + "KodiIdleTime" + "LastLogActivity" + "Load" + "LogindSessionsIdle" + "Mpd" + "NetworkBandwidth" + "Ping" + "Processes" + "Smb" + "Users" + "XIdleTime" + "XPath" + ]); description = '' Name of the class implementing the check. If this option is not specified, the check's name must represent a valid internal check class. @@ -71,19 +90,23 @@ let wakeupType = types.submodule { freeformType = settingsFormat.type.nestedTypes.elemType; - options.enabled = mkEnableOption "this wake-up check" // { default = true; }; + options.enabled = mkEnableOption "this wake-up check" // { + default = true; + }; options.class = mkOption { default = null; - type = with types; nullOr (enum [ - "Calendar" - "Command" - "File" - "Periodic" - "SystemdTimer" - "XPath" - "XPathDelta" - ]); + type = + with types; + nullOr (enum [ + "Calendar" + "Command" + "File" + "Periodic" + "SystemdTimer" + "XPath" + "XPathDelta" + ]); description = '' Name of the class implementing the check. If this option is not specified, the check's name must represent a valid internal check class. diff --git a/nixos/modules/services/misc/bcg.nix b/nixos/modules/services/misc/bcg.nix index 98193fcafb3e4a..002ff03ab068ae 100644 --- a/nixos/modules/services/misc/bcg.nix +++ b/nixos/modules/services/misc/bcg.nix @@ -6,7 +6,7 @@ }: let cfg = config.services.bcg; - configFile = (pkgs.formats.yaml {}).generate "bcg.conf.yaml" ( + configFile = (pkgs.formats.yaml { }).generate "bcg.conf.yaml" ( lib.filterAttrsRecursive (n: v: v != null) { inherit (cfg) device name mqtt; retain_node_messages = cfg.retainNodeMessages; @@ -26,7 +26,7 @@ in package = lib.mkPackageOption pkgs [ "python3Packages" "bcg" ] { }; environmentFiles = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; example = [ "/run/keys/bcg.env" ]; description = '' File to load as environment file. Environment variables from this file @@ -36,7 +36,13 @@ in ''; }; verbose = lib.mkOption { - type = lib.types.enum ["CRITICAL" "ERROR" "WARNING" "INFO" "DEBUG"]; + type = lib.types.enum [ + "CRITICAL" + "ERROR" + "WARNING" + "INFO" + "DEBUG" + ]; default = "WARNING"; description = "Verbosity level."; }; @@ -131,7 +137,7 @@ in }; rename = lib.mkOption { type = with lib.types; attrsOf str; - default = {}; + default = { }; description = "Rename nodes to different name."; }; }; @@ -143,25 +149,27 @@ in python3Packages.bch ]; - systemd.services.bcg = let - envConfig = cfg.environmentFiles != []; - finalConfig = if envConfig - then "\${RUNTIME_DIRECTORY}/bcg.config.yaml" - else configFile; - in { - description = "BigClown Gateway"; - wantedBy = [ "multi-user.target" ]; - wants = [ "network-online.target" ] ++ lib.optional config.services.mosquitto.enable "mosquitto.service"; - after = [ "network-online.target" ]; - preStart = lib.mkIf envConfig '' - umask 077 - ${pkgs.envsubst}/bin/envsubst -i "${configFile}" -o "${finalConfig}" + systemd.services.bcg = + let + envConfig = cfg.environmentFiles != [ ]; + finalConfig = if envConfig then "\${RUNTIME_DIRECTORY}/bcg.config.yaml" else configFile; + in + { + description = "BigClown Gateway"; + wantedBy = [ "multi-user.target" ]; + wants = [ + "network-online.target" + ] ++ lib.optional config.services.mosquitto.enable "mosquitto.service"; + after = [ "network-online.target" ]; + preStart = lib.mkIf envConfig '' + umask 077 + ${pkgs.envsubst}/bin/envsubst -i "${configFile}" -o "${finalConfig}" ''; - serviceConfig = { - EnvironmentFile = cfg.environmentFiles; - ExecStart = "${cfg.package}/bin/bcg -c ${finalConfig} -v ${cfg.verbose}"; - RuntimeDirectory = "bcg"; + serviceConfig = { + EnvironmentFile = cfg.environmentFiles; + ExecStart = "${cfg.package}/bin/bcg -c ${finalConfig} -v ${cfg.verbose}"; + RuntimeDirectory = "bcg"; + }; }; - }; }; } diff --git a/nixos/modules/services/misc/beanstalkd.nix b/nixos/modules/services/misc/beanstalkd.nix index 5f7e4be34daa69..d2a652e5372d7b 100644 --- a/nixos/modules/services/misc/beanstalkd.nix +++ b/nixos/modules/services/misc/beanstalkd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.beanstalkd; pkg = pkgs.beanstalkd; diff --git a/nixos/modules/services/misc/bepasty.nix b/nixos/modules/services/misc/bepasty.nix index 76e85a91317c23..d890fe507ae7c0 100644 --- a/nixos/modules/services/misc/bepasty.nix +++ b/nixos/modules/services/misc/bepasty.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let gunicorn = pkgs.python3Packages.gunicorn; bepasty = pkgs.bepasty; @@ -14,105 +19,115 @@ in enable = lib.mkEnableOption "bepasty, a binary pastebin server"; servers = lib.mkOption { - default = {}; + default = { }; description = '' configure a number of bepasty servers which will be started with gunicorn. - ''; - type = with lib.types ; attrsOf (submodule ({ config, ... } : { - - options = { - - bind = lib.mkOption { - type = lib.types.str; - description = '' - Bind address to be used for this server. - ''; - example = "0.0.0.0:8000"; - default = "127.0.0.1:8000"; - }; - - dataDir = lib.mkOption { - type = lib.types.str; - description = '' - Path to the directory where the pastes will be saved to - ''; - default = default_home+"/data"; - }; - - defaultPermissions = lib.mkOption { - type = lib.types.str; - description = '' - default permissions for all unauthenticated accesses. - ''; - example = "read,create,delete"; - default = "read"; - }; - - extraConfig = lib.mkOption { - type = lib.types.lines; - description = '' - Extra configuration for bepasty server to be appended on the - configuration. - see https://bepasty-server.readthedocs.org/en/latest/quickstart.html#configuring-bepasty - for all options. - ''; - default = ""; - example = '' - PERMISSIONS = { - 'myadminsecret': 'admin,list,create,read,delete', - } - MAX_ALLOWED_FILE_SIZE = 5 * 1000 * 1000 - ''; - }; - - secretKey = lib.mkOption { - type = lib.types.str; - description = '' - server secret for safe session cookies, must be set. - - Warning: this secret is stored in the WORLD-READABLE Nix store! - - It's recommended to use {option}`secretKeyFile` - which takes precedence over {option}`secretKey`. - ''; - default = ""; - }; - - secretKeyFile = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - description = '' - A file that contains the server secret for safe session cookies, must be set. - - {option}`secretKeyFile` takes precedence over {option}`secretKey`. - - Warning: when {option}`secretKey` is non-empty {option}`secretKeyFile` - defaults to a file in the WORLD-READABLE Nix store containing that secret. - ''; - }; - - workDir = lib.mkOption { - type = lib.types.str; - description = '' - Path to the working directory (used for config and pidfile). - Defaults to the users home directory. - ''; - default = default_home; - }; - - }; - config = { - secretKeyFile = lib.mkDefault ( - if config.secretKey != "" - then toString (pkgs.writeTextFile { - name = "bepasty-secret-key"; - text = config.secretKey; - }) - else null - ); - }; - })); + ''; + type = + with lib.types; + attrsOf ( + submodule ( + { config, ... }: + { + + options = { + + bind = lib.mkOption { + type = lib.types.str; + description = '' + Bind address to be used for this server. + ''; + example = "0.0.0.0:8000"; + default = "127.0.0.1:8000"; + }; + + dataDir = lib.mkOption { + type = lib.types.str; + description = '' + Path to the directory where the pastes will be saved to + ''; + default = default_home + "/data"; + }; + + defaultPermissions = lib.mkOption { + type = lib.types.str; + description = '' + default permissions for all unauthenticated accesses. + ''; + example = "read,create,delete"; + default = "read"; + }; + + extraConfig = lib.mkOption { + type = lib.types.lines; + description = '' + Extra configuration for bepasty server to be appended on the + configuration. + see https://bepasty-server.readthedocs.org/en/latest/quickstart.html#configuring-bepasty + for all options. + ''; + default = ""; + example = '' + PERMISSIONS = { + 'myadminsecret': 'admin,list,create,read,delete', + } + MAX_ALLOWED_FILE_SIZE = 5 * 1000 * 1000 + ''; + }; + + secretKey = lib.mkOption { + type = lib.types.str; + description = '' + server secret for safe session cookies, must be set. + + Warning: this secret is stored in the WORLD-READABLE Nix store! + + It's recommended to use {option}`secretKeyFile` + which takes precedence over {option}`secretKey`. + ''; + default = ""; + }; + + secretKeyFile = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = null; + description = '' + A file that contains the server secret for safe session cookies, must be set. + + {option}`secretKeyFile` takes precedence over {option}`secretKey`. + + Warning: when {option}`secretKey` is non-empty {option}`secretKeyFile` + defaults to a file in the WORLD-READABLE Nix store containing that secret. + ''; + }; + + workDir = lib.mkOption { + type = lib.types.str; + description = '' + Path to the working directory (used for config and pidfile). + Defaults to the users home directory. + ''; + default = default_home; + }; + + }; + config = { + secretKeyFile = lib.mkDefault ( + if config.secretKey != "" then + toString ( + pkgs.writeTextFile { + name = "bepasty-secret-key"; + text = config.secretKey; + } + ) + else + null + ); + }; + } + ) + ); }; }; @@ -121,27 +136,34 @@ in environment.systemPackages = [ bepasty ]; # creates gunicorn systemd service for each configured server - systemd.services = lib.mapAttrs' (name: server: - lib.nameValuePair ("bepasty-server-${name}-gunicorn") - ({ - description = "Bepasty Server ${name}"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - restartIfChanged = true; - - environment = let + systemd.services = lib.mapAttrs' ( + name: server: + lib.nameValuePair ("bepasty-server-${name}-gunicorn") ({ + description = "Bepasty Server ${name}"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + restartIfChanged = true; + + environment = + let penv = python.buildEnv.override { - extraLibs = [ bepasty gevent ]; + extraLibs = [ + bepasty + gevent + ]; }; - in { + in + { BEPASTY_CONFIG = "${server.workDir}/bepasty-${name}.conf"; - PYTHONPATH= "${penv}/${python.sitePackages}/"; + PYTHONPATH = "${penv}/${python.sitePackages}/"; }; - serviceConfig = { - Type = "simple"; - PrivateTmp = true; - ExecStartPre = assert server.secretKeyFile != null; pkgs.writeScript "bepasty-server.${name}-init" '' + serviceConfig = { + Type = "simple"; + PrivateTmp = true; + ExecStartPre = + assert server.secretKeyFile != null; + pkgs.writeScript "bepasty-server.${name}-init" '' #!/bin/sh mkdir -p "${server.workDir}" mkdir -p "${server.dataDir}" @@ -154,23 +176,24 @@ in ${server.extraConfig} EOF ''; - ExecStart = ''${gunicorn}/bin/gunicorn bepasty.wsgi --name ${name} \ - -u ${user} \ - -g ${group} \ - --workers 3 --log-level=info \ - --bind=${server.bind} \ - --pid ${server.workDir}/gunicorn-${name}.pid \ - -k gevent - ''; - }; - }) + ExecStart = '' + ${gunicorn}/bin/gunicorn bepasty.wsgi --name ${name} \ + -u ${user} \ + -g ${group} \ + --workers 3 --log-level=info \ + --bind=${server.bind} \ + --pid ${server.workDir}/gunicorn-${name}.pid \ + -k gevent + ''; + }; + }) ) cfg.servers; - users.users.${user} = - { uid = config.ids.uids.bepasty; - group = group; - home = default_home; - }; + users.users.${user} = { + uid = config.ids.uids.bepasty; + group = group; + home = default_home; + }; users.groups.${group}.gid = config.ids.gids.bepasty; }; diff --git a/nixos/modules/services/misc/blenderfarm.nix b/nixos/modules/services/misc/blenderfarm.nix index 0d8ecf7af8e20c..dbe6bcad136544 100644 --- a/nixos/modules/services/misc/blenderfarm.nix +++ b/nixos/modules/services/misc/blenderfarm.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let cfg = config.services.blendfarm; @@ -35,8 +36,9 @@ in }; basicSecurityPasswordFile = lib.mkOption { - description = ''Path to the password file the client needs to connect to the server. - The password must not contain a forward slash.''; + description = '' + Path to the password file the client needs to connect to the server. + The password must not contain a forward slash.''; default = null; type = nullOr str; }; @@ -83,20 +85,21 @@ in wants = [ "network-online.target" ]; description = "blendfarm server"; path = [ cfg.blenderPackage ]; - preStart = '' - rm -f ServerSettings - install -m640 ${configFile} ServerSettings - if [ ! -d "BlenderData/nix-blender-linux64" ]; then - mkdir -p BlenderData/nix-blender-linux64 - echo "nix-blender" > VersionCustom - fi - rm -f BlenderData/nix-blender-linux64/blender - ln -s ${lib.getExe cfg.blenderPackage} BlenderData/nix-blender-linux64/blender - '' + - lib.optionalString (cfg.basicSecurityPasswordFile != null) '' - BLENDFARM_PASSWORD=$(${pkgs.systemd}/bin/systemd-creds cat BLENDFARM_PASS_FILE) - sed -i "s/null/\"$BLENDFARM_PASSWORD\"/g" ServerSettings - ''; + preStart = + '' + rm -f ServerSettings + install -m640 ${configFile} ServerSettings + if [ ! -d "BlenderData/nix-blender-linux64" ]; then + mkdir -p BlenderData/nix-blender-linux64 + echo "nix-blender" > VersionCustom + fi + rm -f BlenderData/nix-blender-linux64/blender + ln -s ${lib.getExe cfg.blenderPackage} BlenderData/nix-blender-linux64/blender + '' + + lib.optionalString (cfg.basicSecurityPasswordFile != null) '' + BLENDFARM_PASSWORD=$(${pkgs.systemd}/bin/systemd-creds cat BLENDFARM_PASS_FILE) + sed -i "s/null/\"$BLENDFARM_PASSWORD\"/g" ServerSettings + ''; serviceConfig = { ExecStart = "${cfg.package}/bin/LogicReinc.BlendFarm.Server"; DynamicUser = true; @@ -106,10 +109,16 @@ in User = cfg.user; Group = cfg.group; StateDirectoryMode = "0755"; - LoadCredential = lib.optional (cfg.basicSecurityPasswordFile != null) "BLENDFARM_PASS_FILE:${cfg.basicSecurityPasswordFile}"; + LoadCredential = lib.optional ( + cfg.basicSecurityPasswordFile != null + ) "BLENDFARM_PASS_FILE:${cfg.basicSecurityPasswordFile}"; ReadWritePaths = ""; CapabilityBoundingSet = ""; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; PrivateDevices = true; PrivateUsers = true; diff --git a/nixos/modules/services/misc/calibre-server.nix b/nixos/modules/services/misc/calibre-server.nix index 160a1c1e53c4ac..10da80b8c49829 100644 --- a/nixos/modules/services/misc/calibre-server.nix +++ b/nixos/modules/services/misc/calibre-server.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.calibre-server; @@ -6,22 +11,33 @@ let documentationLink = "https://manual.calibre-ebook.com"; generatedDocumentationLink = documentationLink + "/generated/en/calibre-server.html"; - execFlags = (lib.concatStringsSep " " - (lib.mapAttrsToList (k: v: "${k} ${toString v}") (lib.filterAttrs (name: value: value != null) { - "--listen-on" = cfg.host; - "--port" = cfg.port; - "--auth-mode" = cfg.auth.mode; - "--userdb" = cfg.auth.userDb; - }) ++ [ (lib.optionalString (cfg.auth.enable == true) "--enable-auth") ] ++ cfg.extraFlags) + execFlags = ( + lib.concatStringsSep " " ( + lib.mapAttrsToList (k: v: "${k} ${toString v}") ( + lib.filterAttrs (name: value: value != null) { + "--listen-on" = cfg.host; + "--port" = cfg.port; + "--auth-mode" = cfg.auth.mode; + "--userdb" = cfg.auth.userDb; + } + ) + ++ [ (lib.optionalString (cfg.auth.enable == true) "--enable-auth") ] + ++ cfg.extraFlags + ) ); in { imports = [ - (lib.mkChangedOptionModule [ "services" "calibre-server" "libraryDir" ] [ "services" "calibre-server" "libraries" ] - (config: - let libraryDir = lib.getAttrFromPath [ "services" "calibre-server" "libraryDir" ] config; - in [ libraryDir ] + (lib.mkChangedOptionModule + [ "services" "calibre-server" "libraryDir" ] + [ "services" "calibre-server" "libraries" ] + ( + config: + let + libraryDir = lib.getAttrFromPath [ "services" "calibre-server" "libraryDir" ] config; + in + [ libraryDir ] ) ) ]; @@ -85,8 +101,7 @@ in openFirewall = lib.mkOption { type = lib.types.bool; default = false; - description = - "Open ports in the firewall for the Calibre Server web interface."; + description = "Open ports in the firewall for the Calibre Server web interface."; }; auth = { @@ -100,7 +115,11 @@ in }; mode = lib.mkOption { - type = lib.types.enum [ "auto" "basic" "digest" ]; + type = lib.types.enum [ + "auto" + "basic" + "digest" + ]; default = "auto"; description = '' Choose the type of authentication used. @@ -153,8 +172,7 @@ in }; }; - networking.firewall = - lib.mkIf cfg.openFirewall { allowedTCPPorts = [ cfg.port ]; }; + networking.firewall = lib.mkIf cfg.openFirewall { allowedTCPPorts = [ cfg.port ]; }; }; diff --git a/nixos/modules/services/misc/canto-daemon.nix b/nixos/modules/services/misc/canto-daemon.nix index c5a702b79e4478..1fc4e3d0944f83 100644 --- a/nixos/modules/services/misc/canto-daemon.nix +++ b/nixos/modules/services/misc/canto-daemon.nix @@ -1,11 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let -cfg = config.services.canto-daemon; + cfg = config.services.canto-daemon; -in { +in +{ -##### interface + ##### interface options = { @@ -19,7 +25,7 @@ in { }; -##### implementation + ##### implementation config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/misc/cfdyndns.nix b/nixos/modules/services/misc/cfdyndns.nix index a34e5d6d391351..bd870c2acdda24 100644 --- a/nixos/modules/services/misc/cfdyndns.nix +++ b/nixos/modules/services/misc/cfdyndns.nix @@ -1,12 +1,19 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.cfdyndns; in { imports = [ - (lib.mkRemovedOptionModule - [ "services" "cfdyndns" "apikey" ] - "Use services.cfdyndns.apikeyFile instead.") + (lib.mkRemovedOptionModule [ + "services" + "cfdyndns" + "apikey" + ] "Use services.cfdyndns.apikeyFile instead.") ]; options = { @@ -39,7 +46,7 @@ in }; records = lib.mkOption { - default = []; + default = [ ]; example = [ "host.tld" ]; type = lib.types.listOf lib.types.str; description = '' @@ -57,11 +64,13 @@ in startAt = "*:0/5"; serviceConfig = { Type = "simple"; - LoadCredential = lib.optional (cfg.apiTokenFile != null) "CLOUDFLARE_APITOKEN_FILE:${cfg.apiTokenFile}"; + LoadCredential = lib.optional ( + cfg.apiTokenFile != null + ) "CLOUDFLARE_APITOKEN_FILE:${cfg.apiTokenFile}"; DynamicUser = true; }; environment = { - CLOUDFLARE_RECORDS="${lib.concatStringsSep "," cfg.records}"; + CLOUDFLARE_RECORDS = "${lib.concatStringsSep "," cfg.records}"; }; script = '' ${lib.optionalString (cfg.apikeyFile != null) '' diff --git a/nixos/modules/services/misc/cgminer.nix b/nixos/modules/services/misc/cgminer.nix index 6aa6bc63c99c87..f87a05d00fc1ac 100644 --- a/nixos/modules/services/misc/cgminer.nix +++ b/nixos/modules/services/misc/cgminer.nix @@ -1,25 +1,33 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.cgminer; - convType = with builtins; - v: if lib.isBool v then lib.boolToString v else toString v; - mergedHwConfig = - lib.mapAttrsToList (n: v: ''"${n}": "${(lib.concatStringsSep "," (map convType v))}"'') - (lib.foldAttrs (n: a: [n] ++ a) [] cfg.hardware); - mergedConfig = with builtins; - lib.mapAttrsToList (n: v: ''"${n}": ${if lib.isBool v then convType v else ''"${convType v}"''}'') - cfg.config; + convType = with builtins; v: if lib.isBool v then lib.boolToString v else toString v; + mergedHwConfig = lib.mapAttrsToList ( + n: v: ''"${n}": "${(lib.concatStringsSep "," (map convType v))}"'' + ) (lib.foldAttrs (n: a: [ n ] ++ a) [ ] cfg.hardware); + mergedConfig = + with builtins; + lib.mapAttrsToList ( + n: v: ''"${n}": ${if lib.isBool v then convType v else ''"${convType v}"''}'' + ) cfg.config; cgminerConfig = pkgs.writeText "cgminer.conf" '' - { - ${lib.concatStringsSep ",\n" mergedHwConfig}, - ${lib.concatStringsSep ",\n" mergedConfig}, - "pools": [ - ${lib.concatStringsSep ",\n" - (map (v: ''{"url": "${v.url}", "user": "${v.user}", "pass": "${v.pass}"}'') - cfg.pools)}] - } + { + ${lib.concatStringsSep ",\n" mergedHwConfig}, + ${lib.concatStringsSep ",\n" mergedConfig}, + "pools": [ + ${ + lib.concatStringsSep ",\n" ( + map (v: ''{"url": "${v.url}", "user": "${v.user}", "pass": "${v.pass}"}'') cfg.pools + ) + }] + } ''; in { @@ -39,45 +47,48 @@ in }; pools = lib.mkOption { - default = []; # Run benchmark + default = [ ]; # Run benchmark type = lib.types.listOf (lib.types.attrsOf lib.types.str); description = "List of pools where to mine"; - example = [{ - url = "http://p2pool.org:9332"; - username = "17EUZxTvs9uRmPsjPZSYUU3zCz9iwstudk"; - password="X"; - }]; + example = [ + { + url = "http://p2pool.org:9332"; + username = "17EUZxTvs9uRmPsjPZSYUU3zCz9iwstudk"; + password = "X"; + } + ]; }; hardware = lib.mkOption { - default = []; # Run without options + default = [ ]; # Run without options type = lib.types.listOf (lib.types.attrsOf (lib.types.either lib.types.str lib.types.int)); - description= "List of config options for every GPU"; + description = "List of config options for every GPU"; example = [ - { - intensity = 9; - gpu-engine = "0-985"; - gpu-fan = "0-85"; - gpu-memclock = 860; - gpu-powertune = 20; - temp-cutoff = 95; - temp-overheat = 85; - temp-target = 75; - } - { - intensity = 9; - gpu-engine = "0-950"; - gpu-fan = "0-85"; - gpu-memclock = 825; - gpu-powertune = 20; - temp-cutoff = 95; - temp-overheat = 85; - temp-target = 75; - }]; + { + intensity = 9; + gpu-engine = "0-985"; + gpu-fan = "0-85"; + gpu-memclock = 860; + gpu-powertune = 20; + temp-cutoff = 95; + temp-overheat = 85; + temp-target = 75; + } + { + intensity = 9; + gpu-engine = "0-950"; + gpu-fan = "0-85"; + gpu-memclock = 825; + gpu-powertune = 20; + temp-cutoff = 95; + temp-overheat = 85; + temp-target = 75; + } + ]; }; config = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf (lib.types.either lib.types.bool lib.types.int); description = "Additional config"; example = { @@ -95,7 +106,6 @@ in }; }; - ###### implementation config = lib.mkIf config.services.cgminer.enable { @@ -108,7 +118,7 @@ in }; }; users.groups = lib.optionalAttrs (cfg.user == "cgminer") { - cgminer = {}; + cgminer = { }; }; environment.systemPackages = [ cfg.package ]; @@ -116,7 +126,10 @@ in systemd.services.cgminer = { path = [ pkgs.cgminer ]; - after = [ "network.target" "display-manager.service" ]; + after = [ + "network.target" + "display-manager.service" + ]; wantedBy = [ "multi-user.target" ]; environment = { @@ -126,7 +139,7 @@ in GPU_USE_SYNC_OBJECTS = "1"; }; - startLimitIntervalSec = 60; # 1 min + startLimitIntervalSec = 60; # 1 min serviceConfig = { ExecStart = "${pkgs.cgminer}/bin/cgminer --syslog --text-only --config ${cgminerConfig}"; User = cfg.user; diff --git a/nixos/modules/services/misc/clipcat.nix b/nixos/modules/services/misc/clipcat.nix index 4a46adc0758a92..4860f023c9e5ed 100644 --- a/nixos/modules/services/misc/clipcat.nix +++ b/nixos/modules/services/misc/clipcat.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.clipcat; -in { +in +{ - options.services.clipcat= { + options.services.clipcat = { enable = lib.mkEnableOption "Clipcat clipboard daemon"; package = lib.mkPackageOption pkgs "clipcat" { }; @@ -11,10 +17,10 @@ in { config = lib.mkIf cfg.enable { systemd.user.services.clipcat = { - enable = true; + enable = true; description = "clipcat daemon"; wantedBy = [ "graphical-session.target" ]; - after = [ "graphical-session.target" ]; + after = [ "graphical-session.target" ]; serviceConfig.ExecStart = "${cfg.package}/bin/clipcatd --no-daemon"; }; diff --git a/nixos/modules/services/misc/clipmenu.nix b/nixos/modules/services/misc/clipmenu.nix index 559917b7a2bfb7..cf17a443ed97fc 100644 --- a/nixos/modules/services/misc/clipmenu.nix +++ b/nixos/modules/services/misc/clipmenu.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.clipmenu; -in { +in +{ options.services.clipmenu = { enable = lib.mkEnableOption "clipmenu, the clipboard management daemon"; @@ -11,10 +17,10 @@ in { config = lib.mkIf cfg.enable { systemd.user.services.clipmenu = { - enable = true; + enable = true; description = "Clipboard management daemon"; wantedBy = [ "graphical-session.target" ]; - after = [ "graphical-session.target" ]; + after = [ "graphical-session.target" ]; serviceConfig.ExecStart = "${cfg.package}/bin/clipmenud"; }; diff --git a/nixos/modules/services/misc/confd.nix b/nixos/modules/services/misc/confd.nix index 7744cee3204997..fc24c01a894096 100644 --- a/nixos/modules/services/misc/confd.nix +++ b/nixos/modules/services/misc/confd.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.confd; @@ -12,14 +17,20 @@ let watch = ${lib.boolToString cfg.watch} ''; -in { +in +{ options.services.confd = { enable = lib.mkEnableOption "confd, a service to manage local application configuration files using templates and data from etcd/consul/redis/zookeeper"; backend = lib.mkOption { description = "Confd config storage backend to use."; default = "etcd"; - type = lib.types.enum ["etcd" "consul" "redis" "zookeeper"]; + type = lib.types.enum [ + "etcd" + "consul" + "redis" + "zookeeper" + ]; }; interval = lib.mkOption { @@ -49,7 +60,10 @@ in { logLevel = lib.mkOption { description = "Confd log level."; default = "info"; - type = lib.types.enum ["info" "debug"]; + type = lib.types.enum [ + "info" + "debug" + ]; }; confDir = lib.mkOption { diff --git a/nixos/modules/services/misc/cpuminer-cryptonight.nix b/nixos/modules/services/misc/cpuminer-cryptonight.nix index c61c0d7c34bdd2..adaee2bbb2157f 100644 --- a/nixos/modules/services/misc/cpuminer-cryptonight.nix +++ b/nixos/modules/services/misc/cpuminer-cryptonight.nix @@ -1,12 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.cpuminer-cryptonight; json = builtins.toJSON ( - cfg // { - enable = null; - threads = - if cfg.threads == 0 then null else toString cfg.threads; + cfg + // { + enable = null; + threads = if cfg.threads == 0 then null else toString cfg.threads; } ); diff --git a/nixos/modules/services/misc/db-rest.nix b/nixos/modules/services/misc/db-rest.nix index fbf8b327af049a..6cb9dd3da57724 100644 --- a/nixos/modules/services/misc/db-rest.nix +++ b/nixos/modules/services/misc/db-rest.nix @@ -1,6 +1,20 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let - inherit (lib) mkOption types mkIf mkMerge mkDefault mkEnableOption mkPackageOption maintainers; + inherit (lib) + mkOption + types + mkIf + mkMerge + mkDefault + mkEnableOption + mkPackageOption + maintainers + ; cfg = config.services.db-rest; in { @@ -84,7 +98,9 @@ in config = mkIf cfg.enable { assertions = [ { - assertion = (cfg.redis.enable && !cfg.redis.createLocally) -> (cfg.redis.host != null && cfg.redis.port != null); + assertion = + (cfg.redis.enable && !cfg.redis.createLocally) + -> (cfg.redis.host != null && cfg.redis.port != null); message = '' {option}`services.db-rest.redis.createLocally` and redis network connection ({option}`services.db-rest.redis.host` or {option}`services.db-rest.redis.port`) enabled. Disable either of them. ''; @@ -100,8 +116,7 @@ in systemd.services.db-rest = mkMerge [ { description = "db-rest service"; - after = [ "network.target" ] - ++ lib.optional cfg.redis.createLocally "redis-db-rest.service"; + after = [ "network.target" ] ++ lib.optional cfg.redis.createLocally "redis-db-rest.service"; requires = lib.optional cfg.redis.createLocally "redis-db-rest.service"; wantedBy = [ "multi-user.target" ]; serviceConfig = { @@ -111,9 +126,15 @@ in WorkingDirectory = cfg.package; User = cfg.user; Group = cfg.group; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; MemoryDenyWriteExecute = false; - LoadCredential = lib.optional (cfg.redis.enable && cfg.redis.passwordFile != null) "REDIS_PASSWORD:${cfg.redis.passwordFile}"; + LoadCredential = lib.optional ( + cfg.redis.enable && cfg.redis.passwordFile != null + ) "REDIS_PASSWORD:${cfg.redis.passwordFile}"; ExecStart = mkDefault "${cfg.package}/bin/db-rest"; RemoveIPC = true; @@ -146,22 +167,24 @@ in PORT = toString cfg.port; }; } - (mkIf cfg.redis.enable (if cfg.redis.createLocally then - { environment.REDIS_URL = config.services.redis.servers.db-rest.unixSocket; } - else - { - script = - let - username = lib.optionalString (cfg.redis.user != null) (cfg.redis.user); - host = cfg.redis.host; - port = toString cfg.redis.port; - protocol = if cfg.redis.useSSL then "rediss" else "redis"; - in - '' - export REDIS_URL="${protocol}://${username}:$(${config.systemd.package}/bin/systemd-creds cat REDIS_PASSWORD)@${host}:${port}" - exec ${cfg.package}/bin/db-rest - ''; - })) + (mkIf cfg.redis.enable ( + if cfg.redis.createLocally then + { environment.REDIS_URL = config.services.redis.servers.db-rest.unixSocket; } + else + { + script = + let + username = lib.optionalString (cfg.redis.user != null) (cfg.redis.user); + host = cfg.redis.host; + port = toString cfg.redis.port; + protocol = if cfg.redis.useSSL then "rediss" else "redis"; + in + '' + export REDIS_URL="${protocol}://${username}:$(${config.systemd.package}/bin/systemd-creds cat REDIS_PASSWORD)@${host}:${port}" + exec ${cfg.package}/bin/db-rest + ''; + } + )) ]; users.users = lib.mkMerge [ diff --git a/nixos/modules/services/misc/devmon.nix b/nixos/modules/services/misc/devmon.nix index 13e2ab7f31c258..7bf801c6a4f5b2 100644 --- a/nixos/modules/services/misc/devmon.nix +++ b/nixos/modules/services/misc/devmon.nix @@ -1,8 +1,14 @@ -{ pkgs, config, lib, ... }: +{ + pkgs, + config, + lib, + ... +}: let cfg = config.services.devmon; -in { +in +{ options = { services.devmon = { enable = lib.mkEnableOption "devmon, an automatic device mounting daemon"; @@ -13,7 +19,12 @@ in { systemd.user.services.devmon = { description = "devmon automatic device mounting daemon"; wantedBy = [ "default.target" ]; - path = [ pkgs.udevil pkgs.procps pkgs.udisks2 pkgs.which ]; + path = [ + pkgs.udevil + pkgs.procps + pkgs.udisks2 + pkgs.which + ]; serviceConfig.ExecStart = "${pkgs.udevil}/bin/devmon"; }; diff --git a/nixos/modules/services/misc/devpi-server.nix b/nixos/modules/services/misc/devpi-server.nix index ad72a8ced69a3e..309ef8325f9fa0 100644 --- a/nixos/modules/services/misc/devpi-server.nix +++ b/nixos/modules/services/misc/devpi-server.nix @@ -73,9 +73,9 @@ in # have 0600 permissions. preStart = '' - ${lib.optionalString (!isNull cfg.secretFile) - "install -Dm 0600 \${CREDENTIALS_DIRECTORY}/devpi-secret ${runtimeDir}/${secretsFileName}" - } + ${lib.optionalString ( + !isNull cfg.secretFile + ) "install -Dm 0600 \${CREDENTIALS_DIRECTORY}/devpi-secret ${runtimeDir}/${secretsFileName}"} if [ -f ${serverDir}/.nodeinfo ]; then # already initialized the package index, exit gracefully @@ -85,7 +85,7 @@ in + lib.optionalString cfg.replica "--role=replica --master-url=${cfg.primaryUrl}"; serviceConfig = { - LoadCredential = lib.mkIf (! isNull cfg.secretFile) [ + LoadCredential = lib.mkIf (!isNull cfg.secretFile) [ "devpi-secret:${cfg.secretFile}" ]; Restart = "always"; @@ -98,7 +98,7 @@ in "--host=${cfg.host}" "--port=${builtins.toString cfg.port}" ] - ++ lib.optionals (! isNull cfg.secretFile) [ + ++ lib.optionals (!isNull cfg.secretFile) [ "--secretfile=${runtimeDir}/${secretsFileName}" ] ++ ( diff --git a/nixos/modules/services/misc/dictd.nix b/nixos/modules/services/misc/dictd.nix index b11a87f2890518..b216459b2d9b90 100644 --- a/nixos/modules/services/misc/dictd.nix +++ b/nixos/modules/services/misc/dictd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.dictd; in @@ -21,7 +26,10 @@ in DBs = lib.mkOption { type = lib.types.listOf lib.types.package; - default = with pkgs.dictdDBs; [ wiktionary wordnet ]; + default = with pkgs.dictdDBs; [ + wiktionary + wordnet + ]; defaultText = lib.literalExpression "with pkgs.dictdDBs; [ wiktionary wordnet ]"; example = lib.literalExpression "[ pkgs.dictdDBs.nld2eng ]"; description = "List of databases to make available."; @@ -31,39 +39,46 @@ in }; - ###### implementation - config = let dictdb = pkgs.dictDBCollector { dictlist = map (x: { - name = x.name; - filename = x; } ) cfg.DBs; }; - in lib.mkIf cfg.enable { + config = + let + dictdb = pkgs.dictDBCollector { + dictlist = map (x: { + name = x.name; + filename = x; + }) cfg.DBs; + }; + in + lib.mkIf cfg.enable { - # get the command line client on system path to make some use of the service - environment.systemPackages = [ pkgs.dict ]; + # get the command line client on system path to make some use of the service + environment.systemPackages = [ pkgs.dict ]; - environment.etc."dict.conf".text = '' - server localhost - ''; + environment.etc."dict.conf".text = '' + server localhost + ''; - users.users.dictd = - { group = "dictd"; + users.users.dictd = { + group = "dictd"; description = "DICT.org dictd server"; home = "${dictdb}/share/dictd"; uid = config.ids.uids.dictd; }; - users.groups.dictd.gid = config.ids.gids.dictd; - - systemd.services.dictd = { - description = "DICT.org Dictionary Server"; - wantedBy = [ "multi-user.target" ]; - environment = { LOCALE_ARCHIVE = "/run/current-system/sw/lib/locale/locale-archive"; }; - # Work around the fact that dictd doesn't handle SIGTERM; it terminates - # with code 143 instead of exiting with code 0. - serviceConfig.SuccessExitStatus = [ 143 ]; - serviceConfig.Type = "forking"; - script = "${pkgs.dict}/sbin/dictd -s -c ${dictdb}/share/dictd/dictd.conf --locale en_US.UTF-8"; + users.groups.dictd.gid = config.ids.gids.dictd; + + systemd.services.dictd = { + description = "DICT.org Dictionary Server"; + wantedBy = [ "multi-user.target" ]; + environment = { + LOCALE_ARCHIVE = "/run/current-system/sw/lib/locale/locale-archive"; + }; + # Work around the fact that dictd doesn't handle SIGTERM; it terminates + # with code 143 instead of exiting with code 0. + serviceConfig.SuccessExitStatus = [ 143 ]; + serviceConfig.Type = "forking"; + script = "${pkgs.dict}/sbin/dictd -s -c ${dictdb}/share/dictd/dictd.conf --locale en_US.UTF-8"; + }; }; - }; } diff --git a/nixos/modules/services/misc/disnix.nix b/nixos/modules/services/misc/disnix.nix index 1869822a07f3eb..8c808d5143e027 100644 --- a/nixos/modules/services/misc/disnix.nix +++ b/nixos/modules/services/misc/disnix.nix @@ -1,5 +1,10 @@ # Disnix server -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.disnix; @@ -24,7 +29,7 @@ in useWebServiceInterface = lib.mkEnableOption "the DisnixWebService interface running on Apache Tomcat"; - package = lib.mkPackageOption pkgs "disnix" {}; + package = lib.mkPackageOption pkgs "disnix" { }; enableProfilePath = lib.mkEnableOption "exposing the Disnix profiles in the system's PATH"; @@ -42,8 +47,12 @@ in config = lib.mkIf cfg.enable { services.dysnomia.enable = true; - environment.systemPackages = [ pkgs.disnix ] ++ lib.optional cfg.useWebServiceInterface pkgs.DisnixWebService; - environment.variables.PATH = lib.optionals cfg.enableProfilePath (map (profileName: "/nix/var/nix/profiles/disnix/${profileName}/bin" ) cfg.profiles); + environment.systemPackages = [ + pkgs.disnix + ] ++ lib.optional cfg.useWebServiceInterface pkgs.DisnixWebService; + environment.variables.PATH = lib.optionals cfg.enableProfilePath ( + map (profileName: "/nix/var/nix/profiles/disnix/${profileName}/bin") cfg.profiles + ); environment.variables.DISNIX_REMOTE_CLIENT = lib.optionalString (cfg.enableMultiUser) "disnix-client"; services.dbus.enable = true; @@ -52,7 +61,8 @@ in services.tomcat.enable = cfg.useWebServiceInterface; services.tomcat.extraGroups = [ "disnix" ]; services.tomcat.javaOpts = "${lib.optionalString cfg.useWebServiceInterface "-Djava.library.path=${pkgs.libmatthew_java}/lib/jni"} "; - services.tomcat.sharedLibs = lib.optional cfg.useWebServiceInterface "${pkgs.DisnixWebService}/share/java/DisnixConnection.jar" + services.tomcat.sharedLibs = + lib.optional cfg.useWebServiceInterface "${pkgs.DisnixWebService}/share/java/DisnixConnection.jar" ++ lib.optional cfg.useWebServiceInterface "${pkgs.dbus_java}/share/java/dbus.jar"; services.tomcat.webapps = lib.optional cfg.useWebServiceInterface pkgs.DisnixWebService; @@ -63,7 +73,8 @@ in description = "Disnix server"; wants = [ "dysnomia.target" ]; wantedBy = [ "multi-user.target" ]; - after = [ "dbus.service" ] + after = + [ "dbus.service" ] ++ lib.optional config.services.httpd.enable "httpd.service" ++ lib.optional config.services.mysql.enable "mysql.service" ++ lib.optional config.services.postgresql.enable "postgresql.service" @@ -74,13 +85,23 @@ in restartIfChanged = false; - path = [ config.nix.package cfg.package config.services.dysnomia.package "/run/current-system/sw" ]; - - environment = { - HOME = "/root"; - } - // (lib.optionalAttrs (config.environment.variables ? DYSNOMIA_CONTAINERS_PATH) { inherit (config.environment.variables) DYSNOMIA_CONTAINERS_PATH; }) - // (lib.optionalAttrs (config.environment.variables ? DYSNOMIA_MODULES_PATH) { inherit (config.environment.variables) DYSNOMIA_MODULES_PATH; }); + path = [ + config.nix.package + cfg.package + config.services.dysnomia.package + "/run/current-system/sw" + ]; + + environment = + { + HOME = "/root"; + } + // (lib.optionalAttrs (config.environment.variables ? DYSNOMIA_CONTAINERS_PATH) { + inherit (config.environment.variables) DYSNOMIA_CONTAINERS_PATH; + }) + // (lib.optionalAttrs (config.environment.variables ? DYSNOMIA_MODULES_PATH) { + inherit (config.environment.variables) DYSNOMIA_MODULES_PATH; + }); serviceConfig.ExecStart = "${cfg.package}/bin/disnix-service"; }; diff --git a/nixos/modules/services/misc/docker-registry.nix b/nixos/modules/services/misc/docker-registry.nix index 76fc16020d32f8..66a131332e7818 100644 --- a/nixos/modules/services/misc/docker-registry.nix +++ b/nixos/modules/services/misc/docker-registry.nix @@ -1,13 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.dockerRegistry; - blobCache = if cfg.enableRedisCache - then "redis" - else "inmemory"; + blobCache = if cfg.enableRedisCache then "redis" else "inmemory"; registryConfig = { - version = "0.1"; + version = "0.1"; log.fields.service = "registry"; storage = { cache.blobdescriptor = blobCache; @@ -15,7 +18,7 @@ let } // (lib.optionalAttrs (cfg.storagePath != null) { filesystem.rootdirectory = cfg.storagePath; }); http = { addr = "${cfg.listenAddress}:${builtins.toString cfg.port}"; - headers.X-Content-Type-Options = ["nosniff"]; + headers.X-Content-Type-Options = [ "nosniff" ]; }; health.storagedriver = { enabled = true; @@ -39,7 +42,8 @@ let }; configFile = cfg.configFile; -in { +in +{ options.services.dockerRegistry = { enable = lib.mkEnableOption "Docker Registry"; @@ -103,19 +107,21 @@ in { log.level = "debug"; } ''; - default = {}; + default = { }; type = lib.types.attrs; }; configFile = lib.mkOption { - default = pkgs.writeText "docker-registry-config.yml" (builtins.toJSON (lib.recursiveUpdate registryConfig cfg.extraConfig)); + default = pkgs.writeText "docker-registry-config.yml" ( + builtins.toJSON (lib.recursiveUpdate registryConfig cfg.extraConfig) + ); defaultText = lib.literalExpression ''pkgs.writeText "docker-registry-config.yml" "# my custom docker-registry-config.yml ..."''; description = '' - Path to CNCF distribution config file. + Path to CNCF distribution config file. - Setting this option will override any configuration applied by the extraConfig option. + Setting this option will override any configuration applied by the extraConfig option. ''; - type = lib.types.path; + type = lib.types.path; }; enableGarbageCollect = lib.mkEnableOption "garbage collect"; @@ -167,11 +173,12 @@ in { (lib.optionalAttrs (cfg.storagePath != null) { createHome = true; home = cfg.storagePath; - }) // { + }) + // { group = "docker-registry"; isSystemUser = true; }; - users.groups.docker-registry = {}; + users.groups.docker-registry = { }; networking.firewall = lib.mkIf cfg.openFirewall { allowedTCPPorts = [ cfg.port ]; diff --git a/nixos/modules/services/misc/duckling.nix b/nixos/modules/services/misc/duckling.nix index ed0b7b37d8c852..70e9066eb33820 100644 --- a/nixos/modules/services/misc/duckling.nix +++ b/nixos/modules/services/misc/duckling.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.duckling; -in { +in +{ options = { services.duckling = { enable = lib.mkEnableOption "duckling"; @@ -19,8 +25,8 @@ in { config = lib.mkIf cfg.enable { systemd.services.duckling = { description = "Duckling server service"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; environment = { PORT = builtins.toString cfg.port; diff --git a/nixos/modules/services/misc/dysnomia.nix b/nixos/modules/services/misc/dysnomia.nix index 36b6293843c401..8d96f4264ede0b 100644 --- a/nixos/modules/services/misc/dysnomia.nix +++ b/nixos/modules/services/misc/dysnomia.nix @@ -1,14 +1,25 @@ -{pkgs, lib, config, ...}: +{ + pkgs, + lib, + config, + ... +}: let cfg = config.services.dysnomia; - printProperties = properties: - lib.concatMapStrings (propertyName: + printProperties = + properties: + lib.concatMapStrings ( + propertyName: let property = properties.${propertyName}; in - if lib.isList property then "${propertyName}=(${lib.concatMapStrings (elem: "\"${toString elem}\" ") (properties.${propertyName})})\n" - else "${propertyName}=\"${toString property}\"\n" + if lib.isList property then + "${propertyName}=(${ + lib.concatMapStrings (elem: "\"${toString elem}\" ") (properties.${propertyName}) + })\n" + else + "${propertyName}=\"${toString property}\"\n" ) (builtins.attrNames properties); properties = pkgs.stdenv.mkDerivation { @@ -26,7 +37,8 @@ let mkdir -p $out cd $out - ${lib.concatMapStrings (containerName: + ${lib.concatMapStrings ( + containerName: let containerProperties = cfg.containers.${containerName}; in @@ -40,16 +52,18 @@ let ''; }; - linkMutableComponents = {containerName}: + linkMutableComponents = + { containerName }: '' mkdir ${containerName} - ${lib.concatMapStrings (componentName: + ${lib.concatMapStrings ( + componentName: let component = cfg.components.${containerName}.${componentName}; in "ln -s ${component} ${containerName}/${componentName}\n" - ) (builtins.attrNames (cfg.components.${containerName} or {}))} + ) (builtins.attrNames (cfg.components.${containerName} or { }))} ''; componentsDir = pkgs.stdenv.mkDerivation { @@ -58,9 +72,9 @@ let mkdir -p $out cd $out - ${lib.concatMapStrings (containerName: - linkMutableComponents { inherit containerName; } - ) (builtins.attrNames cfg.components)} + ${lib.concatMapStrings (containerName: linkMutableComponents { inherit containerName; }) ( + builtins.attrNames cfg.components + )} ''; }; @@ -100,37 +114,37 @@ in properties = lib.mkOption { description = "An attribute set in which each attribute represents a machine property. Optionally, these values can be shell substitutions."; - default = {}; + default = { }; type = lib.types.attrs; }; containers = lib.mkOption { description = "An attribute set in which each key represents a container and each value an attribute set providing its configuration properties"; - default = {}; + default = { }; type = lib.types.attrsOf lib.types.attrs; }; components = lib.mkOption { description = "An attribute set in which each key represents a container and each value an attribute set in which each key represents a component and each value a derivation constructing its initial state"; - default = {}; + default = { }; type = lib.types.attrsOf lib.types.attrs; }; extraContainerProperties = lib.mkOption { description = "An attribute set providing additional container settings in addition to the default properties"; - default = {}; + default = { }; type = lib.types.attrs; }; extraContainerPaths = lib.mkOption { description = "A list of paths containing additional container configurations that are added to the search folders"; - default = []; + default = [ ]; type = lib.types.listOf lib.types.path; }; extraModulePaths = lib.mkOption { description = "A list of paths containing additional modules that are added to the search folders"; - default = []; + default = [ ]; type = lib.types.listOf lib.types.path; }; @@ -143,7 +157,7 @@ in }; imports = [ - (lib.mkRenamedOptionModule ["dysnomia"] ["services" "dysnomia"]) + (lib.mkRenamedOptionModule [ "dysnomia" ] [ "services" "dysnomia" ]) ]; config = lib.mkIf cfg.enable { @@ -162,93 +176,118 @@ in environment.variables = { DYSNOMIA_STATEDIR = "/var/state/dysnomia-nixos"; - DYSNOMIA_CONTAINERS_PATH = "${lib.concatMapStrings (containerPath: "${containerPath}:") cfg.extraContainerPaths}/etc/dysnomia/containers"; - DYSNOMIA_MODULES_PATH = "${lib.concatMapStrings (modulePath: "${modulePath}:") cfg.extraModulePaths}/etc/dysnomia/modules"; + DYSNOMIA_CONTAINERS_PATH = "${ + lib.concatMapStrings (containerPath: "${containerPath}:") cfg.extraContainerPaths + }/etc/dysnomia/containers"; + DYSNOMIA_MODULES_PATH = "${ + lib.concatMapStrings (modulePath: "${modulePath}:") cfg.extraModulePaths + }/etc/dysnomia/modules"; }; environment.systemPackages = [ cfg.package ]; - services.dysnomia.package = pkgs.dysnomia.override (origArgs: dysnomiaFlags // lib.optionalAttrs (cfg.enableLegacyModules) { - enableLegacy = builtins.trace '' - WARNING: Dysnomia has been configured to use the legacy 'process' and 'wrapper' - modules for compatibility reasons! If you rely on these modules, consider - migrating to better alternatives. + services.dysnomia.package = pkgs.dysnomia.override ( + origArgs: + dysnomiaFlags + // lib.optionalAttrs (cfg.enableLegacyModules) { + enableLegacy = builtins.trace '' + WARNING: Dysnomia has been configured to use the legacy 'process' and 'wrapper' + modules for compatibility reasons! If you rely on these modules, consider + migrating to better alternatives. - More information: https://raw.githubusercontent.com/svanderburg/dysnomia/f65a9a84827bcc4024d6b16527098b33b02e4054/README-legacy.md + More information: https://raw.githubusercontent.com/svanderburg/dysnomia/f65a9a84827bcc4024d6b16527098b33b02e4054/README-legacy.md - If you have migrated already or don't rely on these Dysnomia modules, you can - disable legacy mode with the following NixOS configuration option: + If you have migrated already or don't rely on these Dysnomia modules, you can + disable legacy mode with the following NixOS configuration option: - dysnomia.enableLegacyModules = false; + dysnomia.enableLegacyModules = false; - In a future version of Dysnomia (and NixOS) the legacy option will go away! - '' true; - }); + In a future version of Dysnomia (and NixOS) the legacy option will go away! + '' true; + } + ); services.dysnomia.properties = { hostname = config.networking.hostName; inherit (pkgs.stdenv.hostPlatform) system; - supportedTypes = [ - "echo" - "fileset" - "process" - "wrapper" - - # These are not base modules, but they are still enabled because they work with technology that are always enabled in NixOS - "systemd-unit" - "sysvinit-script" - "nixos-configuration" - ] - ++ lib.optional (dysnomiaFlags.enableApacheWebApplication) "apache-webapplication" - ++ lib.optional (dysnomiaFlags.enableAxis2WebService) "axis2-webservice" - ++ lib.optional (dysnomiaFlags.enableDockerContainer) "docker-container" - ++ lib.optional (dysnomiaFlags.enableEjabberdDump) "ejabberd-dump" - ++ lib.optional (dysnomiaFlags.enableInfluxDatabase) "influx-database" - ++ lib.optional (dysnomiaFlags.enableMySQLDatabase) "mysql-database" - ++ lib.optional (dysnomiaFlags.enablePostgreSQLDatabase) "postgresql-database" - ++ lib.optional (dysnomiaFlags.enableTomcatWebApplication) "tomcat-webapplication" - ++ lib.optional (dysnomiaFlags.enableMongoDatabase) "mongo-database" - ++ lib.optional (dysnomiaFlags.enableSubversionRepository) "subversion-repository"; + supportedTypes = + [ + "echo" + "fileset" + "process" + "wrapper" + + # These are not base modules, but they are still enabled because they work with technology that are always enabled in NixOS + "systemd-unit" + "sysvinit-script" + "nixos-configuration" + ] + ++ lib.optional (dysnomiaFlags.enableApacheWebApplication) "apache-webapplication" + ++ lib.optional (dysnomiaFlags.enableAxis2WebService) "axis2-webservice" + ++ lib.optional (dysnomiaFlags.enableDockerContainer) "docker-container" + ++ lib.optional (dysnomiaFlags.enableEjabberdDump) "ejabberd-dump" + ++ lib.optional (dysnomiaFlags.enableInfluxDatabase) "influx-database" + ++ lib.optional (dysnomiaFlags.enableMySQLDatabase) "mysql-database" + ++ lib.optional (dysnomiaFlags.enablePostgreSQLDatabase) "postgresql-database" + ++ lib.optional (dysnomiaFlags.enableTomcatWebApplication) "tomcat-webapplication" + ++ lib.optional (dysnomiaFlags.enableMongoDatabase) "mongo-database" + ++ lib.optional (dysnomiaFlags.enableSubversionRepository) "subversion-repository"; }; - services.dysnomia.containers = lib.recursiveUpdate ({ - process = {}; - wrapper = {}; - } - // lib.optionalAttrs (config.services.httpd.enable) { apache-webapplication = { - documentRoot = config.services.httpd.virtualHosts.localhost.documentRoot; - }; } - // lib.optionalAttrs (config.services.tomcat.axis2.enable) { axis2-webservice = {}; } - // lib.optionalAttrs (config.services.ejabberd.enable) { ejabberd-dump = { - ejabberdUser = config.services.ejabberd.user; - }; } - // lib.optionalAttrs (config.services.mysql.enable) { mysql-database = { - mysqlPort = config.services.mysql.settings.mysqld.port; - mysqlSocket = "/run/mysqld/mysqld.sock"; - } // lib.optionalAttrs cfg.enableAuthentication { - mysqlUsername = "root"; - }; - } - // lib.optionalAttrs (config.services.postgresql.enable) { postgresql-database = { - } // lib.optionalAttrs (cfg.enableAuthentication) { - postgresqlUsername = "postgres"; - }; - } - // lib.optionalAttrs (config.services.tomcat.enable) { tomcat-webapplication = { - tomcatPort = 8080; - }; } - // lib.optionalAttrs (config.services.mongodb.enable) { mongo-database = {}; } - // lib.optionalAttrs (config.services.influxdb.enable) { - influx-database = { - influxdbUsername = config.services.influxdb.user; - influxdbDataDir = "${config.services.influxdb.dataDir}/data"; - influxdbMetaDir = "${config.services.influxdb.dataDir}/meta"; - }; - } - // lib.optionalAttrs (config.services.svnserve.enable) { subversion-repository = { - svnBaseDir = config.services.svnserve.svnBaseDir; - }; }) cfg.extraContainerProperties; + services.dysnomia.containers = lib.recursiveUpdate ( + { + process = { }; + wrapper = { }; + } + // lib.optionalAttrs (config.services.httpd.enable) { + apache-webapplication = { + documentRoot = config.services.httpd.virtualHosts.localhost.documentRoot; + }; + } + // lib.optionalAttrs (config.services.tomcat.axis2.enable) { axis2-webservice = { }; } + // lib.optionalAttrs (config.services.ejabberd.enable) { + ejabberd-dump = { + ejabberdUser = config.services.ejabberd.user; + }; + } + // lib.optionalAttrs (config.services.mysql.enable) { + mysql-database = + { + mysqlPort = config.services.mysql.settings.mysqld.port; + mysqlSocket = "/run/mysqld/mysqld.sock"; + } + // lib.optionalAttrs cfg.enableAuthentication { + mysqlUsername = "root"; + }; + } + // lib.optionalAttrs (config.services.postgresql.enable) { + postgresql-database = + { + } + // lib.optionalAttrs (cfg.enableAuthentication) { + postgresqlUsername = "postgres"; + }; + } + // lib.optionalAttrs (config.services.tomcat.enable) { + tomcat-webapplication = { + tomcatPort = 8080; + }; + } + // lib.optionalAttrs (config.services.mongodb.enable) { mongo-database = { }; } + // lib.optionalAttrs (config.services.influxdb.enable) { + influx-database = { + influxdbUsername = config.services.influxdb.user; + influxdbDataDir = "${config.services.influxdb.dataDir}/data"; + influxdbMetaDir = "${config.services.influxdb.dataDir}/meta"; + }; + } + // lib.optionalAttrs (config.services.svnserve.enable) { + subversion-repository = { + svnBaseDir = config.services.svnserve.svnBaseDir; + }; + } + ) cfg.extraContainerProperties; boot.extraSystemdUnitPaths = [ "/etc/systemd-mutable/system" ]; diff --git a/nixos/modules/services/misc/errbot.nix b/nixos/modules/services/misc/errbot.nix index 1c7135e774e834..d9f52af7fe723d 100644 --- a/nixos/modules/services/misc/errbot.nix +++ b/nixos/modules/services/misc/errbot.nix @@ -1,101 +1,117 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.errbot; - pluginEnv = plugins: pkgs.buildEnv { - name = "errbot-plugins"; - paths = plugins; - }; - mkConfigDir = instanceCfg: dataDir: pkgs.writeTextDir "config.py" '' - import logging - BACKEND = '${instanceCfg.backend}' - BOT_DATA_DIR = '${dataDir}' - BOT_EXTRA_PLUGIN_DIR = '${pluginEnv instanceCfg.plugins}' + pluginEnv = + plugins: + pkgs.buildEnv { + name = "errbot-plugins"; + paths = plugins; + }; + mkConfigDir = + instanceCfg: dataDir: + pkgs.writeTextDir "config.py" '' + import logging + BACKEND = '${instanceCfg.backend}' + BOT_DATA_DIR = '${dataDir}' + BOT_EXTRA_PLUGIN_DIR = '${pluginEnv instanceCfg.plugins}' - BOT_LOG_LEVEL = logging.${instanceCfg.logLevel} - BOT_LOG_FILE = False + BOT_LOG_LEVEL = logging.${instanceCfg.logLevel} + BOT_LOG_FILE = False - BOT_ADMINS = (${lib.concatMapStringsSep "," (name: "'${name}'") instanceCfg.admins}) + BOT_ADMINS = (${lib.concatMapStringsSep "," (name: "'${name}'") instanceCfg.admins}) - BOT_IDENTITY = ${builtins.toJSON instanceCfg.identity} + BOT_IDENTITY = ${builtins.toJSON instanceCfg.identity} - ${instanceCfg.extraConfig} - ''; -in { + ${instanceCfg.extraConfig} + ''; +in +{ options = { services.errbot.instances = lib.mkOption { - default = {}; + default = { }; description = "Errbot instance configs"; - type = lib.types.attrsOf (lib.types.submodule { - options = { - dataDir = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; - description = "Data directory for errbot instance."; - }; + type = lib.types.attrsOf ( + lib.types.submodule { + options = { + dataDir = lib.mkOption { + type = lib.types.nullOr lib.types.path; + default = null; + description = "Data directory for errbot instance."; + }; - plugins = lib.mkOption { - type = lib.types.listOf lib.types.package; - default = []; - description = "List of errbot plugin derivations."; - }; + plugins = lib.mkOption { + type = lib.types.listOf lib.types.package; + default = [ ]; + description = "List of errbot plugin derivations."; + }; - logLevel = lib.mkOption { - type = lib.types.str; - default = "INFO"; - description = "Errbot log level"; - }; + logLevel = lib.mkOption { + type = lib.types.str; + default = "INFO"; + description = "Errbot log level"; + }; - admins = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - description = "List of identifiers of errbot admins."; - }; + admins = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + description = "List of identifiers of errbot admins."; + }; - backend = lib.mkOption { - type = lib.types.str; - default = "XMPP"; - description = "Errbot backend name."; - }; + backend = lib.mkOption { + type = lib.types.str; + default = "XMPP"; + description = "Errbot backend name."; + }; - identity = lib.mkOption { - type = lib.types.attrs; - description = "Errbot identity configuration"; - }; + identity = lib.mkOption { + type = lib.types.attrs; + description = "Errbot identity configuration"; + }; - extraConfig = lib.mkOption { - type = lib.types.lines; - default = ""; - description = "String to be appended to the config verbatim"; + extraConfig = lib.mkOption { + type = lib.types.lines; + default = ""; + description = "String to be appended to the config verbatim"; + }; }; - }; - }); + } + ); }; }; - config = lib.mkIf (cfg.instances != {}) { + config = lib.mkIf (cfg.instances != { }) { users.users.errbot = { group = "errbot"; isSystemUser = true; }; - users.groups.errbot = {}; + users.groups.errbot = { }; - systemd.services = lib.mapAttrs' (name: instanceCfg: lib.nameValuePair "errbot-${name}" ( - let - dataDir = if instanceCfg.dataDir != null then instanceCfg.dataDir else - "/var/lib/errbot/${name}"; - in { - after = [ "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; - preStart = '' - mkdir -p ${dataDir} - chown -R errbot:errbot ${dataDir} - ''; - serviceConfig = { - User = "errbot"; - Restart = "on-failure"; - ExecStart = "${pkgs.errbot}/bin/errbot -c ${mkConfigDir instanceCfg dataDir}/config.py"; - PermissionsStartOnly = true; - }; - })) cfg.instances; + systemd.services = lib.mapAttrs' ( + name: instanceCfg: + lib.nameValuePair "errbot-${name}" ( + let + dataDir = if instanceCfg.dataDir != null then instanceCfg.dataDir else "/var/lib/errbot/${name}"; + in + { + after = [ "network-online.target" ]; + wantedBy = [ "multi-user.target" ]; + preStart = '' + mkdir -p ${dataDir} + chown -R errbot:errbot ${dataDir} + ''; + serviceConfig = { + User = "errbot"; + Restart = "on-failure"; + ExecStart = "${pkgs.errbot}/bin/errbot -c ${mkConfigDir instanceCfg dataDir}/config.py"; + PermissionsStartOnly = true; + }; + } + ) + ) cfg.instances; }; } diff --git a/nixos/modules/services/misc/etebase-server.nix b/nixos/modules/services/misc/etebase-server.nix index ba45a1703ac275..cd1cf884523194 100644 --- a/nixos/modules/services/misc/etebase-server.nix +++ b/nixos/modules/services/misc/etebase-server.nix @@ -1,8 +1,13 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.etebase-server; - iniFmt = pkgs.formats.ini {}; + iniFmt = pkgs.formats.ini { }; configIni = iniFmt.generate "etebase-server.ini" cfg.settings; @@ -10,18 +15,24 @@ let in { imports = [ - (lib.mkRemovedOptionModule - [ "services" "etebase-server" "customIni" ] - "Set the option `services.etebase-server.settings' instead.") - (lib.mkRemovedOptionModule - [ "services" "etebase-server" "database" ] - "Set the option `services.etebase-server.settings.database' instead.") + (lib.mkRemovedOptionModule [ + "services" + "etebase-server" + "customIni" + ] "Set the option `services.etebase-server.settings' instead.") + (lib.mkRemovedOptionModule [ + "services" + "etebase-server" + "database" + ] "Set the option `services.etebase-server.settings.database' instead.") (lib.mkRenamedOptionModule [ "services" "etebase-server" "secretFile" ] - [ "services" "etebase-server" "settings" "secret_file" ]) + [ "services" "etebase-server" "settings" "secret_file" ] + ) (lib.mkRenamedOptionModule [ "services" "etebase-server" "host" ] - [ "services" "etebase-server" "settings" "allowed_hosts" "allowed_host1" ]) + [ "services" "etebase-server" "settings" "allowed_hosts" "allowed_host1" ] + ) ]; options = { @@ -120,7 +131,10 @@ in }; database = { engine = lib.mkOption { - type = lib.types.enum [ "django.db.backends.sqlite3" "django.db.backends.postgresql" ]; + type = lib.types.enum [ + "django.db.backends.sqlite3" + "django.db.backends.postgresql" + ]; default = "django.db.backends.sqlite3"; description = "The database engine to use."; }; @@ -133,7 +147,7 @@ in }; }; }; - default = {}; + default = { }; description = '' Configuration for `etebase-server`. Refer to @@ -162,25 +176,33 @@ in config = lib.mkIf cfg.enable { environment.systemPackages = with pkgs; [ - (runCommand "etebase-server" { - nativeBuildInputs = [ makeWrapper ]; - } '' - makeWrapper ${cfg.package}/bin/etebase-server \ - $out/bin/etebase-server \ - --chdir ${lib.escapeShellArg cfg.dataDir} \ - --prefix ETEBASE_EASY_CONFIG_PATH : "${configIni}" - '') + (runCommand "etebase-server" + { + nativeBuildInputs = [ makeWrapper ]; + } + '' + makeWrapper ${cfg.package}/bin/etebase-server \ + $out/bin/etebase-server \ + --chdir ${lib.escapeShellArg cfg.dataDir} \ + --prefix ETEBASE_EASY_CONFIG_PATH : "${configIni}" + '' + ) ]; - systemd.tmpfiles.rules = [ - "d '${cfg.dataDir}' - ${cfg.user} ${config.users.users.${cfg.user}.group} - -" - ] ++ lib.optionals (cfg.unixSocket != null) [ - "d '${builtins.dirOf cfg.unixSocket}' - ${cfg.user} ${config.users.users.${cfg.user}.group} - -" - ]; + systemd.tmpfiles.rules = + [ + "d '${cfg.dataDir}' - ${cfg.user} ${config.users.users.${cfg.user}.group} - -" + ] + ++ lib.optionals (cfg.unixSocket != null) [ + "d '${builtins.dirOf cfg.unixSocket}' - ${cfg.user} ${config.users.users.${cfg.user}.group} - -" + ]; systemd.services.etebase-server = { description = "An Etebase (EteSync 2.0) server"; - after = [ "network.target" "systemd-tmpfiles-setup.service" ]; + after = [ + "network.target" + "systemd-tmpfiles-setup.service" + ]; path = [ cfg.package ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { @@ -204,10 +226,13 @@ in script = let python = cfg.package.python; - networking = if cfg.unixSocket != null - then "--uds ${cfg.unixSocket}" - else "--host 0.0.0.0 --port ${toString cfg.port}"; - in '' + networking = + if cfg.unixSocket != null then + "--uds ${cfg.unixSocket}" + else + "--host 0.0.0.0 --port ${toString cfg.port}"; + in + '' ${python.pkgs.uvicorn}/bin/uvicorn ${networking} \ --app-dir ${cfg.package}/${cfg.package.python.sitePackages} \ etebase_server.asgi:application @@ -221,7 +246,7 @@ in home = cfg.dataDir; }; - groups.${defaultUser} = {}; + groups.${defaultUser} = { }; }; networking.firewall = lib.mkIf cfg.openFirewall { diff --git a/nixos/modules/services/misc/etesync-dav.nix b/nixos/modules/services/misc/etesync-dav.nix index d9a8a137e82e6a..489bd5557a877e 100644 --- a/nixos/modules/services/misc/etesync-dav.nix +++ b/nixos/modules/services/misc/etesync-dav.nix @@ -1,90 +1,95 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.etesync-dav; in - { - options.services.etesync-dav = { - enable = lib.mkEnableOption "etesync-dav, end-to-end encrypted sync for contacts, calendars and tasks"; +{ + options.services.etesync-dav = { + enable = lib.mkEnableOption "etesync-dav, end-to-end encrypted sync for contacts, calendars and tasks"; - host = lib.mkOption { - type = lib.types.str; - default = "localhost"; - description = "The server host address."; - }; + host = lib.mkOption { + type = lib.types.str; + default = "localhost"; + description = "The server host address."; + }; - port = lib.mkOption { - type = lib.types.port; - default = 37358; - description = "The server host port."; - }; + port = lib.mkOption { + type = lib.types.port; + default = 37358; + description = "The server host port."; + }; - apiUrl = lib.mkOption { - type = lib.types.str; - default = "https://api.etebase.com/partner/etesync/"; - description = "The url to the etesync API."; - }; + apiUrl = lib.mkOption { + type = lib.types.str; + default = "https://api.etebase.com/partner/etesync/"; + description = "The url to the etesync API."; + }; - openFirewall = lib.mkOption { - default = false; - type = lib.types.bool; - description = "Whether to open the firewall for the specified port."; - }; + openFirewall = lib.mkOption { + default = false; + type = lib.types.bool; + description = "Whether to open the firewall for the specified port."; + }; - sslCertificate = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; - example = "/var/etesync.crt"; - description = '' - Path to server SSL certificate. It will be copied into - etesync-dav's data directory. - ''; - }; + sslCertificate = lib.mkOption { + type = lib.types.nullOr lib.types.path; + default = null; + example = "/var/etesync.crt"; + description = '' + Path to server SSL certificate. It will be copied into + etesync-dav's data directory. + ''; + }; - sslCertificateKey = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; - example = "/var/etesync.key"; - description = '' - Path to server SSL certificate key. It will be copied into - etesync-dav's data directory. - ''; - }; + sslCertificateKey = lib.mkOption { + type = lib.types.nullOr lib.types.path; + default = null; + example = "/var/etesync.key"; + description = '' + Path to server SSL certificate key. It will be copied into + etesync-dav's data directory. + ''; }; + }; - config = lib.mkIf cfg.enable { - networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall [ cfg.port ]; + config = lib.mkIf cfg.enable { + networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall [ cfg.port ]; - systemd.services.etesync-dav = { - description = "etesync-dav - A CalDAV and CardDAV adapter for EteSync"; - wants = [ "network-online.target" ]; - after = [ "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; - path = [ pkgs.etesync-dav ]; - environment = { - ETESYNC_LISTEN_ADDRESS = cfg.host; - ETESYNC_LISTEN_PORT = toString cfg.port; - ETESYNC_URL = cfg.apiUrl; - ETESYNC_DATA_DIR = "/var/lib/etesync-dav"; - }; + systemd.services.etesync-dav = { + description = "etesync-dav - A CalDAV and CardDAV adapter for EteSync"; + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; + wantedBy = [ "multi-user.target" ]; + path = [ pkgs.etesync-dav ]; + environment = { + ETESYNC_LISTEN_ADDRESS = cfg.host; + ETESYNC_LISTEN_PORT = toString cfg.port; + ETESYNC_URL = cfg.apiUrl; + ETESYNC_DATA_DIR = "/var/lib/etesync-dav"; + }; - serviceConfig = { - Type = "simple"; - DynamicUser = true; - StateDirectory = "etesync-dav"; - ExecStart = "${pkgs.etesync-dav}/bin/etesync-dav"; - ExecStartPre = lib.mkIf (cfg.sslCertificate != null || cfg.sslCertificateKey != null) ( - pkgs.writers.writeBash "etesync-dav-copy-keys" '' - ${lib.optionalString (cfg.sslCertificate != null) '' - cp ${toString cfg.sslCertificate} $STATE_DIRECTORY/etesync.crt - ''} - ${lib.optionalString (cfg.sslCertificateKey != null) '' - cp ${toString cfg.sslCertificateKey} $STATE_DIRECTORY/etesync.key - ''} - '' - ); - Restart = "on-failure"; - RestartSec = "30min 1s"; - }; + serviceConfig = { + Type = "simple"; + DynamicUser = true; + StateDirectory = "etesync-dav"; + ExecStart = "${pkgs.etesync-dav}/bin/etesync-dav"; + ExecStartPre = lib.mkIf (cfg.sslCertificate != null || cfg.sslCertificateKey != null) ( + pkgs.writers.writeBash "etesync-dav-copy-keys" '' + ${lib.optionalString (cfg.sslCertificate != null) '' + cp ${toString cfg.sslCertificate} $STATE_DIRECTORY/etesync.crt + ''} + ${lib.optionalString (cfg.sslCertificateKey != null) '' + cp ${toString cfg.sslCertificateKey} $STATE_DIRECTORY/etesync.key + ''} + '' + ); + Restart = "on-failure"; + RestartSec = "30min 1s"; }; }; - } + }; +} diff --git a/nixos/modules/services/misc/evdevremapkeys.nix b/nixos/modules/services/misc/evdevremapkeys.nix index 754bce9f03d28c..122afda2f86c97 100644 --- a/nixos/modules/services/misc/evdevremapkeys.nix +++ b/nixos/modules/services/misc/evdevremapkeys.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let format = pkgs.formats.yaml { }; cfg = config.services.evdevremapkeys; diff --git a/nixos/modules/services/misc/felix.nix b/nixos/modules/services/misc/felix.nix index 3def12e3adef97..c0bfb54bfa7523 100644 --- a/nixos/modules/services/misc/felix.nix +++ b/nixos/modules/services/misc/felix.nix @@ -1,5 +1,10 @@ # Felix server -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.felix; @@ -39,17 +44,16 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { users.groups.osgi.gid = config.ids.gids.osgi; - users.users.osgi = - { uid = config.ids.uids.osgi; - description = "OSGi user"; - home = "/homeless-shelter"; - }; + users.users.osgi = { + uid = config.ids.uids.osgi; + description = "OSGi user"; + home = "/homeless-shelter"; + }; systemd.services.felix = { description = "Felix server"; diff --git a/nixos/modules/services/misc/forgejo.nix b/nixos/modules/services/misc/forgejo.nix index 9aa7b13b02e191..299b574b4400b3 100644 --- a/nixos/modules/services/misc/forgejo.nix +++ b/nixos/modules/services/misc/forgejo.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.forgejo; @@ -12,14 +18,19 @@ let usePostgresql = cfg.database.type == "postgres"; useSqlite = cfg.database.type == "sqlite3"; - secrets = let - mkSecret = section: values: lib.mapAttrsToList (key: value: { - env = envEscape "FORGEJO__${section}__${key}__FILE"; - path = value; - }) values; - # https://codeberg.org/forgejo/forgejo/src/tag/v7.0.2/contrib/environment-to-ini/environment-to-ini.go - envEscape = string: lib.replaceStrings [ "." "-" ] [ "_0X2E_" "_0X2D_" ] (lib.strings.toUpper string); - in lib.flatten (lib.mapAttrsToList mkSecret cfg.secrets); + secrets = + let + mkSecret = + section: values: + lib.mapAttrsToList (key: value: { + env = envEscape "FORGEJO__${section}__${key}__FILE"; + path = value; + }) values; + # https://codeberg.org/forgejo/forgejo/src/tag/v7.0.2/contrib/environment-to-ini/environment-to-ini.go + envEscape = + string: lib.replaceStrings [ "." "-" ] [ "_0X2E_" "_0X2D_" ] (lib.strings.toUpper string); + in + lib.flatten (lib.mapAttrsToList mkSecret cfg.secrets); inherit (lib) literalExpression @@ -40,26 +51,70 @@ let in { imports = [ - (mkRenamedOptionModule [ "services" "forgejo" "appName" ] [ "services" "forgejo" "settings" "DEFAULT" "APP_NAME" ]) - (mkRemovedOptionModule [ "services" "forgejo" "extraConfig" ] "services.forgejo.extraConfig has been removed. Please use the freeform services.forgejo.settings option instead") - (mkRemovedOptionModule [ "services" "forgejo" "database" "password" ] "services.forgejo.database.password has been removed. Please use services.forgejo.database.passwordFile instead") - (mkRenamedOptionModule [ "services" "forgejo" "mailerPasswordFile" ] [ "services" "forgejo" "secrets" "mailer" "PASSWD" ]) + (mkRenamedOptionModule + [ "services" "forgejo" "appName" ] + [ "services" "forgejo" "settings" "DEFAULT" "APP_NAME" ] + ) + (mkRemovedOptionModule [ "services" "forgejo" "extraConfig" ] + "services.forgejo.extraConfig has been removed. Please use the freeform services.forgejo.settings option instead" + ) + (mkRemovedOptionModule [ "services" "forgejo" "database" "password" ] + "services.forgejo.database.password has been removed. Please use services.forgejo.database.passwordFile instead" + ) + (mkRenamedOptionModule + [ "services" "forgejo" "mailerPasswordFile" ] + [ "services" "forgejo" "secrets" "mailer" "PASSWD" ] + ) # copied from services.gitea; remove at some point - (mkRenamedOptionModule [ "services" "forgejo" "cookieSecure" ] [ "services" "forgejo" "settings" "session" "COOKIE_SECURE" ]) - (mkRenamedOptionModule [ "services" "forgejo" "disableRegistration" ] [ "services" "forgejo" "settings" "service" "DISABLE_REGISTRATION" ]) - (mkRenamedOptionModule [ "services" "forgejo" "domain" ] [ "services" "forgejo" "settings" "server" "DOMAIN" ]) - (mkRenamedOptionModule [ "services" "forgejo" "httpAddress" ] [ "services" "forgejo" "settings" "server" "HTTP_ADDR" ]) - (mkRenamedOptionModule [ "services" "forgejo" "httpPort" ] [ "services" "forgejo" "settings" "server" "HTTP_PORT" ]) - (mkRenamedOptionModule [ "services" "forgejo" "log" "level" ] [ "services" "forgejo" "settings" "log" "LEVEL" ]) - (mkRenamedOptionModule [ "services" "forgejo" "log" "rootPath" ] [ "services" "forgejo" "settings" "log" "ROOT_PATH" ]) - (mkRenamedOptionModule [ "services" "forgejo" "rootUrl" ] [ "services" "forgejo" "settings" "server" "ROOT_URL" ]) - (mkRenamedOptionModule [ "services" "forgejo" "ssh" "clonePort" ] [ "services" "forgejo" "settings" "server" "SSH_PORT" ]) - (mkRenamedOptionModule [ "services" "forgejo" "staticRootPath" ] [ "services" "forgejo" "settings" "server" "STATIC_ROOT_PATH" ]) - (mkChangedOptionModule [ "services" "forgejo" "enableUnixSocket" ] [ "services" "forgejo" "settings" "server" "PROTOCOL" ] ( - config: if config.services.forgejo.enableUnixSocket then "http+unix" else "http" - )) - (mkRemovedOptionModule [ "services" "forgejo" "ssh" "enable" ] "services.forgejo.ssh.enable has been migrated into freeform setting services.forgejo.settings.server.DISABLE_SSH. Keep in mind that the setting is inverted") + (mkRenamedOptionModule + [ "services" "forgejo" "cookieSecure" ] + [ "services" "forgejo" "settings" "session" "COOKIE_SECURE" ] + ) + (mkRenamedOptionModule + [ "services" "forgejo" "disableRegistration" ] + [ "services" "forgejo" "settings" "service" "DISABLE_REGISTRATION" ] + ) + (mkRenamedOptionModule + [ "services" "forgejo" "domain" ] + [ "services" "forgejo" "settings" "server" "DOMAIN" ] + ) + (mkRenamedOptionModule + [ "services" "forgejo" "httpAddress" ] + [ "services" "forgejo" "settings" "server" "HTTP_ADDR" ] + ) + (mkRenamedOptionModule + [ "services" "forgejo" "httpPort" ] + [ "services" "forgejo" "settings" "server" "HTTP_PORT" ] + ) + (mkRenamedOptionModule + [ "services" "forgejo" "log" "level" ] + [ "services" "forgejo" "settings" "log" "LEVEL" ] + ) + (mkRenamedOptionModule + [ "services" "forgejo" "log" "rootPath" ] + [ "services" "forgejo" "settings" "log" "ROOT_PATH" ] + ) + (mkRenamedOptionModule + [ "services" "forgejo" "rootUrl" ] + [ "services" "forgejo" "settings" "server" "ROOT_URL" ] + ) + (mkRenamedOptionModule + [ "services" "forgejo" "ssh" "clonePort" ] + [ "services" "forgejo" "settings" "server" "SSH_PORT" ] + ) + (mkRenamedOptionModule + [ "services" "forgejo" "staticRootPath" ] + [ "services" "forgejo" "settings" "server" "STATIC_ROOT_PATH" ] + ) + (mkChangedOptionModule + [ "services" "forgejo" "enableUnixSocket" ] + [ "services" "forgejo" "settings" "server" "PROTOCOL" ] + (config: if config.services.forgejo.enableUnixSocket then "http+unix" else "http") + ) + (mkRemovedOptionModule [ "services" "forgejo" "ssh" "enable" ] + "services.forgejo.ssh.enable has been migrated into freeform setting services.forgejo.settings.server.DISABLE_SSH. Keep in mind that the setting is inverted" + ) ]; options = { @@ -109,7 +164,11 @@ in database = { type = mkOption { - type = types.enum [ "sqlite3" "mysql" "postgres" ]; + type = types.enum [ + "sqlite3" + "mysql" + "postgres" + ]; example = "mysql"; default = "sqlite3"; description = "Database engine to use."; @@ -156,7 +215,13 @@ in socket = mkOption { type = types.nullOr types.path; - default = if (cfg.database.createDatabase && usePostgresql) then "/run/postgresql" else if (cfg.database.createDatabase && useMysql) then "/run/mysqld/mysqld.sock" else null; + default = + if (cfg.database.createDatabase && usePostgresql) then + "/run/postgresql" + else if (cfg.database.createDatabase && useMysql) then + "/run/mysqld/mysqld.sock" + else + null; defaultText = literalExpression "null"; example = "/run/mysqld/mysqld.sock"; description = "Path to the unix socket file to use for authentication."; @@ -199,7 +264,17 @@ in }; type = mkOption { - type = types.enum [ "zip" "tar" "tar.sz" "tar.gz" "tar.xz" "tar.bz2" "tar.br" "tar.lz4" "tar.zst" ]; + type = types.enum [ + "zip" + "tar" + "tar.sz" + "tar.gz" + "tar.xz" + "tar.bz2" + "tar.br" + "tar.lz4" + "tar.zst" + ]; default = "zip"; description = "Archive format used to store the dump file."; }; @@ -273,21 +348,38 @@ in }; LEVEL = mkOption { default = "Info"; - type = types.enum [ "Trace" "Debug" "Info" "Warn" "Error" "Critical" ]; + type = types.enum [ + "Trace" + "Debug" + "Info" + "Warn" + "Error" + "Critical" + ]; description = "General log level."; }; }; server = { PROTOCOL = mkOption { - type = types.enum [ "http" "https" "fcgi" "http+unix" "fcgi+unix" ]; + type = types.enum [ + "http" + "https" + "fcgi" + "http+unix" + "fcgi+unix" + ]; default = "http"; description = ''Listen protocol. `+unix` means "over unix", not "in addition to."''; }; HTTP_ADDR = mkOption { type = types.either types.str types.path; - default = if lib.hasSuffix "+unix" cfg.settings.server.PROTOCOL then "/run/forgejo/forgejo.sock" else "0.0.0.0"; + default = + if lib.hasSuffix "+unix" cfg.settings.server.PROTOCOL then + "/run/forgejo/forgejo.sock" + else + "0.0.0.0"; defaultText = literalExpression ''if lib.hasSuffix "+unix" cfg.settings.server.PROTOCOL then "/run/forgejo/forgejo.sock" else "0.0.0.0"''; description = "Listen address. Must be a path when using a unix socket."; }; @@ -370,18 +462,18 @@ in ::: ''; example = literalExpression '' - { - metrics = { - TOKEN = "/run/keys/forgejo-metrics-token"; - }; - camo = { - HMAC_KEY = "/run/keys/forgejo-camo-hmac"; - }; - service = { - HCAPTCHA_SECRET = "/run/keys/forgejo-hcaptcha-secret"; - HCAPTCHA_SITEKEY = "/run/keys/forgejo-hcaptcha-sitekey"; - }; - } + { + metrics = { + TOKEN = "/run/keys/forgejo-metrics-token"; + }; + camo = { + HMAC_KEY = "/run/keys/forgejo-camo-hmac"; + }; + service = { + HCAPTCHA_SECRET = "/run/keys/forgejo-hcaptcha-secret"; + HCAPTCHA_SITEKEY = "/run/keys/forgejo-hcaptcha-sitekey"; + }; + } ''; type = types.submodule { freeformType = with types; attrsOf (attrsOf path); @@ -397,7 +489,8 @@ in assertion = cfg.database.createDatabase -> useSqlite || cfg.database.user == cfg.user; message = "services.forgejo.database.user must match services.forgejo.user if the database is to be automatically provisioned"; } - { assertion = cfg.database.createDatabase && usePostgresql -> cfg.database.user == cfg.database.name; + { + assertion = cfg.database.createDatabase && usePostgresql -> cfg.database.user == cfg.database.name; message = '' When creating a database via NixOS, the db user and db name must be equal! If you already have an existing DB+user and this assertion is new, you can safely set @@ -419,7 +512,11 @@ in DB_TYPE = cfg.database.type; } (mkIf (useMysql || usePostgresql) { - HOST = if cfg.database.socket != null then cfg.database.socket else cfg.database.host + ":" + toString cfg.database.port; + HOST = + if cfg.database.socket != null then + cfg.database.socket + else + cfg.database.host + ":" + toString cfg.database.port; NAME = cfg.database.name; USER = cfg.database.user; }) @@ -491,38 +588,42 @@ in ensureUsers = [ { name = cfg.database.user; - ensurePermissions = { "${cfg.database.name}.*" = "ALL PRIVILEGES"; }; + ensurePermissions = { + "${cfg.database.name}.*" = "ALL PRIVILEGES"; + }; } ]; }; - systemd.tmpfiles.rules = [ - "d '${cfg.dump.backupDir}' 0750 ${cfg.user} ${cfg.group} - -" - "z '${cfg.dump.backupDir}' 0750 ${cfg.user} ${cfg.group} - -" - "d '${cfg.repositoryRoot}' 0750 ${cfg.user} ${cfg.group} - -" - "z '${cfg.repositoryRoot}' 0750 ${cfg.user} ${cfg.group} - -" - "d '${cfg.stateDir}' 0750 ${cfg.user} ${cfg.group} - -" - "d '${cfg.stateDir}/conf' 0750 ${cfg.user} ${cfg.group} - -" - "d '${cfg.customDir}' 0750 ${cfg.user} ${cfg.group} - -" - "d '${cfg.customDir}/conf' 0750 ${cfg.user} ${cfg.group} - -" - "d '${cfg.stateDir}/data' 0750 ${cfg.user} ${cfg.group} - -" - "d '${cfg.stateDir}/log' 0750 ${cfg.user} ${cfg.group} - -" - "z '${cfg.stateDir}' 0750 ${cfg.user} ${cfg.group} - -" - "z '${cfg.stateDir}/.ssh' 0700 ${cfg.user} ${cfg.group} - -" - "z '${cfg.stateDir}/conf' 0750 ${cfg.user} ${cfg.group} - -" - "z '${cfg.customDir}' 0750 ${cfg.user} ${cfg.group} - -" - "z '${cfg.customDir}/conf' 0750 ${cfg.user} ${cfg.group} - -" - "z '${cfg.stateDir}/data' 0750 ${cfg.user} ${cfg.group} - -" - "z '${cfg.stateDir}/log' 0750 ${cfg.user} ${cfg.group} - -" - - # If we have a folder or symlink with Forgejo locales, remove it - # And symlink the current Forgejo locales in place - "L+ '${cfg.stateDir}/conf/locale' - - - - ${cfg.package.out}/locale" - - ] ++ optionals cfg.lfs.enable [ - "d '${cfg.lfs.contentDir}' 0750 ${cfg.user} ${cfg.group} - -" - "z '${cfg.lfs.contentDir}' 0750 ${cfg.user} ${cfg.group} - -" - ]; + systemd.tmpfiles.rules = + [ + "d '${cfg.dump.backupDir}' 0750 ${cfg.user} ${cfg.group} - -" + "z '${cfg.dump.backupDir}' 0750 ${cfg.user} ${cfg.group} - -" + "d '${cfg.repositoryRoot}' 0750 ${cfg.user} ${cfg.group} - -" + "z '${cfg.repositoryRoot}' 0750 ${cfg.user} ${cfg.group} - -" + "d '${cfg.stateDir}' 0750 ${cfg.user} ${cfg.group} - -" + "d '${cfg.stateDir}/conf' 0750 ${cfg.user} ${cfg.group} - -" + "d '${cfg.customDir}' 0750 ${cfg.user} ${cfg.group} - -" + "d '${cfg.customDir}/conf' 0750 ${cfg.user} ${cfg.group} - -" + "d '${cfg.stateDir}/data' 0750 ${cfg.user} ${cfg.group} - -" + "d '${cfg.stateDir}/log' 0750 ${cfg.user} ${cfg.group} - -" + "z '${cfg.stateDir}' 0750 ${cfg.user} ${cfg.group} - -" + "z '${cfg.stateDir}/.ssh' 0700 ${cfg.user} ${cfg.group} - -" + "z '${cfg.stateDir}/conf' 0750 ${cfg.user} ${cfg.group} - -" + "z '${cfg.customDir}' 0750 ${cfg.user} ${cfg.group} - -" + "z '${cfg.customDir}/conf' 0750 ${cfg.user} ${cfg.group} - -" + "z '${cfg.stateDir}/data' 0750 ${cfg.user} ${cfg.group} - -" + "z '${cfg.stateDir}/log' 0750 ${cfg.user} ${cfg.group} - -" + + # If we have a folder or symlink with Forgejo locales, remove it + # And symlink the current Forgejo locales in place + "L+ '${cfg.stateDir}/conf/locale' - - - - ${cfg.package.out}/locale" + + ] + ++ optionals cfg.lfs.enable [ + "d '${cfg.lfs.contentDir}' 0750 ${cfg.user} ${cfg.group} - -" + "z '${cfg.lfs.contentDir}' 0750 ${cfg.user} ${cfg.group} - -" + ]; systemd.services.forgejo-secrets = mkIf (!cfg.useWizard) { description = "Forgejo secret bootstrap helper"; @@ -536,9 +637,9 @@ in fi ${optionalString cfg.lfs.enable '' - if [ ! -s '${cfg.secrets.server.LFS_JWT_SECRET}' ]; then - ${exe} generate secret LFS_JWT_SECRET > '${cfg.secrets.server.LFS_JWT_SECRET}' - fi + if [ ! -s '${cfg.secrets.server.LFS_JWT_SECRET}' ]; then + ${exe} generate secret LFS_JWT_SECRET > '${cfg.secrets.server.LFS_JWT_SECRET}' + fi ''} if [ ! -s '${cfg.secrets.security.INTERNAL_TOKEN}' ]; then @@ -557,24 +658,35 @@ in systemd.services.forgejo = { description = "Forgejo (Beyond coding. We forge.)"; - after = [ - "network.target" - ] ++ optionals usePostgresql [ - "postgresql.service" - ] ++ optionals useMysql [ - "mysql.service" - ] ++ optionals (!cfg.useWizard) [ - "forgejo-secrets.service" - ]; - requires = optionals (cfg.database.createDatabase && usePostgresql) [ - "postgresql.service" - ] ++ optionals (cfg.database.createDatabase && useMysql) [ - "mysql.service" - ] ++ optionals (!cfg.useWizard) [ - "forgejo-secrets.service" - ]; + after = + [ + "network.target" + ] + ++ optionals usePostgresql [ + "postgresql.service" + ] + ++ optionals useMysql [ + "mysql.service" + ] + ++ optionals (!cfg.useWizard) [ + "forgejo-secrets.service" + ]; + requires = + optionals (cfg.database.createDatabase && usePostgresql) [ + "postgresql.service" + ] + ++ optionals (cfg.database.createDatabase && useMysql) [ + "mysql.service" + ] + ++ optionals (!cfg.useWizard) [ + "forgejo-secrets.service" + ]; wantedBy = [ "multi-user.target" ]; - path = [ cfg.package pkgs.git pkgs.gnupg ]; + path = [ + cfg.package + pkgs.git + pkgs.gnupg + ]; # In older versions the secret naming for JWT was kind of confusing. # The file jwt_secret hold the value for LFS_JWT_SECRET and JWT_SECRET @@ -583,32 +695,31 @@ in # values for JWT_SECRET and the file jwt_secret gets renamed to # lfs_jwt_secret. # We have to consider this to stay compatible with older installations. - preStart = - '' - ${optionalString (!cfg.useWizard) '' - function forgejo_setup { - config='${cfg.customDir}/conf/app.ini' - cp -f '${format.generate "app.ini" cfg.settings}' "$config" - - chmod u+w "$config" - ${lib.getExe' cfg.package "environment-to-ini"} --config "$config" - chmod u-w "$config" - } - (umask 027; forgejo_setup) - ''} - - # run migrations/init the database - ${exe} migrate - - # update all hooks' binary paths - ${exe} admin regenerate hooks - - # update command option in authorized_keys - if [ -r ${cfg.stateDir}/.ssh/authorized_keys ] - then - ${exe} admin regenerate keys - fi - ''; + preStart = '' + ${optionalString (!cfg.useWizard) '' + function forgejo_setup { + config='${cfg.customDir}/conf/app.ini' + cp -f '${format.generate "app.ini" cfg.settings}' "$config" + + chmod u+w "$config" + ${lib.getExe' cfg.package "environment-to-ini"} --config "$config" + chmod u-w "$config" + } + (umask 027; forgejo_setup) + ''} + + # run migrations/init the database + ${exe} migrate + + # update all hooks' binary paths + ${exe} admin regenerate hooks + + # update command option in authorized_keys + if [ -r ${cfg.stateDir}/.ssh/authorized_keys ] + then + ${exe} admin regenerate keys + fi + ''; serviceConfig = { Type = "simple"; @@ -624,7 +735,13 @@ in ProcSubset = "pid"; ProtectProc = "invisible"; # Access write directories - ReadWritePaths = [ cfg.customDir cfg.dump.backupDir cfg.repositoryRoot cfg.stateDir cfg.lfs.contentDir ]; + ReadWritePaths = [ + cfg.customDir + cfg.dump.backupDir + cfg.repositoryRoot + cfg.stateDir + cfg.lfs.contentDir + ]; UMask = "0027"; # Capabilities CapabilityBoundingSet = ""; @@ -642,7 +759,11 @@ in ProtectKernelModules = true; ProtectKernelLogs = true; ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; LockPersonality = true; MemoryDenyWriteExecute = true; @@ -652,7 +773,10 @@ in PrivateMounts = true; # System Call Filtering SystemCallArchitectures = "native"; - SystemCallFilter = [ "~@cpu-emulation @debug @keyring @mount @obsolete @privileged @setuid" "setrlimit" ]; + SystemCallFilter = [ + "~@cpu-emulation @debug @keyring @mount @obsolete @privileged @setuid" + "setrlimit" + ]; # cfg.secrets LoadCredential = map (e: "${e.env}:${e.path}") secrets; }; @@ -699,7 +823,9 @@ in serviceConfig = { Type = "oneshot"; User = cfg.user; - ExecStart = "${exe} dump --type ${cfg.dump.type}" + optionalString (cfg.dump.file != null) " --file ${cfg.dump.file}"; + ExecStart = + "${exe} dump --type ${cfg.dump.type}" + + optionalString (cfg.dump.file != null) " --file ${cfg.dump.file}"; WorkingDirectory = cfg.dump.backupDir; }; }; @@ -713,5 +839,8 @@ in }; meta.doc = ./forgejo.md; - meta.maintainers = with lib.maintainers; [ bendlas emilylange ]; + meta.maintainers = with lib.maintainers; [ + bendlas + emilylange + ]; } diff --git a/nixos/modules/services/misc/freeswitch.nix b/nixos/modules/services/misc/freeswitch.nix index eace38229ca52e..e9d3bb5c05da63 100644 --- a/nixos/modules/services/misc/freeswitch.nix +++ b/nixos/modules/services/misc/freeswitch.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.freeswitch; pkg = cfg.package; @@ -6,15 +11,16 @@ let mkdir -p $out cp -rT ${cfg.configTemplate} $out chmod -R +w $out - ${lib.concatStringsSep "\n" (lib.mapAttrsToList (fileName: filePath: '' - mkdir -p $out/$(dirname ${fileName}) - cp ${filePath} $out/${fileName} - '') cfg.configDir)} + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList (fileName: filePath: '' + mkdir -p $out/$(dirname ${fileName}) + cp ${filePath} $out/${fileName} + '') cfg.configDir + )} ''; - configPath = if cfg.enableReload - then "/etc/freeswitch" - else configDirectory; -in { + configPath = if cfg.enableReload then "/etc/freeswitch" else configDirectory; +in +{ options = { services.freeswitch = { enable = lib.mkEnableOption "FreeSWITCH"; diff --git a/nixos/modules/services/misc/fstrim.nix b/nixos/modules/services/misc/fstrim.nix index f22505841fa396..6e115d99dcd942 100644 --- a/nixos/modules/services/misc/fstrim.nix +++ b/nixos/modules/services/misc/fstrim.nix @@ -1,16 +1,25 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.fstrim; -in { +in +{ options = { services.fstrim = { - enable = (lib.mkEnableOption "periodic SSD TRIM of mounted partitions in background" // { - default = true; - }); + enable = ( + lib.mkEnableOption "periodic SSD TRIM of mounted partitions in background" + // { + default = true; + } + ); interval = lib.mkOption { type = lib.types.str; @@ -33,7 +42,10 @@ in { systemd.timers.fstrim = { timerConfig = { - OnCalendar = [ "" cfg.interval ]; + OnCalendar = [ + "" + cfg.interval + ]; }; wantedBy = [ "timers.target" ]; }; diff --git a/nixos/modules/services/misc/gammu-smsd.nix b/nixos/modules/services/misc/gammu-smsd.nix index 78f4e53815f2f7..ea237e78d99fff 100644 --- a/nixos/modules/services/misc/gammu-smsd.nix +++ b/nixos/modules/services/misc/gammu-smsd.nix @@ -1,4 +1,9 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: let cfg = config.services.gammu-smsd; @@ -29,25 +34,30 @@ let ''} ${lib.optionalString (cfg.backend.service == "sql" && cfg.backend.sql.driver == "native_pgsql") ( - with cfg.backend; '' + with cfg.backend; + '' Driver = ${sql.driver} - ${lib.optionalString (sql.database!= null) "Database = ${sql.database}"} + ${lib.optionalString (sql.database != null) "Database = ${sql.database}"} ${lib.optionalString (sql.host != null) "Host = ${sql.host}"} ${lib.optionalString (sql.user != null) "User = ${sql.user}"} ${lib.optionalString (sql.password != null) "Password = ${sql.password}"} - '')} + '' + )} ${cfg.extraConfig.smsd} ''; initDBDir = "share/doc/gammu/examples/sql"; - gammuPackage = with cfg.backend; (pkgs.gammu.override { - dbiSupport = service == "sql" && sql.driver == "sqlite"; - postgresSupport = service == "sql" && sql.driver == "native_pgsql"; - }); + gammuPackage = + with cfg.backend; + (pkgs.gammu.override { + dbiSupport = service == "sql" && sql.driver == "sqlite"; + postgresSupport = service == "sql" && sql.driver == "native_pgsql"; + }); -in { +in +{ options = { services.gammu-smsd = { @@ -92,7 +102,6 @@ in { }; }; - log = { file = lib.mkOption { type = lib.types.str; @@ -101,13 +110,20 @@ in { }; format = lib.mkOption { - type = lib.types.enum [ "nothing" "text" "textall" "textalldate" "errors" "errorsdate" "binary" ]; + type = lib.types.enum [ + "nothing" + "text" + "textall" + "textalldate" + "errors" + "errorsdate" + "binary" + ]; default = "errors"; description = "Determines what will be logged to the LogFile"; }; }; - extraConfig = { gammu = lib.mkOption { type = lib.types.lines; @@ -115,7 +131,6 @@ in { description = "Extra config lines to be added into [gammu] section"; }; - smsd = lib.mkOption { type = lib.types.lines; default = ""; @@ -123,10 +138,13 @@ in { }; }; - backend = { service = lib.mkOption { - type = lib.types.enum [ "null" "files" "sql" ]; + type = lib.types.enum [ + "null" + "files" + "sql" + ]; default = "null"; description = "Service to use to store sms data."; }; @@ -159,7 +177,12 @@ in { sql = { driver = lib.mkOption { - type = lib.types.enum [ "native_mysql" "native_pgsql" "odbc" "dbi" ]; + type = lib.types.enum [ + "native_mysql" + "native_pgsql" + "odbc" + "dbi" + ]; description = "DB driver to use"; }; @@ -204,40 +227,53 @@ in { group = cfg.device.group; }; - environment.systemPackages = with cfg.backend; [ gammuPackage ] - ++ lib.optionals (service == "sql" && sql.driver == "sqlite") [ pkgs.sqlite ]; + environment.systemPackages = + with cfg.backend; + [ gammuPackage ] ++ lib.optionals (service == "sql" && sql.driver == "sqlite") [ pkgs.sqlite ]; systemd.services.gammu-smsd = { description = "gammu-smsd daemon"; wantedBy = [ "multi-user.target" ]; - wants = with cfg.backend; [ ] - ++ lib.optionals (service == "sql" && sql.driver == "native_pgsql") [ "postgresql.service" ]; - - preStart = with cfg.backend; - - lib.optionalString (service == "files") (with files; '' - mkdir -m 755 -p ${inboxPath} ${outboxPath} ${sentSMSPath} ${errorSMSPath} - chown ${cfg.user} -R ${inboxPath} - chown ${cfg.user} -R ${outboxPath} - chown ${cfg.user} -R ${sentSMSPath} - chown ${cfg.user} -R ${errorSMSPath} - '') - + lib.optionalString (service == "sql" && sql.driver == "sqlite") '' - cat "${gammuPackage}/${initDBDir}/sqlite.sql" \ - | ${pkgs.sqlite.bin}/bin/sqlite3 ${sql.database} + wants = + with cfg.backend; + [ ] ++ lib.optionals (service == "sql" && sql.driver == "native_pgsql") [ "postgresql.service" ]; + + preStart = + with cfg.backend; + + lib.optionalString (service == "files") ( + with files; + '' + mkdir -m 755 -p ${inboxPath} ${outboxPath} ${sentSMSPath} ${errorSMSPath} + chown ${cfg.user} -R ${inboxPath} + chown ${cfg.user} -R ${outboxPath} + chown ${cfg.user} -R ${sentSMSPath} + chown ${cfg.user} -R ${errorSMSPath} + '' + ) + + lib.optionalString (service == "sql" && sql.driver == "sqlite") '' + cat "${gammuPackage}/${initDBDir}/sqlite.sql" \ + | ${pkgs.sqlite.bin}/bin/sqlite3 ${sql.database} '' - + (let execPsql = extraArgs: lib.concatStringsSep " " [ - (lib.optionalString (sql.password != null) "PGPASSWORD=${sql.password}") - "${config.services.postgresql.package}/bin/psql" - (lib.optionalString (sql.host != null) "-h ${sql.host}") - (lib.optionalString (sql.user != null) "-U ${sql.user}") - "$extraArgs" - "${sql.database}" - ]; in lib.optionalString (service == "sql" && sql.driver == "native_pgsql") '' - echo '\i '"${gammuPackage}/${initDBDir}/pgsql.sql" | ${execPsql ""} - ''); + + ( + let + execPsql = + extraArgs: + lib.concatStringsSep " " [ + (lib.optionalString (sql.password != null) "PGPASSWORD=${sql.password}") + "${config.services.postgresql.package}/bin/psql" + (lib.optionalString (sql.host != null) "-h ${sql.host}") + (lib.optionalString (sql.user != null) "-U ${sql.user}") + "$extraArgs" + "${sql.database}" + ]; + in + lib.optionalString (service == "sql" && sql.driver == "native_pgsql") '' + echo '\i '"${gammuPackage}/${initDBDir}/pgsql.sql" | ${execPsql ""} + '' + ); serviceConfig = { User = "${cfg.user}"; diff --git a/nixos/modules/services/misc/geoipupdate.nix b/nixos/modules/services/misc/geoipupdate.nix index f46bf7b394feaf..c53450f0afc404 100644 --- a/nixos/modules/services/misc/geoipupdate.nix +++ b/nixos/modules/services/misc/geoipupdate.nix @@ -1,12 +1,27 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.geoipupdate; - inherit (builtins) isAttrs isString isInt isList typeOf hashString; + inherit (builtins) + isAttrs + isString + isInt + isList + typeOf + hashString + ; in { imports = [ - (lib.mkRemovedOptionModule [ "services" "geoip-updater" ] "services.geoip-updater has been removed, use services.geoipupdate instead.") + (lib.mkRemovedOptionModule [ + "services" + "geoip-updater" + ] "services.geoip-updater has been removed, use services.geoipupdate instead.") ]; options = { @@ -54,9 +69,13 @@ in freeformType = with lib.types; let - type = oneOf [str int bool]; + type = oneOf [ + str + int + bool + ]; in - attrsOf (either type (listOf type)); + attrsOf (either type (listOf type)); options = { @@ -149,19 +168,33 @@ in isSecret = v: isAttrs v && v ? _secret && isString v._secret; geoipupdateKeyValue = lib.generators.toKeyValue { mkKeyValue = lib.flip lib.generators.mkKeyValueDefault " " rec { - mkValueString = v: - if isInt v then toString v - else if isString v then v - else if true == v then "1" - else if false == v then "0" - else if isList v then lib.concatMapStringsSep " " mkValueString v - else if isSecret v then hashString "sha256" v._secret - else throw "unsupported type ${typeOf v}: ${(lib.generators.toPretty {}) v}"; + mkValueString = + v: + if isInt v then + toString v + else if isString v then + v + else if true == v then + "1" + else if false == v then + "0" + else if isList v then + lib.concatMapStringsSep " " mkValueString v + else if isSecret v then + hashString "sha256" v._secret + else + throw "unsupported type ${typeOf v}: ${(lib.generators.toPretty { }) v}"; }; }; secretPaths = lib.catAttrs "_secret" (lib.collect isSecret cfg.settings); mkSecretReplacement = file: '' - replace-secret ${lib.escapeShellArgs [ (hashString "sha256" file) file "/run/geoipupdate/GeoIP.conf" ]} + replace-secret ${ + lib.escapeShellArgs [ + (hashString "sha256" file) + file + "/run/geoipupdate/GeoIP.conf" + ] + } ''; secretReplacements = lib.concatMapStrings mkSecretReplacement secretPaths; @@ -177,7 +210,7 @@ in ${secretReplacements} ''; in - "+${pkgs.writeShellScript "start-pre-full-privileges" script}"; + "+${pkgs.writeShellScript "start-pre-full-privileges" script}"; ExecStart = "${pkgs.geoipupdate}/bin/geoipupdate -f /run/geoipupdate/GeoIP.conf"; User = "geoip"; DynamicUser = true; @@ -197,8 +230,14 @@ in ProtectKernelTunables = true; ProtectProc = "invisible"; ProcSubset = "pid"; - SystemCallFilter = [ "@system-service" "~@privileged" ]; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictRealtime = true; RestrictNamespaces = true; MemoryDenyWriteExecute = true; diff --git a/nixos/modules/services/misc/gitolite.nix b/nixos/modules/services/misc/gitolite.nix index 779a9ac9929db7..9cb7bc769e86ba 100644 --- a/nixos/modules/services/misc/gitolite.nix +++ b/nixos/modules/services/misc/gitolite.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.gitolite; # Use writeTextDir to not leak Nix store hash into file name @@ -51,7 +56,7 @@ in commonHooks = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; description = '' A list of custom git hooks that get copied to `~/.gitolite/hooks/common`. ''; @@ -117,122 +122,141 @@ in }; config = lib.mkIf cfg.enable ( - let - manageGitoliteRc = cfg.extraGitoliteRc != ""; - rcDir = pkgs.runCommand "gitolite-rc" { preferLocalBuild = true; } rcDirScript; - rcDirScript = - '' - mkdir "$out" - export HOME=temp-home - mkdir -p "$HOME/.gitolite/logs" # gitolite can't run without it - '${pkgs.gitolite}'/bin/gitolite print-default-rc >>"$out/gitolite.rc.default" - cat <>"$out/gitolite.rc" - # This file is managed by NixOS. - # Use services.gitolite options to control it. - - END - cat "$out/gitolite.rc.default" >>"$out/gitolite.rc" - '' + - lib.optionalString (cfg.extraGitoliteRc != "") '' - echo -n ${lib.escapeShellArg '' - - # Added by NixOS: - ${lib.removeSuffix "\n" cfg.extraGitoliteRc} - - # per perl rules, this should be the last line in such a file: - 1; - ''} >>"$out/gitolite.rc" - ''; - in { - services.gitolite.extraGitoliteRc = lib.optionalString cfg.enableGitAnnex '' - # Enable git-annex support: - push( @{$RC{ENABLE}}, 'git-annex-shell ua'); - ''; - - users.users.${cfg.user} = { - description = cfg.description; - home = cfg.dataDir; - uid = config.ids.uids.gitolite; - group = cfg.group; - useDefaultShell = true; - }; - users.groups.${cfg.group}.gid = config.ids.gids.gitolite; + let + manageGitoliteRc = cfg.extraGitoliteRc != ""; + rcDir = pkgs.runCommand "gitolite-rc" { preferLocalBuild = true; } rcDirScript; + rcDirScript = + '' + mkdir "$out" + export HOME=temp-home + mkdir -p "$HOME/.gitolite/logs" # gitolite can't run without it + '${pkgs.gitolite}'/bin/gitolite print-default-rc >>"$out/gitolite.rc.default" + cat <>"$out/gitolite.rc" + # This file is managed by NixOS. + # Use services.gitolite options to control it. + + END + cat "$out/gitolite.rc.default" >>"$out/gitolite.rc" + '' + + lib.optionalString (cfg.extraGitoliteRc != "") '' + echo -n ${lib.escapeShellArg '' - systemd.services.gitolite-init = { - description = "Gitolite initialization"; - wantedBy = [ "multi-user.target" ]; - unitConfig.RequiresMountsFor = cfg.dataDir; + # Added by NixOS: + ${lib.removeSuffix "\n" cfg.extraGitoliteRc} - environment = { - GITOLITE_RC = ".gitolite.rc"; - GITOLITE_RC_DEFAULT = "${rcDir}/gitolite.rc.default"; + # per perl rules, this should be the last line in such a file: + 1; + ''} >>"$out/gitolite.rc" + ''; + in + { + services.gitolite.extraGitoliteRc = lib.optionalString cfg.enableGitAnnex '' + # Enable git-annex support: + push( @{$RC{ENABLE}}, 'git-annex-shell ua'); + ''; + + users.users.${cfg.user} = { + description = cfg.description; + home = cfg.dataDir; + uid = config.ids.uids.gitolite; + group = cfg.group; + useDefaultShell = true; }; + users.groups.${cfg.group}.gid = config.ids.gids.gitolite; - serviceConfig = lib.mkMerge [ - (lib.mkIf (cfg.dataDir == "/var/lib/gitolite") { - StateDirectory = "gitolite gitolite/.gitolite gitolite/.gitolite/logs"; - StateDirectoryMode = "0750"; - }) - { - Type = "oneshot"; - User = cfg.user; - Group = cfg.group; - WorkingDirectory = "~"; - RemainAfterExit = true; - } - ]; - - path = [ pkgs.gitolite pkgs.git pkgs.perl pkgs.bash pkgs.diffutils config.programs.ssh.package ]; - script = - let - rcSetupScriptIfCustomFile = - if manageGitoliteRc then '' - cat <ERROR: NixOS can't apply declarative configuration - <3>to your .gitolite.rc file, because it seems to be - <3>already customized manually. - <3>See the services.gitolite.extraGitoliteRc option - <3>in "man configuration.nix" for more information. - END - # Not sure if the line below addresses the issue directly or just - # adds a delay, but without it our error message often doesn't - # show up in `systemctl status gitolite-init`. - journalctl --flush - exit 1 - '' else '' - : - ''; - rcSetupScriptIfDefaultFileOrStoreSymlink = - if manageGitoliteRc then '' - ln -sf "${rcDir}/gitolite.rc" "$GITOLITE_RC" - '' else '' - [[ -L "$GITOLITE_RC" ]] && rm -f "$GITOLITE_RC" + systemd.services.gitolite-init = { + description = "Gitolite initialization"; + wantedBy = [ "multi-user.target" ]; + unitConfig.RequiresMountsFor = cfg.dataDir; + + environment = { + GITOLITE_RC = ".gitolite.rc"; + GITOLITE_RC_DEFAULT = "${rcDir}/gitolite.rc.default"; + }; + + serviceConfig = lib.mkMerge [ + (lib.mkIf (cfg.dataDir == "/var/lib/gitolite") { + StateDirectory = "gitolite gitolite/.gitolite gitolite/.gitolite/logs"; + StateDirectoryMode = "0750"; + }) + { + Type = "oneshot"; + User = cfg.user; + Group = cfg.group; + WorkingDirectory = "~"; + RemainAfterExit = true; + } + ]; + + path = [ + pkgs.gitolite + pkgs.git + pkgs.perl + pkgs.bash + pkgs.diffutils + config.programs.ssh.package + ]; + script = + let + rcSetupScriptIfCustomFile = + if manageGitoliteRc then + '' + cat <ERROR: NixOS can't apply declarative configuration + <3>to your .gitolite.rc file, because it seems to be + <3>already customized manually. + <3>See the services.gitolite.extraGitoliteRc option + <3>in "man configuration.nix" for more information. + END + # Not sure if the line below addresses the issue directly or just + # adds a delay, but without it our error message often doesn't + # show up in `systemctl status gitolite-init`. + journalctl --flush + exit 1 + '' + else + '' + : + ''; + rcSetupScriptIfDefaultFileOrStoreSymlink = + if manageGitoliteRc then + '' + ln -sf "${rcDir}/gitolite.rc" "$GITOLITE_RC" + '' + else + '' + [[ -L "$GITOLITE_RC" ]] && rm -f "$GITOLITE_RC" + ''; + in + '' + if ( [[ ! -e "$GITOLITE_RC" ]] && [[ ! -L "$GITOLITE_RC" ]] ) || + ( [[ -f "$GITOLITE_RC" ]] && diff -q "$GITOLITE_RC" "$GITOLITE_RC_DEFAULT" >/dev/null ) || + ( [[ -L "$GITOLITE_RC" ]] && [[ "$(readlink "$GITOLITE_RC")" =~ ^/nix/store/ ]] ) + then + '' + + rcSetupScriptIfDefaultFileOrStoreSymlink + + '' + else + '' + + rcSetupScriptIfCustomFile + + '' + fi + + if [ ! -d repositories ]; then + gitolite setup -pk ${pubkeyFile} + fi + if [ -n "${hooks}" ]; then + cp -f ${hooks} .gitolite/hooks/common/ + chmod +x .gitolite/hooks/common/* + fi + gitolite setup # Upgrade if needed ''; - in - '' - if ( [[ ! -e "$GITOLITE_RC" ]] && [[ ! -L "$GITOLITE_RC" ]] ) || - ( [[ -f "$GITOLITE_RC" ]] && diff -q "$GITOLITE_RC" "$GITOLITE_RC_DEFAULT" >/dev/null ) || - ( [[ -L "$GITOLITE_RC" ]] && [[ "$(readlink "$GITOLITE_RC")" =~ ^/nix/store/ ]] ) - then - '' + rcSetupScriptIfDefaultFileOrStoreSymlink + - '' - else - '' + rcSetupScriptIfCustomFile + - '' - fi - - if [ ! -d repositories ]; then - gitolite setup -pk ${pubkeyFile} - fi - if [ -n "${hooks}" ]; then - cp -f ${hooks} .gitolite/hooks/common/ - chmod +x .gitolite/hooks/common/* - fi - gitolite setup # Upgrade if needed - ''; - }; + }; - environment.systemPackages = [ pkgs.gitolite pkgs.git ] - ++ lib.optional cfg.enableGitAnnex pkgs.git-annex; - }); + environment.systemPackages = [ + pkgs.gitolite + pkgs.git + ] ++ lib.optional cfg.enableGitAnnex pkgs.git-annex; + } + ); } diff --git a/nixos/modules/services/misc/gitweb.nix b/nixos/modules/services/misc/gitweb.nix index fb31deb8538ac4..3030dc5c8285d4 100644 --- a/nixos/modules/services/misc/gitweb.nix +++ b/nixos/modules/services/misc/gitweb.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.gitweb; diff --git a/nixos/modules/services/misc/gpsd.nix b/nixos/modules/services/misc/gpsd.nix index 76aa151f204adf..75a323332f3695 100644 --- a/nixos/modules/services/misc/gpsd.nix +++ b/nixos/modules/services/misc/gpsd.nix @@ -1,17 +1,23 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let uid = config.ids.uids.gpsd; gid = config.ids.gids.gpsd; cfg = config.services.gpsd; -in { +in +{ ###### interface imports = [ - (lib.mkRemovedOptionModule [ "services" "gpsd" "device" ] - "Use `services.gpsd.devices` instead.") + (lib.mkRemovedOptionModule [ "services" "gpsd" "device" ] "Use `services.gpsd.devices` instead.") ]; options = { @@ -92,7 +98,11 @@ in { extraArgs = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "-r" "-s" "19200" ]; + example = [ + "-r" + "-s" + "19200" + ]; description = '' A list of extra command line arguments to pass to gpsd. Check gpsd(8) mangpage for possible arguments. @@ -122,18 +132,20 @@ in { after = [ "network.target" ]; serviceConfig = { Type = "forking"; - ExecStart = let - devices = utils.escapeSystemdExecArgs cfg.devices; - extraArgs = utils.escapeSystemdExecArgs cfg.extraArgs; - in '' - ${pkgs.gpsd}/sbin/gpsd -D "${toString cfg.debugLevel}" \ - -S "${toString cfg.port}" \ - ${lib.optionalString cfg.readonly "-b"} \ - ${lib.optionalString cfg.nowait "-n"} \ - ${lib.optionalString cfg.listenany "-G"} \ - ${extraArgs} \ - ${devices} - ''; + ExecStart = + let + devices = utils.escapeSystemdExecArgs cfg.devices; + extraArgs = utils.escapeSystemdExecArgs cfg.extraArgs; + in + '' + ${pkgs.gpsd}/sbin/gpsd -D "${toString cfg.debugLevel}" \ + -S "${toString cfg.port}" \ + ${lib.optionalString cfg.readonly "-b"} \ + ${lib.optionalString cfg.nowait "-n"} \ + ${lib.optionalString cfg.listenany "-G"} \ + ${extraArgs} \ + ${devices} + ''; }; }; diff --git a/nixos/modules/services/misc/greenclip.nix b/nixos/modules/services/misc/greenclip.nix index ce44ad4f666341..878fb52c584b31 100644 --- a/nixos/modules/services/misc/greenclip.nix +++ b/nixos/modules/services/misc/greenclip.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.greenclip; -in { +in +{ options.services.greenclip = { enable = lib.mkEnableOption "Greenclip, a clipboard manager"; @@ -11,10 +17,10 @@ in { config = lib.mkIf cfg.enable { systemd.user.services.greenclip = { - enable = true; + enable = true; description = "greenclip daemon"; wantedBy = [ "graphical-session.target" ]; - after = [ "graphical-session.target" ]; + after = [ "graphical-session.target" ]; serviceConfig = { ExecStart = "${cfg.package}/bin/greenclip daemon"; Restart = "always"; diff --git a/nixos/modules/services/misc/guix/default.nix b/nixos/modules/services/misc/guix/default.nix index 9cd346a92b51e8..049a6a5b42223c 100644 --- a/nixos/modules/services/misc/guix/default.nix +++ b/nixos/modules/services/misc/guix/default.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.guix; @@ -14,13 +19,14 @@ let isSystemUser = true; }; - guixBuildUsers = numberOfUsers: - builtins.listToAttrs (map - (user: { + guixBuildUsers = + numberOfUsers: + builtins.listToAttrs ( + map (user: { name = user.name; value = user; - }) - (builtins.genList guixBuildUser numberOfUsers)); + }) (builtins.genList guixBuildUser numberOfUsers) + ); # A set of Guix user profiles to be linked at activation. All of these should # be default profiles managed by Guix CLI and the profiles are located in @@ -85,7 +91,10 @@ in extraArgs = mkOption { type = with types; listOf str; default = [ ]; - example = [ "--max-jobs=4" "--debug" ]; + example = [ + "--max-jobs=4" + "--debug" + ]; description = '' Extra flags to pass to the Guix daemon service. ''; @@ -217,7 +226,7 @@ in description = '' Extra flags to pass to the substitute server. ''; - default = []; + default = [ ]; example = [ "--compression=zstd:6" "--discover=no" @@ -257,208 +266,224 @@ in }; }; - config = lib.mkIf cfg.enable (lib.mkMerge [ - { - environment.systemPackages = [ package ]; - - users.users = guixBuildUsers cfg.nrBuildUsers; - users.groups.${cfg.group} = { }; - - # Guix uses Avahi (through guile-avahi) both for the auto-discovering and - # advertising substitute servers in the local network. - services.avahi.enable = lib.mkDefault true; - services.avahi.publish.enable = lib.mkDefault true; - services.avahi.publish.userServices = lib.mkDefault true; - - # It's similar to Nix daemon so there's no question whether or not this - # should be sandboxed. - systemd.services.guix-daemon = { - environment = serviceEnv; - script = '' - exec ${lib.getExe' package "guix-daemon"} \ - --build-users-group=${cfg.group} \ - ${lib.optionalString (cfg.substituters.urls != [ ]) - "--substitute-urls='${lib.concatStringsSep " " cfg.substituters.urls}'"} \ - ${lib.escapeShellArgs cfg.extraArgs} - ''; - serviceConfig = { - OOMPolicy = "continue"; - RemainAfterExit = "yes"; - Restart = "always"; - TasksMax = 8192; + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + { + environment.systemPackages = [ package ]; + + users.users = guixBuildUsers cfg.nrBuildUsers; + users.groups.${cfg.group} = { }; + + # Guix uses Avahi (through guile-avahi) both for the auto-discovering and + # advertising substitute servers in the local network. + services.avahi.enable = lib.mkDefault true; + services.avahi.publish.enable = lib.mkDefault true; + services.avahi.publish.userServices = lib.mkDefault true; + + # It's similar to Nix daemon so there's no question whether or not this + # should be sandboxed. + systemd.services.guix-daemon = { + environment = serviceEnv; + script = '' + exec ${lib.getExe' package "guix-daemon"} \ + --build-users-group=${cfg.group} \ + ${ + lib.optionalString ( + cfg.substituters.urls != [ ] + ) "--substitute-urls='${lib.concatStringsSep " " cfg.substituters.urls}'" + } \ + ${lib.escapeShellArgs cfg.extraArgs} + ''; + serviceConfig = { + OOMPolicy = "continue"; + RemainAfterExit = "yes"; + Restart = "always"; + TasksMax = 8192; + }; + unitConfig.RequiresMountsFor = [ + cfg.storeDir + cfg.stateDir + ]; + wantedBy = [ "multi-user.target" ]; }; - unitConfig.RequiresMountsFor = [ - cfg.storeDir - cfg.stateDir - ]; - wantedBy = [ "multi-user.target" ]; - }; - - # This is based from Nix daemon socket unit from upstream Nix package. - # Guix build daemon has support for systemd-style socket activation. - systemd.sockets.guix-daemon = { - description = "Guix daemon socket"; - before = [ "multi-user.target" ]; - listenStreams = [ "${cfg.stateDir}/guix/daemon-socket/socket" ]; - unitConfig.RequiresMountsFor = [ cfg.storeDir cfg.stateDir ]; - wantedBy = [ "sockets.target" ]; - }; - - systemd.mounts = [{ - description = "Guix read-only store directory"; - before = [ "guix-daemon.service" ]; - what = cfg.storeDir; - where = cfg.storeDir; - type = "none"; - options = "bind,ro"; - - unitConfig.DefaultDependencies = false; - wantedBy = [ "guix-daemon.service" ]; - }]; - - # Make transferring files from one store to another easier with the usual - # case being of most substitutes from the official Guix CI instance. - environment.etc."guix/acl".source = aclFile; - - # Link the usual Guix profiles to the home directory. This is useful in - # ephemeral setups where only certain part of the filesystem is - # persistent (e.g., "Erase my darlings"-type of setup). - system.userActivationScripts.guix-activate-user-profiles.text = let - guixProfile = profile: "${cfg.stateDir}/guix/profiles/per-user/\${USER}/${profile}"; - linkProfile = profile: location: let - userProfile = guixProfile profile; - in '' - [ -d "${userProfile}" ] && ln -sfn "${userProfile}" "${location}" - ''; - linkProfileToPath = acc: profile: location: - acc + (linkProfile profile location); - - # This should contain export-only Guix user profiles. The rest of it is - # handled manually in the activation script. - guixUserProfiles' = lib.attrsets.removeAttrs guixUserProfiles [ "guix-home" ]; - - linkExportsScript = lib.foldlAttrs linkProfileToPath "" guixUserProfiles'; - in '' - # Don't export this please! It is only expected to be used for this - # activation script and nothing else. - XDG_CONFIG_HOME=''${XDG_CONFIG_HOME:-$HOME/.config} - - # Linking the usual Guix profiles into the home directory. - ${linkExportsScript} - - # Activate all of the default Guix non-exports profiles manually. - ${linkProfile "guix-home" "$HOME/.guix-home"} - [ -L "$HOME/.guix-home" ] && "$HOME/.guix-home/activate" - ''; - # GUIX_LOCPATH is basically LOCPATH but for Guix libc which in turn used by - # virtually every Guix-built packages. This is so that Guix-installed - # applications wouldn't use incompatible locale data and not touch its host - # system. - environment.sessionVariables.GUIX_LOCPATH = lib.makeSearchPath "lib/locale" guixProfiles; - - # What Guix profiles export is very similar to Nix profiles so it is - # acceptable to list it here. Also, it is more likely that the user would - # want to use packages explicitly installed from Guix so we're putting it - # first. - environment.profiles = lib.mkBefore guixProfiles; - } - - (lib.mkIf cfg.publish.enable { - systemd.services.guix-publish = { - description = "Guix remote store"; - environment = serviceEnv; - - # Mounts will be required by the daemon service anyways so there's no - # need add RequiresMountsFor= or something similar. - requires = [ "guix-daemon.service" ]; - after = [ "guix-daemon.service" ]; - partOf = [ "guix-daemon.service" ]; - - preStart = lib.mkIf cfg.publish.generateKeyPair '' - # Generate the keypair if it's missing. - [ -f "/etc/guix/signing-key.sec" ] && [ -f "/etc/guix/signing-key.pub" ] || \ - ${lib.getExe' package "guix"} archive --generate-key || { - rm /etc/guix/signing-key.*; - ${lib.getExe' package "guix"} archive --generate-key; - } - ''; - script = '' - exec ${lib.getExe' package "guix"} publish \ - --user=${cfg.publish.user} --port=${builtins.toString cfg.publish.port} \ - ${lib.escapeShellArgs cfg.publish.extraArgs} - ''; - - serviceConfig = { - Restart = "always"; - RestartSec = 10; - - ProtectClock = true; - ProtectHostname = true; - ProtectKernelTunables = true; - ProtectKernelModules = true; - ProtectControlGroups = true; - SystemCallFilter = [ - "@system-service" - "@debug" - "@setuid" + # This is based from Nix daemon socket unit from upstream Nix package. + # Guix build daemon has support for systemd-style socket activation. + systemd.sockets.guix-daemon = { + description = "Guix daemon socket"; + before = [ "multi-user.target" ]; + listenStreams = [ "${cfg.stateDir}/guix/daemon-socket/socket" ]; + unitConfig.RequiresMountsFor = [ + cfg.storeDir + cfg.stateDir ]; + wantedBy = [ "sockets.target" ]; + }; - RestrictNamespaces = true; - RestrictAddressFamilies = [ - "AF_UNIX" - "AF_INET" - "AF_INET6" - ]; + systemd.mounts = [ + { + description = "Guix read-only store directory"; + before = [ "guix-daemon.service" ]; + what = cfg.storeDir; + where = cfg.storeDir; + type = "none"; + options = "bind,ro"; + + unitConfig.DefaultDependencies = false; + wantedBy = [ "guix-daemon.service" ]; + } + ]; - # While the permissions can be set, it is assumed to be taken by Guix - # daemon service which it has already done the setup. - ConfigurationDirectory = "guix"; + # Make transferring files from one store to another easier with the usual + # case being of most substitutes from the official Guix CI instance. + environment.etc."guix/acl".source = aclFile; + + # Link the usual Guix profiles to the home directory. This is useful in + # ephemeral setups where only certain part of the filesystem is + # persistent (e.g., "Erase my darlings"-type of setup). + system.userActivationScripts.guix-activate-user-profiles.text = + let + guixProfile = profile: "${cfg.stateDir}/guix/profiles/per-user/\${USER}/${profile}"; + linkProfile = + profile: location: + let + userProfile = guixProfile profile; + in + '' + [ -d "${userProfile}" ] && ln -sfn "${userProfile}" "${location}" + ''; + linkProfileToPath = + acc: profile: location: + acc + (linkProfile profile location); + + # This should contain export-only Guix user profiles. The rest of it is + # handled manually in the activation script. + guixUserProfiles' = lib.attrsets.removeAttrs guixUserProfiles [ "guix-home" ]; + + linkExportsScript = lib.foldlAttrs linkProfileToPath "" guixUserProfiles'; + in + '' + # Don't export this please! It is only expected to be used for this + # activation script and nothing else. + XDG_CONFIG_HOME=''${XDG_CONFIG_HOME:-$HOME/.config} + + # Linking the usual Guix profiles into the home directory. + ${linkExportsScript} + + # Activate all of the default Guix non-exports profiles manually. + ${linkProfile "guix-home" "$HOME/.guix-home"} + [ -L "$HOME/.guix-home" ] && "$HOME/.guix-home/activate" + ''; + + # GUIX_LOCPATH is basically LOCPATH but for Guix libc which in turn used by + # virtually every Guix-built packages. This is so that Guix-installed + # applications wouldn't use incompatible locale data and not touch its host + # system. + environment.sessionVariables.GUIX_LOCPATH = lib.makeSearchPath "lib/locale" guixProfiles; + + # What Guix profiles export is very similar to Nix profiles so it is + # acceptable to list it here. Also, it is more likely that the user would + # want to use packages explicitly installed from Guix so we're putting it + # first. + environment.profiles = lib.mkBefore guixProfiles; + } + + (lib.mkIf cfg.publish.enable { + systemd.services.guix-publish = { + description = "Guix remote store"; + environment = serviceEnv; + + # Mounts will be required by the daemon service anyways so there's no + # need add RequiresMountsFor= or something similar. + requires = [ "guix-daemon.service" ]; + after = [ "guix-daemon.service" ]; + partOf = [ "guix-daemon.service" ]; + + preStart = lib.mkIf cfg.publish.generateKeyPair '' + # Generate the keypair if it's missing. + [ -f "/etc/guix/signing-key.sec" ] && [ -f "/etc/guix/signing-key.pub" ] || \ + ${lib.getExe' package "guix"} archive --generate-key || { + rm /etc/guix/signing-key.*; + ${lib.getExe' package "guix"} archive --generate-key; + } + ''; + script = '' + exec ${lib.getExe' package "guix"} publish \ + --user=${cfg.publish.user} --port=${builtins.toString cfg.publish.port} \ + ${lib.escapeShellArgs cfg.publish.extraArgs} + ''; + + serviceConfig = { + Restart = "always"; + RestartSec = 10; + + ProtectClock = true; + ProtectHostname = true; + ProtectKernelTunables = true; + ProtectKernelModules = true; + ProtectControlGroups = true; + SystemCallFilter = [ + "@system-service" + "@debug" + "@setuid" + ]; + + RestrictNamespaces = true; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; + + # While the permissions can be set, it is assumed to be taken by Guix + # daemon service which it has already done the setup. + ConfigurationDirectory = "guix"; + + AmbientCapabilities = [ "CAP_NET_BIND_SERVICE" ]; + CapabilityBoundingSet = [ + "CAP_NET_BIND_SERVICE" + "CAP_SETUID" + "CAP_SETGID" + ]; + }; + wantedBy = [ "multi-user.target" ]; + }; - AmbientCapabilities = [ "CAP_NET_BIND_SERVICE" ]; - CapabilityBoundingSet = [ - "CAP_NET_BIND_SERVICE" - "CAP_SETUID" - "CAP_SETGID" - ]; + users.users.guix-publish = lib.mkIf (cfg.publish.user == "guix-publish") { + description = "Guix publish user"; + group = config.users.groups.guix-publish.name; + isSystemUser = true; }; - wantedBy = [ "multi-user.target" ]; - }; + users.groups.guix-publish = { }; + }) - users.users.guix-publish = lib.mkIf (cfg.publish.user == "guix-publish") { - description = "Guix publish user"; - group = config.users.groups.guix-publish.name; - isSystemUser = true; - }; - users.groups.guix-publish = {}; - }) - - (lib.mkIf cfg.gc.enable { - # This service should be handled by root to collect all garbage by all - # users. - systemd.services.guix-gc = { - description = "Guix garbage collection"; - startAt = cfg.gc.dates; - script = '' - exec ${lib.getExe' package "guix"} gc ${lib.escapeShellArgs cfg.gc.extraArgs} - ''; - serviceConfig = { - Type = "oneshot"; - PrivateDevices = true; - PrivateNetwork = true; - ProtectControlGroups = true; - ProtectHostname = true; - ProtectKernelTunables = true; - SystemCallFilter = [ - "@default" - "@file-system" - "@basic-io" - "@system-service" - ]; + (lib.mkIf cfg.gc.enable { + # This service should be handled by root to collect all garbage by all + # users. + systemd.services.guix-gc = { + description = "Guix garbage collection"; + startAt = cfg.gc.dates; + script = '' + exec ${lib.getExe' package "guix"} gc ${lib.escapeShellArgs cfg.gc.extraArgs} + ''; + serviceConfig = { + Type = "oneshot"; + PrivateDevices = true; + PrivateNetwork = true; + ProtectControlGroups = true; + ProtectHostname = true; + ProtectKernelTunables = true; + SystemCallFilter = [ + "@default" + "@file-system" + "@basic-io" + "@system-service" + ]; + }; }; - }; - systemd.timers.guix-gc.timerConfig.Persistent = true; - }) - ]); + systemd.timers.guix-gc.timerConfig.Persistent = true; + }) + ] + ); } diff --git a/nixos/modules/services/misc/headphones.nix b/nixos/modules/services/misc/headphones.nix index b56322b0cbccf2..8440c114ca72ec 100644 --- a/nixos/modules/services/misc/headphones.nix +++ b/nixos/modules/services/misc/headphones.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let name = "headphones"; @@ -53,7 +59,6 @@ in }; }; - ###### implementation config = lib.mkIf cfg.enable { @@ -73,14 +78,14 @@ in }; systemd.services.headphones = { - description = "Headphones Server"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - serviceConfig = { - User = cfg.user; - Group = cfg.group; - ExecStart = "${pkgs.headphones}/bin/headphones --datadir ${cfg.dataDir} --config ${cfg.configFile} --host ${cfg.host} --port ${toString cfg.port}"; - }; + description = "Headphones Server"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + serviceConfig = { + User = cfg.user; + Group = cfg.group; + ExecStart = "${pkgs.headphones}/bin/headphones --datadir ${cfg.dataDir} --config ${cfg.configFile} --host ${cfg.host} --port ${toString cfg.port}"; + }; }; }; } diff --git a/nixos/modules/services/misc/heisenbridge.nix b/nixos/modules/services/misc/heisenbridge.nix index d8c5ec80e892f9..6460b90e84f15a 100644 --- a/nixos/modules/services/misc/heisenbridge.nix +++ b/nixos/modules/services/misc/heisenbridge.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.heisenbridge; @@ -9,14 +14,16 @@ let registrationFile = "/var/lib/heisenbridge/registration.yml"; # JSON is a proper subset of YAML - bridgeConfig = builtins.toFile "heisenbridge-registration.yml" (builtins.toJSON { - id = "heisenbridge"; - url = cfg.registrationUrl; - # Don't specify as_token and hs_token - rate_limited = false; - sender_localpart = "heisenbridge"; - namespaces = cfg.namespaces; - }); + bridgeConfig = builtins.toFile "heisenbridge-registration.yml" ( + builtins.toJSON { + id = "heisenbridge"; + url = cfg.registrationUrl; + # Don't specify as_token and hs_token + rate_limited = false; + sender_localpart = "heisenbridge"; + namespaces = cfg.namespaces; + } + ); in { options.services.heisenbridge = { @@ -188,18 +195,26 @@ in RemoveIPC = true; UMask = "0077"; - CapabilityBoundingSet = [ "CAP_CHOWN" ] ++ lib.optional (cfg.port < 1024 || (cfg.identd.enable && cfg.identd.port < 1024)) "CAP_NET_BIND_SERVICE"; + CapabilityBoundingSet = + [ "CAP_CHOWN" ] + ++ lib.optional ( + cfg.port < 1024 || (cfg.identd.enable && cfg.identd.port < 1024) + ) "CAP_NET_BIND_SERVICE"; AmbientCapabilities = CapabilityBoundingSet; NoNewPrivileges = true; LockPersonality = true; RestrictRealtime = true; - SystemCallFilter = ["@system-service" "~@privileged" "@chown"]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "@chown" + ]; SystemCallArchitectures = "native"; RestrictAddressFamilies = "AF_INET AF_INET6"; }; }; - users.groups.heisenbridge = {}; + users.groups.heisenbridge = { }; users.users.heisenbridge = { description = "Service user for the Heisenbridge"; group = "heisenbridge"; diff --git a/nixos/modules/services/misc/homepage-dashboard.nix b/nixos/modules/services/misc/homepage-dashboard.nix index b29a53d2f1cff5..612a88ed48b530 100644 --- a/nixos/modules/services/misc/homepage-dashboard.nix +++ b/nixos/modules/services/misc/homepage-dashboard.nix @@ -1,7 +1,8 @@ -{ config -, pkgs -, lib -, ... +{ + config, + pkgs, + lib, + ... }: let @@ -73,12 +74,26 @@ in example = [ { Developer = [ - { Github = [{ abbr = "GH"; href = "https://github.com/"; }]; } + { + Github = [ + { + abbr = "GH"; + href = "https://github.com/"; + } + ]; + } ]; } { Entertainment = [ - { YouTube = [{ abbr = "YT"; href = "https://youtube.com/"; }]; } + { + YouTube = [ + { + abbr = "YT"; + href = "https://youtube.com/"; + } + ]; + } ]; } ]; @@ -183,20 +198,22 @@ in # then default to "unmanaged" configuration which is manually updated in # var/lib/homepage-dashboard. This is to maintain backwards compatibility, and should be # deprecated in a future release. - managedConfig = !( - cfg.bookmarks == [ ] && - cfg.customCSS == "" && - cfg.customJS == "" && - cfg.docker == { } && - cfg.kubernetes == { } && - cfg.services == [ ] && - cfg.settings == { } && - cfg.widgets == [ ] - ); + managedConfig = + !( + cfg.bookmarks == [ ] + && cfg.customCSS == "" + && cfg.customJS == "" + && cfg.docker == { } + && cfg.kubernetes == { } + && cfg.services == [ ] + && cfg.settings == { } + && cfg.widgets == [ ] + ); configDir = if managedConfig then "/etc/homepage-dashboard" else "/var/lib/homepage-dashboard"; - msg = "using unmanaged configuration for homepage-dashboard is deprecated and will be removed" + msg = + "using unmanaged configuration for homepage-dashboard is deprecated and will be removed" + " in 24.05. please see the NixOS documentation for `services.homepage-dashboard' and add" + " your bookmarks, services, widgets, and other configuration using the options provided."; in @@ -209,7 +226,8 @@ in "homepage-dashboard/bookmarks.yaml".source = settingsFormat.generate "bookmarks.yaml" cfg.bookmarks; "homepage-dashboard/docker.yaml".source = settingsFormat.generate "docker.yaml" cfg.docker; - "homepage-dashboard/kubernetes.yaml".source = settingsFormat.generate "kubernetes.yaml" cfg.kubernetes; + "homepage-dashboard/kubernetes.yaml".source = + settingsFormat.generate "kubernetes.yaml" cfg.kubernetes; "homepage-dashboard/services.yaml".source = settingsFormat.generate "services.yaml" cfg.services; "homepage-dashboard/settings.yaml".source = settingsFormat.generate "settings.yaml" cfg.settings; "homepage-dashboard/widgets.yaml".source = settingsFormat.generate "widgets.yaml" cfg.widgets; diff --git a/nixos/modules/services/misc/ihaskell.nix b/nixos/modules/services/misc/ihaskell.nix index b2ea3e70dede59..b977ee124e3c73 100644 --- a/nixos/modules/services/misc/ihaskell.nix +++ b/nixos/modules/services/misc/ihaskell.nix @@ -1,4 +1,9 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: let cfg = config.services.ihaskell; @@ -19,7 +24,7 @@ in extraPackages = lib.mkOption { type = lib.types.functionTo (lib.types.listOf lib.types.package); - default = haskellPackages: []; + default = haskellPackages: [ ]; defaultText = lib.literalExpression "haskellPackages: []"; example = lib.literalExpression '' haskellPackages: [ diff --git a/nixos/modules/services/misc/input-remapper.nix b/nixos/modules/services/misc/input-remapper.nix index cf335dacb4ff11..9ab41547705a1d 100644 --- a/nixos/modules/services/misc/input-remapper.nix +++ b/nixos/modules/services/misc/input-remapper.nix @@ -1,5 +1,12 @@ -{ pkgs, lib, config, ... }: -let cfg = config.services.input-remapper; in +{ + pkgs, + lib, + config, + ... +}: +let + cfg = config.services.input-remapper; +in { options = { services.input-remapper = { diff --git a/nixos/modules/services/misc/invidious-router.nix b/nixos/modules/services/misc/invidious-router.nix index 7a90c6ab9ddc03..0300d1190f6b75 100644 --- a/nixos/modules/services/misc/invidious-router.nix +++ b/nixos/modules/services/misc/invidious-router.nix @@ -3,12 +3,14 @@ lib, pkgs, ... -}: let +}: +let cfg = config.services.invidious-router; - settingsFormat = pkgs.formats.yaml {}; + settingsFormat = pkgs.formats.yaml { }; configFile = settingsFormat.generate "config.yaml" cfg.settings; -in { - meta.maintainers = [lib.maintainers.sils]; +in +{ + meta.maintainers = [ lib.maintainers.sils ]; options.services.invidious-router = { enable = lib.mkEnableOption "the invidious-router service"; @@ -89,7 +91,7 @@ in { }; extraDomains = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Additional domains to serve invidious-router on. ''; @@ -98,7 +100,7 @@ in { }; config = lib.mkIf cfg.enable { systemd.services.invidious-router = { - wantedBy = ["multi-user.target"]; + wantedBy = [ "multi-user.target" ]; serviceConfig = { Restart = "on-failure"; ExecStart = "${lib.getExe cfg.package} --configfile ${configFile}"; diff --git a/nixos/modules/services/misc/irkerd.nix b/nixos/modules/services/misc/irkerd.nix index 28966c4ae226a0..ed99fcd871daa8 100644 --- a/nixos/modules/services/misc/irkerd.nix +++ b/nixos/modules/services/misc/irkerd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.irkerd; ports = [ 6659 ]; @@ -40,7 +45,11 @@ in config = lib.mkIf cfg.enable { systemd.services.irkerd = { description = "Internet Relay Chat (IRC) notification daemon"; - documentation = [ "man:irkerd(8)" "man:irkerhook(1)" "man:irk(1)" ]; + documentation = [ + "man:irkerd(8)" + "man:irkerhook(1)" + "man:irk(1)" + ]; after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { @@ -56,7 +65,7 @@ in isSystemUser = true; group = "irkerd"; }; - users.groups.irkerd = {}; + users.groups.irkerd = { }; networking.firewall.allowedTCPPorts = lib.mkIf cfg.openPorts ports; networking.firewall.allowedUDPPorts = lib.mkIf cfg.openPorts ports; diff --git a/nixos/modules/services/misc/jellyfin.nix b/nixos/modules/services/misc/jellyfin.nix index a0060908784228..89640b9a321189 100644 --- a/nixos/modules/services/misc/jellyfin.nix +++ b/nixos/modules/services/misc/jellyfin.nix @@ -1,7 +1,19 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let - inherit (lib) mkIf getExe maintainers mkEnableOption mkOption mkPackageOption; + inherit (lib) + mkIf + getExe + maintainers + mkEnableOption + mkOption + mkPackageOption + ; inherit (lib.types) str path bool; cfg = config.services.jellyfin; in @@ -111,13 +123,21 @@ in ExecStart = "${getExe cfg.package} --datadir '${cfg.dataDir}' --configdir '${cfg.configDir}' --cachedir '${cfg.cacheDir}' --logdir '${cfg.logDir}'"; Restart = "on-failure"; TimeoutSec = 15; - SuccessExitStatus = ["0" "143"]; + SuccessExitStatus = [ + "0" + "143" + ]; # Security options: NoNewPrivileges = true; SystemCallArchitectures = "native"; # AF_NETLINK needed because Jellyfin monitors the network connection - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" "AF_NETLINK" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + "AF_NETLINK" + ]; RestrictNamespaces = !config.boot.isContainer; RestrictRealtime = true; RestrictSUIDSGID = true; @@ -134,7 +154,21 @@ in RemoveIPC = true; SystemCallFilter = [ - "~@clock" "~@aio" "~@chown" "~@cpu-emulation" "~@debug" "~@keyring" "~@memlock" "~@module" "~@mount" "~@obsolete" "~@privileged" "~@raw-io" "~@reboot" "~@setuid" "~@swap" + "~@clock" + "~@aio" + "~@chown" + "~@cpu-emulation" + "~@debug" + "~@keyring" + "~@memlock" + "~@module" + "~@mount" + "~@obsolete" + "~@privileged" + "~@raw-io" + "~@reboot" + "~@setuid" + "~@swap" ]; SystemCallErrorNumber = "EPERM"; }; @@ -149,16 +183,25 @@ in }; users.groups = mkIf (cfg.group == "jellyfin") { - jellyfin = {}; + jellyfin = { }; }; networking.firewall = mkIf cfg.openFirewall { # from https://jellyfin.org/docs/general/networking/index.html - allowedTCPPorts = [ 8096 8920 ]; - allowedUDPPorts = [ 1900 7359 ]; + allowedTCPPorts = [ + 8096 + 8920 + ]; + allowedUDPPorts = [ + 1900 + 7359 + ]; }; }; - meta.maintainers = with maintainers; [ minijackson fsnkty ]; + meta.maintainers = with maintainers; [ + minijackson + fsnkty + ]; } diff --git a/nixos/modules/services/misc/klipper.nix b/nixos/modules/services/misc/klipper.nix index d9eef161eb727c..b2345cbf7f337f 100644 --- a/nixos/modules/services/misc/klipper.nix +++ b/nixos/modules/services/misc/klipper.nix @@ -1,11 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.klipper; format = pkgs.formats.ini { # https://github.com/NixOS/nixpkgs/pull/121613#issuecomment-885241996 - listToValue = l: - if builtins.length l == 1 then lib.generators.mkValueStringDefault { } (lib.head l) - else lib.concatMapStrings (s: "\n ${lib.generators.mkValueStringDefault {} s}") l; + listToValue = + l: + if builtins.length l == 1 then + lib.generators.mkValueStringDefault { } (lib.head l) + else + lib.concatMapStrings (s: "\n ${lib.generators.mkValueStringDefault { } s}") l; mkKeyValue = lib.generators.mkKeyValueDefault { } ":"; }; in @@ -101,8 +109,9 @@ in firmwares = lib.mkOption { description = "Firmwares klipper should manage"; default = { }; - type = with lib.types; attrsOf - (submodule { + type = + with lib.types; + attrsOf (submodule { options = { enable = lib.mkEnableOption '' building of firmware for manual flashing @@ -138,7 +147,13 @@ in message = "Option services.klipper.group is not set when services.klipper.user is specified."; } { - assertion = cfg.settings != null -> lib.foldl (a: b: a && b) true (lib.mapAttrsToList (mcu: _: mcu != null -> (lib.hasAttrByPath [ "${mcu}" "serial" ] cfg.settings)) cfg.firmwares); + assertion = + cfg.settings != null + -> lib.foldl (a: b: a && b) true ( + lib.mapAttrsToList ( + mcu: _: mcu != null -> (lib.hasAttrByPath [ "${mcu}" "serial" ] cfg.settings) + ) cfg.firmwares + ); message = "Option services.klipper.settings.$mcu.serial must be set when settings.klipper.firmware.$mcu is specified"; } { @@ -148,7 +163,8 @@ in ]; environment.etc = lib.mkIf (!cfg.mutableConfig) { - "klipper.cfg".source = if cfg.settings != null then format.generate "klipper.cfg" cfg.settings else cfg.configFile; + "klipper.cfg".source = + if cfg.settings != null then format.generate "klipper.cfg" cfg.settings else cfg.configFile; }; services.klipper = lib.mkIf cfg.octoprintIntegration { @@ -158,18 +174,14 @@ in systemd.services.klipper = let - klippyArgs = "--input-tty=${cfg.inputTTY}" + klippyArgs = + "--input-tty=${cfg.inputTTY}" + lib.optionalString (cfg.apiSocket != null) " --api-server=${cfg.apiSocket}" - + lib.optionalString (cfg.logFile != null) " --logfile=${cfg.logFile}" - ; + + lib.optionalString (cfg.logFile != null) " --logfile=${cfg.logFile}"; printerConfigPath = - if cfg.mutableConfig - then cfg.mutableConfigFolder + "/printer.cfg" - else "/etc/klipper.cfg"; + if cfg.mutableConfig then cfg.mutableConfigFolder + "/printer.cfg" else "/etc/klipper.cfg"; printerConfigFile = - if cfg.settings != null - then format.generate "klipper.cfg" cfg.settings - else cfg.configFile; + if cfg.settings != null then format.generate "klipper.cfg" cfg.settings else cfg.configFile; in { description = "Klipper 3D Printer Firmware"; @@ -186,48 +198,65 @@ in mkdir -p ${cfg.mutableConfigFolder}/gcodes ''; - serviceConfig = { - ExecStart = "${cfg.package}/bin/klippy ${klippyArgs} ${printerConfigPath}"; - RuntimeDirectory = "klipper"; - StateDirectory = "klipper"; - SupplementaryGroups = [ "dialout" ]; - WorkingDirectory = "${cfg.package}/lib"; - OOMScoreAdjust = "-999"; - CPUSchedulingPolicy = "rr"; - CPUSchedulingPriority = 99; - IOSchedulingClass = "realtime"; - IOSchedulingPriority = 0; - UMask = "0002"; - } // (if cfg.user != null then { - Group = cfg.group; - User = cfg.user; - } else { - DynamicUser = true; - User = "klipper"; - }); + serviceConfig = + { + ExecStart = "${cfg.package}/bin/klippy ${klippyArgs} ${printerConfigPath}"; + RuntimeDirectory = "klipper"; + StateDirectory = "klipper"; + SupplementaryGroups = [ "dialout" ]; + WorkingDirectory = "${cfg.package}/lib"; + OOMScoreAdjust = "-999"; + CPUSchedulingPolicy = "rr"; + CPUSchedulingPriority = 99; + IOSchedulingClass = "realtime"; + IOSchedulingPriority = 0; + UMask = "0002"; + } + // ( + if cfg.user != null then + { + Group = cfg.group; + User = cfg.user; + } + else + { + DynamicUser = true; + User = "klipper"; + } + ); }; environment.systemPackages = with pkgs; let default = a: b: if a != null then a else b; - firmwares = lib.filterAttrs (n: v: v != null) (lib.mapAttrs - (mcu: { enable, enableKlipperFlash, configFile, serial }: + firmwares = lib.filterAttrs (n: v: v != null) ( + lib.mapAttrs ( + mcu: + { + enable, + enableKlipperFlash, + configFile, + serial, + }: if enable then - pkgs.klipper-firmware.override - { - mcu = lib.strings.sanitizeDerivationName mcu; - firmwareConfig = configFile; - } else null) - cfg.firmwares); - firmwareFlasher = lib.mapAttrsToList - (mcu: firmware: pkgs.klipper-flash.override { + pkgs.klipper-firmware.override { + mcu = lib.strings.sanitizeDerivationName mcu; + firmwareConfig = configFile; + } + else + null + ) cfg.firmwares + ); + firmwareFlasher = lib.mapAttrsToList ( + mcu: firmware: + pkgs.klipper-flash.override { mcu = lib.strings.sanitizeDerivationName mcu; klipper-firmware = firmware; flashDevice = default cfg.firmwares."${mcu}".serial cfg.settings."${mcu}".serial; firmwareConfig = cfg.firmwares."${mcu}".configFile; - }) - (lib.filterAttrs (mcu: firmware: cfg.firmwares."${mcu}".enableKlipperFlash) firmwares); + } + ) (lib.filterAttrs (mcu: firmware: cfg.firmwares."${mcu}".enableKlipperFlash) firmwares); in [ klipper-genconf ] ++ firmwareFlasher ++ lib.attrValues firmwares; }; diff --git a/nixos/modules/services/misc/languagetool.nix b/nixos/modules/services/misc/languagetool.nix index c1bc2c1958a262..feb2d0d90f9dbd 100644 --- a/nixos/modules/services/misc/languagetool.nix +++ b/nixos/modules/services/misc/languagetool.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.languagetool; settingsFormat = pkgs.formats.javaProperties { }; @@ -42,7 +47,7 @@ in description = "Number of sentences cached."; }; }; - default = {}; + default = { }; description = '' Configuration file options for LanguageTool, see 'languagetool-http-server --help' @@ -77,7 +82,10 @@ in Group = "languagetool"; CapabilityBoundingSet = [ "" ]; RestrictNamespaces = [ "" ]; - SystemCallFilter = [ "@system-service" "~ @privileged" ]; + SystemCallFilter = [ + "@system-service" + "~ @privileged" + ]; ProtectHome = "yes"; Restart = "on-failure"; ExecStart = '' diff --git a/nixos/modules/services/misc/leaps.nix b/nixos/modules/services/misc/leaps.nix index 10d332fb74ad69..a62ce86ada8f0c 100644 --- a/nixos/modules/services/misc/leaps.nix +++ b/nixos/modules/services/misc/leaps.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.leaps; stateDir = "/var/lib/leaps/"; @@ -29,11 +34,11 @@ in config = lib.mkIf cfg.enable { users = { users.leaps = { - uid = config.ids.uids.leaps; - description = "Leaps server user"; - group = "leaps"; - home = stateDir; - createHome = true; + uid = config.ids.uids.leaps; + description = "Leaps server user"; + group = "leaps"; + home = stateDir; + createHome = true; }; groups.leaps = { @@ -42,9 +47,9 @@ in }; systemd.services.leaps = { - description = "leaps service"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + description = "leaps service"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; serviceConfig = { User = "leaps"; diff --git a/nixos/modules/services/misc/lidarr.nix b/nixos/modules/services/misc/lidarr.nix index fd94f6536b22de..1ca0697205b55e 100644 --- a/nixos/modules/services/misc/lidarr.nix +++ b/nixos/modules/services/misc/lidarr.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.lidarr; in diff --git a/nixos/modules/services/misc/lifecycled.nix b/nixos/modules/services/misc/lifecycled.nix index c58b4f7525f534..0f4df5d02b6425 100644 --- a/nixos/modules/services/misc/lifecycled.nix +++ b/nixos/modules/services/misc/lifecycled.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.lifecycled; @@ -8,8 +13,12 @@ let # systemd.services.lifecycled.serviceConfig.Environment configFile = pkgs.writeText "lifecycled" '' LIFECYCLED_HANDLER=${cfg.handler} - ${lib.optionalString (cfg.cloudwatchGroup != null) "LIFECYCLED_CLOUDWATCH_GROUP=${cfg.cloudwatchGroup}"} - ${lib.optionalString (cfg.cloudwatchStream != null) "LIFECYCLED_CLOUDWATCH_STREAM=${cfg.cloudwatchStream}"} + ${lib.optionalString ( + cfg.cloudwatchGroup != null + ) "LIFECYCLED_CLOUDWATCH_GROUP=${cfg.cloudwatchGroup}"} + ${lib.optionalString ( + cfg.cloudwatchStream != null + ) "LIFECYCLED_CLOUDWATCH_STREAM=${cfg.cloudwatchStream}"} ${lib.optionalString cfg.debug "LIFECYCLED_DEBUG=${lib.boolToString cfg.debug}"} ${lib.optionalString (cfg.instanceId != null) "LIFECYCLED_INSTANCE_ID=${cfg.instanceId}"} ${lib.optionalString cfg.json "LIFECYCLED_JSON=${lib.boolToString cfg.json}"} @@ -19,7 +28,10 @@ let ''; in { - meta.maintainers = with lib.maintainers; [ cole-h grahamc ]; + meta.maintainers = with lib.maintainers; [ + cole-h + grahamc + ]; options = { services.lifecycled = { diff --git a/nixos/modules/services/misc/llama-cpp.nix b/nixos/modules/services/misc/llama-cpp.nix index 2fa1a7b28e3b12..90d6cedda0f97d 100644 --- a/nixos/modules/services/misc/llama-cpp.nix +++ b/nixos/modules/services/misc/llama-cpp.nix @@ -1,8 +1,15 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.services.llama-cpp; -in { +in +{ options = { @@ -20,8 +27,15 @@ in { extraFlags = lib.mkOption { type = lib.types.listOf lib.types.str; description = "Extra flags passed to llama-cpp-server."; - example = ["-c" "4096" "-ngl" "32" "--numa" "numactl"]; - default = []; + example = [ + "-c" + "4096" + "-ngl" + "32" + "--numa" + "numactl" + ]; + default = [ ]; }; host = lib.mkOption { @@ -50,8 +64,8 @@ in { systemd.services.llama-cpp = { description = "LLaMA C++ server"; - after = ["network.target"]; - wantedBy = ["multi-user.target"]; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; serviceConfig = { Type = "idle"; diff --git a/nixos/modules/services/misc/logkeys.nix b/nixos/modules/services/misc/logkeys.nix index 428ce626b715b8..2e2bd42c025012 100644 --- a/nixos/modules/services/misc/logkeys.nix +++ b/nixos/modules/services/misc/logkeys.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.logkeys; -in { +in +{ options.services.logkeys = { enable = lib.mkEnableOption "logkeys, a keylogger service"; @@ -18,7 +24,9 @@ in { description = "LogKeys Keylogger Daemon"; wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart = "${pkgs.logkeys}/bin/logkeys -s${lib.optionalString (cfg.device != null) " -d ${cfg.device}"}"; + ExecStart = "${pkgs.logkeys}/bin/logkeys -s${ + lib.optionalString (cfg.device != null) " -d ${cfg.device}" + }"; ExecStop = "${pkgs.logkeys}/bin/logkeys -k"; Type = "forking"; }; diff --git a/nixos/modules/services/misc/mame.nix b/nixos/modules/services/misc/mame.nix index ed98ef3ed8a64f..378ec6d6132f33 100644 --- a/nixos/modules/services/misc/mame.nix +++ b/nixos/modules/services/misc/mame.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.mame; mame = "mame${lib.optionalString pkgs.stdenv.hostPlatform.is64bit "64"}"; diff --git a/nixos/modules/services/misc/mbpfan.nix b/nixos/modules/services/misc/mbpfan.nix index 3061f68bb6e287..54981fa09d04bc 100644 --- a/nixos/modules/services/misc/mbpfan.nix +++ b/nixos/modules/services/misc/mbpfan.nix @@ -1,14 +1,20 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.mbpfan; verbose = lib.optionalString cfg.verbose "v"; - format = pkgs.formats.ini {}; + format = pkgs.formats.ini { }; cfgfile = format.generate "mbpfan.ini" cfg.settings; -in { +in +{ options.services.mbpfan = { enable = lib.mkEnableOption "mbpfan, fan controller daemon for Apple Macs and MacBooks"; - package = lib.mkPackageOption pkgs "mbpfan" {}; + package = lib.mkPackageOption pkgs "mbpfan" { }; verbose = lib.mkOption { type = lib.types.bool; @@ -23,7 +29,7 @@ in { }; settings = lib.mkOption { - default = {}; + default = { }; description = "INI configuration for Mbpfan."; type = lib.types.submodule { freeformType = format.type; @@ -56,16 +62,37 @@ in { }; imports = [ - (lib.mkRenamedOptionModule [ "services" "mbpfan" "pollingInterval" ] [ "services" "mbpfan" "settings" "general" "polling_interval" ]) - (lib.mkRenamedOptionModule [ "services" "mbpfan" "maxTemp" ] [ "services" "mbpfan" "settings" "general" "max_temp" ]) - (lib.mkRenamedOptionModule [ "services" "mbpfan" "lowTemp" ] [ "services" "mbpfan" "settings" "general" "low_temp" ]) - (lib.mkRenamedOptionModule [ "services" "mbpfan" "highTemp" ] [ "services" "mbpfan" "settings" "general" "high_temp" ]) - (lib.mkRenamedOptionModule [ "services" "mbpfan" "minFanSpeed" ] [ "services" "mbpfan" "settings" "general" "min_fan1_speed" ]) - (lib.mkRenamedOptionModule [ "services" "mbpfan" "maxFanSpeed" ] [ "services" "mbpfan" "settings" "general" "max_fan1_speed" ]) + (lib.mkRenamedOptionModule + [ "services" "mbpfan" "pollingInterval" ] + [ "services" "mbpfan" "settings" "general" "polling_interval" ] + ) + (lib.mkRenamedOptionModule + [ "services" "mbpfan" "maxTemp" ] + [ "services" "mbpfan" "settings" "general" "max_temp" ] + ) + (lib.mkRenamedOptionModule + [ "services" "mbpfan" "lowTemp" ] + [ "services" "mbpfan" "settings" "general" "low_temp" ] + ) + (lib.mkRenamedOptionModule + [ "services" "mbpfan" "highTemp" ] + [ "services" "mbpfan" "settings" "general" "high_temp" ] + ) + (lib.mkRenamedOptionModule + [ "services" "mbpfan" "minFanSpeed" ] + [ "services" "mbpfan" "settings" "general" "min_fan1_speed" ] + ) + (lib.mkRenamedOptionModule + [ "services" "mbpfan" "maxFanSpeed" ] + [ "services" "mbpfan" "settings" "general" "max_fan1_speed" ] + ) ]; config = lib.mkIf cfg.enable { - boot.kernelModules = [ "coretemp" "applesmc" ]; + boot.kernelModules = [ + "coretemp" + "applesmc" + ]; environment.systemPackages = [ cfg.package ]; environment.etc."mbpfan.conf".source = cfgfile; diff --git a/nixos/modules/services/misc/mediatomb.nix b/nixos/modules/services/misc/mediatomb.nix index ae9d1fa31be213..eac446817ae797 100644 --- a/nixos/modules/services/misc/mediatomb.nix +++ b/nixos/modules/services/misc/mediatomb.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let gid = config.ids.gids.mediatomb; @@ -28,166 +34,177 @@ let }; }; }; - toMediaDirectory = d: "\n"; - - transcodingConfig = if cfg.transcoding then with pkgs; '' - - - - - - - - - audio/mpeg - no - yes - no - - - - - video/mpeg - yes - yes - yes - - - - - -'' else '' - - -''; - - configText = lib.optionalString (! cfg.customCfg) '' - - - - - - - - - ${cfg.serverName} - uuid:${cfg.uuid} - ${cfg.dataDir} - ${cfg.interface} - ${pkg}/share/${name}/web - - - - ${name}.db - - - - ${lib.optionalString cfg.dsmSupport '' - - - - - redsonic.com - 105 - ''} - ${lib.optionalString cfg.tg100Support '' - 101 - ''} - - - * - - video - - - - - - - ${lib.concatMapStrings toMediaDirectory cfg.mediaDirectories} - - - ${pkg}/share/${name}/js/common.js - ${pkg}/share/${name}/js/playlists.js - - ${pkg}/share/${name}/js/import.js - - - - - - - - - - - - - - - - - - - - - - - - ${lib.optionalString cfg.ps3Support '' - - ''} + toMediaDirectory = + d: + "\n"; + + transcodingConfig = + if cfg.transcoding then + with pkgs; + '' + + + + + + + + + audio/mpeg + no + yes + no + + + + + video/mpeg + yes + yes + yes + + + + + + '' + else + '' + + + ''; + + configText = lib.optionalString (!cfg.customCfg) '' + + + + + + + + + ${cfg.serverName} + uuid:${cfg.uuid} + ${cfg.dataDir} + ${cfg.interface} + ${pkg}/share/${name}/web + + + + ${name}.db + + + ${lib.optionalString cfg.dsmSupport '' - + + + + + redsonic.com + 105 ''} - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ${transcodingConfig} - -''; + ${lib.optionalString cfg.tg100Support '' + 101 + ''} + + + * + + video + + + + + + + ${lib.concatMapStrings toMediaDirectory cfg.mediaDirectories} + + + ${pkg}/share/${name}/js/common.js + ${pkg}/share/${name}/js/playlists.js + + ${pkg}/share/${name}/js/import.js + + + + + + + + + + + + + + + + + + + + + + + + ${lib.optionalString cfg.ps3Support '' + + ''} + ${lib.optionalString cfg.dsmSupport '' + + ''} + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ${transcodingConfig} + + ''; defaultFirewallRules = { # udp 1900 port needs to be opened for SSDP (not configurable within # mediatomb/gerbera) cf. # https://docs.gerbera.io/en/latest/run.html?highlight=udp%20port#network-setup - allowedUDPPorts = [ 1900 cfg.port ]; + allowedUDPPorts = [ + 1900 + cfg.port + ]; allowedTCPPorts = [ cfg.port ]; }; -in { +in +{ ###### interface @@ -316,13 +333,21 @@ in { mediaDirectories = lib.mkOption { type = with lib.types; listOf (submodule mediaDirectory); - default = []; + default = [ ]; description = '' Declare media directories to index. ''; example = [ - { path = "/data/pictures"; recursive = false; hidden-files = false; } - { path = "/data/audio"; recursive = true; hidden-files = false; } + { + path = "/data/pictures"; + recursive = false; + hidden-files = false; + } + { + path = "/data/audio"; + recursive = true; + hidden-files = false; + } ]; }; @@ -342,45 +367,52 @@ in { }; }; - ###### implementation - config = let binaryCommand = "${pkg}/bin/${name}"; - interfaceFlag = lib.optionalString ( cfg.interface != "") "--interface ${cfg.interface}"; - configFlag = lib.optionalString (! cfg.customCfg) "--config ${pkgs.writeText "config.xml" configText}"; - in lib.mkIf cfg.enable { - systemd.services.mediatomb = { - description = "${cfg.serverName} media Server"; - # Gerbera might fail if the network interface is not available on startup - # https://github.com/gerbera/gerbera/issues/1324 - wants = [ "network-online.target" ]; - after = [ "network.target" "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; - serviceConfig.ExecStart = "${binaryCommand} --port ${toString cfg.port} ${interfaceFlag} ${configFlag} --home ${cfg.dataDir}"; - serviceConfig.User = cfg.user; - serviceConfig.Group = cfg.group; - }; + config = + let + binaryCommand = "${pkg}/bin/${name}"; + interfaceFlag = lib.optionalString (cfg.interface != "") "--interface ${cfg.interface}"; + configFlag = lib.optionalString ( + !cfg.customCfg + ) "--config ${pkgs.writeText "config.xml" configText}"; + in + lib.mkIf cfg.enable { + systemd.services.mediatomb = { + description = "${cfg.serverName} media Server"; + # Gerbera might fail if the network interface is not available on startup + # https://github.com/gerbera/gerbera/issues/1324 + wants = [ "network-online.target" ]; + after = [ + "network.target" + "network-online.target" + ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig.ExecStart = "${binaryCommand} --port ${toString cfg.port} ${interfaceFlag} ${configFlag} --home ${cfg.dataDir}"; + serviceConfig.User = cfg.user; + serviceConfig.Group = cfg.group; + }; - users.groups = lib.optionalAttrs (cfg.group == "mediatomb") { - mediatomb.gid = gid; - }; + users.groups = lib.optionalAttrs (cfg.group == "mediatomb") { + mediatomb.gid = gid; + }; - users.users = lib.optionalAttrs (cfg.user == "mediatomb") { - mediatomb = { - isSystemUser = true; - group = cfg.group; - home = cfg.dataDir; - createHome = true; - description = "${name} DLNA Server User"; + users.users = lib.optionalAttrs (cfg.user == "mediatomb") { + mediatomb = { + isSystemUser = true; + group = cfg.group; + home = cfg.dataDir; + createHome = true; + description = "${name} DLNA Server User"; + }; }; - }; - # Open firewall only if users enable it - networking.firewall = lib.mkMerge [ - (lib.mkIf (cfg.openFirewall && cfg.interface != "") { - interfaces."${cfg.interface}" = defaultFirewallRules; - }) - (lib.mkIf (cfg.openFirewall && cfg.interface == "") defaultFirewallRules) - ]; - }; + # Open firewall only if users enable it + networking.firewall = lib.mkMerge [ + (lib.mkIf (cfg.openFirewall && cfg.interface != "") { + interfaces."${cfg.interface}" = defaultFirewallRules; + }) + (lib.mkIf (cfg.openFirewall && cfg.interface == "") defaultFirewallRules) + ]; + }; } diff --git a/nixos/modules/services/misc/mollysocket.nix b/nixos/modules/services/misc/mollysocket.nix index 460e8aa05266b2..9f733612578b0f 100644 --- a/nixos/modules/services/misc/mollysocket.nix +++ b/nixos/modules/services/misc/mollysocket.nix @@ -1,7 +1,18 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) getExe mkIf mkOption mkEnableOption types; + inherit (lib) + getExe + mkIf + mkOption + mkEnableOption + types + ; cfg = config.services.mollysocket; configuration = format.generate "mollysocket.conf" cfg.settings; @@ -9,7 +20,8 @@ let package = pkgs.writeShellScriptBin "mollysocket" '' MOLLY_CONF=${configuration} exec ${getExe pkgs.mollysocket} "$@" ''; -in { +in +{ options.services.mollysocket = { enable = mkEnableOption '' [MollySocket](https://github.com/mollyim/mollysocket) for getting Signal @@ -114,12 +126,19 @@ in { ProtectProc = "invisible"; ProtectSystem = "strict"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@resources" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@resources" + "~@privileged" + ]; UMask = "0077"; }; }; diff --git a/nixos/modules/services/misc/moonraker.nix b/nixos/modules/services/misc/moonraker.nix index b9ddace19e9153..620eb71bd74f0a 100644 --- a/nixos/modules/services/misc/moonraker.nix +++ b/nixos/modules/services/misc/moonraker.nix @@ -1,18 +1,28 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.moonraker; pkg = cfg.package; opt = options.services.moonraker; format = pkgs.formats.ini { # https://github.com/NixOS/nixpkgs/pull/121613#issuecomment-885241996 - listToValue = l: - if builtins.length l == 1 then lib.generators.mkValueStringDefault {} (lib.head l) - else lib.concatMapStrings (s: "\n ${lib.generators.mkValueStringDefault {} s}") l; - mkKeyValue = lib.generators.mkKeyValueDefault {} ":"; + listToValue = + l: + if builtins.length l == 1 then + lib.generators.mkValueStringDefault { } (lib.head l) + else + lib.concatMapStrings (s: "\n ${lib.generators.mkValueStringDefault { } s}") l; + mkKeyValue = lib.generators.mkKeyValueDefault { } ":"; }; unifiedConfigDir = cfg.stateDir + "/config"; -in { +in +{ options = { services.moonraker = { enable = lib.mkEnableOption "Moonraker, an API web server for Klipper"; @@ -76,7 +86,10 @@ in { example = { authorization = { trusted_clients = [ "10.0.0.0/24" ]; - cors_domains = [ "https://app.fluidd.xyz" "https://my.mainsail.xyz" ]; + cors_domains = [ + "https://app.fluidd.xyz" + "https://my.mainsail.xyz" + ]; }; }; description = '' @@ -101,19 +114,21 @@ in { }; config = lib.mkIf cfg.enable { - warnings = [] - ++ (lib.optional (lib.head (cfg.settings.update_manager.enable_system_updates or [false])) '' + warnings = + [ ] + ++ (lib.optional (lib.head (cfg.settings.update_manager.enable_system_updates or [ false ])) '' Enabling system updates is not supported on NixOS and will lead to non-removable warnings in some clients. '') ++ (lib.optional (cfg.configDir != null) '' services.moonraker.configDir has been deprecated upstream and will be removed. Action: ${ - if cfg.configDir == unifiedConfigDir - then "Simply remove services.moonraker.configDir from your config." - else "Move files from `${cfg.configDir}` to `${unifiedConfigDir}` then remove services.moonraker.configDir from your config." + if cfg.configDir == unifiedConfigDir then + "Simply remove services.moonraker.configDir from your config." + else + "Move files from `${cfg.configDir}` to `${unifiedConfigDir}` then remove services.moonraker.configDir from your config." } - ''); + ''); assertions = [ { @@ -133,23 +148,27 @@ in { moonraker.gid = config.ids.gids.moonraker; }; - environment.etc."moonraker.cfg".source = let - forcedConfig = { - server = { - host = cfg.address; - port = cfg.port; - klippy_uds_address = cfg.klipperSocket; - }; - machine = { - validate_service = false; - }; - } // (lib.optionalAttrs (cfg.configDir != null) { - file_manager = { - config_path = cfg.configDir; - }; - }); - fullConfig = lib.recursiveUpdate cfg.settings forcedConfig; - in format.generate "moonraker.cfg" fullConfig; + environment.etc."moonraker.cfg".source = + let + forcedConfig = + { + server = { + host = cfg.address; + port = cfg.port; + klippy_uds_address = cfg.klipperSocket; + }; + machine = { + validate_service = false; + }; + } + // (lib.optionalAttrs (cfg.configDir != null) { + file_manager = { + config_path = cfg.configDir; + }; + }); + fullConfig = lib.recursiveUpdate cfg.settings forcedConfig; + in + format.generate "moonraker.cfg" fullConfig; systemd.tmpfiles.rules = [ "d '${cfg.stateDir}' - ${cfg.user} ${cfg.group} - -" @@ -158,16 +177,17 @@ in { systemd.services.moonraker = { description = "Moonraker, an API web server for Klipper"; wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ] - ++ lib.optional config.services.klipper.enable "klipper.service"; + after = [ "network.target" ] ++ lib.optional config.services.klipper.enable "klipper.service"; # Moonraker really wants its own config to be writable... script = '' config_path=${ # Deprecated separate config dir - if cfg.configDir != null then "${cfg.configDir}/moonraker-temp.cfg" + if cfg.configDir != null then + "${cfg.configDir}/moonraker-temp.cfg" # Config in unified data path - else "${unifiedConfigDir}/moonraker-temp.cfg" + else + "${unifiedConfigDir}/moonraker-temp.cfg" } mkdir -p $(dirname "$config_path") cp /etc/moonraker.cfg "$config_path" diff --git a/nixos/modules/services/misc/mqtt2influxdb.nix b/nixos/modules/services/misc/mqtt2influxdb.nix index cefe7acbba2fb0..6e54fb05839b60 100644 --- a/nixos/modules/services/misc/mqtt2influxdb.nix +++ b/nixos/modules/services/misc/mqtt2influxdb.nix @@ -7,12 +7,10 @@ let cfg = config.services.mqtt2influxdb; filterNull = lib.filterAttrsRecursive (n: v: v != null); - configFile = (pkgs.formats.yaml {}).generate "mqtt2influxdb.config.yaml" ( - filterNull { - inherit (cfg) mqtt influxdb; - points = map filterNull cfg.points; - } - ); + configFile = (pkgs.formats.yaml { }).generate "mqtt2influxdb.config.yaml" (filterNull { + inherit (cfg) mqtt influxdb; + points = map filterNull cfg.points; + }); pointType = lib.types.submodule { options = { @@ -43,7 +41,7 @@ let }; tags = lib.mkOption { type = with lib.types; attrsOf str; - default = {}; + default = { }; description = "Tags applied"; }; }; @@ -118,14 +116,15 @@ let }; } ]; -in { +in +{ options = { services.mqtt2influxdb = { enable = lib.mkEnableOption "BigClown MQTT to InfluxDB bridge"; - package = lib.mkPackageOption pkgs ["python3Packages" "mqtt2influxdb"] {}; + package = lib.mkPackageOption pkgs [ "python3Packages" "mqtt2influxdb" ] { }; environmentFiles = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; example = [ "/run/keys/mqtt2influxdb.env" ]; description = '' File to load as environment file. Environment variables from this file @@ -206,7 +205,7 @@ in { It is highly suggested to use here replacement through environmentFiles as otherwise the password is put world readable to the store. - ''; + ''; }; ssl = lib.mkOption { type = lib.types.bool; @@ -228,24 +227,24 @@ in { }; config = lib.mkIf cfg.enable { - systemd.services.bigclown-mqtt2influxdb = let - envConfig = cfg.environmentFiles != []; - finalConfig = if envConfig - then "$RUNTIME_DIRECTORY/mqtt2influxdb.config.yaml" - else configFile; - in { - description = "BigClown MQTT to InfluxDB bridge"; - wantedBy = ["multi-user.target"]; - wants = lib.mkIf config.services.mosquitto.enable ["mosquitto.service"]; - preStart = '' - umask 077 - ${pkgs.envsubst}/bin/envsubst -i "${configFile}" -o "${finalConfig}" - ''; - serviceConfig = { - EnvironmentFile = cfg.environmentFiles; - ExecStart = "${lib.getExe cfg.package} -dc ${finalConfig}"; - RuntimeDirectory = "mqtt2influxdb"; + systemd.services.bigclown-mqtt2influxdb = + let + envConfig = cfg.environmentFiles != [ ]; + finalConfig = if envConfig then "$RUNTIME_DIRECTORY/mqtt2influxdb.config.yaml" else configFile; + in + { + description = "BigClown MQTT to InfluxDB bridge"; + wantedBy = [ "multi-user.target" ]; + wants = lib.mkIf config.services.mosquitto.enable [ "mosquitto.service" ]; + preStart = '' + umask 077 + ${pkgs.envsubst}/bin/envsubst -i "${configFile}" -o "${finalConfig}" + ''; + serviceConfig = { + EnvironmentFile = cfg.environmentFiles; + ExecStart = "${lib.getExe cfg.package} -dc ${finalConfig}"; + RuntimeDirectory = "mqtt2influxdb"; + }; }; - }; }; } diff --git a/nixos/modules/services/misc/n8n.nix b/nixos/modules/services/misc/n8n.nix index 623c9a3be8a925..f3e9f698e35fa5 100644 --- a/nixos/modules/services/misc/n8n.nix +++ b/nixos/modules/services/misc/n8n.nix @@ -1,7 +1,12 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.n8n; - format = pkgs.formats.json {}; + format = pkgs.formats.json { }; configFile = format.generate "n8n.json" cfg.settings; in { @@ -16,7 +21,7 @@ in settings = lib.mkOption { type = format.type; - default = {}; + default = { }; description = '' Configuration for n8n, see for supported values. diff --git a/nixos/modules/services/misc/nitter.nix b/nixos/modules/services/misc/nitter.nix index 40a4b157aee110..65aea391bcb52e 100644 --- a/nixos/modules/services/misc/nitter.nix +++ b/nixos/modules/services/misc/nitter.nix @@ -1,26 +1,41 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.nitter; configFile = pkgs.writeText "nitter.conf" '' - ${lib.generators.toINI { - # String values need to be quoted - mkKeyValue = lib.generators.mkKeyValueDefault { - mkValueString = v: - if lib.isString v then "\"" + (lib.escape ["\""] (toString v)) + "\"" - else lib.generators.mkValueStringDefault {} v; - } " = "; - } (lib.recursiveUpdate { - Server = cfg.server; - Cache = cfg.cache; - Config = cfg.config // { hmacKey = "@hmac@"; }; - Preferences = cfg.preferences; - } cfg.settings)} + ${lib.generators.toINI + { + # String values need to be quoted + mkKeyValue = lib.generators.mkKeyValueDefault { + mkValueString = + v: + if lib.isString v then + "\"" + (lib.escape [ "\"" ] (toString v)) + "\"" + else + lib.generators.mkValueStringDefault { } v; + } " = "; + } + ( + lib.recursiveUpdate { + Server = cfg.server; + Cache = cfg.cache; + Config = cfg.config // { + hmacKey = "@hmac@"; + }; + Preferences = cfg.preferences; + } cfg.settings + ) + } ''; # `hmac` is a secret used for cryptographic signing of video URLs. # Generate it on first launch, then copy configuration and replace # `@hmac@` with this value. # We are not using sed as it would leak the value in the command line. - preStart = pkgs.writers.writePython3 "nitter-prestart" {} '' + preStart = pkgs.writers.writePython3 "nitter-prestart" { } '' import os import secrets @@ -44,7 +59,11 @@ in { imports = [ # https://github.com/zedeus/nitter/pull/772 - (lib.mkRemovedOptionModule [ "services" "nitter" "replaceInstagram" ] "Nitter no longer supports this option as Bibliogram has been discontinued.") + (lib.mkRemovedOptionModule [ + "services" + "nitter" + "replaceInstagram" + ] "Nitter no longer supports this option as Bibliogram has been discontinued.") ]; options = { @@ -55,7 +74,7 @@ in server = { address = lib.mkOption { - type = lib.types.str; + type = lib.types.str; default = "0.0.0.0"; example = "127.0.0.1"; description = "The address to listen on."; @@ -152,7 +171,9 @@ in description = "Use base64 encoding for proxied media URLs."; }; - enableRSS = lib.mkEnableOption "RSS feeds" // { default = true; }; + enableRSS = lib.mkEnableOption "RSS feeds" // { + default = true; + }; enableDebug = lib.mkEnableOption "request logs and debug endpoints"; @@ -292,7 +313,7 @@ in settings = lib.mkOption { type = lib.types.attrs; - default = {}; + default = { }; description = '' Add settings here to override NixOS module generated settings. @@ -335,58 +356,66 @@ in config = lib.mkIf cfg.enable { assertions = [ { - assertion = !cfg.redisCreateLocally || (cfg.cache.redisHost == "localhost" && cfg.cache.redisPort == 6379); + assertion = + !cfg.redisCreateLocally || (cfg.cache.redisHost == "localhost" && cfg.cache.redisPort == 6379); message = "When services.nitter.redisCreateLocally is enabled, you need to use localhost:6379 as a cache server."; } ]; systemd.services.nitter = { - description = "Nitter (An alternative Twitter front-end)"; - wantedBy = [ "multi-user.target" ]; - wants = [ "network-online.target" ]; - after = [ "network-online.target" ]; - serviceConfig = { - DynamicUser = true; - LoadCredential="guestAccountsFile:${cfg.guestAccounts}"; - StateDirectory = "nitter"; - Environment = [ - "NITTER_CONF_FILE=/var/lib/nitter/nitter.conf" - "NITTER_ACCOUNTS_FILE=%d/guestAccountsFile" - ]; - # Some parts of Nitter expect `public` folder in working directory, - # see https://github.com/zedeus/nitter/issues/414 - WorkingDirectory = "${cfg.package}/share/nitter"; - ExecStart = "${cfg.package}/bin/nitter"; - ExecStartPre = "${preStart}"; - AmbientCapabilities = lib.mkIf (cfg.server.port < 1024) [ "CAP_NET_BIND_SERVICE" ]; - Restart = "on-failure"; - RestartSec = "5s"; - # Hardening - CapabilityBoundingSet = if (cfg.server.port < 1024) then [ "CAP_NET_BIND_SERVICE" ] else [ "" ]; - DeviceAllow = [ "" ]; - LockPersonality = true; - MemoryDenyWriteExecute = true; - PrivateDevices = true; - # A private user cannot have process capabilities on the host's user - # namespace and thus CAP_NET_BIND_SERVICE has no effect. - PrivateUsers = (cfg.server.port >= 1024); - ProcSubset = "pid"; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" "~@resources" ]; - UMask = "0077"; - }; + description = "Nitter (An alternative Twitter front-end)"; + wantedBy = [ "multi-user.target" ]; + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; + serviceConfig = { + DynamicUser = true; + LoadCredential = "guestAccountsFile:${cfg.guestAccounts}"; + StateDirectory = "nitter"; + Environment = [ + "NITTER_CONF_FILE=/var/lib/nitter/nitter.conf" + "NITTER_ACCOUNTS_FILE=%d/guestAccountsFile" + ]; + # Some parts of Nitter expect `public` folder in working directory, + # see https://github.com/zedeus/nitter/issues/414 + WorkingDirectory = "${cfg.package}/share/nitter"; + ExecStart = "${cfg.package}/bin/nitter"; + ExecStartPre = "${preStart}"; + AmbientCapabilities = lib.mkIf (cfg.server.port < 1024) [ "CAP_NET_BIND_SERVICE" ]; + Restart = "on-failure"; + RestartSec = "5s"; + # Hardening + CapabilityBoundingSet = if (cfg.server.port < 1024) then [ "CAP_NET_BIND_SERVICE" ] else [ "" ]; + DeviceAllow = [ "" ]; + LockPersonality = true; + MemoryDenyWriteExecute = true; + PrivateDevices = true; + # A private user cannot have process capabilities on the host's user + # namespace and thus CAP_NET_BIND_SERVICE has no effect. + PrivateUsers = (cfg.server.port >= 1024); + ProcSubset = "pid"; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "~@resources" + ]; + UMask = "0077"; + }; }; services.redis.servers.nitter = lib.mkIf (cfg.redisCreateLocally) { diff --git a/nixos/modules/services/misc/nix-gc.nix b/nixos/modules/services/misc/nix-gc.nix index 69b25d6ae648ec..56d176d81d36a3 100644 --- a/nixos/modules/services/misc/nix-gc.nix +++ b/nixos/modules/services/misc/nix-gc.nix @@ -72,7 +72,6 @@ in }; - ###### implementation config = { diff --git a/nixos/modules/services/misc/nix-ssh-serve.nix b/nixos/modules/services/misc/nix-ssh-serve.nix index b0ccf495c7eb06..b27ef03dae6f4e 100644 --- a/nixos/modules/services/misc/nix-ssh-serve.nix +++ b/nixos/modules/services/misc/nix-ssh-serve.nix @@ -1,10 +1,18 @@ -{ config, lib, pkgs, ... }: -let cfg = config.nix.sshServe; - command = - if cfg.protocol == "ssh" - then "nix-store --serve ${lib.optionalString cfg.write "--write"}" - else "nix-daemon --stdio"; -in { +{ + config, + lib, + pkgs, + ... +}: +let + cfg = config.nix.sshServe; + command = + if cfg.protocol == "ssh" then + "nix-store --serve ${lib.optionalString cfg.write "--write"}" + else + "nix-daemon --stdio"; +in +{ options = { nix.sshServe = { @@ -23,13 +31,16 @@ in { keys = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = [ "ssh-dss AAAAB3NzaC1k... alice@example.org" ]; description = "A list of SSH public keys allowed to access the binary cache via SSH."; }; protocol = lib.mkOption { - type = lib.types.enum [ "ssh" "ssh-ng" ]; + type = lib.types.enum [ + "ssh" + "ssh-ng" + ]; default = "ssh"; description = "The specific Nix-over-SSH protocol to use."; }; @@ -46,7 +57,7 @@ in { group = "nix-ssh"; shell = pkgs.bashInteractive; }; - users.groups.nix-ssh = {}; + users.groups.nix-ssh = { }; services.openssh.enable = true; diff --git a/nixos/modules/services/misc/novacomd.nix b/nixos/modules/services/misc/novacomd.nix index 52423ff0668f63..c8c13df0b6cd8c 100644 --- a/nixos/modules/services/misc/novacomd.nix +++ b/nixos/modules/services/misc/novacomd.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.novacomd; -in { +in +{ options = { services.novacomd = { diff --git a/nixos/modules/services/misc/nzbget.nix b/nixos/modules/services/misc/nzbget.nix index 4738baf6d3e5c2..3891486311f153 100644 --- a/nixos/modules/services/misc/nzbget.nix +++ b/nixos/modules/services/misc/nzbget.nix @@ -1,20 +1,44 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.nzbget; stateDir = "/var/lib/nzbget"; configFile = "${stateDir}/nzbget.conf"; - configOpts = lib.concatStringsSep " " (lib.mapAttrsToList (name: value: "-o ${name}=${lib.escapeShellArg (toStr value)}") cfg.settings); - toStr = v: - if v == true then "yes" - else if v == false then "no" - else if lib.isInt v then toString v - else v; + configOpts = lib.concatStringsSep " " ( + lib.mapAttrsToList (name: value: "-o ${name}=${lib.escapeShellArg (toStr value)}") cfg.settings + ); + toStr = + v: + if v == true then + "yes" + else if v == false then + "no" + else if lib.isInt v then + toString v + else + v; in { imports = [ - (lib.mkRemovedOptionModule [ "services" "misc" "nzbget" "configFile" ] "The configuration of nzbget is now managed by users through the web interface.") - (lib.mkRemovedOptionModule [ "services" "misc" "nzbget" "dataDir" ] "The data directory for nzbget is now /var/lib/nzbget.") - (lib.mkRemovedOptionModule [ "services" "misc" "nzbget" "openFirewall" ] "The port used by nzbget is managed through the web interface so you should adjust your firewall rules accordingly.") + (lib.mkRemovedOptionModule [ + "services" + "misc" + "nzbget" + "configFile" + ] "The configuration of nzbget is now managed by users through the web interface.") + (lib.mkRemovedOptionModule [ + "services" + "misc" + "nzbget" + "dataDir" + ] "The data directory for nzbget is now /var/lib/nzbget.") + (lib.mkRemovedOptionModule [ "services" "misc" "nzbget" "openFirewall" ] + "The port used by nzbget is managed through the web interface so you should adjust your firewall rules accordingly." + ) ]; # interface @@ -38,8 +62,14 @@ in }; settings = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ bool int str ]); - default = {}; + type = + with lib.types; + attrsOf (oneOf [ + bool + int + str + ]); + default = { }; description = '' NZBGet configuration, passed via command line using switch -o. Refer to diff --git a/nixos/modules/services/misc/nzbhydra2.nix b/nixos/modules/services/misc/nzbhydra2.nix index c71e8a92b72744..5636f1a422a1e3 100644 --- a/nixos/modules/services/misc/nzbhydra2.nix +++ b/nixos/modules/services/misc/nzbhydra2.nix @@ -1,7 +1,14 @@ -{ config, pkgs, lib, ... }: -let cfg = config.services.nzbhydra2; +{ + config, + pkgs, + lib, + ... +}: +let + cfg = config.services.nzbhydra2; -in { +in +{ options = { services.nzbhydra2 = { enable = lib.mkEnableOption "NZBHydra2, Usenet meta search"; @@ -23,8 +30,7 @@ in { }; config = lib.mkIf cfg.enable { - systemd.tmpfiles.rules = - [ "d '${cfg.dataDir}' 0700 nzbhydra2 nzbhydra2 - -" ]; + systemd.tmpfiles.rules = [ "d '${cfg.dataDir}' 0700 nzbhydra2 nzbhydra2 - -" ]; systemd.services.nzbhydra2 = { description = "NZBHydra2"; @@ -35,8 +41,7 @@ in { Type = "simple"; User = "nzbhydra2"; Group = "nzbhydra2"; - ExecStart = - "${cfg.package}/bin/nzbhydra2 --nobrowser --datafolder '${cfg.dataDir}'"; + ExecStart = "${cfg.package}/bin/nzbhydra2 --nobrowser --datafolder '${cfg.dataDir}'"; Restart = "on-failure"; # Hardening NoNewPrivileges = true; @@ -49,7 +54,7 @@ in { ProtectControlGroups = true; ProtectKernelModules = true; ProtectKernelTunables = true; - RestrictAddressFamilies ="AF_UNIX AF_INET AF_INET6 AF_NETLINK"; + RestrictAddressFamilies = "AF_UNIX AF_INET AF_INET6 AF_NETLINK"; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; @@ -64,6 +69,6 @@ in { isSystemUser = true; }; - users.groups.nzbhydra2 = {}; + users.groups.nzbhydra2 = { }; }; } diff --git a/nixos/modules/services/misc/octoprint.nix b/nixos/modules/services/misc/octoprint.nix index d8e4c9c302b38e..193e4222a37e7e 100644 --- a/nixos/modules/services/misc/octoprint.nix +++ b/nixos/modules/services/misc/octoprint.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.octoprint; @@ -7,7 +12,7 @@ let plugins.curalegacy.cura_engine = "${pkgs.curaengine_stable}/bin/CuraEngine"; server.port = cfg.port; webcam.ffmpeg = "${pkgs.ffmpeg.bin}/bin/ffmpeg"; - } // lib.optionalAttrs (cfg.host != null) {server.host = cfg.host;}; + } // lib.optionalAttrs (cfg.host != null) { server.host = cfg.host; }; fullConfig = lib.recursiveUpdate cfg.extraConfig baseConfig; diff --git a/nixos/modules/services/misc/ombi.nix b/nixos/modules/services/misc/ombi.nix index 89d8b5c537634a..ea57a33d84fa37 100644 --- a/nixos/modules/services/misc/ombi.nix +++ b/nixos/modules/services/misc/ombi.nix @@ -1,7 +1,14 @@ -{ config, pkgs, lib, ... }: -let cfg = config.services.ombi; +{ + config, + pkgs, + lib, + ... +}: +let + cfg = config.services.ombi; -in { +in +{ options = { services.ombi = { enable = lib.mkEnableOption '' diff --git a/nixos/modules/services/misc/osrm.nix b/nixos/modules/services/misc/osrm.nix index 8feccbbfa72614..60b18362ddbe41 100644 --- a/nixos/modules/services/misc/osrm.nix +++ b/nixos/modules/services/misc/osrm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.osrm; in @@ -30,15 +35,22 @@ in }; algorithm = lib.mkOption { - type = lib.types.enum [ "CH" "CoreCH" "MLD" ]; + type = lib.types.enum [ + "CH" + "CoreCH" + "MLD" + ]; default = "MLD"; description = "Algorithm to use for the data. Must be one of CH, CoreCH, MLD"; }; extraFlags = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; - example = [ "--max-table-size 1000" "--max-matching-size 1000" ]; + default = [ ]; + example = [ + "--max-table-size 1000" + "--max-matching-size 1000" + ]; description = "Extra command line arguments passed to osrm-routed"; }; diff --git a/nixos/modules/services/misc/owncast.nix b/nixos/modules/services/misc/owncast.nix index debbd90d42a7d8..fcb3deed6fe665 100644 --- a/nixos/modules/services/misc/owncast.nix +++ b/nixos/modules/services/misc/owncast.nix @@ -1,6 +1,13 @@ -{ lib, pkgs, config, ... }: -let cfg = config.services.owncast; -in { +{ + lib, + pkgs, + config, + ... +}: +let + cfg = config.services.owncast; +in +{ options.services.owncast = { @@ -89,9 +96,12 @@ in { users.groups = lib.mkIf (cfg.group == "owncast") { owncast = { }; }; - networking.firewall = - lib.mkIf cfg.openFirewall { allowedTCPPorts = [ cfg.rtmp-port ] ++ lib.optional (cfg.listen != "127.0.0.1") cfg.port; }; + networking.firewall = lib.mkIf cfg.openFirewall { + allowedTCPPorts = [ cfg.rtmp-port ] ++ lib.optional (cfg.listen != "127.0.0.1") cfg.port; + }; }; - meta = { maintainers = with lib.maintainers; [ MayNiklas ]; }; + meta = { + maintainers = with lib.maintainers; [ MayNiklas ]; + }; } diff --git a/nixos/modules/services/misc/packagekit.nix b/nixos/modules/services/misc/packagekit.nix index 1be689794d9fbc..d55f736b3bed1a 100644 --- a/nixos/modules/services/misc/packagekit.nix +++ b/nixos/modules/services/misc/packagekit.nix @@ -1,26 +1,37 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.packagekit; inherit (lib) - mkEnableOption mkOption mkIf mkRemovedOptionModule types - listToAttrs recursiveUpdate; + mkEnableOption + mkOption + mkIf + mkRemovedOptionModule + types + listToAttrs + recursiveUpdate + ; iniFmt = pkgs.formats.ini { }; confFiles = [ - (iniFmt.generate "PackageKit.conf" (recursiveUpdate - { + (iniFmt.generate "PackageKit.conf" ( + recursiveUpdate { Daemon = { DefaultBackend = "test_nop"; KeepCache = false; }; - } - cfg.settings)) + } cfg.settings + )) - (iniFmt.generate "Vendor.conf" (recursiveUpdate - { + (iniFmt.generate "Vendor.conf" ( + recursiveUpdate { PackagesNotFound = rec { DefaultUrl = "https://github.com/NixOS/nixpkgs"; CodecUrl = DefaultUrl; @@ -28,14 +39,18 @@ let FontUrl = DefaultUrl; MimeUrl = DefaultUrl; }; - } - cfg.vendorSettings)) + } cfg.vendorSettings + )) ]; in { imports = [ - (mkRemovedOptionModule [ "services" "packagekit" "backend" ] "Always set to test_nop, Nix backend is broken see #177946.") + (mkRemovedOptionModule [ + "services" + "packagekit" + "backend" + ] "Always set to test_nop, Nix backend is broken see #177946.") ]; options.services.packagekit = { @@ -66,9 +81,8 @@ in systemd.packages = with pkgs; [ packagekit ]; - environment.etc = listToAttrs (map - (e: - lib.nameValuePair "PackageKit/${e.name}" { source = e; }) - confFiles); + environment.etc = listToAttrs ( + map (e: lib.nameValuePair "PackageKit/${e.name}" { source = e; }) confFiles + ); }; } diff --git a/nixos/modules/services/misc/parsoid.nix b/nixos/modules/services/misc/parsoid.nix index bb168c4eca85b3..b839309419d68a 100644 --- a/nixos/modules/services/misc/parsoid.nix +++ b/nixos/modules/services/misc/parsoid.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.parsoid; @@ -7,24 +12,34 @@ let confTree = { worker_heartbeat_timeout = 300000; - logging = { level = "info"; }; - services = [{ - module = "lib/index.js"; - entrypoint = "apiServiceWorker"; - conf = { - mwApis = map (x: if lib.isAttrs x then x else { uri = x; }) cfg.wikis; - serverInterface = cfg.interface; - serverPort = cfg.port; - }; - }]; + logging = { + level = "info"; + }; + services = [ + { + module = "lib/index.js"; + entrypoint = "apiServiceWorker"; + conf = { + mwApis = map (x: if lib.isAttrs x then x else { uri = x; }) cfg.wikis; + serverInterface = cfg.interface; + serverPort = cfg.port; + }; + } + ]; }; - confFile = pkgs.writeText "config.yml" (builtins.toJSON (lib.recursiveUpdate confTree cfg.extraConfig)); + confFile = pkgs.writeText "config.yml" ( + builtins.toJSON (lib.recursiveUpdate confTree cfg.extraConfig) + ); in { imports = [ - (lib.mkRemovedOptionModule [ "services" "parsoid" "interwikis" ] "Use services.parsoid.wikis instead") + (lib.mkRemovedOptionModule [ + "services" + "parsoid" + "interwikis" + ] "Use services.parsoid.wikis instead") ]; ##### interface @@ -76,7 +91,7 @@ in extraConfig = lib.mkOption { type = lib.types.attrs; - default = {}; + default = { }; description = '' Extra configuration to add to parsoid configuration. ''; @@ -111,7 +126,10 @@ in ProtectKernelTunables = true; ProtectKernelModules = true; ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; LockPersonality = true; #MemoryDenyWriteExecute = true; diff --git a/nixos/modules/services/misc/persistent-evdev.nix b/nixos/modules/services/misc/persistent-evdev.nix index 650752abd21511..afc57482f7ffa8 100644 --- a/nixos/modules/services/misc/persistent-evdev.nix +++ b/nixos/modules/services/misc/persistent-evdev.nix @@ -1,8 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.persistent-evdev; - settingsFormat = pkgs.formats.json {}; + settingsFormat = pkgs.formats.json { }; configFile = settingsFormat.generate "persistent-evdev-config" { cache = "/var/cache/persistent-evdev"; @@ -14,7 +19,7 @@ in enable = lib.mkEnableOption "virtual input devices that persist even if the backing device is hotplugged"; devices = lib.mkOption { - default = {}; + default = { }; type = with lib.types; attrsOf str; description = '' A set of virtual proxy device labels with backing physical device ids. diff --git a/nixos/modules/services/misc/pghero.nix b/nixos/modules/services/misc/pghero.nix index 39515f10c8e1d1..121c606a817c83 100644 --- a/nixos/modules/services/misc/pghero.nix +++ b/nixos/modules/services/misc/pghero.nix @@ -1,4 +1,10 @@ -{ config, pkgs, lib, utils, ... }: +{ + config, + pkgs, + lib, + utils, + ... +}: let cfg = config.services.pghero; settingsFormat = pkgs.formats.yaml { }; @@ -88,7 +94,10 @@ in description = "PgHero performance dashboard for PostgreSQL"; wantedBy = [ "multi-user.target" ]; requires = [ "pghero.socket" ]; - after = [ "pghero.socket" "network.target" ]; + after = [ + "pghero.socket" + "network.target" + ]; environment = { RAILS_ENV = "production"; @@ -99,11 +108,14 @@ in Type = "notify"; WatchdogSec = "10"; - ExecStart = utils.escapeSystemdExecArgs ([ - (lib.getExe cfg.package) - "--bind-to-activated-sockets" - "only" - ] ++ cfg.extraArgs); + ExecStart = utils.escapeSystemdExecArgs ( + [ + (lib.getExe cfg.package) + "--bind-to-activated-sockets" + "only" + ] + ++ cfg.extraArgs + ); Restart = "always"; WorkingDirectory = "${cfg.package}/share/pghero"; @@ -127,7 +139,11 @@ in PrivateDevices = true; RestrictRealtime = true; RestrictNamespaces = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; DeviceAllow = [ "" ]; DevicePolicy = "closed"; CapabilityBoundingSet = [ "" ]; diff --git a/nixos/modules/services/misc/pinnwand.nix b/nixos/modules/services/misc/pinnwand.nix index 3a5c47aeefd298..1e54a35b4d82ba 100644 --- a/nixos/modules/services/misc/pinnwand.nix +++ b/nixos/modules/services/misc/pinnwand.nix @@ -1,8 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.pinnwand; - format = pkgs.formats.toml {}; + format = pkgs.formats.toml { }; configFile = format.generate "pinnwand.toml" cfg.settings; in { @@ -16,7 +21,7 @@ in }; settings = lib.mkOption { - default = {}; + default = { }; description = '' Your {file}`pinnwand.toml` as a Nix attribute set. Look up possible options in the [documentation](https://pinnwand.readthedocs.io/en/v${pkgs.pinnwand.version}/configuration.html). @@ -47,7 +52,7 @@ in type = lib.types.str; default = ''

Welcome to pinnwand, this site is a pastebin. It allows you to share code with others. If you write code in the text area below and press the paste button you will be given a link you can share with others so they can view your code as well.

People with the link can view your pasted code, only you can remove your paste and it expires automatically. Note that anyone could guess the URI to your paste so don't rely on it being private.

- ''; + ''; description = '' Raw HTML help text shown in the header area. ''; @@ -82,7 +87,7 @@ in StateDirectory = "pinnwand"; StateDirectoryMode = "0700"; - AmbientCapabilities = []; + AmbientCapabilities = [ ]; CapabilityBoundingSet = ""; DevicePolicy = "closed"; LockPersonality = true; diff --git a/nixos/modules/services/misc/plex.nix b/nixos/modules/services/misc/plex.nix index d1524aaae2a372..b058732e479203 100644 --- a/nixos/modules/services/misc/plex.nix +++ b/nixos/modules/services/misc/plex.nix @@ -1,10 +1,19 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.plex; in { imports = [ - (lib.mkRemovedOptionModule [ "services" "plex" "managePlugins" ] "Please omit or define the option: `services.plex.extraPlugins' instead.") + (lib.mkRemovedOptionModule [ + "services" + "plex" + "managePlugins" + ] "Please omit or define the option: `services.plex.extraPlugins' instead.") ]; options = { @@ -45,7 +54,7 @@ in extraPlugins = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; description = '' A list of paths to extra plugin bundles to install in Plex's plugin directory. Every time the systemd unit for Plex starts up, all of the @@ -69,7 +78,7 @@ in extraScanners = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; description = '' A list of paths to extra scanners to install in Plex's scanners directory. @@ -92,7 +101,7 @@ in accelerationDevices = lib.mkOption { type = lib.types.listOf lib.types.str; - default = ["*"]; + default = [ "*" ]; example = [ "/dev/dri/renderD128" ]; description = '' A list of device paths to hardware acceleration devices that Plex should @@ -124,17 +133,18 @@ in # Run the pre-start script with full permissions (the "!" prefix) so it # can create the data directory if necessary. - ExecStartPre = let - preStartScript = pkgs.writeScript "plex-run-prestart" '' - #!${pkgs.bash}/bin/bash - - # Create data directory if it doesn't exist - if ! test -d "$PLEX_DATADIR"; then - echo "Creating initial Plex data directory in: $PLEX_DATADIR" - install -d -m 0755 -o "${cfg.user}" -g "${cfg.group}" "$PLEX_DATADIR" - fi - ''; - in + ExecStartPre = + let + preStartScript = pkgs.writeScript "plex-run-prestart" '' + #!${pkgs.bash}/bin/bash + + # Create data directory if it doesn't exist + if ! test -d "$PLEX_DATADIR"; then + echo "Creating initial Plex data directory in: $PLEX_DATADIR" + install -d -m 0755 -o "${cfg.user}" -g "${cfg.group}" "$PLEX_DATADIR" + fi + ''; + in "!${preStartScript}"; ExecStart = "${cfg.package}/bin/plexmediaserver"; @@ -145,14 +155,21 @@ in # Hardening NoNewPrivileges = true; PrivateTmp = true; - PrivateDevices = cfg.accelerationDevices == []; - DeviceAllow = lib.mkIf (cfg.accelerationDevices != [] && !lib.elem "*" cfg.accelerationDevices) cfg.accelerationDevices; + PrivateDevices = cfg.accelerationDevices == [ ]; + DeviceAllow = lib.mkIf ( + cfg.accelerationDevices != [ ] && !lib.elem "*" cfg.accelerationDevices + ) cfg.accelerationDevices; ProtectSystem = true; ProtectHome = true; ProtectControlGroups = true; ProtectKernelModules = true; ProtectKernelTunables = true; - RestrictAddressFamilies = ["AF_UNIX" "AF_INET" "AF_INET6" "AF_NETLINK"]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + "AF_NETLINK" + ]; # This could be made to work if the namespaces needed were known # RestrictNamespaces = true; RestrictRealtime = true; @@ -163,9 +180,9 @@ in environment = { # Configuration for our FHS userenv script - PLEX_DATADIR=cfg.dataDir; - PLEX_PLUGINS=lib.concatMapStringsSep ":" builtins.toString cfg.extraPlugins; - PLEX_SCANNERS=lib.concatMapStringsSep ":" builtins.toString cfg.extraScanners; + PLEX_DATADIR = cfg.dataDir; + PLEX_PLUGINS = lib.concatMapStringsSep ":" builtins.toString cfg.extraPlugins; + PLEX_SCANNERS = lib.concatMapStringsSep ":" builtins.toString cfg.extraScanners; # The following variables should be set by the FHS userenv script: # PLEX_MEDIA_SERVER_APPLICATION_SUPPORT_DIR @@ -173,19 +190,31 @@ in # Allow access to GPU acceleration; the Plex LD_LIBRARY_PATH is added # by the FHS userenv script. - LD_LIBRARY_PATH="/run/opengl-driver/lib"; + LD_LIBRARY_PATH = "/run/opengl-driver/lib"; - PLEX_MEDIA_SERVER_MAX_PLUGIN_PROCS="6"; - PLEX_MEDIA_SERVER_TMPDIR="/tmp"; - PLEX_MEDIA_SERVER_USE_SYSLOG="true"; - LC_ALL="en_US.UTF-8"; - LANG="en_US.UTF-8"; + PLEX_MEDIA_SERVER_MAX_PLUGIN_PROCS = "6"; + PLEX_MEDIA_SERVER_TMPDIR = "/tmp"; + PLEX_MEDIA_SERVER_USE_SYSLOG = "true"; + LC_ALL = "en_US.UTF-8"; + LANG = "en_US.UTF-8"; }; }; networking.firewall = lib.mkIf cfg.openFirewall { - allowedTCPPorts = [ 32400 3005 8324 32469 ]; - allowedUDPPorts = [ 1900 5353 32410 32412 32413 32414 ]; + allowedTCPPorts = [ + 32400 + 3005 + 8324 + 32469 + ]; + allowedUDPPorts = [ + 1900 + 5353 + 32410 + 32412 + 32413 + 32414 + ]; }; users.users = lib.mkIf (cfg.user == "plex") { diff --git a/nixos/modules/services/misc/plikd.nix b/nixos/modules/services/misc/plikd.nix index 477c1b413fd0e2..f86c178ce2d929 100644 --- a/nixos/modules/services/misc/plikd.nix +++ b/nixos/modules/services/misc/plikd.nix @@ -1,8 +1,13 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.plikd; - format = pkgs.formats.toml {}; + format = pkgs.formats.toml { }; plikdCfg = format.generate "plikd.cfg" cfg.settings; in { @@ -18,7 +23,7 @@ in settings = lib.mkOption { type = format.type; - default = {}; + default = { }; description = '' Configuration for plikd, see for supported values. @@ -33,7 +38,7 @@ in ListenAddress = "localhost"; DataBackend = "file"; DataBackendConfig = { - Directory = "/var/lib/plikd"; + Directory = "/var/lib/plikd"; }; MetadataBackendConfig = { Driver = "sqlite3"; diff --git a/nixos/modules/services/misc/podgrab.nix b/nixos/modules/services/misc/podgrab.nix index 50dc70e2bd767d..af4f4eacb53e1d 100644 --- a/nixos/modules/services/misc/podgrab.nix +++ b/nixos/modules/services/misc/podgrab.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.podgrab; diff --git a/nixos/modules/services/misc/polaris.nix b/nixos/modules/services/misc/polaris.nix index 70c478d193e932..c6aebe1cc66cc0 100644 --- a/nixos/modules/services/misc/polaris.nix +++ b/nixos/modules/services/misc/polaris.nix @@ -1,10 +1,12 @@ -{ config -, pkgs -, lib -, ...}: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.polaris; - settingsFormat = pkgs.formats.toml {}; + settingsFormat = pkgs.formats.toml { }; in { options = { @@ -27,7 +29,7 @@ in extraGroups = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = "Polaris' auxiliary groups."; example = lib.literalExpression ''["media" "music"]''; }; @@ -43,7 +45,7 @@ in settings = lib.mkOption { type = settingsFormat.type; - default = {}; + default = { }; description = '' Contents for the TOML Polaris config, applied each start. Although poorly documented, an example may be found here: @@ -91,15 +93,22 @@ in SupplementaryGroups = cfg.extraGroups; StateDirectory = "polaris"; CacheDirectory = "polaris"; - ExecStart = lib.escapeShellArgs ([ - "${cfg.package}/bin/polaris" - "--foreground" - "--port" cfg.port - "--database" "/var/lib/${StateDirectory}/db.sqlite" - "--cache" "/var/cache/${CacheDirectory}" - ] ++ lib.optionals (cfg.settings != {}) [ - "--config" (settingsFormat.generate "polaris-config.toml" cfg.settings) - ]); + ExecStart = lib.escapeShellArgs ( + [ + "${cfg.package}/bin/polaris" + "--foreground" + "--port" + cfg.port + "--database" + "/var/lib/${StateDirectory}/db.sqlite" + "--cache" + "/var/cache/${CacheDirectory}" + ] + ++ lib.optionals (cfg.settings != { }) [ + "--config" + (settingsFormat.generate "polaris-config.toml" cfg.settings) + ] + ); Restart = "on-failure"; # Security options: @@ -126,7 +135,11 @@ in ProtectKernelTunables = true; RestrictNamespaces = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; RestrictRealtime = true; #RestrictSUIDSGID = true; # implied by DynamicUser @@ -134,7 +147,13 @@ in SystemCallErrorNumber = "EPERM"; SystemCallFilter = [ "@system-service" - "~@cpu-emulation" "~@debug" "~@keyring" "~@memlock" "~@obsolete" "~@privileged" "~@setuid" + "~@cpu-emulation" + "~@debug" + "~@keyring" + "~@memlock" + "~@obsolete" + "~@privileged" + "~@setuid" ]; }; }; diff --git a/nixos/modules/services/misc/portunus.nix b/nixos/modules/services/misc/portunus.nix index 20486f0212f7b0..6f2ca0a83c8d84 100644 --- a/nixos/modules/services/misc/portunus.nix +++ b/nixos/modules/services/misc/portunus.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.portunus; @@ -71,18 +76,20 @@ in ''; oidcClients = lib.mkOption { - type = lib.types.listOf (lib.types.submodule { - options = { - callbackURL = lib.mkOption { - type = lib.types.str; - description = "URL where the OIDC client should redirect"; - }; - id = lib.mkOption { - type = lib.types.str; - description = "ID of the OIDC client"; + type = lib.types.listOf ( + lib.types.submodule { + options = { + callbackURL = lib.mkOption { + type = lib.types.str; + description = "URL where the OIDC client should redirect"; + }; + id = lib.mkOption { + type = lib.types.str; + description = "ID of the OIDC client"; + }; }; - }; - }); + } + ); default = [ ]; example = [ { @@ -190,31 +197,38 @@ in config.file = "/var/lib/dex/dex.db"; }; enablePasswordDB = false; - connectors = [{ - type = "ldap"; - id = "ldap"; - name = "LDAP"; - config = { - host = "${cfg.domain}:636"; - bindDN = "uid=${cfg.ldap.searchUserName},ou=users,${cfg.ldap.suffix}"; - bindPW = "$DEX_SEARCH_USER_PASSWORD"; - userSearch = { - baseDN = "ou=users,${cfg.ldap.suffix}"; - filter = "(objectclass=person)"; - username = "uid"; - idAttr = "uid"; - emailAttr = "mail"; - nameAttr = "cn"; - preferredUsernameAttr = "uid"; - }; - groupSearch = { - baseDN = "ou=groups,${cfg.ldap.suffix}"; - filter = "(objectclass=groupOfNames)"; - nameAttr = "cn"; - userMatchers = [{ userAttr = "DN"; groupAttr = "member"; }]; + connectors = [ + { + type = "ldap"; + id = "ldap"; + name = "LDAP"; + config = { + host = "${cfg.domain}:636"; + bindDN = "uid=${cfg.ldap.searchUserName},ou=users,${cfg.ldap.suffix}"; + bindPW = "$DEX_SEARCH_USER_PASSWORD"; + userSearch = { + baseDN = "ou=users,${cfg.ldap.suffix}"; + filter = "(objectclass=person)"; + username = "uid"; + idAttr = "uid"; + emailAttr = "mail"; + nameAttr = "cn"; + preferredUsernameAttr = "uid"; + }; + groupSearch = { + baseDN = "ou=groups,${cfg.ldap.suffix}"; + filter = "(objectclass=groupOfNames)"; + nameAttr = "cn"; + userMatchers = [ + { + userAttr = "DN"; + groupAttr = "member"; + } + ]; + }; }; - }; - }]; + } + ]; staticClients = lib.forEach cfg.dex.oidcClients (client: { inherit (client) id; @@ -225,7 +239,9 @@ in }; }; - portunus.seedPath = lib.mkIf (cfg.seedSettings != null) (pkgs.writeText "seed.json" (builtins.toJSON cfg.seedSettings)); + portunus.seedPath = lib.mkIf (cfg.seedSettings != null) ( + pkgs.writeText "seed.json" (builtins.toJSON cfg.seedSettings) + ); }; systemd.services = { @@ -247,30 +263,34 @@ in ExecStart = "${cfg.package}/bin/portunus-orchestrator"; Restart = "on-failure"; }; - environment = { - PORTUNUS_LDAP_SUFFIX = cfg.ldap.suffix; - PORTUNUS_SERVER_BINARY = "${cfg.package}/bin/portunus-server"; - PORTUNUS_SERVER_GROUP = cfg.group; - PORTUNUS_SERVER_USER = cfg.user; - PORTUNUS_SERVER_HTTP_LISTEN = "127.0.0.1:${toString cfg.port}"; - PORTUNUS_SERVER_STATE_DIR = cfg.stateDir; - PORTUNUS_SLAPD_BINARY = "${cfg.ldap.package}/libexec/slapd"; - PORTUNUS_SLAPD_GROUP = cfg.ldap.group; - PORTUNUS_SLAPD_USER = cfg.ldap.user; - PORTUNUS_SLAPD_SCHEMA_DIR = "${cfg.ldap.package}/etc/schema"; - } // (lib.optionalAttrs (cfg.seedPath != null) ({ - PORTUNUS_SEED_PATH = cfg.seedPath; - })) // (lib.optionalAttrs cfg.ldap.tls ( - let - acmeDirectory = config.security.acme.certs."${cfg.domain}".directory; - in + environment = { - PORTUNUS_SERVER_HTTP_SECURE = "true"; - PORTUNUS_SLAPD_TLS_CA_CERTIFICATE = "/etc/ssl/certs/ca-certificates.crt"; - PORTUNUS_SLAPD_TLS_CERTIFICATE = "${acmeDirectory}/cert.pem"; - PORTUNUS_SLAPD_TLS_DOMAIN_NAME = cfg.domain; - PORTUNUS_SLAPD_TLS_PRIVATE_KEY = "${acmeDirectory}/key.pem"; - })); + PORTUNUS_LDAP_SUFFIX = cfg.ldap.suffix; + PORTUNUS_SERVER_BINARY = "${cfg.package}/bin/portunus-server"; + PORTUNUS_SERVER_GROUP = cfg.group; + PORTUNUS_SERVER_USER = cfg.user; + PORTUNUS_SERVER_HTTP_LISTEN = "127.0.0.1:${toString cfg.port}"; + PORTUNUS_SERVER_STATE_DIR = cfg.stateDir; + PORTUNUS_SLAPD_BINARY = "${cfg.ldap.package}/libexec/slapd"; + PORTUNUS_SLAPD_GROUP = cfg.ldap.group; + PORTUNUS_SLAPD_USER = cfg.ldap.user; + PORTUNUS_SLAPD_SCHEMA_DIR = "${cfg.ldap.package}/etc/schema"; + } + // (lib.optionalAttrs (cfg.seedPath != null) ({ + PORTUNUS_SEED_PATH = cfg.seedPath; + })) + // (lib.optionalAttrs cfg.ldap.tls ( + let + acmeDirectory = config.security.acme.certs."${cfg.domain}".directory; + in + { + PORTUNUS_SERVER_HTTP_SECURE = "true"; + PORTUNUS_SLAPD_TLS_CA_CERTIFICATE = "/etc/ssl/certs/ca-certificates.crt"; + PORTUNUS_SLAPD_TLS_CERTIFICATE = "${acmeDirectory}/cert.pem"; + PORTUNUS_SLAPD_TLS_DOMAIN_NAME = cfg.domain; + PORTUNUS_SLAPD_TLS_PRIVATE_KEY = "${acmeDirectory}/key.pem"; + } + )); }; }; diff --git a/nixos/modules/services/misc/preload.nix b/nixos/modules/services/misc/preload.nix index 4dadd0e26b16bd..9a9de0f65d374d 100644 --- a/nixos/modules/services/misc/preload.nix +++ b/nixos/modules/services/misc/preload.nix @@ -1,8 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.preload; -in { - meta = { maintainers = pkgs.preload.meta.maintainers; }; +in +{ + meta = { + maintainers = pkgs.preload.meta.maintainers; + }; options.services.preload = { enable = lib.mkEnableOption "preload"; diff --git a/nixos/modules/services/misc/private-gpt.nix b/nixos/modules/services/misc/private-gpt.nix index 7bd2e492f5b56e..e7974f93d66a6f 100644 --- a/nixos/modules/services/misc/private-gpt.nix +++ b/nixos/modules/services/misc/private-gpt.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let inherit (lib) types; diff --git a/nixos/modules/services/misc/prowlarr.nix b/nixos/modules/services/misc/prowlarr.nix index 906f75516abd83..21296985b3ef95 100644 --- a/nixos/modules/services/misc/prowlarr.nix +++ b/nixos/modules/services/misc/prowlarr.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.prowlarr; diff --git a/nixos/modules/services/misc/pufferpanel.nix b/nixos/modules/services/misc/pufferpanel.nix index 3679d25861e667..eb070f0767c228 100644 --- a/nixos/modules/services/misc/pufferpanel.nix +++ b/nixos/modules/services/misc/pufferpanel.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.pufferpanel; in @@ -116,14 +121,18 @@ in # would set PUFFER_LOGS to $LOGS_DIRECTORY if PUFFER_LOGS environment # variable is not defined. script = '' - ${lib.concatLines (lib.mapAttrsToList (name: value: '' - export ${name}="''${${name}-${value}}" - '') { - PUFFER_LOGS = "$LOGS_DIRECTORY"; - PUFFER_DAEMON_DATA_CACHE = "$CACHE_DIRECTORY"; - PUFFER_DAEMON_DATA_SERVERS = "$STATE_DIRECTORY/servers"; - PUFFER_DAEMON_DATA_BINARIES = "$STATE_DIRECTORY/binaries"; - })} + ${lib.concatLines ( + lib.mapAttrsToList + (name: value: '' + export ${name}="''${${name}-${value}}" + '') + { + PUFFER_LOGS = "$LOGS_DIRECTORY"; + PUFFER_DAEMON_DATA_CACHE = "$CACHE_DIRECTORY"; + PUFFER_DAEMON_DATA_SERVERS = "$STATE_DIRECTORY/servers"; + PUFFER_DAEMON_DATA_BINARIES = "$STATE_DIRECTORY/binaries"; + } + )} exec ${lib.getExe cfg.package} run --workDir "$STATE_DIRECTORY" ''; @@ -162,8 +171,15 @@ in PrivateUsers = true; PrivateDevices = true; RestrictRealtime = true; - RestrictNamespaces = [ "user" "mnt" ]; # allow buildFHSEnv - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictNamespaces = [ + "user" + "mnt" + ]; # allow buildFHSEnv + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; LockPersonality = true; DeviceAllow = [ "" ]; DevicePolicy = "closed"; diff --git a/nixos/modules/services/misc/pykms.nix b/nixos/modules/services/misc/pykms.nix index 19985229f548c0..c9613f684e8429 100644 --- a/nixos/modules/services/misc/pykms.nix +++ b/nixos/modules/services/misc/pykms.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.pykms; libDir = "/var/lib/pykms"; @@ -44,7 +49,14 @@ in }; logLevel = lib.mkOption { - type = lib.types.enum [ "CRITICAL" "ERROR" "WARNING" "INFO" "DEBUG" "MININFO" ]; + type = lib.types.enum [ + "CRITICAL" + "ERROR" + "WARNING" + "INFO" + "DEBUG" + "MININFO" + ]; default = "INFO"; description = "How much to log"; }; @@ -70,15 +82,19 @@ in DynamicUser = true; StateDirectory = baseNameOf libDir; ExecStartPre = "${lib.getBin pykms}/libexec/create_pykms_db.sh ${libDir}/clients.db"; - ExecStart = lib.concatStringsSep " " ([ - "${lib.getBin pykms}/bin/server" - "--logfile=STDOUT" - "--loglevel=${cfg.logLevel}" - "--sqlite=${libDir}/clients.db" - ] ++ cfg.extraArgs ++ [ - cfg.listenAddress - (toString cfg.port) - ]); + ExecStart = lib.concatStringsSep " " ( + [ + "${lib.getBin pykms}/bin/server" + "--logfile=STDOUT" + "--loglevel=${cfg.logLevel}" + "--sqlite=${libDir}/clients.db" + ] + ++ cfg.extraArgs + ++ [ + cfg.listenAddress + (toString cfg.port) + ] + ); ProtectHome = "tmpfs"; WorkingDirectory = libDir; SyslogIdentifier = "pykms"; diff --git a/nixos/modules/services/misc/radarr.nix b/nixos/modules/services/misc/radarr.nix index 54c6e9577b314c..bb645acd5f92f8 100644 --- a/nixos/modules/services/misc/radarr.nix +++ b/nixos/modules/services/misc/radarr.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.radarr; diff --git a/nixos/modules/services/misc/readarr.nix b/nixos/modules/services/misc/readarr.nix index 15f1bde2cdfc72..49a3fde81a9d7c 100644 --- a/nixos/modules/services/misc/readarr.nix +++ b/nixos/modules/services/misc/readarr.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.readarr; in diff --git a/nixos/modules/services/misc/redmine.nix b/nixos/modules/services/misc/redmine.nix index d3d329f0594441..eceabc317d1a2d 100644 --- a/nixos/modules/services/misc/redmine.nix +++ b/nixos/modules/services/misc/redmine.nix @@ -1,28 +1,50 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkBefore mkDefault mkEnableOption mkPackageOption - mkIf mkOption mkRemovedOptionModule types; + inherit (lib) + mkBefore + mkDefault + mkEnableOption + mkPackageOption + mkIf + mkOption + mkRemovedOptionModule + types + ; inherit (lib) concatStringsSep literalExpression mapAttrsToList; inherit (lib) optional optionalAttrs optionalString; cfg = config.services.redmine; - format = pkgs.formats.yaml {}; + format = pkgs.formats.yaml { }; bundle = "${cfg.package}/share/redmine/bin/bundle"; databaseSettings = { - production = { - adapter = cfg.database.type; - database = if cfg.database.type == "sqlite3" then "${cfg.stateDir}/database.sqlite3" else cfg.database.name; - } // optionalAttrs (cfg.database.type != "sqlite3") { - host = if (cfg.database.type == "postgresql" && cfg.database.socket != null) then cfg.database.socket else cfg.database.host; - port = cfg.database.port; - username = cfg.database.user; - } // optionalAttrs (cfg.database.type != "sqlite3" && cfg.database.passwordFile != null) { - password = "#dbpass#"; - } // optionalAttrs (cfg.database.type == "mysql2" && cfg.database.socket != null) { - socket = cfg.database.socket; - }; + production = + { + adapter = cfg.database.type; + database = + if cfg.database.type == "sqlite3" then "${cfg.stateDir}/database.sqlite3" else cfg.database.name; + } + // optionalAttrs (cfg.database.type != "sqlite3") { + host = + if (cfg.database.type == "postgresql" && cfg.database.socket != null) then + cfg.database.socket + else + cfg.database.host; + port = cfg.database.port; + username = cfg.database.user; + } + // optionalAttrs (cfg.database.type != "sqlite3" && cfg.database.passwordFile != null) { + password = "#dbpass#"; + } + // optionalAttrs (cfg.database.type == "mysql2" && cfg.database.socket != null) { + socket = cfg.database.socket; + }; }; databaseYml = format.generate "database.yml" databaseSettings; @@ -32,16 +54,20 @@ let unpackTheme = unpack "theme"; unpackPlugin = unpack "plugin"; - unpack = id: (name: source: - pkgs.stdenv.mkDerivation { - name = "redmine-${id}-${name}"; - nativeBuildInputs = [ pkgs.unzip ]; - buildCommand = '' - mkdir -p $out - cd $out - unpackFile ${source} - ''; - }); + unpack = + id: + ( + name: source: + pkgs.stdenv.mkDerivation { + name = "redmine-${id}-${name}"; + nativeBuildInputs = [ pkgs.unzip ]; + buildCommand = '' + mkdir -p $out + cd $out + unpackFile ${source} + ''; + } + ); mysqlLocal = cfg.database.createLocally && cfg.database.type == "mysql2"; pgsqlLocal = cfg.database.createLocally && cfg.database.type == "postgresql"; @@ -49,8 +75,17 @@ let in { imports = [ - (mkRemovedOptionModule [ "services" "redmine" "extraConfig" ] "Use services.redmine.settings instead.") - (mkRemovedOptionModule [ "services" "redmine" "database" "password" ] "Use services.redmine.database.passwordFile instead.") + (mkRemovedOptionModule [ + "services" + "redmine" + "extraConfig" + ] "Use services.redmine.settings instead.") + (mkRemovedOptionModule [ + "services" + "redmine" + "database" + "password" + ] "Use services.redmine.database.passwordFile instead.") ]; # interface @@ -94,7 +129,7 @@ in settings = mkOption { type = format.type; - default = {}; + default = { }; description = '' Redmine configuration ({file}`configuration.yml`). Refer to @@ -129,7 +164,7 @@ in themes = mkOption { type = types.attrsOf types.path; - default = {}; + default = { }; description = "Set of themes."; example = literalExpression '' { @@ -143,7 +178,7 @@ in plugins = mkOption { type = types.attrsOf types.path; - default = {}; + default = { }; description = "Set of plugins."; example = literalExpression '' { @@ -157,7 +192,11 @@ in database = { type = mkOption { - type = types.enum [ "mysql2" "postgresql" "sqlite3" ]; + type = types.enum [ + "mysql2" + "postgresql" + "sqlite3" + ]; example = "postgresql"; default = "mysql2"; description = "Database engine to use."; @@ -201,9 +240,12 @@ in socket = mkOption { type = types.nullOr types.path; default = - if mysqlLocal then "/run/mysqld/mysqld.sock" - else if pgsqlLocal then "/run/postgresql" - else null; + if mysqlLocal then + "/run/mysqld/mysqld.sock" + else if pgsqlLocal then + "/run/postgresql" + else + null; defaultText = literalExpression "/run/mysqld/mysqld.sock"; example = "/run/mysqld/mysqld.sock"; description = "Path to the unix socket file to use for authentication."; @@ -273,22 +315,30 @@ in config = mkIf cfg.enable { assertions = [ - { assertion = cfg.database.type != "sqlite3" -> cfg.database.passwordFile != null || cfg.database.socket != null; + { + assertion = + cfg.database.type != "sqlite3" -> cfg.database.passwordFile != null || cfg.database.socket != null; message = "one of services.redmine.database.socket or services.redmine.database.passwordFile must be set"; } - { assertion = cfg.database.createLocally -> cfg.database.user == cfg.user; + { + assertion = cfg.database.createLocally -> cfg.database.user == cfg.user; message = "services.redmine.database.user must be set to ${cfg.user} if services.redmine.database.createLocally is set true"; } - { assertion = pgsqlLocal -> cfg.database.user == cfg.database.name; + { + assertion = pgsqlLocal -> cfg.database.user == cfg.database.name; message = "services.redmine.database.user and services.redmine.database.name must be the same when using a local postgresql database"; } - { assertion = (cfg.database.createLocally && cfg.database.type != "sqlite3") -> cfg.database.socket != null; + { + assertion = + (cfg.database.createLocally && cfg.database.type != "sqlite3") -> cfg.database.socket != null; message = "services.redmine.database.socket must be set if services.redmine.database.createLocally is set to true and no sqlite database is used"; } - { assertion = cfg.database.createLocally -> cfg.database.host == "localhost"; + { + assertion = cfg.database.createLocally -> cfg.database.host == "localhost"; message = "services.redmine.database.host must be set to localhost if services.redmine.database.createLocally is set to true"; } - { assertion = cfg.components.imagemagick -> cfg.components.minimagick_font_path != ""; + { + assertion = cfg.components.imagemagick -> cfg.components.minimagick_font_path != ""; message = "services.redmine.components.minimagick_font_path must be configured with a path to a font file if services.redmine.components.imagemagick is set to true."; } ]; @@ -316,8 +366,11 @@ in package = mkDefault pkgs.mariadb; ensureDatabases = [ cfg.database.name ]; ensureUsers = [ - { name = cfg.database.user; - ensurePermissions = { "${cfg.database.name}.*" = "ALL PRIVILEGES"; }; + { + name = cfg.database.user; + ensurePermissions = { + "${cfg.database.name}.*" = "ALL PRIVILEGES"; + }; } ]; }; @@ -326,7 +379,8 @@ in enable = true; ensureDatabases = [ cfg.database.name ]; ensureUsers = [ - { name = cfg.database.user; + { + name = cfg.database.user; ensureDBOwnership = true; } ]; @@ -357,21 +411,26 @@ in ]; systemd.services.redmine = { - after = [ "network.target" ] ++ optional mysqlLocal "mysql.service" ++ optional pgsqlLocal "postgresql.service"; + after = + [ "network.target" ] + ++ optional mysqlLocal "mysql.service" + ++ optional pgsqlLocal "postgresql.service"; wantedBy = [ "multi-user.target" ]; environment.RAILS_ENV = "production"; environment.RAILS_CACHE = "${cfg.stateDir}/cache"; environment.REDMINE_LANG = "en"; environment.SCHEMA = "${cfg.stateDir}/cache/schema.db"; - path = with pkgs; [ - ] - ++ optional cfg.components.subversion subversion - ++ optional cfg.components.mercurial mercurial - ++ optional cfg.components.git git - ++ optional cfg.components.cvs cvs - ++ optional cfg.components.breezy breezy - ++ optional cfg.components.imagemagick imagemagick - ++ optional cfg.components.ghostscript ghostscript; + path = + with pkgs; + [ + ] + ++ optional cfg.components.subversion subversion + ++ optional cfg.components.mercurial mercurial + ++ optional cfg.components.git git + ++ optional cfg.components.cvs cvs + ++ optional cfg.components.breezy breezy + ++ optional cfg.components.imagemagick imagemagick + ++ optional cfg.components.ghostscript ghostscript; preStart = '' rm -rf "${cfg.stateDir}/plugins/"* @@ -435,7 +494,7 @@ in Group = cfg.group; TimeoutSec = "300"; WorkingDirectory = "${cfg.package}/share/redmine"; - ExecStart="${bundle} exec rails server -u webrick -e production -b ${toString cfg.address} -p ${toString cfg.port} -P '${cfg.stateDir}/redmine.pid'"; + ExecStart = "${bundle} exec rails server -u webrick -e production -b ${toString cfg.address} -p ${toString cfg.port} -P '${cfg.stateDir}/redmine.pid'"; AmbientCapabilities = ""; CapabilityBoundingSet = ""; LockPersonality = true; @@ -455,12 +514,15 @@ in ProtectProc = "noaccess"; ProtectSystem = "full"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - UMask = 027; + UMask = 27; }; }; diff --git a/nixos/modules/services/misc/renovate.nix b/nixos/modules/services/misc/renovate.nix index 18a0e817b9d7c9..cc1185fb0580d6 100644 --- a/nixos/modules/services/misc/renovate.nix +++ b/nixos/modules/services/misc/renovate.nix @@ -36,7 +36,10 @@ let generateConfig = if cfg.validateSettings then generateValidatedConfig else json.generate; in { - meta.maintainers = with lib.maintainers; [ marie natsukium ]; + meta.maintainers = with lib.maintainers; [ + marie + natsukium + ]; options.services.renovate = { enable = mkEnableOption "renovate"; diff --git a/nixos/modules/services/misc/ripple-data-api.nix b/nixos/modules/services/misc/ripple-data-api.nix index e01e891c95a84e..dd48cdeead07b4 100644 --- a/nixos/modules/services/misc/ripple-data-api.nix +++ b/nixos/modules/services/misc/ripple-data-api.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.rippleDataApi; @@ -29,7 +34,8 @@ let }; }; -in { +in +{ options = { services.rippleDataApi = { enable = lib.mkEnableOption "ripple data api"; @@ -43,7 +49,10 @@ in { importMode = lib.mkOption { description = "Ripple data api import mode."; default = "liveOnly"; - type = lib.types.enum ["live" "liveOnly"]; + type = lib.types.enum [ + "live" + "liveOnly" + ]; }; minLedger = lib.mkOption { @@ -133,7 +142,11 @@ in { services.redis.enable = lib.mkDefault true; systemd.services.ripple-data-api = { - after = [ "couchdb.service" "redis.service" "ripple-data-api-importer.service" ]; + after = [ + "couchdb.service" + "redis.service" + "ripple-data-api-importer.service" + ]; wantedBy = [ "multi-user.target" ]; environment = { @@ -161,32 +174,36 @@ in { LOG_FILE = "/dev/null"; }; - serviceConfig = let - importMode = - if cfg.minLedger != null && cfg.maxLedger != null then - "${toString cfg.minLedger} ${toString cfg.maxLedger}" - else - cfg.importMode; - in { - ExecStart = "${pkgs.ripple-data-api}/bin/importer ${importMode} debug"; - Restart = "always"; - User = "ripple-data-api"; - }; + serviceConfig = + let + importMode = + if cfg.minLedger != null && cfg.maxLedger != null then + "${toString cfg.minLedger} ${toString cfg.maxLedger}" + else + cfg.importMode; + in + { + ExecStart = "${pkgs.ripple-data-api}/bin/importer ${importMode} debug"; + Restart = "always"; + User = "ripple-data-api"; + }; preStart = lib.mkMerge [ (lib.mkIf (cfg.couchdb.create) '' - HOST="http://${lib.optionalString (cfg.couchdb.pass != "") "${cfg.couchdb.user}:${cfg.couchdb.pass}@"}${cfg.couchdb.host}:${toString cfg.couchdb.port}" + HOST="http://${ + lib.optionalString (cfg.couchdb.pass != "") "${cfg.couchdb.user}:${cfg.couchdb.pass}@" + }${cfg.couchdb.host}:${toString cfg.couchdb.port}" curl -X PUT $HOST/${cfg.couchdb.db} || true '') "${pkgs.ripple-data-api}/bin/update-views" ]; }; - users.users.ripple-data-api = - { description = "Ripple data api user"; - isSystemUser = true; - group = "ripple-data-api"; - }; - users.groups.ripple-data-api = {}; + users.users.ripple-data-api = { + description = "Ripple data api user"; + isSystemUser = true; + group = "ripple-data-api"; + }; + users.groups.ripple-data-api = { }; }; } diff --git a/nixos/modules/services/misc/rippled.nix b/nixos/modules/services/misc/rippled.nix index 5f011dbee4a6ee..8b1f3c7df11788 100644 --- a/nixos/modules/services/misc/rippled.nix +++ b/nixos/modules/services/misc/rippled.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.rippled; opt = options.services.rippled; @@ -8,154 +14,169 @@ let dbCfg = db: '' type=${db.type} path=${db.path} - ${lib.optionalString (db.compression != null) ("compression=${b2i db.compression}") } + ${lib.optionalString (db.compression != null) ("compression=${b2i db.compression}")} ${lib.optionalString (db.onlineDelete != null) ("online_delete=${toString db.onlineDelete}")} ${lib.optionalString (db.advisoryDelete != null) ("advisory_delete=${b2i db.advisoryDelete}")} ${db.extraOpts} ''; - rippledCfg = '' - [server] - ${lib.concatMapStringsSep "\n" (n: "port_${n}") (lib.attrNames cfg.ports)} - - ${lib.concatMapStrings (p: '' - [port_${p.name}] - ip=${p.ip} - port=${toString p.port} - protocol=${lib.concatStringsSep "," p.protocol} - ${lib.optionalString (p.user != "") "user=${p.user}"} - ${lib.optionalString (p.password != "") "user=${p.password}"} - admin=${lib.concatStringsSep "," p.admin} - ${lib.optionalString (p.ssl.key != null) "ssl_key=${p.ssl.key}"} - ${lib.optionalString (p.ssl.cert != null) "ssl_cert=${p.ssl.cert}"} - ${lib.optionalString (p.ssl.chain != null) "ssl_chain=${p.ssl.chain}"} - '') (lib.attrValues cfg.ports)} - - [database_path] - ${cfg.databasePath} - - [node_db] - ${dbCfg cfg.nodeDb} - - ${lib.optionalString (cfg.tempDb != null) '' - [temp_db] - ${dbCfg cfg.tempDb}''} - - ${lib.optionalString (cfg.importDb != null) '' - [import_db] - ${dbCfg cfg.importDb}''} - - [ips] - ${lib.concatStringsSep "\n" cfg.ips} - - [ips_fixed] - ${lib.concatStringsSep "\n" cfg.ipsFixed} - - [validators] - ${lib.concatStringsSep "\n" cfg.validators} - - [node_size] - ${cfg.nodeSize} - - [ledger_history] - ${toString cfg.ledgerHistory} - - [fetch_depth] - ${toString cfg.fetchDepth} - - [validation_quorum] - ${toString cfg.validationQuorum} - - [sntp_servers] - ${lib.concatStringsSep "\n" cfg.sntpServers} - - ${lib.optionalString cfg.statsd.enable '' - [insight] - server=statsd - address=${cfg.statsd.address} - prefix=${cfg.statsd.prefix} - ''} - - [rpc_startup] - { "command": "log_level", "severity": "${cfg.logLevel}" } - '' + cfg.extraConfig; - - portOptions = { name, ...}: { - options = { - name = lib.mkOption { - internal = true; - default = name; - }; - - ip = lib.mkOption { - default = "127.0.0.1"; - description = "Ip where rippled listens."; - type = lib.types.str; - }; - - port = lib.mkOption { - description = "Port where rippled listens."; - type = lib.types.port; - }; + rippledCfg = + '' + [server] + ${lib.concatMapStringsSep "\n" (n: "port_${n}") (lib.attrNames cfg.ports)} + + ${lib.concatMapStrings (p: '' + [port_${p.name}] + ip=${p.ip} + port=${toString p.port} + protocol=${lib.concatStringsSep "," p.protocol} + ${lib.optionalString (p.user != "") "user=${p.user}"} + ${lib.optionalString (p.password != "") "user=${p.password}"} + admin=${lib.concatStringsSep "," p.admin} + ${lib.optionalString (p.ssl.key != null) "ssl_key=${p.ssl.key}"} + ${lib.optionalString (p.ssl.cert != null) "ssl_cert=${p.ssl.cert}"} + ${lib.optionalString (p.ssl.chain != null) "ssl_chain=${p.ssl.chain}"} + '') (lib.attrValues cfg.ports)} + + [database_path] + ${cfg.databasePath} + + [node_db] + ${dbCfg cfg.nodeDb} + + ${lib.optionalString (cfg.tempDb != null) '' + [temp_db] + ${dbCfg cfg.tempDb}''} + + ${lib.optionalString (cfg.importDb != null) '' + [import_db] + ${dbCfg cfg.importDb}''} + + [ips] + ${lib.concatStringsSep "\n" cfg.ips} + + [ips_fixed] + ${lib.concatStringsSep "\n" cfg.ipsFixed} + + [validators] + ${lib.concatStringsSep "\n" cfg.validators} + + [node_size] + ${cfg.nodeSize} + + [ledger_history] + ${toString cfg.ledgerHistory} + + [fetch_depth] + ${toString cfg.fetchDepth} + + [validation_quorum] + ${toString cfg.validationQuorum} + + [sntp_servers] + ${lib.concatStringsSep "\n" cfg.sntpServers} + + ${lib.optionalString cfg.statsd.enable '' + [insight] + server=statsd + address=${cfg.statsd.address} + prefix=${cfg.statsd.prefix} + ''} + + [rpc_startup] + { "command": "log_level", "severity": "${cfg.logLevel}" } + '' + + cfg.extraConfig; + + portOptions = + { name, ... }: + { + options = { + name = lib.mkOption { + internal = true; + default = name; + }; - protocol = lib.mkOption { - description = "Protocols expose by rippled."; - type = lib.types.listOf (lib.types.enum ["http" "https" "ws" "wss" "peer"]); - }; + ip = lib.mkOption { + default = "127.0.0.1"; + description = "Ip where rippled listens."; + type = lib.types.str; + }; - user = lib.mkOption { - description = "When set, these credentials will be required on HTTP/S requests."; - type = lib.types.str; - default = ""; - }; + port = lib.mkOption { + description = "Port where rippled listens."; + type = lib.types.port; + }; - password = lib.mkOption { - description = "When set, these credentials will be required on HTTP/S requests."; - type = lib.types.str; - default = ""; - }; + protocol = lib.mkOption { + description = "Protocols expose by rippled."; + type = lib.types.listOf ( + lib.types.enum [ + "http" + "https" + "ws" + "wss" + "peer" + ] + ); + }; - admin = lib.mkOption { - description = "A comma-separated list of admin IP addresses."; - type = lib.types.listOf lib.types.str; - default = ["127.0.0.1"]; - }; + user = lib.mkOption { + description = "When set, these credentials will be required on HTTP/S requests."; + type = lib.types.str; + default = ""; + }; - ssl = { - key = lib.mkOption { - description = '' - Specifies the filename holding the SSL key in PEM format. - ''; - default = null; - type = lib.types.nullOr lib.types.path; + password = lib.mkOption { + description = "When set, these credentials will be required on HTTP/S requests."; + type = lib.types.str; + default = ""; }; - cert = lib.mkOption { - description = '' - Specifies the path to the SSL certificate file in PEM format. - This is not needed if the chain includes it. - ''; - default = null; - type = lib.types.nullOr lib.types.path; + admin = lib.mkOption { + description = "A comma-separated list of admin IP addresses."; + type = lib.types.listOf lib.types.str; + default = [ "127.0.0.1" ]; }; - chain = lib.mkOption { - description = '' - If you need a certificate chain, specify the path to the - certificate chain here. The chain may include the end certificate. - ''; - default = null; - type = lib.types.nullOr lib.types.path; + ssl = { + key = lib.mkOption { + description = '' + Specifies the filename holding the SSL key in PEM format. + ''; + default = null; + type = lib.types.nullOr lib.types.path; + }; + + cert = lib.mkOption { + description = '' + Specifies the path to the SSL certificate file in PEM format. + This is not needed if the chain includes it. + ''; + default = null; + type = lib.types.nullOr lib.types.path; + }; + + chain = lib.mkOption { + description = '' + If you need a certificate chain, specify the path to the + certificate chain here. The chain may include the end certificate. + ''; + default = null; + type = lib.types.nullOr lib.types.path; + }; }; }; }; - }; dbOptions = { options = { type = lib.mkOption { description = "Rippled database type."; - type = lib.types.enum ["rocksdb" "nudb"]; + type = lib.types.enum [ + "rocksdb" + "nudb" + ]; default = "rocksdb"; }; @@ -214,20 +235,23 @@ in default = { rpc = { port = 5005; - admin = ["127.0.0.1"]; - protocol = ["http"]; + admin = [ "127.0.0.1" ]; + protocol = [ "http" ]; }; peer = { port = 51235; ip = "0.0.0.0"; - protocol = ["peer"]; + protocol = [ "peer" ]; }; ws_public = { port = 5006; ip = "0.0.0.0"; - protocol = ["ws" "wss"]; + protocol = [ + "ws" + "wss" + ]; }; }; }; @@ -264,7 +288,13 @@ in Rippled size of the node you are running. "tiny", "small", "medium", "large", and "huge" ''; - type = lib.types.enum ["tiny" "small" "medium" "large" "huge"]; + type = lib.types.enum [ + "tiny" + "small" + "medium" + "large" + "huge" + ]; default = "small"; }; @@ -280,7 +310,7 @@ in to least trusted. ''; type = lib.types.listOf lib.types.str; - default = ["r.ripple.com 51235"]; + default = [ "r.ripple.com 51235" ]; }; ipsFixed = lib.mkOption { @@ -294,7 +324,7 @@ in A port may optionally be specified after adding a space to the address ''; type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; }; validators = lib.mkOption { @@ -334,7 +364,7 @@ in The number of past ledgers to acquire on server startup and the minimum to maintain while running. ''; - type = lib.types.either lib.types.int (lib.types.enum ["full"]); + type = lib.types.either lib.types.int (lib.types.enum [ "full" ]); default = 1296000; # 1 month }; @@ -343,7 +373,7 @@ in The number of past ledgers to serve to other peers that request historical ledger data (or "full" for no limit). ''; - type = lib.types.either lib.types.int (lib.types.enum ["full"]); + type = lib.types.either lib.types.int (lib.types.enum [ "full" ]); default = "full"; }; @@ -362,7 +392,11 @@ in logLevel = lib.mkOption { description = "Logging verbosity."; - type = lib.types.enum ["debug" "error" "info"]; + type = lib.types.enum [ + "debug" + "error" + "info" + ]; default = "error"; }; @@ -398,19 +432,18 @@ in }; }; - ###### implementation config = lib.mkIf cfg.enable { users.users.rippled = { - description = "Ripple server user"; - isSystemUser = true; - group = "rippled"; - home = cfg.databasePath; - createHome = true; - }; - users.groups.rippled = {}; + description = "Ripple server user"; + isSystemUser = true; + group = "rippled"; + home = cfg.databasePath; + createHome = true; + }; + users.groups.rippled = { }; systemd.services.rippled = { after = [ "network.target" ]; @@ -420,7 +453,7 @@ in ExecStart = "${cfg.package}/bin/rippled --fg --conf ${cfg.config}"; User = "rippled"; Restart = "on-failure"; - LimitNOFILE=10000; + LimitNOFILE = 10000; }; }; diff --git a/nixos/modules/services/misc/rkvm.nix b/nixos/modules/services/misc/rkvm.nix index 805b2923bb0f64..f2f0d95ecf235f 100644 --- a/nixos/modules/services/misc/rkvm.nix +++ b/nixos/modules/services/misc/rkvm.nix @@ -1,4 +1,10 @@ -{ options, config, pkgs, lib, ... }: +{ + options, + config, + pkgs, + lib, + ... +}: let opt = options.services.rkvm; cfg = config.services.rkvm; @@ -23,61 +29,63 @@ in enable = lib.mkEnableOption "the rkvm server daemon (input transmitter)"; settings = lib.mkOption { - type = lib.types.submodule - { - freeformType = toml.type; - options = { - listen = lib.mkOption { - type = lib.types.str; - default = "0.0.0.0:5258"; - description = '' - An internet socket address to listen on, either IPv4 or IPv6. - ''; - }; - - switch-keys = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = [ "left-alt" "left-ctrl" ]; - description = '' - A key list specifying a host switch combination. - - _A list of key names is available in ._ - ''; - }; - - certificate = lib.mkOption { - type = lib.types.path; - default = "/etc/rkvm/certificate.pem"; - description = '' - TLS certificate path. - - ::: {.note} - This should be generated with {command}`rkvm-certificate-gen`. - ::: - ''; - }; - - key = lib.mkOption { - type = lib.types.path; - default = "/etc/rkvm/key.pem"; - description = '' - TLS key path. - - ::: {.note} - This should be generated with {command}`rkvm-certificate-gen`. - ::: - ''; - }; - - password = lib.mkOption { - type = lib.types.str; - description = '' - Shared secret token to authenticate the client. - Make sure this matches your client's config. - ''; - }; + type = lib.types.submodule { + freeformType = toml.type; + options = { + listen = lib.mkOption { + type = lib.types.str; + default = "0.0.0.0:5258"; + description = '' + An internet socket address to listen on, either IPv4 or IPv6. + ''; + }; + + switch-keys = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ + "left-alt" + "left-ctrl" + ]; + description = '' + A key list specifying a host switch combination. + + _A list of key names is available in ._ + ''; + }; + + certificate = lib.mkOption { + type = lib.types.path; + default = "/etc/rkvm/certificate.pem"; + description = '' + TLS certificate path. + + ::: {.note} + This should be generated with {command}`rkvm-certificate-gen`. + ::: + ''; + }; + + key = lib.mkOption { + type = lib.types.path; + default = "/etc/rkvm/key.pem"; + description = '' + TLS key path. + + ::: {.note} + This should be generated with {command}`rkvm-certificate-gen`. + ::: + ''; + }; + + password = lib.mkOption { + type = lib.types.str; + description = '' + Shared secret token to authenticate the client. + Make sure this matches your client's config. + ''; }; }; + }; default = { }; description = "Structured server daemon configuration"; @@ -88,41 +96,40 @@ in enable = lib.mkEnableOption "the rkvm client daemon (input receiver)"; settings = lib.mkOption { - type = lib.types.submodule - { - freeformType = toml.type; - options = { - server = lib.mkOption { - type = lib.types.str; - example = "192.168.0.123:5258"; - description = '' - An RKVM server's internet socket address, either IPv4 or IPv6. - ''; - }; - - certificate = lib.mkOption { - type = lib.types.path; - default = "/etc/rkvm/certificate.pem"; - description = '' - TLS ceritficate path. - - ::: {.note} - This should be generated with {command}`rkvm-certificate-gen`. - ::: - ''; - }; - - password = lib.mkOption { - type = lib.types.str; - description = '' - Shared secret token to authenticate the client. - Make sure this matches your server's config. - ''; - }; + type = lib.types.submodule { + freeformType = toml.type; + options = { + server = lib.mkOption { + type = lib.types.str; + example = "192.168.0.123:5258"; + description = '' + An RKVM server's internet socket address, either IPv4 or IPv6. + ''; + }; + + certificate = lib.mkOption { + type = lib.types.path; + default = "/etc/rkvm/certificate.pem"; + description = '' + TLS ceritficate path. + + ::: {.note} + This should be generated with {command}`rkvm-certificate-gen`. + ::: + ''; + }; + + password = lib.mkOption { + type = lib.types.str; + description = '' + Shared secret token to authenticate the client. + Make sure this matches your server's config. + ''; }; }; + }; - default = {}; + default = { }; description = "Structured client daemon configuration"; }; }; @@ -137,16 +144,22 @@ in mkBase = component: { description = "RKVM ${component}"; wantedBy = [ "multi-user.target" ]; - after = { - server = [ "network.target" ]; - client = [ "network-online.target" ]; - }.${component}; - wants = { - server = [ ]; - client = [ "network-online.target" ]; - }.${component}; + after = + { + server = [ "network.target" ]; + client = [ "network-online.target" ]; + } + .${component}; + wants = + { + server = [ ]; + client = [ "network-online.target" ]; + } + .${component}; serviceConfig = { - ExecStart = "${cfg.package}/bin/rkvm-${component} ${toml.generate "rkvm-${component}.toml" cfg.${component}.settings}"; + ExecStart = "${cfg.package}/bin/rkvm-${component} ${ + toml.generate "rkvm-${component}.toml" cfg.${component}.settings + }"; Restart = "always"; RestartSec = 5; Type = "simple"; diff --git a/nixos/modules/services/misc/rshim.nix b/nixos/modules/services/misc/rshim.nix index 4a66f61fa40a7e..e52135893b411a 100644 --- a/nixos/modules/services/misc/rshim.nix +++ b/nixos/modules/services/misc/rshim.nix @@ -1,14 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.rshim; - rshimCommand = [ "${cfg.package}/bin/rshim" ] + rshimCommand = + [ "${cfg.package}/bin/rshim" ] ++ lib.optionals (cfg.backend != null) [ "--backend ${cfg.backend}" ] ++ lib.optionals (cfg.device != null) [ "--device ${cfg.device}" ] ++ lib.optionals (cfg.index != null) [ "--index ${builtins.toString cfg.index}" ] - ++ [ "--log-level ${builtins.toString cfg.log-level}" ] - ; + ++ [ "--log-level ${builtins.toString cfg.log-level}" ]; in { options.services.rshim = { @@ -17,7 +22,13 @@ in package = lib.mkPackageOption pkgs "rshim-user-space" { }; backend = lib.mkOption { - type = with lib.types; nullOr (enum [ "usb" "pcie" "pcie_lf" ]); + type = + with lib.types; + nullOr (enum [ + "usb" + "pcie" + "pcie_lf" + ]); description = '' Specify the backend to attach. If not specified, the driver will scan all rshim backends unless the `device` option is given with a device @@ -58,7 +69,12 @@ in }; config = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ int str ]); + type = + with lib.types; + attrsOf (oneOf [ + int + str + ]); description = '' Structural setting for the rshim configuration file (`/etc/rshim.conf`). It can be used to specify the static mapping @@ -76,9 +92,9 @@ in config = lib.mkIf cfg.enable { environment.etc = lib.mkIf (cfg.config != { }) { - "rshim.conf".text = lib.generators.toKeyValue - { mkKeyValue = lib.generators.mkKeyValueDefault { } " "; } - cfg.config; + "rshim.conf".text = lib.generators.toKeyValue { + mkKeyValue = lib.generators.mkKeyValueDefault { } " "; + } cfg.config; }; systemd.services.rshim = { diff --git a/nixos/modules/services/misc/safeeyes.nix b/nixos/modules/services/misc/safeeyes.nix index 1d225e4b39d938..c3c8d7b8a3ff68 100644 --- a/nixos/modules/services/misc/safeeyes.nix +++ b/nixos/modules/services/misc/safeeyes.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.safeeyes; @@ -29,7 +34,7 @@ in description = "Safeeyes"; wantedBy = [ "graphical-session.target" ]; - partOf = [ "graphical-session.target" ]; + partOf = [ "graphical-session.target" ]; startLimitIntervalSec = 350; startLimitBurst = 10; diff --git a/nixos/modules/services/misc/serviio.nix b/nixos/modules/services/misc/serviio.nix index 60b6113c5e090c..4553a125418e0b 100644 --- a/nixos/modules/services/misc/serviio.nix +++ b/nixos/modules/services/misc/serviio.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.serviio; @@ -19,7 +24,8 @@ let exec ${pkgs.jre}/bin/java -Xmx512M -Xms20M -XX:+UseG1GC -XX:GCTimeRatio=1 -XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=20 $JAVA_OPTS -classpath "$SERVIIO_CLASS_PATH" org.serviio.MediaServer "$@" ''; -in { +in +{ ###### interface options = { @@ -60,19 +66,19 @@ in { }; }; - users.users.serviio = - { group = "serviio"; - home = cfg.dataDir; - description = "Serviio Media Server User"; - createHome = true; - isSystemUser = true; - }; + users.users.serviio = { + group = "serviio"; + home = cfg.dataDir; + description = "Serviio Media Server User"; + createHome = true; + isSystemUser = true; + }; users.groups.serviio = { }; networking.firewall = { allowedTCPPorts = [ - 8895 # serve UPnP responses + 8895 # serve UPnP responses 23423 # console 23424 # mediabrowser ]; diff --git a/nixos/modules/services/misc/sickbeard.nix b/nixos/modules/services/misc/sickbeard.nix index 237abf7185a327..7c6205c7793ac3 100644 --- a/nixos/modules/services/misc/sickbeard.nix +++ b/nixos/modules/services/misc/sickbeard.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let name = "sickbeard"; @@ -55,7 +61,6 @@ in }; }; - ###### implementation config = lib.mkIf cfg.enable { @@ -76,7 +81,7 @@ in systemd.services.sickbeard = { description = "Sickbeard Server"; - wantedBy = [ "multi-user.target" ]; + wantedBy = [ "multi-user.target" ]; after = [ "network.target" ]; serviceConfig = { diff --git a/nixos/modules/services/misc/signald.nix b/nixos/modules/services/misc/signald.nix index 8a4ce1cc17b634..90b18440191743 100644 --- a/nixos/modules/services/misc/signald.nix +++ b/nixos/modules/services/misc/signald.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.signald; dataDir = "/var/lib/signald"; @@ -89,12 +94,19 @@ in ProtectKernelModules = true; ProtectKernelTunables = true; ProtectProc = "invisible"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged @resources @setuid @keyring" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged @resources @setuid @keyring" + ]; TemporaryFileSystem = "/:ro"; # Does not work well with the temporary root #UMask = "0066"; diff --git a/nixos/modules/services/misc/siproxd.nix b/nixos/modules/services/misc/siproxd.nix index f941ded123957e..822fc7b8d48065 100644 --- a/nixos/modules/services/misc/siproxd.nix +++ b/nixos/modules/services/misc/siproxd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.siproxd; @@ -14,9 +19,15 @@ let rtp_port_high = ${toString cfg.rtpPortHigh} rtp_dscp = ${toString cfg.rtpDscp} sip_dscp = ${toString cfg.sipDscp} - ${lib.optionalString (cfg.hostsAllowReg != []) "hosts_allow_reg = ${lib.concatStringsSep "," cfg.hostsAllowReg}"} - ${lib.optionalString (cfg.hostsAllowSip != []) "hosts_allow_sip = ${lib.concatStringsSep "," cfg.hostsAllowSip}"} - ${lib.optionalString (cfg.hostsDenySip != []) "hosts_deny_sip = ${lib.concatStringsSep "," cfg.hostsDenySip}"} + ${lib.optionalString ( + cfg.hostsAllowReg != [ ] + ) "hosts_allow_reg = ${lib.concatStringsSep "," cfg.hostsAllowReg}"} + ${lib.optionalString ( + cfg.hostsAllowSip != [ ] + ) "hosts_allow_sip = ${lib.concatStringsSep "," cfg.hostsAllowSip}"} + ${lib.optionalString ( + cfg.hostsDenySip != [ ] + ) "hosts_deny_sip = ${lib.concatStringsSep "," cfg.hostsDenySip}"} ${lib.optionalString (cfg.passwordFile != "") "proxy_auth_pwfile = ${cfg.passwordFile}"} ${cfg.extraConfig} ''; @@ -55,7 +66,10 @@ in hostsAllowReg = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "192.168.1.0/24" "192.168.2.0/24" ]; + example = [ + "192.168.1.0/24" + "192.168.2.0/24" + ]; description = '' Access control list for incoming SIP registrations. ''; @@ -64,7 +78,10 @@ in hostsAllowSip = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "123.45.0.0/16" "123.46.0.0/16" ]; + example = [ + "123.45.0.0/16" + "123.46.0.0/16" + ]; description = '' Access control list for incoming SIP traffic. ''; @@ -73,7 +90,10 @@ in hostsDenySip = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "10.0.0.0/8" "11.0.0.0/8" ]; + example = [ + "10.0.0.0/8" + "11.0.0.0/8" + ]; description = '' Access control list for denying incoming SIP registrations and traffic. @@ -92,7 +112,7 @@ in type = lib.types.int; default = 7070; description = '' - Bottom of UDP port range for incoming and outgoing RTP traffic + Bottom of UDP port range for incoming and outgoing RTP traffic ''; }; @@ -100,7 +120,7 @@ in type = lib.types.int; default = 7089; description = '' - Top of UDP port range for incoming and outgoing RTP traffic + Top of UDP port range for incoming and outgoing RTP traffic ''; }; diff --git a/nixos/modules/services/misc/soft-serve.nix b/nixos/modules/services/misc/soft-serve.nix index 9a3fb1af9b8136..e9719c02e41e66 100644 --- a/nixos/modules/services/misc/soft-serve.nix +++ b/nixos/modules/services/misc/soft-serve.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.soft-serve; configFile = format.generate "config.yaml" cfg.settings; @@ -76,7 +81,11 @@ in ProtectKernelModules = true; ProtectKernelLogs = true; ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; LockPersonality = true; MemoryDenyWriteExecute = true; diff --git a/nixos/modules/services/misc/sonarr.nix b/nixos/modules/services/misc/sonarr.nix index b147bf9e69f498..65f43df08312e0 100644 --- a/nixos/modules/services/misc/sonarr.nix +++ b/nixos/modules/services/misc/sonarr.nix @@ -1,4 +1,10 @@ -{ config, pkgs, lib, utils, ... }: +{ + config, + pkgs, + lib, + utils, + ... +}: let cfg = config.services.sonarr; in diff --git a/nixos/modules/services/misc/sourcehut/default.nix b/nixos/modules/services/misc/sourcehut/default.nix index 94a96dba6790ff..ebce033fd55c13 100644 --- a/nixos/modules/services/misc/sourcehut/default.nix +++ b/nixos/modules/services/misc/sourcehut/default.nix @@ -1,59 +1,113 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let inherit (builtins) head tail; inherit (lib) generators maintainers types; - inherit (lib.attrsets) attrValues filterAttrs mapAttrs mapAttrsToList recursiveUpdate; + inherit (lib.attrsets) + attrValues + filterAttrs + mapAttrs + mapAttrsToList + recursiveUpdate + ; inherit (lib.lists) flatten optional optionals; - inherit (lib.options) literalExpression mkEnableOption mkOption mkPackageOption; - inherit (lib.strings) concatMapStringsSep concatStringsSep optionalString versionOlder; + inherit (lib.options) + literalExpression + mkEnableOption + mkOption + mkPackageOption + ; + inherit (lib.strings) + concatMapStringsSep + concatStringsSep + optionalString + versionOlder + ; inherit (lib.trivial) mapNullable; - inherit (lib.modules) mkBefore mkDefault mkForce mkIf mkMerge - mkRemovedOptionModule mkRenamedOptionModule; - inherit (config.services) nginx postfix postgresql redis; + inherit (lib.modules) + mkBefore + mkDefault + mkForce + mkIf + mkMerge + mkRemovedOptionModule + mkRenamedOptionModule + ; + inherit (config.services) + nginx + postfix + postgresql + redis + ; inherit (config.users) users groups; cfg = config.services.sourcehut; domain = cfg.settings."sr.ht".global-domain; settingsFormat = pkgs.formats.ini { - listToValue = concatMapStringsSep "," (generators.mkValueStringDefault {}); - mkKeyValue = k: v: - optionalString (v != null) - (generators.mkKeyValueDefault { - mkValueString = v: - if v == true then "yes" - else if v == false then "no" - else generators.mkValueStringDefault {} v; - } "=" k v); + listToValue = concatMapStringsSep "," (generators.mkValueStringDefault { }); + mkKeyValue = + k: v: + optionalString (v != null) ( + generators.mkKeyValueDefault { + mkValueString = + v: + if v == true then + "yes" + else if v == false then + "no" + else + generators.mkValueStringDefault { } v; + } "=" k v + ); }; - configIniOfService = srv: settingsFormat.generate "sourcehut-${srv}-config.ini" - # Each service needs access to only a subset of sections (and secrets). - (filterAttrs (k: v: v != null) - (mapAttrs (section: v: - let srvMatch = builtins.match "^([a-z]*)\\.sr\\.ht(::.*)?$" section; in - if srvMatch == null # Include sections shared by all services - || head srvMatch == srv # Include sections for the service being configured - then v - # Enable Web links and integrations between services. - else if tail srvMatch == [ null ] && cfg.${head srvMatch}.enable - then { - inherit (v) origin; - # mansrht crashes without it - oauth-client-id = v.oauth-client-id or null; - } - # Drop sub-sections of other services - else null) - (recursiveUpdate cfg.settings { - # Those paths are mounted using BindPaths= or BindReadOnlyPaths= - # for services needing access to them. - "builds.sr.ht::worker".buildlogs = "/var/log/sourcehut/buildsrht-worker"; - "git.sr.ht".post-update-script = "/usr/bin/gitsrht-update-hook"; - "git.sr.ht".repos = cfg.settings."git.sr.ht".repos; - "hg.sr.ht".changegroup-script = "/usr/bin/hgsrht-hook-changegroup"; - "hg.sr.ht".repos = cfg.settings."hg.sr.ht".repos; - # Making this a per service option despite being in a global section, - # so that it uses the redis-server used by the service. - "sr.ht".redis-host = cfg.${srv}.redis.host; - }))); + configIniOfService = + srv: + settingsFormat.generate "sourcehut-${srv}-config.ini" + # Each service needs access to only a subset of sections (and secrets). + ( + filterAttrs (k: v: v != null) ( + mapAttrs + ( + section: v: + let + srvMatch = builtins.match "^([a-z]*)\\.sr\\.ht(::.*)?$" section; + in + if + srvMatch == null # Include sections shared by all services + || head srvMatch == srv # Include sections for the service being configured + then + v + # Enable Web links and integrations between services. + else if tail srvMatch == [ null ] && cfg.${head srvMatch}.enable then + { + inherit (v) origin; + # mansrht crashes without it + oauth-client-id = v.oauth-client-id or null; + } + # Drop sub-sections of other services + else + null + ) + ( + recursiveUpdate cfg.settings { + # Those paths are mounted using BindPaths= or BindReadOnlyPaths= + # for services needing access to them. + "builds.sr.ht::worker".buildlogs = "/var/log/sourcehut/buildsrht-worker"; + "git.sr.ht".post-update-script = "/usr/bin/gitsrht-update-hook"; + "git.sr.ht".repos = cfg.settings."git.sr.ht".repos; + "hg.sr.ht".changegroup-script = "/usr/bin/hgsrht-hook-changegroup"; + "hg.sr.ht".repos = cfg.settings."hg.sr.ht".repos; + # Making this a per service option despite being in a global section, + # so that it uses the redis-server used by the service. + "sr.ht".redis-host = cfg.${srv}.redis.host; + } + ) + ) + ); commonServiceSettings = srv: { origin = mkOption { description = "URL ${srv}.sr.ht is being served at (protocol://domain)"; @@ -76,7 +130,9 @@ let type = types.str; default = "postgresql:///localhost?user=${srv}srht&host=/run/postgresql"; }; - migrate-on-upgrade = mkEnableOption "automatic migrations on package upgrade" // { default = true; }; + migrate-on-upgrade = mkEnableOption "automatic migrations on package upgrade" // { + default = true; + }; oauth-client-id = mkOption { description = "${srv}.sr.ht's OAuth client id for meta.sr.ht."; type = types.str; @@ -97,30 +153,34 @@ let }; # Specialized python containing all the modules - python = pkgs.sourcehut.python.withPackages (ps: with ps; [ - gunicorn - eventlet - # For monitoring Celery: sudo -u listssrht celery --app listssrht.process -b redis+socket:///run/redis-sourcehut/redis.sock?virtual_host=1 flower - flower - # Sourcehut services - srht - buildsrht - gitsrht - hgsrht - hubsrht - listssrht - mansrht - metasrht - # Not a python package - #pagessrht - pastesrht - todosrht - ]); - mkOptionNullOrStr = description: mkOption { - description = description; - type = with types; nullOr str; - default = null; - }; + python = pkgs.sourcehut.python.withPackages ( + ps: with ps; [ + gunicorn + eventlet + # For monitoring Celery: sudo -u listssrht celery --app listssrht.process -b redis+socket:///run/redis-sourcehut/redis.sock?virtual_host=1 flower + flower + # Sourcehut services + srht + buildsrht + gitsrht + hgsrht + hubsrht + listssrht + mansrht + metasrht + # Not a python package + #pagessrht + pastesrht + todosrht + ] + ); + mkOptionNullOrStr = + description: + mkOption { + description = description; + type = with types; nullOr str; + default = null; + }; in { options.services.sourcehut = { @@ -153,7 +213,7 @@ in enable = mkEnableOption ''local nginx integration''; virtualHost = mkOption { type = types.attrs; - default = {}; + default = { }; description = "Virtual-host configuration merged with all Sourcehut's virtual-hosts."; }; }; @@ -181,7 +241,10 @@ in }; environment = mkOption { description = "Values other than \"production\" adds a banner to each page."; - type = types.enum [ "development" "production" ]; + type = types.enum [ + "development" + "production" + ]; default = "development"; }; network-key = mkOption { @@ -323,7 +386,10 @@ in If master and worker are on the same system set to `/usr/bin/runner-shell`. ''; - type = types.enum ["/usr/bin/master-shell" "/usr/bin/runner-shell"]; + type = types.enum [ + "/usr/bin/master-shell" + "/usr/bin/runner-shell" + ]; default = "/usr/bin/master-shell"; }; }; @@ -397,7 +463,10 @@ in See [](#opt-services.sourcehut.listenAddress). ''; type = with types; listOf str; - default = [ "127.0.0.0/8" "::1/128" ]; + default = [ + "127.0.0.0/8" + "::1/128" + ]; }; }; @@ -478,7 +547,7 @@ in Uses fnmatch for wildcard expansion. ''; type = with types; listOf str; - default = ["text/html"]; + default = [ "text/html" ]; }; reject-url = mkOption { description = "Reject URL."; @@ -507,15 +576,18 @@ in }; options."meta.sr.ht" = - removeAttrs (commonServiceSettings "meta") - ["oauth-client-id" "oauth-client-secret"] // { - webhooks = mkOption { - description = "The Redis connection used for the webhooks worker."; - type = types.str; - default = "redis+socket:///run/redis-sourcehut-metasrht/redis.sock?virtual_host=1"; + removeAttrs (commonServiceSettings "meta") [ + "oauth-client-id" + "oauth-client-secret" + ] + // { + webhooks = mkOption { + description = "The Redis connection used for the webhooks worker."; + type = types.str; + default = "redis+socket:///run/redis-sourcehut-metasrht/redis.sock?virtual_host=1"; + }; + welcome-emails = mkEnableOption "sending stock sourcehut welcome emails after signup"; }; - welcome-emails = mkEnableOption "sending stock sourcehut welcome emails after signup"; - }; options."meta.sr.ht::api" = { internal-ipnet = mkOption { description = '' @@ -525,24 +597,31 @@ in See [](#opt-services.sourcehut.listenAddress). ''; type = with types; listOf str; - default = [ "127.0.0.0/8" "::1/128" ]; + default = [ + "127.0.0.0/8" + "::1/128" + ]; }; }; options."meta.sr.ht::aliases" = mkOption { description = "Aliases for the client IDs of commonly used OAuth clients."; type = with types; attrsOf int; - default = {}; - example = { "git.sr.ht" = 12345; }; + default = { }; + example = { + "git.sr.ht" = 12345; + }; }; options."meta.sr.ht::billing" = { enabled = mkEnableOption "the billing system"; stripe-public-key = mkOptionNullOrStr "Public key for Stripe. Get your keys at https://dashboard.stripe.com/account/apikeys"; - stripe-secret-key = mkOptionNullOrStr '' - An absolute file path (which should be outside the Nix-store) - to a secret key for Stripe. Get your keys at https://dashboard.stripe.com/account/apikeys - '' // { - apply = mapNullable (s: "<" + toString s); - }; + stripe-secret-key = + mkOptionNullOrStr '' + An absolute file path (which should be outside the Nix-store) + to a secret key for Stripe. Get your keys at https://dashboard.stripe.com/account/apikeys + '' + // { + apply = mapNullable (s: "<" + toString s); + }; }; options."meta.sr.ht::settings" = { registration = mkEnableOption "public registration"; @@ -593,7 +672,10 @@ in See [](#opt-services.sourcehut.listenAddress). ''; type = with types; listOf str; - default = [ "127.0.0.0/8" "::1/128" ]; + default = [ + "127.0.0.0/8" + "::1/128" + ]; }; }; @@ -658,21 +740,22 @@ in images = mkOption { type = with types; attrsOf (attrsOf (attrsOf package)); default = { }; - example = lib.literalExpression ''(let - # Pinning unstable to allow usage with flakes and limit rebuilds. - pkgs_unstable = builtins.fetchGit { - url = "https://github.com/NixOS/nixpkgs"; - rev = "ff96a0fa5635770390b184ae74debea75c3fd534"; - ref = "nixos-unstable"; - }; - image_from_nixpkgs = (import ("''${pkgs.sourcehut.buildsrht}/lib/images/nixos/image.nix") { - pkgs = (import pkgs_unstable {}); - }); - in - { - nixos.unstable.x86_64 = image_from_nixpkgs; - } - )''; + example = lib.literalExpression '' + (let + # Pinning unstable to allow usage with flakes and limit rebuilds. + pkgs_unstable = builtins.fetchGit { + url = "https://github.com/NixOS/nixpkgs"; + rev = "ff96a0fa5635770390b184ae74debea75c3fd534"; + ref = "nixos-unstable"; + }; + image_from_nixpkgs = (import ("''${pkgs.sourcehut.buildsrht}/lib/images/nixos/image.nix") { + pkgs = (import pkgs_unstable {}); + }); + in + { + nixos.unstable.x86_64 = image_from_nixpkgs; + } + )''; description = '' Images for builds.sr.ht. Each package should be distro.release.arch and point to a /nix/store/package/root.img.qcow2. ''; @@ -705,7 +788,11 @@ in process = { extraArgs = mkOption { type = with types; listOf str; - default = [ "--loglevel DEBUG" "--pool eventlet" "--without-heartbeat" ]; + default = [ + "--loglevel DEBUG" + "--pool eventlet" + "--without-heartbeat" + ]; description = "Extra arguments passed to the Celery responsible for processing mails."; }; celeryConfig = mkOption { @@ -732,14 +819,16 @@ in } (mkIf cfg.postgresql.enable { assertions = [ - { assertion = postgresql.enable; + { + assertion = postgresql.enable; message = "postgresql must be enabled and configured"; } ]; }) (mkIf cfg.postfix.enable { assertions = [ - { assertion = postfix.enable; + { + assertion = postfix.enable; message = "postfix must be enabled and configured"; } ]; @@ -751,7 +840,8 @@ in }) (mkIf cfg.nginx.enable { assertions = [ - { assertion = nginx.enable; + { + assertion = nginx.enable; message = "nginx must be enabled and configured"; } ]; @@ -777,8 +867,7 @@ in }; environment.etc."ssh/sourcehut/config.ini".source = settingsFormat.generate "sourcehut-dispatch-config.ini" - (filterAttrs (k: v: k == "git.sr.ht::dispatch") - cfg.settings); + (filterAttrs (k: v: k == "git.sr.ht::dispatch") cfg.settings); environment.etc."ssh/sourcehut/subdir/srht-dispatch" = { # sshd_config(5): The program must be owned by root, not writable by group or others mode = "0755"; @@ -789,23 +878,29 @@ in ${pkgs.sourcehut.gitsrht}/bin/gitsrht-dispatch "$@" ''; }; - systemd.tmpfiles.settings."10-sourcehut-gitsrht" = mkIf cfg.git.enable ( - mkMerge [ - (builtins.listToAttrs (map (name: { - name = "/var/log/sourcehut/gitsrht-${name}"; - value.f = { - inherit (cfg.git) user group; - mode = "0644"; - }; - }) [ "keys" "shell" "update-hook" ])) - { - ${cfg.settings."git.sr.ht".repos}.d = { - inherit (cfg.git) user group; - mode = "0644"; - }; - } - ] - ); + systemd.tmpfiles.settings."10-sourcehut-gitsrht" = mkIf cfg.git.enable (mkMerge [ + (builtins.listToAttrs ( + map + (name: { + name = "/var/log/sourcehut/gitsrht-${name}"; + value.f = { + inherit (cfg.git) user group; + mode = "0644"; + }; + }) + [ + "keys" + "shell" + "update-hook" + ] + )) + { + ${cfg.settings."git.sr.ht".repos}.d = { + inherit (cfg.git) user group; + mode = "0644"; + }; + } + ]); systemd.services.sshd = { preStart = mkIf cfg.hg.enable '' chown ${cfg.hg.user}:${cfg.hg.group} /var/log/sourcehut/hgsrht-keys @@ -828,8 +923,8 @@ in ''}:/usr/bin/buildsrht-keys" "${pkgs.sourcehut.buildsrht}/bin/master-shell:/usr/bin/master-shell" "${pkgs.sourcehut.buildsrht}/bin/runner-shell:/usr/bin/runner-shell" - ] ++ - optionals cfg.git.enable [ + ] + ++ optionals cfg.git.enable [ # /path/to/gitsrht-keys calls /path/to/gitsrht-shell, # or [git.sr.ht] shell= if set. "${pkgs.writeShellScript "gitsrht-keys-wrapper" '' @@ -858,8 +953,8 @@ in exec -a "$0" ${pkgs.sourcehut.gitsrht}/bin/gitsrht-update-hook "$@" fi ''}:/usr/bin/gitsrht-update-hook" - ] ++ - optionals cfg.hg.enable [ + ] + ++ optionals cfg.hg.enable [ # /path/to/hgsrht-keys calls /path/to/hgsrht-shell, # or [hg.sr.ht] shell= if set. "${pkgs.writeShellScript "hgsrht-keys-wrapper" '' @@ -895,336 +990,394 @@ in extraServices.buildsrht-api = { serviceConfig.Restart = "always"; serviceConfig.RestartSec = "5s"; - serviceConfig.ExecStart = "${pkgs.sourcehut.buildsrht}/bin/buildsrht-api -b ${cfg.listenAddress}:${toString (cfg.builds.port + 100)}"; + serviceConfig.ExecStart = "${pkgs.sourcehut.buildsrht}/bin/buildsrht-api -b ${cfg.listenAddress}:${ + toString (cfg.builds.port + 100) + }"; }; # TODO: a celery worker on the master and worker are apparently needed - extraServices.buildsrht-worker = let - qemuPackage = pkgs.qemu_kvm; - serviceName = "buildsrht-worker"; - statePath = "/var/lib/sourcehut/${serviceName}"; - in mkIf cfg.builds.enableWorker { - path = [ pkgs.openssh pkgs.docker ]; - preStart = '' - set -x - if test -z "$(docker images -q qemu:latest 2>/dev/null)" \ - || test "$(cat ${statePath}/docker-image-qemu)" != "${qemuPackage.version}" - then - # Create and import qemu:latest image for docker - ${pkgs.dockerTools.streamLayeredImage { - name = "qemu"; - tag = "latest"; - contents = [ qemuPackage ]; - }} | docker load - # Mark down current package version - echo '${qemuPackage.version}' >${statePath}/docker-image-qemu - fi - ''; - serviceConfig = { - ExecStart = "${pkgs.sourcehut.buildsrht}/bin/buildsrht-worker"; - BindPaths = [ cfg.settings."builds.sr.ht::worker".buildlogs ]; - LogsDirectory = [ "sourcehut/${serviceName}" ]; - RuntimeDirectory = [ "sourcehut/${serviceName}/subdir" ]; - StateDirectory = [ "sourcehut/${serviceName}" ]; - TimeoutStartSec = "1800s"; - # buildsrht-worker looks up ../config.ini - WorkingDirectory = "-"+"/run/sourcehut/${serviceName}/subdir"; + extraServices.buildsrht-worker = + let + qemuPackage = pkgs.qemu_kvm; + serviceName = "buildsrht-worker"; + statePath = "/var/lib/sourcehut/${serviceName}"; + in + mkIf cfg.builds.enableWorker { + path = [ + pkgs.openssh + pkgs.docker + ]; + preStart = '' + set -x + if test -z "$(docker images -q qemu:latest 2>/dev/null)" \ + || test "$(cat ${statePath}/docker-image-qemu)" != "${qemuPackage.version}" + then + # Create and import qemu:latest image for docker + ${ + pkgs.dockerTools.streamLayeredImage { + name = "qemu"; + tag = "latest"; + contents = [ qemuPackage ]; + } + } | docker load + # Mark down current package version + echo '${qemuPackage.version}' >${statePath}/docker-image-qemu + fi + ''; + serviceConfig = { + ExecStart = "${pkgs.sourcehut.buildsrht}/bin/buildsrht-worker"; + BindPaths = [ cfg.settings."builds.sr.ht::worker".buildlogs ]; + LogsDirectory = [ "sourcehut/${serviceName}" ]; + RuntimeDirectory = [ "sourcehut/${serviceName}/subdir" ]; + StateDirectory = [ "sourcehut/${serviceName}" ]; + TimeoutStartSec = "1800s"; + # buildsrht-worker looks up ../config.ini + WorkingDirectory = "-" + "/run/sourcehut/${serviceName}/subdir"; + }; }; - }; - extraConfig = let - image_dirs = flatten ( - mapAttrsToList (distro: revs: - mapAttrsToList (rev: archs: - mapAttrsToList (arch: image: - pkgs.runCommand "buildsrht-images" { } '' - mkdir -p $out/${distro}/${rev}/${arch} - ln -s ${image}/*.qcow2 $out/${distro}/${rev}/${arch}/root.img.qcow2 - '' - ) archs - ) revs - ) cfg.builds.images - ); - image_dir_pre = pkgs.symlinkJoin { - name = "buildsrht-worker-images-pre"; - paths = image_dirs; + extraConfig = + let + image_dirs = flatten ( + mapAttrsToList ( + distro: revs: + mapAttrsToList ( + rev: archs: + mapAttrsToList ( + arch: image: + pkgs.runCommand "buildsrht-images" { } '' + mkdir -p $out/${distro}/${rev}/${arch} + ln -s ${image}/*.qcow2 $out/${distro}/${rev}/${arch}/root.img.qcow2 + '' + ) archs + ) revs + ) cfg.builds.images + ); + image_dir_pre = pkgs.symlinkJoin { + name = "buildsrht-worker-images-pre"; + paths = image_dirs; # FIXME: not working, apparently because ubuntu/latest is a broken link # ++ [ "${pkgs.sourcehut.buildsrht}/lib/images" ]; - }; - image_dir = pkgs.runCommand "buildsrht-worker-images" { } '' - mkdir -p $out/images - cp -Lr ${image_dir_pre}/* $out/images - ''; - in mkMerge [ - { - users.users.${cfg.builds.user}.shell = pkgs.bash; + }; + image_dir = pkgs.runCommand "buildsrht-worker-images" { } '' + mkdir -p $out/images + cp -Lr ${image_dir_pre}/* $out/images + ''; + in + mkMerge [ + { + users.users.${cfg.builds.user}.shell = pkgs.bash; - virtualisation.docker.enable = true; + virtualisation.docker.enable = true; - services.sourcehut.settings = mkMerge [ - { # Note that git.sr.ht::dispatch is not a typo, - # gitsrht-dispatch always use this section - "git.sr.ht::dispatch"."/usr/bin/buildsrht-keys" = - mkDefault "${cfg.builds.user}:${cfg.builds.group}"; - } - (mkIf cfg.builds.enableWorker { - "builds.sr.ht::worker".shell = "/usr/bin/runner-shell"; - "builds.sr.ht::worker".images = mkDefault "${image_dir}/images"; - "builds.sr.ht::worker".controlcmd = mkDefault "${image_dir}/images/control"; - }) - ]; - } - (mkIf cfg.builds.enableWorker { - users.groups = { - docker.members = [ cfg.builds.user ]; - }; - }) - (mkIf (cfg.builds.enableWorker && cfg.nginx.enable) { - # Allow nginx access to buildlogs - users.users.${nginx.user}.extraGroups = [ cfg.builds.group ]; - systemd.services.nginx = { - serviceConfig.BindReadOnlyPaths = [ cfg.settings."builds.sr.ht::worker".buildlogs ]; - }; - services.nginx.virtualHosts."logs.${domain}" = mkMerge [ { - /* FIXME: is a listen needed? - listen = with builtins; - # FIXME: not compatible with IPv6 - let address = split ":" cfg.settings."builds.sr.ht::worker".name; in - [{ addr = elemAt address 0; port = lib.toInt (elemAt address 2); }]; - */ - locations."/logs/".alias = cfg.settings."builds.sr.ht::worker".buildlogs + "/"; - } cfg.nginx.virtualHost ]; - }) - ]; + services.sourcehut.settings = mkMerge [ + { + # Note that git.sr.ht::dispatch is not a typo, + # gitsrht-dispatch always use this section + "git.sr.ht::dispatch"."/usr/bin/buildsrht-keys" = + mkDefault "${cfg.builds.user}:${cfg.builds.group}"; + } + (mkIf cfg.builds.enableWorker { + "builds.sr.ht::worker".shell = "/usr/bin/runner-shell"; + "builds.sr.ht::worker".images = mkDefault "${image_dir}/images"; + "builds.sr.ht::worker".controlcmd = mkDefault "${image_dir}/images/control"; + }) + ]; + } + (mkIf cfg.builds.enableWorker { + users.groups = { + docker.members = [ cfg.builds.user ]; + }; + }) + (mkIf (cfg.builds.enableWorker && cfg.nginx.enable) { + # Allow nginx access to buildlogs + users.users.${nginx.user}.extraGroups = [ cfg.builds.group ]; + systemd.services.nginx = { + serviceConfig.BindReadOnlyPaths = [ cfg.settings."builds.sr.ht::worker".buildlogs ]; + }; + services.nginx.virtualHosts."logs.${domain}" = mkMerge [ + { + /* + FIXME: is a listen needed? + listen = with builtins; + # FIXME: not compatible with IPv6 + let address = split ":" cfg.settings."builds.sr.ht::worker".name; in + [{ addr = elemAt address 0; port = lib.toInt (elemAt address 2); }]; + */ + locations."/logs/".alias = cfg.settings."builds.sr.ht::worker".buildlogs + "/"; + } + cfg.nginx.virtualHost + ]; + }) + ]; }) - (import ./service.nix "git" (let - baseService = { - path = [ cfg.git.package ]; - serviceConfig.BindPaths = [ "${cfg.settings."git.sr.ht".repos}:/var/lib/sourcehut/gitsrht/repos" ]; - }; - in { - inherit configIniOfService; - mainService = mkMerge [ baseService { - serviceConfig.StateDirectory = [ "sourcehut/gitsrht" "sourcehut/gitsrht/repos" ]; - preStart = mkIf (versionOlder config.system.stateVersion "22.05") (mkBefore '' - # Fix Git hooks of repositories pre-dating https://github.com/NixOS/nixpkgs/pull/133984 - ( - set +f - shopt -s nullglob - for h in /var/lib/sourcehut/gitsrht/repos/~*/*/hooks/{pre-receive,update,post-update} - do ln -fnsv /usr/bin/gitsrht-update-hook "$h"; done - ) - ''); - } ]; - port = 5001; - webhooks = true; - extraTimers.gitsrht-periodic = { - service = baseService; - timerConfig.OnCalendar = ["*:0/20"]; - }; - extraConfig = mkMerge [ - { - # https://stackoverflow.com/questions/22314298/git-push-results-in-fatal-protocol-error-bad-line-length-character-this - # Probably could use gitsrht-shell if output is restricted to just parameters... - users.users.${cfg.git.user}.shell = pkgs.bash; - services.sourcehut.settings = { - "git.sr.ht::dispatch"."/usr/bin/gitsrht-keys" = - mkDefault "${cfg.git.user}:${cfg.git.group}"; - }; - systemd.services.sshd = baseService; - } - (mkIf cfg.nginx.enable { - services.nginx.virtualHosts."git.${domain}" = { - locations."/authorize" = { - proxyPass = "http://${cfg.listenAddress}:${toString cfg.git.port}"; - extraConfig = '' - proxy_pass_request_body off; - proxy_set_header Content-Length ""; - proxy_set_header X-Original-URI $request_uri; - ''; + (import ./service.nix "git" ( + let + baseService = { + path = [ cfg.git.package ]; + serviceConfig.BindPaths = [ "${cfg.settings."git.sr.ht".repos}:/var/lib/sourcehut/gitsrht/repos" ]; + }; + in + { + inherit configIniOfService; + mainService = mkMerge [ + baseService + { + serviceConfig.StateDirectory = [ + "sourcehut/gitsrht" + "sourcehut/gitsrht/repos" + ]; + preStart = mkIf (versionOlder config.system.stateVersion "22.05") (mkBefore '' + # Fix Git hooks of repositories pre-dating https://github.com/NixOS/nixpkgs/pull/133984 + ( + set +f + shopt -s nullglob + for h in /var/lib/sourcehut/gitsrht/repos/~*/*/hooks/{pre-receive,update,post-update} + do ln -fnsv /usr/bin/gitsrht-update-hook "$h"; done + ) + ''); + } + ]; + port = 5001; + webhooks = true; + extraTimers.gitsrht-periodic = { + service = baseService; + timerConfig.OnCalendar = [ "*:0/20" ]; + }; + extraConfig = mkMerge [ + { + # https://stackoverflow.com/questions/22314298/git-push-results-in-fatal-protocol-error-bad-line-length-character-this + # Probably could use gitsrht-shell if output is restricted to just parameters... + users.users.${cfg.git.user}.shell = pkgs.bash; + services.sourcehut.settings = { + "git.sr.ht::dispatch"."/usr/bin/gitsrht-keys" = mkDefault "${cfg.git.user}:${cfg.git.group}"; }; - locations."~ ^/([^/]+)/([^/]+)/(HEAD|info/refs|objects/info/.*|git-upload-pack).*$" = { - root = "/var/lib/sourcehut/gitsrht/repos"; - fastcgiParams = { - GIT_HTTP_EXPORT_ALL = ""; - GIT_PROJECT_ROOT = "$document_root"; - PATH_INFO = "$uri"; - SCRIPT_FILENAME = "${cfg.git.package}/bin/git-http-backend"; + systemd.services.sshd = baseService; + } + (mkIf cfg.nginx.enable { + services.nginx.virtualHosts."git.${domain}" = { + locations."/authorize" = { + proxyPass = "http://${cfg.listenAddress}:${toString cfg.git.port}"; + extraConfig = '' + proxy_pass_request_body off; + proxy_set_header Content-Length ""; + proxy_set_header X-Original-URI $request_uri; + ''; + }; + locations."~ ^/([^/]+)/([^/]+)/(HEAD|info/refs|objects/info/.*|git-upload-pack).*$" = { + root = "/var/lib/sourcehut/gitsrht/repos"; + fastcgiParams = { + GIT_HTTP_EXPORT_ALL = ""; + GIT_PROJECT_ROOT = "$document_root"; + PATH_INFO = "$uri"; + SCRIPT_FILENAME = "${cfg.git.package}/bin/git-http-backend"; + }; + extraConfig = '' + auth_request /authorize; + fastcgi_read_timeout 500s; + fastcgi_pass unix:/run/gitsrht-fcgiwrap.sock; + gzip off; + ''; }; - extraConfig = '' - auth_request /authorize; - fastcgi_read_timeout 500s; - fastcgi_pass unix:/run/gitsrht-fcgiwrap.sock; - gzip off; - ''; }; + systemd.sockets.gitsrht-fcgiwrap = { + before = [ "nginx.service" ]; + wantedBy = [ + "sockets.target" + "gitsrht.service" + ]; + # This path remains accessible to nginx.service, which has no RootDirectory= + socketConfig.ListenStream = "/run/gitsrht-fcgiwrap.sock"; + socketConfig.SocketUser = nginx.user; + socketConfig.SocketMode = "600"; + }; + }) + ]; + extraServices.gitsrht-api.serviceConfig = { + Restart = "always"; + RestartSec = "5s"; + ExecStart = "${pkgs.sourcehut.gitsrht}/bin/gitsrht-api -b ${cfg.listenAddress}:${toString (cfg.git.port + 100)}"; + BindPaths = [ "${cfg.settings."git.sr.ht".repos}:/var/lib/sourcehut/gitsrht/repos" ]; + }; + extraServices.gitsrht-fcgiwrap = mkIf cfg.nginx.enable { + serviceConfig = { + # Socket is passed by gitsrht-fcgiwrap.socket + ExecStart = "${pkgs.fcgiwrap}/sbin/fcgiwrap -c ${toString cfg.git.fcgiwrap.preforkProcess}"; + # No need for config.ini + ExecStartPre = mkForce [ ]; + User = null; + DynamicUser = true; + BindReadOnlyPaths = [ "${cfg.settings."git.sr.ht".repos}:/var/lib/sourcehut/gitsrht/repos" ]; + IPAddressDeny = "any"; + InaccessiblePaths = [ + "-+/run/postgresql" + "-+/run/redis-sourcehut" + ]; + PrivateNetwork = true; + RestrictAddressFamilies = mkForce [ "none" ]; + SystemCallFilter = mkForce [ + "@system-service" + "~@aio" + "~@keyring" + "~@memlock" + "~@privileged" + "~@resources" + "~@setuid" + # @timer is needed for alarm() + ]; }; - systemd.sockets.gitsrht-fcgiwrap = { - before = [ "nginx.service" ]; - wantedBy = [ "sockets.target" "gitsrht.service" ]; - # This path remains accessible to nginx.service, which has no RootDirectory= - socketConfig.ListenStream = "/run/gitsrht-fcgiwrap.sock"; - socketConfig.SocketUser = nginx.user; - socketConfig.SocketMode = "600"; - }; - }) - ]; - extraServices.gitsrht-api.serviceConfig = { - Restart = "always"; - RestartSec = "5s"; - ExecStart = "${pkgs.sourcehut.gitsrht}/bin/gitsrht-api -b ${cfg.listenAddress}:${toString (cfg.git.port + 100)}"; - BindPaths = [ "${cfg.settings."git.sr.ht".repos}:/var/lib/sourcehut/gitsrht/repos" ]; - }; - extraServices.gitsrht-fcgiwrap = mkIf cfg.nginx.enable { - serviceConfig = { - # Socket is passed by gitsrht-fcgiwrap.socket - ExecStart = "${pkgs.fcgiwrap}/sbin/fcgiwrap -c ${toString cfg.git.fcgiwrap.preforkProcess}"; - # No need for config.ini - ExecStartPre = mkForce []; - User = null; - DynamicUser = true; - BindReadOnlyPaths = [ "${cfg.settings."git.sr.ht".repos}:/var/lib/sourcehut/gitsrht/repos" ]; - IPAddressDeny = "any"; - InaccessiblePaths = [ "-+/run/postgresql" "-+/run/redis-sourcehut" ]; - PrivateNetwork = true; - RestrictAddressFamilies = mkForce [ "none" ]; - SystemCallFilter = mkForce [ - "@system-service" - "~@aio" "~@keyring" "~@memlock" "~@privileged" "~@resources" "~@setuid" - # @timer is needed for alarm() - ]; }; - }; - })) + } + )) - (import ./service.nix "hg" (let - baseService = { - path = [ cfg.hg.package ]; - serviceConfig.BindPaths = [ "${cfg.settings."hg.sr.ht".repos}:/var/lib/sourcehut/hgsrht/repos" ]; - }; - in { - inherit configIniOfService; - mainService = mkMerge [ baseService { - serviceConfig.StateDirectory = [ "sourcehut/hgsrht" "sourcehut/hgsrht/repos" ]; - } ]; - port = 5010; - webhooks = true; - extraTimers.hgsrht-periodic = { - service = baseService; - timerConfig.OnCalendar = ["*:0/20"]; - }; - extraTimers.hgsrht-clonebundles = mkIf cfg.hg.cloneBundles { - service = baseService; - timerConfig.OnCalendar = ["daily"]; - timerConfig.AccuracySec = "1h"; - }; - extraServices.hgsrht-api = { - serviceConfig.Restart = "always"; - serviceConfig.RestartSec = "5s"; - serviceConfig.ExecStart = "${pkgs.sourcehut.hgsrht}/bin/hgsrht-api -b ${cfg.listenAddress}:${toString (cfg.hg.port + 100)}"; - }; - extraConfig = mkMerge [ - { - users.users.${cfg.hg.user}.shell = pkgs.bash; - services.sourcehut.settings = { - # Note that git.sr.ht::dispatch is not a typo, - # gitsrht-dispatch always uses this section. - "git.sr.ht::dispatch"."/usr/bin/hgsrht-keys" = - mkDefault "${cfg.hg.user}:${cfg.hg.group}"; - }; - systemd.services.sshd = baseService; - } - (mkIf cfg.nginx.enable { - # Allow nginx access to repositories - users.users.${nginx.user}.extraGroups = [ cfg.hg.group ]; - services.nginx.virtualHosts."hg.${domain}" = { - locations."/authorize" = { - proxyPass = "http://${cfg.listenAddress}:${toString cfg.hg.port}"; - extraConfig = '' - proxy_pass_request_body off; - proxy_set_header Content-Length ""; - proxy_set_header X-Original-URI $request_uri; - ''; + (import ./service.nix "hg" ( + let + baseService = { + path = [ cfg.hg.package ]; + serviceConfig.BindPaths = [ "${cfg.settings."hg.sr.ht".repos}:/var/lib/sourcehut/hgsrht/repos" ]; + }; + in + { + inherit configIniOfService; + mainService = mkMerge [ + baseService + { + serviceConfig.StateDirectory = [ + "sourcehut/hgsrht" + "sourcehut/hgsrht/repos" + ]; + } + ]; + port = 5010; + webhooks = true; + extraTimers.hgsrht-periodic = { + service = baseService; + timerConfig.OnCalendar = [ "*:0/20" ]; + }; + extraTimers.hgsrht-clonebundles = mkIf cfg.hg.cloneBundles { + service = baseService; + timerConfig.OnCalendar = [ "daily" ]; + timerConfig.AccuracySec = "1h"; + }; + extraServices.hgsrht-api = { + serviceConfig.Restart = "always"; + serviceConfig.RestartSec = "5s"; + serviceConfig.ExecStart = "${pkgs.sourcehut.hgsrht}/bin/hgsrht-api -b ${cfg.listenAddress}:${toString (cfg.hg.port + 100)}"; + }; + extraConfig = mkMerge [ + { + users.users.${cfg.hg.user}.shell = pkgs.bash; + services.sourcehut.settings = { + # Note that git.sr.ht::dispatch is not a typo, + # gitsrht-dispatch always uses this section. + "git.sr.ht::dispatch"."/usr/bin/hgsrht-keys" = mkDefault "${cfg.hg.user}:${cfg.hg.group}"; }; - # Let clients reach pull bundles. We don't really need to lock this down even for - # private repos because the bundles are named after the revision hashes... - # so someone would need to know or guess a SHA value to download anything. - # TODO: proxyPass to an hg serve service? - locations."~ ^/[~^][a-z0-9_]+/[a-zA-Z0-9_.-]+/\\.hg/bundles/.*$" = { - root = "/var/lib/nginx/hgsrht/repos"; - extraConfig = '' - auth_request /authorize; - gzip off; - ''; + systemd.services.sshd = baseService; + } + (mkIf cfg.nginx.enable { + # Allow nginx access to repositories + users.users.${nginx.user}.extraGroups = [ cfg.hg.group ]; + services.nginx.virtualHosts."hg.${domain}" = { + locations."/authorize" = { + proxyPass = "http://${cfg.listenAddress}:${toString cfg.hg.port}"; + extraConfig = '' + proxy_pass_request_body off; + proxy_set_header Content-Length ""; + proxy_set_header X-Original-URI $request_uri; + ''; + }; + # Let clients reach pull bundles. We don't really need to lock this down even for + # private repos because the bundles are named after the revision hashes... + # so someone would need to know or guess a SHA value to download anything. + # TODO: proxyPass to an hg serve service? + locations."~ ^/[~^][a-z0-9_]+/[a-zA-Z0-9_.-]+/\\.hg/bundles/.*$" = { + root = "/var/lib/nginx/hgsrht/repos"; + extraConfig = '' + auth_request /authorize; + gzip off; + ''; + }; }; - }; - systemd.services.nginx = { - serviceConfig.BindReadOnlyPaths = [ "${cfg.settings."hg.sr.ht".repos}:/var/lib/nginx/hgsrht/repos" ]; - }; - }) - ]; - })) + systemd.services.nginx = { + serviceConfig.BindReadOnlyPaths = [ + "${cfg.settings."hg.sr.ht".repos}:/var/lib/nginx/hgsrht/repos" + ]; + }; + }) + ]; + } + )) (import ./service.nix "hub" { inherit configIniOfService; port = 5014; extraConfig = { services.nginx = mkIf cfg.nginx.enable { - virtualHosts."hub.${domain}" = mkMerge [ { - serverAliases = [ domain ]; - } cfg.nginx.virtualHost ]; + virtualHosts."hub.${domain}" = mkMerge [ + { + serverAliases = [ domain ]; + } + cfg.nginx.virtualHost + ]; }; }; }) - (import ./service.nix "lists" (let - srvsrht = "listssrht"; - in { - inherit configIniOfService; - port = 5006; - webhooks = true; - extraServices.listssrht-api = { - serviceConfig.Restart = "always"; - serviceConfig.RestartSec = "5s"; - serviceConfig.ExecStart = "${pkgs.sourcehut.listssrht}/bin/listssrht-api -b ${cfg.listenAddress}:${toString (cfg.lists.port + 100)}"; - }; - # Receive the mail from Postfix and enqueue them into Redis and PostgreSQL - extraServices.listssrht-lmtp = { - wants = [ "postfix.service" ]; - unitConfig.JoinsNamespaceOf = optional cfg.postfix.enable "postfix.service"; - serviceConfig.ExecStart = "${pkgs.sourcehut.listssrht}/bin/listssrht-lmtp"; - # Avoid crashing: os.chown(sock, os.getuid(), sock_gid) - serviceConfig.PrivateUsers = mkForce false; - }; - # Dequeue the mails from Redis and dispatch them - extraServices.listssrht-process = { - serviceConfig = { - preStart = '' - cp ${pkgs.writeText "${srvsrht}-webhooks-celeryconfig.py" cfg.lists.process.celeryConfig} \ - /run/sourcehut/${srvsrht}-webhooks/celeryconfig.py - ''; - ExecStart = "${cfg.python}/bin/celery --app listssrht.process worker --hostname listssrht-process@%%h " + concatStringsSep " " cfg.lists.process.extraArgs; - # Avoid crashing: os.getloadavg() - ProcSubset = mkForce "all"; + (import ./service.nix "lists" ( + let + srvsrht = "listssrht"; + in + { + inherit configIniOfService; + port = 5006; + webhooks = true; + extraServices.listssrht-api = { + serviceConfig.Restart = "always"; + serviceConfig.RestartSec = "5s"; + serviceConfig.ExecStart = "${pkgs.sourcehut.listssrht}/bin/listssrht-api -b ${cfg.listenAddress}:${ + toString (cfg.lists.port + 100) + }"; }; - }; - extraConfig = mkIf cfg.postfix.enable { - users.groups.${postfix.group}.members = [ cfg.lists.user ]; - services.sourcehut.settings."lists.sr.ht::mail".sock-group = postfix.group; - services.postfix = { - destination = [ "lists.${domain}" ]; - # FIXME: an accurate recipient list should be queried - # from the lists.sr.ht PostgreSQL database to avoid backscattering. - # But usernames are unfortunately not in that database but in meta.sr.ht. - # Note that two syntaxes are allowed: - # - ~username/list-name@lists.${domain} - # - u.username.list-name@lists.${domain} - localRecipients = [ "@lists.${domain}" ]; - transport = '' - lists.${domain} lmtp:unix:${cfg.settings."lists.sr.ht::worker".sock} - ''; + # Receive the mail from Postfix and enqueue them into Redis and PostgreSQL + extraServices.listssrht-lmtp = { + wants = [ "postfix.service" ]; + unitConfig.JoinsNamespaceOf = optional cfg.postfix.enable "postfix.service"; + serviceConfig.ExecStart = "${pkgs.sourcehut.listssrht}/bin/listssrht-lmtp"; + # Avoid crashing: os.chown(sock, os.getuid(), sock_gid) + serviceConfig.PrivateUsers = mkForce false; }; - }; - })) + # Dequeue the mails from Redis and dispatch them + extraServices.listssrht-process = { + serviceConfig = { + preStart = '' + cp ${pkgs.writeText "${srvsrht}-webhooks-celeryconfig.py" cfg.lists.process.celeryConfig} \ + /run/sourcehut/${srvsrht}-webhooks/celeryconfig.py + ''; + ExecStart = + "${cfg.python}/bin/celery --app listssrht.process worker --hostname listssrht-process@%%h " + + concatStringsSep " " cfg.lists.process.extraArgs; + # Avoid crashing: os.getloadavg() + ProcSubset = mkForce "all"; + }; + }; + extraConfig = mkIf cfg.postfix.enable { + users.groups.${postfix.group}.members = [ cfg.lists.user ]; + services.sourcehut.settings."lists.sr.ht::mail".sock-group = postfix.group; + services.postfix = { + destination = [ "lists.${domain}" ]; + # FIXME: an accurate recipient list should be queried + # from the lists.sr.ht PostgreSQL database to avoid backscattering. + # But usernames are unfortunately not in that database but in meta.sr.ht. + # Note that two syntaxes are allowed: + # - ~username/list-name@lists.${domain} + # - u.username.list-name@lists.${domain} + localRecipients = [ "@lists.${domain}" ]; + transport = '' + lists.${domain} lmtp:unix:${cfg.settings."lists.sr.ht::worker".sock} + ''; + }; + }; + } + )) (import ./service.nix "man" { inherit configIniOfService; @@ -1236,34 +1389,46 @@ in port = 5000; webhooks = true; extraTimers.metasrht-daily.timerConfig = { - OnCalendar = ["daily"]; + OnCalendar = [ "daily" ]; AccuracySec = "1h"; }; extraServices.metasrht-api = { serviceConfig.Restart = "always"; serviceConfig.RestartSec = "5s"; - preStart = "set -x\n" + concatStringsSep "\n\n" (attrValues (mapAttrs (k: s: - let srvMatch = builtins.match "^([a-z]*)\\.sr\\.ht$" k; - srv = head srvMatch; - in - # Configure client(s) as "preauthorized" - optionalString (srvMatch != null && cfg.${srv}.enable && ((s.oauth-client-id or null) != null)) '' - # Configure ${srv}'s OAuth client as "preauthorized" - ${postgresql.package}/bin/psql '${cfg.settings."meta.sr.ht".connection-string}' \ - -c "UPDATE oauthclient SET preauthorized = true WHERE client_id = '${s.oauth-client-id}'" - '' - ) cfg.settings)); + preStart = + "set -x\n" + + concatStringsSep "\n\n" ( + attrValues ( + mapAttrs ( + k: s: + let + srvMatch = builtins.match "^([a-z]*)\\.sr\\.ht$" k; + srv = head srvMatch; + in + # Configure client(s) as "preauthorized" + optionalString (srvMatch != null && cfg.${srv}.enable && ((s.oauth-client-id or null) != null)) '' + # Configure ${srv}'s OAuth client as "preauthorized" + ${postgresql.package}/bin/psql '${cfg.settings."meta.sr.ht".connection-string}' \ + -c "UPDATE oauthclient SET preauthorized = true WHERE client_id = '${s.oauth-client-id}'" + '' + ) cfg.settings + ) + ); serviceConfig.ExecStart = "${pkgs.sourcehut.metasrht}/bin/metasrht-api -b ${cfg.listenAddress}:${toString (cfg.meta.port + 100)}"; }; extraConfig = { assertions = [ - { assertion = let s = cfg.settings."meta.sr.ht::billing"; in - s.enabled == "yes" -> (s.stripe-public-key != null && s.stripe-secret-key != null); + { + assertion = + let + s = cfg.settings."meta.sr.ht::billing"; + in + s.enabled == "yes" -> (s.stripe-public-key != null && s.stripe-secret-key != null); message = "If meta.sr.ht::billing is enabled, the keys must be defined."; } ]; - environment.systemPackages = optional cfg.meta.enable - (pkgs.writeShellScriptBin "metasrht-manageuser" '' + environment.systemPackages = optional cfg.meta.enable ( + pkgs.writeShellScriptBin "metasrht-manageuser" '' set -eux if test "$(${pkgs.coreutils}/bin/id -n -u)" != '${cfg.meta.user}' then exec sudo -u '${cfg.meta.user}' "$0" "$@" @@ -1277,44 +1442,49 @@ in exit 1 fi fi - ''); + '' + ); }; }) (import ./service.nix "pages" { inherit configIniOfService; port = 5112; - mainService = let - srvsrht = "pagessrht"; - version = pkgs.sourcehut.${srvsrht}.version; - stateDir = "/var/lib/sourcehut/${srvsrht}"; - iniKey = "pages.sr.ht"; - in { - preStart = mkBefore '' - set -x - # Use the /run/sourcehut/${srvsrht}/config.ini - # installed by a previous ExecStartPre= in baseService - cd /run/sourcehut/${srvsrht} + mainService = + let + srvsrht = "pagessrht"; + version = pkgs.sourcehut.${srvsrht}.version; + stateDir = "/var/lib/sourcehut/${srvsrht}"; + iniKey = "pages.sr.ht"; + in + { + preStart = mkBefore '' + set -x + # Use the /run/sourcehut/${srvsrht}/config.ini + # installed by a previous ExecStartPre= in baseService + cd /run/sourcehut/${srvsrht} - if test ! -e ${stateDir}/db; then - ${postgresql.package}/bin/psql '${cfg.settings.${iniKey}.connection-string}' -f ${pkgs.sourcehut.pagessrht}/share/sql/schema.sql - echo ${version} >${stateDir}/db - fi + if test ! -e ${stateDir}/db; then + ${postgresql.package}/bin/psql '${ + cfg.settings.${iniKey}.connection-string + }' -f ${pkgs.sourcehut.pagessrht}/share/sql/schema.sql + echo ${version} >${stateDir}/db + fi - ${optionalString cfg.settings.${iniKey}.migrate-on-upgrade '' - # Just try all the migrations because they're not linked to the version - for sql in ${pkgs.sourcehut.pagessrht}/share/sql/migrations/*.sql; do - ${postgresql.package}/bin/psql '${cfg.settings.${iniKey}.connection-string}' -f "$sql" || true - done - ''} + ${optionalString cfg.settings.${iniKey}.migrate-on-upgrade '' + # Just try all the migrations because they're not linked to the version + for sql in ${pkgs.sourcehut.pagessrht}/share/sql/migrations/*.sql; do + ${postgresql.package}/bin/psql '${cfg.settings.${iniKey}.connection-string}' -f "$sql" || true + done + ''} - # Disable webhook - touch ${stateDir}/webhook - ''; - serviceConfig = { - ExecStart = mkForce "${pkgs.sourcehut.pagessrht}/bin/pages.sr.ht -b ${cfg.listenAddress}:${toString cfg.pages.port}"; + # Disable webhook + touch ${stateDir}/webhook + ''; + serviceConfig = { + ExecStart = mkForce "${pkgs.sourcehut.pagessrht}/bin/pages.sr.ht -b ${cfg.listenAddress}:${toString cfg.pages.port}"; + }; }; - }; }) (import ./service.nix "paste" { @@ -1323,7 +1493,9 @@ in extraServices.pastesrht-api = { serviceConfig.Restart = "always"; serviceConfig.RestartSec = "5s"; - serviceConfig.ExecStart = "${pkgs.sourcehut.pastesrht}/bin/pastesrht-api -b ${cfg.listenAddress}:${toString (cfg.paste.port + 100)}"; + serviceConfig.ExecStart = "${pkgs.sourcehut.pastesrht}/bin/pastesrht-api -b ${cfg.listenAddress}:${ + toString (cfg.paste.port + 100) + }"; }; }) @@ -1362,21 +1534,29 @@ in }; }) - (mkRenamedOptionModule [ "services" "sourcehut" "originBase" ] - [ "services" "sourcehut" "settings" "sr.ht" "global-domain" ]) - (mkRenamedOptionModule [ "services" "sourcehut" "address" ] - [ "services" "sourcehut" "listenAddress" ]) + (mkRenamedOptionModule + [ "services" "sourcehut" "originBase" ] + [ "services" "sourcehut" "settings" "sr.ht" "global-domain" ] + ) + (mkRenamedOptionModule + [ "services" "sourcehut" "address" ] + [ "services" "sourcehut" "listenAddress" ] + ) (mkRemovedOptionModule [ "services" "sourcehut" "dispatch" ] '' - dispatch is deprecated. See https://sourcehut.org/blog/2022-08-01-dispatch-deprecation-plans/ - for more information. + dispatch is deprecated. See https://sourcehut.org/blog/2022-08-01-dispatch-deprecation-plans/ + for more information. '') - (mkRemovedOptionModule [ "services" "sourcehut" "services"] '' - This option was removed in favor of individual .enable flags. + (mkRemovedOptionModule [ "services" "sourcehut" "services" ] '' + This option was removed in favor of individual .enable flags. '') ]; meta.doc = ./default.md; - meta.maintainers = with maintainers; [ tomberek nessdoor christoph-heiss ]; + meta.maintainers = with maintainers; [ + tomberek + nessdoor + christoph-heiss + ]; } diff --git a/nixos/modules/services/misc/sourcehut/service.nix b/nixos/modules/services/misc/sourcehut/service.nix index 3507a49ea13a88..37040c5e8661b0 100644 --- a/nixos/modules/services/misc/sourcehut/service.nix +++ b/nixos/modules/services/misc/sourcehut/service.nix @@ -1,21 +1,33 @@ srv: -{ configIniOfService -, srvsrht ? "${srv}srht" # Because "buildsrht" does not follow that pattern (missing an "s"). -, iniKey ? "${srv}.sr.ht" -, webhooks ? false -, extraTimers ? { } -, mainService ? { } -, extraServices ? { } -, extraConfig ? { } -, port +{ + configIniOfService, + srvsrht ? "${srv}srht", # Because "buildsrht" does not follow that pattern (missing an "s"). + iniKey ? "${srv}.sr.ht", + webhooks ? false, + extraTimers ? { }, + mainService ? { }, + extraServices ? { }, + extraConfig ? { }, + port, +}: +{ + config, + lib, + pkgs, + ... }: -{ config, lib, pkgs, ... }: let inherit (lib) types; inherit (lib.attrsets) mapAttrs optionalAttrs; inherit (lib.lists) optional; - inherit (lib.modules) mkBefore mkDefault mkForce mkIf mkMerge; + inherit (lib.modules) + mkBefore + mkDefault + mkForce + mkIf + mkMerge + ; inherit (lib.options) mkEnableOption mkOption; inherit (lib.strings) concatStringsSep hasSuffix optionalString; inherit (config.services) postgresql; @@ -24,7 +36,12 @@ let cfg = config.services.sourcehut; configIni = configIniOfService srv; srvCfg = cfg.${srv}; - baseService = serviceName: { allowStripe ? false }: extraService: + baseService = + serviceName: + { + allowStripe ? false, + }: + extraService: let runDir = "/run/sourcehut/${serviceName}"; rootDir = "/run/sourcehut/chroots/${serviceName}"; @@ -32,12 +49,13 @@ let mkMerge [ extraService { - after = [ "network.target" ] ++ - optional cfg.postgresql.enable "postgresql.service" ++ - optional cfg.redis.enable "redis-sourcehut-${srvsrht}.service"; + after = + [ "network.target" ] + ++ optional cfg.postgresql.enable "postgresql.service" + ++ optional cfg.redis.enable "redis-sourcehut-${srvsrht}.service"; requires = - optional cfg.postgresql.enable "postgresql.service" ++ - optional cfg.redis.enable "redis-sourcehut-${srvsrht}.service"; + optional cfg.postgresql.enable "postgresql.service" + ++ optional cfg.redis.enable "redis-sourcehut-${srvsrht}.service"; path = [ pkgs.gawk ]; environment.HOME = runDir; serviceConfig = { @@ -64,27 +82,31 @@ let # config.ini is looked up in there, before /etc/srht/config.ini # Note that it fails to be set in ExecStartPre= WorkingDirectory = mkDefault ("-" + runDir); - BindReadOnlyPaths = [ - builtins.storeDir - "/etc" - "/run/booted-system" - "/run/current-system" - "/run/systemd" - ] ++ - optional cfg.postgresql.enable "/run/postgresql" ++ - optional cfg.redis.enable "/run/redis-sourcehut-${srvsrht}"; + BindReadOnlyPaths = + [ + builtins.storeDir + "/etc" + "/run/booted-system" + "/run/current-system" + "/run/systemd" + ] + ++ optional cfg.postgresql.enable "/run/postgresql" + ++ optional cfg.redis.enable "/run/redis-sourcehut-${srvsrht}"; # LoadCredential= are unfortunately not available in ExecStartPre= # Hence this one is run as root (the +) with RootDirectoryStartOnly= # to reach credentials wherever they are. # Note that each systemd service gets its own ${runDir}/config.ini file. ExecStartPre = mkBefore [ - ("+" + pkgs.writeShellScript "${serviceName}-credentials" '' - set -x - # Replace values beginning with a '<' by the content of the file whose name is after. - gawk '{ if (match($0,/^([^=]+=)<(.+)/,m)) { getline f < m[2]; print m[1] f } else print $0 }' ${configIni} | - ${optionalString (!allowStripe) "gawk '!/^stripe-secret-key=/' |"} - install -o ${srvCfg.user} -g root -m 400 /dev/stdin ${runDir}/config.ini - '') + ( + "+" + + pkgs.writeShellScript "${serviceName}-credentials" '' + set -x + # Replace values beginning with a '<' by the content of the file whose name is after. + gawk '{ if (match($0,/^([^=]+=)<(.+)/,m)) { getline f < m[2]; print m[1] f } else print $0 }' ${configIni} | + ${optionalString (!allowStripe) "gawk '!/^stripe-secret-key=/' |"} + install -o ${srvCfg.user} -g root -m 400 /dev/stdin ${runDir}/config.ini + '' + ) ]; # The following options are only for optimizing: # systemd-analyze security @@ -110,7 +132,11 @@ let ProtectProc = "invisible"; ProtectSystem = "strict"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; @@ -132,81 +158,91 @@ let ]; in { - options.services.sourcehut.${srv} = { - enable = mkEnableOption "${srv} service"; - - user = mkOption { - type = types.str; - default = srvsrht; - description = '' - User for ${srv}.sr.ht. - ''; - }; - - group = mkOption { - type = types.str; - default = srvsrht; - description = '' - Group for ${srv}.sr.ht. - Membership grants access to the Git/Mercurial repositories by default, - but not to the config.ini file (where secrets are). - ''; - }; - - port = mkOption { - type = types.port; - default = port; - description = '' - Port on which the "${srv}" backend should listen. - ''; - }; + options.services.sourcehut.${srv} = + { + enable = mkEnableOption "${srv} service"; - redis = { - host = mkOption { + user = mkOption { type = types.str; - default = "unix:///run/redis-sourcehut-${srvsrht}/redis.sock?db=0"; - example = "redis://shared.wireguard:6379/0"; + default = srvsrht; description = '' - The redis host URL. This is used for caching and temporary storage, and must - be shared between nodes (e.g. git1.sr.ht and git2.sr.ht), but need not be - shared between services. It may be shared between services, however, with no - ill effect, if this better suits your infrastructure. + User for ${srv}.sr.ht. ''; }; - }; - postgresql = { - database = mkOption { + group = mkOption { type = types.str; - default = "${srv}.sr.ht"; + default = srvsrht; description = '' - PostgreSQL database name for the ${srv}.sr.ht service, - used if [](#opt-services.sourcehut.postgresql.enable) is `true`. + Group for ${srv}.sr.ht. + Membership grants access to the Git/Mercurial repositories by default, + but not to the config.ini file (where secrets are). + ''; + }; + + port = mkOption { + type = types.port; + default = port; + description = '' + Port on which the "${srv}" backend should listen. ''; }; - }; - gunicorn = { - extraArgs = mkOption { - type = with types; listOf str; - default = [ "--timeout 120" "--workers 1" "--log-level=info" ]; - description = "Extra arguments passed to Gunicorn."; + redis = { + host = mkOption { + type = types.str; + default = "unix:///run/redis-sourcehut-${srvsrht}/redis.sock?db=0"; + example = "redis://shared.wireguard:6379/0"; + description = '' + The redis host URL. This is used for caching and temporary storage, and must + be shared between nodes (e.g. git1.sr.ht and git2.sr.ht), but need not be + shared between services. It may be shared between services, however, with no + ill effect, if this better suits your infrastructure. + ''; + }; }; - }; - } // optionalAttrs webhooks { - webhooks = { - extraArgs = mkOption { - type = with types; listOf str; - default = [ "--loglevel DEBUG" "--pool eventlet" "--without-heartbeat" ]; - description = "Extra arguments passed to the Celery responsible for webhooks."; + + postgresql = { + database = mkOption { + type = types.str; + default = "${srv}.sr.ht"; + description = '' + PostgreSQL database name for the ${srv}.sr.ht service, + used if [](#opt-services.sourcehut.postgresql.enable) is `true`. + ''; + }; }; - celeryConfig = mkOption { - type = types.lines; - default = ""; - description = "Content of the `celeryconfig.py` used by the Celery responsible for webhooks."; + + gunicorn = { + extraArgs = mkOption { + type = with types; listOf str; + default = [ + "--timeout 120" + "--workers 1" + "--log-level=info" + ]; + description = "Extra arguments passed to Gunicorn."; + }; + }; + } + // optionalAttrs webhooks { + webhooks = { + extraArgs = mkOption { + type = with types; listOf str; + default = [ + "--loglevel DEBUG" + "--pool eventlet" + "--without-heartbeat" + ]; + description = "Extra arguments passed to the Celery responsible for webhooks."; + }; + celeryConfig = mkOption { + type = types.lines; + default = ""; + description = "Content of the `celeryconfig.py` used by the Celery responsible for webhooks."; + }; }; }; - }; config = lib.mkIf (cfg.enable && srvCfg.enable) (mkMerge [ extraConfig @@ -219,50 +255,52 @@ in description = mkDefault "sourcehut user for ${srv}.sr.ht"; }; }; - groups = { - "${srvCfg.group}" = { }; - } // optionalAttrs - (cfg.postgresql.enable - && hasSuffix "0" (postgresql.settings.unix_socket_permissions or "")) - { - "postgres".members = [ srvCfg.user ]; - } // optionalAttrs - (cfg.redis.enable - && hasSuffix "0" (redis.settings.unixsocketperm or "")) + groups = { + "${srvCfg.group}" = { }; + } + // + optionalAttrs + (cfg.postgresql.enable && hasSuffix "0" (postgresql.settings.unix_socket_permissions or "")) + { + "postgres".members = [ srvCfg.user ]; + } + // optionalAttrs (cfg.redis.enable && hasSuffix "0" (redis.settings.unixsocketperm or "")) { "redis-sourcehut-${srvsrht}".members = [ srvCfg.user ]; }; }; services.nginx = mkIf cfg.nginx.enable { - virtualHosts."${srv}.${cfg.settings."sr.ht".global-domain}" = mkMerge [{ - forceSSL = mkDefault true; - locations."/".proxyPass = "http://${cfg.listenAddress}:${toString srvCfg.port}"; - locations."/static" = { - root = "${pkgs.sourcehut.${srvsrht}}/${pkgs.sourcehut.python.sitePackages}/${srvsrht}"; - extraConfig = mkDefault '' - expires 30d; - ''; - }; - locations."/query" = mkIf (cfg.settings.${iniKey} ? api-origin) { - proxyPass = cfg.settings.${iniKey}.api-origin; - extraConfig = '' - add_header 'Access-Control-Allow-Origin' '*'; - add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS'; - add_header 'Access-Control-Allow-Headers' 'User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range'; + virtualHosts."${srv}.${cfg.settings."sr.ht".global-domain}" = mkMerge [ + { + forceSSL = mkDefault true; + locations."/".proxyPass = "http://${cfg.listenAddress}:${toString srvCfg.port}"; + locations."/static" = { + root = "${pkgs.sourcehut.${srvsrht}}/${pkgs.sourcehut.python.sitePackages}/${srvsrht}"; + extraConfig = mkDefault '' + expires 30d; + ''; + }; + locations."/query" = mkIf (cfg.settings.${iniKey} ? api-origin) { + proxyPass = cfg.settings.${iniKey}.api-origin; + extraConfig = '' + add_header 'Access-Control-Allow-Origin' '*'; + add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS'; + add_header 'Access-Control-Allow-Headers' 'User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range'; - if ($request_method = 'OPTIONS') { - add_header 'Access-Control-Max-Age' 1728000; - add_header 'Content-Type' 'text/plain; charset=utf-8'; - add_header 'Content-Length' 0; - return 204; - } + if ($request_method = 'OPTIONS') { + add_header 'Access-Control-Max-Age' 1728000; + add_header 'Content-Type' 'text/plain; charset=utf-8'; + add_header 'Content-Length' 0; + return 204; + } - add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range'; - ''; - }; - } - cfg.nginx.virtualHost]; + add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range'; + ''; + }; + } + cfg.nginx.virtualHost + ]; }; services.postgresql = mkIf cfg.postgresql.enable { @@ -270,23 +308,22 @@ in local ${srvCfg.postgresql.database} ${srvCfg.user} trust ''; ensureDatabases = [ srvCfg.postgresql.database ]; - ensureUsers = map - (name: { - inherit name; - # We don't use it because we have a special default database name with dots. - # TODO(for maintainers of sourcehut): migrate away from custom preStart script. - ensureDBOwnership = false; - }) [ srvCfg.user ]; + ensureUsers = map (name: { + inherit name; + # We don't use it because we have a special default database name with dots. + # TODO(for maintainers of sourcehut): migrate away from custom preStart script. + ensureDBOwnership = false; + }) [ srvCfg.user ]; }; - services.sourcehut.settings = mkMerge [ { "${srv}.sr.ht".origin = mkDefault "https://${srv}.${cfg.settings."sr.ht".global-domain}"; } (mkIf cfg.postgresql.enable { - "${srv}.sr.ht".connection-string = mkDefault "postgresql:///${srvCfg.postgresql.database}?user=${srvCfg.user}&host=/run/postgresql"; + "${srv}.sr.ht".connection-string = + mkDefault "postgresql:///${srvCfg.postgresql.database}?user=${srvCfg.user}&host=/run/postgresql"; }) ]; @@ -295,7 +332,16 @@ in databases = 3; syslog = true; # TODO: set a more informed value - save = mkDefault [ [ 1800 10 ] [ 300 100 ] ]; + save = mkDefault [ + [ + 1800 + 10 + ] + [ + 300 + 100 + ] + ]; settings = { # TODO: set a more informed value maxmemory = "128MB"; @@ -320,7 +366,9 @@ in #RestartSec = mkDefault "2min"; StateDirectory = [ "sourcehut/${srvsrht}" ]; StateDirectoryMode = "2750"; - ExecStart = "${cfg.python}/bin/gunicorn ${srvsrht}.app:app --name ${srvsrht} --bind ${cfg.listenAddress}:${toString srvCfg.port} " + concatStringsSep " " srvCfg.gunicorn.extraArgs; + ExecStart = + "${cfg.python}/bin/gunicorn ${srvsrht}.app:app --name ${srvsrht} --bind ${cfg.listenAddress}:${toString srvCfg.port} " + + concatStringsSep " " srvCfg.gunicorn.extraArgs; }; preStart = let @@ -363,42 +411,48 @@ in } (mkIf webhooks { - "${srvsrht}-webhooks" = baseService "${srvsrht}-webhooks" { } - { - description = "sourcehut ${srv}.sr.ht webhooks service"; - after = [ "${srvsrht}.service" ]; - wantedBy = [ "${srvsrht}.service" ]; - partOf = [ "${srvsrht}.service" ]; - preStart = '' - cp ${pkgs.writeText "${srvsrht}-webhooks-celeryconfig.py" srvCfg.webhooks.celeryConfig} \ - /run/sourcehut/${srvsrht}-webhooks/celeryconfig.py - ''; - serviceConfig = { - Type = "simple"; - Restart = "always"; - ExecStart = "${cfg.python}/bin/celery --app ${srvsrht}.webhooks worker --hostname ${srvsrht}-webhooks@%%h " + concatStringsSep " " srvCfg.webhooks.extraArgs; - # Avoid crashing: os.getloadavg() - ProcSubset = mkForce "all"; - }; + "${srvsrht}-webhooks" = baseService "${srvsrht}-webhooks" { } { + description = "sourcehut ${srv}.sr.ht webhooks service"; + after = [ "${srvsrht}.service" ]; + wantedBy = [ "${srvsrht}.service" ]; + partOf = [ "${srvsrht}.service" ]; + preStart = '' + cp ${pkgs.writeText "${srvsrht}-webhooks-celeryconfig.py" srvCfg.webhooks.celeryConfig} \ + /run/sourcehut/${srvsrht}-webhooks/celeryconfig.py + ''; + serviceConfig = { + Type = "simple"; + Restart = "always"; + ExecStart = + "${cfg.python}/bin/celery --app ${srvsrht}.webhooks worker --hostname ${srvsrht}-webhooks@%%h " + + concatStringsSep " " srvCfg.webhooks.extraArgs; + # Avoid crashing: os.getloadavg() + ProcSubset = mkForce "all"; }; + }; }) - (mapAttrs - (timerName: timer: (baseService timerName { } (mkMerge [ + (mapAttrs ( + timerName: timer: + (baseService timerName { } (mkMerge [ { description = "sourcehut ${timerName} service"; - after = [ "network.target" "${srvsrht}.service" ]; + after = [ + "network.target" + "${srvsrht}.service" + ]; serviceConfig = { Type = "oneshot"; ExecStart = "${pkgs.sourcehut.${srvsrht}}/bin/${timerName}"; }; } (timer.service or { }) - ]))) - extraTimers) + ])) + ) extraTimers) - (mapAttrs - (serviceName: extraService: baseService serviceName { } (mkMerge [ + (mapAttrs ( + serviceName: extraService: + baseService serviceName { } (mkMerge [ { description = "sourcehut ${serviceName} service"; # So that extraServices have the PostgreSQL database initialized. @@ -411,8 +465,8 @@ in }; } extraService - ])) - extraServices) + ]) + ) extraServices) # Work around 'pq: permission denied for schema public' with postgres v15. # See https://github.com/NixOS/nixpkgs/issues/216989 @@ -425,21 +479,20 @@ in && lib.strings.versionAtLeast config.services.postgresql.package.version "15.0" ) { - postgresql.postStart = (lib.mkAfter '' - $PSQL -tAc 'ALTER DATABASE "${srvCfg.postgresql.database}" OWNER TO "${srvCfg.user}";' - ''); + postgresql.postStart = ( + lib.mkAfter '' + $PSQL -tAc 'ALTER DATABASE "${srvCfg.postgresql.database}" OWNER TO "${srvCfg.user}";' + '' + ); } ) ]; - systemd.timers = mapAttrs - (timerName: timer: - { - description = "sourcehut timer for ${timerName}"; - wantedBy = [ "timers.target" ]; - inherit (timer) timerConfig; - }) - extraTimers; + systemd.timers = mapAttrs (timerName: timer: { + description = "sourcehut timer for ${timerName}"; + wantedBy = [ "timers.target" ]; + inherit (timer) timerConfig; + }) extraTimers; } ]); } diff --git a/nixos/modules/services/misc/spice-autorandr.nix b/nixos/modules/services/misc/spice-autorandr.nix index 92b8a15e93c5de..c2be651fcd2834 100644 --- a/nixos/modules/services/misc/spice-autorandr.nix +++ b/nixos/modules/services/misc/spice-autorandr.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.spice-autorandr; diff --git a/nixos/modules/services/misc/spice-vdagentd.nix b/nixos/modules/services/misc/spice-vdagentd.nix index 762f9c95b615dd..e829f733c401bc 100644 --- a/nixos/modules/services/misc/spice-vdagentd.nix +++ b/nixos/modules/services/misc/spice-vdagentd.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.spice-vdagentd; in diff --git a/nixos/modules/services/misc/spice-webdavd.nix b/nixos/modules/services/misc/spice-webdavd.nix index 6f12f4418aaa4c..878ec7a6444847 100644 --- a/nixos/modules/services/misc/spice-webdavd.nix +++ b/nixos/modules/services/misc/spice-webdavd.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.spice-webdavd; in diff --git a/nixos/modules/services/misc/sssd.nix b/nixos/modules/services/misc/sssd.nix index 6d6f855c57f1c0..babc76621a0f3b 100644 --- a/nixos/modules/services/misc/sssd.nix +++ b/nixos/modules/services/misc/sssd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.sssd; nscd = config.services.nscd; @@ -6,7 +11,8 @@ let dataDir = "/var/lib/sssd"; settingsFile = "${dataDir}/sssd.conf"; settingsFileUnsubstituted = pkgs.writeText "${dataDir}/sssd-unsubstituted.conf" cfg.config; -in { +in +{ options = { services.sssd = { enable = lib.mkEnableOption "the System Security Services Daemon"; @@ -82,10 +88,19 @@ in { systemd.services.sssd = { description = "System Security Services Daemon"; - wantedBy = [ "multi-user.target" ]; - before = [ "systemd-user-sessions.service" "nss-user-lookup.target" ]; - after = [ "network-online.target" "nscd.service" ]; - requires = [ "network-online.target" "nscd.service" ]; + wantedBy = [ "multi-user.target" ]; + before = [ + "systemd-user-sessions.service" + "nss-user-lookup.target" + ]; + after = [ + "network-online.target" + "nscd.service" + ]; + requires = [ + "network-online.target" + "nscd.service" + ]; wants = [ "nss-user-lookup.target" ]; restartTriggers = [ config.environment.etc."nscd.conf".source @@ -148,18 +163,19 @@ in { }) (lib.mkIf cfg.sshAuthorizedKeysIntegration { - # Ugly: sshd refuses to start if a store path is given because /nix/store is group-writable. - # So indirect by a symlink. - environment.etc."ssh/authorized_keys_command" = { - mode = "0755"; - text = '' - #!/bin/sh - exec ${pkgs.sssd}/bin/sss_ssh_authorizedkeys "$@" - ''; - }; - services.openssh.authorizedKeysCommand = "/etc/ssh/authorized_keys_command"; - services.openssh.authorizedKeysCommandUser = "nobody"; - })]; + # Ugly: sshd refuses to start if a store path is given because /nix/store is group-writable. + # So indirect by a symlink. + environment.etc."ssh/authorized_keys_command" = { + mode = "0755"; + text = '' + #!/bin/sh + exec ${pkgs.sssd}/bin/sss_ssh_authorizedkeys "$@" + ''; + }; + services.openssh.authorizedKeysCommand = "/etc/ssh/authorized_keys_command"; + services.openssh.authorizedKeysCommandUser = "nobody"; + }) + ]; meta.maintainers = with lib.maintainers; [ bbigras ]; } diff --git a/nixos/modules/services/misc/subsonic.nix b/nixos/modules/services/misc/subsonic.nix index 8d2ddf724f706a..fb160497b56e2e 100644 --- a/nixos/modules/services/misc/subsonic.nix +++ b/nixos/modules/services/misc/subsonic.nix @@ -1,8 +1,15 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.subsonic; opt = options.services.subsonic; -in { +in +{ options = { services.subsonic = { enable = lib.mkEnableOption "Subsonic daemon"; diff --git a/nixos/modules/services/misc/sundtek.nix b/nixos/modules/services/misc/sundtek.nix index 089d86cb5972f7..4c518011c4f167 100644 --- a/nixos/modules/services/misc/sundtek.nix +++ b/nixos/modules/services/misc/sundtek.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.sundtek; @@ -21,7 +26,7 @@ in ExecStart = '' ${pkgs.sundtek}/bin/mediasrv -d -v -p ${pkgs.sundtek}/bin ;\ ${pkgs.sundtek}/bin/mediaclient --start --wait-for-devices - ''; + ''; ExecStop = "${pkgs.sundtek}/bin/mediaclient --shutdown"; RemainAfterExit = true; }; diff --git a/nixos/modules/services/misc/svnserve.nix b/nixos/modules/services/misc/svnserve.nix index 8e0aee51754c6b..b72e6186c1cd44 100644 --- a/nixos/modules/services/misc/svnserve.nix +++ b/nixos/modules/services/misc/svnserve.nix @@ -1,5 +1,10 @@ # SVN server -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.svnserve; @@ -29,7 +34,6 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/misc/synergy.nix b/nixos/modules/services/misc/synergy.nix index 495f29ba1f9158..f4f2f22a8b487f 100644 --- a/nixos/modules/services/misc/synergy.nix +++ b/nixos/modules/services/misc/synergy.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfgC = config.services.synergy.client; @@ -92,27 +97,40 @@ in }; - ###### implementation config = lib.mkMerge [ (lib.mkIf cfgC.enable { systemd.user.services.synergy-client = { - after = [ "network.target" "graphical-session.target" ]; + after = [ + "network.target" + "graphical-session.target" + ]; description = "Synergy client"; wantedBy = lib.optional cfgC.autoStart "graphical-session.target"; path = [ pkgs.synergy ]; - serviceConfig.ExecStart = ''${pkgs.synergy}/bin/synergyc -f ${lib.optionalString (cfgC.screenName != "") "-n ${cfgC.screenName}"} ${cfgC.serverAddress}''; + serviceConfig.ExecStart = ''${pkgs.synergy}/bin/synergyc -f ${ + lib.optionalString (cfgC.screenName != "") "-n ${cfgC.screenName}" + } ${cfgC.serverAddress}''; serviceConfig.Restart = "on-failure"; }; }) (lib.mkIf cfgS.enable { systemd.user.services.synergy-server = { - after = [ "network.target" "graphical-session.target" ]; + after = [ + "network.target" + "graphical-session.target" + ]; description = "Synergy server"; wantedBy = lib.optional cfgS.autoStart "graphical-session.target"; path = [ pkgs.synergy ]; - serviceConfig.ExecStart = ''${pkgs.synergy}/bin/synergys -c ${cfgS.configFile} -f${lib.optionalString (cfgS.address != "") " -a ${cfgS.address}"}${lib.optionalString (cfgS.screenName != "") " -n ${cfgS.screenName}"}${lib.optionalString cfgS.tls.enable " --enable-crypto"}${lib.optionalString (cfgS.tls.cert != null) (" --tls-cert ${cfgS.tls.cert}")}''; + serviceConfig.ExecStart = ''${pkgs.synergy}/bin/synergys -c ${cfgS.configFile} -f${ + lib.optionalString (cfgS.address != "") " -a ${cfgS.address}" + }${ + lib.optionalString (cfgS.screenName != "") " -n ${cfgS.screenName}" + }${lib.optionalString cfgS.tls.enable " --enable-crypto"}${ + lib.optionalString (cfgS.tls.cert != null) (" --tls-cert ${cfgS.tls.cert}") + }''; serviceConfig.Restart = "on-failure"; }; }) @@ -120,27 +138,28 @@ in } -/* SYNERGY SERVER example configuration file -section: screens - laptop: - dm: - win: -end -section: aliases +/* + SYNERGY SERVER example configuration file + section: screens laptop: - 192.168.5.5 dm: - 192.168.5.78 win: - 192.168.5.54 -end -section: links - laptop: - left = dm - dm: - right = laptop - left = win - win: - right = dm -end + end + section: aliases + laptop: + 192.168.5.5 + dm: + 192.168.5.78 + win: + 192.168.5.54 + end + section: links + laptop: + left = dm + dm: + right = laptop + left = win + win: + right = dm + end */ diff --git a/nixos/modules/services/misc/sysprof.nix b/nixos/modules/services/misc/sysprof.nix index ab91a8b586a232..f5b12d3de7ebd6 100644 --- a/nixos/modules/services/misc/sysprof.nix +++ b/nixos/modules/services/misc/sysprof.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { options = { diff --git a/nixos/modules/services/misc/tabby.nix b/nixos/modules/services/misc/tabby.nix index f84ceccc424e29..53cd553e649ff5 100644 --- a/nixos/modules/services/misc/tabby.nix +++ b/nixos/modules/services/misc/tabby.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) types; @@ -55,7 +60,14 @@ in }; acceleration = lib.mkOption { - type = types.nullOr (types.enum [ "cpu" "rocm" "cuda" "metal" ]); + type = types.nullOr ( + types.enum [ + "cpu" + "rocm" + "cuda" + "metal" + ] + ); default = null; example = "rocm"; description = '' @@ -140,61 +152,61 @@ in systemPackages = [ tabbyPackage ]; }; - - systemd = let - serviceUser = { - WorkingDirectory = "/var/lib/tabby"; - StateDirectory = [ "tabby" ]; - ConfigurationDirectory = [ "tabby" ]; - DynamicUser = true; - User = "tabby"; - Group = "tabby"; - }; - - serviceEnv = lib.mkMerge [ - { - TABBY_ROOT = "%S/tabby"; - } - (lib.mkIf (!cfg.usageCollection) { - TABBY_DISABLE_USAGE_COLLECTION = "1"; - }) - ]; - in { - services.tabby = { - wantedBy = [ "multi-user.target" ]; - description = "Self-hosted AI coding assistant using large language models"; - after = [ "network.target" ]; - environment = serviceEnv; - serviceConfig = lib.mkMerge [ - serviceUser + systemd = + let + serviceUser = { + WorkingDirectory = "/var/lib/tabby"; + StateDirectory = [ "tabby" ]; + ConfigurationDirectory = [ "tabby" ]; + DynamicUser = true; + User = "tabby"; + Group = "tabby"; + }; + + serviceEnv = lib.mkMerge [ { - ExecStart = - "${lib.getExe tabbyPackage} serve --model ${cfg.model} --port ${toString cfg.port} --device ${tabbyPackage.featureDevice}"; + TABBY_ROOT = "%S/tabby"; } + (lib.mkIf (!cfg.usageCollection) { + TABBY_DISABLE_USAGE_COLLECTION = "1"; + }) ]; + in + { + services.tabby = { + wantedBy = [ "multi-user.target" ]; + description = "Self-hosted AI coding assistant using large language models"; + after = [ "network.target" ]; + environment = serviceEnv; + serviceConfig = lib.mkMerge [ + serviceUser + { + ExecStart = "${lib.getExe tabbyPackage} serve --model ${cfg.model} --port ${toString cfg.port} --device ${tabbyPackage.featureDevice}"; + } + ]; + }; + + services.tabby-scheduler = lib.mkIf (cfg.indexInterval != "never") { + wantedBy = [ "multi-user.target" ]; + description = "Tabby repository indexing service"; + after = [ "network.target" ]; + environment = serviceEnv; + preStart = "cp -f /etc/tabby/config.toml \${TABBY_ROOT}/config.toml"; + serviceConfig = lib.mkMerge [ + serviceUser + { + # Type = "oneshot"; + ExecStart = "${lib.getExe tabbyPackage} scheduler --now"; + } + ]; + }; + timers.tabby-scheduler = lib.mkIf (cfg.indexInterval != "never") { + description = "Update timer for tabby-scheduler"; + partOf = [ "tabby-scheduler.service" ]; + wantedBy = [ "timers.target" ]; + timerConfig.OnUnitInactiveSec = cfg.indexInterval; + }; }; - - services.tabby-scheduler = lib.mkIf (cfg.indexInterval != "never") { - wantedBy = [ "multi-user.target" ]; - description = "Tabby repository indexing service"; - after = [ "network.target" ]; - environment = serviceEnv; - preStart = "cp -f /etc/tabby/config.toml \${TABBY_ROOT}/config.toml"; - serviceConfig = lib.mkMerge [ - serviceUser - { - # Type = "oneshot"; - ExecStart = "${lib.getExe tabbyPackage} scheduler --now"; - } - ]; - }; - timers.tabby-scheduler = lib.mkIf (cfg.indexInterval != "never") { - description = "Update timer for tabby-scheduler"; - partOf = [ "tabby-scheduler.service" ]; - wantedBy = [ "timers.target" ]; - timerConfig.OnUnitInactiveSec = cfg.indexInterval; - }; - }; }; meta.maintainers = with lib.maintainers; [ ghthor ]; diff --git a/nixos/modules/services/misc/tandoor-recipes.nix b/nixos/modules/services/misc/tandoor-recipes.nix index 0d211c946d5f71..1baa60f9f9cd0a 100644 --- a/nixos/modules/services/misc/tandoor-recipes.nix +++ b/nixos/modules/services/misc/tandoor-recipes.nix @@ -1,19 +1,25 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.tandoor-recipes; pkg = cfg.package; # SECRET_KEY through an env file - env = { - GUNICORN_CMD_ARGS = "--bind=${cfg.address}:${toString cfg.port}"; - DEBUG = "0"; - DEBUG_TOOLBAR = "0"; - MEDIA_ROOT = "/var/lib/tandoor-recipes"; - } // lib.optionalAttrs (config.time.timeZone != null) { - TZ = config.time.timeZone; - } // ( - lib.mapAttrs (_: toString) cfg.extraConfig - ); + env = + { + GUNICORN_CMD_ARGS = "--bind=${cfg.address}:${toString cfg.port}"; + DEBUG = "0"; + DEBUG_TOOLBAR = "0"; + MEDIA_ROOT = "/var/lib/tandoor-recipes"; + } + // lib.optionalAttrs (config.time.timeZone != null) { + TZ = config.time.timeZone; + } + // (lib.mapAttrs (_: toString) cfg.extraConfig); manage = pkgs.writeShellScript "manage" '' set -o allexport # Export the following env vars @@ -90,7 +96,9 @@ in RuntimeDirectory = "tandoor-recipes"; BindReadOnlyPaths = [ - "${config.environment.etc."ssl/certs/ca-certificates.crt".source}:/etc/ssl/certs/ca-certificates.crt" + "${ + config.environment.etc."ssl/certs/ca-certificates.crt".source + }:/etc/ssl/certs/ca-certificates.crt" builtins.storeDir "-/etc/resolv.conf" "-/etc/nsswitch.conf" @@ -110,12 +118,22 @@ in ProtectKernelLogs = true; ProtectKernelModules = true; ProtectKernelTunables = true; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; SystemCallArchitectures = "native"; # gunicorn needs setuid - SystemCallFilter = [ "@system-service" "~@privileged" "@resources" "@setuid" "@keyring" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "@resources" + "@setuid" + "@keyring" + ]; UMask = "0066"; }; diff --git a/nixos/modules/services/misc/taskserver/default.nix b/nixos/modules/services/misc/taskserver/default.nix index 618d369be21f41..64ff7437fb0893 100644 --- a/nixos/modules/services/misc/taskserver/default.nix +++ b/nixos/modules/services/misc/taskserver/default.nix @@ -1,20 +1,27 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.taskserver; taskd = "${pkgs.taskserver}/bin/taskd"; - mkManualPkiOption = desc: lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; - description = '' - ${desc} + mkManualPkiOption = + desc: + lib.mkOption { + type = lib.types.nullOr lib.types.path; + default = null; + description = '' + ${desc} - ::: {.note} - Setting this option will prevent automatic CA creation and handling. - ::: - ''; - }; + ::: {.note} + Setting this option will prevent automatic CA creation and handling. + ::: + ''; + }; manualPkiOptions = { ca.cert = mkManualPkiOption '' @@ -43,16 +50,18 @@ let ::: ''; - mkExpireOption = desc: lib.mkOption { - type = lib.types.nullOr lib.types.int; - default = null; - example = 365; - apply = val: if val == null then -1 else val; - description = mkAutoDesc '' - The expiration time of ${desc} in days or `null` for no - expiration time. - ''; - }; + mkExpireOption = + desc: + lib.mkOption { + type = lib.types.nullOr lib.types.int; + default = null; + example = 365; + apply = val: if val == null then -1 else val; + description = mkAutoDesc '' + The expiration time of ${desc} in days or `null` for no + expiration time. + ''; + }; autoPkiOptions = { bits = lib.mkOption { @@ -70,81 +79,113 @@ let }; }; - needToCreateCA = let - notFound = path: let - dotted = lib.concatStringsSep "." path; - in throw "Can't find option definitions for path `${dotted}'."; - findPkiDefinitions = path: attrs: let - mkSublist = key: val: let - newPath = path ++ lib.singleton key; - in if lib.isOption val - then lib.attrByPath newPath (notFound newPath) cfg.pki.manual - else findPkiDefinitions newPath val; - in lib.flatten (lib.mapAttrsToList mkSublist attrs); - in lib.all (x: x == null) (findPkiDefinitions [] manualPkiOptions); - - orgOptions = { ... }: { - options.users = lib.mkOption { - type = lib.types.uniq (lib.types.listOf lib.types.str); - default = []; - example = [ "alice" "bob" ]; - description = '' - A list of user names that belong to the organization. - ''; - }; + needToCreateCA = + let + notFound = + path: + let + dotted = lib.concatStringsSep "." path; + in + throw "Can't find option definitions for path `${dotted}'."; + findPkiDefinitions = + path: attrs: + let + mkSublist = + key: val: + let + newPath = path ++ lib.singleton key; + in + if lib.isOption val then + lib.attrByPath newPath (notFound newPath) cfg.pki.manual + else + findPkiDefinitions newPath val; + in + lib.flatten (lib.mapAttrsToList mkSublist attrs); + in + lib.all (x: x == null) (findPkiDefinitions [ ] manualPkiOptions); + + orgOptions = + { ... }: + { + options.users = lib.mkOption { + type = lib.types.uniq (lib.types.listOf lib.types.str); + default = [ ]; + example = [ + "alice" + "bob" + ]; + description = '' + A list of user names that belong to the organization. + ''; + }; - options.groups = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - example = [ "workers" "slackers" ]; - description = '' - A list of group names that belong to the organization. - ''; + options.groups = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + example = [ + "workers" + "slackers" + ]; + description = '' + A list of group names that belong to the organization. + ''; + }; }; - }; certtool = "${pkgs.gnutls.bin}/bin/certtool"; - nixos-taskserver = with pkgs.python3.pkgs; buildPythonApplication { - name = "nixos-taskserver"; - - src = pkgs.runCommand "nixos-taskserver-src" { preferLocalBuild = true; } '' - mkdir -p "$out" - cat "${pkgs.substituteAll { - src = ./helper-tool.py; - inherit taskd certtool; - inherit (cfg) dataDir user group fqdn; - certBits = cfg.pki.auto.bits; - clientExpiration = cfg.pki.auto.expiration.client; - crlExpiration = cfg.pki.auto.expiration.crl; - isAutoConfig = if needToCreateCA then "True" else "False"; - }}" > "$out/main.py" - cat > "$out/setup.py" < "$out/main.py" + cat > "$out/setup.py" < for full details. - ''; + description = + let + url = "https://gnutls.org/manual/html_node/Priority-Strings.html"; + in + '' + List of GnuTLS ciphers to use. See the GnuTLS documentation about + priority strings at <${url}> for full details. + ''; }; organisations = lib.mkOption { type = lib.types.attrsOf (lib.types.submodule orgOptions); - default = {}; - example.myShinyOrganisation.users = [ "alice" "bob" ]; - example.myShinyOrganisation.groups = [ "staff" "outsiders" ]; - example.yetAnotherOrganisation.users = [ "foo" "bar" ]; + default = { }; + example.myShinyOrganisation.users = [ + "alice" + "bob" + ]; + example.myShinyOrganisation.groups = [ + "staff" + "outsiders" + ]; + example.yetAnotherOrganisation.users = [ + "foo" + "bar" + ]; description = '' An attribute set where the keys name the organisation and the values are a set of lists of {option}`users` and @@ -241,7 +293,7 @@ in { allowedClientIDs = lib.mkOption { type = with lib.types; either str (listOf str); - default = []; + default = [ ]; example = [ "[Tt]ask [2-9]+" ]; description = '' A list of regular expressions that are matched against the reported @@ -255,7 +307,7 @@ in { disallowedClientIDs = lib.mkOption { type = with lib.types; either str (listOf str); - default = []; + default = [ ]; example = [ "[Tt]ask [2-9]+" ]; description = '' A list of regular expressions that are matched against the reported @@ -302,7 +354,10 @@ in { }; trust = lib.mkOption { - type = lib.types.enum [ "allow all" "strict" ]; + type = lib.types.enum [ + "allow all" + "strict" + ]; default = "strict"; description = '' Determines how client certificates are validated. @@ -335,25 +390,45 @@ in { Nix types like integers or booleans are automatically converted to the right values Taskserver would expect. ''; - apply = let - mkKey = path: if path == ["server" "listen"] then "server" - else lib.concatStringsSep "." path; - recurse = path: attrs: let - mapper = name: val: let - newPath = path ++ [ name ]; - scalar = if val == true then "true" - else if val == false then "false" - else toString val; - in if lib.isAttrs val then recurse newPath val - else [ "${mkKey newPath}=${scalar}" ]; - in lib.concatLists (lib.mapAttrsToList mapper attrs); - in recurse []; + apply = + let + mkKey = + path: + if + path == [ + "server" + "listen" + ] + then + "server" + else + lib.concatStringsSep "." path; + recurse = + path: attrs: + let + mapper = + name: val: + let + newPath = path ++ [ name ]; + scalar = + if val == true then + "true" + else if val == false then + "false" + else + toString val; + in + if lib.isAttrs val then recurse newPath val else [ "${mkKey newPath}=${scalar}" ]; + in + lib.concatLists (lib.mapAttrsToList mapper attrs); + in + recurse [ ]; }; }; }; imports = [ - (lib.mkRemovedOptionModule ["services" "taskserver" "extraConfig"] '' + (lib.mkRemovedOptionModule [ "services" "taskserver" "extraConfig" ] '' This option was removed in favor of `services.taskserver.config` with different semantics (it's now a list of attributes instead of lines). @@ -401,20 +476,26 @@ in { # server trust = cfg.trust; - server = { - listen = "${cfg.listenHost}:${toString cfg.listenPort}"; - } // (if needToCreateCA then { - cert = "${cfg.dataDir}/keys/server.cert"; - key = "${cfg.dataDir}/keys/server.key"; - crl = "${cfg.dataDir}/keys/server.crl"; - } else { - cert = "${cfg.pki.manual.server.cert}"; - key = "${cfg.pki.manual.server.key}"; - ${lib.mapNullable (_: "crl") cfg.pki.manual.server.crl} = "${cfg.pki.manual.server.crl}"; - }); - - ca.cert = if needToCreateCA then "${cfg.dataDir}/keys/ca.cert" - else "${cfg.pki.manual.ca.cert}"; + server = + { + listen = "${cfg.listenHost}:${toString cfg.listenPort}"; + } + // ( + if needToCreateCA then + { + cert = "${cfg.dataDir}/keys/server.cert"; + key = "${cfg.dataDir}/keys/server.key"; + crl = "${cfg.dataDir}/keys/server.crl"; + } + else + { + cert = "${cfg.pki.manual.server.cert}"; + key = "${cfg.pki.manual.server.key}"; + ${lib.mapNullable (_: "crl") cfg.pki.manual.server.crl} = "${cfg.pki.manual.server.crl}"; + } + ); + + ca.cert = if needToCreateCA then "${cfg.dataDir}/keys/ca.cert" else "${cfg.pki.manual.ca.cert}"; }; systemd.services.taskserver-init = { @@ -453,17 +534,21 @@ in { environment.TASKDDATA = cfg.dataDir; - preStart = let - jsonOrgs = builtins.toJSON cfg.organisations; - jsonFile = pkgs.writeText "orgs.json" jsonOrgs; - helperTool = "${nixos-taskserver}/bin/nixos-taskserver"; - in "${helperTool} process-json '${jsonFile}'"; + preStart = + let + jsonOrgs = builtins.toJSON cfg.organisations; + jsonFile = pkgs.writeText "orgs.json" jsonOrgs; + helperTool = "${nixos-taskserver}/bin/nixos-taskserver"; + in + "${helperTool} process-json '${jsonFile}'"; serviceConfig = { - ExecStart = let - mkCfgFlag = flag: lib.escapeShellArg "--${flag}"; - cfgFlags = lib.concatMapStringsSep " " mkCfgFlag cfg.config; - in "@${taskd} taskd server ${cfgFlags}"; + ExecStart = + let + mkCfgFlag = flag: lib.escapeShellArg "--${flag}"; + cfgFlags = lib.concatMapStringsSep " " mkCfgFlag cfg.config; + in + "@${taskd} taskd server ${cfgFlags}"; ExecReload = "${pkgs.coreutils}/bin/kill -USR1 $MAINPID"; Restart = "on-failure"; PermissionsStartOnly = true; diff --git a/nixos/modules/services/misc/tautulli.nix b/nixos/modules/services/misc/tautulli.nix index 467a632c72801a..dc3559ea94e0e2 100644 --- a/nixos/modules/services/misc/tautulli.nix +++ b/nixos/modules/services/misc/tautulli.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.tautulli; in @@ -73,7 +78,10 @@ in networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall [ cfg.port ]; users.users = lib.mkIf (cfg.user == "plexpy") { - plexpy = { group = cfg.group; uid = config.ids.uids.plexpy; }; + plexpy = { + group = cfg.group; + uid = config.ids.uids.plexpy; + }; }; }; } diff --git a/nixos/modules/services/misc/tiddlywiki.nix b/nixos/modules/services/misc/tiddlywiki.nix index 4cff412132d1a9..a6fe03ea69bb85 100644 --- a/nixos/modules/services/misc/tiddlywiki.nix +++ b/nixos/modules/services/misc/tiddlywiki.nix @@ -1,13 +1,21 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.tiddlywiki; - listenParams = lib.concatStrings (lib.mapAttrsToList (n: v: " '${n}=${toString v}' ") cfg.listenOptions); + listenParams = lib.concatStrings ( + lib.mapAttrsToList (n: v: " '${n}=${toString v}' ") cfg.listenOptions + ); exe = "${pkgs.nodePackages.tiddlywiki}/lib/node_modules/.bin/tiddlywiki"; name = "tiddlywiki"; dataDir = "/var/lib/" + name; -in { +in +{ options.services.tiddlywiki = { @@ -15,10 +23,10 @@ in { listenOptions = lib.mkOption { type = lib.types.attrs; - default = {}; + default = { }; example = { credentials = "../credentials.csv"; - readers="(authenticated)"; + readers = "(authenticated)"; port = 3456; }; description = '' diff --git a/nixos/modules/services/misc/tp-auto-kbbl.nix b/nixos/modules/services/misc/tp-auto-kbbl.nix index fe0192116982bf..6db22e5aa8405e 100644 --- a/nixos/modules/services/misc/tp-auto-kbbl.nix +++ b/nixos/modules/services/misc/tp-auto-kbbl.nix @@ -1,7 +1,14 @@ -{ config, lib, pkgs, ... }: -let cfg = config.services.tp-auto-kbbl; - -in { +{ + config, + lib, + pkgs, + ... +}: +let + cfg = config.services.tp-auto-kbbl; + +in +{ meta.maintainers = with lib.maintainers; [ sebtm ]; options = { @@ -32,8 +39,13 @@ in { systemd.services.tp-auto-kbbl = { serviceConfig = { - ExecStart = lib.concatStringsSep " " - ([ "${cfg.package}/bin/tp-auto-kbbl" "--device ${cfg.device}" ] ++ cfg.arguments); + ExecStart = lib.concatStringsSep " " ( + [ + "${cfg.package}/bin/tp-auto-kbbl" + "--device ${cfg.device}" + ] + ++ cfg.arguments + ); Restart = "always"; Type = "simple"; }; diff --git a/nixos/modules/services/misc/transfer-sh.nix b/nixos/modules/services/misc/transfer-sh.nix index b0d1b724d72719..0433f8971507d3 100644 --- a/nixos/modules/services/misc/transfer-sh.nix +++ b/nixos/modules/services/misc/transfer-sh.nix @@ -1,10 +1,25 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.transfer-sh; inherit (lib) - mkDefault mkEnableOption mkPackageOption mkIf mkOption - types mapAttrs isBool getExe boolToString optionalAttrs; + mkDefault + mkEnableOption + mkPackageOption + mkIf + mkOption + types + mapAttrs + isBool + getExe + boolToString + optionalAttrs + ; in { options.services.transfer-sh = { @@ -13,7 +28,15 @@ in package = mkPackageOption pkgs "transfer-sh" { }; settings = mkOption { - type = types.submodule { freeformType = with types; attrsOf (oneOf [ bool int str ]); }; + type = types.submodule { + freeformType = + with types; + attrsOf (oneOf [ + bool + int + str + ]); + }; default = { }; example = { LISTENER = ":8080"; @@ -30,7 +53,12 @@ in }; provider = mkOption { - type = types.enum [ "local" "s3" "storj" "gdrive" ]; + type = types.enum [ + "local" + "s3" + "storj" + "gdrive" + ]; default = "local"; description = "Storage providers to use"; }; @@ -56,19 +84,21 @@ in localProvider = (cfg.provider == "local"); stateDirectory = "/var/lib/transfer.sh"; in - mkIf cfg.enable - { - services.transfer-sh.settings = { + mkIf cfg.enable { + services.transfer-sh.settings = + { LISTENER = mkDefault ":8080"; - } // optionalAttrs localProvider { + } + // optionalAttrs localProvider { BASEDIR = mkDefault stateDirectory; }; - systemd.services.transfer-sh = { - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - environment = mapAttrs (_: v: if isBool v then boolToString v else toString v) cfg.settings; - serviceConfig = { + systemd.services.transfer-sh = { + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + environment = mapAttrs (_: v: if isBool v then boolToString v else toString v) cfg.settings; + serviceConfig = + { DevicePolicy = "closed"; DynamicUser = true; ExecStart = "${getExe cfg.package} --provider ${cfg.provider}"; @@ -83,19 +113,24 @@ in ProtectKernelModules = true; ProtectKernelTunables = true; ProtectProc = "invisible"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; SystemCallArchitectures = [ "native" ]; SystemCallFilter = [ "@system-service" ]; StateDirectory = baseNameOf stateDirectory; - } // optionalAttrs (cfg.secretFile != null) { + } + // optionalAttrs (cfg.secretFile != null) { EnvironmentFile = cfg.secretFile; - } // optionalAttrs localProvider { + } + // optionalAttrs localProvider { ReadWritePaths = cfg.settings.BASEDIR; }; - }; }; + }; meta.maintainers = with lib.maintainers; [ ocfox ]; } diff --git a/nixos/modules/services/misc/tuxclocker.nix b/nixos/modules/services/misc/tuxclocker.nix index ccbd4c6980e0f7..f316994314becf 100644 --- a/nixos/modules/services/misc/tuxclocker.nix +++ b/nixos/modules/services/misc/tuxclocker.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.programs.tuxclocker; in @@ -16,7 +21,10 @@ in enabledNVIDIADevices = lib.mkOption { type = lib.types.listOf lib.types.int; default = [ ]; - example = [ 0 1 ]; + example = [ + 0 + 1 + ]; description = '' Enable NVIDIA GPU controls for a device by index. Sets the `Coolbits` Xorg option to enable all TuxClocker controls. @@ -34,35 +42,39 @@ in }; }; - config = let + config = + let package = if cfg.useUnfree then pkgs.tuxclocker else pkgs.tuxclocker-without-unfree; in - lib.mkIf cfg.enable { - environment.systemPackages = [ - package - ]; + lib.mkIf cfg.enable { + environment.systemPackages = [ + package + ]; - services.dbus.packages = [ - package - ]; + services.dbus.packages = [ + package + ]; - # MSR is used for some features - boot.kernelModules = [ "msr" ]; + # MSR is used for some features + boot.kernelModules = [ "msr" ]; - # https://download.nvidia.com/XFree86/Linux-x86_64/430.14/README/xconfigoptions.html#Coolbits - services.xserver.config = let - configSection = (i: '' - Section "Device" - Driver "nvidia" - Option "Coolbits" "31" - Identifier "Device-nvidia[${toString i}]" - EndSection - ''); + # https://download.nvidia.com/XFree86/Linux-x86_64/430.14/README/xconfigoptions.html#Coolbits + services.xserver.config = + let + configSection = ( + i: '' + Section "Device" + Driver "nvidia" + Option "Coolbits" "31" + Identifier "Device-nvidia[${toString i}]" + EndSection + '' + ); in - lib.concatStrings (map configSection cfg.enabledNVIDIADevices); + lib.concatStrings (map configSection cfg.enabledNVIDIADevices); - # https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/drivers/gpu/drm/amd/include/amd_shared.h#n207 - # Enable everything modifiable in TuxClocker - boot.kernelParams = lib.mkIf cfg.enableAMD [ "amdgpu.ppfeaturemask=0xfffd7fff" ]; - }; + # https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/drivers/gpu/drm/amd/include/amd_shared.h#n207 + # Enable everything modifiable in TuxClocker + boot.kernelParams = lib.mkIf cfg.enableAMD [ "amdgpu.ppfeaturemask=0xfffd7fff" ]; + }; } diff --git a/nixos/modules/services/misc/uhub.nix b/nixos/modules/services/misc/uhub.nix index 58bf6a2c2ed7aa..befebdc20cdbdf 100644 --- a/nixos/modules/services/misc/uhub.nix +++ b/nixos/modules/services/misc/uhub.nix @@ -1,113 +1,144 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let settingsFormat = { - type = with lib.types; attrsOf (oneOf [ bool int str ]); - generate = name: attrs: - pkgs.writeText name (lib.strings.concatStringsSep "\n" - (lib.attrsets.mapAttrsToList - (key: value: "${key}=${builtins.toJSON value}") attrs)); + type = + with lib.types; + attrsOf (oneOf [ + bool + int + str + ]); + generate = + name: attrs: + pkgs.writeText name ( + lib.strings.concatStringsSep "\n" ( + lib.attrsets.mapAttrsToList (key: value: "${key}=${builtins.toJSON value}") attrs + ) + ); }; -in { +in +{ options = { services.uhub = lib.mkOption { default = { }; description = "Uhub ADC hub instances"; - type = lib.types.attrsOf (lib.types.submodule { - options = { + type = lib.types.attrsOf ( + lib.types.submodule { + options = { - enable = lib.mkEnableOption "hub instance" // { default = true; }; + enable = lib.mkEnableOption "hub instance" // { + default = true; + }; - enableTLS = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Whether to enable TLS support."; - }; + enableTLS = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Whether to enable TLS support."; + }; - settings = lib.mkOption { - inherit (settingsFormat) type; - description = '' - Configuration of uhub. - See https://www.uhub.org/doc/config.php for a list of options. - ''; - default = { }; - example = { - server_bind_addr = "any"; - server_port = 1511; - hub_name = "My Public Hub"; - hub_description = "Yet another ADC hub"; - max_users = 150; + settings = lib.mkOption { + inherit (settingsFormat) type; + description = '' + Configuration of uhub. + See https://www.uhub.org/doc/config.php for a list of options. + ''; + default = { }; + example = { + server_bind_addr = "any"; + server_port = 1511; + hub_name = "My Public Hub"; + hub_description = "Yet another ADC hub"; + max_users = 150; + }; }; - }; - plugins = lib.mkOption { - description = "Uhub plugin configuration."; - type = with lib.types; - listOf (submodule { - options = { - plugin = lib.mkOption { - type = path; - example = lib.literalExpression - "$${pkgs.uhub}/plugins/mod_auth_sqlite.so"; - description = "Path to plugin file."; + plugins = lib.mkOption { + description = "Uhub plugin configuration."; + type = + with lib.types; + listOf (submodule { + options = { + plugin = lib.mkOption { + type = path; + example = lib.literalExpression "$${pkgs.uhub}/plugins/mod_auth_sqlite.so"; + description = "Path to plugin file."; + }; + settings = lib.mkOption { + description = "Settings specific to this plugin."; + type = with types; attrsOf str; + example = { + file = "/etc/uhub/users.db"; + }; + }; }; - settings = lib.mkOption { - description = "Settings specific to this plugin."; - type = with types; attrsOf str; - example = { file = "/etc/uhub/users.db"; }; - }; - }; - }); - default = [ ]; - }; + }); + default = [ ]; + }; - }; - }); + }; + } + ); }; }; - config = let - hubs = lib.attrsets.filterAttrs (_: cfg: cfg.enable) config.services.uhub; - in { + config = + let + hubs = lib.attrsets.filterAttrs (_: cfg: cfg.enable) config.services.uhub; + in + { - environment.etc = lib.attrsets.mapAttrs' (name: cfg: - let - settings' = cfg.settings // { - tls_enable = cfg.enableTLS; - file_plugins = pkgs.writeText "uhub-plugins.conf" - (lib.strings.concatStringsSep "\n" (map ({ plugin, settings }: - '' - plugin ${plugin} "${ - toString - (lib.attrsets.mapAttrsToList (key: value: "${key}=${value}") - settings) - }"'') cfg.plugins)); - }; - in { - name = "uhub/${name}.conf"; - value.source = settingsFormat.generate "uhub-${name}.conf" settings'; - }) hubs; + environment.etc = lib.attrsets.mapAttrs' ( + name: cfg: + let + settings' = cfg.settings // { + tls_enable = cfg.enableTLS; + file_plugins = pkgs.writeText "uhub-plugins.conf" ( + lib.strings.concatStringsSep "\n" ( + map ( + { plugin, settings }: + ''plugin ${plugin} "${ + toString (lib.attrsets.mapAttrsToList (key: value: "${key}=${value}") settings) + }"'' + ) cfg.plugins + ) + ); + }; + in + { + name = "uhub/${name}.conf"; + value.source = settingsFormat.generate "uhub-${name}.conf" settings'; + } + ) hubs; - systemd.services = lib.attrsets.mapAttrs' (name: cfg: { - name = "uhub-${name}"; - value = let pkg = pkgs.uhub.override { tlsSupport = cfg.enableTLS; }; - in { - description = "high performance peer-to-peer hub for the ADC network"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - reloadIfChanged = true; - serviceConfig = { - Type = "notify"; - ExecStart = "${pkg}/bin/uhub -c /etc/uhub/${name}.conf -L"; - ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - DynamicUser = true; + systemd.services = lib.attrsets.mapAttrs' (name: cfg: { + name = "uhub-${name}"; + value = + let + pkg = pkgs.uhub.override { tlsSupport = cfg.enableTLS; }; + in + { + description = "high performance peer-to-peer hub for the ADC network"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + reloadIfChanged = true; + serviceConfig = { + Type = "notify"; + ExecStart = "${pkg}/bin/uhub -c /etc/uhub/${name}.conf -L"; + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + DynamicUser = true; - AmbientCapabilities = "CAP_NET_BIND_SERVICE"; - CapabilityBoundingSet = "CAP_NET_BIND_SERVICE"; - }; - }; - }) hubs; - }; + AmbientCapabilities = "CAP_NET_BIND_SERVICE"; + CapabilityBoundingSet = "CAP_NET_BIND_SERVICE"; + }; + }; + }) hubs; + }; } diff --git a/nixos/modules/services/misc/wastebin.nix b/nixos/modules/services/misc/wastebin.nix index 51dfe625c01076..499b071e4f3e68 100644 --- a/nixos/modules/services/misc/wastebin.nix +++ b/nixos/modules/services/misc/wastebin.nix @@ -1,10 +1,24 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.wastebin; inherit (lib) - mkEnableOption mkPackageOption mkIf mkOption - types mapAttrs isBool getExe boolToString optionalAttrs; + mkEnableOption + mkPackageOption + mkIf + mkOption + types + mapAttrs + isBool + getExe + boolToString + optionalAttrs + ; in { @@ -48,7 +62,13 @@ in type = types.submodule { - freeformType = with types; attrsOf (oneOf [ bool int str ]); + freeformType = + with types; + attrsOf (oneOf [ + bool + int + str + ]); options = { @@ -101,12 +121,11 @@ in RUST_LOG = mkOption { default = "info"; type = types.str; - description = - '' - Influences logging. Besides the typical trace, debug, info etc. - keys, you can also set the tower_http key to some log level to get - additional information request and response logs. - ''; + description = '' + Influences logging. Besides the typical trace, debug, info etc. + keys, you can also set the tower_http key to some log level to get + additional information request and response logs. + ''; }; }; }; @@ -119,13 +138,13 @@ in }; }; - config = mkIf cfg.enable - { - systemd.services.wastebin = { - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - environment = mapAttrs (_: v: if isBool v then boolToString v else toString v) cfg.settings; - serviceConfig = { + config = mkIf cfg.enable { + systemd.services.wastebin = { + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + environment = mapAttrs (_: v: if isBool v then boolToString v else toString v) cfg.settings; + serviceConfig = + { DevicePolicy = "closed"; DynamicUser = true; ExecStart = "${getExe cfg.package}"; @@ -140,18 +159,22 @@ in ProtectKernelModules = true; ProtectKernelTunables = true; ProtectProc = "invisible"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; SystemCallArchitectures = [ "native" ]; SystemCallFilter = [ "@system-service" ]; StateDirectory = baseNameOf cfg.stateDir; ReadWritePaths = cfg.stateDir; - } // optionalAttrs (cfg.secretFile != null) { + } + // optionalAttrs (cfg.secretFile != null) { EnvironmentFile = cfg.secretFile; }; - }; }; + }; meta.maintainers = with lib.maintainers; [ pinpox ]; } diff --git a/nixos/modules/services/misc/weechat.nix b/nixos/modules/services/misc/weechat.nix index 45180e2bbd5fd8..4b7f9dc4e022d2 100644 --- a/nixos/modules/services/misc/weechat.nix +++ b/nixos/modules/services/misc/weechat.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.weechat; in @@ -27,7 +32,7 @@ in config = lib.mkIf cfg.enable { users = { - groups.weechat = {}; + groups.weechat = { }; users.weechat = { createHome = true; group = "weechat"; @@ -48,12 +53,12 @@ in wants = [ "network.target" ]; }; - security.wrappers.screen = - { setuid = true; - owner = "root"; - group = "root"; - source = "${pkgs.screen}/bin/screen"; - }; + security.wrappers.screen = { + setuid = true; + owner = "root"; + group = "root"; + source = "${pkgs.screen}/bin/screen"; + }; }; meta.doc = ./weechat.md; diff --git a/nixos/modules/services/misc/xmrig.nix b/nixos/modules/services/misc/xmrig.nix index 4317f197d008f6..1d1c0724a892c6 100644 --- a/nixos/modules/services/misc/xmrig.nix +++ b/nixos/modules/services/misc/xmrig.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.xmrig; json = pkgs.formats.json { }; diff --git a/nixos/modules/services/misc/zoneminder.nix b/nixos/modules/services/misc/zoneminder.nix index 5b0b1448f68562..c6299d654e288d 100644 --- a/nixos/modules/services/misc/zoneminder.nix +++ b/nixos/modules/services/misc/zoneminder.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.zoneminder; @@ -8,10 +13,12 @@ let dirName = pkg.dirName; user = "zoneminder"; - group = { - nginx = config.services.nginx.group; - none = user; - }.${cfg.webserver}; + group = + { + nginx = config.services.nginx.group; + none = user; + } + .${cfg.webserver}; useNginx = cfg.webserver == "nginx"; @@ -25,12 +32,15 @@ let dirs = dirList: [ dirName ] ++ map (e: "${dirName}/${e}") dirList; cacheDirs = [ "swap" ]; - libDirs = [ "events" "exports" "images" "sounds" ]; + libDirs = [ + "events" + "exports" + "images" + "sounds" + ]; - dirStanzas = baseDir: - lib.concatStringsSep "\n" (map (e: - "ZM_DIR_${lib.toUpper e}=${baseDir}/${e}" - ) libDirs); + dirStanzas = + baseDir: lib.concatStringsSep "\n" (map (e: "ZM_DIR_${lib.toUpper e}=${baseDir}/${e}") libDirs); defaultsFile = pkgs.writeText "60-defaults.conf" '' # 01-system-paths.conf @@ -63,7 +73,8 @@ let ${cfg.extraConfig} ''; -in { +in +{ options = { services.zoneminder = with lib; { enable = lib.mkEnableOption '' @@ -78,7 +89,10 @@ in { ''; webserver = mkOption { - type = types.enum [ "nginx" "none" ]; + type = types.enum [ + "nginx" + "none" + ]; default = "nginx"; description = '' The webserver to configure for the PHP frontend. @@ -186,14 +200,15 @@ in { config = lib.mkIf cfg.enable { assertions = [ - { assertion = cfg.database.createLocally -> cfg.database.username == user; + { + assertion = cfg.database.createLocally -> cfg.database.username == user; message = "services.zoneminder.database.username must be set to ${user} if services.zoneminder.database.createLocally is set true"; } ]; environment.etc = { "zoneminder/60-defaults.conf".source = defaultsFile; - "zoneminder/80-nixos.conf".source = configFile; + "zoneminder/80-nixos.conf".source = configFile; }; networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall [ @@ -213,10 +228,14 @@ in { enable = true; package = lib.mkDefault pkgs.mariadb; ensureDatabases = [ cfg.database.name ]; - ensureUsers = [{ - name = cfg.database.username; - ensurePermissions = { "${cfg.database.name}.*" = "ALL PRIVILEGES"; }; - }]; + ensureUsers = [ + { + name = cfg.database.username; + ensurePermissions = { + "${cfg.database.name}.*" = "ALL PRIVILEGES"; + }; + } + ]; }; nginx = lib.mkIf useNginx { @@ -225,7 +244,12 @@ in { ${cfg.hostname} = { default = true; root = "${pkg}/share/zoneminder/www"; - listen = [ { addr = "0.0.0.0"; inherit (cfg) port; } ]; + listen = [ + { + addr = "0.0.0.0"; + inherit (cfg) port; + } + ]; extraConfig = '' index index.php; @@ -283,7 +307,13 @@ in { pools.zoneminder = { inherit user group; phpPackage = pkgs.php.withExtensions ( - { enabled, all }: enabled ++ [ all.apcu all.sysvsem ]); + { enabled, all }: + enabled + ++ [ + all.apcu + all.sysvsem + ] + ); phpOptions = '' date.timezone = "${config.time.timeZone}" ''; @@ -316,32 +346,37 @@ in { ]; after = [ "nginx.service" ] ++ lib.optional cfg.database.createLocally "mysql.service"; wantedBy = [ "multi-user.target" ]; - restartTriggers = [ defaultsFile configFile ]; - preStart = lib.optionalString useCustomDir '' - install -dm775 -o ${user} -g ${group} ${cfg.storageDir}/{${lib.concatStringsSep "," libDirs}} - '' + lib.optionalString cfg.database.createLocally '' - if ! test -e "/var/lib/${dirName}/db-created"; then - ${config.services.mysql.package}/bin/mysql < ${pkg}/share/zoneminder/db/zm_create.sql - touch "/var/lib/${dirName}/db-created" - fi - - ${zoneminder}/bin/zmupdate.pl -nointeractive - ${zoneminder}/bin/zmupdate.pl --nointeractive -f - - # Update ZM's Nix store path in the configuration table. Do nothing if the config doesn't - # contain ZM's Nix store path. - ${config.services.mysql.package}/bin/mysql -u zoneminder zm << EOF - UPDATE Config - SET Value = REGEXP_REPLACE(Value, "^/nix/store/[^-/]+-zoneminder-[^/]+", "${pkgs.zoneminder}") - WHERE Name = "ZM_FONT_FILE_LOCATION"; - EOF - ''; + restartTriggers = [ + defaultsFile + configFile + ]; + preStart = + lib.optionalString useCustomDir '' + install -dm775 -o ${user} -g ${group} ${cfg.storageDir}/{${lib.concatStringsSep "," libDirs}} + '' + + lib.optionalString cfg.database.createLocally '' + if ! test -e "/var/lib/${dirName}/db-created"; then + ${config.services.mysql.package}/bin/mysql < ${pkg}/share/zoneminder/db/zm_create.sql + touch "/var/lib/${dirName}/db-created" + fi + + ${zoneminder}/bin/zmupdate.pl -nointeractive + ${zoneminder}/bin/zmupdate.pl --nointeractive -f + + # Update ZM's Nix store path in the configuration table. Do nothing if the config doesn't + # contain ZM's Nix store path. + ${config.services.mysql.package}/bin/mysql -u zoneminder zm << EOF + UPDATE Config + SET Value = REGEXP_REPLACE(Value, "^/nix/store/[^-/]+-zoneminder-[^/]+", "${pkgs.zoneminder}") + WHERE Name = "ZM_FONT_FILE_LOCATION"; + EOF + ''; serviceConfig = { User = user; Group = group; SupplementaryGroups = [ "video" ]; - ExecStart = "${zoneminder}/bin/zmpkg.pl start"; - ExecStop = "${zoneminder}/bin/zmpkg.pl stop"; + ExecStart = "${zoneminder}/bin/zmpkg.pl start"; + ExecStop = "${zoneminder}/bin/zmpkg.pl stop"; ExecReload = "${zoneminder}/bin/zmpkg.pl restart"; PIDFile = "/run/${dirName}/zm.pid"; Type = "forking"; diff --git a/nixos/modules/services/misc/zookeeper.nix b/nixos/modules/services/misc/zookeeper.nix index fc06d56b0d5a82..498eab040f26e6 100644 --- a/nixos/modules/services/misc/zookeeper.nix +++ b/nixos/modules/services/misc/zookeeper.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.zookeeper; @@ -18,7 +23,8 @@ let ]; }; -in { +in +{ options.services.zookeeper = { enable = lib.mkEnableOption "Zookeeper"; @@ -87,9 +93,16 @@ in { extraCmdLineOptions = lib.mkOption { description = "Extra command line options for the Zookeeper launcher."; - default = [ "-Dcom.sun.management.jmxremote" "-Dcom.sun.management.jmxremote.local.only=true" ]; + default = [ + "-Dcom.sun.management.jmxremote" + "-Dcom.sun.management.jmxremote.local.only=true" + ]; type = lib.types.listOf lib.types.str; - example = [ "-Djava.net.preferIPv4Stack=true" "-Dcom.sun.management.jmxremote" "-Dcom.sun.management.jmxremote.local.only=true" ]; + example = [ + "-Djava.net.preferIPv4Stack=true" + "-Dcom.sun.management.jmxremote" + "-Dcom.sun.management.jmxremote.local.only=true" + ]; }; preferIPv4 = lib.mkOption { @@ -111,9 +124,8 @@ in { }; }; - config = lib.mkIf cfg.enable { - environment.systemPackages = [cfg.package]; + environment.systemPackages = [ cfg.package ]; systemd.tmpfiles.rules = [ "d '${cfg.dataDir}' 0700 zookeeper - - -" @@ -148,6 +160,6 @@ in { description = "Zookeeper daemon user"; home = cfg.dataDir; }; - users.groups.zookeeper = {}; + users.groups.zookeeper = { }; }; } diff --git a/nixos/modules/services/monitoring/alerta.nix b/nixos/modules/services/monitoring/alerta.nix index 54aff7d6a92c36..ea8694727c633e 100644 --- a/nixos/modules/services/monitoring/alerta.nix +++ b/nixos/modules/services/monitoring/alerta.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.alerta; @@ -53,7 +58,10 @@ in corsOrigins = lib.mkOption { type = lib.types.listOf lib.types.str; description = "List of URLs that can access the API for Cross-Origin Resource Sharing (CORS)"; - default = [ "http://localhost" "http://localhost:5000" ]; + default = [ + "http://localhost" + "http://localhost:5000" + ]; }; authenticationRequired = lib.mkOption { diff --git a/nixos/modules/services/monitoring/alloy.nix b/nixos/modules/services/monitoring/alloy.nix index 8507900756b63b..25ca8eb1a74b34 100644 --- a/nixos/modules/services/monitoring/alloy.nix +++ b/nixos/modules/services/monitoring/alloy.nix @@ -1,10 +1,18 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: let cfg = config.services.alloy; in { meta = { - maintainers = with lib.maintainers; [ flokli hbjydev ]; + maintainers = with lib.maintainers; [ + flokli + hbjydev + ]; }; options.services.alloy = { @@ -45,7 +53,10 @@ in extraFlags = lib.mkOption { type = with lib.types; listOf str; default = [ ]; - example = [ "--server.http.listen-addr=127.0.0.1:12346" "--disable-reporting" ]; + example = [ + "--server.http.listen-addr=127.0.0.1:12346" + "--disable-reporting" + ]; description = '' Extra command-line flags passed to {command}`alloy run`. @@ -54,7 +65,6 @@ in }; }; - config = lib.mkIf cfg.enable { systemd.services.alloy = { wantedBy = [ "multi-user.target" ]; diff --git a/nixos/modules/services/monitoring/arbtt.nix b/nixos/modules/services/monitoring/arbtt.nix index 9c04e4447c733e..fce2945e6685a2 100644 --- a/nixos/modules/services/monitoring/arbtt.nix +++ b/nixos/modules/services/monitoring/arbtt.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.arbtt; -in { +in +{ options = { services.arbtt = { enable = lib.mkEnableOption "Arbtt statistics capture service"; diff --git a/nixos/modules/services/monitoring/below.nix b/nixos/modules/services/monitoring/below.nix index 26a38e5f82a42e..79f9badf65fe74 100644 --- a/nixos/modules/services/monitoring/below.nix +++ b/nixos/modules/services/monitoring/below.nix @@ -1,28 +1,43 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.below; cfgContents = lib.concatStringsSep "\n" ( - lib.mapAttrsToList (n: v: ''${n} = "${v}"'') (lib.filterAttrs (_k: v: v != null) { - log_dir = cfg.dirs.log; - store_dir = cfg.dirs.store; - cgroup_filter_out = cfg.cgroupFilterOut; - }) + lib.mapAttrsToList (n: v: ''${n} = "${v}"'') ( + lib.filterAttrs (_k: v: v != null) { + log_dir = cfg.dirs.log; + store_dir = cfg.dirs.store; + cgroup_filter_out = cfg.cgroupFilterOut; + } + ) ); - mkDisableOption = n: lib.mkOption { - type = lib.types.bool; - default = true; - description = "Whether to enable ${n}."; - }; - optionalType = ty: x: lib.mkOption (x // { - description = x.description; - type = (lib.types.nullOr ty); - default = null; - }); + mkDisableOption = + n: + lib.mkOption { + type = lib.types.bool; + default = true; + description = "Whether to enable ${n}."; + }; + optionalType = + ty: x: + lib.mkOption ( + x + // { + description = x.description; + type = (lib.types.nullOr ty); + default = null; + } + ); optionalPath = optionalType lib.types.path; optionalStr = optionalType lib.types.str; optionalInt = optionalType lib.types.int; -in { +in +{ options = { services.below = { enable = lib.mkEnableOption "'below' resource monitor"; @@ -33,7 +48,7 @@ in { }; collect = { diskStats = mkDisableOption "dist_stat collection"; - ioStats = lib.mkEnableOption "io.stat collection for cgroups"; + ioStats = lib.mkEnableOption "io.stat collection for cgroups"; exitStats = mkDisableOption "eBPF-based exitstats"; }; compression.enable = lib.mkEnableOption "data compression"; @@ -89,15 +104,19 @@ in { serviceConfig.ExecStart = [ "" - ("${lib.getExe pkgs.below} record " + (lib.concatStringsSep " " ( - lib.optional (!cfg.collect.diskStats) "--disable-disk-stat" ++ - lib.optional cfg.collect.ioStats "--collect-io-stat" ++ - lib.optional (!cfg.collect.exitStats) "--disable-exitstats" ++ - lib.optional cfg.compression.enable "--compress" ++ + ( + "${lib.getExe pkgs.below} record " + + (lib.concatStringsSep " " ( + lib.optional (!cfg.collect.diskStats) "--disable-disk-stat" + ++ lib.optional cfg.collect.ioStats "--collect-io-stat" + ++ lib.optional (!cfg.collect.exitStats) "--disable-exitstats" + ++ lib.optional cfg.compression.enable "--compress" + ++ - lib.optional (cfg.retention.size != null) "--store-size-limit ${toString cfg.retention.size}" ++ - lib.optional (cfg.retention.time != null) "--retain-for-s ${toString cfg.retention.time}" - ))) + lib.optional (cfg.retention.size != null) "--store-size-limit ${toString cfg.retention.size}" + ++ lib.optional (cfg.retention.time != null) "--retain-for-s ${toString cfg.retention.time}" + )) + ) ]; }; }; diff --git a/nixos/modules/services/monitoring/bosun.nix b/nixos/modules/services/monitoring/bosun.nix index 08288f644e7770..d701a1a5254420 100644 --- a/nixos/modules/services/monitoring/bosun.nix +++ b/nixos/modules/services/monitoring/bosun.nix @@ -1,10 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.bosun; configFile = pkgs.writeText "bosun.conf" '' - ${lib.optionalString (cfg.opentsdbHost !=null) "tsdbHost = ${cfg.opentsdbHost}"} - ${lib.optionalString (cfg.influxHost !=null) "influxHost = ${cfg.influxHost}"} + ${lib.optionalString (cfg.opentsdbHost != null) "tsdbHost = ${cfg.opentsdbHost}"} + ${lib.optionalString (cfg.influxHost != null) "influxHost = ${cfg.influxHost}"} httpListen = ${cfg.listenAddress} stateFile = ${cfg.stateFile} ledisDir = ${cfg.ledisDir} @@ -13,7 +18,8 @@ let ${cfg.extraConfig} ''; -in { +in +{ options = { @@ -53,7 +59,7 @@ in { default = null; example = "localhost:8086"; description = '' - Host and port of the influxdb database. + Host and port of the influxdb database. ''; }; diff --git a/nixos/modules/services/monitoring/cadvisor.nix b/nixos/modules/services/monitoring/cadvisor.nix index b801cde833d6e2..c376fad895fe98 100644 --- a/nixos/modules/services/monitoring/cadvisor.nix +++ b/nixos/modules/services/monitoring/cadvisor.nix @@ -1,8 +1,14 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.cadvisor; -in { +in +{ options = { services.cadvisor = { enable = lib.mkEnableOption "Cadvisor service"; @@ -80,7 +86,7 @@ in { extraOptions = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Additional cadvisor options. @@ -91,18 +97,27 @@ in { }; config = lib.mkMerge [ - { services.cadvisor.storageDriverPasswordFile = lib.mkIf (cfg.storageDriverPassword != "") ( - lib.mkDefault (toString (pkgs.writeTextFile { - name = "cadvisor-storage-driver-password"; - text = cfg.storageDriverPassword; - })) + { + services.cadvisor.storageDriverPasswordFile = lib.mkIf (cfg.storageDriverPassword != "") ( + lib.mkDefault ( + toString ( + pkgs.writeTextFile { + name = "cadvisor-storage-driver-password"; + text = cfg.storageDriverPassword; + } + ) + ) ); } (lib.mkIf cfg.enable { systemd.services.cadvisor = { wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "docker.service" "influxdb.service" ]; + after = [ + "network.target" + "docker.service" + "influxdb.service" + ]; path = lib.optionals config.boot.zfs.enabled [ pkgs.zfs ]; @@ -128,7 +143,7 @@ in { ''} ''; - serviceConfig.TimeoutStartSec=300; + serviceConfig.TimeoutStartSec = 300; }; }) ]; diff --git a/nixos/modules/services/monitoring/certspotter.nix b/nixos/modules/services/monitoring/certspotter.nix index 5551f0e37c512e..7d27844f612454 100644 --- a/nixos/modules/services/monitoring/certspotter.nix +++ b/nixos/modules/services/monitoring/certspotter.nix @@ -1,7 +1,9 @@ -{ config -, lib -, pkgs -, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.certspotter; @@ -13,16 +15,21 @@ let } ++ lib.optional (cfg.emailRecipients != [ ]) { name = "email_recipients"; - path = pkgs.writeText "certspotter-email_recipients" (builtins.concatStringsSep "\n" cfg.emailRecipients); + path = pkgs.writeText "certspotter-email_recipients" ( + builtins.concatStringsSep "\n" cfg.emailRecipients + ); } # always generate hooks dir when no emails are provided to allow running cert spotter with no hooks/emails ++ lib.optional (cfg.emailRecipients == [ ] || cfg.hooks != [ ]) { name = "hooks.d"; - path = pkgs.linkFarm "certspotter-hooks" (lib.imap1 (i: path: { - inherit path; - name = "hook${toString i}"; - }) cfg.hooks); - }); + path = pkgs.linkFarm "certspotter-hooks" ( + lib.imap1 (i: path: { + inherit path; + name = "hook${toString i}"; + }) cfg.hooks + ); + } + ); in { options.services.certspotter = { @@ -52,7 +59,10 @@ in type = with lib.types; listOf str; description = "Domain names to watch. To monitor a domain with all subdomains, prefix its name with `.` (e.g. `.example.org`)."; default = [ ]; - example = [ ".example.org" "another.example.com" ]; + example = [ + ".example.org" + "another.example.com" + ]; }; emailRecipients = lib.mkOption { @@ -65,7 +75,9 @@ in type = with lib.types; listOf path; description = '' Scripts to run upon the detection of a new certificate. See `man 8 certspotter-script` or - [the GitHub page](https://github.com/SSLMate/certspotter/blob/${pkgs.certspotter.src.rev or "master"}/man/certspotter-script.md) + [the GitHub page](https://github.com/SSLMate/certspotter/blob/${ + pkgs.certspotter.src.rev or "master" + }/man/certspotter-script.md) for more info. ''; default = [ ]; @@ -97,13 +109,17 @@ in } ]; - services.certspotter.sendmailPath = let - inherit (config.security) wrapperDir; - inherit (config.services.mail) sendmailSetuidWrapper; - in lib.mkMerge [ - (lib.mkIf (sendmailSetuidWrapper != null) (lib.mkOptionDefault "${wrapperDir}/${sendmailSetuidWrapper.program}")) - (lib.mkIf (sendmailSetuidWrapper == null) (lib.mkOptionDefault null)) - ]; + services.certspotter.sendmailPath = + let + inherit (config.security) wrapperDir; + inherit (config.services.mail) sendmailSetuidWrapper; + in + lib.mkMerge [ + (lib.mkIf (sendmailSetuidWrapper != null) ( + lib.mkOptionDefault "${wrapperDir}/${sendmailSetuidWrapper.program}" + )) + (lib.mkIf (sendmailSetuidWrapper == null) (lib.mkOptionDefault null)) + ]; users.users.certspotter = { description = "Cert Spotter user"; @@ -118,7 +134,8 @@ in after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; environment.CERTSPOTTER_CONFIG_DIR = configDir; - environment.SENDMAIL_PATH = if cfg.sendmailPath != null then cfg.sendmailPath else "/run/current-system/sw/bin/false"; + environment.SENDMAIL_PATH = + if cfg.sendmailPath != null then cfg.sendmailPath else "/run/current-system/sw/bin/false"; script = '' export CERTSPOTTER_STATE_DIR="$STATE_DIRECTORY" cd "$CERTSPOTTER_STATE_DIR" diff --git a/nixos/modules/services/monitoring/collectd.nix b/nixos/modules/services/monitoring/collectd.nix index 1bd7da52fef822..fc97d4f63e6c4f 100644 --- a/nixos/modules/services/monitoring/collectd.nix +++ b/nixos/modules/services/monitoring/collectd.nix @@ -1,30 +1,36 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.collectd; baseDirLine = ''BaseDir "${cfg.dataDir}"''; unvalidated_conf = pkgs.writeText "collectd-unvalidated.conf" cfg.extraConfig; - conf = if cfg.validateConfig then - pkgs.runCommand "collectd.conf" {} '' - echo testing ${unvalidated_conf} - cp ${unvalidated_conf} collectd.conf - # collectd -t fails if BaseDir does not exist. - substituteInPlace collectd.conf --replace ${lib.escapeShellArgs [ baseDirLine ]} 'BaseDir "."' - ${package}/bin/collectd -t -C collectd.conf - cp ${unvalidated_conf} $out - '' else unvalidated_conf; - - package = - if cfg.buildMinimalPackage - then minimalPackage - else cfg.package; + conf = + if cfg.validateConfig then + pkgs.runCommand "collectd.conf" { } '' + echo testing ${unvalidated_conf} + cp ${unvalidated_conf} collectd.conf + # collectd -t fails if BaseDir does not exist. + substituteInPlace collectd.conf --replace ${lib.escapeShellArgs [ baseDirLine ]} 'BaseDir "."' + ${package}/bin/collectd -t -C collectd.conf + cp ${unvalidated_conf} $out + '' + else + unvalidated_conf; + + package = if cfg.buildMinimalPackage then minimalPackage else cfg.package; minimalPackage = cfg.package.override { enabledPlugins = [ "syslog" ] ++ builtins.attrNames cfg.plugins; }; -in { +in +{ options.services.collectd = with lib.types; { enable = lib.mkEnableOption "collectd agent"; @@ -73,7 +79,7 @@ in { }; include = lib.mkOption { - default = []; + default = [ ]; description = '' Additional paths to load config from. ''; @@ -81,8 +87,12 @@ in { }; plugins = lib.mkOption { - default = {}; - example = { cpu = ""; memory = ""; network = "Server 192.168.1.1 25826"; }; + default = { }; + example = { + cpu = ""; + memory = ""; + network = "Server 192.168.1.1 25826"; + }; description = '' Attribute set of plugin names to plugin config segments ''; @@ -113,12 +123,14 @@ in { NotifyLevel "OKAY" - ${lib.concatStrings (lib.mapAttrsToList (plugin: pluginConfig: '' - LoadPlugin ${plugin} - - ${pluginConfig} - - '') cfg.plugins)} + ${lib.concatStrings ( + lib.mapAttrsToList (plugin: pluginConfig: '' + LoadPlugin ${plugin} + + ${pluginConfig} + + '') cfg.plugins + )} ${lib.concatMapStrings (f: '' Include "${f}" @@ -150,7 +162,7 @@ in { }; users.groups = lib.optionalAttrs (cfg.user == "collectd") { - collectd = {}; + collectd = { }; }; }; } diff --git a/nixos/modules/services/monitoring/das_watchdog.nix b/nixos/modules/services/monitoring/das_watchdog.nix index e076bf64364e12..82c9fea168d126 100644 --- a/nixos/modules/services/monitoring/das_watchdog.nix +++ b/nixos/modules/services/monitoring/das_watchdog.nix @@ -1,11 +1,17 @@ # A general watchdog for the linux operating system that should run in the # background at all times to ensure a realtime process won't hang the machine -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (pkgs) das_watchdog; -in { +in +{ ###### interface options = { @@ -18,7 +24,10 @@ in { environment.systemPackages = [ das_watchdog ]; systemd.services.das_watchdog = { description = "Watchdog to ensure a realtime process won't hang the machine"; - after = [ "multi-user.target" "sound.target" ]; + after = [ + "multi-user.target" + "sound.target" + ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { User = "root"; diff --git a/nixos/modules/services/monitoring/do-agent.nix b/nixos/modules/services/monitoring/do-agent.nix index e5f1bdf7fdfc4e..23595ac00c3234 100644 --- a/nixos/modules/services/monitoring/do-agent.nix +++ b/nixos/modules/services/monitoring/do-agent.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.do-agent; @@ -14,7 +19,10 @@ in systemd.services.do-agent = { wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart = [ "" "${pkgs.do-agent}/bin/do-agent --syslog" ]; + ExecStart = [ + "" + "${pkgs.do-agent}/bin/do-agent --syslog" + ]; DynamicUser = true; }; }; diff --git a/nixos/modules/services/monitoring/goss.nix b/nixos/modules/services/monitoring/goss.nix index 00246752a7cd62..b53df0806d26da 100644 --- a/nixos/modules/services/monitoring/goss.nix +++ b/nixos/modules/services/monitoring/goss.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.goss; @@ -6,7 +11,8 @@ let settingsFormat = pkgs.formats.yaml { }; configFile = settingsFormat.generate "goss.yaml" cfg.settings; -in { +in +{ meta = { doc = ./goss.md; maintainers = [ lib.maintainers.anthonyroussel ]; diff --git a/nixos/modules/services/monitoring/grafana-agent.nix b/nixos/modules/services/monitoring/grafana-agent.nix index f82675c8c6cb77..f00514d61936cc 100644 --- a/nixos/modules/services/monitoring/grafana-agent.nix +++ b/nixos/modules/services/monitoring/grafana-agent.nix @@ -1,4 +1,10 @@ -{ lib, pkgs, config, generators, ... }: +{ + lib, + pkgs, + config, + generators, + ... +}: let cfg = config.services.grafana-agent; settingsFormat = pkgs.formats.yaml { }; @@ -6,7 +12,10 @@ let in { meta = { - maintainers = with lib.maintainers; [ flokli zimbatm ]; + maintainers = with lib.maintainers; [ + flokli + zimbatm + ]; }; options.services.grafana-agent = { @@ -34,7 +43,10 @@ in extraFlags = lib.mkOption { type = with lib.types; listOf str; default = [ ]; - example = [ "-enable-features=integrations-next" "-disable-reporting" ]; + example = [ + "-enable-features=integrations-next" + "-disable-reporting" + ]; description = '' Extra command-line flags passed to {command}`grafana-agent`. @@ -68,43 +80,49 @@ in } ''; example = { - metrics.global.remote_write = [{ - url = "\${METRICS_REMOTE_WRITE_URL}"; - basic_auth.username = "\${METRICS_REMOTE_WRITE_USERNAME}"; - basic_auth.password_file = "\${CREDENTIALS_DIRECTORY}/metrics_remote_write_password"; - }]; - logs.configs = [{ - name = "default"; - scrape_configs = [ - { - job_name = "journal"; - journal = { - max_age = "12h"; - labels.job = "systemd-journal"; - }; - relabel_configs = [ - { - source_labels = [ "__journal__systemd_unit" ]; - target_label = "systemd_unit"; - } - { - source_labels = [ "__journal__hostname" ]; - target_label = "nodename"; - } - { - source_labels = [ "__journal_syslog_identifier" ]; - target_label = "syslog_identifier"; - } - ]; - } - ]; - positions.filename = "\${STATE_DIRECTORY}/loki_positions.yaml"; - clients = [{ - url = "\${LOGS_REMOTE_WRITE_URL}"; - basic_auth.username = "\${LOGS_REMOTE_WRITE_USERNAME}"; - basic_auth.password_file = "\${CREDENTIALS_DIRECTORY}/logs_remote_write_password"; - }]; - }]; + metrics.global.remote_write = [ + { + url = "\${METRICS_REMOTE_WRITE_URL}"; + basic_auth.username = "\${METRICS_REMOTE_WRITE_USERNAME}"; + basic_auth.password_file = "\${CREDENTIALS_DIRECTORY}/metrics_remote_write_password"; + } + ]; + logs.configs = [ + { + name = "default"; + scrape_configs = [ + { + job_name = "journal"; + journal = { + max_age = "12h"; + labels.job = "systemd-journal"; + }; + relabel_configs = [ + { + source_labels = [ "__journal__systemd_unit" ]; + target_label = "systemd_unit"; + } + { + source_labels = [ "__journal__hostname" ]; + target_label = "nodename"; + } + { + source_labels = [ "__journal_syslog_identifier" ]; + target_label = "syslog_identifier"; + } + ]; + } + ]; + positions.filename = "\${STATE_DIRECTORY}/loki_positions.yaml"; + clients = [ + { + url = "\${LOGS_REMOTE_WRITE_URL}"; + basic_auth.username = "\${LOGS_REMOTE_WRITE_USERNAME}"; + basic_auth.password_file = "\${CREDENTIALS_DIRECTORY}/logs_remote_write_password"; + } + ]; + } + ]; }; }; }; diff --git a/nixos/modules/services/monitoring/grafana-image-renderer.nix b/nixos/modules/services/monitoring/grafana-image-renderer.nix index e477f73adaa130..9ec6cc9d97aeef 100644 --- a/nixos/modules/services/monitoring/grafana-image-renderer.nix +++ b/nixos/modules/services/monitoring/grafana-image-renderer.nix @@ -1,11 +1,17 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: let cfg = config.services.grafana-image-renderer; format = pkgs.formats.json { }; configFile = format.generate "grafana-image-renderer-config.json" cfg.settings; -in { +in +{ options.services.grafana-image-renderer = { enable = lib.mkEnableOption "grafana-image-renderer"; @@ -34,7 +40,12 @@ in { ''; }; logging.level = lib.mkOption { - type = lib.types.enum [ "error" "warning" "info" "debug" ]; + type = lib.types.enum [ + "error" + "warning" + "info" + "debug" + ]; default = "info"; description = '' The log-level of the {file}`grafana-image-renderer.service`-unit. @@ -58,7 +69,11 @@ in { }; mode = lib.mkOption { default = "default"; - type = lib.types.enum [ "default" "reusable" "clustered" ]; + type = lib.types.enum [ + "default" + "reusable" + "clustered" + ]; description = '' Rendering mode of `grafana-image-renderer`: @@ -82,7 +97,7 @@ in { }; }; - default = {}; + default = { }; description = '' Configuration attributes for `grafana-image-renderer`. @@ -95,7 +110,8 @@ in { config = lib.mkIf cfg.enable { assertions = [ - { assertion = cfg.provisionGrafana -> config.services.grafana.enable; + { + assertion = cfg.provisionGrafana -> config.services.grafana.enable; message = '' To provision a Grafana instance to use grafana-image-renderer, `services.grafana.enable` must be set to `true`! diff --git a/nixos/modules/services/monitoring/grafana-reporter.nix b/nixos/modules/services/monitoring/grafana-reporter.nix index 91725206ea12aa..3b3c3cc3887a2b 100644 --- a/nixos/modules/services/monitoring/grafana-reporter.nix +++ b/nixos/modules/services/monitoring/grafana-reporter.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.grafana_reporter; -in { +in +{ options.services.grafana_reporter = { enable = lib.mkEnableOption "grafana_reporter"; @@ -10,7 +16,10 @@ in { protocol = lib.mkOption { description = "Grafana protocol."; default = "http"; - type = lib.types.enum ["http" "https"]; + type = lib.types.enum [ + "http" + "https" + ]; }; addr = lib.mkOption { description = "Grafana address."; @@ -47,18 +56,20 @@ in { config = lib.mkIf cfg.enable { systemd.services.grafana_reporter = { description = "Grafana Reporter Service Daemon"; - wantedBy = ["multi-user.target"]; - after = ["network.target"]; - serviceConfig = let - args = lib.concatStringsSep " " [ - "-proto ${cfg.grafana.protocol}://" - "-ip ${cfg.grafana.addr}:${toString cfg.grafana.port}" - "-port :${toString cfg.port}" - "-templates ${cfg.templateDir}" - ]; - in { - ExecStart = "${pkgs.grafana-reporter}/bin/grafana-reporter ${args}"; - }; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + serviceConfig = + let + args = lib.concatStringsSep " " [ + "-proto ${cfg.grafana.protocol}://" + "-ip ${cfg.grafana.addr}:${toString cfg.grafana.port}" + "-port :${toString cfg.port}" + "-templates ${cfg.templateDir}" + ]; + in + { + ExecStart = "${pkgs.grafana-reporter}/bin/grafana-reporter ${args}"; + }; }; }; } diff --git a/nixos/modules/services/monitoring/graphite.nix b/nixos/modules/services/monitoring/graphite.nix index 7987f34f1278be..162d9ce679bec6 100644 --- a/nixos/modules/services/monitoring/graphite.nix +++ b/nixos/modules/services/monitoring/graphite.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.graphite; opt = options.services.graphite; @@ -7,17 +13,20 @@ let dataDir = cfg.dataDir; staticDir = cfg.dataDir + "/static"; - graphiteLocalSettingsDir = pkgs.runCommand "graphite_local_settings" { - inherit graphiteLocalSettings; - preferLocalBuild = true; - } '' - mkdir -p $out - ln -s $graphiteLocalSettings $out/graphite_local_settings.py - ''; + graphiteLocalSettingsDir = + pkgs.runCommand "graphite_local_settings" + { + inherit graphiteLocalSettings; + preferLocalBuild = true; + } + '' + mkdir -p $out + ln -s $graphiteLocalSettings $out/graphite_local_settings.py + ''; graphiteLocalSettings = pkgs.writeText "graphite_local_settings.py" ( - "STATIC_ROOT = '${staticDir}'\n" + - lib.optionalString (config.time.timeZone != null) "TIME_ZONE = '${config.time.timeZone}'\n" + "STATIC_ROOT = '${staticDir}'\n" + + lib.optionalString (config.time.timeZone != null) "TIME_ZONE = '${config.time.timeZone}'\n" + cfg.web.extraConfig ); @@ -41,27 +50,31 @@ let ]; }; - carbonOpts = name: with config.ids; '' - --nodaemon --syslog --prefix=${name} --pidfile /run/${name}/${name}.pid ${name} - ''; + carbonOpts = + name: with config.ids; '' + --nodaemon --syslog --prefix=${name} --pidfile /run/${name}/${name}.pid ${name} + ''; carbonEnv = { - PYTHONPATH = let - cenv = pkgs.python3.buildEnv.override { - extraLibs = [ pkgs.python3Packages.carbon ]; - }; - in "${cenv}/${pkgs.python3.sitePackages}"; + PYTHONPATH = + let + cenv = pkgs.python3.buildEnv.override { + extraLibs = [ pkgs.python3Packages.carbon ]; + }; + in + "${cenv}/${pkgs.python3.sitePackages}"; GRAPHITE_ROOT = dataDir; GRAPHITE_CONF_DIR = configDir; GRAPHITE_STORAGE_DIR = dataDir; }; -in { +in +{ imports = [ - (lib.mkRemovedOptionModule ["services" "graphite" "api"] "") - (lib.mkRemovedOptionModule ["services" "graphite" "beacon"] "") - (lib.mkRemovedOptionModule ["services" "graphite" "pager"] "") + (lib.mkRemovedOptionModule [ "services" "graphite" "api" ] "") + (lib.mkRemovedOptionModule [ "services" "graphite" "beacon" ] "") + (lib.mkRemovedOptionModule [ "services" "graphite" "pager" ] "") ]; ###### interface @@ -247,7 +260,7 @@ in { }; extraConfig = lib.mkOption { - default = {}; + default = { }; description = '' Extra seyren configuration. See @@ -267,60 +280,72 @@ in { config = lib.mkMerge [ (lib.mkIf cfg.carbon.enableCache { - systemd.services.carbonCache = let name = "carbon-cache"; in { - description = "Graphite Data Storage Backend"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - environment = carbonEnv; - serviceConfig = { - Slice = "system-graphite.slice"; - RuntimeDirectory = name; - ExecStart = "${pkgs.python3Packages.twisted}/bin/twistd ${carbonOpts name}"; - User = "graphite"; - Group = "graphite"; - PermissionsStartOnly = true; - PIDFile="/run/${name}/${name}.pid"; + systemd.services.carbonCache = + let + name = "carbon-cache"; + in + { + description = "Graphite Data Storage Backend"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + environment = carbonEnv; + serviceConfig = { + Slice = "system-graphite.slice"; + RuntimeDirectory = name; + ExecStart = "${pkgs.python3Packages.twisted}/bin/twistd ${carbonOpts name}"; + User = "graphite"; + Group = "graphite"; + PermissionsStartOnly = true; + PIDFile = "/run/${name}/${name}.pid"; + }; + preStart = '' + install -dm0700 -o graphite -g graphite ${cfg.dataDir} + install -dm0700 -o graphite -g graphite ${cfg.dataDir}/whisper + ''; }; - preStart = '' - install -dm0700 -o graphite -g graphite ${cfg.dataDir} - install -dm0700 -o graphite -g graphite ${cfg.dataDir}/whisper - ''; - }; }) (lib.mkIf cfg.carbon.enableAggregator { - systemd.services.carbonAggregator = let name = "carbon-aggregator"; in { - enable = cfg.carbon.enableAggregator; - description = "Carbon Data Aggregator"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - environment = carbonEnv; - serviceConfig = { - Slice = "system-graphite.slice"; - RuntimeDirectory = name; - ExecStart = "${pkgs.python3Packages.twisted}/bin/twistd ${carbonOpts name}"; - User = "graphite"; - Group = "graphite"; - PIDFile="/run/${name}/${name}.pid"; + systemd.services.carbonAggregator = + let + name = "carbon-aggregator"; + in + { + enable = cfg.carbon.enableAggregator; + description = "Carbon Data Aggregator"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + environment = carbonEnv; + serviceConfig = { + Slice = "system-graphite.slice"; + RuntimeDirectory = name; + ExecStart = "${pkgs.python3Packages.twisted}/bin/twistd ${carbonOpts name}"; + User = "graphite"; + Group = "graphite"; + PIDFile = "/run/${name}/${name}.pid"; + }; }; - }; }) (lib.mkIf cfg.carbon.enableRelay { - systemd.services.carbonRelay = let name = "carbon-relay"; in { - description = "Carbon Data Relay"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - environment = carbonEnv; - serviceConfig = { - Slice = "system-graphite.slice"; - RuntimeDirectory = name; - ExecStart = "${pkgs.python3Packages.twisted}/bin/twistd ${carbonOpts name}"; - User = "graphite"; - Group = "graphite"; - PIDFile="/run/${name}/${name}.pid"; + systemd.services.carbonRelay = + let + name = "carbon-relay"; + in + { + description = "Carbon Data Relay"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + environment = carbonEnv; + serviceConfig = { + Slice = "system-graphite.slice"; + RuntimeDirectory = name; + ExecStart = "${pkgs.python3Packages.twisted}/bin/twistd ${carbonOpts name}"; + User = "graphite"; + Group = "graphite"; + PIDFile = "/run/${name}/${name}.pid"; + }; }; - }; }) (lib.mkIf (cfg.carbon.enableCache || cfg.carbon.enableAggregator || cfg.carbon.enableRelay) { @@ -336,19 +361,21 @@ in { after = [ "network.target" ]; path = [ pkgs.perl ]; environment = { - PYTHONPATH = let + PYTHONPATH = + let penv = pkgs.python3.buildEnv.override { extraLibs = [ pkgs.python3Packages.graphite-web ]; }; penvPack = "${penv}/${pkgs.python3.sitePackages}"; - in lib.concatStringsSep ":" [ - "${graphiteLocalSettingsDir}" - "${penvPack}" - # explicitly adding pycairo in path because it cannot be imported via buildEnv - "${pkgs.python3Packages.pycairo}/${pkgs.python3.sitePackages}" - ]; + in + lib.concatStringsSep ":" [ + "${graphiteLocalSettingsDir}" + "${penvPack}" + # explicitly adding pycairo in path because it cannot be imported via buildEnv + "${pkgs.python3Packages.pycairo}/${pkgs.python3.sitePackages}" + ]; DJANGO_SETTINGS_MODULE = "graphite.settings"; GRAPHITE_SETTINGS_MODULE = "graphite_local_settings"; GRAPHITE_CONF_DIR = configDir; @@ -394,7 +421,10 @@ in { systemd.services.seyren = { description = "Graphite Alerting Dashboard"; wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "mongodb.service" ]; + after = [ + "network.target" + "mongodb.service" + ]; environment = seyrenConfig; serviceConfig = { ExecStart = "${pkgs.seyren}/bin/seyren -httpPort ${toString cfg.seyren.port}"; @@ -414,22 +444,28 @@ in { services.mongodb.enable = lib.mkDefault true; }) - (lib.mkIf ( - cfg.carbon.enableCache || cfg.carbon.enableAggregator || cfg.carbon.enableRelay || - cfg.web.enable || cfg.seyren.enable - ) { - systemd.slices.system-graphite = { - description = "Graphite Graphing System Slice"; - documentation = [ "https://graphite.readthedocs.io/en/latest/overview.html" ]; - }; + (lib.mkIf + ( + cfg.carbon.enableCache + || cfg.carbon.enableAggregator + || cfg.carbon.enableRelay + || cfg.web.enable + || cfg.seyren.enable + ) + { + systemd.slices.system-graphite = { + description = "Graphite Graphing System Slice"; + documentation = [ "https://graphite.readthedocs.io/en/latest/overview.html" ]; + }; - users.users.graphite = { - uid = config.ids.uids.graphite; - group = "graphite"; - description = "Graphite daemon user"; - home = dataDir; - }; - users.groups.graphite.gid = config.ids.gids.graphite; - }) + users.users.graphite = { + uid = config.ids.uids.graphite; + group = "graphite"; + description = "Graphite daemon user"; + home = dataDir; + }; + users.groups.graphite.gid = config.ids.gids.graphite; + } + ) ]; } diff --git a/nixos/modules/services/monitoring/hdaps.nix b/nixos/modules/services/monitoring/hdaps.nix index ee9b85a50ae481..54520737ead00c 100644 --- a/nixos/modules/services/monitoring/hdaps.nix +++ b/nixos/modules/services/monitoring/hdaps.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hdapsd; hdapsd = [ pkgs.hdapsd ]; @@ -6,9 +11,9 @@ in { options = { services.hdapsd.enable = lib.mkEnableOption '' - Hard Drive Active Protection System Daemon, - devices are detected and managed automatically by udev and systemd - ''; + Hard Drive Active Protection System Daemon, + devices are detected and managed automatically by udev and systemd + ''; }; config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/monitoring/heapster.nix b/nixos/modules/services/monitoring/heapster.nix index ea03ec46c55c7b..df28f62066a814 100644 --- a/nixos/modules/services/monitoring/heapster.nix +++ b/nixos/modules/services/monitoring/heapster.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.heapster; -in { +in +{ options.services.heapster = { enable = lib.mkEnableOption "Heapster monitoring"; @@ -28,8 +34,11 @@ in { config = lib.mkIf cfg.enable { systemd.services.heapster = { - wantedBy = ["multi-user.target"]; - after = ["cadvisor.service" "kube-apiserver.service"]; + wantedBy = [ "multi-user.target" ]; + after = [ + "cadvisor.service" + "kube-apiserver.service" + ]; serviceConfig = { ExecStart = "${cfg.package}/bin/heapster --source=${cfg.source} --sink=${cfg.sink} ${cfg.extraOpts}"; @@ -42,6 +51,6 @@ in { group = "heapster"; description = "Heapster user"; }; - users.groups.heapster = {}; + users.groups.heapster = { }; }; } diff --git a/nixos/modules/services/monitoring/incron.nix b/nixos/modules/services/monitoring/incron.nix index f7370e4eac23b8..a3739beb8fbed8 100644 --- a/nixos/modules/services/monitoring/incron.nix +++ b/nixos/modules/services/monitoring/incron.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.incron; @@ -51,7 +56,7 @@ in extraPackages = lib.mkOption { type = lib.types.listOf lib.types.package; - default = []; + default = [ ]; example = lib.literalExpression "[ pkgs.rsync ]"; description = "Extra packages available to the system incrontab."; }; @@ -62,13 +67,14 @@ in config = lib.mkIf cfg.enable { - warnings = lib.optional (cfg.allow != null && cfg.deny != null) - "If `services.incron.allow` is set then `services.incron.deny` will be ignored."; + warnings = lib.optional ( + cfg.allow != null && cfg.deny != null + ) "If `services.incron.allow` is set then `services.incron.deny` will be ignored."; environment.systemPackages = [ pkgs.incron ]; - security.wrappers.incrontab = - { setuid = true; + security.wrappers.incrontab = { + setuid = true; owner = "root"; group = "root"; source = "${pkgs.incron}/bin/incrontab"; diff --git a/nixos/modules/services/monitoring/kapacitor.nix b/nixos/modules/services/monitoring/kapacitor.nix index f42dfff623a097..db4ed1beb12b5a 100644 --- a/nixos/modules/services/monitoring/kapacitor.nix +++ b/nixos/modules/services/monitoring/kapacitor.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.kapacitor; diff --git a/nixos/modules/services/monitoring/karma.nix b/nixos/modules/services/monitoring/karma.nix index 2300067719fff3..50b8d384a4a368 100644 --- a/nixos/modules/services/monitoring/karma.nix +++ b/nixos/modules/services/monitoring/karma.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.karma; yaml = pkgs.formats.yaml { }; @@ -21,13 +26,13 @@ in environment = lib.mkOption { type = with lib.types; attrsOf str; - default = {}; + default = { }; description = '' Additional environment variables to provide to karma. ''; example = { ALERTMANAGER_URI = "https://alertmanager.example.com"; - ALERTMANAGER_NAME= "single"; + ALERTMANAGER_NAME = "single"; }; }; @@ -41,7 +46,7 @@ in extraOptions = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; description = '' Extra command line options. ''; diff --git a/nixos/modules/services/monitoring/kthxbye.nix b/nixos/modules/services/monitoring/kthxbye.nix index a4ea97f0fa7555..e2232597736a3c 100644 --- a/nixos/modules/services/monitoring/kthxbye.nix +++ b/nixos/modules/services/monitoring/kthxbye.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.kthxbye; in @@ -19,7 +24,7 @@ in extraOptions = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; description = '' Extra command line options. diff --git a/nixos/modules/services/monitoring/loki.nix b/nixos/modules/services/monitoring/loki.nix index 892605fa701630..b3daf470ad9c50 100644 --- a/nixos/modules/services/monitoring/loki.nix +++ b/nixos/modules/services/monitoring/loki.nix @@ -1,16 +1,29 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) escapeShellArgs mkEnableOption mkIf mkOption types; + inherit (lib) + escapeShellArgs + mkEnableOption + mkIf + mkOption + types + ; cfg = config.services.loki; - prettyJSON = conf: + prettyJSON = + conf: pkgs.runCommand "loki-config.json" { } '' echo '${builtins.toJSON conf}' | ${pkgs.jq}/bin/jq 'del(._module)' > $out ''; -in { +in +{ options.services.loki = { enable = mkEnableOption "loki"; @@ -41,8 +54,8 @@ in { }; configuration = mkOption { - type = (pkgs.formats.json {}).type; - default = {}; + type = (pkgs.formats.json { }).type; + default = { }; description = '' Specify the configuration for Loki in Nix. ''; @@ -58,7 +71,7 @@ in { extraFlags = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "--server.http-listen-port=3101" ]; description = '' Specify a list of additional command line flags, @@ -68,17 +81,19 @@ in { }; config = mkIf cfg.enable { - assertions = [{ - assertion = ( - (cfg.configuration == {} -> cfg.configFile != null) && - (cfg.configFile != null -> cfg.configuration == {}) - ); - message = '' - Please specify either - 'services.loki.configuration' or - 'services.loki.configFile'. - ''; - }]; + assertions = [ + { + assertion = ( + (cfg.configuration == { } -> cfg.configFile != null) + && (cfg.configFile != null -> cfg.configuration == { }) + ); + message = '' + Please specify either + 'services.loki.configuration' or + 'services.loki.configFile'. + ''; + } + ]; environment.systemPackages = [ cfg.package ]; # logcli @@ -97,34 +112,40 @@ in { after = [ "network-online.target" ]; wantedBy = [ "multi-user.target" ]; - serviceConfig = let - conf = if cfg.configFile == null - then - # Config validation may fail when using extraFlags = [ "-config.expand-env=true" ]. - # To work around this, we simply skip it when extraFlags is not empty. - if cfg.extraFlags == [] - then validateConfig (prettyJSON cfg.configuration) - else prettyJSON cfg.configuration - else cfg.configFile; - validateConfig = file: - pkgs.runCommand "validate-loki-conf" { - nativeBuildInputs = [ cfg.package ]; - } '' - loki -verify-config -config.file "${file}" - ln -s "${file}" "$out" - ''; - in - { - ExecStart = "${cfg.package}/bin/loki --config.file=${conf} ${escapeShellArgs cfg.extraFlags}"; - User = cfg.user; - Restart = "always"; - PrivateTmp = true; - ProtectHome = true; - ProtectSystem = "full"; - DevicePolicy = "closed"; - NoNewPrivileges = true; - WorkingDirectory = cfg.dataDir; - }; + serviceConfig = + let + conf = + if cfg.configFile == null then + # Config validation may fail when using extraFlags = [ "-config.expand-env=true" ]. + # To work around this, we simply skip it when extraFlags is not empty. + if cfg.extraFlags == [ ] then + validateConfig (prettyJSON cfg.configuration) + else + prettyJSON cfg.configuration + else + cfg.configFile; + validateConfig = + file: + pkgs.runCommand "validate-loki-conf" + { + nativeBuildInputs = [ cfg.package ]; + } + '' + loki -verify-config -config.file "${file}" + ln -s "${file}" "$out" + ''; + in + { + ExecStart = "${cfg.package}/bin/loki --config.file=${conf} ${escapeShellArgs cfg.extraFlags}"; + User = cfg.user; + Restart = "always"; + PrivateTmp = true; + ProtectHome = true; + ProtectSystem = "full"; + DevicePolicy = "closed"; + NoNewPrivileges = true; + WorkingDirectory = cfg.dataDir; + }; }; }; } diff --git a/nixos/modules/services/monitoring/longview.nix b/nixos/modules/services/monitoring/longview.nix index ecb4836169db67..6123b2ccbaed7f 100644 --- a/nixos/modules/services/monitoring/longview.nix +++ b/nixos/modules/services/monitoring/longview.nix @@ -1,11 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.longview; runDir = "/run/longview"; configsDir = "${runDir}/longview.d"; -in { +in +{ options = { services.longview = { @@ -101,57 +107,78 @@ in { }; config = lib.mkIf cfg.enable { - systemd.services.longview = - { description = "Longview Metrics Collection"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - serviceConfig.Type = "forking"; - serviceConfig.ExecStop = "-${pkgs.coreutils}/bin/kill -TERM $MAINPID"; - serviceConfig.ExecReload = "-${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - serviceConfig.PIDFile = "${runDir}/longview.pid"; - serviceConfig.ExecStart = "${pkgs.longview}/bin/longview"; - preStart = '' + systemd.services.longview = { + description = "Longview Metrics Collection"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig.Type = "forking"; + serviceConfig.ExecStop = "-${pkgs.coreutils}/bin/kill -TERM $MAINPID"; + serviceConfig.ExecReload = "-${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + serviceConfig.PIDFile = "${runDir}/longview.pid"; + serviceConfig.ExecStart = "${pkgs.longview}/bin/longview"; + preStart = + '' umask 077 mkdir -p ${configsDir} - '' + (lib.optionalString (cfg.apiKeyFile != null) '' + '' + + (lib.optionalString (cfg.apiKeyFile != null) '' cp --no-preserve=all "${cfg.apiKeyFile}" ${runDir}/longview.key - '') + (lib.optionalString (cfg.apacheStatusUrl != "") '' + '') + + (lib.optionalString (cfg.apacheStatusUrl != "") '' cat > ${configsDir}/Apache.conf < ${configsDir}/MySQL.conf < ${configsDir}/Nginx.conf < ''; - default = {}; + default = { }; example = { verbose = false; silent = false; @@ -44,19 +50,28 @@ in { options.host_status = { on_start = lib.mkOption { - type = lib.types.enum [ "working" "standby" "maintenance" "poweroff" ]; + type = lib.types.enum [ + "working" + "standby" + "maintenance" + "poweroff" + ]; description = "Host status after agent startup."; default = "working"; }; on_stop = lib.mkOption { - type = lib.types.enum [ "working" "standby" "maintenance" "poweroff" ]; + type = lib.types.enum [ + "working" + "standby" + "maintenance" + "poweroff" + ]; description = "Host status after agent shutdown."; default = "poweroff"; }; }; - options.diagnostic = - lib.mkEnableOption "collecting memory usage for the agent itself"; + options.diagnostic = lib.mkEnableOption "collecting memory usage for the agent itself"; }; }; }; @@ -82,7 +97,10 @@ in { systemd.services.mackerel-agent = { description = "mackerel.io agent"; wants = [ "network-online.target" ]; - after = [ "network-online.target" "nss-lookup.target" ]; + after = [ + "network-online.target" + "nss-lookup.target" + ]; wantedBy = [ "multi-user.target" ]; environment = { MACKEREL_PLUGIN_WORKDIR = lib.mkDefault "%C/mackerel-agent"; diff --git a/nixos/modules/services/monitoring/metricbeat.nix b/nixos/modules/services/monitoring/metricbeat.nix index fe6f7f1cfcfaef..c8e2f4c7773ce0 100644 --- a/nixos/modules/services/monitoring/metricbeat.nix +++ b/nixos/modules/services/monitoring/metricbeat.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) @@ -12,7 +17,7 @@ let ; cfg = config.services.metricbeat; - settingsFormat = pkgs.formats.yaml {}; + settingsFormat = pkgs.formats.yaml { }; in { @@ -39,30 +44,47 @@ in See . ''; - default = {}; - type = types.attrsOf (types.submodule ({ name, ... }: { - freeformType = settingsFormat.type; - options = { - module = mkOption { - type = types.str; - default = name; - description = '' - The name of the module. - - Look for the value after `module:` on the individual - module pages linked from . - ''; - }; - }; - })); + default = { }; + type = types.attrsOf ( + types.submodule ( + { name, ... }: + { + freeformType = settingsFormat.type; + options = { + module = mkOption { + type = types.str; + default = name; + description = '' + The name of the module. + + Look for the value after `module:` on the individual + module pages linked from . + ''; + }; + }; + } + ) + ); example = { system = { - metricsets = ["cpu" "load" "memory" "network" "process" "process_summary" "uptime" "socket_summary"]; + metricsets = [ + "cpu" + "load" + "memory" + "network" + "process" + "process_summary" + "uptime" + "socket_summary" + ]; enabled = true; period = "10s"; - processes = [".*"]; - cpu.metrics = ["percentages" "normalized_percentages"]; - core.metrics = ["percentages"]; + processes = [ ".*" ]; + cpu.metrics = [ + "percentages" + "normalized_percentages" + ]; + core.metrics = [ "percentages" ]; }; }; }; @@ -83,7 +105,7 @@ in tags = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = '' Tags to place on the shipped metrics. See . @@ -92,7 +114,7 @@ in metricbeat.modules = mkOption { type = types.listOf settingsFormat.type; - default = []; + default = [ ]; internal = true; description = '' The metric collecting modules. Use [](#opt-services.metricbeat.modules) instead. @@ -102,7 +124,7 @@ in }; }; }; - default = {}; + default = { }; description = '' Configuration for metricbeat. See for supported values. ''; @@ -116,7 +138,7 @@ in assertions = [ { # empty modules would cause a failure at runtime - assertion = cfg.settings.metricbeat.modules != []; + assertion = cfg.settings.metricbeat.modules != [ ]; message = "services.metricbeat: You must configure one or more modules."; } ]; diff --git a/nixos/modules/services/monitoring/mimir.nix b/nixos/modules/services/monitoring/mimir.nix index 76fff95ae597b5..ffb87610f41825 100644 --- a/nixos/modules/services/monitoring/mimir.nix +++ b/nixos/modules/services/monitoring/mimir.nix @@ -1,18 +1,31 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) escapeShellArgs mkEnableOption mkPackageOption mkIf mkOption types; + inherit (lib) + escapeShellArgs + mkEnableOption + mkPackageOption + mkIf + mkOption + types + ; cfg = config.services.mimir; - settingsFormat = pkgs.formats.yaml {}; -in { + settingsFormat = pkgs.formats.yaml { }; +in +{ options.services.mimir = { enable = mkEnableOption "mimir"; configuration = mkOption { - type = (pkgs.formats.json {}).type; - default = {}; + type = (pkgs.formats.json { }).type; + default = { }; description = '' Specify the configuration for Mimir in Nix. ''; @@ -30,7 +43,7 @@ in { extraFlags = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "--config.expand-env=true" ]; description = '' Specify a list of additional command line flags, @@ -43,37 +56,42 @@ in { # for mimirtool environment.systemPackages = [ cfg.package ]; - assertions = [{ - assertion = ( - (cfg.configuration == {} -> cfg.configFile != null) && - (cfg.configFile != null -> cfg.configuration == {}) - ); - message = '' - Please specify either - 'services.mimir.configuration' or - 'services.mimir.configFile'. - ''; - }]; + assertions = [ + { + assertion = ( + (cfg.configuration == { } -> cfg.configFile != null) + && (cfg.configFile != null -> cfg.configuration == { }) + ); + message = '' + Please specify either + 'services.mimir.configuration' or + 'services.mimir.configFile'. + ''; + } + ]; systemd.services.mimir = { description = "mimir Service Daemon"; wantedBy = [ "multi-user.target" ]; - serviceConfig = let - conf = if cfg.configFile == null - then settingsFormat.generate "config.yaml" cfg.configuration - else cfg.configFile; - in - { - ExecStart = "${cfg.package}/bin/mimir --config.file=${conf} ${escapeShellArgs cfg.extraFlags}"; - DynamicUser = true; - Restart = "always"; - ProtectSystem = "full"; - DevicePolicy = "closed"; - NoNewPrivileges = true; - WorkingDirectory = "/var/lib/mimir"; - StateDirectory = "mimir"; - }; + serviceConfig = + let + conf = + if cfg.configFile == null then + settingsFormat.generate "config.yaml" cfg.configuration + else + cfg.configFile; + in + { + ExecStart = "${cfg.package}/bin/mimir --config.file=${conf} ${escapeShellArgs cfg.extraFlags}"; + DynamicUser = true; + Restart = "always"; + ProtectSystem = "full"; + DevicePolicy = "closed"; + NoNewPrivileges = true; + WorkingDirectory = "/var/lib/mimir"; + StateDirectory = "mimir"; + }; }; }; } diff --git a/nixos/modules/services/monitoring/monit.nix b/nixos/modules/services/monitoring/monit.nix index 3fa4e178b113cc..d1de417dd90c91 100644 --- a/nixos/modules/services/monitoring/monit.nix +++ b/nixos/modules/services/monitoring/monit.nix @@ -1,4 +1,9 @@ -{config, pkgs, lib, ...}: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.monit; in diff --git a/nixos/modules/services/monitoring/munin.nix b/nixos/modules/services/monitoring/munin.nix index 91a000ade87bc3..8551ec6c9c7a92 100644 --- a/nixos/modules/services/monitoring/munin.nix +++ b/nixos/modules/services/monitoring/munin.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: # TODO: support munin-async # TODO: LWP/Pg perl libs aren't recognized # TODO: support fastcgi @@ -11,60 +16,57 @@ let nodeCfg = config.services.munin-node; cronCfg = config.services.munin-cron; - muninConf = pkgs.writeText "munin.conf" - '' - dbdir /var/lib/munin - htmldir /var/www/munin - logdir /var/log/munin - rundir /run/munin + muninConf = pkgs.writeText "munin.conf" '' + dbdir /var/lib/munin + htmldir /var/www/munin + logdir /var/log/munin + rundir /run/munin - ${lib.optionalString (cronCfg.extraCSS != "") "staticdir ${customStaticDir}"} + ${lib.optionalString (cronCfg.extraCSS != "") "staticdir ${customStaticDir}"} - ${cronCfg.extraGlobalConfig} + ${cronCfg.extraGlobalConfig} - ${cronCfg.hosts} - ''; + ${cronCfg.hosts} + ''; - nodeConf = pkgs.writeText "munin-node.conf" - '' - log_level 3 - log_file Sys::Syslog - port 4949 - host * - background 0 - user root - group root - host_name ${config.networking.hostName} - setsid 0 - - # wrapped plugins by makeWrapper being with dots - ignore_file ^\. - - allow ^::1$ - allow ^127\.0\.0\.1$ - - ${nodeCfg.extraConfig} - ''; + nodeConf = pkgs.writeText "munin-node.conf" '' + log_level 3 + log_file Sys::Syslog + port 4949 + host * + background 0 + user root + group root + host_name ${config.networking.hostName} + setsid 0 + + # wrapped plugins by makeWrapper being with dots + ignore_file ^\. - pluginConf = pkgs.writeText "munin-plugin-conf" - '' - [hddtemp_smartctl] - user root - group root + allow ^::1$ + allow ^127\.0\.0\.1$ - [meminfo] - user root - group root + ${nodeCfg.extraConfig} + ''; - [ipmi*] - user root - group root + pluginConf = pkgs.writeText "munin-plugin-conf" '' + [hddtemp_smartctl] + user root + group root - [munin*] - env.UPDATE_STATSFILE /var/lib/munin/munin-update.stats + [meminfo] + user root + group root - ${nodeCfg.extraPluginConfig} - ''; + [ipmi*] + user root + group root + + [munin*] + env.UPDATE_STATSFILE /var/lib/munin/munin-update.stats + + ${nodeCfg.extraPluginConfig} + ''; pluginConfDir = pkgs.stdenv.mkDerivation { name = "munin-plugin-conf.d"; @@ -77,16 +79,14 @@ let # Copy one Munin plugin into the Nix store with a specific name. # This is suitable for use with plugins going directly into /etc/munin/plugins, # i.e. munin.extraPlugins. - internOnePlugin = { name, path }: - "cp -a '${path}' '${name}'"; + internOnePlugin = { name, path }: "cp -a '${path}' '${name}'"; # Copy an entire tree of Munin plugins into a single directory in the Nix # store, with no renaming. The output is suitable for use with # munin-node-configure --suggest, i.e. munin.extraAutoPlugins. # Note that this flattens the input; this is intentional, as # munin-node-configure won't recurse into subdirectories. - internManyPlugins = path: - "find '${path}' -type f -perm /a+x -exec cp -a -t . '{}' '+'"; + internManyPlugins = path: "find '${path}' -type f -perm /a+x -exec cp -a -t . '{}' '+'"; # Use the appropriate intern-fn to copy the plugins into the store and patch # them afterwards in an attempt to get them to run on NixOS. @@ -98,8 +98,9 @@ let # For now we make the simplifying assumption that no file will contain lines # which mix store paths and FHS paths, and thus run our substitution only on # lines which do not contain store paths. - internAndFixPlugins = name: intern-fn: paths: - pkgs.runCommand name {} '' + internAndFixPlugins = + name: intern-fn: paths: + pkgs.runCommand name { } '' mkdir -p "$out" cd "$out" ${lib.concatStringsSep "\n" (map intern-fn paths)} @@ -112,14 +113,18 @@ let # TODO: write a derivation for munin-contrib, so that for contrib plugins # you can just refer to them by name rather than needing to include a copy # of munin-contrib in your nixos configuration. - extraPluginDir = internAndFixPlugins "munin-extra-plugins.d" - internOnePlugin - (lib.attrsets.mapAttrsToList (k: v: { name = k; path = v; }) nodeCfg.extraPlugins); - - extraAutoPluginDir = internAndFixPlugins "munin-extra-auto-plugins.d" - internManyPlugins nodeCfg.extraAutoPlugins; - - customStaticDir = pkgs.runCommand "munin-custom-static-data" {} '' + extraPluginDir = internAndFixPlugins "munin-extra-plugins.d" internOnePlugin ( + lib.attrsets.mapAttrsToList (k: v: { + name = k; + path = v; + }) nodeCfg.extraPlugins + ); + + extraAutoPluginDir = + internAndFixPlugins "munin-extra-auto-plugins.d" internManyPlugins + nodeCfg.extraAutoPlugins; + + customStaticDir = pkgs.runCommand "munin-custom-static-data" { } '' cp -a "${pkgs.munin}/etc/opt/munin/static" "$out" cd "$out" chmod -R u+w . @@ -168,7 +173,7 @@ in }; extraPlugins = lib.mkOption { - default = {}; + default = { }; type = with lib.types; attrsOf path; description = '' Additional Munin plugins to activate. Keys are the name of the plugin @@ -198,7 +203,7 @@ in }; extraAutoPlugins = lib.mkOption { - default = []; + default = [ ]; type = with lib.types; listOf path; description = '' Additional Munin plugins to autoconfigure, using @@ -243,7 +248,10 @@ in `/var/log/munin/munin-update.log` for timing information, and the NixOS build of Munin does not write this file. ''; - example = [ "diskstats" "zfs_usage_*" ]; + example = [ + "diskstats" + "zfs_usage_*" + ]; }; }; @@ -314,100 +322,111 @@ in }; - config = lib.mkMerge [ (lib.mkIf (nodeCfg.enable || cronCfg.enable) { - - environment.systemPackages = [ pkgs.munin ]; - - users.users.munin = { - description = "Munin monitoring user"; - group = "munin"; - uid = config.ids.uids.munin; - home = "/var/lib/munin"; - }; - - users.groups.munin = { - gid = config.ids.gids.munin; - }; - - }) (lib.mkIf nodeCfg.enable { - - systemd.services.munin-node = { - description = "Munin Node"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - path = with pkgs; [ munin smartmontools "/run/current-system/sw" "/run/wrappers" ]; - environment.MUNIN_LIBDIR = "${pkgs.munin}/lib"; - environment.MUNIN_PLUGSTATE = "/run/munin"; - environment.MUNIN_LOGDIR = "/var/log/munin"; - preStart = '' - echo "Updating munin plugins..." + config = lib.mkMerge [ + (lib.mkIf (nodeCfg.enable || cronCfg.enable) { - mkdir -p /etc/munin/plugins - rm -rf /etc/munin/plugins/* + environment.systemPackages = [ pkgs.munin ]; - # Autoconfigure builtin plugins - ${pkgs.munin}/bin/munin-node-configure --suggest --shell --families contrib,auto,manual --config ${nodeConf} --libdir=${pkgs.munin}/lib/plugins --servicedir=/etc/munin/plugins --sconfdir=${pluginConfDir} 2>/dev/null | ${pkgs.bash}/bin/bash + users.users.munin = { + description = "Munin monitoring user"; + group = "munin"; + uid = config.ids.uids.munin; + home = "/var/lib/munin"; + }; - # Autoconfigure extra plugins - ${pkgs.munin}/bin/munin-node-configure --suggest --shell --families contrib,auto,manual --config ${nodeConf} --libdir=${extraAutoPluginDir} --servicedir=/etc/munin/plugins --sconfdir=${pluginConfDir} 2>/dev/null | ${pkgs.bash}/bin/bash + users.groups.munin = { + gid = config.ids.gids.munin; + }; - ${lib.optionalString (nodeCfg.extraPlugins != {}) '' + }) + (lib.mkIf nodeCfg.enable { + + systemd.services.munin-node = { + description = "Munin Node"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + path = with pkgs; [ + munin + smartmontools + "/run/current-system/sw" + "/run/wrappers" + ]; + environment.MUNIN_LIBDIR = "${pkgs.munin}/lib"; + environment.MUNIN_PLUGSTATE = "/run/munin"; + environment.MUNIN_LOGDIR = "/var/log/munin"; + preStart = '' + echo "Updating munin plugins..." + + mkdir -p /etc/munin/plugins + rm -rf /etc/munin/plugins/* + + # Autoconfigure builtin plugins + ${pkgs.munin}/bin/munin-node-configure --suggest --shell --families contrib,auto,manual --config ${nodeConf} --libdir=${pkgs.munin}/lib/plugins --servicedir=/etc/munin/plugins --sconfdir=${pluginConfDir} 2>/dev/null | ${pkgs.bash}/bin/bash + + # Autoconfigure extra plugins + ${pkgs.munin}/bin/munin-node-configure --suggest --shell --families contrib,auto,manual --config ${nodeConf} --libdir=${extraAutoPluginDir} --servicedir=/etc/munin/plugins --sconfdir=${pluginConfDir} 2>/dev/null | ${pkgs.bash}/bin/bash + + ${lib.optionalString (nodeCfg.extraPlugins != { }) '' # Link in manually enabled plugins ln -f -s -t /etc/munin/plugins ${extraPluginDir}/* ''} - ${lib.optionalString (nodeCfg.disabledPlugins != []) '' + ${lib.optionalString (nodeCfg.disabledPlugins != [ ]) '' # Disable plugins cd /etc/munin/plugins rm -f ${toString nodeCfg.disabledPlugins} ''} - ''; - serviceConfig = { - ExecStart = "${pkgs.munin}/sbin/munin-node --config ${nodeConf} --servicedir /etc/munin/plugins/ --sconfdir=${pluginConfDir}"; + ''; + serviceConfig = { + ExecStart = "${pkgs.munin}/sbin/munin-node --config ${nodeConf} --servicedir /etc/munin/plugins/ --sconfdir=${pluginConfDir}"; + }; }; - }; - # munin_stats plugin breaks as of 2.0.33 when this doesn't exist - systemd.tmpfiles.settings."10-munin"."/run/munin".d = { - mode = "0755"; - user = "munin"; - group = "munin"; - }; + # munin_stats plugin breaks as of 2.0.33 when this doesn't exist + systemd.tmpfiles.settings."10-munin"."/run/munin".d = { + mode = "0755"; + user = "munin"; + group = "munin"; + }; - }) (lib.mkIf cronCfg.enable { + }) + (lib.mkIf cronCfg.enable { - # Munin is hardcoded to use DejaVu Mono and the graphs come out wrong if - # it's not available. - fonts.packages = [ pkgs.dejavu_fonts ]; + # Munin is hardcoded to use DejaVu Mono and the graphs come out wrong if + # it's not available. + fonts.packages = [ pkgs.dejavu_fonts ]; - systemd.timers.munin-cron = { - description = "batch Munin master programs"; - wantedBy = [ "timers.target" ]; - timerConfig.OnCalendar = "*:0/5"; - }; + systemd.timers.munin-cron = { + description = "batch Munin master programs"; + wantedBy = [ "timers.target" ]; + timerConfig.OnCalendar = "*:0/5"; + }; - systemd.services.munin-cron = { - description = "batch Munin master programs"; - unitConfig.Documentation = "man:munin-cron(8)"; + systemd.services.munin-cron = { + description = "batch Munin master programs"; + unitConfig.Documentation = "man:munin-cron(8)"; - serviceConfig = { - Type = "oneshot"; - User = "munin"; - ExecStart = "${pkgs.munin}/bin/munin-cron --config ${muninConf}"; + serviceConfig = { + Type = "oneshot"; + User = "munin"; + ExecStart = "${pkgs.munin}/bin/munin-cron --config ${muninConf}"; + }; }; - }; - systemd.tmpfiles.settings."20-munin" = let - defaultConfig = { - mode = "0755"; - user = "munin"; - group = "munin"; - }; - in { - "/run/munin".d = defaultConfig; - "/var/log/munin".d = defaultConfig; - "/var/www/munin".d = defaultConfig; - "/var/lib/munin".d = defaultConfig; - }; - })]; + systemd.tmpfiles.settings."20-munin" = + let + defaultConfig = { + mode = "0755"; + user = "munin"; + group = "munin"; + }; + in + { + "/run/munin".d = defaultConfig; + "/var/log/munin".d = defaultConfig; + "/var/www/munin".d = defaultConfig; + "/var/lib/munin".d = defaultConfig; + }; + }) + ]; } diff --git a/nixos/modules/services/monitoring/ocsinventory-agent.nix b/nixos/modules/services/monitoring/ocsinventory-agent.nix index 591738ed4ef789..83fec3b2b57d6d 100644 --- a/nixos/modules/services/monitoring/ocsinventory-agent.nix +++ b/nixos/modules/services/monitoring/ocsinventory-agent.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.ocsinventory-agent; @@ -98,7 +103,8 @@ in let configFile = settingsFormat.generate "ocsinventory-agent.cfg" cfg.settings; - in lib.mkIf cfg.enable { + in + lib.mkIf cfg.enable { # Path of the configuration file is hard-coded and cannot be changed # https://github.com/OCSInventory-NG/UnixAgent/blob/v2.10.0/lib/Ocsinventory/Agent/Config.pm#L78 # diff --git a/nixos/modules/services/monitoring/opentelemetry-collector.nix b/nixos/modules/services/monitoring/opentelemetry-collector.nix index d9b8c27ccdfe3b..55502a77366bf8 100644 --- a/nixos/modules/services/monitoring/opentelemetry-collector.nix +++ b/nixos/modules/services/monitoring/opentelemetry-collector.nix @@ -1,7 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkPackageOption mkIf mkOption types getExe; + inherit (lib) + mkEnableOption + mkPackageOption + mkIf + mkOption + types + getExe + ; cfg = config.services.opentelemetry-collector; opentelemetry-collector = cfg.package; @@ -34,16 +46,16 @@ in }; config = mkIf cfg.enable { - assertions = [{ - assertion = ( - (cfg.settings == { }) != (cfg.configFile == null) - ); - message = '' - Please specify a configuration for Opentelemetry Collector with either - 'services.opentelemetry-collector.settings' or - 'services.opentelemetry-collector.configFile'. - ''; - }]; + assertions = [ + { + assertion = ((cfg.settings == { }) != (cfg.configFile == null)); + message = '' + Please specify a configuration for Opentelemetry Collector with either + 'services.opentelemetry-collector.settings' or + 'services.opentelemetry-collector.configFile'. + ''; + } + ]; systemd.services.opentelemetry-collector = { description = "Opentelemetry Collector Service Daemon"; @@ -52,9 +64,10 @@ in serviceConfig = let conf = - if cfg.configFile == null - then settingsFormat.generate "config.yaml" cfg.settings - else cfg.configFile; + if cfg.configFile == null then + settingsFormat.generate "config.yaml" cfg.settings + else + cfg.configFile; in { ExecStart = "${getExe opentelemetry-collector} --config=file:${conf}"; diff --git a/nixos/modules/services/monitoring/osquery.nix b/nixos/modules/services/monitoring/osquery.nix index 8f728ebab1157d..fbe6f45b9d8e38 100644 --- a/nixos/modules/services/monitoring/osquery.nix +++ b/nixos/modules/services/monitoring/osquery.nix @@ -1,8 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.osquery; - dirname = path: with lib.strings; with lib.lists; concatStringsSep "/" - (init (splitString "/" (normalizePath path))); + dirname = + path: + with lib.strings; + with lib.lists; + concatStringsSep "/" (init (splitString "/" (normalizePath path))); # conf is the osquery configuration file used when the --config_plugin=filesystem. # filesystem is the osquery default value for the config_plugin flag. @@ -10,11 +18,13 @@ let # flagfile is the file containing osquery command line flags to be # provided to the application using the special --flagfile option. - flagfile = pkgs.writeText "osquery.flags" - (lib.concatStringsSep "\n" - (lib.mapAttrsToList (name: value: "--${name}=${value}") + flagfile = pkgs.writeText "osquery.flags" ( + lib.concatStringsSep "\n" ( + lib.mapAttrsToList (name: value: "--${name}=${value}") # Use the conf derivation if not otherwise specified. - ({ config_path = conf; } // cfg.flags))); + ({ config_path = conf; } // cfg.flags) + ) + ); osqueryi = pkgs.runCommand "osqueryi" { nativeBuildInputs = [ pkgs.makeWrapper ]; } '' mkdir -p $out/bin @@ -47,7 +57,8 @@ in example = { config_refresh = "10"; }; - type = with lib.types; + type = + with lib.types; submodule { freeformType = attrsOf str; options = { @@ -77,7 +88,10 @@ in config = lib.mkIf cfg.enable { environment.systemPackages = [ osqueryi ]; systemd.services.osqueryd = { - after = [ "network.target" "syslog.service" ]; + after = [ + "network.target" + "syslog.service" + ]; description = "The osquery daemon"; serviceConfig = { ExecStart = "${pkgs.osquery}/bin/osqueryd --flagfile ${flagfile}"; diff --git a/nixos/modules/services/monitoring/parsedmarc.nix b/nixos/modules/services/monitoring/parsedmarc.nix index a14ade59c29eb8..22c37f3e26e225 100644 --- a/nixos/modules/services/monitoring/parsedmarc.nix +++ b/nixos/modules/services/monitoring/parsedmarc.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.parsedmarc; @@ -6,16 +12,31 @@ let isSecret = v: isAttrs v && v ? _secret && isString v._secret; ini = pkgs.formats.ini { mkKeyValue = lib.flip lib.generators.mkKeyValueDefault "=" rec { - mkValueString = v: - if isInt v then toString v - else if isString v then v - else if true == v then "True" - else if false == v then "False" - else if isSecret v then hashString "sha256" v._secret - else throw "unsupported type ${typeOf v}: ${(lib.generators.toPretty {}) v}"; + mkValueString = + v: + if isInt v then + toString v + else if isString v then + v + else if true == v then + "True" + else if false == v then + "False" + else if isSecret v then + hashString "sha256" v._secret + else + throw "unsupported type ${typeOf v}: ${(lib.generators.toPretty { }) v}"; }; }; - inherit (builtins) elem isAttrs isString isInt isList typeOf hashString; + inherit (builtins) + elem + isAttrs + isString + isInt + isList + typeOf + hashString + ; in { options.services.parsedmarc = { @@ -301,15 +322,15 @@ in description = '' The addresses to send outgoing mail to. ''; - apply = x: if x == [] || x == null then null else lib.concatStringsSep "," x; + apply = x: if x == [ ] || x == null then null else lib.concatStringsSep "," x; }; }; elasticsearch = { hosts = lib.mkOption { - default = []; + default = [ ]; type = with lib.types; listOf str; - apply = x: if x == [] then null else lib.concatStringsSep "," x; + apply = x: if x == [ ] then null else lib.concatStringsSep "," x; description = '' A list of Elasticsearch hosts to push parsed reports to. @@ -366,12 +387,23 @@ in config = lib.mkIf cfg.enable { - warnings = let - deprecationWarning = optname: "Starting in 8.0.0, the `${optname}` option has been moved from the `services.parsedmarc.settings.imap`" - + "configuration section to the `services.parsedmarc.settings.mailbox` configuration section."; - hasImapOpt = lib.flip builtins.hasAttr cfg.settings.imap; - movedOptions = [ "reports_folder" "archive_folder" "watch" "delete" "test" "batch_size" ]; - in builtins.map deprecationWarning (builtins.filter hasImapOpt movedOptions); + warnings = + let + deprecationWarning = + optname: + "Starting in 8.0.0, the `${optname}` option has been moved from the `services.parsedmarc.settings.imap`" + + "configuration section to the `services.parsedmarc.settings.mailbox` configuration section."; + hasImapOpt = lib.flip builtins.hasAttr cfg.settings.imap; + movedOptions = [ + "reports_folder" + "archive_folder" + "watch" + "delete" + "test" + "batch_size" + ]; + in + builtins.map deprecationWarning (builtins.filter hasImapOpt movedOptions); services.elasticsearch.enable = lib.mkDefault cfg.provision.elasticsearch; @@ -402,7 +434,8 @@ in }; services.grafana = { - declarativePlugins = with pkgs.grafanaPlugins; + declarativePlugins = + with pkgs.grafanaPlugins; lib.mkIf cfg.provision.grafana.dashboard [ grafana-worldmap-panel grafana-piechart-panel @@ -414,32 +447,34 @@ in let esVersion = lib.getVersion config.services.elasticsearch.package; in - lib.mkIf cfg.provision.grafana.datasource [ - { - name = "dmarc-ag"; - type = "elasticsearch"; - access = "proxy"; - url = "http://localhost:9200"; - jsonData = { - timeField = "date_range"; - inherit esVersion; - }; - } - { - name = "dmarc-fo"; - type = "elasticsearch"; - access = "proxy"; - url = "http://localhost:9200"; - jsonData = { - timeField = "date_range"; - inherit esVersion; - }; - } - ]; - dashboards.settings.providers = lib.mkIf cfg.provision.grafana.dashboard [{ - name = "parsedmarc"; - options.path = "${pkgs.parsedmarc.dashboard}"; - }]; + lib.mkIf cfg.provision.grafana.datasource [ + { + name = "dmarc-ag"; + type = "elasticsearch"; + access = "proxy"; + url = "http://localhost:9200"; + jsonData = { + timeField = "date_range"; + inherit esVersion; + }; + } + { + name = "dmarc-fo"; + type = "elasticsearch"; + access = "proxy"; + url = "http://localhost:9200"; + jsonData = { + timeField = "date_range"; + inherit esVersion; + }; + } + ]; + dashboards.settings.providers = lib.mkIf cfg.provision.grafana.dashboard [ + { + name = "parsedmarc"; + options.path = "${pkgs.parsedmarc.dashboard}"; + } + ]; }; }; @@ -470,7 +505,14 @@ in # lists, empty attrsets and null. This makes it possible to # list interesting options in `settings` without them always # ending up in the resulting config. - filteredConfig = lib.converge (lib.filterAttrsRecursive (_: v: ! elem v [ null [] {} ])) cfg.settings; + filteredConfig = lib.converge (lib.filterAttrsRecursive ( + _: v: + !elem v [ + null + [ ] + { } + ] + )) cfg.settings; # Extract secrets (attributes set to an attrset with a # "_secret" key) from the settings and generate the commands @@ -478,61 +520,86 @@ in secretPaths = lib.catAttrs "_secret" (lib.collect isSecret filteredConfig); parsedmarcConfig = ini.generate "parsedmarc.ini" filteredConfig; mkSecretReplacement = file: '' - replace-secret ${lib.escapeShellArgs [ (hashString "sha256" file) file "/run/parsedmarc/parsedmarc.ini" ]} + replace-secret ${ + lib.escapeShellArgs [ + (hashString "sha256" file) + file + "/run/parsedmarc/parsedmarc.ini" + ] + } ''; secretReplacements = lib.concatMapStrings mkSecretReplacement secretPaths; in - { - wantedBy = [ "multi-user.target" ]; - after = [ "postfix.service" "dovecot2.service" "elasticsearch.service" ]; - path = with pkgs; [ replace-secret openssl shadow ]; - serviceConfig = { - ExecStartPre = let - startPreFullPrivileges = '' - set -o errexit -o pipefail -o nounset -o errtrace - shopt -s inherit_errexit - - umask u=rwx,g=,o= - cp ${parsedmarcConfig} /run/parsedmarc/parsedmarc.ini - chown parsedmarc:parsedmarc /run/parsedmarc/parsedmarc.ini - ${secretReplacements} - '' + lib.optionalString cfg.provision.localMail.enable '' - openssl rand -hex 64 >/run/parsedmarc/dmarc_user_passwd - replace-secret '@imap-password@' '/run/parsedmarc/dmarc_user_passwd' /run/parsedmarc/parsedmarc.ini - echo "Setting new randomized password for user '${cfg.provision.localMail.recipientName}'." - cat <(echo -n "${cfg.provision.localMail.recipientName}:") /run/parsedmarc/dmarc_user_passwd | chpasswd - ''; + { + wantedBy = [ "multi-user.target" ]; + after = [ + "postfix.service" + "dovecot2.service" + "elasticsearch.service" + ]; + path = with pkgs; [ + replace-secret + openssl + shadow + ]; + serviceConfig = { + ExecStartPre = + let + startPreFullPrivileges = + '' + set -o errexit -o pipefail -o nounset -o errtrace + shopt -s inherit_errexit + + umask u=rwx,g=,o= + cp ${parsedmarcConfig} /run/parsedmarc/parsedmarc.ini + chown parsedmarc:parsedmarc /run/parsedmarc/parsedmarc.ini + ${secretReplacements} + '' + + lib.optionalString cfg.provision.localMail.enable '' + openssl rand -hex 64 >/run/parsedmarc/dmarc_user_passwd + replace-secret '@imap-password@' '/run/parsedmarc/dmarc_user_passwd' /run/parsedmarc/parsedmarc.ini + echo "Setting new randomized password for user '${cfg.provision.localMail.recipientName}'." + cat <(echo -n "${cfg.provision.localMail.recipientName}:") /run/parsedmarc/dmarc_user_passwd | chpasswd + ''; in - "+${pkgs.writeShellScript "parsedmarc-start-pre-full-privileges" startPreFullPrivileges}"; - Type = "simple"; - User = "parsedmarc"; - Group = "parsedmarc"; - DynamicUser = true; - RuntimeDirectory = "parsedmarc"; - RuntimeDirectoryMode = "0700"; - CapabilityBoundingSet = ""; - PrivateDevices = true; - PrivateMounts = true; - PrivateUsers = true; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - ProcSubset = "pid"; - SystemCallFilter = [ "@system-service" "~@privileged" "~@resources" ]; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; - RestrictRealtime = true; - RestrictNamespaces = true; - MemoryDenyWriteExecute = true; - LockPersonality = true; - SystemCallArchitectures = "native"; - ExecStart = "${lib.getExe pkgs.parsedmarc} -c /run/parsedmarc/parsedmarc.ini"; - }; + "+${pkgs.writeShellScript "parsedmarc-start-pre-full-privileges" startPreFullPrivileges}"; + Type = "simple"; + User = "parsedmarc"; + Group = "parsedmarc"; + DynamicUser = true; + RuntimeDirectory = "parsedmarc"; + RuntimeDirectoryMode = "0700"; + CapabilityBoundingSet = ""; + PrivateDevices = true; + PrivateMounts = true; + PrivateUsers = true; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + ProcSubset = "pid"; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "~@resources" + ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; + RestrictRealtime = true; + RestrictNamespaces = true; + MemoryDenyWriteExecute = true; + LockPersonality = true; + SystemCallArchitectures = "native"; + ExecStart = "${lib.getExe pkgs.parsedmarc} -c /run/parsedmarc/parsedmarc.ini"; }; + }; users.users.${cfg.provision.localMail.recipientName} = lib.mkIf cfg.provision.localMail.enable { isNormalUser = true; diff --git a/nixos/modules/services/monitoring/prometheus/alertmanager-webhook-logger.nix b/nixos/modules/services/monitoring/prometheus/alertmanager-webhook-logger.nix index 1761e630510786..5dd0b59011cabc 100644 --- a/nixos/modules/services/monitoring/prometheus/alertmanager-webhook-logger.nix +++ b/nixos/modules/services/monitoring/prometheus/alertmanager-webhook-logger.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.prometheus.alertmanagerWebhookLogger; in @@ -10,7 +15,7 @@ in extraFlags = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = "Extra command line options to pass to alertmanager-webhook-logger."; }; }; @@ -55,9 +60,12 @@ in ProtectKernelLogs = true; ProtectControlGroups = true; - Restart = "on-failure"; + Restart = "on-failure"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; diff --git a/nixos/modules/services/monitoring/prometheus/alertmanager.nix b/nixos/modules/services/monitoring/prometheus/alertmanager.nix index 70bd07c5982056..078abf9a1ff955 100644 --- a/nixos/modules/services/monitoring/prometheus/alertmanager.nix +++ b/nixos/modules/services/monitoring/prometheus/alertmanager.nix @@ -1,36 +1,50 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.prometheus.alertmanager; mkConfigFile = pkgs.writeText "alertmanager.yml" (builtins.toJSON cfg.configuration); - checkedConfig = file: + checkedConfig = + file: if cfg.checkConfig then pkgs.runCommand "checked-config" { nativeBuildInputs = [ cfg.package ]; } '' ln -s ${file} $out amtool check-config $out - '' else file; - - alertmanagerYml = let - yml = if cfg.configText != null then - pkgs.writeText "alertmanager.yml" cfg.configText - else mkConfigFile; - in checkedConfig yml; - - cmdlineArgs = cfg.extraFlags ++ [ - "--config.file /tmp/alert-manager-substituted.yaml" - "--web.listen-address ${cfg.listenAddress}:${toString cfg.port}" - "--log.level ${cfg.logLevel}" - "--storage.path /var/lib/alertmanager" - (toString (map (peer: "--cluster.peer ${peer}:9094") cfg.clusterPeers)) - ] ++ (lib.optional (cfg.webExternalUrl != null) - "--web.external-url ${cfg.webExternalUrl}" - ) ++ (lib.optional (cfg.logFormat != null) - "--log.format ${cfg.logFormat}" - ); -in { + '' + else + file; + + alertmanagerYml = + let + yml = + if cfg.configText != null then pkgs.writeText "alertmanager.yml" cfg.configText else mkConfigFile; + in + checkedConfig yml; + + cmdlineArgs = + cfg.extraFlags + ++ [ + "--config.file /tmp/alert-manager-substituted.yaml" + "--web.listen-address ${cfg.listenAddress}:${toString cfg.port}" + "--log.level ${cfg.logLevel}" + "--storage.path /var/lib/alertmanager" + (toString (map (peer: "--cluster.peer ${peer}:9094") cfg.clusterPeers)) + ] + ++ (lib.optional (cfg.webExternalUrl != null) "--web.external-url ${cfg.webExternalUrl}") + ++ (lib.optional (cfg.logFormat != null) "--log.format ${cfg.logFormat}"); +in +{ imports = [ - (lib.mkRemovedOptionModule [ "services" "prometheus" "alertmanager" "user" ] "The alertmanager service is now using systemd's DynamicUser mechanism which obviates a user setting.") - (lib.mkRemovedOptionModule [ "services" "prometheus" "alertmanager" "group" ] "The alertmanager service is now using systemd's DynamicUser mechanism which obviates a group setting.") + (lib.mkRemovedOptionModule [ "services" "prometheus" "alertmanager" "user" ] + "The alertmanager service is now using systemd's DynamicUser mechanism which obviates a user setting." + ) + (lib.mkRemovedOptionModule [ "services" "prometheus" "alertmanager" "group" ] + "The alertmanager service is now using systemd's DynamicUser mechanism which obviates a group setting." + ) (lib.mkRemovedOptionModule [ "services" "prometheus" "alertmanagerURL" ] '' Due to incompatibility, the alertmanagerURL option has been removed, please use 'services.prometheus.alertmanagers' instead. @@ -91,7 +105,13 @@ in { }; logLevel = lib.mkOption { - type = lib.types.enum ["debug" "info" "warn" "error" "fatal"]; + type = lib.types.enum [ + "debug" + "info" + "warn" + "error" + "fatal" + ]; default = "warn"; description = '' Only log messages with the given severity or above. @@ -136,7 +156,7 @@ in { clusterPeers = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Initial peers for HA cluster. ''; @@ -144,7 +164,7 @@ in { extraFlags = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Extra commandline options when launching the Alertmanager. ''; @@ -168,8 +188,9 @@ in { (lib.mkIf cfg.enable { assertions = lib.singleton { assertion = cfg.configuration != null || cfg.configText != null; - message = "Can not enable alertmanager without a configuration. " - + "Set either the `configuration` or `configText` attribute."; + message = + "Can not enable alertmanager without a configuration. " + + "Set either the `configuration` or `configText` attribute."; }; }) (lib.mkIf cfg.enable { @@ -177,16 +198,18 @@ in { systemd.services.alertmanager = { wantedBy = [ "multi-user.target" ]; - wants = [ "network-online.target" ]; - after = [ "network-online.target" ]; + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; preStart = '' - ${lib.getBin pkgs.envsubst}/bin/envsubst -o "/tmp/alert-manager-substituted.yaml" \ - -i "${alertmanagerYml}" + ${lib.getBin pkgs.envsubst}/bin/envsubst -o "/tmp/alert-manager-substituted.yaml" \ + -i "${alertmanagerYml}" ''; serviceConfig = { - ExecStart = "${cfg.package}/bin/alertmanager" + - lib.optionalString (lib.length cmdlineArgs != 0) (" \\\n " + - lib.concatStringsSep " \\\n " cmdlineArgs); + ExecStart = + "${cfg.package}/bin/alertmanager" + + lib.optionalString (lib.length cmdlineArgs != 0) ( + " \\\n " + lib.concatStringsSep " \\\n " cmdlineArgs + ); ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; EnvironmentFile = lib.mkIf (cfg.environmentFile != null) cfg.environmentFile; @@ -217,9 +240,13 @@ in { ProtectKernelLogs = true; ProtectControlGroups = true; - Restart = "always"; + Restart = "always"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_NETLINK" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_NETLINK" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/apcupsd.nix b/nixos/modules/services/monitoring/prometheus/exporters/apcupsd.nix index f188fe1f68fb87..3f5d66b0168f9c 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/apcupsd.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/apcupsd.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.apcupsd; @@ -16,7 +22,11 @@ in }; apcupsdNetwork = mkOption { - type = types.enum ["tcp" "tcp4" "tcp6"]; + type = types.enum [ + "tcp" + "tcp4" + "tcp6" + ]; default = "tcp"; description = '' Network of the apcupsd Network Information Server (NIS): one of "tcp", "tcp4", or "tcp6". diff --git a/nixos/modules/services/monitoring/prometheus/exporters/artifactory.nix b/nixos/modules/services/monitoring/prometheus/exporters/artifactory.nix index e98982c0dd3124..5b329117dea444 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/artifactory.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/artifactory.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.artifactory; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/bind.nix b/nixos/modules/services/monitoring/prometheus/exporters/bind.nix index 1c7dcf8b1ef03e..3390374172c4a7 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/bind.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/bind.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.bind; @@ -22,15 +28,28 @@ in ''; }; bindVersion = mkOption { - type = types.enum [ "xml.v2" "xml.v3" "auto" ]; + type = types.enum [ + "xml.v2" + "xml.v3" + "auto" + ]; default = "auto"; description = '' BIND statistics version. Can be detected automatically. ''; }; bindGroups = mkOption { - type = types.listOf (types.enum [ "server" "view" "tasks" ]); - default = [ "server" "view" ]; + type = types.listOf ( + types.enum [ + "server" + "view" + "tasks" + ] + ); + default = [ + "server" + "view" + ]; description = '' List of statistics to collect. Available: [server, view, tasks] ''; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/bird.nix b/nixos/modules/services/monitoring/prometheus/exporters/bird.nix index 5d91eeed106d48..00b217e1fd2ab2 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/bird.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/bird.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.bird; @@ -13,7 +19,10 @@ in port = 9324; extraOpts = { birdVersion = mkOption { - type = types.enum [ 1 2 ]; + type = types.enum [ + 1 + 2 + ]; default = 2; description = '' Specifies whether BIRD1 or BIRD2 is in use. diff --git a/nixos/modules/services/monitoring/prometheus/exporters/bitcoin.nix b/nixos/modules/services/monitoring/prometheus/exporters/bitcoin.nix index e1b7dc91a0d773..ca1e0f7aaa9530 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/bitcoin.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/bitcoin.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.bitcoin; @@ -25,7 +31,10 @@ in }; rpcScheme = mkOption { - type = types.enum [ "http" "https" ]; + type = types.enum [ + "http" + "https" + ]; default = "http"; description = '' Whether to connect to bitcoind over http or https. @@ -58,7 +67,7 @@ in extraEnv = mkOption { type = types.attrsOf types.str; - default = {}; + default = { }; description = '' Extra environment variables for the exporter. ''; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/blackbox.nix b/nixos/modules/services/monitoring/prometheus/exporters/blackbox.nix index 33a1fdc528053d..c053fc5417c110 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/blackbox.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/blackbox.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let logPrefix = "services.prometheus.exporter.blackbox"; @@ -12,29 +18,37 @@ let # This ensures that we can deal with string paths, path types and # store-path strings with context. - coerceConfigFile = file: + coerceConfigFile = + file: if (builtins.isPath file) || (lib.isStorePath file) then file else - (lib.warn '' - ${logPrefix}: configuration file "${file}" is being copied to the nix-store. - If you would like to avoid that, please set enableConfigCheck to false. - '' /. + file); - checkConfigLocation = file: + ( + lib.warn '' + ${logPrefix}: configuration file "${file}" is being copied to the nix-store. + If you would like to avoid that, please set enableConfigCheck to false. + '' /. + + file + ); + checkConfigLocation = + file: if lib.hasPrefix "/tmp/" file then - throw - "${logPrefix}: configuration file must not reside within /tmp - it won't be visible to the systemd service." + throw "${logPrefix}: configuration file must not reside within /tmp - it won't be visible to the systemd service." else file; - checkConfig = file: - pkgs.runCommand "checked-blackbox-exporter.conf" { - preferLocalBuild = true; - nativeBuildInputs = [ pkgs.buildPackages.prometheus-blackbox-exporter ]; - } '' - ln -s ${coerceConfigFile file} $out - blackbox_exporter --config.check --config.file $out - ''; -in { + checkConfig = + file: + pkgs.runCommand "checked-blackbox-exporter.conf" + { + preferLocalBuild = true; + nativeBuildInputs = [ pkgs.buildPackages.prometheus-blackbox-exporter ]; + } + '' + ln -s ${coerceConfigFile file} $out + blackbox_exporter --config.check --config.file $out + ''; +in +{ port = 9115; extraOpts = { configFile = mkOption { @@ -54,21 +68,21 @@ in { }; }; - serviceOpts = let - adjustedConfigFile = if cfg.enableConfigCheck then - checkConfig cfg.configFile - else - checkConfigLocation cfg.configFile; - in { - serviceConfig = { - AmbientCapabilities = [ "CAP_NET_RAW" ]; # for ping probes - ExecStart = '' - ${pkgs.prometheus-blackbox-exporter}/bin/blackbox_exporter \ - --web.listen-address ${cfg.listenAddress}:${toString cfg.port} \ - --config.file ${escapeShellArg adjustedConfigFile} \ - ${concatStringsSep " \\\n " cfg.extraFlags} - ''; - ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + serviceOpts = + let + adjustedConfigFile = + if cfg.enableConfigCheck then checkConfig cfg.configFile else checkConfigLocation cfg.configFile; + in + { + serviceConfig = { + AmbientCapabilities = [ "CAP_NET_RAW" ]; # for ping probes + ExecStart = '' + ${pkgs.prometheus-blackbox-exporter}/bin/blackbox_exporter \ + --web.listen-address ${cfg.listenAddress}:${toString cfg.port} \ + --config.file ${escapeShellArg adjustedConfigFile} \ + ${concatStringsSep " \\\n " cfg.extraFlags} + ''; + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + }; }; - }; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/buildkite-agent.nix b/nixos/modules/services/monitoring/prometheus/exporters/buildkite-agent.nix index 0af1e33b2c4455..6a2b441e11ebaf 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/buildkite-agent.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/buildkite-agent.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.buildkite-agent; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/collectd.nix b/nixos/modules/services/monitoring/prometheus/exporters/collectd.nix index 6f4c936fd40936..b67ac32b443afc 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/collectd.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/collectd.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.collectd; @@ -34,11 +40,15 @@ in default = "0.0.0.0"; description = '' Address to listen on for binary network packets. - ''; + ''; }; securityLevel = mkOption { - type = types.enum ["None" "Sign" "Encrypt"]; + type = types.enum [ + "None" + "Sign" + "Encrypt" + ]; default = "None"; description = '' Minimum required security level for accepted packets. @@ -47,7 +57,10 @@ in }; logFormat = mkOption { - type = types.enum [ "logfmt" "json" ]; + type = types.enum [ + "logfmt" + "json" + ]; default = "logfmt"; example = "json"; description = '' @@ -56,28 +69,36 @@ in }; logLevel = mkOption { - type = types.enum ["debug" "info" "warn" "error" "fatal"]; + type = types.enum [ + "debug" + "info" + "warn" + "error" + "fatal" + ]; default = "info"; description = '' Only log messages with the given severity or above. ''; }; }; - serviceOpts = let - collectSettingsArgs = optionalString (cfg.collectdBinary.enable) '' - --collectd.listen-address ${cfg.collectdBinary.listenAddress}:${toString cfg.collectdBinary.port} \ - --collectd.security-level ${cfg.collectdBinary.securityLevel} \ - ''; - in { - serviceConfig = { - ExecStart = '' - ${pkgs.prometheus-collectd-exporter}/bin/collectd_exporter \ - --log.format ${escapeShellArg cfg.logFormat} \ - --log.level ${cfg.logLevel} \ - --web.listen-address ${cfg.listenAddress}:${toString cfg.port} \ - ${collectSettingsArgs} \ - ${concatStringsSep " \\\n " cfg.extraFlags} + serviceOpts = + let + collectSettingsArgs = optionalString (cfg.collectdBinary.enable) '' + --collectd.listen-address ${cfg.collectdBinary.listenAddress}:${toString cfg.collectdBinary.port} \ + --collectd.security-level ${cfg.collectdBinary.securityLevel} \ ''; + in + { + serviceConfig = { + ExecStart = '' + ${pkgs.prometheus-collectd-exporter}/bin/collectd_exporter \ + --log.format ${escapeShellArg cfg.logFormat} \ + --log.level ${cfg.logLevel} \ + --web.listen-address ${cfg.listenAddress}:${toString cfg.port} \ + ${collectSettingsArgs} \ + ${concatStringsSep " \\\n " cfg.extraFlags} + ''; + }; }; - }; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/deluge.nix b/nixos/modules/services/monitoring/prometheus/exporters/deluge.nix index 5943b46eeb5fcd..ec3cbaf9c40e07 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/deluge.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/deluge.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.prometheus.exporters.deluge; @@ -67,19 +72,24 @@ in ExecStart = '' ${pkgs.prometheus-deluge-exporter}/bin/deluge-exporter ''; - Environment = [ - "LISTEN_PORT=${toString cfg.port}" - "LISTEN_ADDRESS=${toString cfg.listenAddress}" + Environment = + [ + "LISTEN_PORT=${toString cfg.port}" + "LISTEN_ADDRESS=${toString cfg.listenAddress}" - "DELUGE_HOST=${cfg.delugeHost}" - "DELUGE_USER=${cfg.delugeUser}" - "DELUGE_PORT=${toString cfg.delugePort}" - ] ++ lib.optionals (cfg.delugePassword != null) [ - "DELUGE_PASSWORD=${cfg.delugePassword}" - ] ++ lib.optionals cfg.exportPerTorrentMetrics [ - "PER_TORRENT_METRICS=1" - ]; - EnvironmentFile = lib.optionalString (cfg.delugePasswordFile != null) "/etc/deluge-exporter/password"; + "DELUGE_HOST=${cfg.delugeHost}" + "DELUGE_USER=${cfg.delugeUser}" + "DELUGE_PORT=${toString cfg.delugePort}" + ] + ++ lib.optionals (cfg.delugePassword != null) [ + "DELUGE_PASSWORD=${cfg.delugePassword}" + ] + ++ lib.optionals cfg.exportPerTorrentMetrics [ + "PER_TORRENT_METRICS=1" + ]; + EnvironmentFile = lib.optionalString ( + cfg.delugePasswordFile != null + ) "/etc/deluge-exporter/password"; }; }; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/dmarc.nix b/nixos/modules/services/monitoring/prometheus/exporters/dmarc.nix index 3674fab1e4f83b..4cb11fbaa45a4d 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/dmarc.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/dmarc.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.dmarc; @@ -8,7 +14,10 @@ let inherit (cfg) folders port; listen_addr = cfg.listenAddress; storage_path = "$STATE_DIRECTORY"; - imap = (builtins.removeAttrs cfg.imap [ "passwordFile" ]) // { password = "$IMAP_PASSWORD"; use_ssl = true; }; + imap = (builtins.removeAttrs cfg.imap [ "passwordFile" ]) // { + password = "$IMAP_PASSWORD"; + use_ssl = true; + }; poll_interval_seconds = cfg.pollIntervalSeconds; deduplication_max_seconds = cfg.deduplicationMaxSeconds; logging = { @@ -16,7 +25,8 @@ let disable_existing_loggers = false; }; }; -in { +in +{ port = 9797; extraOpts = { imap = { @@ -97,7 +107,10 @@ in { }; }; serviceOpts = { - path = with pkgs; [ envsubst coreutils ]; + path = with pkgs; [ + envsubst + coreutils + ]; serviceConfig = { StateDirectory = "prometheus-dmarc-exporter"; WorkingDirectory = "/var/lib/prometheus-dmarc-exporter"; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/dnsmasq.nix b/nixos/modules/services/monitoring/prometheus/exporters/dnsmasq.nix index 9028d1fd5a6632..504af0d70d0929 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/dnsmasq.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/dnsmasq.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.dnsmasq; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/dnssec.nix b/nixos/modules/services/monitoring/prometheus/exporters/dnssec.nix index dda1ad1988a614..067d7dacfa2726 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/dnssec.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/dnssec.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.prometheus.exporters.dnssec; configFormat = pkgs.formats.toml { }; configFile = configFormat.generate "dnssec-checks.toml" cfg.configuration; -in { +in +{ port = 9204; extraOpts = { configuration = lib.mkOption { @@ -70,21 +76,26 @@ in { }; serviceOpts = { - serviceConfig = let - startScript = pkgs.writeShellScriptBin "prometheus-dnssec-exporter-start" - "${lib.concatStringsSep " " - ([ "${pkgs.prometheus-dnssec-exporter}/bin/prometheus-dnssec-exporter" ] - ++ lib.optionals (cfg.configuration != null) - [ "-config ${configFile}" ] - ++ lib.optionals (cfg.listenAddress != null) - [ "-listen-address ${lib.escapeShellArg cfg.listenAddress}" ] - ++ lib.optionals (cfg.resolvers != [ ]) [ - "-resolvers ${ - lib.escapeShellArg (lib.concatStringsSep "," cfg.resolvers) - }" - ] ++ lib.optionals (cfg.timeout != null) - [ "-timeout ${lib.escapeShellArg cfg.timeout}" ] ++ cfg.extraFlags)}"; - in { ExecStart = lib.getExe startScript; }; + serviceConfig = + let + startScript = pkgs.writeShellScriptBin "prometheus-dnssec-exporter-start" "${lib.concatStringsSep + " " + ( + [ "${pkgs.prometheus-dnssec-exporter}/bin/prometheus-dnssec-exporter" ] + ++ lib.optionals (cfg.configuration != null) [ "-config ${configFile}" ] + ++ lib.optionals (cfg.listenAddress != null) [ + "-listen-address ${lib.escapeShellArg cfg.listenAddress}" + ] + ++ lib.optionals (cfg.resolvers != [ ]) [ + "-resolvers ${lib.escapeShellArg (lib.concatStringsSep "," cfg.resolvers)}" + ] + ++ lib.optionals (cfg.timeout != null) [ "-timeout ${lib.escapeShellArg cfg.timeout}" ] + ++ cfg.extraFlags + ) + }"; + in + { + ExecStart = lib.getExe startScript; + }; }; } - diff --git a/nixos/modules/services/monitoring/prometheus/exporters/domain.nix b/nixos/modules/services/monitoring/prometheus/exporters/domain.nix index c271a040d288f7..3fe7ebc0f64470 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/domain.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/domain.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.domain; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/dovecot.nix b/nixos/modules/services/monitoring/prometheus/exporters/dovecot.nix index f11e91fd761a90..701bf800d71840 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/dovecot.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/dovecot.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.dovecot; @@ -70,7 +76,10 @@ in scopes = mkOption { type = types.listOf types.str; default = [ "user" ]; - example = [ "user" "global" ]; + example = [ + "user" + "global" + ]; description = '' Stats scopes to query. ''; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/exportarr.nix b/nixos/modules/services/monitoring/prometheus/exporters/exportarr.nix index 45c2c697519cf9..d5b076daf925d3 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/exportarr.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/exportarr.nix @@ -1,10 +1,15 @@ -{ config, lib, pkgs, options, type, ... }: +{ + config, + lib, + pkgs, + options, + type, + ... +}: let cfg = config.services.prometheus.exporters."exportarr-${type}"; - exportarrEnvironment = ( - lib.mapAttrs (_: toString) cfg.environment - ) // { + exportarrEnvironment = (lib.mapAttrs (_: toString) cfg.environment) // { PORT = toString cfg.port; URL = cfg.url; API_KEY_FILE = lib.mkIf (cfg.apiKeyFile != null) "%d/api-key"; @@ -48,7 +53,10 @@ in ExecStart = ''${cfg.package}/bin/exportarr ${type} "$@"''; ProcSubset = "pid"; ProtectProc = "invisible"; - SystemCallFilter = ["@system-service" "~@privileged"]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; }; environment = exportarrEnvironment; }; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/flow.nix b/nixos/modules/services/monitoring/prometheus/exporters/flow.nix index 7719215952a530..372a91dd01e353 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/flow.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/flow.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.flow; @@ -9,7 +15,8 @@ let concatStringsSep optionalString ; -in { +in +{ port = 9590; extraOpts = { brokers = mkOption { @@ -26,7 +33,7 @@ in { partitions = mkOption { type = types.listOf types.int; - default = []; + default = [ ]; description = '' The number of the partitions to consume, none means all. ''; @@ -47,7 +54,7 @@ in { -asn ${toString cfg.asn} \ -topic ${cfg.topic} \ -brokers ${concatStringsSep "," cfg.brokers} \ - ${optionalString (cfg.partitions != []) "-partitions ${concatStringsSep "," cfg.partitions}"} \ + ${optionalString (cfg.partitions != [ ]) "-partitions ${concatStringsSep "," cfg.partitions}"} \ -addr ${cfg.listenAddress}:${toString cfg.port} ${concatStringsSep " " cfg.extraFlags} ''; }; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/fritz.nix b/nixos/modules/services/monitoring/prometheus/exporters/fritz.nix index fcf7e8784f6024..386a89a0ba2ed5 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/fritz.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/fritz.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let inherit (lib) mkOption types; cfg = config.services.prometheus.exporters.fritz; @@ -30,55 +36,63 @@ in visible = false; }; log_level = mkOption { - type = types.enum [ "DEBUG" "INFO" "WARNING" "ERROR" "CRITICAL" ]; + type = types.enum [ + "DEBUG" + "INFO" + "WARNING" + "ERROR" + "CRITICAL" + ]; default = "INFO"; description = '' Log level to use for the exporter. ''; }; devices = mkOption { - default = []; + default = [ ]; description = "Fritz!-devices to monitor using the exporter."; - type = with types; listOf (submodule { - freeformType = yaml.type; + type = + with types; + listOf (submodule { + freeformType = yaml.type; - options = { - name = mkOption { - type = types.str; - default = ""; - description = '' - Name to use for the device. - ''; - }; - hostname = mkOption { - type = types.str; - default = "fritz.box"; - description = '' - Hostname under which the target device is reachable. - ''; - }; - username = mkOption { - type = types.str; - description = '' - Username to authenticate with the target device. - ''; - }; - password_file = mkOption { - type = types.path; - description = '' - Path to a file which contains the password to authenticate with the target device. - Needs to be readable by the user the exporter runs under. - ''; - }; - host_info = mkOption { - type = types.bool; - description = '' - Enable extended host info for this device. *Warning*: This will heavily increase scrape time. - ''; - default = false; + options = { + name = mkOption { + type = types.str; + default = ""; + description = '' + Name to use for the device. + ''; + }; + hostname = mkOption { + type = types.str; + default = "fritz.box"; + description = '' + Hostname under which the target device is reachable. + ''; + }; + username = mkOption { + type = types.str; + description = '' + Username to authenticate with the target device. + ''; + }; + password_file = mkOption { + type = types.path; + description = '' + Path to a file which contains the password to authenticate with the target device. + Needs to be readable by the user the exporter runs under. + ''; + }; + host_info = mkOption { + type = types.bool; + description = '' + Enable extended host info for this device. *Warning*: This will heavily increase scrape time. + ''; + default = false; + }; }; - }; - }); + }); }; }; }; @@ -87,10 +101,14 @@ in serviceOpts = { serviceConfig = { - ExecStart = utils.escapeSystemdExecArgs ([ - (lib.getExe pkgs.fritz-exporter) - "--config" configFile - ] ++ cfg.extraFlags); + ExecStart = utils.escapeSystemdExecArgs ( + [ + (lib.getExe pkgs.fritz-exporter) + "--config" + configFile + ] + ++ cfg.extraFlags + ); DynamicUser = false; }; }; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/fritzbox.nix b/nixos/modules/services/monitoring/prometheus/exporters/fritzbox.nix index 29470147c13f2e..7c91e79958031e 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/fritzbox.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/fritzbox.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.fritzbox; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/graphite.nix b/nixos/modules/services/monitoring/prometheus/exporters/graphite.nix index 523a720425c03e..f79afcd1f03b69 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/graphite.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/graphite.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.graphite; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/idrac.nix b/nixos/modules/services/monitoring/prometheus/exporters/idrac.nix index 54696187feb150..58bb4954c25398 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/idrac.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/idrac.nix @@ -1,12 +1,20 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.idrac; inherit (lib) mkOption types; - configFile = if cfg.configurationPath != null - then cfg.configurationPath - else pkgs.writeText "idrac.yml" (builtins.toJSON cfg.configuration); + configFile = + if cfg.configurationPath != null then + cfg.configurationPath + else + pkgs.writeText "idrac.yml" (builtins.toJSON cfg.configuration); in { port = 9348; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/imap-mailstat.nix b/nixos/modules/services/monitoring/prometheus/exporters/imap-mailstat.nix index 92d02a3f146356..c5d97dc122388e 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/imap-mailstat.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/imap-mailstat.nix @@ -1,16 +1,29 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.imap-mailstat; - valueToString = value: - if (builtins.typeOf value == "string") then "\"${value}\"" - else ( - if (builtins.typeOf value == "int") then "${toString value}" - else ( - if (builtins.typeOf value == "bool") then (if value then "true" else "false") - else "XXX ${toString value}" - ) - ); + valueToString = + value: + if (builtins.typeOf value == "string") then + "\"${value}\"" + else + ( + if (builtins.typeOf value == "int") then + "${toString value}" + else + ( + if (builtins.typeOf value == "bool") then + (if value then "true" else "false") + else + "XXX ${toString value}" + ) + ); inherit (lib) mkOption types @@ -20,17 +33,29 @@ let mapAttrs optionalString ; - createConfigFile = accounts: + createConfigFile = + accounts: # unfortunately on toTOML yet # https://github.com/NixOS/nix/issues/3929 pkgs.writeText "imap-mailstat-exporter.conf" '' - ${concatStrings (attrValues (mapAttrs (name: config: "[[Accounts]]\nname = \"${name}\"\n${concatStrings (attrValues (mapAttrs (k: v: "${k} = ${valueToString v}\n") config))}") accounts))} + ${concatStrings ( + attrValues ( + mapAttrs ( + name: config: + "[[Accounts]]\nname = \"${name}\"\n${ + concatStrings (attrValues (mapAttrs (k: v: "${k} = ${valueToString v}\n") config)) + }" + ) accounts + ) + )} ''; - mkOpt = type: description: mkOption { - type = types.nullOr type; - default = null; - description = description; - }; + mkOpt = + type: description: + mkOption { + type = types.nullOr type; + default = null; + description = description; + }; accountOptions.options = { mailaddress = mkOpt types.str "Your email address (at the moment used as login name)"; username = mkOpt types.str "If empty string mailaddress value is used"; @@ -52,7 +77,7 @@ in }; accounts = mkOption { type = types.attrsOf (types.submodule accountOptions); - default = {}; + default = { }; description = '' Accounts to monitor ''; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/influxdb.nix b/nixos/modules/services/monitoring/prometheus/exporters/influxdb.nix index 3a5680439d4c28..254e2e157e49f6 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/influxdb.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/influxdb.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.influxdb; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/ipmi.nix b/nixos/modules/services/monitoring/prometheus/exporters/ipmi.nix index 51db6059081fb0..57ee1e9b2a2102 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/ipmi.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/ipmi.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let logPrefix = "services.prometheus.exporter.ipmi"; @@ -10,7 +16,8 @@ let optionals escapeShellArg ; -in { +in +{ port = 9290; extraOpts = { @@ -32,16 +39,27 @@ in { }; serviceOpts.serviceConfig = { - ExecStart = with cfg; concatStringsSep " " ([ - "${pkgs.prometheus-ipmi-exporter}/bin/ipmi_exporter" - "--web.listen-address ${listenAddress}:${toString port}" - ] ++ optionals (cfg.webConfigFile != null) [ - "--web.config.file ${escapeShellArg cfg.webConfigFile}" - ] ++ optionals (cfg.configFile != null) [ - "--config.file ${escapeShellArg cfg.configFile}" - ] ++ extraFlags); + ExecStart = + with cfg; + concatStringsSep " " ( + [ + "${pkgs.prometheus-ipmi-exporter}/bin/ipmi_exporter" + "--web.listen-address ${listenAddress}:${toString port}" + ] + ++ optionals (cfg.webConfigFile != null) [ + "--web.config.file ${escapeShellArg cfg.webConfigFile}" + ] + ++ optionals (cfg.configFile != null) [ + "--config.file ${escapeShellArg cfg.configFile}" + ] + ++ extraFlags + ); ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; }; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/jitsi.nix b/nixos/modules/services/monitoring/prometheus/exporters/jitsi.nix index 6a6c003c197764..47bd923be7dfcc 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/jitsi.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/jitsi.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.jitsi; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/json.nix b/nixos/modules/services/monitoring/prometheus/exporters/json.nix index 1c8db0ea3e0b10..46aed2ba479340 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/json.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/json.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.json; @@ -43,6 +49,9 @@ in For more information, take a look at the official documentation (https://github.com/prometheus-community/json_exporter) of the json_exporter. '') - ({ options.warnings = options.warnings; options.assertions = options.assertions; }) + ({ + options.warnings = options.warnings; + options.assertions = options.assertions; + }) ]; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/junos-czerwonk.nix b/nixos/modules/services/monitoring/prometheus/exporters/junos-czerwonk.nix index 3519cce6e821b2..ea3ee895f15c75 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/junos-czerwonk.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/junos-czerwonk.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.junos-czerwonk; @@ -10,9 +16,12 @@ let concatStringsSep ; - configFile = if cfg.configuration != null then configurationFile else (escapeShellArg cfg.configurationFile); + configFile = + if cfg.configuration != null then configurationFile else (escapeShellArg cfg.configurationFile); - configurationFile = pkgs.writeText "prometheus-junos-czerwonk-exporter.conf" (builtins.toJSON (cfg.configuration)); + configurationFile = pkgs.writeText "prometheus-junos-czerwonk-exporter.conf" ( + builtins.toJSON (cfg.configuration) + ); in { port = 9326; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/kea.nix b/nixos/modules/services/monitoring/prometheus/exporters/kea.nix index d0f2eb6b8a3c0c..f40cae4492e034 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/kea.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/kea.nix @@ -1,8 +1,9 @@ -{ config -, lib -, pkgs -, utils -, ... +{ + config, + lib, + pkgs, + utils, + ... }: let @@ -13,7 +14,8 @@ let mkRenamedOptionModule literalExpression ; -in { +in +{ imports = [ (mkRenamedOptionModule [ "controlSocketPaths" ] [ "targets" ]) ]; @@ -41,11 +43,17 @@ in { serviceConfig = { User = "kea"; DynamicUser = true; - ExecStart = utils.escapeSystemdExecArgs ([ - (lib.getExe pkgs.prometheus-kea-exporter) - "--address" cfg.listenAddress - "--port" cfg.port - ] ++ cfg.extraFlags ++ cfg.targets); + ExecStart = utils.escapeSystemdExecArgs ( + [ + (lib.getExe pkgs.prometheus-kea-exporter) + "--address" + cfg.listenAddress + "--port" + cfg.port + ] + ++ cfg.extraFlags + ++ cfg.targets + ); RuntimeDirectory = "kea"; RuntimeDirectoryPreserve = true; RestrictAddressFamilies = [ diff --git a/nixos/modules/services/monitoring/prometheus/exporters/keylight.nix b/nixos/modules/services/monitoring/prometheus/exporters/keylight.nix index 44169cce6745eb..27fa925988a404 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/keylight.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/keylight.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.keylight; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/knot.nix b/nixos/modules/services/monitoring/prometheus/exporters/knot.nix index ed902fc27c1524..df42ca726bcd11 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/knot.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/knot.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.knot; @@ -8,7 +14,8 @@ let literalExpression concatStringsSep ; -in { +in +{ port = 9433; extraOpts = { knotLibraryPath = mkOption { diff --git a/nixos/modules/services/monitoring/prometheus/exporters/lnd.nix b/nixos/modules/services/monitoring/prometheus/exporters/lnd.nix index edface276f541f..d690ddeee498fd 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/lnd.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/lnd.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.lnd; @@ -40,6 +46,9 @@ in ${concatStringsSep " \\\n " cfg.extraFlags} ''; LogsDirectory = "prometheus-lnd-exporter"; - ReadOnlyPaths = [ cfg.lndTlsPath cfg.lndMacaroonDir ]; + ReadOnlyPaths = [ + cfg.lndTlsPath + cfg.lndMacaroonDir + ]; }; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/mail.nix b/nixos/modules/services/monitoring/prometheus/exporters/mail.nix index f6dd6f7eb994a0..7dc40293d46424 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/mail.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/mail.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.mail; @@ -15,19 +21,29 @@ let concatStringsSep ; - configFile = if cfg.configuration != null then configurationFile else (escapeShellArg cfg.configFile); + configFile = + if cfg.configuration != null then configurationFile else (escapeShellArg cfg.configFile); - configurationFile = pkgs.writeText "prometheus-mail-exporter.conf" (builtins.toJSON ( - # removes the _module attribute, null values and converts attrNames to lowercase - mapAttrs' (name: value: - if name == "servers" - then nameValuePair (toLower name) - ((map (srv: (mapAttrs' (n: v: nameValuePair (toLower n) v) - (filterAttrs (n: v: !(n == "_module" || v == null)) srv) - ))) value) - else nameValuePair (toLower name) value - ) (filterAttrs (n: _: !(n == "_module")) cfg.configuration) - )); + configurationFile = pkgs.writeText "prometheus-mail-exporter.conf" ( + builtins.toJSON ( + # removes the _module attribute, null values and converts attrNames to lowercase + mapAttrs' ( + name: value: + if name == "servers" then + nameValuePair (toLower name) ( + (map ( + srv: + (mapAttrs' (n: v: nameValuePair (toLower n) v) ( + filterAttrs (n: v: !(n == "_module" || v == null)) srv + )) + )) + value + ) + else + nameValuePair (toLower name) value + ) (filterAttrs (n: _: !(n == "_module")) cfg.configuration) + ) + ); serverOptions.options = { name = mkOption { @@ -111,7 +127,7 @@ let }; servers = mkOption { type = types.listOf (types.submodule serverOptions); - default = []; + default = [ ]; example = literalExpression '' [ { name = "testserver"; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/mikrotik.nix b/nixos/modules/services/monitoring/prometheus/exporters/mikrotik.nix index cd438f13edd25d..b3b27380778c05 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/mikrotik.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/mikrotik.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.mikrotik; @@ -53,19 +59,23 @@ in ''; }; }; - serviceOpts = let - configFile = if cfg.configFile != null - then cfg.configFile - else "${pkgs.writeText "mikrotik-exporter.yml" (builtins.toJSON cfg.configuration)}"; - in { - serviceConfig = { - # -port is misleading name, it actually accepts address too - ExecStart = '' - ${pkgs.prometheus-mikrotik-exporter}/bin/mikrotik-exporter \ - -config-file=${escapeShellArg configFile} \ - -port=${cfg.listenAddress}:${toString cfg.port} \ - ${concatStringsSep " \\\n " cfg.extraFlags} - ''; + serviceOpts = + let + configFile = + if cfg.configFile != null then + cfg.configFile + else + "${pkgs.writeText "mikrotik-exporter.yml" (builtins.toJSON cfg.configuration)}"; + in + { + serviceConfig = { + # -port is misleading name, it actually accepts address too + ExecStart = '' + ${pkgs.prometheus-mikrotik-exporter}/bin/mikrotik-exporter \ + -config-file=${escapeShellArg configFile} \ + -port=${cfg.listenAddress}:${toString cfg.port} \ + ${concatStringsSep " \\\n " cfg.extraFlags} + ''; + }; }; - }; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/modemmanager.nix b/nixos/modules/services/monitoring/prometheus/exporters/modemmanager.nix index 37ff49b27000f5..91e83126b8c17d 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/modemmanager.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/modemmanager.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.modemmanager; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/mongodb.nix b/nixos/modules/services/monitoring/prometheus/exporters/mongodb.nix index 288434e93abb0e..83b9c6a7d7d05d 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/mongodb.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/mongodb.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.mongodb; @@ -25,7 +31,10 @@ in collStats = mkOption { type = types.listOf types.str; default = [ ]; - example = [ "db1.coll1" "db2" ]; + example = [ + "db1.coll1" + "db2" + ]; description = '' List of comma separared databases.collections to get $collStats ''; @@ -33,7 +42,10 @@ in indexStats = mkOption { type = types.listOf types.str; default = [ ]; - example = [ "db1.coll1" "db2" ]; + example = [ + "db1.coll1" + "db2" + ]; description = '' List of comma separared databases.collections to get $indexStats ''; @@ -41,7 +53,16 @@ in collector = mkOption { type = types.listOf types.str; default = [ ]; - example = [ "diagnosticdata" "replicasetstatus" "dbstats" "topmetrics" "currentopmetrics" "indexstats" "dbstats" "profile" ]; + example = [ + "diagnosticdata" + "replicasetstatus" + "dbstats" + "topmetrics" + "currentopmetrics" + "indexstats" + "dbstats" + "profile" + ]; description = "Enabled collectors"; }; collectAll = mkOption { @@ -64,9 +85,22 @@ in ExecStart = '' ${getExe pkgs.prometheus-mongodb-exporter} \ --mongodb.uri="${cfg.uri}" \ - ${if cfg.collectAll then "--collect-all" else concatMapStringsSep " " (x: "--collect.${x}") cfg.collector} \ - ${optionalString (length cfg.collStats > 0) "--mongodb.collstats-colls=${concatStringsSep "," cfg.collStats}"} \ - ${optionalString (length cfg.indexStats > 0) "--mongodb.indexstats-colls=${concatStringsSep "," cfg.indexStats}"} \ + ${ + if cfg.collectAll then + "--collect-all" + else + concatMapStringsSep " " (x: "--collect.${x}") cfg.collector + } \ + ${ + optionalString ( + length cfg.collStats > 0 + ) "--mongodb.collstats-colls=${concatStringsSep "," cfg.collStats}" + } \ + ${ + optionalString ( + length cfg.indexStats > 0 + ) "--mongodb.indexstats-colls=${concatStringsSep "," cfg.indexStats}" + } \ --web.listen-address="${cfg.listenAddress}:${toString cfg.port}" \ --web.telemetry-path="${cfg.telemetryPath}" \ ${escapeShellArgs cfg.extraFlags} diff --git a/nixos/modules/services/monitoring/prometheus/exporters/mysqld.nix b/nixos/modules/services/monitoring/prometheus/exporters/mysqld.nix index 5b2c2274f0539f..5a2b2ab47ccd6a 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/mysqld.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/mysqld.nix @@ -1,8 +1,24 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.mysqld; - inherit (lib) types mkOption mkIf mkForce cli concatStringsSep optionalString escapeShellArgs; -in { + inherit (lib) + types + mkOption + mkIf + mkForce + cli + concatStringsSep + optionalString + escapeShellArgs + ; +in +{ port = 9104; extraOpts = { telemetryPath = mkOption { @@ -57,4 +73,3 @@ in { }; }; } - diff --git a/nixos/modules/services/monitoring/prometheus/exporters/nats.nix b/nixos/modules/services/monitoring/prometheus/exporters/nats.nix index 224ce474d53772..d02cc72aa89695 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/nats.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/nats.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.nats; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/nextcloud.nix b/nixos/modules/services/monitoring/prometheus/exporters/nextcloud.nix index d221bac8421ac5..fba902b5999014 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/nextcloud.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/nextcloud.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.nextcloud; @@ -64,12 +70,17 @@ in --addr ${cfg.listenAddress}:${toString cfg.port} \ --timeout ${cfg.timeout} \ --server ${cfg.url} \ - ${if cfg.passwordFile != null then '' - --username ${cfg.username} \ - --password ${escapeShellArg "@${cfg.passwordFile}"} \ - '' else '' - --auth-token ${escapeShellArg "@${cfg.tokenFile}"} \ - ''} \ + ${ + if cfg.passwordFile != null then + '' + --username ${cfg.username} \ + --password ${escapeShellArg "@${cfg.passwordFile}"} \ + '' + else + '' + --auth-token ${escapeShellArg "@${cfg.tokenFile}"} \ + '' + } \ ${concatStringsSep " \\\n " cfg.extraFlags}''; }; }; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/nginx.nix b/nixos/modules/services/monitoring/prometheus/exporters/nginx.nix index 091ad2291d2a6f..ec918e165f5aa4 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/nginx.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/nginx.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.nginx; @@ -39,7 +45,7 @@ in }; constLabels = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "label1=value1" "label2=value2" @@ -49,27 +55,37 @@ in ''; }; }; - serviceOpts = mkMerge ([{ - environment.CONST_LABELS = concatStringsSep "," cfg.constLabels; - serviceConfig = { - ExecStart = '' - ${pkgs.prometheus-nginx-exporter}/bin/nginx-prometheus-exporter \ - --nginx.scrape-uri='${cfg.scrapeUri}' \ - --${lib.optionalString (!cfg.sslVerify) "no-"}nginx.ssl-verify \ - --web.listen-address=${cfg.listenAddress}:${toString cfg.port} \ - --web.telemetry-path=${cfg.telemetryPath} \ - ${concatStringsSep " \\\n " cfg.extraFlags} - ''; - }; - }] ++ [(mkIf config.services.nginx.enable { - after = [ "nginx.service" ]; - requires = [ "nginx.service" ]; - })]); + serviceOpts = mkMerge ( + [ + { + environment.CONST_LABELS = concatStringsSep "," cfg.constLabels; + serviceConfig = { + ExecStart = '' + ${pkgs.prometheus-nginx-exporter}/bin/nginx-prometheus-exporter \ + --nginx.scrape-uri='${cfg.scrapeUri}' \ + --${lib.optionalString (!cfg.sslVerify) "no-"}nginx.ssl-verify \ + --web.listen-address=${cfg.listenAddress}:${toString cfg.port} \ + --web.telemetry-path=${cfg.telemetryPath} \ + ${concatStringsSep " \\\n " cfg.extraFlags} + ''; + }; + } + ] + ++ [ + (mkIf config.services.nginx.enable { + after = [ "nginx.service" ]; + requires = [ "nginx.service" ]; + }) + ] + ); imports = [ (mkRenamedOptionModule [ "telemetryEndpoint" ] [ "telemetryPath" ]) (mkRemovedOptionModule [ "insecure" ] '' This option was replaced by 'prometheus.exporters.nginx.sslVerify'. '') - ({ options.warnings = options.warnings; options.assertions = options.assertions; }) + ({ + options.warnings = options.warnings; + options.assertions = options.assertions; + }) ]; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/nginxlog.nix b/nixos/modules/services/monitoring/prometheus/exporters/nginxlog.nix index 63d25f3d88fb31..8a01b07d9fec55 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/nginxlog.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/nginxlog.nix @@ -1,9 +1,16 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.nginxlog; inherit (lib) mkOption types; -in { +in +{ port = 9117; extraOpts = { settings = mkOption { @@ -19,7 +26,7 @@ in { ''; }; namespaces = mkOption { - default = []; + default = [ ]; type = types.listOf (types.attrsOf types.anything); description = '' @@ -28,7 +35,7 @@ in { }; }; }; - default = {}; + default = { }; description = '' All settings of nginxlog expressed as an Nix attrset. @@ -49,22 +56,26 @@ in { }; }; - serviceOpts = let - listenConfig = { - listen = { - port = cfg.port; - address = cfg.listenAddress; - metrics_endpoint = cfg.metricsEndpoint; + serviceOpts = + let + listenConfig = { + listen = { + port = cfg.port; + address = cfg.listenAddress; + metrics_endpoint = cfg.metricsEndpoint; + }; + }; + completeConfig = pkgs.writeText "nginxlog-exporter.yaml" ( + builtins.toJSON (lib.recursiveUpdate listenConfig cfg.settings) + ); + in + { + serviceConfig = { + ExecStart = '' + ${pkgs.prometheus-nginxlog-exporter}/bin/prometheus-nginxlog-exporter -config-file ${completeConfig} + ''; + Restart = "always"; + ProtectSystem = "full"; }; }; - completeConfig = pkgs.writeText "nginxlog-exporter.yaml" (builtins.toJSON (lib.recursiveUpdate listenConfig cfg.settings)); - in { - serviceConfig = { - ExecStart = '' - ${pkgs.prometheus-nginxlog-exporter}/bin/prometheus-nginxlog-exporter -config-file ${completeConfig} - ''; - Restart="always"; - ProtectSystem="full"; - }; - }; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/node.nix b/nixos/modules/services/monitoring/prometheus/exporters/node.nix index 9d6b51ad140d0f..d2245fb9306275 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/node.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/node.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.node; @@ -18,7 +24,7 @@ in extraOpts = { enabledCollectors = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "systemd" ]; description = '' Collectors to enable. The collectors listed here are enabled in addition to the default ones. @@ -26,7 +32,7 @@ in }; disabledCollectors = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "timex" ]; description = '' Collectors to disable which are enabled by default. @@ -43,13 +49,17 @@ in ${concatMapStringsSep " " (x: "--no-collector." + x) cfg.disabledCollectors} \ --web.listen-address ${cfg.listenAddress}:${toString cfg.port} ${concatStringsSep " " cfg.extraFlags} ''; - RestrictAddressFamilies = optionals (collectorIsEnabled "logind" || collectorIsEnabled "systemd") [ - # needs access to dbus via unix sockets (logind/systemd) - "AF_UNIX" - ] ++ optionals (collectorIsEnabled "network_route" || collectorIsEnabled "wifi" || ! collectorIsDisabled "netdev") [ - # needs netlink sockets for wireless collector - "AF_NETLINK" - ]; + RestrictAddressFamilies = + optionals (collectorIsEnabled "logind" || collectorIsEnabled "systemd") [ + # needs access to dbus via unix sockets (logind/systemd) + "AF_UNIX" + ] + ++ optionals + (collectorIsEnabled "network_route" || collectorIsEnabled "wifi" || !collectorIsDisabled "netdev") + [ + # needs netlink sockets for wireless collector + "AF_NETLINK" + ]; # The timex collector needs to access clock APIs ProtectClock = collectorIsDisabled "timex"; # Allow space monitoring under /home diff --git a/nixos/modules/services/monitoring/prometheus/exporters/nut.nix b/nixos/modules/services/monitoring/prometheus/exporters/nut.nix index 157bdadddfc99a..47b45d46f99e9a 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/nut.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/nut.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.nut; @@ -54,13 +60,18 @@ in }; serviceOpts = { script = '' - ${optionalString (cfg.passwordPath != null) - "export NUT_EXPORTER_PASSWORD=$(cat ${toString cfg.passwordPath})"} + ${optionalString ( + cfg.passwordPath != null + ) "export NUT_EXPORTER_PASSWORD=$(cat ${toString cfg.passwordPath})"} ${pkgs.prometheus-nut-exporter}/bin/nut_exporter \ --nut.server=${cfg.nutServer} \ --web.listen-address="${cfg.listenAddress}:${toString cfg.port}" \ ${optionalString (cfg.nutUser != "") "--nut.username=${cfg.nutUser}"} \ - ${optionalString (cfg.nutVariables != []) "--nut.vars_enable=${concatStringsSep "," cfg.nutVariables}"} \ + ${ + optionalString ( + cfg.nutVariables != [ ] + ) "--nut.vars_enable=${concatStringsSep "," cfg.nutVariables}" + } \ ${concatStringsSep " " cfg.extraFlags} ''; }; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/pgbouncer.nix b/nixos/modules/services/monitoring/prometheus/exporters/pgbouncer.nix index 5c111687c1d75d..945a950ed85de2 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/pgbouncer.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/pgbouncer.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.pgbouncer; @@ -90,7 +96,12 @@ in }; logLevel = mkOption { - type = types.enum [ "debug" "info" "warn" "error" ]; + type = types.enum [ + "debug" + "info" + "warn" + "error" + ]; default = "info"; description = '' Only log messages with the given severity or above. @@ -98,7 +109,10 @@ in }; logFormat = mkOption { - type = types.enum [ "logfmt" "json" ]; + type = types.enum [ + "logfmt" + "json" + ]; default = "logfmt"; description = '' Output format of log messages. One of: [logfmt, json] @@ -125,26 +139,40 @@ in serviceOpts = { after = [ "pgbouncer.service" ]; - script = concatStringsSep " " ([ - "exec -- ${escapeShellArg (getExe cfg.package)}" - "--web.listen-address ${cfg.listenAddress}:${toString cfg.port}" - ] ++ optionals (cfg.connectionString != null) [ - "--pgBouncer.connectionString ${escapeShellArg cfg.connectionString}" - ] ++ optionals (cfg.telemetryPath != null) [ - "--web.telemetry-path ${escapeShellArg cfg.telemetryPath}" - ] ++ optionals (cfg.pidFile != null) [ - "--pgBouncer.pid-file ${escapeShellArg cfg.pidFile}" - ] ++ optionals (cfg.logLevel != null) [ - "--log.level ${escapeShellArg cfg.logLevel}" - ] ++ optionals (cfg.logFormat != null) [ - "--log.format ${escapeShellArg cfg.logFormat}" - ] ++ optionals (cfg.webSystemdSocket != false) [ - "--web.systemd-socket ${escapeShellArg cfg.webSystemdSocket}" - ] ++ optionals (cfg.webConfigFile != null) [ - "--web.config.file ${escapeShellArg cfg.webConfigFile}" - ] ++ cfg.extraFlags); - - serviceConfig.RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + script = concatStringsSep " " ( + [ + "exec -- ${escapeShellArg (getExe cfg.package)}" + "--web.listen-address ${cfg.listenAddress}:${toString cfg.port}" + ] + ++ optionals (cfg.connectionString != null) [ + "--pgBouncer.connectionString ${escapeShellArg cfg.connectionString}" + ] + ++ optionals (cfg.telemetryPath != null) [ + "--web.telemetry-path ${escapeShellArg cfg.telemetryPath}" + ] + ++ optionals (cfg.pidFile != null) [ + "--pgBouncer.pid-file ${escapeShellArg cfg.pidFile}" + ] + ++ optionals (cfg.logLevel != null) [ + "--log.level ${escapeShellArg cfg.logLevel}" + ] + ++ optionals (cfg.logFormat != null) [ + "--log.format ${escapeShellArg cfg.logFormat}" + ] + ++ optionals (cfg.webSystemdSocket != false) [ + "--web.systemd-socket ${escapeShellArg cfg.webSystemdSocket}" + ] + ++ optionals (cfg.webConfigFile != null) [ + "--web.config.file ${escapeShellArg cfg.webConfigFile}" + ] + ++ cfg.extraFlags + ); + + serviceConfig.RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; serviceConfig.EnvironmentFile = lib.mkIf (cfg.connectionEnvFile != null) [ cfg.connectionEnvFile ]; @@ -160,6 +188,9 @@ in into the cmdline of the exporter making the connection string effectively world-readable. '') - ({ options.warnings = options.warnings; options.assertions = options.assertions; }) + ({ + options.warnings = options.warnings; + options.assertions = options.assertions; + }) ]; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/php-fpm.nix b/nixos/modules/services/monitoring/prometheus/exporters/php-fpm.nix index 5d8253f26c4367..e93ccf50ac6deb 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/php-fpm.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/php-fpm.nix @@ -1,17 +1,19 @@ -{ config -, lib -, pkgs -, options -, ... +{ + config, + lib, + pkgs, + options, + ... }: let logPrefix = "services.prometheus.exporter.php-fpm"; cfg = config.services.prometheus.exporters.php-fpm; -in { +in +{ port = 9253; extraOpts = { - package = lib.mkPackageOption pkgs "prometheus-php-fpm-exporter" {}; + package = lib.mkPackageOption pkgs "prometheus-php-fpm-exporter" { }; telemetryPath = lib.mkOption { type = lib.types.str; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/pihole.nix b/nixos/modules/services/monitoring/prometheus/exporters/pihole.nix index 30b260dc3792a1..f2d37c6b95e605 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/pihole.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/pihole.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.pihole; @@ -11,8 +17,11 @@ let in { imports = [ - (mkRemovedOptionModule [ "interval"] "This option has been removed.") - ({ options.warnings = options.warnings; options.assertions = options.assertions; }) + (mkRemovedOptionModule [ "interval" ] "This option has been removed.") + ({ + options.warnings = options.warnings; + options.assertions = options.assertions; + }) ]; port = 9617; @@ -50,7 +59,10 @@ in ''; }; protocol = mkOption { - type = types.enum [ "http" "https" ]; + type = types.enum [ + "http" + "https" + ]; default = "http"; example = "https"; description = '' diff --git a/nixos/modules/services/monitoring/prometheus/exporters/ping.nix b/nixos/modules/services/monitoring/prometheus/exporters/ping.nix index 9122a6be66e661..90fb3470eef8b4 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/ping.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/ping.nix @@ -1,11 +1,16 @@ -{ config, lib, pkgs, options, ... }: - +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.ping; inherit (lib) mkOption types concatStringsSep; - settingsFormat = pkgs.formats.yaml {}; + settingsFormat = pkgs.formats.yaml { }; configFile = settingsFormat.generate "config.yml" cfg.settings; in { @@ -21,7 +26,7 @@ in settings = mkOption { type = settingsFormat.type; - default = {}; + default = { }; description = '' Configuration for ping_exporter, see diff --git a/nixos/modules/services/monitoring/prometheus/exporters/postfix.nix b/nixos/modules/services/monitoring/prometheus/exporters/postfix.nix index fdd7a0453603c2..53a4056b86dda1 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/postfix.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/postfix.nix @@ -98,22 +98,20 @@ in --web.listen-address ${cfg.listenAddress}:${toString cfg.port} \ --web.telemetry-path ${cfg.telemetryPath} \ --postfix.showq_path ${escapeShellArg cfg.showqPath} \ - ${ - concatStringsSep " \\\n " ( - cfg.extraFlags - ++ optional cfg.systemd.enable "--systemd.enable" - ++ optional cfg.systemd.enable ( - if cfg.systemd.slice != null then - "--systemd.slice ${cfg.systemd.slice}" - else - "--systemd.unit ${cfg.systemd.unit}" - ) - ++ optional ( - cfg.systemd.enable && (cfg.systemd.journalPath != null) - ) "--systemd.journal_path ${escapeShellArg cfg.systemd.journalPath}" - ++ optional (!cfg.systemd.enable) "--postfix.logfile_path ${escapeShellArg cfg.logfilePath}" + ${concatStringsSep " \\\n " ( + cfg.extraFlags + ++ optional cfg.systemd.enable "--systemd.enable" + ++ optional cfg.systemd.enable ( + if cfg.systemd.slice != null then + "--systemd.slice ${cfg.systemd.slice}" + else + "--systemd.unit ${cfg.systemd.unit}" ) - } + ++ optional ( + cfg.systemd.enable && (cfg.systemd.journalPath != null) + ) "--systemd.journal_path ${escapeShellArg cfg.systemd.journalPath}" + ++ optional (!cfg.systemd.enable) "--postfix.logfile_path ${escapeShellArg cfg.logfilePath}" + )} ''; }; }; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/postgres.nix b/nixos/modules/services/monitoring/prometheus/exporters/postgres.nix index bf392382660abd..8450d79e7fb3b4 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/postgres.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/postgres.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.postgres; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/process.nix b/nixos/modules/services/monitoring/prometheus/exporters/process.nix index 8e5eceee067ce0..eb6bce56b48513 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/process.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/process.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.process; @@ -15,7 +21,7 @@ in extraOpts = { settings.process_names = mkOption { type = types.listOf types.anything; - default = []; + default = [ ]; example = literalExpression '' [ # Remove nix store path from process name diff --git a/nixos/modules/services/monitoring/prometheus/exporters/pve.nix b/nixos/modules/services/monitoring/prometheus/exporters/pve.nix index fa5852a4999dd1..c13dc71cf34064 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/pve.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/pve.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.pve; @@ -124,25 +130,27 @@ in }; }; serviceOpts = { - serviceConfig = { - DynamicUser = cfg.environmentFile == null; - LoadCredential = "configFile:${computedConfigFile}"; - ExecStart = '' - ${cfg.package}/bin/pve_exporter \ - --${optionalString (!cfg.collectors.status) "no-"}collector.status \ - --${optionalString (!cfg.collectors.version) "no-"}collector.version \ - --${optionalString (!cfg.collectors.node) "no-"}collector.node \ - --${optionalString (!cfg.collectors.cluster) "no-"}collector.cluster \ - --${optionalString (!cfg.collectors.resources) "no-"}collector.resources \ - --${optionalString (!cfg.collectors.config) "no-"}collector.config \ - --${optionalString (!cfg.collectors.replication) "no-"}collector.replication \ - ${optionalString (cfg.server.keyFile != null) "--server.keyfile ${cfg.server.keyFile}"} \ - ${optionalString (cfg.server.certFile != null) "--server.certfile ${cfg.server.certFile}"} \ - --config.file %d/configFile \ - --web.listen-address ${cfg.listenAddress}:${toString cfg.port} - ''; - } // optionalAttrs (cfg.environmentFile != null) { - EnvironmentFile = cfg.environmentFile; - }; + serviceConfig = + { + DynamicUser = cfg.environmentFile == null; + LoadCredential = "configFile:${computedConfigFile}"; + ExecStart = '' + ${cfg.package}/bin/pve_exporter \ + --${optionalString (!cfg.collectors.status) "no-"}collector.status \ + --${optionalString (!cfg.collectors.version) "no-"}collector.version \ + --${optionalString (!cfg.collectors.node) "no-"}collector.node \ + --${optionalString (!cfg.collectors.cluster) "no-"}collector.cluster \ + --${optionalString (!cfg.collectors.resources) "no-"}collector.resources \ + --${optionalString (!cfg.collectors.config) "no-"}collector.config \ + --${optionalString (!cfg.collectors.replication) "no-"}collector.replication \ + ${optionalString (cfg.server.keyFile != null) "--server.keyfile ${cfg.server.keyFile}"} \ + ${optionalString (cfg.server.certFile != null) "--server.certfile ${cfg.server.certFile}"} \ + --config.file %d/configFile \ + --web.listen-address ${cfg.listenAddress}:${toString cfg.port} + ''; + } + // optionalAttrs (cfg.environmentFile != null) { + EnvironmentFile = cfg.environmentFile; + }; }; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/py-air-control.nix b/nixos/modules/services/monitoring/prometheus/exporters/py-air-control.nix index d788ce363d6145..773506195001a5 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/py-air-control.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/py-air-control.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.py-air-control; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/redis.nix b/nixos/modules/services/monitoring/prometheus/exporters/redis.nix index 672e3dfe7b059d..7ed7a7b51228aa 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/redis.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/redis.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.redis; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/restic.nix b/nixos/modules/services/monitoring/prometheus/exporters/restic.nix index 2eeb76f6f12bfe..99cdaf81305b2e 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/restic.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/restic.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.restic; @@ -62,7 +68,12 @@ in }; rcloneOptions = mkOption { - type = with types; attrsOf (oneOf [ str bool ]); + type = + with types; + attrsOf (oneOf [ + str + bool + ]); default = { }; description = '' Options to pass to rclone to control its behavior. @@ -75,7 +86,12 @@ in }; rcloneConfig = mkOption { - type = with types; attrsOf (oneOf [ str bool ]); + type = + with types; + attrsOf (oneOf [ + str + bool + ]); default = { }; description = '' Configuration for the rclone remote being used for backup. @@ -114,9 +130,10 @@ in serviceOpts = { script = '' export RESTIC_REPOSITORY=${ - if cfg.repositoryFile != null - then "$(cat $CREDENTIALS_DIRECTORY/RESTIC_REPOSITORY)" - else "${cfg.repository}" + if cfg.repositoryFile != null then + "$(cat $CREDENTIALS_DIRECTORY/RESTIC_REPOSITORY)" + else + "${cfg.repository}" } export RESTIC_PASSWORD_FILE=$CREDENTIALS_DIRECTORY/RESTIC_PASSWORD_FILE ${pkgs.prometheus-restic-exporter}/bin/restic-exporter.py \ @@ -124,10 +141,9 @@ in ''; serviceConfig = { EnvironmentFile = mkIf (cfg.environmentFile != null) cfg.environmentFile; - LoadCredential = - [ "RESTIC_PASSWORD_FILE:${cfg.passwordFile}" ] - ++ optional (cfg.repositoryFile != null) - [ "RESTIC_REPOSITORY:${cfg.repositoryFile}" ]; + LoadCredential = [ + "RESTIC_PASSWORD_FILE:${cfg.passwordFile}" + ] ++ optional (cfg.repositoryFile != null) [ "RESTIC_REPOSITORY:${cfg.repositoryFile}" ]; }; environment = let @@ -141,18 +157,14 @@ in LISTEN_PORT = toString cfg.port; REFRESH_INTERVAL = toString cfg.refreshInterval; } - // (mapAttrs' - (name: value: - nameValuePair (rcloneAttrToOpt name) (toRcloneVal value) - ) - cfg.rcloneOptions) + // (mapAttrs' ( + name: value: nameValuePair (rcloneAttrToOpt name) (toRcloneVal value) + ) cfg.rcloneOptions) // optionalAttrs (cfg.rcloneConfigFile != null) { RCLONE_CONFIG = cfg.rcloneConfigFile; } - // (mapAttrs' - (name: value: - nameValuePair (rcloneAttrToConf name) (toRcloneVal value) - ) - cfg.rcloneConfig); + // (mapAttrs' ( + name: value: nameValuePair (rcloneAttrToConf name) (toRcloneVal value) + ) cfg.rcloneConfig); }; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/rspamd.nix b/nixos/modules/services/monitoring/prometheus/exporters/rspamd.nix index 8993aee5d24825..21e03154a88f21 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/rspamd.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/rspamd.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.rspamd; @@ -12,53 +18,59 @@ let literalExpression ; - mkFile = conf: - pkgs.writeText "rspamd-exporter-config.yml" (builtins.toJSON conf); + mkFile = conf: pkgs.writeText "rspamd-exporter-config.yml" (builtins.toJSON conf); generateConfig = extraLabels: { - modules.default.metrics = (map (path: { - name = "rspamd_${replaceStrings [ "[" "." " " "]" "\\" "'" ] [ "_" "_" "_" "" "" "" ] path}"; - path = "{ .${path} }"; - labels = extraLabels; - }) [ - "actions['add\\ header']" - "actions['no\\ action']" - "actions['rewrite\\ subject']" - "actions['soft\\ reject']" - "actions.greylist" - "actions.reject" - "bytes_allocated" - "chunks_allocated" - "chunks_freed" - "chunks_oversized" - "connections" - "control_connections" - "ham_count" - "learned" - "pools_allocated" - "pools_freed" - "read_only" - "scanned" - "shared_chunks_allocated" - "spam_count" - "total_learns" - ]) ++ [{ - name = "rspamd_statfiles"; - type = "object"; - path = "{.statfiles[*]}"; - labels = recursiveUpdate { - symbol = "{.symbol}"; - type = "{.type}"; - } extraLabels; - values = { - revision = "{.revision}"; - size = "{.size}"; - total = "{.total}"; - used = "{.used}"; - languages = "{.languages}"; - users = "{.users}"; - }; - }]; + modules.default.metrics = + (map + (path: { + name = "rspamd_${replaceStrings [ "[" "." " " "]" "\\" "'" ] [ "_" "_" "_" "" "" "" ] path}"; + path = "{ .${path} }"; + labels = extraLabels; + }) + [ + "actions['add\\ header']" + "actions['no\\ action']" + "actions['rewrite\\ subject']" + "actions['soft\\ reject']" + "actions.greylist" + "actions.reject" + "bytes_allocated" + "chunks_allocated" + "chunks_freed" + "chunks_oversized" + "connections" + "control_connections" + "ham_count" + "learned" + "pools_allocated" + "pools_freed" + "read_only" + "scanned" + "shared_chunks_allocated" + "spam_count" + "total_learns" + ] + ) + ++ [ + { + name = "rspamd_statfiles"; + type = "object"; + path = "{.statfiles[*]}"; + labels = recursiveUpdate { + symbol = "{.symbol}"; + type = "{.type}"; + } extraLabels; + values = { + revision = "{.revision}"; + size = "{.size}"; + total = "{.total}"; + used = "{.used}"; + languages = "{.languages}"; + users = "{.users}"; + }; + } + ]; }; in { @@ -99,6 +111,9 @@ in For more information, take a look at the official documentation (https://github.com/prometheus-community/json_exporter) of the json_exporter. '') - ({ options.warnings = options.warnings; options.assertions = options.assertions; }) + ({ + options.warnings = options.warnings; + options.assertions = options.assertions; + }) ]; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/rtl_433.nix b/nixos/modules/services/monitoring/prometheus/exporters/rtl_433.nix index 02624a0e80e764..d07497686cf140 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/rtl_433.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/rtl_433.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.rtl_433; @@ -6,56 +12,67 @@ in { port = 9550; - extraOpts = let - mkMatcherOptionType = field: description: with lib.types; - listOf (submodule { - options = { - name = lib.mkOption { - type = str; - description = "Name to match."; - }; - "${field}" = lib.mkOption { - type = int; - description = description; - }; - location = lib.mkOption { - type = str; - description = "Location to match."; + extraOpts = + let + mkMatcherOptionType = + field: description: + with lib.types; + listOf (submodule { + options = { + name = lib.mkOption { + type = str; + description = "Name to match."; + }; + "${field}" = lib.mkOption { + type = int; + description = description; + }; + location = lib.mkOption { + type = str; + description = "Location to match."; + }; }; - }; - }); - in - { - rtl433Flags = lib.mkOption { - type = lib.types.str; - default = "-C si"; - example = "-C si -R 19"; - description = '' - Flags passed verbatim to rtl_433 binary. - Having `-C si` (the default) is recommended since only Celsius temperatures are parsed. - ''; + }); + in + { + rtl433Flags = lib.mkOption { + type = lib.types.str; + default = "-C si"; + example = "-C si -R 19"; + description = '' + Flags passed verbatim to rtl_433 binary. + Having `-C si` (the default) is recommended since only Celsius temperatures are parsed. + ''; + }; + channels = lib.mkOption { + type = mkMatcherOptionType "channel" "Channel to match."; + default = [ ]; + example = [ + { + name = "Acurite"; + channel = 6543; + location = "Kitchen"; + } + ]; + description = '' + List of channel matchers to export. + ''; + }; + ids = lib.mkOption { + type = mkMatcherOptionType "id" "ID to match."; + default = [ ]; + example = [ + { + name = "Nexus"; + id = 1; + location = "Bedroom"; + } + ]; + description = '' + List of ID matchers to export. + ''; + }; }; - channels = lib.mkOption { - type = mkMatcherOptionType "channel" "Channel to match."; - default = []; - example = [ - { name = "Acurite"; channel = 6543; location = "Kitchen"; } - ]; - description = '' - List of channel matchers to export. - ''; - }; - ids = lib.mkOption { - type = mkMatcherOptionType "id" "ID to match."; - default = []; - example = [ - { name = "Nexus"; id = 1; location = "Bedroom"; } - ]; - description = '' - List of ID matchers to export. - ''; - }; - }; serviceOpts = { serviceConfig = { @@ -66,18 +83,19 @@ in DeviceAllow = lib.mkForce "char-usb_device rw"; RestrictAddressFamilies = [ "AF_NETLINK" ]; - ExecStart = let - matchers = (map (m: - "--channel_matcher '${m.name},${toString m.channel},${m.location}'" - ) cfg.channels) ++ (map (m: - "--id_matcher '${m.name},${toString m.id},${m.location}'" - ) cfg.ids); in '' - ${pkgs.prometheus-rtl_433-exporter}/bin/rtl_433_prometheus \ - -listen ${cfg.listenAddress}:${toString cfg.port} \ - -subprocess "${pkgs.rtl_433}/bin/rtl_433 -F json ${cfg.rtl433Flags}" \ - ${lib.concatStringsSep " \\\n " matchers} \ - ${lib.concatStringsSep " \\\n " cfg.extraFlags} - ''; + ExecStart = + let + matchers = + (map (m: "--channel_matcher '${m.name},${toString m.channel},${m.location}'") cfg.channels) + ++ (map (m: "--id_matcher '${m.name},${toString m.id},${m.location}'") cfg.ids); + in + '' + ${pkgs.prometheus-rtl_433-exporter}/bin/rtl_433_prometheus \ + -listen ${cfg.listenAddress}:${toString cfg.port} \ + -subprocess "${pkgs.rtl_433}/bin/rtl_433 -F json ${cfg.rtl433Flags}" \ + ${lib.concatStringsSep " \\\n " matchers} \ + ${lib.concatStringsSep " \\\n " cfg.extraFlags} + ''; }; }; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/sabnzbd.nix b/nixos/modules/services/monitoring/prometheus/exporters/sabnzbd.nix index 0d937ac6673f83..900074c60821ee 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/sabnzbd.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/sabnzbd.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let inherit (lib) mkOption types; @@ -10,31 +16,36 @@ in extraOpts = { servers = mkOption { description = "List of sabnzbd servers to connect to."; - type = types.listOf (types.submodule { - options = { - baseUrl = mkOption { - type = types.str; - description = "Base URL of the sabnzbd server."; - example = "http://localhost:8080/sabnzbd"; - }; - apiKeyFile = mkOption { - type = types.str; - description = '' - The path to a file containing the API key. - The file is securely passed to the service by leveraging systemd credentials. - No special permissions need to be set on this file. - ''; - example = "/run/secrets/sabnzbd_apikey"; + type = types.listOf ( + types.submodule { + options = { + baseUrl = mkOption { + type = types.str; + description = "Base URL of the sabnzbd server."; + example = "http://localhost:8080/sabnzbd"; + }; + apiKeyFile = mkOption { + type = types.str; + description = '' + The path to a file containing the API key. + The file is securely passed to the service by leveraging systemd credentials. + No special permissions need to be set on this file. + ''; + example = "/run/secrets/sabnzbd_apikey"; + }; }; - }; - }); + } + ); }; }; serviceOpts = let servers = lib.zipAttrs cfg.servers; - credentials = lib.imap0 (i: v: { name = "apikey-${toString i}"; path = v; }) servers.apiKeyFile; + credentials = lib.imap0 (i: v: { + name = "apikey-${toString i}"; + path = v; + }) servers.apiKeyFile; in { serviceConfig.LoadCredential = builtins.map ({ name, path }: "${name}:${path}") credentials; @@ -47,7 +58,9 @@ in script = let - apiKeys = lib.concatStringsSep "," (builtins.map (cred: "$(< $CREDENTIALS_DIRECTORY/${cred.name})") credentials); + apiKeys = lib.concatStringsSep "," ( + builtins.map (cred: "$(< $CREDENTIALS_DIRECTORY/${cred.name})") credentials + ); in '' export SABNZBD_APIKEYS="${apiKeys}" diff --git a/nixos/modules/services/monitoring/prometheus/exporters/scaphandre.nix b/nixos/modules/services/monitoring/prometheus/exporters/scaphandre.nix index fbee2850db7442..a3dadccfda197a 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/scaphandre.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/scaphandre.nix @@ -1,14 +1,16 @@ -{ config -, lib -, pkgs -, options -, ... +{ + config, + lib, + pkgs, + options, + ... }: let logPrefix = "services.prometheus.exporter.scaphandre"; cfg = config.services.prometheus.exporters.scaphandre; -in { +in +{ port = 8080; extraOpts = { telemetryPath = lib.mkOption { diff --git a/nixos/modules/services/monitoring/prometheus/exporters/script.nix b/nixos/modules/services/monitoring/prometheus/exporters/script.nix index 0967ce236a62eb..57113c2e249085 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/script.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/script.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.script; @@ -14,26 +20,28 @@ in port = 9172; extraOpts = { settings.scripts = mkOption { - type = with types; listOf (submodule { - options = { - name = mkOption { - type = str; - example = "sleep"; - description = "Name of the script."; - }; - script = mkOption { - type = str; - example = "sleep 5"; - description = "Shell script to execute when metrics are requested."; - }; - timeout = mkOption { - type = nullOr int; - default = null; - example = 60; - description = "Optional timeout for the script in seconds."; + type = + with types; + listOf (submodule { + options = { + name = mkOption { + type = str; + example = "sleep"; + description = "Name of the script."; + }; + script = mkOption { + type = str; + example = "sleep 5"; + description = "Shell script to execute when metrics are requested."; + }; + timeout = mkOption { + type = nullOr int; + default = null; + example = 60; + description = "Optional timeout for the script in seconds."; + }; }; - }; - }); + }); example = literalExpression '' { scripts = [ diff --git a/nixos/modules/services/monitoring/prometheus/exporters/shelly.nix b/nixos/modules/services/monitoring/prometheus/exporters/shelly.nix index be3e483c6ee19e..e6d5885c660a09 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/shelly.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/shelly.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.shelly; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/smartctl.nix b/nixos/modules/services/monitoring/prometheus/exporters/smartctl.nix index 90adfe911a7374..94f2a3731f4706 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/smartctl.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/smartctl.nix @@ -1,15 +1,24 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.smartctl; inherit (lib) mkOption types literalExpression; - args = lib.escapeShellArgs ([ - "--web.listen-address=${cfg.listenAddress}:${toString cfg.port}" - "--smartctl.interval=${cfg.maxInterval}" - ] ++ map (device: "--smartctl.device=${device}") cfg.devices - ++ cfg.extraFlags); + args = lib.escapeShellArgs ( + [ + "--web.listen-address=${cfg.listenAddress}:${toString cfg.port}" + "--smartctl.interval=${cfg.maxInterval}" + ] + ++ map (device: "--smartctl.device=${device}") cfg.devices + ++ cfg.extraFlags + ); in { @@ -58,8 +67,14 @@ in PrivateDevices = lib.mkForce false; ProtectProc = "invisible"; ProcSubset = "pid"; - SupplementaryGroups = [ "disk" "smartctl-exporter-access" ]; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SupplementaryGroups = [ + "disk" + "smartctl-exporter-access" + ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; }; }; } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/smokeping.nix b/nixos/modules/services/monitoring/prometheus/exporters/smokeping.nix index c3baed1503764d..0a3ceba88d2011 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/smokeping.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/smokeping.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.smokeping; @@ -6,7 +12,8 @@ let goDuration = types.mkOptionType { name = "goDuration"; description = "Go duration (https://golang.org/pkg/time/#ParseDuration)"; - check = x: types.str.check x && builtins.match "(-?[0-9]+(\.[0-9]+)?(ns|us|µs|ms|s|m|h))+" x != null; + check = + x: types.str.check x && builtins.match "(-?[0-9]+(\.[0-9]+)?(ns|us|µs|ms|s|m|h))+" x != null; inherit (types.str) merge; }; in diff --git a/nixos/modules/services/monitoring/prometheus/exporters/sql.nix b/nixos/modules/services/monitoring/prometheus/exporters/sql.nix index 59715f5d33e24a..765ee10c480944 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/sql.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/sql.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.sql; inherit (lib) @@ -32,7 +38,7 @@ let }; startupSql = mkOption { type = listOf str; - default = []; + default = [ ]; description = "A list of SQL statements to execute once after making a connection."; }; queries = mkOption { @@ -65,15 +71,16 @@ let }; configFile = - if cfg.configFile != null - then cfg.configFile + if cfg.configFile != null then + cfg.configFile else let nameInline = mapAttrsToList (k: v: v // { name = k; }); renameStartupSql = j: removeAttrs (j // { startup_sql = j.startupSql; }) [ "startupSql" ]; configuration = { - jobs = map renameStartupSql - (nameInline (mapAttrs (k: v: (v // { queries = nameInline v.queries; })) cfg.configuration.jobs)); + jobs = map renameStartupSql ( + nameInline (mapAttrs (k: v: (v // { queries = nameInline v.queries; })) cfg.configuration.jobs) + ); }; in builtins.toFile "config.yaml" (builtins.toJSON configuration); diff --git a/nixos/modules/services/monitoring/prometheus/exporters/statsd.nix b/nixos/modules/services/monitoring/prometheus/exporters/statsd.nix index b1bc65c9a492f7..5069302aef8e73 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/statsd.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/statsd.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.statsd; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/surfboard.nix b/nixos/modules/services/monitoring/prometheus/exporters/surfboard.nix index d848e263a3b643..4306b813c57890 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/surfboard.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/surfboard.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.surfboard; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/systemd.nix b/nixos/modules/services/monitoring/prometheus/exporters/systemd.nix index 52bad81ed7d515..5dab7e3728501b 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/systemd.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/systemd.nix @@ -1,9 +1,15 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.prometheus.exporters.systemd; inherit (lib) concatStringsSep; -in { +in +{ port = 9558; serviceOpts = { diff --git a/nixos/modules/services/monitoring/prometheus/exporters/unbound.nix b/nixos/modules/services/monitoring/prometheus/exporters/unbound.nix index df6011e2434b1a..80a97d42e97270 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/unbound.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/unbound.nix @@ -1,8 +1,9 @@ -{ config -, lib -, pkgs -, options -, ... +{ + config, + lib, + pkgs, + options, + ... }: let @@ -19,9 +20,16 @@ let in { imports = [ - (mkRemovedOptionModule [ "controlInterface" ] "This option was removed, use the `unbound.host` option instead.") - (mkRemovedOptionModule [ "fetchType" ] "This option was removed, use the `unbound.host` option instead.") - ({ options.warnings = options.warnings; options.assertions = options.assertions; }) + (mkRemovedOptionModule [ + "controlInterface" + ] "This option was removed, use the `unbound.host` option instead.") + (mkRemovedOptionModule [ + "fetchType" + ] "This option was removed, use the `unbound.host` option instead.") + ({ + options.warnings = options.warnings; + options.assertions = options.assertions; + }) ]; port = 9167; @@ -73,31 +81,38 @@ in }; }; - serviceOpts = mkMerge ([{ - serviceConfig = { - User = "unbound"; # to access the unbound_control.key - ExecStart = '' - ${pkgs.prometheus-unbound-exporter}/bin/unbound_exporter \ - --unbound.host "${cfg.unbound.host}" \ - --web.listen-address ${cfg.listenAddress}:${toString cfg.port} \ - --web.telemetry-path ${cfg.telemetryPath} \ - ${optionalString (cfg.unbound.ca != null) "--unbound.ca ${cfg.unbound.ca}"} \ - ${optionalString (cfg.unbound.certificate != null) "--unbound.cert ${cfg.unbound.certificate}"} \ - ${optionalString (cfg.unbound.key != null) "--unbound.key ${cfg.unbound.key}"} \ - ${toString cfg.extraFlags} - ''; - RestrictAddressFamilies = [ - "AF_UNIX" - "AF_INET" - "AF_INET6" - ]; - } // optionalAttrs (!config.services.unbound.enable) { - DynamicUser = true; - }; - }] ++ [ - (mkIf config.services.unbound.enable { - after = [ "unbound.service" ]; - requires = [ "unbound.service" ]; - }) - ]); + serviceOpts = mkMerge ( + [ + { + serviceConfig = + { + User = "unbound"; # to access the unbound_control.key + ExecStart = '' + ${pkgs.prometheus-unbound-exporter}/bin/unbound_exporter \ + --unbound.host "${cfg.unbound.host}" \ + --web.listen-address ${cfg.listenAddress}:${toString cfg.port} \ + --web.telemetry-path ${cfg.telemetryPath} \ + ${optionalString (cfg.unbound.ca != null) "--unbound.ca ${cfg.unbound.ca}"} \ + ${optionalString (cfg.unbound.certificate != null) "--unbound.cert ${cfg.unbound.certificate}"} \ + ${optionalString (cfg.unbound.key != null) "--unbound.key ${cfg.unbound.key}"} \ + ${toString cfg.extraFlags} + ''; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; + } + // optionalAttrs (!config.services.unbound.enable) { + DynamicUser = true; + }; + } + ] + ++ [ + (mkIf config.services.unbound.enable { + after = [ "unbound.service" ]; + requires = [ "unbound.service" ]; + }) + ] + ); } diff --git a/nixos/modules/services/monitoring/prometheus/exporters/unpoller.nix b/nixos/modules/services/monitoring/prometheus/exporters/unpoller.nix index 7b9ba4c5d1edbd..81a79ad64b6085 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/unpoller.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/unpoller.nix @@ -1,22 +1,31 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.unpoller; inherit (lib) mkEnableOption generators; - configFile = pkgs.writeText "prometheus-unpoller-exporter.json" (generators.toJSON {} { - poller = { inherit (cfg.log) debug quiet; }; - unifi = { inherit (cfg) controllers; }; - influxdb.disable = true; - datadog.disable = true; # workaround for https://github.com/unpoller/unpoller/issues/442 - prometheus = { - http_listen = "${cfg.listenAddress}:${toString cfg.port}"; - report_errors = cfg.log.prometheusErrors; - }; - inherit (cfg) loki; - }); + configFile = pkgs.writeText "prometheus-unpoller-exporter.json" ( + generators.toJSON { } { + poller = { inherit (cfg.log) debug quiet; }; + unifi = { inherit (cfg) controllers; }; + influxdb.disable = true; + datadog.disable = true; # workaround for https://github.com/unpoller/unpoller/issues/442 + prometheus = { + http_listen = "${cfg.listenAddress}:${toString cfg.port}"; + report_errors = cfg.log.prometheusErrors; + }; + inherit (cfg) loki; + } + ); -in { +in +{ port = 9130; extraOpts = { diff --git a/nixos/modules/services/monitoring/prometheus/exporters/v2ray.nix b/nixos/modules/services/monitoring/prometheus/exporters/v2ray.nix index 4fda15c9ee4ea1..6b03454030bc3c 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/v2ray.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/v2ray.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.v2ray; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/varnish.nix b/nixos/modules/services/monitoring/prometheus/exporters/varnish.nix index e94c513ae84f10..b132122f253f34 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/varnish.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/varnish.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.varnish; @@ -82,13 +88,15 @@ in --web.listen-address ${cfg.listenAddress}:${toString cfg.port} \ --web.telemetry-path ${cfg.telemetryPath} \ --varnishstat-path ${escapeShellArg cfg.varnishStatPath} \ - ${concatStringsSep " \\\n " (cfg.extraFlags + ${concatStringsSep " \\\n " ( + cfg.extraFlags ++ optional (cfg.healthPath != null) "--web.health-path ${cfg.healthPath}" ++ optional (cfg.instance != null) "-n ${escapeShellArg cfg.instance}" ++ optional cfg.noExit "--no-exit" ++ optional cfg.withGoMetrics "--with-go-metrics" ++ optional cfg.verbose "--verbose" - ++ optional cfg.raw "--raw")} + ++ optional cfg.raw "--raw" + )} ''; }; }; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/wireguard.nix b/nixos/modules/services/monitoring/prometheus/exporters/wireguard.nix index 7a48c836425ffb..4c9269f34cfd4a 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/wireguard.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/wireguard.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.wireguard; @@ -10,11 +16,15 @@ let optionalString escapeShellArg ; -in { +in +{ port = 9586; imports = [ (mkRenamedOptionModule [ "addr" ] [ "listenAddress" ]) - ({ options.warnings = options.warnings; options.assertions = options.assertions; }) + ({ + options.warnings = options.warnings; + options.assertions = options.assertions; + }) ]; extraOpts = { verbose = mkEnableOption "verbose logging mode for prometheus-wireguard-exporter"; diff --git a/nixos/modules/services/monitoring/prometheus/exporters/zfs.nix b/nixos/modules/services/monitoring/prometheus/exporters/zfs.nix index a685b94b827f4a..40e11e65b18f0c 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters/zfs.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters/zfs.nix @@ -1,5 +1,10 @@ -{ config, lib, pkgs, options, ... }: - +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.prometheus.exporters.zfs; diff --git a/nixos/modules/services/monitoring/prometheus/pushgateway.nix b/nixos/modules/services/monitoring/prometheus/pushgateway.nix index ebc8b9d889dcbc..c86a3f84c952c5 100644 --- a/nixos/modules/services/monitoring/prometheus/pushgateway.nix +++ b/nixos/modules/services/monitoring/prometheus/pushgateway.nix @@ -1,9 +1,14 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.prometheus.pushgateway; cmdlineArgs = - opt "web.listen-address" cfg.web.listen-address + opt "web.listen-address" cfg.web.listen-address ++ opt "web.telemetry-path" cfg.web.telemetry-path ++ opt "web.external-url" cfg.web.external-url ++ opt "web.route-prefix" cfg.web.route-prefix @@ -13,9 +18,10 @@ let ++ opt "log.format" cfg.log.format ++ cfg.extraFlags; - opt = k : v : lib.optional (v != null) ''--${k}="${v}"''; + opt = k: v: lib.optional (v != null) ''--${k}="${v}"''; -in { +in +{ options = { services.prometheus.pushgateway = { enable = lib.mkEnableOption "Prometheus Pushgateway"; @@ -73,7 +79,15 @@ in { }; log.level = lib.mkOption { - type = lib.types.nullOr (lib.types.enum ["debug" "info" "warn" "error" "fatal"]); + type = lib.types.nullOr ( + lib.types.enum [ + "debug" + "info" + "warn" + "error" + "fatal" + ] + ); default = null; description = '' Only log messages with the given severity or above. @@ -95,7 +109,7 @@ in { extraFlags = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Extra commandline options when launching the Pushgateway. ''; @@ -135,18 +149,20 @@ in { { assertion = !lib.hasPrefix "/" cfg.stateDir; message = - "The option services.prometheus.pushgateway.stateDir" + - " shouldn't be an absolute directory." + - " It should be a directory relative to /var/lib."; + "The option services.prometheus.pushgateway.stateDir" + + " shouldn't be an absolute directory." + + " It should be a directory relative to /var/lib."; } ]; systemd.services.pushgateway = { wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + after = [ "network.target" ]; serviceConfig = { - ExecStart = "${cfg.package}/bin/pushgateway" + - lib.optionalString (lib.length cmdlineArgs != 0) (" \\\n " + - lib.concatStringsSep " \\\n " cmdlineArgs); + ExecStart = + "${cfg.package}/bin/pushgateway" + + lib.optionalString (lib.length cmdlineArgs != 0) ( + " \\\n " + lib.concatStringsSep " \\\n " cmdlineArgs + ); CapabilityBoundingSet = [ "" ]; DeviceAllow = [ "" ]; @@ -174,9 +190,12 @@ in { ProtectKernelLogs = true; ProtectControlGroups = true; - Restart = "always"; + Restart = "always"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; diff --git a/nixos/modules/services/monitoring/prometheus/sachet.nix b/nixos/modules/services/monitoring/prometheus/sachet.nix index bc1416308f16fe..799a6859a7e73f 100644 --- a/nixos/modules/services/monitoring/prometheus/sachet.nix +++ b/nixos/modules/services/monitoring/prometheus/sachet.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.prometheus.sachet; configFile = pkgs.writeText "sachet.yml" (builtins.toJSON cfg.configuration); @@ -61,7 +66,10 @@ in systemd.services.sachet = { wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "network-online.target" ]; + after = [ + "network.target" + "network-online.target" + ]; script = '' ${pkgs.envsubst}/bin/envsubst -i "${configFile}" > /tmp/sachet.yaml exec ${pkgs.prometheus-sachet}/bin/sachet -config /tmp/sachet.yaml -listen-address ${cfg.address}:${builtins.toString cfg.port} diff --git a/nixos/modules/services/monitoring/prometheus/xmpp-alerts.nix b/nixos/modules/services/monitoring/prometheus/xmpp-alerts.nix index 2e367e47cc61a0..4e726b8b56402d 100644 --- a/nixos/modules/services/monitoring/prometheus/xmpp-alerts.nix +++ b/nixos/modules/services/monitoring/prometheus/xmpp-alerts.nix @@ -1,14 +1,20 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.prometheus.xmpp-alerts; - settingsFormat = pkgs.formats.yaml {}; + settingsFormat = pkgs.formats.yaml { }; configFile = settingsFormat.generate "prometheus-xmpp-alerts.yml" cfg.settings; in { imports = [ (lib.mkRenamedOptionModule [ "services" "prometheus" "xmpp-alerts" "configuration" ] - [ "services" "prometheus" "xmpp-alerts" "settings" ]) + [ "services" "prometheus" "xmpp-alerts" "settings" ] + ) ]; options.services.prometheus.xmpp-alerts = { @@ -16,7 +22,7 @@ in settings = lib.mkOption { type = settingsFormat.type; - default = {}; + default = { }; description = '' Configuration for prometheus xmpp-alerts, see @@ -44,7 +50,10 @@ in ProtectControlGroups = true; NoNewPrivileges = true; SystemCallArchitectures = "native"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; SystemCallFilter = [ "@system-service" ]; }; }; diff --git a/nixos/modules/services/monitoring/riemann-dash.nix b/nixos/modules/services/monitoring/riemann-dash.nix index 47db86035e4023..1a713ab7e72ff4 100644 --- a/nixos/modules/services/monitoring/riemann-dash.nix +++ b/nixos/modules/services/monitoring/riemann-dash.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.riemann-dash; @@ -14,7 +19,8 @@ let exec ${pkgs.riemann-dash}/bin/riemann-dash ${conf} ''; -in { +in +{ options = { diff --git a/nixos/modules/services/monitoring/riemann-tools.nix b/nixos/modules/services/monitoring/riemann-tools.nix index fc15dcf8534474..5fd7dd9082b307 100644 --- a/nixos/modules/services/monitoring/riemann-tools.nix +++ b/nixos/modules/services/monitoring/riemann-tools.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.riemann-tools; @@ -10,8 +15,8 @@ let exec ${pkgs.riemann-tools}/bin/riemann-health ${builtins.concatStringsSep " " cfg.extraArgs} --host ${riemannHost} ''; - -in { +in +{ options = { @@ -32,12 +37,16 @@ in { }; extraArgs = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' A list of commandline-switches forwarded to a riemann-tool. See for example `riemann-health --help` for available options. ''; - example = ["-p 5555" "--timeout=30" "--attribute=myattribute=42"]; + example = [ + "-p 5555" + "--timeout=30" + "--attribute=myattribute=42" + ]; }; }; }; diff --git a/nixos/modules/services/monitoring/riemann.nix b/nixos/modules/services/monitoring/riemann.nix index 97ae9e2211af30..84e522307a5f2d 100644 --- a/nixos/modules/services/monitoring/riemann.nix +++ b/nixos/modules/services/monitoring/riemann.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.riemann; @@ -8,7 +13,7 @@ let ); riemannConfig = lib.concatStringsSep "\n" ( - [cfg.config] ++ (map (f: ''(load-file "${f}")'') cfg.configFiles) + [ cfg.config ] ++ (map (f: ''(load-file "${f}")'') cfg.configFiles) ); launcher = pkgs.writeScriptBin "riemann" '' @@ -18,7 +23,8 @@ let riemann.bin ${cfg.configFile} ''; -in { +in +{ options = { @@ -34,7 +40,7 @@ in { }; configFiles = lib.mkOption { type = with lib.types; listOf path; - default = []; + default = [ ]; description = '' Extra files containing Riemann configuration. These files will be loaded at runtime by Riemann (with Clojure's @@ -52,14 +58,14 @@ in { }; extraClasspathEntries = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; description = '' Extra entries added to the Java classpath when running Riemann. ''; }; extraJavaOpts = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; description = '' Extra Java options used when launching Riemann. ''; @@ -77,9 +83,7 @@ in { group = "riemann"; }; - services.riemann.configFile = lib.mkDefault ( - pkgs.writeText "riemann-config.clj" riemannConfig - ); + services.riemann.configFile = lib.mkDefault (pkgs.writeText "riemann-config.clj" riemannConfig); systemd.services.riemann = { wantedBy = [ "multi-user.target" ]; diff --git a/nixos/modules/services/monitoring/rustdesk-server.nix b/nixos/modules/services/monitoring/rustdesk-server.nix index 10495ee0618de2..695000495cc680 100644 --- a/nixos/modules/services/monitoring/rustdesk-server.nix +++ b/nixos/modules/services/monitoring/rustdesk-server.nix @@ -1,142 +1,185 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: let - TCPPorts = [21115 21116 21117 21118 21119]; - UDPPorts = [21116]; -in { + TCPPorts = [ + 21115 + 21116 + 21117 + 21118 + 21119 + ]; + UDPPorts = [ 21116 ]; +in +{ imports = [ - (lib.mkRemovedOptionModule [ "services" "rustdesk-server" "relayIP" ] "This option has been replaced by services.rustdesk-server.signal.relayHosts") - (lib.mkRenamedOptionModule [ "services" "rustdesk-server" "extraRelayArgs" ] [ "services" "rustdesk-server" "relay" "extraArgs" ]) - (lib.mkRenamedOptionModule [ "services" "rustdesk-server" "extraSignalArgs" ] [ "services" "rustdesk-server" "signal" "extraArgs" ]) + (lib.mkRemovedOptionModule [ + "services" + "rustdesk-server" + "relayIP" + ] "This option has been replaced by services.rustdesk-server.signal.relayHosts") + (lib.mkRenamedOptionModule + [ "services" "rustdesk-server" "extraRelayArgs" ] + [ "services" "rustdesk-server" "relay" "extraArgs" ] + ) + (lib.mkRenamedOptionModule + [ "services" "rustdesk-server" "extraSignalArgs" ] + [ "services" "rustdesk-server" "signal" "extraArgs" ] + ) ]; - options.services.rustdesk-server = with lib; with types; { - enable = mkEnableOption "RustDesk, a remote access and remote control software, allowing maintenance of computers and other devices"; - - package = mkPackageOption pkgs "rustdesk-server" {}; + options.services.rustdesk-server = + with lib; + with types; + { + enable = mkEnableOption "RustDesk, a remote access and remote control software, allowing maintenance of computers and other devices"; - openFirewall = mkOption { - type = types.bool; - default = false; - description = '' - Open the connection ports. - TCP (${lib.concatStringsSep ", " (map toString TCPPorts)}) - UDP (${lib.concatStringsSep ", " (map toString UDPPorts)}) - ''; - }; + package = mkPackageOption pkgs "rustdesk-server" { }; - signal = { - enable = mkOption { - type = bool; - default = true; + openFirewall = mkOption { + type = types.bool; + default = false; description = '' - Whether to enable the RustDesk signal server. + Open the connection ports. + TCP (${lib.concatStringsSep ", " (map toString TCPPorts)}) + UDP (${lib.concatStringsSep ", " (map toString UDPPorts)}) ''; }; - relayHosts = mkOption { - type = listOf str; - default = []; - # reference: https://rustdesk.com/docs/en/self-host/rustdesk-server-pro/relay/ - description = '' - The relay server IP addresses or DNS names of the RustDesk relay. - ''; + signal = { + enable = mkOption { + type = bool; + default = true; + description = '' + Whether to enable the RustDesk signal server. + ''; + }; + + relayHosts = mkOption { + type = listOf str; + default = [ ]; + # reference: https://rustdesk.com/docs/en/self-host/rustdesk-server-pro/relay/ + description = '' + The relay server IP addresses or DNS names of the RustDesk relay. + ''; + }; + + extraArgs = mkOption { + type = listOf str; + default = [ ]; + example = [ + "-k" + "_" + ]; + description = '' + A list of extra command line arguments to pass to the `hbbs` process. + ''; + }; + }; - extraArgs = mkOption { - type = listOf str; - default = []; - example = [ "-k" "_" ]; - description = '' - A list of extra command line arguments to pass to the `hbbs` process. - ''; + relay = { + enable = mkOption { + type = bool; + default = true; + description = '' + Whether to enable the RustDesk relay server. + ''; + }; + extraArgs = mkOption { + type = listOf str; + default = [ ]; + example = [ + "-k" + "_" + ]; + description = '' + A list of extra command line arguments to pass to the `hbbr` process. + ''; + }; }; }; - relay = { - enable = mkOption { - type = bool; - default = true; - description = '' - Whether to enable the RustDesk relay server. - ''; + config = + let + cfg = config.services.rustdesk-server; + serviceDefaults = { + enable = true; + requiredBy = [ "rustdesk.target" ]; + serviceConfig = { + Slice = "system-rustdesk.slice"; + User = "rustdesk"; + Group = "rustdesk"; + DynamicUser = "yes"; + Environment = [ ]; + WorkingDirectory = "/var/lib/rustdesk"; + StateDirectory = "rustdesk"; + StateDirectoryMode = "0750"; + LockPersonality = true; + PrivateDevices = true; + PrivateMounts = true; + PrivateUsers = true; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + RestrictNamespaces = true; + }; }; - extraArgs = mkOption { - type = listOf str; - default = []; - example = [ "-k" "_" ]; - description = '' - A list of extra command line arguments to pass to the `hbbr` process. - ''; + in + lib.mkIf cfg.enable { + users.users.rustdesk = { + description = "System user for RustDesk"; + isSystemUser = true; + group = "rustdesk"; }; - }; + users.groups.rustdesk = { }; - }; - - config = let - cfg = config.services.rustdesk-server; - serviceDefaults = { - enable = true; - requiredBy = [ "rustdesk.target" ]; - serviceConfig = { - Slice = "system-rustdesk.slice"; - User = "rustdesk"; - Group = "rustdesk"; - DynamicUser = "yes"; - Environment = []; - WorkingDirectory = "/var/lib/rustdesk"; - StateDirectory = "rustdesk"; - StateDirectoryMode = "0750"; - LockPersonality = true; - PrivateDevices = true; - PrivateMounts = true; - PrivateUsers = true; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - RestrictNamespaces = true; - }; - }; - in lib.mkIf cfg.enable { - users.users.rustdesk = { - description = "System user for RustDesk"; - isSystemUser = true; - group = "rustdesk"; - }; - users.groups.rustdesk = {}; + networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall TCPPorts; + networking.firewall.allowedUDPPorts = lib.mkIf cfg.openFirewall UDPPorts; - networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall TCPPorts; - networking.firewall.allowedUDPPorts = lib.mkIf cfg.openFirewall UDPPorts; + systemd.slices.system-rustdesk = { + enable = true; + description = "RustDesk Remote Desktop Slice"; + }; - systemd.slices.system-rustdesk = { - enable = true; - description = "RustDesk Remote Desktop Slice"; - }; + systemd.targets.rustdesk = { + enable = true; + description = "Target designed to group RustDesk Signal & RustDesk Relay"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + }; - systemd.targets.rustdesk = { - enable = true; - description = "Target designed to group RustDesk Signal & RustDesk Relay"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; + systemd.services.rustdesk-signal = + let + relayArg = builtins.concatStringsSep ":" cfg.signal.relayHosts; + in + lib.mkIf cfg.signal.enable ( + lib.mkMerge [ + serviceDefaults + { + serviceConfig.ExecStart = "${cfg.package}/bin/hbbs --relay-servers ${relayArg} ${lib.escapeShellArgs cfg.signal.extraArgs}"; + } + ] + ); + + systemd.services.rustdesk-relay = lib.mkIf cfg.relay.enable ( + lib.mkMerge [ + serviceDefaults + { + serviceConfig.ExecStart = "${cfg.package}/bin/hbbr ${lib.escapeShellArgs cfg.relay.extraArgs}"; + } + ] + ); }; - systemd.services.rustdesk-signal = - let - relayArg = builtins.concatStringsSep ":" cfg.signal.relayHosts; - in - lib.mkIf cfg.signal.enable (lib.mkMerge [ serviceDefaults { - serviceConfig.ExecStart = "${cfg.package}/bin/hbbs --relay-servers ${relayArg} ${lib.escapeShellArgs cfg.signal.extraArgs}"; - } ]); - - systemd.services.rustdesk-relay = lib.mkIf cfg.relay.enable (lib.mkMerge [ serviceDefaults { - serviceConfig.ExecStart = "${cfg.package}/bin/hbbr ${lib.escapeShellArgs cfg.relay.extraArgs}"; - } ]); - }; - meta.maintainers = with lib.maintainers; [ ppom ]; } diff --git a/nixos/modules/services/monitoring/scollector.nix b/nixos/modules/services/monitoring/scollector.nix index 19625e057436bb..9ebf852e4a77c7 100644 --- a/nixos/modules/services/monitoring/scollector.nix +++ b/nixos/modules/services/monitoring/scollector.nix @@ -1,21 +1,24 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.scollector; - collectors = pkgs.runCommand "collectors" { preferLocalBuild = true; } - '' + collectors = pkgs.runCommand "collectors" { preferLocalBuild = true; } '' mkdir -p $out - ${lib.concatStringsSep - "\n" - (lib.mapAttrsToList - (frequency: binaries: - "mkdir -p $out/${frequency}\n" + - (lib.concatStringsSep - "\n" - (map (path: "ln -s ${path} $out/${frequency}/$(basename ${path})") - binaries))) - cfg.collectors)} - ''; + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList ( + frequency: binaries: + "mkdir -p $out/${frequency}\n" + + (lib.concatStringsSep "\n" ( + map (path: "ln -s ${path} $out/${frequency}/$(basename ${path})") binaries + )) + ) cfg.collectors + )} + ''; conf = pkgs.writeText "scollector.toml" '' Host = "${cfg.bosunHost}" @@ -23,7 +26,8 @@ let ${cfg.extraConfig} ''; -in { +in +{ options = { @@ -66,7 +70,7 @@ in { collectors = lib.mkOption { type = with lib.types; attrsOf (listOf path); - default = {}; + default = { }; example = lib.literalExpression ''{ "0" = [ "''${postgresStats}/bin/collect-stats" ]; }''; description = '' An attribute set mapping the frequency of collection to a list of @@ -77,7 +81,7 @@ in { extraOpts = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; example = [ "-d" ]; description = '' Extra scollector command line options @@ -102,7 +106,10 @@ in { description = "scollector metrics collector (part of Bosun)"; wantedBy = [ "multi-user.target" ]; - path = [ pkgs.coreutils pkgs.iproute2 ]; + path = [ + pkgs.coreutils + pkgs.iproute2 + ]; serviceConfig = { User = cfg.user; diff --git a/nixos/modules/services/monitoring/smartd.nix b/nixos/modules/services/monitoring/smartd.nix index 2cb5897f5d4c03..388b0829f74257 100644 --- a/nixos/modules/services/monitoring/smartd.nix +++ b/nixos/modules/services/monitoring/smartd.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let host = config.networking.fqdnOrHostName; @@ -55,8 +61,9 @@ let ''} ''; - notifyOpts = lib.optionalString (nm.enable || nw.enable || nx.enable) - ("-m -M exec ${smartdNotify} " + lib.optionalString cfg.notifications.test "-M test "); + notifyOpts = lib.optionalString (nm.enable || nw.enable || nx.enable) ( + "-m -M exec ${smartdNotify} " + lib.optionalString cfg.notifications.test "-M test " + ); smartdConf = pkgs.writeText "smartd.conf" '' # Autogenerated smartd startup config file @@ -64,31 +71,32 @@ let ${lib.concatMapStringsSep "\n" (d: "${d.device} ${d.options}") cfg.devices} - ${lib.optionalString cfg.autodetect - "DEVICESCAN ${notifyOpts}${cfg.defaults.autodetected}"} + ${lib.optionalString cfg.autodetect "DEVICESCAN ${notifyOpts}${cfg.defaults.autodetected}"} ''; - smartdDeviceOpts = { ... }: { + smartdDeviceOpts = + { ... }: + { - options = { + options = { - device = lib.mkOption { - example = "/dev/sda"; - type = lib.types.str; - description = "Location of the device."; - }; + device = lib.mkOption { + example = "/dev/sda"; + type = lib.types.str; + description = "Location of the device."; + }; + + options = lib.mkOption { + default = ""; + example = "-d sat"; + type = lib.types.separatedString " "; + description = "Options that determine how smartd monitors the device."; + }; - options = lib.mkOption { - default = ""; - example = "-d sat"; - type = lib.types.separatedString " "; - description = "Options that determine how smartd monitors the device."; }; }; - }; - in { @@ -113,9 +121,12 @@ in }; extraOptions = lib.mkOption { - default = []; + default = [ ]; type = lib.types.listOf lib.types.str; - example = ["-A /var/log/smartd/" "--interval=3600"]; + example = [ + "-A /var/log/smartd/" + "--interval=3600" + ]; description = '' Extra command-line options passed to the `smartd` daemon on startup. @@ -243,8 +254,14 @@ in }; devices = lib.mkOption { - default = []; - example = [ { device = "/dev/sda"; } { device = "/dev/sdb"; options = "-d sat"; } ]; + default = [ ]; + example = [ + { device = "/dev/sda"; } + { + device = "/dev/sdb"; + options = "-d sat"; + } + ]; type = with lib.types; listOf (submodule smartdDeviceOpts); description = "List of devices to monitor."; }; @@ -253,15 +270,16 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { - assertions = [ { - assertion = cfg.autodetect || cfg.devices != []; - message = "smartd can't run with both disabled autodetect and an empty list of devices to monitor."; - } ]; + assertions = [ + { + assertion = cfg.autodetect || cfg.devices != [ ]; + message = "smartd can't run with both disabled autodetect and an empty list of devices to monitor."; + } + ]; systemd.services.smartd = { description = "S.M.A.R.T. Daemon"; diff --git a/nixos/modules/services/monitoring/snmpd.nix b/nixos/modules/services/monitoring/snmpd.nix index bff9ce3fbc88bc..b4e0d4f8aeb276 100644 --- a/nixos/modules/services/monitoring/snmpd.nix +++ b/nixos/modules/services/monitoring/snmpd.nix @@ -1,16 +1,25 @@ -{ pkgs, config, lib, ... }: +{ + pkgs, + config, + lib, + ... +}: let cfg = config.services.snmpd; - configFile = if cfg.configText != "" then - pkgs.writeText "snmpd.cfg" '' - ${cfg.configText} - '' else null; -in { + configFile = + if cfg.configText != "" then + pkgs.writeText "snmpd.cfg" '' + ${cfg.configText} + '' + else + null; +in +{ options.services.snmpd = { enable = lib.mkEnableOption "snmpd"; - package = lib.mkPackageOption pkgs "net-snmp" {}; + package = lib.mkPackageOption pkgs "net-snmp" { }; listenAddress = lib.mkOption { type = lib.types.str; diff --git a/nixos/modules/services/monitoring/statsd.nix b/nixos/modules/services/monitoring/statsd.nix index e0bd332e2418ab..43462a95ccae73 100644 --- a/nixos/modules/services/monitoring/statsd.nix +++ b/nixos/modules/services/monitoring/statsd.nix @@ -1,16 +1,26 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.statsd; - isBuiltinBackend = name: - builtins.elem name [ "graphite" "console" "repeater" ]; + isBuiltinBackend = + name: + builtins.elem name [ + "graphite" + "console" + "repeater" + ]; - backendsToPackages = let - mkMap = list: name: - if isBuiltinBackend name then list - else list ++ [ pkgs.nodePackages.${name} ]; - in lib.foldl mkMap []; + backendsToPackages = + let + mkMap = list: name: if isBuiltinBackend name then list else list ++ [ pkgs.nodePackages.${name} ]; + in + lib.foldl mkMap [ ]; configFile = pkgs.writeText "statsd.conf" '' { @@ -19,13 +29,12 @@ let mgmt_address: "${cfg.mgmt_address}", mgmt_port: "${toString cfg.mgmt_port}", backends: [${ - lib.concatMapStringsSep "," (name: - if (isBuiltinBackend name) - then ''"./backends/${name}"'' - else ''"${name}"'' - ) cfg.backends}], - ${lib.optionalString (cfg.graphiteHost!=null) ''graphiteHost: "${cfg.graphiteHost}",''} - ${lib.optionalString (cfg.graphitePort!=null) ''graphitePort: "${toString cfg.graphitePort}",''} + lib.concatMapStringsSep "," ( + name: if (isBuiltinBackend name) then ''"./backends/${name}"'' else ''"${name}"'' + ) cfg.backends + }], + ${lib.optionalString (cfg.graphiteHost != null) ''graphiteHost: "${cfg.graphiteHost}",''} + ${lib.optionalString (cfg.graphitePort != null) ''graphitePort: "${toString cfg.graphitePort}",''} console: { prettyprint: false }, @@ -81,7 +90,7 @@ in backends = lib.mkOption { description = "List of backends statsd will use for data persistence"; - default = []; + default = [ ]; example = [ "graphite" "console" diff --git a/nixos/modules/services/monitoring/sysstat.nix b/nixos/modules/services/monitoring/sysstat.nix index ca674defd65eee..d4a702aad1678a 100644 --- a/nixos/modules/services/monitoring/sysstat.nix +++ b/nixos/modules/services/monitoring/sysstat.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.sysstat; -in { +in +{ options = { services.sysstat = { enable = lib.mkEnableOption "sar system activity collection"; diff --git a/nixos/modules/services/monitoring/teamviewer.nix b/nixos/modules/services/monitoring/teamviewer.nix index 45bb45a53c1b09..e7e86ff84ff886 100644 --- a/nixos/modules/services/monitoring/teamviewer.nix +++ b/nixos/modules/services/monitoring/teamviewer.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.teamviewer; diff --git a/nixos/modules/services/monitoring/telegraf.nix b/nixos/modules/services/monitoring/telegraf.nix index 06339269b42776..bcdd2ece571848 100644 --- a/nixos/modules/services/monitoring/telegraf.nix +++ b/nixos/modules/services/monitoring/telegraf.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.telegraf; - settingsFormat = pkgs.formats.toml {}; + settingsFormat = pkgs.formats.toml { }; configFile = settingsFormat.generate "config.toml" cfg.extraConfig; -in { +in +{ ###### interface options = { services.telegraf = { @@ -14,7 +20,7 @@ in { environmentFiles = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; example = [ "/run/keys/telegraf.env" ]; description = '' File to load as environment file. Environment variables from this file @@ -25,12 +31,12 @@ in { }; extraConfig = lib.mkOption { - default = {}; + default = { }; description = "Extra configuration options for telegraf"; type = settingsFormat.type; example = { outputs.influxdb = { - urls = ["http://localhost:8086"]; + urls = [ "http://localhost:8086" ]; database = "telegraf"; }; inputs.statsd = { @@ -42,41 +48,46 @@ in { }; }; - ###### implementation config = lib.mkIf config.services.telegraf.enable { services.telegraf.extraConfig = { - inputs = {}; - outputs = {}; + inputs = { }; + outputs = { }; }; - systemd.services.telegraf = let - finalConfigFile = if config.services.telegraf.environmentFiles == [] - then configFile - else "/var/run/telegraf/config.toml"; - in { - description = "Telegraf Agent"; - wantedBy = [ "multi-user.target" ]; - wants = [ "network-online.target" ]; - after = [ "network-online.target" ]; - path = lib.optional (config.services.telegraf.extraConfig.inputs ? procstat) pkgs.procps - ++ lib.optional (config.services.telegraf.extraConfig.inputs ? ping) pkgs.iputils; - serviceConfig = { - EnvironmentFile = config.services.telegraf.environmentFiles; - ExecStartPre = lib.optional (config.services.telegraf.environmentFiles != []) - (pkgs.writeShellScript "pre-start" '' - umask 077 - ${pkgs.envsubst}/bin/envsubst -i "${configFile}" > /var/run/telegraf/config.toml - ''); - ExecStart="${cfg.package}/bin/telegraf -config ${finalConfigFile}"; - ExecReload="${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - RuntimeDirectory = "telegraf"; - User = "telegraf"; - Group = "telegraf"; - Restart = "on-failure"; - # for ping probes - AmbientCapabilities = [ "CAP_NET_RAW" ]; + systemd.services.telegraf = + let + finalConfigFile = + if config.services.telegraf.environmentFiles == [ ] then + configFile + else + "/var/run/telegraf/config.toml"; + in + { + description = "Telegraf Agent"; + wantedBy = [ "multi-user.target" ]; + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; + path = + lib.optional (config.services.telegraf.extraConfig.inputs ? procstat) pkgs.procps + ++ lib.optional (config.services.telegraf.extraConfig.inputs ? ping) pkgs.iputils; + serviceConfig = { + EnvironmentFile = config.services.telegraf.environmentFiles; + ExecStartPre = lib.optional (config.services.telegraf.environmentFiles != [ ]) ( + pkgs.writeShellScript "pre-start" '' + umask 077 + ${pkgs.envsubst}/bin/envsubst -i "${configFile}" > /var/run/telegraf/config.toml + '' + ); + ExecStart = "${cfg.package}/bin/telegraf -config ${finalConfigFile}"; + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + RuntimeDirectory = "telegraf"; + User = "telegraf"; + Group = "telegraf"; + Restart = "on-failure"; + # for ping probes + AmbientCapabilities = [ "CAP_NET_RAW" ]; + }; }; - }; users.users.telegraf = { uid = config.ids.uids.telegraf; @@ -84,6 +95,6 @@ in { description = "telegraf daemon user"; }; - users.groups.telegraf = {}; + users.groups.telegraf = { }; }; } diff --git a/nixos/modules/services/monitoring/tremor-rs.nix b/nixos/modules/services/monitoring/tremor-rs.nix index ebd27771c2393d..1797062e876c06 100644 --- a/nixos/modules/services/monitoring/tremor-rs.nix +++ b/nixos/modules/services/monitoring/tremor-rs.nix @@ -1,11 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.tremor-rs; loggerSettingsFormat = pkgs.formats.yaml { }; loggerConfigFile = loggerSettingsFormat.generate "logger.yaml" cfg.loggerSettings; -in { +in +{ options = { services.tremor-rs = { @@ -13,7 +19,7 @@ in { troyFileList = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; description = "List of troy files to load."; }; @@ -37,7 +43,7 @@ in { loggerSettings = lib.mkOption { description = "Tremor logger configuration"; - default = {}; + default = { }; type = loggerSettingsFormat.type; example = { @@ -90,7 +96,7 @@ in { config = lib.mkIf (cfg.enable) { - environment.systemPackages = [ pkgs.tremor-rs ] ; + environment.systemPackages = [ pkgs.tremor-rs ]; systemd.services.tremor-rs = { description = "Tremor event- or stream-processing system"; @@ -120,7 +126,10 @@ in { RestrictNamespaces = true; LockPersonality = true; RemoveIPC = true; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; }; }; }; diff --git a/nixos/modules/services/monitoring/tuptime.nix b/nixos/modules/services/monitoring/tuptime.nix index 07ada853760b4c..58094a1851825c 100644 --- a/nixos/modules/services/monitoring/tuptime.nix +++ b/nixos/modules/services/monitoring/tuptime.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.tuptime; -in { +in +{ options.services.tuptime = { @@ -24,7 +30,6 @@ in { }; }; - config = lib.mkIf cfg.enable { environment.systemPackages = [ pkgs.tuptime ]; @@ -70,7 +75,10 @@ in { description = "Tuptime scheduled sync timer"; # this timer should be started if the service is started # even if the timer was previously stopped - wantedBy = [ "tuptime.service" "timers.target" ]; + wantedBy = [ + "tuptime.service" + "timers.target" + ]; # this timer should be stopped if the service is stopped partOf = [ "tuptime.service" ]; timerConfig = { diff --git a/nixos/modules/services/monitoring/unpoller.nix b/nixos/modules/services/monitoring/unpoller.nix index 1cdd8a78ea8ffe..514afb2fe8b27e 100644 --- a/nixos/modules/services/monitoring/unpoller.nix +++ b/nixos/modules/services/monitoring/unpoller.nix @@ -1,12 +1,26 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.unpoller; - configFile = pkgs.writeText "unpoller.json" (lib.generators.toJSON {} { - inherit (cfg) poller influxdb loki prometheus unifi; - }); + configFile = pkgs.writeText "unpoller.json" ( + lib.generators.toJSON { } { + inherit (cfg) + poller + influxdb + loki + prometheus + unifi + ; + } + ); -in { +in +{ imports = [ (lib.mkRenamedOptionModule [ "services" "unifi-poller" ] [ "services" "unpoller" ]) ]; @@ -32,7 +46,7 @@ in { }; plugins = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; description = '' Load additional plugins. ''; @@ -174,122 +188,133 @@ in { }; }; - unifi = let - controllerOptions = { - user = lib.mkOption { - type = lib.types.str; - default = "unifi"; - description = '' - Unifi service user name. - ''; - }; - pass = lib.mkOption { - type = lib.types.path; - default = pkgs.writeText "unpoller-unifi-default.password" "unifi"; - defaultText = lib.literalExpression "unpoller-unifi-default.password"; - description = '' - Path of a file containing the password for the unifi service user. - This file needs to be readable by the unifi-poller user. - ''; - apply = v: "file://${v}"; - }; - url = lib.mkOption { - type = lib.types.str; - default = "https://unifi:8443"; - description = '' - URL of the Unifi controller. - ''; - }; - sites = lib.mkOption { - type = with lib.types; either (enum [ "default" "all" ]) (listOf str); - default = "all"; - description = '' - List of site names for which statistics should be exported. - Or the string "default" for the default site or the string "all" for all sites. - ''; - apply = lib.toList; - }; - save_ids = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Collect and save data from the intrusion detection system to influxdb and Loki. - ''; - }; - save_events = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Collect and save data from UniFi events to influxdb and Loki. - ''; - }; - save_alarms = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Collect and save data from UniFi alarms to influxdb and Loki. - ''; - }; - save_anomalies = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Collect and save data from UniFi anomalies to influxdb and Loki. - ''; - }; - save_dpi = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Collect and save data from deep packet inspection. - Adds around 150 data points and impacts performance. - ''; + unifi = + let + controllerOptions = { + user = lib.mkOption { + type = lib.types.str; + default = "unifi"; + description = '' + Unifi service user name. + ''; + }; + pass = lib.mkOption { + type = lib.types.path; + default = pkgs.writeText "unpoller-unifi-default.password" "unifi"; + defaultText = lib.literalExpression "unpoller-unifi-default.password"; + description = '' + Path of a file containing the password for the unifi service user. + This file needs to be readable by the unifi-poller user. + ''; + apply = v: "file://${v}"; + }; + url = lib.mkOption { + type = lib.types.str; + default = "https://unifi:8443"; + description = '' + URL of the Unifi controller. + ''; + }; + sites = lib.mkOption { + type = + with lib.types; + either (enum [ + "default" + "all" + ]) (listOf str); + default = "all"; + description = '' + List of site names for which statistics should be exported. + Or the string "default" for the default site or the string "all" for all sites. + ''; + apply = lib.toList; + }; + save_ids = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Collect and save data from the intrusion detection system to influxdb and Loki. + ''; + }; + save_events = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Collect and save data from UniFi events to influxdb and Loki. + ''; + }; + save_alarms = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Collect and save data from UniFi alarms to influxdb and Loki. + ''; + }; + save_anomalies = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Collect and save data from UniFi anomalies to influxdb and Loki. + ''; + }; + save_dpi = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Collect and save data from deep packet inspection. + Adds around 150 data points and impacts performance. + ''; + }; + save_sites = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Collect and save site data. + ''; + }; + hash_pii = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Hash, with md5, client names and MAC addresses. This attempts + to protect personally identifiable information. + ''; + }; + verify_ssl = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Verify the Unifi controller's certificate. + ''; + }; }; - save_sites = lib.mkOption { - type = lib.types.bool; - default = true; - description = '' - Collect and save site data. - ''; - }; - hash_pii = lib.mkOption { + + in + { + dynamic = lib.mkOption { type = lib.types.bool; default = false; description = '' - Hash, with md5, client names and MAC addresses. This attempts - to protect personally identifiable information. + Let prometheus select which controller to poll when scraping. + Use with default credentials. See unifi-poller wiki for more. ''; }; - verify_ssl = lib.mkOption { - type = lib.types.bool; - default = true; + + defaults = controllerOptions; + + controllers = lib.mkOption { + type = + with lib.types; + listOf (submodule { + options = controllerOptions; + }); + default = [ ]; description = '' - Verify the Unifi controller's certificate. + List of Unifi controllers to poll. Use defaults if empty. ''; + apply = map (lib.flip removeAttrs [ "_module" ]); }; }; - - in { - dynamic = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Let prometheus select which controller to poll when scraping. - Use with default credentials. See unifi-poller wiki for more. - ''; - }; - - defaults = controllerOptions; - - controllers = lib.mkOption { - type = with lib.types; listOf (submodule { options = controllerOptions; }); - default = []; - description = '' - List of Unifi controllers to poll. Use defaults if empty. - ''; - apply = map (lib.flip removeAttrs [ "_module" ]); - }; - }; }; config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/monitoring/uptime-kuma.nix b/nixos/modules/services/monitoring/uptime-kuma.nix index 0dd636fe1cc328..3b15cb80a86120 100644 --- a/nixos/modules/services/monitoring/uptime-kuma.nix +++ b/nixos/modules/services/monitoring/uptime-kuma.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.uptime-kuma; in @@ -69,14 +74,18 @@ in ProtectProc = "noaccess"; ProtectSystem = "strict"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" "AF_NETLINK" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + "AF_NETLINK" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - UMask = 027; + UMask = 27; }; }; }; } - diff --git a/nixos/modules/services/monitoring/uptime.nix b/nixos/modules/services/monitoring/uptime.nix index 79b86be6cc7155..c7c77d6a09e12a 100644 --- a/nixos/modules/services/monitoring/uptime.nix +++ b/nixos/modules/services/monitoring/uptime.nix @@ -1,29 +1,48 @@ -{ config, options, pkgs, lib, ... }: +{ + config, + options, + pkgs, + lib, + ... +}: let - inherit (lib) literalExpression mkOption mkEnableOption mkIf mkMerge types optional; + inherit (lib) + literalExpression + mkOption + mkEnableOption + mkIf + mkMerge + types + optional + ; cfg = config.services.uptime; opt = options.services.uptime; - configDir = pkgs.runCommand "config" { preferLocalBuild = true; } - (if cfg.configFile != null then '' - mkdir $out - ext=`echo ${cfg.configFile} | grep -o \\..*` - ln -sv ${cfg.configFile} $out/default$ext - ln -sv /var/lib/uptime/runtime.json $out/runtime.json - '' else '' - mkdir $out - cat ${pkgs.nodePackages.node-uptime}/lib/node_modules/node-uptime/config/default.yaml > $out/default.yaml - cat >> $out/default.yaml < $out/default.yaml + cat >> $out/default.yaml < @@ -115,7 +137,7 @@ in { CacheDirectory = "vmagent"; ExecStart = lib.escapeShellArgs ( startCLIList - ++ lib.optionals (cfg.prometheusConfig != {}) ["-promscrape.config=${prometheusConfigYml}"] + ++ lib.optionals (cfg.prometheusConfig != { }) [ "-promscrape.config=${prometheusConfigYml}" ] ); LoadCredential = lib.optional (cfg.remoteWrite.basicAuthPasswordFile != null) [ "remote_write_basic_auth_password:${cfg.remoteWrite.basicAuthPasswordFile}" diff --git a/nixos/modules/services/monitoring/vmalert.nix b/nixos/modules/services/monitoring/vmalert.nix index 14fdfbbda29acb..438d067643fba3 100644 --- a/nixos/modules/services/monitoring/vmalert.nix +++ b/nixos/modules/services/monitoring/vmalert.nix @@ -1,21 +1,38 @@ -{ config, pkgs, lib, ... }: with lib; +{ + config, + pkgs, + lib, + ... +}: +with lib; let cfg = config.services.vmalert; - format = pkgs.formats.yaml {}; + format = pkgs.formats.yaml { }; - confOpts = concatStringsSep " \\\n" (mapAttrsToList mkLine (filterAttrs (_: v: v != false) cfg.settings)); - confType = with types; + confOpts = concatStringsSep " \\\n" ( + mapAttrsToList mkLine (filterAttrs (_: v: v != false) cfg.settings) + ); + confType = + with types; let - valueType = oneOf [ bool int path str ]; + valueType = oneOf [ + bool + int + path + str + ]; in attrsOf (either valueType (listOf valueType)); - mkLine = key: value: - if value == true then "-${key}" - else if isList value then concatMapStringsSep " " (v: "-${key}=${escapeShellArg (toString v)}") value - else "-${key}=${escapeShellArg (toString value)}" - ; + mkLine = + key: value: + if value == true then + "-${key}" + else if isList value then + concatMapStringsSep " " (v: "-${key}=${escapeShellArg (toString v)}") value + else + "-${key}=${escapeShellArg (toString value)}"; in { # interface @@ -47,7 +64,7 @@ in "notifier.url" = mkOption { type = with types; listOf nonEmptyStr; - default = []; + default = [ ]; example = [ "http://127.0.0.1:9093" ]; description = '' Prometheus Alertmanager URL. List all Alertmanager URLs if it runs in the cluster mode to ensure high availability. @@ -87,12 +104,14 @@ in rules = mkOption { type = format.type; - default = {}; + default = { }; example = { group = [ - { name = "TestGroup"; + { + name = "TestGroup"; rules = [ - { alert = "ExampleAlertAlwaysFiring"; + { + alert = "ExampleAlertAlwaysFiring"; expr = '' sum by(job) (up == 1) diff --git a/nixos/modules/services/monitoring/vnstat.nix b/nixos/modules/services/monitoring/vnstat.nix index afacb696420b06..958a46e8173083 100644 --- a/nixos/modules/services/monitoring/vnstat.nix +++ b/nixos/modules/services/monitoring/vnstat.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.vnstat; -in { +in +{ options.services.vnstat = { enable = lib.mkEnableOption "update of network usage statistics via vnstatd"; }; @@ -11,7 +17,7 @@ in { environment.systemPackages = [ pkgs.vnstat ]; users = { - groups.vnstatd = {}; + groups.vnstatd = { }; users.vnstatd = { isSystemUser = true; diff --git a/nixos/modules/services/monitoring/watchdogd.nix b/nixos/modules/services/monitoring/watchdogd.nix index f54d7aa80b18cf..1aa290a467cba4 100644 --- a/nixos/modules/services/monitoring/watchdogd.nix +++ b/nixos/modules/services/monitoring/watchdogd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.watchdogd; @@ -33,54 +38,59 @@ let ''; }; }; -in { +in +{ options.services.watchdogd = { enable = lib.mkEnableOption "watchdogd, an advanced system & process supervisor"; package = lib.mkPackageOption pkgs "watchdogd" { }; settings = lib.mkOption { - type = with lib.types; submodule { - freeformType = let - valueType = oneOf [ - bool - int - float - str - ]; - in attrsOf (either valueType (attrsOf valueType)); + type = + with lib.types; + submodule { + freeformType = + let + valueType = oneOf [ + bool + int + float + str + ]; + in + attrsOf (either valueType (attrsOf valueType)); - options = { - timeout = lib.mkOption { - type = types.ints.unsigned; - default = 15; - description = '' - The WDT timeout before reset. - ''; - }; - interval = lib.mkOption { - type = types.ints.unsigned; - default = 5; - description = '' - The kick interval, i.e. how often {manpage}`watchdogd(8)` should reset the WDT timer. - ''; - }; + options = { + timeout = lib.mkOption { + type = types.ints.unsigned; + default = 15; + description = '' + The WDT timeout before reset. + ''; + }; + interval = lib.mkOption { + type = types.ints.unsigned; + default = 5; + description = '' + The kick interval, i.e. how often {manpage}`watchdogd(8)` should reset the WDT timer. + ''; + }; - safe-exit = lib.mkOption { - type = types.bool; - default = true; - description = '' - With {var}`safeExit` enabled, the daemon will ask the driver to disable the WDT before exiting. - However, some WDT drivers (or hardware) may not support this. - ''; - }; + safe-exit = lib.mkOption { + type = types.bool; + default = true; + description = '' + With {var}`safeExit` enabled, the daemon will ask the driver to disable the WDT before exiting. + However, some WDT drivers (or hardware) may not support this. + ''; + }; - filenr = mkPluginOpts "filenr" 0.9 1.0; + filenr = mkPluginOpts "filenr" 0.9 1.0; - loadavg = mkPluginOpts "loadavg" 1.0 2.0; + loadavg = mkPluginOpts "loadavg" 1.0 2.0; - meminfo = mkPluginOpts "meminfo" 0.9 0.95; + meminfo = mkPluginOpts "meminfo" 0.9 0.95; + }; }; - }; default = { }; description = '' Configuration to put in {file}`watchdogd.conf`. @@ -89,42 +99,52 @@ in { }; }; - config = let - toConfig = attrs: lib.concatStringsSep "\n" (lib.mapAttrsToList toValue attrs); + config = + let + toConfig = attrs: lib.concatStringsSep "\n" (lib.mapAttrsToList toValue attrs); - toValue = name: value: - if lib.isAttrs value - then lib.pipe value [ - (lib.mapAttrsToList toValue) - (map (s: " ${s}")) - (lib.concatStringsSep "\n") - (s: "${name} {\n${s}\n}") - ] - else if lib.isBool value - then "${name} = ${lib.boolToString value}" - else if lib.any (f: f value) [lib.isString lib.isInt lib.isFloat] - then "${name} = ${toString value}" - else throw '' - Found invalid type in `services.watchdogd.settings`: '${lib.typeOf value}' - ''; + toValue = + name: value: + if lib.isAttrs value then + lib.pipe value [ + (lib.mapAttrsToList toValue) + (map (s: " ${s}")) + (lib.concatStringsSep "\n") + (s: "${name} {\n${s}\n}") + ] + else if lib.isBool value then + "${name} = ${lib.boolToString value}" + else if + lib.any (f: f value) [ + lib.isString + lib.isInt + lib.isFloat + ] + then + "${name} = ${toString value}" + else + throw '' + Found invalid type in `services.watchdogd.settings`: '${lib.typeOf value}' + ''; - watchdogdConf = pkgs.writeText "watchdogd.conf" (toConfig cfg.settings); - in lib.mkIf cfg.enable { - environment.systemPackages = [ cfg.package ]; + watchdogdConf = pkgs.writeText "watchdogd.conf" (toConfig cfg.settings); + in + lib.mkIf cfg.enable { + environment.systemPackages = [ cfg.package ]; - systemd.services.watchdogd = { - documentation = [ - "man:watchdogd(8)" - "man:watchdogd.conf(5)" - ]; - wantedBy = [ "multi-user.target" ]; - description = "Advanced system & process supervisor"; - serviceConfig = { - Type = "simple"; - ExecStart = "${cfg.package}/bin/watchdogd -n -f ${watchdogdConf}"; + systemd.services.watchdogd = { + documentation = [ + "man:watchdogd(8)" + "man:watchdogd.conf(5)" + ]; + wantedBy = [ "multi-user.target" ]; + description = "Advanced system & process supervisor"; + serviceConfig = { + Type = "simple"; + ExecStart = "${cfg.package}/bin/watchdogd -n -f ${watchdogdConf}"; + }; }; }; - }; meta.maintainers = with lib.maintainers; [ vifino ]; } diff --git a/nixos/modules/services/monitoring/zabbix-agent.nix b/nixos/modules/services/monitoring/zabbix-agent.nix index b3850baa738b3c..8a8afcb501c8e6 100644 --- a/nixos/modules/services/monitoring/zabbix-agent.nix +++ b/nixos/modules/services/monitoring/zabbix-agent.nix @@ -1,10 +1,28 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.zabbixAgent; - inherit (lib) mkDefault mkEnableOption mkPackageOption mkIf mkMerge mkOption; - inherit (lib) attrValues concatMapStringsSep literalExpression optionalString types; + inherit (lib) + mkDefault + mkEnableOption + mkPackageOption + mkIf + mkMerge + mkOption + ; + inherit (lib) + attrValues + concatMapStringsSep + literalExpression + optionalString + types + ; inherit (lib.generators) toKeyValue; user = "zabbix-agent"; @@ -15,13 +33,19 @@ let paths = attrValues cfg.modules; }; - configFile = pkgs.writeText "zabbix_agent.conf" (toKeyValue { listsAsDuplicateKeys = true; } cfg.settings); + configFile = pkgs.writeText "zabbix_agent.conf" ( + toKeyValue { listsAsDuplicateKeys = true; } cfg.settings + ); in { imports = [ - (lib.mkRemovedOptionModule [ "services" "zabbixAgent" "extraConfig" ] "Use services.zabbixAgent.settings instead.") + (lib.mkRemovedOptionModule [ + "services" + "zabbixAgent" + "extraConfig" + ] "Use services.zabbixAgent.settings instead.") ]; # interface @@ -47,7 +71,7 @@ in modules = mkOption { type = types.attrsOf types.package; description = "A set of modules to load."; - default = {}; + default = { }; example = literalExpression '' { "dummy.so" = pkgs.stdenv.mkDerivation { @@ -98,8 +122,14 @@ in }; settings = mkOption { - type = with types; attrsOf (oneOf [ int str (listOf str) ]); - default = {}; + type = + with types; + attrsOf (oneOf [ + int + str + (listOf str) + ]); + default = { }; description = '' Zabbix Agent configuration. Refer to @@ -125,7 +155,7 @@ in Server = cfg.server; ListenPort = cfg.listen.port; } - (mkIf (cfg.modules != {}) { + (mkIf (cfg.modules != { }) { LoadModule = builtins.attrNames cfg.modules; LoadModulePath = "${moduleEnv}/lib"; }) @@ -155,7 +185,13 @@ in # https://www.zabbix.com/documentation/current/manual/config/items/userparameters # > User parameters are commands executed by Zabbix agent. # > /bin/sh is used as a command line interpreter under UNIX operating systems. - path = with pkgs; [ bash "/run/wrappers" ] ++ cfg.extraPackages; + path = + with pkgs; + [ + bash + "/run/wrappers" + ] + ++ cfg.extraPackages; serviceConfig = { ExecStart = "@${cfg.package}/sbin/zabbix_agentd zabbix_agentd -f --config ${configFile}"; diff --git a/nixos/modules/services/monitoring/zabbix-proxy.nix b/nixos/modules/services/monitoring/zabbix-proxy.nix index dec403df85ea8b..2336446d6f4737 100644 --- a/nixos/modules/services/monitoring/zabbix-proxy.nix +++ b/nixos/modules/services/monitoring/zabbix-proxy.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.zabbixProxy; @@ -6,8 +12,24 @@ let pgsql = config.services.postgresql; mysql = config.services.mysql; - inherit (lib) mkAfter mkDefault mkEnableOption mkIf mkMerge mkOption; - inherit (lib) attrValues concatMapStringsSep getName literalExpression optional optionalAttrs optionalString types; + inherit (lib) + mkAfter + mkDefault + mkEnableOption + mkIf + mkMerge + mkOption + ; + inherit (lib) + attrValues + concatMapStringsSep + getName + literalExpression + optional + optionalAttrs + optionalString + types + ; inherit (lib.generators) toKeyValue; user = "zabbix"; @@ -21,7 +43,9 @@ let paths = attrValues cfg.modules; }; - configFile = pkgs.writeText "zabbix_proxy.conf" (toKeyValue { listsAsDuplicateKeys = true; } cfg.settings); + configFile = pkgs.writeText "zabbix_proxy.conf" ( + toKeyValue { listsAsDuplicateKeys = true; } cfg.settings + ); mysqlLocal = cfg.database.createLocally && cfg.database.type == "mysql"; pgsqlLocal = cfg.database.createLocally && cfg.database.type == "pgsql"; @@ -30,7 +54,11 @@ in { imports = [ - (lib.mkRemovedOptionModule [ "services" "zabbixProxy" "extraConfig" ] "Use services.zabbixProxy.settings instead.") + (lib.mkRemovedOptionModule [ + "services" + "zabbixProxy" + "extraConfig" + ] "Use services.zabbixProxy.settings instead.") ]; # interface @@ -44,22 +72,29 @@ in type = types.str; description = '' The IP address or hostname of the Zabbix server to connect to. - ''; - }; + ''; + }; package = mkOption { type = types.package; default = - if cfg.database.type == "mysql" then pkgs.zabbix.proxy-mysql - else if cfg.database.type == "pgsql" then pkgs.zabbix.proxy-pgsql - else pkgs.zabbix.proxy-sqlite; + if cfg.database.type == "mysql" then + pkgs.zabbix.proxy-mysql + else if cfg.database.type == "pgsql" then + pkgs.zabbix.proxy-pgsql + else + pkgs.zabbix.proxy-sqlite; defaultText = literalExpression "pkgs.zabbix.proxy-pgsql"; description = "The Zabbix package to use."; }; extraPackages = mkOption { type = types.listOf types.package; - default = with pkgs; [ nettools nmap traceroute ]; + default = with pkgs; [ + nettools + nmap + traceroute + ]; defaultText = literalExpression "[ nettools nmap traceroute ]"; description = '' Packages to be added to the Zabbix {env}`PATH`. @@ -70,7 +105,7 @@ in modules = mkOption { type = types.attrsOf types.package; description = "A set of modules to load."; - default = {}; + default = { }; example = literalExpression '' { "dummy.so" = pkgs.stdenv.mkDerivation { @@ -89,7 +124,11 @@ in database = { type = mkOption { - type = types.enum [ "mysql" "pgsql" "sqlite" ]; + type = types.enum [ + "mysql" + "pgsql" + "sqlite" + ]; example = "mysql"; default = "pgsql"; description = "Database engine to use."; @@ -177,8 +216,14 @@ in }; settings = mkOption { - type = with types; attrsOf (oneOf [ int str (listOf str) ]); - default = {}; + type = + with types; + attrsOf (oneOf [ + int + str + (listOf str) + ]); + default = { }; description = '' Zabbix Proxy configuration. Refer to @@ -200,13 +245,17 @@ in config = mkIf cfg.enable { assertions = [ - { assertion = !config.services.zabbixServer.enable; + { + assertion = !config.services.zabbixServer.enable; message = "Please choose one of services.zabbixServer or services.zabbixProxy."; } - { assertion = cfg.database.createLocally -> cfg.database.user == user && cfg.database.name == cfg.database.user; + { + assertion = + cfg.database.createLocally -> cfg.database.user == user && cfg.database.name == cfg.database.user; message = "services.zabbixProxy.database.user must be set to ${user} if services.zabbixProxy.database.createLocally is set true"; } - { assertion = cfg.database.createLocally -> cfg.database.passwordFile == null; + { + assertion = cfg.database.createLocally -> cfg.database.passwordFile == null; message = "a password cannot be specified if services.zabbixProxy.database.createLocally is set to true"; } ]; @@ -228,7 +277,7 @@ in (mkIf (cfg.database.createLocally != true) { DBPort = cfg.database.port; }) (mkIf (cfg.database.passwordFile != null) { Include = [ "${passwordFile}" ]; }) (mkIf (mysqlLocal && cfg.database.socket != null) { DBSocket = cfg.database.socket; }) - (mkIf (cfg.modules != {}) { LoadModulePath = "${moduleEnv}/lib"; }) + (mkIf (cfg.modules != { }) { LoadModulePath = "${moduleEnv}/lib"; }) ]; networking.firewall = mkIf cfg.openFirewall { @@ -240,18 +289,26 @@ in package = mkDefault pkgs.mariadb; }; - systemd.services.mysql.postStart = mkAfter (optionalString mysqlLocal '' - ( echo "CREATE DATABASE IF NOT EXISTS \`${cfg.database.name}\` CHARACTER SET utf8 COLLATE utf8_bin;" - echo "CREATE USER IF NOT EXISTS '${cfg.database.user}'@'localhost' IDENTIFIED WITH ${if (getName config.services.mysql.package == getName pkgs.mariadb) then "unix_socket" else "auth_socket"};" - echo "GRANT ALL PRIVILEGES ON \`${cfg.database.name}\`.* TO '${cfg.database.user}'@'localhost';" - ) | ${config.services.mysql.package}/bin/mysql -N - ''); + systemd.services.mysql.postStart = mkAfter ( + optionalString mysqlLocal '' + ( echo "CREATE DATABASE IF NOT EXISTS \`${cfg.database.name}\` CHARACTER SET utf8 COLLATE utf8_bin;" + echo "CREATE USER IF NOT EXISTS '${cfg.database.user}'@'localhost' IDENTIFIED WITH ${ + if (getName config.services.mysql.package == getName pkgs.mariadb) then + "unix_socket" + else + "auth_socket" + };" + echo "GRANT ALL PRIVILEGES ON \`${cfg.database.name}\`.* TO '${cfg.database.user}'@'localhost';" + ) | ${config.services.mysql.package}/bin/mysql -N + '' + ); services.postgresql = optionalAttrs pgsqlLocal { enable = true; ensureDatabases = [ cfg.database.name ]; ensureUsers = [ - { name = cfg.database.user; + { + name = cfg.database.user; ensureDBOwnership = true; } ]; @@ -268,12 +325,12 @@ in }; security.wrappers = { - fping = - { setuid = true; - owner = "root"; - group = "root"; - source = "${pkgs.fping}/bin/fping"; - }; + fping = { + setuid = true; + owner = "root"; + group = "root"; + source = "${pkgs.fping}/bin/fping"; + }; }; systemd.services.zabbix-proxy = { @@ -283,24 +340,28 @@ in after = optional mysqlLocal "mysql.service" ++ optional pgsqlLocal "postgresql.service"; path = [ "/run/wrappers" ] ++ cfg.extraPackages; - preStart = optionalString pgsqlLocal '' - if ! test -e "${stateDir}/db-created"; then - cat ${cfg.package}/share/zabbix/database/postgresql/schema.sql | ${pgsql.package}/bin/psql ${cfg.database.name} - touch "${stateDir}/db-created" - fi - '' + optionalString mysqlLocal '' - if ! test -e "${stateDir}/db-created"; then - cat ${cfg.package}/share/zabbix/database/mysql/schema.sql | ${mysql.package}/bin/mysql ${cfg.database.name} - touch "${stateDir}/db-created" - fi - '' + optionalString (cfg.database.type == "sqlite") '' - if ! test -e "${cfg.database.name}"; then - ${pkgs.sqlite}/bin/sqlite3 "${cfg.database.name}" < ${cfg.package}/share/zabbix/database/sqlite3/schema.sql - fi - '' + optionalString (cfg.database.passwordFile != null) '' - # create a copy of the supplied password file in a format zabbix can consume - install -m 0600 <(echo "DBPassword = $(cat ${cfg.database.passwordFile})") ${passwordFile} - ''; + preStart = + optionalString pgsqlLocal '' + if ! test -e "${stateDir}/db-created"; then + cat ${cfg.package}/share/zabbix/database/postgresql/schema.sql | ${pgsql.package}/bin/psql ${cfg.database.name} + touch "${stateDir}/db-created" + fi + '' + + optionalString mysqlLocal '' + if ! test -e "${stateDir}/db-created"; then + cat ${cfg.package}/share/zabbix/database/mysql/schema.sql | ${mysql.package}/bin/mysql ${cfg.database.name} + touch "${stateDir}/db-created" + fi + '' + + optionalString (cfg.database.type == "sqlite") '' + if ! test -e "${cfg.database.name}"; then + ${pkgs.sqlite}/bin/sqlite3 "${cfg.database.name}" < ${cfg.package}/share/zabbix/database/sqlite3/schema.sql + fi + '' + + optionalString (cfg.database.passwordFile != null) '' + # create a copy of the supplied password file in a format zabbix can consume + install -m 0600 <(echo "DBPassword = $(cat ${cfg.database.passwordFile})") ${passwordFile} + ''; serviceConfig = { ExecStart = "@${cfg.package}/sbin/zabbix_proxy zabbix_proxy -f --config ${configFile}"; diff --git a/nixos/modules/services/monitoring/zabbix-server.nix b/nixos/modules/services/monitoring/zabbix-server.nix index 3c6f60b9d722e6..3fd18ce2d6d1ee 100644 --- a/nixos/modules/services/monitoring/zabbix-server.nix +++ b/nixos/modules/services/monitoring/zabbix-server.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.zabbixServer; @@ -6,8 +12,24 @@ let pgsql = config.services.postgresql; mysql = config.services.mysql; - inherit (lib) mkAfter mkDefault mkEnableOption mkIf mkMerge mkOption; - inherit (lib) attrValues concatMapStringsSep getName literalExpression optional optionalAttrs optionalString types; + inherit (lib) + mkAfter + mkDefault + mkEnableOption + mkIf + mkMerge + mkOption + ; + inherit (lib) + attrValues + concatMapStringsSep + getName + literalExpression + optional + optionalAttrs + optionalString + types + ; inherit (lib.generators) toKeyValue; user = "zabbix"; @@ -21,7 +43,9 @@ let paths = attrValues cfg.modules; }; - configFile = pkgs.writeText "zabbix_server.conf" (toKeyValue { listsAsDuplicateKeys = true; } cfg.settings); + configFile = pkgs.writeText "zabbix_server.conf" ( + toKeyValue { listsAsDuplicateKeys = true; } cfg.settings + ); mysqlLocal = cfg.database.createLocally && cfg.database.type == "mysql"; pgsqlLocal = cfg.database.createLocally && cfg.database.type == "pgsql"; @@ -30,9 +54,20 @@ in { imports = [ - (lib.mkRenamedOptionModule [ "services" "zabbixServer" "dbServer" ] [ "services" "zabbixServer" "database" "host" ]) - (lib.mkRemovedOptionModule [ "services" "zabbixServer" "dbPassword" ] "Use services.zabbixServer.database.passwordFile instead.") - (lib.mkRemovedOptionModule [ "services" "zabbixServer" "extraConfig" ] "Use services.zabbixServer.settings instead.") + (lib.mkRenamedOptionModule + [ "services" "zabbixServer" "dbServer" ] + [ "services" "zabbixServer" "database" "host" ] + ) + (lib.mkRemovedOptionModule [ + "services" + "zabbixServer" + "dbPassword" + ] "Use services.zabbixServer.database.passwordFile instead.") + (lib.mkRemovedOptionModule [ + "services" + "zabbixServer" + "extraConfig" + ] "Use services.zabbixServer.settings instead.") ]; # interface @@ -44,14 +79,19 @@ in package = mkOption { type = types.package; - default = if cfg.database.type == "mysql" then pkgs.zabbix.server-mysql else pkgs.zabbix.server-pgsql; + default = + if cfg.database.type == "mysql" then pkgs.zabbix.server-mysql else pkgs.zabbix.server-pgsql; defaultText = literalExpression "pkgs.zabbix.server-pgsql"; description = "The Zabbix package to use."; }; extraPackages = mkOption { type = types.listOf types.package; - default = with pkgs; [ nettools nmap traceroute ]; + default = with pkgs; [ + nettools + nmap + traceroute + ]; defaultText = literalExpression "[ nettools nmap traceroute ]"; description = '' Packages to be added to the Zabbix {env}`PATH`. @@ -62,7 +102,7 @@ in modules = mkOption { type = types.attrsOf types.package; description = "A set of modules to load."; - default = {}; + default = { }; example = literalExpression '' { "dummy.so" = pkgs.stdenv.mkDerivation { @@ -81,7 +121,10 @@ in database = { type = mkOption { - type = types.enum [ "mysql" "pgsql" ]; + type = types.enum [ + "mysql" + "pgsql" + ]; example = "mysql"; default = "pgsql"; description = "Database engine to use."; @@ -168,8 +211,14 @@ in }; settings = mkOption { - type = with types; attrsOf (oneOf [ int str (listOf str) ]); - default = {}; + type = + with types; + attrsOf (oneOf [ + int + str + (listOf str) + ]); + default = { }; description = '' Zabbix Server configuration. Refer to @@ -191,10 +240,13 @@ in config = mkIf cfg.enable { assertions = [ - { assertion = cfg.database.createLocally -> cfg.database.user == user && cfg.database.user == cfg.database.name; + { + assertion = + cfg.database.createLocally -> cfg.database.user == user && cfg.database.user == cfg.database.name; message = "services.zabbixServer.database.user must be set to ${user} if services.zabbixServer.database.createLocally is set true"; } - { assertion = cfg.database.createLocally -> cfg.database.passwordFile == null; + { + assertion = cfg.database.createLocally -> cfg.database.passwordFile == null; message = "a password cannot be specified if services.zabbixServer.database.createLocally is set to true"; } ]; @@ -216,7 +268,7 @@ in (mkIf (cfg.database.createLocally != true) { DBPort = cfg.database.port; }) (mkIf (cfg.database.passwordFile != null) { Include = [ "${passwordFile}" ]; }) (mkIf (mysqlLocal && cfg.database.socket != null) { DBSocket = cfg.database.socket; }) - (mkIf (cfg.modules != {}) { LoadModulePath = "${moduleEnv}/lib"; }) + (mkIf (cfg.modules != { }) { LoadModulePath = "${moduleEnv}/lib"; }) ]; networking.firewall = mkIf cfg.openFirewall { @@ -228,18 +280,26 @@ in package = mkDefault pkgs.mariadb; }; - systemd.services.mysql.postStart = mkAfter (optionalString mysqlLocal '' - ( echo "CREATE DATABASE IF NOT EXISTS \`${cfg.database.name}\` CHARACTER SET utf8 COLLATE utf8_bin;" - echo "CREATE USER IF NOT EXISTS '${cfg.database.user}'@'localhost' IDENTIFIED WITH ${if (getName config.services.mysql.package == getName pkgs.mariadb) then "unix_socket" else "auth_socket"};" - echo "GRANT ALL PRIVILEGES ON \`${cfg.database.name}\`.* TO '${cfg.database.user}'@'localhost';" - ) | ${config.services.mysql.package}/bin/mysql -N - ''); + systemd.services.mysql.postStart = mkAfter ( + optionalString mysqlLocal '' + ( echo "CREATE DATABASE IF NOT EXISTS \`${cfg.database.name}\` CHARACTER SET utf8 COLLATE utf8_bin;" + echo "CREATE USER IF NOT EXISTS '${cfg.database.user}'@'localhost' IDENTIFIED WITH ${ + if (getName config.services.mysql.package == getName pkgs.mariadb) then + "unix_socket" + else + "auth_socket" + };" + echo "GRANT ALL PRIVILEGES ON \`${cfg.database.name}\`.* TO '${cfg.database.user}'@'localhost';" + ) | ${config.services.mysql.package}/bin/mysql -N + '' + ); services.postgresql = optionalAttrs pgsqlLocal { enable = true; ensureDatabases = [ cfg.database.name ]; ensureUsers = [ - { name = cfg.database.user; + { + name = cfg.database.user; ensureDBOwnership = true; } ]; @@ -256,12 +316,12 @@ in }; security.wrappers = { - fping = - { setuid = true; - owner = "root"; - group = "root"; - source = "${pkgs.fping}/bin/fping"; - }; + fping = { + setuid = true; + owner = "root"; + group = "root"; + source = "${pkgs.fping}/bin/fping"; + }; }; systemd.services.zabbix-server = { @@ -271,29 +331,33 @@ in after = optional mysqlLocal "mysql.service" ++ optional pgsqlLocal "postgresql.service"; path = [ "/run/wrappers" ] ++ cfg.extraPackages; - preStart = '' - # pre 19.09 compatibility - if test -e "${runtimeDir}/db-created"; then - mv "${runtimeDir}/db-created" "${stateDir}/" - fi - '' + optionalString pgsqlLocal '' - if ! test -e "${stateDir}/db-created"; then - cat ${cfg.package}/share/zabbix/database/postgresql/schema.sql | ${pgsql.package}/bin/psql ${cfg.database.name} - cat ${cfg.package}/share/zabbix/database/postgresql/images.sql | ${pgsql.package}/bin/psql ${cfg.database.name} - cat ${cfg.package}/share/zabbix/database/postgresql/data.sql | ${pgsql.package}/bin/psql ${cfg.database.name} - touch "${stateDir}/db-created" - fi - '' + optionalString mysqlLocal '' - if ! test -e "${stateDir}/db-created"; then - cat ${cfg.package}/share/zabbix/database/mysql/schema.sql | ${mysql.package}/bin/mysql ${cfg.database.name} - cat ${cfg.package}/share/zabbix/database/mysql/images.sql | ${mysql.package}/bin/mysql ${cfg.database.name} - cat ${cfg.package}/share/zabbix/database/mysql/data.sql | ${mysql.package}/bin/mysql ${cfg.database.name} - touch "${stateDir}/db-created" - fi - '' + optionalString (cfg.database.passwordFile != null) '' - # create a copy of the supplied password file in a format zabbix can consume - install -m 0600 <(echo "DBPassword = $(cat ${cfg.database.passwordFile})") ${passwordFile} - ''; + preStart = + '' + # pre 19.09 compatibility + if test -e "${runtimeDir}/db-created"; then + mv "${runtimeDir}/db-created" "${stateDir}/" + fi + '' + + optionalString pgsqlLocal '' + if ! test -e "${stateDir}/db-created"; then + cat ${cfg.package}/share/zabbix/database/postgresql/schema.sql | ${pgsql.package}/bin/psql ${cfg.database.name} + cat ${cfg.package}/share/zabbix/database/postgresql/images.sql | ${pgsql.package}/bin/psql ${cfg.database.name} + cat ${cfg.package}/share/zabbix/database/postgresql/data.sql | ${pgsql.package}/bin/psql ${cfg.database.name} + touch "${stateDir}/db-created" + fi + '' + + optionalString mysqlLocal '' + if ! test -e "${stateDir}/db-created"; then + cat ${cfg.package}/share/zabbix/database/mysql/schema.sql | ${mysql.package}/bin/mysql ${cfg.database.name} + cat ${cfg.package}/share/zabbix/database/mysql/images.sql | ${mysql.package}/bin/mysql ${cfg.database.name} + cat ${cfg.package}/share/zabbix/database/mysql/data.sql | ${mysql.package}/bin/mysql ${cfg.database.name} + touch "${stateDir}/db-created" + fi + '' + + optionalString (cfg.database.passwordFile != null) '' + # create a copy of the supplied password file in a format zabbix can consume + install -m 0600 <(echo "DBPassword = $(cat ${cfg.database.passwordFile})") ${passwordFile} + ''; serviceConfig = { ExecStart = "@${cfg.package}/sbin/zabbix_server zabbix_server -f --config ${configFile}"; @@ -309,8 +373,8 @@ in }; systemd.services.httpd.after = - optional (config.services.zabbixWeb.enable && mysqlLocal) "mysql.service" ++ - optional (config.services.zabbixWeb.enable && pgsqlLocal) "postgresql.service"; + optional (config.services.zabbixWeb.enable && mysqlLocal) "mysql.service" + ++ optional (config.services.zabbixWeb.enable && pgsqlLocal) "postgresql.service"; }; diff --git a/nixos/modules/services/network-filesystems/cachefilesd.nix b/nixos/modules/services/network-filesystems/cachefilesd.nix index b1c13cf41501c9..6408e59498743b 100644 --- a/nixos/modules/services/network-filesystems/cachefilesd.nix +++ b/nixos/modules/services/network-filesystems/cachefilesd.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.cachefilesd; diff --git a/nixos/modules/services/network-filesystems/davfs2.nix b/nixos/modules/services/network-filesystems/davfs2.nix index 49a363476c9756..2a1460a8eef031 100644 --- a/nixos/modules/services/network-filesystems/davfs2.nix +++ b/nixos/modules/services/network-filesystems/davfs2.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib.attrsets) optionalAttrs; @@ -7,23 +12,40 @@ let inherit (lib.modules) mkIf mkRemovedOptionModule; inherit (lib.options) literalExpression mkEnableOption mkOption; inherit (lib.strings) escape; - inherit (lib.types) attrsOf bool int lines oneOf str submodule; + inherit (lib.types) + attrsOf + bool + int + lines + oneOf + str + submodule + ; cfg = config.services.davfs2; - escapeString = escape ["\"" "\\"]; + escapeString = escape [ + "\"" + "\\" + ]; - formatValue = value: - if true == value then "1" - else if false == value then "0" - else if builtins.isString value then "\"${escapeString value}\"" - else toString value; + formatValue = + value: + if true == value then + "1" + else if false == value then + "0" + else if builtins.isString value then + "\"${escapeString value}\"" + else + toString value; configFile = pkgs.writeText "davfs2.conf" ( toINIWithGlobalSection { mkSectionName = escapeString; mkKeyValue = k: v: "${k} ${formatValue v}"; - } cfg.settings); + } cfg.settings + ); in { @@ -58,10 +80,15 @@ in settings = mkOption { type = submodule { - freeformType = let - valueTypes = [ bool int str ]; - in - attrsOf (attrsOf (oneOf (valueTypes ++ [ (attrsOf (oneOf valueTypes)) ] ))); + freeformType = + let + valueTypes = [ + bool + int + str + ]; + in + attrsOf (attrsOf (oneOf (valueTypes ++ [ (attrsOf (oneOf valueTypes)) ]))); }; default = { }; example = literalExpression '' @@ -83,7 +110,7 @@ in description = '' Extra settings appended to the configuration of davfs2. See {manpage}`davfs2.conf(5)` for available settings. - '' ; + ''; }; }; diff --git a/nixos/modules/services/network-filesystems/diod.nix b/nixos/modules/services/network-filesystems/diod.nix index 8b3f4f9bd8c5f0..8ad0d6e53893d9 100644 --- a/nixos/modules/services/network-filesystems/diod.nix +++ b/nixos/modules/services/network-filesystems/diod.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.diod; @@ -9,8 +14,8 @@ let auth_required = ${diodBool cfg.authRequired} exportall = ${diodBool cfg.exportall} exportopts = "${lib.concatStringsSep "," cfg.exportopts}" - exports = { ${lib.concatStringsSep ", " (map (s: ''"${s}"'' ) cfg.exports)} } - listen = { ${lib.concatStringsSep ", " (map (s: ''"${s}"'' ) cfg.listen)} } + exports = { ${lib.concatStringsSep ", " (map (s: ''"${s}"'') cfg.exports)} } + listen = { ${lib.concatStringsSep ", " (map (s: ''"${s}"'') cfg.listen)} } logdest = "${cfg.logdest}" nwthreads = ${toString cfg.nwthreads} squashuser = "${cfg.squashuser}" @@ -39,7 +44,7 @@ in exports = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' List the file systems that clients will be allowed to mount. All paths should be fully qualified. The exports table can include two types of element: @@ -66,7 +71,7 @@ in exportopts = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Establish a default set of export options. These are overridden, not appended to, by opts attributes in an "exports" entry. @@ -125,7 +130,6 @@ in ''; }; - statfsPassthru = lib.mkOption { type = lib.types.bool; default = false; diff --git a/nixos/modules/services/network-filesystems/drbd.nix b/nixos/modules/services/network-filesystems/drbd.nix index 2ecf8558a10ff8..973ed80d82b91d 100644 --- a/nixos/modules/services/network-filesystems/drbd.nix +++ b/nixos/modules/services/network-filesystems/drbd.nix @@ -1,6 +1,13 @@ # Support for DRBD, the Distributed Replicated Block Device. -{ config, lib, pkgs, ... }: -let cfg = config.services.drbd; in +{ + config, + lib, + pkgs, + ... +}: +let + cfg = config.services.drbd; +in { @@ -27,7 +34,6 @@ let cfg = config.services.drbd; in }; - ###### implementation config = lib.mkIf cfg.enable { @@ -38,16 +44,19 @@ let cfg = config.services.drbd; in boot.kernelModules = [ "drbd" ]; - boot.extraModprobeConfig = - '' - options drbd usermode_helper=/run/current-system/sw/bin/drbdadm - ''; + boot.extraModprobeConfig = '' + options drbd usermode_helper=/run/current-system/sw/bin/drbdadm + ''; - environment.etc."drbd.conf" = - { source = pkgs.writeText "drbd.conf" cfg.config; }; + environment.etc."drbd.conf" = { + source = pkgs.writeText "drbd.conf" cfg.config; + }; systemd.services.drbd = { - after = [ "systemd-udev.settle.service" "network.target" ]; + after = [ + "systemd-udev.settle.service" + "network.target" + ]; wants = [ "systemd-udev.settle.service" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { diff --git a/nixos/modules/services/network-filesystems/eris-server.nix b/nixos/modules/services/network-filesystems/eris-server.nix index 7ad190c62f0a09..688222a114ff03 100644 --- a/nixos/modules/services/network-filesystems/eris-server.nix +++ b/nixos/modules/services/network-filesystems/eris-server.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.eris-server; stateDirectoryPath = "\${STATE_DIRECTORY}"; nullOrStr = with lib.types; nullOr str; -in { +in +{ options.services.eris-server = { @@ -70,45 +76,52 @@ in { }; config = lib.mkIf cfg.enable { - assertions = [{ - assertion = lib.strings.versionAtLeast cfg.package.version "20231219"; - message = - "Version of `config.services.eris-server.package` is incompatible with this module"; - }]; + assertions = [ + { + assertion = lib.strings.versionAtLeast cfg.package.version "20231219"; + message = "Version of `config.services.eris-server.package` is incompatible with this module"; + } + ]; - systemd.services.eris-server = let - cmd = "${cfg.package}/bin/eris-go server" - + (lib.optionalString (cfg.listenCoap != null) - " --coap '${cfg.listenCoap}'") - + (lib.optionalString (cfg.listenHttp != null) - " --http '${cfg.listenHttp}'") - + (lib.optionalString cfg.decode " --decode") - + (lib.optionalString (cfg.mountpoint != null) - " --mountpoint '${cfg.mountpoint}'"); - in { - description = "ERIS block server"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - environment.ERIS_STORE_URL = toString cfg.backends; - script = lib.mkIf (cfg.mountpoint != null) '' - export PATH=${config.security.wrapperDir}:$PATH - ${cmd} - ''; - serviceConfig = let - umounter = lib.mkIf (cfg.mountpoint != null) - "-${config.security.wrapperDir}/fusermount -uz ${cfg.mountpoint}"; - in if (cfg.mountpoint == null) then { - ExecStart = cmd; - } else - { - ExecStartPre = umounter; - ExecStopPost = umounter; - } // { - Restart = "always"; - RestartSec = 20; - AmbientCapabilities = "CAP_NET_BIND_SERVICE"; - }; - }; + systemd.services.eris-server = + let + cmd = + "${cfg.package}/bin/eris-go server" + + (lib.optionalString (cfg.listenCoap != null) " --coap '${cfg.listenCoap}'") + + (lib.optionalString (cfg.listenHttp != null) " --http '${cfg.listenHttp}'") + + (lib.optionalString cfg.decode " --decode") + + (lib.optionalString (cfg.mountpoint != null) " --mountpoint '${cfg.mountpoint}'"); + in + { + description = "ERIS block server"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + environment.ERIS_STORE_URL = toString cfg.backends; + script = lib.mkIf (cfg.mountpoint != null) '' + export PATH=${config.security.wrapperDir}:$PATH + ${cmd} + ''; + serviceConfig = + let + umounter = lib.mkIf ( + cfg.mountpoint != null + ) "-${config.security.wrapperDir}/fusermount -uz ${cfg.mountpoint}"; + in + if (cfg.mountpoint == null) then + { + ExecStart = cmd; + } + else + { + ExecStartPre = umounter; + ExecStopPost = umounter; + } + // { + Restart = "always"; + RestartSec = 20; + AmbientCapabilities = "CAP_NET_BIND_SERVICE"; + }; + }; }; meta.maintainers = with lib.maintainers; [ ehmry ]; diff --git a/nixos/modules/services/network-filesystems/glusterfs.nix b/nixos/modules/services/network-filesystems/glusterfs.nix index d34370875f6bd9..87a979f79a872e 100644 --- a/nixos/modules/services/network-filesystems/glusterfs.nix +++ b/nixos/modules/services/network-filesystems/glusterfs.nix @@ -1,16 +1,22 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (pkgs) glusterfs rsync; - tlsCmd = if (cfg.tlsSettings != null) then - '' - mkdir -p /var/lib/glusterd - touch /var/lib/glusterd/secure-access - '' - else - '' - rm -f /var/lib/glusterd/secure-access - ''; + tlsCmd = + if (cfg.tlsSettings != null) then + '' + mkdir -p /var/lib/glusterd + touch /var/lib/glusterd/secure-access + '' + else + '' + rm -f /var/lib/glusterd/secure-access + ''; restartTriggers = lib.optionals (cfg.tlsSettings != null) [ config.environment.etc."ssl/glusterfs.pem".source @@ -33,7 +39,15 @@ in enable = lib.mkEnableOption "GlusterFS Daemon"; logLevel = lib.mkOption { - type = lib.types.enum ["DEBUG" "INFO" "WARNING" "ERROR" "CRITICAL" "TRACE" "NONE"]; + type = lib.types.enum [ + "DEBUG" + "INFO" + "WARNING" + "ERROR" + "CRITICAL" + "TRACE" + "NONE" + ]; description = "Log level used by the GlusterFS daemon"; default = "INFO"; }; @@ -58,7 +72,12 @@ in }; killMode = lib.mkOption { - type = lib.types.enum ["control-group" "process" "mixed" "none"]; + type = lib.types.enum [ + "control-group" + "process" + "mixed" + "none" + ]; description = '' The systemd KillMode to use for glusterd. @@ -92,7 +111,7 @@ in extraFlags = lib.mkOption { type = lib.types.listOf lib.types.str; description = "Extra flags passed to the GlusterFS daemon"; - default = []; + default = [ ]; }; tlsSettings = lib.mkOption { @@ -107,24 +126,26 @@ in See also: https://gluster.readthedocs.io/en/latest/Administrator%20Guide/SSL/ ''; default = null; - type = lib.types.nullOr (lib.types.submodule { - options = { - tlsKeyPath = lib.mkOption { - type = lib.types.str; - description = "Path to the private key used for TLS."; - }; - - tlsPem = lib.mkOption { - type = lib.types.path; - description = "Path to the certificate used for TLS."; - }; - - caCert = lib.mkOption { - type = lib.types.path; - description = "Path certificate authority used to sign the cluster certificates."; + type = lib.types.nullOr ( + lib.types.submodule { + options = { + tlsKeyPath = lib.mkOption { + type = lib.types.str; + description = "Path to the private key used for TLS."; + }; + + tlsPem = lib.mkOption { + type = lib.types.path; + description = "Path to the certificate used for TLS."; + }; + + caCert = lib.mkOption { + type = lib.types.path; + description = "Path certificate authority used to sign the cluster certificates."; + }; }; - }; - }); + } + ); }; }; }; @@ -152,29 +173,30 @@ in requires = lib.optional cfg.useRpcbind "rpcbind.service"; after = [ "network.target" ] ++ lib.optional cfg.useRpcbind "rpcbind.service"; - preStart = '' - install -m 0755 -d /var/log/glusterfs - '' - # The copying of hooks is due to upstream bug https://bugzilla.redhat.com/show_bug.cgi?id=1452761 - # Excludes one hook due to missing SELinux binaries. - + '' - mkdir -p /var/lib/glusterd/hooks/ - ${rsync}/bin/rsync -a --exclude="S10selinux-label-brick.sh" ${glusterfs}/var/lib/glusterd/hooks/ /var/lib/glusterd/hooks/ - - ${tlsCmd} - '' - # `glusterfind` needs dirs that upstream installs at `make install` phase - # https://github.com/gluster/glusterfs/blob/v3.10.2/tools/glusterfind/Makefile.am#L16-L17 - + '' - mkdir -p /var/lib/glusterd/glusterfind/.keys - mkdir -p /var/lib/glusterd/hooks/1/delete/post/ - ''; + preStart = + '' + install -m 0755 -d /var/log/glusterfs + '' + # The copying of hooks is due to upstream bug https://bugzilla.redhat.com/show_bug.cgi?id=1452761 + # Excludes one hook due to missing SELinux binaries. + + '' + mkdir -p /var/lib/glusterd/hooks/ + ${rsync}/bin/rsync -a --exclude="S10selinux-label-brick.sh" ${glusterfs}/var/lib/glusterd/hooks/ /var/lib/glusterd/hooks/ + + ${tlsCmd} + '' + # `glusterfind` needs dirs that upstream installs at `make install` phase + # https://github.com/gluster/glusterfs/blob/v3.10.2/tools/glusterfind/Makefile.am#L16-L17 + + '' + mkdir -p /var/lib/glusterd/glusterfind/.keys + mkdir -p /var/lib/glusterd/hooks/1/delete/post/ + ''; serviceConfig = { - LimitNOFILE=65536; - ExecStart="${glusterfs}/sbin/glusterd --no-daemon --log-level=${cfg.logLevel} ${toString cfg.extraFlags}"; - KillMode=cfg.killMode; - TimeoutStopSec=cfg.stopKillTimeout; + LimitNOFILE = 65536; + ExecStart = "${glusterfs}/sbin/glusterd --no-daemon --log-level=${cfg.logLevel} ${toString cfg.extraFlags}"; + KillMode = cfg.killMode; + TimeoutStopSec = cfg.stopKillTimeout; }; }; @@ -195,11 +217,11 @@ in path = [ glusterfs ]; serviceConfig = { - Type="simple"; - PIDFile="/run/glustereventsd.pid"; - ExecStart="${glusterfs}/sbin/glustereventsd --pid-file /run/glustereventsd.pid"; - ExecReload="/bin/kill -SIGUSR2 $MAINPID"; - KillMode="control-group"; + Type = "simple"; + PIDFile = "/run/glustereventsd.pid"; + ExecStart = "${glusterfs}/sbin/glustereventsd --pid-file /run/glustereventsd.pid"; + ExecReload = "/bin/kill -SIGUSR2 $MAINPID"; + KillMode = "control-group"; }; }; }; diff --git a/nixos/modules/services/network-filesystems/kbfs.nix b/nixos/modules/services/network-filesystems/kbfs.nix index 034fc95765061b..c0501ae01eb161 100644 --- a/nixos/modules/services/network-filesystems/kbfs.nix +++ b/nixos/modules/services/network-filesystems/kbfs.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (config.security) wrapperDir; cfg = config.services.kbfs; -in { +in +{ ###### interface @@ -36,7 +42,7 @@ in { extraFlags = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = [ "-label kbfs" "-mount-type normal" @@ -51,72 +57,74 @@ in { ###### implementation - config = lib.mkIf cfg.enable (lib.mkMerge [ - { - # Upstream: https://github.com/keybase/client/blob/master/packaging/linux/systemd/kbfs.service - systemd.user.services.kbfs = { - description = "Keybase File System"; - - # Note that the "Requires" directive will cause a unit to be restarted whenever its dependency is restarted. - # Do not issue a hard dependency on keybase, because kbfs can reconnect to a restarted service. - # Do not issue a hard dependency on keybase-redirector, because it's ok if it fails (e.g., if it is disabled). - wants = [ "keybase.service" ] ++ lib.optional cfg.enableRedirector "keybase-redirector.service"; - path = [ "/run/wrappers" ]; - unitConfig.ConditionUser = "!@system"; - - serviceConfig = { - Type = "notify"; - # Keybase notifies from a forked process - EnvironmentFile = [ - "-%E/keybase/keybase.autogen.env" - "-%E/keybase/keybase.env" - ]; - ExecStartPre = [ - "${pkgs.coreutils}/bin/mkdir -p \"${cfg.mountPoint}\"" - "-${wrapperDir}/fusermount -uz \"${cfg.mountPoint}\"" - ]; - ExecStart = "${pkgs.kbfs}/bin/kbfsfuse ${toString cfg.extraFlags} \"${cfg.mountPoint}\""; - ExecStop = "${wrapperDir}/fusermount -uz \"${cfg.mountPoint}\""; - Restart = "on-failure"; - PrivateTmp = true; + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + { + # Upstream: https://github.com/keybase/client/blob/master/packaging/linux/systemd/kbfs.service + systemd.user.services.kbfs = { + description = "Keybase File System"; + + # Note that the "Requires" directive will cause a unit to be restarted whenever its dependency is restarted. + # Do not issue a hard dependency on keybase, because kbfs can reconnect to a restarted service. + # Do not issue a hard dependency on keybase-redirector, because it's ok if it fails (e.g., if it is disabled). + wants = [ "keybase.service" ] ++ lib.optional cfg.enableRedirector "keybase-redirector.service"; + path = [ "/run/wrappers" ]; + unitConfig.ConditionUser = "!@system"; + + serviceConfig = { + Type = "notify"; + # Keybase notifies from a forked process + EnvironmentFile = [ + "-%E/keybase/keybase.autogen.env" + "-%E/keybase/keybase.env" + ]; + ExecStartPre = [ + "${pkgs.coreutils}/bin/mkdir -p \"${cfg.mountPoint}\"" + "-${wrapperDir}/fusermount -uz \"${cfg.mountPoint}\"" + ]; + ExecStart = "${pkgs.kbfs}/bin/kbfsfuse ${toString cfg.extraFlags} \"${cfg.mountPoint}\""; + ExecStop = "${wrapperDir}/fusermount -uz \"${cfg.mountPoint}\""; + Restart = "on-failure"; + PrivateTmp = true; + }; + wantedBy = [ "default.target" ]; }; - wantedBy = [ "default.target" ]; - }; - - services.keybase.enable = true; - environment.systemPackages = [ pkgs.kbfs ]; - } + services.keybase.enable = true; - (lib.mkIf cfg.enableRedirector { - security.wrappers."keybase-redirector".source = "${pkgs.kbfs}/bin/redirector"; + environment.systemPackages = [ pkgs.kbfs ]; + } - systemd.tmpfiles.settings."10-kbfs"."/keybase".d = { - user = "root"; - group = "root"; - mode = "0755"; - age = "0"; - }; + (lib.mkIf cfg.enableRedirector { + security.wrappers."keybase-redirector".source = "${pkgs.kbfs}/bin/redirector"; - # Upstream: https://github.com/keybase/client/blob/master/packaging/linux/systemd/keybase-redirector.service - systemd.user.services.keybase-redirector = { - description = "Keybase Root Redirector for KBFS"; - wants = [ "keybase.service" ]; - unitConfig.ConditionUser = "!@system"; - - serviceConfig = { - EnvironmentFile = [ - "-%E/keybase/keybase.autogen.env" - "-%E/keybase/keybase.env" - ]; - # Note: The /keybase mount point is not currently configurable upstream. - ExecStart = "${wrapperDir}/keybase-redirector /keybase"; - Restart = "on-failure"; - PrivateTmp = true; + systemd.tmpfiles.settings."10-kbfs"."/keybase".d = { + user = "root"; + group = "root"; + mode = "0755"; + age = "0"; }; - wantedBy = [ "default.target" ]; - }; - }) - ]); + # Upstream: https://github.com/keybase/client/blob/master/packaging/linux/systemd/keybase-redirector.service + systemd.user.services.keybase-redirector = { + description = "Keybase Root Redirector for KBFS"; + wants = [ "keybase.service" ]; + unitConfig.ConditionUser = "!@system"; + + serviceConfig = { + EnvironmentFile = [ + "-%E/keybase/keybase.autogen.env" + "-%E/keybase/keybase.env" + ]; + # Note: The /keybase mount point is not currently configurable upstream. + ExecStart = "${wrapperDir}/keybase-redirector /keybase"; + Restart = "on-failure"; + PrivateTmp = true; + }; + + wantedBy = [ "default.target" ]; + }; + }) + ] + ); } diff --git a/nixos/modules/services/network-filesystems/kubo.nix b/nixos/modules/services/network-filesystems/kubo.nix index 0c2e14c3a2b30b..e13bd0b9c10569 100644 --- a/nixos/modules/services/network-filesystems/kubo.nix +++ b/nixos/modules/services/network-filesystems/kubo.nix @@ -1,21 +1,34 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.services.kubo; - settingsFormat = pkgs.formats.json {}; + settingsFormat = pkgs.formats.json { }; - rawDefaultConfig = lib.importJSON (pkgs.runCommand "kubo-default-config" { - nativeBuildInputs = [ cfg.package ]; - } '' - export IPFS_PATH="$TMPDIR" - ipfs init --empty-repo --profile=${profile} - ipfs --offline config show > "$out" - ''); + rawDefaultConfig = lib.importJSON ( + pkgs.runCommand "kubo-default-config" + { + nativeBuildInputs = [ cfg.package ]; + } + '' + export IPFS_PATH="$TMPDIR" + ipfs init --empty-repo --profile=${profile} + ipfs --offline config show > "$out" + '' + ); # Remove the PeerID (an attribute of "Identity") of the temporary Kubo repo. # The "Pinning" section contains the "RemoteServices" section, which would prevent # the daemon from starting as that setting can't be changed via ipfs config replace. - defaultConfig = builtins.removeAttrs rawDefaultConfig [ "Identity" "Pinning" ]; + defaultConfig = builtins.removeAttrs rawDefaultConfig [ + "Identity" + "Pinning" + ]; customizedConfig = lib.recursiveUpdate defaultConfig cfg.settings; @@ -34,60 +47,61 @@ let ''; kuboFlags = utils.escapeSystemdExecArgs ( - lib.optional cfg.autoMount "--mount" ++ - lib.optional cfg.enableGC "--enable-gc" ++ - lib.optional (cfg.serviceFdlimit != null) "--manage-fdlimit=false" ++ - lib.optional (cfg.defaultMode == "offline") "--offline" ++ - lib.optional (cfg.defaultMode == "norouting") "--routing=none" ++ - cfg.extraFlags + lib.optional cfg.autoMount "--mount" + ++ lib.optional cfg.enableGC "--enable-gc" + ++ lib.optional (cfg.serviceFdlimit != null) "--manage-fdlimit=false" + ++ lib.optional (cfg.defaultMode == "offline") "--offline" + ++ lib.optional (cfg.defaultMode == "norouting") "--routing=none" + ++ cfg.extraFlags ); - profile = - if cfg.localDiscovery - then "local-discovery" - else "server"; + profile = if cfg.localDiscovery then "local-discovery" else "server"; splitMulitaddr = addrRaw: lib.tail (lib.splitString "/" addrRaw); - multiaddrsToListenStreams = addrIn: + multiaddrsToListenStreams = + addrIn: let - addrs = if builtins.isList addrIn - then addrIn else [ addrIn ]; + addrs = if builtins.isList addrIn then addrIn else [ addrIn ]; unfilteredResult = map multiaddrToListenStream addrs; in - builtins.filter (addr: addr != null) unfilteredResult; + builtins.filter (addr: addr != null) unfilteredResult; - multiaddrsToListenDatagrams = addrIn: + multiaddrsToListenDatagrams = + addrIn: let - addrs = if builtins.isList addrIn - then addrIn else [ addrIn ]; + addrs = if builtins.isList addrIn then addrIn else [ addrIn ]; unfilteredResult = map multiaddrToListenDatagram addrs; in - builtins.filter (addr: addr != null) unfilteredResult; + builtins.filter (addr: addr != null) unfilteredResult; - multiaddrToListenStream = addrRaw: + multiaddrToListenStream = + addrRaw: let addr = splitMulitaddr addrRaw; s = builtins.elemAt addr; in - if s 0 == "ip4" && s 2 == "tcp" - then "${s 1}:${s 3}" - else if s 0 == "ip6" && s 2 == "tcp" - then "[${s 1}]:${s 3}" - else if s 0 == "unix" - then "/${lib.concatStringsSep "/" (lib.tail addr)}" - else null; # not valid for listen stream, skip - - multiaddrToListenDatagram = addrRaw: + if s 0 == "ip4" && s 2 == "tcp" then + "${s 1}:${s 3}" + else if s 0 == "ip6" && s 2 == "tcp" then + "[${s 1}]:${s 3}" + else if s 0 == "unix" then + "/${lib.concatStringsSep "/" (lib.tail addr)}" + else + null; # not valid for listen stream, skip + + multiaddrToListenDatagram = + addrRaw: let addr = splitMulitaddr addrRaw; s = builtins.elemAt addr; in - if s 0 == "ip4" && s 2 == "udp" - then "${s 1}:${s 3}" - else if s 0 == "ip6" && s 2 == "udp" - then "[${s 1}]:${s 3}" - else null; # not valid for listen datagram, skip + if s 0 == "ip4" && s 2 == "udp" then + "${s 1}:${s 3}" + else if s 0 == "ip6" && s 2 == "udp" then + "[${s 1}]:${s 3}" + else + null; # not valid for listen datagram, skip in { @@ -122,9 +136,10 @@ in dataDir = lib.mkOption { type = lib.types.str; default = - if lib.versionAtLeast config.system.stateVersion "17.09" - then "/var/lib/ipfs" - else "/var/lib/ipfs/.ipfs"; + if lib.versionAtLeast config.system.stateVersion "17.09" then + "/var/lib/ipfs" + else + "/var/lib/ipfs/.ipfs"; defaultText = lib.literalExpression '' if lib.versionAtLeast config.system.stateVersion "17.09" then "/var/lib/ipfs" @@ -134,7 +149,11 @@ in }; defaultMode = lib.mkOption { - type = lib.types.enum [ "online" "offline" "norouting" ]; + type = lib.types.enum [ + "online" + "offline" + "norouting" + ]; default = "online"; description = "systemd service that is enabled by default"; }; @@ -169,7 +188,10 @@ in options = { Addresses.API = lib.mkOption { - type = lib.types.oneOf [ lib.types.str (lib.types.listOf lib.types.str) ]; + type = lib.types.oneOf [ + lib.types.str + (lib.types.listOf lib.types.str) + ]; default = [ ]; description = '' Multiaddr or array of multiaddrs describing the address to serve the local HTTP API on. @@ -180,7 +202,10 @@ in }; Addresses.Gateway = lib.mkOption { - type = lib.types.oneOf [ lib.types.str (lib.types.listOf lib.types.str) ]; + type = lib.types.oneOf [ + lib.types.str + (lib.types.listOf lib.types.str) + ]; default = "/ip4/127.0.0.1/tcp/8080"; description = "Where the IPFS Gateway can be reached"; }; @@ -239,8 +264,9 @@ in localDiscovery = lib.mkOption { type = lib.types.bool; - description = ''Whether to enable local discovery for the Kubo daemon. - This will allow Kubo to scan ports on your local network. Some hosting services will ban you if you do this. + description = '' + Whether to enable local discovery for the Kubo daemon. + This will allow Kubo to scan ports on your local network. Some hosting services will ban you if you do this. ''; default = false; }; @@ -272,13 +298,22 @@ in ''; } { - assertion = !((builtins.hasAttr "Pinning" cfg.settings) && (builtins.hasAttr "RemoteServices" cfg.settings.Pinning)); + assertion = + !( + (builtins.hasAttr "Pinning" cfg.settings) + && (builtins.hasAttr "RemoteServices" cfg.settings.Pinning) + ); message = '' You can't set services.kubo.settings.Pinning.RemoteServices because the ``config replace`` subcommand used at startup does not work with it. ''; } { - assertion = !((lib.versionAtLeast cfg.package.version "0.21") && (builtins.hasAttr "Experimental" cfg.settings) && (builtins.hasAttr "AcceleratedDHTClient" cfg.settings.Experimental)); + assertion = + !( + (lib.versionAtLeast cfg.package.version "0.21") + && (builtins.hasAttr "Experimental" cfg.settings) + && (builtins.hasAttr "AcceleratedDHTClient" cfg.settings.Experimental) + ); message = '' The `services.kubo.settings.Experimental.AcceleratedDHTClient` option was renamed to `services.kubo.settings.Routing.AcceleratedDHTClient` in Kubo 0.21. ''; @@ -313,74 +348,90 @@ in ipfs.gid = config.ids.gids.ipfs; }; - systemd.tmpfiles.settings."10-kubo" = let - defaultConfig = { inherit (cfg) user group; }; - in { - ${cfg.dataDir}.d = defaultConfig; - ${cfg.settings.Mounts.IPFS}.d = lib.mkIf (cfg.autoMount) defaultConfig; - ${cfg.settings.Mounts.IPNS}.d = lib.mkIf (cfg.autoMount) defaultConfig; - }; + systemd.tmpfiles.settings."10-kubo" = + let + defaultConfig = { inherit (cfg) user group; }; + in + { + ${cfg.dataDir}.d = defaultConfig; + ${cfg.settings.Mounts.IPFS}.d = lib.mkIf (cfg.autoMount) defaultConfig; + ${cfg.settings.Mounts.IPNS}.d = lib.mkIf (cfg.autoMount) defaultConfig; + }; # The hardened systemd unit breaks the fuse-mount function according to documentation in the unit file itself - systemd.packages = if cfg.autoMount - then [ cfg.package.systemd_unit ] - else [ cfg.package.systemd_unit_hardened ]; + systemd.packages = + if cfg.autoMount then [ cfg.package.systemd_unit ] else [ cfg.package.systemd_unit_hardened ]; services.kubo.settings = lib.mkIf cfg.autoMount { Mounts.FuseAllowOther = lib.mkDefault true; }; - systemd.services.ipfs = { - path = [ "/run/wrappers" cfg.package ]; - environment.IPFS_PATH = cfg.dataDir; - - preStart = '' - if [[ ! -f "$IPFS_PATH/config" ]]; then - ipfs init --empty-repo=${lib.boolToString cfg.emptyRepo} - else - # After an unclean shutdown this file may exist which will cause the config command to attempt to talk to the daemon. This will hang forever if systemd is holding our sockets open. - rm -vf "$IPFS_PATH/api" - '' + lib.optionalString cfg.autoMigrate '' - '${lib.getExe pkgs.kubo-migrator}' -to '${cfg.package.repoVersion}' -y - '' + '' - fi - ipfs --offline config show | - ${pkgs.jq}/bin/jq -s '.[0].Pinning as $Pinning | .[0].Identity as $Identity | .[1] + {$Identity,$Pinning}' - '${configFile}' | - - # This command automatically injects the private key and other secrets from - # the old config file back into the new config file. - # Unfortunately, it doesn't keep the original `Identity.PeerID`, - # so we need `ipfs config show` and jq above. - # See https://github.com/ipfs/kubo/issues/8993 for progress on fixing this problem. - # Kubo also wants a specific version of the original "Pinning.RemoteServices" - # section (redacted by `ipfs config show`), such that that section doesn't - # change when the changes are applied. Whyyyyyy..... - ipfs --offline config replace - - ''; - postStop = lib.mkIf cfg.autoMount '' - # After an unclean shutdown the fuse mounts at cfg.settings.Mounts.IPFS and cfg.settings.Mounts.IPNS are locked - umount --quiet '${cfg.settings.Mounts.IPFS}' '${cfg.settings.Mounts.IPNS}' || true - ''; - serviceConfig = { - ExecStart = [ "" "${cfg.package}/bin/ipfs daemon ${kuboFlags}" ]; - User = cfg.user; - Group = cfg.group; - StateDirectory = ""; - ReadWritePaths = lib.optionals (!cfg.autoMount) [ "" cfg.dataDir ]; - # Make sure the socket units are started before ipfs.service - Sockets = [ "ipfs-gateway.socket" "ipfs-api.socket" ]; - } // lib.optionalAttrs (cfg.serviceFdlimit != null) { LimitNOFILE = cfg.serviceFdlimit; }; - } // lib.optionalAttrs (!cfg.startWhenNeeded) { - wantedBy = [ "default.target" ]; - }; + systemd.services.ipfs = + { + path = [ + "/run/wrappers" + cfg.package + ]; + environment.IPFS_PATH = cfg.dataDir; + + preStart = + '' + if [[ ! -f "$IPFS_PATH/config" ]]; then + ipfs init --empty-repo=${lib.boolToString cfg.emptyRepo} + else + # After an unclean shutdown this file may exist which will cause the config command to attempt to talk to the daemon. This will hang forever if systemd is holding our sockets open. + rm -vf "$IPFS_PATH/api" + '' + + lib.optionalString cfg.autoMigrate '' + '${lib.getExe pkgs.kubo-migrator}' -to '${cfg.package.repoVersion}' -y + '' + + '' + fi + ipfs --offline config show | + ${pkgs.jq}/bin/jq -s '.[0].Pinning as $Pinning | .[0].Identity as $Identity | .[1] + {$Identity,$Pinning}' - '${configFile}' | + + # This command automatically injects the private key and other secrets from + # the old config file back into the new config file. + # Unfortunately, it doesn't keep the original `Identity.PeerID`, + # so we need `ipfs config show` and jq above. + # See https://github.com/ipfs/kubo/issues/8993 for progress on fixing this problem. + # Kubo also wants a specific version of the original "Pinning.RemoteServices" + # section (redacted by `ipfs config show`), such that that section doesn't + # change when the changes are applied. Whyyyyyy..... + ipfs --offline config replace - + ''; + postStop = lib.mkIf cfg.autoMount '' + # After an unclean shutdown the fuse mounts at cfg.settings.Mounts.IPFS and cfg.settings.Mounts.IPNS are locked + umount --quiet '${cfg.settings.Mounts.IPFS}' '${cfg.settings.Mounts.IPNS}' || true + ''; + serviceConfig = { + ExecStart = [ + "" + "${cfg.package}/bin/ipfs daemon ${kuboFlags}" + ]; + User = cfg.user; + Group = cfg.group; + StateDirectory = ""; + ReadWritePaths = lib.optionals (!cfg.autoMount) [ + "" + cfg.dataDir + ]; + # Make sure the socket units are started before ipfs.service + Sockets = [ + "ipfs-gateway.socket" + "ipfs-api.socket" + ]; + } // lib.optionalAttrs (cfg.serviceFdlimit != null) { LimitNOFILE = cfg.serviceFdlimit; }; + } + // lib.optionalAttrs (!cfg.startWhenNeeded) { + wantedBy = [ "default.target" ]; + }; systemd.sockets.ipfs-gateway = { wantedBy = [ "sockets.target" ]; socketConfig = { - ListenStream = - [ "" ] ++ (multiaddrsToListenStreams cfg.settings.Addresses.Gateway); - ListenDatagram = - [ "" ] ++ (multiaddrsToListenDatagrams cfg.settings.Addresses.Gateway); + ListenStream = [ "" ] ++ (multiaddrsToListenStreams cfg.settings.Addresses.Gateway); + ListenDatagram = [ "" ] ++ (multiaddrsToListenDatagrams cfg.settings.Addresses.Gateway); }; }; @@ -389,8 +440,10 @@ in socketConfig = { # We also include "%t/ipfs.sock" because there is no way to put the "%t" # in the multiaddr. - ListenStream = - [ "" "%t/ipfs.sock" ] ++ (multiaddrsToListenStreams cfg.settings.Addresses.API); + ListenStream = [ + "" + "%t/ipfs.sock" + ] ++ (multiaddrsToListenStreams cfg.settings.Addresses.API); SocketMode = "0660"; SocketUser = cfg.user; SocketGroup = cfg.group; @@ -411,23 +464,62 @@ in (lib.mkRenamedOptionModule [ "services" "ipfs" "defaultMode" ] [ "services" "kubo" "defaultMode" ]) (lib.mkRenamedOptionModule [ "services" "ipfs" "autoMount" ] [ "services" "kubo" "autoMount" ]) (lib.mkRenamedOptionModule [ "services" "ipfs" "autoMigrate" ] [ "services" "kubo" "autoMigrate" ]) - (lib.mkRenamedOptionModule [ "services" "ipfs" "ipfsMountDir" ] [ "services" "kubo" "settings" "Mounts" "IPFS" ]) - (lib.mkRenamedOptionModule [ "services" "ipfs" "ipnsMountDir" ] [ "services" "kubo" "settings" "Mounts" "IPNS" ]) - (lib.mkRenamedOptionModule [ "services" "ipfs" "gatewayAddress" ] [ "services" "kubo" "settings" "Addresses" "Gateway" ]) - (lib.mkRenamedOptionModule [ "services" "ipfs" "apiAddress" ] [ "services" "kubo" "settings" "Addresses" "API" ]) - (lib.mkRenamedOptionModule [ "services" "ipfs" "swarmAddress" ] [ "services" "kubo" "settings" "Addresses" "Swarm" ]) + (lib.mkRenamedOptionModule + [ "services" "ipfs" "ipfsMountDir" ] + [ "services" "kubo" "settings" "Mounts" "IPFS" ] + ) + (lib.mkRenamedOptionModule + [ "services" "ipfs" "ipnsMountDir" ] + [ "services" "kubo" "settings" "Mounts" "IPNS" ] + ) + (lib.mkRenamedOptionModule + [ "services" "ipfs" "gatewayAddress" ] + [ "services" "kubo" "settings" "Addresses" "Gateway" ] + ) + (lib.mkRenamedOptionModule + [ "services" "ipfs" "apiAddress" ] + [ "services" "kubo" "settings" "Addresses" "API" ] + ) + (lib.mkRenamedOptionModule + [ "services" "ipfs" "swarmAddress" ] + [ "services" "kubo" "settings" "Addresses" "Swarm" ] + ) (lib.mkRenamedOptionModule [ "services" "ipfs" "enableGC" ] [ "services" "kubo" "enableGC" ]) (lib.mkRenamedOptionModule [ "services" "ipfs" "emptyRepo" ] [ "services" "kubo" "emptyRepo" ]) (lib.mkRenamedOptionModule [ "services" "ipfs" "extraConfig" ] [ "services" "kubo" "settings" ]) (lib.mkRenamedOptionModule [ "services" "ipfs" "extraFlags" ] [ "services" "kubo" "extraFlags" ]) - (lib.mkRenamedOptionModule [ "services" "ipfs" "localDiscovery" ] [ "services" "kubo" "localDiscovery" ]) - (lib.mkRenamedOptionModule [ "services" "ipfs" "serviceFdlimit" ] [ "services" "kubo" "serviceFdlimit" ]) - (lib.mkRenamedOptionModule [ "services" "ipfs" "startWhenNeeded" ] [ "services" "kubo" "startWhenNeeded" ]) + (lib.mkRenamedOptionModule + [ "services" "ipfs" "localDiscovery" ] + [ "services" "kubo" "localDiscovery" ] + ) + (lib.mkRenamedOptionModule + [ "services" "ipfs" "serviceFdlimit" ] + [ "services" "kubo" "serviceFdlimit" ] + ) + (lib.mkRenamedOptionModule + [ "services" "ipfs" "startWhenNeeded" ] + [ "services" "kubo" "startWhenNeeded" ] + ) (lib.mkRenamedOptionModule [ "services" "kubo" "extraConfig" ] [ "services" "kubo" "settings" ]) - (lib.mkRenamedOptionModule [ "services" "kubo" "gatewayAddress" ] [ "services" "kubo" "settings" "Addresses" "Gateway" ]) - (lib.mkRenamedOptionModule [ "services" "kubo" "apiAddress" ] [ "services" "kubo" "settings" "Addresses" "API" ]) - (lib.mkRenamedOptionModule [ "services" "kubo" "swarmAddress" ] [ "services" "kubo" "settings" "Addresses" "Swarm" ]) - (lib.mkRenamedOptionModule [ "services" "kubo" "ipfsMountDir" ] [ "services" "kubo" "settings" "Mounts" "IPFS" ]) - (lib.mkRenamedOptionModule [ "services" "kubo" "ipnsMountDir" ] [ "services" "kubo" "settings" "Mounts" "IPNS" ]) + (lib.mkRenamedOptionModule + [ "services" "kubo" "gatewayAddress" ] + [ "services" "kubo" "settings" "Addresses" "Gateway" ] + ) + (lib.mkRenamedOptionModule + [ "services" "kubo" "apiAddress" ] + [ "services" "kubo" "settings" "Addresses" "API" ] + ) + (lib.mkRenamedOptionModule + [ "services" "kubo" "swarmAddress" ] + [ "services" "kubo" "settings" "Addresses" "Swarm" ] + ) + (lib.mkRenamedOptionModule + [ "services" "kubo" "ipfsMountDir" ] + [ "services" "kubo" "settings" "Mounts" "IPFS" ] + ) + (lib.mkRenamedOptionModule + [ "services" "kubo" "ipnsMountDir" ] + [ "services" "kubo" "settings" "Mounts" "IPNS" ] + ) ]; } diff --git a/nixos/modules/services/network-filesystems/litestream/default.nix b/nixos/modules/services/network-filesystems/litestream/default.nix index f4b0281ebbe200..d8d3440c25d34f 100644 --- a/nixos/modules/services/network-filesystems/litestream/default.nix +++ b/nixos/modules/services/network-filesystems/litestream/default.nix @@ -1,7 +1,12 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.litestream; - settingsFormat = pkgs.formats.yaml {}; + settingsFormat = pkgs.formats.yaml { }; in { options.services.litestream = { @@ -84,7 +89,7 @@ in group = "litestream"; isSystemUser = true; }; - users.groups.litestream = {}; + users.groups.litestream = { }; }; meta.doc = ./default.md; diff --git a/nixos/modules/services/network-filesystems/netatalk.nix b/nixos/modules/services/network-filesystems/netatalk.nix index e8c97df3151b24..b8475c05ccb7f1 100644 --- a/nixos/modules/services/network-filesystems/netatalk.nix +++ b/nixos/modules/services/network-filesystems/netatalk.nix @@ -1,9 +1,15 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.netatalk; settingsFormat = pkgs.formats.ini { }; afpConfFile = settingsFormat.generate "afp.conf" cfg.settings; -in { +in +{ options = { services.netatalk = { @@ -19,7 +25,9 @@ in { inherit (settingsFormat) type; default = { }; example = { - Global = { "uam list" = "uams_guest.so"; }; + Global = { + "uam list" = "uams_guest.so"; + }; Homes = { path = "afp-data"; "basedir regex" = "/home"; @@ -47,13 +55,22 @@ in { }; }; - imports = (map (option: - lib.mkRemovedOptionModule [ "services" "netatalk" option ] - "This option was removed in favor of `services.netatalk.settings`.") [ - "extraConfig" - "homes" - "volumes" - ]); + imports = ( + map + ( + option: + lib.mkRemovedOptionModule [ + "services" + "netatalk" + option + ] "This option was removed in favor of `services.netatalk.settings`." + ) + [ + "extraConfig" + "homes" + "volumes" + ] + ); config = lib.mkIf cfg.enable { @@ -64,9 +81,11 @@ in { systemd.services.netatalk = { description = "Netatalk AFP fileserver for Macintosh clients"; - unitConfig.Documentation = - "man:afp.conf(5) man:netatalk(8) man:afpd(8) man:cnid_metad(8) man:cnid_dbd(8)"; - after = [ "network.target" "avahi-daemon.service" ]; + unitConfig.Documentation = "man:afp.conf(5) man:netatalk(8) man:afpd(8) man:cnid_metad(8) man:cnid_dbd(8)"; + after = [ + "network.target" + "avahi-daemon.service" + ]; wantedBy = [ "multi-user.target" ]; path = [ pkgs.netatalk ]; diff --git a/nixos/modules/services/network-filesystems/nfsd.nix b/nixos/modules/services/network-filesystems/nfsd.nix index 67597d37813fe7..8729945fc3fd27 100644 --- a/nixos/modules/services/network-filesystems/nfsd.nix +++ b/nixos/modules/services/network-filesystems/nfsd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.nfs.server; @@ -9,8 +14,14 @@ in { imports = [ - (lib.mkRenamedOptionModule [ "services" "nfs" "lockdPort" ] [ "services" "nfs" "server" "lockdPort" ]) - (lib.mkRenamedOptionModule [ "services" "nfs" "statdPort" ] [ "services" "nfs" "server" "statdPort" ]) + (lib.mkRenamedOptionModule + [ "services" "nfs" "lockdPort" ] + [ "services" "nfs" "server" "lockdPort" ] + ) + (lib.mkRenamedOptionModule + [ "services" "nfs" "statdPort" ] + [ "services" "nfs" "server" "statdPort" ] + ) ]; ###### interface @@ -105,7 +116,6 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { @@ -116,35 +126,31 @@ in environment.etc.exports.source = exports; - systemd.services.nfs-server = - { enable = true; - wantedBy = [ "multi-user.target" ]; + systemd.services.nfs-server = { + enable = true; + wantedBy = [ "multi-user.target" ]; - preStart = - '' - mkdir -p /var/lib/nfs/v4recovery - ''; - }; + preStart = '' + mkdir -p /var/lib/nfs/v4recovery + ''; + }; - systemd.services.nfs-mountd = - { enable = true; - restartTriggers = [ exports ]; - - preStart = - '' - mkdir -p /var/lib/nfs - - ${lib.optionalString cfg.createMountPoints - '' - # create export directories: - # skip comments, take first col which may either be a quoted - # "foo bar" or just foo (-> man export) - sed '/^#.*/d;s/^"\([^"]*\)".*/\1/;t;s/[ ].*//' ${exports} \ - | xargs -d '\n' mkdir -p - '' - } - ''; - }; + systemd.services.nfs-mountd = { + enable = true; + restartTriggers = [ exports ]; + + preStart = '' + mkdir -p /var/lib/nfs + + ${lib.optionalString cfg.createMountPoints '' + # create export directories: + # skip comments, take first col which may either be a quoted + # "foo bar" or just foo (-> man export) + sed '/^#.*/d;s/^"\([^"]*\)".*/\1/;t;s/[ ].*//' ${exports} \ + | xargs -d '\n' mkdir -p + ''} + ''; + }; }; diff --git a/nixos/modules/services/network-filesystems/openafs/client.nix b/nixos/modules/services/network-filesystems/openafs/client.nix index e7c2b952632844..d0989253576b22 100644 --- a/nixos/modules/services/network-filesystems/openafs/client.nix +++ b/nixos/modules/services/network-filesystems/openafs/client.nix @@ -1,10 +1,23 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: # openafsMod, openafsBin, mkCellServDB with import ./lib.nix { inherit config lib pkgs; }; let - inherit (lib) getBin literalExpression mkOption mkIf optionalString singleton types; + inherit (lib) + getBin + literalExpression + mkOption + mkIf + optionalString + singleton + types + ; cfg = config.services.openafsClient; @@ -13,7 +26,9 @@ let sha256 = "1wmjn6mmyy2r8p10nlbdzs4nrqxy8a9pjyrdciy5nmppg4053rk2"; }; - clientServDB = pkgs.writeText "client-cellServDB-${cfg.cellName}" (mkCellServDB cfg.cellName cfg.cellServDB); + clientServDB = pkgs.writeText "client-cellServDB-${cfg.cellName}" ( + mkCellServDB cfg.cellName cfg.cellServDB + ); afsConfig = pkgs.runCommand "afsconfig" { preferLocalBuild = true; } '' mkdir -p $out @@ -50,16 +65,26 @@ in }; cellServDB = mkOption { - default = []; - type = with types; listOf (submodule { options = cellServDBConfig; }); + default = [ ]; + type = + with types; + listOf (submodule { + options = cellServDBConfig; + }); description = '' This cell's database server records, added to the global CellServDB. See CellServDB(5) man page for syntax. Ignored when `afsdb` is set to `true`. ''; example = [ - { ip = "1.2.3.4"; dnsname = "first.afsdb.server.dns.fqdn.org"; } - { ip = "2.3.4.5"; dnsname = "second.afsdb.server.dns.fqdn.org"; } + { + ip = "1.2.3.4"; + dnsname = "first.afsdb.server.dns.fqdn.org"; + } + { + ip = "2.3.4.5"; + dnsname = "second.afsdb.server.dns.fqdn.org"; + } ]; }; @@ -179,16 +204,17 @@ in }; }; - ###### implementation config = mkIf cfg.enable { assertions = [ - { assertion = cfg.afsdb || cfg.cellServDB != []; + { + assertion = cfg.afsdb || cfg.cellServDB != [ ]; message = "You should specify all cell-local database servers in config.services.openafsClient.cellServDB or set config.services.openafsClient.afsdb."; } - { assertion = cfg.cellName != ""; + { + assertion = cfg.cellName != ""; message = "You must specify the local cell name in config.services.openafsClient.cellName."; } ]; @@ -216,8 +242,10 @@ in description = "AFS client"; wantedBy = [ "multi-user.target" ]; wants = lib.optional (!cfg.startDisconnected) "network-online.target"; - after = singleton (if cfg.startDisconnected then "network.target" else "network-online.target"); - serviceConfig = { RemainAfterExit = true; }; + after = singleton (if cfg.startDisconnected then "network.target" else "network-online.target"); + serviceConfig = { + RemainAfterExit = true; + }; restartIfChanged = false; preStart = '' diff --git a/nixos/modules/services/network-filesystems/openafs/lib.nix b/nixos/modules/services/network-filesystems/openafs/lib.nix index 726c47b7057556..abf59226abfe08 100644 --- a/nixos/modules/services/network-filesystems/openafs/lib.nix +++ b/nixos/modules/services/network-filesystems/openafs/lib.nix @@ -1,15 +1,25 @@ -{ config, lib, ...}: +{ config, lib, ... }: let - inherit (lib) concatStringsSep mkOption types optionalString; + inherit (lib) + concatStringsSep + mkOption + types + optionalString + ; -in { +in +{ - mkCellServDB = cellName: db: '' - >${cellName} - '' + (concatStringsSep "\n" (map (dbm: optionalString (dbm.ip != "" && dbm.dnsname != "") "${dbm.ip} #${dbm.dnsname}") - db)) - + "\n"; + mkCellServDB = + cellName: db: + '' + >${cellName} + '' + + (concatStringsSep "\n" ( + map (dbm: optionalString (dbm.ip != "" && dbm.dnsname != "") "${dbm.ip} #${dbm.dnsname}") db + )) + + "\n"; # CellServDB configuration type cellServDBConfig = { diff --git a/nixos/modules/services/network-filesystems/openafs/server.nix b/nixos/modules/services/network-filesystems/openafs/server.nix index 8186277b477752..4286bc7dbd5486 100644 --- a/nixos/modules/services/network-filesystems/openafs/server.nix +++ b/nixos/modules/services/network-filesystems/openafs/server.nix @@ -1,68 +1,100 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: # openafsBin, openafsSrv, mkCellServDB with import ./lib.nix { inherit config lib pkgs; }; let - inherit (lib) concatStringsSep literalExpression mkIf mkOption mkEnableOption - mkPackageOption optionalString types; - - bosConfig = pkgs.writeText "BosConfig" ('' - restrictmode 1 - restarttime 16 0 0 0 0 - checkbintime 3 0 5 0 0 - '' + (optionalString cfg.roles.database.enable '' - bnode simple vlserver 1 - parm ${openafsSrv}/libexec/openafs/vlserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} ${cfg.roles.database.vlserverArgs} - end - bnode simple ptserver 1 - parm ${openafsSrv}/libexec/openafs/ptserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} ${cfg.roles.database.ptserverArgs} - end - '') + (optionalString cfg.roles.fileserver.enable '' - bnode dafs dafs 1 - parm ${openafsSrv}/libexec/openafs/dafileserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} -udpsize ${udpSizeStr} ${cfg.roles.fileserver.fileserverArgs} - parm ${openafsSrv}/libexec/openafs/davolserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} -udpsize ${udpSizeStr} ${cfg.roles.fileserver.volserverArgs} - parm ${openafsSrv}/libexec/openafs/salvageserver ${cfg.roles.fileserver.salvageserverArgs} - parm ${openafsSrv}/libexec/openafs/dasalvager ${cfg.roles.fileserver.salvagerArgs} - end - '') + (optionalString (cfg.roles.database.enable && cfg.roles.backup.enable && (!cfg.roles.backup.enableFabs)) '' - bnode simple buserver 1 - parm ${openafsSrv}/libexec/openafs/buserver ${cfg.roles.backup.buserverArgs} ${optionalString useBuCellServDB "-cellservdb /etc/openafs/backup/"} - end - '') + (optionalString (cfg.roles.database.enable && - cfg.roles.backup.enable && - cfg.roles.backup.enableFabs) '' - bnode simple buserver 1 - parm ${lib.getBin pkgs.fabs}/bin/fabsys server --config ${fabsConfFile} ${cfg.roles.backup.fabsArgs} - end - '')); - - netInfo = if (cfg.advertisedAddresses != []) then - pkgs.writeText "NetInfo" ((concatStringsSep "\nf " cfg.advertisedAddresses) + "\n") - else null; - - buCellServDB = pkgs.writeText "backup-cellServDB-${cfg.cellName}" - (mkCellServDB cfg.cellName cfg.roles.backup.cellServDB); - - useBuCellServDB = (cfg.roles.backup.cellServDB != []) && (!cfg.roles.backup.enableFabs); + inherit (lib) + concatStringsSep + literalExpression + mkIf + mkOption + mkEnableOption + mkPackageOption + optionalString + types + ; + + bosConfig = pkgs.writeText "BosConfig" ( + '' + restrictmode 1 + restarttime 16 0 0 0 0 + checkbintime 3 0 5 0 0 + '' + + (optionalString cfg.roles.database.enable '' + bnode simple vlserver 1 + parm ${openafsSrv}/libexec/openafs/vlserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} ${cfg.roles.database.vlserverArgs} + end + bnode simple ptserver 1 + parm ${openafsSrv}/libexec/openafs/ptserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} ${cfg.roles.database.ptserverArgs} + end + '') + + (optionalString cfg.roles.fileserver.enable '' + bnode dafs dafs 1 + parm ${openafsSrv}/libexec/openafs/dafileserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} -udpsize ${udpSizeStr} ${cfg.roles.fileserver.fileserverArgs} + parm ${openafsSrv}/libexec/openafs/davolserver ${optionalString cfg.dottedPrincipals "-allow-dotted-principals"} -udpsize ${udpSizeStr} ${cfg.roles.fileserver.volserverArgs} + parm ${openafsSrv}/libexec/openafs/salvageserver ${cfg.roles.fileserver.salvageserverArgs} + parm ${openafsSrv}/libexec/openafs/dasalvager ${cfg.roles.fileserver.salvagerArgs} + end + '') + + (optionalString + (cfg.roles.database.enable && cfg.roles.backup.enable && (!cfg.roles.backup.enableFabs)) + '' + bnode simple buserver 1 + parm ${openafsSrv}/libexec/openafs/buserver ${cfg.roles.backup.buserverArgs} ${optionalString useBuCellServDB "-cellservdb /etc/openafs/backup/"} + end + '' + ) + + (optionalString + (cfg.roles.database.enable && cfg.roles.backup.enable && cfg.roles.backup.enableFabs) + '' + bnode simple buserver 1 + parm ${lib.getBin pkgs.fabs}/bin/fabsys server --config ${fabsConfFile} ${cfg.roles.backup.fabsArgs} + end + '' + ) + ); + + netInfo = + if (cfg.advertisedAddresses != [ ]) then + pkgs.writeText "NetInfo" ((concatStringsSep "\nf " cfg.advertisedAddresses) + "\n") + else + null; + + buCellServDB = pkgs.writeText "backup-cellServDB-${cfg.cellName}" ( + mkCellServDB cfg.cellName cfg.roles.backup.cellServDB + ); + + useBuCellServDB = (cfg.roles.backup.cellServDB != [ ]) && (!cfg.roles.backup.enableFabs); cfg = config.services.openafsServer; udpSizeStr = toString cfg.udpPacketSize; - fabsConfFile = pkgs.writeText "fabs.yaml" (builtins.toJSON ({ - afs = { - aklog = cfg.package + "/bin/aklog"; - cell = cfg.cellName; - dumpscan = cfg.package + "/bin/afsdump_scan"; - fs = cfg.package + "/bin/fs"; - pts = cfg.package + "/bin/pts"; - vos = cfg.package + "/bin/vos"; - }; - k5start.command = (lib.getBin pkgs.kstart) + "/bin/k5start"; - } // cfg.roles.backup.fabsExtraConfig)); + fabsConfFile = pkgs.writeText "fabs.yaml" ( + builtins.toJSON ( + { + afs = { + aklog = cfg.package + "/bin/aklog"; + cell = cfg.cellName; + dumpscan = cfg.package + "/bin/afsdump_scan"; + fs = cfg.package + "/bin/fs"; + pts = cfg.package + "/bin/pts"; + vos = cfg.package + "/bin/vos"; + }; + k5start.command = (lib.getBin pkgs.kstart) + "/bin/k5start"; + } + // cfg.roles.backup.fabsExtraConfig + ) + ); -in { +in +{ options = { @@ -84,7 +116,7 @@ in { advertisedAddresses = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = "List of IP addresses this server is advertised under. See NetInfo(5)"; }; @@ -96,8 +128,8 @@ in { }; cellServDB = mkOption { - default = []; - type = with types; listOf (submodule [ { options = cellServDBConfig;} ]); + default = [ ]; + type = with types; listOf (submodule [ { options = cellServDBConfig; } ]); description = "Definition of all cell-local database server machines."; }; @@ -194,8 +226,8 @@ in { }; cellServDB = mkOption { - default = []; - type = with types; listOf (submodule [ { options = cellServDBConfig;} ]); + default = [ ]; + type = with types; listOf (submodule [ { options = cellServDBConfig; } ]); description = '' Definition of all cell-local backup database server machines. Use this when your cell uses less backup database servers than @@ -214,22 +246,22 @@ in { }; fabsExtraConfig = mkOption { - default = {}; + default = { }; type = types.attrs; description = '' Additional configuration parameters for the FABS backup server. ''; example = literalExpression '' - { - afs.localauth = true; - afs.keytab = config.sops.secrets.fabsKeytab.path; - } + { + afs.localauth = true; + afs.keytab = config.sops.secrets.fabsKeytab.path; + } ''; }; }; }; - dottedPrincipals= mkOption { + dottedPrincipals = mkOption { default = false; type = types.bool; description = '' @@ -257,10 +289,12 @@ in { config = mkIf cfg.enable { assertions = [ - { assertion = cfg.cellServDB != []; + { + assertion = cfg.cellServDB != [ ]; message = "You must specify all cell-local database servers in config.services.openafsServer.cellServDB."; } - { assertion = cfg.cellName != ""; + { + assertion = cfg.cellName != ""; message = "You must specify the local cell name in config.services.openafsServer.cellName."; } ]; diff --git a/nixos/modules/services/network-filesystems/orangefs/client.nix b/nixos/modules/services/network-filesystems/orangefs/client.nix index 3923289e6f6416..d1e2535f4bde24 100644 --- a/nixos/modules/services/network-filesystems/orangefs/client.nix +++ b/nixos/modules/services/network-filesystems/orangefs/client.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ...} : +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.orangefs.client; -in { +in +{ ###### interface options = { @@ -11,7 +17,7 @@ in { extraOptions = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; description = "Extra command line options for pvfs2-client."; }; @@ -22,38 +28,46 @@ in { the pvfs client service needs to be running for it to be mounted. ''; - example = [{ - mountPoint = "/orangefs"; - target = "tcp://server:3334/orangefs"; - }]; - - type = with lib.types; listOf (submodule ({ ... } : { - options = { - - mountPoint = lib.mkOption { - type = lib.types.str; - default = "/orangefs"; - description = "Mount point."; - }; - - options = lib.mkOption { - type = with lib.types; listOf str; - default = []; - description = "Mount options"; - }; - - target = lib.mkOption { - type = lib.types.str; - example = "tcp://server:3334/orangefs"; - description = "Target URL"; - }; - }; - })); + example = [ + { + mountPoint = "/orangefs"; + target = "tcp://server:3334/orangefs"; + } + ]; + + type = + with lib.types; + listOf ( + submodule ( + { ... }: + { + options = { + + mountPoint = lib.mkOption { + type = lib.types.str; + default = "/orangefs"; + description = "Mount point."; + }; + + options = lib.mkOption { + type = with lib.types; listOf str; + default = [ ]; + description = "Mount options"; + }; + + target = lib.mkOption { + type = lib.types.str; + example = "tcp://server:3334/orangefs"; + description = "Target URL"; + }; + }; + } + ) + ); }; }; }; - ###### implementation config = lib.mkIf cfg.enable { @@ -69,9 +83,9 @@ in { serviceConfig = { Type = "simple"; - ExecStart = '' - ${pkgs.orangefs}/bin/pvfs2-client-core \ - --logtype=syslog ${lib.concatStringsSep " " cfg.extraOptions} + ExecStart = '' + ${pkgs.orangefs}/bin/pvfs2-client-core \ + --logtype=syslog ${lib.concatStringsSep " " cfg.extraOptions} ''; TimeoutStopSec = "120"; @@ -90,4 +104,3 @@ in { }) cfg.fileSystems; }; } - diff --git a/nixos/modules/services/network-filesystems/orangefs/server.nix b/nixos/modules/services/network-filesystems/orangefs/server.nix index c198d47645592b..99d7b27011c25e 100644 --- a/nixos/modules/services/network-filesystems/orangefs/server.nix +++ b/nixos/modules/services/network-filesystems/orangefs/server.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ...} : +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.orangefs.server; @@ -20,22 +25,28 @@ let ${lib.concatStringsSep "\n" ( - lib.imap0 (i: alias: - let - begin = i * handleStep + 3; - end = begin + handleStep - 1; - in "Range ${alias} ${toString begin}-${toString end}") aliases - )} + lib.imap0 ( + i: alias: + let + begin = i * handleStep + 3; + end = begin + handleStep - 1; + in + "Range ${alias} ${toString begin}-${toString end}" + ) aliases + )} ${lib.concatStringsSep "\n" ( - lib.imap0 (i: alias: - let - begin = i * handleStep + 3 + (lib.length aliases) * handleStep; - end = begin + handleStep - 1; - in "Range ${alias} ${toString begin}-${toString end}") aliases - )} + lib.imap0 ( + i: alias: + let + begin = i * handleStep + 3 + (lib.length aliases) * handleStep; + end = begin + handleStep - 1; + in + "Range ${alias} ${toString begin}-${toString end}" + ) aliases + )} @@ -66,7 +77,8 @@ let ${lib.concatStringsSep "\n" fileSystems} ''; -in { +in +{ ###### interface options = { @@ -74,7 +86,12 @@ in { enable = lib.mkEnableOption "OrangeFS server"; logType = lib.mkOption { - type = with lib.types; enum [ "file" "syslog" ]; + type = + with lib.types; + enum [ + "file" + "syslog" + ]; default = "syslog"; description = "Destination for log messages."; }; @@ -96,7 +113,10 @@ in { BMIModules = lib.mkOption { type = with lib.types; listOf str; default = [ "bmi_tcp" ]; - example = [ "bmi_tcp" "bmi_ib"]; + example = [ + "bmi_tcp" + "bmi_ib" + ]; description = "List of BMI modules to load."; }; @@ -114,7 +134,7 @@ in { servers = lib.mkOption { type = with lib.types; attrsOf lib.types.str; - default = {}; + default = { }; example = { node1 = "tcp://node1:3334"; node2 = "tcp://node2:3334"; @@ -126,7 +146,9 @@ in { description = '' These options will create the `` sections of config file. ''; - default = { orangefs = {}; }; + default = { + orangefs = { }; + }; example = lib.literalExpression '' { fs1 = { @@ -138,45 +160,52 @@ in { }; } ''; - type = with lib.types; attrsOf (submodule ({ ... } : { - options = { - id = lib.mkOption { - type = lib.types.int; - default = 1; - description = "File system ID (must be unique within configuration)."; - }; - - rootHandle = lib.mkOption { - type = lib.types.int; - default = 3; - description = "File system root ID."; - }; - - extraConfig = lib.mkOption { - type = lib.types.lines; - default = ""; - description = "Extra config for `` section."; - }; - - troveSyncMeta = lib.mkOption { - type = lib.types.bool; - default = true; - description = "Sync meta data."; - }; - - troveSyncData = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Sync data."; - }; - - extraStorageHints = lib.mkOption { - type = lib.types.lines; - default = ""; - description = "Extra config for `` section."; - }; - }; - })); + type = + with lib.types; + attrsOf ( + submodule ( + { ... }: + { + options = { + id = lib.mkOption { + type = lib.types.int; + default = 1; + description = "File system ID (must be unique within configuration)."; + }; + + rootHandle = lib.mkOption { + type = lib.types.int; + default = 3; + description = "File system root ID."; + }; + + extraConfig = lib.mkOption { + type = lib.types.lines; + default = ""; + description = "Extra config for `` section."; + }; + + troveSyncMeta = lib.mkOption { + type = lib.types.bool; + default = true; + description = "Sync meta data."; + }; + + troveSyncData = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Sync data."; + }; + + extraStorageHints = lib.mkOption { + type = lib.types.lines; + default = ""; + description = "Extra config for `` section."; + }; + }; + } + ) + ); }; }; }; @@ -191,7 +220,7 @@ in { isSystemUser = true; group = "orangefs"; }; - users.groups.orangefs = {}; + users.groups.orangefs = { }; # To format the file system the config file is needed. environment.etc."orangefs/server.conf" = { diff --git a/nixos/modules/services/network-filesystems/rsyncd.nix b/nixos/modules/services/network-filesystems/rsyncd.nix index 93dc41c3c956e8..810ed10b695da3 100644 --- a/nixos/modules/services/network-filesystems/rsyncd.nix +++ b/nixos/modules/services/network-filesystems/rsyncd.nix @@ -1,9 +1,15 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.rsyncd; settingsFormat = pkgs.formats.ini { }; configFile = settingsFormat.generate "rsyncd.conf" cfg.settings; -in { +in +{ options = { services.rsyncd = { @@ -32,7 +38,10 @@ in { cvs = { path = "/data/cvs"; comment = "CVS repository (requires authentication)"; - "auth users" = [ "tridge" "susan" ]; + "auth users" = [ + "tridge" + "susan" + ]; "secrets file" = "/etc/rsyncd.secrets"; }; }; @@ -51,68 +60,81 @@ in { }; }; - imports = (map (option: - lib.mkRemovedOptionModule [ "services" "rsyncd" option ] - "This option was removed in favor of `services.rsyncd.settings`.") [ - "address" - "extraConfig" - "motd" - "user" - "group" - ]); + imports = ( + map + ( + option: + lib.mkRemovedOptionModule [ + "services" + "rsyncd" + option + ] "This option was removed in favor of `services.rsyncd.settings`." + ) + [ + "address" + "extraConfig" + "motd" + "user" + "group" + ] + ); config = lib.mkIf cfg.enable { services.rsyncd.settings.global.port = toString cfg.port; - systemd = let - serviceConfigSecurity = { - ProtectSystem = "full"; - PrivateDevices = "on"; - NoNewPrivileges = "on"; - }; - in { - services.rsync = { - enable = !cfg.socketActivated; - aliases = [ "rsyncd.service" ]; - - description = "fast remote file copy program daemon"; - after = [ "network.target" ]; - documentation = [ "man:rsync(1)" "man:rsyncd.conf(5)" ]; - - serviceConfig = serviceConfigSecurity // { - ExecStart = - "${pkgs.rsync}/bin/rsync --daemon --no-detach --config=${configFile}"; - RestartSec = 1; + systemd = + let + serviceConfigSecurity = { + ProtectSystem = "full"; + PrivateDevices = "on"; + NoNewPrivileges = "on"; }; + in + { + services.rsync = { + enable = !cfg.socketActivated; + aliases = [ "rsyncd.service" ]; + + description = "fast remote file copy program daemon"; + after = [ "network.target" ]; + documentation = [ + "man:rsync(1)" + "man:rsyncd.conf(5)" + ]; + + serviceConfig = serviceConfigSecurity // { + ExecStart = "${pkgs.rsync}/bin/rsync --daemon --no-detach --config=${configFile}"; + RestartSec = 1; + }; - wantedBy = [ "multi-user.target" ]; - }; + wantedBy = [ "multi-user.target" ]; + }; - services."rsync@" = { - description = "fast remote file copy program daemon"; - after = [ "network.target" ]; + services."rsync@" = { + description = "fast remote file copy program daemon"; + after = [ "network.target" ]; - serviceConfig = serviceConfigSecurity // { - ExecStart = "${pkgs.rsync}/bin/rsync --daemon --config=${configFile}"; - StandardInput = "socket"; - StandardOutput = "inherit"; - StandardError = "journal"; + serviceConfig = serviceConfigSecurity // { + ExecStart = "${pkgs.rsync}/bin/rsync --daemon --config=${configFile}"; + StandardInput = "socket"; + StandardOutput = "inherit"; + StandardError = "journal"; + }; }; - }; - sockets.rsync = { - enable = cfg.socketActivated; + sockets.rsync = { + enable = cfg.socketActivated; - description = "socket for fast remote file copy program daemon"; - conflicts = [ "rsync.service" ]; + description = "socket for fast remote file copy program daemon"; + conflicts = [ "rsync.service" ]; - listenStreams = [ (toString cfg.port) ]; - socketConfig.Accept = true; + listenStreams = [ (toString cfg.port) ]; + socketConfig.Accept = true; - wantedBy = [ "sockets.target" ]; + wantedBy = [ "sockets.target" ]; + }; }; - }; }; diff --git a/nixos/modules/services/network-filesystems/samba-wsdd.nix b/nixos/modules/services/network-filesystems/samba-wsdd.nix index 60ede5a1bda21b..22c4f503109fa7 100644 --- a/nixos/modules/services/network-filesystems/samba-wsdd.nix +++ b/nixos/modules/services/network-filesystems/samba-wsdd.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.samba-wsdd; -in { +in +{ options = { services.samba-wsdd = { enable = lib.mkEnableOption '' @@ -58,7 +64,12 @@ in { extraOptions = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ "--shortlog" ]; - example = [ "--verbose" "--no-http" "--ipv4only" "--no-host" ]; + example = [ + "--verbose" + "--no-http" + "--ipv4only" + "--no-host" + ]; description = "Additional wsdd options."; }; }; @@ -76,9 +87,15 @@ in { DynamicUser = true; Type = "simple"; ExecStart = '' - ${pkgs.wsdd}/bin/wsdd ${lib.optionalString (cfg.interface != null) "--interface '${cfg.interface}'"} \ - ${lib.optionalString (cfg.hoplimit != null) "--hoplimit '${toString cfg.hoplimit}'"} \ - ${lib.optionalString (cfg.workgroup != null) "--workgroup '${cfg.workgroup}'"} \ + ${pkgs.wsdd}/bin/wsdd ${ + lib.optionalString (cfg.interface != null) "--interface '${cfg.interface}'" + } \ + ${ + lib.optionalString (cfg.hoplimit != null) "--hoplimit '${toString cfg.hoplimit}'" + } \ + ${ + lib.optionalString (cfg.workgroup != null) "--workgroup '${cfg.workgroup}'" + } \ ${lib.optionalString (cfg.hostname != null) "--hostname '${cfg.hostname}'"} \ ${lib.optionalString (cfg.domain != null) "--domain '${cfg.domain}'"} \ ${lib.optionalString cfg.discovery "--discovery --listen '${cfg.listen}'"} \ @@ -105,7 +122,12 @@ in { ProtectKernelModules = true; ProtectKernelLogs = true; ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" "AF_NETLINK" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + "AF_NETLINK" + ]; RestrictNamespaces = true; LockPersonality = true; MemoryDenyWriteExecute = true; diff --git a/nixos/modules/services/network-filesystems/samba.nix b/nixos/modules/services/network-filesystems/samba.nix index c0d12586dec834..9cc5a49168f67e 100644 --- a/nixos/modules/services/network-filesystems/samba.nix +++ b/nixos/modules/services/network-filesystems/samba.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.samba; @@ -7,9 +12,14 @@ let }; # Ensure the global section is always first globalConfigFile = settingsFormat.generate "smb-global.conf" { global = cfg.settings.global; }; - sharesConfigFile = settingsFormat.generate "smb-shares.conf" (lib.removeAttrs cfg.settings [ "global" ]); + sharesConfigFile = settingsFormat.generate "smb-shares.conf" ( + lib.removeAttrs cfg.settings [ "global" ] + ); - configFile = pkgs.concatText "smb.conf" [ globalConfigFile sharesConfigFile ]; + configFile = pkgs.concatText "smb.conf" [ + globalConfigFile + sharesConfigFile + ]; in @@ -21,7 +31,9 @@ in imports = [ (lib.mkRemovedOptionModule [ "services" "samba" "defaultShare" ] "") - (lib.mkRemovedOptionModule [ "services" "samba" "syncPasswordsByPam" ] "This option has been removed by upstream, see https://bugzilla.samba.org/show_bug.cgi?id=10669#c10") + (lib.mkRemovedOptionModule [ "services" "samba" "syncPasswordsByPam" ] + "This option has been removed by upstream, see https://bugzilla.samba.org/show_bug.cgi?id=10669#c10" + ) (lib.mkRemovedOptionModule [ "services" "samba" "configText" ] '' Use services.samba.settings instead. @@ -30,13 +42,29 @@ in text for config as introduced by RFC0042: https://github.com/NixOS/rfcs/blob/master/rfcs/0042-config-option.md '') - (lib.mkRemovedOptionModule [ "services" "samba" "extraConfig" ] "Use services.samba.settings instead.") - (lib.mkRenamedOptionModule [ "services" "samba" "invalidUsers" ] [ "services" "samba" "settings" "global" "invalid users" ]) - (lib.mkRenamedOptionModule [ "services" "samba" "securityType" ] [ "services" "samba" "settings" "global" "security" ]) + (lib.mkRemovedOptionModule [ + "services" + "samba" + "extraConfig" + ] "Use services.samba.settings instead.") + (lib.mkRenamedOptionModule + [ "services" "samba" "invalidUsers" ] + [ "services" "samba" "settings" "global" "invalid users" ] + ) + (lib.mkRenamedOptionModule + [ "services" "samba" "securityType" ] + [ "services" "samba" "settings" "global" "security" ] + ) (lib.mkRenamedOptionModule [ "services" "samba" "shares" ] [ "services" "samba" "settings" ]) - (lib.mkRenamedOptionModule [ "services" "samba" "enableWinbindd" ] [ "services" "samba" "winbindd" "enable" ]) - (lib.mkRenamedOptionModule [ "services" "samba" "enableNmbd" ] [ "services" "samba" "nmbd" "enable" ]) + (lib.mkRenamedOptionModule + [ "services" "samba" "enableWinbindd" ] + [ "services" "samba" "winbindd" "enable" ] + ) + (lib.mkRenamedOptionModule + [ "services" "samba" "enableNmbd" ] + [ "services" "samba" "nmbd" "enable" ] + ) ]; ###### interface @@ -126,7 +154,12 @@ in freeformType = settingsFormat.type; options = { global.security = lib.mkOption { - type = lib.types.enum [ "auto" "user" "domain" "ads" ]; + type = lib.types.enum [ + "auto" + "user" + "domain" + "ads" + ]; default = "user"; description = "Samba security type."; }; @@ -176,167 +209,192 @@ in ###### implementation - config = lib.mkMerge - [ { assertions = - [ { assertion = cfg.nsswins -> cfg.winbindd.enable; - message = "If services.samba.nsswins is enabled, then services.samba.winbindd.enable must also be enabled"; - } - ]; - } - - (lib.mkIf cfg.enable { - environment.etc."samba/smb.conf".source = configFile; - - system.nssModules = lib.optional cfg.nsswins cfg.package; - system.nssDatabases.hosts = lib.optional cfg.nsswins "wins"; - - systemd = { - slices.system-samba = { - description = "Samba (SMB Networking Protocol) Slice"; - }; - targets.samba = { - description = "Samba Server"; - after = [ "network.target" ]; - wants = [ "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; - }; - tmpfiles.rules = [ - "d /var/lock/samba - - - - -" - "d /var/log/samba - - - - -" - "d /var/cache/samba - - - - -" - "d /var/lib/samba/private - - - - -" - ]; - }; - - security.pam.services.samba = {}; - environment.systemPackages = [ cfg.package ]; - # Like other mount* related commands that need the setuid bit, this is - # required too. - security.wrappers."mount.cifs" = { - program = "mount.cifs"; - source = "${lib.getBin pkgs.cifs-utils}/bin/mount.cifs"; - owner = "root"; - group = "root"; - setuid = true; + config = lib.mkMerge [ + { + assertions = [ + { + assertion = cfg.nsswins -> cfg.winbindd.enable; + message = "If services.samba.nsswins is enabled, then services.samba.winbindd.enable must also be enabled"; + } + ]; + } + + (lib.mkIf cfg.enable { + environment.etc."samba/smb.conf".source = configFile; + + system.nssModules = lib.optional cfg.nsswins cfg.package; + system.nssDatabases.hosts = lib.optional cfg.nsswins "wins"; + + systemd = { + slices.system-samba = { + description = "Samba (SMB Networking Protocol) Slice"; }; - - networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall [ 139 445 ]; - networking.firewall.allowedUDPPorts = lib.mkIf cfg.openFirewall [ 137 138 ]; - }) - - (lib.mkIf (cfg.enable && cfg.nmbd.enable) { - systemd.services.samba-nmbd = { - description = "Samba NMB Daemon"; - documentation = [ "man:nmbd(8)" "man:samba(7)" "man:smb.conf(5)" ]; - - after = [ - "network.target" - "network-online.target" - ]; - - partOf = [ "samba.target" ]; - wantedBy = [ "samba.target" ]; + targets.samba = { + description = "Samba Server"; + after = [ "network.target" ]; wants = [ "network-online.target" ]; + wantedBy = [ "multi-user.target" ]; + }; + tmpfiles.rules = [ + "d /var/lock/samba - - - - -" + "d /var/log/samba - - - - -" + "d /var/cache/samba - - - - -" + "d /var/lib/samba/private - - - - -" + ]; + }; - environment.LD_LIBRARY_PATH = config.system.nssModules.path; - - serviceConfig = { - ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - ExecStart = "${cfg.package}/sbin/nmbd --foreground --no-process-group ${lib.escapeShellArgs cfg.nmbd.extraArgs}"; - LimitCORE = "infinity"; - PIDFile = "/run/samba/nmbd.pid"; - Slice = "system-samba.slice"; - Type = "notify"; - }; - - unitConfig.RequiresMountsFor = "/var/lib/samba"; + security.pam.services.samba = { }; + environment.systemPackages = [ cfg.package ]; + # Like other mount* related commands that need the setuid bit, this is + # required too. + security.wrappers."mount.cifs" = { + program = "mount.cifs"; + source = "${lib.getBin pkgs.cifs-utils}/bin/mount.cifs"; + owner = "root"; + group = "root"; + setuid = true; + }; - restartTriggers = [ configFile ]; + networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall [ + 139 + 445 + ]; + networking.firewall.allowedUDPPorts = lib.mkIf cfg.openFirewall [ + 137 + 138 + ]; + }) + + (lib.mkIf (cfg.enable && cfg.nmbd.enable) { + systemd.services.samba-nmbd = { + description = "Samba NMB Daemon"; + documentation = [ + "man:nmbd(8)" + "man:samba(7)" + "man:smb.conf(5)" + ]; + + after = [ + "network.target" + "network-online.target" + ]; + + partOf = [ "samba.target" ]; + wantedBy = [ "samba.target" ]; + wants = [ "network-online.target" ]; + + environment.LD_LIBRARY_PATH = config.system.nssModules.path; + + serviceConfig = { + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + ExecStart = "${cfg.package}/sbin/nmbd --foreground --no-process-group ${lib.escapeShellArgs cfg.nmbd.extraArgs}"; + LimitCORE = "infinity"; + PIDFile = "/run/samba/nmbd.pid"; + Slice = "system-samba.slice"; + Type = "notify"; }; - }) - (lib.mkIf (cfg.enable && cfg.smbd.enable) { - systemd.services.samba-smbd = { - description = "Samba SMB Daemon"; - documentation = [ "man:smbd(8)" "man:samba(7)" "man:smb.conf(5)" ]; + unitConfig.RequiresMountsFor = "/var/lib/samba"; - after = [ + restartTriggers = [ configFile ]; + }; + }) + + (lib.mkIf (cfg.enable && cfg.smbd.enable) { + systemd.services.samba-smbd = { + description = "Samba SMB Daemon"; + documentation = [ + "man:smbd(8)" + "man:samba(7)" + "man:smb.conf(5)" + ]; + + after = + [ "network.target" "network-online.target" - ] ++ lib.optionals (cfg.nmbd.enable) [ + ] + ++ lib.optionals (cfg.nmbd.enable) [ "samba-nmbd.service" - ] ++ lib.optionals (cfg.winbindd.enable) [ + ] + ++ lib.optionals (cfg.winbindd.enable) [ "samba-winbindd.service" ]; - partOf = [ "samba.target" ]; - wantedBy = [ "samba.target" ]; - wants = [ "network-online.target" ]; - - environment.LD_LIBRARY_PATH = config.system.nssModules.path; + partOf = [ "samba.target" ]; + wantedBy = [ "samba.target" ]; + wants = [ "network-online.target" ]; - serviceConfig = { - ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - ExecStart = "${cfg.package}/sbin/smbd --foreground --no-process-group ${lib.escapeShellArgs cfg.smbd.extraArgs}"; - LimitCORE = "infinity"; - LimitNOFILE = 16384; - PIDFile = "/run/samba/smbd.pid"; - Slice = "system-samba.slice"; - Type = "notify"; - }; + environment.LD_LIBRARY_PATH = config.system.nssModules.path; - unitConfig.RequiresMountsFor = "/var/lib/samba"; - - restartTriggers = [ configFile ]; + serviceConfig = { + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + ExecStart = "${cfg.package}/sbin/smbd --foreground --no-process-group ${lib.escapeShellArgs cfg.smbd.extraArgs}"; + LimitCORE = "infinity"; + LimitNOFILE = 16384; + PIDFile = "/run/samba/smbd.pid"; + Slice = "system-samba.slice"; + Type = "notify"; }; - }) - (lib.mkIf (cfg.enable && cfg.winbindd.enable) { - systemd.services.samba-winbindd = { - description = "Samba Winbind Daemon"; - documentation = [ "man:winbindd(8)" "man:samba(7)" "man:smb.conf(5)" ]; + unitConfig.RequiresMountsFor = "/var/lib/samba"; - after = [ + restartTriggers = [ configFile ]; + }; + }) + + (lib.mkIf (cfg.enable && cfg.winbindd.enable) { + systemd.services.samba-winbindd = { + description = "Samba Winbind Daemon"; + documentation = [ + "man:winbindd(8)" + "man:samba(7)" + "man:smb.conf(5)" + ]; + + after = + [ "network.target" - ] ++ lib.optionals (cfg.nmbd.enable) [ + ] + ++ lib.optionals (cfg.nmbd.enable) [ "samba-nmbd.service" ]; - partOf = [ "samba.target" ]; - wantedBy = [ "samba.target" ]; + partOf = [ "samba.target" ]; + wantedBy = [ "samba.target" ]; - environment.LD_LIBRARY_PATH = config.system.nssModules.path; + environment.LD_LIBRARY_PATH = config.system.nssModules.path; - serviceConfig = { - ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - ExecStart = "${cfg.package}/sbin/winbindd --foreground --no-process-group ${lib.escapeShellArgs cfg.winbindd.extraArgs}"; - LimitCORE = "infinity"; - PIDFile = "/run/samba/winbindd.pid"; - Slice = "system-samba.slice"; - Type = "notify"; - }; + serviceConfig = { + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + ExecStart = "${cfg.package}/sbin/winbindd --foreground --no-process-group ${lib.escapeShellArgs cfg.winbindd.extraArgs}"; + LimitCORE = "infinity"; + PIDFile = "/run/samba/winbindd.pid"; + Slice = "system-samba.slice"; + Type = "notify"; + }; - unitConfig.RequiresMountsFor = "/var/lib/samba"; + unitConfig.RequiresMountsFor = "/var/lib/samba"; - restartTriggers = [ configFile ]; - }; - }) + restartTriggers = [ configFile ]; + }; + }) - (lib.mkIf (cfg.enable && cfg.usershares.enable) { - users.groups.${cfg.usershares.group} = {}; + (lib.mkIf (cfg.enable && cfg.usershares.enable) { + users.groups.${cfg.usershares.group} = { }; - systemd.tmpfiles.settings."50-samba-usershares"."/var/lib/samba/usershares".d = { - user = "root"; - group = cfg.usershares.group; - mode = "1775"; # sticky so users can't delete others' shares - }; + systemd.tmpfiles.settings."50-samba-usershares"."/var/lib/samba/usershares".d = { + user = "root"; + group = cfg.usershares.group; + mode = "1775"; # sticky so users can't delete others' shares + }; - # set some reasonable defaults - services.samba.settings.global = lib.mkDefault { - "usershare path" = "/var/lib/samba/usershares"; - "usershare max shares" = 100; # high enough to be considered ~unlimited - "usershare allow guests" = true; - }; - }) - ]; + # set some reasonable defaults + services.samba.settings.global = lib.mkDefault { + "usershare path" = "/var/lib/samba/usershares"; + "usershare max shares" = 100; # high enough to be considered ~unlimited + "usershare allow guests" = true; + }; + }) + ]; } diff --git a/nixos/modules/services/network-filesystems/tahoe.nix b/nixos/modules/services/network-filesystems/tahoe.nix index e3296e6f66d540..9b99f4ce5a4468 100644 --- a/nixos/modules/services/network-filesystems/tahoe.nix +++ b/nixos/modules/services/network-filesystems/tahoe.nix @@ -1,12 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.tahoe; in - { - options.services.tahoe = { - introducers = lib.mkOption { - default = {}; - type = with lib.types; attrsOf (submodule { +{ + options.services.tahoe = { + introducers = lib.mkOption { + default = { }; + type = + with lib.types; + attrsOf (submodule { options = { nickname = lib.mkOption { type = lib.types.str; @@ -33,13 +40,15 @@ in package = lib.mkPackageOption pkgs "tahoelafs" { }; }; }); - description = '' - The Tahoe introducers. - ''; - }; - nodes = lib.mkOption { - default = {}; - type = with lib.types; attrsOf (submodule { + description = '' + The Tahoe introducers. + ''; + }; + nodes = lib.mkOption { + default = { }; + type = + with lib.types; + attrsOf (submodule { options = { nickname = lib.mkOption { type = lib.types.str; @@ -170,181 +179,194 @@ in package = lib.mkPackageOption pkgs "tahoelafs" { }; }; }); - description = '' - The Tahoe nodes. - ''; - }; + description = '' + The Tahoe nodes. + ''; }; - config = lib.mkMerge [ - (lib.mkIf (cfg.introducers != {}) { - environment = { - etc = lib.flip lib.mapAttrs' cfg.introducers (node: settings: - lib.nameValuePair "tahoe-lafs/introducer-${node}.cfg" { - mode = "0444"; - text = '' - # This configuration is generated by Nix. Edit at your own - # peril; here be dragons. + }; + config = lib.mkMerge [ + (lib.mkIf (cfg.introducers != { }) { + environment = { + etc = lib.flip lib.mapAttrs' cfg.introducers ( + node: settings: + lib.nameValuePair "tahoe-lafs/introducer-${node}.cfg" { + mode = "0444"; + text = '' + # This configuration is generated by Nix. Edit at your own + # peril; here be dragons. - [node] - nickname = ${settings.nickname} - tub.port = ${toString settings.tub.port} - ${lib.optionalString (settings.tub.location != null) - "tub.location = ${settings.tub.location}"} - ''; - }); - # Actually require Tahoe, so that we will have it installed. - systemPackages = lib.flip lib.mapAttrsToList cfg.introducers (node: settings: - settings.package - ); - }; - # Open up the firewall. - # networking.firewall.allowedTCPPorts = lib.flip lib.mapAttrsToList cfg.introducers - # (node: settings: settings.tub.port); - systemd.services = lib.flip lib.mapAttrs' cfg.introducers (node: settings: - let - pidfile = "/run/tahoe.introducer-${node}.pid"; - # This is a directory, but it has no trailing slash. Tahoe commands - # get antsy when there's a trailing slash. - nodedir = "/var/db/tahoe-lafs/introducer-${node}"; - in lib.nameValuePair "tahoe.introducer-${node}" { - description = "Tahoe LAFS node ${node}"; - wantedBy = [ "multi-user.target" ]; - path = [ settings.package ]; - restartTriggers = [ - config.environment.etc."tahoe-lafs/introducer-${node}.cfg".source ]; - serviceConfig = { - Type = "simple"; - PIDFile = pidfile; - # Believe it or not, Tahoe is very brittle about the order of - # arguments to $(tahoe run). The node directory must come first, - # and arguments which alter Twisted's behavior come afterwards. - ExecStart = '' - ${settings.package}/bin/tahoe run ${lib.escapeShellArg nodedir} --pidfile=${lib.escapeShellArg pidfile} - ''; - }; - preStart = '' - if [ ! -d ${lib.escapeShellArg nodedir} ]; then - mkdir -p /var/db/tahoe-lafs - # See https://github.com/NixOS/nixpkgs/issues/25273 - tahoe create-introducer \ - --hostname="${config.networking.hostName}" \ - ${lib.escapeShellArg nodedir} - fi - - # Tahoe has created a predefined tahoe.cfg which we must now - # scribble over. - # XXX I thought that a symlink would work here, but it doesn't, so - # we must do this on every prestart. Fixes welcome. - # rm ${nodedir}/tahoe.cfg - # ln -s /etc/tahoe-lafs/introducer-${node}.cfg ${nodedir}/tahoe.cfg - cp /etc/tahoe-lafs/introducer-"${node}".cfg ${lib.escapeShellArg nodedir}/tahoe.cfg + [node] + nickname = ${settings.nickname} + tub.port = ${toString settings.tub.port} + ${lib.optionalString (settings.tub.location != null) "tub.location = ${settings.tub.location}"} + ''; + } + ); + # Actually require Tahoe, so that we will have it installed. + systemPackages = lib.flip lib.mapAttrsToList cfg.introducers (node: settings: settings.package); + }; + # Open up the firewall. + # networking.firewall.allowedTCPPorts = lib.flip lib.mapAttrsToList cfg.introducers + # (node: settings: settings.tub.port); + systemd.services = lib.flip lib.mapAttrs' cfg.introducers ( + node: settings: + let + pidfile = "/run/tahoe.introducer-${node}.pid"; + # This is a directory, but it has no trailing slash. Tahoe commands + # get antsy when there's a trailing slash. + nodedir = "/var/db/tahoe-lafs/introducer-${node}"; + in + lib.nameValuePair "tahoe.introducer-${node}" { + description = "Tahoe LAFS node ${node}"; + wantedBy = [ "multi-user.target" ]; + path = [ settings.package ]; + restartTriggers = [ + config.environment.etc."tahoe-lafs/introducer-${node}.cfg".source + ]; + serviceConfig = { + Type = "simple"; + PIDFile = pidfile; + # Believe it or not, Tahoe is very brittle about the order of + # arguments to $(tahoe run). The node directory must come first, + # and arguments which alter Twisted's behavior come afterwards. + ExecStart = '' + ${settings.package}/bin/tahoe run ${lib.escapeShellArg nodedir} --pidfile=${lib.escapeShellArg pidfile} ''; - }); - users.users = lib.flip lib.mapAttrs' cfg.introducers (node: _: - lib.nameValuePair "tahoe.introducer-${node}" { - description = "Tahoe node user for introducer ${node}"; - isSystemUser = true; - }); - }) - (lib.mkIf (cfg.nodes != {}) { - environment = { - etc = lib.flip lib.mapAttrs' cfg.nodes (node: settings: - lib.nameValuePair "tahoe-lafs/${node}.cfg" { - mode = "0444"; - text = '' - # This configuration is generated by Nix. Edit at your own - # peril; here be dragons. + }; + preStart = '' + if [ ! -d ${lib.escapeShellArg nodedir} ]; then + mkdir -p /var/db/tahoe-lafs + # See https://github.com/NixOS/nixpkgs/issues/25273 + tahoe create-introducer \ + --hostname="${config.networking.hostName}" \ + ${lib.escapeShellArg nodedir} + fi - [node] - nickname = ${settings.nickname} - tub.port = ${toString settings.tub.port} - ${lib.optionalString (settings.tub.location != null) - "tub.location = ${settings.tub.location}"} - # This is a Twisted endpoint. Twisted Web doesn't work on - # non-TCP. ~ C. - web.port = tcp:${toString settings.web.port} + # Tahoe has created a predefined tahoe.cfg which we must now + # scribble over. + # XXX I thought that a symlink would work here, but it doesn't, so + # we must do this on every prestart. Fixes welcome. + # rm ${nodedir}/tahoe.cfg + # ln -s /etc/tahoe-lafs/introducer-${node}.cfg ${nodedir}/tahoe.cfg + cp /etc/tahoe-lafs/introducer-"${node}".cfg ${lib.escapeShellArg nodedir}/tahoe.cfg + ''; + } + ); + users.users = lib.flip lib.mapAttrs' cfg.introducers ( + node: _: + lib.nameValuePair "tahoe.introducer-${node}" { + description = "Tahoe node user for introducer ${node}"; + isSystemUser = true; + } + ); + }) + (lib.mkIf (cfg.nodes != { }) { + environment = { + etc = lib.flip lib.mapAttrs' cfg.nodes ( + node: settings: + lib.nameValuePair "tahoe-lafs/${node}.cfg" { + mode = "0444"; + text = '' + # This configuration is generated by Nix. Edit at your own + # peril; here be dragons. - [client] - ${lib.optionalString (settings.client.introducer != null) - "introducer.furl = ${settings.client.introducer}"} - ${lib.optionalString (settings.client.helper != null) - "helper.furl = ${settings.client.helper}"} + [node] + nickname = ${settings.nickname} + tub.port = ${toString settings.tub.port} + ${lib.optionalString (settings.tub.location != null) "tub.location = ${settings.tub.location}"} + # This is a Twisted endpoint. Twisted Web doesn't work on + # non-TCP. ~ C. + web.port = tcp:${toString settings.web.port} - shares.needed = ${toString settings.client.shares.needed} - shares.happy = ${toString settings.client.shares.happy} - shares.total = ${toString settings.client.shares.total} + [client] + ${lib.optionalString ( + settings.client.introducer != null + ) "introducer.furl = ${settings.client.introducer}"} + ${lib.optionalString (settings.client.helper != null) "helper.furl = ${settings.client.helper}"} - [storage] - enabled = ${lib.boolToString settings.storage.enable} - reserved_space = ${settings.storage.reservedSpace} + shares.needed = ${toString settings.client.shares.needed} + shares.happy = ${toString settings.client.shares.happy} + shares.total = ${toString settings.client.shares.total} - [helper] - enabled = ${lib.boolToString settings.helper.enable} + [storage] + enabled = ${lib.boolToString settings.storage.enable} + reserved_space = ${settings.storage.reservedSpace} - [sftpd] - enabled = ${lib.boolToString settings.sftpd.enable} - ${lib.optionalString (settings.sftpd.port != null) - "port = ${toString settings.sftpd.port}"} - ${lib.optionalString (settings.sftpd.hostPublicKeyFile != null) - "host_pubkey_file = ${settings.sftpd.hostPublicKeyFile}"} - ${lib.optionalString (settings.sftpd.hostPrivateKeyFile != null) - "host_privkey_file = ${settings.sftpd.hostPrivateKeyFile}"} - ${lib.optionalString (settings.sftpd.accounts.file != null) - "accounts.file = ${settings.sftpd.accounts.file}"} - ${lib.optionalString (settings.sftpd.accounts.url != null) - "accounts.url = ${settings.sftpd.accounts.url}"} - ''; - }); - # Actually require Tahoe, so that we will have it installed. - systemPackages = lib.flip lib.mapAttrsToList cfg.nodes (node: settings: - settings.package - ); - }; - # Open up the firewall. - # networking.firewall.allowedTCPPorts = lib.flip lib.mapAttrsToList cfg.nodes - # (node: settings: settings.tub.port); - systemd.services = lib.flip lib.mapAttrs' cfg.nodes (node: settings: - let - pidfile = "/run/tahoe.${node}.pid"; - # This is a directory, but it has no trailing slash. Tahoe commands - # get antsy when there's a trailing slash. - nodedir = "/var/db/tahoe-lafs/${node}"; - in lib.nameValuePair "tahoe.${node}" { - description = "Tahoe LAFS node ${node}"; - wantedBy = [ "multi-user.target" ]; - path = [ settings.package ]; - restartTriggers = [ - config.environment.etc."tahoe-lafs/${node}.cfg".source ]; - serviceConfig = { - Type = "simple"; - PIDFile = pidfile; - # Believe it or not, Tahoe is very brittle about the order of - # arguments to $(tahoe run). The node directory must come first, - # and arguments which alter Twisted's behavior come afterwards. - ExecStart = '' - ${settings.package}/bin/tahoe run ${lib.escapeShellArg nodedir} --pidfile=${lib.escapeShellArg pidfile} - ''; - }; - preStart = '' - if [ ! -d ${lib.escapeShellArg nodedir} ]; then - mkdir -p /var/db/tahoe-lafs - tahoe create-node --hostname=localhost ${lib.escapeShellArg nodedir} - fi + [helper] + enabled = ${lib.boolToString settings.helper.enable} - # Tahoe has created a predefined tahoe.cfg which we must now - # scribble over. - # XXX I thought that a symlink would work here, but it doesn't, so - # we must do this on every prestart. Fixes welcome. - # rm ${nodedir}/tahoe.cfg - # ln -s /etc/tahoe-lafs/${lib.escapeShellArg node}.cfg ${nodedir}/tahoe.cfg - cp /etc/tahoe-lafs/${lib.escapeShellArg node}.cfg ${lib.escapeShellArg nodedir}/tahoe.cfg + [sftpd] + enabled = ${lib.boolToString settings.sftpd.enable} + ${lib.optionalString (settings.sftpd.port != null) "port = ${toString settings.sftpd.port}"} + ${lib.optionalString ( + settings.sftpd.hostPublicKeyFile != null + ) "host_pubkey_file = ${settings.sftpd.hostPublicKeyFile}"} + ${lib.optionalString ( + settings.sftpd.hostPrivateKeyFile != null + ) "host_privkey_file = ${settings.sftpd.hostPrivateKeyFile}"} + ${lib.optionalString ( + settings.sftpd.accounts.file != null + ) "accounts.file = ${settings.sftpd.accounts.file}"} + ${lib.optionalString ( + settings.sftpd.accounts.url != null + ) "accounts.url = ${settings.sftpd.accounts.url}"} ''; - }); - users.users = lib.flip lib.mapAttrs' cfg.nodes (node: _: - lib.nameValuePair "tahoe.${node}" { - description = "Tahoe node user for node ${node}"; - isSystemUser = true; - }); - }) - ]; - } + } + ); + # Actually require Tahoe, so that we will have it installed. + systemPackages = lib.flip lib.mapAttrsToList cfg.nodes (node: settings: settings.package); + }; + # Open up the firewall. + # networking.firewall.allowedTCPPorts = lib.flip lib.mapAttrsToList cfg.nodes + # (node: settings: settings.tub.port); + systemd.services = lib.flip lib.mapAttrs' cfg.nodes ( + node: settings: + let + pidfile = "/run/tahoe.${node}.pid"; + # This is a directory, but it has no trailing slash. Tahoe commands + # get antsy when there's a trailing slash. + nodedir = "/var/db/tahoe-lafs/${node}"; + in + lib.nameValuePair "tahoe.${node}" { + description = "Tahoe LAFS node ${node}"; + wantedBy = [ "multi-user.target" ]; + path = [ settings.package ]; + restartTriggers = [ + config.environment.etc."tahoe-lafs/${node}.cfg".source + ]; + serviceConfig = { + Type = "simple"; + PIDFile = pidfile; + # Believe it or not, Tahoe is very brittle about the order of + # arguments to $(tahoe run). The node directory must come first, + # and arguments which alter Twisted's behavior come afterwards. + ExecStart = '' + ${settings.package}/bin/tahoe run ${lib.escapeShellArg nodedir} --pidfile=${lib.escapeShellArg pidfile} + ''; + }; + preStart = '' + if [ ! -d ${lib.escapeShellArg nodedir} ]; then + mkdir -p /var/db/tahoe-lafs + tahoe create-node --hostname=localhost ${lib.escapeShellArg nodedir} + fi + + # Tahoe has created a predefined tahoe.cfg which we must now + # scribble over. + # XXX I thought that a symlink would work here, but it doesn't, so + # we must do this on every prestart. Fixes welcome. + # rm ${nodedir}/tahoe.cfg + # ln -s /etc/tahoe-lafs/${lib.escapeShellArg node}.cfg ${nodedir}/tahoe.cfg + cp /etc/tahoe-lafs/${lib.escapeShellArg node}.cfg ${lib.escapeShellArg nodedir}/tahoe.cfg + ''; + } + ); + users.users = lib.flip lib.mapAttrs' cfg.nodes ( + node: _: + lib.nameValuePair "tahoe.${node}" { + description = "Tahoe node user for node ${node}"; + isSystemUser = true; + } + ); + }) + ]; +} diff --git a/nixos/modules/services/network-filesystems/u9fs.nix b/nixos/modules/services/network-filesystems/u9fs.nix index 346705f5e3d00d..4d568599275a01 100644 --- a/nixos/modules/services/network-filesystems/u9fs.nix +++ b/nixos/modules/services/network-filesystems/u9fs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.u9fs; in @@ -35,9 +40,9 @@ in default = ""; example = "-a none"; description = '' - Extra arguments to pass on invocation, - see {command}`man 4 u9fs` - ''; + Extra arguments to pass on invocation, + see {command}`man 4 u9fs` + ''; }; }; @@ -58,13 +63,13 @@ in description = "9P Protocol Server"; reloadIfChanged = true; requires = [ "u9fs.socket" ]; - serviceConfig = - { ExecStart = "-${pkgs.u9fs}/bin/u9fs ${cfg.extraArgs}"; - StandardInput = "socket"; - StandardError = "journal"; - User = cfg.user; - AmbientCapabilities = "cap_setuid cap_setgid"; - }; + serviceConfig = { + ExecStart = "-${pkgs.u9fs}/bin/u9fs ${cfg.extraArgs}"; + StandardInput = "socket"; + StandardError = "journal"; + User = cfg.user; + AmbientCapabilities = "cap_setuid cap_setgid"; + }; }; }; diff --git a/nixos/modules/services/network-filesystems/webdav-server-rs.nix b/nixos/modules/services/network-filesystems/webdav-server-rs.nix index 31f641a82d797f..79fae8021d7d90 100644 --- a/nixos/modules/services/network-filesystems/webdav-server-rs.nix +++ b/nixos/modules/services/network-filesystems/webdav-server-rs.nix @@ -1,13 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.webdav-server-rs; format = pkgs.formats.toml { }; - settings = lib.recursiveUpdate - { - server.uid = config.users.users."${cfg.user}".uid; - server.gid = config.users.groups."${cfg.group}".gid; - } - cfg.settings; + settings = lib.recursiveUpdate { + server.uid = config.users.users."${cfg.user}".uid; + server.gid = config.users.groups."${cfg.group}".gid; + } cfg.settings; in { options = { @@ -93,7 +96,8 @@ in message = "users.users.${cfg.user} and users.users.${cfg.user}.uid must be defined."; } { - assertion = lib.hasAttr cfg.group config.users.groups && config.users.groups."${cfg.group}".gid != null; + assertion = + lib.hasAttr cfg.group config.users.groups && config.users.groups."${cfg.group}".gid != null; message = "users.groups.${cfg.group} and users.groups.${cfg.group}.gid must be defined."; } ]; diff --git a/nixos/modules/services/network-filesystems/webdav.nix b/nixos/modules/services/network-filesystems/webdav.nix index 28f129fc12d290..d0ae780a3aec5f 100644 --- a/nixos/modules/services/network-filesystems/webdav.nix +++ b/nixos/modules/services/network-filesystems/webdav.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.webdav; format = pkgs.formats.yaml { }; diff --git a/nixos/modules/services/network-filesystems/xtreemfs.nix b/nixos/modules/services/network-filesystems/xtreemfs.nix index e2cde1903edd20..24ce5f7c224ffa 100644 --- a/nixos/modules/services/network-filesystems/xtreemfs.nix +++ b/nixos/modules/services/network-filesystems/xtreemfs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.xtreemfs; @@ -7,13 +12,15 @@ let home = cfg.homeDir; - startupScript = class: configPath: pkgs.writeScript "xtreemfs-osd.sh" '' - #! ${pkgs.runtimeShell} - JAVA_HOME="${pkgs.jdk}" - JAVADIR="${xtreemfs}/share/java" - JAVA_CALL="$JAVA_HOME/bin/java -ea -cp $JAVADIR/XtreemFS.jar:$JAVADIR/BabuDB.jar:$JAVADIR/Flease.jar:$JAVADIR/protobuf-java-2.5.0.jar:$JAVADIR/Foundation.jar:$JAVADIR/jdmkrt.jar:$JAVADIR/jdmktk.jar:$JAVADIR/commons-codec-1.3.jar" - $JAVA_CALL ${class} ${configPath} - ''; + startupScript = + class: configPath: + pkgs.writeScript "xtreemfs-osd.sh" '' + #! ${pkgs.runtimeShell} + JAVA_HOME="${pkgs.jdk}" + JAVADIR="${xtreemfs}/share/java" + JAVA_CALL="$JAVA_HOME/bin/java -ea -cp $JAVADIR/XtreemFS.jar:$JAVADIR/BabuDB.jar:$JAVADIR/Flease.jar:$JAVADIR/protobuf-java-2.5.0.jar:$JAVADIR/Foundation.jar:$JAVADIR/jdmkrt.jar:$JAVADIR/jdmktk.jar:$JAVADIR/commons-codec-1.3.jar" + $JAVA_CALL ${class} ${configPath} + ''; dirReplicationConfig = pkgs.writeText "xtreemfs-dir-replication-plugin.properties" '' babudb.repl.backupDir = ${home}/server-repl-dir @@ -69,7 +76,7 @@ let ${cfg.osd.extraConfig} ''; - optionalDir = lib.optionals cfg.dir.enable ["xtreemfs-dir.service"]; + optionalDir = lib.optionals cfg.dir.enable [ "xtreemfs-dir.service" ]; systemdOptionalDependencies = { after = [ "network.target" ] ++ optionalDir; @@ -139,7 +146,13 @@ in ''; }; syncMode = lib.mkOption { - type = lib.types.enum [ "ASYNC" "SYNC_WRITE_METADATA" "SYNC_WRITE" "FDATASYNC" "FSYNC" ]; + type = lib.types.enum [ + "ASYNC" + "SYNC_WRITE_METADATA" + "SYNC_WRITE" + "FDATASYNC" + "FSYNC" + ]; default = "FSYNC"; example = "FDATASYNC"; description = '' @@ -265,7 +278,13 @@ in }; syncMode = lib.mkOption { default = "FSYNC"; - type = lib.types.enum [ "ASYNC" "SYNC_WRITE_METADATA" "SYNC_WRITE" "FDATASYNC" "FSYNC" ]; + type = lib.types.enum [ + "ASYNC" + "SYNC_WRITE_METADATA" + "SYNC_WRITE" + "FDATASYNC" + "FSYNC" + ]; example = "FDATASYNC"; description = '' The sync mode influences how operations are committed to the disk @@ -443,23 +462,22 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { environment.systemPackages = [ xtreemfs ]; - users.users.xtreemfs = - { uid = config.ids.uids.xtreemfs; - description = "XtreemFS user"; - createHome = true; - home = home; - }; + users.users.xtreemfs = { + uid = config.ids.uids.xtreemfs; + description = "XtreemFS user"; + createHome = true; + home = home; + }; - users.groups.xtreemfs = - { gid = config.ids.gids.xtreemfs; - }; + users.groups.xtreemfs = { + gid = config.ids.gids.xtreemfs; + }; systemd.services.xtreemfs-dir = lib.mkIf cfg.dir.enable { description = "XtreemFS-DIR Server"; @@ -471,21 +489,27 @@ in }; }; - systemd.services.xtreemfs-mrc = lib.mkIf cfg.mrc.enable ({ - description = "XtreemFS-MRC Server"; - serviceConfig = { - User = "xtreemfs"; - ExecStart = "${startupScript "org.xtreemfs.mrc.MRC" mrcConfig}"; - }; - } // systemdOptionalDependencies); - - systemd.services.xtreemfs-osd = lib.mkIf cfg.osd.enable ({ - description = "XtreemFS-OSD Server"; - serviceConfig = { - User = "xtreemfs"; - ExecStart = "${startupScript "org.xtreemfs.osd.OSD" osdConfig}"; - }; - } // systemdOptionalDependencies); + systemd.services.xtreemfs-mrc = lib.mkIf cfg.mrc.enable ( + { + description = "XtreemFS-MRC Server"; + serviceConfig = { + User = "xtreemfs"; + ExecStart = "${startupScript "org.xtreemfs.mrc.MRC" mrcConfig}"; + }; + } + // systemdOptionalDependencies + ); + + systemd.services.xtreemfs-osd = lib.mkIf cfg.osd.enable ( + { + description = "XtreemFS-OSD Server"; + serviceConfig = { + User = "xtreemfs"; + ExecStart = "${startupScript "org.xtreemfs.osd.OSD" osdConfig}"; + }; + } + // systemdOptionalDependencies + ); }; diff --git a/nixos/modules/services/network-filesystems/yandex-disk.nix b/nixos/modules/services/network-filesystems/yandex-disk.nix index ee9b58b081a37f..c2364898f9984c 100644 --- a/nixos/modules/services/network-filesystems/yandex-disk.nix +++ b/nixos/modules/services/network-filesystems/yandex-disk.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.yandex-disk; @@ -68,17 +73,18 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { - users.users = lib.mkIf (cfg.user == null) [ { - name = u; - uid = config.ids.uids.yandexdisk; - group = "nogroup"; - home = dir; - } ]; + users.users = lib.mkIf (cfg.user == null) [ + { + name = u; + uid = config.ids.uids.yandexdisk; + group = "nogroup"; + home = dir; + } + ]; systemd.services.yandex-disk = { description = "Yandex-disk server"; @@ -110,4 +116,3 @@ in }; } - diff --git a/nixos/modules/services/networking/3proxy.nix b/nixos/modules/services/networking/3proxy.nix index 03c67ed2f6f8f0..e15abb63aec493 100644 --- a/nixos/modules/services/networking/3proxy.nix +++ b/nixos/modules/services/networking/3proxy.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let pkg = pkgs._3proxy; cfg = config.services._3proxy; optionalList = list: if list == [ ] then "*" else lib.concatMapStringsSep "," toString list; -in { +in +{ options.services._3proxy = { enable = lib.mkEnableOption "3proxy"; confFile = lib.mkOption { @@ -40,176 +46,205 @@ in { ''; }; services = lib.mkOption { - type = lib.types.listOf (lib.types.submodule { - options = { - type = lib.mkOption { - type = lib.types.enum [ - "proxy" - "socks" - "pop3p" - "ftppr" - "admin" - "dnspr" - "tcppm" - "udppm" - ]; - example = "proxy"; - description = '' - Service type. The following values are valid: + type = lib.types.listOf ( + lib.types.submodule { + options = { + type = lib.mkOption { + type = lib.types.enum [ + "proxy" + "socks" + "pop3p" + "ftppr" + "admin" + "dnspr" + "tcppm" + "udppm" + ]; + example = "proxy"; + description = '' + Service type. The following values are valid: - - `"proxy"`: HTTP/HTTPS proxy (default port 3128). - - `"socks"`: SOCKS 4/4.5/5 proxy (default port 1080). - - `"pop3p"`: POP3 proxy (default port 110). - - `"ftppr"`: FTP proxy (default port 21). - - `"admin"`: Web interface (default port 80). - - `"dnspr"`: Caching DNS proxy (default port 53). - - `"tcppm"`: TCP portmapper. - - `"udppm"`: UDP portmapper. - ''; - }; - bindAddress = lib.mkOption { - type = lib.types.str; - default = "[::]"; - example = "127.0.0.1"; - description = '' - Address used for service. - ''; - }; - bindPort = lib.mkOption { - type = lib.types.nullOr lib.types.int; - default = null; - example = 3128; - description = '' - Override default port used for service. - ''; - }; - maxConnections = lib.mkOption { - type = lib.types.int; - default = 100; - example = 1000; - description = '' - Maximum number of simulationeous connections to this service. - ''; - }; - auth = lib.mkOption { - type = lib.types.listOf (lib.types.enum [ "none" "iponly" "strong" ]); - example = [ "iponly" "strong" ]; - description = '' - Authentication type. The following values are valid: + - `"proxy"`: HTTP/HTTPS proxy (default port 3128). + - `"socks"`: SOCKS 4/4.5/5 proxy (default port 1080). + - `"pop3p"`: POP3 proxy (default port 110). + - `"ftppr"`: FTP proxy (default port 21). + - `"admin"`: Web interface (default port 80). + - `"dnspr"`: Caching DNS proxy (default port 53). + - `"tcppm"`: TCP portmapper. + - `"udppm"`: UDP portmapper. + ''; + }; + bindAddress = lib.mkOption { + type = lib.types.str; + default = "[::]"; + example = "127.0.0.1"; + description = '' + Address used for service. + ''; + }; + bindPort = lib.mkOption { + type = lib.types.nullOr lib.types.int; + default = null; + example = 3128; + description = '' + Override default port used for service. + ''; + }; + maxConnections = lib.mkOption { + type = lib.types.int; + default = 100; + example = 1000; + description = '' + Maximum number of simulationeous connections to this service. + ''; + }; + auth = lib.mkOption { + type = lib.types.listOf ( + lib.types.enum [ + "none" + "iponly" + "strong" + ] + ); + example = [ + "iponly" + "strong" + ]; + description = '' + Authentication type. The following values are valid: - - `"none"`: disables both authentication and authorization. You can not use ACLs. - - `"iponly"`: specifies no authentication. ACLs authorization is used. - - `"strong"`: authentication by username/password. If user is not registered their access is denied regardless of ACLs. + - `"none"`: disables both authentication and authorization. You can not use ACLs. + - `"iponly"`: specifies no authentication. ACLs authorization is used. + - `"strong"`: authentication by username/password. If user is not registered their access is denied regardless of ACLs. - Double authentication is possible, e.g. + Double authentication is possible, e.g. - ``` - { - auth = [ "iponly" "strong" ]; - acl = [ - { - rule = "allow"; - targets = [ "192.168.0.0/16" ]; - } - { - rule = "allow" - users = [ "user1" "user2" ]; - } - ]; - } - ``` - In this example strong username authentication is not required to access 192.168.0.0/16. - ''; - }; - acl = lib.mkOption { - type = lib.types.listOf (lib.types.submodule { - options = { - rule = lib.mkOption { - type = lib.types.enum [ "allow" "deny" ]; - example = "allow"; - description = '' - ACL rule. The following values are valid: + ``` + { + auth = [ "iponly" "strong" ]; + acl = [ + { + rule = "allow"; + targets = [ "192.168.0.0/16" ]; + } + { + rule = "allow" + users = [ "user1" "user2" ]; + } + ]; + } + ``` + In this example strong username authentication is not required to access 192.168.0.0/16. + ''; + }; + acl = lib.mkOption { + type = lib.types.listOf ( + lib.types.submodule { + options = { + rule = lib.mkOption { + type = lib.types.enum [ + "allow" + "deny" + ]; + example = "allow"; + description = '' + ACL rule. The following values are valid: - - `"allow"`: connections allowed. - - `"deny"`: connections not allowed. - ''; - }; - users = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = [ ]; - example = [ "user1" "user2" "user3" ]; - description = '' - List of users, use empty list for any. - ''; - }; - sources = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = [ ]; - example = [ "127.0.0.1" "192.168.1.0/24" ]; - description = '' - List of source IP range, use empty list for any. - ''; - }; - targets = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = [ ]; - example = [ "127.0.0.1" "192.168.1.0/24" ]; - description = '' - List of target IP ranges, use empty list for any. - May also contain host names instead of addresses. - It's possible to use wildmask in the beginning and in the the end of hostname, e.g. `*badsite.com` or `*badcontent*`. - Hostname is only checked if hostname presents in request. - ''; - }; - targetPorts = lib.mkOption { - type = lib.types.listOf lib.types.int; - default = [ ]; - example = [ 80 443 ]; - description = '' - List of target ports, use empty list for any. - ''; - }; - }; - }); - default = [ ]; - example = lib.literalExpression '' - [ - { - rule = "allow"; - users = [ "user1" ]; - } - { - rule = "allow"; - sources = [ "192.168.1.0/24" ]; + - `"allow"`: connections allowed. + - `"deny"`: connections not allowed. + ''; + }; + users = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + example = [ + "user1" + "user2" + "user3" + ]; + description = '' + List of users, use empty list for any. + ''; + }; + sources = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + example = [ + "127.0.0.1" + "192.168.1.0/24" + ]; + description = '' + List of source IP range, use empty list for any. + ''; + }; + targets = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + example = [ + "127.0.0.1" + "192.168.1.0/24" + ]; + description = '' + List of target IP ranges, use empty list for any. + May also contain host names instead of addresses. + It's possible to use wildmask in the beginning and in the the end of hostname, e.g. `*badsite.com` or `*badcontent*`. + Hostname is only checked if hostname presents in request. + ''; + }; + targetPorts = lib.mkOption { + type = lib.types.listOf lib.types.int; + default = [ ]; + example = [ + 80 + 443 + ]; + description = '' + List of target ports, use empty list for any. + ''; + }; + }; } - { - rule = "deny"; - } - ] - ''; - description = '' - Use this option to limit user access to resources. - ''; + ); + default = [ ]; + example = lib.literalExpression '' + [ + { + rule = "allow"; + users = [ "user1" ]; + } + { + rule = "allow"; + sources = [ "192.168.1.0/24" ]; + } + { + rule = "deny"; + } + ] + ''; + description = '' + Use this option to limit user access to resources. + ''; + }; + extraArguments = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = null; + example = "-46"; + description = '' + Extra arguments for service. + Consult "Options" section in [documentation](https://github.com/z3APA3A/3proxy/wiki/3proxy.cfg) for available arguments. + ''; + }; + extraConfig = lib.mkOption { + type = lib.types.nullOr lib.types.lines; + default = null; + description = '' + Extra configuration for service. Use this to configure things like bandwidth limiter or ACL-based redirection. + Consult [documentation](https://github.com/z3APA3A/3proxy/wiki/3proxy.cfg) for available options. + ''; + }; }; - extraArguments = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - example = "-46"; - description = '' - Extra arguments for service. - Consult "Options" section in [documentation](https://github.com/z3APA3A/3proxy/wiki/3proxy.cfg) for available arguments. - ''; - }; - extraConfig = lib.mkOption { - type = lib.types.nullOr lib.types.lines; - default = null; - description = '' - Extra configuration for service. Use this to configure things like bandwidth limiter or ACL-based redirection. - Consult [documentation](https://github.com/z3APA3A/3proxy/wiki/3proxy.cfg) for available options. - ''; - }; - }; - }); + } + ); default = [ ]; example = lib.literalExpression '' [ @@ -267,7 +302,10 @@ in { nserver = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "127.0.0.53" "192.168.1.3:5353/tcp" ]; + example = [ + "127.0.0.53" + "192.168.1.3:5353/tcp" + ]; description = '' List of nameservers to use. @@ -314,54 +352,52 @@ in { }; config = lib.mkIf cfg.enable { - services._3proxy.confFile = lib.mkDefault (pkgs.writeText "3proxy.conf" '' - # log to stdout - log + services._3proxy.confFile = lib.mkDefault ( + pkgs.writeText "3proxy.conf" '' + # log to stdout + log - ${lib.concatMapStringsSep "\n" (x: "nserver " + x) cfg.resolution.nserver} + ${lib.concatMapStringsSep "\n" (x: "nserver " + x) cfg.resolution.nserver} - nscache ${toString cfg.resolution.nscache} - nscache6 ${toString cfg.resolution.nscache6} + nscache ${toString cfg.resolution.nscache} + nscache6 ${toString cfg.resolution.nscache6} - ${lib.concatMapStringsSep "\n" (x: "nsrecord " + x) - (lib.mapAttrsToList (name: value: "${name} ${value}") - cfg.resolution.nsrecord)} + ${lib.concatMapStringsSep "\n" (x: "nsrecord " + x) ( + lib.mapAttrsToList (name: value: "${name} ${value}") cfg.resolution.nsrecord + )} - ${lib.optionalString (cfg.usersFile != null) - ''users $"${cfg.usersFile}"'' - } + ${lib.optionalString (cfg.usersFile != null) ''users $"${cfg.usersFile}"''} - ${lib.concatMapStringsSep "\n" (service: '' - auth ${lib.concatStringsSep " " service.auth} + ${lib.concatMapStringsSep "\n" (service: '' + auth ${lib.concatStringsSep " " service.auth} - ${lib.optionalString (cfg.denyPrivate) - "deny * * ${optionalList cfg.privateRanges}"} + ${lib.optionalString (cfg.denyPrivate) "deny * * ${optionalList cfg.privateRanges}"} - ${lib.concatMapStringsSep "\n" (acl: - "${acl.rule} ${ - lib.concatMapStringsSep " " optionalList [ - acl.users - acl.sources - acl.targets - acl.targetPorts - ] - }") service.acl} + ${lib.concatMapStringsSep "\n" ( + acl: + "${acl.rule} ${ + lib.concatMapStringsSep " " optionalList [ + acl.users + acl.sources + acl.targets + acl.targetPorts + ] + }" + ) service.acl} - maxconn ${toString service.maxConnections} + maxconn ${toString service.maxConnections} - ${lib.optionalString (service.extraConfig != null) service.extraConfig} + ${lib.optionalString (service.extraConfig != null) service.extraConfig} - ${service.type} -i${toString service.bindAddress} ${ - lib.optionalString (service.bindPort != null) - "-p${toString service.bindPort}" - } ${ - lib.optionalString (service.extraArguments != null) service.extraArguments - } + ${service.type} -i${toString service.bindAddress} ${ + lib.optionalString (service.bindPort != null) "-p${toString service.bindPort}" + } ${lib.optionalString (service.extraArguments != null) service.extraArguments} - flush - '') cfg.services} - ${lib.optionalString (cfg.extraConfig != null) cfg.extraConfig} - ''); + flush + '') cfg.services} + ${lib.optionalString (cfg.extraConfig != null) cfg.extraConfig} + '' + ); systemd.services."3proxy" = { description = "Tiny free proxy server"; documentation = [ "https://github.com/z3APA3A/3proxy/wiki" ]; diff --git a/nixos/modules/services/networking/acme-dns.nix b/nixos/modules/services/networking/acme-dns.nix index 08e0e1d1731736..665f0bd8fd9273 100644 --- a/nixos/modules/services/networking/acme-dns.nix +++ b/nixos/modules/services/networking/acme-dns.nix @@ -1,7 +1,8 @@ -{ lib -, config -, pkgs -, ... +{ + lib, + config, + pkgs, + ... }: let @@ -42,7 +43,17 @@ in }; protocol = mkOption { - type = types.enum [ "both" "both4" "both6" "udp" "udp4" "udp6" "tcp" "tcp4" "tcp6" ]; + type = types.enum [ + "both" + "both4" + "both6" + "udp" + "udp4" + "udp6" + "tcp" + "tcp4" + "tcp6" + ]; description = "Protocols to serve DNS responses on."; default = "both"; }; @@ -83,7 +94,10 @@ in database = { engine = mkOption { - type = types.enum [ "sqlite3" "postgres" ]; + type = types.enum [ + "sqlite3" + "postgres" + ]; description = "Database engine to use."; default = "sqlite3"; }; @@ -119,16 +133,25 @@ in }; tls = mkOption { - type = types.enum [ "letsencrypt" "letsencryptstaging" "cert" "none" ]; + type = types.enum [ + "letsencrypt" + "letsencryptstaging" + "cert" + "none" + ]; description = "TLS backend to use."; default = "none"; }; }; - logconfig = { loglevel = mkOption { - type = types.enum [ "error" "warning" "info" "debug" ]; + type = types.enum [ + "error" + "warning" + "info" + "debug" + ]; description = "Level to log on."; default = "info"; }; @@ -143,7 +166,10 @@ in systemd.services.acme-dns = { wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart = [ "" "${lib.getExe cfg.package} -c ${format.generate "acme-dns.toml" cfg.settings}" ]; + ExecStart = [ + "" + "${lib.getExe cfg.package} -c ${format.generate "acme-dns.toml" cfg.settings}" + ]; StateDirectory = "acme-dns"; WorkingDirectory = "%S/acme-dns"; DynamicUser = true; diff --git a/nixos/modules/services/networking/adguardhome.nix b/nixos/modules/services/networking/adguardhome.nix index dab81ce18b2993..fc23d2af0b22dd 100644 --- a/nixos/modules/services/networking/adguardhome.nix +++ b/nixos/modules/services/networking/adguardhome.nix @@ -1,30 +1,45 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.adguardhome; settingsFormat = pkgs.formats.yaml { }; - args = lib.concatStringsSep " " ([ - "--no-check-update" - "--pidfile /run/AdGuardHome/AdGuardHome.pid" - "--work-dir /var/lib/AdGuardHome/" - "--config /var/lib/AdGuardHome/AdGuardHome.yaml" - ] ++ cfg.extraArgs); - - settings = if (cfg.settings != null) then - cfg.settings // (if cfg.settings.schema_version < 23 then { - bind_host = cfg.host; - bind_port = cfg.port; - } else { - http.address = "${cfg.host}:${toString cfg.port}"; - }) - else - null; - - configFile = - (settingsFormat.generate "AdGuardHome.yaml" settings).overrideAttrs (_: { - checkPhase = "${cfg.package}/bin/adguardhome -c $out --check-config"; - }); -in { + args = lib.concatStringsSep " " ( + [ + "--no-check-update" + "--pidfile /run/AdGuardHome/AdGuardHome.pid" + "--work-dir /var/lib/AdGuardHome/" + "--config /var/lib/AdGuardHome/AdGuardHome.yaml" + ] + ++ cfg.extraArgs + ); + + settings = + if (cfg.settings != null) then + cfg.settings + // ( + if cfg.settings.schema_version < 23 then + { + bind_host = cfg.host; + bind_port = cfg.port; + } + else + { + http.address = "${cfg.host}:${toString cfg.port}"; + } + ) + else + null; + + configFile = (settingsFormat.generate "AdGuardHome.yaml" settings).overrideAttrs (_: { + checkPhase = "${cfg.package}/bin/adguardhome -c $out --check-config"; + }); +in +{ options.services.adguardhome = with lib.types; { enable = lib.mkEnableOption "AdGuard Home network-wide ad blocker"; @@ -130,24 +145,24 @@ in { config = lib.mkIf cfg.enable { assertions = [ { - assertion = cfg.settings != null - -> !(lib.hasAttrByPath [ "bind_host" ] cfg.settings); + assertion = cfg.settings != null -> !(lib.hasAttrByPath [ "bind_host" ] cfg.settings); message = "AdGuard option `settings.bind_host' has been superseded by `services.adguardhome.host'"; } { - assertion = cfg.settings != null - -> !(lib.hasAttrByPath [ "bind_port" ] cfg.settings); + assertion = cfg.settings != null -> !(lib.hasAttrByPath [ "bind_port" ] cfg.settings); message = "AdGuard option `settings.bind_port' has been superseded by `services.adguardhome.port'"; } { - assertion = settings != null -> cfg.mutableSettings - || lib.hasAttrByPath [ "dns" "bootstrap_dns" ] settings; + assertion = + settings != null -> cfg.mutableSettings || lib.hasAttrByPath [ "dns" "bootstrap_dns" ] settings; message = "AdGuard setting dns.bootstrap_dns needs to be configured for a minimal working configuration"; } { - assertion = settings != null -> cfg.mutableSettings - || lib.hasAttrByPath [ "dns" "bootstrap_dns" ] settings - && lib.isList settings.dns.bootstrap_dns; + assertion = + settings != null + -> + cfg.mutableSettings + || lib.hasAttrByPath [ "dns" "bootstrap_dns" ] settings && lib.isList settings.dns.bootstrap_dns; message = "AdGuard setting dns.bootstrap_dns needs to be a list"; } ]; @@ -181,8 +196,7 @@ in { serviceConfig = { DynamicUser = true; ExecStart = "${lib.getExe cfg.package} ${args}"; - AmbientCapabilities = [ "CAP_NET_BIND_SERVICE" ] - ++ lib.optionals cfg.allowDHCP [ "CAP_NET_RAW" ]; + AmbientCapabilities = [ "CAP_NET_BIND_SERVICE" ] ++ lib.optionals cfg.allowDHCP [ "CAP_NET_RAW" ]; Restart = "always"; RestartSec = 10; RuntimeDirectory = "AdGuardHome"; diff --git a/nixos/modules/services/networking/alice-lg.nix b/nixos/modules/services/networking/alice-lg.nix index c43f898bd7d3d8..6c322f4cf633ba 100644 --- a/nixos/modules/services/networking/alice-lg.nix +++ b/nixos/modules/services/networking/alice-lg.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.alice-lg; settingsFormat = pkgs.formats.ini { }; diff --git a/nixos/modules/services/networking/aria2.nix b/nixos/modules/services/networking/aria2.nix index e0a41491e61c58..3e0961c753cbcc 100644 --- a/nixos/modules/services/networking/aria2.nix +++ b/nixos/modules/services/networking/aria2.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.aria2; @@ -7,30 +12,49 @@ let defaultRpcListenPort = 6800; defaultDir = "${homeDir}/Downloads"; - portRangesToString = ranges: lib.concatStringsSep "," (map - (x: - if x.from == x.to - then builtins.toString x.from - else builtins.toString x.from + "-" + builtins.toString x.to - ) - ranges); + portRangesToString = + ranges: + lib.concatStringsSep "," ( + map ( + x: + if x.from == x.to then + builtins.toString x.from + else + builtins.toString x.from + "-" + builtins.toString x.to + ) ranges + ); customToKeyValue = lib.generators.toKeyValue { - mkKeyValue = lib.generators.mkKeyValueDefault - { - mkValueString = v: - if builtins.isList v then portRangesToString v - else lib.generators.mkValueStringDefault { } v; - } "="; + mkKeyValue = lib.generators.mkKeyValueDefault { + mkValueString = + v: if builtins.isList v then portRangesToString v else lib.generators.mkValueStringDefault { } v; + } "="; }; in { imports = [ - (lib.mkRemovedOptionModule [ "services" "aria2" "rpcSecret" ] "Use services.aria2.rpcSecretFile instead") - (lib.mkRemovedOptionModule [ "services" "aria2" "extraArguments" ] "Use services.aria2.settings instead") - (lib.mkRenamedOptionModule [ "services" "aria2" "downloadDir" ] [ "services" "aria2" "settings" "dir" ]) - (lib.mkRenamedOptionModule [ "services" "aria2" "listenPortRange" ] [ "services" "aria2" "settings" "listen-port" ]) - (lib.mkRenamedOptionModule [ "services" "aria2" "rpcListenPort" ] [ "services" "aria2" "settings" "rpc-listen-port" ]) + (lib.mkRemovedOptionModule [ + "services" + "aria2" + "rpcSecret" + ] "Use services.aria2.rpcSecretFile instead") + (lib.mkRemovedOptionModule [ + "services" + "aria2" + "extraArguments" + ] "Use services.aria2.settings instead") + (lib.mkRenamedOptionModule + [ "services" "aria2" "downloadDir" ] + [ "services" "aria2" "settings" "dir" ] + ) + (lib.mkRenamedOptionModule + [ "services" "aria2" "listenPortRange" ] + [ "services" "aria2" "settings" "listen-port" ] + ) + (lib.mkRenamedOptionModule + [ "services" "aria2" "rpcListenPort" ] + [ "services" "aria2" "settings" "rpc-listen-port" ] + ) ]; options = { @@ -101,7 +125,14 @@ in ''; default = { }; type = lib.types.submodule { - freeformType = with lib.types; attrsOf (oneOf [ bool int float singleLineStr ]); + freeformType = + with lib.types; + attrsOf (oneOf [ + bool + int + float + singleLineStr + ]); options = { save-session = lib.mkOption { type = lib.types.singleLineStr; @@ -125,7 +156,12 @@ in }; listen-port = lib.mkOption { type = with lib.types; listOf (attrsOf port); - default = [{ from = 6881; to = 6999; }]; + default = [ + { + from = 6881; + to = 6999; + } + ]; description = "Set UDP listening port range used by DHT(IPv4, IPv6) and UDP tracker."; }; rpc-listen-port = lib.mkOption { diff --git a/nixos/modules/services/networking/asterisk.nix b/nixos/modules/services/networking/asterisk.nix index f165974f2ae725..28b169f0978271 100644 --- a/nixos/modules/services/networking/asterisk.nix +++ b/nixos/modules/services/networking/asterisk.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.asterisk; @@ -11,42 +16,45 @@ let # Add filecontents from files of useTheseDefaultConfFiles to confFiles, do not override defaultConfFiles = lib.subtractLists (lib.attrNames cfg.confFiles) cfg.useTheseDefaultConfFiles; - allConfFiles = { - # Default asterisk.conf file - "asterisk.conf".text = '' - [directories] - astetcdir => /etc/asterisk - astmoddir => ${cfg.package}/lib/asterisk/modules - astvarlibdir => /var/lib/asterisk - astdbdir => /var/lib/asterisk - astkeydir => /var/lib/asterisk - astdatadir => /var/lib/asterisk - astagidir => /var/lib/asterisk/agi-bin - astspooldir => /var/spool/asterisk - astrundir => /run/asterisk - astlogdir => /var/log/asterisk - astsbindir => ${cfg.package}/sbin - ${cfg.extraConfig} - ''; - - # Loading all modules by default is considered sensible by the authors of - # "Asterisk: The Definitive Guide". Secure sites will likely want to - # specify their own "modules.conf" in the confFiles option. - "modules.conf".text = '' - [modules] - autoload=yes - ''; - - # Use syslog for logging so logs can be viewed with journalctl - "logger.conf".text = '' - [general] - - [logfiles] - syslog.local0 => notice,warning,error - ''; - } // - lib.mapAttrs (name: text: { inherit text; }) cfg.confFiles // - lib.listToAttrs (map (x: lib.nameValuePair x { source = cfg.package + "/etc/asterisk/" + x; }) defaultConfFiles); + allConfFiles = + { + # Default asterisk.conf file + "asterisk.conf".text = '' + [directories] + astetcdir => /etc/asterisk + astmoddir => ${cfg.package}/lib/asterisk/modules + astvarlibdir => /var/lib/asterisk + astdbdir => /var/lib/asterisk + astkeydir => /var/lib/asterisk + astdatadir => /var/lib/asterisk + astagidir => /var/lib/asterisk/agi-bin + astspooldir => /var/spool/asterisk + astrundir => /run/asterisk + astlogdir => /var/log/asterisk + astsbindir => ${cfg.package}/sbin + ${cfg.extraConfig} + ''; + + # Loading all modules by default is considered sensible by the authors of + # "Asterisk: The Definitive Guide". Secure sites will likely want to + # specify their own "modules.conf" in the confFiles option. + "modules.conf".text = '' + [modules] + autoload=yes + ''; + + # Use syslog for logging so logs can be viewed with journalctl + "logger.conf".text = '' + [general] + + [logfiles] + syslog.local0 => notice,warning,error + ''; + } + // lib.mapAttrs (name: text: { inherit text; }) cfg.confFiles + // lib.listToAttrs ( + map (x: lib.nameValuePair x { source = cfg.package + "/etc/asterisk/" + x; }) defaultConfFiles + ); in @@ -76,53 +84,52 @@ in }; confFiles = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.str; - example = lib.literalExpression - '' - { - "extensions.conf" = ''' - [tests] - ; Dial 100 for "hello, world" - exten => 100,1,Answer() - same => n,Wait(1) - same => n,Playback(hello-world) - same => n,Hangup() - - [softphones] - include => tests - - [unauthorized] - '''; - "sip.conf" = ''' - [general] - allowguest=no ; Require authentication - context=unauthorized ; Send unauthorized users to /dev/null - srvlookup=no ; Don't do DNS lookup - udpbindaddr=0.0.0.0 ; Listen on all interfaces - nat=force_rport,comedia ; Assume device is behind NAT - - [softphone](!) - type=friend ; Match on username first, IP second - context=softphones ; Send to softphones context in - ; extensions.conf file - host=dynamic ; Device will register with asterisk - disallow=all ; Manually specify codecs to allow - allow=g722 - allow=ulaw - allow=alaw - - [myphone](softphone) - secret=GhoshevFew ; Change this password! - '''; - "logger.conf" = ''' - [general] - - [logfiles] - ; Add debug output to log - syslog.local0 => notice,warning,error,debug - '''; - } + example = lib.literalExpression '' + { + "extensions.conf" = ''' + [tests] + ; Dial 100 for "hello, world" + exten => 100,1,Answer() + same => n,Wait(1) + same => n,Playback(hello-world) + same => n,Hangup() + + [softphones] + include => tests + + [unauthorized] + '''; + "sip.conf" = ''' + [general] + allowguest=no ; Require authentication + context=unauthorized ; Send unauthorized users to /dev/null + srvlookup=no ; Don't do DNS lookup + udpbindaddr=0.0.0.0 ; Listen on all interfaces + nat=force_rport,comedia ; Assume device is behind NAT + + [softphone](!) + type=friend ; Match on username first, IP second + context=softphones ; Send to softphones context in + ; extensions.conf file + host=dynamic ; Device will register with asterisk + disallow=all ; Manually specify codecs to allow + allow=g722 + allow=ulaw + allow=alaw + + [myphone](softphone) + secret=GhoshevFew ; Change this password! + '''; + "logger.conf" = ''' + [general] + + [logfiles] + ; Add debug output to log + syslog.local0 => notice,warning,error,debug + '''; + } ''; description = '' Sets the content of config files (typically ending with @@ -142,20 +149,54 @@ in }; useTheseDefaultConfFiles = lib.mkOption { - default = [ "ari.conf" "acl.conf" "agents.conf" "amd.conf" "calendar.conf" "cdr.conf" "cdr_syslog.conf" "cdr_custom.conf" "cel.conf" "cel_custom.conf" "cli_aliases.conf" "confbridge.conf" "dundi.conf" "features.conf" "hep.conf" "iax.conf" "pjsip.conf" "pjsip_wizard.conf" "phone.conf" "phoneprov.conf" "queues.conf" "res_config_sqlite3.conf" "res_parking.conf" "statsd.conf" "udptl.conf" "unistim.conf" ]; + default = [ + "ari.conf" + "acl.conf" + "agents.conf" + "amd.conf" + "calendar.conf" + "cdr.conf" + "cdr_syslog.conf" + "cdr_custom.conf" + "cel.conf" + "cel_custom.conf" + "cli_aliases.conf" + "confbridge.conf" + "dundi.conf" + "features.conf" + "hep.conf" + "iax.conf" + "pjsip.conf" + "pjsip_wizard.conf" + "phone.conf" + "phoneprov.conf" + "queues.conf" + "res_config_sqlite3.conf" + "res_parking.conf" + "statsd.conf" + "udptl.conf" + "unistim.conf" + ]; type = lib.types.listOf lib.types.str; - example = [ "sip.conf" "dundi.conf" ]; - description = ''Sets these config files to the default content. The default value for - this option contains all necesscary files to avoid errors at startup. - This does not override settings via {option}`services.asterisk.confFiles`. + example = [ + "sip.conf" + "dundi.conf" + ]; + description = '' + Sets these config files to the default content. The default value for + this option contains all necesscary files to avoid errors at startup. + This does not override settings via {option}`services.asterisk.confFiles`. ''; }; extraArguments = lib.mkOption { - default = []; + default = [ ]; type = lib.types.listOf lib.types.str; - example = - [ "-vvvddd" "-e" "1024" ]; + example = [ + "-vvvddd" + "-e" + "1024" + ]; description = '' Additional command line arguments to pass to Asterisk. ''; @@ -167,22 +208,22 @@ in config = lib.mkIf cfg.enable { environment.systemPackages = [ cfg.package ]; - environment.etc = lib.mapAttrs' (name: value: - lib.nameValuePair "asterisk/${name}" value + environment.etc = lib.mapAttrs' ( + name: value: lib.nameValuePair "asterisk/${name}" value ) allConfFiles; - users.users.asterisk = - { name = asteriskUser; - group = asteriskGroup; - uid = config.ids.uids.asterisk; - description = "Asterisk daemon user"; - home = varlibdir; - }; + users.users.asterisk = { + name = asteriskUser; + group = asteriskGroup; + uid = config.ids.uids.asterisk; + description = "Asterisk daemon user"; + home = varlibdir; + }; - users.groups.asterisk = - { name = asteriskGroup; - gid = config.ids.gids.asterisk; - }; + users.groups.asterisk = { + name = asteriskGroup; + gid = config.ids.gids.asterisk; + }; systemd.services.asterisk = { description = '' @@ -214,8 +255,9 @@ in argString = lib.concatStringsSep " " cfg.extraArguments; in "${cfg.package}/bin/asterisk -U ${asteriskUser} -C /etc/asterisk/asterisk.conf ${argString} -F"; - ExecReload = ''${cfg.package}/bin/asterisk -x "core reload" - ''; + ExecReload = '' + ${cfg.package}/bin/asterisk -x "core reload" + ''; Type = "forking"; PIDFile = "/run/asterisk/asterisk.pid"; }; diff --git a/nixos/modules/services/networking/atftpd.nix b/nixos/modules/services/networking/atftpd.nix index ab674d85715c6e..b2446dcbd65b8f 100644 --- a/nixos/modules/services/networking/atftpd.nix +++ b/nixos/modules/services/networking/atftpd.nix @@ -1,5 +1,10 @@ # NixOS module for atftpd TFTP server -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.atftpd; @@ -22,7 +27,7 @@ in }; extraOptions = lib.mkOption { - default = []; + default = [ ]; type = lib.types.listOf lib.types.str; example = lib.literalExpression '' [ "--bind-address 192.168.9.1" diff --git a/nixos/modules/services/networking/autossh.nix b/nixos/modules/services/networking/autossh.nix index f8934845c28e22..d40c7b5cb4153e 100644 --- a/nixos/modules/services/networking/autossh.nix +++ b/nixos/modules/services/networking/autossh.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.autossh; @@ -14,43 +19,45 @@ in services.autossh = { sessions = lib.mkOption { - type = lib.types.listOf (lib.types.submodule { - options = { - name = lib.mkOption { - type = lib.types.str; - example = "socks-peer"; - description = "Name of the local AutoSSH session"; - }; - user = lib.mkOption { - type = lib.types.str; - example = "bill"; - description = "Name of the user the AutoSSH session should run as"; - }; - monitoringPort = lib.mkOption { - type = lib.types.int; - default = 0; - example = 20000; - description = '' - Port to be used by AutoSSH for peer monitoring. Note, that - AutoSSH also uses mport+1. Value of 0 disables the keep-alive - style monitoring - ''; - }; - extraArguments = lib.mkOption { - type = lib.types.separatedString " "; - example = "-N -D4343 bill@socks.example.net"; - description = '' - Arguments to be passed to AutoSSH and retransmitted to SSH - process. Some meaningful options include -N (don't run remote - command), -D (open SOCKS proxy on local port), -R (forward - remote port), -L (forward local port), -v (Enable debug). Check - ssh manual for the complete list. - ''; + type = lib.types.listOf ( + lib.types.submodule { + options = { + name = lib.mkOption { + type = lib.types.str; + example = "socks-peer"; + description = "Name of the local AutoSSH session"; + }; + user = lib.mkOption { + type = lib.types.str; + example = "bill"; + description = "Name of the user the AutoSSH session should run as"; + }; + monitoringPort = lib.mkOption { + type = lib.types.int; + default = 0; + example = 20000; + description = '' + Port to be used by AutoSSH for peer monitoring. Note, that + AutoSSH also uses mport+1. Value of 0 disables the keep-alive + style monitoring + ''; + }; + extraArguments = lib.mkOption { + type = lib.types.separatedString " "; + example = "-N -D4343 bill@socks.example.net"; + description = '' + Arguments to be passed to AutoSSH and retransmitted to SSH + process. Some meaningful options include -N (don't run remote + command), -D (open SOCKS proxy on local port), -R (forward + remote port), -L (forward local port), -v (Enable debug). Check + ssh manual for the complete list. + ''; + }; }; - }; - }); + } + ); - default = []; + default = [ ]; description = '' List of AutoSSH sessions to start as systemd services. Each service is named 'autossh-{session.name}'. @@ -58,10 +65,10 @@ in example = [ { - name="socks-peer"; - user="bill"; + name = "socks-peer"; + user = "bill"; monitoringPort = 20000; - extraArguments="-N -D4343 billremote@socks.host.net"; + extraArguments = "-N -D4343 billremote@socks.host.net"; } ]; @@ -72,12 +79,14 @@ in ###### implementation - config = lib.mkIf (cfg.sessions != []) { + config = lib.mkIf (cfg.sessions != [ ]) { systemd.services = - lib.foldr ( s : acc : acc // - { + lib.foldr ( + s: acc: + acc + // { "autossh-${s.name}" = let mport = if s ? monitoringPort then s.monitoringPort else 0; @@ -89,20 +98,21 @@ in wantedBy = [ "multi-user.target" ]; # To be able to start the service with no network connection - environment.AUTOSSH_GATETIME="0"; + environment.AUTOSSH_GATETIME = "0"; # How often AutoSSH checks the network, in seconds - environment.AUTOSSH_POLL="30"; + environment.AUTOSSH_POLL = "30"; serviceConfig = { - User = "${s.user}"; - # AutoSSH may exit with 0 code if the SSH session was - # gracefully terminated by either local or remote side. - Restart = "on-success"; - ExecStart = "${pkgs.autossh}/bin/autossh -M ${toString mport} ${s.extraArguments}"; + User = "${s.user}"; + # AutoSSH may exit with 0 code if the SSH session was + # gracefully terminated by either local or remote side. + Restart = "on-success"; + ExecStart = "${pkgs.autossh}/bin/autossh -M ${toString mport} ${s.extraArguments}"; }; }; - }) {} cfg.sessions; + } + ) { } cfg.sessions; environment.systemPackages = [ pkgs.autossh ]; diff --git a/nixos/modules/services/networking/babeld.nix b/nixos/modules/services/networking/babeld.nix index 538654f90ae4c7..bc5574139d35f3 100644 --- a/nixos/modules/services/networking/babeld.nix +++ b/nixos/modules/services/networking/babeld.nix @@ -1,29 +1,41 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.babeld; - conditionalBoolToString = value: if (lib.isBool value) then (lib.boolToString value) else (toString value); + conditionalBoolToString = + value: if (lib.isBool value) then (lib.boolToString value) else (toString value); - paramsString = params: - lib.concatMapStringsSep " " (name: "${name} ${conditionalBoolToString (lib.getAttr name params)}") - (lib.attrNames params); + paramsString = + params: + lib.concatMapStringsSep " " (name: "${name} ${conditionalBoolToString (lib.getAttr name params)}") ( + lib.attrNames params + ); - interfaceConfig = name: + interfaceConfig = + name: let interface = lib.getAttr name cfg.interfaces; in "interface ${name} ${paramsString interface}\n"; - configFile = with cfg; pkgs.writeText "babeld.conf" ( - '' - skip-kernel-setup true - '' - + (lib.optionalString (cfg.interfaceDefaults != null) '' - default ${paramsString cfg.interfaceDefaults} - '') - + (lib.concatMapStrings interfaceConfig (lib.attrNames cfg.interfaces)) - + extraConfig); + configFile = + with cfg; + pkgs.writeText "babeld.conf" ( + '' + skip-kernel-setup true + '' + + (lib.optionalString (cfg.interfaceDefaults != null) '' + default ${paramsString cfg.interfaceDefaults} + '') + + (lib.concatMapStrings interfaceConfig (lib.attrNames cfg.interfaces)) + + extraConfig + ); in @@ -46,27 +58,26 @@ in See {manpage}`babeld(8)` for options. ''; type = lib.types.nullOr (lib.types.attrsOf lib.types.unspecified); - example = - { - type = "tunnel"; - split-horizon = true; - }; + example = { + type = "tunnel"; + split-horizon = true; + }; }; interfaces = lib.mkOption { - default = {}; + default = { }; description = '' A set describing babeld interfaces. See {manpage}`babeld(8)` for options. ''; type = lib.types.attrsOf (lib.types.attrsOf lib.types.unspecified); - example = - { enp0s2 = - { type = "wired"; - hello-interval = 5; - split-horizon = "auto"; - }; + example = { + enp0s2 = { + type = "wired"; + hello-interval = 5; + split-horizon = "auto"; }; + }; }; extraConfig = lib.mkOption { @@ -81,17 +92,20 @@ in }; - ###### implementation config = lib.mkIf config.services.babeld.enable { - boot.kernel.sysctl = { - "net.ipv6.conf.all.forwarding" = 1; - "net.ipv6.conf.all.accept_redirects" = 0; - "net.ipv4.conf.all.forwarding" = 1; - "net.ipv4.conf.all.rp_filter" = 0; - } // lib.mapAttrs' (ifname: _: lib.nameValuePair "net.ipv4.conf.${ifname}.rp_filter" (lib.mkDefault 0)) config.services.babeld.interfaces; + boot.kernel.sysctl = + { + "net.ipv6.conf.all.forwarding" = 1; + "net.ipv6.conf.all.accept_redirects" = 0; + "net.ipv4.conf.all.forwarding" = 1; + "net.ipv4.conf.all.rp_filter" = 0; + } + // lib.mapAttrs' ( + ifname: _: lib.nameValuePair "net.ipv4.conf.${ifname}.rp_filter" (lib.mkDefault 0) + ) config.services.babeld.interfaces; systemd.services.babeld = { description = "Babel routing daemon"; @@ -103,7 +117,12 @@ in CapabilityBoundingSet = [ "CAP_NET_ADMIN" ]; DevicePolicy = "closed"; DynamicUser = true; - IPAddressAllow = [ "fe80::/64" "ff00::/8" "::1/128" "127.0.0.0/8" ]; + IPAddressAllow = [ + "fe80::/64" + "ff00::/8" + "::1/128" + "127.0.0.0/8" + ]; IPAddressDeny = "any"; LockPersonality = true; NoNewPrivileges = true; @@ -114,7 +133,11 @@ in ProtectKernelModules = true; ProtectKernelLogs = true; ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_NETLINK" "AF_INET6" "AF_INET" ]; + RestrictAddressFamilies = [ + "AF_NETLINK" + "AF_INET6" + "AF_INET" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; diff --git a/nixos/modules/services/networking/bee.nix b/nixos/modules/services/networking/bee.nix index 6f3f7af607fbf3..82710ca45570df 100644 --- a/nixos/modules/services/networking/bee.nix +++ b/nixos/modules/services/networking/bee.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.bee; - format = pkgs.formats.yaml {}; + format = pkgs.formats.yaml { }; configFile = format.generate "bee.yaml" cfg.settings; -in { +in +{ meta = { # doc = ./bee.xml; maintainers = [ ]; @@ -59,12 +65,15 @@ in { config = lib.mkIf cfg.enable { assertions = [ - { assertion = (lib.hasAttr "password" cfg.settings) != true; + { + assertion = (lib.hasAttr "password" cfg.settings) != true; message = '' `services.bee.settings.password` is insecure. Use `services.bee.settings.password-file` or `systemd.services.bee.serviceConfig.EnvironmentFile` instead. ''; } - { assertion = (lib.hasAttr "swap-endpoint" cfg.settings) || (cfg.settings.swap-enable or true == false); + { + assertion = + (lib.hasAttr "swap-endpoint" cfg.settings) || (cfg.settings.swap-enable or true == false); message = '' In a swap-enabled network a working Ethereum blockchain node is required. You must specify one using `services.bee.settings.swap-endpoint`, or disable `services.bee.settings.swap-enable` = false. ''; @@ -72,10 +81,10 @@ in { ]; services.bee.settings = { - data-dir = lib.mkDefault "/var/lib/bee"; - password-file = lib.mkDefault "/var/lib/bee/password"; - clef-signer-enable = lib.mkDefault true; - swap-endpoint = lib.mkDefault "https://rpc.slock.it/goerli"; + data-dir = lib.mkDefault "/var/lib/bee"; + password-file = lib.mkDefault "/var/lib/bee/password"; + clef-signer-enable = lib.mkDefault true; + swap-endpoint = lib.mkDefault "https://rpc.slock.it/goerli"; }; systemd.packages = [ cfg.package ]; # include the upstream bee.service file @@ -98,22 +107,22 @@ in { }; preStart = with cfg.settings; '' - if ! test -f ${password-file}; then - < /dev/urandom tr -dc _A-Z-a-z-0-9 2> /dev/null | head -c32 | install -m 600 /dev/stdin ${password-file} - echo "Initialized ${password-file} from /dev/urandom" - fi - if [ ! -f ${data-dir}/keys/libp2p.key ]; then - ${cfg.package}/bin/bee init --config=${configFile} >/dev/null - echo " -Logs: journalctl -f -u bee.service - -Bee has SWAP enabled by default and it needs ethereum endpoint to operate. -It is recommended to use external signer with bee. -Check documentation for more info: -- SWAP https://docs.ethswarm.org/docs/installation/manual#swap-bandwidth-incentives - -After you finish configuration run 'sudo bee-get-addr'." - fi + if ! test -f ${password-file}; then + < /dev/urandom tr -dc _A-Z-a-z-0-9 2> /dev/null | head -c32 | install -m 600 /dev/stdin ${password-file} + echo "Initialized ${password-file} from /dev/urandom" + fi + if [ ! -f ${data-dir}/keys/libp2p.key ]; then + ${cfg.package}/bin/bee init --config=${configFile} >/dev/null + echo " + Logs: journalctl -f -u bee.service + + Bee has SWAP enabled by default and it needs ethereum endpoint to operate. + It is recommended to use external signer with bee. + Check documentation for more info: + - SWAP https://docs.ethswarm.org/docs/installation/manual#swap-bandwidth-incentives + + After you finish configuration run 'sudo bee-get-addr'." + fi ''; }; @@ -127,7 +136,7 @@ After you finish configuration run 'sudo bee-get-addr'." }; users.groups = lib.optionalAttrs (cfg.group == "bee") { - bee = {}; + bee = { }; }; }; } diff --git a/nixos/modules/services/networking/biboumi.nix b/nixos/modules/services/networking/biboumi.nix index 33cb1d95bc51fd..c9259cf82ccbf0 100644 --- a/nixos/modules/services/networking/biboumi.nix +++ b/nixos/modules/services/networking/biboumi.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, options, ... }: +{ + config, + lib, + pkgs, + options, + ... +}: let cfg = config.services.biboumi; inherit (config.environment) etc; @@ -6,9 +12,9 @@ let stateDir = "/var/lib/biboumi"; settingsFile = pkgs.writeText "biboumi.cfg" ( lib.generators.toKeyValue { - mkKeyValue = k: v: - lib.optionalString (v != null) (lib.generators.mkKeyValueDefault {} "=" k v); - } cfg.settings); + mkKeyValue = k: v: lib.optionalString (v != null) (lib.generators.mkKeyValueDefault { } "=" k v); + } cfg.settings + ); need_CAP_NET_BIND_SERVICE = cfg.settings.identd_port != 0 && cfg.settings.identd_port < 1024; in { @@ -21,16 +27,24 @@ in See [biboumi 8.5](https://lab.louiz.org/louiz/biboumi/blob/8.5/doc/biboumi.1.rst) for documentation. ''; - default = {}; + default = { }; type = lib.types.submodule { - freeformType = with lib.types; - (attrsOf (nullOr (oneOf [str int bool]))) // { + freeformType = + with lib.types; + (attrsOf ( + nullOr (oneOf [ + str + int + bool + ]) + )) + // { description = "settings option"; }; options.admin = lib.mkOption { type = with lib.types; listOf str; - default = []; - example = ["admin@example.org"]; + default = [ ]; + example = [ "admin@example.org" ]; apply = lib.concatStringsSep ":"; description = '' The bare JID of the gateway administrator. This JID will have more @@ -169,8 +183,9 @@ in }; config = lib.mkIf cfg.enable { - networking.firewall = lib.mkIf (cfg.openFirewall && cfg.settings.identd_port != 0) - { allowedTCPPorts = [ cfg.settings.identd_port ]; }; + networking.firewall = lib.mkIf (cfg.openFirewall && cfg.settings.identd_port != 0) { + allowedTCPPorts = [ cfg.settings.identd_port ]; + }; systemd.services.biboumi = { description = "Biboumi, XMPP to IRC gateway"; @@ -183,11 +198,16 @@ in WatchdogSec = 20; Restart = "always"; # Use "+" because credentialsFile may not be accessible to User= or Group=. - ExecStartPre = [("+" + pkgs.writeShellScript "biboumi-prestart" '' - set -eux - cat ${settingsFile} '${cfg.credentialsFile}' | - install -m 644 /dev/stdin /run/biboumi/biboumi.cfg - '')]; + ExecStartPre = [ + ( + "+" + + pkgs.writeShellScript "biboumi-prestart" '' + set -eux + cat ${settingsFile} '${cfg.credentialsFile}' | + install -m 644 /dev/stdin /run/biboumi/biboumi.cfg + '' + ) + ]; ExecStart = "${pkgs.biboumi}/bin/biboumi /run/biboumi/biboumi.cfg"; ExecReload = "${pkgs.coreutils}/bin/kill -USR1 $MAINPID"; # Firewalls needing opening for output connections can still do that @@ -201,7 +221,10 @@ in RootDirectory = rootDir; RootDirectoryStartOnly = true; InaccessiblePaths = [ "-+${rootDir}" ]; - RuntimeDirectory = [ "biboumi" (lib.removePrefix "/run/" rootDir) ]; + RuntimeDirectory = [ + "biboumi" + (lib.removePrefix "/run/" rootDir) + ]; RuntimeDirectoryMode = "700"; StateDirectory = "biboumi"; StateDirectoryMode = "700"; @@ -244,7 +267,11 @@ in ProtectSystem = "strict"; RemoveIPC = true; # AF_UNIX is for /run/systemd/notify - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; @@ -256,7 +283,13 @@ in # To run such a perf in ExecStart=, you have to: # - AmbientCapabilities="CAP_SYS_ADMIN" # - mount -o remount,mode=755 /sys/kernel/debug/{,tracing} - "~@aio" "~@chown" "~@ipc" "~@keyring" "~@resources" "~@setuid" "~@timer" + "~@aio" + "~@chown" + "~@ipc" + "~@keyring" + "~@resources" + "~@setuid" + "~@timer" ]; SystemCallArchitectures = "native"; SystemCallErrorNumber = "EPERM"; diff --git a/nixos/modules/services/networking/bird-lg.nix b/nixos/modules/services/networking/bird-lg.nix index f73c0b796e6f10..ed296b98943f31 100644 --- a/nixos/modules/services/networking/bird-lg.nix +++ b/nixos/modules/services/networking/bird-lg.nix @@ -1,49 +1,61 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.bird-lg; stringOrConcat = sep: v: if builtins.isString v then v else lib.concatStringsSep sep v; - frontend_args = let - fe = cfg.frontend; - in { - "--servers" = lib.concatStringsSep "," fe.servers; - "--domain" = fe.domain; - "--listen" = fe.listenAddress; - "--proxy-port" = fe.proxyPort; - "--whois" = fe.whois; - "--dns-interface" = fe.dnsInterface; - "--bgpmap-info" = lib.concatStringsSep "," cfg.frontend.bgpMapInfo; - "--title-brand" = fe.titleBrand; - "--navbar-brand" = fe.navbar.brand; - "--navbar-brand-url" = fe.navbar.brandURL; - "--navbar-all-servers" = fe.navbar.allServers; - "--navbar-all-url" = fe.navbar.allServersURL; - "--net-specific-mode" = fe.netSpecificMode; - "--protocol-filter" = lib.concatStringsSep "," cfg.frontend.protocolFilter; - }; + frontend_args = + let + fe = cfg.frontend; + in + { + "--servers" = lib.concatStringsSep "," fe.servers; + "--domain" = fe.domain; + "--listen" = fe.listenAddress; + "--proxy-port" = fe.proxyPort; + "--whois" = fe.whois; + "--dns-interface" = fe.dnsInterface; + "--bgpmap-info" = lib.concatStringsSep "," cfg.frontend.bgpMapInfo; + "--title-brand" = fe.titleBrand; + "--navbar-brand" = fe.navbar.brand; + "--navbar-brand-url" = fe.navbar.brandURL; + "--navbar-all-servers" = fe.navbar.allServers; + "--navbar-all-url" = fe.navbar.allServersURL; + "--net-specific-mode" = fe.netSpecificMode; + "--protocol-filter" = lib.concatStringsSep "," cfg.frontend.protocolFilter; + }; - proxy_args = let - px = cfg.proxy; - in { - "--allowed" = lib.concatStringsSep "," px.allowedIPs; - "--bird" = px.birdSocket; - "--listen" = px.listenAddress; - "--traceroute_bin" = px.traceroute.binary; - "--traceroute_flags" = lib.concatStringsSep " " px.traceroute.flags; - "--traceroute_raw" = px.traceroute.rawOutput; - }; + proxy_args = + let + px = cfg.proxy; + in + { + "--allowed" = lib.concatStringsSep "," px.allowedIPs; + "--bird" = px.birdSocket; + "--listen" = px.listenAddress; + "--traceroute_bin" = px.traceroute.binary; + "--traceroute_flags" = lib.concatStringsSep " " px.traceroute.flags; + "--traceroute_raw" = px.traceroute.rawOutput; + }; - mkArgValue = value: - if lib.isString value - then lib.escapeShellArg value - else if lib.isBool value - then lib.boolToString value - else toString value; + mkArgValue = + value: + if lib.isString value then + lib.escapeShellArg value + else if lib.isBool value then + lib.boolToString value + else + toString value; - filterNull = lib.filterAttrs (_: v: v != "" && v != null && v != []); + filterNull = lib.filterAttrs (_: v: v != "" && v != null && v != [ ]); - argsAttrToList = args: lib.mapAttrsToList (name: value: "${name} " + mkArgValue value ) (filterNull args); + argsAttrToList = + args: lib.mapAttrsToList (name: value: "${name} " + mkArgValue value) (filterNull args); in { options = { @@ -85,7 +97,10 @@ in servers = lib.mkOption { type = lib.types.listOf lib.types.str; - example = [ "gigsgigscloud" "hostdare" ]; + example = [ + "gigsgigscloud" + "hostdare" + ]; description = "Server name prefixes."; }; @@ -103,7 +118,12 @@ in bgpMapInfo = lib.mkOption { type = lib.types.listOf lib.types.str; - default = [ "asn" "as-name" "ASName" "descr" ]; + default = [ + "asn" + "as-name" + "ASName" + "descr" + ]; description = "Information displayed in bgpmap."; }; @@ -191,7 +211,11 @@ in allowedIPs = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "192.168.25.52" "192.168.25.53" "192.168.0.0/24" ]; + example = [ + "192.168.25.52" + "192.168.25.53" + "192.168.0.0/24" + ]; description = "List of IPs or networks to allow (default all allowed)."; }; @@ -242,13 +266,12 @@ in config = { warnings = - lib.optional (cfg.frontend.enable && builtins.isString cfg.frontend.extraArgs) '' + lib.optional (cfg.frontend.enable && builtins.isString cfg.frontend.extraArgs) '' Passing strings to `services.bird-lg.frontend.extraOptions' is deprecated. Please pass a list of strings instead. '' - ++ lib.optional (cfg.proxy.enable && builtins.isString cfg.proxy.extraArgs) '' + ++ lib.optional (cfg.proxy.enable && builtins.isString cfg.proxy.extraArgs) '' Passing strings to `services.bird-lg.proxy.extraOptions' is deprecated. Please pass a list of strings instead. - '' - ; + ''; systemd.services = { bird-lg-frontend = lib.mkIf cfg.frontend.enable { diff --git a/nixos/modules/services/networking/bird.nix b/nixos/modules/services/networking/bird.nix index 01a5a48f1ed514..4588e39ea37ca7 100644 --- a/nixos/modules/services/networking/bird.nix +++ b/nixos/modules/services/networking/bird.nix @@ -1,10 +1,25 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkIf mkOption optionalString types; + inherit (lib) + mkEnableOption + mkIf + mkOption + optionalString + types + ; cfg = config.services.bird2; - caps = [ "CAP_NET_ADMIN" "CAP_NET_BIND_SERVICE" "CAP_NET_RAW" ]; + caps = [ + "CAP_NET_ADMIN" + "CAP_NET_BIND_SERVICE" + "CAP_NET_RAW" + ]; in { ###### interface @@ -52,7 +67,6 @@ in }; }; - imports = [ (lib.mkRemovedOptionModule [ "services" "bird" ] "Use services.bird2 instead") (lib.mkRemovedOptionModule [ "services" "bird6" ] "Use services.bird2 instead") diff --git a/nixos/modules/services/networking/birdwatcher.nix b/nixos/modules/services/networking/birdwatcher.nix index 434f0e2095f302..07df2ee6244435 100644 --- a/nixos/modules/services/networking/birdwatcher.nix +++ b/nixos/modules/services/networking/birdwatcher.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.birdwatcher; in @@ -10,7 +15,10 @@ in flags = lib.mkOption { default = [ ]; type = lib.types.listOf lib.types.str; - example = [ "-worker-pool-size 16" "-6" ]; + example = [ + "-worker-pool-size 16" + "-6" + ]; description = '' Flags to append to the program call ''; @@ -69,8 +77,10 @@ in }; config = - let flagsStr = lib.escapeShellArgs cfg.flags; - in lib.mkIf cfg.enable { + let + flagsStr = lib.escapeShellArgs cfg.flags; + in + lib.mkIf cfg.enable { environment.etc."birdwatcher/birdwatcher.conf".source = pkgs.writeTextFile { name = "birdwatcher.conf"; text = cfg.settings; diff --git a/nixos/modules/services/networking/bitcoind.nix b/nixos/modules/services/networking/bitcoind.nix index 36cdcd49ea156f..e46a101c204356 100644 --- a/nixos/modules/services/networking/bitcoind.nix +++ b/nixos/modules/services/networking/bitcoind.nix @@ -1,253 +1,282 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; let eachBitcoind = filterAttrs (bitcoindName: cfg: cfg.enable) config.services.bitcoind; - rpcUserOpts = { name, ... }: { - options = { - name = mkOption { - type = types.str; - example = "alice"; - description = '' - Username for JSON-RPC connections. - ''; - }; - passwordHMAC = mkOption { - type = types.uniq (types.strMatching "[0-9a-f]+\\$[0-9a-f]{64}"); - example = "f7efda5c189b999524f151318c0c86$d5b51b3beffbc02b724e5d095828e0bc8b2456e9ac8757ae3211a5d9b16a22ae"; - description = '' - Password HMAC-SHA-256 for JSON-RPC connections. Must be a string of the - format \$\. + rpcUserOpts = + { name, ... }: + { + options = { + name = mkOption { + type = types.str; + example = "alice"; + description = '' + Username for JSON-RPC connections. + ''; + }; + passwordHMAC = mkOption { + type = types.uniq (types.strMatching "[0-9a-f]+\\$[0-9a-f]{64}"); + example = "f7efda5c189b999524f151318c0c86$d5b51b3beffbc02b724e5d095828e0bc8b2456e9ac8757ae3211a5d9b16a22ae"; + description = '' + Password HMAC-SHA-256 for JSON-RPC connections. Must be a string of the + format \$\. - Tool (Python script) for HMAC generation is available here: - - ''; + Tool (Python script) for HMAC generation is available here: + + ''; + }; + }; + config = { + name = mkDefault name; }; }; - config = { - name = mkDefault name; - }; - }; - - bitcoindOpts = { config, lib, name, ...}: { - options = { - enable = mkEnableOption "Bitcoin daemon"; + bitcoindOpts = + { + config, + lib, + name, + ... + }: + { + options = { - package = mkPackageOption pkgs "bitcoind" { }; + enable = mkEnableOption "Bitcoin daemon"; - configFile = mkOption { - type = types.nullOr types.path; - default = null; - example = "/var/lib/${name}/bitcoin.conf"; - description = "The configuration file path to supply bitcoind."; - }; + package = mkPackageOption pkgs "bitcoind" { }; - extraConfig = mkOption { - type = types.lines; - default = ""; - example = '' - par=16 - rpcthreads=16 - logips=1 - ''; - description = "Additional configurations to be appended to {file}`bitcoin.conf`."; - }; + configFile = mkOption { + type = types.nullOr types.path; + default = null; + example = "/var/lib/${name}/bitcoin.conf"; + description = "The configuration file path to supply bitcoind."; + }; - dataDir = mkOption { - type = types.path; - default = "/var/lib/bitcoind-${name}"; - description = "The data directory for bitcoind."; - }; + extraConfig = mkOption { + type = types.lines; + default = ""; + example = '' + par=16 + rpcthreads=16 + logips=1 + ''; + description = "Additional configurations to be appended to {file}`bitcoin.conf`."; + }; - user = mkOption { - type = types.str; - default = "bitcoind-${name}"; - description = "The user as which to run bitcoind."; - }; + dataDir = mkOption { + type = types.path; + default = "/var/lib/bitcoind-${name}"; + description = "The data directory for bitcoind."; + }; - group = mkOption { - type = types.str; - default = config.user; - description = "The group as which to run bitcoind."; - }; + user = mkOption { + type = types.str; + default = "bitcoind-${name}"; + description = "The user as which to run bitcoind."; + }; - rpc = { - port = mkOption { - type = types.nullOr types.port; - default = null; - description = "Override the default port on which to listen for JSON-RPC connections."; + group = mkOption { + type = types.str; + default = config.user; + description = "The group as which to run bitcoind."; }; - users = mkOption { - default = {}; - example = literalExpression '' - { - alice.passwordHMAC = "f7efda5c189b999524f151318c0c86$d5b51b3beffbc02b724e5d095828e0bc8b2456e9ac8757ae3211a5d9b16a22ae"; - bob.passwordHMAC = "b2dd077cb54591a2f3139e69a897ac$4e71f08d48b4347cf8eff3815c0e25ae2e9a4340474079f55705f40574f4ec99"; - } - ''; - type = types.attrsOf (types.submodule rpcUserOpts); - description = "RPC user information for JSON-RPC connections."; + + rpc = { + port = mkOption { + type = types.nullOr types.port; + default = null; + description = "Override the default port on which to listen for JSON-RPC connections."; + }; + users = mkOption { + default = { }; + example = literalExpression '' + { + alice.passwordHMAC = "f7efda5c189b999524f151318c0c86$d5b51b3beffbc02b724e5d095828e0bc8b2456e9ac8757ae3211a5d9b16a22ae"; + bob.passwordHMAC = "b2dd077cb54591a2f3139e69a897ac$4e71f08d48b4347cf8eff3815c0e25ae2e9a4340474079f55705f40574f4ec99"; + } + ''; + type = types.attrsOf (types.submodule rpcUserOpts); + description = "RPC user information for JSON-RPC connections."; + }; }; - }; - pidFile = mkOption { - type = types.path; - default = "${config.dataDir}/bitcoind.pid"; - description = "Location of bitcoind pid file."; - }; + pidFile = mkOption { + type = types.path; + default = "${config.dataDir}/bitcoind.pid"; + description = "Location of bitcoind pid file."; + }; - testnet = mkOption { - type = types.bool; - default = false; - description = "Whether to use the testnet instead of mainnet."; - }; + testnet = mkOption { + type = types.bool; + default = false; + description = "Whether to use the testnet instead of mainnet."; + }; - port = mkOption { - type = types.nullOr types.port; - default = null; - description = "Override the default port on which to listen for connections."; - }; + port = mkOption { + type = types.nullOr types.port; + default = null; + description = "Override the default port on which to listen for connections."; + }; - dbCache = mkOption { - type = types.nullOr (types.ints.between 4 16384); - default = null; - example = 4000; - description = "Override the default database cache size in MiB."; - }; + dbCache = mkOption { + type = types.nullOr (types.ints.between 4 16384); + default = null; + example = 4000; + description = "Override the default database cache size in MiB."; + }; - prune = mkOption { - type = types.nullOr (types.coercedTo - (types.enum [ "disable" "manual" ]) - (x: if x == "disable" then 0 else 1) - types.ints.unsigned - ); - default = null; - example = 10000; - description = '' - Reduce storage requirements by enabling pruning (deleting) of old - blocks. This allows the pruneblockchain RPC to be called to delete - specific blocks, and enables automatic pruning of old blocks if a - target size in MiB is provided. This mode is incompatible with -txindex - and -rescan. Warning: Reverting this setting requires re-downloading - the entire blockchain. ("disable" = disable pruning blocks, "manual" - = allow manual pruning via RPC, >=550 = automatically prune block files - to stay under the specified target size in MiB). - ''; - }; + prune = mkOption { + type = types.nullOr ( + types.coercedTo (types.enum [ + "disable" + "manual" + ]) (x: if x == "disable" then 0 else 1) types.ints.unsigned + ); + default = null; + example = 10000; + description = '' + Reduce storage requirements by enabling pruning (deleting) of old + blocks. This allows the pruneblockchain RPC to be called to delete + specific blocks, and enables automatic pruning of old blocks if a + target size in MiB is provided. This mode is incompatible with -txindex + and -rescan. Warning: Reverting this setting requires re-downloading + the entire blockchain. ("disable" = disable pruning blocks, "manual" + = allow manual pruning via RPC, >=550 = automatically prune block files + to stay under the specified target size in MiB). + ''; + }; - extraCmdlineOptions = mkOption { - type = types.listOf types.str; - default = []; - description = '' - Extra command line options to pass to bitcoind. - Run bitcoind --help to list all available options. - ''; + extraCmdlineOptions = mkOption { + type = types.listOf types.str; + default = [ ]; + description = '' + Extra command line options to pass to bitcoind. + Run bitcoind --help to list all available options. + ''; + }; }; }; - }; in { options = { services.bitcoind = mkOption { type = types.attrsOf (types.submodule bitcoindOpts); - default = {}; + default = { }; description = "Specification of one or more bitcoind instances."; }; }; - config = mkIf (eachBitcoind != {}) { + config = mkIf (eachBitcoind != { }) { - assertions = flatten (mapAttrsToList (bitcoindName: cfg: [ - { - assertion = (cfg.prune != null) -> (builtins.elem cfg.prune [ "disable" "manual" 0 1 ] || (builtins.isInt cfg.prune && cfg.prune >= 550)); - message = '' - If set, services.bitcoind.${bitcoindName}.prune has to be "disable", "manual", 0 , 1 or >= 550. - ''; - } - { - assertion = (cfg.rpc.users != {}) -> (cfg.configFile == null); - message = '' - You cannot set both services.bitcoind.${bitcoindName}.rpc.users and services.bitcoind.${bitcoindName}.configFile - as they are exclusive. RPC user setting would have no effect if custom configFile would be used. - ''; - } - ]) eachBitcoind); + assertions = flatten ( + mapAttrsToList (bitcoindName: cfg: [ + { + assertion = + (cfg.prune != null) + -> ( + builtins.elem cfg.prune [ + "disable" + "manual" + 0 + 1 + ] + || (builtins.isInt cfg.prune && cfg.prune >= 550) + ); + message = '' + If set, services.bitcoind.${bitcoindName}.prune has to be "disable", "manual", 0 , 1 or >= 550. + ''; + } + { + assertion = (cfg.rpc.users != { }) -> (cfg.configFile == null); + message = '' + You cannot set both services.bitcoind.${bitcoindName}.rpc.users and services.bitcoind.${bitcoindName}.configFile + as they are exclusive. RPC user setting would have no effect if custom configFile would be used. + ''; + } + ]) eachBitcoind + ); - environment.systemPackages = flatten (mapAttrsToList (bitcoindName: cfg: [ - cfg.package - ]) eachBitcoind); + environment.systemPackages = flatten ( + mapAttrsToList (bitcoindName: cfg: [ + cfg.package + ]) eachBitcoind + ); - systemd.services = mapAttrs' (bitcoindName: cfg: ( - nameValuePair "bitcoind-${bitcoindName}" ( - let - configFile = pkgs.writeText "bitcoin.conf" '' - # If Testnet is enabled, we need to add [test] section - # otherwise, some options (e.g.: custom RPC port) will not work - ${optionalString cfg.testnet "[test]"} - # RPC users - ${concatMapStringsSep "\n" - (rpcUser: "rpcauth=${rpcUser.name}:${rpcUser.passwordHMAC}") - (attrValues cfg.rpc.users) - } - # Extra config options (from bitcoind nixos service) - ${cfg.extraConfig} - ''; - in { - description = "Bitcoin daemon"; - wants = [ "network-online.target" ]; - after = [ "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - User = cfg.user; - Group = cfg.group; - ExecStart = '' - ${cfg.package}/bin/bitcoind \ - ${if (cfg.configFile != null) then - "-conf=${cfg.configFile}" - else - "-conf=${configFile}" - } \ - -datadir=${cfg.dataDir} \ - -pid=${cfg.pidFile} \ - ${optionalString cfg.testnet "-testnet"}\ - ${optionalString (cfg.port != null) "-port=${toString cfg.port}"}\ - ${optionalString (cfg.prune != null) "-prune=${toString cfg.prune}"}\ - ${optionalString (cfg.dbCache != null) "-dbcache=${toString cfg.dbCache}"}\ - ${optionalString (cfg.rpc.port != null) "-rpcport=${toString cfg.rpc.port}"}\ - ${toString cfg.extraCmdlineOptions} + systemd.services = mapAttrs' ( + bitcoindName: cfg: + (nameValuePair "bitcoind-${bitcoindName}" ( + let + configFile = pkgs.writeText "bitcoin.conf" '' + # If Testnet is enabled, we need to add [test] section + # otherwise, some options (e.g.: custom RPC port) will not work + ${optionalString cfg.testnet "[test]"} + # RPC users + ${concatMapStringsSep "\n" (rpcUser: "rpcauth=${rpcUser.name}:${rpcUser.passwordHMAC}") ( + attrValues cfg.rpc.users + )} + # Extra config options (from bitcoind nixos service) + ${cfg.extraConfig} ''; - Restart = "on-failure"; + in + { + description = "Bitcoin daemon"; + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + User = cfg.user; + Group = cfg.group; + ExecStart = '' + ${cfg.package}/bin/bitcoind \ + ${if (cfg.configFile != null) then "-conf=${cfg.configFile}" else "-conf=${configFile}"} \ + -datadir=${cfg.dataDir} \ + -pid=${cfg.pidFile} \ + ${optionalString cfg.testnet "-testnet"}\ + ${optionalString (cfg.port != null) "-port=${toString cfg.port}"}\ + ${optionalString (cfg.prune != null) "-prune=${toString cfg.prune}"}\ + ${optionalString (cfg.dbCache != null) "-dbcache=${toString cfg.dbCache}"}\ + ${optionalString (cfg.rpc.port != null) "-rpcport=${toString cfg.rpc.port}"}\ + ${toString cfg.extraCmdlineOptions} + ''; + Restart = "on-failure"; - # Hardening measures - PrivateTmp = "true"; - ProtectSystem = "full"; - NoNewPrivileges = "true"; - PrivateDevices = "true"; - MemoryDenyWriteExecute = "true"; - }; - } - ))) eachBitcoind; + # Hardening measures + PrivateTmp = "true"; + ProtectSystem = "full"; + NoNewPrivileges = "true"; + PrivateDevices = "true"; + MemoryDenyWriteExecute = "true"; + }; + } + )) + ) eachBitcoind; - systemd.tmpfiles.rules = flatten (mapAttrsToList (bitcoindName: cfg: [ - "d '${cfg.dataDir}' 0770 '${cfg.user}' '${cfg.group}' - -" - ]) eachBitcoind); + systemd.tmpfiles.rules = flatten ( + mapAttrsToList (bitcoindName: cfg: [ + "d '${cfg.dataDir}' 0770 '${cfg.user}' '${cfg.group}' - -" + ]) eachBitcoind + ); - users.users = mapAttrs' (bitcoindName: cfg: ( - nameValuePair "bitcoind-${bitcoindName}" { - name = cfg.user; - group = cfg.group; - description = "Bitcoin daemon user"; - home = cfg.dataDir; - isSystemUser = true; - })) eachBitcoind; + users.users = mapAttrs' ( + bitcoindName: cfg: + (nameValuePair "bitcoind-${bitcoindName}" { + name = cfg.user; + group = cfg.group; + description = "Bitcoin daemon user"; + home = cfg.dataDir; + isSystemUser = true; + }) + ) eachBitcoind; - users.groups = mapAttrs' (bitcoindName: cfg: ( - nameValuePair "${cfg.group}" { } - )) eachBitcoind; + users.groups = mapAttrs' (bitcoindName: cfg: (nameValuePair "${cfg.group}" { })) eachBitcoind; }; diff --git a/nixos/modules/services/networking/bitlbee.nix b/nixos/modules/services/networking/bitlbee.nix index 3ebbab97b68e1c..27182bb5cca9df 100644 --- a/nixos/modules/services/networking/bitlbee.nix +++ b/nixos/modules/services/networking/bitlbee.nix @@ -1,16 +1,20 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.bitlbee; bitlbeeUid = config.ids.uids.bitlbee; bitlbeePkg = pkgs.bitlbee.override { - enableLibPurple = cfg.libpurple_plugins != []; + enableLibPurple = cfg.libpurple_plugins != [ ]; enablePam = cfg.authBackend == "pam"; }; - bitlbeeConfig = pkgs.writeText "bitlbee.conf" - '' + bitlbeeConfig = pkgs.writeText "bitlbee.conf" '' [settings] RunMode = Daemon ConfigDir = ${cfg.configDir} @@ -25,13 +29,11 @@ let [defaults] ${cfg.extraDefaults} - ''; + ''; - purple_plugin_path = - lib.concatMapStringsSep ":" - (plugin: "${plugin}/lib/pidgin/:${plugin}/lib/purple-2/") - cfg.libpurple_plugins - ; + purple_plugin_path = lib.concatMapStringsSep ":" ( + plugin: "${plugin}/lib/pidgin/:${plugin}/lib/purple-2/" + ) cfg.libpurple_plugins; in @@ -73,7 +75,10 @@ in authBackend = lib.mkOption { default = "storage"; - type = lib.types.enum [ "storage" "pam" ]; + type = lib.types.enum [ + "storage" + "pam" + ]; description = '' How users are authenticated storage -- save passwords internally @@ -83,7 +88,11 @@ in authMode = lib.mkOption { default = "Open"; - type = lib.types.enum [ "Open" "Closed" "Registered" ]; + type = lib.types.enum [ + "Open" + "Closed" + "Registered" + ]; description = '' The following authentication modes are available: Open -- Accept connections from anyone, use NickServ for user authentication. @@ -104,7 +113,7 @@ in plugins = lib.mkOption { type = lib.types.listOf lib.types.package; - default = []; + default = [ ]; example = lib.literalExpression "[ pkgs.bitlbee-facebook ]"; description = '' The list of bitlbee plugins to install. @@ -113,7 +122,7 @@ in libpurple_plugins = lib.mkOption { type = lib.types.listOf lib.types.package; - default = []; + default = [ ]; example = lib.literalExpression "[ pkgs.purple-matrix ]"; description = '' The list of libpurple plugins to install. @@ -160,7 +169,7 @@ in ###### implementation - config = lib.mkMerge [ + config = lib.mkMerge [ (lib.mkIf config.services.bitlbee.enable { systemd.services.bitlbee = { environment.PURPLE_PLUGIN_PATH = purple_plugin_path; @@ -180,7 +189,7 @@ in }) (lib.mkIf (config.services.bitlbee.authBackend == "pam") { - security.pam.services.bitlbee = {}; + security.pam.services.bitlbee = { }; }) ]; diff --git a/nixos/modules/services/networking/blockbook-frontend.nix b/nixos/modules/services/networking/blockbook-frontend.nix index 6200a098c34a02..bc9a3633fc69c4 100644 --- a/nixos/modules/services/networking/blockbook-frontend.nix +++ b/nixos/modules/services/networking/blockbook-frontend.nix @@ -1,187 +1,204 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let eachBlockbook = config.services.blockbook-frontend; - blockbookOpts = { config, lib, name, ...}: { + blockbookOpts = + { + config, + lib, + name, + ... + }: + { - options = { + options = { - enable = lib.mkEnableOption "blockbook-frontend application"; + enable = lib.mkEnableOption "blockbook-frontend application"; - package = lib.mkPackageOption pkgs "blockbook" { }; + package = lib.mkPackageOption pkgs "blockbook" { }; - user = lib.mkOption { - type = lib.types.str; - default = "blockbook-frontend-${name}"; - description = "The user as which to run blockbook-frontend-${name}."; - }; + user = lib.mkOption { + type = lib.types.str; + default = "blockbook-frontend-${name}"; + description = "The user as which to run blockbook-frontend-${name}."; + }; - group = lib.mkOption { - type = lib.types.str; - default = "${config.user}"; - description = "The group as which to run blockbook-frontend-${name}."; - }; + group = lib.mkOption { + type = lib.types.str; + default = "${config.user}"; + description = "The group as which to run blockbook-frontend-${name}."; + }; - certFile = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; - example = "/etc/secrets/blockbook-frontend-${name}/certFile"; - description = '' - To enable SSL, specify path to the name of certificate files without extension. - Expecting {file}`certFile.crt` and {file}`certFile.key`. - ''; - }; + certFile = lib.mkOption { + type = lib.types.nullOr lib.types.path; + default = null; + example = "/etc/secrets/blockbook-frontend-${name}/certFile"; + description = '' + To enable SSL, specify path to the name of certificate files without extension. + Expecting {file}`certFile.crt` and {file}`certFile.key`. + ''; + }; - configFile = lib.mkOption { - type = with lib.types; nullOr path; - default = null; - example = "${config.dataDir}/config.json"; - description = "Location of the blockbook configuration file."; - }; + configFile = lib.mkOption { + type = with lib.types; nullOr path; + default = null; + example = "${config.dataDir}/config.json"; + description = "Location of the blockbook configuration file."; + }; - coinName = lib.mkOption { - type = lib.types.str; - default = "Bitcoin"; - description = '' - See - for current of coins supported in master (Note: may differ from release). - ''; - }; + coinName = lib.mkOption { + type = lib.types.str; + default = "Bitcoin"; + description = '' + See + for current of coins supported in master (Note: may differ from release). + ''; + }; - cssDir = lib.mkOption { - type = lib.types.path; - default = "${config.package}/share/css/"; - defaultText = lib.literalExpression ''"''${package}/share/css/"''; - example = lib.literalExpression ''"''${dataDir}/static/css/"''; - description = '' - Location of the dir with {file}`main.css` CSS file. - By default, the one shipped with the package is used. - ''; - }; + cssDir = lib.mkOption { + type = lib.types.path; + default = "${config.package}/share/css/"; + defaultText = lib.literalExpression ''"''${package}/share/css/"''; + example = lib.literalExpression ''"''${dataDir}/static/css/"''; + description = '' + Location of the dir with {file}`main.css` CSS file. + By default, the one shipped with the package is used. + ''; + }; - dataDir = lib.mkOption { - type = lib.types.path; - default = "/var/lib/blockbook-frontend-${name}"; - description = "Location of blockbook-frontend-${name} data directory."; - }; + dataDir = lib.mkOption { + type = lib.types.path; + default = "/var/lib/blockbook-frontend-${name}"; + description = "Location of blockbook-frontend-${name} data directory."; + }; - debug = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Debug mode, return more verbose errors, reload templates on each request."; - }; + debug = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Debug mode, return more verbose errors, reload templates on each request."; + }; - internal = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = ":9030"; - description = "Internal http server binding `[address]:port`."; - }; + internal = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = ":9030"; + description = "Internal http server binding `[address]:port`."; + }; - messageQueueBinding = lib.mkOption { - type = lib.types.str; - default = "tcp://127.0.0.1:38330"; - description = "Message Queue Binding `address:port`."; - }; + messageQueueBinding = lib.mkOption { + type = lib.types.str; + default = "tcp://127.0.0.1:38330"; + description = "Message Queue Binding `address:port`."; + }; - public = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = ":9130"; - description = "Public http server binding `[address]:port`."; - }; + public = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = ":9130"; + description = "Public http server binding `[address]:port`."; + }; - rpc = { - url = lib.mkOption { - type = lib.types.str; - default = "http://127.0.0.1"; - description = "URL for JSON-RPC connections."; + rpc = { + url = lib.mkOption { + type = lib.types.str; + default = "http://127.0.0.1"; + description = "URL for JSON-RPC connections."; + }; + + port = lib.mkOption { + type = lib.types.port; + default = 8030; + description = "Port for JSON-RPC connections."; + }; + + user = lib.mkOption { + type = lib.types.str; + default = "rpc"; + description = "Username for JSON-RPC connections."; + }; + + password = lib.mkOption { + type = lib.types.str; + default = "rpc"; + description = '' + RPC password for JSON-RPC connections. + Warning: this is stored in cleartext in the Nix store!!! + Use `configFile` or `passwordFile` if needed. + ''; + }; + + passwordFile = lib.mkOption { + type = lib.types.nullOr lib.types.path; + default = null; + description = '' + File containing password of the RPC user. + Note: This options is ignored when `configFile` is used. + ''; + }; }; - port = lib.mkOption { - type = lib.types.port; - default = 8030; - description = "Port for JSON-RPC connections."; + sync = lib.mkOption { + type = lib.types.bool; + default = true; + description = "Synchronizes until tip, if together with zeromq, keeps index synchronized."; }; - user = lib.mkOption { - type = lib.types.str; - default = "rpc"; - description = "Username for JSON-RPC connections."; + templateDir = lib.mkOption { + type = lib.types.path; + default = "${config.package}/share/templates/"; + defaultText = lib.literalExpression ''"''${package}/share/templates/"''; + example = lib.literalExpression ''"''${dataDir}/templates/static/"''; + description = "Location of the HTML templates. By default, ones shipped with the package are used."; }; - password = lib.mkOption { - type = lib.types.str; - default = "rpc"; + extraConfig = lib.mkOption { + type = lib.types.attrs; + default = { }; + example = lib.literalExpression '' + { + "alternative_estimate_fee" = "whatthefee-disabled"; + "alternative_estimate_fee_params" = "{\"url\": \"https://whatthefee.io/data.json\", \"periodSeconds\": 60}"; + "fiat_rates" = "coingecko"; + "fiat_rates_params" = "{\"url\": \"https://api.coingecko.com/api/v3\", \"coin\": \"bitcoin\", \"periodSeconds\": 60}"; + "coin_shortcut" = "BTC"; + "coin_label" = "Bitcoin"; + "parse" = true; + "subversion" = ""; + "address_format" = ""; + "xpub_magic" = 76067358; + "xpub_magic_segwit_p2sh" = 77429938; + "xpub_magic_segwit_native" = 78792518; + "mempool_workers" = 8; + "mempool_sub_workers" = 2; + "block_addresses_to_keep" = 300; + }''; description = '' - RPC password for JSON-RPC connections. - Warning: this is stored in cleartext in the Nix store!!! - Use `configFile` or `passwordFile` if needed. + Additional configurations to be appended to {file}`coin.conf`. + Overrides any already defined configuration options. + See + for current configuration options supported in master (Note: may differ from release). ''; }; - passwordFile = lib.mkOption { - type = lib.types.nullOr lib.types.path; - default = null; + extraCmdLineOptions = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + example = [ + "-workers=1" + "-dbcache=0" + "-logtosderr" + ]; description = '' - File containing password of the RPC user. - Note: This options is ignored when `configFile` is used. + Extra command line options to pass to Blockbook. + Run blockbook --help to list all available options. ''; }; }; - - sync = lib.mkOption { - type = lib.types.bool; - default = true; - description = "Synchronizes until tip, if together with zeromq, keeps index synchronized."; - }; - - templateDir = lib.mkOption { - type = lib.types.path; - default = "${config.package}/share/templates/"; - defaultText = lib.literalExpression ''"''${package}/share/templates/"''; - example = lib.literalExpression ''"''${dataDir}/templates/static/"''; - description = "Location of the HTML templates. By default, ones shipped with the package are used."; - }; - - extraConfig = lib.mkOption { - type = lib.types.attrs; - default = {}; - example = lib.literalExpression '' { - "alternative_estimate_fee" = "whatthefee-disabled"; - "alternative_estimate_fee_params" = "{\"url\": \"https://whatthefee.io/data.json\", \"periodSeconds\": 60}"; - "fiat_rates" = "coingecko"; - "fiat_rates_params" = "{\"url\": \"https://api.coingecko.com/api/v3\", \"coin\": \"bitcoin\", \"periodSeconds\": 60}"; - "coin_shortcut" = "BTC"; - "coin_label" = "Bitcoin"; - "parse" = true; - "subversion" = ""; - "address_format" = ""; - "xpub_magic" = 76067358; - "xpub_magic_segwit_p2sh" = 77429938; - "xpub_magic_segwit_native" = 78792518; - "mempool_workers" = 8; - "mempool_sub_workers" = 2; - "block_addresses_to_keep" = 300; - }''; - description = '' - Additional configurations to be appended to {file}`coin.conf`. - Overrides any already defined configuration options. - See - for current configuration options supported in master (Note: may differ from release). - ''; - }; - - extraCmdLineOptions = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - example = [ "-workers=1" "-dbcache=0" "-logtosderr" ]; - description = '' - Extra command line options to pass to Blockbook. - Run blockbook --help to list all available options. - ''; - }; }; - }; in { # interface @@ -189,28 +206,37 @@ in options = { services.blockbook-frontend = lib.mkOption { type = lib.types.attrsOf (lib.types.submodule blockbookOpts); - default = {}; + default = { }; description = "Specification of one or more blockbook-frontend instances."; }; }; # implementation - config = lib.mkIf (eachBlockbook != {}) { + config = lib.mkIf (eachBlockbook != { }) { - systemd.services = lib.mapAttrs' (blockbookName: cfg: ( - lib.nameValuePair "blockbook-frontend-${blockbookName}" ( + systemd.services = lib.mapAttrs' ( + blockbookName: cfg: + (lib.nameValuePair "blockbook-frontend-${blockbookName}" ( let - configFile = if cfg.configFile != null then cfg.configFile else - pkgs.writeText "config.conf" (builtins.toJSON ( { - coin_name = "${cfg.coinName}"; - rpc_user = "${cfg.rpc.user}"; - rpc_pass = "${cfg.rpc.password}"; - rpc_url = "${cfg.rpc.url}:${toString cfg.rpc.port}"; - message_queue_binding = "${cfg.messageQueueBinding}"; - } // cfg.extraConfig) - ); - in { + configFile = + if cfg.configFile != null then + cfg.configFile + else + pkgs.writeText "config.conf" ( + builtins.toJSON ( + { + coin_name = "${cfg.coinName}"; + rpc_user = "${cfg.rpc.user}"; + rpc_pass = "${cfg.rpc.password}"; + rpc_url = "${cfg.rpc.url}:${toString cfg.rpc.port}"; + message_queue_binding = "${cfg.messageQueueBinding}"; + } + // cfg.extraConfig + ) + ); + in + { description = "blockbook-frontend-${blockbookName} daemon"; after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; @@ -227,42 +253,49 @@ in User = cfg.user; Group = cfg.group; ExecStart = '' - ${cfg.package}/bin/blockbook \ - ${if (cfg.rpc.passwordFile != null && cfg.configFile == null) then - "-blockchaincfg=${cfg.dataDir}/${blockbookName}-config.json" - else - "-blockchaincfg=${configFile}" - } \ - -datadir=${cfg.dataDir} \ - ${lib.optionalString (cfg.sync != false) "-sync"} \ - ${lib.optionalString (cfg.certFile != null) "-certfile=${toString cfg.certFile}"} \ - ${lib.optionalString (cfg.debug != false) "-debug"} \ - ${lib.optionalString (cfg.internal != null) "-internal=${toString cfg.internal}"} \ - ${lib.optionalString (cfg.public != null) "-public=${toString cfg.public}"} \ - ${toString cfg.extraCmdLineOptions} + ${cfg.package}/bin/blockbook \ + ${ + if (cfg.rpc.passwordFile != null && cfg.configFile == null) then + "-blockchaincfg=${cfg.dataDir}/${blockbookName}-config.json" + else + "-blockchaincfg=${configFile}" + } \ + -datadir=${cfg.dataDir} \ + ${lib.optionalString (cfg.sync != false) "-sync"} \ + ${lib.optionalString (cfg.certFile != null) "-certfile=${toString cfg.certFile}"} \ + ${lib.optionalString (cfg.debug != false) "-debug"} \ + ${lib.optionalString (cfg.internal != null) "-internal=${toString cfg.internal}"} \ + ${lib.optionalString (cfg.public != null) "-public=${toString cfg.public}"} \ + ${toString cfg.extraCmdLineOptions} ''; Restart = "on-failure"; WorkingDirectory = cfg.dataDir; LimitNOFILE = 65536; }; } - ) )) eachBlockbook; - - systemd.tmpfiles.rules = lib.flatten (lib.mapAttrsToList (blockbookName: cfg: [ - "d ${cfg.dataDir} 0750 ${cfg.user} ${cfg.group} - -" - "d ${cfg.dataDir}/static 0750 ${cfg.user} ${cfg.group} - -" - ]) eachBlockbook); - - users.users = lib.mapAttrs' (blockbookName: cfg: ( - lib.nameValuePair "blockbook-frontend-${blockbookName}" { - name = cfg.user; - group = cfg.group; - home = cfg.dataDir; - isSystemUser = true; - })) eachBlockbook; - - users.groups = lib.mapAttrs' (instanceName: cfg: ( - lib.nameValuePair "${cfg.group}" { })) eachBlockbook; + )) + ) eachBlockbook; + + systemd.tmpfiles.rules = lib.flatten ( + lib.mapAttrsToList (blockbookName: cfg: [ + "d ${cfg.dataDir} 0750 ${cfg.user} ${cfg.group} - -" + "d ${cfg.dataDir}/static 0750 ${cfg.user} ${cfg.group} - -" + ]) eachBlockbook + ); + + users.users = lib.mapAttrs' ( + blockbookName: cfg: + (lib.nameValuePair "blockbook-frontend-${blockbookName}" { + name = cfg.user; + group = cfg.group; + home = cfg.dataDir; + isSystemUser = true; + }) + ) eachBlockbook; + + users.groups = lib.mapAttrs' ( + instanceName: cfg: (lib.nameValuePair "${cfg.group}" { }) + ) eachBlockbook; }; meta.maintainers = with lib.maintainers; [ _1000101 ]; diff --git a/nixos/modules/services/networking/blocky.nix b/nixos/modules/services/networking/blocky.nix index 1260d9da7ac299..1920a5c11c5690 100644 --- a/nixos/modules/services/networking/blocky.nix +++ b/nixos/modules/services/networking/blocky.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.blocky; diff --git a/nixos/modules/services/networking/centrifugo.nix b/nixos/modules/services/networking/centrifugo.nix index 65df02513d6e89..7b9a05069498a7 100644 --- a/nixos/modules/services/networking/centrifugo.nix +++ b/nixos/modules/services/networking/centrifugo.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.centrifugo; diff --git a/nixos/modules/services/networking/cgit.nix b/nixos/modules/services/networking/cgit.nix index 208979364684d7..126070aa26cc48 100644 --- a/nixos/modules/services/networking/cgit.nix +++ b/nixos/modules/services/networking/cgit.nix @@ -1,9 +1,25 @@ -{ config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: let cfgs = config.services.cgit; - settingType = with lib.types; oneOf [ bool int str ]; - repeatedSettingType = with lib.types; oneOf [ settingType (listOf settingType) ]; + settingType = + with lib.types; + oneOf [ + bool + int + str + ]; + repeatedSettingType = + with lib.types; + oneOf [ + settingType + (listOf settingType) + ]; genAttrs' = names: f: lib.listToAttrs (map f names); @@ -11,227 +27,262 @@ let let # taken from https://github.com/python/cpython/blob/05cb728d68a278d11466f9a6c8258d914135c96c/Lib/re.py#L251-L266 special = [ - "(" ")" "[" "]" "{" "}" "?" "*" "+" "-" "|" "^" "$" "\\" "." "&" "~" - "#" " " "\t" "\n" "\r" + "(" + ")" + "[" + "]" + "{" + "}" + "?" + "*" + "+" + "-" + "|" + "^" + "$" + "\\" + "." + "&" + "~" + "#" + " " + "\t" + "\n" + "\r" " " # \v / 0x0B " " # \f / 0x0C ]; in - lib.replaceStrings special (map (c: "\\${c}") special); + lib.replaceStrings special (map (c: "\\${c}") special); stripLocation = cfg: lib.removeSuffix "/" cfg.nginx.location; regexLocation = cfg: regexEscape (stripLocation cfg); mkFastcgiPass = name: cfg: '' - ${if cfg.nginx.location == "/" then '' - fastcgi_param PATH_INFO $uri; - '' else '' - fastcgi_split_path_info ^(${regexLocation cfg})(/.+)$; - fastcgi_param PATH_INFO $fastcgi_path_info; - '' + ${ + if cfg.nginx.location == "/" then + '' + fastcgi_param PATH_INFO $uri; + '' + else + '' + fastcgi_split_path_info ^(${regexLocation cfg})(/.+)$; + fastcgi_param PATH_INFO $fastcgi_path_info; + '' }fastcgi_pass unix:${config.services.fcgiwrap.instances."cgit-${name}".socket.address}; ''; - cgitrcLine = name: value: "${name}=${ - if value == true then - "1" - else if value == false then - "0" - else - toString value - }"; + cgitrcLine = + name: value: + "${name}=${ + if value == true then + "1" + else if value == false then + "0" + else + toString value + }"; # list value as multiple lines (for "readme" for example) - cgitrcEntry = name: value: - if lib.isList value then - map (cgitrcLine name) value - else - [ (cgitrcLine name value) ]; - - mkCgitrc = cfg: pkgs.writeText "cgitrc" '' - # global settings - ${lib.concatStringsSep "\n" ( - lib.flatten (lib.mapAttrsToList - cgitrcEntry - ({ virtual-root = cfg.nginx.location; } // cfg.settings) + cgitrcEntry = + name: value: if lib.isList value then map (cgitrcLine name) value else [ (cgitrcLine name value) ]; + + mkCgitrc = + cfg: + pkgs.writeText "cgitrc" '' + # global settings + ${lib.concatStringsSep "\n" ( + lib.flatten ( + lib.mapAttrsToList cgitrcEntry ({ virtual-root = cfg.nginx.location; } // cfg.settings) ) - ) - } - ${lib.optionalString (cfg.scanPath != null) (cgitrcLine "scan-path" cfg.scanPath)} - - # repository settings - ${lib.concatStrings ( - lib.mapAttrsToList - (url: settings: '' - ${cgitrcLine "repo.url" url} - ${lib.concatStringsSep "\n" ( - lib.mapAttrsToList (name: cgitrcLine "repo.${name}") settings - ) - } - '') - cfg.repos - ) - } + )} + ${lib.optionalString (cfg.scanPath != null) (cgitrcLine "scan-path" cfg.scanPath)} - # extra config - ${cfg.extraConfig} - ''; + # repository settings + ${lib.concatStrings ( + lib.mapAttrsToList (url: settings: '' + ${cgitrcLine "repo.url" url} + ${lib.concatStringsSep "\n" (lib.mapAttrsToList (name: cgitrcLine "repo.${name}") settings)} + '') cfg.repos + )} + + # extra config + ${cfg.extraConfig} + ''; fcgiwrapUnitName = name: "fcgiwrap-cgit-${name}"; fcgiwrapRuntimeDir = name: "/run/${fcgiwrapUnitName name}"; - gitProjectRoot = name: cfg: if cfg.scanPath != null - then cfg.scanPath - else "${fcgiwrapRuntimeDir name}/repos"; + gitProjectRoot = + name: cfg: if cfg.scanPath != null then cfg.scanPath else "${fcgiwrapRuntimeDir name}/repos"; in { options = { services.cgit = lib.mkOption { description = "Configure cgit instances."; - default = {}; - type = lib.types.attrsOf (lib.types.submodule ({ config, ... }: { - options = { - enable = lib.mkEnableOption "cgit"; - - package = lib.mkPackageOption pkgs "cgit" {}; - - nginx.virtualHost = lib.mkOption { - description = "VirtualHost to serve cgit on, defaults to the attribute name."; - type = lib.types.str; - default = config._module.args.name; - example = "git.example.com"; - }; + default = { }; + type = lib.types.attrsOf ( + lib.types.submodule ( + { config, ... }: + { + options = { + enable = lib.mkEnableOption "cgit"; - nginx.location = lib.mkOption { - description = "Location to serve cgit under."; - type = lib.types.str; - default = "/"; - example = "/git/"; - }; + package = lib.mkPackageOption pkgs "cgit" { }; - repos = lib.mkOption { - description = "cgit repository settings, see cgitrc(5)"; - type = with lib.types; attrsOf (attrsOf settingType); - default = {}; - example = { - blah = { - path = "/var/lib/git/example"; - desc = "An example repository"; + nginx.virtualHost = lib.mkOption { + description = "VirtualHost to serve cgit on, defaults to the attribute name."; + type = lib.types.str; + default = config._module.args.name; + example = "git.example.com"; }; - }; - }; - scanPath = lib.mkOption { - description = "A path which will be scanned for repositories."; - type = lib.types.nullOr lib.types.path; - default = null; - example = "/var/lib/git"; - }; + nginx.location = lib.mkOption { + description = "Location to serve cgit under."; + type = lib.types.str; + default = "/"; + example = "/git/"; + }; - settings = lib.mkOption { - description = "cgit configuration, see cgitrc(5)"; - type = lib.types.attrsOf repeatedSettingType; - default = {}; - example = lib.literalExpression '' - { - enable-follow-links = true; - source-filter = "''${pkgs.cgit}/lib/cgit/filters/syntax-highlighting.py"; - } - ''; - }; + repos = lib.mkOption { + description = "cgit repository settings, see cgitrc(5)"; + type = with lib.types; attrsOf (attrsOf settingType); + default = { }; + example = { + blah = { + path = "/var/lib/git/example"; + desc = "An example repository"; + }; + }; + }; - extraConfig = lib.mkOption { - description = "These lines go to the end of cgitrc verbatim."; - type = lib.types.lines; - default = ""; - }; + scanPath = lib.mkOption { + description = "A path which will be scanned for repositories."; + type = lib.types.nullOr lib.types.path; + default = null; + example = "/var/lib/git"; + }; - user = lib.mkOption { - description = "User to run the cgit service as."; - type = lib.types.str; - default = "cgit"; - }; + settings = lib.mkOption { + description = "cgit configuration, see cgitrc(5)"; + type = lib.types.attrsOf repeatedSettingType; + default = { }; + example = lib.literalExpression '' + { + enable-follow-links = true; + source-filter = "''${pkgs.cgit}/lib/cgit/filters/syntax-highlighting.py"; + } + ''; + }; - group = lib.mkOption { - description = "Group to run the cgit service as."; - type = lib.types.str; - default = "cgit"; - }; - }; - })); + extraConfig = lib.mkOption { + description = "These lines go to the end of cgitrc verbatim."; + type = lib.types.lines; + default = ""; + }; + + user = lib.mkOption { + description = "User to run the cgit service as."; + type = lib.types.str; + default = "cgit"; + }; + + group = lib.mkOption { + description = "Group to run the cgit service as."; + type = lib.types.str; + default = "cgit"; + }; + }; + } + ) + ); }; }; config = lib.mkIf (lib.any (cfg: cfg.enable) (lib.attrValues cfgs)) { assertions = lib.mapAttrsToList (vhost: cfg: { - assertion = !cfg.enable || (cfg.scanPath == null) != (cfg.repos == {}); + assertion = !cfg.enable || (cfg.scanPath == null) != (cfg.repos == { }); message = "Exactly one of services.cgit.${vhost}.scanPath or services.cgit.${vhost}.repos must be set."; }) cfgs; - users = lib.mkMerge (lib.flip lib.mapAttrsToList cfgs (_: cfg: { - users.${cfg.user} = { - isSystemUser = true; - inherit (cfg) group; - }; - groups.${cfg.group} = { }; - })); + users = lib.mkMerge ( + lib.flip lib.mapAttrsToList cfgs ( + _: cfg: { + users.${cfg.user} = { + isSystemUser = true; + inherit (cfg) group; + }; + groups.${cfg.group} = { }; + } + ) + ); - services.fcgiwrap.instances = lib.flip lib.mapAttrs' cfgs (name: cfg: + services.fcgiwrap.instances = lib.flip lib.mapAttrs' cfgs ( + name: cfg: lib.nameValuePair "cgit-${name}" { process = { inherit (cfg) user group; }; socket = { inherit (config.services.nginx) user group; }; } ); - systemd.services = lib.flip lib.mapAttrs' cfgs (name: cfg: - lib.nameValuePair (fcgiwrapUnitName name) - (lib.mkIf (cfg.repos != { }) { - serviceConfig.RuntimeDirectory = fcgiwrapUnitName name; - preStart = '' - GIT_PROJECT_ROOT=${lib.escapeShellArg (gitProjectRoot name cfg)} - mkdir -p "$GIT_PROJECT_ROOT" - cd "$GIT_PROJECT_ROOT" - ${lib.concatLines (lib.flip lib.mapAttrsToList cfg.repos (name: repo: '' - ln -s ${lib.escapeShellArg repo.path} ${lib.escapeShellArg name} - ''))} - ''; - } - )); + systemd.services = lib.flip lib.mapAttrs' cfgs ( + name: cfg: + lib.nameValuePair (fcgiwrapUnitName name) ( + lib.mkIf (cfg.repos != { }) { + serviceConfig.RuntimeDirectory = fcgiwrapUnitName name; + preStart = '' + GIT_PROJECT_ROOT=${lib.escapeShellArg (gitProjectRoot name cfg)} + mkdir -p "$GIT_PROJECT_ROOT" + cd "$GIT_PROJECT_ROOT" + ${lib.concatLines ( + lib.flip lib.mapAttrsToList cfg.repos ( + name: repo: '' + ln -s ${lib.escapeShellArg repo.path} ${lib.escapeShellArg name} + '' + ) + )} + ''; + } + ) + ); services.nginx.enable = true; - services.nginx.virtualHosts = lib.mkMerge (lib.mapAttrsToList (name: cfg: { - ${cfg.nginx.virtualHost} = { - locations = ( - genAttrs' - [ "cgit.css" "cgit.png" "favicon.ico" "robots.txt" ] - (fileName: lib.nameValuePair "= ${stripLocation cfg}/${fileName}" { - extraConfig = '' - alias ${cfg.package}/cgit/${fileName}; - ''; - }) - ) // { - "~ ${regexLocation cfg}/.+/(info/refs|git-upload-pack)" = { - fastcgiParams = rec { - SCRIPT_FILENAME = "${pkgs.git}/libexec/git-core/git-http-backend"; - GIT_HTTP_EXPORT_ALL = "1"; - GIT_PROJECT_ROOT = gitProjectRoot name cfg; - HOME = GIT_PROJECT_ROOT; - }; - extraConfig = mkFastcgiPass name cfg; - }; - "${stripLocation cfg}/" = { - fastcgiParams = { - SCRIPT_FILENAME = "${cfg.package}/cgit/cgit.cgi"; - QUERY_STRING = "$args"; - HTTP_HOST = "$server_name"; - CGIT_CONFIG = mkCgitrc cfg; + services.nginx.virtualHosts = lib.mkMerge ( + lib.mapAttrsToList (name: cfg: { + ${cfg.nginx.virtualHost} = { + locations = + (genAttrs' [ "cgit.css" "cgit.png" "favicon.ico" "robots.txt" ] ( + fileName: + lib.nameValuePair "= ${stripLocation cfg}/${fileName}" { + extraConfig = '' + alias ${cfg.package}/cgit/${fileName}; + ''; + } + )) + // { + "~ ${regexLocation cfg}/.+/(info/refs|git-upload-pack)" = { + fastcgiParams = rec { + SCRIPT_FILENAME = "${pkgs.git}/libexec/git-core/git-http-backend"; + GIT_HTTP_EXPORT_ALL = "1"; + GIT_PROJECT_ROOT = gitProjectRoot name cfg; + HOME = GIT_PROJECT_ROOT; + }; + extraConfig = mkFastcgiPass name cfg; + }; + "${stripLocation cfg}/" = { + fastcgiParams = { + SCRIPT_FILENAME = "${cfg.package}/cgit/cgit.cgi"; + QUERY_STRING = "$args"; + HTTP_HOST = "$server_name"; + CGIT_CONFIG = mkCgitrc cfg; + }; + extraConfig = mkFastcgiPass name cfg; + }; }; - extraConfig = mkFastcgiPass name cfg; - }; }; - }; - }) cfgs); + }) cfgs + ); }; } diff --git a/nixos/modules/services/networking/charybdis.nix b/nixos/modules/services/networking/charybdis.nix index 6aaad823702cac..9f07abfdeadb94 100644 --- a/nixos/modules/services/networking/charybdis.nix +++ b/nixos/modules/services/networking/charybdis.nix @@ -1,7 +1,18 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkIf mkOption singleton types; + inherit (lib) + mkEnableOption + mkIf + mkOption + singleton + types + ; inherit (pkgs) coreutils charybdis; cfg = config.services.charybdis; @@ -66,49 +77,50 @@ in }; - ###### implementation - config = mkIf cfg.enable (lib.mkMerge [ - { - users.users.${cfg.user} = { - description = "Charybdis IRC daemon user"; - uid = config.ids.uids.ircd; - group = cfg.group; - }; - - users.groups.${cfg.group} = { - gid = config.ids.gids.ircd; - }; + config = mkIf cfg.enable ( + lib.mkMerge [ + { + users.users.${cfg.user} = { + description = "Charybdis IRC daemon user"; + uid = config.ids.uids.ircd; + group = cfg.group; + }; - systemd.tmpfiles.settings."10-charybdis".${cfg.statedir}.d = { - inherit (cfg) user group; - }; + users.groups.${cfg.group} = { + gid = config.ids.gids.ircd; + }; - environment.etc."charybdis/ircd.conf".source = configFile; - - systemd.services.charybdis = { - description = "Charybdis IRC daemon"; - wantedBy = [ "multi-user.target" ]; - reloadIfChanged = true; - restartTriggers = [ - configFile - ]; - environment = { - BANDB_DBPATH = "${cfg.statedir}/ban.db"; + systemd.tmpfiles.settings."10-charybdis".${cfg.statedir}.d = { + inherit (cfg) user group; }; - serviceConfig = { - ExecStart = "${charybdis}/bin/charybdis -foreground -logfile /dev/stdout -configfile /etc/charybdis/ircd.conf"; - ExecReload = "${coreutils}/bin/kill -HUP $MAINPID"; - Group = cfg.group; - User = cfg.user; + + environment.etc."charybdis/ircd.conf".source = configFile; + + systemd.services.charybdis = { + description = "Charybdis IRC daemon"; + wantedBy = [ "multi-user.target" ]; + reloadIfChanged = true; + restartTriggers = [ + configFile + ]; + environment = { + BANDB_DBPATH = "${cfg.statedir}/ban.db"; + }; + serviceConfig = { + ExecStart = "${charybdis}/bin/charybdis -foreground -logfile /dev/stdout -configfile /etc/charybdis/ircd.conf"; + ExecReload = "${coreutils}/bin/kill -HUP $MAINPID"; + Group = cfg.group; + User = cfg.user; + }; }; - }; - } + } - (mkIf (cfg.motd != null) { - environment.etc."charybdis/ircd.motd".text = cfg.motd; - }) - ]); + (mkIf (cfg.motd != null) { + environment.etc."charybdis/ircd.motd".text = cfg.motd; + }) + ] + ); } diff --git a/nixos/modules/services/networking/chisel-server.nix b/nixos/modules/services/networking/chisel-server.nix index 2b585c22f304dd..b2f07c8d168823 100644 --- a/nixos/modules/services/networking/chisel-server.nix +++ b/nixos/modules/services/networking/chisel-server.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.chisel-server; -in { +in +{ options = { services.chisel-server = { enable = lib.mkEnableOption "Chisel Tunnel Server"; @@ -22,7 +28,7 @@ in { type = with lib.types; nullOr path; default = null; }; - keepalive = lib.mkOption { + keepalive = lib.mkOption { description = "Keepalive interval, falls back to 25s"; type = with lib.types; nullOr str; default = null; @@ -53,15 +59,17 @@ in { wantedBy = [ "network-online.target" ]; serviceConfig = { - ExecStart = "${pkgs.chisel}/bin/chisel server " + lib.concatStringsSep " " ( - lib.optional (cfg.host != null) "--host ${cfg.host}" - ++ lib.optional (cfg.port != null) "--port ${builtins.toString cfg.port}" - ++ lib.optional (cfg.authfile != null) "--authfile ${cfg.authfile}" - ++ lib.optional (cfg.keepalive != null) "--keepalive ${cfg.keepalive}" - ++ lib.optional (cfg.backend != null) "--backend ${cfg.backend}" - ++ lib.optional cfg.socks5 "--socks5" - ++ lib.optional cfg.reverse "--reverse" - ); + ExecStart = + "${pkgs.chisel}/bin/chisel server " + + lib.concatStringsSep " " ( + lib.optional (cfg.host != null) "--host ${cfg.host}" + ++ lib.optional (cfg.port != null) "--port ${builtins.toString cfg.port}" + ++ lib.optional (cfg.authfile != null) "--authfile ${cfg.authfile}" + ++ lib.optional (cfg.keepalive != null) "--keepalive ${cfg.keepalive}" + ++ lib.optional (cfg.backend != null) "--backend ${cfg.backend}" + ++ lib.optional cfg.socks5 "--socks5" + ++ lib.optional cfg.reverse "--reverse" + ); # Security Hardening # Refer to systemd.exec(5) for option descriptions. @@ -82,7 +90,11 @@ in { ProtectProc = "invisible"; ProtectKernelModules = true; ProtectKernelTunables = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; RestrictNamespaces = true; RestrictRealtime = true; SystemCallArchitectures = "native"; diff --git a/nixos/modules/services/networking/cjdns.nix b/nixos/modules/services/networking/cjdns.nix index 6aaaf629506894..1b9f53c9b28a59 100644 --- a/nixos/modules/services/networking/cjdns.nix +++ b/nixos/modules/services/networking/cjdns.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let pkg = pkgs.cjdns; @@ -6,73 +11,91 @@ let cfg = config.services.cjdns; connectToSubmodule = - { ... }: - { options = - { password = lib.mkOption { - type = lib.types.str; - description = "Authorized password to the opposite end of the tunnel."; - }; - login = lib.mkOption { - default = ""; - type = lib.types.str; - description = "(optional) name your peer has for you"; - }; - peerName = lib.mkOption { - default = ""; - type = lib.types.str; - description = "(optional) human-readable name for peer"; - }; - publicKey = lib.mkOption { - type = lib.types.str; - description = "Public key at the opposite end of the tunnel."; - }; - hostname = lib.mkOption { - default = ""; - example = "foobar.hype"; - type = lib.types.str; - description = "Optional hostname to add to /etc/hosts; prevents reverse lookup failures."; + { ... }: + { + options = { + password = lib.mkOption { + type = lib.types.str; + description = "Authorized password to the opposite end of the tunnel."; + }; + login = lib.mkOption { + default = ""; + type = lib.types.str; + description = "(optional) name your peer has for you"; + }; + peerName = lib.mkOption { + default = ""; + type = lib.types.str; + description = "(optional) human-readable name for peer"; + }; + publicKey = lib.mkOption { + type = lib.types.str; + description = "Public key at the opposite end of the tunnel."; + }; + hostname = lib.mkOption { + default = ""; + example = "foobar.hype"; + type = lib.types.str; + description = "Optional hostname to add to /etc/hosts; prevents reverse lookup failures."; + }; }; }; - }; # Additional /etc/hosts entries for peers with an associated hostname - cjdnsExtraHosts = pkgs.runCommand "cjdns-hosts" {} '' + cjdnsExtraHosts = pkgs.runCommand "cjdns-hosts" { } '' exec >$out - ${lib.concatStringsSep "\n" (lib.mapAttrsToList (k: v: - lib.optionalString (v.hostname != "") - "echo $(${pkgs.cjdns}/bin/publictoip6 ${v.publicKey}) ${v.hostname}") - (cfg.ETHInterface.connectTo // cfg.UDPInterface.connectTo))} + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList ( + k: v: + lib.optionalString ( + v.hostname != "" + ) "echo $(${pkgs.cjdns}/bin/publictoip6 ${v.publicKey}) ${v.hostname}" + ) (cfg.ETHInterface.connectTo // cfg.UDPInterface.connectTo) + )} ''; - parseModules = x: - x // { connectTo = lib.mapAttrs (name: value: { inherit (value) password publicKey; }) x.connectTo; }; - - cjdrouteConf = builtins.toJSON ( lib.recursiveUpdate { - admin = { - bind = cfg.admin.bind; - password = "@CJDNS_ADMIN_PASSWORD@"; - }; - authorizedPasswords = map (p: { password = p; }) cfg.authorizedPasswords; - interfaces = { - ETHInterface = if (cfg.ETHInterface.bind != "") then [ (parseModules cfg.ETHInterface) ] else [ ]; - UDPInterface = if (cfg.UDPInterface.bind != "") then [ (parseModules cfg.UDPInterface) ] else [ ]; + parseModules = + x: + x + // { + connectTo = lib.mapAttrs (name: value: { inherit (value) password publicKey; }) x.connectTo; }; - privateKey = "@CJDNS_PRIVATE_KEY@"; + cjdrouteConf = builtins.toJSON ( + lib.recursiveUpdate { + admin = { + bind = cfg.admin.bind; + password = "@CJDNS_ADMIN_PASSWORD@"; + }; + authorizedPasswords = map (p: { password = p; }) cfg.authorizedPasswords; + interfaces = { + ETHInterface = if (cfg.ETHInterface.bind != "") then [ (parseModules cfg.ETHInterface) ] else [ ]; + UDPInterface = if (cfg.UDPInterface.bind != "") then [ (parseModules cfg.UDPInterface) ] else [ ]; + }; + + privateKey = "@CJDNS_PRIVATE_KEY@"; - resetAfterInactivitySeconds = 100; + resetAfterInactivitySeconds = 100; - router = { - interface = { type = "TUNInterface"; }; - ipTunnel = { - allowedConnections = []; - outgoingConnections = []; + router = { + interface = { + type = "TUNInterface"; + }; + ipTunnel = { + allowedConnections = [ ]; + outgoingConnections = [ ]; + }; }; - }; - security = [ { exemptAngel = 1; setuser = "nobody"; } ]; + security = [ + { + exemptAngel = 1; + setuser = "nobody"; + } + ]; - } cfg.extraConfig); + } cfg.extraConfig + ); in @@ -94,8 +117,10 @@ in extraConfig = lib.mkOption { type = lib.types.attrs; - default = {}; - example = { router.interface.tunDevice = "tun10"; }; + default = { }; + example = { + router.interface.tunDevice = "tun10"; + }; description = '' Extra configuration, given as attrs, that will be merged recursively with the rest of the JSON generated by this module, at the root node. @@ -143,9 +168,9 @@ in description = '' Address and port to bind UDP tunnels to. ''; - }; + }; connectTo = lib.mkOption { - type = lib.types.attrsOf ( lib.types.submodule ( connectToSubmodule ) ); + type = lib.types.attrsOf (lib.types.submodule (connectToSubmodule)); default = { }; example = lib.literalExpression '' { @@ -168,9 +193,9 @@ in default = ""; example = "eth0"; description = '' - Bind to this device for native ethernet operation. - `all` is a pseudo-name which will try to connect to all devices. - ''; + Bind to this device for native ethernet operation. + `all` is a pseudo-name which will try to connect to all devices. + ''; }; beacon = lib.mkOption { @@ -191,7 +216,7 @@ in }; connectTo = lib.mkOption { - type = lib.types.attrsOf ( lib.types.submodule ( connectToSubmodule ) ); + type = lib.types.attrsOf (lib.types.submodule (connectToSubmodule)); default = { }; example = lib.literalExpression '' { @@ -231,7 +256,10 @@ in systemd.services.cjdns = { description = "cjdns: routing engine designed for security, scalability, speed and ease of use"; - wantedBy = [ "multi-user.target" "sleep.target"]; + wantedBy = [ + "multi-user.target" + "sleep.target" + ]; after = [ "network-online.target" ]; bindsTo = [ "network-online.target" ]; @@ -253,7 +281,9 @@ in ''; script = ( - if cfg.confFile != null then "${pkg}/bin/cjdroute < ${cfg.confFile}" else + if cfg.confFile != null then + "${pkg}/bin/cjdroute < ${cfg.confFile}" + else '' source /etc/cjdns.keys (cat <<'EOF' @@ -263,7 +293,7 @@ in -e "s/@CJDNS_ADMIN_PASSWORD@/$CJDNS_ADMIN_PASSWORD/g" \ -e "s/@CJDNS_PRIVATE_KEY@/$CJDNS_PRIVATE_KEY/g" \ | ${pkg}/bin/cjdroute - '' + '' ); startLimitIntervalSec = 0; @@ -283,10 +313,12 @@ in networking.hostFiles = lib.mkIf cfg.addExtraHosts [ cjdnsExtraHosts ]; assertions = [ - { assertion = ( cfg.ETHInterface.bind != "" || cfg.UDPInterface.bind != "" || cfg.confFile != null ); + { + assertion = (cfg.ETHInterface.bind != "" || cfg.UDPInterface.bind != "" || cfg.confFile != null); message = "Neither cjdns.ETHInterface.bind nor cjdns.UDPInterface.bind defined."; } - { assertion = config.networking.enableIPv6; + { + assertion = config.networking.enableIPv6; message = "networking.enableIPv6 must be enabled for CJDNS to work"; } ]; diff --git a/nixos/modules/services/networking/clatd.nix b/nixos/modules/services/networking/clatd.nix index 8c7f8e76feff8e..8ddeb51479e47a 100644 --- a/nixos/modules/services/networking/clatd.nix +++ b/nixos/modules/services/networking/clatd.nix @@ -1,8 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.clatd; - settingsFormat = pkgs.formats.keyValue {}; + settingsFormat = pkgs.formats.keyValue { }; configFile = settingsFormat.generate "clatd.conf" cfg.settings; in @@ -19,9 +24,12 @@ in }; settings = lib.mkOption { - type = lib.types.submodule ({ name, ... }: { - freeformType = settingsFormat.type; - }); + type = lib.types.submodule ( + { name, ... }: + { + freeformType = settingsFormat.type; + } + ); default = { }; example = lib.literalExpression '' { diff --git a/nixos/modules/services/networking/cloudflare-dyndns.nix b/nixos/modules/services/networking/cloudflare-dyndns.nix index 0f035362742ef2..e6e9388dd22b2a 100644 --- a/nixos/modules/services/networking/cloudflare-dyndns.nix +++ b/nixos/modules/services/networking/cloudflare-dyndns.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.cloudflare-dyndns; in @@ -72,32 +77,35 @@ in }; config = lib.mkIf cfg.enable { - systemd.services.cloudflare-dyndns = { - description = "CloudFlare Dynamic DNS Client"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; + systemd.services.cloudflare-dyndns = + { + description = "CloudFlare Dynamic DNS Client"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; - environment = { - CLOUDFLARE_DOMAINS = toString cfg.domains; - }; + environment = { + CLOUDFLARE_DOMAINS = toString cfg.domains; + }; - serviceConfig = { - Type = "simple"; - DynamicUser = true; - StateDirectory = "cloudflare-dyndns"; - EnvironmentFile = cfg.apiTokenFile; - ExecStart = - let - args = [ "--cache-file /var/lib/cloudflare-dyndns/ip.cache" ] - ++ (if cfg.ipv4 then [ "-4" ] else [ "-no-4" ]) - ++ (if cfg.ipv6 then [ "-6" ] else [ "-no-6" ]) - ++ lib.optional cfg.deleteMissing "--delete-missing" - ++ lib.optional cfg.proxied "--proxied"; - in - "${lib.getExe cfg.package} ${toString args}"; + serviceConfig = { + Type = "simple"; + DynamicUser = true; + StateDirectory = "cloudflare-dyndns"; + EnvironmentFile = cfg.apiTokenFile; + ExecStart = + let + args = + [ "--cache-file /var/lib/cloudflare-dyndns/ip.cache" ] + ++ (if cfg.ipv4 then [ "-4" ] else [ "-no-4" ]) + ++ (if cfg.ipv6 then [ "-6" ] else [ "-no-6" ]) + ++ lib.optional cfg.deleteMissing "--delete-missing" + ++ lib.optional cfg.proxied "--proxied"; + in + "${lib.getExe cfg.package} ${toString args}"; + }; + } + // lib.optionalAttrs (cfg.frequency != null) { + startAt = cfg.frequency; }; - } // lib.optionalAttrs (cfg.frequency != null) { - startAt = cfg.frequency; - }; }; } diff --git a/nixos/modules/services/networking/cloudflare-warp.nix b/nixos/modules/services/networking/cloudflare-warp.nix index 2ab5f287ac496d..9cd946903adc07 100644 --- a/nixos/modules/services/networking/cloudflare-warp.nix +++ b/nixos/modules/services/networking/cloudflare-warp.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.cloudflare-warp; in @@ -64,7 +69,10 @@ in { Type = "simple"; ExecStart = "${cfg.package}/bin/warp-svc"; - ReadWritePaths = [ "${cfg.rootDir}" "/etc/resolv.conf" ]; + ReadWritePaths = [ + "${cfg.rootDir}" + "/etc/resolv.conf" + ]; CapabilityBoundingSet = caps; AmbientCapabilities = caps; Restart = "always"; diff --git a/nixos/modules/services/networking/cloudflared.nix b/nixos/modules/services/networking/cloudflared.nix index 7023e79d31f92f..12eaf35e5fdff2 100644 --- a/nixos/modules/services/networking/cloudflared.nix +++ b/nixos/modules/services/networking/cloudflared.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.cloudflared; @@ -121,7 +126,12 @@ let }; proxyType = lib.mkOption { - type = with lib.types; nullOr (enum [ "" "socks" ]); + type = + with lib.types; + nullOr (enum [ + "" + "socks" + ]); default = null; example = ""; description = '' @@ -155,83 +165,97 @@ in description = '' Cloudflare tunnels. ''; - type = lib.types.attrsOf (lib.types.submodule ({ name, ... }: { - options = { - inherit originRequest; - - credentialsFile = lib.mkOption { - type = lib.types.str; - description = '' - Credential file. - - See [Credentials file](https://developers.cloudflare.com/cloudflare-one/connections/connect-apps/install-and-setup/tunnel-useful-terms/#credentials-file). - ''; - }; - - warp-routing = { - enabled = lib.mkOption { - type = with lib.types; nullOr bool; - default = null; - description = '' - Enable warp routing. - - See [Connect from WARP to a private network on Cloudflare using Cloudflare Tunnel](https://developers.cloudflare.com/cloudflare-one/tutorials/warp-to-tunnel/). - ''; - }; - }; - - default = lib.mkOption { - type = lib.types.str; - description = '' - Catch-all service if no ingress matches. - - See `service`. - ''; - example = "http_status:404"; - }; - - ingress = lib.mkOption { - type = with lib.types; attrsOf (either str (submodule ({ hostname, ... }: { - options = { - inherit originRequest; + type = lib.types.attrsOf ( + lib.types.submodule ( + { name, ... }: + { + options = { + inherit originRequest; + + credentialsFile = lib.mkOption { + type = lib.types.str; + description = '' + Credential file. + + See [Credentials file](https://developers.cloudflare.com/cloudflare-one/connections/connect-apps/install-and-setup/tunnel-useful-terms/#credentials-file). + ''; + }; - service = lib.mkOption { - type = with lib.types; nullOr str; + warp-routing = { + enabled = lib.mkOption { + type = with lib.types; nullOr bool; default = null; description = '' - Service to pass the traffic. + Enable warp routing. - See [Supported protocols](https://developers.cloudflare.com/cloudflare-one/connections/connect-apps/configuration/local-management/ingress/#supported-protocols). + See [Connect from WARP to a private network on Cloudflare using Cloudflare Tunnel](https://developers.cloudflare.com/cloudflare-one/tutorials/warp-to-tunnel/). ''; - example = "http://localhost:80, tcp://localhost:8000, unix:/home/production/echo.sock, hello_world or http_status:404"; }; + }; - path = lib.mkOption { - type = with lib.types; nullOr str; - default = null; - description = '' - Path filter. + default = lib.mkOption { + type = lib.types.str; + description = '' + Catch-all service if no ingress matches. - If not specified, all paths will be matched. - ''; - example = "/*.(jpg|png|css|js)"; - }; + See `service`. + ''; + example = "http_status:404"; + }; + ingress = lib.mkOption { + type = + with lib.types; + attrsOf ( + either str ( + submodule ( + { hostname, ... }: + { + options = { + inherit originRequest; + + service = lib.mkOption { + type = with lib.types; nullOr str; + default = null; + description = '' + Service to pass the traffic. + + See [Supported protocols](https://developers.cloudflare.com/cloudflare-one/connections/connect-apps/configuration/local-management/ingress/#supported-protocols). + ''; + example = "http://localhost:80, tcp://localhost:8000, unix:/home/production/echo.sock, hello_world or http_status:404"; + }; + + path = lib.mkOption { + type = with lib.types; nullOr str; + default = null; + description = '' + Path filter. + + If not specified, all paths will be matched. + ''; + example = "/*.(jpg|png|css|js)"; + }; + + }; + } + ) + ) + ); + default = { }; + description = '' + Ingress rules. + + See [Ingress rules](https://developers.cloudflare.com/cloudflare-one/connections/connect-apps/configuration/local-management/ingress/). + ''; + example = { + "*.domain.com" = "http://localhost:80"; + "*.anotherone.com" = "http://localhost:80"; + }; }; - }))); - default = { }; - description = '' - Ingress rules. - - See [Ingress rules](https://developers.cloudflare.com/cloudflare-one/connections/connect-apps/configuration/local-management/ingress/). - ''; - example = { - "*.domain.com" = "http://localhost:80"; - "*.anotherone.com" = "http://localhost:80"; }; - }; - }; - })); + } + ) + ); default = { }; example = { @@ -249,66 +273,74 @@ in }; config = lib.mkIf cfg.enable { - systemd.targets = - lib.mapAttrs' - (name: tunnel: - lib.nameValuePair "cloudflared-tunnel-${name}" { - description = "Cloudflare tunnel '${name}' target"; - requires = [ "cloudflared-tunnel-${name}.service" ]; - after = [ "cloudflared-tunnel-${name}.service" ]; - unitConfig.StopWhenUnneeded = true; - } - ) - config.services.cloudflared.tunnels; - - systemd.services = - lib.mapAttrs' - (name: tunnel: - let - filterConfig = lib.attrsets.filterAttrsRecursive (_: v: ! builtins.elem v [ null [ ] { } ]); - - filterIngressSet = lib.filterAttrs (_: v: builtins.typeOf v == "set"); - filterIngressStr = lib.filterAttrs (_: v: builtins.typeOf v == "string"); - - ingressesSet = filterIngressSet tunnel.ingress; - ingressesStr = filterIngressStr tunnel.ingress; - - fullConfig = filterConfig { - tunnel = name; - "credentials-file" = tunnel.credentialsFile; - warp-routing = filterConfig tunnel.warp-routing; - originRequest = filterConfig tunnel.originRequest; - ingress = - (map - (key: { - hostname = key; - } // lib.getAttr key (filterConfig (filterConfig ingressesSet))) - (lib.attrNames ingressesSet)) - ++ - (map - (key: { - hostname = key; - service = lib.getAttr key ingressesStr; - }) - (lib.attrNames ingressesStr)) - ++ [{ service = tunnel.default; }]; - }; + systemd.targets = lib.mapAttrs' ( + name: tunnel: + lib.nameValuePair "cloudflared-tunnel-${name}" { + description = "Cloudflare tunnel '${name}' target"; + requires = [ "cloudflared-tunnel-${name}.service" ]; + after = [ "cloudflared-tunnel-${name}.service" ]; + unitConfig.StopWhenUnneeded = true; + } + ) config.services.cloudflared.tunnels; + + systemd.services = lib.mapAttrs' ( + name: tunnel: + let + filterConfig = lib.attrsets.filterAttrsRecursive ( + _: v: + !builtins.elem v [ + null + [ ] + { } + ] + ); + + filterIngressSet = lib.filterAttrs (_: v: builtins.typeOf v == "set"); + filterIngressStr = lib.filterAttrs (_: v: builtins.typeOf v == "string"); + + ingressesSet = filterIngressSet tunnel.ingress; + ingressesStr = filterIngressStr tunnel.ingress; + + fullConfig = filterConfig { + tunnel = name; + "credentials-file" = tunnel.credentialsFile; + warp-routing = filterConfig tunnel.warp-routing; + originRequest = filterConfig tunnel.originRequest; + ingress = + (map ( + key: + { + hostname = key; + } + // lib.getAttr key (filterConfig (filterConfig ingressesSet)) + ) (lib.attrNames ingressesSet)) + ++ (map (key: { + hostname = key; + service = lib.getAttr key ingressesStr; + }) (lib.attrNames ingressesStr)) + ++ [ { service = tunnel.default; } ]; + }; - mkConfigFile = pkgs.writeText "cloudflared.yml" (builtins.toJSON fullConfig); - in - lib.nameValuePair "cloudflared-tunnel-${name}" ({ - after = [ "network.target" "network-online.target" ]; - wants = [ "network.target" "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - User = cfg.user; - Group = cfg.group; - ExecStart = "${cfg.package}/bin/cloudflared tunnel --config=${mkConfigFile} --no-autoupdate run"; - Restart = "on-failure"; - }; - }) - ) - config.services.cloudflared.tunnels; + mkConfigFile = pkgs.writeText "cloudflared.yml" (builtins.toJSON fullConfig); + in + lib.nameValuePair "cloudflared-tunnel-${name}" ({ + after = [ + "network.target" + "network-online.target" + ]; + wants = [ + "network.target" + "network-online.target" + ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + User = cfg.user; + Group = cfg.group; + ExecStart = "${cfg.package}/bin/cloudflared tunnel --config=${mkConfigFile} --no-autoupdate run"; + Restart = "on-failure"; + }; + }) + ) config.services.cloudflared.tunnels; users.users = lib.mkIf (cfg.user == "cloudflared") { cloudflared = { @@ -322,5 +354,8 @@ in }; }; - meta.maintainers = with lib.maintainers; [ bbigras anpin ]; + meta.maintainers = with lib.maintainers; [ + bbigras + anpin + ]; } diff --git a/nixos/modules/services/networking/cntlm.nix b/nixos/modules/services/networking/cntlm.nix index 4615380c41ebe0..13a9bb7b04ec67 100644 --- a/nixos/modules/services/networking/cntlm.nix +++ b/nixos/modules/services/networking/cntlm.nix @@ -1,28 +1,34 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.cntlm; - configFile = if cfg.configText != "" then - pkgs.writeText "cntlm.conf" '' - ${cfg.configText} - '' + configFile = + if cfg.configText != "" then + pkgs.writeText "cntlm.conf" '' + ${cfg.configText} + '' else - pkgs.writeText "lighttpd.conf" '' - # Cntlm Authentication Proxy Configuration - Username ${cfg.username} - Domain ${cfg.domain} - Password ${cfg.password} - ${lib.optionalString (cfg.netbios_hostname != "") "Workstation ${cfg.netbios_hostname}"} - ${lib.concatMapStrings (entry: "Proxy ${entry}\n") cfg.proxy} - ${lib.optionalString (cfg.noproxy != []) "NoProxy ${lib.concatStringsSep ", " cfg.noproxy}"} - - ${lib.concatMapStrings (port: '' - Listen ${toString port} - '') cfg.port} - - ${cfg.extraConfig} - ''; + pkgs.writeText "lighttpd.conf" '' + # Cntlm Authentication Proxy Configuration + Username ${cfg.username} + Domain ${cfg.domain} + Password ${cfg.password} + ${lib.optionalString (cfg.netbios_hostname != "") "Workstation ${cfg.netbios_hostname}"} + ${lib.concatMapStrings (entry: "Proxy ${entry}\n") cfg.proxy} + ${lib.optionalString (cfg.noproxy != [ ]) "NoProxy ${lib.concatStringsSep ", " cfg.noproxy}"} + + ${lib.concatMapStrings (port: '' + Listen ${toString port} + '') cfg.port} + + ${cfg.extraConfig} + ''; in @@ -74,13 +80,16 @@ in description = '' A list of domains where the proxy is skipped. ''; - default = []; + default = [ ]; type = lib.types.listOf lib.types.str; - example = [ "*.example.com" "example.com" ]; + example = [ + "*.example.com" + "example.com" + ]; }; port = lib.mkOption { - default = [3128]; + default = [ 3128 ]; type = lib.types.listOf lib.types.port; description = "Specifies on which ports the cntlm daemon listens."; }; @@ -92,9 +101,9 @@ in }; configText = lib.mkOption { - type = lib.types.lines; - default = ""; - description = "Verbatim contents of {file}`cntlm.conf`."; + type = lib.types.lines; + default = ""; + description = "Verbatim contents of {file}`cntlm.conf`."; }; }; diff --git a/nixos/modules/services/networking/connman.nix b/nixos/modules/services/networking/connman.nix index 2391f11c1cbd55..427b9c409c9281 100644 --- a/nixos/modules/services/networking/connman.nix +++ b/nixos/modules/services/networking/connman.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.connman; @@ -9,7 +14,8 @@ let ${cfg.extraConfig} ''; enableIwd = cfg.wifi.backend == "iwd"; -in { +in +{ meta.maintainers = with lib.maintainers; [ AndersonTorres ]; imports = [ @@ -54,7 +60,13 @@ in { networkInterfaceBlacklist = lib.mkOption { type = with lib.types; listOf str; - default = [ "vmnet" "vboxnet" "virbr" "ifb" "ve" ]; + default = [ + "vmnet" + "vboxnet" + "virbr" + "ifb" + "ve" + ]; description = '' Default blacklisted interfaces, this includes NixOS containers interfaces (ve). ''; @@ -62,7 +74,10 @@ in { wifi = { backend = lib.mkOption { - type = lib.types.enum [ "wpa_supplicant" "iwd" ]; + type = lib.types.enum [ + "wpa_supplicant" + "iwd" + ]; default = "wpa_supplicant"; description = '' Specify the Wi-Fi backend used. @@ -85,15 +100,18 @@ in { ###### implementation config = lib.mkIf cfg.enable { - assertions = [{ - assertion = !config.networking.useDHCP; - message = "You can not use services.connman with networking.useDHCP"; - }{ - # TODO: connman seemingly can be used along network manager and - # connmanFull supports this - so this should be worked out somehow - assertion = !config.networking.networkmanager.enable; - message = "You can not use services.connman with networking.networkmanager"; - }]; + assertions = [ + { + assertion = !config.networking.useDHCP; + message = "You can not use services.connman with networking.useDHCP"; + } + { + # TODO: connman seemingly can be used along network manager and + # connmanFull supports this - so this should be worked out somehow + assertion = !config.networking.networkmanager.enable; + message = "You can not use services.connman with networking.networkmanager"; + } + ]; environment.systemPackages = [ cfg.package ]; @@ -106,12 +124,15 @@ in { Type = "dbus"; BusName = "net.connman"; Restart = "on-failure"; - ExecStart = toString ([ - "${cfg.package}/sbin/connmand" - "--config=${configFile}" - "--nodaemon" - ] ++ lib.optional enableIwd "--wifi=iwd_agent" - ++ cfg.extraFlags); + ExecStart = toString ( + [ + "${cfg.package}/sbin/connmand" + "--config=${configFile}" + "--nodaemon" + ] + ++ lib.optional enableIwd "--wifi=iwd_agent" + ++ cfg.extraFlags + ); StandardOutput = "null"; }; }; diff --git a/nixos/modules/services/networking/consul.nix b/nixos/modules/services/networking/consul.nix index 855d3872aa62e1..74fcaaaddcdc45 100644 --- a/nixos/modules/services/networking/consul.nix +++ b/nixos/modules/services/networking/consul.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let dataDir = "/var/lib/consul"; @@ -11,12 +17,15 @@ let }; } // cfg.extraConfig; - configFiles = [ "/etc/consul.json" "/etc/consul-addrs.json" ] - ++ cfg.extraConfigFiles; + configFiles = [ + "/etc/consul.json" + "/etc/consul-addrs.json" + ] ++ cfg.extraConfigFiles; devices = lib.attrValues (lib.filterAttrs (_: i: i != null) cfg.interface); - systemdDevices = lib.forEach devices - (i: "sys-subsystem-net-devices-${utils.escapeSystemdPath i}.device"); + systemdDevices = lib.forEach devices ( + i: "sys-subsystem-net-devices-${utils.escapeSystemdPath i}.device" + ); in { options = { @@ -73,7 +82,11 @@ in }; forceAddrFamily = lib.mkOption { - type = lib.types.enum [ "any" "ipv4" "ipv6" ]; + type = lib.types.enum [ + "any" + "ipv4" + "ipv6" + ]; default = "any"; description = '' Whether to bind ipv4/ipv6 or both kind of addresses. @@ -150,121 +163,139 @@ in }; config = lib.mkIf cfg.enable ( - lib.mkMerge [{ - - users.users.consul = { - description = "Consul agent daemon user"; - isSystemUser = true; - group = "consul"; - # The shell is needed for health checks - shell = "/run/current-system/sw/bin/bash"; - }; - users.groups.consul = {}; + lib.mkMerge [ + { + + users.users.consul = { + description = "Consul agent daemon user"; + isSystemUser = true; + group = "consul"; + # The shell is needed for health checks + shell = "/run/current-system/sw/bin/bash"; + }; + users.groups.consul = { }; - environment = { - etc."consul.json".text = builtins.toJSON configOptions; - # We need consul.d to exist for consul to start - etc."consul.d/dummy.json".text = "{ }"; - systemPackages = [ cfg.package ]; - }; + environment = { + etc."consul.json".text = builtins.toJSON configOptions; + # We need consul.d to exist for consul to start + etc."consul.d/dummy.json".text = "{ }"; + systemPackages = [ cfg.package ]; + }; - warnings = lib.flatten [ - (lib.optional (cfg.forceIpv4 != null) '' - The option consul.forceIpv4 is deprecated, please use - consul.forceAddrFamily instead. - '') - ]; - - systemd.services.consul = { - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ] ++ systemdDevices; - bindsTo = systemdDevices; - restartTriggers = [ config.environment.etc."consul.json".source ] - ++ lib.mapAttrsToList (_: d: d.source) - (lib.filterAttrs (n: _: lib.hasPrefix "consul.d/" n) config.environment.etc); - - serviceConfig = { - ExecStart = "@${lib.getExe cfg.package} consul agent -config-dir /etc/consul.d" - + lib.concatMapStrings (n: " -config-file ${n}") configFiles; - ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - PermissionsStartOnly = true; - User = if cfg.dropPrivileges then "consul" else null; - Restart = "on-failure"; - TimeoutStartSec = "infinity"; - } // (lib.optionalAttrs (cfg.leaveOnStop) { - ExecStop = "${lib.getExe cfg.package} leave"; - }); - - path = with pkgs; [ iproute2 gawk cfg.package ]; - preStart = let - family = if cfg.forceAddrFamily == "ipv6" then - "-6" - else if cfg.forceAddrFamily == "ipv4" then - "-4" - else - ""; - in '' - mkdir -m 0700 -p ${dataDir} - chown -R consul ${dataDir} - - # Determine interface addresses - getAddrOnce () { - ip ${family} addr show dev "$1" scope global \ - | awk -F '[ /\t]*' '/inet/ {print $3}' | head -n 1 - } - getAddr () { - ADDR="$(getAddrOnce $1)" - LEFT=60 # Die after 1 minute - while [ -z "$ADDR" ]; do - sleep 1 - LEFT=$(expr $LEFT - 1) - if [ "$LEFT" -eq "0" ]; then - echo "Address lookup timed out" - exit 1 - fi - ADDR="$(getAddrOnce $1)" - done - echo "$ADDR" - } - echo "{" > /etc/consul-addrs.json - delim=" " - '' - + lib.concatStrings (lib.flip lib.mapAttrsToList cfg.interface (name: i: - lib.optionalString (i != null) '' - echo "$delim \"${name}_addr\": \"$(getAddr "${i}")\"" >> /etc/consul-addrs.json - delim="," - '')) - + '' - echo "}" >> /etc/consul-addrs.json - ''; - }; - } - - # deprecated - (lib.mkIf (cfg.forceIpv4 != null && cfg.forceIpv4) { - services.consul.forceAddrFamily = "ipv4"; - }) - - (lib.mkIf (cfg.alerts.enable) { - systemd.services.consul-alerts = { - wantedBy = [ "multi-user.target" ]; - after = [ "consul.service" ]; - - path = [ cfg.package ]; - - serviceConfig = { - ExecStart = '' - ${lib.getExe cfg.alerts.package} start \ - --alert-addr=${cfg.alerts.listenAddr} \ - --consul-addr=${cfg.alerts.consulAddr} \ - ${lib.optionalString cfg.alerts.watchChecks "--watch-checks"} \ - ${lib.optionalString cfg.alerts.watchEvents "--watch-events"} - ''; - User = if cfg.dropPrivileges then "consul" else null; - Restart = "on-failure"; + warnings = lib.flatten [ + (lib.optional (cfg.forceIpv4 != null) '' + The option consul.forceIpv4 is deprecated, please use + consul.forceAddrFamily instead. + '') + ]; + + systemd.services.consul = { + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ] ++ systemdDevices; + bindsTo = systemdDevices; + restartTriggers = + [ config.environment.etc."consul.json".source ] + ++ lib.mapAttrsToList (_: d: d.source) ( + lib.filterAttrs (n: _: lib.hasPrefix "consul.d/" n) config.environment.etc + ); + + serviceConfig = + { + ExecStart = + "@${lib.getExe cfg.package} consul agent -config-dir /etc/consul.d" + + lib.concatMapStrings (n: " -config-file ${n}") configFiles; + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + PermissionsStartOnly = true; + User = if cfg.dropPrivileges then "consul" else null; + Restart = "on-failure"; + TimeoutStartSec = "infinity"; + } + // (lib.optionalAttrs (cfg.leaveOnStop) { + ExecStop = "${lib.getExe cfg.package} leave"; + }); + + path = with pkgs; [ + iproute2 + gawk + cfg.package + ]; + preStart = + let + family = + if cfg.forceAddrFamily == "ipv6" then + "-6" + else if cfg.forceAddrFamily == "ipv4" then + "-4" + else + ""; + in + '' + mkdir -m 0700 -p ${dataDir} + chown -R consul ${dataDir} + + # Determine interface addresses + getAddrOnce () { + ip ${family} addr show dev "$1" scope global \ + | awk -F '[ /\t]*' '/inet/ {print $3}' | head -n 1 + } + getAddr () { + ADDR="$(getAddrOnce $1)" + LEFT=60 # Die after 1 minute + while [ -z "$ADDR" ]; do + sleep 1 + LEFT=$(expr $LEFT - 1) + if [ "$LEFT" -eq "0" ]; then + echo "Address lookup timed out" + exit 1 + fi + ADDR="$(getAddrOnce $1)" + done + echo "$ADDR" + } + echo "{" > /etc/consul-addrs.json + delim=" " + '' + + lib.concatStrings ( + lib.flip lib.mapAttrsToList cfg.interface ( + name: i: + lib.optionalString (i != null) '' + echo "$delim \"${name}_addr\": \"$(getAddr "${i}")\"" >> /etc/consul-addrs.json + delim="," + '' + ) + ) + + '' + echo "}" >> /etc/consul-addrs.json + ''; }; - }; - }) + } + + # deprecated + (lib.mkIf (cfg.forceIpv4 != null && cfg.forceIpv4) { + services.consul.forceAddrFamily = "ipv4"; + }) + + (lib.mkIf (cfg.alerts.enable) { + systemd.services.consul-alerts = { + wantedBy = [ "multi-user.target" ]; + after = [ "consul.service" ]; + + path = [ cfg.package ]; + + serviceConfig = { + ExecStart = '' + ${lib.getExe cfg.alerts.package} start \ + --alert-addr=${cfg.alerts.listenAddr} \ + --consul-addr=${cfg.alerts.consulAddr} \ + ${lib.optionalString cfg.alerts.watchChecks "--watch-checks"} \ + ${lib.optionalString cfg.alerts.watchEvents "--watch-events"} + ''; + User = if cfg.dropPrivileges then "consul" else null; + Restart = "on-failure"; + }; + }; + }) - ]); + ] + ); } diff --git a/nixos/modules/services/networking/coredns.nix b/nixos/modules/services/networking/coredns.nix index 14602e06fe820d..46202fa088f194 100644 --- a/nixos/modules/services/networking/coredns.nix +++ b/nixos/modules/services/networking/coredns.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.coredns; configFile = pkgs.writeText "Corefile" cfg.config; -in { +in +{ options.services.coredns = { enable = lib.mkEnableOption "Coredns dns server"; @@ -23,7 +29,7 @@ in { package = lib.mkPackageOption pkgs "coredns" { }; extraArgs = lib.mkOption { - default = []; + default = [ ]; example = [ "-dns.port=53" ]; type = lib.types.listOf lib.types.str; description = "Extra arguments to pass to coredns."; diff --git a/nixos/modules/services/networking/corerad.nix b/nixos/modules/services/networking/corerad.nix index edeee881008fc8..3851c22f6eeca9 100644 --- a/nixos/modules/services/networking/corerad.nix +++ b/nixos/modules/services/networking/corerad.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.corerad; - settingsFormat = pkgs.formats.toml {}; + settingsFormat = pkgs.formats.toml { }; -in { +in +{ meta.maintainers = with lib.maintainers; [ mdlayher ]; options.services.corerad = { diff --git a/nixos/modules/services/networking/coturn.nix b/nixos/modules/services/networking/coturn.nix index ab8806dc03a187..b50aad89871b83 100644 --- a/nixos/modules/services/networking/coturn.nix +++ b/nixos/modules/services/networking/coturn.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.services.coturn; pidfile = "/run/turnserver/turnserver.pid"; @@ -14,8 +20,12 @@ let ${lib.optionalString cfg.lt-cred-mech "lt-cred-mech"} ${lib.optionalString cfg.no-auth "no-auth"} ${lib.optionalString cfg.use-auth-secret "use-auth-secret"} - ${lib.optionalString (cfg.static-auth-secret != null) "static-auth-secret=${cfg.static-auth-secret}"} - ${lib.optionalString (cfg.static-auth-secret-file != null) "static-auth-secret=#static-auth-secret#"} + ${lib.optionalString ( + cfg.static-auth-secret != null + ) "static-auth-secret=${cfg.static-auth-secret}"} + ${lib.optionalString ( + cfg.static-auth-secret-file != null + ) "static-auth-secret=#static-auth-secret#"} realm=${cfg.realm} ${lib.optionalString cfg.no-udp "no-udp"} ${lib.optionalString cfg.no-tcp "no-tcp"} @@ -36,7 +46,8 @@ let ${lib.optionalString (cfg.cli-password != null) "cli-password=${cfg.cli-password}"} ${cfg.extraConfig} ''; -in { +in +{ options = { services.coturn = { enable = lib.mkEnableOption "coturn TURN server"; @@ -89,8 +100,11 @@ in { }; listening-ips = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; - example = [ "203.0.113.42" "2001:DB8::42" ]; + default = [ ]; + example = [ + "203.0.113.42" + "2001:DB8::42" + ]; description = '' Listener IP addresses of relay server. If no IP(s) specified in the config file or in the command line options, @@ -99,8 +113,11 @@ in { }; relay-ips = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; - example = [ "203.0.113.42" "2001:DB8::42" ]; + default = [ ]; + example = [ + "203.0.113.42" + "2001:DB8::42" + ]; description = '' Relay address (the local IP address that will be used to relay the packets to the peer). @@ -301,106 +318,120 @@ in { }; }; - config = lib.mkIf cfg.enable (lib.mkMerge [ - { assertions = [ - { assertion = cfg.static-auth-secret != null -> cfg.static-auth-secret-file == null ; - message = "static-auth-secret and static-auth-secret-file cannot be set at the same time"; + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + { + assertions = [ + { + assertion = cfg.static-auth-secret != null -> cfg.static-auth-secret-file == null; + message = "static-auth-secret and static-auth-secret-file cannot be set at the same time"; + } + ]; } - ];} - { - users.users.turnserver = - { uid = config.ids.uids.turnserver; + { + users.users.turnserver = { + uid = config.ids.uids.turnserver; group = "turnserver"; description = "coturn TURN server user"; }; - users.groups.turnserver = - { gid = config.ids.gids.turnserver; + users.groups.turnserver = { + gid = config.ids.gids.turnserver; members = [ "turnserver" ]; }; - systemd.services.coturn = let - runConfig = "/run/coturn/turnserver.cfg"; - in { - description = "coturn TURN server"; - after = [ "network-online.target" ]; - wants = [ "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; + systemd.services.coturn = + let + runConfig = "/run/coturn/turnserver.cfg"; + in + { + description = "coturn TURN server"; + after = [ "network-online.target" ]; + wants = [ "network-online.target" ]; + wantedBy = [ "multi-user.target" ]; - unitConfig = { - Documentation = "man:coturn(1) man:turnadmin(1) man:turnserver(1)"; - }; + unitConfig = { + Documentation = "man:coturn(1) man:turnadmin(1) man:turnserver(1)"; + }; - preStart = '' - cat ${configFile} > ${runConfig} - ${lib.optionalString (cfg.static-auth-secret-file != null) '' - ${pkgs.replace-secret}/bin/replace-secret \ - "#static-auth-secret#" \ - ${cfg.static-auth-secret-file} \ - ${runConfig} - '' } - chmod 640 ${runConfig} - ''; - serviceConfig = rec { - Type = "simple"; - ExecStart = utils.escapeSystemdExecArgs [ - (lib.getExe' pkgs.coturn "turnserver") - "-c" - runConfig - ]; - User = "turnserver"; - Group = "turnserver"; - RuntimeDirectory = [ - "coturn" - "turnserver" - ]; - RuntimeDirectoryMode = "0700"; - Restart = "on-abort"; + preStart = '' + cat ${configFile} > ${runConfig} + ${lib.optionalString (cfg.static-auth-secret-file != null) '' + ${pkgs.replace-secret}/bin/replace-secret \ + "#static-auth-secret#" \ + ${cfg.static-auth-secret-file} \ + ${runConfig} + ''} + chmod 640 ${runConfig} + ''; + serviceConfig = rec { + Type = "simple"; + ExecStart = utils.escapeSystemdExecArgs [ + (lib.getExe' pkgs.coturn "turnserver") + "-c" + runConfig + ]; + User = "turnserver"; + Group = "turnserver"; + RuntimeDirectory = [ + "coturn" + "turnserver" + ]; + RuntimeDirectoryMode = "0700"; + Restart = "on-abort"; - # Hardening - AmbientCapabilities = if - cfg.listening-port < 1024 || - cfg.alt-listening-port < 1024 || - cfg.tls-listening-port < 1024 || - cfg.alt-tls-listening-port < 1024 || - cfg.min-port < 1024 - then [ "CAP_NET_BIND_SERVICE" ] else [ "" ]; - CapabilityBoundingSet = AmbientCapabilities; - DevicePolicy = "closed"; - LockPersonality = true; - MemoryDenyWriteExecute = true; - NoNewPrivileges = true; - PrivateDevices = true; - PrivateTmp = true; - PrivateUsers = true; - ProcSubset = "pid"; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - ProtectSystem = "strict"; - RemoveIPC = true; - RestrictAddressFamilies = [ - "AF_INET" - "AF_INET6" - ] ++ lib.optionals (cfg.listening-ips == [ ]) [ - # only used for interface discovery when no listening ips are configured - "AF_NETLINK" - ]; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ - "@system-service" - "~@privileged @resources" - ]; - UMask = "0077"; - }; - }; - }]); + # Hardening + AmbientCapabilities = + if + cfg.listening-port < 1024 + || cfg.alt-listening-port < 1024 + || cfg.tls-listening-port < 1024 + || cfg.alt-tls-listening-port < 1024 + || cfg.min-port < 1024 + then + [ "CAP_NET_BIND_SERVICE" ] + else + [ "" ]; + CapabilityBoundingSet = AmbientCapabilities; + DevicePolicy = "closed"; + LockPersonality = true; + MemoryDenyWriteExecute = true; + NoNewPrivileges = true; + PrivateDevices = true; + PrivateTmp = true; + PrivateUsers = true; + ProcSubset = "pid"; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + ProtectSystem = "strict"; + RemoveIPC = true; + RestrictAddressFamilies = + [ + "AF_INET" + "AF_INET6" + ] + ++ lib.optionals (cfg.listening-ips == [ ]) [ + # only used for interface discovery when no listening ips are configured + "AF_NETLINK" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged @resources" + ]; + UMask = "0077"; + }; + }; + } + ] + ); } diff --git a/nixos/modules/services/networking/create_ap.nix b/nixos/modules/services/networking/create_ap.nix index cebea3c9059cc3..a67f11f2a6ac8c 100644 --- a/nixos/modules/services/networking/create_ap.nix +++ b/nixos/modules/services/networking/create_ap.nix @@ -1,14 +1,26 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.create_ap; configFile = pkgs.writeText "create_ap.conf" (lib.generators.toKeyValue { } cfg.settings); -in { +in +{ options = { services.create_ap = { enable = lib.mkEnableOption "setting up wifi hotspots using create_ap"; settings = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ int bool str ]); - default = {}; + type = + with lib.types; + attrsOf (oneOf [ + int + bool + str + ]); + default = { }; description = '' Configuration for `create_ap`. See [upstream example configuration](https://raw.githubusercontent.com/lakinduakash/linux-wifi-hotspot/master/src/scripts/create_ap.conf) diff --git a/nixos/modules/services/networking/croc.nix b/nixos/modules/services/networking/croc.nix index 799bf390d526ce..b6395992af82da 100644 --- a/nixos/modules/services/networking/croc.nix +++ b/nixos/modules/services/networking/croc.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) types; cfg = config.services.croc; @@ -9,7 +14,13 @@ in enable = lib.mkEnableOption "croc relay"; ports = lib.mkOption { type = with types; listOf port; - default = [9009 9010 9011 9012 9013]; + default = [ + 9009 + 9010 + 9011 + 9012 + 9013 + ]; description = "Ports of the relay."; }; pass = lib.mkOption { @@ -26,7 +37,9 @@ in after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart = "${pkgs.croc}/bin/croc --pass '${cfg.pass}' ${lib.optionalString cfg.debug "--debug"} relay --ports ${lib.concatMapStringsSep "," toString cfg.ports}"; + ExecStart = "${pkgs.croc}/bin/croc --pass '${cfg.pass}' ${lib.optionalString cfg.debug "--debug"} relay --ports ${ + lib.concatMapStringsSep "," toString cfg.ports + }"; # The following options are only for optimizing: # systemd-analyze security croc AmbientCapabilities = ""; @@ -54,7 +67,10 @@ in ProtectProc = "invisible"; ProtectSystem = "strict"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; @@ -68,11 +84,17 @@ in # to allow traversal of directories they create in RootDirectory=. UMask = "0066"; # Create rootDir in the host's mount namespace. - RuntimeDirectory = [(baseNameOf rootDir)]; + RuntimeDirectory = [ (baseNameOf rootDir) ]; RuntimeDirectoryMode = "700"; SystemCallFilter = [ "@system-service" - "~@aio" "~@keyring" "~@memlock" "~@privileged" "~@setuid" "~@sync" "~@timer" + "~@aio" + "~@keyring" + "~@memlock" + "~@privileged" + "~@setuid" + "~@sync" + "~@timer" ]; SystemCallArchitectures = "native"; SystemCallErrorNumber = "EPERM"; @@ -82,5 +104,8 @@ in networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall cfg.ports; }; - meta.maintainers = with lib.maintainers; [ hax404 julm ]; + meta.maintainers = with lib.maintainers; [ + hax404 + julm + ]; } diff --git a/nixos/modules/services/networking/dae.nix b/nixos/modules/services/networking/dae.nix index 34ebb47c18e778..328db5850dcc3c 100644 --- a/nixos/modules/services/networking/dae.nix +++ b/nixos/modules/services/networking/dae.nix @@ -1,26 +1,38 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.dae; assets = cfg.assets; - genAssetsDrv = paths: pkgs.symlinkJoin { - name = "dae-assets"; - inherit paths; - }; + genAssetsDrv = + paths: + pkgs.symlinkJoin { + name = "dae-assets"; + inherit paths; + }; in { - meta.maintainers = with lib.maintainers; [ pokon548 oluceps ]; + meta.maintainers = with lib.maintainers; [ + pokon548 + oluceps + ]; options = { - services.dae = with lib;{ + services.dae = with lib; { enable = mkEnableOption "dae, a Linux high-performance transparent proxy solution based on eBPF"; package = mkPackageOption pkgs "dae" { }; - assets = mkOption { - type = with types;(listOf path); - default = with pkgs; [ v2ray-geoip v2ray-domain-list-community ]; + type = with types; (listOf path); + default = with pkgs; [ + v2ray-geoip + v2ray-domain-list-community + ]; defaultText = literalExpression "with pkgs; [ v2ray-geoip v2ray-domain-list-community ]"; description = '' Assets required to run dae. @@ -43,17 +55,19 @@ in }; openFirewall = mkOption { - type = with types; submodule { - options = { - enable = mkEnableOption "opening {option}`port` in the firewall"; - port = mkOption { - type = types.port; - description = '' - Port to be opened. Consist with field `tproxy_port` in config file. - ''; + type = + with types; + submodule { + options = { + enable = mkEnableOption "opening {option}`port` in the firewall"; + port = mkOption { + type = types.port; + description = '' + Port to be opened. Consist with field `tproxy_port` in config file. + ''; + }; }; }; - }; default = { enable = true; port = 12345; @@ -89,81 +103,87 @@ in ''; }; - disableTxChecksumIpGeneric = - mkEnableOption "" // { description = "See "; }; + disableTxChecksumIpGeneric = mkEnableOption "" // { + description = "See "; + }; }; }; - config = lib.mkIf cfg.enable - - { - environment.systemPackages = [ cfg.package ]; - systemd.packages = [ cfg.package ]; + config = + lib.mkIf cfg.enable + + { + environment.systemPackages = [ cfg.package ]; + systemd.packages = [ cfg.package ]; + + networking = lib.mkIf cfg.openFirewall.enable { + firewall = + let + portToOpen = cfg.openFirewall.port; + in + { + allowedTCPPorts = [ portToOpen ]; + allowedUDPPorts = [ portToOpen ]; + }; + }; - networking = lib.mkIf cfg.openFirewall.enable { - firewall = - let portToOpen = cfg.openFirewall.port; + systemd.services.dae = + let + daeBin = lib.getExe cfg.package; + + configPath = + if cfg.configFile != null then cfg.configFile else pkgs.writeText "config.dae" cfg.config; + + TxChecksumIpGenericWorkaround = + with lib; + (getExe pkgs.writeShellApplication { + name = "disable-tx-checksum-ip-generic"; + text = with pkgs; '' + iface=$(${iproute2}/bin/ip route | ${lib.getExe gawk} '/default/ {print $5}') + ${lib.getExe ethtool} -K "$iface" tx-checksum-ip-generic off + ''; + }); in { - allowedTCPPorts = [ portToOpen ]; - allowedUDPPorts = [ portToOpen ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + LoadCredential = [ "config.dae:${configPath}" ]; + ExecStartPre = [ + "" + "${daeBin} validate -c \${CREDENTIALS_DIRECTORY}/config.dae" + ] ++ (with lib; optional cfg.disableTxChecksumIpGeneric TxChecksumIpGenericWorkaround); + ExecStart = [ + "" + "${daeBin} run --disable-timestamp -c \${CREDENTIALS_DIRECTORY}/config.dae" + ]; + Environment = "DAE_LOCATION_ASSET=${cfg.assetsPath}"; + }; }; - }; - systemd.services.dae = - let - daeBin = lib.getExe cfg.package; - - configPath = - if cfg.configFile != null - then cfg.configFile else pkgs.writeText "config.dae" cfg.config; - - TxChecksumIpGenericWorkaround = with lib; - (getExe pkgs.writeShellApplication { - name = "disable-tx-checksum-ip-generic"; - text = with pkgs; '' - iface=$(${iproute2}/bin/ip route | ${lib.getExe gawk} '/default/ {print $5}') - ${lib.getExe ethtool} -K "$iface" tx-checksum-ip-generic off - ''; - }); - in - { - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - LoadCredential = [ "config.dae:${configPath}" ]; - ExecStartPre = [ "" "${daeBin} validate -c \${CREDENTIALS_DIRECTORY}/config.dae" ] - ++ (with lib; optional cfg.disableTxChecksumIpGeneric TxChecksumIpGenericWorkaround); - ExecStart = [ "" "${daeBin} run --disable-timestamp -c \${CREDENTIALS_DIRECTORY}/config.dae" ]; - Environment = "DAE_LOCATION_ASSET=${cfg.assetsPath}"; - }; - }; + assertions = [ + { + assertion = lib.pathExists (toString (genAssetsDrv cfg.assets) + "/share/v2ray"); + message = '' + Packages in `assets` has no preset paths included. + Please set `assetsPath` instead. + ''; + } - assertions = [ - { - assertion = lib.pathExists (toString (genAssetsDrv cfg.assets) + "/share/v2ray"); - message = '' - Packages in `assets` has no preset paths included. - Please set `assetsPath` instead. - ''; - } - - { - assertion = !((config.services.dae.config != null) - && (config.services.dae.configFile != null)); - message = '' - Option `config` and `configFile` could not be set - at the same time. - ''; - } - - { - assertion = !((config.services.dae.config == null) - && (config.services.dae.configFile == null)); - message = '' - Either `config` or `configFile` should be set. - ''; - } - ]; - }; + { + assertion = !((config.services.dae.config != null) && (config.services.dae.configFile != null)); + message = '' + Option `config` and `configFile` could not be set + at the same time. + ''; + } + + { + assertion = !((config.services.dae.config == null) && (config.services.dae.configFile == null)); + message = '' + Either `config` or `configFile` should be set. + ''; + } + ]; + }; } diff --git a/nixos/modules/services/networking/dante.nix b/nixos/modules/services/networking/dante.nix index aef518ddbfd977..3cb08a6c23a953 100644 --- a/nixos/modules/services/networking/dante.nix +++ b/nixos/modules/services/networking/dante.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.dante; confFile = pkgs.writeText "dante-sockd.conf" '' @@ -20,7 +25,7 @@ in enable = lib.mkEnableOption "Dante SOCKS proxy"; config = lib.mkOption { - type = lib.types.lines; + type = lib.types.lines; description = '' Contents of Dante's configuration file. NOTE: user.privileged, user.unprivileged and logoutput are set by the service. @@ -31,30 +36,31 @@ in config = lib.mkIf cfg.enable { assertions = [ - { assertion = cfg.config != ""; - message = "please provide Dante configuration file contents"; + { + assertion = cfg.config != ""; + message = "please provide Dante configuration file contents"; } ]; users.users.dante = { - description = "Dante SOCKS proxy daemon user"; - isSystemUser = true; - group = "dante"; + description = "Dante SOCKS proxy daemon user"; + isSystemUser = true; + group = "dante"; }; - users.groups.dante = {}; + users.groups.dante = { }; systemd.services.dante = { - description = "Dante SOCKS v4 and v5 compatible proxy server"; - wants = [ "network-online.target" ]; - after = [ "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; + description = "Dante SOCKS v4 and v5 compatible proxy server"; + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; + wantedBy = [ "multi-user.target" ]; serviceConfig = { - Type = "simple"; - ExecStart = "${pkgs.dante}/bin/sockd -f ${confFile}"; - ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + Type = "simple"; + ExecStart = "${pkgs.dante}/bin/sockd -f ${confFile}"; + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; # Can crash sometimes; see https://github.com/NixOS/nixpkgs/pull/39005#issuecomment-381828708 - Restart = "on-failure"; + Restart = "on-failure"; }; }; }; diff --git a/nixos/modules/services/networking/deconz.nix b/nixos/modules/services/networking/deconz.nix index d8908470bb2316..88e294f86c2de9 100644 --- a/nixos/modules/services/networking/deconz.nix +++ b/nixos/modules/services/networking/deconz.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.deconz; @@ -113,7 +118,8 @@ in + " --ws-port=${toString cfg.wsPort}" + " --auto-connect=1" + (lib.optionalString (cfg.device != null) " --dev=${cfg.device}") - + " " + (lib.escapeShellArgs cfg.extraArgs); + + " " + + (lib.escapeShellArgs cfg.extraArgs); Restart = "on-failure"; AmbientCapabilities = capabilities; CapabilityBoundingSet = capabilities; diff --git a/nixos/modules/services/networking/dnscache.nix b/nixos/modules/services/networking/dnscache.nix index e743d1c5432390..f360aa86c7b8de 100644 --- a/nixos/modules/services/networking/dnscache.nix +++ b/nixos/modules/services/networking/dnscache.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.dnscache; @@ -9,11 +14,13 @@ let touch "$out/ip/"${lib.escapeShellArg ip} '') cfg.clientIps} - ${lib.concatStrings (lib.mapAttrsToList (host: ips: '' - ${lib.concatMapStrings (ip: '' - echo ${lib.escapeShellArg ip} >> "$out/servers/"${lib.escapeShellArg host} - '') ips} - '') cfg.domainServers)} + ${lib.concatStrings ( + lib.mapAttrsToList (host: ips: '' + ${lib.concatMapStrings (ip: '' + echo ${lib.escapeShellArg ip} >> "$out/servers/"${lib.escapeShellArg host} + '') ips} + '') cfg.domainServers + )} # if a list of root servers was not provided in config, copy it # over. (this is also done by dnscache-conf, but we 'rm -rf @@ -25,7 +32,8 @@ let fi ''; -in { +in +{ ###### interface @@ -48,7 +56,10 @@ in { default = [ "127.0.0.1" ]; type = lib.types.listOf lib.types.str; description = "Client IP addresses (or prefixes) from which to accept connections."; - example = ["192.168" "172.23.75.82"]; + example = [ + "192.168" + "172.23.75.82" + ]; }; domainServers = lib.mkOption { @@ -84,15 +95,19 @@ in { config = lib.mkIf config.services.dnscache.enable { environment.systemPackages = [ pkgs.djbdns ]; users.users.dnscache = { - isSystemUser = true; - group = "dnscache"; + isSystemUser = true; + group = "dnscache"; }; - users.groups.dnscache = {}; + users.groups.dnscache = { }; systemd.services.dnscache = { description = "djbdns dnscache server"; wantedBy = [ "multi-user.target" ]; - path = with pkgs; [ bash daemontools djbdns ]; + path = with pkgs; [ + bash + daemontools + djbdns + ]; preStart = '' rm -rf /var/lib/dnscache dnscache-conf dnscache dnscache /var/lib/dnscache ${config.services.dnscache.ip} diff --git a/nixos/modules/services/networking/dnscrypt-proxy2.nix b/nixos/modules/services/networking/dnscrypt-proxy2.nix index 980eda117b1ebe..273d0b3a6bbb28 100644 --- a/nixos/modules/services/networking/dnscrypt-proxy2.nix +++ b/nixos/modules/services/networking/dnscrypt-proxy2.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, ... }: with lib; +{ + config, + lib, + pkgs, + ... +}: +with lib; let cfg = config.services.dnscrypt-proxy2; @@ -24,7 +30,7 @@ in } ''; type = types.attrs; - default = {}; + default = { }; }; upstreamDefaults = mkOption { @@ -44,18 +50,26 @@ in ''; example = "/etc/dnscrypt-proxy/dnscrypt-proxy.toml"; type = types.path; - default = pkgs.runCommand "dnscrypt-proxy.toml" { - json = builtins.toJSON cfg.settings; - passAsFile = [ "json" ]; - } '' - ${if cfg.upstreamDefaults then '' - ${pkgs.buildPackages.remarshal}/bin/toml2json ${pkgs.dnscrypt-proxy.src}/dnscrypt-proxy/example-dnscrypt-proxy.toml > example.json - ${pkgs.buildPackages.jq}/bin/jq --slurp add example.json $jsonPath > config.json # merges the two - '' else '' - cp $jsonPath config.json - ''} - ${pkgs.buildPackages.remarshal}/bin/json2toml < config.json > $out - ''; + default = + pkgs.runCommand "dnscrypt-proxy.toml" + { + json = builtins.toJSON cfg.settings; + passAsFile = [ "json" ]; + } + '' + ${ + if cfg.upstreamDefaults then + '' + ${pkgs.buildPackages.remarshal}/bin/toml2json ${pkgs.dnscrypt-proxy.src}/dnscrypt-proxy/example-dnscrypt-proxy.toml > example.json + ${pkgs.buildPackages.jq}/bin/jq --slurp add example.json $jsonPath > config.json # merges the two + '' + else + '' + cp $jsonPath config.json + '' + } + ${pkgs.buildPackages.remarshal}/bin/json2toml < config.json > $out + ''; defaultText = literalMD "TOML file generated from {option}`services.dnscrypt-proxy2.settings`"; }; }; diff --git a/nixos/modules/services/networking/dnsdist.nix b/nixos/modules/services/networking/dnsdist.nix index cd87abb3d0725d..761dcea67de5df 100644 --- a/nixos/modules/services/networking/dnsdist.nix +++ b/nixos/modules/services/networking/dnsdist.nix @@ -1,8 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.dnsdist; - toLua = lib.generators.toLua {}; + toLua = lib.generators.toLua { }; mkBind = cfg: toLua "${cfg.listenAddress}:${toString cfg.listenPort}"; @@ -74,7 +79,8 @@ let dnscrypt_setup() ''; -in { +in +{ options = { services.dnsdist = { enable = lib.mkEnableOption "dnsdist domain name server"; @@ -161,7 +167,7 @@ in { group = "dnsdist"; }; - users.groups.dnsdist = {}; + users.groups.dnsdist = { }; systemd.packages = [ pkgs.dnsdist ]; @@ -175,8 +181,14 @@ in { RuntimeDirectory = "dnsdist"; StateDirectory = "dnsdist"; # upstream overrides for better nixos compatibility - ExecStartPre = [ "" "${pkgs.dnsdist}/bin/dnsdist --check-config --config ${configFile}" ]; - ExecStart = [ "" "${pkgs.dnsdist}/bin/dnsdist --supervised --disable-syslog --config ${configFile}" ]; + ExecStartPre = [ + "" + "${pkgs.dnsdist}/bin/dnsdist --check-config --config ${configFile}" + ]; + ExecStart = [ + "" + "${pkgs.dnsdist}/bin/dnsdist --supervised --disable-syslog --config ${configFile}" + ]; }; }; }; diff --git a/nixos/modules/services/networking/dnsproxy.nix b/nixos/modules/services/networking/dnsproxy.nix index 80b66743ce9d62..1d1666e0941e38 100644 --- a/nixos/modules/services/networking/dnsproxy.nix +++ b/nixos/modules/services/networking/dnsproxy.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) @@ -11,7 +16,8 @@ let mkIf mkOption mkPackageOption - types; + types + ; cfg = config.services.dnsproxy; @@ -72,7 +78,10 @@ in config = mkIf cfg.enable { systemd.services.dnsproxy = { description = "Simple DNS proxy with DoH, DoT, DoQ and DNSCrypt support"; - after = [ "network.target" "nss-lookup.target" ]; + after = [ + "network.target" + "nss-lookup.target" + ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { ExecStart = "${getExe cfg.package} ${escapeShellArgs finalFlags}"; @@ -89,13 +98,19 @@ in ProtectHostname = true; ProtectKernelLogs = true; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; SystemCallErrorNumber = "EPERM"; - SystemCallFilter = [ "@system-service" "~@privileged @resources" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged @resources" + ]; }; }; }; diff --git a/nixos/modules/services/networking/doh-proxy-rust.nix b/nixos/modules/services/networking/doh-proxy-rust.nix index 32b7a3750480a7..a0ac643f2532fe 100644 --- a/nixos/modules/services/networking/doh-proxy-rust.nix +++ b/nixos/modules/services/networking/doh-proxy-rust.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.doh-proxy-rust; -in { +in +{ options.services.doh-proxy-rust = { @@ -11,7 +17,7 @@ in { flags = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; example = [ "--server-address=9.9.9.9:53" ]; description = '' A list of command-line flags to pass to doh-proxy. For details on the @@ -24,7 +30,10 @@ in { config = lib.mkIf cfg.enable { systemd.services.doh-proxy-rust = { description = "doh-proxy-rust"; - after = [ "network.target" "nss-lookup.target" ]; + after = [ + "network.target" + "nss-lookup.target" + ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { ExecStart = "${pkgs.doh-proxy-rust}/bin/doh-proxy ${lib.escapeShellArgs cfg.flags}"; @@ -47,7 +56,10 @@ in { RestrictSUIDSGID = true; SystemCallArchitectures = "native"; SystemCallErrorNumber = "EPERM"; - SystemCallFilter = [ "@system-service" "~@privileged @resources" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged @resources" + ]; }; }; }; diff --git a/nixos/modules/services/networking/envoy.nix b/nixos/modules/services/networking/envoy.nix index 876c05755936ed..87e84b2031ad05 100644 --- a/nixos/modules/services/networking/envoy.nix +++ b/nixos/modules/services/networking/envoy.nix @@ -1,11 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.envoy; format = pkgs.formats.json { }; conf = format.generate "envoy.json" cfg.settings; - validateConfig = required: file: + validateConfig = + required: file: pkgs.runCommand "validate-envoy-conf" { } '' - ${cfg.package}/bin/envoy --log-level error --mode validate -c "${file}" ${lib.optionalString (!required) "|| true"} + ${cfg.package}/bin/envoy --log-level error --mode validate -c "${file}" ${ + lib.optionalString (!required) "|| true" + } cp "${file}" "$out" ''; in @@ -85,12 +93,22 @@ in ProtectKernelTunables = true; ProtectProc = "ptraceable"; ProtectSystem = "strict"; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" "AF_NETLINK" "AF_XDP" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + "AF_NETLINK" + "AF_XDP" + ]; RestrictNamespaces = true; RestrictRealtime = true; SystemCallArchitectures = "native"; SystemCallErrorNumber = "EPERM"; - SystemCallFilter = [ "@system-service" "~@privileged" "~@resources" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "~@resources" + ]; UMask = "0066"; }; }; diff --git a/nixos/modules/services/networking/epmd.nix b/nixos/modules/services/networking/epmd.nix index 90876a67f74dab..d1794e8c2e26a6 100644 --- a/nixos/modules/services/networking/epmd.nix +++ b/nixos/modules/services/networking/epmd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.epmd; in @@ -15,25 +20,26 @@ in ''; }; package = lib.mkPackageOption pkgs "erlang" { }; - listenStream = lib.mkOption - { - type = lib.types.str; - default = "[::]:4369"; - description = '' - the listenStream used by the systemd socket. - see https://www.freedesktop.org/software/systemd/man/systemd.socket.html#ListenStream= for more information. - use this to change the port epmd will run on. - if not defined, epmd will use "[::]:4369" - ''; - }; + listenStream = lib.mkOption { + type = lib.types.str; + default = "[::]:4369"; + description = '' + the listenStream used by the systemd socket. + see https://www.freedesktop.org/software/systemd/man/systemd.socket.html#ListenStream= for more information. + use this to change the port epmd will run on. + if not defined, epmd will use "[::]:4369" + ''; + }; }; ###### implementation config = lib.mkIf cfg.enable { - assertions = [{ - assertion = cfg.listenStream == "[::]:4369" -> config.networking.enableIPv6; - message = "epmd listens by default on ipv6, enable ipv6 or change config.services.epmd.listenStream"; - }]; + assertions = [ + { + assertion = cfg.listenStream == "[::]:4369" -> config.networking.enableIPv6; + message = "epmd listens by default on ipv6, enable ipv6 or change config.services.epmd.listenStream"; + } + ]; systemd.sockets.epmd = rec { description = "Erlang Port Mapper Daemon Activation Socket"; wantedBy = [ "sockets.target" ]; diff --git a/nixos/modules/services/networking/ergo.nix b/nixos/modules/services/networking/ergo.nix index 7e06b7d76b202d..4bda05a41728ad 100644 --- a/nixos/modules/services/networking/ergo.nix +++ b/nixos/modules/services/networking/ergo.nix @@ -1,34 +1,52 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.ergo; opt = options.services.ergo; - inherit (lib) literalExpression mkEnableOption mkIf mkOption optionalString types; - - configFile = pkgs.writeText "ergo.conf" ('' -ergo { - directory = "${cfg.dataDir}" - node { - mining = false - } - wallet.secretStorage.secretDir = "${cfg.dataDir}/wallet/keystore" -} - -scorex { - network { - bindAddress = "${cfg.listen.ip}:${toString cfg.listen.port}" - } -'' + optionalString (cfg.api.keyHash != null) '' - restApi { - apiKeyHash = "${cfg.api.keyHash}" - bindAddress = "${cfg.api.listen.ip}:${toString cfg.api.listen.port}" - } -'' + '' -} -''); - -in { + inherit (lib) + literalExpression + mkEnableOption + mkIf + mkOption + optionalString + types + ; + + configFile = pkgs.writeText "ergo.conf" ( + '' + ergo { + directory = "${cfg.dataDir}" + node { + mining = false + } + wallet.secretStorage.secretDir = "${cfg.dataDir}/wallet/keystore" + } + + scorex { + network { + bindAddress = "${cfg.listen.ip}:${toString cfg.listen.port}" + } + '' + + optionalString (cfg.api.keyHash != null) '' + restApi { + apiKeyHash = "${cfg.api.keyHash}" + bindAddress = "${cfg.api.listen.ip}:${toString cfg.api.listen.port}" + } + '' + + '' + } + '' + ); + +in +{ options = { @@ -56,32 +74,32 @@ in { }; api = { - keyHash = mkOption { - type = types.nullOr types.str; - default = null; - example = "324dcf027dd4a30a932c441f365a25e86b173defa4b8e58948253471b81b72cf"; - description = "Hex-encoded Blake2b256 hash of an API key as a 64-chars long Base16 string."; - }; - - listen = { - ip = mkOption { - type = types.str; - default = "0.0.0.0"; - description = "IP address that the Ergo node API should listen on if {option}`api.keyHash` is defined."; + keyHash = mkOption { + type = types.nullOr types.str; + default = null; + example = "324dcf027dd4a30a932c441f365a25e86b173defa4b8e58948253471b81b72cf"; + description = "Hex-encoded Blake2b256 hash of an API key as a 64-chars long Base16 string."; + }; + + listen = { + ip = mkOption { + type = types.str; + default = "0.0.0.0"; + description = "IP address that the Ergo node API should listen on if {option}`api.keyHash` is defined."; }; - port = mkOption { - type = types.port; - default = 9052; - description = "Listen port for the API endpoint if {option}`api.keyHash` is defined."; + port = mkOption { + type = types.port; + default = 9052; + description = "Listen port for the API endpoint if {option}`api.keyHash` is defined."; + }; }; - }; }; testnet = mkOption { - type = types.bool; - default = false; - description = "Connect to testnet network instead of the default mainnet."; + type = types.bool; + default = false; + description = "Connect to testnet network instead of the default mainnet."; }; user = mkOption { @@ -119,10 +137,10 @@ in { serviceConfig = { User = cfg.user; Group = cfg.group; - ExecStart = ''${pkgs.ergo}/bin/ergo \ - ${optionalString (!cfg.testnet) - "--mainnet"} \ - -c ${configFile}''; + ExecStart = '' + ${pkgs.ergo}/bin/ergo \ + ${optionalString (!cfg.testnet) "--mainnet"} \ + -c ${configFile}''; }; }; @@ -138,7 +156,7 @@ in { isSystemUser = true; }; - users.groups.${cfg.group} = {}; + users.groups.${cfg.group} = { }; }; } diff --git a/nixos/modules/services/networking/ergochat.nix b/nixos/modules/services/networking/ergochat.nix index b4b4e488fc1153..0ad9a2c41c75cc 100644 --- a/nixos/modules/services/networking/ergochat.nix +++ b/nixos/modules/services/networking/ergochat.nix @@ -1,6 +1,14 @@ -{ config, lib, options, pkgs, ... }: let +{ + config, + lib, + options, + pkgs, + ... +}: +let cfg = config.services.ergochat; -in { +in +{ options = { services.ergochat = { @@ -16,7 +24,7 @@ in { configFile = lib.mkOption { type = lib.types.path; - default = (pkgs.formats.yaml {}).generate "ergo.conf" cfg.settings; + default = (pkgs.formats.yaml { }).generate "ergo.conf" cfg.settings; defaultText = lib.literalMD "generated config file from `settings`"; description = '' Path to configuration file. @@ -25,7 +33,7 @@ in { }; settings = lib.mkOption { - type = (pkgs.formats.yaml {}).type; + type = (pkgs.formats.yaml { }).type; description = '' Ergo IRC daemon configuration file. https://raw.githubusercontent.com/ergochat/ergo/master/default.yaml @@ -37,7 +45,7 @@ in { server = { name = "example.com"; listeners = { - ":6667" = {}; + ":6667" = { }; }; casemapping = "permissive"; enforce-utf = true; @@ -130,8 +138,9 @@ in { environment.etc."ergo.yaml".source = cfg.configFile; # merge configured values with default values - services.ergochat.settings = - lib.mapAttrsRecursive (_: lib.mkDefault) options.services.ergochat.settings.default; + services.ergochat.settings = lib.mapAttrsRecursive ( + _: lib.mkDefault + ) options.services.ergochat.settings.default; systemd.services.ergochat = { description = "Ergo IRC daemon"; @@ -151,5 +160,8 @@ in { }; }; - meta.maintainers = with lib.maintainers; [ lassulus tv ]; + meta.maintainers = with lib.maintainers; [ + lassulus + tv + ]; } diff --git a/nixos/modules/services/networking/eternal-terminal.nix b/nixos/modules/services/networking/eternal-terminal.nix index 584eafd2962cf3..0c1a339929bd49 100644 --- a/nixos/modules/services/networking/eternal-terminal.nix +++ b/nixos/modules/services/networking/eternal-terminal.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.eternal-terminal; diff --git a/nixos/modules/services/networking/expressvpn.nix b/nixos/modules/services/networking/expressvpn.nix index 431a1da70b955a..d78f20effb5ed1 100644 --- a/nixos/modules/services/networking/expressvpn.nix +++ b/nixos/modules/services/networking/expressvpn.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { options.services.expressvpn.enable = lib.mkOption { type = lib.types.bool; @@ -20,7 +25,10 @@ }; wantedBy = [ "multi-user.target" ]; wants = [ "network-online.target" ]; - after = [ "network.target" "network-online.target" ]; + after = [ + "network.target" + "network-online.target" + ]; }; }; diff --git a/nixos/modules/services/networking/fakeroute.nix b/nixos/modules/services/networking/fakeroute.nix index c832a33ffedd77..a877a0d7d211e8 100644 --- a/nixos/modules/services/networking/fakeroute.nix +++ b/nixos/modules/services/networking/fakeroute.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.fakeroute; @@ -18,7 +23,7 @@ in route = lib.mkOption { type = with lib.types; listOf str; - default = []; + default = [ ]; example = [ "216.102.187.130" "4.0.1.122" @@ -26,8 +31,8 @@ in "63.199.8.242" ]; description = '' - Fake route that will appear after the real - one to any host running a traceroute. + Fake route that will appear after the real + one to any host running a traceroute. ''; }; @@ -35,7 +40,6 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/networking/fastnetmon-advanced.nix b/nixos/modules/services/networking/fastnetmon-advanced.nix index d534c7fbc0585d..c57b5a6b660037 100644 --- a/nixos/modules/services/networking/fastnetmon-advanced.nix +++ b/nixos/modules/services/networking/fastnetmon-advanced.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let # Background information: FastNetMon requires a MongoDB to start. This is because @@ -12,47 +17,56 @@ let settingsFormat = pkgs.formats.yaml { }; # obtain the default configs by starting up ferretdb and fcli in a derivation - default_configs = pkgs.runCommand "default-configs" { - nativeBuildInputs = [ - pkgs.ferretdb - pkgs.fastnetmon-advanced # for fcli - pkgs.proot - ]; - } '' - mkdir ferretdb fastnetmon $out - FERRETDB_TELEMETRY="disable" FERRETDB_HANDLER="sqlite" FERRETDB_STATE_DIR="$PWD/ferretdb" FERRETDB_SQLITE_URL="file:$PWD/ferretdb/" ferretdb & - - cat << EOF > fastnetmon/fastnetmon.conf - ${builtins.toJSON { - mongodb_username = ""; - }} - EOF - proot -b fastnetmon:/etc/fastnetmon -0 fcli create_configuration - proot -b fastnetmon:/etc/fastnetmon -0 fcli set bgp default - proot -b fastnetmon:/etc/fastnetmon -0 fcli export_configuration backup.tar - tar -C $out --no-same-owner -xvf backup.tar - ''; + default_configs = + pkgs.runCommand "default-configs" + { + nativeBuildInputs = [ + pkgs.ferretdb + pkgs.fastnetmon-advanced # for fcli + pkgs.proot + ]; + } + '' + mkdir ferretdb fastnetmon $out + FERRETDB_TELEMETRY="disable" FERRETDB_HANDLER="sqlite" FERRETDB_STATE_DIR="$PWD/ferretdb" FERRETDB_SQLITE_URL="file:$PWD/ferretdb/" ferretdb & + + cat << EOF > fastnetmon/fastnetmon.conf + ${builtins.toJSON { + mongodb_username = ""; + }} + EOF + proot -b fastnetmon:/etc/fastnetmon -0 fcli create_configuration + proot -b fastnetmon:/etc/fastnetmon -0 fcli set bgp default + proot -b fastnetmon:/etc/fastnetmon -0 fcli export_configuration backup.tar + tar -C $out --no-same-owner -xvf backup.tar + ''; # merge the user configs into the default configs - config_tar = pkgs.runCommand "fastnetmon-config.tar" { - nativeBuildInputs = with pkgs; [ jq ]; - } '' - jq -s add ${default_configs}/main.json ${pkgs.writeText "main-add.json" (builtins.toJSON cfg.settings)} > main.json - mkdir hostgroup - ${lib.concatImapStringsSep "\n" (pos: hostgroup: '' - jq -s add ${default_configs}/hostgroup/0.json ${pkgs.writeText "hostgroup-${toString (pos - 1)}-add.json" (builtins.toJSON hostgroup)} > hostgroup/${toString (pos - 1)}.json - '') hostgroups} - mkdir bgp - ${lib.concatImapStringsSep "\n" (pos: bgp: '' - jq -s add ${default_configs}/bgp/0.json ${pkgs.writeText "bgp-${toString (pos - 1)}-add.json" (builtins.toJSON bgp)} > bgp/${toString (pos - 1)}.json - '') bgpPeers} - tar -cf $out main.json ${lib.concatImapStringsSep " " (pos: _: "hostgroup/${toString (pos - 1)}.json") hostgroups} ${lib.concatImapStringsSep " " (pos: _: "bgp/${toString (pos - 1)}.json") bgpPeers} - ''; + config_tar = + pkgs.runCommand "fastnetmon-config.tar" + { + nativeBuildInputs = with pkgs; [ jq ]; + } + '' + jq -s add ${default_configs}/main.json ${pkgs.writeText "main-add.json" (builtins.toJSON cfg.settings)} > main.json + mkdir hostgroup + ${lib.concatImapStringsSep "\n" (pos: hostgroup: '' + jq -s add ${default_configs}/hostgroup/0.json ${pkgs.writeText "hostgroup-${toString (pos - 1)}-add.json" (builtins.toJSON hostgroup)} > hostgroup/${toString (pos - 1)}.json + '') hostgroups} + mkdir bgp + ${lib.concatImapStringsSep "\n" (pos: bgp: '' + jq -s add ${default_configs}/bgp/0.json ${pkgs.writeText "bgp-${toString (pos - 1)}-add.json" (builtins.toJSON bgp)} > bgp/${toString (pos - 1)}.json + '') bgpPeers} + tar -cf $out main.json ${ + lib.concatImapStringsSep " " (pos: _: "hostgroup/${toString (pos - 1)}.json") hostgroups + } ${lib.concatImapStringsSep " " (pos: _: "bgp/${toString (pos - 1)}.json") bgpPeers} + ''; hostgroups = lib.mapAttrsToList (name: hostgroup: { inherit name; } // hostgroup) cfg.hostgroups; bgpPeers = lib.mapAttrsToList (name: bgpPeer: { inherit name; } // bgpPeer) cfg.bgpPeers; -in { +in +{ options.services.fastnetmon-advanced = with lib; { enable = mkEnableOption "the fastnetmon-advanced DDoS Protection daemon"; @@ -63,7 +77,7 @@ in { See the [FastNetMon Advanced Configuration options reference](https://fastnetmon.com/docs-fnm-advanced/fastnetmon-advanced-configuration-options/) for more details. ''; type = settingsFormat.type; - default = {}; + default = { }; example = literalExpression '' { networks_list = [ "192.0.2.0/24" ]; @@ -75,12 +89,12 @@ in { hostgroups = mkOption { description = "Hostgroups to declaratively load into FastNetMon Advanced"; type = types.attrsOf settingsFormat.type; - default = {}; + default = { }; }; bgpPeers = mkOption { description = "BGP Peers to declaratively load into FastNetMon Advanced"; type = types.attrsOf settingsFormat.type; - default = {}; + default = { }; }; enableAdvancedTrafficPersistence = mkOption { @@ -95,130 +109,141 @@ in { }; }; - config = lib.mkMerge [ (lib.mkIf cfg.enable { - environment.systemPackages = with pkgs; [ - fastnetmon-advanced # for fcli - ]; - - environment.etc."fastnetmon/license.lic".source = "/var/lib/fastnetmon/license.lic"; - environment.etc."fastnetmon/gobgpd.conf".source = "/run/fastnetmon/gobgpd.conf"; - environment.etc."fastnetmon/fastnetmon.conf".source = pkgs.writeText "fastnetmon.conf" (builtins.toJSON { - mongodb_username = ""; - }); - - services.ferretdb.enable = true; - - systemd.services.fastnetmon-setup = { - wantedBy = [ "multi-user.target" ]; - after = [ "ferretdb.service" ]; - path = with pkgs; [ fastnetmon-advanced config.systemd.package ]; - script = '' - fcli create_configuration - fcli delete hostgroup global - fcli import_configuration ${config_tar} - systemctl --no-block try-restart fastnetmon - ''; - serviceConfig.Type = "oneshot"; - }; - - systemd.services.fastnetmon = { - wantedBy = [ "multi-user.target" ]; - after = [ "ferretdb.service" "fastnetmon-setup.service" "polkit.service" ]; - path = with pkgs; [ iproute2 ]; - unitConfig = { - # Disable logic which shuts service when we do too many restarts - # We do restarts from sudo fcli commit and it's expected that we may have many restarts - # Details: https://github.com/systemd/systemd/issues/2416 - StartLimitInterval = 0; + config = lib.mkMerge [ + (lib.mkIf cfg.enable { + environment.systemPackages = with pkgs; [ + fastnetmon-advanced # for fcli + ]; + + environment.etc."fastnetmon/license.lic".source = "/var/lib/fastnetmon/license.lic"; + environment.etc."fastnetmon/gobgpd.conf".source = "/run/fastnetmon/gobgpd.conf"; + environment.etc."fastnetmon/fastnetmon.conf".source = pkgs.writeText "fastnetmon.conf" ( + builtins.toJSON { + mongodb_username = ""; + } + ); + + services.ferretdb.enable = true; + + systemd.services.fastnetmon-setup = { + wantedBy = [ "multi-user.target" ]; + after = [ "ferretdb.service" ]; + path = with pkgs; [ + fastnetmon-advanced + config.systemd.package + ]; + script = '' + fcli create_configuration + fcli delete hostgroup global + fcli import_configuration ${config_tar} + systemctl --no-block try-restart fastnetmon + ''; + serviceConfig.Type = "oneshot"; }; - serviceConfig = { - ExecStart = "${pkgs.fastnetmon-advanced}/bin/fastnetmon --log_to_console"; - - LimitNOFILE = 65535; - # Restart service when it fails due to any reasons, we need to keep processing traffic no matter what happened - Restart= "on-failure"; - RestartSec= "5s"; - - DynamicUser = true; - CacheDirectory = "fastnetmon"; - RuntimeDirectory = "fastnetmon"; # for gobgpd config - StateDirectory = "fastnetmon"; # for license file + + systemd.services.fastnetmon = { + wantedBy = [ "multi-user.target" ]; + after = [ + "ferretdb.service" + "fastnetmon-setup.service" + "polkit.service" + ]; + path = with pkgs; [ iproute2 ]; + unitConfig = { + # Disable logic which shuts service when we do too many restarts + # We do restarts from sudo fcli commit and it's expected that we may have many restarts + # Details: https://github.com/systemd/systemd/issues/2416 + StartLimitInterval = 0; + }; + serviceConfig = { + ExecStart = "${pkgs.fastnetmon-advanced}/bin/fastnetmon --log_to_console"; + + LimitNOFILE = 65535; + # Restart service when it fails due to any reasons, we need to keep processing traffic no matter what happened + Restart = "on-failure"; + RestartSec = "5s"; + + DynamicUser = true; + CacheDirectory = "fastnetmon"; + RuntimeDirectory = "fastnetmon"; # for gobgpd config + StateDirectory = "fastnetmon"; # for license file + }; }; - }; - security.polkit.enable = true; - security.polkit.extraConfig = '' - polkit.addRule(function(action, subject) { - if (action.id == "org.freedesktop.systemd1.manage-units" && - subject.isInGroup("fastnetmon")) { - if (action.lookup("unit") == "gobgp.service") { - var verb = action.lookup("verb"); - if (verb == "start" || verb == "stop" || verb == "restart") { - return polkit.Result.YES; + security.polkit.enable = true; + security.polkit.extraConfig = '' + polkit.addRule(function(action, subject) { + if (action.id == "org.freedesktop.systemd1.manage-units" && + subject.isInGroup("fastnetmon")) { + if (action.lookup("unit") == "gobgp.service") { + var verb = action.lookup("verb"); + if (verb == "start" || verb == "stop" || verb == "restart") { + return polkit.Result.YES; + } } } - } - }); - ''; - # dbus/polkit with DynamicUser is broken with the default implementation - services.dbus.implementation = "broker"; - - # We don't use the existing gobgp NixOS module and package, because the gobgp - # version might not be compatible with fastnetmon. Also, the service name - # _must_ be 'gobgp' and not 'gobgpd', so that fastnetmon can reload the config. - systemd.services.gobgp = { - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - description = "GoBGP Routing Daemon"; - unitConfig = { - ConditionPathExists = "/run/fastnetmon/gobgpd.conf"; - }; - serviceConfig = { - Type = "notify"; - ExecStartPre = "${pkgs.fastnetmon-advanced}/bin/fnm-gobgpd -f /run/fastnetmon/gobgpd.conf -d"; - SupplementaryGroups = [ "fastnetmon" ]; - ExecStart = "${pkgs.fastnetmon-advanced}/bin/fnm-gobgpd -f /run/fastnetmon/gobgpd.conf --sdnotify"; - ExecReload = "${pkgs.fastnetmon-advanced}/bin/fnm-gobgpd -r"; - DynamicUser = true; - AmbientCapabilities = "cap_net_bind_service"; + }); + ''; + # dbus/polkit with DynamicUser is broken with the default implementation + services.dbus.implementation = "broker"; + + # We don't use the existing gobgp NixOS module and package, because the gobgp + # version might not be compatible with fastnetmon. Also, the service name + # _must_ be 'gobgp' and not 'gobgpd', so that fastnetmon can reload the config. + systemd.services.gobgp = { + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + description = "GoBGP Routing Daemon"; + unitConfig = { + ConditionPathExists = "/run/fastnetmon/gobgpd.conf"; + }; + serviceConfig = { + Type = "notify"; + ExecStartPre = "${pkgs.fastnetmon-advanced}/bin/fnm-gobgpd -f /run/fastnetmon/gobgpd.conf -d"; + SupplementaryGroups = [ "fastnetmon" ]; + ExecStart = "${pkgs.fastnetmon-advanced}/bin/fnm-gobgpd -f /run/fastnetmon/gobgpd.conf --sdnotify"; + ExecReload = "${pkgs.fastnetmon-advanced}/bin/fnm-gobgpd -r"; + DynamicUser = true; + AmbientCapabilities = "cap_net_bind_service"; + }; }; - }; - }) + }) - (lib.mkIf (cfg.enable && cfg.enableAdvancedTrafficPersistence) { - ## Advanced Traffic persistence - ## https://fastnetmon.com/docs-fnm-advanced/fastnetmon-advanced-traffic-persistency/ + (lib.mkIf (cfg.enable && cfg.enableAdvancedTrafficPersistence) { + ## Advanced Traffic persistence + ## https://fastnetmon.com/docs-fnm-advanced/fastnetmon-advanced-traffic-persistency/ - services.clickhouse.enable = true; + services.clickhouse.enable = true; - services.fastnetmon-advanced.settings.traffic_db = true; + services.fastnetmon-advanced.settings.traffic_db = true; - services.fastnetmon-advanced.traffic_db.settings = { - clickhouse_batch_size = lib.mkDefault 1000; - clickhouse_batch_delay = lib.mkDefault 1; - traffic_db_host = lib.mkDefault "127.0.0.1"; - traffic_db_port = lib.mkDefault 8100; - clickhouse_host = lib.mkDefault "127.0.0.1"; - clickhouse_port = lib.mkDefault 9000; - clickhouse_user = lib.mkDefault "default"; - clickhouse_password = lib.mkDefault ""; - }; - environment.etc."fastnetmon/traffic_db.conf".text = builtins.toJSON cfg.traffic_db.settings; - - systemd.services.traffic_db = { - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - serviceConfig = { - ExecStart = "${pkgs.fastnetmon-advanced}/bin/traffic_db"; - # Restart service when it fails due to any reasons, we need to keep processing traffic no matter what happened - Restart= "on-failure"; - RestartSec= "5s"; - - DynamicUser = true; + services.fastnetmon-advanced.traffic_db.settings = { + clickhouse_batch_size = lib.mkDefault 1000; + clickhouse_batch_delay = lib.mkDefault 1; + traffic_db_host = lib.mkDefault "127.0.0.1"; + traffic_db_port = lib.mkDefault 8100; + clickhouse_host = lib.mkDefault "127.0.0.1"; + clickhouse_port = lib.mkDefault 9000; + clickhouse_user = lib.mkDefault "default"; + clickhouse_password = lib.mkDefault ""; + }; + environment.etc."fastnetmon/traffic_db.conf".text = builtins.toJSON cfg.traffic_db.settings; + + systemd.services.traffic_db = { + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + serviceConfig = { + ExecStart = "${pkgs.fastnetmon-advanced}/bin/traffic_db"; + # Restart service when it fails due to any reasons, we need to keep processing traffic no matter what happened + Restart = "on-failure"; + RestartSec = "5s"; + + DynamicUser = true; + }; }; - }; - }) ]; + }) + ]; meta.maintainers = lib.teams.wdz.members; } diff --git a/nixos/modules/services/networking/ferm.nix b/nixos/modules/services/networking/ferm.nix index 1fc982d8e9c8e8..f107d5b1f30476 100644 --- a/nixos/modules/services/networking/ferm.nix +++ b/nixos/modules/services/networking/ferm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.ferm; @@ -11,7 +16,8 @@ let ${cfg.package}/bin/ferm --noexec $out ''; }; -in { +in +{ options = { services.ferm = { enable = lib.mkOption { @@ -44,7 +50,7 @@ in { wantedBy = [ "multi-user.target" ]; reloadIfChanged = true; serviceConfig = { - Type="oneshot"; + Type = "oneshot"; RemainAfterExit = "yes"; ExecStart = "${cfg.package}/bin/ferm ${configFile}"; ExecReload = "${cfg.package}/bin/ferm ${configFile}"; diff --git a/nixos/modules/services/networking/firefox-syncserver.nix b/nixos/modules/services/networking/firefox-syncserver.nix index 2f706c3bc3f982..352faed492dc36 100644 --- a/nixos/modules/services/networking/firefox-syncserver.nix +++ b/nixos/modules/services/networking/firefox-syncserver.nix @@ -1,4 +1,10 @@ -{ config, pkgs, lib, options, ... }: +{ + config, + pkgs, + lib, + options, + ... +}: let cfg = config.services.firefox-syncserver; @@ -9,69 +15,71 @@ let dbIsLocal = cfg.database.host == "localhost"; dbURL = "mysql://${cfg.database.user}@${cfg.database.host}/${cfg.database.name}"; - format = pkgs.formats.toml {}; + format = pkgs.formats.toml { }; settings = { human_logs = true; syncstorage = { database_url = dbURL; }; - tokenserver = { - node_type = "mysql"; - database_url = dbURL; - fxa_email_domain = "api.accounts.firefox.com"; - fxa_oauth_server_url = "https://oauth.accounts.firefox.com/v1"; - run_migrations = true; - # if JWK caching is not enabled the token server must verify tokens - # using the fxa api, on a thread pool with a static size. - additional_blocking_threads_for_fxa_requests = 10; - } // lib.optionalAttrs cfg.singleNode.enable { - # Single-node mode is likely to be used on small instances with little - # capacity. The default value (0.1) can only ever release capacity when - # accounts are removed if the total capacity is 10 or larger to begin - # with. - # https://github.com/mozilla-services/syncstorage-rs/issues/1313#issuecomment-1145293375 - node_capacity_release_rate = 1; - }; + tokenserver = + { + node_type = "mysql"; + database_url = dbURL; + fxa_email_domain = "api.accounts.firefox.com"; + fxa_oauth_server_url = "https://oauth.accounts.firefox.com/v1"; + run_migrations = true; + # if JWK caching is not enabled the token server must verify tokens + # using the fxa api, on a thread pool with a static size. + additional_blocking_threads_for_fxa_requests = 10; + } + // lib.optionalAttrs cfg.singleNode.enable { + # Single-node mode is likely to be used on small instances with little + # capacity. The default value (0.1) can only ever release capacity when + # accounts are removed if the total capacity is 10 or larger to begin + # with. + # https://github.com/mozilla-services/syncstorage-rs/issues/1313#issuecomment-1145293375 + node_capacity_release_rate = 1; + }; }; configFile = format.generate "syncstorage.toml" (lib.recursiveUpdate settings cfg.settings); setupScript = pkgs.writeShellScript "firefox-syncserver-setup" '' - set -euo pipefail - shopt -s inherit_errexit - - schema_configured() { - mysql ${cfg.database.name} -Ne 'SHOW TABLES' | grep -q services - } - - update_config() { - mysql ${cfg.database.name} <<"EOF" - BEGIN; - - INSERT INTO `services` (`id`, `service`, `pattern`) - VALUES (1, 'sync-1.5', '{node}/1.5/{uid}') - ON DUPLICATE KEY UPDATE service='sync-1.5', pattern='{node}/1.5/{uid}'; - INSERT INTO `nodes` (`id`, `service`, `node`, `available`, `current_load`, - `capacity`, `downed`, `backoff`) - VALUES (1, 1, '${cfg.singleNode.url}', ${toString cfg.singleNode.capacity}, - 0, ${toString cfg.singleNode.capacity}, 0, 0) - ON DUPLICATE KEY UPDATE node = '${cfg.singleNode.url}', capacity=${toString cfg.singleNode.capacity}; - - COMMIT; - EOF - } - - - for (( try = 0; try < 60; try++ )); do - if ! schema_configured; then - sleep 2 - else - update_config - exit 0 - fi - done - - echo "Single-node setup failed" - exit 1 - ''; + set -euo pipefail + shopt -s inherit_errexit + + schema_configured() { + mysql ${cfg.database.name} -Ne 'SHOW TABLES' | grep -q services + } + + update_config() { + mysql ${cfg.database.name} <<"EOF" + BEGIN; + + INSERT INTO `services` (`id`, `service`, `pattern`) + VALUES (1, 'sync-1.5', '{node}/1.5/{uid}') + ON DUPLICATE KEY UPDATE service='sync-1.5', pattern='{node}/1.5/{uid}'; + INSERT INTO `nodes` (`id`, `service`, `node`, `available`, `current_load`, + `capacity`, `downed`, `backoff`) + VALUES (1, 1, '${cfg.singleNode.url}', ${toString cfg.singleNode.capacity}, + 0, ${toString cfg.singleNode.capacity}, 0, 0) + ON DUPLICATE KEY UPDATE node = '${cfg.singleNode.url}', capacity=${toString cfg.singleNode.capacity}; + + COMMIT; + EOF + } + + + for (( try = 0; try < 60; try++ )); do + if ! schema_configured; then + sleep 2 + else + update_config + exit 0 + fi + done + + echo "Single-node setup failed" + exit 1 + ''; in { @@ -240,12 +248,14 @@ in services.mysql = lib.mkIf cfg.database.createLocally { enable = true; ensureDatabases = [ cfg.database.name ]; - ensureUsers = [{ - name = cfg.database.user; - ensurePermissions = { - "${cfg.database.name}.*" = "all privileges"; - }; - }]; + ensureUsers = [ + { + name = cfg.database.user; + ensurePermissions = { + "${cfg.database.name}.*" = "all privileges"; + }; + } + ]; }; systemd.services.firefox-syncserver = { @@ -279,7 +289,11 @@ in ProtectHostname = true; LockPersonality = true; ProtectKernelTunables = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; RestrictRealtime = true; ProtectSystem = "strict"; ProtectProc = "invisible"; @@ -287,7 +301,10 @@ in ProtectHome = true; PrivateUsers = true; PrivateTmp = true; - SystemCallFilter = [ "@system-service" "~ @privileged @resources" ]; + SystemCallFilter = [ + "@system-service" + "~ @privileged @resources" + ]; UMask = "0077"; }; }; diff --git a/nixos/modules/services/networking/firewall-iptables.nix b/nixos/modules/services/networking/firewall-iptables.nix index 086106f0d8d2b6..53d7d3434daee5 100644 --- a/nixos/modules/services/networking/firewall-iptables.nix +++ b/nixos/modules/services/networking/firewall-iptables.nix @@ -1,46 +1,54 @@ -/* This module enables a simple firewall. - - The firewall can be customised in arbitrary ways by setting - ‘networking.firewall.extraCommands’. For modularity, the firewall - uses several chains: - - - ‘nixos-fw’ is the main chain for input packet processing. - - - ‘nixos-fw-accept’ is called for accepted packets. If you want - additional logging, or want to reject certain packets anyway, you - can insert rules at the start of this chain. - - - ‘nixos-fw-log-refuse’ and ‘nixos-fw-refuse’ are called for - refused packets. (The former jumps to the latter after logging - the packet.) If you want additional logging, or want to accept - certain packets anyway, you can insert rules at the start of - this chain. - - - ‘nixos-fw-rpfilter’ is used as the main chain in the mangle table, - called from the built-in ‘PREROUTING’ chain. If the kernel - supports it and `cfg.checkReversePath` is set this chain will - perform a reverse path filter test. - - - ‘nixos-drop’ is used while reloading the firewall in order to drop - all traffic. Since reloading isn't implemented in an atomic way - this'll prevent any traffic from leaking through while reloading - the firewall. However, if the reloading fails, the ‘firewall-stop’ - script will be called which in return will effectively disable the - complete firewall (in the default configuration). - +/* + This module enables a simple firewall. + + The firewall can be customised in arbitrary ways by setting + ‘networking.firewall.extraCommands’. For modularity, the firewall + uses several chains: + + - ‘nixos-fw’ is the main chain for input packet processing. + + - ‘nixos-fw-accept’ is called for accepted packets. If you want + additional logging, or want to reject certain packets anyway, you + can insert rules at the start of this chain. + + - ‘nixos-fw-log-refuse’ and ‘nixos-fw-refuse’ are called for + refused packets. (The former jumps to the latter after logging + the packet.) If you want additional logging, or want to accept + certain packets anyway, you can insert rules at the start of + this chain. + + - ‘nixos-fw-rpfilter’ is used as the main chain in the mangle table, + called from the built-in ‘PREROUTING’ chain. If the kernel + supports it and `cfg.checkReversePath` is set this chain will + perform a reverse path filter test. + + - ‘nixos-drop’ is used while reloading the firewall in order to drop + all traffic. Since reloading isn't implemented in an atomic way + this'll prevent any traffic from leaking through while reloading + the firewall. However, if the reloading fails, the ‘firewall-stop’ + script will be called which in return will effectively disable the + complete firewall (in the default configuration). */ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.networking.firewall; inherit (config.boot.kernelPackages) kernel; - kernelHasRPFilter = ((kernel.config.isEnabled or (x: false)) "IP_NF_MATCH_RPFILTER") || (kernel.features.netfilterRPFilter or false); + kernelHasRPFilter = + ((kernel.config.isEnabled or (x: false)) "IP_NF_MATCH_RPFILTER") + || (kernel.features.netfilterRPFilter or false); helpers = import ./helpers.nix { inherit config lib; }; - writeShScript = name: text: + writeShScript = + name: text: let dir = pkgs.writeScriptBin name '' #! ${pkgs.runtimeShell} -e @@ -70,15 +78,20 @@ let # The "nixos-fw-refuse" chain rejects or drops packets. ip46tables -N nixos-fw-refuse - ${if cfg.rejectPackets then '' - # Send a reset for existing TCP connections that we've - # somehow forgotten about. Send ICMP "port unreachable" - # for everything else. - ip46tables -A nixos-fw-refuse -p tcp ! --syn -j REJECT --reject-with tcp-reset - ip46tables -A nixos-fw-refuse -j REJECT - '' else '' - ip46tables -A nixos-fw-refuse -j DROP - ''} + ${ + if cfg.rejectPackets then + '' + # Send a reset for existing TCP connections that we've + # somehow forgotten about. Send ICMP "port unreachable" + # for everything else. + ip46tables -A nixos-fw-refuse -p tcp ! --syn -j REJECT --reject-with tcp-reset + ip46tables -A nixos-fw-refuse -j REJECT + '' + else + '' + ip46tables -A nixos-fw-refuse -j DROP + '' + } # The "nixos-fw-log-refuse" chain performs logging, then @@ -114,7 +127,9 @@ let # Perform a reverse-path test to refuse spoofers # For now, we just drop, as the mangle table doesn't have a log-refuse yet ip46tables -t mangle -N nixos-fw-rpfilter 2> /dev/null || true - ip46tables -t mangle -A nixos-fw-rpfilter -m rpfilter --validmark ${lib.optionalString (cfg.checkReversePath == "loose") "--loose"} -j RETURN + ip46tables -t mangle -A nixos-fw-rpfilter -m rpfilter --validmark ${ + lib.optionalString (cfg.checkReversePath == "loose") "--loose" + } -j RETURN # Allows this host to act as a DHCP4 client without first having to use APIPA iptables -t mangle -A nixos-fw-rpfilter -p udp --sport 67 --dport 68 -j RETURN @@ -139,47 +154,69 @@ let ip46tables -A nixos-fw -m conntrack --ctstate ESTABLISHED,RELATED -j nixos-fw-accept # Accept connections to the allowed TCP ports. - ${lib.concatStrings (lib.mapAttrsToList (iface: cfg: - lib.concatMapStrings (port: - '' - ip46tables -A nixos-fw -p tcp --dport ${toString port} -j nixos-fw-accept ${lib.optionalString (iface != "default") "-i ${iface}"} - '' - ) cfg.allowedTCPPorts - ) cfg.allInterfaces)} + ${lib.concatStrings ( + lib.mapAttrsToList ( + iface: cfg: + lib.concatMapStrings (port: '' + ip46tables -A nixos-fw -p tcp --dport ${toString port} -j nixos-fw-accept ${ + lib.optionalString (iface != "default") "-i ${iface}" + } + '') cfg.allowedTCPPorts + ) cfg.allInterfaces + )} # Accept connections to the allowed TCP port ranges. - ${lib.concatStrings (lib.mapAttrsToList (iface: cfg: - lib.concatMapStrings (rangeAttr: - let range = toString rangeAttr.from + ":" + toString rangeAttr.to; in - '' - ip46tables -A nixos-fw -p tcp --dport ${range} -j nixos-fw-accept ${lib.optionalString (iface != "default") "-i ${iface}"} - '' - ) cfg.allowedTCPPortRanges - ) cfg.allInterfaces)} + ${lib.concatStrings ( + lib.mapAttrsToList ( + iface: cfg: + lib.concatMapStrings ( + rangeAttr: + let + range = toString rangeAttr.from + ":" + toString rangeAttr.to; + in + '' + ip46tables -A nixos-fw -p tcp --dport ${range} -j nixos-fw-accept ${ + lib.optionalString (iface != "default") "-i ${iface}" + } + '' + ) cfg.allowedTCPPortRanges + ) cfg.allInterfaces + )} # Accept packets on the allowed UDP ports. - ${lib.concatStrings (lib.mapAttrsToList (iface: cfg: - lib.concatMapStrings (port: - '' - ip46tables -A nixos-fw -p udp --dport ${toString port} -j nixos-fw-accept ${lib.optionalString (iface != "default") "-i ${iface}"} - '' - ) cfg.allowedUDPPorts - ) cfg.allInterfaces)} + ${lib.concatStrings ( + lib.mapAttrsToList ( + iface: cfg: + lib.concatMapStrings (port: '' + ip46tables -A nixos-fw -p udp --dport ${toString port} -j nixos-fw-accept ${ + lib.optionalString (iface != "default") "-i ${iface}" + } + '') cfg.allowedUDPPorts + ) cfg.allInterfaces + )} # Accept packets on the allowed UDP port ranges. - ${lib.concatStrings (lib.mapAttrsToList (iface: cfg: - lib.concatMapStrings (rangeAttr: - let range = toString rangeAttr.from + ":" + toString rangeAttr.to; in - '' - ip46tables -A nixos-fw -p udp --dport ${range} -j nixos-fw-accept ${lib.optionalString (iface != "default") "-i ${iface}"} - '' - ) cfg.allowedUDPPortRanges - ) cfg.allInterfaces)} + ${lib.concatStrings ( + lib.mapAttrsToList ( + iface: cfg: + lib.concatMapStrings ( + rangeAttr: + let + range = toString rangeAttr.from + ":" + toString rangeAttr.to; + in + '' + ip46tables -A nixos-fw -p udp --dport ${range} -j nixos-fw-accept ${ + lib.optionalString (iface != "default") "-i ${iface}" + } + '' + ) cfg.allowedUDPPortRanges + ) cfg.allInterfaces + )} # Optionally respond to ICMPv4 pings. ${lib.optionalString cfg.allowPing '' - iptables -w -A nixos-fw -p icmp --icmp-type echo-request ${lib.optionalString (cfg.pingLimit != null) - "-m limit ${cfg.pingLimit} " + iptables -w -A nixos-fw -p icmp --icmp-type echo-request ${ + lib.optionalString (cfg.pingLimit != null) "-m limit ${cfg.pingLimit} " }-j nixos-fw-accept ''} @@ -304,7 +341,10 @@ in wantedBy = [ "sysinit.target" ]; wants = [ "network-pre.target" ]; after = [ "systemd-modules-load.service" ]; - before = [ "network-pre.target" "shutdown.target" ]; + before = [ + "network-pre.target" + "shutdown.target" + ]; conflicts = [ "shutdown.target" ]; path = [ cfg.package ] ++ cfg.extraPackages; diff --git a/nixos/modules/services/networking/firewall-nftables.nix b/nixos/modules/services/networking/firewall-nftables.nix index 06f070caf25aa2..d9695c0e4d2721 100644 --- a/nixos/modules/services/networking/firewall-nftables.nix +++ b/nixos/modules/services/networking/firewall-nftables.nix @@ -1,16 +1,20 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.networking.firewall; - ifaceSet = lib.concatStringsSep ", " ( - map (x: ''"${x}"'') cfg.trustedInterfaces - ); + ifaceSet = lib.concatStringsSep ", " (map (x: ''"${x}"'') cfg.trustedInterfaces); - portsToNftSet = ports: portRanges: lib.concatStringsSep ", " ( - map (x: toString x) ports - ++ map (x: "${toString x.from}-${toString x.to}") portRanges - ); + portsToNftSet = + ports: portRanges: + lib.concatStringsSep ", " ( + map (x: toString x) ports ++ map (x: "${toString x.from}-${toString x.to}") portRanges + ); in @@ -81,68 +85,72 @@ in networking.nftables.tables."nixos-fw".family = "inet"; networking.nftables.tables."nixos-fw".content = '' - set temp-ports { - comment "Temporarily opened ports" - type inet_proto . inet_service - flags interval - auto-merge - } - - ${lib.optionalString (cfg.checkReversePath != false) '' - chain rpfilter { - type filter hook prerouting priority mangle + 10; policy drop; + set temp-ports { + comment "Temporarily opened ports" + type inet_proto . inet_service + flags interval + auto-merge + } - meta nfproto ipv4 udp sport . udp dport { 67 . 68, 68 . 67 } accept comment "DHCPv4 client/server" - fib saddr . mark ${lib.optionalString (cfg.checkReversePath != "loose") ". iif"} oif exists accept + ${lib.optionalString (cfg.checkReversePath != false) '' + chain rpfilter { + type filter hook prerouting priority mangle + 10; policy drop; - jump rpfilter-allow + meta nfproto ipv4 udp sport . udp dport { 67 . 68, 68 . 67 } accept comment "DHCPv4 client/server" + fib saddr . mark ${lib.optionalString (cfg.checkReversePath != "loose") ". iif"} oif exists accept - ${lib.optionalString cfg.logReversePathDrops '' - log level info prefix "rpfilter drop: " - ''} + jump rpfilter-allow - } - ''} + ${lib.optionalString cfg.logReversePathDrops '' + log level info prefix "rpfilter drop: " + ''} - chain rpfilter-allow { - ${cfg.extraReversePathFilterRules} } + ''} - chain input { - type filter hook input priority filter; policy drop; + chain rpfilter-allow { + ${cfg.extraReversePathFilterRules} + } - ${lib.optionalString (ifaceSet != "") ''iifname { ${ifaceSet} } accept comment "trusted interfaces"''} + chain input { + type filter hook input priority filter; policy drop; - # Some ICMPv6 types like NDP is untracked - ct state vmap { - invalid : drop, - established : accept, - related : accept, - new : jump input-allow, - untracked: jump input-allow, - } + ${lib.optionalString ( + ifaceSet != "" + ) ''iifname { ${ifaceSet} } accept comment "trusted interfaces"''} - ${lib.optionalString cfg.logRefusedConnections '' - tcp flags syn / fin,syn,rst,ack log level info prefix "refused connection: " - ''} - ${lib.optionalString (cfg.logRefusedPackets && !cfg.logRefusedUnicastsOnly) '' - pkttype broadcast log level info prefix "refused broadcast: " - pkttype multicast log level info prefix "refused multicast: " - ''} - ${lib.optionalString cfg.logRefusedPackets '' - pkttype host log level info prefix "refused packet: " - ''} + # Some ICMPv6 types like NDP is untracked + ct state vmap { + invalid : drop, + established : accept, + related : accept, + new : jump input-allow, + untracked: jump input-allow, + } - ${lib.optionalString cfg.rejectPackets '' - meta l4proto tcp reject with tcp reset - reject - ''} + ${lib.optionalString cfg.logRefusedConnections '' + tcp flags syn / fin,syn,rst,ack log level info prefix "refused connection: " + ''} + ${lib.optionalString (cfg.logRefusedPackets && !cfg.logRefusedUnicastsOnly) '' + pkttype broadcast log level info prefix "refused broadcast: " + pkttype multicast log level info prefix "refused multicast: " + ''} + ${lib.optionalString cfg.logRefusedPackets '' + pkttype host log level info prefix "refused packet: " + ''} - } + ${lib.optionalString cfg.rejectPackets '' + meta l4proto tcp reject with tcp reset + reject + ''} + + } - chain input-allow { + chain input-allow { - ${lib.concatStrings (lib.mapAttrsToList (iface: cfg: + ${lib.concatStrings ( + lib.mapAttrsToList ( + iface: cfg: let ifaceExpr = lib.optionalString (iface != "default") "iifname ${iface}"; tcpSet = portsToNftSet cfg.allowedTCPPorts cfg.allowedTCPPortRanges; @@ -152,45 +160,48 @@ in ${lib.optionalString (tcpSet != "") "${ifaceExpr} tcp dport { ${tcpSet} } accept"} ${lib.optionalString (udpSet != "") "${ifaceExpr} udp dport { ${udpSet} } accept"} '' - ) cfg.allInterfaces)} + ) cfg.allInterfaces + )} - meta l4proto . th dport @temp-ports accept + meta l4proto . th dport @temp-ports accept - ${lib.optionalString cfg.allowPing '' - icmp type echo-request ${lib.optionalString (cfg.pingLimit != null) "limit rate ${cfg.pingLimit}"} accept comment "allow ping" - ''} + ${lib.optionalString cfg.allowPing '' + icmp type echo-request ${ + lib.optionalString (cfg.pingLimit != null) "limit rate ${cfg.pingLimit}" + } accept comment "allow ping" + ''} - icmpv6 type != { nd-redirect, 139 } accept comment "Accept all ICMPv6 messages except redirects and node information queries (type 139). See RFC 4890, section 4.4." - ip6 daddr fe80::/64 udp dport 546 accept comment "DHCPv6 client" + icmpv6 type != { nd-redirect, 139 } accept comment "Accept all ICMPv6 messages except redirects and node information queries (type 139). See RFC 4890, section 4.4." + ip6 daddr fe80::/64 udp dport 546 accept comment "DHCPv6 client" - ${cfg.extraInputRules} + ${cfg.extraInputRules} - } - - ${lib.optionalString cfg.filterForward '' - chain forward { - type filter hook forward priority filter; policy drop; + } - ct state vmap { - invalid : drop, - established : accept, - related : accept, - new : jump forward-allow, - untracked : jump forward-allow, - } + ${lib.optionalString cfg.filterForward '' + chain forward { + type filter hook forward priority filter; policy drop; + ct state vmap { + invalid : drop, + established : accept, + related : accept, + new : jump forward-allow, + untracked : jump forward-allow, } - chain forward-allow { + } - icmpv6 type != { router-renumbering, 139 } accept comment "Accept all ICMPv6 messages except renumbering and node information queries (type 139). See RFC 4890, section 4.3." + chain forward-allow { - ct status dnat accept comment "allow port forward" + icmpv6 type != { router-renumbering, 139 } accept comment "Accept all ICMPv6 messages except renumbering and node information queries (type 139). See RFC 4890, section 4.3." - ${cfg.extraForwardRules} + ct status dnat accept comment "allow port forward" - } - ''} + ${cfg.extraForwardRules} + + } + ''} ''; }; diff --git a/nixos/modules/services/networking/firewall.nix b/nixos/modules/services/networking/firewall.nix index ab575b884a71ba..bf3119292eeeb3 100644 --- a/nixos/modules/services/networking/firewall.nix +++ b/nixos/modules/services/networking/firewall.nix @@ -1,17 +1,24 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.networking.firewall; - canonicalizePortList = - ports: lib.unique (builtins.sort builtins.lessThan ports); + canonicalizePortList = ports: lib.unique (builtins.sort builtins.lessThan ports); commonOptions = { allowedTCPPorts = lib.mkOption { type = lib.types.listOf lib.types.port; default = [ ]; apply = canonicalizePortList; - example = [ 22 80 ]; + example = [ + 22 + 80 + ]; description = '' List of TCP ports on which incoming connections are accepted. @@ -21,7 +28,12 @@ let allowedTCPPortRanges = lib.mkOption { type = lib.types.listOf (lib.types.attrsOf lib.types.port); default = [ ]; - example = [{ from = 8999; to = 9003; }]; + example = [ + { + from = 8999; + to = 9003; + } + ]; description = '' A range of TCP ports on which incoming connections are accepted. @@ -41,7 +53,12 @@ let allowedUDPPortRanges = lib.mkOption { type = lib.types.listOf (lib.types.attrsOf lib.types.port); default = [ ]; - example = [{ from = 60000; to = 61000; }]; + example = [ + { + from = 60000; + to = 61000; + } + ]; description = '' Range of open UDP ports. ''; @@ -158,7 +175,12 @@ in }; checkReversePath = lib.mkOption { - type = lib.types.either lib.types.bool (lib.types.enum [ "strict" "loose" ]); + type = lib.types.either lib.types.bool ( + lib.types.enum [ + "strict" + "loose" + ] + ); default = true; defaultText = lib.literalMD "`true` except if the iptables based firewall is in use and the kernel lacks rpfilter support"; example = "loose"; @@ -199,7 +221,18 @@ in connectionTrackingModules = lib.mkOption { type = lib.types.listOf lib.types.str; default = [ ]; - example = [ "ftp" "irc" "sane" "sip" "tftp" "amanda" "h323" "netbios_sn" "pptp" "snmp" ]; + example = [ + "ftp" + "irc" + "sane" + "sip" + "tftp" + "amanda" + "h323" + "netbios_sn" + "pptp" + "snmp" + ]; description = '' List of connection-tracking helpers that are auto-loaded. The complete list of possible values is given in the example. @@ -239,7 +272,7 @@ in interfaces = lib.mkOption { default = { }; - type = with lib.types; attrsOf (submodule [{ options = commonOptions; }]); + type = with lib.types; attrsOf (submodule [ { options = commonOptions; } ]); description = '' Interface-specific open ports. ''; @@ -248,8 +281,10 @@ in allInterfaces = lib.mkOption { internal = true; visible = false; - default = { default = lib.mapAttrs (name: value: cfg.${name}) commonOptions; } // cfg.interfaces; - type = with lib.types; attrsOf (submodule [{ options = commonOptions; }]); + default = { + default = lib.mapAttrs (name: value: cfg.${name}) commonOptions; + } // cfg.interfaces; + type = with lib.types; attrsOf (submodule [ { options = commonOptions; } ]); description = '' All open ports. ''; @@ -258,7 +293,6 @@ in }; - config = lib.mkIf cfg.enable { assertions = [ @@ -267,7 +301,8 @@ in message = "filterForward only works with the nftables based firewall"; } { - assertion = cfg.autoLoadConntrackHelpers -> lib.versionOlder config.boot.kernelPackages.kernel.version "6"; + assertion = + cfg.autoLoadConntrackHelpers -> lib.versionOlder config.boot.kernelPackages.kernel.version "6"; message = "conntrack helper autoloading has been removed from kernel 6.0 and newer"; } ]; @@ -279,7 +314,8 @@ in pkgs.nixos-firewall-tool ] ++ cfg.extraPackages; - boot.kernelModules = (lib.optional cfg.autoLoadConntrackHelpers "nf_conntrack") + boot.kernelModules = + (lib.optional cfg.autoLoadConntrackHelpers "nf_conntrack") ++ map (x: "nf_conntrack_${x}") cfg.connectionTrackingModules; boot.extraModprobeConfig = lib.optionalString cfg.autoLoadConntrackHelpers '' options nf_conntrack nf_conntrack_helper=1 diff --git a/nixos/modules/services/networking/flannel.nix b/nixos/modules/services/networking/flannel.nix index 05987df88c1873..95ad9d8374c090 100644 --- a/nixos/modules/services/networking/flannel.nix +++ b/nixos/modules/services/networking/flannel.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.flannel; @@ -9,7 +14,8 @@ let SubnetMax = cfg.subnetMax; Backend = cfg.backend; }; -in { +in +{ options.services.flannel = { enable = lib.mkEnableOption "flannel"; @@ -37,7 +43,7 @@ in { endpoints = lib.mkOption { description = "Etcd endpoints"; type = lib.types.listOf lib.types.str; - default = ["http://127.0.0.1:2379"]; + default = [ "http://127.0.0.1:2379" ]; }; prefix = lib.mkOption { @@ -91,7 +97,10 @@ in { storageBackend = lib.mkOption { description = "Determines where flannel stores its configuration at runtime"; - type = lib.types.enum ["etcd" "kubernetes"]; + type = lib.types.enum [ + "etcd" + "kubernetes" + ]; default = "etcd"; }; @@ -137,24 +146,27 @@ in { description = "Flannel Service"; wantedBy = [ "multi-user.target" ]; after = [ "network.target" ]; - environment = { - FLANNELD_PUBLIC_IP = cfg.publicIp; - FLANNELD_IFACE = cfg.iface; - } // lib.optionalAttrs (cfg.storageBackend == "etcd") { - FLANNELD_ETCD_ENDPOINTS = lib.concatStringsSep "," cfg.etcd.endpoints; - FLANNELD_ETCD_KEYFILE = cfg.etcd.keyFile; - FLANNELD_ETCD_CERTFILE = cfg.etcd.certFile; - FLANNELD_ETCD_CAFILE = cfg.etcd.caFile; - ETCDCTL_CERT = cfg.etcd.certFile; - ETCDCTL_KEY = cfg.etcd.keyFile; - ETCDCTL_CACERT = cfg.etcd.caFile; - ETCDCTL_ENDPOINTS = lib.concatStringsSep "," cfg.etcd.endpoints; - ETCDCTL_API = "3"; - } // lib.optionalAttrs (cfg.storageBackend == "kubernetes") { - FLANNELD_KUBE_SUBNET_MGR = "true"; - FLANNELD_KUBECONFIG_FILE = cfg.kubeconfig; - NODE_NAME = cfg.nodeName; - }; + environment = + { + FLANNELD_PUBLIC_IP = cfg.publicIp; + FLANNELD_IFACE = cfg.iface; + } + // lib.optionalAttrs (cfg.storageBackend == "etcd") { + FLANNELD_ETCD_ENDPOINTS = lib.concatStringsSep "," cfg.etcd.endpoints; + FLANNELD_ETCD_KEYFILE = cfg.etcd.keyFile; + FLANNELD_ETCD_CERTFILE = cfg.etcd.certFile; + FLANNELD_ETCD_CAFILE = cfg.etcd.caFile; + ETCDCTL_CERT = cfg.etcd.certFile; + ETCDCTL_KEY = cfg.etcd.keyFile; + ETCDCTL_CACERT = cfg.etcd.caFile; + ETCDCTL_ENDPOINTS = lib.concatStringsSep "," cfg.etcd.endpoints; + ETCDCTL_API = "3"; + } + // lib.optionalAttrs (cfg.storageBackend == "kubernetes") { + FLANNELD_KUBE_SUBNET_MGR = "true"; + FLANNELD_KUBECONFIG_FILE = cfg.kubeconfig; + NODE_NAME = cfg.nodeName; + }; path = [ pkgs.iptables ]; preStart = lib.optionalString (cfg.storageBackend == "etcd") '' echo "setting network configuration" @@ -172,7 +184,9 @@ in { }; }; - services.etcd.enable = lib.mkDefault (cfg.storageBackend == "etcd" && cfg.etcd.endpoints == ["http://127.0.0.1:2379"]); + services.etcd.enable = lib.mkDefault ( + cfg.storageBackend == "etcd" && cfg.etcd.endpoints == [ "http://127.0.0.1:2379" ] + ); # for some reason, flannel doesn't let you configure this path # see: https://github.com/coreos/flannel/blob/master/Documentation/configuration.md#configuration diff --git a/nixos/modules/services/networking/freenet.nix b/nixos/modules/services/networking/freenet.nix index 4323b98d67075f..1c9b0ef66618ab 100644 --- a/nixos/modules/services/networking/freenet.nix +++ b/nixos/modules/services/networking/freenet.nix @@ -1,5 +1,10 @@ # NixOS module for Freenet daemon -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.freenet; diff --git a/nixos/modules/services/networking/freeradius.nix b/nixos/modules/services/networking/freeradius.nix index d747219b29cb6e..cd766f91957909 100644 --- a/nixos/modules/services/networking/freeradius.nix +++ b/nixos/modules/services/networking/freeradius.nix @@ -1,31 +1,35 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.freeradius; - freeradiusService = cfg: - { + freeradiusService = cfg: { description = "FreeRadius server"; - wantedBy = ["multi-user.target"]; - after = ["network.target"]; - wants = ["network.target"]; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + wants = [ "network.target" ]; preStart = '' ${cfg.package}/bin/radiusd -C -d ${cfg.configDir} -l stdout ''; serviceConfig = { - ExecStart = "${cfg.package}/bin/radiusd -f -d ${cfg.configDir} -l stdout" + - lib.optionalString cfg.debug " -xx"; - ExecReload = [ - "${cfg.package}/bin/radiusd -C -d ${cfg.configDir} -l stdout" - "${pkgs.coreutils}/bin/kill -HUP $MAINPID" - ]; - User = "radius"; - ProtectSystem = "full"; - ProtectHome = "on"; - Restart = "on-failure"; - RestartSec = 2; - LogsDirectory = "radius"; + ExecStart = + "${cfg.package}/bin/radiusd -f -d ${cfg.configDir} -l stdout" + lib.optionalString cfg.debug " -xx"; + ExecReload = [ + "${cfg.package}/bin/radiusd -C -d ${cfg.configDir} -l stdout" + "${pkgs.coreutils}/bin/kill -HUP $MAINPID" + ]; + User = "radius"; + ProtectSystem = "full"; + ProtectHome = "on"; + Restart = "on-failure"; + RestartSec = 2; + LogsDirectory = "radius"; }; }; @@ -64,19 +68,18 @@ in services.freeradius = freeradiusConfig; }; - ###### implementation config = lib.mkIf (cfg.enable) { users = { users.radius = { - /*uid = config.ids.uids.radius;*/ + # uid = config.ids.uids.radius; description = "Radius daemon user"; isSystemUser = true; group = "radius"; }; - groups.radius = {}; + groups.radius = { }; }; systemd.services.freeradius = freeradiusService cfg; diff --git a/nixos/modules/services/networking/frp.nix b/nixos/modules/services/networking/frp.nix index 56af543b845bad..b09d54f47827a4 100644 --- a/nixos/modules/services/networking/frp.nix +++ b/nixos/modules/services/networking/frp.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.frp; settingsFormat = pkgs.formats.toml { }; @@ -14,7 +19,10 @@ in package = lib.mkPackageOption pkgs "frp" { }; role = lib.mkOption { - type = lib.types.enum [ "server" "client" ]; + type = lib.types.enum [ + "server" + "client" + ]; description = '' The frp consists of `client` and `server`. The server is usually deployed on the machine with a public IP address, and @@ -32,9 +40,9 @@ in or [server](https://github.com/fatedier/frp/blob/dev/conf/frps_full_example.toml) on github. ''; example = { - serverAddr = "x.x.x.x"; - serverPort = 7000; - }; + serverAddr = "x.x.x.x"; + serverPort = 7000; + }; }; }; }; @@ -69,7 +77,10 @@ in ProtectKernelModules = true; ProtectKernelLogs = true; ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ] ++ lib.optionals isClient [ "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ] ++ lib.optionals isClient [ "AF_UNIX" ]; LockPersonality = true; MemoryDenyWriteExecute = true; RestrictRealtime = true; diff --git a/nixos/modules/services/networking/frr.nix b/nixos/modules/services/networking/frr.nix index 3ffd1c3f070a51..e26385802af165 100644 --- a/nixos/modules/services/networking/frr.nix +++ b/nixos/modules/services/networking/frr.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let @@ -67,7 +72,11 @@ let "fabric" ]; - obsoleteServices = renamedServices ++ [ "static" "mgmt" "zebra" ]; + obsoleteServices = renamedServices ++ [ + "static" + "mgmt" + "zebra" + ]; allDaemons = builtins.attrNames daemonDefaultOptions; @@ -110,7 +119,9 @@ let ''; }; } - // (if (builtins.elem service daemons) then { enable = lib.mkEnableOption "FRR ${service}"; } else { }); + // ( + if (builtins.elem service daemons) then { enable = lib.mkEnableOption "FRR ${service}"; } else { } + ); in @@ -159,21 +170,66 @@ in { options.services.frr = (lib.genAttrs allDaemons serviceOptions); } (lib.mkRemovedOptionModule [ "services" "frr" "zebra" "enable" ] "FRR zebra is always enabled") ] - ++ (map (d: lib.mkRenamedOptionModule [ "services" "frr" d "enable" ] [ "services" "frr" "${d}d" "enable" ]) renamedServices) - ++ (map (d: lib.mkRenamedOptionModule [ "services" "frr" d "extraOptions" ] [ "services" "frr" "${d}d" "extraOptions" ]) (renamedServices ++ [ "static" "mgmt" ])) - ++ (map (d: lib.mkRemovedOptionModule [ "services" "frr" d "enable" ] "FRR ${d}d is always enabled") [ "static" "mgmt" ]) - ++ (map (d: lib.mkRemovedOptionModule [ "services" "frr" d "config" ] "FRR switched to integrated-vtysh-config, please use services.frr.config") obsoleteServices) - ++ (map (d: lib.mkRemovedOptionModule [ "services" "frr" d "configFile" ] "FRR switched to integrated-vtysh-config, please use services.frr.config or services.frr.configFile") obsoleteServices) - ++ (map (d: lib.mkRemovedOptionModule [ "services" "frr" d "vtyListenAddress" ] "Please change -A option in services.frr.${d}.options instead") obsoleteServices) - ++ (map (d: lib.mkRemovedOptionModule [ "services" "frr" d "vtyListenPort" ] "Please use `-P «vtyListenPort»` option with services.frr.${d}.extraOptions instead, or change services.frr.${d}.options accordingly") obsoleteServices) - ; + ++ (map ( + d: lib.mkRenamedOptionModule [ "services" "frr" d "enable" ] [ "services" "frr" "${d}d" "enable" ] + ) renamedServices) + ++ (map + ( + d: + lib.mkRenamedOptionModule + [ "services" "frr" d "extraOptions" ] + [ "services" "frr" "${d}d" "extraOptions" ] + ) + ( + renamedServices + ++ [ + "static" + "mgmt" + ] + ) + ) + ++ (map (d: lib.mkRemovedOptionModule [ "services" "frr" d "enable" ] "FRR ${d}d is always enabled") + [ + "static" + "mgmt" + ] + ) + ++ (map ( + d: + lib.mkRemovedOptionModule [ + "services" + "frr" + d + "config" + ] "FRR switched to integrated-vtysh-config, please use services.frr.config" + ) obsoleteServices) + ++ (map ( + d: + lib.mkRemovedOptionModule [ "services" "frr" d "configFile" ] + "FRR switched to integrated-vtysh-config, please use services.frr.config or services.frr.configFile" + ) obsoleteServices) + ++ (map ( + d: + lib.mkRemovedOptionModule [ + "services" + "frr" + d + "vtyListenAddress" + ] "Please change -A option in services.frr.${d}.options instead" + ) obsoleteServices) + ++ (map ( + d: + lib.mkRemovedOptionModule [ "services" "frr" d "vtyListenPort" ] + "Please use `-P «vtyListenPort»` option with services.frr.${d}.extraOptions instead, or change services.frr.${d}.options accordingly" + ) obsoleteServices); ###### implementation config = let daemonList = lib.concatStringsSep "\n" (map daemonLine daemons); - daemonOptionLine = d: "${d}_options=\"${lib.concatStringsSep " " (cfg.${d}.options ++ cfg.${d}.extraOptions)}\""; + daemonOptionLine = + d: "${d}_options=\"${lib.concatStringsSep " " (cfg.${d}.options ++ cfg.${d}.extraOptions)}\""; daemonOptions = lib.concatStringsSep "\n" (map daemonOptionLine allDaemons); in lib.mkIf (lib.any isEnabled daemons || cfg.configFile != null || cfg.config != "") { diff --git a/nixos/modules/services/networking/gateone.nix b/nixos/modules/services/networking/gateone.nix index 83a7ea24859438..51817124cb1d61 100644 --- a/nixos/modules/services/networking/gateone.nix +++ b/nixos/modules/services/networking/gateone.nix @@ -1,9 +1,14 @@ -{ config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.gateone; in { -options = { + options = { services.gateone = { enable = lib.mkEnableOption "GateOne server"; pidDir = lib.mkOption { @@ -17,42 +22,52 @@ options = { description = "Path of configuration files for GateOne."; }; }; -}; -config = lib.mkIf cfg.enable { - environment.systemPackages = with pkgs.pythonPackages; [ - gateone pkgs.openssh pkgs.procps pkgs.coreutils pkgs.cacert]; - - users.users.gateone = { - description = "GateOne privilege separation user"; - uid = config.ids.uids.gateone; - home = cfg.settingsDir; }; - users.groups.gateone.gid = config.ids.gids.gateone; + config = lib.mkIf cfg.enable { + environment.systemPackages = with pkgs.pythonPackages; [ + gateone + pkgs.openssh + pkgs.procps + pkgs.coreutils + pkgs.cacert + ]; - systemd.services.gateone = with pkgs; { - description = "GateOne web-based terminal"; - path = [ pythonPackages.gateone nix openssh procps coreutils ]; - preStart = '' - if [ ! -d ${cfg.settingsDir} ] ; then - mkdir -m 0750 -p ${cfg.settingsDir} - chown -R gateone:gateone ${cfg.settingsDir} - fi - if [ ! -d ${cfg.pidDir} ] ; then - mkdir -m 0750 -p ${cfg.pidDir} - chown -R gateone:gateone ${cfg.pidDir} - fi - ''; - #unitConfig.RequiresMountsFor = "${cfg.settingsDir}"; - serviceConfig = { - ExecStart = ''${pythonPackages.gateone}/bin/gateone --settings_dir=${cfg.settingsDir} --pid_file=${cfg.pidDir}/gateone.pid --gid=${toString config.ids.gids.gateone} --uid=${toString config.ids.uids.gateone}''; - User = "gateone"; - Group = "gateone"; - WorkingDirectory = cfg.settingsDir; + users.users.gateone = { + description = "GateOne privilege separation user"; + uid = config.ids.uids.gateone; + home = cfg.settingsDir; }; + users.groups.gateone.gid = config.ids.gids.gateone; + + systemd.services.gateone = with pkgs; { + description = "GateOne web-based terminal"; + path = [ + pythonPackages.gateone + nix + openssh + procps + coreutils + ]; + preStart = '' + if [ ! -d ${cfg.settingsDir} ] ; then + mkdir -m 0750 -p ${cfg.settingsDir} + chown -R gateone:gateone ${cfg.settingsDir} + fi + if [ ! -d ${cfg.pidDir} ] ; then + mkdir -m 0750 -p ${cfg.pidDir} + chown -R gateone:gateone ${cfg.pidDir} + fi + ''; + #unitConfig.RequiresMountsFor = "${cfg.settingsDir}"; + serviceConfig = { + ExecStart = ''${pythonPackages.gateone}/bin/gateone --settings_dir=${cfg.settingsDir} --pid_file=${cfg.pidDir}/gateone.pid --gid=${toString config.ids.gids.gateone} --uid=${toString config.ids.uids.gateone}''; + User = "gateone"; + Group = "gateone"; + WorkingDirectory = cfg.settingsDir; + }; - wantedBy = [ "multi-user.target" ]; - requires = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + requires = [ "network.target" ]; + }; }; -}; } - diff --git a/nixos/modules/services/networking/gdomap.nix b/nixos/modules/services/networking/gdomap.nix index b7d6e2a2b690fc..bfec51c616bb12 100644 --- a/nixos/modules/services/networking/gdomap.nix +++ b/nixos/modules/services/networking/gdomap.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { # # interface @@ -6,7 +11,7 @@ options = { services.gdomap = { enable = lib.mkEnableOption "GNUstep Distributed Objects name server"; - }; + }; }; # @@ -19,7 +24,7 @@ description = "gdomap server"; wantedBy = [ "multi-user.target" ]; after = [ "network.target" ]; - path = [ pkgs.gnustep.base ]; + path = [ pkgs.gnustep.base ]; serviceConfig.ExecStart = "${pkgs.gnustep.base}/bin/gdomap -f"; }; }; diff --git a/nixos/modules/services/networking/ghostunnel.nix b/nixos/modules/services/networking/ghostunnel.nix index b8d3cc3629790f..ea087d699e703e 100644 --- a/nixos/modules/services/networking/ghostunnel.nix +++ b/nixos/modules/services/networking/ghostunnel.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) attrValues @@ -19,7 +24,8 @@ let mainCfg = config.services.ghostunnel; - module = { config, name, ... }: + module = + { config, name, ... }: { options = { @@ -97,7 +103,7 @@ let Allow client if common name appears in the list. ''; type = types.listOf types.str; - default = []; + default = [ ]; }; allowOU = mkOption { @@ -105,7 +111,7 @@ let Allow client if organizational unit name appears in the list. ''; type = types.listOf types.str; - default = []; + default = [ ]; }; allowDNS = mkOption { @@ -113,7 +119,7 @@ let Allow client if DNS subject alternative name appears in the list. ''; type = types.listOf types.str; - default = []; + default = [ ]; }; allowURI = mkOption { @@ -121,7 +127,7 @@ let Allow client if URI subject alternative name appears in the list. ''; type = types.listOf types.str; - default = []; + default = [ ]; }; extraArguments = mkOption { @@ -154,7 +160,8 @@ let config.atRoot = { assertions = [ - { message = '' + { + message = '' services.ghostunnel.servers.${name}: At least one access control flag is required. Set at least one of: - services.ghostunnel.servers.${name}.disableAuthentication @@ -164,13 +171,13 @@ let - services.ghostunnel.servers.${name}.allowDNS - services.ghostunnel.servers.${name}.allowURI ''; - assertion = config.disableAuthentication + assertion = + config.disableAuthentication || config.allowAll - || config.allowCN != [] - || config.allowOU != [] - || config.allowDNS != [] - || config.allowURI != [] - ; + || config.allowCN != [ ] + || config.allowOU != [ ] + || config.allowDNS != [ ] + || config.allowURI != [ ]; } ]; @@ -180,13 +187,14 @@ let wantedBy = [ "multi-user.target" ]; serviceConfig = { Restart = "always"; - AmbientCapabilities = ["CAP_NET_BIND_SERVICE"]; + AmbientCapabilities = [ "CAP_NET_BIND_SERVICE" ]; DynamicUser = true; - LoadCredential = optional (config.keystore != null) "keystore:${config.keystore}" + LoadCredential = + optional (config.keystore != null) "keystore:${config.keystore}" ++ optional (config.cert != null) "cert:${config.cert}" ++ optional (config.key != null) "key:${config.key}" ++ optional (config.cacert != null) "cacert:${config.cacert}"; - }; + }; script = concatStringsSep " " ( [ "${mainCfg.package}/bin/ghostunnel" ] ++ optional (config.keystore != null) "--keystore=$CREDENTIALS_DIRECTORY/keystore" @@ -197,14 +205,15 @@ let "server" "--listen ${config.listen}" "--target ${config.target}" - ] ++ optional config.allowAll "--allow-all" - ++ map (v: "--allow-cn=${escapeShellArg v}") config.allowCN - ++ map (v: "--allow-ou=${escapeShellArg v}") config.allowOU - ++ map (v: "--allow-dns=${escapeShellArg v}") config.allowDNS - ++ map (v: "--allow-uri=${escapeShellArg v}") config.allowURI - ++ optional config.disableAuthentication "--disable-authentication" - ++ optional config.unsafeTarget "--unsafe-target" - ++ [ config.extraArguments ] + ] + ++ optional config.allowAll "--allow-all" + ++ map (v: "--allow-cn=${escapeShellArg v}") config.allowCN + ++ map (v: "--allow-ou=${escapeShellArg v}") config.allowOU + ++ map (v: "--allow-dns=${escapeShellArg v}") config.allowDNS + ++ map (v: "--allow-uri=${escapeShellArg v}") config.allowURI + ++ optional config.disableAuthentication "--disable-authentication" + ++ optional config.unsafeTarget "--unsafe-target" + ++ [ config.extraArguments ] ); }; }; @@ -223,7 +232,7 @@ in Server mode ghostunnels (TLS listener -> plain TCP/UNIX target) ''; type = types.attrsOf (types.submodule module); - default = {}; + default = { }; }; }; diff --git a/nixos/modules/services/networking/git-daemon.nix b/nixos/modules/services/networking/git-daemon.nix index 215d7f79a52cf3..d1b492ec61c0c4 100644 --- a/nixos/modules/services/networking/git-daemon.nix +++ b/nixos/modules/services/networking/git-daemon.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.gitDaemon; @@ -56,8 +61,11 @@ in repositories = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; - example = [ "/srv/git" "/home/user/git/repo2" ]; + default = [ ]; + example = [ + "/srv/git" + "/home/user/git/repo2" + ]; description = '' A whitelist of paths of git repositories, or directories containing repositories all of which would be published. Paths must not end in "/". @@ -120,11 +128,14 @@ in systemd.services.git-daemon = { after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; - script = "${lib.getExe cfg.package} daemon --reuseaddr " + script = + "${lib.getExe cfg.package} daemon --reuseaddr " + (lib.optionalString (cfg.basePath != "") "--base-path=${cfg.basePath} ") + (lib.optionalString (cfg.listenAddress != "") "--listen=${cfg.listenAddress} ") + "--port=${toString cfg.port} --user=${cfg.user} --group=${cfg.group} ${cfg.options} " - + "--verbose " + (lib.optionalString cfg.exportAll "--export-all ") + lib.concatStringsSep " " cfg.repositories; + + "--verbose " + + (lib.optionalString cfg.exportAll "--export-all ") + + lib.concatStringsSep " " cfg.repositories; }; }; diff --git a/nixos/modules/services/networking/gns3-server.nix b/nixos/modules/services/networking/gns3-server.nix index 71980f52df2d44..769cde21bc2016 100644 --- a/nixos/modules/services/networking/gns3-server.nix +++ b/nixos/modules/services/networking/gns3-server.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.gns3-server; @@ -6,7 +11,8 @@ let settingsFormat = pkgs.formats.ini { }; configFile = settingsFormat.generate "gns3-server.conf" cfg.settings; -in { +in +{ meta = { doc = ./gns3-server.md; maintainers = [ lib.maintainers.anthonyroussel ]; @@ -45,8 +51,11 @@ in { settings = lib.mkOption { type = lib.types.submodule { freeformType = settingsFormat.type; }; - default = {}; - example = { host = "127.0.0.1"; port = 3080; }; + default = { }; + example = { + host = "127.0.0.1"; + port = 3080; + }; description = '' The global options in `config` file in ini format. @@ -103,179 +112,188 @@ in { }; }; - config = let - flags = { - enableDocker = config.virtualisation.docker.enable; - enableLibvirtd = config.virtualisation.libvirtd.enable; - }; + config = + let + flags = { + enableDocker = config.virtualisation.docker.enable; + enableLibvirtd = config.virtualisation.libvirtd.enable; + }; - in lib.mkIf cfg.enable { - assertions = [ - { - assertion = cfg.ssl.enable -> cfg.ssl.certFile != null; - message = "Please provide a certificate to use for SSL encryption."; - } - { - assertion = cfg.ssl.enable -> cfg.ssl.keyFile != null; - message = "Please provide a private key to use for SSL encryption."; - } - { - assertion = cfg.auth.enable -> cfg.auth.user != null; - message = "Please provide a username to use for HTTP authentication."; - } - { - assertion = cfg.auth.enable -> cfg.auth.passwordFile != null; - message = "Please provide a password file to use for HTTP authentication."; - } - ]; - - users.groups.gns3 = { }; - - users.groups.ubridge = lib.mkIf cfg.ubridge.enable { }; - - users.users.gns3 = { - group = "gns3"; - isSystemUser = true; - }; + in + lib.mkIf cfg.enable { + assertions = [ + { + assertion = cfg.ssl.enable -> cfg.ssl.certFile != null; + message = "Please provide a certificate to use for SSL encryption."; + } + { + assertion = cfg.ssl.enable -> cfg.ssl.keyFile != null; + message = "Please provide a private key to use for SSL encryption."; + } + { + assertion = cfg.auth.enable -> cfg.auth.user != null; + message = "Please provide a username to use for HTTP authentication."; + } + { + assertion = cfg.auth.enable -> cfg.auth.passwordFile != null; + message = "Please provide a password file to use for HTTP authentication."; + } + ]; + + users.groups.gns3 = { }; + + users.groups.ubridge = lib.mkIf cfg.ubridge.enable { }; + + users.users.gns3 = { + group = "gns3"; + isSystemUser = true; + }; - security.wrappers.ubridge = lib.mkIf cfg.ubridge.enable { - capabilities = "cap_net_raw,cap_net_admin=eip"; - group = "ubridge"; - owner = "root"; - permissions = "u=rwx,g=rx,o=r"; - source = lib.getExe cfg.ubridge.package; - }; + security.wrappers.ubridge = lib.mkIf cfg.ubridge.enable { + capabilities = "cap_net_raw,cap_net_admin=eip"; + group = "ubridge"; + owner = "root"; + permissions = "u=rwx,g=rx,o=r"; + source = lib.getExe cfg.ubridge.package; + }; - services.gns3-server.settings = lib.mkMerge [ - { - Server = { - appliances_path = lib.mkDefault "/var/lib/gns3/appliances"; - configs_path = lib.mkDefault "/var/lib/gns3/configs"; - images_path = lib.mkDefault "/var/lib/gns3/images"; - projects_path = lib.mkDefault "/var/lib/gns3/projects"; - symbols_path = lib.mkDefault "/var/lib/gns3/symbols"; - }; - } - (lib.mkIf (cfg.ubridge.enable) { - Server.ubridge_path = lib.mkDefault "/run/wrappers/bin/ubridge"; - }) - (lib.mkIf (cfg.auth.enable) { - Server = { - auth = lib.mkDefault (lib.boolToString cfg.auth.enable); - user = lib.mkDefault cfg.auth.user; - password = lib.mkDefault "@AUTH_PASSWORD@"; + services.gns3-server.settings = lib.mkMerge [ + { + Server = { + appliances_path = lib.mkDefault "/var/lib/gns3/appliances"; + configs_path = lib.mkDefault "/var/lib/gns3/configs"; + images_path = lib.mkDefault "/var/lib/gns3/images"; + projects_path = lib.mkDefault "/var/lib/gns3/projects"; + symbols_path = lib.mkDefault "/var/lib/gns3/symbols"; + }; + } + (lib.mkIf (cfg.ubridge.enable) { + Server.ubridge_path = lib.mkDefault "/run/wrappers/bin/ubridge"; + }) + (lib.mkIf (cfg.auth.enable) { + Server = { + auth = lib.mkDefault (lib.boolToString cfg.auth.enable); + user = lib.mkDefault cfg.auth.user; + password = lib.mkDefault "@AUTH_PASSWORD@"; + }; + }) + (lib.mkIf (cfg.vpcs.enable) { + VPCS.vpcs_path = lib.mkDefault (lib.getExe cfg.vpcs.package); + }) + (lib.mkIf (cfg.dynamips.enable) { + Dynamips.dynamips_path = lib.mkDefault (lib.getExe cfg.dynamips.package); + }) + ]; + + systemd.services.gns3-server = + let + commandArgs = lib.cli.toGNUCommandLineShell { } { + config = "/etc/gns3/gns3_server.conf"; + pid = "/run/gns3/server.pid"; + log = cfg.log.file; + ssl = cfg.ssl.enable; + # These are implicitly not set if `null` + certfile = cfg.ssl.certFile; + certkey = cfg.ssl.keyFile; + }; + in + { + description = "GNS3 Server"; + + after = [ + "network.target" + "network-online.target" + ]; + wantedBy = [ "multi-user.target" ]; + wants = [ "network-online.target" ]; + + # configFile cannot be stored in RuntimeDirectory, because GNS3 + # uses the `--config` base path to stores supplementary configuration files at runtime. + # + preStart = '' + install -m660 ${configFile} /etc/gns3/gns3_server.conf + + ${lib.optionalString cfg.auth.enable '' + ${pkgs.replace-secret}/bin/replace-secret \ + '@AUTH_PASSWORD@' \ + "''${CREDENTIALS_DIRECTORY}/AUTH_PASSWORD" \ + /etc/gns3/gns3_server.conf + ''} + ''; + + path = lib.optional flags.enableLibvirtd pkgs.qemu; + + reloadTriggers = [ configFile ]; + + serviceConfig = { + ConfigurationDirectory = "gns3"; + ConfigurationDirectoryMode = "0750"; + Environment = "HOME=%S/gns3"; + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + ExecStart = "${lib.getExe cfg.package} ${commandArgs}"; + Group = "gns3"; + LimitNOFILE = 16384; + LoadCredential = lib.mkIf cfg.auth.enable [ "AUTH_PASSWORD:${cfg.auth.passwordFile}" ]; + LogsDirectory = "gns3"; + LogsDirectoryMode = "0750"; + PIDFile = "/run/gns3/server.pid"; + Restart = "on-failure"; + RestartSec = 5; + RuntimeDirectory = "gns3"; + StateDirectory = "gns3"; + StateDirectoryMode = "0750"; + SupplementaryGroups = + lib.optional flags.enableDocker "docker" + ++ lib.optional flags.enableLibvirtd "libvirtd" + ++ lib.optional cfg.ubridge.enable "ubridge"; + User = "gns3"; + WorkingDirectory = "%S/gns3"; + + # Required for ubridge integration to work + # + # GNS3 needs to run SUID binaries (ubridge) + # but NoNewPrivileges breaks execution of SUID binaries + DynamicUser = false; + NoNewPrivileges = false; + RestrictSUIDSGID = false; + PrivateUsers = false; + + # Hardening + DeviceAllow = + [ + # ubridge needs access to tun/tap devices + "/dev/net/tap rw" + "/dev/net/tun rw" + ] + ++ lib.optionals flags.enableLibvirtd [ + "/dev/kvm" + ]; + DevicePolicy = "closed"; + LockPersonality = true; + MemoryDenyWriteExecute = true; + PrivateTmp = true; + # Don't restrict ProcSubset because python3Packages.psutil requires read access to /proc/stat + # ProcSubset = "pid"; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + ProtectSystem = "strict"; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_NETLINK" + "AF_UNIX" + "AF_PACKET" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + UMask = "0022"; + }; }; - }) - (lib.mkIf (cfg.vpcs.enable) { - VPCS.vpcs_path = lib.mkDefault (lib.getExe cfg.vpcs.package); - }) - (lib.mkIf (cfg.dynamips.enable) { - Dynamips.dynamips_path = lib.mkDefault (lib.getExe cfg.dynamips.package); - }) - ]; - - systemd.services.gns3-server = let - commandArgs = lib.cli.toGNUCommandLineShell { } { - config = "/etc/gns3/gns3_server.conf"; - pid = "/run/gns3/server.pid"; - log = cfg.log.file; - ssl = cfg.ssl.enable; - # These are implicitly not set if `null` - certfile = cfg.ssl.certFile; - certkey = cfg.ssl.keyFile; - }; - in - { - description = "GNS3 Server"; - - after = [ "network.target" "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; - wants = [ "network-online.target" ]; - - # configFile cannot be stored in RuntimeDirectory, because GNS3 - # uses the `--config` base path to stores supplementary configuration files at runtime. - # - preStart = '' - install -m660 ${configFile} /etc/gns3/gns3_server.conf - - ${lib.optionalString cfg.auth.enable '' - ${pkgs.replace-secret}/bin/replace-secret \ - '@AUTH_PASSWORD@' \ - "''${CREDENTIALS_DIRECTORY}/AUTH_PASSWORD" \ - /etc/gns3/gns3_server.conf - ''} - ''; - - path = lib.optional flags.enableLibvirtd pkgs.qemu; - - reloadTriggers = [ configFile ]; - - serviceConfig = { - ConfigurationDirectory = "gns3"; - ConfigurationDirectoryMode = "0750"; - Environment = "HOME=%S/gns3"; - ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - ExecStart = "${lib.getExe cfg.package} ${commandArgs}"; - Group = "gns3"; - LimitNOFILE = 16384; - LoadCredential = lib.mkIf cfg.auth.enable [ "AUTH_PASSWORD:${cfg.auth.passwordFile}" ]; - LogsDirectory = "gns3"; - LogsDirectoryMode = "0750"; - PIDFile = "/run/gns3/server.pid"; - Restart = "on-failure"; - RestartSec = 5; - RuntimeDirectory = "gns3"; - StateDirectory = "gns3"; - StateDirectoryMode = "0750"; - SupplementaryGroups = lib.optional flags.enableDocker "docker" - ++ lib.optional flags.enableLibvirtd "libvirtd" - ++ lib.optional cfg.ubridge.enable "ubridge"; - User = "gns3"; - WorkingDirectory = "%S/gns3"; - - # Required for ubridge integration to work - # - # GNS3 needs to run SUID binaries (ubridge) - # but NoNewPrivileges breaks execution of SUID binaries - DynamicUser = false; - NoNewPrivileges = false; - RestrictSUIDSGID = false; - PrivateUsers = false; - - # Hardening - DeviceAllow = [ - # ubridge needs access to tun/tap devices - "/dev/net/tap rw" - "/dev/net/tun rw" - ] ++ lib.optionals flags.enableLibvirtd [ - "/dev/kvm" - ]; - DevicePolicy = "closed"; - LockPersonality = true; - MemoryDenyWriteExecute = true; - PrivateTmp = true; - # Don't restrict ProcSubset because python3Packages.psutil requires read access to /proc/stat - # ProcSubset = "pid"; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - ProtectSystem = "strict"; - RestrictAddressFamilies = [ - "AF_INET" - "AF_INET6" - "AF_NETLINK" - "AF_UNIX" - "AF_PACKET" - ]; - RestrictNamespaces = true; - RestrictRealtime = true; - UMask = "0022"; - }; }; - }; } diff --git a/nixos/modules/services/networking/gnunet.nix b/nixos/modules/services/networking/gnunet.nix index 7380f22c13f2f2..a00c0e8e923d75 100644 --- a/nixos/modules/services/networking/gnunet.nix +++ b/nixos/modules/services/networking/gnunet.nix @@ -1,35 +1,39 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.gnunet; stateDir = "/var/lib/gnunet"; - configFile = with cfg; - '' - [PATHS] - GNUNET_HOME = ${stateDir} - GNUNET_RUNTIME_DIR = /run/gnunet - GNUNET_USER_RUNTIME_DIR = /run/gnunet - GNUNET_DATA_HOME = ${stateDir}/data + configFile = with cfg; '' + [PATHS] + GNUNET_HOME = ${stateDir} + GNUNET_RUNTIME_DIR = /run/gnunet + GNUNET_USER_RUNTIME_DIR = /run/gnunet + GNUNET_DATA_HOME = ${stateDir}/data - [ats] - WAN_QUOTA_IN = ${toString load.maxNetDownBandwidth} b - WAN_QUOTA_OUT = ${toString load.maxNetUpBandwidth} b + [ats] + WAN_QUOTA_IN = ${toString load.maxNetDownBandwidth} b + WAN_QUOTA_OUT = ${toString load.maxNetUpBandwidth} b - [datastore] - QUOTA = ${toString fileSharing.quota} MB + [datastore] + QUOTA = ${toString fileSharing.quota} MB - [transport-udp] - PORT = ${toString udp.port} - ADVERTISED_PORT = ${toString udp.port} + [transport-udp] + PORT = ${toString udp.port} + ADVERTISED_PORT = ${toString udp.port} - [transport-tcp] - PORT = ${toString tcp.port} - ADVERTISED_PORT = ${toString tcp.port} + [transport-tcp] + PORT = ${toString tcp.port} + ADVERTISED_PORT = ${toString tcp.port} - ${extraOptions} - ''; + ${extraOptions} + ''; in @@ -63,7 +67,7 @@ in udp = { port = lib.mkOption { type = lib.types.port; - default = 2086; # assigned by IANA + default = 2086; # assigned by IANA description = '' The UDP port for use by GNUnet. ''; @@ -73,7 +77,7 @@ in tcp = { port = lib.mkOption { type = lib.types.port; - default = 2086; # assigned by IANA + default = 2086; # assigned by IANA description = '' The TCP port for use by GNUnet. ''; @@ -125,7 +129,6 @@ in }; - ###### implementation config = lib.mkIf config.services.gnunet.enable { @@ -149,7 +152,10 @@ in after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; restartTriggers = [ config.environment.etc."gnunet.conf".source ]; - path = [ cfg.package pkgs.miniupnpc ]; + path = [ + cfg.package + pkgs.miniupnpc + ]; serviceConfig.ExecStart = "${cfg.package}/lib/gnunet/libexec/gnunet-service-arm -c /etc/gnunet.conf"; serviceConfig.User = "gnunet"; serviceConfig.UMask = "0007"; diff --git a/nixos/modules/services/networking/go-autoconfig.nix b/nixos/modules/services/networking/go-autoconfig.nix index b31ef227c587f7..b7ed11405003c0 100644 --- a/nixos/modules/services/networking/go-autoconfig.nix +++ b/nixos/modules/services/networking/go-autoconfig.nix @@ -1,11 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.go-autoconfig; format = pkgs.formats.yaml { }; configFile = format.generate "config.yml" cfg.settings; -in { +in +{ options = { services.go-autoconfig = { diff --git a/nixos/modules/services/networking/go-camo.nix b/nixos/modules/services/networking/go-camo.nix index adf80901cdc988..3bf4687895f2bb 100644 --- a/nixos/modules/services/networking/go-camo.nix +++ b/nixos/modules/services/networking/go-camo.nix @@ -1,8 +1,20 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: let cfg = config.services.go-camo; - inherit (lib) mkOption mkEnableOption mkIf mkMerge types optionalString; + inherit (lib) + mkOption + mkEnableOption + mkIf + mkMerge + types + optionalString + ; in { options.services.go-camo = { @@ -41,7 +53,7 @@ in }; extraOptions = mkOption { type = with types; listOf str; - default = []; + default = [ ]; description = "Extra options passed to the go-camo command."; }; }; @@ -57,7 +69,20 @@ in script = '' GOCAMO_HMAC="$(cat "$GOCAMO_HMAC_FILE")" export GOCAMO_HMAC - exec ${lib.escapeShellArgs(lib.lists.remove "" ([ "${pkgs.go-camo}/bin/go-camo" cfg.listen cfg.sslListen cfg.sslKey cfg.sslCert ] ++ cfg.extraOptions))} + exec ${ + lib.escapeShellArgs ( + lib.lists.remove "" ( + [ + "${pkgs.go-camo}/bin/go-camo" + cfg.listen + cfg.sslListen + cfg.sslKey + cfg.sslCert + ] + ++ cfg.extraOptions + ) + ) + } ''; serviceConfig = { NoNewPrivileges = true; diff --git a/nixos/modules/services/networking/go-neb.nix b/nixos/modules/services/networking/go-neb.nix index 4a43c574ff5308..ae0ce8147e6281 100644 --- a/nixos/modules/services/networking/go-neb.nix +++ b/nixos/modules/services/networking/go-neb.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.go-neb; - settingsFormat = pkgs.formats.yaml {}; + settingsFormat = pkgs.formats.yaml { }; configFile = settingsFormat.generate "config.yaml" cfg.config; -in { +in +{ options.services.go-neb = { enable = lib.mkEnableOption "an extensible matrix bot written in Go"; @@ -43,33 +49,40 @@ in { }; config = lib.mkIf cfg.enable { - systemd.services.go-neb = let - finalConfigFile = if cfg.secretFile == null then configFile else "/var/run/go-neb/config.yaml"; - in { - description = "Extensible matrix bot written in Go"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - environment = { - BASE_URL = cfg.baseUrl; - BIND_ADDRESS = cfg.bindAddress; - CONFIG_FILE = finalConfigFile; - }; + systemd.services.go-neb = + let + finalConfigFile = if cfg.secretFile == null then configFile else "/var/run/go-neb/config.yaml"; + in + { + description = "Extensible matrix bot written in Go"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + environment = { + BASE_URL = cfg.baseUrl; + BIND_ADDRESS = cfg.bindAddress; + CONFIG_FILE = finalConfigFile; + }; - serviceConfig = { - ExecStartPre = lib.optional (cfg.secretFile != null) - ("+" + pkgs.writeShellScript "pre-start" '' - umask 077 - export $(xargs < ${cfg.secretFile}) - ${pkgs.envsubst}/bin/envsubst -i "${configFile}" > ${finalConfigFile} - chown go-neb ${finalConfigFile} - ''); - RuntimeDirectory = "go-neb"; - ExecStart = "${pkgs.go-neb}/bin/go-neb"; - User = "go-neb"; - DynamicUser = true; + serviceConfig = { + ExecStartPre = lib.optional (cfg.secretFile != null) ( + "+" + + pkgs.writeShellScript "pre-start" '' + umask 077 + export $(xargs < ${cfg.secretFile}) + ${pkgs.envsubst}/bin/envsubst -i "${configFile}" > ${finalConfigFile} + chown go-neb ${finalConfigFile} + '' + ); + RuntimeDirectory = "go-neb"; + ExecStart = "${pkgs.go-neb}/bin/go-neb"; + User = "go-neb"; + DynamicUser = true; + }; }; - }; }; - meta.maintainers = with lib.maintainers; [ hexa maralorn ]; + meta.maintainers = with lib.maintainers; [ + hexa + maralorn + ]; } diff --git a/nixos/modules/services/networking/go-shadowsocks2.nix b/nixos/modules/services/networking/go-shadowsocks2.nix index 438d3fb1c0a608..810c3b48eae17e 100644 --- a/nixos/modules/services/networking/go-shadowsocks2.nix +++ b/nixos/modules/services/networking/go-shadowsocks2.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.go-shadowsocks2.server; -in { +in +{ options.services.go-shadowsocks2.server = { enable = lib.mkEnableOption "go-shadowsocks2 server"; diff --git a/nixos/modules/services/networking/gobgpd.nix b/nixos/modules/services/networking/gobgpd.nix index 79f1adf4e314d8..bc56927ee28c66 100644 --- a/nixos/modules/services/networking/gobgpd.nix +++ b/nixos/modules/services/networking/gobgpd.nix @@ -1,9 +1,15 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.gobgpd; format = pkgs.formats.toml { }; confFile = format.generate "gobgpd.conf" cfg.settings; -in { +in +{ options.services.gobgpd = { enable = lib.mkEnableOption "GoBGP Routing Daemon"; diff --git a/nixos/modules/services/networking/gvpe.nix b/nixos/modules/services/networking/gvpe.nix index 275146ada2d0f5..dc948d50788dcf 100644 --- a/nixos/modules/services/networking/gvpe.nix +++ b/nixos/modules/services/networking/gvpe.nix @@ -1,42 +1,49 @@ # GNU Virtual Private Ethernet -{config, pkgs, lib, ...}: +{ + config, + pkgs, + lib, + ... +}: let inherit (lib) mkOption mkIf types; cfg = config.services.gvpe; - finalConfig = if cfg.configFile != null then - cfg.configFile - else if cfg.configText != null then - pkgs.writeTextFile { - name = "gvpe.conf"; - text = cfg.configText; - } - else - throw "You must either specify contents of the config file or the config file itself for GVPE"; + finalConfig = + if cfg.configFile != null then + cfg.configFile + else if cfg.configText != null then + pkgs.writeTextFile { + name = "gvpe.conf"; + text = cfg.configText; + } + else + throw "You must either specify contents of the config file or the config file itself for GVPE"; - ifupScript = if cfg.ipAddress == null || cfg.subnet == null then - throw "Specify IP address and subnet (with mask) for GVPE" - else if cfg.nodename == null then - throw "You must set node name for GVPE" - else - (pkgs.writeTextFile { - name = "gvpe-if-up"; - text = '' - #! /bin/sh + ifupScript = + if cfg.ipAddress == null || cfg.subnet == null then + throw "Specify IP address and subnet (with mask) for GVPE" + else if cfg.nodename == null then + throw "You must set node name for GVPE" + else + (pkgs.writeTextFile { + name = "gvpe-if-up"; + text = '' + #! /bin/sh - export PATH=$PATH:${pkgs.iproute2}/sbin + export PATH=$PATH:${pkgs.iproute2}/sbin - ip link set dev $IFNAME up - ip address add ${cfg.ipAddress} dev $IFNAME - ip route add ${cfg.subnet} dev $IFNAME + ip link set dev $IFNAME up + ip address add ${cfg.ipAddress} dev $IFNAME + ip route add ${cfg.subnet} dev $IFNAME - ${cfg.customIFSetup} - ''; - executable = true; - }); + ${cfg.customIFSetup} + ''; + executable = true; + }); in { @@ -119,7 +126,8 @@ in cp ${ifupScript} /var/gvpe/if-up ''; - script = "${pkgs.gvpe}/sbin/gvpe -c /var/gvpe -D ${cfg.nodename} " + script = + "${pkgs.gvpe}/sbin/gvpe -c /var/gvpe -D ${cfg.nodename} " + " ${cfg.nodename}.pid-file=/var/gvpe/gvpe.pid" + " ${cfg.nodename}.if-up=if-up" + " &> /var/log/gvpe"; diff --git a/nixos/modules/services/networking/hans.nix b/nixos/modules/services/networking/hans.nix index b1cb37158a0438..82cd3e8a00dd9d 100644 --- a/nixos/modules/services/networking/hans.nix +++ b/nixos/modules/services/networking/hans.nix @@ -1,5 +1,10 @@ # NixOS module for hans, ip over icmp daemon -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hans; @@ -14,7 +19,7 @@ in services.hans = { clients = lib.mkOption { - default = {}; + default = { }; description = '' Each attribute of this option defines a systemd service that runs hans. Many or none may be defined. @@ -24,38 +29,39 @@ in corresponding attribute name. ''; example = lib.literalExpression '' - { - foo = { - server = "192.0.2.1"; - extraConfig = "-v"; + { + foo = { + server = "192.0.2.1"; + extraConfig = "-v"; + } } - } ''; - type = lib.types.attrsOf (lib.types.submodule ( - { - options = { - server = lib.mkOption { - type = lib.types.str; - default = ""; - description = "IP address of server running hans"; - example = "192.0.2.1"; - }; + type = lib.types.attrsOf ( + lib.types.submodule ({ + options = { + server = lib.mkOption { + type = lib.types.str; + default = ""; + description = "IP address of server running hans"; + example = "192.0.2.1"; + }; + + extraConfig = lib.mkOption { + type = lib.types.str; + default = ""; + description = "Additional command line parameters"; + example = "-v"; + }; + + passwordFile = lib.mkOption { + type = lib.types.str; + default = ""; + description = "File that contains password"; + }; - extraConfig = lib.mkOption { - type = lib.types.str; - default = ""; - description = "Additional command line parameters"; - example = "-v"; }; - - passwordFile = lib.mkOption { - type = lib.types.str; - default = ""; - description = "File that contains password"; - }; - - }; - })); + }) + ); }; server = { @@ -97,7 +103,7 @@ in ### implementation - config = lib.mkIf (cfg.server.enable || cfg.clients != {}) { + config = lib.mkIf (cfg.server.enable || cfg.clients != { }) { boot.kernel.sysctl = lib.optionalAttrs cfg.server.respondToSystemPings { "net.ipv4.icmp_echo_ignore_all" = 1; }; @@ -105,31 +111,35 @@ in boot.kernelModules = [ "tun" ]; systemd.services = - let - createHansClientService = name: cfg: - { - description = "hans client - ${name}"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - script = "${pkgs.hans}/bin/hans -f -u ${hansUser} ${cfg.extraConfig} -c ${cfg.server} ${lib.optionalString (cfg.passwordFile != "") "-p $(cat \"${cfg.passwordFile}\")"}"; - serviceConfig = { - RestartSec = "30s"; - Restart = "always"; + let + createHansClientService = name: cfg: { + description = "hans client - ${name}"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + script = "${pkgs.hans}/bin/hans -f -u ${hansUser} ${cfg.extraConfig} -c ${cfg.server} ${ + lib.optionalString (cfg.passwordFile != "") "-p $(cat \"${cfg.passwordFile}\")" + }"; + serviceConfig = { + RestartSec = "30s"; + Restart = "always"; + }; + }; + in + lib.listToAttrs ( + lib.mapAttrsToList ( + name: value: lib.nameValuePair "hans-${name}" (createHansClientService name value) + ) cfg.clients + ) + // { + hans = lib.mkIf (cfg.server.enable) { + description = "hans, ip over icmp server daemon"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + script = "${pkgs.hans}/bin/hans -f -u ${hansUser} ${cfg.server.extraConfig} -s ${cfg.server.ip} ${lib.optionalString cfg.server.respondToSystemPings "-r"} ${ + lib.optionalString (cfg.server.passwordFile != "") "-p $(cat \"${cfg.server.passwordFile}\")" + }"; }; }; - in - lib.listToAttrs ( - lib.mapAttrsToList - (name: value: lib.nameValuePair "hans-${name}" (createHansClientService name value)) - cfg.clients - ) // { - hans = lib.mkIf (cfg.server.enable) { - description = "hans, ip over icmp server daemon"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - script = "${pkgs.hans}/bin/hans -f -u ${hansUser} ${cfg.server.extraConfig} -s ${cfg.server.ip} ${lib.optionalString cfg.server.respondToSystemPings "-r"} ${lib.optionalString (cfg.server.passwordFile != "") "-p $(cat \"${cfg.server.passwordFile}\")"}"; - }; - }; users.users.${hansUser} = { description = "Hans daemon user"; diff --git a/nixos/modules/services/networking/haproxy.nix b/nixos/modules/services/networking/haproxy.nix index 23c06f2949808d..0397b5f2d6413f 100644 --- a/nixos/modules/services/networking/haproxy.nix +++ b/nixos/modules/services/networking/haproxy.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.haproxy; haproxyCfg = pkgs.writeText "haproxy.conf" '' @@ -41,10 +46,12 @@ in config = lib.mkIf cfg.enable { - assertions = [{ - assertion = cfg.config != null; - message = "You must provide services.haproxy.config."; - }]; + assertions = [ + { + assertion = cfg.config != null; + message = "You must provide services.haproxy.config."; + } + ]; # configuration file indirection is needed to support reloading environment.etc."haproxy.cfg".source = haproxyCfg; @@ -82,7 +89,7 @@ in ProtectKernelTunables = true; ProtectKernelModules = true; ProtectControlGroups = true; - SystemCallFilter= "~@cpu-emulation @keyring @module @obsolete @raw-io @reboot @swap @sync"; + SystemCallFilter = "~@cpu-emulation @keyring @module @obsolete @raw-io @reboot @swap @sync"; # needed in case we bind to port < 1024 AmbientCapabilities = "CAP_NET_BIND_SERVICE"; }; @@ -96,7 +103,7 @@ in }; users.groups = lib.optionalAttrs (cfg.group == "haproxy") { - haproxy = {}; + haproxy = { }; }; }; } diff --git a/nixos/modules/services/networking/harmonia.nix b/nixos/modules/services/networking/harmonia.nix index ac5c35ddb280bc..8f495bb0cca163 100644 --- a/nixos/modules/services/networking/harmonia.nix +++ b/nixos/modules/services/networking/harmonia.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.harmonia; format = pkgs.formats.toml { }; @@ -40,8 +45,9 @@ in }; config = lib.mkIf cfg.enable { - warnings = lib.optional (cfg.signKeyPath != null) - "`services.harmonia.signKeyPath` is deprecated, use `services.harmonia.signKeyPaths` instead"; + warnings = lib.optional ( + cfg.signKeyPath != null + ) "`services.harmonia.signKeyPath` is deprecated, use `services.harmonia.signKeyPaths` instead"; nix.settings.extra-allowed-users = [ "harmonia" ]; users.users.harmonia = { isSystemUser = true; diff --git a/nixos/modules/services/networking/headscale.nix b/nixos/modules/services/networking/headscale.nix index 9261ec03c53254..495dc6650e60b5 100644 --- a/nixos/modules/services/networking/headscale.nix +++ b/nixos/modules/services/networking/headscale.nix @@ -3,7 +3,8 @@ lib, pkgs, ... -}: let +}: +let cfg = config.services.headscale; dataDir = "/var/lib/headscale"; @@ -17,20 +18,22 @@ unix_socket = "${runDir}/headscale.sock"; }; - settingsFormat = pkgs.formats.yaml {}; + settingsFormat = pkgs.formats.yaml { }; configFile = settingsFormat.generate "headscale.yaml" cfg.settings; cliConfigFile = settingsFormat.generate "headscale.yaml" cliConfig; assertRemovedOption = option: message: { assertion = !lib.hasAttrByPath option cfg; - message = "The option `services.headscale.${lib.options.showOption option}` was removed. " + message; + message = + "The option `services.headscale.${lib.options.showOption option}` was removed. " + message; }; -in { +in +{ options = { services.headscale = { enable = lib.mkEnableOption "headscale, Open Source coordination server for Tailscale"; - package = lib.mkPackageOption pkgs "headscale" {}; + package = lib.mkPackageOption pkgs "headscale" { }; user = lib.mkOption { default = "headscale"; @@ -105,42 +108,47 @@ in { ''; }; - prefixes = let - prefDesc = '' - Each prefix consists of either an IPv4 or IPv6 address, - and the associated prefix length, delimited by a slash. - It must be within IP ranges supported by the Tailscale - client - i.e., subnets of 100.64.0.0/10 and fd7a:115c:a1e0::/48. - ''; - in { - v4 = lib.mkOption { - type = lib.types.str; - default = "100.64.0.0/10"; - description = prefDesc; - }; + prefixes = + let + prefDesc = '' + Each prefix consists of either an IPv4 or IPv6 address, + and the associated prefix length, delimited by a slash. + It must be within IP ranges supported by the Tailscale + client - i.e., subnets of 100.64.0.0/10 and fd7a:115c:a1e0::/48. + ''; + in + { + v4 = lib.mkOption { + type = lib.types.str; + default = "100.64.0.0/10"; + description = prefDesc; + }; - v6 = lib.mkOption { - type = lib.types.str; - default = "fd7a:115c:a1e0::/48"; - description = prefDesc; - }; + v6 = lib.mkOption { + type = lib.types.str; + default = "fd7a:115c:a1e0::/48"; + description = prefDesc; + }; - allocation = lib.mkOption { - type = lib.types.enum ["sequential" "random"]; - example = "random"; - default = "sequential"; - description = '' - Strategy used for allocation of IPs to nodes, available options: - - sequential (default): assigns the next free IP from the previous given IP. - - random: assigns the next free IP from a pseudo-random IP generator (crypto/rand). - ''; + allocation = lib.mkOption { + type = lib.types.enum [ + "sequential" + "random" + ]; + example = "random"; + default = "sequential"; + description = '' + Strategy used for allocation of IPs to nodes, available options: + - sequential (default): assigns the next free IP from the previous given IP. + - random: assigns the next free IP from a pseudo-random IP generator (crypto/rand). + ''; + }; }; - }; derp = { urls = lib.mkOption { type = lib.types.listOf lib.types.str; - default = ["https://controlplane.tailscale.com/derpmap/default"]; + default = [ "https://controlplane.tailscale.com/derpmap/default" ]; description = '' List of urls containing DERP maps. See [How Tailscale works](https://tailscale.com/blog/how-tailscale-works/) for more information on DERP maps. @@ -149,7 +157,7 @@ in { paths = lib.mkOption { type = lib.types.listOf lib.types.path; - default = []; + default = [ ]; description = '' List of file paths containing DERP maps. See [How Tailscale works](https://tailscale.com/blog/how-tailscale-works/) for more information on DERP maps. @@ -194,7 +202,11 @@ in { database = { type = lib.mkOption { - type = lib.types.enum ["sqlite" "sqlite3" "postgres"]; + type = lib.types.enum [ + "sqlite" + "sqlite3" + "postgres" + ]; example = "postgres"; default = "sqlite"; description = '' @@ -310,7 +322,7 @@ in { nameservers = { global = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' List of nameservers to pass to Tailscale clients. ''; @@ -319,11 +331,11 @@ in { search_domains = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Search domains to inject to Tailscale clients. ''; - example = ["mydomain.internal"]; + example = [ "mydomain.internal" ]; }; }; @@ -355,7 +367,11 @@ in { scope = lib.mkOption { type = lib.types.listOf lib.types.str; - default = ["openid" "profile" "email"]; + default = [ + "openid" + "profile" + "email" + ]; description = '' Scopes used in the OIDC flow. ''; @@ -363,7 +379,7 @@ in { extra_params = lib.mkOption { type = lib.types.attrsOf lib.types.str; - default = {}; + default = { }; description = '' Custom query parameters to send with the Authorize Endpoint request. ''; @@ -374,21 +390,21 @@ in { allowed_domains = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Allowed principal domains. if an authenticated user's domain is not in this list authentication request will be rejected. ''; - example = ["example.com"]; + example = [ "example.com" ]; }; allowed_users = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Users allowed to authenticate even if not in allowedDomains. ''; - example = ["alice@example.com"]; + example = [ "alice@example.com" ]; }; strip_email_domain = lib.mkOption { @@ -409,7 +425,10 @@ in { }; tls_letsencrypt_challenge_type = lib.mkOption { - type = lib.types.enum ["TLS-ALPN-01" "HTTP-01"]; + type = lib.types.enum [ + "TLS-ALPN-01" + "HTTP-01" + ]; default = "HTTP-01"; description = '' Type of ACME challenge to use, currently supported types: @@ -445,7 +464,10 @@ in { policy = { mode = lib.mkOption { - type = lib.types.enum ["file" "database"]; + type = lib.types.enum [ + "file" + "database" + ]; default = "file"; description = '' The mode can be "file" or "database" that defines @@ -469,23 +491,68 @@ in { }; imports = with lib; [ - (mkRenamedOptionModule ["services" "headscale" "derp" "autoUpdate"] ["services" "headscale" "settings" "derp" "auto_update_enable"]) - (mkRenamedOptionModule ["services" "headscale" "derp" "paths"] ["services" "headscale" "settings" "derp" "paths"]) - (mkRenamedOptionModule ["services" "headscale" "derp" "updateFrequency"] ["services" "headscale" "settings" "derp" "update_frequency"]) - (mkRenamedOptionModule ["services" "headscale" "derp" "urls"] ["services" "headscale" "settings" "derp" "urls"]) - (mkRenamedOptionModule ["services" "headscale" "ephemeralNodeInactivityTimeout"] ["services" "headscale" "settings" "ephemeral_node_inactivity_timeout"]) - (mkRenamedOptionModule ["services" "headscale" "logLevel"] ["services" "headscale" "settings" "log" "level"]) - (mkRenamedOptionModule ["services" "headscale" "openIdConnect" "clientId"] ["services" "headscale" "settings" "oidc" "client_id"]) - (mkRenamedOptionModule ["services" "headscale" "openIdConnect" "clientSecretFile"] ["services" "headscale" "settings" "oidc" "client_secret_path"]) - (mkRenamedOptionModule ["services" "headscale" "openIdConnect" "issuer"] ["services" "headscale" "settings" "oidc" "issuer"]) - (mkRenamedOptionModule ["services" "headscale" "serverUrl"] ["services" "headscale" "settings" "server_url"]) - (mkRenamedOptionModule ["services" "headscale" "tls" "certFile"] ["services" "headscale" "settings" "tls_cert_path"]) - (mkRenamedOptionModule ["services" "headscale" "tls" "keyFile"] ["services" "headscale" "settings" "tls_key_path"]) - (mkRenamedOptionModule ["services" "headscale" "tls" "letsencrypt" "challengeType"] ["services" "headscale" "settings" "tls_letsencrypt_challenge_type"]) - (mkRenamedOptionModule ["services" "headscale" "tls" "letsencrypt" "hostname"] ["services" "headscale" "settings" "tls_letsencrypt_hostname"]) - (mkRenamedOptionModule ["services" "headscale" "tls" "letsencrypt" "httpListen"] ["services" "headscale" "settings" "tls_letsencrypt_listen"]) - - (mkRemovedOptionModule ["services" "headscale" "openIdConnect" "domainMap"] '' + (mkRenamedOptionModule + [ "services" "headscale" "derp" "autoUpdate" ] + [ "services" "headscale" "settings" "derp" "auto_update_enable" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "derp" "paths" ] + [ "services" "headscale" "settings" "derp" "paths" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "derp" "updateFrequency" ] + [ "services" "headscale" "settings" "derp" "update_frequency" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "derp" "urls" ] + [ "services" "headscale" "settings" "derp" "urls" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "ephemeralNodeInactivityTimeout" ] + [ "services" "headscale" "settings" "ephemeral_node_inactivity_timeout" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "logLevel" ] + [ "services" "headscale" "settings" "log" "level" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "openIdConnect" "clientId" ] + [ "services" "headscale" "settings" "oidc" "client_id" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "openIdConnect" "clientSecretFile" ] + [ "services" "headscale" "settings" "oidc" "client_secret_path" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "openIdConnect" "issuer" ] + [ "services" "headscale" "settings" "oidc" "issuer" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "serverUrl" ] + [ "services" "headscale" "settings" "server_url" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "tls" "certFile" ] + [ "services" "headscale" "settings" "tls_cert_path" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "tls" "keyFile" ] + [ "services" "headscale" "settings" "tls_key_path" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "tls" "letsencrypt" "challengeType" ] + [ "services" "headscale" "settings" "tls_letsencrypt_challenge_type" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "tls" "letsencrypt" "hostname" ] + [ "services" "headscale" "settings" "tls_letsencrypt_hostname" ] + ) + (mkRenamedOptionModule + [ "services" "headscale" "tls" "letsencrypt" "httpListen" ] + [ "services" "headscale" "settings" "tls_letsencrypt_listen" ] + ) + + (mkRemovedOptionModule [ "services" "headscale" "openIdConnect" "domainMap" ] '' Headscale no longer uses domain_map. If you're using an old version of headscale you can still set this option via services.headscale.settings.oidc.domain_map. '') ]; @@ -495,24 +562,35 @@ in { { # This is stricter than it needs to be but is exactly what upstream does: # https://github.com/kradalby/headscale/blob/adc084f20f843d7963c999764fa83939668d2d2c/hscontrol/types/config.go#L799 - assertion = with cfg.settings; dns.use_username_in_magic_dns or false || dns.base_domain == "" || !lib.hasInfix dns.base_domain server_url; + assertion = + with cfg.settings; + dns.use_username_in_magic_dns or false + || dns.base_domain == "" + || !lib.hasInfix dns.base_domain server_url; message = "server_url cannot contain the base_domain, this will cause the headscale server and embedded DERP to become unreachable from the Tailscale node."; } { assertion = with cfg.settings; dns.magic_dns -> dns.base_domain != ""; message = "dns.base_domain must be set when using MagicDNS"; } - (assertRemovedOption ["settings" "acl_policy_path"] "Use `policy.path` instead.") - (assertRemovedOption ["settings" "db_host"] "Use `database.postgres.host` instead.") - (assertRemovedOption ["settings" "db_name"] "Use `database.postgres.name` instead.") - (assertRemovedOption ["settings" "db_password_file"] "Use `database.postgres.password_file` instead.") - (assertRemovedOption ["settings" "db_path"] "Use `database.sqlite.path` instead.") - (assertRemovedOption ["settings" "db_port"] "Use `database.postgres.port` instead.") - (assertRemovedOption ["settings" "db_type"] "Use `database.type` instead.") - (assertRemovedOption ["settings" "db_user"] "Use `database.postgres.user` instead.") - (assertRemovedOption ["settings" "dns_config"] "Use `dns` instead.") - (assertRemovedOption ["settings" "dns_config" "domains"] "Use `dns.search_domains` instead.") - (assertRemovedOption ["settings" "dns_config" "nameservers"] "Use `dns.nameservers.global` instead.") + (assertRemovedOption [ "settings" "acl_policy_path" ] "Use `policy.path` instead.") + (assertRemovedOption [ "settings" "db_host" ] "Use `database.postgres.host` instead.") + (assertRemovedOption [ "settings" "db_name" ] "Use `database.postgres.name` instead.") + (assertRemovedOption [ + "settings" + "db_password_file" + ] "Use `database.postgres.password_file` instead.") + (assertRemovedOption [ "settings" "db_path" ] "Use `database.sqlite.path` instead.") + (assertRemovedOption [ "settings" "db_port" ] "Use `database.postgres.port` instead.") + (assertRemovedOption [ "settings" "db_type" ] "Use `database.type` instead.") + (assertRemovedOption [ "settings" "db_user" ] "Use `database.postgres.user` instead.") + (assertRemovedOption [ "settings" "dns_config" ] "Use `dns` instead.") + (assertRemovedOption [ "settings" "dns_config" "domains" ] "Use `dns.search_domains` instead.") + (assertRemovedOption [ + "settings" + "dns_config" + "nameservers" + ] "Use `dns.nameservers.global` instead.") ]; services.headscale.settings = lib.mkMerge [ @@ -529,10 +607,10 @@ in { # to talk to the server instance. etc."headscale/config.yaml".source = cliConfigFile; - systemPackages = [cfg.package]; + systemPackages = [ cfg.package ]; }; - users.groups.headscale = lib.mkIf (cfg.group == "headscale") {}; + users.groups.headscale = lib.mkIf (cfg.group == "headscale") { }; users.users.headscale = lib.mkIf (cfg.user == "headscale") { description = "headscale user"; @@ -543,9 +621,9 @@ in { systemd.services.headscale = { description = "headscale coordination server for Tailscale"; - wants = ["network-online.target"]; - after = ["network-online.target"]; - wantedBy = ["multi-user.target"]; + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; + wantedBy = [ "multi-user.target" ]; script = '' ${lib.optionalString (cfg.settings.database.postgres.password_file != null) '' @@ -555,51 +633,60 @@ in { exec ${lib.getExe cfg.package} serve --config ${configFile} ''; - serviceConfig = let - capabilityBoundingSet = ["CAP_CHOWN"] ++ lib.optional (cfg.port < 1024) "CAP_NET_BIND_SERVICE"; - in { - Restart = "always"; - Type = "simple"; - User = cfg.user; - Group = cfg.group; - - # Hardening options - RuntimeDirectory = "headscale"; - # Allow headscale group access so users can be added and use the CLI. - RuntimeDirectoryMode = "0750"; - - StateDirectory = "headscale"; - StateDirectoryMode = "0750"; - - ProtectSystem = "strict"; - ProtectHome = true; - PrivateTmp = true; - PrivateDevices = true; - ProtectKernelTunables = true; - ProtectControlGroups = true; - RestrictSUIDSGID = true; - PrivateMounts = true; - ProtectKernelModules = true; - ProtectKernelLogs = true; - ProtectHostname = true; - ProtectClock = true; - ProtectProc = "invisible"; - ProcSubset = "pid"; - RestrictNamespaces = true; - RemoveIPC = true; - UMask = "0077"; - - CapabilityBoundingSet = capabilityBoundingSet; - AmbientCapabilities = capabilityBoundingSet; - NoNewPrivileges = true; - LockPersonality = true; - RestrictRealtime = true; - SystemCallFilter = ["@system-service" "~@privileged" "@chown"]; - SystemCallArchitectures = "native"; - RestrictAddressFamilies = "AF_INET AF_INET6 AF_UNIX"; - }; + serviceConfig = + let + capabilityBoundingSet = [ "CAP_CHOWN" ] ++ lib.optional (cfg.port < 1024) "CAP_NET_BIND_SERVICE"; + in + { + Restart = "always"; + Type = "simple"; + User = cfg.user; + Group = cfg.group; + + # Hardening options + RuntimeDirectory = "headscale"; + # Allow headscale group access so users can be added and use the CLI. + RuntimeDirectoryMode = "0750"; + + StateDirectory = "headscale"; + StateDirectoryMode = "0750"; + + ProtectSystem = "strict"; + ProtectHome = true; + PrivateTmp = true; + PrivateDevices = true; + ProtectKernelTunables = true; + ProtectControlGroups = true; + RestrictSUIDSGID = true; + PrivateMounts = true; + ProtectKernelModules = true; + ProtectKernelLogs = true; + ProtectHostname = true; + ProtectClock = true; + ProtectProc = "invisible"; + ProcSubset = "pid"; + RestrictNamespaces = true; + RemoveIPC = true; + UMask = "0077"; + + CapabilityBoundingSet = capabilityBoundingSet; + AmbientCapabilities = capabilityBoundingSet; + NoNewPrivileges = true; + LockPersonality = true; + RestrictRealtime = true; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "@chown" + ]; + SystemCallArchitectures = "native"; + RestrictAddressFamilies = "AF_INET AF_INET6 AF_UNIX"; + }; }; }; - meta.maintainers = with lib.maintainers; [kradalby misterio77]; + meta.maintainers = with lib.maintainers; [ + kradalby + misterio77 + ]; } diff --git a/nixos/modules/services/networking/helpers.nix b/nixos/modules/services/networking/helpers.nix index d7d42de0e3a868..9b3539de63b113 100644 --- a/nixos/modules/services/networking/helpers.nix +++ b/nixos/modules/services/networking/helpers.nix @@ -1,11 +1,10 @@ -{ config, lib, ... }: '' +{ config, lib, ... }: +'' # Helper command to manipulate both the IPv4 and IPv6 tables. ip46tables() { iptables -w "$@" - ${ - lib.optionalString config.networking.enableIPv6 '' - ip6tables -w "$@" - '' - } + ${lib.optionalString config.networking.enableIPv6 '' + ip6tables -w "$@" + ''} } '' diff --git a/nixos/modules/services/networking/htpdate.nix b/nixos/modules/services/networking/htpdate.nix index fa422854872c60..39ccac19e14a3a 100644 --- a/nixos/modules/services/networking/htpdate.nix +++ b/nixos/modules/services/networking/htpdate.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (pkgs) htpdate; diff --git a/nixos/modules/services/networking/https-dns-proxy.nix b/nixos/modules/services/networking/https-dns-proxy.nix index 63c38d20ac8f28..2476edf4a469e8 100644 --- a/nixos/modules/services/networking/https-dns-proxy.nix +++ b/nixos/modules/services/networking/https-dns-proxy.nix @@ -1,27 +1,48 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) concatStringsSep - mkEnableOption mkIf mkOption types; + mkEnableOption + mkIf + mkOption + types + ; cfg = config.services.https-dns-proxy; providers = { cloudflare = { - ips = [ "1.1.1.1" "1.0.0.1" ]; + ips = [ + "1.1.1.1" + "1.0.0.1" + ]; url = "https://cloudflare-dns.com/dns-query"; }; google = { - ips = [ "8.8.8.8" "8.8.4.4" ]; + ips = [ + "8.8.8.8" + "8.8.4.4" + ]; url = "https://dns.google/dns-query"; }; quad9 = { - ips = [ "9.9.9.9" "149.112.112.112" ]; + ips = [ + "9.9.9.9" + "149.112.112.112" + ]; url = "https://dns.quad9.net/dns-query"; }; opendns = { - ips = [ "208.67.222.222" "208.67.220.220" ]; + ips = [ + "208.67.222.222" + "208.67.220.220" + ]; url = "https://doh.opendns.com/dns-query"; }; custom = { @@ -31,13 +52,12 @@ let defaultProvider = "quad9"; - providerCfg = - concatStringsSep " " [ - "-b" - (concatStringsSep "," providers."${cfg.provider.kind}".ips) - "-r" - providers."${cfg.provider.kind}".url - ]; + providerCfg = concatStringsSep " " [ + "-b" + (concatStringsSep "," providers."${cfg.provider.kind}".ips) + "-r" + providers."${cfg.provider.kind}".url + ]; in { diff --git a/nixos/modules/services/networking/hylafax/default.nix b/nixos/modules/services/networking/hylafax/default.nix index d8ffa3fc04d201..9880612c73aefa 100644 --- a/nixos/modules/services/networking/hylafax/default.nix +++ b/nixos/modules/services/networking/hylafax/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { @@ -16,14 +21,16 @@ isSystemUser = true; inherit (config.users.users.nobody) home; }; - assertions = [{ - assertion = config.services.hylafax.modems != {}; - message = '' - HylaFAX cannot be used without modems. - Please define at least one modem with - . - ''; - }]; + assertions = [ + { + assertion = config.services.hylafax.modems != { }; + message = '' + HylaFAX cannot be used without modems. + Please define at least one modem with + . + ''; + } + ]; }; meta.maintainers = [ lib.maintainers.yarny ]; diff --git a/nixos/modules/services/networking/hylafax/modem-default.nix b/nixos/modules/services/networking/hylafax/modem-default.nix index 707b82092829a7..9251f9d048c325 100644 --- a/nixos/modules/services/networking/hylafax/modem-default.nix +++ b/nixos/modules/services/networking/hylafax/modem-default.nix @@ -7,8 +7,8 @@ TagLineFont = "etc/LiberationSans-25.pcf"; TagLineLocale = "en_US.UTF-8"; - AdminGroup = "root"; # groups that can change server config - AnswerRotary = "fax"; # don't accept anything else but faxes + AdminGroup = "root"; # groups that can change server config + AnswerRotary = "fax"; # don't accept anything else but faxes LogFileMode = "0640"; PriorityScheduling = true; RecvFileMode = "0640"; @@ -16,7 +16,7 @@ SessionTracing = "0x78701"; UUCPLockDir = "/var/lock"; - SendPageCmd = "${pkgs.coreutils}/bin/false"; # prevent pager transmit - SendUUCPCmd = "${pkgs.coreutils}/bin/false"; # prevent UUCP transmit + SendPageCmd = "${pkgs.coreutils}/bin/false"; # prevent pager transmit + SendUUCPCmd = "${pkgs.coreutils}/bin/false"; # prevent UUCP transmit } diff --git a/nixos/modules/services/networking/hylafax/options.nix b/nixos/modules/services/networking/hylafax/options.nix index 973dfa054afcb8..8248f2a82eb089 100644 --- a/nixos/modules/services/networking/hylafax/options.nix +++ b/nixos/modules/services/networking/hylafax/options.nix @@ -1,9 +1,25 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib.options) literalExpression mkEnableOption mkOption; - inherit (lib.types) bool enum ints lines attrsOf nonEmptyStr nullOr path str submodule; + inherit (lib.types) + bool + enum + ints + lines + attrsOf + nonEmptyStr + nullOr + path + str + submodule + ; inherit (lib.modules) mkDefault mkIf mkMerge; commonDescr = '' @@ -24,59 +40,65 @@ let # This type definition resolves all # those types into a list of strings. let - inherit (lib.types) attrsOf coercedTo int listOf; - innerType = coercedTo bool (x: if x then "Yes" else "No") - (coercedTo int (toString) str); + inherit (lib.types) + attrsOf + coercedTo + int + listOf + ; + innerType = coercedTo bool (x: if x then "Yes" else "No") (coercedTo int (toString) str); in - attrsOf (coercedTo innerType lib.singleton (listOf innerType)); + attrsOf (coercedTo innerType lib.singleton (listOf innerType)); cfg = config.services.hylafax; - modemConfigOptions = { name, config, ... }: { - options = { - name = mkOption { - type = nonEmptyStr; - example = "ttyS1"; - description = '' - Name of modem device, - will be searched for in {file}`/dev`. - ''; - }; - type = mkOption { - type = nonEmptyStr; - example = "cirrus"; - description = '' - Name of modem configuration file, - will be searched for in {file}`config` - in the spooling area directory. - ''; - }; - config = mkOption { - type = configAttrType; - example = { - AreaCode = "49"; - LocalCode = "30"; - FAXNumber = "123456"; - LocalIdentifier = "LostInBerlin"; + modemConfigOptions = + { name, config, ... }: + { + options = { + name = mkOption { + type = nonEmptyStr; + example = "ttyS1"; + description = '' + Name of modem device, + will be searched for in {file}`/dev`. + ''; + }; + type = mkOption { + type = nonEmptyStr; + example = "cirrus"; + description = '' + Name of modem configuration file, + will be searched for in {file}`config` + in the spooling area directory. + ''; + }; + config = mkOption { + type = configAttrType; + example = { + AreaCode = "49"; + LocalCode = "30"; + FAXNumber = "123456"; + LocalIdentifier = "LostInBerlin"; + }; + description = '' + Attribute set of values for the given modem. + ${commonDescr} + Options defined here override options in + {option}`commonModemConfig` for this modem. + ''; }; - description = '' - Attribute set of values for the given modem. - ${commonDescr} - Options defined here override options in - {option}`commonModemConfig` for this modem. - ''; }; + config.name = mkDefault name; + config.config.Include = [ "config/${config.type}" ]; }; - config.name = mkDefault name; - config.config.Include = [ "config/${config.type}" ]; - }; defaultConfig = let inherit (config.security) wrapperDir; inherit (config.services.mail.sendmailSetuidWrapper) program; mkIfDefault = cond: value: mkIf cond (mkDefault value); - noWrapper = config.services.mail.sendmailSetuidWrapper==null; + noWrapper = config.services.mail.sendmailSetuidWrapper == null; # If a sendmail setuid wrapper exists, # we add the path to the default configuration file. # Otherwise, we use `false` to provoke @@ -85,37 +107,31 @@ let (mkIfDefault noWrapper "${pkgs.coreutils}/bin/false") (mkIfDefault (!noWrapper) "${wrapperDir}/${program}") ]; - importDefaultConfig = file: - lib.attrsets.mapAttrs - (lib.trivial.const mkDefault) - (import file { inherit pkgs; }); + importDefaultConfig = + file: lib.attrsets.mapAttrs (lib.trivial.const mkDefault) (import file { inherit pkgs; }); c.commonModemConfig = importDefaultConfig ./modem-default.nix; c.faxqConfig = importDefaultConfig ./faxq-default.nix; c.hfaxdConfig = importDefaultConfig ./hfaxd-default.nix; in - c; + c; localConfig = let c.hfaxdConfig.UserAccessFile = cfg.userAccessFile; - c.faxqConfig = lib.attrsets.mapAttrs - (lib.trivial.const (v: mkIf (v!=null) v)) - { - AreaCode = cfg.areaCode; - CountryCode = cfg.countryCode; - LongDistancePrefix = cfg.longDistancePrefix; - InternationalPrefix = cfg.internationalPrefix; - }; + c.faxqConfig = lib.attrsets.mapAttrs (lib.trivial.const (v: mkIf (v != null) v)) { + AreaCode = cfg.areaCode; + CountryCode = cfg.countryCode; + LongDistancePrefix = cfg.longDistancePrefix; + InternationalPrefix = cfg.internationalPrefix; + }; c.commonModemConfig = c.faxqConfig; in - c; + c; in - { - options.services.hylafax = { enable = mkEnableOption "HylaFAX server"; @@ -246,7 +262,7 @@ in modems = mkOption { type = attrsOf (submodule [ modemConfigOptions ]); - default = {}; + default = { }; example.ttyS1 = { type = "cirrus"; config = { @@ -327,7 +343,11 @@ in ''; }; faxqclean.archiving = mkOption { - type = enum [ "never" "as-flagged" "always" ]; + type = enum [ + "never" + "as-flagged" + "always" + ]; default = "as-flagged"; example = "always"; description = '' @@ -362,11 +382,9 @@ in }; - - config.services.hylafax = - mkIf - (config.services.hylafax.enable) - (mkMerge [ defaultConfig localConfig ]) - ; + config.services.hylafax = mkIf (config.services.hylafax.enable) (mkMerge [ + defaultConfig + localConfig + ]); } diff --git a/nixos/modules/services/networking/hylafax/systemd.nix b/nixos/modules/services/networking/hylafax/systemd.nix index df6d0f49eec484..8850d961e63d4b 100644 --- a/nixos/modules/services/networking/hylafax/systemd.nix +++ b/nixos/modules/services/networking/hylafax/systemd.nix @@ -1,5 +1,9 @@ -{ config, lib, pkgs, ... }: - +{ + config, + lib, + pkgs, + ... +}: let @@ -9,7 +13,8 @@ let cfg = config.services.hylafax; mapModems = lib.forEach (lib.attrValues cfg.modems); - mkConfigFile = name: conf: + mkConfigFile = + name: conf: # creates hylafax config file, # makes sure "Include" is listed *first* let @@ -17,31 +22,32 @@ let (lib.mapAttrsToList (key: map (val: "${key}: ${val}"))) lib.concatLists ]; - include = mkLines { Include = conf.Include or []; }; - other = mkLines ( conf // { Include = []; } ); + include = mkLines { Include = conf.Include or [ ]; }; + other = mkLines (conf // { Include = [ ]; }); in - pkgs.writeText "hylafax-config${name}" - (concatStringsSep "\n" (include ++ other)); + pkgs.writeText "hylafax-config${name}" (concatStringsSep "\n" (include ++ other)); globalConfigPath = mkConfigFile "" cfg.faxqConfig; modemConfigPath = let - mkModemConfigFile = { config, name, ... }: - mkConfigFile ".${name}" - (cfg.commonModemConfig // config); - mkLine = { name, type, ... }@modem: '' - # check if modem config file exists: - test -f "${pkgs.hylafaxplus}/spool/config/${type}" - ln \ - --symbolic \ - --no-target-directory \ - "${mkModemConfigFile modem}" \ - "$out/config.${name}" - ''; + mkModemConfigFile = + { config, name, ... }: mkConfigFile ".${name}" (cfg.commonModemConfig // config); + mkLine = + { name, type, ... }@modem: + '' + # check if modem config file exists: + test -f "${pkgs.hylafaxplus}/spool/config/${type}" + ln \ + --symbolic \ + --no-target-directory \ + "${mkModemConfigFile modem}" \ + "$out/config.${name}" + ''; in - pkgs.runCommand "hylafax-config-modems" { preferLocalBuild = true; } - ''mkdir --parents "$out/" ${concatStringsSep "\n" (mapModems mkLine)}''; + pkgs.runCommand "hylafax-config-modems" { + preferLocalBuild = true; + } ''mkdir --parents "$out/" ${concatStringsSep "\n" (mapModems mkLine)}''; setupSpoolScript = pkgs.substituteAll { name = "hylafax-setup-spool.sh"; @@ -77,20 +83,17 @@ let paths.hylafax-faxq = { description = "HylaFAX queue manager sendq watch"; - documentation = [ "man:faxq(8)" "man:sendq(5)" ]; + documentation = [ + "man:faxq(8)" + "man:sendq(5)" + ]; wantedBy = [ "multi-user.target" ]; pathConfig.PathExistsGlob = [ "${cfg.spoolAreaPath}/sendq/q*" ]; }; timers = mkMerge [ - ( - mkIf (cfg.faxcron.enable.frequency!=null) - { hylafax-faxcron.timerConfig.Persistent = true; } - ) - ( - mkIf (cfg.faxqclean.enable.frequency!=null) - { hylafax-faxqclean.timerConfig.Persistent = true; } - ) + (mkIf (cfg.faxcron.enable.frequency != null) { hylafax-faxcron.timerConfig.Persistent = true; }) + (mkIf (cfg.faxqclean.enable.frequency != null) { hylafax-faxqclean.timerConfig.Persistent = true; }) ]; hardenService = @@ -103,7 +106,7 @@ let # with some options to customize it. let hardening = { - PrivateDevices = true; # breaks /dev/tty... + PrivateDevices = true; # breaks /dev/tty... PrivateNetwork = true; PrivateTmp = true; #ProtectClock = true; # breaks /dev/tty... (why?) @@ -116,10 +119,10 @@ let RestrictNamespaces = true; RestrictRealtime = true; }; - filter = key: value: (value != null) || ! (lib.hasAttr key hardening); - apply = service: lib.filterAttrs filter (hardening // (service.serviceConfig or {})); + filter = key: value: (value != null) || !(lib.hasAttr key hardening); + apply = service: lib.filterAttrs filter (hardening // (service.serviceConfig or { })); in - service: service // { serviceConfig = apply service; }; + service: service // { serviceConfig = apply service; }; services.hylafax-spool = { description = "HylaFAX spool area preparation"; @@ -145,7 +148,7 @@ let documentation = [ "man:faxq(8)" ]; requires = [ "hylafax-spool.service" ]; after = [ "hylafax-spool.service" ]; - wants = mapModems ( { name, ... }: "hylafax-faxgetty@${name}.service" ); + wants = mapModems ({ name, ... }: "hylafax-faxgetty@${name}.service"); wantedBy = mkIf cfg.autostart [ "multi-user.target" ]; serviceConfig.Type = "forking"; serviceConfig.ExecStart = ''${pkgs.hylafaxplus}/spool/bin/faxq -q "${cfg.spoolAreaPath}"''; @@ -184,7 +187,7 @@ let after = [ "hylafax-spool.service" ]; requires = [ "hylafax-spool.service" ]; wantedBy = mkIf cfg.faxcron.enable.spoolInit requires; - startAt = mkIf (cfg.faxcron.enable.frequency!=null) cfg.faxcron.enable.frequency; + startAt = mkIf (cfg.faxcron.enable.frequency != null) cfg.faxcron.enable.frequency; serviceConfig.ExecStart = concatStringsSep " " [ "${pkgs.hylafaxplus}/spool/bin/faxcron" ''-q "${cfg.spoolAreaPath}"'' @@ -200,26 +203,30 @@ let after = [ "hylafax-spool.service" ]; requires = [ "hylafax-spool.service" ]; wantedBy = mkIf cfg.faxqclean.enable.spoolInit requires; - startAt = mkIf (cfg.faxqclean.enable.frequency!=null) cfg.faxqclean.enable.frequency; + startAt = mkIf (cfg.faxqclean.enable.frequency != null) cfg.faxqclean.enable.frequency; serviceConfig.ExecStart = concatStringsSep " " [ "${pkgs.hylafaxplus}/spool/bin/faxqclean" ''-q "${cfg.spoolAreaPath}"'' "-v" - (optionalString (cfg.faxqclean.archiving!="never") "-a") - (optionalString (cfg.faxqclean.archiving=="always") "-A") - ''-j ${toString (cfg.faxqclean.doneqMinutes*60)}'' - ''-d ${toString (cfg.faxqclean.docqMinutes*60)}'' + (optionalString (cfg.faxqclean.archiving != "never") "-a") + (optionalString (cfg.faxqclean.archiving == "always") "-A") + ''-j ${toString (cfg.faxqclean.doneqMinutes * 60)}'' + ''-d ${toString (cfg.faxqclean.docqMinutes * 60)}'' ]; }; - mkFaxgettyService = { name, ... }: + mkFaxgettyService = + { name, ... }: lib.nameValuePair "hylafax-faxgetty@${name}" rec { description = "HylaFAX faxgetty for %I"; documentation = [ "man:faxgetty(8)" ]; bindsTo = [ "dev-%i.device" ]; requires = [ "hylafax-spool.service" ]; after = bindsTo ++ requires; - before = [ "hylafax-faxq.service" "getty.target" ]; + before = [ + "hylafax-faxq.service" + "getty.target" + ]; unitConfig.StopWhenUnneeded = true; unitConfig.AssertFileNotEmpty = "${cfg.spoolAreaPath}/etc/config.%I"; serviceConfig.UtmpIdentifier = "%I"; @@ -236,8 +243,7 @@ let serviceConfig.RestrictRealtime = null; }; - modemServices = - lib.listToAttrs (mapModems mkFaxgettyService); + modemServices = lib.listToAttrs (mapModems mkFaxgettyService); in diff --git a/nixos/modules/services/networking/i2p.nix b/nixos/modules/services/networking/i2p.nix index 5d7b339dc01b51..09d14a759b24fe 100644 --- a/nixos/modules/services/networking/i2p.nix +++ b/nixos/modules/services/networking/i2p.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.i2p; homeDir = "/var/lib/i2p"; diff --git a/nixos/modules/services/networking/i2pd.nix b/nixos/modules/services/networking/i2pd.nix index 72069e609ac28a..d7784b0a1c8862 100644 --- a/nixos/modules/services/networking/i2pd.nix +++ b/nixos/modules/services/networking/i2pd.nix @@ -1,8 +1,28 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkIf mkOption mkDefault mkEnableOption types optional optionals; - inherit (lib.types) nullOr bool listOf str attrsOf submodule; + inherit (lib) + mkIf + mkOption + mkDefault + mkEnableOption + types + optional + optionals + ; + inherit (lib.types) + nullOr + bool + listOf + str + attrsOf + submodule + ; cfg = config.services.i2pd; @@ -15,7 +35,7 @@ let optionalNullString = o: s: optional (s != null) (strOpt o s); optionalNullBool = o: b: optional (b != null) (boolOpt o b); optionalNullInt = o: i: optional (i != null) (intOpt o i); - optionalEmptyList = o: l: optional ([] != l) (lstOpt o l); + optionalEmptyList = o: l: optional ([ ] != l) (lstOpt o l); mkEnableTrueOption = name: mkEnableOption name // { default = true; }; @@ -51,8 +71,10 @@ let }; }; - mkKeyedEndpointOpt = name: addr: port: keyloc: - (mkEndpointOpt name addr port) // { + mkKeyedEndpointOpt = + name: addr: port: keyloc: + (mkEndpointOpt name addr port) + // { keys = mkOption { type = nullOr str; default = keyloc; @@ -74,161 +96,186 @@ let }; }; - commonTunOpts = name: { - outbound = i2cpOpts name; - inbound = i2cpOpts name; - crypto.tagsToSend = mkOption { - type = types.int; - description = "Number of ElGamal/AES tags to send."; - default = 40; - }; - destination = mkOption { - type = types.str; - description = "Remote endpoint, I2P hostname or b32.i2p address."; - }; - keys = mkOption { - type = types.str; - default = name + "-keys.dat"; - description = "Keyset used for tunnel identity."; - }; - } // mkEndpointOpt name "127.0.0.1" 0; + commonTunOpts = + name: + { + outbound = i2cpOpts name; + inbound = i2cpOpts name; + crypto.tagsToSend = mkOption { + type = types.int; + description = "Number of ElGamal/AES tags to send."; + default = 40; + }; + destination = mkOption { + type = types.str; + description = "Remote endpoint, I2P hostname or b32.i2p address."; + }; + keys = mkOption { + type = types.str; + default = name + "-keys.dat"; + description = "Keyset used for tunnel identity."; + }; + } + // mkEndpointOpt name "127.0.0.1" 0; sec = name: "\n[" + name + "]"; notice = "# DO NOT EDIT -- this file has been generated automatically."; - i2pdConf = let - opts = [ - notice - (strOpt "loglevel" cfg.logLevel) - (boolOpt "logclftime" cfg.logCLFTime) - (boolOpt "ipv4" cfg.enableIPv4) - (boolOpt "ipv6" cfg.enableIPv6) - (boolOpt "notransit" cfg.notransit) - (boolOpt "floodfill" cfg.floodfill) - (intOpt "netid" cfg.netid) - ] ++ (optionalNullInt "bandwidth" cfg.bandwidth) - ++ (optionalNullInt "port" cfg.port) - ++ (optionalNullString "family" cfg.family) - ++ (optionalNullString "datadir" cfg.dataDir) - ++ (optionalNullInt "share" cfg.share) - ++ (optionalNullBool "ssu" cfg.ssu) - ++ (optionalNullBool "ntcp" cfg.ntcp) - ++ (optionalNullString "ntcpproxy" cfg.ntcpProxy) - ++ (optionalNullString "ifname" cfg.ifname) - ++ (optionalNullString "ifname4" cfg.ifname4) - ++ (optionalNullString "ifname6" cfg.ifname6) - ++ [ - (sec "limits") - (intOpt "transittunnels" cfg.limits.transittunnels) - (intOpt "coresize" cfg.limits.coreSize) - (intOpt "openfiles" cfg.limits.openFiles) - (intOpt "ntcphard" cfg.limits.ntcpHard) - (intOpt "ntcpsoft" cfg.limits.ntcpSoft) - (intOpt "ntcpthreads" cfg.limits.ntcpThreads) - (sec "upnp") - (boolOpt "enabled" cfg.upnp.enable) - (sec "precomputation") - (boolOpt "elgamal" cfg.precomputation.elgamal) - (sec "reseed") - (boolOpt "verify" cfg.reseed.verify) - ] ++ (optionalNullString "file" cfg.reseed.file) - ++ (optionalEmptyList "urls" cfg.reseed.urls) - ++ (optionalNullString "floodfill" cfg.reseed.floodfill) - ++ (optionalNullString "zipfile" cfg.reseed.zipfile) - ++ (optionalNullString "proxy" cfg.reseed.proxy) - ++ [ - (sec "trust") - (boolOpt "enabled" cfg.trust.enable) - (boolOpt "hidden" cfg.trust.hidden) - ] ++ (optionalEmptyList "routers" cfg.trust.routers) - ++ (optionalNullString "family" cfg.trust.family) - ++ [ - (sec "websockets") - (boolOpt "enabled" cfg.websocket.enable) - (strOpt "address" cfg.websocket.address) - (intOpt "port" cfg.websocket.port) - (sec "exploratory") - (intOpt "inbound.length" cfg.exploratory.inbound.length) - (intOpt "inbound.quantity" cfg.exploratory.inbound.quantity) - (intOpt "outbound.length" cfg.exploratory.outbound.length) - (intOpt "outbound.quantity" cfg.exploratory.outbound.quantity) - (sec "ntcp2") - (boolOpt "enabled" cfg.ntcp2.enable) - (boolOpt "published" cfg.ntcp2.published) - (intOpt "port" cfg.ntcp2.port) - (sec "addressbook") - (strOpt "defaulturl" cfg.addressbook.defaulturl) - ] ++ (optionalEmptyList "subscriptions" cfg.addressbook.subscriptions) - ++ [ - (sec "meshnets") - (boolOpt "yggdrasil" cfg.yggdrasil.enable) - ] ++ (optionalNullString "yggaddress" cfg.yggdrasil.address) - ++ (lib.flip map - (lib.collect (proto: proto ? port && proto ? address) cfg.proto) - (proto: let protoOpts = [ - (sec proto.name) - (boolOpt "enabled" proto.enable) - (strOpt "address" proto.address) - (intOpt "port" proto.port) - ] ++ (optionals (proto ? keys) (optionalNullString "keys" proto.keys)) - ++ (optionals (proto ? auth) (optionalNullBool "auth" proto.auth)) - ++ (optionals (proto ? user) (optionalNullString "user" proto.user)) - ++ (optionals (proto ? pass) (optionalNullString "pass" proto.pass)) - ++ (optionals (proto ? strictHeaders) (optionalNullBool "strictheaders" proto.strictHeaders)) - ++ (optionals (proto ? hostname) (optionalNullString "hostname" proto.hostname)) - ++ (optionals (proto ? outproxy) (optionalNullString "outproxy" proto.outproxy)) - ++ (optionals (proto ? outproxyPort) (optionalNullInt "outproxyport" proto.outproxyPort)) - ++ (optionals (proto ? outproxyEnable) (optionalNullBool "outproxy.enabled" proto.outproxyEnable)); - in (lib.concatStringsSep "\n" protoOpts) - )); - in + i2pdConf = + let + opts = + [ + notice + (strOpt "loglevel" cfg.logLevel) + (boolOpt "logclftime" cfg.logCLFTime) + (boolOpt "ipv4" cfg.enableIPv4) + (boolOpt "ipv6" cfg.enableIPv6) + (boolOpt "notransit" cfg.notransit) + (boolOpt "floodfill" cfg.floodfill) + (intOpt "netid" cfg.netid) + ] + ++ (optionalNullInt "bandwidth" cfg.bandwidth) + ++ (optionalNullInt "port" cfg.port) + ++ (optionalNullString "family" cfg.family) + ++ (optionalNullString "datadir" cfg.dataDir) + ++ (optionalNullInt "share" cfg.share) + ++ (optionalNullBool "ssu" cfg.ssu) + ++ (optionalNullBool "ntcp" cfg.ntcp) + ++ (optionalNullString "ntcpproxy" cfg.ntcpProxy) + ++ (optionalNullString "ifname" cfg.ifname) + ++ (optionalNullString "ifname4" cfg.ifname4) + ++ (optionalNullString "ifname6" cfg.ifname6) + ++ [ + (sec "limits") + (intOpt "transittunnels" cfg.limits.transittunnels) + (intOpt "coresize" cfg.limits.coreSize) + (intOpt "openfiles" cfg.limits.openFiles) + (intOpt "ntcphard" cfg.limits.ntcpHard) + (intOpt "ntcpsoft" cfg.limits.ntcpSoft) + (intOpt "ntcpthreads" cfg.limits.ntcpThreads) + (sec "upnp") + (boolOpt "enabled" cfg.upnp.enable) + (sec "precomputation") + (boolOpt "elgamal" cfg.precomputation.elgamal) + (sec "reseed") + (boolOpt "verify" cfg.reseed.verify) + ] + ++ (optionalNullString "file" cfg.reseed.file) + ++ (optionalEmptyList "urls" cfg.reseed.urls) + ++ (optionalNullString "floodfill" cfg.reseed.floodfill) + ++ (optionalNullString "zipfile" cfg.reseed.zipfile) + ++ (optionalNullString "proxy" cfg.reseed.proxy) + ++ [ + (sec "trust") + (boolOpt "enabled" cfg.trust.enable) + (boolOpt "hidden" cfg.trust.hidden) + ] + ++ (optionalEmptyList "routers" cfg.trust.routers) + ++ (optionalNullString "family" cfg.trust.family) + ++ [ + (sec "websockets") + (boolOpt "enabled" cfg.websocket.enable) + (strOpt "address" cfg.websocket.address) + (intOpt "port" cfg.websocket.port) + (sec "exploratory") + (intOpt "inbound.length" cfg.exploratory.inbound.length) + (intOpt "inbound.quantity" cfg.exploratory.inbound.quantity) + (intOpt "outbound.length" cfg.exploratory.outbound.length) + (intOpt "outbound.quantity" cfg.exploratory.outbound.quantity) + (sec "ntcp2") + (boolOpt "enabled" cfg.ntcp2.enable) + (boolOpt "published" cfg.ntcp2.published) + (intOpt "port" cfg.ntcp2.port) + (sec "addressbook") + (strOpt "defaulturl" cfg.addressbook.defaulturl) + ] + ++ (optionalEmptyList "subscriptions" cfg.addressbook.subscriptions) + ++ [ + (sec "meshnets") + (boolOpt "yggdrasil" cfg.yggdrasil.enable) + ] + ++ (optionalNullString "yggaddress" cfg.yggdrasil.address) + ++ (lib.flip map (lib.collect (proto: proto ? port && proto ? address) cfg.proto) ( + proto: + let + protoOpts = + [ + (sec proto.name) + (boolOpt "enabled" proto.enable) + (strOpt "address" proto.address) + (intOpt "port" proto.port) + ] + ++ (optionals (proto ? keys) (optionalNullString "keys" proto.keys)) + ++ (optionals (proto ? auth) (optionalNullBool "auth" proto.auth)) + ++ (optionals (proto ? user) (optionalNullString "user" proto.user)) + ++ (optionals (proto ? pass) (optionalNullString "pass" proto.pass)) + ++ (optionals (proto ? strictHeaders) (optionalNullBool "strictheaders" proto.strictHeaders)) + ++ (optionals (proto ? hostname) (optionalNullString "hostname" proto.hostname)) + ++ (optionals (proto ? outproxy) (optionalNullString "outproxy" proto.outproxy)) + ++ (optionals (proto ? outproxyPort) (optionalNullInt "outproxyport" proto.outproxyPort)) + ++ (optionals (proto ? outproxyEnable) (optionalNullBool "outproxy.enabled" proto.outproxyEnable)); + in + (lib.concatStringsSep "\n" protoOpts) + )); + in pkgs.writeText "i2pd.conf" (lib.concatStringsSep "\n" opts); - tunnelConf = let - mkOutTunnel = tun: - let - outTunOpts = [ - (sec tun.name) - "type = client" - (intOpt "port" tun.port) - (strOpt "destination" tun.destination) - ] ++ (optionals (tun ? destinationPort) (optionalNullInt "destinationport" tun.destinationPort)) - ++ (optionals (tun ? keys) (optionalNullString "keys" tun.keys)) - ++ (optionals (tun ? address) (optionalNullString "address" tun.address)) - ++ (optionals (tun ? inbound.length) (optionalNullInt "inbound.length" tun.inbound.length)) - ++ (optionals (tun ? inbound.quantity) (optionalNullInt "inbound.quantity" tun.inbound.quantity)) - ++ (optionals (tun ? outbound.length) (optionalNullInt "outbound.length" tun.outbound.length)) - ++ (optionals (tun ? outbound.quantity) (optionalNullInt "outbound.quantity" tun.outbound.quantity)) - ++ (optionals (tun ? crypto.tagsToSend) (optionalNullInt "crypto.tagstosend" tun.crypto.tagsToSend)); - in + tunnelConf = + let + mkOutTunnel = + tun: + let + outTunOpts = + [ + (sec tun.name) + "type = client" + (intOpt "port" tun.port) + (strOpt "destination" tun.destination) + ] + ++ (optionals (tun ? destinationPort) (optionalNullInt "destinationport" tun.destinationPort)) + ++ (optionals (tun ? keys) (optionalNullString "keys" tun.keys)) + ++ (optionals (tun ? address) (optionalNullString "address" tun.address)) + ++ (optionals (tun ? inbound.length) (optionalNullInt "inbound.length" tun.inbound.length)) + ++ (optionals (tun ? inbound.quantity) (optionalNullInt "inbound.quantity" tun.inbound.quantity)) + ++ (optionals (tun ? outbound.length) (optionalNullInt "outbound.length" tun.outbound.length)) + ++ (optionals (tun ? outbound.quantity) (optionalNullInt "outbound.quantity" tun.outbound.quantity)) + ++ (optionals (tun ? crypto.tagsToSend) ( + optionalNullInt "crypto.tagstosend" tun.crypto.tagsToSend + )); + in lib.concatStringsSep "\n" outTunOpts; - mkInTunnel = tun: - let - inTunOpts = [ - (sec tun.name) - "type = server" - (intOpt "port" tun.port) - (strOpt "host" tun.address) - ] ++ (optionals (tun ? destination) (optionalNullString "destination" tun.destination)) - ++ (optionals (tun ? keys) (optionalNullString "keys" tun.keys)) - ++ (optionals (tun ? inPort) (optionalNullInt "inport" tun.inPort)) - ++ (optionals (tun ? accessList) (optionalEmptyList "accesslist" tun.accessList)); - in + mkInTunnel = + tun: + let + inTunOpts = + [ + (sec tun.name) + "type = server" + (intOpt "port" tun.port) + (strOpt "host" tun.address) + ] + ++ (optionals (tun ? destination) (optionalNullString "destination" tun.destination)) + ++ (optionals (tun ? keys) (optionalNullString "keys" tun.keys)) + ++ (optionals (tun ? inPort) (optionalNullInt "inport" tun.inPort)) + ++ (optionals (tun ? accessList) (optionalEmptyList "accesslist" tun.accessList)); + in lib.concatStringsSep "\n" inTunOpts; - allOutTunnels = lib.collect (tun: tun ? port && tun ? destination) cfg.outTunnels; - allInTunnels = lib.collect (tun: tun ? port && tun ? address) cfg.inTunnels; + allOutTunnels = lib.collect (tun: tun ? port && tun ? destination) cfg.outTunnels; + allInTunnels = lib.collect (tun: tun ? port && tun ? address) cfg.inTunnels; - opts = [ notice ] ++ (map mkOutTunnel allOutTunnels) ++ (map mkInTunnel allInTunnels); - in + opts = [ notice ] ++ (map mkOutTunnel allOutTunnels) ++ (map mkInTunnel allInTunnels); + in pkgs.writeText "i2pd-tunnels.conf" (lib.concatStringsSep "\n" opts); i2pdFlags = lib.concatStringsSep " " ( - optional (cfg.address != null) ("--host=" + cfg.address) ++ [ - "--service" - ("--conf=" + i2pdConf) - ("--tunconf=" + tunnelConf) - ]); + optional (cfg.address != null) ("--host=" + cfg.address) + ++ [ + "--service" + ("--conf=" + i2pdConf) + ("--tunconf=" + tunnelConf) + ] + ); in @@ -255,7 +302,12 @@ in package = lib.mkPackageOption pkgs "i2pd" { }; logLevel = mkOption { - type = types.enum ["debug" "info" "warn" "error"]; + type = types.enum [ + "debug" + "info" + "warn" + "error" + ]; default = "error"; description = '' The log level. {command}`i2pd` defaults to "info" @@ -359,8 +411,8 @@ in type = with types; nullOr int; default = null; description = '' - Set a router bandwidth limit integer in KBps. - If not set, {command}`i2pd` defaults to 32KBps. + Set a router bandwidth limit integer in KBps. + If not set, {command}`i2pd` defaults to 32KBps. ''; }; @@ -408,7 +460,7 @@ in reseed.urls = mkOption { type = listOf str; - default = []; + default = [ ]; description = '' Reseed URLs. ''; @@ -438,14 +490,14 @@ in ''; }; - addressbook.defaulturl = mkOption { + addressbook.defaulturl = mkOption { type = types.str; default = "http://joajgazyztfssty4w2on5oaqksz6tqoxbduy553y34mf4byv6gpq.b32.i2p/export/alive-hosts.txt"; description = '' AddressBook subscription URL for initial setup ''; }; - addressbook.subscriptions = mkOption { + addressbook.subscriptions = mkOption { type = listOf str; default = [ "http://inr.i2p/export/alive-hosts.txt" @@ -469,7 +521,7 @@ in trust.routers = mkOption { type = listOf str; - default = []; + default = [ ]; description = '' Only connect to the listed routers. ''; @@ -588,16 +640,14 @@ in }; }; - proto.httpProxy = (mkKeyedEndpointOpt "httpproxy" "127.0.0.1" 4444 "httpproxy-keys.dat") - // { + proto.httpProxy = (mkKeyedEndpointOpt "httpproxy" "127.0.0.1" 4444 "httpproxy-keys.dat") // { outproxy = mkOption { type = nullOr str; default = null; description = "Upstream outproxy bind address."; }; }; - proto.socksProxy = (mkKeyedEndpointOpt "socksproxy" "127.0.0.1" 4447 "socksproxy-keys.dat") - // { + proto.socksProxy = (mkKeyedEndpointOpt "socksproxy" "127.0.0.1" 4447 "socksproxy-keys.dat") // { outproxyEnable = mkEnableOption "SOCKS outproxy"; outproxy = mkOption { type = types.str; @@ -617,47 +667,53 @@ in proto.i2pControl = mkEndpointOpt "i2pcontrol" "127.0.0.1" 7650; outTunnels = mkOption { - default = {}; - type = attrsOf (submodule ( - { name, ... }: { - options = { - destinationPort = mkOption { - type = with types; nullOr int; - default = null; - description = "Connect to particular port at destination."; + default = { }; + type = attrsOf ( + submodule ( + { name, ... }: + { + options = { + destinationPort = mkOption { + type = with types; nullOr int; + default = null; + description = "Connect to particular port at destination."; + }; + } // commonTunOpts name; + config = { + name = mkDefault name; }; - } // commonTunOpts name; - config = { - name = mkDefault name; - }; - } - )); + } + ) + ); description = '' Connect to someone as a client and establish a local accept endpoint ''; }; inTunnels = mkOption { - default = {}; - type = attrsOf (submodule ( - { name, ... }: { - options = { - inPort = mkOption { - type = types.int; - default = 0; - description = "Service port. Default to the tunnel's listen port."; - }; - accessList = mkOption { - type = listOf str; - default = []; - description = "I2P nodes that are allowed to connect to this service."; + default = { }; + type = attrsOf ( + submodule ( + { name, ... }: + { + options = { + inPort = mkOption { + type = types.int; + default = 0; + description = "Service port. Default to the tunnel's listen port."; + }; + accessList = mkOption { + type = listOf str; + default = [ ]; + description = "I2P nodes that are allowed to connect to this service."; + }; + } // commonTunOpts name; + config = { + name = mkDefault name; }; - } // commonTunOpts name; - config = { - name = mkDefault name; - }; - } - )); + } + ) + ); description = '' Serve something on I2P network at port and delegate requests to address inPort. ''; @@ -665,7 +721,6 @@ in }; }; - ###### implementation config = mkIf cfg.enable { @@ -684,8 +739,7 @@ in description = "Minimal I2P router"; after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; - serviceConfig = - { + serviceConfig = { User = "i2pd"; WorkingDirectory = homeDir; Restart = "on-abort"; diff --git a/nixos/modules/services/networking/icecream/daemon.nix b/nixos/modules/services/networking/icecream/daemon.nix index 0626766eddd071..789ff377bbaf28 100644 --- a/nixos/modules/services/networking/icecream/daemon.nix +++ b/nixos/modules/services/networking/icecream/daemon.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.icecream.daemon; -in { +in +{ ###### interface @@ -12,7 +18,7 @@ in { services.icecream.daemon = { - enable = mkEnableOption "Icecream Daemon"; + enable = mkEnableOption "Icecream Daemon"; openFirewall = mkOption { type = types.bool; @@ -103,7 +109,7 @@ in { extraArgs = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = "Additional command line parameters."; example = [ "-v" ]; }; @@ -122,19 +128,38 @@ in { wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart = escapeShellArgs ([ - "${getBin cfg.package}/bin/iceccd" - "-b" "$STATE_DIRECTORY" - "-u" "icecc" - (toString cfg.nice) - ] - ++ optionals (cfg.schedulerHost != null) ["-s" cfg.schedulerHost] - ++ optionals (cfg.netName != null) [ "-n" cfg.netName ] - ++ optionals (cfg.cacheLimit != null) [ "--cache-limit" (toString cfg.cacheLimit) ] - ++ optionals (cfg.maxProcesses != null) [ "-m" (toString cfg.maxProcesses) ] - ++ optionals (cfg.hostname != null) [ "-N" (cfg.hostname) ] - ++ optional cfg.noRemote "--no-remote" - ++ cfg.extraArgs); + ExecStart = escapeShellArgs ( + [ + "${getBin cfg.package}/bin/iceccd" + "-b" + "$STATE_DIRECTORY" + "-u" + "icecc" + (toString cfg.nice) + ] + ++ optionals (cfg.schedulerHost != null) [ + "-s" + cfg.schedulerHost + ] + ++ optionals (cfg.netName != null) [ + "-n" + cfg.netName + ] + ++ optionals (cfg.cacheLimit != null) [ + "--cache-limit" + (toString cfg.cacheLimit) + ] + ++ optionals (cfg.maxProcesses != null) [ + "-m" + (toString cfg.maxProcesses) + ] + ++ optionals (cfg.hostname != null) [ + "-N" + (cfg.hostname) + ] + ++ optional cfg.noRemote "--no-remote" + ++ cfg.extraArgs + ); DynamicUser = true; User = "icecc"; Group = "icecc"; diff --git a/nixos/modules/services/networking/icecream/scheduler.nix b/nixos/modules/services/networking/icecream/scheduler.nix index 597a554d0b87e7..69548f013a8403 100644 --- a/nixos/modules/services/networking/icecream/scheduler.nix +++ b/nixos/modules/services/networking/icecream/scheduler.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.icecream.scheduler; -in { +in +{ ###### interface @@ -58,7 +64,7 @@ in { extraArgs = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = "Additional command line parameters"; example = [ "-v" ]; }; @@ -79,13 +85,19 @@ in { wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart = escapeShellArgs ([ - "${getBin cfg.package}/bin/icecc-scheduler" - "-p" (toString cfg.port) - ] - ++ optionals (cfg.netName != null) [ "-n" (toString cfg.netName) ] - ++ optional cfg.persistentClientConnection "-r" - ++ cfg.extraArgs); + ExecStart = escapeShellArgs ( + [ + "${getBin cfg.package}/bin/icecc-scheduler" + "-p" + (toString cfg.port) + ] + ++ optionals (cfg.netName != null) [ + "-n" + (toString cfg.netName) + ] + ++ optional cfg.persistentClientConnection "-r" + ++ cfg.extraArgs + ); DynamicUser = true; }; diff --git a/nixos/modules/services/networking/imaginary.nix b/nixos/modules/services/networking/imaginary.nix index cb2fb62f34b39d..3b4fd07d56e079 100644 --- a/nixos/modules/services/networking/imaginary.nix +++ b/nixos/modules/services/networking/imaginary.nix @@ -1,10 +1,22 @@ -{ lib, config, pkgs, utils, ... }: +{ + lib, + config, + pkgs, + utils, + ... +}: let - inherit (lib) mkEnableOption mkIf mkOption types; + inherit (lib) + mkEnableOption + mkIf + mkOption + types + ; cfg = config.services.imaginary; -in { +in +{ options.services.imaginary = { enable = mkEnableOption "imaginary image processing microservice"; @@ -32,12 +44,14 @@ in { options. ''; type = types.submodule { - freeformType = with types; attrsOf (oneOf [ - bool - int - (nonEmptyListOf str) - str - ]); + freeformType = + with types; + attrsOf (oneOf [ + bool + int + (nonEmptyListOf str) + str + ]); options = { return-size = mkOption { @@ -51,29 +65,38 @@ in { }; config = mkIf cfg.enable { - assertions = [ { - assertion = ! lib.hasAttr "a" cfg.settings; - message = "Use services.imaginary.address to specify the -a flag."; - } { - assertion = ! lib.hasAttr "p" cfg.settings; - message = "Use services.imaginary.port to specify the -p flag."; - } ]; + assertions = [ + { + assertion = !lib.hasAttr "a" cfg.settings; + message = "Use services.imaginary.address to specify the -a flag."; + } + { + assertion = !lib.hasAttr "p" cfg.settings; + message = "Use services.imaginary.port to specify the -p flag."; + } + ]; systemd.services.imaginary = { after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = rec { - ExecStart = let - args = lib.mapAttrsToList (key: val: - "-" + key + "=" + lib.concatStringsSep "," (map toString (lib.toList val)) - ) (cfg.settings // { a = cfg.address; p = cfg.port; }); - in "${pkgs.imaginary}/bin/imaginary ${utils.escapeSystemdExecArgs args}"; + ExecStart = + let + args = + lib.mapAttrsToList + (key: val: "-" + key + "=" + lib.concatStringsSep "," (map toString (lib.toList val))) + ( + cfg.settings + // { + a = cfg.address; + p = cfg.port; + } + ); + in + "${pkgs.imaginary}/bin/imaginary ${utils.escapeSystemdExecArgs args}"; ProtectProc = "invisible"; BindReadOnlyPaths = lib.optional (cfg.settings ? mount) cfg.settings.mount; - CapabilityBoundingSet = if cfg.port < 1024 then - [ "CAP_NET_BIND_SERVICE" ] - else - [ "" ]; + CapabilityBoundingSet = if cfg.port < 1024 then [ "CAP_NET_BIND_SERVICE" ] else [ "" ]; AmbientCapabilities = CapabilityBoundingSet; NoNewPrivileges = true; DynamicUser = true; diff --git a/nixos/modules/services/networking/inadyn.nix b/nixos/modules/services/networking/inadyn.nix index c98d6a2315061f..a2684f2aee4d85 100644 --- a/nixos/modules/services/networking/inadyn.nix +++ b/nixos/modules/services/networking/inadyn.nix @@ -1,19 +1,31 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.inadyn; # check if a value of an attrset is not null or an empty collection nonEmptyValue = _: v: v != null && v != [ ] && v != { }; - renderOption = k: v: - if builtins.elem k [ "provider" "custom" ] then - lib.concatStringsSep "\n" - (lib.mapAttrsToList - (name: config: '' - ${k} ${name} { - ${lib.concatStringsSep "\n " (lib.mapAttrsToList renderOption (lib.filterAttrs nonEmptyValue config))} - }'') - v) + renderOption = + k: v: + if + builtins.elem k [ + "provider" + "custom" + ] + then + lib.concatStringsSep "\n" ( + lib.mapAttrsToList (name: config: '' + ${k} ${name} { + ${lib.concatStringsSep "\n " ( + lib.mapAttrsToList renderOption (lib.filterAttrs nonEmptyValue config) + )} + }'') v + ) else if k == "include" then "${k}(\"${v}\")" else if k == "hostname" && builtins.isList v then @@ -25,53 +37,56 @@ let else "${k} = ${toString v}"; - configFile' = pkgs.writeText "inadyn.conf" - '' - # This file was generated by nix - # do not edit + configFile' = pkgs.writeText "inadyn.conf" '' + # This file was generated by nix + # do not edit - ${(lib.concatStringsSep "\n" (lib.mapAttrsToList renderOption (lib.filterAttrs nonEmptyValue cfg.settings)))} - ''; + ${ + (lib.concatStringsSep "\n" ( + lib.mapAttrsToList renderOption (lib.filterAttrs nonEmptyValue cfg.settings) + )) + } + ''; configFile = if (cfg.configFile != null) then cfg.configFile else configFile'; in { - options.services.inadyn = with lib.types; + options.services.inadyn = + with lib.types; let - providerOptions = - { - include = lib.mkOption { - default = null; - description = "File to include additional settings for this provider from."; - type = nullOr path; - }; - ssl = lib.mkOption { - default = true; - description = "Whether to use HTTPS for this DDNS provider."; - type = bool; - }; - username = lib.mkOption { - default = null; - description = "Username for this DDNS provider."; - type = nullOr str; - }; - password = lib.mkOption { - default = null; - description = '' - Password for this DDNS provider. - - WARNING: This will be world-readable in the nix store. - To store credentials securely, use the `include` or `configFile` options. - ''; - type = nullOr str; - }; - hostname = lib.mkOption { - default = "*"; - example = "your.cool-domain.com"; - description = "Hostname alias(es)."; - type = either str (listOf str); - }; + providerOptions = { + include = lib.mkOption { + default = null; + description = "File to include additional settings for this provider from."; + type = nullOr path; + }; + ssl = lib.mkOption { + default = true; + description = "Whether to use HTTPS for this DDNS provider."; + type = bool; }; + username = lib.mkOption { + default = null; + description = "Username for this DDNS provider."; + type = nullOr str; + }; + password = lib.mkOption { + default = null; + description = '' + Password for this DDNS provider. + + WARNING: This will be world-readable in the nix store. + To store credentials securely, use the `include` or `configFile` options. + ''; + type = nullOr str; + }; + hostname = lib.mkOption { + default = "*"; + example = "your.cool-domain.com"; + description = "Hostname alias(es)."; + type = either str (listOf str); + }; + }; in { enable = lib.mkEnableOption ('' @@ -112,7 +127,14 @@ in type = str; }; logLevel = lib.mkOption { - type = lib.types.enum [ "none" "err" "warning" "info" "notice" "debug" ]; + type = lib.types.enum [ + "none" + "err" + "warning" + "info" + "notice" + "debug" + ]; default = "notice"; description = "Set inadyn's log level."; }; diff --git a/nixos/modules/services/networking/inspircd.nix b/nixos/modules/services/networking/inspircd.nix index 5838b76d1da5d6..5ae169dd41554b 100644 --- a/nixos/modules/services/networking/inspircd.nix +++ b/nixos/modules/services/networking/inspircd.nix @@ -1,11 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.inspircd; configFile = pkgs.writeText "inspircd.conf" cfg.config; -in { +in +{ meta = { maintainers = [ lib.maintainers.sternenseemann ]; }; diff --git a/nixos/modules/services/networking/iodine.nix b/nixos/modules/services/networking/iodine.nix index 2bdfa6f1b844a5..ed3ff28cd5f4d3 100644 --- a/nixos/modules/services/networking/iodine.nix +++ b/nixos/modules/services/networking/iodine.nix @@ -1,19 +1,33 @@ # NixOS module for iodine, ip over dns daemon -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.iodine; iodinedUser = "iodined"; - /* is this path made unreadable by ProtectHome = true ? */ + # is this path made unreadable by ProtectHome = true ? isProtected = x: lib.hasPrefix "/root" x || lib.hasPrefix "/home" x; in { imports = [ - (lib.mkRenamedOptionModule [ "services" "iodined" "enable" ] [ "services" "iodine" "server" "enable" ]) - (lib.mkRenamedOptionModule [ "services" "iodined" "domain" ] [ "services" "iodine" "server" "domain" ]) + (lib.mkRenamedOptionModule + [ "services" "iodined" "enable" ] + [ "services" "iodine" "server" "enable" ] + ) + (lib.mkRenamedOptionModule + [ "services" "iodined" "domain" ] + [ "services" "iodine" "server" "domain" ] + ) (lib.mkRenamedOptionModule [ "services" "iodined" "ip" ] [ "services" "iodine" "server" "ip" ]) - (lib.mkRenamedOptionModule [ "services" "iodined" "extraConfig" ] [ "services" "iodine" "server" "extraConfig" ]) + (lib.mkRenamedOptionModule + [ "services" "iodined" "extraConfig" ] + [ "services" "iodine" "server" "extraConfig" ] + ) (lib.mkRemovedOptionModule [ "services" "iodined" "client" ] "") ]; @@ -23,7 +37,7 @@ in services.iodine = { clients = lib.mkOption { - default = {}; + default = { }; description = '' Each attribute of this option defines a systemd service that runs iodine. Many or none may be defined. @@ -42,38 +56,36 @@ in } ''; type = lib.types.attrsOf ( - lib.types.submodule ( - { - options = { - server = lib.mkOption { - type = lib.types.str; - default = ""; - description = "Hostname of server running iodined"; - example = "tunnel.mydomain.com"; - }; - - relay = lib.mkOption { - type = lib.types.str; - default = ""; - description = "DNS server to use as an intermediate relay to the iodined server"; - example = "8.8.8.8"; - }; - - extraConfig = lib.mkOption { - type = lib.types.str; - default = ""; - description = "Additional command line parameters"; - example = "-l 192.168.1.10 -p 23"; - }; - - passwordFile = lib.mkOption { - type = lib.types.str; - default = ""; - description = "Path to a file containing the password."; - }; + lib.types.submodule ({ + options = { + server = lib.mkOption { + type = lib.types.str; + default = ""; + description = "Hostname of server running iodined"; + example = "tunnel.mydomain.com"; }; - } - ) + + relay = lib.mkOption { + type = lib.types.str; + default = ""; + description = "DNS server to use as an intermediate relay to the iodined server"; + example = "8.8.8.8"; + }; + + extraConfig = lib.mkOption { + type = lib.types.str; + default = ""; + description = "Additional command line parameters"; + example = "-l 192.168.1.10 -p 23"; + }; + + passwordFile = lib.mkOption { + type = lib.types.str; + default = ""; + description = "Path to a file containing the password."; + }; + }; + }) ); }; @@ -117,72 +129,78 @@ in ### implementation - config = lib.mkIf (cfg.server.enable || cfg.clients != {}) { + config = lib.mkIf (cfg.server.enable || cfg.clients != { }) { environment.systemPackages = [ pkgs.iodine ]; boot.kernelModules = [ "tun" ]; systemd.services = let - createIodineClientService = name: cfg: - { - description = "iodine client - ${name}"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - script = "exec ${pkgs.iodine}/bin/iodine -f -u ${iodinedUser} ${cfg.extraConfig} ${lib.optionalString (cfg.passwordFile != "") "< \"${builtins.toString cfg.passwordFile}\""} ${cfg.relay} ${cfg.server}"; - serviceConfig = { - RestartSec = "30s"; - Restart = "always"; - - # hardening : - # Filesystem access - ProtectSystem = "strict"; - ProtectHome = if isProtected cfg.passwordFile then "read-only" else "true" ; - PrivateTmp = true; - ReadWritePaths = "/dev/net/tun"; - PrivateDevices = false; - ProtectKernelTunables = true; - ProtectKernelModules = true; - ProtectControlGroups = true; - # Caps - NoNewPrivileges = true; - # Misc. - LockPersonality = true; - RestrictRealtime = true; - PrivateMounts = true; - MemoryDenyWriteExecute = true; - }; + createIodineClientService = name: cfg: { + description = "iodine client - ${name}"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + script = "exec ${pkgs.iodine}/bin/iodine -f -u ${iodinedUser} ${cfg.extraConfig} ${ + lib.optionalString (cfg.passwordFile != "") "< \"${builtins.toString cfg.passwordFile}\"" + } ${cfg.relay} ${cfg.server}"; + serviceConfig = { + RestartSec = "30s"; + Restart = "always"; + + # hardening : + # Filesystem access + ProtectSystem = "strict"; + ProtectHome = if isProtected cfg.passwordFile then "read-only" else "true"; + PrivateTmp = true; + ReadWritePaths = "/dev/net/tun"; + PrivateDevices = false; + ProtectKernelTunables = true; + ProtectKernelModules = true; + ProtectControlGroups = true; + # Caps + NoNewPrivileges = true; + # Misc. + LockPersonality = true; + RestrictRealtime = true; + PrivateMounts = true; + MemoryDenyWriteExecute = true; }; + }; in - lib.listToAttrs ( - lib.mapAttrsToList - (name: value: lib.nameValuePair "iodine-${name}" (createIodineClientService name value)) - cfg.clients - ) // { - iodined = lib.mkIf (cfg.server.enable) { - description = "iodine, ip over dns server daemon"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - script = "exec ${pkgs.iodine}/bin/iodined -f -u ${iodinedUser} ${cfg.server.extraConfig} ${lib.optionalString (cfg.server.passwordFile != "") "< \"${builtins.toString cfg.server.passwordFile}\""} ${cfg.server.ip} ${cfg.server.domain}"; - serviceConfig = { - # Filesystem access - ProtectSystem = "strict"; - ProtectHome = if isProtected cfg.server.passwordFile then "read-only" else "true" ; - PrivateTmp = true; - ReadWritePaths = "/dev/net/tun"; - PrivateDevices = false; - ProtectKernelTunables = true; - ProtectKernelModules = true; - ProtectControlGroups = true; - # Caps - NoNewPrivileges = true; - # Misc. - LockPersonality = true; - RestrictRealtime = true; - PrivateMounts = true; - MemoryDenyWriteExecute = true; - }; + lib.listToAttrs ( + lib.mapAttrsToList ( + name: value: lib.nameValuePair "iodine-${name}" (createIodineClientService name value) + ) cfg.clients + ) + // { + iodined = lib.mkIf (cfg.server.enable) { + description = "iodine, ip over dns server daemon"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + script = "exec ${pkgs.iodine}/bin/iodined -f -u ${iodinedUser} ${cfg.server.extraConfig} ${ + lib.optionalString ( + cfg.server.passwordFile != "" + ) "< \"${builtins.toString cfg.server.passwordFile}\"" + } ${cfg.server.ip} ${cfg.server.domain}"; + serviceConfig = { + # Filesystem access + ProtectSystem = "strict"; + ProtectHome = if isProtected cfg.server.passwordFile then "read-only" else "true"; + PrivateTmp = true; + ReadWritePaths = "/dev/net/tun"; + PrivateDevices = false; + ProtectKernelTunables = true; + ProtectKernelModules = true; + ProtectControlGroups = true; + # Caps + NoNewPrivileges = true; + # Misc. + LockPersonality = true; + RestrictRealtime = true; + PrivateMounts = true; + MemoryDenyWriteExecute = true; }; }; + }; users.users.${iodinedUser} = { uid = config.ids.uids.iodined; diff --git a/nixos/modules/services/networking/iperf3.nix b/nixos/modules/services/networking/iperf3.nix index 2b1ee71f142121..6bcf17306e1d1b 100644 --- a/nixos/modules/services/networking/iperf3.nix +++ b/nixos/modules/services/networking/iperf3.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, ... }: with lib; +{ + config, + lib, + pkgs, + ... +}: +with lib; let cfg = config.services.iperf3; @@ -6,18 +12,18 @@ let enable = mkEnableOption "iperf3 network throughput testing server"; package = mkPackageOption pkgs "iperf3" { }; port = mkOption { - type = types.ints.u16; - default = 5201; + type = types.ints.u16; + default = 5201; description = "Server port to listen on for iperf3 client requests."; }; affinity = mkOption { - type = types.nullOr types.ints.unsigned; - default = null; + type = types.nullOr types.ints.unsigned; + default = null; description = "CPU affinity for the process."; }; bind = mkOption { - type = types.nullOr types.str; - default = null; + type = types.nullOr types.str; + default = null; description = "Bind to the specific interface associated with the given address."; }; openFirewall = mkOption { @@ -26,33 +32,33 @@ let description = "Open ports in the firewall for iperf3."; }; verbose = mkOption { - type = types.bool; - default = false; + type = types.bool; + default = false; description = "Give more detailed output."; }; forceFlush = mkOption { - type = types.bool; - default = false; + type = types.bool; + default = false; description = "Force flushing output at every interval."; }; debug = mkOption { - type = types.bool; - default = false; + type = types.bool; + default = false; description = "Emit debugging output."; }; rsaPrivateKey = mkOption { - type = types.nullOr types.path; - default = null; + type = types.nullOr types.path; + default = null; description = "Path to the RSA private key (not password-protected) used to decrypt authentication credentials from the client."; }; authorizedUsersFile = mkOption { - type = types.nullOr types.path; - default = null; + type = types.nullOr types.path; + default = null; description = "Path to the configuration file containing authorized users credentials to run iperf tests."; }; extraFlags = mkOption { - type = types.listOf types.str; - default = [ ]; + type = types.listOf types.str; + default = [ ]; description = "Extra flags to pass to iperf3(1)."; }; }; @@ -83,7 +89,11 @@ let ${optionalString (cfg.affinity != null) "--affinity ${toString cfg.affinity}"} \ ${optionalString (cfg.bind != null) "--bind ${cfg.bind}"} \ ${optionalString (cfg.rsaPrivateKey != null) "--rsa-private-key-path ${cfg.rsaPrivateKey}"} \ - ${optionalString (cfg.authorizedUsersFile != null) "--authorized-users-path ${cfg.authorizedUsersFile}"} \ + ${ + optionalString ( + cfg.authorizedUsersFile != null + ) "--authorized-users-path ${cfg.authorizedUsersFile}" + } \ ${optionalString cfg.verbose "--verbose"} \ ${optionalString cfg.debug "--debug"} \ ${optionalString cfg.forceFlush "--forceflush"} \ @@ -92,7 +102,8 @@ let }; }; }; -in { +in +{ options.services.iperf3 = api; config = mkIf cfg.enable imp; } diff --git a/nixos/modules/services/networking/ircd-hybrid/default.nix b/nixos/modules/services/networking/ircd-hybrid/default.nix index 6422e31a7bddff..95e19636edaf30 100644 --- a/nixos/modules/services/networking/ircd-hybrid/default.nix +++ b/nixos/modules/services/networking/ircd-hybrid/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -8,20 +13,40 @@ let ircdService = pkgs.stdenv.mkDerivation rec { name = "ircd-hybrid-service"; - scripts = [ "=>/bin" ./control.in ]; - substFiles = [ "=>/conf" ./ircd.conf ]; - inherit (pkgs) ircdHybrid coreutils su iproute2 gnugrep procps; + scripts = [ + "=>/bin" + ./control.in + ]; + substFiles = [ + "=>/conf" + ./ircd.conf + ]; + inherit (pkgs) + ircdHybrid + coreutils + su + iproute2 + gnugrep + procps + ; ipv6Enabled = boolToString config.networking.enableIPv6; - inherit (cfg) serverName sid description adminEmail - extraPort; + inherit (cfg) + serverName + sid + description + adminEmail + extraPort + ; cryptoSettings = - (optionalString (cfg.rsaKey != null) "rsa_private_key_file = \"${cfg.rsaKey}\";\n") + - (optionalString (cfg.certificate != null) "ssl_certificate_file = \"${cfg.certificate}\";\n"); + (optionalString (cfg.rsaKey != null) "rsa_private_key_file = \"${cfg.rsaKey}\";\n") + + (optionalString (cfg.certificate != null) "ssl_certificate_file = \"${cfg.certificate}\";\n"); - extraListen = map (ip: "host = \""+ip+"\";\nport = 6665 .. 6669, "+extraPort+"; ") cfg.extraIPs; + extraListen = map ( + ip: "host = \"" + ip + "\";\nport = 6665 .. 6669, " + extraPort + "; " + ) cfg.extraIPs; builder = ./builder.sh; }; @@ -90,8 +115,8 @@ in }; extraIPs = mkOption { - default = []; - example = ["127.0.0.1"]; + default = [ ]; + example = [ "127.0.0.1" ]; type = types.listOf types.str; description = '' Extra IP's to bind. @@ -110,16 +135,15 @@ in }; - ###### implementation config = mkIf config.services.ircdHybrid.enable { - users.users.ircd = - { description = "IRCD owner"; - group = "ircd"; - uid = config.ids.uids.ircd; - }; + users.users.ircd = { + description = "IRCD owner"; + group = "ircd"; + uid = config.ids.uids.ircd; + }; users.groups.ircd.gid = config.ids.gids.ircd; diff --git a/nixos/modules/services/networking/iscsi/initiator.nix b/nixos/modules/services/networking/iscsi/initiator.nix index a89d58403c6bcc..7a4ca5d58254d2 100644 --- a/nixos/modules/services/networking/iscsi/initiator.nix +++ b/nixos/modules/services/networking/iscsi/initiator.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, ... }: with lib; +{ + config, + lib, + pkgs, + ... +}: +with lib; let cfg = config.services.openiscsi; in @@ -38,7 +44,7 @@ in }; config = mkIf cfg.enable { - environment.etc."iscsi/iscsid.conf.fragment".source = pkgs.runCommand "iscsid.conf" {} '' + environment.etc."iscsi/iscsid.conf.fragment".source = pkgs.runCommand "iscsid.conf" { } '' cat "${cfg.package}/etc/iscsi/iscsid.conf" > $out cat << 'EOF' >> $out ${cfg.extraConfig} @@ -61,7 +67,8 @@ in echo "Warning: services.openiscsi.extraConfigFile ${cfg.extraConfigFile} does not exist!" >&2 fi ''; - in '' + in + '' ( cat ${config.environment.etc."iscsi/iscsid.conf.fragment".source} ${extraCfgDumper} @@ -72,7 +79,9 @@ in systemd.services."iscsi" = mkIf cfg.enableAutoLoginOut { wantedBy = [ "remote-fs.target" ]; - serviceConfig.ExecStartPre = mkIf (cfg.discoverPortal != null) "${cfg.package}/bin/iscsiadm --mode discoverydb --type sendtargets --portal ${escapeShellArg cfg.discoverPortal} --discover"; + serviceConfig.ExecStartPre = + mkIf (cfg.discoverPortal != null) + "${cfg.package}/bin/iscsiadm --mode discoverydb --type sendtargets --portal ${escapeShellArg cfg.discoverPortal} --discover"; }; environment.systemPackages = [ cfg.package ]; diff --git a/nixos/modules/services/networking/iscsi/root-initiator.nix b/nixos/modules/services/networking/iscsi/root-initiator.nix index 3d80d1c575524d..86396ae1e24fae 100644 --- a/nixos/modules/services/networking/iscsi/root-initiator.nix +++ b/nixos/modules/services/networking/iscsi/root-initiator.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, ... }: with lib; +{ + config, + lib, + pkgs, + ... +}: +with lib; let cfg = config.boot.iscsi-initiator; in @@ -113,7 +119,9 @@ in extraUtilsCommands = '' copy_bin_and_libs ${pkgs.openiscsi}/bin/iscsid copy_bin_and_libs ${pkgs.openiscsi}/bin/iscsiadm - ${optionalString (!config.boot.initrd.network.ssh.enable) "cp -pv ${pkgs.glibc.out}/lib/libnss_files.so.* $out/lib"} + ${optionalString ( + !config.boot.initrd.network.ssh.enable + ) "cp -pv ${pkgs.glibc.out}/lib/libnss_files.so.* $out/lib"} mkdir -p $out/etc/iscsi cp ${config.environment.etc.hosts.source} $out/etc/hosts @@ -128,51 +136,58 @@ in $out/bin/iscsiadm --version ''; - preLVMCommands = let - extraCfgDumper = optionalString (cfg.extraConfigFile != null) '' - if [ -f "${cfg.extraConfigFile}" ]; then - printf "\n# The following is from ${cfg.extraConfigFile}:\n" - cat "${cfg.extraConfigFile}" - else - echo "Warning: boot.iscsi-initiator.extraConfigFile ${cfg.extraConfigFile} does not exist!" >&2 - fi + preLVMCommands = + let + extraCfgDumper = optionalString (cfg.extraConfigFile != null) '' + if [ -f "${cfg.extraConfigFile}" ]; then + printf "\n# The following is from ${cfg.extraConfigFile}:\n" + cat "${cfg.extraConfigFile}" + else + echo "Warning: boot.iscsi-initiator.extraConfigFile ${cfg.extraConfigFile} does not exist!" >&2 + fi + ''; + in + '' + ${optionalString (!config.boot.initrd.network.ssh.enable) '' + # stolen from initrd-ssh.nix + echo 'root:x:0:0:root:/root:/bin/ash' > /etc/passwd + echo 'passwd: files' > /etc/nsswitch.conf + ''} + + cp -f $extraUtils/etc/hosts /etc/hosts + + mkdir -p /etc/iscsi /run/lock/iscsi + echo "InitiatorName=${cfg.name}" > /etc/iscsi/initiatorname.iscsi + + ( + cat "$extraUtils/etc/iscsi/iscsid.fragment.conf" + printf "\n" + ${optionalString cfg.loginAll ''echo "node.startup = automatic"''} + ${extraCfgDumper} + ) > /etc/iscsi/iscsid.conf + + iscsid --foreground --no-pid-file --debug ${toString cfg.logLevel} & + iscsiadm --mode discoverydb \ + --type sendtargets \ + --discover \ + --portal ${escapeShellArg cfg.discoverPortal} \ + --debug ${toString cfg.logLevel} + + ${ + if cfg.loginAll then + '' + iscsiadm --mode node --loginall all + '' + else + '' + iscsiadm --mode node --targetname ${escapeShellArg cfg.target} --login + '' + } + + ${cfg.extraIscsiCommands} + + pkill -9 iscsid ''; - in '' - ${optionalString (!config.boot.initrd.network.ssh.enable) '' - # stolen from initrd-ssh.nix - echo 'root:x:0:0:root:/root:/bin/ash' > /etc/passwd - echo 'passwd: files' > /etc/nsswitch.conf - ''} - - cp -f $extraUtils/etc/hosts /etc/hosts - - mkdir -p /etc/iscsi /run/lock/iscsi - echo "InitiatorName=${cfg.name}" > /etc/iscsi/initiatorname.iscsi - - ( - cat "$extraUtils/etc/iscsi/iscsid.fragment.conf" - printf "\n" - ${optionalString cfg.loginAll ''echo "node.startup = automatic"''} - ${extraCfgDumper} - ) > /etc/iscsi/iscsid.conf - - iscsid --foreground --no-pid-file --debug ${toString cfg.logLevel} & - iscsiadm --mode discoverydb \ - --type sendtargets \ - --discover \ - --portal ${escapeShellArg cfg.discoverPortal} \ - --debug ${toString cfg.logLevel} - - ${if cfg.loginAll then '' - iscsiadm --mode node --loginall all - '' else '' - iscsiadm --mode node --targetname ${escapeShellArg cfg.target} --login - ''} - - ${cfg.extraIscsiCommands} - - pkill -9 iscsid - ''; }; services.openiscsi = { diff --git a/nixos/modules/services/networking/iscsi/target.nix b/nixos/modules/services/networking/iscsi/target.nix index 8a10e7d346ae35..bfc2293768954e 100644 --- a/nixos/modules/services/networking/iscsi/target.nix +++ b/nixos/modules/services/networking/iscsi/target.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -13,7 +18,7 @@ in config = mkOption { type = attrs; - default = {}; + default = { }; description = '' Content of /etc/target/saveconfig.json This file is normally read and written by targetcli @@ -31,11 +36,18 @@ in environment.systemPackages = with pkgs; [ targetcli ]; - boot.kernelModules = [ "configfs" "target_core_mod" "iscsi_target_mod" ]; + boot.kernelModules = [ + "configfs" + "target_core_mod" + "iscsi_target_mod" + ]; systemd.services.iscsi-target = { enable = true; - after = [ "network.target" "local-fs.target" ]; + after = [ + "network.target" + "local-fs.target" + ]; requires = [ "sys-kernel-config.mount" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { diff --git a/nixos/modules/services/networking/ivpn.nix b/nixos/modules/services/networking/ivpn.nix index 6482bbadaeb2a0..7bf96d38afbe4f 100644 --- a/nixos/modules/services/networking/ivpn.nix +++ b/nixos/modules/services/networking/ivpn.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.ivpn; in @@ -17,7 +22,10 @@ in config = lib.mkIf cfg.enable { boot.kernelModules = [ "tun" ]; - environment.systemPackages = with pkgs; [ ivpn ivpn-service ]; + environment.systemPackages = with pkgs; [ + ivpn + ivpn-service + ]; # iVPN writes to /etc/iproute2/rt_tables networking.iproute2.enable = true; @@ -26,7 +34,10 @@ in systemd.services.ivpn-service = { description = "iVPN daemon"; wantedBy = [ "multi-user.target" ]; - wants = [ "network.target" "network-online.target" ]; + wants = [ + "network.target" + "network-online.target" + ]; after = [ "network-online.target" "NetworkManager.service" diff --git a/nixos/modules/services/networking/iwd.nix b/nixos/modules/services/networking/iwd.nix index 5ee0db32d65d88..2209841678b31c 100644 --- a/nixos/modules/services/networking/iwd.nix +++ b/nixos/modules/services/networking/iwd.nix @@ -1,16 +1,28 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) - mkEnableOption mkPackageOption mkIf mkOption types - recursiveUpdate; + mkEnableOption + mkPackageOption + mkIf + mkOption + types + recursiveUpdate + ; cfg = config.networking.wireless.iwd; ini = pkgs.formats.ini { }; defaults = { # without UseDefaultInterface, sometimes wlan0 simply goes AWOL with NetworkManager # https://iwd.wiki.kernel.org/interface_lifecycle#interface_management_in_iwd - General.UseDefaultInterface = with config.networking.networkmanager; (enable && (wifi.backend == "iwd")); + General.UseDefaultInterface = + with config.networking.networkmanager; + (enable && (wifi.backend == "iwd")); }; configFile = ini.generate "main.conf" (recursiveUpdate defaults cfg.settings); @@ -42,12 +54,14 @@ in }; config = mkIf cfg.enable { - assertions = [{ - assertion = !config.networking.wireless.enable; - message = '' - Only one wireless daemon is allowed at the time: networking.wireless.enable and networking.wireless.iwd.enable are mutually exclusive. - ''; - }]; + assertions = [ + { + assertion = !config.networking.wireless.enable; + message = '' + Only one wireless daemon is allowed at the time: networking.wireless.enable and networking.wireless.iwd.enable are mutually exclusive. + ''; + } + ]; environment.etc."iwd/${configFile.name}".source = configFile; diff --git a/nixos/modules/services/networking/jibri/default.nix b/nixos/modules/services/networking/jibri/default.nix index b8cddafb74f978..94018ef99f4b1b 100644 --- a/nixos/modules/services/networking/jibri/default.nix +++ b/nixos/modules/services/networking/jibri/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -9,7 +14,9 @@ let # We're passing passwords in environment variables that have names generated # from an attribute name, which may not be a valid bash identifier. - toVarName = s: "XMPP_PASSWORD_" + stringAsChars (c: if builtins.match "[A-Za-z0-9]" c != null then c else "_") s; + toVarName = + s: + "XMPP_PASSWORD_" + stringAsChars (c: if builtins.match "[A-Za-z0-9]" c != null then c else "_") s; defaultJibriConfig = { id = ""; @@ -19,33 +26,35 @@ let http.external-api-port = 2222; http.internal-api-port = 3333; - xmpp.environments = flip mapAttrsToList cfg.xmppEnvironments (name: env: { - inherit name; + xmpp.environments = flip mapAttrsToList cfg.xmppEnvironments ( + name: env: { + inherit name; - xmpp-server-hosts = env.xmppServerHosts; - xmpp-domain = env.xmppDomain; - control-muc = { - domain = env.control.muc.domain; - room-name = env.control.muc.roomName; - nickname = env.control.muc.nickname; - }; + xmpp-server-hosts = env.xmppServerHosts; + xmpp-domain = env.xmppDomain; + control-muc = { + domain = env.control.muc.domain; + room-name = env.control.muc.roomName; + nickname = env.control.muc.nickname; + }; - control-login = { - domain = env.control.login.domain; - username = env.control.login.username; - password = format.lib.mkSubstitution (toVarName "${name}_control"); - }; + control-login = { + domain = env.control.login.domain; + username = env.control.login.username; + password = format.lib.mkSubstitution (toVarName "${name}_control"); + }; - call-login = { - domain = env.call.login.domain; - username = env.call.login.username; - password = format.lib.mkSubstitution (toVarName "${name}_call"); - }; + call-login = { + domain = env.call.login.domain; + username = env.call.login.username; + password = format.lib.mkSubstitution (toVarName "${name}_call"); + }; - strip-from-room-domain = env.stripFromRoomDomain; - usage-timeout = env.usageTimeout; - trust-all-xmpp-certs = env.disableCertificateVerification; - }); + strip-from-room-domain = env.stripFromRoomDomain; + usage-timeout = env.usageTimeout; + trust-all-xmpp-certs = env.disableCertificateVerification; + } + ); }; recording = { @@ -62,10 +71,7 @@ let "--enabled" "--disable-infobars" "--autoplay-policy=no-user-gesture-required" - ] - ++ lists.optional cfg.ignoreCert - "--ignore-certificate-errors"; - + ] ++ lists.optional cfg.ignoreCert "--ignore-certificate-errors"; stats.enable-stats-d = true; webhook.subscribers = [ ]; @@ -179,122 +185,130 @@ in }; ''; default = { }; - type = attrsOf (submodule ({ name, ... }: { - options = { - xmppServerHosts = mkOption { - type = listOf str; - example = [ "xmpp.example.org" ]; - description = '' - Hostnames of the XMPP servers to connect to. - ''; - }; - xmppDomain = mkOption { - type = str; - example = "xmpp.example.org"; - description = '' - The base XMPP domain. - ''; - }; - control.muc.domain = mkOption { - type = str; - description = '' - The domain part of the MUC to connect to for control. - ''; - }; - control.muc.roomName = mkOption { - type = str; - default = "JibriBrewery"; - description = '' - The room name of the MUC to connect to for control. - ''; - }; - control.muc.nickname = mkOption { - type = str; - default = "jibri"; - description = '' - The nickname for this Jibri instance in the MUC. - ''; - }; - control.login.domain = mkOption { - type = str; - description = '' - The domain part of the JID for this Jibri instance. - ''; - }; - control.login.username = mkOption { - type = str; - default = "jvb"; - description = '' - User part of the JID. - ''; - }; - control.login.passwordFile = mkOption { - type = str; - example = "/run/keys/jibri-xmpp1"; - description = '' - File containing the password for the user. - ''; - }; - - call.login.domain = mkOption { - type = str; - example = "recorder.xmpp.example.org"; - description = '' - The domain part of the JID for the recorder. - ''; - }; - call.login.username = mkOption { - type = str; - default = "recorder"; - description = '' - User part of the JID for the recorder. - ''; - }; - call.login.passwordFile = mkOption { - type = str; - example = "/run/keys/jibri-recorder-xmpp1"; - description = '' - File containing the password for the user. - ''; - }; - disableCertificateVerification = mkOption { - type = bool; - default = false; - description = '' - Whether to skip validation of the server's certificate. - ''; - }; - - stripFromRoomDomain = mkOption { - type = str; - default = "0"; - example = "conference."; - description = '' - The prefix to strip from the room's JID domain to derive the call URL. - ''; - }; - usageTimeout = mkOption { - type = str; - default = "0"; - example = "1 hour"; - description = '' - The duration that the Jibri session can be. - A value of zero means indefinitely. - ''; - }; - }; - - config = - let - nick = mkDefault (builtins.replaceStrings [ "." ] [ "-" ] ( - config.networking.hostName + optionalString (config.networking.domain != null) ".${config.networking.domain}" - )); - in + type = attrsOf ( + submodule ( + { name, ... }: { - call.login.username = nick; - control.muc.nickname = nick; - }; - })); + options = { + xmppServerHosts = mkOption { + type = listOf str; + example = [ "xmpp.example.org" ]; + description = '' + Hostnames of the XMPP servers to connect to. + ''; + }; + xmppDomain = mkOption { + type = str; + example = "xmpp.example.org"; + description = '' + The base XMPP domain. + ''; + }; + control.muc.domain = mkOption { + type = str; + description = '' + The domain part of the MUC to connect to for control. + ''; + }; + control.muc.roomName = mkOption { + type = str; + default = "JibriBrewery"; + description = '' + The room name of the MUC to connect to for control. + ''; + }; + control.muc.nickname = mkOption { + type = str; + default = "jibri"; + description = '' + The nickname for this Jibri instance in the MUC. + ''; + }; + control.login.domain = mkOption { + type = str; + description = '' + The domain part of the JID for this Jibri instance. + ''; + }; + control.login.username = mkOption { + type = str; + default = "jvb"; + description = '' + User part of the JID. + ''; + }; + control.login.passwordFile = mkOption { + type = str; + example = "/run/keys/jibri-xmpp1"; + description = '' + File containing the password for the user. + ''; + }; + + call.login.domain = mkOption { + type = str; + example = "recorder.xmpp.example.org"; + description = '' + The domain part of the JID for the recorder. + ''; + }; + call.login.username = mkOption { + type = str; + default = "recorder"; + description = '' + User part of the JID for the recorder. + ''; + }; + call.login.passwordFile = mkOption { + type = str; + example = "/run/keys/jibri-recorder-xmpp1"; + description = '' + File containing the password for the user. + ''; + }; + disableCertificateVerification = mkOption { + type = bool; + default = false; + description = '' + Whether to skip validation of the server's certificate. + ''; + }; + + stripFromRoomDomain = mkOption { + type = str; + default = "0"; + example = "conference."; + description = '' + The prefix to strip from the room's JID domain to derive the call URL. + ''; + }; + usageTimeout = mkOption { + type = str; + default = "0"; + example = "1 hour"; + description = '' + The duration that the Jibri session can be. + A value of zero means indefinitely. + ''; + }; + }; + + config = + let + nick = mkDefault ( + builtins.replaceStrings [ "." ] [ "-" ] ( + config.networking.hostName + + optionalString (config.networking.domain != null) ".${config.networking.domain}" + ) + ); + in + { + call.login.username = nick; + control.muc.nickname = nick; + }; + } + ) + ); }; }; @@ -305,14 +319,23 @@ in isSystemUser = true; group = "jibri"; home = "/var/lib/jibri"; - extraGroups = [ "jitsi-meet" "adm" "audio" "video" "plugdev" ]; + extraGroups = [ + "jitsi-meet" + "adm" + "audio" + "video" + "plugdev" + ]; }; systemd.services.jibri-xorg = { description = "Jitsi Xorg Process"; after = [ "network.target" ]; - wantedBy = [ "jibri.service" "jibri-icewm.service" ]; + wantedBy = [ + "jibri.service" + "jibri-icewm.service" + ]; preStart = '' cp --no-preserve=mode,ownership ${pkgs.jibri}/etc/jitsi/jibri/* /var/lib/jibri @@ -360,21 +383,29 @@ in systemd.services.jibri = { description = "Jibri Process"; - requires = [ "jibri-icewm.service" "jibri-xorg.service" ]; + requires = [ + "jibri-icewm.service" + "jibri-xorg.service" + ]; after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; - path = with pkgs; [ chromedriver chromium ffmpeg-full ]; - - script = (concatStrings (mapAttrsToList - (name: env: '' - export ${toVarName "${name}_control"}=$(cat ${env.control.login.passwordFile}) - export ${toVarName "${name}_call"}=$(cat ${env.call.login.passwordFile}) - '') - cfg.xmppEnvironments)) - + '' - ${pkgs.jdk11_headless}/bin/java -Djava.util.logging.config.file=${./logging.properties-journal} -Dconfig.file=${configFile} -jar ${pkgs.jibri}/opt/jitsi/jibri/jibri.jar --config /var/lib/jibri/jibri.json - ''; + path = with pkgs; [ + chromedriver + chromium + ffmpeg-full + ]; + + script = + (concatStrings ( + mapAttrsToList (name: env: '' + export ${toVarName "${name}_control"}=$(cat ${env.control.login.passwordFile}) + export ${toVarName "${name}_call"}=$(cat ${env.call.login.passwordFile}) + '') cfg.xmppEnvironments + )) + + '' + ${pkgs.jdk11_headless}/bin/java -Djava.util.logging.config.file=${./logging.properties-journal} -Dconfig.file=${configFile} -jar ${pkgs.jibri}/opt/jitsi/jibri/jibri.jar --config /var/lib/jibri/jibri.json + ''; environment.HOME = "/var/lib/jibri"; @@ -397,8 +428,12 @@ in }; # Configure Chromium to not show the "Chrome is being controlled by automatic test software" message. - environment.etc."chromium/policies/managed/managed_policies.json".text = builtins.toJSON { CommandLineFlagSecurityWarningsEnabled = false; }; - warnings = [ "All security warnings for Chromium have been disabled. This is necessary for Jibri, but it also impacts all other uses of Chromium on this system." ]; + environment.etc."chromium/policies/managed/managed_policies.json".text = builtins.toJSON { + CommandLineFlagSecurityWarningsEnabled = false; + }; + warnings = [ + "All security warnings for Chromium have been disabled. This is necessary for Jibri, but it also impacts all other uses of Chromium on this system." + ]; boot = { extraModprobeConfig = '' diff --git a/nixos/modules/services/networking/jicofo.nix b/nixos/modules/services/networking/jicofo.nix index 91906e417361d3..9d0fbfd74081e4 100644 --- a/nixos/modules/services/networking/jicofo.nix +++ b/nixos/modules/services/networking/jicofo.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.jicofo; @@ -99,55 +104,62 @@ in }; }; - users.groups.jitsi-meet = {}; - - systemd.services.jicofo = let - jicofoProps = { - "-Dnet.java.sip.communicator.SC_HOME_DIR_LOCATION" = "/etc/jitsi"; - "-Dnet.java.sip.communicator.SC_HOME_DIR_NAME" = "jicofo"; - "-Djava.util.logging.config.file" = "/etc/jitsi/jicofo/logging.properties"; - "-Dconfig.file" = configFile; - }; - in - { - description = "JItsi COnference FOcus"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - - restartTriggers = [ - configFile - ]; - environment.JAVA_SYS_PROPS = lib.concatStringsSep " " (lib.mapAttrsToList (k: v: "${k}=${toString v}") jicofoProps); - - script = '' - export JICOFO_AUTH_PASS="$(<${cfg.userPasswordFile})" - exec "${pkgs.jicofo}/bin/jicofo" - ''; + users.groups.jitsi-meet = { }; - serviceConfig = { - Type = "exec"; - - DynamicUser = true; - User = "jicofo"; - Group = "jitsi-meet"; - - CapabilityBoundingSet = ""; - NoNewPrivileges = true; - ProtectSystem = "strict"; - ProtectHome = true; - PrivateTmp = true; - PrivateDevices = true; - ProtectHostname = true; - ProtectKernelTunables = true; - ProtectKernelModules = true; - ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; - RestrictNamespaces = true; - LockPersonality = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; + systemd.services.jicofo = + let + jicofoProps = { + "-Dnet.java.sip.communicator.SC_HOME_DIR_LOCATION" = "/etc/jitsi"; + "-Dnet.java.sip.communicator.SC_HOME_DIR_NAME" = "jicofo"; + "-Djava.util.logging.config.file" = "/etc/jitsi/jicofo/logging.properties"; + "-Dconfig.file" = configFile; + }; + in + { + description = "JItsi COnference FOcus"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + + restartTriggers = [ + configFile + ]; + environment.JAVA_SYS_PROPS = lib.concatStringsSep " " ( + lib.mapAttrsToList (k: v: "${k}=${toString v}") jicofoProps + ); + + script = '' + export JICOFO_AUTH_PASS="$(<${cfg.userPasswordFile})" + exec "${pkgs.jicofo}/bin/jicofo" + ''; + + serviceConfig = { + Type = "exec"; + + DynamicUser = true; + User = "jicofo"; + Group = "jitsi-meet"; + + CapabilityBoundingSet = ""; + NoNewPrivileges = true; + ProtectSystem = "strict"; + ProtectHome = true; + PrivateTmp = true; + PrivateDevices = true; + ProtectHostname = true; + ProtectKernelTunables = true; + ProtectKernelModules = true; + ProtectControlGroups = true; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; + RestrictNamespaces = true; + LockPersonality = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + }; }; - }; environment.etc."jitsi/jicofo/sip-communicator.properties".text = ""; environment.etc."jitsi/jicofo/logging.properties".source = diff --git a/nixos/modules/services/networking/jigasi.nix b/nixos/modules/services/networking/jigasi.nix index d69d905788f401..54b2f36685f6a4 100644 --- a/nixos/modules/services/networking/jigasi.nix +++ b/nixos/modules/services/networking/jigasi.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.jigasi; homeDirName = "jigasi-home"; @@ -113,119 +118,127 @@ in "org.jitsi.jigasi.BRIDGE_MUC" = cfg.bridgeMuc; }; - users.groups.jitsi-meet = {}; - - systemd.services.jigasi = let - jigasiProps = { - "-Dnet.java.sip.communicator.SC_HOME_DIR_LOCATION" = "${stateDir}"; - "-Dnet.java.sip.communicator.SC_HOME_DIR_NAME" = "${homeDirName}"; - "-Djava.util.logging.config.file" = "${pkgs.jigasi}/etc/jitsi/jigasi/logging.properties"; - }; - in - { - description = "Jitsi Gateway to SIP"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - - preStart = '' - [ -f "${sipCommunicatorPropertiesFile}" ] && rm -f "${sipCommunicatorPropertiesFile}" - mkdir -p "$(dirname ${sipCommunicatorPropertiesFile})" - temp="${sipCommunicatorPropertiesFile}.unsubstituted" - - export DOMAIN_BASE="${cfg.xmppDomain}" - export JIGASI_XMPP_PASSWORD=$(cat "${cfg.userPasswordFile}") - export JIGASI_DEFAULT_JVB_ROOM_NAME="${cfg.defaultJvbRoomName}" - - # encode the credentials to base64 - export JIGASI_SIPPWD=$(echo -n "$JIGASI_SIPPWD" | base64 -w 0) - export JIGASI_XMPP_PASSWORD_BASE64=$(cat "${cfg.userPasswordFile}" | base64 -w 0) - - cp "${sipCommunicatorPropertiesFileUnsubstituted}" "$temp" - chmod 644 "$temp" - cat <>"$temp" - net.java.sip.communicator.impl.protocol.sip.acc1403273890647.SERVER_PORT=$JIGASI_SIPPORT - net.java.sip.communicator.impl.protocol.sip.acc1403273890647.PREFERRED_TRANSPORT=udp - EOF - chmod 444 "$temp" - - # Replace <<$VAR_NAME>> from example config to $VAR_NAME for environment substitution - sed -i -E \ - 's/<<([^>]+)>>/\$\1/g' \ - "$temp" - - sed -i \ - 's|\(net\.java\.sip\.communicator\.impl\.protocol\.jabber\.acc-xmpp-1\.PASSWORD=\).*|\1\$JIGASI_XMPP_PASSWORD_BASE64|g' \ - "$temp" - - sed -i \ - 's|\(#\)\(org.jitsi.jigasi.DEFAULT_JVB_ROOM_NAME=\).*|\2\$JIGASI_DEFAULT_JVB_ROOM_NAME|g' \ - "$temp" - - ${pkgs.envsubst}/bin/envsubst \ - -o "${sipCommunicatorPropertiesFile}" \ - -i "$temp" - - # Set the brewery room name - sed -i \ - 's|\(net\.java\.sip\.communicator\.impl\.protocol\.jabber\.acc-xmpp-1\.BREWERY=\).*|\1${cfg.bridgeMuc}|g' \ - "${sipCommunicatorPropertiesFile}" - sed -i \ - 's|\(org\.jitsi\.jigasi\.ALLOWED_JID=\).*|\1${cfg.bridgeMuc}|g' \ - "${sipCommunicatorPropertiesFile}" - - - # Disable certificate verification for self-signed certificates - sed -i \ - 's|\(# \)\(net.java.sip.communicator.service.gui.ALWAYS_TRUST_MODE_ENABLED=true\)|\2|g' \ - "${sipCommunicatorPropertiesFile}" - ''; - - restartTriggers = [ - config.environment.etc."jitsi/jigasi/sip-communicator.properties".source - ]; - environment.JAVA_SYS_PROPS = lib.concatStringsSep " " (lib.mapAttrsToList (k: v: "${k}=${toString v}") jigasiProps); - - script = '' - ${pkgs.jigasi}/bin/jigasi \ - --host="${cfg.xmppHost}" \ - --domain="${if cfg.xmppDomain == null then cfg.xmppHost else cfg.xmppDomain}" \ - --secret="$(cat ${cfg.componentPasswordFile})" \ - --user_name="${cfg.userName}" \ - --user_domain="${cfg.userDomain}" \ - --user_password="$(cat ${cfg.userPasswordFile})" \ - --configdir="${stateDir}" \ - --configdirname="${homeDirName}" - ''; - - serviceConfig = { - Type = "exec"; - - DynamicUser = true; - User = "jigasi"; - Group = "jitsi-meet"; - - CapabilityBoundingSet = ""; - NoNewPrivileges = true; - ProtectSystem = "strict"; - ProtectHome = true; - PrivateTmp = true; - PrivateDevices = true; - ProtectHostname = true; - ProtectKernelTunables = true; - ProtectKernelModules = true; - ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; - RestrictNamespaces = true; - LockPersonality = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - StateDirectory = baseNameOf stateDir; - EnvironmentFile = cfg.environmentFile; + users.groups.jitsi-meet = { }; + + systemd.services.jigasi = + let + jigasiProps = { + "-Dnet.java.sip.communicator.SC_HOME_DIR_LOCATION" = "${stateDir}"; + "-Dnet.java.sip.communicator.SC_HOME_DIR_NAME" = "${homeDirName}"; + "-Djava.util.logging.config.file" = "${pkgs.jigasi}/etc/jitsi/jigasi/logging.properties"; + }; + in + { + description = "Jitsi Gateway to SIP"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + + preStart = '' + [ -f "${sipCommunicatorPropertiesFile}" ] && rm -f "${sipCommunicatorPropertiesFile}" + mkdir -p "$(dirname ${sipCommunicatorPropertiesFile})" + temp="${sipCommunicatorPropertiesFile}.unsubstituted" + + export DOMAIN_BASE="${cfg.xmppDomain}" + export JIGASI_XMPP_PASSWORD=$(cat "${cfg.userPasswordFile}") + export JIGASI_DEFAULT_JVB_ROOM_NAME="${cfg.defaultJvbRoomName}" + + # encode the credentials to base64 + export JIGASI_SIPPWD=$(echo -n "$JIGASI_SIPPWD" | base64 -w 0) + export JIGASI_XMPP_PASSWORD_BASE64=$(cat "${cfg.userPasswordFile}" | base64 -w 0) + + cp "${sipCommunicatorPropertiesFileUnsubstituted}" "$temp" + chmod 644 "$temp" + cat <>"$temp" + net.java.sip.communicator.impl.protocol.sip.acc1403273890647.SERVER_PORT=$JIGASI_SIPPORT + net.java.sip.communicator.impl.protocol.sip.acc1403273890647.PREFERRED_TRANSPORT=udp + EOF + chmod 444 "$temp" + + # Replace <<$VAR_NAME>> from example config to $VAR_NAME for environment substitution + sed -i -E \ + 's/<<([^>]+)>>/\$\1/g' \ + "$temp" + + sed -i \ + 's|\(net\.java\.sip\.communicator\.impl\.protocol\.jabber\.acc-xmpp-1\.PASSWORD=\).*|\1\$JIGASI_XMPP_PASSWORD_BASE64|g' \ + "$temp" + + sed -i \ + 's|\(#\)\(org.jitsi.jigasi.DEFAULT_JVB_ROOM_NAME=\).*|\2\$JIGASI_DEFAULT_JVB_ROOM_NAME|g' \ + "$temp" + + ${pkgs.envsubst}/bin/envsubst \ + -o "${sipCommunicatorPropertiesFile}" \ + -i "$temp" + + # Set the brewery room name + sed -i \ + 's|\(net\.java\.sip\.communicator\.impl\.protocol\.jabber\.acc-xmpp-1\.BREWERY=\).*|\1${cfg.bridgeMuc}|g' \ + "${sipCommunicatorPropertiesFile}" + sed -i \ + 's|\(org\.jitsi\.jigasi\.ALLOWED_JID=\).*|\1${cfg.bridgeMuc}|g' \ + "${sipCommunicatorPropertiesFile}" + + + # Disable certificate verification for self-signed certificates + sed -i \ + 's|\(# \)\(net.java.sip.communicator.service.gui.ALWAYS_TRUST_MODE_ENABLED=true\)|\2|g' \ + "${sipCommunicatorPropertiesFile}" + ''; + + restartTriggers = [ + config.environment.etc."jitsi/jigasi/sip-communicator.properties".source + ]; + environment.JAVA_SYS_PROPS = lib.concatStringsSep " " ( + lib.mapAttrsToList (k: v: "${k}=${toString v}") jigasiProps + ); + + script = '' + ${pkgs.jigasi}/bin/jigasi \ + --host="${cfg.xmppHost}" \ + --domain="${if cfg.xmppDomain == null then cfg.xmppHost else cfg.xmppDomain}" \ + --secret="$(cat ${cfg.componentPasswordFile})" \ + --user_name="${cfg.userName}" \ + --user_domain="${cfg.userDomain}" \ + --user_password="$(cat ${cfg.userPasswordFile})" \ + --configdir="${stateDir}" \ + --configdirname="${homeDirName}" + ''; + + serviceConfig = { + Type = "exec"; + + DynamicUser = true; + User = "jigasi"; + Group = "jitsi-meet"; + + CapabilityBoundingSet = ""; + NoNewPrivileges = true; + ProtectSystem = "strict"; + ProtectHome = true; + PrivateTmp = true; + PrivateDevices = true; + ProtectHostname = true; + ProtectKernelTunables = true; + ProtectKernelModules = true; + ProtectControlGroups = true; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; + RestrictNamespaces = true; + LockPersonality = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + StateDirectory = baseNameOf stateDir; + EnvironmentFile = cfg.environmentFile; + }; }; - }; - environment.etc."jitsi/jigasi/sip-communicator.properties".source = - lib.mkDefault "${sipCommunicatorPropertiesFile}"; + environment.etc."jitsi/jigasi/sip-communicator.properties".source = lib.mkDefault "${ + sipCommunicatorPropertiesFile + }"; environment.etc."jitsi/jigasi/logging.properties".source = lib.mkDefault "${stateDir}/logging.properties-journal"; }; diff --git a/nixos/modules/services/networking/jitsi-videobridge.nix b/nixos/modules/services/networking/jitsi-videobridge.nix index 14eb64eae25359..3303aeb7f78cd4 100644 --- a/nixos/modules/services/networking/jitsi-videobridge.nix +++ b/nixos/modules/services/networking/jitsi-videobridge.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.jitsi-videobridge; attrsToArgs = a: lib.concatStringsSep " " (lib.mapAttrsToList (k: v: "${k}=${toString v}") a); @@ -7,7 +12,10 @@ let # We're passing passwords in environment variables that have names generated # from an attribute name, which may not be a valid bash identifier. - toVarName = s: "XMPP_PASSWORD_" + lib.stringAsChars (c: if builtins.match "[A-Za-z0-9]" c != null then c else "_") s; + toVarName = + s: + "XMPP_PASSWORD_" + + lib.stringAsChars (c: if builtins.match "[A-Za-z0-9]" c != null then c else "_") s; defaultJvbConfig = { videobridge = { @@ -22,15 +30,17 @@ let enabled = true; transports = [ { type = "muc"; } ]; }; - apis.xmpp-client.configs = lib.flip lib.mapAttrs cfg.xmppConfigs (name: xmppConfig: { - hostname = xmppConfig.hostName; - domain = xmppConfig.domain; - username = xmppConfig.userName; - password = format.lib.mkSubstitution (toVarName name); - muc_jids = xmppConfig.mucJids; - muc_nickname = xmppConfig.mucNickname; - disable_certificate_verification = xmppConfig.disableCertificateVerification; - }); + apis.xmpp-client.configs = lib.flip lib.mapAttrs cfg.xmppConfigs ( + name: xmppConfig: { + hostname = xmppConfig.hostName; + domain = xmppConfig.domain; + username = xmppConfig.userName; + password = format.lib.mkSubstitution (toVarName name); + muc_jids = xmppConfig.mucJids; + muc_nickname = xmppConfig.mucNickname; + disable_certificate_verification = xmppConfig.disableCertificateVerification; + } + ); apis.rest.enabled = cfg.colibriRestApi; }; }; @@ -87,67 +97,72 @@ in }; } ''; - type = attrsOf (submodule ({ name, ... }: { - options = { - hostName = lib.mkOption { - type = str; - example = "xmpp.example.org"; - description = '' - Hostname of the XMPP server to connect to. Name of the attribute set is used by default. - ''; - }; - domain = lib.mkOption { - type = nullOr str; - default = null; - example = "auth.xmpp.example.org"; - description = '' - Domain part of JID of the XMPP user, if it is different from hostName. - ''; - }; - userName = lib.mkOption { - type = str; - default = "jvb"; - description = '' - User part of the JID. - ''; - }; - passwordFile = lib.mkOption { - type = str; - example = "/run/keys/jitsi-videobridge-xmpp1"; - description = '' - File containing the password for the user. - ''; - }; - mucJids = lib.mkOption { - type = str; - example = "jvbbrewery@internal.xmpp.example.org"; - description = '' - JID of the MUC to join. JiCoFo needs to be configured to join the same MUC. - ''; - }; - mucNickname = lib.mkOption { - # Upstream DEBs use UUID, let's use hostname instead. - type = str; - description = '' - Videobridges use the same XMPP account and need to be distinguished by the - nickname (aka resource part of the JID). By default, system hostname is used. - ''; - }; - disableCertificateVerification = lib.mkOption { - type = bool; - default = false; - description = '' - Whether to skip validation of the server's certificate. - ''; - }; - }; - config = { - hostName = lib.mkDefault name; - mucNickname = lib.mkDefault (builtins.replaceStrings [ "." ] [ "-" ] ( - config.networking.fqdnOrHostName - )); - }; - })); + type = attrsOf ( + submodule ( + { name, ... }: + { + options = { + hostName = lib.mkOption { + type = str; + example = "xmpp.example.org"; + description = '' + Hostname of the XMPP server to connect to. Name of the attribute set is used by default. + ''; + }; + domain = lib.mkOption { + type = nullOr str; + default = null; + example = "auth.xmpp.example.org"; + description = '' + Domain part of JID of the XMPP user, if it is different from hostName. + ''; + }; + userName = lib.mkOption { + type = str; + default = "jvb"; + description = '' + User part of the JID. + ''; + }; + passwordFile = lib.mkOption { + type = str; + example = "/run/keys/jitsi-videobridge-xmpp1"; + description = '' + File containing the password for the user. + ''; + }; + mucJids = lib.mkOption { + type = str; + example = "jvbbrewery@internal.xmpp.example.org"; + description = '' + JID of the MUC to join. JiCoFo needs to be configured to join the same MUC. + ''; + }; + mucNickname = lib.mkOption { + # Upstream DEBs use UUID, let's use hostname instead. + type = str; + description = '' + Videobridges use the same XMPP account and need to be distinguished by the + nickname (aka resource part of the JID). By default, system hostname is used. + ''; + }; + disableCertificateVerification = lib.mkOption { + type = bool; + default = false; + description = '' + Whether to skip validation of the server's certificate. + ''; + }; + }; + config = { + hostName = lib.mkDefault name; + mucNickname = lib.mkDefault ( + builtins.replaceStrings [ "." ] [ "-" ] (config.networking.fqdnOrHostName) + ); + }; + } + ) + ); }; nat = { @@ -176,7 +191,7 @@ in "stun.framasoft.org:3478" "meet-jit-si-turnrelay.jitsi.net:443" ]; - example = []; + example = [ ]; description = '' Addresses of public STUN services to use to automatically find the public and local addresses of this Jitsi-Videobridge instance @@ -215,69 +230,81 @@ in }; config = lib.mkIf cfg.enable { - users.groups.jitsi-meet = {}; + users.groups.jitsi-meet = { }; services.jitsi-videobridge.extraProperties = - if (cfg.nat.localAddress != null) then { - "org.ice4j.ice.harvest.NAT_HARVESTER_LOCAL_ADDRESS" = cfg.nat.localAddress; - "org.ice4j.ice.harvest.NAT_HARVESTER_PUBLIC_ADDRESS" = cfg.nat.publicAddress; - } else { - "org.ice4j.ice.harvest.STUN_MAPPING_HARVESTER_ADDRESSES" = lib.concatStringsSep "," cfg.nat.harvesterAddresses; - }; + if (cfg.nat.localAddress != null) then + { + "org.ice4j.ice.harvest.NAT_HARVESTER_LOCAL_ADDRESS" = cfg.nat.localAddress; + "org.ice4j.ice.harvest.NAT_HARVESTER_PUBLIC_ADDRESS" = cfg.nat.publicAddress; + } + else + { + "org.ice4j.ice.harvest.STUN_MAPPING_HARVESTER_ADDRESSES" = + lib.concatStringsSep "," cfg.nat.harvesterAddresses; + }; - systemd.services.jitsi-videobridge2 = let - jvbProps = { - "-Dnet.java.sip.communicator.SC_HOME_DIR_LOCATION" = "/etc/jitsi"; - "-Dnet.java.sip.communicator.SC_HOME_DIR_NAME" = "videobridge"; - "-Djava.util.logging.config.file" = "/etc/jitsi/videobridge/logging.properties"; - "-Dconfig.file" = format.generate "jvb.conf" jvbConfig; - # Mitigate CVE-2021-44228 - "-Dlog4j2.formatMsgNoLookups" = true; - } // (lib.mapAttrs' (k: v: lib.nameValuePair "-D${k}" v) cfg.extraProperties); - in - { - aliases = [ "jitsi-videobridge.service" ]; - description = "Jitsi Videobridge"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; + systemd.services.jitsi-videobridge2 = + let + jvbProps = { + "-Dnet.java.sip.communicator.SC_HOME_DIR_LOCATION" = "/etc/jitsi"; + "-Dnet.java.sip.communicator.SC_HOME_DIR_NAME" = "videobridge"; + "-Djava.util.logging.config.file" = "/etc/jitsi/videobridge/logging.properties"; + "-Dconfig.file" = format.generate "jvb.conf" jvbConfig; + # Mitigate CVE-2021-44228 + "-Dlog4j2.formatMsgNoLookups" = true; + } // (lib.mapAttrs' (k: v: lib.nameValuePair "-D${k}" v) cfg.extraProperties); + in + { + aliases = [ "jitsi-videobridge.service" ]; + description = "Jitsi Videobridge"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; - environment.JAVA_SYS_PROPS = attrsToArgs jvbProps; + environment.JAVA_SYS_PROPS = attrsToArgs jvbProps; - script = (lib.concatStrings (lib.mapAttrsToList (name: xmppConfig: - "export ${toVarName name}=$(cat ${xmppConfig.passwordFile})\n" - ) cfg.xmppConfigs)) - + '' - ${pkgs.jitsi-videobridge}/bin/jitsi-videobridge - ''; + script = + (lib.concatStrings ( + lib.mapAttrsToList ( + name: xmppConfig: "export ${toVarName name}=$(cat ${xmppConfig.passwordFile})\n" + ) cfg.xmppConfigs + )) + + '' + ${pkgs.jitsi-videobridge}/bin/jitsi-videobridge + ''; - serviceConfig = { - Type = "exec"; + serviceConfig = { + Type = "exec"; - DynamicUser = true; - User = "jitsi-videobridge"; - Group = "jitsi-meet"; + DynamicUser = true; + User = "jitsi-videobridge"; + Group = "jitsi-meet"; - CapabilityBoundingSet = ""; - NoNewPrivileges = true; - ProtectSystem = "strict"; - ProtectHome = true; - PrivateTmp = true; - PrivateDevices = true; - ProtectHostname = true; - ProtectKernelTunables = true; - ProtectKernelModules = true; - ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; - RestrictNamespaces = true; - LockPersonality = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; + CapabilityBoundingSet = ""; + NoNewPrivileges = true; + ProtectSystem = "strict"; + ProtectHome = true; + PrivateTmp = true; + PrivateDevices = true; + ProtectHostname = true; + ProtectKernelTunables = true; + ProtectKernelModules = true; + ProtectControlGroups = true; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; + RestrictNamespaces = true; + LockPersonality = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; - TasksMax = 65000; - LimitNPROC = 65000; - LimitNOFILE = 65000; + TasksMax = 65000; + LimitNPROC = 65000; + LimitNOFILE = 65000; + }; }; - }; environment.etc."jitsi/videobridge/logging.properties".source = lib.mkDefault "${pkgs.jitsi-videobridge}/etc/jitsi/videobridge/logging.properties-journal"; @@ -287,15 +314,19 @@ in boot.kernel.sysctl."net.core.rmem_max" = lib.mkDefault 10485760; boot.kernel.sysctl."net.core.netdev_max_backlog" = lib.mkDefault 100000; - networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall - [ jvbConfig.videobridge.ice.tcp.port ]; - networking.firewall.allowedUDPPorts = lib.mkIf cfg.openFirewall - [ jvbConfig.videobridge.ice.udp.port ]; + networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall [ + jvbConfig.videobridge.ice.tcp.port + ]; + networking.firewall.allowedUDPPorts = lib.mkIf cfg.openFirewall [ + jvbConfig.videobridge.ice.udp.port + ]; - assertions = [{ - message = "publicAddress must be set if and only if localAddress is set"; - assertion = (cfg.nat.publicAddress == null) == (cfg.nat.localAddress == null); - }]; + assertions = [ + { + message = "publicAddress must be set if and only if localAddress is set"; + assertion = (cfg.nat.publicAddress == null) == (cfg.nat.localAddress == null); + } + ]; }; meta.maintainers = lib.teams.jitsi.members; diff --git a/nixos/modules/services/networking/jool.nix b/nixos/modules/services/networking/jool.nix index 8db947db6a458d..e782bd587fc5c5 100644 --- a/nixos/modules/services/networking/jool.nix +++ b/nixos/modules/services/networking/jool.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.networking.jool; @@ -20,24 +25,31 @@ let ]; # Give capabilities to load the module and configure it - AmbientCapabilities = [ "CAP_SYS_MODULE" "CAP_NET_ADMIN" ]; + AmbientCapabilities = [ + "CAP_SYS_MODULE" + "CAP_NET_ADMIN" + ]; RestrictAddressFamilies = [ "AF_NETLINK" ]; # Other restrictions RestrictNamespaces = [ "net" ]; - SystemCallFilter = [ "@system-service" "@module" ]; - CapabilityBoundingSet = [ "CAP_SYS_MODULE" "CAP_NET_ADMIN" ]; + SystemCallFilter = [ + "@system-service" + "@module" + ]; + CapabilityBoundingSet = [ + "CAP_SYS_MODULE" + "CAP_NET_ADMIN" + ]; }; - configFormat = pkgs.formats.json {}; + configFormat = pkgs.formats.json { }; # Generate the config file of instance `name` - nat64Conf = name: - configFormat.generate "jool-nat64-${name}.conf" - (cfg.nat64.${name} // { instance = name; }); - siitConf = name: - configFormat.generate "jool-siit-${name}.conf" - (cfg.siit.${name} // { instance = name; }); + nat64Conf = + name: configFormat.generate "jool-nat64-${name}.conf" (cfg.nat64.${name} // { instance = name; }); + siitConf = + name: configFormat.generate "jool-siit-${name}.conf" (cfg.siit.${name} // { instance = name; }); # NAT64 config type nat64Options = lib.types.submodule { @@ -45,7 +57,10 @@ let freeformType = configFormat.type; # Some options with a default value options.framework = lib.mkOption { - type = lib.types.enum [ "netfilter" "iptables" ]; + type = lib.types.enum [ + "netfilter" + "iptables" + ]; default = "netfilter"; description = '' The framework to use for attaching Jool's translation to the exist @@ -55,8 +70,9 @@ let ''; }; options.global.pool6 = lib.mkOption { - type = lib.types.strMatching "[[:xdigit:]:]+/[[:digit:]]+" - // { description = "Network prefix in CIDR notation"; }; + type = lib.types.strMatching "[[:xdigit:]:]+/[[:digit:]]+" // { + description = "Network prefix in CIDR notation"; + }; default = "64:ff9b::/96"; description = '' The prefix used for embedding IPv4 into IPv6 addresses. @@ -71,7 +87,7 @@ let # The format is, again, plain JSON freeformType = configFormat.type; # Some options with a default value - options = { inherit (nat64Options.getSubOptions []) framework; }; + options = { inherit (nat64Options.getSubOptions [ ]) framework; }; }; makeNat64Unit = name: opts: { @@ -84,8 +100,8 @@ let Type = "oneshot"; RemainAfterExit = true; ExecStartPre = "${pkgs.kmod}/bin/modprobe jool"; - ExecStart = "${jool-cli}/bin/jool file handle ${nat64Conf name}"; - ExecStop = "${jool-cli}/bin/jool -f ${nat64Conf name} instance remove"; + ExecStart = "${jool-cli}/bin/jool file handle ${nat64Conf name}"; + ExecStop = "${jool-cli}/bin/jool -f ${nat64Conf name} instance remove"; } // hardening; }; }; @@ -100,8 +116,8 @@ let Type = "oneshot"; RemainAfterExit = true; ExecStartPre = "${pkgs.kmod}/bin/modprobe jool_siit"; - ExecStart = "${jool-cli}/bin/jool_siit file handle ${siitConf name}"; - ExecStop = "${jool-cli}/bin/jool_siit -f ${siitConf name} instance remove"; + ExecStart = "${jool-cli}/bin/jool_siit file handle ${siitConf name}"; + ExecStop = "${jool-cli}/bin/jool_siit -f ${siitConf name} instance remove"; } // hardening; }; }; @@ -125,7 +141,10 @@ in networking.jool.enable = lib.mkOption { type = lib.types.bool; default = false; - relatedPackages = [ "linuxPackages.jool" "jool-cli" ]; + relatedPackages = [ + "linuxPackages.jool" + "jool-cli" + ]; description = '' Whether to enable Jool, an Open Source implementation of IPv4/IPv6 translation on Linux. @@ -260,20 +279,21 @@ in environment.systemPackages = [ jool-cli ]; # Install services for each instance - systemd.services = lib.mkMerge - (lib.mapAttrsToList makeNat64Unit cfg.nat64 ++ - lib.mapAttrsToList makeSiitUnit cfg.siit); + systemd.services = lib.mkMerge ( + lib.mapAttrsToList makeNat64Unit cfg.nat64 ++ lib.mapAttrsToList makeSiitUnit cfg.siit + ); # Check the configuration of each instance - system.checks = lib.optional (cfg.nat64 != {} || cfg.siit != {}) - (pkgs.runCommand "jool-validated" + system.checks = lib.optional (cfg.nat64 != { } || cfg.siit != { }) ( + pkgs.runCommand "jool-validated" { nativeBuildInputs = with pkgs.buildPackages; [ jool-cli ]; preferLocalBuild = true; } - (lib.concatStrings - (lib.mapAttrsToList checkNat64 cfg.nat64 ++ - lib.mapAttrsToList checkSiit cfg.siit))); + ( + lib.concatStrings (lib.mapAttrsToList checkNat64 cfg.nat64 ++ lib.mapAttrsToList checkSiit cfg.siit) + ) + ); }; meta.maintainers = with lib.maintainers; [ rnhmjoj ]; diff --git a/nixos/modules/services/networking/jotta-cli.nix b/nixos/modules/services/networking/jotta-cli.nix index 566e7fc503a6d1..0f2a561909a4eb 100644 --- a/nixos/modules/services/networking/jotta-cli.nix +++ b/nixos/modules/services/networking/jotta-cli.nix @@ -1,13 +1,24 @@ -{ config, lib, pkgs, ... }: -let cfg = config.services.jotta-cli; -in { +{ + config, + lib, + pkgs, + ... +}: +let + cfg = config.services.jotta-cli; +in +{ options = { services.jotta-cli = { enable = lib.mkEnableOption "Jottacloud Command-line Tool"; options = lib.mkOption { - default = [ "stdoutlog" "datadir" "%h/.jottad/" ]; + default = [ + "stdoutlog" + "datadir" + "%h/.jottad/" + ]; example = [ ]; type = with lib.types; listOf str; description = "Command-line options passed to jottad."; diff --git a/nixos/modules/services/networking/kea.nix b/nixos/modules/services/networking/kea.nix index 33e578cadc97cc..39b2380cadd341 100644 --- a/nixos/modules/services/networking/kea.nix +++ b/nixos/modules/services/networking/kea.nix @@ -1,30 +1,39 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let cfg = config.services.kea; - format = pkgs.formats.json {}; + format = pkgs.formats.json { }; chooseNotNull = x: y: if x != null then x else y; - ctrlAgentConfig = chooseNotNull cfg.ctrl-agent.configFile (format.generate "kea-ctrl-agent.conf" { - Control-agent = cfg.ctrl-agent.settings; - }); - - dhcp4Config = chooseNotNull cfg.dhcp4.configFile (format.generate "kea-dhcp4.conf" { - Dhcp4 = cfg.dhcp4.settings; - }); - - dhcp6Config = chooseNotNull cfg.dhcp6.configFile (format.generate "kea-dhcp6.conf" { - Dhcp6 = cfg.dhcp6.settings; - }); - - dhcpDdnsConfig = chooseNotNull cfg.dhcp-ddns.configFile (format.generate "kea-dhcp-ddns.conf" { - DhcpDdns = cfg.dhcp-ddns.settings; - }); + ctrlAgentConfig = chooseNotNull cfg.ctrl-agent.configFile ( + format.generate "kea-ctrl-agent.conf" { + Control-agent = cfg.ctrl-agent.settings; + } + ); + + dhcp4Config = chooseNotNull cfg.dhcp4.configFile ( + format.generate "kea-dhcp4.conf" { + Dhcp4 = cfg.dhcp4.settings; + } + ); + + dhcp6Config = chooseNotNull cfg.dhcp6.configFile ( + format.generate "kea-dhcp6.conf" { + Dhcp6 = cfg.dhcp6.settings; + } + ); + + dhcpDdnsConfig = chooseNotNull cfg.dhcp-ddns.configFile ( + format.generate "kea-dhcp-ddns.conf" { + DhcpDdns = cfg.dhcp-ddns.settings; + } + ); package = pkgs.kea; in @@ -34,14 +43,14 @@ in description = '' Kea Control Agent configuration ''; - default = {}; + default = { }; type = submodule { options = { enable = lib.mkEnableOption "Kea Control Agent"; extraArgs = lib.mkOption { type = listOf str; - default = []; + default = [ ]; description = '' List of additional arguments to pass to the daemon. ''; @@ -73,14 +82,14 @@ in description = '' DHCP4 Server configuration ''; - default = {}; + default = { }; type = submodule { options = { enable = lib.mkEnableOption "Kea DHCP4 server"; extraArgs = lib.mkOption { type = listOf str; - default = []; + default = [ ]; description = '' List of additional arguments to pass to the daemon. ''; @@ -114,13 +123,17 @@ in persist = true; name = "/var/lib/kea/dhcp4.leases"; }; - subnet4 = [ { - id = 1; - subnet = "192.0.2.0/24"; - pools = [ { - pool = "192.0.2.100 - 192.0.2.240"; - } ]; - } ]; + subnet4 = [ + { + id = 1; + subnet = "192.0.2.0/24"; + pools = [ + { + pool = "192.0.2.100 - 192.0.2.240"; + } + ]; + } + ]; }; description = '' Kea DHCP4 configuration as an attribute set, see . @@ -134,14 +147,14 @@ in description = '' DHCP6 Server configuration ''; - default = {}; + default = { }; type = submodule { options = { enable = lib.mkEnableOption "Kea DHCP6 server"; extraArgs = lib.mkOption { type = listOf str; - default = []; + default = [ ]; description = '' List of additional arguments to pass to the daemon. ''; @@ -176,13 +189,17 @@ in persist = true; name = "/var/lib/kea/dhcp6.leases"; }; - subnet6 = [ { - id = 1; - subnet = "2001:db8:1::/64"; - pools = [ { - pool = "2001:db8:1::1-2001:db8:1::ffff"; - } ]; - } ]; + subnet6 = [ + { + id = 1; + subnet = "2001:db8:1::/64"; + pools = [ + { + pool = "2001:db8:1::1-2001:db8:1::ffff"; + } + ]; + } + ]; }; description = '' Kea DHCP6 configuration as an attribute set, see . @@ -196,14 +213,14 @@ in description = '' Kea DHCP-DDNS configuration ''; - default = {}; + default = { }; type = submodule { options = { enable = lib.mkEnableOption "Kea DDNS server"; extraArgs = lib.mkOption { type = listOf str; - default = []; + default = [ ]; description = '' List of additional arguments to pass to the daemon. ''; @@ -246,211 +263,223 @@ in }; }; - config = let - commonServiceConfig = { - ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; - DynamicUser = true; - User = "kea"; - ConfigurationDirectory = "kea"; - RuntimeDirectory = "kea"; - RuntimeDirectoryPreserve = true; - StateDirectory = "kea"; - UMask = "0077"; - }; - in lib.mkIf (cfg.ctrl-agent.enable || cfg.dhcp4.enable || cfg.dhcp6.enable || cfg.dhcp-ddns.enable) (lib.mkMerge [ - { - environment.systemPackages = [ package ]; - } - - (lib.mkIf cfg.ctrl-agent.enable { - assertions = [{ - assertion = lib.xor (cfg.ctrl-agent.settings == null) (cfg.ctrl-agent.configFile == null); - message = "Either services.kea.ctrl-agent.settings or services.kea.ctrl-agent.configFile must be set to a non-null value."; - }]; - - environment.etc."kea/ctrl-agent.conf".source = ctrlAgentConfig; - - systemd.services.kea-ctrl-agent = { - description = "Kea Control Agent"; - documentation = [ - "man:kea-ctrl-agent(8)" - "https://kea.readthedocs.io/en/kea-${package.version}/arm/agent.html" - ]; - - wants = [ - "network-online.target" - ]; - after = [ - "network-online.target" - "time-sync.target" - ]; - wantedBy = [ - "kea-dhcp4-server.service" - "kea-dhcp6-server.service" - "kea-dhcp-ddns-server.service" - ]; - - environment = { - KEA_PIDFILE_DIR = "/run/kea"; - KEA_LOCKFILE_DIR = "/run/kea"; + config = + let + commonServiceConfig = { + ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; + DynamicUser = true; + User = "kea"; + ConfigurationDirectory = "kea"; + RuntimeDirectory = "kea"; + RuntimeDirectoryPreserve = true; + StateDirectory = "kea"; + UMask = "0077"; }; + in + lib.mkIf (cfg.ctrl-agent.enable || cfg.dhcp4.enable || cfg.dhcp6.enable || cfg.dhcp-ddns.enable) ( + lib.mkMerge [ + { + environment.systemPackages = [ package ]; + } + + (lib.mkIf cfg.ctrl-agent.enable { + assertions = [ + { + assertion = lib.xor (cfg.ctrl-agent.settings == null) (cfg.ctrl-agent.configFile == null); + message = "Either services.kea.ctrl-agent.settings or services.kea.ctrl-agent.configFile must be set to a non-null value."; + } + ]; + + environment.etc."kea/ctrl-agent.conf".source = ctrlAgentConfig; + + systemd.services.kea-ctrl-agent = { + description = "Kea Control Agent"; + documentation = [ + "man:kea-ctrl-agent(8)" + "https://kea.readthedocs.io/en/kea-${package.version}/arm/agent.html" + ]; + + wants = [ + "network-online.target" + ]; + after = [ + "network-online.target" + "time-sync.target" + ]; + wantedBy = [ + "kea-dhcp4-server.service" + "kea-dhcp6-server.service" + "kea-dhcp-ddns-server.service" + ]; + + environment = { + KEA_PIDFILE_DIR = "/run/kea"; + KEA_LOCKFILE_DIR = "/run/kea"; + }; - restartTriggers = [ - ctrlAgentConfig - ]; + restartTriggers = [ + ctrlAgentConfig + ]; - serviceConfig = { - ExecStart = "${package}/bin/kea-ctrl-agent -c /etc/kea/ctrl-agent.conf ${lib.escapeShellArgs cfg.ctrl-agent.extraArgs}"; - KillMode = "process"; - Restart = "on-failure"; - } // commonServiceConfig; - }; - }) - - (lib.mkIf cfg.dhcp4.enable { - assertions = [{ - assertion = lib.xor (cfg.dhcp4.settings == null) (cfg.dhcp4.configFile == null); - message = "Either services.kea.dhcp4.settings or services.kea.dhcp4.configFile must be set to a non-null value."; - }]; - - environment.etc."kea/dhcp4-server.conf".source = dhcp4Config; - - systemd.services.kea-dhcp4-server = { - description = "Kea DHCP4 Server"; - documentation = [ - "man:kea-dhcp4(8)" - "https://kea.readthedocs.io/en/kea-${package.version}/arm/dhcp4-srv.html" - ]; - - after = [ - "network-online.target" - "time-sync.target" - ]; - wants = [ - "network-online.target" - ]; - wantedBy = [ - "multi-user.target" - ]; - - environment = { - KEA_PIDFILE_DIR = "/run/kea"; - KEA_LOCKFILE_DIR = "/run/kea"; - }; + serviceConfig = { + ExecStart = "${package}/bin/kea-ctrl-agent -c /etc/kea/ctrl-agent.conf ${lib.escapeShellArgs cfg.ctrl-agent.extraArgs}"; + KillMode = "process"; + Restart = "on-failure"; + } // commonServiceConfig; + }; + }) + + (lib.mkIf cfg.dhcp4.enable { + assertions = [ + { + assertion = lib.xor (cfg.dhcp4.settings == null) (cfg.dhcp4.configFile == null); + message = "Either services.kea.dhcp4.settings or services.kea.dhcp4.configFile must be set to a non-null value."; + } + ]; + + environment.etc."kea/dhcp4-server.conf".source = dhcp4Config; + + systemd.services.kea-dhcp4-server = { + description = "Kea DHCP4 Server"; + documentation = [ + "man:kea-dhcp4(8)" + "https://kea.readthedocs.io/en/kea-${package.version}/arm/dhcp4-srv.html" + ]; + + after = [ + "network-online.target" + "time-sync.target" + ]; + wants = [ + "network-online.target" + ]; + wantedBy = [ + "multi-user.target" + ]; + + environment = { + KEA_PIDFILE_DIR = "/run/kea"; + KEA_LOCKFILE_DIR = "/run/kea"; + }; - restartTriggers = [ - dhcp4Config - ]; - - serviceConfig = { - ExecStart = "${package}/bin/kea-dhcp4 -c /etc/kea/dhcp4-server.conf ${lib.escapeShellArgs cfg.dhcp4.extraArgs}"; - # Kea does not request capabilities by itself - AmbientCapabilities = [ - "CAP_NET_BIND_SERVICE" - "CAP_NET_RAW" - ]; - CapabilityBoundingSet = [ - "CAP_NET_BIND_SERVICE" - "CAP_NET_RAW" - ]; - } // commonServiceConfig; - }; - }) - - (lib.mkIf cfg.dhcp6.enable { - assertions = [{ - assertion = lib.xor (cfg.dhcp6.settings == null) (cfg.dhcp6.configFile == null); - message = "Either services.kea.dhcp6.settings or services.kea.dhcp6.configFile must be set to a non-null value."; - }]; - - environment.etc."kea/dhcp6-server.conf".source = dhcp6Config; - - systemd.services.kea-dhcp6-server = { - description = "Kea DHCP6 Server"; - documentation = [ - "man:kea-dhcp6(8)" - "https://kea.readthedocs.io/en/kea-${package.version}/arm/dhcp6-srv.html" - ]; - - after = [ - "network-online.target" - "time-sync.target" - ]; - wants = [ - "network-online.target" - ]; - wantedBy = [ - "multi-user.target" - ]; - - environment = { - KEA_PIDFILE_DIR = "/run/kea"; - KEA_LOCKFILE_DIR = "/run/kea"; - }; + restartTriggers = [ + dhcp4Config + ]; + + serviceConfig = { + ExecStart = "${package}/bin/kea-dhcp4 -c /etc/kea/dhcp4-server.conf ${lib.escapeShellArgs cfg.dhcp4.extraArgs}"; + # Kea does not request capabilities by itself + AmbientCapabilities = [ + "CAP_NET_BIND_SERVICE" + "CAP_NET_RAW" + ]; + CapabilityBoundingSet = [ + "CAP_NET_BIND_SERVICE" + "CAP_NET_RAW" + ]; + } // commonServiceConfig; + }; + }) + + (lib.mkIf cfg.dhcp6.enable { + assertions = [ + { + assertion = lib.xor (cfg.dhcp6.settings == null) (cfg.dhcp6.configFile == null); + message = "Either services.kea.dhcp6.settings or services.kea.dhcp6.configFile must be set to a non-null value."; + } + ]; + + environment.etc."kea/dhcp6-server.conf".source = dhcp6Config; + + systemd.services.kea-dhcp6-server = { + description = "Kea DHCP6 Server"; + documentation = [ + "man:kea-dhcp6(8)" + "https://kea.readthedocs.io/en/kea-${package.version}/arm/dhcp6-srv.html" + ]; + + after = [ + "network-online.target" + "time-sync.target" + ]; + wants = [ + "network-online.target" + ]; + wantedBy = [ + "multi-user.target" + ]; + + environment = { + KEA_PIDFILE_DIR = "/run/kea"; + KEA_LOCKFILE_DIR = "/run/kea"; + }; - restartTriggers = [ - dhcp6Config - ]; - - serviceConfig = { - ExecStart = "${package}/bin/kea-dhcp6 -c /etc/kea/dhcp6-server.conf ${lib.escapeShellArgs cfg.dhcp6.extraArgs}"; - # Kea does not request capabilities by itself - AmbientCapabilities = [ - "CAP_NET_BIND_SERVICE" - ]; - CapabilityBoundingSet = [ - "CAP_NET_BIND_SERVICE" - ]; - } // commonServiceConfig; - }; - }) - - (lib.mkIf cfg.dhcp-ddns.enable { - assertions = [{ - assertion = lib.xor (cfg.dhcp-ddns.settings == null) (cfg.dhcp-ddns.configFile == null); - message = "Either services.kea.dhcp-ddns.settings or services.kea.dhcp-ddns.configFile must be set to a non-null value."; - }]; - - environment.etc."kea/dhcp-ddns.conf".source = dhcpDdnsConfig; - - systemd.services.kea-dhcp-ddns-server = { - description = "Kea DHCP-DDNS Server"; - documentation = [ - "man:kea-dhcp-ddns(8)" - "https://kea.readthedocs.io/en/kea-${package.version}/arm/ddns.html" - ]; - - wants = [ "network-online.target" ]; - after = [ - "network-online.target" - "time-sync.target" - ]; - wantedBy = [ - "multi-user.target" - ]; - - environment = { - KEA_PIDFILE_DIR = "/run/kea"; - KEA_LOCKFILE_DIR = "/run/kea"; - }; + restartTriggers = [ + dhcp6Config + ]; + + serviceConfig = { + ExecStart = "${package}/bin/kea-dhcp6 -c /etc/kea/dhcp6-server.conf ${lib.escapeShellArgs cfg.dhcp6.extraArgs}"; + # Kea does not request capabilities by itself + AmbientCapabilities = [ + "CAP_NET_BIND_SERVICE" + ]; + CapabilityBoundingSet = [ + "CAP_NET_BIND_SERVICE" + ]; + } // commonServiceConfig; + }; + }) + + (lib.mkIf cfg.dhcp-ddns.enable { + assertions = [ + { + assertion = lib.xor (cfg.dhcp-ddns.settings == null) (cfg.dhcp-ddns.configFile == null); + message = "Either services.kea.dhcp-ddns.settings or services.kea.dhcp-ddns.configFile must be set to a non-null value."; + } + ]; + + environment.etc."kea/dhcp-ddns.conf".source = dhcpDdnsConfig; + + systemd.services.kea-dhcp-ddns-server = { + description = "Kea DHCP-DDNS Server"; + documentation = [ + "man:kea-dhcp-ddns(8)" + "https://kea.readthedocs.io/en/kea-${package.version}/arm/ddns.html" + ]; + + wants = [ "network-online.target" ]; + after = [ + "network-online.target" + "time-sync.target" + ]; + wantedBy = [ + "multi-user.target" + ]; + + environment = { + KEA_PIDFILE_DIR = "/run/kea"; + KEA_LOCKFILE_DIR = "/run/kea"; + }; - restartTriggers = [ - dhcpDdnsConfig - ]; - - serviceConfig = { - ExecStart = "${package}/bin/kea-dhcp-ddns -c /etc/kea/dhcp-ddns.conf ${lib.escapeShellArgs cfg.dhcp-ddns.extraArgs}"; - AmbientCapabilities = [ - "CAP_NET_BIND_SERVICE" - ]; - CapabilityBoundingSet = [ - "CAP_NET_BIND_SERVICE" - ]; - } // commonServiceConfig; - }; - }) + restartTriggers = [ + dhcpDdnsConfig + ]; + + serviceConfig = { + ExecStart = "${package}/bin/kea-dhcp-ddns -c /etc/kea/dhcp-ddns.conf ${lib.escapeShellArgs cfg.dhcp-ddns.extraArgs}"; + AmbientCapabilities = [ + "CAP_NET_BIND_SERVICE" + ]; + CapabilityBoundingSet = [ + "CAP_NET_BIND_SERVICE" + ]; + } // commonServiceConfig; + }; + }) - ]); + ] + ); meta.maintainers = with lib.maintainers; [ hexa ]; # uses attributes of the linked package diff --git a/nixos/modules/services/networking/keepalived/virtual-ip-options.nix b/nixos/modules/services/networking/keepalived/virtual-ip-options.nix index 1b8889b1b47247..36863d93736ddc 100644 --- a/nixos/modules/services/networking/keepalived/virtual-ip-options.nix +++ b/nixos/modules/services/networking/keepalived/virtual-ip-options.nix @@ -1,4 +1,4 @@ -{ lib } : +{ lib }: with lib; { diff --git a/nixos/modules/services/networking/keepalived/vrrp-instance-options.nix b/nixos/modules/services/networking/keepalived/vrrp-instance-options.nix index da681e74ff3c13..8f1799efcb552a 100644 --- a/nixos/modules/services/networking/keepalived/vrrp-instance-options.nix +++ b/nixos/modules/services/networking/keepalived/vrrp-instance-options.nix @@ -1,4 +1,4 @@ -{ lib } : +{ lib }: with lib; { @@ -12,7 +12,10 @@ with lib; }; state = mkOption { - type = types.enum [ "MASTER" "BACKUP" ]; + type = types.enum [ + "MASTER" + "BACKUP" + ]; default = "BACKUP"; description = '' Initial state. As soon as the other machine(s) come up, an election will @@ -62,8 +65,8 @@ with lib; type = types.nullOr types.str; default = null; description = '' - Name of the vmac interface to use. keepalived will come up with a name - if you don't specify one. + Name of the vmac interface to use. keepalived will come up with a name + if you don't specify one. ''; }; @@ -79,15 +82,15 @@ with lib; type = types.nullOr types.str; default = null; description = '' - Default IP for binding vrrpd is the primary IP on interface. If you - want to hide location of vrrpd, use this IP as src_addr for unicast - vrrp packets. + Default IP for binding vrrpd is the primary IP on interface. If you + want to hide location of vrrpd, use this IP as src_addr for unicast + vrrp packets. ''; }; unicastPeers = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = '' Do not send VRRP adverts over VRRP multicast group. Instead it sends adverts to the following list of ip addresses using unicast design @@ -98,25 +101,35 @@ with lib; }; virtualIps = mkOption { - type = types.listOf (types.submodule (import ./virtual-ip-options.nix { - inherit lib; - })); - default = []; + type = types.listOf ( + types.submodule ( + import ./virtual-ip-options.nix { + inherit lib; + } + ) + ); + default = [ ]; # TODO: example description = "Declarative vhost config"; }; trackScripts = mkOption { type = types.listOf types.str; - default = []; - example = [ "chk_cmd1" "chk_cmd2" ]; + default = [ ]; + example = [ + "chk_cmd1" + "chk_cmd2" + ]; description = "List of script names to invoke for health tracking."; }; trackInterfaces = mkOption { type = types.listOf types.str; - default = []; - example = [ "eth0" "eth1" ]; + default = [ ]; + example = [ + "eth0" + "eth1" + ]; description = "List of network interfaces to monitor for health tracking."; }; diff --git a/nixos/modules/services/networking/keepalived/vrrp-script-options.nix b/nixos/modules/services/networking/keepalived/vrrp-script-options.nix index df7a89cff8cdd4..22e01b6509b2e7 100644 --- a/nixos/modules/services/networking/keepalived/vrrp-script-options.nix +++ b/nixos/modules/services/networking/keepalived/vrrp-script-options.nix @@ -1,4 +1,4 @@ -{ lib } : +{ lib }: with lib; with lib.types; diff --git a/nixos/modules/services/networking/keybase.nix b/nixos/modules/services/networking/keybase.nix index 9bb7ad3844a068..86868ef7c219f4 100644 --- a/nixos/modules/services/networking/keybase.nix +++ b/nixos/modules/services/networking/keybase.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.keybase; -in { +in +{ ###### interface diff --git a/nixos/modules/services/networking/knot.nix b/nixos/modules/services/networking/knot.nix index a992fd99694efd..12a72bfe02c790 100644 --- a/nixos/modules/services/networking/knot.nix +++ b/nixos/modules/services/networking/knot.nix @@ -1,5 +1,10 @@ -{ config, lib, pkgs, utils, ... }: - +{ + config, + lib, + pkgs, + utils, + ... +}: let inherit (lib) @@ -25,126 +30,177 @@ let mkPackageOption optionals types - ; + ; inherit (utils) escapeSystemdExecArgs - ; + ; cfg = config.services.knot; - yamlConfig = let - result = assert secsCheck; nix2yaml cfg.settings; - - secAllow = n: hasPrefix "mod-" n || elem n [ - "module" - "server" "xdp" "control" - "log" - "statistics" "database" - "keystore" "key" "remote" "remotes" "acl" "submission" "policy" - "template" - "zone" - "include" - ]; - secsCheck = let - secsBad = filter (n: !secAllow n) (attrNames cfg.settings); - in if secsBad == [] then true else throw - ("services.knot.settings contains unknown sections: " + toString secsBad); - - nix2yaml = nix_def: concatStrings ( - # We output the config section in the upstream-mandated order. - # Ordering is important due to forward-references not being allowed. - # See definition of conf_export and 'const yp_item_t conf_schema' - # upstream for reference. Last updated for 3.3. - # When changing the set of sections, also update secAllow above. - [ (sec_list_fa "id" nix_def "module") ] - ++ map (sec_plain nix_def) - [ "server" "xdp" "control" ] - ++ [ (sec_list_fa "target" nix_def "log") ] - ++ map (sec_plain nix_def) - [ "statistics" "database" ] - ++ map (sec_list_fa "id" nix_def) - [ "keystore" "key" "remote" "remotes" "acl" "submission" "policy" ] - - # Export module sections before the template section. - ++ map (sec_list_fa "id" nix_def) (filter (hasPrefix "mod-") (attrNames nix_def)) - - ++ [ (sec_list_fa "id" nix_def "template") ] - ++ [ (sec_list_fa "domain" nix_def "zone") ] - ++ [ (sec_plain nix_def "include") ] - ++ [ (sec_plain nix_def "clear") ] - ); - - # A plain section contains directly attributes (we don't really check that ATM). - sec_plain = nix_def: sec_name: if !hasAttr sec_name nix_def then "" else - n2y "" { ${sec_name} = nix_def.${sec_name}; }; - - # This section contains a list of attribute sets. In each of the sets - # there's an attribute (`fa_name`, typically "id") that must exist and come first. - # Alternatively we support using attribute sets instead of lists; example diff: - # -template = [ { id = "default"; /* other attributes */ } { id = "foo"; } ] - # +template = { default = { /* those attributes */ }; foo = { }; } - sec_list_fa = fa_name: nix_def: sec_name: if !hasAttr sec_name nix_def then "" else - let - elem2yaml = fa_val: other_attrs: - " - " + n2y "" { ${fa_name} = fa_val; } - + " " + n2y " " other_attrs - + "\n"; - sec = nix_def.${sec_name}; - in - sec_name + ":\n" + - (if isList sec - then flip concatMapStrings sec - (elem: elem2yaml elem.${fa_name} (removeAttrs elem [ fa_name ])) - else concatStrings (mapAttrsToList elem2yaml sec) + yamlConfig = + let + result = + assert secsCheck; + nix2yaml cfg.settings; + + secAllow = + n: + hasPrefix "mod-" n + || elem n [ + "module" + "server" + "xdp" + "control" + "log" + "statistics" + "database" + "keystore" + "key" + "remote" + "remotes" + "acl" + "submission" + "policy" + "template" + "zone" + "include" + ]; + secsCheck = + let + secsBad = filter (n: !secAllow n) (attrNames cfg.settings); + in + if secsBad == [ ] then + true + else + throw ("services.knot.settings contains unknown sections: " + toString secsBad); + + nix2yaml = + nix_def: + concatStrings ( + # We output the config section in the upstream-mandated order. + # Ordering is important due to forward-references not being allowed. + # See definition of conf_export and 'const yp_item_t conf_schema' + # upstream for reference. Last updated for 3.3. + # When changing the set of sections, also update secAllow above. + [ (sec_list_fa "id" nix_def "module") ] + ++ map (sec_plain nix_def) [ + "server" + "xdp" + "control" + ] + ++ [ (sec_list_fa "target" nix_def "log") ] + ++ map (sec_plain nix_def) [ + "statistics" + "database" + ] + ++ map (sec_list_fa "id" nix_def) [ + "keystore" + "key" + "remote" + "remotes" + "acl" + "submission" + "policy" + ] + + # Export module sections before the template section. + ++ map (sec_list_fa "id" nix_def) (filter (hasPrefix "mod-") (attrNames nix_def)) + + ++ [ (sec_list_fa "id" nix_def "template") ] + ++ [ (sec_list_fa "domain" nix_def "zone") ] + ++ [ (sec_plain nix_def "include") ] + ++ [ (sec_plain nix_def "clear") ] + ); + + # A plain section contains directly attributes (we don't really check that ATM). + sec_plain = + nix_def: sec_name: + if !hasAttr sec_name nix_def then "" else n2y "" { ${sec_name} = nix_def.${sec_name}; }; + + # This section contains a list of attribute sets. In each of the sets + # there's an attribute (`fa_name`, typically "id") that must exist and come first. + # Alternatively we support using attribute sets instead of lists; example diff: + # -template = [ { id = "default"; /* other attributes */ } { id = "foo"; } ] + # +template = { default = { /* those attributes */ }; foo = { }; } + sec_list_fa = + fa_name: nix_def: sec_name: + if !hasAttr sec_name nix_def then + "" + else + let + elem2yaml = + fa_val: other_attrs: + " - " + n2y "" { ${fa_name} = fa_val; } + " " + n2y " " other_attrs + "\n"; + sec = nix_def.${sec_name}; + in + sec_name + + ":\n" + + ( + if isList sec then + flip concatMapStrings sec (elem: elem2yaml elem.${fa_name} (removeAttrs elem [ fa_name ])) + else + concatStrings (mapAttrsToList elem2yaml sec) ); - # This convertor doesn't care about ordering of attributes. - # TODO: it could probably be simplified even more, now that it's not - # to be used directly, but we might want some other tweaks, too. - n2y = indent: val: - if doRecurse val then concatStringsSep "\n${indent}" - (mapAttrsToList - # This is a bit wacky - set directly under a set would start on bad indent, - # so we start those on a new line, but not other types of attribute values. - (aname: aval: "${aname}:${if doRecurse aval then "\n${indent} " else " "}" - + n2y (indent + " ") aval) - val - ) - + "\n" + # This convertor doesn't care about ordering of attributes. + # TODO: it could probably be simplified even more, now that it's not + # to be used directly, but we might want some other tweaks, too. + n2y = + indent: val: + if doRecurse val then + concatStringsSep "\n${indent}" ( + mapAttrsToList + # This is a bit wacky - set directly under a set would start on bad indent, + # so we start those on a new line, but not other types of attribute values. + ( + aname: aval: + "${aname}:${if doRecurse aval then "\n${indent} " else " "}" + n2y (indent + " ") aval + ) + val + ) + + "\n" else - /* - if isList val && stringLength indent < 4 then concatMapStrings - (elem: "\n${indent}- " + n2y (indent + " ") elem) - val + /* + if isList val && stringLength indent < 4 then concatMapStrings + (elem: "\n${indent}- " + n2y (indent + " ") elem) + val + else + */ + if + isList val # and long indent + then + "[ " + concatMapStringsSep ", " quoteString val + " ]" + else if isBool val then + (if val then "on" else "off") else - */ - if isList val /* and long indent */ then - "[ " + concatMapStringsSep ", " quoteString val + " ]" else - if isBool val then (if val then "on" else "off") else - quoteString val; - - # We don't want paths like ./my-zone.txt be converted to plain strings. - quoteString = s: ''"${if builtins.typeOf s == "path" then s else toString s}"''; - # We don't want to walk the insides of derivation attributes. - doRecurse = val: isAttrs val && !isDerivation val; - - in result; - - configFile = if cfg.settingsFile != null then - # Note: with extraConfig, the 23.05 compat code did include keyFiles from settingsFile. - assert cfg.settings == {} && (cfg.keyFiles == [] || cfg.extraConfig != null); - cfg.settingsFile - else - mkConfigFile yamlConfig; - - mkConfigFile = configString: pkgs.writeTextFile { - name = "knot.conf"; - text = (concatMapStringsSep "\n" (file: "include: ${file}") cfg.keyFiles) + "\n" + configString; - checkPhase = lib.optionalString cfg.checkConfig '' - ${cfg.package}/bin/knotc --config=$out conf-check - ''; - }; + quoteString val; + + # We don't want paths like ./my-zone.txt be converted to plain strings. + quoteString = s: ''"${if builtins.typeOf s == "path" then s else toString s}"''; + # We don't want to walk the insides of derivation attributes. + doRecurse = val: isAttrs val && !isDerivation val; + + in + result; + + configFile = + if cfg.settingsFile != null then + # Note: with extraConfig, the 23.05 compat code did include keyFiles from settingsFile. + assert cfg.settings == { } && (cfg.keyFiles == [ ] || cfg.extraConfig != null); + cfg.settingsFile + else + mkConfigFile yamlConfig; + + mkConfigFile = + configString: + pkgs.writeTextFile { + name = "knot.conf"; + text = (concatMapStringsSep "\n" (file: "include: ${file}") cfg.keyFiles) + "\n" + configString; + checkPhase = lib.optionalString cfg.checkConfig '' + ${cfg.package}/bin/knotc --config=$out conf-check + ''; + }; socketFile = "/run/knot/knot.sock"; @@ -170,7 +226,8 @@ let ln -s '${cfg.package}/share/man' "$out/share/" ''; }; -in { +in +{ options = { services.knot = { enable = mkEnableOption "Knot authoritative-only DNS server"; @@ -197,7 +254,7 @@ in { type = types.bool; # TODO: maybe we could do some checks even when private keys complicate this? # conf-check fails hard on missing IPs/devices with XDP - default = cfg.keyFiles == [] && !cfg.enableXDP; + default = cfg.keyFiles == [ ] && !cfg.enableXDP; defaultText = '' Disabled when the config uses `keyFiles` or `enableXDP`. ''; @@ -210,7 +267,7 @@ in { extraArgs = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = '' List of additional command line parameters for knotd ''; @@ -218,7 +275,7 @@ in { keyFiles = mkOption { type = types.listOf types.path; - default = []; + default = [ ]; description = '' A list of files containing additional configuration to be included using the include directive. This option @@ -230,8 +287,8 @@ in { }; settings = mkOption { - type = (pkgs.formats.yaml {}).type; - default = {}; + type = (pkgs.formats.yaml { }).type; + default = { }; description = '' Extra configuration as nix values. ''; @@ -252,13 +309,13 @@ in { }; imports = [ # Compatibility with NixOS 23.05. - (mkChangedOptionModule [ "services" "knot" "extraConfig" ] [ "services" "knot" "settingsFile" ] - (config: mkConfigFile config.services.knot.extraConfig) - ) + (mkChangedOptionModule [ "services" "knot" "extraConfig" ] [ "services" "knot" "settingsFile" ] ( + config: mkConfigFile config.services.knot.extraConfig + )) ]; config = mkIf config.services.knot.enable { - users.groups.knot = {}; + users.groups.knot = { }; users.users.knot = { isSystemUser = true; group = "knot"; @@ -272,81 +329,93 @@ in { description = cfg.package.meta.description; wantedBy = [ "multi-user.target" ]; wants = [ "network.target" ]; - after = ["network.target" ]; - - serviceConfig = let - # https://www.knot-dns.cz/docs/3.3/singlehtml/index.html#pre-requisites - xdpCapabilities = lib.optionals (cfg.enableXDP) [ - "CAP_NET_ADMIN" - "CAP_NET_RAW" - "CAP_SYS_ADMIN" - "CAP_IPC_LOCK" - ] ++ lib.optionals (lib.versionOlder config.boot.kernelPackages.kernel.version "5.11") [ - "CAP_SYS_RESOURCE" - ]; - in { - Type = "notify"; - ExecStart = escapeSystemdExecArgs ([ - (lib.getExe cfg.package) - "--config=${configFile}" - "--socket=${socketFile}" - ] ++ cfg.extraArgs); - ExecReload = escapeSystemdExecArgs [ - "${knot-cli-wrappers}/bin/knotc" "reload" - ]; - User = "knot"; - Group = "knot"; - - AmbientCapabilities = [ - "CAP_NET_BIND_SERVICE" - ] ++ xdpCapabilities; - CapabilityBoundingSet = [ - "CAP_NET_BIND_SERVICE" - ] ++ xdpCapabilities; - DeviceAllow = ""; - DevicePolicy = "closed"; - LockPersonality = true; - MemoryDenyWriteExecute = true; - NoNewPrivileges = true; - PrivateDevices = true; - PrivateTmp = true; - PrivateUsers = false; # breaks capability passing - ProcSubset = "pid"; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - ProtectSystem = "strict"; - RemoveIPC = true; - Restart = "on-abort"; - RestrictAddressFamilies = [ - "AF_INET" - "AF_INET6" - "AF_UNIX" - ] ++ optionals (cfg.enableXDP) [ - "AF_NETLINK" - "AF_XDP" - ]; - RestrictNamespaces = true; - RestrictRealtime =true; - RestrictSUIDSGID = true; - RuntimeDirectory = "knot"; - StateDirectory = "knot"; - StateDirectoryMode = "0700"; - SystemCallArchitectures = "native"; - SystemCallFilter = [ - "@system-service" - "~@privileged" - "@chown" - ] ++ optionals (cfg.enableXDP) [ - "bpf" - ]; - UMask = "0077"; - }; + after = [ "network.target" ]; + + serviceConfig = + let + # https://www.knot-dns.cz/docs/3.3/singlehtml/index.html#pre-requisites + xdpCapabilities = + lib.optionals (cfg.enableXDP) [ + "CAP_NET_ADMIN" + "CAP_NET_RAW" + "CAP_SYS_ADMIN" + "CAP_IPC_LOCK" + ] + ++ lib.optionals (lib.versionOlder config.boot.kernelPackages.kernel.version "5.11") [ + "CAP_SYS_RESOURCE" + ]; + in + { + Type = "notify"; + ExecStart = escapeSystemdExecArgs ( + [ + (lib.getExe cfg.package) + "--config=${configFile}" + "--socket=${socketFile}" + ] + ++ cfg.extraArgs + ); + ExecReload = escapeSystemdExecArgs [ + "${knot-cli-wrappers}/bin/knotc" + "reload" + ]; + User = "knot"; + Group = "knot"; + + AmbientCapabilities = [ + "CAP_NET_BIND_SERVICE" + ] ++ xdpCapabilities; + CapabilityBoundingSet = [ + "CAP_NET_BIND_SERVICE" + ] ++ xdpCapabilities; + DeviceAllow = ""; + DevicePolicy = "closed"; + LockPersonality = true; + MemoryDenyWriteExecute = true; + NoNewPrivileges = true; + PrivateDevices = true; + PrivateTmp = true; + PrivateUsers = false; # breaks capability passing + ProcSubset = "pid"; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + ProtectSystem = "strict"; + RemoveIPC = true; + Restart = "on-abort"; + RestrictAddressFamilies = + [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ] + ++ optionals (cfg.enableXDP) [ + "AF_NETLINK" + "AF_XDP" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + RuntimeDirectory = "knot"; + StateDirectory = "knot"; + StateDirectoryMode = "0700"; + SystemCallArchitectures = "native"; + SystemCallFilter = + [ + "@system-service" + "~@privileged" + "@chown" + ] + ++ optionals (cfg.enableXDP) [ + "bpf" + ]; + UMask = "0077"; + }; }; environment.systemPackages = [ knot-cli-wrappers ]; diff --git a/nixos/modules/services/networking/kresd.nix b/nixos/modules/services/networking/kresd.nix index 4c1d6c50d8305b..c93b591701a73b 100644 --- a/nixos/modules/services/networking/kresd.nix +++ b/nixos/modules/services/networking/kresd.nix @@ -1,24 +1,37 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.kresd; # Convert systemd-style address specification to kresd config line(s). # On Nix level we don't attempt to precisely validate the address specifications. # The optional IPv6 scope spec comes *after* port, perhaps surprisingly. - mkListen = kind: addr: let - al_v4 = builtins.match "([0-9.]+):([0-9]+)($)" addr; - al_v6 = builtins.match "\\[(.+)]:([0-9]+)(%.*|$)" addr; - al_portOnly = builtins.match "(^)([0-9]+)" addr; - al = lib.findFirst (a: a != null) - (throw "services.kresd.*: incorrect address specification '${addr}'") - [ al_v4 al_v6 al_portOnly ]; - port = lib.elemAt al 1; - addrSpec = if al_portOnly == null then "'${lib.head al}${lib.elemAt al 2}'" else "{'::', '0.0.0.0'}"; - in # freebind is set for compatibility with earlier kresd services; - # it could be configurable, for example. - '' - net.listen(${addrSpec}, ${port}, { kind = '${kind}', freebind = true }) - ''; + mkListen = + kind: addr: + let + al_v4 = builtins.match "([0-9.]+):([0-9]+)($)" addr; + al_v6 = builtins.match "\\[(.+)]:([0-9]+)(%.*|$)" addr; + al_portOnly = builtins.match "(^)([0-9]+)" addr; + al = + lib.findFirst (a: a != null) (throw "services.kresd.*: incorrect address specification '${addr}'") + [ + al_v4 + al_v6 + al_portOnly + ]; + port = lib.elemAt al 1; + addrSpec = + if al_portOnly == null then "'${lib.head al}${lib.elemAt al 2}'" else "{'::', '0.0.0.0'}"; + in + # freebind is set for compatibility with earlier kresd services; + # it could be configurable, for example. + '' + net.listen(${addrSpec}, ${port}, { kind = '${kind}', freebind = true }) + ''; configFile = pkgs.writeText "kresd.conf" ( "" @@ -27,15 +40,20 @@ let + lib.concatMapStrings (mkListen "doh2") cfg.listenDoH + cfg.extraConfig ); -in { - meta.maintainers = [ lib.maintainers.vcunat /* upstream developer */ ]; +in +{ + meta.maintainers = [ + lib.maintainers.vcunat # upstream developer + ]; imports = [ (lib.mkChangedOptionModule [ "services" "kresd" "interfaces" ] [ "services" "kresd" "listenPlain" ] - (config: - let value = lib.getAttrFromPath [ "services" "kresd" "interfaces" ] config; - in map - (iface: if lib.elem ":" (lib.stringToCharacters iface) then "[${iface}]:53" else "${iface}:53") # Syntax depends on being IPv6 or IPv4. + ( + config: + let + value = lib.getAttrFromPath [ "services" "kresd" "interfaces" ] config; + in + map (iface: if lib.elem ":" (lib.stringToCharacters iface) then "[${iface}]:53" else "${iface}:53") # Syntax depends on being IPv6 or IPv4. value ) ) @@ -67,7 +85,10 @@ in { }; listenPlain = lib.mkOption { type = with lib.types; listOf str; - default = [ "[::1]:53" "127.0.0.1:53" ]; + default = [ + "[::1]:53" + "127.0.0.1:53" + ]; example = [ "53" ]; description = '' What addresses and ports the server should listen on. @@ -76,8 +97,12 @@ in { }; listenTLS = lib.mkOption { type = with lib.types; listOf str; - default = []; - example = [ "198.51.100.1:853" "[2001:db8::1]:853" "853" ]; + default = [ ]; + example = [ + "198.51.100.1:853" + "[2001:db8::1]:853" + "853" + ]; description = '' Addresses and ports on which kresd should provide DNS over TLS (see RFC 7858). For detailed syntax see ListenStream in {manpage}`systemd.socket(5)`. @@ -85,8 +110,12 @@ in { }; listenDoH = lib.mkOption { type = with lib.types; listOf str; - default = []; - example = [ "198.51.100.1:443" "[2001:db8::1]:443" "443" ]; + default = [ ]; + example = [ + "198.51.100.1:443" + "[2001:db8::1]:443" + "443" + ]; description = '' Addresses and ports on which kresd should provide DNS over HTTPS/2 (see RFC 8484). For detailed syntax see ListenStream in {manpage}`systemd.socket(5)`. @@ -110,22 +139,25 @@ in { networking.resolvconf.useLocalResolver = lib.mkDefault true; - users.users.knot-resolver = - { isSystemUser = true; - group = "knot-resolver"; - description = "Knot-resolver daemon user"; - }; + users.users.knot-resolver = { + isSystemUser = true; + group = "knot-resolver"; + description = "Knot-resolver daemon user"; + }; users.groups.knot-resolver.gid = null; systemd.packages = [ cfg.package ]; # the units are patched inside the package a bit - systemd.targets.kresd = { # configure units started by default + systemd.targets.kresd = { + # configure units started by default wantedBy = [ "multi-user.target" ]; - wants = [ "kres-cache-gc.service" ] - ++ map (i: "kresd@${toString i}.service") (lib.range 1 cfg.instances); + wants = [ + "kres-cache-gc.service" + ] ++ map (i: "kresd@${toString i}.service") (lib.range 1 cfg.instances); }; systemd.services."kresd@".serviceConfig = { - ExecStart = "${cfg.package}/bin/kresd --noninteractive " + ExecStart = + "${cfg.package}/bin/kresd --noninteractive " + "-c ${cfg.package}/lib/knot-resolver/distro-preconfig.lua -c ${configFile}"; # Ensure /run/knot-resolver exists RuntimeDirectory = "knot-resolver"; diff --git a/nixos/modules/services/networking/lambdabot.nix b/nixos/modules/services/networking/lambdabot.nix index 8c8e5648450c41..c029fcc8580645 100644 --- a/nixos/modules/services/networking/lambdabot.nix +++ b/nixos/modules/services/networking/lambdabot.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.lambdabot; diff --git a/nixos/modules/services/networking/legit.nix b/nixos/modules/services/networking/legit.nix index 412f8275800b7d..2a4024a9fd286f 100644 --- a/nixos/modules/services/networking/legit.nix +++ b/nixos/modules/services/networking/legit.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) @@ -9,7 +14,8 @@ let mkPackageOption optionalAttrs optional - types; + types + ; cfg = config.services.legit; @@ -59,7 +65,10 @@ in }; mainBranch = mkOption { type = types.listOf types.str; - default = [ "main" "master" ]; + default = [ + "main" + "master" + ]; description = "Main branch to look for."; }; ignore = mkOption { @@ -142,10 +151,11 @@ in Restart = "always"; WorkingDirectory = cfg.settings.repo.scanPath; - StateDirectory = [ ] ++ - optional (cfg.settings.repo.scanPath == defaultStateDir) "legit" ++ - optional (cfg.settings.dirs.static == defaultStaticDir) "legit/static" ++ - optional (cfg.settings.dirs.templates == defaultTemplatesDir) "legit/templates"; + StateDirectory = + [ ] + ++ optional (cfg.settings.repo.scanPath == defaultStateDir) "legit" + ++ optional (cfg.settings.dirs.static == defaultStaticDir) "legit/static" + ++ optional (cfg.settings.dirs.templates == defaultTemplatesDir) "legit/templates"; # Hardening CapabilityBoundingSet = [ "" ]; @@ -168,12 +178,18 @@ in ProtectSystem = "strict"; ReadWritePaths = cfg.settings.repo.scanPath; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; UMask = "0077"; }; }; diff --git a/nixos/modules/services/networking/libreswan.nix b/nixos/modules/services/networking/libreswan.nix index 04f565a2bf8f08..916b6f8293d065 100644 --- a/nixos/modules/services/networking/libreswan.nix +++ b/nixos/modules/services/networking/libreswan.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.libreswan; @@ -6,33 +11,49 @@ let libexec = "${pkgs.libreswan}/libexec/ipsec"; ipsec = "${pkgs.libreswan}/sbin/ipsec"; - trim = chars: str: - let - nonchars = lib.filter (x : !(lib.elem x.value chars)) - (lib.imap0 (i: v: {ind = i; value = v;}) (lib.stringToCharacters str)); - in - lib.optionalString (nonchars != [ ]) - (lib.substring (lib.head nonchars).ind (lib.add 1 (lib.sub (lib.last nonchars).ind (lib.head nonchars).ind)) str); - indent = str: lib.concatStrings (lib.concatMap (s: [" " (trim [" " "\t"] s) "\n"]) (lib.splitString "\n" str)); + trim = + chars: str: + let + nonchars = lib.filter (x: !(lib.elem x.value chars)) ( + lib.imap0 (i: v: { + ind = i; + value = v; + }) (lib.stringToCharacters str) + ); + in + lib.optionalString (nonchars != [ ]) ( + lib.substring (lib.head nonchars).ind (lib.add 1 ( + lib.sub (lib.last nonchars).ind (lib.head nonchars).ind + )) str + ); + indent = + str: + lib.concatStrings ( + lib.concatMap (s: [ + " " + (trim [ " " "\t" ] s) + "\n" + ]) (lib.splitString "\n" str) + ); configText = indent (toString cfg.configSetup); - connectionText = lib.concatStrings (lib.mapAttrsToList (n: v: - '' + connectionText = lib.concatStrings ( + lib.mapAttrsToList (n: v: '' conn ${n} ${indent v} - '') cfg.connections); + '') cfg.connections + ); - configFile = pkgs.writeText "ipsec-nixos.conf" - '' - config setup - ${configText} + configFile = pkgs.writeText "ipsec-nixos.conf" '' + config setup + ${configText} - ${connectionText} - ''; + ${connectionText} + ''; - policyFiles = lib.mapAttrs' (name: text: - { name = "ipsec.d/policies/${name}"; - value.source = pkgs.writeText "ipsec-policy-${name}" text; - }) cfg.policies; + policyFiles = lib.mapAttrs' (name: text: { + name = "ipsec.d/policies/${name}"; + value.source = pkgs.writeText "ipsec-policy-${name}" text; + }) cfg.policies; in @@ -49,20 +70,20 @@ in configSetup = lib.mkOption { type = lib.types.lines; default = '' - protostack=netkey - virtual_private=%v4:10.0.0.0/8,%v4:192.168.0.0/16,%v4:172.16.0.0/12,%v4:25.0.0.0/8,%v4:100.64.0.0/10,%v6:fd00::/8,%v6:fe80::/10 + protostack=netkey + virtual_private=%v4:10.0.0.0/8,%v4:192.168.0.0/16,%v4:172.16.0.0/12,%v4:25.0.0.0/8,%v4:100.64.0.0/10,%v6:fd00::/8,%v6:fe80::/10 ''; example = '' - secretsfile=/root/ipsec.secrets - protostack=netkey - virtual_private=%v4:10.0.0.0/8,%v4:192.168.0.0/16,%v4:172.16.0.0/12,%v4:25.0.0.0/8,%v4:100.64.0.0/10,%v6:fd00::/8,%v6:fe80::/10 + secretsfile=/root/ipsec.secrets + protostack=netkey + virtual_private=%v4:10.0.0.0/8,%v4:192.168.0.0/16,%v4:172.16.0.0/12,%v4:25.0.0.0/8,%v4:100.64.0.0/10,%v6:fd00::/8,%v6:fe80::/10 ''; description = "Options to go in the 'config setup' section of the Libreswan IPsec configuration"; }; connections = lib.mkOption { type = lib.types.attrsOf lib.types.lines; - default = {}; + default = { }; example = lib.literalExpression '' { myconnection = ''' auto=add @@ -81,7 +102,7 @@ in policies = lib.mkOption { type = lib.types.attrsOf lib.types.lines; - default = {}; + default = { }; example = lib.literalExpression '' { private-or-clear = ''' # Attempt opportunistic IPsec for the entire Internet @@ -113,13 +134,15 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { # Install package, systemd units, etc. - environment.systemPackages = [ pkgs.libreswan pkgs.iproute2 ]; + environment.systemPackages = [ + pkgs.libreswan + pkgs.iproute2 + ]; systemd.packages = [ pkgs.libreswan ]; systemd.tmpfiles.packages = [ pkgs.libreswan ]; @@ -151,7 +174,7 @@ in ''; serviceConfig = { StateDirectory = "ipsec/nss"; - StateDirectoryMode = 0700; + StateDirectoryMode = 700; }; }; diff --git a/nixos/modules/services/networking/lldpd.nix b/nixos/modules/services/networking/lldpd.nix index 98a4cff265f14b..7c030728f4fe11 100644 --- a/nixos/modules/services/networking/lldpd.nix +++ b/nixos/modules/services/networking/lldpd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.lldpd; @@ -10,8 +15,12 @@ in extraArgs = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; - example = [ "-c" "-k" "-I eth0" ]; + default = [ ]; + example = [ + "-c" + "-k" + "-I eth0" + ]; description = "List of command line parameters for lldpd"; }; }; @@ -23,7 +32,7 @@ in home = "/run/lldpd"; isSystemUser = true; }; - users.groups._lldpd = {}; + users.groups._lldpd = { }; environment.systemPackages = [ pkgs.lldpd ]; systemd.packages = [ pkgs.lldpd ]; diff --git a/nixos/modules/services/networking/logmein-hamachi.nix b/nixos/modules/services/networking/logmein-hamachi.nix index 852101f09dffca..d0ce1b53267e44 100644 --- a/nixos/modules/services/networking/logmein-hamachi.nix +++ b/nixos/modules/services/networking/logmein-hamachi.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.logmein-hamachi; @@ -15,14 +20,13 @@ in type = lib.types.bool; default = false; description = '' - Whether to enable LogMeIn Hamachi, a proprietary - (closed source) commercial VPN software. - ''; + Whether to enable LogMeIn Hamachi, a proprietary + (closed source) commercial VPN software. + ''; }; }; - ###### implementation config = lib.mkIf cfg.enable { diff --git a/nixos/modules/services/networking/lokinet.nix b/nixos/modules/services/networking/lokinet.nix index 76203c61b504e4..5c06011822aeea 100644 --- a/nixos/modules/services/networking/lokinet.nix +++ b/nixos/modules/services/networking/lokinet.nix @@ -1,11 +1,20 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.lokinet; dataDir = "/var/lib/lokinet"; settingsFormat = pkgs.formats.ini { listsAsDuplicateKeys = true; }; - configFile = settingsFormat.generate "lokinet.ini" (lib.filterAttrsRecursive (n: v: v != null) cfg.settings); -in with lib; { + configFile = settingsFormat.generate "lokinet.ini" ( + lib.filterAttrsRecursive (n: v: v != null) cfg.settings + ); +in +with lib; +{ options.services.lokinet = { enable = mkEnableOption "Lokinet daemon"; @@ -19,7 +28,8 @@ in with lib; { }; settings = mkOption { - type = with types; + type = + with types; submodule { freeformType = settingsFormat.type; @@ -34,7 +44,10 @@ in with lib; { upstream = mkOption { type = listOf str; default = [ "9.9.9.10" ]; - example = [ "1.1.1.1" "8.8.8.8" ]; + example = [ + "1.1.1.1" + "8.8.8.8" + ]; description = '' Upstream resolver(s) to use as fallback for non-loki addresses. Multiple values accepted. @@ -105,8 +118,14 @@ in with lib; { systemd.services.lokinet = { description = "Lokinet"; - after = [ "network-online.target" "network.target" ]; - wants = [ "network-online.target" "network.target" ]; + after = [ + "network-online.target" + "network.target" + ]; + wants = [ + "network-online.target" + "network.target" + ]; wantedBy = [ "multi-user.target" ]; preStart = '' @@ -121,7 +140,10 @@ in with lib; { serviceConfig = { DynamicUser = true; StateDirectory = "lokinet"; - AmbientCapabilities = [ "CAP_NET_ADMIN" "CAP_NET_BIND_SERVICE" ]; + AmbientCapabilities = [ + "CAP_NET_ADMIN" + "CAP_NET_BIND_SERVICE" + ]; ExecStart = "${cfg.package}/bin/lokinet ${dataDir}/lokinet.ini"; Restart = "always"; RestartSec = "5s"; @@ -140,7 +162,12 @@ in with lib; { ProtectKernelTunables = true; ProtectSystem = "strict"; ReadWritePaths = "/dev/net/tun"; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" "AF_NETLINK" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + "AF_NETLINK" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; diff --git a/nixos/modules/services/networking/lxd-image-server.nix b/nixos/modules/services/networking/lxd-image-server.nix index 4712a3c1b3db9a..98906262ce1ebc 100644 --- a/nixos/modules/services/networking/lxd-image-server.nix +++ b/nixos/modules/services/networking/lxd-image-server.nix @@ -1,7 +1,12 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.lxd-image-server; - format = pkgs.formats.toml {}; + format = pkgs.formats.toml { }; location = "/var/www/simplestreams"; in @@ -24,7 +29,7 @@ in Example see . ''; - default = {}; + default = { }; }; nginx = { @@ -44,7 +49,7 @@ in isSystemUser = true; group = cfg.group; }; - users.groups.${cfg.group} = {}; + users.groups.${cfg.group} = { }; environment.etc."lxd-image-server/config.toml".source = format.generate "config.toml" cfg.settings; diff --git a/nixos/modules/services/networking/matterbridge.nix b/nixos/modules/services/networking/matterbridge.nix index 74b388d6840850..4f995d500f3f5a 100644 --- a/nixos/modules/services/networking/matterbridge.nix +++ b/nixos/modules/services/networking/matterbridge.nix @@ -1,4 +1,10 @@ -{ options, config, pkgs, lib, ... }: +{ + options, + config, + pkgs, + lib, + ... +}: let cfg = config.services.matterbridge; @@ -88,19 +94,18 @@ in }; config = lib.mkIf cfg.enable { - warnings = lib.optional options.services.matterbridge.configFile.isDefined - "The option services.matterbridge.configFile is insecure and should be replaced with services.matterbridge.configPath"; - - users.users = lib.optionalAttrs (cfg.user == "matterbridge") - { matterbridge = { - group = "matterbridge"; - isSystemUser = true; - }; - }; + warnings = lib.optional options.services.matterbridge.configFile.isDefined "The option services.matterbridge.configFile is insecure and should be replaced with services.matterbridge.configPath"; - users.groups = lib.optionalAttrs (cfg.group == "matterbridge") - { matterbridge = { }; + users.users = lib.optionalAttrs (cfg.user == "matterbridge") { + matterbridge = { + group = "matterbridge"; + isSystemUser = true; }; + }; + + users.groups = lib.optionalAttrs (cfg.group == "matterbridge") { + matterbridge = { }; + }; systemd.services.matterbridge = { description = "Matterbridge chat platform bridge"; diff --git a/nixos/modules/services/networking/microsocks.nix b/nixos/modules/services/networking/microsocks.nix index 09afaf6edf031c..9956b8f158eb8a 100644 --- a/nixos/modules/services/networking/microsocks.nix +++ b/nixos/modules/services/networking/microsocks.nix @@ -1,4 +1,5 @@ -{ config, +{ + config, lib, pkgs, ... @@ -8,16 +9,29 @@ let cfg = config.services.microsocks; cmd = - if cfg.execWrapper != null - then "${cfg.execWrapper} ${cfg.package}/bin/microsocks" - else "${cfg.package}/bin/microsocks"; + if cfg.execWrapper != null then + "${cfg.execWrapper} ${cfg.package}/bin/microsocks" + else + "${cfg.package}/bin/microsocks"; args = - [ "-i" cfg.ip "-p" (toString cfg.port) ] + [ + "-i" + cfg.ip + "-p" + (toString cfg.port) + ] ++ lib.optionals (cfg.authOnce) [ "-1" ] ++ lib.optionals (cfg.disableLogging) [ "-q" ] - ++ lib.optionals (cfg.outgoingBindIp != null) [ "-b" cfg.outgoingBindIp ] - ++ lib.optionals (cfg.authUsername != null) [ "-u" cfg.authUsername ]; -in { + ++ lib.optionals (cfg.outgoingBindIp != null) [ + "-b" + cfg.outgoingBindIp + ] + ++ lib.optionals (cfg.authUsername != null) [ + "-u" + cfg.authUsername + ]; +in +{ options.services.microsocks = { enable = lib.mkEnableOption "Tiny, portable SOCKS5 server with very moderate resource usage"; user = lib.mkOption { @@ -30,7 +44,7 @@ in { description = "Group microsocks runs as."; type = lib.types.str; }; - package = lib.mkPackageOption pkgs "microsocks" {}; + package = lib.mkPackageOption pkgs "microsocks" { }; ip = lib.mkOption { type = lib.types.str; default = "127.0.0.1"; @@ -100,7 +114,7 @@ in { }; }; groups = lib.mkIf (cfg.group == "microsocks") { - microsocks = {}; + microsocks = { }; }; }; systemd.services.microsocks = { @@ -113,7 +127,9 @@ in { Group = cfg.group; Restart = "on-failure"; RestartSec = 10; - LoadCredential = lib.optionalString (cfg.authPasswordFile != null) "MICROSOCKS_PASSWORD_FILE:${cfg.authPasswordFile}"; + LoadCredential = lib.optionalString ( + cfg.authPasswordFile != null + ) "MICROSOCKS_PASSWORD_FILE:${cfg.authPasswordFile}"; MemoryDenyWriteExecute = true; SystemCallArchitectures = "native"; PrivateTmp = true; @@ -133,14 +149,15 @@ in { ]; }; script = - if cfg.authPasswordFile != null - then '' - PASSWORD=$(cat "$CREDENTIALS_DIRECTORY/MICROSOCKS_PASSWORD_FILE") - ${cmd} ${lib.escapeShellArgs args} -P "$PASSWORD" - '' - else '' - ${cmd} ${lib.escapeShellArgs args} - ''; + if cfg.authPasswordFile != null then + '' + PASSWORD=$(cat "$CREDENTIALS_DIRECTORY/MICROSOCKS_PASSWORD_FILE") + ${cmd} ${lib.escapeShellArgs args} -P "$PASSWORD" + '' + else + '' + ${cmd} ${lib.escapeShellArgs args} + ''; }; }; } diff --git a/nixos/modules/services/networking/miniupnpd.nix b/nixos/modules/services/networking/miniupnpd.nix index 9494d6f68e0906..ccbddbf3d5a189 100644 --- a/nixos/modules/services/networking/miniupnpd.nix +++ b/nixos/modules/services/networking/miniupnpd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -22,8 +27,9 @@ let ''; firewall = if config.networking.nftables.enable then "nftables" else "iptables"; miniupnpd = pkgs.miniupnpd.override { inherit firewall; }; - firewallScripts = lib.optionals (firewall == "iptables") - ([ "iptables"] ++ lib.optional (config.networking.enableIPv6) "ip6tables"); + firewallScripts = lib.optionals (firewall == "iptables") ( + [ "iptables" ] ++ lib.optional (config.networking.enableIPv6) "ip6tables" + ); in { options = { @@ -39,7 +45,10 @@ in internalIPs = mkOption { type = types.listOf types.str; - example = [ "192.168.1.1/24" "enp1s0" ]; + example = [ + "192.168.1.1/24" + "enp1s0" + ]; description = '' The IP address ranges to listen on. ''; @@ -66,13 +75,21 @@ in }; config = mkIf cfg.enable { - networking.firewall.extraCommands = lib.mkIf (firewallScripts != []) (builtins.concatStringsSep "\n" (map (fw: '' - EXTIF=${cfg.externalInterface} ${pkgs.bash}/bin/bash -x ${miniupnpd}/etc/miniupnpd/${fw}_init.sh - '') firewallScripts)); + networking.firewall.extraCommands = lib.mkIf (firewallScripts != [ ]) ( + builtins.concatStringsSep "\n" ( + map (fw: '' + EXTIF=${cfg.externalInterface} ${pkgs.bash}/bin/bash -x ${miniupnpd}/etc/miniupnpd/${fw}_init.sh + '') firewallScripts + ) + ); - networking.firewall.extraStopCommands = lib.mkIf (firewallScripts != []) (builtins.concatStringsSep "\n" (map (fw: '' - EXTIF=${cfg.externalInterface} ${pkgs.bash}/bin/bash -x ${miniupnpd}/etc/miniupnpd/${fw}_removeall.sh - '') firewallScripts)); + networking.firewall.extraStopCommands = lib.mkIf (firewallScripts != [ ]) ( + builtins.concatStringsSep "\n" ( + map (fw: '' + EXTIF=${cfg.externalInterface} ${pkgs.bash}/bin/bash -x ${miniupnpd}/etc/miniupnpd/${fw}_removeall.sh + '') firewallScripts + ) + ); networking.nftables = lib.mkIf (firewall == "nftables") { # see nft_init in ${miniupnpd-nftables}/etc/miniupnpd diff --git a/nixos/modules/services/networking/miredo.nix b/nixos/modules/services/networking/miredo.nix index 12be41b7e7b6b6..d9314216717987 100644 --- a/nixos/modules/services/networking/miredo.nix +++ b/nixos/modules/services/networking/miredo.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -63,7 +68,6 @@ in }; }; - ###### implementation config = mkIf cfg.enable { diff --git a/nixos/modules/services/networking/mjpg-streamer.nix b/nixos/modules/services/networking/mjpg-streamer.nix index 7867a5af1e5146..4f0747d8a262f1 100644 --- a/nixos/modules/services/networking/mjpg-streamer.nix +++ b/nixos/modules/services/networking/mjpg-streamer.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,7 +11,8 @@ let cfg = config.services.mjpg-streamer; -in { +in +{ options = { diff --git a/nixos/modules/services/networking/mmsd.nix b/nixos/modules/services/networking/mmsd.nix index e801150a3fc98b..5e65d46e0b5a69 100644 --- a/nixos/modules/services/networking/mmsd.nix +++ b/nixos/modules/services/networking/mmsd.nix @@ -1,4 +1,9 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: with lib; let cfg = config.services.mmsd; @@ -18,8 +23,8 @@ in extraArgs = mkOption { type = with types; listOf str; description = "Extra arguments passed to `mmsd-tng`"; - default = []; - example = ["--debug"]; + default = [ ]; + example = [ "--debug" ]; }; }; config = mkIf cfg.enable { diff --git a/nixos/modules/services/networking/monero.nix b/nixos/modules/services/networking/monero.nix index 5cb418a9f1e62d..1ef0c696e2c8bd 100644 --- a/nixos/modules/services/networking/monero.nix +++ b/nixos/modules/services/networking/monero.nix @@ -1,42 +1,48 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - cfg = config.services.monero; + cfg = config.services.monero; - listToConf = option: list: - lib.concatMapStrings (value: "${option}=${value}\n") list; + listToConf = option: list: lib.concatMapStrings (value: "${option}=${value}\n") list; login = (cfg.rpc.user != null && cfg.rpc.password != null); - configFile = with cfg; pkgs.writeText "monero.conf" '' - log-file=/dev/stdout - data-dir=${dataDir} - - ${lib.optionalString mining.enable '' - start-mining=${mining.address} - mining-threads=${toString mining.threads} - ''} - - rpc-bind-ip=${rpc.address} - rpc-bind-port=${toString rpc.port} - ${lib.optionalString login '' - rpc-login=${rpc.user}:${rpc.password} - ''} - ${lib.optionalString rpc.restricted '' - restricted-rpc=1 - ''} - - limit-rate-up=${toString limits.upload} - limit-rate-down=${toString limits.download} - max-concurrency=${toString limits.threads} - block-sync-size=${toString limits.syncSize} - - ${listToConf "add-peer" extraNodes} - ${listToConf "add-priority-node" priorityNodes} - ${listToConf "add-exclusive-node" exclusiveNodes} - - ${extraConfig} - ''; + configFile = + with cfg; + pkgs.writeText "monero.conf" '' + log-file=/dev/stdout + data-dir=${dataDir} + + ${lib.optionalString mining.enable '' + start-mining=${mining.address} + mining-threads=${toString mining.threads} + ''} + + rpc-bind-ip=${rpc.address} + rpc-bind-port=${toString rpc.port} + ${lib.optionalString login '' + rpc-login=${rpc.user}:${rpc.password} + ''} + ${lib.optionalString rpc.restricted '' + restricted-rpc=1 + ''} + + limit-rate-up=${toString limits.upload} + limit-rate-down=${toString limits.download} + max-concurrency=${toString limits.threads} + block-sync-size=${toString limits.syncSize} + + ${listToConf "add-peer" extraNodes} + ${listToConf "add-priority-node" priorityNodes} + ${listToConf "add-exclusive-node" exclusiveNodes} + + ${extraConfig} + ''; in @@ -75,7 +81,7 @@ in }; mining.threads = lib.mkOption { - type = lib.types.addCheck lib.types.int (x: x>=0); + type = lib.types.addCheck lib.types.int (x: x >= 0); default = 0; description = '' Number of threads used for mining. @@ -124,7 +130,7 @@ in }; limits.upload = lib.mkOption { - type = lib.types.addCheck lib.types.int (x: x>=-1); + type = lib.types.addCheck lib.types.int (x: x >= -1); default = -1; description = '' Limit of the upload rate in kB/s. @@ -133,7 +139,7 @@ in }; limits.download = lib.mkOption { - type = lib.types.addCheck lib.types.int (x: x>=-1); + type = lib.types.addCheck lib.types.int (x: x >= -1); default = -1; description = '' Limit of the download rate in kB/s. @@ -142,7 +148,7 @@ in }; limits.threads = lib.mkOption { - type = lib.types.addCheck lib.types.int (x: x>=0); + type = lib.types.addCheck lib.types.int (x: x >= 0); default = 0; description = '' Maximum number of threads used for a parallel job. @@ -151,7 +157,7 @@ in }; limits.syncSize = lib.mkOption { - type = lib.types.addCheck lib.types.int (x: x>=0); + type = lib.types.addCheck lib.types.int (x: x >= 0); default = 0; description = '' Maximum number of blocks to sync at once. @@ -197,7 +203,6 @@ in }; - ###### implementation config = lib.mkIf cfg.enable { @@ -214,23 +219,26 @@ in systemd.services.monero = { description = "monero daemon"; - after = [ "network.target" ]; + after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { - User = "monero"; + User = "monero"; Group = "monero"; ExecStart = "${pkgs.monero-cli}/bin/monerod --config-file=${configFile} --non-interactive"; Restart = "always"; - SuccessExitStatus = [ 0 1 ]; + SuccessExitStatus = [ + 0 + 1 + ]; }; }; assertions = lib.singleton { assertion = cfg.mining.enable -> cfg.mining.address != ""; - message = '' - You need a Monero address to receive mining rewards: - specify one using option monero.mining.address. + message = '' + You need a Monero address to receive mining rewards: + specify one using option monero.mining.address. ''; }; @@ -239,4 +247,3 @@ in meta.maintainers = with lib.maintainers; [ rnhmjoj ]; } - diff --git a/nixos/modules/services/networking/morty.nix b/nixos/modules/services/networking/morty.nix index c3ed718fe8d840..8f672162a3c425 100644 --- a/nixos/modules/services/networking/morty.nix +++ b/nixos/modules/services/networking/morty.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -63,29 +68,29 @@ in config = mkIf config.services.morty.enable { - users.users.morty = - { description = "Morty user"; - createHome = true; - home = "/var/lib/morty"; - isSystemUser = true; - group = "morty"; - }; - users.groups.morty = {}; - - systemd.services.morty = - { - description = "Morty sanitizing proxy server."; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - User = "morty"; - ExecStart = ''${cfg.package}/bin/morty \ - -listen ${cfg.listenAddress}:${toString cfg.port} \ - ${optionalString cfg.ipv6 "-ipv6"} \ - ${optionalString (cfg.key != "") "-key " + cfg.key} \ - ''; - }; + users.users.morty = { + description = "Morty user"; + createHome = true; + home = "/var/lib/morty"; + isSystemUser = true; + group = "morty"; + }; + users.groups.morty = { }; + + systemd.services.morty = { + description = "Morty sanitizing proxy server."; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + User = "morty"; + ExecStart = '' + ${cfg.package}/bin/morty \ + -listen ${cfg.listenAddress}:${toString cfg.port} \ + ${optionalString cfg.ipv6 "-ipv6"} \ + ${optionalString (cfg.key != "") "-key " + cfg.key} \ + ''; }; + }; environment.systemPackages = [ cfg.package ]; }; diff --git a/nixos/modules/services/networking/mosquitto.nix b/nixos/modules/services/networking/mosquitto.nix index e628be0d5b1b34..9753d0a4a5426d 100644 --- a/nixos/modules/services/networking/mosquitto.nix +++ b/nixos/modules/services/networking/mosquitto.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.mosquitto; @@ -10,208 +15,247 @@ let }; path = lib.types.addCheck lib.types.path (p: str.check "${p}"); configKey = lib.types.strMatching "[^\r\n\t ]+"; - optionType = with lib.types; oneOf [ str path bool int ] // { - description = "string, path, bool, or integer"; - }; - optionToString = v: - if lib.isBool v then lib.boolToString v - else if path.check v then "${v}" - else toString v; - - assertKeysValid = prefix: valid: config: - lib.mapAttrsToList - (n: _: { - assertion = valid ? ${n}; - message = "Invalid config key ${prefix}.${n}."; - }) - config; - - formatFreeform = { prefix ? "" }: lib.mapAttrsToList (n: v: "${prefix}${n} ${optionToString v}"); - - userOptions = with lib.types; submodule { - options = { - password = lib.mkOption { - type = uniq (nullOr str); - default = null; - description = '' - Specifies the (clear text) password for the MQTT User. - ''; - }; + optionType = + with lib.types; + oneOf [ + str + path + bool + int + ] + // { + description = "string, path, bool, or integer"; + }; + optionToString = + v: + if lib.isBool v then + lib.boolToString v + else if path.check v then + "${v}" + else + toString v; + + assertKeysValid = + prefix: valid: config: + lib.mapAttrsToList (n: _: { + assertion = valid ? ${n}; + message = "Invalid config key ${prefix}.${n}."; + }) config; + + formatFreeform = + { + prefix ? "", + }: + lib.mapAttrsToList (n: v: "${prefix}${n} ${optionToString v}"); + + userOptions = + with lib.types; + submodule { + options = { + password = lib.mkOption { + type = uniq (nullOr str); + default = null; + description = '' + Specifies the (clear text) password for the MQTT User. + ''; + }; - passwordFile = lib.mkOption { - type = uniq (nullOr path); - example = "/path/to/file"; - default = null; - description = '' - Specifies the path to a file containing the - clear text password for the MQTT user. - The file is securely passed to mosquitto by - leveraging systemd credentials. No special - permissions need to be set on this file. - ''; - }; + passwordFile = lib.mkOption { + type = uniq (nullOr path); + example = "/path/to/file"; + default = null; + description = '' + Specifies the path to a file containing the + clear text password for the MQTT user. + The file is securely passed to mosquitto by + leveraging systemd credentials. No special + permissions need to be set on this file. + ''; + }; - hashedPassword = lib.mkOption { - type = uniq (nullOr str); - default = null; - description = '' - Specifies the hashed password for the MQTT User. - To generate hashed password install the `mosquitto` - package and use `mosquitto_passwd`, then extract - the second field (after the `:`) from the generated - file. - ''; - }; + hashedPassword = lib.mkOption { + type = uniq (nullOr str); + default = null; + description = '' + Specifies the hashed password for the MQTT User. + To generate hashed password install the `mosquitto` + package and use `mosquitto_passwd`, then extract + the second field (after the `:`) from the generated + file. + ''; + }; - hashedPasswordFile = lib.mkOption { - type = uniq (nullOr path); - example = "/path/to/file"; - default = null; - description = '' - Specifies the path to a file containing the - hashed password for the MQTT user. - To generate hashed password install the `mosquitto` - package and use `mosquitto_passwd`, then remove the - `username:` prefix from the generated file. - The file is securely passed to mosquitto by - leveraging systemd credentials. No special - permissions need to be set on this file. - ''; - }; + hashedPasswordFile = lib.mkOption { + type = uniq (nullOr path); + example = "/path/to/file"; + default = null; + description = '' + Specifies the path to a file containing the + hashed password for the MQTT user. + To generate hashed password install the `mosquitto` + package and use `mosquitto_passwd`, then remove the + `username:` prefix from the generated file. + The file is securely passed to mosquitto by + leveraging systemd credentials. No special + permissions need to be set on this file. + ''; + }; - acl = lib.mkOption { - type = listOf str; - example = [ "read A/B" "readwrite A/#" ]; - default = []; - description = '' - Control client access to topics on the broker. - ''; + acl = lib.mkOption { + type = listOf str; + example = [ + "read A/B" + "readwrite A/#" + ]; + default = [ ]; + description = '' + Control client access to topics on the broker. + ''; + }; }; }; - }; - userAsserts = prefix: users: - lib.mapAttrsToList - (n: _: { - assertion = builtins.match "[^:\r\n]+" n != null; - message = "Invalid user name ${n} in ${prefix}"; - }) - users - ++ lib.mapAttrsToList - (n: u: { - assertion = lib.count (s: s != null) [ - u.password u.passwordFile u.hashedPassword u.hashedPasswordFile + userAsserts = + prefix: users: + lib.mapAttrsToList (n: _: { + assertion = builtins.match "[^:\r\n]+" n != null; + message = "Invalid user name ${n} in ${prefix}"; + }) users + ++ lib.mapAttrsToList (n: u: { + assertion = + lib.count (s: s != null) [ + u.password + u.passwordFile + u.hashedPassword + u.hashedPasswordFile ] <= 1; - message = "Cannot set more than one password option for user ${n} in ${prefix}"; - }) users; + message = "Cannot set more than one password option for user ${n} in ${prefix}"; + }) users; listenerScope = index: "listener-${toString index}"; userScope = prefix: index: "${prefix}-user-${toString index}"; credentialID = prefix: credential: "${prefix}-${credential}"; - toScopedUsers = listenerScope: users: lib.pipe users [ - lib.attrNames - (lib.imap0 (index: user: lib.nameValuePair user - (users.${user} // { scope = userScope listenerScope index; }) - )) - lib.listToAttrs - ]; - - userCredentials = user: credentials: lib.pipe credentials [ - (lib.filter (credential: user.${credential} != null)) - (map (credential: "${credentialID user.scope credential}:${user.${credential}}")) - ]; - usersCredentials = listenerScope: users: credentials: lib.pipe users [ - (toScopedUsers listenerScope) - (lib.mapAttrsToList (_: user: userCredentials user credentials)) - lib.concatLists - ]; - systemdCredentials = listeners: listenerCredentials: lib.pipe listeners [ - (lib.imap0 (index: listener: listenerCredentials (listenerScope index) listener)) - lib.concatLists - ]; - - makePasswordFile = listenerScope: users: path: + toScopedUsers = + listenerScope: users: + lib.pipe users [ + lib.attrNames + (lib.imap0 ( + index: user: lib.nameValuePair user (users.${user} // { scope = userScope listenerScope index; }) + )) + lib.listToAttrs + ]; + + userCredentials = + user: credentials: + lib.pipe credentials [ + (lib.filter (credential: user.${credential} != null)) + (map (credential: "${credentialID user.scope credential}:${user.${credential}}")) + ]; + usersCredentials = + listenerScope: users: credentials: + lib.pipe users [ + (toScopedUsers listenerScope) + (lib.mapAttrsToList (_: user: userCredentials user credentials)) + lib.concatLists + ]; + systemdCredentials = + listeners: listenerCredentials: + lib.pipe listeners [ + (lib.imap0 (index: listener: listenerCredentials (listenerScope index) listener)) + lib.concatLists + ]; + + makePasswordFile = + listenerScope: users: path: let - makeLines = store: file: let - scopedUsers = toScopedUsers listenerScope users; - in - lib.mapAttrsToList - (name: user: ''addLine ${lib.escapeShellArg name} "''$(systemd-creds cat ${credentialID user.scope store})"'') - (lib.filterAttrs (_: user: user.${store} != null) scopedUsers) - ++ lib.mapAttrsToList - (name: user: ''addFile ${lib.escapeShellArg name} "''${CREDENTIALS_DIRECTORY}/${credentialID user.scope file}"'') - (lib.filterAttrs (_: user: user.${file} != null) scopedUsers); + makeLines = + store: file: + let + scopedUsers = toScopedUsers listenerScope users; + in + lib.mapAttrsToList ( + name: user: + ''addLine ${lib.escapeShellArg name} "''$(systemd-creds cat ${credentialID user.scope store})"'' + ) (lib.filterAttrs (_: user: user.${store} != null) scopedUsers) + ++ lib.mapAttrsToList ( + name: user: + ''addFile ${lib.escapeShellArg name} "''${CREDENTIALS_DIRECTORY}/${credentialID user.scope file}"'' + ) (lib.filterAttrs (_: user: user.${file} != null) scopedUsers); plainLines = makeLines "password" "passwordFile"; hashedLines = makeLines "hashedPassword" "hashedPasswordFile"; in - pkgs.writeScript "make-mosquitto-passwd" - ('' - #! ${pkgs.runtimeShell} - - set -eu - - file=${lib.escapeShellArg path} - - rm -f "$file" - touch "$file" - - addLine() { - echo "$1:$2" >> "$file" - } - addFile() { - if [ $(wc -l <"$2") -gt 1 ]; then - echo "invalid mosquitto password file $2" >&2 - return 1 - fi - echo "$1:$(cat "$2")" >> "$file" - } + pkgs.writeScript "make-mosquitto-passwd" ( + '' + #! ${pkgs.runtimeShell} + + set -eu + + file=${lib.escapeShellArg path} + + rm -f "$file" + touch "$file" + + addLine() { + echo "$1:$2" >> "$file" + } + addFile() { + if [ $(wc -l <"$2") -gt 1 ]; then + echo "invalid mosquitto password file $2" >&2 + return 1 + fi + echo "$1:$(cat "$2")" >> "$file" + } + '' + + lib.concatStringsSep "\n" ( + plainLines + ++ lib.optional (plainLines != [ ]) '' + ${cfg.package}/bin/mosquitto_passwd -U "$file" '' - + lib.concatStringsSep "\n" - (plainLines - ++ lib.optional (plainLines != []) '' - ${cfg.package}/bin/mosquitto_passwd -U "$file" - '' - ++ hashedLines)); - - authPluginOptions = with lib.types; submodule { - options = { - plugin = lib.mkOption { - type = path; - description = '' - Plugin path to load, should be a `.so` file. - ''; - }; + ++ hashedLines + ) + ); - denySpecialChars = lib.mkOption { - type = bool; - description = '' - Automatically disallow all clients using `#` - or `+` in their name/id. - ''; - default = true; - }; + authPluginOptions = + with lib.types; + submodule { + options = { + plugin = lib.mkOption { + type = path; + description = '' + Plugin path to load, should be a `.so` file. + ''; + }; + + denySpecialChars = lib.mkOption { + type = bool; + description = '' + Automatically disallow all clients using `#` + or `+` in their name/id. + ''; + default = true; + }; - options = lib.mkOption { - type = attrsOf optionType; - description = '' - Options for the auth plugin. Each key turns into a `auth_opt_*` - line in the config. - ''; - default = {}; + options = lib.mkOption { + type = attrsOf optionType; + description = '' + Options for the auth plugin. Each key turns into a `auth_opt_*` + line in the config. + ''; + default = { }; + }; }; }; - }; - authAsserts = prefix: auth: - lib.mapAttrsToList - (n: _: { - assertion = configKey.check n; - message = "Invalid auth plugin key ${prefix}.${n}"; - }) - auth; + authAsserts = + prefix: auth: + lib.mapAttrsToList (n: _: { + assertion = configKey.check n; + message = "Invalid auth plugin key ${prefix}.${n}"; + }) auth; - formatAuthPlugin = plugin: + formatAuthPlugin = + plugin: [ "auth_plugin ${plugin.plugin}" "auth_plugin_deny_special_chars ${optionToString plugin.denySpecialChars}" @@ -250,88 +294,98 @@ let use_username_as_clientid = 1; }; - listenerOptions = with lib.types; submodule { - options = { - port = lib.mkOption { - type = port; - description = '' - Port to listen on. Must be set to 0 to listen on a unix domain socket. - ''; - default = 1883; - }; + listenerOptions = + with lib.types; + submodule { + options = { + port = lib.mkOption { + type = port; + description = '' + Port to listen on. Must be set to 0 to listen on a unix domain socket. + ''; + default = 1883; + }; - address = lib.mkOption { - type = nullOr str; - description = '' - Address to listen on. Listen on `0.0.0.0`/`::` - when unset. - ''; - default = null; - }; + address = lib.mkOption { + type = nullOr str; + description = '' + Address to listen on. Listen on `0.0.0.0`/`::` + when unset. + ''; + default = null; + }; - authPlugins = lib.mkOption { - type = listOf authPluginOptions; - description = '' - Authentication plugin to attach to this listener. - Refer to the [mosquitto.conf documentation](https://mosquitto.org/man/mosquitto-conf-5.html) - for details on authentication plugins. - ''; - default = []; - }; + authPlugins = lib.mkOption { + type = listOf authPluginOptions; + description = '' + Authentication plugin to attach to this listener. + Refer to the [mosquitto.conf documentation](https://mosquitto.org/man/mosquitto-conf-5.html) + for details on authentication plugins. + ''; + default = [ ]; + }; - users = lib.mkOption { - type = attrsOf userOptions; - example = { john = { password = "123456"; acl = [ "readwrite john/#" ]; }; }; - description = '' - A set of users and their passwords and ACLs. - ''; - default = {}; - }; + users = lib.mkOption { + type = attrsOf userOptions; + example = { + john = { + password = "123456"; + acl = [ "readwrite john/#" ]; + }; + }; + description = '' + A set of users and their passwords and ACLs. + ''; + default = { }; + }; - omitPasswordAuth = lib.mkOption { - type = bool; - description = '' - Omits password checking, allowing anyone to log in with any user name unless - other mandatory authentication methods (eg TLS client certificates) are configured. - ''; - default = false; - }; + omitPasswordAuth = lib.mkOption { + type = bool; + description = '' + Omits password checking, allowing anyone to log in with any user name unless + other mandatory authentication methods (eg TLS client certificates) are configured. + ''; + default = false; + }; - acl = lib.mkOption { - type = listOf str; - description = '' - Additional ACL items to prepend to the generated ACL file. - ''; - example = [ "pattern read #" "topic readwrite anon/report/#" ]; - default = []; - }; + acl = lib.mkOption { + type = listOf str; + description = '' + Additional ACL items to prepend to the generated ACL file. + ''; + example = [ + "pattern read #" + "topic readwrite anon/report/#" + ]; + default = [ ]; + }; - settings = lib.mkOption { - type = submodule { - freeformType = attrsOf optionType; + settings = lib.mkOption { + type = submodule { + freeformType = attrsOf optionType; + }; + description = '' + Additional settings for this listener. + ''; + default = { }; }; - description = '' - Additional settings for this listener. - ''; - default = {}; }; }; - }; - listenerAsserts = prefix: listener: + listenerAsserts = + prefix: listener: assertKeysValid "${prefix}.settings" freeformListenerKeys listener.settings ++ userAsserts prefix listener.users - ++ lib.imap0 - (i: v: authAsserts "${prefix}.authPlugins.${toString i}" v) - listener.authPlugins; + ++ lib.imap0 (i: v: authAsserts "${prefix}.authPlugins.${toString i}" v) listener.authPlugins; - formatListener = idx: listener: + formatListener = + idx: listener: [ "listener ${toString listener.port} ${toString listener.address}" "acl_file /etc/mosquitto/acl-${toString idx}.conf" ] - ++ lib.optional (! listener.omitPasswordAuth) "password_file ${cfg.dataDir}/passwd-${toString idx}" - ++ formatFreeform {} listener.settings + ++ lib.optional (!listener.omitPasswordAuth) "password_file ${cfg.dataDir}/passwd-${toString idx}" + ++ formatFreeform { } listener.settings ++ lib.concatMap formatAuthPlugin listener.authPlugins; freeformBridgeKeys = { @@ -370,70 +424,76 @@ let try_private = 1; }; - bridgeOptions = with lib.types; submodule { - options = { - addresses = lib.mkOption { - type = listOf (submodule { - options = { - address = lib.mkOption { - type = str; - description = '' - Address of the remote MQTT broker. - ''; + bridgeOptions = + with lib.types; + submodule { + options = { + addresses = lib.mkOption { + type = listOf (submodule { + options = { + address = lib.mkOption { + type = str; + description = '' + Address of the remote MQTT broker. + ''; + }; + + port = lib.mkOption { + type = port; + description = '' + Port of the remote MQTT broker. + ''; + default = 1883; + }; }; + }); + default = [ ]; + description = '' + Remote endpoints for the bridge. + ''; + }; - port = lib.mkOption { - type = port; - description = '' - Port of the remote MQTT broker. - ''; - default = 1883; - }; - }; - }); - default = []; - description = '' - Remote endpoints for the bridge. - ''; - }; - - topics = lib.mkOption { - type = listOf str; - description = '' - Topic patterns to be shared between the two brokers. - Refer to the [ - mosquitto.conf documentation](https://mosquitto.org/man/mosquitto-conf-5.html) for details on the format. - ''; - default = []; - example = [ "# both 2 local/topic/ remote/topic/" ]; - }; + topics = lib.mkOption { + type = listOf str; + description = '' + Topic patterns to be shared between the two brokers. + Refer to the [ + mosquitto.conf documentation](https://mosquitto.org/man/mosquitto-conf-5.html) for details on the format. + ''; + default = [ ]; + example = [ "# both 2 local/topic/ remote/topic/" ]; + }; - settings = lib.mkOption { - type = submodule { - freeformType = attrsOf optionType; + settings = lib.mkOption { + type = submodule { + freeformType = attrsOf optionType; + }; + description = '' + Additional settings for this bridge. + ''; + default = { }; }; - description = '' - Additional settings for this bridge. - ''; - default = {}; }; }; - }; - bridgeAsserts = prefix: bridge: + bridgeAsserts = + prefix: bridge: assertKeysValid "${prefix}.settings" freeformBridgeKeys bridge.settings - ++ [ { - assertion = lib.length bridge.addresses > 0; - message = "Bridge ${prefix} needs remote broker addresses"; - } ]; + ++ [ + { + assertion = lib.length bridge.addresses > 0; + message = "Bridge ${prefix} needs remote broker addresses"; + } + ]; - formatBridge = name: bridge: + formatBridge = + name: bridge: [ "connection ${name}" "addresses ${lib.concatMapStringsSep " " (a: "${a.address}:${toString a.port}") bridge.addresses}" ] ++ map (t: "topic ${t}") bridge.topics - ++ formatFreeform {} bridge.settings; + ++ formatFreeform { } bridge.settings; freeformGlobalKeys = { allow_duplicate_messages = 1; @@ -472,7 +532,7 @@ let bridges = lib.mkOption { type = attrsOf bridgeOptions; - default = {}; + default = { }; description = '' Bridges to build to other MQTT brokers. ''; @@ -480,7 +540,7 @@ let listeners = lib.mkOption { type = listOf listenerOptions; - default = []; + default = [ ]; description = '' Listeners to configure on this broker. ''; @@ -494,11 +554,19 @@ let `*.conf` files in the directory will be read in case-sensitive alphabetical order. ''; - default = []; + default = [ ]; }; logDest = lib.mkOption { - type = listOf (either path (enum [ "stdout" "stderr" "syslog" "topic" "dlt" ])); + type = listOf ( + either path (enum [ + "stdout" + "stderr" + "syslog" + "topic" + "dlt" + ]) + ); description = '' Destinations to send log messages to. ''; @@ -506,12 +574,22 @@ let }; logType = lib.mkOption { - type = listOf (enum [ "debug" "error" "warning" "notice" "information" - "subscribe" "unsubscribe" "websockets" "none" "all" ]); + type = listOf (enum [ + "debug" + "error" + "warning" + "notice" + "information" + "subscribe" + "unsubscribe" + "websockets" + "none" + "all" + ]); description = '' Types of messages to log. ''; - default = []; + default = [ ]; }; persistence = lib.mkOption { @@ -537,33 +615,32 @@ let description = '' Global configuration options for the mosquitto broker. ''; - default = {}; + default = { }; }; }; - globalAsserts = prefix: cfg: + globalAsserts = + prefix: cfg: lib.flatten [ (assertKeysValid "${prefix}.settings" freeformGlobalKeys cfg.settings) (lib.imap0 (n: l: listenerAsserts "${prefix}.listener.${toString n}" l) cfg.listeners) (lib.mapAttrsToList (n: b: bridgeAsserts "${prefix}.bridge.${n}" b) cfg.bridges) ]; - formatGlobal = cfg: + formatGlobal = + cfg: [ "per_listener_settings true" "persistence ${optionToString cfg.persistence}" ] - ++ map - (d: if path.check d then "log_dest file ${d}" else "log_dest ${d}") - cfg.logDest + ++ map (d: if path.check d then "log_dest file ${d}" else "log_dest ${d}") cfg.logDest ++ map (t: "log_type ${t}") cfg.logType - ++ formatFreeform {} cfg.settings + ++ formatFreeform { } cfg.settings ++ lib.concatLists (lib.imap0 formatListener cfg.listeners) ++ lib.concatLists (lib.mapAttrsToList formatBridge cfg.bridges) ++ map (d: "include_dir ${d}") cfg.includeDirs; - configFile = pkgs.writeText "mosquitto.conf" - (lib.concatStringsSep "\n" (formatGlobal cfg)); + configFile = pkgs.writeText "mosquitto.conf" (lib.concatStringsSep "\n" (formatGlobal cfg)); in @@ -596,16 +673,26 @@ in ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; # Credentials - SetCredential = let - listenerCredentials = listenerScope: listener: - usersCredentials listenerScope listener.users [ "password" "hashedPassword" ]; - in + SetCredential = + let + listenerCredentials = + listenerScope: listener: + usersCredentials listenerScope listener.users [ + "password" + "hashedPassword" + ]; + in systemdCredentials cfg.listeners listenerCredentials; - LoadCredential = let - listenerCredentials = listenerScope: listener: - usersCredentials listenerScope listener.users [ "passwordFile" "hashedPasswordFile" ]; - in + LoadCredential = + let + listenerCredentials = + listenerScope: listener: + usersCredentials listenerScope listener.users [ + "passwordFile" + "hashedPasswordFile" + ]; + in systemdCredentials cfg.listeners listenerCredentials; # Hardening @@ -629,35 +716,31 @@ in ProtectSystem = "strict"; ReadWritePaths = [ cfg.dataDir - "/tmp" # mosquitto_passwd creates files in /tmp before moving them + "/tmp" # mosquitto_passwd creates files in /tmp before moving them ] ++ lib.filter path.check cfg.logDest; - ReadOnlyPaths = - map (p: "${p}") - (cfg.includeDirs - ++ lib.filter - (v: v != null) - (lib.flatten [ - (map - (l: [ - (l.settings.psk_file or null) - (l.settings.http_dir or null) - (l.settings.cafile or null) - (l.settings.capath or null) - (l.settings.certfile or null) - (l.settings.crlfile or null) - (l.settings.dhparamfile or null) - (l.settings.keyfile or null) - ]) - cfg.listeners) - (lib.mapAttrsToList - (_: b: [ - (b.settings.bridge_cafile or null) - (b.settings.bridge_capath or null) - (b.settings.bridge_certfile or null) - (b.settings.bridge_keyfile or null) - ]) - cfg.bridges) - ])); + ReadOnlyPaths = map (p: "${p}") ( + cfg.includeDirs + ++ lib.filter (v: v != null) ( + lib.flatten [ + (map (l: [ + (l.settings.psk_file or null) + (l.settings.http_dir or null) + (l.settings.cafile or null) + (l.settings.capath or null) + (l.settings.certfile or null) + (l.settings.crlfile or null) + (l.settings.dhparamfile or null) + (l.settings.keyfile or null) + ]) cfg.listeners) + (lib.mapAttrsToList (_: b: [ + (b.settings.bridge_cafile or null) + (b.settings.bridge_capath or null) + (b.settings.bridge_certfile or null) + (b.settings.bridge_keyfile or null) + ]) cfg.bridges) + ] + ) + ); RemoveIPC = true; RestrictAddressFamilies = [ "AF_UNIX" @@ -676,33 +759,31 @@ in ]; UMask = "0077"; }; - preStart = - lib.concatStringsSep - "\n" - (lib.imap0 - (idx: listener: makePasswordFile (listenerScope idx) listener.users "${cfg.dataDir}/passwd-${toString idx}") - cfg.listeners); + preStart = lib.concatStringsSep "\n" ( + lib.imap0 ( + idx: listener: + makePasswordFile (listenerScope idx) listener.users "${cfg.dataDir}/passwd-${toString idx}" + ) cfg.listeners + ); }; environment.etc = lib.listToAttrs ( - lib.imap0 - (idx: listener: { - name = "mosquitto/acl-${toString idx}.conf"; - value = { - user = config.users.users.mosquitto.name; - group = config.users.users.mosquitto.group; - mode = "0400"; - text = (lib.concatStringsSep - "\n" - (lib.flatten [ + lib.imap0 (idx: listener: { + name = "mosquitto/acl-${toString idx}.conf"; + value = { + user = config.users.users.mosquitto.name; + group = config.users.users.mosquitto.group; + mode = "0400"; + text = ( + lib.concatStringsSep "\n" ( + lib.flatten [ listener.acl - (lib.mapAttrsToList - (n: u: [ "user ${n}" ] ++ map (t: "topic ${t}") u.acl) - listener.users) - ])); - }; - }) - cfg.listeners + (lib.mapAttrsToList (n: u: [ "user ${n}" ] ++ map (t: "topic ${t}") u.acl) listener.users) + ] + ) + ); + }; + }) cfg.listeners ); users.users.mosquitto = { diff --git a/nixos/modules/services/networking/mozillavpn.nix b/nixos/modules/services/networking/mozillavpn.nix index c10272b4d7fff8..d53beb6cb8842a 100644 --- a/nixos/modules/services/networking/mozillavpn.nix +++ b/nixos/modules/services/networking/mozillavpn.nix @@ -1,8 +1,12 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { - options.services.mozillavpn.enable = - lib.mkEnableOption "Mozilla VPN daemon"; + options.services.mozillavpn.enable = lib.mkEnableOption "Mozilla VPN daemon"; config = lib.mkIf config.services.mozillavpn.enable { environment.systemPackages = [ pkgs.mozillavpn ]; diff --git a/nixos/modules/services/networking/mstpd.nix b/nixos/modules/services/networking/mstpd.nix index bd71010ce549c3..eeb717530f9cef 100644 --- a/nixos/modules/services/networking/mstpd.nix +++ b/nixos/modules/services/networking/mstpd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.mstpd; in diff --git a/nixos/modules/services/networking/mtprotoproxy.nix b/nixos/modules/services/networking/mtprotoproxy.nix index 679e84458b20b6..fa97131b737add 100644 --- a/nixos/modules/services/networking/mtprotoproxy.nix +++ b/nixos/modules/services/networking/mtprotoproxy.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,14 +11,17 @@ let cfg = config.services.mtprotoproxy; - configOpts = { - PORT = cfg.port; - USERS = cfg.users; - SECURE_ONLY = cfg.secureOnly; - } // lib.optionalAttrs (cfg.adTag != null) { AD_TAG = cfg.adTag; } + configOpts = + { + PORT = cfg.port; + USERS = cfg.users; + SECURE_ONLY = cfg.secureOnly; + } + // lib.optionalAttrs (cfg.adTag != null) { AD_TAG = cfg.adTag; } // cfg.extraConfig; - convertOption = opt: + convertOption = + opt: if isString opt || isInt opt then builtins.toJSON opt else if isBool opt then @@ -21,11 +29,17 @@ let else if isList opt then "[" + concatMapStringsSep "," convertOption opt + "]" else if isAttrs opt then - "{" + concatStringsSep "," (mapAttrsToList (name: opt: "${builtins.toJSON name}: ${convertOption opt}") opt) + "}" + "{" + + concatStringsSep "," ( + mapAttrsToList (name: opt: "${builtins.toJSON name}: ${convertOption opt}") opt + ) + + "}" else throw "Invalid option type"; - configFile = pkgs.writeText "config.py" (concatStringsSep "\n" (mapAttrsToList (name: opt: "${name} = ${convertOption opt}") configOpts)); + configFile = pkgs.writeText "config.py" ( + concatStringsSep "\n" (mapAttrsToList (name: opt: "${name} = ${convertOption opt}") configOpts) + ); in @@ -78,7 +92,7 @@ in extraConfig = mkOption { type = types.attrs; - default = {}; + default = { }; example = { STATS_PRINT_PERIOD = 600; }; @@ -91,7 +105,6 @@ in }; - ###### implementation config = mkIf cfg.enable { diff --git a/nixos/modules/services/networking/mtr-exporter.nix b/nixos/modules/services/networking/mtr-exporter.nix index 2b96cb2491acda..e7c8bea4499bab 100644 --- a/nixos/modules/services/networking/mtr-exporter.nix +++ b/nixos/modules/services/networking/mtr-exporter.nix @@ -1,21 +1,47 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) - maintainers types literalExpression - escapeShellArg escapeShellArgs - mkEnableOption mkOption mkRemovedOptionModule mkIf - mkPackageOption optionalString concatMapStrings concatStringsSep; + maintainers + types + literalExpression + escapeShellArg + escapeShellArgs + mkEnableOption + mkOption + mkRemovedOptionModule + mkIf + mkPackageOption + optionalString + concatMapStrings + concatStringsSep + ; cfg = config.services.mtr-exporter; - jobsConfig = pkgs.writeText "mtr-exporter.conf" (concatMapStrings (job: '' - ${job.name} -- ${job.schedule} -- ${concatStringsSep " " job.flags} ${job.address} - '') cfg.jobs); -in { + jobsConfig = pkgs.writeText "mtr-exporter.conf" ( + concatMapStrings (job: '' + ${job.name} -- ${job.schedule} -- ${concatStringsSep " " job.flags} ${job.address} + '') cfg.jobs + ); +in +{ imports = [ - (mkRemovedOptionModule [ "services" "mtr-exporter" "target" ] "Use services.mtr-exporter.jobs instead.") - (mkRemovedOptionModule [ "services" "mtr-exporter" "mtrFlags" ] "Use services.mtr-exporter.jobs..flags instead.") + (mkRemovedOptionModule [ + "services" + "mtr-exporter" + "target" + ] "Use services.mtr-exporter.jobs instead.") + (mkRemovedOptionModule [ + "services" + "mtr-exporter" + "mtrFlags" + ] "Use services.mtr-exporter.jobs..flags instead.") ]; options = { @@ -37,8 +63,8 @@ in { extraFlags = mkOption { type = types.listOf types.str; - default = []; - example = ["-flag.deprecatedMetrics"]; + default = [ ]; + example = [ "-flag.deprecatedMetrics" ]; description = '' Extra command line options to pass to MTR exporter. ''; @@ -50,34 +76,36 @@ in { jobs = mkOption { description = "List of MTR jobs. Will be added to /etc/mtr-exporter.conf"; - type = types.nonEmptyListOf (types.submodule { - options = { - name = mkOption { - type = types.str; - description = "Name of ICMP pinging job."; + type = types.nonEmptyListOf ( + types.submodule { + options = { + name = mkOption { + type = types.str; + description = "Name of ICMP pinging job."; + }; + + address = mkOption { + type = types.str; + example = "host.example.org:1234"; + description = "Target address for MTR client."; + }; + + schedule = mkOption { + type = types.str; + default = "@every 60s"; + example = "@hourly"; + description = "Schedule of MTR checks. Also accepts Cron format."; + }; + + flags = mkOption { + type = with types; listOf str; + default = [ ]; + example = [ "-G1" ]; + description = "Additional flags to pass to MTR."; + }; }; - - address = mkOption { - type = types.str; - example = "host.example.org:1234"; - description = "Target address for MTR client."; - }; - - schedule = mkOption { - type = types.str; - default = "@every 60s"; - example = "@hourly"; - description = "Schedule of MTR checks. Also accepts Cron format."; - }; - - flags = mkOption { - type = with types; listOf str; - default = []; - example = ["-G1"]; - description = "Additional flags to pass to MTR."; - }; - }; - }); + } + ); }; }; }; diff --git a/nixos/modules/services/networking/multipath.nix b/nixos/modules/services/networking/multipath.nix index 85cc11a3168347..5fef5725f9e001 100644 --- a/nixos/modules/services/networking/multipath.nix +++ b/nixos/modules/services/networking/multipath.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, ... }: with lib; +{ + config, + lib, + pkgs, + ... +}: +with lib; # See http://christophe.varoqui.free.fr/usage.html and # https://github.com/opensvc/multipath-tools/blob/master/multipath/multipath.conf.5 @@ -6,19 +12,21 @@ let cfg = config.services.multipath; - indentLines = n: str: concatStringsSep "\n" ( - map (line: "${fixedWidthString n " " " "}${line}") ( - filter ( x: x != "" ) ( splitString "\n" str ) - ) - ); + indentLines = + n: str: + concatStringsSep "\n" ( + map (line: "${fixedWidthString n " " " "}${line}") (filter (x: x != "") (splitString "\n" str)) + ); - addCheckDesc = desc: elemType: check: types.addCheck elemType check - // { description = "${elemType.description} (with check: ${desc})"; }; + addCheckDesc = + desc: elemType: check: + types.addCheck elemType check // { description = "${elemType.description} (with check: ${desc})"; }; hexChars = stringToCharacters "0123456789abcdef"; isHexString = s: all (c: elem c hexChars) (stringToCharacters (toLower s)); hexStr = addCheckDesc "hexadecimal string" types.str isHexString; -in { +in +{ options.services.multipath = with types; { @@ -83,14 +91,26 @@ in { }; hardware_handler = mkOption { - type = nullOr (enum [ "emc" "rdac" "hp_sw" "alua" "ana" ]); + type = nullOr (enum [ + "emc" + "rdac" + "hp_sw" + "alua" + "ana" + ]); default = null; description = "The hardware handler to use for this device type"; }; # Optional arguments path_grouping_policy = mkOption { - type = nullOr (enum [ "failover" "multibus" "group_by_serial" "group_by_prio" "group_by_node_name" ]); + type = nullOr (enum [ + "failover" + "multibus" + "group_by_serial" + "group_by_prio" + "group_by_node_name" + ]); default = null; # real default: "failover" description = "The default path grouping policy to apply to unspecified multipaths"; }; @@ -122,15 +142,37 @@ in { }; path_checker = mkOption { - type = enum [ "readsector0" "tur" "emc_clariion" "hp_sw" "rdac" "directio" "cciss_tur" "none" ]; + type = enum [ + "readsector0" + "tur" + "emc_clariion" + "hp_sw" + "rdac" + "directio" + "cciss_tur" + "none" + ]; default = "tur"; description = "The default method used to determine the paths state"; }; prio = mkOption { type = nullOr (enum [ - "none" "const" "sysfs" "emc" "alua" "ontap" "rdac" "hp_sw" "hds" - "random" "weightedpath" "path_latency" "ana" "datacore" "iet" + "none" + "const" + "sysfs" + "emc" + "alua" + "ontap" + "rdac" + "hp_sw" + "hds" + "random" + "weightedpath" + "path_latency" + "ana" + "datacore" + "iet" ]); default = null; # real default: "const" description = "The name of the path priority routine"; @@ -155,7 +197,10 @@ in { }; rr_weight = mkOption { - type = nullOr (enum [ "priorities" "uniform" ]); + type = nullOr (enum [ + "priorities" + "uniform" + ]); default = null; # real default: "uniform" description = '' If set to priorities the multipath configurator will assign path weights @@ -217,7 +262,10 @@ in { }; flush_on_last_del = mkOption { - type = nullOr (enum [ "yes" "no" ]); + type = nullOr (enum [ + "yes" + "no" + ]); default = null; # real default: "no" description = '' If set to "yes" multipathd will disable queueing when the last path to a @@ -226,7 +274,10 @@ in { }; user_friendly_names = mkOption { - type = nullOr (enum [ "yes" "no" ]); + type = nullOr (enum [ + "yes" + "no" + ]); default = null; # real default: "no" description = '' If set to "yes", using the bindings file /etc/multipath/bindings @@ -238,7 +289,10 @@ in { }; detect_prio = mkOption { - type = nullOr (enum [ "yes" "no" ]); + type = nullOr (enum [ + "yes" + "no" + ]); default = null; # real default: "yes" description = '' If set to "yes", multipath will try to detect if the device supports @@ -250,7 +304,10 @@ in { }; detect_checker = mkOption { - type = nullOr (enum [ "yes" "no" ]); + type = nullOr (enum [ + "yes" + "no" + ]); default = null; # real default: "yes" description = '' If set to "yes", multipath will try to detect if the device supports @@ -260,7 +317,10 @@ in { }; deferred_remove = mkOption { - type = nullOr (enum [ "yes" "no" ]); + type = nullOr (enum [ + "yes" + "no" + ]); default = null; # real default: "no" description = '' If set to "yes", multipathd will do a deferred remove instead of a @@ -345,7 +405,10 @@ in { }; skip_kpartx = mkOption { - type = nullOr (enum [ "yes" "no" ]); + type = nullOr (enum [ + "yes" + "no" + ]); default = null; # real default: "no" description = "If set to yes, kpartx will not automatically create partitions on the device"; }; @@ -483,16 +546,24 @@ in { config = mkIf cfg.enable { environment.etc."multipath.conf".text = let - inherit (cfg) defaults blacklist blacklist_exceptions overrides; - - mkDeviceBlock = cfg: let - nonNullCfg = lib.filterAttrs (k: v: v != null) cfg; - attrs = lib.mapAttrsToList (name: value: " ${name} ${toString value}") nonNullCfg; - in '' - device { - ${lib.concatStringsSep "\n" attrs} - } - ''; + inherit (cfg) + defaults + blacklist + blacklist_exceptions + overrides + ; + + mkDeviceBlock = + cfg: + let + nonNullCfg = lib.filterAttrs (k: v: v != null) cfg; + attrs = lib.mapAttrsToList (name: value: " ${name} ${toString value}") nonNullCfg; + in + '' + device { + ${lib.concatStringsSep "\n" attrs} + } + ''; devices = lib.concatMapStringsSep "\n" mkDeviceBlock cfg.devices; mkMultipathBlock = m: '' @@ -503,7 +574,8 @@ in { ''; multipaths = lib.concatMapStringsSep "\n" mkMultipathBlock cfg.pathGroups; - in '' + in + '' devices { ${indentLines 2 devices} } @@ -536,13 +608,19 @@ in { systemd.packages = [ cfg.package ]; environment.systemPackages = [ cfg.package ]; - boot.kernelModules = [ "dm-multipath" "dm-service-time" ]; + boot.kernelModules = [ + "dm-multipath" + "dm-service-time" + ]; # We do not have systemd in stage-1 boot so must invoke `multipathd` # with the `-1` argument which disables systemd calls. Invoke `multipath` # to display the multipath mappings in the output of `journalctl -b`. # TODO: Implement for systemd stage 1 - boot.initrd.kernelModules = [ "dm-multipath" "dm-service-time" ]; + boot.initrd.kernelModules = [ + "dm-multipath" + "dm-service-time" + ]; boot.initrd.postDeviceCommands = mkIf (!config.boot.initrd.systemd.enable) '' modprobe -a dm-multipath dm-service-time multipathd -s diff --git a/nixos/modules/services/networking/mycelium.nix b/nixos/modules/services/networking/mycelium.nix index 0d0b2945af4c12..26c9be290fed50 100644 --- a/nixos/modules/services/networking/mycelium.nix +++ b/nixos/modules/services/networking/mycelium.nix @@ -1,4 +1,10 @@ -{ config, pkgs, lib, utils, ... }: +{ + config, + pkgs, + lib, + utils, + ... +}: let cfg = config.services.mycelium; @@ -58,7 +64,10 @@ in }; config = lib.mkIf cfg.enable { networking.firewall.allowedTCPPorts = lib.optionals cfg.openFirewall [ 9651 ]; - networking.firewall.allowedUDPPorts = lib.optionals cfg.openFirewall [ 9650 9651 ]; + networking.firewall.allowedUDPPorts = lib.optionals cfg.openFirewall [ + 9650 + 9651 + ]; environment.systemPackages = [ cfg.package ]; @@ -89,49 +98,57 @@ in RestrictNamespaces = true; RestrictRealtime = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged @keyring" ]; - ExecStart = lib.concatStringsSep " " ([ - (lib.getExe cfg.package) - (if (cfg.keyFile != null) then - "--key-file \${CREDENTIALS_DIRECTORY}/keyfile" else - "--key-file %S/mycelium/key.bin" - ) - "--tun-name" - "mycelium" - "${utils.escapeSystemdExecArgs cfg.extraArgs}" - ] ++ - (lib.optional (cfg.addHostedPublicNodes || cfg.peers != [ ]) "--peers") - ++ cfg.peers ++ (lib.optionals cfg.addHostedPublicNodes [ - "tcp://188.40.132.242:9651" # DE 01 - "tcp://[2a01:4f8:221:1e0b::2]:9651" - "quic://188.40.132.242:9651" - "quic://[2a01:4f8:221:1e0b::2]:9651" + SystemCallFilter = [ + "@system-service" + "~@privileged @keyring" + ]; + ExecStart = lib.concatStringsSep " " ( + [ + (lib.getExe cfg.package) + ( + if (cfg.keyFile != null) then + "--key-file \${CREDENTIALS_DIRECTORY}/keyfile" + else + "--key-file %S/mycelium/key.bin" + ) + "--tun-name" + "mycelium" + "${utils.escapeSystemdExecArgs cfg.extraArgs}" + ] + ++ (lib.optional (cfg.addHostedPublicNodes || cfg.peers != [ ]) "--peers") + ++ cfg.peers + ++ (lib.optionals cfg.addHostedPublicNodes [ + "tcp://188.40.132.242:9651" # DE 01 + "tcp://[2a01:4f8:221:1e0b::2]:9651" + "quic://188.40.132.242:9651" + "quic://[2a01:4f8:221:1e0b::2]:9651" - "tcp://136.243.47.186:9651" # DE 02 - "tcp://[2a01:4f8:212:fa6::2]:9651" - "quic://136.243.47.186:9651" - "quic://[2a01:4f8:212:fa6::2]:9651" + "tcp://136.243.47.186:9651" # DE 02 + "tcp://[2a01:4f8:212:fa6::2]:9651" + "quic://136.243.47.186:9651" + "quic://[2a01:4f8:212:fa6::2]:9651" - "tcp://185.69.166.7:9651" # BE 03 - "tcp://[2a02:1802:5e:0:8478:51ff:fee2:3331]:9651" - "quic://185.69.166.7:9651" - "quic://[2a02:1802:5e:0:8478:51ff:fee2:3331]:9651" + "tcp://185.69.166.7:9651" # BE 03 + "tcp://[2a02:1802:5e:0:8478:51ff:fee2:3331]:9651" + "quic://185.69.166.7:9651" + "quic://[2a02:1802:5e:0:8478:51ff:fee2:3331]:9651" - "tcp://185.69.166.8:9651" # BE 04 - "tcp://[2a02:1802:5e:0:8c9e:7dff:fec9:f0d2]:9651" - "quic://185.69.166.8:9651" - "quic://[2a02:1802:5e:0:8c9e:7dff:fec9:f0d2]:9651" + "tcp://185.69.166.8:9651" # BE 04 + "tcp://[2a02:1802:5e:0:8c9e:7dff:fec9:f0d2]:9651" + "quic://185.69.166.8:9651" + "quic://[2a02:1802:5e:0:8c9e:7dff:fec9:f0d2]:9651" - "tcp://65.21.231.58:9651" # FI 05 - "tcp://[2a01:4f9:6a:1dc5::2]:9651" - "quic://65.21.231.58:9651" - "quic://[2a01:4f9:6a:1dc5::2]:9651" + "tcp://65.21.231.58:9651" # FI 05 + "tcp://[2a01:4f9:6a:1dc5::2]:9651" + "quic://65.21.231.58:9651" + "quic://[2a01:4f9:6a:1dc5::2]:9651" - "tcp://65.109.18.113:9651" # FI 06 - "tcp://[2a01:4f9:5a:1042::2]:9651" - "quic://65.109.18.113:9651" - "quic://[2a01:4f9:5a:1042::2]:9651" - ])); + "tcp://65.109.18.113:9651" # FI 06 + "tcp://[2a01:4f9:5a:1042::2]:9651" + "quic://65.109.18.113:9651" + "quic://[2a01:4f9:5a:1042::2]:9651" + ]) + ); Restart = "always"; RestartSec = 5; TimeoutStopSec = 5; @@ -139,6 +156,9 @@ in }; }; meta = { - maintainers = with lib.maintainers; [ flokli lassulus ]; + maintainers = with lib.maintainers; [ + flokli + lassulus + ]; }; } diff --git a/nixos/modules/services/networking/namecoind.nix b/nixos/modules/services/networking/namecoind.nix index 8f7a5123f7e18e..77de4fa6cb6f1c 100644 --- a/nixos/modules/services/networking/namecoind.nix +++ b/nixos/modules/services/networking/namecoind.nix @@ -1,38 +1,45 @@ - -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let - cfg = config.services.namecoind; + cfg = config.services.namecoind; dataDir = "/var/lib/namecoind"; - useSSL = (cfg.rpc.certificate != null) && (cfg.rpc.key != null); - useRPC = (cfg.rpc.user != null) && (cfg.rpc.password != null); - - listToConf = option: list: - concatMapStrings (value :"${option}=${value}\n") list; - - configFile = pkgs.writeText "namecoin.conf" ('' - server=1 - daemon=0 - txindex=1 - txprevcache=1 - walletpath=${cfg.wallet} - gen=${if cfg.generate then "1" else "0"} - ${listToConf "addnode" cfg.extraNodes} - ${listToConf "connect" cfg.trustedNodes} - '' + optionalString useRPC '' - rpcbind=${cfg.rpc.address} - rpcport=${toString cfg.rpc.port} - rpcuser=${cfg.rpc.user} - rpcpassword=${cfg.rpc.password} - ${listToConf "rpcallowip" cfg.rpc.allowFrom} - '' + optionalString useSSL '' - rpcssl=1 - rpcsslcertificatechainfile=${cfg.rpc.certificate} - rpcsslprivatekeyfile=${cfg.rpc.key} - rpcsslciphers=TLSv1.2+HIGH:TLSv1+HIGH:!SSLv2:!aNULL:!eNULL:!3DES:@STRENGTH - ''); + useSSL = (cfg.rpc.certificate != null) && (cfg.rpc.key != null); + useRPC = (cfg.rpc.user != null) && (cfg.rpc.password != null); + + listToConf = option: list: concatMapStrings (value: "${option}=${value}\n") list; + + configFile = pkgs.writeText "namecoin.conf" ( + '' + server=1 + daemon=0 + txindex=1 + txprevcache=1 + walletpath=${cfg.wallet} + gen=${if cfg.generate then "1" else "0"} + ${listToConf "addnode" cfg.extraNodes} + ${listToConf "connect" cfg.trustedNodes} + '' + + optionalString useRPC '' + rpcbind=${cfg.rpc.address} + rpcport=${toString cfg.rpc.port} + rpcuser=${cfg.rpc.user} + rpcpassword=${cfg.rpc.password} + ${listToConf "rpcallowip" cfg.rpc.allowFrom} + '' + + optionalString useSSL '' + rpcssl=1 + rpcsslcertificatechainfile=${cfg.rpc.certificate} + rpcsslprivatekeyfile=${cfg.rpc.key} + rpcsslciphers=TLSv1.2+HIGH:TLSv1+HIGH:!SSLv2:!aNULL:!eNULL:!3DES:@STRENGTH + '' + ); in @@ -130,7 +137,6 @@ in ''; }; - rpc.allowFrom = mkOption { type = types.listOf types.str; default = [ "127.0.0.1" ]; @@ -144,43 +150,42 @@ in }; - ###### implementation config = mkIf cfg.enable { users.users.namecoin = { - uid = config.ids.uids.namecoin; + uid = config.ids.uids.namecoin; description = "Namecoin daemon user"; home = dataDir; createHome = true; }; users.groups.namecoin = { - gid = config.ids.gids.namecoin; + gid = config.ids.gids.namecoin; }; systemd.services.namecoind = { description = "Namecoind daemon"; - after = [ "network.target" ]; + after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; startLimitIntervalSec = 120; startLimitBurst = 5; serviceConfig = { - User = "namecoin"; + User = "namecoin"; Group = "namecoin"; - ExecStart = "${pkgs.namecoind}/bin/namecoind -conf=${configFile} -datadir=${dataDir} -printtoconsole"; - ExecStop = "${pkgs.coreutils}/bin/kill -KILL $MAINPID"; + ExecStart = "${pkgs.namecoind}/bin/namecoind -conf=${configFile} -datadir=${dataDir} -printtoconsole"; + ExecStop = "${pkgs.coreutils}/bin/kill -KILL $MAINPID"; ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; Nice = "10"; PrivateTmp = true; - TimeoutStopSec = "60s"; - TimeoutStartSec = "2s"; - Restart = "always"; + TimeoutStopSec = "60s"; + TimeoutStartSec = "2s"; + Restart = "always"; }; - preStart = optionalString (cfg.wallet != "${dataDir}/wallet.dat") '' + preStart = optionalString (cfg.wallet != "${dataDir}/wallet.dat") '' # check wallet file permissions if [ "$(stat --printf '%u' ${cfg.wallet})" != "${toString config.ids.uids.namecoin}" \ -o "$(stat --printf '%g' ${cfg.wallet})" != "${toString config.ids.gids.namecoin}" \ diff --git a/nixos/modules/services/networking/nar-serve.nix b/nixos/modules/services/networking/nar-serve.nix index ea5be25a4d26b2..9982e75e68a7d7 100644 --- a/nixos/modules/services/networking/nar-serve.nix +++ b/nixos/modules/services/networking/nar-serve.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let inherit (lib) mkOption types; @@ -6,7 +11,10 @@ let in { meta = { - maintainers = with lib.maintainers; [ rizary zimbatm ]; + maintainers = with lib.maintainers; [ + rizary + zimbatm + ]; }; options = { services.nar-serve = { diff --git a/nixos/modules/services/networking/nat-iptables.nix b/nixos/modules/services/networking/nat-iptables.nix index 4a4d1f2a258db1..804dc0e0340c0e 100644 --- a/nixos/modules/services/networking/nat-iptables.nix +++ b/nixos/modules/services/networking/nat-iptables.nix @@ -2,17 +2,20 @@ # XXX: todo: support multiple upstream links # see http://yesican.chsoft.biz/lartc/MultihomedLinuxNetworking.html -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.networking.nat; - mkDest = externalIP: - if externalIP == null - then "-j MASQUERADE" - else "-j SNAT --to-source ${externalIP}"; + mkDest = + externalIP: if externalIP == null then "-j MASQUERADE" else "-j SNAT --to-source ${externalIP}"; dest = mkDest cfg.externalIP; destIPv6 = mkDest cfg.externalIPv6; @@ -39,87 +42,110 @@ let ${cfg.extraStopCommands} ''; - mkSetupNat = { iptables, dest, internalIPs, forwardPorts, externalIp }: '' - # We can't match on incoming interface in POSTROUTING, so - # mark packets coming from the internal interfaces. - ${concatMapStrings (iface: '' - ${iptables} -w -t nat -A nixos-nat-pre \ - -i '${iface}' -j MARK --set-mark 1 - ${iptables} -w -t filter -A nixos-filter-forward \ - -i '${iface}' ${optionalString (cfg.externalInterface != null) "-o ${cfg.externalInterface}"} -j ACCEPT - '') cfg.internalInterfaces} - - # NAT the marked packets. - ${optionalString (cfg.internalInterfaces != []) '' - ${iptables} -w -t nat -A nixos-nat-post -m mark --mark 1 \ - ${optionalString (cfg.externalInterface != null) "-o ${cfg.externalInterface}"} ${dest} - ''} - - # NAT packets coming from the internal IPs. - ${concatMapStrings (range: '' - ${iptables} -w -t nat -A nixos-nat-post \ - -s '${range}' ${optionalString (cfg.externalInterface != null) "-o ${cfg.externalInterface}"} ${dest} + mkSetupNat = + { + iptables, + dest, + internalIPs, + forwardPorts, + externalIp, + }: + '' + # We can't match on incoming interface in POSTROUTING, so + # mark packets coming from the internal interfaces. + ${concatMapStrings (iface: '' + ${iptables} -w -t nat -A nixos-nat-pre \ + -i '${iface}' -j MARK --set-mark 1 + ${iptables} -w -t filter -A nixos-filter-forward \ + -i '${iface}' ${ + optionalString (cfg.externalInterface != null) "-o ${cfg.externalInterface}" + } -j ACCEPT + '') cfg.internalInterfaces} + + # NAT the marked packets. + ${optionalString (cfg.internalInterfaces != [ ]) '' + ${iptables} -w -t nat -A nixos-nat-post -m mark --mark 1 \ + ${optionalString (cfg.externalInterface != null) "-o ${cfg.externalInterface}"} ${dest} + ''} + + # NAT packets coming from the internal IPs. + ${concatMapStrings (range: '' + ${iptables} -w -t nat -A nixos-nat-post \ + -s '${range}' ${ + optionalString (cfg.externalInterface != null) "-o ${cfg.externalInterface}" + } ${dest} + ${iptables} -w -t filter -A nixos-filter-forward \ + -s '${range}' ${ + optionalString (cfg.externalInterface != null) "-o ${cfg.externalInterface}" + } -j ACCEPT + '') internalIPs} + + # Related connections are allowed ${iptables} -w -t filter -A nixos-filter-forward \ - -s '${range}' ${optionalString (cfg.externalInterface != null) "-o ${cfg.externalInterface}"} -j ACCEPT - '') internalIPs} - - # Related connections are allowed - ${iptables} -w -t filter -A nixos-filter-forward \ - -m state --state ESTABLISHED,RELATED -j ACCEPT - - # NAT from external ports to internal ports. - ${concatMapStrings (fwd: '' - ${iptables} -w -t nat -A nixos-nat-pre \ - -i ${toString cfg.externalInterface} -p ${fwd.proto} \ - ${optionalString (externalIp != null) "-d ${externalIp}"} --dport ${builtins.toString fwd.sourcePort} \ - -j DNAT --to-destination ${fwd.destination} - ${iptables} -w -t filter -A nixos-filter-forward \ - -i ${toString cfg.externalInterface} -p ${fwd.proto} \ - --dport ${builtins.toString fwd.sourcePort} -j ACCEPT - - ${concatMapStrings (loopbackip: - let - matchIP = if isIPv6 fwd.destination then "[[]([0-9a-fA-F:]+)[]]" else "([0-9.]+)"; - m = builtins.match "${matchIP}:([0-9-]+)" fwd.destination; - destinationIP = if m == null then throw "bad ip:ports `${fwd.destination}'" else elemAt m 0; - destinationPorts = if m == null then throw "bad ip:ports `${fwd.destination}'" else builtins.replaceStrings ["-"] [":"] (elemAt m 1); - in '' - # Allow connections to ${loopbackip}:${toString fwd.sourcePort} from the host itself - ${iptables} -w -t nat -A nixos-nat-out \ - -d ${loopbackip} -p ${fwd.proto} \ - --dport ${builtins.toString fwd.sourcePort} \ - -j DNAT --to-destination ${fwd.destination} - - # Allow connections to ${loopbackip}:${toString fwd.sourcePort} from other hosts behind NAT - ${concatMapStrings (range: '' - ${iptables} -w -t nat -A nixos-nat-pre \ - -d ${loopbackip} -p ${fwd.proto} -s '${range}' \ - --dport ${builtins.toString fwd.sourcePort} \ - -j DNAT --to-destination ${fwd.destination} - ${iptables} -w -t nat -A nixos-nat-post \ - -d ${destinationIP} -p ${fwd.proto} \ - -s '${range}' --dport ${destinationPorts} \ - -j SNAT --to-source ${loopbackip} - ${iptables} -w -t filter -A nixos-filter-forward \ - -d ${destinationIP} -p ${fwd.proto} \ - -s '${range}' --dport ${destinationPorts} -j ACCEPT - '') internalIPs} - ${concatMapStrings (iface: '' - ${iptables} -w -t nat -A nixos-nat-pre \ - -d ${loopbackip} -p ${fwd.proto} -i '${iface}' \ + -m state --state ESTABLISHED,RELATED -j ACCEPT + + # NAT from external ports to internal ports. + ${concatMapStrings (fwd: '' + ${iptables} -w -t nat -A nixos-nat-pre \ + -i ${toString cfg.externalInterface} -p ${fwd.proto} \ + ${ + optionalString (externalIp != null) "-d ${externalIp}" + } --dport ${builtins.toString fwd.sourcePort} \ + -j DNAT --to-destination ${fwd.destination} + ${iptables} -w -t filter -A nixos-filter-forward \ + -i ${toString cfg.externalInterface} -p ${fwd.proto} \ + --dport ${builtins.toString fwd.sourcePort} -j ACCEPT + + ${concatMapStrings ( + loopbackip: + let + matchIP = if isIPv6 fwd.destination then "[[]([0-9a-fA-F:]+)[]]" else "([0-9.]+)"; + m = builtins.match "${matchIP}:([0-9-]+)" fwd.destination; + destinationIP = if m == null then throw "bad ip:ports `${fwd.destination}'" else elemAt m 0; + destinationPorts = + if m == null then + throw "bad ip:ports `${fwd.destination}'" + else + builtins.replaceStrings [ "-" ] [ ":" ] (elemAt m 1); + in + '' + # Allow connections to ${loopbackip}:${toString fwd.sourcePort} from the host itself + ${iptables} -w -t nat -A nixos-nat-out \ + -d ${loopbackip} -p ${fwd.proto} \ --dport ${builtins.toString fwd.sourcePort} \ -j DNAT --to-destination ${fwd.destination} - ${iptables} -w -t nat -A nixos-nat-post \ - -d ${destinationIP} -p ${fwd.proto} \ - -i '${iface}' --dport ${destinationPorts} \ - -j SNAT --to-source ${loopbackip} - ${iptables} -w -t filter -A nixos-filter-forward \ - -d ${destinationIP} -p ${fwd.proto} \ - -i '${iface}' --dport ${destinationPorts} -j ACCEPT - '') cfg.internalInterfaces} - '') fwd.loopbackIPs} - '') forwardPorts} - ''; + + # Allow connections to ${loopbackip}:${toString fwd.sourcePort} from other hosts behind NAT + ${concatMapStrings (range: '' + ${iptables} -w -t nat -A nixos-nat-pre \ + -d ${loopbackip} -p ${fwd.proto} -s '${range}' \ + --dport ${builtins.toString fwd.sourcePort} \ + -j DNAT --to-destination ${fwd.destination} + ${iptables} -w -t nat -A nixos-nat-post \ + -d ${destinationIP} -p ${fwd.proto} \ + -s '${range}' --dport ${destinationPorts} \ + -j SNAT --to-source ${loopbackip} + ${iptables} -w -t filter -A nixos-filter-forward \ + -d ${destinationIP} -p ${fwd.proto} \ + -s '${range}' --dport ${destinationPorts} -j ACCEPT + '') internalIPs} + ${concatMapStrings (iface: '' + ${iptables} -w -t nat -A nixos-nat-pre \ + -d ${loopbackip} -p ${fwd.proto} -i '${iface}' \ + --dport ${builtins.toString fwd.sourcePort} \ + -j DNAT --to-destination ${fwd.destination} + ${iptables} -w -t nat -A nixos-nat-post \ + -d ${destinationIP} -p ${fwd.proto} \ + -i '${iface}' --dport ${destinationPorts} \ + -j SNAT --to-source ${loopbackip} + ${iptables} -w -t filter -A nixos-filter-forward \ + -d ${destinationIP} -p ${fwd.proto} \ + -i '${iface}' --dport ${destinationPorts} -j ACCEPT + '') cfg.internalInterfaces} + '' + ) fwd.loopbackIPs} + '') forwardPorts} + ''; setupNat = '' ${helpers} @@ -192,35 +218,36 @@ in }; + config = mkIf (!config.networking.nftables.enable) (mkMerge [ + ({ networking.firewall.extraCommands = mkBefore flushNat; }) + (mkIf config.networking.nat.enable { + + networking.firewall = mkIf config.networking.firewall.enable { + extraCommands = setupNat; + extraStopCommands = flushNat; + }; + + systemd.services = mkIf (!config.networking.firewall.enable) { + nat = { + description = "Network Address Translation"; + wantedBy = [ "network.target" ]; + after = [ + "network-pre.target" + "systemd-modules-load.service" + ]; + path = [ config.networking.firewall.package ]; + unitConfig.ConditionCapability = "CAP_NET_ADMIN"; + + serviceConfig = { + Type = "oneshot"; + RemainAfterExit = true; + }; - config = mkIf (!config.networking.nftables.enable) - (mkMerge [ - ({ networking.firewall.extraCommands = mkBefore flushNat; }) - (mkIf config.networking.nat.enable { - - networking.firewall = mkIf config.networking.firewall.enable { - extraCommands = setupNat; - extraStopCommands = flushNat; - }; - - systemd.services = mkIf (!config.networking.firewall.enable) { - nat = { - description = "Network Address Translation"; - wantedBy = [ "network.target" ]; - after = [ "network-pre.target" "systemd-modules-load.service" ]; - path = [ config.networking.firewall.package ]; - unitConfig.ConditionCapability = "CAP_NET_ADMIN"; - - serviceConfig = { - Type = "oneshot"; - RemainAfterExit = true; - }; - - script = flushNat + setupNat; + script = flushNat + setupNat; - postStop = flushNat; - }; + postStop = flushNat; }; - }) - ]); + }; + }) + ]); } diff --git a/nixos/modules/services/networking/nat-nftables.nix b/nixos/modules/services/networking/nat-nftables.nix index 951b14cec79126..891559071c9e8a 100644 --- a/nixos/modules/services/networking/nat-nftables.nix +++ b/nixos/modules/services/networking/nat-nftables.nix @@ -5,10 +5,7 @@ with lib; let cfg = config.networking.nat; - mkDest = externalIP: - if externalIP == null - then "masquerade" - else "snat ${externalIP}"; + mkDest = externalIP: if externalIP == null then "masquerade" else "snat ${externalIP}"; dest = mkDest cfg.externalIP; destIPv6 = mkDest cfg.externalIPv6; @@ -23,7 +20,8 @@ let # Whether given IP (plus optional port) is an IPv6. isIPv6 = ip: length (lib.splitString ":" ip) > 2; - splitIPPorts = IPPorts: + splitIPPorts = + IPPorts: let matchIP = if isIPv6 IPPorts then "[[]([0-9a-fA-F:]+)[]]" else "([0-9.]+)"; m = builtins.match "${matchIP}:([0-9-]+)" IPPorts; @@ -33,43 +31,55 @@ let ports = if m == null then throw "bad ip:ports `${IPPorts}'" else elemAt m 1; }; - mkTable = { ipVer, dest, ipSet, forwardPorts, dmzHost, externalIP }: + mkTable = + { + ipVer, + dest, + ipSet, + forwardPorts, + dmzHost, + externalIP, + }: let # nftables maps for port forward # [daddr .] l4proto . dport : addr . port - fwdMap = toNftSet (map - (fwd: + fwdMap = toNftSet ( + map ( + fwd: with (splitIPPorts fwd.destination); - "${optionalString (externalIP != null) "${externalIP} . "}${fwd.proto} . ${toNftRange fwd.sourcePort} : ${IP} . ${ports}" - ) - forwardPorts); + "${ + optionalString (externalIP != null) "${externalIP} . " + }${fwd.proto} . ${toNftRange fwd.sourcePort} : ${IP} . ${ports}" + ) forwardPorts + ); # nftables maps for port forward loopback dnat # daddr . l4proto . dport : addr . port - fwdLoopDnatMap = toNftSet (concatMap - (fwd: map - (loopbackip: + fwdLoopDnatMap = toNftSet ( + concatMap ( + fwd: + map ( + loopbackip: with (splitIPPorts fwd.destination); "${loopbackip} . ${fwd.proto} . ${toNftRange fwd.sourcePort} : ${IP} . ${ports}" - ) - fwd.loopbackIPs) - forwardPorts); + ) fwd.loopbackIPs + ) forwardPorts + ); # nftables set for port forward loopback snat # daddr . l4proto . dport - fwdLoopSnatSet = toNftSet (map - (fwd: - with (splitIPPorts fwd.destination); - "${IP} . ${fwd.proto} . ${ports}" - ) - forwardPorts); + fwdLoopSnatSet = toNftSet ( + map (fwd: with (splitIPPorts fwd.destination); "${IP} . ${fwd.proto} . ${ports}") forwardPorts + ); in '' chain pre { type nat hook prerouting priority dstnat; ${optionalString (fwdMap != "") '' - iifname "${cfg.externalInterface}" meta l4proto { tcp, udp } dnat ${optionalString (externalIP != null) "${ipVer} daddr . "}meta l4proto . th dport map { ${fwdMap} } comment "port forward" + iifname "${cfg.externalInterface}" meta l4proto { tcp, udp } dnat ${ + optionalString (externalIP != null) "${ipVer} daddr . " + }meta l4proto . th dport map { ${fwdMap} } comment "port forward" ''} ${optionalString (fwdLoopDnatMap != "") '' diff --git a/nixos/modules/services/networking/nat.nix b/nixos/modules/services/networking/nat.nix index 8cd2464d335804..71a719d6d8db8e 100644 --- a/nixos/modules/services/networking/nat.nix +++ b/nixos/modules/services/networking/nat.nix @@ -2,7 +2,12 @@ # XXX: todo: support multiple upstream links # see http://yesican.chsoft.biz/lartc/MultihomedLinuxNetworking.html -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -104,39 +109,49 @@ in }; networking.nat.forwardPorts = mkOption { - type = with types; listOf (submodule { - options = { - sourcePort = mkOption { - type = types.either types.int (types.strMatching "[[:digit:]]+:[[:digit:]]+"); - example = 8080; - description = "Source port of the external interface; to specify a port range, use a string with a colon (e.g. \"60000:61000\")"; - }; - - destination = mkOption { - type = types.str; - example = "10.0.0.1:80"; - description = "Forward connection to destination ip:port (or [ipv6]:port); to specify a port range, use ip:start-end"; - }; - - proto = mkOption { - type = types.str; - default = "tcp"; - example = "udp"; - description = "Protocol of forwarded connection"; + type = + with types; + listOf (submodule { + options = { + sourcePort = mkOption { + type = types.either types.int (types.strMatching "[[:digit:]]+:[[:digit:]]+"); + example = 8080; + description = "Source port of the external interface; to specify a port range, use a string with a colon (e.g. \"60000:61000\")"; + }; + + destination = mkOption { + type = types.str; + example = "10.0.0.1:80"; + description = "Forward connection to destination ip:port (or [ipv6]:port); to specify a port range, use ip:start-end"; + }; + + proto = mkOption { + type = types.str; + default = "tcp"; + example = "udp"; + description = "Protocol of forwarded connection"; + }; + + loopbackIPs = mkOption { + type = types.listOf types.str; + default = [ ]; + example = literalExpression ''[ "55.1.2.3" ]''; + description = "Public IPs for NAT reflection; for connections to `loopbackip:sourcePort` from the host itself and from other hosts behind NAT"; + }; }; - - loopbackIPs = mkOption { - type = types.listOf types.str; - default = [ ]; - example = literalExpression ''[ "55.1.2.3" ]''; - description = "Public IPs for NAT reflection; for connections to `loopbackip:sourcePort` from the host itself and from other hosts behind NAT"; - }; - }; - }); + }); default = [ ]; example = [ - { sourcePort = 8080; destination = "10.0.0.1:80"; proto = "tcp"; } - { sourcePort = 8080; destination = "[fc00::2]:80"; proto = "tcp"; } + { + sourcePort = 8080; + destination = "10.0.0.1:80"; + proto = "tcp"; + } + { + sourcePort = 8080; + destination = "[fc00::2]:80"; + proto = "tcp"; + } ]; description = '' List of forwarded ports from the external interface to @@ -157,7 +172,6 @@ in }; - config = mkIf config.networking.nat.enable { assertions = [ @@ -182,19 +196,21 @@ in boot = { kernelModules = [ "nf_nat_ftp" ]; - kernel.sysctl = { - "net.ipv4.conf.all.forwarding" = mkOverride 99 true; - "net.ipv4.conf.default.forwarding" = mkOverride 99 true; - } // optionalAttrs cfg.enableIPv6 { - # Do not prevent IPv6 autoconfiguration. - # See . - "net.ipv6.conf.all.accept_ra" = mkOverride 99 2; - "net.ipv6.conf.default.accept_ra" = mkOverride 99 2; - - # Forward IPv6 packets. - "net.ipv6.conf.all.forwarding" = mkOverride 99 true; - "net.ipv6.conf.default.forwarding" = mkOverride 99 true; - }; + kernel.sysctl = + { + "net.ipv4.conf.all.forwarding" = mkOverride 99 true; + "net.ipv4.conf.default.forwarding" = mkOverride 99 true; + } + // optionalAttrs cfg.enableIPv6 { + # Do not prevent IPv6 autoconfiguration. + # See . + "net.ipv6.conf.all.accept_ra" = mkOverride 99 2; + "net.ipv6.conf.default.accept_ra" = mkOverride 99 2; + + # Forward IPv6 packets. + "net.ipv6.conf.all.forwarding" = mkOverride 99 true; + "net.ipv6.conf.default.forwarding" = mkOverride 99 true; + }; }; }; diff --git a/nixos/modules/services/networking/nats.nix b/nixos/modules/services/networking/nats.nix index 4851daae4dbabc..0ab9d9f015c200 100644 --- a/nixos/modules/services/networking/nats.nix +++ b/nixos/modules/services/networking/nats.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -10,14 +15,18 @@ let configFile = format.generate "nats.conf" cfg.settings; - validateConfig = file: - pkgs.runCommand "validate-nats-conf" { - nativeBuildInputs = [ pkgs.nats-server ]; - } '' - nats-server --config "${configFile}" -t - ln -s "${configFile}" "$out" - ''; -in { + validateConfig = + file: + pkgs.runCommand "validate-nats-conf" + { + nativeBuildInputs = [ pkgs.nats-server ]; + } + '' + nats-server --config "${configFile}" -t + ln -s "${configFile}" "$out" + ''; +in +{ ### Interface @@ -140,11 +149,17 @@ in { ProtectSystem = "strict"; ReadOnlyPaths = [ ]; ReadWritePaths = [ cfg.dataDir ]; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; UMask = "0077"; } ]; diff --git a/nixos/modules/services/networking/nbd.nix b/nixos/modules/services/networking/nbd.nix index c2cf1612296ae7..1fcbc1969543fc 100644 --- a/nixos/modules/services/networking/nbd.nix +++ b/nixos/modules/services/networking/nbd.nix @@ -1,41 +1,72 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkIf mkOption types optionalAttrs; - inherit (lib.types) nullOr listOf str attrsOf submodule; + inherit (lib) + mkIf + mkOption + types + optionalAttrs + ; + inherit (lib.types) + nullOr + listOf + str + attrsOf + submodule + ; cfg = config.services.nbd; - iniFields = with types; attrsOf (oneOf [ bool int float str ]); + iniFields = + with types; + attrsOf (oneOf [ + bool + int + float + str + ]); # The `[generic]` section must come before all the others in the # config file. This means we can't just dump an attrset to INI # because that sorts the sections by name. Instead, we serialize it # on its own first. genericSection = { - generic = (cfg.server.extraOptions // { - user = "root"; - group = "root"; - port = cfg.server.listenPort; - } // (optionalAttrs (cfg.server.listenAddress != null) { - listenaddr = cfg.server.listenAddress; - })); + generic = ( + cfg.server.extraOptions + // { + user = "root"; + group = "root"; + port = cfg.server.listenPort; + } + // (optionalAttrs (cfg.server.listenAddress != null) { + listenaddr = cfg.server.listenAddress; + }) + ); }; - exportSections = - lib.mapAttrs - (_: { path, allowAddresses, extraOptions }: - extraOptions // { - exportname = path; - } // (optionalAttrs (allowAddresses != null) { - authfile = pkgs.writeText "authfile" (lib.concatStringsSep "\n" allowAddresses); - })) - cfg.server.exports; - serverConfig = - pkgs.writeText "nbd-server-config" '' - ${lib.generators.toINI {} genericSection} - ${lib.generators.toINI {} exportSections} - ''; - splitLists = - lib.partition - (path: lib.hasPrefix "/dev/" path) - (lib.mapAttrsToList (_: { path, ... }: path) cfg.server.exports); + exportSections = lib.mapAttrs ( + _: + { + path, + allowAddresses, + extraOptions, + }: + extraOptions + // { + exportname = path; + } + // (optionalAttrs (allowAddresses != null) { + authfile = pkgs.writeText "authfile" (lib.concatStringsSep "\n" allowAddresses); + }) + ) cfg.server.exports; + serverConfig = pkgs.writeText "nbd-server-config" '' + ${lib.generators.toINI { } genericSection} + ${lib.generators.toINI { } exportSections} + ''; + splitLists = lib.partition (path: lib.hasPrefix "/dev/" path) ( + lib.mapAttrsToList (_: { path, ... }: path) cfg.server.exports + ); allowedDevices = splitLists.right; boundPaths = splitLists.wrong; in @@ -65,35 +96,37 @@ in exports = mkOption { description = "Files or block devices to make available over the network."; default = { }; - type = attrsOf - (submodule { - options = { - path = mkOption { - type = str; - description = "File or block device to export."; - example = "/dev/sdb1"; - }; + type = attrsOf (submodule { + options = { + path = mkOption { + type = str; + description = "File or block device to export."; + example = "/dev/sdb1"; + }; - allowAddresses = mkOption { - type = nullOr (listOf str); - default = null; - example = [ "10.10.0.0/24" "127.0.0.1" ]; - description = "IPs and subnets that are authorized to connect for this device. If not specified, the server will allow all connections."; - }; + allowAddresses = mkOption { + type = nullOr (listOf str); + default = null; + example = [ + "10.10.0.0/24" + "127.0.0.1" + ]; + description = "IPs and subnets that are authorized to connect for this device. If not specified, the server will allow all connections."; + }; - extraOptions = mkOption { - type = iniFields; - default = { - flush = true; - fua = true; - }; - description = '' - Extra options for this export. See - {manpage}`nbd-server(5)`. - ''; + extraOptions = mkOption { + type = iniFields; + default = { + flush = true; + fua = true; }; + description = '' + Extra options for this export. See + {manpage}`nbd-server(5)`. + ''; }; - }); + }; + }); }; listenAddress = mkOption { diff --git a/nixos/modules/services/networking/nebula.nix b/nixos/modules/services/networking/nebula.nix index 2ddad4e4094c6c..35d7fafb43b576 100644 --- a/nixos/modules/services/networking/nebula.nix +++ b/nixos/modules/services/networking/nebula.nix @@ -1,19 +1,22 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.nebula; enabledNetworks = lib.filterAttrs (n: v: v.enable) cfg.networks; - format = pkgs.formats.yaml {}; + format = pkgs.formats.yaml { }; nameToId = netName: "nebula-${netName}"; - resolveFinalPort = netCfg: + resolveFinalPort = + netCfg: if netCfg.listen.port == null then - if (netCfg.isLighthouse || netCfg.isRelay) then - 4242 - else - 0 + if (netCfg.isLighthouse || netCfg.isRelay) then 4242 else 0 else netCfg.listen.port; in @@ -24,188 +27,209 @@ in services.nebula = { networks = lib.mkOption { description = "Nebula network definitions."; - default = {}; - type = lib.types.attrsOf (lib.types.submodule { - options = { - enable = lib.mkOption { - type = lib.types.bool; - default = true; - description = "Enable or disable this network."; - }; + default = { }; + type = lib.types.attrsOf ( + lib.types.submodule { + options = { + enable = lib.mkOption { + type = lib.types.bool; + default = true; + description = "Enable or disable this network."; + }; - package = lib.mkPackageOption pkgs "nebula" { }; + package = lib.mkPackageOption pkgs "nebula" { }; - ca = lib.mkOption { - type = lib.types.path; - description = "Path to the certificate authority certificate."; - example = "/etc/nebula/ca.crt"; - }; + ca = lib.mkOption { + type = lib.types.path; + description = "Path to the certificate authority certificate."; + example = "/etc/nebula/ca.crt"; + }; - cert = lib.mkOption { - type = lib.types.path; - description = "Path to the host certificate."; - example = "/etc/nebula/host.crt"; - }; + cert = lib.mkOption { + type = lib.types.path; + description = "Path to the host certificate."; + example = "/etc/nebula/host.crt"; + }; - key = lib.mkOption { - type = lib.types.oneOf [lib.types.nonEmptyStr lib.types.path]; - description = "Path or reference to the host key."; - example = "/etc/nebula/host.key"; - }; + key = lib.mkOption { + type = lib.types.oneOf [ + lib.types.nonEmptyStr + lib.types.path + ]; + description = "Path or reference to the host key."; + example = "/etc/nebula/host.key"; + }; - staticHostMap = lib.mkOption { - type = lib.types.attrsOf (lib.types.listOf (lib.types.str)); - default = {}; - description = '' - The static host map defines a set of hosts with fixed IP addresses on the internet (or any network). - A host can have multiple fixed IP addresses defined here, and nebula will try each when establishing a tunnel. - ''; - example = { "192.168.100.1" = [ "100.64.22.11:4242" ]; }; - }; + staticHostMap = lib.mkOption { + type = lib.types.attrsOf (lib.types.listOf (lib.types.str)); + default = { }; + description = '' + The static host map defines a set of hosts with fixed IP addresses on the internet (or any network). + A host can have multiple fixed IP addresses defined here, and nebula will try each when establishing a tunnel. + ''; + example = { + "192.168.100.1" = [ "100.64.22.11:4242" ]; + }; + }; - isLighthouse = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Whether this node is a lighthouse."; - }; + isLighthouse = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Whether this node is a lighthouse."; + }; - isRelay = lib.mkOption { - type = lib.types.bool; - default = false; - description = "Whether this node is a relay."; - }; + isRelay = lib.mkOption { + type = lib.types.bool; + default = false; + description = "Whether this node is a relay."; + }; - lighthouses = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - description = '' - List of IPs of lighthouse hosts this node should report to and query from. This should be empty on lighthouse - nodes. The IPs should be the lighthouse's Nebula IPs, not their external IPs. - ''; - example = [ "192.168.100.1" ]; - }; + lighthouses = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + description = '' + List of IPs of lighthouse hosts this node should report to and query from. This should be empty on lighthouse + nodes. The IPs should be the lighthouse's Nebula IPs, not their external IPs. + ''; + example = [ "192.168.100.1" ]; + }; - relays = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - description = '' - List of IPs of relays that this node should allow traffic from. - ''; - example = [ "192.168.100.1" ]; - }; + relays = lib.mkOption { + type = lib.types.listOf lib.types.str; + default = [ ]; + description = '' + List of IPs of relays that this node should allow traffic from. + ''; + example = [ "192.168.100.1" ]; + }; - listen.host = lib.mkOption { - type = lib.types.str; - default = "0.0.0.0"; - description = "IP address to listen on."; - }; + listen.host = lib.mkOption { + type = lib.types.str; + default = "0.0.0.0"; + description = "IP address to listen on."; + }; - listen.port = lib.mkOption { - type = lib.types.nullOr lib.types.port; - default = null; - defaultText = lib.literalExpression '' - if (config.services.nebula.networks.''${name}.isLighthouse || - config.services.nebula.networks.''${name}.isRelay) then - 4242 - else - 0; - ''; - description = "Port number to listen on."; - }; + listen.port = lib.mkOption { + type = lib.types.nullOr lib.types.port; + default = null; + defaultText = lib.literalExpression '' + if (config.services.nebula.networks.''${name}.isLighthouse || + config.services.nebula.networks.''${name}.isRelay) then + 4242 + else + 0; + ''; + description = "Port number to listen on."; + }; - tun.disable = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - When tun is disabled, a lighthouse can be started without a local tun interface (and therefore without root). - ''; - }; + tun.disable = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + When tun is disabled, a lighthouse can be started without a local tun interface (and therefore without root). + ''; + }; - tun.device = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; - description = "Name of the tun device. Defaults to nebula.\${networkName}."; - }; + tun.device = lib.mkOption { + type = lib.types.nullOr lib.types.str; + default = null; + description = "Name of the tun device. Defaults to nebula.\${networkName}."; + }; - firewall.outbound = lib.mkOption { - type = lib.types.listOf lib.types.attrs; - default = []; - description = "Firewall rules for outbound traffic."; - example = [ { port = "any"; proto = "any"; host = "any"; } ]; - }; + firewall.outbound = lib.mkOption { + type = lib.types.listOf lib.types.attrs; + default = [ ]; + description = "Firewall rules for outbound traffic."; + example = [ + { + port = "any"; + proto = "any"; + host = "any"; + } + ]; + }; - firewall.inbound = lib.mkOption { - type = lib.types.listOf lib.types.attrs; - default = []; - description = "Firewall rules for inbound traffic."; - example = [ { port = "any"; proto = "any"; host = "any"; } ]; - }; + firewall.inbound = lib.mkOption { + type = lib.types.listOf lib.types.attrs; + default = [ ]; + description = "Firewall rules for inbound traffic."; + example = [ + { + port = "any"; + proto = "any"; + host = "any"; + } + ]; + }; - settings = lib.mkOption { - type = format.type; - default = {}; - description = '' - Nebula configuration. Refer to - - for details on supported values. - ''; - example = lib.literalExpression '' - { - lighthouse.dns = { - host = "0.0.0.0"; - port = 53; - }; - } - ''; + settings = lib.mkOption { + type = format.type; + default = { }; + description = '' + Nebula configuration. Refer to + + for details on supported values. + ''; + example = lib.literalExpression '' + { + lighthouse.dns = { + host = "0.0.0.0"; + port = 53; + }; + } + ''; + }; }; - }; - }); + } + ); }; }; }; # Implementation - config = lib.mkIf (enabledNetworks != {}) { - systemd.services = lib.mkMerge (lib.mapAttrsToList (netName: netCfg: - let - networkId = nameToId netName; - settings = lib.recursiveUpdate { - pki = { - ca = netCfg.ca; - cert = netCfg.cert; - key = netCfg.key; - }; - static_host_map = netCfg.staticHostMap; - lighthouse = { - am_lighthouse = netCfg.isLighthouse; - hosts = netCfg.lighthouses; - }; - relay = { - am_relay = netCfg.isRelay; - relays = netCfg.relays; - use_relays = true; - }; - listen = { - host = netCfg.listen.host; - port = resolveFinalPort netCfg; - }; - tun = { - disabled = netCfg.tun.disable; - dev = if (netCfg.tun.device != null) then netCfg.tun.device else "nebula.${netName}"; - }; - firewall = { - inbound = netCfg.firewall.inbound; - outbound = netCfg.firewall.outbound; - }; - } netCfg.settings; - configFile = format.generate "nebula-config-${netName}.yml" ( - lib.warnIf - ((settings.lighthouse.am_lighthouse || settings.relay.am_relay) && settings.listen.port == 0) - '' - Nebula network '${netName}' is configured as a lighthouse or relay, and its port is ${builtins.toString settings.listen.port}. - You will likely experience connectivity issues: https://nebula.defined.net/docs/config/listen/#listenport - '' - settings + config = lib.mkIf (enabledNetworks != { }) { + systemd.services = lib.mkMerge ( + lib.mapAttrsToList ( + netName: netCfg: + let + networkId = nameToId netName; + settings = lib.recursiveUpdate { + pki = { + ca = netCfg.ca; + cert = netCfg.cert; + key = netCfg.key; + }; + static_host_map = netCfg.staticHostMap; + lighthouse = { + am_lighthouse = netCfg.isLighthouse; + hosts = netCfg.lighthouses; + }; + relay = { + am_relay = netCfg.isRelay; + relays = netCfg.relays; + use_relays = true; + }; + listen = { + host = netCfg.listen.host; + port = resolveFinalPort netCfg; + }; + tun = { + disabled = netCfg.tun.disable; + dev = if (netCfg.tun.device != null) then netCfg.tun.device else "nebula.${netName}"; + }; + firewall = { + inbound = netCfg.firewall.inbound; + outbound = netCfg.firewall.outbound; + }; + } netCfg.settings; + configFile = format.generate "nebula-config-${netName}.yml" ( + lib.warnIf + ((settings.lighthouse.am_lighthouse || settings.relay.am_relay) && settings.listen.port == 0) + '' + Nebula network '${netName}' is configured as a lighthouse or relay, and its port is ${builtins.toString settings.listen.port}. + You will likely experience connectivity issues: https://nebula.defined.net/docs/config/listen/#listenport + '' + settings ); in { @@ -213,7 +237,10 @@ in "nebula@${netName}" = { description = "Nebula VPN service for ${netName}"; wants = [ "basic.target" ]; - after = [ "basic.target" "network.target" ]; + after = [ + "basic.target" + "network.target" + ]; before = [ "sshd.service" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { @@ -246,25 +273,33 @@ in }; unitConfig.StartLimitIntervalSec = 0; # ensure Restart=always is always honoured (networks can go down for arbitrarily long) }; - }) enabledNetworks); + } + ) enabledNetworks + ); # Open the chosen ports for UDP. - networking.firewall.allowedUDPPorts = - lib.unique (lib.filter (port: port > 0) (lib.mapAttrsToList (netName: netCfg: resolveFinalPort netCfg) enabledNetworks)); + networking.firewall.allowedUDPPorts = lib.unique ( + lib.filter (port: port > 0) ( + lib.mapAttrsToList (netName: netCfg: resolveFinalPort netCfg) enabledNetworks + ) + ); # Create the service users and groups. - users.users = lib.mkMerge (lib.mapAttrsToList (netName: netCfg: - { + users.users = lib.mkMerge ( + lib.mapAttrsToList (netName: netCfg: { ${nameToId netName} = { group = nameToId netName; description = "Nebula service user for network ${netName}"; isSystemUser = true; }; - }) enabledNetworks); + }) enabledNetworks + ); - users.groups = lib.mkMerge (lib.mapAttrsToList (netName: netCfg: { - ${nameToId netName} = {}; - }) enabledNetworks); + users.groups = lib.mkMerge ( + lib.mapAttrsToList (netName: netCfg: { + ${nameToId netName} = { }; + }) enabledNetworks + ); }; meta.maintainers = with lib.maintainers; [ numinit ]; diff --git a/nixos/modules/services/networking/netbird.nix b/nixos/modules/services/networking/netbird.nix index d39c373dbc94c8..9771503e14e284 100644 --- a/nixos/modules/services/networking/netbird.nix +++ b/nixos/modules/services/networking/netbird.nix @@ -112,57 +112,52 @@ in networking.dhcpcd.denyInterfaces = attrNames cfg.tunnels; systemd.network.networks = mkIf config.networking.useNetworkd ( - mapAttrs' - ( - name: _: - nameValuePair "50-netbird-${name}" { - matchConfig = { - Name = name; - }; - linkConfig = { - Unmanaged = true; - ActivationPolicy = "manual"; - }; - } - ) - cfg.tunnels + mapAttrs' ( + name: _: + nameValuePair "50-netbird-${name}" { + matchConfig = { + Name = name; + }; + linkConfig = { + Unmanaged = true; + ActivationPolicy = "manual"; + }; + } + ) cfg.tunnels ); - systemd.services = - mapAttrs' - ( - name: - { environment, stateDir, ... }: - nameValuePair "netbird-${name}" { - description = "A WireGuard-based mesh network that connects your devices into a single private network"; + systemd.services = mapAttrs' ( + name: + { environment, stateDir, ... }: + nameValuePair "netbird-${name}" { + description = "A WireGuard-based mesh network that connects your devices into a single private network"; - documentation = [ "https://netbird.io/docs/" ]; + documentation = [ "https://netbird.io/docs/" ]; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; - path = with pkgs; [ openresolv ]; + path = with pkgs; [ openresolv ]; - inherit environment; + inherit environment; - serviceConfig = { - ExecStart = "${getExe cfg.package} service run"; - Restart = "always"; - RuntimeDirectory = stateDir; - StateDirectory = stateDir; - StateDirectoryMode = "0700"; - WorkingDirectory = "/var/lib/${stateDir}"; - }; + serviceConfig = { + ExecStart = "${getExe cfg.package} service run"; + Restart = "always"; + RuntimeDirectory = stateDir; + StateDirectory = stateDir; + StateDirectoryMode = "0700"; + WorkingDirectory = "/var/lib/${stateDir}"; + }; - unitConfig = { - StartLimitInterval = 5; - StartLimitBurst = 10; - }; + unitConfig = { + StartLimitInterval = 5; + StartLimitBurst = 10; + }; - stopIfChanged = false; - } - ) - cfg.tunnels; + stopIfChanged = false; + } + ) cfg.tunnels; }) ]; } diff --git a/nixos/modules/services/networking/netclient.nix b/nixos/modules/services/networking/netclient.nix index b4819f84bab2cd..1c3336fd19c6b2 100644 --- a/nixos/modules/services/networking/netclient.nix +++ b/nixos/modules/services/networking/netclient.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.netclient; in diff --git a/nixos/modules/services/networking/networkd-dispatcher.nix b/nixos/modules/services/networking/networkd-dispatcher.nix index 2cf3fa4cce98fc..49d5cd545656a5 100644 --- a/nixos/modules/services/networking/networkd-dispatcher.nix +++ b/nixos/modules/services/networking/networkd-dispatcher.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,7 +11,8 @@ let cfg = config.services.networkd-dispatcher; -in { +in +{ options = { services.networkd-dispatcher = { @@ -18,7 +24,7 @@ in { ''; rules = mkOption { - default = {}; + default = { }; example = lib.literalExpression '' { "restart-tor" = { onState = ["routable" "off"]; @@ -38,28 +44,38 @@ in { [upstream instructions](https://gitlab.com/craftyguy/networkd-dispatcher) for an introduction and example scripts. ''; - type = types.attrsOf (types.submodule { - options = { - onState = mkOption { - type = types.listOf (types.enum [ - "routable" "dormant" "no-carrier" "off" "carrier" "degraded" - "configuring" "configured" - ]); - default = null; - description = '' - List of names of the systemd-networkd operational states which - should trigger the script. See - for a description of the specific state type. - ''; + type = types.attrsOf ( + types.submodule { + options = { + onState = mkOption { + type = types.listOf ( + types.enum [ + "routable" + "dormant" + "no-carrier" + "off" + "carrier" + "degraded" + "configuring" + "configured" + ] + ); + default = null; + description = '' + List of names of the systemd-networkd operational states which + should trigger the script. See + for a description of the specific state type. + ''; + }; + script = mkOption { + type = types.lines; + description = '' + Shell commands executed on specified operational states. + ''; + }; }; - script = mkOption { - type = types.lines; - description = '' - Shell commands executed on specified operational states. - ''; - }; - }; - }); + } + ); }; extraArgs = mkOption { @@ -84,25 +100,29 @@ in { }; }; - services.networkd-dispatcher.extraArgs = let - scriptDir = pkgs.symlinkJoin { - name = "networkd-dispatcher-script-dir"; - paths = lib.mapAttrsToList (name: cfg: - (map(state: - pkgs.writeTextFile { - inherit name; - text = cfg.script; - destination = "/${state}.d/${name}"; - executable = true; - } - ) cfg.onState) - ) cfg.rules; - }; - in [ - "--verbose" - "--script-dir" "${scriptDir}" - ]; + services.networkd-dispatcher.extraArgs = + let + scriptDir = pkgs.symlinkJoin { + name = "networkd-dispatcher-script-dir"; + paths = lib.mapAttrsToList ( + name: cfg: + (map ( + state: + pkgs.writeTextFile { + inherit name; + text = cfg.script; + destination = "/${state}.d/${name}"; + executable = true; + } + ) cfg.onState) + ) cfg.rules; + }; + in + [ + "--verbose" + "--script-dir" + "${scriptDir}" + ]; }; } - diff --git a/nixos/modules/services/networking/nextdns.nix b/nixos/modules/services/networking/nextdns.nix index b070eeec894fee..d8ba2930446cf1 100644 --- a/nixos/modules/services/networking/nextdns.nix +++ b/nixos/modules/services/networking/nextdns.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.nextdns; -in { +in +{ options = { services.nextdns = { enable = mkOption { @@ -14,8 +20,11 @@ in { }; arguments = mkOption { type = types.listOf types.str; - default = []; - example = [ "-config" "10.0.3.0/24=abcdef" ]; + default = [ ]; + example = [ + "-config" + "10.0.3.0/24=abcdef" + ]; description = "Additional arguments to be passed to nextdns run."; }; }; diff --git a/nixos/modules/services/networking/nftables.nix b/nixos/modules/services/networking/nftables.nix index 0c1725f12b3d78..7ee1b7caafed1a 100644 --- a/nixos/modules/services/networking/nftables.nix +++ b/nixos/modules/services/networking/nftables.nix @@ -1,35 +1,49 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.networking.nftables; - tableSubmodule = { name, ... }: { - options = { - enable = lib.mkOption { - type = lib.types.bool; - default = true; - description = "Enable this table."; - }; + tableSubmodule = + { name, ... }: + { + options = { + enable = lib.mkOption { + type = lib.types.bool; + default = true; + description = "Enable this table."; + }; - name = lib.mkOption { - type = lib.types.str; - description = "Table name."; - }; + name = lib.mkOption { + type = lib.types.str; + description = "Table name."; + }; - content = lib.mkOption { - type = lib.types.lines; - description = "The table content."; - }; + content = lib.mkOption { + type = lib.types.lines; + description = "The table content."; + }; - family = lib.mkOption { - description = "Table family."; - type = lib.types.enum [ "ip" "ip6" "inet" "arp" "bridge" "netdev" ]; + family = lib.mkOption { + description = "Table family."; + type = lib.types.enum [ + "ip" + "ip6" + "inet" + "arp" + "bridge" + "netdev" + ]; + }; }; - }; - config = { - name = lib.mkDefault name; + config = { + name = lib.mkDefault name; + }; }; - }; in { ###### interface @@ -39,21 +53,21 @@ in type = lib.types.bool; default = false; description = '' - Whether to enable nftables and use nftables based firewall if enabled. - nftables is a Linux-based packet filtering framework intended to - replace frameworks like iptables. - - Note that if you have Docker enabled you will not be able to use - nftables without intervention. Docker uses iptables internally to - setup NAT for containers. This module disables the ip_tables kernel - module, however Docker automatically loads the module. Please see - - for more information. - - There are other programs that use iptables internally too, such as - libvirt. For information on how the two firewalls interact, see - . - ''; + Whether to enable nftables and use nftables based firewall if enabled. + nftables is a Linux-based packet filtering framework intended to + replace frameworks like iptables. + + Note that if you have Docker enabled you will not be able to use + nftables without intervention. Docker uses iptables internally to + setup NAT for containers. This module disables the ip_tables kernel + module, however Docker automatically loads the module. Please see + + for more information. + + There are other programs that use iptables internally too, such as + libvirt. For information on how the two firewalls interact, see + . + ''; }; networking.nftables.checkRuleset = lib.mkOption { @@ -69,7 +83,9 @@ in }; networking.nftables.checkRulesetRedirects = lib.mkOption { - type = lib.types.addCheck (lib.types.attrsOf lib.types.path) (attrs: lib.all lib.types.path.check (lib.attrNames attrs)); + type = lib.types.addCheck (lib.types.attrsOf lib.types.path) ( + attrs: lib.all lib.types.path.check (lib.attrNames attrs) + ); default = { "/etc/hosts" = config.environment.etc.hosts.source; "/etc/protocols" = config.environment.etc.protocols.source; @@ -113,9 +129,9 @@ in delete table inet some-table; ''; description = '' - Extra deletion commands to be run on every firewall start, reload - and after stopping the firewall. - ''; + Extra deletion commands to be run on every firewall start, reload + and after stopping the firewall. + ''; }; networking.nftables.ruleset = lib.mkOption { @@ -164,21 +180,21 @@ in } ''; description = '' - The ruleset to be used with nftables. Should be in a format that - can be loaded using "/bin/nft -f". The ruleset is updated atomically. - Note that if the tables should be cleaned first, either: - - networking.nftables.flushRuleset = true; needs to be set (flushes all tables) - - networking.nftables.extraDeletions needs to be set - - or networking.nftables.tables can be used, which will clean up the table automatically - ''; + The ruleset to be used with nftables. Should be in a format that + can be loaded using "/bin/nft -f". The ruleset is updated atomically. + Note that if the tables should be cleaned first, either: + - networking.nftables.flushRuleset = true; needs to be set (flushes all tables) + - networking.nftables.extraDeletions needs to be set + - or networking.nftables.tables can be used, which will clean up the table automatically + ''; }; networking.nftables.rulesetFile = lib.mkOption { type = lib.types.nullOr lib.types.path; default = null; description = '' - The ruleset file to be used with nftables. Should be in a format that - can be loaded using "nft -f". The ruleset is updated atomically. - ''; + The ruleset file to be used with nftables. Should be in a format that + can be loaded using "nft -f". The ruleset is updated atomically. + ''; }; networking.nftables.flattenRulesetFile = lib.mkOption { @@ -196,7 +212,7 @@ in networking.nftables.tables = lib.mkOption { type = lib.types.attrsOf (lib.types.submodule tableSubmodule); - default = {}; + default = { }; description = '' Tables to be added to ruleset. @@ -257,78 +273,115 @@ in boot.blacklistedKernelModules = [ "ip_tables" ]; environment.systemPackages = [ pkgs.nftables ]; # versionOlder for backportability, remove afterwards - networking.nftables.flushRuleset = lib.mkDefault (lib.versionOlder config.system.stateVersion "23.11" || (cfg.rulesetFile != null || cfg.ruleset != "")); + networking.nftables.flushRuleset = lib.mkDefault ( + lib.versionOlder config.system.stateVersion "23.11" + || (cfg.rulesetFile != null || cfg.ruleset != "") + ); systemd.services.nftables = { description = "nftables firewall"; after = [ "sysinit.target" ]; - before = [ "network-pre.target" "shutdown.target" ]; + before = [ + "network-pre.target" + "shutdown.target" + ]; conflicts = [ "shutdown.target" ]; - wants = [ "network-pre.target" "sysinit.target" ]; + wants = [ + "network-pre.target" + "sysinit.target" + ]; wantedBy = [ "multi-user.target" ]; reloadIfChanged = true; - serviceConfig = let - enabledTables = lib.filterAttrs (_: table: table.enable) cfg.tables; - deletionsScript = pkgs.writeScript "nftables-deletions" '' - #! ${pkgs.nftables}/bin/nft -f - ${if cfg.flushRuleset then "flush ruleset" - else lib.concatStringsSep "\n" (lib.mapAttrsToList (_: table: '' - table ${table.family} ${table.name} - delete table ${table.family} ${table.name} - '') enabledTables)} - ${cfg.extraDeletions} - ''; - deletionsScriptVar = "/var/lib/nftables/deletions.nft"; - ensureDeletions = pkgs.writeShellScript "nftables-ensure-deletions" '' - touch ${deletionsScriptVar} - chmod +x ${deletionsScriptVar} - ''; - saveDeletionsScript = pkgs.writeShellScript "nftables-save-deletions" '' - cp ${deletionsScript} ${deletionsScriptVar} - ''; - cleanupDeletionsScript = pkgs.writeShellScript "nftables-cleanup-deletions" '' - rm ${deletionsScriptVar} - ''; - rulesScript = pkgs.writeTextFile { - name = "nftables-rules"; - executable = true; - text = '' + serviceConfig = + let + enabledTables = lib.filterAttrs (_: table: table.enable) cfg.tables; + deletionsScript = pkgs.writeScript "nftables-deletions" '' #! ${pkgs.nftables}/bin/nft -f - # previous deletions, if any - include "${deletionsScriptVar}" - # current deletions - include "${deletionsScript}" - ${lib.concatStringsSep "\n" (lib.mapAttrsToList (_: table: '' - table ${table.family} ${table.name} { - ${table.content} - } - '') enabledTables)} - ${cfg.ruleset} - ${if cfg.rulesetFile != null then - if cfg.flattenRulesetFile then - builtins.readFile cfg.rulesetFile - else '' - include "${cfg.rulesetFile}" - '' - else ""} + ${ + if cfg.flushRuleset then + "flush ruleset" + else + lib.concatStringsSep "\n" ( + lib.mapAttrsToList (_: table: '' + table ${table.family} ${table.name} + delete table ${table.family} ${table.name} + '') enabledTables + ) + } + ${cfg.extraDeletions} + ''; + deletionsScriptVar = "/var/lib/nftables/deletions.nft"; + ensureDeletions = pkgs.writeShellScript "nftables-ensure-deletions" '' + touch ${deletionsScriptVar} + chmod +x ${deletionsScriptVar} ''; - checkPhase = lib.optionalString cfg.checkRuleset '' - cp $out ruleset.conf - sed 's|include "${deletionsScriptVar}"||' -i ruleset.conf - ${cfg.preCheckRuleset} - export NIX_REDIRECTS=${lib.escapeShellArg (lib.concatStringsSep ":" (lib.mapAttrsToList (n: v: "${n}=${v}") cfg.checkRulesetRedirects))} - LD_PRELOAD="${pkgs.buildPackages.libredirect}/lib/libredirect.so ${pkgs.buildPackages.lklWithFirewall.lib}/lib/liblkl-hijack.so" \ - ${pkgs.buildPackages.nftables}/bin/nft --check --file ruleset.conf + saveDeletionsScript = pkgs.writeShellScript "nftables-save-deletions" '' + cp ${deletionsScript} ${deletionsScriptVar} ''; + cleanupDeletionsScript = pkgs.writeShellScript "nftables-cleanup-deletions" '' + rm ${deletionsScriptVar} + ''; + rulesScript = pkgs.writeTextFile { + name = "nftables-rules"; + executable = true; + text = '' + #! ${pkgs.nftables}/bin/nft -f + # previous deletions, if any + include "${deletionsScriptVar}" + # current deletions + include "${deletionsScript}" + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList (_: table: '' + table ${table.family} ${table.name} { + ${table.content} + } + '') enabledTables + )} + ${cfg.ruleset} + ${ + if cfg.rulesetFile != null then + if cfg.flattenRulesetFile then + builtins.readFile cfg.rulesetFile + else + '' + include "${cfg.rulesetFile}" + '' + else + "" + } + ''; + checkPhase = lib.optionalString cfg.checkRuleset '' + cp $out ruleset.conf + sed 's|include "${deletionsScriptVar}"||' -i ruleset.conf + ${cfg.preCheckRuleset} + export NIX_REDIRECTS=${ + lib.escapeShellArg ( + lib.concatStringsSep ":" (lib.mapAttrsToList (n: v: "${n}=${v}") cfg.checkRulesetRedirects) + ) + } + LD_PRELOAD="${pkgs.buildPackages.libredirect}/lib/libredirect.so ${pkgs.buildPackages.lklWithFirewall.lib}/lib/liblkl-hijack.so" \ + ${pkgs.buildPackages.nftables}/bin/nft --check --file ruleset.conf + ''; + }; + in + { + Type = "oneshot"; + RemainAfterExit = true; + ExecStart = [ + ensureDeletions + rulesScript + ]; + ExecStartPost = saveDeletionsScript; + ExecReload = [ + ensureDeletions + rulesScript + saveDeletionsScript + ]; + ExecStop = [ + deletionsScriptVar + cleanupDeletionsScript + ]; + StateDirectory = "nftables"; }; - in { - Type = "oneshot"; - RemainAfterExit = true; - ExecStart = [ ensureDeletions rulesScript ]; - ExecStartPost = saveDeletionsScript; - ExecReload = [ ensureDeletions rulesScript saveDeletionsScript ]; - ExecStop = [ deletionsScriptVar cleanupDeletionsScript ]; - StateDirectory = "nftables"; - }; unitConfig.DefaultDependencies = false; }; }; diff --git a/nixos/modules/services/networking/nghttpx/backend-params-submodule.nix b/nixos/modules/services/networking/nghttpx/backend-params-submodule.nix index 6523f4b8b9e0f6..bbf8691bb67842 100644 --- a/nixos/modules/services/networking/nghttpx/backend-params-submodule.nix +++ b/nixos/modules/services/networking/nghttpx/backend-params-submodule.nix @@ -1,8 +1,12 @@ -{ lib, ...}: -{ options = { +{ lib, ... }: +{ + options = { proto = lib.mkOption { - type = lib.types.enum [ "h2" "http/1.1" ]; - default = "http/1.1"; + type = lib.types.enum [ + "h2" + "http/1.1" + ]; + default = "http/1.1"; description = '' This option configures the protocol the backend server expects to use. @@ -13,8 +17,8 @@ }; tls = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = '' This option determines whether nghttpx will negotiate its connection with a backend server using TLS or not. The burden @@ -26,8 +30,8 @@ }; sni = lib.mkOption { - type = lib.types.nullOr lib.types.str; - default = null; + type = lib.types.nullOr lib.types.str; + default = null; description = '' Override the TLS SNI field value. This value (in nghttpx) defaults to the host value of the backend configuration. @@ -38,8 +42,8 @@ }; fall = lib.mkOption { - type = lib.types.int; - default = 0; + type = lib.types.int; + default = 0; description = '' If nghttpx cannot connect to the backend N times in a row, the backend is assumed to be offline and is excluded from load @@ -52,8 +56,8 @@ }; rise = lib.mkOption { - type = lib.types.int; - default = 0; + type = lib.types.int; + default = 0; description = '' If the backend is excluded from load balancing, nghttpx will periodically attempt to make a connection to the backend. If @@ -67,8 +71,11 @@ }; affinity = lib.mkOption { - type = lib.types.enum [ "ip" "none" ]; - default = "none"; + type = lib.types.enum [ + "ip" + "none" + ]; + default = "none"; description = '' If "ip" is given, client IP based session affinity is enabled. If "none" is given, session affinity is disabled. @@ -89,8 +96,8 @@ }; dns = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = '' Name resolution of a backends host name is done at start up, or configuration reload. If "dns" is true, name resolution @@ -106,8 +113,8 @@ }; redirect-if-not-tls = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = '' If true, a backend match requires the frontend connection be TLS encrypted. If it is not, nghttpx responds to the request diff --git a/nixos/modules/services/networking/nghttpx/backend-submodule.nix b/nixos/modules/services/networking/nghttpx/backend-submodule.nix index eb559e926e76bd..19829f59ea91d7 100644 --- a/nixos/modules/services/networking/nghttpx/backend-submodule.nix +++ b/nixos/modules/services/networking/nghttpx/backend-submodule.nix @@ -1,10 +1,8 @@ { lib, ... }: -{ options = { +{ + options = { server = lib.mkOption { - type = - lib.types.either - (lib.types.submodule (import ./server-options.nix)) - (lib.types.path); + type = lib.types.either (lib.types.submodule (import ./server-options.nix)) (lib.types.path); example = { host = "127.0.0.1"; port = 8888; @@ -20,13 +18,13 @@ }; patterns = lib.mkOption { - type = lib.types.listOf lib.types.str; + type = lib.types.listOf lib.types.str; example = [ "*.host.net/v1/" "host.org/v2/mypath" "/somepath" ]; - default = []; + default = [ ]; description = '' List of nghttpx backend patterns. @@ -36,12 +34,12 @@ }; params = lib.mkOption { - type = lib.types.nullOr (lib.types.submodule (import ./backend-params-submodule.nix)); + type = lib.types.nullOr (lib.types.submodule (import ./backend-params-submodule.nix)); example = { proto = "h2"; - tls = true; + tls = true; }; - default = null; + default = null; description = '' Parameters to configure a backend. ''; diff --git a/nixos/modules/services/networking/nghttpx/default.nix b/nixos/modules/services/networking/nghttpx/default.nix index b8a0a24e3aad1a..40eba4849adc69 100644 --- a/nixos/modules/services/networking/nghttpx/default.nix +++ b/nixos/modules/services/networking/nghttpx/default.nix @@ -1,24 +1,33 @@ -{config, pkgs, lib, ...}: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.nghttpx; # renderHost :: Either ServerOptions Path -> String - renderHost = server: - if builtins.isString server - then "unix://${server}" - else "${server.host},${builtins.toString server.port}"; + renderHost = + server: + if builtins.isString server then + "unix://${server}" + else + "${server.host},${builtins.toString server.port}"; # Filter out submodule parameters whose value is null or false or is # the key _module. # # filterParams :: ParamsSubmodule -> ParamsSubmodule - filterParams = p: - lib.filterAttrs - (n: v: ("_module" != n) && (null != v) && (false != v)) - (lib.optionalAttrs (null != p) p); + filterParams = + p: + lib.filterAttrs (n: v: ("_module" != n) && (null != v) && (false != v)) ( + lib.optionalAttrs (null != p) p + ); # renderBackend :: BackendSubmodule -> String - renderBackend = backend: + renderBackend = + backend: let host = renderHost backend.server; patterns = lib.concatStringsSep ":" backend.patterns; @@ -27,53 +36,55 @@ let # complicated because nghttpx backend patterns can be entirely # omitted and the params may be given as a mixed collection of # 'key=val' pairs or atoms (e.g: 'proto=h2;tls') - params = - lib.mapAttrsToList - (n: v: - if builtins.isBool v - then n - else if builtins.isString v - then "${n}=${v}" - else "${n}=${builtins.toString v}") - (filterParams backend.params); + params = lib.mapAttrsToList ( + n: v: + if builtins.isBool v then + n + else if builtins.isString v then + "${n}=${v}" + else + "${n}=${builtins.toString v}" + ) (filterParams backend.params); # NB: params are delimited by a ";" which is the same delimiter # to separate the host;[pattern];[params] sections of a backend - sections = - builtins.filter (e: "" != e) ([ + sections = builtins.filter (e: "" != e) ( + [ host patterns - ]++params); + ] + ++ params + ); formattedSections = lib.concatStringsSep ";" sections; in - "backend=${formattedSections}"; + "backend=${formattedSections}"; # renderFrontend :: FrontendSubmodule -> String - renderFrontend = frontend: + renderFrontend = + frontend: let - host = renderHost frontend.server; - params0 = - lib.mapAttrsToList - (n: v: if builtins.isBool v then n else v) - (filterParams frontend.params); + host = renderHost frontend.server; + params0 = lib.mapAttrsToList (n: v: if builtins.isBool v then n else v) ( + filterParams frontend.params + ); # NB: nghttpx doesn't accept "tls", you must omit "no-tls" for # the default behavior of turning on TLS. params1 = lib.remove "tls" params0; - sections = [ host] ++ params1; + sections = [ host ] ++ params1; formattedSections = lib.concatStringsSep ";" sections; in - "frontend=${formattedSections}"; + "frontend=${formattedSections}"; configurationFile = pkgs.writeText "nghttpx.conf" '' - ${lib.optionalString (null != cfg.tls) ("private-key-file="+cfg.tls.key)} - ${lib.optionalString (null != cfg.tls) ("certificate-file="+cfg.tls.crt)} + ${lib.optionalString (null != cfg.tls) ("private-key-file=" + cfg.tls.key)} + ${lib.optionalString (null != cfg.tls) ("certificate-file=" + cfg.tls.crt)} user=nghttpx ${lib.concatMapStringsSep "\n" renderFrontend cfg.frontends} - ${lib.concatMapStringsSep "\n" renderBackend cfg.backends} + ${lib.concatMapStringsSep "\n" renderBackend cfg.backends} backlog=${builtins.toString cfg.backlog} backend-address-family=${cfg.backend-address-family} @@ -87,7 +98,8 @@ let ${cfg.extraConfig} ''; in -{ imports = [ +{ + imports = [ ./nghttpx-options.nix ]; @@ -99,17 +111,16 @@ in isSystemUser = true; }; - systemd.services = { nghttpx = { wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - script = '' + after = [ "network.target" ]; + script = '' ${pkgs.nghttp2}/bin/nghttpx --conf=${configurationFile} ''; serviceConfig = { - Restart = "on-failure"; + Restart = "on-failure"; RestartSec = 60; }; }; diff --git a/nixos/modules/services/networking/nghttpx/frontend-params-submodule.nix b/nixos/modules/services/networking/nghttpx/frontend-params-submodule.nix index 33c8572bd14fc6..2addc3e6e867ad 100644 --- a/nixos/modules/services/networking/nghttpx/frontend-params-submodule.nix +++ b/nixos/modules/services/networking/nghttpx/frontend-params-submodule.nix @@ -1,8 +1,12 @@ -{ lib, ...}: -{ options = { +{ lib, ... }: +{ + options = { tls = lib.mkOption { - type = lib.types.enum [ "tls" "no-tls" ]; - default = "tls"; + type = lib.types.enum [ + "tls" + "no-tls" + ]; + default = "tls"; description = '' Enable or disable TLS. If true (enabled) the key and certificate must be configured for nghttpx. @@ -13,7 +17,7 @@ }; sni-fwd = lib.mkOption { - type = lib.types.bool; + type = lib.types.bool; default = false; description = '' When performing a match to select a backend server, SNI host @@ -26,8 +30,8 @@ }; api = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = '' Enable API access for this frontend. This enables you to dynamically modify nghttpx at run-time therefore this feature @@ -39,8 +43,8 @@ }; healthmon = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = '' Make this frontend a health monitor endpoint. Any request received on this frontend is responded to with a 200 OK. @@ -51,8 +55,8 @@ }; proxyproto = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = '' Accept PROXY protocol version 1 on frontend connection. diff --git a/nixos/modules/services/networking/nghttpx/frontend-submodule.nix b/nixos/modules/services/networking/nghttpx/frontend-submodule.nix index 887ef45021319f..3083b4e2b986a1 100644 --- a/nixos/modules/services/networking/nghttpx/frontend-submodule.nix +++ b/nixos/modules/services/networking/nghttpx/frontend-submodule.nix @@ -1,10 +1,8 @@ { lib, ... }: -{ options = { +{ + options = { server = lib.mkOption { - type = - lib.types.either - (lib.types.submodule (import ./server-options.nix)) - (lib.types.path); + type = lib.types.either (lib.types.submodule (import ./server-options.nix)) (lib.types.path); example = { host = "127.0.0.1"; port = 8888; @@ -23,11 +21,11 @@ }; params = lib.mkOption { - type = lib.types.nullOr (lib.types.submodule (import ./frontend-params-submodule.nix)); + type = lib.types.nullOr (lib.types.submodule (import ./frontend-params-submodule.nix)); example = { - tls = "tls"; + tls = "tls"; }; - default = null; + default = null; description = '' Parameters to configure a backend. ''; diff --git a/nixos/modules/services/networking/nghttpx/nghttpx-options.nix b/nixos/modules/services/networking/nghttpx/nghttpx-options.nix index cb77c0c6d1cd0f..79fd8b57c3eb59 100644 --- a/nixos/modules/services/networking/nghttpx/nghttpx-options.nix +++ b/nixos/modules/services/networking/nghttpx/nghttpx-options.nix @@ -1,14 +1,16 @@ { lib, ... }: -{ options.services.nghttpx = { +{ + options.services.nghttpx = { enable = lib.mkEnableOption "nghttpx"; frontends = lib.mkOption { - type = lib.types.listOf (lib.types.submodule (import ./frontend-submodule.nix)); + type = lib.types.listOf (lib.types.submodule (import ./frontend-submodule.nix)); description = '' A list of frontend listener specifications. ''; example = [ - { server = { + { + server = { host = "*"; port = 80; }; @@ -20,19 +22,20 @@ ]; }; - backends = lib.mkOption { + backends = lib.mkOption { type = lib.types.listOf (lib.types.submodule (import ./backend-submodule.nix)); description = '' A list of backend specifications. ''; example = [ - { server = { + { + server = { host = "172.16.0.22"; port = 8443; }; patterns = [ "/" ]; - params = { - proto = "http/1.1"; + params = { + proto = "http/1.1"; redirect-if-not-tls = true; }; } @@ -40,8 +43,8 @@ }; tls = lib.mkOption { - type = lib.types.nullOr (lib.types.submodule (import ./tls-submodule.nix)); - default = null; + type = lib.types.nullOr (lib.types.submodule (import ./tls-submodule.nix)); + default = null; description = '' TLS certificate and key paths. Note that this does not enable TLS for a frontend listener, to do so, a frontend @@ -54,8 +57,8 @@ }; extraConfig = lib.mkOption { - type = lib.types.lines; - default = ""; + type = lib.types.lines; + default = ""; description = '' Extra configuration options to be appended to the generated configuration file. @@ -63,8 +66,8 @@ }; single-process = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = '' Run this program in a single process mode for debugging purpose. Without this option, nghttpx creates at least 2 @@ -79,8 +82,8 @@ }; backlog = lib.mkOption { - type = lib.types.int; - default = 65536; + type = lib.types.int; + default = 65536; description = '' Listen backlog size. @@ -106,8 +109,8 @@ }; workers = lib.mkOption { - type = lib.types.int; - default = 1; + type = lib.types.int; + default = 1; description = '' Set the number of worker threads. @@ -116,8 +119,8 @@ }; single-thread = lib.mkOption { - type = lib.types.bool; - default = false; + type = lib.types.bool; + default = false; description = '' Run everything in one thread inside the worker process. This feature is provided for better debugging experience, or for @@ -129,8 +132,8 @@ }; rlimit-nofile = lib.mkOption { - type = lib.types.int; - default = 0; + type = lib.types.int; + default = 0; description = '' Set maximum number of open files (RLIMIT_NOFILE) to \. If 0 is given, nghttpx does not set the limit. diff --git a/nixos/modules/services/networking/nghttpx/server-options.nix b/nixos/modules/services/networking/nghttpx/server-options.nix index ef23bfd793c5c0..19e03cac557dc3 100644 --- a/nixos/modules/services/networking/nghttpx/server-options.nix +++ b/nixos/modules/services/networking/nghttpx/server-options.nix @@ -1,15 +1,16 @@ { lib, ... }: -{ options = { +{ + options = { host = lib.mkOption { - type = lib.types.str; - example = "127.0.0.1"; + type = lib.types.str; + example = "127.0.0.1"; description = '' Server host address. ''; }; port = lib.mkOption { - type = lib.types.int; - example = 5088; + type = lib.types.int; + example = 5088; description = '' Server host port. ''; diff --git a/nixos/modules/services/networking/nghttpx/tls-submodule.nix b/nixos/modules/services/networking/nghttpx/tls-submodule.nix index 8f3cdaae2c8182..2b9cdf92114ed6 100644 --- a/nixos/modules/services/networking/nghttpx/tls-submodule.nix +++ b/nixos/modules/services/networking/nghttpx/tls-submodule.nix @@ -1,18 +1,19 @@ -{lib, ...}: -{ options = { +{ lib, ... }: +{ + options = { key = lib.mkOption { - type = lib.types.str; - example = "/etc/ssl/keys/mykeyfile.key"; - default = "/etc/ssl/keys/server.key"; + type = lib.types.str; + example = "/etc/ssl/keys/mykeyfile.key"; + default = "/etc/ssl/keys/server.key"; description = '' Path to the TLS key file. ''; }; crt = lib.mkOption { - type = lib.types.str; - example = "/etc/ssl/certs/mycert.crt"; - default = "/etc/ssl/certs/server.crt"; + type = lib.types.str; + example = "/etc/ssl/certs/mycert.crt"; + default = "/etc/ssl/certs/server.crt"; description = '' Path to the TLS certificate file. ''; diff --git a/nixos/modules/services/networking/ngircd.nix b/nixos/modules/services/networking/ngircd.nix index 76e4642c861940..5b2009e0491548 100644 --- a/nixos/modules/services/networking/ngircd.nix +++ b/nixos/modules/services/networking/ngircd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -17,7 +22,8 @@ let ${cfg.package}/sbin/ngircd --config $out --configtest ''; }; -in { +in +{ options = { services.ngircd = { enable = mkEnableOption "the ngircd IRC server"; @@ -49,7 +55,7 @@ in { group = "ngircd"; description = "ngircd user."; }; - users.groups.ngircd = {}; + users.groups.ngircd = { }; }; } diff --git a/nixos/modules/services/networking/nix-serve.nix b/nixos/modules/services/networking/nix-serve.nix index 9f1c54adcfb4a4..22a4db19bdee29 100644 --- a/nixos/modules/services/networking/nix-serve.nix +++ b/nixos/modules/services/networking/nix-serve.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -69,7 +74,10 @@ in after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; - path = [ config.nix.package.out pkgs.bzip2.bin ]; + path = [ + config.nix.package.out + pkgs.bzip2.bin + ]; environment.NIX_REMOTE = "daemon"; script = '' @@ -85,8 +93,9 @@ in User = "nix-serve"; Group = "nix-serve"; DynamicUser = true; - LoadCredential = lib.optionalString (cfg.secretKeyFile != null) - "NIX_SECRET_KEY_FILE:${cfg.secretKeyFile}"; + LoadCredential = lib.optionalString ( + cfg.secretKeyFile != null + ) "NIX_SECRET_KEY_FILE:${cfg.secretKeyFile}"; }; }; diff --git a/nixos/modules/services/networking/nix-store-gcs-proxy.nix b/nixos/modules/services/networking/nix-store-gcs-proxy.nix index 0012302db2e3cd..828f4d5c244dc9 100644 --- a/nixos/modules/services/networking/nix-store-gcs-proxy.nix +++ b/nixos/modules/services/networking/nix-store-gcs-proxy.nix @@ -1,75 +1,84 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let - opts = { name, config, ... }: { - options = { - enable = mkOption { - default = true; - type = types.bool; - example = true; - description = "Whether to enable proxy for this bucket"; - }; - bucketName = mkOption { - type = types.str; - default = name; - example = "my-bucket-name"; - description = "Name of Google storage bucket"; - }; - address = mkOption { - type = types.str; - example = "localhost:3000"; - description = "The address of the proxy."; + opts = + { name, config, ... }: + { + options = { + enable = mkOption { + default = true; + type = types.bool; + example = true; + description = "Whether to enable proxy for this bucket"; + }; + bucketName = mkOption { + type = types.str; + default = name; + example = "my-bucket-name"; + description = "Name of Google storage bucket"; + }; + address = mkOption { + type = types.str; + example = "localhost:3000"; + description = "The address of the proxy."; + }; }; }; - }; enabledProxies = lib.filterAttrs (n: v: v.enable) config.services.nix-store-gcs-proxy; mapProxies = function: lib.mkMerge (lib.mapAttrsToList function enabledProxies); in { options.services.nix-store-gcs-proxy = mkOption { type = types.attrsOf (types.submodule opts); - default = {}; + default = { }; description = '' An attribute set describing an HTTP to GCS proxy that allows us to use GCS bucket via HTTP protocol. ''; }; - config.systemd.services = mapProxies (name: cfg: { - "nix-store-gcs-proxy-${name}" = { - description = "A HTTP nix store that proxies requests to Google Storage"; - wantedBy = ["multi-user.target"]; + config.systemd.services = mapProxies ( + name: cfg: { + "nix-store-gcs-proxy-${name}" = { + description = "A HTTP nix store that proxies requests to Google Storage"; + wantedBy = [ "multi-user.target" ]; - startLimitIntervalSec = 10; - serviceConfig = { - RestartSec = 5; - ExecStart = '' - ${pkgs.nix-store-gcs-proxy}/bin/nix-store-gcs-proxy \ - --bucket-name ${cfg.bucketName} \ - --addr ${cfg.address} - ''; + startLimitIntervalSec = 10; + serviceConfig = { + RestartSec = 5; + ExecStart = '' + ${pkgs.nix-store-gcs-proxy}/bin/nix-store-gcs-proxy \ + --bucket-name ${cfg.bucketName} \ + --addr ${cfg.address} + ''; - DynamicUser = true; + DynamicUser = true; - ProtectSystem = "strict"; - ProtectHome = true; - PrivateTmp = true; - PrivateDevices = true; - PrivateMounts = true; - PrivateUsers = true; + ProtectSystem = "strict"; + ProtectHome = true; + PrivateTmp = true; + PrivateDevices = true; + PrivateMounts = true; + PrivateUsers = true; - ProtectKernelTunables = true; - ProtectKernelModules = true; - ProtectControlGroups = true; + ProtectKernelTunables = true; + ProtectKernelModules = true; + ProtectControlGroups = true; - NoNewPrivileges = true; - LockPersonality = true; - RestrictRealtime = true; + NoNewPrivileges = true; + LockPersonality = true; + RestrictRealtime = true; + }; }; - }; - }); + } + ); meta.maintainers = [ maintainers.mrkkrp ]; } diff --git a/nixos/modules/services/networking/nixops-dns.nix b/nixos/modules/services/networking/nixops-dns.nix index 5d009d6d30845c..55434c4fa53fe5 100644 --- a/nixos/modules/services/networking/nixops-dns.nix +++ b/nixos/modules/services/networking/nixops-dns.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let @@ -58,7 +63,7 @@ in serviceConfig = { Type = "simple"; User = cfg.user; - ExecStart="${pkg}/bin/nixops-dns --domain=.${cfg.domain}"; + ExecStart = "${pkg}/bin/nixops-dns --domain=.${cfg.domain}"; }; }; diff --git a/nixos/modules/services/networking/nncp.nix b/nixos/modules/services/networking/nncp.nix index 8c5b5a61a181d9..5ea42905d86ab9 100644 --- a/nixos/modules/services/networking/nncp.nix +++ b/nixos/modules/services/networking/nncp.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let @@ -9,7 +14,8 @@ let settingsFormat = pkgs.formats.json { }; jsonCfgFile = settingsFormat.generate "nncp.json" programCfg.settings; pkg = programCfg.package; -in { +in +{ options = { services.nncp = { @@ -57,16 +63,21 @@ in { config = mkIf (programCfg.enable or callerCfg.enable or daemonCfg.enable) { - assertions = [{ - assertion = with builtins; - let - callerCongfigured = - let neigh = config.programs.nncp.settings.neigh or { }; - in lib.lists.any (x: hasAttr "calls" x && x.calls != [ ]) - (attrValues neigh); - in !callerCfg.enable || callerCongfigured; - message = "NNCP caller enabled but call configuration is missing"; - }]; + assertions = [ + { + assertion = + with builtins; + let + callerCongfigured = + let + neigh = config.programs.nncp.settings.neigh or { }; + in + lib.lists.any (x: hasAttr "calls" x && x.calls != [ ]) (attrValues neigh); + in + !callerCfg.enable || callerCongfigured; + message = "NNCP caller enabled but call configuration is missing"; + } + ]; systemd.services."nncp-caller" = { inherit (callerCfg) enable; @@ -75,10 +86,7 @@ in { after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart = '' - ${pkg}/bin/nncp-caller -noprogress -cfg "${nncpCfgFile}" ${ - lib.strings.escapeShellArgs callerCfg.extraArgs - }''; + ExecStart = ''${pkg}/bin/nncp-caller -noprogress -cfg "${nncpCfgFile}" ${lib.strings.escapeShellArgs callerCfg.extraArgs}''; Group = "uucp"; UMask = "0002"; }; @@ -91,10 +99,7 @@ in { after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart = '' - ${pkg}/bin/nncp-daemon -noprogress -cfg "${nncpCfgFile}" ${ - lib.strings.escapeShellArgs daemonCfg.extraArgs - }''; + ExecStart = ''${pkg}/bin/nncp-daemon -noprogress -cfg "${nncpCfgFile}" ${lib.strings.escapeShellArgs daemonCfg.extraArgs}''; Restart = "on-failure"; Group = "uucp"; UMask = "0002"; @@ -106,10 +111,7 @@ in { documentation = [ "http://www.nncpgo.org/nncp_002ddaemon.html" ]; after = [ "network.target" ]; serviceConfig = { - ExecStart = '' - ${pkg}/bin/nncp-daemon -noprogress -ucspi -cfg "${nncpCfgFile}" ${ - lib.strings.escapeShellArgs daemonCfg.extraArgs - }''; + ExecStart = ''${pkg}/bin/nncp-daemon -noprogress -ucspi -cfg "${nncpCfgFile}" ${lib.strings.escapeShellArgs daemonCfg.extraArgs}''; Group = "uucp"; UMask = "0002"; StandardInput = "socket"; diff --git a/nixos/modules/services/networking/nntp-proxy.nix b/nixos/modules/services/networking/nntp-proxy.nix index 0a174ec3466425..7495004021111f 100644 --- a/nixos/modules/services/networking/nntp-proxy.nix +++ b/nixos/modules/services/networking/nntp-proxy.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -39,14 +44,17 @@ let # Verbose levels: ERROR, WARNING, NOTICE, INFO, DEBUG verbose = "${toUpper cfg.verbosity}"; # Password is made with: 'mkpasswd -m sha-512 ' - users = (${concatStringsSep ",\n" (mapAttrsToList (username: userConfig: - '' - { - username = "${username}"; - password = "${userConfig.passwordHash}"; - max_connections = ${toString userConfig.maxConnections}; - } - '') cfg.users)}); + users = (${ + concatStringsSep ",\n" ( + mapAttrsToList (username: userConfig: '' + { + username = "${username}"; + password = "${userConfig.passwordHash}"; + max_connections = ${toString userConfig.maxConnections}; + } + '') cfg.users + ) + }); }; ''; @@ -146,7 +154,13 @@ in }; verbosity = mkOption { - type = types.enum [ "error" "warning" "notice" "info" "debug" ]; + type = types.enum [ + "error" + "warning" + "notice" + "info" + "debug" + ]; default = "info"; example = "error"; description = '' @@ -155,38 +169,40 @@ in }; users = mkOption { - type = types.attrsOf (types.submodule { - options = { - username = mkOption { - type = types.str; - description = '' - Username - ''; - }; - - passwordHash = mkOption { - type = types.str; - example = "$6$GtzE7FrpE$wwuVgFYU.TZH4Rz.Snjxk9XGua89IeVwPQ/fEUD8eujr40q5Y021yhn0aNcsQ2Ifw.BLclyzvzgegopgKcneL0"; - description = '' - SHA-512 password hash (can be generated by - `mkpasswd -m sha-512 `) - ''; + type = types.attrsOf ( + types.submodule { + options = { + username = mkOption { + type = types.str; + description = '' + Username + ''; + }; + + passwordHash = mkOption { + type = types.str; + example = "$6$GtzE7FrpE$wwuVgFYU.TZH4Rz.Snjxk9XGua89IeVwPQ/fEUD8eujr40q5Y021yhn0aNcsQ2Ifw.BLclyzvzgegopgKcneL0"; + description = '' + SHA-512 password hash (can be generated by + `mkpasswd -m sha-512 `) + ''; + }; + + maxConnections = mkOption { + type = types.int; + default = 1; + description = '' + Maximum number of concurrent connections to the proxy for this user + ''; + }; }; - - maxConnections = mkOption { - type = types.int; - default = 1; - description = '' - Maximum number of concurrent connections to the proxy for this user - ''; - }; - }; - }); + } + ); description = '' NNTP-Proxy user configuration ''; - default = {}; + default = { }; example = literalExpression '' { "user1" = { @@ -213,13 +229,18 @@ in group = "nntp-proxy"; description = "NNTP-Proxy daemon user"; }; - users.groups.nntp-proxy = {}; + users.groups.nntp-proxy = { }; systemd.services.nntp-proxy = { description = "NNTP proxy"; - after = [ "network.target" "nss-lookup.target" ]; + after = [ + "network.target" + "nss-lookup.target" + ]; wantedBy = [ "multi-user.target" ]; - serviceConfig = { User="nntp-proxy"; }; + serviceConfig = { + User = "nntp-proxy"; + }; serviceConfig.ExecStart = "${nntp-proxy}/bin/nntp-proxy ${confFile}"; preStart = '' if [ ! \( -f ${cfg.sslCert} -a -f ${cfg.sslKey} \) ]; then diff --git a/nixos/modules/services/networking/nomad.nix b/nixos/modules/services/networking/nomad.nix index a30622ac8548ae..f66e82e7143b8d 100644 --- a/nixos/modules/services/networking/nomad.nix +++ b/nixos/modules/services/networking/nomad.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.nomad; @@ -132,12 +137,14 @@ in after = [ "network-online.target" ]; restartTriggers = [ config.environment.etc."nomad.json".source ]; - path = cfg.extraPackages ++ (with pkgs; [ - # Client mode requires at least the following: - coreutils - iproute2 - iptables - ]); + path = + cfg.extraPackages + ++ (with pkgs; [ + # Client mode requires at least the following: + coreutils + iproute2 + iptables + ]); serviceConfig = mkMerge [ { @@ -145,15 +152,16 @@ in ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; ExecStart = let - pluginsDir = pkgs.symlinkJoin - { - name = "nomad-plugins"; - paths = cfg.extraSettingsPlugins; - }; + pluginsDir = pkgs.symlinkJoin { + name = "nomad-plugins"; + paths = cfg.extraSettingsPlugins; + }; in - "${cfg.package}/bin/nomad agent -config=/etc/nomad.json -plugin-dir=${pluginsDir}/bin" + - concatMapStrings (path: " -config=${path}") cfg.extraSettingsPaths + - concatMapStrings (key: " -config=\${CREDENTIALS_DIRECTORY}/${key}") (lib.attrNames cfg.credentials); + "${cfg.package}/bin/nomad agent -config=/etc/nomad.json -plugin-dir=${pluginsDir}/bin" + + concatMapStrings (path: " -config=${path}") cfg.extraSettingsPaths + + concatMapStrings (key: " -config=\${CREDENTIALS_DIRECTORY}/${key}") ( + lib.attrNames cfg.credentials + ); KillMode = "process"; KillSignal = "SIGINT"; LimitNOFILE = 65536; diff --git a/nixos/modules/services/networking/nsd.nix b/nixos/modules/services/networking/nsd.nix index fe878ddbe05f1e..bc6aa5ae3fffbf 100644 --- a/nixos/modules/services/networking/nsd.nix +++ b/nixos/modules/services/networking/nsd.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -21,19 +26,24 @@ let mkZoneFileName = name: if name == "." then "root" else name; # replaces include: directives for keys with fake keys for nsd-checkconf - injectFakeKeys = keys: concatStrings - (mapAttrsToList - (keyName: keyOptions: '' - fakeKey="$(${pkgs.bind}/bin/tsig-keygen -a ${escapeShellArgs [ keyOptions.algorithm keyName ]} | grep -oP "\s*secret \"\K.*(?=\";)")" + injectFakeKeys = + keys: + concatStrings ( + mapAttrsToList (keyName: keyOptions: '' + fakeKey="$(${pkgs.bind}/bin/tsig-keygen -a ${ + escapeShellArgs [ + keyOptions.algorithm + keyName + ] + } | grep -oP "\s*secret \"\K.*(?=\";)")" sed "s@^\s*include:\s*\"${stateDir}/private/${keyName}\"\$@secret: $fakeKey@" -i $out/nsd.conf - '') - keys); + '') keys + ); nsdEnv = pkgs.buildEnv { name = "nsd-env"; - paths = [ configFile ] - ++ mapAttrsToList (name: zone: writeZoneData name zone.data) zoneConfigs; + paths = [ configFile ] ++ mapAttrsToList (name: zone: writeZoneData name zone.data) zoneConfigs; postBuild = '' echo "checking zone files" @@ -64,12 +74,13 @@ let ''; }; - writeZoneData = name: text: pkgs.writeTextFile { - name = "nsd-zone-${mkZoneFileName name}"; - inherit text; - destination = "/zones/${mkZoneFileName name}"; - }; - + writeZoneData = + name: text: + pkgs.writeTextFile { + name = "nsd-zone-${mkZoneFileName name}"; + inherit text; + destination = "/zones/${mkZoneFileName name}"; + }; # options are ordered alphanumerically by the nixos option name configFile = pkgs.writeTextDir "nsd.conf" '' @@ -89,19 +100,19 @@ let # interfaces ${forEach " ip-address: " cfg.interfaces} - ip-freebind: ${yesOrNo cfg.ipFreebind} - hide-version: ${yesOrNo cfg.hideVersion} + ip-freebind: ${yesOrNo cfg.ipFreebind} + hide-version: ${yesOrNo cfg.hideVersion} identity: "${cfg.identity}" - ip-transparent: ${yesOrNo cfg.ipTransparent} - do-ip4: ${yesOrNo cfg.ipv4} + ip-transparent: ${yesOrNo cfg.ipTransparent} + do-ip4: ${yesOrNo cfg.ipv4} ipv4-edns-size: ${toString cfg.ipv4EDNSSize} - do-ip6: ${yesOrNo cfg.ipv6} + do-ip6: ${yesOrNo cfg.ipv6} ipv6-edns-size: ${toString cfg.ipv6EDNSSize} - log-time-ascii: ${yesOrNo cfg.logTimeAscii} + log-time-ascii: ${yesOrNo cfg.logTimeAscii} ${maybeString "nsid: " cfg.nsid} port: ${toString cfg.port} - reuseport: ${yesOrNo cfg.reuseport} - round-robin: ${yesOrNo cfg.roundRobin} + reuseport: ${yesOrNo cfg.reuseport} + round-robin: ${yesOrNo cfg.roundRobin} server-count: ${toString cfg.serverCount} ${maybeToString "statistics: " cfg.statistics} tcp-count: ${toString cfg.tcpCount} @@ -110,20 +121,20 @@ let verbosity: ${toString cfg.verbosity} ${maybeString "version: " cfg.version} xfrd-reload-timeout: ${toString cfg.xfrdReloadTimeout} - zonefiles-check: ${yesOrNo cfg.zonefilesCheck} + zonefiles-check: ${yesOrNo cfg.zonefilesCheck} zonefiles-write: ${toString cfg.zonefilesWrite} ${maybeString "rrl-ipv4-prefix-length: " cfg.ratelimit.ipv4PrefixLength} ${maybeString "rrl-ipv6-prefix-length: " cfg.ratelimit.ipv6PrefixLength} rrl-ratelimit: ${toString cfg.ratelimit.ratelimit} - ${maybeString "rrl-slip: " cfg.ratelimit.slip} + ${maybeString "rrl-slip: " cfg.ratelimit.slip} rrl-size: ${toString cfg.ratelimit.size} rrl-whitelist-ratelimit: ${toString cfg.ratelimit.whitelistRatelimit} ${keyConfigFile} remote-control: - control-enable: ${yesOrNo cfg.remoteControl.enable} + control-enable: ${yesOrNo cfg.remoteControl.enable} control-key-file: "${cfg.remoteControl.controlKeyFile}" control-cert-file: "${cfg.remoteControl.controlCertFile}" ${forEach " control-interface: " cfg.remoteControl.interfaces} @@ -141,20 +152,22 @@ let maybeToString = prefix: x: optionalString (x != null) ''${prefix} ${toString x}''; forEach = pre: l: concatMapStrings (x: pre + x + "\n") l; - - keyConfigFile = concatStrings (mapAttrsToList (keyName: keyOptions: '' - key: - name: "${keyName}" - algorithm: "${keyOptions.algorithm}" - include: "${stateDir}/private/${keyName}" - '') cfg.keys); - - copyKeys = concatStrings (mapAttrsToList (keyName: keyOptions: '' - secret=$(cat "${keyOptions.keyFile}") - dest="${stateDir}/private/${keyName}" - install -m 0400 -o "${username}" -g "${username}" <(echo " secret: \"$secret\"") "$dest" - '') cfg.keys); - + keyConfigFile = concatStrings ( + mapAttrsToList (keyName: keyOptions: '' + key: + name: "${keyName}" + algorithm: "${keyOptions.algorithm}" + include: "${stateDir}/private/${keyName}" + '') cfg.keys + ); + + copyKeys = concatStrings ( + mapAttrsToList (keyName: keyOptions: '' + secret=$(cat "${keyOptions.keyFile}") + dest="${stateDir}/private/${keyName}" + install -m 0400 -o "${username}" -g "${username}" <(echo " secret: \"$secret\"") "$dest" + '') cfg.keys + ); # options are ordered alphanumerically by the nixos option name zoneConfigFile = name: zone: '' @@ -162,35 +175,40 @@ let name: "${name}" zonefile: "${stateDir}/zones/${mkZoneFileName name}" ${maybeString "outgoing-interface: " zone.outgoingInterface} - ${forEach " rrl-whitelist: " zone.rrlWhitelist} - ${maybeString "zonestats: " zone.zoneStats} + ${forEach " rrl-whitelist: " zone.rrlWhitelist} + ${maybeString "zonestats: " zone.zoneStats} ${maybeToString "max-refresh-time: " zone.maxRefreshSecs} ${maybeToString "min-refresh-time: " zone.minRefreshSecs} ${maybeToString "max-retry-time: " zone.maxRetrySecs} ${maybeToString "min-retry-time: " zone.minRetrySecs} - allow-axfr-fallback: ${yesOrNo zone.allowAXFRFallback} - multi-master-check: ${yesOrNo zone.multiMasterCheck} - ${forEach " allow-notify: " zone.allowNotify} - ${forEach " request-xfr: " zone.requestXFR} + allow-axfr-fallback: ${yesOrNo zone.allowAXFRFallback} + multi-master-check: ${yesOrNo zone.multiMasterCheck} + ${forEach " allow-notify: " zone.allowNotify} + ${forEach " request-xfr: " zone.requestXFR} - ${forEach " notify: " zone.notify} + ${forEach " notify: " zone.notify} notify-retry: ${toString zone.notifyRetry} - ${forEach " provide-xfr: " zone.provideXFR} + ${forEach " provide-xfr: " zone.provideXFR} ''; - zoneConfigs = zoneConfigs' {} "" { children = cfg.zones; }; - - zoneConfigs' = parent: name: zone: - if !(zone ? children) || zone.children == null || zone.children == { } - # leaf -> actual zone - then listToAttrs [ (nameValuePair name (parent // zone)) ] - - # fork -> pattern - else zipAttrsWith (name: head) ( - mapAttrsToList (name: child: zoneConfigs' (parent // zone // { children = {}; }) name child) - zone.children + zoneConfigs = zoneConfigs' { } "" { children = cfg.zones; }; + + zoneConfigs' = + parent: name: zone: + if + !(zone ? children) || zone.children == null || zone.children == { } + # leaf -> actual zone + then + listToAttrs [ (nameValuePair name (parent // zone)) ] + + # fork -> pattern + else + zipAttrsWith (name: head) ( + mapAttrsToList ( + name: child: zoneConfigs' (parent // zone // { children = { }; }) name child + ) zone.children ); # options are ordered alphanumerically @@ -209,9 +227,11 @@ let allowNotify = mkOption { type = types.listOf types.str; default = [ ]; - example = [ "192.0.2.0/24 NOKEY" "10.0.0.1-10.0.0.5 my_tsig_key_name" - "10.0.3.4&255.255.0.0 BLOCKED" - ]; + example = [ + "192.0.2.0/24 NOKEY" + "10.0.0.1-10.0.0.5 my_tsig_key_name" + "10.0.3.4&255.255.0.0 BLOCKED" + ]; description = '' Listed primary servers are allowed to notify this secondary server. @@ -241,7 +261,7 @@ let # type here with `zoneConfigs`, since that would set all the attributes # to default values, breaking the parent inheriting function. type = types.attrsOf types.anything; - default = {}; + default = { }; description = '' Children zones inherit all options of their parents. Attributes defined in a child will overwrite the ones of its parent. Only @@ -283,20 +303,22 @@ let }; zsk = mkOption { type = keyPolicy; - default = { keySize = 2048; - prePublish = "1w"; - postPublish = "1w"; - rollPeriod = "1mo"; - }; + default = { + keySize = 2048; + prePublish = "1w"; + postPublish = "1w"; + rollPeriod = "1mo"; + }; description = "Key policy for zone signing keys"; }; ksk = mkOption { type = keyPolicy; - default = { keySize = 4096; - prePublish = "1mo"; - postPublish = "1mo"; - rollPeriod = "0"; - }; + default = { + keySize = 4096; + prePublish = "1mo"; + postPublish = "1mo"; + rollPeriod = "0"; + }; description = "Key policy for key signing keys"; }; }; @@ -350,8 +372,11 @@ let notify = mkOption { type = types.listOf types.str; - default = []; - example = [ "10.0.0.1@3721 my_key" "::5 NOKEY" ]; + default = [ ]; + example = [ + "10.0.0.1@3721 my_key" + "::5 NOKEY" + ]; description = '' This primary server will notify all given secondary servers about zone changes. @@ -388,8 +413,11 @@ let provideXFR = mkOption { type = types.listOf types.str; - default = []; - example = [ "192.0.2.0/24 NOKEY" "192.0.2.0/24 my_tsig_key_name" ]; + default = [ ]; + example = [ + "192.0.2.0/24 NOKEY" + "192.0.2.0/24 my_tsig_key_name" + ]; description = '' Allow these IPs and TSIG to transfer zones, addr TSIG|NOKEY|BLOCKED address range 192.0.2.0/24, 1.2.3.4&255.255.0.0, 3.0.2.20-3.0.2.40 @@ -398,15 +426,28 @@ let requestXFR = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = '' Format: `[AXFR|UDP] ` ''; }; rrlWhitelist = mkOption { - type = with types; listOf (enum [ "nxdomain" "error" "referral" "any" "rrsig" "wildcard" "nodata" "dnskey" "positive" "all" ]); - default = []; + type = + with types; + listOf (enum [ + "nxdomain" + "error" + "referral" + "any" + "rrsig" + "wildcard" + "nodata" + "dnskey" + "positive" + "all" + ]); + default = [ ]; description = '' Whitelists the given rrl-types. ''; @@ -450,7 +491,7 @@ let dnssecZones = (filterAttrs (n: v: if v ? dnssec then v.dnssec else false) zoneConfigs); - dnssec = dnssecZones != {}; + dnssec = dnssecZones != { }; dnssecTools = pkgs.bind.override { enablePython = true; }; @@ -464,21 +505,23 @@ let ${dnssecTools}/bin/dnssec-signzone -S -K ${stateDir}/dnssec -o ${name} -O full -N date ${stateDir}/zones/${name} ${nsdPkg}/sbin/nsd-checkzone ${name} ${stateDir}/zones/${name}.signed && mv -v ${stateDir}/zones/${name}.signed ${stateDir}/zones/${name} ''; - policyFile = name: policy: pkgs.writeText "${name}.policy" '' - zone ${name} { - algorithm ${policy.algorithm}; - key-size zsk ${toString policy.zsk.keySize}; - key-size ksk ${toString policy.ksk.keySize}; - keyttl ${policy.keyttl}; - pre-publish zsk ${policy.zsk.prePublish}; - pre-publish ksk ${policy.ksk.prePublish}; - post-publish zsk ${policy.zsk.postPublish}; - post-publish ksk ${policy.ksk.postPublish}; - roll-period zsk ${policy.zsk.rollPeriod}; - roll-period ksk ${policy.ksk.rollPeriod}; - coverage ${policy.coverage}; - }; - ''; + policyFile = + name: policy: + pkgs.writeText "${name}.policy" '' + zone ${name} { + algorithm ${policy.algorithm}; + key-size zsk ${toString policy.zsk.keySize}; + key-size ksk ${toString policy.ksk.keySize}; + keyttl ${policy.keyttl}; + pre-publish zsk ${policy.zsk.prePublish}; + pre-publish ksk ${policy.ksk.prePublish}; + post-publish zsk ${policy.zsk.postPublish}; + post-publish ksk ${policy.ksk.postPublish}; + roll-period zsk ${policy.zsk.rollPeriod}; + roll-period ksk ${policy.ksk.rollPeriod}; + coverage ${policy.coverage}; + }; + ''; in { # options are ordered alphanumerically @@ -522,7 +565,10 @@ in interfaces = mkOption { type = types.listOf types.str; - default = [ "127.0.0.0" "::1" ]; + default = [ + "127.0.0.0" + "::1" + ]; description = '' What addresses the server should listen to. ''; @@ -711,32 +757,33 @@ in ''; }; - keys = mkOption { - type = types.attrsOf (types.submodule { - options = { - - algorithm = mkOption { - type = types.str; - default = "hmac-sha256"; - description = '' - Authentication algorithm for this key. - ''; - }; + type = types.attrsOf ( + types.submodule { + options = { + + algorithm = mkOption { + type = types.str; + default = "hmac-sha256"; + description = '' + Authentication algorithm for this key. + ''; + }; - keyFile = mkOption { - type = types.path; - description = '' - Path to the file which contains the actual base64 encoded - key. The key will be copied into "${stateDir}/private" before - NSD starts. The copied file is only accessibly by the NSD - user. - ''; - }; + keyFile = mkOption { + type = types.path; + description = '' + Path to the file which contains the actual base64 encoded + key. The key will be copied into "${stateDir}/private" before + NSD starts. The copied file is only accessibly by the NSD + user. + ''; + }; - }; - }); - default = {}; + }; + } + ); + default = { }; example = literalExpression '' { "tsig.example.org" = { algorithm = "hmac-md5"; @@ -749,7 +796,6 @@ in ''; }; - ratelimit = { enable = mkEnableOption "ratelimit capabilities"; @@ -810,7 +856,6 @@ in }; - remoteControl = { enable = mkEnableOption "remote control via nsd-control"; @@ -835,7 +880,10 @@ in interfaces = mkOption { type = types.listOf types.str; - default = [ "127.0.0.1" "::1" ]; + default = [ + "127.0.0.1" + "::1" + ]; description = '' Which interfaces NSD should bind to for remote control. ''; @@ -871,7 +919,7 @@ in zones = mkOption { type = types.attrsOf zoneOptions; - default = {}; + default = { }; example = literalExpression '' { "serverGroup1" = { provideXFR = [ "10.1.2.3 NOKEY" ]; @@ -918,8 +966,9 @@ in assertions = singleton { assertion = zoneConfigs ? "." -> cfg.rootServer; - message = "You have a root zone configured. If this is really what you " - + "want, please enable 'services.nsd.rootServer'."; + message = + "You have a root zone configured. If this is really what you " + + "want, please enable 'services.nsd.rootServer'."; }; environment = { @@ -932,7 +981,7 @@ in users.users.${username} = { description = "NSD service user"; home = stateDir; - createHome = true; + createHome = true; uid = config.ids.uids.nsd; group = username; }; @@ -944,7 +993,7 @@ in wantedBy = [ "multi-user.target" ]; startLimitBurst = 4; - startLimitIntervalSec = 5 * 60; # 5 mins + startLimitIntervalSec = 5 * 60; # 5 mins serviceConfig = { ExecStart = "${nsdPkg}/sbin/nsd -d -c ${nsdEnv}/nsd.conf"; StandardError = "null"; diff --git a/nixos/modules/services/networking/ntopng.nix b/nixos/modules/services/networking/ntopng.nix index ebe9e3072e982c..d8b4b86a265116 100644 --- a/nixos/modules/services/networking/ntopng.nix +++ b/nixos/modules/services/networking/ntopng.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with lib; @@ -14,19 +20,20 @@ let else "redis-${cfg.redis.createInstance}.service"; - configFile = if cfg.configText != "" then - pkgs.writeText "ntopng.conf" '' - ${cfg.configText} - '' + configFile = + if cfg.configText != "" then + pkgs.writeText "ntopng.conf" '' + ${cfg.configText} + '' else - pkgs.writeText "ntopng.conf" '' - ${concatStringsSep "\n" (map (e: "--interface=${e}") cfg.interfaces)} - --http-port=${toString cfg.httpPort} - --redis=${cfg.redis.address} - --data-dir=/var/lib/ntopng - --user=ntopng - ${cfg.extraConfig} - ''; + pkgs.writeText "ntopng.conf" '' + ${concatStringsSep "\n" (map (e: "--interface=${e}") cfg.interfaces)} + --http-port=${toString cfg.httpPort} + --redis=${cfg.redis.address} + --data-dir=/var/lib/ntopng + --user=ntopng + ${cfg.extraConfig} + ''; in @@ -61,7 +68,10 @@ in interfaces = mkOption { default = [ "any" ]; - example = [ "eth0" "wlan0" ]; + example = [ + "eth0" + "wlan0" + ]; type = types.listOf types.str; description = '' List of interfaces to monitor. Use "any" to monitor all interfaces. @@ -126,7 +136,8 @@ in # ntopng uses redis for data storage services.ntopng.redis.address = - mkIf createRedis config.services.redis.servers.${cfg.redis.createInstance}.unixSocket; + mkIf createRedis + config.services.redis.servers.${cfg.redis.createInstance}.unixSocket; services.redis.servers = mkIf createRedis { ${cfg.redis.createInstance} = { diff --git a/nixos/modules/services/networking/ntp/ntpd-rs.nix b/nixos/modules/services/networking/ntp/ntpd-rs.nix index 296c89c4c6f54d..557bf05fbc42a6 100644 --- a/nixos/modules/services/networking/ntp/ntpd-rs.nix +++ b/nixos/modules/services/networking/ntp/ntpd-rs.nix @@ -1,4 +1,9 @@ -{ lib, config, pkgs, ... }: +{ + lib, + config, + pkgs, + ... +}: let cfg = config.services.ntpd-rs; @@ -56,12 +61,12 @@ in observability = { observation-path = lib.mkDefault "/var/run/ntpd-rs/observe"; }; - source = lib.mkIf cfg.useNetworkingTimeServers (map - (ts: { + source = lib.mkIf cfg.useNetworkingTimeServers ( + map (ts: { mode = "server"; address = ts; - }) - config.networking.timeServers); + }) config.networking.timeServers + ); }; systemd.services.ntpd-rs = { @@ -70,7 +75,10 @@ in User = ""; Group = ""; DynamicUser = true; - ExecStart = [ "" "${lib.makeBinPath [ cfg.package ]}/ntp-daemon --config=${configFile}" ]; + ExecStart = [ + "" + "${lib.makeBinPath [ cfg.package ]}/ntp-daemon --config=${configFile}" + ]; }; }; @@ -80,7 +88,10 @@ in User = ""; Group = ""; DynamicUser = true; - ExecStart = [ "" "${lib.makeBinPath [ cfg.package ]}/ntp-metrics-exporter --config=${configFile}" ]; + ExecStart = [ + "" + "${lib.makeBinPath [ cfg.package ]}/ntp-metrics-exporter --config=${configFile}" + ]; }; }; }; diff --git a/nixos/modules/services/networking/ntp/openntpd.nix b/nixos/modules/services/networking/ntp/openntpd.nix index 9414be1f85021d..c4ad630826b5c1 100644 --- a/nixos/modules/services/networking/ntp/openntpd.nix +++ b/nixos/modules/services/networking/ntp/openntpd.nix @@ -1,4 +1,10 @@ -{ pkgs, lib, config, options, ... }: +{ + pkgs, + lib, + config, + options, + ... +}: with lib; @@ -67,14 +73,21 @@ in description = "OpenNTP daemon user"; home = "/var/empty"; }; - users.groups.ntp = {}; + users.groups.ntp = { }; systemd.services.openntpd = { description = "OpenNTP Server"; wantedBy = [ "multi-user.target" ]; - wants = [ "network-online.target" "time-sync.target" ]; + wants = [ + "network-online.target" + "time-sync.target" + ]; before = [ "time-sync.target" ]; - after = [ "dnsmasq.service" "bind.service" "network-online.target" ]; + after = [ + "dnsmasq.service" + "bind.service" + "network-online.target" + ]; serviceConfig = { ExecStart = "${package}/sbin/ntpd -p ${pidFile} ${cfg.extraOptions}"; Type = "forking"; diff --git a/nixos/modules/services/networking/nullidentdmod.nix b/nixos/modules/services/networking/nullidentdmod.nix index b0d338a2794108..db53091f073278 100644 --- a/nixos/modules/services/networking/nullidentdmod.nix +++ b/nixos/modules/services/networking/nullidentdmod.nix @@ -1,7 +1,15 @@ -{ config, lib, pkgs, ... }: with lib; let +{ + config, + lib, + pkgs, + ... +}: +with lib; +let cfg = config.services.nullidentdmod; -in { +in +{ options.services.nullidentdmod = with types; { enable = mkEnableOption "the nullidentdmod identd daemon"; @@ -25,7 +33,9 @@ in { description = "NullidentdMod service"; serviceConfig = { DynamicUser = true; - ExecStart = "${pkgs.nullidentdmod}/bin/nullidentdmod${optionalString (cfg.userid != null) " ${cfg.userid}"}"; + ExecStart = "${pkgs.nullidentdmod}/bin/nullidentdmod${ + optionalString (cfg.userid != null) " ${cfg.userid}" + }"; StandardInput = "socket"; StandardOutput = "socket"; }; diff --git a/nixos/modules/services/networking/nylon.nix b/nixos/modules/services/networking/nylon.nix index 2e5399a05c3c9f..b9d579a61c1e91 100644 --- a/nixos/modules/services/networking/nylon.nix +++ b/nixos/modules/services/networking/nylon.nix @@ -1,119 +1,134 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.nylon; homeDir = "/var/lib/nylon"; - configFile = cfg: pkgs.writeText "nylon-${cfg.name}.conf" '' - [General] - No-Simultaneous-Conn=${toString cfg.nrConnections} - Log=${if cfg.logging then "1" else "0"} - Verbose=${if cfg.verbosity then "1" else "0"} - - [Server] - Binding-Interface=${cfg.acceptInterface} - Connecting-Interface=${cfg.bindInterface} - Port=${toString cfg.port} - Allow-IP=${lib.concatStringsSep " " cfg.allowedIPRanges} - Deny-IP=${lib.concatStringsSep " " cfg.deniedIPRanges} - ''; - - nylonOpts = { name, ... }: { - - options = { - - enable = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Enables nylon as a running service upon activation. - ''; - }; - - name = lib.mkOption { - type = lib.types.str; - default = ""; - description = "The name of this nylon instance."; - }; - - nrConnections = lib.mkOption { - type = lib.types.int; - default = 10; - description = '' - The number of allowed simultaneous connections to the daemon, default 10. - ''; + configFile = + cfg: + pkgs.writeText "nylon-${cfg.name}.conf" '' + [General] + No-Simultaneous-Conn=${toString cfg.nrConnections} + Log=${if cfg.logging then "1" else "0"} + Verbose=${if cfg.verbosity then "1" else "0"} + + [Server] + Binding-Interface=${cfg.acceptInterface} + Connecting-Interface=${cfg.bindInterface} + Port=${toString cfg.port} + Allow-IP=${lib.concatStringsSep " " cfg.allowedIPRanges} + Deny-IP=${lib.concatStringsSep " " cfg.deniedIPRanges} + ''; + + nylonOpts = + { name, ... }: + { + + options = { + + enable = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Enables nylon as a running service upon activation. + ''; + }; + + name = lib.mkOption { + type = lib.types.str; + default = ""; + description = "The name of this nylon instance."; + }; + + nrConnections = lib.mkOption { + type = lib.types.int; + default = 10; + description = '' + The number of allowed simultaneous connections to the daemon, default 10. + ''; + }; + + logging = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Enable logging, default is no logging. + ''; + }; + + verbosity = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Enable verbose output, default is to not be verbose. + ''; + }; + + acceptInterface = lib.mkOption { + type = lib.types.str; + default = "lo"; + description = '' + Tell nylon which interface to listen for client requests on, default is "lo". + ''; + }; + + bindInterface = lib.mkOption { + type = lib.types.str; + default = "enp3s0f0"; + description = '' + Tell nylon which interface to use as an uplink, default is "enp3s0f0". + ''; + }; + + port = lib.mkOption { + type = lib.types.port; + default = 1080; + description = '' + What port to listen for client requests, default is 1080. + ''; + }; + + allowedIPRanges = lib.mkOption { + type = with lib.types; listOf str; + default = [ + "192.168.0.0/16" + "127.0.0.1/8" + "172.16.0.1/12" + "10.0.0.0/8" + ]; + description = '' + Allowed client IP ranges are evaluated first, defaults to ARIN IPv4 private ranges: + [ "192.168.0.0/16" "127.0.0.0/8" "172.16.0.0/12" "10.0.0.0/8" ] + ''; + }; + + deniedIPRanges = lib.mkOption { + type = with lib.types; listOf str; + default = [ "0.0.0.0/0" ]; + description = '' + Denied client IP ranges, these gets evaluated after the allowed IP ranges, defaults to all IPv4 addresses: + [ "0.0.0.0/0" ] + To block all other access than the allowed. + ''; + }; }; - - logging = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Enable logging, default is no logging. - ''; - }; - - verbosity = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Enable verbose output, default is to not be verbose. - ''; - }; - - acceptInterface = lib.mkOption { - type = lib.types.str; - default = "lo"; - description = '' - Tell nylon which interface to listen for client requests on, default is "lo". - ''; - }; - - bindInterface = lib.mkOption { - type = lib.types.str; - default = "enp3s0f0"; - description = '' - Tell nylon which interface to use as an uplink, default is "enp3s0f0". - ''; - }; - - port = lib.mkOption { - type = lib.types.port; - default = 1080; - description = '' - What port to listen for client requests, default is 1080. - ''; - }; - - allowedIPRanges = lib.mkOption { - type = with lib.types; listOf str; - default = [ "192.168.0.0/16" "127.0.0.1/8" "172.16.0.1/12" "10.0.0.0/8" ]; - description = '' - Allowed client IP ranges are evaluated first, defaults to ARIN IPv4 private ranges: - [ "192.168.0.0/16" "127.0.0.0/8" "172.16.0.0/12" "10.0.0.0/8" ] - ''; - }; - - deniedIPRanges = lib.mkOption { - type = with lib.types; listOf str; - default = [ "0.0.0.0/0" ]; - description = '' - Denied client IP ranges, these gets evaluated after the allowed IP ranges, defaults to all IPv4 addresses: - [ "0.0.0.0/0" ] - To block all other access than the allowed. - ''; + config = { + name = lib.mkDefault name; }; }; - config = { name = lib.mkDefault name; }; - }; mkNamedNylon = cfg: { "nylon-${cfg.name}" = { description = "Nylon, a lightweight SOCKS proxy server"; after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; - serviceConfig = - { + serviceConfig = { User = "nylon"; Group = "nylon"; WorkingDirectory = homeDir; @@ -135,7 +150,7 @@ in options = { services.nylon = lib.mkOption { - default = {}; + default = { }; description = "Collection of named nylon instances"; type = with lib.types; attrsOf (submodule nylonOpts); internal = true; @@ -145,7 +160,7 @@ in ###### implementation - config = lib.mkIf (lib.length(enabledNylons) > 0) { + config = lib.mkIf (lib.length (enabledNylons) > 0) { users.users.nylon = { group = "nylon"; @@ -157,7 +172,7 @@ in users.groups.nylon.gid = config.ids.gids.nylon; - systemd.services = lib.foldr (a: b: a // b) {} nylonUnits; + systemd.services = lib.foldr (a: b: a // b) { } nylonUnits; }; } diff --git a/nixos/modules/services/networking/ocserv.nix b/nixos/modules/services/networking/ocserv.nix index afdd8254ffd228..6c403a9b342700 100644 --- a/nixos/modules/services/networking/ocserv.nix +++ b/nixos/modules/services/networking/ocserv.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -80,13 +85,16 @@ in environment.systemPackages = [ pkgs.ocserv ]; environment.etc."ocserv/ocserv.conf".text = cfg.config; - security.pam.services.ocserv = {}; + security.pam.services.ocserv = { }; systemd.services.ocserv = { description = "OpenConnect SSL VPN server"; documentation = [ "man:ocserv(8)" ]; wants = [ "network-online.target" ]; - after = [ "dbus.service" "network-online.target" ]; + after = [ + "dbus.service" + "network-online.target" + ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { diff --git a/nixos/modules/services/networking/ofono.nix b/nixos/modules/services/networking/ofono.nix index 460b06443c412c..640251ae920061 100644 --- a/nixos/modules/services/networking/ofono.nix +++ b/nixos/modules/services/networking/ofono.nix @@ -1,5 +1,10 @@ # Ofono daemon. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -7,11 +12,7 @@ let cfg = config.services.ofono; - plugin_path = - lib.concatMapStringsSep ":" - (plugin: "${plugin}/lib/ofono/plugins") - cfg.plugins - ; + plugin_path = lib.concatMapStringsSep ":" (plugin: "${plugin}/lib/ofono/plugins") cfg.plugins; in @@ -23,7 +24,7 @@ in plugins = mkOption { type = types.listOf types.package; - default = []; + default = [ ]; example = literalExpression "[ pkgs.modem-manager-gui ]"; description = '' The list of plugins to install. @@ -38,7 +39,7 @@ in systemd.packages = [ pkgs.ofono ]; - systemd.services.ofono.environment.OFONO_PLUGIN_PATH = mkIf (cfg.plugins != []) plugin_path; + systemd.services.ofono.environment.OFONO_PLUGIN_PATH = mkIf (cfg.plugins != [ ]) plugin_path; }; } diff --git a/nixos/modules/services/networking/oidentd.nix b/nixos/modules/services/networking/oidentd.nix index feb84806ba99ce..159da0913995b6 100644 --- a/nixos/modules/services/networking/oidentd.nix +++ b/nixos/modules/services/networking/oidentd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -20,7 +25,6 @@ with lib; }; - ###### implementation config = mkIf config.services.oidentd.enable { diff --git a/nixos/modules/services/networking/oink.nix b/nixos/modules/services/networking/oink.nix index 7954cbed709d23..e98c1690ee5259 100644 --- a/nixos/modules/services/networking/oink.nix +++ b/nixos/modules/services/networking/oink.nix @@ -1,8 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.oink; - makeOinkConfig = attrs: (pkgs.formats.json { }).generate - "oink.json" (lib.mapAttrs' (k: v: lib.nameValuePair (lib.toLower k) v) attrs); + makeOinkConfig = + attrs: + (pkgs.formats.json { }).generate "oink.json" ( + lib.mapAttrs' (k: v: lib.nameValuePair (lib.toLower k) v) attrs + ); oinkConfig = makeOinkConfig { global = cfg.settings; domains = cfg.domains; @@ -40,7 +48,7 @@ in }; domains = lib.mkOption { type = with lib.types; listOf (attrsOf anything); - default = []; + default = [ ]; example = [ { domain = "nixos.org"; diff --git a/nixos/modules/services/networking/onedrive.nix b/nixos/modules/services/networking/onedrive.nix index 0c4e27507c1c61..dae3ed31b30bcf 100644 --- a/nixos/modules/services/networking/onedrive.nix +++ b/nixos/modules/services/networking/onedrive.nix @@ -1,43 +1,46 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.onedrive; - onedriveLauncher = pkgs.writeShellScriptBin - "onedrive-launcher" - '' - # XDG_CONFIG_HOME is not recognized in the environment here. - if [ -f $HOME/.config/onedrive-launcher ] - then - # Hopefully using underscore boundary helps locate variables - for _onedrive_config_dirname_ in $(cat $HOME/.config/onedrive-launcher | grep -v '[ \t]*#' ) - do - systemctl --user start onedrive@$_onedrive_config_dirname_ - done - else - systemctl --user start onedrive@onedrive - fi - '' - ; + onedriveLauncher = pkgs.writeShellScriptBin "onedrive-launcher" '' + # XDG_CONFIG_HOME is not recognized in the environment here. + if [ -f $HOME/.config/onedrive-launcher ] + then + # Hopefully using underscore boundary helps locate variables + for _onedrive_config_dirname_ in $(cat $HOME/.config/onedrive-launcher | grep -v '[ \t]*#' ) + do + systemctl --user start onedrive@$_onedrive_config_dirname_ + done + else + systemctl --user start onedrive@onedrive + fi + ''; -in { +in +{ ### Documentation # meta.doc = ./onedrive.xml; ### Interface options.services.onedrive = { - enable = lib.mkEnableOption "OneDrive service"; + enable = lib.mkEnableOption "OneDrive service"; - package = lib.mkOption { - type = lib.types.package; - default = pkgs.onedrive; - defaultText = lib.literalExpression "pkgs.onedrive"; - description = '' - OneDrive package to use. - ''; - }; + package = lib.mkOption { + type = lib.types.package; + default = pkgs.onedrive; + defaultText = lib.literalExpression "pkgs.onedrive"; + description = '' + OneDrive package to use. + ''; + }; }; -### Implementation + ### Implementation config = lib.mkIf cfg.enable { environment.systemPackages = [ cfg.package ]; @@ -50,9 +53,9 @@ in { ExecStart = '' ${cfg.package}/bin/onedrive --monitor --confdir=%h/.config/%i ''; - Restart="on-failure"; - RestartSec=3; - RestartPreventExitStatus=3; + Restart = "on-failure"; + RestartSec = 3; + RestartPreventExitStatus = 3; }; }; diff --git a/nixos/modules/services/networking/openconnect.nix b/nixos/modules/services/networking/openconnect.nix index e2c06943e1d723..6660e769f48ad1 100644 --- a/nixos/modules/services/networking/openconnect.nix +++ b/nixos/modules/services/networking/openconnect.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with lib; let cfg = config.networking.openconnect; @@ -24,8 +30,15 @@ let protocol = mkOption { description = "Protocol to use."; example = "anyconnect"; - type = - types.enum [ "anyconnect" "array" "nc" "pulse" "gp" "f5" "fortinet" ]; + type = types.enum [ + "anyconnect" + "array" + "nc" + "pulse" + "gp" + "f5" + "fortinet" + ]; }; user = mkOption { @@ -83,18 +96,21 @@ let }; }; }; - generateExtraConfig = extra_cfg: - strings.concatStringsSep "\n" (attrsets.mapAttrsToList - (name: value: if (value == true) then name else "${name}=${value}") - (attrsets.filterAttrs (_: value: value != false) extra_cfg)); - generateConfig = name: icfg: + generateExtraConfig = + extra_cfg: + strings.concatStringsSep "\n" ( + attrsets.mapAttrsToList (name: value: if (value == true) then name else "${name}=${value}") ( + attrsets.filterAttrs (_: value: value != false) extra_cfg + ) + ); + generateConfig = + name: icfg: pkgs.writeText "config" '' interface=${name} ${optionalString (icfg.protocol != null) "protocol=${icfg.protocol}"} ${optionalString (icfg.user != null) "user=${icfg.user}"} ${optionalString (icfg.passwordFile != null) "passwd-on-stdin"} - ${optionalString (icfg.certificate != null) - "certificate=${icfg.certificate}"} + ${optionalString (icfg.certificate != null) "certificate=${icfg.certificate}"} ${optionalString (icfg.privateKey != null) "sslkey=${icfg.privateKey}"} ${generateExtraConfig icfg.extraOptions} @@ -102,20 +118,22 @@ let generateUnit = name: icfg: { description = "OpenConnect Interface - ${name}"; requires = [ "network-online.target" ]; - after = [ "network.target" "network-online.target" ]; + after = [ + "network.target" + "network-online.target" + ]; wantedBy = optional icfg.autoStart "multi-user.target"; serviceConfig = { Type = "simple"; - ExecStart = "${openconnect}/bin/openconnect --config=${ - generateConfig name icfg - } ${icfg.gateway}"; + ExecStart = "${openconnect}/bin/openconnect --config=${generateConfig name icfg} ${icfg.gateway}"; StandardInput = lib.mkIf (icfg.passwordFile != null) "file:${icfg.passwordFile}"; ProtectHome = true; }; }; -in { +in +{ options.networking.openconnect = { package = mkPackageOption pkgs "openconnect" { }; diff --git a/nixos/modules/services/networking/ostinato.nix b/nixos/modules/services/networking/ostinato.nix index 635c4e9bc0fa63..cfe7f934bf3621 100644 --- a/nixos/modules/services/networking/ostinato.nix +++ b/nixos/modules/services/networking/ostinato.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -37,7 +42,10 @@ in }; rateAccuracy = mkOption { - type = types.enum [ "High" "Low" ]; + type = types.enum [ + "High" + "Low" + ]; default = "High"; description = '' To ensure that the actual transmit rate is as close as possible to @@ -64,8 +72,11 @@ in portList = { include = mkOption { type = types.listOf types.str; - default = []; - example = [ "eth*" "lo*" ]; + default = [ ]; + example = [ + "eth*" + "lo*" + ]; description = '' For a port to pass the filter and appear on the port list managed by drone, it be allowed by this include list. @@ -73,8 +84,11 @@ in }; exclude = mkOption { type = types.listOf types.str; - default = []; - example = [ "usbmon*" "eth0" ]; + default = [ ]; + example = [ + "usbmon*" + "eth0" + ]; description = '' A list of ports does not appear on the port list managed by drone. ''; diff --git a/nixos/modules/services/networking/owamp.nix b/nixos/modules/services/networking/owamp.nix index 45907f7d6e9a7f..da6b7b78042ccd 100644 --- a/nixos/modules/services/networking/owamp.nix +++ b/nixos/modules/services/networking/owamp.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -13,7 +18,6 @@ in services.owamp.enable = mkEnableOption "OWAMP server"; }; - ###### implementation config = mkIf cfg.enable { @@ -30,10 +34,10 @@ in wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart="${pkgs.owamp}/bin/owampd -R /run/owamp -d /run/owamp -v -Z "; + ExecStart = "${pkgs.owamp}/bin/owampd -R /run/owamp -d /run/owamp -v -Z "; PrivateTmp = true; Restart = "always"; - Type="simple"; + Type = "simple"; User = "owamp"; Group = "owamp"; RuntimeDirectory = "owamp"; diff --git a/nixos/modules/services/networking/pdns-recursor.nix b/nixos/modules/services/networking/pdns-recursor.nix index a03a20e6bc6dc7..3b554c7e31a165 100644 --- a/nixos/modules/services/networking/pdns-recursor.nix +++ b/nixos/modules/services/networking/pdns-recursor.nix @@ -1,37 +1,60 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.pdns-recursor; - oneOrMore = type: with types; either type (listOf type); - valueType = with types; oneOf [ int str bool path ]; + oneOrMore = type: with types; either type (listOf type); + valueType = + with types; + oneOf [ + int + str + bool + path + ]; configType = with types; attrsOf (nullOr (oneOrMore valueType)); - toBool = val: if val then "yes" else "no"; - serialize = val: with types; - if str.check val then val - else if int.check val then toString val - else if path.check val then toString val - else if bool.check val then toBool val - else if builtins.isList val then (concatMapStringsSep "," serialize val) - else ""; - - configDir = pkgs.writeTextDir "recursor.conf" - (concatStringsSep "\n" - (flip mapAttrsToList cfg.settings - (name: val: "${name}=${serialize val}"))); + toBool = val: if val then "yes" else "no"; + serialize = + val: + with types; + if str.check val then + val + else if int.check val then + toString val + else if path.check val then + toString val + else if bool.check val then + toBool val + else if builtins.isList val then + (concatMapStringsSep "," serialize val) + else + ""; + + configDir = pkgs.writeTextDir "recursor.conf" ( + concatStringsSep "\n" (flip mapAttrsToList cfg.settings (name: val: "${name}=${serialize val}")) + ); mkDefaultAttrs = mapAttrs (n: v: mkDefault v); -in { +in +{ options.services.pdns-recursor = { enable = mkEnableOption "PowerDNS Recursor, a recursive DNS server"; dns.address = mkOption { type = oneOrMore types.str; - default = [ "::" "0.0.0.0" ]; + default = [ + "::" + "0.0.0.0" + ]; description = '' IP addresses Recursor DNS server will bind to. ''; @@ -48,11 +71,20 @@ in { dns.allowFrom = mkOption { type = types.listOf types.str; default = [ - "127.0.0.0/8" "10.0.0.0/8" "100.64.0.0/10" - "169.254.0.0/16" "192.168.0.0/16" "172.16.0.0/12" - "::1/128" "fc00::/7" "fe80::/10" + "127.0.0.0/8" + "10.0.0.0/8" + "100.64.0.0/10" + "169.254.0.0/16" + "192.168.0.0/16" + "172.16.0.0/12" + "::1/128" + "fc00::/7" + "fe80::/10" + ]; + example = [ + "0.0.0.0/0" + "::/0" ]; - example = [ "0.0.0.0/0" "::/0" ]; description = '' IP address ranges of clients allowed to make DNS queries. ''; @@ -76,8 +108,14 @@ in { api.allowFrom = mkOption { type = types.listOf types.str; - default = [ "127.0.0.1" "::1" ]; - example = [ "0.0.0.0/0" "::/0" ]; + default = [ + "127.0.0.1" + "::1" + ]; + example = [ + "0.0.0.0/0" + "::/0" + ]; description = '' IP address ranges of clients allowed to make API requests. ''; @@ -87,13 +125,13 @@ in { type = types.bool; default = false; description = '' - Whether to export names and IP addresses defined in /etc/hosts. + Whether to export names and IP addresses defined in /etc/hosts. ''; }; forwardZones = mkOption { type = types.attrs; - default = {}; + default = { }; description = '' DNS zones to be forwarded to other authoritative servers. ''; @@ -101,15 +139,23 @@ in { forwardZonesRecurse = mkOption { type = types.attrs; - example = { eth = "[::1]:5353"; }; - default = {}; + example = { + eth = "[::1]:5353"; + }; + default = { }; description = '' DNS zones to be forwarded to other recursive servers. ''; }; dnssecValidation = mkOption { - type = types.enum ["off" "process-no-validate" "process" "log-fail" "validate"]; + type = types.enum [ + "off" + "process-no-validate" + "process" + "log-fail" + "validate" + ]; default = "validate"; description = '' Controls the level of DNSSEC processing done by the PowerDNS Recursor. @@ -163,23 +209,23 @@ in { services.pdns-recursor.settings = mkDefaultAttrs { local-address = cfg.dns.address; - local-port = cfg.dns.port; - allow-from = cfg.dns.allowFrom; + local-port = cfg.dns.port; + allow-from = cfg.dns.allowFrom; - webserver-address = cfg.api.address; - webserver-port = cfg.api.port; + webserver-address = cfg.api.address; + webserver-port = cfg.api.port; webserver-allow-from = cfg.api.allowFrom; - forward-zones = mapAttrsToList (zone: uri: "${zone}.=${uri}") cfg.forwardZones; + forward-zones = mapAttrsToList (zone: uri: "${zone}.=${uri}") cfg.forwardZones; forward-zones-recurse = mapAttrsToList (zone: uri: "${zone}.=${uri}") cfg.forwardZonesRecurse; export-etc-hosts = cfg.exportHosts; - dnssec = cfg.dnssecValidation; - serve-rfc1918 = cfg.serveRFC1918; - lua-config-file = pkgs.writeText "recursor.lua" cfg.luaConfig; + dnssec = cfg.dnssecValidation; + serve-rfc1918 = cfg.serveRFC1918; + lua-config-file = pkgs.writeText "recursor.lua" cfg.luaConfig; - daemon = false; - write-pid = false; - log-timestamp = false; + daemon = false; + write-pid = false; + log-timestamp = false; disable-syslog = true; }; @@ -189,7 +235,10 @@ in { wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart = [ "" "${pkgs.pdns-recursor}/bin/pdns_recursor --config-dir=${configDir}" ]; + ExecStart = [ + "" + "${pkgs.pdns-recursor}/bin/pdns_recursor --config-dir=${configDir}" + ]; }; }; @@ -199,13 +248,16 @@ in { description = "PowerDNS Recursor daemon user"; }; - users.groups.pdns-recursor = {}; + users.groups.pdns-recursor = { }; }; imports = [ - (mkRemovedOptionModule [ "services" "pdns-recursor" "extraConfig" ] - "To change extra Recursor settings use services.pdns-recursor.settings instead.") + (mkRemovedOptionModule [ + "services" + "pdns-recursor" + "extraConfig" + ] "To change extra Recursor settings use services.pdns-recursor.settings instead.") ]; meta.maintainers = with lib.maintainers; [ rnhmjoj ]; diff --git a/nixos/modules/services/networking/pdnsd.nix b/nixos/modules/services/networking/pdnsd.nix index 50b9b9d2028918..cda55cc2a7e8b1 100644 --- a/nixos/modules/services/networking/pdnsd.nix +++ b/nixos/modules/services/networking/pdnsd.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -7,59 +12,59 @@ let pdnsd = pkgs.pdnsd; pdnsdUser = "pdnsd"; pdnsdGroup = "pdnsd"; - pdnsdConf = pkgs.writeText "pdnsd.conf" - '' - global { - run_as=${pdnsdUser}; - cache_dir="${cfg.cacheDir}"; - ${cfg.globalConfig} - } + pdnsdConf = pkgs.writeText "pdnsd.conf" '' + global { + run_as=${pdnsdUser}; + cache_dir="${cfg.cacheDir}"; + ${cfg.globalConfig} + } - server { - ${cfg.serverConfig} - } - ${cfg.extraConfig} - ''; + server { + ${cfg.serverConfig} + } + ${cfg.extraConfig} + ''; in -{ options = - { services.pdnsd = - { enable = mkEnableOption "pdnsd"; +{ + options = { + services.pdnsd = { + enable = mkEnableOption "pdnsd"; - cacheDir = mkOption { - type = types.str; - default = "/var/cache/pdnsd"; - description = "Directory holding the pdnsd cache"; - }; + cacheDir = mkOption { + type = types.str; + default = "/var/cache/pdnsd"; + description = "Directory holding the pdnsd cache"; + }; - globalConfig = mkOption { - type = types.lines; - default = ""; - description = '' - Global configuration that should be added to the global directory - of `pdnsd.conf`. - ''; - }; + globalConfig = mkOption { + type = types.lines; + default = ""; + description = '' + Global configuration that should be added to the global directory + of `pdnsd.conf`. + ''; + }; - serverConfig = mkOption { - type = types.lines; - default = ""; - description = '' - Server configuration that should be added to the server directory - of `pdnsd.conf`. - ''; - }; + serverConfig = mkOption { + type = types.lines; + default = ""; + description = '' + Server configuration that should be added to the server directory + of `pdnsd.conf`. + ''; + }; - extraConfig = mkOption { - type = types.lines; - default = ""; - description = '' - Extra configuration directives that should be added to - `pdnsd.conf`. - ''; - }; - }; + extraConfig = mkOption { + type = types.lines; + default = ""; + description = '' + Extra configuration directives that should be added to + `pdnsd.conf`. + ''; + }; }; + }; config = mkIf cfg.enable { users.users.${pdnsdUser} = { @@ -72,20 +77,18 @@ in gid = config.ids.gids.pdnsd; }; - systemd.services.pdnsd = - { wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - preStart = - '' - mkdir -p "${cfg.cacheDir}" - touch "${cfg.cacheDir}/pdnsd.cache" - chown -R ${pdnsdUser}:${pdnsdGroup} "${cfg.cacheDir}" - ''; - description = "pdnsd"; - serviceConfig = - { - ExecStart = "${pdnsd}/bin/pdnsd -c ${pdnsdConf}"; - }; + systemd.services.pdnsd = { + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + preStart = '' + mkdir -p "${cfg.cacheDir}" + touch "${cfg.cacheDir}/pdnsd.cache" + chown -R ${pdnsdUser}:${pdnsdGroup} "${cfg.cacheDir}" + ''; + description = "pdnsd"; + serviceConfig = { + ExecStart = "${pdnsd}/bin/pdnsd -c ${pdnsdConf}"; }; + }; }; } diff --git a/nixos/modules/services/networking/peroxide.nix b/nixos/modules/services/networking/peroxide.nix index 582e25fbacc9ad..101a5fdffeefcd 100644 --- a/nixos/modules/services/networking/peroxide.nix +++ b/nixos/modules/services/networking/peroxide.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -17,7 +22,15 @@ in logLevel = mkOption { # https://github.com/sirupsen/logrus#level-logging - type = types.enum [ "Panic" "Fatal" "Error" "Warning" "Info" "Debug" "Trace" ]; + type = types.enum [ + "Panic" + "Fatal" + "Error" + "Warning" + "Info" + "Debug" + "Trace" + ]; default = "Warning"; example = "Info"; description = "Only log messages of this priority or higher."; @@ -90,7 +103,10 @@ in LogsDirectoryMode = "0750"; # Specify just "peroxide" so that the user has write permission, because # peroxide deletes and recreates the cache directory on startup. - CacheDirectory = [ "peroxide" "peroxide/cache" ]; + CacheDirectory = [ + "peroxide" + "peroxide/cache" + ]; CacheDirectoryMode = "0700"; StateDirectory = stateDir; StateDirectoryMode = "0700"; @@ -127,5 +143,8 @@ in environment.systemPackages = [ cfg.package ]; }; - meta.maintainers = with maintainers; [ aanderse aidalgol ]; + meta.maintainers = with maintainers; [ + aanderse + aidalgol + ]; } diff --git a/nixos/modules/services/networking/picosnitch.nix b/nixos/modules/services/networking/picosnitch.nix index bdbb1e691227f8..841e05bdd62d59 100644 --- a/nixos/modules/services/networking/picosnitch.nix +++ b/nixos/modules/services/networking/picosnitch.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/networking/pixiecore.nix b/nixos/modules/services/networking/pixiecore.nix index 111cb7e3550409..fc0d5ec1a7abbe 100644 --- a/nixos/modules/services/networking/pixiecore.nix +++ b/nixos/modules/services/networking/pixiecore.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -23,7 +28,11 @@ in mode = mkOption { description = "Which mode to use"; default = "boot"; - type = types.enum [ "api" "boot" "quick" ]; + type = types.enum [ + "api" + "boot" + "quick" + ]; }; debug = mkOption { @@ -41,7 +50,15 @@ in quick = mkOption { description = "Which quick option to use"; default = "xyz"; - type = types.enum [ "arch" "centos" "coreos" "debian" "fedora" "ubuntu" "xyz" ]; + type = types.enum [ + "arch" + "centos" + "coreos" + "debian" + "fedora" + "ubuntu" + "xyz" + ]; }; kernel = mkOption { @@ -88,14 +105,14 @@ in extraArguments = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = "Additional command line arguments to pass to Pixiecore"; }; }; }; config = mkIf cfg.enable { - users.groups.pixiecore = {}; + users.groups.pixiecore = { }; users.users.pixiecore = { description = "Pixiecore daemon user"; group = "pixiecore"; @@ -103,15 +120,22 @@ in }; networking.firewall = mkIf cfg.openFirewall { - allowedTCPPorts = [ cfg.port cfg.statusPort ]; - allowedUDPPorts = [ 67 69 4011 ]; + allowedTCPPorts = [ + cfg.port + cfg.statusPort + ]; + allowedUDPPorts = [ + 67 + 69 + 4011 + ]; }; systemd.services.pixiecore = { description = "Pixiecore server"; - after = [ "network.target"]; - wants = [ "network.target"]; - wantedBy = [ "multi-user.target"]; + after = [ "network.target" ]; + wants = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; serviceConfig = { User = "pixiecore"; Restart = "always"; @@ -119,24 +143,37 @@ in ExecStart = let argString = - if cfg.mode == "boot" - then [ "boot" cfg.kernel ] - ++ optional (cfg.initrd != "") cfg.initrd - ++ optionals (cfg.cmdLine != "") [ "--cmdline" cfg.cmdLine ] - else if cfg.mode == "quick" - then [ "quick" cfg.quick ] - else [ "api" cfg.apiServer ]; + if cfg.mode == "boot" then + [ + "boot" + cfg.kernel + ] + ++ optional (cfg.initrd != "") cfg.initrd + ++ optionals (cfg.cmdLine != "") [ + "--cmdline" + cfg.cmdLine + ] + else if cfg.mode == "quick" then + [ + "quick" + cfg.quick + ] + else + [ + "api" + cfg.apiServer + ]; in - '' - ${pkgs.pixiecore}/bin/pixiecore \ - ${lib.escapeShellArgs argString} \ - ${optionalString cfg.debug "--debug"} \ - ${optionalString cfg.dhcpNoBind "--dhcp-no-bind"} \ - --listen-addr ${lib.escapeShellArg cfg.listen} \ - --port ${toString cfg.port} \ - --status-port ${toString cfg.statusPort} \ - ${escapeShellArgs cfg.extraArguments} - ''; + '' + ${pkgs.pixiecore}/bin/pixiecore \ + ${lib.escapeShellArgs argString} \ + ${optionalString cfg.debug "--debug"} \ + ${optionalString cfg.dhcpNoBind "--dhcp-no-bind"} \ + --listen-addr ${lib.escapeShellArg cfg.listen} \ + --port ${toString cfg.port} \ + --status-port ${toString cfg.statusPort} \ + ${escapeShellArgs cfg.extraArguments} + ''; }; }; }; diff --git a/nixos/modules/services/networking/polipo.nix b/nixos/modules/services/networking/polipo.nix index e9cac7181b5cb3..67f83358312e42 100644 --- a/nixos/modules/services/networking/polipo.nix +++ b/nixos/modules/services/networking/polipo.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -10,8 +15,8 @@ let proxyAddress = ${cfg.proxyAddress} proxyPort = ${toString cfg.proxyPort} allowedClients = ${concatStringsSep ", " cfg.allowedClients} - ${optionalString (cfg.parentProxy != "") "parentProxy = ${cfg.parentProxy}" } - ${optionalString (cfg.socksParentProxy != "") "socksParentProxy = ${cfg.socksParentProxy}" } + ${optionalString (cfg.parentProxy != "") "parentProxy = ${cfg.parentProxy}"} + ${optionalString (cfg.socksParentProxy != "") "socksParentProxy = ${cfg.socksParentProxy}"} ${config.services.polipo.extraConfig} ''; @@ -39,8 +44,16 @@ in allowedClients = mkOption { type = types.listOf types.str; - default = [ "127.0.0.1" "::1" ]; - example = [ "127.0.0.1" "::1" "134.157.168.0/24" "2001:660:116::/48" ]; + default = [ + "127.0.0.1" + "::1" + ]; + example = [ + "127.0.0.1" + "::1" + "134.157.168.0/24" + "2001:660:116::/48" + ]; description = '' List of IP addresses or network addresses that may connect to Polipo. ''; @@ -81,24 +94,27 @@ in config = mkIf cfg.enable { - users.users.polipo = - { uid = config.ids.uids.polipo; - description = "Polipo caching proxy user"; - home = "/var/cache/polipo"; - createHome = true; - }; + users.users.polipo = { + uid = config.ids.uids.polipo; + description = "Polipo caching proxy user"; + home = "/var/cache/polipo"; + createHome = true; + }; - users.groups.polipo = - { gid = config.ids.gids.polipo; - members = [ "polipo" ]; - }; + users.groups.polipo = { + gid = config.ids.gids.polipo; + members = [ "polipo" ]; + }; systemd.services.polipo = { description = "caching web proxy"; - after = [ "network.target" "nss-lookup.target" ]; - wantedBy = [ "multi-user.target"]; + after = [ + "network.target" + "nss-lookup.target" + ]; + wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart = "${pkgs.polipo}/bin/polipo -c ${polipoConfig}"; + ExecStart = "${pkgs.polipo}/bin/polipo -c ${polipoConfig}"; User = "polipo"; }; }; diff --git a/nixos/modules/services/networking/powerdns.nix b/nixos/modules/services/networking/powerdns.nix index bd8d08bc878cbd..ed4ec232b8d191 100644 --- a/nixos/modules/services/networking/powerdns.nix +++ b/nixos/modules/services/networking/powerdns.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,7 +11,8 @@ let cfg = config.services.powerdns; configDir = pkgs.writeTextDir "pdns.conf" "${cfg.extraConfig}"; finalConfigDir = if cfg.secretFile == null then configDir else "/run/pdns"; -in { +in +{ options = { services.powerdns = { enable = mkEnableOption "PowerDNS domain name server"; @@ -44,16 +50,25 @@ in { systemd.services.pdns = { wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "mysql.service" "postgresql.service" "openldap.service" ]; + after = [ + "network.target" + "mysql.service" + "postgresql.service" + "openldap.service" + ]; serviceConfig = { EnvironmentFile = lib.optional (cfg.secretFile != null) cfg.secretFile; - ExecStartPre = lib.optional (cfg.secretFile != null) - (pkgs.writeShellScript "pdns-pre-start" '' + ExecStartPre = lib.optional (cfg.secretFile != null) ( + pkgs.writeShellScript "pdns-pre-start" '' umask 077 ${pkgs.envsubst}/bin/envsubst -i "${configDir}/pdns.conf" > ${finalConfigDir}/pdns.conf - ''); - ExecStart = [ "" "${pkgs.pdns}/bin/pdns_server --config-dir=${finalConfigDir} --guardian=no --daemon=no --disable-syslog --log-timestamp=no --write-pid=no" ]; + '' + ); + ExecStart = [ + "" + "${pkgs.pdns}/bin/pdns_server --config-dir=${finalConfigDir} --guardian=no --daemon=no --disable-syslog --log-timestamp=no --write-pid=no" + ]; }; }; @@ -63,7 +78,7 @@ in { description = "PowerDNS"; }; - users.groups.pdns = {}; + users.groups.pdns = { }; }; } diff --git a/nixos/modules/services/networking/pppd.nix b/nixos/modules/services/networking/pppd.nix index 3642a4b15a661e..b4ea3e213f889d 100644 --- a/nixos/modules/services/networking/pppd.nix +++ b/nixos/modules/services/networking/pppd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -17,133 +22,139 @@ in package = mkPackageOption pkgs "ppp" { }; peers = mkOption { - default = {}; + default = { }; description = "pppd peers."; - type = types.attrsOf (types.submodule ( - { name, ... }: - { - options = { - name = mkOption { - type = types.str; - default = name; - example = "dialup"; - description = "Name of the PPP peer."; - }; + type = types.attrsOf ( + types.submodule ( + { name, ... }: + { + options = { + name = mkOption { + type = types.str; + default = name; + example = "dialup"; + description = "Name of the PPP peer."; + }; - enable = mkOption { - type = types.bool; - default = true; - example = false; - description = "Whether to enable this PPP peer."; - }; + enable = mkOption { + type = types.bool; + default = true; + example = false; + description = "Whether to enable this PPP peer."; + }; - autostart = mkOption { - type = types.bool; - default = true; - example = false; - description = "Whether the PPP session is automatically started at boot time."; - }; + autostart = mkOption { + type = types.bool; + default = true; + example = false; + description = "Whether the PPP session is automatically started at boot time."; + }; - config = mkOption { - type = types.lines; - default = ""; - description = "pppd configuration for this peer, see the pppd(8) man page."; + config = mkOption { + type = types.lines; + default = ""; + description = "pppd configuration for this peer, see the pppd(8) man page."; + }; }; - }; - })); + } + ) + ); }; }; }; - config = let - enabledConfigs = filter (f: f.enable) (attrValues cfg.peers); + config = + let + enabledConfigs = filter (f: f.enable) (attrValues cfg.peers); - mkEtc = peerCfg: { - name = "ppp/peers/${peerCfg.name}"; - value.text = peerCfg.config; - }; + mkEtc = peerCfg: { + name = "ppp/peers/${peerCfg.name}"; + value.text = peerCfg.config; + }; - mkSystemd = peerCfg: { - name = "pppd-${peerCfg.name}"; - value = { - restartTriggers = [ config.environment.etc."ppp/peers/${peerCfg.name}".source ]; - before = [ "network.target" ]; - wants = [ "network.target" ]; - after = [ "network-pre.target" ]; - environment = { - # pppd likes to write directly into /var/run. This is rude - # on a modern system, so we use libredirect to transparently - # move those files into /run/pppd. - LD_PRELOAD = "${pkgs.libredirect}/lib/libredirect.so"; - NIX_REDIRECTS = "/var/run=/run/pppd"; - }; - serviceConfig = let - capabilities = [ - "CAP_BPF" - "CAP_SYS_TTY_CONFIG" - "CAP_NET_ADMIN" - "CAP_NET_RAW" - ]; - in - { - ExecStart = "${getBin cfg.package}/sbin/pppd call ${peerCfg.name} nodetach nolog"; - Restart = "always"; - RestartSec = 5; + mkSystemd = peerCfg: { + name = "pppd-${peerCfg.name}"; + value = { + restartTriggers = [ config.environment.etc."ppp/peers/${peerCfg.name}".source ]; + before = [ "network.target" ]; + wants = [ "network.target" ]; + after = [ "network-pre.target" ]; + environment = { + # pppd likes to write directly into /var/run. This is rude + # on a modern system, so we use libredirect to transparently + # move those files into /run/pppd. + LD_PRELOAD = "${pkgs.libredirect}/lib/libredirect.so"; + NIX_REDIRECTS = "/var/run=/run/pppd"; + }; + serviceConfig = + let + capabilities = [ + "CAP_BPF" + "CAP_SYS_TTY_CONFIG" + "CAP_NET_ADMIN" + "CAP_NET_RAW" + ]; + in + { + ExecStart = "${getBin cfg.package}/sbin/pppd call ${peerCfg.name} nodetach nolog"; + Restart = "always"; + RestartSec = 5; - AmbientCapabilities = capabilities; - CapabilityBoundingSet = capabilities; - KeyringMode = "private"; - LockPersonality = true; - MemoryDenyWriteExecute = true; - NoNewPrivileges = true; - PrivateMounts = true; - PrivateTmp = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelModules = true; - # pppd can be configured to tweak kernel settings. - ProtectKernelTunables = false; - ProtectSystem = "strict"; - RemoveIPC = true; - RestrictAddressFamilies = [ - "AF_ATMPVC" - "AF_ATMSVC" - "AF_INET" - "AF_INET6" - "AF_IPX" - "AF_NETLINK" - "AF_PACKET" - "AF_PPPOX" - "AF_UNIX" - ]; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SecureBits = "no-setuid-fixup-locked noroot-locked"; - SystemCallFilter = "@system-service"; - SystemCallArchitectures = "native"; + AmbientCapabilities = capabilities; + CapabilityBoundingSet = capabilities; + KeyringMode = "private"; + LockPersonality = true; + MemoryDenyWriteExecute = true; + NoNewPrivileges = true; + PrivateMounts = true; + PrivateTmp = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelModules = true; + # pppd can be configured to tweak kernel settings. + ProtectKernelTunables = false; + ProtectSystem = "strict"; + RemoveIPC = true; + RestrictAddressFamilies = [ + "AF_ATMPVC" + "AF_ATMSVC" + "AF_INET" + "AF_INET6" + "AF_IPX" + "AF_NETLINK" + "AF_PACKET" + "AF_PPPOX" + "AF_UNIX" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SecureBits = "no-setuid-fixup-locked noroot-locked"; + SystemCallFilter = "@system-service"; + SystemCallArchitectures = "native"; - # All pppd instances on a system must share a runtime - # directory in order for PPP multilink to work correctly. So - # we give all instances the same /run/pppd directory to store - # things in. - # - # For the same reason, we can't set PrivateUsers=true, because - # all instances need to run as the same user to access the - # multilink database. - RuntimeDirectory = "pppd"; - RuntimeDirectoryPreserve = true; + # All pppd instances on a system must share a runtime + # directory in order for PPP multilink to work correctly. So + # we give all instances the same /run/pppd directory to store + # things in. + # + # For the same reason, we can't set PrivateUsers=true, because + # all instances need to run as the same user to access the + # multilink database. + RuntimeDirectory = "pppd"; + RuntimeDirectoryPreserve = true; + }; + wantedBy = mkIf peerCfg.autostart [ "multi-user.target" ]; }; - wantedBy = mkIf peerCfg.autostart [ "multi-user.target" ]; }; - }; - etcFiles = listToAttrs (map mkEtc enabledConfigs); - systemdConfigs = listToAttrs (map mkSystemd enabledConfigs); + etcFiles = listToAttrs (map mkEtc enabledConfigs); + systemdConfigs = listToAttrs (map mkSystemd enabledConfigs); - in mkIf cfg.enable { - environment.etc = etcFiles; - systemd.services = systemdConfigs; - }; + in + mkIf cfg.enable { + environment.etc = etcFiles; + systemd.services = systemdConfigs; + }; } diff --git a/nixos/modules/services/networking/pptpd.nix b/nixos/modules/services/networking/pptpd.nix index 441ab52372f92b..a065709efe64d0 100644 --- a/nixos/modules/services/networking/pptpd.nix +++ b/nixos/modules/services/networking/pptpd.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -8,34 +13,34 @@ with lib; enable = mkEnableOption "pptpd, the Point-to-Point Tunneling Protocol daemon"; serverIp = mkOption { - type = types.str; + type = types.str; description = "The server-side IP address."; - default = "10.124.124.1"; + default = "10.124.124.1"; }; clientIpRange = mkOption { - type = types.str; + type = types.str; description = "The range from which client IPs are drawn."; - default = "10.124.124.2-11"; + default = "10.124.124.2-11"; }; maxClients = mkOption { - type = types.int; + type = types.int; description = "The maximum number of simultaneous connections."; - default = 10; + default = 10; }; extraPptpdOptions = mkOption { - type = types.lines; + type = types.lines; description = "Adds extra lines to the pptpd configuration file."; - default = ""; + default = ""; }; extraPppdOptions = mkOption { - type = types.lines; + type = types.lines; description = "Adds extra lines to the pppd options file."; - default = ""; - example = '' + default = ""; + example = '' ms-dns 8.8.8.8 ms-dns 8.8.4.4 ''; @@ -44,78 +49,80 @@ with lib; }; config = mkIf config.services.pptpd.enable { - systemd.services.pptpd = let - cfg = config.services.pptpd; - - pptpd-conf = pkgs.writeText "pptpd.conf" '' - # Inspired from pptpd-1.4.0/samples/pptpd.conf - ppp ${ppp-pptpd-wrapped}/bin/pppd - option ${pppd-options} - pidfile /run/pptpd.pid - localip ${cfg.serverIp} - remoteip ${cfg.clientIpRange} - connections ${toString cfg.maxClients} # (Will get harmless warning if inconsistent with IP range) - - # Extra - ${cfg.extraPptpdOptions} - ''; - - pppd-options = pkgs.writeText "ppp-options-pptpd.conf" '' - # From: cat pptpd-1.4.0/samples/options.pptpd | grep -v ^# | grep -v ^$ - name pptpd - refuse-pap - refuse-chap - refuse-mschap - require-mschap-v2 - require-mppe-128 - proxyarp - lock - nobsdcomp - novj - novjccomp - nologfd - - # Extra: - ${cfg.extraPppdOptions} - ''; - - ppp-pptpd-wrapped = pkgs.stdenv.mkDerivation { - name = "ppp-pptpd-wrapped"; - phases = [ "installPhase" ]; - nativeBuildInputs = with pkgs; [ makeWrapper ]; - installPhase = '' - mkdir -p $out/bin - makeWrapper ${pkgs.ppp}/bin/pppd $out/bin/pppd \ - --set LD_PRELOAD "${pkgs.libredirect}/lib/libredirect.so" \ - --set NIX_REDIRECTS "/etc/ppp=/etc/ppp-pptpd" + systemd.services.pptpd = + let + cfg = config.services.pptpd; + + pptpd-conf = pkgs.writeText "pptpd.conf" '' + # Inspired from pptpd-1.4.0/samples/pptpd.conf + ppp ${ppp-pptpd-wrapped}/bin/pppd + option ${pppd-options} + pidfile /run/pptpd.pid + localip ${cfg.serverIp} + remoteip ${cfg.clientIpRange} + connections ${toString cfg.maxClients} # (Will get harmless warning if inconsistent with IP range) + + # Extra + ${cfg.extraPptpdOptions} ''; + + pppd-options = pkgs.writeText "ppp-options-pptpd.conf" '' + # From: cat pptpd-1.4.0/samples/options.pptpd | grep -v ^# | grep -v ^$ + name pptpd + refuse-pap + refuse-chap + refuse-mschap + require-mschap-v2 + require-mppe-128 + proxyarp + lock + nobsdcomp + novj + novjccomp + nologfd + + # Extra: + ${cfg.extraPppdOptions} + ''; + + ppp-pptpd-wrapped = pkgs.stdenv.mkDerivation { + name = "ppp-pptpd-wrapped"; + phases = [ "installPhase" ]; + nativeBuildInputs = with pkgs; [ makeWrapper ]; + installPhase = '' + mkdir -p $out/bin + makeWrapper ${pkgs.ppp}/bin/pppd $out/bin/pppd \ + --set LD_PRELOAD "${pkgs.libredirect}/lib/libredirect.so" \ + --set NIX_REDIRECTS "/etc/ppp=/etc/ppp-pptpd" + ''; + }; + in + { + description = "pptpd server"; + + requires = [ "network-online.target" ]; + wantedBy = [ "multi-user.target" ]; + + preStart = '' + mkdir -p -m 700 /etc/ppp-pptpd + + secrets="/etc/ppp-pptpd/chap-secrets" + + [ -f "$secrets" ] || install -m 600 -o root -g root /dev/stdin "$secrets" << EOF + # From: pptpd-1.4.0/samples/chap-secrets + # Secrets for authentication using CHAP + # client server secret IP addresses + #username pptpd password * + EOF + ''; + + serviceConfig = { + ExecStart = "${pkgs.pptpd}/bin/pptpd --conf ${pptpd-conf}"; + KillMode = "process"; + Restart = "on-success"; + Type = "forking"; + PIDFile = "/run/pptpd.pid"; + }; }; - in { - description = "pptpd server"; - - requires = [ "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; - - preStart = '' - mkdir -p -m 700 /etc/ppp-pptpd - - secrets="/etc/ppp-pptpd/chap-secrets" - - [ -f "$secrets" ] || install -m 600 -o root -g root /dev/stdin "$secrets" << EOF - # From: pptpd-1.4.0/samples/chap-secrets - # Secrets for authentication using CHAP - # client server secret IP addresses - #username pptpd password * - EOF - ''; - - serviceConfig = { - ExecStart = "${pkgs.pptpd}/bin/pptpd --conf ${pptpd-conf}"; - KillMode = "process"; - Restart = "on-success"; - Type = "forking"; - PIDFile = "/run/pptpd.pid"; - }; - }; }; } diff --git a/nixos/modules/services/networking/privoxy.nix b/nixos/modules/services/networking/privoxy.nix index d40dd603085a9c..145eee919736e2 100644 --- a/nixos/modules/services/networking/privoxy.nix +++ b/nixos/modules/services/networking/privoxy.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,44 +11,54 @@ let cfg = config.services.privoxy; - serialise = name: val: - if isList val then concatMapStrings (serialise name) val - else if isBool val then serialise name (if val then "1" else "0") - else "${name} ${toString val}\n"; - - configType = with types; - let atom = oneOf [ int bool str path ]; - in attrsOf (either atom (listOf atom)) - // { description = '' - privoxy configuration type. The format consists of an attribute - set of settings. Each setting can be either a value (integer, string, - boolean or path) or a list of such values. - ''; - }; + serialise = + name: val: + if isList val then + concatMapStrings (serialise name) val + else if isBool val then + serialise name (if val then "1" else "0") + else + "${name} ${toString val}\n"; + + configType = + with types; + let + atom = oneOf [ + int + bool + str + path + ]; + in + attrsOf (either atom (listOf atom)) + // { + description = '' + privoxy configuration type. The format consists of an attribute + set of settings. Each setting can be either a value (integer, string, + boolean or path) or a list of such values. + ''; + }; ageType = types.str // { - check = x: - isString x && - (builtins.match "([0-9]+([smhdw]|min|ms|us)*)+" x != null); + check = x: isString x && (builtins.match "([0-9]+([smhdw]|min|ms|us)*)+" x != null); description = "tmpfiles.d(5) age format"; }; - configFile = pkgs.writeText "privoxy.conf" - (concatStrings ( + configFile = pkgs.writeText "privoxy.conf" ( + concatStrings ( # Relative paths in some options are relative to confdir. Privoxy seems # to parse the options in order of appearance, so this must come first. # Nix however doesn't preserve the order in attrsets, so we have to # hardcode confdir here. - [ "confdir ${pkgs.privoxy}/etc\n" ] - ++ mapAttrsToList serialise cfg.settings - )); + [ "confdir ${pkgs.privoxy}/etc\n" ] ++ mapAttrsToList serialise cfg.settings + ) + ); - inspectAction = pkgs.writeText "inspect-all-https.action" - '' - # Enable HTTPS inspection for all requests - {+https-inspection} - / - ''; + inspectAction = pkgs.writeText "inspect-all-https.action" '' + # Enable HTTPS inspection for all requests + {+https-inspection} + / + ''; in @@ -145,9 +160,12 @@ in type = types.listOf types.str; # This must come after all other entries, in order to override the # other actions/filters installed by Privoxy or the user. - apply = x: x ++ optional (cfg.userActions != "") - (toString (pkgs.writeText "user.actions" cfg.userActions)); - default = [ "match-all.action" "default.action" ]; + apply = + x: x ++ optional (cfg.userActions != "") (toString (pkgs.writeText "user.actions" cfg.userActions)); + default = [ + "match-all.action" + "default.action" + ]; description = '' List of paths to Privoxy action files. These paths may either be absolute or relative to the privoxy configuration directory. @@ -157,15 +175,15 @@ in options.filterfile = mkOption { type = types.listOf types.str; default = [ "default.filter" ]; - apply = x: x ++ optional (cfg.userFilters != "") - (toString (pkgs.writeText "user.filter" cfg.userFilters)); + apply = + x: x ++ optional (cfg.userFilters != "") (toString (pkgs.writeText "user.filter" cfg.userFilters)); description = '' List of paths to Privoxy filter files. These paths may either be absolute or relative to the privoxy configuration directory. ''; }; }; - default = {}; + default = { }; example = literalExpression '' { # Listen on IPv6 only listen-address = "[::]:8118"; @@ -205,14 +223,16 @@ in group = "privoxy"; }; - users.groups.privoxy = {}; + users.groups.privoxy = { }; - systemd.tmpfiles.rules = optional cfg.inspectHttps - "d ${cfg.settings.certificate-directory} 0770 privoxy privoxy ${cfg.certsLifetime}"; + systemd.tmpfiles.rules = optional cfg.inspectHttps "d ${cfg.settings.certificate-directory} 0770 privoxy privoxy ${cfg.certsLifetime}"; systemd.services.privoxy = { description = "Filtering web proxy"; - after = [ "network.target" "nss-lookup.target" ]; + after = [ + "network.target" + "nss-lookup.target" + ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { User = "privoxy"; @@ -223,52 +243,70 @@ in ProtectHome = true; ProtectSystem = "full"; }; - unitConfig = mkIf cfg.inspectHttps { - ConditionPathExists = with cfg.settings; - [ ca-cert-file ca-key-file ]; + unitConfig = mkIf cfg.inspectHttps { + ConditionPathExists = with cfg.settings; [ + ca-cert-file + ca-key-file + ]; }; }; services.tor.settings.SOCKSPort = mkIf cfg.enableTor [ # Route HTTP traffic over a faster port (without IsolateDestAddr). - { addr = "127.0.0.1"; port = 9063; IsolateDestAddr = false; } + { + addr = "127.0.0.1"; + port = 9063; + IsolateDestAddr = false; + } ]; - services.privoxy.settings = { - user-manual = "${pkgs.privoxy}/share/doc/privoxy/user-manual"; - # This is needed for external filters - temporary-directory = "/tmp"; - filterfile = [ "default.filter" ]; - actionsfile = - [ "match-all.action" + services.privoxy.settings = + { + user-manual = "${pkgs.privoxy}/share/doc/privoxy/user-manual"; + # This is needed for external filters + temporary-directory = "/tmp"; + filterfile = [ "default.filter" ]; + actionsfile = [ + "match-all.action" "default.action" ] ++ optional cfg.inspectHttps (toString inspectAction); - } // (optionalAttrs cfg.enableTor { - forward-socks5 = "/ 127.0.0.1:9063 ."; - toggle = true; - enable-remote-toggle = false; - enable-edit-actions = false; - enable-remote-http-toggle = false; - }) // (optionalAttrs cfg.inspectHttps { - # This allows setting absolute key/crt paths - ca-directory = "/var/empty"; - certificate-directory = "/run/privoxy/certs"; - trusted-cas-file = "/etc/ssl/certs/ca-certificates.crt"; - }); + } + // (optionalAttrs cfg.enableTor { + forward-socks5 = "/ 127.0.0.1:9063 ."; + toggle = true; + enable-remote-toggle = false; + enable-edit-actions = false; + enable-remote-http-toggle = false; + }) + // (optionalAttrs cfg.inspectHttps { + # This allows setting absolute key/crt paths + ca-directory = "/var/empty"; + certificate-directory = "/run/privoxy/certs"; + trusted-cas-file = "/etc/ssl/certs/ca-certificates.crt"; + }); }; imports = let - top = x: [ "services" "privoxy" x ]; - setting = x: [ "services" "privoxy" "settings" x ]; + top = x: [ + "services" + "privoxy" + x + ]; + setting = x: [ + "services" + "privoxy" + "settings" + x + ]; in - [ (mkRenamedOptionModule (top "enableEditActions") (setting "enable-edit-actions")) + [ + (mkRenamedOptionModule (top "enableEditActions") (setting "enable-edit-actions")) (mkRenamedOptionModule (top "listenAddress") (setting "listen-address")) (mkRenamedOptionModule (top "actionsFiles") (setting "actionsfile")) (mkRenamedOptionModule (top "filterFiles") (setting "filterfile")) - (mkRemovedOptionModule (top "extraConfig") - '' + (mkRemovedOptionModule (top "extraConfig") '' Use services.privoxy.settings instead. This is part of the general move to use structured settings instead of raw text for config as introduced by RFC0042: diff --git a/nixos/modules/services/networking/pyload.nix b/nixos/modules/services/networking/pyload.nix index 93f8dd7d731a93..144f97148ef9cd 100644 --- a/nixos/modules/services/networking/pyload.nix +++ b/nixos/modules/services/networking/pyload.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.services.pyload; @@ -132,7 +138,11 @@ in RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@resources" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@resources" + "~@privileged" + ]; UMask = "0002"; CapabilityBoundingSet = [ "~CAP_BLOCK_SUSPEND" diff --git a/nixos/modules/services/networking/quassel.nix b/nixos/modules/services/networking/quassel.nix index 30b61dd9e59962..d699c9b6f155a4 100644 --- a/nixos/modules/services/networking/quassel.nix +++ b/nixos/modules/services/networking/quassel.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with lib; @@ -78,14 +84,15 @@ in }; - ###### implementation config = mkIf cfg.enable { assertions = [ - { assertion = cfg.requireSSL -> cfg.certificateFile != null; + { + assertion = cfg.requireSSL -> cfg.certificateFile != null; message = "Quassel needs a certificate file in order to require SSL"; - }]; + } + ]; users.users = optionalAttrs (cfg.user == null) { quassel = { @@ -107,25 +114,29 @@ in "d '${cfg.dataDir}' - ${user} - - -" ]; - systemd.services.quassel = - { description = "Quassel IRC client daemon"; + systemd.services.quassel = { + description = "Quassel IRC client daemon"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ] ++ optional config.services.postgresql.enable "postgresql.service" - ++ optional config.services.mysql.enable "mysql.service"; + wantedBy = [ "multi-user.target" ]; + after = + [ "network.target" ] + ++ optional config.services.postgresql.enable "postgresql.service" + ++ optional config.services.mysql.enable "mysql.service"; - serviceConfig = - { - ExecStart = concatStringsSep " " ([ + serviceConfig = { + ExecStart = concatStringsSep " " ( + [ "${quassel}/bin/quasselcore" "--listen=${concatStringsSep "," cfg.interfaces}" "--port=${toString cfg.portNumber}" "--configdir=${cfg.dataDir}" - ] ++ optional cfg.requireSSL "--require-ssl" - ++ optional (cfg.certificateFile != null) "--ssl-cert=${cfg.certificateFile}"); - User = user; - }; + ] + ++ optional cfg.requireSSL "--require-ssl" + ++ optional (cfg.certificateFile != null) "--ssl-cert=${cfg.certificateFile}" + ); + User = user; }; + }; }; diff --git a/nixos/modules/services/networking/quicktun.nix b/nixos/modules/services/networking/quicktun.nix index b9fc5c8ebdb747..b2253cb72a718f 100644 --- a/nixos/modules/services/networking/quicktun.nix +++ b/nixos/modules/services/networking/quicktun.nix @@ -1,4 +1,10 @@ -{ options, config, pkgs, lib, ... }: +{ + options, + config, + pkgs, + lib, + ... +}: let inherit (lib) mkOption types mkIf; @@ -15,120 +21,132 @@ in See for more information about available options. ''; - type = types.attrsOf (types.submodule ({ name, ... }: let - qtcfg = cfg.${name}; - in { - options = { - tunMode = mkOption { - type = with types; coercedTo bool (b: if b then 1 else 0) (ints.between 0 1); - default = false; - example = true; - description = "Whether to operate in tun (IP) or tap (Ethernet) mode."; - }; - - remoteAddress = mkOption { - type = types.str; - default = "0.0.0.0"; - example = "tunnel.example.com"; - description = '' - IP address or hostname of the remote end (use `0.0.0.0` for a floating/dynamic remote endpoint). - ''; - }; - - localAddress = mkOption { - type = with types; nullOr str; - default = null; - example = "0.0.0.0"; - description = "IP address or hostname of the local end."; - }; - - localPort = mkOption { - type = types.port; - default = 2998; - description = "Local UDP port."; - }; - - remotePort = mkOption { - type = types.port; - default = qtcfg.localPort; - defaultText = lib.literalExpression "config.services.quicktun..localPort"; - description = " remote UDP port"; - }; - - remoteFloat = mkOption { - type = with types; coercedTo bool (b: if b then 1 else 0) (ints.between 0 1); - default = false; - example = true; - description = '' - Whether to allow the remote address and port to change when properly encrypted packets are received. - ''; - }; - - protocol = mkOption { - type = types.enum [ "raw" "nacl0" "nacltai" "salty" ]; - default = "nacltai"; - description = "Which protocol to use."; - }; - - privateKey = mkOption { - type = with types; nullOr str; - default = null; - description = '' - Local secret key in hexadecimal form. - - ::: {.warning} - This option is deprecated. Please use {var}`services.quicktun..privateKeyFile` instead. - ::: - - ::: {.note} - Not needed when {var}`services.quicktun..protocol` is set to `raw`. - ::: - ''; - }; - - privateKeyFile = mkOption { - type = with types; nullOr path; - # This is a hack to deprecate `privateKey` without using `mkChangedModuleOption` - default = if qtcfg.privateKey == null then null else pkgs.writeText "quickttun-key-${name}" qtcfg.privateKey; - defaultText = "null"; - description = '' - Path to file containing local secret key in binary or hexadecimal form. - - ::: {.note} - Not needed when {var}`services.quicktun..protocol` is set to `raw`. - ::: - ''; - }; - - publicKey = mkOption { - type = with types; nullOr str; - default = null; - description = '' - Remote public key in hexadecimal form. - - ::: {.note} - Not needed when {var}`services.quicktun..protocol` is set to `raw`. - ::: - ''; - }; - - timeWindow = mkOption { - type = types.ints.unsigned; - default = 5; - description = '' - Allowed time window for first received packet in seconds (positive number allows packets from history) - ''; - }; - - upScript = mkOption { - type = with types; nullOr lines; - default = null; - description = '' - Run specified command or script after the tunnel device has been opened. - ''; - }; - }; - })); + type = types.attrsOf ( + types.submodule ( + { name, ... }: + let + qtcfg = cfg.${name}; + in + { + options = { + tunMode = mkOption { + type = with types; coercedTo bool (b: if b then 1 else 0) (ints.between 0 1); + default = false; + example = true; + description = "Whether to operate in tun (IP) or tap (Ethernet) mode."; + }; + + remoteAddress = mkOption { + type = types.str; + default = "0.0.0.0"; + example = "tunnel.example.com"; + description = '' + IP address or hostname of the remote end (use `0.0.0.0` for a floating/dynamic remote endpoint). + ''; + }; + + localAddress = mkOption { + type = with types; nullOr str; + default = null; + example = "0.0.0.0"; + description = "IP address or hostname of the local end."; + }; + + localPort = mkOption { + type = types.port; + default = 2998; + description = "Local UDP port."; + }; + + remotePort = mkOption { + type = types.port; + default = qtcfg.localPort; + defaultText = lib.literalExpression "config.services.quicktun..localPort"; + description = " remote UDP port"; + }; + + remoteFloat = mkOption { + type = with types; coercedTo bool (b: if b then 1 else 0) (ints.between 0 1); + default = false; + example = true; + description = '' + Whether to allow the remote address and port to change when properly encrypted packets are received. + ''; + }; + + protocol = mkOption { + type = types.enum [ + "raw" + "nacl0" + "nacltai" + "salty" + ]; + default = "nacltai"; + description = "Which protocol to use."; + }; + + privateKey = mkOption { + type = with types; nullOr str; + default = null; + description = '' + Local secret key in hexadecimal form. + + ::: {.warning} + This option is deprecated. Please use {var}`services.quicktun..privateKeyFile` instead. + ::: + + ::: {.note} + Not needed when {var}`services.quicktun..protocol` is set to `raw`. + ::: + ''; + }; + + privateKeyFile = mkOption { + type = with types; nullOr path; + # This is a hack to deprecate `privateKey` without using `mkChangedModuleOption` + default = + if qtcfg.privateKey == null then null else pkgs.writeText "quickttun-key-${name}" qtcfg.privateKey; + defaultText = "null"; + description = '' + Path to file containing local secret key in binary or hexadecimal form. + + ::: {.note} + Not needed when {var}`services.quicktun..protocol` is set to `raw`. + ::: + ''; + }; + + publicKey = mkOption { + type = with types; nullOr str; + default = null; + description = '' + Remote public key in hexadecimal form. + + ::: {.note} + Not needed when {var}`services.quicktun..protocol` is set to `raw`. + ::: + ''; + }; + + timeWindow = mkOption { + type = types.ints.unsigned; + default = 5; + description = '' + Allowed time window for first received packet in seconds (positive number allows packets from history) + ''; + }; + + upScript = mkOption { + type = with types; nullOr lines; + default = null; + description = '' + Run specified command or script after the tunnel device has been opened. + ''; + }; + }; + } + ) + ); }; }; @@ -137,13 +155,16 @@ in (lib.mapAttrsToList (name: value: if value.privateKey != null then name else null)) (builtins.filter (n: n != null)) (map (n: " - services.quicktun.${n}.privateKey")) - (services: lib.optional (services != [ ]) '' - `services.quicktun..privateKey` is deprecated. - Please use `services.quicktun..privateKeyFile` instead. - - Offending options: - ${lib.concatStringsSep "\n" services} - '') + ( + services: + lib.optional (services != [ ]) '' + `services.quicktun..privateKey` is deprecated. + Please use `services.quicktun..privateKeyFile` instead. + + Offending options: + ${lib.concatStringsSep "\n" services} + '' + ) ]; systemd.services = lib.mkMerge ( @@ -162,7 +183,9 @@ in PRIVATE_KEY_FILE = mkIf (qtcfg.privateKeyFile != null) qtcfg.privateKeyFile; PUBLIC_KEY = mkIf (qtcfg.publicKey != null) qtcfg.publicKey; TIME_WINDOW = toString qtcfg.timeWindow; - TUN_UP_SCRIPT = mkIf (qtcfg.upScript != null) (pkgs.writeScript "quicktun-${name}-up.sh" qtcfg.upScript); + TUN_UP_SCRIPT = mkIf (qtcfg.upScript != null) ( + pkgs.writeScript "quicktun-${name}-up.sh" qtcfg.upScript + ); SUID = "nobody"; }; serviceConfig = { diff --git a/nixos/modules/services/networking/quorum.nix b/nixos/modules/services/networking/quorum.nix index 8f6df0881b2398..d86d32bc2de428 100644 --- a/nixos/modules/services/networking/quorum.nix +++ b/nixos/modules/services/networking/quorum.nix @@ -1,7 +1,20 @@ -{ config, options, pkgs, lib, ... }: +{ + config, + options, + pkgs, + lib, + ... +}: let - inherit (lib) mkEnableOption mkIf mkOption literalExpression types optionalString; + inherit (lib) + mkEnableOption + mkIf + mkOption + literalExpression + types + optionalString + ; cfg = config.services.quorum; opt = options.services.quorum; @@ -9,7 +22,8 @@ let genesisFile = pkgs.writeText "genesis.json" (builtins.toJSON cfg.genesis); staticNodesFile = pkgs.writeText "static-nodes.json" (builtins.toJSON cfg.staticNodes); -in { +in +{ options = { services.quorum = { @@ -42,8 +56,10 @@ in { staticNodes = mkOption { type = types.listOf types.str; - default = []; - example = [ "enode://dd333ec28f0a8910c92eb4d336461eea1c20803eed9cf2c056557f986e720f8e693605bba2f4e8f289b1162e5ac7c80c914c7178130711e393ca76abc1d92f57@0.0.0.0:30303?discport=0" ]; + default = [ ]; + example = [ + "enode://dd333ec28f0a8910c92eb4d336461eea1c20803eed9cf2c056557f986e720f8e693605bba2f4e8f289b1162e5ac7c80c914c7178130711e393ca76abc1d92f57@0.0.0.0:30303?discport=0" + ]; description = "List of validator nodes."; }; @@ -54,7 +70,11 @@ in { }; syncmode = mkOption { - type = types.enum [ "fast" "full" "light" ]; + type = types.enum [ + "fast" + "full" + "light" + ]; default = "full"; description = "Blockchain sync mode."; }; @@ -97,7 +117,7 @@ in { }; }; - ws = { + ws = { enable = mkOption { type = types.bool; default = true; @@ -122,47 +142,48 @@ in { description = "API's offered over the WS-RPC interface."; }; - origins = mkOption { + origins = mkOption { type = types.str; default = "*"; description = "Origins from which to accept websockets requests"; - }; - }; + }; + }; genesis = mkOption { type = types.nullOr types.attrs; default = null; - example = literalExpression '' { - alloc = { - a47385db68718bdcbddc2d2bb7c54018066ec111 = { - balance = "1000000000000000000000000000"; - }; - }; - coinbase = "0x0000000000000000000000000000000000000000"; - config = { - byzantiumBlock = 4; - chainId = 494702925; - eip150Block = 2; - eip155Block = 3; - eip158Block = 3; - homesteadBlock = 1; - isQuorum = true; - istanbul = { - epoch = 30000; - policy = 0; - }; - }; - difficulty = "0x1"; - extraData = "0x0000000000000000000000000000000000000000000000000000000000000000f85ad59438f0508111273d8e482f49410ca4078afc86a961b8410000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000c0"; - gasLimit = "0x2FEFD800"; - mixHash = "0x63746963616c2062797a616e74696e65201111756c7420746f6c6572616e6365"; - nonce = "0x0"; - parentHash = "0x0000000000000000000000000000000000000000000000000000000000000000"; - timestamp = "0x00"; - }''; + example = literalExpression '' + { + alloc = { + a47385db68718bdcbddc2d2bb7c54018066ec111 = { + balance = "1000000000000000000000000000"; + }; + }; + coinbase = "0x0000000000000000000000000000000000000000"; + config = { + byzantiumBlock = 4; + chainId = 494702925; + eip150Block = 2; + eip155Block = 3; + eip158Block = 3; + homesteadBlock = 1; + isQuorum = true; + istanbul = { + epoch = 30000; + policy = 0; + }; + }; + difficulty = "0x1"; + extraData = "0x0000000000000000000000000000000000000000000000000000000000000000f85ad59438f0508111273d8e482f49410ca4078afc86a961b8410000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000c0"; + gasLimit = "0x2FEFD800"; + mixHash = "0x63746963616c2062797a616e74696e65201111756c7420746f6c6572616e6365"; + nonce = "0x0"; + parentHash = "0x0000000000000000000000000000000000000000000000000000000000000000"; + timestamp = "0x00"; + }''; description = "Blockchain genesis settings."; }; - }; + }; }; config = mkIf cfg.enable { @@ -193,22 +214,20 @@ in { serviceConfig = { User = cfg.user; Group = cfg.group; - ExecStart = ''${pkgs.quorum}/bin/geth \ - --nodiscover \ - --verbosity 5 \ - --nodekey ${cfg.nodekeyFile} \ - --istanbul.blockperiod ${toString cfg.blockperiod} \ - --syncmode ${cfg.syncmode} \ - ${optionalString (cfg.permissioned) - "--permissioned"} \ - --mine --miner.threads 1 \ - ${optionalString (cfg.rpc.enable) - "--rpc --rpcaddr ${cfg.rpc.address} --rpcport ${toString cfg.rpc.port} --rpcapi ${cfg.rpc.api}"} \ - ${optionalString (cfg.ws.enable) - "--ws --ws.addr ${cfg.ws.address} --ws.port ${toString cfg.ws.port} --ws.api ${cfg.ws.api} --ws.origins ${cfg.ws.origins}"} \ - --emitcheckpoints \ - --datadir ${dataDir} \ - --port ${toString cfg.port}''; + ExecStart = '' + ${pkgs.quorum}/bin/geth \ + --nodiscover \ + --verbosity 5 \ + --nodekey ${cfg.nodekeyFile} \ + --istanbul.blockperiod ${toString cfg.blockperiod} \ + --syncmode ${cfg.syncmode} \ + ${optionalString (cfg.permissioned) "--permissioned"} \ + --mine --miner.threads 1 \ + ${optionalString (cfg.rpc.enable) "--rpc --rpcaddr ${cfg.rpc.address} --rpcport ${toString cfg.rpc.port} --rpcapi ${cfg.rpc.api}"} \ + ${optionalString (cfg.ws.enable) "--ws --ws.addr ${cfg.ws.address} --ws.port ${toString cfg.ws.port} --ws.api ${cfg.ws.api} --ws.origins ${cfg.ws.origins}"} \ + --emitcheckpoints \ + --datadir ${dataDir} \ + --port ${toString cfg.port}''; Restart = "on-failure"; # Hardening measures @@ -226,6 +245,6 @@ in { home = dataDir; isSystemUser = true; }; - users.groups.${cfg.group} = {}; + users.groups.${cfg.group} = { }; }; } diff --git a/nixos/modules/services/networking/r53-ddns.nix b/nixos/modules/services/networking/r53-ddns.nix index a8839762d530d9..9b4fa4c52672fc 100644 --- a/nixos/modules/services/networking/r53-ddns.nix +++ b/nixos/modules/services/networking/r53-ddns.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -61,7 +66,8 @@ in systemd.services.r53-ddns = { description = "r53-ddns service"; serviceConfig = { - ExecStart = "${pkg}/bin/r53-ddns -zone-id ${cfg.zoneID} -domain ${cfg.domain}" + ExecStart = + "${pkg}/bin/r53-ddns -zone-id ${cfg.zoneID} -domain ${cfg.domain}" + lib.optionalString (cfg.hostname != null) " -hostname ${cfg.hostname}"; EnvironmentFile = "${cfg.environmentFile}"; DynamicUser = true; diff --git a/nixos/modules/services/networking/radicale.nix b/nixos/modules/services/networking/radicale.nix index 7037e6817803d5..d210efe14b3c97 100644 --- a/nixos/modules/services/networking/radicale.nix +++ b/nixos/modules/services/networking/radicale.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -9,21 +14,20 @@ let listToValue = concatMapStringsSep ", " (generators.mkValueStringDefault { }); }; - pkg = if cfg.package == null then - pkgs.radicale - else - cfg.package; + pkg = if cfg.package == null then pkgs.radicale else cfg.package; - confFile = if cfg.settings == { } then - pkgs.writeText "radicale.conf" cfg.config - else - format.generate "radicale.conf" cfg.settings; + confFile = + if cfg.settings == { } then + pkgs.writeText "radicale.conf" cfg.config + else + format.generate "radicale.conf" cfg.settings; rightsFile = format.generate "radicale.rights" cfg.rights; bindLocalhost = cfg.settings != { } && !hasAttrByPath [ "server" "hosts" ] cfg.settings; -in { +in +{ options.services.radicale = { enable = mkEnableOption "Radicale CalDAV and CardDAV server"; @@ -101,7 +105,7 @@ in { extraArgs = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = "Extra arguments passed to the Radicale daemon."; }; }; @@ -117,21 +121,24 @@ in { } ]; - warnings = optional (cfg.package == null && versionOlder config.system.stateVersion "17.09") '' - The configuration and storage formats of your existing Radicale - installation might be incompatible with the newest version. - For upgrade instructions see - https://radicale.org/2.1.html#documentation/migration-from-1xx-to-2xx. - Set services.radicale.package to suppress this warning. - '' ++ optional (cfg.package == null && versionOlder config.system.stateVersion "20.09") '' - The configuration format of your existing Radicale installation might be - incompatible with the newest version. For upgrade instructions see - https://github.com/Kozea/Radicale/blob/3.0.6/NEWS.md#upgrade-checklist. - Set services.radicale.package to suppress this warning. - '' ++ optional (cfg.config != "") '' - The option services.radicale.config is deprecated. - Use services.radicale.settings instead. - ''; + warnings = + optional (cfg.package == null && versionOlder config.system.stateVersion "17.09") '' + The configuration and storage formats of your existing Radicale + installation might be incompatible with the newest version. + For upgrade instructions see + https://radicale.org/2.1.html#documentation/migration-from-1xx-to-2xx. + Set services.radicale.package to suppress this warning. + '' + ++ optional (cfg.package == null && versionOlder config.system.stateVersion "20.09") '' + The configuration format of your existing Radicale installation might be + incompatible with the newest version. For upgrade instructions see + https://github.com/Kozea/Radicale/blob/3.0.6/NEWS.md#upgrade-checklist. + Set services.radicale.package to suppress this warning. + '' + ++ optional (cfg.config != "") '' + The option services.radicale.config is deprecated. + Use services.radicale.settings instead. + ''; services.radicale.settings.rights = mkIf (cfg.rights != { }) { type = "from_file"; @@ -145,7 +152,7 @@ in { group = "radicale"; }; - users.groups.radicale = {}; + users.groups.radicale = { }; systemd.services.radicale = { description = "A Simple Calendar and Contact Server"; @@ -153,18 +160,24 @@ in { requires = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { - ExecStart = concatStringsSep " " ([ - "${pkg}/bin/radicale" "-C" confFile - ] ++ ( - map escapeShellArg cfg.extraArgs - )); + ExecStart = concatStringsSep " " ( + [ + "${pkg}/bin/radicale" + "-C" + confFile + ] + ++ (map escapeShellArg cfg.extraArgs) + ); User = "radicale"; Group = "radicale"; StateDirectory = "radicale/collections"; StateDirectoryMode = "0750"; # Hardening CapabilityBoundingSet = [ "" ]; - DeviceAllow = [ "/dev/stdin" "/dev/urandom" ]; + DeviceAllow = [ + "/dev/stdin" + "/dev/urandom" + ]; DevicePolicy = "strict"; IPAddressAllow = mkIf bindLocalhost "localhost"; IPAddressDeny = mkIf bindLocalhost "any"; @@ -184,16 +197,24 @@ in { ProtectKernelTunables = true; ProtectProc = "invisible"; ProtectSystem = "strict"; - ReadWritePaths = lib.optional - (hasAttrByPath [ "storage" "filesystem_folder" ] cfg.settings) - cfg.settings.storage.filesystem_folder; + ReadWritePaths = lib.optional (hasAttrByPath [ + "storage" + "filesystem_folder" + ] cfg.settings) cfg.settings.storage.filesystem_folder; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" "~@resources" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "~@resources" + ]; UMask = "0027"; WorkingDirectory = "/var/lib/radicale"; }; diff --git a/nixos/modules/services/networking/realm.nix b/nixos/modules/services/networking/realm.nix index 5b0c34ac825ff2..2eba0ed3149ff2 100644 --- a/nixos/modules/services/networking/realm.nix +++ b/nixos/modules/services/networking/realm.nix @@ -1,14 +1,21 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let cfg = config.services.realm; configFormat = pkgs.formats.json { }; configFile = configFormat.generate "config.json" cfg.config; inherit (lib) - mkEnableOption mkPackageOption mkOption mkIf types getExe; + mkEnableOption + mkPackageOption + mkOption + mkIf + types + getExe + ; in { @@ -42,7 +49,10 @@ in ProtectProc = "invisible"; ProtectKernelTunables = true; ExecStart = "${getExe cfg.package} --config ${configFile}"; - AmbientCapabilities = [ "CAP_NET_ADMIN" "CAP_NET_BIND_SERVICE" ]; + AmbientCapabilities = [ + "CAP_NET_ADMIN" + "CAP_NET_BIND_SERVICE" + ]; }; wantedBy = [ "multi-user.target" ]; }; diff --git a/nixos/modules/services/networking/rosenpass.nix b/nixos/modules/services/networking/rosenpass.nix index 92ecc1cb31a369..2ad2196179f8a7 100644 --- a/nixos/modules/services/networking/rosenpass.nix +++ b/nixos/modules/services/networking/rosenpass.nix @@ -1,8 +1,9 @@ -{ config -, lib -, options -, pkgs -, ... +{ + config, + lib, + options, + pkgs, + ... }: let inherit (lib) @@ -71,7 +72,10 @@ in }; verbosity = mkOption { - type = enum [ "Verbose" "Quiet" ]; + type = enum [ + "Verbose" + "Quiet" + ]; default = "Quiet"; description = "Verbosity of output produced by the service."; }; @@ -149,7 +153,13 @@ in } ]; relevantExtractions = filter (x: x.relevant) extractions; - extract = { root, peer, key, ... }: + extract = + { + root, + peer, + key, + ... + }: filter (x: x != null) (flatten (concatMap (x: (map key (peer x))) (attrValues root))); configuredKeys = flatten (map extract relevantExtractions); itemize = xs: concatLines (map (x: " - ${x}") xs); @@ -167,22 +177,24 @@ in ${itemize (descriptions relevantExtractions)} ${unusual} '') - ++ - optional (relevantExtractions == [ ]) '' + ++ optional (relevantExtractions == [ ]) '' You have configured Rosenpass, but you have not configured Wireguard via any of: ${itemize (descriptions extractions)} ${unusual} ''; - environment.systemPackages = [ cfg.package pkgs.wireguard-tools ]; + environment.systemPackages = [ + cfg.package + pkgs.wireguard-tools + ]; systemd.services.rosenpass = let filterNonNull = filterAttrsRecursive (_: v: v != null); config = settingsFormat.generate "config.toml" ( - filterNonNull (cfg.settings - // - ( + filterNonNull ( + cfg.settings + // ( let credentialPath = id: "$CREDENTIALS_DIRECTORY/${id}"; # NOTE: We would like to remove all `null` values inside `cfg.settings` @@ -208,7 +220,10 @@ in wantedBy = [ "multi-user.target" ]; wants = [ "network-online.target" ]; after = [ "network-online.target" ]; - path = [ cfg.package pkgs.wireguard-tools ]; + path = [ + cfg.package + pkgs.wireguard-tools + ]; serviceConfig = { User = "rosenpass"; diff --git a/nixos/modules/services/networking/scion/scion-control.nix b/nixos/modules/services/networking/scion/scion-control.nix index 8b6733ac0c2443..f0550f32cb1fff 100644 --- a/nixos/modules/services/networking/scion/scion-control.nix +++ b/nixos/modules/services/networking/scion/scion-control.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -54,8 +59,14 @@ in config = mkIf cfg.enable { systemd.services.scion-control = { description = "SCION Control Service"; - after = [ "network-online.target" "scion-dispatcher.service" ]; - wants = [ "network-online.target" "scion-dispatcher.service" ]; + after = [ + "network-online.target" + "scion-dispatcher.service" + ]; + wants = [ + "network-online.target" + "scion-dispatcher.service" + ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { Type = "simple"; diff --git a/nixos/modules/services/networking/scion/scion-daemon.nix b/nixos/modules/services/networking/scion/scion-daemon.nix index 09416178d35abd..36bd78bf5665e8 100644 --- a/nixos/modules/services/networking/scion/scion-daemon.nix +++ b/nixos/modules/services/networking/scion/scion-daemon.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -51,8 +56,14 @@ in config = mkIf cfg.enable { systemd.services.scion-daemon = { description = "SCION Daemon"; - after = [ "network-online.target" "scion-dispatcher.service" ]; - wants = [ "network-online.target" "scion-dispatcher.service" ]; + after = [ + "network-online.target" + "scion-dispatcher.service" + ]; + wants = [ + "network-online.target" + "scion-dispatcher.service" + ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { Type = "simple"; diff --git a/nixos/modules/services/networking/scion/scion-dispatcher.nix b/nixos/modules/services/networking/scion/scion-dispatcher.nix index 7d2e28be75f722..a6559487a19bfd 100644 --- a/nixos/modules/services/networking/scion/scion-dispatcher.nix +++ b/nixos/modules/services/networking/scion/scion-dispatcher.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -45,7 +50,7 @@ in }; config = mkIf cfg.enable { # Needed for group ownership of the dispatcher socket - users.groups.scion = {}; + users.groups.scion = { }; # scion programs hardcode path to dispatcher in /run/shm, and is not # configurable at runtime upstream plans to obsolete the dispatcher in @@ -72,4 +77,3 @@ in }; }; } - diff --git a/nixos/modules/services/networking/scion/scion-router.nix b/nixos/modules/services/networking/scion/scion-router.nix index 7587a06ed9dbe8..52182dd35aa0a9 100644 --- a/nixos/modules/services/networking/scion/scion-router.nix +++ b/nixos/modules/services/networking/scion/scion-router.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/networking/scion/scion.nix b/nixos/modules/services/networking/scion/scion.nix index 0b26f24e7ed024..25787dc92f2d78 100644 --- a/nixos/modules/services/networking/scion/scion.nix +++ b/nixos/modules/services/networking/scion/scion.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -45,7 +50,8 @@ in scion-ip-gateway.enable = true; }; assertions = [ - { assertion = cfg.bypassBootstrapWarning == true; + { + assertion = cfg.bypassBootstrapWarning == true; message = '' SCION is a routing protocol and requires bootstrapping with a manual, imperative key signing ceremony. You may want to join an existing Isolation Domain (ISD) such as scionlab.org, or bootstrap your own. If you have completed and configured the public key infrastructure for SCION and are sure this process is complete, then add the following to your configuration: @@ -57,4 +63,3 @@ in ]; }; } - diff --git a/nixos/modules/services/networking/shorewall.nix b/nixos/modules/services/networking/shorewall.nix index 8d05543e9051cd..3d59b7d09c732f 100644 --- a/nixos/modules/services/networking/shorewall.nix +++ b/nixos/modules/services/networking/shorewall.nix @@ -1,13 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let types = lib.types; cfg = config.services.shorewall; -in { +in +{ options = { services.shorewall = { enable = lib.mkOption { - type = types.bool; - default = false; + type = types.bool; + default = false; description = '' Whether to enable Shorewall IPv4 Firewall. @@ -19,14 +25,14 @@ in { ''; }; package = lib.mkOption { - type = types.package; - default = pkgs.shorewall; + type = types.package; + default = pkgs.shorewall; defaultText = lib.literalExpression "pkgs.shorewall"; description = "The shorewall package to use."; }; configs = lib.mkOption { - type = types.attrsOf types.lines; - default = {}; + type = types.attrsOf types.lines; + default = { }; description = '' This option defines the Shorewall configs. The attribute name defines the name of the config, @@ -40,19 +46,19 @@ in { config = lib.mkIf cfg.enable { systemd.services.firewall.enable = false; systemd.services.shorewall = { - description = "Shorewall IPv4 Firewall"; - after = [ "ipset.target" ]; - before = [ "network-pre.target" ]; - wants = [ "network-pre.target" ]; - wantedBy = [ "multi-user.target" ]; + description = "Shorewall IPv4 Firewall"; + after = [ "ipset.target" ]; + before = [ "network-pre.target" ]; + wants = [ "network-pre.target" ]; + wantedBy = [ "multi-user.target" ]; reloadIfChanged = true; restartTriggers = lib.attrValues cfg.configs; serviceConfig = { - Type = "oneshot"; + Type = "oneshot"; RemainAfterExit = "yes"; - ExecStart = "${cfg.package}/bin/shorewall start"; - ExecReload = "${cfg.package}/bin/shorewall reload"; - ExecStop = "${cfg.package}/bin/shorewall stop"; + ExecStart = "${cfg.package}/bin/shorewall start"; + ExecReload = "${cfg.package}/bin/shorewall reload"; + ExecStop = "${cfg.package}/bin/shorewall stop"; }; preStart = '' install -D -d -m 750 /var/lib/shorewall @@ -62,7 +68,9 @@ in { ''; }; environment = { - etc = lib.mapAttrs' (name: conf: lib.nameValuePair "shorewall/${name}" {source=conf;}) cfg.configs; + etc = lib.mapAttrs' ( + name: conf: lib.nameValuePair "shorewall/${name}" { source = conf; } + ) cfg.configs; systemPackages = [ cfg.package ]; }; }; diff --git a/nixos/modules/services/networking/shorewall6.nix b/nixos/modules/services/networking/shorewall6.nix index 3088e59fa9eb44..fe40f7e430e312 100644 --- a/nixos/modules/services/networking/shorewall6.nix +++ b/nixos/modules/services/networking/shorewall6.nix @@ -1,13 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let types = lib.types; cfg = config.services.shorewall6; -in { +in +{ options = { services.shorewall6 = { enable = lib.mkOption { - type = types.bool; - default = false; + type = types.bool; + default = false; description = '' Whether to enable Shorewall IPv6 Firewall. @@ -19,14 +25,14 @@ in { ''; }; package = lib.mkOption { - type = types.package; - default = pkgs.shorewall; + type = types.package; + default = pkgs.shorewall; defaultText = lib.literalExpression "pkgs.shorewall"; description = "The shorewall package to use."; }; configs = lib.mkOption { - type = types.attrsOf types.lines; - default = {}; + type = types.attrsOf types.lines; + default = { }; description = '' This option defines the Shorewall configs. The attribute name defines the name of the config, @@ -40,19 +46,19 @@ in { config = lib.mkIf cfg.enable { systemd.services.firewall.enable = false; systemd.services.shorewall6 = { - description = "Shorewall IPv6 Firewall"; - after = [ "ipset.target" ]; - before = [ "network-pre.target" ]; - wants = [ "network-pre.target" ]; - wantedBy = [ "multi-user.target" ]; + description = "Shorewall IPv6 Firewall"; + after = [ "ipset.target" ]; + before = [ "network-pre.target" ]; + wants = [ "network-pre.target" ]; + wantedBy = [ "multi-user.target" ]; reloadIfChanged = true; restartTriggers = lib.attrValues cfg.configs; serviceConfig = { - Type = "oneshot"; + Type = "oneshot"; RemainAfterExit = "yes"; - ExecStart = "${cfg.package}/bin/shorewall6 start"; - ExecReload = "${cfg.package}/bin/shorewall6 reload"; - ExecStop = "${cfg.package}/bin/shorewall6 stop"; + ExecStart = "${cfg.package}/bin/shorewall6 start"; + ExecReload = "${cfg.package}/bin/shorewall6 reload"; + ExecStop = "${cfg.package}/bin/shorewall6 stop"; }; preStart = '' install -D -d -m 750 /var/lib/shorewall6 @@ -62,7 +68,9 @@ in { ''; }; environment = { - etc = lib.mapAttrs' (name: conf: lib.nameValuePair "shorewall6/${name}" {source=conf;}) cfg.configs; + etc = lib.mapAttrs' ( + name: conf: lib.nameValuePair "shorewall6/${name}" { source = conf; } + ) cfg.configs; systemPackages = [ cfg.package ]; }; }; diff --git a/nixos/modules/services/networking/sing-box.nix b/nixos/modules/services/networking/sing-box.nix index 1eadeaf4cbc1dc..becf8b62eb7ec6 100644 --- a/nixos/modules/services/networking/sing-box.nix +++ b/nixos/modules/services/networking/sing-box.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.services.sing-box; settingsFormat = pkgs.formats.json { }; diff --git a/nixos/modules/services/networking/sitespeed-io.nix b/nixos/modules/services/networking/sitespeed-io.nix index 2af12ac0be520b..338328dd94f04d 100644 --- a/nixos/modules/services/networking/sitespeed-io.nix +++ b/nixos/modules/services/networking/sitespeed-io.nix @@ -1,4 +1,9 @@ -{ lib, config, pkgs, ... }: +{ + lib, + config, + pkgs, + ... +}: let cfg = config.services.sitespeed-io; format = pkgs.formats.json { }; @@ -41,53 +46,55 @@ in for every run listed here. This lets you examine different websites with different sitespeed-io settings. ''; - type = lib.types.listOf (lib.types.submodule { - options = { - urls = lib.mkOption { - type = with lib.types; listOf str; - default = []; - description = '' - URLs the service should monitor. - ''; - }; + type = lib.types.listOf ( + lib.types.submodule { + options = { + urls = lib.mkOption { + type = with lib.types; listOf str; + default = [ ]; + description = '' + URLs the service should monitor. + ''; + }; - settings = lib.mkOption { - type = lib.types.submodule { - freeformType = format.type; - options = { }; + settings = lib.mkOption { + type = lib.types.submodule { + freeformType = format.type; + options = { }; + }; + default = { }; + description = '' + Configuration for sitespeed-io, see + + for available options. The value here will be directly transformed to + JSON and passed as `--config` to the program. + ''; }; - default = { }; - description = '' - Configuration for sitespeed-io, see - - for available options. The value here will be directly transformed to - JSON and passed as `--config` to the program. - ''; - }; - extraArgs = lib.mkOption { - type = with lib.types; listOf str; - default = []; - description = '' - Extra command line arguments to pass to the program. - ''; + extraArgs = lib.mkOption { + type = with lib.types; listOf str; + default = [ ]; + description = '' + Extra command line arguments to pass to the program. + ''; + }; }; - }; - }); + } + ); }; }; config = lib.mkIf cfg.enable { assertions = [ - { - assertion = cfg.runs != []; - message = "At least one run must be configured."; - } - { - assertion = lib.all (run: run.urls != []) cfg.runs; - message = "All runs must have at least one url configured."; - } - ]; + { + assertion = cfg.runs != [ ]; + message = "At least one run must be configured."; + } + { + assertion = lib.all (run: run.urls != [ ]) cfg.runs; + message = "All runs must have at least one url configured."; + } + ]; systemd.services.sitespeed-io = { description = "Check website status"; @@ -97,15 +104,16 @@ in User = cfg.user; }; preStart = "chmod u+w -R ${cfg.dataDir}"; # Make sure things are writable - script = (lib.concatMapStrings (run: '' - ${lib.getExe cfg.package} \ - --config ${format.generate "sitespeed.json" run.settings} \ - ${lib.escapeShellArgs run.extraArgs} \ - ${builtins.toFile "urls.txt" (lib.concatLines run.urls)} & - '') cfg.runs) + - '' - wait - ''; + script = + (lib.concatMapStrings (run: '' + ${lib.getExe cfg.package} \ + --config ${format.generate "sitespeed.json" run.settings} \ + ${lib.escapeShellArgs run.extraArgs} \ + ${builtins.toFile "urls.txt" (lib.concatLines run.urls)} & + '') cfg.runs) + + '' + wait + ''; }; users = { diff --git a/nixos/modules/services/networking/solanum.nix b/nixos/modules/services/networking/solanum.nix index f9d3c30b3bbbff..ab77ae0d4c9aa9 100644 --- a/nixos/modules/services/networking/solanum.nix +++ b/nixos/modules/services/networking/solanum.nix @@ -1,7 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkIf mkOption types; + inherit (lib) + mkEnableOption + mkIf + mkOption + types + ; inherit (pkgs) solanum util-linux; cfg = config.services.solanum; @@ -73,37 +83,38 @@ in }; - ###### implementation - config = mkIf cfg.enable (lib.mkMerge [ - { - - environment.etc."solanum/ircd.conf".source = configFile; - - systemd.services.solanum = { - description = "Solanum IRC daemon"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - reloadIfChanged = true; - restartTriggers = [ - configFile - ]; - serviceConfig = { - ExecStart = "${solanum}/bin/solanum -foreground -logfile /dev/stdout -configfile /etc/solanum/ircd.conf -pidfile /run/solanum/ircd.pid"; - ExecReload = "${util-linux}/bin/kill -HUP $MAINPID"; - DynamicUser = true; - User = "solanum"; - StateDirectory = "solanum"; - RuntimeDirectory = "solanum"; - LimitNOFILE = "${toString cfg.openFilesLimit}"; + config = mkIf cfg.enable ( + lib.mkMerge [ + { + + environment.etc."solanum/ircd.conf".source = configFile; + + systemd.services.solanum = { + description = "Solanum IRC daemon"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + reloadIfChanged = true; + restartTriggers = [ + configFile + ]; + serviceConfig = { + ExecStart = "${solanum}/bin/solanum -foreground -logfile /dev/stdout -configfile /etc/solanum/ircd.conf -pidfile /run/solanum/ircd.pid"; + ExecReload = "${util-linux}/bin/kill -HUP $MAINPID"; + DynamicUser = true; + User = "solanum"; + StateDirectory = "solanum"; + RuntimeDirectory = "solanum"; + LimitNOFILE = "${toString cfg.openFilesLimit}"; + }; }; - }; - } + } - (mkIf (cfg.motd != null) { - environment.etc."solanum/ircd.motd".text = cfg.motd; - }) - ]); + (mkIf (cfg.motd != null) { + environment.etc."solanum/ircd.motd".text = cfg.motd; + }) + ] + ); } diff --git a/nixos/modules/services/networking/strongswan-swanctl/param-constructors.nix b/nixos/modules/services/networking/strongswan-swanctl/param-constructors.nix index 8746cfc58f7229..cb4ef1079016f8 100644 --- a/nixos/modules/services/networking/strongswan-swanctl/param-constructors.nix +++ b/nixos/modules/services/networking/strongswan-swanctl/param-constructors.nix @@ -39,13 +39,13 @@ # { "${name}" = string }. This allows parameters to change the attribute # name like in the previous example. -lib : +lib: with lib; with (import ./param-lib.nix lib); rec { - mkParamOfType = type : strongswanDefault : description : { + mkParamOfType = type: strongswanDefault: description: { _type = "param"; option = mkOption { type = types.nullOr type; @@ -55,37 +55,42 @@ rec { render = single toString; }; - documentDefault = description : strongswanDefault : - if strongswanDefault == null - then description - else (description + '' + documentDefault = + description: strongswanDefault: + if strongswanDefault == null then + description + else + ( + description + + '' - StrongSwan default: ````${builtins.toJSON strongswanDefault}```` - ''); + StrongSwan default: ````${builtins.toJSON strongswanDefault}```` + '' + ); single = f: name: value: { ${name} = f value; }; - mkStrParam = mkParamOfType types.str; + mkStrParam = mkParamOfType types.str; mkOptionalStrParam = mkStrParam null; - mkEnumParam = values : mkParamOfType (types.enum values); + mkEnumParam = values: mkParamOfType (types.enum values); - mkIntParam = mkParamOfType types.int; + mkIntParam = mkParamOfType types.int; mkOptionalIntParam = mkIntParam null; # We should have floats in Nix... mkFloatParam = mkStrParam; # TODO: Check for hex format: - mkHexParam = mkStrParam; + mkHexParam = mkStrParam; mkOptionalHexParam = mkOptionalStrParam; # TODO: Check for duration format: - mkDurationParam = mkStrParam; + mkDurationParam = mkStrParam; mkOptionalDurationParam = mkOptionalStrParam; - mkYesNoParam = strongswanDefault : description : { + mkYesNoParam = strongswanDefault: description: { _type = "param"; option = mkOption { type = types.nullOr types.bool; @@ -95,12 +100,12 @@ rec { render = single (b: if b then "yes" else "no"); }; yes = true; - no = false; + no = false; mkSpaceSepListParam = mkSepListParam " "; mkCommaSepListParam = mkSepListParam ","; - mkSepListParam = sep : strongswanDefault : description : { + mkSepListParam = sep: strongswanDefault: description: { _type = "param"; option = mkOption { type = types.nullOr (types.listOf types.str); @@ -110,54 +115,53 @@ rec { render = single (value: concatStringsSep sep value); }; - mkAttrsOfParams = params : - mkAttrsOf params (types.submodule {options = paramsToOptions params;}); + mkAttrsOfParams = params: mkAttrsOf params (types.submodule { options = paramsToOptions params; }); - mkAttrsOfParam = param : - mkAttrsOf param param.option.type; + mkAttrsOfParam = param: mkAttrsOf param param.option.type; - mkAttrsOf = param : option : description : { + mkAttrsOf = param: option: description: { _type = "param"; option = mkOption { type = types.attrsOf option; - default = {}; + default = { }; description = description; }; - render = single (attrs: - (paramsToRenderedStrings attrs - (mapAttrs (_n: _v: param) attrs))); + render = single (attrs: (paramsToRenderedStrings attrs (mapAttrs (_n: _v: param) attrs))); }; - mkPrefixedAttrsOfParams = params : - mkPrefixedAttrsOf params (types.submodule {options = paramsToOptions params;}); + mkPrefixedAttrsOfParams = + params: mkPrefixedAttrsOf params (types.submodule { options = paramsToOptions params; }); - mkPrefixedAttrsOfParam = param : - mkPrefixedAttrsOf param param.option.type; + mkPrefixedAttrsOfParam = param: mkPrefixedAttrsOf param param.option.type; - mkPrefixedAttrsOf = p : option : description : { + mkPrefixedAttrsOf = p: option: description: { _type = "param"; option = mkOption { type = types.attrsOf option; - default = {}; + default = { }; description = description; }; - render = prefix: attrs: - let prefixedAttrs = mapAttrs' (name: nameValuePair "${prefix}-${name}") attrs; - in paramsToRenderedStrings prefixedAttrs - (mapAttrs (_n: _v: p) prefixedAttrs); + render = + prefix: attrs: + let + prefixedAttrs = mapAttrs' (name: nameValuePair "${prefix}-${name}") attrs; + in + paramsToRenderedStrings prefixedAttrs (mapAttrs (_n: _v: p) prefixedAttrs); }; - mkPostfixedAttrsOfParams = params : description : { + mkPostfixedAttrsOfParams = params: description: { _type = "param"; option = mkOption { - type = types.attrsOf (types.submodule {options = paramsToOptions params;}); - default = {}; + type = types.attrsOf (types.submodule { options = paramsToOptions params; }); + default = { }; description = description; }; - render = postfix: attrs: - let postfixedAttrs = mapAttrs' (name: nameValuePair "${name}-${postfix}") attrs; - in paramsToRenderedStrings postfixedAttrs - (mapAttrs (_n: _v: params) postfixedAttrs); + render = + postfix: attrs: + let + postfixedAttrs = mapAttrs' (name: nameValuePair "${name}-${postfix}") attrs; + in + paramsToRenderedStrings postfixedAttrs (mapAttrs (_n: _v: params) postfixedAttrs); }; } diff --git a/nixos/modules/services/networking/strongswan-swanctl/param-lib.nix b/nixos/modules/services/networking/strongswan-swanctl/param-lib.nix index 2bbb39a76049be..1619cb6cf089c4 100644 --- a/nixos/modules/services/networking/strongswan-swanctl/param-lib.nix +++ b/nixos/modules/services/networking/strongswan-swanctl/param-lib.nix @@ -1,9 +1,9 @@ -lib : +lib: with lib; rec { - paramsToConf = cfg : ps : mkConf 0 (paramsToRenderedStrings cfg ps); + paramsToConf = cfg: ps: mkConf 0 (paramsToRenderedStrings cfg ps); # mkConf takes an indentation level (which usually starts at 0) and a nested # attribute set of strings and will render that set to a strongswan.conf style @@ -18,65 +18,80 @@ rec { # } # d = 4 # }'' - mkConf = indent : ps : - concatMapStringsSep "\n" - (name: - let value = ps.${name}; - indentation = replicate indent " "; - in - indentation + ( - if isAttrs value - then "${name} {\n" + - mkConf (indent + 2) value + "\n" + - indentation + "}" - else "${name} = ${value}" - ) + mkConf = + indent: ps: + concatMapStringsSep "\n" ( + name: + let + value = ps.${name}; + indentation = replicate indent " "; + in + indentation + + ( + if isAttrs value then + "${name} {\n" + mkConf (indent + 2) value + "\n" + indentation + "}" + else + "${name} = ${value}" ) - (attrNames ps); + ) (attrNames ps); - replicate = n : c : concatStrings (builtins.genList (_x : c) n); + replicate = n: c: concatStrings (builtins.genList (_x: c) n); # `paramsToRenderedStrings cfg ps` converts the NixOS configuration `cfg` # (typically the "config" argument of a NixOS module) and the set of # parameters `ps` (an attribute set where the values are constructed using the # parameter constructors in ./param-constructors.nix) to a nested attribute # set of strings (rendered parameters). - paramsToRenderedStrings = cfg : ps : + paramsToRenderedStrings = + cfg: ps: filterEmptySets ( - (mapParamsRecursive (path: name: param: - let value = attrByPath path null cfg; - in optionalAttrs (value != null) (param.render name value) - ) ps)); + (mapParamsRecursive ( + path: name: param: + let + value = attrByPath path null cfg; + in + optionalAttrs (value != null) (param.render name value) + ) ps) + ); - filterEmptySets = set : filterAttrs (n: v: (v != null)) (mapAttrs (name: value: - if isAttrs value - then let value' = filterEmptySets value; - in if value' == {} - then null - else value' - else value - ) set); + filterEmptySets = + set: + filterAttrs (n: v: (v != null)) ( + mapAttrs ( + name: value: + if isAttrs value then + let + value' = filterEmptySets value; + in + if value' == { } then null else value' + else + value + ) set + ); # Recursively map over every parameter in the given attribute set. mapParamsRecursive = mapAttrsRecursiveCond' (as: (!(as ? _type && as._type == "param"))); - mapAttrsRecursiveCond' = cond: f: set: + mapAttrsRecursiveCond' = + cond: f: set: let - recurse = path: set: + recurse = + path: set: let g = name: value: - if isAttrs value && cond value - then { ${name} = recurse (path ++ [name]) value; } - else f (path ++ [name]) name value; - in mapAttrs'' g set; - in recurse [] set; + if isAttrs value && cond value then + { ${name} = recurse (path ++ [ name ]) value; } + else + f (path ++ [ name ]) name value; + in + mapAttrs'' g set; + in + recurse [ ] set; - mapAttrs'' = f: set: - foldl' (a: b: a // b) {} (map (attr: f attr set.${attr}) (attrNames set)); + mapAttrs'' = f: set: foldl' (a: b: a // b) { } (map (attr: f attr set.${attr}) (attrNames set)); # Extract the options from the given set of parameters. - paramsToOptions = ps : - mapParamsRecursive (_path: name: param: { ${name} = param.option; }) ps; + paramsToOptions = ps: mapParamsRecursive (_path: name: param: { ${name} = param.option; }) ps; } diff --git a/nixos/modules/services/networking/strongswan-swanctl/swanctl-params.nix b/nixos/modules/services/networking/strongswan-swanctl/swanctl-params.nix index e74b3cae7c7837..197b8debaf8387 100644 --- a/nixos/modules/services/networking/strongswan-swanctl/swanctl-params.nix +++ b/nixos/modules/services/networking/strongswan-swanctl/swanctl-params.nix @@ -8,7 +8,8 @@ # cd strongswan # git diff 5.7.2..5.8.0 src/swanctl/swanctl.opt -lib: with (import ./param-constructors.nix lib); +lib: +with (import ./param-constructors.nix lib); let certParams = { @@ -34,1234 +35,1290 @@ let Optional PKCS#11 module name. ''; }; -in { - authorities = mkAttrsOfParams ({ - - cacert = mkOptionalStrParam '' - The certificates may use a relative path from the swanctl - `x509ca` directory or an absolute path. - - Configure one of {option}`cacert`, - {option}`file`, or - {option}`handle` per section. - ''; - - cert_uri_base = mkOptionalStrParam '' - Defines the base URI for the Hash and URL feature supported by - IKEv2. Instead of exchanging complete certificates, IKEv2 allows one to - send an URI that resolves to the DER encoded certificate. The certificate - URIs are built by appending the SHA1 hash of the DER encoded certificates - to this base URI. - ''; - - crl_uris = mkCommaSepListParam [] '' - List of CRL distribution points (ldap, http, or file URI). - ''; - - ocsp_uris = mkCommaSepListParam [] '' - List of OCSP URIs. - ''; - - } // certParams) '' - Section defining complementary attributes of certification authorities, each - in its own subsection with an arbitrary yet unique name - ''; - - connections = mkAttrsOfParams { - - version = mkIntParam 0 '' - IKE major version to use for connection. - - - 1 uses IKEv1 aka ISAKMP, - - 2 uses IKEv2. - - A connection using the default of 0 accepts both IKEv1 and IKEv2 as - responder, and initiates the connection actively with IKEv2. - ''; - - local_addrs = mkCommaSepListParam [] '' - Local address(es) to use for IKE communication. Takes - single IPv4/IPv6 addresses, DNS names, CIDR subnets or IP address ranges. - - As initiator, the first non-range/non-subnet is used to initiate the - connection from. As responder, the local destination address must match at - least to one of the specified addresses, subnets or ranges. - - If FQDNs are assigned they are resolved every time a configuration lookup - is done. If DNS resolution times out, the lookup is delayed for that time. - ''; - - remote_addrs = mkCommaSepListParam [] '' - Remote address(es) to use for IKE communication. Takes - single IPv4/IPv6 addresses, DNS names, CIDR subnets or IP address ranges. - - As initiator, the first non-range/non-subnet is used to initiate the - connection to. As responder, the initiator source address must match at - least to one of the specified addresses, subnets or ranges. - - If FQDNs are assigned they are resolved every time a configuration lookup - is done. If DNS resolution times out, the lookup is delayed for that time. - To initiate a connection, at least one specific address or DNS name must - be specified. - ''; - - local_port = mkIntParam 500 '' - Local UDP port for IKE communication. By default the port of the socket - backend is used, which is usually `500`. If port - `500` is used, automatic IKE port floating to port - `4500` is used to work around NAT issues. - - Using a non-default local IKE port requires support from the socket - backend in use (socket-dynamic). - ''; - - remote_port = mkIntParam 500 '' - Remote UDP port for IKE communication. If the default of port - `500` is used, automatic IKE port floating to port - `4500` is used to work around NAT issues. - ''; - - proposals = mkCommaSepListParam ["default"] '' - A proposal is a set of algorithms. For non-AEAD algorithms, this includes - for IKE an encryption algorithm, an integrity algorithm, a pseudo random - function and a Diffie-Hellman group. For AEAD algorithms, instead of - encryption and integrity algorithms, a combined algorithm is used. - - In IKEv2, multiple algorithms of the same kind can be specified in a - single proposal, from which one gets selected. In IKEv1, only one - algorithm per kind is allowed per proposal, more algorithms get implicitly - stripped. Use multiple proposals to offer different algorithms - combinations in IKEv1. - - Algorithm keywords get separated using dashes. Multiple proposals may be - specified in a list. The special value `default` forms a - default proposal of supported algorithms considered safe, and is usually a - good choice for interoperability. - ''; - - vips = mkCommaSepListParam [] '' - List of virtual IPs to request in IKEv2 configuration payloads or IKEv1 - Mode Config. The wildcard addresses `0.0.0.0` and - `::` request an arbitrary address, specific addresses may - be defined. The responder may return a different address, though, or none - at all. - ''; - - aggressive = mkYesNoParam no '' - Enables Aggressive Mode instead of Main Mode with Identity - Protection. Aggressive Mode is considered less secure, because the ID and - HASH payloads are exchanged unprotected. This allows a passive attacker to - snoop peer identities, and even worse, start dictionary attacks on the - Preshared Key. - ''; - - pull = mkYesNoParam yes '' - If the default of yes is used, Mode Config works in pull mode, where the - initiator actively requests a virtual IP. With no, push mode is used, - where the responder pushes down a virtual IP to the initiating peer. - - Push mode is currently supported for IKEv1, but not in IKEv2. It is used - by a few implementations only, pull mode is recommended. - ''; - - dscp = mkStrParam "000000" '' - Differentiated Services Field Codepoint to set on outgoing IKE packets for - this connection. The value is a six digit binary encoded string specifying - the Codepoint to set, as defined in RFC 2474. - ''; - - encap = mkYesNoParam no '' - To enforce UDP encapsulation of ESP packets, the IKE daemon can fake the - NAT detection payloads. This makes the peer believe that NAT takes place - on the path, forcing it to encapsulate ESP packets in UDP. - - Usually this is not required, but it can help to work around connectivity - issues with too restrictive intermediary firewalls. - ''; - - mobike = mkYesNoParam yes '' - Enables MOBIKE on IKEv2 connections. MOBIKE is enabled by default on IKEv2 - connections, and allows mobility of clients and multi-homing on servers by - migrating active IPsec tunnels. - - Usually keeping MOBIKE enabled is unproblematic, as it is not used if the - peer does not indicate support for it. However, due to the design of - MOBIKE, IKEv2 always floats to port 4500 starting from the second - exchange. Some implementations don't like this behavior, hence it can be - disabled. - ''; - - dpd_delay = mkDurationParam "0s" '' - Interval to check the liveness of a peer actively using IKEv2 - INFORMATIONAL exchanges or IKEv1 R_U_THERE messages. Active DPD checking - is only enforced if no IKE or ESP/AH packet has been received for the - configured DPD delay. - ''; - - dpd_timeout = mkDurationParam "0s" '' - Charon by default uses the normal retransmission mechanism and timeouts to - check the liveness of a peer, as all messages are used for liveness - checking. For compatibility reasons, with IKEv1 a custom interval may be - specified; this option has no effect on connections using IKEv2. - ''; - - fragmentation = mkEnumParam ["yes" "accept" "force" "no"] "yes" '' - Use IKE fragmentation (proprietary IKEv1 extension or RFC 7383 IKEv2 - fragmentation). Acceptable values are `yes` (the default - since 5.5.1), `accept` (since versions:5.5.3), - `force` and `no`. - - - If set to `yes`, and the peer - supports it, oversized IKE messages will be sent in fragments. - - If set to - `accept`, support for fragmentation is announced to the peer but the daemon - does not send its own messages in fragments. - - If set to `force` (only - supported for IKEv1) the initial IKE message will already be fragmented if - required. - - Finally, setting the option to `no` will disable announcing - support for this feature. - - Note that fragmented IKE messages sent by a peer are always processed - irrespective of the value of this option (even when set to no). - ''; - - childless = mkEnumParam [ "allow" "prefer" "force" "never" ] "allow" '' - Use childless IKE_SA initiation (_allow_, _prefer_, _force_ or _never_). - - Use childless IKE_SA initiation (RFC 6023) for IKEv2, with the first - CHILD_SA created with a separate CREATE_CHILD_SA exchange (e.g. to use an - independent DH exchange for all CHILD_SAs). Acceptable values are `allow` - (the default), `prefer`, `force` and `never`. If set to `allow`, responders - will accept childless IKE_SAs (as indicated via notify in the IKE_SA_INIT - response) while initiators continue to create regular IKE_SAs with the first - CHILD_SA created during IKE_AUTH, unless the IKE_SA is initiated explicitly - without any children (which will fail if the responder does not support or - has disabled this extension). The effect of `prefer` is the same as `allow` - on responders, but as initiator a childless IKE_SA is initiated if the - responder supports it. If set to `force`, only childless initiation is - accepted in either role. Finally, setting the option to `never` disables - support for childless IKE_SAs as responder. - ''; - - send_certreq = mkYesNoParam yes '' - Send certificate request payloads to offer trusted root CA certificates to - the peer. Certificate requests help the peer to choose an appropriate - certificate/private key for authentication and are enabled by default. - Disabling certificate requests can be useful if too many trusted root CA - certificates are installed, as each certificate request increases the size - of the initial IKE packets. - ''; - - send_cert = mkEnumParam ["always" "never" "ifasked" ] "ifasked" '' - Send certificate payloads when using certificate authentication. - - - With the default of `ifasked` the daemon sends - certificate payloads only if certificate requests have been received. - - `never` disables sending of certificate payloads - altogether, - - `always` causes certificate payloads to be sent - unconditionally whenever certificate authentication is used. - ''; - - ppk_id = mkOptionalStrParam '' - String identifying the Postquantum Preshared Key (PPK) to be used. - ''; - - ppk_required = mkYesNoParam no '' - Whether a Postquantum Preshared Key (PPK) is required for this connection. - ''; - - keyingtries = mkIntParam 1 '' - Number of retransmission sequences to perform during initial - connect. Instead of giving up initiation after the first retransmission - sequence with the default value of `1`, additional - sequences may be started according to the configured value. A value of - `0` initiates a new sequence until the connection - establishes or fails with a permanent error. - ''; - - unique = mkEnumParam ["no" "never" "keep" "replace"] "no" '' - Connection uniqueness policy to enforce. To avoid multiple connections - from the same user, a uniqueness policy can be enforced. - - - The value `never` does never enforce such a policy, even - if a peer included INITIAL_CONTACT notification messages, - - whereas `no` replaces existing connections for the same - identity if a new one has the INITIAL_CONTACT notify. - - `keep` rejects new connection attempts if the same user - already has an active connection, - - `replace` deletes any existing connection if a new one - for the same user gets established. - - To compare connections for uniqueness, the remote IKE identity is used. If - EAP or XAuth authentication is involved, the EAP-Identity or XAuth - username is used to enforce the uniqueness policy instead. - - On initiators this setting specifies whether an INITIAL_CONTACT notify is - sent during IKE_AUTH if no existing connection is found with the remote - peer (determined by the identities of the first authentication - round). Unless set to `never` the client will send a notify. - ''; - - reauth_time = mkDurationParam "0s" '' - Time to schedule IKE reauthentication. IKE reauthentication recreates the - IKE/ISAKMP SA from scratch and re-evaluates the credentials. In asymmetric - configurations (with EAP or configuration payloads) it might not be - possible to actively reauthenticate as responder. The IKEv2 - reauthentication lifetime negotiation can instruct the client to perform - reauthentication. - - Reauthentication is disabled by default. Enabling it usually may lead to - small connection interruptions, as strongSwan uses a break-before-make - policy with IKEv2 to avoid any conflicts with associated tunnel resources. - ''; - - rekey_time = mkDurationParam "4h" '' - IKE rekeying refreshes key material using a Diffie-Hellman exchange, but - does not re-check associated credentials. It is supported in IKEv2 only, - IKEv1 performs a reauthentication procedure instead. - - With the default value IKE rekeying is scheduled every 4 hours, minus the - configured rand_time. If a reauth_time is configured, rekey_time defaults - to zero, disabling rekeying; explicitly set both to enforce rekeying and - reauthentication. - ''; - - over_time = mkOptionalDurationParam '' - Hard IKE_SA lifetime if rekey/reauth does not complete, as time. To avoid - having an IKE/ISAKMP kept alive if IKE reauthentication or rekeying fails - perpetually, a maximum hard lifetime may be specified. If the IKE_SA fails - to rekey or reauthenticate within the specified time, the IKE_SA gets - closed. - - In contrast to CHILD_SA rekeying, over_time is relative in time to the - rekey_time and reauth_time values, as it applies to both. - - The default is 10% of the longer of {option}`rekey_time` and - {option}`reauth_time`. - ''; - - rand_time = mkOptionalDurationParam '' - Time range from which to choose a random value to subtract from - rekey/reauth times. To avoid having both peers initiating the rekey/reauth - procedure simultaneously, a random time gets subtracted from the - rekey/reauth times. - - The default is equal to the configured {option}`over_time`. - ''; - - pools = mkCommaSepListParam [] '' - List of named IP pools to allocate virtual IP addresses - and other configuration attributes from. Each name references a pool by - name from either the pools section or an external pool. - ''; - - if_id_in = mkStrParam "0" '' - XFRM interface ID set on inbound policies/SA, can be overridden by child - config, see there for details. - - The special value `%unique` allocates a unique interface ID per IKE_SA, - which is inherited by all its CHILD_SAs (unless overridden there), beyond - that the value `%unique-dir` assigns a different unique interface ID for - each direction (in/out). - - ''; - - if_id_out = mkStrParam "0" '' - XFRM interface ID set on outbound policies/SA, can be overridden by child - config, see there for details. - - The special value `%unique` allocates a unique interface ID per IKE_SA, - which is inherited by all its CHILD_SAs (unless overridden there), beyond - that the value `%unique-dir` assigns a different unique interface ID for - each direction (in/out). - ''; - - mediation = mkYesNoParam no '' - Whether this connection is a mediation connection, that is, whether this - connection is used to mediate other connections using the IKEv2 Mediation - Extension. Mediation connections create no CHILD_SA. - ''; - - mediated_by = mkOptionalStrParam '' - The name of the connection to mediate this connection through. If given, - the connection will be mediated through the named mediation - connection. The mediation connection must have mediation enabled. - ''; - - mediation_peer = mkOptionalStrParam '' - Identity under which the peer is registered at the mediation server, that - is, the IKE identity the other end of this connection uses as its local - identity on its connection to the mediation server. This is the identity - we request the mediation server to mediate us with. Only relevant on - connections that set mediated_by. If it is not given, the remote IKE - identity of the first authentication round of this connection will be - used. - ''; - - local = mkPrefixedAttrsOfParams { - - round = mkIntParam 0 '' - Optional numeric identifier by which authentication rounds are - sorted. If not specified rounds are ordered by their position in the - config file/vici message. - ''; - - certs = mkCommaSepListParam [] '' - List of certificate candidates to use for - authentication. The certificates may use a relative path from the - swanctl `x509` directory or an absolute path. - - The certificate used for authentication is selected based on the - received certificate request payloads. If no appropriate CA can be - located, the first certificate is used. - ''; - - cert = mkPostfixedAttrsOfParams certParams '' - Section for a certificate candidate to use for - authentication. Certificates in certs are transmitted as binary blobs, - these sections offer more flexibility. - ''; - - pubkeys = mkCommaSepListParam [] '' - List of raw public key candidates to use for - authentication. The public keys may use a relative path from the swanctl - `pubkey` directory or an absolute path. - - Even though multiple local public keys could be defined in principle, - only the first public key in the list is used for authentication. - ''; - - auth = mkStrParam "pubkey" '' - Authentication to perform locally. - - - The default `pubkey` uses public key authentication - using a private key associated to a usable certificate. - - `psk` uses pre-shared key authentication. - - The IKEv1 specific `xauth` is used for XAuth or Hybrid - authentication, - - while the IKEv2 specific `eap` keyword defines EAP - authentication. - - For `xauth`, a specific backend name may be appended, - separated by a dash. The appropriate `xauth` backend is - selected to perform the XAuth exchange. For traditional XAuth, the - `xauth` method is usually defined in the second - authentication round following an initial `pubkey` (or - `psk`) round. Using `xauth` in the - first round performs Hybrid Mode client authentication. - - For `eap`, a specific EAP method name may be appended, separated by a - dash. An EAP module implementing the appropriate method is selected to - perform the EAP conversation. - - Since 5.4.0, if both peers support RFC 7427 ("Signature Authentication - in IKEv2") specific hash algorithms to be used during IKEv2 - authentication may be configured. To do so use `ike:` - followed by a trust chain signature scheme constraint (see description - of the {option}`remote` section's {option}`auth` - keyword). For example, with `ike:pubkey-sha384-sha256` - a public key signature scheme with either SHA-384 or SHA-256 would get - used for authentication, in that order and depending on the hash - algorithms supported by the peer. If no specific hash algorithms are - configured, the default is to prefer an algorithm that matches or - exceeds the strength of the signature key. If no constraints with - `ike:` prefix are configured any signature scheme - constraint (without `ike:` prefix) will also apply to - IKEv2 authentication, unless this is disabled in - `strongswan.conf`. To use RSASSA-PSS signatures use - `rsa/pss` instead of `pubkey` or - `rsa` as in e.g. - `ike:rsa/pss-sha256`. If `pubkey` or - `rsa` constraints are configured RSASSA-PSS signatures - will only be used if enabled in `strongswan.conf`(5). - ''; - - id = mkOptionalStrParam '' - IKE identity to use for authentication round. When using certificate - authentication, the IKE identity must be contained in the certificate, - either as subject or as subjectAltName. - ''; - - eap_id = mkOptionalStrParam '' - Client EAP-Identity to use in EAP-Identity exchange and the EAP method. - ''; - - aaa_id = mkOptionalStrParam '' - Server side EAP-Identity to expect in the EAP method. Some EAP methods, - such as EAP-TLS, use an identity for the server to perform mutual - authentication. This identity may differ from the IKE identity, - especially when EAP authentication is delegated from the IKE responder - to an AAA backend. - - For EAP-(T)TLS, this defines the identity for which the server must - provide a certificate in the TLS exchange. - ''; - - xauth_id = mkOptionalStrParam '' - Client XAuth username used in the XAuth exchange. - ''; - - } '' - Section for a local authentication round. A local authentication round - defines the rules how authentication is performed for the local - peer. Multiple rounds may be defined to use IKEv2 RFC 4739 Multiple - Authentication or IKEv1 XAuth. - - Each round is defined in a section having `local` as - prefix, and an optional unique suffix. To define a single authentication - round, the suffix may be omitted. - ''; - - remote = mkPrefixedAttrsOfParams { - - round = mkIntParam 0 '' - Optional numeric identifier by which authentication rounds are - sorted. If not specified rounds are ordered by their position in the - config file/vici message. - ''; - - id = mkStrParam "%any" '' - IKE identity to expect for authentication round. When using certificate - authentication, the IKE identity must be contained in the certificate, - either as subject or as subjectAltName. - ''; - - eap_id = mkOptionalStrParam '' - Identity to use as peer identity during EAP authentication. If set to - `%any` the EAP-Identity method will be used to ask the - client for an EAP identity. - ''; - - groups = mkCommaSepListParam [] '' - Authorization group memberships to require. The peer - must prove membership to at least one of the specified groups. Group - membership can be certified by different means, for example by - appropriate Attribute Certificates or by an AAA backend involved in the - authentication. - ''; - - cert_policy = mkCommaSepListParam [] '' - List of certificate policy OIDs the peer's certificate - must have. OIDs are specified using the numerical dotted representation. - ''; - - certs = mkCommaSepListParam [] '' - List of certificates to accept for authentication. The certificates may - use a relative path from the swanctl `x509` directory - or an absolute path. - ''; - - cert = mkPostfixedAttrsOfParams certParams '' - Section for a certificate candidate to use for - authentication. Certificates in certs are transmitted as binary blobs, - these sections offer more flexibility. - ''; - - ca_id = mkOptionalStrParam '' - Identity in CA certificate to accept for authentication. The specified - identity must be contained in one (intermediate) CA of the remote peer - trustchain, either as subject or as subjectAltName. This has the same - effect as specifying `cacerts` to force clients under - a CA to specific connections; it does not require the CA certificate - to be available locally, and can be received from the peer during the - IKE exchange. - ''; - - cacerts = mkCommaSepListParam [] '' - List of CA certificates to accept for - authentication. The certificates may use a relative path from the - swanctl `x509ca` directory or an absolute path. - ''; - - cacert = mkPostfixedAttrsOfParams certParams '' - Section for a CA certificate to accept for authentication. Certificates - in cacerts are transmitted as binary blobs, these sections offer more - flexibility. - ''; - - pubkeys = mkCommaSepListParam [] '' - List of raw public keys to accept for - authentication. The public keys may use a relative path from the swanctl - `pubkey` directory or an absolute path. - ''; - - revocation = mkEnumParam ["strict" "ifuri" "relaxed"] "relaxed" '' - Certificate revocation policy for CRL or OCSP revocation. - - - A `strict` revocation policy fails if no revocation information is - available, i.e. the certificate is not known to be unrevoked. - - `ifuri` fails only if a CRL/OCSP URI is available, but certificate - revocation checking fails, i.e. there should be revocation information - available, but it could not be obtained. - - The default revocation policy `relaxed` fails only if a certificate is - revoked, i.e. it is explicitly known that it is bad. - ''; - - auth = mkStrParam "pubkey" '' - Authentication to expect from remote. See the {option}`local` - section's {option}`auth` keyword description about the details of - supported mechanisms. - - Since 5.4.0, to require a trustchain public key strength for the remote - side, specify the key type followed by the minimum strength in bits (for - example `ecdsa-384` or - `rsa-2048-ecdsa-256`). To limit the acceptable set of - hashing algorithms for trustchain validation, append hash algorithms to - pubkey or a key strength definition (for example - `pubkey-sha256-sha512`, - `rsa-2048-sha256-sha384-sha512` or - `rsa-2048-sha256-ecdsa-256-sha256-sha384`). - Unless disabled in `strongswan.conf`, or explicit IKEv2 - signature constraints are configured (refer to the description of the - {option}`local` section's {option}`auth` keyword for - details), such key types and hash algorithms are also applied as - constraints against IKEv2 signature authentication schemes used by the - remote side. To require RSASSA-PSS signatures use - `rsa/pss` instead of `pubkey` or - `rsa` as in e.g. `rsa/pss-sha256`. If - `pubkey` or `rsa` constraints are - configured RSASSA-PSS signatures will only be accepted if enabled in - `strongswan.conf`(5). - - To specify trust chain constraints for EAP-(T)TLS, append a colon to the - EAP method, followed by the key type/size and hash algorithm as - discussed above (e.g. `eap-tls:ecdsa-384-sha384`). - ''; - - } '' - Section for a remote authentication round. A remote authentication round - defines the constraints how the peers must authenticate to use this - connection. Multiple rounds may be defined to use IKEv2 RFC 4739 Multiple - Authentication or IKEv1 XAuth. - - Each round is defined in a section having `remote` as - prefix, and an optional unique suffix. To define a single authentication - round, the suffix may be omitted. - ''; - - children = mkAttrsOfParams { - ah_proposals = mkCommaSepListParam [] '' - AH proposals to offer for the CHILD_SA. A proposal is a set of - algorithms. For AH, this includes an integrity algorithm and an optional - Diffie-Hellman group. If a DH group is specified, CHILD_SA/Quick Mode - rekeying and initial negotiation uses a separate Diffie-Hellman exchange - using the specified group (refer to esp_proposals for details). - - In IKEv2, multiple algorithms of the same kind can be specified in a - single proposal, from which one gets selected. In IKEv1, only one - algorithm per kind is allowed per proposal, more algorithms get - implicitly stripped. Use multiple proposals to offer different algorithms - combinations in IKEv1. - - Algorithm keywords get separated using dashes. Multiple proposals may be - specified in a list. The special value `default` forms - a default proposal of supported algorithms considered safe, and is - usually a good choice for interoperability. By default no AH proposals - are included, instead ESP is proposed. - ''; - - esp_proposals = mkCommaSepListParam ["default"] '' - ESP proposals to offer for the CHILD_SA. A proposal is a set of - algorithms. For ESP non-AEAD proposals, this includes an integrity - algorithm, an encryption algorithm, an optional Diffie-Hellman group and - an optional Extended Sequence Number Mode indicator. For AEAD proposals, - a combined mode algorithm is used instead of the separate - encryption/integrity algorithms. - - If a DH group is specified, CHILD_SA/Quick Mode rekeying and initial - negotiation use a separate Diffie-Hellman exchange using the specified - group. However, for IKEv2, the keys of the CHILD_SA created implicitly - with the IKE_SA will always be derived from the IKE_SA's key material. So - any DH group specified here will only apply when the CHILD_SA is later - rekeyed or is created with a separate CREATE_CHILD_SA exchange. A - proposal mismatch might, therefore, not immediately be noticed when the - SA is established, but may later cause rekeying to fail. - - Extended Sequence Number support may be indicated with the - `esn` and `noesn` values, both may be - included to indicate support for both modes. If omitted, - `noesn` is assumed. - - In IKEv2, multiple algorithms of the same kind can be specified in a - single proposal, from which one gets selected. In IKEv1, only one - algorithm per kind is allowed per proposal, more algorithms get - implicitly stripped. Use multiple proposals to offer different algorithms - combinations in IKEv1. - - Algorithm keywords get separated using dashes. Multiple proposals may be - specified as a list. The special value `default` forms - a default proposal of supported algorithms considered safe, and is - usually a good choice for interoperability. If no algorithms are - specified for AH nor ESP, the default set of algorithms for ESP is - included. - ''; - - sha256_96 = mkYesNoParam no '' - HMAC-SHA-256 is used with 128-bit truncation with IPsec. For - compatibility with implementations that incorrectly use 96-bit truncation - this option may be enabled to configure the shorter truncation length in - the kernel. This is not negotiated, so this only works with peers that - use the incorrect truncation length (or have this option enabled). - ''; - - local_ts = mkCommaSepListParam ["dynamic"] '' - List of local traffic selectors to include in CHILD_SA. Each selector is - a CIDR subnet definition, followed by an optional proto/port - selector. The special value `dynamic` may be used - instead of a subnet definition, which gets replaced by the tunnel outer - address or the virtual IP, if negotiated. This is the default. - - A protocol/port selector is surrounded by opening and closing square - brackets. Between these brackets, a numeric or getservent(3) protocol - name may be specified. After the optional protocol restriction, an - optional port restriction may be specified, separated by a slash. The - port restriction may be numeric, a getservent(3) service name, or the - special value `opaque` for RFC 4301 OPAQUE - selectors. Port ranges may be specified as well, none of the kernel - backends currently support port ranges, though. - - When IKEv1 is used only the first selector is interpreted, except if the - Cisco Unity extension plugin is used. This is due to a limitation of the - IKEv1 protocol, which only allows a single pair of selectors per - CHILD_SA. So to tunnel traffic matched by several pairs of selectors when - using IKEv1 several children (CHILD_SAs) have to be defined that cover - the selectors. The IKE daemon uses traffic selector narrowing for IKEv1, - the same way it is standardized and implemented for IKEv2. However, this - may lead to problems with other implementations. To avoid that, configure - identical selectors in such scenarios. - ''; - - remote_ts = mkCommaSepListParam ["dynamic"] '' - List of remote selectors to include in CHILD_SA. See - {option}`local_ts` for a description of the selector syntax. - ''; - - rekey_time = mkDurationParam "1h" '' - Time to schedule CHILD_SA rekeying. CHILD_SA rekeying refreshes key - material, optionally using a Diffie-Hellman exchange if a group is - specified in the proposal. To avoid rekey collisions initiated by both - ends simultaneously, a value in the range of {option}`rand_time` - gets subtracted to form the effective soft lifetime. - - By default CHILD_SA rekeying is scheduled every hour, minus - {option}`rand_time`. - ''; - - life_time = mkOptionalDurationParam '' - Maximum lifetime before CHILD_SA gets closed. Usually this hard lifetime - is never reached, because the CHILD_SA gets rekeyed before. If that fails - for whatever reason, this limit closes the CHILD_SA. The default is 10% - more than the {option}`rekey_time`. - ''; - - rand_time = mkOptionalDurationParam '' - Time range from which to choose a random value to subtract from - {option}`rekey_time`. The default is the difference between - {option}`life_time` and {option}`rekey_time`. - ''; - - rekey_bytes = mkIntParam 0 '' - Number of bytes processed before initiating CHILD_SA rekeying. CHILD_SA - rekeying refreshes key material, optionally using a Diffie-Hellman - exchange if a group is specified in the proposal. - - To avoid rekey collisions initiated by both ends simultaneously, a value - in the range of {option}`rand_bytes` gets subtracted to form the - effective soft volume limit. - - Volume based CHILD_SA rekeying is disabled by default. - ''; - - life_bytes = mkOptionalIntParam '' - Maximum bytes processed before CHILD_SA gets closed. Usually this hard - volume limit is never reached, because the CHILD_SA gets rekeyed - before. If that fails for whatever reason, this limit closes the - CHILD_SA. The default is 10% more than {option}`rekey_bytes`. - ''; - - rand_bytes = mkOptionalIntParam '' - Byte range from which to choose a random value to subtract from - {option}`rekey_bytes`. The default is the difference between - {option}`life_bytes` and {option}`rekey_bytes`. - ''; - - rekey_packets = mkIntParam 0 '' - Number of packets processed before initiating CHILD_SA rekeying. CHILD_SA - rekeying refreshes key material, optionally using a Diffie-Hellman - exchange if a group is specified in the proposal. - - To avoid rekey collisions initiated by both ends simultaneously, a value - in the range of {option}`rand_packets` gets subtracted to form - the effective soft packet count limit. - - Packet count based CHILD_SA rekeying is disabled by default. - ''; - - life_packets = mkOptionalIntParam '' - Maximum number of packets processed before CHILD_SA gets closed. Usually - this hard packets limit is never reached, because the CHILD_SA gets - rekeyed before. If that fails for whatever reason, this limit closes the - CHILD_SA. - - The default is 10% more than {option}`rekey_bytes`. - ''; - - rand_packets = mkOptionalIntParam '' - Packet range from which to choose a random value to subtract from - {option}`rekey_packets`. The default is the difference between - {option}`life_packets` and {option}`rekey_packets`. - ''; - - updown = mkOptionalStrParam '' - Updown script to invoke on CHILD_SA up and down events. - ''; - - hostaccess = mkYesNoParam no '' - Hostaccess variable to pass to `updown` script. - ''; - - mode = mkEnumParam [ "tunnel" - "transport" - "transport_proxy" - "beet" - "pass" - "drop" - ] "tunnel" '' - IPsec Mode to establish CHILD_SA with. - - - `tunnel` negotiates the CHILD_SA in IPsec Tunnel Mode, - - whereas `transport` uses IPsec Transport Mode. - - `transport_proxy` signifying the special Mobile IPv6 - Transport Proxy Mode. - - `beet` is the Bound End to End Tunnel mixture mode, - working with fixed inner addresses without the need to include them in - each packet. - - Both `transport` and `beet` modes are - subject to mode negotiation; `tunnel` mode is - negotiated if the preferred mode is not available. - - `pass` and `drop` are used to install - shunt policies which explicitly bypass the defined traffic from IPsec - processing or drop it, respectively. - ''; - - policies = mkYesNoParam yes '' - Whether to install IPsec policies or not. Disabling this can be useful in - some scenarios e.g. MIPv6, where policies are not managed by the IKE - daemon. Since 5.3.3. - ''; - - policies_fwd_out = mkYesNoParam no '' - Whether to install outbound FWD IPsec policies or not. Enabling this is - required in case there is a drop policy that would match and block - forwarded traffic for this CHILD_SA. Since 5.5.1. - ''; - - dpd_action = mkEnumParam ["clear" "trap" "restart"] "clear" '' - Action to perform for this CHILD_SA on DPD timeout. The default clear - closes the CHILD_SA and does not take further action. trap installs a - trap policy, which will catch matching traffic and tries to re-negotiate - the tunnel on-demand. restart immediately tries to re-negotiate the - CHILD_SA under a fresh IKE_SA. - ''; - - ipcomp = mkYesNoParam no '' - Enable IPComp compression before encryption. If enabled, IKE tries to - negotiate IPComp compression to compress ESP payload data prior to - encryption. - ''; - - inactivity = mkDurationParam "0s" '' - Timeout before closing CHILD_SA after inactivity. If no traffic has been - processed in either direction for the configured timeout, the CHILD_SA - gets closed due to inactivity. The default value of 0 disables inactivity - checks. - ''; - - reqid = mkIntParam 0 '' - Fixed reqid to use for this CHILD_SA. This might be helpful in some - scenarios, but works only if each CHILD_SA configuration is instantiated - not more than once. The default of 0 uses dynamic reqids, allocated - incrementally. - ''; - - priority = mkIntParam 0 '' - Optional fixed priority for IPsec policies. This could be useful to - install high-priority drop policies. The default of 0 uses dynamically - calculated priorities based on the size of the traffic selectors. - ''; - - interface = mkOptionalStrParam '' - Optional interface name to restrict outbound IPsec policies. - ''; - - mark_in = mkStrParam "0/0x00000000" '' - Netfilter mark and mask for input traffic. On Linux, Netfilter may - require marks on each packet to match an SA/policy having that option - set. This allows installing duplicate policies and enables Netfilter - rules to select specific SAs/policies for incoming traffic. Note that - inbound marks are only set on policies, by default, unless - {option}`mark_in_sa` is enabled. The special value - `%unique` sets a unique mark on each CHILD_SA instance, - beyond that the value `%unique-dir` assigns a different - unique mark for each - - An additional mask may be appended to the mark, separated by - `/`. The default mask if omitted is - `0xffffffff`. - ''; - - mark_in_sa = mkYesNoParam no '' - Whether to set {option}`mark_in` on the inbound SA. By default, - the inbound mark is only set on the inbound policy. The tuple destination - address, protocol and SPI is unique and the mark is not required to find - the correct SA, allowing to mark traffic after decryption instead (where - more specific selectors may be used) to match different policies. Marking - packets before decryption is still possible, even if no mark is set on - the SA. - ''; - - mark_out = mkStrParam "0/0x00000000" '' - Netfilter mark and mask for output traffic. On Linux, Netfilter may - require marks on each packet to match a policy/SA having that option - set. This allows installing duplicate policies and enables Netfilter - rules to select specific policies/SAs for outgoing traffic. The special - value `%unique` sets a unique mark on each CHILD_SA - instance, beyond that the value `%unique-dir` assigns a - different unique mark for each CHILD_SA direction (in/out). - - An additional mask may be appended to the mark, separated by - `/`. The default mask if omitted is - `0xffffffff`. - ''; - - set_mark_in = mkStrParam "0/0x00000000" '' - Netfilter mark applied to packets after the inbound IPsec SA processed - them. This way it's not necessary to mark packets via Netfilter before - decryption or right afterwards to match policies or process them - differently (e.g. via policy routing). - - An additional mask may be appended to the mark, separated by - `/`. The default mask if omitted is 0xffffffff. The - special value `%same` uses the value (but not the mask) - from {option}`mark_in` as mark value, which can be fixed, - `%unique` or `%unique-dir`. - - Setting marks in XFRM input requires Linux 4.19 or higher. - ''; - - set_mark_out = mkStrParam "0/0x00000000" '' - Netfilter mark applied to packets after the outbound IPsec SA processed - them. This allows processing ESP packets differently than the original - traffic (e.g. via policy routing). - - An additional mask may be appended to the mark, separated by - `/`. The default mask if omitted is 0xffffffff. The - special value `%same` uses the value (but not the mask) - from {option}`mark_out` as mark value, which can be fixed, - `%unique_` or `%unique-dir`. - - Setting marks in XFRM output is supported since Linux 4.14. Setting a - mask requires at least Linux 4.19. - ''; - - if_id_in = mkStrParam "0" '' - XFRM interface ID set on inbound policies/SA. This allows installing - duplicate policies/SAs and associates them with an interface with the - same ID. The special value `%unique` sets a unique - interface ID on each CHILD_SA instance, beyond that the value - `%unique-dir` assigns a different unique interface ID - for each CHILD_SA direction (in/out). - ''; - - if_id_out = mkStrParam "0" '' - XFRM interface ID set on outbound policies/SA. This allows installing - duplicate policies/SAs and associates them with an interface with the - same ID. The special value `%unique` sets a unique - interface ID on each CHILD_SA instance, beyond that the value - `%unique-dir` assigns a different unique interface ID - for each CHILD_SA direction (in/out). - - The daemon will not install routes for CHILD_SAs that have this option set. - ''; - - tfc_padding = mkParamOfType (with lib.types; either int (enum ["mtu"])) 0 '' - Pads ESP packets with additional data to have a consistent ESP packet - size for improved Traffic Flow Confidentiality. The padding defines the - minimum size of all ESP packets sent. The default value of - `0` disables TFC padding, the special value - `mtu` adds TFC padding to create a packet size equal to - the Path Maximum Transfer Unit. - ''; - - replay_window = mkIntParam 32 '' - IPsec replay window to configure for this CHILD_SA. Larger values than - the default of `32` are supported using the Netlink - backend only, a value of `0` disables IPsec replay - protection. +in +{ + authorities = + mkAttrsOfParams + ( + { + + cacert = mkOptionalStrParam '' + The certificates may use a relative path from the swanctl + `x509ca` directory or an absolute path. + + Configure one of {option}`cacert`, + {option}`file`, or + {option}`handle` per section. + ''; + + cert_uri_base = mkOptionalStrParam '' + Defines the base URI for the Hash and URL feature supported by + IKEv2. Instead of exchanging complete certificates, IKEv2 allows one to + send an URI that resolves to the DER encoded certificate. The certificate + URIs are built by appending the SHA1 hash of the DER encoded certificates + to this base URI. + ''; + + crl_uris = mkCommaSepListParam [ ] '' + List of CRL distribution points (ldap, http, or file URI). + ''; + + ocsp_uris = mkCommaSepListParam [ ] '' + List of OCSP URIs. + ''; + + } + // certParams + ) + '' + Section defining complementary attributes of certification authorities, each + in its own subsection with an arbitrary yet unique name + ''; + + connections = + mkAttrsOfParams + { + + version = mkIntParam 0 '' + IKE major version to use for connection. + + - 1 uses IKEv1 aka ISAKMP, + - 2 uses IKEv2. + - A connection using the default of 0 accepts both IKEv1 and IKEv2 as + responder, and initiates the connection actively with IKEv2. + ''; + + local_addrs = mkCommaSepListParam [ ] '' + Local address(es) to use for IKE communication. Takes + single IPv4/IPv6 addresses, DNS names, CIDR subnets or IP address ranges. + + As initiator, the first non-range/non-subnet is used to initiate the + connection from. As responder, the local destination address must match at + least to one of the specified addresses, subnets or ranges. + + If FQDNs are assigned they are resolved every time a configuration lookup + is done. If DNS resolution times out, the lookup is delayed for that time. + ''; + + remote_addrs = mkCommaSepListParam [ ] '' + Remote address(es) to use for IKE communication. Takes + single IPv4/IPv6 addresses, DNS names, CIDR subnets or IP address ranges. + + As initiator, the first non-range/non-subnet is used to initiate the + connection to. As responder, the initiator source address must match at + least to one of the specified addresses, subnets or ranges. + + If FQDNs are assigned they are resolved every time a configuration lookup + is done. If DNS resolution times out, the lookup is delayed for that time. + To initiate a connection, at least one specific address or DNS name must + be specified. + ''; + + local_port = mkIntParam 500 '' + Local UDP port for IKE communication. By default the port of the socket + backend is used, which is usually `500`. If port + `500` is used, automatic IKE port floating to port + `4500` is used to work around NAT issues. + + Using a non-default local IKE port requires support from the socket + backend in use (socket-dynamic). + ''; + + remote_port = mkIntParam 500 '' + Remote UDP port for IKE communication. If the default of port + `500` is used, automatic IKE port floating to port + `4500` is used to work around NAT issues. + ''; + + proposals = mkCommaSepListParam [ "default" ] '' + A proposal is a set of algorithms. For non-AEAD algorithms, this includes + for IKE an encryption algorithm, an integrity algorithm, a pseudo random + function and a Diffie-Hellman group. For AEAD algorithms, instead of + encryption and integrity algorithms, a combined algorithm is used. + + In IKEv2, multiple algorithms of the same kind can be specified in a + single proposal, from which one gets selected. In IKEv1, only one + algorithm per kind is allowed per proposal, more algorithms get implicitly + stripped. Use multiple proposals to offer different algorithms + combinations in IKEv1. + + Algorithm keywords get separated using dashes. Multiple proposals may be + specified in a list. The special value `default` forms a + default proposal of supported algorithms considered safe, and is usually a + good choice for interoperability. + ''; + + vips = mkCommaSepListParam [ ] '' + List of virtual IPs to request in IKEv2 configuration payloads or IKEv1 + Mode Config. The wildcard addresses `0.0.0.0` and + `::` request an arbitrary address, specific addresses may + be defined. The responder may return a different address, though, or none + at all. + ''; + + aggressive = mkYesNoParam no '' + Enables Aggressive Mode instead of Main Mode with Identity + Protection. Aggressive Mode is considered less secure, because the ID and + HASH payloads are exchanged unprotected. This allows a passive attacker to + snoop peer identities, and even worse, start dictionary attacks on the + Preshared Key. + ''; + + pull = mkYesNoParam yes '' + If the default of yes is used, Mode Config works in pull mode, where the + initiator actively requests a virtual IP. With no, push mode is used, + where the responder pushes down a virtual IP to the initiating peer. + + Push mode is currently supported for IKEv1, but not in IKEv2. It is used + by a few implementations only, pull mode is recommended. + ''; + + dscp = mkStrParam "000000" '' + Differentiated Services Field Codepoint to set on outgoing IKE packets for + this connection. The value is a six digit binary encoded string specifying + the Codepoint to set, as defined in RFC 2474. + ''; + + encap = mkYesNoParam no '' + To enforce UDP encapsulation of ESP packets, the IKE daemon can fake the + NAT detection payloads. This makes the peer believe that NAT takes place + on the path, forcing it to encapsulate ESP packets in UDP. + + Usually this is not required, but it can help to work around connectivity + issues with too restrictive intermediary firewalls. + ''; + + mobike = mkYesNoParam yes '' + Enables MOBIKE on IKEv2 connections. MOBIKE is enabled by default on IKEv2 + connections, and allows mobility of clients and multi-homing on servers by + migrating active IPsec tunnels. + + Usually keeping MOBIKE enabled is unproblematic, as it is not used if the + peer does not indicate support for it. However, due to the design of + MOBIKE, IKEv2 always floats to port 4500 starting from the second + exchange. Some implementations don't like this behavior, hence it can be + disabled. + ''; + + dpd_delay = mkDurationParam "0s" '' + Interval to check the liveness of a peer actively using IKEv2 + INFORMATIONAL exchanges or IKEv1 R_U_THERE messages. Active DPD checking + is only enforced if no IKE or ESP/AH packet has been received for the + configured DPD delay. + ''; + + dpd_timeout = mkDurationParam "0s" '' + Charon by default uses the normal retransmission mechanism and timeouts to + check the liveness of a peer, as all messages are used for liveness + checking. For compatibility reasons, with IKEv1 a custom interval may be + specified; this option has no effect on connections using IKEv2. + ''; + + fragmentation = mkEnumParam [ "yes" "accept" "force" "no" ] "yes" '' + Use IKE fragmentation (proprietary IKEv1 extension or RFC 7383 IKEv2 + fragmentation). Acceptable values are `yes` (the default + since 5.5.1), `accept` (since versions:5.5.3), + `force` and `no`. + + - If set to `yes`, and the peer + supports it, oversized IKE messages will be sent in fragments. + - If set to + `accept`, support for fragmentation is announced to the peer but the daemon + does not send its own messages in fragments. + - If set to `force` (only + supported for IKEv1) the initial IKE message will already be fragmented if + required. + - Finally, setting the option to `no` will disable announcing + support for this feature. + + Note that fragmented IKE messages sent by a peer are always processed + irrespective of the value of this option (even when set to no). + ''; + + childless = mkEnumParam [ "allow" "prefer" "force" "never" ] "allow" '' + Use childless IKE_SA initiation (_allow_, _prefer_, _force_ or _never_). + + Use childless IKE_SA initiation (RFC 6023) for IKEv2, with the first + CHILD_SA created with a separate CREATE_CHILD_SA exchange (e.g. to use an + independent DH exchange for all CHILD_SAs). Acceptable values are `allow` + (the default), `prefer`, `force` and `never`. If set to `allow`, responders + will accept childless IKE_SAs (as indicated via notify in the IKE_SA_INIT + response) while initiators continue to create regular IKE_SAs with the first + CHILD_SA created during IKE_AUTH, unless the IKE_SA is initiated explicitly + without any children (which will fail if the responder does not support or + has disabled this extension). The effect of `prefer` is the same as `allow` + on responders, but as initiator a childless IKE_SA is initiated if the + responder supports it. If set to `force`, only childless initiation is + accepted in either role. Finally, setting the option to `never` disables + support for childless IKE_SAs as responder. + ''; + + send_certreq = mkYesNoParam yes '' + Send certificate request payloads to offer trusted root CA certificates to + the peer. Certificate requests help the peer to choose an appropriate + certificate/private key for authentication and are enabled by default. + Disabling certificate requests can be useful if too many trusted root CA + certificates are installed, as each certificate request increases the size + of the initial IKE packets. + ''; + + send_cert = mkEnumParam [ "always" "never" "ifasked" ] "ifasked" '' + Send certificate payloads when using certificate authentication. + + - With the default of `ifasked` the daemon sends + certificate payloads only if certificate requests have been received. + - `never` disables sending of certificate payloads + altogether, + - `always` causes certificate payloads to be sent + unconditionally whenever certificate authentication is used. + ''; + + ppk_id = mkOptionalStrParam '' + String identifying the Postquantum Preshared Key (PPK) to be used. + ''; + + ppk_required = mkYesNoParam no '' + Whether a Postquantum Preshared Key (PPK) is required for this connection. + ''; + + keyingtries = mkIntParam 1 '' + Number of retransmission sequences to perform during initial + connect. Instead of giving up initiation after the first retransmission + sequence with the default value of `1`, additional + sequences may be started according to the configured value. A value of + `0` initiates a new sequence until the connection + establishes or fails with a permanent error. + ''; + + unique = mkEnumParam [ "no" "never" "keep" "replace" ] "no" '' + Connection uniqueness policy to enforce. To avoid multiple connections + from the same user, a uniqueness policy can be enforced. + + - The value `never` does never enforce such a policy, even + if a peer included INITIAL_CONTACT notification messages, + - whereas `no` replaces existing connections for the same + identity if a new one has the INITIAL_CONTACT notify. + - `keep` rejects new connection attempts if the same user + already has an active connection, + - `replace` deletes any existing connection if a new one + for the same user gets established. + + To compare connections for uniqueness, the remote IKE identity is used. If + EAP or XAuth authentication is involved, the EAP-Identity or XAuth + username is used to enforce the uniqueness policy instead. + + On initiators this setting specifies whether an INITIAL_CONTACT notify is + sent during IKE_AUTH if no existing connection is found with the remote + peer (determined by the identities of the first authentication + round). Unless set to `never` the client will send a notify. + ''; + + reauth_time = mkDurationParam "0s" '' + Time to schedule IKE reauthentication. IKE reauthentication recreates the + IKE/ISAKMP SA from scratch and re-evaluates the credentials. In asymmetric + configurations (with EAP or configuration payloads) it might not be + possible to actively reauthenticate as responder. The IKEv2 + reauthentication lifetime negotiation can instruct the client to perform + reauthentication. + + Reauthentication is disabled by default. Enabling it usually may lead to + small connection interruptions, as strongSwan uses a break-before-make + policy with IKEv2 to avoid any conflicts with associated tunnel resources. + ''; + + rekey_time = mkDurationParam "4h" '' + IKE rekeying refreshes key material using a Diffie-Hellman exchange, but + does not re-check associated credentials. It is supported in IKEv2 only, + IKEv1 performs a reauthentication procedure instead. + + With the default value IKE rekeying is scheduled every 4 hours, minus the + configured rand_time. If a reauth_time is configured, rekey_time defaults + to zero, disabling rekeying; explicitly set both to enforce rekeying and + reauthentication. + ''; + + over_time = mkOptionalDurationParam '' + Hard IKE_SA lifetime if rekey/reauth does not complete, as time. To avoid + having an IKE/ISAKMP kept alive if IKE reauthentication or rekeying fails + perpetually, a maximum hard lifetime may be specified. If the IKE_SA fails + to rekey or reauthenticate within the specified time, the IKE_SA gets + closed. + + In contrast to CHILD_SA rekeying, over_time is relative in time to the + rekey_time and reauth_time values, as it applies to both. + + The default is 10% of the longer of {option}`rekey_time` and + {option}`reauth_time`. + ''; + + rand_time = mkOptionalDurationParam '' + Time range from which to choose a random value to subtract from + rekey/reauth times. To avoid having both peers initiating the rekey/reauth + procedure simultaneously, a random time gets subtracted from the + rekey/reauth times. + + The default is equal to the configured {option}`over_time`. + ''; + + pools = mkCommaSepListParam [ ] '' + List of named IP pools to allocate virtual IP addresses + and other configuration attributes from. Each name references a pool by + name from either the pools section or an external pool. + ''; + + if_id_in = mkStrParam "0" '' + XFRM interface ID set on inbound policies/SA, can be overridden by child + config, see there for details. + + The special value `%unique` allocates a unique interface ID per IKE_SA, + which is inherited by all its CHILD_SAs (unless overridden there), beyond + that the value `%unique-dir` assigns a different unique interface ID for + each direction (in/out). + + ''; + + if_id_out = mkStrParam "0" '' + XFRM interface ID set on outbound policies/SA, can be overridden by child + config, see there for details. + + The special value `%unique` allocates a unique interface ID per IKE_SA, + which is inherited by all its CHILD_SAs (unless overridden there), beyond + that the value `%unique-dir` assigns a different unique interface ID for + each direction (in/out). + ''; + + mediation = mkYesNoParam no '' + Whether this connection is a mediation connection, that is, whether this + connection is used to mediate other connections using the IKEv2 Mediation + Extension. Mediation connections create no CHILD_SA. + ''; + + mediated_by = mkOptionalStrParam '' + The name of the connection to mediate this connection through. If given, + the connection will be mediated through the named mediation + connection. The mediation connection must have mediation enabled. + ''; + + mediation_peer = mkOptionalStrParam '' + Identity under which the peer is registered at the mediation server, that + is, the IKE identity the other end of this connection uses as its local + identity on its connection to the mediation server. This is the identity + we request the mediation server to mediate us with. Only relevant on + connections that set mediated_by. If it is not given, the remote IKE + identity of the first authentication round of this connection will be + used. + ''; + + local = + mkPrefixedAttrsOfParams + { + + round = mkIntParam 0 '' + Optional numeric identifier by which authentication rounds are + sorted. If not specified rounds are ordered by their position in the + config file/vici message. + ''; + + certs = mkCommaSepListParam [ ] '' + List of certificate candidates to use for + authentication. The certificates may use a relative path from the + swanctl `x509` directory or an absolute path. + + The certificate used for authentication is selected based on the + received certificate request payloads. If no appropriate CA can be + located, the first certificate is used. + ''; + + cert = mkPostfixedAttrsOfParams certParams '' + Section for a certificate candidate to use for + authentication. Certificates in certs are transmitted as binary blobs, + these sections offer more flexibility. + ''; + + pubkeys = mkCommaSepListParam [ ] '' + List of raw public key candidates to use for + authentication. The public keys may use a relative path from the swanctl + `pubkey` directory or an absolute path. + + Even though multiple local public keys could be defined in principle, + only the first public key in the list is used for authentication. + ''; + + auth = mkStrParam "pubkey" '' + Authentication to perform locally. + + - The default `pubkey` uses public key authentication + using a private key associated to a usable certificate. + - `psk` uses pre-shared key authentication. + - The IKEv1 specific `xauth` is used for XAuth or Hybrid + authentication, + - while the IKEv2 specific `eap` keyword defines EAP + authentication. + - For `xauth`, a specific backend name may be appended, + separated by a dash. The appropriate `xauth` backend is + selected to perform the XAuth exchange. For traditional XAuth, the + `xauth` method is usually defined in the second + authentication round following an initial `pubkey` (or + `psk`) round. Using `xauth` in the + first round performs Hybrid Mode client authentication. + - For `eap`, a specific EAP method name may be appended, separated by a + dash. An EAP module implementing the appropriate method is selected to + perform the EAP conversation. + - Since 5.4.0, if both peers support RFC 7427 ("Signature Authentication + in IKEv2") specific hash algorithms to be used during IKEv2 + authentication may be configured. To do so use `ike:` + followed by a trust chain signature scheme constraint (see description + of the {option}`remote` section's {option}`auth` + keyword). For example, with `ike:pubkey-sha384-sha256` + a public key signature scheme with either SHA-384 or SHA-256 would get + used for authentication, in that order and depending on the hash + algorithms supported by the peer. If no specific hash algorithms are + configured, the default is to prefer an algorithm that matches or + exceeds the strength of the signature key. If no constraints with + `ike:` prefix are configured any signature scheme + constraint (without `ike:` prefix) will also apply to + IKEv2 authentication, unless this is disabled in + `strongswan.conf`. To use RSASSA-PSS signatures use + `rsa/pss` instead of `pubkey` or + `rsa` as in e.g. + `ike:rsa/pss-sha256`. If `pubkey` or + `rsa` constraints are configured RSASSA-PSS signatures + will only be used if enabled in `strongswan.conf`(5). + ''; + + id = mkOptionalStrParam '' + IKE identity to use for authentication round. When using certificate + authentication, the IKE identity must be contained in the certificate, + either as subject or as subjectAltName. + ''; + + eap_id = mkOptionalStrParam '' + Client EAP-Identity to use in EAP-Identity exchange and the EAP method. + ''; + + aaa_id = mkOptionalStrParam '' + Server side EAP-Identity to expect in the EAP method. Some EAP methods, + such as EAP-TLS, use an identity for the server to perform mutual + authentication. This identity may differ from the IKE identity, + especially when EAP authentication is delegated from the IKE responder + to an AAA backend. + + For EAP-(T)TLS, this defines the identity for which the server must + provide a certificate in the TLS exchange. + ''; + + xauth_id = mkOptionalStrParam '' + Client XAuth username used in the XAuth exchange. + ''; + + } + '' + Section for a local authentication round. A local authentication round + defines the rules how authentication is performed for the local + peer. Multiple rounds may be defined to use IKEv2 RFC 4739 Multiple + Authentication or IKEv1 XAuth. + + Each round is defined in a section having `local` as + prefix, and an optional unique suffix. To define a single authentication + round, the suffix may be omitted. + ''; + + remote = + mkPrefixedAttrsOfParams + { + + round = mkIntParam 0 '' + Optional numeric identifier by which authentication rounds are + sorted. If not specified rounds are ordered by their position in the + config file/vici message. + ''; + + id = mkStrParam "%any" '' + IKE identity to expect for authentication round. When using certificate + authentication, the IKE identity must be contained in the certificate, + either as subject or as subjectAltName. + ''; + + eap_id = mkOptionalStrParam '' + Identity to use as peer identity during EAP authentication. If set to + `%any` the EAP-Identity method will be used to ask the + client for an EAP identity. + ''; + + groups = mkCommaSepListParam [ ] '' + Authorization group memberships to require. The peer + must prove membership to at least one of the specified groups. Group + membership can be certified by different means, for example by + appropriate Attribute Certificates or by an AAA backend involved in the + authentication. + ''; + + cert_policy = mkCommaSepListParam [ ] '' + List of certificate policy OIDs the peer's certificate + must have. OIDs are specified using the numerical dotted representation. + ''; + + certs = mkCommaSepListParam [ ] '' + List of certificates to accept for authentication. The certificates may + use a relative path from the swanctl `x509` directory + or an absolute path. + ''; + + cert = mkPostfixedAttrsOfParams certParams '' + Section for a certificate candidate to use for + authentication. Certificates in certs are transmitted as binary blobs, + these sections offer more flexibility. + ''; + + ca_id = mkOptionalStrParam '' + Identity in CA certificate to accept for authentication. The specified + identity must be contained in one (intermediate) CA of the remote peer + trustchain, either as subject or as subjectAltName. This has the same + effect as specifying `cacerts` to force clients under + a CA to specific connections; it does not require the CA certificate + to be available locally, and can be received from the peer during the + IKE exchange. + ''; + + cacerts = mkCommaSepListParam [ ] '' + List of CA certificates to accept for + authentication. The certificates may use a relative path from the + swanctl `x509ca` directory or an absolute path. + ''; + + cacert = mkPostfixedAttrsOfParams certParams '' + Section for a CA certificate to accept for authentication. Certificates + in cacerts are transmitted as binary blobs, these sections offer more + flexibility. + ''; + + pubkeys = mkCommaSepListParam [ ] '' + List of raw public keys to accept for + authentication. The public keys may use a relative path from the swanctl + `pubkey` directory or an absolute path. + ''; + + revocation = mkEnumParam [ "strict" "ifuri" "relaxed" ] "relaxed" '' + Certificate revocation policy for CRL or OCSP revocation. + + - A `strict` revocation policy fails if no revocation information is + available, i.e. the certificate is not known to be unrevoked. + - `ifuri` fails only if a CRL/OCSP URI is available, but certificate + revocation checking fails, i.e. there should be revocation information + available, but it could not be obtained. + - The default revocation policy `relaxed` fails only if a certificate is + revoked, i.e. it is explicitly known that it is bad. + ''; + + auth = mkStrParam "pubkey" '' + Authentication to expect from remote. See the {option}`local` + section's {option}`auth` keyword description about the details of + supported mechanisms. + + Since 5.4.0, to require a trustchain public key strength for the remote + side, specify the key type followed by the minimum strength in bits (for + example `ecdsa-384` or + `rsa-2048-ecdsa-256`). To limit the acceptable set of + hashing algorithms for trustchain validation, append hash algorithms to + pubkey or a key strength definition (for example + `pubkey-sha256-sha512`, + `rsa-2048-sha256-sha384-sha512` or + `rsa-2048-sha256-ecdsa-256-sha256-sha384`). + Unless disabled in `strongswan.conf`, or explicit IKEv2 + signature constraints are configured (refer to the description of the + {option}`local` section's {option}`auth` keyword for + details), such key types and hash algorithms are also applied as + constraints against IKEv2 signature authentication schemes used by the + remote side. To require RSASSA-PSS signatures use + `rsa/pss` instead of `pubkey` or + `rsa` as in e.g. `rsa/pss-sha256`. If + `pubkey` or `rsa` constraints are + configured RSASSA-PSS signatures will only be accepted if enabled in + `strongswan.conf`(5). + + To specify trust chain constraints for EAP-(T)TLS, append a colon to the + EAP method, followed by the key type/size and hash algorithm as + discussed above (e.g. `eap-tls:ecdsa-384-sha384`). + ''; + + } + '' + Section for a remote authentication round. A remote authentication round + defines the constraints how the peers must authenticate to use this + connection. Multiple rounds may be defined to use IKEv2 RFC 4739 Multiple + Authentication or IKEv1 XAuth. + + Each round is defined in a section having `remote` as + prefix, and an optional unique suffix. To define a single authentication + round, the suffix may be omitted. + ''; + + children = + mkAttrsOfParams + { + ah_proposals = mkCommaSepListParam [ ] '' + AH proposals to offer for the CHILD_SA. A proposal is a set of + algorithms. For AH, this includes an integrity algorithm and an optional + Diffie-Hellman group. If a DH group is specified, CHILD_SA/Quick Mode + rekeying and initial negotiation uses a separate Diffie-Hellman exchange + using the specified group (refer to esp_proposals for details). + + In IKEv2, multiple algorithms of the same kind can be specified in a + single proposal, from which one gets selected. In IKEv1, only one + algorithm per kind is allowed per proposal, more algorithms get + implicitly stripped. Use multiple proposals to offer different algorithms + combinations in IKEv1. + + Algorithm keywords get separated using dashes. Multiple proposals may be + specified in a list. The special value `default` forms + a default proposal of supported algorithms considered safe, and is + usually a good choice for interoperability. By default no AH proposals + are included, instead ESP is proposed. + ''; + + esp_proposals = mkCommaSepListParam [ "default" ] '' + ESP proposals to offer for the CHILD_SA. A proposal is a set of + algorithms. For ESP non-AEAD proposals, this includes an integrity + algorithm, an encryption algorithm, an optional Diffie-Hellman group and + an optional Extended Sequence Number Mode indicator. For AEAD proposals, + a combined mode algorithm is used instead of the separate + encryption/integrity algorithms. + + If a DH group is specified, CHILD_SA/Quick Mode rekeying and initial + negotiation use a separate Diffie-Hellman exchange using the specified + group. However, for IKEv2, the keys of the CHILD_SA created implicitly + with the IKE_SA will always be derived from the IKE_SA's key material. So + any DH group specified here will only apply when the CHILD_SA is later + rekeyed or is created with a separate CREATE_CHILD_SA exchange. A + proposal mismatch might, therefore, not immediately be noticed when the + SA is established, but may later cause rekeying to fail. + + Extended Sequence Number support may be indicated with the + `esn` and `noesn` values, both may be + included to indicate support for both modes. If omitted, + `noesn` is assumed. + + In IKEv2, multiple algorithms of the same kind can be specified in a + single proposal, from which one gets selected. In IKEv1, only one + algorithm per kind is allowed per proposal, more algorithms get + implicitly stripped. Use multiple proposals to offer different algorithms + combinations in IKEv1. + + Algorithm keywords get separated using dashes. Multiple proposals may be + specified as a list. The special value `default` forms + a default proposal of supported algorithms considered safe, and is + usually a good choice for interoperability. If no algorithms are + specified for AH nor ESP, the default set of algorithms for ESP is + included. + ''; + + sha256_96 = mkYesNoParam no '' + HMAC-SHA-256 is used with 128-bit truncation with IPsec. For + compatibility with implementations that incorrectly use 96-bit truncation + this option may be enabled to configure the shorter truncation length in + the kernel. This is not negotiated, so this only works with peers that + use the incorrect truncation length (or have this option enabled). + ''; + + local_ts = mkCommaSepListParam [ "dynamic" ] '' + List of local traffic selectors to include in CHILD_SA. Each selector is + a CIDR subnet definition, followed by an optional proto/port + selector. The special value `dynamic` may be used + instead of a subnet definition, which gets replaced by the tunnel outer + address or the virtual IP, if negotiated. This is the default. + + A protocol/port selector is surrounded by opening and closing square + brackets. Between these brackets, a numeric or getservent(3) protocol + name may be specified. After the optional protocol restriction, an + optional port restriction may be specified, separated by a slash. The + port restriction may be numeric, a getservent(3) service name, or the + special value `opaque` for RFC 4301 OPAQUE + selectors. Port ranges may be specified as well, none of the kernel + backends currently support port ranges, though. + + When IKEv1 is used only the first selector is interpreted, except if the + Cisco Unity extension plugin is used. This is due to a limitation of the + IKEv1 protocol, which only allows a single pair of selectors per + CHILD_SA. So to tunnel traffic matched by several pairs of selectors when + using IKEv1 several children (CHILD_SAs) have to be defined that cover + the selectors. The IKE daemon uses traffic selector narrowing for IKEv1, + the same way it is standardized and implemented for IKEv2. However, this + may lead to problems with other implementations. To avoid that, configure + identical selectors in such scenarios. + ''; + + remote_ts = mkCommaSepListParam [ "dynamic" ] '' + List of remote selectors to include in CHILD_SA. See + {option}`local_ts` for a description of the selector syntax. + ''; + + rekey_time = mkDurationParam "1h" '' + Time to schedule CHILD_SA rekeying. CHILD_SA rekeying refreshes key + material, optionally using a Diffie-Hellman exchange if a group is + specified in the proposal. To avoid rekey collisions initiated by both + ends simultaneously, a value in the range of {option}`rand_time` + gets subtracted to form the effective soft lifetime. + + By default CHILD_SA rekeying is scheduled every hour, minus + {option}`rand_time`. + ''; + + life_time = mkOptionalDurationParam '' + Maximum lifetime before CHILD_SA gets closed. Usually this hard lifetime + is never reached, because the CHILD_SA gets rekeyed before. If that fails + for whatever reason, this limit closes the CHILD_SA. The default is 10% + more than the {option}`rekey_time`. + ''; + + rand_time = mkOptionalDurationParam '' + Time range from which to choose a random value to subtract from + {option}`rekey_time`. The default is the difference between + {option}`life_time` and {option}`rekey_time`. + ''; + + rekey_bytes = mkIntParam 0 '' + Number of bytes processed before initiating CHILD_SA rekeying. CHILD_SA + rekeying refreshes key material, optionally using a Diffie-Hellman + exchange if a group is specified in the proposal. + + To avoid rekey collisions initiated by both ends simultaneously, a value + in the range of {option}`rand_bytes` gets subtracted to form the + effective soft volume limit. + + Volume based CHILD_SA rekeying is disabled by default. + ''; + + life_bytes = mkOptionalIntParam '' + Maximum bytes processed before CHILD_SA gets closed. Usually this hard + volume limit is never reached, because the CHILD_SA gets rekeyed + before. If that fails for whatever reason, this limit closes the + CHILD_SA. The default is 10% more than {option}`rekey_bytes`. + ''; + + rand_bytes = mkOptionalIntParam '' + Byte range from which to choose a random value to subtract from + {option}`rekey_bytes`. The default is the difference between + {option}`life_bytes` and {option}`rekey_bytes`. + ''; + + rekey_packets = mkIntParam 0 '' + Number of packets processed before initiating CHILD_SA rekeying. CHILD_SA + rekeying refreshes key material, optionally using a Diffie-Hellman + exchange if a group is specified in the proposal. + + To avoid rekey collisions initiated by both ends simultaneously, a value + in the range of {option}`rand_packets` gets subtracted to form + the effective soft packet count limit. + + Packet count based CHILD_SA rekeying is disabled by default. + ''; + + life_packets = mkOptionalIntParam '' + Maximum number of packets processed before CHILD_SA gets closed. Usually + this hard packets limit is never reached, because the CHILD_SA gets + rekeyed before. If that fails for whatever reason, this limit closes the + CHILD_SA. + + The default is 10% more than {option}`rekey_bytes`. + ''; + + rand_packets = mkOptionalIntParam '' + Packet range from which to choose a random value to subtract from + {option}`rekey_packets`. The default is the difference between + {option}`life_packets` and {option}`rekey_packets`. + ''; + + updown = mkOptionalStrParam '' + Updown script to invoke on CHILD_SA up and down events. + ''; + + hostaccess = mkYesNoParam no '' + Hostaccess variable to pass to `updown` script. + ''; + + mode = + mkEnumParam + [ + "tunnel" + "transport" + "transport_proxy" + "beet" + "pass" + "drop" + ] + "tunnel" + '' + IPsec Mode to establish CHILD_SA with. + + - `tunnel` negotiates the CHILD_SA in IPsec Tunnel Mode, + - whereas `transport` uses IPsec Transport Mode. + - `transport_proxy` signifying the special Mobile IPv6 + Transport Proxy Mode. + - `beet` is the Bound End to End Tunnel mixture mode, + working with fixed inner addresses without the need to include them in + each packet. + - Both `transport` and `beet` modes are + subject to mode negotiation; `tunnel` mode is + negotiated if the preferred mode is not available. + - `pass` and `drop` are used to install + shunt policies which explicitly bypass the defined traffic from IPsec + processing or drop it, respectively. + ''; + + policies = mkYesNoParam yes '' + Whether to install IPsec policies or not. Disabling this can be useful in + some scenarios e.g. MIPv6, where policies are not managed by the IKE + daemon. Since 5.3.3. + ''; + + policies_fwd_out = mkYesNoParam no '' + Whether to install outbound FWD IPsec policies or not. Enabling this is + required in case there is a drop policy that would match and block + forwarded traffic for this CHILD_SA. Since 5.5.1. + ''; + + dpd_action = mkEnumParam [ "clear" "trap" "restart" ] "clear" '' + Action to perform for this CHILD_SA on DPD timeout. The default clear + closes the CHILD_SA and does not take further action. trap installs a + trap policy, which will catch matching traffic and tries to re-negotiate + the tunnel on-demand. restart immediately tries to re-negotiate the + CHILD_SA under a fresh IKE_SA. + ''; + + ipcomp = mkYesNoParam no '' + Enable IPComp compression before encryption. If enabled, IKE tries to + negotiate IPComp compression to compress ESP payload data prior to + encryption. + ''; + + inactivity = mkDurationParam "0s" '' + Timeout before closing CHILD_SA after inactivity. If no traffic has been + processed in either direction for the configured timeout, the CHILD_SA + gets closed due to inactivity. The default value of 0 disables inactivity + checks. + ''; + + reqid = mkIntParam 0 '' + Fixed reqid to use for this CHILD_SA. This might be helpful in some + scenarios, but works only if each CHILD_SA configuration is instantiated + not more than once. The default of 0 uses dynamic reqids, allocated + incrementally. + ''; + + priority = mkIntParam 0 '' + Optional fixed priority for IPsec policies. This could be useful to + install high-priority drop policies. The default of 0 uses dynamically + calculated priorities based on the size of the traffic selectors. + ''; + + interface = mkOptionalStrParam '' + Optional interface name to restrict outbound IPsec policies. + ''; + + mark_in = mkStrParam "0/0x00000000" '' + Netfilter mark and mask for input traffic. On Linux, Netfilter may + require marks on each packet to match an SA/policy having that option + set. This allows installing duplicate policies and enables Netfilter + rules to select specific SAs/policies for incoming traffic. Note that + inbound marks are only set on policies, by default, unless + {option}`mark_in_sa` is enabled. The special value + `%unique` sets a unique mark on each CHILD_SA instance, + beyond that the value `%unique-dir` assigns a different + unique mark for each + + An additional mask may be appended to the mark, separated by + `/`. The default mask if omitted is + `0xffffffff`. + ''; + + mark_in_sa = mkYesNoParam no '' + Whether to set {option}`mark_in` on the inbound SA. By default, + the inbound mark is only set on the inbound policy. The tuple destination + address, protocol and SPI is unique and the mark is not required to find + the correct SA, allowing to mark traffic after decryption instead (where + more specific selectors may be used) to match different policies. Marking + packets before decryption is still possible, even if no mark is set on + the SA. + ''; + + mark_out = mkStrParam "0/0x00000000" '' + Netfilter mark and mask for output traffic. On Linux, Netfilter may + require marks on each packet to match a policy/SA having that option + set. This allows installing duplicate policies and enables Netfilter + rules to select specific policies/SAs for outgoing traffic. The special + value `%unique` sets a unique mark on each CHILD_SA + instance, beyond that the value `%unique-dir` assigns a + different unique mark for each CHILD_SA direction (in/out). + + An additional mask may be appended to the mark, separated by + `/`. The default mask if omitted is + `0xffffffff`. + ''; + + set_mark_in = mkStrParam "0/0x00000000" '' + Netfilter mark applied to packets after the inbound IPsec SA processed + them. This way it's not necessary to mark packets via Netfilter before + decryption or right afterwards to match policies or process them + differently (e.g. via policy routing). + + An additional mask may be appended to the mark, separated by + `/`. The default mask if omitted is 0xffffffff. The + special value `%same` uses the value (but not the mask) + from {option}`mark_in` as mark value, which can be fixed, + `%unique` or `%unique-dir`. + + Setting marks in XFRM input requires Linux 4.19 or higher. + ''; + + set_mark_out = mkStrParam "0/0x00000000" '' + Netfilter mark applied to packets after the outbound IPsec SA processed + them. This allows processing ESP packets differently than the original + traffic (e.g. via policy routing). + + An additional mask may be appended to the mark, separated by + `/`. The default mask if omitted is 0xffffffff. The + special value `%same` uses the value (but not the mask) + from {option}`mark_out` as mark value, which can be fixed, + `%unique_` or `%unique-dir`. + + Setting marks in XFRM output is supported since Linux 4.14. Setting a + mask requires at least Linux 4.19. + ''; + + if_id_in = mkStrParam "0" '' + XFRM interface ID set on inbound policies/SA. This allows installing + duplicate policies/SAs and associates them with an interface with the + same ID. The special value `%unique` sets a unique + interface ID on each CHILD_SA instance, beyond that the value + `%unique-dir` assigns a different unique interface ID + for each CHILD_SA direction (in/out). + ''; + + if_id_out = mkStrParam "0" '' + XFRM interface ID set on outbound policies/SA. This allows installing + duplicate policies/SAs and associates them with an interface with the + same ID. The special value `%unique` sets a unique + interface ID on each CHILD_SA instance, beyond that the value + `%unique-dir` assigns a different unique interface ID + for each CHILD_SA direction (in/out). + + The daemon will not install routes for CHILD_SAs that have this option set. + ''; + + tfc_padding = mkParamOfType (with lib.types; either int (enum [ "mtu" ])) 0 '' + Pads ESP packets with additional data to have a consistent ESP packet + size for improved Traffic Flow Confidentiality. The padding defines the + minimum size of all ESP packets sent. The default value of + `0` disables TFC padding, the special value + `mtu` adds TFC padding to create a packet size equal to + the Path Maximum Transfer Unit. + ''; + + replay_window = mkIntParam 32 '' + IPsec replay window to configure for this CHILD_SA. Larger values than + the default of `32` are supported using the Netlink + backend only, a value of `0` disables IPsec replay + protection. + ''; + + hw_offload = mkEnumParam [ "yes" "no" "auto" "crypto" "packet" ] "no" '' + Enable hardware offload for this CHILD_SA, if supported by the IPsec + implementation. The values `crypto` or `packet` enforce crypto or full + packet offloading and the installation will fail if the selected mode is not + supported by either kernel or device. On Linux, `packet` also offloads + policies, including trap policies. The value `auto` enables full packet + or crypto offloading, if either is supported, but the installation does not + fail otherwise. + ''; + + copy_df = mkYesNoParam yes '' + Whether to copy the DF bit to the outer IPv4 header in tunnel mode. This + effectively disables Path MTU discovery (PMTUD). Controlling this + behavior is not supported by all kernel interfaces. + ''; + + copy_ecn = mkYesNoParam yes '' + Whether to copy the ECN (Explicit Congestion Notification) header field + to/from the outer IP header in tunnel mode. Controlling this behavior is + not supported by all kernel interfaces. + ''; + + copy_dscp = mkEnumParam [ "out" "in" "yes" "no" ] "out" '' + Whether to copy the DSCP (Differentiated Services Field Codepoint) + header field to/from the outer IP header in tunnel mode. The value + `out` only copies the field from the inner to the outer + header, the value `in` does the opposite and only + copies the field from the outer to the inner header when decapsulating, + the value `yes` copies the field in both directions, + and the value `no` disables copying the field + altogether. Setting this to `yes` or + `in` could allow an attacker to adversely affect other + traffic at the receiver, which is why the default is + `out`. Controlling this behavior is not supported by + all kernel interfaces. + ''; + + start_action = mkEnumParam [ "none" "trap" "start" "trap|start" ] "none" '' + Action to perform after loading the configuration. + + - The default of `none` loads the connection only, which + then can be manually initiated or used as a responder configuration. + - The value `trap` installs a trap policy, which triggers + the tunnel as soon as matching traffic has been detected. + - The value `start` initiates the connection actively. + - Since version 5.9.6 two modes above can be combined with `trap|start`, + to immediately initiate a connection for which trap policies have been installed. + + When unloading or replacing a CHILD_SA configuration having a + {option}`start_action` different from `none`, + the inverse action is performed. Configurations with + `start` get closed, while such with + `trap` get uninstalled. + ''; + + close_action = mkEnumParam [ "none" "trap" "start" ] "none" '' + Action to perform after a CHILD_SA gets closed by the peer. + + - The default of `none` does not take any action, + - `trap` installs a trap policy for the CHILD_SA. + - `start` tries to re-create the CHILD_SA. + + {option}`close_action` does not provide any guarantee that the + CHILD_SA is kept alive. It acts on explicit close messages only, but not + on negotiation failures. Use trap policies to reliably re-create failed + CHILD_SAs. + ''; + + } + '' + CHILD_SA configuration sub-section. Each connection definition may have + one or more sections in its {option}`children` subsection. The + section name defines the name of the CHILD_SA configuration, which must be + unique within the connection (denoted \ below). + ''; + } + '' + Section defining IKE connection configurations, each in its own subsection + with an arbitrary yet unique name + ''; + + secrets = + let + mkEapXauthParams = + mkPrefixedAttrsOfParams + { + secret = mkOptionalStrParam '' + Value of the EAP/XAuth secret. It may either be an ASCII string, a hex + encoded string if it has a 0x prefix or a Base64 encoded string if it + has a 0s prefix in its value. + ''; + + id = mkPrefixedAttrsOfParam (mkOptionalStrParam "") '' + Identity the EAP/XAuth secret belongs to. Multiple unique identities may + be specified, each having an `id` prefix, if a secret + is shared between multiple users. + ''; + + } + '' + EAP secret section for a specific secret. Each EAP secret is defined in a + unique section having the `eap` prefix. EAP secrets are + used for XAuth authentication as well. + ''; + + in + { + + eap = mkEapXauthParams; + xauth = mkEapXauthParams; + + ntlm = + mkPrefixedAttrsOfParams + { + secret = mkOptionalStrParam '' + Value of the NTLM secret, which is the NT Hash of the actual secret, + that is, MD4(UTF-16LE(secret)). The resulting 16-byte value may either + be given as a hex encoded string with a 0x prefix or as a Base64 encoded + string with a 0s prefix. + ''; + + id = mkPrefixedAttrsOfParam (mkOptionalStrParam "") '' + Identity the NTLM secret belongs to. Multiple unique identities may be + specified, each having an id prefix, if a secret is shared between + multiple users. + ''; + } + '' + NTLM secret section for a specific secret. Each NTLM secret is defined in + a unique section having the `ntlm` prefix. NTLM secrets + may only be used for EAP-MSCHAPv2 authentication. + ''; + + ike = + mkPrefixedAttrsOfParams + { + secret = mkOptionalStrParam '' + Value of the IKE preshared secret. It may either be an ASCII string, a + hex encoded string if it has a 0x prefix or a Base64 encoded string if + it has a 0s prefix in its value. + ''; + + id = mkPrefixedAttrsOfParam (mkOptionalStrParam "") '' + IKE identity the IKE preshared secret belongs to. Multiple unique + identities may be specified, each having an `id` + prefix, if a secret is shared between multiple peers. + ''; + } + '' + IKE preshared secret section for a specific secret. Each IKE PSK is + defined in a unique section having the `ike` prefix. + ''; + + ppk = + mkPrefixedAttrsOfParams + { + secret = mkOptionalStrParam '' + Value of the PPK. It may either be an ASCII string, a hex encoded string + if it has a `0x` prefix or a Base64 encoded string if + it has a `0s` prefix in its value. Should have at least + 256 bits of entropy for 128-bit security. + ''; + + id = mkPrefixedAttrsOfParam (mkOptionalStrParam "") '' + PPK identity the PPK belongs to. Multiple unique identities may be + specified, each having an `id` prefix, if a secret is + shared between multiple peers. + ''; + } + '' + Postquantum Preshared Key (PPK) section for a specific secret. Each PPK is + defined in a unique section having the `ppk` prefix. + ''; + + private = + mkPrefixedAttrsOfParams + { + file = mkOptionalStrParam '' + File name in the private folder for which this passphrase should be used. + ''; + + secret = mkOptionalStrParam '' + Value of decryption passphrase for private key. + ''; + } + '' + Private key decryption passphrase for a key in the + `private` folder. + ''; + + rsa = + mkPrefixedAttrsOfParams + { + file = mkOptionalStrParam '' + File name in the `rsa` folder for which this passphrase + should be used. + ''; + secret = mkOptionalStrParam '' + Value of decryption passphrase for RSA key. + ''; + } + '' + Private key decryption passphrase for a key in the `rsa` + folder. + ''; + + ecdsa = + mkPrefixedAttrsOfParams + { + file = mkOptionalStrParam '' + File name in the `ecdsa` folder for which this + passphrase should be used. + ''; + secret = mkOptionalStrParam '' + Value of decryption passphrase for ECDSA key. + ''; + } + '' + Private key decryption passphrase for a key in the + `ecdsa` folder. + ''; + + pkcs8 = + mkPrefixedAttrsOfParams + { + file = mkOptionalStrParam '' + File name in the `pkcs8` folder for which this + passphrase should be used. + ''; + secret = mkOptionalStrParam '' + Value of decryption passphrase for PKCS#8 key. + ''; + } + '' + Private key decryption passphrase for a key in the + `pkcs8` folder. + ''; + + pkcs12 = + mkPrefixedAttrsOfParams + { + file = mkOptionalStrParam '' + File name in the `pkcs12` folder for which this + passphrase should be used. + ''; + secret = mkOptionalStrParam '' + Value of decryption passphrase for PKCS#12 container. + ''; + } + '' + PKCS#12 decryption passphrase for a container in the + `pkcs12` folder. + ''; + + token = mkPrefixedAttrsOfParams { + handle = mkOptionalHexParam '' + Hex-encoded CKA_ID or handle of the private key on the token or TPM, + respectively. + ''; + + slot = mkOptionalIntParam '' + Optional slot number to access the token. + ''; + + module = mkOptionalStrParam '' + Optional PKCS#11 module name to access the token. + ''; + + pin = mkOptionalStrParam '' + Optional PIN required to access the key on the token. If none is + provided the user is prompted during an interactive + `--load-creds` call. + ''; + } "Definition for a private key that's stored on a token/smartcard/TPM."; + + }; + + pools = + mkAttrsOfParams + { + addrs = mkOptionalStrParam '' + Subnet or range defining addresses allocated in pool. Accepts a single + CIDR subnet defining the pool to allocate addresses from or an address + range (\-\). Pools must be unique and non-overlapping. + ''; + + dns = mkCommaSepListParam [ ] "Address or CIDR subnets"; + nbns = mkCommaSepListParam [ ] "Address or CIDR subnets"; + dhcp = mkCommaSepListParam [ ] "Address or CIDR subnets"; + netmask = mkCommaSepListParam [ ] "Address or CIDR subnets"; + server = mkCommaSepListParam [ ] "Address or CIDR subnets"; + subnet = mkCommaSepListParam [ ] "Address or CIDR subnets"; + split_include = mkCommaSepListParam [ ] "Address or CIDR subnets"; + split_exclude = mkCommaSepListParam [ ] "Address or CIDR subnets"; + } + '' + Section defining named pools. Named pools may be referenced by connections + with the pools option to assign virtual IPs and other configuration + attributes. Each pool must have a unique name (denoted \ below). ''; - - hw_offload = mkEnumParam ["yes" "no" "auto" "crypto" "packet"] "no" '' - Enable hardware offload for this CHILD_SA, if supported by the IPsec - implementation. The values `crypto` or `packet` enforce crypto or full - packet offloading and the installation will fail if the selected mode is not - supported by either kernel or device. On Linux, `packet` also offloads - policies, including trap policies. The value `auto` enables full packet - or crypto offloading, if either is supported, but the installation does not - fail otherwise. - ''; - - copy_df = mkYesNoParam yes '' - Whether to copy the DF bit to the outer IPv4 header in tunnel mode. This - effectively disables Path MTU discovery (PMTUD). Controlling this - behavior is not supported by all kernel interfaces. - ''; - - copy_ecn = mkYesNoParam yes '' - Whether to copy the ECN (Explicit Congestion Notification) header field - to/from the outer IP header in tunnel mode. Controlling this behavior is - not supported by all kernel interfaces. - ''; - - copy_dscp = mkEnumParam [ "out" "in" "yes" "no" ] "out" '' - Whether to copy the DSCP (Differentiated Services Field Codepoint) - header field to/from the outer IP header in tunnel mode. The value - `out` only copies the field from the inner to the outer - header, the value `in` does the opposite and only - copies the field from the outer to the inner header when decapsulating, - the value `yes` copies the field in both directions, - and the value `no` disables copying the field - altogether. Setting this to `yes` or - `in` could allow an attacker to adversely affect other - traffic at the receiver, which is why the default is - `out`. Controlling this behavior is not supported by - all kernel interfaces. - ''; - - start_action = mkEnumParam ["none" "trap" "start" "trap|start" ] "none" '' - Action to perform after loading the configuration. - - - The default of `none` loads the connection only, which - then can be manually initiated or used as a responder configuration. - - The value `trap` installs a trap policy, which triggers - the tunnel as soon as matching traffic has been detected. - - The value `start` initiates the connection actively. - - Since version 5.9.6 two modes above can be combined with `trap|start`, - to immediately initiate a connection for which trap policies have been installed. - - When unloading or replacing a CHILD_SA configuration having a - {option}`start_action` different from `none`, - the inverse action is performed. Configurations with - `start` get closed, while such with - `trap` get uninstalled. - ''; - - close_action = mkEnumParam ["none" "trap" "start"] "none" '' - Action to perform after a CHILD_SA gets closed by the peer. - - - The default of `none` does not take any action, - - `trap` installs a trap policy for the CHILD_SA. - - `start` tries to re-create the CHILD_SA. - - {option}`close_action` does not provide any guarantee that the - CHILD_SA is kept alive. It acts on explicit close messages only, but not - on negotiation failures. Use trap policies to reliably re-create failed - CHILD_SAs. - ''; - - } '' - CHILD_SA configuration sub-section. Each connection definition may have - one or more sections in its {option}`children` subsection. The - section name defines the name of the CHILD_SA configuration, which must be - unique within the connection (denoted \ below). - ''; - } '' - Section defining IKE connection configurations, each in its own subsection - with an arbitrary yet unique name - ''; - - secrets = let - mkEapXauthParams = mkPrefixedAttrsOfParams { - secret = mkOptionalStrParam '' - Value of the EAP/XAuth secret. It may either be an ASCII string, a hex - encoded string if it has a 0x prefix or a Base64 encoded string if it - has a 0s prefix in its value. - ''; - - id = mkPrefixedAttrsOfParam (mkOptionalStrParam "") '' - Identity the EAP/XAuth secret belongs to. Multiple unique identities may - be specified, each having an `id` prefix, if a secret - is shared between multiple users. - ''; - - } '' - EAP secret section for a specific secret. Each EAP secret is defined in a - unique section having the `eap` prefix. EAP secrets are - used for XAuth authentication as well. - ''; - - in { - - eap = mkEapXauthParams; - xauth = mkEapXauthParams; - - ntlm = mkPrefixedAttrsOfParams { - secret = mkOptionalStrParam '' - Value of the NTLM secret, which is the NT Hash of the actual secret, - that is, MD4(UTF-16LE(secret)). The resulting 16-byte value may either - be given as a hex encoded string with a 0x prefix or as a Base64 encoded - string with a 0s prefix. - ''; - - id = mkPrefixedAttrsOfParam (mkOptionalStrParam "") '' - Identity the NTLM secret belongs to. Multiple unique identities may be - specified, each having an id prefix, if a secret is shared between - multiple users. - ''; - } '' - NTLM secret section for a specific secret. Each NTLM secret is defined in - a unique section having the `ntlm` prefix. NTLM secrets - may only be used for EAP-MSCHAPv2 authentication. - ''; - - ike = mkPrefixedAttrsOfParams { - secret = mkOptionalStrParam '' - Value of the IKE preshared secret. It may either be an ASCII string, a - hex encoded string if it has a 0x prefix or a Base64 encoded string if - it has a 0s prefix in its value. - ''; - - id = mkPrefixedAttrsOfParam (mkOptionalStrParam "") '' - IKE identity the IKE preshared secret belongs to. Multiple unique - identities may be specified, each having an `id` - prefix, if a secret is shared between multiple peers. - ''; - } '' - IKE preshared secret section for a specific secret. Each IKE PSK is - defined in a unique section having the `ike` prefix. - ''; - - ppk = mkPrefixedAttrsOfParams { - secret = mkOptionalStrParam '' - Value of the PPK. It may either be an ASCII string, a hex encoded string - if it has a `0x` prefix or a Base64 encoded string if - it has a `0s` prefix in its value. Should have at least - 256 bits of entropy for 128-bit security. - ''; - - id = mkPrefixedAttrsOfParam (mkOptionalStrParam "") '' - PPK identity the PPK belongs to. Multiple unique identities may be - specified, each having an `id` prefix, if a secret is - shared between multiple peers. - ''; - } '' - Postquantum Preshared Key (PPK) section for a specific secret. Each PPK is - defined in a unique section having the `ppk` prefix. - ''; - - private = mkPrefixedAttrsOfParams { - file = mkOptionalStrParam '' - File name in the private folder for which this passphrase should be used. - ''; - - secret = mkOptionalStrParam '' - Value of decryption passphrase for private key. - ''; - } '' - Private key decryption passphrase for a key in the - `private` folder. - ''; - - rsa = mkPrefixedAttrsOfParams { - file = mkOptionalStrParam '' - File name in the `rsa` folder for which this passphrase - should be used. - ''; - secret = mkOptionalStrParam '' - Value of decryption passphrase for RSA key. - ''; - } '' - Private key decryption passphrase for a key in the `rsa` - folder. - ''; - - ecdsa = mkPrefixedAttrsOfParams { - file = mkOptionalStrParam '' - File name in the `ecdsa` folder for which this - passphrase should be used. - ''; - secret = mkOptionalStrParam '' - Value of decryption passphrase for ECDSA key. - ''; - } '' - Private key decryption passphrase for a key in the - `ecdsa` folder. - ''; - - pkcs8 = mkPrefixedAttrsOfParams { - file = mkOptionalStrParam '' - File name in the `pkcs8` folder for which this - passphrase should be used. - ''; - secret = mkOptionalStrParam '' - Value of decryption passphrase for PKCS#8 key. - ''; - } '' - Private key decryption passphrase for a key in the - `pkcs8` folder. - ''; - - pkcs12 = mkPrefixedAttrsOfParams { - file = mkOptionalStrParam '' - File name in the `pkcs12` folder for which this - passphrase should be used. - ''; - secret = mkOptionalStrParam '' - Value of decryption passphrase for PKCS#12 container. - ''; - } '' - PKCS#12 decryption passphrase for a container in the - `pkcs12` folder. - ''; - - token = mkPrefixedAttrsOfParams { - handle = mkOptionalHexParam '' - Hex-encoded CKA_ID or handle of the private key on the token or TPM, - respectively. - ''; - - slot = mkOptionalIntParam '' - Optional slot number to access the token. - ''; - - module = mkOptionalStrParam '' - Optional PKCS#11 module name to access the token. - ''; - - pin = mkOptionalStrParam '' - Optional PIN required to access the key on the token. If none is - provided the user is prompted during an interactive - `--load-creds` call. - ''; - } "Definition for a private key that's stored on a token/smartcard/TPM."; - - }; - - pools = mkAttrsOfParams { - addrs = mkOptionalStrParam '' - Subnet or range defining addresses allocated in pool. Accepts a single - CIDR subnet defining the pool to allocate addresses from or an address - range (\-\). Pools must be unique and non-overlapping. - ''; - - dns = mkCommaSepListParam [] "Address or CIDR subnets"; - nbns = mkCommaSepListParam [] "Address or CIDR subnets"; - dhcp = mkCommaSepListParam [] "Address or CIDR subnets"; - netmask = mkCommaSepListParam [] "Address or CIDR subnets"; - server = mkCommaSepListParam [] "Address or CIDR subnets"; - subnet = mkCommaSepListParam [] "Address or CIDR subnets"; - split_include = mkCommaSepListParam [] "Address or CIDR subnets"; - split_exclude = mkCommaSepListParam [] "Address or CIDR subnets"; - } '' - Section defining named pools. Named pools may be referenced by connections - with the pools option to assign virtual IPs and other configuration - attributes. Each pool must have a unique name (denoted \ below). - ''; } diff --git a/nixos/modules/services/networking/strongswan.nix b/nixos/modules/services/networking/strongswan.nix index 1cb9f4e1fc5aa9..5144a0c4e03417 100644 --- a/nixos/modules/services/networking/strongswan.nix +++ b/nixos/modules/services/networking/strongswan.nix @@ -1,27 +1,48 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (builtins) toFile; - inherit (lib) concatMapStrings concatStringsSep mapAttrsToList - mkIf mkEnableOption mkOption types literalExpression optionalString; + inherit (lib) + concatMapStrings + concatStringsSep + mapAttrsToList + mkIf + mkEnableOption + mkOption + types + literalExpression + optionalString + ; cfg = config.services.strongswan; ipsecSecrets = secrets: concatMapStrings (f: "include ${f}\n") secrets; - ipsecConf = {setup, connections, ca}: + ipsecConf = + { + setup, + connections, + ca, + }: let # https://wiki.strongswan.org/projects/strongswan/wiki/IpsecConf - makeSections = type: sections: concatStringsSep "\n\n" ( - mapAttrsToList (sec: attrs: - "${type} ${sec}\n" + - (concatStringsSep "\n" ( mapAttrsToList (k: v: " ${k}=${v}") attrs )) - ) sections - ); - setupConf = makeSections "config" { inherit setup; }; + makeSections = + type: sections: + concatStringsSep "\n\n" ( + mapAttrsToList ( + sec: attrs: + "${type} ${sec}\n" + (concatStringsSep "\n" (mapAttrsToList (k: v: " ${k}=${v}") attrs)) + ) sections + ); + setupConf = makeSections "config" { inherit setup; }; connectionsConf = makeSections "conn" connections; - caConf = makeSections "ca" ca; + caConf = makeSections "ca" ca; in builtins.toFile "ipsec.conf" '' @@ -30,21 +51,30 @@ let ${caConf} ''; - strongswanConf = {setup, connections, ca, secretsFile, managePlugins, enabledPlugins}: toFile "strongswan.conf" '' - charon { - ${optionalString managePlugins "load_modular = no"} - ${optionalString managePlugins ("load = " + (concatStringsSep " " enabledPlugins))} - plugins { - stroke { - secrets_file = ${secretsFile} + strongswanConf = + { + setup, + connections, + ca, + secretsFile, + managePlugins, + enabledPlugins, + }: + toFile "strongswan.conf" '' + charon { + ${optionalString managePlugins "load_modular = no"} + ${optionalString managePlugins ("load = " + (concatStringsSep " " enabledPlugins))} + plugins { + stroke { + secrets_file = ${secretsFile} + } } } - } - starter { - config_file = ${ipsecConf { inherit setup connections ca; }} - } - ''; + starter { + config_file = ${ipsecConf { inherit setup connections ca; }} + } + ''; in { @@ -53,7 +83,7 @@ in secrets = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "/run/keys/ipsec-foo.secret" ]; description = '' A list of paths to IPSec secret files. These @@ -65,8 +95,11 @@ in setup = mkOption { type = types.attrsOf types.str; - default = {}; - example = { cachecrls = "yes"; strictcrlpolicy = "yes"; }; + default = { }; + example = { + cachecrls = "yes"; + strictcrlpolicy = "yes"; + }; description = '' A set of options for the ‘config setup’ section of the {file}`ipsec.conf` file. Defines general @@ -76,7 +109,7 @@ in connections = mkOption { type = types.attrsOf (types.attrsOf types.str); - default = {}; + default = { }; example = literalExpression '' { "%default" = { @@ -100,10 +133,10 @@ in ca = mkOption { type = types.attrsOf (types.attrsOf types.str); - default = {}; + default = { }; example = { strongswan = { - auto = "add"; + auto = "add"; cacert = "/run/keys/strongswanCert.pem"; crluri = "http://crl2.strongswan.org/strongswan.crl"; }; @@ -127,7 +160,7 @@ in enabledPlugins = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = '' A list of additional plugins to enable if {option}`managePlugins` is true. @@ -135,34 +168,44 @@ in }; }; - - config = with cfg; mkIf enable - { - - # here we should use the default strongswan ipsec.secrets and - # append to it (default one is empty so not a pb for now) - environment.etc."ipsec.secrets".text = ipsecSecrets cfg.secrets; - - systemd.services.strongswan = { - description = "strongSwan IPSec Service"; - wantedBy = [ "multi-user.target" ]; - path = with pkgs; [ kmod iproute2 iptables util-linux ]; # XXX Linux - wants = [ "network-online.target" ]; - after = [ "network-online.target" ]; - environment = { - STRONGSWAN_CONF = strongswanConf { - inherit setup connections ca managePlugins enabledPlugins; - secretsFile = "/etc/ipsec.secrets"; + config = + with cfg; + mkIf enable { + + # here we should use the default strongswan ipsec.secrets and + # append to it (default one is empty so not a pb for now) + environment.etc."ipsec.secrets".text = ipsecSecrets cfg.secrets; + + systemd.services.strongswan = { + description = "strongSwan IPSec Service"; + wantedBy = [ "multi-user.target" ]; + path = with pkgs; [ + kmod + iproute2 + iptables + util-linux + ]; # XXX Linux + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; + environment = { + STRONGSWAN_CONF = strongswanConf { + inherit + setup + connections + ca + managePlugins + enabledPlugins + ; + secretsFile = "/etc/ipsec.secrets"; + }; }; + serviceConfig = { + ExecStart = "${pkgs.strongswan}/sbin/ipsec start --nofork"; + }; + preStart = '' + # with 'nopeerdns' setting, ppp writes into this folder + mkdir -m 700 -p /etc/ppp + ''; }; - serviceConfig = { - ExecStart = "${pkgs.strongswan}/sbin/ipsec start --nofork"; - }; - preStart = '' - # with 'nopeerdns' setting, ppp writes into this folder - mkdir -m 700 -p /etc/ppp - ''; }; - }; } - diff --git a/nixos/modules/services/networking/stunnel.nix b/nixos/modules/services/networking/stunnel.nix index da308dde8b26e9..ddc50a04789a75 100644 --- a/nixos/modules/services/networking/stunnel.nix +++ b/nixos/modules/services/networking/stunnel.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.stunnel; @@ -6,21 +11,27 @@ let verifyRequiredField = type: field: n: c: { assertion = lib.hasAttr field c; - message = "stunnel: \"${n}\" ${type} configuration - Field ${field} is required."; + message = "stunnel: \"${n}\" ${type} configuration - Field ${field} is required."; }; verifyChainPathAssert = n: c: { assertion = (c.verifyHostname or null) == null || (c.verifyChain || c.verifyPeer); - message = "stunnel: \"${n}\" client configuration - hostname verification " + - "is not possible without either verifyChain or verifyPeer enabled"; + message = + "stunnel: \"${n}\" client configuration - hostname verification " + + "is not possible without either verifyChain or verifyPeer enabled"; }; removeNulls = lib.mapAttrs (_: lib.filterAttrs (_: v: v != null)); - mkValueString = v: - if v == true then "yes" - else if v == false then "no" - else lib.generators.mkValueStringDefault {} v; - generateConfig = c: + mkValueString = + v: + if v == true then + "yes" + else if v == false then + "no" + else + lib.generators.mkValueStringDefault { } v; + generateConfig = + c: lib.generators.toINI { mkSectionName = lib.id; mkKeyValue = k: v: "${k} = ${mkValueString v}"; @@ -55,7 +66,16 @@ in }; logLevel = lib.mkOption { - type = lib.types.enum [ "emerg" "alert" "crit" "err" "warning" "notice" "info" "debug" ]; + type = lib.types.enum [ + "emerg" + "alert" + "crit" + "err" + "warning" + "notice" + "info" + "debug" + ]; default = "info"; description = "Verbosity of stunnel output."; }; @@ -72,14 +92,23 @@ in description = "Enable support for the insecure SSLv3 protocol."; }; - servers = lib.mkOption { description = '' Define the server configurations. See "SERVICE-LEVEL OPTIONS" in {manpage}`stunnel(8)`. ''; - type = with lib.types; attrsOf (attrsOf (nullOr (oneOf [bool int str]))); + type = + with lib.types; + attrsOf ( + attrsOf ( + nullOr (oneOf [ + bool + int + str + ]) + ) + ); example = { fancyWebserver = { accept = 443; @@ -98,24 +127,40 @@ in See "SERVICE-LEVEL OPTIONS" in {manpage}`stunnel(8)`. ''; - type = with lib.types; attrsOf (attrsOf (nullOr (oneOf [bool int str]))); - - apply = let - applyDefaults = c: - { - CAFile = "${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt"; - OCSPaia = true; - verifyChain = true; - } // c; - setCheckHostFromVerifyHostname = c: - # To preserve backward-compatibility with the old NixOS stunnel module - # definition, allow "verifyHostname" as an alias for "checkHost". - c // { - checkHost = c.checkHost or c.verifyHostname or null; - verifyHostname = null; # Not a real stunnel configuration setting - }; - forceClient = c: c // { client = true; }; - in lib.mapAttrs (_: c: forceClient (setCheckHostFromVerifyHostname (applyDefaults c))); + type = + with lib.types; + attrsOf ( + attrsOf ( + nullOr (oneOf [ + bool + int + str + ]) + ) + ); + + apply = + let + applyDefaults = + c: + { + CAFile = "${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt"; + OCSPaia = true; + verifyChain = true; + } + // c; + setCheckHostFromVerifyHostname = + c: + # To preserve backward-compatibility with the old NixOS stunnel module + # definition, allow "verifyHostname" as an alias for "checkHost". + c + // { + checkHost = c.checkHost or c.verifyHostname or null; + verifyHostname = null; # Not a real stunnel configuration setting + }; + forceClient = c: c // { client = true; }; + in + lib.mapAttrs (_: c: forceClient (setCheckHostFromVerifyHostname (applyDefaults c))); example = { foobar = { @@ -129,14 +174,14 @@ in }; }; - ###### implementation config = lib.mkIf cfg.enable { assertions = lib.concatLists [ (lib.singleton { - assertion = (lib.length (lib.attrValues cfg.servers) != 0) || ((lib.length (lib.attrValues cfg.clients)) != 0); + assertion = + (lib.length (lib.attrValues cfg.servers) != 0) || ((lib.length (lib.attrValues cfg.clients)) != 0); message = "stunnel: At least one server- or client-configuration has to be present."; }) @@ -151,19 +196,19 @@ in environment.systemPackages = [ pkgs.stunnel ]; environment.etc."stunnel.cfg".text = '' - ${ lib.optionalString (cfg.user != null) "setuid = ${cfg.user}" } - ${ lib.optionalString (cfg.group != null) "setgid = ${cfg.group}" } + ${lib.optionalString (cfg.user != null) "setuid = ${cfg.user}"} + ${lib.optionalString (cfg.group != null) "setgid = ${cfg.group}"} debug = ${cfg.logLevel} - ${ lib.optionalString cfg.fipsMode "fips = yes" } - ${ lib.optionalString cfg.enableInsecureSSLv3 "options = -NO_SSLv3" } + ${lib.optionalString cfg.fipsMode "fips = yes"} + ${lib.optionalString cfg.enableInsecureSSLv3 "options = -NO_SSLv3"} ; ----- SERVER CONFIGURATIONS ----- - ${ generateConfig cfg.servers } + ${generateConfig cfg.servers} ; ----- CLIENT CONFIGURATIONS ----- - ${ generateConfig cfg.clients } + ${generateConfig cfg.clients} ''; systemd.services.stunnel = { diff --git a/nixos/modules/services/networking/sunshine.nix b/nixos/modules/services/networking/sunshine.nix index ec78db1f3f8e99..eaa769246add08 100644 --- a/nixos/modules/services/networking/sunshine.nix +++ b/nixos/modules/services/networking/sunshine.nix @@ -1,6 +1,22 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let - inherit (lib) mkEnableOption mkPackageOption mkOption literalExpression mkIf mkDefault types optionals getExe; + inherit (lib) + mkEnableOption + mkPackageOption + mkOption + literalExpression + mkIf + mkDefault + types + optionals + getExe + ; inherit (utils) escapeSystemdExecArgs; cfg = config.services.sunshine; @@ -116,8 +132,19 @@ in ]; networking.firewall = mkIf cfg.openFirewall { - allowedTCPPorts = generatePorts cfg.settings.port [ (-5) 0 1 21 ]; - allowedUDPPorts = generatePorts cfg.settings.port [ 9 10 11 13 21 ]; + allowedTCPPorts = generatePorts cfg.settings.port [ + (-5) + 0 + 1 + 21 + ]; + allowedUDPPorts = generatePorts cfg.settings.port [ + 9 + 10 + 11 + 13 + 21 + ]; }; boot.kernelModules = [ "uinput" ]; @@ -152,9 +179,15 @@ in serviceConfig = { # only add configFile if an application or a setting other than the default port is set to allow configuration from web UI - ExecStart = escapeSystemdExecArgs ([ - (if cfg.capSysAdmin then "${config.security.wrapperDir}/sunshine" else "${getExe cfg.package}") - ] ++ optionals (cfg.applications.apps != [ ] || (builtins.length (builtins.attrNames cfg.settings) > 1 || cfg.settings.port != defaultPort)) [ "${configFile}" ]); + ExecStart = escapeSystemdExecArgs ( + [ + (if cfg.capSysAdmin then "${config.security.wrapperDir}/sunshine" else "${getExe cfg.package}") + ] + ++ optionals ( + cfg.applications.apps != [ ] + || (builtins.length (builtins.attrNames cfg.settings) > 1 || cfg.settings.port != defaultPort) + ) [ "${configFile}" ] + ); Restart = "on-failure"; RestartSec = "5s"; }; diff --git a/nixos/modules/services/networking/tailscale-auth.nix b/nixos/modules/services/networking/tailscale-auth.nix index f21d1f108911c2..32ddbdfd155d2d 100644 --- a/nixos/modules/services/networking/tailscale-auth.nix +++ b/nixos/modules/services/networking/tailscale-auth.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) @@ -16,7 +21,7 @@ in options.services.tailscaleAuth = { enable = mkEnableOption "tailscale.nginx-auth, to authenticate users via tailscale"; - package = mkPackageOption pkgs "tailscale-nginx-auth" {}; + package = mkPackageOption pkgs "tailscale-nginx-auth" { }; user = mkOption { type = types.str; @@ -94,11 +99,20 @@ in SystemCallErrorNumber = "EPERM"; SystemCallFilter = [ "@system-service" - "~@cpu-emulation" "~@debug" "~@keyring" "~@memlock" "~@obsolete" "~@privileged" "~@setuid" + "~@cpu-emulation" + "~@debug" + "~@keyring" + "~@memlock" + "~@obsolete" + "~@privileged" + "~@setuid" ]; }; }; }; - meta.maintainers = with maintainers; [ dan-theriault phaer ]; + meta.maintainers = with maintainers; [ + dan-theriault + phaer + ]; } diff --git a/nixos/modules/services/networking/tetrd.nix b/nixos/modules/services/networking/tetrd.nix index 0801ce12924642..a182cc347306ce 100644 --- a/nixos/modules/services/networking/tetrd.nix +++ b/nixos/modules/services/networking/tetrd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { options.services.tetrd.enable = lib.mkEnableOption "tetrd"; @@ -41,7 +46,12 @@ ProtectProc = "invisible"; ProtectSystem = "strict"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" "AF_NETLINK" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + "AF_NETLINK" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; diff --git a/nixos/modules/services/networking/twingate.nix b/nixos/modules/services/networking/twingate.nix index 94339d8c217ad1..4e9edf6bb23dbb 100644 --- a/nixos/modules/services/networking/twingate.nix +++ b/nixos/modules/services/networking/twingate.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.twingate; diff --git a/nixos/modules/services/networking/v2raya.nix b/nixos/modules/services/networking/v2raya.nix index 556258a2a05020..a1b574870218c6 100644 --- a/nixos/modules/services/networking/v2raya.nix +++ b/nixos/modules/services/networking/v2raya.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -52,10 +57,16 @@ in }; wantedBy = [ "multi-user.target" ]; - path = with pkgs; [ iptables bash iproute2 ] ++ lib.optionals nftablesEnabled [ nftables ]; # required by v2rayA TProxy functionality + path = + with pkgs; + [ + iptables + bash + iproute2 + ] + ++ lib.optionals nftablesEnabled [ nftables ]; # required by v2rayA TProxy functionality }; }; meta.maintainers = with maintainers; [ elliot ]; } - diff --git a/nixos/modules/services/networking/vdirsyncer.nix b/nixos/modules/services/networking/vdirsyncer.nix index 10a101befa7bd3..692ce12c7a6c0c 100644 --- a/nixos/modules/services/networking/vdirsyncer.nix +++ b/nixos/modules/services/networking/vdirsyncer.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,44 +11,48 @@ let cfg = config.services.vdirsyncer; - toIniJson = with generators; toINI { - mkKeyValue = mkKeyValueDefault { - mkValueString = builtins.toJSON; - } "="; - }; + toIniJson = + with generators; + toINI { + mkKeyValue = mkKeyValueDefault { + mkValueString = builtins.toJSON; + } "="; + }; - toConfigFile = name: cfg': - if - cfg'.configFile != null - then + toConfigFile = + name: cfg': + if cfg'.configFile != null then cfg'.configFile else - pkgs.writeText "vdirsyncer-${name}.conf" (toIniJson ( - { - general = cfg'.config.general // { - status_path = if cfg'.config.statusPath == null - then "/var/lib/vdirsyncer/${name}" - else cfg'.config.statusPath; - }; - } // ( - mapAttrs' (name: nameValuePair "pair ${name}") cfg'.config.pairs - ) // ( - mapAttrs' (name: nameValuePair "storage ${name}") cfg'.config.storages + pkgs.writeText "vdirsyncer-${name}.conf" ( + toIniJson ( + { + general = cfg'.config.general // { + status_path = + if cfg'.config.statusPath == null then "/var/lib/vdirsyncer/${name}" else cfg'.config.statusPath; + }; + } + // (mapAttrs' (name: nameValuePair "pair ${name}") cfg'.config.pairs) + // (mapAttrs' (name: nameValuePair "storage ${name}") cfg'.config.storages) ) - )); + ); userUnitConfig = name: cfg': { - serviceConfig = { - User = if cfg'.user == null then "vdirsyncer" else cfg'.user; - Group = if cfg'.group == null then "vdirsyncer" else cfg'.group; - } // (optionalAttrs (cfg'.user == null) { - DynamicUser = true; - }) // (optionalAttrs (cfg'.additionalGroups != []) { - SupplementaryGroups = cfg'.additionalGroups; - }) // (optionalAttrs (cfg'.config.statusPath == null) { - StateDirectory = "vdirsyncer/${name}"; - StateDirectoryMode = "0700"; - }); + serviceConfig = + { + User = if cfg'.user == null then "vdirsyncer" else cfg'.user; + Group = if cfg'.group == null then "vdirsyncer" else cfg'.group; + } + // (optionalAttrs (cfg'.user == null) { + DynamicUser = true; + }) + // (optionalAttrs (cfg'.additionalGroups != [ ]) { + SupplementaryGroups = cfg'.additionalGroups; + }) + // (optionalAttrs (cfg'.config.statusPath == null) { + StateDirectory = "vdirsyncer/${name}"; + StateDirectoryMode = "0700"; + }); }; commonUnitConfig = { @@ -73,144 +82,153 @@ in services.vdirsyncer = { enable = mkEnableOption "vdirsyncer"; - package = mkPackageOption pkgs "vdirsyncer" {}; + package = mkPackageOption pkgs "vdirsyncer" { }; jobs = mkOption { description = "vdirsyncer job configurations"; - type = types.attrsOf (types.submodule { - options = { - enable = (mkEnableOption "this vdirsyncer job") // { - default = true; - example = false; - }; - - user = mkOption { - type = types.nullOr types.str; - default = null; - description = '' - User account to run vdirsyncer as, otherwise as a systemd - dynamic user - ''; - }; - - group = mkOption { - type = types.nullOr types.str; - default = null; - description = "group to run vdirsyncer as"; - }; - - additionalGroups = mkOption { - type = types.listOf types.str; - default = []; - description = "additional groups to add the dynamic user to"; - }; - - forceDiscover = mkOption { - type = types.bool; - default = false; - description = '' - Run `yes | vdirsyncer discover` prior to `vdirsyncer sync` - ''; - }; - - timerConfig = mkOption { - type = types.attrs; - default = { - OnBootSec = "1h"; - OnUnitActiveSec = "6h"; + type = types.attrsOf ( + types.submodule { + options = { + enable = (mkEnableOption "this vdirsyncer job") // { + default = true; + example = false; }; - description = "systemd timer configuration"; - }; - configFile = mkOption { - type = types.nullOr types.path; - default = null; - description = "existing configuration file"; - }; + user = mkOption { + type = types.nullOr types.str; + default = null; + description = '' + User account to run vdirsyncer as, otherwise as a systemd + dynamic user + ''; + }; - config = { - statusPath = mkOption { + group = mkOption { type = types.nullOr types.str; default = null; - defaultText = literalExpression "/var/lib/vdirsyncer/\${attrName}"; - description = "vdirsyncer's status path"; + description = "group to run vdirsyncer as"; }; - general = mkOption { - type = types.attrs; - default = {}; - description = "general configuration"; + additionalGroups = mkOption { + type = types.listOf types.str; + default = [ ]; + description = "additional groups to add the dynamic user to"; }; - pairs = mkOption { - type = types.attrsOf types.attrs; - default = {}; - description = "vdirsyncer pair configurations"; - example = literalExpression '' - { - my_contacts = { - a = "my_cloud_contacts"; - b = "my_local_contacts"; - collections = [ "from a" ]; - conflict_resolution = "a wins"; - metadata = [ "color" "displayname" ]; - }; - }; + forceDiscover = mkOption { + type = types.bool; + default = false; + description = '' + Run `yes | vdirsyncer discover` prior to `vdirsyncer sync` ''; }; - storages = mkOption { - type = types.attrsOf types.attrs; - default = {}; - description = "vdirsyncer storage configurations"; - example = literalExpression '' - { - my_cloud_contacts = { - type = "carddav"; - url = "https://dav.example.com/"; - read_only = true; - username = "user"; - "password.fetch" = [ "command" "cat" "/etc/vdirsyncer/cloud.passwd" ]; - }; - my_local_contacts = { - type = "carddav"; - url = "https://localhost/"; - username = "user"; - "password.fetch" = [ "command" "cat" "/etc/vdirsyncer/local.passwd" ]; + timerConfig = mkOption { + type = types.attrs; + default = { + OnBootSec = "1h"; + OnUnitActiveSec = "6h"; + }; + description = "systemd timer configuration"; + }; + + configFile = mkOption { + type = types.nullOr types.path; + default = null; + description = "existing configuration file"; + }; + + config = { + statusPath = mkOption { + type = types.nullOr types.str; + default = null; + defaultText = literalExpression "/var/lib/vdirsyncer/\${attrName}"; + description = "vdirsyncer's status path"; + }; + + general = mkOption { + type = types.attrs; + default = { }; + description = "general configuration"; + }; + + pairs = mkOption { + type = types.attrsOf types.attrs; + default = { }; + description = "vdirsyncer pair configurations"; + example = literalExpression '' + { + my_contacts = { + a = "my_cloud_contacts"; + b = "my_local_contacts"; + collections = [ "from a" ]; + conflict_resolution = "a wins"; + metadata = [ "color" "displayname" ]; + }; }; - } - ''; + ''; + }; + + storages = mkOption { + type = types.attrsOf types.attrs; + default = { }; + description = "vdirsyncer storage configurations"; + example = literalExpression '' + { + my_cloud_contacts = { + type = "carddav"; + url = "https://dav.example.com/"; + read_only = true; + username = "user"; + "password.fetch" = [ "command" "cat" "/etc/vdirsyncer/cloud.passwd" ]; + }; + my_local_contacts = { + type = "carddav"; + url = "https://localhost/"; + username = "user"; + "password.fetch" = [ "command" "cat" "/etc/vdirsyncer/local.passwd" ]; + }; + } + ''; + }; }; }; - }; - }); + } + ); }; }; }; config = mkIf cfg.enable { - systemd.services = mapAttrs' (name: cfg': nameValuePair "vdirsyncer@${name}" ( - foldr recursiveUpdate {} [ - commonUnitConfig - (userUnitConfig name cfg') - { - description = "synchronize calendars and contacts (${name})"; - environment.VDIRSYNCER_CONFIG = toConfigFile name cfg'; - serviceConfig.ExecStart = - (optional cfg'.forceDiscover ( - pkgs.writeShellScript "vdirsyncer-discover-yes" '' - set -e - yes | ${cfg.package}/bin/vdirsyncer discover - '' - )) ++ [ "${cfg.package}/bin/vdirsyncer sync" ]; - } - ] - )) (filterAttrs (name: cfg': cfg'.enable) cfg.jobs); - - systemd.timers = mapAttrs' (name: cfg': nameValuePair "vdirsyncer@${name}" { - wantedBy = [ "timers.target" ]; - description = "synchronize calendars and contacts (${name})"; - inherit (cfg') timerConfig; - }) cfg.jobs; + systemd.services = mapAttrs' ( + name: cfg': + nameValuePair "vdirsyncer@${name}" ( + foldr recursiveUpdate { } [ + commonUnitConfig + (userUnitConfig name cfg') + { + description = "synchronize calendars and contacts (${name})"; + environment.VDIRSYNCER_CONFIG = toConfigFile name cfg'; + serviceConfig.ExecStart = + (optional cfg'.forceDiscover ( + pkgs.writeShellScript "vdirsyncer-discover-yes" '' + set -e + yes | ${cfg.package}/bin/vdirsyncer discover + '' + )) + ++ [ "${cfg.package}/bin/vdirsyncer sync" ]; + } + ] + ) + ) (filterAttrs (name: cfg': cfg'.enable) cfg.jobs); + + systemd.timers = mapAttrs' ( + name: cfg': + nameValuePair "vdirsyncer@${name}" { + wantedBy = [ "timers.target" ]; + description = "synchronize calendars and contacts (${name})"; + inherit (cfg') timerConfig; + } + ) cfg.jobs; }; } diff --git a/nixos/modules/services/networking/vsftpd.nix b/nixos/modules/services/networking/vsftpd.nix index 07b93e92a75099..e6ef14b2e3e405 100644 --- a/nixos/modules/services/networking/vsftpd.nix +++ b/nixos/modules/services/networking/vsftpd.nix @@ -1,19 +1,24 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let - /* minimal secure setup: - - enable = true; - forceLocalLoginsSSL = true; - forceLocalDataSSL = true; - userlistDeny = false; - localUsers = true; - userlist = ["non-root-user" "other-non-root-user"]; - rsaCertFile = "/var/vsftpd/vsftpd.pem"; + /* + minimal secure setup: + enable = true; + forceLocalLoginsSSL = true; + forceLocalDataSSL = true; + userlistDeny = false; + localUsers = true; + userlist = ["non-root-user" "other-non-root-user"]; + rsaCertFile = "/var/vsftpd/vsftpd.pem"; */ cfg = config.services.vsftpd; @@ -86,7 +91,7 @@ let outgoing data connections can only connect to the client. Only enable if you know what you are doing! '') - (yesNoOption "ssl_tlsv1" "ssl_tlsv1" true '' + (yesNoOption "ssl_tlsv1" "ssl_tlsv1" true '' Only applies if {option}`ssl_enable` is activated. If enabled, this option will permit TLS v1 protocol connections. TLS v1 connections are preferred. @@ -103,42 +108,41 @@ let '') ]; - configFile = pkgs.writeText "vsftpd.conf" - '' - ${concatMapStrings (x: "${x.cfgText}\n") optionDescription} - ${optionalString (cfg.rsaCertFile != null) '' - ssl_enable=YES - rsa_cert_file=${cfg.rsaCertFile} - ''} - ${optionalString (cfg.rsaKeyFile != null) '' - rsa_private_key_file=${cfg.rsaKeyFile} - ''} - ${optionalString (cfg.userlistFile != null) '' - userlist_file=${cfg.userlistFile} - ''} - background=YES - listen=NO - listen_ipv6=YES - nopriv_user=vsftpd - secure_chroot_dir=/var/empty - ${optionalString (cfg.localRoot != null) '' - local_root=${cfg.localRoot} - ''} - syslog_enable=YES - ${optionalString (pkgs.stdenv.hostPlatform.system == "x86_64-linux") '' - seccomp_sandbox=NO - ''} - anon_umask=${cfg.anonymousUmask} - ${optionalString cfg.anonymousUser '' - anon_root=${cfg.anonymousUserHome} - ''} - ${optionalString cfg.enableVirtualUsers '' - guest_enable=YES - guest_username=vsftpd - ''} - pam_service_name=vsftpd - ${cfg.extraConfig} - ''; + configFile = pkgs.writeText "vsftpd.conf" '' + ${concatMapStrings (x: "${x.cfgText}\n") optionDescription} + ${optionalString (cfg.rsaCertFile != null) '' + ssl_enable=YES + rsa_cert_file=${cfg.rsaCertFile} + ''} + ${optionalString (cfg.rsaKeyFile != null) '' + rsa_private_key_file=${cfg.rsaKeyFile} + ''} + ${optionalString (cfg.userlistFile != null) '' + userlist_file=${cfg.userlistFile} + ''} + background=YES + listen=NO + listen_ipv6=YES + nopriv_user=vsftpd + secure_chroot_dir=/var/empty + ${optionalString (cfg.localRoot != null) '' + local_root=${cfg.localRoot} + ''} + syslog_enable=YES + ${optionalString (pkgs.stdenv.hostPlatform.system == "x86_64-linux") '' + seccomp_sandbox=NO + ''} + anon_umask=${cfg.anonymousUmask} + ${optionalString cfg.anonymousUser '' + anon_root=${cfg.anonymousUserHome} + ''} + ${optionalString cfg.enableVirtualUsers '' + guest_enable=YES + guest_username=vsftpd + ''} + pam_service_name=vsftpd + ${cfg.extraConfig} + ''; in @@ -153,7 +157,7 @@ in enable = mkEnableOption "vsftpd"; userlist = mkOption { - default = []; + default = [ ]; type = types.listOf types.str; description = "See {option}`userlistFile`."; }; @@ -265,42 +269,48 @@ in }; - ###### implementation config = mkIf cfg.enable { assertions = [ - { assertion = - (cfg.forceLocalLoginsSSL -> cfg.rsaCertFile != null) - && (cfg.forceLocalDataSSL -> cfg.rsaCertFile != null); + { + assertion = + (cfg.forceLocalLoginsSSL -> cfg.rsaCertFile != null) + && (cfg.forceLocalDataSSL -> cfg.rsaCertFile != null); message = "vsftpd: If forceLocalLoginsSSL or forceLocalDataSSL is true then a rsaCertFile must be provided!"; } { - assertion = (cfg.enableVirtualUsers -> cfg.userDbPath != null) - && (cfg.enableVirtualUsers -> cfg.localUsers); + assertion = + (cfg.enableVirtualUsers -> cfg.userDbPath != null) && (cfg.enableVirtualUsers -> cfg.localUsers); message = "vsftpd: If enableVirtualUsers is true, you need to setup both the userDbPath and localUsers options."; - }]; - - users.users = { - "vsftpd" = { - group = "vsftpd"; - isSystemUser = true; - description = "VSFTPD user"; - home = if cfg.localRoot != null - then cfg.localRoot # <= Necessary for virtual users. - else "/homeless-shelter"; - }; - } // optionalAttrs cfg.anonymousUser { - "ftp" = { name = "ftp"; + } + ]; + + users.users = + { + "vsftpd" = { + group = "vsftpd"; + isSystemUser = true; + description = "VSFTPD user"; + home = + if cfg.localRoot != null then + cfg.localRoot # <= Necessary for virtual users. + else + "/homeless-shelter"; + }; + } + // optionalAttrs cfg.anonymousUser { + "ftp" = { + name = "ftp"; uid = config.ids.uids.ftp; group = "ftp"; description = "Anonymous FTP user"; home = cfg.anonymousUserHome; }; - }; + }; - users.groups.vsftpd = {}; + users.groups.vsftpd = { }; users.groups.ftp.gid = config.ids.gids.ftp; # If you really have to access root via FTP use mkOverride or userlistDeny @@ -308,9 +318,10 @@ in services.vsftpd.userlist = optional cfg.userlistDeny "root"; systemd = { - tmpfiles.rules = optional cfg.anonymousUser - #Type Path Mode User Gr Age Arg - "d '${builtins.toString cfg.anonymousUserHome}' 0555 'ftp' 'ftp' - -"; + tmpfiles.rules = + optional cfg.anonymousUser + #Type Path Mode User Gr Age Arg + "d '${builtins.toString cfg.anonymousUserHome}' 0555 'ftp' 'ftp' - -"; services.vsftpd = { description = "Vsftpd Server"; @@ -322,7 +333,7 @@ in }; }; - security.pam.services.vsftpd.text = mkIf (cfg.enableVirtualUsers && cfg.userDbPath != null)'' + security.pam.services.vsftpd.text = mkIf (cfg.enableVirtualUsers && cfg.userDbPath != null) '' auth required pam_userdb.so db=${cfg.userDbPath} account required pam_userdb.so db=${cfg.userDbPath} ''; diff --git a/nixos/modules/services/networking/wasabibackend.nix b/nixos/modules/services/networking/wasabibackend.nix index 89431ae9b41967..1c8c884fbe1171 100644 --- a/nixos/modules/services/networking/wasabibackend.nix +++ b/nixos/modules/services/networking/wasabibackend.nix @@ -1,30 +1,49 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.wasabibackend; opt = options.services.wasabibackend; - inherit (lib) literalExpression mkEnableOption mkIf mkOption optionalAttrs optionalString types; - - confOptions = { + inherit (lib) + literalExpression + mkEnableOption + mkIf + mkOption + optionalAttrs + optionalString + types + ; + + confOptions = + { BitcoinRpcConnectionString = "${cfg.rpc.user}:${cfg.rpc.password}"; - } // optionalAttrs (cfg.network == "mainnet") { + } + // optionalAttrs (cfg.network == "mainnet") { Network = "Main"; MainNetBitcoinP2pEndPoint = "${cfg.endpoint.ip}:${toString cfg.endpoint.port}"; MainNetBitcoinCoreRpcEndPoint = "${cfg.rpc.ip}:${toString cfg.rpc.port}"; - } // optionalAttrs (cfg.network == "testnet") { + } + // optionalAttrs (cfg.network == "testnet") { Network = "TestNet"; TestNetBitcoinP2pEndPoint = "${cfg.endpoint.ip}:${toString cfg.endpoint.port}"; TestNetBitcoinCoreRpcEndPoint = "${cfg.rpc.ip}:${toString cfg.rpc.port}"; - } // optionalAttrs (cfg.network == "regtest") { + } + // optionalAttrs (cfg.network == "regtest") { Network = "RegTest"; RegTestBitcoinP2pEndPoint = "${cfg.endpoint.ip}:${toString cfg.endpoint.port}"; RegTestBitcoinCoreRpcEndPoint = "${cfg.rpc.ip}:${toString cfg.rpc.port}"; - }; + }; configFile = pkgs.writeText "wasabibackend.conf" (builtins.toJSON confOptions); -in { +in +{ options = { @@ -44,7 +63,11 @@ in { }; network = mkOption { - type = types.enum [ "mainnet" "testnet" "regtest" ]; + type = types.enum [ + "mainnet" + "testnet" + "regtest" + ]; default = "mainnet"; description = "The network to use for the Wasabi backend service."; }; @@ -127,16 +150,21 @@ in { }; preStart = '' mkdir -p ${cfg.dataDir}/.walletwasabi/backend - ${if cfg.customConfigFile != null then '' - cp -v ${cfg.customConfigFile} ${cfg.dataDir}/.walletwasabi/backend/Config.json - '' else '' - cp -v ${configFile} ${cfg.dataDir}/.walletwasabi/backend/Config.json - ${optionalString (cfg.rpc.passwordFile != null) '' - CONFIGTMP=$(mktemp) - cat ${cfg.dataDir}/.walletwasabi/backend/Config.json | ${pkgs.jq}/bin/jq --arg rpconnection "${cfg.rpc.user}:$(cat "${cfg.rpc.passwordFile}")" '. + { BitcoinRpcConnectionString: $rpconnection }' > $CONFIGTMP - mv $CONFIGTMP ${cfg.dataDir}/.walletwasabi/backend/Config.json - ''} - ''} + ${ + if cfg.customConfigFile != null then + '' + cp -v ${cfg.customConfigFile} ${cfg.dataDir}/.walletwasabi/backend/Config.json + '' + else + '' + cp -v ${configFile} ${cfg.dataDir}/.walletwasabi/backend/Config.json + ${optionalString (cfg.rpc.passwordFile != null) '' + CONFIGTMP=$(mktemp) + cat ${cfg.dataDir}/.walletwasabi/backend/Config.json | ${pkgs.jq}/bin/jq --arg rpconnection "${cfg.rpc.user}:$(cat "${cfg.rpc.passwordFile}")" '. + { BitcoinRpcConnectionString: $rpconnection }' > $CONFIGTMP + mv $CONFIGTMP ${cfg.dataDir}/.walletwasabi/backend/Config.json + ''} + '' + } chmod ug+w ${cfg.dataDir}/.walletwasabi/backend/Config.json ''; serviceConfig = { @@ -155,7 +183,7 @@ in { isSystemUser = true; }; - users.groups.${cfg.group} = {}; + users.groups.${cfg.group} = { }; }; } diff --git a/nixos/modules/services/networking/webhook.nix b/nixos/modules/services/networking/webhook.nix index 3c24bd9849f415..7a7c8e1e709581 100644 --- a/nixos/modules/services/networking/webhook.nix +++ b/nixos/modules/services/networking/webhook.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,29 +11,36 @@ let cfg = config.services.webhook; defaultUser = "webhook"; - hookFormat = pkgs.formats.json {}; - - hookType = types.submodule ({ name, ... }: { - freeformType = hookFormat.type; - options = { - id = mkOption { - type = types.str; - default = name; - description = '' - The ID of your hook. This value is used to create the HTTP endpoint (`protocol://yourserver:port/prefix/''${id}`). - ''; - }; - execute-command = mkOption { - type = types.str; - description = "The command that should be executed when the hook is triggered."; + hookFormat = pkgs.formats.json { }; + + hookType = types.submodule ( + { name, ... }: + { + freeformType = hookFormat.type; + options = { + id = mkOption { + type = types.str; + default = name; + description = '' + The ID of your hook. This value is used to create the HTTP endpoint (`protocol://yourserver:port/prefix/''${id}`). + ''; + }; + execute-command = mkOption { + type = types.str; + description = "The command that should be executed when the hook is triggered."; + }; }; - }; - }); + } + ); - hookFiles = mapAttrsToList (name: hook: hookFormat.generate "webhook-${name}.json" [ hook ]) cfg.hooks - ++ mapAttrsToList (name: hook: pkgs.writeText "webhook-${name}.json.tmpl" "[${hook}]") cfg.hooksTemplated; + hookFiles = + mapAttrsToList (name: hook: hookFormat.generate "webhook-${name}.json" [ hook ]) cfg.hooks + ++ mapAttrsToList ( + name: hook: pkgs.writeText "webhook-${name}.json.tmpl" "[${hook}]" + ) cfg.hooksTemplated; -in { +in +{ options = { services.webhook = { enable = mkEnableOption '' @@ -36,7 +48,7 @@ in { which execute configured commands for any person or service that knows the URL ''; - package = mkPackageOption pkgs "webhook" {}; + package = mkPackageOption pkgs "webhook" { }; user = mkOption { type = types.str; default = defaultUser; @@ -79,7 +91,7 @@ in { }; enableTemplates = mkOption { type = types.bool; - default = cfg.hooksTemplated != {}; + default = cfg.hooksTemplated != { }; defaultText = literalExpression "hooksTemplated != {}"; description = '' Enable the generated hooks file to be parsed as a Go template. @@ -95,7 +107,7 @@ in { }; hooks = mkOption { type = types.attrsOf hookType; - default = {}; + default = { }; example = { echo = { execute-command = "echo"; @@ -118,7 +130,7 @@ in { }; hooksTemplated = mkOption { type = types.attrsOf types.str; - default = {}; + default = { }; example = { echo-template = '' { @@ -144,7 +156,7 @@ in { }; extraArgs = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "-secure" ]; description = '' These are arguments passed to the webhook command in the systemd service. @@ -155,37 +167,38 @@ in { }; environment = mkOption { type = types.attrsOf types.str; - default = {}; + default = { }; description = "Extra environment variables passed to webhook."; }; }; }; config = mkIf cfg.enable { - assertions = let - overlappingHooks = builtins.intersectAttrs cfg.hooks cfg.hooksTemplated; - in [ - { - assertion = hookFiles != []; - message = "At least one hook needs to be configured for webhook to run."; - } - { - assertion = overlappingHooks == {}; - message = "`services.webhook.hooks` and `services.webhook.hooksTemplated` have overlapping attribute(s): ${concatStringsSep ", " (builtins.attrNames overlappingHooks)}"; - } - ]; + assertions = + let + overlappingHooks = builtins.intersectAttrs cfg.hooks cfg.hooksTemplated; + in + [ + { + assertion = hookFiles != [ ]; + message = "At least one hook needs to be configured for webhook to run."; + } + { + assertion = overlappingHooks == { }; + message = "`services.webhook.hooks` and `services.webhook.hooksTemplated` have overlapping attribute(s): ${concatStringsSep ", " (builtins.attrNames overlappingHooks)}"; + } + ]; users.users = mkIf (cfg.user == defaultUser) { - ${defaultUser} = - { - isSystemUser = true; - group = cfg.group; - description = "Webhook daemon user"; - }; + ${defaultUser} = { + isSystemUser = true; + group = cfg.group; + description = "Webhook daemon user"; + }; }; users.groups = mkIf (cfg.user == defaultUser && cfg.group == defaultUser) { - ${defaultUser} = {}; + ${defaultUser} = { }; }; networking.firewall.allowedTCPPorts = mkIf cfg.openFirewall [ cfg.port ]; @@ -195,15 +208,28 @@ in { after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; environment = config.networking.proxy.envVars // cfg.environment; - script = let - args = [ "-ip" cfg.ip "-port" (toString cfg.port) "-urlprefix" cfg.urlPrefix ] - ++ concatMap (hook: [ "-hooks" hook ]) hookFiles + script = + let + args = + [ + "-ip" + cfg.ip + "-port" + (toString cfg.port) + "-urlprefix" + cfg.urlPrefix + ] + ++ concatMap (hook: [ + "-hooks" + hook + ]) hookFiles ++ optional cfg.enableTemplates "-template" ++ optional cfg.verbose "-verbose" ++ cfg.extraArgs; - in '' - ${cfg.package}/bin/webhook ${escapeShellArgs args} - ''; + in + '' + ${cfg.package}/bin/webhook ${escapeShellArgs args} + ''; serviceConfig = { Restart = "on-failure"; User = cfg.user; diff --git a/nixos/modules/services/networking/websockify.nix b/nixos/modules/services/networking/websockify.nix index 41336000b0addc..c9219fc17d516f 100644 --- a/nixos/modules/services/networking/websockify.nix +++ b/nixos/modules/services/networking/websockify.nix @@ -1,8 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; -let cfg = config.services.networking.websockify; in { +let + cfg = config.services.networking.websockify; +in +{ options = { services.networking.websockify = { enable = mkOption { @@ -27,7 +35,7 @@ let cfg = config.services.networking.websockify; in { portMap = mkOption { description = "Ports to map by default."; - default = {}; + default = { }; type = types.attrsOf types.int; }; }; diff --git a/nixos/modules/services/networking/wg-access-server.nix b/nixos/modules/services/networking/wg-access-server.nix index cd05cd06154fa7..a0777fd86e3089 100644 --- a/nixos/modules/services/networking/wg-access-server.nix +++ b/nixos/modules/services/networking/wg-access-server.nix @@ -1,6 +1,16 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let - inherit (lib) mkEnableOption mkPackageOption mkOption types; + inherit (lib) + mkEnableOption + mkPackageOption + mkOption + types + ; cfg = config.services.wg-access-server; @@ -60,20 +70,33 @@ in config = lib.mkIf cfg.enable { assertions = map - (attrPath: - { - assertion = !lib.hasAttrByPath attrPath config.services.wg-access-server.settings; - message = '' - {option}`services.wg-access-server.settings.${lib.concatStringsSep "." attrPath}` must definded - in {option}`services.wg-access-server.secretsFile`. - ''; - }) + (attrPath: { + assertion = !lib.hasAttrByPath attrPath config.services.wg-access-server.settings; + message = '' + {option}`services.wg-access-server.settings.${lib.concatStringsSep "." attrPath}` must definded + in {option}`services.wg-access-server.secretsFile`. + ''; + }) [ [ "adminPassword" ] - [ "wireguard" "privateKey" ] - [ "auth" "sessionStore" ] - [ "auth" "oidc" "clientSecret" ] - [ "auth" "gitlab" "clientSecret" ] + [ + "wireguard" + "privateKey" + ] + [ + "auth" + "sessionStore" + ] + [ + "auth" + "oidc" + "clientSecret" + ] + [ + "auth" + "gitlab" + "clientSecret" + ] ]; boot.kernel.sysctl = { diff --git a/nixos/modules/services/networking/wg-netmanager.nix b/nixos/modules/services/networking/wg-netmanager.nix index 493ff7ceba9f11..eb13d35ccccbda 100644 --- a/nixos/modules/services/networking/wg-netmanager.nix +++ b/nixos/modules/services/networking/wg-netmanager.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -20,7 +25,11 @@ in description = "Wireguard network manager"; wantedBy = [ "multi-user.target" ]; after = [ "network.target" ]; - path = with pkgs; [ wireguard-tools iproute2 wireguard-go ]; + path = with pkgs; [ + wireguard-tools + iproute2 + wireguard-go + ]; serviceConfig = { Type = "simple"; Restart = "on-failure"; @@ -29,11 +38,14 @@ in ExecStop = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; ReadWritePaths = [ - "/tmp" # wg-netmanager creates files in /tmp before deleting them after use + "/tmp" # wg-netmanager creates files in /tmp before deleting them after use ]; }; - unitConfig = { - ConditionPathExists = ["/etc/wg_netmanager/network.yaml" "/etc/wg_netmanager/peer.yaml"]; + unitConfig = { + ConditionPathExists = [ + "/etc/wg_netmanager/network.yaml" + "/etc/wg_netmanager/peer.yaml" + ]; }; }; }; diff --git a/nixos/modules/services/networking/wgautomesh.nix b/nixos/modules/services/networking/wgautomesh.nix index c66e3e376343e0..4eb0d3ba418dd8 100644 --- a/nixos/modules/services/networking/wgautomesh.nix +++ b/nixos/modules/services/networking/wgautomesh.nix @@ -1,4 +1,9 @@ -{ lib, config, pkgs, ... }: +{ + lib, + config, + pkgs, + ... +}: with lib; let cfg = config.services.wgautomesh; @@ -6,24 +11,25 @@ let configFile = # Have to remove nulls manually as TOML generator will not just skip key # if value is null - settingsFormat.generate "wgautomesh-config.toml" - (filterAttrs (k: v: v != null) - (mapAttrs - (k: v: - if k == "peers" - then map (e: filterAttrs (k: v: v != null) e) v - else v) - cfg.settings)); + settingsFormat.generate "wgautomesh-config.toml" ( + filterAttrs (k: v: v != null) ( + mapAttrs (k: v: if k == "peers" then map (e: filterAttrs (k: v: v != null) e) v else v) cfg.settings + ) + ); runtimeConfigFile = - if cfg.enableGossipEncryption - then "/run/wgautomesh/wgautomesh.toml" - else configFile; + if cfg.enableGossipEncryption then "/run/wgautomesh/wgautomesh.toml" else configFile; in { options.services.wgautomesh = { enable = mkEnableOption "the wgautomesh daemon"; logLevel = mkOption { - type = types.enum [ "trace" "debug" "info" "warn" "error" ]; + type = types.enum [ + "trace" + "debug" + "info" + "warn" + "error" + ]; default = "info"; description = "wgautomesh log level."; }; @@ -87,31 +93,33 @@ in ''; }; peers = mkOption { - type = types.listOf (types.submodule { - options = { - pubkey = mkOption { - type = types.str; - description = "Wireguard public key of this peer."; - }; - address = mkOption { - type = types.str; - description = '' - Wireguard address of this peer (a single IP address, multiple - addresses or address ranges are not supported). - ''; - example = "10.0.0.42"; - }; - endpoint = mkOption { - type = types.nullOr types.str; - description = '' - Bootstrap endpoint for connecting to this Wireguard peer if no - other address is known or none are working. - ''; - default = null; - example = "wgnode.mydomain.example:51820"; + type = types.listOf ( + types.submodule { + options = { + pubkey = mkOption { + type = types.str; + description = "Wireguard public key of this peer."; + }; + address = mkOption { + type = types.str; + description = '' + Wireguard address of this peer (a single IP address, multiple + addresses or address ranges are not supported). + ''; + example = "10.0.0.42"; + }; + endpoint = mkOption { + type = types.nullOr types.str; + description = '' + Bootstrap endpoint for connecting to this Wireguard peer if no + other address is known or none are working. + ''; + default = null; + example = "wgnode.mydomain.example:51820"; + }; }; - }; - }); + } + ); default = [ ]; description = "wgautomesh peer list."; }; @@ -131,7 +139,9 @@ in systemd.services.wgautomesh = { path = [ pkgs.wireguard-tools ]; - environment = { RUST_LOG = "wgautomesh=${cfg.logLevel}"; }; + environment = { + RUST_LOG = "wgautomesh=${cfg.logLevel}"; + }; description = "wgautomesh"; serviceConfig = { Type = "simple"; @@ -142,9 +152,10 @@ in LoadCredential = mkIf cfg.enableGossipEncryption [ "gossip_secret:${cfg.gossipSecretFile}" ]; ExecStartPre = mkIf cfg.enableGossipEncryption [ - ''${pkgs.envsubst}/bin/envsubst \ - -i ${configFile} \ - -o ${runtimeConfigFile}'' + '' + ${pkgs.envsubst}/bin/envsubst \ + -i ${configFile} \ + -o ${runtimeConfigFile}'' ]; DynamicUser = true; @@ -156,8 +167,6 @@ in }; wantedBy = [ "multi-user.target" ]; }; - networking.firewall.allowedUDPPorts = - mkIf cfg.openFirewall [ cfg.settings.gossip_port ]; + networking.firewall.allowedUDPPorts = mkIf cfg.openFirewall [ cfg.settings.gossip_port ]; }; } - diff --git a/nixos/modules/services/networking/wpa_supplicant.nix b/nixos/modules/services/networking/wpa_supplicant.nix index 4fec023a23684f..536aebe4931c4f 100644 --- a/nixos/modules/services/networking/wpa_supplicant.nix +++ b/nixos/modules/services/networking/wpa_supplicant.nix @@ -1,4 +1,11 @@ -{ config, lib, options, pkgs, utils, ... }: +{ + config, + lib, + options, + pkgs, + utils, + ... +}: with lib; @@ -6,93 +13,109 @@ let cfg = config.networking.wireless; opt = options.networking.wireless; - wpa3Protocols = [ "SAE" "FT-SAE" ]; - hasMixedWPA = opts: + wpa3Protocols = [ + "SAE" + "FT-SAE" + ]; + hasMixedWPA = + opts: let hasWPA3 = !mutuallyExclusive opts.authProtocols wpa3Protocols; others = subtractLists wpa3Protocols opts.authProtocols; - in hasWPA3 && others != []; + in + hasWPA3 && others != [ ]; # Gives a WPA3 network higher priority - increaseWPA3Priority = opts: - opts // optionalAttrs (hasMixedWPA opts) - { priority = if opts.priority == null - then 1 - else opts.priority + 1; - }; + increaseWPA3Priority = + opts: + opts + // optionalAttrs (hasMixedWPA opts) { + priority = if opts.priority == null then 1 else opts.priority + 1; + }; # Creates a WPA2 fallback network - mkWPA2Fallback = opts: - opts // { authProtocols = subtractLists wpa3Protocols opts.authProtocols; }; + mkWPA2Fallback = opts: opts // { authProtocols = subtractLists wpa3Protocols opts.authProtocols; }; # Networks attrset as a list - networkList = mapAttrsToList (ssid: opts: opts // { inherit ssid; }) - cfg.networks; + networkList = mapAttrsToList (ssid: opts: opts // { inherit ssid; }) cfg.networks; # List of all networks (normal + generated fallbacks) allNetworks = - if cfg.fallbackToWPA2 - then map increaseWPA3Priority networkList - ++ map mkWPA2Fallback (filter hasMixedWPA networkList) - else networkList; + if cfg.fallbackToWPA2 then + map increaseWPA3Priority networkList ++ map mkWPA2Fallback (filter hasMixedWPA networkList) + else + networkList; # Content of wpa_supplicant.conf generatedConfig = concatStringsSep "\n" ( (map mkNetwork allNetworks) - ++ optional cfg.userControlled.enable (concatStringsSep "\n" - [ "ctrl_interface=/run/wpa_supplicant" + ++ optional cfg.userControlled.enable ( + concatStringsSep "\n" [ + "ctrl_interface=/run/wpa_supplicant" "ctrl_interface_group=${cfg.userControlled.group}" "update_config=1" - ]) + ] + ) ++ [ "pmf=1" ] - ++ optional (cfg.secretsFile != null) - "ext_password_backend=file:${cfg.secretsFile}" + ++ optional (cfg.secretsFile != null) "ext_password_backend=file:${cfg.secretsFile}" ++ optional cfg.scanOnLowSignal ''bgscan="simple:30:-70:3600"'' - ++ optional (cfg.extraConfig != "") cfg.extraConfig); + ++ optional (cfg.extraConfig != "") cfg.extraConfig + ); - configIsGenerated = with cfg; - networks != {} || extraConfig != "" || userControlled.enable; + configIsGenerated = with cfg; networks != { } || extraConfig != "" || userControlled.enable; # the original configuration file configFile = - if configIsGenerated - then pkgs.writeText "wpa_supplicant.conf" generatedConfig - else "/etc/wpa_supplicant.conf"; + if configIsGenerated then + pkgs.writeText "wpa_supplicant.conf" generatedConfig + else + "/etc/wpa_supplicant.conf"; # Creates a network block for wpa_supplicant.conf - mkNetwork = opts: - let - quote = x: ''"${x}"''; - indent = x: " " + x; - - pskString = if opts.psk != null - then quote opts.psk - else opts.pskRaw; - - options = [ - "ssid=${quote opts.ssid}" - (if pskString != null || opts.auth != null - then "key_mgmt=${concatStringsSep " " opts.authProtocols}" - else "key_mgmt=NONE") - ] ++ optional opts.hidden "scan_ssid=1" - ++ optional (pskString != null) "psk=${pskString}" - ++ optionals (opts.auth != null) (filter (x: x != "") (splitString "\n" opts.auth)) - ++ optional (opts.priority != null) "priority=${toString opts.priority}" - ++ optional (opts.extraConfig != "") opts.extraConfig; - in '' - network={ - ${concatMapStringsSep "\n" indent options} - } - ''; + mkNetwork = + opts: + let + quote = x: ''"${x}"''; + indent = x: " " + x; + + pskString = if opts.psk != null then quote opts.psk else opts.pskRaw; + + options = + [ + "ssid=${quote opts.ssid}" + ( + if pskString != null || opts.auth != null then + "key_mgmt=${concatStringsSep " " opts.authProtocols}" + else + "key_mgmt=NONE" + ) + ] + ++ optional opts.hidden "scan_ssid=1" + ++ optional (pskString != null) "psk=${pskString}" + ++ optionals (opts.auth != null) (filter (x: x != "") (splitString "\n" opts.auth)) + ++ optional (opts.priority != null) "priority=${toString opts.priority}" + ++ optional (opts.extraConfig != "") opts.extraConfig; + in + '' + network={ + ${concatMapStringsSep "\n" indent options} + } + ''; # Creates a systemd unit for wpa_supplicant bound to a given (or any) interface - mkUnit = iface: + mkUnit = + iface: let - deviceUnit = optional (iface != null) "sys-subsystem-net-devices-${utils.escapeSystemdPath iface}.device"; - configStr = if cfg.allowAuxiliaryImperativeNetworks - then "-c /etc/wpa_supplicant.conf -I ${configFile}" - else "-c ${configFile}"; - in { + deviceUnit = optional ( + iface != null + ) "sys-subsystem-net-devices-${utils.escapeSystemdPath iface}.device"; + configStr = + if cfg.allowAuxiliaryImperativeNetworks then + "-c /etc/wpa_supplicant.conf -I ${configFile}" + else + "-c ${configFile}"; + in + { description = "WPA Supplicant instance" + optionalString (iface != null) " for interface ${iface}"; after = deviceUnit; @@ -110,8 +133,7 @@ let serviceConfig.RuntimeDirectory = "wpa_supplicant"; serviceConfig.RuntimeDirectoryMode = "700"; - script = - '' + script = '' ${optionalString (configIsGenerated && !cfg.allowAuxiliaryImperativeNetworks) '' if [ -f /etc/wpa_supplicant.conf ]; then echo >&2 "<3>/etc/wpa_supplicant.conf present but ignored. Generated ${configFile} is used instead." @@ -125,30 +147,35 @@ let iface_args="-s ${optionalString cfg.dbusControlled "-u"} -D${cfg.driver} ${configStr}" - ${if iface == null then '' - # detect interfaces automatically - - # check if there are no wireless interfaces - if ! find -H /sys/class/net/* -name wireless | grep -q .; then - # if so, wait until one appears - echo "Waiting for wireless interfaces" - grep -q '^ACTION=add' < <(stdbuf -oL -- udevadm monitor -s net/wlan -pu) - # Note: the above line has been carefully written: - # 1. The process substitution avoids udevadm hanging (after grep has quit) - # until it tries to write to the pipe again. Not even pipefail works here. - # 2. stdbuf is needed because udevadm output is buffered by default and grep - # may hang until more udev events enter the pipe. - fi - - # add any interface found to the daemon arguments - for name in $(find -H /sys/class/net/* -name wireless | cut -d/ -f 5); do - echo "Adding interface $name" - args+="''${args:+ -N} -i$name $iface_args" - done - '' else '' - # add known interface to the daemon arguments - args="-i${iface} $iface_args" - ''} + ${ + if iface == null then + '' + # detect interfaces automatically + + # check if there are no wireless interfaces + if ! find -H /sys/class/net/* -name wireless | grep -q .; then + # if so, wait until one appears + echo "Waiting for wireless interfaces" + grep -q '^ACTION=add' < <(stdbuf -oL -- udevadm monitor -s net/wlan -pu) + # Note: the above line has been carefully written: + # 1. The process substitution avoids udevadm hanging (after grep has quit) + # until it tries to write to the pipe again. Not even pipefail works here. + # 2. stdbuf is needed because udevadm output is buffered by default and grep + # may hang until more udev events enter the pipe. + fi + + # add any interface found to the daemon arguments + for name in $(find -H /sys/class/net/* -name wireless | cut -d/ -f 5); do + echo "Adding interface $name" + args+="''${args:+ -N} -i$name $iface_args" + done + '' + else + '' + # add known interface to the daemon arguments + args="-i${iface} $iface_args" + '' + } # finally start daemon exec wpa_supplicant $args @@ -157,15 +184,19 @@ let systemctl = "/run/current-system/systemd/bin/systemctl"; -in { +in +{ options = { networking.wireless = { enable = mkEnableOption "wpa_supplicant"; interfaces = mkOption { type = types.listOf types.str; - default = []; - example = [ "wlan0" "wlan1" ]; + default = [ ]; + example = [ + "wlan0" + "wlan1" + ]; description = '' The interfaces {command}`wpa_supplicant` will use. If empty, it will automatically use all wireless interfaces. @@ -182,15 +213,17 @@ in { description = "Force a specific wpa_supplicant driver."; }; - allowAuxiliaryImperativeNetworks = mkEnableOption "support for imperative & declarative networks" // { - description = '' - Whether to allow configuring networks "imperatively" (e.g. via - `wpa_supplicant_gui`) and declaratively via - [](#opt-networking.wireless.networks). + allowAuxiliaryImperativeNetworks = + mkEnableOption "support for imperative & declarative networks" + // { + description = '' + Whether to allow configuring networks "imperatively" (e.g. via + `wpa_supplicant_gui`) and declaratively via + [](#opt-networking.wireless.networks). - Please note that this adds a custom patch to `wpa_supplicant`. - ''; - }; + Please note that this adds a custom patch to `wpa_supplicant`. + ''; + }; scanOnLowSignal = mkOption { type = types.bool; @@ -249,172 +282,179 @@ in { }; networks = mkOption { - type = types.attrsOf (types.submodule { - options = { - psk = mkOption { - type = types.nullOr (types.strMatching "[[:print:]]{8,63}"); - default = null; - description = '' - The network's pre-shared key in plaintext defaulting - to being a network without any authentication. - - ::: {.warning} - Be aware that this will be written to the Nix store - in plaintext! Use {var}`pskRaw` with an external - reference to keep it safe. - ::: - - ::: {.note} - Mutually exclusive with {var}`pskRaw`. - ::: - ''; - }; + type = types.attrsOf ( + types.submodule { + options = { + psk = mkOption { + type = types.nullOr (types.strMatching "[[:print:]]{8,63}"); + default = null; + description = '' + The network's pre-shared key in plaintext defaulting + to being a network without any authentication. + + ::: {.warning} + Be aware that this will be written to the Nix store + in plaintext! Use {var}`pskRaw` with an external + reference to keep it safe. + ::: + + ::: {.note} + Mutually exclusive with {var}`pskRaw`. + ::: + ''; + }; + + pskRaw = mkOption { + type = types.nullOr (types.strMatching "([[:xdigit:]]{64})|(ext:[^=]+)"); + default = null; + example = "ext:name_of_the_secret_here"; + description = '' + Either the raw pre-shared key in hexadecimal format + or the name of the secret (as defined inside + [](#opt-networking.wireless.secretsFile) and prefixed + with `ext:`) containing the network pre-shared key. + + ::: {.warning} + Be aware that this will be written to the Nix store + in plaintext! Always use an external reference. + ::: + + ::: {.note} + The external secret can be either the plaintext + passphrase or the raw pre-shared key. + ::: + + ::: {.note} + Mutually exclusive with {var}`psk` and {var}`auth`. + ::: + ''; + }; + + authProtocols = mkOption { + default = [ + # WPA2 and WPA3 + "WPA-PSK" + "WPA-EAP" + "SAE" + # 802.11r variants of the above + "FT-PSK" + "FT-EAP" + "FT-SAE" + ]; + # The list can be obtained by running this command + # awk ' + # /^# key_mgmt: /{ run=1 } + # /^#$/{ run=0 } + # /^# [A-Z0-9-]{2,}/{ if(run){printf("\"%s\"\n", $2)} } + # ' /run/current-system/sw/share/doc/wpa_supplicant/wpa_supplicant.conf.example + type = types.listOf ( + types.enum [ + "WPA-PSK" + "WPA-EAP" + "IEEE8021X" + "NONE" + "WPA-NONE" + "FT-PSK" + "FT-EAP" + "FT-EAP-SHA384" + "WPA-PSK-SHA256" + "WPA-EAP-SHA256" + "SAE" + "FT-SAE" + "WPA-EAP-SUITE-B" + "WPA-EAP-SUITE-B-192" + "OSEN" + "FILS-SHA256" + "FILS-SHA384" + "FT-FILS-SHA256" + "FT-FILS-SHA384" + "OWE" + "DPP" + ] + ); + description = '' + The list of authentication protocols accepted by this network. + This corresponds to the `key_mgmt` option in wpa_supplicant. + ''; + }; + + auth = mkOption { + type = types.nullOr types.str; + default = null; + example = '' + eap=PEAP + identity="user@example.com" + password=ext:example_password + ''; + description = '' + Use this option to configure advanced authentication methods + like EAP. See {manpage}`wpa_supplicant.conf(5)` for example + configurations. + + ::: {.warning} + Be aware that this will be written to the Nix store + in plaintext! Use an external reference like + `ext:secretname` for secrets. + ::: + + ::: {.note} + Mutually exclusive with {var}`psk` and {var}`pskRaw`. + ::: + ''; + }; + + hidden = mkOption { + type = types.bool; + default = false; + description = '' + Set this to `true` if the SSID of the network is hidden. + ''; + example = literalExpression '' + { echelon = { + hidden = true; + psk = "abcdefgh"; + }; + } + ''; + }; + + priority = mkOption { + type = types.nullOr types.int; + default = null; + description = '' + By default, all networks will get same priority group (0). If + some of the networks are more desirable, this field can be used + to change the order in which wpa_supplicant goes through the + networks when selecting a BSS. The priority groups will be + iterated in decreasing priority (i.e., the larger the priority + value, the sooner the network is matched against the scan + results). Within each priority group, networks will be selected + based on security policy, signal strength, etc. + ''; + }; + + extraConfig = mkOption { + type = types.str; + default = ""; + example = '' + bssid_blacklist=02:11:22:33:44:55 02:22:aa:44:55:66 + ''; + description = '' + Extra configuration lines appended to the network block. + See {manpage}`wpa_supplicant.conf(5)` for available options. + ''; + }; - pskRaw = mkOption { - type = types.nullOr - (types.strMatching "([[:xdigit:]]{64})|(ext:[^=]+)"); - default = null; - example = "ext:name_of_the_secret_here"; - description = '' - Either the raw pre-shared key in hexadecimal format - or the name of the secret (as defined inside - [](#opt-networking.wireless.secretsFile) and prefixed - with `ext:`) containing the network pre-shared key. - - ::: {.warning} - Be aware that this will be written to the Nix store - in plaintext! Always use an external reference. - ::: - - ::: {.note} - The external secret can be either the plaintext - passphrase or the raw pre-shared key. - ::: - - ::: {.note} - Mutually exclusive with {var}`psk` and {var}`auth`. - ::: - ''; }; - - authProtocols = mkOption { - default = [ - # WPA2 and WPA3 - "WPA-PSK" "WPA-EAP" "SAE" - # 802.11r variants of the above - "FT-PSK" "FT-EAP" "FT-SAE" - ]; - # The list can be obtained by running this command - # awk ' - # /^# key_mgmt: /{ run=1 } - # /^#$/{ run=0 } - # /^# [A-Z0-9-]{2,}/{ if(run){printf("\"%s\"\n", $2)} } - # ' /run/current-system/sw/share/doc/wpa_supplicant/wpa_supplicant.conf.example - type = types.listOf (types.enum [ - "WPA-PSK" - "WPA-EAP" - "IEEE8021X" - "NONE" - "WPA-NONE" - "FT-PSK" - "FT-EAP" - "FT-EAP-SHA384" - "WPA-PSK-SHA256" - "WPA-EAP-SHA256" - "SAE" - "FT-SAE" - "WPA-EAP-SUITE-B" - "WPA-EAP-SUITE-B-192" - "OSEN" - "FILS-SHA256" - "FILS-SHA384" - "FT-FILS-SHA256" - "FT-FILS-SHA384" - "OWE" - "DPP" - ]); - description = '' - The list of authentication protocols accepted by this network. - This corresponds to the `key_mgmt` option in wpa_supplicant. - ''; - }; - - auth = mkOption { - type = types.nullOr types.str; - default = null; - example = '' - eap=PEAP - identity="user@example.com" - password=ext:example_password - ''; - description = '' - Use this option to configure advanced authentication methods - like EAP. See {manpage}`wpa_supplicant.conf(5)` for example - configurations. - - ::: {.warning} - Be aware that this will be written to the Nix store - in plaintext! Use an external reference like - `ext:secretname` for secrets. - ::: - - ::: {.note} - Mutually exclusive with {var}`psk` and {var}`pskRaw`. - ::: - ''; - }; - - hidden = mkOption { - type = types.bool; - default = false; - description = '' - Set this to `true` if the SSID of the network is hidden. - ''; - example = literalExpression '' - { echelon = { - hidden = true; - psk = "abcdefgh"; - }; - } - ''; - }; - - priority = mkOption { - type = types.nullOr types.int; - default = null; - description = '' - By default, all networks will get same priority group (0). If - some of the networks are more desirable, this field can be used - to change the order in which wpa_supplicant goes through the - networks when selecting a BSS. The priority groups will be - iterated in decreasing priority (i.e., the larger the priority - value, the sooner the network is matched against the scan - results). Within each priority group, networks will be selected - based on security policy, signal strength, etc. - ''; - }; - - extraConfig = mkOption { - type = types.str; - default = ""; - example = '' - bssid_blacklist=02:11:22:33:44:55 02:22:aa:44:55:66 - ''; - description = '' - Extra configuration lines appended to the network block. - See {manpage}`wpa_supplicant.conf(5)` for available options. - ''; - }; - - }; - }); + } + ); description = '' The network definitions to automatically connect to when {command}`wpa_supplicant` is running. If this parameter is left empty wpa_supplicant will use /etc/wpa_supplicant.conf as the configuration file. ''; - default = {}; + default = { }; example = literalExpression '' { echelon = { # SSID with no spaces or special characters psk = "abcdefgh"; # (password will be written to /nix/store!) @@ -483,8 +523,7 @@ in { }; imports = [ - (mkRemovedOptionModule [ "networking" "wireless" "environmentFile" ] - '' + (mkRemovedOptionModule [ "networking" "wireless" "environmentFile" ] '' Secrets are now handled by the `networking.wireless.secretsFile` and `networking.wireless.networks..pskRaw` options. The change is motivated by a mechanism recently added by wpa_supplicant @@ -508,26 +547,44 @@ in { ]; config = mkIf cfg.enable { - assertions = flip mapAttrsToList cfg.networks (name: cfg: { - assertion = with cfg; count (x: x != null) [ psk pskRaw auth ] <= 1; - message = ''options networking.wireless."${name}".{psk,pskRaw,auth} are mutually exclusive''; - }) ++ [ - { - assertion = length cfg.interfaces > 1 -> !cfg.dbusControlled; - message = - let daemon = if config.networking.networkmanager.enable then "NetworkManager" else - if config.services.connman.enable then "connman" else null; + assertions = + flip mapAttrsToList cfg.networks ( + name: cfg: { + assertion = + with cfg; + count (x: x != null) [ + psk + pskRaw + auth + ] <= 1; + message = ''options networking.wireless."${name}".{psk,pskRaw,auth} are mutually exclusive''; + } + ) + ++ [ + { + assertion = length cfg.interfaces > 1 -> !cfg.dbusControlled; + message = + let + daemon = + if config.networking.networkmanager.enable then + "NetworkManager" + else if config.services.connman.enable then + "connman" + else + null; n = toString (length cfg.interfaces); - in '' - It's not possible to run multiple wpa_supplicant instances with DBus support. - Note: you're seeing this error because `networking.wireless.interfaces` has - ${n} entries, implying an equal number of wpa_supplicant instances. - '' + optionalString (daemon != null) '' - You don't need to change `networking.wireless.interfaces` when using ${daemon}: - in this case the interfaces will be configured automatically for you. - ''; - } - ]; + in + '' + It's not possible to run multiple wpa_supplicant instances with DBus support. + Note: you're seeing this error because `networking.wireless.interfaces` has + ${n} entries, implying an equal number of wpa_supplicant instances. + '' + + optionalString (daemon != null) '' + You don't need to change `networking.wireless.interfaces` when using ${daemon}: + in this case the interfaces will be configured automatically for you. + ''; + } + ]; hardware.wirelessRegulatoryDatabase = true; @@ -535,19 +592,20 @@ in { services.dbus.packages = optional cfg.dbusControlled pkgs.wpa_supplicant; systemd.services = - if cfg.interfaces == [] - then { wpa_supplicant = mkUnit null; } - else listToAttrs (map (i: nameValuePair "wpa_supplicant-${i}" (mkUnit i)) cfg.interfaces); + if cfg.interfaces == [ ] then + { wpa_supplicant = mkUnit null; } + else + listToAttrs (map (i: nameValuePair "wpa_supplicant-${i}" (mkUnit i)) cfg.interfaces); # Restart wpa_supplicant after resuming from sleep powerManagement.resumeCommands = concatStringsSep "\n" ( - optional (cfg.interfaces == []) "${systemctl} try-restart wpa_supplicant" + optional (cfg.interfaces == [ ]) "${systemctl} try-restart wpa_supplicant" ++ map (i: "${systemctl} try-restart wpa_supplicant-${i}") cfg.interfaces ); # Restart wpa_supplicant when a wlan device appears or disappears. This is # only needed when an interface hasn't been specified by the user. - services.udev.extraRules = optionalString (cfg.interfaces == []) '' + services.udev.extraRules = optionalString (cfg.interfaces == [ ]) '' ACTION=="add|remove", SUBSYSTEM=="net", ENV{DEVTYPE}=="wlan", \ RUN+="${systemctl} try-restart wpa_supplicant.service" ''; diff --git a/nixos/modules/services/networking/x2goserver.nix b/nixos/modules/services/networking/x2goserver.nix index e46a493924ef72..53e938d11554af 100644 --- a/nixos/modules/services/networking/x2goserver.nix +++ b/nixos/modules/services/networking/x2goserver.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,9 +11,11 @@ let cfg = config.services.x2goserver; defaults = { - superenicer = { enable = cfg.superenicer.enable; }; + superenicer = { + enable = cfg.superenicer.enable; + }; }; - confText = generators.toINI {} (recursiveUpdate defaults cfg.settings); + confText = generators.toINI { } (recursiveUpdate defaults cfg.settings); x2goServerConf = pkgs.writeText "x2goserver.conf" confText; x2goAgentOptions = pkgs.writeText "x2goagent.options" '' @@ -16,7 +23,8 @@ let X2GO_NXAGENT_DEFAULT_OPTIONS="${concatStringsSep " " cfg.nxagentDefaultOptions}" ''; -in { +in +{ imports = [ (mkRenamedOptionModule [ "programs" "x2goserver" ] [ "services" "x2goserver" ]) ]; @@ -41,7 +49,10 @@ in { nxagentDefaultOptions = mkOption { type = types.listOf types.str; - default = [ "-extension GLX" "-nolisten tcp" ]; + default = [ + "-extension GLX" + "-nolisten tcp" + ]; description = '' List of default nx agent options. ''; @@ -49,7 +60,7 @@ in { settings = mkOption { type = types.attrsOf types.attrs; - default = {}; + default = { }; description = '' x2goserver.conf ini configuration as nix attributes. See `x2goserver.conf(5)` for details @@ -78,7 +89,7 @@ in { environment.systemPackages = [ pkgs.x2goserver ]; - users.groups.x2go = {}; + users.groups.x2go = { }; users.users.x2go = { home = "/var/lib/x2go/db"; group = "x2go"; @@ -100,35 +111,61 @@ in { setgid = true; }; - systemd.tmpfiles.rules = with pkgs; [ - "d /var/lib/x2go/ - x2go x2go - -" - "d /var/lib/x2go/db - x2go x2go - -" - "d /var/lib/x2go/conf - x2go x2go - -" - "d /run/x2go 0755 x2go x2go - -" - ] ++ - # x2goclient sends SSH commands with preset PATH set to - # "/usr/local/bin;/usr/bin;/bin". Since we cannot filter arbitrary ssh - # commands, we have to make the following executables available. - map (f: "L+ /usr/local/bin/${f} - - - - ${x2goserver}/bin/${f}") [ - "x2goagent" "x2gobasepath" "x2gocleansessions" "x2gocmdexitmessage" - "x2godbadmin" "x2gofeature" "x2gofeaturelist" "x2gofm" "x2gogetapps" - "x2gogetservers" "x2golistdesktops" "x2golistmounts" "x2golistsessions" - "x2golistsessions_root" "x2golistshadowsessions" "x2gomountdirs" - "x2gopath" "x2goprint" "x2goresume-desktopsharing" "x2goresume-session" - "x2goruncommand" "x2goserver-run-extensions" "x2gosessionlimit" - "x2gosetkeyboard" "x2goshowblocks" "x2gostartagent" - "x2gosuspend-desktopsharing" "x2gosuspend-session" - "x2goterminate-desktopsharing" "x2goterminate-session" - "x2goumount-session" "x2goversion" - ] ++ [ - "L+ /usr/local/bin/awk - - - - ${gawk}/bin/awk" - "L+ /usr/local/bin/chmod - - - - ${coreutils}/bin/chmod" - "L+ /usr/local/bin/cp - - - - ${coreutils}/bin/cp" - "L+ /usr/local/bin/sed - - - - ${gnused}/bin/sed" - "L+ /usr/local/bin/setsid - - - - ${util-linux}/bin/setsid" - "L+ /usr/local/bin/xrandr - - - - ${xorg.xrandr}/bin/xrandr" - "L+ /usr/local/bin/xmodmap - - - - ${xorg.xmodmap}/bin/xmodmap" - ]; + systemd.tmpfiles.rules = + with pkgs; + [ + "d /var/lib/x2go/ - x2go x2go - -" + "d /var/lib/x2go/db - x2go x2go - -" + "d /var/lib/x2go/conf - x2go x2go - -" + "d /run/x2go 0755 x2go x2go - -" + ] + ++ + # x2goclient sends SSH commands with preset PATH set to + # "/usr/local/bin;/usr/bin;/bin". Since we cannot filter arbitrary ssh + # commands, we have to make the following executables available. + map (f: "L+ /usr/local/bin/${f} - - - - ${x2goserver}/bin/${f}") [ + "x2goagent" + "x2gobasepath" + "x2gocleansessions" + "x2gocmdexitmessage" + "x2godbadmin" + "x2gofeature" + "x2gofeaturelist" + "x2gofm" + "x2gogetapps" + "x2gogetservers" + "x2golistdesktops" + "x2golistmounts" + "x2golistsessions" + "x2golistsessions_root" + "x2golistshadowsessions" + "x2gomountdirs" + "x2gopath" + "x2goprint" + "x2goresume-desktopsharing" + "x2goresume-session" + "x2goruncommand" + "x2goserver-run-extensions" + "x2gosessionlimit" + "x2gosetkeyboard" + "x2goshowblocks" + "x2gostartagent" + "x2gosuspend-desktopsharing" + "x2gosuspend-session" + "x2goterminate-desktopsharing" + "x2goterminate-session" + "x2goumount-session" + "x2goversion" + ] + ++ [ + "L+ /usr/local/bin/awk - - - - ${gawk}/bin/awk" + "L+ /usr/local/bin/chmod - - - - ${coreutils}/bin/chmod" + "L+ /usr/local/bin/cp - - - - ${coreutils}/bin/cp" + "L+ /usr/local/bin/sed - - - - ${gnused}/bin/sed" + "L+ /usr/local/bin/setsid - - - - ${util-linux}/bin/setsid" + "L+ /usr/local/bin/xrandr - - - - ${xorg.xrandr}/bin/xrandr" + "L+ /usr/local/bin/xmodmap - - - - ${xorg.xmodmap}/bin/xmodmap" + ]; systemd.services.x2goserver = { description = "X2Go Server Daemon"; diff --git a/nixos/modules/services/networking/xandikos.nix b/nixos/modules/services/networking/xandikos.nix index e05fee1656cd0d..1b72cd03ba9cf8 100644 --- a/nixos/modules/services/networking/xandikos.nix +++ b/nixos/modules/services/networking/xandikos.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -38,7 +43,7 @@ in }; extraOptions = mkOption { - default = []; + default = [ ]; type = types.listOf types.str; example = literalExpression '' [ "--autocreate" @@ -53,7 +58,7 @@ in }; nginx = mkOption { - default = {}; + default = { }; description = '' Configuration for nginx reverse proxy. ''; @@ -82,62 +87,58 @@ in }; - config = mkIf cfg.enable ( - mkMerge [ - { - meta.maintainers = with lib.maintainers; [ _0x4A6F ]; - - systemd.services.xandikos = { - description = "A Simple Calendar and Contact Server"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - - serviceConfig = { - User = "xandikos"; - Group = "xandikos"; - DynamicUser = "yes"; - RuntimeDirectory = "xandikos"; - StateDirectory = "xandikos"; - StateDirectoryMode = "0700"; - PrivateDevices = true; - # Sandboxing - CapabilityBoundingSet = "CAP_NET_RAW CAP_NET_ADMIN"; - ProtectSystem = "strict"; - ProtectHome = true; - PrivateTmp = true; - ProtectKernelTunables = true; - ProtectKernelModules = true; - ProtectControlGroups = true; - RestrictAddressFamilies = "AF_INET AF_INET6 AF_UNIX AF_PACKET AF_NETLINK"; - RestrictNamespaces = true; - LockPersonality = true; - MemoryDenyWriteExecute = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - ExecStart = '' - ${cfg.package}/bin/xandikos \ - --directory /var/lib/xandikos \ - --listen-address ${cfg.address} \ - --port ${toString cfg.port} \ - --route-prefix ${cfg.routePrefix} \ - ${lib.concatStringsSep " " cfg.extraOptions} - ''; - }; + config = mkIf cfg.enable (mkMerge [ + { + meta.maintainers = with lib.maintainers; [ _0x4A6F ]; + + systemd.services.xandikos = { + description = "A Simple Calendar and Contact Server"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + + serviceConfig = { + User = "xandikos"; + Group = "xandikos"; + DynamicUser = "yes"; + RuntimeDirectory = "xandikos"; + StateDirectory = "xandikos"; + StateDirectoryMode = "0700"; + PrivateDevices = true; + # Sandboxing + CapabilityBoundingSet = "CAP_NET_RAW CAP_NET_ADMIN"; + ProtectSystem = "strict"; + ProtectHome = true; + PrivateTmp = true; + ProtectKernelTunables = true; + ProtectKernelModules = true; + ProtectControlGroups = true; + RestrictAddressFamilies = "AF_INET AF_INET6 AF_UNIX AF_PACKET AF_NETLINK"; + RestrictNamespaces = true; + LockPersonality = true; + MemoryDenyWriteExecute = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + ExecStart = '' + ${cfg.package}/bin/xandikos \ + --directory /var/lib/xandikos \ + --listen-address ${cfg.address} \ + --port ${toString cfg.port} \ + --route-prefix ${cfg.routePrefix} \ + ${lib.concatStringsSep " " cfg.extraOptions} + ''; }; - } - - ( - mkIf cfg.nginx.enable { - services.nginx = { - enable = true; - virtualHosts."${cfg.nginx.hostName}" = { - locations."/" = { - proxyPass = "http://${cfg.address}:${toString cfg.port}/"; - }; - }; + }; + } + + (mkIf cfg.nginx.enable { + services.nginx = { + enable = true; + virtualHosts."${cfg.nginx.hostName}" = { + locations."/" = { + proxyPass = "http://${cfg.address}:${toString cfg.port}/"; }; - } - ) - ] - ); + }; + }; + }) + ]); } diff --git a/nixos/modules/services/networking/xinetd.nix b/nixos/modules/services/networking/xinetd.nix index e42943285d125a..f5d4cbeffabb35 100644 --- a/nixos/modules/services/networking/xinetd.nix +++ b/nixos/modules/services/networking/xinetd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,35 +11,33 @@ let cfg = config.services.xinetd; - configFile = pkgs.writeText "xinetd.conf" - '' - defaults - { - log_type = SYSLOG daemon info - log_on_failure = HOST - log_on_success = PID HOST DURATION EXIT - ${cfg.extraDefaults} - } - - ${concatMapStrings makeService cfg.services} - ''; - - makeService = srv: - '' - service ${srv.name} - { - protocol = ${srv.protocol} - ${optionalString srv.unlisted "type = UNLISTED"} - ${optionalString (srv.flags != "") "flags = ${srv.flags}"} - socket_type = ${if srv.protocol == "udp" then "dgram" else "stream"} - ${optionalString (srv.port != 0) "port = ${toString srv.port}"} - wait = ${if srv.protocol == "udp" then "yes" else "no"} - user = ${srv.user} - server = ${srv.server} - ${optionalString (srv.serverArgs != "") "server_args = ${srv.serverArgs}"} - ${srv.extraConfig} - } - ''; + configFile = pkgs.writeText "xinetd.conf" '' + defaults + { + log_type = SYSLOG daemon info + log_on_failure = HOST + log_on_success = PID HOST DURATION EXIT + ${cfg.extraDefaults} + } + + ${concatMapStrings makeService cfg.services} + ''; + + makeService = srv: '' + service ${srv.name} + { + protocol = ${srv.protocol} + ${optionalString srv.unlisted "type = UNLISTED"} + ${optionalString (srv.flags != "") "flags = ${srv.flags}"} + socket_type = ${if srv.protocol == "udp" then "dgram" else "stream"} + ${optionalString (srv.port != 0) "port = ${toString srv.port}"} + wait = ${if srv.protocol == "udp" then "yes" else "no"} + user = ${srv.user} + server = ${srv.server} + ${optionalString (srv.serverArgs != "") "server_args = ${srv.serverArgs}"} + ${srv.extraConfig} + } + ''; in @@ -55,83 +58,84 @@ in }; services.xinetd.services = mkOption { - default = []; + default = [ ]; description = '' A list of services provided by xinetd. ''; - type = with types; listOf (submodule ({ - - options = { - - name = mkOption { - type = types.str; - example = "login"; - description = "Name of the service."; - }; - - protocol = mkOption { - type = types.str; - default = "tcp"; - description = "Protocol of the service. Usually `tcp` or `udp`."; - }; - - port = mkOption { - type = types.port; - default = 0; - example = 123; - description = "Port number of the service."; - }; - - user = mkOption { - type = types.str; - default = "nobody"; - description = "User account for the service"; - }; - - server = mkOption { - type = types.str; - example = "/foo/bin/ftpd"; - description = "Path of the program that implements the service."; - }; - - serverArgs = mkOption { - type = types.separatedString " "; - default = ""; - description = "Command-line arguments for the server program."; - }; - - flags = mkOption { - type = types.str; - default = ""; - description = ""; - }; - - unlisted = mkOption { - type = types.bool; - default = false; - description = '' - Whether this server is listed in - {file}`/etc/services`. If so, the port - number can be omitted. - ''; - }; + type = + with types; + listOf (submodule ({ + + options = { + + name = mkOption { + type = types.str; + example = "login"; + description = "Name of the service."; + }; + + protocol = mkOption { + type = types.str; + default = "tcp"; + description = "Protocol of the service. Usually `tcp` or `udp`."; + }; + + port = mkOption { + type = types.port; + default = 0; + example = 123; + description = "Port number of the service."; + }; + + user = mkOption { + type = types.str; + default = "nobody"; + description = "User account for the service"; + }; + + server = mkOption { + type = types.str; + example = "/foo/bin/ftpd"; + description = "Path of the program that implements the service."; + }; + + serverArgs = mkOption { + type = types.separatedString " "; + default = ""; + description = "Command-line arguments for the server program."; + }; + + flags = mkOption { + type = types.str; + default = ""; + description = ""; + }; + + unlisted = mkOption { + type = types.bool; + default = false; + description = '' + Whether this server is listed in + {file}`/etc/services`. If so, the port + number can be omitted. + ''; + }; + + extraConfig = mkOption { + type = types.lines; + default = ""; + description = "Extra configuration-lines added to the section of the service."; + }; - extraConfig = mkOption { - type = types.lines; - default = ""; - description = "Extra configuration-lines added to the section of the service."; }; - }; - - })); + })); }; }; - ###### implementation config = mkIf cfg.enable { diff --git a/nixos/modules/services/networking/xl2tpd.nix b/nixos/modules/services/networking/xl2tpd.nix index 4ecd3c54e41217..fd234cec03a6b4 100644 --- a/nixos/modules/services/networking/xl2tpd.nix +++ b/nixos/modules/services/networking/xl2tpd.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -8,28 +13,28 @@ with lib; enable = mkEnableOption "xl2tpd, the Layer 2 Tunnelling Protocol Daemon"; serverIp = mkOption { - type = types.str; + type = types.str; description = "The server-side IP address."; - default = "10.125.125.1"; + default = "10.125.125.1"; }; clientIpRange = mkOption { - type = types.str; + type = types.str; description = "The range from which client IPs are drawn."; - default = "10.125.125.2-11"; + default = "10.125.125.2-11"; }; extraXl2tpOptions = mkOption { - type = types.lines; + type = types.lines; description = "Adds extra lines to the xl2tpd configuration file."; - default = ""; + default = ""; }; extraPppdOptions = mkOption { - type = types.lines; + type = types.lines; description = "Adds extra lines to the pppd options file."; - default = ""; - example = '' + default = ""; + example = '' ms-dns 8.8.8.8 ms-dns 8.8.4.4 ''; @@ -38,93 +43,95 @@ with lib; }; config = mkIf config.services.xl2tpd.enable { - systemd.services.xl2tpd = let - cfg = config.services.xl2tpd; - - # Config files from https://help.ubuntu.com/community/L2TPServer - xl2tpd-conf = pkgs.writeText "xl2tpd.conf" '' - [global] - ipsec saref = no - - [lns default] - local ip = ${cfg.serverIp} - ip range = ${cfg.clientIpRange} - pppoptfile = ${pppd-options} - length bit = yes - - ; Extra - ${cfg.extraXl2tpOptions} - ''; - - pppd-options = pkgs.writeText "ppp-options-xl2tpd.conf" '' - refuse-pap - refuse-chap - refuse-mschap - require-mschap-v2 - # require-mppe-128 - asyncmap 0 - auth - crtscts - idle 1800 - mtu 1200 - mru 1200 - lock - hide-password - local - # debug - name xl2tpd - # proxyarp - lcp-echo-interval 30 - lcp-echo-failure 4 - - # Extra: - ${cfg.extraPppdOptions} - ''; - - xl2tpd-ppp-wrapped = pkgs.stdenv.mkDerivation { - name = "xl2tpd-ppp-wrapped"; - phases = [ "installPhase" ]; - nativeBuildInputs = with pkgs; [ makeWrapper ]; - installPhase = '' - mkdir -p $out/bin - - makeWrapper ${pkgs.ppp}/sbin/pppd $out/bin/pppd \ - --set LD_PRELOAD "${pkgs.libredirect}/lib/libredirect.so" \ - --set NIX_REDIRECTS "/etc/ppp=/etc/xl2tpd/ppp" - - makeWrapper ${pkgs.xl2tpd}/bin/xl2tpd $out/bin/xl2tpd \ - --set LD_PRELOAD "${pkgs.libredirect}/lib/libredirect.so" \ - --set NIX_REDIRECTS "${pkgs.ppp}/sbin/pppd=$out/bin/pppd" + systemd.services.xl2tpd = + let + cfg = config.services.xl2tpd; + + # Config files from https://help.ubuntu.com/community/L2TPServer + xl2tpd-conf = pkgs.writeText "xl2tpd.conf" '' + [global] + ipsec saref = no + + [lns default] + local ip = ${cfg.serverIp} + ip range = ${cfg.clientIpRange} + pppoptfile = ${pppd-options} + length bit = yes + + ; Extra + ${cfg.extraXl2tpOptions} ''; - }; - in { - description = "xl2tpd server"; - - requires = [ "network-online.target" ]; - wantedBy = [ "multi-user.target" ]; - - preStart = '' - install -m 700 -d /etc/xl2tpd/ppp - [ -f /etc/xl2tpd/ppp/chap-secrets ] || install -m 600 -o root -g root /dev/stdin /etc/xl2tpd/ppp/chap-secrets < /tmp/cronout 2>&1" "* * * * * eelco echo Hello World > /home/eelco/cronout" @@ -75,7 +79,7 @@ in cronFiles = mkOption { type = types.listOf types.path; - default = []; + default = [ ]; description = '' A list of extra crontab files that will be read and appended to the main crontab file when the cron service starts. @@ -86,50 +90,53 @@ in }; - ###### implementation config = mkMerge [ - { services.cron.enable = mkDefault (allFiles != []); } + { services.cron.enable = mkDefault (allFiles != [ ]); } (mkIf (config.services.cron.enable) { - security.wrappers.crontab = - { setuid = true; - owner = "root"; - group = "root"; - source = "${cronNixosPkg}/bin/crontab"; - }; + security.wrappers.crontab = { + setuid = true; + owner = "root"; + group = "root"; + source = "${cronNixosPkg}/bin/crontab"; + }; environment.systemPackages = [ cronNixosPkg ]; - environment.etc.crontab = - { source = pkgs.runCommand "crontabs" { inherit allFiles; preferLocalBuild = true; } + environment.etc.crontab = { + source = + pkgs.runCommand "crontabs" + { + inherit allFiles; + preferLocalBuild = true; + } '' touch $out for i in $allFiles; do cat "$i" >> $out done ''; - mode = "0600"; # Cron requires this. - }; + mode = "0600"; # Cron requires this. + }; - systemd.services.cron = - { description = "Cron Daemon"; + systemd.services.cron = { + description = "Cron Daemon"; - wantedBy = [ "multi-user.target" ]; + wantedBy = [ "multi-user.target" ]; - preStart = - '' - mkdir -m 710 -p /var/cron + preStart = '' + mkdir -m 710 -p /var/cron - # By default, allow all users to create a crontab. This - # is denoted by the existence of an empty cron.deny file. - if ! test -e /var/cron/cron.allow -o -e /var/cron/cron.deny; then - touch /var/cron/cron.deny - fi - ''; + # By default, allow all users to create a crontab. This + # is denoted by the existence of an empty cron.deny file. + if ! test -e /var/cron/cron.allow -o -e /var/cron/cron.deny; then + touch /var/cron/cron.deny + fi + ''; - restartTriggers = [ config.time.timeZone ]; - serviceConfig.ExecStart = "${cronNixosPkg}/bin/cron -n"; - }; + restartTriggers = [ config.time.timeZone ]; + serviceConfig.ExecStart = "${cronNixosPkg}/bin/cron -n"; + }; }) diff --git a/nixos/modules/services/scheduling/fcron.nix b/nixos/modules/services/scheduling/fcron.nix index db627841526e2c..9beebb6dba6c15 100644 --- a/nixos/modules/services/scheduling/fcron.nix +++ b/nixos/modules/services/scheduling/fcron.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -9,23 +14,22 @@ let queuelen = optionalString (cfg.queuelen != null) "-q ${toString cfg.queuelen}"; # Duplicate code, also found in cron.nix. Needs deduplication. - systemCronJobs = - '' - SHELL=${pkgs.bash}/bin/bash - PATH=${config.system.path}/bin:${config.system.path}/sbin - ${optionalString (config.services.cron.mailto != null) '' - MAILTO="${config.services.cron.mailto}" - ''} - NIX_CONF_DIR=/etc/nix - ${lib.concatStrings (map (job: job + "\n") config.services.cron.systemCronJobs)} - ''; - - allowdeny = target: users: - { source = pkgs.writeText "fcron.${target}" (concatStringsSep "\n" users); - target = "fcron.${target}"; - mode = "644"; - gid = config.ids.gids.fcron; - }; + systemCronJobs = '' + SHELL=${pkgs.bash}/bin/bash + PATH=${config.system.path}/bin:${config.system.path}/sbin + ${optionalString (config.services.cron.mailto != null) '' + MAILTO="${config.services.cron.mailto}" + ''} + NIX_CONF_DIR=/etc/nix + ${lib.concatStrings (map (job: job + "\n") config.services.cron.systemCronJobs)} + ''; + + allowdeny = target: users: { + source = pkgs.writeText "fcron.${target}" (concatStringsSep "\n" users); + target = "fcron.${target}"; + mode = "644"; + gid = config.ids.gids.fcron; + }; in @@ -54,7 +58,7 @@ in deny = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = "Users forbidden from using fcron."; }; @@ -79,41 +83,45 @@ in }; - ###### implementation config = mkIf cfg.enable { services.fcron.systab = systemCronJobs; - environment.etc = listToAttrs - (map (x: { name = x.target; value = x; }) - [ (allowdeny "allow" (cfg.allow)) - (allowdeny "deny" cfg.deny) - # see man 5 fcron.conf - { source = - let - isSendmailWrapped = - lib.hasAttr "sendmail" config.security.wrappers; - sendmailPath = - if isSendmailWrapped then "/run/wrappers/bin/sendmail" - else "${config.system.path}/bin/sendmail"; - in - pkgs.writeText "fcron.conf" '' - fcrontabs = /var/spool/fcron - pidfile = /run/fcron.pid - fifofile = /run/fcron.fifo - fcronallow = /etc/fcron.allow - fcrondeny = /etc/fcron.deny - shell = /bin/sh - sendmail = ${sendmailPath} - editor = ${pkgs.vim}/bin/vim - ''; - target = "fcron.conf"; - gid = config.ids.gids.fcron; - mode = "0644"; - } - ]); + environment.etc = listToAttrs ( + map + (x: { + name = x.target; + value = x; + }) + [ + (allowdeny "allow" (cfg.allow)) + (allowdeny "deny" cfg.deny) + # see man 5 fcron.conf + { + source = + let + isSendmailWrapped = lib.hasAttr "sendmail" config.security.wrappers; + sendmailPath = + if isSendmailWrapped then "/run/wrappers/bin/sendmail" else "${config.system.path}/bin/sendmail"; + in + pkgs.writeText "fcron.conf" '' + fcrontabs = /var/spool/fcron + pidfile = /run/fcron.pid + fifofile = /run/fcron.fifo + fcronallow = /etc/fcron.allow + fcrondeny = /etc/fcron.deny + shell = /bin/sh + sendmail = ${sendmailPath} + editor = ${pkgs.vim}/bin/vim + ''; + target = "fcron.conf"; + gid = config.ids.gids.fcron; + mode = "0644"; + } + ] + ); environment.systemPackages = [ pkgs.fcron ]; users.users.fcron = { diff --git a/nixos/modules/services/search/elasticsearch-curator.nix b/nixos/modules/services/search/elasticsearch-curator.nix index 1c365124a0ef8f..38d33ee82bbb61 100644 --- a/nixos/modules/services/search/elasticsearch-curator.nix +++ b/nixos/modules/services/search/elasticsearch-curator.nix @@ -1,39 +1,45 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let - cfg = config.services.elasticsearch-curator; - curatorConfig = pkgs.writeTextFile { - name = "config.yaml"; - text = '' - --- - # Remember, leave a key empty if there is no value. None will be a string, - # not a Python "NoneType" - client: - hosts: ${builtins.toJSON cfg.hosts} - port: ${toString cfg.port} - url_prefix: - use_ssl: False - certificate: - client_cert: - client_key: - ssl_no_validate: False - http_auth: - timeout: 30 - master_only: False - logging: - loglevel: INFO - logfile: - logformat: default - blacklist: ['elasticsearch', 'urllib3'] - ''; - }; - curatorAction = pkgs.writeTextFile { - name = "action.yaml"; - text = cfg.actionYAML; - }; -in { + cfg = config.services.elasticsearch-curator; + curatorConfig = pkgs.writeTextFile { + name = "config.yaml"; + text = '' + --- + # Remember, leave a key empty if there is no value. None will be a string, + # not a Python "NoneType" + client: + hosts: ${builtins.toJSON cfg.hosts} + port: ${toString cfg.port} + url_prefix: + use_ssl: False + certificate: + client_cert: + client_key: + ssl_no_validate: False + http_auth: + timeout: 30 + master_only: False + logging: + loglevel: INFO + logfile: + logformat: default + blacklist: ['elasticsearch', 'urllib3'] + ''; + }; + curatorAction = pkgs.writeTextFile { + name = "action.yaml"; + text = cfg.actionYAML; + }; +in +{ options.services.elasticsearch-curator = { @@ -46,7 +52,7 @@ in { hosts = mkOption { description = "a list of elasticsearch hosts to connect to"; type = types.listOf types.str; - default = ["localhost"]; + default = [ "localhost" ]; }; port = mkOption { description = "the port that elasticsearch is listening on"; @@ -87,8 +93,7 @@ in { startAt = cfg.interval; serviceConfig = { ExecStart = - "${pkgs.elasticsearch-curator}/bin/curator" + - " --config ${curatorConfig} ${curatorAction}"; + "${pkgs.elasticsearch-curator}/bin/curator" + " --config ${curatorConfig} ${curatorAction}"; }; }; }; diff --git a/nixos/modules/services/search/elasticsearch.nix b/nixos/modules/services/search/elasticsearch.nix index db19e47493a6a1..c7f21236e0fdaa 100644 --- a/nixos/modules/services/search/elasticsearch.nix +++ b/nixos/modules/services/search/elasticsearch.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -138,7 +143,7 @@ in example = lib.literalExpression "[ pkgs.elasticsearchPlugins.discovery-ec2 ]"; }; - restartIfChanged = mkOption { + restartIfChanged = mkOption { type = types.bool; description = '' Automatically restart the service on config change. diff --git a/nixos/modules/services/search/hound.nix b/nixos/modules/services/search/hound.nix index 7aca1adc19b082..33ade1b963b4a8 100644 --- a/nixos/modules/services/search/hound.nix +++ b/nixos/modules/services/search/hound.nix @@ -1,11 +1,23 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hound; settingsFormat = pkgs.formats.json { }; -in { +in +{ imports = [ - (lib.mkRemovedOptionModule [ "services" "hound" "extraGroups" ] "Use users.users.hound.extraGroups instead") - (lib.mkChangedOptionModule [ "services" "hound" "config" ] [ "services" "hound" "settings" ] (config: builtins.fromJSON config.services.hound.config)) + (lib.mkRemovedOptionModule [ + "services" + "hound" + "extraGroups" + ] "Use users.users.hound.extraGroups instead") + (lib.mkChangedOptionModule [ "services" "hound" "config" ] [ "services" "hound" "settings" ] ( + config: builtins.fromJSON config.services.hound.config + )) ]; meta.maintainers = with lib.maintainers; [ SuperSandro2000 ]; diff --git a/nixos/modules/services/search/manticore.nix b/nixos/modules/services/search/manticore.nix index 885bfc3df52132..76cb16bee0d130 100644 --- a/nixos/modules/services/search/manticore.nix +++ b/nixos/modules/services/search/manticore.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -7,29 +12,36 @@ let cfg = config.services.manticore; format = pkgs.formats.json { }; - toSphinx = { - mkKeyValue ? generators.mkKeyValueDefault {} "=", - listsAsDuplicateKeys ? true - }: attrsOfAttrs: + toSphinx = + { + mkKeyValue ? generators.mkKeyValueDefault { } "=", + listsAsDuplicateKeys ? true, + }: + attrsOfAttrs: let - # map function to string for each key val - mapAttrsToStringsSep = sep: mapFn: attrs: - concatStringsSep sep - (mapAttrsToList mapFn attrs); - mkSection = sectName: sectValues: '' + # map function to string for each key val + mapAttrsToStringsSep = + sep: mapFn: attrs: + concatStringsSep sep (mapAttrsToList mapFn attrs); + mkSection = + sectName: sectValues: + '' ${sectName} { - '' + lib.generators.toKeyValue { inherit mkKeyValue listsAsDuplicateKeys; } sectValues + ''}''; + '' + + lib.generators.toKeyValue { inherit mkKeyValue listsAsDuplicateKeys; } sectValues + + ''}''; in - # map input to ini sections - mapAttrsToStringsSep "\n" mkSection attrsOfAttrs; + # map input to ini sections + mapAttrsToStringsSep "\n" mkSection attrsOfAttrs; configFile = pkgs.writeText "manticore.conf" ( toSphinx { - mkKeyValue = k: v: " ${k} = ${v}"; + mkKeyValue = k: v: " ${k} = ${v}"; } cfg.settings ); -in { +in +{ options = { services.manticore = { @@ -85,42 +97,51 @@ in { services.manticore = { wantedBy = [ "multi-user.target" ]; after = [ "network.target" ]; - serviceConfig = { - ExecStart = [ - "" - "${pkgs.manticoresearch}/bin/searchd --config ${configFile}" - ]; - ExecStop = [ - "" - "${pkgs.manticoresearch}/bin/searchd --config ${configFile} --stopwait" - ]; - ExecStartPre = [ "" ]; - DynamicUser = true; - LogsDirectory = "manticore"; - RuntimeDirectory = "manticore"; - StateDirectory = "manticore"; - ReadWritePaths = ""; - CapabilityBoundingSet = ""; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; - RestrictNamespaces = true; - PrivateDevices = true; - PrivateUsers = true; - ProtectClock = true; - ProtectControlGroups = true; - ProtectHome = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" ]; - RestrictRealtime = true; - LockPersonality = true; - MemoryDenyWriteExecute = true; - UMask = "0066"; - ProtectHostname = true; - } // lib.optionalAttrs (cfg.settings.searchd.pid_file != null) { - PIDFile = cfg.settings.searchd.pid_file; - }; + serviceConfig = + { + ExecStart = [ + "" + "${pkgs.manticoresearch}/bin/searchd --config ${configFile}" + ]; + ExecStop = [ + "" + "${pkgs.manticoresearch}/bin/searchd --config ${configFile} --stopwait" + ]; + ExecStartPre = [ "" ]; + DynamicUser = true; + LogsDirectory = "manticore"; + RuntimeDirectory = "manticore"; + StateDirectory = "manticore"; + ReadWritePaths = ""; + CapabilityBoundingSet = ""; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; + RestrictNamespaces = true; + PrivateDevices = true; + PrivateUsers = true; + ProtectClock = true; + ProtectControlGroups = true; + ProtectHome = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; + RestrictRealtime = true; + LockPersonality = true; + MemoryDenyWriteExecute = true; + UMask = "0066"; + ProtectHostname = true; + } + // lib.optionalAttrs (cfg.settings.searchd.pid_file != null) { + PIDFile = cfg.settings.searchd.pid_file; + }; }; }; diff --git a/nixos/modules/services/search/opensearch.nix b/nixos/modules/services/search/opensearch.nix index f98ca90068df8a..59e04114eb696e 100644 --- a/nixos/modules/services/search/opensearch.nix +++ b/nixos/modules/services/search/opensearch.nix @@ -1,11 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.opensearch; - settingsFormat = pkgs.formats.yaml {}; + settingsFormat = pkgs.formats.yaml { }; configDir = cfg.dataDir + "/config"; @@ -86,7 +91,7 @@ in }; }; - default = {}; + default = { }; description = '' OpenSearch configuration. @@ -180,86 +185,93 @@ in OPENSEARCH_JAVA_OPTS = toString cfg.extraJavaOptions; OPENSEARCH_PATH_CONF = configDir; }; - serviceConfig = { - ExecStartPre = - let - startPreFullPrivileges = '' - set -o errexit -o pipefail -o nounset -o errtrace - shopt -s inherit_errexit - '' + (optionalString (!config.boot.isContainer) '' - # Only set vm.max_map_count if lower than ES required minimum - # This avoids conflict if configured via boot.kernel.sysctl - if [ $(${pkgs.procps}/bin/sysctl -n vm.max_map_count) -lt 262144 ]; then - ${pkgs.procps}/bin/sysctl -w vm.max_map_count=262144 - fi - ''); - startPreUnprivileged = '' - set -o errexit -o pipefail -o nounset -o errtrace - shopt -s inherit_errexit - - # Install plugins - - # remove plugins directory if it is empty. - if [[ -d ${cfg.dataDir}/plugins && -z "$(ls -A ${cfg.dataDir}/plugins)" ]]; then - rm -r "${cfg.dataDir}/plugins" - fi - - ln -sfT "${cfg.package}/plugins" "${cfg.dataDir}/plugins" - ln -sfT ${cfg.package}/lib ${cfg.dataDir}/lib - ln -sfT ${cfg.package}/modules ${cfg.dataDir}/modules - - # opensearch needs to create the opensearch.keystore in the config directory - # so this directory needs to be writable. - mkdir -p ${configDir} - chmod 0700 ${configDir} - - # Note that we copy config files from the nix store instead of symbolically linking them - # because otherwise X-Pack Security will raise the following exception: - # java.security.AccessControlException: - # access denied ("java.io.FilePermission" "/var/lib/opensearch/config/opensearch.yml" "read") - - rm -f ${configDir}/opensearch.yml - cp ${opensearchYml} ${configDir}/opensearch.yml - - # Make sure the logging configuration for old OpenSearch versions is removed: - rm -f "${configDir}/logging.yml" - rm -f ${configDir}/${loggingConfigFilename} - cp ${loggingConfigFile} ${configDir}/${loggingConfigFilename} - mkdir -p ${configDir}/scripts - - rm -f ${configDir}/jvm.options - cp ${cfg.package}/config/jvm.options ${configDir}/jvm.options - - # redirect jvm logs to the data directory - mkdir -p ${cfg.dataDir}/logs - chmod 0700 ${cfg.dataDir}/logs - sed -e '#logs/gc.log#${cfg.dataDir}/logs/gc.log#' -i ${configDir}/jvm.options - ''; - in [ - "+${pkgs.writeShellScript "opensearch-start-pre-full-privileges" startPreFullPrivileges}" - "${pkgs.writeShellScript "opensearch-start-pre-unprivileged" startPreUnprivileged}" - ]; - ExecStartPost = pkgs.writeShellScript "opensearch-start-post" '' - set -o errexit -o pipefail -o nounset -o errtrace - shopt -s inherit_errexit - - # Make sure opensearch is up and running before dependents - # are started - while ! ${pkgs.curl}/bin/curl -sS -f http://${cfg.settings."network.host"}:${toString cfg.settings."http.port"} 2>/dev/null; do - sleep 1 - done - ''; - ExecStart = "${cfg.package}/bin/opensearch ${toString cfg.extraCmdLineOptions}"; - User = cfg.user; - Group = cfg.group; - LimitNOFILE = "1024000"; - Restart = "always"; - TimeoutStartSec = "infinity"; - DynamicUser = usingDefaultUserAndGroup && usingDefaultDataDir; - } // (optionalAttrs (usingDefaultDataDir) { - StateDirectory = "opensearch"; - StateDirectoryMode = "0700"; - }); + serviceConfig = + { + ExecStartPre = + let + startPreFullPrivileges = + '' + set -o errexit -o pipefail -o nounset -o errtrace + shopt -s inherit_errexit + '' + + (optionalString (!config.boot.isContainer) '' + # Only set vm.max_map_count if lower than ES required minimum + # This avoids conflict if configured via boot.kernel.sysctl + if [ $(${pkgs.procps}/bin/sysctl -n vm.max_map_count) -lt 262144 ]; then + ${pkgs.procps}/bin/sysctl -w vm.max_map_count=262144 + fi + ''); + startPreUnprivileged = '' + set -o errexit -o pipefail -o nounset -o errtrace + shopt -s inherit_errexit + + # Install plugins + + # remove plugins directory if it is empty. + if [[ -d ${cfg.dataDir}/plugins && -z "$(ls -A ${cfg.dataDir}/plugins)" ]]; then + rm -r "${cfg.dataDir}/plugins" + fi + + ln -sfT "${cfg.package}/plugins" "${cfg.dataDir}/plugins" + ln -sfT ${cfg.package}/lib ${cfg.dataDir}/lib + ln -sfT ${cfg.package}/modules ${cfg.dataDir}/modules + + # opensearch needs to create the opensearch.keystore in the config directory + # so this directory needs to be writable. + mkdir -p ${configDir} + chmod 0700 ${configDir} + + # Note that we copy config files from the nix store instead of symbolically linking them + # because otherwise X-Pack Security will raise the following exception: + # java.security.AccessControlException: + # access denied ("java.io.FilePermission" "/var/lib/opensearch/config/opensearch.yml" "read") + + rm -f ${configDir}/opensearch.yml + cp ${opensearchYml} ${configDir}/opensearch.yml + + # Make sure the logging configuration for old OpenSearch versions is removed: + rm -f "${configDir}/logging.yml" + rm -f ${configDir}/${loggingConfigFilename} + cp ${loggingConfigFile} ${configDir}/${loggingConfigFilename} + mkdir -p ${configDir}/scripts + + rm -f ${configDir}/jvm.options + cp ${cfg.package}/config/jvm.options ${configDir}/jvm.options + + # redirect jvm logs to the data directory + mkdir -p ${cfg.dataDir}/logs + chmod 0700 ${cfg.dataDir}/logs + sed -e '#logs/gc.log#${cfg.dataDir}/logs/gc.log#' -i ${configDir}/jvm.options + ''; + in + [ + "+${pkgs.writeShellScript "opensearch-start-pre-full-privileges" startPreFullPrivileges}" + "${pkgs.writeShellScript "opensearch-start-pre-unprivileged" startPreUnprivileged}" + ]; + ExecStartPost = pkgs.writeShellScript "opensearch-start-post" '' + set -o errexit -o pipefail -o nounset -o errtrace + shopt -s inherit_errexit + + # Make sure opensearch is up and running before dependents + # are started + while ! ${pkgs.curl}/bin/curl -sS -f http://${cfg.settings."network.host"}:${ + toString cfg.settings."http.port" + } 2>/dev/null; do + sleep 1 + done + ''; + ExecStart = "${cfg.package}/bin/opensearch ${toString cfg.extraCmdLineOptions}"; + User = cfg.user; + Group = cfg.group; + LimitNOFILE = "1024000"; + Restart = "always"; + TimeoutStartSec = "infinity"; + DynamicUser = usingDefaultUserAndGroup && usingDefaultDataDir; + } + // (optionalAttrs (usingDefaultDataDir) { + StateDirectory = "opensearch"; + StateDirectoryMode = "0700"; + }); }; environment.systemPackages = [ cfg.package ]; diff --git a/nixos/modules/services/search/qdrant.nix b/nixos/modules/services/search/qdrant.nix index 41a4e9b41f6d90..3b2ce4f6fd5cde 100644 --- a/nixos/modules/services/search/qdrant.nix +++ b/nixos/modules/services/search/qdrant.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let @@ -7,7 +12,8 @@ let settingsFormat = pkgs.formats.yaml { }; configFile = settingsFormat.generate "config.yaml" cfg.settings; -in { +in +{ options = { services.qdrant = { @@ -101,7 +107,7 @@ in { after = [ "network.target" ]; serviceConfig = { - LimitNOFILE=65536; + LimitNOFILE = 65536; ExecStart = "${pkgs.qdrant}/bin/qdrant --config-path ${configFile}"; DynamicUser = true; Restart = "on-failure"; @@ -123,7 +129,10 @@ in { RestrictNamespaces = true; LockPersonality = true; RemoveIPC = true; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; }; }; }; diff --git a/nixos/modules/services/search/quickwit.nix b/nixos/modules/services/search/quickwit.nix index c4cc0c2427dff2..c55b32154b535d 100644 --- a/nixos/modules/services/search/quickwit.nix +++ b/nixos/modules/services/search/quickwit.nix @@ -1,11 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.quickwit; - settingsFormat = pkgs.formats.yaml {}; + settingsFormat = pkgs.formats.yaml { }; quickwitYml = settingsFormat.generate "quickwit.yml" cfg.settings; usingDefaultDataDir = cfg.dataDir == "/var/lib/quickwit"; @@ -25,7 +30,7 @@ in freeformType = settingsFormat.type; options."rest" = lib.mkOption { - default = {}; + default = { }; description = '' Rest server configuration for Quickwit ''; @@ -68,7 +73,7 @@ in }; }; - default = {}; + default = { }; description = '' Quickwit configuration. @@ -134,55 +139,57 @@ in environment = { QW_DATA_DIR = cfg.dataDir; }; - serviceConfig = { - ExecStart = '' - ${cfg.package}/bin/quickwit run --config ${quickwitYml} \ - ${escapeShellArgs cfg.extraFlags} - ''; - User = cfg.user; - Group = cfg.group; - Restart = "on-failure"; - DynamicUser = usingDefaultUserAndGroup && usingDefaultDataDir; - CapabilityBoundingSet = [ "" ]; - DevicePolicy = "closed"; - LockPersonality = true; - MemoryDenyWriteExecute = true; - NoNewPrivileges = true; - PrivateDevices = true; - ProcSubset = "pid"; - ProtectClock = true; - ProtectHome = true; - ProtectHostname = true; - ProtectControlGroups = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - ProtectSystem = "strict"; - ReadWritePaths = [ - cfg.dataDir - ]; - RestrictAddressFamilies = [ - "AF_NETLINK" - "AF_INET" - "AF_INET6" - ]; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ - # 1. allow a reasonable set of syscalls - "@system-service @resources" - # 2. and deny unreasonable ones - "~@privileged" - # 3. then allow the required subset within denied groups - "@chown" - ]; - } // (optionalAttrs (usingDefaultDataDir) { - StateDirectory = "quickwit"; - StateDirectoryMode = "0700"; - }); + serviceConfig = + { + ExecStart = '' + ${cfg.package}/bin/quickwit run --config ${quickwitYml} \ + ${escapeShellArgs cfg.extraFlags} + ''; + User = cfg.user; + Group = cfg.group; + Restart = "on-failure"; + DynamicUser = usingDefaultUserAndGroup && usingDefaultDataDir; + CapabilityBoundingSet = [ "" ]; + DevicePolicy = "closed"; + LockPersonality = true; + MemoryDenyWriteExecute = true; + NoNewPrivileges = true; + PrivateDevices = true; + ProcSubset = "pid"; + ProtectClock = true; + ProtectHome = true; + ProtectHostname = true; + ProtectControlGroups = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + ProtectSystem = "strict"; + ReadWritePaths = [ + cfg.dataDir + ]; + RestrictAddressFamilies = [ + "AF_NETLINK" + "AF_INET" + "AF_INET6" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + # 1. allow a reasonable set of syscalls + "@system-service @resources" + # 2. and deny unreasonable ones + "~@privileged" + # 3. then allow the required subset within denied groups + "@chown" + ]; + } + // (optionalAttrs (usingDefaultDataDir) { + StateDirectory = "quickwit"; + StateDirectoryMode = "0700"; + }); }; environment.systemPackages = [ cfg.package ]; diff --git a/nixos/modules/services/search/sonic-server.nix b/nixos/modules/services/search/sonic-server.nix index 7a8fa225fa4a91..c6028e47f15d6a 100644 --- a/nixos/modules/services/search/sonic-server.nix +++ b/nixos/modules/services/search/sonic-server.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.sonic-server; @@ -6,7 +11,8 @@ let settingsFormat = pkgs.formats.toml { }; configFile = settingsFormat.generate "sonic-server-config.toml" cfg.settings; -in { +in +{ meta.maintainers = [ lib.maintainers.anthonyroussel ]; options = { @@ -38,18 +44,18 @@ in { config = lib.mkIf cfg.enable { services.sonic-server.settings = lib.mapAttrs (name: lib.mkDefault) { - server = {}; - channel.search = {}; + server = { }; + channel.search = { }; store = { kv = { path = "/var/lib/sonic/kv"; - database = {}; - pool = {}; + database = { }; + pool = { }; }; fst = { path = "/var/lib/sonic/fst"; - graph = {}; - pool = {}; + graph = { }; + pool = { }; }; }; }; diff --git a/nixos/modules/services/search/typesense.nix b/nixos/modules/services/search/typesense.nix index a44d932593e516..8556bacd0a7af9 100644 --- a/nixos/modules/services/search/typesense.nix +++ b/nixos/modules/services/search/typesense.nix @@ -1,6 +1,11 @@ -{ config, lib, pkgs, ... }: let - inherit - (lib) +{ + config, + lib, + pkgs, + ... +}: +let + inherit (lib) concatMapStringsSep generators mkEnableOption @@ -14,19 +19,16 @@ cfg = config.services.typesense; settingsFormatIni = pkgs.formats.ini { listToValue = concatMapStringsSep " " (generators.mkValueStringDefault { }); - mkKeyValue = generators.mkKeyValueDefault - { - mkValueString = v: - if v == null then "" - else generators.mkValueStringDefault { } v; - } - "="; + mkKeyValue = generators.mkKeyValueDefault { + mkValueString = v: if v == null then "" else generators.mkValueStringDefault { } v; + } "="; }; configFile = settingsFormatIni.generate "typesense.ini" cfg.settings; -in { +in +{ options.services.typesense = { enable = mkEnableOption "typesense"; - package = mkPackageOption pkgs "typesense" {}; + package = mkPackageOption pkgs "typesense" { }; apiKeyFile = mkOption { type = types.path; @@ -39,7 +41,7 @@ in { settings = mkOption { description = "Typesense configuration. Refer to [the documentation](https://typesense.org/docs/0.24.1/api/server-configuration.html) for supported values."; - default = {}; + default = { }; type = types.submodule { freeformType = settingsFormatIni.type; options.server = { diff --git a/nixos/modules/services/security/aesmd.nix b/nixos/modules/services/security/aesmd.nix index 4da5c00752d56e..4f7f55e78e99de 100644 --- a/nixos/modules/services/security/aesmd.nix +++ b/nixos/modules/services/security/aesmd.nix @@ -1,23 +1,43 @@ -{ config, options, pkgs, lib, ... }: +{ + config, + options, + pkgs, + lib, + ... +}: let - inherit (lib) concatStringsSep literalExpression makeLibraryPath mkEnableOption - mkForce mkIf mkOption mkPackageOption mkRemovedOptionModule optional types; + inherit (lib) + concatStringsSep + literalExpression + makeLibraryPath + mkEnableOption + mkForce + mkIf + mkOption + mkPackageOption + mkRemovedOptionModule + optional + types + ; cfg = config.services.aesmd; opt = options.services.aesmd; sgx-psw = cfg.package; - configFile = with cfg.settings; pkgs.writeText "aesmd.conf" ( - concatStringsSep "\n" ( - optional (whitelistUrl != null) "whitelist url = ${whitelistUrl}" ++ - optional (proxy != null) "aesm proxy = ${proxy}" ++ - optional (proxyType != null) "proxy type = ${proxyType}" ++ - optional (defaultQuotingType != null) "default quoting type = ${defaultQuotingType}" ++ - # Newline at end of file - [ "" ] - ) - ); + configFile = + with cfg.settings; + pkgs.writeText "aesmd.conf" ( + concatStringsSep "\n" ( + optional (whitelistUrl != null) "whitelist url = ${whitelistUrl}" + ++ optional (proxy != null) "aesm proxy = ${proxy}" + ++ optional (proxyType != null) "proxy type = ${proxyType}" + ++ optional (defaultQuotingType != null) "default quoting type = ${defaultQuotingType}" + ++ + # Newline at end of file + [ "" ] + ) + ); in { imports = [ @@ -64,7 +84,13 @@ in description = "HTTP network proxy."; }; options.proxyType = mkOption { - type = with types; nullOr (enum [ "default" "direct" "manual" ]); + type = + with types; + nullOr (enum [ + "default" + "direct" + "manual" + ]); default = if (cfg.settings.proxy != null) then "manual" else null; defaultText = literalExpression '' if (config.${opt.settings}.proxy != null) then "manual" else null @@ -78,7 +104,13 @@ in ''; }; options.defaultQuotingType = mkOption { - type = with types; nullOr (enum [ "ecdsa_256" "epid_linkable" "epid_unlinkable" ]); + type = + with types; + nullOr (enum [ + "ecdsa_256" + "epid_linkable" + "epid_unlinkable" + ]); default = null; example = "ecdsa_256"; description = "Attestation quote type."; @@ -88,10 +120,12 @@ in }; config = mkIf cfg.enable { - assertions = [{ - assertion = !(config.boot.specialFileSystems."/dev".options ? "noexec"); - message = "SGX requires exec permission for /dev"; - }]; + assertions = [ + { + assertion = !(config.boot.specialFileSystems."/dev".options ? "noexec"); + message = "SGX requires exec permission for /dev"; + } + ]; hardware.cpu.intel.sgx.provision.enable = true; @@ -110,7 +144,10 @@ in description = "Intel Architectural Enclave Service Manager"; wantedBy = [ "multi-user.target" ]; - after = [ "auditd.service" "network.target" ]; + after = [ + "auditd.service" + "network.target" + ]; environment = { NAME = "aesm_service"; diff --git a/nixos/modules/services/security/authelia.nix b/nixos/modules/services/security/authelia.nix index bbd6bde5ebc184..cd5273bd2163b3 100644 --- a/nixos/modules/services/security/authelia.nix +++ b/nixos/modules/services/security/authelia.nix @@ -1,7 +1,8 @@ -{ lib -, pkgs -, config -, ... +{ + lib, + pkgs, + config, + ... }: let @@ -9,301 +10,355 @@ let format = pkgs.formats.yaml { }; - autheliaOpts = with lib; { name, ... }: { - options = { - enable = mkEnableOption "Authelia instance"; - - name = mkOption { - type = types.str; - default = name; - description = '' - Name is used as a suffix for the service name, user, and group. - By default it takes the value you use for `` in: - {option}`services.authelia.` - ''; - }; + autheliaOpts = + with lib; + { name, ... }: + { + options = { + enable = mkEnableOption "Authelia instance"; + + name = mkOption { + type = types.str; + default = name; + description = '' + Name is used as a suffix for the service name, user, and group. + By default it takes the value you use for `` in: + {option}`services.authelia.` + ''; + }; - package = mkPackageOption pkgs "authelia" { }; + package = mkPackageOption pkgs "authelia" { }; - user = mkOption { - default = "authelia-${name}"; - type = types.str; - description = "The name of the user for this authelia instance."; - }; + user = mkOption { + default = "authelia-${name}"; + type = types.str; + description = "The name of the user for this authelia instance."; + }; - group = mkOption { - default = "authelia-${name}"; - type = types.str; - description = "The name of the group for this authelia instance."; - }; + group = mkOption { + default = "authelia-${name}"; + type = types.str; + description = "The name of the group for this authelia instance."; + }; - secrets = mkOption { - description = '' - It is recommended you keep your secrets separate from the configuration. - It's especially important to keep the raw secrets out of your nix configuration, - as the values will be preserved in your nix store. - This attribute allows you to configure the location of secret files to be loaded at runtime. - - https://www.authelia.com/configuration/methods/secrets/ - ''; - default = { }; - type = types.submodule { - options = { - manual = mkOption { - default = false; - example = true; - description = '' - Configuring authelia's secret files via the secrets attribute set - is intended to be convenient and help catch cases where values are required - to run at all. - If a user wants to set these values themselves and bypass the validation they can set this value to true. - ''; - type = types.bool; - }; + secrets = mkOption { + description = '' + It is recommended you keep your secrets separate from the configuration. + It's especially important to keep the raw secrets out of your nix configuration, + as the values will be preserved in your nix store. + This attribute allows you to configure the location of secret files to be loaded at runtime. + + https://www.authelia.com/configuration/methods/secrets/ + ''; + default = { }; + type = types.submodule { + options = { + manual = mkOption { + default = false; + example = true; + description = '' + Configuring authelia's secret files via the secrets attribute set + is intended to be convenient and help catch cases where values are required + to run at all. + If a user wants to set these values themselves and bypass the validation they can set this value to true. + ''; + type = types.bool; + }; - # required - jwtSecretFile = mkOption { - type = types.nullOr types.path; - default = null; - description = '' - Path to your JWT secret used during identity verificaton. - ''; - }; + # required + jwtSecretFile = mkOption { + type = types.nullOr types.path; + default = null; + description = '' + Path to your JWT secret used during identity verificaton. + ''; + }; - oidcIssuerPrivateKeyFile = mkOption { - type = types.nullOr types.path; - default = null; - description = '' - Path to your private key file used to encrypt OIDC JWTs. - ''; - }; + oidcIssuerPrivateKeyFile = mkOption { + type = types.nullOr types.path; + default = null; + description = '' + Path to your private key file used to encrypt OIDC JWTs. + ''; + }; - oidcHmacSecretFile = mkOption { - type = types.nullOr types.path; - default = null; - description = '' - Path to your HMAC secret used to sign OIDC JWTs. - ''; - }; + oidcHmacSecretFile = mkOption { + type = types.nullOr types.path; + default = null; + description = '' + Path to your HMAC secret used to sign OIDC JWTs. + ''; + }; - sessionSecretFile = mkOption { - type = types.nullOr types.path; - default = null; - description = '' - Path to your session secret. Only used when redis is used as session storage. - ''; - }; + sessionSecretFile = mkOption { + type = types.nullOr types.path; + default = null; + description = '' + Path to your session secret. Only used when redis is used as session storage. + ''; + }; - # required - storageEncryptionKeyFile = mkOption { - type = types.nullOr types.path; - default = null; - description = '' - Path to your storage encryption key. - ''; + # required + storageEncryptionKeyFile = mkOption { + type = types.nullOr types.path; + default = null; + description = '' + Path to your storage encryption key. + ''; + }; }; }; }; - }; - - environmentVariables = mkOption { - type = types.attrsOf types.str; - description = '' - Additional environment variables to provide to authelia. - If you are providing secrets please consider the options under {option}`services.authelia..secrets` - or make sure you use the `_FILE` suffix. - If you provide the raw secret rather than the location of a secret file that secret will be preserved in the nix store. - For more details: https://www.authelia.com/configuration/methods/secrets/ - ''; - default = { }; - }; - settings = mkOption { - description = '' - Your Authelia config.yml as a Nix attribute set. - There are several values that are defined and documented in nix such as `default_2fa_method`, - but additional items can also be included. - - https://github.com/authelia/authelia/blob/master/config.template.yml - ''; - default = { }; - example = '' - { - theme = "light"; - default_2fa_method = "totp"; - log.level = "debug"; - server.disable_healthcheck = true; - } - ''; - type = types.submodule { - freeformType = format.type; - options = { - theme = mkOption { - type = types.enum [ "light" "dark" "grey" "auto" ]; - default = "light"; - example = "dark"; - description = "The theme to display."; - }; - - default_2fa_method = mkOption { - type = types.enum [ "" "totp" "webauthn" "mobile_push" ]; - default = ""; - example = "webauthn"; - description = '' - Default 2FA method for new users and fallback for preferred but disabled methods. - ''; - }; + environmentVariables = mkOption { + type = types.attrsOf types.str; + description = '' + Additional environment variables to provide to authelia. + If you are providing secrets please consider the options under {option}`services.authelia..secrets` + or make sure you use the `_FILE` suffix. + If you provide the raw secret rather than the location of a secret file that secret will be preserved in the nix store. + For more details: https://www.authelia.com/configuration/methods/secrets/ + ''; + default = { }; + }; - server = { - address = mkOption { - type = types.str; - default = "tcp://:9091/"; - example = "unix:///var/run/authelia.sock?path=authelia&umask=0117"; - description = "The address to listen on."; + settings = mkOption { + description = '' + Your Authelia config.yml as a Nix attribute set. + There are several values that are defined and documented in nix such as `default_2fa_method`, + but additional items can also be included. + + https://github.com/authelia/authelia/blob/master/config.template.yml + ''; + default = { }; + example = '' + { + theme = "light"; + default_2fa_method = "totp"; + log.level = "debug"; + server.disable_healthcheck = true; + } + ''; + type = types.submodule { + freeformType = format.type; + options = { + theme = mkOption { + type = types.enum [ + "light" + "dark" + "grey" + "auto" + ]; + default = "light"; + example = "dark"; + description = "The theme to display."; }; - }; - log = { - level = mkOption { - type = types.enum [ "trace" "debug" "info" "warn" "error" ]; - default = "debug"; - example = "info"; - description = "Level of verbosity for logs."; + default_2fa_method = mkOption { + type = types.enum [ + "" + "totp" + "webauthn" + "mobile_push" + ]; + default = ""; + example = "webauthn"; + description = '' + Default 2FA method for new users and fallback for preferred but disabled methods. + ''; }; - format = mkOption { - type = types.enum [ "json" "text" ]; - default = "json"; - example = "text"; - description = "Format the logs are written as."; + server = { + address = mkOption { + type = types.str; + default = "tcp://:9091/"; + example = "unix:///var/run/authelia.sock?path=authelia&umask=0117"; + description = "The address to listen on."; + }; }; - file_path = mkOption { - type = types.nullOr types.path; - default = null; - example = "/var/log/authelia/authelia.log"; - description = "File path where the logs will be written. If not set logs are written to stdout."; - }; + log = { + level = mkOption { + type = types.enum [ + "trace" + "debug" + "info" + "warn" + "error" + ]; + default = "debug"; + example = "info"; + description = "Level of verbosity for logs."; + }; - keep_stdout = mkOption { - type = types.bool; - default = false; - example = true; - description = "Whether to also log to stdout when a `file_path` is defined."; - }; - }; + format = mkOption { + type = types.enum [ + "json" + "text" + ]; + default = "json"; + example = "text"; + description = "Format the logs are written as."; + }; - telemetry = { - metrics = { - enabled = mkOption { + file_path = mkOption { + type = types.nullOr types.path; + default = null; + example = "/var/log/authelia/authelia.log"; + description = "File path where the logs will be written. If not set logs are written to stdout."; + }; + + keep_stdout = mkOption { type = types.bool; default = false; example = true; - description = "Enable Metrics."; + description = "Whether to also log to stdout when a `file_path` is defined."; }; + }; - address = mkOption { - type = types.str; - default = "tcp://127.0.0.1:9959"; - example = "tcp://0.0.0.0:8888"; - description = "The address to listen on for metrics. This should be on a different port to the main `server.port` value."; + telemetry = { + metrics = { + enabled = mkOption { + type = types.bool; + default = false; + example = true; + description = "Enable Metrics."; + }; + + address = mkOption { + type = types.str; + default = "tcp://127.0.0.1:9959"; + example = "tcp://0.0.0.0:8888"; + description = "The address to listen on for metrics. This should be on a different port to the main `server.port` value."; + }; }; }; }; }; }; - }; - settingsFiles = mkOption { - type = types.listOf types.path; - default = [ ]; - example = [ "/etc/authelia/config.yml" "/etc/authelia/access-control.yml" "/etc/authelia/config/" ]; - description = '' - Here you can provide authelia with configuration files or directories. - It is possible to give authelia multiple files and use the nix generated configuration - file set via {option}`services.authelia..settings`. - ''; + settingsFiles = mkOption { + type = types.listOf types.path; + default = [ ]; + example = [ + "/etc/authelia/config.yml" + "/etc/authelia/access-control.yml" + "/etc/authelia/config/" + ]; + description = '' + Here you can provide authelia with configuration files or directories. + It is possible to give authelia multiple files and use the nix generated configuration + file set via {option}`services.authelia..settings`. + ''; + }; }; }; - }; - writeOidcJwksConfigFile = oidcIssuerPrivateKeyFile: pkgs.writeText "oidc-jwks.yaml" '' - identity_providers: - oidc: - jwks: - - key: {{ secret "${oidcIssuerPrivateKeyFile}" | mindent 10 "|" | msquote }} - ''; + writeOidcJwksConfigFile = + oidcIssuerPrivateKeyFile: + pkgs.writeText "oidc-jwks.yaml" '' + identity_providers: + oidc: + jwks: + - key: {{ secret "${oidcIssuerPrivateKeyFile}" | mindent 10 "|" | msquote }} + ''; # Remove an attribute in a nested set # https://discourse.nixos.org/t/modify-an-attrset-in-nix/29919/5 - removeAttrByPath = set: pathList: - lib.updateManyAttrsByPath [{ - path = lib.init pathList; - update = old: - lib.filterAttrs (n: v: n != (lib.last pathList)) old; - }] - set; + removeAttrByPath = + set: pathList: + lib.updateManyAttrsByPath [ + { + path = lib.init pathList; + update = old: lib.filterAttrs (n: v: n != (lib.last pathList)) old; + } + ] set; in { - options.services.authelia.instances = with lib; mkOption { - default = { }; - type = types.attrsOf (types.submodule autheliaOpts); - description = '' - Multi-domain protection currently requires multiple instances of Authelia. - If you don't require multiple instances of Authelia you can define just the one. - - https://www.authelia.com/roadmap/active/multi-domain-protection/ - ''; - example = '' - { - main = { - enable = true; - secrets.storageEncryptionKeyFile = "/etc/authelia/storageEncryptionKeyFile"; - secrets.jwtSecretFile = "/etc/authelia/jwtSecretFile"; - settings = { - theme = "light"; - default_2fa_method = "totp"; - log.level = "debug"; - server.disable_healthcheck = true; + options.services.authelia.instances = + with lib; + mkOption { + default = { }; + type = types.attrsOf (types.submodule autheliaOpts); + description = '' + Multi-domain protection currently requires multiple instances of Authelia. + If you don't require multiple instances of Authelia you can define just the one. + + https://www.authelia.com/roadmap/active/multi-domain-protection/ + ''; + example = '' + { + main = { + enable = true; + secrets.storageEncryptionKeyFile = "/etc/authelia/storageEncryptionKeyFile"; + secrets.jwtSecretFile = "/etc/authelia/jwtSecretFile"; + settings = { + theme = "light"; + default_2fa_method = "totp"; + log.level = "debug"; + server.disable_healthcheck = true; + }; }; - }; - preprod = { - enable = false; - secrets.storageEncryptionKeyFile = "/mnt/pre-prod/authelia/storageEncryptionKeyFile"; - secrets.jwtSecretFile = "/mnt/pre-prod/jwtSecretFile"; - settings = { - theme = "dark"; - default_2fa_method = "webauthn"; - server.host = "0.0.0.0"; + preprod = { + enable = false; + secrets.storageEncryptionKeyFile = "/mnt/pre-prod/authelia/storageEncryptionKeyFile"; + secrets.jwtSecretFile = "/mnt/pre-prod/jwtSecretFile"; + settings = { + theme = "dark"; + default_2fa_method = "webauthn"; + server.host = "0.0.0.0"; + }; }; - }; - test.enable = true; - test.secrets.manual = true; - test.settings.theme = "grey"; - test.settings.server.disable_healthcheck = true; - test.settingsFiles = [ "/mnt/test/authelia" "/mnt/test-authelia.conf" ]; - }; - } - ''; - }; + test.enable = true; + test.secrets.manual = true; + test.settings.theme = "grey"; + test.settings.server.disable_healthcheck = true; + test.settingsFiles = [ "/mnt/test/authelia" "/mnt/test-authelia.conf" ]; + }; + } + ''; + }; config = let - mkInstanceServiceConfig = instance: + mkInstanceServiceConfig = + instance: let cleanedSettings = - if (instance.settings.server?host || instance.settings.server?port || instance.settings.server?path) then - # Old settings are used: display a warning and remove the default value of server.address - # as authelia does not allow both old and new settings to be set - lib.warn "Please replace services.authelia.instances.${instance.name}.settings.{host,port,path} with services.authelia.instances.${instance.name}.settings.address, before release 5.0.0" - (removeAttrByPath instance.settings [ "server" "address" ]) + if + ( + instance.settings.server ? host + || instance.settings.server ? port + || instance.settings.server ? path + ) + then + # Old settings are used: display a warning and remove the default value of server.address + # as authelia does not allow both old and new settings to be set + lib.warn + "Please replace services.authelia.instances.${instance.name}.settings.{host,port,path} with services.authelia.instances.${instance.name}.settings.address, before release 5.0.0" + ( + removeAttrByPath instance.settings [ + "server" + "address" + ] + ) else instance.settings; execCommand = "${instance.package}/bin/authelia"; configFile = format.generate "config.yml" cleanedSettings; - oidcJwksConfigFile = lib.optional (instance.secrets.oidcIssuerPrivateKeyFile != null) (writeOidcJwksConfigFile instance.secrets.oidcIssuerPrivateKeyFile); - configArg = "--config ${builtins.concatStringsSep "," (lib.concatLists [[configFile] instance.settingsFiles oidcJwksConfigFile])}"; + oidcJwksConfigFile = lib.optional (instance.secrets.oidcIssuerPrivateKeyFile != null) ( + writeOidcJwksConfigFile instance.secrets.oidcIssuerPrivateKeyFile + ); + configArg = "--config ${ + builtins.concatStringsSep "," ( + lib.concatLists [ + [ configFile ] + instance.settingsFiles + oidcJwksConfigFile + ] + ) + }"; in { description = "Authelia authentication and authorization server"; @@ -352,7 +407,11 @@ in ProtectProc = "noaccess"; ProtectSystem = "strict"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; @@ -372,46 +431,49 @@ in }; }; mkInstanceUsersConfig = instance: { - groups."authelia-${instance.name}" = - lib.mkIf (instance.group == "authelia-${instance.name}") { - name = "authelia-${instance.name}"; - }; - users."authelia-${instance.name}" = - lib.mkIf (instance.user == "authelia-${instance.name}") { - name = "authelia-${instance.name}"; - isSystemUser = true; - group = instance.group; - }; + groups."authelia-${instance.name}" = lib.mkIf (instance.group == "authelia-${instance.name}") { + name = "authelia-${instance.name}"; + }; + users."authelia-${instance.name}" = lib.mkIf (instance.user == "authelia-${instance.name}") { + name = "authelia-${instance.name}"; + isSystemUser = true; + group = instance.group; + }; }; instances = lib.attrValues cfg.instances; in { - assertions = lib.flatten (lib.flip lib.mapAttrsToList cfg.instances (name: instance: - [ - { - assertion = instance.secrets.manual || (instance.secrets.jwtSecretFile != null && instance.secrets.storageEncryptionKeyFile != null); - message = '' - Authelia requires a JWT Secret and a Storage Encryption Key to work. - Either set them like so: - services.authelia.${name}.secrets.jwtSecretFile = /my/path/to/jwtsecret; - services.authelia.${name}.secrets.storageEncryptionKeyFile = /my/path/to/encryptionkey; - Or set services.authelia.${name}.secrets.manual = true and provide them yourself via - environmentVariables or settingsFiles. - Do not include raw secrets in nix settings. - ''; - } - ] - )); - - systemd.services = lib.mkMerge - (map - (instance: lib.mkIf instance.enable { + assertions = lib.flatten ( + lib.flip lib.mapAttrsToList cfg.instances ( + name: instance: [ + { + assertion = + instance.secrets.manual + || (instance.secrets.jwtSecretFile != null && instance.secrets.storageEncryptionKeyFile != null); + message = '' + Authelia requires a JWT Secret and a Storage Encryption Key to work. + Either set them like so: + services.authelia.${name}.secrets.jwtSecretFile = /my/path/to/jwtsecret; + services.authelia.${name}.secrets.storageEncryptionKeyFile = /my/path/to/encryptionkey; + Or set services.authelia.${name}.secrets.manual = true and provide them yourself via + environmentVariables or settingsFiles. + Do not include raw secrets in nix settings. + ''; + } + ] + ) + ); + + systemd.services = lib.mkMerge ( + map ( + instance: + lib.mkIf instance.enable { "authelia-${instance.name}" = mkInstanceServiceConfig instance; - }) - instances); - users = lib.mkMerge - (map - (instance: lib.mkIf instance.enable (mkInstanceUsersConfig instance)) - instances); + } + ) instances + ); + users = lib.mkMerge ( + map (instance: lib.mkIf instance.enable (mkInstanceUsersConfig instance)) instances + ); }; } diff --git a/nixos/modules/services/security/bitwarden-directory-connector-cli.nix b/nixos/modules/services/security/bitwarden-directory-connector-cli.nix index fef4a88648979a..633563a1156181 100644 --- a/nixos/modules/services/security/bitwarden-directory-connector-cli.nix +++ b/nixos/modules/services/security/bitwarden-directory-connector-cli.nix @@ -4,13 +4,15 @@ pkgs, ... }: -with lib; let +with lib; +let cfg = config.services.bitwarden-directory-connector-cli; -in { +in +{ options.services.bitwarden-directory-connector-cli = { enable = mkEnableOption "Bitwarden Directory Connector"; - package = mkPackageOption pkgs "bitwarden-directory-connector-cli" {}; + package = mkPackageOption pkgs "bitwarden-directory-connector-cli" { }; domain = mkOption { type = types.str; @@ -35,72 +37,79 @@ in { Options to configure the LDAP connection. If you used the desktop application to test the configuration you can find the settings by searching for `ldap` in `~/.config/Bitwarden\ Directory\ Connector/data.json`. ''; - default = {}; - type = types.submodule ({ - config, - options, - ... - }: { - freeformType = types.attrsOf (pkgs.formats.json {}).type; - - config.finalJSON = builtins.toJSON (removeAttrs config (filter (x: x == "finalJSON" || ! options.${x}.isDefined or false) (attrNames options))); - - options = { - finalJSON = mkOption { - type = (pkgs.formats.json {}).type; - internal = true; - readOnly = true; - visible = false; - }; - - ssl = mkOption { - type = types.bool; - default = false; - description = "Whether to use TLS."; - }; - startTls = mkOption { - type = types.bool; - default = false; - description = "Whether to use STARTTLS."; - }; - - hostname = mkOption { - type = types.str; - description = "The host the LDAP is accessible on."; - example = "ldap.example.com"; - }; - - port = mkOption { - type = types.port; - default = 389; - description = "Port LDAP is accessible on."; - }; - - ad = mkOption { - type = types.bool; - default = false; - description = "Whether the LDAP Server is an Active Directory."; - }; - - pagedSearch = mkOption { - type = types.bool; - default = false; - description = "Whether the LDAP server paginates search results."; - }; - - rootPath = mkOption { - type = types.str; - description = "Root path for LDAP."; - example = "dc=example,dc=com"; + default = { }; + type = types.submodule ( + { + config, + options, + ... + }: + { + freeformType = types.attrsOf (pkgs.formats.json { }).type; + + config.finalJSON = builtins.toJSON ( + removeAttrs config ( + filter (x: x == "finalJSON" || !options.${x}.isDefined or false) (attrNames options) + ) + ); + + options = { + finalJSON = mkOption { + type = (pkgs.formats.json { }).type; + internal = true; + readOnly = true; + visible = false; + }; + + ssl = mkOption { + type = types.bool; + default = false; + description = "Whether to use TLS."; + }; + startTls = mkOption { + type = types.bool; + default = false; + description = "Whether to use STARTTLS."; + }; + + hostname = mkOption { + type = types.str; + description = "The host the LDAP is accessible on."; + example = "ldap.example.com"; + }; + + port = mkOption { + type = types.port; + default = 389; + description = "Port LDAP is accessible on."; + }; + + ad = mkOption { + type = types.bool; + default = false; + description = "Whether the LDAP Server is an Active Directory."; + }; + + pagedSearch = mkOption { + type = types.bool; + default = false; + description = "Whether the LDAP server paginates search results."; + }; + + rootPath = mkOption { + type = types.str; + description = "Root path for LDAP."; + example = "dc=example,dc=com"; + }; + + username = mkOption { + type = types.str; + description = "The user to authenticate as."; + example = "cn=admin,dc=example,dc=com"; + }; }; - - username = mkOption { - type = types.str; - description = "The user to authenticate as."; - example = "cn=admin,dc=example,dc=com"; - }; - }; - }); + } + ); }; sync = mkOption { @@ -108,125 +117,132 @@ in { Options to configure what gets synced. If you used the desktop application to test the configuration you can find the settings by searching for `sync` in `~/.config/Bitwarden\ Directory\ Connector/data.json`. ''; - default = {}; - type = types.submodule ({ - config, - options, - ... - }: { - freeformType = types.attrsOf (pkgs.formats.json {}).type; - - config.finalJSON = builtins.toJSON (removeAttrs config (filter (x: x == "finalJSON" || ! options.${x}.isDefined or false) (attrNames options))); - - options = { - finalJSON = mkOption { - type = (pkgs.formats.json {}).type; - internal = true; - readOnly = true; - visible = false; - }; - - removeDisabled = mkOption { - type = types.bool; - default = true; - description = "Remove users from bitwarden groups if no longer in the ldap group."; - }; - - overwriteExisting = mkOption { - type = types.bool; - default = false; - description = "Remove and re-add users/groups, See https://bitwarden.com/help/user-group-filters/#overwriting-syncs for more details."; - }; - - largeImport = mkOption { - type = types.bool; - default = false; - description = "Enable if you are syncing more than 2000 users/groups."; - }; - - memberAttribute = mkOption { - type = types.str; - description = "Attribute that lists members in a LDAP group."; - example = "uniqueMember"; - }; - - creationDateAttribute = mkOption { - type = types.str; - description = "Attribute that lists a user's creation date."; - example = "whenCreated"; - }; - - useEmailPrefixSuffix = mkOption { - type = types.bool; - default = false; - description = "If a user has no email address, combine a username prefix with a suffix value to form an email."; - }; - emailPrefixAttribute = mkOption { - type = types.str; - description = "The attribute that contains the users username."; - example = "accountName"; - }; - emailSuffix = mkOption { - type = types.str; - description = "Suffix for the email, normally @example.com."; - example = "@example.com"; - }; - - users = mkOption { - type = types.bool; - default = false; - description = "Sync users."; + default = { }; + type = types.submodule ( + { + config, + options, + ... + }: + { + freeformType = types.attrsOf (pkgs.formats.json { }).type; + + config.finalJSON = builtins.toJSON ( + removeAttrs config ( + filter (x: x == "finalJSON" || !options.${x}.isDefined or false) (attrNames options) + ) + ); + + options = { + finalJSON = mkOption { + type = (pkgs.formats.json { }).type; + internal = true; + readOnly = true; + visible = false; + }; + + removeDisabled = mkOption { + type = types.bool; + default = true; + description = "Remove users from bitwarden groups if no longer in the ldap group."; + }; + + overwriteExisting = mkOption { + type = types.bool; + default = false; + description = "Remove and re-add users/groups, See https://bitwarden.com/help/user-group-filters/#overwriting-syncs for more details."; + }; + + largeImport = mkOption { + type = types.bool; + default = false; + description = "Enable if you are syncing more than 2000 users/groups."; + }; + + memberAttribute = mkOption { + type = types.str; + description = "Attribute that lists members in a LDAP group."; + example = "uniqueMember"; + }; + + creationDateAttribute = mkOption { + type = types.str; + description = "Attribute that lists a user's creation date."; + example = "whenCreated"; + }; + + useEmailPrefixSuffix = mkOption { + type = types.bool; + default = false; + description = "If a user has no email address, combine a username prefix with a suffix value to form an email."; + }; + emailPrefixAttribute = mkOption { + type = types.str; + description = "The attribute that contains the users username."; + example = "accountName"; + }; + emailSuffix = mkOption { + type = types.str; + description = "Suffix for the email, normally @example.com."; + example = "@example.com"; + }; + + users = mkOption { + type = types.bool; + default = false; + description = "Sync users."; + }; + userPath = mkOption { + type = types.str; + description = "User directory, relative to root."; + default = "ou=users"; + }; + userObjectClass = mkOption { + type = types.str; + description = "Class that users must have."; + default = "inetOrgPerson"; + }; + userEmailAttribute = mkOption { + type = types.str; + description = "Attribute for a users email."; + default = "mail"; + }; + userFilter = mkOption { + type = types.str; + description = "LDAP filter for users."; + example = "(memberOf=cn=sales,ou=groups,dc=example,dc=com)"; + default = ""; + }; + + groups = mkOption { + type = types.bool; + default = false; + description = "Whether to sync ldap groups into BitWarden."; + }; + groupPath = mkOption { + type = types.str; + description = "Group directory, relative to root."; + default = "ou=groups"; + }; + groupObjectClass = mkOption { + type = types.str; + description = "A class that groups will have."; + default = "groupOfNames"; + }; + groupNameAttribute = mkOption { + type = types.str; + description = "Attribute for a name of group."; + default = "cn"; + }; + groupFilter = mkOption { + type = types.str; + description = "LDAP filter for groups."; + example = "(cn=sales)"; + default = ""; + }; }; - userPath = mkOption { - type = types.str; - description = "User directory, relative to root."; - default = "ou=users"; - }; - userObjectClass = mkOption { - type = types.str; - description = "Class that users must have."; - default = "inetOrgPerson"; - }; - userEmailAttribute = mkOption { - type = types.str; - description = "Attribute for a users email."; - default = "mail"; - }; - userFilter = mkOption { - type = types.str; - description = "LDAP filter for users."; - example = "(memberOf=cn=sales,ou=groups,dc=example,dc=com)"; - default = ""; - }; - - groups = mkOption { - type = types.bool; - default = false; - description = "Whether to sync ldap groups into BitWarden."; - }; - groupPath = mkOption { - type = types.str; - description = "Group directory, relative to root."; - default = "ou=groups"; - }; - groupObjectClass = mkOption { - type = types.str; - description = "A class that groups will have."; - default = "groupOfNames"; - }; - groupNameAttribute = mkOption { - type = types.str; - description = "Attribute for a name of group."; - default = "cn"; - }; - groupFilter = mkOption { - type = types.str; - description = "LDAP filter for groups."; - example = "(cn=sales)"; - default = ""; - }; - }; - }); + } + ); }; secrets = { @@ -249,7 +265,7 @@ in { }; config = mkIf cfg.enable { - users.groups."${cfg.user}" = {}; + users.groups."${cfg.user}" = { }; users.users."${cfg.user}" = { isSystemUser = true; group = cfg.user; @@ -258,9 +274,9 @@ in { systemd = { timers.bitwarden-directory-connector-cli = { description = "Sync timer for Bitwarden Directory Connector"; - wantedBy = ["timers.target"]; - after = ["network-online.target"]; - wants = ["network-online.target"]; + wantedBy = [ "timers.target" ]; + after = [ "network-online.target" ]; + wants = [ "network-online.target" ]; timerConfig = { OnCalendar = cfg.interval; Unit = "bitwarden-directory-connector-cli.service"; @@ -270,7 +286,7 @@ in { services.bitwarden-directory-connector-cli = { description = "Main process for Bitwarden Directory Connector"; - path = [pkgs.jq]; + path = [ pkgs.jq ]; environment = { BITWARDENCLI_CONNECTOR_APPDATA_DIR = "/tmp"; @@ -319,5 +335,5 @@ in { }; }; - meta.maintainers = with maintainers; [Silver-Golden]; + meta.maintainers = with maintainers; [ Silver-Golden ]; } diff --git a/nixos/modules/services/security/certmgr.nix b/nixos/modules/services/security/certmgr.nix index c6d6e83576c5c1..f3164072b6b517 100644 --- a/nixos/modules/services/security/certmgr.nix +++ b/nixos/modules/services/security/certmgr.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -12,24 +17,29 @@ let allSpecs = pkgs.linkFarm "certmgr.d" specs; - certmgrYaml = pkgs.writeText "certmgr.yaml" (builtins.toJSON { - dir = allSpecs; - default_remote = cfg.defaultRemote; - svcmgr = cfg.svcManager; - before = cfg.validMin; - interval = cfg.renewInterval; - inherit (cfg) metricsPort metricsAddress; - }); - - specPaths = map dirOf (concatMap (spec: - if isAttrs spec then - collect isString (filterAttrsRecursive (n: v: isAttrs v || n == "path") spec) - else - [ spec ] - ) (attrValues cfg.specs)); + certmgrYaml = pkgs.writeText "certmgr.yaml" ( + builtins.toJSON { + dir = allSpecs; + default_remote = cfg.defaultRemote; + svcmgr = cfg.svcManager; + before = cfg.validMin; + interval = cfg.renewInterval; + inherit (cfg) metricsPort metricsAddress; + } + ); + + specPaths = map dirOf ( + concatMap ( + spec: + if isAttrs spec then + collect isString (filterAttrsRecursive (n: v: isAttrs v || n == "path") spec) + else + [ spec ] + ) (attrValues cfg.specs) + ); preStart = '' - ${concatStringsSep " \\\n" (["mkdir -p"] ++ map escapeShellArg specPaths)} + ${concatStringsSep " \\\n" ([ "mkdir -p" ] ++ map escapeShellArg specPaths)} ${cfg.package}/bin/certmgr -f ${certmgrYaml} check ''; in @@ -70,80 +80,92 @@ in }; specs = mkOption { - default = {}; + default = { }; example = literalExpression '' - { - exampleCert = - let - domain = "example.com"; - secret = name: "/var/lib/secrets/''${name}.pem"; - in { - service = "nginx"; - action = "reload"; - authority = { - file.path = secret "ca"; - }; - certificate = { - path = secret domain; - }; - private_key = { - owner = "root"; - group = "root"; - mode = "0600"; - path = secret "''${domain}-key"; - }; - request = { - CN = domain; - hosts = [ "mail.''${domain}" "www.''${domain}" ]; - key = { - algo = "rsa"; - size = 2048; + { + exampleCert = + let + domain = "example.com"; + secret = name: "/var/lib/secrets/''${name}.pem"; + in { + service = "nginx"; + action = "reload"; + authority = { + file.path = secret "ca"; }; - names = { - O = "Example Organization"; - C = "USA"; + certificate = { + path = secret domain; + }; + private_key = { + owner = "root"; + group = "root"; + mode = "0600"; + path = secret "''${domain}-key"; + }; + request = { + CN = domain; + hosts = [ "mail.''${domain}" "www.''${domain}" ]; + key = { + algo = "rsa"; + size = 2048; + }; + names = { + O = "Example Organization"; + C = "USA"; + }; }; }; - }; - otherCert = "/var/certmgr/specs/other-cert.json"; - } + otherCert = "/var/certmgr/specs/other-cert.json"; + } ''; - type = with types; attrsOf (either path (submodule { - options = { - service = mkOption { - type = nullOr str; - default = null; - description = "The service on which to perform \ after fetching."; - }; - - action = mkOption { - type = addCheck str (x: cfg.svcManager == "command" || elem x ["restart" "reload" "nop"]); - default = "nop"; - description = "The action to take after fetching."; - }; - - # These ought all to be specified according to certmgr spec def. - authority = mkOption { - type = attrs; - description = "certmgr spec authority object."; - }; - - certificate = mkOption { - type = nullOr attrs; - description = "certmgr spec certificate object."; - }; - - private_key = mkOption { - type = nullOr attrs; - description = "certmgr spec private_key object."; - }; - - request = mkOption { - type = nullOr attrs; - description = "certmgr spec request object."; - }; - }; - })); + type = + with types; + attrsOf ( + either path (submodule { + options = { + service = mkOption { + type = nullOr str; + default = null; + description = "The service on which to perform \ after fetching."; + }; + + action = mkOption { + type = addCheck str ( + x: + cfg.svcManager == "command" + || elem x [ + "restart" + "reload" + "nop" + ] + ); + default = "nop"; + description = "The action to take after fetching."; + }; + + # These ought all to be specified according to certmgr spec def. + authority = mkOption { + type = attrs; + description = "certmgr spec authority object."; + }; + + certificate = mkOption { + type = nullOr attrs; + description = "certmgr spec certificate object."; + }; + + private_key = mkOption { + type = nullOr attrs; + description = "certmgr spec private_key object."; + }; + + request = mkOption { + type = nullOr attrs; + description = "certmgr spec request object."; + }; + }; + }) + ); description = '' Certificate specs as described by: @@ -153,7 +175,14 @@ in svcManager = mkOption { default = "systemd"; - type = types.enum [ "circus" "command" "dummy" "openrc" "systemd" "sysv" ]; + type = types.enum [ + "circus" + "command" + "dummy" + "openrc" + "systemd" + "sysv" + ]; description = '' This specifies the service manager to use for restarting or reloading services. See: . @@ -167,11 +196,15 @@ in config = mkIf cfg.enable { assertions = [ { - assertion = cfg.specs != {}; + assertion = cfg.specs != { }; message = "Certmgr specs cannot be empty."; } { - assertion = !any (hasAttrByPath [ "authority" "auth_key" ]) (attrValues cfg.specs); + assertion = + !any (hasAttrByPath [ + "authority" + "auth_key" + ]) (attrValues cfg.specs); message = '' Inline services.certmgr.specs are added to the Nix store rendering them world readable. Specify paths as specs, if you want to use include auth_key - or use the auth_key_file option." diff --git a/nixos/modules/services/security/cfssl.nix b/nixos/modules/services/security/cfssl.nix index a6012e78c5b645..9e22121f97f673 100644 --- a/nixos/modules/services/security/cfssl.nix +++ b/nixos/modules/services/security/cfssl.nix @@ -1,10 +1,17 @@ -{ config, options, lib, pkgs, ... }: +{ + config, + options, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.cfssl; -in { +in +{ options.services.cfssl = { enable = mkEnableOption "the CFSSL CA api-server"; @@ -150,7 +157,14 @@ in { logLevel = mkOption { default = 1; - type = types.enum [ 0 1 2 3 4 5 ]; + type = types.enum [ + 0 + 1 + 2 + 3 + 4 + 5 + ]; description = "Log level (0 = DEBUG, 5 = FATAL)."; }; }; @@ -179,9 +193,11 @@ in { User = "cfssl"; Group = "cfssl"; - ExecStart = with cfg; let - opt = n: v: optionalString (v != null) ''-${n}="${v}"''; - in + ExecStart = + with cfg; + let + opt = n: v: optionalString (v != null) ''-${n}="${v}"''; + in lib.concatStringsSep " \\\n" [ "${pkgs.cfssl}/bin/cfssl serve" (opt "address" address) diff --git a/nixos/modules/services/security/endlessh-go.nix b/nixos/modules/services/security/endlessh-go.nix index 9f9225994c7ff5..8a22c01390a65b 100644 --- a/nixos/modules/services/security/endlessh-go.nix +++ b/nixos/modules/services/security/endlessh-go.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -59,7 +64,10 @@ in extraOptions = mkOption { type = with types; listOf str; default = [ ]; - example = [ "-conn_type=tcp4" "-max_clients=8192" ]; + example = [ + "-conn_type=tcp4" + "-max_clients=8192" + ]; description = '' Additional command line options to pass to the endlessh-go daemon. ''; @@ -87,16 +95,22 @@ in in { Restart = "always"; - ExecStart = with cfg; concatStringsSep " " ([ - (lib.getExe cfg.package) - "-logtostderr" - "-host=${listenAddress}" - "-port=${toString port}" - ] ++ optionals prometheus.enable [ - "-enable_prometheus" - "-prometheus_host=${prometheus.listenAddress}" - "-prometheus_port=${toString prometheus.port}" - ] ++ extraOptions); + ExecStart = + with cfg; + concatStringsSep " " ( + [ + (lib.getExe cfg.package) + "-logtostderr" + "-host=${listenAddress}" + "-port=${toString port}" + ] + ++ optionals prometheus.enable [ + "-enable_prometheus" + "-prometheus_host=${prometheus.listenAddress}" + "-prometheus_port=${toString prometheus.port}" + ] + ++ extraOptions + ); DynamicUser = true; RootDirectory = rootDirectory; BindReadOnlyPaths = [ builtins.storeDir ]; @@ -123,17 +137,22 @@ in ProtectProc = "noaccess"; ProcSubset = "pid"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; }; }; - networking.firewall.allowedTCPPorts = with cfg; - optionals openFirewall [ port ]; + networking.firewall.allowedTCPPorts = with cfg; optionals openFirewall [ port ]; }; meta.maintainers = with maintainers; [ azahi ]; diff --git a/nixos/modules/services/security/endlessh.nix b/nixos/modules/services/security/endlessh.nix index cb7480dbeaba0c..479e27d18ccd72 100644 --- a/nixos/modules/services/security/endlessh.nix +++ b/nixos/modules/services/security/endlessh.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -24,7 +29,11 @@ in extraOptions = mkOption { type = with types; listOf str; default = [ ]; - example = [ "-6" "-d 9000" "-v" ]; + example = [ + "-6" + "-d 9000" + "-v" + ]; description = '' Additional command line options to pass to the endlessh daemon. ''; @@ -52,10 +61,15 @@ in in { Restart = "always"; - ExecStart = with cfg; concatStringsSep " " ([ - "${pkgs.endlessh}/bin/endlessh" - "-p ${toString port}" - ] ++ extraOptions); + ExecStart = + with cfg; + concatStringsSep " " ( + [ + "${pkgs.endlessh}/bin/endlessh" + "-p ${toString port}" + ] + ++ extraOptions + ); DynamicUser = true; RootDirectory = rootDirectory; BindReadOnlyPaths = [ builtins.storeDir ]; @@ -82,17 +96,23 @@ in ProtectProc = "noaccess"; ProcSubset = "pid"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@resources" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@resources" + "~@privileged" + ]; }; }; - networking.firewall.allowedTCPPorts = with cfg; - optionals openFirewall [ port ]; + networking.firewall.allowedTCPPorts = with cfg; optionals openFirewall [ port ]; }; meta.maintainers = with maintainers; [ azahi ]; diff --git a/nixos/modules/services/security/esdm.nix b/nixos/modules/services/security/esdm.nix index 835c3b6a090e24..fbce629262751a 100644 --- a/nixos/modules/services/security/esdm.nix +++ b/nixos/modules/services/security/esdm.nix @@ -1,4 +1,9 @@ -{ lib, config, pkgs, ... }: +{ + lib, + config, + pkgs, + ... +}: let cfg = config.services.esdm; @@ -44,10 +49,22 @@ in # It is necessary to set those options for these services to be started by systemd in NixOS (lib.mkIf cfg.enableLinuxCompatServices { systemd.targets."esdm-linux-compat".wantedBy = [ "basic.target" ]; - systemd.services."esdm-server-suspend".wantedBy = [ "sleep.target" "suspend.target" "hibernate.target" ]; - systemd.services."esdm-server-resume".wantedBy = [ "sleep.target" "suspend.target" "hibernate.target" ]; + systemd.services."esdm-server-suspend".wantedBy = [ + "sleep.target" + "suspend.target" + "hibernate.target" + ]; + systemd.services."esdm-server-resume".wantedBy = [ + "sleep.target" + "suspend.target" + "hibernate.target" + ]; }) - ]); + ] + ); - meta.maintainers = with lib.maintainers; [ orichter thillux ]; + meta.maintainers = with lib.maintainers; [ + orichter + thillux + ]; } diff --git a/nixos/modules/services/security/fail2ban.nix b/nixos/modules/services/security/fail2ban.nix index 8be2faa5754d75..d006f08f121a4a 100644 --- a/nixos/modules/services/security/fail2ban.nix +++ b/nixos/modules/services/security/fail2ban.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -11,14 +16,19 @@ let mkKeyValue = generators.mkKeyValueDefault { } " = "; }; - mkJailConfig = name: attrs: - optionalAttrs (name != "DEFAULT") { inherit (attrs) enabled; } // - optionalAttrs (attrs.filter != null) { filter = if (builtins.isString filter) then filter else name; } // - attrs.settings; - - mkFilter = name: attrs: nameValuePair "fail2ban/filter.d/${name}.conf" { - source = configFormat.generate "filter.d/${name}.conf" attrs.filter; - }; + mkJailConfig = + name: attrs: + optionalAttrs (name != "DEFAULT") { inherit (attrs) enabled; } + // optionalAttrs (attrs.filter != null) { + filter = if (builtins.isString filter) then filter else name; + } + // attrs.settings; + + mkFilter = + name: attrs: + nameValuePair "fail2ban/filter.d/${name}.conf" { + source = configFormat.generate "filter.d/${name}.conf" attrs.filter; + }; fail2banConf = configFormat.generate "fail2ban.local" cfg.daemonSettings; @@ -30,17 +40,23 @@ let configFile = configFormat.generate "jail.local" ( { INCLUDES.before = "paths-nixos.conf"; } // (mapAttrs mkJailConfig attrsJails) ); - extraConfig = concatStringsSep "\n" (attrValues (mapAttrs - (name: def: - optionalString (def != "") - '' + extraConfig = concatStringsSep "\n" ( + attrValues ( + mapAttrs ( + name: def: + optionalString (def != "") '' [${name}] ${def} - '') - strJails)); + '' + ) strJails + ) + ); in - pkgs.concatText "jail.local" [ configFile (pkgs.writeText "extra-jail.local" extraConfig) ]; + pkgs.concatText "jail.local" [ + configFile + (pkgs.writeText "extra-jail.local" extraConfig) + ]; pathsConf = pkgs.writeText "paths-nixos.conf" '' # NixOS @@ -58,8 +74,14 @@ in { imports = [ - (mkRemovedOptionModule [ "services" "fail2ban" "daemonConfig" ] "The daemon is now configured through the attribute set `services.fail2ban.daemonSettings`.") - (mkRemovedOptionModule [ "services" "fail2ban" "extraSettings" ] "The extra default configuration can now be set using `services.fail2ban.jails.DEFAULT.settings`.") + (mkRemovedOptionModule [ + "services" + "fail2ban" + "daemonConfig" + ] "The daemon is now configured through the attribute set `services.fail2ban.daemonSettings`.") + (mkRemovedOptionModule [ "services" "fail2ban" "extraSettings" ] + "The extra default configuration can now be set using `services.fail2ban.jails.DEFAULT.settings`." + ) ]; ###### interface @@ -207,7 +229,10 @@ in ignoreIP = mkOption { default = [ ]; type = types.listOf types.str; - example = [ "192.168.0.0/16" "2001:DB8::42" ]; + example = [ + "192.168.0.0/16" + "2001:DB8::42" + ]; description = '' "ignoreIP" can be a list of IP addresses, CIDR masks or DNS hosts. Fail2ban will not ban a host which matches an address in this list. Several addresses can be defined using space (and/or comma) separator. @@ -261,28 +286,37 @@ in }; }; ''; - type = with types; attrsOf (either lines (submodule ({ name, ... }: { - options = { - enabled = mkEnableOption "this jail" // { - default = true; - readOnly = name == "DEFAULT"; - }; - - filter = mkOption { - type = nullOr (either str configFormat.type); - - default = null; - description = "Content of the filter used for this jail."; - }; - - settings = mkOption { - inherit (settingsFormat) type; - - default = { }; - description = "Additional settings for this jail."; - }; - }; - }))); + type = + with types; + attrsOf ( + either lines ( + submodule ( + { name, ... }: + { + options = { + enabled = mkEnableOption "this jail" // { + default = true; + readOnly = name == "DEFAULT"; + }; + + filter = mkOption { + type = nullOr (either str configFormat.type); + + default = null; + description = "Content of the filter used for this jail."; + }; + + settings = mkOption { + inherit (settingsFormat) type; + + default = { }; + description = "Additional settings for this jail."; + }; + }; + } + ) + ) + ); description = '' The configuration of each Fail2ban “jail”. A jail consists of an action (such as blocking a port using @@ -326,29 +360,46 @@ in environment.systemPackages = [ cfg.package ]; - environment.etc = { - "fail2ban/fail2ban.local".source = fail2banConf; - "fail2ban/jail.local".source = jailConf; - "fail2ban/fail2ban.conf".source = "${cfg.package}/etc/fail2ban/fail2ban.conf"; - "fail2ban/jail.conf".source = "${cfg.package}/etc/fail2ban/jail.conf"; - "fail2ban/paths-common.conf".source = "${cfg.package}/etc/fail2ban/paths-common.conf"; - "fail2ban/paths-nixos.conf".source = pathsConf; - "fail2ban/action.d".source = "${cfg.package}/etc/fail2ban/action.d/*.conf"; - "fail2ban/filter.d".source = "${cfg.package}/etc/fail2ban/filter.d/*.conf"; - } // (mapAttrs' mkFilter (filterAttrs (_: v: v.filter != null && !builtins.isString v.filter) attrsJails)); + environment.etc = + { + "fail2ban/fail2ban.local".source = fail2banConf; + "fail2ban/jail.local".source = jailConf; + "fail2ban/fail2ban.conf".source = "${cfg.package}/etc/fail2ban/fail2ban.conf"; + "fail2ban/jail.conf".source = "${cfg.package}/etc/fail2ban/jail.conf"; + "fail2ban/paths-common.conf".source = "${cfg.package}/etc/fail2ban/paths-common.conf"; + "fail2ban/paths-nixos.conf".source = pathsConf; + "fail2ban/action.d".source = "${cfg.package}/etc/fail2ban/action.d/*.conf"; + "fail2ban/filter.d".source = "${cfg.package}/etc/fail2ban/filter.d/*.conf"; + } + // (mapAttrs' mkFilter ( + filterAttrs (_: v: v.filter != null && !builtins.isString v.filter) attrsJails + )); systemd.packages = [ cfg.package ]; systemd.services.fail2ban = { wantedBy = [ "multi-user.target" ]; partOf = optional config.networking.firewall.enable "firewall.service"; - restartTriggers = [ fail2banConf jailConf pathsConf ]; + restartTriggers = [ + fail2banConf + jailConf + pathsConf + ]; - path = [ cfg.package cfg.packageFirewall pkgs.iproute2 ] ++ cfg.extraPackages; + path = [ + cfg.package + cfg.packageFirewall + pkgs.iproute2 + ] ++ cfg.extraPackages; serviceConfig = { # Capabilities - CapabilityBoundingSet = [ "CAP_AUDIT_READ" "CAP_DAC_READ_SEARCH" "CAP_NET_ADMIN" "CAP_NET_RAW" ]; + CapabilityBoundingSet = [ + "CAP_AUDIT_READ" + "CAP_DAC_READ_SEARCH" + "CAP_NET_ADMIN" + "CAP_NET_RAW" + ]; # Security NoNewPrivileges = true; # Directory @@ -382,24 +433,30 @@ in # sets default values for all other jails. services.fail2ban.jails = mkMerge [ { - DEFAULT.settings = (optionalAttrs cfg.bantime-increment.enable - ({ "bantime.increment" = cfg.bantime-increment.enable; } // (mapAttrs' - (name: nameValuePair "bantime.${name}") - (filterAttrs (n: v: v != null && n != "enable") cfg.bantime-increment)) - ) - ) // { - # Miscellaneous options - inherit (cfg) banaction maxretry bantime; - ignoreip = ''127.0.0.1/8 ${optionalString config.networking.enableIPv6 "::1"} ${concatStringsSep " " cfg.ignoreIP}''; - backend = "systemd"; - # Actions - banaction_allports = cfg.banaction-allports; - }; + DEFAULT.settings = + (optionalAttrs cfg.bantime-increment.enable ( + { + "bantime.increment" = cfg.bantime-increment.enable; + } + // (mapAttrs' (name: nameValuePair "bantime.${name}") ( + filterAttrs (n: v: v != null && n != "enable") cfg.bantime-increment + )) + )) + // { + # Miscellaneous options + inherit (cfg) banaction maxretry bantime; + ignoreip = ''127.0.0.1/8 ${optionalString config.networking.enableIPv6 "::1"} ${concatStringsSep " " cfg.ignoreIP}''; + backend = "systemd"; + # Actions + banaction_allports = cfg.banaction-allports; + }; } # Block SSH if there are too many failing connection attempts. (mkIf config.services.openssh.enable { - sshd.settings.port = mkDefault (concatMapStringsSep "," builtins.toString config.services.openssh.ports); + sshd.settings.port = mkDefault ( + concatMapStringsSep "," builtins.toString config.services.openssh.ports + ); }) ]; diff --git a/nixos/modules/services/security/haka.nix b/nixos/modules/services/security/haka.nix index 4a6325d65ad146..05bb6025e5ec33 100644 --- a/nixos/modules/services/security/haka.nix +++ b/nixos/modules/services/security/haka.nix @@ -1,6 +1,11 @@ # This module defines global configuration for Haka. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -10,12 +15,14 @@ let haka = cfg.package; - hakaConf = pkgs.writeText "haka.conf" - '' + hakaConf = pkgs.writeText "haka.conf" '' [general] - configuration = ${if lib.strings.hasPrefix "/" cfg.configFile - then "${cfg.configFile}" - else "${haka}/share/haka/sample/${cfg.configFile}"} + configuration = ${ + if lib.strings.hasPrefix "/" cfg.configFile then + "${cfg.configFile}" + else + "${haka}/share/haka/sample/${cfg.configFile}" + } ${optionalString (builtins.lessThan 0 cfg.threads) "thread = ${cfg.threads}"} [packet] @@ -99,14 +106,14 @@ in nfqueue = mkEnableOption "nfqueue"; dump.enable = mkEnableOption "dump"; - dump.input = mkOption { + dump.input = mkOption { default = "/tmp/input.pcap"; example = "/path/to/file.pcap"; type = types.path; description = "Path to file where incoming packets are dumped"; }; - dump.output = mkOption { + dump.output = mkOption { default = "/tmp/output.pcap"; example = "/path/to/file.pcap"; type = types.path; @@ -115,22 +122,24 @@ in }; }; - ###### implementation config = mkIf cfg.enable { assertions = [ - { assertion = cfg.pcap != cfg.nfqueue; + { + assertion = cfg.pcap != cfg.nfqueue; message = "either pcap or nfqueue can be enabled, not both."; } - { assertion = cfg.nfqueue -> !cfg.dump.enable; + { + assertion = cfg.nfqueue -> !cfg.dump.enable; message = "dump can only be used with nfqueue."; } - { assertion = cfg.interfaces != []; + { + assertion = cfg.interfaces != [ ]; message = "at least one interface must be specified."; - }]; - + } + ]; environment.systemPackages = [ haka ]; diff --git a/nixos/modules/services/security/haveged.nix b/nixos/modules/services/security/haveged.nix index 4c686d74268af0..778877825bb6a1 100644 --- a/nixos/modules/services/security/haveged.nix +++ b/nixos/modules/services/security/haveged.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -46,14 +51,21 @@ in }; wantedBy = [ "sysinit.target" ]; after = [ "systemd-tmpfiles-setup-dev.service" ]; - before = [ "sysinit.target" "shutdown.target" "systemd-journald.service" ]; + before = [ + "sysinit.target" + "shutdown.target" + "systemd-journald.service" + ]; serviceConfig = { ExecStart = "${pkgs.haveged}/bin/haveged -w ${toString cfg.refill_threshold} --Foreground -v 1"; Restart = "always"; SuccessExitStatus = "137 143"; SecureBits = "noroot-locked"; - CapabilityBoundingSet = [ "CAP_SYS_ADMIN" "CAP_SYS_CHROOT" ]; + CapabilityBoundingSet = [ + "CAP_SYS_ADMIN" + "CAP_SYS_CHROOT" + ]; # We can *not* set PrivateTmp=true as it can cause an ordering cycle. PrivateTmp = false; PrivateDevices = true; @@ -67,7 +79,11 @@ in LockPersonality = true; MemoryDenyWriteExecute = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "newuname" "~@mount" ]; + SystemCallFilter = [ + "@system-service" + "newuname" + "~@mount" + ]; SystemCallErrorNumber = "EPERM"; }; diff --git a/nixos/modules/services/security/hockeypuck.nix b/nixos/modules/services/security/hockeypuck.nix index 2e7d6ef5b0e324..4352241a1ae9be 100644 --- a/nixos/modules/services/security/hockeypuck.nix +++ b/nixos/modules/services/security/hockeypuck.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hockeypuck; settingsFormat = pkgs.formats.toml { }; -in { +in +{ meta.maintainers = with lib.maintainers; [ etu ]; options.services.hockeypuck = { @@ -85,11 +91,14 @@ in { group = "hockeypuck"; description = "Hockeypuck user"; }; - users.groups.hockeypuck = {}; + users.groups.hockeypuck = { }; systemd.services.hockeypuck = { description = "Hockeypuck OpenPGP Key Server"; - after = [ "network.target" "postgresql.target" ]; + after = [ + "network.target" + "postgresql.target" + ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { WorkingDirectory = "/var/lib/hockeypuck"; diff --git a/nixos/modules/services/security/hologram-agent.nix b/nixos/modules/services/security/hologram-agent.nix index a2cf9611d677bc..e28efd1d12f6c0 100644 --- a/nixos/modules/services/security/hologram-agent.nix +++ b/nixos/modules/services/security/hologram-agent.nix @@ -1,14 +1,22 @@ -{pkgs, config, lib, ...}: +{ + pkgs, + config, + lib, + ... +}: with lib; let cfg = config.services.hologram-agent; - cfgFile = pkgs.writeText "hologram-agent.json" (builtins.toJSON { - host = cfg.dialAddress; - }); -in { + cfgFile = pkgs.writeText "hologram-agent.json" ( + builtins.toJSON { + host = cfg.dialAddress; + } + ); +in +{ options = { services.hologram-agent = { enable = mkOption { @@ -18,14 +26,14 @@ in { }; dialAddress = mkOption { - type = types.str; - default = "localhost:3100"; + type = types.str; + default = "localhost:3100"; description = "Hologram server and port."; }; httpPort = mkOption { - type = types.str; - default = "80"; + type = types.str; + default = "80"; description = "Port for metadata service to listen on."; }; @@ -36,14 +44,20 @@ in { boot.kernelModules = [ "dummy" ]; networking.interfaces.dummy0.ipv4.addresses = [ - { address = "169.254.169.254"; prefixLength = 32; } + { + address = "169.254.169.254"; + prefixLength = 32; + } ]; systemd.services.hologram-agent = { description = "Provide EC2 instance credentials to machines outside of EC2"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - requires = [ "network-link-dummy0.service" "network-addresses-dummy0.service" ]; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + requires = [ + "network-link-dummy0.service" + "network-addresses-dummy0.service" + ]; preStart = '' /run/current-system/sw/bin/rm -fv /run/hologram.sock ''; diff --git a/nixos/modules/services/security/hologram-server.nix b/nixos/modules/services/security/hologram-server.nix index 4acf6ae0e21820..58e2e58e9c0bb2 100644 --- a/nixos/modules/services/security/hologram-server.nix +++ b/nixos/modules/services/security/hologram-server.nix @@ -1,33 +1,41 @@ -{pkgs, config, lib, ...}: +{ + pkgs, + config, + lib, + ... +}: with lib; let cfg = config.services.hologram-server; - cfgFile = pkgs.writeText "hologram-server.json" (builtins.toJSON { - ldap = { - host = cfg.ldapHost; - bind = { - dn = cfg.ldapBindDN; - password = cfg.ldapBindPassword; - }; - insecureldap = cfg.ldapInsecure; - userattr = cfg.ldapUserAttr; - baseDN = cfg.ldapBaseDN; - enableldapRoles = cfg.enableLdapRoles; - roleAttr = cfg.roleAttr; - groupClassAttr = cfg.groupClassAttr; - }; - aws = { - account = cfg.awsAccount; - defaultrole = cfg.awsDefaultRole; - }; - stats = cfg.statsAddress; - listen = cfg.listenAddress; - cachetimeout = cfg.cacheTimeoutSeconds; - }); -in { + cfgFile = pkgs.writeText "hologram-server.json" ( + builtins.toJSON { + ldap = { + host = cfg.ldapHost; + bind = { + dn = cfg.ldapBindDN; + password = cfg.ldapBindPassword; + }; + insecureldap = cfg.ldapInsecure; + userattr = cfg.ldapUserAttr; + baseDN = cfg.ldapBaseDN; + enableldapRoles = cfg.enableLdapRoles; + roleAttr = cfg.roleAttr; + groupClassAttr = cfg.groupClassAttr; + }; + aws = { + account = cfg.awsAccount; + defaultrole = cfg.awsDefaultRole; + }; + stats = cfg.statsAddress; + listen = cfg.listenAddress; + cachetimeout = cfg.cacheTimeoutSeconds; + } + ); +in +{ options = { services.hologram-server = { enable = mkOption { @@ -37,46 +45,46 @@ in { }; listenAddress = mkOption { - type = types.str; - default = "0.0.0.0:3100"; + type = types.str; + default = "0.0.0.0:3100"; description = "Address and port to listen on"; }; ldapHost = mkOption { - type = types.str; + type = types.str; description = "Address of the LDAP server to use"; }; ldapInsecure = mkOption { - type = types.bool; - default = false; + type = types.bool; + default = false; description = "Whether to connect to LDAP over SSL or not"; }; ldapUserAttr = mkOption { - type = types.str; - default = "cn"; + type = types.str; + default = "cn"; description = "The LDAP attribute for usernames"; }; ldapBaseDN = mkOption { - type = types.str; + type = types.str; description = "The base DN for your Hologram users"; }; ldapBindDN = mkOption { - type = types.str; + type = types.str; description = "DN of account to use to query the LDAP server"; }; ldapBindPassword = mkOption { - type = types.str; + type = types.str; description = "Password of account to use to query the LDAP server"; }; enableLdapRoles = mkOption { - type = types.bool; - default = false; + type = types.bool; + default = false; description = "Whether to assign user roles based on the user's LDAP group memberships"; }; @@ -87,30 +95,30 @@ in { }; roleAttr = mkOption { - type = types.str; - default = "businessCategory"; + type = types.str; + default = "businessCategory"; description = "Which LDAP group attribute to search for authorized role ARNs"; }; awsAccount = mkOption { - type = types.str; + type = types.str; description = "AWS account number"; }; awsDefaultRole = mkOption { - type = types.str; + type = types.str; description = "AWS default role"; }; statsAddress = mkOption { - type = types.str; - default = ""; + type = types.str; + default = ""; description = "Address of statsd server"; }; cacheTimeoutSeconds = mkOption { - type = types.int; - default = 3600; + type = types.int; + default = 3600; description = "How often (in seconds) to refresh the LDAP cache"; }; }; @@ -119,8 +127,8 @@ in { config = mkIf cfg.enable { systemd.services.hologram-server = { description = "Provide EC2 instance credentials to machines outside of EC2"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; serviceConfig = { ExecStart = "${pkgs.hologram}/bin/hologram-server --debug --conf ${cfgFile}"; diff --git a/nixos/modules/services/security/infnoise.nix b/nixos/modules/services/security/infnoise.nix index 4fb8adaf33f894..36dce8bb3e038c 100644 --- a/nixos/modules/services/security/infnoise.nix +++ b/nixos/modules/services/security/infnoise.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.infnoise; -in { +in +{ options = { services.infnoise = { enable = mkEnableOption "the Infinite Noise TRNG driver"; diff --git a/nixos/modules/services/security/intune.nix b/nixos/modules/services/security/intune.nix index c0f1ca77031dcc..59ae735a1a8cad 100644 --- a/nixos/modules/services/security/intune.nix +++ b/nixos/modules/services/security/intune.nix @@ -1,7 +1,8 @@ -{ config -, pkgs -, lib -, ... +{ + config, + pkgs, + lib, + ... }: let cfg = config.services.intune; @@ -11,7 +12,6 @@ in enable = lib.mkEnableOption "Microsoft Intune"; }; - config = lib.mkIf cfg.enable { users.users.microsoft-identity-broker = { group = "microsoft-identity-broker"; @@ -19,8 +19,14 @@ in }; users.groups.microsoft-identity-broker = { }; - environment.systemPackages = [ pkgs.microsoft-identity-broker pkgs.intune-portal ]; - systemd.packages = [ pkgs.microsoft-identity-broker pkgs.intune-portal ]; + environment.systemPackages = [ + pkgs.microsoft-identity-broker + pkgs.intune-portal + ]; + systemd.packages = [ + pkgs.microsoft-identity-broker + pkgs.intune-portal + ]; systemd.tmpfiles.packages = [ pkgs.intune-portal ]; services.dbus.packages = [ pkgs.microsoft-identity-broker ]; diff --git a/nixos/modules/services/security/jitterentropy-rngd.nix b/nixos/modules/services/security/jitterentropy-rngd.nix index 104aeccebc9ccc..190250a0236640 100644 --- a/nixos/modules/services/security/jitterentropy-rngd.nix +++ b/nixos/modules/services/security/jitterentropy-rngd.nix @@ -1,11 +1,15 @@ -{ lib, config, pkgs, ... }: +{ + lib, + config, + pkgs, + ... +}: let cfg = config.services.jitterentropy-rngd; in { options.services.jitterentropy-rngd = { - enable = - lib.mkEnableOption "jitterentropy-rngd service configuration"; + enable = lib.mkEnableOption "jitterentropy-rngd service configuration"; package = lib.mkPackageOption pkgs "jitterentropy-rngd" { }; }; diff --git a/nixos/modules/services/security/munge.nix b/nixos/modules/services/security/munge.nix index e124f098bfbd36..16481f116532e5 100644 --- a/nixos/modules/services/security/munge.nix +++ b/nixos/modules/services/security/munge.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -36,12 +41,12 @@ in environment.systemPackages = [ pkgs.munge ]; users.users.munge = { - description = "Munge daemon user"; - isSystemUser = true; - group = "munge"; + description = "Munge daemon user"; + isSystemUser = true; + group = "munge"; }; - users.groups.munge = {}; + users.groups.munge = { }; systemd.services.munged = { wantedBy = [ "multi-user.target" ]; @@ -54,7 +59,10 @@ in "time-sync.target" ]; - path = [ pkgs.munge pkgs.coreutils ]; + path = [ + pkgs.munge + pkgs.coreutils + ]; serviceConfig = { ExecStartPre = "+${pkgs.coreutils}/bin/chmod 0400 ${cfg.password}"; diff --git a/nixos/modules/services/security/oauth2-proxy-nginx.nix b/nixos/modules/services/security/oauth2-proxy-nginx.nix index 2dffeb993803ff..af1878cd09dc60 100644 --- a/nixos/modules/services/security/oauth2-proxy-nginx.nix +++ b/nixos/modules/services/security/oauth2-proxy-nginx.nix @@ -24,37 +24,43 @@ in }; virtualHosts = lib.mkOption { - type = let - vhostSubmodule = lib.types.submodule { - options = { - allowed_groups = lib.mkOption { - type = lib.types.nullOr (lib.types.listOf lib.types.str); - description = "List of groups to allow access to this vhost, or null to allow all."; - default = null; - }; - allowed_emails = lib.mkOption { - type = lib.types.nullOr (lib.types.listOf lib.types.str); - description = "List of emails to allow access to this vhost, or null to allow all."; - default = null; - }; - allowed_email_domains = lib.mkOption { - type = lib.types.nullOr (lib.types.listOf lib.types.str); - description = "List of email domains to allow access to this vhost, or null to allow all."; - default = null; + type = + let + vhostSubmodule = lib.types.submodule { + options = { + allowed_groups = lib.mkOption { + type = lib.types.nullOr (lib.types.listOf lib.types.str); + description = "List of groups to allow access to this vhost, or null to allow all."; + default = null; + }; + allowed_emails = lib.mkOption { + type = lib.types.nullOr (lib.types.listOf lib.types.str); + description = "List of emails to allow access to this vhost, or null to allow all."; + default = null; + }; + allowed_email_domains = lib.mkOption { + type = lib.types.nullOr (lib.types.listOf lib.types.str); + description = "List of email domains to allow access to this vhost, or null to allow all."; + default = null; + }; }; }; - }; - oldType = lib.types.listOf lib.types.str; - convertFunc = x: - lib.warn "services.oauth2-proxy.nginx.virtualHosts should be an attrset, found ${lib.generators.toPretty {} x}" - lib.genAttrs x (_: {}); - newType = lib.types.attrsOf vhostSubmodule; - in lib.types.coercedTo oldType convertFunc newType; - default = {}; + oldType = lib.types.listOf lib.types.str; + convertFunc = + x: + lib.warn + "services.oauth2-proxy.nginx.virtualHosts should be an attrset, found ${lib.generators.toPretty { } x}" + lib.genAttrs + x + (_: { }); + newType = lib.types.attrsOf vhostSubmodule; + in + lib.types.coercedTo oldType convertFunc newType; + default = { }; example = { "protected.foo.com" = { - allowed_groups = ["admins"]; - allowed_emails = ["boss@foo.com"]; + allowed_groups = [ "admins" ]; + allowed_emails = [ "boss@foo.com" ]; }; }; description = '' @@ -64,72 +70,85 @@ in }; }; - config.services.oauth2-proxy = lib.mkIf (cfg.virtualHosts != {} && (lib.hasPrefix "127.0.0.1:" cfg.proxy)) { - enable = true; - }; - - config.services.nginx = lib.mkIf (cfg.virtualHosts != {} && config.services.oauth2-proxy.enable) (lib.mkMerge ([ - { - virtualHosts.${cfg.domain}.locations."/oauth2/" = { - proxyPass = cfg.proxy; - extraConfig = '' - auth_request off; - proxy_set_header X-Scheme $scheme; - proxy_set_header X-Auth-Request-Redirect $scheme://$host$request_uri; - ''; + config.services.oauth2-proxy = + lib.mkIf (cfg.virtualHosts != { } && (lib.hasPrefix "127.0.0.1:" cfg.proxy)) + { + enable = true; }; - } - ] ++ lib.optional (cfg.virtualHosts != {}) { - recommendedProxySettings = true; # needed because duplicate headers - } ++ (lib.mapAttrsToList (vhost: conf: { - virtualHosts.${vhost} = { - locations = { - "/".extraConfig = '' - # pass information via X-User and X-Email headers to backend, requires running with --set-xauthrequest flag - proxy_set_header X-User $user; - proxy_set_header X-Email $email; - # if you enabled --cookie-refresh, this is needed for it to work with auth_request - add_header Set-Cookie $auth_cookie; - ''; + config.services.nginx = lib.mkIf (cfg.virtualHosts != { } && config.services.oauth2-proxy.enable) ( + lib.mkMerge ( + [ + { + virtualHosts.${cfg.domain}.locations."/oauth2/" = { + proxyPass = cfg.proxy; + extraConfig = '' + auth_request off; + proxy_set_header X-Scheme $scheme; + proxy_set_header X-Auth-Request-Redirect $scheme://$host$request_uri; + ''; + }; + } + ] + ++ lib.optional (cfg.virtualHosts != { }) { + recommendedProxySettings = true; # needed because duplicate headers + } + ++ (lib.mapAttrsToList (vhost: conf: { + virtualHosts.${vhost} = { + locations = { + "/".extraConfig = '' + # pass information via X-User and X-Email headers to backend, requires running with --set-xauthrequest flag + proxy_set_header X-User $user; + proxy_set_header X-Email $email; - "/oauth2/auth" = let - maybeQueryArg = name: value: - if value == null then null - else "${name}=${lib.concatStringsSep "," (builtins.map lib.escapeURL value)}"; - allArgs = lib.mapAttrsToList maybeQueryArg conf; - cleanArgs = builtins.filter (x: x != null) allArgs; - cleanArgsStr = lib.concatStringsSep "&" cleanArgs; - in { - # nginx doesn't support passing query string arguments to auth_request, - # so pass them here instead - proxyPass = "${cfg.proxy}/oauth2/auth?${cleanArgsStr}"; - extraConfig = '' - auth_request off; - proxy_set_header X-Scheme $scheme; - # nginx auth_request includes headers but not body - proxy_set_header Content-Length ""; - proxy_pass_request_body off; - ''; - }; + # if you enabled --cookie-refresh, this is needed for it to work with auth_request + add_header Set-Cookie $auth_cookie; + ''; + + "/oauth2/auth" = + let + maybeQueryArg = + name: value: + if value == null then + null + else + "${name}=${lib.concatStringsSep "," (builtins.map lib.escapeURL value)}"; + allArgs = lib.mapAttrsToList maybeQueryArg conf; + cleanArgs = builtins.filter (x: x != null) allArgs; + cleanArgsStr = lib.concatStringsSep "&" cleanArgs; + in + { + # nginx doesn't support passing query string arguments to auth_request, + # so pass them here instead + proxyPass = "${cfg.proxy}/oauth2/auth?${cleanArgsStr}"; + extraConfig = '' + auth_request off; + proxy_set_header X-Scheme $scheme; + # nginx auth_request includes headers but not body + proxy_set_header Content-Length ""; + proxy_pass_request_body off; + ''; + }; + + "@redirectToAuth2ProxyLogin" = { + return = "307 https://${cfg.domain}/oauth2/start?rd=$scheme://$host$request_uri"; + extraConfig = '' + auth_request off; + ''; + }; + }; - "@redirectToAuth2ProxyLogin" = { - return = "307 https://${cfg.domain}/oauth2/start?rd=$scheme://$host$request_uri"; extraConfig = '' - auth_request off; + auth_request /oauth2/auth; + error_page 401 = @redirectToAuth2ProxyLogin; + + # set variables being used in locations."/".extraConfig + auth_request_set $user $upstream_http_x_auth_request_user; + auth_request_set $email $upstream_http_x_auth_request_email; + auth_request_set $auth_cookie $upstream_http_set_cookie; ''; }; - }; - - extraConfig = '' - auth_request /oauth2/auth; - error_page 401 = @redirectToAuth2ProxyLogin; - - # set variables being used in locations."/".extraConfig - auth_request_set $user $upstream_http_x_auth_request_user; - auth_request_set $email $upstream_http_x_auth_request_email; - auth_request_set $auth_cookie $upstream_http_set_cookie; - ''; - }; - }) cfg.virtualHosts))); + }) cfg.virtualHosts) + ) + ); } diff --git a/nixos/modules/services/security/oauth2-proxy.nix b/nixos/modules/services/security/oauth2-proxy.nix index 38da06e1538ab6..658a356cc51cee 100644 --- a/nixos/modules/services/security/oauth2-proxy.nix +++ b/nixos/modules/services/security/oauth2-proxy.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.oauth2-proxy; @@ -13,71 +18,99 @@ let resource = cfg.azure.resource; }; - github = cfg: { github = { - inherit (cfg.github) org team; - }; }; + github = cfg: { + github = { + inherit (cfg.github) org team; + }; + }; - google = cfg: { google = with cfg.google; lib.optionalAttrs (groups != []) { - admin-email = adminEmail; - service-account = serviceAccountJSON; - group = groups; - }; }; + google = cfg: { + google = + with cfg.google; + lib.optionalAttrs (groups != [ ]) { + admin-email = adminEmail; + service-account = serviceAccountJSON; + group = groups; + }; + }; }; authenticatedEmailsFile = pkgs.writeText "authenticated-emails" cfg.email.addresses; - getProviderOptions = cfg: provider: providerSpecificOptions.${provider} or (_: {}) cfg; - - allConfig = with cfg; { - inherit (cfg) provider scope upstream; - approval-prompt = approvalPrompt; - basic-auth-password = basicAuthPassword; - client-id = clientID; - client-secret = clientSecret; - custom-templates-dir = customTemplatesDir; - email-domain = email.domains; - http-address = httpAddress; - login-url = loginURL; - pass-access-token = passAccessToken; - pass-basic-auth = passBasicAuth; - pass-host-header = passHostHeader; - reverse-proxy = reverseProxy; - proxy-prefix = proxyPrefix; - profile-url = profileURL; - oidc-issuer-url = oidcIssuerUrl; - redeem-url = redeemURL; - redirect-url = redirectURL; - request-logging = requestLogging; - skip-auth-regex = skipAuthRegexes; - signature-key = signatureKey; - validate-url = validateURL; - htpasswd-file = htpasswd.file; - cookie = { - inherit (cookie) domain secure expire name secret refresh; - httponly = cookie.httpOnly; - }; - set-xauthrequest = setXauthrequest; - } // lib.optionalAttrs (cfg.email.addresses != null) { - authenticated-emails-file = authenticatedEmailsFile; - } // lib.optionalAttrs (cfg.passBasicAuth) { - basic-auth-password = cfg.basicAuthPassword; - } // lib.optionalAttrs (cfg.htpasswd.file != null) { - display-htpasswd-form = cfg.htpasswd.displayForm; - } // lib.optionalAttrs tls.enable { - tls-cert-file = tls.certificate; - tls-key-file = tls.key; - https-address = tls.httpsAddress; - } // (getProviderOptions cfg cfg.provider) // cfg.extraConfig; - - mapConfig = key: attr: - lib.optionalString (attr != null && attr != []) ( - if lib.isDerivation attr then mapConfig key (toString attr) else - if (builtins.typeOf attr) == "set" then lib.concatStringsSep " " - (lib.mapAttrsToList (name: value: mapConfig (key + "-" + name) value) attr) else - if (builtins.typeOf attr) == "list" then lib.concatMapStringsSep " " (mapConfig key) attr else - if (builtins.typeOf attr) == "bool" then "--${key}=${lib.boolToString attr}" else - if (builtins.typeOf attr) == "string" then "--${key}='${attr}'" else - "--${key}=${toString attr}"); + getProviderOptions = cfg: provider: providerSpecificOptions.${provider} or (_: { }) cfg; + + allConfig = + with cfg; + { + inherit (cfg) provider scope upstream; + approval-prompt = approvalPrompt; + basic-auth-password = basicAuthPassword; + client-id = clientID; + client-secret = clientSecret; + custom-templates-dir = customTemplatesDir; + email-domain = email.domains; + http-address = httpAddress; + login-url = loginURL; + pass-access-token = passAccessToken; + pass-basic-auth = passBasicAuth; + pass-host-header = passHostHeader; + reverse-proxy = reverseProxy; + proxy-prefix = proxyPrefix; + profile-url = profileURL; + oidc-issuer-url = oidcIssuerUrl; + redeem-url = redeemURL; + redirect-url = redirectURL; + request-logging = requestLogging; + skip-auth-regex = skipAuthRegexes; + signature-key = signatureKey; + validate-url = validateURL; + htpasswd-file = htpasswd.file; + cookie = { + inherit (cookie) + domain + secure + expire + name + secret + refresh + ; + httponly = cookie.httpOnly; + }; + set-xauthrequest = setXauthrequest; + } + // lib.optionalAttrs (cfg.email.addresses != null) { + authenticated-emails-file = authenticatedEmailsFile; + } + // lib.optionalAttrs (cfg.passBasicAuth) { + basic-auth-password = cfg.basicAuthPassword; + } + // lib.optionalAttrs (cfg.htpasswd.file != null) { + display-htpasswd-form = cfg.htpasswd.displayForm; + } + // lib.optionalAttrs tls.enable { + tls-cert-file = tls.certificate; + tls-key-file = tls.key; + https-address = tls.httpsAddress; + } + // (getProviderOptions cfg cfg.provider) + // cfg.extraConfig; + + mapConfig = + key: attr: + lib.optionalString (attr != null && attr != [ ]) ( + if lib.isDerivation attr then + mapConfig key (toString attr) + else if (builtins.typeOf attr) == "set" then + lib.concatStringsSep " " (lib.mapAttrsToList (name: value: mapConfig (key + "-" + name) value) attr) + else if (builtins.typeOf attr) == "list" then + lib.concatMapStringsSep " " (mapConfig key) attr + else if (builtins.typeOf attr) == "bool" then + "--${key}=${lib.boolToString attr}" + else if (builtins.typeOf attr) == "string" then + "--${key}='${attr}'" + else + "--${key}=${toString attr}" + ); configString = lib.concatStringsSep " " (lib.mapAttrsToList mapConfig allConfig); in @@ -114,7 +147,10 @@ in }; approvalPrompt = lib.mkOption { - type = lib.types.enum ["force" "auto"]; + type = lib.types.enum [ + "force" + "auto" + ]; default = "force"; description = '' OAuth approval_prompt. @@ -146,19 +182,19 @@ in }; skipAuthRegexes = lib.mkOption { - type = lib.types.listOf lib.types.str; - default = []; - description = '' - Skip authentication for requests matching any of these regular - expressions. - ''; + type = lib.types.listOf lib.types.str; + default = [ ]; + description = '' + Skip authentication for requests matching any of these regular + expressions. + ''; }; # XXX: Not clear whether these two options are mutually exclusive or not. email = { domains = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Authenticate emails with the specified domains. Use `*` to authenticate any email. @@ -257,7 +293,7 @@ in groups = lib.mkOption { type = lib.types.listOf lib.types.str; - default = []; + default = [ ]; description = '' Restrict logins to members of these Google groups. ''; @@ -289,12 +325,11 @@ in }; }; - #################################################### # UPSTREAM Configuration upstream = lib.mkOption { - type = with lib.types; coercedTo str (x: [x]) (listOf str); - default = []; + type = with lib.types; coercedTo str (x: [ x ]) (listOf str); + default = [ ]; description = '' The http url(s) of the upstream endpoint or `file://` paths for static files. Routing is based on the path. @@ -538,7 +573,7 @@ in }; extraConfig = lib.mkOption { - default = {}; + default = { }; type = lib.types.attrsOf lib.types.anything; description = '' Extra config to pass to oauth2-proxy. @@ -575,12 +610,18 @@ in group = "oauth2-proxy"; }; - users.groups.oauth2-proxy = {}; + users.groups.oauth2-proxy = { }; systemd.services.oauth2-proxy = - let needsKeycloak = lib.elem cfg.provider ["keycloak" "keycloak-oidc"] - && config.services.keycloak.enable; - in { + let + needsKeycloak = + lib.elem cfg.provider [ + "keycloak" + "keycloak-oidc" + ] + && config.services.keycloak.enable; + in + { description = "OAuth2 Proxy"; path = [ cfg.package ]; wantedBy = [ "multi-user.target" ]; diff --git a/nixos/modules/services/security/opensnitch.nix b/nixos/modules/services/security/opensnitch.nix index 6e2f6ca73b776e..10b44052ac6eb1 100644 --- a/nixos/modules/services/security/opensnitch.nix +++ b/nixos/modules/services/security/opensnitch.nix @@ -1,22 +1,30 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.opensnitch; - format = pkgs.formats.json {}; + format = pkgs.formats.json { }; - predefinedRules = flip mapAttrs cfg.rules (name: cfg: { - file = pkgs.writeText "rule" (builtins.toJSON cfg); - }); + predefinedRules = flip mapAttrs cfg.rules ( + name: cfg: { + file = pkgs.writeText "rule" (builtins.toJSON cfg); + } + ); -in { +in +{ options = { services.opensnitch = { enable = mkEnableOption "Opensnitch application firewall"; rules = mkOption { - default = {}; + default = { }; example = literalExpression '' { "tor" = { @@ -73,7 +81,10 @@ in { }; DefaultAction = mkOption { - type = types.enum [ "allow" "deny" ]; + type = types.enum [ + "allow" + "deny" + ]; description = '' Default action whether to block or allow application internet access. @@ -88,14 +99,25 @@ in { }; ProcMonitorMethod = mkOption { - type = types.enum [ "ebpf" "proc" "ftrace" "audit" ]; + type = types.enum [ + "ebpf" + "proc" + "ftrace" + "audit" + ]; description = '' Which process monitoring method to use. ''; }; LogLevel = mkOption { - type = types.enum [ 0 1 2 3 4 ]; + type = types.enum [ + 0 + 1 + 2 + 3 + 4 + ]; description = '' Default log level from 0 to 4 (debug, info, important, warning, error). @@ -103,7 +125,10 @@ in { }; Firewall = mkOption { - type = types.enum [ "iptables" "nftables" ]; + type = types.enum [ + "iptables" + "nftables" + ]; description = '' Which firewall backend to use. ''; @@ -129,7 +154,11 @@ in { Ebpf.ModulesPath = mkOption { type = types.path; - default = if cfg.settings.ProcMonitorMethod == "ebpf" then "${config.boot.kernelPackages.opensnitch-ebpf}/etc/opensnitchd" else null; + default = + if cfg.settings.ProcMonitorMethod == "ebpf" then + "${config.boot.kernelPackages.opensnitch-ebpf}/etc/opensnitchd" + else + null; defaultText = literalExpression '' if cfg.settings.ProcMonitorMethod == "ebpf" then "\\$\\{config.boot.kernelPackages.opensnitch-ebpf\\}/etc/opensnitchd" @@ -163,7 +192,13 @@ in { config = mkIf cfg.enable { # pkg.opensnitch is referred to elsewhere in the module so we don't need to worry about it being garbage collected - services.opensnitch.settings = mapAttrs (_: v: mkDefault v) (builtins.fromJSON (builtins.unsafeDiscardStringContext (builtins.readFile "${pkgs.opensnitch}/etc/opensnitchd/default-config.json"))); + services.opensnitch.settings = mapAttrs (_: v: mkDefault v) ( + builtins.fromJSON ( + builtins.unsafeDiscardStringContext ( + builtins.readFile "${pkgs.opensnitch}/etc/opensnitchd/default-config.json" + ) + ) + ); systemd = { packages = [ pkgs.opensnitch ]; @@ -175,25 +210,33 @@ in { "${pkgs.opensnitch}/bin/opensnitchd --config-file ${format.generate "default-config.json" cfg.settings}" ]; }; - preStart = mkIf (cfg.rules != {}) (let - rules = flip mapAttrsToList predefinedRules (file: content: { - inherit (content) file; - local = "${cfg.settings.Rules.Path}/${file}.json"; - }); - in '' - # Remove all firewall rules from rules path (configured with - # cfg.settings.Rules.Path) that are symlinks to a store-path, but aren't - # declared in `cfg.rules` (i.e. all networks that were "removed" from - # `cfg.rules`). - find ${cfg.settings.Rules.Path} -type l -lname '${builtins.storeDir}/*' ${optionalString (rules != {}) '' - -not \( ${concatMapStringsSep " -o " ({ local, ... }: - "-name '${baseNameOf local}*'") - rules} \) \ - ''} -delete - ${concatMapStrings ({ file, local }: '' - ln -sf '${file}' "${local}" - '') rules} - ''); + preStart = mkIf (cfg.rules != { }) ( + let + rules = flip mapAttrsToList predefinedRules ( + file: content: { + inherit (content) file; + local = "${cfg.settings.Rules.Path}/${file}.json"; + } + ); + in + '' + # Remove all firewall rules from rules path (configured with + # cfg.settings.Rules.Path) that are symlinks to a store-path, but aren't + # declared in `cfg.rules` (i.e. all networks that were "removed" from + # `cfg.rules`). + find ${cfg.settings.Rules.Path} -type l -lname '${builtins.storeDir}/*' ${ + optionalString (rules != { }) '' + -not \( ${concatMapStringsSep " -o " ({ local, ... }: "-name '${baseNameOf local}*'") rules} \) \ + '' + } -delete + ${concatMapStrings ( + { file, local }: + '' + ln -sf '${file}' "${local}" + '' + ) rules} + '' + ); }; tmpfiles.rules = [ "d ${cfg.settings.Rules.Path} 0750 root root - -" @@ -205,4 +248,3 @@ in { meta.maintainers = with lib.maintainers; [ onny ]; } - diff --git a/nixos/modules/services/security/pass-secret-service.nix b/nixos/modules/services/security/pass-secret-service.nix index 9530a9f8cf6939..499a934d136600 100644 --- a/nixos/modules/services/security/pass-secret-service.nix +++ b/nixos/modules/services/security/pass-secret-service.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/security/physlock.nix b/nixos/modules/services/security/physlock.nix index 7285de94ad6cdd..0a6536f4dc6bad 100644 --- a/nixos/modules/services/security/physlock.nix +++ b/nixos/modules/services/security/physlock.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -85,7 +90,7 @@ in extraTargets = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "display-manager.service" ]; description = '' Other targets to lock the screen just before. @@ -103,7 +108,6 @@ in }; - ###### implementation config = mkIf cfg.enable (mkMerge [ @@ -115,31 +119,35 @@ in systemd.services.physlock = { enable = true; description = "Physlock"; - wantedBy = optional cfg.lockOn.suspend "suspend.target" - ++ optional cfg.lockOn.hibernate "hibernate.target" - ++ cfg.lockOn.extraTargets; - before = optional cfg.lockOn.suspend "systemd-suspend.service" - ++ optional cfg.lockOn.hibernate "systemd-hibernate.service" - ++ optional (cfg.lockOn.hibernate || cfg.lockOn.suspend) "systemd-suspend-then-hibernate.service" - ++ cfg.lockOn.extraTargets; + wantedBy = + optional cfg.lockOn.suspend "suspend.target" + ++ optional cfg.lockOn.hibernate "hibernate.target" + ++ cfg.lockOn.extraTargets; + before = + optional cfg.lockOn.suspend "systemd-suspend.service" + ++ optional cfg.lockOn.hibernate "systemd-hibernate.service" + ++ optional (cfg.lockOn.hibernate || cfg.lockOn.suspend) "systemd-suspend-then-hibernate.service" + ++ cfg.lockOn.extraTargets; serviceConfig = { Type = "forking"; - ExecStart = "${pkgs.physlock}/bin/physlock -d${optionalString cfg.muteKernelMessages "m"}${optionalString cfg.disableSysRq "s"}${optionalString (cfg.lockMessage != "") " -p \"${cfg.lockMessage}\""}"; + ExecStart = "${pkgs.physlock}/bin/physlock -d${optionalString cfg.muteKernelMessages "m"}${optionalString cfg.disableSysRq "s"}${ + optionalString (cfg.lockMessage != "") " -p \"${cfg.lockMessage}\"" + }"; }; }; - security.pam.services.physlock = {}; + security.pam.services.physlock = { }; } (mkIf cfg.allowAnyUser { - security.wrappers.physlock = - { setuid = true; - owner = "root"; - group = "root"; - source = "${pkgs.physlock}/bin/physlock"; - }; + security.wrappers.physlock = { + setuid = true; + owner = "root"; + group = "root"; + source = "${pkgs.physlock}/bin/physlock"; + }; }) ]); diff --git a/nixos/modules/services/security/shibboleth-sp.nix b/nixos/modules/services/security/shibboleth-sp.nix index 0a85173501d5fe..e9f92dcc0928da 100644 --- a/nixos/modules/services/security/shibboleth-sp.nix +++ b/nixos/modules/services/security/shibboleth-sp.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.shibboleth-sp; -in { +in +{ options = { services.shibboleth-sp = { enable = lib.mkOption { @@ -40,8 +46,11 @@ in { config = lib.mkIf cfg.enable { systemd.services.shibboleth-sp = { description = "Provides SSO and federation for web applications"; - after = lib.optionals cfg.fastcgi.enable [ "shibresponder.service" "shibauthorizer.service" ]; - wantedBy = [ "multi-user.target" ]; + after = lib.optionals cfg.fastcgi.enable [ + "shibresponder.service" + "shibauthorizer.service" + ]; + wantedBy = [ "multi-user.target" ]; serviceConfig = { ExecStart = "${pkgs.shibboleth-sp}/bin/shibd -F -d ${pkgs.shibboleth-sp} -c ${cfg.configFile}"; }; @@ -49,9 +58,9 @@ in { systemd.services.shibresponder = lib.mkIf cfg.fastcgi.enable { description = "Provides SSO through Shibboleth via FastCGI"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - path = [ "${pkgs.spawn_fcgi}" ]; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + path = [ "${pkgs.spawn_fcgi}" ]; environment.SHIBSP_CONFIG = "${cfg.configFile}"; serviceConfig = { ExecStart = "${pkgs.spawn_fcgi}/bin/spawn-fcgi -n -p ${toString cfg.fastcgi.shibResponderPort} ${pkgs.shibboleth-sp}/lib/shibboleth/shibresponder"; @@ -60,9 +69,9 @@ in { systemd.services.shibauthorizer = lib.mkIf cfg.fastcgi.enable { description = "Provides SSO through Shibboleth via FastCGI"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - path = [ "${pkgs.spawn_fcgi}" ]; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + path = [ "${pkgs.spawn_fcgi}" ]; environment.SHIBSP_CONFIG = "${cfg.configFile}"; serviceConfig = { ExecStart = "${pkgs.spawn_fcgi}/bin/spawn-fcgi -n -p ${toString cfg.fastcgi.shibAuthorizerPort} ${pkgs.shibboleth-sp}/lib/shibboleth/shibauthorizer"; diff --git a/nixos/modules/services/security/sks.nix b/nixos/modules/services/security/sks.nix index 20d2dadbb7e222..2c0067325936ed 100644 --- a/nixos/modules/services/security/sks.nix +++ b/nixos/modules/services/security/sks.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -9,8 +14,12 @@ let ${cfg.extraDbConfig} ''; -in { - meta.maintainers = with maintainers; [ calbrecht jcumming ]; +in +{ + meta.maintainers = with maintainers; [ + calbrecht + jcumming + ]; options = { @@ -52,7 +61,10 @@ in { }; hkpAddress = mkOption { - default = [ "127.0.0.1" "::1" ]; + default = [ + "127.0.0.1" + "::1" + ]; type = types.listOf types.str; description = '' Domain names, IPv4 and/or IPv6 addresses to listen on for HKP @@ -94,48 +106,52 @@ in { createHome = true; group = "sks"; useDefaultShell = true; - packages = [ sksPkg pkgs.db ]; + packages = [ + sksPkg + pkgs.db + ]; }; groups.sks = { }; }; - systemd.services = let - hkpAddress = "'" + (builtins.concatStringsSep " " cfg.hkpAddress) + "'" ; - hkpPort = builtins.toString cfg.hkpPort; - in { - sks-db = { - description = "SKS database server"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - preStart = '' - ${lib.optionalString (cfg.webroot != null) - "ln -sfT \"${cfg.webroot}\" web"} - mkdir -p dump - ${sksPkg}/bin/sks build dump/*.gpg -n 10 -cache 100 || true #*/ - ${sksPkg}/bin/sks cleandb || true - ${sksPkg}/bin/sks pbuild -cache 20 -ptree_cache 70 || true - # Check that both database configs are symlinks before overwriting them - # TODO: The initial build will be without DB_CONFIG, but this will - # hopefully not cause any significant problems. It might be better to - # create both directories manually but we have to check that this does - # not affect the initial build of the DB. - for CONFIG_FILE in KDB/DB_CONFIG PTree/DB_CONFIG; do - if [ -e $CONFIG_FILE ] && [ ! -L $CONFIG_FILE ]; then - echo "$CONFIG_FILE exists but is not a symlink." >&2 - echo "Please remove $PWD/$CONFIG_FILE manually to continue." >&2 - exit 1 - fi - ln -sf ${dbConfig} $CONFIG_FILE - done - ''; - serviceConfig = { - WorkingDirectory = "~"; - User = "sks"; - Group = "sks"; - Restart = "always"; - ExecStart = "${sksPkg}/bin/sks db -hkp_address ${hkpAddress} -hkp_port ${hkpPort}"; + systemd.services = + let + hkpAddress = "'" + (builtins.concatStringsSep " " cfg.hkpAddress) + "'"; + hkpPort = builtins.toString cfg.hkpPort; + in + { + sks-db = { + description = "SKS database server"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + preStart = '' + ${lib.optionalString (cfg.webroot != null) "ln -sfT \"${cfg.webroot}\" web"} + mkdir -p dump + ${sksPkg}/bin/sks build dump/*.gpg -n 10 -cache 100 || true #*/ + ${sksPkg}/bin/sks cleandb || true + ${sksPkg}/bin/sks pbuild -cache 20 -ptree_cache 70 || true + # Check that both database configs are symlinks before overwriting them + # TODO: The initial build will be without DB_CONFIG, but this will + # hopefully not cause any significant problems. It might be better to + # create both directories manually but we have to check that this does + # not affect the initial build of the DB. + for CONFIG_FILE in KDB/DB_CONFIG PTree/DB_CONFIG; do + if [ -e $CONFIG_FILE ] && [ ! -L $CONFIG_FILE ]; then + echo "$CONFIG_FILE exists but is not a symlink." >&2 + echo "Please remove $PWD/$CONFIG_FILE manually to continue." >&2 + exit 1 + fi + ln -sf ${dbConfig} $CONFIG_FILE + done + ''; + serviceConfig = { + WorkingDirectory = "~"; + User = "sks"; + Group = "sks"; + Restart = "always"; + ExecStart = "${sksPkg}/bin/sks db -hkp_address ${hkpAddress} -hkp_port ${hkpPort}"; + }; }; }; - }; }; } diff --git a/nixos/modules/services/security/sshguard.nix b/nixos/modules/services/security/sshguard.nix index 3be0a8c700b9e0..ab768f787a6607 100644 --- a/nixos/modules/services/security/sshguard.nix +++ b/nixos/modules/services/security/sshguard.nix @@ -1,26 +1,35 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.sshguard; - configFile = let - args = lib.concatStringsSep " " ([ - "-afb" - "-p info" - "-o cat" - "-n1" - ] ++ (map (name: "-t ${escapeShellArg name}") cfg.services)); - backend = if config.networking.nftables.enable - then "sshg-fw-nft-sets" - else "sshg-fw-ipset"; - in pkgs.writeText "sshguard.conf" '' - BACKEND="${pkgs.sshguard}/libexec/${backend}" - LOGREADER="LANG=C ${config.systemd.package}/bin/journalctl ${args}" - ''; - -in { + configFile = + let + args = lib.concatStringsSep " " ( + [ + "-afb" + "-p info" + "-o cat" + "-n1" + ] + ++ (map (name: "-t ${escapeShellArg name}") cfg.services) + ); + backend = if config.networking.nftables.enable then "sshg-fw-nft-sets" else "sshg-fw-ipset"; + in + pkgs.writeText "sshguard.conf" '' + BACKEND="${pkgs.sshguard}/libexec/${backend}" + LOGREADER="LANG=C ${config.systemd.package}/bin/journalctl ${args}" + ''; + +in +{ ###### interface @@ -37,8 +46,8 @@ in { default = 30; type = types.int; description = '' - Block attackers when their cumulative attack score exceeds threshold. Most attacks have a score of 10. - ''; + Block attackers when their cumulative attack score exceeds threshold. Most attacks have a score of 10. + ''; }; blacklist_threshold = mkOption { @@ -46,52 +55,58 @@ in { example = 120; type = types.nullOr types.int; description = '' - Blacklist an attacker when its score exceeds threshold. Blacklisted addresses are loaded from and added to blacklist-file. - ''; + Blacklist an attacker when its score exceeds threshold. Blacklisted addresses are loaded from and added to blacklist-file. + ''; }; blacklist_file = mkOption { default = "/var/lib/sshguard/blacklist.db"; type = types.path; description = '' - Blacklist an attacker when its score exceeds threshold. Blacklisted addresses are loaded from and added to blacklist-file. - ''; + Blacklist an attacker when its score exceeds threshold. Blacklisted addresses are loaded from and added to blacklist-file. + ''; }; blocktime = mkOption { default = 120; type = types.int; description = '' - Block attackers for initially blocktime seconds after exceeding threshold. Subsequent blocks increase by a factor of 1.5. + Block attackers for initially blocktime seconds after exceeding threshold. Subsequent blocks increase by a factor of 1.5. - sshguard unblocks attacks at random intervals, so actual block times will be longer. - ''; + sshguard unblocks attacks at random intervals, so actual block times will be longer. + ''; }; detection_time = mkOption { default = 1800; type = types.int; description = '' - Remember potential attackers for up to detection_time seconds before resetting their score. - ''; + Remember potential attackers for up to detection_time seconds before resetting their score. + ''; }; whitelist = mkOption { default = [ ]; - example = [ "198.51.100.56" "198.51.100.2" ]; + example = [ + "198.51.100.56" + "198.51.100.2" + ]; type = types.listOf types.str; description = '' - Whitelist a list of addresses, hostnames, or address blocks. - ''; + Whitelist a list of addresses, hostnames, or address blocks. + ''; }; services = mkOption { default = [ "sshd" ]; - example = [ "sshd" "exim" ]; + example = [ + "sshd" + "exim" + ]; type = types.listOf types.str; description = '' - Systemd services sshguard should receive logs of. - ''; + Systemd services sshguard should receive logs of. + ''; }; }; }; @@ -111,9 +126,21 @@ in { restartTriggers = [ configFile ]; - path = with pkgs; if config.networking.nftables.enable - then [ nftables iproute2 systemd ] - else [ iptables ipset iproute2 systemd ]; + path = + with pkgs; + if config.networking.nftables.enable then + [ + nftables + iproute2 + systemd + ] + else + [ + iptables + ipset + iproute2 + systemd + ]; # The sshguard ipsets must exist before we invoke # iptables. sshguard creates the ipsets after startup if @@ -121,34 +148,45 @@ in { # the iptables rules because postStart races with the creation # of the ipsets. So instead, we create both the ipsets and # firewall rules before sshguard starts. - preStart = optionalString config.networking.firewall.enable '' - ${pkgs.ipset}/bin/ipset -quiet create -exist sshguard4 hash:net family inet - ${pkgs.iptables}/bin/iptables -I INPUT -m set --match-set sshguard4 src -j DROP - '' + optionalString (config.networking.firewall.enable && config.networking.enableIPv6) '' - ${pkgs.ipset}/bin/ipset -quiet create -exist sshguard6 hash:net family inet6 - ${pkgs.iptables}/bin/ip6tables -I INPUT -m set --match-set sshguard6 src -j DROP - ''; - - postStop = optionalString config.networking.firewall.enable '' - ${pkgs.iptables}/bin/iptables -D INPUT -m set --match-set sshguard4 src -j DROP - ${pkgs.ipset}/bin/ipset -quiet destroy sshguard4 - '' + optionalString (config.networking.firewall.enable && config.networking.enableIPv6) '' - ${pkgs.iptables}/bin/ip6tables -D INPUT -m set --match-set sshguard6 src -j DROP - ${pkgs.ipset}/bin/ipset -quiet destroy sshguard6 - ''; + preStart = + optionalString config.networking.firewall.enable '' + ${pkgs.ipset}/bin/ipset -quiet create -exist sshguard4 hash:net family inet + ${pkgs.iptables}/bin/iptables -I INPUT -m set --match-set sshguard4 src -j DROP + '' + + optionalString (config.networking.firewall.enable && config.networking.enableIPv6) '' + ${pkgs.ipset}/bin/ipset -quiet create -exist sshguard6 hash:net family inet6 + ${pkgs.iptables}/bin/ip6tables -I INPUT -m set --match-set sshguard6 src -j DROP + ''; + + postStop = + optionalString config.networking.firewall.enable '' + ${pkgs.iptables}/bin/iptables -D INPUT -m set --match-set sshguard4 src -j DROP + ${pkgs.ipset}/bin/ipset -quiet destroy sshguard4 + '' + + optionalString (config.networking.firewall.enable && config.networking.enableIPv6) '' + ${pkgs.iptables}/bin/ip6tables -D INPUT -m set --match-set sshguard6 src -j DROP + ${pkgs.ipset}/bin/ipset -quiet destroy sshguard6 + ''; unitConfig.Documentation = "man:sshguard(8)"; serviceConfig = { Type = "simple"; - ExecStart = let - args = lib.concatStringsSep " " ([ - "-a ${toString cfg.attack_threshold}" - "-p ${toString cfg.blocktime}" - "-s ${toString cfg.detection_time}" - (optionalString (cfg.blacklist_threshold != null) "-b ${toString cfg.blacklist_threshold}:${cfg.blacklist_file}") - ] ++ (map (name: "-w ${escapeShellArg name}") cfg.whitelist)); - in "${pkgs.sshguard}/bin/sshguard ${args}"; + ExecStart = + let + args = lib.concatStringsSep " " ( + [ + "-a ${toString cfg.attack_threshold}" + "-p ${toString cfg.blocktime}" + "-s ${toString cfg.detection_time}" + (optionalString ( + cfg.blacklist_threshold != null + ) "-b ${toString cfg.blacklist_threshold}:${cfg.blacklist_file}") + ] + ++ (map (name: "-w ${escapeShellArg name}") cfg.whitelist) + ); + in + "${pkgs.sshguard}/bin/sshguard ${args}"; Restart = "always"; ProtectSystem = "strict"; ProtectHome = "tmpfs"; diff --git a/nixos/modules/services/security/sslmate-agent.nix b/nixos/modules/services/security/sslmate-agent.nix index 57cb955a39dd91..081f4c0778411f 100644 --- a/nixos/modules/services/security/sslmate-agent.nix +++ b/nixos/modules/services/security/sslmate-agent.nix @@ -1,11 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.sslmate-agent; -in { +in +{ meta.maintainers = [ ]; options = { diff --git a/nixos/modules/services/security/step-ca.nix b/nixos/modules/services/security/step-ca.nix index 70651e995dda11..9c03fde123d8e6 100644 --- a/nixos/modules/services/security/step-ca.nix +++ b/nixos/modules/services/security/step-ca.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.step-ca; settingsFormat = (pkgs.formats.json { }); @@ -73,22 +78,24 @@ in config = lib.mkIf config.services.step-ca.enable ( let - configFile = settingsFormat.generate "ca.json" (cfg.settings // { - address = cfg.address + ":" + toString cfg.port; - }); + configFile = settingsFormat.generate "ca.json" ( + cfg.settings + // { + address = cfg.address + ":" + toString cfg.port; + } + ); in { - assertions = - [ - { - assertion = !lib.isStorePath cfg.intermediatePasswordFile; - message = '' - points to - a file in the Nix store. You should use a quoted absolute path to - prevent this. - ''; - } - ]; + assertions = [ + { + assertion = !lib.isStorePath cfg.intermediatePasswordFile; + message = '' + points to + a file in the Nix store. You should use a quoted absolute path to + prevent this. + ''; + } + ]; systemd.packages = [ cfg.package ]; @@ -132,7 +139,7 @@ in isSystemUser = true; }; - users.groups.step-ca = {}; + users.groups.step-ca = { }; networking.firewall = lib.mkIf cfg.openFirewall { allowedTCPPorts = [ cfg.port ]; diff --git a/nixos/modules/services/security/tang.nix b/nixos/modules/services/security/tang.nix index be36d9895bf305..3d65a5cf6ead45 100644 --- a/nixos/modules/services/security/tang.nix +++ b/nixos/modules/services/security/tang.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.tang; @@ -17,7 +22,11 @@ in listenStream = mkOption { type = with types; listOf str; default = [ "7654" ]; - example = [ "198.168.100.1:7654" "[2001:db8::1]:7654" "7654" ]; + example = [ + "198.168.100.1:7654" + "[2001:db8::1]:7654" + "7654" + ]; description = '' Addresses and/or ports on which tang should listen. For detailed syntax see ListenStream in {manpage}`systemd.socket(5)`. @@ -74,7 +83,11 @@ in RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" "~@resources" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "~@resources" + ]; IPAddressDeny = "any"; IPAddressAllow = cfg.ipAddressAllow; }; @@ -91,5 +104,8 @@ in }; }; }; - meta.maintainers = with lib.maintainers; [ jfroche julienmalka ]; + meta.maintainers = with lib.maintainers; [ + jfroche + julienmalka + ]; } diff --git a/nixos/modules/services/security/tor.nix b/nixos/modules/services/security/tor.nix index 6cceb1bad82d57..7c7d1a66c77484 100644 --- a/nixos/modules/services/security/tor.nix +++ b/nixos/modules/services/security/tor.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with builtins; with lib; @@ -12,41 +18,58 @@ let See [torrc manual](https://2019.www.torproject.org/docs/tor-manual.html.en#${option}). ''; bindsPrivilegedPort = - any (p0: - let p1 = if p0 ? "port" then p0.port else p0; in - if p1 == "auto" then false - else let p2 = if isInt p1 then p1 else toInt p1; in - p1 != null && 0 < p2 && p2 < 1024) - (flatten [ - cfg.settings.ORPort - cfg.settings.DirPort - cfg.settings.DNSPort - cfg.settings.ExtORPort - cfg.settings.HTTPTunnelPort - cfg.settings.NATDPort - cfg.settings.SOCKSPort - cfg.settings.TransPort - ]); - optionBool = optionName: mkOption { - type = with types; nullOr bool; - default = null; - description = (descriptionGeneric optionName); - }; - optionInt = optionName: mkOption { - type = with types; nullOr int; - default = null; - description = (descriptionGeneric optionName); - }; - optionString = optionName: mkOption { - type = with types; nullOr str; - default = null; - description = (descriptionGeneric optionName); - }; - optionStrings = optionName: mkOption { - type = with types; listOf str; - default = []; - description = (descriptionGeneric optionName); - }; + any + ( + p0: + let + p1 = if p0 ? "port" then p0.port else p0; + in + if p1 == "auto" then + false + else + let + p2 = if isInt p1 then p1 else toInt p1; + in + p1 != null && 0 < p2 && p2 < 1024 + ) + (flatten [ + cfg.settings.ORPort + cfg.settings.DirPort + cfg.settings.DNSPort + cfg.settings.ExtORPort + cfg.settings.HTTPTunnelPort + cfg.settings.NATDPort + cfg.settings.SOCKSPort + cfg.settings.TransPort + ]); + optionBool = + optionName: + mkOption { + type = with types; nullOr bool; + default = null; + description = (descriptionGeneric optionName); + }; + optionInt = + optionName: + mkOption { + type = with types; nullOr int; + default = null; + description = (descriptionGeneric optionName); + }; + optionString = + optionName: + mkOption { + type = with types; nullOr str; + default = null; + description = (descriptionGeneric optionName); + }; + optionStrings = + optionName: + mkOption { + type = with types; listOf str; + default = [ ]; + description = (descriptionGeneric optionName); + }; optionAddress = mkOption { type = with types; nullOr str; default = null; @@ -63,34 +86,61 @@ let ''; }; optionPort = mkOption { - type = with types; nullOr (oneOf [port (enum ["auto"])]); + type = + with types; + nullOr (oneOf [ + port + (enum [ "auto" ]) + ]); default = null; }; - optionPorts = optionName: mkOption { - type = with types; listOf port; - default = []; - description = (descriptionGeneric optionName); - }; - optionIsolablePort = with types; oneOf [ - port (enum ["auto"]) - (submodule ({config, ...}: { - options = { - addr = optionAddress; - port = optionPort; - flags = optionFlags; - SessionGroup = mkOption { type = nullOr int; default = null; }; - } // genAttrs isolateFlags (name: mkOption { type = types.bool; default = false; }); - config = { - flags = filter (name: config.${name} == true) isolateFlags ++ - optional (config.SessionGroup != null) "SessionGroup=${toString config.SessionGroup}"; - }; - })) - ]; - optionIsolablePorts = optionName: mkOption { - default = []; - type = with types; either optionIsolablePort (listOf optionIsolablePort); - description = (descriptionGeneric optionName); - }; + optionPorts = + optionName: + mkOption { + type = with types; listOf port; + default = [ ]; + description = (descriptionGeneric optionName); + }; + optionIsolablePort = + with types; + oneOf [ + port + (enum [ "auto" ]) + (submodule ( + { config, ... }: + { + options = + { + addr = optionAddress; + port = optionPort; + flags = optionFlags; + SessionGroup = mkOption { + type = nullOr int; + default = null; + }; + } + // genAttrs isolateFlags ( + name: + mkOption { + type = types.bool; + default = false; + } + ); + config = { + flags = + filter (name: config.${name} == true) isolateFlags + ++ optional (config.SessionGroup != null) "SessionGroup=${toString config.SessionGroup}"; + }; + } + )) + ]; + optionIsolablePorts = + optionName: + mkOption { + default = [ ]; + type = with types; either optionIsolablePort (listOf optionIsolablePort); + description = (descriptionGeneric optionName); + }; isolateFlags = [ "IsolateClientAddr" "IsolateClientProtocol" @@ -99,157 +149,342 @@ let "IsolateSOCKSAuth" "KeepAliveIsolateSOCKSAuth" ]; - optionSOCKSPort = doConfig: let - flags = [ - "CacheDNS" "CacheIPv4DNS" "CacheIPv6DNS" "GroupWritable" "IPv6Traffic" - "NoDNSRequest" "NoIPv4Traffic" "NoOnionTraffic" "OnionTrafficOnly" - "PreferIPv6" "PreferIPv6Automap" "PreferSOCKSNoAuth" "UseDNSCache" - "UseIPv4Cache" "UseIPv6Cache" "WorldWritable" - ] ++ isolateFlags; - in with types; oneOf [ - port (submodule ({config, ...}: { - options = { - unix = optionUnix; - addr = optionAddress; - port = optionPort; - flags = optionFlags; - SessionGroup = mkOption { type = nullOr int; default = null; }; - } // genAttrs flags (name: mkOption { type = types.bool; default = false; }); - config = mkIf doConfig { # Only add flags in SOCKSPort to avoid duplicates - flags = filter (name: config.${name} == true) flags ++ - optional (config.SessionGroup != null) "SessionGroup=${toString config.SessionGroup}"; - }; - })) + optionSOCKSPort = + doConfig: + let + flags = [ + "CacheDNS" + "CacheIPv4DNS" + "CacheIPv6DNS" + "GroupWritable" + "IPv6Traffic" + "NoDNSRequest" + "NoIPv4Traffic" + "NoOnionTraffic" + "OnionTrafficOnly" + "PreferIPv6" + "PreferIPv6Automap" + "PreferSOCKSNoAuth" + "UseDNSCache" + "UseIPv4Cache" + "UseIPv6Cache" + "WorldWritable" + ] ++ isolateFlags; + in + with types; + oneOf [ + port + (submodule ( + { config, ... }: + { + options = + { + unix = optionUnix; + addr = optionAddress; + port = optionPort; + flags = optionFlags; + SessionGroup = mkOption { + type = nullOr int; + default = null; + }; + } + // genAttrs flags ( + name: + mkOption { + type = types.bool; + default = false; + } + ); + config = mkIf doConfig { + # Only add flags in SOCKSPort to avoid duplicates + flags = + filter (name: config.${name} == true) flags + ++ optional (config.SessionGroup != null) "SessionGroup=${toString config.SessionGroup}"; + }; + } + )) ]; optionFlags = mkOption { type = with types; listOf str; - default = []; - }; - optionORPort = optionName: mkOption { - default = []; - example = 443; - type = with types; oneOf [port (enum ["auto"]) (listOf (oneOf [ - port - (enum ["auto"]) - (submodule ({config, ...}: - let flags = [ "IPv4Only" "IPv6Only" "NoAdvertise" "NoListen" ]; - in { - options = { - addr = optionAddress; - port = optionPort; - flags = optionFlags; - } // genAttrs flags (name: mkOption { type = types.bool; default = false; }); - config = { - flags = filter (name: config.${name} == true) flags; - }; - })) - ]))]; - description = (descriptionGeneric optionName); - }; - optionBandwidth = optionName: mkOption { - type = with types; nullOr (either int str); - default = null; - description = (descriptionGeneric optionName); - }; - optionPath = optionName: mkOption { - type = with types; nullOr path; - default = null; - description = (descriptionGeneric optionName); + default = [ ]; }; + optionORPort = + optionName: + mkOption { + default = [ ]; + example = 443; + type = + with types; + oneOf [ + port + (enum [ "auto" ]) + (listOf (oneOf [ + port + (enum [ "auto" ]) + (submodule ( + { config, ... }: + let + flags = [ + "IPv4Only" + "IPv6Only" + "NoAdvertise" + "NoListen" + ]; + in + { + options = + { + addr = optionAddress; + port = optionPort; + flags = optionFlags; + } + // genAttrs flags ( + name: + mkOption { + type = types.bool; + default = false; + } + ); + config = { + flags = filter (name: config.${name} == true) flags; + }; + } + )) + ])) + ]; + description = (descriptionGeneric optionName); + }; + optionBandwidth = + optionName: + mkOption { + type = with types; nullOr (either int str); + default = null; + description = (descriptionGeneric optionName); + }; + optionPath = + optionName: + mkOption { + type = with types; nullOr path; + default = null; + description = (descriptionGeneric optionName); + }; - mkValueString = k: v: - if v == null then "" + mkValueString = + k: v: + if v == null then + "" else if isBool v then (if v then "1" else "0") else if v ? "unix" && v.unix != null then - "unix:"+v.unix + - optionalString (v ? "flags") (" " + concatStringsSep " " v.flags) + "unix:" + v.unix + optionalString (v ? "flags") (" " + concatStringsSep " " v.flags) else if v ? "port" && v.port != null then - optionalString (v ? "addr" && v.addr != null) "${v.addr}:" + - toString v.port + - optionalString (v ? "flags") (" " + concatStringsSep " " v.flags) + optionalString (v ? "addr" && v.addr != null) "${v.addr}:" + + toString v.port + + optionalString (v ? "flags") (" " + concatStringsSep " " v.flags) else if k == "ServerTransportPlugin" then - optionalString (v.transports != []) "${concatStringsSep "," v.transports} exec ${v.exec}" + optionalString (v.transports != [ ]) "${concatStringsSep "," v.transports} exec ${v.exec}" else if k == "HidServAuth" then v.onion + " " + v.auth - else generators.mkValueStringDefault {} v; - genTorrc = settings: - generators.toKeyValue { - listsAsDuplicateKeys = true; - mkKeyValue = k: generators.mkKeyValueDefault { mkValueString = mkValueString k; } " " k; - } - (lib.mapAttrs (k: v: - # Not necesssary, but prettier rendering - if elem k [ "AutomapHostsSuffixes" "DirPolicy" "ExitPolicy" "SocksPolicy" ] - && v != [] - then concatStringsSep "," v - else v) - (lib.filterAttrs (k: v: !(v == null || v == "")) - settings)); + else + generators.mkValueStringDefault { } v; + genTorrc = + settings: + generators.toKeyValue + { + listsAsDuplicateKeys = true; + mkKeyValue = k: generators.mkKeyValueDefault { mkValueString = mkValueString k; } " " k; + } + ( + lib.mapAttrs ( + k: v: + # Not necesssary, but prettier rendering + if + elem k [ + "AutomapHostsSuffixes" + "DirPolicy" + "ExitPolicy" + "SocksPolicy" + ] + && v != [ ] + then + concatStringsSep "," v + else + v + ) (lib.filterAttrs (k: v: !(v == null || v == "")) settings) + ); torrc = pkgs.writeText "torrc" ( - genTorrc cfg.settings + - concatStrings (mapAttrsToList (name: onion: - "HiddenServiceDir ${onion.path}\n" + - genTorrc onion.settings) cfg.relay.onionServices) + genTorrc cfg.settings + + concatStrings ( + mapAttrsToList ( + name: onion: "HiddenServiceDir ${onion.path}\n" + genTorrc onion.settings + ) cfg.relay.onionServices + ) ); in { imports = [ - (mkRenamedOptionModule [ "services" "tor" "client" "dns" "automapHostsSuffixes" ] [ "services" "tor" "settings" "AutomapHostsSuffixes" ]) - (mkRemovedOptionModule [ "services" "tor" "client" "dns" "isolationOptions" ] "Use services.tor.settings.DNSPort instead.") - (mkRemovedOptionModule [ "services" "tor" "client" "dns" "listenAddress" ] "Use services.tor.settings.DNSPort instead.") - (mkRemovedOptionModule [ "services" "tor" "client" "privoxy" "enable" ] "Use services.privoxy.enable and services.privoxy.enableTor instead.") - (mkRemovedOptionModule [ "services" "tor" "client" "socksIsolationOptions" ] "Use services.tor.settings.SOCKSPort instead.") - (mkRemovedOptionModule [ "services" "tor" "client" "socksListenAddressFaster" ] "Use services.tor.settings.SOCKSPort instead.") - (mkRenamedOptionModule [ "services" "tor" "client" "socksPolicy" ] [ "services" "tor" "settings" "SocksPolicy" ]) - (mkRemovedOptionModule [ "services" "tor" "client" "transparentProxy" "isolationOptions" ] "Use services.tor.settings.TransPort instead.") - (mkRemovedOptionModule [ "services" "tor" "client" "transparentProxy" "listenAddress" ] "Use services.tor.settings.TransPort instead.") - (mkRenamedOptionModule [ "services" "tor" "controlPort" ] [ "services" "tor" "settings" "ControlPort" ]) - (mkRemovedOptionModule [ "services" "tor" "extraConfig" ] "Please use services.tor.settings instead.") - (mkRenamedOptionModule [ "services" "tor" "hiddenServices" ] [ "services" "tor" "relay" "onionServices" ]) - (mkRenamedOptionModule [ "services" "tor" "relay" "accountingMax" ] [ "services" "tor" "settings" "AccountingMax" ]) - (mkRenamedOptionModule [ "services" "tor" "relay" "accountingStart" ] [ "services" "tor" "settings" "AccountingStart" ]) - (mkRenamedOptionModule [ "services" "tor" "relay" "address" ] [ "services" "tor" "settings" "Address" ]) - (mkRenamedOptionModule [ "services" "tor" "relay" "bandwidthBurst" ] [ "services" "tor" "settings" "BandwidthBurst" ]) - (mkRenamedOptionModule [ "services" "tor" "relay" "bandwidthRate" ] [ "services" "tor" "settings" "BandwidthRate" ]) - (mkRenamedOptionModule [ "services" "tor" "relay" "bridgeTransports" ] [ "services" "tor" "settings" "ServerTransportPlugin" "transports" ]) - (mkRenamedOptionModule [ "services" "tor" "relay" "contactInfo" ] [ "services" "tor" "settings" "ContactInfo" ]) - (mkRenamedOptionModule [ "services" "tor" "relay" "exitPolicy" ] [ "services" "tor" "settings" "ExitPolicy" ]) - (mkRemovedOptionModule [ "services" "tor" "relay" "isBridge" ] "Use services.tor.relay.role instead.") + (mkRenamedOptionModule + [ "services" "tor" "client" "dns" "automapHostsSuffixes" ] + [ "services" "tor" "settings" "AutomapHostsSuffixes" ] + ) + (mkRemovedOptionModule [ + "services" + "tor" + "client" + "dns" + "isolationOptions" + ] "Use services.tor.settings.DNSPort instead.") + (mkRemovedOptionModule [ + "services" + "tor" + "client" + "dns" + "listenAddress" + ] "Use services.tor.settings.DNSPort instead.") + (mkRemovedOptionModule [ + "services" + "tor" + "client" + "privoxy" + "enable" + ] "Use services.privoxy.enable and services.privoxy.enableTor instead.") + (mkRemovedOptionModule [ + "services" + "tor" + "client" + "socksIsolationOptions" + ] "Use services.tor.settings.SOCKSPort instead.") + (mkRemovedOptionModule [ + "services" + "tor" + "client" + "socksListenAddressFaster" + ] "Use services.tor.settings.SOCKSPort instead.") + (mkRenamedOptionModule + [ "services" "tor" "client" "socksPolicy" ] + [ "services" "tor" "settings" "SocksPolicy" ] + ) + (mkRemovedOptionModule [ + "services" + "tor" + "client" + "transparentProxy" + "isolationOptions" + ] "Use services.tor.settings.TransPort instead.") + (mkRemovedOptionModule [ + "services" + "tor" + "client" + "transparentProxy" + "listenAddress" + ] "Use services.tor.settings.TransPort instead.") + (mkRenamedOptionModule + [ "services" "tor" "controlPort" ] + [ "services" "tor" "settings" "ControlPort" ] + ) + (mkRemovedOptionModule [ + "services" + "tor" + "extraConfig" + ] "Please use services.tor.settings instead.") + (mkRenamedOptionModule + [ "services" "tor" "hiddenServices" ] + [ "services" "tor" "relay" "onionServices" ] + ) + (mkRenamedOptionModule + [ "services" "tor" "relay" "accountingMax" ] + [ "services" "tor" "settings" "AccountingMax" ] + ) + (mkRenamedOptionModule + [ "services" "tor" "relay" "accountingStart" ] + [ "services" "tor" "settings" "AccountingStart" ] + ) + (mkRenamedOptionModule + [ "services" "tor" "relay" "address" ] + [ "services" "tor" "settings" "Address" ] + ) + (mkRenamedOptionModule + [ "services" "tor" "relay" "bandwidthBurst" ] + [ "services" "tor" "settings" "BandwidthBurst" ] + ) + (mkRenamedOptionModule + [ "services" "tor" "relay" "bandwidthRate" ] + [ "services" "tor" "settings" "BandwidthRate" ] + ) + (mkRenamedOptionModule + [ "services" "tor" "relay" "bridgeTransports" ] + [ "services" "tor" "settings" "ServerTransportPlugin" "transports" ] + ) + (mkRenamedOptionModule + [ "services" "tor" "relay" "contactInfo" ] + [ "services" "tor" "settings" "ContactInfo" ] + ) + (mkRenamedOptionModule + [ "services" "tor" "relay" "exitPolicy" ] + [ "services" "tor" "settings" "ExitPolicy" ] + ) + (mkRemovedOptionModule [ + "services" + "tor" + "relay" + "isBridge" + ] "Use services.tor.relay.role instead.") (mkRemovedOptionModule [ "services" "tor" "relay" "isExit" ] "Use services.tor.relay.role instead.") - (mkRenamedOptionModule [ "services" "tor" "relay" "nickname" ] [ "services" "tor" "settings" "Nickname" ]) + (mkRenamedOptionModule + [ "services" "tor" "relay" "nickname" ] + [ "services" "tor" "settings" "Nickname" ] + ) (mkRenamedOptionModule [ "services" "tor" "relay" "port" ] [ "services" "tor" "settings" "ORPort" ]) - (mkRenamedOptionModule [ "services" "tor" "relay" "portSpec" ] [ "services" "tor" "settings" "ORPort" ]) + (mkRenamedOptionModule + [ "services" "tor" "relay" "portSpec" ] + [ "services" "tor" "settings" "ORPort" ] + ) ]; options = { services.tor = { - enable = mkEnableOption ''Tor daemon. - By default, the daemon is run without - relay, exit, bridge or client connectivity''; + enable = mkEnableOption '' + Tor daemon. + By default, the daemon is run without + relay, exit, bridge or client connectivity''; openFirewall = mkEnableOption "opening of the relay port(s) in the firewall"; package = mkPackageOption pkgs "tor" { }; - enableGeoIP = mkEnableOption ''use of GeoIP databases. - Disabling this will disable by-country statistics for bridges and relays - and some client and third-party software functionality'' // { default = true; }; + enableGeoIP = + mkEnableOption '' + use of GeoIP databases. + Disabling this will disable by-country statistics for bridges and relays + and some client and third-party software functionality'' + // { + default = true; + }; - controlSocket.enable = mkEnableOption ''control socket, - created in `${runDir}/control`''; + controlSocket.enable = mkEnableOption '' + control socket, + created in `${runDir}/control`''; client = { - enable = mkEnableOption ''the routing of application connections. - You might want to disable this if you plan running a dedicated Tor relay''; + enable = mkEnableOption '' + the routing of application connections. + You might want to disable this if you plan running a dedicated Tor relay''; transparentProxy.enable = mkEnableOption "transparent proxy"; dns.enable = mkEnableOption "DNS resolver"; socksListenAddress = mkOption { type = optionSOCKSPort false; - default = {addr = "127.0.0.1"; port = 9050; IsolateDestAddr = true;}; - example = {addr = "192.168.0.1"; port = 9090; IsolateDestAddr = true;}; + default = { + addr = "127.0.0.1"; + port = 9050; + IsolateDestAddr = true; + }; + example = { + addr = "192.168.0.1"; + port = 9090; + IsolateDestAddr = true; + }; description = '' Bind to this address to listen for connections from Socks-speaking applications. @@ -258,27 +493,32 @@ in onionServices = mkOption { description = (descriptionGeneric "HiddenServiceDir"); - default = {}; + default = { }; example = { "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" = { - clientAuthorizations = ["/run/keys/tor/alice.prv.x25519"]; + clientAuthorizations = [ "/run/keys/tor/alice.prv.x25519" ]; }; }; - type = types.attrsOf (types.submodule ({name, config, ...}: { - options.clientAuthorizations = mkOption { - description = '' - Clients' authorizations for a v3 onion service, - as a list of files containing each one private key, in the format: - ``` - descriptor:x25519: - ``` - ${descriptionGeneric "_client_authorization"} - ''; - type = with types; listOf path; - default = []; - example = ["/run/keys/tor/alice.prv.x25519"]; - }; - })); + type = types.attrsOf ( + types.submodule ( + { name, config, ... }: + { + options.clientAuthorizations = mkOption { + description = '' + Clients' authorizations for a v3 onion service, + as a list of files containing each one private key, in the format: + ``` + descriptor:x25519: + ``` + ${descriptionGeneric "_client_authorization"} + ''; + type = with types; listOf path; + default = [ ]; + example = [ "/run/keys/tor/alice.prv.x25519" ]; + }; + } + ) + ); }; }; @@ -299,7 +539,12 @@ in }; role = mkOption { - type = types.enum [ "exit" "relay" "bridge" "private-bridge" ]; + type = types.enum [ + "exit" + "relay" + "bridge" + "private-bridge" + ]; description = '' Your role in Tor network. There're several options: @@ -386,7 +631,7 @@ in onionServices = mkOption { description = (descriptionGeneric "HiddenServiceDir"); - default = {}; + default = { }; example = { "example.org/www" = { map = [ 80 ]; @@ -395,136 +640,185 @@ in ]; }; }; - type = types.attrsOf (types.submodule ({name, config, ...}: { - options.path = mkOption { - type = types.path; - description = '' - Path where to store the data files of the hidden service. - If the {option}`secretKey` is null - this defaults to `${stateDir}/onion/$onion`, - otherwise to `${runDir}/onion/$onion`. - ''; - }; - options.secretKey = mkOption { - type = with types; nullOr path; - default = null; - example = "/run/keys/tor/onion/expyuzz4wqqyqhjn/hs_ed25519_secret_key"; - description = '' - Secret key of the onion service. - If null, Tor reuses any preexisting secret key (in {option}`path`) - or generates a new one. - The associated public key and hostname are deterministically regenerated - from this file if they do not exist. - ''; - }; - options.authorizeClient = mkOption { - description = (descriptionGeneric "HiddenServiceAuthorizeClient"); - default = null; - type = types.nullOr (types.submodule ({...}: { - options = { - authType = mkOption { - type = types.enum [ "basic" "stealth" ]; - description = '' - Either `"basic"` for a general-purpose authorization protocol - or `"stealth"` for a less scalable protocol - that also hides service activity from unauthorized clients. - ''; - }; - clientNames = mkOption { - type = with types; nonEmptyListOf (strMatching "[A-Za-z0-9+-_]+"); - description = '' - Only clients that are listed here are authorized to access the hidden service. - Generated authorization data can be found in {file}`${stateDir}/onion/$name/hostname`. - Clients need to put this authorization data in their configuration file using - [](#opt-services.tor.settings.HidServAuth). - ''; - }; + type = types.attrsOf ( + types.submodule ( + { name, config, ... }: + { + options.path = mkOption { + type = types.path; + description = '' + Path where to store the data files of the hidden service. + If the {option}`secretKey` is null + this defaults to `${stateDir}/onion/$onion`, + otherwise to `${runDir}/onion/$onion`. + ''; }; - })); - }; - options.authorizedClients = mkOption { - description = '' - Authorized clients for a v3 onion service, - as a list of public key, in the format: - ``` - descriptor:x25519: - ``` - ${descriptionGeneric "_client_authorization"} - ''; - type = with types; listOf str; - default = []; - example = ["descriptor:x25519:XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX"]; - }; - options.map = mkOption { - description = (descriptionGeneric "HiddenServicePort"); - type = with types; listOf (oneOf [ - port (submodule ({...}: { - options = { - port = optionPort; - target = mkOption { - default = null; - type = nullOr (submodule ({...}: { - options = { - unix = optionUnix; - addr = optionAddress; - port = optionPort; - }; - })); - }; - }; - })) - ]); - apply = map (v: if isInt v then {port=v; target=null;} else v); - }; - options.version = mkOption { - description = (descriptionGeneric "HiddenServiceVersion"); - type = with types; nullOr (enum [2 3]); - default = null; - }; - options.settings = mkOption { - description = '' - Settings of the onion service. - ${descriptionGeneric "_hidden_service_options"} - ''; - default = {}; - type = types.submodule { - freeformType = with types; - (attrsOf (nullOr (oneOf [str int bool (listOf str)]))) // { - description = "settings option"; - }; - options.HiddenServiceAllowUnknownPorts = optionBool "HiddenServiceAllowUnknownPorts"; - options.HiddenServiceDirGroupReadable = optionBool "HiddenServiceDirGroupReadable"; - options.HiddenServiceExportCircuitID = mkOption { - description = (descriptionGeneric "HiddenServiceExportCircuitID"); - type = with types; nullOr (enum ["haproxy"]); + options.secretKey = mkOption { + type = with types; nullOr path; default = null; + example = "/run/keys/tor/onion/expyuzz4wqqyqhjn/hs_ed25519_secret_key"; + description = '' + Secret key of the onion service. + If null, Tor reuses any preexisting secret key (in {option}`path`) + or generates a new one. + The associated public key and hostname are deterministically regenerated + from this file if they do not exist. + ''; }; - options.HiddenServiceMaxStreams = mkOption { - description = (descriptionGeneric "HiddenServiceMaxStreams"); - type = with types; nullOr (ints.between 0 65535); + options.authorizeClient = mkOption { + description = (descriptionGeneric "HiddenServiceAuthorizeClient"); default = null; + type = types.nullOr ( + types.submodule ( + { ... }: + { + options = { + authType = mkOption { + type = types.enum [ + "basic" + "stealth" + ]; + description = '' + Either `"basic"` for a general-purpose authorization protocol + or `"stealth"` for a less scalable protocol + that also hides service activity from unauthorized clients. + ''; + }; + clientNames = mkOption { + type = with types; nonEmptyListOf (strMatching "[A-Za-z0-9+-_]+"); + description = '' + Only clients that are listed here are authorized to access the hidden service. + Generated authorization data can be found in {file}`${stateDir}/onion/$name/hostname`. + Clients need to put this authorization data in their configuration file using + [](#opt-services.tor.settings.HidServAuth). + ''; + }; + }; + } + ) + ); }; - options.HiddenServiceMaxStreamsCloseCircuit = optionBool "HiddenServiceMaxStreamsCloseCircuit"; - options.HiddenServiceNumIntroductionPoints = mkOption { - description = (descriptionGeneric "HiddenServiceNumIntroductionPoints"); - type = with types; nullOr (ints.between 0 20); + options.authorizedClients = mkOption { + description = '' + Authorized clients for a v3 onion service, + as a list of public key, in the format: + ``` + descriptor:x25519: + ``` + ${descriptionGeneric "_client_authorization"} + ''; + type = with types; listOf str; + default = [ ]; + example = [ "descriptor:x25519:XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX" ]; + }; + options.map = mkOption { + description = (descriptionGeneric "HiddenServicePort"); + type = + with types; + listOf (oneOf [ + port + (submodule ( + { ... }: + { + options = { + port = optionPort; + target = mkOption { + default = null; + type = nullOr ( + submodule ( + { ... }: + { + options = { + unix = optionUnix; + addr = optionAddress; + port = optionPort; + }; + } + ) + ); + }; + }; + } + )) + ]); + apply = map ( + v: + if isInt v then + { + port = v; + target = null; + } + else + v + ); + }; + options.version = mkOption { + description = (descriptionGeneric "HiddenServiceVersion"); + type = + with types; + nullOr (enum [ + 2 + 3 + ]); default = null; }; - options.HiddenServiceSingleHopMode = optionBool "HiddenServiceSingleHopMode"; - options.RendPostPeriod = optionString "RendPostPeriod"; - }; - }; - config = { - path = mkDefault ((if config.secretKey == null then stateDir else runDir) + "/onion/${name}"); - settings.HiddenServiceVersion = config.version; - settings.HiddenServiceAuthorizeClient = - if config.authorizeClient != null then - config.authorizeClient.authType + " " + - concatStringsSep "," config.authorizeClient.clientNames - else null; - settings.HiddenServicePort = map (p: mkValueString "" p.port + " " + mkValueString "" p.target) config.map; - }; - })); + options.settings = mkOption { + description = '' + Settings of the onion service. + ${descriptionGeneric "_hidden_service_options"} + ''; + default = { }; + type = types.submodule { + freeformType = + with types; + (attrsOf ( + nullOr (oneOf [ + str + int + bool + (listOf str) + ]) + )) + // { + description = "settings option"; + }; + options.HiddenServiceAllowUnknownPorts = optionBool "HiddenServiceAllowUnknownPorts"; + options.HiddenServiceDirGroupReadable = optionBool "HiddenServiceDirGroupReadable"; + options.HiddenServiceExportCircuitID = mkOption { + description = (descriptionGeneric "HiddenServiceExportCircuitID"); + type = with types; nullOr (enum [ "haproxy" ]); + default = null; + }; + options.HiddenServiceMaxStreams = mkOption { + description = (descriptionGeneric "HiddenServiceMaxStreams"); + type = with types; nullOr (ints.between 0 65535); + default = null; + }; + options.HiddenServiceMaxStreamsCloseCircuit = optionBool "HiddenServiceMaxStreamsCloseCircuit"; + options.HiddenServiceNumIntroductionPoints = mkOption { + description = (descriptionGeneric "HiddenServiceNumIntroductionPoints"); + type = with types; nullOr (ints.between 0 20); + default = null; + }; + options.HiddenServiceSingleHopMode = optionBool "HiddenServiceSingleHopMode"; + options.RendPostPeriod = optionString "RendPostPeriod"; + }; + }; + config = { + path = mkDefault ((if config.secretKey == null then stateDir else runDir) + "/onion/${name}"); + settings.HiddenServiceVersion = config.version; + settings.HiddenServiceAuthorizeClient = + if config.authorizeClient != null then + config.authorizeClient.authType + " " + concatStringsSep "," config.authorizeClient.clientNames + else + null; + settings.HiddenServicePort = map ( + p: mkValueString "" p.port + " " + mkValueString "" p.target + ) config.map; + }; + } + ) + ); }; }; @@ -533,10 +827,19 @@ in See [torrc manual](https://2019.www.torproject.org/docs/tor-manual.html.en) for documentation. ''; - default = {}; + default = { }; type = types.submodule { - freeformType = with types; - (attrsOf (nullOr (oneOf [str int bool (listOf str)]))) // { + freeformType = + with types; + (attrsOf ( + nullOr (oneOf [ + str + int + bool + (listOf str) + ]) + )) + // { description = "settings option"; }; options.Address = optionString "Address"; @@ -551,14 +854,19 @@ in options.AuthoritativeDirectory = optionBool "AuthoritativeDirectory"; options.AutomapHostsOnResolve = optionBool "AutomapHostsOnResolve"; options.AutomapHostsSuffixes = optionStrings "AutomapHostsSuffixes" // { - default = [".onion" ".exit"]; - example = [".onion"]; + default = [ + ".onion" + ".exit" + ]; + example = [ ".onion" ]; }; options.BandwidthBurst = optionBandwidth "BandwidthBurst"; options.BandwidthRate = optionBandwidth "BandwidthRate"; options.BridgeAuthoritativeDir = optionBool "BridgeAuthoritativeDir"; options.BridgeRecordUsageByCountry = optionBool "BridgeRecordUsageByCountry"; - options.BridgeRelay = optionBool "BridgeRelay" // { default = false; }; + options.BridgeRelay = optionBool "BridgeRelay" // { + default = false; + }; options.CacheDirectory = optionPath "CacheDirectory"; options.CacheDirectoryGroupReadable = optionBool "CacheDirectoryGroupReadable"; # default is null and like "auto" options.CellStatistics = optionBool "CellStatistics"; @@ -579,32 +887,58 @@ in options.ContactInfo = optionString "ContactInfo"; options.ControlPort = mkOption rec { description = (descriptionGeneric "ControlPort"); - default = []; - example = [{port = 9051;}]; - type = with types; oneOf [port (enum ["auto"]) (listOf (oneOf [ - port (enum ["auto"]) (submodule ({config, ...}: let - flags = ["GroupWritable" "RelaxDirModeCheck" "WorldWritable"]; - in { - options = { - unix = optionUnix; - flags = optionFlags; - addr = optionAddress; - port = optionPort; - } // genAttrs flags (name: mkOption { type = types.bool; default = false; }); - config = { - flags = filter (name: config.${name} == true) flags; - }; - })) - ]))]; + default = [ ]; + example = [ { port = 9051; } ]; + type = + with types; + oneOf [ + port + (enum [ "auto" ]) + (listOf (oneOf [ + port + (enum [ "auto" ]) + (submodule ( + { config, ... }: + let + flags = [ + "GroupWritable" + "RelaxDirModeCheck" + "WorldWritable" + ]; + in + { + options = + { + unix = optionUnix; + flags = optionFlags; + addr = optionAddress; + port = optionPort; + } + // genAttrs flags ( + name: + mkOption { + type = types.bool; + default = false; + } + ); + config = { + flags = filter (name: config.${name} == true) flags; + }; + } + )) + ])) + ]; }; - options.ControlPortFileGroupReadable= optionBool "ControlPortFileGroupReadable"; + options.ControlPortFileGroupReadable = optionBool "ControlPortFileGroupReadable"; options.ControlPortWriteToFile = optionPath "ControlPortWriteToFile"; options.ControlSocket = optionPath "ControlSocket"; options.ControlSocketsGroupWritable = optionBool "ControlSocketsGroupWritable"; options.CookieAuthFile = optionPath "CookieAuthFile"; options.CookieAuthFileGroupReadable = optionBool "CookieAuthFileGroupReadable"; options.CookieAuthentication = optionBool "CookieAuthentication"; - options.DataDirectory = optionPath "DataDirectory" // { default = stateDir; }; + options.DataDirectory = optionPath "DataDirectory" // { + default = stateDir; + }; options.DataDirectoryGroupReadable = optionBool "DataDirectoryGroupReadable"; options.DirPortFrontPage = optionPath "DirPortFrontPage"; options.DirAllowPrivateAddresses = optionBool "DirAllowPrivateAddresses"; @@ -615,8 +949,8 @@ in options.DirPolicy = mkOption { description = (descriptionGeneric "DirPolicy"); type = with types; listOf str; - default = []; - example = ["accept *:*"]; + default = [ ]; + example = [ "accept *:*" ]; }; options.DirPort = optionORPort "DirPort"; options.DirReqStatistics = optionBool "DirReqStatistics"; @@ -632,8 +966,8 @@ in options.EnforceDistinctSubnets = optionBool "EnforceDistinctSubnets"; options.EntryStatistics = optionBool "EntryStatistics"; options.ExitPolicy = optionStrings "ExitPolicy" // { - default = ["reject *:*"]; - example = ["accept *:*"]; + default = [ "reject *:*" ]; + example = [ "accept *:*" ]; }; options.ExitPolicyRejectLocalInterfaces = optionBool "ExitPolicyRejectLocalInterfaces"; options.ExitPolicyRejectPrivate = optionBool "ExitPolicyRejectPrivate"; @@ -642,14 +976,21 @@ in options.ExtORPort = mkOption { description = (descriptionGeneric "ExtORPort"); default = null; - type = with types; nullOr (oneOf [ - port (enum ["auto"]) (submodule ({...}: { - options = { - addr = optionAddress; - port = optionPort; - }; - })) - ]); + type = + with types; + nullOr (oneOf [ + port + (enum [ "auto" ]) + (submodule ( + { ... }: + { + options = { + addr = optionAddress; + port = optionPort; + }; + } + )) + ]); apply = p: if isInt p || isString p then { port = p; } else p; }; options.ExtORPortCookieAuthFile = optionPath "ExtORPortCookieAuthFile"; @@ -670,22 +1011,24 @@ in options.GuardfractionFile = optionPath "GuardfractionFile"; options.HidServAuth = mkOption { description = (descriptionGeneric "HidServAuth"); - default = []; - type = with types; listOf (oneOf [ - (submodule { - options = { - onion = mkOption { - type = strMatching "[a-z2-7]{16}\\.onion"; - description = "Onion address."; - example = "xxxxxxxxxxxxxxxx.onion"; - }; - auth = mkOption { - type = strMatching "[A-Za-z0-9+/]{22}"; - description = "Authentication cookie."; + default = [ ]; + type = + with types; + listOf (oneOf [ + (submodule { + options = { + onion = mkOption { + type = strMatching "[a-z2-7]{16}\\.onion"; + description = "Onion address."; + example = "xxxxxxxxxxxxxxxx.onion"; + }; + auth = mkOption { + type = strMatching "[A-Za-z0-9+/]{22}"; + description = "Authentication cookie."; + }; }; - }; - }) - ]); + }) + ]); example = [ { onion = "xxxxxxxxxxxxxxxx.onion"; @@ -721,7 +1064,18 @@ in options.PublishHidServDescriptors = optionBool "PublishHidServDescriptors"; options.PublishServerDescriptor = mkOption { description = (descriptionGeneric "PublishServerDescriptor"); - type = with types; nullOr (enum [false true 0 1 "0" "1" "v3" "bridge"]); + type = + with types; + nullOr (enum [ + false + true + 0 + 1 + "0" + "1" + "v3" + "bridge" + ]); default = null; }; options.ReducedExitPolicy = optionBool "ReducedExitPolicy"; @@ -740,19 +1094,31 @@ in options.ServerTransportPlugin = mkOption { description = (descriptionGeneric "ServerTransportPlugin"); default = null; - type = with types; nullOr (submodule ({...}: { - options = { - transports = mkOption { - description = "List of pluggable transports."; - type = listOf str; - example = ["obfs2" "obfs3" "obfs4" "scramblesuit"]; - }; - exec = mkOption { - type = types.str; - description = "Command of pluggable transport."; - }; - }; - })); + type = + with types; + nullOr ( + submodule ( + { ... }: + { + options = { + transports = mkOption { + description = "List of pluggable transports."; + type = listOf str; + example = [ + "obfs2" + "obfs3" + "obfs4" + "scramblesuit" + ]; + }; + exec = mkOption { + type = types.str; + description = "Command of pluggable transport."; + }; + }; + } + ) + ); }; options.ShutdownWaitLength = mkOption { type = types.int; @@ -760,24 +1126,31 @@ in description = (descriptionGeneric "ShutdownWaitLength"); }; options.SocksPolicy = optionStrings "SocksPolicy" // { - example = ["accept *:*"]; + example = [ "accept *:*" ]; }; options.SOCKSPort = mkOption { description = (descriptionGeneric "SOCKSPort"); - default = lib.optionals cfg.settings.HiddenServiceNonAnonymousMode [{port = 0;}]; + default = lib.optionals cfg.settings.HiddenServiceNonAnonymousMode [ { port = 0; } ]; defaultText = literalExpression '' if config.${opt.settings}.HiddenServiceNonAnonymousMode == true then [ { port = 0; } ] else [ ] ''; - example = [{port = 9090;}]; + example = [ { port = 9090; } ]; type = types.listOf (optionSOCKSPort true); }; options.TestingTorNetwork = optionBool "TestingTorNetwork"; options.TransPort = optionIsolablePorts "TransPort"; options.TransProxyType = mkOption { description = (descriptionGeneric "TransProxyType"); - type = with types; nullOr (enum ["default" "TPROXY" "ipfw" "pf-divert"]); + type = + with types; + nullOr (enum [ + "default" + "TPROXY" + "ipfw" + "pf-divert" + ]); default = null; }; #options.TruncateLogFile @@ -798,45 +1171,49 @@ in config = mkIf cfg.enable { # Not sure if `cfg.relay.role == "private-bridge"` helps as tor # sends a lot of stats - warnings = optional (cfg.settings.BridgeRelay && - flatten (mapAttrsToList (n: o: o.map) cfg.relay.onionServices) != []) - '' - Running Tor hidden services on a public relay makes the - presence of hidden services visible through simple statistical - analysis of publicly available data. - See https://trac.torproject.org/projects/tor/ticket/8742 + warnings = + optional + (cfg.settings.BridgeRelay && flatten (mapAttrsToList (n: o: o.map) cfg.relay.onionServices) != [ ]) + '' + Running Tor hidden services on a public relay makes the + presence of hidden services visible through simple statistical + analysis of publicly available data. + See https://trac.torproject.org/projects/tor/ticket/8742 - You can safely ignore this warning if you don't intend to - actually hide your hidden services. In either case, you can - always create a container/VM with a separate Tor daemon instance. - '' ++ - flatten (mapAttrsToList (n: o: - optionals (o.settings.HiddenServiceVersion == 2) [ - (optional (o.settings.HiddenServiceExportCircuitID != null) '' - HiddenServiceExportCircuitID is used in the HiddenService: ${n} - but this option is only for v3 hidden services. - '') - ] ++ - optionals (o.settings.HiddenServiceVersion != 2) [ - (optional (o.settings.HiddenServiceAuthorizeClient != null) '' - HiddenServiceAuthorizeClient is used in the HiddenService: ${n} - but this option is only for v2 hidden services. - '') - (optional (o.settings.RendPostPeriod != null) '' - RendPostPeriod is used in the HiddenService: ${n} - but this option is only for v2 hidden services. - '') - ] - ) cfg.relay.onionServices); + You can safely ignore this warning if you don't intend to + actually hide your hidden services. In either case, you can + always create a container/VM with a separate Tor daemon instance. + '' + ++ flatten ( + mapAttrsToList ( + n: o: + optionals (o.settings.HiddenServiceVersion == 2) [ + (optional (o.settings.HiddenServiceExportCircuitID != null) '' + HiddenServiceExportCircuitID is used in the HiddenService: ${n} + but this option is only for v3 hidden services. + '') + ] + ++ optionals (o.settings.HiddenServiceVersion != 2) [ + (optional (o.settings.HiddenServiceAuthorizeClient != null) '' + HiddenServiceAuthorizeClient is used in the HiddenService: ${n} + but this option is only for v2 hidden services. + '') + (optional (o.settings.RendPostPeriod != null) '' + RendPostPeriod is used in the HiddenService: ${n} + but this option is only for v2 hidden services. + '') + ] + ) cfg.relay.onionServices + ); users.groups.tor.gid = config.ids.gids.tor; - users.users.tor = - { description = "Tor Daemon User"; - createHome = true; - home = stateDir; - group = "tor"; - uid = config.ids.uids.tor; - }; + users.users.tor = { + description = "Tor Daemon User"; + createHome = true; + home = stateDir; + group = "tor"; + uid = config.ids.uids.tor; + }; services.tor.settings = mkMerge [ (mkIf cfg.enableGeoIP { @@ -844,18 +1221,31 @@ in GeoIPv6File = "${cfg.package.geoip}/share/tor/geoip6"; }) (mkIf cfg.controlSocket.enable { - ControlPort = [ { unix = runDir + "/control"; GroupWritable=true; RelaxDirModeCheck=true; } ]; + ControlPort = [ + { + unix = runDir + "/control"; + GroupWritable = true; + RelaxDirModeCheck = true; + } + ]; }) (mkIf cfg.relay.enable ( optionalAttrs (cfg.relay.role != "exit") { - ExitPolicy = mkForce ["reject *:*"]; - } // - optionalAttrs (elem cfg.relay.role ["bridge" "private-bridge"]) { - BridgeRelay = true; - ExtORPort.port = mkDefault "auto"; - ServerTransportPlugin.transports = mkDefault ["obfs4"]; - ServerTransportPlugin.exec = mkDefault "${lib.getExe pkgs.obfs4} managed"; - } // optionalAttrs (cfg.relay.role == "private-bridge") { + ExitPolicy = mkForce [ "reject *:*" ]; + } + // + optionalAttrs + (elem cfg.relay.role [ + "bridge" + "private-bridge" + ]) + { + BridgeRelay = true; + ExtORPort.port = mkDefault "auto"; + ServerTransportPlugin.transports = mkDefault [ "obfs4" ]; + ServerTransportPlugin.exec = mkDefault "${lib.getExe pkgs.obfs4} managed"; + } + // optionalAttrs (cfg.relay.role == "private-bridge") { ExtraInfoStatistics = false; PublishServerDescriptor = false; } @@ -866,8 +1256,8 @@ in # which can trigger all sort of problems when not carefully done, # like the blocklisting of the machine's IP addresses # by some hosting providers... - DirPort = mkForce []; - ORPort = mkForce []; + DirPort = mkForce [ ]; + ORPort = mkForce [ ]; PublishServerDescriptor = mkForce false; }) (mkIf (!cfg.client.enable) { @@ -876,27 +1266,46 @@ in SOCKSPort = mkForce [ 0 ]; }) (mkIf cfg.client.enable ( - { SOCKSPort = [ cfg.client.socksListenAddress ]; - } // optionalAttrs cfg.client.transparentProxy.enable { - TransPort = [{ addr = "127.0.0.1"; port = 9040; }]; - } // optionalAttrs cfg.client.dns.enable { - DNSPort = [{ addr = "127.0.0.1"; port = 9053; }]; + { + SOCKSPort = [ cfg.client.socksListenAddress ]; + } + // optionalAttrs cfg.client.transparentProxy.enable { + TransPort = [ + { + addr = "127.0.0.1"; + port = 9040; + } + ]; + } + // optionalAttrs cfg.client.dns.enable { + DNSPort = [ + { + addr = "127.0.0.1"; + port = 9053; + } + ]; AutomapHostsOnResolve = true; - } // optionalAttrs (flatten (mapAttrsToList (n: o: o.clientAuthorizations) cfg.client.onionServices) != []) { - ClientOnionAuthDir = runDir + "/ClientOnionAuthDir"; } + // + optionalAttrs + (flatten (mapAttrsToList (n: o: o.clientAuthorizations) cfg.client.onionServices) != [ ]) + { + ClientOnionAuthDir = runDir + "/ClientOnionAuthDir"; + } )) ]; networking.firewall = mkIf cfg.openFirewall { allowedTCPPorts = - concatMap (o: - if isInt o && o > 0 then [o] - else optionals (o ? "port" && isInt o.port && o.port > 0) [o.port] - ) (flatten [ - cfg.settings.ORPort - cfg.settings.DirPort - ]); + concatMap + ( + o: + if isInt o && o > 0 then [ o ] else optionals (o ? "port" && isInt o.port && o.port > 0) [ o.port ] + ) + (flatten [ + cfg.settings.ORPort + cfg.settings.DirPort + ]); }; systemd.services.tor = { @@ -904,7 +1313,7 @@ in path = [ pkgs.tor ]; wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + after = [ "network.target" ]; restartTriggers = [ torrc ]; serviceConfig = { @@ -914,34 +1323,50 @@ in ExecStartPre = [ "${cfg.package}/bin/tor -f ${torrc} --verify-config" # DOC: Appendix G of https://spec.torproject.org/rend-spec-v3 - ("+" + pkgs.writeShellScript "ExecStartPre" (concatStringsSep "\n" (flatten (["set -eu"] ++ - mapAttrsToList (name: onion: - optional (onion.authorizedClients != []) '' - rm -rf ${escapeShellArg onion.path}/authorized_clients - install -d -o tor -g tor -m 0700 ${escapeShellArg onion.path} ${escapeShellArg onion.path}/authorized_clients - '' ++ - imap0 (i: pubKey: '' - echo ${pubKey} | - install -o tor -g tor -m 0400 /dev/stdin ${escapeShellArg onion.path}/authorized_clients/${toString i}.auth - '') onion.authorizedClients ++ - optional (onion.secretKey != null) '' - install -d -o tor -g tor -m 0700 ${escapeShellArg onion.path} - key="$(cut -f1 -d: ${escapeShellArg onion.secretKey} | head -1)" - case "$key" in - ("== ed25519v"*"-secret") - install -o tor -g tor -m 0400 ${escapeShellArg onion.secretKey} ${escapeShellArg onion.path}/hs_ed25519_secret_key;; - (*) echo >&2 "NixOS does not (yet) support secret key type for onion: ${name}"; exit 1;; - esac - '' - ) cfg.relay.onionServices ++ - mapAttrsToList (name: onion: imap0 (i: prvKeyPath: - let hostname = removeSuffix ".onion" name; in '' - printf "%s:" ${escapeShellArg hostname} | cat - ${escapeShellArg prvKeyPath} | - install -o tor -g tor -m 0700 /dev/stdin \ - ${runDir}/ClientOnionAuthDir/${escapeShellArg hostname}.${toString i}.auth_private - '') onion.clientAuthorizations) - cfg.client.onionServices - )))) + ( + "+" + + pkgs.writeShellScript "ExecStartPre" ( + concatStringsSep "\n" ( + flatten ( + [ "set -eu" ] + ++ mapAttrsToList ( + name: onion: + optional (onion.authorizedClients != [ ]) '' + rm -rf ${escapeShellArg onion.path}/authorized_clients + install -d -o tor -g tor -m 0700 ${escapeShellArg onion.path} ${escapeShellArg onion.path}/authorized_clients + '' + ++ imap0 (i: pubKey: '' + echo ${pubKey} | + install -o tor -g tor -m 0400 /dev/stdin ${escapeShellArg onion.path}/authorized_clients/${toString i}.auth + '') onion.authorizedClients + ++ optional (onion.secretKey != null) '' + install -d -o tor -g tor -m 0700 ${escapeShellArg onion.path} + key="$(cut -f1 -d: ${escapeShellArg onion.secretKey} | head -1)" + case "$key" in + ("== ed25519v"*"-secret") + install -o tor -g tor -m 0400 ${escapeShellArg onion.secretKey} ${escapeShellArg onion.path}/hs_ed25519_secret_key;; + (*) echo >&2 "NixOS does not (yet) support secret key type for onion: ${name}"; exit 1;; + esac + '' + ) cfg.relay.onionServices + ++ mapAttrsToList ( + name: onion: + imap0 ( + i: prvKeyPath: + let + hostname = removeSuffix ".onion" name; + in + '' + printf "%s:" ${escapeShellArg hostname} | cat - ${escapeShellArg prvKeyPath} | + install -o tor -g tor -m 0700 /dev/stdin \ + ${runDir}/ClientOnionAuthDir/${escapeShellArg hostname}.${toString i}.auth_private + '' + ) onion.clientAuthorizations + ) cfg.client.onionServices + ) + ) + ) + ) ]; ExecStart = "${cfg.package}/bin/tor -f ${torrc}"; ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; @@ -958,13 +1383,16 @@ in ]; RuntimeDirectoryMode = "0710"; StateDirectoryMode = "0700"; - StateDirectory = [ + StateDirectory = + [ "tor" "tor/onion" - ] ++ - flatten (mapAttrsToList (name: onion: - optional (onion.secretKey == null) "tor/onion/${name}" - ) cfg.relay.onionServices); + ] + ++ flatten ( + mapAttrsToList ( + name: onion: optional (onion.secretKey == null) "tor/onion/${name}" + ) cfg.relay.onionServices + ); # The following options are only to optimize: # systemd-analyze security tor RootDirectory = runDir + "/root"; @@ -972,13 +1400,17 @@ in #InaccessiblePaths = [ "-+${runDir}/root" ]; UMask = "0066"; BindPaths = [ stateDir ]; - BindReadOnlyPaths = [ storeDir "/etc" ] ++ - optionals config.services.resolved.enable [ + BindReadOnlyPaths = + [ + storeDir + "/etc" + ] + ++ optionals config.services.resolved.enable [ "/run/systemd/resolve/stub-resolv.conf" "/run/systemd/resolve/resolv.conf" ]; - AmbientCapabilities = [""] ++ lib.optional bindsPrivilegedPort "CAP_NET_BIND_SERVICE"; - CapabilityBoundingSet = [""] ++ lib.optional bindsPrivilegedPort "CAP_NET_BIND_SERVICE"; + AmbientCapabilities = [ "" ] ++ lib.optional bindsPrivilegedPort "CAP_NET_BIND_SERVICE"; + CapabilityBoundingSet = [ "" ] ++ lib.optional bindsPrivilegedPort "CAP_NET_BIND_SERVICE"; # ProtectClock= adds DeviceAllow=char-rtc r DeviceAllow = ""; LockPersonality = true; @@ -1002,7 +1434,12 @@ in ProtectProc = "invisible"; ProtectSystem = "strict"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" "AF_NETLINK" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + "AF_NETLINK" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; @@ -1012,7 +1449,13 @@ in # Groups in @system-service which do not contain a syscall listed by: # perf stat -x, 2>perf.log -e 'syscalls:sys_enter_*' tor # in tests, and seem likely not necessary for tor. - "~@aio" "~@chown" "~@keyring" "~@memlock" "~@resources" "~@setuid" "~@timer" + "~@aio" + "~@chown" + "~@keyring" + "~@memlock" + "~@resources" + "~@setuid" + "~@timer" ]; SystemCallArchitectures = "native"; SystemCallErrorNumber = "EPERM"; diff --git a/nixos/modules/services/security/torify.nix b/nixos/modules/services/security/torify.nix index 5f147ac4a30fea..aa60618b42996f 100644 --- a/nixos/modules/services/security/torify.nix +++ b/nixos/modules/services/security/torify.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let @@ -7,8 +12,8 @@ let torify = pkgs.writeTextFile { name = "tsocks"; text = '' - #!${pkgs.runtimeShell} - TSOCKS_CONF_FILE=${pkgs.writeText "tsocks.conf" cfg.tsocks.config} LD_PRELOAD="${pkgs.tsocks}/lib/libtsocks.so $LD_PRELOAD" "$@" + #!${pkgs.runtimeShell} + TSOCKS_CONF_FILE=${pkgs.writeText "tsocks.conf" cfg.tsocks.config} LD_PRELOAD="${pkgs.tsocks}/lib/libtsocks.so $LD_PRELOAD" "$@" ''; executable = true; destination = "/bin/tsocks"; @@ -66,11 +71,11 @@ in config = mkIf cfg.tsocks.enable { - environment.systemPackages = [ torify ]; # expose it to the users + environment.systemPackages = [ torify ]; # expose it to the users services.tor.tsocks.config = '' - server = ${toString(head (splitString ":" cfg.tsocks.server))} - server_port = ${toString(tail (splitString ":" cfg.tsocks.server))} + server = ${toString (head (splitString ":" cfg.tsocks.server))} + server_port = ${toString (tail (splitString ":" cfg.tsocks.server))} local = 127.0.0.0/255.128.0.0 local = 127.128.0.0/255.192.0.0 diff --git a/nixos/modules/services/security/usbguard.nix b/nixos/modules/services/security/usbguard.nix index 17bffa57ef3ad0..d73d1c65747b57 100644 --- a/nixos/modules/services/security/usbguard.nix +++ b/nixos/modules/services/security/usbguard.nix @@ -1,11 +1,24 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.usbguard; # valid policy options - policy = (types.enum [ "allow" "block" "reject" "keep" "apply-policy" ]); + policy = ( + types.enum [ + "allow" + "block" + "reject" + "keep" + "apply-policy" + ] + ); # decide what file to use for rules ruleFile = if cfg.rules != null then pkgs.writeText "usbguard-rules" cfg.rules else cfg.ruleFile; @@ -80,7 +93,11 @@ in }; implicitPolicyTarget = mkOption { - type = types.enum [ "allow" "block" "reject" ]; + type = types.enum [ + "allow" + "block" + "reject" + ]; default = "block"; description = '' How to treat USB devices that don't match any rule in the policy. @@ -110,7 +127,11 @@ in }; insertedDevicePolicy = mkOption { - type = types.enum [ "block" "reject" "apply-policy" ]; + type = types.enum [ + "block" + "reject" + "apply-policy" + ]; default = "apply-policy"; description = '' How to treat USB devices that are already connected after the daemon @@ -133,7 +154,10 @@ in IPCAllowedUsers = mkOption { type = types.listOf types.str; default = [ "root" ]; - example = [ "root" "yourusername" ]; + example = [ + "root" + "yourusername" + ]; description = '' A list of usernames that the daemon will accept IPC connections from. ''; @@ -161,7 +185,6 @@ in }; }; - ###### implementation config = mkIf cfg.enable { @@ -204,7 +227,10 @@ in ProtectSystem = true; ReadOnlyPaths = "-/"; ReadWritePaths = "-/dev/shm -/tmp"; - RestrictAddressFamilies = [ "AF_UNIX" "AF_NETLINK" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_NETLINK" + ]; RestrictNamespaces = true; RestrictRealtime = true; SystemCallArchitectures = "native"; @@ -232,10 +258,8 @@ in security.polkit.extraConfig = let - groupCheck = (lib.concatStrings (map - (g: "subject.isInGroup(\"${g}\") || ") - cfg.IPCAllowedGroups)) - + "false"; + groupCheck = + (lib.concatStrings (map (g: "subject.isInGroup(\"${g}\") || ") cfg.IPCAllowedGroups)) + "false"; in optionalString cfg.dbus.enable '' polkit.addRule(function(action, subject) { @@ -254,8 +278,17 @@ in ''; }; imports = [ - (mkRemovedOptionModule [ "services" "usbguard" "IPCAccessControlFiles" ] "The usbguard module now hardcodes IPCAccessControlFiles to /var/lib/usbguard/IPCAccessControl.d.") - (mkRemovedOptionModule [ "services" "usbguard" "auditFilePath" ] "Removed usbguard module audit log files. Audit logs can be found in the systemd journal.") - (mkRenamedOptionModule [ "services" "usbguard" "implictPolicyTarget" ] [ "services" "usbguard" "implicitPolicyTarget" ]) + (mkRemovedOptionModule [ "services" "usbguard" "IPCAccessControlFiles" ] + "The usbguard module now hardcodes IPCAccessControlFiles to /var/lib/usbguard/IPCAccessControl.d." + ) + (mkRemovedOptionModule [ + "services" + "usbguard" + "auditFilePath" + ] "Removed usbguard module audit log files. Audit logs can be found in the systemd journal.") + (mkRenamedOptionModule + [ "services" "usbguard" "implictPolicyTarget" ] + [ "services" "usbguard" "implicitPolicyTarget" ] + ) ]; } diff --git a/nixos/modules/services/security/vault-agent.nix b/nixos/modules/services/security/vault-agent.nix index 04fb08b8f9b88c..ca5576804a7b11 100644 --- a/nixos/modules/services/security/vault-agent.nix +++ b/nixos/modules/services/security/vault-agent.nix @@ -1,88 +1,118 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let format = pkgs.formats.json { }; - commonOptions = { pkgName, flavour ? pkgName }: mkOption { - default = { }; - description = '' - Attribute set of ${flavour} instances. - Creates independent `${flavour}-''${name}.service` systemd units for each instance defined here. - ''; - type = with types; attrsOf (submodule ({ name, ... }: { - options = { - enable = mkEnableOption "this ${flavour} instance" // { default = true; }; + commonOptions = + { + pkgName, + flavour ? pkgName, + }: + mkOption { + default = { }; + description = '' + Attribute set of ${flavour} instances. + Creates independent `${flavour}-''${name}.service` systemd units for each instance defined here. + ''; + type = + with types; + attrsOf ( + submodule ( + { name, ... }: + { + options = { + enable = mkEnableOption "this ${flavour} instance" // { + default = true; + }; - package = mkPackageOption pkgs pkgName { }; + package = mkPackageOption pkgs pkgName { }; - user = mkOption { - type = types.str; - default = "root"; - description = '' - User under which this instance runs. - ''; - }; + user = mkOption { + type = types.str; + default = "root"; + description = '' + User under which this instance runs. + ''; + }; - group = mkOption { - type = types.str; - default = "root"; - description = '' - Group under which this instance runs. - ''; - }; + group = mkOption { + type = types.str; + default = "root"; + description = '' + Group under which this instance runs. + ''; + }; - settings = mkOption { - type = types.submodule { - freeformType = format.type; + settings = mkOption { + type = types.submodule { + freeformType = format.type; - options = { - pid_file = mkOption { - default = "/run/${flavour}/${name}.pid"; - type = types.str; - description = '' - Path to use for the pid file. - ''; - }; + options = { + pid_file = mkOption { + default = "/run/${flavour}/${name}.pid"; + type = types.str; + description = '' + Path to use for the pid file. + ''; + }; - template = mkOption { - default = null; - type = with types; nullOr (listOf (attrsOf anything)); - description = - let upstreamDocs = - if flavour == "vault-agent" - then "https://developer.hashicorp.com/vault/docs/agent/template" - else "https://github.com/hashicorp/consul-template/blob/main/docs/configuration.md#templates"; - in '' - Template section of ${flavour}. - Refer to <${upstreamDocs}> for supported values. - ''; - }; - }; - }; + template = mkOption { + default = null; + type = with types; nullOr (listOf (attrsOf anything)); + description = + let + upstreamDocs = + if flavour == "vault-agent" then + "https://developer.hashicorp.com/vault/docs/agent/template" + else + "https://github.com/hashicorp/consul-template/blob/main/docs/configuration.md#templates"; + in + '' + Template section of ${flavour}. + Refer to <${upstreamDocs}> for supported values. + ''; + }; + }; + }; - default = { }; + default = { }; - description = - let upstreamDocs = - if flavour == "vault-agent" - then "https://developer.hashicorp.com/vault/docs/agent#configuration-file-options" - else "https://github.com/hashicorp/consul-template/blob/main/docs/configuration.md#configuration-file"; - in '' - Free-form settings written directly to the `config.json` file. - Refer to <${upstreamDocs}> for supported values. + description = + let + upstreamDocs = + if flavour == "vault-agent" then + "https://developer.hashicorp.com/vault/docs/agent#configuration-file-options" + else + "https://github.com/hashicorp/consul-template/blob/main/docs/configuration.md#configuration-file"; + in + '' + Free-form settings written directly to the `config.json` file. + Refer to <${upstreamDocs}> for supported values. - ::: {.note} - Resulting format is JSON not HCL. - Refer to if you are unsure how to convert HCL options to JSON. - ::: - ''; - }; - }; - })); - }; + ::: {.note} + Resulting format is JSON not HCL. + Refer to if you are unsure how to convert HCL options to JSON. + ::: + ''; + }; + }; + } + ) + ); + }; - createAgentInstance = { instance, name, flavour }: + createAgentInstance = + { + instance, + name, + flavour, + }: let configFile = format.generate "${name}.json" instance.settings; in @@ -97,7 +127,9 @@ let User = instance.user; Group = instance.group; RuntimeDirectory = flavour; - ExecStart = "${getExe instance.package} ${optionalString ((getName instance.package) == "vault") "agent"} -config ${configFile}"; + ExecStart = "${getExe instance.package} ${ + optionalString ((getName instance.package) == "vault") "agent" + } -config ${configFile}"; ExecReload = "${pkgs.coreutils}/bin/kill -SIGHUP $MAINPID"; KillSignal = "SIGINT"; TimeoutStopSec = "30s"; @@ -108,19 +140,36 @@ in { options = { services.consul-template.instances = commonOptions { pkgName = "consul-template"; }; - services.vault-agent.instances = commonOptions { pkgName = "vault"; flavour = "vault-agent"; }; + services.vault-agent.instances = commonOptions { + pkgName = "vault"; + flavour = "vault-agent"; + }; }; - config = mkMerge (map - (flavour: - let cfg = config.services.${flavour}; in - mkIf (cfg.instances != { }) { - systemd.services = mapAttrs' - (name: instance: nameValuePair "${flavour}-${name}" (createAgentInstance { inherit name instance flavour; })) - cfg.instances; - }) - [ "consul-template" "vault-agent" ]); + config = mkMerge ( + map + ( + flavour: + let + cfg = config.services.${flavour}; + in + mkIf (cfg.instances != { }) { + systemd.services = mapAttrs' ( + name: instance: + nameValuePair "${flavour}-${name}" (createAgentInstance { + inherit name instance flavour; + }) + ) cfg.instances; + } + ) + [ + "consul-template" + "vault-agent" + ] + ); - meta.maintainers = with maintainers; [ emilylange tcheronneau ]; + meta.maintainers = with maintainers; [ + emilylange + tcheronneau + ]; } - diff --git a/nixos/modules/services/security/vault.nix b/nixos/modules/services/security/vault.nix index 650f9bda99c33a..cab8937a861552 100644 --- a/nixos/modules/services/security/vault.nix +++ b/nixos/modules/services/security/vault.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with lib; @@ -9,34 +15,43 @@ let configFile = pkgs.writeText "vault.hcl" '' # vault in dev mode will refuse to start if its configuration sets listener ${lib.optionalString (!cfg.dev) '' - listener "tcp" { - address = "${cfg.address}" - ${if (cfg.tlsCertFile == null || cfg.tlsKeyFile == null) then '' - tls_disable = "true" - '' else '' - tls_cert_file = "${cfg.tlsCertFile}" - tls_key_file = "${cfg.tlsKeyFile}" - ''} - ${cfg.listenerExtraConfig} - } + listener "tcp" { + address = "${cfg.address}" + ${ + if (cfg.tlsCertFile == null || cfg.tlsKeyFile == null) then + '' + tls_disable = "true" + '' + else + '' + tls_cert_file = "${cfg.tlsCertFile}" + tls_key_file = "${cfg.tlsKeyFile}" + '' + } + ${cfg.listenerExtraConfig} + } ''} storage "${cfg.storageBackend}" { - ${optionalString (cfg.storagePath != null) ''path = "${cfg.storagePath}"''} + ${optionalString (cfg.storagePath != null) ''path = "${cfg.storagePath}"''} ${optionalString (cfg.storageConfig != null) cfg.storageConfig} } ${optionalString (cfg.telemetryConfig != "") '' - telemetry { - ${cfg.telemetryConfig} - } - ''} + telemetry { + ${cfg.telemetryConfig} + } + ''} ${cfg.extraConfig} ''; - allConfigPaths = [configFile] ++ cfg.extraSettingsPaths; - configOptions = escapeShellArgs - (lib.optional cfg.dev "-dev" ++ - lib.optional (cfg.dev && cfg.devRootTokenID != null) "-dev-root-token-id=${cfg.devRootTokenID}" - ++ (concatMap (p: ["-config" p]) allConfigPaths)); + allConfigPaths = [ configFile ] ++ cfg.extraSettingsPaths; + configOptions = escapeShellArgs ( + lib.optional cfg.dev "-dev" + ++ lib.optional (cfg.dev && cfg.devRootTokenID != null) "-dev-root-token-id=${cfg.devRootTokenID}" + ++ (concatMap (p: [ + "-config" + p + ]) allConfigPaths) + ); in @@ -92,14 +107,30 @@ in }; storageBackend = mkOption { - type = types.enum [ "inmem" "file" "consul" "zookeeper" "s3" "azure" "dynamodb" "etcd" "mssql" "mysql" "postgresql" "swift" "gcs" "raft" ]; + type = types.enum [ + "inmem" + "file" + "consul" + "zookeeper" + "s3" + "azure" + "dynamodb" + "etcd" + "mssql" + "mysql" + "postgresql" + "swift" + "gcs" + "raft" + ]; default = "inmem"; description = "The name of the type of storage backend"; }; storagePath = mkOption { type = types.nullOr types.path; - default = if cfg.storageBackend == "file" || cfg.storageBackend == "raft" then "/var/lib/vault" else null; + default = + if cfg.storageBackend == "file" || cfg.storageBackend == "raft" then "/var/lib/vault" else null; defaultText = literalExpression '' if config.${opt.storageBackend} == "file" || cfg.storageBackend == "raft" then "/var/lib/vault" @@ -135,7 +166,7 @@ in extraSettingsPaths = mkOption { type = types.listOf types.path; - default = []; + default = [ ]; description = '' Configuration files to load besides the immutable one defined by the NixOS module. This can be used to avoid putting credentials in the Nix store, which can be read by any user. @@ -173,8 +204,8 @@ in } { assertion = ( - (cfg.storageBackend == "file" -> (cfg.storagePath != null && cfg.storageConfig == null)) && - (cfg.storagePath != null -> (cfg.storageBackend == "file" || cfg.storageBackend == "raft")) + (cfg.storageBackend == "file" -> (cfg.storagePath != null && cfg.storageConfig == null)) + && (cfg.storagePath != null -> (cfg.storageBackend == "file" || cfg.storageBackend == "raft")) ); message = ''You must set services.vault.storagePath only when using the "file" or "raft" backend''; } @@ -188,15 +219,17 @@ in }; users.groups.vault.gid = config.ids.gids.vault; - systemd.tmpfiles.rules = optional (cfg.storagePath != null) - "d '${cfg.storagePath}' 0700 vault vault - -"; + systemd.tmpfiles.rules = optional ( + cfg.storagePath != null + ) "d '${cfg.storagePath}' 0700 vault vault - -"; systemd.services.vault = { description = "Vault server daemon"; - wantedBy = ["multi-user.target"]; - after = [ "network.target" ] - ++ optional (config.services.consul.enable && cfg.storageBackend == "consul") "consul.service"; + wantedBy = [ "multi-user.target" ]; + after = [ + "network.target" + ] ++ optional (config.services.consul.enable && cfg.storageBackend == "consul") "consul.service"; restartIfChanged = false; # do not restart on "nixos-rebuild switch". It would seal the storage and disrupt the clients. diff --git a/nixos/modules/services/security/vaultwarden/default.nix b/nixos/modules/services/security/vaultwarden/default.nix index 11d49b580b310e..285dbc5d70468c 100644 --- a/nixos/modules/services/security/vaultwarden/default.nix +++ b/nixos/modules/services/security/vaultwarden/default.nix @@ -1,41 +1,72 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.vaultwarden; user = config.users.users.vaultwarden.name; group = config.users.groups.vaultwarden.name; - StateDirectory = if lib.versionOlder config.system.stateVersion "24.11" then "bitwarden_rs" else "vaultwarden"; + StateDirectory = + if lib.versionOlder config.system.stateVersion "24.11" then "bitwarden_rs" else "vaultwarden"; dataDir = "/var/lib/${StateDirectory}"; # Convert name from camel case (e.g. disable2FARemember) to upper case snake case (e.g. DISABLE_2FA_REMEMBER). - nameToEnvVar = name: + nameToEnvVar = + name: let parts = builtins.split "([A-Z0-9]+)" name; - partsToEnvVar = parts: lib.foldl' (key: x: let last = lib.stringLength key - 1; in - if lib.isList x then key + lib.optionalString (key != "" && lib.substring last 1 key != "_") "_" + lib.head x - else if key != "" && lib.elem (lib.substring 0 1 x) lib.lowerChars then # to handle e.g. [ "disable" [ "2FAR" ] "emember" ] - lib.substring 0 last key + lib.optionalString (lib.substring (last - 1) 1 key != "_") "_" + lib.substring last 1 key + lib.toUpper x - else key + lib.toUpper x) "" parts; - in if builtins.match "[A-Z0-9_]+" name != null then name else partsToEnvVar parts; + partsToEnvVar = + parts: + lib.foldl' ( + key: x: + let + last = lib.stringLength key - 1; + in + if lib.isList x then + key + lib.optionalString (key != "" && lib.substring last 1 key != "_") "_" + lib.head x + else if key != "" && lib.elem (lib.substring 0 1 x) lib.lowerChars then # to handle e.g. [ "disable" [ "2FAR" ] "emember" ] + lib.substring 0 last key + + lib.optionalString (lib.substring (last - 1) 1 key != "_") "_" + + lib.substring last 1 key + + lib.toUpper x + else + key + lib.toUpper x + ) "" parts; + in + if builtins.match "[A-Z0-9_]+" name != null then name else partsToEnvVar parts; # Due to the different naming schemes allowed for config keys, # we can only check for values consistently after converting them to their corresponding environment variable name. configEnv = let - configEnv = lib.concatMapAttrs (name: value: lib.optionalAttrs (value != null) { - ${nameToEnvVar name} = if lib.isBool value then lib.boolToString value else toString value; - }) cfg.config; - in { DATA_FOLDER = dataDir; } // lib.optionalAttrs (!(configEnv ? WEB_VAULT_ENABLED) || configEnv.WEB_VAULT_ENABLED == "true") { + configEnv = lib.concatMapAttrs ( + name: value: + lib.optionalAttrs (value != null) { + ${nameToEnvVar name} = if lib.isBool value then lib.boolToString value else toString value; + } + ) cfg.config; + in + { + DATA_FOLDER = dataDir; + } + // lib.optionalAttrs (!(configEnv ? WEB_VAULT_ENABLED) || configEnv.WEB_VAULT_ENABLED == "true") { WEB_VAULT_FOLDER = "${cfg.webVaultPackage}/share/vaultwarden/vault"; - } // configEnv; + } + // configEnv; - configFile = pkgs.writeText "vaultwarden.env" (lib.concatStrings (lib.mapAttrsToList (name: value: "${name}=${value}\n") configEnv)); + configFile = pkgs.writeText "vaultwarden.env" ( + lib.concatStrings (lib.mapAttrsToList (name: value: "${name}=${value}\n") configEnv) + ); vaultwarden = cfg.package.override { inherit (cfg) dbBackend; }; -in { +in +{ imports = [ (lib.mkRenamedOptionModule [ "services" "bitwarden_rs" ] [ "services" "vaultwarden" ]) ]; @@ -44,7 +75,11 @@ in { enable = lib.mkEnableOption "vaultwarden"; dbBackend = lib.mkOption { - type = lib.types.enum [ "sqlite" "mysql" "postgresql" ]; + type = lib.types.enum [ + "sqlite" + "mysql" + "postgresql" + ]; default = "sqlite"; description = '' Which database backend vaultwarden will be using. @@ -61,7 +96,15 @@ in { }; config = lib.mkOption { - type = with lib.types; attrsOf (nullOr (oneOf [ bool int str ])); + type = + with lib.types; + attrsOf ( + nullOr (oneOf [ + bool + int + str + ]) + ); default = { ROCKET_ADDRESS = "::1"; # default to localhost ROCKET_PORT = 8222; @@ -269,6 +312,9 @@ in { meta = { # uses attributes of the linked package buildDocsInSandbox = false; - maintainers = with lib.maintainers; [ dotlambda SuperSandro2000 ]; + maintainers = with lib.maintainers; [ + dotlambda + SuperSandro2000 + ]; }; } diff --git a/nixos/modules/services/security/yubikey-agent.nix b/nixos/modules/services/security/yubikey-agent.nix index 6a4dc7014970a1..c746730ca51dd5 100644 --- a/nixos/modules/services/security/yubikey-agent.nix +++ b/nixos/modules/services/security/yubikey-agent.nix @@ -1,6 +1,11 @@ # Global configuration for yubikey-agent. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -10,7 +15,10 @@ in { ###### interface - meta.maintainers = with maintainers; [ philandstuff rawkode ]; + meta.maintainers = with maintainers; [ + philandstuff + rawkode + ]; options = { diff --git a/nixos/modules/services/system/automatic-timezoned.nix b/nixos/modules/services/system/automatic-timezoned.nix index 50f84f39af7d2f..aa84a8887c8714 100644 --- a/nixos/modules/services/system/automatic-timezoned.nix +++ b/nixos/modules/services/system/automatic-timezoned.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/system/bpftune.nix b/nixos/modules/services/system/bpftune.nix index 295aba28c05f91..c69a53b6d55496 100644 --- a/nixos/modules/services/system/bpftune.nix +++ b/nixos/modules/services/system/bpftune.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.bpftune; in diff --git a/nixos/modules/services/system/cachix-agent/default.nix b/nixos/modules/services/system/cachix-agent/default.nix index a6fe9f0cfed4d6..e4df9ae5cc9cd8 100644 --- a/nixos/modules/services/system/cachix-agent/default.nix +++ b/nixos/modules/services/system/cachix-agent/default.nix @@ -1,10 +1,16 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; let cfg = config.services.cachix-agent; -in { +in +{ meta.maintainers = [ lib.maintainers.domenkozar ]; options.services.cachix-agent = { @@ -50,7 +56,7 @@ in { systemd.services.cachix-agent = { description = "Cachix Deploy Agent"; wants = [ "network-online.target" ]; - after = ["network-online.target"]; + after = [ "network-online.target" ]; path = [ config.nix.package ]; wantedBy = [ "multi-user.target" ]; @@ -67,7 +73,9 @@ in { RestartSec = 5; EnvironmentFile = cfg.credentialsFile; ExecStart = '' - ${cfg.package}/bin/cachix ${lib.optionalString cfg.verbose "--verbose"} ${lib.optionalString (cfg.host != null) "--host ${cfg.host}"} \ + ${cfg.package}/bin/cachix ${lib.optionalString cfg.verbose "--verbose"} ${ + lib.optionalString (cfg.host != null) "--host ${cfg.host}" + } \ deploy agent ${cfg.name} ${optionalString (cfg.profile != null) cfg.profile} ''; }; diff --git a/nixos/modules/services/system/cachix-watch-store.nix b/nixos/modules/services/system/cachix-watch-store.nix index ead3503d7e0352..3505fe3a9a0936 100644 --- a/nixos/modules/services/system/cachix-watch-store.nix +++ b/nixos/modules/services/system/cachix-watch-store.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -6,7 +11,10 @@ let cfg = config.services.cachix-watch-store; in { - meta.maintainers = [ lib.maintainers.jfroche lib.maintainers.domenkozar ]; + meta.maintainers = [ + lib.maintainers.jfroche + lib.maintainers.domenkozar + ]; options.services.cachix-watch-store = { enable = mkEnableOption "Cachix Watch Store: https://docs.cachix.org"; @@ -78,19 +86,33 @@ in DynamicUser = true; LoadCredential = [ "cachix-token:${toString cfg.cachixTokenFile}" - ] - ++ lib.optional (cfg.signingKeyFile != null) "signing-key:${toString cfg.signingKeyFile}"; + ] ++ lib.optional (cfg.signingKeyFile != null) "signing-key:${toString cfg.signingKeyFile}"; }; script = let - command = [ "${cfg.package}/bin/cachix" ] - ++ (lib.optional cfg.verbose "--verbose") ++ (lib.optionals (cfg.host != null) [ "--host" cfg.host ]) - ++ [ "watch-store" ] ++ (lib.optionals (cfg.compressionLevel != null) [ "--compression-level" (toString cfg.compressionLevel) ]) - ++ (lib.optionals (cfg.jobs != null) [ "--jobs" (toString cfg.jobs) ]) ++ [ cfg.cacheName ]; + command = + [ "${cfg.package}/bin/cachix" ] + ++ (lib.optional cfg.verbose "--verbose") + ++ (lib.optionals (cfg.host != null) [ + "--host" + cfg.host + ]) + ++ [ "watch-store" ] + ++ (lib.optionals (cfg.compressionLevel != null) [ + "--compression-level" + (toString cfg.compressionLevel) + ]) + ++ (lib.optionals (cfg.jobs != null) [ + "--jobs" + (toString cfg.jobs) + ]) + ++ [ cfg.cacheName ]; in '' export CACHIX_AUTH_TOKEN="$(<"$CREDENTIALS_DIRECTORY/cachix-token")" - ${lib.optionalString (cfg.signingKeyFile != null) ''export CACHIX_SIGNING_KEY="$(<"$CREDENTIALS_DIRECTORY/signing-key")"''} + ${lib.optionalString ( + cfg.signingKeyFile != null + ) ''export CACHIX_SIGNING_KEY="$(<"$CREDENTIALS_DIRECTORY/signing-key")"''} ${lib.escapeShellArgs command} ''; }; diff --git a/nixos/modules/services/system/cloud-init.nix b/nixos/modules/services/system/cloud-init.nix index 7148d62b90842a..d9ec130add915b 100644 --- a/nixos/modules/services/system/cloud-init.nix +++ b/nixos/modules/services/system/cloud-init.nix @@ -1,23 +1,29 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.cloud-init; - path = with pkgs; [ - cloud-init - iproute2 - nettools - openssh - shadow - util-linux - busybox - ] - ++ optional cfg.btrfs.enable btrfs-progs - ++ optional cfg.ext4.enable e2fsprogs - ++ optional cfg.xfs.enable xfsprogs - ++ cfg.extraPackages - ; + path = + with pkgs; + [ + cloud-init + iproute2 + nettools + openssh + shadow + util-linux + busybox + ] + ++ optional cfg.btrfs.enable btrfs-progs + ++ optional cfg.ext4.enable e2fsprogs + ++ optional cfg.xfs.enable xfsprogs + ++ cfg.extraPackages; hasFs = fsName: lib.any (fs: fs.fsType == fsName) (lib.attrValues config.fileSystems); settingsFormat = pkgs.formats.yaml { }; cfgfile = settingsFormat.generate "cloud.cfg" cfg.settings; @@ -166,11 +172,7 @@ in }; environment.etc."cloud/cloud.cfg" = - if cfg.config == "" then - { source = cfgfile; } - else - { text = cfg.config; } - ; + if cfg.config == "" then { source = cfgfile; } else { text = cfg.config; }; systemd.network.enable = mkIf cfg.network.enable true; @@ -180,7 +182,10 @@ in # In certain environments (AWS for example), cloud-init-local will # first configure an IP through DHCP, and later delete it. # This can cause race conditions with anything else trying to set IP through DHCP. - before = [ "systemd-networkd.service" "dhcpcd.service" ]; + before = [ + "systemd-networkd.service" + "dhcpcd.service" + ]; path = path; serviceConfig = { Type = "oneshot"; @@ -200,8 +205,14 @@ in "sshd.service" "sshd-keygen.service" ]; - after = [ "network-online.target" "cloud-init-local.service" ]; - before = [ "sshd.service" "sshd-keygen.service" ]; + after = [ + "network-online.target" + "cloud-init-local.service" + ]; + before = [ + "sshd.service" + "sshd-keygen.service" + ]; requires = [ "network.target" ]; path = path; serviceConfig = { @@ -217,7 +228,10 @@ in description = "Apply the settings specified in cloud-config"; wantedBy = [ "multi-user.target" ]; wants = [ "network-online.target" ]; - after = [ "network-online.target" "cloud-config.target" ]; + after = [ + "network-online.target" + "cloud-config.target" + ]; path = path; serviceConfig = { @@ -233,7 +247,11 @@ in description = "Execute cloud user/final scripts"; wantedBy = [ "multi-user.target" ]; wants = [ "network-online.target" ]; - after = [ "network-online.target" "cloud-config.service" "rc-local.service" ]; + after = [ + "network-online.target" + "cloud-config.service" + "rc-local.service" + ]; requires = [ "cloud-config.target" ]; path = path; serviceConfig = { @@ -247,7 +265,10 @@ in systemd.targets.cloud-config = { description = "Cloud-config availability"; - requires = [ "cloud-init-local.service" "cloud-init.service" ]; + requires = [ + "cloud-init-local.service" + "cloud-init.service" + ]; }; }; diff --git a/nixos/modules/services/system/kerberos/default.nix b/nixos/modules/services/system/kerberos/default.nix index 34c7c6c84f865e..90baae98624f33 100644 --- a/nixos/modules/services/system/kerberos/default.nix +++ b/nixos/modules/services/system/kerberos/default.nix @@ -1,16 +1,26 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let inherit (lib) mkOption types; cfg = config.services.kerberos_server; inherit (config.security.krb5) package; - format = import ../../../security/krb5/krb5-conf-format.nix { inherit pkgs lib; } { enableKdcACLEntries = true; }; + format = import ../../../security/krb5/krb5-conf-format.nix { inherit pkgs lib; } { + enableKdcACLEntries = true; + }; in { imports = [ - (lib.mkRenamedOptionModule [ "services" "kerberos_server" "realms" ] [ "services" "kerberos_server" "settings" "realms" ]) + (lib.mkRenamedOptionModule + [ "services" "kerberos_server" "realms" ] + [ "services" "kerberos_server" "settings" "realms" ] + ) ./mit.nix ./heimdal.nix diff --git a/nixos/modules/services/system/kerberos/heimdal.nix b/nixos/modules/services/system/kerberos/heimdal.nix index cec4dd276e6b9f..4c1df2088ae3e5 100644 --- a/nixos/modules/services/system/kerberos/heimdal.nix +++ b/nixos/modules/services/system/kerberos/heimdal.nix @@ -1,17 +1,31 @@ -{ pkgs, config, lib, ... } : +{ + pkgs, + config, + lib, + ... +}: let - inherit (lib) mapAttrs; + inherit (lib) mapAttrs; cfg = config.services.kerberos_server; package = config.security.krb5.package; aclConfigs = lib.pipe cfg.settings.realms [ - (mapAttrs (name: { acl, ... }: lib.concatMapStringsSep "\n" ( - { principal, access, target, ... }: - "${principal}\t${lib.concatStringsSep "," (lib.toList access)}\t${target}" - ) acl)) - (lib.mapAttrsToList (name: text: - { + (mapAttrs ( + name: + { acl, ... }: + lib.concatMapStringsSep "\n" ( + { + principal, + access, + target, + ... + }: + "${principal}\t${lib.concatStringsSep "," (lib.toList access)}\t${target}" + ) acl + )) + (lib.mapAttrsToList ( + name: text: { dbname = "/var/lib/heimdal/heimdal"; acl_file = pkgs.writeText "${name}.acl" text; } @@ -25,7 +39,9 @@ let }; }; - format = import ../../../security/krb5/krb5-conf-format.nix { inherit pkgs lib; } { enableKdcACLEntries = true; }; + format = import ../../../security/krb5/krb5-conf-format.nix { inherit pkgs lib; } { + enableKdcACLEntries = true; + }; kdcConfFile = format.generate "kdc.conf" finalConfig; in @@ -34,19 +50,21 @@ in config = lib.mkIf (cfg.enable && package.passthru.implementation == "heimdal") { environment.etc."heimdal-kdc/kdc.conf".source = kdcConfFile; - systemd.tmpfiles.settings."10-heimdal" = let - databases = lib.pipe finalConfig.kdc.database [ - (map (dbAttrs: dbAttrs.dbname or null)) - (lib.filter (x: x != null)) - lib.unique - ]; - in lib.genAttrs databases (_: { - d = { - user = "root"; - group = "root"; - mode = "0700"; - }; - }); + systemd.tmpfiles.settings."10-heimdal" = + let + databases = lib.pipe finalConfig.kdc.database [ + (map (dbAttrs: dbAttrs.dbname or null)) + (lib.filter (x: x != null)) + lib.unique + ]; + in + lib.genAttrs databases (_: { + d = { + user = "root"; + group = "root"; + mode = "0700"; + }; + }); systemd.services.kadmind = { description = "Kerberos Administration Daemon"; diff --git a/nixos/modules/services/system/kerberos/mit.nix b/nixos/modules/services/system/kerberos/mit.nix index 9ce58986e27af9..c698468dddeee9 100644 --- a/nixos/modules/services/system/kerberos/mit.nix +++ b/nixos/modules/services/system/kerberos/mit.nix @@ -1,4 +1,9 @@ -{ pkgs, config, lib, ... } : +{ + pkgs, + config, + lib, + ... +}: let inherit (lib) mapAttrs; @@ -6,25 +11,45 @@ let package = config.security.krb5.package; PIDFile = "/run/kdc.pid"; - format = import ../../../security/krb5/krb5-conf-format.nix { inherit pkgs lib; } { enableKdcACLEntries = true; }; + format = import ../../../security/krb5/krb5-conf-format.nix { inherit pkgs lib; } { + enableKdcACLEntries = true; + }; aclMap = { - add = "a"; cpw = "c"; delete = "d"; get = "i"; list = "l"; modify = "m"; + add = "a"; + cpw = "c"; + delete = "d"; + get = "i"; + list = "l"; + modify = "m"; all = "*"; }; aclConfigs = lib.pipe cfg.settings.realms [ - (mapAttrs (name: { acl, ... }: lib.concatMapStringsSep "\n" ( - { principal, access, target, ... }: let - access_code = map (a: aclMap.${a}) (lib.toList access); - in "${principal} ${lib.concatStrings access_code} ${target}" - ) acl)) + (mapAttrs ( + name: + { acl, ... }: + lib.concatMapStringsSep "\n" ( + { + principal, + access, + target, + ... + }: + let + access_code = map (a: aclMap.${a}) (lib.toList access); + in + "${principal} ${lib.concatStrings access_code} ${target}" + ) acl + )) - (lib.concatMapAttrs (name: text: { - ${name} = { - acl_file = pkgs.writeText "${name}.acl" text; - }; - })) + (lib.concatMapAttrs ( + name: text: { + ${name} = { + acl_file = pkgs.writeText "${name}.acl" text; + }; + } + )) ]; finalConfig = cfg.settings // { diff --git a/nixos/modules/services/system/localtimed.nix b/nixos/modules/services/system/localtimed.nix index ef5ac1e69e0cee..745d767d074469 100644 --- a/nixos/modules/services/system/localtimed.nix +++ b/nixos/modules/services/system/localtimed.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.localtimed; -in { +in +{ imports = [ (lib.mkRenamedOptionModule [ "services" "localtime" ] [ "services" "localtimed" ]) ]; options = { diff --git a/nixos/modules/services/system/nix-daemon.nix b/nixos/modules/services/system/nix-daemon.nix index adadce4f88d6d5..4a761048c71378 100644 --- a/nixos/modules/services/system/nix-daemon.nix +++ b/nixos/modules/services/system/nix-daemon.nix @@ -5,7 +5,12 @@ - nixos/modules/config/nix.nix: the nix.conf - nixos/modules/config/nix-remote-build.nix: the nix.conf */ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -40,8 +45,28 @@ in { imports = [ - (mkRenamedOptionModuleWith { sinceRelease = 2205; from = [ "nix" "daemonIONiceLevel" ]; to = [ "nix" "daemonIOSchedPriority" ]; }) - (mkRenamedOptionModuleWith { sinceRelease = 2211; from = [ "nix" "readOnlyStore" ]; to = [ "boot" "readOnlyNixStore" ]; }) + (mkRenamedOptionModuleWith { + sinceRelease = 2205; + from = [ + "nix" + "daemonIONiceLevel" + ]; + to = [ + "nix" + "daemonIOSchedPriority" + ]; + }) + (mkRenamedOptionModuleWith { + sinceRelease = 2211; + from = [ + "nix" + "readOnlyStore" + ]; + to = [ + "boot" + "readOnlyNixStore" + ]; + }) (mkRemovedOptionModule [ "nix" "daemonNiceLevel" ] "Consider nix.daemonCPUSchedPolicy instead.") ]; @@ -70,7 +95,11 @@ in }; daemonCPUSchedPolicy = mkOption { - type = types.enum [ "other" "batch" "idle" ]; + type = types.enum [ + "other" + "batch" + "idle" + ]; default = "other"; example = "batch"; description = '' @@ -96,11 +125,14 @@ in For more fine-grained resource control, please refer to {manpage}`systemd.resource-control(5)` and adjust {option}`systemd.services.nix-daemon` directly. - ''; + ''; }; daemonIOSchedClass = mkOption { - type = types.enum [ "best-effort" "idle" ]; + type = types.enum [ + "best-effort" + "idle" + ]; default = "best-effort"; example = "idle"; description = '' @@ -119,7 +151,7 @@ in systems that experience only intermittent phases of high I/O load, such as desktop or portable computers used interactively. Other systems should use the `best-effort` class. - ''; + ''; }; daemonIOSchedPriority = mkOption { @@ -155,16 +187,13 @@ in }; }; - ###### implementation config = mkIf cfg.enable { - environment.systemPackages = - [ - nixPackage - pkgs.nix-info - ] - ++ optional (config.programs.bash.completion.enable) pkgs.nix-bash-completions; + environment.systemPackages = [ + nixPackage + pkgs.nix-info + ] ++ optional (config.programs.bash.completion.enable) pkgs.nix-bash-completions; systemd.packages = [ nixPackage ]; @@ -181,69 +210,75 @@ in systemd.sockets.nix-daemon.wantedBy = [ "sockets.target" ]; - systemd.services.nix-daemon = - { - path = [ nixPackage pkgs.util-linux config.programs.ssh.package ] - ++ optionals cfg.distributedBuilds [ pkgs.gzip ]; - - environment = cfg.envVars - // { CURL_CA_BUNDLE = "/etc/ssl/certs/ca-certificates.crt"; } - // config.networking.proxy.envVars; - - unitConfig.RequiresMountsFor = "/nix/store"; - - serviceConfig = - { - CPUSchedulingPolicy = cfg.daemonCPUSchedPolicy; - IOSchedulingClass = cfg.daemonIOSchedClass; - IOSchedulingPriority = cfg.daemonIOSchedPriority; - LimitNOFILE = 1048576; - Delegate = "yes"; - }; - - restartTriggers = [ config.environment.etc."nix/nix.conf".source ]; - - # `stopIfChanged = false` changes to switch behavior - # from stop -> update units -> start - # to update units -> restart - # - # The `stopIfChanged` setting therefore controls a trade-off between a - # more predictable lifecycle, which runs the correct "version" of - # the `ExecStop` line, and on the other hand the availability of - # sockets during the switch, as the effectiveness of the stop operation - # depends on the socket being stopped as well. - # - # As `nix-daemon.service` does not make use of `ExecStop`, we prefer - # to keep the socket up and available. This is important for machines - # that run Nix-based services, such as automated build, test, and deploy - # services, that expect the daemon socket to be available at all times. - # - # Notably, the Nix client does not retry on failure to connect to the - # daemon socket, and the in-process RemoteStore instance will disable - # itself. This makes retries infeasible even for services that are - # aware of the issue. Failure to connect can affect not only new client - # processes, but also new RemoteStore instances in existing processes, - # as well as existing RemoteStore instances that have not saturated - # their connection pool. - # - # Also note that `stopIfChanged = true` does not kill existing - # connection handling daemons, as one might wish to happen before a - # breaking Nix upgrade (which is rare). The daemon forks that handle - # the individual connections split off into their own sessions, causing - # them not to be stopped by systemd. - # If a Nix upgrade does require all existing daemon processes to stop, - # nix-daemon must do so on its own accord, and only when the new version - # starts and detects that Nix's persistent state needs an upgrade. - stopIfChanged = false; - + systemd.services.nix-daemon = { + path = [ + nixPackage + pkgs.util-linux + config.programs.ssh.package + ] ++ optionals cfg.distributedBuilds [ pkgs.gzip ]; + + environment = + cfg.envVars + // { + CURL_CA_BUNDLE = "/etc/ssl/certs/ca-certificates.crt"; + } + // config.networking.proxy.envVars; + + unitConfig.RequiresMountsFor = "/nix/store"; + + serviceConfig = { + CPUSchedulingPolicy = cfg.daemonCPUSchedPolicy; + IOSchedulingClass = cfg.daemonIOSchedClass; + IOSchedulingPriority = cfg.daemonIOSchedPriority; + LimitNOFILE = 1048576; + Delegate = "yes"; }; + restartTriggers = [ config.environment.etc."nix/nix.conf".source ]; + + # `stopIfChanged = false` changes to switch behavior + # from stop -> update units -> start + # to update units -> restart + # + # The `stopIfChanged` setting therefore controls a trade-off between a + # more predictable lifecycle, which runs the correct "version" of + # the `ExecStop` line, and on the other hand the availability of + # sockets during the switch, as the effectiveness of the stop operation + # depends on the socket being stopped as well. + # + # As `nix-daemon.service` does not make use of `ExecStop`, we prefer + # to keep the socket up and available. This is important for machines + # that run Nix-based services, such as automated build, test, and deploy + # services, that expect the daemon socket to be available at all times. + # + # Notably, the Nix client does not retry on failure to connect to the + # daemon socket, and the in-process RemoteStore instance will disable + # itself. This makes retries infeasible even for services that are + # aware of the issue. Failure to connect can affect not only new client + # processes, but also new RemoteStore instances in existing processes, + # as well as existing RemoteStore instances that have not saturated + # their connection pool. + # + # Also note that `stopIfChanged = true` does not kill existing + # connection handling daemons, as one might wish to happen before a + # breaking Nix upgrade (which is rare). The daemon forks that handle + # the individual connections split off into their own sessions, causing + # them not to be stopped by systemd. + # If a Nix upgrade does require all existing daemon processes to stop, + # nix-daemon must do so on its own accord, and only when the new version + # starts and detects that Nix's persistent state needs an upgrade. + stopIfChanged = false; + + }; + # Set up the environment variables for running Nix. environment.sessionVariables = cfg.envVars; nix.nrBuildUsers = mkDefault ( - if cfg.settings.auto-allocate-uids or false then 0 - else max 32 (if cfg.settings.max-jobs == "auto" then 0 else cfg.settings.max-jobs) + if cfg.settings.auto-allocate-uids or false then + 0 + else + max 32 (if cfg.settings.max-jobs == "auto" then 0 else cfg.settings.max-jobs) ); users.users = nixbldUsers; diff --git a/nixos/modules/services/system/nscd.nix b/nixos/modules/services/system/nscd.nix index 4b28f8100225b4..c5b14e23fdda34 100644 --- a/nixos/modules/services/system/nscd.nix +++ b/nixos/modules/services/system/nscd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -65,9 +70,7 @@ in package = mkOption { type = types.package; default = - if pkgs.stdenv.hostPlatform.libc == "glibc" - then pkgs.stdenv.cc.libc.bin - else pkgs.glibc.bin; + if pkgs.stdenv.hostPlatform.libc == "glibc" then pkgs.stdenv.cc.libc.bin else pkgs.glibc.bin; defaultText = lib.literalExpression '' if pkgs.stdenv.hostPlatform.libc == "glibc" then pkgs.stdenv.cc.libc.bin @@ -83,7 +86,6 @@ in }; - ###### implementation config = mkIf cfg.enable { @@ -96,60 +98,68 @@ in users.groups.${cfg.group} = { }; - systemd.services.nscd = - { - description = "Name Service Cache Daemon" - + lib.optionalString cfg.enableNsncd " (nsncd)"; - - before = [ "nss-lookup.target" "nss-user-lookup.target" ]; - wants = [ "nss-lookup.target" "nss-user-lookup.target" ]; - wantedBy = [ "multi-user.target" ]; - requiredBy = [ "nss-lookup.target" "nss-user-lookup.target" ]; - - environment = { LD_LIBRARY_PATH = nssModulesPath; }; + systemd.services.nscd = { + description = "Name Service Cache Daemon" + lib.optionalString cfg.enableNsncd " (nsncd)"; + + before = [ + "nss-lookup.target" + "nss-user-lookup.target" + ]; + wants = [ + "nss-lookup.target" + "nss-user-lookup.target" + ]; + wantedBy = [ "multi-user.target" ]; + requiredBy = [ + "nss-lookup.target" + "nss-user-lookup.target" + ]; + + environment = { + LD_LIBRARY_PATH = nssModulesPath; + }; - restartTriggers = lib.optionals (!cfg.enableNsncd) ([ + restartTriggers = lib.optionals (!cfg.enableNsncd) ( + [ config.environment.etc.hosts.source config.environment.etc."nsswitch.conf".source config.environment.etc."nscd.conf".source - ] ++ optionals config.users.mysql.enable [ + ] + ++ optionals config.users.mysql.enable [ config.environment.etc."libnss-mysql.cfg".source config.environment.etc."libnss-mysql-root.cfg".source - ]); - - # In some configurations, nscd needs to be started as root; it will - # drop privileges after all the NSS modules have read their - # configuration files. So prefix the ExecStart command with "!" to - # prevent systemd from dropping privileges early. See ExecStart in - # systemd.service(5). We use a static user, because some NSS modules - # sill want to read their configuration files after the privilege drop - # and so users can set the owner of those files to the nscd user. - serviceConfig = - { - ExecStart = - if cfg.enableNsncd then "${pkgs.nsncd}/bin/nsncd" - else "!@${cfg.package}/bin/nscd nscd"; - Type = if cfg.enableNsncd then "notify" else "forking"; - User = cfg.user; - Group = cfg.group; - RemoveIPC = true; - PrivateTmp = true; - # https://github.com/twosigma/nsncd/pull/33/files#r1496927653 - Environment = [ "NSNCD_HANDOFF_TIMEOUT=10" ]; - NoNewPrivileges = true; - RestrictSUIDSGID = true; - ProtectSystem = "strict"; - ProtectHome = "read-only"; - RuntimeDirectory = "nscd"; - PIDFile = "/run/nscd/nscd.pid"; - Restart = "always"; - ExecReload = - lib.optionals (!cfg.enableNsncd) [ - "${cfg.package}/bin/nscd --invalidate passwd" - "${cfg.package}/bin/nscd --invalidate group" - "${cfg.package}/bin/nscd --invalidate hosts" - ]; - }; + ] + ); + + # In some configurations, nscd needs to be started as root; it will + # drop privileges after all the NSS modules have read their + # configuration files. So prefix the ExecStart command with "!" to + # prevent systemd from dropping privileges early. See ExecStart in + # systemd.service(5). We use a static user, because some NSS modules + # sill want to read their configuration files after the privilege drop + # and so users can set the owner of those files to the nscd user. + serviceConfig = { + ExecStart = if cfg.enableNsncd then "${pkgs.nsncd}/bin/nsncd" else "!@${cfg.package}/bin/nscd nscd"; + Type = if cfg.enableNsncd then "notify" else "forking"; + User = cfg.user; + Group = cfg.group; + RemoveIPC = true; + PrivateTmp = true; + # https://github.com/twosigma/nsncd/pull/33/files#r1496927653 + Environment = [ "NSNCD_HANDOFF_TIMEOUT=10" ]; + NoNewPrivileges = true; + RestrictSUIDSGID = true; + ProtectSystem = "strict"; + ProtectHome = "read-only"; + RuntimeDirectory = "nscd"; + PIDFile = "/run/nscd/nscd.pid"; + Restart = "always"; + ExecReload = lib.optionals (!cfg.enableNsncd) [ + "${cfg.package}/bin/nscd --invalidate passwd" + "${cfg.package}/bin/nscd --invalidate group" + "${cfg.package}/bin/nscd --invalidate hosts" + ]; }; + }; }; } diff --git a/nixos/modules/services/system/saslauthd.nix b/nixos/modules/services/system/saslauthd.nix index 0c198792b1e789..17dae880a0ef49 100644 --- a/nixos/modules/services/system/saslauthd.nix +++ b/nixos/modules/services/system/saslauthd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -36,7 +41,6 @@ in }; - ###### implementation config = mkIf cfg.enable { diff --git a/nixos/modules/services/system/systembus-notify.nix b/nixos/modules/services/system/systembus-notify.nix index 073885732b4b4a..460a9473e1e6ce 100644 --- a/nixos/modules/services/system/systembus-notify.nix +++ b/nixos/modules/services/system/systembus-notify.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.systembus-notify; diff --git a/nixos/modules/services/system/systemd-lock-handler.nix b/nixos/modules/services/system/systemd-lock-handler.nix index 0d3e33236adb05..f19840802c1ce6 100644 --- a/nixos/modules/services/system/systemd-lock-handler.nix +++ b/nixos/modules/services/system/systemd-lock-handler.nix @@ -1,7 +1,8 @@ -{ config -, pkgs -, lib -, ... +{ + config, + pkgs, + lib, + ... }: let cfg = config.services.systemd-lock-handler; diff --git a/nixos/modules/services/system/uptimed.nix b/nixos/modules/services/system/uptimed.nix index d844e5d83e369c..b0c4daa3c1869f 100644 --- a/nixos/modules/services/system/uptimed.nix +++ b/nixos/modules/services/system/uptimed.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -26,28 +31,28 @@ in users.users.uptimed = { description = "Uptimed daemon user"; - home = stateDir; - uid = config.ids.uids.uptimed; - group = "uptimed"; + home = stateDir; + uid = config.ids.uids.uptimed; + group = "uptimed"; }; - users.groups.uptimed = {}; + users.groups.uptimed = { }; systemd.services.uptimed = { unitConfig.Documentation = "man:uptimed(8) man:uprecords(1)"; description = "uptimed service"; - wantedBy = [ "multi-user.target" ]; + wantedBy = [ "multi-user.target" ]; serviceConfig = { - Restart = "on-failure"; - User = "uptimed"; - Nice = 19; - IOSchedulingClass = "idle"; - PrivateTmp = "yes"; - PrivateNetwork = "yes"; - NoNewPrivileges = "yes"; - StateDirectory = [ "uptimed" ]; + Restart = "on-failure"; + User = "uptimed"; + Nice = 19; + IOSchedulingClass = "idle"; + PrivateTmp = "yes"; + PrivateNetwork = "yes"; + NoNewPrivileges = "yes"; + StateDirectory = [ "uptimed" ]; InaccessibleDirectories = "/home"; - ExecStart = "${pkgs.uptimed}/sbin/uptimed -f -p ${stateDir}/pid"; + ExecStart = "${pkgs.uptimed}/sbin/uptimed -f -p ${stateDir}/pid"; }; preStart = '' diff --git a/nixos/modules/services/torrent/flexget.nix b/nixos/modules/services/torrent/flexget.nix index 138e9781045c92..35ade70d8b6382 100644 --- a/nixos/modules/services/torrent/flexget.nix +++ b/nixos/modules/services/torrent/flexget.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -9,14 +14,15 @@ let ${cfg.config} ${optionalString cfg.systemScheduler "schedules: no"} -''; + ''; configFile = "${toString cfg.homeDir}/flexget.yml"; -in { +in +{ options = { services.flexget = { enable = mkEnableOption "FlexGet daemon"; - package = mkPackageOption pkgs "flexget" {}; + package = mkPackageOption pkgs "flexget" { }; user = mkOption { default = "deluge"; diff --git a/nixos/modules/services/torrent/flood.nix b/nixos/modules/services/torrent/flood.nix index 213f4ef046483a..a623c62b4400fd 100644 --- a/nixos/modules/services/torrent/flood.nix +++ b/nixos/modules/services/torrent/flood.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.services.flood; @@ -43,14 +49,17 @@ in serviceConfig = { Restart = "on-failure"; RestartSec = "3s"; - ExecStart = utils.escapeSystemdExecArgs ([ - (lib.getExe cfg.package) - "--host" - cfg.host - "--port" - (toString cfg.port) - "--rundir=/var/lib/flood" - ] ++ cfg.extraArgs); + ExecStart = utils.escapeSystemdExecArgs ( + [ + (lib.getExe cfg.package) + "--host" + cfg.host + "--port" + (toString cfg.port) + "--rundir=/var/lib/flood" + ] + ++ cfg.extraArgs + ); CapabilityBoundingSet = [ "" ]; DynamicUser = true; @@ -67,13 +76,21 @@ in ProtectKernelTunables = true; ProtectProc = "invisible"; ProtectSystem = "strict"; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; StateDirectory = "flood"; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "@pkey" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "@pkey" + "~@privileged" + ]; }; }; @@ -82,4 +99,3 @@ in ]; }; } - diff --git a/nixos/modules/services/torrent/magnetico.nix b/nixos/modules/services/torrent/magnetico.nix index 8a5e9f309649c0..fda552aff8fdcf 100644 --- a/nixos/modules/services/torrent/magnetico.nix +++ b/nixos/modules/services/torrent/magnetico.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -7,38 +12,53 @@ let dataDir = "/var/lib/magnetico"; - credFile = with cfg.web; - if credentialsFile != null - then credentialsFile - else pkgs.writeText "magnetico-credentials" - (concatStrings (mapAttrsToList - (user: hash: "${user}:${hash}\n") - cfg.web.credentials)); + credFile = + with cfg.web; + if credentialsFile != null then + credentialsFile + else + pkgs.writeText "magnetico-credentials" ( + concatStrings (mapAttrsToList (user: hash: "${user}:${hash}\n") cfg.web.credentials) + ); # default options in magneticod/main.go - dbURI = concatStrings - [ "sqlite3://${dataDir}/database.sqlite3" - "?_journal_mode=WAL" - "&_busy_timeout=3000" - "&_foreign_keys=true" - ]; - - crawlerArgs = with cfg.crawler; escapeShellArgs - ([ "--database=${dbURI}" - "--indexer-addr=${address}:${toString port}" - "--indexer-max-neighbors=${toString maxNeighbors}" - "--leech-max-n=${toString maxLeeches}" - ] ++ extraOptions); - - webArgs = with cfg.web; escapeShellArgs - ([ "--database=${dbURI}" - (if (cfg.web.credentialsFile != null || cfg.web.credentials != { }) - then "--credentials=${toString credFile}" - else "--no-auth") - "--addr=${address}:${toString port}" - ] ++ extraOptions); - -in { + dbURI = concatStrings [ + "sqlite3://${dataDir}/database.sqlite3" + "?_journal_mode=WAL" + "&_busy_timeout=3000" + "&_foreign_keys=true" + ]; + + crawlerArgs = + with cfg.crawler; + escapeShellArgs ( + [ + "--database=${dbURI}" + "--indexer-addr=${address}:${toString port}" + "--indexer-max-neighbors=${toString maxNeighbors}" + "--leech-max-n=${toString maxLeeches}" + ] + ++ extraOptions + ); + + webArgs = + with cfg.web; + escapeShellArgs ( + [ + "--database=${dbURI}" + ( + if (cfg.web.credentialsFile != null || cfg.web.credentials != { }) then + "--credentials=${toString credFile}" + else + "--no-auth" + ) + "--addr=${address}:${toString port}" + ] + ++ extraOptions + ); + +in +{ ###### interface @@ -85,7 +105,7 @@ in { crawler.extraOptions = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = '' Extra command line arguments to pass to magneticod. ''; @@ -110,7 +130,7 @@ in { web.credentials = mkOption { type = types.attrsOf types.str; - default = {}; + default = { }; example = lib.literalExpression '' { myuser = "$2y$12$YE01LZ8jrbQbx6c0s2hdZO71dSjn2p/O9XsYJpz.5968yCysUgiaG"; @@ -156,7 +176,7 @@ in { web.extraOptions = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = '' Extra command line arguments to pass to magneticow. ''; @@ -173,16 +193,16 @@ in { group = "magnetico"; isSystemUser = true; }; - users.groups.magnetico = {}; + users.groups.magnetico = { }; systemd.services.magneticod = { description = "Magnetico DHT crawler"; wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + after = [ "network.target" ]; serviceConfig = { - User = "magnetico"; - Restart = "on-failure"; + User = "magnetico"; + Restart = "on-failure"; ExecStart = "${pkgs.magnetico}/bin/magneticod ${crawlerArgs}"; }; }; @@ -190,18 +210,20 @@ in { systemd.services.magneticow = { description = "Magnetico web interface"; wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "magneticod.service"]; + after = [ + "network.target" + "magneticod.service" + ]; serviceConfig = { - User = "magnetico"; + User = "magnetico"; StateDirectory = "magnetico"; - Restart = "on-failure"; - ExecStart = "${pkgs.magnetico}/bin/magneticow ${webArgs}"; + Restart = "on-failure"; + ExecStart = "${pkgs.magnetico}/bin/magneticow ${webArgs}"; }; }; - assertions = - [ + assertions = [ { assertion = cfg.web.credentialsFile == null || cfg.web.credentials == { }; message = '' diff --git a/nixos/modules/services/torrent/opentracker.nix b/nixos/modules/services/torrent/opentracker.nix index b30ea7e2377bfd..518830d4c279b8 100644 --- a/nixos/modules/services/torrent/opentracker.nix +++ b/nixos/modules/services/torrent/opentracker.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.opentracker; -in { +in +{ options.services.opentracker = { enable = mkEnableOption "opentracker"; @@ -35,4 +41,3 @@ in { }; }; } - diff --git a/nixos/modules/services/torrent/peerflix.nix b/nixos/modules/services/torrent/peerflix.nix index 821c829f6b4af2..abfbae6b77806c 100644 --- a/nixos/modules/services/torrent/peerflix.nix +++ b/nixos/modules/services/torrent/peerflix.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with lib; @@ -13,7 +19,8 @@ let } ''; -in { +in +{ ###### interface @@ -66,6 +73,6 @@ in { isSystemUser = true; group = "peerflix"; }; - users.groups.peerflix = {}; + users.groups.peerflix = { }; }; } diff --git a/nixos/modules/services/torrent/rtorrent.nix b/nixos/modules/services/torrent/rtorrent.nix index 609b06b5e70662..822e1ab1c3c518 100644 --- a/nixos/modules/services/torrent/rtorrent.nix +++ b/nixos/modules/services/torrent/rtorrent.nix @@ -1,4 +1,10 @@ -{ config, options, pkgs, lib, ... }: +{ + config, + options, + pkgs, + lib, + ... +}: with lib; @@ -7,7 +13,8 @@ let cfg = config.services.rtorrent; opt = options.services.rtorrent; -in { +in +{ meta.maintainers = with lib.maintainers; [ thiagokokada ]; options.services.rtorrent = { @@ -94,7 +101,7 @@ in { config = mkIf cfg.enable { users.groups = mkIf (cfg.group == "rtorrent") { - rtorrent = {}; + rtorrent = { }; }; users.users = mkIf (cfg.user == "rtorrent") { @@ -188,49 +195,61 @@ in { systemd = { services = { - rtorrent = let - rtorrentConfigFile = pkgs.writeText "rtorrent.rc" cfg.configText; - in { - description = "rTorrent system service"; - after = [ "network.target" ]; - path = [ cfg.package pkgs.bash ]; - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - User = cfg.user; - Group = cfg.group; - Type = "simple"; - Restart = "on-failure"; - WorkingDirectory = cfg.dataDir; - ExecStartPre=''${pkgs.bash}/bin/bash -c "if test -e ${cfg.dataDir}/session/rtorrent.lock && test -z $(${pkgs.procps}/bin/pidof rtorrent); then rm -f ${cfg.dataDir}/session/rtorrent.lock; fi"''; - ExecStart="${cfg.package}/bin/rtorrent -n -o system.daemon.set=true -o import=${rtorrentConfigFile}"; - RuntimeDirectory = "rtorrent"; - RuntimeDirectoryMode = 750; - - CapabilityBoundingSet = [ "" ]; - LockPersonality = true; - NoNewPrivileges = true; - PrivateDevices = true; - PrivateTmp = true; - ProtectClock = true; - ProtectControlGroups = true; - # If the default user is changed, there is a good chance that they - # want to store data in e.g.: $HOME directory - # Relax hardening in this case - ProtectHome = lib.mkIf (cfg.user == "rtorrent") true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - ProtectSystem = "full"; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + rtorrent = + let + rtorrentConfigFile = pkgs.writeText "rtorrent.rc" cfg.configText; + in + { + description = "rTorrent system service"; + after = [ "network.target" ]; + path = [ + cfg.package + pkgs.bash + ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + User = cfg.user; + Group = cfg.group; + Type = "simple"; + Restart = "on-failure"; + WorkingDirectory = cfg.dataDir; + ExecStartPre = ''${pkgs.bash}/bin/bash -c "if test -e ${cfg.dataDir}/session/rtorrent.lock && test -z $(${pkgs.procps}/bin/pidof rtorrent); then rm -f ${cfg.dataDir}/session/rtorrent.lock; fi"''; + ExecStart = "${cfg.package}/bin/rtorrent -n -o system.daemon.set=true -o import=${rtorrentConfigFile}"; + RuntimeDirectory = "rtorrent"; + RuntimeDirectoryMode = 750; + + CapabilityBoundingSet = [ "" ]; + LockPersonality = true; + NoNewPrivileges = true; + PrivateDevices = true; + PrivateTmp = true; + ProtectClock = true; + ProtectControlGroups = true; + # If the default user is changed, there is a good chance that they + # want to store data in e.g.: $HOME directory + # Relax hardening in this case + ProtectHome = lib.mkIf (cfg.user == "rtorrent") true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + ProtectSystem = "full"; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; + }; }; - }; }; tmpfiles.rules = [ "d '${cfg.dataDir}' ${cfg.dataPermissions} ${cfg.user} ${cfg.group} -" ]; diff --git a/nixos/modules/services/torrent/torrentstream.nix b/nixos/modules/services/torrent/torrentstream.nix index 9c0e6f85dc57d6..7374cad4f260d3 100644 --- a/nixos/modules/services/torrent/torrentstream.nix +++ b/nixos/modules/services/torrent/torrentstream.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.torrentstream; diff --git a/nixos/modules/services/tracing/tempo.nix b/nixos/modules/services/tracing/tempo.nix index e962af76ad8837..5d329cc7f530d9 100644 --- a/nixos/modules/services/tracing/tempo.nix +++ b/nixos/modules/services/tracing/tempo.nix @@ -1,18 +1,29 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkIf mkOption types; + inherit (lib) + mkEnableOption + mkIf + mkOption + types + ; cfg = config.services.tempo; - settingsFormat = pkgs.formats.yaml {}; -in { + settingsFormat = pkgs.formats.yaml { }; +in +{ options.services.tempo = { enable = mkEnableOption "Grafana Tempo"; settings = mkOption { type = settingsFormat.type; - default = {}; + default = { }; description = '' Specify the configuration for Tempo in Nix. @@ -30,11 +41,10 @@ in { extraFlags = mkOption { type = types.listOf types.str; - default = []; - example = lib.literalExpression - '' - [ "-config.expand-env=true" ] - ''; + default = [ ]; + example = lib.literalExpression '' + [ "-config.expand-env=true" ] + ''; description = '' Additional flags to pass to the `ExecStart=` in `tempo.service`. ''; @@ -45,36 +55,39 @@ in { # for tempo-cli and friends environment.systemPackages = [ pkgs.tempo ]; - assertions = [{ - assertion = ( - (cfg.settings == {}) != (cfg.configFile == null) - ); - message = '' - Please specify a configuration for Tempo with either - 'services.tempo.settings' or - 'services.tempo.configFile'. - ''; - }]; + assertions = [ + { + assertion = ((cfg.settings == { }) != (cfg.configFile == null)); + message = '' + Please specify a configuration for Tempo with either + 'services.tempo.settings' or + 'services.tempo.configFile'. + ''; + } + ]; systemd.services.tempo = { description = "Grafana Tempo Service Daemon"; wantedBy = [ "multi-user.target" ]; - serviceConfig = let - conf = if cfg.configFile == null - then settingsFormat.generate "config.yaml" cfg.settings - else cfg.configFile; - in - { - ExecStart = "${pkgs.tempo}/bin/tempo --config.file=${conf} ${lib.escapeShellArgs cfg.extraFlags}"; - DynamicUser = true; - Restart = "always"; - ProtectSystem = "full"; - DevicePolicy = "closed"; - NoNewPrivileges = true; - WorkingDirectory = "/var/lib/tempo"; - StateDirectory = "tempo"; - }; + serviceConfig = + let + conf = + if cfg.configFile == null then + settingsFormat.generate "config.yaml" cfg.settings + else + cfg.configFile; + in + { + ExecStart = "${pkgs.tempo}/bin/tempo --config.file=${conf} ${lib.escapeShellArgs cfg.extraFlags}"; + DynamicUser = true; + Restart = "always"; + ProtectSystem = "full"; + DevicePolicy = "closed"; + NoNewPrivileges = true; + WorkingDirectory = "/var/lib/tempo"; + StateDirectory = "tempo"; + }; }; }; } diff --git a/nixos/modules/services/ttys/gpm.nix b/nixos/modules/services/ttys/gpm.nix index 308a6d3643a60c..3651da731a3d4f 100644 --- a/nixos/modules/services/ttys/gpm.nix +++ b/nixos/modules/services/ttys/gpm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -35,22 +40,21 @@ in }; - ###### implementation config = mkIf cfg.enable { - systemd.services.gpm = - { description = "Console Mouse Daemon"; + systemd.services.gpm = { + description = "Console Mouse Daemon"; - wantedBy = [ "multi-user.target" ]; - requires = [ "dev-input-mice.device" ]; - after = [ "dev-input-mice.device" ]; + wantedBy = [ "multi-user.target" ]; + requires = [ "dev-input-mice.device" ]; + after = [ "dev-input-mice.device" ]; - serviceConfig.ExecStart = "@${pkgs.gpm}/sbin/gpm gpm -m /dev/input/mice -t ${cfg.protocol}"; - serviceConfig.Type = "forking"; - serviceConfig.PIDFile = "/run/gpm.pid"; - }; + serviceConfig.ExecStart = "@${pkgs.gpm}/sbin/gpm gpm -m /dev/input/mice -t ${cfg.protocol}"; + serviceConfig.Type = "forking"; + serviceConfig.PIDFile = "/run/gpm.pid"; + }; }; diff --git a/nixos/modules/services/ttys/kmscon.nix b/nixos/modules/services/ttys/kmscon.nix index d274b508300f22..9706a384bffebd 100644 --- a/nixos/modules/services/ttys/kmscon.nix +++ b/nixos/modules/services/ttys/kmscon.nix @@ -1,13 +1,30 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let - inherit (lib) mapAttrs mkIf mkOption optional optionals types; + inherit (lib) + mapAttrs + mkIf + mkOption + optional + optionals + types + ; cfg = config.services.kmscon; autologinArg = lib.optionalString (cfg.autologinUser != null) "-f ${cfg.autologinUser}"; - configDir = pkgs.writeTextFile { name = "kmscon-config"; destination = "/kmscon.conf"; text = cfg.extraConfig; }; -in { + configDir = pkgs.writeTextFile { + name = "kmscon-config"; + destination = "/kmscon.conf"; + text = cfg.extraConfig; + }; +in +{ options = { services.kmscon = { enable = mkOption { @@ -32,13 +49,23 @@ in { description = "Fonts used by kmscon, in order of priority."; default = null; example = lib.literalExpression ''[ { name = "Source Code Pro"; package = pkgs.source-code-pro; } ]''; - type = with types; - let fontType = submodule { - options = { - name = mkOption { type = str; description = "Font name, as used by fontconfig."; }; - package = mkOption { type = package; description = "Package providing the font."; }; + type = + with types; + let + fontType = submodule { + options = { + name = mkOption { + type = str; + description = "Font name, as used by fontconfig."; + }; + package = mkOption { + type = package; + description = "Package providing the font."; }; - }; in nullOr (nonEmptyListOf fontType); + }; + }; + in + nullOr (nonEmptyListOf fontType); }; useXkbConfig = mkOption { @@ -76,7 +103,10 @@ in { systemd.packages = [ pkgs.kmscon ]; systemd.services."kmsconvt@" = { - after = [ "systemd-logind.service" "systemd-vconsole-setup.service" ]; + after = [ + "systemd-logind.service" + "systemd-vconsole-setup.service" + ]; requires = [ "systemd-logind.service" ]; serviceConfig.ExecStart = [ @@ -97,15 +127,29 @@ in { services.kmscon.extraConfig = let - xkb = optionals cfg.useXkbConfig - (lib.mapAttrsToList (n: v: "xkb-${n}=${v}") ( - lib.filterAttrs - (n: v: builtins.elem n ["layout" "model" "options" "variant"] && v != "") - config.services.xserver.xkb - )); - render = optionals cfg.hwRender [ "drm" "hwaccel" ]; - fonts = optional (cfg.fonts != null) "font-name=${lib.concatMapStringsSep ", " (f: f.name) cfg.fonts}"; - in lib.concatLines (xkb ++ render ++ fonts); + xkb = optionals cfg.useXkbConfig ( + lib.mapAttrsToList (n: v: "xkb-${n}=${v}") ( + lib.filterAttrs ( + n: v: + builtins.elem n [ + "layout" + "model" + "options" + "variant" + ] + && v != "" + ) config.services.xserver.xkb + ) + ); + render = optionals cfg.hwRender [ + "drm" + "hwaccel" + ]; + fonts = + optional (cfg.fonts != null) + "font-name=${lib.concatMapStringsSep ", " (f: f.name) cfg.fonts}"; + in + lib.concatLines (xkb ++ render ++ fonts); hardware.graphics.enable = mkIf cfg.hwRender true; diff --git a/nixos/modules/services/video/epgstation/default.nix b/nixos/modules/services/video/epgstation/default.nix index 3bf7e5849251eb..99190297eb7586 100644 --- a/nixos/modules/services/video/epgstation/default.nix +++ b/nixos/modules/services/video/epgstation/default.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: let cfg = config.services.epgstation; @@ -48,23 +54,54 @@ let logConfig = yaml.generate "logConfig.yml" { appenders.stdout.type = "stdout"; categories = { - default = { appenders = [ "stdout" ]; level = "info"; }; - system = { appenders = [ "stdout" ]; level = "info"; }; - access = { appenders = [ "stdout" ]; level = "info"; }; - stream = { appenders = [ "stdout" ]; level = "info"; }; + default = { + appenders = [ "stdout" ]; + level = "info"; + }; + system = { + appenders = [ "stdout" ]; + level = "info"; + }; + access = { + appenders = [ "stdout" ]; + level = "info"; + }; + stream = { + appenders = [ "stdout" ]; + level = "info"; + }; }; }; # Deprecate top level options that are redundant. - deprecateTopLevelOption = config: + deprecateTopLevelOption = + config: lib.mkRenamedOptionModule - ([ "services" "epgstation" ] ++ config) - ([ "services" "epgstation" "settings" ] ++ config); - - removeOption = config: instruction: - lib.mkRemovedOptionModule - ([ "services" "epgstation" ] ++ config) - instruction; + ( + [ + "services" + "epgstation" + ] + ++ config + ) + ( + [ + "services" + "epgstation" + "settings" + ] + ++ config + ); + + removeOption = + config: instruction: + lib.mkRemovedOptionModule ( + [ + "services" + "epgstation" + ] + ++ config + ) instruction; in { meta.maintainers = with lib.maintainers; [ midchildan ]; @@ -73,8 +110,7 @@ in (deprecateTopLevelOption [ "port" ]) (deprecateTopLevelOption [ "socketioPort" ]) (deprecateTopLevelOption [ "clientSocketioPort" ]) - (removeOption [ "basicAuth" ] - "Use a TLS-terminated reverse proxy with authentication instead.") + (removeOption [ "basicAuth" ] "Use a TLS-terminated reverse proxy with authentication instead.") ]; options.services.epgstation = { @@ -187,15 +223,17 @@ in ''; }; - options.mirakurunPath = with mirakurun; lib.mkOption { - type = lib.types.str; - default = "http+unix://${lib.replaceStrings ["/"] ["%2F"] sock}"; - defaultText = lib.literalExpression '' - "http+unix://''${lib.replaceStrings ["/"] ["%2F"] config.${option}}" - ''; - example = "http://localhost:40772"; - description = "URL to connect to Mirakurun."; - }; + options.mirakurunPath = + with mirakurun; + lib.mkOption { + type = lib.types.str; + default = "http+unix://${lib.replaceStrings [ "/" ] [ "%2F" ] sock}"; + defaultText = lib.literalExpression '' + "http+unix://''${lib.replaceStrings ["/"] ["%2F"] config.${option}}" + ''; + example = "http://localhost:40772"; + description = "URL to connect to Mirakurun."; + }; options.encodeProcessNum = lib.mkOption { type = lib.types.ints.positive; @@ -257,7 +295,10 @@ in }; networking.firewall = lib.mkIf cfg.openFirewall { - allowedTCPPorts = with cfg.settings; [ port socketioPort ]; + allowedTCPPorts = with cfg.settings; [ + port + socketioPort + ]; }; users.users.epgstation = { @@ -309,14 +350,17 @@ in (lib.mkIf cfg.usePreconfiguredStreaming streamingConfig) ]; - systemd.tmpfiles.settings."10-epgstation" = - lib.listToAttrs - (map (dir: lib.nameValuePair dir { - d = { - user = username; - group = groupname; - }; - }) + systemd.tmpfiles.settings."10-epgstation" = lib.listToAttrs ( + map + ( + dir: + lib.nameValuePair dir { + d = { + user = username; + group = groupname; + }; + } + ) [ "/var/lib/epgstation/key" "/var/lib/epgstation/streamfiles" @@ -327,13 +371,15 @@ in "/var/lib/epgstation/db/migrations/mysql" "/var/lib/epgstation/db/migrations/postgres" "/var/lib/epgstation/db/migrations/sqlite" - ]); + ] + ); systemd.services.epgstation = { inherit description; wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ] + after = + [ "network.target" ] ++ lib.optional config.services.mirakurun.enable "mirakurun.service" ++ lib.optional config.services.mysql.enable "mysql.service"; diff --git a/nixos/modules/services/video/go2rtc/default.nix b/nixos/modules/services/video/go2rtc/default.nix index f74c172907febb..5f90943fdc2b8d 100644 --- a/nixos/modules/services/video/go2rtc/default.nix +++ b/nixos/modules/services/video/go2rtc/default.nix @@ -1,8 +1,9 @@ -{ lib -, config -, options -, pkgs -, ... +{ + lib, + config, + options, + pkgs, + ... }: let @@ -17,7 +18,7 @@ let cfg = config.services.go2rtc; opt = options.services.go2rtc; - format = pkgs.formats.yaml {}; + format = pkgs.formats.yaml { }; configFile = format.generate "go2rtc.yaml" cfg.settings; in @@ -30,7 +31,7 @@ in package = mkPackageOption pkgs "go2rtc" { }; settings = mkOption { - default = {}; + default = { }; description = '' go2rtc configuration as a Nix attribute set. @@ -69,7 +70,7 @@ in streams = mkOption { type = attrsOf (either str (listOf str)); - default = {}; + default = { }; example = literalExpression '' { cam1 = "onvif://admin:password@192.168.1.123:2020"; diff --git a/nixos/modules/services/video/mediamtx.nix b/nixos/modules/services/video/mediamtx.nix index 5d8d76be69a3a4..054e30b75e5a2b 100644 --- a/nixos/modules/services/video/mediamtx.nix +++ b/nixos/modules/services/video/mediamtx.nix @@ -1,8 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.mediamtx; - format = pkgs.formats.yaml {}; + format = pkgs.formats.yaml { }; in { meta.maintainers = with lib.maintainers; [ fpletz ]; @@ -19,7 +24,7 @@ in . ''; type = format.type; - default = {}; + default = { }; example = { paths = { cam = { @@ -33,7 +38,7 @@ in env = lib.mkOption { type = with lib.types; attrsOf anything; description = "Extra environment variables for MediaMTX"; - default = {}; + default = { }; example = { MTX_CONFKEY = "mykey"; }; diff --git a/nixos/modules/services/video/mirakurun.nix b/nixos/modules/services/video/mirakurun.nix index bdd30805dbe83a..b1446422b9886b 100644 --- a/nixos/modules/services/video/mirakurun.nix +++ b/nixos/modules/services/video/mirakurun.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -7,7 +12,7 @@ let mirakurun = pkgs.mirakurun; username = config.users.users.mirakurun.name; groupname = config.users.users.mirakurun.group; - settingsFmt = pkgs.formats.yaml {}; + settingsFmt = pkgs.formats.yaml { }; polkitRule = pkgs.writeTextDir "share/polkit-1/rules.d/10-mirakurun.rules" '' polkit.addRule(function (action, subject) { @@ -21,188 +26,192 @@ let }); ''; in - { - options = { - services.mirakurun = { - enable = mkEnableOption "the Mirakurun DVR Tuner Server"; - - port = mkOption { - type = with types; nullOr port; - default = 40772; - description = '' - Port to listen on. If `null`, it won't listen on - any port. - ''; - }; - - openFirewall = mkOption { - type = types.bool; - default = false; - description = '' - Open ports in the firewall for Mirakurun. - - ::: {.warning} - Exposing Mirakurun to the open internet is generally advised - against. Only use it inside a trusted local network, or - consider putting it behind a VPN if you want remote access. - ::: - ''; - }; - - unixSocket = mkOption { - type = with types; nullOr path; - default = "/var/run/mirakurun/mirakurun.sock"; - description = '' - Path to unix socket to listen on. If `null`, it - won't listen on any unix sockets. - ''; - }; - - allowSmartCardAccess = mkOption { - type = types.bool; - default = true; - description = '' - Install polkit rules to allow Mirakurun to access smart card readers - which is commonly used along with tuner devices. - ''; - }; - - serverSettings = mkOption { - type = settingsFmt.type; - default = {}; - example = literalExpression '' - { - highWaterMark = 25165824; - overflowTimeLimit = 30000; - }; - ''; - description = '' - Options for server.yml. - - Documentation: - - ''; - }; - - tunerSettings = mkOption { - type = with types; nullOr settingsFmt.type; - default = null; - example = literalExpression '' - [ - { - name = "tuner-name"; - types = [ "GR" "BS" "CS" "SKY" ]; - dvbDevicePath = "/dev/dvb/adapterX/dvrX"; - } - ]; - ''; - description = '' - Options which are added to tuners.yml. If none is specified, it will - automatically be generated at runtime. - - Documentation: - - ''; - }; - - channelSettings = mkOption { - type = with types; nullOr settingsFmt.type; - default = null; - example = literalExpression '' - [ - { - name = "channel"; - types = "GR"; - channel = "0"; - } - ]; - ''; - description = '' - Options which are added to channels.yml. If none is specified, it - will automatically be generated at runtime. - - Documentation: - - ''; - }; +{ + options = { + services.mirakurun = { + enable = mkEnableOption "the Mirakurun DVR Tuner Server"; + + port = mkOption { + type = with types; nullOr port; + default = 40772; + description = '' + Port to listen on. If `null`, it won't listen on + any port. + ''; }; - }; - config = mkIf cfg.enable { - environment.systemPackages = [ mirakurun ] ++ optional cfg.allowSmartCardAccess polkitRule; - environment.etc = { - "mirakurun/server.yml".source = settingsFmt.generate "server.yml" cfg.serverSettings; - "mirakurun/tuners.yml" = mkIf (cfg.tunerSettings != null) { - source = settingsFmt.generate "tuners.yml" cfg.tunerSettings; - mode = "0644"; - user = username; - group = groupname; - }; - "mirakurun/channels.yml" = mkIf (cfg.channelSettings != null) { - source = settingsFmt.generate "channels.yml" cfg.channelSettings; - mode = "0644"; - user = username; - group = groupname; - }; + openFirewall = mkOption { + type = types.bool; + default = false; + description = '' + Open ports in the firewall for Mirakurun. + + ::: {.warning} + Exposing Mirakurun to the open internet is generally advised + against. Only use it inside a trusted local network, or + consider putting it behind a VPN if you want remote access. + ::: + ''; }; - networking.firewall = mkIf cfg.openFirewall { - allowedTCPPorts = mkIf (cfg.port != null) [ cfg.port ]; + unixSocket = mkOption { + type = with types; nullOr path; + default = "/var/run/mirakurun/mirakurun.sock"; + description = '' + Path to unix socket to listen on. If `null`, it + won't listen on any unix sockets. + ''; }; - users.users.mirakurun = { - description = "Mirakurun user"; - group = "video"; - isSystemUser = true; + allowSmartCardAccess = mkOption { + type = types.bool; + default = true; + description = '' + Install polkit rules to allow Mirakurun to access smart card readers + which is commonly used along with tuner devices. + ''; + }; - # NPM insists on creating ~/.npm - home = "/var/cache/mirakurun"; + serverSettings = mkOption { + type = settingsFmt.type; + default = { }; + example = literalExpression '' + { + highWaterMark = 25165824; + overflowTimeLimit = 30000; + }; + ''; + description = '' + Options for server.yml. + + Documentation: + + ''; }; - services.mirakurun.serverSettings = { - logLevel = mkDefault 2; - path = mkIf (cfg.unixSocket != null) cfg.unixSocket; - port = mkIf (cfg.port != null) cfg.port; + tunerSettings = mkOption { + type = with types; nullOr settingsFmt.type; + default = null; + example = literalExpression '' + [ + { + name = "tuner-name"; + types = [ "GR" "BS" "CS" "SKY" ]; + dvbDevicePath = "/dev/dvb/adapterX/dvrX"; + } + ]; + ''; + description = '' + Options which are added to tuners.yml. If none is specified, it will + automatically be generated at runtime. + + Documentation: + + ''; }; - systemd.tmpfiles.settings."10-mirakurun"."/etc/mirakurun".d = { + channelSettings = mkOption { + type = with types; nullOr settingsFmt.type; + default = null; + example = literalExpression '' + [ + { + name = "channel"; + types = "GR"; + channel = "0"; + } + ]; + ''; + description = '' + Options which are added to channels.yml. If none is specified, it + will automatically be generated at runtime. + + Documentation: + + ''; + }; + }; + }; + + config = mkIf cfg.enable { + environment.systemPackages = [ mirakurun ] ++ optional cfg.allowSmartCardAccess polkitRule; + environment.etc = { + "mirakurun/server.yml".source = settingsFmt.generate "server.yml" cfg.serverSettings; + "mirakurun/tuners.yml" = mkIf (cfg.tunerSettings != null) { + source = settingsFmt.generate "tuners.yml" cfg.tunerSettings; + mode = "0644"; user = username; group = groupname; }; + "mirakurun/channels.yml" = mkIf (cfg.channelSettings != null) { + source = settingsFmt.generate "channels.yml" cfg.channelSettings; + mode = "0644"; + user = username; + group = groupname; + }; + }; + + networking.firewall = mkIf cfg.openFirewall { + allowedTCPPorts = mkIf (cfg.port != null) [ cfg.port ]; + }; + + users.users.mirakurun = { + description = "Mirakurun user"; + group = "video"; + isSystemUser = true; + + # NPM insists on creating ~/.npm + home = "/var/cache/mirakurun"; + }; + + services.mirakurun.serverSettings = { + logLevel = mkDefault 2; + path = mkIf (cfg.unixSocket != null) cfg.unixSocket; + port = mkIf (cfg.port != null) cfg.port; + }; + + systemd.tmpfiles.settings."10-mirakurun"."/etc/mirakurun".d = { + user = username; + group = groupname; + }; + + systemd.services.mirakurun = { + description = mirakurun.meta.description; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + serviceConfig = { + ExecStart = "${mirakurun}/bin/mirakurun start"; + User = username; + Group = groupname; + CacheDirectory = "mirakurun"; + RuntimeDirectory = "mirakurun"; + StateDirectory = "mirakurun"; + Nice = -10; + IOSchedulingClass = "realtime"; + IOSchedulingPriority = 7; + }; - systemd.services.mirakurun = { - description = mirakurun.meta.description; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - serviceConfig = { - ExecStart = "${mirakurun}/bin/mirakurun start"; - User = username; - Group = groupname; - CacheDirectory = "mirakurun"; - RuntimeDirectory="mirakurun"; - StateDirectory="mirakurun"; - Nice = -10; - IOSchedulingClass = "realtime"; - IOSchedulingPriority = 7; - }; - - environment = { - SERVER_CONFIG_PATH = "/etc/mirakurun/server.yml"; - TUNERS_CONFIG_PATH = "/etc/mirakurun/tuners.yml"; - CHANNELS_CONFIG_PATH = "/etc/mirakurun/channels.yml"; - SERVICES_DB_PATH = "/var/lib/mirakurun/services.json"; - PROGRAMS_DB_PATH = "/var/lib/mirakurun/programs.json"; - LOGO_DATA_DIR_PATH = "/var/lib/mirakurun/logos"; - NODE_ENV = "production"; - }; - - restartTriggers = let + environment = { + SERVER_CONFIG_PATH = "/etc/mirakurun/server.yml"; + TUNERS_CONFIG_PATH = "/etc/mirakurun/tuners.yml"; + CHANNELS_CONFIG_PATH = "/etc/mirakurun/channels.yml"; + SERVICES_DB_PATH = "/var/lib/mirakurun/services.json"; + PROGRAMS_DB_PATH = "/var/lib/mirakurun/programs.json"; + LOGO_DATA_DIR_PATH = "/var/lib/mirakurun/logos"; + NODE_ENV = "production"; + }; + + restartTriggers = + let getconf = target: config.environment.etc."mirakurun/${target}.yml".source; - targets = [ - "server" - ] ++ optional (cfg.tunerSettings != null) "tuners" + targets = + [ + "server" + ] + ++ optional (cfg.tunerSettings != null) "tuners" ++ optional (cfg.channelSettings != null) "channels"; - in (map getconf targets); - }; + in + (map getconf targets); }; - } + }; +} diff --git a/nixos/modules/services/video/photonvision.nix b/nixos/modules/services/video/photonvision.nix index e2b27b3cc41049..70e527e2a51b4f 100644 --- a/nixos/modules/services/video/photonvision.nix +++ b/nixos/modules/services/video/photonvision.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.photonvision; @@ -8,7 +13,7 @@ in services.photonvision = { enable = lib.mkEnableOption "PhotonVision"; - package = lib.mkPackageOption pkgs "photonvision" {}; + package = lib.mkPackageOption pkgs "photonvision" { }; openFirewall = lib.mkOption { description = '' @@ -58,7 +63,12 @@ in networking.firewall = lib.mkIf cfg.openFirewall { allowedTCPPorts = [ 5800 ]; - allowedTCPPortRanges = [{ from = 1180; to = 1190; }]; + allowedTCPPortRanges = [ + { + from = 1180; + to = 1190; + } + ]; }; }; } diff --git a/nixos/modules/services/video/v4l2-relayd.nix b/nixos/modules/services/video/v4l2-relayd.nix index 7d1d712fa4a3de..0b2c94ad9eeaf5 100644 --- a/nixos/modules/services/video/v4l2-relayd.nix +++ b/nixos/modules/services/video/v4l2-relayd.nix @@ -1,101 +1,125 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let - inherit (lib) attrValues concatStringsSep filterAttrs length listToAttrs literalExpression - makeSearchPathOutput mkEnableOption mkIf mkOption nameValuePair optionals types; + inherit (lib) + attrValues + concatStringsSep + filterAttrs + length + listToAttrs + literalExpression + makeSearchPathOutput + mkEnableOption + mkIf + mkOption + nameValuePair + optionals + types + ; inherit (utils) escapeSystemdPath; cfg = config.services.v4l2-relayd; kernelPackages = config.boot.kernelPackages; - gst = (with pkgs.gst_all_1; [ - gst-plugins-bad - gst-plugins-base - gst-plugins-good - gstreamer.out - ]); - - instanceOpts = { name, ... }: { - options = { - enable = mkEnableOption "this v4l2-relayd instance"; - - name = mkOption { - type = types.str; - default = name; - description = '' - The name of the instance. - ''; - }; - - cardLabel = mkOption { - type = types.str; - description = '' - The name the camera will show up as. - ''; - }; - - extraPackages = mkOption { - type = with types; listOf package; - default = [ ]; - description = '' - Extra packages to add to {env}`GST_PLUGIN_PATH` for the instance. - ''; - }; + gst = ( + with pkgs.gst_all_1; + [ + gst-plugins-bad + gst-plugins-base + gst-plugins-good + gstreamer.out + ] + ); + + instanceOpts = + { name, ... }: + { + options = { + enable = mkEnableOption "this v4l2-relayd instance"; - input = { - pipeline = mkOption { + name = mkOption { type = types.str; + default = name; description = '' - The gstreamer-pipeline to use for the input-stream. + The name of the instance. ''; }; - format = mkOption { + cardLabel = mkOption { type = types.str; - default = "YUY2"; description = '' - The video-format to read from input-stream. + The name the camera will show up as. ''; }; - width = mkOption { - type = types.ints.positive; - default = 1280; + extraPackages = mkOption { + type = with types; listOf package; + default = [ ]; description = '' - The width to read from input-stream. + Extra packages to add to {env}`GST_PLUGIN_PATH` for the instance. ''; }; - height = mkOption { - type = types.ints.positive; - default = 720; - description = '' - The height to read from input-stream. - ''; - }; + input = { + pipeline = mkOption { + type = types.str; + description = '' + The gstreamer-pipeline to use for the input-stream. + ''; + }; - framerate = mkOption { - type = types.ints.positive; - default = 30; - description = '' - The framerate to read from input-stream. - ''; + format = mkOption { + type = types.str; + default = "YUY2"; + description = '' + The video-format to read from input-stream. + ''; + }; + + width = mkOption { + type = types.ints.positive; + default = 1280; + description = '' + The width to read from input-stream. + ''; + }; + + height = mkOption { + type = types.ints.positive; + default = 720; + description = '' + The height to read from input-stream. + ''; + }; + + framerate = mkOption { + type = types.ints.positive; + default = 30; + description = '' + The framerate to read from input-stream. + ''; + }; }; - }; - output = { - format = mkOption { - type = types.str; - default = "YUY2"; - description = '' - The video-format to write to output-stream. - ''; + output = { + format = mkOption { + type = types.str; + default = "YUY2"; + description = '' + The video-format to write to output-stream. + ''; + }; }; - }; + }; }; - }; in { @@ -126,7 +150,10 @@ in mkInstanceService = instance: { description = "Streaming relay for v4l2loopback using GStreamer"; - after = [ "modprobe@v4l2loopback.service" "systemd-logind.service" ]; + after = [ + "modprobe@v4l2loopback.service" + "systemd-logind.service" + ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { @@ -152,13 +179,16 @@ in "framerate=${toString instance.input.framerate}/1" ]; - outputPipeline = [ - "appsrc name=appsrc ${appsrcOptions}" - "videoconvert" - ] ++ optionals (instance.input.format != instance.output.format) [ - "video/x-raw,format=${instance.output.format}" - "queue" - ] ++ [ "v4l2sink name=v4l2sink device=$(cat $V4L2_DEVICE_FILE)" ]; + outputPipeline = + [ + "appsrc name=appsrc ${appsrcOptions}" + "videoconvert" + ] + ++ optionals (instance.input.format != instance.output.format) [ + "video/x-raw,format=${instance.output.format}" + "queue" + ] + ++ [ "v4l2sink name=v4l2sink device=$(cat $V4L2_DEVICE_FILE)" ]; in '' exec ${pkgs.v4l2-relayd}/bin/v4l2-relayd -i "${instance.input.pipeline}" -o "${concatStringsSep " ! " outputPipeline}" @@ -175,11 +205,14 @@ in ''; }; - mkInstanceServices = instances: listToAttrs (map - (instance: - nameValuePair "v4l2-relayd-${escapeSystemdPath instance.name}" (mkInstanceService instance) - ) - instances); + mkInstanceServices = + instances: + listToAttrs ( + map ( + instance: + nameValuePair "v4l2-relayd-${escapeSystemdPath instance.name}" (mkInstanceService instance) + ) instances + ); enabledInstances = attrValues (filterAttrs (n: v: v.enable) cfg.instances); diff --git a/nixos/modules/services/wayland/cage.nix b/nixos/modules/services/wayland/cage.nix index c96bc5adf1cf08..954cfd8faaa803 100644 --- a/nixos/modules/services/wayland/cage.nix +++ b/nixos/modules/services/wayland/cage.nix @@ -1,10 +1,16 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; let cfg = config.services.cage; -in { +in +{ options.services.cage.enable = mkEnableOption "cage kiosk service"; options.services.cage.user = mkOption { @@ -17,15 +23,15 @@ in { options.services.cage.extraArguments = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; defaultText = literalExpression "[]"; description = "Additional command line arguments to pass to Cage."; - example = ["-d"]; + example = [ "-d" ]; }; options.services.cage.environment = mkOption { type = types.attrsOf types.str; - default = {}; + default = { }; example = { WLR_LIBINPUT_NO_DEVICES = "1"; }; @@ -58,7 +64,11 @@ in { "getty@tty1.service" ]; before = [ "graphical.target" ]; - wants = [ "dbus.socket" "systemd-logind.service" "plymouth-quit.service"]; + wants = [ + "dbus.socket" + "systemd-logind.service" + "plymouth-quit.service" + ]; wantedBy = [ "graphical.target" ]; conflicts = [ "getty@tty1.service" ]; diff --git a/nixos/modules/services/web-apps/alps.nix b/nixos/modules/services/web-apps/alps.nix index e72b85eb356907..0a0925856e7113 100644 --- a/nixos/modules/services/web-apps/alps.nix +++ b/nixos/modules/services/web-apps/alps.nix @@ -1,10 +1,16 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: with lib; let cfg = config.services.alps; -in { +in +{ options.services.alps = { enable = mkEnableOption "alps"; @@ -25,7 +31,10 @@ in { }; theme = mkOption { - type = types.enum [ "alps" "sourcehut" ]; + type = types.enum [ + "alps" + "sourcehut" + ]; default = "sourcehut"; description = '' The frontend's theme to use. @@ -81,8 +90,10 @@ in { internal = true; type = types.listOf types.str; default = [ - "-addr" "${cfg.bindIP}:${toString cfg.port}" - "-theme" "${cfg.theme}" + "-addr" + "${cfg.bindIP}:${toString cfg.port}" + "-theme" + "${cfg.theme}" "imaps://${cfg.imaps.host}:${toString cfg.imaps.port}" "smtps://${cfg.smtps.host}:${toString cfg.smtps.port}" ]; @@ -95,7 +106,10 @@ in { documentation = [ "https://git.sr.ht/~migadu/alps" ]; wantedBy = [ "multi-user.target" ]; wants = [ "network-online.target" ]; - after = [ "network.target" "network-online.target" ]; + after = [ + "network.target" + "network-online.target" + ]; serviceConfig = { ExecStart = "${cfg.package}/bin/alps ${escapeShellArgs cfg.args}"; @@ -119,14 +133,20 @@ in { ProtectProc = "invisible"; ProtectSystem = "strict"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SocketBindAllow = cfg.port; SocketBindDeny = "any"; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged @obsolete" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged @obsolete" + ]; }; }; }; diff --git a/nixos/modules/services/web-apps/audiobookshelf.nix b/nixos/modules/services/web-apps/audiobookshelf.nix index 2f00c852ac8fe0..d72bdd95ad6050 100644 --- a/nixos/modules/services/web-apps/audiobookshelf.nix +++ b/nixos/modules/services/web-apps/audiobookshelf.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/web-apps/bluemap.nix b/nixos/modules/services/web-apps/bluemap.nix index 0b45501980e6ca..b04f7a64e75a73 100644 --- a/nixos/modules/services/web-apps/bluemap.nix +++ b/nixos/modules/services/web-apps/bluemap.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.bluemap; format = pkgs.formats.hocon { }; @@ -7,20 +12,21 @@ let webappConfig = format.generate "webapp.conf" cfg.webappSettings; webserverConfig = format.generate "webserver.conf" cfg.webserverSettings; - mapsFolder = pkgs.linkFarm "maps" - (lib.attrsets.mapAttrs' (name: value: - lib.nameValuePair "${name}.conf" - (format.generate "${name}.conf" value)) - cfg.maps); + mapsFolder = pkgs.linkFarm "maps" ( + lib.attrsets.mapAttrs' ( + name: value: lib.nameValuePair "${name}.conf" (format.generate "${name}.conf" value) + ) cfg.maps + ); - addonsFolder = pkgs.linkFarm "addons" - (lib.attrsets.mapAttrs' (name: value: lib.nameValuePair "${name}.jar" value) cfg.addons); + addonsFolder = pkgs.linkFarm "addons" ( + lib.attrsets.mapAttrs' (name: value: lib.nameValuePair "${name}.jar" value) cfg.addons + ); - storageFolder = pkgs.linkFarm "storage" - (lib.attrsets.mapAttrs' (name: value: - lib.nameValuePair "${name}.conf" - (format.generate "${name}.conf" value)) - cfg.storage); + storageFolder = pkgs.linkFarm "storage" ( + lib.attrsets.mapAttrs' ( + name: value: lib.nameValuePair "${name}.conf" (format.generate "${name}.conf" value) + ) cfg.storage + ); configFolder = pkgs.linkFarm "bluemap-config" { "maps" = mapsFolder; @@ -33,9 +39,13 @@ let }; inherit (lib) mkOption; -in { +in +{ imports = [ - (lib.mkRenamedOptionModule [ "services" "bluemap" "resourcepacks" ] [ "services" "bluemap" "packs" ]) + (lib.mkRenamedOptionModule + [ "services" "bluemap" "resourcepacks" ] + [ "services" "bluemap" "packs" ] + ) ]; options.services.bluemap = { @@ -146,15 +156,17 @@ in { }; maps = mkOption { - type = lib.types.attrsOf (lib.types.submodule { - freeformType = format.type; - options = { - world = lib.mkOption { - type = lib.types.path; - description = "Path to world folder containing the dimension to render"; + type = lib.types.attrsOf ( + lib.types.submodule { + freeformType = format.type; + options = { + world = lib.mkOption { + type = lib.types.path; + description = "Path to world folder containing the dimension to render"; + }; }; - }; - }); + } + ); default = { "overworld" = { world = "${cfg.defaultWorld}"; @@ -248,16 +260,21 @@ in { }; storage = mkOption { - type = lib.types.attrsOf (lib.types.submodule { - freeformType = format.type; - options = { - storage-type = mkOption { - type = lib.types.enum [ "FILE" "SQL" ]; - description = "Type of storage config"; - default = "FILE"; + type = lib.types.attrsOf ( + lib.types.submodule { + freeformType = format.type; + options = { + storage-type = mkOption { + type = lib.types.enum [ + "FILE" + "SQL" + ]; + description = "Type of storage config"; + default = "FILE"; + }; }; - }; - }); + } + ); description = '' Where the rendered map will be stored. Unless you are doing something advanced you should probably leave this alone and configure webRoot instead. @@ -287,16 +304,16 @@ in { }; }; - config = lib.mkIf cfg.enable { - assertions = - [ { assertion = config.services.bluemap.eula; - message = '' - You have enabled bluemap but have not accepted minecraft's EULA. - You can achieve this through setting `services.bluemap.eula = true` - ''; - } - ]; + assertions = [ + { + assertion = config.services.bluemap.eula; + message = '' + You have enabled bluemap but have not accepted minecraft's EULA. + You can achieve this through setting `services.bluemap.eula = true` + ''; + } + ]; services.bluemap.coreSettings.accept-download = cfg.eula; @@ -336,6 +353,9 @@ in { }; meta = { - maintainers = with lib.maintainers; [ dandellion h7x4 ]; + maintainers = with lib.maintainers; [ + dandellion + h7x4 + ]; }; } diff --git a/nixos/modules/services/web-apps/c2fmzq-server.nix b/nixos/modules/services/web-apps/c2fmzq-server.nix index dee131182de162..f1935e05407f2e 100644 --- a/nixos/modules/services/web-apps/c2fmzq-server.nix +++ b/nixos/modules/services/web-apps/c2fmzq-server.nix @@ -1,19 +1,38 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: let - inherit (lib) mkEnableOption mkPackageOption mkOption types; + inherit (lib) + mkEnableOption + mkPackageOption + mkOption + types + ; cfg = config.services.c2fmzq-server; argsFormat = { - type = with lib.types; attrsOf (nullOr (oneOf [ bool int str ])); + type = + with lib.types; + attrsOf ( + nullOr (oneOf [ + bool + int + str + ]) + ); generate = lib.cli.toGNUCommandLineShell { mkBool = k: v: [ "--${k}=${if v then "true" else "false"}" ]; }; }; -in { +in +{ options.services.c2fmzq-server = { enable = mkEnableOption "c2fmzq-server"; @@ -81,7 +100,10 @@ in { documentation = [ "https://github.com/c2FmZQ/c2FmZQ/blob/main/README.md" ]; wantedBy = [ "multi-user.target" ]; wants = [ "network-online.target" ]; - after = [ "network.target" "network-online.target" ]; + after = [ + "network.target" + "network-online.target" + ]; serviceConfig = { ExecStart = "${lib.getExe cfg.package} ${argsFormat.generate cfg.settings}"; @@ -110,7 +132,10 @@ in { ProtectProc = "invisible"; ProtectSystem = "strict"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; @@ -118,7 +143,10 @@ in { SocketBindDeny = "any"; StateDirectory = "c2fmzq-server"; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged @obsolete" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged @obsolete" + ]; }; }; }; diff --git a/nixos/modules/services/web-apps/castopod.nix b/nixos/modules/services/web-apps/castopod.nix index e60a9b3b1fb792..fae20df530ef6d 100644 --- a/nixos/modules/services/web-apps/castopod.nix +++ b/nixos/modules/services/web-apps/castopod.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.castopod; fpm = config.services.phpfpm.pools.castopod; @@ -6,14 +11,19 @@ let user = "castopod"; # https://docs.castopod.org/getting-started/install.html#requirements - phpPackage = pkgs.php82.withExtensions ({ enabled, all }: with all; [ - intl - curl - mbstring - gd - exif - mysqlnd - ] ++ enabled); + phpPackage = pkgs.php82.withExtensions ( + { enabled, all }: + with all; + [ + intl + curl + mbstring + gd + exif + mysqlnd + ] + ++ enabled + ); in { meta.doc = ./castopod.md; @@ -73,7 +83,13 @@ in }; }; settings = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ str int bool ]); + type = + with lib.types; + attrsOf (oneOf [ + str + int + bool + ]); default = { }; example = { "email.protocol" = "smtp"; @@ -110,7 +126,13 @@ in description = "The domain serving your CastoPod instance."; }; poolSettings = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ str int bool ]); + type = + with lib.types; + attrsOf (oneOf [ + str + int + bool + ]); default = { "pm" = "dynamic"; "pm.max_children" = "32"; @@ -142,7 +164,9 @@ in config = lib.mkIf cfg.enable { services.castopod.settings = let - sslEnabled = with config.services.nginx.virtualHosts.${cfg.localDomain}; addSSL || forceSSL || onlySSL || enableACME || useACMEHost != null; + sslEnabled = + with config.services.nginx.virtualHosts.${cfg.localDomain}; + addSSL || forceSSL || onlySSL || enableACME || useACMEHost != null; baseURL = "http${lib.optionalString sslEnabled "s"}://${cfg.localDomain}"; in lib.mapAttrs (_: lib.mkDefault) { @@ -187,7 +211,10 @@ in after = lib.optional config.services.mysql.enable "mysql.service"; requires = lib.optional config.services.mysql.enable "mysql.service"; wantedBy = [ "multi-user.target" ]; - path = [ pkgs.openssl phpPackage ]; + path = [ + pkgs.openssl + phpPackage + ]; script = let envFile = "${cfg.dataDir}/.env"; @@ -210,11 +237,16 @@ in echo "analytics.salt=$(cat ${cfg.dataDir}/salt)" >> ${envFile} - ${if (cfg.database.passwordFile != null) then '' - echo "database.default.password=$(cat "$CREDENTIALS_DIRECTORY/dbpasswordfile)" >> ${envFile} - '' else '' - echo "database.default.password=" >> ${envFile} - ''} + ${ + if (cfg.database.passwordFile != null) then + '' + echo "database.default.password=$(cat "$CREDENTIALS_DIRECTORY/dbpasswordfile)" >> ${envFile} + '' + else + '' + echo "database.default.password=" >> ${envFile} + '' + } ${lib.optionalString (cfg.environmentFile != null) '' cat "$CREDENTIALS_DIRECTORY/envfile" >> ${envFile} @@ -224,10 +256,9 @@ in ''; serviceConfig = { StateDirectory = "castopod"; - LoadCredential = lib.optional (cfg.environmentFile != null) - "envfile:${cfg.environmentFile}" - ++ (lib.optional (cfg.database.passwordFile != null) - "dbpasswordfile:${cfg.database.passwordFile}"); + LoadCredential = + lib.optional (cfg.environmentFile != null) "envfile:${cfg.environmentFile}" + ++ (lib.optional (cfg.database.passwordFile != null) "dbpasswordfile:${cfg.database.passwordFile}"); WorkingDirectory = "${cfg.package}/share/castopod"; Type = "oneshot"; RemainAfterExit = true; @@ -267,10 +298,14 @@ in enable = true; package = lib.mkDefault pkgs.mariadb; ensureDatabases = [ cfg.database.name ]; - ensureUsers = [{ - name = cfg.database.user; - ensurePermissions = { "${cfg.database.name}.*" = "ALL PRIVILEGES"; }; - }]; + ensureUsers = [ + { + name = cfg.database.user; + ensurePermissions = { + "${cfg.database.name}.*" = "ALL PRIVILEGES"; + }; + } + ]; }; services.nginx = lib.mkIf cfg.configureNginx { diff --git a/nixos/modules/services/web-apps/changedetection-io.nix b/nixos/modules/services/web-apps/changedetection-io.nix index 32448486cc9565..c4866839a97f0f 100644 --- a/nixos/modules/services/web-apps/changedetection-io.nix +++ b/nixos/modules/services/web-apps/changedetection-io.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -123,37 +128,40 @@ in } ]; - systemd = let - defaultStateDir = cfg.datastorePath == "/var/lib/changedetection-io"; - in { - services.changedetection-io = { - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; - serviceConfig = { - User = cfg.user; - Group = cfg.group; - StateDirectory = mkIf defaultStateDir "changedetection-io"; - StateDirectoryMode = mkIf defaultStateDir "0750"; - WorkingDirectory = cfg.datastorePath; - Environment = [ "HIDE_REFERER=true" ] - ++ lib.optional (cfg.baseURL != null) "BASE_URL=${cfg.baseURL}" - ++ lib.optional cfg.behindProxy "USE_X_SETTINGS=1" - ++ lib.optional cfg.webDriverSupport "WEBDRIVER_URL=http://127.0.0.1:${toString cfg.chromePort}/wd/hub" - ++ lib.optional cfg.playwrightSupport "PLAYWRIGHT_DRIVER_URL=ws://127.0.0.1:${toString cfg.chromePort}/?stealth=1&--disable-web-security=true"; - EnvironmentFile = mkIf (cfg.environmentFile != null) cfg.environmentFile; - ExecStart = '' - ${pkgs.changedetection-io}/bin/changedetection.py \ - -h ${cfg.listenAddress} -p ${toString cfg.port} -d ${cfg.datastorePath} - ''; - ProtectHome = true; - ProtectSystem = true; - Restart = "on-failure"; + systemd = + let + defaultStateDir = cfg.datastorePath == "/var/lib/changedetection-io"; + in + { + services.changedetection-io = { + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + serviceConfig = { + User = cfg.user; + Group = cfg.group; + StateDirectory = mkIf defaultStateDir "changedetection-io"; + StateDirectoryMode = mkIf defaultStateDir "0750"; + WorkingDirectory = cfg.datastorePath; + Environment = + [ "HIDE_REFERER=true" ] + ++ lib.optional (cfg.baseURL != null) "BASE_URL=${cfg.baseURL}" + ++ lib.optional cfg.behindProxy "USE_X_SETTINGS=1" + ++ lib.optional cfg.webDriverSupport "WEBDRIVER_URL=http://127.0.0.1:${toString cfg.chromePort}/wd/hub" + ++ lib.optional cfg.playwrightSupport "PLAYWRIGHT_DRIVER_URL=ws://127.0.0.1:${toString cfg.chromePort}/?stealth=1&--disable-web-security=true"; + EnvironmentFile = mkIf (cfg.environmentFile != null) cfg.environmentFile; + ExecStart = '' + ${pkgs.changedetection-io}/bin/changedetection.py \ + -h ${cfg.listenAddress} -p ${toString cfg.port} -d ${cfg.datastorePath} + ''; + ProtectHome = true; + ProtectSystem = true; + Restart = "on-failure"; + }; }; + tmpfiles.rules = mkIf (!defaultStateDir) [ + "d ${cfg.datastorePath} 0750 ${cfg.user} ${cfg.group} - -" + ]; }; - tmpfiles.rules = mkIf (!defaultStateDir) [ - "d ${cfg.datastorePath} 0750 ${cfg.user} ${cfg.group} - -" - ]; - }; users = { users = optionalAttrs (cfg.user == "changedetection-io") { diff --git a/nixos/modules/services/web-apps/chatgpt-retrieval-plugin.nix b/nixos/modules/services/web-apps/chatgpt-retrieval-plugin.nix index c1ab7ec40949c8..dba076436df7b0 100644 --- a/nixos/modules/services/web-apps/chatgpt-retrieval-plugin.nix +++ b/nixos/modules/services/web-apps/chatgpt-retrieval-plugin.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -41,7 +46,14 @@ in }; datastore = mkOption { - type = types.enum [ "pinecone" "weaviate" "zilliz" "milvus" "qdrant" "redis" ]; + type = types.enum [ + "pinecone" + "weaviate" + "zilliz" + "milvus" + "qdrant" + "redis" + ]; default = "qdrant"; description = "This specifies the vector database provider you want to use to store and query embeddings."; }; diff --git a/nixos/modules/services/web-apps/cloudlog.nix b/nixos/modules/services/web-apps/cloudlog.nix index 6550d112d53733..0c51a5118bbd08 100644 --- a/nixos/modules/services/web-apps/cloudlog.nix +++ b/nixos/modules/services/web-apps/cloudlog.nix @@ -1,40 +1,49 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; let cfg = config.services.cloudlog; - dbFile = let - password = if cfg.database.createLocally - then "''" - else "trim(file_get_contents('${cfg.database.passwordFile}'))"; - in pkgs.writeText "database.php" '' - "", - 'hostname' => '${cfg.database.host}', - 'username' => '${cfg.database.user}', - 'password' => ${password}, - 'database' => '${cfg.database.name}', - 'dbdriver' => 'mysqli', - 'dbprefix' => "", - 'pconnect' => TRUE, - 'db_debug' => (ENVIRONMENT !== 'production'), - 'cache_on' => FALSE, - 'cachedir' => "", - 'char_set' => 'utf8mb4', - 'dbcollat' => 'utf8mb4_general_ci', - 'swap_pre' => "", - 'encrypt' => FALSE, - 'compress' => FALSE, - 'stricton' => FALSE, - 'failover' => array(), - 'save_queries' => TRUE - ); - ''; + dbFile = + let + password = + if cfg.database.createLocally then + "''" + else + "trim(file_get_contents('${cfg.database.passwordFile}'))"; + in + pkgs.writeText "database.php" '' + "", + 'hostname' => '${cfg.database.host}', + 'username' => '${cfg.database.user}', + 'password' => ${password}, + 'database' => '${cfg.database.name}', + 'dbdriver' => 'mysqli', + 'dbprefix' => "", + 'pconnect' => TRUE, + 'db_debug' => (ENVIRONMENT !== 'production'), + 'cache_on' => FALSE, + 'cachedir' => "", + 'char_set' => 'utf8mb4', + 'dbcollat' => 'utf8mb4_general_ci', + 'swap_pre' => "", + 'encrypt' => FALSE, + 'compress' => FALSE, + 'stricton' => FALSE, + 'failover' => array(), + 'save_queries' => TRUE + ); + ''; configFile = pkgs.writeText "config.php" '' . + Any additional text to be appended to the config.php + configuration file. This is a PHP script. For configuration + settings, see . ''; default = ""; type = str; @@ -308,7 +321,7 @@ in pools.cloudlog = { inherit (cfg) user; group = config.services.nginx.group; - settings = { + settings = { "listen.owner" = config.services.nginx.user; "listen.group" = config.services.nginx.group; } // cfg.poolConfig; @@ -322,12 +335,12 @@ in root = "${package}"; locations."/".tryFiles = "$uri /index.php$is_args$args"; locations."~ ^/index.php(/|$)".extraConfig = '' - include ${config.services.nginx.package}/conf/fastcgi_params; - include ${pkgs.nginx}/conf/fastcgi.conf; - fastcgi_split_path_info ^(.+\.php)(.+)$; - fastcgi_pass unix:${config.services.phpfpm.pools.cloudlog.socket}; - fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; - ''; + include ${config.services.nginx.package}/conf/fastcgi_params; + include ${pkgs.nginx}/conf/fastcgi.conf; + fastcgi_split_path_info ^(.+\.php)(.+)$; + fastcgi_pass unix:${config.services.phpfpm.pools.cloudlog.socket}; + fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; + ''; }; }; }; @@ -335,12 +348,14 @@ in services.mysql = mkIf cfg.database.createLocally { enable = true; ensureDatabases = [ cfg.database.name ]; - ensureUsers = [{ - name = cfg.database.user; - ensurePermissions = { - "${cfg.database.name}.*" = "ALL PRIVILEGES"; - }; - }]; + ensureUsers = [ + { + name = cfg.database.user; + ensurePermissions = { + "${cfg.database.name}.*" = "ALL PRIVILEGES"; + }; + } + ]; }; systemd = { @@ -353,14 +368,16 @@ in }; wantedBy = [ "phpfpm-cloudlog.service" ]; after = [ "mysql.service" ]; - script = let - mysql = "${config.services.mysql.package}/bin/mysql"; - in '' - if [ ! -f ${cfg.dataDir}/.dbexists ]; then - ${mysql} ${cfg.database.name} < ${pkgs.cloudlog}/install/assets/install.sql - touch ${cfg.dataDir}/.dbexists - fi - ''; + script = + let + mysql = "${config.services.mysql.package}/bin/mysql"; + in + '' + if [ ! -f ${cfg.dataDir}/.dbexists ]; then + ${mysql} ${cfg.database.name} < ${pkgs.cloudlog}/install/assets/install.sql + touch ${cfg.dataDir}/.dbexists + fi + ''; }; cloudlog-upload-lotw = { description = "Upload QSOs to LoTW if certs have been provided"; @@ -449,7 +466,7 @@ in Persistent = true; }; }; - cloudlog-update-wwff = { + cloudlog-update-wwff = { enable = cfg.update-wwff.enable; wantedBy = [ "timers.target" ]; partOf = [ "cloudlog-update-wwff.service" ]; @@ -480,17 +497,19 @@ in }; }; }; - tmpfiles.rules = let - group = config.services.nginx.group; - in [ - "d ${cfg.dataDir} 0750 ${cfg.user} ${group} - -" - "d ${cfg.dataDir}/updates 0750 ${cfg.user} ${group} - -" - "d ${cfg.dataDir}/uploads 0750 ${cfg.user} ${group} - -" - "d ${cfg.dataDir}/backup 0750 ${cfg.user} ${group} - -" - "d ${cfg.dataDir}/logbook 0750 ${cfg.user} ${group} - -" - "d ${cfg.dataDir}/assets/json 0750 ${cfg.user} ${group} - -" - "d ${cfg.dataDir}/assets/qslcard 0750 ${cfg.user} ${group} - -" - ]; + tmpfiles.rules = + let + group = config.services.nginx.group; + in + [ + "d ${cfg.dataDir} 0750 ${cfg.user} ${group} - -" + "d ${cfg.dataDir}/updates 0750 ${cfg.user} ${group} - -" + "d ${cfg.dataDir}/uploads 0750 ${cfg.user} ${group} - -" + "d ${cfg.dataDir}/backup 0750 ${cfg.user} ${group} - -" + "d ${cfg.dataDir}/logbook 0750 ${cfg.user} ${group} - -" + "d ${cfg.dataDir}/assets/json 0750 ${cfg.user} ${group} - -" + "d ${cfg.dataDir}/assets/qslcard 0750 ${cfg.user} ${group} - -" + ]; }; users.users."${cfg.user}" = { diff --git a/nixos/modules/services/web-apps/code-server.nix b/nixos/modules/services/web-apps/code-server.nix index f94a1a8b53fa4b..c310fa70b94486 100644 --- a/nixos/modules/services/web-apps/code-server.nix +++ b/nixos/modules/services/web-apps/code-server.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.code-server; defaultUser = "code-server"; defaultGroup = defaultUser; -in { +in +{ options = { services.code-server = { enable = lib.mkEnableOption "code-server"; @@ -36,7 +42,9 @@ in { Additional environment variables to pass to code-server. ''; default = { }; - example = { PKG_CONFIG_PATH = "/run/current-system/sw/lib/pkgconfig"; }; + example = { + PKG_CONFIG_PATH = "/run/current-system/sw/lib/pkgconfig"; + }; }; extraArguments = lib.mkOption { @@ -69,7 +77,10 @@ in { description = '' The type of authentication to use. ''; - type = lib.types.enum [ "none" "password" ]; + type = lib.types.enum [ + "none" + "password" + ]; }; hashedPassword = lib.mkOption { @@ -121,7 +132,7 @@ in { socketMode = lib.mkOption { default = null; description = '' - File mode of the socket. + File mode of the socket. ''; type = lib.types.nullOr lib.types.str; }; @@ -212,27 +223,37 @@ in { HASHED_PASSWORD = cfg.hashedPassword; } // cfg.extraEnvironment; serviceConfig = { - ExecStart = '' - ${lib.getExe cfg.package} \ - --auth=${cfg.auth} \ - --bind-addr=${cfg.host}:${toString cfg.port} \ - '' + lib.optionalString (cfg.socket != null) '' + ExecStart = + '' + ${lib.getExe cfg.package} \ + --auth=${cfg.auth} \ + --bind-addr=${cfg.host}:${toString cfg.port} \ + '' + + lib.optionalString (cfg.socket != null) '' --socket=${cfg.socket} \ - '' + lib.optionalString (cfg.userDataDir != null) '' + '' + + lib.optionalString (cfg.userDataDir != null) '' --user-data-dir=${cfg.userDataDir} \ - '' + lib.optionalString (cfg.extensionsDir != null) '' + '' + + lib.optionalString (cfg.extensionsDir != null) '' --extensions-dir=${cfg.extensionsDir} \ - '' + lib.optionalString (cfg.disableTelemetry == true) '' + '' + + lib.optionalString (cfg.disableTelemetry == true) '' --disable-telemetry \ - '' + lib.optionalString (cfg.disableUpdateCheck == true) '' + '' + + lib.optionalString (cfg.disableUpdateCheck == true) '' --disable-update-check \ - '' + lib.optionalString (cfg.disableFileDownloads == true) '' + '' + + lib.optionalString (cfg.disableFileDownloads == true) '' --disable-file-downloads \ - '' + lib.optionalString (cfg.disableWorkspaceTrust == true) '' + '' + + lib.optionalString (cfg.disableWorkspaceTrust == true) '' --disable-workspace-trust \ - '' + lib.optionalString (cfg.disableGettingStartedOverride == true) '' + '' + + lib.optionalString (cfg.disableGettingStartedOverride == true) '' --disable-getting-started-override \ - '' + lib.escapeShellArgs cfg.extraArguments; + '' + + lib.escapeShellArgs cfg.extraArguments; ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; RuntimeDirectory = cfg.user; User = cfg.user; diff --git a/nixos/modules/services/web-apps/coder.nix b/nixos/modules/services/web-apps/coder.nix index 5450adbe118da4..bdbc7b28bc9734 100644 --- a/nixos/modules/services/web-apps/coder.nix +++ b/nixos/modules/services/web-apps/coder.nix @@ -1,11 +1,18 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with lib; let cfg = config.services.coder; name = "coder"; -in { +in +{ options = { services.coder = { enable = mkEnableOption "Coder service"; @@ -76,7 +83,7 @@ in { extra = mkOption { type = types.attrs; description = "Extra environment variables to pass run Coder's server with. See Coder documentation."; - default = {}; + default = { }; example = { CODER_OAUTH2_GITHUB_ALLOW_SIGNUPS = true; CODER_OAUTH2_GITHUB_ALLOWED_ORGS = "your-org"; @@ -159,7 +166,10 @@ in { config = mkIf cfg.enable { assertions = [ - { assertion = cfg.database.createLocally -> cfg.database.username == name && cfg.database.database == cfg.database.username; + { + assertion = + cfg.database.createLocally + -> cfg.database.username == name && cfg.database.database == cfg.database.username; message = "services.coder.database.username must be set to ${name} if services.coder.database.createLocally is set true"; } ]; @@ -172,7 +182,11 @@ in { environment = cfg.environment.extra // { CODER_ACCESS_URL = cfg.accessUrl; CODER_WILDCARD_ACCESS_URL = cfg.wildcardAccessUrl; - CODER_PG_CONNECTION_URL = "user=${cfg.database.username} ${optionalString (cfg.database.password != null) "password=${cfg.database.password}"} database=${cfg.database.database} host=${cfg.database.host} ${optionalString (cfg.database.sslmode != null) "sslmode=${cfg.database.sslmode}"}"; + CODER_PG_CONNECTION_URL = "user=${cfg.database.username} ${ + optionalString (cfg.database.password != null) "password=${cfg.database.password}" + } database=${cfg.database.database} host=${cfg.database.host} ${ + optionalString (cfg.database.sslmode != null) "sslmode=${cfg.database.sslmode}" + }"; CODER_ADDRESS = cfg.listenAddress; CODER_TLS_ENABLE = optionalString (cfg.tlsCert != null) "1"; CODER_TLS_CERT_FILE = cfg.tlsCert; @@ -203,15 +217,16 @@ in { ensureDatabases = [ cfg.database.database ]; - ensureUsers = [{ - name = cfg.user; - ensureDBOwnership = true; + ensureUsers = [ + { + name = cfg.user; + ensureDBOwnership = true; } ]; }; users.groups = optionalAttrs (cfg.group == name) { - "${cfg.group}" = {}; + "${cfg.group}" = { }; }; users.users = optionalAttrs (cfg.user == name) { ${name} = { diff --git a/nixos/modules/services/web-apps/convos.nix b/nixos/modules/services/web-apps/convos.nix index da5f7cbf724f46..e99edf0cc35d1b 100644 --- a/nixos/modules/services/web-apps/convos.nix +++ b/nixos/modules/services/web-apps/convos.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -62,7 +67,10 @@ in LockPersonality = true; RestrictRealtime = true; RestrictNamespaces = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6"]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; SystemCallFilter = "@system-service"; SystemCallArchitectures = "native"; CapabilityBoundingSet = ""; diff --git a/nixos/modules/services/web-apps/dex.nix b/nixos/modules/services/web-apps/dex.nix index 45e16603373d16..ca87ba273a9d18 100644 --- a/nixos/modules/services/web-apps/dex.nix +++ b/nixos/modules/services/web-apps/dex.nix @@ -1,21 +1,37 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.dex; - fixClient = client: if client ? secretFile then ((builtins.removeAttrs client [ "secretFile" ]) // { secret = client.secretFile; }) else client; - filteredSettings = mapAttrs (n: v: if n == "staticClients" then (builtins.map fixClient v) else v) cfg.settings; - secretFiles = flatten (builtins.map (c: optional (c ? secretFile) c.secretFile) (cfg.settings.staticClients or [])); + fixClient = + client: + if client ? secretFile then + ((builtins.removeAttrs client [ "secretFile" ]) // { secret = client.secretFile; }) + else + client; + filteredSettings = mapAttrs ( + n: v: if n == "staticClients" then (builtins.map fixClient v) else v + ) cfg.settings; + secretFiles = flatten ( + builtins.map (c: optional (c ? secretFile) c.secretFile) (cfg.settings.staticClients or [ ]) + ); - settingsFormat = pkgs.formats.yaml {}; + settingsFormat = pkgs.formats.yaml { }; configFile = settingsFormat.generate "config.yaml" filteredSettings; - startPreScript = pkgs.writeShellScript "dex-start-pre" - (concatStringsSep "\n" (map (file: '' - replace-secret '${file}' '${file}' /run/dex/config.yaml - '') - secretFiles)); + startPreScript = pkgs.writeShellScript "dex-start-pre" ( + concatStringsSep "\n" ( + map (file: '' + replace-secret '${file}' '${file}' /run/dex/config.yaml + '') secretFiles + ) + ); in { options.services.dex = { @@ -33,7 +49,7 @@ in settings = mkOption { type = settingsFormat.type; - default = {}; + default = { }; example = literalExpression '' { # External url @@ -70,58 +86,69 @@ in systemd.services.dex = { description = "dex identity provider"; wantedBy = [ "multi-user.target" ]; - after = [ "networking.target" ] ++ (optional (cfg.settings.storage.type == "postgres") "postgresql.service"); + after = [ + "networking.target" + ] ++ (optional (cfg.settings.storage.type == "postgres") "postgresql.service"); path = with pkgs; [ replace-secret ]; - serviceConfig = { - ExecStart = "${pkgs.dex-oidc}/bin/dex serve /run/dex/config.yaml"; - ExecStartPre = [ - "${pkgs.coreutils}/bin/install -m 600 ${configFile} /run/dex/config.yaml" - "+${startPreScript}" - ]; + serviceConfig = + { + ExecStart = "${pkgs.dex-oidc}/bin/dex serve /run/dex/config.yaml"; + ExecStartPre = [ + "${pkgs.coreutils}/bin/install -m 600 ${configFile} /run/dex/config.yaml" + "+${startPreScript}" + ]; - RuntimeDirectory = "dex"; - BindReadOnlyPaths = [ - "/nix/store" - "-/etc/dex" - "-/etc/hosts" - "-/etc/localtime" - "-/etc/nsswitch.conf" - "-/etc/resolv.conf" - "-/etc/ssl/certs/ca-certificates.crt" - ]; - BindPaths = optional (cfg.settings.storage.type == "postgres") "/var/run/postgresql"; - # ProtectClock= adds DeviceAllow=char-rtc r - DeviceAllow = ""; - DynamicUser = true; - LockPersonality = true; - MemoryDenyWriteExecute = true; - NoNewPrivileges = true; - PrivateDevices = true; - PrivateMounts = true; - # Port needs to be exposed to the host network - #PrivateNetwork = true; - PrivateTmp = true; - PrivateUsers = true; - ProcSubset = "pid"; - ProtectClock = true; - ProtectHome = true; - ProtectHostname = true; - ProtectSystem = "strict"; - ProtectControlGroups = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged @setuid @keyring" ]; - UMask = "0066"; - } // optionalAttrs (cfg.environmentFile != null) { - EnvironmentFile = cfg.environmentFile; - }; + RuntimeDirectory = "dex"; + BindReadOnlyPaths = [ + "/nix/store" + "-/etc/dex" + "-/etc/hosts" + "-/etc/localtime" + "-/etc/nsswitch.conf" + "-/etc/resolv.conf" + "-/etc/ssl/certs/ca-certificates.crt" + ]; + BindPaths = optional (cfg.settings.storage.type == "postgres") "/var/run/postgresql"; + # ProtectClock= adds DeviceAllow=char-rtc r + DeviceAllow = ""; + DynamicUser = true; + LockPersonality = true; + MemoryDenyWriteExecute = true; + NoNewPrivileges = true; + PrivateDevices = true; + PrivateMounts = true; + # Port needs to be exposed to the host network + #PrivateNetwork = true; + PrivateTmp = true; + PrivateUsers = true; + ProcSubset = "pid"; + ProtectClock = true; + ProtectHome = true; + ProtectHostname = true; + ProtectSystem = "strict"; + ProtectControlGroups = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged @setuid @keyring" + ]; + UMask = "0066"; + } + // optionalAttrs (cfg.environmentFile != null) { + EnvironmentFile = cfg.environmentFile; + }; }; }; diff --git a/nixos/modules/services/web-apps/discourse.nix b/nixos/modules/services/web-apps/discourse.nix index 849a03be8bc878..45a36138ff5421 100644 --- a/nixos/modules/services/web-apps/discourse.nix +++ b/nixos/modules/services/web-apps/discourse.nix @@ -1,7 +1,14 @@ -{ config, options, lib, pkgs, utils, ... }: +{ + config, + options, + lib, + pkgs, + utils, + ... +}: let - json = pkgs.formats.json {}; + json = pkgs.formats.json { }; cfg = config.services.discourse; opt = options.services.discourse; @@ -9,19 +16,15 @@ let # Keep in sync with https://github.com/discourse/discourse_docker/blob/main/image/base/slim.Dockerfile#L5 upstreamPostgresqlVersion = lib.getVersion pkgs.postgresql_13; - postgresqlPackage = if config.services.postgresql.enable then - config.services.postgresql.package - else - pkgs.postgresql; + postgresqlPackage = + if config.services.postgresql.enable then config.services.postgresql.package else pkgs.postgresql; postgresqlVersion = lib.getVersion postgresqlPackage; # We only want to create a database if we're actually going to connect to it. databaseActuallyCreateLocally = cfg.database.createLocally && cfg.database.host == null; - tlsEnabled = cfg.enableACME - || cfg.sslCertificate != null - || cfg.sslCertificateKey != null; + tlsEnabled = cfg.enableACME || cfg.sslCertificate != null || cfg.sslCertificateKey != null; in { options = { @@ -31,9 +34,11 @@ in package = lib.mkOption { type = lib.types.package; default = pkgs.discourse; - apply = p: p.override { - plugins = lib.unique (p.enabledPlugins ++ cfg.plugins); - }; + apply = + p: + p.override { + plugins = lib.unique (p.enabledPlugins ++ cfg.plugins); + }; defaultText = lib.literalExpression "pkgs.discourse"; description = '' The discourse package to use. @@ -108,8 +113,17 @@ in }; backendSettings = lib.mkOption { - type = with lib.types; attrsOf (nullOr (oneOf [ str int bool float ])); - default = {}; + type = + with lib.types; + attrsOf ( + nullOr (oneOf [ + str + int + bool + float + ]) + ); + default = { }; example = lib.literalExpression '' { max_reqs_per_ip_per_minute = 300; @@ -133,7 +147,7 @@ in siteSettings = lib.mkOption { type = json.type; - default = {}; + default = { }; example = lib.literalExpression '' { required = { @@ -404,7 +418,13 @@ in }; authentication = lib.mkOption { - type = with lib.types; nullOr (enum ["plain" "login" "cram_md5"]); + type = + with lib.types; + nullOr (enum [ + "plain" + "login" + "cram_md5" + ]); default = null; description = '' Authentication type to use, see https://api.rubyonrails.org/classes/ActionMailer/Base.html @@ -483,7 +503,7 @@ in plugins = lib.mkOption { type = lib.types.listOf lib.types.package; - default = []; + default = [ ]; example = lib.literalExpression '' with config.services.discourse.package.plugins; [ discourse-canned-replies @@ -527,14 +547,16 @@ in message = "Could not automatically determine hostname, set service.discourse.hostname manually."; } { - assertion = cfg.database.ignorePostgresqlVersion || (databaseActuallyCreateLocally -> upstreamPostgresqlVersion == postgresqlVersion); - message = "The PostgreSQL version recommended for use with Discourse is ${upstreamPostgresqlVersion}, you're using ${postgresqlVersion}. " - + "Either update your PostgreSQL package to the correct version or set services.discourse.database.ignorePostgresqlVersion. " - + "See https://nixos.org/manual/nixos/stable/index.html#module-postgresql for details on how to upgrade PostgreSQL."; + assertion = + cfg.database.ignorePostgresqlVersion + || (databaseActuallyCreateLocally -> upstreamPostgresqlVersion == postgresqlVersion); + message = + "The PostgreSQL version recommended for use with Discourse is ${upstreamPostgresqlVersion}, you're using ${postgresqlVersion}. " + + "Either update your PostgreSQL package to the correct version or set services.discourse.database.ignorePostgresqlVersion. " + + "See https://nixos.org/manual/nixos/stable/index.html#module-postgresql for details on how to upgrade PostgreSQL."; } ]; - # Default config values are from `config/discourse_defaults.conf` # upstream. services.discourse.backendSettings = lib.mapAttrs (_: lib.mkDefault) { @@ -657,15 +679,20 @@ in }; services.redis.servers.discourse = - lib.mkIf (lib.elem cfg.redis.host [ "localhost" "127.0.0.1" ]) { - enable = true; - bind = cfg.redis.host; - port = cfg.backendSettings.redis_port; - }; + lib.mkIf + (lib.elem cfg.redis.host [ + "localhost" + "127.0.0.1" + ]) + { + enable = true; + bind = cfg.redis.host; + port = cfg.backendSettings.redis_port; + }; services.postgresql = lib.mkIf databaseActuallyCreateLocally { enable = true; - ensureUsers = [{ name = "discourse"; }]; + ensureUsers = [ { name = "discourse"; } ]; }; # The postgresql module doesn't currently support concepts like @@ -675,29 +702,29 @@ in let pgsql = config.services.postgresql; in - lib.mkIf databaseActuallyCreateLocally { - after = [ "postgresql.service" ]; - bindsTo = [ "postgresql.service" ]; - wantedBy = [ "discourse.service" ]; - partOf = [ "discourse.service" ]; - path = [ - pgsql.package - ]; - script = '' - set -o errexit -o pipefail -o nounset -o errtrace - shopt -s inherit_errexit + lib.mkIf databaseActuallyCreateLocally { + after = [ "postgresql.service" ]; + bindsTo = [ "postgresql.service" ]; + wantedBy = [ "discourse.service" ]; + partOf = [ "discourse.service" ]; + path = [ + pgsql.package + ]; + script = '' + set -o errexit -o pipefail -o nounset -o errtrace + shopt -s inherit_errexit - psql -tAc "SELECT 1 FROM pg_database WHERE datname = 'discourse'" | grep -q 1 || psql -tAc 'CREATE DATABASE "discourse" OWNER "discourse"' - psql '${cfg.database.name}' -tAc "CREATE EXTENSION IF NOT EXISTS pg_trgm" - psql '${cfg.database.name}' -tAc "CREATE EXTENSION IF NOT EXISTS hstore" - ''; + psql -tAc "SELECT 1 FROM pg_database WHERE datname = 'discourse'" | grep -q 1 || psql -tAc 'CREATE DATABASE "discourse" OWNER "discourse"' + psql '${cfg.database.name}' -tAc "CREATE EXTENSION IF NOT EXISTS pg_trgm" + psql '${cfg.database.name}' -tAc "CREATE EXTENSION IF NOT EXISTS hstore" + ''; - serviceConfig = { - User = pgsql.superUser; - Type = "oneshot"; - RemainAfterExit = true; - }; + serviceConfig = { + User = pgsql.superUser; + Type = "oneshot"; + RemainAfterExit = true; }; + }; systemd.services.discourse = { wantedBy = [ "multi-user.target" ]; @@ -706,12 +733,14 @@ in "postgresql.service" "discourse-postgresql.service" ]; - bindsTo = [ - "redis-discourse.service" - ] ++ lib.optionals (cfg.database.host == null) [ - "postgresql.service" - "discourse-postgresql.service" - ]; + bindsTo = + [ + "redis-discourse.service" + ] + ++ lib.optionals (cfg.database.host == null) [ + "postgresql.service" + "discourse-postgresql.service" + ]; path = cfg.package.runtimeDeps ++ [ postgresqlPackage pkgs.replace-secret @@ -727,20 +756,30 @@ in let discourseKeyValue = lib.generators.toKeyValue { mkKeyValue = lib.flip lib.generators.mkKeyValueDefault " = " { - mkValueString = v: with builtins; - if isInt v then toString v - else if isString v then ''"${v}"'' - else if true == v then "true" - else if false == v then "false" - else if null == v then "" - else if isFloat v then lib.strings.floatToString v - else throw "unsupported type ${typeOf v}: ${(lib.generators.toPretty {}) v}"; + mkValueString = + v: + with builtins; + if isInt v then + toString v + else if isString v then + ''"${v}"'' + else if true == v then + "true" + else if false == v then + "false" + else if null == v then + "" + else if isFloat v then + lib.strings.floatToString v + else + throw "unsupported type ${typeOf v}: ${(lib.generators.toPretty { }) v}"; }; }; discourseConf = pkgs.writeText "discourse.conf" (discourseKeyValue cfg.backendSettings); - mkSecretReplacement = file: + mkSecretReplacement = + file: lib.optionalString (file != null) '' replace-secret '${file}' '${file}' /run/discourse/config/discourse.conf ''; @@ -754,7 +793,8 @@ in discourse-rake admin:create_noninteractively ''; - in '' + in + '' set -o errexit -o pipefail -o nounset -o errtrace shopt -s inherit_errexit @@ -770,10 +810,7 @@ in ( umask u=rwx,g=,o= - ${utils.genJqSecretsReplacementSnippet - cfg.siteSettings - "/run/discourse/config/nixos_site_settings.json" - } + ${utils.genJqSecretsReplacementSnippet cfg.siteSettings "/run/discourse/config/nixos_site_settings.json"} install -T -m 0600 -o discourse ${discourseConf} /run/discourse/config/discourse.conf ${mkSecretReplacement cfg.database.passwordFile} ${mkSecretReplacement cfg.mail.outgoing.passwordFile} @@ -834,7 +871,7 @@ in recommendedGzipSettings = true; recommendedProxySettings = true; - upstreams.discourse.servers."unix:/run/discourse/sockets/unicorn.sock" = {}; + upstreams.discourse.servers."unix:/run/discourse/sockets/unicorn.sock" = { }; appendHttpConfig = '' # inactive means we keep stuff around for 1440m minutes regardless of last access (1 week) @@ -854,12 +891,18 @@ in locations = let - proxy = { extraConfig ? "" }: { - proxyPass = "http://discourse"; - extraConfig = extraConfig + '' - proxy_set_header X-Request-Start "t=''${msec}"; - ''; - }; + proxy = + { + extraConfig ? "", + }: + { + proxyPass = "http://discourse"; + extraConfig = + extraConfig + + '' + proxy_set_header X-Request-Start "t=''${msec}"; + ''; + }; cache = time: '' expires ${time}; add_header Cache-Control public,immutable; @@ -867,40 +910,46 @@ in cache_1y = cache "1y"; cache_1d = cache "1d"; in - { - "/".tryFiles = "$uri @discourse"; - "@discourse" = proxy {}; - "^~ /backups/".extraConfig = '' - internal; + { + "/".tryFiles = "$uri @discourse"; + "@discourse" = proxy { }; + "^~ /backups/".extraConfig = '' + internal; + ''; + "/favicon.ico" = { + return = "204"; + extraConfig = '' + access_log off; + log_not_found off; ''; - "/favicon.ico" = { - return = "204"; - extraConfig = '' - access_log off; - log_not_found off; - ''; - }; - "~ ^/uploads/short-url/" = proxy {}; - "~ ^/secure-media-uploads/" = proxy {}; - "~* (fonts|assets|plugins|uploads)/.*\.(eot|ttf|woff|woff2|ico|otf)$".extraConfig = cache_1y + '' + }; + "~ ^/uploads/short-url/" = proxy { }; + "~ ^/secure-media-uploads/" = proxy { }; + "~* (fonts|assets|plugins|uploads)/.*\.(eot|ttf|woff|woff2|ico|otf)$".extraConfig = + cache_1y + + '' add_header Access-Control-Allow-Origin *; ''; - "/srv/status" = proxy { - extraConfig = '' - access_log off; - log_not_found off; - ''; - }; - "~ ^/javascripts/".extraConfig = cache_1d; - "~ ^/assets/(?.+)$".extraConfig = cache_1y + '' + "/srv/status" = proxy { + extraConfig = '' + access_log off; + log_not_found off; + ''; + }; + "~ ^/javascripts/".extraConfig = cache_1d; + "~ ^/assets/(?.+)$".extraConfig = + cache_1y + + '' # asset pipeline enables this brotli_static on; gzip_static on; ''; - "~ ^/plugins/".extraConfig = cache_1y; - "~ /images/emoji/".extraConfig = cache_1y; - "~ ^/uploads/" = proxy { - extraConfig = cache_1y + '' + "~ ^/plugins/".extraConfig = cache_1y; + "~ /images/emoji/".extraConfig = cache_1y; + "~ ^/uploads/" = proxy { + extraConfig = + cache_1y + + '' proxy_set_header X-Sendfile-Type X-Accel-Redirect; proxy_set_header X-Accel-Mapping ${cfg.package}/share/discourse/public/=/downloads/; @@ -920,14 +969,15 @@ in try_files $uri =404; } ''; - }; - "~ ^/admin/backups/" = proxy { - extraConfig = '' - proxy_set_header X-Sendfile-Type X-Accel-Redirect; - proxy_set_header X-Accel-Mapping ${cfg.package}/share/discourse/public/=/downloads/; - ''; - }; - "~ ^/(svg-sprite/|letter_avatar/|letter_avatar_proxy/|user_avatar|highlight-js|stylesheets|theme-javascripts|favicon/proxied|service-worker)" = proxy { + }; + "~ ^/admin/backups/" = proxy { + extraConfig = '' + proxy_set_header X-Sendfile-Type X-Accel-Redirect; + proxy_set_header X-Accel-Mapping ${cfg.package}/share/discourse/public/=/downloads/; + ''; + }; + "~ ^/(svg-sprite/|letter_avatar/|letter_avatar_proxy/|user_avatar|highlight-js|stylesheets|theme-javascripts|favicon/proxied|service-worker)" = + proxy { extraConfig = '' # if Set-Cookie is in the response nothing gets cached # this is double bad cause we are not passing last modified in @@ -942,17 +992,17 @@ in proxy_cache_valid 200 301 302 7d; ''; }; - "/message-bus/" = proxy { - extraConfig = '' - proxy_http_version 1.1; - proxy_buffering off; - ''; - }; - "/downloads/".extraConfig = '' - internal; - alias ${cfg.package}/share/discourse/public/; + "/message-bus/" = proxy { + extraConfig = '' + proxy_http_version 1.1; + proxy_buffering off; ''; }; + "/downloads/".extraConfig = '' + internal; + alias ${cfg.package}/share/discourse/public/; + ''; + }; }; }; @@ -966,52 +1016,54 @@ in }; mail-receiver-json = json.generate "mail-receiver.json" mail-receiver-environment; in - { - before = [ "postfix.service" ]; - after = [ "discourse.service" ]; - wantedBy = [ "discourse.service" ]; - partOf = [ "discourse.service" ]; - path = [ - cfg.package.rake - pkgs.jq - ]; - preStart = lib.optionalString (cfg.mail.incoming.apiKeyFile == null) '' + { + before = [ "postfix.service" ]; + after = [ "discourse.service" ]; + wantedBy = [ "discourse.service" ]; + partOf = [ "discourse.service" ]; + path = [ + cfg.package.rake + pkgs.jq + ]; + preStart = lib.optionalString (cfg.mail.incoming.apiKeyFile == null) '' + set -o errexit -o pipefail -o nounset -o errtrace + shopt -s inherit_errexit + + if [[ ! -e /var/lib/discourse-mail-receiver/api_key ]]; then + discourse-rake api_key:create_master[email-receiver] >/var/lib/discourse-mail-receiver/api_key + fi + ''; + script = + let + apiKeyPath = + if cfg.mail.incoming.apiKeyFile == null then + "/var/lib/discourse-mail-receiver/api_key" + else + cfg.mail.incoming.apiKeyFile; + in + '' set -o errexit -o pipefail -o nounset -o errtrace shopt -s inherit_errexit - if [[ ! -e /var/lib/discourse-mail-receiver/api_key ]]; then - discourse-rake api_key:create_master[email-receiver] >/var/lib/discourse-mail-receiver/api_key - fi - ''; - script = - let - apiKeyPath = - if cfg.mail.incoming.apiKeyFile == null then - "/var/lib/discourse-mail-receiver/api_key" - else - cfg.mail.incoming.apiKeyFile; - in '' - set -o errexit -o pipefail -o nounset -o errtrace - shopt -s inherit_errexit - - api_key=$(<'${apiKeyPath}') - export api_key + api_key=$(<'${apiKeyPath}') + export api_key - jq <${mail-receiver-json} \ - '.DISCOURSE_API_KEY = $ENV.api_key' \ - >'/run/discourse-mail-receiver/mail-receiver-environment.json' - ''; + jq <${mail-receiver-json} \ + '.DISCOURSE_API_KEY = $ENV.api_key' \ + >'/run/discourse-mail-receiver/mail-receiver-environment.json' + ''; - serviceConfig = { - Type = "oneshot"; - RemainAfterExit = true; - RuntimeDirectory = "discourse-mail-receiver"; - RuntimeDirectoryMode = "0700"; - StateDirectory = "discourse-mail-receiver"; - User = "discourse"; - Group = "discourse"; - }; - }); + serviceConfig = { + Type = "oneshot"; + RemainAfterExit = true; + RuntimeDirectory = "discourse-mail-receiver"; + RuntimeDirectoryMode = "0700"; + StateDirectory = "discourse-mail-receiver"; + User = "discourse"; + Group = "discourse"; + }; + } + ); services.discourse.siteSettings = { required = { @@ -1070,17 +1122,19 @@ in }; }; - users.users = { - discourse = { - group = "discourse"; - isSystemUser = true; - }; - } // (lib.optionalAttrs cfg.nginx.enable { - ${config.services.nginx.user}.extraGroups = [ "discourse" ]; - }); + users.users = + { + discourse = { + group = "discourse"; + isSystemUser = true; + }; + } + // (lib.optionalAttrs cfg.nginx.enable { + ${config.services.nginx.user}.extraGroups = [ "discourse" ]; + }); users.groups = { - discourse = {}; + discourse = { }; }; environment.systemPackages = [ diff --git a/nixos/modules/services/web-apps/documize.nix b/nixos/modules/services/web-apps/documize.nix index ab6d08f05992ae..54feb6447ed420 100644 --- a/nixos/modules/services/web-apps/documize.nix +++ b/nixos/modules/services/web-apps/documize.nix @@ -1,16 +1,28 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: with lib; let cfg = config.services.documize; - mkParams = optional: concatMapStrings (name: let - predicate = optional -> cfg.${name} != null; - template = " -${name} '${toString cfg.${name}}'"; - in optionalString predicate template); - -in { + mkParams = + optional: + concatMapStrings ( + name: + let + predicate = optional -> cfg.${name} != null; + template = " -${name} '${toString cfg.${name}}'"; + in + optionalString predicate template + ); + +in +{ options.services.documize = { enable = mkEnableOption "Documize Wiki"; @@ -76,7 +88,13 @@ in { }; dbtype = mkOption { - type = types.enum [ "mysql" "percona" "mariadb" "postgresql" "sqlserver" ]; + type = types.enum [ + "mysql" + "percona" + "mariadb" + "postgresql" + "sqlserver" + ]; default = "postgresql"; description = '' Specify the database provider: `mysql`, `percona`, `mariadb`, `postgresql`, `sqlserver` @@ -117,8 +135,19 @@ in { serviceConfig = { ExecStart = concatStringsSep " " [ "${cfg.package}/bin/documize" - (mkParams false [ "db" "dbtype" "port" ]) - (mkParams true [ "offline" "location" "forcesslport" "key" "cert" "salt" ]) + (mkParams false [ + "db" + "dbtype" + "port" + ]) + (mkParams true [ + "offline" + "location" + "forcesslport" + "key" + "cert" + "salt" + ]) ]; Restart = "always"; DynamicUser = "yes"; diff --git a/nixos/modules/services/web-apps/eintopf.nix b/nixos/modules/services/web-apps/eintopf.nix index a2b304445597ea..c814e58f6aca82 100644 --- a/nixos/modules/services/web-apps/eintopf.nix +++ b/nixos/modules/services/web-apps/eintopf.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,7 +11,8 @@ let cfg = config.services.eintopf; -in { +in +{ options.services.eintopf = { enable = mkEnableOption "Eintopf community event calendar web app"; @@ -50,12 +56,12 @@ in { serviceConfig = { ExecStart = "${pkgs.eintopf}/bin/eintopf"; WorkingDirectory = "/var/lib/eintopf"; - StateDirectory = "eintopf" ; + StateDirectory = "eintopf"; EnvironmentFile = [ cfg.secrets ]; # hardening AmbientCapabilities = ""; - CapabilityBoundingSet = "" ; + CapabilityBoundingSet = ""; DevicePolicy = "closed"; DynamicUser = true; LockPersonality = true; @@ -75,12 +81,18 @@ in { ProtectProc = "invisible"; ProtectSystem = "strict"; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; UMask = "0077"; }; }; diff --git a/nixos/modules/services/web-apps/engelsystem.nix b/nixos/modules/services/web-apps/engelsystem.nix index b32e5e05953f78..07e1d8c735e9e7 100644 --- a/nixos/modules/services/web-apps/engelsystem.nix +++ b/nixos/modules/services/web-apps/engelsystem.nix @@ -15,12 +15,16 @@ let mkPackageOption mkRenamedOptionModule types - ; + ; cfg = config.services.engelsystem; -in { +in +{ imports = [ - (mkRenamedOptionModule [ "services" "engelsystem" "config" ] [ "services" "engelsystem" "settings" ]) + (mkRenamedOptionModule + [ "services" "engelsystem" "config" ] + [ "services" "engelsystem" "settings" ] + ) ]; options.services.engelsystem = { @@ -94,18 +98,21 @@ in { services.mysql = mkIf cfg.createDatabase { enable = true; package = mkDefault pkgs.mariadb; - ensureUsers = [{ - name = "engelsystem"; - ensurePermissions = { "engelsystem.*" = "ALL PRIVILEGES"; }; - }]; + ensureUsers = [ + { + name = "engelsystem"; + ensurePermissions = { + "engelsystem.*" = "ALL PRIVILEGES"; + }; + } + ]; ensureDatabases = [ "engelsystem" ]; }; - environment.etc."engelsystem/config.php".source = - pkgs.writeText "config.php" '' - "$versionFile" fi ''; - after = [ "engelsystem-init.service" "mysql.service" ]; + after = [ + "engelsystem-init.service" + "mysql.service" + ]; }; - systemd.services."phpfpm-engelsystem".after = - [ "engelsystem-migrate.service" ]; + systemd.services."phpfpm-engelsystem".after = [ "engelsystem-migrate.service" ]; users.users.engelsystem = { isSystemUser = true; diff --git a/nixos/modules/services/web-apps/ethercalc.nix b/nixos/modules/services/web-apps/ethercalc.nix index fd6c6e05a87273..e9bd924041a54b 100644 --- a/nixos/modules/services/web-apps/ethercalc.nix +++ b/nixos/modules/services/web-apps/ethercalc.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.ethercalc; -in { +in +{ options = { services.ethercalc = { enable = mkOption { @@ -43,13 +49,13 @@ in { config = mkIf cfg.enable { systemd.services.ethercalc = { description = "Ethercalc service"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; serviceConfig = { - DynamicUser = true; - ExecStart = "${cfg.package}/bin/ethercalc --host ${cfg.host} --port ${toString cfg.port}"; - Restart = "always"; - StateDirectory = "ethercalc"; + DynamicUser = true; + ExecStart = "${cfg.package}/bin/ethercalc --host ${cfg.host} --port ${toString cfg.port}"; + Restart = "always"; + StateDirectory = "ethercalc"; WorkingDirectory = "/var/lib/ethercalc"; }; }; diff --git a/nixos/modules/services/web-apps/flarum.nix b/nixos/modules/services/web-apps/flarum.nix index 219fd713fa5c74..d7f558c73d07e2 100644 --- a/nixos/modules/services/web-apps/flarum.nix +++ b/nixos/modules/services/web-apps/flarum.nix @@ -1,26 +1,34 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: with lib; let cfg = config.services.flarum; - flarumInstallConfig = pkgs.writeText "config.json" (builtins.toJSON { - debug = false; - offline = false; - - baseUrl = cfg.baseUrl; - databaseConfiguration = cfg.database; - adminUser = { - username = cfg.adminUser; - password = cfg.initialAdminPassword; - email = cfg.adminEmail; - }; - settings = { - forum_title = cfg.forumTitle; - }; - }); -in { + flarumInstallConfig = pkgs.writeText "config.json" ( + builtins.toJSON { + debug = false; + offline = false; + + baseUrl = cfg.baseUrl; + databaseConfiguration = cfg.database; + adminUser = { + username = cfg.adminUser; + password = cfg.initialAdminPassword; + email = cfg.adminEmail; + }; + settings = { + forum_title = cfg.forumTitle; + }; + } + ); +in +{ options.services.flarum = { enable = mkEnableOption "Flarum discussion platform"; @@ -83,7 +91,13 @@ in { }; database = mkOption rec { - type = with types; attrsOf (oneOf [str bool int]); + type = + with types; + attrsOf (oneOf [ + str + bool + int + ]); description = "MySQL database parameters"; default = { # the database driver; i.e. MySQL; MariaDB... @@ -125,7 +139,7 @@ in { homeMode = "755"; group = cfg.group; }; - users.groups.${cfg.group} = {}; + users.groups.${cfg.group} = { }; services.phpfpm.pools.flarum = { user = cfg.user; @@ -164,7 +178,7 @@ in { services.mysql = mkIf cfg.enable { enable = true; package = pkgs.mariadb; - ensureDatabases = [cfg.database.database]; + ensureDatabases = [ cfg.database.database ]; ensureUsers = [ { name = cfg.database.username; @@ -184,35 +198,41 @@ in { systemd.services.flarum-install = { description = "Flarum installation"; - requiredBy = ["phpfpm-flarum.service"]; - before = ["phpfpm-flarum.service"]; - requires = ["mysql.service"]; - after = ["mysql.service"]; + requiredBy = [ "phpfpm-flarum.service" ]; + before = [ "phpfpm-flarum.service" ]; + requires = [ "mysql.service" ]; + after = [ "mysql.service" ]; serviceConfig = { Type = "oneshot"; User = cfg.user; Group = cfg.group; }; - path = [config.services.phpfpm.phpPackage]; - script = '' - mkdir -p ${cfg.stateDir}/{extensions,public/assets/avatars} - mkdir -p ${cfg.stateDir}/storage/{cache,formatter,sessions,views} - cd ${cfg.stateDir} - cp -f ${cfg.package}/share/php/flarum/{extend.php,site.php,flarum} . - ln -sf ${cfg.package}/share/php/flarum/vendor . - ln -sf ${cfg.package}/share/php/flarum/public/index.php public/ - '' + optionalString (cfg.createDatabaseLocally && cfg.database.driver == "mysql") '' - if [ ! -f config.php ]; then - php flarum install --file=${flarumInstallConfig} - fi - '' + '' - if [ -f config.php ]; then - php flarum migrate - php flarum cache:clear - fi - ''; + path = [ config.services.phpfpm.phpPackage ]; + script = + '' + mkdir -p ${cfg.stateDir}/{extensions,public/assets/avatars} + mkdir -p ${cfg.stateDir}/storage/{cache,formatter,sessions,views} + cd ${cfg.stateDir} + cp -f ${cfg.package}/share/php/flarum/{extend.php,site.php,flarum} . + ln -sf ${cfg.package}/share/php/flarum/vendor . + ln -sf ${cfg.package}/share/php/flarum/public/index.php public/ + '' + + optionalString (cfg.createDatabaseLocally && cfg.database.driver == "mysql") '' + if [ ! -f config.php ]; then + php flarum install --file=${flarumInstallConfig} + fi + '' + + '' + if [ -f config.php ]; then + php flarum migrate + php flarum cache:clear + fi + ''; }; }; - meta.maintainers = with lib.maintainers; [ fsagbuya jasonodoom ]; + meta.maintainers = with lib.maintainers; [ + fsagbuya + jasonodoom + ]; } diff --git a/nixos/modules/services/web-apps/gotosocial.nix b/nixos/modules/services/web-apps/gotosocial.nix index aee1edf66a6a75..dc40fb8156f93f 100644 --- a/nixos/modules/services/web-apps/gotosocial.nix +++ b/nixos/modules/services/web-apps/gotosocial.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.gotosocial; settingsFormat = pkgs.formats.yaml { }; @@ -98,17 +103,20 @@ in } ]; - services.gotosocial.settings = (lib.mapAttrs (name: lib.mkDefault) ( - defaultSettings // { - web-asset-base-dir = "${cfg.package}/share/gotosocial/web/assets/"; - web-template-base-dir = "${cfg.package}/share/gotosocial/web/template/"; - } - )) // (lib.optionalAttrs cfg.setupPostgresqlDB { - db-type = "postgres"; - db-address = "/run/postgresql"; - db-database = "gotosocial"; - db-user = "gotosocial"; - }); + services.gotosocial.settings = + (lib.mapAttrs (name: lib.mkDefault) ( + defaultSettings + // { + web-asset-base-dir = "${cfg.package}/share/gotosocial/web/assets/"; + web-template-base-dir = "${cfg.package}/share/gotosocial/web/template/"; + } + )) + // (lib.optionalAttrs cfg.setupPostgresqlDB { + db-type = "postgres"; + db-address = "/run/postgresql"; + db-database = "gotosocial"; + db-user = "gotosocial"; + }); environment.systemPackages = [ gotosocial-admin ]; @@ -136,8 +144,7 @@ in systemd.services.gotosocial = { description = "ActivityPub social network server"; wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ] - ++ lib.optional cfg.setupPostgresqlDB "postgresql.service"; + after = [ "network.target" ] ++ lib.optional cfg.setupPostgresqlDB "postgresql.service"; requires = lib.optional cfg.setupPostgresqlDB "postgresql.service"; restartTriggers = [ configFile ]; diff --git a/nixos/modules/services/web-apps/grocy.nix b/nixos/modules/services/web-apps/grocy.nix index eb4feb191aa590..a15da9d7c5deab 100644 --- a/nixos/modules/services/web-apps/grocy.nix +++ b/nixos/modules/services/web-apps/grocy.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.grocy; -in { +in +{ options.services.grocy = { enable = mkEnableOption "grocy"; @@ -27,7 +33,13 @@ in { }; phpfpm.settings = mkOption { - type = with types; attrsOf (oneOf [ int str bool ]); + type = + with types; + attrsOf (oneOf [ + int + str + bool + ]); default = { "pm" = "dynamic"; "php_admin_value[error_log]" = "stderr"; @@ -66,7 +78,24 @@ in { }; culture = mkOption { - type = types.enum [ "de" "en" "da" "en_GB" "es" "fr" "hu" "it" "nl" "no" "pl" "pt_BR" "ru" "sk_SK" "sv_SE" "tr" ]; + type = types.enum [ + "de" + "en" + "da" + "en_GB" + "es" + "fr" + "hu" + "it" + "nl" + "no" + "pl" + "pt_BR" + "ru" + "sk_SK" + "sv_SE" + "tr" + ]; default = "en"; description = '' Display language of the frontend. @@ -109,9 +138,12 @@ in { group = "nginx"; }; - systemd.tmpfiles.rules = map ( - dirName: "d '${cfg.dataDir}/${dirName}' - grocy nginx - -" - ) [ "viewcache" "plugins" "settingoverrides" "storage" ]; + systemd.tmpfiles.rules = map (dirName: "d '${cfg.dataDir}/${dirName}' - grocy nginx - -") [ + "viewcache" + "plugins" + "settingoverrides" + "storage" + ]; services.phpfpm.pools.grocy = { user = "grocy"; @@ -145,7 +177,8 @@ in { services.nginx = { enable = true; virtualHosts."${cfg.hostName}" = mkMerge [ - { root = "${cfg.package}/public"; + { + root = "${cfg.package}/public"; locations."/".extraConfig = '' rewrite ^ /index.php; ''; diff --git a/nixos/modules/services/web-apps/guacamole-client.nix b/nixos/modules/services/web-apps/guacamole-client.nix index 98a6cac34f3de6..e263526e8c556e 100644 --- a/nixos/modules/services/web-apps/guacamole-client.nix +++ b/nixos/modules/services/web-apps/guacamole-client.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let cfg = config.services.guacamole-client; @@ -44,9 +45,9 @@ in }; config = lib.mkIf cfg.enable { - environment.etc."guacamole/guacamole.properties" = lib.mkIf - (cfg.settings != {}) - { source = (settingsFormat.generate "guacamole.properties" cfg.settings); }; + environment.etc."guacamole/guacamole.properties" = lib.mkIf (cfg.settings != { }) { + source = (settingsFormat.generate "guacamole.properties" cfg.settings); + }; services = lib.mkIf cfg.enableWebserver { tomcat = { diff --git a/nixos/modules/services/web-apps/guacamole-server.nix b/nixos/modules/services/web-apps/guacamole-server.nix index 6f6d12e9939fe2..0662394565c3c0 100644 --- a/nixos/modules/services/web-apps/guacamole-server.nix +++ b/nixos/modules/services/web-apps/guacamole-server.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let cfg = config.services.guacamole-server; @@ -61,8 +62,12 @@ in config = lib.mkIf cfg.enable { # Setup configuration files. - environment.etc."guacamole/logback.xml" = lib.mkIf (cfg.logbackXml != null) { source = cfg.logbackXml; }; - environment.etc."guacamole/user-mapping.xml" = lib.mkIf (cfg.userMappingXml != null) { source = cfg.userMappingXml; }; + environment.etc."guacamole/logback.xml" = lib.mkIf (cfg.logbackXml != null) { + source = cfg.logbackXml; + }; + environment.etc."guacamole/user-mapping.xml" = lib.mkIf (cfg.userMappingXml != null) { + source = cfg.userMappingXml; + }; systemd.services.guacamole-server = { description = "Apache Guacamole server (guacd)"; diff --git a/nixos/modules/services/web-apps/healthchecks.nix b/nixos/modules/services/web-apps/healthchecks.nix index c7db999a62c21e..866e59ffbf83af 100644 --- a/nixos/modules/services/web-apps/healthchecks.nix +++ b/nixos/modules/services/web-apps/healthchecks.nix @@ -1,4 +1,11 @@ -{ config, lib, options, pkgs, buildEnv, ... }: +{ + config, + lib, + options, + pkgs, + buildEnv, + ... +}: with lib; @@ -13,7 +20,9 @@ let STATIC_ROOT = cfg.dataDir + "/static"; } // lib.filterAttrs (_: v: !builtins.isNull v) cfg.settings; - environmentFile = pkgs.writeText "healthchecks-environment" (lib.generators.toKeyValue { } environment); + environmentFile = pkgs.writeText "healthchecks-environment" ( + lib.generators.toKeyValue { } environment + ); healthchecksManageScript = pkgs.writeShellScriptBin "healthchecks-manage" '' sudo=exec @@ -157,17 +166,18 @@ in }; DB = mkOption { - type = types.enum [ "sqlite" "postgres" "mysql" ]; + type = types.enum [ + "sqlite" + "postgres" + "mysql" + ]; default = "sqlite"; description = "Database engine to use."; }; DB_NAME = mkOption { type = types.str; - default = - if settings.config.DB == "sqlite" - then "${cfg.dataDir}/healthchecks.sqlite" - else "hc"; + default = if settings.config.DB == "sqlite" then "${cfg.dataDir}/healthchecks.sqlite" else "hc"; defaultText = lib.literalExpression '' if config.${settings.options.DB} == "sqlite" then "''${config.${opt.dataDir}}/healthchecks.sqlite" @@ -187,7 +197,10 @@ in description = "Target for all Healthchecks services"; wantedBy = [ "multi-user.target" ]; wants = [ "network-online.target" ]; - after = [ "network.target" "network-online.target" ]; + after = [ + "network.target" + "network-online.target" + ]; }; systemd.services = @@ -222,10 +235,12 @@ in wantedBy = [ "healthchecks.target" ]; after = [ "healthchecks-migration.service" ]; - preStart = '' - ${pkg}/opt/healthchecks/manage.py collectstatic --no-input - ${pkg}/opt/healthchecks/manage.py remove_stale_contenttypes --no-input - '' + lib.optionalString (cfg.settings.DEBUG != "True") "${pkg}/opt/healthchecks/manage.py compress"; + preStart = + '' + ${pkg}/opt/healthchecks/manage.py collectstatic --no-input + ${pkg}/opt/healthchecks/manage.py remove_stale_contenttypes --no-input + '' + + lib.optionalString (cfg.settings.DEBUG != "True") "${pkg}/opt/healthchecks/manage.py compress"; serviceConfig = commonConfig // { Restart = "always"; @@ -265,19 +280,17 @@ in }; users.users = optionalAttrs (cfg.user == defaultUser) { - ${defaultUser} = - { - description = "healthchecks service owner"; - isSystemUser = true; - group = defaultUser; - }; + ${defaultUser} = { + description = "healthchecks service owner"; + isSystemUser = true; + group = defaultUser; + }; }; users.groups = optionalAttrs (cfg.user == defaultUser) { - ${defaultUser} = - { - members = [ defaultUser ]; - }; + ${defaultUser} = { + members = [ defaultUser ]; + }; }; }; } diff --git a/nixos/modules/services/web-apps/hedgedoc.nix b/nixos/modules/services/web-apps/hedgedoc.nix index 36d79a4153ece0..817114cb452ca0 100644 --- a/nixos/modules/services/web-apps/hedgedoc.nix +++ b/nixos/modules/services/web-apps/hedgedoc.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) mkOption types literalExpression; @@ -9,20 +14,26 @@ let # versionAtLeast statement remains set to 21.03 for backwards compatibility. # See https://github.com/NixOS/nixpkgs/pull/108899 and # https://github.com/NixOS/rfcs/blob/master/rfcs/0080-nixos-release-schedule.md. - name = if lib.versionAtLeast config.system.stateVersion "21.03" then - "hedgedoc" - else - "codimd"; + name = if lib.versionAtLeast config.system.stateVersion "21.03" then "hedgedoc" else "codimd"; settingsFormat = pkgs.formats.json { }; in { - meta.maintainers = with lib.maintainers; [ SuperSandro2000 h7x4 ]; + meta.maintainers = with lib.maintainers; [ + SuperSandro2000 + h7x4 + ]; imports = [ (lib.mkRenamedOptionModule [ "services" "codimd" ] [ "services" "hedgedoc" ]) - (lib.mkRenamedOptionModule [ "services" "hedgedoc" "configuration" ] [ "services" "hedgedoc" "settings" ]) - (lib.mkRenamedOptionModule [ "services" "hedgedoc" "groups" ] [ "users" "users" "hedgedoc" "extraGroups" ]) + (lib.mkRenamedOptionModule + [ "services" "hedgedoc" "configuration" ] + [ "services" "hedgedoc" "settings" ] + ) + (lib.mkRenamedOptionModule + [ "services" "hedgedoc" "groups" ] + [ "users" "users" "hedgedoc" "extraGroups" ] + ) (lib.mkRemovedOptionModule [ "services" "hedgedoc" "workDir" ] '' This option has been removed in favor of systemd managing the state directory. @@ -110,7 +121,10 @@ in defaultText = literalExpression '' with config.services.hedgedoc.settings; [ host ] ++ lib.optionals (domain != null) [ domain ] ''; - example = [ "localhost" "hedgedoc.org" ]; + example = [ + "localhost" + "hedgedoc.org" + ]; description = '' List of domains to whitelist. ''; diff --git a/nixos/modules/services/web-apps/hledger-web.nix b/nixos/modules/services/web-apps/hledger-web.nix index 32d9df4e8458f1..bf7c525ba79986 100644 --- a/nixos/modules/services/web-apps/hledger-web.nix +++ b/nixos/modules/services/web-apps/hledger-web.nix @@ -1,8 +1,14 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: with lib; let cfg = config.services.hledger-web; -in { +in +{ options.services.hledger-web = { enable = mkEnableOption "hledger-web service"; @@ -27,7 +33,12 @@ in { }; allow = mkOption { - type = types.enum [ "view" "add" "edit" "sandstorm" ]; + type = types.enum [ + "view" + "add" + "edit" + "sandstorm" + ]; default = "view"; description = '' User's access level for changing data. @@ -69,7 +80,7 @@ in { extraOptions = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "--forecast" ]; description = '' Extra command line arguments to pass to hledger-web. @@ -79,8 +90,11 @@ in { }; imports = [ - (mkRemovedOptionModule [ "services" "hledger-web" "capabilities" ] - "This option has been replaced by new option `services.hledger-web.allow`.") + (mkRemovedOptionModule [ + "services" + "hledger-web" + "capabilities" + ] "This option has been replaced by new option `services.hledger-web.allow`.") ]; config = mkIf cfg.enable { @@ -93,39 +107,49 @@ in { useDefaultShell = true; }; - users.groups.hledger = {}; - - systemd.services.hledger-web = let - serverArgs = with cfg; escapeShellArgs ([ - "--serve" - "--host=${host}" - "--port=${toString port}" - "--allow=${allow}" - (optionalString (cfg.baseUrl != null) "--base-url=${cfg.baseUrl}") - (optionalString (cfg.serveApi) "--serve-api") - ] ++ (map (f: "--file=${stateDir}/${f}") cfg.journalFiles) - ++ extraOptions); - in { - description = "hledger-web - web-app for the hledger accounting tool."; - documentation = [ "https://hledger.org/hledger-web.html" ]; - wantedBy = [ "multi-user.target" ]; - after = [ "networking.target" ]; - serviceConfig = mkMerge [ - { - ExecStart = "${pkgs.hledger-web}/bin/hledger-web ${serverArgs}"; - Restart = "always"; - WorkingDirectory = cfg.stateDir; - User = "hledger"; - Group = "hledger"; - PrivateTmp = true; - } - (mkIf (cfg.stateDir == "/var/lib/hledger-web") { - StateDirectory = "hledger-web"; - }) - ]; - }; + users.groups.hledger = { }; + + systemd.services.hledger-web = + let + serverArgs = + with cfg; + escapeShellArgs ( + [ + "--serve" + "--host=${host}" + "--port=${toString port}" + "--allow=${allow}" + (optionalString (cfg.baseUrl != null) "--base-url=${cfg.baseUrl}") + (optionalString (cfg.serveApi) "--serve-api") + ] + ++ (map (f: "--file=${stateDir}/${f}") cfg.journalFiles) + ++ extraOptions + ); + in + { + description = "hledger-web - web-app for the hledger accounting tool."; + documentation = [ "https://hledger.org/hledger-web.html" ]; + wantedBy = [ "multi-user.target" ]; + after = [ "networking.target" ]; + serviceConfig = mkMerge [ + { + ExecStart = "${pkgs.hledger-web}/bin/hledger-web ${serverArgs}"; + Restart = "always"; + WorkingDirectory = cfg.stateDir; + User = "hledger"; + Group = "hledger"; + PrivateTmp = true; + } + (mkIf (cfg.stateDir == "/var/lib/hledger-web") { + StateDirectory = "hledger-web"; + }) + ]; + }; }; - meta.maintainers = with lib.maintainers; [ marijanp erictapen ]; + meta.maintainers = with lib.maintainers; [ + marijanp + erictapen + ]; } diff --git a/nixos/modules/services/web-apps/honk.nix b/nixos/modules/services/web-apps/honk.nix index e6a44619212247..15d8b5acc3b2b1 100644 --- a/nixos/modules/services/web-apps/honk.nix +++ b/nixos/modules/services/web-apps/honk.nix @@ -1,22 +1,25 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let cfg = config.services.honk; - honk-initdb-script = cfg: pkgs.writeShellApplication { - name = "honk-initdb-script"; + honk-initdb-script = + cfg: + pkgs.writeShellApplication { + name = "honk-initdb-script"; - runtimeInputs = with pkgs; [ coreutils ]; + runtimeInputs = with pkgs; [ coreutils ]; - text = '' - PW=$(cat "$CREDENTIALS_DIRECTORY/honk_passwordFile") + text = '' + PW=$(cat "$CREDENTIALS_DIRECTORY/honk_passwordFile") - echo -e "${cfg.username}\n''$PW\n${cfg.host}:${toString cfg.port}\n${cfg.servername}" | ${lib.getExe cfg.package} -datadir "$STATE_DIRECTORY" init - ''; - }; + echo -e "${cfg.username}\n''$PW\n${cfg.host}:${toString cfg.port}\n${cfg.servername}" | ${lib.getExe cfg.package} -datadir "$STATE_DIRECTORY" init + ''; + }; in { options = { @@ -129,7 +132,9 @@ in preStart = '' mkdir -p $STATE_DIRECTORY/views ${lib.optionalString (cfg.extraJS != null) "ln -fs ${cfg.extraJS} $STATE_DIRECTORY/views/local.js"} - ${lib.optionalString (cfg.extraCSS != null) "ln -fs ${cfg.extraCSS} $STATE_DIRECTORY/views/local.css"} + ${lib.optionalString ( + cfg.extraCSS != null + ) "ln -fs ${cfg.extraCSS} $STATE_DIRECTORY/views/local.css"} ${lib.getExe cfg.package} -datadir $STATE_DIRECTORY -viewdir ${cfg.package}/share/honk backup $STATE_DIRECTORY/backup ${lib.getExe cfg.package} -datadir $STATE_DIRECTORY -viewdir ${cfg.package}/share/honk upgrade ${lib.getExe cfg.package} -datadir $STATE_DIRECTORY -viewdir ${cfg.package}/share/honk cleanup diff --git a/nixos/modules/services/web-apps/icingaweb2/icingaweb2.nix b/nixos/modules/services/web-apps/icingaweb2/icingaweb2.nix index 862ba730abfc58..680257d23b21ab 100644 --- a/nixos/modules/services/web-apps/icingaweb2/icingaweb2.nix +++ b/nixos/modules/services/web-apps/icingaweb2/icingaweb2.nix @@ -1,4 +1,11 @@ -{ config, lib, pkgs, ... }: with lib; let +{ + config, + lib, + pkgs, + ... +}: +with lib; +let cfg = config.services.icingaweb2; fpm = config.services.phpfpm.pools.${poolName}; poolName = "icingaweb2"; @@ -8,7 +15,8 @@ module_path = "${pkgs.icingaweb2}/modules"; }; }; -in { +in +{ meta.maintainers = teams.helsinki-systems.members; options.services.icingaweb2 = with types; { @@ -18,8 +26,8 @@ in { type = str; default = poolName; description = '' - Name of existing PHP-FPM pool that is used to run Icingaweb2. - If not specified, a pool will automatically created with default values. + Name of existing PHP-FPM pool that is used to run Icingaweb2. + If not specified, a pool will automatically created with default values. ''; }; @@ -58,7 +66,7 @@ in { modulePackages = mkOption { type = attrsOf package; - default = {}; + default = { }; example = literalExpression '' { "snow" = icingaweb2Modules.theme-snow; @@ -178,7 +186,11 @@ in { ${poolName} = { user = "icingaweb2"; phpEnv = { - ICINGAWEB_LIBDIR = toString (pkgs.linkFarm "icingaweb2-libdir" (mapAttrsToList (name: path: { inherit name path; }) cfg.libraryPaths)); + ICINGAWEB_LIBDIR = toString ( + pkgs.linkFarm "icingaweb2-libdir" ( + mapAttrsToList (name: path: { inherit name path; }) cfg.libraryPaths + ) + ); }; phpPackage = pkgs.php.withExtensions ({ enabled, all }: [ all.imagick ] ++ enabled); phpOptions = '' @@ -233,11 +245,19 @@ in { }; # /etc/icingaweb2 - environment.etc = let - doModule = name: optionalAttrs (cfg.modules.${name}.enable) { "icingaweb2/enabledModules/${name}".source = "${pkgs.icingaweb2}/modules/${name}"; }; - in {} + environment.etc = + let + doModule = + name: + optionalAttrs (cfg.modules.${name}.enable) { + "icingaweb2/enabledModules/${name}".source = "${pkgs.icingaweb2}/modules/${name}"; + }; + in + { } # Module packages - // (mapAttrs' (k: v: nameValuePair "icingaweb2/enabledModules/${k}" { source = v; }) cfg.modulePackages) + // (mapAttrs' ( + k: v: nameValuePair "icingaweb2/enabledModules/${k}" { source = v; } + ) cfg.modulePackages) # Built-in modules // doModule "doc" // doModule "migrate" @@ -245,14 +265,24 @@ in { // doModule "test" // doModule "translation" # Configs - // optionalAttrs (cfg.generalConfig != null) { "icingaweb2/config.ini".text = generators.toINI {} (defaultConfig // cfg.generalConfig); } - // optionalAttrs (cfg.resources != null) { "icingaweb2/resources.ini".text = generators.toINI {} cfg.resources; } - // optionalAttrs (cfg.authentications != null) { "icingaweb2/authentication.ini".text = generators.toINI {} cfg.authentications; } - // optionalAttrs (cfg.groupBackends != null) { "icingaweb2/groups.ini".text = generators.toINI {} cfg.groupBackends; } - // optionalAttrs (cfg.roles != null) { "icingaweb2/roles.ini".text = generators.toINI {} cfg.roles; }; + // optionalAttrs (cfg.generalConfig != null) { + "icingaweb2/config.ini".text = generators.toINI { } (defaultConfig // cfg.generalConfig); + } + // optionalAttrs (cfg.resources != null) { + "icingaweb2/resources.ini".text = generators.toINI { } cfg.resources; + } + // optionalAttrs (cfg.authentications != null) { + "icingaweb2/authentication.ini".text = generators.toINI { } cfg.authentications; + } + // optionalAttrs (cfg.groupBackends != null) { + "icingaweb2/groups.ini".text = generators.toINI { } cfg.groupBackends; + } + // optionalAttrs (cfg.roles != null) { + "icingaweb2/roles.ini".text = generators.toINI { } cfg.roles; + }; # User and group - users.groups.icingaweb2 = {}; + users.groups.icingaweb2 = { }; users.users.icingaweb2 = { description = "Icingaweb2 service user"; group = "icingaweb2"; diff --git a/nixos/modules/services/web-apps/icingaweb2/module-monitoring.nix b/nixos/modules/services/web-apps/icingaweb2/module-monitoring.nix index e9c1d4ffe5eab8..8ca1d9d071034c 100644 --- a/nixos/modules/services/web-apps/icingaweb2/module-monitoring.nix +++ b/nixos/modules/services/web-apps/icingaweb2/module-monitoring.nix @@ -1,4 +1,11 @@ -{ config, lib, pkgs, ... }: with lib; let +{ + config, + lib, + pkgs, + ... +}: +with lib; +let cfg = config.services.icingaweb2.modules.monitoring; configIni = '' @@ -6,30 +13,37 @@ protected_customvars = "${concatStringsSep "," cfg.generalConfig.protectedVars}" ''; - backendsIni = let - formatBool = b: if b then "1" else "0"; - in concatStringsSep "\n" (mapAttrsToList (name: config: '' - [${name}] - type = "ido" - resource = "${config.resource}" - disabled = "${formatBool config.disabled}" - '') cfg.backends); - - transportsIni = concatStringsSep "\n" (mapAttrsToList (name: config: '' - [${name}] - type = "${config.type}" - ${optionalString (config.instance != null) ''instance = "${config.instance}"''} - ${optionalString (config.type == "local" || config.type == "remote") ''path = "${config.path}"''} - ${optionalString (config.type != "local") '' - host = "${config.host}" - ${optionalString (config.port != null) ''port = "${toString config.port}"''} - user${optionalString (config.type == "api") "name"} = "${config.username}" - ''} - ${optionalString (config.type == "api") ''password = "${config.password}"''} - ${optionalString (config.type == "remote") ''resource = "${config.resource}"''} - '') cfg.transports); - -in { + backendsIni = + let + formatBool = b: if b then "1" else "0"; + in + concatStringsSep "\n" ( + mapAttrsToList (name: config: '' + [${name}] + type = "ido" + resource = "${config.resource}" + disabled = "${formatBool config.disabled}" + '') cfg.backends + ); + + transportsIni = concatStringsSep "\n" ( + mapAttrsToList (name: config: '' + [${name}] + type = "${config.type}" + ${optionalString (config.instance != null) ''instance = "${config.instance}"''} + ${optionalString (config.type == "local" || config.type == "remote") ''path = "${config.path}"''} + ${optionalString (config.type != "local") '' + host = "${config.host}" + ${optionalString (config.port != null) ''port = "${toString config.port}"''} + user${optionalString (config.type == "api") "name"} = "${config.username}" + ''} + ${optionalString (config.type == "api") ''password = "${config.password}"''} + ${optionalString (config.type == "remote") ''resource = "${config.resource}"''} + '') cfg.transports + ); + +in +{ options.services.icingaweb2.modules.monitoring = with types; { enable = mkOption { type = bool; @@ -46,7 +60,11 @@ in { protectedVars = mkOption { type = listOf str; - default = [ "*pw*" "*pass*" "community" ]; + default = [ + "*pw*" + "*pass*" + "community" + ]; description = "List of string patterns for custom variables which should be excluded from user’s view."; }; }; @@ -58,29 +76,38 @@ in { }; backends = mkOption { - default = { icinga = { resource = "icinga_ido"; }; }; - description = "Monitoring backends to define"; - type = attrsOf (submodule ({ name, ... }: { - options = { - name = mkOption { - visible = false; - default = name; - type = str; - description = "Name of this backend"; - }; - - resource = mkOption { - type = str; - description = "Name of the IDO resource"; - }; - - disabled = mkOption { - type = bool; - default = false; - description = "Disable this backend"; - }; + default = { + icinga = { + resource = "icinga_ido"; }; - })); + }; + description = "Monitoring backends to define"; + type = attrsOf ( + submodule ( + { name, ... }: + { + options = { + name = mkOption { + visible = false; + default = name; + type = str; + description = "Name of this backend"; + }; + + resource = mkOption { + type = str; + description = "Name of the IDO resource"; + }; + + disabled = mkOption { + type = bool; + default = false; + description = "Disable this backend"; + }; + }; + } + ) + ); }; mutableTransports = mkOption { @@ -90,68 +117,88 @@ in { }; transports = mkOption { - default = {}; + default = { }; description = "Command transports to define"; - type = attrsOf (submodule ({ name, ... }: { - options = { - name = mkOption { - visible = false; - default = name; - type = str; - description = "Name of this transport"; - }; - - type = mkOption { - type = enum [ "api" "local" "remote" ]; - default = "api"; - description = "Type of this transport"; - }; - - instance = mkOption { - type = nullOr str; - default = null; - description = "Assign a icinga instance to this transport"; - }; - - path = mkOption { - type = str; - description = "Path to the socket for local or remote transports"; - }; - - host = mkOption { - type = str; - description = "Host for the api or remote transport"; - }; - - port = mkOption { - type = nullOr str; - default = null; - description = "Port to connect to for the api or remote transport"; - }; - - username = mkOption { - type = str; - description = "Username for the api or remote transport"; - }; - - password = mkOption { - type = str; - description = "Password for the api transport"; - }; - - resource = mkOption { - type = str; - description = "SSH identity resource for the remote transport"; - }; - }; - })); + type = attrsOf ( + submodule ( + { name, ... }: + { + options = { + name = mkOption { + visible = false; + default = name; + type = str; + description = "Name of this transport"; + }; + + type = mkOption { + type = enum [ + "api" + "local" + "remote" + ]; + default = "api"; + description = "Type of this transport"; + }; + + instance = mkOption { + type = nullOr str; + default = null; + description = "Assign a icinga instance to this transport"; + }; + + path = mkOption { + type = str; + description = "Path to the socket for local or remote transports"; + }; + + host = mkOption { + type = str; + description = "Host for the api or remote transport"; + }; + + port = mkOption { + type = nullOr str; + default = null; + description = "Port to connect to for the api or remote transport"; + }; + + username = mkOption { + type = str; + description = "Username for the api or remote transport"; + }; + + password = mkOption { + type = str; + description = "Password for the api transport"; + }; + + resource = mkOption { + type = str; + description = "SSH identity resource for the remote transport"; + }; + }; + } + ) + ); }; }; config = mkIf (config.services.icingaweb2.enable && cfg.enable) { - environment.etc = { "icingaweb2/enabledModules/monitoring" = { source = "${pkgs.icingaweb2}/modules/monitoring"; }; } - // optionalAttrs (!cfg.generalConfig.mutable) { "icingaweb2/modules/monitoring/config.ini".text = configIni; } - // optionalAttrs (!cfg.mutableBackends) { "icingaweb2/modules/monitoring/backends.ini".text = backendsIni; } - // optionalAttrs (!cfg.mutableTransports) { "icingaweb2/modules/monitoring/commandtransports.ini".text = transportsIni; }; + environment.etc = + { + "icingaweb2/enabledModules/monitoring" = { + source = "${pkgs.icingaweb2}/modules/monitoring"; + }; + } + // optionalAttrs (!cfg.generalConfig.mutable) { + "icingaweb2/modules/monitoring/config.ini".text = configIni; + } + // optionalAttrs (!cfg.mutableBackends) { + "icingaweb2/modules/monitoring/backends.ini".text = backendsIni; + } + // optionalAttrs (!cfg.mutableTransports) { + "icingaweb2/modules/monitoring/commandtransports.ini".text = transportsIni; + }; }; } diff --git a/nixos/modules/services/web-apps/invidious.nix b/nixos/modules/services/web-apps/invidious.nix index e4223cf1e8b127..1429a131e5d139 100644 --- a/nixos/modules/services/web-apps/invidious.nix +++ b/nixos/modules/services/web-apps/invidious.nix @@ -1,4 +1,10 @@ -{ lib, config, pkgs, options, ... }: +{ + lib, + config, + pkgs, + options, + ... +}: let cfg = config.services.invidious; # To allow injecting secrets with jq, json (instead of yaml) is used @@ -30,10 +36,18 @@ let ProtectHome = true; ProtectKernelLogs = true; ProtectProc = "invisible"; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" "~@resources" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "~@resources" + ]; # Because of various issues Invidious must be restarted often, at least once a day, ideally # every hour. @@ -45,7 +59,8 @@ let RuntimeRandomizedExtraSec = lib.mkDefault "5min"; }; }; - mkInvidiousService = scaleIndex: + mkInvidiousService = + scaleIndex: lib.foldl' lib.recursiveUpdate commonInvidousServiceConfig [ # only generate the hmac file in the first service (lib.optionalAttrs (scaleIndex == 0) { @@ -62,76 +77,77 @@ let wants = commonInvidousServiceConfig.wants ++ [ "invidious.service" ]; }) { - script = '' - configParts=() - '' - # autogenerated hmac_key - + lib.optionalString generateHmac '' - configParts+=("$(${pkgs.jq}/bin/jq -R '{"hmac_key":.}' <"${generatedHmacKeyFile}")") - '' - # generated settings file - + '' - configParts+=("$(< ${lib.escapeShellArg settingsFile})") - '' - # optional database password file - + lib.optionalString (cfg.database.host != null) '' - configParts+=("$(${pkgs.jq}/bin/jq -R '{"db":{"password":.}}' ${lib.escapeShellArg cfg.database.passwordFile})") - '' - # optional extra settings file - + lib.optionalString (cfg.extraSettingsFile != null) '' - configParts+=("$(< ${lib.escapeShellArg cfg.extraSettingsFile})") - '' - # explicitly specified hmac key file - + lib.optionalString (cfg.hmacKeyFile != null) '' - configParts+=("$(< ${lib.escapeShellArg cfg.hmacKeyFile})") - '' - # configure threads for secondary instances - + lib.optionalString (scaleIndex > 0) '' - configParts+=('{"channel_threads":0, "feed_threads":0}') - '' - # configure different ports for the instances - + '' - configParts+=('{"port":${toString (cfg.port + scaleIndex)}}') - '' - # merge all parts into a single configuration with later elements overriding previous elements - + '' - export INVIDIOUS_CONFIG="$(${pkgs.jq}/bin/jq -s 'reduce .[] as $item ({}; . * $item)' <<<"''${configParts[*]}")" - exec ${cfg.package}/bin/invidious - ''; + script = + '' + configParts=() + '' + # autogenerated hmac_key + + lib.optionalString generateHmac '' + configParts+=("$(${pkgs.jq}/bin/jq -R '{"hmac_key":.}' <"${generatedHmacKeyFile}")") + '' + # generated settings file + + '' + configParts+=("$(< ${lib.escapeShellArg settingsFile})") + '' + # optional database password file + + lib.optionalString (cfg.database.host != null) '' + configParts+=("$(${pkgs.jq}/bin/jq -R '{"db":{"password":.}}' ${lib.escapeShellArg cfg.database.passwordFile})") + '' + # optional extra settings file + + lib.optionalString (cfg.extraSettingsFile != null) '' + configParts+=("$(< ${lib.escapeShellArg cfg.extraSettingsFile})") + '' + # explicitly specified hmac key file + + lib.optionalString (cfg.hmacKeyFile != null) '' + configParts+=("$(< ${lib.escapeShellArg cfg.hmacKeyFile})") + '' + # configure threads for secondary instances + + lib.optionalString (scaleIndex > 0) '' + configParts+=('{"channel_threads":0, "feed_threads":0}') + '' + # configure different ports for the instances + + '' + configParts+=('{"port":${toString (cfg.port + scaleIndex)}}') + '' + # merge all parts into a single configuration with later elements overriding previous elements + + '' + export INVIDIOUS_CONFIG="$(${pkgs.jq}/bin/jq -s 'reduce .[] as $item ({}; . * $item)' <<<"''${configParts[*]}")" + exec ${cfg.package}/bin/invidious + ''; } ]; serviceConfig = { - systemd.services = builtins.listToAttrs (builtins.genList - (scaleIndex: { + systemd.services = builtins.listToAttrs ( + builtins.genList (scaleIndex: { name = "invidious" + lib.optionalString (scaleIndex > 0) "-${builtins.toString scaleIndex}"; value = mkInvidiousService scaleIndex; - }) - cfg.serviceScale); + }) cfg.serviceScale + ); - services.invidious.settings = { - # Automatically initialises and migrates the database if necessary - check_tables = true; - - db = { - user = lib.mkDefault ( - if (lib.versionAtLeast config.system.stateVersion "24.05") - then "invidious" - else "kemal" - ); - dbname = lib.mkDefault "invidious"; - port = cfg.database.port; - # Blank for unix sockets, see - # https://github.com/will/crystal-pg/blob/1548bb255210/src/pq/conninfo.cr#L100-L108 - host = lib.optionalString (cfg.database.host != null) cfg.database.host; - # Not needed because peer authentication is enabled - password = lib.mkIf (cfg.database.host == null) ""; - }; - - host_binding = cfg.address; - } // (lib.optionalAttrs (cfg.domain != null) { - inherit (cfg) domain; - }); + services.invidious.settings = + { + # Automatically initialises and migrates the database if necessary + check_tables = true; + + db = { + user = lib.mkDefault ( + if (lib.versionAtLeast config.system.stateVersion "24.05") then "invidious" else "kemal" + ); + dbname = lib.mkDefault "invidious"; + port = cfg.database.port; + # Blank for unix sockets, see + # https://github.com/will/crystal-pg/blob/1548bb255210/src/pq/conninfo.cr#L100-L108 + host = lib.optionalString (cfg.database.host != null) cfg.database.host; + # Not needed because peer authentication is enabled + password = lib.mkIf (cfg.database.host == null) ""; + }; + + host_binding = cfg.address; + } + // (lib.optionalAttrs (cfg.domain != null) { + inherit (cfg) domain; + }); assertions = [ { @@ -166,7 +182,10 @@ let services.postgresql = { enable = true; - ensureUsers = lib.singleton { name = cfg.settings.db.user; ensureDBOwnership = true; }; + ensureUsers = lib.singleton { + name = cfg.settings.db.user; + ensureDBOwnership = true; + }; ensureDatabases = lib.singleton cfg.settings.db.dbname; }; }; @@ -227,8 +246,16 @@ let ProtectKernelLogs = true; CapabilityBoundingSet = ""; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" "~@resources" "@network-io" ]; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "~@resources" + "@network-io" + ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; }; }; @@ -240,34 +267,35 @@ let external_port = 80; }; - services.nginx = let - ip = if cfg.address == "0.0.0.0" then "127.0.0.1" else cfg.address; - in - { - enable = true; - virtualHosts.${cfg.domain} = { - locations."/".proxyPass = - if cfg.serviceScale == 1 then - "http://${ip}:${toString cfg.port}" - else "http://upstream-invidious"; - - enableACME = lib.mkDefault true; - forceSSL = lib.mkDefault true; - }; - upstreams = lib.mkIf (cfg.serviceScale > 1) { - "upstream-invidious".servers = builtins.listToAttrs (builtins.genList - (scaleIndex: { - name = "${ip}:${toString (cfg.port + scaleIndex)}"; - value = { }; - }) - cfg.serviceScale); + services.nginx = + let + ip = if cfg.address == "0.0.0.0" then "127.0.0.1" else cfg.address; + in + { + enable = true; + virtualHosts.${cfg.domain} = { + locations."/".proxyPass = + if cfg.serviceScale == 1 then "http://${ip}:${toString cfg.port}" else "http://upstream-invidious"; + + enableACME = lib.mkDefault true; + forceSSL = lib.mkDefault true; + }; + upstreams = lib.mkIf (cfg.serviceScale > 1) { + "upstream-invidious".servers = builtins.listToAttrs ( + builtins.genList (scaleIndex: { + name = "${ip}:${toString (cfg.port + scaleIndex)}"; + value = { }; + }) cfg.serviceScale + ); + }; }; - }; - assertions = [{ - assertion = cfg.domain != null; - message = "To use services.invidious.nginx, you need to set services.invidious.domain"; - }]; + assertions = [ + { + assertion = cfg.domain != null; + message = "To use services.invidious.nginx, you need to set services.invidious.domain"; + } + ]; }; in { @@ -453,11 +481,13 @@ in }; }; - config = lib.mkIf cfg.enable (lib.mkMerge [ - serviceConfig - localDatabaseConfig - nginxConfig - ytproxyConfig - sigHelperConfig - ]); + config = lib.mkIf cfg.enable ( + lib.mkMerge [ + serviceConfig + localDatabaseConfig + nginxConfig + ytproxyConfig + sigHelperConfig + ] + ); } diff --git a/nixos/modules/services/web-apps/invoiceplane.nix b/nixos/modules/services/web-apps/invoiceplane.nix index 3b0a1773066457..8904c41beea7ee 100644 --- a/nixos/modules/services/web-apps/invoiceplane.nix +++ b/nixos/modules/services/web-apps/invoiceplane.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -8,72 +13,91 @@ let user = "invoiceplane"; webserver = config.services.${cfg.webserver}; - invoiceplane-config = hostName: cfg: pkgs.writeText "ipconfig.php" '' - IP_URL=http://${hostName} - ENABLE_DEBUG=false - DISABLE_SETUP=false - REMOVE_INDEXPHP=false - DB_HOSTNAME=${cfg.database.host} - DB_USERNAME=${cfg.database.user} - # NOTE: file_get_contents adds newline at the end of returned string - DB_PASSWORD=${optionalString (cfg.database.passwordFile != null) "trim(file_get_contents('${cfg.database.passwordFile}'), \"\\r\\n\")"} - DB_DATABASE=${cfg.database.name} - DB_PORT=${toString cfg.database.port} - SESS_EXPIRATION=864000 - ENABLE_INVOICE_DELETION=false - DISABLE_READ_ONLY=false - ENCRYPTION_KEY= - ENCRYPTION_CIPHER=AES-256 - SETUP_COMPLETED=false - REMOVE_INDEXPHP=true - ''; - - mkPhpValue = v: - if isString v then escapeShellArg v - # NOTE: If any value contains a , (comma) this will not get escaped - else if isList v && strings.isConvertibleWithToString v then escapeShellArg (concatMapStringsSep "," toString v) - else if isInt v then toString v - else if isBool v then boolToString v - else abort "The Invoiceplane config value ${lib.generators.toPretty {} v} can not be encoded." - ; - - extraConfig = hostName: cfg: let - settings = mapAttrsToList (k: v: "${k}=${mkPhpValue v}") cfg.settings; - in pkgs.writeText "extraConfig.php" (concatStringsSep "\n" settings); - - pkg = hostName: cfg: pkgs.stdenv.mkDerivation rec { - pname = "invoiceplane-${hostName}"; - version = src.version; - src = pkgs.invoiceplane; - - postPatch = '' - # Patch index.php file to load additional config file - substituteInPlace index.php \ - --replace-fail "require('vendor/autoload.php');" "require('vendor/autoload.php'); \$dotenv = Dotenv\Dotenv::createImmutable(__DIR__, 'extraConfig.php'); \$dotenv->load();"; + invoiceplane-config = + hostName: cfg: + pkgs.writeText "ipconfig.php" '' + IP_URL=http://${hostName} + ENABLE_DEBUG=false + DISABLE_SETUP=false + REMOVE_INDEXPHP=false + DB_HOSTNAME=${cfg.database.host} + DB_USERNAME=${cfg.database.user} + # NOTE: file_get_contents adds newline at the end of returned string + DB_PASSWORD=${ + optionalString ( + cfg.database.passwordFile != null + ) "trim(file_get_contents('${cfg.database.passwordFile}'), \"\\r\\n\")" + } + DB_DATABASE=${cfg.database.name} + DB_PORT=${toString cfg.database.port} + SESS_EXPIRATION=864000 + ENABLE_INVOICE_DELETION=false + DISABLE_READ_ONLY=false + ENCRYPTION_KEY= + ENCRYPTION_CIPHER=AES-256 + SETUP_COMPLETED=false + REMOVE_INDEXPHP=true ''; - installPhase = '' - mkdir -p $out - cp -r * $out/ - - # symlink uploads and log directories - rm -r $out/uploads $out/application/logs $out/vendor/mpdf/mpdf/tmp - ln -sf ${cfg.stateDir}/uploads $out/ - ln -sf ${cfg.stateDir}/logs $out/application/ - ln -sf ${cfg.stateDir}/tmp $out/vendor/mpdf/mpdf/ - - # symlink the InvoicePlane config - ln -s ${cfg.stateDir}/ipconfig.php $out/ipconfig.php - - # symlink the extraConfig file - ln -s ${extraConfig hostName cfg} $out/extraConfig.php - - # symlink additional templates - ${concatMapStringsSep "\n" (template: "cp -r ${template}/. $out/application/views/invoice_templates/pdf/") cfg.invoiceTemplates} - ''; - }; + mkPhpValue = + v: + if isString v then + escapeShellArg v + # NOTE: If any value contains a , (comma) this will not get escaped + else if isList v && strings.isConvertibleWithToString v then + escapeShellArg (concatMapStringsSep "," toString v) + else if isInt v then + toString v + else if isBool v then + boolToString v + else + abort "The Invoiceplane config value ${lib.generators.toPretty { } v} can not be encoded."; + + extraConfig = + hostName: cfg: + let + settings = mapAttrsToList (k: v: "${k}=${mkPhpValue v}") cfg.settings; + in + pkgs.writeText "extraConfig.php" (concatStringsSep "\n" settings); + + pkg = + hostName: cfg: + pkgs.stdenv.mkDerivation rec { + pname = "invoiceplane-${hostName}"; + version = src.version; + src = pkgs.invoiceplane; + + postPatch = '' + # Patch index.php file to load additional config file + substituteInPlace index.php \ + --replace-fail "require('vendor/autoload.php');" "require('vendor/autoload.php'); \$dotenv = Dotenv\Dotenv::createImmutable(__DIR__, 'extraConfig.php'); \$dotenv->load();"; + ''; + + installPhase = '' + mkdir -p $out + cp -r * $out/ + + # symlink uploads and log directories + rm -r $out/uploads $out/application/logs $out/vendor/mpdf/mpdf/tmp + ln -sf ${cfg.stateDir}/uploads $out/ + ln -sf ${cfg.stateDir}/logs $out/application/ + ln -sf ${cfg.stateDir}/tmp $out/vendor/mpdf/mpdf/ + + # symlink the InvoicePlane config + ln -s ${cfg.stateDir}/ipconfig.php $out/ipconfig.php + + # symlink the extraConfig file + ln -s ${extraConfig hostName cfg} $out/extraConfig.php + + # symlink additional templates + ${concatMapStringsSep "\n" ( + template: "cp -r ${template}/. $out/application/views/invoice_templates/pdf/" + ) cfg.invoiceTemplates} + ''; + }; - siteOpts = { lib, name, ... }: + siteOpts = + { lib, name, ... }: { options = { @@ -133,7 +157,7 @@ let invoiceTemplates = mkOption { type = types.listOf types.path; - default = []; + default = [ ]; description = '' List of path(s) to respective template(s) which are copied from the 'invoice_templates/pdf' directory. @@ -164,7 +188,13 @@ let }; poolConfig = mkOption { - type = with types; attrsOf (oneOf [ str int bool ]); + type = + with types; + attrsOf (oneOf [ + str + int + bool + ]); default = { "pm" = "dynamic"; "pm.max_children" = 32; @@ -181,7 +211,7 @@ let settings = mkOption { type = types.attrsOf types.anything; - default = {}; + default = { }; description = '' Structural InvoicePlane configuration. Refer to @@ -225,12 +255,15 @@ in options.sites = mkOption { type = types.attrsOf (types.submodule siteOpts); - default = {}; + default = { }; description = "Specification of one or more InvoicePlane sites to serve"; }; options.webserver = mkOption { - type = types.enum [ "caddy" "nginx" ]; + type = types.enum [ + "caddy" + "nginx" + ]; default = "caddy"; example = "nginx"; description = '' @@ -238,163 +271,181 @@ in ''; }; }; - default = {}; + default = { }; description = "InvoicePlane configuration."; }; }; # implementation - config = mkIf (eachSite != {}) (mkMerge [{ + config = mkIf (eachSite != { }) (mkMerge [ + { - assertions = flatten (mapAttrsToList (hostName: cfg: [ - { assertion = cfg.database.createLocally -> cfg.database.user == user; - message = ''services.invoiceplane.sites."${hostName}".database.user must be ${user} if the database is to be automatically provisioned''; - } - { assertion = cfg.database.createLocally -> cfg.database.passwordFile == null; - message = ''services.invoiceplane.sites."${hostName}".database.passwordFile cannot be specified if services.invoiceplane.sites."${hostName}".database.createLocally is set to true.''; - } - { assertion = cfg.cron.enable -> cfg.cron.key != null; - message = ''services.invoiceplane.sites."${hostName}".cron.key must be set in order to use cron service.''; - } - ]) eachSite); - - services.mysql = mkIf (any (v: v.database.createLocally) (attrValues eachSite)) { - enable = true; - package = mkDefault pkgs.mariadb; - ensureDatabases = mapAttrsToList (hostName: cfg: cfg.database.name) eachSite; - ensureUsers = mapAttrsToList (hostName: cfg: - { name = cfg.database.user; - ensurePermissions = { "${cfg.database.name}.*" = "ALL PRIVILEGES"; }; - } - ) eachSite; - }; + assertions = flatten ( + mapAttrsToList (hostName: cfg: [ + { + assertion = cfg.database.createLocally -> cfg.database.user == user; + message = ''services.invoiceplane.sites."${hostName}".database.user must be ${user} if the database is to be automatically provisioned''; + } + { + assertion = cfg.database.createLocally -> cfg.database.passwordFile == null; + message = ''services.invoiceplane.sites."${hostName}".database.passwordFile cannot be specified if services.invoiceplane.sites."${hostName}".database.createLocally is set to true.''; + } + { + assertion = cfg.cron.enable -> cfg.cron.key != null; + message = ''services.invoiceplane.sites."${hostName}".cron.key must be set in order to use cron service.''; + } + ]) eachSite + ); + + services.mysql = mkIf (any (v: v.database.createLocally) (attrValues eachSite)) { + enable = true; + package = mkDefault pkgs.mariadb; + ensureDatabases = mapAttrsToList (hostName: cfg: cfg.database.name) eachSite; + ensureUsers = mapAttrsToList (hostName: cfg: { + name = cfg.database.user; + ensurePermissions = { + "${cfg.database.name}.*" = "ALL PRIVILEGES"; + }; + }) eachSite; + }; - services.phpfpm = { - phpPackage = pkgs.php81; - pools = mapAttrs' (hostName: cfg: ( - nameValuePair "invoiceplane-${hostName}" { - inherit user; - group = webserver.group; - settings = { - "listen.owner" = webserver.user; - "listen.group" = webserver.group; - } // cfg.poolConfig; - } - )) eachSite; - }; + services.phpfpm = { + phpPackage = pkgs.php81; + pools = mapAttrs' ( + hostName: cfg: + (nameValuePair "invoiceplane-${hostName}" { + inherit user; + group = webserver.group; + settings = { + "listen.owner" = webserver.user; + "listen.group" = webserver.group; + } // cfg.poolConfig; + }) + ) eachSite; + }; - } - - { - - systemd.tmpfiles.rules = flatten (mapAttrsToList (hostName: cfg: [ - "d ${cfg.stateDir} 0750 ${user} ${webserver.group} - -" - "f ${cfg.stateDir}/ipconfig.php 0750 ${user} ${webserver.group} - -" - "d ${cfg.stateDir}/logs 0750 ${user} ${webserver.group} - -" - "d ${cfg.stateDir}/uploads 0750 ${user} ${webserver.group} - -" - "d ${cfg.stateDir}/uploads/archive 0750 ${user} ${webserver.group} - -" - "d ${cfg.stateDir}/uploads/customer_files 0750 ${user} ${webserver.group} - -" - "d ${cfg.stateDir}/uploads/temp 0750 ${user} ${webserver.group} - -" - "d ${cfg.stateDir}/uploads/temp/mpdf 0750 ${user} ${webserver.group} - -" - "d ${cfg.stateDir}/tmp 0750 ${user} ${webserver.group} - -" - ]) eachSite); - - systemd.services.invoiceplane-config = { - serviceConfig.Type = "oneshot"; - script = concatStrings (mapAttrsToList (hostName: cfg: - '' - mkdir -p ${cfg.stateDir}/logs \ - ${cfg.stateDir}/uploads - if ! grep -q IP_URL "${cfg.stateDir}/ipconfig.php"; then - cp "${invoiceplane-config hostName cfg}" "${cfg.stateDir}/ipconfig.php" - fi - '') eachSite); - wantedBy = [ "multi-user.target" ]; - }; + } - users.users.${user} = { - group = webserver.group; - isSystemUser = true; - }; + { - } - { + systemd.tmpfiles.rules = flatten ( + mapAttrsToList (hostName: cfg: [ + "d ${cfg.stateDir} 0750 ${user} ${webserver.group} - -" + "f ${cfg.stateDir}/ipconfig.php 0750 ${user} ${webserver.group} - -" + "d ${cfg.stateDir}/logs 0750 ${user} ${webserver.group} - -" + "d ${cfg.stateDir}/uploads 0750 ${user} ${webserver.group} - -" + "d ${cfg.stateDir}/uploads/archive 0750 ${user} ${webserver.group} - -" + "d ${cfg.stateDir}/uploads/customer_files 0750 ${user} ${webserver.group} - -" + "d ${cfg.stateDir}/uploads/temp 0750 ${user} ${webserver.group} - -" + "d ${cfg.stateDir}/uploads/temp/mpdf 0750 ${user} ${webserver.group} - -" + "d ${cfg.stateDir}/tmp 0750 ${user} ${webserver.group} - -" + ]) eachSite + ); + + systemd.services.invoiceplane-config = { + serviceConfig.Type = "oneshot"; + script = concatStrings ( + mapAttrsToList (hostName: cfg: '' + mkdir -p ${cfg.stateDir}/logs \ + ${cfg.stateDir}/uploads + if ! grep -q IP_URL "${cfg.stateDir}/ipconfig.php"; then + cp "${invoiceplane-config hostName cfg}" "${cfg.stateDir}/ipconfig.php" + fi + '') eachSite + ); + wantedBy = [ "multi-user.target" ]; + }; - # Cron service implementation + users.users.${user} = { + group = webserver.group; + isSystemUser = true; + }; - systemd.timers = mapAttrs' (hostName: cfg: ( - nameValuePair "invoiceplane-cron-${hostName}" (mkIf cfg.cron.enable { - wantedBy = [ "timers.target" ]; - timerConfig = { - OnBootSec = "5m"; - OnUnitActiveSec = "5m"; - Unit = "invoiceplane-cron-${hostName}.service"; - }; - }) - )) eachSite; - - systemd.services = - mapAttrs' (hostName: cfg: ( - nameValuePair "invoiceplane-cron-${hostName}" (mkIf cfg.cron.enable { - serviceConfig = { - Type = "oneshot"; - User = user; - ExecStart = "${pkgs.curl}/bin/curl --header 'Host: ${hostName}' http://localhost/invoices/cron/recur/${cfg.cron.key}"; - }; - }) - )) eachSite; - - } - - (mkIf (cfg.webserver == "caddy") { - services.caddy = { - enable = true; - virtualHosts = mapAttrs' (hostName: cfg: ( - nameValuePair "http://${hostName}" { - extraConfig = '' - root * ${pkg hostName cfg} - file_server - php_fastcgi unix/${config.services.phpfpm.pools."invoiceplane-${hostName}".socket} - ''; - } - )) eachSite; - }; - }) - - (mkIf (cfg.webserver == "nginx") { - services.nginx = { - enable = true; - virtualHosts = mapAttrs' (hostName: cfg: ( - nameValuePair hostName { - root = pkg hostName cfg; - extraConfig = '' - index index.php index.html index.htm; - - if (!-e $request_filename){ - rewrite ^(.*)$ /index.php break; - } - ''; + } + { - locations = { - "/setup".extraConfig = '' - rewrite ^(.*)$ http://${hostName}/ redirect; + # Cron service implementation + + systemd.timers = mapAttrs' ( + hostName: cfg: + (nameValuePair "invoiceplane-cron-${hostName}" ( + mkIf cfg.cron.enable { + wantedBy = [ "timers.target" ]; + timerConfig = { + OnBootSec = "5m"; + OnUnitActiveSec = "5m"; + Unit = "invoiceplane-cron-${hostName}.service"; + }; + } + )) + ) eachSite; + + systemd.services = mapAttrs' ( + hostName: cfg: + (nameValuePair "invoiceplane-cron-${hostName}" ( + mkIf cfg.cron.enable { + serviceConfig = { + Type = "oneshot"; + User = user; + ExecStart = "${pkgs.curl}/bin/curl --header 'Host: ${hostName}' http://localhost/invoices/cron/recur/${cfg.cron.key}"; + }; + } + )) + ) eachSite; + + } + + (mkIf (cfg.webserver == "caddy") { + services.caddy = { + enable = true; + virtualHosts = mapAttrs' ( + hostName: cfg: + (nameValuePair "http://${hostName}" { + extraConfig = '' + root * ${pkg hostName cfg} + file_server + php_fastcgi unix/${config.services.phpfpm.pools."invoiceplane-${hostName}".socket} + ''; + }) + ) eachSite; + }; + }) + + (mkIf (cfg.webserver == "nginx") { + services.nginx = { + enable = true; + virtualHosts = mapAttrs' ( + hostName: cfg: + (nameValuePair hostName { + root = pkg hostName cfg; + extraConfig = '' + index index.php index.html index.htm; + + if (!-e $request_filename){ + rewrite ^(.*)$ /index.php break; + } ''; - "~ .php$" = { - extraConfig = '' - fastcgi_split_path_info ^(.+\.php)(/.+)$; - fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; - fastcgi_pass unix:${config.services.phpfpm.pools."invoiceplane-${hostName}".socket}; - include ${config.services.nginx.package}/conf/fastcgi_params; - include ${config.services.nginx.package}/conf/fastcgi.conf; + locations = { + "/setup".extraConfig = '' + rewrite ^(.*)$ http://${hostName}/ redirect; ''; + + "~ .php$" = { + extraConfig = '' + fastcgi_split_path_info ^(.+\.php)(/.+)$; + fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; + fastcgi_pass unix:${config.services.phpfpm.pools."invoiceplane-${hostName}".socket}; + include ${config.services.nginx.package}/conf/fastcgi_params; + include ${config.services.nginx.package}/conf/fastcgi.conf; + ''; + }; }; - }; - } - )) eachSite; - }; - }) + }) + ) eachSite; + }; + }) ]); } diff --git a/nixos/modules/services/web-apps/isso.nix b/nixos/modules/services/web-apps/isso.nix index 4e7785d1eb3e37..87804b7ea7cfae 100644 --- a/nixos/modules/services/web-apps/isso.nix +++ b/nixos/modules/services/web-apps/isso.nix @@ -1,13 +1,25 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkIf mkOption types literalExpression; + inherit (lib) + mkEnableOption + mkIf + mkOption + types + literalExpression + ; cfg = config.services.isso; settingsFormat = pkgs.formats.ini { }; configFile = settingsFormat.generate "isso.conf" cfg.settings; -in { +in +{ options = { services.isso = { @@ -79,11 +91,18 @@ in { ProtectKernelModules = true; ProtectKernelTunables = true; ProtectProc = "invisible"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" "~@resources" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "~@resources" + ]; UMask = "0077"; }; }; diff --git a/nixos/modules/services/web-apps/jitsi-meet.nix b/nixos/modules/services/web-apps/jitsi-meet.nix index f880691b55e9c9..aecddd814d9a81 100644 --- a/nixos/modules/services/web-apps/jitsi-meet.nix +++ b/nixos/modules/services/web-apps/jitsi-meet.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -17,7 +22,8 @@ let process.stdout.write(JSON.stringify(eval(process.argv[3]))); ''; userJson = pkgs.writeText "user.json" (builtins.toJSON userCfg); - in (pkgs.runCommand "${varName}.js" { } '' + in + (pkgs.runCommand "${varName}.js" { } '' ${pkgs.nodejs}/bin/node ${extractor} ${source} ${varName} > default.json ( echo "var ${varName} = " @@ -229,7 +235,7 @@ in proxy65 = mkIf cfg.prosody.lockdown (mkDefault false); }; httpInterfaces = mkIf cfg.prosody.lockdown (mkDefault [ "127.0.0.1" ]); - httpsPorts = mkIf cfg.prosody.lockdown (mkDefault []); + httpsPorts = mkIf cfg.prosody.lockdown (mkDefault [ ]); muc = [ { domain = "conference.${cfg.hostName}"; @@ -318,26 +324,31 @@ in muc_component = "conference.${cfg.hostName}" breakout_rooms_component = "breakout.${cfg.hostName}" '') - (mkBefore ('' - muc_mapper_domain_base = "${cfg.hostName}" - - cross_domain_websocket = true; - consider_websocket_secure = true; - - unlimited_jids = { - "focus@auth.${cfg.hostName}", - "jvb@auth.${cfg.hostName}" - } - '' + optionalString cfg.prosody.lockdown '' - c2s_interfaces = { "127.0.0.1" }; - modules_disabled = { "s2s" }; - '')) + (mkBefore ( + '' + muc_mapper_domain_base = "${cfg.hostName}" + + cross_domain_websocket = true; + consider_websocket_secure = true; + + unlimited_jids = { + "focus@auth.${cfg.hostName}", + "jvb@auth.${cfg.hostName}" + } + '' + + optionalString cfg.prosody.lockdown '' + c2s_interfaces = { "127.0.0.1" }; + modules_disabled = { "s2s" }; + '' + )) ]; virtualHosts.${cfg.hostName} = { enabled = true; domain = cfg.hostName; extraConfig = '' - authentication = ${if cfg.secureDomain.enable then "\"${cfg.secureDomain.authentication}\"" else "\"jitsi-anonymous\""} + authentication = ${ + if cfg.secureDomain.enable then "\"${cfg.secureDomain.authentication}\"" else "\"jitsi-anonymous\"" + } c2s_require_encryption = false admins = { "focus@auth.${cfg.hostName}" } smacks_max_unacked_stanzas = 5 @@ -390,17 +401,24 @@ in }; }; systemd.services.prosody = mkIf cfg.prosody.enable { - preStart = let - videobridgeSecret = if cfg.videobridge.passwordFile != null then cfg.videobridge.passwordFile else "/var/lib/jitsi-meet/videobridge-secret"; - in '' - ${config.services.prosody.package}/bin/prosodyctl register focus auth.${cfg.hostName} "$(cat /var/lib/jitsi-meet/jicofo-user-secret)" - ${config.services.prosody.package}/bin/prosodyctl register jvb auth.${cfg.hostName} "$(cat ${videobridgeSecret})" - ${config.services.prosody.package}/bin/prosodyctl mod_roster_command subscribe focus.${cfg.hostName} focus@auth.${cfg.hostName} - ${config.services.prosody.package}/bin/prosodyctl register jibri auth.${cfg.hostName} "$(cat /var/lib/jitsi-meet/jibri-auth-secret)" - ${config.services.prosody.package}/bin/prosodyctl register recorder recorder.${cfg.hostName} "$(cat /var/lib/jitsi-meet/jibri-recorder-secret)" - '' + optionalString cfg.jigasi.enable '' - ${config.services.prosody.package}/bin/prosodyctl register jigasi auth.${cfg.hostName} "$(cat /var/lib/jitsi-meet/jigasi-user-secret)" - ''; + preStart = + let + videobridgeSecret = + if cfg.videobridge.passwordFile != null then + cfg.videobridge.passwordFile + else + "/var/lib/jitsi-meet/videobridge-secret"; + in + '' + ${config.services.prosody.package}/bin/prosodyctl register focus auth.${cfg.hostName} "$(cat /var/lib/jitsi-meet/jicofo-user-secret)" + ${config.services.prosody.package}/bin/prosodyctl register jvb auth.${cfg.hostName} "$(cat ${videobridgeSecret})" + ${config.services.prosody.package}/bin/prosodyctl mod_roster_command subscribe focus.${cfg.hostName} focus@auth.${cfg.hostName} + ${config.services.prosody.package}/bin/prosodyctl register jibri auth.${cfg.hostName} "$(cat /var/lib/jitsi-meet/jibri-auth-secret)" + ${config.services.prosody.package}/bin/prosodyctl register recorder recorder.${cfg.hostName} "$(cat /var/lib/jitsi-meet/jibri-recorder-secret)" + '' + + optionalString cfg.jigasi.enable '' + ${config.services.prosody.package}/bin/prosodyctl register jigasi auth.${cfg.hostName} "$(cat /var/lib/jitsi-meet/jigasi-user-secret)" + ''; serviceConfig = { EnvironmentFile = [ "/var/lib/jitsi-meet/secrets-env" ]; @@ -416,7 +434,13 @@ in systemd.services.jitsi-meet-init-secrets = { wantedBy = [ "multi-user.target" ]; - before = [ "jicofo.service" "jitsi-videobridge2.service" ] ++ (optional cfg.prosody.enable "prosody.service") ++ (optional cfg.jigasi.enable "jigasi.service"); + before = + [ + "jicofo.service" + "jitsi-videobridge2.service" + ] + ++ (optional cfg.prosody.enable "prosody.service") + ++ (optional cfg.jigasi.enable "jigasi.service"); serviceConfig = { Type = "oneshot"; UMask = "027"; @@ -425,34 +449,46 @@ in WorkingDirectory = "/var/lib/jitsi-meet"; }; - script = let - secrets = [ "jicofo-component-secret" "jicofo-user-secret" "jibri-auth-secret" "jibri-recorder-secret" ] ++ (optionals cfg.jigasi.enable [ "jigasi-user-secret" "jigasi-component-secret" ]) ++ (optional (cfg.videobridge.passwordFile == null) "videobridge-secret"); - in - '' - ${concatMapStringsSep "\n" (s: '' - if [ ! -f ${s} ]; then - tr -dc a-zA-Z0-9 ${s} + script = + let + secrets = + [ + "jicofo-component-secret" + "jicofo-user-secret" + "jibri-auth-secret" + "jibri-recorder-secret" + ] + ++ (optionals cfg.jigasi.enable [ + "jigasi-user-secret" + "jigasi-component-secret" + ]) + ++ (optional (cfg.videobridge.passwordFile == null) "videobridge-secret"); + in + '' + ${concatMapStringsSep "\n" (s: '' + if [ ! -f ${s} ]; then + tr -dc a-zA-Z0-9 ${s} + fi + '') secrets} + + # for easy access in prosody + echo "JICOFO_COMPONENT_SECRET=$(cat jicofo-component-secret)" > secrets-env + echo "JIGASI_COMPONENT_SECRET=$(cat jigasi-component-secret)" >> secrets-env + '' + + optionalString cfg.prosody.enable '' + # generate self-signed certificates + if [ ! -f /var/lib/jitsi-meet/jitsi-meet.crt ]; then + ${getBin pkgs.openssl}/bin/openssl req \ + -x509 \ + -newkey rsa:4096 \ + -keyout /var/lib/jitsi-meet/jitsi-meet.key \ + -out /var/lib/jitsi-meet/jitsi-meet.crt \ + -days 36500 \ + -nodes \ + -subj '/CN=${cfg.hostName}/CN=auth.${cfg.hostName}' + chmod 640 /var/lib/jitsi-meet/jitsi-meet.key fi - '') secrets} - - # for easy access in prosody - echo "JICOFO_COMPONENT_SECRET=$(cat jicofo-component-secret)" > secrets-env - echo "JIGASI_COMPONENT_SECRET=$(cat jigasi-component-secret)" >> secrets-env - '' - + optionalString cfg.prosody.enable '' - # generate self-signed certificates - if [ ! -f /var/lib/jitsi-meet/jitsi-meet.crt ]; then - ${getBin pkgs.openssl}/bin/openssl req \ - -x509 \ - -newkey rsa:4096 \ - -keyout /var/lib/jitsi-meet/jitsi-meet.key \ - -out /var/lib/jitsi-meet/jitsi-meet.crt \ - -days 36500 \ - -nodes \ - -subj '/CN=${cfg.hostName}/CN=auth.${cfg.hostName}' - chmod 640 /var/lib/jitsi-meet/jitsi-meet.key - fi - ''; + ''; }; systemd.services.jitsi-excalidraw = mkIf cfg.excalidraw.enable { @@ -482,12 +518,18 @@ in ProtectKernelTunables = true; ProtectKernelModules = true; ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; LockPersonality = true; RestrictRealtime = true; RestrictSUIDSGID = true; - SystemCallFilter = [ "@system-service @pkey" "~@privileged" ]; + SystemCallFilter = [ + "@system-service @pkey" + "~@privileged" + ]; }; }; @@ -527,10 +569,14 @@ in ''; }; locations."=/config.js" = mkDefault { - alias = overrideJs "${pkgs.jitsi-meet}/config.js" "config" (recursiveUpdate defaultCfg cfg.config) cfg.extraConfig; + alias = + overrideJs "${pkgs.jitsi-meet}/config.js" "config" (recursiveUpdate defaultCfg cfg.config) + cfg.extraConfig; }; locations."=/interface_config.js" = mkDefault { - alias = overrideJs "${pkgs.jitsi-meet}/interface_config.js" "interfaceConfig" cfg.interfaceConfig ""; + alias = + overrideJs "${pkgs.jitsi-meet}/interface_config.js" "interfaceConfig" cfg.interfaceConfig + ""; }; locations."/socket.io/" = mkIf cfg.excalidraw.enable { proxyPass = "http://127.0.0.1:${toString cfg.excalidraw.port}"; @@ -543,52 +589,62 @@ in enable = mkDefault true; virtualHosts.${cfg.hostName} = { extraConfig = - let - templatedJitsiMeet = pkgs.runCommand "templated-jitsi-meet" { } '' - cp -R --no-preserve=all ${pkgs.jitsi-meet}/* . - for file in *.html **/*.html ; do - ${pkgs.sd}/bin/sd '' '{{ include "$1" }}' $file - done - rm config.js - rm interface_config.js - cp -R . $out - cp ${overrideJs "${pkgs.jitsi-meet}/config.js" "config" (recursiveUpdate defaultCfg cfg.config) cfg.extraConfig} $out/config.js - cp ${overrideJs "${pkgs.jitsi-meet}/interface_config.js" "interfaceConfig" cfg.interfaceConfig ""} $out/interface_config.js - cp ./libs/external_api.min.js $out/external_api.js + let + templatedJitsiMeet = pkgs.runCommand "templated-jitsi-meet" { } '' + cp -R --no-preserve=all ${pkgs.jitsi-meet}/* . + for file in *.html **/*.html ; do + ${pkgs.sd}/bin/sd '' '{{ include "$1" }}' $file + done + rm config.js + rm interface_config.js + cp -R . $out + cp ${ + overrideJs "${pkgs.jitsi-meet}/config.js" "config" (recursiveUpdate defaultCfg cfg.config) + cfg.extraConfig + } $out/config.js + cp ${ + overrideJs "${pkgs.jitsi-meet}/interface_config.js" "interfaceConfig" cfg.interfaceConfig "" + } $out/interface_config.js + cp ./libs/external_api.min.js $out/external_api.js + ''; + in + (optionalString cfg.excalidraw.enable '' + handle /socket.io/ { + reverse_proxy 127.0.0.1:${toString cfg.excalidraw.port} + } + '') + + '' + handle /http-bind { + header Host ${cfg.hostName} + reverse_proxy 127.0.0.1:5280 + } + handle /xmpp-websocket { + reverse_proxy 127.0.0.1:5280 + } + handle { + templates + root * ${templatedJitsiMeet} + try_files {path} {path} + try_files {path} /index.html + file_server + } ''; - in (optionalString cfg.excalidraw.enable '' - handle /socket.io/ { - reverse_proxy 127.0.0.1:${toString cfg.excalidraw.port} - } - '') + '' - handle /http-bind { - header Host ${cfg.hostName} - reverse_proxy 127.0.0.1:5280 - } - handle /xmpp-websocket { - reverse_proxy 127.0.0.1:5280 - } - handle { - templates - root * ${templatedJitsiMeet} - try_files {path} {path} - try_files {path} /index.html - file_server - } - ''; }; }; - services.jitsi-meet.config = recursiveUpdate - (mkIf cfg.excalidraw.enable { - whiteboard = { - enabled = true; - collabServerBaseUrl = "https://${cfg.hostName}"; - }; - }) - (mkIf cfg.secureDomain.enable { - hosts.anonymousdomain = "guest.${cfg.hostName}"; - }); + services.jitsi-meet.config = + recursiveUpdate + (mkIf cfg.excalidraw.enable { + whiteboard = { + enabled = true; + collabServerBaseUrl = "https://${cfg.hostName}"; + }; + }) + ( + mkIf cfg.secureDomain.enable { + hosts.anonymousdomain = "guest.${cfg.hostName}"; + } + ); services.jitsi-videobridge = mkIf cfg.videobridge.enable { enable = true; @@ -610,10 +666,11 @@ in userPasswordFile = "/var/lib/jitsi-meet/jicofo-user-secret"; componentPasswordFile = "/var/lib/jitsi-meet/jicofo-component-secret"; bridgeMuc = "jvbbrewery@internal.auth.${cfg.hostName}"; - config = mkMerge [{ - jicofo.xmpp.service.disable-certificate-verification = true; - jicofo.xmpp.client.disable-certificate-verification = true; - } + config = mkMerge [ + { + jicofo.xmpp.service.disable-certificate-verification = true; + jicofo.xmpp.client.disable-certificate-verification = true; + } (lib.mkIf (config.services.jibri.enable || cfg.jibri.enable) { jicofo.jibri = { brewery-jid = "JibriBrewery@internal.auth.${cfg.hostName}"; @@ -629,7 +686,8 @@ in }; xmpp.client.client-proxy = "focus.${cfg.hostName}"; }; - })]; + }) + ]; }; services.jibri = mkIf cfg.jibri.enable { diff --git a/nixos/modules/services/web-apps/kasmweb/default.nix b/nixos/modules/services/web-apps/kasmweb/default.nix index f626e369334edb..9cb64a1495d5d4 100644 --- a/nixos/modules/services/web-apps/kasmweb/default.nix +++ b/nixos/modules/services/web-apps/kasmweb/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.kasmweb; @@ -130,15 +135,20 @@ in "docker-kasm_db.service" "podman-kasm_db.service" ]; - wants = ["network-online.target"]; - after = ["network-online.target"]; + wants = [ "network-online.target" ]; + after = [ "network-online.target" ]; serviceConfig = { Type = "oneshot"; TimeoutStartSec = 300; ExecStart = pkgs.substituteAll { src = ./initialize_kasmweb.sh; isExecutable = true; - binPath = lib.makeBinPath [ pkgs.docker pkgs.openssl pkgs.gnused pkgs.yq-go ]; + binPath = lib.makeBinPath [ + pkgs.docker + pkgs.openssl + pkgs.gnused + pkgs.yq-go + ]; runtimeShell = pkgs.runtimeShell; kasmweb = pkgs.kasmweb; postgresUser = "postgres"; @@ -153,7 +163,8 @@ in defaultAdminPassword defaultManagerToken defaultRegistrationToken - defaultGuacToken; + defaultGuacToken + ; }; }; }; @@ -188,7 +199,10 @@ in dependsOn = [ "kasm_db" ]; entrypoint = "/bin/bash"; cmd = [ "/opt/kasm/current/init_seeds.sh" ]; - extraOptions = [ "--network=kasm_default_network" "--userns=host" ]; + extraOptions = [ + "--network=kasm_default_network" + "--userns=host" + ]; }; kasm_redis = { image = "redis:5-alpine"; @@ -198,7 +212,10 @@ in "-c" "redis-server --requirepass ${cfg.redisPassword}" ]; - extraOptions = [ "--network=kasm_default_network" "--userns=host" ]; + extraOptions = [ + "--network=kasm_default_network" + "--userns=host" + ]; }; kasm_api = { image = "kasmweb/api:${pkgs.kasmweb.version}"; @@ -209,7 +226,10 @@ in "kasmweb_api_data:/tmp" ]; dependsOn = [ "kasm_db_init" ]; - extraOptions = [ "--network=kasm_default_network" "--userns=host" ]; + extraOptions = [ + "--network=kasm_default_network" + "--userns=host" + ]; }; kasm_manager = { image = "kasmweb/manager:${pkgs.kasmweb.version}"; @@ -218,8 +238,16 @@ in volumes = [ "${cfg.datastorePath}/:/opt/kasm/current/" ]; - dependsOn = [ "kasm_db_init" "kasm_db" "kasm_api" ]; - extraOptions = [ "--network=kasm_default_network" "--userns=host" "--read-only"]; + dependsOn = [ + "kasm_db_init" + "kasm_db" + "kasm_api" + ]; + extraOptions = [ + "--network=kasm_default_network" + "--userns=host" + "--read-only" + ]; }; kasm_agent = { image = "kasmweb/agent:${pkgs.kasmweb.version}"; @@ -232,7 +260,11 @@ in "${cfg.datastorePath}/conf/nginx:/etc/nginx/conf.d" ]; dependsOn = [ "kasm_manager" ]; - extraOptions = [ "--network=kasm_default_network" "--userns=host" "--read-only" ]; + extraOptions = [ + "--network=kasm_default_network" + "--userns=host" + "--read-only" + ]; }; kasm_share = { image = "kasmweb/share:${pkgs.kasmweb.version}"; @@ -241,8 +273,16 @@ in volumes = [ "${cfg.datastorePath}/:/opt/kasm/current/" ]; - dependsOn = [ "kasm_db_init" "kasm_db" "kasm_redis" ]; - extraOptions = [ "--network=kasm_default_network" "--userns=host" "--read-only" ]; + dependsOn = [ + "kasm_db_init" + "kasm_db" + "kasm_redis" + ]; + extraOptions = [ + "--network=kasm_default_network" + "--userns=host" + "--read-only" + ]; }; kasm_guac = { image = "kasmweb/kasm-guac:${pkgs.kasmweb.version}"; @@ -251,8 +291,15 @@ in volumes = [ "${cfg.datastorePath}/:/opt/kasm/current/" ]; - dependsOn = [ "kasm_db" "kasm_redis" ]; - extraOptions = [ "--network=kasm_default_network" "--userns=host" "--read-only" ]; + dependsOn = [ + "kasm_db" + "kasm_redis" + ]; + extraOptions = [ + "--network=kasm_default_network" + "--userns=host" + "--read-only" + ]; }; kasm_proxy = { image = "kasmweb/nginx:latest"; @@ -267,10 +314,18 @@ in "${cfg.datastorePath}/log/nginx:/var/log/external/nginx" "${cfg.datastorePath}/log/logrotate:/var/log/external/logrotate" ]; - dependsOn = [ "kasm_manager" "kasm_api" "kasm_agent" "kasm_share" - "kasm_guac" ]; - extraOptions = [ "--network=kasm_default_network" "--userns=host" - "--network-alias=proxy"]; + dependsOn = [ + "kasm_manager" + "kasm_api" + "kasm_agent" + "kasm_share" + "kasm_guac" + ]; + extraOptions = [ + "--network=kasm_default_network" + "--userns=host" + "--network-alias=proxy" + ]; }; }; }; diff --git a/nixos/modules/services/web-apps/keycloak.nix b/nixos/modules/services/web-apps/keycloak.nix index b8dc9e2ef0dd31..406b978d6704bf 100644 --- a/nixos/modules/services/web-apps/keycloak.nix +++ b/nixos/modules/services/web-apps/keycloak.nix @@ -1,4 +1,10 @@ -{ config, options, pkgs, lib, ... }: +{ + config, + options, + pkgs, + lib, + ... +}: let cfg = config.services.keycloak; @@ -40,35 +46,36 @@ let prefixUnlessEmpty = prefix: string: optionalString (string != "") "${prefix}${string}"; in { - imports = - [ - (mkRenamedOptionModule - [ "services" "keycloak" "bindAddress" ] - [ "services" "keycloak" "settings" "http-host" ]) - (mkRenamedOptionModule - [ "services" "keycloak" "forceBackendUrlToFrontendUrl"] - [ "services" "keycloak" "settings" "hostname-strict-backchannel"]) - (mkChangedOptionModule - [ "services" "keycloak" "httpPort" ] - [ "services" "keycloak" "settings" "http-port" ] - (config: - builtins.fromJSON config.services.keycloak.httpPort)) - (mkChangedOptionModule - [ "services" "keycloak" "httpsPort" ] - [ "services" "keycloak" "settings" "https-port" ] - (config: - builtins.fromJSON config.services.keycloak.httpsPort)) - (mkRemovedOptionModule - [ "services" "keycloak" "frontendUrl" ] - '' - Set `services.keycloak.settings.hostname' and `services.keycloak.settings.http-relative-path' instead. - NOTE: You likely want to set 'http-relative-path' to '/auth' to keep compatibility with your clients. - See its description for more information. - '') - (mkRemovedOptionModule - [ "services" "keycloak" "extraConfig" ] - "Use `services.keycloak.settings' instead.") - ]; + imports = [ + (mkRenamedOptionModule + [ "services" "keycloak" "bindAddress" ] + [ "services" "keycloak" "settings" "http-host" ] + ) + (mkRenamedOptionModule + [ "services" "keycloak" "forceBackendUrlToFrontendUrl" ] + [ "services" "keycloak" "settings" "hostname-strict-backchannel" ] + ) + (mkChangedOptionModule + [ "services" "keycloak" "httpPort" ] + [ "services" "keycloak" "settings" "http-port" ] + (config: builtins.fromJSON config.services.keycloak.httpPort) + ) + (mkChangedOptionModule + [ "services" "keycloak" "httpsPort" ] + [ "services" "keycloak" "settings" "https-port" ] + (config: builtins.fromJSON config.services.keycloak.httpsPort) + ) + (mkRemovedOptionModule [ "services" "keycloak" "frontendUrl" ] '' + Set `services.keycloak.settings.hostname' and `services.keycloak.settings.http-relative-path' instead. + NOTE: You likely want to set 'http-relative-path' to '/auth' to keep compatibility with your clients. + See its description for more information. + '') + (mkRemovedOptionModule [ + "services" + "keycloak" + "extraConfig" + ] "Use `services.keycloak.settings' instead.") + ]; options.services.keycloak = let @@ -82,9 +89,11 @@ in path enum package - port; + port + ; - assertStringPath = optionName: value: + assertStringPath = + optionName: value: if isPath value then throw '' services.keycloak.${optionName}: @@ -92,7 +101,8 @@ in is a Nix path, but should be a string, since Nix paths are copied into the world-readable Nix store. '' - else value; + else + value; in { enable = mkOption { @@ -139,7 +149,11 @@ in database = { type = mkOption { - type = enum [ "mysql" "mariadb" "postgresql" ]; + type = enum [ + "mysql" + "mariadb" + "postgresql" + ]; default = "postgresql"; example = "mariadb"; description = '' @@ -276,7 +290,14 @@ in settings = mkOption { type = lib.types.submodule { - freeformType = attrsOf (nullOr (oneOf [ str int bool (attrsOf path) ])); + freeformType = attrsOf ( + nullOr (oneOf [ + str + int + bool + (attrsOf path) + ]) + ); options = { http-host = mkOption { @@ -389,7 +410,12 @@ in # connect to it. databaseActuallyCreateLocally = cfg.database.createLocally && cfg.database.host == "localhost"; createLocalPostgreSQL = databaseActuallyCreateLocally && cfg.database.type == "postgresql"; - createLocalMySQL = databaseActuallyCreateLocally && elem cfg.database.type [ "mysql" "mariadb" ]; + createLocalMySQL = + databaseActuallyCreateLocally + && elem cfg.database.type [ + "mysql" + "mariadb" + ]; mySqlCaKeystore = pkgs.runCommand "mysql-ca-keystore" { } '' ${pkgs.jre}/bin/keytool -importcert -trustcacerts -alias MySQLCACert -file ${cfg.database.caCert} -keystore $out -storepass notsosecretpassword -noprompt @@ -421,228 +447,260 @@ in fi done - ${concatStringsSep "\n" (mapAttrsToList (name: theme: "linkTheme ${theme} ${escapeShellArg name}") cfg.themes)} + ${concatStringsSep "\n" ( + mapAttrsToList (name: theme: "linkTheme ${theme} ${escapeShellArg name}") cfg.themes + )} ''; keycloakConfig = lib.generators.toKeyValue { mkKeyValue = lib.flip lib.generators.mkKeyValueDefault "=" { - mkValueString = v: - if isInt v then toString v - else if isString v then v - else if true == v then "true" - else if false == v then "false" - else if isSecret v then hashString "sha256" v._secret - else throw "unsupported type ${typeOf v}: ${(lib.generators.toPretty {}) v}"; + mkValueString = + v: + if isInt v then + toString v + else if isString v then + v + else if true == v then + "true" + else if false == v then + "false" + else if isSecret v then + hashString "sha256" v._secret + else + throw "unsupported type ${typeOf v}: ${(lib.generators.toPretty { }) v}"; }; }; isSecret = v: isAttrs v && v ? _secret && isString v._secret; - filteredConfig = lib.converge (lib.filterAttrsRecursive (_: v: ! elem v [{ } null])) cfg.settings; + filteredConfig = lib.converge (lib.filterAttrsRecursive ( + _: v: + !elem v [ + { } + null + ] + )) cfg.settings; confFile = pkgs.writeText "keycloak.conf" (keycloakConfig filteredConfig); keycloakBuild = cfg.package.override { inherit confFile; - plugins = cfg.package.enabledPlugins ++ cfg.plugins ++ - (with cfg.package.plugins; [quarkus-systemd-notify quarkus-systemd-notify-deployment]); + plugins = + cfg.package.enabledPlugins + ++ cfg.plugins + ++ (with cfg.package.plugins; [ + quarkus-systemd-notify + quarkus-systemd-notify-deployment + ]); }; in - mkIf cfg.enable - { - assertions = [ - { - assertion = (cfg.database.useSSL && cfg.database.type == "postgresql") -> (cfg.database.caCert != null); - message = "A CA certificate must be specified (in 'services.keycloak.database.caCert') when PostgreSQL is used with SSL"; - } - { - assertion = createLocalPostgreSQL -> config.services.postgresql.settings.standard_conforming_strings or true; - message = "Setting up a local PostgreSQL db for Keycloak requires `standard_conforming_strings` turned on to work reliably"; - } - { - assertion = cfg.settings.hostname != null || ! cfg.settings.hostname-strict or true; - message = "Setting the Keycloak hostname is required, see `services.keycloak.settings.hostname`"; - } - { - assertion = cfg.settings.hostname-url or null == null; - message = '' - The option `services.keycloak.settings.hostname-url' has been removed. - Set `services.keycloak.settings.hostname' instead. - See [New Hostname options](https://www.keycloak.org/docs/25.0.0/upgrading/#new-hostname-options) for details. - ''; - } - { - assertion = cfg.settings.hostname-strict-backchannel or null == null; - message = '' - The option `services.keycloak.settings.hostname-strict-backchannel' has been removed. - Set `services.keycloak.settings.hostname-backchannel-dynamic' instead. - See [New Hostname options](https://www.keycloak.org/docs/25.0.0/upgrading/#new-hostname-options) for details. - ''; - } - { - assertion = cfg.settings.proxy or null == null; - message = '' - The option `services.keycloak.settings.proxy' has been removed. - Set `services.keycloak.settings.proxy-headers` in combination - with other hostname options as needed instead. - See [Proxy option removed](https://www.keycloak.org/docs/latest/upgrading/index.html#proxy-option-removed) - for more information. - ''; - } - ]; - - environment.systemPackages = [ keycloakBuild ]; - - services.keycloak.settings = - let - postgresParams = concatStringsSep "&" ( - optionals cfg.database.useSSL [ - "ssl=true" - ] ++ optionals (cfg.database.caCert != null) [ - "sslrootcert=${cfg.database.caCert}" - "sslmode=verify-ca" - ] - ); - mariadbParams = concatStringsSep "&" ([ + mkIf cfg.enable { + assertions = [ + { + assertion = + (cfg.database.useSSL && cfg.database.type == "postgresql") -> (cfg.database.caCert != null); + message = "A CA certificate must be specified (in 'services.keycloak.database.caCert') when PostgreSQL is used with SSL"; + } + { + assertion = + createLocalPostgreSQL -> config.services.postgresql.settings.standard_conforming_strings or true; + message = "Setting up a local PostgreSQL db for Keycloak requires `standard_conforming_strings` turned on to work reliably"; + } + { + assertion = cfg.settings.hostname != null || !cfg.settings.hostname-strict or true; + message = "Setting the Keycloak hostname is required, see `services.keycloak.settings.hostname`"; + } + { + assertion = cfg.settings.hostname-url or null == null; + message = '' + The option `services.keycloak.settings.hostname-url' has been removed. + Set `services.keycloak.settings.hostname' instead. + See [New Hostname options](https://www.keycloak.org/docs/25.0.0/upgrading/#new-hostname-options) for details. + ''; + } + { + assertion = cfg.settings.hostname-strict-backchannel or null == null; + message = '' + The option `services.keycloak.settings.hostname-strict-backchannel' has been removed. + Set `services.keycloak.settings.hostname-backchannel-dynamic' instead. + See [New Hostname options](https://www.keycloak.org/docs/25.0.0/upgrading/#new-hostname-options) for details. + ''; + } + { + assertion = cfg.settings.proxy or null == null; + message = '' + The option `services.keycloak.settings.proxy' has been removed. + Set `services.keycloak.settings.proxy-headers` in combination + with other hostname options as needed instead. + See [Proxy option removed](https://www.keycloak.org/docs/latest/upgrading/index.html#proxy-option-removed) + for more information. + ''; + } + ]; + + environment.systemPackages = [ keycloakBuild ]; + + services.keycloak.settings = + let + postgresParams = concatStringsSep "&" ( + optionals cfg.database.useSSL [ + "ssl=true" + ] + ++ optionals (cfg.database.caCert != null) [ + "sslrootcert=${cfg.database.caCert}" + "sslmode=verify-ca" + ] + ); + mariadbParams = concatStringsSep "&" ( + [ "characterEncoding=UTF-8" - ] ++ optionals cfg.database.useSSL [ + ] + ++ optionals cfg.database.useSSL [ "useSSL=true" "requireSSL=true" "verifyServerCertificate=true" - ] ++ optionals (cfg.database.caCert != null) [ + ] + ++ optionals (cfg.database.caCert != null) [ "trustCertificateKeyStoreUrl=file:${mySqlCaKeystore}" "trustCertificateKeyStorePassword=notsosecretpassword" - ]); - dbProps = if cfg.database.type == "postgresql" then postgresParams else mariadbParams; - in - mkMerge [ - { - db = if cfg.database.type == "postgresql" then "postgres" else cfg.database.type; - db-username = if databaseActuallyCreateLocally then "keycloak" else cfg.database.username; - db-password._secret = cfg.database.passwordFile; - db-url-host = cfg.database.host; - db-url-port = toString cfg.database.port; - db-url-database = if databaseActuallyCreateLocally then "keycloak" else cfg.database.name; - db-url-properties = prefixUnlessEmpty "?" dbProps; - db-url = null; - } - (mkIf (cfg.sslCertificate != null && cfg.sslCertificateKey != null) { - https-certificate-file = "/run/keycloak/ssl/ssl_cert"; - https-certificate-key-file = "/run/keycloak/ssl/ssl_key"; - }) - ]; + ] + ); + dbProps = if cfg.database.type == "postgresql" then postgresParams else mariadbParams; + in + mkMerge [ + { + db = if cfg.database.type == "postgresql" then "postgres" else cfg.database.type; + db-username = if databaseActuallyCreateLocally then "keycloak" else cfg.database.username; + db-password._secret = cfg.database.passwordFile; + db-url-host = cfg.database.host; + db-url-port = toString cfg.database.port; + db-url-database = if databaseActuallyCreateLocally then "keycloak" else cfg.database.name; + db-url-properties = prefixUnlessEmpty "?" dbProps; + db-url = null; + } + (mkIf (cfg.sslCertificate != null && cfg.sslCertificateKey != null) { + https-certificate-file = "/run/keycloak/ssl/ssl_cert"; + https-certificate-key-file = "/run/keycloak/ssl/ssl_key"; + }) + ]; - systemd.services.keycloakPostgreSQLInit = mkIf createLocalPostgreSQL { - after = [ "postgresql.service" ]; - before = [ "keycloak.service" ]; - bindsTo = [ "postgresql.service" ]; - path = [ config.services.postgresql.package ]; - serviceConfig = { - Type = "oneshot"; - RemainAfterExit = true; - User = "postgres"; - Group = "postgres"; - LoadCredential = [ "db_password:${cfg.database.passwordFile}" ]; - }; - script = '' - set -o errexit -o pipefail -o nounset -o errtrace - shopt -s inherit_errexit - - create_role="$(mktemp)" - trap 'rm -f "$create_role"' EXIT - - # Read the password from the credentials directory and - # escape any single quotes by adding additional single - # quotes after them, following the rules laid out here: - # https://www.postgresql.org/docs/current/sql-syntax-lexical.html#SQL-SYNTAX-CONSTANTS - db_password="$(<"$CREDENTIALS_DIRECTORY/db_password")" - db_password="''${db_password//\'/\'\'}" - - echo "CREATE ROLE keycloak WITH LOGIN PASSWORD '$db_password' CREATEDB" > "$create_role" - psql -tAc "SELECT 1 FROM pg_roles WHERE rolname='keycloak'" | grep -q 1 || psql -tA --file="$create_role" - psql -tAc "SELECT 1 FROM pg_database WHERE datname = 'keycloak'" | grep -q 1 || psql -tAc 'CREATE DATABASE "keycloak" OWNER "keycloak"' - ''; + systemd.services.keycloakPostgreSQLInit = mkIf createLocalPostgreSQL { + after = [ "postgresql.service" ]; + before = [ "keycloak.service" ]; + bindsTo = [ "postgresql.service" ]; + path = [ config.services.postgresql.package ]; + serviceConfig = { + Type = "oneshot"; + RemainAfterExit = true; + User = "postgres"; + Group = "postgres"; + LoadCredential = [ "db_password:${cfg.database.passwordFile}" ]; }; + script = '' + set -o errexit -o pipefail -o nounset -o errtrace + shopt -s inherit_errexit + + create_role="$(mktemp)" + trap 'rm -f "$create_role"' EXIT + + # Read the password from the credentials directory and + # escape any single quotes by adding additional single + # quotes after them, following the rules laid out here: + # https://www.postgresql.org/docs/current/sql-syntax-lexical.html#SQL-SYNTAX-CONSTANTS + db_password="$(<"$CREDENTIALS_DIRECTORY/db_password")" + db_password="''${db_password//\'/\'\'}" + + echo "CREATE ROLE keycloak WITH LOGIN PASSWORD '$db_password' CREATEDB" > "$create_role" + psql -tAc "SELECT 1 FROM pg_roles WHERE rolname='keycloak'" | grep -q 1 || psql -tA --file="$create_role" + psql -tAc "SELECT 1 FROM pg_database WHERE datname = 'keycloak'" | grep -q 1 || psql -tAc 'CREATE DATABASE "keycloak" OWNER "keycloak"' + ''; + }; - systemd.services.keycloakMySQLInit = mkIf createLocalMySQL { - after = [ "mysql.service" ]; - before = [ "keycloak.service" ]; - bindsTo = [ "mysql.service" ]; - path = [ config.services.mysql.package ]; - serviceConfig = { - Type = "oneshot"; - RemainAfterExit = true; - User = config.services.mysql.user; - Group = config.services.mysql.group; - LoadCredential = [ "db_password:${cfg.database.passwordFile}" ]; - }; - script = '' - set -o errexit -o pipefail -o nounset -o errtrace - shopt -s inherit_errexit - - # Read the password from the credentials directory and - # escape any single quotes by adding additional single - # quotes after them, following the rules laid out here: - # https://dev.mysql.com/doc/refman/8.0/en/string-literals.html - db_password="$(<"$CREDENTIALS_DIRECTORY/db_password")" - db_password="''${db_password//\'/\'\'}" - - ( echo "SET sql_mode = 'NO_BACKSLASH_ESCAPES';" - echo "CREATE USER IF NOT EXISTS 'keycloak'@'localhost' IDENTIFIED BY '$db_password';" - echo "CREATE DATABASE IF NOT EXISTS keycloak CHARACTER SET utf8 COLLATE utf8_unicode_ci;" - echo "GRANT ALL PRIVILEGES ON keycloak.* TO 'keycloak'@'localhost';" - ) | mysql -N - ''; + systemd.services.keycloakMySQLInit = mkIf createLocalMySQL { + after = [ "mysql.service" ]; + before = [ "keycloak.service" ]; + bindsTo = [ "mysql.service" ]; + path = [ config.services.mysql.package ]; + serviceConfig = { + Type = "oneshot"; + RemainAfterExit = true; + User = config.services.mysql.user; + Group = config.services.mysql.group; + LoadCredential = [ "db_password:${cfg.database.passwordFile}" ]; }; + script = '' + set -o errexit -o pipefail -o nounset -o errtrace + shopt -s inherit_errexit + + # Read the password from the credentials directory and + # escape any single quotes by adding additional single + # quotes after them, following the rules laid out here: + # https://dev.mysql.com/doc/refman/8.0/en/string-literals.html + db_password="$(<"$CREDENTIALS_DIRECTORY/db_password")" + db_password="''${db_password//\'/\'\'}" + + ( echo "SET sql_mode = 'NO_BACKSLASH_ESCAPES';" + echo "CREATE USER IF NOT EXISTS 'keycloak'@'localhost' IDENTIFIED BY '$db_password';" + echo "CREATE DATABASE IF NOT EXISTS keycloak CHARACTER SET utf8 COLLATE utf8_unicode_ci;" + echo "GRANT ALL PRIVILEGES ON keycloak.* TO 'keycloak'@'localhost';" + ) | mysql -N + ''; + }; - systemd.services.keycloak = - let - databaseServices = - if createLocalPostgreSQL then [ + systemd.services.keycloak = + let + databaseServices = + if createLocalPostgreSQL then + [ "keycloakPostgreSQLInit.service" "postgresql.service" ] - else if createLocalMySQL then [ + else if createLocalMySQL then + [ "keycloakMySQLInit.service" "mysql.service" ] - else [ ]; - secretPaths = catAttrs "_secret" (collect isSecret cfg.settings); - mkSecretReplacement = file: '' - replace-secret ${hashString "sha256" file} $CREDENTIALS_DIRECTORY/${baseNameOf file} /run/keycloak/conf/keycloak.conf - ''; - secretReplacements = lib.concatMapStrings mkSecretReplacement secretPaths; - in - { - after = databaseServices; - bindsTo = databaseServices; - wantedBy = [ "multi-user.target" ]; - path = with pkgs; [ - keycloakBuild - openssl - replace-secret - ]; - environment = { + else + [ ]; + secretPaths = catAttrs "_secret" (collect isSecret cfg.settings); + mkSecretReplacement = file: '' + replace-secret ${hashString "sha256" file} $CREDENTIALS_DIRECTORY/${baseNameOf file} /run/keycloak/conf/keycloak.conf + ''; + secretReplacements = lib.concatMapStrings mkSecretReplacement secretPaths; + in + { + after = databaseServices; + bindsTo = databaseServices; + wantedBy = [ "multi-user.target" ]; + path = with pkgs; [ + keycloakBuild + openssl + replace-secret + ]; + environment = + { KC_HOME_DIR = "/run/keycloak"; KC_CONF_DIR = "/run/keycloak/conf"; - } // lib.optionalAttrs (cfg.initialAdminPassword != null) { + } + // lib.optionalAttrs (cfg.initialAdminPassword != null) { KC_BOOTSTRAP_ADMIN_USERNAME = "admin"; KC_BOOTSTRAP_ADMIN_PASSWORD = cfg.initialAdminPassword; }; - serviceConfig = { - LoadCredential = - map (p: "${baseNameOf p}:${p}") secretPaths - ++ optionals (cfg.sslCertificate != null && cfg.sslCertificateKey != null) [ - "ssl_cert:${cfg.sslCertificate}" - "ssl_key:${cfg.sslCertificateKey}" - ]; - User = "keycloak"; - Group = "keycloak"; - DynamicUser = true; - RuntimeDirectory = "keycloak"; - RuntimeDirectoryMode = "0700"; - AmbientCapabilities = "CAP_NET_BIND_SERVICE"; - Type = "notify"; # Requires quarkus-systemd-notify plugin - NotifyAccess = "all"; - }; - script = '' + serviceConfig = { + LoadCredential = + map (p: "${baseNameOf p}:${p}") secretPaths + ++ optionals (cfg.sslCertificate != null && cfg.sslCertificateKey != null) [ + "ssl_cert:${cfg.sslCertificate}" + "ssl_key:${cfg.sslCertificateKey}" + ]; + User = "keycloak"; + Group = "keycloak"; + DynamicUser = true; + RuntimeDirectory = "keycloak"; + RuntimeDirectoryMode = "0700"; + AmbientCapabilities = "CAP_NET_BIND_SERVICE"; + Type = "notify"; # Requires quarkus-systemd-notify plugin + NotifyAccess = "all"; + }; + script = + '' set -o errexit -o pipefail -o nounset -o errtrace shopt -s inherit_errexit @@ -661,22 +719,24 @@ in # sequences. sed -i '/db-/ s|\\|\\\\|g' /run/keycloak/conf/keycloak.conf - '' + optionalString (cfg.sslCertificate != null && cfg.sslCertificateKey != null) '' + '' + + optionalString (cfg.sslCertificate != null && cfg.sslCertificateKey != null) '' mkdir -p /run/keycloak/ssl cp $CREDENTIALS_DIRECTORY/ssl_{cert,key} /run/keycloak/ssl/ - '' + '' + '' + + '' kc.sh --verbose start --optimized ''; - }; + }; - services.postgresql.enable = mkDefault createLocalPostgreSQL; - services.mysql.enable = mkDefault createLocalMySQL; - services.mysql.package = - let - dbPkg = if cfg.database.type == "mariadb" then pkgs.mariadb else pkgs.mysql80; - in - mkIf createLocalMySQL (mkDefault dbPkg); - }; + services.postgresql.enable = mkDefault createLocalPostgreSQL; + services.mysql.enable = mkDefault createLocalMySQL; + services.mysql.package = + let + dbPkg = if cfg.database.type == "mariadb" then pkgs.mariadb else pkgs.mysql80; + in + mkIf createLocalMySQL (mkDefault dbPkg); + }; meta.doc = ./keycloak.md; meta.maintainers = [ maintainers.talyz ]; diff --git a/nixos/modules/services/web-apps/lanraragi.nix b/nixos/modules/services/web-apps/lanraragi.nix index 7b7fb01918bbcf..4c029d3018276d 100644 --- a/nixos/modules/services/web-apps/lanraragi.nix +++ b/nixos/modules/services/web-apps/lanraragi.nix @@ -1,4 +1,9 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: let cfg = config.services.lanraragi; @@ -53,7 +58,10 @@ in systemd.services.lanraragi = { description = "LANraragi main service"; - after = [ "network.target" "redis-lanraragi.service" ]; + after = [ + "network.target" + "redis-lanraragi.service" + ]; requires = [ "redis-lanraragi.service" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { @@ -71,23 +79,29 @@ in "LRR_NETWORK" = "http://*:${toString cfg.port}"; "HOME" = "/var/lib/lanraragi"; }; - preStart = '' - cat > lrr.conf < "127.0.0.1:${toString cfg.redis.port}", - redis_password => "${lib.optionalString (cfg.redis.passwordFile != null) ''$(head -n1 ${cfg.redis.passwordFile})''}", - redis_database => "0", - redis_database_minion => "1", - redis_database_config => "2", - redis_database_search => "3", - } - EOF - '' + lib.optionalString (cfg.passwordFile != null) '' - ${lib.getExe pkgs.redis} -h 127.0.0.1 -p ${toString cfg.redis.port} ${lib.optionalString (cfg.redis.passwordFile != null) ''-a "$(head -n1 ${cfg.redis.passwordFile})"''}< lrr.conf < "127.0.0.1:${toString cfg.redis.port}", + redis_password => "${ + lib.optionalString (cfg.redis.passwordFile != null) ''$(head -n1 ${cfg.redis.passwordFile})'' + }", + redis_database => "0", + redis_database_minion => "1", + redis_database_config => "2", + redis_database_search => "3", + } + EOF + '' + + lib.optionalString (cfg.passwordFile != null) '' + ${lib.getExe pkgs.redis} -h 127.0.0.1 -p ${toString cfg.redis.port} ${ + lib.optionalString (cfg.redis.passwordFile != null) ''-a "$(head -n1 ${cfg.redis.passwordFile})"'' + }< cfg.settings.database.host == "localhost" || cfg.settings.database.host == "/run/postgresql"; + assertion = + cfg.database.createLocally + -> cfg.settings.database.host == "localhost" || cfg.settings.database.host == "/run/postgresql"; message = "if you want to create the database locally, you need to use a local database"; } { - assertion = (!(hasAttrByPath ["federation"] cfg.settings)) && (!(hasAttrByPath ["federation" "enabled"] cfg.settings)); + assertion = + (!(hasAttrByPath [ "federation" ] cfg.settings)) + && (!(hasAttrByPath [ "federation" "enabled" ] cfg.settings)); message = "`services.lemmy.settings.federation` was removed in 0.17.0 and no longer has any effect"; } { @@ -245,46 +301,56 @@ in } ]; - systemd.services.lemmy = let - substitutedConfig = "/run/lemmy/config.hjson"; - in { - description = "Lemmy server"; - - environment = { - LEMMY_CONFIG_LOCATION = if secrets == {} then settingsFormat.generate "config.hjson" cfg.settings else substitutedConfig; - LEMMY_DATABASE_URL = if cfg.database.uri != null then cfg.database.uri else (mkIf (cfg.database.createLocally) "postgres:///lemmy?host=/run/postgresql&user=lemmy"); - }; + systemd.services.lemmy = + let + substitutedConfig = "/run/lemmy/config.hjson"; + in + { + description = "Lemmy server"; + + environment = { + LEMMY_CONFIG_LOCATION = + if secrets == { } then settingsFormat.generate "config.hjson" cfg.settings else substitutedConfig; + LEMMY_DATABASE_URL = + if cfg.database.uri != null then + cfg.database.uri + else + (mkIf (cfg.database.createLocally) "postgres:///lemmy?host=/run/postgresql&user=lemmy"); + }; - documentation = [ - "https://join-lemmy.org/docs/en/admins/from_scratch.html" - "https://join-lemmy.org/docs/en/" - ]; + documentation = [ + "https://join-lemmy.org/docs/en/admins/from_scratch.html" + "https://join-lemmy.org/docs/en/" + ]; - wantedBy = [ "multi-user.target" ]; + wantedBy = [ "multi-user.target" ]; - after = [ "pict-rs.service" ] ++ lib.optionals cfg.database.createLocally [ "postgresql.service" ]; + after = [ "pict-rs.service" ] ++ lib.optionals cfg.database.createLocally [ "postgresql.service" ]; - requires = lib.optionals cfg.database.createLocally [ "postgresql.service" ]; + requires = lib.optionals cfg.database.createLocally [ "postgresql.service" ]; - # substitute secrets and prevent others from reading the result - # if somehow $CREDENTIALS_DIRECTORY is not set we fail - preStart = mkIf (secrets != {}) '' - set -u - umask u=rw,g=,o= - cd "$CREDENTIALS_DIRECTORY" - ${utils.genJqSecretsReplacementSnippet cfg.settings substitutedConfig} - ''; + # substitute secrets and prevent others from reading the result + # if somehow $CREDENTIALS_DIRECTORY is not set we fail + preStart = mkIf (secrets != { }) '' + set -u + umask u=rw,g=,o= + cd "$CREDENTIALS_DIRECTORY" + ${utils.genJqSecretsReplacementSnippet cfg.settings substitutedConfig} + ''; - serviceConfig = { - DynamicUser = true; - RuntimeDirectory = "lemmy"; - ExecStart = "${cfg.server.package}/bin/lemmy_server"; - LoadCredential = lib.foldlAttrs (acc: option: data: acc ++ [ "${option}:${toString data.path}" ]) [] secrets; - PrivateTmp = true; - MemoryDenyWriteExecute = true; - NoNewPrivileges = true; + serviceConfig = { + DynamicUser = true; + RuntimeDirectory = "lemmy"; + ExecStart = "${cfg.server.package}/bin/lemmy_server"; + LoadCredential = lib.foldlAttrs ( + acc: option: data: + acc ++ [ "${option}:${toString data.path}" ] + ) [ ] secrets; + PrivateTmp = true; + MemoryDenyWriteExecute = true; + NoNewPrivileges = true; + }; }; - }; systemd.services.lemmy-ui = { description = "Lemmy ui"; diff --git a/nixos/modules/services/web-apps/limesurvey.nix b/nixos/modules/services/web-apps/limesurvey.nix index dbcd9eae2d29a7..c1d4d01b6a6a36 100644 --- a/nixos/modules/services/web-apps/limesurvey.nix +++ b/nixos/modules/services/web-apps/limesurvey.nix @@ -1,9 +1,28 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkDefault mkEnableOption mkForce mkIf mkMerge mkOption mkPackageOption; - inherit (lib) literalExpression mapAttrs optional optionalString types; + inherit (lib) + mkDefault + mkEnableOption + mkForce + mkIf + mkMerge + mkOption + mkPackageOption + ; + inherit (lib) + literalExpression + mapAttrs + optional + optionalString + types + ; cfg = config.services.limesurvey; fpm = config.services.phpfpm.pools.limesurvey; @@ -12,9 +31,17 @@ let group = config.services.httpd.group; stateDir = "/var/lib/limesurvey"; - configType = with types; oneOf [ (attrsOf configType) str int bool ] // { - description = "limesurvey config type (str, int, bool or attribute set thereof)"; - }; + configType = + with types; + oneOf [ + (attrsOf configType) + str + int + bool + ] + // { + description = "limesurvey config type (str, int, bool or attribute set thereof)"; + }; limesurveyConfig = pkgs.writeText "config.php" '' @@ -201,19 +244,24 @@ in config = mkIf cfg.enable { assertions = [ - { assertion = cfg.database.createLocally -> cfg.database.type == "mysql"; + { + assertion = cfg.database.createLocally -> cfg.database.type == "mysql"; message = "services.limesurvey.createLocally is currently only supported for database type 'mysql'"; } - { assertion = cfg.database.createLocally -> cfg.database.user == user; + { + assertion = cfg.database.createLocally -> cfg.database.user == user; message = "services.limesurvey.database.user must be set to ${user} if services.limesurvey.database.createLocally is set true"; } - { assertion = cfg.database.createLocally -> cfg.database.socket != null; + { + assertion = cfg.database.createLocally -> cfg.database.socket != null; message = "services.limesurvey.database.socket must be set if services.limesurvey.database.createLocally is set to true"; } - { assertion = cfg.database.createLocally -> cfg.database.passwordFile == null; + { + assertion = cfg.database.createLocally -> cfg.database.passwordFile == null; message = "a password cannot be specified if services.limesurvey.database.createLocally is set to true"; } - { assertion = cfg.encryptionKey != null || cfg.encryptionKeyFile != null; + { + assertion = cfg.encryptionKey != null || cfg.encryptionKeyFile != null; message = '' You must set `services.limesurvey.encryptionKeyFile` to a file containing a 32-character uppercase hex string. @@ -221,7 +269,8 @@ in in the LimeSurvey interface and create backups before filling the key. ''; } - { assertion = cfg.encryptionNonce != null || cfg.encryptionNonceFile != null; + { + assertion = cfg.encryptionNonce != null || cfg.encryptionNonceFile != null; message = '' You must set `services.limesurvey.encryptionNonceFile` to a file containing a 24-character uppercase hex string. @@ -235,10 +284,15 @@ in runtimePath = "${stateDir}/tmp/runtime"; components = { db = { - connectionString = "${cfg.database.type}:dbname=${cfg.database.name};host=${if pgsqlLocal then cfg.database.socket else cfg.database.host};port=${toString cfg.database.port}" + - optionalString mysqlLocal ";socket=${cfg.database.socket}"; + connectionString = + "${cfg.database.type}:dbname=${cfg.database.name};host=${ + if pgsqlLocal then cfg.database.socket else cfg.database.host + };port=${toString cfg.database.port}" + + optionalString mysqlLocal ";socket=${cfg.database.socket}"; username = cfg.database.user; - password = mkIf (cfg.database.passwordFile != null) "file_get_contents(\"${toString cfg.database.passwordFile}\");"; + password = mkIf ( + cfg.database.passwordFile != null + ) "file_get_contents(\"${toString cfg.database.passwordFile}\");"; tablePrefix = "limesurvey_"; }; assetManager.basePath = "${stateDir}/tmp/assets"; @@ -250,7 +304,9 @@ in config = { tempdir = "${stateDir}/tmp"; uploaddir = "${stateDir}/upload"; - force_ssl = mkIf (cfg.virtualHost.addSSL || cfg.virtualHost.forceSSL || cfg.virtualHost.onlySSL) "on"; + force_ssl = mkIf ( + cfg.virtualHost.addSSL || cfg.virtualHost.forceSSL || cfg.virtualHost.onlySSL + ) "on"; config.defaultlang = "en"; }; }; @@ -260,7 +316,8 @@ in package = mkDefault pkgs.mariadb; ensureDatabases = [ cfg.database.name ]; ensureUsers = [ - { name = cfg.database.user; + { + name = cfg.database.user; ensurePermissions = { "${cfg.database.name}.*" = "SELECT, CREATE, INSERT, UPDATE, DELETE, ALTER, DROP, INDEX"; }; @@ -289,8 +346,18 @@ in chown ${user}:${group} "${stateDir}/credentials/encryption_nonce" ''; LoadCredential = [ - "encryption_key:${if cfg.encryptionKeyFile != null then cfg.encryptionKeyFile else pkgs.writeText "key" cfg.encryptionKey}" - "encryption_nonce:${if cfg.encryptionNonceFile != null then cfg.encryptionNonceFile else pkgs.writeText "nonce" cfg.encryptionKey}" + "encryption_key:${ + if cfg.encryptionKeyFile != null then + cfg.encryptionKeyFile + else + pkgs.writeText "key" cfg.encryptionKey + }" + "encryption_nonce:${ + if cfg.encryptionNonceFile != null then + cfg.encryptionNonceFile + else + pkgs.writeText "nonce" cfg.encryptionKey + }" ]; }; @@ -298,36 +365,39 @@ in enable = true; adminAddr = mkDefault cfg.virtualHost.adminAddr; extraModules = [ "proxy_fcgi" ]; - virtualHosts.${cfg.virtualHost.hostName} = mkMerge [ cfg.virtualHost { - documentRoot = mkForce "${cfg.package}/share/limesurvey"; - extraConfig = '' - Alias "/tmp" "${stateDir}/tmp" - - AllowOverride all - Require all granted - Options -Indexes +FollowSymlinks - - - Alias "/upload" "${stateDir}/upload" - - AllowOverride all - Require all granted - Options -Indexes - - - - - - SetHandler "proxy:unix:${fpm.socket}|fcgi://localhost/" - - - - AllowOverride all - Options -Indexes - DirectoryIndex index.php - - ''; - } ]; + virtualHosts.${cfg.virtualHost.hostName} = mkMerge [ + cfg.virtualHost + { + documentRoot = mkForce "${cfg.package}/share/limesurvey"; + extraConfig = '' + Alias "/tmp" "${stateDir}/tmp" + + AllowOverride all + Require all granted + Options -Indexes +FollowSymlinks + + + Alias "/upload" "${stateDir}/upload" + + AllowOverride all + Require all granted + Options -Indexes + + + + + + SetHandler "proxy:unix:${fpm.socket}|fcgi://localhost/" + + + + AllowOverride all + Options -Indexes + DirectoryIndex index.php + + ''; + } + ]; }; systemd.tmpfiles.rules = [ @@ -356,13 +426,25 @@ in Group = group; Type = "oneshot"; LoadCredential = [ - "encryption_key:${if cfg.encryptionKeyFile != null then cfg.encryptionKeyFile else pkgs.writeText "key" cfg.encryptionKey}" - "encryption_nonce:${if cfg.encryptionNonceFile != null then cfg.encryptionNonceFile else pkgs.writeText "nonce" cfg.encryptionKey}" + "encryption_key:${ + if cfg.encryptionKeyFile != null then + cfg.encryptionKeyFile + else + pkgs.writeText "key" cfg.encryptionKey + }" + "encryption_nonce:${ + if cfg.encryptionNonceFile != null then + cfg.encryptionNonceFile + else + pkgs.writeText "nonce" cfg.encryptionKey + }" ]; }; }; - systemd.services.httpd.after = optional mysqlLocal "mysql.service" ++ optional pgsqlLocal "postgresql.service"; + systemd.services.httpd.after = + optional mysqlLocal "mysql.service" + ++ optional pgsqlLocal "postgresql.service"; users.users.${user} = { group = group; diff --git a/nixos/modules/services/web-apps/mattermost.nix b/nixos/modules/services/web-apps/mattermost.nix index fee0ec2d641d23..4f12774327f266 100644 --- a/nixos/modules/services/web-apps/mattermost.nix +++ b/nixos/modules/services/web-apps/mattermost.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -10,88 +15,96 @@ let postgresPackage = config.services.postgresql.package; - createDb = { - statePath ? cfg.statePath, - localDatabaseUser ? cfg.localDatabaseUser, - localDatabasePassword ? cfg.localDatabasePassword, - localDatabaseName ? cfg.localDatabaseName, - useSudo ? true - }: '' - if ! test -e ${escapeShellArg "${statePath}/.db-created"}; then - ${lib.optionalString useSudo "${pkgs.sudo}/bin/sudo -u ${escapeShellArg config.services.postgresql.superUser} \\"} - ${postgresPackage}/bin/psql postgres -c \ - "CREATE ROLE ${localDatabaseUser} WITH LOGIN NOCREATEDB NOCREATEROLE ENCRYPTED PASSWORD '${localDatabasePassword}'" - ${lib.optionalString useSudo "${pkgs.sudo}/bin/sudo -u ${escapeShellArg config.services.postgresql.superUser} \\"} - ${postgresPackage}/bin/createdb \ - --owner ${escapeShellArg localDatabaseUser} ${escapeShellArg localDatabaseName} - touch ${escapeShellArg "${statePath}/.db-created"} - fi - ''; - - mattermostPluginDerivations = with pkgs; - map (plugin: stdenv.mkDerivation { - name = "mattermost-plugin"; - installPhase = '' - mkdir -p $out/share - cp ${plugin} $out/share/plugin.tar.gz - ''; - dontUnpack = true; - dontPatch = true; - dontConfigure = true; - dontBuild = true; - preferLocalBuild = true; - }) cfg.plugins; - - mattermostPlugins = with pkgs; - if mattermostPluginDerivations == [] then null - else stdenv.mkDerivation { - name = "${cfg.package.name}-plugins"; - nativeBuildInputs = [ - autoPatchelfHook - ] ++ mattermostPluginDerivations; - buildInputs = [ - cfg.package - ]; - installPhase = '' - mkdir -p $out/data/plugins - plugins=(${escapeShellArgs (map (plugin: "${plugin}/share/plugin.tar.gz") mattermostPluginDerivations)}) - for plugin in "''${plugins[@]}"; do - hash="$(sha256sum "$plugin" | cut -d' ' -f1)" - mkdir -p "$hash" - tar -C "$hash" -xzf "$plugin" - autoPatchelf "$hash" - GZIP_OPT=-9 tar -C "$hash" -cvzf "$out/data/plugins/$hash.tar.gz" . - rm -rf "$hash" - done - ''; - - dontUnpack = true; - dontPatch = true; - dontConfigure = true; - dontBuild = true; - preferLocalBuild = true; - }; + createDb = + { + statePath ? cfg.statePath, + localDatabaseUser ? cfg.localDatabaseUser, + localDatabasePassword ? cfg.localDatabasePassword, + localDatabaseName ? cfg.localDatabaseName, + useSudo ? true, + }: + '' + if ! test -e ${escapeShellArg "${statePath}/.db-created"}; then + ${lib.optionalString useSudo "${pkgs.sudo}/bin/sudo -u ${escapeShellArg config.services.postgresql.superUser} \\"} + ${postgresPackage}/bin/psql postgres -c \ + "CREATE ROLE ${localDatabaseUser} WITH LOGIN NOCREATEDB NOCREATEROLE ENCRYPTED PASSWORD '${localDatabasePassword}'" + ${lib.optionalString useSudo "${pkgs.sudo}/bin/sudo -u ${escapeShellArg config.services.postgresql.superUser} \\"} + ${postgresPackage}/bin/createdb \ + --owner ${escapeShellArg localDatabaseUser} ${escapeShellArg localDatabaseName} + touch ${escapeShellArg "${statePath}/.db-created"} + fi + ''; + + mattermostPluginDerivations = + with pkgs; + map ( + plugin: + stdenv.mkDerivation { + name = "mattermost-plugin"; + installPhase = '' + mkdir -p $out/share + cp ${plugin} $out/share/plugin.tar.gz + ''; + dontUnpack = true; + dontPatch = true; + dontConfigure = true; + dontBuild = true; + preferLocalBuild = true; + } + ) cfg.plugins; + + mattermostPlugins = + with pkgs; + if mattermostPluginDerivations == [ ] then + null + else + stdenv.mkDerivation { + name = "${cfg.package.name}-plugins"; + nativeBuildInputs = [ + autoPatchelfHook + ] ++ mattermostPluginDerivations; + buildInputs = [ + cfg.package + ]; + installPhase = '' + mkdir -p $out/data/plugins + plugins=(${ + escapeShellArgs (map (plugin: "${plugin}/share/plugin.tar.gz") mattermostPluginDerivations) + }) + for plugin in "''${plugins[@]}"; do + hash="$(sha256sum "$plugin" | cut -d' ' -f1)" + mkdir -p "$hash" + tar -C "$hash" -xzf "$plugin" + autoPatchelf "$hash" + GZIP_OPT=-9 tar -C "$hash" -cvzf "$out/data/plugins/$hash.tar.gz" . + rm -rf "$hash" + done + ''; + + dontUnpack = true; + dontPatch = true; + dontConfigure = true; + dontBuild = true; + preferLocalBuild = true; + }; - mattermostConfWithoutPlugins = recursiveUpdate - { ServiceSettings.SiteURL = cfg.siteUrl; - ServiceSettings.ListenAddress = cfg.listenAddress; - TeamSettings.SiteName = cfg.siteName; - SqlSettings.DriverName = "postgres"; - SqlSettings.DataSource = database; - PluginSettings.Directory = "${cfg.statePath}/plugins/server"; - PluginSettings.ClientDirectory = "${cfg.statePath}/plugins/client"; + mattermostConfWithoutPlugins = recursiveUpdate { + ServiceSettings.SiteURL = cfg.siteUrl; + ServiceSettings.ListenAddress = cfg.listenAddress; + TeamSettings.SiteName = cfg.siteName; + SqlSettings.DriverName = "postgres"; + SqlSettings.DataSource = database; + PluginSettings.Directory = "${cfg.statePath}/plugins/server"; + PluginSettings.ClientDirectory = "${cfg.statePath}/plugins/client"; + } cfg.extraConfig; + + mattermostConf = recursiveUpdate mattermostConfWithoutPlugins ( + lib.optionalAttrs (mattermostPlugins != null) { + PluginSettings = { + Enable = true; + }; } - cfg.extraConfig; - - mattermostConf = recursiveUpdate - mattermostConfWithoutPlugins - ( - lib.optionalAttrs (mattermostPlugins != null) { - PluginSettings = { - Enable = true; - }; - } - ); + ); mattermostConfJSON = pkgs.writeText "mattermost-config.json" (builtins.toJSON mattermostConf); @@ -169,8 +182,13 @@ in }; plugins = mkOption { - type = types.listOf (types.oneOf [types.path types.package]); - default = []; + type = types.listOf ( + types.oneOf [ + types.path + types.package + ] + ); + default = [ ]; example = "[ ./com.github.moussetc.mattermost.plugin.giphy-2.0.0.tar.gz ]"; description = '' Plugins to add to the configuration. Overrides any installed if non-null. @@ -249,7 +267,10 @@ in parameters = mkOption { type = types.listOf types.str; default = [ ]; - example = [ "-mmserver chat.example.com" "-bind [::]:6667" ]; + example = [ + "-mmserver chat.example.com" + "-bind [::]:6667" + ]; description = '' Set commandline parameters to pass to matterircd. See https://github.com/42wim/matterircd#usage for more information. @@ -282,38 +303,48 @@ in systemd.services.mattermost = { description = "Mattermost chat service"; wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "postgresql.service" ]; - - preStart = '' - mkdir -p "${cfg.statePath}"/{data,config,logs,plugins} - mkdir -p "${cfg.statePath}/plugins"/{client,server} - ln -sf ${cfg.package}/{bin,fonts,i18n,templates,client} "${cfg.statePath}" - '' + lib.optionalString (mattermostPlugins != null) '' - rm -rf "${cfg.statePath}/data/plugins" - ln -sf ${mattermostPlugins}/data/plugins "${cfg.statePath}/data" - '' + lib.optionalString (!cfg.mutableConfig) '' - rm -f "${cfg.statePath}/config/config.json" - ${pkgs.jq}/bin/jq -s '.[0] * .[1]' ${cfg.package}/config/config.json ${mattermostConfJSON} > "${cfg.statePath}/config/config.json" - '' + lib.optionalString cfg.mutableConfig '' - if ! test -e "${cfg.statePath}/config/.initial-created"; then - rm -f ${cfg.statePath}/config/config.json + after = [ + "network.target" + "postgresql.service" + ]; + + preStart = + '' + mkdir -p "${cfg.statePath}"/{data,config,logs,plugins} + mkdir -p "${cfg.statePath}/plugins"/{client,server} + ln -sf ${cfg.package}/{bin,fonts,i18n,templates,client} "${cfg.statePath}" + '' + + lib.optionalString (mattermostPlugins != null) '' + rm -rf "${cfg.statePath}/data/plugins" + ln -sf ${mattermostPlugins}/data/plugins "${cfg.statePath}/data" + '' + + lib.optionalString (!cfg.mutableConfig) '' + rm -f "${cfg.statePath}/config/config.json" ${pkgs.jq}/bin/jq -s '.[0] * .[1]' ${cfg.package}/config/config.json ${mattermostConfJSON} > "${cfg.statePath}/config/config.json" - touch "${cfg.statePath}/config/.initial-created" - fi - '' + lib.optionalString (cfg.mutableConfig && cfg.preferNixConfig) '' - new_config="$(${pkgs.jq}/bin/jq -s '.[0] * .[1]' "${cfg.statePath}/config/config.json" ${mattermostConfJSON})" - - rm -f "${cfg.statePath}/config/config.json" - echo "$new_config" > "${cfg.statePath}/config/config.json" - '' + lib.optionalString cfg.localDatabaseCreate (createDb {}) + '' - # Don't change permissions recursively on the data, current, and symlinked directories (see ln -sf command above). - # This dramatically decreases startup times for installations with a lot of files. - find . -maxdepth 1 -not -name data -not -name client -not -name templates -not -name i18n -not -name fonts -not -name bin -not -name . \ - -exec chown "${cfg.user}:${cfg.group}" -R {} \; -exec chmod u+rw,g+r,o-rwx -R {} \; - - chown "${cfg.user}:${cfg.group}" "${cfg.statePath}/data" . - chmod u+rw,g+r,o-rwx "${cfg.statePath}/data" . - ''; + '' + + lib.optionalString cfg.mutableConfig '' + if ! test -e "${cfg.statePath}/config/.initial-created"; then + rm -f ${cfg.statePath}/config/config.json + ${pkgs.jq}/bin/jq -s '.[0] * .[1]' ${cfg.package}/config/config.json ${mattermostConfJSON} > "${cfg.statePath}/config/config.json" + touch "${cfg.statePath}/config/.initial-created" + fi + '' + + lib.optionalString (cfg.mutableConfig && cfg.preferNixConfig) '' + new_config="$(${pkgs.jq}/bin/jq -s '.[0] * .[1]' "${cfg.statePath}/config/config.json" ${mattermostConfJSON})" + + rm -f "${cfg.statePath}/config/config.json" + echo "$new_config" > "${cfg.statePath}/config/config.json" + '' + + lib.optionalString cfg.localDatabaseCreate (createDb { }) + + '' + # Don't change permissions recursively on the data, current, and symlinked directories (see ln -sf command above). + # This dramatically decreases startup times for installations with a lot of files. + find . -maxdepth 1 -not -name data -not -name client -not -name templates -not -name i18n -not -name fonts -not -name bin -not -name . \ + -exec chown "${cfg.user}:${cfg.group}" -R {} \; -exec chmod u+rw,g+r,o-rwx -R {} \; + + chown "${cfg.user}:${cfg.group}" "${cfg.statePath}/data" . + chmod u+rw,g+r,o-rwx "${cfg.statePath}/data" . + ''; serviceConfig = { PermissionsStartOnly = true; diff --git a/nixos/modules/services/web-apps/mealie.nix b/nixos/modules/services/web-apps/mealie.nix index ab94103954e138..48b0450eac2db0 100644 --- a/nixos/modules/services/web-apps/mealie.nix +++ b/nixos/modules/services/web-apps/mealie.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.mealie; pkg = cfg.package; @@ -23,7 +28,7 @@ in settings = lib.mkOption { type = with lib.types; attrsOf anything; - default = {}; + default = { }; description = '' Configuration of the Mealie service. @@ -70,7 +75,7 @@ in ExecStart = "${lib.getExe pkg} -b ${cfg.listenAddress}:${builtins.toString cfg.port}"; EnvironmentFile = lib.mkIf (cfg.credentialsFile != null) cfg.credentialsFile; StateDirectory = "mealie"; - StandardOutput="journal"; + StandardOutput = "journal"; }; }; }; diff --git a/nixos/modules/services/web-apps/meme-bingo-web.nix b/nixos/modules/services/web-apps/meme-bingo-web.nix index 4623bc22c26ffe..68be85906075f0 100644 --- a/nixos/modules/services/web-apps/meme-bingo-web.nix +++ b/nixos/modules/services/web-apps/meme-bingo-web.nix @@ -1,10 +1,23 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkPackageOption mkIf mkOption types literalExpression; + inherit (lib) + mkEnableOption + mkPackageOption + mkIf + mkOption + types + literalExpression + ; cfg = config.services.meme-bingo-web; -in { +in +{ options = { services.meme-bingo-web = { enable = mkEnableOption '' @@ -59,7 +72,10 @@ in { # Hardening CapabilityBoundingSet = [ "" ]; DeviceAllow = [ "/dev/random" ]; - InaccessiblePaths = [ "/dev/shm" "/sys" ]; + InaccessiblePaths = [ + "/dev/shm" + "/sys" + ]; LockPersonality = true; PrivateDevices = true; PrivateUsers = true; @@ -73,12 +89,22 @@ in { ProtectKernelModules = true; ProtectKernelTunables = true; ProtectProc = "invisible"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; - RestrictFilesystems = [ "@basic-api" "~sysfs" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; + RestrictFilesystems = [ + "@basic-api" + "~sysfs" + ]; RestrictNamespaces = true; RestrictRealtime = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" "~@resources" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "~@resources" + ]; UMask = "0077"; RestrictSUIDSGID = true; RemoveIPC = true; diff --git a/nixos/modules/services/web-apps/microbin.nix b/nixos/modules/services/web-apps/microbin.nix index e404609a4c22b9..18a4d482a52405 100644 --- a/nixos/modules/services/web-apps/microbin.nix +++ b/nixos/modules/services/web-apps/microbin.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.microbin; @@ -10,7 +15,15 @@ in package = lib.mkPackageOption pkgs "microbin" { }; settings = lib.mkOption { - type = lib.types.submodule { freeformType = with lib.types; attrsOf (oneOf [ bool int str ]); }; + type = lib.types.submodule { + freeformType = + with lib.types; + attrsOf (oneOf [ + bool + int + str + ]); + }; default = { }; example = { MICROBIN_PORT = 8080; @@ -59,7 +72,9 @@ in systemd.services.microbin = { after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; - environment = lib.mapAttrs (_: v: if lib.isBool v then lib.boolToString v else toString v) cfg.settings; + environment = lib.mapAttrs ( + _: v: if lib.isBool v then lib.boolToString v else toString v + ) cfg.settings; serviceConfig = { DevicePolicy = "closed"; DynamicUser = true; @@ -77,7 +92,10 @@ in ProtectKernelTunables = true; ProtectProc = "invisible"; ReadWritePaths = cfg.dataDir; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictNamespaces = true; RestrictRealtime = true; StateDirectory = "microbin"; diff --git a/nixos/modules/services/web-apps/miniflux.nix b/nixos/modules/services/web-apps/miniflux.nix index b733ceec74dbe3..8cacaa5aa330ad 100644 --- a/nixos/modules/services/web-apps/miniflux.nix +++ b/nixos/modules/services/web-apps/miniflux.nix @@ -1,7 +1,20 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkPackageOption mkOption types literalExpression mkIf mkDefault; + inherit (lib) + mkEnableOption + mkPackageOption + mkOption + types + literalExpression + mkIf + mkDefault + ; cfg = config.services.miniflux; defaultAddress = "localhost:8080"; @@ -31,7 +44,12 @@ in }; config = mkOption { - type = with types; attrsOf (oneOf [ str int ]); + type = + with types; + attrsOf (oneOf [ + str + int + ]); example = literalExpression '' { CLEANUP_FREQUENCY = 48; @@ -63,7 +81,8 @@ in config = mkIf cfg.enable { assertions = [ - { assertion = cfg.config.CREATE_ADMIN == 0 || cfg.adminCredentialsFile != null; + { + assertion = cfg.config.CREATE_ADMIN == 0 || cfg.adminCredentialsFile != null; message = "services.miniflux.adminCredentialsFile must be set if services.miniflux.config.CREATE_ADMIN is 1"; } ]; @@ -77,17 +96,22 @@ in services.postgresql = lib.mkIf cfg.createDatabaseLocally { enable = true; - ensureUsers = [ { - name = "miniflux"; - ensureDBOwnership = true; - } ]; + ensureUsers = [ + { + name = "miniflux"; + ensureDBOwnership = true; + } + ]; ensureDatabases = [ "miniflux" ]; }; systemd.services.miniflux-dbsetup = lib.mkIf cfg.createDatabaseLocally { description = "Miniflux database setup"; requires = [ "postgresql.service" ]; - after = [ "network.target" "postgresql.service" ]; + after = [ + "network.target" + "postgresql.service" + ]; serviceConfig = { Type = "oneshot"; User = config.services.postgresql.superUser; @@ -99,8 +123,12 @@ in description = "Miniflux service"; wantedBy = [ "multi-user.target" ]; requires = lib.optional cfg.createDatabaseLocally "miniflux-dbsetup.service"; - after = [ "network.target" ] - ++ lib.optionals cfg.createDatabaseLocally [ "postgresql.service" "miniflux-dbsetup.service" ]; + after = + [ "network.target" ] + ++ lib.optionals cfg.createDatabaseLocally [ + "postgresql.service" + "miniflux-dbsetup.service" + ]; serviceConfig = { Type = "notify"; @@ -131,12 +159,19 @@ in ProtectKernelModules = true; ProtectKernelTunables = true; ProtectProc = "invisible"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; UMask = "0077"; }; diff --git a/nixos/modules/services/web-apps/mobilizon.nix b/nixos/modules/services/web-apps/mobilizon.nix index 122e55ac912af8..d70c50d981dee9 100644 --- a/nixos/modules/services/web-apps/mobilizon.nix +++ b/nixos/modules/services/web-apps/mobilizon.nix @@ -1,4 +1,9 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: with lib; @@ -104,7 +109,16 @@ in }; ip = mkOption { type = elixirTypes.tuple; - default = settingsFormat.lib.mkTuple [ 0 0 0 0 0 0 0 1 ]; + default = settingsFormat.lib.mkTuple [ + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 1 + ]; description = '' The IP address to listen on. Defaults to [::1] notated as a byte tuple. ''; @@ -208,7 +222,20 @@ in assertions = [ { - assertion = cfg.nginx.enable -> (cfg.settings.":mobilizon"."Mobilizon.Web.Endpoint".http.ip == settingsFormat.lib.mkTuple [ 0 0 0 0 0 0 0 1 ]); + assertion = + cfg.nginx.enable + -> ( + cfg.settings.":mobilizon"."Mobilizon.Web.Endpoint".http.ip == settingsFormat.lib.mkTuple [ + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 1 + ] + ); message = "Setting the IP mobilizon listens on is only possible when the nginx config is not used, as it is hardcoded there."; } ]; @@ -218,12 +245,12 @@ in "Mobilizon.Web.Endpoint" = { server = true; url.host = mkDefault instanceSettings.hostname; - secret_key_base = - settingsFormat.lib.mkGetEnv { envVariable = "MOBILIZON_INSTANCE_SECRET"; }; + secret_key_base = settingsFormat.lib.mkGetEnv { envVariable = "MOBILIZON_INSTANCE_SECRET"; }; }; - "Mobilizon.Web.Auth.Guardian".secret_key = - settingsFormat.lib.mkGetEnv { envVariable = "MOBILIZON_AUTH_SECRET"; }; + "Mobilizon.Web.Auth.Guardian".secret_key = settingsFormat.lib.mkGetEnv { + envVariable = "MOBILIZON_AUTH_SECRET"; + }; ":instance" = { registrations_open = mkDefault false; @@ -299,9 +326,7 @@ in # Taken from here: # https://framagit.org/framasoft/mobilizon/-/blob/1.0.7/lib/mix/tasks/mobilizon/instance.ex#L132-133 genSecret = - "IO.puts(:crypto.strong_rand_bytes(64)" + - "|> Base.encode64()" + - "|> binary_part(0, 64))"; + "IO.puts(:crypto.strong_rand_bytes(64)" + "|> Base.encode64()" + "|> binary_part(0, 64))"; # Taken from here: # https://github.com/elixir-lang/elixir/blob/v1.11.3/lib/mix/lib/mix/release.ex#L499 @@ -339,7 +364,10 @@ in description = "Mobilizon PostgreSQL setup"; after = [ "postgresql.service" ]; - before = [ "mobilizon.service" "mobilizon-setup-secrets.service" ]; + before = [ + "mobilizon.service" + "mobilizon-setup-secrets.service" + ]; wantedBy = [ "mobilizon.service" ]; path = [ postgresql ]; @@ -350,15 +378,14 @@ in # as PostgreSQL 15 changed their behaviors w.r.t. to privileges. # See https://github.com/NixOS/nixpkgs/issues/216989 to get rid # of that workaround. - script = - '' - psql "${repoSettings.database}" -c "\ - CREATE EXTENSION IF NOT EXISTS postgis; \ - CREATE EXTENSION IF NOT EXISTS pg_trgm; \ - CREATE EXTENSION IF NOT EXISTS unaccent;" - psql -tAc 'ALTER DATABASE "${repoSettings.database}" OWNER TO "${dbUser}";' + script = '' + psql "${repoSettings.database}" -c "\ + CREATE EXTENSION IF NOT EXISTS postgis; \ + CREATE EXTENSION IF NOT EXISTS pg_trgm; \ + CREATE EXTENSION IF NOT EXISTS unaccent;" + psql -tAc 'ALTER DATABASE "${repoSettings.database}" OWNER TO "${dbUser}";' - ''; + ''; serviceConfig = { Type = "oneshot"; @@ -390,8 +417,7 @@ in services.nginx = let inherit (cfg.settings.":mobilizon".":instance") hostname; - proxyPass = "http://[::1]:" - + toString cfg.settings.":mobilizon"."Mobilizon.Web.Endpoint".http.port; + proxyPass = "http://[::1]:" + toString cfg.settings.":mobilizon"."Mobilizon.Web.Endpoint".http.port; in lib.mkIf cfg.nginx.enable { enable = true; @@ -444,5 +470,8 @@ in environment.systemPackages = [ launchers ]; }; - meta.maintainers = with lib.maintainers; [ minijackson erictapen ]; + meta.maintainers = with lib.maintainers; [ + minijackson + erictapen + ]; } diff --git a/nixos/modules/services/web-apps/moodle.nix b/nixos/modules/services/web-apps/moodle.nix index 9a66591badb5a1..e49f7a89d0de01 100644 --- a/nixos/modules/services/web-apps/moodle.nix +++ b/nixos/modules/services/web-apps/moodle.nix @@ -1,8 +1,28 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkDefault mkEnableOption mkPackageOption mkForce mkIf mkMerge mkOption types; - inherit (lib) concatStringsSep literalExpression mapAttrsToList optional optionalString; + inherit (lib) + mkDefault + mkEnableOption + mkPackageOption + mkForce + mkIf + mkMerge + mkOption + types + ; + inherit (lib) + concatStringsSep + literalExpression + mapAttrsToList + optional + optionalString + ; cfg = config.services.moodle; fpm = config.services.phpfpm.pools.moodle; @@ -12,52 +32,97 @@ let stateDir = "/var/lib/moodle"; moodleConfig = pkgs.writeText "config.php" '' - dbtype = '${ { mysql = "mariadb"; pgsql = "pgsql"; }.${cfg.database.type} }'; - $CFG->dblibrary = 'native'; - $CFG->dbhost = '${cfg.database.host}'; - $CFG->dbname = '${cfg.database.name}'; - $CFG->dbuser = '${cfg.database.user}'; - ${optionalString (cfg.database.passwordFile != null) "$CFG->dbpass = file_get_contents('${cfg.database.passwordFile}');"} - $CFG->prefix = 'mdl_'; - $CFG->dboptions = array ( - 'dbpersist' => 0, - 'dbport' => '${toString cfg.database.port}', - ${optionalString (cfg.database.socket != null) "'dbsocket' => '${cfg.database.socket}',"} - 'dbcollation' => 'utf8mb4_unicode_ci', - ); - - $CFG->wwwroot = '${if cfg.virtualHost.addSSL || cfg.virtualHost.forceSSL || cfg.virtualHost.onlySSL then "https" else "http"}://${cfg.virtualHost.hostName}'; - $CFG->dataroot = '${stateDir}'; - $CFG->admin = 'admin'; - - $CFG->directorypermissions = 02777; - $CFG->disableupdateautodeploy = true; - - $CFG->pathtogs = '${pkgs.ghostscript}/bin/gs'; - $CFG->pathtophp = '${phpExt}/bin/php'; - $CFG->pathtodu = '${pkgs.coreutils}/bin/du'; - $CFG->aspellpath = '${pkgs.aspell}/bin/aspell'; - $CFG->pathtodot = '${pkgs.graphviz}/bin/dot'; - - ${cfg.extraConfig} - - require_once('${cfg.package}/share/moodle/lib/setup.php'); - - // There is no php closing tag in this file, - // it is intentional because it prevents trailing whitespace problems! + dbtype = '${ + { + mysql = "mariadb"; + pgsql = "pgsql"; + } + .${cfg.database.type} + }'; + $CFG->dblibrary = 'native'; + $CFG->dbhost = '${cfg.database.host}'; + $CFG->dbname = '${cfg.database.name}'; + $CFG->dbuser = '${cfg.database.user}'; + ${optionalString ( + cfg.database.passwordFile != null + ) "$CFG->dbpass = file_get_contents('${cfg.database.passwordFile}');"} + $CFG->prefix = 'mdl_'; + $CFG->dboptions = array ( + 'dbpersist' => 0, + 'dbport' => '${toString cfg.database.port}', + ${optionalString (cfg.database.socket != null) "'dbsocket' => '${cfg.database.socket}',"} + 'dbcollation' => 'utf8mb4_unicode_ci', + ); + + $CFG->wwwroot = '${ + if cfg.virtualHost.addSSL || cfg.virtualHost.forceSSL || cfg.virtualHost.onlySSL then + "https" + else + "http" + }://${cfg.virtualHost.hostName}'; + $CFG->dataroot = '${stateDir}'; + $CFG->admin = 'admin'; + + $CFG->directorypermissions = 02777; + $CFG->disableupdateautodeploy = true; + + $CFG->pathtogs = '${pkgs.ghostscript}/bin/gs'; + $CFG->pathtophp = '${phpExt}/bin/php'; + $CFG->pathtodu = '${pkgs.coreutils}/bin/du'; + $CFG->aspellpath = '${pkgs.aspell}/bin/aspell'; + $CFG->pathtodot = '${pkgs.graphviz}/bin/dot'; + + ${cfg.extraConfig} + + require_once('${cfg.package}/share/moodle/lib/setup.php'); + + // There is no php closing tag in this file, + // it is intentional because it prevents trailing whitespace problems! ''; mysqlLocal = cfg.database.createLocally && cfg.database.type == "mysql"; pgsqlLocal = cfg.database.createLocally && cfg.database.type == "pgsql"; phpExt = pkgs.php83.buildEnv { - extensions = { all, ... }: with all; [ iconv mbstring curl openssl tokenizer soap ctype zip gd simplexml dom intl sqlite3 pgsql pdo_sqlite pdo_pgsql pdo_odbc pdo_mysql pdo mysqli session zlib xmlreader fileinfo filter opcache exif sodium ]; + extensions = + { all, ... }: + with all; + [ + iconv + mbstring + curl + openssl + tokenizer + soap + ctype + zip + gd + simplexml + dom + intl + sqlite3 + pgsql + pdo_sqlite + pdo_pgsql + pdo_odbc + pdo_mysql + pdo + mysqli + session + zlib + xmlreader + fileinfo + filter + opcache + exif + sodium + ]; extraConfig = "max_input_vars = 5000"; }; in @@ -79,7 +144,10 @@ in database = { type = mkOption { - type = types.enum [ "mysql" "pgsql" ]; + type = types.enum [ + "mysql" + "pgsql" + ]; default = "mysql"; description = "Database engine to use."; }; @@ -93,10 +161,12 @@ in port = mkOption { type = types.port; description = "Database host port."; - default = { - mysql = 3306; - pgsql = 5432; - }.${cfg.database.type}; + default = + { + mysql = 3306; + pgsql = 5432; + } + .${cfg.database.type}; defaultText = literalExpression "3306"; }; @@ -125,9 +195,12 @@ in socket = mkOption { type = types.nullOr types.path; default = - if mysqlLocal then "/run/mysqld/mysqld.sock" - else if pgsqlLocal then "/run/postgresql" - else null; + if mysqlLocal then + "/run/mysqld/mysqld.sock" + else if pgsqlLocal then + "/run/postgresql" + else + null; defaultText = literalExpression "/run/mysqld/mysqld.sock"; description = "Path to the unix socket file to use for authentication."; }; @@ -156,7 +229,13 @@ in }; poolConfig = mkOption { - type = with types; attrsOf (oneOf [ str int bool ]); + type = + with types; + attrsOf (oneOf [ + str + int + bool + ]); default = { "pm" = "dynamic"; "pm.max_children" = 32; @@ -189,10 +268,13 @@ in config = mkIf cfg.enable { assertions = [ - { assertion = cfg.database.createLocally -> cfg.database.user == user && cfg.database.user == cfg.database.name; + { + assertion = + cfg.database.createLocally -> cfg.database.user == user && cfg.database.user == cfg.database.name; message = "services.moodle.database.user must be set to ${user} if services.moodle.database.createLocally is set true"; } - { assertion = cfg.database.createLocally -> cfg.database.passwordFile == null; + { + assertion = cfg.database.createLocally -> cfg.database.passwordFile == null; message = "a password cannot be specified if services.moodle.database.createLocally is set to true"; } ]; @@ -202,9 +284,11 @@ in package = mkDefault pkgs.mariadb; ensureDatabases = [ cfg.database.name ]; ensureUsers = [ - { name = cfg.database.user; + { + name = cfg.database.user; ensurePermissions = { - "${cfg.database.name}.*" = "SELECT, INSERT, UPDATE, DELETE, CREATE, CREATE TEMPORARY TABLES, DROP, INDEX, ALTER"; + "${cfg.database.name}.*" = + "SELECT, INSERT, UPDATE, DELETE, CREATE, CREATE TEMPORARY TABLES, DROP, INDEX, ALTER"; }; } ]; @@ -214,7 +298,8 @@ in enable = true; ensureDatabases = [ cfg.database.name ]; ensureUsers = [ - { name = cfg.database.user; + { + name = cfg.database.user; ensureDBOwnership = true; } ]; @@ -239,20 +324,23 @@ in enable = true; adminAddr = mkDefault cfg.virtualHost.adminAddr; extraModules = [ "proxy_fcgi" ]; - virtualHosts.${cfg.virtualHost.hostName} = mkMerge [ cfg.virtualHost { - documentRoot = mkForce "${cfg.package}/share/moodle"; - extraConfig = '' - - - - SetHandler "proxy:unix:${fpm.socket}|fcgi://localhost/" - - - Options -Indexes - DirectoryIndex index.php - - ''; - } ]; + virtualHosts.${cfg.virtualHost.hostName} = mkMerge [ + cfg.virtualHost + { + documentRoot = mkForce "${cfg.package}/share/moodle"; + extraConfig = '' + + + + SetHandler "proxy:unix:${fpm.socket}|fcgi://localhost/" + + + Options -Indexes + DirectoryIndex index.php + + ''; + } + ]; }; systemd.tmpfiles.settings."10-moodle".${stateDir}.d = { @@ -304,7 +392,9 @@ in }; }; - systemd.services.httpd.after = optional mysqlLocal "mysql.service" ++ optional pgsqlLocal "postgresql.service"; + systemd.services.httpd.after = + optional mysqlLocal "mysql.service" + ++ optional pgsqlLocal "postgresql.service"; users.users.${user} = { group = group; diff --git a/nixos/modules/services/web-apps/netbox.nix b/nixos/modules/services/web-apps/netbox.nix index 6f5e1536d61640..e0e01026e7adc1 100644 --- a/nixos/modules/services/web-apps/netbox.nix +++ b/nixos/modules/services/web-apps/netbox.nix @@ -1,8 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.netbox; - pythonFmt = pkgs.formats.pythonVars {}; + pythonFmt = pkgs.formats.pythonVars { }; staticDir = cfg.dataDir + "/static"; settingsFile = pythonFmt.generate "netbox-settings.py" cfg.settings; @@ -10,24 +15,35 @@ let name = "netbox-extraConfig.py"; text = cfg.extraConfig; }; - configFile = pkgs.concatText "configuration.py" [ settingsFile extraConfigFile ]; - - pkg = (cfg.package.overrideAttrs (old: { - installPhase = old.installPhase + '' - ln -s ${configFile} $out/opt/netbox/netbox/netbox/configuration.py - '' + lib.optionalString cfg.enableLdap '' - ln -s ${cfg.ldapConfigPath} $out/opt/netbox/netbox/netbox/ldap_config.py - ''; - })).override { - inherit (cfg) plugins; - }; - netboxManageScript = with pkgs; (writeScriptBin "netbox-manage" '' - #!${stdenv.shell} - export PYTHONPATH=${pkg.pythonPath} - sudo -u netbox ${pkg}/bin/netbox "$@" - ''); - -in { + configFile = pkgs.concatText "configuration.py" [ + settingsFile + extraConfigFile + ]; + + pkg = + (cfg.package.overrideAttrs (old: { + installPhase = + old.installPhase + + '' + ln -s ${configFile} $out/opt/netbox/netbox/netbox/configuration.py + '' + + lib.optionalString cfg.enableLdap '' + ln -s ${cfg.ldapConfigPath} $out/opt/netbox/netbox/netbox/ldap_config.py + ''; + })).override + { + inherit (cfg) plugins; + }; + netboxManageScript = + with pkgs; + (writeScriptBin "netbox-manage" '' + #!${stdenv.shell} + export PYTHONPATH=${pkg.pythonPath} + sudo -u netbox ${pkg}/bin/netbox "$@" + ''); + +in +{ options.services.netbox = { enable = lib.mkOption { type = lib.types.bool; @@ -54,7 +70,7 @@ in { options = { ALLOWED_HOSTS = lib.mkOption { type = with lib.types; listOf str; - default = ["*"]; + default = [ "*" ]; description = '' A list of valid fully-qualified domain names (FQDNs) and/or IP addresses that can be used to reach the NetBox service. @@ -75,11 +91,12 @@ in { package = lib.mkOption { type = lib.types.package; default = - if lib.versionAtLeast config.system.stateVersion "24.11" - then pkgs.netbox_4_1 - else if lib.versionAtLeast config.system.stateVersion "24.05" - then pkgs.netbox_3_7 - else pkgs.netbox_3_6; + if lib.versionAtLeast config.system.stateVersion "24.11" then + pkgs.netbox_4_1 + else if lib.versionAtLeast config.system.stateVersion "24.05" then + pkgs.netbox_3_7 + else + pkgs.netbox_3_6; defaultText = lib.literalExpression '' if lib.versionAtLeast config.system.stateVersion "24.11" then pkgs.netbox_4_1 @@ -102,7 +119,7 @@ in { plugins = lib.mkOption { type = with lib.types; functionTo (listOf package); - default = _: []; + default = _: [ ]; defaultText = lib.literalExpression '' python3Packages: with python3Packages; []; ''; @@ -210,14 +227,14 @@ in { # sections, and it is strongly recommended to use two separate database # IDs. REDIS = { - tasks = { - URL = "unix://${config.services.redis.servers.netbox.unixSocket}?db=0"; - SSL = false; - }; - caching = { - URL = "unix://${config.services.redis.servers.netbox.unixSocket}?db=1"; - SSL = false; - }; + tasks = { + URL = "unix://${config.services.redis.servers.netbox.unixSocket}?db=0"; + SSL = false; + }; + caching = { + URL = "unix://${config.services.redis.servers.netbox.unixSocket}?db=1"; + SSL = false; + }; }; REMOTE_AUTH_BACKEND = lib.mkIf cfg.enableLdap "netbox.authentication.LDAPBackend"; @@ -240,13 +257,15 @@ in { }; }; - extraConfig = '' - with open("${cfg.secretKeyFile}", "r") as file: - SECRET_KEY = file.readline() - '' + (lib.optionalString (cfg.keycloakClientSecret != null) '' - with open("${cfg.keycloakClientSecret}", "r") as file: - SOCIAL_AUTH_KEYCLOAK_SECRET = file.readline() - ''); + extraConfig = + '' + with open("${cfg.secretKeyFile}", "r") as file: + SECRET_KEY = file.readline() + '' + + (lib.optionalString (cfg.keycloakClientSecret != null) '' + with open("${cfg.keycloakClientSecret}", "r") as file: + SOCIAL_AUTH_KEYCLOAK_SECRET = file.readline() + ''); }; services.redis.servers.netbox.enable = true; @@ -268,102 +287,111 @@ in { description = "Target for all NetBox services"; wantedBy = [ "multi-user.target" ]; wants = [ "network-online.target" ]; - after = [ "network-online.target" "redis-netbox.service" ]; + after = [ + "network-online.target" + "redis-netbox.service" + ]; }; - systemd.services = let - defaultServiceConfig = { - WorkingDirectory = "${cfg.dataDir}"; - User = "netbox"; - Group = "netbox"; - StateDirectory = "netbox"; - StateDirectoryMode = "0750"; - Restart = "on-failure"; - RestartSec = 30; - }; - in { - netbox = { - description = "NetBox WSGI Service"; - documentation = [ "https://docs.netbox.dev/" ]; - - wantedBy = [ "netbox.target" ]; - - after = [ "network-online.target" ]; - wants = [ "network-online.target" ]; - - environment.PYTHONPATH = pkg.pythonPath; - - preStart = '' - # On the first run, or on upgrade / downgrade, run migrations and related. - # This mostly correspond to upstream NetBox's 'upgrade.sh' script. - versionFile="${cfg.dataDir}/version" - - if [[ -h "$versionFile" && "$(readlink -- "$versionFile")" == "${cfg.package}" ]]; then - exit 0 - fi - - ${pkg}/bin/netbox migrate - ${pkg}/bin/netbox trace_paths --no-input - ${pkg}/bin/netbox collectstatic --clear --no-input - ${pkg}/bin/netbox remove_stale_contenttypes --no-input - ${pkg}/bin/netbox reindex --lazy - ${pkg}/bin/netbox clearsessions - ${lib.optionalString - # The clearcache command was removed in 3.7.0: - # https://github.com/netbox-community/netbox/issues/14458 - (lib.versionOlder cfg.package.version "3.7.0") - "${pkg}/bin/netbox clearcache"} - - ln -sfn "${cfg.package}" "$versionFile" - ''; - - serviceConfig = defaultServiceConfig // { - ExecStart = '' - ${pkg.gunicorn}/bin/gunicorn netbox.wsgi \ - --bind ${cfg.listenAddress}:${toString cfg.port} \ - --pythonpath ${pkg}/opt/netbox/netbox + systemd.services = + let + defaultServiceConfig = { + WorkingDirectory = "${cfg.dataDir}"; + User = "netbox"; + Group = "netbox"; + StateDirectory = "netbox"; + StateDirectoryMode = "0750"; + Restart = "on-failure"; + RestartSec = 30; + }; + in + { + netbox = { + description = "NetBox WSGI Service"; + documentation = [ "https://docs.netbox.dev/" ]; + + wantedBy = [ "netbox.target" ]; + + after = [ "network-online.target" ]; + wants = [ "network-online.target" ]; + + environment.PYTHONPATH = pkg.pythonPath; + + preStart = '' + # On the first run, or on upgrade / downgrade, run migrations and related. + # This mostly correspond to upstream NetBox's 'upgrade.sh' script. + versionFile="${cfg.dataDir}/version" + + if [[ -h "$versionFile" && "$(readlink -- "$versionFile")" == "${cfg.package}" ]]; then + exit 0 + fi + + ${pkg}/bin/netbox migrate + ${pkg}/bin/netbox trace_paths --no-input + ${pkg}/bin/netbox collectstatic --clear --no-input + ${pkg}/bin/netbox remove_stale_contenttypes --no-input + ${pkg}/bin/netbox reindex --lazy + ${pkg}/bin/netbox clearsessions + ${lib.optionalString + # The clearcache command was removed in 3.7.0: + # https://github.com/netbox-community/netbox/issues/14458 + (lib.versionOlder cfg.package.version "3.7.0") + "${pkg}/bin/netbox clearcache" + } + + ln -sfn "${cfg.package}" "$versionFile" ''; - PrivateTmp = true; - TimeoutStartSec = lib.mkDefault "5min"; + + serviceConfig = defaultServiceConfig // { + ExecStart = '' + ${pkg.gunicorn}/bin/gunicorn netbox.wsgi \ + --bind ${cfg.listenAddress}:${toString cfg.port} \ + --pythonpath ${pkg}/opt/netbox/netbox + ''; + PrivateTmp = true; + TimeoutStartSec = lib.mkDefault "5min"; + }; }; - }; - netbox-rq = { - description = "NetBox Request Queue Worker"; - documentation = [ "https://docs.netbox.dev/" ]; + netbox-rq = { + description = "NetBox Request Queue Worker"; + documentation = [ "https://docs.netbox.dev/" ]; - wantedBy = [ "netbox.target" ]; - after = [ "netbox.service" ]; + wantedBy = [ "netbox.target" ]; + after = [ "netbox.service" ]; - environment.PYTHONPATH = pkg.pythonPath; + environment.PYTHONPATH = pkg.pythonPath; - serviceConfig = defaultServiceConfig // { - ExecStart = '' - ${pkg}/bin/netbox rqworker high default low - ''; - PrivateTmp = true; + serviceConfig = defaultServiceConfig // { + ExecStart = '' + ${pkg}/bin/netbox rqworker high default low + ''; + PrivateTmp = true; + }; }; - }; - netbox-housekeeping = { - description = "NetBox housekeeping job"; - documentation = [ "https://docs.netbox.dev/" ]; + netbox-housekeeping = { + description = "NetBox housekeeping job"; + documentation = [ "https://docs.netbox.dev/" ]; - wantedBy = [ "multi-user.target" ]; + wantedBy = [ "multi-user.target" ]; - after = [ "network-online.target" "netbox.service" ]; - wants = [ "network-online.target" ]; + after = [ + "network-online.target" + "netbox.service" + ]; + wants = [ "network-online.target" ]; - environment.PYTHONPATH = pkg.pythonPath; + environment.PYTHONPATH = pkg.pythonPath; - serviceConfig = defaultServiceConfig // { - Type = "oneshot"; - ExecStart = '' - ${pkg}/bin/netbox housekeeping - ''; + serviceConfig = defaultServiceConfig // { + Type = "oneshot"; + ExecStart = '' + ${pkg}/bin/netbox housekeeping + ''; + }; }; }; - }; systemd.timers.netbox-housekeeping = { description = "Run NetBox housekeeping job"; @@ -371,7 +399,10 @@ in { wantedBy = [ "multi-user.target" ]; - after = [ "network-online.target" "netbox.service" ]; + after = [ + "network-online.target" + "netbox.service" + ]; wants = [ "network-online.target" ]; timerConfig = { @@ -386,7 +417,7 @@ in { isSystemUser = true; group = "netbox"; }; - users.groups.netbox = {}; + users.groups.netbox = { }; users.groups."${config.services.redis.servers.netbox.user}".members = [ "netbox" ]; }; } diff --git a/nixos/modules/services/web-apps/nextcloud-notify_push.nix b/nixos/modules/services/web-apps/nextcloud-notify_push.nix index 475cddf5f751f4..f7ad98e16d3382 100644 --- a/nixos/modules/services/web-apps/nextcloud-notify_push.nix +++ b/nixos/modules/services/web-apps/nextcloud-notify_push.nix @@ -1,112 +1,136 @@ -{ config, options, lib, pkgs, ... }: +{ + config, + options, + lib, + pkgs, + ... +}: let cfg = config.services.nextcloud.notify_push; cfgN = config.services.nextcloud; in { - options.services.nextcloud.notify_push = { - enable = lib.mkEnableOption "Notify push"; + options.services.nextcloud.notify_push = + { + enable = lib.mkEnableOption "Notify push"; - package = lib.mkOption { - type = lib.types.package; - default = pkgs.nextcloud-notify_push; - defaultText = lib.literalMD "pkgs.nextcloud-notify_push"; - description = "Which package to use for notify_push"; - }; + package = lib.mkOption { + type = lib.types.package; + default = pkgs.nextcloud-notify_push; + defaultText = lib.literalMD "pkgs.nextcloud-notify_push"; + description = "Which package to use for notify_push"; + }; - socketPath = lib.mkOption { - type = lib.types.str; - default = "/run/nextcloud-notify_push/sock"; - description = "Socket path to use for notify_push"; - }; + socketPath = lib.mkOption { + type = lib.types.str; + default = "/run/nextcloud-notify_push/sock"; + description = "Socket path to use for notify_push"; + }; - logLevel = lib.mkOption { - type = lib.types.enum [ "error" "warn" "info" "debug" "trace" ]; - default = "error"; - description = "Log level"; - }; + logLevel = lib.mkOption { + type = lib.types.enum [ + "error" + "warn" + "info" + "debug" + "trace" + ]; + default = "error"; + description = "Log level"; + }; - bendDomainToLocalhost = lib.mkOption { - type = lib.types.bool; - default = false; - description = '' - Whether to add an entry to `/etc/hosts` for the configured nextcloud domain to point to `localhost` and add `localhost `to nextcloud's `trusted_proxies` config option. + bendDomainToLocalhost = lib.mkOption { + type = lib.types.bool; + default = false; + description = '' + Whether to add an entry to `/etc/hosts` for the configured nextcloud domain to point to `localhost` and add `localhost `to nextcloud's `trusted_proxies` config option. - This is useful when nextcloud's domain is not a static IP address and when the reverse proxy cannot be bypassed because the backend connection is done via unix socket. - ''; - }; - } // ( - lib.genAttrs [ - "dbtype" - "dbname" - "dbuser" - "dbpassFile" - "dbhost" - "dbport" - "dbtableprefix" - ] ( - opt: options.services.nextcloud.config.${opt} // { - default = config.services.nextcloud.config.${opt}; - defaultText = lib.literalExpression "config.services.nextcloud.config.${opt}"; - } - ) - ); + This is useful when nextcloud's domain is not a static IP address and when the reverse proxy cannot be bypassed because the backend connection is done via unix socket. + ''; + }; + } + // (lib.genAttrs + [ + "dbtype" + "dbname" + "dbuser" + "dbpassFile" + "dbhost" + "dbport" + "dbtableprefix" + ] + ( + opt: + options.services.nextcloud.config.${opt} + // { + default = config.services.nextcloud.config.${opt}; + defaultText = lib.literalExpression "config.services.nextcloud.config.${opt}"; + } + ) + ); config = lib.mkIf cfg.enable { - systemd.services.nextcloud-notify_push = let - nextcloudUrl = "http${lib.optionalString cfgN.https "s"}://${cfgN.hostName}"; - in { - description = "Push daemon for Nextcloud clients"; - documentation = [ "https://github.com/nextcloud/notify_push" ]; - after = [ - "phpfpm-nextcloud.service" - "redis-nextcloud.service" - ]; - wantedBy = [ "multi-user.target" ]; - environment = { - NEXTCLOUD_URL = nextcloudUrl; - SOCKET_PATH = cfg.socketPath; - DATABASE_PREFIX = cfg.dbtableprefix; - LOG = cfg.logLevel; - }; - postStart = '' - ${cfgN.occ}/bin/nextcloud-occ notify_push:setup ${nextcloudUrl}/push - ''; - script = let - dbType = if cfg.dbtype == "pgsql" then "postgresql" else cfg.dbtype; - dbUser = lib.optionalString (cfg.dbuser != null) cfg.dbuser; - dbPass = lib.optionalString (cfg.dbpassFile != null) ":$DATABASE_PASSWORD"; - dbHostHasPrefix = prefix: lib.hasPrefix prefix (toString cfg.dbhost); - isPostgresql = dbType == "postgresql"; - isMysql = dbType == "mysql"; - isSocket = (isPostgresql && dbHostHasPrefix "/") || (isMysql && dbHostHasPrefix "localhost:/"); - dbHost = lib.optionalString (cfg.dbhost != null) (if - isSocket then - lib.optionalString isMysql "@localhost" - else - "@${cfg.dbhost}"); - dbOpts = lib.optionalString (cfg.dbhost != null && isSocket) ( - if isPostgresql then "?host=${cfg.dbhost}" else - if isMysql then "?socket=${lib.removePrefix "localhost:" cfg.dbhost}" else throw "unsupported dbtype" - ); - dbName = lib.optionalString (cfg.dbname != null) "/${cfg.dbname}"; - dbUrl = "${dbType}://${dbUser}${dbPass}${dbHost}${dbName}${dbOpts}"; - in lib.optionalString (dbPass != "") '' - export DATABASE_PASSWORD="$(<"${cfg.dbpassFile}")" - '' + '' - export DATABASE_URL="${dbUrl}" - exec ${cfg.package}/bin/notify_push '${cfgN.datadir}/config/config.php' - ''; - serviceConfig = { - User = "nextcloud"; - Group = "nextcloud"; - RuntimeDirectory = [ "nextcloud-notify_push" ]; - Restart = "on-failure"; - RestartSec = "5s"; - Type = "notify"; + systemd.services.nextcloud-notify_push = + let + nextcloudUrl = "http${lib.optionalString cfgN.https "s"}://${cfgN.hostName}"; + in + { + description = "Push daemon for Nextcloud clients"; + documentation = [ "https://github.com/nextcloud/notify_push" ]; + after = [ + "phpfpm-nextcloud.service" + "redis-nextcloud.service" + ]; + wantedBy = [ "multi-user.target" ]; + environment = { + NEXTCLOUD_URL = nextcloudUrl; + SOCKET_PATH = cfg.socketPath; + DATABASE_PREFIX = cfg.dbtableprefix; + LOG = cfg.logLevel; + }; + postStart = '' + ${cfgN.occ}/bin/nextcloud-occ notify_push:setup ${nextcloudUrl}/push + ''; + script = + let + dbType = if cfg.dbtype == "pgsql" then "postgresql" else cfg.dbtype; + dbUser = lib.optionalString (cfg.dbuser != null) cfg.dbuser; + dbPass = lib.optionalString (cfg.dbpassFile != null) ":$DATABASE_PASSWORD"; + dbHostHasPrefix = prefix: lib.hasPrefix prefix (toString cfg.dbhost); + isPostgresql = dbType == "postgresql"; + isMysql = dbType == "mysql"; + isSocket = (isPostgresql && dbHostHasPrefix "/") || (isMysql && dbHostHasPrefix "localhost:/"); + dbHost = lib.optionalString (cfg.dbhost != null) ( + if isSocket then lib.optionalString isMysql "@localhost" else "@${cfg.dbhost}" + ); + dbOpts = lib.optionalString (cfg.dbhost != null && isSocket) ( + if isPostgresql then + "?host=${cfg.dbhost}" + else if isMysql then + "?socket=${lib.removePrefix "localhost:" cfg.dbhost}" + else + throw "unsupported dbtype" + ); + dbName = lib.optionalString (cfg.dbname != null) "/${cfg.dbname}"; + dbUrl = "${dbType}://${dbUser}${dbPass}${dbHost}${dbName}${dbOpts}"; + in + lib.optionalString (dbPass != "") '' + export DATABASE_PASSWORD="$(<"${cfg.dbpassFile}")" + '' + + '' + export DATABASE_URL="${dbUrl}" + exec ${cfg.package}/bin/notify_push '${cfgN.datadir}/config/config.php' + ''; + serviceConfig = { + User = "nextcloud"; + Group = "nextcloud"; + RuntimeDirectory = [ "nextcloud-notify_push" ]; + Restart = "on-failure"; + RestartSec = "5s"; + Type = "notify"; + }; }; - }; networking.hosts = lib.mkIf cfg.bendDomainToLocalhost { "127.0.0.1" = [ cfgN.hostName ]; @@ -123,7 +147,10 @@ in } (lib.mkIf cfg.bendDomainToLocalhost { - nextcloud.settings.trusted_proxies = [ "127.0.0.1" "::1" ]; + nextcloud.settings.trusted_proxies = [ + "127.0.0.1" + "::1" + ]; }) ]; }; diff --git a/nixos/modules/services/web-apps/nexus.nix b/nixos/modules/services/web-apps/nexus.nix index fdf42ace6b0e87..b3ad13f4102b1a 100644 --- a/nixos/modules/services/web-apps/nexus.nix +++ b/nixos/modules/services/web-apps/nexus.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/web-apps/nifi.nix b/nixos/modules/services/web-apps/nifi.nix index 48de6b1495abb2..a59e5066cf48b5 100644 --- a/nixos/modules/services/web-apps/nifi.nix +++ b/nixos/modules/services/web-apps/nifi.nix @@ -1,4 +1,10 @@ -{ lib, pkgs, config, options, ... }: +{ + lib, + pkgs, + config, + options, + ... +}: let cfg = config.services.nifi; @@ -11,10 +17,13 @@ let NIFI_LOG_DIR = "/var/log/nifi"; }; - envFile = pkgs.writeText "nifi.env" (lib.concatMapStrings (s: s + "\n") ( - (lib.concatLists (lib.mapAttrsToList (name: value: - lib.optional (value != null) ''${name}="${toString value}"'' - ) env)))); + envFile = pkgs.writeText "nifi.env" ( + lib.concatMapStrings (s: s + "\n") ( + (lib.concatLists ( + lib.mapAttrsToList (name: value: lib.optional (value != null) ''${name}="${toString value}"'') env + )) + ) + ); nifiEnv = pkgs.writeShellScriptBin "nifi-env" '' set -a @@ -22,7 +31,8 @@ let eval -- "\$@" ''; -in { +in +{ options = { services.nifi = { enable = lib.mkEnableOption "Apache NiFi"; @@ -127,39 +137,45 @@ in { config = lib.mkIf cfg.enable { assertions = [ - { assertion = cfg.initUser!=null || cfg.initPasswordFile==null; - message = '' - needs to be set if enabled. - ''; + { + assertion = cfg.initUser != null || cfg.initPasswordFile == null; + message = '' + needs to be set if enabled. + ''; } - { assertion = cfg.initUser==null || cfg.initPasswordFile!=null; - message = '' - needs to be set if enabled. - ''; + { + assertion = cfg.initUser == null || cfg.initPasswordFile != null; + message = '' + needs to be set if enabled. + ''; } - { assertion = cfg.proxyHost==null || cfg.proxyPort!=null; - message = '' - needs to be set if value specified. - ''; + { + assertion = cfg.proxyHost == null || cfg.proxyPort != null; + message = '' + needs to be set if value specified. + ''; } - { assertion = cfg.proxyHost!=null || cfg.proxyPort==null; - message = '' - needs to be set if value specified. - ''; + { + assertion = cfg.proxyHost != null || cfg.proxyPort == null; + message = '' + needs to be set if value specified. + ''; } - { assertion = cfg.initJavaHeapSize==null || cfg.maxJavaHeapSize!=null; - message = '' - needs to be set if value specified. - ''; + { + assertion = cfg.initJavaHeapSize == null || cfg.maxJavaHeapSize != null; + message = '' + needs to be set if value specified. + ''; } - { assertion = cfg.initJavaHeapSize!=null || cfg.maxJavaHeapSize==null; - message = '' - needs to be set if value specified. - ''; + { + assertion = cfg.initJavaHeapSize != null || cfg.maxJavaHeapSize == null; + message = '' + needs to be set if value specified. + ''; } ]; - warnings = lib.optional (cfg.enableHTTPS==false) '' + warnings = lib.optional (cfg.enableHTTPS == false) '' Please do not disable HTTPS mode in production. In this mode, access to the nifi is opened without authentication. ''; @@ -173,7 +189,6 @@ in { }; }; - systemd.services.nifi = { description = "Apache NiFi"; after = [ "network.target" ]; @@ -233,20 +248,26 @@ in { -e '/nifi.security.keyPasswd/s|^#\+||' \ -e '/nifi.security.truststorePasswd/s|^#\+||' ''} - ${lib.optionalString ((cfg.enableHTTPS == true) && (cfg.proxyHost != null) && (cfg.proxyPort != null)) '' - sed -i /var/lib/nifi/conf/nifi.properties \ - -e 's|nifi.web.proxy.host=.*|nifi.web.proxy.host=${cfg.proxyHost}:${(toString cfg.proxyPort)}|g' - ''} - ${lib.optionalString ((cfg.enableHTTPS == false) || (cfg.proxyHost == null) && (cfg.proxyPort == null)) '' - sed -i /var/lib/nifi/conf/nifi.properties \ - -e 's|nifi.web.proxy.host=.*|nifi.web.proxy.host=|g' - ''} - ${lib.optionalString ((cfg.initJavaHeapSize != null) && (cfg.maxJavaHeapSize != null))'' + ${lib.optionalString + ((cfg.enableHTTPS == true) && (cfg.proxyHost != null) && (cfg.proxyPort != null)) + '' + sed -i /var/lib/nifi/conf/nifi.properties \ + -e 's|nifi.web.proxy.host=.*|nifi.web.proxy.host=${cfg.proxyHost}:${(toString cfg.proxyPort)}|g' + '' + } + ${lib.optionalString + ((cfg.enableHTTPS == false) || (cfg.proxyHost == null) && (cfg.proxyPort == null)) + '' + sed -i /var/lib/nifi/conf/nifi.properties \ + -e 's|nifi.web.proxy.host=.*|nifi.web.proxy.host=|g' + '' + } + ${lib.optionalString ((cfg.initJavaHeapSize != null) && (cfg.maxJavaHeapSize != null)) '' sed -i /var/lib/nifi/conf/bootstrap.conf \ -e 's|java.arg.2=.*|java.arg.2=-Xms${(toString cfg.initJavaHeapSize)}m|g' \ -e 's|java.arg.3=.*|java.arg.3=-Xmx${(toString cfg.maxJavaHeapSize)}m|g' ''} - ${lib.optionalString ((cfg.initJavaHeapSize == null) && (cfg.maxJavaHeapSize == null))'' + ${lib.optionalString ((cfg.initJavaHeapSize == null) && (cfg.maxJavaHeapSize == null)) '' sed -i /var/lib/nifi/conf/bootstrap.conf \ -e 's|java.arg.2=.*|java.arg.2=-Xms512m|g' \ -e 's|java.arg.3=.*|java.arg.3=-Xmx512m|g' @@ -292,14 +313,17 @@ in { RestrictAddressFamilies = [ "AF_INET AF_INET6" ]; RestrictNamespaces = true; LockPersonality = true; - MemoryDenyWriteExecute = false; + MemoryDenyWriteExecute = false; RestrictRealtime = true; RestrictSUIDSGID = true; RemoveIPC = true; PrivateMounts = true; # System Call Filtering SystemCallArchitectures = "native"; - SystemCallFilter = [ "~@cpu-emulation @debug @keyring @memlock @mount @obsolete @resources @privileged @setuid" "@chown" ]; + SystemCallFilter = [ + "~@cpu-emulation @debug @keyring @memlock @mount @obsolete @resources @privileged @setuid" + "@chown" + ]; }; }; diff --git a/nixos/modules/services/web-apps/node-red.nix b/nixos/modules/services/web-apps/node-red.nix index cf6429c0094e81..1b999e7abc8619 100644 --- a/nixos/modules/services/web-apps/node-red.nix +++ b/nixos/modules/services/web-apps/node-red.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -85,7 +90,7 @@ in define = mkOption { type = types.attrs; - default = {}; + default = { }; description = "List of settings.js overrides to pass via -D to Node-RED."; example = literalExpression '' { @@ -118,12 +123,17 @@ in environment = { HOME = cfg.userDir; }; - path = lib.optionals cfg.withNpmAndGcc [ pkgs.nodejs pkgs.gcc ]; + path = lib.optionals cfg.withNpmAndGcc [ + pkgs.nodejs + pkgs.gcc + ]; serviceConfig = mkMerge [ { User = cfg.user; Group = cfg.group; - ExecStart = "${cfg.package}/bin/node-red ${pkgs.lib.optionalString cfg.safe "--safe"} --settings ${cfg.configFile} --port ${toString cfg.port} --userDir ${cfg.userDir} ${concatStringsSep " " (mapAttrsToList (name: value: "-D ${name}=${value}") cfg.define)}"; + ExecStart = "${cfg.package}/bin/node-red ${pkgs.lib.optionalString cfg.safe "--safe"} --settings ${cfg.configFile} --port ${toString cfg.port} --userDir ${cfg.userDir} ${ + concatStringsSep " " (mapAttrsToList (name: value: "-D ${name}=${value}") cfg.define) + }"; PrivateTmp = true; Restart = "always"; WorkingDirectory = cfg.userDir; diff --git a/nixos/modules/services/web-apps/onlyoffice.nix b/nixos/modules/services/web-apps/onlyoffice.nix index 0d0e01d4f7bc05..d56a4d66283cfb 100644 --- a/nixos/modules/services/web-apps/onlyoffice.nix +++ b/nixos/modules/services/web-apps/onlyoffice.nix @@ -1,4 +1,9 @@ -{ lib, config, pkgs, ... }: +{ + lib, + config, + pkgs, + ... +}: let cfg = config.services.onlyoffice; @@ -86,20 +91,25 @@ in upstreams = { # /etc/nginx/includes/http-common.conf onlyoffice-docservice = { - servers = { "localhost:${toString cfg.port}" = { }; }; + servers = { + "localhost:${toString cfg.port}" = { }; + }; }; onlyoffice-example = lib.mkIf cfg.enableExampleServer { - servers = { "localhost:${toString cfg.examplePort}" = { }; }; + servers = { + "localhost:${toString cfg.examplePort}" = { }; + }; }; }; virtualHosts.${cfg.hostname} = { locations = { # /etc/nginx/includes/ds-docservice.conf - "~ ^(\/[\d]+\.[\d]+\.[\d]+[\.|-][\d]+)?\/(web-apps\/apps\/api\/documents\/api\.js)$".extraConfig = '' - expires -1; - alias ${cfg.package}/var/www/onlyoffice/documentserver/$2; - ''; + "~ ^(\/[\d]+\.[\d]+\.[\d]+[\.|-][\d]+)?\/(web-apps\/apps\/api\/documents\/api\.js)$".extraConfig = + '' + expires -1; + alias ${cfg.package}/var/www/onlyoffice/documentserver/$2; + ''; "~ ^(\/[\d]+\.[\d]+\.[\d]+[\.|-][\d]+)?\/(web-apps)(\/.*\.json)$".extraConfig = '' expires 365d; error_log /dev/null crit; @@ -110,10 +120,11 @@ in error_log /dev/null crit; alias ${cfg.package}/var/www/onlyoffice/documentserver/$2$3; ''; - "~ ^(\/[\d]+\.[\d]+\.[\d]+[\.|-][\d]+)?\/(web-apps|sdkjs|sdkjs-plugins|fonts)(\/.*)$".extraConfig = '' - expires 365d; - alias ${cfg.package}/var/www/onlyoffice/documentserver/$2$3; - ''; + "~ ^(\/[\d]+\.[\d]+\.[\d]+[\.|-][\d]+)?\/(web-apps|sdkjs|sdkjs-plugins|fonts)(\/.*)$".extraConfig = + '' + expires 365d; + alias ${cfg.package}/var/www/onlyoffice/documentserver/$2$3; + ''; "~* ^(\/cache\/files.*)(\/.*)".extraConfig = '' alias /var/lib/onlyoffice/documentserver/App_Data$1; add_header Content-Disposition "attachment; filename*=UTF-8''$arg_filename"; @@ -189,18 +200,28 @@ in postgresql = { enable = lib.mkDefault true; ensureDatabases = [ "onlyoffice" ]; - ensureUsers = [{ - name = "onlyoffice"; - ensureDBOwnership = true; - }]; + ensureUsers = [ + { + name = "onlyoffice"; + ensureDBOwnership = true; + } + ]; }; }; systemd.services = { onlyoffice-converter = { description = "onlyoffice converter"; - after = [ "network.target" "onlyoffice-docservice.service" "postgresql.service" ]; - requires = [ "network.target" "onlyoffice-docservice.service" "postgresql.service" ]; + after = [ + "network.target" + "onlyoffice-docservice.service" + "postgresql.service" + ]; + requires = [ + "network.target" + "onlyoffice-docservice.service" + "postgresql.service" + ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { ExecStart = "${cfg.package.fhs}/bin/onlyoffice-wrapper FileConverter/converter /run/onlyoffice/config"; @@ -216,7 +237,16 @@ in onlyoffice-docservice = let onlyoffice-prestart = pkgs.writeShellScript "onlyoffice-prestart" '' - PATH=$PATH:${lib.makeBinPath (with pkgs; [ jq moreutils config.services.postgresql.package ])} + PATH=$PATH:${ + lib.makeBinPath ( + with pkgs; + [ + jq + moreutils + config.services.postgresql.package + ] + ) + } umask 077 mkdir -p /run/onlyoffice/config/ /var/lib/onlyoffice/documentserver/sdkjs/{slide/themes,common}/ /var/lib/onlyoffice/documentserver/{fonts,server/FileConverter/bin}/ cp -r ${cfg.package}/etc/onlyoffice/documentserver/* /run/onlyoffice/config/ @@ -258,7 +288,10 @@ in in { description = "onlyoffice documentserver"; - after = [ "network.target" "postgresql.service" ]; + after = [ + "network.target" + "postgresql.service" + ]; requires = [ "postgresql.service" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { diff --git a/nixos/modules/services/web-apps/openvscode-server.nix b/nixos/modules/services/web-apps/openvscode-server.nix index b3c22cd43b78e5..0350d715c6185a 100644 --- a/nixos/modules/services/web-apps/openvscode-server.nix +++ b/nixos/modules/services/web-apps/openvscode-server.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.openvscode-server; @@ -27,7 +32,9 @@ in Additional environment variables to pass to openvscode-server. ''; default = { }; - example = { PKG_CONFIG_PATH = "/run/current-system/sw/lib/pkgconfig"; }; + example = { + PKG_CONFIG_PATH = "/run/current-system/sw/lib/pkgconfig"; + }; }; extraArguments = lib.mkOption { @@ -132,7 +139,14 @@ in description = '' Sets the initial telemetry level. Valid levels are: 'off', 'crash', 'error' and 'all'. ''; - type = lib.types.nullOr (lib.types.enum [ "off" "crash" "error" "all" ]); + type = lib.types.nullOr ( + lib.types.enum [ + "off" + "crash" + "error" + "all" + ] + ); }; connectionToken = lib.mkOption { @@ -164,28 +178,38 @@ in path = cfg.extraPackages; environment = cfg.extraEnvironment; serviceConfig = { - ExecStart = '' - ${lib.getExe cfg.package} \ - --accept-server-license-terms \ - --host=${cfg.host} \ - --port=${toString cfg.port} \ - '' + lib.optionalString (cfg.telemetryLevel != null) '' - --telemetry-level=${cfg.telemetryLevel} \ - '' + lib.optionalString (cfg.withoutConnectionToken) '' - --without-connection-token \ - '' + lib.optionalString (cfg.socketPath != null) '' - --socket-path=${cfg.socketPath} \ - '' + lib.optionalString (cfg.userDataDir != null) '' - --user-data-dir=${cfg.userDataDir} \ - '' + lib.optionalString (cfg.serverDataDir != null) '' - --server-data-dir=${cfg.serverDataDir} \ - '' + lib.optionalString (cfg.extensionsDir != null) '' - --extensions-dir=${cfg.extensionsDir} \ - '' + lib.optionalString (cfg.connectionToken != null) '' - --connection-token=${cfg.connectionToken} \ - '' + lib.optionalString (cfg.connectionTokenFile != null) '' - --connection-token-file=${cfg.connectionTokenFile} \ - '' + lib.escapeShellArgs cfg.extraArguments; + ExecStart = + '' + ${lib.getExe cfg.package} \ + --accept-server-license-terms \ + --host=${cfg.host} \ + --port=${toString cfg.port} \ + '' + + lib.optionalString (cfg.telemetryLevel != null) '' + --telemetry-level=${cfg.telemetryLevel} \ + '' + + lib.optionalString (cfg.withoutConnectionToken) '' + --without-connection-token \ + '' + + lib.optionalString (cfg.socketPath != null) '' + --socket-path=${cfg.socketPath} \ + '' + + lib.optionalString (cfg.userDataDir != null) '' + --user-data-dir=${cfg.userDataDir} \ + '' + + lib.optionalString (cfg.serverDataDir != null) '' + --server-data-dir=${cfg.serverDataDir} \ + '' + + lib.optionalString (cfg.extensionsDir != null) '' + --extensions-dir=${cfg.extensionsDir} \ + '' + + lib.optionalString (cfg.connectionToken != null) '' + --connection-token=${cfg.connectionToken} \ + '' + + lib.optionalString (cfg.connectionTokenFile != null) '' + --connection-token-file=${cfg.connectionTokenFile} \ + '' + + lib.escapeShellArgs cfg.extraArguments; ExecReload = "${pkgs.coreutils}/bin/kill -HUP $MAINPID"; RuntimeDirectory = cfg.user; User = cfg.user; diff --git a/nixos/modules/services/web-apps/openwebrx.nix b/nixos/modules/services/web-apps/openwebrx.nix index 2ac187dc88c9d7..f8c19fa7ed7f60 100644 --- a/nixos/modules/services/web-apps/openwebrx.nix +++ b/nixos/modules/services/web-apps/openwebrx.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.openwebrx; in diff --git a/nixos/modules/services/web-apps/outline.nix b/nixos/modules/services/web-apps/outline.nix index ba426ce89bbf26..78ebc71eb20625 100644 --- a/nixos/modules/services/web-apps/outline.nix +++ b/nixos/modules/services/web-apps/outline.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: let defaultUser = "outline"; @@ -7,7 +12,11 @@ let in { imports = [ - (mkRemovedOptionModule [ "services" "outline" "sequelizeArguments" ] "Database migration are run agains configurated database by outline directly") + (mkRemovedOptionModule [ + "services" + "outline" + "sequelizeArguments" + ] "Database migration are run agains configurated database by outline directly") ]; # See here for a reference of all the options: # https://github.com/outline/outline/blob/v0.67.0/.env.sample @@ -138,7 +147,10 @@ in type = lib.types.submodule { options = { storageType = lib.mkOption { - type = lib.types.enum [ "local" "s3" ]; + type = lib.types.enum [ + "local" + "s3" + ]; description = "File storage type, it can be local or s3."; default = "s3"; }; @@ -206,18 +218,20 @@ in to `https://[publicUrl]/auth/slack.callback`. ''; default = null; - type = lib.types.nullOr (lib.types.submodule { - options = { - clientId = lib.mkOption { - type = lib.types.str; - description = "Authentication key."; + type = lib.types.nullOr ( + lib.types.submodule { + options = { + clientId = lib.mkOption { + type = lib.types.str; + description = "Authentication key."; + }; + secretFile = lib.mkOption { + type = lib.types.str; + description = "File path containing the authentication secret."; + }; }; - secretFile = lib.mkOption { - type = lib.types.str; - description = "File path containing the authentication secret."; - }; - }; - }); + } + ); }; googleAuthentication = lib.mkOption { @@ -229,18 +243,20 @@ in `https://[publicUrl]/auth/google.callback`. ''; default = null; - type = lib.types.nullOr (lib.types.submodule { - options = { - clientId = lib.mkOption { - type = lib.types.str; - description = "Authentication client identifier."; - }; - clientSecretFile = lib.mkOption { - type = lib.types.str; - description = "File path containing the authentication secret."; + type = lib.types.nullOr ( + lib.types.submodule { + options = { + clientId = lib.mkOption { + type = lib.types.str; + description = "Authentication client identifier."; + }; + clientSecretFile = lib.mkOption { + type = lib.types.str; + description = "File path containing the authentication secret."; + }; }; - }; - }); + } + ); }; azureAuthentication = lib.mkOption { @@ -251,22 +267,24 @@ in for details on setting up your Azure App. ''; default = null; - type = lib.types.nullOr (lib.types.submodule { - options = { - clientId = lib.mkOption { - type = lib.types.str; - description = "Authentication client identifier."; - }; - clientSecretFile = lib.mkOption { - type = lib.types.str; - description = "File path containing the authentication secret."; - }; - resourceAppId = lib.mkOption { - type = lib.types.str; - description = "Authentication application resource ID."; + type = lib.types.nullOr ( + lib.types.submodule { + options = { + clientId = lib.mkOption { + type = lib.types.str; + description = "Authentication client identifier."; + }; + clientSecretFile = lib.mkOption { + type = lib.types.str; + description = "File path containing the authentication secret."; + }; + resourceAppId = lib.mkOption { + type = lib.types.str; + description = "Authentication application resource ID."; + }; }; - }; - }); + } + ); }; oidcAuthentication = lib.mkOption { @@ -277,48 +295,54 @@ in `https://[publicUrl]/auth/oidc.callback`. ''; default = null; - type = lib.types.nullOr (lib.types.submodule { - options = { - clientId = lib.mkOption { - type = lib.types.str; - description = "Authentication client identifier."; - }; - clientSecretFile = lib.mkOption { - type = lib.types.str; - description = "File path containing the authentication secret."; + type = lib.types.nullOr ( + lib.types.submodule { + options = { + clientId = lib.mkOption { + type = lib.types.str; + description = "Authentication client identifier."; + }; + clientSecretFile = lib.mkOption { + type = lib.types.str; + description = "File path containing the authentication secret."; + }; + authUrl = lib.mkOption { + type = lib.types.str; + description = "OIDC authentication URL endpoint."; + }; + tokenUrl = lib.mkOption { + type = lib.types.str; + description = "OIDC token URL endpoint."; + }; + userinfoUrl = lib.mkOption { + type = lib.types.str; + description = "OIDC userinfo URL endpoint."; + }; + usernameClaim = lib.mkOption { + type = lib.types.str; + description = '' + Specify which claims to derive user information from. Supports any + valid JSON path with the JWT payload + ''; + default = "preferred_username"; + }; + displayName = lib.mkOption { + type = lib.types.str; + description = "Display name for OIDC authentication."; + default = "OpenID"; + }; + scopes = lib.mkOption { + type = lib.types.listOf lib.types.str; + description = "OpenID authentication scopes."; + default = [ + "openid" + "profile" + "email" + ]; + }; }; - authUrl = lib.mkOption { - type = lib.types.str; - description = "OIDC authentication URL endpoint."; - }; - tokenUrl = lib.mkOption { - type = lib.types.str; - description = "OIDC token URL endpoint."; - }; - userinfoUrl = lib.mkOption { - type = lib.types.str; - description = "OIDC userinfo URL endpoint."; - }; - usernameClaim = lib.mkOption { - type = lib.types.str; - description = '' - Specify which claims to derive user information from. Supports any - valid JSON path with the JWT payload - ''; - default = "preferred_username"; - }; - displayName = lib.mkOption { - type = lib.types.str; - description = "Display name for OIDC authentication."; - default = "OpenID"; - }; - scopes = lib.mkOption { - type = lib.types.listOf lib.types.str; - description = "OpenID authentication scopes."; - default = [ "openid" "profile" "email" ]; - }; - }; - }); + } + ); }; # @@ -407,23 +431,25 @@ in https://wiki.generaloutline.com/share/be25efd1-b3ef-4450-b8e5-c4a4fc11e02a ''; default = null; - type = lib.types.nullOr (lib.types.submodule { - options = { - verificationTokenFile = lib.mkOption { - type = lib.types.str; - description = "File path containing the verification token."; - }; - appId = lib.mkOption { - type = lib.types.str; - description = "Application ID."; + type = lib.types.nullOr ( + lib.types.submodule { + options = { + verificationTokenFile = lib.mkOption { + type = lib.types.str; + description = "File path containing the verification token."; + }; + appId = lib.mkOption { + type = lib.types.str; + description = "Application ID."; + }; + messageActions = lib.mkOption { + type = lib.types.bool; + default = true; + description = "Whether to enable message actions."; + }; }; - messageActions = lib.mkOption { - type = lib.types.bool; - default = true; - description = "Whether to enable message actions."; - }; - }; - }); + } + ); }; googleAnalyticsId = lib.mkOption { @@ -470,69 +496,71 @@ in authentication for an SMTP server. ''; default = null; - type = lib.types.nullOr (lib.types.submodule { - options = { - host = lib.mkOption { - type = lib.types.str; - description = "Host name or IP address of the SMTP server."; - }; - port = lib.mkOption { - type = lib.types.port; - description = "TCP port of the SMTP server."; - }; - username = lib.mkOption { - type = lib.types.str; - description = "Username to authenticate with."; + type = lib.types.nullOr ( + lib.types.submodule { + options = { + host = lib.mkOption { + type = lib.types.str; + description = "Host name or IP address of the SMTP server."; + }; + port = lib.mkOption { + type = lib.types.port; + description = "TCP port of the SMTP server."; + }; + username = lib.mkOption { + type = lib.types.str; + description = "Username to authenticate with."; + }; + passwordFile = lib.mkOption { + type = lib.types.str; + description = '' + File path containing the password to authenticate with. + ''; + }; + fromEmail = lib.mkOption { + type = lib.types.str; + description = "Sender email in outgoing mail."; + }; + replyEmail = lib.mkOption { + type = lib.types.str; + description = "Reply address in outgoing mail."; + }; + tlsCiphers = lib.mkOption { + type = lib.types.str; + default = ""; + description = "Override SMTP cipher configuration."; + }; + secure = lib.mkOption { + type = lib.types.bool; + default = true; + description = "Use a secure SMTP connection."; + }; }; - passwordFile = lib.mkOption { - type = lib.types.str; - description = '' - File path containing the password to authenticate with. - ''; - }; - fromEmail = lib.mkOption { - type = lib.types.str; - description = "Sender email in outgoing mail."; - }; - replyEmail = lib.mkOption { - type = lib.types.str; - description = "Reply address in outgoing mail."; - }; - tlsCiphers = lib.mkOption { - type = lib.types.str; - default = ""; - description = "Override SMTP cipher configuration."; - }; - secure = lib.mkOption { - type = lib.types.bool; - default = true; - description = "Use a secure SMTP connection."; - }; - }; - }); + } + ); }; defaultLanguage = lib.mkOption { type = lib.types.enum [ - "da_DK" - "de_DE" - "en_US" - "es_ES" - "fa_IR" - "fr_FR" - "it_IT" - "ja_JP" - "ko_KR" - "nl_NL" - "pl_PL" - "pt_BR" - "pt_PT" - "ru_RU" - "sv_SE" - "th_TH" - "vi_VN" - "zh_CN" - "zh_TW" + "da_DK" + "de_DE" + "en_US" + "es_ES" + "fa_IR" + "fr_FR" + "it_IT" + "ja_JP" + "ko_KR" + "nl_NL" + "pl_PL" + "pt_BR" + "pt_PT" + "ru_RU" + "sv_SE" + "th_TH" + "vi_VN" + "zh_CN" + "zh_TW" ]; default = "en_US"; description = '' @@ -571,18 +599,22 @@ in systemd.tmpfiles.rules = [ "f ${cfg.secretKeyFile} 0600 ${cfg.user} ${cfg.group} -" "f ${cfg.utilsSecretFile} 0600 ${cfg.user} ${cfg.group} -" - (if (cfg.storage.storageType == "s3") then - "f ${cfg.storage.secretKeyFile} 0600 ${cfg.user} ${cfg.group} -" - else - "d ${cfg.storage.localRootDir} 0700 ${cfg.user} ${cfg.group} - -") + ( + if (cfg.storage.storageType == "s3") then + "f ${cfg.storage.secretKeyFile} 0600 ${cfg.user} ${cfg.group} -" + else + "d ${cfg.storage.localRootDir} 0700 ${cfg.user} ${cfg.group} - -" + ) ]; services.postgresql = lib.mkIf (cfg.databaseUrl == "local") { enable = true; - ensureUsers = [{ - name = "outline"; - ensureDBOwnership = true; - }]; + ensureUsers = [ + { + name = "outline"; + ensureDBOwnership = true; + } + ]; ensureDatabases = [ "outline" ]; }; @@ -592,169 +624,177 @@ in port = 0; # Disable the TCP listener }; - systemd.services.outline = let - localRedisUrl = "redis+unix:///run/redis-outline/redis.sock"; - localPostgresqlUrl = "postgres://localhost/outline?host=/run/postgresql"; - in { - description = "Outline wiki and knowledge base"; - wantedBy = [ "multi-user.target" ]; - after = [ "networking.target" ] - ++ lib.optional (cfg.databaseUrl == "local") "postgresql.service" - ++ lib.optional (cfg.redisUrl == "local") "redis-outline.service"; - requires = lib.optional (cfg.databaseUrl == "local") "postgresql.service" - ++ lib.optional (cfg.redisUrl == "local") "redis-outline.service"; - path = [ - pkgs.openssl # Required by the preStart script - ]; - - - environment = lib.mkMerge [ - { - NODE_ENV = "production"; - - REDIS_URL = if cfg.redisUrl == "local" then localRedisUrl else cfg.redisUrl; - URL = cfg.publicUrl; - PORT = builtins.toString cfg.port; - - CDN_URL = cfg.cdnUrl; - FORCE_HTTPS = builtins.toString cfg.forceHttps; - ENABLE_UPDATES = builtins.toString cfg.enableUpdateCheck; - WEB_CONCURRENCY = builtins.toString cfg.concurrency; - MAXIMUM_IMPORT_SIZE = builtins.toString cfg.maximumImportSize; - DEBUG = cfg.debugOutput; - GOOGLE_ANALYTICS_ID = lib.optionalString (cfg.googleAnalyticsId != null) cfg.googleAnalyticsId; - SENTRY_DSN = lib.optionalString (cfg.sentryDsn != null) cfg.sentryDsn; - SENTRY_TUNNEL = lib.optionalString (cfg.sentryTunnel != null) cfg.sentryTunnel; - TEAM_LOGO = lib.optionalString (cfg.logo != null) cfg.logo; - DEFAULT_LANGUAGE = cfg.defaultLanguage; - - RATE_LIMITER_ENABLED = builtins.toString cfg.rateLimiter.enable; - RATE_LIMITER_REQUESTS = builtins.toString cfg.rateLimiter.requests; - RATE_LIMITER_DURATION_WINDOW = builtins.toString cfg.rateLimiter.durationWindow; - - FILE_STORAGE = cfg.storage.storageType; - FILE_STORAGE_UPLOAD_MAX_SIZE = builtins.toString cfg.storage.uploadMaxSize; - FILE_STORAGE_LOCAL_ROOT_DIR = cfg.storage.localRootDir; - } - - (lib.mkIf (cfg.storage.storageType == "s3") { - AWS_ACCESS_KEY_ID = cfg.storage.accessKey; - AWS_REGION = cfg.storage.region; - AWS_S3_UPLOAD_BUCKET_URL = cfg.storage.uploadBucketUrl; - AWS_S3_UPLOAD_BUCKET_NAME = cfg.storage.uploadBucketName; - AWS_S3_FORCE_PATH_STYLE = builtins.toString cfg.storage.forcePathStyle; - AWS_S3_ACL = cfg.storage.acl; - }) - - (lib.mkIf (cfg.slackAuthentication != null) { - SLACK_CLIENT_ID = cfg.slackAuthentication.clientId; - }) - - (lib.mkIf (cfg.googleAuthentication != null) { - GOOGLE_CLIENT_ID = cfg.googleAuthentication.clientId; - }) - - (lib.mkIf (cfg.azureAuthentication != null) { - AZURE_CLIENT_ID = cfg.azureAuthentication.clientId; - AZURE_RESOURCE_APP_ID = cfg.azureAuthentication.resourceAppId; - }) - - (lib.mkIf (cfg.oidcAuthentication != null) { - OIDC_CLIENT_ID = cfg.oidcAuthentication.clientId; - OIDC_AUTH_URI = cfg.oidcAuthentication.authUrl; - OIDC_TOKEN_URI = cfg.oidcAuthentication.tokenUrl; - OIDC_USERINFO_URI = cfg.oidcAuthentication.userinfoUrl; - OIDC_USERNAME_CLAIM = cfg.oidcAuthentication.usernameClaim; - OIDC_DISPLAY_NAME = cfg.oidcAuthentication.displayName; - OIDC_SCOPES = lib.concatStringsSep " " cfg.oidcAuthentication.scopes; - }) - - (lib.mkIf (cfg.slackIntegration != null) { - SLACK_APP_ID = cfg.slackIntegration.appId; - SLACK_MESSAGE_ACTIONS = builtins.toString cfg.slackIntegration.messageActions; - }) - - (lib.mkIf (cfg.smtp != null) { - SMTP_HOST = cfg.smtp.host; - SMTP_PORT = builtins.toString cfg.smtp.port; - SMTP_USERNAME = cfg.smtp.username; - SMTP_FROM_EMAIL = cfg.smtp.fromEmail; - SMTP_REPLY_EMAIL = cfg.smtp.replyEmail; - SMTP_TLS_CIPHERS = cfg.smtp.tlsCiphers; - SMTP_SECURE = builtins.toString cfg.smtp.secure; - }) - ]; - - preStart = '' - if [ ! -s ${lib.escapeShellArg cfg.secretKeyFile} ]; then - openssl rand -hex 32 > ${lib.escapeShellArg cfg.secretKeyFile} - fi - if [ ! -s ${lib.escapeShellArg cfg.utilsSecretFile} ]; then - openssl rand -hex 32 > ${lib.escapeShellArg cfg.utilsSecretFile} - fi - - ''; - - script = '' - export SECRET_KEY="$(head -n1 ${lib.escapeShellArg cfg.secretKeyFile})" - export UTILS_SECRET="$(head -n1 ${lib.escapeShellArg cfg.utilsSecretFile})" - ${lib.optionalString (cfg.storage.storageType == "s3") '' - export AWS_SECRET_ACCESS_KEY="$(head -n1 ${lib.escapeShellArg cfg.storage.secretKeyFile})" - ''} - ${lib.optionalString (cfg.slackAuthentication != null) '' - export SLACK_CLIENT_SECRET="$(head -n1 ${lib.escapeShellArg cfg.slackAuthentication.secretFile})" - ''} - ${lib.optionalString (cfg.googleAuthentication != null) '' - export GOOGLE_CLIENT_SECRET="$(head -n1 ${lib.escapeShellArg cfg.googleAuthentication.clientSecretFile})" - ''} - ${lib.optionalString (cfg.azureAuthentication != null) '' - export AZURE_CLIENT_SECRET="$(head -n1 ${lib.escapeShellArg cfg.azureAuthentication.clientSecretFile})" - ''} - ${lib.optionalString (cfg.oidcAuthentication != null) '' - export OIDC_CLIENT_SECRET="$(head -n1 ${lib.escapeShellArg cfg.oidcAuthentication.clientSecretFile})" - ''} - ${lib.optionalString (cfg.sslKeyFile != null) '' - export SSL_KEY="$(head -n1 ${lib.escapeShellArg cfg.sslKeyFile})" - ''} - ${lib.optionalString (cfg.sslCertFile != null) '' - export SSL_CERT="$(head -n1 ${lib.escapeShellArg cfg.sslCertFile})" - ''} - ${lib.optionalString (cfg.slackIntegration != null) '' - export SLACK_VERIFICATION_TOKEN="$(head -n1 ${lib.escapeShellArg cfg.slackIntegration.verificationTokenFile})" - ''} - ${lib.optionalString (cfg.smtp != null) '' - export SMTP_PASSWORD="$(head -n1 ${lib.escapeShellArg cfg.smtp.passwordFile})" - ''} - - ${if (cfg.databaseUrl == "local") then '' - export DATABASE_URL=${lib.escapeShellArg localPostgresqlUrl} - export PGSSLMODE=disable - '' else '' - export DATABASE_URL=${lib.escapeShellArg cfg.databaseUrl} - ''} - - ${cfg.package}/bin/outline-server - ''; - - serviceConfig = { - User = cfg.user; - Group = cfg.group; - Restart = "always"; - ProtectSystem = "strict"; - PrivateHome = true; - PrivateTmp = true; - UMask = "0007"; - - StateDirectory = "outline"; - StateDirectoryMode = "0750"; - RuntimeDirectory = "outline"; - RuntimeDirectoryMode = "0750"; - # This working directory is required to find stuff like the set of - # onboarding files: - WorkingDirectory = "${cfg.package}/share/outline"; - # In case this directory is not in /var/lib/outline, it needs to be made writable explicitly - ReadWritePaths = lib.mkIf (cfg.storage.storageType == "local") [ cfg.storage.localRootDir ]; + systemd.services.outline = + let + localRedisUrl = "redis+unix:///run/redis-outline/redis.sock"; + localPostgresqlUrl = "postgres://localhost/outline?host=/run/postgresql"; + in + { + description = "Outline wiki and knowledge base"; + wantedBy = [ "multi-user.target" ]; + after = + [ "networking.target" ] + ++ lib.optional (cfg.databaseUrl == "local") "postgresql.service" + ++ lib.optional (cfg.redisUrl == "local") "redis-outline.service"; + requires = + lib.optional (cfg.databaseUrl == "local") "postgresql.service" + ++ lib.optional (cfg.redisUrl == "local") "redis-outline.service"; + path = [ + pkgs.openssl # Required by the preStart script + ]; + + environment = lib.mkMerge [ + { + NODE_ENV = "production"; + + REDIS_URL = if cfg.redisUrl == "local" then localRedisUrl else cfg.redisUrl; + URL = cfg.publicUrl; + PORT = builtins.toString cfg.port; + + CDN_URL = cfg.cdnUrl; + FORCE_HTTPS = builtins.toString cfg.forceHttps; + ENABLE_UPDATES = builtins.toString cfg.enableUpdateCheck; + WEB_CONCURRENCY = builtins.toString cfg.concurrency; + MAXIMUM_IMPORT_SIZE = builtins.toString cfg.maximumImportSize; + DEBUG = cfg.debugOutput; + GOOGLE_ANALYTICS_ID = lib.optionalString (cfg.googleAnalyticsId != null) cfg.googleAnalyticsId; + SENTRY_DSN = lib.optionalString (cfg.sentryDsn != null) cfg.sentryDsn; + SENTRY_TUNNEL = lib.optionalString (cfg.sentryTunnel != null) cfg.sentryTunnel; + TEAM_LOGO = lib.optionalString (cfg.logo != null) cfg.logo; + DEFAULT_LANGUAGE = cfg.defaultLanguage; + + RATE_LIMITER_ENABLED = builtins.toString cfg.rateLimiter.enable; + RATE_LIMITER_REQUESTS = builtins.toString cfg.rateLimiter.requests; + RATE_LIMITER_DURATION_WINDOW = builtins.toString cfg.rateLimiter.durationWindow; + + FILE_STORAGE = cfg.storage.storageType; + FILE_STORAGE_UPLOAD_MAX_SIZE = builtins.toString cfg.storage.uploadMaxSize; + FILE_STORAGE_LOCAL_ROOT_DIR = cfg.storage.localRootDir; + } + + (lib.mkIf (cfg.storage.storageType == "s3") { + AWS_ACCESS_KEY_ID = cfg.storage.accessKey; + AWS_REGION = cfg.storage.region; + AWS_S3_UPLOAD_BUCKET_URL = cfg.storage.uploadBucketUrl; + AWS_S3_UPLOAD_BUCKET_NAME = cfg.storage.uploadBucketName; + AWS_S3_FORCE_PATH_STYLE = builtins.toString cfg.storage.forcePathStyle; + AWS_S3_ACL = cfg.storage.acl; + }) + + (lib.mkIf (cfg.slackAuthentication != null) { + SLACK_CLIENT_ID = cfg.slackAuthentication.clientId; + }) + + (lib.mkIf (cfg.googleAuthentication != null) { + GOOGLE_CLIENT_ID = cfg.googleAuthentication.clientId; + }) + + (lib.mkIf (cfg.azureAuthentication != null) { + AZURE_CLIENT_ID = cfg.azureAuthentication.clientId; + AZURE_RESOURCE_APP_ID = cfg.azureAuthentication.resourceAppId; + }) + + (lib.mkIf (cfg.oidcAuthentication != null) { + OIDC_CLIENT_ID = cfg.oidcAuthentication.clientId; + OIDC_AUTH_URI = cfg.oidcAuthentication.authUrl; + OIDC_TOKEN_URI = cfg.oidcAuthentication.tokenUrl; + OIDC_USERINFO_URI = cfg.oidcAuthentication.userinfoUrl; + OIDC_USERNAME_CLAIM = cfg.oidcAuthentication.usernameClaim; + OIDC_DISPLAY_NAME = cfg.oidcAuthentication.displayName; + OIDC_SCOPES = lib.concatStringsSep " " cfg.oidcAuthentication.scopes; + }) + + (lib.mkIf (cfg.slackIntegration != null) { + SLACK_APP_ID = cfg.slackIntegration.appId; + SLACK_MESSAGE_ACTIONS = builtins.toString cfg.slackIntegration.messageActions; + }) + + (lib.mkIf (cfg.smtp != null) { + SMTP_HOST = cfg.smtp.host; + SMTP_PORT = builtins.toString cfg.smtp.port; + SMTP_USERNAME = cfg.smtp.username; + SMTP_FROM_EMAIL = cfg.smtp.fromEmail; + SMTP_REPLY_EMAIL = cfg.smtp.replyEmail; + SMTP_TLS_CIPHERS = cfg.smtp.tlsCiphers; + SMTP_SECURE = builtins.toString cfg.smtp.secure; + }) + ]; + + preStart = '' + if [ ! -s ${lib.escapeShellArg cfg.secretKeyFile} ]; then + openssl rand -hex 32 > ${lib.escapeShellArg cfg.secretKeyFile} + fi + if [ ! -s ${lib.escapeShellArg cfg.utilsSecretFile} ]; then + openssl rand -hex 32 > ${lib.escapeShellArg cfg.utilsSecretFile} + fi + + ''; + + script = '' + export SECRET_KEY="$(head -n1 ${lib.escapeShellArg cfg.secretKeyFile})" + export UTILS_SECRET="$(head -n1 ${lib.escapeShellArg cfg.utilsSecretFile})" + ${lib.optionalString (cfg.storage.storageType == "s3") '' + export AWS_SECRET_ACCESS_KEY="$(head -n1 ${lib.escapeShellArg cfg.storage.secretKeyFile})" + ''} + ${lib.optionalString (cfg.slackAuthentication != null) '' + export SLACK_CLIENT_SECRET="$(head -n1 ${lib.escapeShellArg cfg.slackAuthentication.secretFile})" + ''} + ${lib.optionalString (cfg.googleAuthentication != null) '' + export GOOGLE_CLIENT_SECRET="$(head -n1 ${lib.escapeShellArg cfg.googleAuthentication.clientSecretFile})" + ''} + ${lib.optionalString (cfg.azureAuthentication != null) '' + export AZURE_CLIENT_SECRET="$(head -n1 ${lib.escapeShellArg cfg.azureAuthentication.clientSecretFile})" + ''} + ${lib.optionalString (cfg.oidcAuthentication != null) '' + export OIDC_CLIENT_SECRET="$(head -n1 ${lib.escapeShellArg cfg.oidcAuthentication.clientSecretFile})" + ''} + ${lib.optionalString (cfg.sslKeyFile != null) '' + export SSL_KEY="$(head -n1 ${lib.escapeShellArg cfg.sslKeyFile})" + ''} + ${lib.optionalString (cfg.sslCertFile != null) '' + export SSL_CERT="$(head -n1 ${lib.escapeShellArg cfg.sslCertFile})" + ''} + ${lib.optionalString (cfg.slackIntegration != null) '' + export SLACK_VERIFICATION_TOKEN="$(head -n1 ${lib.escapeShellArg cfg.slackIntegration.verificationTokenFile})" + ''} + ${lib.optionalString (cfg.smtp != null) '' + export SMTP_PASSWORD="$(head -n1 ${lib.escapeShellArg cfg.smtp.passwordFile})" + ''} + + ${ + if (cfg.databaseUrl == "local") then + '' + export DATABASE_URL=${lib.escapeShellArg localPostgresqlUrl} + export PGSSLMODE=disable + '' + else + '' + export DATABASE_URL=${lib.escapeShellArg cfg.databaseUrl} + '' + } + + ${cfg.package}/bin/outline-server + ''; + + serviceConfig = { + User = cfg.user; + Group = cfg.group; + Restart = "always"; + ProtectSystem = "strict"; + PrivateHome = true; + PrivateTmp = true; + UMask = "0007"; + + StateDirectory = "outline"; + StateDirectoryMode = "0750"; + RuntimeDirectory = "outline"; + RuntimeDirectoryMode = "0750"; + # This working directory is required to find stuff like the set of + # onboarding files: + WorkingDirectory = "${cfg.package}/share/outline"; + # In case this directory is not in /var/lib/outline, it needs to be made writable explicitly + ReadWritePaths = lib.mkIf (cfg.storage.storageType == "local") [ cfg.storage.localRootDir ]; + }; }; - }; }; } diff --git a/nixos/modules/services/web-apps/peering-manager.nix b/nixos/modules/services/web-apps/peering-manager.nix index acdc3937452932..dd70567adab074 100644 --- a/nixos/modules/services/web-apps/peering-manager.nix +++ b/nixos/modules/services/web-apps/peering-manager.nix @@ -1,34 +1,49 @@ -{ config, lib, pkgs, buildEnv, ... }: +{ + config, + lib, + pkgs, + buildEnv, + ... +}: let cfg = config.services.peering-manager; - pythonFmt = pkgs.formats.pythonVars {}; + pythonFmt = pkgs.formats.pythonVars { }; settingsFile = pythonFmt.generate "peering-manager-settings.py" cfg.settings; extraConfigFile = pkgs.writeTextFile { name = "peering-manager-extraConfig.py"; text = cfg.extraConfig; }; - configFile = pkgs.concatText "configuration.py" [ settingsFile extraConfigFile ]; - - pkg = (pkgs.peering-manager.overrideAttrs (old: { - postInstall = '' - ln -s ${configFile} $out/opt/peering-manager/peering_manager/configuration.py - '' + lib.optionalString cfg.enableLdap '' - ln -s ${cfg.ldapConfigPath} $out/opt/peering-manager/peering_manager/ldap_config.py - '' + lib.optionalString cfg.enableOidc '' - ln -s ${cfg.oidcConfigPath} $out/opt/peering-manager/peering_manager/oidc_config.py - ''; - })).override { - inherit (cfg) plugins; - }; + configFile = pkgs.concatText "configuration.py" [ + settingsFile + extraConfigFile + ]; + + pkg = + (pkgs.peering-manager.overrideAttrs (old: { + postInstall = + '' + ln -s ${configFile} $out/opt/peering-manager/peering_manager/configuration.py + '' + + lib.optionalString cfg.enableLdap '' + ln -s ${cfg.ldapConfigPath} $out/opt/peering-manager/peering_manager/ldap_config.py + '' + + lib.optionalString cfg.enableOidc '' + ln -s ${cfg.oidcConfigPath} $out/opt/peering-manager/peering_manager/oidc_config.py + ''; + })).override + { + inherit (cfg) plugins; + }; peeringManagerManageScript = pkgs.writeScriptBin "peering-manager-manage" '' #!${pkgs.stdenv.shell} export PYTHONPATH=${pkg.pythonPath} sudo -u peering-manager ${pkg}/bin/peering-manager "$@" ''; -in { +in +{ options.services.peering-manager = with lib; { enable = mkOption { type = types.bool; @@ -67,7 +82,7 @@ in { plugins = mkOption { type = types.functionTo (types.listOf types.package); - default = _: []; + default = _: [ ]; defaultText = literalExpression '' python3Packages: with python3Packages; []; ''; @@ -105,7 +120,7 @@ in { options = { ALLOWED_HOSTS = lib.mkOption { type = with lib.types; listOf str; - default = ["*"]; + default = [ "*" ]; description = '' A list of valid fully-qualified domain names (FQDNs) and/or IP addresses that can be used to reach the peering manager service. @@ -185,17 +200,27 @@ in { }; }; - extraConfig = '' - with open("${cfg.secretKeyFile}", "r") as file: - SECRET_KEY = file.readline() - '' + lib.optionalString (cfg.peeringdbApiKeyFile != null) '' - with open("${cfg.peeringdbApiKeyFile}", "r") as file: - PEERINGDB_API_KEY = file.readline() - ''; + extraConfig = + '' + with open("${cfg.secretKeyFile}", "r") as file: + SECRET_KEY = file.readline() + '' + + lib.optionalString (cfg.peeringdbApiKeyFile != null) '' + with open("${cfg.peeringdbApiKeyFile}", "r") as file: + PEERINGDB_API_KEY = file.readline() + ''; - plugins = (ps: - (lib.optionals cfg.enableLdap [ ps.django-auth-ldap ]) ++ - (lib.optionals cfg.enableOidc (with ps; [ mozilla-django-oidc pyopenssl josepy ])) + plugins = ( + ps: + (lib.optionals cfg.enableLdap [ ps.django-auth-ldap ]) + ++ (lib.optionals cfg.enableOidc ( + with ps; + [ + mozilla-django-oidc + pyopenssl + josepy + ] + )) ); }; @@ -220,103 +245,108 @@ in { description = "Target for all Peering Manager services"; wantedBy = [ "multi-user.target" ]; wants = [ "network-online.target" ]; - after = [ "network-online.target" "redis-peering-manager.service" ]; + after = [ + "network-online.target" + "redis-peering-manager.service" + ]; }; - systemd.services = let - defaults = { - environment = { - PYTHONPATH = pkg.pythonPath; - }; - serviceConfig = { - WorkingDirectory = "/var/lib/peering-manager"; - User = "peering-manager"; - Group = "peering-manager"; - StateDirectory = "peering-manager"; - StateDirectoryMode = "0750"; - Restart = "on-failure"; + systemd.services = + let + defaults = { + environment = { + PYTHONPATH = pkg.pythonPath; + }; + serviceConfig = { + WorkingDirectory = "/var/lib/peering-manager"; + User = "peering-manager"; + Group = "peering-manager"; + StateDirectory = "peering-manager"; + StateDirectoryMode = "0750"; + Restart = "on-failure"; + }; }; - }; - in { - peering-manager-migration = lib.recursiveUpdate defaults { - description = "Peering Manager migrations"; - wantedBy = [ "peering-manager.target" ]; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${pkg}/bin/peering-manager migrate"; + in + { + peering-manager-migration = lib.recursiveUpdate defaults { + description = "Peering Manager migrations"; + wantedBy = [ "peering-manager.target" ]; + serviceConfig = { + Type = "oneshot"; + ExecStart = "${pkg}/bin/peering-manager migrate"; + }; }; - }; - peering-manager = lib.recursiveUpdate defaults { - description = "Peering Manager WSGI Service"; - wantedBy = [ "peering-manager.target" ]; - after = [ "peering-manager-migration.service" ]; + peering-manager = lib.recursiveUpdate defaults { + description = "Peering Manager WSGI Service"; + wantedBy = [ "peering-manager.target" ]; + after = [ "peering-manager-migration.service" ]; - preStart = '' - ${pkg}/bin/peering-manager remove_stale_contenttypes --no-input - ''; - - serviceConfig = { - ExecStart = '' - ${pkg.python.pkgs.gunicorn}/bin/gunicorn peering_manager.wsgi \ - --bind ${cfg.listenAddress}:${toString cfg.port} \ - --pythonpath ${pkg}/opt/peering-manager + preStart = '' + ${pkg}/bin/peering-manager remove_stale_contenttypes --no-input ''; + + serviceConfig = { + ExecStart = '' + ${pkg.python.pkgs.gunicorn}/bin/gunicorn peering_manager.wsgi \ + --bind ${cfg.listenAddress}:${toString cfg.port} \ + --pythonpath ${pkg}/opt/peering-manager + ''; + }; }; - }; - peering-manager-rq = lib.recursiveUpdate defaults { - description = "Peering Manager Request Queue Worker"; - wantedBy = [ "peering-manager.target" ]; - after = [ "peering-manager.service" ]; - serviceConfig.ExecStart = "${pkg}/bin/peering-manager rqworker high default low"; - }; + peering-manager-rq = lib.recursiveUpdate defaults { + description = "Peering Manager Request Queue Worker"; + wantedBy = [ "peering-manager.target" ]; + after = [ "peering-manager.service" ]; + serviceConfig.ExecStart = "${pkg}/bin/peering-manager rqworker high default low"; + }; - peering-manager-housekeeping = lib.recursiveUpdate defaults { - description = "Peering Manager housekeeping job"; - after = [ "peering-manager.service" ]; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${pkg}/bin/peering-manager housekeeping"; + peering-manager-housekeeping = lib.recursiveUpdate defaults { + description = "Peering Manager housekeeping job"; + after = [ "peering-manager.service" ]; + serviceConfig = { + Type = "oneshot"; + ExecStart = "${pkg}/bin/peering-manager housekeeping"; + }; }; - }; - peering-manager-peeringdb-sync = lib.recursiveUpdate defaults { - description = "PeeringDB sync"; - after = [ "peering-manager.service" ]; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${pkg}/bin/peering-manager peeringdb_sync"; + peering-manager-peeringdb-sync = lib.recursiveUpdate defaults { + description = "PeeringDB sync"; + after = [ "peering-manager.service" ]; + serviceConfig = { + Type = "oneshot"; + ExecStart = "${pkg}/bin/peering-manager peeringdb_sync"; + }; }; - }; - peering-manager-prefix-fetch = lib.recursiveUpdate defaults { - description = "Fetch IRR AS-SET prefixes"; - after = [ "peering-manager.service" ]; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${pkg}/bin/peering-manager grab_prefixes"; + peering-manager-prefix-fetch = lib.recursiveUpdate defaults { + description = "Fetch IRR AS-SET prefixes"; + after = [ "peering-manager.service" ]; + serviceConfig = { + Type = "oneshot"; + ExecStart = "${pkg}/bin/peering-manager grab_prefixes"; + }; }; - }; - peering-manager-configuration-deployment = lib.recursiveUpdate defaults { - description = "Push configuration to routers"; - after = [ "peering-manager.service" ]; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${pkg}/bin/peering-manager configure_routers"; + peering-manager-configuration-deployment = lib.recursiveUpdate defaults { + description = "Push configuration to routers"; + after = [ "peering-manager.service" ]; + serviceConfig = { + Type = "oneshot"; + ExecStart = "${pkg}/bin/peering-manager configure_routers"; + }; }; - }; - peering-manager-session-poll = lib.recursiveUpdate defaults { - description = "Poll peering sessions from routers"; - after = [ "peering-manager.service" ]; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${pkg}/bin/peering-manager poll_bgp_sessions --all"; + peering-manager-session-poll = lib.recursiveUpdate defaults { + description = "Poll peering sessions from routers"; + after = [ "peering-manager.service" ]; + serviceConfig = { + Type = "oneshot"; + ExecStart = "${pkg}/bin/peering-manager poll_bgp_sessions --all"; + }; }; }; - }; systemd.timers = { peering-manager-housekeeping = { @@ -359,8 +389,10 @@ in { isSystemUser = true; group = "peering-manager"; }; - users.groups.peering-manager = {}; - users.groups."${config.services.redis.servers.peering-manager.user}".members = [ "peering-manager" ]; + users.groups.peering-manager = { }; + users.groups."${config.services.redis.servers.peering-manager.user}".members = [ + "peering-manager" + ]; }; meta.maintainers = with lib.maintainers; [ yuka ]; diff --git a/nixos/modules/services/web-apps/peertube.nix b/nixos/modules/services/web-apps/peertube.nix index bffc74e1061005..b61344a95db888 100644 --- a/nixos/modules/services/web-apps/peertube.nix +++ b/nixos/modules/services/web-apps/peertube.nix @@ -1,10 +1,16 @@ -{ lib, pkgs, config, options, ... }: +{ + lib, + pkgs, + config, + options, + ... +}: let cfg = config.services.peertube; opt = options.services.peertube; - settingsFormat = pkgs.formats.json {}; + settingsFormat = pkgs.formats.json { }; configFile = settingsFormat.generate "production.json" cfg.settings; env = { @@ -16,7 +22,17 @@ let HOME = cfg.package; }; - systemCallsList = [ "@cpu-emulation" "@debug" "@keyring" "@ipc" "@memlock" "@mount" "@obsolete" "@privileged" "@setuid" ]; + systemCallsList = [ + "@cpu-emulation" + "@debug" + "@keyring" + "@ipc" + "@memlock" + "@mount" + "@obsolete" + "@privileged" + "@setuid" + ]; cfgService = { # Proc filesystem @@ -50,10 +66,13 @@ let SystemCallArchitectures = "native"; }; - envFile = pkgs.writeText "peertube.env" (lib.concatMapStrings (s: s + "\n") ( - (lib.concatLists (lib.mapAttrsToList (name: value: - lib.optional (value != null) ''${name}="${toString value}"'' - ) env)))); + envFile = pkgs.writeText "peertube.env" ( + lib.concatMapStrings (s: s + "\n") ( + (lib.concatLists ( + lib.mapAttrsToList (name: value: lib.optional (value != null) ''${name}="${toString value}"'') env + )) + ) + ); peertubeEnv = pkgs.writeShellScriptBin "peertube-env" '' set -a @@ -61,11 +80,19 @@ let eval -- "\$@" ''; - nginxCommonHeaders = lib.optionalString config.services.nginx.virtualHosts.${cfg.localDomain}.forceSSL '' - add_header Strict-Transport-Security 'max-age=31536000'; - '' + lib.optionalString (config.services.nginx.virtualHosts.${cfg.localDomain}.quic && config.services.nginx.virtualHosts.${cfg.localDomain}.http3) '' - add_header Alt-Svc 'h3=":$server_port"; ma=604800'; - ''; + nginxCommonHeaders = + lib.optionalString config.services.nginx.virtualHosts.${cfg.localDomain}.forceSSL '' + add_header Strict-Transport-Security 'max-age=31536000'; + '' + + + lib.optionalString + ( + config.services.nginx.virtualHosts.${cfg.localDomain}.quic + && config.services.nginx.virtualHosts.${cfg.localDomain}.http3 + ) + '' + add_header Alt-Svc 'h3=":$server_port"; ma=604800'; + ''; nginxCommonHeadersExtra = '' add_header Access-Control-Allow-Origin '*'; @@ -73,7 +100,8 @@ let add_header Access-Control-Allow-Headers 'Range,DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type'; ''; -in { +in +{ options.services.peertube = { enable = lib.mkEnableOption "Peertube"; @@ -116,7 +144,10 @@ in { dataDirs = lib.mkOption { type = lib.types.listOf lib.types.path; default = [ ]; - example = [ "/opt/peertube/storage" "/var/cache/peertube" ]; + example = [ + "/opt/peertube/storage" + "/var/cache/peertube" + ]; description = "Allow access to custom data locations."; }; @@ -283,48 +314,58 @@ in { config = lib.mkIf cfg.enable { assertions = [ - { assertion = cfg.serviceEnvironmentFile == null || !lib.hasPrefix builtins.storeDir cfg.serviceEnvironmentFile; - message = '' - points to - a file in the Nix store. You should use a quoted absolute path to - prevent this. - ''; + { + assertion = + cfg.serviceEnvironmentFile == null || !lib.hasPrefix builtins.storeDir cfg.serviceEnvironmentFile; + message = '' + points to + a file in the Nix store. You should use a quoted absolute path to + prevent this. + ''; } - { assertion = cfg.secrets.secretsFile != null; - message = '' - needs to be set. - ''; + { + assertion = cfg.secrets.secretsFile != null; + message = '' + needs to be set. + ''; } - { assertion = !(cfg.redis.enableUnixSocket && (cfg.redis.host != null || cfg.redis.port != null)); - message = '' - and redis network connection ( or ) enabled. Disable either of them. + { + assertion = !(cfg.redis.enableUnixSocket && (cfg.redis.host != null || cfg.redis.port != null)); + message = '' + and redis network connection ( or ) enabled. Disable either of them. ''; } - { assertion = cfg.redis.enableUnixSocket || (cfg.redis.host != null && cfg.redis.port != null); - message = '' - and needs to be set if is not enabled. + { + assertion = cfg.redis.enableUnixSocket || (cfg.redis.host != null && cfg.redis.port != null); + message = '' + and needs to be set if is not enabled. ''; } - { assertion = cfg.redis.passwordFile == null || !lib.hasPrefix builtins.storeDir cfg.redis.passwordFile; - message = '' - points to - a file in the Nix store. You should use a quoted absolute path to - prevent this. - ''; + { + assertion = + cfg.redis.passwordFile == null || !lib.hasPrefix builtins.storeDir cfg.redis.passwordFile; + message = '' + points to + a file in the Nix store. You should use a quoted absolute path to + prevent this. + ''; } - { assertion = cfg.database.passwordFile == null || !lib.hasPrefix builtins.storeDir cfg.database.passwordFile; - message = '' - points to - a file in the Nix store. You should use a quoted absolute path to - prevent this. - ''; + { + assertion = + cfg.database.passwordFile == null || !lib.hasPrefix builtins.storeDir cfg.database.passwordFile; + message = '' + points to + a file in the Nix store. You should use a quoted absolute path to + prevent this. + ''; } - { assertion = cfg.smtp.passwordFile == null || !lib.hasPrefix builtins.storeDir cfg.smtp.passwordFile; - message = '' - points to - a file in the Nix store. You should use a quoted absolute path to - prevent this. - ''; + { + assertion = cfg.smtp.passwordFile == null || !lib.hasPrefix builtins.storeDir cfg.smtp.passwordFile; + message = '' + points to + a file in the Nix store. You should use a quoted absolute path to + prevent this. + ''; } ]; @@ -380,7 +421,11 @@ in { }; }; } - (lib.mkIf cfg.redis.enableUnixSocket { redis = { socket = "/run/redis-peertube/redis.sock"; }; }) + (lib.mkIf cfg.redis.enableUnixSocket { + redis = { + socket = "/run/redis-peertube/redis.sock"; + }; + }) ]; systemd.tmpfiles.rules = [ @@ -392,18 +437,23 @@ in { systemd.services.peertube-init-db = lib.mkIf cfg.database.createLocally { description = "Initialization database for PeerTube daemon"; - after = [ "network.target" "postgresql.service" ]; + after = [ + "network.target" + "postgresql.service" + ]; requires = [ "postgresql.service" ]; - script = let - psqlSetupCommands = pkgs.writeText "peertube-init.sql" '' - SELECT 'CREATE USER "${cfg.database.user}"' WHERE NOT EXISTS (SELECT FROM pg_roles WHERE rolname = '${cfg.database.user}')\gexec - SELECT 'CREATE DATABASE "${cfg.database.name}" OWNER "${cfg.database.user}" TEMPLATE template0 ENCODING UTF8' WHERE NOT EXISTS (SELECT FROM pg_database WHERE datname = '${cfg.database.name}')\gexec - \c '${cfg.database.name}' - CREATE EXTENSION IF NOT EXISTS pg_trgm; - CREATE EXTENSION IF NOT EXISTS unaccent; - ''; - in "${config.services.postgresql.package}/bin/psql -f ${psqlSetupCommands}"; + script = + let + psqlSetupCommands = pkgs.writeText "peertube-init.sql" '' + SELECT 'CREATE USER "${cfg.database.user}"' WHERE NOT EXISTS (SELECT FROM pg_roles WHERE rolname = '${cfg.database.user}')\gexec + SELECT 'CREATE DATABASE "${cfg.database.name}" OWNER "${cfg.database.user}" TEMPLATE template0 ENCODING UTF8' WHERE NOT EXISTS (SELECT FROM pg_database WHERE datname = '${cfg.database.name}')\gexec + \c '${cfg.database.name}' + CREATE EXTENSION IF NOT EXISTS pg_trgm; + CREATE EXTENSION IF NOT EXISTS unaccent; + ''; + in + "${config.services.postgresql.package}/bin/psql -f ${psqlSetupCommands}"; serviceConfig = { Type = "oneshot"; @@ -421,35 +471,48 @@ in { systemd.services.peertube = { description = "PeerTube daemon"; - after = [ "network.target" ] + after = + [ "network.target" ] ++ lib.optional cfg.redis.createLocally "redis-peertube.service" - ++ lib.optionals cfg.database.createLocally [ "postgresql.service" "peertube-init-db.service" ]; - requires = lib.optional cfg.redis.createLocally "redis-peertube.service" - ++ lib.optionals cfg.database.createLocally [ "postgresql.service" "peertube-init-db.service" ]; + ++ lib.optionals cfg.database.createLocally [ + "postgresql.service" + "peertube-init-db.service" + ]; + requires = + lib.optional cfg.redis.createLocally "redis-peertube.service" + ++ lib.optionals cfg.database.createLocally [ + "postgresql.service" + "peertube-init-db.service" + ]; wantedBy = [ "multi-user.target" ]; environment = env; - path = with pkgs; [ nodejs_18 yarn ffmpeg-headless openssl ]; + path = with pkgs; [ + nodejs_18 + yarn + ffmpeg-headless + openssl + ]; script = '' umask 077 cat > /var/lib/peertube/config/local.yaml < - * - - The NixOS module will handle the configuration changes for you, - at least. - '' + if lib.versionAtLeast config.system.stateVersion "23.11" then + pkgs.pict-rs + else + throw '' + pict-rs made changes to the database schema between 0.3 and 0.4. It + will apply these automatically on the first run of 0.4, but the old + version will no longer work after that. + + Your configuration is currently using the old default of pict-rs + 0.3. Unfortunately, 0.3 no longer builds due to the Rust 1.80 update, + and has been removed. pict-rs has already been updated to 0.5 in + Nixpkgs, which has another schema change but removes the migration + logic for 0.3. + + You will need to migrate to 0.4 first, and then to 0.5. As 0.4 is + no longer present in Nixpkgs, the recommended migration path is: + + * Import a separate Nixpkgs old enough to contain 0.4, temporarily + set `services.pict-rs.package` to its pict-rs, set the + `PICTRS__OLD_DB__PATH` environment variable for the migration, and + activate your configuration to start it. The following configuration + snippet should work: + + services.pict-rs.package = + (import (builtins.fetchTarball { + url = "https://github.com/NixOS/nixpkgs/archive/9b19f5e77dd906cb52dade0b7bd280339d2a1f3d.tar.gz"; + sha256 = "sha256:0939vbhln9d33xkqw63nsk908k03fxihj85zaf70i3il9z42q8mc"; + }) pkgs.config).pict-rs; + + systemd.services.pict-rs.environment.PICTRS__OLD_DB__PATH = config.services.pict-rs.dataDir; + + * After the migration to 0.4 completes, remove the package and + environment variable overrides, set `services.pict-rs.package` to + the current `pkgs.pict-rs` instead, and activate your configuration + to begin the migration to 0.5. + + For more information, see: + + * + * + + The NixOS module will handle the configuration changes for you, + at least. + '' ); systemd.services.pict-rs = { diff --git a/nixos/modules/services/web-apps/plausible.nix b/nixos/modules/services/web-apps/plausible.nix index 213d5125ee93b3..2640c9e53cf712 100644 --- a/nixos/modules/services/web-apps/plausible.nix +++ b/nixos/modules/services/web-apps/plausible.nix @@ -1,11 +1,17 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: with lib; let cfg = config.services.plausible; -in { +in +{ options.services.plausible = { enable = mkEnableOption "plausible"; @@ -13,7 +19,9 @@ in { database = { clickhouse = { - setup = mkEnableOption "creating a clickhouse instance" // { default = true; }; + setup = mkEnableOption "creating a clickhouse instance" // { + default = true; + }; url = mkOption { default = "http://localhost:8123/default"; type = types.str; @@ -23,7 +31,9 @@ in { }; }; postgres = { - setup = mkEnableOption "creating a postgresql instance" // { default = true; }; + setup = mkEnableOption "creating a postgresql instance" // { + default = true; + }; dbname = mkOption { default = "plausible"; type = types.str; @@ -44,7 +54,11 @@ in { server = { disableRegistration = mkOption { default = true; - type = types.enum [true false "invite_only"]; + type = types.enum [ + true + false + "invite_only" + ]; description = '' Whether to prohibit creating an account in plausible's UI or allow on `invite_only`. ''; @@ -136,11 +150,33 @@ in { }; imports = [ - (mkRemovedOptionModule [ "services" "plausible" "releaseCookiePath" ] "Plausible uses no distributed Erlang features, so this option is no longer necessary and was removed") - (mkRemovedOptionModule [ "services" "plausible" "adminUser" "name" ] "Admin user is now created using first start wizard") - (mkRemovedOptionModule [ "services" "plausible" "adminUser" "email" ] "Admin user is now created using first start wizard") - (mkRemovedOptionModule [ "services" "plausible" "adminUser" "passwordFile" ] "Admin user is now created using first start wizard") - (mkRemovedOptionModule [ "services" "plausible" "adminUser" "activate" ] "Admin user is now created using first start wizard") + (mkRemovedOptionModule [ "services" "plausible" "releaseCookiePath" ] + "Plausible uses no distributed Erlang features, so this option is no longer necessary and was removed" + ) + (mkRemovedOptionModule [ + "services" + "plausible" + "adminUser" + "name" + ] "Admin user is now created using first start wizard") + (mkRemovedOptionModule [ + "services" + "plausible" + "adminUser" + "email" + ] "Admin user is now created using first start wizard") + (mkRemovedOptionModule [ + "services" + "plausible" + "adminUser" + "passwordFile" + ] "Admin user is now created using first start wizard") + (mkRemovedOptionModule [ + "services" + "plausible" + "adminUser" + "activate" + ] "Admin user is now created using first start wizard") ]; config = mkIf cfg.enable { @@ -160,75 +196,82 @@ in { inherit (cfg.package.meta) description; documentation = [ "https://plausible.io/docs/self-hosting" ]; wantedBy = [ "multi-user.target" ]; - after = optional cfg.database.clickhouse.setup "clickhouse.service" - ++ optionals cfg.database.postgres.setup [ + after = + optional cfg.database.clickhouse.setup "clickhouse.service" + ++ optionals cfg.database.postgres.setup [ "postgresql.service" "plausible-postgres.service" ]; - requires = optional cfg.database.clickhouse.setup "clickhouse.service" + requires = + optional cfg.database.clickhouse.setup "clickhouse.service" ++ optionals cfg.database.postgres.setup [ "postgresql.service" "plausible-postgres.service" ]; - environment = { - # NixOS specific option to avoid that it's trying to write into its store-path. - # See also https://github.com/lau/tzdata#data-directory-and-releases - STORAGE_DIR = "/var/lib/plausible/elixir_tzdata"; + environment = + { + # NixOS specific option to avoid that it's trying to write into its store-path. + # See also https://github.com/lau/tzdata#data-directory-and-releases + STORAGE_DIR = "/var/lib/plausible/elixir_tzdata"; - # Configuration options from - # https://plausible.io/docs/self-hosting-configuration - PORT = toString cfg.server.port; - LISTEN_IP = cfg.server.listenAddress; + # Configuration options from + # https://plausible.io/docs/self-hosting-configuration + PORT = toString cfg.server.port; + LISTEN_IP = cfg.server.listenAddress; - # Note [plausible-needs-no-erlang-distributed-features]: - # Plausible does not use, and does not plan to use, any of - # Erlang's distributed features, see: - # https://github.com/plausible/analytics/pull/1190#issuecomment-1018820934 - # Thus, disable distribution for improved simplicity and security: - # - # When distribution is enabled, - # Elixir spwans the Erlang VM, which will listen by default on all - # interfaces for messages between Erlang nodes (capable of - # remote code execution); it can be protected by a cookie; see - # https://erlang.org/doc/reference_manual/distributed.html#security). - # - # It would be possible to restrict the interface to one of our choice - # (e.g. localhost or a VPN IP) similar to how we do it with `listenAddress` - # for the Plausible web server; if distribution is ever needed in the future, - # https://github.com/NixOS/nixpkgs/pull/130297 shows how to do it. - # - # But since Plausible does not use this feature in any way, - # we just disable it. - RELEASE_DISTRIBUTION = "none"; - # Additional safeguard, in case `RELEASE_DISTRIBUTION=none` ever - # stops disabling the start of EPMD. - ERL_EPMD_ADDRESS = "127.0.0.1"; + # Note [plausible-needs-no-erlang-distributed-features]: + # Plausible does not use, and does not plan to use, any of + # Erlang's distributed features, see: + # https://github.com/plausible/analytics/pull/1190#issuecomment-1018820934 + # Thus, disable distribution for improved simplicity and security: + # + # When distribution is enabled, + # Elixir spwans the Erlang VM, which will listen by default on all + # interfaces for messages between Erlang nodes (capable of + # remote code execution); it can be protected by a cookie; see + # https://erlang.org/doc/reference_manual/distributed.html#security). + # + # It would be possible to restrict the interface to one of our choice + # (e.g. localhost or a VPN IP) similar to how we do it with `listenAddress` + # for the Plausible web server; if distribution is ever needed in the future, + # https://github.com/NixOS/nixpkgs/pull/130297 shows how to do it. + # + # But since Plausible does not use this feature in any way, + # we just disable it. + RELEASE_DISTRIBUTION = "none"; + # Additional safeguard, in case `RELEASE_DISTRIBUTION=none` ever + # stops disabling the start of EPMD. + ERL_EPMD_ADDRESS = "127.0.0.1"; - DISABLE_REGISTRATION = if isBool cfg.server.disableRegistration then boolToString cfg.server.disableRegistration else cfg.server.disableRegistration; + DISABLE_REGISTRATION = + if isBool cfg.server.disableRegistration then + boolToString cfg.server.disableRegistration + else + cfg.server.disableRegistration; - RELEASE_TMP = "/var/lib/plausible/tmp"; - # Home is needed to connect to the node with iex - HOME = "/var/lib/plausible"; + RELEASE_TMP = "/var/lib/plausible/tmp"; + # Home is needed to connect to the node with iex + HOME = "/var/lib/plausible"; - DATABASE_URL = "postgresql:///${cfg.database.postgres.dbname}?host=${cfg.database.postgres.socket}"; - CLICKHOUSE_DATABASE_URL = cfg.database.clickhouse.url; + DATABASE_URL = "postgresql:///${cfg.database.postgres.dbname}?host=${cfg.database.postgres.socket}"; + CLICKHOUSE_DATABASE_URL = cfg.database.clickhouse.url; - BASE_URL = cfg.server.baseUrl; + BASE_URL = cfg.server.baseUrl; - MAILER_EMAIL = cfg.mail.email; - SMTP_HOST_ADDR = cfg.mail.smtp.hostAddr; - SMTP_HOST_PORT = toString cfg.mail.smtp.hostPort; - SMTP_RETRIES = toString cfg.mail.smtp.retries; - SMTP_HOST_SSL_ENABLED = boolToString cfg.mail.smtp.enableSSL; + MAILER_EMAIL = cfg.mail.email; + SMTP_HOST_ADDR = cfg.mail.smtp.hostAddr; + SMTP_HOST_PORT = toString cfg.mail.smtp.hostPort; + SMTP_RETRIES = toString cfg.mail.smtp.retries; + SMTP_HOST_SSL_ENABLED = boolToString cfg.mail.smtp.enableSSL; - SELFHOST = "true"; - } // (optionalAttrs (cfg.mail.smtp.user != null) { - SMTP_USER_NAME = cfg.mail.smtp.user; - }); + SELFHOST = "true"; + } + // (optionalAttrs (cfg.mail.smtp.user != null) { + SMTP_USER_NAME = cfg.mail.smtp.user; + }); - path = [ cfg.package ] - ++ optional cfg.database.postgres.setup config.services.postgresql.package; + path = [ cfg.package ] ++ optional cfg.database.postgres.setup config.services.postgresql.package; script = '' # Elixir does not start up if `RELEASE_COOKIE` is not set, # even though we set `RELEASE_DISTRIBUTION=none` so the cookie should be unused. @@ -236,8 +279,9 @@ in { export RELEASE_COOKIE=$(tr -dc A-Za-z0-9 < /dev/urandom | head -c 20) export SECRET_KEY_BASE="$(< $CREDENTIALS_DIRECTORY/SECRET_KEY_BASE )" - ${lib.optionalString (cfg.mail.smtp.passwordFile != null) - ''export SMTP_USER_PWD="$(< $CREDENTIALS_DIRECTORY/SMTP_USER_PWD )"''} + ${lib.optionalString ( + cfg.mail.smtp.passwordFile != null + ) ''export SMTP_USER_PWD="$(< $CREDENTIALS_DIRECTORY/SMTP_USER_PWD )"''} ${lib.optionalString cfg.database.postgres.setup '' # setup @@ -255,9 +299,13 @@ in { PrivateTmp = true; WorkingDirectory = "/var/lib/plausible"; StateDirectory = "plausible"; - LoadCredential = [ - "SECRET_KEY_BASE:${cfg.server.secretKeybaseFile}" - ] ++ lib.optionals (cfg.mail.smtp.passwordFile != null) [ "SMTP_USER_PWD:${cfg.mail.smtp.passwordFile}"]; + LoadCredential = + [ + "SECRET_KEY_BASE:${cfg.server.secretKeybaseFile}" + ] + ++ lib.optionals (cfg.mail.smtp.passwordFile != null) [ + "SMTP_USER_PWD:${cfg.mail.smtp.passwordFile}" + ]; }; }; } diff --git a/nixos/modules/services/web-apps/powerdns-admin.nix b/nixos/modules/services/web-apps/powerdns-admin.nix index d1886129515e17..7c23cd10efad48 100644 --- a/nixos/modules/services/web-apps/powerdns-admin.nix +++ b/nixos/modules/services/web-apps/powerdns-admin.nix @@ -1,21 +1,27 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.powerdns-admin; - configText = '' - ${cfg.config} - '' - + optionalString (cfg.secretKeyFile != null) '' - with open('${cfg.secretKeyFile}') as file: - SECRET_KEY = file.read() - '' - + optionalString (cfg.saltFile != null) '' - with open('${cfg.saltFile}') as file: - SALT = file.read() - ''; + configText = + '' + ${cfg.config} + '' + + optionalString (cfg.secretKeyFile != null) '' + with open('${cfg.secretKeyFile}') as file: + SECRET_KEY = file.read() + '' + + optionalString (cfg.saltFile != null) '' + with open('${cfg.saltFile}') as file: + SALT = file.read() + ''; in { options.services.powerdns-admin = { @@ -87,15 +93,16 @@ in User = "powerdnsadmin"; Group = "powerdnsadmin"; - BindReadOnlyPaths = [ - "/nix/store" - "-/etc/resolv.conf" - "-/etc/nsswitch.conf" - "-/etc/hosts" - "-/etc/localtime" - ] - ++ (optional (cfg.secretKeyFile != null) cfg.secretKeyFile) - ++ (optional (cfg.saltFile != null) cfg.saltFile); + BindReadOnlyPaths = + [ + "/nix/store" + "-/etc/resolv.conf" + "-/etc/nsswitch.conf" + "-/etc/hosts" + "-/etc/localtime" + ] + ++ (optional (cfg.secretKeyFile != null) cfg.secretKeyFile) + ++ (optional (cfg.saltFile != null) cfg.saltFile); # ProtectClock= adds DeviceAllow=char-rtc r DeviceAllow = ""; # Implies ProtectSystem=strict, which re-mounts all paths @@ -120,7 +127,11 @@ in ProtectKernelModules = true; ProtectKernelTunables = true; ProtectProc = "invisible"; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; RestrictNamespaces = true; RestrictRealtime = true; RestrictSUIDSGID = true; diff --git a/nixos/modules/services/web-apps/pretalx.nix b/nixos/modules/services/web-apps/pretalx.nix index 89952f09c92e79..c7d35d029963e6 100644 --- a/nixos/modules/services/web-apps/pretalx.nix +++ b/nixos/modules/services/web-apps/pretalx.nix @@ -1,8 +1,9 @@ -{ config -, lib -, pkgs -, utils -, ... +{ + config, + lib, + pkgs, + utils, + ... }: let @@ -16,25 +17,29 @@ let }; pythonEnv = finalPackage.python.buildEnv.override { - extraLibs = with finalPackage.python.pkgs; [ - (toPythonModule finalPackage) - gunicorn - ] - ++ finalPackage.optional-dependencies.redis - ++ lib.optionals cfg.celery.enable [ celery ] - ++ lib.optionals (cfg.settings.database.backend == "postgresql") finalPackage.optional-dependencies.postgres; + extraLibs = + with finalPackage.python.pkgs; + [ + (toPythonModule finalPackage) + gunicorn + ] + ++ finalPackage.optional-dependencies.redis + ++ lib.optionals cfg.celery.enable [ celery ] + ++ lib.optionals ( + cfg.settings.database.backend == "postgresql" + ) finalPackage.optional-dependencies.postgres; }; in { meta = with lib; { - maintainers = with maintainers; [ hexa] ++ teams.c3d2.members; + maintainers = with maintainers; [ hexa ] ++ teams.c3d2.members; }; options.services.pretalx = { enable = lib.mkEnableOption "pretalx"; - package = lib.mkPackageOption pkgs "pretalx" {}; + package = lib.mkPackageOption pkgs "pretalx" { }; group = lib.mkOption { type = lib.types.str; @@ -50,7 +55,7 @@ in plugins = lib.mkOption { type = with lib.types; listOf package; - default = []; + default = [ ]; example = lib.literalExpression '' with config.services.pretalx.package.plugins; [ pages @@ -153,9 +158,13 @@ in host = lib.mkOption { type = with lib.types; nullOr types.path; - default = if cfg.settings.database.backend == "postgresql" then "/run/postgresql" - else if cfg.settings.database.backend == "mysql" then "/run/mysqld/mysqld.sock" - else null; + default = + if cfg.settings.database.backend == "postgresql" then + "/run/postgresql" + else if cfg.settings.database.backend == "mysql" then + "/run/mysqld/mysqld.sock" + else + null; defaultText = lib.literalExpression '' if config.services.pretalx.settings..database.backend == "postgresql" then "/run/postgresql" else if config.services.pretalx.settings.database.backend == "mysql" then "/run/mysqld/mysqld.sock" @@ -349,130 +358,144 @@ in }; }; - postgresql = lib.mkIf (cfg.database.createLocally && cfg.settings.database.backend == "postgresql") { - enable = true; - ensureUsers = [ { - name = cfg.settings.database.user; - ensureDBOwnership = true; - } ]; - ensureDatabases = [ cfg.settings.database.name ]; - }; + postgresql = + lib.mkIf (cfg.database.createLocally && cfg.settings.database.backend == "postgresql") + { + enable = true; + ensureUsers = [ + { + name = cfg.settings.database.user; + ensureDBOwnership = true; + } + ]; + ensureDatabases = [ cfg.settings.database.name ]; + }; redis.servers.pretalx.enable = true; }; - systemd.services = let - commonUnitConfig = { - environment.PRETALX_CONFIG_FILE = configFile; - serviceConfig = { - User = "pretalx"; - Group = "pretalx"; - StateDirectory = [ - "pretalx" - "pretalx/media" - ]; - StateDirectoryMode = "0750"; - LogsDirectory = "pretalx"; - WorkingDirectory = cfg.settings.filesystem.data; - SupplementaryGroups = [ "redis-pretalx" ]; - AmbientCapabilities = ""; - CapabilityBoundingSet = [ "" ]; - DevicePolicy = "closed"; - LockPersonality = true; - MemoryDenyWriteExecute = true; - NoNewPrivileges = true; - PrivateDevices = true; - PrivateTmp = true; - ProcSubset = "pid"; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - ProtectSystem = "strict"; - RemoveIPC = true; - RestrictAddressFamilies = [ - "AF_INET" - "AF_INET6" - "AF_UNIX" - ]; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ - "@system-service" - "~@privileged" - "@chown" - ]; - UMask = "0027"; + systemd.services = + let + commonUnitConfig = { + environment.PRETALX_CONFIG_FILE = configFile; + serviceConfig = { + User = "pretalx"; + Group = "pretalx"; + StateDirectory = [ + "pretalx" + "pretalx/media" + ]; + StateDirectoryMode = "0750"; + LogsDirectory = "pretalx"; + WorkingDirectory = cfg.settings.filesystem.data; + SupplementaryGroups = [ "redis-pretalx" ]; + AmbientCapabilities = ""; + CapabilityBoundingSet = [ "" ]; + DevicePolicy = "closed"; + LockPersonality = true; + MemoryDenyWriteExecute = true; + NoNewPrivileges = true; + PrivateDevices = true; + PrivateTmp = true; + ProcSubset = "pid"; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + ProtectSystem = "strict"; + RemoveIPC = true; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "@chown" + ]; + UMask = "0027"; + }; }; - }; - in { - pretalx-web = lib.recursiveUpdate commonUnitConfig { - description = "pretalx web service"; - after = [ - "network.target" - "redis-pretalx.service" - ] ++ lib.optionals (cfg.settings.database.backend == "postgresql") [ - "postgresql.service" - ] ++ lib.optionals (cfg.settings.database.backend == "mysql") [ - "mysql.service" - ]; - wantedBy = [ "multi-user.target" ]; - preStart = '' - versionFile="${cfg.settings.filesystem.data}/.version" - version=$(cat "$versionFile" 2>/dev/null || echo 0) - - if [[ $version != ${cfg.package.version} ]]; then - ${lib.getExe' pythonEnv "pretalx-manage"} migrate - - echo "${cfg.package.version}" > "$versionFile" - fi - ''; - serviceConfig = { - ExecStart = "${lib.getExe' pythonEnv "gunicorn"} --bind unix:/run/pretalx/pretalx.sock ${cfg.gunicorn.extraArgs} pretalx.wsgi"; - RuntimeDirectory = "pretalx"; + in + { + pretalx-web = lib.recursiveUpdate commonUnitConfig { + description = "pretalx web service"; + after = + [ + "network.target" + "redis-pretalx.service" + ] + ++ lib.optionals (cfg.settings.database.backend == "postgresql") [ + "postgresql.service" + ] + ++ lib.optionals (cfg.settings.database.backend == "mysql") [ + "mysql.service" + ]; + wantedBy = [ "multi-user.target" ]; + preStart = '' + versionFile="${cfg.settings.filesystem.data}/.version" + version=$(cat "$versionFile" 2>/dev/null || echo 0) + + if [[ $version != ${cfg.package.version} ]]; then + ${lib.getExe' pythonEnv "pretalx-manage"} migrate + + echo "${cfg.package.version}" > "$versionFile" + fi + ''; + serviceConfig = { + ExecStart = "${lib.getExe' pythonEnv "gunicorn"} --bind unix:/run/pretalx/pretalx.sock ${cfg.gunicorn.extraArgs} pretalx.wsgi"; + RuntimeDirectory = "pretalx"; + }; }; - }; - pretalx-periodic = lib.recursiveUpdate commonUnitConfig { - description = "pretalx periodic task runner"; - # every 15 minutes - startAt = [ "*:3,18,33,48" ]; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${lib.getExe' pythonEnv "pretalx-manage"} runperiodic"; + pretalx-periodic = lib.recursiveUpdate commonUnitConfig { + description = "pretalx periodic task runner"; + # every 15 minutes + startAt = [ "*:3,18,33,48" ]; + serviceConfig = { + Type = "oneshot"; + ExecStart = "${lib.getExe' pythonEnv "pretalx-manage"} runperiodic"; + }; }; - }; - pretalx-clear-sessions = lib.recursiveUpdate commonUnitConfig { - description = "pretalx session pruning"; - startAt = [ "monthly" ]; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${lib.getExe' pythonEnv "pretalx-manage"} clearsessions"; + pretalx-clear-sessions = lib.recursiveUpdate commonUnitConfig { + description = "pretalx session pruning"; + startAt = [ "monthly" ]; + serviceConfig = { + Type = "oneshot"; + ExecStart = "${lib.getExe' pythonEnv "pretalx-manage"} clearsessions"; + }; }; - }; - pretalx-worker = lib.mkIf cfg.celery.enable (lib.recursiveUpdate commonUnitConfig { - description = "pretalx asynchronous job runner"; - after = [ - "network.target" - "redis-pretalx.service" - ] ++ lib.optionals (cfg.settings.database.backend == "postgresql") [ - "postgresql.service" - ] ++ lib.optionals (cfg.settings.database.backend == "mysql") [ - "mysql.service" - ]; - wantedBy = [ "multi-user.target" ]; - serviceConfig.ExecStart = "${lib.getExe' pythonEnv "celery"} -A pretalx.celery_app worker ${cfg.celery.extraArgs}"; - }); + pretalx-worker = lib.mkIf cfg.celery.enable ( + lib.recursiveUpdate commonUnitConfig { + description = "pretalx asynchronous job runner"; + after = + [ + "network.target" + "redis-pretalx.service" + ] + ++ lib.optionals (cfg.settings.database.backend == "postgresql") [ + "postgresql.service" + ] + ++ lib.optionals (cfg.settings.database.backend == "mysql") [ + "mysql.service" + ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig.ExecStart = "${lib.getExe' pythonEnv "celery"} -A pretalx.celery_app worker ${cfg.celery.extraArgs}"; + } + ); - nginx.serviceConfig.SupplementaryGroups = lib.mkIf cfg.nginx.enable [ "pretalx" ]; - }; + nginx.serviceConfig.SupplementaryGroups = lib.mkIf cfg.nginx.enable [ "pretalx" ]; + }; systemd.sockets.pretalx-web.socketConfig = { ListenStream = "/run/pretalx/pretalx.sock"; @@ -480,7 +503,7 @@ in }; users = { - groups.${cfg.group} = {}; + groups.${cfg.group} = { }; users.${cfg.user} = { isSystemUser = true; inherit (cfg) group; diff --git a/nixos/modules/services/web-apps/pretix.nix b/nixos/modules/services/web-apps/pretix.nix index f521c49668c876..68b65e2260d239 100644 --- a/nixos/modules/services/web-apps/pretix.nix +++ b/nixos/modules/services/web-apps/pretix.nix @@ -1,8 +1,9 @@ -{ config -, lib -, pkgs -, utils -, ... +{ + config, + lib, + pkgs, + utils, + ... }: let @@ -26,9 +27,10 @@ let optionalString recursiveUpdate types - ; + ; - filterRecursiveNull = o: + filterRecursiveNull = + o: if isAttrs o then mapAttrs (_: v: filterRecursiveNull v) (filterAttrs (_: v: v != null) o) else if isList o then @@ -46,13 +48,15 @@ let }; pythonEnv = cfg.package.python.buildEnv.override { - extraLibs = with cfg.package.python.pkgs; [ - (toPythonModule finalPackage) - gunicorn - ] - ++ lib.optionals (cfg.settings.memcached.location != null) - cfg.package.optional-dependencies.memcached - ; + extraLibs = + with cfg.package.python.pkgs; + [ + (toPythonModule finalPackage) + gunicorn + ] + ++ lib.optionals ( + cfg.settings.memcached.location != null + ) cfg.package.optional-dependencies.memcached; }; withRedis = cfg.settings.redis.location != null; @@ -96,7 +100,7 @@ in plugins = mkOption { type = types.listOf types.package; - default = []; + default = [ ]; example = literalExpression '' with config.services.pretix.package.plugins; [ passbook @@ -455,128 +459,132 @@ in postgresql = mkIf (cfg.database.createLocally && cfg.settings.database.backend == "postgresql") { enable = true; - ensureUsers = [ { - name = cfg.settings.database.user; - ensureDBOwnership = true; - } ]; + ensureUsers = [ + { + name = cfg.settings.database.user; + ensureDBOwnership = true; + } + ]; ensureDatabases = [ cfg.settings.database.name ]; }; redis.servers.pretix.enable = withRedis; }; - systemd.services = let - commonUnitConfig = { - environment.PRETIX_CONFIG_FILE = configFile; - serviceConfig = { - User = "pretix"; - Group = "pretix"; - EnvironmentFile = optionals (cfg.environmentFile != null) [ - cfg.environmentFile - ]; - StateDirectory = [ - "pretix" - ]; - StateDirectoryMode = "0750"; - CacheDirectory = "pretix"; - LogsDirectory = "pretix"; - WorkingDirectory = cfg.settings.pretix.datadir; - SupplementaryGroups = optionals withRedis [ - "redis-pretix" - ]; - AmbientCapabilities = ""; - CapabilityBoundingSet = [ "" ]; - DevicePolicy = "closed"; - LockPersonality = true; - MemoryDenyWriteExecute = false; # required by pdftk - NoNewPrivileges = true; - PrivateDevices = true; - PrivateTmp = true; - ProcSubset = "pid"; - ProtectControlGroups = true; - ProtectHome = true; - ProtectHostname = true; - ProtectKernelLogs = true; - ProtectKernelModules = true; - ProtectKernelTunables = true; - ProtectProc = "invisible"; - ProtectSystem = "strict"; - RemoveIPC = true; - RestrictAddressFamilies = [ - "AF_INET" - "AF_INET6" - "AF_UNIX" - ]; - RestrictNamespaces = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - SystemCallArchitectures = "native"; - SystemCallFilter = [ - "@system-service" - "~@privileged" - "@chown" - ]; - UMask = "0027"; + systemd.services = + let + commonUnitConfig = { + environment.PRETIX_CONFIG_FILE = configFile; + serviceConfig = { + User = "pretix"; + Group = "pretix"; + EnvironmentFile = optionals (cfg.environmentFile != null) [ + cfg.environmentFile + ]; + StateDirectory = [ + "pretix" + ]; + StateDirectoryMode = "0750"; + CacheDirectory = "pretix"; + LogsDirectory = "pretix"; + WorkingDirectory = cfg.settings.pretix.datadir; + SupplementaryGroups = optionals withRedis [ + "redis-pretix" + ]; + AmbientCapabilities = ""; + CapabilityBoundingSet = [ "" ]; + DevicePolicy = "closed"; + LockPersonality = true; + MemoryDenyWriteExecute = false; # required by pdftk + NoNewPrivileges = true; + PrivateDevices = true; + PrivateTmp = true; + ProcSubset = "pid"; + ProtectControlGroups = true; + ProtectHome = true; + ProtectHostname = true; + ProtectKernelLogs = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectProc = "invisible"; + ProtectSystem = "strict"; + RemoveIPC = true; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; + RestrictNamespaces = true; + RestrictRealtime = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + SystemCallFilter = [ + "@system-service" + "~@privileged" + "@chown" + ]; + UMask = "0027"; + }; }; - }; - in { - pretix-web = recursiveUpdate commonUnitConfig { - description = "pretix web service"; - after = [ - "network.target" - "redis-pretix.service" - "postgresql.service" - ]; - wantedBy = [ "multi-user.target" ]; - preStart = '' - versionFile="${cfg.settings.pretix.datadir}/.version" - version=$(cat "$versionFile" 2>/dev/null || echo 0) + in + { + pretix-web = recursiveUpdate commonUnitConfig { + description = "pretix web service"; + after = [ + "network.target" + "redis-pretix.service" + "postgresql.service" + ]; + wantedBy = [ "multi-user.target" ]; + preStart = '' + versionFile="${cfg.settings.pretix.datadir}/.version" + version=$(cat "$versionFile" 2>/dev/null || echo 0) - pluginsFile="${cfg.settings.pretix.datadir}/.plugins" - plugins=$(cat "$pluginsFile" 2>/dev/null || echo "") - configuredPlugins="${concatMapStringsSep "|" (package: package.name) cfg.plugins}" + pluginsFile="${cfg.settings.pretix.datadir}/.plugins" + plugins=$(cat "$pluginsFile" 2>/dev/null || echo "") + configuredPlugins="${concatMapStringsSep "|" (package: package.name) cfg.plugins}" - if [[ $version != ${cfg.package.version} || $plugins != $configuredPlugins ]]; then - ${getExe' pythonEnv "pretix-manage"} migrate + if [[ $version != ${cfg.package.version} || $plugins != $configuredPlugins ]]; then + ${getExe' pythonEnv "pretix-manage"} migrate - echo "${cfg.package.version}" > "$versionFile" - echo "$configuredPlugins" > "$pluginsFile" - fi - ''; - serviceConfig = { - TimeoutStartSec = "15min"; - ExecStart = "${getExe' pythonEnv "gunicorn"} --bind unix:/run/pretix/pretix.sock ${cfg.gunicorn.extraArgs} pretix.wsgi"; - RuntimeDirectory = "pretix"; - Restart = "on-failure"; + echo "${cfg.package.version}" > "$versionFile" + echo "$configuredPlugins" > "$pluginsFile" + fi + ''; + serviceConfig = { + TimeoutStartSec = "15min"; + ExecStart = "${getExe' pythonEnv "gunicorn"} --bind unix:/run/pretix/pretix.sock ${cfg.gunicorn.extraArgs} pretix.wsgi"; + RuntimeDirectory = "pretix"; + Restart = "on-failure"; + }; }; - }; - pretix-periodic = recursiveUpdate commonUnitConfig { - description = "pretix periodic task runner"; - # every 15 minutes - startAt = [ "*:3,18,33,48" ]; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${getExe' pythonEnv "pretix-manage"} runperiodic"; + pretix-periodic = recursiveUpdate commonUnitConfig { + description = "pretix periodic task runner"; + # every 15 minutes + startAt = [ "*:3,18,33,48" ]; + serviceConfig = { + Type = "oneshot"; + ExecStart = "${getExe' pythonEnv "pretix-manage"} runperiodic"; + }; }; - }; - pretix-worker = recursiveUpdate commonUnitConfig { - description = "pretix asynchronous job runner"; - after = [ - "network.target" - "redis-pretix.service" - "postgresql.service" - ]; - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - ExecStart = "${getExe' pythonEnv "celery"} -A pretix.celery_app worker ${cfg.celery.extraArgs}"; - Restart = "on-failure"; + pretix-worker = recursiveUpdate commonUnitConfig { + description = "pretix asynchronous job runner"; + after = [ + "network.target" + "redis-pretix.service" + "postgresql.service" + ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + ExecStart = "${getExe' pythonEnv "celery"} -A pretix.celery_app worker ${cfg.celery.extraArgs}"; + Restart = "on-failure"; + }; }; - }; - nginx.serviceConfig.SupplementaryGroups = mkIf cfg.nginx.enable [ "pretix" ]; - }; + nginx.serviceConfig.SupplementaryGroups = mkIf cfg.nginx.enable [ "pretix" ]; + }; systemd.sockets.pretix-web.socketConfig = { ListenStream = "/run/pretix/pretix.sock"; @@ -584,7 +592,7 @@ in }; users = { - groups.${cfg.group} = {}; + groups.${cfg.group} = { }; users.${cfg.user} = { isSystemUser = true; inherit (cfg) group; diff --git a/nixos/modules/services/web-apps/prosody-filer.nix b/nixos/modules/services/web-apps/prosody-filer.nix index 91880cab2976d9..93bc37a5be5492 100644 --- a/nixos/modules/services/web-apps/prosody-filer.nix +++ b/nixos/modules/services/web-apps/prosody-filer.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let @@ -7,7 +12,8 @@ let settingsFormat = pkgs.formats.toml { }; configFile = settingsFormat.generate "prosody-filer.toml" cfg.settings; -in { +in +{ options = { services.prosody-filer = { @@ -78,8 +84,14 @@ in { RestrictNamespaces = true; LockPersonality = true; RemoveIPC = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; }; }; }; diff --git a/nixos/modules/services/web-apps/rimgo.nix b/nixos/modules/services/web-apps/rimgo.nix index 4d35473fda31be..47aaf5317b2d6d 100644 --- a/nixos/modules/services/web-apps/rimgo.nix +++ b/nixos/modules/services/web-apps/rimgo.nix @@ -17,7 +17,7 @@ let optionalString getExe mapAttrs - ; + ; in { options.services.rimgo = { diff --git a/nixos/modules/services/web-apps/rss-bridge.nix b/nixos/modules/services/web-apps/rss-bridge.nix index 9c22b72d31cd0b..f375635c94b64d 100644 --- a/nixos/modules/services/web-apps/rss-bridge.nix +++ b/nixos/modules/services/web-apps/rss-bridge.nix @@ -1,24 +1,37 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.rss-bridge; poolName = "rss-bridge"; - cfgHalf = lib.mapAttrsRecursive (path: value: let - envName = lib.toUpper ("RSSBRIDGE_" + lib.concatStringsSep "_" path); - envValue = if lib.isList value then - lib.concatStringsSep "," value - else if lib.isBool value then - lib.boolToString value - else - toString value; - in if (value != null) then "fastcgi_param \"${envName}\" \"${envValue}\";" else null) cfg.config; + cfgHalf = lib.mapAttrsRecursive ( + path: value: + let + envName = lib.toUpper ("RSSBRIDGE_" + lib.concatStringsSep "_" path); + envValue = + if lib.isList value then + lib.concatStringsSep "," value + else if lib.isBool value then + lib.boolToString value + else + toString value; + in + if (value != null) then "fastcgi_param \"${envName}\" \"${envValue}\";" else null + ) cfg.config; cfgEnv = lib.concatStringsSep "\n" (lib.collect lib.isString cfgHalf); in { imports = [ - (mkRenamedOptionModule [ "services" "rss-bridge" "whitelist" ] [ "services" "rss-bridge" "config" "system" "enabled_bridges" ]) + (mkRenamedOptionModule + [ "services" "rss-bridge" "whitelist" ] + [ "services" "rss-bridge" "config" "system" "enabled_bridges" ] + ) ]; options = { @@ -70,7 +83,7 @@ in config = mkOption { type = types.submodule { - freeformType = (pkgs.formats.ini {}).type; + freeformType = (pkgs.formats.ini { }).type; options = { system = { enabled_bridges = mkOption { @@ -131,10 +144,10 @@ in systemd.tmpfiles.settings.rss-bridge = { "${cfg.config.FileCache.path}".d = { - mode = "0750"; - user = cfg.user; - group = cfg.group; - }; + mode = "0750"; + user = cfg.user; + group = cfg.group; + }; }; services.nginx = mkIf (cfg.virtualHost != null) { diff --git a/nixos/modules/services/web-apps/rutorrent.nix b/nixos/modules/services/web-apps/rutorrent.nix index cce701fef49781..8cbda677c2b125 100644 --- a/nixos/modules/services/web-apps/rutorrent.nix +++ b/nixos/modules/services/web-apps/rutorrent.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -7,7 +12,10 @@ let rtorrentPluginDependencies = with pkgs; { _task = [ procps ]; - unpack = [ unzip unrar ]; + unpack = [ + unzip + unrar + ]; rss = [ curl ]; mediainfo = [ mediainfo ]; spectrogram = [ sox ]; @@ -18,9 +26,10 @@ let _cloudflare = [ python3 ]; }; - getPluginDependencies = dependencies: concatMap (p: attrByPath [ p ] [] dependencies); + getPluginDependencies = dependencies: concatMap (p: attrByPath [ p ] [ ] dependencies); -in { +in +{ options = { services.rutorrent = { enable = mkEnableOption "ruTorrent"; @@ -72,7 +81,13 @@ in { }; poolSettings = mkOption { - type = with types; attrsOf (oneOf [ str int bool ]); + type = + with types; + attrsOf (oneOf [ + str + int + bool + ]); default = { "pm" = "dynamic"; "pm.max_children" = 32; @@ -110,124 +125,145 @@ in { }; config = mkIf cfg.enable (mkMerge [ - { assertions = let - usedRpcPlugins = intersectLists cfg.plugins [ "httprpc" "rpc" ]; - in [ - { assertion = (length usedRpcPlugins < 2); - message = "Please specify only one of httprpc or rpc plugins"; - } - { assertion = !(length usedRpcPlugins > 0 && cfg.nginx.exposeInsecureRPC2mount); - message = "Please do not use exposeInsecureRPC2mount if you use one of httprpc or rpc plugins"; - } - ]; - - warnings = let - nginxVhostCfg = config.services.nginx.virtualHosts."${cfg.hostName}"; - in [] - ++ (optional (cfg.nginx.exposeInsecureRPC2mount && (nginxVhostCfg.basicAuth == {} || nginxVhostCfg.basicAuthFile == null )) '' - You are using exposeInsecureRPC2mount without using basic auth on the virtual host. The exposed rpc mount allow for remote command execution. - - Please make sure it is not accessible from the outside. - ''); + { + assertions = + let + usedRpcPlugins = intersectLists cfg.plugins [ + "httprpc" + "rpc" + ]; + in + [ + { + assertion = (length usedRpcPlugins < 2); + message = "Please specify only one of httprpc or rpc plugins"; + } + { + assertion = !(length usedRpcPlugins > 0 && cfg.nginx.exposeInsecureRPC2mount); + message = "Please do not use exposeInsecureRPC2mount if you use one of httprpc or rpc plugins"; + } + ]; + + warnings = + let + nginxVhostCfg = config.services.nginx.virtualHosts."${cfg.hostName}"; + in + [ ] + ++ (optional + ( + cfg.nginx.exposeInsecureRPC2mount + && (nginxVhostCfg.basicAuth == { } || nginxVhostCfg.basicAuthFile == null) + ) + '' + You are using exposeInsecureRPC2mount without using basic auth on the virtual host. The exposed rpc mount allow for remote command execution. + + Please make sure it is not accessible from the outside. + '' + ); systemd = { services = { rtorrent.path = getPluginDependencies rtorrentPluginDependencies cfg.plugins; - rutorrent-setup = let - rutorrentConfig = pkgs.writeText "rutorrent-config.php" '' - false, - 'proto' => 'http', // 'http' or 'https' - 'host' => 'PROXY_HOST_HERE', - 'port' => 3128 - ); - - @define('RPC_TIME_OUT', 5, true); // in seconds - - @define('LOG_RPC_CALLS', false, true); - @define('LOG_RPC_FAULTS', true, true); - - // for php - @define('PHP_USE_GZIP', false, true); - @define('PHP_GZIP_LEVEL', 2, true); - - $schedule_rand = 10; // rand for schedulers start, +0..X seconds - - $do_diagnostic = true; - $log_file = '${cfg.dataDir}/logs/errors.log'; // path to log file (comment or leave blank to disable logging) - - $saveUploadedTorrents = true; // Save uploaded torrents to profile/torrents directory or not - $overwriteUploadedTorrents = false; // Overwrite existing uploaded torrents in profile/torrents directory or make unique name - - $topDirectory = '/'; // Upper available directory. Absolute path with trail slash. - $forbidUserSettings = false; - - $scgi_port = 0; - $scgi_host = "unix://${cfg.rpcSocket}"; - - $XMLRPCMountPoint = "/RPC2"; // DO NOT DELETE THIS LINE!!! DO NOT COMMENT THIS LINE!!! - - $throttleMaxSpeed = 327625*1024; - - $pathToExternals = array( - "php" => "${pkgs.php}/bin/php", // Something like /usr/bin/php. If empty, will be found in PATH. - "curl" => "${pkgs.curl}/bin/curl", // Something like /usr/bin/curl. If empty, will be found in PATH. - "gzip" => "${pkgs.gzip}/bin/gzip", // Something like /usr/bin/gzip. If empty, will be found in PATH. - "id" => "${pkgs.coreutils}/bin/id", // Something like /usr/bin/id. If empty, will be found in PATH. - "stat" => "${pkgs.coreutils}/bin/stat", // Something like /usr/bin/stat. If empty, will be found in PATH. - "pgrep" => "${pkgs.procps}/bin/pgrep", // TODO why can't we use phpEnv.PATH - ); - - $localhosts = array( // list of local interfaces - "127.0.0.1", - "localhost", - ); - - $profilePath = '${cfg.dataDir}/share'; // Path to user profiles - $profileMask = 0770; // Mask for files and directory creation in user profiles. - // Both Webserver and rtorrent users must have read-write access to it. - // For example, if Webserver and rtorrent users are in the same group then the value may be 0770. - - $tempDirectory = null; // Temp directory. Absolute path with trail slash. If null, then autodetect will be used. - - $canUseXSendFile = false; // If true then use X-Sendfile feature if it exist - - $locale = "UTF8"; - ''; - in { - wantedBy = [ "multi-user.target" ]; - before = [ "phpfpm-rutorrent.service" ]; - script = '' - ln -sf ${pkgs.rutorrent}/{css,images,js,lang,index.html} ${cfg.dataDir}/ - mkdir -p ${cfg.dataDir}/{conf,logs,plugins} ${cfg.dataDir}/share/{settings,torrents,users} - ln -sf ${pkgs.rutorrent}/conf/{access.ini,plugins.ini} ${cfg.dataDir}/conf/ - ln -sf ${rutorrentConfig} ${cfg.dataDir}/conf/config.php - - cp -r ${pkgs.rutorrent}/php ${cfg.dataDir}/ - - ${optionalString (cfg.plugins != []) - ''cp -r ${concatMapStringsSep " " (p: "${pkgs.rutorrent}/plugins/${p}") cfg.plugins} ${cfg.dataDir}/plugins/''} - - chown -R ${cfg.user}:${cfg.group} ${cfg.dataDir}/{conf,share,logs,plugins} - chmod -R 755 ${cfg.dataDir}/{conf,share,logs,plugins} - ''; - serviceConfig.Type = "oneshot"; - }; + rutorrent-setup = + let + rutorrentConfig = pkgs.writeText "rutorrent-config.php" '' + false, + 'proto' => 'http', // 'http' or 'https' + 'host' => 'PROXY_HOST_HERE', + 'port' => 3128 + ); + + @define('RPC_TIME_OUT', 5, true); // in seconds + + @define('LOG_RPC_CALLS', false, true); + @define('LOG_RPC_FAULTS', true, true); + + // for php + @define('PHP_USE_GZIP', false, true); + @define('PHP_GZIP_LEVEL', 2, true); + + $schedule_rand = 10; // rand for schedulers start, +0..X seconds + + $do_diagnostic = true; + $log_file = '${cfg.dataDir}/logs/errors.log'; // path to log file (comment or leave blank to disable logging) + + $saveUploadedTorrents = true; // Save uploaded torrents to profile/torrents directory or not + $overwriteUploadedTorrents = false; // Overwrite existing uploaded torrents in profile/torrents directory or make unique name + + $topDirectory = '/'; // Upper available directory. Absolute path with trail slash. + $forbidUserSettings = false; + + $scgi_port = 0; + $scgi_host = "unix://${cfg.rpcSocket}"; + + $XMLRPCMountPoint = "/RPC2"; // DO NOT DELETE THIS LINE!!! DO NOT COMMENT THIS LINE!!! + + $throttleMaxSpeed = 327625*1024; + + $pathToExternals = array( + "php" => "${pkgs.php}/bin/php", // Something like /usr/bin/php. If empty, will be found in PATH. + "curl" => "${pkgs.curl}/bin/curl", // Something like /usr/bin/curl. If empty, will be found in PATH. + "gzip" => "${pkgs.gzip}/bin/gzip", // Something like /usr/bin/gzip. If empty, will be found in PATH. + "id" => "${pkgs.coreutils}/bin/id", // Something like /usr/bin/id. If empty, will be found in PATH. + "stat" => "${pkgs.coreutils}/bin/stat", // Something like /usr/bin/stat. If empty, will be found in PATH. + "pgrep" => "${pkgs.procps}/bin/pgrep", // TODO why can't we use phpEnv.PATH + ); + + $localhosts = array( // list of local interfaces + "127.0.0.1", + "localhost", + ); + + $profilePath = '${cfg.dataDir}/share'; // Path to user profiles + $profileMask = 0770; // Mask for files and directory creation in user profiles. + // Both Webserver and rtorrent users must have read-write access to it. + // For example, if Webserver and rtorrent users are in the same group then the value may be 0770. + + $tempDirectory = null; // Temp directory. Absolute path with trail slash. If null, then autodetect will be used. + + $canUseXSendFile = false; // If true then use X-Sendfile feature if it exist + + $locale = "UTF8"; + ''; + in + { + wantedBy = [ "multi-user.target" ]; + before = [ "phpfpm-rutorrent.service" ]; + script = '' + ln -sf ${pkgs.rutorrent}/{css,images,js,lang,index.html} ${cfg.dataDir}/ + mkdir -p ${cfg.dataDir}/{conf,logs,plugins} ${cfg.dataDir}/share/{settings,torrents,users} + ln -sf ${pkgs.rutorrent}/conf/{access.ini,plugins.ini} ${cfg.dataDir}/conf/ + ln -sf ${rutorrentConfig} ${cfg.dataDir}/conf/config.php + + cp -r ${pkgs.rutorrent}/php ${cfg.dataDir}/ + + ${optionalString (cfg.plugins != [ ]) + ''cp -r ${ + concatMapStringsSep " " (p: "${pkgs.rutorrent}/plugins/${p}") cfg.plugins + } ${cfg.dataDir}/plugins/'' + } + + chown -R ${cfg.user}:${cfg.group} ${cfg.dataDir}/{conf,share,logs,plugins} + chmod -R 755 ${cfg.dataDir}/{conf,share,logs,plugins} + ''; + serviceConfig.Type = "oneshot"; + }; }; tmpfiles.rules = [ "d '${cfg.dataDir}' 0775 ${cfg.user} ${cfg.group} -" ]; }; - users.groups."${cfg.group}" = {}; + users.groups."${cfg.group}" = { }; users.users = { "${cfg.user}" = { @@ -245,18 +281,23 @@ in { } (mkIf cfg.nginx.enable (mkMerge [ - { services = { - phpfpm.pools.rutorrent = let - envPath = lib.makeBinPath (getPluginDependencies phpPluginDependencies cfg.plugins); - pool = { - user = cfg.user; - group = config.services.rtorrent.group; - settings = mapAttrs (name: mkDefault) { - "listen.owner" = config.services.nginx.user; - "listen.group" = config.services.nginx.group; - } // cfg.poolSettings; - }; - in if (envPath == "") then pool else pool // { phpEnv.PATH = envPath; }; + { + services = { + phpfpm.pools.rutorrent = + let + envPath = lib.makeBinPath (getPluginDependencies phpPluginDependencies cfg.plugins); + pool = { + user = cfg.user; + group = config.services.rtorrent.group; + settings = + mapAttrs (name: mkDefault) { + "listen.owner" = config.services.nginx.user; + "listen.group" = config.services.nginx.group; + } + // cfg.poolSettings; + }; + in + if (envPath == "") then pool else pool // { phpEnv.PATH = envPath; }; nginx = { enable = true; diff --git a/nixos/modules/services/web-apps/selfoss.nix b/nixos/modules/services/web-apps/selfoss.nix index 899976ac696c85..81701f2cc001b0 100644 --- a/nixos/modules/services/web-apps/selfoss.nix +++ b/nixos/modules/services/web-apps/selfoss.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.selfoss; @@ -8,51 +13,53 @@ let dataDir = "/var/lib/selfoss"; selfoss-config = - let - db_type = cfg.database.type; - default_port = if (db_type == "mysql") then 3306 else 5342; - in - pkgs.writeText "selfoss-config.ini" '' - [globals] - ${lib.optionalString (db_type != "sqlite") '' - db_type=${db_type} - db_host=${cfg.database.host} - db_database=${cfg.database.name} - db_username=${cfg.database.user} - db_password=${cfg.database.password} - db_port=${toString (if (cfg.database.port != null) then cfg.database.port - else default_port)} - '' - } - ${cfg.extraConfig} - ''; + let + db_type = cfg.database.type; + default_port = if (db_type == "mysql") then 3306 else 5342; + in + pkgs.writeText "selfoss-config.ini" '' + [globals] + ${lib.optionalString (db_type != "sqlite") '' + db_type=${db_type} + db_host=${cfg.database.host} + db_database=${cfg.database.name} + db_username=${cfg.database.user} + db_password=${cfg.database.password} + db_port=${toString (if (cfg.database.port != null) then cfg.database.port else default_port)} + ''} + ${cfg.extraConfig} + ''; in - { - options = { - services.selfoss = { - enable = mkEnableOption "selfoss"; - - user = mkOption { - type = types.str; - default = "nginx"; - description = '' - User account under which both the service and the web-application run. - ''; - }; +{ + options = { + services.selfoss = { + enable = mkEnableOption "selfoss"; + + user = mkOption { + type = types.str; + default = "nginx"; + description = '' + User account under which both the service and the web-application run. + ''; + }; - pool = mkOption { - type = types.str; - default = "${poolName}"; - description = '' - Name of existing phpfpm pool that is used to run web-application. - If not specified a pool will be created automatically with - default values. - ''; - }; + pool = mkOption { + type = types.str; + default = "${poolName}"; + description = '' + Name of existing phpfpm pool that is used to run web-application. + If not specified a pool will be created automatically with + default values. + ''; + }; database = { type = mkOption { - type = types.enum ["pgsql" "mysql" "sqlite"]; + type = types.enum [ + "pgsql" + "mysql" + "sqlite" + ]; default = "sqlite"; description = '' Database to store feeds. Supported are sqlite, pgsql and mysql. diff --git a/nixos/modules/services/web-apps/sftpgo.nix b/nixos/modules/services/web-apps/sftpgo.nix index 4d9a8e44c2b354..2a76ccc1797799 100644 --- a/nixos/modules/services/web-apps/sftpgo.nix +++ b/nixos/modules/services/web-apps/sftpgo.nix @@ -1,14 +1,22 @@ -{ options, config, lib, pkgs, utils, ... }: +{ + options, + config, + lib, + pkgs, + utils, + ... +}: with lib; let cfg = config.services.sftpgo; defaultUser = "sftpgo"; - settingsFormat = pkgs.formats.json {}; + settingsFormat = pkgs.formats.json { }; configFile = settingsFormat.generate "sftpgo.json" cfg.settings; hasPrivilegedPorts = any (port: port > 0 && port < 1024) ( - catAttrs "port" (cfg.settings.httpd.bindings + catAttrs "port" ( + cfg.settings.httpd.bindings ++ cfg.settings.ftpd.bindings ++ cfg.settings.sftpd.bindings ++ cfg.settings.webdavd.bindings @@ -27,11 +35,14 @@ in extraArgs = mkOption { type = with types; listOf str; - default = []; + default = [ ]; description = '' Additional command line arguments to pass to the sftpgo daemon. ''; - example = [ "--log-level" "info" ]; + example = [ + "--log-level" + "info" + ]; }; dataDir = mkOption { @@ -44,7 +55,7 @@ in extraReadWriteDirs = mkOption { type = types.listOf types.path; - default = []; + default = [ ]; description = '' Extra directories where SFTPGo is allowed to write to. ''; @@ -77,226 +88,246 @@ in }; settings = mkOption { - default = {}; + default = { }; description = '' The primary sftpgo configuration. See the [configuration reference](https://sftpgo.github.io/latest/config-file/) for possible values. ''; - type = with types; submodule { - freeformType = settingsFormat.type; - options = { - httpd.bindings = mkOption { - default = []; - description = '' - Configure listen addresses and ports for httpd. - ''; - type = types.listOf (types.submodule { - freeformType = settingsFormat.type; - options = { - address = mkOption { - type = types.str; - default = "127.0.0.1"; - description = '' - Network listen address. Leave blank to listen on all available network interfaces. - On *NIX you can specify an absolute path to listen on a Unix-domain socket. - ''; - }; - - port = mkOption { - type = types.port; - default = 8080; - description = '' - The port for serving HTTP(S) requests. - - Setting the port to `0` disables listening on this interface binding. - ''; - }; - - enable_web_admin = mkOption { - type = types.bool; - default = true; - description = '' - Enable the built-in web admin for this interface binding. - ''; - }; - - enable_web_client = mkOption { - type = types.bool; - default = true; - description = '' - Enable the built-in web client for this interface binding. - ''; - }; - }; - }); - }; - - ftpd.bindings = mkOption { - default = []; - description = '' - Configure listen addresses and ports for ftpd. - ''; - type = types.listOf (types.submodule { - freeformType = settingsFormat.type; - options = { - address = mkOption { - type = types.str; - default = "127.0.0.1"; - description = '' - Network listen address. Leave blank to listen on all available network interfaces. - On *NIX you can specify an absolute path to listen on a Unix-domain socket. - ''; - }; - - port = mkOption { - type = types.port; - default = 0; - description = '' - The port for serving FTP requests. - - Setting the port to `0` disables listening on this interface binding. - ''; - }; - }; - }); - }; - - sftpd.bindings = mkOption { - default = []; - description = '' - Configure listen addresses and ports for sftpd. - ''; - type = types.listOf (types.submodule { - freeformType = settingsFormat.type; - options = { - address = mkOption { - type = types.str; - default = "127.0.0.1"; - description = '' - Network listen address. Leave blank to listen on all available network interfaces. - On *NIX you can specify an absolute path to listen on a Unix-domain socket. - ''; - }; - - port = mkOption { - type = types.port; - default = 0; - description = '' - The port for serving SFTP requests. - - Setting the port to `0` disables listening on this interface binding. - ''; - }; - }; - }); - }; - - webdavd.bindings = mkOption { - default = []; - description = '' - Configure listen addresses and ports for webdavd. - ''; - type = types.listOf (types.submodule { - freeformType = settingsFormat.type; - options = { - address = mkOption { - type = types.str; - default = "127.0.0.1"; - description = '' - Network listen address. Leave blank to listen on all available network interfaces. - On *NIX you can specify an absolute path to listen on a Unix-domain socket. - ''; - }; - - port = mkOption { - type = types.port; - default = 0; - description = '' - The port for serving WebDAV requests. - - Setting the port to `0` disables listening on this interface binding. - ''; - }; - }; - }); - }; - - smtp = mkOption { - default = {}; - description = '' - SMTP configuration section. - ''; - type = types.submodule { - freeformType = settingsFormat.type; - options = { - host = mkOption { - type = types.str; - default = ""; - description = '' - Location of SMTP email server. Leave empty to disable email sending capabilities. - ''; - }; - - port = mkOption { - type = types.port; - default = 465; - description = "Port of the SMTP Server."; - }; + type = + with types; + submodule { + freeformType = settingsFormat.type; + options = { + httpd.bindings = mkOption { + default = [ ]; + description = '' + Configure listen addresses and ports for httpd. + ''; + type = types.listOf ( + types.submodule { + freeformType = settingsFormat.type; + options = { + address = mkOption { + type = types.str; + default = "127.0.0.1"; + description = '' + Network listen address. Leave blank to listen on all available network interfaces. + On *NIX you can specify an absolute path to listen on a Unix-domain socket. + ''; + }; + + port = mkOption { + type = types.port; + default = 8080; + description = '' + The port for serving HTTP(S) requests. + + Setting the port to `0` disables listening on this interface binding. + ''; + }; + + enable_web_admin = mkOption { + type = types.bool; + default = true; + description = '' + Enable the built-in web admin for this interface binding. + ''; + }; + + enable_web_client = mkOption { + type = types.bool; + default = true; + description = '' + Enable the built-in web client for this interface binding. + ''; + }; + }; + } + ); + }; - encryption = mkOption { - type = types.enum [ 0 1 2 ]; - default = 1; - description = '' - Encryption scheme: - - `0`: No encryption - - `1`: TLS - - `2`: STARTTLS - ''; - }; + ftpd.bindings = mkOption { + default = [ ]; + description = '' + Configure listen addresses and ports for ftpd. + ''; + type = types.listOf ( + types.submodule { + freeformType = settingsFormat.type; + options = { + address = mkOption { + type = types.str; + default = "127.0.0.1"; + description = '' + Network listen address. Leave blank to listen on all available network interfaces. + On *NIX you can specify an absolute path to listen on a Unix-domain socket. + ''; + }; + + port = mkOption { + type = types.port; + default = 0; + description = '' + The port for serving FTP requests. + + Setting the port to `0` disables listening on this interface binding. + ''; + }; + }; + } + ); + }; - auth_type = mkOption { - type = types.enum [ 0 1 2 ]; - default = 0; - description = '' - - `0`: Plain - - `1`: Login - - `2`: CRAM-MD5 - ''; - }; + sftpd.bindings = mkOption { + default = [ ]; + description = '' + Configure listen addresses and ports for sftpd. + ''; + type = types.listOf ( + types.submodule { + freeformType = settingsFormat.type; + options = { + address = mkOption { + type = types.str; + default = "127.0.0.1"; + description = '' + Network listen address. Leave blank to listen on all available network interfaces. + On *NIX you can specify an absolute path to listen on a Unix-domain socket. + ''; + }; + + port = mkOption { + type = types.port; + default = 0; + description = '' + The port for serving SFTP requests. + + Setting the port to `0` disables listening on this interface binding. + ''; + }; + }; + } + ); + }; - user = mkOption { - type = types.str; - default = "sftpgo"; - description = "SMTP username."; - }; + webdavd.bindings = mkOption { + default = [ ]; + description = '' + Configure listen addresses and ports for webdavd. + ''; + type = types.listOf ( + types.submodule { + freeformType = settingsFormat.type; + options = { + address = mkOption { + type = types.str; + default = "127.0.0.1"; + description = '' + Network listen address. Leave blank to listen on all available network interfaces. + On *NIX you can specify an absolute path to listen on a Unix-domain socket. + ''; + }; + + port = mkOption { + type = types.port; + default = 0; + description = '' + The port for serving WebDAV requests. + + Setting the port to `0` disables listening on this interface binding. + ''; + }; + }; + } + ); + }; - from = mkOption { - type = types.str; - default = "SFTPGo "; - description = '' - From address. - ''; + smtp = mkOption { + default = { }; + description = '' + SMTP configuration section. + ''; + type = types.submodule { + freeformType = settingsFormat.type; + options = { + host = mkOption { + type = types.str; + default = ""; + description = '' + Location of SMTP email server. Leave empty to disable email sending capabilities. + ''; + }; + + port = mkOption { + type = types.port; + default = 465; + description = "Port of the SMTP Server."; + }; + + encryption = mkOption { + type = types.enum [ + 0 + 1 + 2 + ]; + default = 1; + description = '' + Encryption scheme: + - `0`: No encryption + - `1`: TLS + - `2`: STARTTLS + ''; + }; + + auth_type = mkOption { + type = types.enum [ + 0 + 1 + 2 + ]; + default = 0; + description = '' + - `0`: Plain + - `1`: Login + - `2`: CRAM-MD5 + ''; + }; + + user = mkOption { + type = types.str; + default = "sftpgo"; + description = "SMTP username."; + }; + + from = mkOption { + type = types.str; + default = "SFTPGo "; + description = '' + From address. + ''; + }; }; }; }; }; }; - }; }; }; config = mkIf cfg.enable { - services.sftpgo.settings = (mapAttrs (name: mkDefault) { - ftpd.bindings = [{ port = 0; }]; - httpd.bindings = [{ port = 0; }]; - sftpd.bindings = [{ port = 0; }]; - webdavd.bindings = [{ port = 0; }]; - httpd.openapi_path = "${cfg.package}/share/sftpgo/openapi"; - httpd.templates_path = "${cfg.package}/share/sftpgo/templates"; - httpd.static_files_path = "${cfg.package}/share/sftpgo/static"; - smtp.templates_path = "${cfg.package}/share/sftpgo/templates"; - }); + services.sftpgo.settings = ( + mapAttrs (name: mkDefault) { + ftpd.bindings = [ { port = 0; } ]; + httpd.bindings = [ { port = 0; } ]; + sftpd.bindings = [ { port = 0; } ]; + webdavd.bindings = [ { port = 0; } ]; + httpd.openapi_path = "${cfg.package}/share/sftpgo/openapi"; + httpd.templates_path = "${cfg.package}/share/sftpgo/templates"; + httpd.static_files_path = "${cfg.package}/share/sftpgo/static"; + smtp.templates_path = "${cfg.package}/share/sftpgo/templates"; + } + ); users = optionalAttrs (cfg.user == defaultUser) { users = { @@ -361,7 +392,10 @@ in RestrictRealtime = true; RestrictSUIDSGID = true; SystemCallArchitectures = "native"; - SystemCallFilter = [ "@system-service" "~@privileged" ]; + SystemCallFilter = [ + "@system-service" + "~@privileged" + ]; UMask = "0077"; }) (mkIf hasPrivilegedPorts { diff --git a/nixos/modules/services/web-apps/shiori.nix b/nixos/modules/services/web-apps/shiori.nix index bec5ab4083bb1a..fac667d930905f 100644 --- a/nixos/modules/services/web-apps/shiori.nix +++ b/nixos/modules/services/web-apps/shiori.nix @@ -1,7 +1,14 @@ -{ config, lib, pkgs, ... }: - -let cfg = config.services.shiori; -in { +{ + config, + lib, + pkgs, + ... +}: + +let + cfg = config.services.shiori; +in +{ options = { services.shiori = { enable = lib.mkEnableOption "Shiori simple bookmarks manager"; @@ -54,18 +61,20 @@ in { systemd.services.shiori = { description = "Shiori simple bookmarks manager"; wantedBy = [ "multi-user.target" ]; - after = [ "postgresql.service" "mysql.service" ]; - environment = { - SHIORI_DIR = "/var/lib/shiori"; - } // lib.optionalAttrs (cfg.databaseUrl != null) { - SHIORI_DATABASE_URL = cfg.databaseUrl; - }; + after = [ + "postgresql.service" + "mysql.service" + ]; + environment = + { + SHIORI_DIR = "/var/lib/shiori"; + } + // lib.optionalAttrs (cfg.databaseUrl != null) { + SHIORI_DATABASE_URL = cfg.databaseUrl; + }; serviceConfig = { - ExecStart = - "${cfg.package}/bin/shiori server --address '${cfg.address}' --port '${ - toString cfg.port - }' --webroot '${cfg.webRoot}'"; + ExecStart = "${cfg.package}/bin/shiori server --address '${cfg.address}' --port '${toString cfg.port}' --webroot '${cfg.webRoot}'"; DynamicUser = true; StateDirectory = "shiori"; @@ -73,21 +82,24 @@ in { RuntimeDirectory = "shiori"; # Security options - EnvironmentFile = - lib.optional (cfg.environmentFile != null) cfg.environmentFile; - BindReadOnlyPaths = [ - "/nix/store" - - # For SSL certificates, and the resolv.conf - "/etc" - ] ++ lib.optional (config.services.postgresql.enable && - cfg.databaseUrl != null && - lib.strings.hasPrefix "postgres://" cfg.databaseUrl) - "/run/postgresql" - ++ lib.optional (config.services.mysql.enable && - cfg.databaseUrl != null && - lib.strings.hasPrefix "mysql://" cfg.databaseUrl) - "/var/run/mysqld"; + EnvironmentFile = lib.optional (cfg.environmentFile != null) cfg.environmentFile; + BindReadOnlyPaths = + [ + "/nix/store" + + # For SSL certificates, and the resolv.conf + "/etc" + ] + ++ lib.optional ( + config.services.postgresql.enable + && cfg.databaseUrl != null + && lib.strings.hasPrefix "postgres://" cfg.databaseUrl + ) "/run/postgresql" + ++ lib.optional ( + config.services.mysql.enable + && cfg.databaseUrl != null + && lib.strings.hasPrefix "mysql://" cfg.databaseUrl + ) "/var/run/mysqld"; CapabilityBoundingSet = ""; @@ -109,7 +121,11 @@ in { ProtectKernelTunables = true; RestrictNamespaces = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + "AF_UNIX" + ]; RestrictRealtime = true; RestrictSUIDSGID = true; @@ -131,5 +147,8 @@ in { }; }; - meta.maintainers = with lib.maintainers; [ minijackson CaptainJawZ ]; + meta.maintainers = with lib.maintainers; [ + minijackson + CaptainJawZ + ]; } diff --git a/nixos/modules/services/web-apps/silverbullet.nix b/nixos/modules/services/web-apps/silverbullet.nix index a6a830e674b497..e1b795a30749ed 100644 --- a/nixos/modules/services/web-apps/silverbullet.nix +++ b/nixos/modules/services/web-apps/silverbullet.nix @@ -1,7 +1,8 @@ -{ config -, pkgs -, lib -, ... +{ + config, + pkgs, + lib, + ... }: let cfg = config.services.silverbullet; @@ -100,8 +101,12 @@ in User = "${cfg.user}"; Group = "${cfg.group}"; EnvironmentFile = lib.mkIf (cfg.envFile != null) "${cfg.envFile}"; - StateDirectory = lib.mkIf (lib.hasPrefix "/var/lib/" cfg.spaceDir) (lib.last (lib.splitString "/" cfg.spaceDir)); - ExecStart = "${lib.getExe cfg.package} --port ${toString cfg.listenPort} --hostname '${cfg.listenAddress}' '${cfg.spaceDir}' " + lib.concatStringsSep " " cfg.extraArgs; + StateDirectory = lib.mkIf (lib.hasPrefix "/var/lib/" cfg.spaceDir) ( + lib.last (lib.splitString "/" cfg.spaceDir) + ); + ExecStart = + "${lib.getExe cfg.package} --port ${toString cfg.listenPort} --hostname '${cfg.listenAddress}' '${cfg.spaceDir}' " + + lib.concatStringsSep " " cfg.extraArgs; Restart = "on-failure"; }; }; diff --git a/nixos/modules/services/web-apps/sogo.nix b/nixos/modules/services/web-apps/sogo.nix index 1102418077664a..c34896d1112ec0 100644 --- a/nixos/modules/services/web-apps/sogo.nix +++ b/nixos/modules/services/web-apps/sogo.nix @@ -1,18 +1,37 @@ -{ config, pkgs, lib, ... }: with lib; let +{ + config, + pkgs, + lib, + ... +}: +with lib; +let cfg = config.services.sogo; preStart = pkgs.writeShellScriptBin "sogo-prestart" '' - ${if (cfg.configReplaces != {}) then '' - # Insert secrets - ${concatStringsSep "\n" (mapAttrsToList (k: v: ''export ${k}="$(cat "${v}" | tr -d '\n')"'') cfg.configReplaces)} - - ${pkgs.perl}/bin/perl -p ${concatStringsSep " " (mapAttrsToList (k: v: '' -e 's/${k}/''${ENV{"${k}"}}/g;' '') cfg.configReplaces)} /etc/sogo/sogo.conf.raw | install -m 640 -o sogo -g sogo /dev/stdin /etc/sogo/sogo.conf - '' else '' - install -m 640 -o sogo -g sogo /etc/sogo/sogo.conf.raw /etc/sogo/sogo.conf - ''} + ${ + if (cfg.configReplaces != { }) then + '' + # Insert secrets + ${concatStringsSep "\n" ( + mapAttrsToList (k: v: ''export ${k}="$(cat "${v}" | tr -d '\n')"'') cfg.configReplaces + )} + + ${pkgs.perl}/bin/perl -p ${ + concatStringsSep " " ( + mapAttrsToList (k: v: ''-e 's/${k}/''${ENV{"${k}"}}/g;' '') cfg.configReplaces + ) + } /etc/sogo/sogo.conf.raw | install -m 640 -o sogo -g sogo /dev/stdin /etc/sogo/sogo.conf + '' + else + '' + install -m 640 -o sogo -g sogo /etc/sogo/sogo.conf.raw /etc/sogo/sogo.conf + '' + } ''; -in { +in +{ options.services.sogo = with types; { enable = mkEnableOption "SOGo groupware"; @@ -49,7 +68,7 @@ in { specified file. ''; type = attrsOf str; - default = {}; + default = { }; example = { LDAP_BINDPW = "/var/lib/secrets/sogo/ldappw"; }; @@ -84,7 +103,13 @@ in { systemd.services.sogo = { description = "SOGo groupware"; - after = [ "postgresql.service" "mysql.service" "memcached.service" "openldap.service" "dovecot2.service" ]; + after = [ + "postgresql.service" + "mysql.service" + "memcached.service" + "openldap.service" + "dovecot2.service" + ]; wantedBy = [ "multi-user.target" ]; restartTriggers = [ config.environment.etc."sogo/sogo.conf.raw".source ]; @@ -165,14 +190,23 @@ in { systemd.services.sogo-ealarms = { description = "SOGo email alarms"; - after = [ "postgresql.service" "mysqld.service" "memcached.service" "openldap.service" "dovecot2.service" "sogo.service" ]; + after = [ + "postgresql.service" + "mysqld.service" + "memcached.service" + "openldap.service" + "dovecot2.service" + "sogo.service" + ]; restartTriggers = [ config.environment.etc."sogo/sogo.conf.raw".source ]; startAt = [ "minutely" ]; serviceConfig = { Type = "oneshot"; - ExecStart = "${pkgs.sogo}/bin/sogo-ealarms-notify${optionalString (cfg.ealarmsCredFile != null) " -p ${cfg.ealarmsCredFile}"}"; + ExecStart = "${pkgs.sogo}/bin/sogo-ealarms-notify${ + optionalString (cfg.ealarmsCredFile != null) " -p ${cfg.ealarmsCredFile}" + }"; ProtectSystem = "strict"; ProtectHome = true; @@ -251,13 +285,14 @@ in { alias ${pkgs.sogo}/lib/GNUstep/SOGo/$1.SOGo/Resources/$2; ''; - locations."~ ^/SOGo/so/ControlPanel/Products/[^/]*UI/Resources/.*\\.(jpg|png|gif|css|js)$".extraConfig = '' - alias ${pkgs.sogo}/lib/GNUstep/SOGo/$1.SOGo/Resources/$2; - ''; + locations."~ ^/SOGo/so/ControlPanel/Products/[^/]*UI/Resources/.*\\.(jpg|png|gif|css|js)$".extraConfig = + '' + alias ${pkgs.sogo}/lib/GNUstep/SOGo/$1.SOGo/Resources/$2; + ''; }; # User and group - users.groups.sogo = {}; + users.groups.sogo = { }; users.users.sogo = { group = "sogo"; isSystemUser = true; diff --git a/nixos/modules/services/web-apps/suwayomi-server.nix b/nixos/modules/services/web-apps/suwayomi-server.nix index caa091685d2fb6..0041ee9f7860a1 100644 --- a/nixos/modules/services/web-apps/suwayomi-server.nix +++ b/nixos/modules/services/web-apps/suwayomi-server.nix @@ -1,8 +1,18 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.suwayomi-server; - inherit (lib) mkOption mkEnableOption mkIf types; + inherit (lib) + mkOption + mkEnableOption + mkIf + types + ; format = pkgs.formats.hocon { }; in @@ -104,7 +114,7 @@ in extensionRepos = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "https://raw.githubusercontent.com/MY_ACCOUNT/MY_REPO/repo/index.min.json" ]; @@ -149,12 +159,16 @@ in config = mkIf cfg.enable { - assertions = [{ - assertion = with cfg.settings.server; basicAuthEnabled -> (basicAuthUsername != null && basicAuthPasswordFile != null); - message = '' - [suwayomi-server]: the username and the password file cannot be null when the basic auth is enabled - ''; - }]; + assertions = [ + { + assertion = + with cfg.settings.server; + basicAuthEnabled -> (basicAuthUsername != null && basicAuthPasswordFile != null); + message = '' + [suwayomi-server]: the username and the password file cannot be null when the basic auth is enabled + ''; + } + ]; networking.firewall.allowedTCPPorts = mkIf cfg.openFirewall [ cfg.settings.server.port ]; @@ -181,16 +195,19 @@ in systemd.services.suwayomi-server = let - configFile = format.generate "server.conf" (lib.pipe cfg.settings [ - (settings: lib.recursiveUpdate settings { - server.basicAuthPasswordFile = null; - server.basicAuthPassword = - if settings.server.basicAuthEnabled - then "$TACHIDESK_SERVER_BASIC_AUTH_PASSWORD" - else null; - }) - (lib.filterAttrsRecursive (_: x: x != null)) - ]); + configFile = format.generate "server.conf" ( + lib.pipe cfg.settings [ + ( + settings: + lib.recursiveUpdate settings { + server.basicAuthPasswordFile = null; + server.basicAuthPassword = + if settings.server.basicAuthEnabled then "$TACHIDESK_SERVER_BASIC_AUTH_PASSWORD" else null; + } + ) + (lib.filterAttrsRecursive (_: x: x != null)) + ] + ); in { description = "A free and open source manga reader server that runs extensions built for Tachiyomi."; diff --git a/nixos/modules/services/web-apps/vikunja.nix b/nixos/modules/services/web-apps/vikunja.nix index 9727eaccc1d016..4a6bae2d123aef 100644 --- a/nixos/modules/services/web-apps/vikunja.nix +++ b/nixos/modules/services/web-apps/vikunja.nix @@ -1,16 +1,24 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: with lib; let cfg = config.services.vikunja; - format = pkgs.formats.yaml {}; + format = pkgs.formats.yaml { }; configFile = format.generate "config.yaml" cfg.settings; useMysql = cfg.database.type == "mysql"; usePostgresql = cfg.database.type == "postgres"; -in { +in +{ imports = [ - (mkRemovedOptionModule [ "services" "vikunja" "setupNginx" ] "services.vikunja no longer supports the automatic set up of a nginx virtual host. Set up your own webserver config with a proxy pass to the vikunja service.") + (mkRemovedOptionModule [ "services" "vikunja" "setupNginx" ] + "services.vikunja no longer supports the automatic set up of a nginx virtual host. Set up your own webserver config with a proxy pass to the vikunja service." + ) ]; options.services.vikunja = with lib; { @@ -25,7 +33,10 @@ in { ''; }; frontendScheme = mkOption { - type = types.enum [ "http" "https" ]; + type = types.enum [ + "http" + "https" + ]; description = '' Whether the site is available via http or https. ''; @@ -42,16 +53,20 @@ in { settings = mkOption { type = format.type; - default = {}; + default = { }; description = '' Vikunja configuration. Refer to for details on supported values. - ''; + ''; }; database = { type = mkOption { - type = types.enum [ "sqlite" "mysql" "postgres" ]; + type = types.enum [ + "sqlite" + "mysql" + "postgres" + ]; example = "postgres"; default = "sqlite"; description = "Database engine to use."; @@ -81,7 +96,13 @@ in { config = lib.mkIf cfg.enable { services.vikunja.settings = { database = { - inherit (cfg.database) type host user database path; + inherit (cfg.database) + type + host + user + database + path + ; }; service = { interface = ":${toString cfg.port}"; @@ -94,7 +115,10 @@ in { systemd.services.vikunja = { description = "vikunja"; - after = [ "network.target" ] ++ lib.optional usePostgresql "postgresql.service" ++ lib.optional useMysql "mysql.service"; + after = + [ "network.target" ] + ++ lib.optional usePostgresql "postgresql.service" + ++ lib.optional useMysql "mysql.service"; wantedBy = [ "multi-user.target" ]; path = [ cfg.package ]; restartTriggers = [ configFile ]; diff --git a/nixos/modules/services/web-apps/whitebophir.nix b/nixos/modules/services/web-apps/whitebophir.nix index 332a8d9d4ec652..8222bdb978c5b9 100644 --- a/nixos/modules/services/web-apps/whitebophir.nix +++ b/nixos/modules/services/web-apps/whitebophir.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.whitebophir; -in { +in +{ options = { services.whitebophir = { enable = mkEnableOption "whitebophir, an online collaborative whiteboard server (persistent state will be maintained under {file}`/var/lib/whitebophir`)"; @@ -28,18 +34,18 @@ in { config = mkIf cfg.enable { systemd.services.whitebophir = { description = "Whitebophir Service"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; environment = { - PORT = toString cfg.port; - HOST = toString cfg.listenAddress; + PORT = toString cfg.port; + HOST = toString cfg.listenAddress; WBO_HISTORY_DIR = "/var/lib/whitebophir"; }; serviceConfig = { - DynamicUser = true; - ExecStart = "${cfg.package}/bin/whitebophir"; - Restart = "always"; + DynamicUser = true; + ExecStart = "${cfg.package}/bin/whitebophir"; + Restart = "always"; StateDirectory = "whitebophir"; }; }; diff --git a/nixos/modules/services/web-apps/wiki-js.nix b/nixos/modules/services/web-apps/wiki-js.nix index dedc4c58462848..4c742c26afadf9 100644 --- a/nixos/modules/services/web-apps/wiki-js.nix +++ b/nixos/modules/services/web-apps/wiki-js.nix @@ -1,4 +1,9 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: with lib; @@ -8,7 +13,8 @@ let format = pkgs.formats.json { }; configFile = format.generate "wiki-js.yml" cfg.settings; -in { +in +{ options.services.wiki-js = { enable = mkEnableOption "wiki-js"; @@ -30,7 +36,7 @@ in { }; settings = mkOption { - default = {}; + default = { }; type = types.submodule { freeformType = format.type; options = { @@ -53,7 +59,12 @@ in { db = { type = mkOption { default = "postgres"; - type = types.enum [ "postgres" "mysql" "mariadb" "mssql" ]; + type = types.enum [ + "postgres" + "mysql" + "mariadb" + "mssql" + ]; description = '' Database driver to use for persistence. Please note that `sqlite` is currently not supported as the build process for it is currently not implemented @@ -79,7 +90,14 @@ in { logLevel = mkOption { default = "info"; - type = types.enum [ "error" "warn" "info" "verbose" "debug" "silly" ]; + type = types.enum [ + "error" + "warn" + "info" + "verbose" + "debug" + "silly" + ]; description = '' Define how much detail is supposed to be logged at runtime. ''; diff --git a/nixos/modules/services/web-apps/windmill.nix b/nixos/modules/services/web-apps/windmill.nix index 2571740ebbf155..b7b3ba3ca976f5 100644 --- a/nixos/modules/services/web-apps/windmill.nix +++ b/nixos/modules/services/web-apps/windmill.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.windmill; @@ -72,7 +77,13 @@ in }; logLevel = lib.mkOption { - type = lib.types.enum [ "error" "warn" "info" "debug" "trace" ]; + type = lib.types.enum [ + "error" + "warn" + "info" + "debug" + "trace" + ]; default = "info"; description = "Log level"; }; @@ -85,112 +96,125 @@ in ensureDatabases = [ cfg.database.name ]; ensureUsers = [ - { name = cfg.database.user; + { + name = cfg.database.user; ensureDBOwnership = true; } ]; - }; - - systemd.services = - let - useUrlPath = (cfg.database.urlPath != null); - serviceConfig = { - DynamicUser = true; - # using the same user to simplify db connection - User = cfg.database.user; - ExecStart = "${pkgs.windmill}/bin/windmill"; - - Restart = "always"; - } // lib.optionalAttrs useUrlPath { - LoadCredential = [ - "DATABASE_URL_FILE:${cfg.database.urlPath}" - ]; - }; - db_url_envs = lib.optionalAttrs useUrlPath { - DATABASE_URL_FILE = "%d/DATABASE_URL_FILE"; - } // lib.optionalAttrs (!useUrlPath) { - DATABASE_URL = cfg.database.url; - }; - in - { - - # coming from https://github.com/windmill-labs/windmill/blob/main/init-db-as-superuser.sql - # modified to not grant priviledges on all tables - # create role windmill_user and windmill_admin only if they don't exist - postgresql.postStart = lib.mkIf cfg.database.createLocally (lib.mkAfter '' - $PSQL -tA <<"EOF" -DO $$ -BEGIN - IF NOT EXISTS ( - SELECT FROM pg_catalog.pg_roles - WHERE rolname = 'windmill_user' - ) THEN - CREATE ROLE windmill_user; - GRANT ALL PRIVILEGES ON DATABASE ${cfg.database.name} TO windmill_user; - ELSE - RAISE NOTICE 'Role "windmill_user" already exists. Skipping.'; - END IF; - IF NOT EXISTS ( - SELECT FROM pg_catalog.pg_roles - WHERE rolname = 'windmill_admin' - ) THEN - CREATE ROLE windmill_admin WITH BYPASSRLS; - GRANT windmill_user TO windmill_admin; - ELSE - RAISE NOTICE 'Role "windmill_admin" already exists. Skipping.'; - END IF; - GRANT windmill_admin TO windmill; -END -$$; -EOF - ''); - - windmill-server = { - description = "Windmill server"; - after = [ "network.target" ] ++ lib.optional cfg.database.createLocally "postgresql.service"; - wantedBy = [ "multi-user.target" ]; - - serviceConfig = serviceConfig // { StateDirectory = "windmill";}; - - environment = { - PORT = builtins.toString cfg.serverPort; - WM_BASE_URL = cfg.baseUrl; - RUST_LOG = cfg.logLevel; - MODE = "server"; - } // db_url_envs; - }; - - windmill-worker = { - description = "Windmill worker"; - after = [ "network.target" ] ++ lib.optional cfg.database.createLocally "postgresql.service"; - wantedBy = [ "multi-user.target" ]; - - serviceConfig = serviceConfig // { StateDirectory = "windmill-worker";}; - - environment = { - WM_BASE_URL = cfg.baseUrl; - RUST_LOG = cfg.logLevel; - MODE = "worker"; - WORKER_GROUP = "default"; - KEEP_JOB_DIR = "false"; - } // db_url_envs; - }; - - windmill-worker-native = { - description = "Windmill worker native"; - after = [ "network.target" ] ++ lib.optional cfg.database.createLocally "postgresql.service"; - wantedBy = [ "multi-user.target" ]; - - serviceConfig = serviceConfig // { StateDirectory = "windmill-worker-native";}; + }; - environment = { - WM_BASE_URL = cfg.baseUrl; - RUST_LOG = cfg.logLevel; - MODE = "worker"; - WORKER_GROUP = "native"; - } // db_url_envs; + systemd.services = + let + useUrlPath = (cfg.database.urlPath != null); + serviceConfig = + { + DynamicUser = true; + # using the same user to simplify db connection + User = cfg.database.user; + ExecStart = "${pkgs.windmill}/bin/windmill"; + + Restart = "always"; + } + // lib.optionalAttrs useUrlPath { + LoadCredential = [ + "DATABASE_URL_FILE:${cfg.database.urlPath}" + ]; + }; + db_url_envs = + lib.optionalAttrs useUrlPath { + DATABASE_URL_FILE = "%d/DATABASE_URL_FILE"; + } + // lib.optionalAttrs (!useUrlPath) { + DATABASE_URL = cfg.database.url; + }; + in + { + + # coming from https://github.com/windmill-labs/windmill/blob/main/init-db-as-superuser.sql + # modified to not grant priviledges on all tables + # create role windmill_user and windmill_admin only if they don't exist + postgresql.postStart = lib.mkIf cfg.database.createLocally ( + lib.mkAfter '' + $PSQL -tA <<"EOF" + DO $$ + BEGIN + IF NOT EXISTS ( + SELECT FROM pg_catalog.pg_roles + WHERE rolname = 'windmill_user' + ) THEN + CREATE ROLE windmill_user; + GRANT ALL PRIVILEGES ON DATABASE ${cfg.database.name} TO windmill_user; + ELSE + RAISE NOTICE 'Role "windmill_user" already exists. Skipping.'; + END IF; + IF NOT EXISTS ( + SELECT FROM pg_catalog.pg_roles + WHERE rolname = 'windmill_admin' + ) THEN + CREATE ROLE windmill_admin WITH BYPASSRLS; + GRANT windmill_user TO windmill_admin; + ELSE + RAISE NOTICE 'Role "windmill_admin" already exists. Skipping.'; + END IF; + GRANT windmill_admin TO windmill; + END + $$; + EOF + '' + ); + + windmill-server = { + description = "Windmill server"; + after = [ "network.target" ] ++ lib.optional cfg.database.createLocally "postgresql.service"; + wantedBy = [ "multi-user.target" ]; + + serviceConfig = serviceConfig // { + StateDirectory = "windmill"; + }; + + environment = { + PORT = builtins.toString cfg.serverPort; + WM_BASE_URL = cfg.baseUrl; + RUST_LOG = cfg.logLevel; + MODE = "server"; + } // db_url_envs; + }; + + windmill-worker = { + description = "Windmill worker"; + after = [ "network.target" ] ++ lib.optional cfg.database.createLocally "postgresql.service"; + wantedBy = [ "multi-user.target" ]; + + serviceConfig = serviceConfig // { + StateDirectory = "windmill-worker"; + }; + + environment = { + WM_BASE_URL = cfg.baseUrl; + RUST_LOG = cfg.logLevel; + MODE = "worker"; + WORKER_GROUP = "default"; + KEEP_JOB_DIR = "false"; + } // db_url_envs; + }; + + windmill-worker-native = { + description = "Windmill worker native"; + after = [ "network.target" ] ++ lib.optional cfg.database.createLocally "postgresql.service"; + wantedBy = [ "multi-user.target" ]; + + serviceConfig = serviceConfig // { + StateDirectory = "windmill-worker-native"; + }; + + environment = { + WM_BASE_URL = cfg.baseUrl; + RUST_LOG = cfg.logLevel; + MODE = "worker"; + WORKER_GROUP = "native"; + } // db_url_envs; + }; }; - }; }; } diff --git a/nixos/modules/services/web-apps/your_spotify.nix b/nixos/modules/services/web-apps/your_spotify.nix index 3eb2ffef4f9338..393726b22b01d5 100644 --- a/nixos/modules/services/web-apps/your_spotify.nix +++ b/nixos/modules/services/web-apps/your_spotify.nix @@ -3,9 +3,9 @@ config, lib, ... -}: let - inherit - (lib) +}: +let + inherit (lib) boolToString concatMapAttrs concatStrings @@ -21,107 +21,118 @@ ; cfg = config.services.your_spotify; - configEnv = concatMapAttrs (name: value: + configEnv = concatMapAttrs ( + name: value: optionalAttrs (value != null) { - ${name} = - if isBool value - then boolToString value - else toString value; - }) - cfg.settings; + ${name} = if isBool value then boolToString value else toString value; + } + ) cfg.settings; - configFile = pkgs.writeText "your_spotify.env" (concatStrings (mapAttrsToList (name: value: "${name}=${value}\n") configEnv)); -in { - options.services.your_spotify = let - inherit (types) nullOr port str path package; - in { - enable = mkEnableOption "your_spotify"; + configFile = pkgs.writeText "your_spotify.env" ( + concatStrings (mapAttrsToList (name: value: "${name}=${value}\n") configEnv) + ); +in +{ + options.services.your_spotify = + let + inherit (types) + nullOr + port + str + path + package + ; + in + { + enable = mkEnableOption "your_spotify"; - enableLocalDB = mkEnableOption "a local mongodb instance"; - nginxVirtualHost = mkOption { - type = nullOr str; - default = null; - description = '' - If set creates an nginx virtual host for the client. - In most cases this should be the CLIENT_ENDPOINT without - protocol prefix. - ''; - }; + enableLocalDB = mkEnableOption "a local mongodb instance"; + nginxVirtualHost = mkOption { + type = nullOr str; + default = null; + description = '' + If set creates an nginx virtual host for the client. + In most cases this should be the CLIENT_ENDPOINT without + protocol prefix. + ''; + }; - package = mkPackageOption pkgs "your_spotify" {}; + package = mkPackageOption pkgs "your_spotify" { }; - clientPackage = mkOption { - type = package; - description = "Client package to use."; - }; + clientPackage = mkOption { + type = package; + description = "Client package to use."; + }; - spotifySecretFile = mkOption { - type = path; - description = '' - A file containing the secret key of your Spotify application. - Refer to: [Creating the Spotify Application](https://github.com/Yooooomi/your_spotify#creating-the-spotify-application). - ''; - }; + spotifySecretFile = mkOption { + type = path; + description = '' + A file containing the secret key of your Spotify application. + Refer to: [Creating the Spotify Application](https://github.com/Yooooomi/your_spotify#creating-the-spotify-application). + ''; + }; - settings = mkOption { - description = '' - Your Spotify Configuration. Refer to [Your Spotify](https://github.com/Yooooomi/your_spotify) for definitions and values. - ''; - example = lib.literalExpression '' - { - CLIENT_ENDPOINT = "https://example.com"; - API_ENDPOINT = "https://api.example.com"; - SPOTIFY_PUBLIC = "spotify_client_id"; - } - ''; - type = types.submodule { - freeformType = types.attrsOf types.str; - options = { - CLIENT_ENDPOINT = mkOption { - type = str; - description = '' - The endpoint of your web application. - Has to include a protocol Prefix (e.g. `http://`) - ''; - example = "https://your_spotify.example.org"; - }; - API_ENDPOINT = mkOption { - type = str; - description = '' - The endpoint of your server - This api has to be reachable from the device you use the website from not from the server. - This means that for example you may need two nginx virtual hosts if you want to expose this on the - internet. - Has to include a protocol Prefix (e.g. `http://`) - ''; - example = "https://localhost:3000"; - }; - SPOTIFY_PUBLIC = mkOption { - type = str; - description = '' - The public client ID of your Spotify application. - Refer to: [Creating the Spotify Application](https://github.com/Yooooomi/your_spotify#creating-the-spotify-application) - ''; - }; - MONGO_ENDPOINT = mkOption { - type = str; - description = ''The endpoint of the Mongo database.''; - default = "mongodb://localhost:27017/your_spotify"; - }; - PORT = mkOption { - type = port; - description = "The port of the api server"; - default = 3000; + settings = mkOption { + description = '' + Your Spotify Configuration. Refer to [Your Spotify](https://github.com/Yooooomi/your_spotify) for definitions and values. + ''; + example = lib.literalExpression '' + { + CLIENT_ENDPOINT = "https://example.com"; + API_ENDPOINT = "https://api.example.com"; + SPOTIFY_PUBLIC = "spotify_client_id"; + } + ''; + type = types.submodule { + freeformType = types.attrsOf types.str; + options = { + CLIENT_ENDPOINT = mkOption { + type = str; + description = '' + The endpoint of your web application. + Has to include a protocol Prefix (e.g. `http://`) + ''; + example = "https://your_spotify.example.org"; + }; + API_ENDPOINT = mkOption { + type = str; + description = '' + The endpoint of your server + This api has to be reachable from the device you use the website from not from the server. + This means that for example you may need two nginx virtual hosts if you want to expose this on the + internet. + Has to include a protocol Prefix (e.g. `http://`) + ''; + example = "https://localhost:3000"; + }; + SPOTIFY_PUBLIC = mkOption { + type = str; + description = '' + The public client ID of your Spotify application. + Refer to: [Creating the Spotify Application](https://github.com/Yooooomi/your_spotify#creating-the-spotify-application) + ''; + }; + MONGO_ENDPOINT = mkOption { + type = str; + description = ''The endpoint of the Mongo database.''; + default = "mongodb://localhost:27017/your_spotify"; + }; + PORT = mkOption { + type = port; + description = "The port of the api server"; + default = 3000; + }; }; }; }; }; - }; config = mkIf cfg.enable { - services.your_spotify.clientPackage = mkDefault (cfg.package.client.override {apiEndpoint = cfg.settings.API_ENDPOINT;}); + services.your_spotify.clientPackage = mkDefault ( + cfg.package.client.override { apiEndpoint = cfg.settings.API_ENDPOINT; } + ); systemd.services.your_spotify = { - after = ["network.target"]; + after = [ "network.target" ]; script = '' export SPOTIFY_SECRET=$(< "$CREDENTIALS_DIRECTORY/SPOTIFY_SECRET") ${lib.getExe' cfg.package "your_spotify_migrate"} @@ -131,7 +142,7 @@ in { User = "your_spotify"; Group = "your_spotify"; DynamicUser = true; - EnvironmentFile = [configFile]; + EnvironmentFile = [ configFile ]; StateDirectory = "your_spotify"; LimitNOFILE = "1048576"; PrivateTmp = true; @@ -139,7 +150,7 @@ in { StateDirectoryMode = "0700"; Restart = "always"; - LoadCredential = ["SPOTIFY_SECRET:${cfg.spotifySecretFile}"]; + LoadCredential = [ "SPOTIFY_SECRET:${cfg.spotifySecretFile}" ]; # Hardening CapabilityBoundingSet = ""; @@ -170,7 +181,7 @@ in { ]; UMask = "0077"; }; - wantedBy = ["multi-user.target"]; + wantedBy = [ "multi-user.target" ]; }; services.nginx = mkIf (cfg.nginxVirtualHost != null) { enable = true; @@ -187,5 +198,5 @@ in { enable = true; }; }; - meta.maintainers = with lib.maintainers; [patrickdag]; + meta.maintainers = with lib.maintainers; [ patrickdag ]; } diff --git a/nixos/modules/services/web-apps/youtrack.nix b/nixos/modules/services/web-apps/youtrack.nix index e80cdda680871b..989d9e4fbaffa3 100644 --- a/nixos/modules/services/web-apps/youtrack.nix +++ b/nixos/modules/services/web-apps/youtrack.nix @@ -1,16 +1,43 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.youtrack; in { imports = [ - (lib.mkRenamedOptionModule [ "services" "youtrack" "baseUrl" ] [ "services" "youtrack" "environmentalParameters" "base-url" ]) - (lib.mkRenamedOptionModule [ "services" "youtrack" "port" ] [ "services" "youtrack" "environmentalParameters" "listen-port" ]) - (lib.mkRemovedOptionModule [ "services" "youtrack" "maxMemory" ] "Please instead use `services.youtrack.generalParameters`.") - (lib.mkRemovedOptionModule [ "services" "youtrack" "maxMetaspaceSize" ] "Please instead use `services.youtrack.generalParameters`.") - (lib.mkRemovedOptionModule [ "services" "youtrack" "extraParams" ] "Please migrate to `services.youtrack.generalParameters`.") - (lib.mkRemovedOptionModule [ "services" "youtrack" "jvmOpts" ] "Please migrate to `services.youtrack.generalParameters`.") + (lib.mkRenamedOptionModule + [ "services" "youtrack" "baseUrl" ] + [ "services" "youtrack" "environmentalParameters" "base-url" ] + ) + (lib.mkRenamedOptionModule + [ "services" "youtrack" "port" ] + [ "services" "youtrack" "environmentalParameters" "listen-port" ] + ) + (lib.mkRemovedOptionModule [ + "services" + "youtrack" + "maxMemory" + ] "Please instead use `services.youtrack.generalParameters`.") + (lib.mkRemovedOptionModule [ + "services" + "youtrack" + "maxMetaspaceSize" + ] "Please instead use `services.youtrack.generalParameters`.") + (lib.mkRemovedOptionModule [ + "services" + "youtrack" + "extraParams" + ] "Please migrate to `services.youtrack.generalParameters`.") + (lib.mkRemovedOptionModule [ + "services" + "youtrack" + "jvmOpts" + ] "Please migrate to `services.youtrack.generalParameters`.") ]; options.services.youtrack = { @@ -70,12 +97,18 @@ in "-Xmx1024m" ]; ''; - default = []; + default = [ ]; }; environmentalParameters = lib.mkOption { type = lib.types.submodule { - freeformType = with lib.types; attrsOf (oneOf [ int str port ]); + freeformType = + with lib.types; + attrsOf (oneOf [ + int + str + port + ]); options = { listen-address = lib.mkOption { type = lib.types.str; @@ -99,52 +132,60 @@ in secure-mode = "tls"; } ''; - default = {}; + default = { }; }; }; config = lib.mkIf cfg.enable { - services.youtrack.generalParameters = [ "-Ddisable.configuration.wizard.on.upgrade=${lib.boolToString cfg.autoUpgrade}" ]; - - systemd.services.youtrack = let - jvmoptions = pkgs.writeTextFile { - name = "youtrack.jvmoptions"; - text = (lib.concatStringsSep "\n" cfg.generalParameters); - }; + services.youtrack.generalParameters = [ + "-Ddisable.configuration.wizard.on.upgrade=${lib.boolToString cfg.autoUpgrade}" + ]; + + systemd.services.youtrack = + let + jvmoptions = pkgs.writeTextFile { + name = "youtrack.jvmoptions"; + text = (lib.concatStringsSep "\n" cfg.generalParameters); + }; - package = cfg.package.override { - statePath = cfg.statePath; + package = cfg.package.override { + statePath = cfg.statePath; + }; + in + { + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + path = with pkgs; [ unixtools.hostname ]; + preStart = '' + # This detects old (i.e. <= 2022.3) installations that were not migrated yet + # and migrates them to the new state directory style + if [[ -d ${cfg.statePath}/teamsysdata ]] && [[ ! -d ${cfg.statePath}/2022_3 ]] + then + mkdir -p ${cfg.statePath}/2022_3 + mv ${cfg.statePath}/teamsysdata ${cfg.statePath}/2022_3 + mv ${cfg.statePath}/.youtrack ${cfg.statePath}/2022_3 + fi + mkdir -p ${cfg.statePath}/{backups,conf,data,logs,temp} + ${pkgs.coreutils}/bin/ln -fs ${jvmoptions} ${cfg.statePath}/conf/youtrack.jvmoptions + ${package}/bin/youtrack configure ${ + lib.concatStringsSep " " ( + lib.mapAttrsToList (name: value: "--${name}=${toString value}") cfg.environmentalParameters + ) + } + ''; + serviceConfig = lib.mkMerge [ + { + Type = "simple"; + User = "youtrack"; + Group = "youtrack"; + Restart = "on-failure"; + ExecStart = "${package}/bin/youtrack run"; + } + (lib.mkIf (cfg.statePath == "/var/lib/youtrack") { + StateDirectory = "youtrack"; + }) + ]; }; - in { - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - path = with pkgs; [ unixtools.hostname ]; - preStart = '' - # This detects old (i.e. <= 2022.3) installations that were not migrated yet - # and migrates them to the new state directory style - if [[ -d ${cfg.statePath}/teamsysdata ]] && [[ ! -d ${cfg.statePath}/2022_3 ]] - then - mkdir -p ${cfg.statePath}/2022_3 - mv ${cfg.statePath}/teamsysdata ${cfg.statePath}/2022_3 - mv ${cfg.statePath}/.youtrack ${cfg.statePath}/2022_3 - fi - mkdir -p ${cfg.statePath}/{backups,conf,data,logs,temp} - ${pkgs.coreutils}/bin/ln -fs ${jvmoptions} ${cfg.statePath}/conf/youtrack.jvmoptions - ${package}/bin/youtrack configure ${lib.concatStringsSep " " (lib.mapAttrsToList (name: value: "--${name}=${toString value}") cfg.environmentalParameters )} - ''; - serviceConfig = lib.mkMerge [ - { - Type = "simple"; - User = "youtrack"; - Group = "youtrack"; - Restart = "on-failure"; - ExecStart = "${package}/bin/youtrack run"; - } - (lib.mkIf (cfg.statePath == "/var/lib/youtrack") { - StateDirectory = "youtrack"; - }) - ]; - }; users.users.youtrack = { description = "Youtrack service user"; @@ -154,10 +195,11 @@ in group = "youtrack"; }; - users.groups.youtrack = {}; + users.groups.youtrack = { }; services.nginx = lib.mkIf (cfg.virtualHost != null) { - upstreams.youtrack.servers."${cfg.address}:${toString cfg.environmentalParameters.listen-port}" = {}; + upstreams.youtrack.servers."${cfg.address}:${toString cfg.environmentalParameters.listen-port}" = + { }; virtualHosts.${cfg.virtualHost}.locations = { "/" = { proxyPass = "http://youtrack"; diff --git a/nixos/modules/services/web-apps/zitadel.nix b/nixos/modules/services/web-apps/zitadel.nix index ed7fae8d9dda09..2ddd0a52dc9cab 100644 --- a/nixos/modules/services/web-apps/zitadel.nix +++ b/nixos/modules/services/web-apps/zitadel.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.zitadel; @@ -7,8 +12,15 @@ let in { options.services.zitadel = - let inherit (lib) mkEnableOption mkOption mkPackageOption types; - in { + let + inherit (lib) + mkEnableOption + mkOption + mkPackageOption + types + ; + in + { enable = mkEnableOption "ZITADEL, a user and identity access management platform"; package = mkPackageOption pkgs "ZITADEL" { default = [ "zitadel" ]; }; @@ -42,7 +54,11 @@ in }; tlsMode = mkOption { - type = types.enum [ "external" "enabled" "disabled" ]; + type = types.enum [ + "external" + "enabled" + "disabled" + ]; default = "external"; example = "enabled"; description = '' @@ -169,19 +185,22 @@ in }; config = lib.mkIf cfg.enable { - assertions = [{ - assertion = cfg.tlsMode == "enabled" - -> ((cfg.settings.TLS.Key != null || cfg.settings.TLS.KeyPath != null) - && (cfg.settings.TLS.Cert != null || cfg.settings.TLS.CertPath - != null)); - message = '' - A TLS certificate and key must be configured in - services.zitadel.settings.TLS if services.zitadel.tlsMode is enabled. - ''; - }]; - - networking.firewall.allowedTCPPorts = - lib.mkIf cfg.openFirewall [ cfg.settings.Port ]; + assertions = [ + { + assertion = + cfg.tlsMode == "enabled" + -> ( + (cfg.settings.TLS.Key != null || cfg.settings.TLS.KeyPath != null) + && (cfg.settings.TLS.Cert != null || cfg.settings.TLS.CertPath != null) + ); + message = '' + A TLS certificate and key must be configured in + services.zitadel.settings.TLS if services.zitadel.tlsMode is enabled. + ''; + } + ]; + + networking.firewall.allowedTCPPorts = lib.mkIf cfg.openFirewall [ cfg.settings.Port ]; systemd.services.zitadel = let diff --git a/nixos/modules/services/web-servers/agate.nix b/nixos/modules/services/web-servers/agate.nix index 76c1a94f3bf289..8e6c5b33460744 100644 --- a/nixos/modules/services/web-servers/agate.nix +++ b/nixos/modules/services/web-servers/agate.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -72,11 +77,19 @@ in description = "Agate"; wantedBy = [ "multi-user.target" ]; wants = [ "network-online.target" ]; - after = [ "network.target" "network-online.target" ]; + after = [ + "network.target" + "network-online.target" + ]; script = let - prefixKeyList = key: list: concatMap (v: [ key v ]) list; + prefixKeyList = + key: list: + concatMap (v: [ + key + v + ]) list; addresses = prefixKeyList "--addr" cfg.addresses; hostnames = prefixKeyList "--hostname" cfg.hostnames; in @@ -84,14 +97,19 @@ in exec ${cfg.package}/bin/agate ${ escapeShellArgs ( [ - "--content" "${cfg.contentDir}" - "--certs" "${cfg.certificatesDir}" - ] ++ - addresses ++ - (optionals (cfg.hostnames != []) hostnames) ++ - (optionals (cfg.language != null) [ "--lang" cfg.language ]) ++ - (optionals cfg.onlyTls_1_3 [ "--only-tls13" ]) ++ - (optionals (cfg.extraArgs != []) cfg.extraArgs) + "--content" + "${cfg.contentDir}" + "--certs" + "${cfg.certificatesDir}" + ] + ++ addresses + ++ (optionals (cfg.hostnames != [ ]) hostnames) + ++ (optionals (cfg.language != null) [ + "--lang" + cfg.language + ]) + ++ (optionals cfg.onlyTls_1_3 [ "--only-tls13" ]) + ++ (optionals (cfg.extraArgs != [ ]) cfg.extraArgs) ) } ''; @@ -123,7 +141,10 @@ in ProtectKernelTunables = true; RestrictNamespaces = true; - RestrictAddressFamilies = [ "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_INET" + "AF_INET6" + ]; RestrictRealtime = true; SystemCallArchitectures = "native"; diff --git a/nixos/modules/services/web-servers/apache-httpd/location-options.nix b/nixos/modules/services/web-servers/apache-httpd/location-options.nix index 80dc1674c5a2ae..68d90d6007cfab 100644 --- a/nixos/modules/services/web-servers/apache-httpd/location-options.nix +++ b/nixos/modules/services/web-servers/apache-httpd/location-options.nix @@ -1,4 +1,9 @@ -{ config, lib, name, ... }: +{ + config, + lib, + name, + ... +}: let inherit (lib) mkOption types; in diff --git a/nixos/modules/services/web-servers/apache-httpd/vhost-options.nix b/nixos/modules/services/web-servers/apache-httpd/vhost-options.nix index f3d57ac16ea2fd..43b24fdc4a96bb 100644 --- a/nixos/modules/services/web-servers/apache-httpd/vhost-options.nix +++ b/nixos/modules/services/web-servers/apache-httpd/vhost-options.nix @@ -1,6 +1,16 @@ -{ config, lib, name, ... }: +{ + config, + lib, + name, + ... +}: let - inherit (lib) literalExpression mkOption nameValuePair types; + inherit (lib) + literalExpression + mkOption + nameValuePair + types + ; in { options = { @@ -13,37 +23,53 @@ in serverAliases = mkOption { type = types.listOf types.str; - default = []; - example = ["www.example.org" "www.example.org:8080" "example.org"]; + default = [ ]; + example = [ + "www.example.org" + "www.example.org:8080" + "example.org" + ]; description = '' Additional names of virtual hosts served by this virtual host configuration. ''; }; listen = mkOption { - type = with types; listOf (submodule ({ - options = { - port = mkOption { - type = types.port; - description = "Port to listen on"; - }; - ip = mkOption { - type = types.str; - default = "*"; - description = "IP to listen on. 0.0.0.0 for IPv4 only, * for all."; + type = + with types; + listOf (submodule ({ + options = { + port = mkOption { + type = types.port; + description = "Port to listen on"; + }; + ip = mkOption { + type = types.str; + default = "*"; + description = "IP to listen on. 0.0.0.0 for IPv4 only, * for all."; + }; + ssl = mkOption { + type = types.bool; + default = false; + description = "Whether to enable SSL (https) support."; + }; }; - ssl = mkOption { - type = types.bool; - default = false; - description = "Whether to enable SSL (https) support."; - }; - }; - })); - default = []; + })); + default = [ ]; example = [ - { ip = "195.154.1.1"; port = 443; ssl = true;} - { ip = "192.154.1.1"; port = 80; } - { ip = "*"; port = 8080; } + { + ip = "195.154.1.1"; + port = 443; + ssl = true; + } + { + ip = "192.154.1.1"; + port = 80; + } + { + ip = "*"; + port = 8080; + } ]; description = '' Listen addresses and ports for this virtual host. @@ -181,9 +207,10 @@ in servedDirs = mkOption { type = types.listOf types.attrs; - default = []; + default = [ ]; example = [ - { urlPath = "/nix"; + { + urlPath = "/nix"; dir = "/home/eelco/Dev/nix-homepage"; } ]; @@ -194,9 +221,10 @@ in servedFiles = mkOption { type = types.listOf types.attrs; - default = []; + default = [ ]; example = [ - { urlPath = "/foo/bar.png"; + { + urlPath = "/foo/bar.png"; file = "/home/eelco/some-file.png"; } ]; @@ -265,7 +293,7 @@ in locations = mkOption { type = with types; attrsOf (submodule (import ./location-options.nix)); - default = {}; + default = { }; example = literalExpression '' { "/" = { @@ -285,7 +313,9 @@ in config = { - locations = builtins.listToAttrs (map (elem: nameValuePair elem.urlPath { alias = elem.file; }) config.servedFiles); + locations = builtins.listToAttrs ( + map (elem: nameValuePair elem.urlPath { alias = elem.file; }) config.servedFiles + ); }; } diff --git a/nixos/modules/services/web-servers/caddy/default.nix b/nixos/modules/services/web-servers/caddy/default.nix index 9261fe340b13d7..d87a04e0f5f159 100644 --- a/nixos/modules/services/web-servers/caddy/default.nix +++ b/nixos/modules/services/web-servers/caddy/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -12,21 +17,26 @@ let dependentCertNames = filter (cert: certs.${cert}.dnsProvider == null) vhostCertNames; # those that might depend on the HTTP server independentCertNames = filter (cert: certs.${cert}.dnsProvider != null) vhostCertNames; # those that don't depend on the HTTP server - mkVHostConf = hostOpts: + mkVHostConf = + hostOpts: let sslCertDir = config.security.acme.certs.${hostOpts.useACMEHost}.directory; in - '' - ${hostOpts.hostName} ${concatStringsSep " " hostOpts.serverAliases} { - ${optionalString (hostOpts.listenAddresses != [ ]) "bind ${concatStringsSep " " hostOpts.listenAddresses}"} - ${optionalString (hostOpts.useACMEHost != null) "tls ${sslCertDir}/cert.pem ${sslCertDir}/key.pem"} - log { - ${hostOpts.logFormat} - } - - ${hostOpts.extraConfig} + '' + ${hostOpts.hostName} ${concatStringsSep " " hostOpts.serverAliases} { + ${optionalString ( + hostOpts.listenAddresses != [ ] + ) "bind ${concatStringsSep " " hostOpts.listenAddresses}"} + ${optionalString ( + hostOpts.useACMEHost != null + ) "tls ${sslCertDir}/cert.pem ${sslCertDir}/key.pem"} + log { + ${hostOpts.logFormat} } - ''; + + ${hostOpts.extraConfig} + } + ''; settingsFormat = pkgs.formats.json { }; @@ -43,13 +53,17 @@ let ${concatMapStringsSep "\n" mkVHostConf virtualHosts} ''; - Caddyfile-formatted = pkgs.runCommand "Caddyfile-formatted" { nativeBuildInputs = [ cfg.package ]; } '' - mkdir -p $out - cp --no-preserve=mode ${Caddyfile}/Caddyfile $out/Caddyfile - caddy fmt --overwrite $out/Caddyfile - ''; + Caddyfile-formatted = + pkgs.runCommand "Caddyfile-formatted" { nativeBuildInputs = [ cfg.package ]; } + '' + mkdir -p $out + cp --no-preserve=mode ${Caddyfile}/Caddyfile $out/Caddyfile + caddy fmt --overwrite $out/Caddyfile + ''; in - "${if pkgs.stdenv.buildPlatform == pkgs.stdenv.hostPlatform then Caddyfile-formatted else Caddyfile}/Caddyfile"; + "${ + if pkgs.stdenv.buildPlatform == pkgs.stdenv.hostPlatform then Caddyfile-formatted else Caddyfile + }/Caddyfile"; etcConfigFile = "caddy/caddy_config"; @@ -59,7 +73,11 @@ let in { imports = [ - (mkRemovedOptionModule [ "services" "caddy" "agree" ] "this option is no longer necessary for Caddy 2") + (mkRemovedOptionModule [ + "services" + "caddy" + "agree" + ] "this option is no longer necessary for Caddy 2") (mkRenamedOptionModule [ "services" "caddy" "ca" ] [ "services" "caddy" "acmeCA" ]) (mkRenamedOptionModule [ "services" "caddy" "config" ] [ "services" "caddy" "extraConfig" ]) ]; @@ -166,7 +184,11 @@ in }; adapter = mkOption { - default = if ((cfg.configFile != configFile) || (builtins.baseNameOf cfg.configFile) == "Caddyfile") then "caddyfile" else null; + default = + if ((cfg.configFile != configFile) || (builtins.baseNameOf cfg.configFile) == "Caddyfile") then + "caddyfile" + else + null; defaultText = literalExpression '' if ((cfg.configFile != configFile) || (builtins.baseNameOf cfg.configFile) == "Caddyfile") then "caddyfile" else null ''; @@ -237,7 +259,7 @@ in virtualHosts = mkOption { type = with types; attrsOf (submodule (import ./vhost-options.nix { inherit cfg; })); - default = {}; + default = { }; example = literalExpression '' { "hydra.example.com" = { @@ -303,7 +325,7 @@ in settings = mkOption { type = settingsFormat.type; - default = {}; + default = { }; description = '' Structured configuration for Caddy to generate a Caddy JSON configuration file. See for available options. @@ -361,15 +383,21 @@ in # implementation config = mkIf cfg.enable { - assertions = [ - { assertion = cfg.configFile == configFile -> cfg.adapter == "caddyfile" || cfg.adapter == null; - message = "To specify an adapter other than 'caddyfile' please provide your own configuration via `services.caddy.configFile`"; - } - ] ++ map (name: mkCertOwnershipAssertion { - cert = config.security.acme.certs.${name}; - groups = config.users.groups; - services = [ config.systemd.services.caddy ]; - }) vhostCertNames; + assertions = + [ + { + assertion = cfg.configFile == configFile -> cfg.adapter == "caddyfile" || cfg.adapter == null; + message = "To specify an adapter other than 'caddyfile' please provide your own configuration via `services.caddy.configFile`"; + } + ] + ++ map ( + name: + mkCertOwnershipAssertion { + cert = config.security.acme.certs.${name}; + groups = config.users.groups; + services = [ config.systemd.services.caddy ]; + } + ) vhostCertNames; services.caddy.globalConfig = '' ${optionalString (cfg.email != null) "email ${cfg.email}"} @@ -386,7 +414,8 @@ in systemd.packages = [ cfg.package ]; systemd.services.caddy = { wants = map (certName: "acme-finished-${certName}.target") vhostCertNames; - after = map (certName: "acme-selfsigned-${certName}.service") vhostCertNames + after = + map (certName: "acme-selfsigned-${certName}.service") vhostCertNames ++ map (certName: "acme-${certName}.service") independentCertNames; # avoid loading self-signed key w/ real cert, or vice-versa before = map (certName: "acme-${certName}.service") dependentCertNames; @@ -394,32 +423,41 @@ in startLimitIntervalSec = 14400; startLimitBurst = 10; reloadTriggers = optional cfg.enableReload cfg.configFile; - restartTriggers = optional (! cfg.enableReload) cfg.configFile; - - serviceConfig = let - runOptions = ''--config ${configPath} ${optionalString (cfg.adapter != null) "--adapter ${cfg.adapter}"}''; - in { - # Override the `ExecStart` line from upstream's systemd unit file by our own: - # https://www.freedesktop.org/software/systemd/man/systemd.service.html#ExecStart= - # If the empty string is assigned to this option, the list of commands to start is reset, prior assignments of this option will have no effect. - ExecStart = [ "" ''${cfg.package}/bin/caddy run ${runOptions} ${optionalString cfg.resume "--resume"}'' ]; - # Validating the configuration before applying it ensures we’ll get a proper error that will be reported when switching to the configuration - ExecReload = [ "" ] ++ lib.optional cfg.enableReload "${lib.getExe cfg.package} reload ${runOptions} --force"; - User = cfg.user; - Group = cfg.group; - ReadWritePaths = [ cfg.dataDir ]; - StateDirectory = mkIf (cfg.dataDir == "/var/lib/caddy") [ "caddy" ]; - LogsDirectory = mkIf (cfg.logDir == "/var/log/caddy") [ "caddy" ]; - Restart = "on-failure"; - RestartPreventExitStatus = 1; - RestartSec = "5s"; - EnvironmentFile = optional (cfg.environmentFile != null) cfg.environmentFile; - - # TODO: attempt to upstream these options - NoNewPrivileges = true; - PrivateDevices = true; - ProtectHome = true; - }; + restartTriggers = optional (!cfg.enableReload) cfg.configFile; + + serviceConfig = + let + runOptions = ''--config ${configPath} ${ + optionalString (cfg.adapter != null) "--adapter ${cfg.adapter}" + }''; + in + { + # Override the `ExecStart` line from upstream's systemd unit file by our own: + # https://www.freedesktop.org/software/systemd/man/systemd.service.html#ExecStart= + # If the empty string is assigned to this option, the list of commands to start is reset, prior assignments of this option will have no effect. + ExecStart = [ + "" + ''${cfg.package}/bin/caddy run ${runOptions} ${optionalString cfg.resume "--resume"}'' + ]; + # Validating the configuration before applying it ensures we’ll get a proper error that will be reported when switching to the configuration + ExecReload = [ + "" + ] ++ lib.optional cfg.enableReload "${lib.getExe cfg.package} reload ${runOptions} --force"; + User = cfg.user; + Group = cfg.group; + ReadWritePaths = [ cfg.dataDir ]; + StateDirectory = mkIf (cfg.dataDir == "/var/lib/caddy") [ "caddy" ]; + LogsDirectory = mkIf (cfg.logDir == "/var/log/caddy") [ "caddy" ]; + Restart = "on-failure"; + RestartPreventExitStatus = 1; + RestartSec = "5s"; + EnvironmentFile = optional (cfg.environmentFile != null) cfg.environmentFile; + + # TODO: attempt to upstream these options + NoNewPrivileges = true; + PrivateDevices = true; + ProtectHome = true; + }; }; users.users = optionalAttrs (cfg.user == "caddy") { @@ -436,12 +474,15 @@ in security.acme.certs = let - certCfg = map (certName: nameValuePair certName { - group = mkDefault cfg.group; - reloadServices = [ "caddy.service" ]; - }) vhostCertNames; + certCfg = map ( + certName: + nameValuePair certName { + group = mkDefault cfg.group; + reloadServices = [ "caddy.service" ]; + } + ) vhostCertNames; in - listToAttrs certCfg; + listToAttrs certCfg; environment.etc.${etcConfigFile}.source = cfg.configFile; }; diff --git a/nixos/modules/services/web-servers/caddy/vhost-options.nix b/nixos/modules/services/web-servers/caddy/vhost-options.nix index c092f2d7963751..04feb6dc66c677 100644 --- a/nixos/modules/services/web-servers/caddy/vhost-options.nix +++ b/nixos/modules/services/web-servers/caddy/vhost-options.nix @@ -1,5 +1,10 @@ { cfg }: -{ config, lib, name, ... }: +{ + config, + lib, + name, + ... +}: let inherit (lib) literalExpression mkOption types; in @@ -15,7 +20,10 @@ in serverAliases = mkOption { type = with types; listOf str; default = [ ]; - example = [ "www.example.org" "example.org" ]; + example = [ + "www.example.org" + "example.org" + ]; description = '' Additional names of virtual hosts served by this virtual host configuration. ''; @@ -27,7 +35,10 @@ in A list of host interfaces to bind to for this virtual host. ''; default = [ ]; - example = [ "127.0.0.1" "::1" ]; + example = [ + "127.0.0.1" + "::1" + ]; }; useACMEHost = mkOption { diff --git a/nixos/modules/services/web-servers/fcgiwrap.nix b/nixos/modules/services/web-servers/fcgiwrap.nix index 36a327b9ab9f99..6824938fe5a00e 100644 --- a/nixos/modules/services/web-servers/fcgiwrap.nix +++ b/nixos/modules/services/web-servers/fcgiwrap.nix @@ -1,150 +1,192 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let - forEachInstance = f: flip mapAttrs' config.services.fcgiwrap.instances ( - name: cfg: nameValuePair "fcgiwrap-${name}" (f cfg) - ); + forEachInstance = + f: + flip mapAttrs' config.services.fcgiwrap.instances ( + name: cfg: nameValuePair "fcgiwrap-${name}" (f cfg) + ); -in { - imports = forEach [ - "enable" - "user" - "group" - "socketType" - "socketAddress" - "preforkProcesses" - ] (attr: mkRemovedOptionModule [ "services" "fcgiwrap" attr ] '' - The global shared fcgiwrap instance is no longer supported due to - security issues. - Isolated instances should instead be configured through - `services.fcgiwrap.instances.*'. - ''); +in +{ + imports = + forEach + [ + "enable" + "user" + "group" + "socketType" + "socketAddress" + "preforkProcesses" + ] + ( + attr: + mkRemovedOptionModule [ "services" "fcgiwrap" attr ] '' + The global shared fcgiwrap instance is no longer supported due to + security issues. + Isolated instances should instead be configured through + `services.fcgiwrap.instances.*'. + '' + ); options.services.fcgiwrap.instances = mkOption { description = "Configuration for fcgiwrap instances."; default = { }; - type = types.attrsOf (types.submodule ({ config, ... }: { options = { - process.prefork = mkOption { - type = types.ints.positive; - default = 1; - description = "Number of processes to prefork."; - }; + type = types.attrsOf ( + types.submodule ( + { config, ... }: + { + options = { + process.prefork = mkOption { + type = types.ints.positive; + default = 1; + description = "Number of processes to prefork."; + }; - process.user = mkOption { - type = types.nullOr types.str; - default = null; - description = '' - User as which this instance of fcgiwrap will be run. - Set to `null` (the default) to use a dynamically allocated user. - ''; - }; + process.user = mkOption { + type = types.nullOr types.str; + default = null; + description = '' + User as which this instance of fcgiwrap will be run. + Set to `null` (the default) to use a dynamically allocated user. + ''; + }; - process.group = mkOption { - type = types.nullOr types.str; - default = null; - description = "Group as which this instance of fcgiwrap will be run."; - }; + process.group = mkOption { + type = types.nullOr types.str; + default = null; + description = "Group as which this instance of fcgiwrap will be run."; + }; - socket.type = mkOption { - type = types.enum [ "unix" "tcp" "tcp6" ]; - default = "unix"; - description = "Socket type: 'unix', 'tcp' or 'tcp6'."; - }; + socket.type = mkOption { + type = types.enum [ + "unix" + "tcp" + "tcp6" + ]; + default = "unix"; + description = "Socket type: 'unix', 'tcp' or 'tcp6'."; + }; - socket.address = mkOption { - type = types.str; - default = "/run/fcgiwrap-${config._module.args.name}.sock"; - example = "1.2.3.4:5678"; - description = '' - Socket address. - In case of a UNIX socket, this should be its filesystem path. - ''; - }; + socket.address = mkOption { + type = types.str; + default = "/run/fcgiwrap-${config._module.args.name}.sock"; + example = "1.2.3.4:5678"; + description = '' + Socket address. + In case of a UNIX socket, this should be its filesystem path. + ''; + }; - socket.user = mkOption { - type = types.nullOr types.str; - default = null; - description = '' - User to be set as owner of the UNIX socket. - ''; - }; + socket.user = mkOption { + type = types.nullOr types.str; + default = null; + description = '' + User to be set as owner of the UNIX socket. + ''; + }; - socket.group = mkOption { - type = types.nullOr types.str; - default = null; - description = '' - Group to be set as owner of the UNIX socket. - ''; - }; + socket.group = mkOption { + type = types.nullOr types.str; + default = null; + description = '' + Group to be set as owner of the UNIX socket. + ''; + }; - socket.mode = mkOption { - type = types.nullOr types.str; - default = if config.socket.type == "unix" then "0600" else null; - defaultText = literalExpression '' - if config.socket.type == "unix" then "0600" else null - ''; - description = '' - Mode to be set on the UNIX socket. - Defaults to private to the socket's owner. - ''; - }; - }; })); + socket.mode = mkOption { + type = types.nullOr types.str; + default = if config.socket.type == "unix" then "0600" else null; + defaultText = literalExpression '' + if config.socket.type == "unix" then "0600" else null + ''; + description = '' + Mode to be set on the UNIX socket. + Defaults to private to the socket's owner. + ''; + }; + }; + } + ) + ); }; config = { - assertions = concatLists (mapAttrsToList (name: cfg: [ - { - assertion = cfg.socket.type == "unix" -> cfg.socket.user != null; - message = "Socket owner is required for the UNIX socket type."; - } - { - assertion = cfg.socket.type == "unix" -> cfg.socket.group != null; - message = "Socket owner is required for the UNIX socket type."; - } - { - assertion = cfg.socket.user != null -> cfg.socket.type == "unix"; - message = "Socket owner can only be set for the UNIX socket type."; - } - { - assertion = cfg.socket.group != null -> cfg.socket.type == "unix"; - message = "Socket owner can only be set for the UNIX socket type."; - } - { - assertion = cfg.socket.mode != null -> cfg.socket.type == "unix"; - message = "Socket mode can only be set for the UNIX socket type."; - } - ]) config.services.fcgiwrap.instances); + assertions = concatLists ( + mapAttrsToList (name: cfg: [ + { + assertion = cfg.socket.type == "unix" -> cfg.socket.user != null; + message = "Socket owner is required for the UNIX socket type."; + } + { + assertion = cfg.socket.type == "unix" -> cfg.socket.group != null; + message = "Socket owner is required for the UNIX socket type."; + } + { + assertion = cfg.socket.user != null -> cfg.socket.type == "unix"; + message = "Socket owner can only be set for the UNIX socket type."; + } + { + assertion = cfg.socket.group != null -> cfg.socket.type == "unix"; + message = "Socket owner can only be set for the UNIX socket type."; + } + { + assertion = cfg.socket.mode != null -> cfg.socket.type == "unix"; + message = "Socket mode can only be set for the UNIX socket type."; + } + ]) config.services.fcgiwrap.instances + ); systemd.services = forEachInstance (cfg: { after = [ "nss-user-lookup.target" ]; wantedBy = optional (cfg.socket.type != "unix") "multi-user.target"; - serviceConfig = { - ExecStart = '' - ${pkgs.fcgiwrap}/sbin/fcgiwrap ${cli.toGNUCommandLineShell {} ({ - c = cfg.process.prefork; - } // (optionalAttrs (cfg.socket.type != "unix") { - s = "${cfg.socket.type}:${cfg.socket.address}"; - }))} - ''; - } // (if cfg.process.user != null then { - User = cfg.process.user; - Group = cfg.process.group; - } else { - DynamicUser = true; - }); + serviceConfig = + { + ExecStart = '' + ${pkgs.fcgiwrap}/sbin/fcgiwrap ${ + cli.toGNUCommandLineShell { } ( + { + c = cfg.process.prefork; + } + // (optionalAttrs (cfg.socket.type != "unix") { + s = "${cfg.socket.type}:${cfg.socket.address}"; + }) + ) + } + ''; + } + // ( + if cfg.process.user != null then + { + User = cfg.process.user; + Group = cfg.process.group; + } + else + { + DynamicUser = true; + } + ); }); - systemd.sockets = forEachInstance (cfg: mkIf (cfg.socket.type == "unix") { - wantedBy = [ "sockets.target" ]; - socketConfig = { - ListenStream = cfg.socket.address; - SocketUser = cfg.socket.user; - SocketGroup = cfg.socket.group; - SocketMode = cfg.socket.mode; - }; - }); + systemd.sockets = forEachInstance ( + cfg: + mkIf (cfg.socket.type == "unix") { + wantedBy = [ "sockets.target" ]; + socketConfig = { + ListenStream = cfg.socket.address; + SocketUser = cfg.socket.user; + SocketGroup = cfg.socket.group; + SocketMode = cfg.socket.mode; + }; + } + ); }; } diff --git a/nixos/modules/services/web-servers/hitch/default.nix b/nixos/modules/services/web-servers/hitch/default.nix index b1c72c0dd7b7b4..a5a536ff9917d2 100644 --- a/nixos/modules/services/web-servers/hitch/default.nix +++ b/nixos/modules/services/web-servers/hitch/default.nix @@ -1,17 +1,26 @@ -{ config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.hitch; ocspDir = lib.optionalString cfg.ocsp-stapling.enabled "/var/cache/hitch/ocsp"; - hitchConfig = with lib; pkgs.writeText "hitch.conf" (concatStringsSep "\n" [ - ("backend = \"${cfg.backend}\"") - (concatMapStrings (s: "frontend = \"${s}\"\n") cfg.frontend) - (concatMapStrings (s: "pem-file = \"${s}\"\n") cfg.pem-files) - ("ciphers = \"${cfg.ciphers}\"") - ("ocsp-dir = \"${ocspDir}\"") - "user = \"${cfg.user}\"" - "group = \"${cfg.group}\"" - cfg.extraConfig - ]); + hitchConfig = + with lib; + pkgs.writeText "hitch.conf" ( + concatStringsSep "\n" [ + ("backend = \"${cfg.backend}\"") + (concatMapStrings (s: "frontend = \"${s}\"\n") cfg.frontend) + (concatMapStrings (s: "pem-file = \"${s}\"\n") cfg.pem-files) + ("ciphers = \"${cfg.ciphers}\"") + ("ocsp-dir = \"${ocspDir}\"") + "user = \"${cfg.user}\"" + "group = \"${cfg.group}\"" + cfg.extraConfig + ] + ); in with lib; { @@ -45,7 +54,7 @@ with lib; pem-files = mkOption { type = types.listOf types.path; - default = []; + default = [ ]; description = "PEM files to use"; }; @@ -84,12 +93,14 @@ with lib; description = "Hitch"; wantedBy = [ "multi-user.target" ]; after = [ "network.target" ]; - preStart = '' - ${pkgs.hitch}/sbin/hitch -t --config ${hitchConfig} - '' + (optionalString cfg.ocsp-stapling.enabled '' - mkdir -p ${ocspDir} - chown -R hitch:hitch ${ocspDir} - ''); + preStart = + '' + ${pkgs.hitch}/sbin/hitch -t --config ${hitchConfig} + '' + + (optionalString cfg.ocsp-stapling.enabled '' + mkdir -p ${ocspDir} + chown -R hitch:hitch ${ocspDir} + ''); serviceConfig = { Type = "forking"; ExecStart = "${pkgs.hitch}/sbin/hitch --daemon --config ${hitchConfig}"; @@ -106,6 +117,6 @@ with lib; group = "hitch"; isSystemUser = true; }; - users.groups.hitch = {}; + users.groups.hitch = { }; }; } diff --git a/nixos/modules/services/web-servers/jboss/default.nix b/nixos/modules/services/web-servers/jboss/default.nix index d243e0f3f1b787..88bd1071b35bc6 100644 --- a/nixos/modules/services/web-servers/jboss/default.nix +++ b/nixos/modules/services/web-servers/jboss/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -10,7 +15,15 @@ let name = "jboss-server"; builder = ./builder.sh; inherit (pkgs) jboss su; - inherit (cfg) tempDir logDir libUrl deployDir serverDir user useJK; + inherit (cfg) + tempDir + logDir + libUrl + deployDir + serverDir + user + useJK + ; }; in @@ -75,7 +88,6 @@ in }; - ###### implementation config = mkIf config.services.jboss.enable { diff --git a/nixos/modules/services/web-servers/keter/bundle.nix b/nixos/modules/services/web-servers/keter/bundle.nix index 32b08c3be206b6..fd040b9847fb0c 100644 --- a/nixos/modules/services/web-servers/keter/bundle.nix +++ b/nixos/modules/services/web-servers/keter/bundle.nix @@ -1,25 +1,31 @@ -/* This makes a keter bundle as described on the github page: +/* + This makes a keter bundle as described on the github page: https://github.com/snoyberg/keter#bundling-your-app-for-keter */ -{ keterDomain -, keterExecutable -, gnutar -, writeTextFile -, lib -, stdenv -, ... +{ + keterDomain, + keterExecutable, + gnutar, + writeTextFile, + lib, + stdenv, + ... }: let - str.stanzas = [{ - # we just use nix as an absolute path so we're not bundling any binaries - type = "webapp"; - /* Note that we're not actually putting the executable in the bundle, - we already can use the nix store for copying, so we just - symlink to the app. */ - exec = keterExecutable; - host = keterDomain; - }]; + str.stanzas = [ + { + # we just use nix as an absolute path so we're not bundling any binaries + type = "webapp"; + /* + Note that we're not actually putting the executable in the bundle, + we already can use the nix store for copying, so we just + symlink to the app. + */ + exec = keterExecutable; + host = keterDomain; + } + ]; configFile = writeTextFile { name = "keter.yml"; text = (lib.generators.toYAML { } str); diff --git a/nixos/modules/services/web-servers/keter/default.nix b/nixos/modules/services/web-servers/keter/default.nix index 8685953d6e9d54..515d44f7ee5b43 100644 --- a/nixos/modules/services/web-servers/keter/default.nix +++ b/nixos/modules/services/web-servers/keter/default.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.services.keter; yaml = pkgs.formats.yaml { }; @@ -14,10 +19,11 @@ in ]; options.services.keter = { - enable = lib.mkEnableOption ''keter, a web app deployment manager. -Note that this module only support loading of webapps: -Keep an old app running and swap the ports when the new one is booted -''; + enable = lib.mkEnableOption '' + keter, a web app deployment manager. + Note that this module only support loading of webapps: + Keep an old app running and swap the ports when the new one is booted + ''; root = lib.mkOption { type = lib.types.str; @@ -32,7 +38,6 @@ Keep an old app running and swap the ports when the new one is booted description = "The keter package to be used"; }; - globalKeterConfig = lib.mkOption { type = lib.types.submodule { freeformType = yaml.type; @@ -43,19 +48,26 @@ Keep an old app running and swap the ports when the new one is booted description = "You want that ip-from-header in the nginx setup case. It allows nginx setting the original ip address rather then it being localhost (due to reverse proxying)"; }; listeners = lib.mkOption { - default = [{ host = "*"; port = 6981; }]; - type = lib.types.listOf (lib.types.submodule { - options = { - host = lib.mkOption { - type = lib.types.str; - description = "host"; - }; - port = lib.mkOption { - type = lib.types.port; - description = "port"; + default = [ + { + host = "*"; + port = 6981; + } + ]; + type = lib.types.listOf ( + lib.types.submodule { + options = { + host = lib.mkOption { + type = lib.types.str; + description = "host"; + }; + port = lib.mkOption { + type = lib.types.port; + description = "port"; + }; }; - }; - }); + } + ); description = '' You want that ip-from-header in the nginx setup case. @@ -121,15 +133,19 @@ Keep an old app running and swap the ports when the new one is booted let incoming = "${cfg.root}/incoming"; - globalKeterConfigFile = pkgs.writeTextFile { name = "keter-config.yml"; text = (lib.generators.toYAML { } (cfg.globalKeterConfig // { root = cfg.root; })); }; # If things are expected to change often, put it in the bundle! - bundle = pkgs.callPackage ./bundle.nix - (cfg.bundle // { keterExecutable = executable; keterDomain = cfg.bundle.domain; }); + bundle = pkgs.callPackage ./bundle.nix ( + cfg.bundle + // { + keterExecutable = executable; + keterDomain = cfg.bundle.domain; + } + ); # This indirection is required to ensure the nix path # gets copied over to the target machine in remote deployments. @@ -153,7 +169,10 @@ Keep an old app running and swap the ports when the new one is booted mkdir -p ${incoming} ${lib.getExe cfg.package} ${globalKeterConfigFile}; ''; - wantedBy = [ "multi-user.target" "nginx.service" ]; + wantedBy = [ + "multi-user.target" + "nginx.service" + ]; serviceConfig = { Restart = "always"; diff --git a/nixos/modules/services/web-servers/lighttpd/cgit.nix b/nixos/modules/services/web-servers/lighttpd/cgit.nix index b825d4757b8c1b..fed636f62fa5bb 100644 --- a/nixos/modules/services/web-servers/lighttpd/cgit.nix +++ b/nixos/modules/services/web-servers/lighttpd/cgit.nix @@ -1,20 +1,24 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.lighttpd.cgit; pathPrefix = optionalString (stringLength cfg.subdir != 0) ("/" + cfg.subdir); - configFile = pkgs.writeText "cgitrc" - '' - # default paths to static assets - css=${pathPrefix}/cgit.css - logo=${pathPrefix}/cgit.png - favicon=${pathPrefix}/favicon.ico + configFile = pkgs.writeText "cgitrc" '' + # default paths to static assets + css=${pathPrefix}/cgit.css + logo=${pathPrefix}/cgit.png + favicon=${pathPrefix}/favicon.ico - # user configuration - ${cfg.configText} - ''; + # user configuration + ${cfg.configText} + ''; in { @@ -65,7 +69,11 @@ in environment.systemPackages = [ pkgs.cgit ]; # declare module dependencies - services.lighttpd.enableModules = [ "mod_cgi" "mod_alias" "mod_setenv" ]; + services.lighttpd.enableModules = [ + "mod_cgi" + "mod_alias" + "mod_setenv" + ]; services.lighttpd.extraConfig = '' $HTTP["url"] =~ "^/${cfg.subdir}" { diff --git a/nixos/modules/services/web-servers/lighttpd/collectd.nix b/nixos/modules/services/web-servers/lighttpd/collectd.nix index 5e5c0adda1c262..c34bb2c3706dd1 100644 --- a/nixos/modules/services/web-servers/lighttpd/collectd.nix +++ b/nixos/modules/services/web-servers/lighttpd/collectd.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with lib; @@ -11,7 +17,7 @@ let libdir: "${config.services.collectd.package}/lib/collectd" ''; - defaultCollectionCgi = config.services.collectd.package.overrideDerivation(old: { + defaultCollectionCgi = config.services.collectd.package.overrideDerivation (old: { name = "collection.cgi"; dontConfigure = true; buildPhase = "true"; @@ -41,7 +47,11 @@ in }; config = mkIf cfg.enable { - services.lighttpd.enableModules = [ "mod_cgi" "mod_alias" "mod_setenv" ]; + services.lighttpd.enableModules = [ + "mod_cgi" + "mod_alias" + "mod_setenv" + ]; services.lighttpd.extraConfig = '' $HTTP["url"] =~ "^/collectd" { @@ -52,7 +62,15 @@ in "/collectd" => "${cfg.collectionCgi}" ) setenv.add-environment = ( - "PERL5LIB" => "${with pkgs.perlPackages; makePerlPath [ CGI HTMLParser URI pkgs.rrdtool ]}", + "PERL5LIB" => "${ + with pkgs.perlPackages; + makePerlPath [ + CGI + HTMLParser + URI + pkgs.rrdtool + ] + }", "COLLECTION_CONF" => "${collectionConf}" ) } diff --git a/nixos/modules/services/web-servers/lighttpd/default.nix b/nixos/modules/services/web-servers/lighttpd/default.nix index ea5ad835f3ab5d..c79d32be2c46fe 100644 --- a/nixos/modules/services/web-servers/lighttpd/default.nix +++ b/nixos/modules/services/web-servers/lighttpd/default.nix @@ -1,6 +1,11 @@ # NixOS module for lighttpd web server -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -53,71 +58,73 @@ let "mod_geoip" "mod_magnet" "mod_mysql_vhost" - "mod_openssl" # since v1.4.46 + "mod_openssl" # since v1.4.46 "mod_scgi" "mod_setenv" "mod_trigger_b4_dl" "mod_uploadprogress" - "mod_vhostdb" # since v1.4.46 + "mod_vhostdb" # since v1.4.46 "mod_webdav" - "mod_wstunnel" # since v1.4.46 + "mod_wstunnel" # since v1.4.46 ]; - maybeModuleString = moduleName: - optionalString (elem moduleName cfg.enableModules) ''"${moduleName}"''; + maybeModuleString = + moduleName: optionalString (elem moduleName cfg.enableModules) ''"${moduleName}"''; - modulesIncludeString = concatStringsSep ",\n" - (filter (x: x != "") (map maybeModuleString allKnownModules)); + modulesIncludeString = concatStringsSep ",\n" ( + filter (x: x != "") (map maybeModuleString allKnownModules) + ); - configFile = if cfg.configText != "" then - pkgs.writeText "lighttpd.conf" '' - ${cfg.configText} - '' + configFile = + if cfg.configText != "" then + pkgs.writeText "lighttpd.conf" '' + ${cfg.configText} + '' else - pkgs.writeText "lighttpd.conf" '' - server.document-root = "${cfg.document-root}" - server.port = ${toString cfg.port} - server.username = "lighttpd" - server.groupname = "lighttpd" - - # As for why all modules are loaded here, instead of having small - # server.modules += () entries in each sub-service extraConfig snippet, - # read this: - # - # https://redmine.lighttpd.net/projects/1/wiki/Server_modulesDetails - # https://redmine.lighttpd.net/issues/2337 - # - # Basically, lighttpd doesn't want to load (or even silently ignore) a - # module for a second time, and there is no way to check if a module has - # been loaded already. So if two services were to put the same module in - # server.modules += (), that would break the lighttpd configuration. - server.modules = ( - ${modulesIncludeString} - ) - - # Logging (logs end up in systemd journal) - accesslog.use-syslog = "enable" - server.errorlog-use-syslog = "enable" - - ${lib.optionalString cfg.enableUpstreamMimeTypes '' - include "${pkgs.lighttpd}/share/lighttpd/doc/config/conf.d/mime.conf" - ''} - - static-file.exclude-extensions = ( ".fcgi", ".php", ".rb", "~", ".inc" ) - index-file.names = ( "index.html" ) - - ${optionalString cfg.mod_userdir '' - userdir.path = "public_html" - ''} - - ${optionalString cfg.mod_status '' - status.status-url = "/server-status" - status.statistics-url = "/server-statistics" - status.config-url = "/server-config" - ''} - - ${cfg.extraConfig} - ''; + pkgs.writeText "lighttpd.conf" '' + server.document-root = "${cfg.document-root}" + server.port = ${toString cfg.port} + server.username = "lighttpd" + server.groupname = "lighttpd" + + # As for why all modules are loaded here, instead of having small + # server.modules += () entries in each sub-service extraConfig snippet, + # read this: + # + # https://redmine.lighttpd.net/projects/1/wiki/Server_modulesDetails + # https://redmine.lighttpd.net/issues/2337 + # + # Basically, lighttpd doesn't want to load (or even silently ignore) a + # module for a second time, and there is no way to check if a module has + # been loaded already. So if two services were to put the same module in + # server.modules += (), that would break the lighttpd configuration. + server.modules = ( + ${modulesIncludeString} + ) + + # Logging (logs end up in systemd journal) + accesslog.use-syslog = "enable" + server.errorlog-use-syslog = "enable" + + ${lib.optionalString cfg.enableUpstreamMimeTypes '' + include "${pkgs.lighttpd}/share/lighttpd/doc/config/conf.d/mime.conf" + ''} + + static-file.exclude-extensions = ( ".fcgi", ".php", ".rb", "~", ".inc" ) + index-file.names = ( "index.html" ) + + ${optionalString cfg.mod_userdir '' + userdir.path = "public_html" + ''} + + ${optionalString cfg.mod_status '' + status.status-url = "/server-status" + status.statistics-url = "/server-statistics" + status.config-url = "/server-config" + ''} + + ${cfg.extraConfig} + ''; in @@ -165,7 +172,10 @@ in enableModules = mkOption { type = types.listOf types.str; default = [ ]; - example = [ "mod_cgi" "mod_status" ]; + example = [ + "mod_cgi" + "mod_status" + ]; description = '' List of lighttpd modules to enable. Sub-services take care of enabling modules as needed, so this option is mainly for when you @@ -222,7 +232,8 @@ in config = mkIf cfg.enable { assertions = [ - { assertion = all (x: elem x allKnownModules) cfg.enableModules; + { + assertion = all (x: elem x allKnownModules) cfg.enableModules; message = '' One (or more) modules in services.lighttpd.enableModules are unrecognized. @@ -234,12 +245,12 @@ in } ]; - services.lighttpd.enableModules = mkMerge - [ (mkIf cfg.mod_status [ "mod_status" ]) - (mkIf cfg.mod_userdir [ "mod_userdir" ]) - # always load mod_accesslog so that we can log to the journal - [ "mod_accesslog" ] - ]; + services.lighttpd.enableModules = mkMerge [ + (mkIf cfg.mod_status [ "mod_status" ]) + (mkIf cfg.mod_userdir [ "mod_userdir" ]) + # always load mod_accesslog so that we can log to the journal + [ "mod_accesslog" ] + ]; systemd.services.lighttpd = { description = "Lighttpd Web Server"; diff --git a/nixos/modules/services/web-servers/lighttpd/gitweb.nix b/nixos/modules/services/web-servers/lighttpd/gitweb.nix index c494d6966a7f58..0b138bc5c26a86 100644 --- a/nixos/modules/services/web-servers/lighttpd/gitweb.nix +++ b/nixos/modules/services/web-servers/lighttpd/gitweb.nix @@ -1,12 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.gitweb; - package = pkgs.gitweb.override (optionalAttrs cfg.gitwebTheme { - gitwebTheme = true; - }); + package = pkgs.gitweb.override ( + optionalAttrs cfg.gitwebTheme { + gitwebTheme = true; + } + ); in { @@ -26,7 +33,12 @@ in config = mkIf config.services.lighttpd.gitweb.enable { # declare module dependencies - services.lighttpd.enableModules = [ "mod_cgi" "mod_redirect" "mod_alias" "mod_setenv" ]; + services.lighttpd.enableModules = [ + "mod_cgi" + "mod_redirect" + "mod_alias" + "mod_setenv" + ]; services.lighttpd.extraConfig = '' $HTTP["url"] =~ "^/gitweb" { diff --git a/nixos/modules/services/web-servers/merecat.nix b/nixos/modules/services/web-servers/merecat.nix index ff65480a0f2d61..a669acaedb7e33 100644 --- a/nixos/modules/services/web-servers/merecat.nix +++ b/nixos/modules/services/web-servers/merecat.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,16 +11,16 @@ let cfg = config.services.merecat; format = pkgs.formats.keyValue { mkKeyValue = generators.mkKeyValueDefault { - mkValueString = v: + mkValueString = + v: # In merecat.conf, booleans are "true" and "false" - if builtins.isBool v - then if v then "true" else "false" - else generators.mkValueStringDefault {} v; + if builtins.isBool v then if v then "true" else "false" else generators.mkValueStringDefault { } v; } "="; }; configFile = format.generate "merecat.conf" cfg.settings; -in { +in +{ options.services.merecat = { diff --git a/nixos/modules/services/web-servers/mighttpd2.nix b/nixos/modules/services/web-servers/mighttpd2.nix index 11626967514443..3e2f61c170fabd 100644 --- a/nixos/modules/services/web-servers/mighttpd2.nix +++ b/nixos/modules/services/web-servers/mighttpd2.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,7 +11,8 @@ let cfg = config.services.mighttpd2; configFile = pkgs.writeText "mighty-config" cfg.config; routingFile = pkgs.writeText "mighty-routing" cfg.routing; -in { +in +{ options.services.mighttpd2 = { enable = mkEnableOption "Mighttpd2 web server"; @@ -94,11 +100,12 @@ in { }; config = mkIf cfg.enable { - assertions = - [ { assertion = cfg.routing != ""; - message = "You need at least one rule in mighttpd2.routing"; - } - ]; + assertions = [ + { + assertion = cfg.routing != ""; + message = "You need at least one rule in mighttpd2.routing"; + } + ]; systemd.services.mighttpd2 = { description = "Mighttpd2 web server"; wants = [ "network-online.target" ]; diff --git a/nixos/modules/services/web-servers/molly-brown.nix b/nixos/modules/services/web-servers/molly-brown.nix index f4aa98cde95928..153ace5a1aa435 100644 --- a/nixos/modules/services/web-servers/molly-brown.nix +++ b/nixos/modules/services/web-servers/molly-brown.nix @@ -1,12 +1,18 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.molly-brown; settingsFormat = pkgs.formats.toml { }; - configFile = settingsFormat.generate "molly-brown.toml" cfg.settings; -in { + configFile = settingsFormat.generate "molly-brown.toml" cfg.settings; +in +{ options.services.molly-brown = { @@ -73,16 +79,19 @@ in { config = mkIf cfg.enable { - services.molly-brown.settings = let logDir = "/var/log/molly-brown"; - in { - Port = cfg.port; - Hostname = cfg.hostName; - CertPath = cfg.certPath; - KeyPath = cfg.keyPath; - DocBase = cfg.docBase; - AccessLog = "${logDir}/access.log"; - ErrorLog = "${logDir}/error.log"; - }; + services.molly-brown.settings = + let + logDir = "/var/log/molly-brown"; + in + { + Port = cfg.port; + Hostname = cfg.hostName; + CertPath = cfg.certPath; + KeyPath = cfg.keyPath; + DocBase = cfg.docBase; + AccessLog = "${logDir}/access.log"; + ErrorLog = "${logDir}/error.log"; + }; systemd.services.molly-brown = { description = "Molly Brown gemini server"; diff --git a/nixos/modules/services/web-servers/nginx/gitweb.nix b/nixos/modules/services/web-servers/nginx/gitweb.nix index 81f794bf9b3f8c..c379245c5bff9d 100644 --- a/nixos/modules/services/web-servers/nginx/gitweb.nix +++ b/nixos/modules/services/web-servers/nginx/gitweb.nix @@ -1,13 +1,20 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.nginx.gitweb; gitwebConfig = config.services.gitweb; - package = pkgs.gitweb.override (optionalAttrs gitwebConfig.gitwebTheme { - gitwebTheme = true; - }); + package = pkgs.gitweb.override ( + optionalAttrs gitwebConfig.gitwebTheme { + gitwebTheme = true; + } + ); in { @@ -61,7 +68,7 @@ in systemd.services.gitweb = { description = "GitWeb service"; script = "${package}/gitweb.cgi --fastcgi --nproc=1"; - environment = { + environment = { FCGI_SOCKET_PATH = "/run/gitweb/gitweb.sock"; }; serviceConfig = { diff --git a/nixos/modules/services/web-servers/nginx/tailscale-auth.nix b/nixos/modules/services/web-servers/nginx/tailscale-auth.nix index de1d708cbb423f..7529e6258fd25d 100644 --- a/nixos/modules/services/web-servers/nginx/tailscale-auth.nix +++ b/nixos/modules/services/web-servers/nginx/tailscale-auth.nix @@ -15,10 +15,22 @@ let in { imports = [ - (mkAliasOptionModule [ "services" "nginx" "tailscaleAuth" "package" ] [ "services" "tailscaleAuth" "package" ]) - (mkAliasOptionModule [ "services" "nginx" "tailscaleAuth" "user" ] [ "services" "tailscaleAuth" "user" ]) - (mkAliasOptionModule [ "services" "nginx" "tailscaleAuth" "group" ] [ "services" "tailscaleAuth" "group" ]) - (mkAliasOptionModule [ "services" "nginx" "tailscaleAuth" "socketPath" ] [ "services" "tailscaleAuth" "socketPath" ]) + (mkAliasOptionModule + [ "services" "nginx" "tailscaleAuth" "package" ] + [ "services" "tailscaleAuth" "package" ] + ) + (mkAliasOptionModule + [ "services" "nginx" "tailscaleAuth" "user" ] + [ "services" "tailscaleAuth" "user" ] + ) + (mkAliasOptionModule + [ "services" "nginx" "tailscaleAuth" "group" ] + [ "services" "tailscaleAuth" "group" ] + ) + (mkAliasOptionModule + [ "services" "nginx" "tailscaleAuth" "socketPath" ] + [ "services" "tailscaleAuth" "socketPath" ] + ) ]; options.services.nginx.tailscaleAuth = { @@ -36,7 +48,7 @@ in virtualHosts = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = '' A list of nginx virtual hosts to put behind tailscale.nginx-auth ''; @@ -54,43 +66,43 @@ in wants = [ "nginx.service" ]; }; - services.nginx.virtualHosts = genAttrs - cfg.virtualHosts - (vhost: { - locations."/auth" = { - extraConfig = '' - internal; + services.nginx.virtualHosts = genAttrs cfg.virtualHosts (vhost: { + locations."/auth" = { + extraConfig = '' + internal; - proxy_pass http://unix:${cfgAuth.socketPath}; - proxy_pass_request_body off; + proxy_pass http://unix:${cfgAuth.socketPath}; + proxy_pass_request_body off; - # Upstream uses $http_host here, but we are using gixy to check nginx configurations - # gixy wants us to use $host: https://github.com/yandex/gixy/blob/master/docs/en/plugins/hostspoofing.md - proxy_set_header Host $host; - proxy_set_header Remote-Addr $remote_addr; - proxy_set_header Remote-Port $remote_port; - proxy_set_header Original-URI $request_uri; - proxy_set_header X-Scheme $scheme; - proxy_set_header X-Auth-Request-Redirect $scheme://$host$request_uri; - ''; - }; - locations."/".extraConfig = '' - auth_request /auth; - auth_request_set $auth_user $upstream_http_tailscale_user; - auth_request_set $auth_name $upstream_http_tailscale_name; - auth_request_set $auth_login $upstream_http_tailscale_login; - auth_request_set $auth_tailnet $upstream_http_tailscale_tailnet; - auth_request_set $auth_profile_picture $upstream_http_tailscale_profile_picture; + # Upstream uses $http_host here, but we are using gixy to check nginx configurations + # gixy wants us to use $host: https://github.com/yandex/gixy/blob/master/docs/en/plugins/hostspoofing.md + proxy_set_header Host $host; + proxy_set_header Remote-Addr $remote_addr; + proxy_set_header Remote-Port $remote_port; + proxy_set_header Original-URI $request_uri; + proxy_set_header X-Scheme $scheme; + proxy_set_header X-Auth-Request-Redirect $scheme://$host$request_uri; + ''; + }; + locations."/".extraConfig = '' + auth_request /auth; + auth_request_set $auth_user $upstream_http_tailscale_user; + auth_request_set $auth_name $upstream_http_tailscale_name; + auth_request_set $auth_login $upstream_http_tailscale_login; + auth_request_set $auth_tailnet $upstream_http_tailscale_tailnet; + auth_request_set $auth_profile_picture $upstream_http_tailscale_profile_picture; - proxy_set_header X-Webauth-User "$auth_user"; - proxy_set_header X-Webauth-Name "$auth_name"; - proxy_set_header X-Webauth-Login "$auth_login"; - proxy_set_header X-Webauth-Tailnet "$auth_tailnet"; - proxy_set_header X-Webauth-Profile-Picture "$auth_profile_picture"; + proxy_set_header X-Webauth-User "$auth_user"; + proxy_set_header X-Webauth-Name "$auth_name"; + proxy_set_header X-Webauth-Login "$auth_login"; + proxy_set_header X-Webauth-Tailnet "$auth_tailnet"; + proxy_set_header X-Webauth-Profile-Picture "$auth_profile_picture"; - ${lib.optionalString (cfg.expectedTailnet != "") ''proxy_set_header Expected-Tailnet "${cfg.expectedTailnet}";''} - ''; - }); + ${lib.optionalString ( + cfg.expectedTailnet != "" + ) ''proxy_set_header Expected-Tailnet "${cfg.expectedTailnet}";''} + ''; + }); }; meta.maintainers = with maintainers; [ phaer ]; diff --git a/nixos/modules/services/web-servers/rustus.nix b/nixos/modules/services/web-servers/rustus.nix index b356133df085db..9ca87bb16bf3b6 100644 --- a/nixos/modules/services/web-servers/rustus.nix +++ b/nixos/modules/services/web-servers/rustus.nix @@ -1,4 +1,9 @@ -{ lib, pkgs, config, ... }: +{ + lib, + pkgs, + config, + ... +}: with lib; let cfg = config.services.rustus; @@ -29,7 +34,11 @@ in }; log_level = mkOption { - type = types.enum [ "DEBUG" "INFO" "ERROR" ]; + type = types.enum [ + "DEBUG" + "INFO" + "ERROR" + ]; description = '' Desired log level ''; @@ -67,20 +76,25 @@ in description = '' list of origins allowed to upload ''; - default = ["*"]; - example = ["*.staging.domain" "*.prod.domain"]; + default = [ "*" ]; + example = [ + "*.staging.domain" + "*.prod.domain" + ]; }; tus_extensions = mkOption { - type = types.listOf (types.enum [ - "getting" - "creation" - "termination" - "creation-with-upload" - "creation-defer-length" - "concatenation" - "checksum" - ]); + type = types.listOf ( + types.enum [ + "getting" + "creation" + "termination" + "creation-with-upload" + "creation-defer-length" + "concatenation" + "checksum" + ] + ); description = '' Since TUS protocol offers extensibility you can turn off some protocol extensions. ''; @@ -108,7 +122,7 @@ in description = '' Storages are used to actually store your files. You can configure where you want to store files. ''; - default = {}; + default = { }; example = lib.literalExpression '' { type = "hybrid-s3" @@ -121,7 +135,10 @@ in type = lib.types.submodule { options = { type = lib.mkOption { - type = lib.types.enum ["file-storage" "hybrid-s3"]; + type = lib.types.enum [ + "file-storage" + "hybrid-s3" + ]; description = "Type of storage to use"; }; s3_access_key_file = lib.mkOption { @@ -169,11 +186,11 @@ in description = '' Info storages are used to store information about file uploads. These storages must be persistent, because every time chunk is uploaded rustus updates information about upload. And when someone wants to download file, information about it requested from storage to get actual path of an upload. ''; - default = {}; + default = { }; type = lib.types.submodule { options = { type = lib.mkOption { - type = lib.types.enum ["file-info-storage"]; + type = lib.types.enum [ "file-info-storage" ]; description = "Type of info storage to use"; default = "file-info-storage"; }; @@ -193,64 +210,64 @@ in let isHybridS3 = cfg.storage.type == "hybrid-s3"; in - { - description = "Rustus server"; - documentation = [ "https://s3rius.github.io/rustus/" ]; + { + description = "Rustus server"; + documentation = [ "https://s3rius.github.io/rustus/" ]; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; - environment = { - RUSTUS_SERVER_HOST = cfg.host; - RUSTUS_SERVER_PORT = toString cfg.port; - RUSTUS_LOG_LEVEL = cfg.log_level; - RUSTUS_MAX_BODY_SIZE = cfg.max_body_size; - RUSTUS_URL = cfg.url; - RUSTUS_DISABLE_HEALTH_ACCESS_LOG = lib.mkIf cfg.disable_health_access_logs "true"; - RUSTUS_CORS = lib.concatStringsSep "," cfg.cors; - RUSTUS_TUS_EXTENSIONS = lib.concatStringsSep "," cfg.tus_extensions; - RUSTUS_REMOVE_PARTS= if cfg.remove_parts then "true" else "false"; - RUSTUS_STORAGE = cfg.storage.type; - RUSTUS_DATA_DIR = cfg.storage.data_dir; - RUSTUS_DIR_STRUCTURE = cfg.storage.dir_structure; - RUSTUS_FORCE_FSYNC = if cfg.storage.force_sync then "true" else "false"; - RUSTUS_S3_URL = mkIf isHybridS3 cfg.storage.s3_url; - RUSTUS_S3_BUCKET = mkIf isHybridS3 cfg.storage.s3_bucket; - RUSTUS_S3_REGION = mkIf isHybridS3 cfg.storage.s3_region; - RUSTUS_S3_ACCESS_KEY_PATH = mkIf isHybridS3 "%d/S3_ACCESS_KEY_PATH"; - RUSTUS_S3_SECRET_KEY_PATH = mkIf isHybridS3 "%d/S3_SECRET_KEY_PATH"; - RUSTUS_INFO_STORAGE = cfg.info_storage.type; - RUSTUS_INFO_DIR = cfg.info_storage.dir; - }; + environment = { + RUSTUS_SERVER_HOST = cfg.host; + RUSTUS_SERVER_PORT = toString cfg.port; + RUSTUS_LOG_LEVEL = cfg.log_level; + RUSTUS_MAX_BODY_SIZE = cfg.max_body_size; + RUSTUS_URL = cfg.url; + RUSTUS_DISABLE_HEALTH_ACCESS_LOG = lib.mkIf cfg.disable_health_access_logs "true"; + RUSTUS_CORS = lib.concatStringsSep "," cfg.cors; + RUSTUS_TUS_EXTENSIONS = lib.concatStringsSep "," cfg.tus_extensions; + RUSTUS_REMOVE_PARTS = if cfg.remove_parts then "true" else "false"; + RUSTUS_STORAGE = cfg.storage.type; + RUSTUS_DATA_DIR = cfg.storage.data_dir; + RUSTUS_DIR_STRUCTURE = cfg.storage.dir_structure; + RUSTUS_FORCE_FSYNC = if cfg.storage.force_sync then "true" else "false"; + RUSTUS_S3_URL = mkIf isHybridS3 cfg.storage.s3_url; + RUSTUS_S3_BUCKET = mkIf isHybridS3 cfg.storage.s3_bucket; + RUSTUS_S3_REGION = mkIf isHybridS3 cfg.storage.s3_region; + RUSTUS_S3_ACCESS_KEY_PATH = mkIf isHybridS3 "%d/S3_ACCESS_KEY_PATH"; + RUSTUS_S3_SECRET_KEY_PATH = mkIf isHybridS3 "%d/S3_SECRET_KEY_PATH"; + RUSTUS_INFO_STORAGE = cfg.info_storage.type; + RUSTUS_INFO_DIR = cfg.info_storage.dir; + }; - serviceConfig = { - ExecStart = "${pkgs.rustus}/bin/rustus"; - StateDirectory = "rustus"; - # User name is defined here to enable restoring a backup for example - # You will run the backup restore command as sudo -u rustus in order - # to have write permissions to /var/lib - User = "rustus"; - DynamicUser = true; - LoadCredential = lib.optionals isHybridS3 [ - "S3_ACCESS_KEY_PATH:${cfg.storage.s3_access_key_file}" - "S3_SECRET_KEY_PATH:${cfg.storage.s3_secret_key_file}" - ]; - # hardening - RestrictRealtime=true; - RestrictNamespaces=true; - LockPersonality=true; - ProtectKernelModules=true; - ProtectKernelTunables=true; - ProtectKernelLogs=true; - ProtectControlGroups=true; - ProtectHostUserNamespaces=true; - ProtectClock=true; - RestrictSUIDSGID=true; - SystemCallArchitectures="native"; - CapabilityBoundingSet=""; - ProtectProc = "invisible"; - # TODO consider SystemCallFilter LimitAS ProcSubset + serviceConfig = { + ExecStart = "${pkgs.rustus}/bin/rustus"; + StateDirectory = "rustus"; + # User name is defined here to enable restoring a backup for example + # You will run the backup restore command as sudo -u rustus in order + # to have write permissions to /var/lib + User = "rustus"; + DynamicUser = true; + LoadCredential = lib.optionals isHybridS3 [ + "S3_ACCESS_KEY_PATH:${cfg.storage.s3_access_key_file}" + "S3_SECRET_KEY_PATH:${cfg.storage.s3_secret_key_file}" + ]; + # hardening + RestrictRealtime = true; + RestrictNamespaces = true; + LockPersonality = true; + ProtectKernelModules = true; + ProtectKernelTunables = true; + ProtectKernelLogs = true; + ProtectControlGroups = true; + ProtectHostUserNamespaces = true; + ProtectClock = true; + RestrictSUIDSGID = true; + SystemCallArchitectures = "native"; + CapabilityBoundingSet = ""; + ProtectProc = "invisible"; + # TODO consider SystemCallFilter LimitAS ProcSubset + }; }; - }; }; } diff --git a/nixos/modules/services/web-servers/stargazer.nix b/nixos/modules/services/web-servers/stargazer.nix index 249fd30bf6001f..32feaf0337e7ee 100644 --- a/nixos/modules/services/web-servers/stargazer.nix +++ b/nixos/modules/services/web-servers/stargazer.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.stargazer; @@ -19,18 +24,22 @@ let ''; genINI = lib.generators.toINI { }; - configFile = pkgs.writeText "config.ini" (lib.strings.concatStrings ( - [ globalSection ] ++ (lib.lists.forEach cfg.routes (section: - let - name = section.route; - params = builtins.removeAttrs section [ "route" ]; - in - genINI - { + configFile = pkgs.writeText "config.ini" ( + lib.strings.concatStrings ( + [ globalSection ] + ++ (lib.lists.forEach cfg.routes ( + section: + let + name = section.route; + params = builtins.removeAttrs section [ "route" ]; + in + genINI { "${name}" = params; - } + "\n" - )) - )); + } + + "\n" + )) + ) + ); in { options.services.stargazer = { @@ -151,22 +160,27 @@ in }; routes = lib.mkOption { - type = lib.types.listOf - (lib.types.submodule { - freeformType = with lib.types; attrsOf (nullOr - (oneOf [ - bool - int - float - str - ]) // { - description = "INI atom (null, bool, int, float or string)"; - }); + type = lib.types.listOf ( + lib.types.submodule { + freeformType = + with lib.types; + attrsOf ( + nullOr (oneOf [ + bool + int + float + str + ]) + // { + description = "INI atom (null, bool, int, float or string)"; + } + ); options.route = lib.mkOption { type = lib.types.str; description = "Route section name"; }; - }); + } + ); default = [ ]; description = '' Routes that Stargazer should server. @@ -246,23 +260,26 @@ in LockPersonality = true; RestrictRealtime = true; RemoveIPC = true; - CapabilityBoundingSet = [ - "~CAP_SYS_PTRACE" - "~CAP_SYS_ADMIN" - "~CAP_SETPCAP" - "~CAP_SYS_TIME" - "~CAP_SYS_PACCT" - "~CAP_SYS_TTY_CONFIG " - "~CAP_SYS_CHROOT" - "~CAP_SYS_BOOT" - "~CAP_NET_ADMIN" - ] ++ lib.lists.optional (!cfg.allowCgiUser) [ - "~CAP_SETGID" - "~CAP_SETUID" - ]; + CapabilityBoundingSet = + [ + "~CAP_SYS_PTRACE" + "~CAP_SYS_ADMIN" + "~CAP_SETPCAP" + "~CAP_SYS_TIME" + "~CAP_SYS_PACCT" + "~CAP_SYS_TTY_CONFIG " + "~CAP_SYS_CHROOT" + "~CAP_SYS_BOOT" + "~CAP_NET_ADMIN" + ] + ++ lib.lists.optional (!cfg.allowCgiUser) [ + "~CAP_SETGID" + "~CAP_SETUID" + ]; SystemCallArchitectures = "native"; - SystemCallFilter = [ "~@cpu-emulation @debug @keyring @mount @obsolete" ] - ++ lib.lists.optional (!cfg.allowCgiUser) [ "@privileged @setuid" ]; + SystemCallFilter = [ + "~@cpu-emulation @debug @keyring @mount @obsolete" + ] ++ lib.lists.optional (!cfg.allowCgiUser) [ "@privileged @setuid" ]; }; }; diff --git a/nixos/modules/services/web-servers/static-web-server.nix b/nixos/modules/services/web-servers/static-web-server.nix index 9a80f141efcf0d..0db154167941da 100644 --- a/nixos/modules/services/web-servers/static-web-server.nix +++ b/nixos/modules/services/web-servers/static-web-server.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.static-web-server; - toml = pkgs.formats.toml {}; + toml = pkgs.formats.toml { }; configFilePath = toml.generate "config.toml" cfg.configuration; -in { +in +{ options = { services.static-web-server = { enable = lib.mkEnableOption ''Static Web Server''; @@ -28,7 +34,10 @@ in { default = { }; type = toml.type; example = { - general = { log-level = "error"; directory-listing = true; }; + general = { + log-level = "error"; + directory-listing = true; + }; }; description = '' Configuration for Static Web Server. See @@ -47,14 +56,20 @@ in { systemd.sockets.static-web-server = { wantedBy = [ "sockets.target" ]; # Start with empty string to reset upstream option - listenStreams = [ "" cfg.listen ]; + listenStreams = [ + "" + cfg.listen + ]; }; systemd.services.static-web-server = { wantedBy = [ "multi-user.target" ]; serviceConfig = { # Remove upstream sample environment file; use config.toml exclusively EnvironmentFile = [ "" ]; - ExecStart = [ "" "${pkgs.static-web-server}/bin/static-web-server --fd 0 --config-file ${configFilePath} --root ${cfg.root}" ]; + ExecStart = [ + "" + "${pkgs.static-web-server}/bin/static-web-server --fd 0 --config-file ${configFilePath} --root ${cfg.root}" + ]; # Supplementary groups doesn't work unless we create the group ourselves SupplementaryGroups = [ "" ]; # If the user is serving files from their home dir, override ProtectHome to allow that diff --git a/nixos/modules/services/web-servers/tomcat.nix b/nixos/modules/services/web-servers/tomcat.nix index 1c5a9af5c92452..2fffc7cd47db5a 100644 --- a/nixos/modules/services/web-servers/tomcat.nix +++ b/nixos/modules/services/web-servers/tomcat.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let @@ -8,7 +13,10 @@ in { meta = { - maintainers = with lib.maintainers; [ danbst anthonyroussel ]; + maintainers = with lib.maintainers; [ + danbst + anthonyroussel + ]; }; ###### interface @@ -130,27 +138,29 @@ in }; virtualHosts = lib.mkOption { - type = lib.types.listOf (lib.types.submodule { - options = { - name = lib.mkOption { - type = lib.types.str; - description = "name of the virtualhost"; - }; - aliases = lib.mkOption { - type = lib.types.listOf lib.types.str; - description = "aliases of the virtualhost"; - default = [ ]; - }; - webapps = lib.mkOption { - type = lib.types.listOf lib.types.path; - description = '' - List containing web application WAR files and/or directories containing - web applications and configuration files for the virtual host. - ''; - default = [ ]; + type = lib.types.listOf ( + lib.types.submodule { + options = { + name = lib.mkOption { + type = lib.types.str; + description = "name of the virtualhost"; + }; + aliases = lib.mkOption { + type = lib.types.listOf lib.types.str; + description = "aliases of the virtualhost"; + default = [ ]; + }; + webapps = lib.mkOption { + type = lib.types.listOf lib.types.path; + description = '' + List containing web application WAR files and/or directories containing + web applications and configuration files for the virtual host. + ''; + default = [ ]; + }; }; - }; - }); + } + ); default = [ ]; description = "List consisting of a virtual host name and a list of web applications to deploy on each virtual host"; }; @@ -181,14 +191,13 @@ in users.groups.tomcat.gid = config.ids.gids.tomcat; - users.users.tomcat = - { - uid = config.ids.uids.tomcat; - description = "Tomcat user"; - home = "/homeless-shelter"; - group = "tomcat"; - extraGroups = cfg.extraGroups; - }; + users.users.tomcat = { + uid = config.ids.uids.tomcat; + description = "Tomcat user"; + home = "/homeless-shelter"; + group = "tomcat"; + extraGroups = cfg.extraGroups; + }; systemd.services.tomcat = { description = "Apache Tomcat server"; @@ -219,7 +228,7 @@ in ln -sfn ${tomcat}/conf/$i ${cfg.baseDir}/conf/`basename $i` done - ${lib.optionalString (cfg.extraConfigFiles != []) '' + ${lib.optionalString (cfg.extraConfigFiles != [ ]) '' for i in ${toString cfg.extraConfigFiles}; do ln -sfn $i ${cfg.baseDir}/conf/`basename $i` done @@ -231,46 +240,59 @@ in -e 's|shared.loader=|shared.loader=''${catalina.base}/shared/lib/*.jar|' \ ${tomcat}/conf/catalina.properties > ${cfg.baseDir}/conf/catalina.properties - ${if cfg.serverXml != "" then '' - cp -f ${pkgs.writeTextDir "server.xml" cfg.serverXml}/* ${cfg.baseDir}/conf/ - '' else - let - hostElementForVirtualHost = virtualHost: '' - - '' + lib.concatStrings (innerElementsForVirtualHost virtualHost) + '' - - ''; - innerElementsForVirtualHost = virtualHost: - (map (alias: '' - ${alias} - '') virtualHost.aliases) - ++ (lib.optional cfg.logPerVirtualHost '' - - ''); - hostElementsString = lib.concatMapStringsSep "\n" hostElementForVirtualHost cfg.virtualHosts; - hostElementsSedString = lib.replaceStrings ["\n"] ["\\\n"] hostElementsString; - in '' - # Create a modified server.xml which listens on the given port, - # and also includes all virtual hosts. - # The host modification must be last here, - # else if hostElementsSedString is empty sed gets confused as to what to append - sed -e 's//a\\"${lib.escapeShellArg hostElementsSedString} \ - ${tomcat}/conf/server.xml > ${cfg.baseDir}/conf/server.xml - '' + ${ + if cfg.serverXml != "" then + '' + cp -f ${pkgs.writeTextDir "server.xml" cfg.serverXml}/* ${cfg.baseDir}/conf/ + '' + else + let + hostElementForVirtualHost = + virtualHost: + '' + + '' + + lib.concatStrings (innerElementsForVirtualHost virtualHost) + + '' + + ''; + innerElementsForVirtualHost = + virtualHost: + (map (alias: '' + ${alias} + '') virtualHost.aliases) + ++ (lib.optional cfg.logPerVirtualHost '' + + ''); + hostElementsString = lib.concatMapStringsSep "\n" hostElementForVirtualHost cfg.virtualHosts; + hostElementsSedString = lib.replaceStrings [ "\n" ] [ "\\\n" ] hostElementsString; + in + '' + # Create a modified server.xml which listens on the given port, + # and also includes all virtual hosts. + # The host modification must be last here, + # else if hostElementsSedString is empty sed gets confused as to what to append + sed -e 's//a\\"${lib.escapeShellArg hostElementsSedString} \ + ${tomcat}/conf/server.xml > ${cfg.baseDir}/conf/server.xml + '' } - ${lib.optionalString (cfg.logDirs != []) '' + ${lib.optionalString (cfg.logDirs != [ ]) '' for i in ${toString cfg.logDirs}; do mkdir -p ${cfg.baseDir}/logs/$i chown ${cfg.user}:${cfg.group} ${cfg.baseDir}/logs/$i done ''} - ${lib.optionalString cfg.logPerVirtualHost (toString (map (h: '' - mkdir -p ${cfg.baseDir}/logs/${h.name} - chown ${cfg.user}:${cfg.group} ${cfg.baseDir}/logs/${h.name} - '') cfg.virtualHosts))} + ${lib.optionalString cfg.logPerVirtualHost ( + toString ( + map (h: '' + mkdir -p ${cfg.baseDir}/logs/${h.name} + chown ${cfg.user}:${cfg.group} ${cfg.baseDir}/logs/${h.name} + '') cfg.virtualHosts + ) + )} # Symlink all the given common libs files or paths into the lib/ directory for i in ${tomcat} ${toString cfg.commonLibs}; do @@ -325,37 +347,39 @@ in fi done - ${toString (map (virtualHost: '' - # Create webapps directory for the virtual host - mkdir -p ${cfg.baseDir}/virtualhosts/${virtualHost.name}/webapps - - # Modify ownership - chown ${cfg.user}:${cfg.group} ${cfg.baseDir}/virtualhosts/${virtualHost.name}/webapps - - # Symlink all the given web applications files or paths into the webapps/ directory - # of this virtual host - for i in "${lib.optionalString (virtualHost ? webapps) (toString virtualHost.webapps)}"; do - if [ -f $i ]; then - # If the given web application is a file, symlink it into the webapps/ directory - ln -sfn $i ${cfg.baseDir}/virtualhosts/${virtualHost.name}/webapps/`basename $i` - elif [ -d $i ]; then - # If the given web application is a directory, then iterate over the files - # in the special purpose directories and symlink them into the tomcat tree - - for j in $i/webapps/*; do - ln -sfn $j ${cfg.baseDir}/virtualhosts/${virtualHost.name}/webapps/`basename $j` - done - - # Also symlink the configuration files if they are included - if [ -d $i/conf/Catalina ]; then - for j in $i/conf/Catalina/*; do - mkdir -p ${cfg.baseDir}/conf/Catalina/${virtualHost.name} - ln -sfn $j ${cfg.baseDir}/conf/Catalina/${virtualHost.name}/`basename $j` + ${toString ( + map (virtualHost: '' + # Create webapps directory for the virtual host + mkdir -p ${cfg.baseDir}/virtualhosts/${virtualHost.name}/webapps + + # Modify ownership + chown ${cfg.user}:${cfg.group} ${cfg.baseDir}/virtualhosts/${virtualHost.name}/webapps + + # Symlink all the given web applications files or paths into the webapps/ directory + # of this virtual host + for i in "${lib.optionalString (virtualHost ? webapps) (toString virtualHost.webapps)}"; do + if [ -f $i ]; then + # If the given web application is a file, symlink it into the webapps/ directory + ln -sfn $i ${cfg.baseDir}/virtualhosts/${virtualHost.name}/webapps/`basename $i` + elif [ -d $i ]; then + # If the given web application is a directory, then iterate over the files + # in the special purpose directories and symlink them into the tomcat tree + + for j in $i/webapps/*; do + ln -sfn $j ${cfg.baseDir}/virtualhosts/${virtualHost.name}/webapps/`basename $j` done + + # Also symlink the configuration files if they are included + if [ -d $i/conf/Catalina ]; then + for j in $i/conf/Catalina/*; do + mkdir -p ${cfg.baseDir}/conf/Catalina/${virtualHost.name} + ln -sfn $j ${cfg.baseDir}/conf/Catalina/${virtualHost.name}/`basename $j` + done + fi fi - fi - done - '') cfg.virtualHosts)} + done + '') cfg.virtualHosts + )} ${lib.optionalString cfg.axis2.enable '' # Copy the Axis2 web application diff --git a/nixos/modules/services/web-servers/trafficserver/default.nix b/nixos/modules/services/web-servers/trafficserver/default.nix index 1cae7c7e13df28..f6a98b1ebe2f03 100644 --- a/nixos/modules/services/web-servers/trafficserver/default.nix +++ b/nixos/modules/services/web-servers/trafficserver/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -7,18 +12,24 @@ let user = config.users.users.trafficserver.name; group = config.users.groups.trafficserver.name; - getManualUrl = name: "https://docs.trafficserver.apache.org/en/latest/admin-guide/files/${name}.en.html"; + getManualUrl = + name: "https://docs.trafficserver.apache.org/en/latest/admin-guide/files/${name}.en.html"; yaml = pkgs.formats.yaml { }; - mkYamlConf = name: cfg: - if cfg != null then { - "trafficserver/${name}.yaml".source = yaml.generate "${name}.yaml" cfg; - } else { - "trafficserver/${name}.yaml".text = ""; - }; + mkYamlConf = + name: cfg: + if cfg != null then + { + "trafficserver/${name}.yaml".source = yaml.generate "${name}.yaml" cfg; + } + else + { + "trafficserver/${name}.yaml".text = ""; + }; - mkRecordLines = path: value: + mkRecordLines = + path: value: if isAttrs value then lib.mapAttrsToList (n: v: mkRecordLines (path ++ [ n ]) v) value else if isInt value then @@ -120,7 +131,8 @@ in documentation](${getManualUrl "plugin.config"}) for more details. ''; - type = with types; + type = + with types; listOf (submodule { options.path = mkOption { type = str; @@ -140,14 +152,25 @@ in }; records = mkOption { - type = with types; - let valueType = (attrsOf (oneOf [ int float str valueType ])) // { - description = "Traffic Server records value"; - }; + type = + with types; + let + valueType = + (attrsOf (oneOf [ + int + float + str + valueType + ])) + // { + description = "Traffic Server records value"; + }; in valueType; default = { }; - example = { proxy.config.proxy_name = "my_server"; }; + example = { + proxy.config.proxy_name = "my_server"; + }; description = '' List of configurable variables used by Traffic Server. @@ -255,21 +278,23 @@ in }; config = mkIf cfg.enable { - environment.etc = { - "trafficserver/cache.config".text = cfg.cache; - "trafficserver/hosting.config".text = cfg.hosting; - "trafficserver/parent.config".text = cfg.parent; - "trafficserver/plugin.config".text = mkPluginConfig cfg.plugins; - "trafficserver/records.config".text = mkRecordsConfig cfg.records; - "trafficserver/remap.config".text = cfg.remap; - "trafficserver/splitdns.config".text = cfg.splitDns; - "trafficserver/ssl_multicert.config".text = cfg.sslMulticert; - "trafficserver/storage.config".text = cfg.storage; - "trafficserver/volume.config".text = cfg.volume; - } // (mkYamlConf "ip_allow" cfg.ipAllow) - // (mkYamlConf "logging" cfg.logging) - // (mkYamlConf "sni" cfg.sni) - // (mkYamlConf "strategies" cfg.strategies); + environment.etc = + { + "trafficserver/cache.config".text = cfg.cache; + "trafficserver/hosting.config".text = cfg.hosting; + "trafficserver/parent.config".text = cfg.parent; + "trafficserver/plugin.config".text = mkPluginConfig cfg.plugins; + "trafficserver/records.config".text = mkRecordsConfig cfg.records; + "trafficserver/remap.config".text = cfg.remap; + "trafficserver/splitdns.config".text = cfg.splitDns; + "trafficserver/ssl_multicert.config".text = cfg.sslMulticert; + "trafficserver/storage.config".text = cfg.storage; + "trafficserver/volume.config".text = cfg.volume; + } + // (mkYamlConf "ip_allow" cfg.ipAllow) + // (mkYamlConf "logging" cfg.logging) + // (mkYamlConf "sni" cfg.sni) + // (mkYamlConf "strategies" cfg.strategies); environment.systemPackages = [ pkgs.trafficserver ]; systemd.packages = [ pkgs.trafficserver ]; diff --git a/nixos/modules/services/web-servers/ttyd.nix b/nixos/modules/services/web-servers/ttyd.nix index e3cf92e179138c..f95cc62b8b67ea 100644 --- a/nixos/modules/services/web-servers/ttyd.nix +++ b/nixos/modules/services/web-servers/ttyd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let @@ -11,22 +16,59 @@ let ; # Command line arguments for the ttyd daemon - args = [ "--port" (toString cfg.port) ] - ++ optionals (cfg.socket != null) [ "--interface" cfg.socket ] - ++ optionals (cfg.interface != null) [ "--interface" cfg.interface ] - ++ [ "--signal" (toString cfg.signal) ] - ++ (lib.concatLists (lib.mapAttrsToList (_k: _v: [ "--client-option" "${_k}=${_v}" ]) cfg.clientOptions)) - ++ [ "--terminal-type" cfg.terminalType ] - ++ optionals cfg.checkOrigin [ "--check-origin" ] - ++ optionals cfg.writeable [ "--writable" ] # the typo is correct - ++ [ "--max-clients" (toString cfg.maxClients) ] - ++ optionals (cfg.indexFile != null) [ "--index" cfg.indexFile ] - ++ optionals cfg.enableIPv6 [ "--ipv6" ] - ++ optionals cfg.enableSSL [ "--ssl" - "--ssl-cert" cfg.certFile - "--ssl-key" cfg.keyFile ] - ++ optionals ( cfg.enableSSL && cfg.caFile != null ) [ "--ssl-ca" cfg.caFile ] - ++ [ "--debug" (toString cfg.logLevel) ]; + args = + [ + "--port" + (toString cfg.port) + ] + ++ optionals (cfg.socket != null) [ + "--interface" + cfg.socket + ] + ++ optionals (cfg.interface != null) [ + "--interface" + cfg.interface + ] + ++ [ + "--signal" + (toString cfg.signal) + ] + ++ (lib.concatLists ( + lib.mapAttrsToList (_k: _v: [ + "--client-option" + "${_k}=${_v}" + ]) cfg.clientOptions + )) + ++ [ + "--terminal-type" + cfg.terminalType + ] + ++ optionals cfg.checkOrigin [ "--check-origin" ] + ++ optionals cfg.writeable [ "--writable" ] # the typo is correct + ++ [ + "--max-clients" + (toString cfg.maxClients) + ] + ++ optionals (cfg.indexFile != null) [ + "--index" + cfg.indexFile + ] + ++ optionals cfg.enableIPv6 [ "--ipv6" ] + ++ optionals cfg.enableSSL [ + "--ssl" + "--ssl-cert" + cfg.certFile + "--ssl-key" + cfg.keyFile + ] + ++ optionals (cfg.enableSSL && cfg.caFile != null) [ + "--ssl-ca" + cfg.caFile + ] + ++ [ + "--debug" + (toString cfg.logLevel) + ]; in @@ -110,7 +152,7 @@ in clientOptions = mkOption { type = types.attrsOf types.str; - default = {}; + default = { }; example = lib.literalExpression '' { fontSize = "16"; @@ -194,17 +236,24 @@ in config = lib.mkIf cfg.enable { - assertions = - [ { assertion = cfg.enableSSL - -> cfg.certFile != null && cfg.keyFile != null; - message = "SSL is enabled for ttyd, but no certFile or keyFile has been specified."; } - { assertion = cfg.writeable != null; - message = "services.ttyd.writeable must be set"; } - { assertion = ! (cfg.interface != null && cfg.socket != null); - message = "Cannot set both interface and socket for ttyd."; } - { assertion = (cfg.username != null) == (cfg.passwordFile != null); - message = "Need to set both username and passwordFile for ttyd"; } - ]; + assertions = [ + { + assertion = cfg.enableSSL -> cfg.certFile != null && cfg.keyFile != null; + message = "SSL is enabled for ttyd, but no certFile or keyFile has been specified."; + } + { + assertion = cfg.writeable != null; + message = "services.ttyd.writeable must be set"; + } + { + assertion = !(cfg.interface != null && cfg.socket != null); + message = "Cannot set both interface and socket for ttyd."; + } + { + assertion = (cfg.username != null) == (cfg.passwordFile != null); + message = "Need to set both username and passwordFile for ttyd"; + } + ]; systemd.services.ttyd = { description = "ttyd Web Server Daemon"; @@ -213,19 +262,24 @@ in serviceConfig = { User = cfg.user; - LoadCredential = lib.optionalString (cfg.passwordFile != null) "TTYD_PASSWORD_FILE:${cfg.passwordFile}"; - }; - - script = if cfg.passwordFile != null then '' - PASSWORD=$(cat "$CREDENTIALS_DIRECTORY/TTYD_PASSWORD_FILE") - ${pkgs.ttyd}/bin/ttyd ${lib.escapeShellArgs args} \ - --credential ${lib.escapeShellArg cfg.username}:"$PASSWORD" \ - ${cfg.entrypoint} - '' - else '' - ${pkgs.ttyd}/bin/ttyd ${lib.escapeShellArgs args} \ - ${cfg.entrypoint} - ''; + LoadCredential = lib.optionalString ( + cfg.passwordFile != null + ) "TTYD_PASSWORD_FILE:${cfg.passwordFile}"; + }; + + script = + if cfg.passwordFile != null then + '' + PASSWORD=$(cat "$CREDENTIALS_DIRECTORY/TTYD_PASSWORD_FILE") + ${pkgs.ttyd}/bin/ttyd ${lib.escapeShellArgs args} \ + --credential ${lib.escapeShellArg cfg.username}:"$PASSWORD" \ + ${cfg.entrypoint} + '' + else + '' + ${pkgs.ttyd}/bin/ttyd ${lib.escapeShellArgs args} \ + ${cfg.entrypoint} + ''; }; }; } diff --git a/nixos/modules/services/web-servers/unit/default.nix b/nixos/modules/services/web-servers/unit/default.nix index 5e7b7be91a15b3..53c820e2947e33 100644 --- a/nixos/modules/services/web-servers/unit/default.nix +++ b/nixos/modules/services/web-servers/unit/default.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -7,7 +12,8 @@ let configFile = pkgs.writeText "unit.json" cfg.config; -in { +in +{ options = { services.unit = { enable = mkEnableOption "Unit App Server"; @@ -109,7 +115,10 @@ in { RuntimeDirectory = "unit"; RuntimeDirectoryMode = "0750"; # Access write directories - ReadWritePaths = [ cfg.stateDir cfg.logDir ]; + ReadWritePaths = [ + cfg.stateDir + cfg.logDir + ]; # Security NoNewPrivileges = true; # Sandboxing @@ -124,7 +133,11 @@ in { ProtectKernelModules = true; ProtectKernelLogs = true; ProtectControlGroups = true; - RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; + RestrictAddressFamilies = [ + "AF_UNIX" + "AF_INET" + "AF_INET6" + ]; LockPersonality = true; MemoryDenyWriteExecute = true; RestrictRealtime = true; diff --git a/nixos/modules/services/web-servers/uwsgi.nix b/nixos/modules/services/web-servers/uwsgi.nix index e4e3d346f256b9..f35a2ba2297725 100644 --- a/nixos/modules/services/web-servers/uwsgi.nix +++ b/nixos/modules/services/web-servers/uwsgi.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -7,67 +12,88 @@ let isEmperor = cfg.instance.type == "emperor"; - imperialPowers = - [ - # spawn other user processes - "CAP_SETUID" "CAP_SETGID" - "CAP_SYS_CHROOT" - # transfer capabilities - "CAP_SETPCAP" - # create other user sockets - "CAP_CHOWN" - ]; - - buildCfg = name: c: + imperialPowers = [ + # spawn other user processes + "CAP_SETUID" + "CAP_SETGID" + "CAP_SYS_CHROOT" + # transfer capabilities + "CAP_SETPCAP" + # create other user sockets + "CAP_CHOWN" + ]; + + buildCfg = + name: c: let plugins' = - if any (n: !any (m: m == n) cfg.plugins) (c.plugins or []) - then throw "`plugins` attribute in uWSGI configuration contains plugins not in config.services.uwsgi.plugins" - else c.plugins or cfg.plugins; + if any (n: !any (m: m == n) cfg.plugins) (c.plugins or [ ]) then + throw "`plugins` attribute in uWSGI configuration contains plugins not in config.services.uwsgi.plugins" + else + c.plugins or cfg.plugins; plugins = unique plugins'; - hasPython = v: filter (n: n == "python${v}") plugins != []; + hasPython = v: filter (n: n == "python${v}") plugins != [ ]; hasPython2 = hasPython "2"; hasPython3 = hasPython "3"; python = if hasPython2 && hasPython3 then throw "`plugins` attribute in uWSGI configuration shouldn't contain both python2 and python3" - else if hasPython2 then cfg.package.python2 - else if hasPython3 then cfg.package.python3 - else null; + else if hasPython2 then + cfg.package.python2 + else if hasPython3 then + cfg.package.python3 + else + null; - pythonEnv = python.withPackages (c.pythonPackages or (self: [])); + pythonEnv = python.withPackages (c.pythonPackages or (self: [ ])); uwsgiCfg = { uwsgi = - if c.type == "normal" - then { + if c.type == "normal" then + { inherit plugins; - } // removeAttrs c [ "type" "pythonPackages" ] - // optionalAttrs (python != null) { - pyhome = "${pythonEnv}"; - env = - # Argh, uwsgi expects list of key-values there instead of a dictionary. - let envs = partition (hasPrefix "PATH=") (c.env or []); - oldPaths = map (x: substring (stringLength "PATH=") (stringLength x) x) envs.right; - paths = oldPaths ++ [ "${pythonEnv}/bin" ]; - in [ "PATH=${concatStringsSep ":" paths}" ] ++ envs.wrong; - } - else if isEmperor - then { - emperor = if builtins.typeOf c.vassals != "set" then c.vassals - else pkgs.buildEnv { - name = "vassals"; - paths = mapAttrsToList buildCfg c.vassals; - }; - } // removeAttrs c [ "type" "vassals" ] - else throw "`type` attribute in uWSGI configuration should be either 'normal' or 'emperor'"; + } + // removeAttrs c [ + "type" + "pythonPackages" + ] + // optionalAttrs (python != null) { + pyhome = "${pythonEnv}"; + env = + # Argh, uwsgi expects list of key-values there instead of a dictionary. + let + envs = partition (hasPrefix "PATH=") (c.env or [ ]); + oldPaths = map (x: substring (stringLength "PATH=") (stringLength x) x) envs.right; + paths = oldPaths ++ [ "${pythonEnv}/bin" ]; + in + [ "PATH=${concatStringsSep ":" paths}" ] ++ envs.wrong; + } + else if isEmperor then + { + emperor = + if builtins.typeOf c.vassals != "set" then + c.vassals + else + pkgs.buildEnv { + name = "vassals"; + paths = mapAttrsToList buildCfg c.vassals; + }; + } + // removeAttrs c [ + "type" + "vassals" + ] + else + throw "`type` attribute in uWSGI configuration should be either 'normal' or 'emperor'"; }; - in pkgs.writeTextDir "${name}.json" (builtins.toJSON uwsgiCfg); + in + pkgs.writeTextDir "${name}.json" (builtins.toJSON uwsgiCfg); -in { +in +{ options = { services.uwsgi = { @@ -90,25 +116,30 @@ in { }; instance = mkOption { - type = with types; let - valueType = nullOr (oneOf [ - bool - int - float - str - (lazyAttrsOf valueType) - (listOf valueType) - (mkOptionType { - name = "function"; - description = "function"; - check = x: isFunction x; - merge = mergeOneOption; - }) - ]) // { - description = "Json value or lambda"; - emptyValue.value = {}; - }; - in valueType; + type = + with types; + let + valueType = + nullOr (oneOf [ + bool + int + float + str + (lazyAttrsOf valueType) + (listOf valueType) + (mkOptionType { + name = "function"; + description = "function"; + check = x: isFunction x; + merge = mergeOneOption; + }) + ]) + // { + description = "Json value or lambda"; + emptyValue.value = { }; + }; + in + valueType; default = { type = "normal"; }; @@ -141,7 +172,7 @@ in { plugins = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; description = "Plugins used with uWSGI"; }; diff --git a/nixos/modules/services/web-servers/varnish/default.nix b/nixos/modules/services/web-servers/varnish/default.nix index 5ba54f5a386560..d2b035b7cc5f70 100644 --- a/nixos/modules/services/web-servers/varnish/default.nix +++ b/nixos/modules/services/web-servers/varnish/default.nix @@ -1,19 +1,31 @@ -{ config, lib, pkgs, ...}: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.varnish; - commandLine = "-f ${pkgs.writeText "default.vcl" cfg.config}" + - optionalString (cfg.extraModules != []) " -p vmod_path='${makeSearchPathOutput "lib" "lib/varnish/vmods" ([cfg.package] ++ cfg.extraModules)}' -r vmod_path"; + commandLine = + "-f ${pkgs.writeText "default.vcl" cfg.config}" + + + optionalString (cfg.extraModules != [ ]) + " -p vmod_path='${ + makeSearchPathOutput "lib" "lib/varnish/vmods" ([ cfg.package ] ++ cfg.extraModules) + }' -r vmod_path"; in { options = { services.varnish = { enable = mkEnableOption "Varnish Server"; - enableConfigCheck = mkEnableOption "checking the config during build time" // { default = true; }; + enableConfigCheck = mkEnableOption "checking the config during build time" // { + default = true; + }; package = mkPackageOption pkgs "varnish" { }; @@ -43,7 +55,7 @@ in extraModules = mkOption { type = types.listOf types.package; - default = []; + default = [ ]; example = literalExpression "[ pkgs.varnishPackages.geoip ]"; description = '' Varnish modules (except 'std'). @@ -83,7 +95,9 @@ in RestartSec = "5s"; User = "varnish"; Group = "varnish"; - RuntimeDirectory = mkIf (lib.hasPrefix "/run/" cfg.stateDir) (lib.removePrefix "/run/" cfg.stateDir); + RuntimeDirectory = mkIf (lib.hasPrefix "/run/" cfg.stateDir) ( + lib.removePrefix "/run/" cfg.stateDir + ); AmbientCapabilities = "cap_net_bind_service"; NoNewPrivileges = true; LimitNOFILE = 131072; @@ -94,7 +108,7 @@ in # check .vcl syntax at compile time (e.g. before nixops deployment) system.checks = mkIf cfg.enableConfigCheck [ - (pkgs.runCommand "check-varnish-syntax" {} '' + (pkgs.runCommand "check-varnish-syntax" { } '' ${cfg.package}/bin/varnishd -C ${commandLine} 2> $out || (cat $out; exit 1) '') ]; diff --git a/nixos/modules/services/x11/clight.nix b/nixos/modules/services/x11/clight.nix index 40a0f3e065d090..03bcbf84f85355 100644 --- a/nixos/modules/services/x11/clight.nix +++ b/nixos/modules/services/x11/clight.nix @@ -1,32 +1,45 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; let cfg = config.services.clight; - toConf = v: - if builtins.isFloat v then toString v - else if isInt v then toString v - else if isBool v then boolToString v - else if isString v then ''"${escape [''"''] v}"'' - else if isList v then "[ " + concatMapStringsSep ", " toConf v + " ]" - else if isAttrs v then "\n{\n" + convertAttrs v + "\n}" - else abort "clight.toConf: unexpected type (v = ${v})"; - - getSep = v: - if isAttrs v then ":" - else "="; - - convertAttrs = attrs: concatStringsSep "\n" (mapAttrsToList - (name: value: "${toString name} ${getSep value} ${toConf value};") - attrs); - - clightConf = pkgs.writeText "clight.conf" (convertAttrs - (filterAttrs - (_: value: value != null) - cfg.settings)); -in { + toConf = + v: + if builtins.isFloat v then + toString v + else if isInt v then + toString v + else if isBool v then + boolToString v + else if isString v then + ''"${escape [ ''"'' ] v}"'' + else if isList v then + "[ " + concatMapStringsSep ", " toConf v + " ]" + else if isAttrs v then + "\n{\n" + convertAttrs v + "\n}" + else + abort "clight.toConf: unexpected type (v = ${v})"; + + getSep = v: if isAttrs v then ":" else "="; + + convertAttrs = + attrs: + concatStringsSep "\n" ( + mapAttrsToList (name: value: "${toString name} ${getSep value} ${toConf value};") attrs + ); + + clightConf = pkgs.writeText "clight.conf" ( + convertAttrs (filterAttrs (_: value: value != null) cfg.settings) + ); +in +{ options.services.clight = { enable = mkEnableOption "clight"; @@ -49,41 +62,83 @@ in { }; }; - settings = let - validConfigTypes = with types; oneOf [ int str bool float ]; - collectionTypes = with types; oneOf [ validConfigTypes (listOf validConfigTypes) ]; - in mkOption { - type = with types; attrsOf (nullOr (either collectionTypes (attrsOf collectionTypes))); - default = {}; - example = { captures = 20; gamma_long_transition = true; ac_capture_timeouts = [ 120 300 60 ]; }; - description = '' - Additional configuration to extend clight.conf. See - for a - sample configuration file. - ''; - }; + settings = + let + validConfigTypes = + with types; + oneOf [ + int + str + bool + float + ]; + collectionTypes = + with types; + oneOf [ + validConfigTypes + (listOf validConfigTypes) + ]; + in + mkOption { + type = with types; attrsOf (nullOr (either collectionTypes (attrsOf collectionTypes))); + default = { }; + example = { + captures = 20; + gamma_long_transition = true; + ac_capture_timeouts = [ + 120 + 300 + 60 + ]; + }; + description = '' + Additional configuration to extend clight.conf. See + for a + sample configuration file. + ''; + }; }; config = mkIf cfg.enable { - assertions = let - inRange = v: l: r: v >= l && v <= r; - in [ - { assertion = config.location.provider == "manual" -> - inRange config.location.latitude (-90) 90 && inRange config.location.longitude (-180) 180; - message = "You must specify a valid latitude and longitude if manually providing location"; } - ]; + assertions = + let + inRange = + v: l: r: + v >= l && v <= r; + in + [ + { + assertion = + config.location.provider == "manual" + -> inRange config.location.latitude (-90) 90 && inRange config.location.longitude (-180) 180; + message = "You must specify a valid latitude and longitude if manually providing location"; + } + ]; boot.kernelModules = [ "i2c_dev" ]; - environment.systemPackages = with pkgs; [ clight clightd ]; - services.dbus.packages = with pkgs; [ clight clightd ]; + environment.systemPackages = with pkgs; [ + clight + clightd + ]; + services.dbus.packages = with pkgs; [ + clight + clightd + ]; services.upower.enable = true; - services.clight.settings = { - gamma.temp = with cfg.temperature; mkDefault [ day night ]; - } // (optionalAttrs (config.location.provider == "manual") { - daytime.latitude = mkDefault config.location.latitude; - daytime.longitude = mkDefault config.location.longitude; - }); + services.clight.settings = + { + gamma.temp = + with cfg.temperature; + mkDefault [ + day + night + ]; + } + // (optionalAttrs (config.location.provider == "manual") { + daytime.latitude = mkDefault config.location.latitude; + daytime.longitude = mkDefault config.location.longitude; + }); services.geoclue2.appConfig.clightc = { isAllowed = true; @@ -107,8 +162,14 @@ in { }; systemd.user.services.clight = { - after = [ "upower.service" "clightd.service" ]; - wants = [ "upower.service" "clightd.service" ]; + after = [ + "upower.service" + "clightd.service" + ]; + wants = [ + "upower.service" + "clightd.service" + ]; partOf = [ "graphical-session.target" ]; wantedBy = [ "graphical-session.target" ]; diff --git a/nixos/modules/services/x11/colord.nix b/nixos/modules/services/x11/colord.nix index 31ccee6aa33f45..1a9ade71273920 100644 --- a/nixos/modules/services/x11/colord.nix +++ b/nixos/modules/services/x11/colord.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,7 +11,8 @@ let cfg = config.services.colord; -in { +in +{ options = { @@ -34,7 +40,7 @@ in { group = "colord"; }; - users.groups.colord = {}; + users.groups.colord = { }; }; diff --git a/nixos/modules/services/x11/desktop-managers/budgie.nix b/nixos/modules/services/x11/desktop-managers/budgie.nix index a4cd957a95dcaa..e278f2f2f87adb 100644 --- a/nixos/modules/services/x11/desktop-managers/budgie.nix +++ b/nixos/modules/services/x11/desktop-managers/budgie.nix @@ -1,7 +1,21 @@ -{ lib, pkgs, config, utils, ... }: +{ + lib, + pkgs, + config, + utils, + ... +}: let - inherit (lib) concatMapStrings literalExpression mkDefault mkEnableOption mkIf mkOption types; + inherit (lib) + concatMapStrings + literalExpression + mkDefault + mkEnableOption + mkIf + mkOption + types + ; cfg = config.services.xserver.desktopManager.budgie; @@ -45,7 +59,8 @@ let }; notExcluded = pkg: utils.disablePackageByName pkg config.environment.budgie.excludePackages; -in { +in +{ meta.maintainers = lib.teams.budgie.members; options = { @@ -60,7 +75,7 @@ in { Note that this should be a last resort; patching the package is preferred (see GPaste). ''; type = types.listOf types.package; - default = []; + default = [ ]; example = literalExpression "[ pkgs.gpaste ]"; }; @@ -73,13 +88,13 @@ in { extraGSettingsOverridePackages = mkOption { description = "List of packages for which GSettings are overridden."; type = types.listOf types.path; - default = []; + default = [ ]; }; extraPlugins = mkOption { description = "Extra plugins for the Budgie desktop"; type = types.listOf types.package; - default = []; + default = [ ]; example = literalExpression "[ pkgs.budgie-analogue-clock-applet ]"; }; }; @@ -87,7 +102,7 @@ in { environment.budgie.excludePackages = mkOption { description = "Which packages Budgie should exclude from the default environment."; type = types.listOf types.package; - default = []; + default = [ ]; example = literalExpression "[ pkgs.mate-terminal ]"; }; }; @@ -99,9 +114,18 @@ in { services.xserver.displayManager.lightdm.greeters.slick = { enable = mkDefault true; - theme = mkDefault { name = "Qogir"; package = pkgs.qogir-theme; }; - iconTheme = mkDefault { name = "Qogir"; package = pkgs.qogir-icon-theme; }; - cursorTheme = mkDefault { name = "Qogir"; package = pkgs.qogir-icon-theme; }; + theme = mkDefault { + name = "Qogir"; + package = pkgs.qogir-theme; + }; + iconTheme = mkDefault { + name = "Qogir"; + package = pkgs.qogir-icon-theme; + }; + cursorTheme = mkDefault { + name = "Qogir"; + package = pkgs.qogir-icon-theme; + }; }; services.xserver.desktopManager.budgie.sessionPath = [ pkgs.budgie-desktop-view ]; @@ -118,7 +142,8 @@ in { '') cfg.sessionPath} ''; - environment.systemPackages = with pkgs; + environment.systemPackages = + with pkgs; [ # Budgie Desktop. budgie-backgrounds @@ -142,23 +167,23 @@ in { ] ++ lib.optional config.networking.networkmanager.enable pkgs.networkmanagerapplet ++ (utils.removePackagesByName [ - nemo - mate.eom - mate.pluma - mate.atril - mate.engrampa - mate.mate-calc - mate.mate-system-monitor - vlc - - # Desktop themes. - qogir-theme - qogir-icon-theme - nixos-background-info - - # Default settings. - nixos-gsettings-overrides - ] config.environment.budgie.excludePackages) + nemo + mate.eom + mate.pluma + mate.atril + mate.engrampa + mate.mate-calc + mate.mate-system-monitor + vlc + + # Desktop themes. + qogir-theme + qogir-icon-theme + nixos-background-info + + # Default settings. + nixos-gsettings-overrides + ] config.environment.budgie.excludePackages) ++ cfg.sessionPath; # Both budgie-desktop-view and nemo defaults to this emulator. @@ -170,8 +195,8 @@ in { pkgs.hack-font ]; fonts.fontconfig.defaultFonts = { - sansSerif = mkDefault ["Noto Sans"]; - monospace = mkDefault ["Hack"]; + sansSerif = mkDefault [ "Noto Sans" ]; + monospace = mkDefault [ "Hack" ]; }; # Qt application style. @@ -193,7 +218,7 @@ in { programs.dconf.enable = true; # Required by Budgie Screensaver. - security.pam.services.budgie-screensaver = {}; + security.pam.services.budgie-screensaver = { }; # Required by Budgie's Polkit Dialog. security.polkit.enable = mkDefault true; diff --git a/nixos/modules/services/x11/desktop-managers/cde.nix b/nixos/modules/services/x11/desktop-managers/cde.nix index ae9a8ce2239241..8dae3ce0d8862d 100644 --- a/nixos/modules/services/x11/desktop-managers/cde.nix +++ b/nixos/modules/services/x11/desktop-managers/cde.nix @@ -1,18 +1,33 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let xcfg = config.services.xserver; cfg = xcfg.desktopManager.cde; -in { +in +{ options.services.xserver.desktopManager.cde = { enable = mkEnableOption "Common Desktop Environment"; extraPackages = mkOption { type = with types; listOf package; default = with pkgs.xorg; [ - xclock bitmap xlsfonts xfd xrefresh xload xwininfo xdpyinfo xwd xwud + xclock + bitmap + xlsfonts + xfd + xrefresh + xload + xwininfo + xdpyinfo + xwd + xwud ]; defaultText = literalExpression '' with pkgs.xorg; [ @@ -46,7 +61,7 @@ in { } ]; - users.groups.mail = {}; + users.groups.mail = { }; security.wrappers = { dtmail = { setgid = true; @@ -62,11 +77,13 @@ in { ''; services.xserver.desktopManager.session = [ - { name = "CDE"; - start = '' - exec ${pkgs.cdesktopenv}/bin/Xsession - ''; - }]; + { + name = "CDE"; + start = '' + exec ${pkgs.cdesktopenv}/bin/Xsession + ''; + } + ]; }; meta.maintainers = [ ]; diff --git a/nixos/modules/services/x11/desktop-managers/deepin.nix b/nixos/modules/services/x11/desktop-managers/deepin.nix index 8a8e79f52493b4..ca9fb229df973a 100644 --- a/nixos/modules/services/x11/desktop-managers/deepin.nix +++ b/nixos/modules/services/x11/desktop-managers/deepin.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: with lib; @@ -36,191 +42,191 @@ in }; - config = mkIf cfg.enable - { - services.displayManager.sessionPackages = [ pkgs.deepin.dde-session ]; - services.displayManager.defaultSession = mkDefault "dde-x11"; - - # Update the DBus activation environment after launching the desktop manager. - services.xserver.displayManager.sessionCommands = '' - ${lib.getBin pkgs.dbus}/bin/dbus-update-activation-environment --systemd --all - ''; - - hardware.bluetooth.enable = mkDefault true; - security.polkit.enable = true; - - services.deepin.dde-daemon.enable = mkForce true; - services.deepin.dde-api.enable = mkForce true; - services.deepin.app-services.enable = mkForce true; - - services.colord.enable = mkDefault true; - services.accounts-daemon.enable = mkDefault true; - services.gvfs.enable = mkDefault true; - services.gnome.glib-networking.enable = mkDefault true; - services.gnome.gnome-keyring.enable = mkDefault true; - services.bamf.enable = mkDefault true; - - services.libinput.enable = mkDefault true; - services.udisks2.enable = true; - services.upower.enable = mkDefault config.powerManagement.enable; - networking.networkmanager.enable = mkDefault true; - programs.dconf.enable = mkDefault true; - programs.gnupg.agent.pinentryPackage = mkDefault pkgs.pinentry-qt; - - fonts.packages = with pkgs; [ noto-fonts ]; - xdg.mime.enable = true; - xdg.menus.enable = true; - xdg.icons.enable = true; - xdg.portal.enable = mkDefault true; - xdg.portal.extraPortals = mkDefault [ - pkgs.xdg-desktop-portal-gtk - ]; - - # https://github.com/NixOS/nixpkgs/pull/247766#issuecomment-1722839259 - xdg.portal.config.deepin.default = mkDefault [ "gtk" ]; - - environment.sessionVariables = { - NIX_GSETTINGS_OVERRIDES_DIR = "${nixos-gsettings-overrides}/share/gsettings-schemas/nixos-gsettings-overrides/glib-2.0/schemas"; - DDE_POLKIT_AGENT_PLUGINS_DIRS = [ "${pkgs.deepin.dpa-ext-gnomekeyring}/lib/polkit-1-dde/plugins" ]; - }; - - environment.pathsToLink = [ - "/lib/dde-dock/plugins" - "/lib/dde-control-center" - "/lib/dde-session-shell" - "/lib/dde-file-manager" - "/share/backgrounds" - "/share/wallpapers" - "/share/dde-daemon" - "/share/dsg" - "/share/deepin-themes" - "/share/deepin" - "/share/dde-shell" - ]; - - environment.etc = { - "deepin-installer.conf".text = '' - system_info_vendor_name="Copyright (c) 2003-2024 NixOS contributors" - ''; - }; + config = mkIf cfg.enable { + services.displayManager.sessionPackages = [ pkgs.deepin.dde-session ]; + services.displayManager.defaultSession = mkDefault "dde-x11"; + + # Update the DBus activation environment after launching the desktop manager. + services.xserver.displayManager.sessionCommands = '' + ${lib.getBin pkgs.dbus}/bin/dbus-update-activation-environment --systemd --all + ''; + + hardware.bluetooth.enable = mkDefault true; + security.polkit.enable = true; + + services.deepin.dde-daemon.enable = mkForce true; + services.deepin.dde-api.enable = mkForce true; + services.deepin.app-services.enable = mkForce true; + + services.colord.enable = mkDefault true; + services.accounts-daemon.enable = mkDefault true; + services.gvfs.enable = mkDefault true; + services.gnome.glib-networking.enable = mkDefault true; + services.gnome.gnome-keyring.enable = mkDefault true; + services.bamf.enable = mkDefault true; + + services.libinput.enable = mkDefault true; + services.udisks2.enable = true; + services.upower.enable = mkDefault config.powerManagement.enable; + networking.networkmanager.enable = mkDefault true; + programs.dconf.enable = mkDefault true; + programs.gnupg.agent.pinentryPackage = mkDefault pkgs.pinentry-qt; + + fonts.packages = with pkgs; [ noto-fonts ]; + xdg.mime.enable = true; + xdg.menus.enable = true; + xdg.icons.enable = true; + xdg.portal.enable = mkDefault true; + xdg.portal.extraPortals = mkDefault [ + pkgs.xdg-desktop-portal-gtk + ]; + + # https://github.com/NixOS/nixpkgs/pull/247766#issuecomment-1722839259 + xdg.portal.config.deepin.default = mkDefault [ "gtk" ]; + + environment.sessionVariables = { + NIX_GSETTINGS_OVERRIDES_DIR = "${nixos-gsettings-overrides}/share/gsettings-schemas/nixos-gsettings-overrides/glib-2.0/schemas"; + DDE_POLKIT_AGENT_PLUGINS_DIRS = [ "${pkgs.deepin.dpa-ext-gnomekeyring}/lib/polkit-1-dde/plugins" ]; + }; - systemd.tmpfiles.rules = [ - "d /var/lib/AccountsService 0775 root root - -" - "C /var/lib/AccountsService/icons 0775 root root - ${pkgs.deepin.dde-account-faces}/var/lib/AccountsService/icons" - ]; - - security.pam.services.dde-lock.text = '' - # original at {dde-session-shell}/etc/pam.d/dde-lock - auth substack login - account include login - password substack login - session include login + environment.pathsToLink = [ + "/lib/dde-dock/plugins" + "/lib/dde-control-center" + "/lib/dde-session-shell" + "/lib/dde-file-manager" + "/share/backgrounds" + "/share/wallpapers" + "/share/dde-daemon" + "/share/dsg" + "/share/deepin-themes" + "/share/deepin" + "/share/dde-shell" + ]; + + environment.etc = { + "deepin-installer.conf".text = '' + system_info_vendor_name="Copyright (c) 2003-2024 NixOS contributors" ''; - - environment.systemPackages = with pkgs; with deepin; - let - requiredPackages = [ - pciutils # for dtkcore/startdde - xdotool # for dde-daemon - glib # for gsettings program / gdbus - gtk3 # for gtk-launch program - xdg-user-dirs # Update user dirs - util-linux # runuser - polkit_gnome - librsvg # dde-api use rsvg-convert - lshw # for dtkcore - libsForQt5.kde-gtk-config # deepin-api/gtk-thumbnailer need - libsForQt5.kglobalaccel - xsettingsd # lightdm-deepin-greeter - dtkcommon - dtkcore - dtkgui - dtkwidget - dtkdeclarative - qt5platform-plugins - qt6platform-plugins - qt5integration - qt6integration - deepin-pw-check - - dde-account-faces - deepin-icon-theme - deepin-desktop-theme - deepin-sound-theme - deepin-gtk-theme - deepin-wallpapers - deepin-desktop-base - - startdde - dde-shell - dde-launchpad - dde-session-ui - dde-session-shell - dde-file-manager - dde-control-center - dde-network-core - dde-clipboard - dde-polkit-agent - dpa-ext-gnomekeyring - deepin-desktop-schemas - deepin-kwin - dde-session - dde-widgets - dde-appearance - dde-application-manager - deepin-service-manager - dde-api-proxy - dde-tray-loader - ]; - optionalPackages = [ - dde-calendar - dde-grand-search - deepin-terminal - onboard # dde-dock plugin - deepin-calculator - deepin-compressor - deepin-editor - deepin-system-monitor - deepin-shortcut-viewer - ]; - in - requiredPackages - ++ utils.removePackagesByName optionalPackages config.environment.deepin.excludePackages; - - services.dbus.packages = with pkgs.deepin; [ - dde-shell - dde-launchpad - dde-session-ui - dde-session-shell - dde-file-manager - dde-control-center - dde-calendar - dde-clipboard - deepin-kwin - deepin-pw-check - dde-widgets - dde-session - dde-appearance - dde-application-manager - deepin-service-manager - dde-grand-search - dde-api-proxy - ]; - - systemd.packages = with pkgs.deepin; [ - dde-shell - dde-launchpad - dde-file-manager - dde-calendar - dde-clipboard - deepin-kwin - dde-appearance - dde-widgets - dde-session - dde-application-manager - deepin-service-manager - dde-api-proxy - ]; }; -} + systemd.tmpfiles.rules = [ + "d /var/lib/AccountsService 0775 root root - -" + "C /var/lib/AccountsService/icons 0775 root root - ${pkgs.deepin.dde-account-faces}/var/lib/AccountsService/icons" + ]; + + security.pam.services.dde-lock.text = '' + # original at {dde-session-shell}/etc/pam.d/dde-lock + auth substack login + account include login + password substack login + session include login + ''; + + environment.systemPackages = + with pkgs; + with deepin; + let + requiredPackages = [ + pciutils # for dtkcore/startdde + xdotool # for dde-daemon + glib # for gsettings program / gdbus + gtk3 # for gtk-launch program + xdg-user-dirs # Update user dirs + util-linux # runuser + polkit_gnome + librsvg # dde-api use rsvg-convert + lshw # for dtkcore + libsForQt5.kde-gtk-config # deepin-api/gtk-thumbnailer need + libsForQt5.kglobalaccel + xsettingsd # lightdm-deepin-greeter + dtkcommon + dtkcore + dtkgui + dtkwidget + dtkdeclarative + qt5platform-plugins + qt6platform-plugins + qt5integration + qt6integration + deepin-pw-check + + dde-account-faces + deepin-icon-theme + deepin-desktop-theme + deepin-sound-theme + deepin-gtk-theme + deepin-wallpapers + deepin-desktop-base + + startdde + dde-shell + dde-launchpad + dde-session-ui + dde-session-shell + dde-file-manager + dde-control-center + dde-network-core + dde-clipboard + dde-polkit-agent + dpa-ext-gnomekeyring + deepin-desktop-schemas + deepin-kwin + dde-session + dde-widgets + dde-appearance + dde-application-manager + deepin-service-manager + dde-api-proxy + dde-tray-loader + ]; + optionalPackages = [ + dde-calendar + dde-grand-search + deepin-terminal + onboard # dde-dock plugin + deepin-calculator + deepin-compressor + deepin-editor + deepin-system-monitor + deepin-shortcut-viewer + ]; + in + requiredPackages + ++ utils.removePackagesByName optionalPackages config.environment.deepin.excludePackages; + + services.dbus.packages = with pkgs.deepin; [ + dde-shell + dde-launchpad + dde-session-ui + dde-session-shell + dde-file-manager + dde-control-center + dde-calendar + dde-clipboard + deepin-kwin + deepin-pw-check + dde-widgets + dde-session + dde-appearance + dde-application-manager + deepin-service-manager + dde-grand-search + dde-api-proxy + ]; + + systemd.packages = with pkgs.deepin; [ + dde-shell + dde-launchpad + dde-file-manager + dde-calendar + dde-clipboard + deepin-kwin + dde-appearance + dde-widgets + dde-session + dde-application-manager + deepin-service-manager + dde-api-proxy + ]; + }; +} diff --git a/nixos/modules/services/x11/desktop-managers/enlightenment.nix b/nixos/modules/services/x11/desktop-managers/enlightenment.nix index 44c0dbc70fea8b..05ed81e5799276 100644 --- a/nixos/modules/services/x11/desktop-managers/enlightenment.nix +++ b/nixos/modules/services/x11/desktop-managers/enlightenment.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -11,7 +16,8 @@ let pkgs.gst_all_1.gst-plugins-base pkgs.gst_all_1.gst-plugins-good pkgs.gst_all_1.gst-plugins-bad - pkgs.gst_all_1.gst-libav ]; + pkgs.gst_all_1.gst-libav + ]; in @@ -21,7 +27,10 @@ in }; imports = [ - (mkRenamedOptionModule [ "services" "xserver" "desktopManager" "e19" "enable" ] [ "services" "xserver" "desktopManager" "enlightenment" "enable" ]) + (mkRenamedOptionModule + [ "services" "xserver" "desktopManager" "e19" "enable" ] + [ "services" "xserver" "desktopManager" "enlightenment" "enable" ] + ) ]; options = { @@ -70,24 +79,24 @@ in # Wrappers for programs installed by enlightenment that should be setuid security.wrappers = { - enlightenment_ckpasswd = - { setuid = true; - owner = "root"; - group = "root"; - source = "${pkgs.enlightenment.enlightenment}/lib/enlightenment/utils/enlightenment_ckpasswd"; - }; - enlightenment_sys = - { setuid = true; - owner = "root"; - group = "root"; - source = "${pkgs.enlightenment.enlightenment}/lib/enlightenment/utils/enlightenment_sys"; - }; - enlightenment_system = - { setuid = true; - owner = "root"; - group = "root"; - source = "${pkgs.enlightenment.enlightenment}/lib/enlightenment/utils/enlightenment_system"; - }; + enlightenment_ckpasswd = { + setuid = true; + owner = "root"; + group = "root"; + source = "${pkgs.enlightenment.enlightenment}/lib/enlightenment/utils/enlightenment_ckpasswd"; + }; + enlightenment_sys = { + setuid = true; + owner = "root"; + group = "root"; + source = "${pkgs.enlightenment.enlightenment}/lib/enlightenment/utils/enlightenment_sys"; + }; + enlightenment_system = { + setuid = true; + owner = "root"; + group = "root"; + source = "${pkgs.enlightenment.enlightenment}/lib/enlightenment/utils/enlightenment_system"; + }; }; environment.etc."X11/xkb".source = xcfg.xkb.dir; @@ -100,24 +109,23 @@ in services.dbus.packages = [ e.efl ]; - systemd.user.services.efreet = - { enable = true; - description = "org.enlightenment.Efreet"; - serviceConfig = - { ExecStart = "${e.efl}/bin/efreetd"; - StandardOutput = "null"; - }; + systemd.user.services.efreet = { + enable = true; + description = "org.enlightenment.Efreet"; + serviceConfig = { + ExecStart = "${e.efl}/bin/efreetd"; + StandardOutput = "null"; }; + }; - systemd.user.services.ethumb = - { enable = true; - description = "org.enlightenment.Ethumb"; - serviceConfig = - { ExecStart = "${e.efl}/bin/ethumbd"; - StandardOutput = "null"; - }; + systemd.user.services.ethumb = { + enable = true; + description = "org.enlightenment.Ethumb"; + serviceConfig = { + ExecStart = "${e.efl}/bin/ethumbd"; + StandardOutput = "null"; }; - + }; }; diff --git a/nixos/modules/services/x11/desktop-managers/gnome.nix b/nixos/modules/services/x11/desktop-managers/gnome.nix index 34b705b6288d3c..c3a3465f3a4567 100644 --- a/nixos/modules/services/x11/desktop-managers/gnome.nix +++ b/nixos/modules/services/x11/desktop-managers/gnome.nix @@ -1,7 +1,19 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let - inherit (lib) mkOption types mkDefault mkEnableOption literalExpression; + inherit (lib) + mkOption + types + mkDefault + mkEnableOption + literalExpression + ; cfg = config.services.xserver.desktopManager.gnome; serviceCfg = config.services.gnome; @@ -51,14 +63,17 @@ let }; flashbackEnabled = cfg.flashback.enableMetacity || lib.length cfg.flashback.customSessions > 0; - flashbackWms = lib.optional cfg.flashback.enableMetacity { - wmName = "metacity"; - wmLabel = "Metacity"; - wmCommand = "${pkgs.metacity}/bin/metacity"; - enableGnomePanel = true; - } ++ cfg.flashback.customSessions; - - notExcluded = pkg: mkDefault (utils.disablePackageByName pkg config.environment.gnome.excludePackages); + flashbackWms = + lib.optional cfg.flashback.enableMetacity { + wmName = "metacity"; + wmLabel = "Metacity"; + wmCommand = "${pkgs.metacity}/bin/metacity"; + enableGnomePanel = true; + } + ++ cfg.flashback.customSessions; + + notExcluded = + pkg: mkDefault (utils.disablePackageByName pkg config.environment.gnome.excludePackages); in @@ -87,7 +102,7 @@ in }; sessionPath = mkOption { - default = []; + default = [ ]; type = types.listOf types.package; example = literalExpression "[ pkgs.gpaste ]"; description = '' @@ -118,7 +133,7 @@ in }; extraGSettingsOverridePackages = mkOption { - default = []; + default = [ ]; type = types.listOf types.path; description = "List of packages for which gsettings are overridden."; }; @@ -129,35 +144,37 @@ in enableMetacity = mkEnableOption "the standard GNOME Flashback session with Metacity"; customSessions = mkOption { - type = types.listOf (types.submodule { - options = { - wmName = mkOption { - type = types.strMatching "[a-zA-Z0-9_-]+"; - description = "A unique identifier for the window manager."; - example = "xmonad"; - }; - - wmLabel = mkOption { - type = types.str; - description = "The name of the window manager to show in the session chooser."; - example = "XMonad"; - }; - - wmCommand = mkOption { - type = types.str; - description = "The executable of the window manager to use."; - example = literalExpression ''"''${pkgs.haskellPackages.xmonad}/bin/xmonad"''; + type = types.listOf ( + types.submodule { + options = { + wmName = mkOption { + type = types.strMatching "[a-zA-Z0-9_-]+"; + description = "A unique identifier for the window manager."; + example = "xmonad"; + }; + + wmLabel = mkOption { + type = types.str; + description = "The name of the window manager to show in the session chooser."; + example = "XMonad"; + }; + + wmCommand = mkOption { + type = types.str; + description = "The executable of the window manager to use."; + example = literalExpression ''"''${pkgs.haskellPackages.xmonad}/bin/xmonad"''; + }; + + enableGnomePanel = mkOption { + type = types.bool; + default = true; + example = false; + description = "Whether to enable the GNOME panel in this session."; + }; }; - - enableGnomePanel = mkOption { - type = types.bool; - default = true; - example = false; - description = "Whether to enable the GNOME panel in this session."; - }; - }; - }); - default = []; + } + ); + default = [ ]; description = "Other GNOME Flashback sessions to enable."; }; @@ -175,7 +192,7 @@ in }; environment.gnome.excludePackages = mkOption { - default = []; + default = [ ]; example = literalExpression "[ pkgs.totem ]"; type = types.listOf types.package; description = "Which packages gnome should exclude from the default environment"; @@ -186,11 +203,13 @@ in config = lib.mkMerge [ (lib.mkIf (cfg.enable || flashbackEnabled) { # Seed our configuration into nixos-generate-config - system.nixos-generate-config.desktopConfiguration = ['' - # Enable the GNOME Desktop Environment. - services.xserver.displayManager.gdm.enable = true; - services.xserver.desktopManager.gnome.enable = true; - '']; + system.nixos-generate-config.desktopConfiguration = [ + '' + # Enable the GNOME Desktop Environment. + services.xserver.displayManager.gdm.enable = true; + services.xserver.desktopManager.gnome.enable = true; + '' + ]; services.gnome.core-os-services.enable = true; services.gnome.core-shell.enable = true; @@ -225,13 +244,13 @@ in wmNames = map (wm: wm.wmName) flashbackWms; namesAreUnique = lib.unique wmNames == wmNames; in - assert (lib.assertMsg namesAreUnique "Flashback WM names must be unique."); - map - (wm: - pkgs.gnome-flashback.mkSessionForWm { - inherit (wm) wmName wmLabel wmCommand; - } - ) flashbackWms; + assert (lib.assertMsg namesAreUnique "Flashback WM names must be unique."); + map ( + wm: + pkgs.gnome-flashback.mkSessionForWm { + inherit (wm) wmName wmLabel wmCommand; + } + ) flashbackWms; security.pam.services.gnome-flashback = { enableGnomeKeyring = true; @@ -241,16 +260,21 @@ in pkgs.gnome-flashback ] ++ map pkgs.gnome-flashback.mkSystemdTargetForWm flashbackWms; - environment.systemPackages = [ - pkgs.gnome-flashback - (pkgs.gnome-panel-with-modules.override { - panelModulePackages = cfg.flashback.panelModulePackages; - }) - ] - # For /share/applications/${wmName}.desktop - ++ (map (wm: pkgs.gnome-flashback.mkWmApplication { inherit (wm) wmName wmLabel wmCommand; }) flashbackWms) - # For /share/pkgs.gnome-session/sessions/gnome-flashback-${wmName}.session - ++ (map (wm: pkgs.gnome-flashback.mkGnomeSession { inherit (wm) wmName wmLabel enableGnomePanel; }) flashbackWms); + environment.systemPackages = + [ + pkgs.gnome-flashback + (pkgs.gnome-panel-with-modules.override { + panelModulePackages = cfg.flashback.panelModulePackages; + }) + ] + # For /share/applications/${wmName}.desktop + ++ (map ( + wm: pkgs.gnome-flashback.mkWmApplication { inherit (wm) wmName wmLabel wmCommand; } + ) flashbackWms) + # For /share/pkgs.gnome-session/sessions/gnome-flashback-${wmName}.session + ++ (map ( + wm: pkgs.gnome-flashback.mkGnomeSession { inherit (wm) wmName wmLabel enableGnomePanel; } + ) flashbackWms); }) (lib.mkIf serviceCfg.core-os-services.enable { @@ -392,37 +416,37 @@ in # Adapt from https://gitlab.gnome.org/GNOME/gnome-build-meta/-/blob/gnome-45/elements/core/meta-gnome-core-utilities.bst (lib.mkIf serviceCfg.core-utilities.enable { - environment.systemPackages = - utils.removePackagesByName - ([ - pkgs.baobab - pkgs.epiphany - pkgs.gnome-text-editor - pkgs.gnome-calculator - pkgs.gnome-calendar - pkgs.gnome-characters - pkgs.gnome-clocks - pkgs.gnome-console - pkgs.gnome-contacts - pkgs.gnome-font-viewer - pkgs.gnome-logs - pkgs.gnome-maps - pkgs.gnome-music - pkgs.gnome-system-monitor - pkgs.gnome-weather - pkgs.loupe - pkgs.nautilus - pkgs.gnome-connections - pkgs.simple-scan - pkgs.snapshot - pkgs.totem - pkgs.yelp - ] ++ lib.optionals config.services.flatpak.enable [ - # Since PackageKit Nix support is not there yet, - # only install gnome-software if flatpak is enabled. - pkgs.gnome-software - ]) - config.environment.gnome.excludePackages; + environment.systemPackages = utils.removePackagesByName ( + [ + pkgs.baobab + pkgs.epiphany + pkgs.gnome-text-editor + pkgs.gnome-calculator + pkgs.gnome-calendar + pkgs.gnome-characters + pkgs.gnome-clocks + pkgs.gnome-console + pkgs.gnome-contacts + pkgs.gnome-font-viewer + pkgs.gnome-logs + pkgs.gnome-maps + pkgs.gnome-music + pkgs.gnome-system-monitor + pkgs.gnome-weather + pkgs.loupe + pkgs.nautilus + pkgs.gnome-connections + pkgs.simple-scan + pkgs.snapshot + pkgs.totem + pkgs.yelp + ] + ++ lib.optionals config.services.flatpak.enable [ + # Since PackageKit Nix support is not there yet, + # only install gnome-software if flatpak is enabled. + pkgs.gnome-software + ] + ) config.environment.gnome.excludePackages; # Enable default program modules # Since some of these have a corresponding package, we only @@ -486,7 +510,7 @@ in # it doesn't function well enough to be included # in default configurations. # https://github.com/NixOS/nixpkgs/issues/60908 - /* pkgs.gnome-boxes */ + # pkgs.gnome-boxes ] config.environment.gnome.excludePackages; services.sysprof.enable = notExcluded pkgs.sysprof; diff --git a/nixos/modules/services/x11/desktop-managers/kodi.nix b/nixos/modules/services/x11/desktop-managers/kodi.nix index b7c0af210b1438..0dd2f8ffb829ef 100644 --- a/nixos/modules/services/x11/desktop-managers/kodi.nix +++ b/nixos/modules/services/x11/desktop-managers/kodi.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -22,13 +27,15 @@ in }; config = mkIf cfg.enable { - services.xserver.desktopManager.session = [{ - name = "kodi"; - start = '' - LIRC_SOCKET_PATH=/run/lirc/lircd ${cfg.package}/bin/kodi --standalone & - waitPID=$! - ''; - }]; + services.xserver.desktopManager.session = [ + { + name = "kodi"; + start = '' + LIRC_SOCKET_PATH=/run/lirc/lircd ${cfg.package}/bin/kodi --standalone & + waitPID=$! + ''; + } + ]; environment.systemPackages = [ cfg.package ]; }; diff --git a/nixos/modules/services/x11/desktop-managers/lumina.nix b/nixos/modules/services/x11/desktop-managers/lumina.nix index 72411e8fcb5eb1..74fabced3af3ef 100644 --- a/nixos/modules/services/x11/desktop-managers/lumina.nix +++ b/nixos/modules/services/x11/desktop-managers/lumina.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -24,16 +29,13 @@ in }; - config = mkIf cfg.enable { services.displayManager.sessionPackages = [ pkgs.lumina.lumina ]; - environment.systemPackages = - pkgs.lumina.preRequisitePackages ++ - pkgs.lumina.corePackages; + environment.systemPackages = pkgs.lumina.preRequisitePackages ++ pkgs.lumina.corePackages; # Link some extra directories in /run/current-system/software/share environment.pathsToLink = [ diff --git a/nixos/modules/services/x11/desktop-managers/mate.nix b/nixos/modules/services/x11/desktop-managers/mate.nix index 19235be4aa8d52..e5144bc9d10287 100644 --- a/nixos/modules/services/x11/desktop-managers/mate.nix +++ b/nixos/modules/services/x11/desktop-managers/mate.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: with lib; @@ -39,7 +45,7 @@ in }; environment.mate.excludePackages = mkOption { - default = []; + default = [ ]; example = literalExpression "[ pkgs.mate.mate-terminal pkgs.mate.pluma ]"; type = types.listOf types.package; description = "Which MATE packages to exclude from the default environment"; @@ -56,10 +62,10 @@ in # Debugging environment.sessionVariables.MATE_SESSION_DEBUG = mkIf cfg.debug "1"; - environment.systemPackages = utils.removePackagesByName - (pkgs.mate.basePackages ++ - pkgs.mate.extraPackages ++ - [ + environment.systemPackages = utils.removePackagesByName ( + pkgs.mate.basePackages + ++ pkgs.mate.extraPackages + ++ [ (pkgs.mate.caja-with-extensions.override { extensions = cfg.extraCajaExtensions; }) @@ -72,8 +78,8 @@ in pkgs.shared-mime-info pkgs.xdg-user-dirs # Update user dirs as described in https://freedesktop.org/wiki/Software/xdg-user-dirs/ pkgs.yelp # for 'Contents' in 'Help' menus - ]) - config.environment.mate.excludePackages; + ] + ) config.environment.mate.excludePackages; programs.dconf.enable = true; # Shell integration for VTE terminals diff --git a/nixos/modules/services/x11/desktop-managers/none.nix b/nixos/modules/services/x11/desktop-managers/none.nix index f5b5e3104101e4..d4b7e3b392da9a 100644 --- a/nixos/modules/services/x11/desktop-managers/none.nix +++ b/nixos/modules/services/x11/desktop-managers/none.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let runXdgAutostart = config.services.xserver.desktopManager.runXdgAutostartIfNone; @@ -37,8 +42,14 @@ in systemd.user.targets.xdg-autostart-if-no-desktop-manager = { description = "Run XDG autostart files"; # From `plasma-workspace`, `share/systemd/user/plasma-workspace@.target`. - requires = [ "xdg-desktop-autostart.target" "graphical-session.target" ]; - before = [ "xdg-desktop-autostart.target" "graphical-session.target" ]; + requires = [ + "xdg-desktop-autostart.target" + "graphical-session.target" + ]; + before = [ + "xdg-desktop-autostart.target" + "graphical-session.target" + ]; bindsTo = [ "graphical-session.target" ]; }; }) diff --git a/nixos/modules/services/x11/desktop-managers/retroarch.nix b/nixos/modules/services/x11/desktop-managers/retroarch.nix index 3ee7b7795f6c9f..445de823e03f9b 100644 --- a/nixos/modules/services/x11/desktop-managers/retroarch.nix +++ b/nixos/modules/services/x11/desktop-managers/retroarch.nix @@ -1,10 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; -let cfg = config.services.xserver.desktopManager.retroarch; +let + cfg = config.services.xserver.desktopManager.retroarch; -in { +in +{ options.services.xserver.desktopManager.retroarch = { enable = mkEnableOption "RetroArch"; @@ -15,19 +22,24 @@ in { extraArgs = mkOption { type = types.listOf types.str; default = [ ]; - example = [ "--verbose" "--host" ]; + example = [ + "--verbose" + "--host" + ]; description = "Extra arguments to pass to RetroArch."; }; }; config = mkIf cfg.enable { - services.xserver.desktopManager.session = [{ - name = "RetroArch"; - start = '' - ${cfg.package}/bin/retroarch -f ${escapeShellArgs cfg.extraArgs} & - waitPID=$! - ''; - }]; + services.xserver.desktopManager.session = [ + { + name = "RetroArch"; + start = '' + ${cfg.package}/bin/retroarch -f ${escapeShellArgs cfg.extraArgs} & + waitPID=$! + ''; + } + ]; environment.systemPackages = [ cfg.package ]; }; diff --git a/nixos/modules/services/x11/desktop-managers/surf-display.nix b/nixos/modules/services/x11/desktop-managers/surf-display.nix index 10c4a1d21b0a58..519388cf11a598 100644 --- a/nixos/modules/services/x11/desktop-managers/surf-display.nix +++ b/nixos/modules/services/x11/desktop-managers/surf-display.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -42,7 +47,8 @@ let ${cfg.extraConfig} ''; -in { +in +{ options = { services.xserver.desktopManager.surf-display = { enable = mkEnableOption "surf-display as a kiosk browser session"; diff --git a/nixos/modules/services/x11/desktop-managers/xterm.nix b/nixos/modules/services/x11/desktop-managers/xterm.nix index 3424ee1b0e113e..c4db014db796cd 100644 --- a/nixos/modules/services/x11/desktop-managers/xterm.nix +++ b/nixos/modules/services/x11/desktop-managers/xterm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -23,13 +28,13 @@ in config = mkIf cfg.enable { - services.xserver.desktopManager.session = singleton - { name = "xterm"; - start = '' - ${pkgs.xterm}/bin/xterm -ls & - waitPID=$! - ''; - }; + services.xserver.desktopManager.session = singleton { + name = "xterm"; + start = '' + ${pkgs.xterm}/bin/xterm -ls & + waitPID=$! + ''; + }; environment.systemPackages = [ pkgs.xterm ]; diff --git a/nixos/modules/services/x11/display-managers/account-service-util.nix b/nixos/modules/services/x11/display-managers/account-service-util.nix index 00ffd91cb2f6df..93affdef3fc83a 100644 --- a/nixos/modules/services/x11/display-managers/account-service-util.nix +++ b/nixos/modules/services/x11/display-managers/account-service-util.nix @@ -1,9 +1,10 @@ -{ accountsservice -, glib -, gobject-introspection -, python3 -, wrapGAppsNoGuiHook -, lib +{ + accountsservice, + glib, + gobject-introspection, + python3, + wrapGAppsNoGuiHook, + lib, }: python3.pkgs.buildPythonApplication { diff --git a/nixos/modules/services/x11/display-managers/gdm.nix b/nixos/modules/services/x11/display-managers/gdm.nix index 5ec06767f51bf7..a960b546f61426 100644 --- a/nixos/modules/services/x11/display-managers/gdm.nix +++ b/nixos/modules/services/x11/display-managers/gdm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let @@ -8,12 +13,15 @@ let settingsFormat = pkgs.formats.ini { }; configFile = settingsFormat.generate "custom.conf" cfg.gdm.settings; - xSessionWrapper = if (cfg.setupCommands == "") then null else - pkgs.writeScript "gdm-x-session-wrapper" '' - #!${pkgs.bash}/bin/bash - ${cfg.setupCommands} - exec "$@" - ''; + xSessionWrapper = + if (cfg.setupCommands == "") then + null + else + pkgs.writeScript "gdm-x-session-wrapper" '' + #!${pkgs.bash}/bin/bash + ${cfg.setupCommands} + exec "$@" + ''; # Solves problems like: # https://wiki.archlinux.org/index.php/Talk:Bluetooth_headset#GDMs_pulseaudio_instance_captures_bluetooth_headset @@ -38,20 +46,32 @@ in { imports = [ - (lib.mkRenamedOptionModule [ "services" "xserver" "displayManager" "gdm" "autoLogin" "enable" ] [ - "services" - "displayManager" - "autoLogin" - "enable" - ]) - (lib.mkRenamedOptionModule [ "services" "xserver" "displayManager" "gdm" "autoLogin" "user" ] [ + (lib.mkRenamedOptionModule + [ "services" "xserver" "displayManager" "gdm" "autoLogin" "enable" ] + [ + "services" + "displayManager" + "autoLogin" + "enable" + ] + ) + (lib.mkRenamedOptionModule + [ "services" "xserver" "displayManager" "gdm" "autoLogin" "user" ] + [ + "services" + "displayManager" + "autoLogin" + "user" + ] + ) + + (lib.mkRemovedOptionModule [ "services" + "xserver" "displayManager" - "autoLogin" - "user" - ]) - - (lib.mkRemovedOptionModule [ "services" "xserver" "displayManager" "gdm" "nvidiaWayland" ] "We defer to GDM whether Wayland should be enabled.") + "gdm" + "nvidiaWayland" + ] "We defer to GDM whether Wayland should be enabled.") ]; meta = { @@ -123,20 +143,19 @@ in }; - ###### implementation config = lib.mkIf cfg.gdm.enable { services.xserver.displayManager.lightdm.enable = false; - users.users.gdm = - { name = "gdm"; - uid = config.ids.uids.gdm; - group = "gdm"; - home = "/run/gdm"; - description = "GDM user"; - }; + users.users.gdm = { + name = "gdm"; + uid = config.ids.uids.gdm; + group = "gdm"; + home = "/run/gdm"; + description = "GDM user"; + }; users.groups.gdm.gid = config.ids.gids.gdm; @@ -145,14 +164,13 @@ in services.xserver.display = null; services.xserver.verbose = null; - services.displayManager = - { - # Enable desktop session data - enable = true; + services.displayManager = { + # Enable desktop session data + enable = true; - environment = { - GDM_X_SERVER_EXTRA_ARGS = toString - (lib.filter (arg: arg != "-terminate") cfg.xserverArgs); + environment = + { + GDM_X_SERVER_EXTRA_ARGS = toString (lib.filter (arg: arg != "-terminate") cfg.xserverArgs); XDG_DATA_DIRS = lib.makeSearchPath "share" [ gdm # for gnome-login.session config.services.displayManager.sessionData.desktops @@ -160,28 +178,32 @@ in pkgs.adwaita-icon-theme pkgs.hicolor-icon-theme # empty icon theme as a base ]; - } // lib.optionalAttrs (xSessionWrapper != null) { + } + // lib.optionalAttrs (xSessionWrapper != null) { # Make GDM use this wrapper before running the session, which runs the # configured setupCommands. This relies on a patched GDM which supports # this environment variable. GDM_X_SESSION_WRAPPER = "${xSessionWrapper}"; }; - execCmd = "exec ${gdm}/bin/gdm"; - preStart = lib.optionalString (defaultSessionName != null) '' - # Set default session in session chooser to a specified values – basically ignore session history. - ${setSessionScript}/bin/set-session ${config.services.displayManager.sessionData.autologinSession} - ''; - }; + execCmd = "exec ${gdm}/bin/gdm"; + preStart = lib.optionalString (defaultSessionName != null) '' + # Set default session in session chooser to a specified values – basically ignore session history. + ${setSessionScript}/bin/set-session ${config.services.displayManager.sessionData.autologinSession} + ''; + }; - systemd.tmpfiles.rules = [ - "d /run/gdm/.config 0711 gdm gdm" - ] ++ lib.optionals config.hardware.pulseaudio.enable [ - "d /run/gdm/.config/pulse 0711 gdm gdm" - "L+ /run/gdm/.config/pulse/${pulseConfig.name} - - - - ${pulseConfig}" - ] ++ lib.optionals config.services.gnome.gnome-initial-setup.enable [ - # Create stamp file for gnome-initial-setup to prevent it starting in GDM. - "f /run/gdm/.config/gnome-initial-setup-done 0711 gdm gdm - yes" - ]; + systemd.tmpfiles.rules = + [ + "d /run/gdm/.config 0711 gdm gdm" + ] + ++ lib.optionals config.hardware.pulseaudio.enable [ + "d /run/gdm/.config/pulse 0711 gdm gdm" + "L+ /run/gdm/.config/pulse/${pulseConfig.name} - - - - ${pulseConfig}" + ] + ++ lib.optionals config.services.gnome.gnome-initial-setup.enable [ + # Create stamp file for gnome-initial-setup to prevent it starting in GDM. + "f /run/gdm/.config/gnome-initial-setup-done 0711 gdm gdm - yes" + ]; # Otherwise GDM will not be able to start correctly and display Wayland sessions systemd.packages = with pkgs.gnome; [ @@ -225,7 +247,7 @@ in # switch starts multi-user.target, display-manager.service is # stopped so plymouth-quit.service can be started.) systemd.services.plymouth-quit = lib.mkIf config.boot.plymouth.enable { - wantedBy = lib.mkForce []; + wantedBy = lib.mkForce [ ]; }; systemd.services.display-manager.serviceConfig = { @@ -248,19 +270,26 @@ in systemd.user.services.dbus.wantedBy = [ "default.target" ]; - programs.dconf.profiles.gdm.databases = lib.optionals (!cfg.gdm.autoSuspend) [{ - settings."org/gnome/settings-daemon/plugins/power" = { - sleep-inactive-ac-type = "nothing"; - sleep-inactive-battery-type = "nothing"; - sleep-inactive-ac-timeout = lib.gvariant.mkInt32 0; - sleep-inactive-battery-timeout = lib.gvariant.mkInt32 0; - }; - }] ++ lib.optionals (cfg.gdm.banner != null) [{ - settings."org/gnome/login-screen" = { - banner-message-enable = true; - banner-message-text = cfg.gdm.banner; - }; - }] ++ [ "${gdm}/share/gdm/greeter-dconf-defaults" ]; + programs.dconf.profiles.gdm.databases = + lib.optionals (!cfg.gdm.autoSuspend) [ + { + settings."org/gnome/settings-daemon/plugins/power" = { + sleep-inactive-ac-type = "nothing"; + sleep-inactive-battery-type = "nothing"; + sleep-inactive-ac-timeout = lib.gvariant.mkInt32 0; + sleep-inactive-battery-timeout = lib.gvariant.mkInt32 0; + }; + } + ] + ++ lib.optionals (cfg.gdm.banner != null) [ + { + settings."org/gnome/login-screen" = { + banner-message-enable = true; + banner-message-text = cfg.gdm.banner; + }; + } + ] + ++ [ "${gdm}/share/gdm/greeter-dconf-defaults" ]; # Use AutomaticLogin if delay is zero, because it's immediate. # Otherwise with TimedLogin with zero seconds the prompt is still @@ -269,12 +298,12 @@ in daemon = lib.mkMerge [ { WaylandEnable = cfg.gdm.wayland; } # nested if else didn't work - (lib.mkIf (config.services.displayManager.autoLogin.enable && cfg.gdm.autoLogin.delay != 0 ) { + (lib.mkIf (config.services.displayManager.autoLogin.enable && cfg.gdm.autoLogin.delay != 0) { TimedLoginEnable = true; TimedLogin = config.services.displayManager.autoLogin.user; TimedLoginDelay = cfg.gdm.autoLogin.delay; }) - (lib.mkIf (config.services.displayManager.autoLogin.enable && cfg.gdm.autoLogin.delay == 0 ) { + (lib.mkIf (config.services.displayManager.autoLogin.enable && cfg.gdm.autoLogin.delay == 0) { AutomaticLoginEnable = true; AutomaticLogin = config.services.displayManager.autoLogin.user; }) diff --git a/nixos/modules/services/x11/display-managers/lightdm-greeters/enso-os.nix b/nixos/modules/services/x11/display-managers/lightdm-greeters/enso-os.nix index 8975d6fb9f0f72..85de2ce6284979 100644 --- a/nixos/modules/services/x11/display-managers/lightdm-greeters/enso-os.nix +++ b/nixos/modules/services/x11/display-managers/lightdm-greeters/enso-os.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let @@ -20,7 +25,8 @@ let brightness=${toString cfg.brightness} ${cfg.extraConfig} ''; -in { +in +{ options = { services.xserver.displayManager.lightdm.greeters.enso = { enable = mkOption { diff --git a/nixos/modules/services/x11/display-managers/lightdm-greeters/gtk.nix b/nixos/modules/services/x11/display-managers/lightdm-greeters/gtk.nix index 0907aeb839ba35..468ab09c66a564 100644 --- a/nixos/modules/services/x11/display-managers/lightdm-greeters/gtk.nix +++ b/nixos/modules/services/x11/display-managers/lightdm-greeters/gtk.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -15,8 +20,7 @@ let icons = cfg.iconTheme.package; cursors = cfg.cursorTheme.package; - gtkGreeterConf = writeText "lightdm-gtk-greeter.conf" - '' + gtkGreeterConf = writeText "lightdm-gtk-greeter.conf" '' [greeter] theme-name = ${cfg.theme.name} icon-theme-name = ${cfg.iconTheme.name} @@ -27,7 +31,7 @@ let ${optionalString (cfg.indicators != null) "indicators = ${concatStringsSep ";" cfg.indicators}"} ${optionalString (xcfg.dpi != null) "xft-dpi=${toString xcfg.dpi}"} ${cfg.extraConfig} - ''; + ''; in { @@ -128,7 +132,16 @@ in indicators = mkOption { type = types.nullOr (types.listOf types.str); default = null; - example = [ "~host" "~spacer" "~clock" "~spacer" "~session" "~language" "~a11y" "~power" ]; + example = [ + "~host" + "~spacer" + "~clock" + "~spacer" + "~session" + "~language" + "~a11y" + "~power" + ]; description = '' List of allowed indicator modules to use for the lightdm gtk greeter panel. diff --git a/nixos/modules/services/x11/display-managers/lightdm-greeters/mini.nix b/nixos/modules/services/x11/display-managers/lightdm-greeters/mini.nix index 05e21c7211fa28..a3fca737a2b2b1 100644 --- a/nixos/modules/services/x11/display-managers/lightdm-greeters/mini.nix +++ b/nixos/modules/services/x11/display-managers/lightdm-greeters/mini.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -8,8 +13,7 @@ let ldmcfg = dmcfg.lightdm; cfg = ldmcfg.greeters.mini; - miniGreeterConf = pkgs.writeText "lightdm-mini-greeter.conf" - '' + miniGreeterConf = pkgs.writeText "lightdm-mini-greeter.conf" '' [greeter] user = ${cfg.user} show-password-label = true @@ -44,7 +48,7 @@ let password-border-width = 2px ${cfg.extraConfig} - ''; + ''; in { diff --git a/nixos/modules/services/x11/display-managers/lightdm-greeters/mobile.nix b/nixos/modules/services/x11/display-managers/lightdm-greeters/mobile.nix index e67d8e1dcb894d..5d8edbe7c59e66 100644 --- a/nixos/modules/services/x11/display-managers/lightdm-greeters/mobile.nix +++ b/nixos/modules/services/x11/display-managers/lightdm-greeters/mobile.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let @@ -9,8 +14,7 @@ in { options = { services.xserver.displayManager.lightdm.greeters.mobile = { - enable = mkEnableOption - "lightdm-mobile-greeter as the lightdm greeter"; + enable = mkEnableOption "lightdm-mobile-greeter as the lightdm greeter"; }; }; diff --git a/nixos/modules/services/x11/display-managers/lightdm-greeters/pantheon.nix b/nixos/modules/services/x11/display-managers/lightdm-greeters/pantheon.nix index f18e4a914e5799..f598fd1171a2f4 100644 --- a/nixos/modules/services/x11/display-managers/lightdm-greeters/pantheon.nix +++ b/nixos/modules/services/x11/display-managers/lightdm-greeters/pantheon.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -42,8 +47,10 @@ in # Show manual login card. services.xserver.displayManager.lightdm.extraSeatDefaults = "greeter-show-manual-login=true"; - environment.etc."lightdm/io.elementary.greeter.conf".source = "${pkgs.pantheon.elementary-greeter}/etc/lightdm/io.elementary.greeter.conf"; - environment.etc."wingpanel.d/io.elementary.greeter.allowed".source = "${pkgs.pantheon.elementary-default-settings}/etc/wingpanel.d/io.elementary.greeter.allowed"; + environment.etc."lightdm/io.elementary.greeter.conf".source = + "${pkgs.pantheon.elementary-greeter}/etc/lightdm/io.elementary.greeter.conf"; + environment.etc."wingpanel.d/io.elementary.greeter.allowed".source = + "${pkgs.pantheon.elementary-default-settings}/etc/wingpanel.d/io.elementary.greeter.allowed"; }; } diff --git a/nixos/modules/services/x11/display-managers/lightdm-greeters/slick.nix b/nixos/modules/services/x11/display-managers/lightdm-greeters/slick.nix index 4758b8d94eda29..e2d83ce5dcb4f1 100644 --- a/nixos/modules/services/x11/display-managers/lightdm-greeters/slick.nix +++ b/nixos/modules/services/x11/display-managers/lightdm-greeters/slick.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/display-managers/lightdm-greeters/tiny.nix b/nixos/modules/services/x11/display-managers/lightdm-greeters/tiny.nix index 835cf049e4ee59..4780468533de1c 100644 --- a/nixos/modules/services/x11/display-managers/lightdm-greeters/tiny.nix +++ b/nixos/modules/services/x11/display-managers/lightdm-greeters/tiny.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -44,7 +49,6 @@ in }; }; - extraConfig = mkOption { type = types.lines; default = ""; @@ -62,16 +66,16 @@ in services.xserver.displayManager.lightdm.greeters.gtk.enable = false; services.xserver.displayManager.lightdm.greeter = - let - configHeader = '' - #include - static const char *user_text = "${cfg.label.user}"; - static const char *pass_text = "${cfg.label.pass}"; - static const char *session = "${dmcfg.defaultSession}"; - ''; - config = optionalString (cfg.extraConfig != "") (configHeader + cfg.extraConfig); - package = pkgs.lightdm-tiny-greeter.override { conf = config; }; - in + let + configHeader = '' + #include + static const char *user_text = "${cfg.label.user}"; + static const char *pass_text = "${cfg.label.pass}"; + static const char *session = "${dmcfg.defaultSession}"; + ''; + config = optionalString (cfg.extraConfig != "") (configHeader + cfg.extraConfig); + package = pkgs.lightdm-tiny-greeter.override { conf = config; }; + in mkDefault { package = package.xgreeters; name = "lightdm-tiny-greeter"; diff --git a/nixos/modules/services/x11/display-managers/lightdm.nix b/nixos/modules/services/x11/display-managers/lightdm.nix index 25e6c597adcbd3..3e964ef53266d0 100644 --- a/nixos/modules/services/x11/display-managers/lightdm.nix +++ b/nixos/modules/services/x11/display-managers/lightdm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -15,57 +20,54 @@ let inherit (pkgs) lightdm writeScript writeText; # lightdm runs with clearenv(), but we need a few things in the environment for X to startup - xserverWrapper = writeScript "xserver-wrapper" - '' - #! ${pkgs.bash}/bin/bash - ${concatMapStrings (n: "export ${n}=\"${getAttr n xEnv}\"\n") (attrNames xEnv)} - - display=$(echo "$@" | xargs -n 1 | grep -P ^:\\d\$ | head -n 1 | sed s/^://) - if [ -z "$display" ] - then additionalArgs=":0 -logfile /var/log/X.0.log" - else additionalArgs="-logfile /var/log/X.$display.log" - fi - - exec ${xcfg.displayManager.xserverBin} ${toString xcfg.displayManager.xserverArgs} $additionalArgs "$@" - ''; - - usersConf = writeText "users.conf" - '' - [UserList] - minimum-uid=1000 - hidden-users=${concatStringsSep " " dmcfg.hiddenUsers} - hidden-shells=/run/current-system/sw/bin/nologin - ''; - - lightdmConf = writeText "lightdm.conf" - '' - [LightDM] - ${optionalString cfg.greeter.enable '' - greeter-user = ${config.users.users.lightdm.name} - greeters-directory = ${cfg.greeter.package} - ''} - sessions-directory = ${dmcfg.sessionData.desktops}/share/xsessions:${dmcfg.sessionData.desktops}/share/wayland-sessions - ${cfg.extraConfig} - - [Seat:*] - xserver-command = ${xserverWrapper} - session-wrapper = ${dmcfg.sessionData.wrapper} - ${optionalString cfg.greeter.enable '' - greeter-session = ${cfg.greeter.name} + xserverWrapper = writeScript "xserver-wrapper" '' + #! ${pkgs.bash}/bin/bash + ${concatMapStrings (n: "export ${n}=\"${getAttr n xEnv}\"\n") (attrNames xEnv)} + + display=$(echo "$@" | xargs -n 1 | grep -P ^:\\d\$ | head -n 1 | sed s/^://) + if [ -z "$display" ] + then additionalArgs=":0 -logfile /var/log/X.0.log" + else additionalArgs="-logfile /var/log/X.$display.log" + fi + + exec ${xcfg.displayManager.xserverBin} ${toString xcfg.displayManager.xserverArgs} $additionalArgs "$@" + ''; + + usersConf = writeText "users.conf" '' + [UserList] + minimum-uid=1000 + hidden-users=${concatStringsSep " " dmcfg.hiddenUsers} + hidden-shells=/run/current-system/sw/bin/nologin + ''; + + lightdmConf = writeText "lightdm.conf" '' + [LightDM] + ${optionalString cfg.greeter.enable '' + greeter-user = ${config.users.users.lightdm.name} + greeters-directory = ${cfg.greeter.package} + ''} + sessions-directory = ${dmcfg.sessionData.desktops}/share/xsessions:${dmcfg.sessionData.desktops}/share/wayland-sessions + ${cfg.extraConfig} + + [Seat:*] + xserver-command = ${xserverWrapper} + session-wrapper = ${dmcfg.sessionData.wrapper} + ${optionalString cfg.greeter.enable '' + greeter-session = ${cfg.greeter.name} + ''} + ${optionalString dmcfg.autoLogin.enable '' + autologin-user = ${dmcfg.autoLogin.user} + autologin-user-timeout = ${toString cfg.autoLogin.timeout} + autologin-session = ${sessionData.autologinSession} + ''} + ${optionalString (xcfg.displayManager.setupCommands != "") '' + display-setup-script=${pkgs.writeScript "lightdm-display-setup" '' + #!${pkgs.bash}/bin/bash + ${xcfg.displayManager.setupCommands} ''} - ${optionalString dmcfg.autoLogin.enable '' - autologin-user = ${dmcfg.autoLogin.user} - autologin-user-timeout = ${toString cfg.autoLogin.timeout} - autologin-session = ${sessionData.autologinSession} - ''} - ${optionalString (xcfg.displayManager.setupCommands != "") '' - display-setup-script=${pkgs.writeScript "lightdm-display-setup" '' - #!${pkgs.bash}/bin/bash - ${xcfg.displayManager.setupCommands} - ''} - ''} - ${cfg.extraSeatDefaults} - ''; + ''} + ${cfg.extraSeatDefaults} + ''; in { @@ -85,18 +87,24 @@ in ./lightdm-greeters/tiny.nix ./lightdm-greeters/slick.nix ./lightdm-greeters/mobile.nix - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "lightdm" "autoLogin" "enable" ] [ - "services" - "displayManager" - "autoLogin" - "enable" - ]) - (mkRenamedOptionModule [ "services" "xserver" "displayManager" "lightdm" "autoLogin" "user" ] [ - "services" - "displayManager" - "autoLogin" - "user" - ]) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "lightdm" "autoLogin" "enable" ] + [ + "services" + "displayManager" + "autoLogin" + "enable" + ] + ) + (mkRenamedOptionModule + [ "services" "xserver" "displayManager" "lightdm" "autoLogin" "user" ] + [ + "services" + "displayManager" + "autoLogin" + "user" + ] + ) ]; options = { @@ -111,7 +119,7 @@ in ''; }; - greeter = { + greeter = { enable = mkOption { type = types.bool; default = true; @@ -179,17 +187,20 @@ in config = mkIf cfg.enable { assertions = [ - { assertion = xcfg.enable; + { + assertion = xcfg.enable; message = '' LightDM requires services.xserver.enable to be true ''; } - { assertion = dmcfg.autoLogin.enable -> sessionData.autologinSession != null; + { + assertion = dmcfg.autoLogin.enable -> sessionData.autologinSession != null; message = '' LightDM auto-login requires that services.displayManager.defaultSession is set. ''; } - { assertion = !cfg.greeter.enable -> (dmcfg.autoLogin.enable && cfg.autoLogin.timeout == 0); + { + assertion = !cfg.greeter.enable -> (dmcfg.autoLogin.enable && cfg.autoLogin.timeout == 0); message = '' LightDM can only run without greeter if automatic login is enabled and the timeout for it is set to zero. @@ -198,13 +209,16 @@ in ]; # Keep in sync with the defaultText value from the option definition. - services.xserver.displayManager.lightdm.background = mkDefault pkgs.nixos-artwork.wallpapers.simple-dark-gray-bottom.gnomeFilePath; + services.xserver.displayManager.lightdm.background = + mkDefault pkgs.nixos-artwork.wallpapers.simple-dark-gray-bottom.gnomeFilePath; # Set default session in session chooser to a specified values – basically ignore session history. # Auto-login is already covered by a config value. - services.displayManager.preStart = optionalString (!dmcfg.autoLogin.enable && dmcfg.defaultSession != null) '' - ${setSessionScript}/bin/set-session ${dmcfg.defaultSession} - ''; + services.displayManager.preStart = + optionalString (!dmcfg.autoLogin.enable && dmcfg.defaultSession != null) + '' + ${setSessionScript}/bin/set-session ${dmcfg.defaultSession} + ''; # setSessionScript needs session-files in XDG_DATA_DIRS services.displayManager.environment.XDG_DATA_DIRS = "${dmcfg.sessionData.desktops}/share/"; @@ -225,7 +239,7 @@ in "getty@tty7.service" # TODO: Add "plymouth-quit.service" so LightDM can control when plymouth # quits. Currently this breaks switching to configurations with plymouth. - ]; + ]; # Pull in dependencies of services we replace. systemd.services.display-manager.after = [ @@ -271,40 +285,40 @@ in security.polkit.enable = true; security.pam.services.lightdm.text = '' - auth substack login - account include login - password substack login - session include login + auth substack login + account include login + password substack login + session include login ''; security.pam.services.lightdm-greeter.text = '' - auth required pam_succeed_if.so audit quiet_success user = lightdm - auth optional pam_permit.so + auth required pam_succeed_if.so audit quiet_success user = lightdm + auth optional pam_permit.so - account required pam_succeed_if.so audit quiet_success user = lightdm - account sufficient pam_unix.so + account required pam_succeed_if.so audit quiet_success user = lightdm + account sufficient pam_unix.so - password required pam_deny.so + password required pam_deny.so - session required pam_succeed_if.so audit quiet_success user = lightdm - session required pam_env.so conffile=/etc/pam/environment readenv=0 - session optional ${config.systemd.package}/lib/security/pam_systemd.so - session optional pam_keyinit.so force revoke - session optional pam_permit.so + session required pam_succeed_if.so audit quiet_success user = lightdm + session required pam_env.so conffile=/etc/pam/environment readenv=0 + session optional ${config.systemd.package}/lib/security/pam_systemd.so + session optional pam_keyinit.so force revoke + session optional pam_permit.so ''; security.pam.services.lightdm-autologin.text = '' - auth requisite pam_nologin.so + auth requisite pam_nologin.so - auth required pam_succeed_if.so uid >= 1000 quiet - auth required pam_permit.so + auth required pam_succeed_if.so uid >= 1000 quiet + auth required pam_permit.so - account sufficient pam_unix.so + account sufficient pam_unix.so - password requisite pam_unix.so nullok yescrypt + password requisite pam_unix.so nullok yescrypt - session optional pam_keyinit.so revoke - session include login + session optional pam_keyinit.so revoke + session include login ''; users.users.lightdm = { @@ -322,7 +336,7 @@ in ]; users.groups.lightdm.gid = config.ids.gids.lightdm; - services.xserver.tty = null; # We might start multiple X servers so let the tty increment themselves.. + services.xserver.tty = null; # We might start multiple X servers so let the tty increment themselves.. services.xserver.display = null; # We specify our own display (and logfile) in xserver-wrapper up there }; } diff --git a/nixos/modules/services/x11/display-managers/slim.nix b/nixos/modules/services/x11/display-managers/slim.nix index 4b0948a5b7a540..c5963b0be7ec81 100644 --- a/nixos/modules/services/x11/display-managers/slim.nix +++ b/nixos/modules/services/x11/display-managers/slim.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/display-managers/startx.nix b/nixos/modules/services/x11/display-managers/startx.nix index a48566ae068416..a990c9ed5ea531 100644 --- a/nixos/modules/services/x11/display-managers/startx.nix +++ b/nixos/modules/services/x11/display-managers/startx.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -29,7 +34,6 @@ in }; }; - ###### implementation config = mkIf cfg.enable { @@ -48,7 +52,7 @@ in environment.etc."X11/xinit/xserverrc".source = pkgs.writeShellScript "xserverrc" '' exec ${pkgs.xorg.xorgserver}/bin/X ${toString config.services.xserver.displayManager.xserverArgs} "$@" ''; - environment.systemPackages = with pkgs; [ xorg.xinit ]; + environment.systemPackages = with pkgs; [ xorg.xinit ]; }; } diff --git a/nixos/modules/services/x11/extra-layouts.nix b/nixos/modules/services/x11/extra-layouts.nix index 758abc5750cb03..0327609c25cd9f 100644 --- a/nixos/modules/services/x11/extra-layouts.nix +++ b/nixos/modules/services/x11/extra-layouts.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -15,9 +20,9 @@ let languages = mkOption { type = types.listOf types.str; description = '' - A list of languages provided by the layout. - (Use ISO 639-2 codes, for example: "eng" for english) - ''; + A list of languages provided by the layout. + (Use ISO 639-2 codes, for example: "eng" for english) + ''; }; compatFile = mkOption { @@ -89,8 +94,17 @@ in imports = [ (lib.mkRenamedOptionModuleWith { sinceRelease = 2311; - from = [ "services" "xserver" "extraLayouts" ]; - to = [ "services" "xserver" "xkb" "extraLayouts" ]; + from = [ + "services" + "xserver" + "extraLayouts" + ]; + to = [ + "services" + "xserver" + "xkb" + "extraLayouts" + ]; }) ]; @@ -100,16 +114,15 @@ in extraLayouts = mkOption { type = types.attrsOf (types.submodule layoutOpts); default = { }; - example = literalExpression - '' - { - mine = { - description = "My custom xkb layout."; - languages = [ "eng" ]; - symbolsFile = /path/to/my/layout; - }; - } - ''; + example = literalExpression '' + { + mine = { + description = "My custom xkb layout."; + languages = [ "eng" ]; + symbolsFile = /path/to/my/layout; + }; + } + ''; description = '' Extra custom layouts that will be included in the xkb configuration. Information on how to create a new layout can be found here: @@ -133,7 +146,8 @@ in services.xserver = { xkb.dir = "${xkb_patched}/etc/X11/xkb"; - exportConfiguration = config.services.xserver.displayManager.startx.enable + exportConfiguration = + config.services.xserver.displayManager.startx.enable || config.services.xserver.displayManager.sx.enable; }; diff --git a/nixos/modules/services/x11/fractalart.nix b/nixos/modules/services/x11/fractalart.nix index 448248a58794db..9ec64abc904985 100644 --- a/nixos/modules/services/x11/fractalart.nix +++ b/nixos/modules/services/x11/fractalart.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.fractalart; -in { +in +{ options.services.fractalart = { enable = mkOption { type = types.bool; @@ -30,7 +36,7 @@ in { environment.systemPackages = [ pkgs.haskellPackages.FractalArt ]; services.xserver.displayManager.sessionCommands = "${pkgs.haskellPackages.FractalArt}/bin/FractalArt --no-bg -f .background-image" - + optionalString (cfg.width != null) " -w ${toString cfg.width}" - + optionalString (cfg.height != null) " -h ${toString cfg.height}"; + + optionalString (cfg.width != null) " -w ${toString cfg.width}" + + optionalString (cfg.height != null) " -h ${toString cfg.height}"; }; } diff --git a/nixos/modules/services/x11/hardware/cmt.nix b/nixos/modules/services/x11/hardware/cmt.nix index 53906c5c716f43..23f07e5de06e72 100644 --- a/nixos/modules/services/x11/hardware/cmt.nix +++ b/nixos/modules/services/x11/hardware/cmt.nix @@ -1,13 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let -cfg = config.services.xserver.cmt; -etcPath = "X11/xorg.conf.d"; + cfg = config.services.xserver.cmt; + etcPath = "X11/xorg.conf.d"; -in { +in +{ options = { @@ -18,15 +24,64 @@ in { description = "Enable chrome multitouch input (cmt). Touchpad drivers that are configured for chromebooks."; }; models = mkOption { - type = types.enum [ "atlas" "banjo" "candy" "caroline" "cave" "celes" "clapper" "cyan" "daisy" "elan" "elm" "enguarde" "eve" "expresso" "falco" "gandof" "glimmer" "gnawty" "heli" "kevin" "kip" "leon" "lulu" "orco" "pbody" "peppy" "pi" "pit" "puppy" "quawks" "rambi" "samus" "snappy" "spring" "squawks" "swanky" "winky" "wolf" "auron_paine" "auron_yuna" "daisy_skate" "nyan_big" "nyan_blaze" "veyron_jaq" "veyron_jerry" "veyron_mighty" "veyron_minnie" "veyron_speedy" ]; + type = types.enum [ + "atlas" + "banjo" + "candy" + "caroline" + "cave" + "celes" + "clapper" + "cyan" + "daisy" + "elan" + "elm" + "enguarde" + "eve" + "expresso" + "falco" + "gandof" + "glimmer" + "gnawty" + "heli" + "kevin" + "kip" + "leon" + "lulu" + "orco" + "pbody" + "peppy" + "pi" + "pit" + "puppy" + "quawks" + "rambi" + "samus" + "snappy" + "spring" + "squawks" + "swanky" + "winky" + "wolf" + "auron_paine" + "auron_yuna" + "daisy_skate" + "nyan_big" + "nyan_blaze" + "veyron_jaq" + "veyron_jerry" + "veyron_mighty" + "veyron_minnie" + "veyron_speedy" + ]; example = "banjo"; description = '' Which models to enable cmt for. Enter the Code Name for your Chromebook. Code Name can be found at . ''; }; - }; #closes services - }; #closes options + }; # closes services + }; # closes options config = mkIf cfg.enable { diff --git a/nixos/modules/services/x11/hardware/digimend.nix b/nixos/modules/services/x11/hardware/digimend.nix index b1b1682f00b27d..693db5e90720a8 100644 --- a/nixos/modules/services/x11/hardware/digimend.nix +++ b/nixos/modules/services/x11/hardware/digimend.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -22,7 +27,6 @@ in }; - config = mkIf cfg.enable { # digimend drivers use xsetwacom and wacom X11 drivers diff --git a/nixos/modules/services/x11/hardware/synaptics.nix b/nixos/modules/services/x11/hardware/synaptics.nix index c43fdac6b1ec6b..f943242f7bae17 100644 --- a/nixos/modules/services/x11/hardware/synaptics.nix +++ b/nixos/modules/services/x11/hardware/synaptics.nix @@ -1,27 +1,35 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with lib; -let cfg = config.services.xserver.synaptics; - opt = options.services.xserver.synaptics; - tapConfig = if cfg.tapButtons then enabledTapConfig else disabledTapConfig; - enabledTapConfig = '' - Option "MaxTapTime" "180" - Option "MaxTapMove" "220" - Option "TapButton1" "${builtins.elemAt cfg.fingersMap 0}" - Option "TapButton2" "${builtins.elemAt cfg.fingersMap 1}" - Option "TapButton3" "${builtins.elemAt cfg.fingersMap 2}" - ''; - disabledTapConfig = '' - Option "MaxTapTime" "0" - Option "MaxTapMove" "0" - Option "TapButton1" "0" - Option "TapButton2" "0" - Option "TapButton3" "0" - ''; +let + cfg = config.services.xserver.synaptics; + opt = options.services.xserver.synaptics; + tapConfig = if cfg.tapButtons then enabledTapConfig else disabledTapConfig; + enabledTapConfig = '' + Option "MaxTapTime" "180" + Option "MaxTapMove" "220" + Option "TapButton1" "${builtins.elemAt cfg.fingersMap 0}" + Option "TapButton2" "${builtins.elemAt cfg.fingersMap 1}" + Option "TapButton3" "${builtins.elemAt cfg.fingersMap 2}" + ''; + disabledTapConfig = '' + Option "MaxTapTime" "0" + Option "MaxTapMove" "0" + Option "TapButton1" "0" + Option "TapButton2" "0" + Option "TapButton3" "0" + ''; pkg = pkgs.xorg.xf86inputsynaptics; etcFile = "X11/xorg.conf.d/70-synaptics.conf"; -in { +in +{ options = { @@ -38,9 +46,9 @@ in { default = null; example = "/dev/input/event0"; description = '' - Path for touchpad device. Set to null to apply to any - auto-detected touchpad. - ''; + Path for touchpad device. Set to null to apply to any + auto-detected touchpad. + ''; }; accelFactor = mkOption { @@ -90,14 +98,14 @@ in { horizEdgeScroll = mkOption { type = types.bool; - default = ! cfg.horizTwoFingerScroll; + default = !cfg.horizTwoFingerScroll; defaultText = literalExpression "! config.${opt.horizTwoFingerScroll}"; description = "Whether to enable horizontal edge drag-scrolling."; }; vertEdgeScroll = mkOption { type = types.bool; - default = ! cfg.vertTwoFingerScroll; + default = !cfg.vertTwoFingerScroll; defaultText = literalExpression "! config.${opt.vertTwoFingerScroll}"; description = "Whether to enable vertical edge drag-scrolling."; }; @@ -110,16 +118,32 @@ in { buttonsMap = mkOption { type = types.listOf types.int; - default = [1 2 3]; - example = [1 3 2]; + default = [ + 1 + 2 + 3 + ]; + example = [ + 1 + 3 + 2 + ]; description = "Remap touchpad buttons."; apply = map toString; }; fingersMap = mkOption { type = types.listOf types.int; - default = [1 2 3]; - example = [1 3 2]; + default = [ + 1 + 2 + 3 + ]; + example = [ + 1 + 3 + 2 + ]; description = "Remap several-fingers taps."; apply = map toString; }; @@ -166,44 +190,51 @@ in { }; - config = mkIf cfg.enable { services.xserver.modules = [ pkg.out ]; - environment.etc.${etcFile}.source = - "${pkg.out}/share/X11/xorg.conf.d/70-synaptics.conf"; + environment.etc.${etcFile}.source = "${pkg.out}/share/X11/xorg.conf.d/70-synaptics.conf"; environment.systemPackages = [ pkg ]; - services.xserver.config = - '' - # Automatically enable the synaptics driver for all touchpads. - Section "InputClass" - Identifier "synaptics touchpad catchall" - MatchIsTouchpad "on" - ${optionalString (cfg.dev != null) ''MatchDevicePath "${cfg.dev}"''} - Driver "synaptics" - ${optionalString (cfg.minSpeed != null) ''Option "MinSpeed" "${cfg.minSpeed}"''} - ${optionalString (cfg.maxSpeed != null) ''Option "MaxSpeed" "${cfg.maxSpeed}"''} - ${optionalString (cfg.accelFactor != null) ''Option "AccelFactor" "${cfg.accelFactor}"''} - ${optionalString cfg.tapButtons tapConfig} - Option "ClickFinger1" "${builtins.elemAt cfg.buttonsMap 0}" - Option "ClickFinger2" "${builtins.elemAt cfg.buttonsMap 1}" - Option "ClickFinger3" "${builtins.elemAt cfg.buttonsMap 2}" - Option "VertTwoFingerScroll" "${if cfg.vertTwoFingerScroll then "1" else "0"}" - Option "HorizTwoFingerScroll" "${if cfg.horizTwoFingerScroll then "1" else "0"}" - Option "VertEdgeScroll" "${if cfg.vertEdgeScroll then "1" else "0"}" - Option "HorizEdgeScroll" "${if cfg.horizEdgeScroll then "1" else "0"}" - ${optionalString cfg.palmDetect ''Option "PalmDetect" "1"''} - ${optionalString (cfg.palmMinWidth != null) ''Option "PalmMinWidth" "${toString cfg.palmMinWidth}"''} - ${optionalString (cfg.palmMinZ != null) ''Option "PalmMinZ" "${toString cfg.palmMinZ}"''} - ${optionalString (cfg.scrollDelta != null) ''Option "VertScrollDelta" "${toString cfg.scrollDelta}"''} - ${if !cfg.horizontalScroll then ''Option "HorizScrollDelta" "0"'' - else (optionalString (cfg.scrollDelta != null) ''Option "HorizScrollDelta" "${toString cfg.scrollDelta}"'')} - ${cfg.additionalOptions} - EndSection - ''; + services.xserver.config = '' + # Automatically enable the synaptics driver for all touchpads. + Section "InputClass" + Identifier "synaptics touchpad catchall" + MatchIsTouchpad "on" + ${optionalString (cfg.dev != null) ''MatchDevicePath "${cfg.dev}"''} + Driver "synaptics" + ${optionalString (cfg.minSpeed != null) ''Option "MinSpeed" "${cfg.minSpeed}"''} + ${optionalString (cfg.maxSpeed != null) ''Option "MaxSpeed" "${cfg.maxSpeed}"''} + ${optionalString (cfg.accelFactor != null) ''Option "AccelFactor" "${cfg.accelFactor}"''} + ${optionalString cfg.tapButtons tapConfig} + Option "ClickFinger1" "${builtins.elemAt cfg.buttonsMap 0}" + Option "ClickFinger2" "${builtins.elemAt cfg.buttonsMap 1}" + Option "ClickFinger3" "${builtins.elemAt cfg.buttonsMap 2}" + Option "VertTwoFingerScroll" "${if cfg.vertTwoFingerScroll then "1" else "0"}" + Option "HorizTwoFingerScroll" "${if cfg.horizTwoFingerScroll then "1" else "0"}" + Option "VertEdgeScroll" "${if cfg.vertEdgeScroll then "1" else "0"}" + Option "HorizEdgeScroll" "${if cfg.horizEdgeScroll then "1" else "0"}" + ${optionalString cfg.palmDetect ''Option "PalmDetect" "1"''} + ${optionalString ( + cfg.palmMinWidth != null + ) ''Option "PalmMinWidth" "${toString cfg.palmMinWidth}"''} + ${optionalString (cfg.palmMinZ != null) ''Option "PalmMinZ" "${toString cfg.palmMinZ}"''} + ${optionalString ( + cfg.scrollDelta != null + ) ''Option "VertScrollDelta" "${toString cfg.scrollDelta}"''} + ${ + if !cfg.horizontalScroll then + ''Option "HorizScrollDelta" "0"'' + else + (optionalString ( + cfg.scrollDelta != null + ) ''Option "HorizScrollDelta" "${toString cfg.scrollDelta}"'') + } + ${cfg.additionalOptions} + EndSection + ''; assertions = [ { diff --git a/nixos/modules/services/x11/hardware/wacom.nix b/nixos/modules/services/x11/hardware/wacom.nix index 4517788f56d5c5..3707b7f4157533 100644 --- a/nixos/modules/services/x11/hardware/wacom.nix +++ b/nixos/modules/services/x11/hardware/wacom.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -32,7 +37,6 @@ in }; - config = mkIf cfg.enable { environment.systemPackages = [ pkgs.xf86_input_wacom ]; # provides xsetwacom @@ -41,7 +45,8 @@ in services.udev.packages = [ pkgs.xf86_input_wacom ]; - environment.etc."X11/xorg.conf.d/70-wacom.conf".source = "${pkgs.xf86_input_wacom}/share/X11/xorg.conf.d/70-wacom.conf"; + environment.etc."X11/xorg.conf.d/70-wacom.conf".source = + "${pkgs.xf86_input_wacom}/share/X11/xorg.conf.d/70-wacom.conf"; }; diff --git a/nixos/modules/services/x11/imwheel.nix b/nixos/modules/services/x11/imwheel.nix index 311cbc6f733343..2898af201a7e1e 100644 --- a/nixos/modules/services/x11/imwheel.nix +++ b/nixos/modules/services/x11/imwheel.nix @@ -1,71 +1,79 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.xserver.imwheel; in - { - options = { - services.xserver.imwheel = { - enable = mkEnableOption "IMWheel service"; +{ + options = { + services.xserver.imwheel = { + enable = mkEnableOption "IMWheel service"; - extraOptions = mkOption { - type = types.listOf types.str; - default = [ "--buttons=45" ]; - example = [ "--debug" ]; - description = '' - Additional command-line arguments to pass to - {command}`imwheel`. - ''; - }; + extraOptions = mkOption { + type = types.listOf types.str; + default = [ "--buttons=45" ]; + example = [ "--debug" ]; + description = '' + Additional command-line arguments to pass to + {command}`imwheel`. + ''; + }; - rules = mkOption { - type = types.attrsOf types.str; - default = {}; - example = literalExpression '' - { - ".*" = ''' - None, Up, Button4, 8 - None, Down, Button5, 8 - Shift_L, Up, Shift_L|Button4, 4 - Shift_L, Down, Shift_L|Button5, 4 - Control_L, Up, Control_L|Button4 - Control_L, Down, Control_L|Button5 - '''; - } - ''; - description = '' - Window class translation rules. - /etc/X11/imwheelrc is generated based on this config - which means this config is global for all users. - See [official man pages](https://imwheel.sourceforge.net/imwheel.1.html) - for more information. - ''; - }; + rules = mkOption { + type = types.attrsOf types.str; + default = { }; + example = literalExpression '' + { + ".*" = ''' + None, Up, Button4, 8 + None, Down, Button5, 8 + Shift_L, Up, Shift_L|Button4, 4 + Shift_L, Down, Shift_L|Button5, 4 + Control_L, Up, Control_L|Button4 + Control_L, Down, Control_L|Button5 + '''; + } + ''; + description = '' + Window class translation rules. + /etc/X11/imwheelrc is generated based on this config + which means this config is global for all users. + See [official man pages](https://imwheel.sourceforge.net/imwheel.1.html) + for more information. + ''; }; }; + }; - config = mkIf cfg.enable { - environment.systemPackages = [ pkgs.imwheel ]; + config = mkIf cfg.enable { + environment.systemPackages = [ pkgs.imwheel ]; - environment.etc."X11/imwheel/imwheelrc".source = - pkgs.writeText "imwheelrc" (concatStringsSep "\n\n" - (mapAttrsToList - (rule: conf: "\"${rule}\"\n${conf}") cfg.rules - )); + environment.etc."X11/imwheel/imwheelrc".source = pkgs.writeText "imwheelrc" ( + concatStringsSep "\n\n" (mapAttrsToList (rule: conf: "\"${rule}\"\n${conf}") cfg.rules) + ); - systemd.user.services.imwheel = { - description = "imwheel service"; - wantedBy = [ "graphical-session.target" ]; - partOf = [ "graphical-session.target" ]; - serviceConfig = { - ExecStart = "${pkgs.imwheel}/bin/imwheel " + escapeShellArgs ([ - "--detach" - "--kill" - ] ++ cfg.extraOptions); - ExecStop = "${pkgs.procps}/bin/pkill imwheel"; - RestartSec = 3; - Restart = "always"; - }; + systemd.user.services.imwheel = { + description = "imwheel service"; + wantedBy = [ "graphical-session.target" ]; + partOf = [ "graphical-session.target" ]; + serviceConfig = { + ExecStart = + "${pkgs.imwheel}/bin/imwheel " + + escapeShellArgs ( + [ + "--detach" + "--kill" + ] + ++ cfg.extraOptions + ); + ExecStop = "${pkgs.procps}/bin/pkill imwheel"; + RestartSec = 3; + Restart = "always"; }; }; - } + }; +} diff --git a/nixos/modules/services/x11/picom.nix b/nixos/modules/services/x11/picom.nix index fe07ab515ef259..237d78484286f8 100644 --- a/nixos/modules/services/x11/picom.nix +++ b/nixos/modules/services/x11/picom.nix @@ -1,4 +1,10 @@ -{ config, lib, options, pkgs, ... }: +{ + config, + lib, + options, + pkgs, + ... +}: with lib; @@ -7,38 +13,53 @@ let cfg = config.services.picom; opt = options.services.picom; - pairOf = x: with types; - addCheck (listOf x) (y: length y == 2) - // { description = "pair of ${x.description}"; }; + pairOf = + x: + with types; + addCheck (listOf x) (y: length y == 2) // { description = "pair of ${x.description}"; }; mkDefaultAttrs = mapAttrs (n: v: mkDefault v); # Basically a tinkered lib.generators.mkKeyValueDefault # It either serializes a top-level definition "key: { values };" # or an expression "key = { values };" - mkAttrsString = top: - mapAttrsToList (k: v: - let sep = if (top && isAttrs v) then ":" else "="; - in "${escape [ sep ] k}${sep}${mkValueString v};"); + mkAttrsString = + top: + mapAttrsToList ( + k: v: + let + sep = if (top && isAttrs v) then ":" else "="; + in + "${escape [ sep ] k}${sep}${mkValueString v};" + ); # This serializes a Nix expression to the libconfig format. - mkValueString = v: - if types.bool.check v then boolToString v - else if types.int.check v then toString v - else if types.float.check v then toString v - else if types.str.check v then "\"${escape [ "\"" ] v}\"" - else if builtins.isList v then "[ ${concatMapStringsSep " , " mkValueString v} ]" - else if types.attrs.check v then "{ ${concatStringsSep " " (mkAttrsString false v) } }" - else throw '' - invalid expression used in option services.picom.settings: - ${v} - ''; + mkValueString = + v: + if types.bool.check v then + boolToString v + else if types.int.check v then + toString v + else if types.float.check v then + toString v + else if types.str.check v then + "\"${escape [ "\"" ] v}\"" + else if builtins.isList v then + "[ ${concatMapStringsSep " , " mkValueString v} ]" + else if types.attrs.check v then + "{ ${concatStringsSep " " (mkAttrsString false v)} }" + else + throw '' + invalid expression used in option services.picom.settings: + ${v} + ''; toConf = attrs: concatStringsSep "\n" (mkAttrsString true cfg.settings); configFile = pkgs.writeText "picom.conf" (toConf cfg.settings); -in { +in +{ imports = [ (mkAliasOptionModuleMD [ "services" "compton" ] [ "services" "picom" ]) @@ -82,8 +103,14 @@ in { fadeSteps = mkOption { type = pairOf (types.numbers.between 0.01 1); - default = [ 0.028 0.03 ]; - example = [ 0.04 0.04 ]; + default = [ + 0.028 + 0.03 + ]; + example = [ + 0.04 + 0.04 + ]; description = '' Opacity change between fade steps (in and out). ''; @@ -91,7 +118,7 @@ in { fadeExclude = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "window_type *= 'menu'" "name ~= 'Firefox$'" @@ -113,8 +140,14 @@ in { shadowOffsets = mkOption { type = pairOf types.int; - default = [ (-15) (-15) ]; - example = [ (-10) (-15) ]; + default = [ + (-15) + (-15) + ]; + example = [ + (-10) + (-15) + ]; description = '' Left and right offset for shadows (in pixels). ''; @@ -131,7 +164,7 @@ in { shadowExclude = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "window_type *= 'menu'" "name ~= 'Firefox$'" @@ -173,8 +206,12 @@ in { wintypes = mkOption { type = types.attrs; default = { - popup_menu = { opacity = cfg.menuOpacity; }; - dropdown_menu = { opacity = cfg.menuOpacity; }; + popup_menu = { + opacity = cfg.menuOpacity; + }; + dropdown_menu = { + opacity = cfg.menuOpacity; + }; }; defaultText = literalExpression '' { @@ -182,7 +219,7 @@ in { dropdown_menu = { opacity = config.${opt.menuOpacity}; }; } ''; - example = {}; + example = { }; description = '' Rules for specific window types. ''; @@ -190,7 +227,7 @@ in { opacityRules = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "95:class_g = 'URxvt' && !_NET_WM_STATE@:32a" "0:_NET_WM_STATE@:32a *= '_NET_WM_STATE_HIDDEN'" @@ -201,7 +238,12 @@ in { }; backend = mkOption { - type = types.enum [ "egl" "glx" "xrender" "xr_glx_hybrid" ]; + type = types.enum [ + "egl" + "glx" + "xrender" + "xr_glx_hybrid" + ]; default = "xrender"; description = '' Backend to use: `egl`, `glx`, `xrender` or `xr_glx_hybrid`. @@ -209,17 +251,26 @@ in { }; vSync = mkOption { - type = with types; either bool - (enum [ "none" "drm" "opengl" "opengl-oml" "opengl-swc" "opengl-mswc" ]); + type = + with types; + either bool (enum [ + "none" + "drm" + "opengl" + "opengl-oml" + "opengl-swc" + "opengl-mswc" + ]); default = false; - apply = x: + apply = + x: let res = x != "none"; - msg = "The type of services.picom.vSync has changed to bool:" - + " interpreting ${x} as ${boolToString res}"; + msg = + "The type of services.picom.vSync has changed to bool:" + + " interpreting ${x} as ${boolToString res}"; in - if isBool x then x - else warn msg res; + if isBool x then x else warn msg res; description = '' Enable vertical synchronization. Chooses the best method @@ -228,68 +279,85 @@ in { ''; }; - settings = with types; - let - scalar = oneOf [ bool int float str ] - // { description = "scalar types"; }; - - libConfig = oneOf [ scalar (listOf libConfig) (attrsOf libConfig) ] - // { description = "libconfig type"; }; - - topLevel = attrsOf libConfig - // { description = '' - libconfig configuration. The format consists of an attributes - set (called a group) of settings. Each setting can be a scalar type - (boolean, integer, floating point number or string), a list of - scalars or a group itself - ''; - }; - - in mkOption { - type = topLevel; - default = { }; - example = literalExpression '' - blur = - { method = "gaussian"; - size = 10; - deviation = 5.0; + settings = + with types; + let + scalar = + oneOf [ + bool + int + float + str + ] + // { + description = "scalar types"; }; - ''; - description = '' - Picom settings. Use this option to configure Picom settings not exposed - in a NixOS option or to bypass one. For the available options see the - CONFIGURATION FILES section at `picom(1)`. - ''; - }; + + libConfig = + oneOf [ + scalar + (listOf libConfig) + (attrsOf libConfig) + ] + // { + description = "libconfig type"; + }; + + topLevel = attrsOf libConfig // { + description = '' + libconfig configuration. The format consists of an attributes + set (called a group) of settings. Each setting can be a scalar type + (boolean, integer, floating point number or string), a list of + scalars or a group itself + ''; + }; + + in + mkOption { + type = topLevel; + default = { }; + example = literalExpression '' + blur = + { method = "gaussian"; + size = 10; + deviation = 5.0; + }; + ''; + description = '' + Picom settings. Use this option to configure Picom settings not exposed + in a NixOS option or to bypass one. For the available options see the + CONFIGURATION FILES section at `picom(1)`. + ''; + }; }; config = mkIf cfg.enable { services.picom.settings = mkDefaultAttrs { # fading - fading = cfg.fade; - fade-delta = cfg.fadeDelta; - fade-in-step = elemAt cfg.fadeSteps 0; - fade-out-step = elemAt cfg.fadeSteps 1; - fade-exclude = cfg.fadeExclude; + fading = cfg.fade; + fade-delta = cfg.fadeDelta; + fade-in-step = elemAt cfg.fadeSteps 0; + fade-out-step = elemAt cfg.fadeSteps 1; + fade-exclude = cfg.fadeExclude; # shadows - shadow = cfg.shadow; - shadow-offset-x = elemAt cfg.shadowOffsets 0; - shadow-offset-y = elemAt cfg.shadowOffsets 1; - shadow-opacity = cfg.shadowOpacity; - shadow-exclude = cfg.shadowExclude; + shadow = cfg.shadow; + shadow-offset-x = elemAt cfg.shadowOffsets 0; + shadow-offset-y = elemAt cfg.shadowOffsets 1; + shadow-opacity = cfg.shadowOpacity; + shadow-exclude = cfg.shadowExclude; # opacity - active-opacity = cfg.activeOpacity; + active-opacity = cfg.activeOpacity; inactive-opacity = cfg.inactiveOpacity; - wintypes = cfg.wintypes; + wintypes = cfg.wintypes; - opacity-rule = cfg.opacityRules; + opacity-rule = cfg.opacityRules; # other options - backend = cfg.backend; - vsync = cfg.vSync; + backend = cfg.backend; + vsync = cfg.vSync; }; systemd.user.services.picom = { diff --git a/nixos/modules/services/x11/redshift.nix b/nixos/modules/services/x11/redshift.nix index b0b22e6782784d..661053c20016c1 100644 --- a/nixos/modules/services/x11/redshift.nix +++ b/nixos/modules/services/x11/redshift.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -7,21 +12,30 @@ let cfg = config.services.redshift; lcfg = config.location; -in { +in +{ imports = [ - (mkChangedOptionModule [ "services" "redshift" "latitude" ] [ "location" "latitude" ] - (config: - let value = getAttrFromPath [ "services" "redshift" "latitude" ] config; - in if value == null then - throw "services.redshift.latitude is set to null, you can remove this" - else builtins.fromJSON value)) - (mkChangedOptionModule [ "services" "redshift" "longitude" ] [ "location" "longitude" ] - (config: - let value = getAttrFromPath [ "services" "redshift" "longitude" ] config; - in if value == null then - throw "services.redshift.longitude is set to null, you can remove this" - else builtins.fromJSON value)) + (mkChangedOptionModule [ "services" "redshift" "latitude" ] [ "location" "latitude" ] ( + config: + let + value = getAttrFromPath [ "services" "redshift" "latitude" ] config; + in + if value == null then + throw "services.redshift.latitude is set to null, you can remove this" + else + builtins.fromJSON value + )) + (mkChangedOptionModule [ "services" "redshift" "longitude" ] [ "location" "longitude" ] ( + config: + let + value = getAttrFromPath [ "services" "redshift" "longitude" ] config; + in + if value == null then + throw "services.redshift.longitude is set to null, you can remove this" + else + builtins.fromJSON value + )) (mkRenamedOptionModule [ "services" "redshift" "provider" ] [ "location" "provider" ]) ]; @@ -86,8 +100,11 @@ in { extraOptions = mkOption { type = types.listOf types.str; - default = []; - example = [ "-v" "-m randr" ]; + default = [ ]; + example = [ + "-v" + "-m randr" + ]; description = '' Additional command-line arguments to pass to {command}`redshift`. @@ -105,27 +122,29 @@ in { }; systemd.user.services.redshift = - let - providerString = if lcfg.provider == "manual" - then "${toString lcfg.latitude}:${toString lcfg.longitude}" - else lcfg.provider; - in - { - description = "Redshift colour temperature adjuster"; - wantedBy = [ "graphical-session.target" ]; - partOf = [ "graphical-session.target" ]; - serviceConfig = { - ExecStart = '' - ${cfg.package}${cfg.executable} \ - -l ${providerString} \ - -t ${toString cfg.temperature.day}:${toString cfg.temperature.night} \ - -b ${toString cfg.brightness.day}:${toString cfg.brightness.night} \ - ${lib.strings.concatStringsSep " " cfg.extraOptions} - ''; - RestartSec = 3; - Restart = "always"; + let + providerString = + if lcfg.provider == "manual" then + "${toString lcfg.latitude}:${toString lcfg.longitude}" + else + lcfg.provider; + in + { + description = "Redshift colour temperature adjuster"; + wantedBy = [ "graphical-session.target" ]; + partOf = [ "graphical-session.target" ]; + serviceConfig = { + ExecStart = '' + ${cfg.package}${cfg.executable} \ + -l ${providerString} \ + -t ${toString cfg.temperature.day}:${toString cfg.temperature.night} \ + -b ${toString cfg.brightness.day}:${toString cfg.brightness.night} \ + ${lib.strings.concatStringsSep " " cfg.extraOptions} + ''; + RestartSec = 3; + Restart = "always"; + }; }; - }; }; } diff --git a/nixos/modules/services/x11/terminal-server.nix b/nixos/modules/services/x11/terminal-server.nix index e6b50c21a95265..165cbea6574a10 100644 --- a/nixos/modules/services/x11/terminal-server.nix +++ b/nixos/modules/services/x11/terminal-server.nix @@ -14,42 +14,50 @@ with lib; config = { services.xserver.enable = true; - services.xserver.videoDrivers = []; + services.xserver.videoDrivers = [ ]; # Enable GDM. Any display manager will do as long as it supports XDMCP. services.xserver.displayManager.gdm.enable = true; - systemd.sockets.terminal-server = - { description = "Terminal Server Socket"; - wantedBy = [ "sockets.target" ]; - before = [ "multi-user.target" ]; - socketConfig.Accept = true; - socketConfig.ListenStream = 5900; - }; + systemd.sockets.terminal-server = { + description = "Terminal Server Socket"; + wantedBy = [ "sockets.target" ]; + before = [ "multi-user.target" ]; + socketConfig.Accept = true; + socketConfig.ListenStream = 5900; + }; + + systemd.services."terminal-server@" = { + description = "Terminal Server"; + + path = [ + pkgs.xorg.xorgserver.out + pkgs.gawk + pkgs.which + pkgs.openssl + pkgs.xorg.xauth + pkgs.nettools + pkgs.shadow + pkgs.procps + pkgs.util-linux + pkgs.bash + ]; + + environment.FD_GEOM = "1024x786x24"; + environment.FD_XDMCP_IF = "127.0.0.1"; + #environment.FIND_DISPLAY_OUTPUT = "/tmp/foo"; # to debug the "find display" script - systemd.services."terminal-server@" = - { description = "Terminal Server"; - - path = - [ pkgs.xorg.xorgserver.out pkgs.gawk pkgs.which pkgs.openssl pkgs.xorg.xauth - pkgs.nettools pkgs.shadow pkgs.procps pkgs.util-linux pkgs.bash - ]; - - environment.FD_GEOM = "1024x786x24"; - environment.FD_XDMCP_IF = "127.0.0.1"; - #environment.FIND_DISPLAY_OUTPUT = "/tmp/foo"; # to debug the "find display" script - - serviceConfig = - { StandardInput = "socket"; - StandardOutput = "socket"; - StandardError = "journal"; - ExecStart = "@${pkgs.x11vnc}/bin/x11vnc x11vnc -inetd -display WAIT:1024x786:cmd=FINDCREATEDISPLAY-Xvfb.xdmcp -unixpw -ssl SAVE"; - # Don't kill the X server when the user quits the VNC - # connection. FIXME: the X server should run in a - # separate systemd session. - KillMode = "process"; - }; + serviceConfig = { + StandardInput = "socket"; + StandardOutput = "socket"; + StandardError = "journal"; + ExecStart = "@${pkgs.x11vnc}/bin/x11vnc x11vnc -inetd -display WAIT:1024x786:cmd=FINDCREATEDISPLAY-Xvfb.xdmcp -unixpw -ssl SAVE"; + # Don't kill the X server when the user quits the VNC + # connection. FIXME: the X server should run in a + # separate systemd session. + KillMode = "process"; }; + }; }; diff --git a/nixos/modules/services/x11/touchegg.nix b/nixos/modules/services/x11/touchegg.nix index 660ec0b8f706fa..def3dac738e043 100644 --- a/nixos/modules/services/x11/touchegg.nix +++ b/nixos/modules/services/x11/touchegg.nix @@ -1,10 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; -let cfg = config.services.touchegg; +let + cfg = config.services.touchegg; -in { +in +{ meta = { maintainers = teams.pantheon.members; }; diff --git a/nixos/modules/services/x11/unclutter-xfixes.nix b/nixos/modules/services/x11/unclutter-xfixes.nix index a302eee1bad93f..48adb3665f3874 100644 --- a/nixos/modules/services/x11/unclutter-xfixes.nix +++ b/nixos/modules/services/x11/unclutter-xfixes.nix @@ -1,10 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; -let cfg = config.services.unclutter-xfixes; +let + cfg = config.services.unclutter-xfixes; -in { +in +{ options.services.unclutter-xfixes = { enable = mkOption { @@ -30,8 +37,12 @@ in { extraOptions = mkOption { description = "More arguments to pass to the unclutter-xfixes command."; type = types.listOf types.str; - default = []; - example = [ "exclude-root" "ignore-scrolling" "fork" ]; + default = [ ]; + example = [ + "exclude-root" + "ignore-scrolling" + "fork" + ]; }; }; @@ -44,7 +55,7 @@ in { ${cfg.package}/bin/unclutter \ --timeout ${toString cfg.timeout} \ --jitter ${toString (cfg.threshold - 1)} \ - ${concatMapStrings (x: " --"+x) cfg.extraOptions} \ + ${concatMapStrings (x: " --" + x) cfg.extraOptions} \ ''; serviceConfig.RestartSec = 3; serviceConfig.Restart = "always"; diff --git a/nixos/modules/services/x11/unclutter.nix b/nixos/modules/services/x11/unclutter.nix index 7f07bb8582bc7f..bb11c8639783b8 100644 --- a/nixos/modules/services/x11/unclutter.nix +++ b/nixos/modules/services/x11/unclutter.nix @@ -1,10 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; -let cfg = config.services.unclutter; +let + cfg = config.services.unclutter; -in { +in +{ options.services.unclutter = { enable = mkOption { @@ -36,15 +43,18 @@ in { excluded = mkOption { description = "Names of windows where unclutter should not apply"; type = types.listOf types.str; - default = []; + default = [ ]; example = [ "" ]; }; extraOptions = mkOption { description = "More arguments to pass to the unclutter command"; type = types.listOf types.str; - default = []; - example = [ "noevent" "grab" ]; + default = [ ]; + example = [ + "noevent" + "grab" + ]; }; }; @@ -58,7 +68,7 @@ in { -idle ${toString cfg.timeout} \ -jitter ${toString (cfg.threshold - 1)} \ ${optionalString cfg.keystroke "-keystroke"} \ - ${concatMapStrings (x: " -"+x) cfg.extraOptions} \ + ${concatMapStrings (x: " -" + x) cfg.extraOptions} \ -not ${concatStringsSep " " cfg.excluded} \ ''; serviceConfig.PassEnvironment = "DISPLAY"; @@ -68,8 +78,10 @@ in { }; imports = [ - (mkRenamedOptionModule [ "services" "unclutter" "threeshold" ] - [ "services" "unclutter" "threshold" ]) + (mkRenamedOptionModule + [ "services" "unclutter" "threeshold" ] + [ "services" "unclutter" "threshold" ] + ) ]; meta.maintainers = with lib.maintainers; [ rnhmjoj ]; diff --git a/nixos/modules/services/x11/urserver.nix b/nixos/modules/services/x11/urserver.nix index 30f8a9805cfbc6..53df3c683a4144 100644 --- a/nixos/modules/services/x11/urserver.nix +++ b/nixos/modules/services/x11/urserver.nix @@ -1,17 +1,29 @@ # urserver service -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.urserver; -in { +in +{ options.services.urserver.enable = lib.mkEnableOption "urserver"; config = lib.mkIf cfg.enable { networking.firewall = { - allowedTCPPorts = [ 9510 9512 ]; - allowedUDPPorts = [ 9511 9512 ]; + allowedTCPPorts = [ + 9510 + 9512 + ]; + allowedUDPPorts = [ + 9511 + 9512 + ]; }; systemd.user.services.urserver = { diff --git a/nixos/modules/services/x11/urxvtd.nix b/nixos/modules/services/x11/urxvtd.nix index 618db85d477bde..5f8212a3c9ce24 100644 --- a/nixos/modules/services/x11/urxvtd.nix +++ b/nixos/modules/services/x11/urxvtd.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: # maintainer: siddharthist @@ -6,7 +11,8 @@ with lib; let cfg = config.services.urxvtd; -in { +in +{ options.services.urxvtd = { enable = mkOption { type = types.bool; diff --git a/nixos/modules/services/x11/window-managers/2bwm.nix b/nixos/modules/services/x11/window-managers/2bwm.nix index fdbdf35b0f5af4..ce01fcb17a10e8 100644 --- a/nixos/modules/services/x11/window-managers/2bwm.nix +++ b/nixos/modules/services/x11/window-managers/2bwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -16,19 +21,17 @@ in services.xserver.windowManager."2bwm".enable = mkEnableOption "2bwm"; }; - ###### implementation config = mkIf cfg.enable { - services.xserver.windowManager.session = singleton - { name = "2bwm"; - start = - '' - ${pkgs._2bwm}/bin/2bwm & - waitPID=$! - ''; - }; + services.xserver.windowManager.session = singleton { + name = "2bwm"; + start = '' + ${pkgs._2bwm}/bin/2bwm & + waitPID=$! + ''; + }; environment.systemPackages = [ pkgs._2bwm ]; diff --git a/nixos/modules/services/x11/window-managers/afterstep.nix b/nixos/modules/services/x11/window-managers/afterstep.nix index ba88a64c702a66..d88be7db3757db 100644 --- a/nixos/modules/services/x11/window-managers/afterstep.nix +++ b/nixos/modules/services/x11/window-managers/afterstep.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/awesome.nix b/nixos/modules/services/x11/window-managers/awesome.nix index 20a33fa87d4d80..8b3d781c4c2185 100644 --- a/nixos/modules/services/x11/window-managers/awesome.nix +++ b/nixos/modules/services/x11/window-managers/awesome.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -7,9 +12,8 @@ let cfg = config.services.xserver.windowManager.awesome; awesome = cfg.package; getLuaPath = lib: dir: "${lib}/${dir}/lua/${awesome.lua.luaversion}"; - makeSearchPath = lib.concatMapStrings (path: - " --search " + (getLuaPath path "share") + - " --search " + (getLuaPath path "lib") + makeSearchPath = lib.concatMapStrings ( + path: " --search " + (getLuaPath path "share") + " --search " + (getLuaPath path "lib") ); in @@ -24,7 +28,7 @@ in enable = mkEnableOption "Awesome window manager"; luaModules = mkOption { - default = []; + default = [ ]; type = types.listOf types.package; description = "List of lua packages available for being used in the Awesome configuration."; example = literalExpression "[ pkgs.luaPackages.vicious ]"; @@ -41,19 +45,17 @@ in }; - ###### implementation config = mkIf cfg.enable { - services.xserver.windowManager.session = singleton - { name = "awesome"; - start = - '' - ${awesome}/bin/awesome ${lib.optionalString cfg.noArgb "--no-argb"} ${makeSearchPath cfg.luaModules} & - waitPID=$! - ''; - }; + services.xserver.windowManager.session = singleton { + name = "awesome"; + start = '' + ${awesome}/bin/awesome ${lib.optionalString cfg.noArgb "--no-argb"} ${makeSearchPath cfg.luaModules} & + waitPID=$! + ''; + }; environment.systemPackages = [ awesome ]; diff --git a/nixos/modules/services/x11/window-managers/berry.nix b/nixos/modules/services/x11/window-managers/berry.nix index 0d2285e7a60eb1..ba094d0e3efcfb 100644 --- a/nixos/modules/services/x11/window-managers/berry.nix +++ b/nixos/modules/services/x11/window-managers/berry.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/bspwm.nix b/nixos/modules/services/x11/window-managers/bspwm.nix index b7feeab52a56b7..46201036f05afb 100644 --- a/nixos/modules/services/x11/window-managers/bspwm.nix +++ b/nixos/modules/services/x11/window-managers/bspwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -15,9 +20,9 @@ in example = "bspwm-unstable"; }; configFile = mkOption { - type = with types; nullOr path; - example = literalExpression ''"''${pkgs.bspwm}/share/doc/bspwm/examples/bspwmrc"''; - default = null; + type = with types; nullOr path; + example = literalExpression ''"''${pkgs.bspwm}/share/doc/bspwm/examples/bspwmrc"''; + default = null; description = '' Path to the bspwm configuration file. If null, $HOME/.config/bspwm/bspwmrc will be used. @@ -29,9 +34,9 @@ in example = "sxhkd-unstable"; }; configFile = mkOption { - type = with types; nullOr path; - example = literalExpression ''"''${pkgs.bspwm}/share/doc/bspwm/examples/sxhkdrc"''; - default = null; + type = with types; nullOr path; + example = literalExpression ''"''${pkgs.bspwm}/share/doc/bspwm/examples/sxhkdrc"''; + default = null; description = '' Path to the sxhkd configuration file. If null, $HOME/.config/sxhkd/sxhkdrc will be used. @@ -43,10 +48,12 @@ in config = mkIf cfg.enable { services.xserver.windowManager.session = singleton { - name = "bspwm"; + name = "bspwm"; start = '' export _JAVA_AWT_WM_NONREPARENTING=1 - SXHKD_SHELL=/bin/sh ${cfg.sxhkd.package}/bin/sxhkd ${optionalString (cfg.sxhkd.configFile != null) "-c \"${cfg.sxhkd.configFile}\""} & + SXHKD_SHELL=/bin/sh ${cfg.sxhkd.package}/bin/sxhkd ${ + optionalString (cfg.sxhkd.configFile != null) "-c \"${cfg.sxhkd.configFile}\"" + } & ${cfg.package}/bin/bspwm ${optionalString (cfg.configFile != null) "-c \"${cfg.configFile}\""} & waitPID=$! ''; @@ -55,11 +62,22 @@ in }; imports = [ - (mkRemovedOptionModule [ "services" "xserver" "windowManager" "bspwm-unstable" "enable" ] - "Use services.xserver.windowManager.bspwm.enable and set services.xserver.windowManager.bspwm.package to pkgs.bspwm-unstable to use the unstable version of bspwm.") - (mkRemovedOptionModule [ "services" "xserver" "windowManager" "bspwm" "startThroughSession" ] - "bspwm package does not provide bspwm-session anymore.") - (mkRemovedOptionModule [ "services" "xserver" "windowManager" "bspwm" "sessionScript" ] - "bspwm package does not provide bspwm-session anymore.") + (mkRemovedOptionModule [ "services" "xserver" "windowManager" "bspwm-unstable" "enable" ] + "Use services.xserver.windowManager.bspwm.enable and set services.xserver.windowManager.bspwm.package to pkgs.bspwm-unstable to use the unstable version of bspwm." + ) + (mkRemovedOptionModule [ + "services" + "xserver" + "windowManager" + "bspwm" + "startThroughSession" + ] "bspwm package does not provide bspwm-session anymore.") + (mkRemovedOptionModule [ + "services" + "xserver" + "windowManager" + "bspwm" + "sessionScript" + ] "bspwm package does not provide bspwm-session anymore.") ]; } diff --git a/nixos/modules/services/x11/window-managers/clfswm.nix b/nixos/modules/services/x11/window-managers/clfswm.nix index 09b49962f2ad7b..b50b60849495bf 100644 --- a/nixos/modules/services/x11/window-managers/clfswm.nix +++ b/nixos/modules/services/x11/window-managers/clfswm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/cwm.nix b/nixos/modules/services/x11/window-managers/cwm.nix index 03375a226bb6be..d2be487b0d4ca7 100644 --- a/nixos/modules/services/x11/window-managers/cwm.nix +++ b/nixos/modules/services/x11/window-managers/cwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -10,14 +15,13 @@ in services.xserver.windowManager.cwm.enable = mkEnableOption "cwm"; }; config = mkIf cfg.enable { - services.xserver.windowManager.session = singleton - { name = "cwm"; - start = - '' - cwm & - waitPID=$! - ''; - }; + services.xserver.windowManager.session = singleton { + name = "cwm"; + start = '' + cwm & + waitPID=$! + ''; + }; environment.systemPackages = [ pkgs.cwm ]; }; } diff --git a/nixos/modules/services/x11/window-managers/default.nix b/nixos/modules/services/x11/window-managers/default.nix index 85eb4c6614d941..e54a9bd1cfa8be 100644 --- a/nixos/modules/services/x11/window-managers/default.nix +++ b/nixos/modules/services/x11/window-managers/default.nix @@ -48,7 +48,8 @@ in ./xmonad.nix ./yeahwm.nix ./qtile.nix - ./none.nix ]; + ./none.nix + ]; options = { @@ -56,19 +57,25 @@ in session = mkOption { internal = true; - default = []; - example = [{ - name = "wmii"; - start = "..."; - }]; + default = [ ]; + example = [ + { + name = "wmii"; + start = "..."; + } + ]; description = '' Internal option used to add some common line to window manager scripts before forwarding the value to the `displayManager`. ''; - apply = map (d: d // { - manage = "window"; - }); + apply = map ( + d: + d + // { + manage = "window"; + } + ); }; }; diff --git a/nixos/modules/services/x11/window-managers/dk.nix b/nixos/modules/services/x11/window-managers/dk.nix index afd35ae477a64b..29f17f3e070c3c 100644 --- a/nixos/modules/services/x11/window-managers/dk.nix +++ b/nixos/modules/services/x11/window-managers/dk.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.xserver.windowManager.dk; diff --git a/nixos/modules/services/x11/window-managers/e16.nix b/nixos/modules/services/x11/window-managers/e16.nix index 3e1a22c4dabd89..b1ed3ea66417ea 100644 --- a/nixos/modules/services/x11/window-managers/e16.nix +++ b/nixos/modules/services/x11/window-managers/e16.nix @@ -1,4 +1,9 @@ -{ config , lib , pkgs , ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/evilwm.nix b/nixos/modules/services/x11/window-managers/evilwm.nix index 6f1db2110f8797..a89e97f358a6e1 100644 --- a/nixos/modules/services/x11/window-managers/evilwm.nix +++ b/nixos/modules/services/x11/window-managers/evilwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/exwm.nix b/nixos/modules/services/x11/window-managers/exwm.nix index 1c08ef93f9b673..301a3c85d9e16d 100644 --- a/nixos/modules/services/x11/window-managers/exwm.nix +++ b/nixos/modules/services/x11/window-managers/exwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -14,7 +19,8 @@ in imports = [ (mkRemovedOptionModule [ "services" "xserver" "windowManager" "exwm" "enableDefaultConfig" ] - "The upstream EXWM project no longer provides a default configuration, instead copy (parts of) exwm-config.el to your local config.") + "The upstream EXWM project no longer provides a default configuration, instead copy (parts of) exwm-config.el to your local config." + ) ]; options = { @@ -34,7 +40,7 @@ in }; extraPackages = mkOption { type = types.functionTo (types.listOf types.package); - default = epkgs: []; + default = epkgs: [ ]; defaultText = literalExpression "epkgs: []"; example = literalExpression '' epkgs: [ diff --git a/nixos/modules/services/x11/window-managers/fluxbox.nix b/nixos/modules/services/x11/window-managers/fluxbox.nix index b409335702affb..b97433d8730678 100644 --- a/nixos/modules/services/x11/window-managers/fluxbox.nix +++ b/nixos/modules/services/x11/window-managers/fluxbox.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/fvwm2.nix b/nixos/modules/services/x11/window-managers/fvwm2.nix index 909b3a475a9c2f..494008a280d068 100644 --- a/nixos/modules/services/x11/window-managers/fvwm2.nix +++ b/nixos/modules/services/x11/window-managers/fvwm2.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -12,7 +17,8 @@ in imports = [ (mkRenamedOptionModule [ "services" "xserver" "windowManager" "fvwm" ] - [ "services" "xserver" "windowManager" "fvwm2" ]) + [ "services" "xserver" "windowManager" "fvwm2" ] + ) ]; ###### interface @@ -29,18 +35,16 @@ in }; }; - ###### implementation config = mkIf cfg.enable { - services.xserver.windowManager.session = singleton - { name = "fvwm2"; - start = - '' - ${fvwm2}/bin/fvwm & - waitPID=$! - ''; - }; + services.xserver.windowManager.session = singleton { + name = "fvwm2"; + start = '' + ${fvwm2}/bin/fvwm & + waitPID=$! + ''; + }; environment.systemPackages = [ fvwm2 ]; }; diff --git a/nixos/modules/services/x11/window-managers/fvwm3.nix b/nixos/modules/services/x11/window-managers/fvwm3.nix index 43111f917d4942..2335adb2f53133 100644 --- a/nixos/modules/services/x11/window-managers/fvwm3.nix +++ b/nixos/modules/services/x11/window-managers/fvwm3.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -17,18 +22,16 @@ in }; }; - ###### implementation config = mkIf cfg.enable { - services.xserver.windowManager.session = singleton - { name = "fvwm3"; - start = - '' - ${fvwm3}/bin/fvwm3 & - waitPID=$! - ''; - }; + services.xserver.windowManager.session = singleton { + name = "fvwm3"; + start = '' + ${fvwm3}/bin/fvwm3 & + waitPID=$! + ''; + }; environment.systemPackages = [ fvwm3 ]; }; diff --git a/nixos/modules/services/x11/window-managers/hackedbox.nix b/nixos/modules/services/x11/window-managers/hackedbox.nix index 641cf1bdcbe23c..b13f1489b2ed72 100644 --- a/nixos/modules/services/x11/window-managers/hackedbox.nix +++ b/nixos/modules/services/x11/window-managers/hackedbox.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/herbstluftwm.nix b/nixos/modules/services/x11/window-managers/herbstluftwm.nix index 94c9f4aa91c8f5..b216aa49d7a3c4 100644 --- a/nixos/modules/services/x11/window-managers/herbstluftwm.nix +++ b/nixos/modules/services/x11/window-managers/herbstluftwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -14,8 +19,8 @@ in package = mkPackageOption pkgs "herbstluftwm" { }; configFile = mkOption { - default = null; - type = with types; nullOr path; + default = null; + type = with types; nullOr path; description = '' Path to the herbstluftwm configuration file. If left at the default value, $XDG_CONFIG_HOME/herbstluftwm/autostart will @@ -29,11 +34,10 @@ in services.xserver.windowManager.session = singleton { name = "herbstluftwm"; start = - let configFileClause = optionalString - (cfg.configFile != null) - ''-c "${cfg.configFile}"'' - ; - in '' + let + configFileClause = optionalString (cfg.configFile != null) ''-c "${cfg.configFile}"''; + in + '' ${cfg.package}/bin/herbstluftwm ${configFileClause} & waitPID=$! ''; diff --git a/nixos/modules/services/x11/window-managers/hypr.nix b/nixos/modules/services/x11/window-managers/hypr.nix index 18111f8741a208..8763f505d56e24 100644 --- a/nixos/modules/services/x11/window-managers/hypr.nix +++ b/nixos/modules/services/x11/window-managers/hypr.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/i3.nix b/nixos/modules/services/x11/window-managers/i3.nix index 4b2fb40585a70c..47c927b8545600 100644 --- a/nixos/modules/services/x11/window-managers/i3.nix +++ b/nixos/modules/services/x11/window-managers/i3.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -15,8 +20,8 @@ in enable = mkEnableOption "i3 window manager"; configFile = mkOption { - default = null; - type = with types; nullOr path; + default = null; + type = with types; nullOr path; description = '' Path to the i3 configuration file. If left at the default value, $HOME/.i3/config will be used. @@ -33,8 +38,8 @@ in }; extraSessionCommands = mkOption { - default = ""; - type = types.lines; + default = ""; + type = types.lines; description = '' Shell commands executed just before i3 is started. ''; @@ -44,7 +49,11 @@ in extraPackages = mkOption { type = with types; listOf package; - default = with pkgs; [ dmenu i3status i3lock ]; + default = with pkgs; [ + dmenu + i3status + i3lock + ]; defaultText = literalExpression '' with pkgs; [ dmenu @@ -59,19 +68,19 @@ in }; config = mkIf cfg.enable { - services.xserver.windowManager.session = [{ - name = "i3"; - start = '' - ${cfg.extraSessionCommands} + services.xserver.windowManager.session = [ + { + name = "i3"; + start = '' + ${cfg.extraSessionCommands} - ${lib.optionalString cfg.updateSessionEnvironment updateSessionEnvironmentScript} + ${lib.optionalString cfg.updateSessionEnvironment updateSessionEnvironmentScript} - ${cfg.package}/bin/i3 ${optionalString (cfg.configFile != null) - "-c /etc/i3/config" - } & - waitPID=$! - ''; - }]; + ${cfg.package}/bin/i3 ${optionalString (cfg.configFile != null) "-c /etc/i3/config"} & + waitPID=$! + ''; + } + ]; environment.systemPackages = [ cfg.package ] ++ cfg.extraPackages; environment.etc."i3/config" = mkIf (cfg.configFile != null) { source = cfg.configFile; @@ -79,7 +88,12 @@ in }; imports = [ - (mkRemovedOptionModule [ "services" "xserver" "windowManager" "i3-gaps" "enable" ] - "i3-gaps was merged into i3. Use services.xserver.windowManager.i3.enable instead.") + (mkRemovedOptionModule [ + "services" + "xserver" + "windowManager" + "i3-gaps" + "enable" + ] "i3-gaps was merged into i3. Use services.xserver.windowManager.i3.enable instead.") ]; } diff --git a/nixos/modules/services/x11/window-managers/icewm.nix b/nixos/modules/services/x11/window-managers/icewm.nix index cb2f92d8a42c2e..9bb34d248152af 100644 --- a/nixos/modules/services/x11/window-managers/icewm.nix +++ b/nixos/modules/services/x11/window-managers/icewm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -13,14 +18,13 @@ in ###### implementation config = mkIf cfg.enable { - services.xserver.windowManager.session = singleton - { name = "icewm"; - start = - '' - ${pkgs.icewm}/bin/icewm-session & - waitPID=$! - ''; - }; + services.xserver.windowManager.session = singleton { + name = "icewm"; + start = '' + ${pkgs.icewm}/bin/icewm-session & + waitPID=$! + ''; + }; environment.systemPackages = [ pkgs.icewm ]; }; diff --git a/nixos/modules/services/x11/window-managers/jwm.nix b/nixos/modules/services/x11/window-managers/jwm.nix index 0e8dab2e9224d9..bf86d184ae221c 100644 --- a/nixos/modules/services/x11/window-managers/jwm.nix +++ b/nixos/modules/services/x11/window-managers/jwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/katriawm.nix b/nixos/modules/services/x11/window-managers/katriawm.nix index db04f6b43e529e..77f0956af46cd3 100644 --- a/nixos/modules/services/x11/window-managers/katriawm.nix +++ b/nixos/modules/services/x11/window-managers/katriawm.nix @@ -1,7 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkEnableOption mkIf mkPackageOption singleton; + inherit (lib) + mkEnableOption + mkIf + mkPackageOption + singleton + ; cfg = config.services.xserver.windowManager.katriawm; in { @@ -9,7 +19,7 @@ in options = { services.xserver.windowManager.katriawm = { enable = mkEnableOption "katriawm"; - package = mkPackageOption pkgs "katriawm" {}; + package = mkPackageOption pkgs "katriawm" { }; }; }; diff --git a/nixos/modules/services/x11/window-managers/leftwm.nix b/nixos/modules/services/x11/window-managers/leftwm.nix index 3ef40df95df2c1..c58e3ef89ae2d7 100644 --- a/nixos/modules/services/x11/window-managers/leftwm.nix +++ b/nixos/modules/services/x11/window-managers/leftwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/lwm.nix b/nixos/modules/services/x11/window-managers/lwm.nix index e2aa062fd13be0..b1d5e80e3f9d49 100644 --- a/nixos/modules/services/x11/window-managers/lwm.nix +++ b/nixos/modules/services/x11/window-managers/lwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/metacity.nix b/nixos/modules/services/x11/window-managers/metacity.nix index b3c24a9a5bbadf..7d9e21309612c1 100644 --- a/nixos/modules/services/x11/window-managers/metacity.nix +++ b/nixos/modules/services/x11/window-managers/metacity.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let @@ -13,13 +18,13 @@ in config = lib.mkIf cfg.enable { - services.xserver.windowManager.session = lib.singleton - { name = "metacity"; - start = '' - ${metacity}/bin/metacity & - waitPID=$! - ''; - }; + services.xserver.windowManager.session = lib.singleton { + name = "metacity"; + start = '' + ${metacity}/bin/metacity & + waitPID=$! + ''; + }; environment.systemPackages = [ metacity ]; diff --git a/nixos/modules/services/x11/window-managers/mlvwm.nix b/nixos/modules/services/x11/window-managers/mlvwm.nix index 08dd04020296d6..5d25478a830a93 100644 --- a/nixos/modules/services/x11/window-managers/mlvwm.nix +++ b/nixos/modules/services/x11/window-managers/mlvwm.nix @@ -1,8 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; -let cfg = config.services.xserver.windowManager.mlvwm; +let + cfg = config.services.xserver.windowManager.mlvwm; in { @@ -22,15 +28,15 @@ in config = mkIf cfg.enable { - services.xserver.windowManager.session = [{ - name = "mlvwm"; - start = '' - ${pkgs.mlvwm}/bin/mlvwm ${optionalString (cfg.configFile != null) - "-f /etc/mlvwm/mlvwmrc" - } & - waitPID=$! - ''; - }]; + services.xserver.windowManager.session = [ + { + name = "mlvwm"; + start = '' + ${pkgs.mlvwm}/bin/mlvwm ${optionalString (cfg.configFile != null) "-f /etc/mlvwm/mlvwmrc"} & + waitPID=$! + ''; + } + ]; environment.etc."mlvwm/mlvwmrc" = mkIf (cfg.configFile != null) { source = cfg.configFile; diff --git a/nixos/modules/services/x11/window-managers/mwm.nix b/nixos/modules/services/x11/window-managers/mwm.nix index 31f7b725f747dc..6f10e07343cfdd 100644 --- a/nixos/modules/services/x11/window-managers/mwm.nix +++ b/nixos/modules/services/x11/window-managers/mwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/nimdow.nix b/nixos/modules/services/x11/window-managers/nimdow.nix index 2ac9ace63ce468..bde5bd950a0211 100644 --- a/nixos/modules/services/x11/window-managers/nimdow.nix +++ b/nixos/modules/services/x11/window-managers/nimdow.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -16,7 +21,6 @@ in }; }; - config = mkIf cfg.enable { services.xserver.windowManager.session = singleton { name = "nimdow"; @@ -25,6 +29,9 @@ in waitPID=$! ''; }; - environment.systemPackages = [ cfg.package pkgs.st ]; + environment.systemPackages = [ + cfg.package + pkgs.st + ]; }; } diff --git a/nixos/modules/services/x11/window-managers/none.nix b/nixos/modules/services/x11/window-managers/none.nix index 84cf1d77077683..9c8d24a7e50e34 100644 --- a/nixos/modules/services/x11/window-managers/none.nix +++ b/nixos/modules/services/x11/window-managers/none.nix @@ -2,10 +2,12 @@ services = { xserver = { windowManager = { - session = [{ - name = "none"; - start = ""; - }]; + session = [ + { + name = "none"; + start = ""; + } + ]; }; }; }; diff --git a/nixos/modules/services/x11/window-managers/notion.nix b/nixos/modules/services/x11/window-managers/notion.nix index 4ece0d241c90ce..797554eacde941 100644 --- a/nixos/modules/services/x11/window-managers/notion.nix +++ b/nixos/modules/services/x11/window-managers/notion.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -13,13 +18,15 @@ in config = mkIf cfg.enable { services.xserver.windowManager = { - session = [{ - name = "notion"; - start = '' - ${pkgs.notion}/bin/notion & - waitPID=$! - ''; - }]; + session = [ + { + name = "notion"; + start = '' + ${pkgs.notion}/bin/notion & + waitPID=$! + ''; + } + ]; }; environment.systemPackages = [ pkgs.notion ]; }; diff --git a/nixos/modules/services/x11/window-managers/openbox.nix b/nixos/modules/services/x11/window-managers/openbox.nix index 165772d1aa097f..5a9a45ca221ef0 100644 --- a/nixos/modules/services/x11/window-managers/openbox.nix +++ b/nixos/modules/services/x11/window-managers/openbox.nix @@ -1,4 +1,9 @@ -{lib, pkgs, config, ...}: +{ + lib, + pkgs, + config, + ... +}: with lib; let @@ -12,12 +17,14 @@ in config = mkIf cfg.enable { services.xserver.windowManager = { - session = [{ - name = "openbox"; - start = " + session = [ + { + name = "openbox"; + start = " ${pkgs.openbox}/bin/openbox-session "; - }]; + } + ]; }; environment.systemPackages = [ pkgs.openbox ]; }; diff --git a/nixos/modules/services/x11/window-managers/pekwm.nix b/nixos/modules/services/x11/window-managers/pekwm.nix index 850335ce7ddfa1..e4881d676cb69a 100644 --- a/nixos/modules/services/x11/window-managers/pekwm.nix +++ b/nixos/modules/services/x11/window-managers/pekwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/ragnarwm.nix b/nixos/modules/services/x11/window-managers/ragnarwm.nix index 3f550fb7232562..0c5b06fb4e57f9 100644 --- a/nixos/modules/services/x11/window-managers/ragnarwm.nix +++ b/nixos/modules/services/x11/window-managers/ragnarwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/ratpoison.nix b/nixos/modules/services/x11/window-managers/ratpoison.nix index 0d58481d45791b..44413c1adc3aa9 100644 --- a/nixos/modules/services/x11/window-managers/ratpoison.nix +++ b/nixos/modules/services/x11/window-managers/ratpoison.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/sawfish.nix b/nixos/modules/services/x11/window-managers/sawfish.nix index b988b5e1829e61..cf5e8945c0a2b8 100644 --- a/nixos/modules/services/x11/window-managers/sawfish.nix +++ b/nixos/modules/services/x11/window-managers/sawfish.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/smallwm.nix b/nixos/modules/services/x11/window-managers/smallwm.nix index 091ba4f92b94d3..e85b1a7bf2e076 100644 --- a/nixos/modules/services/x11/window-managers/smallwm.nix +++ b/nixos/modules/services/x11/window-managers/smallwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/spectrwm.nix b/nixos/modules/services/x11/window-managers/spectrwm.nix index a1dc298d242695..4a4b6920fdb10c 100644 --- a/nixos/modules/services/x11/window-managers/spectrwm.nix +++ b/nixos/modules/services/x11/window-managers/spectrwm.nix @@ -1,5 +1,9 @@ - -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -14,13 +18,15 @@ in config = mkIf cfg.enable { services.xserver.windowManager = { - session = [{ - name = "spectrwm"; - start = '' - ${pkgs.spectrwm}/bin/spectrwm & - waitPID=$! - ''; - }]; + session = [ + { + name = "spectrwm"; + start = '' + ${pkgs.spectrwm}/bin/spectrwm & + waitPID=$! + ''; + } + ]; }; environment.systemPackages = [ pkgs.spectrwm ]; }; diff --git a/nixos/modules/services/x11/window-managers/stumpwm.nix b/nixos/modules/services/x11/window-managers/stumpwm.nix index fa6844e672f5a0..b97de030d7f6b4 100644 --- a/nixos/modules/services/x11/window-managers/stumpwm.nix +++ b/nixos/modules/services/x11/window-managers/stumpwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/tinywm.nix b/nixos/modules/services/x11/window-managers/tinywm.nix index 8e5d9b9170caba..9508f5757f44fb 100644 --- a/nixos/modules/services/x11/window-managers/tinywm.nix +++ b/nixos/modules/services/x11/window-managers/tinywm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/twm.nix b/nixos/modules/services/x11/window-managers/twm.nix index fc09901aae3b09..46f81775b65ea2 100644 --- a/nixos/modules/services/x11/window-managers/twm.nix +++ b/nixos/modules/services/x11/window-managers/twm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -16,19 +21,17 @@ in services.xserver.windowManager.twm.enable = mkEnableOption "twm"; }; - ###### implementation config = mkIf cfg.enable { - services.xserver.windowManager.session = singleton - { name = "twm"; - start = - '' - ${pkgs.xorg.twm}/bin/twm & - waitPID=$! - ''; - }; + services.xserver.windowManager.session = singleton { + name = "twm"; + start = '' + ${pkgs.xorg.twm}/bin/twm & + waitPID=$! + ''; + }; environment.systemPackages = [ pkgs.xorg.twm ]; diff --git a/nixos/modules/services/x11/window-managers/windowlab.nix b/nixos/modules/services/x11/window-managers/windowlab.nix index fb891a39fa4124..f71bb97cf056a4 100644 --- a/nixos/modules/services/x11/window-managers/windowlab.nix +++ b/nixos/modules/services/x11/window-managers/windowlab.nix @@ -1,4 +1,9 @@ -{lib, pkgs, config, ...}: +{ + lib, + pkgs, + config, + ... +}: let cfg = config.services.xserver.windowManager.windowlab; @@ -6,16 +11,17 @@ in { options = { - services.xserver.windowManager.windowlab.enable = - lib.mkEnableOption "windowlab"; + services.xserver.windowManager.windowlab.enable = lib.mkEnableOption "windowlab"; }; config = lib.mkIf cfg.enable { services.xserver.windowManager = { - session = - [{ name = "windowlab"; - start = "${pkgs.windowlab}/bin/windowlab"; - }]; + session = [ + { + name = "windowlab"; + start = "${pkgs.windowlab}/bin/windowlab"; + } + ]; }; environment.systemPackages = [ pkgs.windowlab ]; }; diff --git a/nixos/modules/services/x11/window-managers/windowmaker.nix b/nixos/modules/services/x11/window-managers/windowmaker.nix index b62723758056e4..f5958d1f2a3e7d 100644 --- a/nixos/modules/services/x11/window-managers/windowmaker.nix +++ b/nixos/modules/services/x11/window-managers/windowmaker.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/window-managers/wmderland.nix b/nixos/modules/services/x11/window-managers/wmderland.nix index 56b69220965171..018c152572b5c8 100644 --- a/nixos/modules/services/x11/window-managers/wmderland.nix +++ b/nixos/modules/services/x11/window-managers/wmderland.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -55,7 +60,8 @@ in ''; }; environment.systemPackages = [ - pkgs.wmderland pkgs.wmderlandc + pkgs.wmderland + pkgs.wmderlandc ] ++ cfg.extraPackages; }; } diff --git a/nixos/modules/services/x11/window-managers/wmii.nix b/nixos/modules/services/x11/window-managers/wmii.nix index 9b50a99bf23f18..a2363eee605600 100644 --- a/nixos/modules/services/x11/window-managers/wmii.nix +++ b/nixos/modules/services/x11/window-managers/wmii.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let @@ -11,28 +16,30 @@ in }; config = mkIf cfg.enable { - services.xserver.windowManager.session = singleton - # stop wmii by - # $wmiir xwrite /ctl quit - # this will cause wmii exiting with exit code 0 - # (or "mod+a quit", which is bound to do the same thing in wmiirc - # by default) - # - # why this loop? - # wmii crashes once a month here. That doesn't matter that much - # wmii can recover very well. However without loop the X session - # terminates and then your workspace setup is lost and all - # applications running on X will terminate. - # Another use case is kill -9 wmii; after rotating screen. - # Note: we don't like kill for that purpose. But it works (-> - # subject "wmii and xrandr" on mailinglist) - { name = "wmii"; - start = '' - while :; do - ${wmii}/bin/wmii && break - done - ''; - }; + services.xserver.windowManager.session = + singleton + # stop wmii by + # $wmiir xwrite /ctl quit + # this will cause wmii exiting with exit code 0 + # (or "mod+a quit", which is bound to do the same thing in wmiirc + # by default) + # + # why this loop? + # wmii crashes once a month here. That doesn't matter that much + # wmii can recover very well. However without loop the X session + # terminates and then your workspace setup is lost and all + # applications running on X will terminate. + # Another use case is kill -9 wmii; after rotating screen. + # Note: we don't like kill for that purpose. But it works (-> + # subject "wmii and xrandr" on mailinglist) + { + name = "wmii"; + start = '' + while :; do + ${wmii}/bin/wmii && break + done + ''; + }; environment.systemPackages = [ wmii ]; }; diff --git a/nixos/modules/services/x11/window-managers/yeahwm.nix b/nixos/modules/services/x11/window-managers/yeahwm.nix index 351bd7dfe48b4d..db623382016ce6 100644 --- a/nixos/modules/services/x11/window-managers/yeahwm.nix +++ b/nixos/modules/services/x11/window-managers/yeahwm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/services/x11/xautolock.nix b/nixos/modules/services/x11/xautolock.nix index 04f3821e7508c5..1fd6c54f6b9638 100644 --- a/nixos/modules/services/x11/xautolock.nix +++ b/nixos/modules/services/x11/xautolock.nix @@ -1,127 +1,139 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.xserver.xautolock; in - { - options = { - services.xserver.xautolock = { - enable = mkEnableOption "xautolock"; - enableNotifier = mkEnableOption "xautolock.notify" // { - description = '' - Whether to enable the notifier feature of xautolock. - This publishes a notification before the autolock. - ''; - }; - - time = mkOption { - default = 15; - type = types.int; - - description = '' - Idle time (in minutes) to wait until xautolock locks the computer. - ''; - }; - - locker = mkOption { - default = "${pkgs.xlockmore}/bin/xlock"; # default according to `man xautolock` - defaultText = literalExpression ''"''${pkgs.xlockmore}/bin/xlock"''; - example = literalExpression ''"''${pkgs.i3lock}/bin/i3lock -i /path/to/img"''; - type = types.str; - - description = '' - The script to use when automatically locking the computer. - ''; - }; - - nowlocker = mkOption { - default = null; - example = literalExpression ''"''${pkgs.i3lock}/bin/i3lock -i /path/to/img"''; - type = types.nullOr types.str; - - description = '' - The script to use when manually locking the computer with {command}`xautolock -locknow`. - ''; - }; - - notify = mkOption { - default = 10; - type = types.int; - - description = '' - Time (in seconds) before the actual lock when the notification about the pending lock should be published. - ''; - }; - - notifier = mkOption { - default = null; - example = literalExpression ''"''${pkgs.libnotify}/bin/notify-send 'Locking in 10 seconds'"''; - type = types.nullOr types.str; - - description = '' - Notification script to be used to warn about the pending autolock. - ''; - }; - - killer = mkOption { - default = null; # default according to `man xautolock` is none - example = "/run/current-system/systemd/bin/systemctl suspend"; - type = types.nullOr types.str; - - description = '' - The script to use when nothing has happened for as long as {option}`killtime` - ''; - }; - - killtime = mkOption { - default = 20; # default according to `man xautolock` - type = types.int; - - description = '' - Minutes xautolock waits until it executes the script specified in {option}`killer` - (Has to be at least 10 minutes) - ''; - }; - - extraOptions = mkOption { - type = types.listOf types.str; - default = [ ]; - example = [ "-detectsleep" ]; - description = '' - Additional command-line arguments to pass to - {command}`xautolock`. - ''; - }; +{ + options = { + services.xserver.xautolock = { + enable = mkEnableOption "xautolock"; + enableNotifier = mkEnableOption "xautolock.notify" // { + description = '' + Whether to enable the notifier feature of xautolock. + This publishes a notification before the autolock. + ''; }; - }; - config = mkIf cfg.enable { - environment.systemPackages = with pkgs; [ xautolock ]; - systemd.user.services.xautolock = { - description = "xautolock service"; - wantedBy = [ "graphical-session.target" ]; - partOf = [ "graphical-session.target" ]; - serviceConfig = with lib; { - ExecStart = strings.concatStringsSep " " ([ + time = mkOption { + default = 15; + type = types.int; + + description = '' + Idle time (in minutes) to wait until xautolock locks the computer. + ''; + }; + + locker = mkOption { + default = "${pkgs.xlockmore}/bin/xlock"; # default according to `man xautolock` + defaultText = literalExpression ''"''${pkgs.xlockmore}/bin/xlock"''; + example = literalExpression ''"''${pkgs.i3lock}/bin/i3lock -i /path/to/img"''; + type = types.str; + + description = '' + The script to use when automatically locking the computer. + ''; + }; + + nowlocker = mkOption { + default = null; + example = literalExpression ''"''${pkgs.i3lock}/bin/i3lock -i /path/to/img"''; + type = types.nullOr types.str; + + description = '' + The script to use when manually locking the computer with {command}`xautolock -locknow`. + ''; + }; + + notify = mkOption { + default = 10; + type = types.int; + + description = '' + Time (in seconds) before the actual lock when the notification about the pending lock should be published. + ''; + }; + + notifier = mkOption { + default = null; + example = literalExpression ''"''${pkgs.libnotify}/bin/notify-send 'Locking in 10 seconds'"''; + type = types.nullOr types.str; + + description = '' + Notification script to be used to warn about the pending autolock. + ''; + }; + + killer = mkOption { + default = null; # default according to `man xautolock` is none + example = "/run/current-system/systemd/bin/systemctl suspend"; + type = types.nullOr types.str; + + description = '' + The script to use when nothing has happened for as long as {option}`killtime` + ''; + }; + + killtime = mkOption { + default = 20; # default according to `man xautolock` + type = types.int; + + description = '' + Minutes xautolock waits until it executes the script specified in {option}`killer` + (Has to be at least 10 minutes) + ''; + }; + + extraOptions = mkOption { + type = types.listOf types.str; + default = [ ]; + example = [ "-detectsleep" ]; + description = '' + Additional command-line arguments to pass to + {command}`xautolock`. + ''; + }; + }; + }; + + config = mkIf cfg.enable { + environment.systemPackages = with pkgs; [ xautolock ]; + systemd.user.services.xautolock = { + description = "xautolock service"; + wantedBy = [ "graphical-session.target" ]; + partOf = [ "graphical-session.target" ]; + serviceConfig = with lib; { + ExecStart = strings.concatStringsSep " " ( + [ "${pkgs.xautolock}/bin/xautolock" "-noclose" "-time ${toString cfg.time}" "-locker '${cfg.locker}'" - ] ++ optionals cfg.enableNotifier [ + ] + ++ optionals cfg.enableNotifier [ "-notify ${toString cfg.notify}" "-notifier '${cfg.notifier}'" - ] ++ optionals (cfg.nowlocker != null) [ + ] + ++ optionals (cfg.nowlocker != null) [ "-nowlocker '${cfg.nowlocker}'" - ] ++ optionals (cfg.killer != null) [ + ] + ++ optionals (cfg.killer != null) [ "-killer '${cfg.killer}'" "-killtime ${toString cfg.killtime}" - ] ++ cfg.extraOptions); - Restart = "always"; - }; + ] + ++ cfg.extraOptions + ); + Restart = "always"; }; - assertions = [ + }; + assertions = + [ { assertion = cfg.enableNotifier -> cfg.notifier != null; message = "When enabling the notifier for xautolock, you also need to specify the notify script"; @@ -130,12 +142,10 @@ in assertion = cfg.killer != null -> cfg.killtime >= 10; message = "killtime has to be at least 10 minutes according to `man xautolock`"; } - ] ++ (lib.forEach [ "locker" "notifier" "nowlocker" "killer" ] - (option: - { - assertion = cfg.${option} != null -> builtins.substring 0 1 cfg.${option} == "/"; - message = "Please specify a canonical path for `services.xserver.xautolock.${option}`"; - }) - ); - }; - } + ] + ++ (lib.forEach [ "locker" "notifier" "nowlocker" "killer" ] (option: { + assertion = cfg.${option} != null -> builtins.substring 0 1 cfg.${option} == "/"; + message = "Please specify a canonical path for `services.xserver.xautolock.${option}`"; + })); + }; +} diff --git a/nixos/modules/services/x11/xbanish.nix b/nixos/modules/services/x11/xbanish.nix index b95fac68f1658a..6813f615c32d54 100644 --- a/nixos/modules/services/x11/xbanish.nix +++ b/nixos/modules/services/x11/xbanish.nix @@ -1,10 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; -let cfg = config.services.xbanish; +let + cfg = config.services.xbanish; -in { +in +{ options.services.xbanish = { enable = mkEnableOption "xbanish"; diff --git a/nixos/modules/services/x11/xfs.nix b/nixos/modules/services/x11/xfs.nix index ea7cfa1aa43c59..9214f176c10bc6 100644 --- a/nixos/modules/services/x11/xfs.nix +++ b/nixos/modules/services/x11/xfs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -26,14 +31,13 @@ in }; - ###### implementation config = mkIf config.services.xfs.enable { - assertions = singleton - { assertion = config.fonts.enableFontDir; - message = "Please enable fonts.enableFontDir to use the X Font Server."; - }; + assertions = singleton { + assertion = config.fonts.enableFontDir; + message = "Please enable fonts.enableFontDir to use the X Font Server."; + }; systemd.services.xfs = { description = "X Font Server"; diff --git a/nixos/modules/services/x11/xscreensaver.nix b/nixos/modules/services/x11/xscreensaver.nix index dc269b892ebcf6..2e2853eb066eb6 100644 --- a/nixos/modules/services/x11/xscreensaver.nix +++ b/nixos/modules/services/x11/xscreensaver.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.xscreensaver; @@ -36,5 +41,8 @@ in }; }; - meta.maintainers = with lib.maintainers; [ vancluever AndersonTorres ]; + meta.maintainers = with lib.maintainers; [ + vancluever + AndersonTorres + ]; } diff --git a/nixos/modules/system/activation/activatable-system.nix b/nixos/modules/system/activation/activatable-system.nix index e442fce7541b9c..bb207ec0c18f2e 100644 --- a/nixos/modules/system/activation/activatable-system.nix +++ b/nixos/modules/system/activation/activatable-system.nix @@ -1,4 +1,10 @@ -{ options, config, lib, pkgs, ... }: +{ + options, + config, + lib, + pkgs, + ... +}: let inherit (lib) @@ -56,21 +62,23 @@ in unset activationScript dryActivationScript ''; - system.systemBuilderCommands = lib.mkIf - config.system.activatable - config.system.activatableSystemBuilderCommands; - system.systemBuilderArgs = lib.mkIf config.system.activatable - (systemBuilderArgs // { + system.systemBuilderCommands = lib.mkIf config.system.activatable config.system.activatableSystemBuilderCommands; + system.systemBuilderArgs = lib.mkIf config.system.activatable ( + systemBuilderArgs + // { toplevelVar = "out"; - }); + } + ); system.build.separateActivationScript = - pkgs.runCommand - "separate-activation-script" - (systemBuilderArgs // { - toplevelVar = "toplevel"; - toplevel = config.system.build.toplevel; - }) + pkgs.runCommand "separate-activation-script" + ( + systemBuilderArgs + // { + toplevelVar = "toplevel"; + toplevel = config.system.build.toplevel; + } + ) '' mkdir $out ${config.system.activatableSystemBuilderCommands} diff --git a/nixos/modules/system/activation/bootspec.nix b/nixos/modules/system/activation/bootspec.nix index 3c2b91cce70162..4f534b240e6768 100644 --- a/nixos/modules/system/activation/bootspec.nix +++ b/nixos/modules/system/activation/bootspec.nix @@ -3,35 +3,43 @@ # Changes to the structure of the document, or the semantics of the values should go through an RFC. # # See: https://github.com/NixOS/rfcs/pull/125 -{ config -, pkgs -, lib -, ... +{ + config, + pkgs, + lib, + ... }: let cfg = config.boot.bootspec; - children = lib.mapAttrs (childName: childConfig: childConfig.configuration.system.build.toplevel) config.specialisation; + children = lib.mapAttrs ( + childName: childConfig: childConfig.configuration.system.build.toplevel + ) config.specialisation; hasAtLeastOneInitrdSecret = lib.length (lib.attrNames config.boot.initrd.secrets) > 0; schemas = { v1 = rec { filename = "boot.json"; - json = - pkgs.writeText filename - (builtins.toJSON + json = pkgs.writeText filename ( + builtins.toJSON # Merge extensions first to not let them shadow NixOS bootspec data. - (cfg.extensions // - { - "org.nixos.bootspec.v1" = { - system = config.boot.kernelPackages.stdenv.hostPlatform.system; - kernel = "${config.boot.kernelPackages.kernel}/${config.system.boot.loader.kernelFile}"; - kernelParams = config.boot.kernelParams; - label = "${config.system.nixos.distroName} ${config.system.nixos.codeName} ${config.system.nixos.label} (Linux ${config.boot.kernelPackages.kernel.modDirVersion})"; - } // lib.optionalAttrs config.boot.initrd.enable { - initrd = "${config.system.build.initialRamdisk}/${config.system.boot.loader.initrdFile}"; - } // lib.optionalAttrs hasAtLeastOneInitrdSecret { - initrdSecrets = "${config.system.build.initialRamdiskSecretAppender}/bin/append-initrd-secrets"; - }; - })); + ( + cfg.extensions + // { + "org.nixos.bootspec.v1" = + { + system = config.boot.kernelPackages.stdenv.hostPlatform.system; + kernel = "${config.boot.kernelPackages.kernel}/${config.system.boot.loader.kernelFile}"; + kernelParams = config.boot.kernelParams; + label = "${config.system.nixos.distroName} ${config.system.nixos.codeName} ${config.system.nixos.label} (Linux ${config.boot.kernelPackages.kernel.modDirVersion})"; + } + // lib.optionalAttrs config.boot.initrd.enable { + initrd = "${config.system.build.initialRamdisk}/${config.system.boot.loader.initrdFile}"; + } + // lib.optionalAttrs hasAtLeastOneInitrdSecret { + initrdSecrets = "${config.system.build.initialRamdiskSecretAppender}/bin/append-initrd-secrets"; + }; + } + ) + ); generator = let @@ -41,31 +49,45 @@ let # Inject toplevel and init into the bootspec. # This can only be done here because we *cannot* depend on $out # referring to the toplevel, except by living in the toplevel itself. - toplevelInjector = lib.escapeShellArgs [ - "${pkgs.buildPackages.jq}/bin/jq" - '' - ."org.nixos.bootspec.v1".toplevel = $toplevel | - ."org.nixos.bootspec.v1".init = $init - '' - "--sort-keys" - "--arg" "toplevel" "${placeholder "out"}" - "--arg" "init" "${placeholder "out"}/init" - ] + " < ${json}"; + toplevelInjector = + lib.escapeShellArgs [ + "${pkgs.buildPackages.jq}/bin/jq" + '' + ."org.nixos.bootspec.v1".toplevel = $toplevel | + ."org.nixos.bootspec.v1".init = $init + '' + "--sort-keys" + "--arg" + "toplevel" + "${placeholder "out"}" + "--arg" + "init" + "${placeholder "out"}/init" + ] + + " < ${json}"; # We slurp all specialisations and inject them as values, such that # `.specialisations.${name}` embeds the specialisation's bootspec # document. specialisationInjector = let - specialisationLoader = (lib.mapAttrsToList - (childName: childToplevel: lib.escapeShellArgs [ "--slurpfile" childName "${childToplevel}/${filename}" ]) - children); + specialisationLoader = ( + lib.mapAttrsToList ( + childName: childToplevel: + lib.escapeShellArgs [ + "--slurpfile" + childName + "${childToplevel}/${filename}" + ] + ) children + ); in lib.escapeShellArgs [ "${pkgs.buildPackages.jq}/bin/jq" "--sort-keys" ''."org.nixos.specialisation.v1" = ($ARGS.named | map_values(. | first))'' - ] + " ${lib.concatStringsSep " " specialisationLoader}"; + ] + + " ${lib.concatStringsSep " " specialisationLoader}"; in "${toplevelInjector} | ${specialisationInjector} > $out/${filename}"; @@ -77,12 +99,17 @@ let in { options.boot.bootspec = { - enable = lib.mkEnableOption "the generation of RFC-0125 bootspec in $system/boot.json, e.g. /run/current-system/boot.json" - // { default = true; internal = true; }; - enableValidation = lib.mkEnableOption ''the validation of bootspec documents for each build. - This will introduce Go in the build-time closure as we are relying on [Cuelang](https://cuelang.org/) for schema validation. - Enable this option if you want to ascertain that your documents are correct - ''; + enable = + lib.mkEnableOption "the generation of RFC-0125 bootspec in $system/boot.json, e.g. /run/current-system/boot.json" + // { + default = true; + internal = true; + }; + enableValidation = lib.mkEnableOption '' + the validation of bootspec documents for each build. + This will introduce Go in the build-time closure as we are relying on [Cuelang](https://cuelang.org/) for schema validation. + Enable this option if you want to ascertain that your documents are correct + ''; extensions = lib.mkOption { # NOTE(RaitoBezarius): this is not enough to validate: extensions."osRelease" = drv; those are picked up by cue validation. diff --git a/nixos/modules/system/activation/lib/test.nix b/nixos/modules/system/activation/lib/test.nix index 39886d305195ac..798417278dc513 100644 --- a/nixos/modules/system/activation/lib/test.nix +++ b/nixos/modules/system/activation/lib/test.nix @@ -1,6 +1,10 @@ # Run: # nix-build -A nixosTests.activation-lib -{ lib, stdenv, testers }: +{ + lib, + stdenv, + testers, +}: let inherit (lib) fileset; diff --git a/nixos/modules/system/activation/no-clone.nix b/nixos/modules/system/activation/no-clone.nix index 32ff54688bd9e1..d1ecc37b2ba0cf 100644 --- a/nixos/modules/system/activation/no-clone.nix +++ b/nixos/modules/system/activation/no-clone.nix @@ -4,6 +4,6 @@ with lib; { boot.loader.grub.device = mkOverride 0 "nodev"; - specialisation = mkOverride 0 {}; + specialisation = mkOverride 0 { }; isSpecialisation = mkOverride 0 true; } diff --git a/nixos/modules/system/activation/specialisation.nix b/nixos/modules/system/activation/specialisation.nix index 41491b67ff039a..1bc25724853921 100644 --- a/nixos/modules/system/activation/specialisation.nix +++ b/nixos/modules/system/activation/specialisation.nix @@ -1,4 +1,11 @@ -{ config, lib, pkgs, extendModules, noUserModules, ... }: +{ + config, + lib, + pkgs, + extendModules, + noUserModules, + ... +}: let inherit (lib) @@ -15,10 +22,9 @@ let # you can provide an easy way to boot the same configuration # as you use, but with another kernel # !!! fix this - children = - mapAttrs - (childName: childConfig: childConfig.configuration.system.build.toplevel) - config.specialisation; + children = mapAttrs ( + childName: childConfig: childConfig.configuration.system.build.toplevel + ) config.specialisation; in { @@ -45,35 +51,34 @@ in sudo /run/current-system/specialisation/fewJobsManyCores/bin/switch-to-configuration test ``` ''; - type = types.attrsOf (types.submodule ( - local@{ ... }: - let - extend = - if local.config.inheritParentConfig - then extendModules - else noUserModules.extendModules; - in - { - options.inheritParentConfig = mkOption { - type = types.bool; - default = true; - description = "Include the entire system's configuration. Set to false to make a completely differently configured system."; - }; + type = types.attrsOf ( + types.submodule ( + local@{ ... }: + let + extend = if local.config.inheritParentConfig then extendModules else noUserModules.extendModules; + in + { + options.inheritParentConfig = mkOption { + type = types.bool; + default = true; + description = "Include the entire system's configuration. Set to false to make a completely differently configured system."; + }; - options.configuration = mkOption { - default = { }; - description = '' - Arbitrary NixOS configuration. + options.configuration = mkOption { + default = { }; + description = '' + Arbitrary NixOS configuration. - Anything you can add to a normal NixOS configuration, you can add - here, including imports and config values, although nested - specialisations will be ignored. - ''; - visible = "shallow"; - inherit (extend { modules = [ ./no-clone.nix ]; }) type; - }; - } - )); + Anything you can add to a normal NixOS configuration, you can add + here, including imports and config values, although nested + specialisations will be ignored. + ''; + visible = "shallow"; + inherit (extend { modules = [ ./no-clone.nix ]; }) type; + }; + } + ) + ); }; }; @@ -81,8 +86,9 @@ in config = { system.systemBuilderCommands = '' mkdir $out/specialisation - ${concatStringsSep "\n" - (mapAttrsToList (name: path: "ln -s ${path} $out/specialisation/${name}") children)} + ${concatStringsSep "\n" ( + mapAttrsToList (name: path: "ln -s ${path} $out/specialisation/${name}") children + )} ''; }; diff --git a/nixos/modules/system/activation/test.nix b/nixos/modules/system/activation/test.nix index fd251d52895796..fe8acb708868c8 100644 --- a/nixos/modules/system/activation/test.nix +++ b/nixos/modules/system/activation/test.nix @@ -1,27 +1,35 @@ -{ lib -, nixos -, expect -, testers +{ + lib, + nixos, + expect, + testers, }: let - node-forbiddenDependencies-fail = nixos ({ ... }: { - system.forbiddenDependenciesRegexes = ["-dev$"]; - environment.etc."dev-dependency" = { - text = "${expect.dev}"; - }; - documentation.enable = false; - fileSystems."/".device = "ignore-root-device"; - boot.loader.grub.enable = false; - }); - node-forbiddenDependencies-succeed = nixos ({ ... }: { - system.forbiddenDependenciesRegexes = ["-dev$"]; - system.extraDependencies = [ expect.dev ]; - documentation.enable = false; - fileSystems."/".device = "ignore-root-device"; - boot.loader.grub.enable = false; - }); + node-forbiddenDependencies-fail = nixos ( + { ... }: + { + system.forbiddenDependenciesRegexes = [ "-dev$" ]; + environment.etc."dev-dependency" = { + text = "${expect.dev}"; + }; + documentation.enable = false; + fileSystems."/".device = "ignore-root-device"; + boot.loader.grub.enable = false; + } + ); + node-forbiddenDependencies-succeed = nixos ( + { ... }: + { + system.forbiddenDependenciesRegexes = [ "-dev$" ]; + system.extraDependencies = [ expect.dev ]; + documentation.enable = false; + fileSystems."/".device = "ignore-root-device"; + boot.loader.grub.enable = false; + } + ); in lib.recurseIntoAttrs { test-forbiddenDependencies-fail = testers.testBuildFailure node-forbiddenDependencies-fail.config.system.build.toplevel; - test-forbiddenDependencies-succeed = node-forbiddenDependencies-succeed.config.system.build.toplevel; + test-forbiddenDependencies-succeed = + node-forbiddenDependencies-succeed.config.system.build.toplevel; } diff --git a/nixos/modules/system/boot/binfmt.nix b/nixos/modules/system/boot/binfmt.nix index e9de71dc4d5a64..e7c914954f1eb0 100644 --- a/nixos/modules/system/boot/binfmt.nix +++ b/nixos/modules/system/boot/binfmt.nix @@ -1,33 +1,58 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) mkOption mkDefault types optionalString; + inherit (lib) + mkOption + mkDefault + types + optionalString + ; cfg = config.boot.binfmt; - makeBinfmtLine = name: { recognitionType, offset, magicOrExtension - , mask, preserveArgvZero, openBinary - , matchCredentials, fixBinary, ... - }: let - type = if recognitionType == "magic" then "M" else "E"; - offset' = toString offset; - mask' = toString mask; - interpreter = "/run/binfmt/${name}"; - flags = if !(matchCredentials -> openBinary) - then throw "boot.binfmt.registrations.${name}: you can't specify openBinary = false when matchCredentials = true." - else optionalString preserveArgvZero "P" + - optionalString (openBinary && !matchCredentials) "O" + - optionalString matchCredentials "C" + - optionalString fixBinary "F"; - in ":${name}:${type}:${offset'}:${magicOrExtension}:${mask'}:${interpreter}:${flags}"; - - mkInterpreter = name: { interpreter, wrapInterpreterInShell, ... }: - if wrapInterpreterInShell - then pkgs.writeShellScript "${name}-interpreter" '' - #!${pkgs.bash}/bin/sh - exec -- ${interpreter} "$@" - '' - else interpreter; - + makeBinfmtLine = + name: + { + recognitionType, + offset, + magicOrExtension, + mask, + preserveArgvZero, + openBinary, + matchCredentials, + fixBinary, + ... + }: + let + type = if recognitionType == "magic" then "M" else "E"; + offset' = toString offset; + mask' = toString mask; + interpreter = "/run/binfmt/${name}"; + flags = + if !(matchCredentials -> openBinary) then + throw "boot.binfmt.registrations.${name}: you can't specify openBinary = false when matchCredentials = true." + else + optionalString preserveArgvZero "P" + + optionalString (openBinary && !matchCredentials) "O" + + optionalString matchCredentials "C" + + optionalString fixBinary "F"; + in + ":${name}:${type}:${offset'}:${magicOrExtension}:${mask'}:${interpreter}:${flags}"; + + mkInterpreter = + name: + { interpreter, wrapInterpreterInShell, ... }: + if wrapInterpreterInShell then + pkgs.writeShellScript "${name}-interpreter" '' + #!${pkgs.bash}/bin/sh + exec -- ${interpreter} "$@" + '' + else + interpreter; # Mapping of systems to “magicOrExtension” and “mask”. Mostly taken from: # - https://github.com/cleverca22/nixos-configs/blob/master/qemu.nix @@ -147,7 +172,8 @@ let i686-windows.magicOrExtension = "MZ"; }; -in { +in +{ imports = [ (lib.mkRenamedOptionModule [ "boot" "binfmtMiscRegistrations" ] [ "boot" "binfmt" "registrations" ]) ]; @@ -155,122 +181,134 @@ in { options = { boot.binfmt = { registrations = mkOption { - default = {}; + default = { }; description = '' Extra binary formats to register with the kernel. See https://www.kernel.org/doc/html/latest/admin-guide/binfmt-misc.html for more details. ''; - type = types.attrsOf (types.submodule ({ config, ... }: { - options = { - recognitionType = mkOption { - default = "magic"; - description = "Whether to recognize executables by magic number or extension."; - type = types.enum [ "magic" "extension" ]; - }; - - offset = mkOption { - default = null; - description = "The byte offset of the magic number used for recognition."; - type = types.nullOr types.int; - }; - - magicOrExtension = mkOption { - description = "The magic number or extension to match on."; - type = types.str; - }; - - mask = mkOption { - default = null; - description = "A mask to be ANDed with the byte sequence of the file before matching"; - type = types.nullOr types.str; - }; - - interpreter = mkOption { - description = '' - The interpreter to invoke to run the program. - - Note that the actual registration will point to - /run/binfmt/''${name}, so the kernel interpreter length - limit doesn't apply. - ''; - type = types.path; - }; - - preserveArgvZero = mkOption { - default = false; - description = '' - Whether to pass the original argv[0] to the interpreter. - - See the description of the 'P' flag in the kernel docs - for more details; - ''; - type = types.bool; - }; - - openBinary = mkOption { - default = config.matchCredentials; - description = '' - Whether to pass the binary to the interpreter as an open - file descriptor, instead of a path. - ''; - type = types.bool; - }; - - matchCredentials = mkOption { - default = false; - description = '' - Whether to launch with the credentials and security - token of the binary, not the interpreter (e.g. setuid - bit). - - See the description of the 'C' flag in the kernel docs - for more details. - - Implies/requires openBinary = true. - ''; - type = types.bool; - }; - - fixBinary = mkOption { - default = false; - description = '' - Whether to open the interpreter file as soon as the - registration is loaded, rather than waiting for a - relevant file to be invoked. - - See the description of the 'F' flag in the kernel docs - for more details. - ''; - type = types.bool; - }; - - wrapInterpreterInShell = mkOption { - default = true; - description = '' - Whether to wrap the interpreter in a shell script. - - This allows a shell command to be set as the interpreter. - ''; - type = types.bool; - }; - - interpreterSandboxPath = mkOption { - internal = true; - default = null; - description = '' - Path of the interpreter to expose in the build sandbox. - ''; - type = types.nullOr types.path; - }; - }; - })); + type = types.attrsOf ( + types.submodule ( + { config, ... }: + { + options = { + recognitionType = mkOption { + default = "magic"; + description = "Whether to recognize executables by magic number or extension."; + type = types.enum [ + "magic" + "extension" + ]; + }; + + offset = mkOption { + default = null; + description = "The byte offset of the magic number used for recognition."; + type = types.nullOr types.int; + }; + + magicOrExtension = mkOption { + description = "The magic number or extension to match on."; + type = types.str; + }; + + mask = mkOption { + default = null; + description = "A mask to be ANDed with the byte sequence of the file before matching"; + type = types.nullOr types.str; + }; + + interpreter = mkOption { + description = '' + The interpreter to invoke to run the program. + + Note that the actual registration will point to + /run/binfmt/''${name}, so the kernel interpreter length + limit doesn't apply. + ''; + type = types.path; + }; + + preserveArgvZero = mkOption { + default = false; + description = '' + Whether to pass the original argv[0] to the interpreter. + + See the description of the 'P' flag in the kernel docs + for more details; + ''; + type = types.bool; + }; + + openBinary = mkOption { + default = config.matchCredentials; + description = '' + Whether to pass the binary to the interpreter as an open + file descriptor, instead of a path. + ''; + type = types.bool; + }; + + matchCredentials = mkOption { + default = false; + description = '' + Whether to launch with the credentials and security + token of the binary, not the interpreter (e.g. setuid + bit). + + See the description of the 'C' flag in the kernel docs + for more details. + + Implies/requires openBinary = true. + ''; + type = types.bool; + }; + + fixBinary = mkOption { + default = false; + description = '' + Whether to open the interpreter file as soon as the + registration is loaded, rather than waiting for a + relevant file to be invoked. + + See the description of the 'F' flag in the kernel docs + for more details. + ''; + type = types.bool; + }; + + wrapInterpreterInShell = mkOption { + default = true; + description = '' + Whether to wrap the interpreter in a shell script. + + This allows a shell command to be set as the interpreter. + ''; + type = types.bool; + }; + + interpreterSandboxPath = mkOption { + internal = true; + default = null; + description = '' + Path of the interpreter to expose in the build sandbox. + ''; + type = types.nullOr types.path; + }; + }; + } + ) + ); }; emulatedSystems = mkOption { - default = []; - example = [ "wasm32-wasi" "x86_64-windows" "aarch64-linux" ]; + default = [ ]; + example = [ + "wasm32-wasi" + "x86_64-windows" + "aarch64-linux" + ]; description = '' List of systems to emulate. Will also configure Nix to support your new systems. @@ -310,55 +348,73 @@ in { message = "boot.binfmt.registrations.\"${name}\" cannot have fixBinary when the interpreter is invoked through a shell."; }) cfg.registrations; - boot.binfmt.registrations = builtins.listToAttrs (map (system: assert system != pkgs.stdenv.hostPlatform.system; { - name = system; - value = { config, ... }: let - elaborated = lib.systems.elaborate { inherit system; }; - useStaticEmulator = cfg.preferStaticEmulators && elaborated.staticEmulatorAvailable pkgs; - interpreter = elaborated.emulator (if useStaticEmulator then pkgs.pkgsStatic else pkgs); - - inherit (elaborated) qemuArch; - isQemu = "qemu-${qemuArch}" == baseNameOf interpreter; - - interpreterReg = let - wrapperName = "qemu-${qemuArch}-binfmt-P"; - wrapper = pkgs.wrapQemuBinfmtP wrapperName interpreter; + boot.binfmt.registrations = builtins.listToAttrs ( + map ( + system: + assert system != pkgs.stdenv.hostPlatform.system; + { + name = system; + value = + { config, ... }: + let + elaborated = lib.systems.elaborate { inherit system; }; + useStaticEmulator = cfg.preferStaticEmulators && elaborated.staticEmulatorAvailable pkgs; + interpreter = elaborated.emulator (if useStaticEmulator then pkgs.pkgsStatic else pkgs); + + inherit (elaborated) qemuArch; + isQemu = "qemu-${qemuArch}" == baseNameOf interpreter; + + interpreterReg = + let + wrapperName = "qemu-${qemuArch}-binfmt-P"; + wrapper = pkgs.wrapQemuBinfmtP wrapperName interpreter; + in + if isQemu && !useStaticEmulator then "${wrapper}/bin/${wrapperName}" else interpreter; + in + ( + { + preserveArgvZero = mkDefault isQemu; + + interpreter = mkDefault interpreterReg; + fixBinary = mkDefault useStaticEmulator; + wrapInterpreterInShell = mkDefault (!config.preserveArgvZero && !config.fixBinary); + interpreterSandboxPath = mkDefault (dirOf (dirOf config.interpreter)); + } + // (magics.${system} or (throw "Cannot create binfmt registration for system ${system}")) + ); + } + ) cfg.emulatedSystems + ); + nix.settings = lib.mkIf (cfg.addEmulatedSystemsToNixSandbox && cfg.emulatedSystems != [ ]) { + extra-platforms = + cfg.emulatedSystems + ++ lib.optional pkgs.stdenv.hostPlatform.isx86_64 "i686-linux"; + extra-sandbox-paths = + let + ruleFor = system: cfg.registrations.${system}; + hasWrappedRule = lib.any (system: (ruleFor system).wrapInterpreterInShell) cfg.emulatedSystems; in - if isQemu && !useStaticEmulator then "${wrapper}/bin/${wrapperName}" - else interpreter; - in ({ - preserveArgvZero = mkDefault isQemu; - - interpreter = mkDefault interpreterReg; - fixBinary = mkDefault useStaticEmulator; - wrapInterpreterInShell = mkDefault (!config.preserveArgvZero && !config.fixBinary); - interpreterSandboxPath = mkDefault (dirOf (dirOf config.interpreter)); - } // (magics.${system} or (throw "Cannot create binfmt registration for system ${system}"))); - }) cfg.emulatedSystems); - nix.settings = lib.mkIf (cfg.addEmulatedSystemsToNixSandbox && cfg.emulatedSystems != []) { - extra-platforms = cfg.emulatedSystems ++ lib.optional pkgs.stdenv.hostPlatform.isx86_64 "i686-linux"; - extra-sandbox-paths = let - ruleFor = system: cfg.registrations.${system}; - hasWrappedRule = lib.any (system: (ruleFor system).wrapInterpreterInShell) cfg.emulatedSystems; - in [ "/run/binfmt" ] + [ "/run/binfmt" ] ++ lib.optional hasWrappedRule "${pkgs.bash}" ++ (map (system: (ruleFor system).interpreterSandboxPath) cfg.emulatedSystems); }; - environment.etc."binfmt.d/nixos.conf".source = builtins.toFile "binfmt_nixos.conf" - (lib.concatStringsSep "\n" (lib.mapAttrsToList makeBinfmtLine config.boot.binfmt.registrations)); + environment.etc."binfmt.d/nixos.conf".source = builtins.toFile "binfmt_nixos.conf" ( + lib.concatStringsSep "\n" (lib.mapAttrsToList makeBinfmtLine config.boot.binfmt.registrations) + ); systemd = lib.mkMerge [ - ({ tmpfiles.rules = [ - "d /run/binfmt 0755 -" - ] ++ lib.mapAttrsToList - (name: interpreter: - "L+ /run/binfmt/${name} - - - - ${interpreter}" - ) - (lib.mapAttrs mkInterpreter config.boot.binfmt.registrations); + ({ + tmpfiles.rules = + [ + "d /run/binfmt 0755 -" + ] + ++ lib.mapAttrsToList (name: interpreter: "L+ /run/binfmt/${name} - - - - ${interpreter}") ( + lib.mapAttrs mkInterpreter config.boot.binfmt.registrations + ); }) - (lib.mkIf (config.boot.binfmt.registrations != {}) { + (lib.mkIf (config.boot.binfmt.registrations != { }) { additionalUpstreamSystemUnits = [ "proc-sys-fs-binfmt_misc.automount" "proc-sys-fs-binfmt_misc.mount" diff --git a/nixos/modules/system/boot/clevis.nix b/nixos/modules/system/boot/clevis.nix index 36328f19e7c652..cd174d363547b1 100644 --- a/nixos/modules/system/boot/clevis.nix +++ b/nixos/modules/system/boot/clevis.nix @@ -1,17 +1,27 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.boot.initrd.clevis; systemd = config.boot.initrd.systemd; - supportedFs = [ "zfs" "bcachefs" ]; + supportedFs = [ + "zfs" + "bcachefs" + ]; in { - meta.maintainers = with lib.maintainers; [ julienmalka camillemndn ]; + meta.maintainers = with lib.maintainers; [ + julienmalka + camillemndn + ]; meta.doc = ./clevis.md; options = { boot.initrd.clevis.enable = lib.mkEnableOption "Clevis in initrd"; - boot.initrd.clevis.package = lib.mkOption { type = lib.types.package; default = pkgs.clevis; @@ -22,12 +32,14 @@ in boot.initrd.clevis.devices = lib.mkOption { description = "Encrypted devices that need to be unlocked at boot using Clevis"; default = { }; - type = lib.types.attrsOf (lib.types.submodule ({ - options.secretFile = lib.mkOption { - description = "Clevis JWE file used to decrypt the device at boot, in concert with the chosen pin (one of TPM2, Tang server, or SSS)."; - type = lib.types.path; - }; - })); + type = lib.types.attrsOf ( + lib.types.submodule ({ + options.secretFile = lib.mkOption { + description = "Clevis JWE file used to decrypt the device at boot, in concert with the chosen pin (one of TPM2, Tang server, or SSS)."; + type = lib.types.path; + }; + }) + ); }; boot.initrd.clevis.useTang = lib.mkOption { @@ -42,20 +54,28 @@ in # Implementation of clevis unlocking for the supported filesystems are located directly in the respective modules. - - assertions = (lib.attrValues (lib.mapAttrs - (device: _: { - assertion = (lib.any (fs: fs.device == device && (lib.elem fs.fsType supportedFs) || (fs.fsType == "zfs" && lib.hasPrefix "${device}/" fs.device)) config.system.build.fileSystems) || (lib.hasAttr device config.boot.initrd.luks.devices); - message = '' - No filesystem or LUKS device with the name ${device} is declared in your configuration.''; - }) - cfg.devices)); - + assertions = ( + lib.attrValues ( + lib.mapAttrs (device: _: { + assertion = + (lib.any ( + fs: + fs.device == device && (lib.elem fs.fsType supportedFs) + || (fs.fsType == "zfs" && lib.hasPrefix "${device}/" fs.device) + ) config.system.build.fileSystems) + || (lib.hasAttr device config.boot.initrd.luks.devices); + message = ''No filesystem or LUKS device with the name ${device} is declared in your configuration.''; + }) cfg.devices + ) + ); warnings = - if cfg.useTang && !config.boot.initrd.network.enable && !config.boot.initrd.systemd.network.enable - then [ "In order to use a Tang pinned secret you must configure networking in initrd" ] - else [ ]; + if + cfg.useTang && !config.boot.initrd.network.enable && !config.boot.initrd.systemd.network.enable + then + [ "In order to use a Tang pinned secret you must configure networking in initrd" ] + else + [ ]; boot.initrd = { extraUtilsCommands = lib.mkIf (!systemd.enable) '' @@ -81,7 +101,9 @@ in sed -i $out/bin/clevis-decrypt-tpm2 -e 's,tpm2_,tpm2 ,' ''; - secrets = lib.mapAttrs' (name: value: lib.nameValuePair "/etc/clevis/${name}.jwe" value.secretFile) cfg.devices; + secrets = lib.mapAttrs' ( + name: value: lib.nameValuePair "/etc/clevis/${name}.jwe" value.secretFile + ) cfg.devices; systemd = { extraBin = lib.mkIf systemd.enable { diff --git a/nixos/modules/system/boot/emergency-mode.nix b/nixos/modules/system/boot/emergency-mode.nix index 11195dc13d102a..34058bc17a6b95 100644 --- a/nixos/modules/system/boot/emergency-mode.nix +++ b/nixos/modules/system/boot/emergency-mode.nix @@ -24,10 +24,10 @@ config = { - systemd.additionalUpstreamSystemUnits = lib.optionals - config.systemd.enableEmergencyMode [ - "emergency.target" "emergency.service" - ]; + systemd.additionalUpstreamSystemUnits = lib.optionals config.systemd.enableEmergencyMode [ + "emergency.target" + "emergency.service" + ]; }; diff --git a/nixos/modules/system/boot/grow-partition.nix b/nixos/modules/system/boot/grow-partition.nix index 1910ff52eac8f7..f9db7ccd68bc77 100644 --- a/nixos/modules/system/boot/grow-partition.nix +++ b/nixos/modules/system/boot/grow-partition.nix @@ -2,7 +2,12 @@ # This allows an instance to be created with a bigger root filesystem # than provided by the machine image. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -25,7 +30,10 @@ with lib; systemd.services.growpart = { wantedBy = [ "-.mount" ]; after = [ "-.mount" ]; - before = [ "systemd-growfs-root.service" "shutdown.target" ]; + before = [ + "systemd-growfs-root.service" + "shutdown.target" + ]; conflicts = [ "shutdown.target" ]; unitConfig.DefaultDependencies = false; serviceConfig = { diff --git a/nixos/modules/system/boot/initrd-network.nix b/nixos/modules/system/boot/initrd-network.nix index 6f63f16271246c..17929761936726 100644 --- a/nixos/modules/system/boot/initrd-network.nix +++ b/nixos/modules/system/boot/initrd-network.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,38 +11,41 @@ let cfg = config.boot.initrd.network; - dhcpInterfaces = lib.attrNames (lib.filterAttrs (iface: v: v.useDHCP == true) (config.networking.interfaces or {})); - doDhcp = cfg.udhcpc.enable || dhcpInterfaces != []; - dhcpIfShellExpr = if config.networking.useDHCP || cfg.udhcpc.enable - then "$(ls /sys/class/net/ | grep -v ^lo$)" - else lib.concatMapStringsSep " " lib.escapeShellArg dhcpInterfaces; - - udhcpcScript = pkgs.writeScript "udhcp-script" - '' - #! /bin/sh - if [ "$1" = bound ]; then - ip address add "$ip/$mask" dev "$interface" - if [ -n "$mtu" ]; then - ip link set mtu "$mtu" dev "$interface" - fi - if [ -n "$staticroutes" ]; then - echo "$staticroutes" \ - | sed -r "s@(\S+) (\S+)@ ip route add \"\1\" via \"\2\" dev \"$interface\" ; @g" \ - | sed -r "s@ via \"0\.0\.0\.0\"@@g" \ - | /bin/sh - fi - if [ -n "$router" ]; then - ip route add "$router" dev "$interface" # just in case if "$router" is not within "$ip/$mask" (e.g. Hetzner Cloud) - ip route add default via "$router" dev "$interface" - fi - if [ -n "$dns" ]; then - rm -f /etc/resolv.conf - for server in $dns; do - echo "nameserver $server" >> /etc/resolv.conf - done - fi + dhcpInterfaces = lib.attrNames ( + lib.filterAttrs (iface: v: v.useDHCP == true) (config.networking.interfaces or { }) + ); + doDhcp = cfg.udhcpc.enable || dhcpInterfaces != [ ]; + dhcpIfShellExpr = + if config.networking.useDHCP || cfg.udhcpc.enable then + "$(ls /sys/class/net/ | grep -v ^lo$)" + else + lib.concatMapStringsSep " " lib.escapeShellArg dhcpInterfaces; + + udhcpcScript = pkgs.writeScript "udhcp-script" '' + #! /bin/sh + if [ "$1" = bound ]; then + ip address add "$ip/$mask" dev "$interface" + if [ -n "$mtu" ]; then + ip link set mtu "$mtu" dev "$interface" fi - ''; + if [ -n "$staticroutes" ]; then + echo "$staticroutes" \ + | sed -r "s@(\S+) (\S+)@ ip route add \"\1\" via \"\2\" dev \"$interface\" ; @g" \ + | sed -r "s@ via \"0\.0\.0\.0\"@@g" \ + | /bin/sh + fi + if [ -n "$router" ]; then + ip route add "$router" dev "$interface" # just in case if "$router" is not within "$ip/$mask" (e.g. Hetzner Cloud) + ip route add default via "$router" dev "$interface" + fi + if [ -n "$dns" ]; then + rm -f /etc/resolv.conf + for server in $dns; do + echo "nameserver $server" >> /etc/resolv.conf + done + fi + fi + ''; udhcpcArgs = toString cfg.udhcpc.extraArgs; @@ -91,7 +99,7 @@ in }; boot.initrd.network.udhcpc.extraArgs = mkOption { - default = []; + default = [ ]; type = types.listOf types.str; description = '' Additional command-line arguments passed verbatim to @@ -109,7 +117,6 @@ in ''; }; - }; config = mkIf cfg.enable { @@ -120,42 +127,47 @@ in copy_bin_and_libs ${pkgs.klibc}/lib/klibc/bin.static/ipconfig ''; - boot.initrd.preLVMCommands = mkIf (!config.boot.initrd.systemd.enable) (mkBefore ( - # Search for interface definitions in command line. - '' - ifaces="" - for o in $(cat /proc/cmdline); do - case $o in - ip=*) - ipconfig $o && ifaces="$ifaces $(echo $o | cut -d: -f6)" - ;; - esac - done - '' - - # Otherwise, use DHCP. - + optionalString doDhcp '' - # Bring up all interfaces. - for iface in ${dhcpIfShellExpr}; do - echo "bringing up network interface $iface..." - ip link set dev "$iface" up && ifaces="$ifaces $iface" - done - - # Acquire DHCP leases. - for iface in ${dhcpIfShellExpr}; do - echo "acquiring IP address via DHCP on $iface..." - udhcpc --quit --now -i $iface -O staticroutes --script ${udhcpcScript} ${udhcpcArgs} - done - '' - - + cfg.postCommands)); + boot.initrd.preLVMCommands = mkIf (!config.boot.initrd.systemd.enable) ( + mkBefore ( + # Search for interface definitions in command line. + '' + ifaces="" + for o in $(cat /proc/cmdline); do + case $o in + ip=*) + ipconfig $o && ifaces="$ifaces $(echo $o | cut -d: -f6)" + ;; + esac + done + '' + + # Otherwise, use DHCP. + + optionalString doDhcp '' + # Bring up all interfaces. + for iface in ${dhcpIfShellExpr}; do + echo "bringing up network interface $iface..." + ip link set dev "$iface" up && ifaces="$ifaces $iface" + done - boot.initrd.postMountCommands = mkIf (cfg.flushBeforeStage2 && !config.boot.initrd.systemd.enable) '' - for iface in $ifaces; do - ip address flush dev "$iface" - ip link set dev "$iface" down - done - ''; + # Acquire DHCP leases. + for iface in ${dhcpIfShellExpr}; do + echo "acquiring IP address via DHCP on $iface..." + udhcpc --quit --now -i $iface -O staticroutes --script ${udhcpcScript} ${udhcpcArgs} + done + '' + + + cfg.postCommands + ) + ); + + boot.initrd.postMountCommands = + mkIf (cfg.flushBeforeStage2 && !config.boot.initrd.systemd.enable) + '' + for iface in $ifaces; do + ip address flush dev "$iface" + ip link set dev "$iface" down + done + ''; }; diff --git a/nixos/modules/system/boot/initrd-openvpn.nix b/nixos/modules/system/boot/initrd-openvpn.nix index 602d80fa338a22..450cff92440c4d 100644 --- a/nixos/modules/system/boot/initrd-openvpn.nix +++ b/nixos/modules/system/boot/initrd-openvpn.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -47,7 +52,10 @@ in ]; # Add kernel modules needed for OpenVPN - boot.initrd.kernelModules = [ "tun" "tap" ]; + boot.initrd.kernelModules = [ + "tun" + "tap" + ]; # Add openvpn and ip binaries to the initrd # The shared libraries are required for DNS resolution @@ -82,7 +90,10 @@ in boot.initrd.systemd.services.openvpn = { wantedBy = [ "initrd.target" ]; path = [ pkgs.iproute2 ]; - after = [ "network.target" "initrd-nixos-copy-secrets.service" ]; + after = [ + "network.target" + "initrd-nixos-copy-secrets.service" + ]; serviceConfig.ExecStart = "${pkgs.openvpn}/bin/openvpn /etc/initrd.ovpn"; serviceConfig.Type = "notify"; }; diff --git a/nixos/modules/system/boot/initrd-ssh.nix b/nixos/modules/system/boot/initrd-ssh.nix index 650ce593e945b6..474f89e1ccf3aa 100644 --- a/nixos/modules/system/boot/initrd-ssh.nix +++ b/nixos/modules/system/boot/initrd-ssh.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -8,7 +13,11 @@ let shell = if cfg.shell == null then "/bin/ash" else cfg.shell; inherit (config.programs.ssh) package; - enabled = let initrd = config.boot.initrd; in (initrd.network.enable || initrd.systemd.network.enable) && cfg.enable; + enabled = + let + initrd = config.boot.initrd; + in + (initrd.network.enable || initrd.systemd.network.enable) && cfg.enable; in @@ -47,7 +56,7 @@ in hostKeys = mkOption { type = types.listOf (types.either types.str types.path); - default = []; + default = [ ]; example = [ "/etc/secrets/initrd/ssh_host_rsa_key" "/etc/secrets/initrd/ssh_host_ed25519_key" @@ -119,185 +128,235 @@ in }; imports = - map (opt: mkRemovedOptionModule ([ "boot" "initrd" "network" "ssh" ] ++ [ opt ]) '' - The initrd SSH functionality now uses OpenSSH rather than Dropbear. - - If you want to keep your existing initrd SSH host keys, convert them with - $ dropbearconvert dropbear openssh dropbear_host_$type_key ssh_host_$type_key - and then set options.boot.initrd.network.ssh.hostKeys. - '') [ "hostRSAKey" "hostDSSKey" "hostECDSAKey" ]; - - config = let - # Nix complains if you include a store hash in initrd path names, so - # as an awful hack we drop the first character of the hash. - initrdKeyPath = path: if isString path - then path - else let name = builtins.baseNameOf path; in - builtins.unsafeDiscardStringContext ("/etc/ssh/" + - substring 1 (stringLength name) name); - - sshdCfg = config.services.openssh; - - sshdConfig = '' - UsePAM no - Port ${toString cfg.port} - - PasswordAuthentication no - AuthorizedKeysFile %h/.ssh/authorized_keys %h/.ssh/authorized_keys2 /etc/ssh/authorized_keys.d/%u - ChallengeResponseAuthentication no - - ${flip concatMapStrings cfg.hostKeys (path: '' - HostKey ${initrdKeyPath path} - '')} - - '' + lib.optionalString (sshdCfg.settings.KexAlgorithms != null) '' - KexAlgorithms ${concatStringsSep "," sshdCfg.settings.KexAlgorithms} - '' + lib.optionalString (sshdCfg.settings.Ciphers != null) '' - Ciphers ${concatStringsSep "," sshdCfg.settings.Ciphers} - '' + lib.optionalString (sshdCfg.settings.Macs != null) '' - MACs ${concatStringsSep "," sshdCfg.settings.Macs} - '' + '' - - LogLevel ${sshdCfg.settings.LogLevel} - - ${if sshdCfg.settings.UseDns then '' - UseDNS yes - '' else '' - UseDNS no - ''} - - ${optionalString (!config.boot.initrd.systemd.enable) '' - SshdSessionPath /bin/sshd-session - ''} - - ${cfg.extraConfig} - ''; - in mkIf enabled { - assertions = [ - { - assertion = cfg.authorizedKeys != [] || cfg.authorizedKeyFiles != []; - message = "You should specify at least one authorized key for initrd SSH"; - } - - { - assertion = (cfg.hostKeys != []) || cfg.ignoreEmptyHostKeys; - message = '' - You must now pre-generate the host keys for initrd SSH. - See the boot.initrd.network.ssh.hostKeys documentation - for instructions. + map + ( + opt: + mkRemovedOptionModule + ( + [ + "boot" + "initrd" + "network" + "ssh" + ] + ++ [ opt ] + ) + '' + The initrd SSH functionality now uses OpenSSH rather than Dropbear. + + If you want to keep your existing initrd SSH host keys, convert them with + $ dropbearconvert dropbear openssh dropbear_host_$type_key ssh_host_$type_key + and then set options.boot.initrd.network.ssh.hostKeys. + '' + ) + [ + "hostRSAKey" + "hostDSSKey" + "hostECDSAKey" + ]; + + config = + let + # Nix complains if you include a store hash in initrd path names, so + # as an awful hack we drop the first character of the hash. + initrdKeyPath = + path: + if isString path then + path + else + let + name = builtins.baseNameOf path; + in + builtins.unsafeDiscardStringContext ("/etc/ssh/" + substring 1 (stringLength name) name); + + sshdCfg = config.services.openssh; + + sshdConfig = + '' + UsePAM no + Port ${toString cfg.port} + + PasswordAuthentication no + AuthorizedKeysFile %h/.ssh/authorized_keys %h/.ssh/authorized_keys2 /etc/ssh/authorized_keys.d/%u + ChallengeResponseAuthentication no + + ${flip concatMapStrings cfg.hostKeys (path: '' + HostKey ${initrdKeyPath path} + '')} + + '' + + lib.optionalString (sshdCfg.settings.KexAlgorithms != null) '' + KexAlgorithms ${concatStringsSep "," sshdCfg.settings.KexAlgorithms} + '' + + lib.optionalString (sshdCfg.settings.Ciphers != null) '' + Ciphers ${concatStringsSep "," sshdCfg.settings.Ciphers} + '' + + lib.optionalString (sshdCfg.settings.Macs != null) '' + MACs ${concatStringsSep "," sshdCfg.settings.Macs} + '' + + '' + + LogLevel ${sshdCfg.settings.LogLevel} + + ${ + if sshdCfg.settings.UseDns then + '' + UseDNS yes + '' + else + '' + UseDNS no + '' + } + + ${optionalString (!config.boot.initrd.systemd.enable) '' + SshdSessionPath /bin/sshd-session + ''} + + ${cfg.extraConfig} ''; - } - ]; - - warnings = lib.optional (config.boot.initrd.systemd.enable && cfg.shell != null) '' - Please set 'boot.initrd.systemd.users.root.shell' instead of 'boot.initrd.network.ssh.shell' - ''; - - boot.initrd.extraUtilsCommands = mkIf (!config.boot.initrd.systemd.enable) '' - copy_bin_and_libs ${package}/bin/sshd - copy_bin_and_libs ${package}/libexec/sshd-session - cp -pv ${pkgs.glibc.out}/lib/libnss_files.so.* $out/lib - ''; - - boot.initrd.extraUtilsCommandsTest = mkIf (!config.boot.initrd.systemd.enable) '' - # sshd requires a host key to check config, so we pass in the test's - tmpkey="$(mktemp initrd-ssh-testkey.XXXXXXXXXX)" - cp "${../../../tests/initrd-network-ssh/ssh_host_ed25519_key}" "$tmpkey" - # keys from Nix store are world-readable, which sshd doesn't like - chmod 600 "$tmpkey" - echo -n ${escapeShellArg sshdConfig} | - $out/bin/sshd -t -f /dev/stdin \ - -h "$tmpkey" - rm "$tmpkey" - ''; - - boot.initrd.network.postCommands = mkIf (!config.boot.initrd.systemd.enable) '' - echo '${shell}' > /etc/shells - echo 'root:x:0:0:root:/root:${shell}' > /etc/passwd - echo 'sshd:x:1:1:sshd:/var/empty:/bin/nologin' >> /etc/passwd - echo 'passwd: files' > /etc/nsswitch.conf - - mkdir -p /var/log /var/empty - touch /var/log/lastlog - - mkdir -p /etc/ssh - echo -n ${escapeShellArg sshdConfig} > /etc/ssh/sshd_config - - echo "export PATH=$PATH" >> /etc/profile - echo "export LD_LIBRARY_PATH=$LD_LIBRARY_PATH" >> /etc/profile - - mkdir -p /root/.ssh - ${concatStrings (map (key: '' - echo ${escapeShellArg key} >> /root/.ssh/authorized_keys - '') cfg.authorizedKeys)} - ${concatStrings (map (keyFile: '' - cat ${keyFile} >> /root/.ssh/authorized_keys - '') cfg.authorizedKeyFiles)} - - ${flip concatMapStrings cfg.hostKeys (path: '' - # keys from Nix store are world-readable, which sshd doesn't like - chmod 0600 "${initrdKeyPath path}" - '')} - - /bin/sshd -e - ''; - - boot.initrd.postMountCommands = mkIf (!config.boot.initrd.systemd.enable) '' - # Stop sshd cleanly before stage 2. - # - # If you want to keep it around to debug post-mount SSH issues, - # run `touch /.keep_sshd` (either from an SSH session or in - # another initrd hook like preDeviceCommands). - if ! [ -e /.keep_sshd ]; then - pkill -x sshd - fi - ''; - - boot.initrd.secrets = listToAttrs - (map (path: nameValuePair (initrdKeyPath path) path) cfg.hostKeys); - - # Systemd initrd stuff - boot.initrd.systemd = mkIf config.boot.initrd.systemd.enable { - users.sshd = { uid = 1; group = "sshd"; }; - groups.sshd = { gid = 1; }; - - users.root.shell = mkIf (config.boot.initrd.network.ssh.shell != null) config.boot.initrd.network.ssh.shell; - - contents = { - "/etc/ssh/sshd_config".text = sshdConfig; - "/etc/ssh/authorized_keys.d/root".text = - concatStringsSep "\n" ( - config.boot.initrd.network.ssh.authorizedKeys ++ - (map (file: lib.fileContents file) config.boot.initrd.network.ssh.authorizedKeyFiles)); - }; - storePaths = [ - "${package}/bin/sshd" - "${package}/libexec/sshd-session" + in + mkIf enabled { + assertions = [ + { + assertion = cfg.authorizedKeys != [ ] || cfg.authorizedKeyFiles != [ ]; + message = "You should specify at least one authorized key for initrd SSH"; + } + + { + assertion = (cfg.hostKeys != [ ]) || cfg.ignoreEmptyHostKeys; + message = '' + You must now pre-generate the host keys for initrd SSH. + See the boot.initrd.network.ssh.hostKeys documentation + for instructions. + ''; + } ]; - services.sshd = { - description = "SSH Daemon"; - wantedBy = [ "initrd.target" ]; - after = [ "network.target" "initrd-nixos-copy-secrets.service" ]; - before = [ "shutdown.target" ]; - conflicts = [ "shutdown.target" ]; - - # Keys from Nix store are world-readable, which sshd doesn't - # like. If this were a real nix store and not the initrd, we - # neither would nor could do this - preStart = flip concatMapStrings cfg.hostKeys (path: '' - /bin/chmod 0600 "${initrdKeyPath path}" - ''); - unitConfig.DefaultDependencies = false; - serviceConfig = { - ExecStart = "${package}/bin/sshd -D -f /etc/ssh/sshd_config"; - Type = "simple"; - KillMode = "process"; - Restart = "on-failure"; + warnings = lib.optional (config.boot.initrd.systemd.enable && cfg.shell != null) '' + Please set 'boot.initrd.systemd.users.root.shell' instead of 'boot.initrd.network.ssh.shell' + ''; + + boot.initrd.extraUtilsCommands = mkIf (!config.boot.initrd.systemd.enable) '' + copy_bin_and_libs ${package}/bin/sshd + copy_bin_and_libs ${package}/libexec/sshd-session + cp -pv ${pkgs.glibc.out}/lib/libnss_files.so.* $out/lib + ''; + + boot.initrd.extraUtilsCommandsTest = mkIf (!config.boot.initrd.systemd.enable) '' + # sshd requires a host key to check config, so we pass in the test's + tmpkey="$(mktemp initrd-ssh-testkey.XXXXXXXXXX)" + cp "${../../../tests/initrd-network-ssh/ssh_host_ed25519_key}" "$tmpkey" + # keys from Nix store are world-readable, which sshd doesn't like + chmod 600 "$tmpkey" + echo -n ${escapeShellArg sshdConfig} | + $out/bin/sshd -t -f /dev/stdin \ + -h "$tmpkey" + rm "$tmpkey" + ''; + + boot.initrd.network.postCommands = mkIf (!config.boot.initrd.systemd.enable) '' + echo '${shell}' > /etc/shells + echo 'root:x:0:0:root:/root:${shell}' > /etc/passwd + echo 'sshd:x:1:1:sshd:/var/empty:/bin/nologin' >> /etc/passwd + echo 'passwd: files' > /etc/nsswitch.conf + + mkdir -p /var/log /var/empty + touch /var/log/lastlog + + mkdir -p /etc/ssh + echo -n ${escapeShellArg sshdConfig} > /etc/ssh/sshd_config + + echo "export PATH=$PATH" >> /etc/profile + echo "export LD_LIBRARY_PATH=$LD_LIBRARY_PATH" >> /etc/profile + + mkdir -p /root/.ssh + ${concatStrings ( + map (key: '' + echo ${escapeShellArg key} >> /root/.ssh/authorized_keys + '') cfg.authorizedKeys + )} + ${concatStrings ( + map (keyFile: '' + cat ${keyFile} >> /root/.ssh/authorized_keys + '') cfg.authorizedKeyFiles + )} + + ${flip concatMapStrings cfg.hostKeys (path: '' + # keys from Nix store are world-readable, which sshd doesn't like + chmod 0600 "${initrdKeyPath path}" + '')} + + /bin/sshd -e + ''; + + boot.initrd.postMountCommands = mkIf (!config.boot.initrd.systemd.enable) '' + # Stop sshd cleanly before stage 2. + # + # If you want to keep it around to debug post-mount SSH issues, + # run `touch /.keep_sshd` (either from an SSH session or in + # another initrd hook like preDeviceCommands). + if ! [ -e /.keep_sshd ]; then + pkill -x sshd + fi + ''; + + boot.initrd.secrets = listToAttrs ( + map (path: nameValuePair (initrdKeyPath path) path) cfg.hostKeys + ); + + # Systemd initrd stuff + boot.initrd.systemd = mkIf config.boot.initrd.systemd.enable { + users.sshd = { + uid = 1; + group = "sshd"; + }; + groups.sshd = { + gid = 1; + }; + + users.root.shell = mkIf ( + config.boot.initrd.network.ssh.shell != null + ) config.boot.initrd.network.ssh.shell; + + contents = { + "/etc/ssh/sshd_config".text = sshdConfig; + "/etc/ssh/authorized_keys.d/root".text = concatStringsSep "\n" ( + config.boot.initrd.network.ssh.authorizedKeys + ++ (map (file: lib.fileContents file) config.boot.initrd.network.ssh.authorizedKeyFiles) + ); + }; + storePaths = [ + "${package}/bin/sshd" + "${package}/libexec/sshd-session" + ]; + + services.sshd = { + description = "SSH Daemon"; + wantedBy = [ "initrd.target" ]; + after = [ + "network.target" + "initrd-nixos-copy-secrets.service" + ]; + before = [ "shutdown.target" ]; + conflicts = [ "shutdown.target" ]; + + # Keys from Nix store are world-readable, which sshd doesn't + # like. If this were a real nix store and not the initrd, we + # neither would nor could do this + preStart = flip concatMapStrings cfg.hostKeys (path: '' + /bin/chmod 0600 "${initrdKeyPath path}" + ''); + unitConfig.DefaultDependencies = false; + serviceConfig = { + ExecStart = "${package}/bin/sshd -D -f /etc/ssh/sshd_config"; + Type = "simple"; + KillMode = "process"; + Restart = "on-failure"; + }; }; }; - }; - }; + }; } diff --git a/nixos/modules/system/boot/kernel_config.nix b/nixos/modules/system/boot/kernel_config.nix index a98ee2deda699d..8ca9c96006a486 100644 --- a/nixos/modules/system/boot/kernel_config.nix +++ b/nixos/modules/system/boot/kernel_config.nix @@ -2,15 +2,24 @@ with lib; let - mergeFalseByDefault = locs: defs: - if defs == [] then abort "This case should never happen." - else if any (x: x == false) (getValues defs) then false - else true; + mergeFalseByDefault = + locs: defs: + if defs == [ ] then + abort "This case should never happen." + else if any (x: x == false) (getValues defs) then + false + else + true; kernelItem = types.submodule { options = { tristate = mkOption { - type = types.enum [ "y" "m" "n" null ]; + type = types.enum [ + "y" + "m" + "n" + null + ]; default = null; internal = true; visible = true; @@ -31,7 +40,9 @@ let }; optional = mkOption { - type = types.bool // { merge = mergeFalseByDefault; }; + type = types.bool // { + merge = mergeFalseByDefault; + }; default = false; description = '' Whether option should generate a failure when unused. @@ -41,17 +52,36 @@ let }; }; - mkValue = with lib; val: - let - isNumber = c: elem c ["0" "1" "2" "3" "4" "5" "6" "7" "8" "9"]; - - in - if (val == "") then "\"\"" - else if val == "y" || val == "m" || val == "n" then val - else if all isNumber (stringToCharacters val) then val - else if substring 0 2 val == "0x" then val - else val; # FIXME: fix quoting one day + mkValue = + with lib; + val: + let + isNumber = + c: + elem c [ + "0" + "1" + "2" + "3" + "4" + "5" + "6" + "7" + "8" + "9" + ]; + in + if (val == "") then + "\"\"" + else if val == "y" || val == "m" || val == "n" then + val + else if all isNumber (stringToCharacters val) then + val + else if substring 0 2 val == "0x" then + val + else + val; # FIXME: fix quoting one day # generate nix intermediate kernel config file of the form # @@ -64,19 +94,21 @@ let # returns a string, expr should be an attribute set # Use mkValuePreprocess to preprocess option values, aka mark 'modules' as 'yes' or vice-versa # use the identity if you don't want to override the configured values - generateNixKConf = exprs: - let - mkConfigLine = key: item: - let - val = if item.freeform != null then item.freeform else item.tristate; - in - optionalString (val != null) - (if (item.optional) - then "${key}? ${mkValue val}\n" - else "${key} ${mkValue val}\n"); + generateNixKConf = + exprs: + let + mkConfigLine = + key: item: + let + val = if item.freeform != null then item.freeform else item.tristate; + in + optionalString (val != null) ( + if (item.optional) then "${key}? ${mkValue val}\n" else "${key} ${mkValue val}\n" + ); - mkConf = cfg: concatStrings (mapAttrsToList mkConfigLine cfg); - in mkConf exprs; + mkConf = cfg: concatStrings (mapAttrsToList mkConfigLine cfg); + in + mkConf exprs; in { @@ -99,11 +131,12 @@ in settings = mkOption { type = types.attrsOf kernelItem; - example = literalExpression '' with lib.kernel; { - "9P_NET" = yes; - USB = option yes; - MMC_BLOCK_MINORS = freeform "32"; - }''; + example = literalExpression '' + with lib.kernel; { + "9P_NET" = yes; + USB = option yes; + MMC_BLOCK_MINORS = freeform "32"; + }''; description = '' Structured kernel configuration. ''; diff --git a/nixos/modules/system/boot/loader/external/external.nix b/nixos/modules/system/boot/loader/external/external.nix index 7f976f755f2e43..f159aa498f8793 100644 --- a/nixos/modules/system/boot/loader/external/external.nix +++ b/nixos/modules/system/boot/loader/external/external.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -7,7 +12,11 @@ let in { meta = { - maintainers = with maintainers; [ cole-h grahamc raitobezarius ]; + maintainers = with maintainers; [ + cole-h + grahamc + raitobezarius + ]; doc = ./external.md; }; diff --git a/nixos/modules/system/boot/loader/grub/ipxe.nix b/nixos/modules/system/boot/loader/grub/ipxe.nix index 8d9ab9966c545c..a988e15a20dbb1 100644 --- a/nixos/modules/system/boot/loader/grub/ipxe.nix +++ b/nixos/modules/system/boot/loader/grub/ipxe.nix @@ -1,58 +1,65 @@ # This module adds a scripted iPXE entry to the GRUB boot menu. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let scripts = builtins.attrNames config.boot.loader.grub.ipxe; - grubEntry = name: - '' - menuentry "iPXE - ${name}" { - linux16 @bootRoot@/ipxe.lkrn - initrd16 @bootRoot@/${name}.ipxe - } + grubEntry = name: '' + menuentry "iPXE - ${name}" { + linux16 @bootRoot@/ipxe.lkrn + initrd16 @bootRoot@/${name}.ipxe + } - ''; + ''; - scriptFile = name: + scriptFile = + name: let value = builtins.getAttr name config.boot.loader.grub.ipxe; in - if builtins.typeOf value == "path" then value - else builtins.toFile "${name}.ipxe" value; + if builtins.typeOf value == "path" then value else builtins.toFile "${name}.ipxe" value; in { - options = - { boot.loader.grub.ipxe = mkOption { - type = types.attrsOf (types.either types.path types.str); - description = '' - Set of iPXE scripts available for - booting from the GRUB boot menu. - ''; - default = { }; - example = literalExpression '' - { demo = ''' - #!ipxe - dhcp - chain http://boot.ipxe.org/demo/boot.php - '''; - } - ''; - }; + options = { + boot.loader.grub.ipxe = mkOption { + type = types.attrsOf (types.either types.path types.str); + description = '' + Set of iPXE scripts available for + booting from the GRUB boot menu. + ''; + default = { }; + example = literalExpression '' + { demo = ''' + #!ipxe + dhcp + chain http://boot.ipxe.org/demo/boot.php + '''; + } + ''; }; + }; config = mkIf (builtins.length scripts != 0) { boot.loader.grub.extraEntries = toString (map grubEntry scripts); boot.loader.grub.extraFiles = - { "ipxe.lkrn" = "${pkgs.ipxe}/ipxe.lkrn"; } - // - builtins.listToAttrs ( map - (name: { name = name+".ipxe"; value = scriptFile name; }) - scripts + { + "ipxe.lkrn" = "${pkgs.ipxe}/ipxe.lkrn"; + } + // builtins.listToAttrs ( + map (name: { + name = name + ".ipxe"; + value = scriptFile name; + }) scripts ); }; diff --git a/nixos/modules/system/boot/loader/grub/memtest.nix b/nixos/modules/system/boot/loader/grub/memtest.nix index 939d36666d217c..b762a7b6ce463d 100644 --- a/nixos/modules/system/boot/loader/grub/memtest.nix +++ b/nixos/modules/system/boot/loader/grub/memtest.nix @@ -1,5 +1,10 @@ # This module adds Memtest86+ to the GRUB boot menu. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -23,7 +28,7 @@ in }; params = mkOption { - default = []; + default = [ ]; example = [ "console=ttyS0,115200" ]; type = types.listOf types.str; description = '' diff --git a/nixos/modules/system/boot/loader/init-script/init-script.nix b/nixos/modules/system/boot/loader/init-script/init-script.nix index 0f2a37bdd09fe3..5c4974f32ae07a 100644 --- a/nixos/modules/system/boot/loader/init-script/init-script.nix +++ b/nixos/modules/system/boot/loader/init-script/init-script.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -9,7 +14,11 @@ let isExecutable = true; inherit (pkgs) bash; inherit (config.system.nixos) distroName; - path = [pkgs.coreutils pkgs.gnused pkgs.gnugrep]; + path = [ + pkgs.coreutils + pkgs.gnused + pkgs.gnugrep + ]; }; in @@ -40,7 +49,6 @@ in }; - ###### implementation config = mkIf config.boot.loader.initScript.enable { diff --git a/nixos/modules/system/boot/loader/loader.nix b/nixos/modules/system/boot/loader/loader.nix index 01475f79b9c25d..bc876ff8f804e3 100644 --- a/nixos/modules/system/boot/loader/loader.nix +++ b/nixos/modules/system/boot/loader/loader.nix @@ -8,13 +8,13 @@ with lib; (mkRenamedOptionModule [ "boot" "loader" "gummiboot" "timeout" ] [ "boot" "loader" "timeout" ]) ]; - options = { - boot.loader.timeout = mkOption { - default = 5; - type = types.nullOr types.int; - description = '' - Timeout (in seconds) until loader boots the default menu item. Use null if the loader menu should be displayed indefinitely. - ''; - }; + options = { + boot.loader.timeout = mkOption { + default = 5; + type = types.nullOr types.int; + description = '' + Timeout (in seconds) until loader boots the default menu item. Use null if the loader menu should be displayed indefinitely. + ''; }; + }; } diff --git a/nixos/modules/system/boot/modprobe.nix b/nixos/modules/system/boot/modprobe.nix index 0b7d253c07c797..df0d5d6679884a 100644 --- a/nixos/modules/system/boot/modprobe.nix +++ b/nixos/modules/system/boot/modprobe.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -7,18 +12,25 @@ with lib; ###### interface options = { - boot.modprobeConfig.enable = mkEnableOption "modprobe config. This is useful for systems like containers which do not require a kernel" // { - default = true; - }; - - boot.modprobeConfig.useUbuntuModuleBlacklist = mkEnableOption "Ubuntu distro's module blacklist" // { - default = true; - }; + boot.modprobeConfig.enable = + mkEnableOption "modprobe config. This is useful for systems like containers which do not require a kernel" + // { + default = true; + }; + + boot.modprobeConfig.useUbuntuModuleBlacklist = + mkEnableOption "Ubuntu distro's module blacklist" + // { + default = true; + }; boot.blacklistedKernelModules = mkOption { type = types.listOf types.str; - default = []; - example = [ "cirrusfb" "i2c_piix4" ]; + default = [ ]; + example = [ + "cirrusfb" + "i2c_piix4" + ]; description = '' List of names of kernel modules that should not be loaded automatically by the hardware probing code. @@ -27,10 +39,9 @@ with lib; boot.extraModprobeConfig = mkOption { default = ""; - example = - '' - options parport_pc io=0x378 irq=7 dma=1 - ''; + example = '' + options parport_pc io=0x378 irq=7 dma=1 + ''; description = '' Any additional configuration to be appended to the generated {file}`modprobe.conf`. This is typically used to @@ -42,36 +53,36 @@ with lib; }; - ###### implementation config = mkIf config.boot.modprobeConfig.enable { - environment.etc."modprobe.d/ubuntu.conf" = mkIf config.boot.modprobeConfig.useUbuntuModuleBlacklist { - source = "${pkgs.kmod-blacklist-ubuntu}/modprobe.conf"; - }; - - environment.etc."modprobe.d/nixos.conf".text = - '' - ${flip concatMapStrings config.boot.blacklistedKernelModules (name: '' - blacklist ${name} - '')} - ${config.boot.extraModprobeConfig} - ''; + environment.etc."modprobe.d/ubuntu.conf" = + mkIf config.boot.modprobeConfig.useUbuntuModuleBlacklist + { + source = "${pkgs.kmod-blacklist-ubuntu}/modprobe.conf"; + }; + + environment.etc."modprobe.d/nixos.conf".text = '' + ${flip concatMapStrings config.boot.blacklistedKernelModules (name: '' + blacklist ${name} + '')} + ${config.boot.extraModprobeConfig} + ''; environment.etc."modprobe.d/debian.conf".source = pkgs.kmod-debian-aliases; - environment.etc."modprobe.d/systemd.conf".source = "${config.systemd.package}/lib/modprobe.d/systemd.conf"; + environment.etc."modprobe.d/systemd.conf".source = + "${config.systemd.package}/lib/modprobe.d/systemd.conf"; environment.systemPackages = [ pkgs.kmod ]; - system.activationScripts.modprobe = stringAfter ["specialfs"] - '' - # Allow the kernel to find our wrapped modprobe (which searches - # in the right location in the Nix store for kernel modules). - # We need this when the kernel (or some module) auto-loads a - # module. - echo ${pkgs.kmod}/bin/modprobe > /proc/sys/kernel/modprobe - ''; + system.activationScripts.modprobe = stringAfter [ "specialfs" ] '' + # Allow the kernel to find our wrapped modprobe (which searches + # in the right location in the Nix store for kernel modules). + # We need this when the kernel (or some module) auto-loads a + # module. + echo ${pkgs.kmod}/bin/modprobe > /proc/sys/kernel/modprobe + ''; }; diff --git a/nixos/modules/system/boot/resolved.nix b/nixos/modules/system/boot/resolved.nix index 65c00b694e0ff0..987480521d1c8b 100644 --- a/nixos/modules/system/boot/resolved.nix +++ b/nixos/modules/system/boot/resolved.nix @@ -1,20 +1,23 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.resolved; - dnsmasqResolve = config.services.dnsmasq.enable && - config.services.dnsmasq.resolveLocalQueries; + dnsmasqResolve = config.services.dnsmasq.enable && config.services.dnsmasq.resolveLocalQueries; resolvedConf = '' [Resolve] - ${optionalString (config.networking.nameservers != []) - "DNS=${concatStringsSep " " config.networking.nameservers}"} - ${optionalString (cfg.fallbackDns != null) - "FallbackDNS=${concatStringsSep " " cfg.fallbackDns}"} - ${optionalString (cfg.domains != []) - "Domains=${concatStringsSep " " cfg.domains}"} + ${optionalString ( + config.networking.nameservers != [ ] + ) "DNS=${concatStringsSep " " config.networking.nameservers}"} + ${optionalString (cfg.fallbackDns != null) "FallbackDNS=${concatStringsSep " " cfg.fallbackDns}"} + ${optionalString (cfg.domains != [ ]) "Domains=${concatStringsSep " " cfg.domains}"} LLMNR=${cfg.llmnr} DNSSEC=${cfg.dnssec} DNSOverTLS=${cfg.dnsovertls} @@ -38,7 +41,10 @@ in services.resolved.fallbackDns = mkOption { default = null; - example = [ "8.8.8.8" "2001:4860:4860::8844" ]; + example = [ + "8.8.8.8" + "2001:4860:4860::8844" + ]; type = types.nullOr (types.listOf types.str); description = '' A list of IPv4 and IPv6 addresses to use as the fallback DNS servers. @@ -68,7 +74,11 @@ in services.resolved.llmnr = mkOption { default = "true"; example = "false"; - type = types.enum [ "true" "resolve" "false" ]; + type = types.enum [ + "true" + "resolve" + "false" + ]; description = '' Controls Link-Local Multicast Name Resolution support (RFC 4795) on the local host. @@ -83,7 +93,11 @@ in services.resolved.dnssec = mkOption { default = "false"; example = "true"; - type = types.enum [ "true" "allow-downgrade" "false" ]; + type = types.enum [ + "true" + "allow-downgrade" + "false" + ]; description = '' If set to - `"true"`: @@ -112,7 +126,11 @@ in services.resolved.dnsovertls = mkOption { default = "false"; example = "true"; - type = types.enum [ "true" "opportunistic" "false" ]; + type = types.enum [ + "true" + "opportunistic" + "false" + ]; description = '' If set to - `"true"`: @@ -155,7 +173,8 @@ in (mkIf cfg.enable { assertions = [ - { assertion = !config.networking.useHostResolvConf; + { + assertion = !config.networking.useHostResolvConf; message = "Using host resolv.conf is not supported with systemd-resolved"; } ]; @@ -165,7 +184,7 @@ in # add resolve to nss hosts database if enabled and nscd enabled # system.nssModules is configured in nixos/modules/system/boot/systemd.nix # added with order 501 to allow modules to go before with mkBefore - system.nssDatabases.hosts = (mkOrder 501 ["resolve [!UNAVAIL=return]"]); + system.nssDatabases.hosts = (mkOrder 501 [ "resolve [!UNAVAIL=return]" ]); systemd.additionalUpstreamSystemUnits = [ "systemd-resolved.service" @@ -177,15 +196,17 @@ in restartTriggers = [ config.environment.etc."systemd/resolved.conf".source ]; }; - environment.etc = { - "systemd/resolved.conf".text = resolvedConf; + environment.etc = + { + "systemd/resolved.conf".text = resolvedConf; - # symlink the dynamic stub resolver of resolv.conf as recommended by upstream: - # https://www.freedesktop.org/software/systemd/man/systemd-resolved.html#/etc/resolv.conf - "resolv.conf".source = "/run/systemd/resolve/stub-resolv.conf"; - } // optionalAttrs dnsmasqResolve { - "dnsmasq-resolv.conf".source = "/run/systemd/resolve/resolv.conf"; - }; + # symlink the dynamic stub resolver of resolv.conf as recommended by upstream: + # https://www.freedesktop.org/software/systemd/man/systemd-resolved.html#/etc/resolv.conf + "resolv.conf".source = "/run/systemd/resolve/stub-resolv.conf"; + } + // optionalAttrs dnsmasqResolve { + "dnsmasq-resolv.conf".source = "/run/systemd/resolve/resolv.conf"; + }; # If networkmanager is enabled, ask it to interface with resolved. networking.networkmanager.dns = "systemd-resolved"; @@ -211,12 +232,12 @@ in tmpfiles.settings.systemd-resolved-stub."/etc/resolv.conf".L.argument = "/run/systemd/resolve/stub-resolv.conf"; - additionalUpstreamUnits = ["systemd-resolved.service"]; - users.systemd-resolve = {}; - groups.systemd-resolve = {}; - storePaths = ["${config.boot.initrd.systemd.package}/lib/systemd/systemd-resolved"]; + additionalUpstreamUnits = [ "systemd-resolved.service" ]; + users.systemd-resolve = { }; + groups.systemd-resolve = { }; + storePaths = [ "${config.boot.initrd.systemd.package}/lib/systemd/systemd-resolved" ]; services.systemd-resolved = { - wantedBy = ["sysinit.target"]; + wantedBy = [ "sysinit.target" ]; aliases = [ "dbus-org.freedesktop.resolve1.service" ]; }; }; diff --git a/nixos/modules/system/boot/shutdown.nix b/nixos/modules/system/boot/shutdown.nix index 3f25dca0cbf96b..9121b695f5cd20 100644 --- a/nixos/modules/system/boot/shutdown.nix +++ b/nixos/modules/system/boot/shutdown.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,22 +11,24 @@ with lib; # This unit saves the value of the system clock to the hardware # clock on shutdown. - systemd.services.save-hwclock = - { description = "Save Hardware Clock"; + systemd.services.save-hwclock = { + description = "Save Hardware Clock"; - wantedBy = [ "shutdown.target" ]; + wantedBy = [ "shutdown.target" ]; - unitConfig = { - DefaultDependencies = false; - ConditionPathExists = "/dev/rtc"; - ConditionPathIsReadWrite = "/etc/"; - }; + unitConfig = { + DefaultDependencies = false; + ConditionPathExists = "/dev/rtc"; + ConditionPathIsReadWrite = "/etc/"; + }; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${pkgs.util-linux}/sbin/hwclock --systohc ${if config.time.hardwareClockInLocalTime then "--localtime" else "--utc"}"; - }; + serviceConfig = { + Type = "oneshot"; + ExecStart = "${pkgs.util-linux}/sbin/hwclock --systohc ${ + if config.time.hardwareClockInLocalTime then "--localtime" else "--utc" + }"; }; + }; boot.kernel.sysctl."kernel.poweroff_cmd" = "${config.systemd.package}/sbin/poweroff"; diff --git a/nixos/modules/system/boot/stage-2.nix b/nixos/modules/system/boot/stage-2.nix index 71ee9144990cba..beb887d0f3e5c6 100644 --- a/nixos/modules/system/boot/stage-2.nix +++ b/nixos/modules/system/boot/stage-2.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -15,15 +20,17 @@ let isExecutable = true; inherit useHostResolvConf; inherit (config.system.build) earlyMountScript; - path = lib.makeBinPath ([ - pkgs.coreutils - pkgs.util-linux - ] ++ lib.optional useHostResolvConf pkgs.openresolv); - postBootCommands = pkgs.writeText "local-cmds" - '' - ${config.boot.postBootCommands} - ${config.powerManagement.powerUpCommands} - ''; + path = lib.makeBinPath ( + [ + pkgs.coreutils + pkgs.util-linux + ] + ++ lib.optional useHostResolvConf pkgs.openresolv + ); + postBootCommands = pkgs.writeText "local-cmds" '' + ${config.boot.postBootCommands} + ${config.powerManagement.powerUpCommands} + ''; }; in @@ -62,7 +69,7 @@ in }; extraSystemdUnitPaths = mkOption { - default = []; + default = [ ]; type = types.listOf types.str; description = '' Additional paths that get appended to the SYSTEMD_UNIT_PATH environment variable @@ -73,7 +80,6 @@ in }; - config = { system.build.bootStage2 = bootStage2; diff --git a/nixos/modules/system/boot/stratisroot.nix b/nixos/modules/system/boot/stratisroot.nix index 241d044db2fe0f..68c387f2d3cc18 100644 --- a/nixos/modules/system/boot/stratisroot.nix +++ b/nixos/modules/system/boot/stratisroot.nix @@ -1,10 +1,18 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let - requiredStratisFilesystems = lib.attrsets.filterAttrs (_: x: utils.fsNeededForBoot x && x.stratis.poolUuid != null) config.fileSystems; + requiredStratisFilesystems = lib.attrsets.filterAttrs ( + _: x: utils.fsNeededForBoot x && x.stratis.poolUuid != null + ) config.fileSystems; in { - options = {}; - config = lib.mkIf (requiredStratisFilesystems != {}) { + options = { }; + config = lib.mkIf (requiredStratisFilesystems != { }) { assertions = [ { assertion = config.boot.initrd.systemd.enable; @@ -20,41 +28,68 @@ in "${pkgs.stratisd}/libexec/stratisd-min" "${pkgs.stratisd.initrd}/bin/stratis-rootfs-setup" ]; - packages = [pkgs.stratisd.initrd]; + packages = [ pkgs.stratisd.initrd ]; extraBin = { thin_check = "${pkgs."thin-provisioning-tools"}/bin/thin_check"; thin_repair = "${pkgs."thin-provisioning-tools"}/bin/thin_repair"; thin_metadata_size = "${pkgs."thin-provisioning-tools"}/bin/thin_metadata_size"; stratis-min = "${pkgs.stratisd}/bin/stratis-min"; }; - services = - lib.attrsets.mapAttrs' ( - mountPoint: fileSystem: { - name = "stratis-setup-${fileSystem.stratis.poolUuid}"; - value = { - description = "setup for Stratis root filesystem"; - unitConfig.DefaultDependencies = "no"; - conflicts = [ "shutdown.target" "initrd-switch-root.target" ]; - onFailure = [ "emergency.target" ]; - unitConfig.OnFailureJobMode = "isolate"; - wants = [ "stratisd-min.service" "plymouth-start.service" ]; - wantedBy = [ "initrd.target" ]; - after = [ "paths.target" "plymouth-start.service" "stratisd-min.service" ]; - before = [ "initrd.target" "shutdown.target" "initrd-switch-root.target" ]; - environment.STRATIS_ROOTFS_UUID = fileSystem.stratis.poolUuid; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${pkgs.stratisd.initrd}/bin/stratis-rootfs-setup"; - RemainAfterExit = "yes"; - }; - }; - } - ) requiredStratisFilesystems; + services = lib.attrsets.mapAttrs' (mountPoint: fileSystem: { + name = "stratis-setup-${fileSystem.stratis.poolUuid}"; + value = { + description = "setup for Stratis root filesystem"; + unitConfig.DefaultDependencies = "no"; + conflicts = [ + "shutdown.target" + "initrd-switch-root.target" + ]; + onFailure = [ "emergency.target" ]; + unitConfig.OnFailureJobMode = "isolate"; + wants = [ + "stratisd-min.service" + "plymouth-start.service" + ]; + wantedBy = [ "initrd.target" ]; + after = [ + "paths.target" + "plymouth-start.service" + "stratisd-min.service" + ]; + before = [ + "initrd.target" + "shutdown.target" + "initrd-switch-root.target" + ]; + environment.STRATIS_ROOTFS_UUID = fileSystem.stratis.poolUuid; + serviceConfig = { + Type = "oneshot"; + ExecStart = "${pkgs.stratisd.initrd}/bin/stratis-rootfs-setup"; + RemainAfterExit = "yes"; + }; + }; + }) requiredStratisFilesystems; }; - availableKernelModules = [ "dm-thin-pool" "dm-crypt" ] ++ [ "aes" "aes_generic" "blowfish" "twofish" - "serpent" "cbc" "xts" "lrw" "sha1" "sha256" "sha512" - "af_alg" "algif_skcipher" - ]; + availableKernelModules = + [ + "dm-thin-pool" + "dm-crypt" + ] + ++ [ + "aes" + "aes_generic" + "blowfish" + "twofish" + "serpent" + "cbc" + "xts" + "lrw" + "sha1" + "sha256" + "sha512" + "af_alg" + "algif_skcipher" + ]; services.udev.packages = [ pkgs.stratisd.initrd pkgs.lvm2 diff --git a/nixos/modules/system/boot/systemd/coredump.nix b/nixos/modules/system/boot/systemd/coredump.nix index ccf5d449b94a34..672ad62f4926ea 100644 --- a/nixos/modules/system/boot/systemd/coredump.nix +++ b/nixos/modules/system/boot/systemd/coredump.nix @@ -1,11 +1,18 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: with lib; let cfg = config.systemd.coredump; systemd = config.systemd.package; -in { +in +{ options = { systemd.coredump.enable = mkOption { default = true; @@ -37,8 +44,7 @@ in { ]; environment.etc = { - "systemd/coredump.conf".text = - '' + "systemd/coredump.conf".text = '' [Coredump] ${cfg.extraConfig} ''; @@ -55,7 +61,10 @@ in { substitutions = [ "--replace-fail" "${systemd}" - "${pkgs.symlinkJoin { name = "systemd"; paths = [ systemd ]; }}" + "${pkgs.symlinkJoin { + name = "systemd"; + paths = [ systemd ]; + }}" ]; }; @@ -66,11 +75,11 @@ in { uid = config.ids.uids.systemd-coredump; group = "systemd-coredump"; }; - users.groups.systemd-coredump = {}; + users.groups.systemd-coredump = { }; }) (mkIf (!cfg.enable) { - boot.kernel.sysctl."kernel.core_pattern" = mkDefault "core"; + boot.kernel.sysctl."kernel.core_pattern" = mkDefault "core"; }) ]; diff --git a/nixos/modules/system/boot/systemd/homed.nix b/nixos/modules/system/boot/systemd/homed.nix index 1fd8846616c9be..1e7ae236af6bd4 100644 --- a/nixos/modules/system/boot/systemd/homed.nix +++ b/nixos/modules/system/boot/systemd/homed.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.homed; diff --git a/nixos/modules/system/boot/systemd/initrd-secrets.nix b/nixos/modules/system/boot/systemd/initrd-secrets.nix index d375238aa146e2..50bc45babe1563 100644 --- a/nixos/modules/system/boot/systemd/initrd-secrets.nix +++ b/nixos/modules/system/boot/systemd/initrd-secrets.nix @@ -1,36 +1,50 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { config = lib.mkIf (config.boot.initrd.enable && config.boot.initrd.systemd.enable) { # Copy secrets into the initrd if they cannot be appended - boot.initrd.systemd.contents = lib.mkIf (!config.boot.loader.supportsInitrdSecrets) - (lib.mapAttrs' (dest: source: lib.nameValuePair "/.initrd-secrets/${dest}" { source = if source == null then dest else source; }) config.boot.initrd.secrets); + boot.initrd.systemd.contents = lib.mkIf (!config.boot.loader.supportsInitrdSecrets) ( + lib.mapAttrs' ( + dest: source: + lib.nameValuePair "/.initrd-secrets/${dest}" { source = if source == null then dest else source; } + ) config.boot.initrd.secrets + ); # Copy secrets to their respective locations - boot.initrd.systemd.services.initrd-nixos-copy-secrets = lib.mkIf (config.boot.initrd.secrets != {}) { - description = "Copy secrets into place"; - # Run as early as possible - wantedBy = [ "sysinit.target" ]; - before = [ "cryptsetup-pre.target" "shutdown.target" ]; - conflicts = [ "shutdown.target" ]; - unitConfig.DefaultDependencies = false; + boot.initrd.systemd.services.initrd-nixos-copy-secrets = + lib.mkIf (config.boot.initrd.secrets != { }) + { + description = "Copy secrets into place"; + # Run as early as possible + wantedBy = [ "sysinit.target" ]; + before = [ + "cryptsetup-pre.target" + "shutdown.target" + ]; + conflicts = [ "shutdown.target" ]; + unitConfig.DefaultDependencies = false; - # We write the secrets to /.initrd-secrets and move them because this allows - # secrets to be written to /run. If we put the secret directly to /run and - # drop this service, we'd mount the /run tmpfs over the secret, making it - # invisible in stage 2. - script = '' - for secret in $(cd /.initrd-secrets; find . -type f -o -type l); do - mkdir -p "$(dirname "/$secret")" - cp "/.initrd-secrets/$secret" "/$secret" - done - ''; + # We write the secrets to /.initrd-secrets and move them because this allows + # secrets to be written to /run. If we put the secret directly to /run and + # drop this service, we'd mount the /run tmpfs over the secret, making it + # invisible in stage 2. + script = '' + for secret in $(cd /.initrd-secrets; find . -type f -o -type l); do + mkdir -p "$(dirname "/$secret")" + cp "/.initrd-secrets/$secret" "/$secret" + done + ''; - serviceConfig = { - Type = "oneshot"; - RemainAfterExit = true; - }; - }; + serviceConfig = { + Type = "oneshot"; + RemainAfterExit = true; + }; + }; # The script needs this boot.initrd.systemd.extraBin.find = "${pkgs.findutils}/bin/find"; }; diff --git a/nixos/modules/system/boot/systemd/initrd.nix b/nixos/modules/system/boot/systemd/initrd.nix index 572c6558ac9626..4a38e7ed1db6ad 100644 --- a/nixos/modules/system/boot/systemd/initrd.nix +++ b/nixos/modules/system/boot/systemd/initrd.nix @@ -1,4 +1,11 @@ -{ lib, options, config, utils, pkgs, ... }: +{ + lib, + options, + config, + utils, + pkgs, + ... +}: with lib; @@ -13,8 +20,8 @@ let targetToUnit timerToUnit mountToUnit - automountToUnit; - + automountToUnit + ; cfg = config.boot.initrd.systemd; @@ -77,9 +84,11 @@ let "sysinit.target.wants" ]; - enabledUpstreamUnits = filter (n: ! elem n cfg.suppressedUnits) upstreamUnits; - enabledUnits = filterAttrs (n: v: ! elem n cfg.suppressedUnits) cfg.units; - jobScripts = concatLists (mapAttrsToList (_: unit: unit.jobScripts or []) (filterAttrs (_: v: v.enable) cfg.services)); + enabledUpstreamUnits = filter (n: !elem n cfg.suppressedUnits) upstreamUnits; + enabledUnits = filterAttrs (n: v: !elem n cfg.suppressedUnits) cfg.units; + jobScripts = concatLists ( + mapAttrsToList (_: unit: unit.jobScripts or [ ]) (filterAttrs (_: v: v.enable) cfg.services) + ); stage1Units = generateUnits { type = "initrd"; @@ -101,16 +110,21 @@ let initrdBinEnv = pkgs.buildEnv { name = "initrd-bin-env"; paths = map getBin cfg.initrdBin; - pathsToLink = ["/bin" "/sbin"]; + pathsToLink = [ + "/bin" + "/sbin" + ]; # Make sure sbin and bin have the same contents, and add extraBin postBuild = '' find $out/bin -maxdepth 1 -type l -print0 | xargs --null cp --no-dereference --no-clobber -t $out/sbin/ find $out/sbin -maxdepth 1 -type l -print0 | xargs --null cp --no-dereference --no-clobber -t $out/bin/ - ${concatStringsSep "\n" (mapAttrsToList (n: v: '' - ln -sf '${v}' $out/bin/'${n}' - ln -sf '${v}' $out/sbin/'${n}' - '') cfg.extraBin)} + ${concatStringsSep "\n" ( + mapAttrsToList (n: v: '' + ln -sf '${v}' $out/bin/'${n}' + ln -sf '${v}' $out/sbin/'${n}' + '') cfg.extraBin + )} ''; }; @@ -122,7 +136,8 @@ let contents = lib.filter ({ source, ... }: !lib.elem source cfg.suppressedStorePaths) cfg.storePaths; }; -in { +in +{ options.boot.initrd.systemd = { enable = mkEnableOption "systemd in initrd" // { description = '' @@ -154,9 +169,19 @@ in { }; managerEnvironment = mkOption { - type = with types; attrsOf (nullOr (oneOf [ str path package ])); - default = {}; - example = { SYSTEMD_LOG_LEVEL = "debug"; }; + type = + with types; + attrsOf ( + nullOr (oneOf [ + str + path + package + ]) + ); + default = { }; + example = { + SYSTEMD_LOG_LEVEL = "debug"; + }; description = '' Environment variables of PID 1. These variables are *not* passed to started units. @@ -170,7 +195,7 @@ in { "/etc/machine-id".source = /etc/machine-id; } ''; - default = {}; + default = { }; type = utils.systemdUtils.types.initrdContents; }; @@ -179,7 +204,7 @@ in { Store paths to copy into the initrd as well. ''; type = utils.systemdUtils.types.initrdStorePath; - default = []; + default = [ ]; }; strip = mkOption { @@ -205,7 +230,7 @@ in { } ''; type = types.attrsOf types.path; - default = {}; + default = { }; }; suppressedStorePaths = mkOption { @@ -214,11 +239,14 @@ in { should not be copied. ''; type = types.listOf types.singleLineStr; - default = []; + default = [ ]; }; root = lib.mkOption { - type = lib.types.enum [ "fstab" "gpt-auto" ]; + type = lib.types.enum [ + "fstab" + "gpt-auto" + ]; default = "fstab"; example = "gpt-auto"; description = '' @@ -231,7 +259,12 @@ in { }; emergencyAccess = mkOption { - type = with types; oneOf [ bool (nullOr (passwdEntry str)) ]; + type = + with types; + oneOf [ + bool + (nullOr (passwdEntry str)) + ]; description = '' Set to true for unauthenticated emergency access, and false or null for no emergency access. @@ -244,7 +277,7 @@ in { initrdBin = mkOption { type = types.listOf types.package; - default = []; + default = [ ]; description = '' Packages to include in /bin for the stage 1 emergency shell. ''; @@ -253,7 +286,10 @@ in { additionalUpstreamUnits = mkOption { default = [ ]; type = types.listOf types.str; - example = [ "debug-shell.service" "systemd-quotacheck.service" ]; + example = [ + "debug-shell.service" + "systemd-quotacheck.service" + ]; description = '' Additional units shipped with systemd that shall be enabled. ''; @@ -274,55 +310,55 @@ in { units = mkOption { description = "Definition of systemd units."; - default = {}; + default = { }; visible = "shallow"; type = systemdUtils.types.units; }; packages = mkOption { - default = []; + default = [ ]; type = types.listOf types.package; example = literalExpression "[ pkgs.systemd-cryptsetup-generator ]"; description = "Packages providing systemd units and hooks."; }; targets = mkOption { - default = {}; + default = { }; visible = "shallow"; type = systemdUtils.types.initrdTargets; description = "Definition of systemd target units."; }; services = mkOption { - default = {}; + default = { }; type = systemdUtils.types.initrdServices; visible = "shallow"; description = "Definition of systemd service units."; }; sockets = mkOption { - default = {}; + default = { }; type = systemdUtils.types.initrdSockets; visible = "shallow"; description = "Definition of systemd socket units."; }; timers = mkOption { - default = {}; + default = { }; type = systemdUtils.types.initrdTimers; visible = "shallow"; description = "Definition of systemd timer units."; }; paths = mkOption { - default = {}; + default = { }; type = systemdUtils.types.initrdPaths; visible = "shallow"; description = "Definition of systemd path units."; }; mounts = mkOption { - default = []; + default = [ ]; type = systemdUtils.types.initrdMounts; visible = "shallow"; description = '' @@ -333,7 +369,7 @@ in { }; automounts = mkOption { - default = []; + default = [ ]; type = systemdUtils.types.automounts; visible = "shallow"; description = '' @@ -344,7 +380,7 @@ in { }; slices = mkOption { - default = {}; + default = { }; type = systemdUtils.types.slices; visible = "shallow"; description = "Definition of slice configurations."; @@ -352,32 +388,42 @@ in { }; config = mkIf (config.boot.initrd.enable && cfg.enable) { - assertions = [ - { - assertion = cfg.root == "fstab" -> any (fs: fs.mountPoint == "/") (builtins.attrValues config.fileSystems); - message = "The ‘fileSystems’ option does not specify your root file system."; - } - ] ++ map (name: { - assertion = lib.attrByPath name (throw "impossible") config.boot.initrd == ""; - message = '' - systemd stage 1 does not support 'boot.initrd.${lib.concatStringsSep "." name}'. Please - convert it to analogous systemd units in 'boot.initrd.systemd'. - - Definitions: - ${lib.concatMapStringsSep "\n" ({ file, ... }: " - ${file}") (lib.attrByPath name (throw "impossible") options.boot.initrd).definitionsWithLocations} - ''; - }) [ - [ "preFailCommands" ] - [ "preDeviceCommands" ] - [ "preLVMCommands" ] - [ "postDeviceCommands" ] - [ "postResumeCommands" ] - [ "postMountCommands" ] - [ "extraUdevRulesCommands" ] - [ "extraUtilsCommands" ] - [ "extraUtilsCommandsTest" ] - [ "network" "postCommands" ] - ]; + assertions = + [ + { + assertion = + cfg.root == "fstab" -> any (fs: fs.mountPoint == "/") (builtins.attrValues config.fileSystems); + message = "The ‘fileSystems’ option does not specify your root file system."; + } + ] + ++ map + (name: { + assertion = lib.attrByPath name (throw "impossible") config.boot.initrd == ""; + message = '' + systemd stage 1 does not support 'boot.initrd.${lib.concatStringsSep "." name}'. Please + convert it to analogous systemd units in 'boot.initrd.systemd'. + + Definitions: + ${lib.concatMapStringsSep "\n" ({ file, ... }: " - ${file}") + (lib.attrByPath name (throw "impossible") options.boot.initrd).definitionsWithLocations + } + ''; + }) + [ + [ "preFailCommands" ] + [ "preDeviceCommands" ] + [ "preLVMCommands" ] + [ "postDeviceCommands" ] + [ "postResumeCommands" ] + [ "postMountCommands" ] + [ "extraUdevRulesCommands" ] + [ "extraUtilsCommands" ] + [ "extraUtilsCommandsTest" ] + [ + "network" + "postCommands" + ] + ]; system.build = { inherit initialRamdisk; }; @@ -387,16 +433,23 @@ in { # systemd-cryptenroll ] ++ lib.optional cfg.package.withEfi "efivarfs"; - boot.kernelParams = [ - "root=${config.boot.initrd.systemd.root}" - ] ++ lib.optional (config.boot.resumeDevice != "") "resume=${config.boot.resumeDevice}" + boot.kernelParams = + [ + "root=${config.boot.initrd.systemd.root}" + ] + ++ lib.optional (config.boot.resumeDevice != "") "resume=${config.boot.resumeDevice}" # `systemd` mounts root in initrd as read-only unless "rw" is on the kernel command line. # For NixOS activation to succeed, we need to have root writable in initrd. ++ lib.optional (config.boot.initrd.systemd.root == "gpt-auto") "rw"; boot.initrd.systemd = { # bashInteractive is easier to use and also required by debug-shell.service - initrdBin = [pkgs.bashInteractive pkgs.coreutils cfg.package.kmod cfg.package]; + initrdBin = [ + pkgs.bashInteractive + pkgs.coreutils + cfg.package.kmod + cfg.package + ]; extraBin = { less = "${pkgs.less}/bin/less"; mount = "${cfg.package.util-linux}/bin/mount"; @@ -406,107 +459,128 @@ in { managerEnvironment.PATH = "/bin:/sbin"; - contents = { - "/tmp/.keep".text = "systemd requires the /tmp mount point in the initrd cpio archive"; - "/init".source = "${cfg.package}/lib/systemd/systemd"; - "/etc/systemd/system".source = stage1Units; - - "/etc/systemd/system.conf".text = '' - [Manager] - DefaultEnvironment=PATH=/bin:/sbin - ${cfg.extraConfig} - ManagerEnvironment=${lib.concatStringsSep " " (lib.mapAttrsToList (n: v: "${n}=${lib.escapeShellArg v}") cfg.managerEnvironment)} - ''; - - "/lib".source = "${modulesClosure}/lib"; - - "/etc/modules-load.d/nixos.conf".text = concatStringsSep "\n" config.boot.initrd.kernelModules; - - # We can use either ! or * to lock the root account in the - # console, but some software like OpenSSH won't even allow you - # to log in with an SSH key if you use ! so we use * instead - "/etc/shadow".text = let - ea = cfg.emergencyAccess; - access = ea != null && !(isBool ea && !ea); - passwd = if isString ea then ea else ""; - in - "root:${if access then passwd else "*"}:::::::"; - - "/bin".source = "${initrdBinEnv}/bin"; - "/sbin".source = "${initrdBinEnv}/sbin"; - - "/etc/sysctl.d/nixos.conf".text = "kernel.modprobe = /sbin/modprobe"; - "/etc/modprobe.d/systemd.conf".source = "${cfg.package}/lib/modprobe.d/systemd.conf"; - "/etc/modprobe.d/ubuntu.conf".source = "${pkgs.kmod-blacklist-ubuntu}/modprobe.conf"; - "/etc/modprobe.d/debian.conf".source = pkgs.kmod-debian-aliases; - - "/etc/os-release".source = config.boot.initrd.osRelease; - "/etc/initrd-release".source = config.boot.initrd.osRelease; - - # For systemd-journald's _HOSTNAME field; needs to be set early, cannot be backfilled. - "/etc/hostname".text = config.networking.hostName; + contents = + { + "/tmp/.keep".text = "systemd requires the /tmp mount point in the initrd cpio archive"; + "/init".source = "${cfg.package}/lib/systemd/systemd"; + "/etc/systemd/system".source = stage1Units; + + "/etc/systemd/system.conf".text = '' + [Manager] + DefaultEnvironment=PATH=/bin:/sbin + ${cfg.extraConfig} + ManagerEnvironment=${ + lib.concatStringsSep " " ( + lib.mapAttrsToList (n: v: "${n}=${lib.escapeShellArg v}") cfg.managerEnvironment + ) + } + ''; + + "/lib".source = "${modulesClosure}/lib"; + + "/etc/modules-load.d/nixos.conf".text = concatStringsSep "\n" config.boot.initrd.kernelModules; + + # We can use either ! or * to lock the root account in the + # console, but some software like OpenSSH won't even allow you + # to log in with an SSH key if you use ! so we use * instead + "/etc/shadow".text = + let + ea = cfg.emergencyAccess; + access = ea != null && !(isBool ea && !ea); + passwd = if isString ea then ea else ""; + in + "root:${if access then passwd else "*"}:::::::"; + + "/bin".source = "${initrdBinEnv}/bin"; + "/sbin".source = "${initrdBinEnv}/sbin"; + + "/etc/sysctl.d/nixos.conf".text = "kernel.modprobe = /sbin/modprobe"; + "/etc/modprobe.d/systemd.conf".source = "${cfg.package}/lib/modprobe.d/systemd.conf"; + "/etc/modprobe.d/ubuntu.conf".source = "${pkgs.kmod-blacklist-ubuntu}/modprobe.conf"; + "/etc/modprobe.d/debian.conf".source = pkgs.kmod-debian-aliases; + + "/etc/os-release".source = config.boot.initrd.osRelease; + "/etc/initrd-release".source = config.boot.initrd.osRelease; + + # For systemd-journald's _HOSTNAME field; needs to be set early, cannot be backfilled. + "/etc/hostname".text = config.networking.hostName; - } // optionalAttrs (config.environment.etc ? "modprobe.d/nixos.conf") { - "/etc/modprobe.d/nixos.conf".source = config.environment.etc."modprobe.d/nixos.conf".source; - }; + } + // optionalAttrs (config.environment.etc ? "modprobe.d/nixos.conf") { + "/etc/modprobe.d/nixos.conf".source = config.environment.etc."modprobe.d/nixos.conf".source; + }; - storePaths = [ - # systemd tooling - "${cfg.package}/lib/systemd/systemd-executor" - "${cfg.package}/lib/systemd/systemd-fsck" - "${cfg.package}/lib/systemd/systemd-hibernate-resume" - "${cfg.package}/lib/systemd/systemd-journald" - "${cfg.package}/lib/systemd/systemd-makefs" - "${cfg.package}/lib/systemd/systemd-modules-load" - "${cfg.package}/lib/systemd/systemd-remount-fs" - "${cfg.package}/lib/systemd/systemd-shutdown" - "${cfg.package}/lib/systemd/systemd-sulogin-shell" - "${cfg.package}/lib/systemd/systemd-sysctl" - "${cfg.package}/lib/systemd/systemd-bsod" - "${cfg.package}/lib/systemd/systemd-sysroot-fstab-check" - - # generators - "${cfg.package}/lib/systemd/system-generators/systemd-debug-generator" - "${cfg.package}/lib/systemd/system-generators/systemd-fstab-generator" - "${cfg.package}/lib/systemd/system-generators/systemd-gpt-auto-generator" - "${cfg.package}/lib/systemd/system-generators/systemd-hibernate-resume-generator" - "${cfg.package}/lib/systemd/system-generators/systemd-run-generator" - - # utilities needed by systemd - "${cfg.package.util-linux}/bin/mount" - "${cfg.package.util-linux}/bin/umount" - "${cfg.package.util-linux}/bin/sulogin" - - # required for script services, and some tools like xfs still want the sh symlink - "${pkgs.bash}/bin" - - # so NSS can look up usernames - "${pkgs.glibc}/lib/libnss_files.so.2" - - # Resolving sysroot symlinks without code exec - "${pkgs.chroot-realpath}/bin/chroot-realpath" - ] ++ optionals cfg.package.withCryptsetup [ - # fido2 support - "${cfg.package}/lib/cryptsetup/libcryptsetup-token-systemd-fido2.so" - "${pkgs.libfido2}/lib/libfido2.so.1" - ] ++ jobScripts - ++ map (c: builtins.removeAttrs c ["text"]) (builtins.attrValues cfg.contents); - - targets.initrd.aliases = ["default.target"]; + storePaths = + [ + # systemd tooling + "${cfg.package}/lib/systemd/systemd-executor" + "${cfg.package}/lib/systemd/systemd-fsck" + "${cfg.package}/lib/systemd/systemd-hibernate-resume" + "${cfg.package}/lib/systemd/systemd-journald" + "${cfg.package}/lib/systemd/systemd-makefs" + "${cfg.package}/lib/systemd/systemd-modules-load" + "${cfg.package}/lib/systemd/systemd-remount-fs" + "${cfg.package}/lib/systemd/systemd-shutdown" + "${cfg.package}/lib/systemd/systemd-sulogin-shell" + "${cfg.package}/lib/systemd/systemd-sysctl" + "${cfg.package}/lib/systemd/systemd-bsod" + "${cfg.package}/lib/systemd/systemd-sysroot-fstab-check" + + # generators + "${cfg.package}/lib/systemd/system-generators/systemd-debug-generator" + "${cfg.package}/lib/systemd/system-generators/systemd-fstab-generator" + "${cfg.package}/lib/systemd/system-generators/systemd-gpt-auto-generator" + "${cfg.package}/lib/systemd/system-generators/systemd-hibernate-resume-generator" + "${cfg.package}/lib/systemd/system-generators/systemd-run-generator" + + # utilities needed by systemd + "${cfg.package.util-linux}/bin/mount" + "${cfg.package.util-linux}/bin/umount" + "${cfg.package.util-linux}/bin/sulogin" + + # required for script services, and some tools like xfs still want the sh symlink + "${pkgs.bash}/bin" + + # so NSS can look up usernames + "${pkgs.glibc}/lib/libnss_files.so.2" + + # Resolving sysroot symlinks without code exec + "${pkgs.chroot-realpath}/bin/chroot-realpath" + ] + ++ optionals cfg.package.withCryptsetup [ + # fido2 support + "${cfg.package}/lib/cryptsetup/libcryptsetup-token-systemd-fido2.so" + "${pkgs.libfido2}/lib/libfido2.so.1" + ] + ++ jobScripts + ++ map (c: builtins.removeAttrs c [ "text" ]) (builtins.attrValues cfg.contents); + + targets.initrd.aliases = [ "default.target" ]; units = - mapAttrs' (n: v: nameValuePair "${n}.path" (pathToUnit v)) cfg.paths + mapAttrs' (n: v: nameValuePair "${n}.path" (pathToUnit v)) cfg.paths // mapAttrs' (n: v: nameValuePair "${n}.service" (serviceToUnit v)) cfg.services - // mapAttrs' (n: v: nameValuePair "${n}.slice" (sliceToUnit v)) cfg.slices - // mapAttrs' (n: v: nameValuePair "${n}.socket" (socketToUnit v)) cfg.sockets - // mapAttrs' (n: v: nameValuePair "${n}.target" (targetToUnit v)) cfg.targets - // mapAttrs' (n: v: nameValuePair "${n}.timer" (timerToUnit v)) cfg.timers - // listToAttrs (map - (v: let n = escapeSystemdPath v.where; - in nameValuePair "${n}.mount" (mountToUnit v)) cfg.mounts) - // listToAttrs (map - (v: let n = escapeSystemdPath v.where; - in nameValuePair "${n}.automount" (automountToUnit v)) cfg.automounts); - + // mapAttrs' (n: v: nameValuePair "${n}.slice" (sliceToUnit v)) cfg.slices + // mapAttrs' (n: v: nameValuePair "${n}.socket" (socketToUnit v)) cfg.sockets + // mapAttrs' (n: v: nameValuePair "${n}.target" (targetToUnit v)) cfg.targets + // mapAttrs' (n: v: nameValuePair "${n}.timer" (timerToUnit v)) cfg.timers + // listToAttrs ( + map ( + v: + let + n = escapeSystemdPath v.where; + in + nameValuePair "${n}.mount" (mountToUnit v) + ) cfg.mounts + ) + // listToAttrs ( + map ( + v: + let + n = escapeSystemdPath v.where; + in + nameValuePair "${n}.automount" (automountToUnit v) + ) cfg.automounts + ); services.initrd-find-nixos-closure = { description = "Find NixOS closure"; @@ -515,7 +589,10 @@ in { RequiresMountsFor = "/sysroot/nix/store"; DefaultDependencies = false; }; - before = [ "initrd.target" "shutdown.target" ]; + before = [ + "initrd.target" + "shutdown.target" + ]; conflicts = [ "shutdown.target" ]; requiredBy = [ "initrd.target" ]; serviceConfig = { @@ -523,45 +600,46 @@ in { RemainAfterExit = true; }; - script = /* bash */ '' - set -uo pipefail - export PATH="/bin:${cfg.package.util-linux}/bin:${pkgs.chroot-realpath}/bin" - - # Figure out what closure to boot - closure= - for o in $(< /proc/cmdline); do - case $o in - init=*) - IFS="=" read -r -a initParam <<< "$o" - closure="''${initParam[1]}" - ;; - esac - done - - # Sanity check - if [ -z "''${closure:-}" ]; then - echo 'No init= parameter on the kernel command line' >&2 - exit 1 - fi - - # Resolve symlinks in the init parameter. We need this for some boot loaders - # (e.g. boot.loader.generationsDir). - closure="$(chroot-realpath /sysroot "$closure")" - - # Assume the directory containing the init script is the closure. - closure="$(dirname "$closure")" - - ln --symbolic "$closure" /nixos-closure - - # If we are not booting a NixOS closure (e.g. init=/bin/sh), - # we don't know what root to prepare so we don't do anything - if ! [ -x "/sysroot$(readlink "/sysroot$closure/prepare-root" || echo "$closure/prepare-root")" ]; then - echo "NEW_INIT=''${initParam[1]}" > /etc/switch-root.conf - echo "$closure does not look like a NixOS installation - not activating" - exit 0 - fi - echo 'NEW_INIT=' > /etc/switch-root.conf - ''; + script = # bash + '' + set -uo pipefail + export PATH="/bin:${cfg.package.util-linux}/bin:${pkgs.chroot-realpath}/bin" + + # Figure out what closure to boot + closure= + for o in $(< /proc/cmdline); do + case $o in + init=*) + IFS="=" read -r -a initParam <<< "$o" + closure="''${initParam[1]}" + ;; + esac + done + + # Sanity check + if [ -z "''${closure:-}" ]; then + echo 'No init= parameter on the kernel command line' >&2 + exit 1 + fi + + # Resolve symlinks in the init parameter. We need this for some boot loaders + # (e.g. boot.loader.generationsDir). + closure="$(chroot-realpath /sysroot "$closure")" + + # Assume the directory containing the init script is the closure. + closure="$(dirname "$closure")" + + ln --symbolic "$closure" /nixos-closure + + # If we are not booting a NixOS closure (e.g. init=/bin/sh), + # we don't know what root to prepare so we don't do anything + if ! [ -x "/sysroot$(readlink "/sysroot$closure/prepare-root" || echo "$closure/prepare-root")" ]; then + echo "NEW_INIT=''${initParam[1]}" > /etc/switch-root.conf + echo "$closure does not look like a NixOS installation - not activating" + exit 0 + fi + echo 'NEW_INIT=' > /etc/switch-root.conf + ''; }; # We need to propagate /run for things like /run/booted-system @@ -594,16 +672,17 @@ in { serviceConfig.Type = "oneshot"; description = "NixOS Activation"; - script = /* bash */ '' - set -uo pipefail - export PATH="/bin:${cfg.package.util-linux}/bin" + script = # bash + '' + set -uo pipefail + export PATH="/bin:${cfg.package.util-linux}/bin" - closure="$(realpath /nixos-closure)" + closure="$(realpath /nixos-closure)" - # Initialize the system - export IN_NIXOS_SYSTEMD_STAGE1=true - exec chroot /sysroot "$closure/prepare-root" - ''; + # Initialize the system + export IN_NIXOS_SYSTEMD_STAGE1=true + exec chroot /sysroot "$closure/prepare-root" + ''; }; # This will either call systemctl with the new init as the last parameter (which @@ -619,7 +698,7 @@ in { }; services.panic-on-fail = { - wantedBy = ["emergency.target"]; + wantedBy = [ "emergency.target" ]; unitConfig = { DefaultDependencies = false; ConditionKernelCommandLine = [ diff --git a/nixos/modules/system/boot/systemd/journald-gateway.nix b/nixos/modules/system/boot/systemd/journald-gateway.nix index 1bcb3f400c619b..b6cf300d3bfb6f 100644 --- a/nixos/modules/system/boot/systemd/journald-gateway.nix +++ b/nixos/modules/system/boot/systemd/journald-gateway.nix @@ -1,11 +1,23 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.journald.gateway; cliArgs = lib.cli.toGNUCommandLineShell { } { # If either of these are null / false, they are not passed in the command-line - inherit (cfg) cert key trust system user merge; + inherit (cfg) + cert + key + trust + system + user + merge + ; }; in { @@ -118,9 +130,9 @@ in users.groups.systemd-journal-gateway.gid = config.ids.gids.systemd-journal-gateway; systemd.services.systemd-journal-gatewayd.serviceConfig.ExecStart = [ - # Clear the default command line - "" - "${pkgs.systemd}/lib/systemd/systemd-journal-gatewayd ${cliArgs}" + # Clear the default command line + "" + "${pkgs.systemd}/lib/systemd/systemd-journal-gatewayd ${cliArgs}" ]; systemd.sockets.systemd-journal-gatewayd = { diff --git a/nixos/modules/system/boot/systemd/journald-remote.nix b/nixos/modules/system/boot/systemd/journald-remote.nix index 13674694c144e0..5aeb3c8f159740 100644 --- a/nixos/modules/system/boot/systemd/journald-remote.nix +++ b/nixos/modules/system/boot/systemd/journald-remote.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.journald.remote; @@ -17,7 +22,10 @@ in listen = lib.mkOption { default = "https"; - type = lib.types.enum [ "https" "http" ]; + type = lib.types.enum [ + "https" + "http" + ]; description = '' Which protocol to listen to. ''; @@ -74,7 +82,10 @@ in SplitMode = lib.mkOption { default = "host"; example = "none"; - type = lib.types.enum [ "host" "none" ]; + type = lib.types.enum [ + "host" + "none" + ]; description = '' With "host", a separate output file is used, based on the hostname of the other endpoint of a connection. With "none", only diff --git a/nixos/modules/system/boot/systemd/journald-upload.nix b/nixos/modules/system/boot/systemd/journald-upload.nix index 053f886ff5c6b9..c2437e7aadf898 100644 --- a/nixos/modules/system/boot/systemd/journald-upload.nix +++ b/nixos/modules/system/boot/systemd/journald-upload.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.journald.upload; diff --git a/nixos/modules/system/boot/systemd/journald.nix b/nixos/modules/system/boot/systemd/journald.nix index 1eb958a3c2cde0..bfcacc4fa8ebbb 100644 --- a/nixos/modules/system/boot/systemd/journald.nix +++ b/nixos/modules/system/boot/systemd/journald.nix @@ -1,9 +1,18 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.journald; -in { +in +{ imports = [ - (lib.mkRenamedOptionModule [ "services" "journald" "enableHttpGateway" ] [ "services" "journald" "gateway" "enable" ]) + (lib.mkRenamedOptionModule + [ "services" "journald" "enableHttpGateway" ] + [ "services" "journald" "gateway" "enable" ] + ) ]; options = { @@ -31,7 +40,12 @@ in { services.journald.storage = lib.mkOption { default = "persistent"; - type = lib.types.enum [ "persistent" "volatile" "auto" "none" ]; + type = lib.types.enum [ + "persistent" + "volatile" + "auto" + "none" + ]; description = '' Controls where to store journal data. See {manpage}`journald.conf(5)` for further information. @@ -85,18 +99,21 @@ in { }; config = { - systemd.additionalUpstreamSystemUnits = [ - "systemd-journald.socket" - "systemd-journald@.socket" - "systemd-journald-varlink@.socket" - "systemd-journald.service" - "systemd-journald@.service" - "systemd-journal-flush.service" - "systemd-journal-catalog-update.service" - "systemd-journald-sync@.service" - ] ++ (lib.optional (!config.boot.isContainer) "systemd-journald-audit.socket") ++ [ - "systemd-journald-dev-log.socket" - "syslog.socket" + systemd.additionalUpstreamSystemUnits = + [ + "systemd-journald.socket" + "systemd-journald@.socket" + "systemd-journald-varlink@.socket" + "systemd-journald.service" + "systemd-journald@.service" + "systemd-journal-flush.service" + "systemd-journal-catalog-update.service" + "systemd-journald-sync@.service" + ] + ++ (lib.optional (!config.boot.isContainer) "systemd-journald-audit.socket") + ++ [ + "systemd-journald-dev-log.socket" + "syslog.socket" ]; environment.etc = { @@ -119,9 +136,13 @@ in { users.groups.systemd-journal.gid = config.ids.gids.systemd-journal; systemd.services.systemd-journal-flush.restartIfChanged = false; - systemd.services.systemd-journald.restartTriggers = [ config.environment.etc."systemd/journald.conf".source ]; + systemd.services.systemd-journald.restartTriggers = [ + config.environment.etc."systemd/journald.conf".source + ]; systemd.services.systemd-journald.stopIfChanged = false; - systemd.services."systemd-journald@".restartTriggers = [ config.environment.etc."systemd/journald.conf".source ]; + systemd.services."systemd-journald@".restartTriggers = [ + config.environment.etc."systemd/journald.conf".source + ]; systemd.services."systemd-journald@".stopIfChanged = false; }; } diff --git a/nixos/modules/system/boot/systemd/logind.nix b/nixos/modules/system/boot/systemd/logind.nix index c7a0a375f6ff95..a216219b0df73b 100644 --- a/nixos/modules/system/boot/systemd/logind.nix +++ b/nixos/modules/system/boot/systemd/logind.nix @@ -1,10 +1,24 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.services.logind; logindHandlerType = lib.types.enum [ - "ignore" "poweroff" "reboot" "halt" "kexec" "suspend" - "hibernate" "hybrid-sleep" "suspend-then-hibernate" "lock" + "ignore" + "poweroff" + "reboot" + "halt" + "kexec" + "suspend" + "hibernate" + "hybrid-sleep" + "suspend-then-hibernate" + "lock" ]; in { @@ -152,21 +166,26 @@ in }; config = { - systemd.additionalUpstreamSystemUnits = [ - "systemd-logind.service" - "autovt@.service" - "systemd-user-sessions.service" - ] ++ lib.optionals config.systemd.package.withImportd [ - "dbus-org.freedesktop.import1.service" - ] ++ lib.optionals config.systemd.package.withMachined [ - "dbus-org.freedesktop.machine1.service" - ] ++ lib.optionals config.systemd.package.withPortabled [ - "dbus-org.freedesktop.portable1.service" - ] ++ [ - "dbus-org.freedesktop.login1.service" - "user@.service" - "user-runtime-dir@.service" - ]; + systemd.additionalUpstreamSystemUnits = + [ + "systemd-logind.service" + "autovt@.service" + "systemd-user-sessions.service" + ] + ++ lib.optionals config.systemd.package.withImportd [ + "dbus-org.freedesktop.import1.service" + ] + ++ lib.optionals config.systemd.package.withMachined [ + "dbus-org.freedesktop.machine1.service" + ] + ++ lib.optionals config.systemd.package.withPortabled [ + "dbus-org.freedesktop.portable1.service" + ] + ++ [ + "dbus-org.freedesktop.login1.service" + "user@.service" + "user-runtime-dir@.service" + ]; environment.etc = { "systemd/logind.conf".text = '' diff --git a/nixos/modules/system/boot/systemd/nspawn.nix b/nixos/modules/system/boot/systemd/nspawn.nix index e9bf82c462a954..21684aed66d488 100644 --- a/nixos/modules/system/boot/systemd/nspawn.nix +++ b/nixos/modules/system/boot/systemd/nspawn.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ...}: +{ + config, + lib, + pkgs, + utils, + ... +}: with utils.systemdUtils.unitOptions; with utils.systemdUtils.lib; @@ -9,14 +15,46 @@ let checkExec = checkUnitConfig "Exec" [ (assertOnlyFields [ - "Boot" "ProcessTwo" "Parameters" "Environment" "User" "WorkingDirectory" - "PivotRoot" "Capability" "DropCapability" "NoNewPrivileges" "KillSignal" - "Personality" "MachineID" "PrivateUsers" "NotifyReady" "SystemCallFilter" - "LimitCPU" "LimitFSIZE" "LimitDATA" "LimitSTACK" "LimitCORE" "LimitRSS" - "LimitNOFILE" "LimitAS" "LimitNPROC" "LimitMEMLOCK" "LimitLOCKS" - "LimitSIGPENDING" "LimitMSGQUEUE" "LimitNICE" "LimitRTPRIO" "LimitRTTIME" - "OOMScoreAdjust" "CPUAffinity" "Hostname" "ResolvConf" "Timezone" - "LinkJournal" "Ephemeral" "AmbientCapability" + "Boot" + "ProcessTwo" + "Parameters" + "Environment" + "User" + "WorkingDirectory" + "PivotRoot" + "Capability" + "DropCapability" + "NoNewPrivileges" + "KillSignal" + "Personality" + "MachineID" + "PrivateUsers" + "NotifyReady" + "SystemCallFilter" + "LimitCPU" + "LimitFSIZE" + "LimitDATA" + "LimitSTACK" + "LimitCORE" + "LimitRSS" + "LimitNOFILE" + "LimitAS" + "LimitNPROC" + "LimitMEMLOCK" + "LimitLOCKS" + "LimitSIGPENDING" + "LimitMSGQUEUE" + "LimitNICE" + "LimitRTPRIO" + "LimitRTTIME" + "OOMScoreAdjust" + "CPUAffinity" + "Hostname" + "ResolvConf" + "Timezone" + "LinkJournal" + "Ephemeral" + "AmbientCapability" ]) (assertValueOneOf "Boot" boolValues) (assertValueOneOf "ProcessTwo" boolValues) @@ -25,32 +63,52 @@ let checkFiles = checkUnitConfig "Files" [ (assertOnlyFields [ - "ReadOnly" "Volatile" "Bind" "BindReadOnly" "TemporaryFileSystem" - "Overlay" "OverlayReadOnly" "PrivateUsersChown" "BindUser" - "Inaccessible" "PrivateUsersOwnership" + "ReadOnly" + "Volatile" + "Bind" + "BindReadOnly" + "TemporaryFileSystem" + "Overlay" + "OverlayReadOnly" + "PrivateUsersChown" + "BindUser" + "Inaccessible" + "PrivateUsersOwnership" ]) (assertValueOneOf "ReadOnly" boolValues) (assertValueOneOf "Volatile" (boolValues ++ [ "state" ])) (assertValueOneOf "PrivateUsersChown" boolValues) - (assertValueOneOf "PrivateUsersOwnership" [ "off" "chown" "map" "auto" ]) + (assertValueOneOf "PrivateUsersOwnership" [ + "off" + "chown" + "map" + "auto" + ]) ]; checkNetwork = checkUnitConfig "Network" [ (assertOnlyFields [ - "Private" "VirtualEthernet" "VirtualEthernetExtra" "Interface" "MACVLAN" - "IPVLAN" "Bridge" "Zone" "Port" + "Private" + "VirtualEthernet" + "VirtualEthernetExtra" + "Interface" + "MACVLAN" + "IPVLAN" + "Bridge" + "Zone" + "Port" ]) (assertValueOneOf "Private" boolValues) (assertValueOneOf "VirtualEthernet" boolValues) ]; instanceOptions = { - options = - (getAttrs [ "enable" ] sharedOptions) - // { + options = (getAttrs [ "enable" ] sharedOptions) // { execConfig = mkOption { - default = {}; - example = { Parameters = "/bin/sh"; }; + default = { }; + example = { + Parameters = "/bin/sh"; + }; type = types.addCheck (types.attrsOf unitOption) checkExec; description = '' Each attribute in this set specifies an option in the @@ -60,8 +118,10 @@ let }; filesConfig = mkOption { - default = {}; - example = { Bind = [ "/home/alice" ]; }; + default = { }; + example = { + Bind = [ "/home/alice" ]; + }; type = types.addCheck (types.attrsOf unitOption) checkFiles; description = '' Each attribute in this set specifies an option in the @@ -71,8 +131,10 @@ let }; networkConfig = mkOption { - default = {}; - example = { Private = false; }; + default = { }; + example = { + Private = false; + }; type = types.addCheck (types.attrsOf unitOption) checkNetwork; description = '' Each attribute in this set specifies an option in the @@ -84,27 +146,31 @@ let }; - instanceToUnit = name: def: - let base = { - text = '' - [Exec] - ${attrsToSection def.execConfig} + instanceToUnit = + name: def: + let + base = { + text = '' + [Exec] + ${attrsToSection def.execConfig} - [Files] - ${attrsToSection def.filesConfig} + [Files] + ${attrsToSection def.filesConfig} - [Network] - ${attrsToSection def.networkConfig} - ''; - } // def; - in base // { unit = makeUnit name base; }; + [Network] + ${attrsToSection def.networkConfig} + ''; + } // def; + in + base // { unit = makeUnit name base; }; -in { +in +{ options = { systemd.nspawn = mkOption { - default = {}; + default = { }; type = with types; attrsOf (submodule instanceOptions); description = "Definition of systemd-nspawn configurations."; }; @@ -113,23 +179,29 @@ in { config = let - units = mapAttrs' (n: v: let nspawnFile = "${n}.nspawn"; in nameValuePair nspawnFile (instanceToUnit nspawnFile v)) cfg; + units = mapAttrs' ( + n: v: + let + nspawnFile = "${n}.nspawn"; + in + nameValuePair nspawnFile (instanceToUnit nspawnFile v) + ) cfg; in - mkMerge [ - (mkIf (cfg != {}) { - environment.etc."systemd/nspawn".source = mkIf (cfg != {}) (generateUnits { - allowCollisions = false; - type = "nspawn"; - inherit units; - upstreamUnits = []; - upstreamWants = []; - }); - }) - { - systemd.targets.multi-user.wants = [ "machines.target" ]; - systemd.services."systemd-nspawn@".environment = { - SYSTEMD_NSPAWN_UNIFIED_HIERARCHY = mkDefault "1"; - }; - } - ]; + mkMerge [ + (mkIf (cfg != { }) { + environment.etc."systemd/nspawn".source = mkIf (cfg != { }) (generateUnits { + allowCollisions = false; + type = "nspawn"; + inherit units; + upstreamUnits = [ ]; + upstreamWants = [ ]; + }); + }) + { + systemd.targets.multi-user.wants = [ "machines.target" ]; + systemd.services."systemd-nspawn@".environment = { + SYSTEMD_NSPAWN_UNIFIED_HIERARCHY = mkDefault "1"; + }; + } + ]; } diff --git a/nixos/modules/system/boot/systemd/oomd.nix b/nixos/modules/system/boot/systemd/oomd.nix index a2a90e0ceb873b..bf162288c14296 100644 --- a/nixos/modules/system/boot/systemd/oomd.nix +++ b/nixos/modules/system/boot/systemd/oomd.nix @@ -1,14 +1,21 @@ -{ config, lib, ... }: let +{ config, lib, ... }: +let cfg = config.systemd.oomd; -in { +in +{ imports = [ - (lib.mkRenamedOptionModule [ "systemd" "oomd" "enableUserServices" ] [ "systemd" "oomd" "enableUserSlices" ]) + (lib.mkRenamedOptionModule + [ "systemd" "oomd" "enableUserServices" ] + [ "systemd" "oomd" "enableUserSlices" ] + ) ]; options.systemd.oomd = { - enable = lib.mkEnableOption "the `systemd-oomd` OOM killer" // { default = true; }; + enable = lib.mkEnableOption "the `systemd-oomd` OOM killer" // { + default = true; + }; # Fedora enables the first and third option by default. See the 10-oomd-* files here: # https://src.fedoraproject.org/rpms/systemd/tree/806c95e1c70af18f81d499b24cd7acfa4c36ffd6 @@ -17,8 +24,14 @@ in { enableUserSlices = lib.mkEnableOption "oomd on all user slices (`user@.slice`) and all user owned slices"; extraConfig = lib.mkOption { - type = with lib.types; attrsOf (oneOf [ str int bool ]); - default = {}; + type = + with lib.types; + attrsOf (oneOf [ + str + int + bool + ]); + default = { }; example = lib.literalExpression ''{ DefaultMemoryPressureDurationSec = "20s"; }''; description = '' Extra config options for `systemd-oomd`. See {command}`man oomd.conf` @@ -34,7 +47,7 @@ in { ]; systemd.services.systemd-oomd.wantedBy = [ "multi-user.target" ]; - environment.etc."systemd/oomd.conf".text = lib.generators.toINI {} { + environment.etc."systemd/oomd.conf".text = lib.generators.toINI { } { OOM = cfg.extraConfig; }; diff --git a/nixos/modules/system/boot/systemd/repart.nix b/nixos/modules/system/boot/systemd/repart.nix index 49db1305bb2b6e..0e1c1b4e2785c1 100644 --- a/nixos/modules/system/boot/systemd/repart.nix +++ b/nixos/modules/system/boot/systemd/repart.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.systemd.repart; @@ -6,12 +12,12 @@ let format = pkgs.formats.ini { }; - definitionsDirectory = utils.systemdUtils.lib.definitions - "repart.d" - format - (lib.mapAttrs (_n: v: { Partition = v; }) cfg.partitions); + definitionsDirectory = utils.systemdUtils.lib.definitions "repart.d" format ( + lib.mapAttrs (_n: v: { Partition = v; }) cfg.partitions + ); - partitionAssertions = lib.mapAttrsToList (fileName: definition: + partitionAssertions = lib.mapAttrsToList ( + fileName: definition: let inherit (utils.systemdUtils.lib) GPTMaxLabelLength; labelLength = builtins.stringLength definition.Label; @@ -64,7 +70,15 @@ in }; partitions = lib.mkOption { - type = with lib.types; attrsOf (attrsOf (oneOf [ str int bool ])); + type = + with lib.types; + attrsOf ( + attrsOf (oneOf [ + str + int + bool + ]) + ); default = { }; example = { "10-root" = { @@ -128,9 +142,10 @@ in # When running in the initrd, systemd-repart by default searches # for definition files in /sysroot or /sysusr. We tell it to look # in the initrd itself. - ''${config.boot.initrd.systemd.package}/bin/systemd-repart \ - --definitions=/etc/repart.d \ - --dry-run=no ${lib.optionalString (initrdCfg.device != null) initrdCfg.device} + '' + ${config.boot.initrd.systemd.package}/bin/systemd-repart \ + --definitions=/etc/repart.d \ + --dry-run=no ${lib.optionalString (initrdCfg.device != null) initrdCfg.device} '' ]; }; @@ -142,11 +157,7 @@ in # on. The service then needs to be ordered to run after this device # is available. requires = lib.mkIf (initrdCfg.device != null) [ deviceUnit ]; - after = - if initrdCfg.device == null then - [ "sysroot.mount" ] - else - [ deviceUnit ]; + after = if initrdCfg.device == null then [ "sysroot.mount" ] else [ deviceUnit ]; }; }; diff --git a/nixos/modules/system/boot/systemd/shutdown.nix b/nixos/modules/system/boot/systemd/shutdown.nix index 48477954e20c75..1e8b8c6f863cf0 100644 --- a/nixos/modules/system/boot/systemd/shutdown.nix +++ b/nixos/modules/system/boot/systemd/shutdown.nix @@ -1,12 +1,22 @@ -{ config, lib, utils, pkgs, ... }: let +{ + config, + lib, + utils, + pkgs, + ... +}: +let cfg = config.systemd.shutdownRamfs; ramfsContents = pkgs.writeText "shutdown-ramfs-contents.json" (builtins.toJSON cfg.storePaths); -in { +in +{ options.systemd.shutdownRamfs = { - enable = lib.mkEnableOption "pivoting back to an initramfs for shutdown" // { default = true; }; + enable = lib.mkEnableOption "pivoting back to an initramfs for shutdown" // { + default = true; + }; contents = lib.mkOption { description = "Set of files that have to be linked into the shutdown ramfs"; example = lib.literalExpression '' @@ -22,7 +32,7 @@ in { Store paths to copy into the shutdown ramfs as well. ''; type = utils.systemdUtils.types.initrdStorePath; - default = []; + default = [ ]; }; }; @@ -32,14 +42,18 @@ in { "/etc/initrd-release".source = config.environment.etc.os-release.source; "/etc/os-release".source = config.environment.etc.os-release.source; }; - systemd.shutdownRamfs.storePaths = [pkgs.runtimeShell "${pkgs.coreutils}/bin"] - ++ map (c: builtins.removeAttrs c ["text"]) (builtins.attrValues cfg.contents); + systemd.shutdownRamfs.storePaths = [ + pkgs.runtimeShell + "${pkgs.coreutils}/bin" + ] ++ map (c: builtins.removeAttrs c [ "text" ]) (builtins.attrValues cfg.contents); - systemd.mounts = [{ - what = "tmpfs"; - where = "/run/initramfs"; - type = "tmpfs"; - }]; + systemd.mounts = [ + { + what = "tmpfs"; + where = "/run/initramfs"; + type = "tmpfs"; + } + ]; systemd.services.generate-shutdown-ramfs = { description = "Generate shutdown ramfs"; diff --git a/nixos/modules/system/boot/systemd/sysupdate.nix b/nixos/modules/system/boot/systemd/sysupdate.nix index 67f0b3b1caadc9..dff4a6066ec0e4 100644 --- a/nixos/modules/system/boot/systemd/sysupdate.nix +++ b/nixos/modules/system/boot/systemd/sysupdate.nix @@ -1,14 +1,17 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let cfg = config.systemd.sysupdate; format = pkgs.formats.ini { listToValue = toString; }; - definitionsDirectory = utils.systemdUtils.lib.definitions - "sysupdate.d" - format - cfg.transfers; + definitionsDirectory = utils.systemdUtils.lib.definitions "sysupdate.d" format cfg.transfers; in { options.systemd.sysupdate = { @@ -79,7 +82,11 @@ in Source = { Type = "url-file"; Path = "https://download.example.com/"; - MatchPattern = [ "nixos_@v+@l-@d.efi" "nixos_@v+@l.efi" "nixos_@v.efi" ]; + MatchPattern = [ + "nixos_@v+@l-@d.efi" + "nixos_@v+@l.efi" + "nixos_@v.efi" + ]; }; Target = { diff --git a/nixos/modules/system/boot/systemd/sysusers.nix b/nixos/modules/system/boot/systemd/sysusers.nix index d0af52e0ae9e47..d7b700f5748cd7 100644 --- a/nixos/modules/system/boot/systemd/sysusers.nix +++ b/nixos/modules/system/boot/systemd/sysusers.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let @@ -11,25 +17,32 @@ let # Type Name ID GECOS Home directory Shell # Users - ${lib.concatLines (lib.mapAttrsToList - (username: opts: + ${lib.concatLines ( + lib.mapAttrsToList ( + username: opts: let uid = if opts.uid == null then "/var/lib/nixos/uid/${username}" else toString opts.uid; in - ''u ${username} ${uid}:${opts.group} "${opts.description}" ${opts.home} ${utils.toShellPath opts.shell}'' - ) - systemUsers) - } + ''u ${username} ${uid}:${opts.group} "${opts.description}" ${opts.home} ${utils.toShellPath opts.shell}'' + ) systemUsers + )} # Groups - ${lib.concatLines (lib.mapAttrsToList - (groupname: opts: ''g ${groupname} ${if opts.gid == null then "/var/lib/nixos/gid/${groupname}" else toString opts.gid}'') userCfg.groups) - } + ${lib.concatLines ( + lib.mapAttrsToList ( + groupname: opts: + ''g ${groupname} ${ + if opts.gid == null then "/var/lib/nixos/gid/${groupname}" else toString opts.gid + }'' + ) userCfg.groups + )} # Group membership - ${lib.concatStrings (lib.mapAttrsToList - (groupname: opts: (lib.concatMapStrings (username: "m ${username} ${groupname}\n")) opts.members ) userCfg.groups) - } + ${lib.concatStrings ( + lib.mapAttrsToList ( + groupname: opts: (lib.concatMapStrings (username: "m ${username} ${groupname}\n")) opts.members + ) userCfg.groups + )} ''; immutableEtc = config.system.etc.overlay.enable && !config.system.etc.overlay.mutable; @@ -37,7 +50,12 @@ let immutablePasswordFilesLocation = "/var/lib/nixos/etc"; passwordFilesLocation = if immutableEtc then immutablePasswordFilesLocation else "/etc"; # The filenames created by systemd-sysusers. - passwordFiles = [ "passwd" "group" "shadow" "gshadow" ]; + passwordFiles = [ + "passwd" + "group" + "shadow" + "gshadow" + ]; in @@ -63,55 +81,57 @@ in config = lib.mkIf cfg.enable { - assertions = [ - { - assertion = config.system.activationScripts.users == ""; - message = "system.activationScripts.users has to be empty to use systemd-sysusers"; - } - ] ++ (lib.mapAttrsToList - (username: opts: { + assertions = + [ + { + assertion = config.system.activationScripts.users == ""; + message = "system.activationScripts.users has to be empty to use systemd-sysusers"; + } + ] + ++ (lib.mapAttrsToList (username: opts: { assertion = !opts.isNormalUser; message = "${username} is a normal user. systemd-sysusers doesn't create normal users, only system users."; - }) - userCfg.users) - ++ lib.mapAttrsToList - (username: opts: { - assertion = (opts.password == opts.initialPassword || opts.password == null) && - (opts.hashedPassword == opts.initialHashedPassword || opts.hashedPassword == null); + }) userCfg.users) + ++ lib.mapAttrsToList (username: opts: { + assertion = + (opts.password == opts.initialPassword || opts.password == null) + && (opts.hashedPassword == opts.initialHashedPassword || opts.hashedPassword == null); message = "user '${username}' uses password or hashedPassword. systemd-sysupdate only supports initial passwords. It'll never update your passwords."; - }) - systemUsers; + }) systemUsers; systemd = { # Create home directories, do not create /var/empty even if that's a user's # home. - tmpfiles.settings.home-directories = lib.mapAttrs' - (username: opts: lib.nameValuePair opts.home { + tmpfiles.settings.home-directories = lib.mapAttrs' ( + username: opts: + lib.nameValuePair opts.home { d = { mode = opts.homeMode; user = username; group = opts.group; }; - }) - (lib.filterAttrs (_username: opts: opts.home != "/var/empty") systemUsers); + } + ) (lib.filterAttrs (_username: opts: opts.home != "/var/empty") systemUsers); # Create uid/gid marker files for those without an explicit id - tmpfiles.settings.nixos-uid = lib.mapAttrs' - (username: opts: lib.nameValuePair "/var/lib/nixos/uid/${username}" { + tmpfiles.settings.nixos-uid = lib.mapAttrs' ( + username: opts: + lib.nameValuePair "/var/lib/nixos/uid/${username}" { f = { user = username; }; - }) - (lib.filterAttrs (_username: opts: opts.uid == null) systemUsers); + } + ) (lib.filterAttrs (_username: opts: opts.uid == null) systemUsers); - tmpfiles.settings.nixos-gid = lib.mapAttrs' - (groupname: opts: lib.nameValuePair "/var/lib/nixos/gid/${groupname}" { + tmpfiles.settings.nixos-gid = lib.mapAttrs' ( + groupname: opts: + lib.nameValuePair "/var/lib/nixos/gid/${groupname}" { f = { group = groupname; }; - }) - (lib.filterAttrs (_groupname: opts: opts.gid == null) userCfg.groups); + } + ) (lib.filterAttrs (_groupname: opts: opts.gid == null) userCfg.groups); additionalUpstreamSystemUnits = [ "systemd-sysusers.service" @@ -131,31 +151,33 @@ in # # We need to explicitly list the config file, otherwise # systemd-sysusers cannot find it when we also pass another flag. - ExecStart = lib.mkIf immutableEtc - [ "" "${config.systemd.package}/bin/systemd-sysusers --root ${builtins.dirOf immutablePasswordFilesLocation} /etc/sysusers.d/00-nixos.conf" ]; + ExecStart = lib.mkIf immutableEtc [ + "" + "${config.systemd.package}/bin/systemd-sysusers --root ${builtins.dirOf immutablePasswordFilesLocation} /etc/sysusers.d/00-nixos.conf" + ]; # Make the source files writable before executing sysusers. - ExecStartPre = lib.mkIf (!userCfg.mutableUsers) - (lib.map - (file: "-${pkgs.util-linux}/bin/umount ${passwordFilesLocation}/${file}") - passwordFiles); + ExecStartPre = lib.mkIf (!userCfg.mutableUsers) ( + lib.map (file: "-${pkgs.util-linux}/bin/umount ${passwordFilesLocation}/${file}") passwordFiles + ); # Make the source files read-only after sysusers has finished. - ExecStartPost = lib.mkIf (!userCfg.mutableUsers) - (lib.map - (file: "${pkgs.util-linux}/bin/mount --bind -o ro ${passwordFilesLocation}/${file} ${passwordFilesLocation}/${file}") - passwordFiles); - - LoadCredential = lib.mapAttrsToList - (username: opts: "passwd.hashed-password.${username}:${opts.hashedPasswordFile}") - (lib.filterAttrs (_username: opts: opts.hashedPasswordFile != null) systemUsers); - SetCredential = (lib.mapAttrsToList - (username: opts: "passwd.hashed-password.${username}:${opts.initialHashedPassword}") - (lib.filterAttrs (_username: opts: opts.initialHashedPassword != null) systemUsers)) - ++ - (lib.mapAttrsToList - (username: opts: "passwd.plaintext-password.${username}:${opts.initialPassword}") - (lib.filterAttrs (_username: opts: opts.initialPassword != null) systemUsers)) - ; + ExecStartPost = lib.mkIf (!userCfg.mutableUsers) ( + lib.map ( + file: + "${pkgs.util-linux}/bin/mount --bind -o ro ${passwordFilesLocation}/${file} ${passwordFilesLocation}/${file}" + ) passwordFiles + ); + + LoadCredential = lib.mapAttrsToList ( + username: opts: "passwd.hashed-password.${username}:${opts.hashedPasswordFile}" + ) (lib.filterAttrs (_username: opts: opts.hashedPasswordFile != null) systemUsers); + SetCredential = + (lib.mapAttrsToList ( + username: opts: "passwd.hashed-password.${username}:${opts.initialHashedPassword}" + ) (lib.filterAttrs (_username: opts: opts.initialHashedPassword != null) systemUsers)) + ++ (lib.mapAttrsToList ( + username: opts: "passwd.plaintext-password.${username}:${opts.initialPassword}" + ) (lib.filterAttrs (_username: opts: opts.initialPassword != null) systemUsers)); }; }; @@ -169,12 +191,17 @@ in # Statically create the symlinks to immutablePasswordFilesLocation when # using an immutable /etc because we will not be able to do it at # runtime! - (lib.mkIf immutableEtc (lib.listToAttrs (lib.map - (file: lib.nameValuePair file { - source = "${immutablePasswordFilesLocation}/${file}"; - mode = "direct-symlink"; - }) - passwordFiles))) + (lib.mkIf immutableEtc ( + lib.listToAttrs ( + lib.map ( + file: + lib.nameValuePair file { + source = "${immutablePasswordFilesLocation}/${file}"; + mode = "direct-symlink"; + } + ) passwordFiles + ) + )) ]; }; diff --git a/nixos/modules/system/boot/systemd/user.nix b/nixos/modules/system/boot/systemd/user.nix index 53fca631678c10..8f1d92c409b33a 100644 --- a/nixos/modules/system/boot/systemd/user.nix +++ b/nixos/modules/system/boot/systemd/user.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: with utils; with systemdUtils.unitOptions; with lib; @@ -8,8 +14,7 @@ let systemd = config.systemd.package; - inherit - (systemdUtils.lib) + inherit (systemdUtils.lib) makeUnit generateUnits targetToUnit @@ -17,7 +22,8 @@ let sliceToUnit socketToUnit timerToUnit - pathToUnit; + pathToUnit + ; upstreamUserUnits = [ "app.slice" @@ -40,7 +46,11 @@ let "xdg-desktop-autostart.target" ] ++ config.systemd.additionalUpstreamUserUnits; - writeTmpfiles = { rules, user ? null }: + writeTmpfiles = + { + rules, + user ? null, + }: let suffix = optionalString (user != null) "-${user}"; in @@ -53,7 +63,8 @@ let ${concatStringsSep "\n" rules} ''; }; -in { +in +{ options = { systemd.user.extraConfig = mkOption { default = ""; @@ -67,42 +78,42 @@ in { systemd.user.units = mkOption { description = "Definition of systemd per-user units."; - default = {}; + default = { }; type = systemdUtils.types.units; }; systemd.user.paths = mkOption { - default = {}; + default = { }; type = systemdUtils.types.paths; description = "Definition of systemd per-user path units."; }; systemd.user.services = mkOption { - default = {}; + default = { }; type = systemdUtils.types.services; description = "Definition of systemd per-user service units."; }; systemd.user.slices = mkOption { - default = {}; + default = { }; type = systemdUtils.types.slices; description = "Definition of systemd per-user slice units."; }; systemd.user.sockets = mkOption { - default = {}; + default = { }; type = systemdUtils.types.sockets; description = "Definition of systemd per-user socket units."; }; systemd.user.targets = mkOption { - default = {}; + default = { }; type = systemdUtils.types.targets; description = "Definition of systemd per-user target units."; }; systemd.user.timers = mkOption { - default = {}; + default = { }; type = systemdUtils.types.timers; description = "Definition of systemd per-user timer units."; }; @@ -110,7 +121,7 @@ in { systemd.user.tmpfiles = { rules = mkOption { type = types.listOf types.str; - default = []; + default = [ ]; example = [ "D %C - - - 7d" ]; description = '' Global user rules for creation, deletion and cleaning of volatile and @@ -125,29 +136,33 @@ in { Per-user rules for creation, deletion and cleaning of volatile and temporary files automatically. ''; - default = {}; - type = types.attrsOf (types.submodule { - options = { - rules = mkOption { - type = types.listOf types.str; - default = []; - example = [ "D %C - - - 7d" ]; - description = '' - Per-user rules for creation, deletion and cleaning of volatile and - temporary files automatically. See - {manpage}`tmpfiles.d(5)` - for the exact format. - ''; + default = { }; + type = types.attrsOf ( + types.submodule { + options = { + rules = mkOption { + type = types.listOf types.str; + default = [ ]; + example = [ "D %C - - - 7d" ]; + description = '' + Per-user rules for creation, deletion and cleaning of volatile and + temporary files automatically. See + {manpage}`tmpfiles.d(5)` + for the exact format. + ''; + }; }; - }; - }); + } + ); }; }; systemd.user.generators = mkOption { type = types.attrsOf types.path; - default = {}; - example = { systemd-gpt-auto-generator = "/dev/null"; }; + default = { }; + example = { + systemd-gpt-auto-generator = "/dev/null"; + }; description = '' Definition of systemd generators; see {manpage}`systemd.generator(5)`. @@ -157,9 +172,9 @@ in { }; systemd.additionalUpstreamUserUnits = mkOption { - default = []; + default = [ ]; type = types.listOf types.str; - example = []; + example = [ ]; description = '' Additional units shipped with systemd that should be enabled for per-user systemd instances. ''; @@ -177,7 +192,7 @@ in { type = "user"; inherit (cfg) units; upstreamUnits = upstreamUserUnits; - upstreamWants = []; + upstreamWants = [ ]; }; "systemd/user.conf".text = '' @@ -187,61 +202,54 @@ in { }; systemd.user.units = - mapAttrs' (n: v: nameValuePair "${n}.path" (pathToUnit v)) cfg.paths + mapAttrs' (n: v: nameValuePair "${n}.path" (pathToUnit v)) cfg.paths // mapAttrs' (n: v: nameValuePair "${n}.service" (serviceToUnit v)) cfg.services - // mapAttrs' (n: v: nameValuePair "${n}.slice" (sliceToUnit v)) cfg.slices - // mapAttrs' (n: v: nameValuePair "${n}.socket" (socketToUnit v)) cfg.sockets - // mapAttrs' (n: v: nameValuePair "${n}.target" (targetToUnit v)) cfg.targets - // mapAttrs' (n: v: nameValuePair "${n}.timer" (timerToUnit v)) cfg.timers; + // mapAttrs' (n: v: nameValuePair "${n}.slice" (sliceToUnit v)) cfg.slices + // mapAttrs' (n: v: nameValuePair "${n}.socket" (socketToUnit v)) cfg.sockets + // mapAttrs' (n: v: nameValuePair "${n}.target" (targetToUnit v)) cfg.targets + // mapAttrs' (n: v: nameValuePair "${n}.timer" (timerToUnit v)) cfg.timers; # Generate timer units for all services that have a ‘startAt’ value. - systemd.user.timers = - mapAttrs (name: service: { - wantedBy = ["timers.target"]; - timerConfig.OnCalendar = service.startAt; - }) - (filterAttrs (name: service: service.startAt != []) cfg.services); + systemd.user.timers = mapAttrs (name: service: { + wantedBy = [ "timers.target" ]; + timerConfig.OnCalendar = service.startAt; + }) (filterAttrs (name: service: service.startAt != [ ]) cfg.services); # Provide the systemd-user PAM service, required to run systemd # user instances. - security.pam.services.systemd-user = - { # Ensure that pam_systemd gets included. This is special-cased - # in systemd to provide XDG_RUNTIME_DIR. - startSession = true; - # Disable pam_mount in systemd-user to prevent it from being called - # multiple times during login, because it will prevent pam_mount from - # unmounting the previously mounted volumes. - pamMount = false; - }; + security.pam.services.systemd-user = { + # Ensure that pam_systemd gets included. This is special-cased + # in systemd to provide XDG_RUNTIME_DIR. + startSession = true; + # Disable pam_mount in systemd-user to prevent it from being called + # multiple times during login, because it will prevent pam_mount from + # unmounting the previously mounted volumes. + pamMount = false; + }; # Some overrides to upstream units. systemd.services."user@".restartIfChanged = false; systemd.services.systemd-user-sessions.restartIfChanged = false; # Restart kills all active sessions. # enable systemd user tmpfiles - systemd.user.services.systemd-tmpfiles-setup.wantedBy = - optional - (cfg.tmpfiles.rules != [] || any (cfg': cfg'.rules != []) (attrValues cfg.tmpfiles.users)) - "basic.target"; + systemd.user.services.systemd-tmpfiles-setup.wantedBy = optional ( + cfg.tmpfiles.rules != [ ] || any (cfg': cfg'.rules != [ ]) (attrValues cfg.tmpfiles.users) + ) "basic.target"; # /run/current-system/sw/etc/xdg is in systemd's $XDG_CONFIG_DIRS so we can # write the tmpfiles.d rules for everyone there - environment.systemPackages = - optional - (cfg.tmpfiles.rules != []) - (writeTmpfiles { inherit (cfg.tmpfiles) rules; }); + environment.systemPackages = optional (cfg.tmpfiles.rules != [ ]) (writeTmpfiles { + inherit (cfg.tmpfiles) rules; + }); # /etc/profiles/per-user/$USER/etc/xdg is in systemd's $XDG_CONFIG_DIRS so # we can write a single user's tmpfiles.d rules there - users.users = - mapAttrs - (user: cfg': { - packages = optional (cfg'.rules != []) (writeTmpfiles { - inherit (cfg') rules; - inherit user; - }); - }) - cfg.tmpfiles.users; + users.users = mapAttrs (user: cfg': { + packages = optional (cfg'.rules != [ ]) (writeTmpfiles { + inherit (cfg') rules; + inherit user; + }); + }) cfg.tmpfiles.users; system.userActivationScripts.tmpfiles = '' ${config.systemd.package}/bin/systemd-tmpfiles --user --create --remove diff --git a/nixos/modules/system/boot/timesyncd.nix b/nixos/modules/system/boot/timesyncd.nix index 117ced1f59ddc1..a2a544bf982927 100644 --- a/nixos/modules/system/boot/timesyncd.nix +++ b/nixos/modules/system/boot/timesyncd.nix @@ -86,29 +86,31 @@ in test -d /var/lib/systemd/timesync || mkdir -p /var/lib/systemd/timesync touch /var/lib/systemd/timesync/clock fi - '' + - # workaround an issue of systemd-timesyncd not starting due to upstream systemd reverting their dynamic users changes - # - https://github.com/NixOS/nixpkgs/pull/61321#issuecomment-492423742 - # - https://github.com/systemd/systemd/issues/12131 - (lib.optionalString (versionOlder config.system.stateVersion "19.09") '' - if [ -L /var/lib/systemd/timesync ]; then - rm /var/lib/systemd/timesync - mv /var/lib/private/systemd/timesync /var/lib/systemd/timesync - fi - '') + '' + + + # workaround an issue of systemd-timesyncd not starting due to upstream systemd reverting their dynamic users changes + # - https://github.com/NixOS/nixpkgs/pull/61321#issuecomment-492423742 + # - https://github.com/systemd/systemd/issues/12131 + (lib.optionalString (versionOlder config.system.stateVersion "19.09") '' + if [ -L /var/lib/systemd/timesync ]; then + rm /var/lib/systemd/timesync + mv /var/lib/private/systemd/timesync /var/lib/systemd/timesync + fi + '') ); }; - environment.etc."systemd/timesyncd.conf".text = '' - [Time] - '' - + optionalString (cfg.servers != null) '' - NTP=${concatStringsSep " " cfg.servers} - '' - + optionalString (cfg.fallbackServers != null) '' - FallbackNTP=${concatStringsSep " " cfg.fallbackServers} - '' - + cfg.extraConfig; + environment.etc."systemd/timesyncd.conf".text = + '' + [Time] + '' + + optionalString (cfg.servers != null) '' + NTP=${concatStringsSep " " cfg.servers} + '' + + optionalString (cfg.fallbackServers != null) '' + FallbackNTP=${concatStringsSep " " cfg.fallbackServers} + '' + + cfg.extraConfig; users.users.systemd-timesync = { uid = config.ids.uids.systemd-timesync; diff --git a/nixos/modules/system/boot/tmp.nix b/nixos/modules/system/boot/tmp.nix index 8287fa5f872f4c..9ec02c594cf0a7 100644 --- a/nixos/modules/system/boot/tmp.nix +++ b/nixos/modules/system/boot/tmp.nix @@ -20,7 +20,10 @@ in }; tmpfsSize = lib.mkOption { - type = lib.types.oneOf [ lib.types.str lib.types.ints.positive ]; + type = lib.types.oneOf [ + lib.types.str + lib.types.ints.positive + ]; default = "50%"; description = '' Size of tmpfs in percentage. @@ -32,12 +35,12 @@ in type = lib.types.bool; default = false; description = '' - Whether to mount a tmpfs on {file}`/tmp` during boot. + Whether to mount a tmpfs on {file}`/tmp` during boot. - ::: {.note} - Large Nix builds can fail if the mounted tmpfs is not large enough. - In such a case either increase the tmpfsSize or disable this option. - ::: + ::: {.note} + Large Nix builds can fail if the mounted tmpfs is not large enough. + In such a case either increase the tmpfsSize or disable this option. + ::: ''; }; }; diff --git a/nixos/modules/system/boot/uki.nix b/nixos/modules/system/boot/uki.nix index c86439e98a3cf5..fd9f1cadd3400f 100644 --- a/nixos/modules/system/boot/uki.nix +++ b/nixos/modules/system/boot/uki.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let @@ -67,24 +72,26 @@ in config = { - boot.uki.name = lib.mkOptionDefault (if config.system.image.id != null then - config.system.image.id - else - "nixos"); + boot.uki.name = lib.mkOptionDefault ( + if config.system.image.id != null then config.system.image.id else "nixos" + ); boot.uki.settings = { - UKI = { - Linux = lib.mkOptionDefault "${config.boot.kernelPackages.kernel}/${config.system.boot.loader.kernelFile}"; - Initrd = lib.mkOptionDefault "${config.system.build.initialRamdisk}/${config.system.boot.loader.initrdFile}"; - Cmdline = lib.mkOptionDefault "init=${config.system.build.toplevel}/init ${toString config.boot.kernelParams}"; - Stub = lib.mkOptionDefault "${pkgs.systemd}/lib/systemd/boot/efi/linux${efiArch}.efi.stub"; - Uname = lib.mkOptionDefault "${config.boot.kernelPackages.kernel.modDirVersion}"; - OSRelease = lib.mkOptionDefault "@${config.system.build.etc}/etc/os-release"; - # This is needed for cross compiling. - EFIArch = lib.mkOptionDefault efiArch; - } // lib.optionalAttrs (config.hardware.deviceTree.enable && config.hardware.deviceTree.name != null) { - DeviceTree = lib.mkOptionDefault "${config.hardware.deviceTree.package}/${config.hardware.deviceTree.name}"; - }; + UKI = + { + Linux = lib.mkOptionDefault "${config.boot.kernelPackages.kernel}/${config.system.boot.loader.kernelFile}"; + Initrd = lib.mkOptionDefault "${config.system.build.initialRamdisk}/${config.system.boot.loader.initrdFile}"; + Cmdline = lib.mkOptionDefault "init=${config.system.build.toplevel}/init ${toString config.boot.kernelParams}"; + Stub = lib.mkOptionDefault "${pkgs.systemd}/lib/systemd/boot/efi/linux${efiArch}.efi.stub"; + Uname = lib.mkOptionDefault "${config.boot.kernelPackages.kernel.modDirVersion}"; + OSRelease = lib.mkOptionDefault "@${config.system.build.etc}/etc/os-release"; + # This is needed for cross compiling. + EFIArch = lib.mkOptionDefault efiArch; + } + // lib.optionalAttrs (config.hardware.deviceTree.enable && config.hardware.deviceTree.name != null) + { + DeviceTree = lib.mkOptionDefault "${config.hardware.deviceTree.package}/${config.hardware.deviceTree.name}"; + }; }; boot.uki.configFile = lib.mkOptionDefault (format.generate "ukify.conf" cfg.settings); diff --git a/nixos/modules/system/boot/uvesafb.nix b/nixos/modules/system/boot/uvesafb.nix index 8da86466a5be88..67850b422e3f2a 100644 --- a/nixos/modules/system/boot/uvesafb.nix +++ b/nixos/modules/system/boot/uvesafb.nix @@ -1,8 +1,19 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.boot.uvesafb; - inherit (lib) mkIf mkEnableOption mkOption types; -in { + inherit (lib) + mkIf + mkEnableOption + mkOption + types + ; +in +{ options = { boot.uvesafb = { enable = mkEnableOption "uvesafb"; @@ -16,9 +27,10 @@ in { v86d.package = mkOption { type = types.package; description = "Which v86d package to use with uvesafb"; - defaultText = ''config.boot.kernelPackages.v86d.overrideAttrs (old: { - hardeningDisable = [ "all" ]; - })''; + defaultText = '' + config.boot.kernelPackages.v86d.overrideAttrs (old: { + hardeningDisable = [ "all" ]; + })''; default = config.boot.kernelPackages.v86d.overrideAttrs (old: { hardeningDisable = [ "all" ]; }); diff --git a/nixos/modules/system/build.nix b/nixos/modules/system/build.nix index 58dc3f0d411348..f48f2850fc08e4 100644 --- a/nixos/modules/system/build.nix +++ b/nixos/modules/system/build.nix @@ -6,14 +6,16 @@ in options = { system.build = mkOption { - default = {}; + default = { }; description = '' Attribute set of derivations used to set up the system. ''; type = types.submoduleWith { - modules = [{ - freeformType = with types; lazyAttrsOf (uniq unspecified); - }]; + modules = [ + { + freeformType = with types; lazyAttrsOf (uniq unspecified); + } + ]; }; }; diff --git a/nixos/modules/system/etc/etc-activation.nix b/nixos/modules/system/etc/etc-activation.nix index f623e6dddc1ef0..aed58af780b77c 100644 --- a/nixos/modules/system/etc/etc-activation.nix +++ b/nixos/modules/system/etc/etc-activation.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { @@ -7,8 +12,10 @@ config = lib.mkMerge [ { - system.activationScripts.etc = - lib.stringAfter [ "users" "groups" ] config.system.build.etcActivationCommands; + system.activationScripts.etc = lib.stringAfter [ + "users" + "groups" + ] config.system.build.etcActivationCommands; } (lib.mkIf config.system.etc.overlay.enable { @@ -19,7 +26,9 @@ message = "`system.etc.overlay.enable` requires `boot.initrd.systemd.enable`"; } { - assertion = (!config.system.etc.overlay.mutable) -> (config.systemd.sysusers.enable || config.services.userborn.enable); + assertion = + (!config.system.etc.overlay.mutable) + -> (config.systemd.sysusers.enable || config.services.userborn.enable); message = "`!system.etc.overlay.mutable` requires `systemd.sysusers.enable` or `services.userborn.enable`"; } { @@ -28,7 +37,11 @@ } ]; - boot.initrd.availableKernelModules = [ "loop" "erofs" "overlay" ]; + boot.initrd.availableKernelModules = [ + "loop" + "erofs" + "overlay" + ]; boot.initrd.systemd = { mounts = [ @@ -63,30 +76,38 @@ where = "/sysroot/etc"; what = "overlay"; type = "overlay"; - options = lib.concatStringsSep "," ([ - "relatime" - "redirect_dir=on" - "metacopy=on" - "lowerdir=/run/etc-metadata::/etc-basedir" - ] ++ lib.optionals config.system.etc.overlay.mutable [ - "rw" - "upperdir=/sysroot/.rw-etc/upper" - "workdir=/sysroot/.rw-etc/work" - ] ++ lib.optionals (!config.system.etc.overlay.mutable) [ - "ro" - ]); + options = lib.concatStringsSep "," ( + [ + "relatime" + "redirect_dir=on" + "metacopy=on" + "lowerdir=/run/etc-metadata::/etc-basedir" + ] + ++ lib.optionals config.system.etc.overlay.mutable [ + "rw" + "upperdir=/sysroot/.rw-etc/upper" + "workdir=/sysroot/.rw-etc/work" + ] + ++ lib.optionals (!config.system.etc.overlay.mutable) [ + "ro" + ] + ); requiredBy = [ "initrd-fs.target" ]; before = [ "initrd-fs.target" ]; - requires = [ - config.boot.initrd.systemd.services.initrd-find-etc.name - ] ++ lib.optionals config.system.etc.overlay.mutable [ - config.boot.initrd.systemd.services."rw-etc".name - ]; - after = [ - config.boot.initrd.systemd.services.initrd-find-etc.name - ] ++ lib.optionals config.system.etc.overlay.mutable [ - config.boot.initrd.systemd.services."rw-etc".name - ]; + requires = + [ + config.boot.initrd.systemd.services.initrd-find-etc.name + ] + ++ lib.optionals config.system.etc.overlay.mutable [ + config.boot.initrd.systemd.services."rw-etc".name + ]; + after = + [ + config.boot.initrd.systemd.services.initrd-find-etc.name + ] + ++ lib.optionals config.system.etc.overlay.mutable [ + config.boot.initrd.systemd.services."rw-etc".name + ]; unitConfig = { RequiresMountsFor = [ "/sysroot/nix/store" @@ -134,17 +155,18 @@ RemainAfterExit = true; }; - script = /* bash */ '' - set -uo pipefail + script = # bash + '' + set -uo pipefail - closure="$(realpath /nixos-closure)" + closure="$(realpath /nixos-closure)" - metadata_image="$(${pkgs.chroot-realpath}/bin/chroot-realpath /sysroot "$closure/etc-metadata-image")" - ln -s "/sysroot$metadata_image" /etc-metadata-image + metadata_image="$(${pkgs.chroot-realpath}/bin/chroot-realpath /sysroot "$closure/etc-metadata-image")" + ln -s "/sysroot$metadata_image" /etc-metadata-image - basedir="$(${pkgs.chroot-realpath}/bin/chroot-realpath /sysroot "$closure/etc-basedir")" - ln -s "/sysroot$basedir" /etc-basedir - ''; + basedir="$(${pkgs.chroot-realpath}/bin/chroot-realpath /sysroot "$closure/etc-basedir")" + ln -s "/sysroot$basedir" /etc-basedir + ''; }; } ]; diff --git a/nixos/modules/system/etc/etc.nix b/nixos/modules/system/etc/etc.nix index 0b5e65255a519d..5f2acd7bacb986 100644 --- a/nixos/modules/system/etc/etc.nix +++ b/nixos/modules/system/etc/etc.nix @@ -1,62 +1,73 @@ # Management of static files in /etc. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let etc' = lib.filter (f: f.enable) (lib.attrValues config.environment.etc); - etc = pkgs.runCommandLocal "etc" { - # This is needed for the systemd module - passthru.targets = map (x: x.target) etc'; - } /* sh */ '' - set -euo pipefail - - makeEtcEntry() { - src="$1" - target="$2" - mode="$3" - user="$4" - group="$5" - - if [[ "$src" = *'*'* ]]; then - # If the source name contains '*', perform globbing. - mkdir -p "$out/etc/$target" - for fn in $src; do - ln -s "$fn" "$out/etc/$target/" - done - else + etc = + pkgs.runCommandLocal "etc" + { + # This is needed for the systemd module + passthru.targets = map (x: x.target) etc'; + } # sh + '' + set -euo pipefail + + makeEtcEntry() { + src="$1" + target="$2" + mode="$3" + user="$4" + group="$5" + + if [[ "$src" = *'*'* ]]; then + # If the source name contains '*', perform globbing. + mkdir -p "$out/etc/$target" + for fn in $src; do + ln -s "$fn" "$out/etc/$target/" + done + else + + mkdir -p "$out/etc/$(dirname "$target")" + if ! [ -e "$out/etc/$target" ]; then + ln -s "$src" "$out/etc/$target" + else + echo "duplicate entry $target -> $src" + if [ "$(readlink "$out/etc/$target")" != "$src" ]; then + echo "mismatched duplicate entry $(readlink "$out/etc/$target") <-> $src" + ret=1 - mkdir -p "$out/etc/$(dirname "$target")" - if ! [ -e "$out/etc/$target" ]; then - ln -s "$src" "$out/etc/$target" - else - echo "duplicate entry $target -> $src" - if [ "$(readlink "$out/etc/$target")" != "$src" ]; then - echo "mismatched duplicate entry $(readlink "$out/etc/$target") <-> $src" - ret=1 + continue + fi + fi - continue + if [ "$mode" != symlink ]; then + echo "$mode" > "$out/etc/$target.mode" + echo "$user" > "$out/etc/$target.uid" + echo "$group" > "$out/etc/$target.gid" + fi fi - fi - - if [ "$mode" != symlink ]; then - echo "$mode" > "$out/etc/$target.mode" - echo "$user" > "$out/etc/$target.uid" - echo "$group" > "$out/etc/$target.gid" - fi - fi - } - - mkdir -p "$out/etc" - ${lib.concatMapStringsSep "\n" (etcEntry: lib.escapeShellArgs [ - "makeEtcEntry" - # Force local source paths to be added to the store - "${etcEntry.source}" - etcEntry.target - etcEntry.mode - etcEntry.user - etcEntry.group - ]) etc'} - ''; + } + + mkdir -p "$out/etc" + ${lib.concatMapStringsSep "\n" ( + etcEntry: + lib.escapeShellArgs [ + "makeEtcEntry" + # Force local source paths to be added to the store + "${etcEntry.source}" + etcEntry.target + etcEntry.mode + etcEntry.user + etcEntry.group + ] + ) etc'} + ''; etcHardlinks = lib.filter (f: f.mode != "symlink" && f.mode != "direct-symlink") etc'; @@ -95,7 +106,7 @@ in }; environment.etc = lib.mkOption { - default = {}; + default = { }; example = lib.literalExpression '' { example-configuration-file = { source = "/nix/store/.../etc/dir/file.conf.example"; @@ -108,196 +119,220 @@ in Set of files that have to be linked in {file}`/etc`. ''; - type = with lib.types; attrsOf (submodule ( - { name, config, options, ... }: - { options = { - - enable = lib.mkOption { - type = lib.types.bool; - default = true; - description = '' - Whether this /etc file should be generated. This - option allows specific /etc files to be disabled. - ''; - }; - - target = lib.mkOption { - type = lib.types.str; - description = '' - Name of symlink (relative to - {file}`/etc`). Defaults to the attribute - name. - ''; - }; - - text = lib.mkOption { - default = null; - type = lib.types.nullOr lib.types.lines; - description = "Text of the file."; - }; - - source = lib.mkOption { - type = lib.types.path; - description = "Path of the source file."; - }; - - mode = lib.mkOption { - type = lib.types.str; - default = "symlink"; - example = "0600"; - description = '' - If set to something else than `symlink`, - the file is copied instead of symlinked, with the given - file mode. - ''; - }; - - uid = lib.mkOption { - default = 0; - type = lib.types.int; - description = '' - UID of created file. Only takes effect when the file is - copied (that is, the mode is not 'symlink'). - ''; - }; - - gid = lib.mkOption { - default = 0; - type = lib.types.int; - description = '' - GID of created file. Only takes effect when the file is - copied (that is, the mode is not 'symlink'). - ''; - }; - - user = lib.mkOption { - default = "+${toString config.uid}"; - type = lib.types.str; - description = '' - User name of created file. - Only takes effect when the file is copied (that is, the mode is not 'symlink'). - Changing this option takes precedence over `uid`. - ''; - }; - - group = lib.mkOption { - default = "+${toString config.gid}"; - type = lib.types.str; - description = '' - Group name of created file. - Only takes effect when the file is copied (that is, the mode is not 'symlink'). - Changing this option takes precedence over `gid`. - ''; - }; - - }; - - config = { - target = lib.mkDefault name; - source = lib.mkIf (config.text != null) ( - let name' = "etc-" + lib.replaceStrings ["/"] ["-"] name; - in lib.mkDerivedConfig options.text (pkgs.writeText name') - ); - }; - - })); + type = + with lib.types; + attrsOf ( + submodule ( + { + name, + config, + options, + ... + }: + { + options = { + + enable = lib.mkOption { + type = lib.types.bool; + default = true; + description = '' + Whether this /etc file should be generated. This + option allows specific /etc files to be disabled. + ''; + }; + + target = lib.mkOption { + type = lib.types.str; + description = '' + Name of symlink (relative to + {file}`/etc`). Defaults to the attribute + name. + ''; + }; + + text = lib.mkOption { + default = null; + type = lib.types.nullOr lib.types.lines; + description = "Text of the file."; + }; + + source = lib.mkOption { + type = lib.types.path; + description = "Path of the source file."; + }; + + mode = lib.mkOption { + type = lib.types.str; + default = "symlink"; + example = "0600"; + description = '' + If set to something else than `symlink`, + the file is copied instead of symlinked, with the given + file mode. + ''; + }; + + uid = lib.mkOption { + default = 0; + type = lib.types.int; + description = '' + UID of created file. Only takes effect when the file is + copied (that is, the mode is not 'symlink'). + ''; + }; + + gid = lib.mkOption { + default = 0; + type = lib.types.int; + description = '' + GID of created file. Only takes effect when the file is + copied (that is, the mode is not 'symlink'). + ''; + }; + + user = lib.mkOption { + default = "+${toString config.uid}"; + type = lib.types.str; + description = '' + User name of created file. + Only takes effect when the file is copied (that is, the mode is not 'symlink'). + Changing this option takes precedence over `uid`. + ''; + }; + + group = lib.mkOption { + default = "+${toString config.gid}"; + type = lib.types.str; + description = '' + Group name of created file. + Only takes effect when the file is copied (that is, the mode is not 'symlink'). + Changing this option takes precedence over `gid`. + ''; + }; + + }; + + config = { + target = lib.mkDefault name; + source = lib.mkIf (config.text != null) ( + let + name' = "etc-" + lib.replaceStrings [ "/" ] [ "-" ] name; + in + lib.mkDerivedConfig options.text (pkgs.writeText name') + ); + }; + + } + ) + ); }; }; - ###### implementation config = { system.build.etc = etc; - system.build.etcActivationCommands = let - etcOverlayOptions = lib.concatStringsSep "," ([ - "relatime" - "redirect_dir=on" - "metacopy=on" - ] ++ lib.optionals config.system.etc.overlay.mutable [ - "upperdir=/.rw-etc/upper" - "workdir=/.rw-etc/work" - ]); - in if config.system.etc.overlay.enable then '' - # This script atomically remounts /etc when switching configuration. On a (re-)boot - # this should not run because /etc is mounted via a systemd mount unit - # instead. To a large extent this mimics what composefs does. Because - # it's relatively simple, however, we avoid the composefs dependency. - # Since this script is not idempotent, it should not run when etc hasn't - # changed. - if [[ ! $IN_NIXOS_SYSTEMD_STAGE1 ]] && [[ "${config.system.build.etc}/etc" != "$(readlink -f /run/current-system/etc)" ]]; then - echo "remounting /etc..." - - tmpMetadataMount=$(mktemp --directory -t nixos-etc-metadata.XXXXXXXXXX) - mount --type erofs -o ro ${config.system.build.etcMetadataImage} $tmpMetadataMount - - # Mount the new /etc overlay to a temporary private mount. - # This needs the indirection via a private bind mount because you - # cannot move shared mounts. - tmpEtcMount=$(mktemp --directory -t nixos-etc.XXXXXXXXXX) - mount --bind --make-private $tmpEtcMount $tmpEtcMount - mount --type overlay overlay \ - --options lowerdir=$tmpMetadataMount::${config.system.build.etcBasedir},${etcOverlayOptions} \ - $tmpEtcMount - - # Before moving the new /etc overlay under the old /etc, we have to - # move mounts on top of /etc to the new /etc mountpoint. - findmnt /etc --submounts --list --noheading --kernel --output TARGET | while read -r mountPoint; do - if [[ "$mountPoint" = "/etc" ]]; then - continue - fi - - tmpMountPoint="$tmpEtcMount/''${mountPoint:5}" - ${if config.system.etc.overlay.mutable then '' - if [[ -f "$mountPoint" ]]; then - touch "$tmpMountPoint" - elif [[ -d "$mountPoint" ]]; then - mkdir -p "$tmpMountPoint" - fi - '' else '' - if [[ ! -e "$tmpMountPoint" ]]; then - echo "Skipping undeclared mountpoint in environment.etc: $mountPoint" + system.build.etcActivationCommands = + let + etcOverlayOptions = lib.concatStringsSep "," ( + [ + "relatime" + "redirect_dir=on" + "metacopy=on" + ] + ++ lib.optionals config.system.etc.overlay.mutable [ + "upperdir=/.rw-etc/upper" + "workdir=/.rw-etc/work" + ] + ); + in + if config.system.etc.overlay.enable then + '' + # This script atomically remounts /etc when switching configuration. On a (re-)boot + # this should not run because /etc is mounted via a systemd mount unit + # instead. To a large extent this mimics what composefs does. Because + # it's relatively simple, however, we avoid the composefs dependency. + # Since this script is not idempotent, it should not run when etc hasn't + # changed. + if [[ ! $IN_NIXOS_SYSTEMD_STAGE1 ]] && [[ "${config.system.build.etc}/etc" != "$(readlink -f /run/current-system/etc)" ]]; then + echo "remounting /etc..." + + tmpMetadataMount=$(mktemp --directory -t nixos-etc-metadata.XXXXXXXXXX) + mount --type erofs -o ro ${config.system.build.etcMetadataImage} $tmpMetadataMount + + # Mount the new /etc overlay to a temporary private mount. + # This needs the indirection via a private bind mount because you + # cannot move shared mounts. + tmpEtcMount=$(mktemp --directory -t nixos-etc.XXXXXXXXXX) + mount --bind --make-private $tmpEtcMount $tmpEtcMount + mount --type overlay overlay \ + --options lowerdir=$tmpMetadataMount::${config.system.build.etcBasedir},${etcOverlayOptions} \ + $tmpEtcMount + + # Before moving the new /etc overlay under the old /etc, we have to + # move mounts on top of /etc to the new /etc mountpoint. + findmnt /etc --submounts --list --noheading --kernel --output TARGET | while read -r mountPoint; do + if [[ "$mountPoint" = "/etc" ]]; then continue fi - '' - } - mount --bind "$mountPoint" "$tmpMountPoint" - done - - # Move the new temporary /etc mount underneath the current /etc mount. - # - # This should eventually use util-linux to perform this move beneath, - # however, this functionality is not yet in util-linux. See this - # tracking issue: https://github.com/util-linux/util-linux/issues/2604 - ${pkgs.move-mount-beneath}/bin/move-mount --move --beneath $tmpEtcMount /etc - - # Unmount the top /etc mount to atomically reveal the new mount. - umount --lazy --recursive /etc - - # Unmount the temporary mount - umount --lazy "$tmpEtcMount" - rmdir "$tmpEtcMount" - - # Unmount old metadata mounts - # For some reason, `findmnt /tmp --submounts` does not show the nested - # mounts. So we'll just find all mounts of type erofs and filter on the - # name of the mountpoint. - findmnt --type erofs --list --kernel --output TARGET | while read -r mountPoint; do - if [[ "$mountPoint" =~ ^/tmp/nixos-etc-metadata\..{10}$ && - "$mountPoint" != "$tmpMetadataMount" ]]; then - umount --lazy $mountPoint - rmdir "$mountPoint" + + tmpMountPoint="$tmpEtcMount/''${mountPoint:5}" + ${ + if config.system.etc.overlay.mutable then + '' + if [[ -f "$mountPoint" ]]; then + touch "$tmpMountPoint" + elif [[ -d "$mountPoint" ]]; then + mkdir -p "$tmpMountPoint" + fi + '' + else + '' + if [[ ! -e "$tmpMountPoint" ]]; then + echo "Skipping undeclared mountpoint in environment.etc: $mountPoint" + continue + fi + '' + } + mount --bind "$mountPoint" "$tmpMountPoint" + done + + # Move the new temporary /etc mount underneath the current /etc mount. + # + # This should eventually use util-linux to perform this move beneath, + # however, this functionality is not yet in util-linux. See this + # tracking issue: https://github.com/util-linux/util-linux/issues/2604 + ${pkgs.move-mount-beneath}/bin/move-mount --move --beneath $tmpEtcMount /etc + + # Unmount the top /etc mount to atomically reveal the new mount. + umount --lazy --recursive /etc + + # Unmount the temporary mount + umount --lazy "$tmpEtcMount" + rmdir "$tmpEtcMount" + + # Unmount old metadata mounts + # For some reason, `findmnt /tmp --submounts` does not show the nested + # mounts. So we'll just find all mounts of type erofs and filter on the + # name of the mountpoint. + findmnt --type erofs --list --kernel --output TARGET | while read -r mountPoint; do + if [[ "$mountPoint" =~ ^/tmp/nixos-etc-metadata\..{10}$ && + "$mountPoint" != "$tmpMetadataMount" ]]; then + umount --lazy $mountPoint + rmdir "$mountPoint" + fi + done fi - done - fi - '' else '' - # Set up the statically computed bits of /etc. - echo "setting up /etc..." - ${pkgs.perl.withPackages (p: [ p.FileSlurp ])}/bin/perl ${./setup-etc.pl} ${etc}/etc - ''; + '' + else + '' + # Set up the statically computed bits of /etc. + echo "setting up /etc..." + ${pkgs.perl.withPackages (p: [ p.FileSlurp ])}/bin/perl ${./setup-etc.pl} ${etc}/etc + ''; system.build.etcBasedir = pkgs.runCommandLocal "etc-lowerdir" { } '' set -euo pipefail @@ -311,12 +346,15 @@ in } mkdir -p "$out" - ${lib.concatMapStringsSep "\n" (etcEntry: lib.escapeShellArgs [ - "makeEtcEntry" - # Force local source paths to be added to the store - "${etcEntry.source}" - etcEntry.target - ]) etcHardlinks} + ${lib.concatMapStringsSep "\n" ( + etcEntry: + lib.escapeShellArgs [ + "makeEtcEntry" + # Force local source paths to be added to the store + "${etcEntry.source}" + etcEntry.target + ] + ) etcHardlinks} ''; system.build.etcMetadataImage = @@ -326,12 +364,17 @@ in ${lib.getExe pkgs.buildPackages.python3} ${./build-composefs-dump.py} ${etcJson} > $out ''; in - pkgs.runCommand "etc-metadata.erofs" { - nativeBuildInputs = with pkgs.buildPackages; [ composefs erofs-utils ]; - } '' - mkcomposefs --from-file ${etcDump} $out - fsck.erofs $out - ''; + pkgs.runCommand "etc-metadata.erofs" + { + nativeBuildInputs = with pkgs.buildPackages; [ + composefs + erofs-utils + ]; + } + '' + mkcomposefs --from-file ${etcDump} $out + fsck.erofs $out + ''; }; diff --git a/nixos/modules/tasks/bcache.nix b/nixos/modules/tasks/bcache.nix index d2c816d663f941..1405899c787bfd 100644 --- a/nixos/modules/tasks/bcache.nix +++ b/nixos/modules/tasks/bcache.nix @@ -1,6 +1,13 @@ -{ config, lib, pkgs, ... }: let +{ + config, + lib, + pkgs, + ... +}: +let cfg = config.boot.bcache; -in { +in +{ options.boot.bcache.enable = lib.mkEnableOption "bcache mount support" // { default = true; example = false; diff --git a/nixos/modules/tasks/cpu-freq.nix b/nixos/modules/tasks/cpu-freq.nix index f1219c07c50131..34be5c3fc61525 100644 --- a/nixos/modules/tasks/cpu-freq.nix +++ b/nixos/modules/tasks/cpu-freq.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -51,7 +56,6 @@ in }; - ###### implementation config = @@ -59,9 +63,7 @@ in governorEnable = cfg.cpuFreqGovernor != null; maxEnable = cfg.cpufreq.max != null; minEnable = cfg.cpufreq.min != null; - enable = - !config.boot.isContainer && - (governorEnable || maxEnable || minEnable); + enable = !config.boot.isContainer && (governorEnable || maxEnable || minEnable); in mkIf enable { @@ -73,18 +75,22 @@ in description = "CPU Frequency Setup"; after = [ "systemd-modules-load.service" ]; wantedBy = [ "multi-user.target" ]; - path = [ cpupower pkgs.kmod ]; + path = [ + cpupower + pkgs.kmod + ]; unitConfig.ConditionVirtualization = false; serviceConfig = { Type = "oneshot"; RemainAfterExit = "yes"; - ExecStart = "${cpupower}/bin/cpupower frequency-set " + - optionalString governorEnable "--governor ${cfg.cpuFreqGovernor} " + - optionalString maxEnable "--max ${toString cfg.cpufreq.max} " + - optionalString minEnable "--min ${toString cfg.cpufreq.min} "; + ExecStart = + "${cpupower}/bin/cpupower frequency-set " + + optionalString governorEnable "--governor ${cfg.cpuFreqGovernor} " + + optionalString maxEnable "--max ${toString cfg.cpufreq.max} " + + optionalString minEnable "--min ${toString cfg.cpufreq.min} "; SuccessExitStatus = "0 237"; }; }; - }; + }; } diff --git a/nixos/modules/tasks/filesystems/apfs.nix b/nixos/modules/tasks/filesystems/apfs.nix index 980a3ad0f9c4b0..e5cb6e62e9fbb1 100644 --- a/nixos/modules/tasks/filesystems/apfs.nix +++ b/nixos/modules/tasks/filesystems/apfs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/tasks/filesystems/btrfs.nix b/nixos/modules/tasks/filesystems/btrfs.nix index 7329a798133790..f4b7455822f020 100644 --- a/nixos/modules/tasks/filesystems/btrfs.nix +++ b/nixos/modules/tasks/filesystems/btrfs.nix @@ -1,4 +1,10 @@ -{ config, lib, pkgs, utils, ... }: +{ + config, + lib, + pkgs, + utils, + ... +}: let inherit (lib) @@ -13,7 +19,8 @@ let listToAttrs filterAttrs mapAttrsToList - foldl'; + foldl' + ; inInitrd = config.boot.initrd.supportedFilesystems.btrfs or false; inSystem = config.boot.supportedFilesystems.btrfs or false; @@ -77,20 +84,17 @@ in "sha256_generic" # Should be baked into our kernel, just to be sure ]; - boot.initrd.extraUtilsCommands = mkIf (!config.boot.initrd.systemd.enable) - '' + boot.initrd.extraUtilsCommands = mkIf (!config.boot.initrd.systemd.enable) '' copy_bin_and_libs ${pkgs.btrfs-progs}/bin/btrfs ln -sv btrfs $out/bin/btrfsck ln -sv btrfsck $out/bin/fsck.btrfs ''; - boot.initrd.extraUtilsCommandsTest = mkIf (!config.boot.initrd.systemd.enable) - '' + boot.initrd.extraUtilsCommandsTest = mkIf (!config.boot.initrd.systemd.enable) '' $out/bin/btrfs --version ''; - boot.initrd.postDeviceCommands = mkIf (!config.boot.initrd.systemd.enable) - '' + boot.initrd.postDeviceCommands = mkIf (!config.boot.initrd.systemd.enable) '' btrfs device scan ''; @@ -100,7 +104,7 @@ in (mkIf enableAutoScrub { assertions = [ { - assertion = cfgScrub.enable -> (cfgScrub.fileSystems != []); + assertion = cfgScrub.enable -> (cfgScrub.fileSystems != [ ]); message = '' If 'services.btrfs.autoScrub' is enabled, you need to have at least one btrfs file system mounted via 'fileSystems' or specify a list manually @@ -113,56 +117,79 @@ in # time, or additionally mounted subvolumes, as well as having a filesystem span # multiple devices (provided the same device is used to mount said filesystem). services.btrfs.autoScrub.fileSystems = - let - isDeviceInList = list: device: builtins.filter (e: e.device == device) list != [ ]; - - uniqueDeviceList = foldl' (acc: e: if isDeviceInList acc e.device then acc else acc ++ [ e ]) [ ]; - in - mkDefault (map (e: e.mountPoint) - (uniqueDeviceList (mapAttrsToList (name: fs: { mountPoint = fs.mountPoint; device = fs.device; }) - (filterAttrs (name: fs: fs.fsType == "btrfs") config.fileSystems)))); + let + isDeviceInList = list: device: builtins.filter (e: e.device == device) list != [ ]; + + uniqueDeviceList = foldl' (acc: e: if isDeviceInList acc e.device then acc else acc ++ [ e ]) [ ]; + in + mkDefault ( + map (e: e.mountPoint) ( + uniqueDeviceList ( + mapAttrsToList (name: fs: { + mountPoint = fs.mountPoint; + device = fs.device; + }) (filterAttrs (name: fs: fs.fsType == "btrfs") config.fileSystems) + ) + ) + ); # TODO: Did not manage to do it via the usual btrfs-scrub@.timer/.service # template units due to problems enabling the parameterized units, # so settled with many units and templating via nix for now. # https://github.com/NixOS/nixpkgs/pull/32496#discussion_r156527544 - systemd.timers = let - scrubTimer = fs: let - fs' = utils.escapeSystemdPath fs; - in nameValuePair "btrfs-scrub-${fs'}" { - description = "regular btrfs scrub timer on ${fs}"; - - wantedBy = [ "timers.target" ]; - timerConfig = { - OnCalendar = cfgScrub.interval; - AccuracySec = "1d"; - Persistent = true; - }; - }; - in listToAttrs (map scrubTimer cfgScrub.fileSystems); - - systemd.services = let - scrubService = fs: let - fs' = utils.escapeSystemdPath fs; - in nameValuePair "btrfs-scrub-${fs'}" { - description = "btrfs scrub on ${fs}"; - # scrub prevents suspend2ram or proper shutdown - conflicts = [ "shutdown.target" "sleep.target" ]; - before = [ "shutdown.target" "sleep.target" ]; - - serviceConfig = { - # simple and not oneshot, otherwise ExecStop is not used - Type = "simple"; - Nice = 19; - IOSchedulingClass = "idle"; - ExecStart = "${pkgs.btrfs-progs}/bin/btrfs scrub start -B ${fs}"; - # if the service is stopped before scrub end, cancel it - ExecStop = pkgs.writeShellScript "btrfs-scrub-maybe-cancel" '' - (${pkgs.btrfs-progs}/bin/btrfs scrub status ${fs} | ${pkgs.gnugrep}/bin/grep finished) || ${pkgs.btrfs-progs}/bin/btrfs scrub cancel ${fs} - ''; - }; - }; - in listToAttrs (map scrubService cfgScrub.fileSystems); + systemd.timers = + let + scrubTimer = + fs: + let + fs' = utils.escapeSystemdPath fs; + in + nameValuePair "btrfs-scrub-${fs'}" { + description = "regular btrfs scrub timer on ${fs}"; + + wantedBy = [ "timers.target" ]; + timerConfig = { + OnCalendar = cfgScrub.interval; + AccuracySec = "1d"; + Persistent = true; + }; + }; + in + listToAttrs (map scrubTimer cfgScrub.fileSystems); + + systemd.services = + let + scrubService = + fs: + let + fs' = utils.escapeSystemdPath fs; + in + nameValuePair "btrfs-scrub-${fs'}" { + description = "btrfs scrub on ${fs}"; + # scrub prevents suspend2ram or proper shutdown + conflicts = [ + "shutdown.target" + "sleep.target" + ]; + before = [ + "shutdown.target" + "sleep.target" + ]; + + serviceConfig = { + # simple and not oneshot, otherwise ExecStop is not used + Type = "simple"; + Nice = 19; + IOSchedulingClass = "idle"; + ExecStart = "${pkgs.btrfs-progs}/bin/btrfs scrub start -B ${fs}"; + # if the service is stopped before scrub end, cancel it + ExecStop = pkgs.writeShellScript "btrfs-scrub-maybe-cancel" '' + (${pkgs.btrfs-progs}/bin/btrfs scrub status ${fs} | ${pkgs.gnugrep}/bin/grep finished) || ${pkgs.btrfs-progs}/bin/btrfs scrub cancel ${fs} + ''; + }; + }; + in + listToAttrs (map scrubService cfgScrub.fileSystems); }) ]; } diff --git a/nixos/modules/tasks/filesystems/cifs.nix b/nixos/modules/tasks/filesystems/cifs.nix index 5a562b2940f7dc..17acabf0f156ab 100644 --- a/nixos/modules/tasks/filesystems/cifs.nix +++ b/nixos/modules/tasks/filesystems/cifs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -13,13 +18,19 @@ in system.fsPackages = mkIf (config.boot.supportedFilesystems.cifs or false) [ pkgs.cifs-utils ]; - boot.initrd.availableKernelModules = mkIf inInitrd - [ "cifs" "nls_utf8" "hmac" "md4" "ecb" "des_generic" "sha256" ]; - - boot.initrd.extraUtilsCommands = mkIf (inInitrd && !config.boot.initrd.systemd.enable) - '' - copy_bin_and_libs ${pkgs.cifs-utils}/sbin/mount.cifs - ''; + boot.initrd.availableKernelModules = mkIf inInitrd [ + "cifs" + "nls_utf8" + "hmac" + "md4" + "ecb" + "des_generic" + "sha256" + ]; + + boot.initrd.extraUtilsCommands = mkIf (inInitrd && !config.boot.initrd.systemd.enable) '' + copy_bin_and_libs ${pkgs.cifs-utils}/sbin/mount.cifs + ''; boot.initrd.systemd.extraBin."mount.cifs" = mkIf inInitrd "${pkgs.cifs-utils}/sbin/mount.cifs"; diff --git a/nixos/modules/tasks/filesystems/ecryptfs.nix b/nixos/modules/tasks/filesystems/ecryptfs.nix index f966a1be153607..8b489d65d84317 100644 --- a/nixos/modules/tasks/filesystems/ecryptfs.nix +++ b/nixos/modules/tasks/filesystems/ecryptfs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: # TODO: make ecryptfs work in initramfs? with lib; @@ -7,18 +12,18 @@ with lib; config = mkIf (config.boot.supportedFilesystems.ecryptfs or false) { system.fsPackages = [ pkgs.ecryptfs ]; security.wrappers = { - "mount.ecryptfs_private" = - { setuid = true; - owner = "root"; - group = "root"; - source = "${pkgs.ecryptfs.out}/bin/mount.ecryptfs_private"; - }; - "umount.ecryptfs_private" = - { setuid = true; - owner = "root"; - group = "root"; - source = "${pkgs.ecryptfs.out}/bin/umount.ecryptfs_private"; - }; + "mount.ecryptfs_private" = { + setuid = true; + owner = "root"; + group = "root"; + source = "${pkgs.ecryptfs.out}/bin/mount.ecryptfs_private"; + }; + "umount.ecryptfs_private" = { + setuid = true; + owner = "root"; + group = "root"; + source = "${pkgs.ecryptfs.out}/bin/umount.ecryptfs_private"; + }; }; }; } diff --git a/nixos/modules/tasks/filesystems/envfs.nix b/nixos/modules/tasks/filesystems/envfs.nix index e67e6eeed9d103..1e821277b6144f 100644 --- a/nixos/modules/tasks/filesystems/envfs.nix +++ b/nixos/modules/tasks/filesystems/envfs.nix @@ -1,4 +1,9 @@ -{ pkgs, config, lib, ... }: +{ + pkgs, + config, + lib, + ... +}: let cfg = config.services.envfs; @@ -8,11 +13,16 @@ let fsType = "envfs"; options = [ "bind-mount=/bin" - "fallback-path=${pkgs.runCommand "fallback-path" {} ('' - mkdir -p $out - ln -s ${config.environment.usrbinenv} $out/env - ln -s ${config.environment.binsh} $out/sh - '' + cfg.extraFallbackPathCommands)}" + "fallback-path=${ + pkgs.runCommand "fallback-path" { } ( + '' + mkdir -p $out + ln -s ${config.environment.usrbinenv} $out/env + ln -s ${config.environment.binsh} $out/sh + '' + + cfg.extraFallbackPathCommands + ) + }" "nofail" ]; }; @@ -22,10 +32,14 @@ let "/bin" = { device = "/usr/bin"; fsType = "none"; - options = [ "bind" "nofail" ]; + options = [ + "bind" + "nofail" + ]; }; }; -in { +in +{ options = { services.envfs = { enable = lib.mkEnableOption "Envfs filesystem" // { diff --git a/nixos/modules/tasks/filesystems/erofs.nix b/nixos/modules/tasks/filesystems/erofs.nix index b13fa253155792..3aabfbf66e5427 100644 --- a/nixos/modules/tasks/filesystems/erofs.nix +++ b/nixos/modules/tasks/filesystems/erofs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let diff --git a/nixos/modules/tasks/filesystems/exfat.nix b/nixos/modules/tasks/filesystems/exfat.nix index 4011653c00df11..9b013c8e9b8564 100644 --- a/nixos/modules/tasks/filesystems/exfat.nix +++ b/nixos/modules/tasks/filesystems/exfat.nix @@ -1,13 +1,22 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; { config = mkIf (config.boot.supportedFilesystems.exfat or false) { - system.fsPackages = if config.boot.kernelPackages.kernelOlder "5.7" then [ - pkgs.exfat # FUSE - ] else [ - pkgs.exfatprogs # non-FUSE - ]; + system.fsPackages = + if config.boot.kernelPackages.kernelOlder "5.7" then + [ + pkgs.exfat # FUSE + ] + else + [ + pkgs.exfatprogs # non-FUSE + ]; }; } diff --git a/nixos/modules/tasks/filesystems/ext.nix b/nixos/modules/tasks/filesystems/ext.nix index 165fe9474c3e8d..883df9e5b379f5 100644 --- a/nixos/modules/tasks/filesystems/ext.nix +++ b/nixos/modules/tasks/filesystems/ext.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let @@ -12,20 +17,24 @@ in { config = { - system.fsPackages = lib.mkIf (config.boot.initrd.systemd.enable -> (inInitrd || inSystem)) [ pkgs.e2fsprogs ]; + system.fsPackages = lib.mkIf (config.boot.initrd.systemd.enable -> (inInitrd || inSystem)) [ + pkgs.e2fsprogs + ]; # As of kernel 4.3, there is no separate ext3 driver (they're also handled by ext4.ko) - boot.initrd.availableKernelModules = lib.mkIf (config.boot.initrd.systemd.enable -> inInitrd) [ "ext2" "ext4" ]; - - boot.initrd.extraUtilsCommands = lib.mkIf (!config.boot.initrd.systemd.enable) - '' - # Copy e2fsck and friends. - copy_bin_and_libs ${pkgs.e2fsprogs}/sbin/e2fsck - copy_bin_and_libs ${pkgs.e2fsprogs}/sbin/tune2fs - ln -sv e2fsck $out/bin/fsck.ext2 - ln -sv e2fsck $out/bin/fsck.ext3 - ln -sv e2fsck $out/bin/fsck.ext4 - ''; + boot.initrd.availableKernelModules = lib.mkIf (config.boot.initrd.systemd.enable -> inInitrd) [ + "ext2" + "ext4" + ]; + + boot.initrd.extraUtilsCommands = lib.mkIf (!config.boot.initrd.systemd.enable) '' + # Copy e2fsck and friends. + copy_bin_and_libs ${pkgs.e2fsprogs}/sbin/e2fsck + copy_bin_and_libs ${pkgs.e2fsprogs}/sbin/tune2fs + ln -sv e2fsck $out/bin/fsck.ext2 + ln -sv e2fsck $out/bin/fsck.ext3 + ln -sv e2fsck $out/bin/fsck.ext4 + ''; boot.initrd.systemd.initrdBin = lib.mkIf inInitrd [ pkgs.e2fsprogs ]; diff --git a/nixos/modules/tasks/filesystems/f2fs.nix b/nixos/modules/tasks/filesystems/f2fs.nix index f4f5fcab9caeff..4c38cacefdc8b1 100644 --- a/nixos/modules/tasks/filesystems/f2fs.nix +++ b/nixos/modules/tasks/filesystems/f2fs.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; @@ -10,7 +15,10 @@ in system.fsPackages = [ pkgs.f2fs-tools ]; - boot.initrd.availableKernelModules = mkIf inInitrd [ "f2fs" "crc32" ]; + boot.initrd.availableKernelModules = mkIf inInitrd [ + "f2fs" + "crc32" + ]; boot.initrd.extraUtilsCommands = mkIf (inInitrd && !config.boot.initrd.systemd.enable) '' copy_bin_and_libs ${pkgs.f2fs-tools}/sbin/fsck.f2fs diff --git a/nixos/modules/tasks/filesystems/glusterfs.nix b/nixos/modules/tasks/filesystems/glusterfs.nix index 02ef95262dbda0..24998a8a1011aa 100644 --- a/nixos/modules/tasks/filesystems/glusterfs.nix +++ b/nixos/modules/tasks/filesystems/glusterfs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/tasks/filesystems/jfs.nix b/nixos/modules/tasks/filesystems/jfs.nix index 73ddb0fb18bb64..dde1506cfecf10 100644 --- a/nixos/modules/tasks/filesystems/jfs.nix +++ b/nixos/modules/tasks/filesystems/jfs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/tasks/filesystems/nfs.nix b/nixos/modules/tasks/filesystems/nfs.nix index f5e205e26e9466..33b0a8c6324c89 100644 --- a/nixos/modules/tasks/filesystems/nfs.nix +++ b/nixos/modules/tasks/filesystems/nfs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inInitrd = config.boot.initrd.supportedFilesystems.nfs or false; @@ -7,7 +12,7 @@ let rpcMountpoint = "${nfsStateDir}/rpc_pipefs"; - format = pkgs.formats.ini {}; + format = pkgs.formats.ini { }; idmapdConfFile = format.generate "idmapd.conf" cfg.idmapd.settings; @@ -15,40 +20,47 @@ let nfsConfSettings = lib.optionalAttrs (cfg.server.nproc != null) { nfsd.threads = cfg.server.nproc; - } // lib.optionalAttrs (cfg.server.hostName != null) { + } + // lib.optionalAttrs (cfg.server.hostName != null) { nfsd.host = cfg.server.hostName; - } // lib.optionalAttrs (cfg.server.mountdPort != null) { + } + // lib.optionalAttrs (cfg.server.mountdPort != null) { mountd.port = cfg.server.mountdPort; - } // lib.optionalAttrs (cfg.server.statdPort != null) { + } + // lib.optionalAttrs (cfg.server.statdPort != null) { statd.port = cfg.server.statdPort; - } // lib.optionalAttrs (cfg.server.lockdPort != null) { + } + // lib.optionalAttrs (cfg.server.lockdPort != null) { lockd.port = cfg.server.lockdPort; lockd.udp-port = cfg.server.lockdPort; }; - nfsConfDeprecated = cfg.extraConfig + '' - [nfsd] - threads=${toString cfg.server.nproc} - ${lib.optionalString (cfg.server.hostName != null) "host=${cfg.server.hostName}"} - ${cfg.server.extraNfsdConfig} + nfsConfDeprecated = + cfg.extraConfig + + '' + [nfsd] + threads=${toString cfg.server.nproc} + ${lib.optionalString (cfg.server.hostName != null) "host=${cfg.server.hostName}"} + ${cfg.server.extraNfsdConfig} - [mountd] - ${lib.optionalString (cfg.server.mountdPort != null) "port=${toString cfg.server.mountdPort}"} + [mountd] + ${lib.optionalString (cfg.server.mountdPort != null) "port=${toString cfg.server.mountdPort}"} - [statd] - ${lib.optionalString (cfg.server.statdPort != null) "port=${toString cfg.server.statdPort}"} + [statd] + ${lib.optionalString (cfg.server.statdPort != null) "port=${toString cfg.server.statdPort}"} - [lockd] - ${lib.optionalString (cfg.server.lockdPort != null) '' - port=${toString cfg.server.lockdPort} - udp-port=${toString cfg.server.lockdPort} - ''} - ''; + [lockd] + ${lib.optionalString (cfg.server.lockdPort != null) '' + port=${toString cfg.server.lockdPort} + udp-port=${toString cfg.server.lockdPort} + ''} + ''; nfsConfFile = - if cfg.settings != {} - then format.generate "nfs.conf" (lib.recursiveUpdate nfsConfSettings cfg.settings) - else pkgs.writeText "nfs.conf" nfsConfDeprecated; + if cfg.settings != { } then + format.generate "nfs.conf" (lib.recursiveUpdate nfsConfSettings cfg.settings) + else + pkgs.writeText "nfs.conf" nfsConfDeprecated; requestKeyConfFile = pkgs.writeText "request-key.conf" '' create id_resolver * * ${pkgs.nfs-utils}/bin/nfsidmap -t 600 %k %d @@ -65,7 +77,7 @@ in services.nfs = { idmapd.settings = lib.mkOption { type = format.type; - default = {}; + default = { }; description = '' libnfsidmap configuration. Refer to @@ -84,7 +96,7 @@ in }; settings = lib.mkOption { type = format.type; - default = {}; + default = { }; description = '' General configuration for NFS daemons and tools. See nfs.conf(5) and related man pages for details. @@ -107,89 +119,101 @@ in ###### implementation - config = lib.mkIf (config.boot.supportedFilesystems.nfs or config.boot.supportedFilesystems.nfs4 or false) { - - warnings = - (lib.optional (cfg.extraConfig != "") '' - `services.nfs.extraConfig` is deprecated. Use `services.nfs.settings` instead. - '') ++ (lib.optional (cfg.server.extraNfsdConfig != "") '' - `services.nfs.server.extraNfsdConfig` is deprecated. Use `services.nfs.settings` instead. - ''); - assertions = [{ - assertion = cfg.settings != {} -> cfg.extraConfig == "" && cfg.server.extraNfsdConfig == ""; - message = "`services.nfs.settings` cannot be used together with `services.nfs.extraConfig` and `services.nfs.server.extraNfsdConfig`."; - }]; - - services.rpcbind.enable = true; - - services.nfs.idmapd.settings = { - General = lib.mkMerge [ - { Pipefs-Directory = rpcMountpoint; } - (lib.mkIf (config.networking.domain != null) { Domain = config.networking.domain; }) - ]; - Mapping = { - Nobody-User = "nobody"; - Nobody-Group = "nogroup"; - }; - Translation = { - Method = "nsswitch"; - }; - }; - - system.fsPackages = [ pkgs.nfs-utils ]; - - boot.initrd.kernelModules = lib.mkIf inInitrd [ "nfs" ]; - - systemd.packages = [ pkgs.nfs-utils ]; - - environment.systemPackages = [ pkgs.keyutils ]; - - environment.etc = { - "idmapd.conf".source = idmapdConfFile; - "nfs.conf".source = nfsConfFile; - "request-key.conf".source = requestKeyConfFile; - }; - - systemd.services.nfs-blkmap = - { restartTriggers = [ nfsConfFile ]; - }; - - systemd.targets.nfs-client = - { wantedBy = [ "multi-user.target" "remote-fs.target" ]; - }; - - systemd.services.nfs-idmapd = - { restartTriggers = [ idmapdConfFile ]; - }; - - systemd.services.nfs-mountd = - { restartTriggers = [ nfsConfFile ]; - enable = lib.mkDefault false; - }; - - systemd.services.nfs-server = - { restartTriggers = [ nfsConfFile ]; - enable = lib.mkDefault false; - }; - - systemd.services.auth-rpcgss-module = + config = + lib.mkIf (config.boot.supportedFilesystems.nfs or config.boot.supportedFilesystems.nfs4 or false) { - unitConfig.ConditionPathExists = [ "" "/etc/krb5.keytab" ]; - }; - systemd.services.rpc-gssd = - { restartTriggers = [ nfsConfFile ]; - unitConfig.ConditionPathExists = [ "" "/etc/krb5.keytab" ]; - }; - - systemd.services.rpc-statd = - { restartTriggers = [ nfsConfFile ]; - - preStart = - '' + warnings = + (lib.optional (cfg.extraConfig != "") '' + `services.nfs.extraConfig` is deprecated. Use `services.nfs.settings` instead. + '') + ++ (lib.optional (cfg.server.extraNfsdConfig != "") '' + `services.nfs.server.extraNfsdConfig` is deprecated. Use `services.nfs.settings` instead. + ''); + assertions = [ + { + assertion = cfg.settings != { } -> cfg.extraConfig == "" && cfg.server.extraNfsdConfig == ""; + message = "`services.nfs.settings` cannot be used together with `services.nfs.extraConfig` and `services.nfs.server.extraNfsdConfig`."; + } + ]; + + services.rpcbind.enable = true; + + services.nfs.idmapd.settings = { + General = lib.mkMerge [ + { Pipefs-Directory = rpcMountpoint; } + (lib.mkIf (config.networking.domain != null) { Domain = config.networking.domain; }) + ]; + Mapping = { + Nobody-User = "nobody"; + Nobody-Group = "nogroup"; + }; + Translation = { + Method = "nsswitch"; + }; + }; + + system.fsPackages = [ pkgs.nfs-utils ]; + + boot.initrd.kernelModules = lib.mkIf inInitrd [ "nfs" ]; + + systemd.packages = [ pkgs.nfs-utils ]; + + environment.systemPackages = [ pkgs.keyutils ]; + + environment.etc = { + "idmapd.conf".source = idmapdConfFile; + "nfs.conf".source = nfsConfFile; + "request-key.conf".source = requestKeyConfFile; + }; + + systemd.services.nfs-blkmap = { + restartTriggers = [ nfsConfFile ]; + }; + + systemd.targets.nfs-client = { + wantedBy = [ + "multi-user.target" + "remote-fs.target" + ]; + }; + + systemd.services.nfs-idmapd = { + restartTriggers = [ idmapdConfFile ]; + }; + + systemd.services.nfs-mountd = { + restartTriggers = [ nfsConfFile ]; + enable = lib.mkDefault false; + }; + + systemd.services.nfs-server = { + restartTriggers = [ nfsConfFile ]; + enable = lib.mkDefault false; + }; + + systemd.services.auth-rpcgss-module = { + unitConfig.ConditionPathExists = [ + "" + "/etc/krb5.keytab" + ]; + }; + + systemd.services.rpc-gssd = { + restartTriggers = [ nfsConfFile ]; + unitConfig.ConditionPathExists = [ + "" + "/etc/krb5.keytab" + ]; + }; + + systemd.services.rpc-statd = { + restartTriggers = [ nfsConfFile ]; + + preStart = '' mkdir -p /var/lib/nfs/{sm,sm.bak} ''; - }; + }; - }; + }; } diff --git a/nixos/modules/tasks/filesystems/ntfs.nix b/nixos/modules/tasks/filesystems/ntfs.nix index 99ba494a7a39ea..8ec839fed7eb8c 100644 --- a/nixos/modules/tasks/filesystems/ntfs.nix +++ b/nixos/modules/tasks/filesystems/ntfs.nix @@ -1,11 +1,18 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; { - config = mkIf (config.boot.supportedFilesystems.ntfs or config.boot.supportedFilesystems.ntfs-3g or false) { + config = + mkIf (config.boot.supportedFilesystems.ntfs or config.boot.supportedFilesystems.ntfs-3g or false) + { - system.fsPackages = [ pkgs.ntfs3g ]; + system.fsPackages = [ pkgs.ntfs3g ]; - }; + }; } diff --git a/nixos/modules/tasks/filesystems/reiserfs.nix b/nixos/modules/tasks/filesystems/reiserfs.nix index f3f5e6aaa10b9b..6302ff73581645 100644 --- a/nixos/modules/tasks/filesystems/reiserfs.nix +++ b/nixos/modules/tasks/filesystems/reiserfs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -15,11 +20,10 @@ in boot.initrd.kernelModules = mkIf inInitrd [ "reiserfs" ]; - boot.initrd.extraUtilsCommands = mkIf (inInitrd && !config.boot.initrd.systemd.enable) - '' - copy_bin_and_libs ${pkgs.reiserfsprogs}/sbin/reiserfsck - ln -s reiserfsck $out/bin/fsck.reiserfs - ''; + boot.initrd.extraUtilsCommands = mkIf (inInitrd && !config.boot.initrd.systemd.enable) '' + copy_bin_and_libs ${pkgs.reiserfsprogs}/sbin/reiserfsck + ln -s reiserfsck $out/bin/fsck.reiserfs + ''; boot.initrd.systemd.initrdBin = mkIf inInitrd [ pkgs.reiserfsprogs ]; diff --git a/nixos/modules/tasks/filesystems/sshfs.nix b/nixos/modules/tasks/filesystems/sshfs.nix index 63ff7f2b6b399e..f070779ecc54cb 100644 --- a/nixos/modules/tasks/filesystems/sshfs.nix +++ b/nixos/modules/tasks/filesystems/sshfs.nix @@ -1,11 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: { - config = lib.mkIf - (config.boot.supportedFilesystems.sshfs - or config.boot.supportedFilesystems."fuse.sshfs" - or false) - { - system.fsPackages = [ pkgs.sshfs ]; - }; + config = + lib.mkIf + (config.boot.supportedFilesystems.sshfs or config.boot.supportedFilesystems."fuse.sshfs" or false) + { + system.fsPackages = [ pkgs.sshfs ]; + }; } diff --git a/nixos/modules/tasks/filesystems/unionfs-fuse.nix b/nixos/modules/tasks/filesystems/unionfs-fuse.nix index 929454ff1529c2..42ec9c0c50c36e 100644 --- a/nixos/modules/tasks/filesystems/unionfs-fuse.nix +++ b/nixos/modules/tasks/filesystems/unionfs-fuse.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { config = lib.mkMerge [ @@ -17,16 +22,16 @@ ''; boot.initrd.postDeviceCommands = lib.mkIf (!config.boot.initrd.systemd.enable) '' - # Hacky!!! fuse hard-codes the path to mount - mkdir -p /nix/store/eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee-${pkgs.util-linux.name}-bin/bin - ln -s $(which mount) /nix/store/eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee-${pkgs.util-linux.name}-bin/bin - ln -s $(which umount) /nix/store/eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee-${pkgs.util-linux.name}-bin/bin - ''; + # Hacky!!! fuse hard-codes the path to mount + mkdir -p /nix/store/eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee-${pkgs.util-linux.name}-bin/bin + ln -s $(which mount) /nix/store/eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee-${pkgs.util-linux.name}-bin/bin + ln -s $(which umount) /nix/store/eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee-${pkgs.util-linux.name}-bin/bin + ''; boot.initrd.systemd.extraBin = { "mount.fuse" = "${pkgs.fuse}/bin/mount.fuse"; "unionfs" = "${pkgs.unionfs-fuse}/bin/unionfs"; - "mount.unionfs-fuse" = pkgs.runCommand "mount.unionfs-fuse" {} '' + "mount.unionfs-fuse" = pkgs.runCommand "mount.unionfs-fuse" { } '' substitute ${pkgs.unionfs-fuse}/sbin/mount.unionfs-fuse $out \ --replace '${pkgs.bash}/bin/bash' /bin/sh \ --replace '${pkgs.fuse}/sbin' /bin \ diff --git a/nixos/modules/tasks/filesystems/vboxsf.nix b/nixos/modules/tasks/filesystems/vboxsf.nix index 00245b5af25277..3271351a5bcafb 100644 --- a/nixos/modules/tasks/filesystems/vboxsf.nix +++ b/nixos/modules/tasks/filesystems/vboxsf.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; diff --git a/nixos/modules/tasks/filesystems/vfat.nix b/nixos/modules/tasks/filesystems/vfat.nix index d7acc0c9e50b9d..6ad032b580c8c1 100644 --- a/nixos/modules/tasks/filesystems/vfat.nix +++ b/nixos/modules/tasks/filesystems/vfat.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -11,15 +16,21 @@ in { config = mkIf (config.boot.supportedFilesystems.vfat or false) { - system.fsPackages = [ pkgs.dosfstools pkgs.mtools ]; - - boot.initrd.kernelModules = mkIf inInitrd [ "vfat" "nls_cp437" "nls_iso8859-1" ]; - - boot.initrd.extraUtilsCommands = mkIf (inInitrd && !config.boot.initrd.systemd.enable) - '' - copy_bin_and_libs ${pkgs.dosfstools}/sbin/dosfsck - ln -sv dosfsck $out/bin/fsck.vfat - ''; + system.fsPackages = [ + pkgs.dosfstools + pkgs.mtools + ]; + + boot.initrd.kernelModules = mkIf inInitrd [ + "vfat" + "nls_cp437" + "nls_iso8859-1" + ]; + + boot.initrd.extraUtilsCommands = mkIf (inInitrd && !config.boot.initrd.systemd.enable) '' + copy_bin_and_libs ${pkgs.dosfstools}/sbin/dosfsck + ln -sv dosfsck $out/bin/fsck.vfat + ''; boot.initrd.systemd.initrdBin = mkIf inInitrd [ pkgs.dosfstools ]; diff --git a/nixos/modules/tasks/filesystems/xfs.nix b/nixos/modules/tasks/filesystems/xfs.nix index 50dc1b3340aa53..0938f677b9152b 100644 --- a/nixos/modules/tasks/filesystems/xfs.nix +++ b/nixos/modules/tasks/filesystems/xfs.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -13,19 +18,20 @@ in system.fsPackages = [ pkgs.xfsprogs.bin ]; - boot.initrd.availableKernelModules = mkIf inInitrd [ "xfs" "crc32c" ]; + boot.initrd.availableKernelModules = mkIf inInitrd [ + "xfs" + "crc32c" + ]; - boot.initrd.extraUtilsCommands = mkIf (inInitrd && !config.boot.initrd.systemd.enable) - '' - copy_bin_and_libs ${pkgs.xfsprogs.bin}/bin/fsck.xfs - copy_bin_and_libs ${pkgs.xfsprogs.bin}/bin/xfs_repair - ''; + boot.initrd.extraUtilsCommands = mkIf (inInitrd && !config.boot.initrd.systemd.enable) '' + copy_bin_and_libs ${pkgs.xfsprogs.bin}/bin/fsck.xfs + copy_bin_and_libs ${pkgs.xfsprogs.bin}/bin/xfs_repair + ''; # Trick just to set 'sh' after the extraUtils nuke-refs. - boot.initrd.extraUtilsCommandsTest = mkIf (inInitrd && !config.boot.initrd.systemd.enable) - '' - sed -i -e 's,^#!.*,#!'$out/bin/sh, $out/bin/fsck.xfs - ''; + boot.initrd.extraUtilsCommandsTest = mkIf (inInitrd && !config.boot.initrd.systemd.enable) '' + sed -i -e 's,^#!.*,#!'$out/bin/sh, $out/bin/fsck.xfs + ''; boot.initrd.systemd.initrdBin = mkIf inInitrd [ pkgs.xfsprogs.bin ]; }; diff --git a/nixos/modules/tasks/lvm.nix b/nixos/modules/tasks/lvm.nix index f72aa5fc0a7c83..e507a8c0e121fc 100644 --- a/nixos/modules/tasks/lvm.nix +++ b/nixos/modules/tasks/lvm.nix @@ -1,9 +1,15 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.lvm; -in { +in +{ options.services.lvm = { enable = mkEnableOption "lvm2" // { default = true; @@ -72,9 +78,14 @@ in { }) (mkIf cfg.boot.thin.enable { boot.initrd = { - kernelModules = [ "dm-snapshot" "dm-thin-pool" ]; + kernelModules = [ + "dm-snapshot" + "dm-thin-pool" + ]; - systemd.initrdBin = lib.mkIf config.boot.initrd.services.lvm.enable [ pkgs.thin-provisioning-tools ]; + systemd.initrdBin = lib.mkIf config.boot.initrd.services.lvm.enable [ + pkgs.thin-provisioning-tools + ]; extraUtilsCommands = mkIf (!config.boot.initrd.systemd.enable) '' for BIN in ${pkgs.thin-provisioning-tools}/bin/*; do @@ -89,17 +100,27 @@ in { ''; }; - environment.etc."lvm/lvm.conf".text = concatMapStringsSep "\n" - (bin: "global/${bin}_executable = ${pkgs.thin-provisioning-tools}/bin/${bin}") - [ "thin_check" "thin_dump" "thin_repair" "cache_check" "cache_dump" "cache_repair" ]; + environment.etc."lvm/lvm.conf".text = + concatMapStringsSep "\n" + (bin: "global/${bin}_executable = ${pkgs.thin-provisioning-tools}/bin/${bin}") + [ + "thin_check" + "thin_dump" + "thin_repair" + "cache_check" + "cache_dump" + "cache_repair" + ]; environment.systemPackages = [ pkgs.thin-provisioning-tools ]; }) (mkIf cfg.boot.vdo.enable { - assertions = [{ - assertion = lib.versionAtLeast config.boot.kernelPackages.kernel.version "6.9"; - message = "boot.vdo.enable requires at least kernel version 6.9"; - }]; + assertions = [ + { + assertion = lib.versionAtLeast config.boot.kernelPackages.kernel.version "6.9"; + message = "boot.vdo.enable requires at least kernel version 6.9"; + } + ]; boot = { initrd = { @@ -107,7 +128,7 @@ in { systemd.initrdBin = lib.mkIf config.boot.initrd.services.lvm.enable [ pkgs.vdo ]; - extraUtilsCommands = mkIf (!config.boot.initrd.systemd.enable)'' + extraUtilsCommands = mkIf (!config.boot.initrd.systemd.enable) '' ls ${pkgs.vdo}/bin/ | while read BIN; do copy_bin_and_libs ${pkgs.vdo}/bin/$BIN done @@ -115,7 +136,7 @@ in { substituteInPlace $out/bin/adaptlvm --replace "${pkgs.bash}/bin/bash" "/bin/sh" ''; - extraUtilsCommandsTest = mkIf (!config.boot.initrd.systemd.enable)'' + extraUtilsCommandsTest = mkIf (!config.boot.initrd.systemd.enable) '' ls ${pkgs.vdo}/bin/ | grep -vE '(adaptlvm|vdorecover)' | while read BIN; do $out/bin/$(basename $BIN) --help > /dev/null done @@ -123,33 +144,46 @@ in { }; }; - services.lvm.package = mkOverride 999 pkgs.lvm2_vdo; # this overrides mkDefault + services.lvm.package = mkOverride 999 pkgs.lvm2_vdo; # this overrides mkDefault environment.systemPackages = [ pkgs.vdo ]; }) (mkIf (cfg.dmeventd.enable || cfg.boot.thin.enable) { - boot.initrd.systemd.contents."/etc/lvm/lvm.conf".text = optionalString (config.boot.initrd.services.lvm.enable && cfg.boot.thin.enable) (concatMapStringsSep "\n" - (bin: "global/${bin}_executable = /bin/${bin}") - [ "thin_check" "thin_dump" "thin_repair" "cache_check" "cache_dump" "cache_repair" ] - ) + "\n" + optionalString cfg.dmeventd.enable '' + boot.initrd.systemd.contents."/etc/lvm/lvm.conf".text = + optionalString (config.boot.initrd.services.lvm.enable && cfg.boot.thin.enable) ( + concatMapStringsSep "\n" (bin: "global/${bin}_executable = /bin/${bin}") [ + "thin_check" + "thin_dump" + "thin_repair" + "cache_check" + "cache_dump" + "cache_repair" + ] + ) + + "\n" + + optionalString cfg.dmeventd.enable '' dmeventd/executable = /bin/false activation/monitoring = 0 ''; boot.initrd.preLVMCommands = mkIf (!config.boot.initrd.systemd.enable) '' - mkdir -p /etc/lvm - cat << EOF >> /etc/lvm/lvm.conf - ${optionalString cfg.boot.thin.enable ( - concatMapStringsSep "\n" - (bin: "global/${bin}_executable = $(command -v ${bin})") - [ "thin_check" "thin_dump" "thin_repair" "cache_check" "cache_dump" "cache_repair" ] - ) - } - ${optionalString cfg.dmeventd.enable '' - dmeventd/executable = "$(command -v false)" - activation/monitoring = 0 - ''} - EOF + mkdir -p /etc/lvm + cat << EOF >> /etc/lvm/lvm.conf + ${optionalString cfg.boot.thin.enable ( + concatMapStringsSep "\n" (bin: "global/${bin}_executable = $(command -v ${bin})") [ + "thin_check" + "thin_dump" + "thin_repair" + "cache_check" + "cache_dump" + "cache_repair" + ] + )} + ${optionalString cfg.dmeventd.enable '' + dmeventd/executable = "$(command -v false)" + activation/monitoring = 0 + ''} + EOF ''; }) ]; diff --git a/nixos/modules/tasks/network-interfaces-systemd.nix b/nixos/modules/tasks/network-interfaces-systemd.nix index 0f85c69428ca05..60aa66347e3aba 100644 --- a/nixos/modules/tasks/network-interfaces-systemd.nix +++ b/nixos/modules/tasks/network-interfaces-systemd.nix @@ -1,4 +1,10 @@ -{ config, lib, utils, pkgs, ... }: +{ + config, + lib, + utils, + pkgs, + ... +}: with utils; with lib; @@ -8,13 +14,9 @@ let cfg = config.networking; interfaces = attrValues cfg.interfaces; - interfaceIps = i: - i.ipv4.addresses - ++ optionals cfg.enableIPv6 i.ipv6.addresses; + interfaceIps = i: i.ipv4.addresses ++ optionals cfg.enableIPv6 i.ipv6.addresses; - interfaceRoutes = i: - i.ipv4.routes - ++ optionals cfg.enableIPv6 i.ipv6.routes; + interfaceRoutes = i: i.ipv4.routes ++ optionals cfg.enableIPv6 i.ipv6.routes; dhcpStr = useDHCP: if useDHCP == true || useDHCP == null then "yes" else "no"; @@ -26,425 +28,546 @@ let ++ map (vlan: vlan.interface) (attrValues cfg.vlans) # add dependency to physical or independently created vswitch member interface # TODO: warn the user that any address configured on those interfaces will be useless - ++ concatMap (i: attrNames (filterAttrs (_: config: config.type != "internal") i.interfaces)) (attrValues cfg.vswitches); - - defaultGateways = mkMerge (forEach [ cfg.defaultGateway cfg.defaultGateway6 ] (gateway: - optionalAttrs (gateway != null && gateway.interface != null) { - networks."40-${gateway.interface}" = { - matchConfig.Name = gateway.interface; - routes = [ - ({ - Gateway = gateway.address; - } // optionalAttrs (gateway.metric != null) { - Metric = gateway.metric; - }) - ]; - }; - } - )); - - genericDhcpNetworks = initrd: mkIf cfg.useDHCP { - networks."99-ethernet-default-dhcp" = { - matchConfig = { - Type = "ether"; - Kind = "!*"; # physical interfaces have no kind - }; - DHCP = "yes"; - networkConfig.IPv6PrivacyExtensions = "kernel"; - }; - networks."99-wireless-client-dhcp" = { - matchConfig.WLANInterfaceType = "station"; - DHCP = "yes"; - networkConfig.IPv6PrivacyExtensions = "kernel"; - # We also set the route metric to one more than the default - # of 1024, so that Ethernet is preferred if both are - # available. - dhcpV4Config.RouteMetric = 1025; - ipv6AcceptRAConfig.RouteMetric = 1025; - }; - }; - + ++ concatMap (i: attrNames (filterAttrs (_: config: config.type != "internal") i.interfaces)) ( + attrValues cfg.vswitches + ); - interfaceNetworks = mkMerge (forEach interfaces (i: { - netdevs = mkIf i.virtual ({ - "40-${i.name}" = { - netdevConfig = { - Name = i.name; - Kind = i.virtualType; - }; - "${i.virtualType}Config" = optionalAttrs (i.virtualOwner != null) { - User = i.virtualOwner; + defaultGateways = mkMerge ( + forEach [ cfg.defaultGateway cfg.defaultGateway6 ] ( + gateway: + optionalAttrs (gateway != null && gateway.interface != null) { + networks."40-${gateway.interface}" = { + matchConfig.Name = gateway.interface; + routes = [ + ( + { + Gateway = gateway.address; + } + // optionalAttrs (gateway.metric != null) { + Metric = gateway.metric; + } + ) + ]; }; - }; - }); - networks."40-${i.name}" = { - name = mkDefault i.name; - DHCP = mkForce (dhcpStr - (if i.useDHCP != null then i.useDHCP else (config.networking.useDHCP && i.ipv4.addresses == [ ]))); - address = forEach (interfaceIps i) - (ip: "${ip.address}/${toString ip.prefixLength}"); - routes = forEach (interfaceRoutes i) - (route: mkMerge [ - # Most of these route options have not been tested. - # Please fix or report any mistakes you may find. - (mkIf (route.address != null && route.prefixLength != null) { - Destination = "${route.address}/${toString route.prefixLength}"; - }) - (mkIf (route.options ? fastopen_no_cookie) { - FastOpenNoCookie = route.options.fastopen_no_cookie; - }) - (mkIf (route.via != null) { - Gateway = route.via; - }) - (mkIf (route.type != null) { - Type = route.type; - }) - (mkIf (route.options ? onlink) { - GatewayOnLink = true; - }) - (mkIf (route.options ? initrwnd) { - InitialAdvertisedReceiveWindow = route.options.initrwnd; - }) - (mkIf (route.options ? initcwnd) { - InitialCongestionWindow = route.options.initcwnd; - }) - (mkIf (route.options ? pref) { - IPv6Preference = route.options.pref; - }) - (mkIf (route.options ? mtu) { - MTUBytes = route.options.mtu; - }) - (mkIf (route.options ? metric) { - Metric = route.options.metric; - }) - (mkIf (route.options ? src) { - PreferredSource = route.options.src; - }) - (mkIf (route.options ? protocol) { - Protocol = route.options.protocol; - }) - (mkIf (route.options ? quickack) { - QuickAck = route.options.quickack; - }) - (mkIf (route.options ? scope) { - Scope = route.options.scope; - }) - (mkIf (route.options ? from) { - Source = route.options.from; - }) - (mkIf (route.options ? table) { - Table = route.options.table; - }) - (mkIf (route.options ? advmss) { - TCPAdvertisedMaximumSegmentSize = route.options.advmss; - }) - (mkIf (route.options ? ttl-propagate) { - TTLPropagate = route.options.ttl-propagate == "enabled"; - }) - ]); - networkConfig.IPv6PrivacyExtensions = "kernel"; - linkConfig = optionalAttrs (i.macAddress != null) { - MACAddress = i.macAddress; - } // optionalAttrs (i.mtu != null) { - MTUBytes = toString i.mtu; - }; - }; - })); + } + ) + ); - bridgeNetworks = mkMerge (flip mapAttrsToList cfg.bridges (name: bridge: { - netdevs."40-${name}" = { - netdevConfig = { - Name = name; - Kind = "bridge"; + genericDhcpNetworks = + initrd: + mkIf cfg.useDHCP { + networks."99-ethernet-default-dhcp" = { + matchConfig = { + Type = "ether"; + Kind = "!*"; # physical interfaces have no kind + }; + DHCP = "yes"; + networkConfig.IPv6PrivacyExtensions = "kernel"; }; - }; - networks = listToAttrs (forEach bridge.interfaces (bi: - nameValuePair "40-${bi}" { - DHCP = mkOverride 0 (dhcpStr false); - networkConfig.Bridge = name; - })); - })); - - vlanNetworks = mkMerge (flip mapAttrsToList cfg.vlans (name: vlan: { - netdevs."40-${name}" = { - netdevConfig = { - Name = name; - Kind = "vlan"; + networks."99-wireless-client-dhcp" = { + matchConfig.WLANInterfaceType = "station"; + DHCP = "yes"; + networkConfig.IPv6PrivacyExtensions = "kernel"; + # We also set the route metric to one more than the default + # of 1024, so that Ethernet is preferred if both are + # available. + dhcpV4Config.RouteMetric = 1025; + ipv6AcceptRAConfig.RouteMetric = 1025; }; - vlanConfig.Id = vlan.id; }; - networks."40-${vlan.interface}" = { - vlan = [ name ]; - }; - })); - -in - -{ - config = mkMerge [ - - (mkIf config.boot.initrd.network.enable { - # Note this is if initrd.network.enable, not if - # initrd.systemd.network.enable. By setting the latter and not the - # former, the user retains full control over the configuration. - boot.initrd.systemd.network = mkMerge [ - defaultGateways - (genericDhcpNetworks true) - interfaceNetworks - bridgeNetworks - vlanNetworks - ]; - boot.initrd.availableKernelModules = - optional (cfg.bridges != {}) "bridge" ++ - optional (cfg.vlans != {}) "8021q"; - }) - (mkIf cfg.useNetworkd { - - assertions = [ { - assertion = cfg.defaultGatewayWindowSize == null; - message = "networking.defaultGatewayWindowSize is not supported by networkd."; - } { - assertion = cfg.defaultGateway != null -> cfg.defaultGateway.interface != null; - message = "networking.defaultGateway.interface is not optional when using networkd."; - } { - assertion = cfg.defaultGateway6 != null -> cfg.defaultGateway6.interface != null; - message = "networking.defaultGateway6.interface is not optional when using networkd."; - } ] ++ flip mapAttrsToList cfg.bridges (n: { rstp, ... }: { - assertion = !rstp; - message = "networking.bridges.${n}.rstp is not supported by networkd."; - }) ++ flip mapAttrsToList cfg.fooOverUDP (n: { local, ... }: { - assertion = local == null; - message = "networking.fooOverUDP.${n}.local is not supported by networkd."; - }); - - networking.dhcpcd.enable = mkDefault false; - - systemd.network = - mkMerge [ { - enable = true; - } - defaultGateways - (genericDhcpNetworks false) - interfaceNetworks - bridgeNetworks - (mkMerge (flip mapAttrsToList cfg.bonds (name: bond: { - netdevs."40-${name}" = { + interfaceNetworks = mkMerge ( + forEach interfaces (i: { + netdevs = mkIf i.virtual ({ + "40-${i.name}" = { netdevConfig = { - Name = name; - Kind = "bond"; + Name = i.name; + Kind = i.virtualType; }; - bondConfig = let - # manual mapping as of 2017-02-03 - # man 5 systemd.netdev [BOND] - # to https://www.kernel.org/doc/Documentation/networking/bonding.txt - # driver options. - driverOptionMapping = let - trans = f: optName: { valTransform = f; optNames = [optName]; }; - simp = trans id; - ms = trans (v: v + "ms"); - in { - Mode = simp "mode"; - TransmitHashPolicy = simp "xmit_hash_policy"; - LACPTransmitRate = simp "lacp_rate"; - MIIMonitorSec = ms "miimon"; - UpDelaySec = ms "updelay"; - DownDelaySec = ms "downdelay"; - LearnPacketIntervalSec = simp "lp_interval"; - AdSelect = simp "ad_select"; - FailOverMACPolicy = simp "fail_over_mac"; - ARPValidate = simp "arp_validate"; - # apparently in ms for this value?! Upstream bug? - ARPIntervalSec = simp "arp_interval"; - ARPIPTargets = simp "arp_ip_target"; - ARPAllTargets = simp "arp_all_targets"; - PrimaryReselectPolicy = simp "primary_reselect"; - ResendIGMP = simp "resend_igmp"; - PacketsPerSlave = simp "packets_per_slave"; - GratuitousARP = { valTransform = id; - optNames = [ "num_grat_arp" "num_unsol_na" ]; }; - AllSlavesActive = simp "all_slaves_active"; - MinLinks = simp "min_links"; - }; - - do = bond.driverOptions; - assertNoUnknownOption = let - knownOptions = flatten (mapAttrsToList (_: kOpts: kOpts.optNames) - driverOptionMapping); - # options that apparently don’t exist in the networkd config - unknownOptions = [ "primary" ]; - assertTrace = bool: msg: if bool then true else builtins.trace msg false; - in assert all (driverOpt: assertTrace - (elem driverOpt (knownOptions ++ unknownOptions)) - "The bond.driverOption `${driverOpt}` cannot be mapped to the list of known networkd bond options. Please add it to the mapping above the assert or to `unknownOptions` should it not exist in networkd.") - (mapAttrsToList (k: _: k) do); ""; - # get those driverOptions that have been set - filterSystemdOptions = filterAttrs (sysDOpt: kOpts: - any (kOpt: do ? ${kOpt}) kOpts.optNames); - # build final set of systemd options to bond values - buildOptionSet = mapAttrs (_: kOpts: with kOpts; - # we simply take the first set kernel bond option - # (one option has multiple names, which is silly) - head (map (optN: valTransform (do.${optN})) - # only map those that exist - (filter (o: do ? ${o}) optNames))); - in seq assertNoUnknownOption - (buildOptionSet (filterSystemdOptions driverOptionMapping)); - - }; - - networks = listToAttrs (forEach bond.interfaces (bi: - nameValuePair "40-${bi}" { - DHCP = mkOverride 0 (dhcpStr false); - networkConfig.Bond = name; - })); - }))) - (mkMerge (flip mapAttrsToList cfg.macvlans (name: macvlan: { - netdevs."40-${name}" = { - netdevConfig = { - Name = name; - Kind = "macvlan"; + "${i.virtualType}Config" = optionalAttrs (i.virtualOwner != null) { + User = i.virtualOwner; }; - macvlanConfig = optionalAttrs (macvlan.mode != null) { Mode = macvlan.mode; }; }; - networks."40-${macvlan.interface}" = { - macvlan = [ name ]; - }; - }))) - (mkMerge (flip mapAttrsToList cfg.fooOverUDP (name: fou: { - netdevs."40-${name}" = { - netdevConfig = { - Name = name; - Kind = "fou"; + }); + networks."40-${i.name}" = { + name = mkDefault i.name; + DHCP = mkForce ( + dhcpStr ( + if i.useDHCP != null then i.useDHCP else (config.networking.useDHCP && i.ipv4.addresses == [ ]) + ) + ); + address = forEach (interfaceIps i) (ip: "${ip.address}/${toString ip.prefixLength}"); + routes = forEach (interfaceRoutes i) ( + route: + mkMerge [ + # Most of these route options have not been tested. + # Please fix or report any mistakes you may find. + (mkIf (route.address != null && route.prefixLength != null) { + Destination = "${route.address}/${toString route.prefixLength}"; + }) + (mkIf (route.options ? fastopen_no_cookie) { + FastOpenNoCookie = route.options.fastopen_no_cookie; + }) + (mkIf (route.via != null) { + Gateway = route.via; + }) + (mkIf (route.type != null) { + Type = route.type; + }) + (mkIf (route.options ? onlink) { + GatewayOnLink = true; + }) + (mkIf (route.options ? initrwnd) { + InitialAdvertisedReceiveWindow = route.options.initrwnd; + }) + (mkIf (route.options ? initcwnd) { + InitialCongestionWindow = route.options.initcwnd; + }) + (mkIf (route.options ? pref) { + IPv6Preference = route.options.pref; + }) + (mkIf (route.options ? mtu) { + MTUBytes = route.options.mtu; + }) + (mkIf (route.options ? metric) { + Metric = route.options.metric; + }) + (mkIf (route.options ? src) { + PreferredSource = route.options.src; + }) + (mkIf (route.options ? protocol) { + Protocol = route.options.protocol; + }) + (mkIf (route.options ? quickack) { + QuickAck = route.options.quickack; + }) + (mkIf (route.options ? scope) { + Scope = route.options.scope; + }) + (mkIf (route.options ? from) { + Source = route.options.from; + }) + (mkIf (route.options ? table) { + Table = route.options.table; + }) + (mkIf (route.options ? advmss) { + TCPAdvertisedMaximumSegmentSize = route.options.advmss; + }) + (mkIf (route.options ? ttl-propagate) { + TTLPropagate = route.options.ttl-propagate == "enabled"; + }) + ] + ); + networkConfig.IPv6PrivacyExtensions = "kernel"; + linkConfig = + optionalAttrs (i.macAddress != null) { + MACAddress = i.macAddress; + } + // optionalAttrs (i.mtu != null) { + MTUBytes = toString i.mtu; }; - # unfortunately networkd cannot encode dependencies of netdevs on addresses/routes, - # so we cannot specify Local=, Peer=, PeerPort=. this looks like a missing feature - # in networkd. - fooOverUDPConfig = { - Port = fou.port; - Encapsulation = if fou.protocol != null then "FooOverUDP" else "GenericUDPEncapsulation"; - } // (optionalAttrs (fou.protocol != null) { - Protocol = fou.protocol; - }); - }; - }))) - (mkMerge (flip mapAttrsToList cfg.sits (name: sit: { + }; + }) + ); + + bridgeNetworks = mkMerge ( + flip mapAttrsToList cfg.bridges ( + name: bridge: { netdevs."40-${name}" = { netdevConfig = { Name = name; - Kind = "sit"; - }; - tunnelConfig = - (optionalAttrs (sit.remote != null) { - Remote = sit.remote; - }) // (optionalAttrs (sit.local != null) { - Local = sit.local; - }) // (optionalAttrs (sit.ttl != null) { - TTL = sit.ttl; - }) // (optionalAttrs (sit.encapsulation != null) ( - { - FooOverUDP = true; - Encapsulation = - if sit.encapsulation.type == "fou" - then "FooOverUDP" - else "GenericUDPEncapsulation"; - FOUDestinationPort = sit.encapsulation.port; - } // (optionalAttrs (sit.encapsulation.sourcePort != null) { - FOUSourcePort = sit.encapsulation.sourcePort; - }))); - }; - networks = mkIf (sit.dev != null) { - "40-${sit.dev}" = { - tunnel = [ name ]; + Kind = "bridge"; }; }; - }))) - (mkMerge (flip mapAttrsToList cfg.greTunnels (name: gre: { + networks = listToAttrs ( + forEach bridge.interfaces ( + bi: + nameValuePair "40-${bi}" { + DHCP = mkOverride 0 (dhcpStr false); + networkConfig.Bridge = name; + } + ) + ); + } + ) + ); + + vlanNetworks = mkMerge ( + flip mapAttrsToList cfg.vlans ( + name: vlan: { netdevs."40-${name}" = { netdevConfig = { Name = name; - Kind = gre.type; + Kind = "vlan"; }; - tunnelConfig = - (optionalAttrs (gre.remote != null) { - Remote = gre.remote; - }) // (optionalAttrs (gre.local != null) { - Local = gre.local; - }) // (optionalAttrs (gre.ttl != null) { - TTL = gre.ttl; - }); + vlanConfig.Id = vlan.id; }; - networks = mkIf (gre.dev != null) { - "40-${gre.dev}" = { - tunnel = [ name ]; - }; + networks."40-${vlan.interface}" = { + vlan = [ name ]; }; - }))) - vlanNetworks - ]; + } + ) + ); + +in + +{ + config = mkMerge [ - # We need to prefill the slaved devices with networking options - # This forces the network interface creator to initialize slaves. - networking.interfaces = listToAttrs (map (i: nameValuePair i { }) slaves); + (mkIf config.boot.initrd.network.enable { + # Note this is if initrd.network.enable, not if + # initrd.systemd.network.enable. By setting the latter and not the + # former, the user retains full control over the configuration. + boot.initrd.systemd.network = mkMerge [ + defaultGateways + (genericDhcpNetworks true) + interfaceNetworks + bridgeNetworks + vlanNetworks + ]; + boot.initrd.availableKernelModules = + optional (cfg.bridges != { }) "bridge" + ++ optional (cfg.vlans != { }) "8021q"; + }) - systemd.services = let - # We must escape interfaces due to the systemd interpretation - subsystemDevice = interface: - "sys-subsystem-net-devices-${escapeSystemdPath interface}.device"; - # support for creating openvswitch switches - createVswitchDevice = n: v: nameValuePair "${n}-netdev" - (let - deps = map subsystemDevice (attrNames (filterAttrs (_: config: config.type != "internal") v.interfaces)); - ofRules = pkgs.writeText "vswitch-${n}-openFlowRules" v.openFlowRules; - in - { description = "Open vSwitch Interface ${n}"; - wantedBy = [ "network.target" (subsystemDevice n) ]; - # and create bridge before systemd-networkd starts because it might create internal interfaces - before = [ "systemd-networkd.service" ]; - # shutdown the bridge when network is shutdown - partOf = [ "network.target" ]; - # requires ovs-vswitchd to be alive at all times - bindsTo = [ "ovs-vswitchd.service" ]; - # start switch after physical interfaces and vswitch daemon - after = [ "network-pre.target" "ovs-vswitchd.service" ] ++ deps; - wants = deps; # if one or more interface fails, the switch should continue to run - serviceConfig.Type = "oneshot"; - serviceConfig.RemainAfterExit = true; - path = [ pkgs.iproute2 config.virtualisation.vswitch.package ]; - preStart = '' - echo "Resetting Open vSwitch ${n}..." - ovs-vsctl --if-exists del-br ${n} -- add-br ${n} \ - -- set bridge ${n} protocols=${concatStringsSep "," v.supportedOpenFlowVersions} - ''; - script = '' - echo "Configuring Open vSwitch ${n}..." - ovs-vsctl ${concatStrings (mapAttrsToList (name: config: " -- add-port ${n} ${name}" + optionalString (config.vlan != null) " tag=${toString config.vlan}") v.interfaces)} \ - ${concatStrings (mapAttrsToList (name: config: optionalString (config.type != null) " -- set interface ${name} type=${config.type}") v.interfaces)} \ - ${concatMapStrings (x: " -- set-controller ${n} " + x) v.controllers} \ - ${concatMapStrings (x: " -- " + x) (splitString "\n" v.extraOvsctlCmds)} + (mkIf cfg.useNetworkd { + assertions = + [ + { + assertion = cfg.defaultGatewayWindowSize == null; + message = "networking.defaultGatewayWindowSize is not supported by networkd."; + } + { + assertion = cfg.defaultGateway != null -> cfg.defaultGateway.interface != null; + message = "networking.defaultGateway.interface is not optional when using networkd."; + } + { + assertion = cfg.defaultGateway6 != null -> cfg.defaultGateway6.interface != null; + message = "networking.defaultGateway6.interface is not optional when using networkd."; + } + ] + ++ flip mapAttrsToList cfg.bridges ( + n: + { rstp, ... }: + { + assertion = !rstp; + message = "networking.bridges.${n}.rstp is not supported by networkd."; + } + ) + ++ flip mapAttrsToList cfg.fooOverUDP ( + n: + { local, ... }: + { + assertion = local == null; + message = "networking.fooOverUDP.${n}.local is not supported by networkd."; + } + ); - echo "Adding OpenFlow rules for Open vSwitch ${n}..." - ovs-ofctl --protocols=${v.openFlowVersion} add-flows ${n} ${ofRules} - ''; - postStop = '' - echo "Cleaning Open vSwitch ${n}" - echo "Shutting down internal ${n} interface" - ip link set dev ${n} down || true - echo "Deleting flows for ${n}" - ovs-ofctl --protocols=${v.openFlowVersion} del-flows ${n} || true - echo "Deleting Open vSwitch ${n}" - ovs-vsctl --if-exists del-br ${n} || true - ''; - }); - in mapAttrs' createVswitchDevice cfg.vswitches - // { - "network-local-commands" = { - after = [ "systemd-networkd.service" ]; - bindsTo = [ "systemd-networkd.service" ]; + networking.dhcpcd.enable = mkDefault false; + + systemd.network = mkMerge [ + { + enable = true; + } + defaultGateways + (genericDhcpNetworks false) + interfaceNetworks + bridgeNetworks + (mkMerge ( + flip mapAttrsToList cfg.bonds ( + name: bond: { + netdevs."40-${name}" = { + netdevConfig = { + Name = name; + Kind = "bond"; + }; + bondConfig = + let + # manual mapping as of 2017-02-03 + # man 5 systemd.netdev [BOND] + # to https://www.kernel.org/doc/Documentation/networking/bonding.txt + # driver options. + driverOptionMapping = + let + trans = f: optName: { + valTransform = f; + optNames = [ optName ]; + }; + simp = trans id; + ms = trans (v: v + "ms"); + in + { + Mode = simp "mode"; + TransmitHashPolicy = simp "xmit_hash_policy"; + LACPTransmitRate = simp "lacp_rate"; + MIIMonitorSec = ms "miimon"; + UpDelaySec = ms "updelay"; + DownDelaySec = ms "downdelay"; + LearnPacketIntervalSec = simp "lp_interval"; + AdSelect = simp "ad_select"; + FailOverMACPolicy = simp "fail_over_mac"; + ARPValidate = simp "arp_validate"; + # apparently in ms for this value?! Upstream bug? + ARPIntervalSec = simp "arp_interval"; + ARPIPTargets = simp "arp_ip_target"; + ARPAllTargets = simp "arp_all_targets"; + PrimaryReselectPolicy = simp "primary_reselect"; + ResendIGMP = simp "resend_igmp"; + PacketsPerSlave = simp "packets_per_slave"; + GratuitousARP = { + valTransform = id; + optNames = [ + "num_grat_arp" + "num_unsol_na" + ]; + }; + AllSlavesActive = simp "all_slaves_active"; + MinLinks = simp "min_links"; + }; + + do = bond.driverOptions; + assertNoUnknownOption = + let + knownOptions = flatten (mapAttrsToList (_: kOpts: kOpts.optNames) driverOptionMapping); + # options that apparently don’t exist in the networkd config + unknownOptions = [ "primary" ]; + assertTrace = bool: msg: if bool then true else builtins.trace msg false; + in + assert all ( + driverOpt: + assertTrace (elem driverOpt (knownOptions ++ unknownOptions)) + "The bond.driverOption `${driverOpt}` cannot be mapped to the list of known networkd bond options. Please add it to the mapping above the assert or to `unknownOptions` should it not exist in networkd." + ) (mapAttrsToList (k: _: k) do); + ""; + # get those driverOptions that have been set + filterSystemdOptions = filterAttrs (sysDOpt: kOpts: any (kOpt: do ? ${kOpt}) kOpts.optNames); + # build final set of systemd options to bond values + buildOptionSet = mapAttrs ( + _: kOpts: + with kOpts; + # we simply take the first set kernel bond option + # (one option has multiple names, which is silly) + head ( + map (optN: valTransform (do.${optN})) + # only map those that exist + (filter (o: do ? ${o}) optNames) + ) + ); + in + seq assertNoUnknownOption (buildOptionSet (filterSystemdOptions driverOptionMapping)); + + }; + + networks = listToAttrs ( + forEach bond.interfaces ( + bi: + nameValuePair "40-${bi}" { + DHCP = mkOverride 0 (dhcpStr false); + networkConfig.Bond = name; + } + ) + ); + } + ) + )) + (mkMerge ( + flip mapAttrsToList cfg.macvlans ( + name: macvlan: { + netdevs."40-${name}" = { + netdevConfig = { + Name = name; + Kind = "macvlan"; + }; + macvlanConfig = optionalAttrs (macvlan.mode != null) { Mode = macvlan.mode; }; + }; + networks."40-${macvlan.interface}" = { + macvlan = [ name ]; + }; + } + ) + )) + (mkMerge ( + flip mapAttrsToList cfg.fooOverUDP ( + name: fou: { + netdevs."40-${name}" = { + netdevConfig = { + Name = name; + Kind = "fou"; + }; + # unfortunately networkd cannot encode dependencies of netdevs on addresses/routes, + # so we cannot specify Local=, Peer=, PeerPort=. this looks like a missing feature + # in networkd. + fooOverUDPConfig = + { + Port = fou.port; + Encapsulation = if fou.protocol != null then "FooOverUDP" else "GenericUDPEncapsulation"; + } + // (optionalAttrs (fou.protocol != null) { + Protocol = fou.protocol; + }); + }; + } + ) + )) + (mkMerge ( + flip mapAttrsToList cfg.sits ( + name: sit: { + netdevs."40-${name}" = { + netdevConfig = { + Name = name; + Kind = "sit"; + }; + tunnelConfig = + (optionalAttrs (sit.remote != null) { + Remote = sit.remote; + }) + // (optionalAttrs (sit.local != null) { + Local = sit.local; + }) + // (optionalAttrs (sit.ttl != null) { + TTL = sit.ttl; + }) + // (optionalAttrs (sit.encapsulation != null) ( + { + FooOverUDP = true; + Encapsulation = if sit.encapsulation.type == "fou" then "FooOverUDP" else "GenericUDPEncapsulation"; + FOUDestinationPort = sit.encapsulation.port; + } + // (optionalAttrs (sit.encapsulation.sourcePort != null) { + FOUSourcePort = sit.encapsulation.sourcePort; + }) + )); + }; + networks = mkIf (sit.dev != null) { + "40-${sit.dev}" = { + tunnel = [ name ]; + }; + }; + } + ) + )) + (mkMerge ( + flip mapAttrsToList cfg.greTunnels ( + name: gre: { + netdevs."40-${name}" = { + netdevConfig = { + Name = name; + Kind = gre.type; + }; + tunnelConfig = + (optionalAttrs (gre.remote != null) { + Remote = gre.remote; + }) + // (optionalAttrs (gre.local != null) { + Local = gre.local; + }) + // (optionalAttrs (gre.ttl != null) { + TTL = gre.ttl; + }); + }; + networks = mkIf (gre.dev != null) { + "40-${gre.dev}" = { + tunnel = [ name ]; + }; + }; + } + ) + )) + vlanNetworks + ]; + + # We need to prefill the slaved devices with networking options + # This forces the network interface creator to initialize slaves. + networking.interfaces = listToAttrs (map (i: nameValuePair i { }) slaves); + + systemd.services = + let + # We must escape interfaces due to the systemd interpretation + subsystemDevice = interface: "sys-subsystem-net-devices-${escapeSystemdPath interface}.device"; + # support for creating openvswitch switches + createVswitchDevice = + n: v: + nameValuePair "${n}-netdev" ( + let + deps = map subsystemDevice ( + attrNames (filterAttrs (_: config: config.type != "internal") v.interfaces) + ); + ofRules = pkgs.writeText "vswitch-${n}-openFlowRules" v.openFlowRules; + in + { + description = "Open vSwitch Interface ${n}"; + wantedBy = [ + "network.target" + (subsystemDevice n) + ]; + # and create bridge before systemd-networkd starts because it might create internal interfaces + before = [ "systemd-networkd.service" ]; + # shutdown the bridge when network is shutdown + partOf = [ "network.target" ]; + # requires ovs-vswitchd to be alive at all times + bindsTo = [ "ovs-vswitchd.service" ]; + # start switch after physical interfaces and vswitch daemon + after = [ + "network-pre.target" + "ovs-vswitchd.service" + ] ++ deps; + wants = deps; # if one or more interface fails, the switch should continue to run + serviceConfig.Type = "oneshot"; + serviceConfig.RemainAfterExit = true; + path = [ + pkgs.iproute2 + config.virtualisation.vswitch.package + ]; + preStart = '' + echo "Resetting Open vSwitch ${n}..." + ovs-vsctl --if-exists del-br ${n} -- add-br ${n} \ + -- set bridge ${n} protocols=${concatStringsSep "," v.supportedOpenFlowVersions} + ''; + script = '' + echo "Configuring Open vSwitch ${n}..." + ovs-vsctl ${ + concatStrings ( + mapAttrsToList ( + name: config: + " -- add-port ${n} ${name}" + optionalString (config.vlan != null) " tag=${toString config.vlan}" + ) v.interfaces + ) + } \ + ${ + concatStrings ( + mapAttrsToList ( + name: config: optionalString (config.type != null) " -- set interface ${name} type=${config.type}" + ) v.interfaces + ) + } \ + ${concatMapStrings (x: " -- set-controller ${n} " + x) v.controllers} \ + ${concatMapStrings (x: " -- " + x) (splitString "\n" v.extraOvsctlCmds)} + + + echo "Adding OpenFlow rules for Open vSwitch ${n}..." + ovs-ofctl --protocols=${v.openFlowVersion} add-flows ${n} ${ofRules} + ''; + postStop = '' + echo "Cleaning Open vSwitch ${n}" + echo "Shutting down internal ${n} interface" + ip link set dev ${n} down || true + echo "Deleting flows for ${n}" + ovs-ofctl --protocols=${v.openFlowVersion} del-flows ${n} || true + echo "Deleting Open vSwitch ${n}" + ovs-vsctl --if-exists del-br ${n} || true + ''; + } + ); + in + mapAttrs' createVswitchDevice cfg.vswitches + // { + "network-local-commands" = { + after = [ "systemd-networkd.service" ]; + bindsTo = [ "systemd-networkd.service" ]; }; - }; - }) + }; + }) ]; } diff --git a/nixos/modules/tasks/powertop.nix b/nixos/modules/tasks/powertop.nix index e8064f9fa80c6c..2483f29675cc83 100644 --- a/nixos/modules/tasks/powertop.nix +++ b/nixos/modules/tasks/powertop.nix @@ -1,10 +1,16 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.powerManagement.powertop; -in { +in +{ ###### interface options.powerManagement.powertop.enable = mkEnableOption "powertop auto tuning on startup"; diff --git a/nixos/modules/tasks/scsi-link-power-management.nix b/nixos/modules/tasks/scsi-link-power-management.nix index 549c35fc5b8d7c..289d075e19be09 100644 --- a/nixos/modules/tasks/scsi-link-power-management.nix +++ b/nixos/modules/tasks/scsi-link-power-management.nix @@ -36,7 +36,6 @@ in }; - ###### implementation config = mkIf (cfg != null) { diff --git a/nixos/modules/tasks/stratis.nix b/nixos/modules/tasks/stratis.nix index f4bb09a89e7ffa..7c16fff894ab7c 100644 --- a/nixos/modules/tasks/stratis.nix +++ b/nixos/modules/tasks/stratis.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.stratis; diff --git a/nixos/modules/tasks/swraid.nix b/nixos/modules/tasks/swraid.nix index ad9b1ab0fa1a1e..01bc91b1b896b3 100644 --- a/nixos/modules/tasks/swraid.nix +++ b/nixos/modules/tasks/swraid.nix @@ -1,4 +1,10 @@ -{ config, pkgs, lib, ... }: let +{ + config, + pkgs, + lib, + ... +}: +let cfg = config.boot.swraid; @@ -6,16 +12,22 @@ enable_implicitly_for_old_state_versions = lib.versionOlder config.system.stateVersion "23.11"; - minimum_config_is_set = config_text: - (builtins.match ".*(MAILADDR|PROGRAM).*" mdadm_conf.text) != null; + minimum_config_is_set = + config_text: (builtins.match ".*(MAILADDR|PROGRAM).*" mdadm_conf.text) != null; -in { +in +{ imports = [ - (lib.mkRenamedOptionModule [ "boot" "initrd" "services" "swraid" "enable" ] [ "boot" "swraid" "enable" ]) - (lib.mkRenamedOptionModule [ "boot" "initrd" "services" "swraid" "mdadmConf" ] [ "boot" "swraid" "mdadmConf" ]) + (lib.mkRenamedOptionModule + [ "boot" "initrd" "services" "swraid" "enable" ] + [ "boot" "swraid" "enable" ] + ) + (lib.mkRenamedOptionModule + [ "boot" "initrd" "services" "swraid" "mdadmConf" ] + [ "boot" "swraid" "mdadmConf" ] + ) ]; - options.boot.swraid = { enable = lib.mkEnableOption "swraid support using mdadm" // { description = '' @@ -43,9 +55,11 @@ in { }; config = lib.mkIf cfg.enable { - warnings = lib.mkIf - ( !enable_implicitly_for_old_state_versions && !minimum_config_is_set mdadm_conf) - [ "mdadm: Neither MAILADDR nor PROGRAM has been set. This will cause the `mdmon` service to crash." ]; + warnings = + lib.mkIf (!enable_implicitly_for_old_state_versions && !minimum_config_is_set mdadm_conf) + [ + "mdadm: Neither MAILADDR nor PROGRAM has been set. This will cause the `mdmon` service to crash." + ]; environment.systemPackages = [ pkgs.mdadm ]; @@ -56,7 +70,13 @@ in { systemd.packages = [ pkgs.mdadm ]; boot.initrd = { - availableKernelModules = [ "md_mod" "raid0" "raid1" "raid10" "raid456" ]; + availableKernelModules = [ + "md_mod" + "raid0" + "raid1" + "raid10" + "raid456" + ]; extraUdevRulesCommands = lib.mkIf (!config.boot.initrd.systemd.enable) '' cp -v ${pkgs.mdadm}/lib/udev/rules.d/*.rules $out/ diff --git a/nixos/modules/tasks/trackpoint.nix b/nixos/modules/tasks/trackpoint.nix index 0859f83fcef54a..4d4dc73bd5cbda 100644 --- a/nixos/modules/tasks/trackpoint.nix +++ b/nixos/modules/tasks/trackpoint.nix @@ -68,48 +68,56 @@ with lib; }; - ###### implementation config = - let cfg = config.hardware.trackpoint; in - mkMerge [ - (mkIf cfg.enable { - services.udev.extraRules = - '' - ACTION=="add|change", SUBSYSTEM=="input", ATTR{name}=="${cfg.device}", ATTR{device/speed}="${toString cfg.speed}", ATTR{device/sensitivity}="${toString cfg.sensitivity}" - ''; - - systemd.services.trackpoint = { - wantedBy = [ "sysinit.target" ] ; - before = [ "sysinit.target" "shutdown.target" ]; - conflicts = [ "shutdown.target" ]; - unitConfig.DefaultDependencies = false; - serviceConfig.Type = "oneshot"; - serviceConfig.RemainAfterExit = true; - serviceConfig.ExecStart = '' - ${config.systemd.package}/bin/udevadm trigger --attr-match=name="${cfg.device}" + let + cfg = config.hardware.trackpoint; + in + mkMerge [ + (mkIf cfg.enable { + services.udev.extraRules = '' + ACTION=="add|change", SUBSYSTEM=="input", ATTR{name}=="${cfg.device}", ATTR{device/speed}="${toString cfg.speed}", ATTR{device/sensitivity}="${toString cfg.sensitivity}" ''; - }; - }) - - (mkIf (cfg.emulateWheel) { - services.xserver.inputClassSections = [ - '' - Identifier "Trackpoint Wheel Emulation" - MatchProduct "${if cfg.fakeButtons then "PS/2 Generic Mouse" else "ETPS/2 Elantech TrackPoint|Elantech PS/2 TrackPoint|TPPS/2 IBM TrackPoint|DualPoint Stick|Synaptics Inc. Composite TouchPad / TrackPoint|ThinkPad USB Keyboard with TrackPoint|USB Trackpoint pointing device|Composite TouchPad / TrackPoint|${cfg.device}"}" - MatchDevicePath "/dev/input/event*" - Option "EmulateWheel" "true" - Option "EmulateWheelButton" "2" - Option "Emulate3Buttons" "false" - Option "XAxisMapping" "6 7" - Option "YAxisMapping" "4 5" - '' - ]; - }) - - (mkIf cfg.fakeButtons { - boot.extraModprobeConfig = "options psmouse proto=bare"; - }) - ]; + + systemd.services.trackpoint = { + wantedBy = [ "sysinit.target" ]; + before = [ + "sysinit.target" + "shutdown.target" + ]; + conflicts = [ "shutdown.target" ]; + unitConfig.DefaultDependencies = false; + serviceConfig.Type = "oneshot"; + serviceConfig.RemainAfterExit = true; + serviceConfig.ExecStart = '' + ${config.systemd.package}/bin/udevadm trigger --attr-match=name="${cfg.device}" + ''; + }; + }) + + (mkIf (cfg.emulateWheel) { + services.xserver.inputClassSections = [ + '' + Identifier "Trackpoint Wheel Emulation" + MatchProduct "${ + if cfg.fakeButtons then + "PS/2 Generic Mouse" + else + "ETPS/2 Elantech TrackPoint|Elantech PS/2 TrackPoint|TPPS/2 IBM TrackPoint|DualPoint Stick|Synaptics Inc. Composite TouchPad / TrackPoint|ThinkPad USB Keyboard with TrackPoint|USB Trackpoint pointing device|Composite TouchPad / TrackPoint|${cfg.device}" + }" + MatchDevicePath "/dev/input/event*" + Option "EmulateWheel" "true" + Option "EmulateWheelButton" "2" + Option "Emulate3Buttons" "false" + Option "XAxisMapping" "6 7" + Option "YAxisMapping" "4 5" + '' + ]; + }) + + (mkIf cfg.fakeButtons { + boot.extraModprobeConfig = "options psmouse proto=bare"; + }) + ]; } diff --git a/nixos/modules/testing/service-runner.nix b/nixos/modules/testing/service-runner.nix index 9060be3cca112c..d610c7a8a98c66 100644 --- a/nixos/modules/testing/service-runner.nix +++ b/nixos/modules/testing/service-runner.nix @@ -4,8 +4,9 @@ with lib; let - makeScript = name: service: pkgs.writeScript "${name}-runner" - '' + makeScript = + name: service: + pkgs.writeScript "${name}-runner" '' #! ${pkgs.perl.withPackages (p: [ p.FileSlurp ])}/bin/perl -w use File::Slurp; @@ -46,13 +47,15 @@ let next if $key eq 'LOCALE_ARCHIVE'; delete $ENV{$key}; } - ${concatStrings (mapAttrsToList (n: v: '' - $ENV{'${n}'} = '${v}'; - '') service.environment)} + ${concatStrings ( + mapAttrsToList (n: v: '' + $ENV{'${n}'} = '${v}'; + '') service.environment + )} # Run the ExecStartPre program. FIXME: this could be a list. my $preStart = < Extracting Anbox root image..." - unsquashfs -dest rootfs ${cfg.image} - - echo "-> Modifying Anbox root image..." - ( - cd rootfs - ${cfg.imageModifications} - ) - - echo "-> Packing modified Anbox root image..." - mksquashfs rootfs $out -comp xz -no-xattrs -all-root - '' - ) { }); + finalImage = + if cfg.imageModifications == "" then + cfg.image + else + (pkgs.callPackage ( + { runCommandNoCC, squashfsTools }: + + runCommandNoCC "${cfg.image.name}-modified.img" + { + nativeBuildInputs = [ + squashfsTools + ]; + } + '' + echo "-> Extracting Anbox root image..." + unsquashfs -dest rootfs ${cfg.image} + + echo "-> Modifying Anbox root image..." + ( + cd rootfs + ${cfg.imageModifications} + ) + + echo "-> Packing modified Anbox root image..." + mksquashfs rootfs $out -comp xz -no-xattrs -all-root + '' + ) { }); in @@ -116,7 +127,7 @@ in }; virtualisation.lxc.enable = true; - networking.bridges.anbox0.interfaces = []; + networking.bridges.anbox0.interfaces = [ ]; networking.interfaces.anbox0.ipv4.addresses = [ cfg.ipv4.gateway ]; networking.nat = { @@ -127,50 +138,57 @@ in # Ensures NetworkManager doesn't touch anbox0 networking.networkmanager.unmanaged = [ "anbox0" ]; - systemd.services.anbox-container-manager = let - anboxloc = "/var/lib/anbox"; - in { - description = "Anbox Container Management Daemon"; - - environment.XDG_RUNTIME_DIR="${anboxloc}"; - - wantedBy = [ "multi-user.target" ]; - preStart = let - initsh = pkgs.writeText "nixos-init" ('' - #!/system/bin/sh - setprop nixos.version ${config.system.nixos.version} - - # we don't have radio - setprop ro.radio.noril yes - stop ril-daemon - - # speed up boot - setprop debug.sf.nobootanimation 1 - '' + cfg.extraInit); - initshloc = "${anboxloc}/rootfs-overlay/system/etc/init.goldfish.sh"; - in '' - mkdir -p ${anboxloc} - mkdir -p $(dirname ${initshloc}) - [ -f ${initshloc} ] && rm ${initshloc} - cp ${initsh} ${initshloc} - chown 100000:100000 ${initshloc} - chmod +x ${initshloc} - ''; - - serviceConfig = { - ExecStart = '' - ${pkgs.anbox}/bin/anbox container-manager \ - --data-path=${anboxloc} \ - --android-image=${finalImage} \ - --container-network-address=${cfg.ipv4.container.address} \ - --container-network-gateway=${cfg.ipv4.gateway.address} \ - --container-network-dns-servers=${cfg.ipv4.dns} \ - --use-rootfs-overlay \ - --privileged \ - --daemon - ''; + systemd.services.anbox-container-manager = + let + anboxloc = "/var/lib/anbox"; + in + { + description = "Anbox Container Management Daemon"; + + environment.XDG_RUNTIME_DIR = "${anboxloc}"; + + wantedBy = [ "multi-user.target" ]; + preStart = + let + initsh = pkgs.writeText "nixos-init" ( + '' + #!/system/bin/sh + setprop nixos.version ${config.system.nixos.version} + + # we don't have radio + setprop ro.radio.noril yes + stop ril-daemon + + # speed up boot + setprop debug.sf.nobootanimation 1 + '' + + cfg.extraInit + ); + initshloc = "${anboxloc}/rootfs-overlay/system/etc/init.goldfish.sh"; + in + '' + mkdir -p ${anboxloc} + mkdir -p $(dirname ${initshloc}) + [ -f ${initshloc} ] && rm ${initshloc} + cp ${initsh} ${initshloc} + chown 100000:100000 ${initshloc} + chmod +x ${initshloc} + ''; + + serviceConfig = { + ExecStart = '' + ${pkgs.anbox}/bin/anbox container-manager \ + --data-path=${anboxloc} \ + --android-image=${finalImage} \ + --container-network-address=${cfg.ipv4.container.address} \ + --container-network-gateway=${cfg.ipv4.gateway.address} \ + --container-network-dns-servers=${cfg.ipv4.dns} \ + --use-rootfs-overlay \ + --privileged \ + --daemon + ''; + }; }; - }; }; } diff --git a/nixos/modules/virtualisation/appvm.nix b/nixos/modules/virtualisation/appvm.nix index 852244c5d98b36..ef255dca43263d 100644 --- a/nixos/modules/virtualisation/appvm.nix +++ b/nixos/modules/virtualisation/appvm.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -6,7 +11,8 @@ let cfg = config.virtualisation.appvm; -in { +in +{ options = { virtualisation.appvm = { @@ -46,4 +52,3 @@ in { }; } - diff --git a/nixos/modules/virtualisation/azure-bootstrap-blobs.nix b/nixos/modules/virtualisation/azure-bootstrap-blobs.nix index 281be9a123185e..bab683ce65f81b 100644 --- a/nixos/modules/virtualisation/azure-bootstrap-blobs.nix +++ b/nixos/modules/virtualisation/azure-bootstrap-blobs.nix @@ -1,3 +1,4 @@ { - "16.03" = "https://nixos.blob.core.windows.net/images/nixos-image-16.03.847.8688c17-x86_64-linux.vhd"; + "16.03" = + "https://nixos.blob.core.windows.net/images/nixos-image-16.03.847.8688c17-x86_64-linux.vhd"; } diff --git a/nixos/modules/virtualisation/build-vm.nix b/nixos/modules/virtualisation/build-vm.nix index 7e279a27364dab..b9db26b78c233f 100644 --- a/nixos/modules/virtualisation/build-vm.nix +++ b/nixos/modules/virtualisation/build-vm.nix @@ -1,4 +1,9 @@ -{ config, extendModules, lib, ... }: +{ + config, + extendModules, + lib, + ... +}: let inherit (lib) @@ -11,13 +16,15 @@ let vmVariantWithBootLoader = vmVariant.extendModules { modules = [ - ({ config, ... }: { - _file = "nixos/default.nix##vmWithBootLoader"; - virtualisation.useBootLoader = true; - virtualisation.useEFIBoot = - config.boot.loader.systemd-boot.enable || - config.boot.loader.efi.canTouchEfiVariables; - }) + ( + { config, ... }: + { + _file = "nixos/default.nix##vmWithBootLoader"; + virtualisation.useBootLoader = true; + virtualisation.useEFIBoot = + config.boot.loader.systemd-boot.enable || config.boot.loader.efi.canTouchEfiVariables; + } + ) ]; }; in @@ -29,7 +36,7 @@ in Machine configuration to be added for the vm script produced by `nixos-rebuild build-vm`. ''; inherit (vmVariant) type; - default = {}; + default = { }; visible = "shallow"; }; @@ -38,7 +45,7 @@ in Machine configuration to be added for the vm script produced by `nixos-rebuild build-vm-with-bootloader`. ''; inherit (vmVariantWithBootLoader) type; - default = {}; + default = { }; visible = "shallow"; }; diff --git a/nixos/modules/virtualisation/container-config.nix b/nixos/modules/virtualisation/container-config.nix index 2460ec45e3fca9..275ae2ec78acdc 100644 --- a/nixos/modules/virtualisation/container-config.nix +++ b/nixos/modules/virtualisation/container-config.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; diff --git a/nixos/modules/virtualisation/containerd.nix b/nixos/modules/virtualisation/containerd.nix index edb22a855d54aa..9e061f85112616 100644 --- a/nixos/modules/virtualisation/containerd.nix +++ b/nixos/modules/virtualisation/containerd.nix @@ -1,20 +1,29 @@ -{ pkgs, lib, config, ... }: +{ + pkgs, + lib, + config, + ... +}: let cfg = config.virtualisation.containerd; - configFile = if cfg.configFile == null then - settingsFormat.generate "containerd.toml" cfg.settings - else - cfg.configFile; + configFile = + if cfg.configFile == null then + settingsFormat.generate "containerd.toml" cfg.settings + else + cfg.configFile; - containerdConfigChecked = pkgs.runCommand "containerd-config-checked.toml" { - nativeBuildInputs = [ pkgs.containerd ]; - } '' - containerd -c ${configFile} config dump >/dev/null - ln -s ${configFile} $out - ''; + containerdConfigChecked = + pkgs.runCommand "containerd-config-checked.toml" + { + nativeBuildInputs = [ pkgs.containerd ]; + } + '' + containerd -c ${configFile} config dump >/dev/null + ln -s ${configFile} $out + ''; - settingsFormat = pkgs.formats.toml {}; + settingsFormat = pkgs.formats.toml { }; in { @@ -24,22 +33,22 @@ in configFile = lib.mkOption { default = null; description = '' - Path to containerd config file. - Setting this option will override any configuration applied by the settings option. + Path to containerd config file. + Setting this option will override any configuration applied by the settings option. ''; type = nullOr path; }; settings = lib.mkOption { type = settingsFormat.type; - default = {}; + default = { }; description = '' Verbatim lines to add to containerd.toml ''; }; args = lib.mkOption { - default = {}; + default = { }; description = "extra args to append to the containerd cmdline"; type = attrsOf str; }; @@ -55,9 +64,8 @@ in settings = { version = 2; plugins."io.containerd.grpc.v1.cri" = { - containerd.snapshotter = - lib.mkIf config.boot.zfs.enabled (lib.mkOptionDefault "zfs"); - cni.bin_dir = lib.mkOptionDefault "${pkgs.cni-plugins}/bin"; + containerd.snapshotter = lib.mkIf config.boot.zfs.enabled (lib.mkOptionDefault "zfs"); + cni.bin_dir = lib.mkOptionDefault "${pkgs.cni-plugins}/bin"; }; }; }; @@ -67,14 +75,23 @@ in systemd.services.containerd = { description = "containerd - container runtime"; wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "local-fs.target" "dbus.service" ]; - path = with pkgs; [ - containerd - runc - iptables - ] ++ lib.optional config.boot.zfs.enabled config.boot.zfs.package; + after = [ + "network.target" + "local-fs.target" + "dbus.service" + ]; + path = + with pkgs; + [ + containerd + runc + iptables + ] + ++ lib.optional config.boot.zfs.enabled config.boot.zfs.package; serviceConfig = { - ExecStart = ''${pkgs.containerd}/bin/containerd ${lib.concatStringsSep " " (lib.cli.toGNUCommandLine {} cfg.args)}''; + ExecStart = ''${pkgs.containerd}/bin/containerd ${ + lib.concatStringsSep " " (lib.cli.toGNUCommandLine { } cfg.args) + }''; Delegate = "yes"; KillMode = "process"; Type = "notify"; diff --git a/nixos/modules/virtualisation/containers.nix b/nixos/modules/virtualisation/containers.nix index c3639f660dfe35..4e07ec3d32bd62 100644 --- a/nixos/modules/virtualisation/containers.nix +++ b/nixos/modules/virtualisation/containers.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.virtualisation.containers; @@ -13,14 +18,13 @@ in options.virtualisation.containers = { - enable = - mkOption { - type = types.bool; - default = false; - description = '' - This option enables the common /etc/containers configuration module. - ''; - }; + enable = mkOption { + type = types.bool; + default = false; + description = '' + This option enables the common /etc/containers configuration module. + ''; + }; ociSeccompBpfHook.enable = mkOption { type = types.bool; @@ -59,7 +63,10 @@ in registries = { search = mkOption { type = types.listOf types.str; - default = [ "docker.io" "quay.io" ]; + default = [ + "docker.io" + "quay.io" + ]; description = '' List of repositories to search. ''; @@ -110,11 +117,13 @@ in virtualisation.containers.containersConf.settings = { network.cni_plugin_dirs = map (p: "${lib.getBin p}/bin") cfg.containersConf.cniPlugins; - engine = { - init_path = "${pkgs.catatonit}/bin/catatonit"; - } // lib.optionalAttrs cfg.ociSeccompBpfHook.enable { - hooks_dir = [ config.boot.kernelPackages.oci-seccomp-bpf-hook ]; - }; + engine = + { + init_path = "${pkgs.catatonit}/bin/catatonit"; + } + // lib.optionalAttrs cfg.ociSeccompBpfHook.enable { + hooks_dir = [ config.boot.kernelPackages.oci-seccomp-bpf-hook ]; + }; }; virtualisation.containers.storage.settings.storage = { @@ -124,19 +133,19 @@ in }; environment.etc = { - "containers/containers.conf".source = - toml.generate "containers.conf" cfg.containersConf.settings; + "containers/containers.conf".source = toml.generate "containers.conf" cfg.containersConf.settings; - "containers/storage.conf".source = - toml.generate "storage.conf" cfg.storage.settings; + "containers/storage.conf".source = toml.generate "storage.conf" cfg.storage.settings; "containers/registries.conf".source = toml.generate "registries.conf" { registries = lib.mapAttrs (n: v: { registries = v; }) cfg.registries; }; "containers/policy.json".source = - if cfg.policy != { } then pkgs.writeText "policy.json" (builtins.toJSON cfg.policy) - else "${pkgs.skopeo.policy}/default-policy.json"; + if cfg.policy != { } then + pkgs.writeText "policy.json" (builtins.toJSON cfg.policy) + else + "${pkgs.skopeo.policy}/default-policy.json"; }; }; diff --git a/nixos/modules/virtualisation/cri-o.nix b/nixos/modules/virtualisation/cri-o.nix index 78f414ffce6b60..973bccc83891fa 100644 --- a/nixos/modules/virtualisation/cri-o.nix +++ b/nixos/modules/virtualisation/cri-o.nix @@ -1,11 +1,17 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.virtualisation.cri-o; crioPackage = pkgs.cri-o.override { - extraPackages = cfg.extraPackages + extraPackages = + cfg.extraPackages ++ lib.optional (config.boot.supportedFilesystems.zfs or false) config.boot.zfs.package; }; @@ -22,13 +28,27 @@ in enable = mkEnableOption "Container Runtime Interface for OCI (CRI-O)"; storageDriver = mkOption { - type = types.enum [ "aufs" "btrfs" "devmapper" "overlay" "vfs" "zfs" ]; + type = types.enum [ + "aufs" + "btrfs" + "devmapper" + "overlay" + "vfs" + "zfs" + ]; default = "overlay"; description = "Storage driver to be used"; }; logLevel = mkOption { - type = types.enum [ "trace" "debug" "info" "warn" "error" "fatal" ]; + type = types.enum [ + "trace" + "debug" + "info" + "warn" + "error" + "fatal" + ]; default = "info"; description = "Log level to be used"; }; @@ -94,7 +114,10 @@ in }; config = mkIf cfg.enable { - environment.systemPackages = [ cfg.package pkgs.cri-tools ]; + environment.systemPackages = [ + cfg.package + pkgs.cri-tools + ]; environment.etc."crictl.yaml".source = "${cfg.package}/etc/crictl.yaml"; @@ -116,9 +139,7 @@ in log_level = cfg.logLevel; manage_ns_lifecycle = true; pinns_path = "${cfg.package}/bin/pinns"; - hooks_dir = - optional (config.virtualisation.containers.ociSeccompBpfHook.enable) - config.boot.kernelPackages.oci-seccomp-bpf-hook; + hooks_dir = optional (config.virtualisation.containers.ociSeccompBpfHook.enable) config.boot.kernelPackages.oci-seccomp-bpf-hook; default_runtime = mkIf (cfg.runtime != null) cfg.runtime; runtimes = mkIf (cfg.runtime != null) { @@ -127,8 +148,10 @@ in }; }; - environment.etc."cni/net.d/10-crio-bridge.conflist".source = "${cfg.package}/etc/cni/net.d/10-crio-bridge.conflist"; - environment.etc."cni/net.d/99-loopback.conflist".source = "${cfg.package}/etc/cni/net.d/99-loopback.conflist"; + environment.etc."cni/net.d/10-crio-bridge.conflist".source = + "${cfg.package}/etc/cni/net.d/10-crio-bridge.conflist"; + environment.etc."cni/net.d/99-loopback.conflist".source = + "${cfg.package}/etc/cni/net.d/99-loopback.conflist"; environment.etc."crio/crio.conf.d/00-default.conf".source = cfgFile; # Enable common /etc/containers configuration diff --git a/nixos/modules/virtualisation/digital-ocean-init.nix b/nixos/modules/virtualisation/digital-ocean-init.nix index b8ccd218d20a2b..b28e512255e388 100644 --- a/nixos/modules/virtualisation/digital-ocean-init.nix +++ b/nixos/modules/virtualisation/digital-ocean-init.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; let cfg = config.virtualisation.digitalOcean; @@ -10,7 +15,8 @@ let ]; } ''; -in { +in +{ options.virtualisation.digitalOcean.rebuildFromUserData = mkOption { type = types.bool; default = true; @@ -37,7 +43,10 @@ in { wantedBy = [ "network-online.target" ]; unitConfig = { ConditionPathExists = "!/etc/nixos/do-userdata.nix"; - After = [ "digitalocean-metadata.service" "network-online.target" ]; + After = [ + "digitalocean-metadata.service" + "network-online.target" + ]; Requires = [ "digitalocean-metadata.service" ]; X-StopOnRemoval = false; }; @@ -46,7 +55,14 @@ in { RemainAfterExit = true; }; restartIfChanged = false; - path = [ pkgs.jq pkgs.gnused pkgs.gnugrep config.systemd.package config.nix.package config.system.build.nixos-rebuild ]; + path = [ + pkgs.jq + pkgs.gnused + pkgs.gnugrep + config.systemd.package + config.nix.package + config.system.build.nixos-rebuild + ]; environment = { HOME = "/root"; NIX_PATH = concatStringsSep ":" [ @@ -88,8 +104,11 @@ in { else echo "no user data is available" fi - ''; + ''; }; }; - meta.maintainers = with maintainers; [ arianvp eamsden ]; + meta.maintainers = with maintainers; [ + arianvp + eamsden + ]; } diff --git a/nixos/modules/virtualisation/docker-image.nix b/nixos/modules/virtualisation/docker-image.nix index baac3a35a78e40..31136231339cd6 100644 --- a/nixos/modules/virtualisation/docker-image.nix +++ b/nixos/modules/virtualisation/docker-image.nix @@ -5,11 +5,10 @@ ../profiles/docker-container.nix # FIXME, shouldn't include something from profiles/ ]; - boot.postBootCommands = - '' - # Set virtualisation to docker - echo "docker" > /run/systemd/container - ''; + boot.postBootCommands = '' + # Set virtualisation to docker + echo "docker" > /run/systemd/container + ''; # Iptables do not work in Docker. networking.firewall.enable = false; diff --git a/nixos/modules/virtualisation/docker-rootless.nix b/nixos/modules/virtualisation/docker-rootless.nix index 15b9f16eefefcb..c1d8ea38a0bb02 100644 --- a/nixos/modules/virtualisation/docker-rootless.nix +++ b/nixos/modules/virtualisation/docker-rootless.nix @@ -1,9 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.virtualisation.docker.rootless; proxy_env = config.networking.proxy.envVars; - settingsFormat = pkgs.formats.json {}; + settingsFormat = pkgs.formats.json { }; daemonSettingsFile = settingsFormat.generate "daemon.json" cfg.daemon.settings; in diff --git a/nixos/modules/virtualisation/ec2-amis.nix b/nixos/modules/virtualisation/ec2-amis.nix index 1ffb326ba7a87a..e94560c9897103 100644 --- a/nixos/modules/virtualisation/ec2-amis.nix +++ b/nixos/modules/virtualisation/ec2-amis.nix @@ -6,4 +6,4 @@ let doAllVersions = mapAttrs (versionName: doRegion); doRegion = mapAttrs (regionName: systems: systems.x86_64-linux); in - doAllVersions everything +doAllVersions everything diff --git a/nixos/modules/virtualisation/ec2-data.nix b/nixos/modules/virtualisation/ec2-data.nix index 2da271a59236f3..e3df23dfff6a76 100644 --- a/nixos/modules/virtualisation/ec2-data.nix +++ b/nixos/modules/virtualisation/ec2-data.nix @@ -2,7 +2,12 @@ # authorized client key and host name of virtual machines running on # Amazon EC2, Eucalyptus and OpenStack Compute (Nova). -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -13,83 +18,84 @@ with lib; config = { - systemd.services.apply-ec2-data = - { description = "Apply EC2 Data"; - - wantedBy = [ "multi-user.target" "sshd.service" ]; - before = [ "sshd.service" ]; - after = ["fetch-ec2-metadata.service"]; - - path = [ pkgs.iproute2 ]; - - script = - '' - ${optionalString (config.networking.hostName == "") '' - echo "setting host name..." - if [ -s /etc/ec2-metadata/hostname ]; then - ${pkgs.nettools}/bin/hostname $(cat /etc/ec2-metadata/hostname) - fi - ''} - - if ! [ -e /root/.ssh/authorized_keys ]; then - echo "obtaining SSH key..." - mkdir -p /root/.ssh - chmod 0700 /root/.ssh - if [ -s /etc/ec2-metadata/public-keys-0-openssh-key ]; then - (umask 177; cat /etc/ec2-metadata/public-keys-0-openssh-key >> /root/.ssh/authorized_keys) - echo "new key added to authorized_keys" - fi - fi - - # Extract the intended SSH host key for this machine from - # the supplied user data, if available. Otherwise sshd will - # generate one normally. - userData=/etc/ec2-metadata/user-data - - mkdir -p /etc/ssh - chmod 0755 /etc/ssh - - if [ -s "$userData" ]; then - key="$(sed 's/|/\n/g; s/SSH_HOST_DSA_KEY://; t; d' $userData)" - key_pub="$(sed 's/SSH_HOST_DSA_KEY_PUB://; t; d' $userData)" - if [ -n "$key" ] && [ -n "$key_pub" ] && [ ! -e /etc/ssh/ssh_host_dsa_key ]; then - (umask 077; echo "$key" > /etc/ssh/ssh_host_dsa_key) - echo "$key_pub" > /etc/ssh/ssh_host_dsa_key.pub - fi - - key="$(sed 's/|/\n/g; s/SSH_HOST_ED25519_KEY://; t; d' $userData)" - key_pub="$(sed 's/SSH_HOST_ED25519_KEY_PUB://; t; d' $userData)" - if [ -n "$key" ] && [ -n "$key_pub" ] && [ ! -e /etc/ssh/ssh_host_ed25519_key ]; then - (umask 077; echo "$key" > /etc/ssh/ssh_host_ed25519_key) - echo "$key_pub" > /etc/ssh/ssh_host_ed25519_key.pub - fi + systemd.services.apply-ec2-data = { + description = "Apply EC2 Data"; + + wantedBy = [ + "multi-user.target" + "sshd.service" + ]; + before = [ "sshd.service" ]; + after = [ "fetch-ec2-metadata.service" ]; + + path = [ pkgs.iproute2 ]; + + script = '' + ${optionalString (config.networking.hostName == "") '' + echo "setting host name..." + if [ -s /etc/ec2-metadata/hostname ]; then + ${pkgs.nettools}/bin/hostname $(cat /etc/ec2-metadata/hostname) + fi + ''} + + if ! [ -e /root/.ssh/authorized_keys ]; then + echo "obtaining SSH key..." + mkdir -p /root/.ssh + chmod 0700 /root/.ssh + if [ -s /etc/ec2-metadata/public-keys-0-openssh-key ]; then + (umask 177; cat /etc/ec2-metadata/public-keys-0-openssh-key >> /root/.ssh/authorized_keys) + echo "new key added to authorized_keys" fi - ''; - - serviceConfig.Type = "oneshot"; - serviceConfig.RemainAfterExit = true; - }; - - systemd.services.print-host-key = - { description = "Print SSH Host Key"; - wantedBy = [ "multi-user.target" ]; - after = [ "sshd.service" ]; - script = - '' - # Print the host public key on the console so that the user - # can obtain it securely by parsing the output of - # ec2-get-console-output. - echo "-----BEGIN SSH HOST KEY FINGERPRINTS-----" > /dev/console - for i in /etc/ssh/ssh_host_*_key.pub; do - ${config.programs.ssh.package}/bin/ssh-keygen -l -f "$i" || true > /dev/console - done - echo "-----END SSH HOST KEY FINGERPRINTS-----" > /dev/console - ''; - serviceConfig.Type = "oneshot"; - serviceConfig.RemainAfterExit = true; - }; + fi + + # Extract the intended SSH host key for this machine from + # the supplied user data, if available. Otherwise sshd will + # generate one normally. + userData=/etc/ec2-metadata/user-data + + mkdir -p /etc/ssh + chmod 0755 /etc/ssh + + if [ -s "$userData" ]; then + key="$(sed 's/|/\n/g; s/SSH_HOST_DSA_KEY://; t; d' $userData)" + key_pub="$(sed 's/SSH_HOST_DSA_KEY_PUB://; t; d' $userData)" + if [ -n "$key" ] && [ -n "$key_pub" ] && [ ! -e /etc/ssh/ssh_host_dsa_key ]; then + (umask 077; echo "$key" > /etc/ssh/ssh_host_dsa_key) + echo "$key_pub" > /etc/ssh/ssh_host_dsa_key.pub + fi + + key="$(sed 's/|/\n/g; s/SSH_HOST_ED25519_KEY://; t; d' $userData)" + key_pub="$(sed 's/SSH_HOST_ED25519_KEY_PUB://; t; d' $userData)" + if [ -n "$key" ] && [ -n "$key_pub" ] && [ ! -e /etc/ssh/ssh_host_ed25519_key ]; then + (umask 077; echo "$key" > /etc/ssh/ssh_host_ed25519_key) + echo "$key_pub" > /etc/ssh/ssh_host_ed25519_key.pub + fi + fi + ''; + + serviceConfig.Type = "oneshot"; + serviceConfig.RemainAfterExit = true; + }; + + systemd.services.print-host-key = { + description = "Print SSH Host Key"; + wantedBy = [ "multi-user.target" ]; + after = [ "sshd.service" ]; + script = '' + # Print the host public key on the console so that the user + # can obtain it securely by parsing the output of + # ec2-get-console-output. + echo "-----BEGIN SSH HOST KEY FINGERPRINTS-----" > /dev/console + for i in /etc/ssh/ssh_host_*_key.pub; do + ${config.programs.ssh.package}/bin/ssh-keygen -l -f "$i" || true > /dev/console + done + echo "-----END SSH HOST KEY FINGERPRINTS-----" > /dev/console + ''; + serviceConfig.Type = "oneshot"; + serviceConfig.RemainAfterExit = true; + }; }; - meta.maintainers = with maintainers; [ arianvp ]; + meta.maintainers = with maintainers; [ arianvp ]; } diff --git a/nixos/modules/virtualisation/ecs-agent.nix b/nixos/modules/virtualisation/ecs-agent.nix index ad23cbedcca728..a7cb9487c9beef 100644 --- a/nixos/modules/virtualisation/ecs-agent.nix +++ b/nixos/modules/virtualisation/ecs-agent.nix @@ -1,10 +1,16 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: with lib; let cfg = config.services.ecs-agent; -in { +in +{ options.services.ecs-agent = { enable = mkEnableOption "Amazon ECS agent"; @@ -13,7 +19,7 @@ in { extra-environment = mkOption { type = types.attrsOf types.str; description = "The environment the ECS agent should run with. See the ECS agent documentation for keys that work here."; - default = {}; + default = { }; }; }; @@ -24,7 +30,7 @@ in { systemd.services.ecs-agent = { inherit (cfg.package.meta) description; - after = [ "network.target" ]; + after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; environment = cfg.extra-environment; diff --git a/nixos/modules/virtualisation/gce-images.nix b/nixos/modules/virtualisation/gce-images.nix index 7b027619a44368..79631ed025df32 100644 --- a/nixos/modules/virtualisation/gce-images.nix +++ b/nixos/modules/virtualisation/gce-images.nix @@ -1,17 +1,20 @@ -let self = { - "14.12" = "gs://nixos-cloud-images/nixos-14.12.471.1f09b77-x86_64-linux.raw.tar.gz"; - "15.09" = "gs://nixos-cloud-images/nixos-15.09.425.7870f20-x86_64-linux.raw.tar.gz"; - "16.03" = "gs://nixos-cloud-images/nixos-image-16.03.847.8688c17-x86_64-linux.raw.tar.gz"; - "17.03" = "gs://nixos-cloud-images/nixos-image-17.03.1082.4aab5c5798-x86_64-linux.raw.tar.gz"; - "18.03" = "gs://nixos-cloud-images/nixos-image-18.03.132536.fdb5ba4cdf9-x86_64-linux.raw.tar.gz"; - "18.09" = "gs://nixos-cloud-images/nixos-image-18.09.1228.a4c4cbb613c-x86_64-linux.raw.tar.gz"; +let + self = { + "14.12" = "gs://nixos-cloud-images/nixos-14.12.471.1f09b77-x86_64-linux.raw.tar.gz"; + "15.09" = "gs://nixos-cloud-images/nixos-15.09.425.7870f20-x86_64-linux.raw.tar.gz"; + "16.03" = "gs://nixos-cloud-images/nixos-image-16.03.847.8688c17-x86_64-linux.raw.tar.gz"; + "17.03" = "gs://nixos-cloud-images/nixos-image-17.03.1082.4aab5c5798-x86_64-linux.raw.tar.gz"; + "18.03" = "gs://nixos-cloud-images/nixos-image-18.03.132536.fdb5ba4cdf9-x86_64-linux.raw.tar.gz"; + "18.09" = "gs://nixos-cloud-images/nixos-image-18.09.1228.a4c4cbb613c-x86_64-linux.raw.tar.gz"; - # This format will be handled by the upcoming NixOPS 2.0 release. - # The old images based on a GS object are deprecated. - "20.09" = { - project = "nixos-cloud"; - name = "nixos-image-20-09-3531-3858fbc08e6-x86-64-linux"; - }; + # This format will be handled by the upcoming NixOPS 2.0 release. + # The old images based on a GS object are deprecated. + "20.09" = { + project = "nixos-cloud"; + name = "nixos-image-20-09-3531-3858fbc08e6-x86-64-linux"; + }; - latest = self."20.09"; -}; in self + latest = self."20.09"; + }; +in +self diff --git a/nixos/modules/virtualisation/grow-partition.nix b/nixos/modules/virtualisation/grow-partition.nix index 444c0bc1630e6e..ad0b47d0ba132c 100644 --- a/nixos/modules/virtualisation/grow-partition.nix +++ b/nixos/modules/virtualisation/grow-partition.nix @@ -1,3 +1,4 @@ # This profile is deprecated, use boot.growPartition directly. -builtins.trace "the profile is deprecated, use boot.growPartition instead" -{ } +builtins.trace + "the profile is deprecated, use boot.growPartition instead" + { } diff --git a/nixos/modules/virtualisation/kvmgt.nix b/nixos/modules/virtualisation/kvmgt.nix index 7d795f8ff5d724..5dfac60c1c6936 100644 --- a/nixos/modules/virtualisation/kvmgt.nix +++ b/nixos/modules/virtualisation/kvmgt.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -14,7 +19,8 @@ let }; }; -in { +in +{ options = { virtualisation.kvmgt = { enable = mkEnableOption '' @@ -29,7 +35,7 @@ in { description = "PCI ID of graphics card. You can figure it with {command}`ls /sys/class/mdev_bus`."; }; vgpus = mkOption { - default = {}; + default = { }; type = with types; attrsOf (submodule [ { options = vgpuOptions; } ]); description = '' Virtual GPUs to be used in Qemu. You can find devices via {command}`ls /sys/bus/pci/devices/*/mdev_supported_types` @@ -55,13 +61,25 @@ in { SUBSYSTEM=="vfio", OWNER="root", GROUP="kvm" ''; - systemd = let - vgpus = listToAttrs (flatten (mapAttrsToList - (mdev: opt: map (id: nameValuePair "kvmgt-${id}" { inherit mdev; uuid = id; }) opt.uuid) - cfg.vgpus)); - in { - paths = mapAttrs (_: opt: - { + systemd = + let + vgpus = listToAttrs ( + flatten ( + mapAttrsToList ( + mdev: opt: + map ( + id: + nameValuePair "kvmgt-${id}" { + inherit mdev; + uuid = id; + } + ) opt.uuid + ) cfg.vgpus + ) + ); + in + { + paths = mapAttrs (_: opt: { description = "KVMGT VGPU ${opt.uuid} path"; wantedBy = [ "multi-user.target" ]; pathConfig = { @@ -69,8 +87,7 @@ in { }; }) vgpus; - services = mapAttrs (_: opt: - { + services = mapAttrs (_: opt: { description = "KVMGT VGPU ${opt.uuid}"; serviceConfig = { Type = "oneshot"; @@ -79,7 +96,7 @@ in { ExecStop = "${pkgs.runtimeShell} -c 'echo 1 > /sys/bus/pci/devices/${cfg.device}/${opt.uuid}/remove'"; }; }) vgpus; - }; + }; }; meta.maintainers = with maintainers; [ patryk27 ]; diff --git a/nixos/modules/virtualisation/linode-config.nix b/nixos/modules/virtualisation/linode-config.nix index 209bff57ea8be6..a6dbe4cbb8f0f7 100644 --- a/nixos/modules/virtualisation/linode-config.nix +++ b/nixos/modules/virtualisation/linode-config.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; { imports = [ ../profiles/qemu-guest.nix ]; @@ -35,7 +40,7 @@ with lib; autoResize = true; }; - swapDevices = mkDefault [{ device = "/dev/sdb"; }]; + swapDevices = mkDefault [ { device = "/dev/sdb"; } ]; # Enable LISH and Linode Booting w/ GRUB boot = { diff --git a/nixos/modules/virtualisation/lxc-image-metadata.nix b/nixos/modules/virtualisation/lxc-image-metadata.nix index c80077dc18e2b8..c7c56aa5273a97 100644 --- a/nixos/modules/virtualisation/lxc-image-metadata.nix +++ b/nixos/modules/virtualisation/lxc-image-metadata.nix @@ -123,9 +123,7 @@ in contents = [ { source = toYAML "metadata.yaml" { - architecture = builtins.elemAt (builtins.match "^([a-z0-9_]+).+" ( - toString pkgs.stdenv.hostPlatform.system - )) 0; + architecture = builtins.elemAt (builtins.match "^([a-z0-9_]+).+" (toString pkgs.stdenv.hostPlatform.system)) 0; creation_date = 1; properties = { description = "${config.system.nixos.distroName} ${config.system.nixos.codeName} ${config.system.nixos.label} ${pkgs.stdenv.hostPlatform.system}"; diff --git a/nixos/modules/virtualisation/lxd-agent.nix b/nixos/modules/virtualisation/lxd-agent.nix index 4bcec117aba97d..50d9a5f26fe99d 100644 --- a/nixos/modules/virtualisation/lxd-agent.nix +++ b/nixos/modules/virtualisation/lxd-agent.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.virtualisation.lxd.agent; @@ -44,7 +49,8 @@ let # Fix up permissions. chown -R root:root "$PREFIX" ''; -in { +in +{ options = { virtualisation.lxd.agent.enable = lib.mkEnableOption "LXD agent"; }; @@ -54,9 +60,13 @@ in { systemd.services.lxd-agent = { enable = true; wantedBy = [ "multi-user.target" ]; - before = [ "shutdown.target" ] ++ lib.optionals config.services.cloud-init.enable [ - "cloud-init.target" "cloud-init.service" "cloud-init-local.service" - ]; + before = + [ "shutdown.target" ] + ++ lib.optionals config.services.cloud-init.enable [ + "cloud-init.target" + "cloud-init.service" + "cloud-init-local.service" + ]; conflicts = [ "shutdown.target" ]; path = [ pkgs.kmod diff --git a/nixos/modules/virtualisation/lxd-virtual-machine.nix b/nixos/modules/virtualisation/lxd-virtual-machine.nix index 138a8589971880..156b69713acd25 100644 --- a/nixos/modules/virtualisation/lxd-virtual-machine.nix +++ b/nixos/modules/virtualisation/lxd-virtual-machine.nix @@ -1,11 +1,14 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - serialDevice = - if pkgs.stdenv.hostPlatform.isx86 - then "ttyS0" - else "ttyAMA0"; # aarch64 -in { + serialDevice = if pkgs.stdenv.hostPlatform.isx86 then "ttyS0" else "ttyAMA0"; # aarch64 +in +{ imports = [ ./lxc-instance-common.nix @@ -39,7 +42,10 @@ in { # image building needs to know what device to install bootloader on boot.loader.grub.device = "/dev/vda"; - boot.kernelParams = ["console=tty1" "console=${serialDevice}"]; + boot.kernelParams = [ + "console=tty1" + "console=${serialDevice}" + ]; services.udev.extraRules = '' SUBSYSTEM=="cpu", CONST{arch}=="x86-64", TEST=="online", ATTR{online}=="0", ATTR{online}="1" diff --git a/nixos/modules/virtualisation/lxd.nix b/nixos/modules/virtualisation/lxd.nix index bdcd60a0560f4d..24d9701b06d626 100644 --- a/nixos/modules/virtualisation/lxd.nix +++ b/nixos/modules/virtualisation/lxd.nix @@ -1,13 +1,23 @@ # Systemd services for lxd. -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.virtualisation.lxd; - preseedFormat = pkgs.formats.yaml {}; -in { + preseedFormat = pkgs.formats.yaml { }; +in +{ imports = [ - (lib.mkRemovedOptionModule [ "virtualisation" "lxd" "zfsPackage" ] "Override zfs in an overlay instead to override it globally") + (lib.mkRemovedOptionModule [ + "virtualisation" + "lxd" + "zfsPackage" + ] "Override zfs in an overlay instead to override it globally") ]; options = { @@ -64,9 +74,11 @@ in { }; preseed = lib.mkOption { - type = lib.types.nullOr (lib.types.submodule { - freeformType = preseedFormat.type; - }); + type = lib.types.nullOr ( + lib.types.submodule { + freeformType = preseedFormat.type; + } + ); default = null; @@ -189,8 +201,7 @@ in { ]; documentation = [ "man:lxd(1)" ]; - path = [ pkgs.util-linux ] - ++ lib.optional cfg.zfsSupport config.boot.zfs.package; + path = [ pkgs.util-linux ] ++ lib.optional cfg.zfsSupport config.boot.zfs.package; environment = lib.mkIf (cfg.ui.enable) { "LXD_UI" = cfg.ui.package; @@ -211,8 +222,7 @@ in { # By default, `lxd` loads configuration files from hard-coded # `/usr/share/lxc/config` - since this is a no-go for us, we have to # explicitly tell it where the actual configuration files are - Environment = lib.mkIf (config.virtualisation.lxc.lxcfs.enable) - "LXD_LXC_TEMPLATE_CONFIG=${pkgs.lxcfs}/share/lxc/config"; + Environment = lib.mkIf (config.virtualisation.lxc.lxcfs.enable) "LXD_LXC_TEMPLATE_CONFIG=${pkgs.lxcfs}/share/lxc/config"; }; unitConfig.ConditionPathExists = "!/var/lib/incus/.migrated-from-lxd"; @@ -220,9 +230,9 @@ in { systemd.services.lxd-preseed = lib.mkIf (cfg.preseed != null) { description = "LXD initialization with preseed file"; - wantedBy = ["multi-user.target"]; - requires = ["lxd.service"]; - after = ["lxd.service"]; + wantedBy = [ "multi-user.target" ]; + requires = [ "lxd.service" ]; + after = [ "lxd.service" ]; script = '' ${pkgs.coreutils}/bin/cat ${preseedFormat.generate "lxd-preseed.yaml" cfg.preseed} | ${cfg.package}/bin/lxd init --preseed @@ -233,11 +243,21 @@ in { }; }; - users.groups.lxd = {}; + users.groups.lxd = { }; users.users.root = { - subUidRanges = [ { startUid = 1000000; count = 65536; } ]; - subGidRanges = [ { startGid = 1000000; count = 65536; } ]; + subUidRanges = [ + { + startUid = 1000000; + count = 65536; + } + ]; + subGidRanges = [ + { + startGid = 1000000; + count = 65536; + } + ]; }; boot.kernel.sysctl = lib.mkIf cfg.recommendedSysctlSettings { @@ -251,7 +271,12 @@ in { "kernel.keys.maxkeys" = 2000; }; - boot.kernelModules = [ "veth" "xt_comment" "xt_CHECKSUM" "xt_MASQUERADE" "vhost_vsock" ] - ++ lib.optionals (!config.networking.nftables.enable) [ "iptable_mangle" ]; + boot.kernelModules = [ + "veth" + "xt_comment" + "xt_CHECKSUM" + "xt_MASQUERADE" + "vhost_vsock" + ] ++ lib.optionals (!config.networking.nftables.enable) [ "iptable_mangle" ]; }; } diff --git a/nixos/modules/virtualisation/multipass.nix b/nixos/modules/virtualisation/multipass.nix index 8a55282c88d8ce..9613010f0f939c 100644 --- a/nixos/modules/virtualisation/multipass.nix +++ b/nixos/modules/virtualisation/multipass.nix @@ -1,7 +1,8 @@ -{ config -, lib -, pkgs -, ... +{ + config, + lib, + pkgs, + ... }: let @@ -13,7 +14,13 @@ in enable = lib.mkEnableOption "Multipass, a simple manager for virtualised Ubuntu instances"; logLevel = lib.mkOption { - type = lib.types.enum [ "error" "warning" "info" "debug" "trace" ]; + type = lib.types.enum [ + "error" + "warning" + "info" + "debug" + "trace" + ]; default = "debug"; description = '' The logging verbosity of the multipassd binary. diff --git a/nixos/modules/virtualisation/oci-common.nix b/nixos/modules/virtualisation/oci-common.nix index a620df063151e2..d92cda7de437cd 100644 --- a/nixos/modules/virtualisation/oci-common.nix +++ b/nixos/modules/virtualisation/oci-common.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.oci; diff --git a/nixos/modules/virtualisation/openstack-config.nix b/nixos/modules/virtualisation/openstack-config.nix index e522f5218a75d8..caa3cbba6a6ba0 100644 --- a/nixos/modules/virtualisation/openstack-config.nix +++ b/nixos/modules/virtualisation/openstack-config.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: # image metadata: # hw_firmware_type=uefi @@ -73,7 +78,10 @@ in path = [ pkgs.wget ]; description = "Fetch Metadata on startup"; wantedBy = [ "multi-user.target" ]; - before = [ "apply-ec2-data.service" "amazon-init.service" ]; + before = [ + "apply-ec2-data.service" + "amazon-init.service" + ]; wants = [ "network-online.target" ]; after = [ "network-online.target" ]; script = metadataFetcher; diff --git a/nixos/modules/virtualisation/openstack-options.nix b/nixos/modules/virtualisation/openstack-options.nix index a06a113e252e45..9d1b1efd676d3b 100644 --- a/nixos/modules/virtualisation/openstack-options.nix +++ b/nixos/modules/virtualisation/openstack-options.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let inherit (lib) literalExpression types; in @@ -25,21 +30,23 @@ in default = { }; - type = types.attrsOf (types.submodule { - options = { - mount = lib.mkOption { - description = "Where to mount this dataset."; - type = types.nullOr types.str; - default = null; - }; + type = types.attrsOf ( + types.submodule { + options = { + mount = lib.mkOption { + description = "Where to mount this dataset."; + type = types.nullOr types.str; + default = null; + }; - properties = lib.mkOption { - description = "Properties to set on this dataset."; - type = types.attrsOf types.str; - default = { }; + properties = lib.mkOption { + description = "Properties to set on this dataset."; + type = types.attrsOf types.str; + default = { }; + }; }; - }; - }); + } + ); }; }; @@ -59,13 +66,16 @@ in fileSystems = let - mountable = lib.filterAttrs (_: value: ((value.mount or null) != null)) config.openstack.zfs.datasets; + mountable = lib.filterAttrs ( + _: value: ((value.mount or null) != null) + ) config.openstack.zfs.datasets; in - lib.mapAttrs' - (dataset: opts: lib.nameValuePair opts.mount { + lib.mapAttrs' ( + dataset: opts: + lib.nameValuePair opts.mount { device = dataset; fsType = "zfs"; - }) - mountable; + } + ) mountable; }; } diff --git a/nixos/modules/virtualisation/openvswitch.nix b/nixos/modules/virtualisation/openvswitch.nix index e0cedce091399d..498044ce43c883 100644 --- a/nixos/modules/virtualisation/openvswitch.nix +++ b/nixos/modules/virtualisation/openvswitch.nix @@ -1,13 +1,19 @@ # Systemd services for openvswitch -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.virtualisation.vswitch; -in { +in +{ options.virtualisation.vswitch = { enable = mkOption { @@ -16,7 +22,7 @@ in { description = '' Whether to enable Open vSwitch. A configuration daemon (ovs-server) will be started. - ''; + ''; }; resetOnStart = mkOption { @@ -25,106 +31,113 @@ in { description = '' Whether to reset the Open vSwitch configuration database to a default configuration on every start of the systemd `ovsdb.service`. - ''; + ''; }; package = mkPackageOption pkgs "openvswitch" { }; }; - config = mkIf cfg.enable (let - - # Where the communication sockets live - runDir = "/run/openvswitch"; + config = mkIf cfg.enable ( + let + + # Where the communication sockets live + runDir = "/run/openvswitch"; + + # The path to the an initialized version of the database + db = pkgs.stdenv.mkDerivation { + name = "vswitch.db"; + dontUnpack = true; + buildPhase = "true"; + buildInputs = with pkgs; [ + cfg.package + ]; + installPhase = "mkdir -p $out"; + }; - # The path to the an initialized version of the database - db = pkgs.stdenv.mkDerivation { - name = "vswitch.db"; - dontUnpack = true; - buildPhase = "true"; - buildInputs = with pkgs; [ - cfg.package + in + { + environment.systemPackages = [ cfg.package ]; + boot.kernelModules = [ + "tun" + "openvswitch" ]; - installPhase = "mkdir -p $out"; - }; - in { - environment.systemPackages = [ cfg.package ]; - boot.kernelModules = [ "tun" "openvswitch" ]; - - boot.extraModulePackages = [ cfg.package ]; - - systemd.services.ovsdb = { - description = "Open_vSwitch Database Server"; - wantedBy = [ "multi-user.target" ]; - after = [ "systemd-udev-settle.service" ]; - path = [ cfg.package ]; - restartTriggers = [ db cfg.package ]; - # Create the config database - preStart = - '' - mkdir -p ${runDir} - mkdir -p /var/db/openvswitch - chmod +w /var/db/openvswitch - ${optionalString cfg.resetOnStart "rm -f /var/db/openvswitch/conf.db"} - if [[ ! -e /var/db/openvswitch/conf.db ]]; then - ${cfg.package}/bin/ovsdb-tool create \ - "/var/db/openvswitch/conf.db" \ - "${cfg.package}/share/openvswitch/vswitch.ovsschema" - fi - chmod -R +w /var/db/openvswitch - if ${cfg.package}/bin/ovsdb-tool needs-conversion /var/db/openvswitch/conf.db | grep -q "yes" - then - echo "Performing database upgrade" - ${cfg.package}/bin/ovsdb-tool convert /var/db/openvswitch/conf.db - else - echo "Database already up to date" - fi + boot.extraModulePackages = [ cfg.package ]; + + systemd.services.ovsdb = { + description = "Open_vSwitch Database Server"; + wantedBy = [ "multi-user.target" ]; + after = [ "systemd-udev-settle.service" ]; + path = [ cfg.package ]; + restartTriggers = [ + db + cfg.package + ]; + # Create the config database + preStart = '' + mkdir -p ${runDir} + mkdir -p /var/db/openvswitch + chmod +w /var/db/openvswitch + ${optionalString cfg.resetOnStart "rm -f /var/db/openvswitch/conf.db"} + if [[ ! -e /var/db/openvswitch/conf.db ]]; then + ${cfg.package}/bin/ovsdb-tool create \ + "/var/db/openvswitch/conf.db" \ + "${cfg.package}/share/openvswitch/vswitch.ovsschema" + fi + chmod -R +w /var/db/openvswitch + if ${cfg.package}/bin/ovsdb-tool needs-conversion /var/db/openvswitch/conf.db | grep -q "yes" + then + echo "Performing database upgrade" + ${cfg.package}/bin/ovsdb-tool convert /var/db/openvswitch/conf.db + else + echo "Database already up to date" + fi ''; - serviceConfig = { - ExecStart = - '' - ${cfg.package}/bin/ovsdb-server \ - --remote=punix:${runDir}/db.sock \ - --private-key=db:Open_vSwitch,SSL,private_key \ - --certificate=db:Open_vSwitch,SSL,certificate \ - --bootstrap-ca-cert=db:Open_vSwitch,SSL,ca_cert \ - --unixctl=ovsdb.ctl.sock \ - --pidfile=/run/openvswitch/ovsdb.pid \ - --detach \ - /var/db/openvswitch/conf.db + serviceConfig = { + ExecStart = '' + ${cfg.package}/bin/ovsdb-server \ + --remote=punix:${runDir}/db.sock \ + --private-key=db:Open_vSwitch,SSL,private_key \ + --certificate=db:Open_vSwitch,SSL,certificate \ + --bootstrap-ca-cert=db:Open_vSwitch,SSL,ca_cert \ + --unixctl=ovsdb.ctl.sock \ + --pidfile=/run/openvswitch/ovsdb.pid \ + --detach \ + /var/db/openvswitch/conf.db ''; - Restart = "always"; - RestartSec = 3; - PIDFile = "/run/openvswitch/ovsdb.pid"; - # Use service type 'forking' to correctly determine when ovsdb-server is ready. - Type = "forking"; + Restart = "always"; + RestartSec = 3; + PIDFile = "/run/openvswitch/ovsdb.pid"; + # Use service type 'forking' to correctly determine when ovsdb-server is ready. + Type = "forking"; + }; + postStart = '' + ${cfg.package}/bin/ovs-vsctl --timeout 3 --retry --no-wait init + ''; }; - postStart = '' - ${cfg.package}/bin/ovs-vsctl --timeout 3 --retry --no-wait init - ''; - }; - systemd.services.ovs-vswitchd = { - description = "Open_vSwitch Daemon"; - wantedBy = [ "multi-user.target" ]; - bindsTo = [ "ovsdb.service" ]; - after = [ "ovsdb.service" ]; - path = [ cfg.package ]; - serviceConfig = { - ExecStart = '' - ${cfg.package}/bin/ovs-vswitchd \ - --pidfile=/run/openvswitch/ovs-vswitchd.pid \ - --detach - ''; - PIDFile = "/run/openvswitch/ovs-vswitchd.pid"; - # Use service type 'forking' to correctly determine when vswitchd is ready. - Type = "forking"; - Restart = "always"; - RestartSec = 3; + systemd.services.ovs-vswitchd = { + description = "Open_vSwitch Daemon"; + wantedBy = [ "multi-user.target" ]; + bindsTo = [ "ovsdb.service" ]; + after = [ "ovsdb.service" ]; + path = [ cfg.package ]; + serviceConfig = { + ExecStart = '' + ${cfg.package}/bin/ovs-vswitchd \ + --pidfile=/run/openvswitch/ovs-vswitchd.pid \ + --detach + ''; + PIDFile = "/run/openvswitch/ovs-vswitchd.pid"; + # Use service type 'forking' to correctly determine when vswitchd is ready. + Type = "forking"; + Restart = "always"; + RestartSec = 3; + }; }; - }; - }); + } + ); imports = [ (mkRemovedOptionModule [ "virtualisation" "vswitch" "ipsec" ] '' diff --git a/nixos/modules/virtualisation/parallels-guest.nix b/nixos/modules/virtualisation/parallels-guest.nix index 91a0532fbaab75..4a16f63028e117 100644 --- a/nixos/modules/virtualisation/parallels-guest.nix +++ b/nixos/modules/virtualisation/parallels-guest.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; @@ -9,7 +14,11 @@ in { imports = [ - (mkRemovedOptionModule [ "hardware" "parallels" "autoMountShares" ] "Shares are always automatically mounted since Parallels Desktop 20.") + (mkRemovedOptionModule [ + "hardware" + "parallels" + "autoMountShares" + ] "Shares are always automatically mounted since Parallels Desktop 20.") ]; options = { @@ -45,8 +54,11 @@ in boot.extraModulePackages = [ prl-tools ]; - boot.kernelModules = [ "prl_fs" "prl_fs_freeze" "prl_tg" ] - ++ optional (pkgs.stdenv.hostPlatform.system == "aarch64-linux") "prl_notifier"; + boot.kernelModules = [ + "prl_fs" + "prl_fs_freeze" + "prl_tg" + ] ++ optional (pkgs.stdenv.hostPlatform.system == "aarch64-linux") "prl_notifier"; services.timesyncd.enable = false; diff --git a/nixos/modules/virtualisation/podman/network-socket-ghostunnel.nix b/nixos/modules/virtualisation/podman/network-socket-ghostunnel.nix index ade4926c94cd44..d5b4bef5f0d99f 100644 --- a/nixos/modules/virtualisation/podman/network-socket-ghostunnel.nix +++ b/nixos/modules/virtualisation/podman/network-socket-ghostunnel.nix @@ -1,4 +1,9 @@ -{ config, lib, pkg, ... }: +{ + config, + lib, + pkg, + ... +}: let inherit (lib) mkOption diff --git a/nixos/modules/virtualisation/podman/network-socket.nix b/nixos/modules/virtualisation/podman/network-socket.nix index 4a6f05e9a2f20b..8aad9cf7bef888 100644 --- a/nixos/modules/virtualisation/podman/network-socket.nix +++ b/nixos/modules/virtualisation/podman/network-socket.nix @@ -1,4 +1,9 @@ -{ config, lib, pkg, ... }: +{ + config, + lib, + pkg, + ... +}: let inherit (lib) mkOption @@ -87,8 +92,7 @@ in }; config = { - networking.firewall.allowedTCPPorts = - lib.optional (cfg.enable && cfg.openFirewall) cfg.port; + networking.firewall.allowedTCPPorts = lib.optional (cfg.enable && cfg.openFirewall) cfg.port; }; meta.maintainers = lib.teams.podman.members ++ [ lib.maintainers.roberth ]; diff --git a/nixos/modules/virtualisation/proxmox-image.nix b/nixos/modules/virtualisation/proxmox-image.nix index 5b28bccfd06456..cb83a9e5ef29fe 100644 --- a/nixos/modules/virtualisation/proxmox-image.nix +++ b/nixos/modules/virtualisation/proxmox-image.nix @@ -370,6 +370,7 @@ with lib; qemuGuest.enable = true; }; - proxmox.qemuExtraConf.${cfg.cloudInit.device} = "${cfg.cloudInit.defaultStorage}:vm-9999-cloudinit,media=cdrom"; + proxmox.qemuExtraConf.${cfg.cloudInit.device} = + "${cfg.cloudInit.defaultStorage}:vm-9999-cloudinit,media=cdrom"; }; } diff --git a/nixos/modules/virtualisation/qemu-guest-agent.nix b/nixos/modules/virtualisation/qemu-guest-agent.nix index fb65d327e7f218..9f12177922bed3 100644 --- a/nixos/modules/virtualisation/qemu-guest-agent.nix +++ b/nixos/modules/virtualisation/qemu-guest-agent.nix @@ -1,22 +1,27 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: with lib; let cfg = config.services.qemuGuest; -in { +in +{ options.services.qemuGuest = { - enable = mkOption { - type = types.bool; - default = false; - description = "Whether to enable the qemu guest agent."; - }; - package = mkPackageOption pkgs [ "qemu_kvm" "ga" ] { }; + enable = mkOption { + type = types.bool; + default = false; + description = "Whether to enable the qemu guest agent."; + }; + package = mkPackageOption pkgs [ "qemu_kvm" "ga" ] { }; }; - config = mkIf cfg.enable ( - mkMerge [ + config = mkIf cfg.enable (mkMerge [ { services.udev.extraRules = '' @@ -35,6 +40,5 @@ in { }; }; } - ] - ); + ]); } diff --git a/nixos/modules/virtualisation/spice-usb-redirection.nix b/nixos/modules/virtualisation/spice-usb-redirection.nix index 1631a91ccf8637..d6ea49be69fd3a 100644 --- a/nixos/modules/virtualisation/spice-usb-redirection.nix +++ b/nixos/modules/virtualisation/spice-usb-redirection.nix @@ -1,4 +1,9 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { options.virtualisation.spiceUSBRedirection.enable = lib.mkOption { type = lib.types.bool; diff --git a/nixos/modules/virtualisation/vagrant-guest.nix b/nixos/modules/virtualisation/vagrant-guest.nix index 120a2a2324d213..d4686a678181b2 100644 --- a/nixos/modules/virtualisation/vagrant-guest.nix +++ b/nixos/modules/virtualisation/vagrant-guest.nix @@ -30,14 +30,17 @@ in ]; users.extraUsers.vagrant = { - isNormalUser = true; - createHome = true; - description = "Vagrant user account"; - extraGroups = [ "users" "wheel" ]; - home = "/home/vagrant"; - password = "vagrant"; + isNormalUser = true; + createHome = true; + description = "Vagrant user account"; + extraGroups = [ + "users" + "wheel" + ]; + home = "/home/vagrant"; + password = "vagrant"; useDefaultShell = true; - uid = 1000; + uid = 1000; }; systemd.services.install-vagrant-ssh-key = { diff --git a/nixos/modules/virtualisation/vagrant-virtualbox-image.nix b/nixos/modules/virtualisation/vagrant-virtualbox-image.nix index 78c228bc46fb04..47a479e98cdb0f 100644 --- a/nixos/modules/virtualisation/vagrant-virtualbox-image.nix +++ b/nixos/modules/virtualisation/vagrant-virtualbox-image.nix @@ -1,6 +1,11 @@ # Vagrant + VirtualBox -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: { imports = [ @@ -23,12 +28,9 @@ # generate the box v1 format which is much easier to generate # https://www.vagrantup.com/docs/boxes/format.html image.extension = lib.mkOverride 999 "${config.image.baseName}.box"; - system.nixos.tags = [ "vagrant"]; + system.nixos.tags = [ "vagrant" ]; system.build.image = lib.mkOverride 999 config.system.build.vagrantVirtualbox; - system.build.vagrantVirtualbox = pkgs.runCommand - config.image.fileName - {} - '' + system.build.vagrantVirtualbox = pkgs.runCommand config.image.fileName { } '' mkdir workdir cd workdir diff --git a/nixos/modules/virtualisation/vmware-guest.nix b/nixos/modules/virtualisation/vmware-guest.nix index 5379a481be5b53..5b9f309f153af3 100644 --- a/nixos/modules/virtualisation/vmware-guest.nix +++ b/nixos/modules/virtualisation/vmware-guest.nix @@ -1,6 +1,21 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let - inherit (lib) getExe' literalExpression mkEnableOption mkIf mkOption mkRenamedOptionModule optionals optionalString types; + inherit (lib) + getExe' + literalExpression + mkEnableOption + mkIf + mkOption + mkRenamedOptionModule + optionals + optionalString + types + ; cfg = config.virtualisation.vmware.guest; xf86inputvmmouse = pkgs.xorg.xf86inputvmmouse; in @@ -25,36 +40,40 @@ in package = mkOption { type = types.package; default = if cfg.headless then pkgs.open-vm-tools-headless else pkgs.open-vm-tools; - defaultText = literalExpression "if config.virtualisation.vmware.headless then pkgs.open-vm-tools-headless else pkgs.open-vm-tools;"; + defaultText = literalExpression "if config.virtualisation.vmware.headless then pkgs.open-vm-tools-headless else pkgs.open-vm-tools;"; example = literalExpression "pkgs.open-vm-tools"; description = "Package providing open-vm-tools."; }; }; config = mkIf cfg.enable { - assertions = [ { - assertion = pkgs.stdenv.hostPlatform.isx86 || pkgs.stdenv.hostPlatform.isAarch64; - message = "VMWare guest is not currently supported on ${pkgs.stdenv.hostPlatform.system}"; - } ]; + assertions = [ + { + assertion = pkgs.stdenv.hostPlatform.isx86 || pkgs.stdenv.hostPlatform.isAarch64; + message = "VMWare guest is not currently supported on ${pkgs.stdenv.hostPlatform.system}"; + } + ]; boot.initrd.availableKernelModules = [ "mptspi" ]; boot.initrd.kernelModules = optionals pkgs.stdenv.hostPlatform.isx86 [ "vmw_pvscsi" ]; environment.systemPackages = [ cfg.package ]; - systemd.services.vmware = - { description = "VMWare Guest Service"; - wantedBy = [ "multi-user.target" ]; - after = [ "display-manager.service" ]; - unitConfig.ConditionVirtualization = "vmware"; - serviceConfig.ExecStart = getExe' cfg.package "vmtoolsd"; - }; + systemd.services.vmware = { + description = "VMWare Guest Service"; + wantedBy = [ "multi-user.target" ]; + after = [ "display-manager.service" ]; + unitConfig.ConditionVirtualization = "vmware"; + serviceConfig.ExecStart = getExe' cfg.package "vmtoolsd"; + }; # Mount the vmblock for drag-and-drop and copy-and-paste. systemd.mounts = mkIf (!cfg.headless) [ { description = "VMware vmblock fuse mount"; - documentation = [ "https://github.com/vmware/open-vm-tools/blob/master/open-vm-tools/vmblock-fuse/design.txt" ]; + documentation = [ + "https://github.com/vmware/open-vm-tools/blob/master/open-vm-tools/vmblock-fuse/design.txt" + ]; unitConfig.ConditionVirtualization = "vmware"; what = getExe' cfg.package "vmware-vmblock-fuse"; where = "/run/vmblock-fuse"; @@ -65,11 +84,11 @@ in ]; security.wrappers.vmware-user-suid-wrapper = mkIf (!cfg.headless) { - setuid = true; - owner = "root"; - group = "root"; - source = getExe' cfg.package "vmware-user-suid-wrapper"; - }; + setuid = true; + owner = "root"; + group = "root"; + source = getExe' cfg.package "vmware-user-suid-wrapper"; + }; environment.etc.vmware-tools.source = "${cfg.package}/etc/vmware-tools/*"; @@ -77,17 +96,17 @@ in modules = optionals pkgs.stdenv.hostPlatform.isx86 [ xf86inputvmmouse ]; config = optionalString (pkgs.stdenv.hostPlatform.isx86) '' - Section "InputClass" - Identifier "VMMouse" - MatchDevicePath "/dev/input/event*" - MatchProduct "ImPS/2 Generic Wheel Mouse" - Driver "vmmouse" - EndSection - ''; + Section "InputClass" + Identifier "VMMouse" + MatchDevicePath "/dev/input/event*" + MatchProduct "ImPS/2 Generic Wheel Mouse" + Driver "vmmouse" + EndSection + ''; displayManager.sessionCommands = '' - ${getExe' cfg.package "vmware-user-suid-wrapper"} - ''; + ${getExe' cfg.package "vmware-user-suid-wrapper"} + ''; }; services.udev.packages = [ cfg.package ]; diff --git a/nixos/modules/virtualisation/vmware-host.nix b/nixos/modules/virtualisation/vmware-host.nix index 5fac2a4a8e8d43..cb7156b740474e 100644 --- a/nixos/modules/virtualisation/vmware-host.nix +++ b/nixos/modules/virtualisation/vmware-host.nix @@ -1,13 +1,17 @@ -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let cfg = config.virtualisation.vmware.host; wrapperDir = "/run/vmware/bin"; # Perfectly fits as /usr/local/bin parentWrapperDir = dirOf wrapperDir; vmwareWrappers = # Needed as hardcoded paths workaround - let mkVmwareSymlink = - program: - '' + let + mkVmwareSymlink = program: '' ln -s "${config.security.wrapperDir}/${program}" $wrapperDir/${program} ''; in @@ -60,7 +64,13 @@ in config = lib.mkIf cfg.enable { boot.extraModulePackages = [ config.boot.kernelPackages.vmware ]; boot.extraModprobeConfig = "alias char-major-10-229 fuse"; - boot.kernelModules = [ "vmw_pvscsi" "vmw_vmci" "vmmon" "vmnet" "fuse" ]; + boot.kernelModules = [ + "vmw_pvscsi" + "vmw_vmci" + "vmmon" + "vmnet" + "fuse" + ]; environment.systemPackages = [ cfg.package ] ++ cfg.extraPackages; services.printing.drivers = [ cfg.package ]; diff --git a/nixos/modules/virtualisation/vmware-image.nix b/nixos/modules/virtualisation/vmware-image.nix index 162d3dc0a0cc02..6eebc6910ff046 100644 --- a/nixos/modules/virtualisation/vmware-image.nix +++ b/nixos/modules/virtualisation/vmware-image.nix @@ -16,7 +16,8 @@ let "streamOptimized" ]; -in { +in +{ imports = [ ../image/file-options.nix (lib.mkRenamedOptionModuleWith { diff --git a/nixos/modules/virtualisation/waydroid.nix b/nixos/modules/virtualisation/waydroid.nix index ae4555f3a6724f..f9891023291c11 100644 --- a/nixos/modules/virtualisation/waydroid.nix +++ b/nixos/modules/virtualisation/waydroid.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.virtualisation.waydroid; @@ -35,7 +40,8 @@ in (kCfg.isEnabled "MEMFD_CREATE") ]; - /* NOTE: we always enable this flag even if CONFIG_PSI_DEFAULT_DISABLED is not on + /* + NOTE: we always enable this flag even if CONFIG_PSI_DEFAULT_DISABLED is not on as reading the kernel config is not always possible and on kernels where it's already on it will be no-op */ diff --git a/nixos/modules/virtualisation/xe-guest-utilities.nix b/nixos/modules/virtualisation/xe-guest-utilities.nix index 14dd25e878cf19..c50a2e7beeb9f2 100644 --- a/nixos/modules/virtualisation/xe-guest-utilities.nix +++ b/nixos/modules/virtualisation/xe-guest-utilities.nix @@ -1,7 +1,13 @@ -{ config, lib, pkgs, ... }: +{ + config, + lib, + pkgs, + ... +}: let cfg = config.services.xe-guest-utilities; -in { +in +{ options = { services.xe-guest-utilities = { enable = lib.mkEnableOption "the XenServer guest utilities daemon"; @@ -13,10 +19,13 @@ in { systemd.services.xe-daemon = { description = "xen daemon file"; - wantedBy = [ "multi-user.target" ]; + wantedBy = [ "multi-user.target" ]; after = [ "xe-linux-distribution.service" ]; requires = [ "proc-xen.mount" ]; - path = [ pkgs.coreutils pkgs.iproute2 ]; + path = [ + pkgs.coreutils + pkgs.iproute2 + ]; serviceConfig = { PIDFile = "/run/xe-daemon.pid"; ExecStart = "${pkgs.xe-guest-utilities}/bin/xe-daemon -p /run/xe-daemon.pid"; @@ -26,9 +35,14 @@ in { systemd.services.xe-linux-distribution = { description = "xen linux distribution service"; - wantedBy = [ "multi-user.target" ]; + wantedBy = [ "multi-user.target" ]; before = [ "xend.service" ]; - path = [ pkgs.xe-guest-utilities pkgs.coreutils pkgs.gawk pkgs.gnused ]; + path = [ + pkgs.xe-guest-utilities + pkgs.coreutils + pkgs.gawk + pkgs.gnused + ]; serviceConfig = { Type = "simple"; RemainAfterExit = "yes"; @@ -37,7 +51,8 @@ in { }; systemd.mounts = [ - { description = "Mount /proc/xen files"; + { + description = "Mount /proc/xen files"; what = "xenfs"; where = "/proc/xen"; type = "xenfs"; diff --git a/nixos/modules/virtualisation/xen-domU.nix b/nixos/modules/virtualisation/xen-domU.nix index ce5a482b1145ba..9c0045e8f8ccc9 100644 --- a/nixos/modules/virtualisation/xen-domU.nix +++ b/nixos/modules/virtualisation/xen-domU.nix @@ -5,10 +5,15 @@ { boot.loader.grub.device = "nodev"; - boot.initrd.kernelModules = - [ "xen-blkfront" "xen-tpmfront" "xen-kbdfront" "xen-fbfront" - "xen-netfront" "xen-pcifront" "xen-scsifront" - ]; + boot.initrd.kernelModules = [ + "xen-blkfront" + "xen-tpmfront" + "xen-kbdfront" + "xen-fbfront" + "xen-netfront" + "xen-pcifront" + "xen-scsifront" + ]; # Send syslog messages to the Xen console. services.syslogd.tty = "hvc0"; diff --git a/nixos/release-combined.nix b/nixos/release-combined.nix index 06403e0fe81ead..3b1c85a4414293 100644 --- a/nixos/release-combined.nix +++ b/nixos/release-combined.nix @@ -2,44 +2,65 @@ # and nixos-14.04). The channel is updated every time the ‘tested’ job # succeeds, and all other jobs have finished (they may fail). -{ nixpkgs ? { outPath = (import ../lib).cleanSource ./..; revCount = 56789; shortRev = "gfedcba"; } -, stableBranch ? false -, supportedSystems ? [ "aarch64-linux" "x86_64-linux" ] -, limitedSupportedSystems ? [ ] +{ + nixpkgs ? { + outPath = (import ../lib).cleanSource ./..; + revCount = 56789; + shortRev = "gfedcba"; + }, + stableBranch ? false, + supportedSystems ? [ + "aarch64-linux" + "x86_64-linux" + ], + limitedSupportedSystems ? [ ], }: let nixpkgsSrc = nixpkgs; # urgh - pkgs = import ./.. {}; + pkgs = import ./.. { }; - removeMaintainers = set: if builtins.isAttrs set - then if (set.type or "") == "derivation" - then set // { meta = builtins.removeAttrs (set.meta or {}) [ "maintainers" ]; } - else pkgs.lib.mapAttrs (n: v: removeMaintainers v) set - else set; + removeMaintainers = + set: + if builtins.isAttrs set then + if (set.type or "") == "derivation" then + set // { meta = builtins.removeAttrs (set.meta or { }) [ "maintainers" ]; } + else + pkgs.lib.mapAttrs (n: v: removeMaintainers v) set + else + set; -in rec { +in +rec { - nixos = removeMaintainers (import ./release.nix { - inherit stableBranch; - supportedSystems = supportedSystems ++ limitedSupportedSystems; - nixpkgs = nixpkgsSrc; - }); + nixos = removeMaintainers ( + import ./release.nix { + inherit stableBranch; + supportedSystems = supportedSystems ++ limitedSupportedSystems; + nixpkgs = nixpkgsSrc; + } + ); - nixpkgs = builtins.removeAttrs (removeMaintainers (import ../pkgs/top-level/release.nix { - inherit supportedSystems; - nixpkgs = nixpkgsSrc; - })) [ "unstable" ]; + nixpkgs = builtins.removeAttrs (removeMaintainers ( + import ../pkgs/top-level/release.nix { + inherit supportedSystems; + nixpkgs = nixpkgsSrc; + } + )) [ "unstable" ]; tested = let onFullSupported = x: map (system: "${x}.${system}") supportedSystems; onAllSupported = x: map (system: "${x}.${system}") (supportedSystems ++ limitedSupportedSystems); - onSystems = systems: x: map (system: "${x}.${system}") - (pkgs.lib.intersectLists systems (supportedSystems ++ limitedSupportedSystems)); - in pkgs.releaseTools.aggregate { + onSystems = + systems: x: + map (system: "${x}.${system}") ( + pkgs.lib.intersectLists systems (supportedSystems ++ limitedSupportedSystems) + ); + in + pkgs.releaseTools.aggregate { name = "nixos-${nixos.channel.version}"; meta = { description = "Release-critical builds for the NixOS channel"; @@ -49,21 +70,21 @@ in rec { [ "nixos.channel" ] (onFullSupported "nixos.dummy") (onAllSupported "nixos.iso_minimal") - (onSystems ["x86_64-linux" "aarch64-linux"] "nixos.amazonImage") + (onSystems [ "x86_64-linux" "aarch64-linux" ] "nixos.amazonImage") (onFullSupported "nixos.iso_plasma6") (onFullSupported "nixos.iso_gnome") (onFullSupported "nixos.manual") - (onSystems ["aarch64-linux"] "nixos.sd_image") + (onSystems [ "aarch64-linux" ] "nixos.sd_image") (onFullSupported "nixos.tests.acme") - (onSystems ["x86_64-linux"] "nixos.tests.boot.biosCdrom") - (onSystems ["x86_64-linux"] "nixos.tests.boot.biosUsb") + (onSystems [ "x86_64-linux" ] "nixos.tests.boot.biosCdrom") + (onSystems [ "x86_64-linux" ] "nixos.tests.boot.biosUsb") (onFullSupported "nixos.tests.boot-stage1") (onFullSupported "nixos.tests.boot.uefiCdrom") (onFullSupported "nixos.tests.boot.uefiUsb") (onFullSupported "nixos.tests.chromium") (onFullSupported "nixos.tests.containers-imperative") (onFullSupported "nixos.tests.containers-ip") - (onSystems ["x86_64-linux"] "nixos.tests.docker") + (onSystems [ "x86_64-linux" ] "nixos.tests.docker") (onFullSupported "nixos.tests.ecryptfs") (onFullSupported "nixos.tests.env") @@ -81,25 +102,25 @@ in rec { (onFullSupported "nixos.tests.gitlab") (onFullSupported "nixos.tests.gnome") (onFullSupported "nixos.tests.gnome-xorg") - (onSystems ["x86_64-linux"] "nixos.tests.hibernate") + (onSystems [ "x86_64-linux" ] "nixos.tests.hibernate") (onFullSupported "nixos.tests.i3wm") - (onSystems ["aarch64-linux"] "nixos.tests.installer.simpleUefiSystemdBoot") - (onSystems ["x86_64-linux"] "nixos.tests.installer.btrfsSimple") - (onSystems ["x86_64-linux"] "nixos.tests.installer.btrfsSubvolDefault") - (onSystems ["x86_64-linux"] "nixos.tests.installer.btrfsSubvolEscape") - (onSystems ["x86_64-linux"] "nixos.tests.installer.btrfsSubvols") - (onSystems ["x86_64-linux"] "nixos.tests.installer.luksroot") - (onSystems ["x86_64-linux"] "nixos.tests.installer.lvm") - (onSystems ["x86_64-linux"] "nixos.tests.installer.separateBootZfs") - (onSystems ["x86_64-linux"] "nixos.tests.installer.separateBootFat") - (onSystems ["x86_64-linux"] "nixos.tests.installer.separateBoot") - (onSystems ["x86_64-linux"] "nixos.tests.installer.simpleLabels") - (onSystems ["x86_64-linux"] "nixos.tests.installer.simpleProvided") - (onSystems ["x86_64-linux"] "nixos.tests.installer.simpleUefiSystemdBoot") - (onSystems ["x86_64-linux"] "nixos.tests.installer.simple") - (onSystems ["x86_64-linux"] "nixos.tests.installer.swraid") - (onSystems ["x86_64-linux"] "nixos.tests.installer.zfsroot") - (onSystems ["x86_64-linux"] "nixos.tests.nixos-rebuild-specialisations") + (onSystems [ "aarch64-linux" ] "nixos.tests.installer.simpleUefiSystemdBoot") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.btrfsSimple") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.btrfsSubvolDefault") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.btrfsSubvolEscape") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.btrfsSubvols") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.luksroot") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.lvm") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.separateBootZfs") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.separateBootFat") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.separateBoot") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.simpleLabels") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.simpleProvided") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.simpleUefiSystemdBoot") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.simple") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.swraid") + (onSystems [ "x86_64-linux" ] "nixos.tests.installer.zfsroot") + (onSystems [ "x86_64-linux" ] "nixos.tests.nixos-rebuild-specialisations") (onFullSupported "nixos.tests.nix-misc.default") (onFullSupported "nixos.tests.ipv6") (onFullSupported "nixos.tests.keymap.azerty") @@ -144,14 +165,14 @@ in rec { (onFullSupported "nixos.tests.networking.networkd.vlan") (onFullSupported "nixos.tests.systemd-networkd-ipv6-prefix-delegation") (onFullSupported "nixos.tests.nfs4.simple") - (onSystems ["x86_64-linux"] "nixos.tests.oci-containers.podman") + (onSystems [ "x86_64-linux" ] "nixos.tests.oci-containers.podman") (onFullSupported "nixos.tests.openssh") (onFullSupported "nixos.tests.pantheon") (onFullSupported "nixos.tests.php.fpm") (onFullSupported "nixos.tests.php.httpd") (onFullSupported "nixos.tests.php.pcre") (onFullSupported "nixos.tests.plasma5") - (onSystems ["x86_64-linux"] "nixos.tests.podman") + (onSystems [ "x86_64-linux" ] "nixos.tests.podman") (onFullSupported "nixos.tests.predictable-interface-names.predictableNetworkd") (onFullSupported "nixos.tests.predictable-interface-names.predictable") (onFullSupported "nixos.tests.predictable-interface-names.unpredictableNetworkd") @@ -168,7 +189,7 @@ in rec { (onFullSupported "nixos.tests.xfce") (onFullSupported "nixpkgs.emacs") (onFullSupported "nixpkgs.jdk") - (onSystems ["x86_64-linux"] "nixpkgs.mesa_i686") # i686 sanity check + useful + (onSystems [ "x86_64-linux" ] "nixpkgs.mesa_i686") # i686 sanity check + useful [ "nixpkgs.tarball" "nixpkgs.release-checks" diff --git a/nixos/release-small.nix b/nixos/release-small.nix index d3a70506ddecb9..d2dc59b8ebabb6 100644 --- a/nixos/release-small.nix +++ b/nixos/release-small.nix @@ -6,9 +6,17 @@ # # nix-build nixos/release-small.nix -A # -{ nixpkgs ? { outPath = (import ../lib).cleanSource ./..; revCount = 56789; shortRev = "gfedcba"; } -, stableBranch ? false -, supportedSystems ? [ "aarch64-linux" "x86_64-linux" ] # no i686-linux +{ + nixpkgs ? { + outPath = (import ../lib).cleanSource ./..; + revCount = 56789; + shortRev = "gfedcba"; + }, + stableBranch ? false, + supportedSystems ? [ + "aarch64-linux" + "x86_64-linux" + ], # no i686-linux }: let @@ -29,10 +37,16 @@ let nixpkgs = nixpkgsSrc; }) [ "unstable" ]; -in rec { +in +rec { nixos = { - inherit (nixos') channel manual options dummy; + inherit (nixos') + channel + manual + options + dummy + ; tests = { inherit (nixos'.tests) acme @@ -48,13 +62,15 @@ in rec { php predictable-interface-names proxy - simple; + simple + ; installer = { inherit (nixos'.tests.installer) lvm separateBoot simple - simpleUefiSystemdBoot; + simpleUefiSystemdBoot + ; }; }; }; @@ -84,58 +100,61 @@ in rec { subversion tarball vim - tests-stdenv-gcc-stageCompare; + tests-stdenv-gcc-stageCompare + ; }; - tested = let - onSupported = x: map (system: "${x}.${system}") supportedSystems; - onSystems = systems: x: map (system: "${x}.${system}") - (pkgs.lib.intersectLists systems supportedSystems); - in pkgs.releaseTools.aggregate { - name = "nixos-${nixos.channel.version}"; - meta = { - description = "Release-critical builds for the NixOS channel"; - maintainers = [ ]; + tested = + let + onSupported = x: map (system: "${x}.${system}") supportedSystems; + onSystems = + systems: x: map (system: "${x}.${system}") (pkgs.lib.intersectLists systems supportedSystems); + in + pkgs.releaseTools.aggregate { + name = "nixos-${nixos.channel.version}"; + meta = { + description = "Release-critical builds for the NixOS channel"; + maintainers = [ ]; + }; + constituents = lib.flatten [ + [ + "nixos.channel" + "nixpkgs.tarball" + "nixpkgs.release-checks" + ] + (map (onSystems [ "x86_64-linux" ]) [ + "nixos.tests.installer.lvm" + "nixos.tests.installer.separateBoot" + "nixos.tests.installer.simple" + ]) + (map onSupported [ + "nixos.dummy" + "nixos.manual" + "nixos.tests.acme" + "nixos.tests.containers-imperative" + "nixos.tests.containers-ip" + "nixos.tests.firewall" + "nixos.tests.ipv6" + "nixos.tests.installer.simpleUefiSystemdBoot" + "nixos.tests.login" + "nixos.tests.misc" + "nixos.tests.nat.firewall" + "nixos.tests.nat.standalone" + "nixos.tests.nfs4.simple" + "nixos.tests.openssh" + "nixos.tests.php.fpm" + "nixos.tests.php.pcre" + "nixos.tests.predictable-interface-names.predictable" + "nixos.tests.predictable-interface-names.predictableNetworkd" + "nixos.tests.predictable-interface-names.unpredictable" + "nixos.tests.predictable-interface-names.unpredictableNetworkd" + "nixos.tests.proxy" + "nixos.tests.simple" + "nixpkgs.jdk" + "nixpkgs.tests-stdenv-gcc-stageCompare" + "nixpkgs.opensshTest" + ]) + ]; }; - constituents = lib.flatten [ - [ - "nixos.channel" - "nixpkgs.tarball" - "nixpkgs.release-checks" - ] - (map (onSystems [ "x86_64-linux" ]) [ - "nixos.tests.installer.lvm" - "nixos.tests.installer.separateBoot" - "nixos.tests.installer.simple" - ]) - (map onSupported [ - "nixos.dummy" - "nixos.manual" - "nixos.tests.acme" - "nixos.tests.containers-imperative" - "nixos.tests.containers-ip" - "nixos.tests.firewall" - "nixos.tests.ipv6" - "nixos.tests.installer.simpleUefiSystemdBoot" - "nixos.tests.login" - "nixos.tests.misc" - "nixos.tests.nat.firewall" - "nixos.tests.nat.standalone" - "nixos.tests.nfs4.simple" - "nixos.tests.openssh" - "nixos.tests.php.fpm" - "nixos.tests.php.pcre" - "nixos.tests.predictable-interface-names.predictable" - "nixos.tests.predictable-interface-names.predictableNetworkd" - "nixos.tests.predictable-interface-names.unpredictable" - "nixos.tests.predictable-interface-names.unpredictableNetworkd" - "nixos.tests.proxy" - "nixos.tests.simple" - "nixpkgs.jdk" - "nixpkgs.tests-stdenv-gcc-stageCompare" - "nixpkgs.opensshTest" - ]) - ]; - }; } diff --git a/nixos/tests/3proxy.nix b/nixos/tests/3proxy.nix index b80b4e166d4810..c888f16f8e1d69 100644 --- a/nixos/tests/3proxy.nix +++ b/nixos/tests/3proxy.nix @@ -1,134 +1,152 @@ -{ lib, pkgs, ... }: { +{ lib, pkgs, ... }: +{ name = "3proxy"; meta.maintainers = with lib.maintainers; [ misuzu ]; nodes = { - peer0 = { lib, ... }: { - networking.useDHCP = false; - networking.interfaces.eth1 = { - ipv4.addresses = [ - { - address = "192.168.0.1"; - prefixLength = 24; - } - { - address = "216.58.211.111"; - prefixLength = 24; - } - ]; + peer0 = + { lib, ... }: + { + networking.useDHCP = false; + networking.interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.0.1"; + prefixLength = 24; + } + { + address = "216.58.211.111"; + prefixLength = 24; + } + ]; + }; }; - }; - peer1 = { lib, ... }: { - networking.useDHCP = false; - networking.interfaces.eth1 = { - ipv4.addresses = [ - { - address = "192.168.0.2"; - prefixLength = 24; - } - { - address = "216.58.211.112"; - prefixLength = 24; - } - ]; - }; - # test that binding to [::] is working when ipv6 is disabled - networking.enableIPv6 = false; - services._3proxy = { - enable = true; - services = [ - { - type = "admin"; - bindPort = 9999; - auth = [ "none" ]; - } - { - type = "proxy"; - bindPort = 3128; - auth = [ "none" ]; - } + peer1 = + { lib, ... }: + { + networking.useDHCP = false; + networking.interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.0.2"; + prefixLength = 24; + } + { + address = "216.58.211.112"; + prefixLength = 24; + } + ]; + }; + # test that binding to [::] is working when ipv6 is disabled + networking.enableIPv6 = false; + services._3proxy = { + enable = true; + services = [ + { + type = "admin"; + bindPort = 9999; + auth = [ "none" ]; + } + { + type = "proxy"; + bindPort = 3128; + auth = [ "none" ]; + } + ]; + }; + networking.firewall.allowedTCPPorts = [ + 3128 + 9999 ]; }; - networking.firewall.allowedTCPPorts = [ 3128 9999 ]; - }; - peer2 = { lib, ... }: { - networking.useDHCP = false; - networking.interfaces.eth1 = { - ipv4.addresses = [ - { - address = "192.168.0.3"; - prefixLength = 24; - } - { - address = "216.58.211.113"; - prefixLength = 24; - } + peer2 = + { lib, ... }: + { + networking.useDHCP = false; + networking.interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.0.3"; + prefixLength = 24; + } + { + address = "216.58.211.113"; + prefixLength = 24; + } + ]; + }; + services._3proxy = { + enable = true; + services = [ + { + type = "admin"; + bindPort = 9999; + auth = [ "none" ]; + } + { + type = "proxy"; + bindPort = 3128; + auth = [ "iponly" ]; + acl = [ + { + rule = "allow"; + } + ]; + } + ]; + }; + networking.firewall.allowedTCPPorts = [ + 3128 + 9999 ]; }; - services._3proxy = { - enable = true; - services = [ - { - type = "admin"; - bindPort = 9999; - auth = [ "none" ]; - } - { - type = "proxy"; - bindPort = 3128; - auth = [ "iponly" ]; - acl = [ - { - rule = "allow"; - } - ]; - } - ]; - }; - networking.firewall.allowedTCPPorts = [ 3128 9999 ]; - }; - peer3 = { lib, pkgs, ... }: { - networking.useDHCP = false; - networking.interfaces.eth1 = { - ipv4.addresses = [ - { - address = "192.168.0.4"; - prefixLength = 24; - } - { - address = "216.58.211.114"; - prefixLength = 24; - } - ]; - }; - services._3proxy = { - enable = true; - usersFile = pkgs.writeText "3proxy.passwd" '' - admin:CR:$1$.GUV4Wvk$WnEVQtaqutD9.beO5ar1W/ - ''; - services = [ - { - type = "admin"; - bindPort = 9999; - auth = [ "none" ]; - } - { - type = "proxy"; - bindPort = 3128; - auth = [ "strong" ]; - acl = [ - { - rule = "allow"; - } - ]; - } + peer3 = + { lib, pkgs, ... }: + { + networking.useDHCP = false; + networking.interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.0.4"; + prefixLength = 24; + } + { + address = "216.58.211.114"; + prefixLength = 24; + } + ]; + }; + services._3proxy = { + enable = true; + usersFile = pkgs.writeText "3proxy.passwd" '' + admin:CR:$1$.GUV4Wvk$WnEVQtaqutD9.beO5ar1W/ + ''; + services = [ + { + type = "admin"; + bindPort = 9999; + auth = [ "none" ]; + } + { + type = "proxy"; + bindPort = 3128; + auth = [ "strong" ]; + acl = [ + { + rule = "allow"; + } + ]; + } + ]; + }; + networking.firewall.allowedTCPPorts = [ + 3128 + 9999 ]; }; - networking.firewall.allowedTCPPorts = [ 3128 9999 ]; - }; }; testScript = '' diff --git a/nixos/tests/aaaaxy.nix b/nixos/tests/aaaaxy.nix index 19861198c3697a..9fa66f6e4e3179 100644 --- a/nixos/tests/aaaaxy.nix +++ b/nixos/tests/aaaaxy.nix @@ -1,4 +1,5 @@ -{ pkgs, lib, ... }: { +{ pkgs, lib, ... }: +{ name = "aaaaxy"; meta.maintainers = with lib.maintainers; [ Luflosi ]; diff --git a/nixos/tests/acme-dns.nix b/nixos/tests/acme-dns.nix index 92d9498fe714e3..16c33c8460e52c 100644 --- a/nixos/tests/acme-dns.nix +++ b/nixos/tests/acme-dns.nix @@ -1,50 +1,58 @@ -import ./make-test-python.nix ({ ... }: { - name = "acme-dns"; - - nodes.machine = { pkgs, ... }: { - services.acme-dns = { - enable = true; - settings = { - general = rec { - domain = "acme-dns.home.arpa"; - nsname = domain; - nsadmin = "admin.home.arpa"; - records = [ - "${domain}. A 127.0.0.1" - "${domain}. AAAA ::1" - "${domain}. NS ${domain}." - ]; +import ./make-test-python.nix ( + { ... }: + { + name = "acme-dns"; + + nodes.machine = + { pkgs, ... }: + { + services.acme-dns = { + enable = true; + settings = { + general = rec { + domain = "acme-dns.home.arpa"; + nsname = domain; + nsadmin = "admin.home.arpa"; + records = [ + "${domain}. A 127.0.0.1" + "${domain}. AAAA ::1" + "${domain}. NS ${domain}." + ]; + }; + logconfig.loglevel = "debug"; + }; }; - logconfig.loglevel = "debug"; + environment.systemPackages = with pkgs; [ + curl + bind + ]; }; - }; - environment.systemPackages = with pkgs; [ curl bind ]; - }; - testScript = '' - import json + testScript = '' + import json - machine.wait_for_unit("acme-dns.service") - machine.wait_for_open_port(53) # dns - machine.wait_for_open_port(8080) # http api + machine.wait_for_unit("acme-dns.service") + machine.wait_for_open_port(53) # dns + machine.wait_for_open_port(8080) # http api - result = machine.succeed("curl --fail -X POST http://localhost:8080/register") - print(result) + result = machine.succeed("curl --fail -X POST http://localhost:8080/register") + print(result) - registration = json.loads(result) + registration = json.loads(result) - machine.succeed(f'dig -t TXT @localhost {registration["fulldomain"]} | grep "SOA" | grep "admin.home.arpa"') + machine.succeed(f'dig -t TXT @localhost {registration["fulldomain"]} | grep "SOA" | grep "admin.home.arpa"') - # acme-dns exspects a TXT value string length of exactly 43 chars - txt = "___dummy_validation_token_for_txt_record___" + # acme-dns exspects a TXT value string length of exactly 43 chars + txt = "___dummy_validation_token_for_txt_record___" - machine.succeed( - "curl --fail -X POST http://localhost:8080/update " - + f' -H "X-Api-User: {registration["username"]}"' - + f' -H "X-Api-Key: {registration["password"]}"' - + f' -d \'{{"subdomain":"{registration["subdomain"]}", "txt":"{txt}"}}\''' - ) + machine.succeed( + "curl --fail -X POST http://localhost:8080/update " + + f' -H "X-Api-User: {registration["username"]}"' + + f' -H "X-Api-Key: {registration["password"]}"' + + f' -d \'{{"subdomain":"{registration["subdomain"]}", "txt":"{txt}"}}\''' + ) - assert txt in machine.succeed(f'dig -t TXT +short @localhost {registration["fulldomain"]}') - ''; -}) + assert txt in machine.succeed(f'dig -t TXT +short @localhost {registration["fulldomain"]}') + ''; + } +) diff --git a/nixos/tests/activation/etc-overlay-immutable.nix b/nixos/tests/activation/etc-overlay-immutable.nix index 882bc651841a6a..da1ea317440c80 100644 --- a/nixos/tests/activation/etc-overlay-immutable.nix +++ b/nixos/tests/activation/etc-overlay-immutable.nix @@ -1,96 +1,100 @@ -{ lib, ... }: { +{ lib, ... }: +{ name = "activation-etc-overlay-immutable"; meta.maintainers = with lib.maintainers; [ nikstur ]; - nodes.machine = { pkgs, ... }: { - system.etc.overlay.enable = true; - system.etc.overlay.mutable = false; - - # Prerequisites - systemd.sysusers.enable = true; - users.mutableUsers = false; - boot.initrd.systemd.enable = true; - boot.kernelPackages = pkgs.linuxPackages_latest; - time.timeZone = "Utc"; - - # The standard resolvconf service tries to write to /etc and crashes, - # which makes nixos-rebuild exit uncleanly when switching into the new generation - services.resolved.enable = true; - - environment.etc = { - "mountpoint/.keep".text = "keep"; - "filemount".text = "keep"; - }; - - specialisation.new-generation.configuration = { - environment.etc."newgen".text = "newgen"; - }; - specialisation.newer-generation.configuration = { - environment.etc."newergen".text = "newergen"; + nodes.machine = + { pkgs, ... }: + { + system.etc.overlay.enable = true; + system.etc.overlay.mutable = false; + + # Prerequisites + systemd.sysusers.enable = true; + users.mutableUsers = false; + boot.initrd.systemd.enable = true; + boot.kernelPackages = pkgs.linuxPackages_latest; + time.timeZone = "Utc"; + + # The standard resolvconf service tries to write to /etc and crashes, + # which makes nixos-rebuild exit uncleanly when switching into the new generation + services.resolved.enable = true; + + environment.etc = { + "mountpoint/.keep".text = "keep"; + "filemount".text = "keep"; + }; + + specialisation.new-generation.configuration = { + environment.etc."newgen".text = "newgen"; + }; + specialisation.newer-generation.configuration = { + environment.etc."newergen".text = "newergen"; + }; }; - }; - testScript = /* python */ '' - newergen = machine.succeed("realpath /run/current-system/specialisation/newer-generation/bin/switch-to-configuration").rstrip() + testScript = # python + '' + newergen = machine.succeed("realpath /run/current-system/specialisation/newer-generation/bin/switch-to-configuration").rstrip() - with subtest("/run/etc-metadata/ is mounted"): - print(machine.succeed("mountpoint /run/etc-metadata")) + with subtest("/run/etc-metadata/ is mounted"): + print(machine.succeed("mountpoint /run/etc-metadata")) - with subtest("No temporary files leaked into stage 2"): - machine.succeed("[ ! -e /etc-metadata-image ]") - machine.succeed("[ ! -e /etc-basedir ]") + with subtest("No temporary files leaked into stage 2"): + machine.succeed("[ ! -e /etc-metadata-image ]") + machine.succeed("[ ! -e /etc-basedir ]") - with subtest("/etc is mounted as an overlay"): - machine.succeed("findmnt --kernel --type overlay /etc") + with subtest("/etc is mounted as an overlay"): + machine.succeed("findmnt --kernel --type overlay /etc") - with subtest("direct symlinks point to the target without indirection"): - assert machine.succeed("readlink -n /etc/localtime") == "/etc/zoneinfo/Utc" + with subtest("direct symlinks point to the target without indirection"): + assert machine.succeed("readlink -n /etc/localtime") == "/etc/zoneinfo/Utc" - with subtest("/etc/mtab points to the right file"): - assert "/proc/mounts" == machine.succeed("readlink --no-newline /etc/mtab") + with subtest("/etc/mtab points to the right file"): + assert "/proc/mounts" == machine.succeed("readlink --no-newline /etc/mtab") - with subtest("Correct mode on the source password files"): - assert machine.succeed("stat -c '%a' /var/lib/nixos/etc/passwd") == "644\n" - assert machine.succeed("stat -c '%a' /var/lib/nixos/etc/group") == "644\n" - assert machine.succeed("stat -c '%a' /var/lib/nixos/etc/shadow") == "0\n" - assert machine.succeed("stat -c '%a' /var/lib/nixos/etc/gshadow") == "0\n" + with subtest("Correct mode on the source password files"): + assert machine.succeed("stat -c '%a' /var/lib/nixos/etc/passwd") == "644\n" + assert machine.succeed("stat -c '%a' /var/lib/nixos/etc/group") == "644\n" + assert machine.succeed("stat -c '%a' /var/lib/nixos/etc/shadow") == "0\n" + assert machine.succeed("stat -c '%a' /var/lib/nixos/etc/gshadow") == "0\n" - with subtest("Password files are symlinks to /var/lib/nixos/etc"): - assert machine.succeed("readlink -f /etc/passwd") == "/var/lib/nixos/etc/passwd\n" - assert machine.succeed("readlink -f /etc/group") == "/var/lib/nixos/etc/group\n" - assert machine.succeed("readlink -f /etc/shadow") == "/var/lib/nixos/etc/shadow\n" - assert machine.succeed("readlink -f /etc/gshadow") == "/var/lib/nixos/etc/gshadow\n" + with subtest("Password files are symlinks to /var/lib/nixos/etc"): + assert machine.succeed("readlink -f /etc/passwd") == "/var/lib/nixos/etc/passwd\n" + assert machine.succeed("readlink -f /etc/group") == "/var/lib/nixos/etc/group\n" + assert machine.succeed("readlink -f /etc/shadow") == "/var/lib/nixos/etc/shadow\n" + assert machine.succeed("readlink -f /etc/gshadow") == "/var/lib/nixos/etc/gshadow\n" - with subtest("switching to the same generation"): - machine.succeed("/run/current-system/bin/switch-to-configuration test") + with subtest("switching to the same generation"): + machine.succeed("/run/current-system/bin/switch-to-configuration test") - with subtest("the initrd didn't get rebuilt"): - machine.succeed("test /run/current-system/initrd -ef /run/current-system/specialisation/new-generation/initrd") + with subtest("the initrd didn't get rebuilt"): + machine.succeed("test /run/current-system/initrd -ef /run/current-system/specialisation/new-generation/initrd") - with subtest("switching to a new generation"): - machine.fail("stat /etc/newgen") + with subtest("switching to a new generation"): + machine.fail("stat /etc/newgen") - machine.succeed("mount -t tmpfs tmpfs /etc/mountpoint") - machine.succeed("touch /etc/mountpoint/extra-file") - machine.succeed("mount --bind /dev/null /etc/filemount") + machine.succeed("mount -t tmpfs tmpfs /etc/mountpoint") + machine.succeed("touch /etc/mountpoint/extra-file") + machine.succeed("mount --bind /dev/null /etc/filemount") - machine.succeed("/run/current-system/specialisation/new-generation/bin/switch-to-configuration switch") + machine.succeed("/run/current-system/specialisation/new-generation/bin/switch-to-configuration switch") - assert machine.succeed("cat /etc/newgen") == "newgen" + assert machine.succeed("cat /etc/newgen") == "newgen" - print(machine.succeed("findmnt /etc/mountpoint")) - print(machine.succeed("ls /etc/mountpoint")) - print(machine.succeed("stat /etc/mountpoint/extra-file")) - print(machine.succeed("findmnt /etc/filemount")) + print(machine.succeed("findmnt /etc/mountpoint")) + print(machine.succeed("ls /etc/mountpoint")) + print(machine.succeed("stat /etc/mountpoint/extra-file")) + print(machine.succeed("findmnt /etc/filemount")) - machine.succeed(f"{newergen} switch") + machine.succeed(f"{newergen} switch") - tmpMounts = machine.succeed("find /tmp -maxdepth 1 -type d -regex '/tmp/nixos-etc\\..*' | wc -l").rstrip() - metaMounts = machine.succeed("find /tmp -maxdepth 1 -type d -regex '/tmp/nixos-etc-metadata\\..*' | wc -l").rstrip() + tmpMounts = machine.succeed("find /tmp -maxdepth 1 -type d -regex '/tmp/nixos-etc\\..*' | wc -l").rstrip() + metaMounts = machine.succeed("find /tmp -maxdepth 1 -type d -regex '/tmp/nixos-etc-metadata\\..*' | wc -l").rstrip() - assert tmpMounts == "0", f"Found {tmpMounts} remaining tmpmounts" - assert metaMounts == "1", f"Found {metaMounts} remaining metamounts" - ''; + assert tmpMounts == "0", f"Found {tmpMounts} remaining tmpmounts" + assert metaMounts == "1", f"Found {metaMounts} remaining metamounts" + ''; } diff --git a/nixos/tests/activation/etc-overlay-mutable.nix b/nixos/tests/activation/etc-overlay-mutable.nix index ef465e3616c354..be87e112089484 100644 --- a/nixos/tests/activation/etc-overlay-mutable.nix +++ b/nixos/tests/activation/etc-overlay-mutable.nix @@ -1,73 +1,77 @@ -{ lib, ... }: { +{ lib, ... }: +{ name = "activation-etc-overlay-mutable"; meta.maintainers = with lib.maintainers; [ nikstur ]; - nodes.machine = { pkgs, ... }: { - system.etc.overlay.enable = true; - system.etc.overlay.mutable = true; - - # Prerequisites - boot.initrd.systemd.enable = true; - boot.kernelPackages = pkgs.linuxPackages_latest; - - specialisation.new-generation.configuration = { - environment.etc."newgen".text = "newgen"; - }; - specialisation.newer-generation.configuration = { - environment.etc."newergen".text = "newergen"; + nodes.machine = + { pkgs, ... }: + { + system.etc.overlay.enable = true; + system.etc.overlay.mutable = true; + + # Prerequisites + boot.initrd.systemd.enable = true; + boot.kernelPackages = pkgs.linuxPackages_latest; + + specialisation.new-generation.configuration = { + environment.etc."newgen".text = "newgen"; + }; + specialisation.newer-generation.configuration = { + environment.etc."newergen".text = "newergen"; + }; }; - }; - testScript = /* python */ '' - newergen = machine.succeed("realpath /run/current-system/specialisation/newer-generation/bin/switch-to-configuration").rstrip() + testScript = # python + '' + newergen = machine.succeed("realpath /run/current-system/specialisation/newer-generation/bin/switch-to-configuration").rstrip() - with subtest("/run/etc-metadata/ is mounted"): - print(machine.succeed("mountpoint /run/etc-metadata")) + with subtest("/run/etc-metadata/ is mounted"): + print(machine.succeed("mountpoint /run/etc-metadata")) - with subtest("No temporary files leaked into stage 2"): - machine.succeed("[ ! -e /etc-metadata-image ]") - machine.succeed("[ ! -e /etc-basedir ]") + with subtest("No temporary files leaked into stage 2"): + machine.succeed("[ ! -e /etc-metadata-image ]") + machine.succeed("[ ! -e /etc-basedir ]") - with subtest("/etc is mounted as an overlay"): - machine.succeed("findmnt --kernel --type overlay /etc") + with subtest("/etc is mounted as an overlay"): + machine.succeed("findmnt --kernel --type overlay /etc") - with subtest("switching to the same generation"): - machine.succeed("/run/current-system/bin/switch-to-configuration test") + with subtest("switching to the same generation"): + machine.succeed("/run/current-system/bin/switch-to-configuration test") - with subtest("the initrd didn't get rebuilt"): - machine.succeed("test /run/current-system/initrd -ef /run/current-system/specialisation/new-generation/initrd") + with subtest("the initrd didn't get rebuilt"): + machine.succeed("test /run/current-system/initrd -ef /run/current-system/specialisation/new-generation/initrd") - with subtest("switching to a new generation"): - machine.fail("stat /etc/newgen") - machine.succeed("echo -n 'mutable' > /etc/mutable") + with subtest("switching to a new generation"): + machine.fail("stat /etc/newgen") + machine.succeed("echo -n 'mutable' > /etc/mutable") - # Directory - machine.succeed("mkdir /etc/mountpoint") - machine.succeed("mount -t tmpfs tmpfs /etc/mountpoint") - machine.succeed("touch /etc/mountpoint/extra-file") + # Directory + machine.succeed("mkdir /etc/mountpoint") + machine.succeed("mount -t tmpfs tmpfs /etc/mountpoint") + machine.succeed("touch /etc/mountpoint/extra-file") - # File - machine.succeed("touch /etc/filemount") - machine.succeed("mount --bind /dev/null /etc/filemount") + # File + machine.succeed("touch /etc/filemount") + machine.succeed("mount --bind /dev/null /etc/filemount") - machine.succeed("/run/current-system/specialisation/new-generation/bin/switch-to-configuration switch") + machine.succeed("/run/current-system/specialisation/new-generation/bin/switch-to-configuration switch") - assert machine.succeed("cat /etc/newgen") == "newgen" - assert machine.succeed("cat /etc/mutable") == "mutable" + assert machine.succeed("cat /etc/newgen") == "newgen" + assert machine.succeed("cat /etc/mutable") == "mutable" - print(machine.succeed("findmnt /etc/mountpoint")) - print(machine.succeed("stat /etc/mountpoint/extra-file")) - print(machine.succeed("findmnt /etc/filemount")) + print(machine.succeed("findmnt /etc/mountpoint")) + print(machine.succeed("stat /etc/mountpoint/extra-file")) + print(machine.succeed("findmnt /etc/filemount")) - machine.succeed(f"{newergen} switch") - assert machine.succeed("cat /etc/newergen") == "newergen" + machine.succeed(f"{newergen} switch") + assert machine.succeed("cat /etc/newergen") == "newergen" - tmpMounts = machine.succeed("find /tmp -maxdepth 1 -type d -regex '/tmp/nixos-etc\\..*' | wc -l").rstrip() - metaMounts = machine.succeed("find /tmp -maxdepth 1 -type d -regex '/tmp/nixos-etc-metadata\\..*' | wc -l").rstrip() + tmpMounts = machine.succeed("find /tmp -maxdepth 1 -type d -regex '/tmp/nixos-etc\\..*' | wc -l").rstrip() + metaMounts = machine.succeed("find /tmp -maxdepth 1 -type d -regex '/tmp/nixos-etc-metadata\\..*' | wc -l").rstrip() - assert tmpMounts == "0", f"Found {tmpMounts} remaining tmpmounts" - assert metaMounts == "1", f"Found {metaMounts} remaining metamounts" - ''; + assert tmpMounts == "0", f"Found {tmpMounts} remaining tmpmounts" + assert metaMounts == "1", f"Found {metaMounts} remaining metamounts" + ''; } diff --git a/nixos/tests/activation/nix-channel.nix b/nixos/tests/activation/nix-channel.nix index d26ea98e56cc57..fac028b326599a 100644 --- a/nixos/tests/activation/nix-channel.nix +++ b/nixos/tests/activation/nix-channel.nix @@ -10,17 +10,19 @@ nix.channel.enable = true; }; - testScript = { nodes, ... }: '' - machine.start(allow_reboot=True) + testScript = + { nodes, ... }: + '' + machine.start(allow_reboot=True) - assert machine.succeed("cat /root/.nix-channels") == "${nodes.machine.system.defaultChannel} nixos\n" + assert machine.succeed("cat /root/.nix-channels") == "${nodes.machine.system.defaultChannel} nixos\n" - nixpkgs_unstable_channel = "https://nixos.org/channels/nixpkgs-unstable nixpkgs" - machine.succeed(f"echo '{nixpkgs_unstable_channel}' > /root/.nix-channels") + nixpkgs_unstable_channel = "https://nixos.org/channels/nixpkgs-unstable nixpkgs" + machine.succeed(f"echo '{nixpkgs_unstable_channel}' > /root/.nix-channels") - machine.reboot() + machine.reboot() - assert machine.succeed("cat /root/.nix-channels") == f"{nixpkgs_unstable_channel}\n" - ''; + assert machine.succeed("cat /root/.nix-channels") == f"{nixpkgs_unstable_channel}\n" + ''; } diff --git a/nixos/tests/activation/perlless.nix b/nixos/tests/activation/perlless.nix index 4d784b4542f459..3e9e9f94583ef3 100644 --- a/nixos/tests/activation/perlless.nix +++ b/nixos/tests/activation/perlless.nix @@ -6,14 +6,16 @@ meta.maintainers = with lib.maintainers; [ nikstur ]; - nodes.machine = { pkgs, modulesPath, ... }: { - imports = [ "${modulesPath}/profiles/perlless.nix" ]; + nodes.machine = + { pkgs, modulesPath, ... }: + { + imports = [ "${modulesPath}/profiles/perlless.nix" ]; - boot.kernelPackages = pkgs.linuxPackages_latest; + boot.kernelPackages = pkgs.linuxPackages_latest; - virtualisation.mountHostNixStore = false; - virtualisation.useNixStoreImage = true; - }; + virtualisation.mountHostNixStore = false; + virtualisation.useNixStoreImage = true; + }; testScript = '' perl_store_paths = machine.succeed("ls /nix/store | grep perl || true") diff --git a/nixos/tests/adguardhome.nix b/nixos/tests/adguardhome.nix index 005d54e17dfdc3..48bed55e3187ad 100644 --- a/nixos/tests/adguardhome.nix +++ b/nixos/tests/adguardhome.nix @@ -2,7 +2,9 @@ name = "adguardhome"; nodes = { - nullConf = { services.adguardhome.enable = true; }; + nullConf = { + services.adguardhome.enable = true; + }; emptyConf = { services.adguardhome = { @@ -38,62 +40,73 @@ }; }; - dhcpConf = { lib, ... }: { - virtualisation.vlans = [ 1 ]; + dhcpConf = + { lib, ... }: + { + virtualisation.vlans = [ 1 ]; - networking = { - # Configure static IP for DHCP server - useDHCP = false; - interfaces."eth1" = lib.mkForce { + networking = { + # Configure static IP for DHCP server useDHCP = false; - ipv4 = { - addresses = [{ - address = "10.0.10.1"; - prefixLength = 24; - }]; - - routes = [{ - address = "10.0.10.0"; - prefixLength = 24; - }]; + interfaces."eth1" = lib.mkForce { + useDHCP = false; + ipv4 = { + addresses = [ + { + address = "10.0.10.1"; + prefixLength = 24; + } + ]; + + routes = [ + { + address = "10.0.10.0"; + prefixLength = 24; + } + ]; + }; }; - }; - # Required for DHCP - firewall.allowedUDPPorts = [ 67 68 ]; - }; + # Required for DHCP + firewall.allowedUDPPorts = [ + 67 + 68 + ]; + }; - services.adguardhome = { - enable = true; - allowDHCP = true; - mutableSettings = false; - settings = { - dns.bootstrap_dns = [ "127.0.0.1" ]; - dhcp = { - # This implicitly enables CAP_NET_RAW - enabled = true; - interface_name = "eth1"; - local_domain_name = "lan"; - dhcpv4 = { - gateway_ip = "10.0.10.1"; - range_start = "10.0.10.100"; - range_end = "10.0.10.101"; - subnet_mask = "255.255.255.0"; + services.adguardhome = { + enable = true; + allowDHCP = true; + mutableSettings = false; + settings = { + dns.bootstrap_dns = [ "127.0.0.1" ]; + dhcp = { + # This implicitly enables CAP_NET_RAW + enabled = true; + interface_name = "eth1"; + local_domain_name = "lan"; + dhcpv4 = { + gateway_ip = "10.0.10.1"; + range_start = "10.0.10.100"; + range_end = "10.0.10.101"; + subnet_mask = "255.255.255.0"; + }; }; }; }; }; - }; - client = { lib, ... }: { - virtualisation.vlans = [ 1 ]; - networking = { - interfaces.eth1 = { - useDHCP = true; - ipv4.addresses = lib.mkForce [ ]; + client = + { lib, ... }: + { + virtualisation.vlans = [ 1 ]; + networking = { + interfaces.eth1 = { + useDHCP = true; + ipv4.addresses = lib.mkForce [ ]; + }; }; }; - }; }; testScript = '' diff --git a/nixos/tests/aesmd.nix b/nixos/tests/aesmd.nix index 848e1c59920146..b7939508b0e397 100644 --- a/nixos/tests/aesmd.nix +++ b/nixos/tests/aesmd.nix @@ -1,44 +1,53 @@ -{ pkgs, lib, ... }: { +{ pkgs, lib, ... }: +{ name = "aesmd"; meta = { - maintainers = with lib.maintainers; [ trundle veehaitch ]; + maintainers = with lib.maintainers; [ + trundle + veehaitch + ]; }; - nodes.machine = { lib, ... }: { - services.aesmd = { - enable = true; - settings = { - defaultQuotingType = "ecdsa_256"; - proxyType = "direct"; - whitelistUrl = "http://nixos.org"; + nodes.machine = + { lib, ... }: + { + services.aesmd = { + enable = true; + settings = { + defaultQuotingType = "ecdsa_256"; + proxyType = "direct"; + whitelistUrl = "http://nixos.org"; + }; }; - }; - - # Should have access to the AESM socket - users.users."sgxtest" = { - isNormalUser = true; - extraGroups = [ "sgx" ]; - }; - # Should NOT have access to the AESM socket - users.users."nosgxtest".isNormalUser = true; - - # We don't have a real SGX machine in NixOS tests - systemd.services.aesmd.unitConfig.AssertPathExists = lib.mkForce [ ]; + # Should have access to the AESM socket + users.users."sgxtest" = { + isNormalUser = true; + extraGroups = [ "sgx" ]; + }; - specialisation = { - withQuoteProvider.configuration = { ... }: { - services.aesmd = { - quoteProviderLibrary = pkgs.sgx-azure-dcap-client; - environment = { - AZDCAP_DEBUG_LOG_LEVEL = "INFO"; + # Should NOT have access to the AESM socket + users.users."nosgxtest".isNormalUser = true; + + # We don't have a real SGX machine in NixOS tests + systemd.services.aesmd.unitConfig.AssertPathExists = lib.mkForce [ ]; + + specialisation = { + withQuoteProvider.configuration = + { ... }: + { + services.aesmd = { + quoteProviderLibrary = pkgs.sgx-azure-dcap-client; + environment = { + AZDCAP_DEBUG_LOG_LEVEL = "INFO"; + }; + }; }; - }; }; }; - }; - testScript = { nodes, ... }: + testScript = + { nodes, ... }: let specialisations = "${nodes.machine.system.build.toplevel}/specialisation"; in diff --git a/nixos/tests/agda.nix b/nixos/tests/agda.nix index a8e90725c06b03..3f48c8353b63db 100644 --- a/nixos/tests/agda.nix +++ b/nixos/tests/agda.nix @@ -1,43 +1,49 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -let - hello-world = pkgs.writeText "hello-world" '' - {-# OPTIONS --guardedness #-} - open import IO - open import Level + let + hello-world = pkgs.writeText "hello-world" '' + {-# OPTIONS --guardedness #-} + open import IO + open import Level - main = run {0ℓ} (putStrLn "Hello World!") - ''; -in -{ - name = "agda"; - meta = with pkgs.lib.maintainers; { - maintainers = [ alexarice turion ]; - }; + main = run {0ℓ} (putStrLn "Hello World!") + ''; + in + { + name = "agda"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + alexarice + turion + ]; + }; - nodes.machine = { pkgs, ... }: { - environment.systemPackages = [ - (pkgs.agda.withPackages { - pkgs = p: [ p.standard-library ]; - }) - ]; - virtualisation.memorySize = 2000; # Agda uses a lot of memory - }; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = [ + (pkgs.agda.withPackages { + pkgs = p: [ p.standard-library ]; + }) + ]; + virtualisation.memorySize = 2000; # Agda uses a lot of memory + }; - testScript = '' - # Minimal script that typechecks - machine.succeed("touch TestEmpty.agda") - machine.succeed("agda TestEmpty.agda") + testScript = '' + # Minimal script that typechecks + machine.succeed("touch TestEmpty.agda") + machine.succeed("agda TestEmpty.agda") - # Hello world - machine.succeed( - "cp ${hello-world} HelloWorld.agda" - ) - machine.succeed("agda -l standard-library -i . -c HelloWorld.agda") - # Check execution - assert "Hello World!" in machine.succeed( - "./HelloWorld" - ), "HelloWorld does not run properly" - ''; -} + # Hello world + machine.succeed( + "cp ${hello-world} HelloWorld.agda" + ) + machine.succeed("agda -l standard-library -i . -c HelloWorld.agda") + # Check execution + assert "Hello World!" in machine.succeed( + "./HelloWorld" + ), "HelloWorld does not run properly" + ''; + } ) diff --git a/nixos/tests/airsonic.nix b/nixos/tests/airsonic.nix index 69f979726bce4b..d214d5d1e1f76b 100644 --- a/nixos/tests/airsonic.nix +++ b/nixos/tests/airsonic.nix @@ -1,29 +1,32 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "airsonic"; - meta = with pkgs.lib.maintainers; { - maintainers = [ sumnerevans ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "airsonic"; + meta = with pkgs.lib.maintainers; { + maintainers = [ sumnerevans ]; + }; - nodes.machine = - { pkgs, ... }: - { - services.airsonic = { - enable = true; - maxMemory = 800; + nodes.machine = + { pkgs, ... }: + { + services.airsonic = { + enable = true; + maxMemory = 800; + }; }; - }; - testScript = '' - def airsonic_is_up(_) -> bool: - status, _ = machine.execute("curl --fail http://localhost:4040/login") - return status == 0 + testScript = '' + def airsonic_is_up(_) -> bool: + status, _ = machine.execute("curl --fail http://localhost:4040/login") + return status == 0 - machine.start() - machine.wait_for_unit("airsonic.service") - machine.wait_for_open_port(4040) + machine.start() + machine.wait_for_unit("airsonic.service") + machine.wait_for_open_port(4040) - with machine.nested("Waiting for UI to work"): - retry(airsonic_is_up) - ''; -}) + with machine.nested("Waiting for UI to work"): + retry(airsonic_is_up) + ''; + } +) diff --git a/nixos/tests/akkoma.nix b/nixos/tests/akkoma.nix index 2a9acd64b7c6c4..1673d13e72ceb9 100644 --- a/nixos/tests/akkoma.nix +++ b/nixos/tests/akkoma.nix @@ -5,120 +5,145 @@ TODO: Test federation. */ -import ./make-test-python.nix ({ pkgs, package ? pkgs.akkoma, confined ? false, ... }: -let - userPassword = "4LKOrGo8SgbPm1a6NclVU5Wb"; - - provisionUser = pkgs.writers.writeBashBin "provisionUser" '' - set -eu -o errtrace -o pipefail - - pleroma_ctl user new jamy jamy@nixos.test --password '${userPassword}' --moderator --admin -y - ''; - - tlsCert = pkgs.runCommand "selfSignedCerts" { - nativeBuildInputs = with pkgs; [ openssl ]; - } '' - mkdir -p $out - openssl req -x509 \ - -subj '/CN=akkoma.nixos.test/' -days 49710 \ - -addext 'subjectAltName = DNS:akkoma.nixos.test' \ - -keyout "$out/key.pem" -newkey ed25519 \ - -out "$out/cert.pem" -noenc - ''; - - sendToot = pkgs.writers.writeBashBin "sendToot" '' - set -eu -o errtrace -o pipefail - - export REQUESTS_CA_BUNDLE="/etc/ssl/certs/ca-certificates.crt" - - ${pkgs.toot}/bin/toot login_cli -i "akkoma.nixos.test" -e "jamy@nixos.test" -p '${userPassword}' - ${pkgs.toot}/bin/toot post "hello world Jamy here" - ${pkgs.toot}/bin/toot timeline -1 | grep -F -q "hello world Jamy here" - - # Test file upload - echo "y" | ${pkgs.toot}/bin/toot upload <(dd if=/dev/zero bs=1024 count=1024 status=none) \ - | grep -F -q "https://akkoma.nixos.test:443/media" - ''; - - checkFe = pkgs.writers.writeBashBin "checkFe" '' - set -eu -o errtrace -o pipefail - - paths=( / /static/{config,styles}.json /pleroma/admin/ ) - - for path in "''${paths[@]}"; do - diff \ - <(${pkgs.curl}/bin/curl -f -S -s -o /dev/null -w '%{response_code}' "https://akkoma.nixos.test$path") \ - <(echo -n 200) - done - ''; - - hosts = nodes: '' - ${nodes.akkoma.networking.primaryIPAddress} akkoma.nixos.test - ${nodes.client.networking.primaryIPAddress} client.nixos.test - ''; -in -{ - name = "akkoma"; - nodes = { - client = { nodes, pkgs, config, ... }: { - security.pki.certificateFiles = [ "${tlsCert}/cert.pem" ]; - networking.extraHosts = hosts nodes; - }; - - akkoma = { nodes, pkgs, config, ... }: { - networking.extraHosts = hosts nodes; - networking.firewall.allowedTCPPorts = [ 443 ]; - environment.systemPackages = with pkgs; [ provisionUser ]; - systemd.services.akkoma.confinement.enable = confined; - - services.akkoma = { - enable = true; - package = package; - config = { - ":pleroma" = { - ":instance" = { - name = "NixOS test Akkoma server"; - description = "NixOS test Akkoma server"; - email = "akkoma@nixos.test"; - notify_email = "akkoma@nixos.test"; - registration_open = true; - }; +import ./make-test-python.nix ( + { + pkgs, + package ? pkgs.akkoma, + confined ? false, + ... + }: + let + userPassword = "4LKOrGo8SgbPm1a6NclVU5Wb"; + + provisionUser = pkgs.writers.writeBashBin "provisionUser" '' + set -eu -o errtrace -o pipefail + + pleroma_ctl user new jamy jamy@nixos.test --password '${userPassword}' --moderator --admin -y + ''; + + tlsCert = + pkgs.runCommand "selfSignedCerts" + { + nativeBuildInputs = with pkgs; [ openssl ]; + } + '' + mkdir -p $out + openssl req -x509 \ + -subj '/CN=akkoma.nixos.test/' -days 49710 \ + -addext 'subjectAltName = DNS:akkoma.nixos.test' \ + -keyout "$out/key.pem" -newkey ed25519 \ + -out "$out/cert.pem" -noenc + ''; + + sendToot = pkgs.writers.writeBashBin "sendToot" '' + set -eu -o errtrace -o pipefail + + export REQUESTS_CA_BUNDLE="/etc/ssl/certs/ca-certificates.crt" + + ${pkgs.toot}/bin/toot login_cli -i "akkoma.nixos.test" -e "jamy@nixos.test" -p '${userPassword}' + ${pkgs.toot}/bin/toot post "hello world Jamy here" + ${pkgs.toot}/bin/toot timeline -1 | grep -F -q "hello world Jamy here" + + # Test file upload + echo "y" | ${pkgs.toot}/bin/toot upload <(dd if=/dev/zero bs=1024 count=1024 status=none) \ + | grep -F -q "https://akkoma.nixos.test:443/media" + ''; + + checkFe = pkgs.writers.writeBashBin "checkFe" '' + set -eu -o errtrace -o pipefail + + paths=( / /static/{config,styles}.json /pleroma/admin/ ) + + for path in "''${paths[@]}"; do + diff \ + <(${pkgs.curl}/bin/curl -f -S -s -o /dev/null -w '%{response_code}' "https://akkoma.nixos.test$path") \ + <(echo -n 200) + done + ''; + + hosts = nodes: '' + ${nodes.akkoma.networking.primaryIPAddress} akkoma.nixos.test + ${nodes.client.networking.primaryIPAddress} client.nixos.test + ''; + in + { + name = "akkoma"; + nodes = { + client = + { + nodes, + pkgs, + config, + ... + }: + { + security.pki.certificateFiles = [ "${tlsCert}/cert.pem" ]; + networking.extraHosts = hosts nodes; + }; - ":media_proxy" = { - enabled = false; + akkoma = + { + nodes, + pkgs, + config, + ... + }: + { + networking.extraHosts = hosts nodes; + networking.firewall.allowedTCPPorts = [ 443 ]; + environment.systemPackages = with pkgs; [ provisionUser ]; + systemd.services.akkoma.confinement.enable = confined; + + services.akkoma = { + enable = true; + package = package; + config = { + ":pleroma" = { + ":instance" = { + name = "NixOS test Akkoma server"; + description = "NixOS test Akkoma server"; + email = "akkoma@nixos.test"; + notify_email = "akkoma@nixos.test"; + registration_open = true; + }; + + ":media_proxy" = { + enabled = false; + }; + + "Pleroma.Web.Endpoint" = { + url.host = "akkoma.nixos.test"; + }; + "Pleroma.Upload" = { + base_url = "https://akkoma.nixos.test:443/media/"; + }; + }; }; - "Pleroma.Web.Endpoint" = { - url.host = "akkoma.nixos.test"; - }; - "Pleroma.Upload" = { - base_url = "https://akkoma.nixos.test:443/media/"; + nginx = { + addSSL = true; + sslCertificate = "${tlsCert}/cert.pem"; + sslCertificateKey = "${tlsCert}/key.pem"; }; }; - }; - nginx = { - addSSL = true; - sslCertificate = "${tlsCert}/cert.pem"; - sslCertificateKey = "${tlsCert}/key.pem"; + services.nginx.enable = true; + services.postgresql.enable = true; }; - }; - - services.nginx.enable = true; - services.postgresql.enable = true; }; - }; - - testScript = { nodes, ... }: '' - start_all() - akkoma.wait_for_unit('akkoma-initdb.service') - akkoma.systemctl('restart akkoma-initdb.service') # test repeated initialisation - akkoma.wait_for_unit('akkoma.service') - akkoma.wait_for_file('/run/akkoma/socket'); - akkoma.succeed('${provisionUser}/bin/provisionUser') - akkoma.wait_for_unit('nginx.service') - client.succeed('${sendToot}/bin/sendToot') - client.succeed('${checkFe}/bin/checkFe') - ''; -}) + testScript = + { nodes, ... }: + '' + start_all() + akkoma.wait_for_unit('akkoma-initdb.service') + akkoma.systemctl('restart akkoma-initdb.service') # test repeated initialisation + akkoma.wait_for_unit('akkoma.service') + akkoma.wait_for_file('/run/akkoma/socket'); + akkoma.succeed('${provisionUser}/bin/provisionUser') + akkoma.wait_for_unit('nginx.service') + client.succeed('${sendToot}/bin/sendToot') + client.succeed('${checkFe}/bin/checkFe') + ''; + } +) diff --git a/nixos/tests/alice-lg.nix b/nixos/tests/alice-lg.nix index 640e60030a04e8..177f7364685d9d 100644 --- a/nixos/tests/alice-lg.nix +++ b/nixos/tests/alice-lg.nix @@ -1,7 +1,11 @@ # This test does a basic functionality check for alice-lg -{ system ? builtins.currentSystem -, pkgs ? import ../.. { inherit system; config = { }; } +{ + system ? builtins.currentSystem, + pkgs ? import ../.. { + inherit system; + config = { }; + }, }: let diff --git a/nixos/tests/all-terminfo.nix b/nixos/tests/all-terminfo.nix index 2f5e56f09f26bd..9eddb6be94f60f 100644 --- a/nixos/tests/all-terminfo.nix +++ b/nixos/tests/all-terminfo.nix @@ -1,35 +1,48 @@ -import ./make-test-python.nix ({ pkgs, ... }: rec { - name = "all-terminfo"; - meta = with pkgs.lib.maintainers; { - maintainers = [ jkarlson ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + rec { + name = "all-terminfo"; + meta = with pkgs.lib.maintainers; { + maintainers = [ jkarlson ]; + }; - nodes.machine = { pkgs, config, lib, ... }: - let - infoFilter = name: drv: - let - o = builtins.tryEval drv; - in - o.success && - lib.isDerivation o.value && - o.value ? outputs && - builtins.elem "terminfo" o.value.outputs && - !o.value.meta.broken; - terminfos = lib.filterAttrs infoFilter pkgs; - excludedTerminfos = lib.filterAttrs (_: drv: !(builtins.elem drv.terminfo config.environment.systemPackages)) terminfos; - includedOuts = lib.filterAttrs (_: drv: builtins.elem drv.out config.environment.systemPackages) terminfos; - in - { - environment = { - enableAllTerminfo = true; - etc."terminfo-missing".text = builtins.concatStringsSep "\n" (builtins.attrNames excludedTerminfos); - etc."terminfo-extra-outs".text = builtins.concatStringsSep "\n" (builtins.attrNames includedOuts); + nodes.machine = + { + pkgs, + config, + lib, + ... + }: + let + infoFilter = + name: drv: + let + o = builtins.tryEval drv; + in + o.success + && lib.isDerivation o.value + && o.value ? outputs + && builtins.elem "terminfo" o.value.outputs + && !o.value.meta.broken; + terminfos = lib.filterAttrs infoFilter pkgs; + excludedTerminfos = lib.filterAttrs ( + _: drv: !(builtins.elem drv.terminfo config.environment.systemPackages) + ) terminfos; + includedOuts = lib.filterAttrs ( + _: drv: builtins.elem drv.out config.environment.systemPackages + ) terminfos; + in + { + environment = { + enableAllTerminfo = true; + etc."terminfo-missing".text = builtins.concatStringsSep "\n" (builtins.attrNames excludedTerminfos); + etc."terminfo-extra-outs".text = builtins.concatStringsSep "\n" (builtins.attrNames includedOuts); + }; }; - }; - testScript = - '' + testScript = '' machine.fail("grep . /etc/terminfo-missing >&2") machine.fail("grep . /etc/terminfo-extra-outs >&2") ''; -}) + } +) diff --git a/nixos/tests/alloy.nix b/nixos/tests/alloy.nix index d87492127d5bb6..d6595c61f991fe 100644 --- a/nixos/tests/alloy.nix +++ b/nixos/tests/alloy.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: +import ./make-test-python.nix ( + { lib, pkgs, ... }: let nodes = { @@ -14,7 +15,10 @@ import ./make-test-python.nix ({ lib, pkgs, ... }: name = "alloy"; meta = with lib.maintainers; { - maintainers = [ flokli hbjydev ]; + maintainers = [ + flokli + hbjydev + ]; }; inherit nodes; @@ -29,4 +33,5 @@ import ./make-test-python.nix ({ lib, pkgs, ... }: ) machine.shutdown() ''; - }) + } +) diff --git a/nixos/tests/alps.nix b/nixos/tests/alps.nix index 9756f2d4da155e..3e990cea8035f3 100644 --- a/nixos/tests/alps.nix +++ b/nixos/tests/alps.nix @@ -2,107 +2,118 @@ let certs = import ./common/acme/server/snakeoil-certs.nix; domain = certs.domain; in -import ./make-test-python.nix ({ pkgs, ... }: { - name = "alps"; - meta = with pkgs.lib.maintainers; { - maintainers = [ hmenke ]; - }; - - nodes = { - server = { - imports = [ ./common/user-account.nix ]; - security.pki.certificateFiles = [ - certs.ca.cert - ]; - networking.extraHosts = '' - 127.0.0.1 ${domain} - ''; - networking.firewall.allowedTCPPorts = [ 25 465 993 ]; - services.postfix = { - enable = true; - enableSubmission = true; - enableSubmissions = true; - tlsTrustedAuthorities = "${certs.ca.cert}"; - sslCert = "${certs.${domain}.cert}"; - sslKey = "${certs.${domain}.key}"; - }; - services.dovecot2 = { - enable = true; - enableImap = true; - sslCACert = "${certs.ca.cert}"; - sslServerCert = "${certs.${domain}.cert}"; - sslServerKey = "${certs.${domain}.key}"; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "alps"; + meta = with pkgs.lib.maintainers; { + maintainers = [ hmenke ]; }; - client = { nodes, config, ... }: { - security.pki.certificateFiles = [ - certs.ca.cert - ]; - networking.extraHosts = '' - ${nodes.server.config.networking.primaryIPAddress} ${domain} - ''; - services.alps = { - enable = true; - theme = "alps"; - imaps = { - host = domain; - port = 993; + nodes = { + server = { + imports = [ ./common/user-account.nix ]; + security.pki.certificateFiles = [ + certs.ca.cert + ]; + networking.extraHosts = '' + 127.0.0.1 ${domain} + ''; + networking.firewall.allowedTCPPorts = [ + 25 + 465 + 993 + ]; + services.postfix = { + enable = true; + enableSubmission = true; + enableSubmissions = true; + tlsTrustedAuthorities = "${certs.ca.cert}"; + sslCert = "${certs.${domain}.cert}"; + sslKey = "${certs.${domain}.key}"; }; - smtps = { - host = domain; - port = 465; + services.dovecot2 = { + enable = true; + enableImap = true; + sslCACert = "${certs.ca.cert}"; + sslServerCert = "${certs.${domain}.cert}"; + sslServerKey = "${certs.${domain}.key}"; }; }; - environment.systemPackages = [ - (pkgs.writers.writePython3Bin "test-alps-login" { } '' - from urllib.request import build_opener, HTTPCookieProcessor, Request - from urllib.parse import urlencode, urljoin - from http.cookiejar import CookieJar - baseurl = "http://localhost:${toString config.services.alps.port}" - username = "alice" - password = "${nodes.server.config.users.users.alice.password}" - cookiejar = CookieJar() - cookieprocessor = HTTPCookieProcessor(cookiejar) - opener = build_opener(cookieprocessor) + client = + { nodes, config, ... }: + { + security.pki.certificateFiles = [ + certs.ca.cert + ]; + networking.extraHosts = '' + ${nodes.server.config.networking.primaryIPAddress} ${domain} + ''; + services.alps = { + enable = true; + theme = "alps"; + imaps = { + host = domain; + port = 993; + }; + smtps = { + host = domain; + port = 465; + }; + }; + environment.systemPackages = [ + (pkgs.writers.writePython3Bin "test-alps-login" { } '' + from urllib.request import build_opener, HTTPCookieProcessor, Request + from urllib.parse import urlencode, urljoin + from http.cookiejar import CookieJar + + baseurl = "http://localhost:${toString config.services.alps.port}" + username = "alice" + password = "${nodes.server.config.users.users.alice.password}" + cookiejar = CookieJar() + cookieprocessor = HTTPCookieProcessor(cookiejar) + opener = build_opener(cookieprocessor) - data = urlencode({"username": username, "password": password}).encode() - req = Request(urljoin(baseurl, "login"), data=data, method="POST") - with opener.open(req) as ret: - # Check that the alps_session cookie is set - print(cookiejar) - assert any(cookie.name == "alps_session" for cookie in cookiejar) + data = urlencode({"username": username, "password": password}).encode() + req = Request(urljoin(baseurl, "login"), data=data, method="POST") + with opener.open(req) as ret: + # Check that the alps_session cookie is set + print(cookiejar) + assert any(cookie.name == "alps_session" for cookie in cookiejar) - req = Request(baseurl) - with opener.open(req) as ret: - # Check that the alps_session cookie is still there... - print(cookiejar) - assert any(cookie.name == "alps_session" for cookie in cookiejar) - # ...and that we have not been redirected back to the login page - print(ret.url) - assert ret.url == urljoin(baseurl, "mailbox/INBOX") + req = Request(baseurl) + with opener.open(req) as ret: + # Check that the alps_session cookie is still there... + print(cookiejar) + assert any(cookie.name == "alps_session" for cookie in cookiejar) + # ...and that we have not been redirected back to the login page + print(ret.url) + assert ret.url == urljoin(baseurl, "mailbox/INBOX") - req = Request(urljoin(baseurl, "logout")) - with opener.open(req) as ret: - # Check that the alps_session cookie is now gone - print(cookiejar) - assert all(cookie.name != "alps_session" for cookie in cookiejar) - '') - ]; + req = Request(urljoin(baseurl, "logout")) + with opener.open(req) as ret: + # Check that the alps_session cookie is now gone + print(cookiejar) + assert all(cookie.name != "alps_session" for cookie in cookiejar) + '') + ]; + }; }; - }; - testScript = { nodes, ... }: '' - server.start() - server.wait_for_unit("postfix.service") - server.wait_for_unit("dovecot2.service") - server.wait_for_open_port(465) - server.wait_for_open_port(993) + testScript = + { nodes, ... }: + '' + server.start() + server.wait_for_unit("postfix.service") + server.wait_for_unit("dovecot2.service") + server.wait_for_open_port(465) + server.wait_for_open_port(993) - client.start() - client.wait_for_unit("alps.service") - client.wait_for_open_port(${toString nodes.client.config.services.alps.port}) - client.succeed("test-alps-login") - ''; -}) + client.start() + client.wait_for_unit("alps.service") + client.wait_for_open_port(${toString nodes.client.config.services.alps.port}) + client.succeed("test-alps-login") + ''; + } +) diff --git a/nixos/tests/amazon-init-shell.nix b/nixos/tests/amazon-init-shell.nix index da4480ed577885..f79cd0364684f2 100644 --- a/nixos/tests/amazon-init-shell.nix +++ b/nixos/tests/amazon-init-shell.nix @@ -5,9 +5,10 @@ # Note that other tests verify that amazon-init can treat user-data as a nixos # configuration expression. -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -18,24 +19,28 @@ makeTest { meta = with maintainers; { maintainers = [ urbas ]; }; - nodes.machine = { lib, pkgs, ... }: - { - imports = [ ../modules/profiles/headless.nix ../modules/virtualisation/amazon-init.nix ]; - services.openssh.enable = true; - system.switch.enable = true; - networking.hostName = ""; - environment.etc."ec2-metadata/user-data" = { - text = '' - #!/usr/bin/bash + nodes.machine = + { lib, pkgs, ... }: + { + imports = [ + ../modules/profiles/headless.nix + ../modules/virtualisation/amazon-init.nix + ]; + services.openssh.enable = true; + system.switch.enable = true; + networking.hostName = ""; + environment.etc."ec2-metadata/user-data" = { + text = '' + #!/usr/bin/bash - echo successful > /tmp/evidence + echo successful > /tmp/evidence - # Emulate running nixos-rebuild switch, just without any building. - # https://github.com/nixos/nixpkgs/blob/4c62505847d88f16df11eff3c81bf9a453a4979e/nixos/modules/virtualisation/amazon-init.nix#L55 - /run/current-system/bin/switch-to-configuration test - ''; + # Emulate running nixos-rebuild switch, just without any building. + # https://github.com/nixos/nixpkgs/blob/4c62505847d88f16df11eff3c81bf9a453a4979e/nixos/modules/virtualisation/amazon-init.nix#L55 + /run/current-system/bin/switch-to-configuration test + ''; + }; }; - }; testScript = '' # To wait until amazon-init terminates its run unnamed.wait_for_unit("amazon-init.service") diff --git a/nixos/tests/amazon-ssm-agent.nix b/nixos/tests/amazon-ssm-agent.nix index 957e9e0e02c5d5..4c55fc1c4faf11 100644 --- a/nixos/tests/amazon-ssm-agent.nix +++ b/nixos/tests/amazon-ssm-agent.nix @@ -1,17 +1,22 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "amazon-ssm-agent"; - meta.maintainers = [ lib.maintainers.anthonyroussel ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "amazon-ssm-agent"; + meta.maintainers = [ lib.maintainers.anthonyroussel ]; - nodes.machine = { config, pkgs, ... }: { - services.amazon-ssm-agent.enable = true; - }; + nodes.machine = + { config, pkgs, ... }: + { + services.amazon-ssm-agent.enable = true; + }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_file("/etc/amazon/ssm/seelog.xml") - machine.wait_for_file("/etc/amazon/ssm/amazon-ssm-agent.json") + machine.wait_for_file("/etc/amazon/ssm/seelog.xml") + machine.wait_for_file("/etc/amazon/ssm/amazon-ssm-agent.json") - machine.wait_for_unit("amazon-ssm-agent.service") - ''; -}) + machine.wait_for_unit("amazon-ssm-agent.service") + ''; + } +) diff --git a/nixos/tests/amd-sev.nix b/nixos/tests/amd-sev.nix index bf9a50c10d0d2e..63e973a5ad0efe 100644 --- a/nixos/tests/amd-sev.nix +++ b/nixos/tests/amd-sev.nix @@ -1,29 +1,36 @@ -{ lib, ... }: { +{ lib, ... }: +{ name = "amd-sev"; meta = { - maintainers = with lib.maintainers; [ trundle veehaitch ]; + maintainers = with lib.maintainers; [ + trundle + veehaitch + ]; }; - nodes.machine = { lib, ... }: { - hardware.cpu.amd.sev.enable = true; - hardware.cpu.amd.sevGuest.enable = true; - - specialisation.sevCustomUserGroup.configuration = { - users.groups.sevtest = { }; - - hardware.cpu.amd.sev = { - enable = true; - group = "root"; - mode = "0600"; - }; - hardware.cpu.amd.sevGuest = { - enable = true; - group = "sevtest"; + nodes.machine = + { lib, ... }: + { + hardware.cpu.amd.sev.enable = true; + hardware.cpu.amd.sevGuest.enable = true; + + specialisation.sevCustomUserGroup.configuration = { + users.groups.sevtest = { }; + + hardware.cpu.amd.sev = { + enable = true; + group = "root"; + mode = "0600"; + }; + hardware.cpu.amd.sevGuest = { + enable = true; + group = "sevtest"; + }; }; }; - }; - testScript = { nodes, ... }: + testScript = + { nodes, ... }: let specialisations = "${nodes.machine.system.build.toplevel}/specialisation"; in diff --git a/nixos/tests/anbox.nix b/nixos/tests/anbox.nix index a00116536db7ef..2988e60eb3ac90 100644 --- a/nixos/tests/anbox.nix +++ b/nixos/tests/anbox.nix @@ -4,33 +4,38 @@ name = "anbox"; meta.maintainers = with lib.maintainers; [ mvnetbiz ]; - nodes.machine = { pkgs, config, ... }: { - imports = [ - ./common/user-account.nix - ./common/x11.nix - ]; - - environment.systemPackages = with pkgs; [ android-tools ]; - - test-support.displayManager.auto.user = "alice"; - - virtualisation.anbox.enable = true; - boot.kernelPackages = pkgs.linuxKernel.packages.linux_5_15; - virtualisation.memorySize = 2500; - }; - - testScript = { nodes, ... }: let - user = nodes.machine.users.users.alice; - bus = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${toString user.uid}/bus"; - in '' - machine.wait_for_x() - - machine.wait_until_succeeds( - "sudo -iu alice ${bus} anbox wait-ready" - ) - - machine.wait_until_succeeds("adb shell true") - - print(machine.succeed("adb devices")) - ''; + nodes.machine = + { pkgs, config, ... }: + { + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; + + environment.systemPackages = with pkgs; [ android-tools ]; + + test-support.displayManager.auto.user = "alice"; + + virtualisation.anbox.enable = true; + boot.kernelPackages = pkgs.linuxKernel.packages.linux_5_15; + virtualisation.memorySize = 2500; + }; + + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + bus = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${toString user.uid}/bus"; + in + '' + machine.wait_for_x() + + machine.wait_until_succeeds( + "sudo -iu alice ${bus} anbox wait-ready" + ) + + machine.wait_until_succeeds("adb shell true") + + print(machine.succeed("adb devices")) + ''; } diff --git a/nixos/tests/angie-api.nix b/nixos/tests/angie-api.nix index 4c8d6b54247b18..95e66de9060ebc 100644 --- a/nixos/tests/angie-api.nix +++ b/nixos/tests/angie-api.nix @@ -1,148 +1,170 @@ -import ./make-test-python.nix ({lib, pkgs, ...}: -let - hosts = '' - 192.168.2.101 example.com - 192.168.2.101 api.example.com - 192.168.2.101 backend.example.com - ''; - -in -{ - name = "angie-api"; - meta.maintainers = with pkgs.lib.maintainers; [ izorkin ]; - - nodes = { - server = { pkgs, ... }: { - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.101"; prefixLength = 24; } - ]; - }; - extraHosts = hosts; - firewall.allowedTCPPorts = [ 80 ]; - }; - - services.nginx = { - enable = true; - package = pkgs.angie; - - upstreams = { - "backend-http" = { - servers = { "backend.example.com:8080" = { fail_timeout = "0"; }; }; - extraConfig = '' - zone upstream 256k; - ''; - }; - "backend-socket" = { - servers = { "unix:/run/example.sock" = { fail_timeout = "0"; }; }; - extraConfig = '' - zone upstream 256k; - ''; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let + hosts = '' + 192.168.2.101 example.com + 192.168.2.101 api.example.com + 192.168.2.101 backend.example.com + ''; + + in + { + name = "angie-api"; + meta.maintainers = with pkgs.lib.maintainers; [ izorkin ]; + + nodes = { + server = + { pkgs, ... }: + { + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.101"; + prefixLength = 24; + } + ]; + }; + extraHosts = hosts; + firewall.allowedTCPPorts = [ 80 ]; }; - }; - virtualHosts."api.example.com" = { - locations."/console/" = { - extraConfig = '' - api /status/; - - allow 192.168.2.201; - deny all; - ''; + services.nginx = { + enable = true; + package = pkgs.angie; + + upstreams = { + "backend-http" = { + servers = { + "backend.example.com:8080" = { + fail_timeout = "0"; + }; + }; + extraConfig = '' + zone upstream 256k; + ''; + }; + "backend-socket" = { + servers = { + "unix:/run/example.sock" = { + fail_timeout = "0"; + }; + }; + extraConfig = '' + zone upstream 256k; + ''; + }; + }; + + virtualHosts."api.example.com" = { + locations."/console/" = { + extraConfig = '' + api /status/; + + allow 192.168.2.201; + deny all; + ''; + }; + }; + + virtualHosts."example.com" = { + locations."/test/" = { + root = lib.mkForce ( + pkgs.runCommandLocal "testdir" { } '' + mkdir -p "$out/test" + cat > "$out/test/index.html" <Hello World! + EOF + '' + ); + extraConfig = '' + status_zone test_zone; + + allow 192.168.2.201; + deny all; + ''; + }; + locations."/test/locked/" = { + extraConfig = '' + status_zone test_zone; + + deny all; + ''; + }; + locations."/test/error/" = { + extraConfig = '' + status_zone test_zone; + + allow all; + ''; + }; + locations."/upstream-http/" = { + proxyPass = "http://backend-http"; + }; + locations."/upstream-socket/" = { + proxyPass = "http://backend-socket"; + }; + }; }; }; - virtualHosts."example.com" = { - locations."/test/" = { - root = lib.mkForce (pkgs.runCommandLocal "testdir" {} '' - mkdir -p "$out/test" - cat > "$out/test/index.html" <Hello World! - EOF - ''); - extraConfig = '' - status_zone test_zone; - - allow 192.168.2.201; - deny all; - ''; - }; - locations."/test/locked/" = { - extraConfig = '' - status_zone test_zone; - - deny all; - ''; - }; - locations."/test/error/" = { - extraConfig = '' - status_zone test_zone; - - allow all; - ''; - }; - locations."/upstream-http/" = { - proxyPass = "http://backend-http"; - }; - locations."/upstream-socket/" = { - proxyPass = "http://backend-socket"; + client = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.201"; + prefixLength = 24; + } + ]; + }; + extraHosts = hosts; }; }; - }; }; - client = { pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.201"; prefixLength = 24; } - ]; - }; - extraHosts = hosts; - }; - }; - }; - - testScript = '' - start_all() - - server.wait_for_unit("nginx") - server.wait_for_open_port(80) - - # Check Angie version - client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.angie.version' | grep '${pkgs.angie.version}'") - - # Check access - client.succeed("curl --verbose --head http://api.example.com/console/ | grep 'HTTP/1.1 200'") - server.succeed("curl --verbose --head http://api.example.com/console/ | grep 'HTTP/1.1 403 Forbidden'") - - # Check responses and requests - client.succeed("curl --verbose http://example.com/test/") - client.succeed("curl --verbose http://example.com/test/locked/") - client.succeed("curl --verbose http://example.com/test/locked/") - client.succeed("curl --verbose http://example.com/test/error/") - client.succeed("curl --verbose http://example.com/test/error/") - client.succeed("curl --verbose http://example.com/test/error/") - server.succeed("curl --verbose http://example.com/test/") - client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.location_zones.test_zone.responses.\"200\"' | grep '1'") - client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.location_zones.test_zone.responses.\"403\"' | grep '3'") - client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.location_zones.test_zone.responses.\"404\"' | grep '3'") - client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.location_zones.test_zone.requests.total' | grep '7'") - - # Check upstreams - client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.upstreams.\"backend-http\".peers.\"192.168.2.101:8080\".state' | grep 'up'") - client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.upstreams.\"backend-http\".peers.\"192.168.2.101:8080\".health.fails' | grep '0'") - client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.upstreams.\"backend-socket\".peers.\"unix:/run/example.sock\".state' | grep 'up'") - client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.upstreams.\"backend-socket\".peers.\"unix:/run/example.sock\".health.fails' | grep '0'") - client.succeed("curl --verbose http://example.com/upstream-http/") - client.succeed("curl --verbose http://example.com/upstream-socket/") - client.succeed("curl --verbose http://example.com/upstream-socket/") - client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.upstreams.\"backend-http\".peers.\"192.168.2.101:8080\".health.fails' | grep '1'") - client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.upstreams.\"backend-socket\".peers.\"unix:/run/example.sock\".health.fails' | grep '2'") - - server.shutdown() - client.shutdown() - ''; -}) + testScript = '' + start_all() + + server.wait_for_unit("nginx") + server.wait_for_open_port(80) + + # Check Angie version + client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.angie.version' | grep '${pkgs.angie.version}'") + + # Check access + client.succeed("curl --verbose --head http://api.example.com/console/ | grep 'HTTP/1.1 200'") + server.succeed("curl --verbose --head http://api.example.com/console/ | grep 'HTTP/1.1 403 Forbidden'") + + # Check responses and requests + client.succeed("curl --verbose http://example.com/test/") + client.succeed("curl --verbose http://example.com/test/locked/") + client.succeed("curl --verbose http://example.com/test/locked/") + client.succeed("curl --verbose http://example.com/test/error/") + client.succeed("curl --verbose http://example.com/test/error/") + client.succeed("curl --verbose http://example.com/test/error/") + server.succeed("curl --verbose http://example.com/test/") + client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.location_zones.test_zone.responses.\"200\"' | grep '1'") + client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.location_zones.test_zone.responses.\"403\"' | grep '3'") + client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.location_zones.test_zone.responses.\"404\"' | grep '3'") + client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.location_zones.test_zone.requests.total' | grep '7'") + + # Check upstreams + client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.upstreams.\"backend-http\".peers.\"192.168.2.101:8080\".state' | grep 'up'") + client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.upstreams.\"backend-http\".peers.\"192.168.2.101:8080\".health.fails' | grep '0'") + client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.upstreams.\"backend-socket\".peers.\"unix:/run/example.sock\".state' | grep 'up'") + client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.upstreams.\"backend-socket\".peers.\"unix:/run/example.sock\".health.fails' | grep '0'") + client.succeed("curl --verbose http://example.com/upstream-http/") + client.succeed("curl --verbose http://example.com/upstream-socket/") + client.succeed("curl --verbose http://example.com/upstream-socket/") + client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.upstreams.\"backend-http\".peers.\"192.168.2.101:8080\".health.fails' | grep '1'") + client.succeed("curl --verbose http://api.example.com/console/ | jq -e '.http.upstreams.\"backend-socket\".peers.\"unix:/run/example.sock\".health.fails' | grep '2'") + + server.shutdown() + client.shutdown() + ''; + } +) diff --git a/nixos/tests/anki-sync-server.nix b/nixos/tests/anki-sync-server.nix index 7d08cc9cb878e6..49075e1d77059f 100644 --- a/nixos/tests/anki-sync-server.nix +++ b/nixos/tests/anki-sync-server.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: let ankiSyncTest = pkgs.writeScript "anki-sync-test.py" '' #!${pkgs.python3}/bin/python @@ -36,28 +37,30 @@ import ./make-test-python.nix ({ pkgs, ... }: testPasswordFile = pkgs.writeText "anki-password" "passfilepassword"; in { - name = "anki-sync-server"; - meta = with pkgs.lib.maintainers; { - maintainers = [ martinetd ]; - }; - - nodes.machine = { pkgs, ...}: { - services.anki-sync-server = { - enable = true; - users = [ - { username = "user"; - password = "password"; - } - { username = "passfileuser"; - passwordFile = testPasswordFile; - } - ]; + name = "anki-sync-server"; + meta = with pkgs.lib.maintainers; { + maintainers = [ martinetd ]; }; - }; + nodes.machine = + { pkgs, ... }: + { + services.anki-sync-server = { + enable = true; + users = [ + { + username = "user"; + password = "password"; + } + { + username = "passfileuser"; + passwordFile = testPasswordFile; + } + ]; + }; + }; - testScript = - '' + testScript = '' start_all() with subtest("Server starts successfully"): @@ -68,4 +71,5 @@ import ./make-test-python.nix ({ pkgs, ... }: with subtest("Can sync"): machine.succeed("${ankiSyncTest}") ''; -}) + } +) diff --git a/nixos/tests/anuko-time-tracker.nix b/nixos/tests/anuko-time-tracker.nix index 18c3bf5cf69578..f341056e853202 100644 --- a/nixos/tests/anuko-time-tracker.nix +++ b/nixos/tests/anuko-time-tracker.nix @@ -1,17 +1,20 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "anuko-time-tracker"; - meta = { - maintainers = with pkgs.lib.maintainers; [ michaelshmitty ]; - }; - nodes = { - machine = { - services.anuko-time-tracker.enable = true; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "anuko-time-tracker"; + meta = { + maintainers = with pkgs.lib.maintainers; [ michaelshmitty ]; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("phpfpm-anuko-time-tracker") - machine.wait_for_open_port(80); - machine.wait_until_succeeds("curl -s --fail -L http://localhost/time.php | grep 'Anuko Time Tracker'") - ''; -}) + nodes = { + machine = { + services.anuko-time-tracker.enable = true; + }; + }; + testScript = '' + start_all() + machine.wait_for_unit("phpfpm-anuko-time-tracker") + machine.wait_for_open_port(80); + machine.wait_until_succeeds("curl -s --fail -L http://localhost/time.php | grep 'Anuko Time Tracker'") + ''; + } +) diff --git a/nixos/tests/apcupsd.nix b/nixos/tests/apcupsd.nix index 287140f039d858..041103252efb69 100644 --- a/nixos/tests/apcupsd.nix +++ b/nixos/tests/apcupsd.nix @@ -2,40 +2,45 @@ let # arbitrary address ipAddr = "192.168.42.42"; in -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "apcupsd"; - meta.maintainers = with lib.maintainers; [ bjornfor ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "apcupsd"; + meta.maintainers = with lib.maintainers; [ bjornfor ]; - nodes = { - machine = { - services.apcupsd = { - enable = true; - configText = '' - UPSTYPE usb - BATTERYLEVEL 42 - # Configure NISIP so that the only way apcaccess can work is to read - # this config. - NISIP ${ipAddr} - ''; - }; - networking.interfaces.eth1 = { - ipv4.addresses = [{ - address = ipAddr; - prefixLength = 24; - }]; + nodes = { + machine = { + services.apcupsd = { + enable = true; + configText = '' + UPSTYPE usb + BATTERYLEVEL 42 + # Configure NISIP so that the only way apcaccess can work is to read + # this config. + NISIP ${ipAddr} + ''; + }; + networking.interfaces.eth1 = { + ipv4.addresses = [ + { + address = ipAddr; + prefixLength = 24; + } + ]; + }; }; }; - }; - # Check that the service starts, that the CLI (apcaccess) works and that it - # uses the config (ipAddr) defined in the service config. - testScript = '' - start_all() - machine.wait_for_unit("apcupsd.service") - machine.wait_for_open_port(3551, "${ipAddr}") - res = machine.succeed("apcaccess") - expect_line="MBATTCHG : 42 Percent" - assert "MBATTCHG : 42 Percent" in res, f"expected apcaccess output to contain '{expect_line}' but got '{res}'" - machine.shutdown() - ''; -}) + # Check that the service starts, that the CLI (apcaccess) works and that it + # uses the config (ipAddr) defined in the service config. + testScript = '' + start_all() + machine.wait_for_unit("apcupsd.service") + machine.wait_for_open_port(3551, "${ipAddr}") + res = machine.succeed("apcaccess") + expect_line="MBATTCHG : 42 Percent" + assert "MBATTCHG : 42 Percent" in res, f"expected apcaccess output to contain '{expect_line}' but got '{res}'" + machine.shutdown() + ''; + } +) diff --git a/nixos/tests/apfs.nix b/nixos/tests/apfs.nix index 3e79fa11dc0495..34a6491e10ab62 100644 --- a/nixos/tests/apfs.nix +++ b/nixos/tests/apfs.nix @@ -1,4 +1,5 @@ -{ lib, ... }: { +{ lib, ... }: +{ name = "apfs"; meta.maintainers = with lib.maintainers; [ Luflosi ]; diff --git a/nixos/tests/appliance-repart-image.nix b/nixos/tests/appliance-repart-image.nix index 861369b9f3ca86..9798ab4e79fa7b 100644 --- a/nixos/tests/appliance-repart-image.nix +++ b/nixos/tests/appliance-repart-image.nix @@ -16,96 +16,105 @@ in meta.maintainers = with lib.maintainers; [ nikstur ]; - nodes.machine = { config, lib, pkgs, ... }: { - - imports = [ ../modules/image/repart.nix ]; - - virtualisation.directBoot.enable = false; - virtualisation.mountHostNixStore = false; - virtualisation.useEFIBoot = true; - - # Disable boot loaders because we install one "manually". - # TODO(raitobezarius): revisit this when #244907 lands - boot.loader.grub.enable = false; - - system.image.id = imageId; - system.image.version = imageVersion; - - virtualisation.fileSystems = lib.mkForce { - "/" = { - device = "/dev/disk/by-partlabel/${rootPartitionLabel}"; - fsType = "ext4"; + nodes.machine = + { + config, + lib, + pkgs, + ... + }: + { + + imports = [ ../modules/image/repart.nix ]; + + virtualisation.directBoot.enable = false; + virtualisation.mountHostNixStore = false; + virtualisation.useEFIBoot = true; + + # Disable boot loaders because we install one "manually". + # TODO(raitobezarius): revisit this when #244907 lands + boot.loader.grub.enable = false; + + system.image.id = imageId; + system.image.version = imageVersion; + + virtualisation.fileSystems = lib.mkForce { + "/" = { + device = "/dev/disk/by-partlabel/${rootPartitionLabel}"; + fsType = "ext4"; + }; }; - }; - image.repart = { - name = "appliance-gpt-image"; - # OVMF does not work with the default repart sector size of 4096 - sectorSize = 512; - partitions = { - "esp" = { - contents = - let - efiArch = config.nixpkgs.hostPlatform.efiArch; - in - { - "/EFI/BOOT/BOOT${lib.toUpper efiArch}.EFI".source = - "${pkgs.systemd}/lib/systemd/boot/efi/systemd-boot${efiArch}.efi"; - - "/EFI/Linux/${config.system.boot.loader.ukiFile}".source = - "${config.system.build.uki}/${config.system.boot.loader.ukiFile}"; + image.repart = { + name = "appliance-gpt-image"; + # OVMF does not work with the default repart sector size of 4096 + sectorSize = 512; + partitions = { + "esp" = { + contents = + let + efiArch = config.nixpkgs.hostPlatform.efiArch; + in + { + "/EFI/BOOT/BOOT${lib.toUpper efiArch}.EFI".source = + "${pkgs.systemd}/lib/systemd/boot/efi/systemd-boot${efiArch}.efi"; + + "/EFI/Linux/${config.system.boot.loader.ukiFile}".source = + "${config.system.build.uki}/${config.system.boot.loader.ukiFile}"; + }; + repartConfig = { + Type = "esp"; + Format = "vfat"; + # Minimize = "guess" seems to not work very vell for vfat + # partitons. It's better to set a sensible default instead. The + # aarch64 kernel seems to generally be a little bigger than the + # x86_64 kernel. To stay on the safe side, leave some more slack + # for every platform other than x86_64. + SizeMinBytes = if config.nixpkgs.hostPlatform.isx86_64 then "64M" else "96M"; }; - repartConfig = { - Type = "esp"; - Format = "vfat"; - # Minimize = "guess" seems to not work very vell for vfat - # partitons. It's better to set a sensible default instead. The - # aarch64 kernel seems to generally be a little bigger than the - # x86_64 kernel. To stay on the safe side, leave some more slack - # for every platform other than x86_64. - SizeMinBytes = if config.nixpkgs.hostPlatform.isx86_64 then "64M" else "96M"; }; - }; - "root" = { - storePaths = [ config.system.build.toplevel ]; - repartConfig = { - Type = "root"; - Format = config.fileSystems."/".fsType; - Label = rootPartitionLabel; - Minimize = "guess"; + "root" = { + storePaths = [ config.system.build.toplevel ]; + repartConfig = { + Type = "root"; + Format = config.fileSystems."/".fsType; + Label = rootPartitionLabel; + Minimize = "guess"; + }; }; }; }; }; - }; - - testScript = { nodes, ... }: '' - import os - import subprocess - import tempfile - - tmp_disk_image = tempfile.NamedTemporaryFile() - - subprocess.run([ - "${nodes.machine.virtualisation.qemu.package}/bin/qemu-img", - "create", - "-f", - "qcow2", - "-b", - "${nodes.machine.system.build.image}/${nodes.machine.image.repart.imageFile}", - "-F", - "raw", - tmp_disk_image.name, - ]) - - # Set NIX_DISK_IMAGE so that the qemu script finds the right disk image. - os.environ['NIX_DISK_IMAGE'] = tmp_disk_image.name - - os_release = machine.succeed("cat /etc/os-release") - assert 'IMAGE_ID="${imageId}"' in os_release - assert 'IMAGE_VERSION="${imageVersion}"' in os_release - - bootctl_status = machine.succeed("bootctl status") - assert "Boot Loader Specification Type #2 (.efi)" in bootctl_status - ''; + + testScript = + { nodes, ... }: + '' + import os + import subprocess + import tempfile + + tmp_disk_image = tempfile.NamedTemporaryFile() + + subprocess.run([ + "${nodes.machine.virtualisation.qemu.package}/bin/qemu-img", + "create", + "-f", + "qcow2", + "-b", + "${nodes.machine.system.build.image}/${nodes.machine.image.repart.imageFile}", + "-F", + "raw", + tmp_disk_image.name, + ]) + + # Set NIX_DISK_IMAGE so that the qemu script finds the right disk image. + os.environ['NIX_DISK_IMAGE'] = tmp_disk_image.name + + os_release = machine.succeed("cat /etc/os-release") + assert 'IMAGE_ID="${imageId}"' in os_release + assert 'IMAGE_VERSION="${imageVersion}"' in os_release + + bootctl_status = machine.succeed("bootctl status") + assert "Boot Loader Specification Type #2 (.efi)" in bootctl_status + ''; } diff --git a/nixos/tests/archi.nix b/nixos/tests/archi.nix index a8cb1c503d4f7a..387c4093a8bbea 100644 --- a/nixos/tests/archi.nix +++ b/nixos/tests/archi.nix @@ -1,33 +1,38 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "archi"; - meta.maintainers = with lib.maintainers; [ paumr ]; - - nodes.machine = { pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; - - environment.systemPackages = with pkgs; [ archi ]; - }; - - enableOCR = true; - - testScript = '' - machine.wait_for_x() - - with subtest("createEmptyModel via CLI"): - machine.succeed("Archi -application com.archimatetool.commandline.app -consoleLog -nosplash --createEmptyModel --saveModel smoke.archimate") - machine.copy_from_vm("smoke.archimate", "") - - with subtest("UI smoketest"): - machine.succeed("DISPLAY=:0 Archi --createEmptyModel >&2 &") - machine.wait_for_window("Archi") - - # wait till main UI is open - # since OCR seems to be buggy wait_for_text was replaced by sleep, issue: #302965 - # machine.wait_for_text("Welcome to Archi") - machine.sleep(20) - - machine.screenshot("welcome-screen") - ''; -}) +import ./make-test-python.nix ( + { lib, ... }: + { + name = "archi"; + meta.maintainers = with lib.maintainers; [ paumr ]; + + nodes.machine = + { pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; + + environment.systemPackages = with pkgs; [ archi ]; + }; + + enableOCR = true; + + testScript = '' + machine.wait_for_x() + + with subtest("createEmptyModel via CLI"): + machine.succeed("Archi -application com.archimatetool.commandline.app -consoleLog -nosplash --createEmptyModel --saveModel smoke.archimate") + machine.copy_from_vm("smoke.archimate", "") + + with subtest("UI smoketest"): + machine.succeed("DISPLAY=:0 Archi --createEmptyModel >&2 &") + machine.wait_for_window("Archi") + + # wait till main UI is open + # since OCR seems to be buggy wait_for_text was replaced by sleep, issue: #302965 + # machine.wait_for_text("Welcome to Archi") + machine.sleep(20) + + machine.screenshot("welcome-screen") + ''; + } +) diff --git a/nixos/tests/aria2.nix b/nixos/tests/aria2.nix index 48fe2094b5dcfa..cf8e4da8977cc6 100644 --- a/nixos/tests/aria2.nix +++ b/nixos/tests/aria2.nix @@ -1,43 +1,54 @@ -import ./make-test-python.nix ({ pkgs, ... }: -let - rpcSecret = "supersecret"; - rpc-listen-port = 6800; - curlBody = { - jsonrpc = 2.0; - id = 1; - method = "aria2.getVersion"; - params = [ "token:${rpcSecret}" ]; - }; -in -rec { - name = "aria2"; +import ./make-test-python.nix ( + { pkgs, ... }: + let + rpcSecret = "supersecret"; + rpc-listen-port = 6800; + curlBody = { + jsonrpc = 2.0; + id = 1; + method = "aria2.getVersion"; + params = [ "token:${rpcSecret}" ]; + }; + in + rec { + name = "aria2"; - nodes.machine = { - environment.etc."aria2Rpc".text = rpcSecret; - services.aria2 = { - enable = true; - rpcSecretFile = "/etc/aria2Rpc"; - settings = { - inherit rpc-listen-port; - allow-overwrite = false; - check-integrity = true; - console-log-level = "warn"; - listen-port = [{ from = 20000; to = 20010; } { from = 22222; to = 22222; }]; - max-concurrent-downloads = 50; - seed-ratio = 1.2; - summary-interval = 0; + nodes.machine = { + environment.etc."aria2Rpc".text = rpcSecret; + services.aria2 = { + enable = true; + rpcSecretFile = "/etc/aria2Rpc"; + settings = { + inherit rpc-listen-port; + allow-overwrite = false; + check-integrity = true; + console-log-level = "warn"; + listen-port = [ + { + from = 20000; + to = 20010; + } + { + from = 22222; + to = 22222; + } + ]; + max-concurrent-downloads = 50; + seed-ratio = 1.2; + summary-interval = 0; + }; }; }; - }; - testScript = '' - machine.start() - machine.wait_for_unit("aria2.service") - curl_cmd = 'curl --fail-with-body -X POST -H "Content-Type: application/json" \ - -d \'${builtins.toJSON curlBody}\' http://localhost:${toString rpc-listen-port}/jsonrpc' - print(machine.wait_until_succeeds(curl_cmd, timeout=10)) - machine.shutdown() - ''; + testScript = '' + machine.start() + machine.wait_for_unit("aria2.service") + curl_cmd = 'curl --fail-with-body -X POST -H "Content-Type: application/json" \ + -d \'${builtins.toJSON curlBody}\' http://localhost:${toString rpc-listen-port}/jsonrpc' + print(machine.wait_until_succeeds(curl_cmd, timeout=10)) + machine.shutdown() + ''; - meta.maintainers = [ pkgs.lib.maintainers.timhae ]; -}) + meta.maintainers = [ pkgs.lib.maintainers.timhae ]; + } +) diff --git a/nixos/tests/armagetronad.nix b/nixos/tests/armagetronad.nix index b657893fc9eef3..d9c7c507638294 100644 --- a/nixos/tests/armagetronad.nix +++ b/nixos/tests/armagetronad.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -11,7 +12,11 @@ let client = { pkgs, ... }: - { imports = [ ./common/user-account.nix ./common/x11.nix ]; + { + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; hardware.graphics.enable = true; virtualisation.memorySize = 384; environment = { @@ -30,72 +35,75 @@ makeTest { enableOCR = true; - nodes = - { - server = { - services.armagetronad.servers = { - high-rubber = { - enable = true; - name = "Smoke Test High Rubber Server"; - port = 4534; - settings = { - SERVER_OPTIONS = "High Rubber server made to run smoke tests."; - CYCLE_RUBBER = 40; - SIZE_FACTOR = 0.5; - }; - roundSettings = { - SAY = [ - "NixOS Smoke Test Server" - "https://nixos.org" - ]; - }; + nodes = { + server = { + services.armagetronad.servers = { + high-rubber = { + enable = true; + name = "Smoke Test High Rubber Server"; + port = 4534; + settings = { + SERVER_OPTIONS = "High Rubber server made to run smoke tests."; + CYCLE_RUBBER = 40; + SIZE_FACTOR = 0.5; + }; + roundSettings = { + SAY = [ + "NixOS Smoke Test Server" + "https://nixos.org" + ]; + }; + }; + sty = { + enable = true; + name = "Smoke Test sty+ct+ap Server"; + package = pkgs.armagetronad."0.2.9-sty+ct+ap".dedicated; + port = 4535; + settings = { + SERVER_OPTIONS = "sty+ct+ap server made to run smoke tests."; + CYCLE_RUBBER = 20; + SIZE_FACTOR = 0.5; }; - sty = { - enable = true; - name = "Smoke Test sty+ct+ap Server"; - package = pkgs.armagetronad."0.2.9-sty+ct+ap".dedicated; - port = 4535; - settings = { - SERVER_OPTIONS = "sty+ct+ap server made to run smoke tests."; - CYCLE_RUBBER = 20; - SIZE_FACTOR = 0.5; - }; - roundSettings = { - SAY = [ - "NixOS Smoke Test sty+ct+ap Server" - "https://nixos.org" - ]; - }; + roundSettings = { + SAY = [ + "NixOS Smoke Test sty+ct+ap Server" + "https://nixos.org" + ]; }; - trunk = { - enable = true; - name = "Smoke Test trunk Server"; - package = pkgs.armagetronad."0.4".dedicated; - port = 4536; - settings = { - SERVER_OPTIONS = "0.4 server made to run smoke tests."; - CYCLE_RUBBER = 20; - SIZE_FACTOR = 0.5; - }; - roundSettings = { - SAY = [ - "NixOS Smoke Test 0.4 Server" - "https://nixos.org" - ]; - }; + }; + trunk = { + enable = true; + name = "Smoke Test trunk Server"; + package = pkgs.armagetronad."0.4".dedicated; + port = 4536; + settings = { + SERVER_OPTIONS = "0.4 server made to run smoke tests."; + CYCLE_RUBBER = 20; + SIZE_FACTOR = 0.5; + }; + roundSettings = { + SAY = [ + "NixOS Smoke Test 0.4 Server" + "https://nixos.org" + ]; }; }; }; - - client1 = client; - client2 = client; }; - testScript = let - xdo = name: text: let - xdoScript = pkgs.writeText "${name}.xdo" text; - in "${pkgs.xdotool}/bin/xdotool ${xdoScript}"; - in + client1 = client; + client2 = client; + }; + + testScript = + let + xdo = + name: text: + let + xdoScript = pkgs.writeText "${name}.xdo" text; + in + "${pkgs.xdotool}/bin/xdotool ${xdoScript}"; + in '' import shlex import threading diff --git a/nixos/tests/atd.nix b/nixos/tests/atd.nix index 4342e9d7dc181a..fa61290174fbd3 100644 --- a/nixos/tests/atd.nix +++ b/nixos/tests/atd.nix @@ -1,31 +1,36 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -{ - name = "atd"; - meta = with pkgs.lib.maintainers; { - maintainers = [ bjornfor ]; - }; - - nodes.machine = - { ... }: - { services.atd.enable = true; - users.users.alice = { isNormalUser = true; }; + { + name = "atd"; + meta = with pkgs.lib.maintainers; { + maintainers = [ bjornfor ]; }; - # "at" has a resolution of 1 minute - testScript = '' - start_all() + nodes.machine = + { ... }: + { + services.atd.enable = true; + users.users.alice = { + isNormalUser = true; + }; + }; + + # "at" has a resolution of 1 minute + testScript = '' + start_all() - machine.wait_for_unit("atd.service") # wait for atd to start - machine.fail("test -f ~root/at-1") - machine.fail("test -f ~alice/at-1") + machine.wait_for_unit("atd.service") # wait for atd to start + machine.fail("test -f ~root/at-1") + machine.fail("test -f ~alice/at-1") - machine.succeed("echo 'touch ~root/at-1' | at now+1min") - machine.succeed("su - alice -c \"echo 'touch at-1' | at now+1min\"") + machine.succeed("echo 'touch ~root/at-1' | at now+1min") + machine.succeed("su - alice -c \"echo 'touch at-1' | at now+1min\"") - machine.succeed("sleep 1.5m") + machine.succeed("sleep 1.5m") - machine.succeed("test -f ~root/at-1") - machine.succeed("test -f ~alice/at-1") - ''; -}) + machine.succeed("test -f ~root/at-1") + machine.succeed("test -f ~alice/at-1") + ''; + } +) diff --git a/nixos/tests/atop.nix b/nixos/tests/atop.nix index f2c488c591703e..d2372c80c3f968 100644 --- a/nixos/tests/atop.nix +++ b/nixos/tests/atop.nix @@ -1,111 +1,132 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; with pkgs.lib; -let assertions = rec { - path = program: path: '' - with subtest("The path of ${program} should be ${path}"): - p = machine.succeed("type -p \"${program}\" | head -c -1") - assert p == "${path}", f"${program} is {p}, expected ${path}" - ''; - unit = name: state: '' - with subtest("Unit ${name} should be ${state}"): - if "${state}" == "active": - machine.wait_for_unit("${name}") - else: - machine.require_unit_state("${name}", "${state}") - ''; - version = '' - import re +let + assertions = rec { + path = program: path: '' + with subtest("The path of ${program} should be ${path}"): + p = machine.succeed("type -p \"${program}\" | head -c -1") + assert p == "${path}", f"${program} is {p}, expected ${path}" + ''; + unit = name: state: '' + with subtest("Unit ${name} should be ${state}"): + if "${state}" == "active": + machine.wait_for_unit("${name}") + else: + machine.require_unit_state("${name}", "${state}") + ''; + version = '' + import re - with subtest("binary should report the correct version"): - pkgver = "${pkgs.atop.version}" - ver = re.sub(r'(?s)^Version: (\d+\.\d+\.\d+).*', r'\1', machine.succeed("atop -V")) - assert ver == pkgver, f"Version is `{ver}`, expected `{pkgver}`" - ''; - atoprc = contents: - if builtins.stringLength contents > 0 then '' - with subtest("/etc/atoprc should have the correct contents"): - f = machine.succeed("cat /etc/atoprc") - assert f == "${contents}", f"/etc/atoprc contents: '{f}', expected '${contents}'" - '' else '' - with subtest("/etc/atoprc should not be present"): - machine.succeed("test ! -e /etc/atoprc") + with subtest("binary should report the correct version"): + pkgver = "${pkgs.atop.version}" + ver = re.sub(r'(?s)^Version: (\d+\.\d+\.\d+).*', r'\1', machine.succeed("atop -V")) + assert ver == pkgver, f"Version is `{ver}`, expected `{pkgver}`" ''; - wrapper = present: - if present then path "atop" "/run/wrappers/bin/atop" + '' - with subtest("Wrapper should be setuid root"): - stat = machine.succeed("stat --printf '%a %u' /run/wrappers/bin/atop") - assert stat == "4511 0", f"Wrapper stat is {stat}, expected '4511 0'" - '' - else path "atop" "/run/current-system/sw/bin/atop"; - atopService = present: - if present then - unit "atop.service" "active" - + '' - with subtest("atop.service should write some data to /var/log/atop"): + atoprc = + contents: + if builtins.stringLength contents > 0 then + '' + with subtest("/etc/atoprc should have the correct contents"): + f = machine.succeed("cat /etc/atoprc") + assert f == "${contents}", f"/etc/atoprc contents: '{f}', expected '${contents}'" + '' + else + '' + with subtest("/etc/atoprc should not be present"): + machine.succeed("test ! -e /etc/atoprc") + ''; + wrapper = + present: + if present then + path "atop" "/run/wrappers/bin/atop" + + '' + with subtest("Wrapper should be setuid root"): + stat = machine.succeed("stat --printf '%a %u' /run/wrappers/bin/atop") + assert stat == "4511 0", f"Wrapper stat is {stat}, expected '4511 0'" + '' + else + path "atop" "/run/current-system/sw/bin/atop"; + atopService = + present: + if present then + unit "atop.service" "active" + + '' + with subtest("atop.service should write some data to /var/log/atop"): - def has_data_files(last: bool) -> bool: - files = int(machine.succeed("ls -1 /var/log/atop | wc -l")) - if files == 0: - machine.log("Did not find at least one 1 data file") - if not last: - machine.log("Will retry...") - return False - return True + def has_data_files(last: bool) -> bool: + files = int(machine.succeed("ls -1 /var/log/atop | wc -l")) + if files == 0: + machine.log("Did not find at least one 1 data file") + if not last: + machine.log("Will retry...") + return False + return True - with machine.nested("Waiting for data files"): - retry(has_data_files) - '' else unit "atop.service" "inactive"; - atopRotateTimer = present: - unit "atop-rotate.timer" (if present then "active" else "inactive"); - atopacctService = present: - if present then - unit "atopacct.service" "active" - + '' - with subtest("atopacct.service should enable process accounting"): - machine.wait_until_succeeds("test -f /run/pacct_source") + with machine.nested("Waiting for data files"): + retry(has_data_files) + '' + else + unit "atop.service" "inactive"; + atopRotateTimer = present: unit "atop-rotate.timer" (if present then "active" else "inactive"); + atopacctService = + present: + if present then + unit "atopacct.service" "active" + + '' + with subtest("atopacct.service should enable process accounting"): + machine.wait_until_succeeds("test -f /run/pacct_source") - with subtest("atopacct.service should write data to /run/pacct_shadow.d"): + with subtest("atopacct.service should write data to /run/pacct_shadow.d"): - def has_data_files(last: bool) -> bool: - files = int(machine.succeed("ls -1 /run/pacct_shadow.d | wc -l")) - if files == 0: - machine.log("Did not find at least one 1 data file") - if not last: - machine.log("Will retry...") - return False - return True + def has_data_files(last: bool) -> bool: + files = int(machine.succeed("ls -1 /run/pacct_shadow.d | wc -l")) + if files == 0: + machine.log("Did not find at least one 1 data file") + if not last: + machine.log("Will retry...") + return False + return True - with machine.nested("Waiting for data files"): - retry(has_data_files) - '' else unit "atopacct.service" "inactive"; - netatop = present: - if present then - unit "netatop.service" "active" - + '' - with subtest("The netatop kernel module should be loaded"): - out = machine.succeed("modprobe -n -v netatop") - assert out == "", f"Module should be loaded already, but modprobe would have done {out}." - '' else '' - with subtest("The netatop kernel module should be absent"): - machine.fail("modprobe -n -v netatop") - ''; - atopgpu = present: - if present then - (unit "atopgpu.service" "active") + (path "atopgpud" "/run/current-system/sw/bin/atopgpud") - else (unit "atopgpu.service" "inactive") + '' - with subtest("atopgpud should not be present"): - machine.fail("type -p atopgpud") - ''; -}; -meta = { - timeout = 600; -}; + with machine.nested("Waiting for data files"): + retry(has_data_files) + '' + else + unit "atopacct.service" "inactive"; + netatop = + present: + if present then + unit "netatop.service" "active" + + '' + with subtest("The netatop kernel module should be loaded"): + out = machine.succeed("modprobe -n -v netatop") + assert out == "", f"Module should be loaded already, but modprobe would have done {out}." + '' + else + '' + with subtest("The netatop kernel module should be absent"): + machine.fail("modprobe -n -v netatop") + ''; + atopgpu = + present: + if present then + (unit "atopgpu.service" "active") + (path "atopgpud" "/run/current-system/sw/bin/atopgpud") + else + (unit "atopgpu.service" "inactive") + + '' + with subtest("atopgpud should not be present"): + machine.fail("type -p atopgpud") + ''; + }; + meta = { + timeout = 600; + }; in { justThePackage = makeTest { @@ -113,16 +134,18 @@ in nodes.machine = { environment.systemPackages = [ pkgs.atop ]; }; - testScript = with assertions; builtins.concatStringsSep "\n" [ - version - (atoprc "") - (wrapper false) - (atopService false) - (atopRotateTimer false) - (atopacctService false) - (netatop false) - (atopgpu false) - ]; + testScript = + with assertions; + builtins.concatStringsSep "\n" [ + version + (atoprc "") + (wrapper false) + (atopService false) + (atopRotateTimer false) + (atopacctService false) + (netatop false) + (atopgpu false) + ]; inherit meta; }; defaults = makeTest { @@ -132,16 +155,18 @@ in enable = true; }; }; - testScript = with assertions; builtins.concatStringsSep "\n" [ - version - (atoprc "") - (wrapper false) - (atopService true) - (atopRotateTimer true) - (atopacctService true) - (netatop false) - (atopgpu false) - ]; + testScript = + with assertions; + builtins.concatStringsSep "\n" [ + version + (atoprc "") + (wrapper false) + (atopService true) + (atopRotateTimer true) + (atopacctService true) + (netatop false) + (atopgpu false) + ]; inherit meta; }; minimal = makeTest { @@ -154,16 +179,18 @@ in atopacctService.enable = false; }; }; - testScript = with assertions; builtins.concatStringsSep "\n" [ - version - (atoprc "") - (wrapper false) - (atopService false) - (atopRotateTimer false) - (atopacctService false) - (netatop false) - (atopgpu false) - ]; + testScript = + with assertions; + builtins.concatStringsSep "\n" [ + version + (atoprc "") + (wrapper false) + (atopService false) + (atopRotateTimer false) + (atopacctService false) + (netatop false) + (atopgpu false) + ]; inherit meta; }; netatop = makeTest { @@ -174,16 +201,18 @@ in netatop.enable = true; }; }; - testScript = with assertions; builtins.concatStringsSep "\n" [ - version - (atoprc "") - (wrapper false) - (atopService true) - (atopRotateTimer true) - (atopacctService true) - (netatop true) - (atopgpu false) - ]; + testScript = + with assertions; + builtins.concatStringsSep "\n" [ + version + (atoprc "") + (wrapper false) + (atopService true) + (atopRotateTimer true) + (atopacctService true) + (netatop true) + (atopgpu false) + ]; inherit meta; }; atopgpu = makeTest { @@ -194,16 +223,18 @@ in atopgpu.enable = true; }; }; - testScript = with assertions; builtins.concatStringsSep "\n" [ - version - (atoprc "") - (wrapper false) - (atopService true) - (atopRotateTimer true) - (atopacctService true) - (netatop false) - (atopgpu true) - ]; + testScript = + with assertions; + builtins.concatStringsSep "\n" [ + version + (atoprc "") + (wrapper false) + (atopService true) + (atopRotateTimer true) + (atopacctService true) + (netatop false) + (atopgpu true) + ]; inherit meta; }; everything = makeTest { @@ -220,16 +251,18 @@ in atopgpu.enable = true; }; }; - testScript = with assertions; builtins.concatStringsSep "\n" [ - version - (atoprc "flags faf1\\ninterval 2\\n") - (wrapper true) - (atopService true) - (atopRotateTimer true) - (atopacctService true) - (netatop true) - (atopgpu true) - ]; + testScript = + with assertions; + builtins.concatStringsSep "\n" [ + version + (atoprc "flags faf1\\ninterval 2\\n") + (wrapper true) + (atopService true) + (atopRotateTimer true) + (atopacctService true) + (netatop true) + (atopgpu true) + ]; inherit meta; }; } diff --git a/nixos/tests/atuin.nix b/nixos/tests/atuin.nix index 3164c83c683dc7..ea0e6cb2eb7921 100644 --- a/nixos/tests/atuin.nix +++ b/nixos/tests/atuin.nix @@ -1,66 +1,66 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: -let - testPort = 8888; - testUser = "testerman"; - testPass = "password"; - testEmail = "test.testerman@test.com"; -in -{ - name = "atuin"; - meta.maintainers = with lib.maintainers; [ devusb ]; + let + testPort = 8888; + testUser = "testerman"; + testPass = "password"; + testEmail = "test.testerman@test.com"; + in + { + name = "atuin"; + meta.maintainers = with lib.maintainers; [ devusb ]; - nodes = { - server = - { ... }: - { - services.postgresql.enable = true; + nodes = { + server = + { ... }: + { + services.postgresql.enable = true; - services.atuin = { - enable = true; - port = testPort; - host = "0.0.0.0"; - openFirewall = true; - openRegistration = true; + services.atuin = { + enable = true; + port = testPort; + host = "0.0.0.0"; + openFirewall = true; + openRegistration = true; + }; }; - }; - client = - { ... }: - { }; + client = { ... }: { }; - }; + }; - testScript = with pkgs; '' - start_all() + testScript = with pkgs; '' + start_all() - # wait for atuin server startup - server.wait_for_unit("atuin.service") - server.wait_for_open_port(${toString testPort}) + # wait for atuin server startup + server.wait_for_unit("atuin.service") + server.wait_for_open_port(${toString testPort}) - # configure atuin client on server node - server.execute("mkdir -p ~/.config/atuin") - server.execute("echo 'sync_address = \"http://localhost:${toString testPort}\"' > ~/.config/atuin/config.toml") + # configure atuin client on server node + server.execute("mkdir -p ~/.config/atuin") + server.execute("echo 'sync_address = \"http://localhost:${toString testPort}\"' > ~/.config/atuin/config.toml") - # register with atuin server on server node - server.succeed("${atuin}/bin/atuin register -u ${testUser} -p ${testPass} -e ${testEmail}") - _, key = server.execute("${atuin}/bin/atuin key") + # register with atuin server on server node + server.succeed("${atuin}/bin/atuin register -u ${testUser} -p ${testPass} -e ${testEmail}") + _, key = server.execute("${atuin}/bin/atuin key") - # store test record in atuin server and sync - server.succeed("ATUIN_SESSION=$(${atuin}/bin/atuin uuid) ${atuin}/bin/atuin history start 'shazbot'") - server.succeed("${atuin}/bin/atuin sync") + # store test record in atuin server and sync + server.succeed("ATUIN_SESSION=$(${atuin}/bin/atuin uuid) ${atuin}/bin/atuin history start 'shazbot'") + server.succeed("${atuin}/bin/atuin sync") - # configure atuin client on client node - client.execute("mkdir -p ~/.config/atuin") - client.execute("echo 'sync_address = \"http://server:${toString testPort}\"' > ~/.config/atuin/config.toml") + # configure atuin client on client node + client.execute("mkdir -p ~/.config/atuin") + client.execute("echo 'sync_address = \"http://server:${toString testPort}\"' > ~/.config/atuin/config.toml") - # log in to atuin server on client node - client.succeed(f"${atuin}/bin/atuin login -u ${testUser} -p ${testPass} -k \"{key}\"") + # log in to atuin server on client node + client.succeed(f"${atuin}/bin/atuin login -u ${testUser} -p ${testPass} -k \"{key}\"") - # pull records from atuin server - client.succeed("${atuin}/bin/atuin sync -f") + # pull records from atuin server + client.succeed("${atuin}/bin/atuin sync -f") - # check for test record - client.succeed("ATUIN_SESSION=$(${atuin}/bin/atuin uuid) ${atuin}/bin/atuin history list | grep shazbot") - ''; -}) + # check for test record + client.succeed("ATUIN_SESSION=$(${atuin}/bin/atuin uuid) ${atuin}/bin/atuin history list | grep shazbot") + ''; + } +) diff --git a/nixos/tests/audiobookshelf.nix b/nixos/tests/audiobookshelf.nix index ccd830eb28daa5..a4dce23abaf828 100644 --- a/nixos/tests/audiobookshelf.nix +++ b/nixos/tests/audiobookshelf.nix @@ -1,20 +1,22 @@ -import ./make-test-python.nix ({ lib, ... }: -{ - name = "audiobookshelf"; - meta.maintainers = with lib.maintainers; [ wietsedv ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "audiobookshelf"; + meta.maintainers = with lib.maintainers; [ wietsedv ]; - nodes.machine = - { pkgs, ... }: - { - services.audiobookshelf = { - enable = true; - port = 1234; + nodes.machine = + { pkgs, ... }: + { + services.audiobookshelf = { + enable = true; + port = 1234; + }; }; - }; - testScript = '' - machine.wait_for_unit("audiobookshelf.service") - machine.wait_for_open_port(1234) - machine.succeed("curl --fail http://localhost:1234/") - ''; -}) + testScript = '' + machine.wait_for_unit("audiobookshelf.service") + machine.wait_for_open_port(1234) + machine.succeed("curl --fail http://localhost:1234/") + ''; + } +) diff --git a/nixos/tests/auth-mysql.nix b/nixos/tests/auth-mysql.nix index 77a69eb1cd5810..0a4d8f577fc7fc 100644 --- a/nixos/tests/auth-mysql.nix +++ b/nixos/tests/auth-mysql.nix @@ -1,18 +1,19 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: -let - dbUser = "nixos_auth"; - dbPassword = "topsecret123"; - dbName = "auth"; + let + dbUser = "nixos_auth"; + dbPassword = "topsecret123"; + dbName = "auth"; - mysqlUsername = "mysqltest"; - mysqlPassword = "topsecretmysqluserpassword123"; - mysqlGroup = "mysqlusers"; + mysqlUsername = "mysqltest"; + mysqlPassword = "topsecretmysqluserpassword123"; + mysqlGroup = "mysqlusers"; - localUsername = "localtest"; - localPassword = "topsecretlocaluserpassword123"; + localUsername = "localtest"; + localPassword = "topsecretlocaluserpassword123"; - mysqlInit = pkgs.writeText "mysqlInit" '' + mysqlInit = pkgs.writeText "mysqlInit" '' CREATE USER '${dbUser}'@'localhost' IDENTIFIED BY '${dbPassword}'; CREATE DATABASE ${dbName}; GRANT ALL PRIVILEGES ON ${dbName}.* TO '${dbUser}'@'localhost'; @@ -39,140 +40,141 @@ let ('${mysqlUsername}', 5000, 5000, SHA2('${mysqlPassword}', 256)); INSERT INTO `groups` (name, gid) VALUES ('${mysqlGroup}', 5000); ''; -in -{ - name = "auth-mysql"; - meta.maintainers = with lib.maintainers; [ netali ]; - - nodes.machine = - { ... }: - { - services.mysql = { - enable = true; - package = pkgs.mariadb; - settings.mysqld.bind-address = "127.0.0.1"; - initialScript = mysqlInit; - }; - - users.users.${localUsername} = { - isNormalUser = true; - password = localPassword; - }; + in + { + name = "auth-mysql"; + meta.maintainers = with lib.maintainers; [ netali ]; + + nodes.machine = + { ... }: + { + services.mysql = { + enable = true; + package = pkgs.mariadb; + settings.mysqld.bind-address = "127.0.0.1"; + initialScript = mysqlInit; + }; - security.pam.services.login.makeHomeDir = true; - - users.mysql = { - enable = true; - host = "127.0.0.1"; - user = dbUser; - database = dbName; - passwordFile = "${builtins.toFile "dbPassword" dbPassword}"; - pam = { - table = "users"; - userColumn = "name"; - passwordColumn = "password"; - passwordCrypt = "sha256"; - disconnectEveryOperation = true; + users.users.${localUsername} = { + isNormalUser = true; + password = localPassword; }; - nss = { - getpwnam = '' - SELECT name, 'x', uid, gid, name, CONCAT('/home/', name), "/run/current-system/sw/bin/bash" \ - FROM users \ - WHERE name='%1$s' \ - LIMIT 1 - ''; - getpwuid = '' - SELECT name, 'x', uid, gid, name, CONCAT('/home/', name), "/run/current-system/sw/bin/bash" \ - FROM users \ - WHERE uid=%1$u \ - LIMIT 1 - ''; - getspnam = '' - SELECT name, password, 1, 0, 99999, 7, 0, -1, 0 \ - FROM users \ - WHERE name='%1$s' \ - LIMIT 1 - ''; - getpwent = '' - SELECT name, 'x', uid, gid, name, CONCAT('/home/', name), "/run/current-system/sw/bin/bash" \ - FROM users - ''; - getspent = '' - SELECT name, password, 1, 0, 99999, 7, 0, -1, 0 \ - FROM users - ''; - getgrnam = '' - SELECT name, 'x', gid FROM groups WHERE name='%1$s' LIMIT 1 - ''; - getgrgid = '' - SELECT name, 'x', gid FROM groups WHERE gid='%1$u' LIMIT 1 - ''; - getgrent = '' - SELECT name, 'x', gid FROM groups - ''; - memsbygid = '' - SELECT name FROM users WHERE gid=%1$u - ''; - gidsbymem = '' - SELECT gid FROM users WHERE name='%1$s' - ''; + + security.pam.services.login.makeHomeDir = true; + + users.mysql = { + enable = true; + host = "127.0.0.1"; + user = dbUser; + database = dbName; + passwordFile = "${builtins.toFile "dbPassword" dbPassword}"; + pam = { + table = "users"; + userColumn = "name"; + passwordColumn = "password"; + passwordCrypt = "sha256"; + disconnectEveryOperation = true; + }; + nss = { + getpwnam = '' + SELECT name, 'x', uid, gid, name, CONCAT('/home/', name), "/run/current-system/sw/bin/bash" \ + FROM users \ + WHERE name='%1$s' \ + LIMIT 1 + ''; + getpwuid = '' + SELECT name, 'x', uid, gid, name, CONCAT('/home/', name), "/run/current-system/sw/bin/bash" \ + FROM users \ + WHERE uid=%1$u \ + LIMIT 1 + ''; + getspnam = '' + SELECT name, password, 1, 0, 99999, 7, 0, -1, 0 \ + FROM users \ + WHERE name='%1$s' \ + LIMIT 1 + ''; + getpwent = '' + SELECT name, 'x', uid, gid, name, CONCAT('/home/', name), "/run/current-system/sw/bin/bash" \ + FROM users + ''; + getspent = '' + SELECT name, password, 1, 0, 99999, 7, 0, -1, 0 \ + FROM users + ''; + getgrnam = '' + SELECT name, 'x', gid FROM groups WHERE name='%1$s' LIMIT 1 + ''; + getgrgid = '' + SELECT name, 'x', gid FROM groups WHERE gid='%1$u' LIMIT 1 + ''; + getgrent = '' + SELECT name, 'x', gid FROM groups + ''; + memsbygid = '' + SELECT name FROM users WHERE gid=%1$u + ''; + gidsbymem = '' + SELECT gid FROM users WHERE name='%1$s' + ''; + }; }; }; - }; - - testScript = '' - def switch_to_tty(tty_number): - machine.fail(f"pgrep -f 'agetty.*tty{tty_number}'") - machine.send_key(f"alt-f{tty_number}") - machine.wait_until_succeeds(f"[ $(fgconsole) = {tty_number} ]") - machine.wait_for_unit(f"getty@tty{tty_number}.service") - machine.wait_until_succeeds(f"pgrep -f 'agetty.*tty{tty_number}'") - - - def try_login(tty_number, username, password): - machine.wait_until_tty_matches(tty_number, "login: ") - machine.send_chars(f"{username}\n") - machine.wait_until_tty_matches(tty_number, f"login: {username}") - machine.wait_until_succeeds("pgrep login") - machine.wait_until_tty_matches(tty_number, "Password: ") - machine.send_chars(f"{password}\n") - - - machine.wait_for_unit("multi-user.target") - machine.wait_for_unit("mysql.service") - machine.wait_until_succeeds("cat /etc/security/pam_mysql.conf | grep users.db_passwd") - machine.wait_until_succeeds("pgrep -f 'agetty.*tty1'") - - with subtest("Local login"): - switch_to_tty("2") - try_login("2", "${localUsername}", "${localPassword}") - - machine.wait_until_succeeds("pgrep -u ${localUsername} bash") - machine.send_chars("id > local_id.txt\n") - machine.wait_for_file("/home/${localUsername}/local_id.txt") - machine.succeed("cat /home/${localUsername}/local_id.txt | grep 'uid=1000(${localUsername}) gid=100(users) groups=100(users)'") - - with subtest("Local incorrect login"): - switch_to_tty("3") - try_login("3", "${localUsername}", "wrongpassword") - - machine.wait_until_tty_matches("3", "Login incorrect") - machine.wait_until_tty_matches("3", "login:") - - with subtest("MySQL login"): - switch_to_tty("4") - try_login("4", "${mysqlUsername}", "${mysqlPassword}") - - machine.wait_until_succeeds("pgrep -u ${mysqlUsername} bash") - machine.send_chars("id > mysql_id.txt\n") - machine.wait_for_file("/home/${mysqlUsername}/mysql_id.txt") - machine.succeed("cat /home/${mysqlUsername}/mysql_id.txt | grep 'uid=5000(${mysqlUsername}) gid=5000(${mysqlGroup}) groups=5000(${mysqlGroup})'") - - with subtest("MySQL incorrect login"): - switch_to_tty("5") - try_login("5", "${mysqlUsername}", "wrongpassword") - - machine.wait_until_tty_matches("5", "Login incorrect") - machine.wait_until_tty_matches("5", "login:") + + testScript = '' + def switch_to_tty(tty_number): + machine.fail(f"pgrep -f 'agetty.*tty{tty_number}'") + machine.send_key(f"alt-f{tty_number}") + machine.wait_until_succeeds(f"[ $(fgconsole) = {tty_number} ]") + machine.wait_for_unit(f"getty@tty{tty_number}.service") + machine.wait_until_succeeds(f"pgrep -f 'agetty.*tty{tty_number}'") + + + def try_login(tty_number, username, password): + machine.wait_until_tty_matches(tty_number, "login: ") + machine.send_chars(f"{username}\n") + machine.wait_until_tty_matches(tty_number, f"login: {username}") + machine.wait_until_succeeds("pgrep login") + machine.wait_until_tty_matches(tty_number, "Password: ") + machine.send_chars(f"{password}\n") + + + machine.wait_for_unit("multi-user.target") + machine.wait_for_unit("mysql.service") + machine.wait_until_succeeds("cat /etc/security/pam_mysql.conf | grep users.db_passwd") + machine.wait_until_succeeds("pgrep -f 'agetty.*tty1'") + + with subtest("Local login"): + switch_to_tty("2") + try_login("2", "${localUsername}", "${localPassword}") + + machine.wait_until_succeeds("pgrep -u ${localUsername} bash") + machine.send_chars("id > local_id.txt\n") + machine.wait_for_file("/home/${localUsername}/local_id.txt") + machine.succeed("cat /home/${localUsername}/local_id.txt | grep 'uid=1000(${localUsername}) gid=100(users) groups=100(users)'") + + with subtest("Local incorrect login"): + switch_to_tty("3") + try_login("3", "${localUsername}", "wrongpassword") + + machine.wait_until_tty_matches("3", "Login incorrect") + machine.wait_until_tty_matches("3", "login:") + + with subtest("MySQL login"): + switch_to_tty("4") + try_login("4", "${mysqlUsername}", "${mysqlPassword}") + + machine.wait_until_succeeds("pgrep -u ${mysqlUsername} bash") + machine.send_chars("id > mysql_id.txt\n") + machine.wait_for_file("/home/${mysqlUsername}/mysql_id.txt") + machine.succeed("cat /home/${mysqlUsername}/mysql_id.txt | grep 'uid=5000(${mysqlUsername}) gid=5000(${mysqlGroup}) groups=5000(${mysqlGroup})'") + + with subtest("MySQL incorrect login"): + switch_to_tty("5") + try_login("5", "${mysqlUsername}", "wrongpassword") + + machine.wait_until_tty_matches("5", "Login incorrect") + machine.wait_until_tty_matches("5", "login:") ''; -}) + } +) diff --git a/nixos/tests/authelia.nix b/nixos/tests/authelia.nix index 679c65fea087a7..88e300e4cbe468 100644 --- a/nixos/tests/authelia.nix +++ b/nixos/tests/authelia.nix @@ -1,169 +1,187 @@ # Test Authelia as an auth server for Traefik as a reverse proxy of a local web service -import ./make-test-python.nix ({ lib, ... }: { - name = "authelia"; - meta.maintainers = with lib.maintainers; [ jk ]; - - nodes = { - authelia = { config, pkgs, lib, ... }: { - services.authelia.instances.testing = { - enable = true; - secrets.storageEncryptionKeyFile = "/etc/authelia/storageEncryptionKeyFile"; - secrets.jwtSecretFile = "/etc/authelia/jwtSecretFile"; - settings = { - authentication_backend.file.path = "/etc/authelia/users_database.yml"; - access_control.default_policy = "one_factor"; - session.domain = "example.com"; - storage.local.path = "/tmp/db.sqlite3"; - notifier.filesystem.filename = "/tmp/notifications.txt"; - }; - }; - - # These should not be set from nix but through other means to not leak the secret! - # This is purely for testing purposes! - environment.etc."authelia/storageEncryptionKeyFile" = { - mode = "0400"; - user = "authelia-testing"; - text = "you_must_generate_a_random_string_of_more_than_twenty_chars_and_configure_this"; - }; - environment.etc."authelia/jwtSecretFile" = { - mode = "0400"; - user = "authelia-testing"; - text = "a_very_important_secret"; - }; - environment.etc."authelia/users_database.yml" = { - mode = "0400"; - user = "authelia-testing"; - text = '' - users: - bob: - disabled: false - displayname: bob - # password of password - password: $argon2id$v=19$m=65536,t=3,p=4$2ohUAfh9yetl+utr4tLcCQ$AsXx0VlwjvNnCsa70u4HKZvFkC8Gwajr2pHGKcND/xs - email: bob@jim.com - groups: - - admin - - dev - ''; - }; - - services.traefik = { - enable = true; - - dynamicConfigOptions = { - tls.certificates = - let - certDir = pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' - openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=example.com/CN=auth.example.com/CN=static.example.com' -days 36500 - mkdir -p $out - cp key.pem cert.pem $out - ''; - in - [{ - certFile = "${certDir}/cert.pem"; - keyFile = "${certDir}/key.pem"; - }]; - http.middlewares.authelia.forwardAuth = { - address = "http://localhost:9091/api/verify?rd=https%3A%2F%2Fauth.example.com%2F"; - trustForwardHeader = true; - authResponseHeaders = [ - "Remote-User" - "Remote-Groups" - "Remote-Email" - "Remote-Name" - ]; - }; - http.middlewares.authelia-basic.forwardAuth = { - address = "http://localhost:9091/api/verify?auth=basic"; - trustForwardHeader = true; - authResponseHeaders = [ - "Remote-User" - "Remote-Groups" - "Remote-Email" - "Remote-Name" - ]; - }; - - http.routers.simplehttp = { - rule = "Host(`static.example.com`)"; - tls = true; - entryPoints = "web"; - service = "simplehttp"; - }; - http.routers.simplehttp-basic-auth = { - rule = "Host(`static-basic-auth.example.com`)"; - tls = true; - entryPoints = "web"; - service = "simplehttp"; - middlewares = [ "authelia-basic@file" ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "authelia"; + meta.maintainers = with lib.maintainers; [ jk ]; + + nodes = { + authelia = + { + config, + pkgs, + lib, + ... + }: + { + services.authelia.instances.testing = { + enable = true; + secrets.storageEncryptionKeyFile = "/etc/authelia/storageEncryptionKeyFile"; + secrets.jwtSecretFile = "/etc/authelia/jwtSecretFile"; + settings = { + authentication_backend.file.path = "/etc/authelia/users_database.yml"; + access_control.default_policy = "one_factor"; + session.domain = "example.com"; + storage.local.path = "/tmp/db.sqlite3"; + notifier.filesystem.filename = "/tmp/notifications.txt"; + }; }; - http.services.simplehttp = { - loadBalancer.servers = [{ - url = "http://localhost:8000"; - }]; + # These should not be set from nix but through other means to not leak the secret! + # This is purely for testing purposes! + environment.etc."authelia/storageEncryptionKeyFile" = { + mode = "0400"; + user = "authelia-testing"; + text = "you_must_generate_a_random_string_of_more_than_twenty_chars_and_configure_this"; }; - - http.routers.authelia = { - rule = "Host(`auth.example.com`)"; - tls = true; - entryPoints = "web"; - service = "authelia@file"; + environment.etc."authelia/jwtSecretFile" = { + mode = "0400"; + user = "authelia-testing"; + text = "a_very_important_secret"; }; - - http.services.authelia = { - loadBalancer.servers = [{ - url = "http://localhost:9091"; - }]; + environment.etc."authelia/users_database.yml" = { + mode = "0400"; + user = "authelia-testing"; + text = '' + users: + bob: + disabled: false + displayname: bob + # password of password + password: $argon2id$v=19$m=65536,t=3,p=4$2ohUAfh9yetl+utr4tLcCQ$AsXx0VlwjvNnCsa70u4HKZvFkC8Gwajr2pHGKcND/xs + email: bob@jim.com + groups: + - admin + - dev + ''; }; - }; - staticConfigOptions = { - global = { - checkNewVersion = false; - sendAnonymousUsage = false; + services.traefik = { + enable = true; + + dynamicConfigOptions = { + tls.certificates = + let + certDir = pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' + openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=example.com/CN=auth.example.com/CN=static.example.com' -days 36500 + mkdir -p $out + cp key.pem cert.pem $out + ''; + in + [ + { + certFile = "${certDir}/cert.pem"; + keyFile = "${certDir}/key.pem"; + } + ]; + http.middlewares.authelia.forwardAuth = { + address = "http://localhost:9091/api/verify?rd=https%3A%2F%2Fauth.example.com%2F"; + trustForwardHeader = true; + authResponseHeaders = [ + "Remote-User" + "Remote-Groups" + "Remote-Email" + "Remote-Name" + ]; + }; + http.middlewares.authelia-basic.forwardAuth = { + address = "http://localhost:9091/api/verify?auth=basic"; + trustForwardHeader = true; + authResponseHeaders = [ + "Remote-User" + "Remote-Groups" + "Remote-Email" + "Remote-Name" + ]; + }; + + http.routers.simplehttp = { + rule = "Host(`static.example.com`)"; + tls = true; + entryPoints = "web"; + service = "simplehttp"; + }; + http.routers.simplehttp-basic-auth = { + rule = "Host(`static-basic-auth.example.com`)"; + tls = true; + entryPoints = "web"; + service = "simplehttp"; + middlewares = [ "authelia-basic@file" ]; + }; + + http.services.simplehttp = { + loadBalancer.servers = [ + { + url = "http://localhost:8000"; + } + ]; + }; + + http.routers.authelia = { + rule = "Host(`auth.example.com`)"; + tls = true; + entryPoints = "web"; + service = "authelia@file"; + }; + + http.services.authelia = { + loadBalancer.servers = [ + { + url = "http://localhost:9091"; + } + ]; + }; + }; + + staticConfigOptions = { + global = { + checkNewVersion = false; + sendAnonymousUsage = false; + }; + + entryPoints.web.address = ":443"; + }; }; - entryPoints.web.address = ":443"; - }; - }; - - systemd.services.simplehttp = - let fakeWebPageDir = pkgs.writeTextDir "index.html" "hello"; in - { - script = "${pkgs.python3}/bin/python -m http.server --directory ${fakeWebPageDir} 8000"; - serviceConfig.Type = "simple"; - wantedBy = [ "multi-user.target" ]; + systemd.services.simplehttp = + let + fakeWebPageDir = pkgs.writeTextDir "index.html" "hello"; + in + { + script = "${pkgs.python3}/bin/python -m http.server --directory ${fakeWebPageDir} 8000"; + serviceConfig.Type = "simple"; + wantedBy = [ "multi-user.target" ]; + }; }; }; - }; - - testScript = '' - start_all() - - authelia.wait_for_unit("simplehttp.service") - authelia.wait_for_unit("traefik.service") - authelia.wait_for_unit("authelia-testing.service") - authelia.wait_for_open_port(443) - authelia.wait_for_unit("multi-user.target") - - with subtest("Check for authelia"): - # expect the login page - assert "Login - Authelia", "could not reach authelia" in \ - authelia.succeed("curl --insecure -sSf -H Host:auth.example.com https://authelia:443/") - - with subtest("Check contacting basic http server via traefik with https works"): - assert "hello", "could not reach raw static site" in \ - authelia.succeed("curl --insecure -sSf -H Host:static.example.com https://authelia:443/") - - with subtest("Test traefik and authelia"): - with subtest("No details fail"): - authelia.fail("curl --insecure -sSf -H Host:static-basic-auth.example.com https://authelia:443/") - with subtest("Incorrect details fail"): - authelia.fail("curl --insecure -sSf -u 'bob:wordpass' -H Host:static-basic-auth.example.com https://authelia:443/") - authelia.fail("curl --insecure -sSf -u 'alice:password' -H Host:static-basic-auth.example.com https://authelia:443/") - with subtest("Correct details pass"): - assert "hello", "could not reach authed static site with valid credentials" in \ - authelia.succeed("curl --insecure -sSf -u 'bob:password' -H Host:static-basic-auth.example.com https://authelia:443/") - ''; -}) + + testScript = '' + start_all() + + authelia.wait_for_unit("simplehttp.service") + authelia.wait_for_unit("traefik.service") + authelia.wait_for_unit("authelia-testing.service") + authelia.wait_for_open_port(443) + authelia.wait_for_unit("multi-user.target") + + with subtest("Check for authelia"): + # expect the login page + assert "Login - Authelia", "could not reach authelia" in \ + authelia.succeed("curl --insecure -sSf -H Host:auth.example.com https://authelia:443/") + + with subtest("Check contacting basic http server via traefik with https works"): + assert "hello", "could not reach raw static site" in \ + authelia.succeed("curl --insecure -sSf -H Host:static.example.com https://authelia:443/") + + with subtest("Test traefik and authelia"): + with subtest("No details fail"): + authelia.fail("curl --insecure -sSf -H Host:static-basic-auth.example.com https://authelia:443/") + with subtest("Incorrect details fail"): + authelia.fail("curl --insecure -sSf -u 'bob:wordpass' -H Host:static-basic-auth.example.com https://authelia:443/") + authelia.fail("curl --insecure -sSf -u 'alice:password' -H Host:static-basic-auth.example.com https://authelia:443/") + with subtest("Correct details pass"): + assert "hello", "could not reach authed static site with valid credentials" in \ + authelia.succeed("curl --insecure -sSf -u 'bob:password' -H Host:static-basic-auth.example.com https://authelia:443/") + ''; + } +) diff --git a/nixos/tests/avahi.nix b/nixos/tests/avahi.nix index 7a2d4bbd0ffc80..7d9432396a2805 100644 --- a/nixos/tests/avahi.nix +++ b/nixos/tests/avahi.nix @@ -1,9 +1,10 @@ -{ system ? builtins.currentSystem -, config ? {} -, pkgs ? import ../.. { inherit system config; } -# bool: whether to use networkd in the tests -, networkd ? false -} @ args: +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, + # bool: whether to use networkd in the tests + networkd ? false, +}@args: # Test whether `avahi-daemon' and `libnss-mdns' work as expected. import ./make-test-python.nix { @@ -12,28 +13,33 @@ import ./make-test-python.nix { maintainers = [ ]; }; - nodes = let - cfg = { ... }: { - services.avahi = { - enable = true; - nssmdns4 = true; - publish.addresses = true; - publish.domain = true; - publish.enable = true; - publish.userServices = true; - publish.workstation = true; - extraServiceFiles.ssh = "${pkgs.avahi}/etc/avahi/services/ssh.service"; - }; - } // pkgs.lib.optionalAttrs (networkd) { - networking = { - useNetworkd = true; - useDHCP = false; - }; + nodes = + let + cfg = + { ... }: + { + services.avahi = { + enable = true; + nssmdns4 = true; + publish.addresses = true; + publish.domain = true; + publish.enable = true; + publish.userServices = true; + publish.workstation = true; + extraServiceFiles.ssh = "${pkgs.avahi}/etc/avahi/services/ssh.service"; + }; + } + // pkgs.lib.optionalAttrs (networkd) { + networking = { + useNetworkd = true; + useDHCP = false; + }; + }; + in + { + one = cfg; + two = cfg; }; - in { - one = cfg; - two = cfg; - }; testScript = '' start_all() diff --git a/nixos/tests/ayatana-indicators.nix b/nixos/tests/ayatana-indicators.nix index 8d134e1af2eecc..12223e52a0c582 100644 --- a/nixos/tests/ayatana-indicators.nix +++ b/nixos/tests/ayatana-indicators.nix @@ -79,8 +79,7 @@ in let runCommandOverServiceList = list: command: lib.strings.concatMapStringsSep "\n" command list; - runCommandOverAyatanaIndicators = runCommandOverServiceList - nodes.machine.systemd.user.targets.ayatana-indicators.wants; + runCommandOverAyatanaIndicators = runCommandOverServiceList nodes.machine.systemd.user.targets.ayatana-indicators.wants; runCommandOverLomiriIndicators = runCommandOverServiceList nodes.machine.systemd.user.targets.lomiri-indicators.wants; in diff --git a/nixos/tests/babeld.nix b/nixos/tests/babeld.nix index e497aa5b64e151..8b2ee35370a2ed 100644 --- a/nixos/tests/babeld.nix +++ b/nixos/tests/babeld.nix @@ -1,123 +1,194 @@ +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "babeld"; + meta = with pkgs.lib.maintainers; { + maintainers = [ hexa ]; + }; -import ./make-test-python.nix ({ pkgs, lib, ...} : { - name = "babeld"; - meta = with pkgs.lib.maintainers; { - maintainers = [ hexa ]; - }; - - nodes = - { client = { pkgs, lib, ... }: - { - virtualisation.vlans = [ 10 ]; - - networking = { - useDHCP = false; - interfaces."eth1" = { - ipv4.addresses = lib.mkForce [ { address = "192.168.10.2"; prefixLength = 24; } ]; - ipv4.routes = lib.mkForce [ { address = "0.0.0.0"; prefixLength = 0; via = "192.168.10.1"; } ]; - ipv6.addresses = lib.mkForce [ { address = "2001:db8:10::2"; prefixLength = 64; } ]; - ipv6.routes = lib.mkForce [ { address = "::"; prefixLength = 0; via = "2001:db8:10::1"; } ]; + nodes = { + client = + { pkgs, lib, ... }: + { + virtualisation.vlans = [ 10 ]; + + networking = { + useDHCP = false; + interfaces."eth1" = { + ipv4.addresses = lib.mkForce [ + { + address = "192.168.10.2"; + prefixLength = 24; + } + ]; + ipv4.routes = lib.mkForce [ + { + address = "0.0.0.0"; + prefixLength = 0; + via = "192.168.10.1"; + } + ]; + ipv6.addresses = lib.mkForce [ + { + address = "2001:db8:10::2"; + prefixLength = 64; + } + ]; + ipv6.routes = lib.mkForce [ + { + address = "::"; + prefixLength = 0; + via = "2001:db8:10::1"; + } + ]; + }; }; }; - }; - - local_router = { pkgs, lib, ... }: - { - virtualisation.vlans = [ 10 20 ]; - networking = { - useDHCP = false; - firewall.enable = false; - - interfaces."eth1" = { - ipv4.addresses = lib.mkForce [ { address = "192.168.10.1"; prefixLength = 24; } ]; - ipv6.addresses = lib.mkForce [ { address = "2001:db8:10::1"; prefixLength = 64; } ]; + local_router = + { pkgs, lib, ... }: + { + virtualisation.vlans = [ + 10 + 20 + ]; + + networking = { + useDHCP = false; + firewall.enable = false; + + interfaces."eth1" = { + ipv4.addresses = lib.mkForce [ + { + address = "192.168.10.1"; + prefixLength = 24; + } + ]; + ipv6.addresses = lib.mkForce [ + { + address = "2001:db8:10::1"; + prefixLength = 64; + } + ]; + }; + + interfaces."eth2" = { + ipv4.addresses = lib.mkForce [ + { + address = "192.168.20.1"; + prefixLength = 24; + } + ]; + ipv6.addresses = lib.mkForce [ + { + address = "2001:db8:20::1"; + prefixLength = 64; + } + ]; + }; }; - interfaces."eth2" = { - ipv4.addresses = lib.mkForce [ { address = "192.168.20.1"; prefixLength = 24; } ]; - ipv6.addresses = lib.mkForce [ { address = "2001:db8:20::1"; prefixLength = 64; } ]; - }; - }; - - services.babeld = { - enable = true; - interfaces.eth2 = { - hello-interval = 1; - type = "wired"; - }; - extraConfig = '' - local-port-readwrite 33123 + services.babeld = { + enable = true; + interfaces.eth2 = { + hello-interval = 1; + type = "wired"; + }; + extraConfig = '' + local-port-readwrite 33123 - import-table 254 # main - export-table 254 # main + import-table 254 # main + export-table 254 # main - in ip 192.168.10.0/24 deny - in ip 192.168.20.0/24 deny - in ip 2001:db8:10::/64 deny - in ip 2001:db8:20::/64 deny + in ip 192.168.10.0/24 deny + in ip 192.168.20.0/24 deny + in ip 2001:db8:10::/64 deny + in ip 2001:db8:20::/64 deny - in ip 192.168.30.0/24 allow - in ip 2001:db8:30::/64 allow + in ip 192.168.30.0/24 allow + in ip 2001:db8:30::/64 allow - in deny + in deny - redistribute local proto 2 - redistribute local deny - ''; + redistribute local proto 2 + redistribute local deny + ''; + }; }; - }; - remote_router = { pkgs, lib, ... }: - { - virtualisation.vlans = [ 20 30 ]; - - networking = { - useDHCP = false; - firewall.enable = false; - - interfaces."eth1" = { - ipv4.addresses = lib.mkForce [ { address = "192.168.20.2"; prefixLength = 24; } ]; - ipv6.addresses = lib.mkForce [ { address = "2001:db8:20::2"; prefixLength = 64; } ]; + remote_router = + { pkgs, lib, ... }: + { + virtualisation.vlans = [ + 20 + 30 + ]; + + networking = { + useDHCP = false; + firewall.enable = false; + + interfaces."eth1" = { + ipv4.addresses = lib.mkForce [ + { + address = "192.168.20.2"; + prefixLength = 24; + } + ]; + ipv6.addresses = lib.mkForce [ + { + address = "2001:db8:20::2"; + prefixLength = 64; + } + ]; + }; + + interfaces."eth2" = { + ipv4.addresses = lib.mkForce [ + { + address = "192.168.30.1"; + prefixLength = 24; + } + ]; + ipv6.addresses = lib.mkForce [ + { + address = "2001:db8:30::1"; + prefixLength = 64; + } + ]; + }; }; - interfaces."eth2" = { - ipv4.addresses = lib.mkForce [ { address = "192.168.30.1"; prefixLength = 24; } ]; - ipv6.addresses = lib.mkForce [ { address = "2001:db8:30::1"; prefixLength = 64; } ]; - }; - }; + services.babeld = { + enable = true; + interfaces.eth1 = { + hello-interval = 1; + type = "wired"; + }; + extraConfig = '' + local-port-readwrite 33123 - services.babeld = { - enable = true; - interfaces.eth1 = { - hello-interval = 1; - type = "wired"; - }; - extraConfig = '' - local-port-readwrite 33123 + import-table 254 # main + export-table 254 # main - import-table 254 # main - export-table 254 # main + in ip 192.168.20.0/24 deny + in ip 192.168.30.0/24 deny + in ip 2001:db8:20::/64 deny + in ip 2001:db8:30::/64 deny - in ip 192.168.20.0/24 deny - in ip 192.168.30.0/24 deny - in ip 2001:db8:20::/64 deny - in ip 2001:db8:30::/64 deny + in ip 192.168.10.0/24 allow + in ip 2001:db8:10::/64 allow - in ip 192.168.10.0/24 allow - in ip 2001:db8:10::/64 allow + in deny - in deny + redistribute local proto 2 + redistribute local deny + ''; + }; - redistribute local proto 2 - redistribute local deny - ''; }; - - }; }; - testScript = - '' + testScript = '' start_all() local_router.wait_for_unit("babeld.service") @@ -135,4 +206,5 @@ import ./make-test-python.nix ({ pkgs, lib, ...} : { remote_router.succeed("ping -c1 192.168.10.2") remote_router.succeed("ping -c1 2001:db8:10::2") ''; -}) + } +) diff --git a/nixos/tests/bazarr.nix b/nixos/tests/bazarr.nix index aa0550e243ae32..b19b0ec00ddf39 100644 --- a/nixos/tests/bazarr.nix +++ b/nixos/tests/bazarr.nix @@ -1,24 +1,26 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -let - port = 42069; -in -{ - name = "bazarr"; - meta.maintainers = with lib.maintainers; [ d-xo ]; + let + port = 42069; + in + { + name = "bazarr"; + meta.maintainers = with lib.maintainers; [ d-xo ]; - nodes.machine = - { pkgs, ... }: - { - services.bazarr = { - enable = true; - listenPort = port; + nodes.machine = + { pkgs, ... }: + { + services.bazarr = { + enable = true; + listenPort = port; + }; }; - }; - testScript = '' - machine.wait_for_unit("bazarr.service") - machine.wait_for_open_port(${toString port}) - machine.succeed("curl --fail http://localhost:${toString port}/") - ''; -}) + testScript = '' + machine.wait_for_unit("bazarr.service") + machine.wait_for_open_port(${toString port}) + machine.succeed("curl --fail http://localhost:${toString port}/") + ''; + } +) diff --git a/nixos/tests/bcachefs.nix b/nixos/tests/bcachefs.nix index ec3c2427f386d4..05855ecdc1b78f 100644 --- a/nixos/tests/bcachefs.nix +++ b/nixos/tests/bcachefs.nix @@ -1,32 +1,40 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "bcachefs"; - meta.maintainers = with pkgs.lib.maintainers; [ Madouura ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "bcachefs"; + meta.maintainers = with pkgs.lib.maintainers; [ Madouura ]; - nodes.machine = { pkgs, ... }: { - virtualisation.emptyDiskImages = [ 4096 ]; - networking.hostId = "deadbeef"; - boot.supportedFilesystems = [ "bcachefs" ]; - environment.systemPackages = with pkgs; [ parted keyutils ]; - }; + nodes.machine = + { pkgs, ... }: + { + virtualisation.emptyDiskImages = [ 4096 ]; + networking.hostId = "deadbeef"; + boot.supportedFilesystems = [ "bcachefs" ]; + environment.systemPackages = with pkgs; [ + parted + keyutils + ]; + }; - testScript = '' - machine.succeed("modprobe bcachefs") - machine.succeed("bcachefs version") - machine.succeed("ls /dev") + testScript = '' + machine.succeed("modprobe bcachefs") + machine.succeed("bcachefs version") + machine.succeed("ls /dev") - machine.succeed( - "mkdir /tmp/mnt", - "udevadm settle", - "parted --script /dev/vdb mklabel msdos", - "parted --script /dev/vdb -- mkpart primary 1024M 50% mkpart primary 50% -1s", - "udevadm settle", - "echo password | bcachefs format --encrypted --metadata_replicas 2 --label vtest /dev/vdb1 /dev/vdb2", - "echo password | bcachefs unlock -k session /dev/vdb1", - "echo password | mount -t bcachefs /dev/vdb1:/dev/vdb2 /tmp/mnt", - "udevadm settle", - "bcachefs fs usage /tmp/mnt", - "umount /tmp/mnt", - "udevadm settle", - ) - ''; -}) + machine.succeed( + "mkdir /tmp/mnt", + "udevadm settle", + "parted --script /dev/vdb mklabel msdos", + "parted --script /dev/vdb -- mkpart primary 1024M 50% mkpart primary 50% -1s", + "udevadm settle", + "echo password | bcachefs format --encrypted --metadata_replicas 2 --label vtest /dev/vdb1 /dev/vdb2", + "echo password | bcachefs unlock -k session /dev/vdb1", + "echo password | mount -t bcachefs /dev/vdb1:/dev/vdb2 /tmp/mnt", + "udevadm settle", + "bcachefs fs usage /tmp/mnt", + "umount /tmp/mnt", + "udevadm settle", + ) + ''; + } +) diff --git a/nixos/tests/beanstalkd.nix b/nixos/tests/beanstalkd.nix index 518f018408ad89..a04b2396aae17f 100644 --- a/nixos/tests/beanstalkd.nix +++ b/nixos/tests/beanstalkd.nix @@ -1,49 +1,52 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: - -let - pythonEnv = pkgs.python3.withPackages (p: [p.beanstalkc]); - - produce = pkgs.writeScript "produce.py" '' - #!${pythonEnv.interpreter} - import beanstalkc - - queue = beanstalkc.Connection(host='localhost', port=11300, parse_yaml=False); - queue.put(b'this is a job') - queue.put(b'this is another job') - ''; - - consume = pkgs.writeScript "consume.py" '' - #!${pythonEnv.interpreter} - import beanstalkc - - queue = beanstalkc.Connection(host='localhost', port=11300, parse_yaml=False); - - job = queue.reserve(timeout=0) - print(job.body.decode('utf-8')) - job.delete() - ''; - -in -{ - name = "beanstalkd"; - meta.maintainers = [ lib.maintainers.aanderse ]; - - nodes.machine = - { ... }: - { services.beanstalkd.enable = true; - }; - - testScript = '' - start_all() - - machine.wait_for_unit("beanstalkd.service") - - machine.succeed("${produce}") - assert "this is a job\n" == machine.succeed( - "${consume}" - ) - assert "this is another job\n" == machine.succeed( - "${consume}" - ) - ''; -}) +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + let + pythonEnv = pkgs.python3.withPackages (p: [ p.beanstalkc ]); + + produce = pkgs.writeScript "produce.py" '' + #!${pythonEnv.interpreter} + import beanstalkc + + queue = beanstalkc.Connection(host='localhost', port=11300, parse_yaml=False); + queue.put(b'this is a job') + queue.put(b'this is another job') + ''; + + consume = pkgs.writeScript "consume.py" '' + #!${pythonEnv.interpreter} + import beanstalkc + + queue = beanstalkc.Connection(host='localhost', port=11300, parse_yaml=False); + + job = queue.reserve(timeout=0) + print(job.body.decode('utf-8')) + job.delete() + ''; + + in + { + name = "beanstalkd"; + meta.maintainers = [ lib.maintainers.aanderse ]; + + nodes.machine = + { ... }: + { + services.beanstalkd.enable = true; + }; + + testScript = '' + start_all() + + machine.wait_for_unit("beanstalkd.service") + + machine.succeed("${produce}") + assert "this is a job\n" == machine.succeed( + "${consume}" + ) + assert "this is another job\n" == machine.succeed( + "${consume}" + ) + ''; + } +) diff --git a/nixos/tests/bees.nix b/nixos/tests/bees.nix index 3ab9f38ada8fef..7d0bd6735ee5f9 100644 --- a/nixos/tests/bees.nix +++ b/nixos/tests/bees.nix @@ -1,62 +1,74 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -{ - name = "bees"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "bees"; - nodes.machine = { config, pkgs, ... }: { - boot.initrd.postDeviceCommands = '' - ${pkgs.btrfs-progs}/bin/mkfs.btrfs -f -L aux1 /dev/vdb - ${pkgs.btrfs-progs}/bin/mkfs.btrfs -f -L aux2 /dev/vdc - ''; - virtualisation.emptyDiskImages = [ 4096 4096 ]; - virtualisation.fileSystems = { - "/aux1" = { # filesystem configured to be deduplicated - device = "/dev/disk/by-label/aux1"; - fsType = "btrfs"; + nodes.machine = + { config, pkgs, ... }: + { + boot.initrd.postDeviceCommands = '' + ${pkgs.btrfs-progs}/bin/mkfs.btrfs -f -L aux1 /dev/vdb + ${pkgs.btrfs-progs}/bin/mkfs.btrfs -f -L aux2 /dev/vdc + ''; + virtualisation.emptyDiskImages = [ + 4096 + 4096 + ]; + virtualisation.fileSystems = { + "/aux1" = { + # filesystem configured to be deduplicated + device = "/dev/disk/by-label/aux1"; + fsType = "btrfs"; + }; + "/aux2" = { + # filesystem not configured to be deduplicated + device = "/dev/disk/by-label/aux2"; + fsType = "btrfs"; + }; + }; + services.beesd.filesystems = { + aux1 = { + spec = "LABEL=aux1"; + hashTableSizeMB = 16; + verbosity = "debug"; + }; + }; }; - "/aux2" = { # filesystem not configured to be deduplicated - device = "/dev/disk/by-label/aux2"; - fsType = "btrfs"; - }; - }; - services.beesd.filesystems = { - aux1 = { - spec = "LABEL=aux1"; - hashTableSizeMB = 16; - verbosity = "debug"; - }; - }; - }; - testScript = - let - someContentIsShared = loc: pkgs.writeShellScript "some-content-is-shared" '' - [[ $(btrfs fi du -s --raw ${lib.escapeShellArg loc}/dedup-me-{1,2} | awk 'BEGIN { count=0; } NR>1 && $3 == 0 { count++ } END { print count }') -eq 0 ]] - ''; - in '' - # shut down the instance started by systemd at boot, so we can test our test procedure - machine.succeed("systemctl stop beesd@aux1.service") + testScript = + let + someContentIsShared = + loc: + pkgs.writeShellScript "some-content-is-shared" '' + [[ $(btrfs fi du -s --raw ${lib.escapeShellArg loc}/dedup-me-{1,2} | awk 'BEGIN { count=0; } NR>1 && $3 == 0 { count++ } END { print count }') -eq 0 ]] + ''; + in + '' + # shut down the instance started by systemd at boot, so we can test our test procedure + machine.succeed("systemctl stop beesd@aux1.service") - machine.succeed( - "dd if=/dev/urandom of=/aux1/dedup-me-1 bs=1M count=8", - "cp --reflink=never /aux1/dedup-me-1 /aux1/dedup-me-2", - "cp --reflink=never /aux1/* /aux2/", - "sync", - ) - machine.fail( - "${someContentIsShared "/aux1"}", - "${someContentIsShared "/aux2"}", - ) - machine.succeed("systemctl start beesd@aux1.service") + machine.succeed( + "dd if=/dev/urandom of=/aux1/dedup-me-1 bs=1M count=8", + "cp --reflink=never /aux1/dedup-me-1 /aux1/dedup-me-2", + "cp --reflink=never /aux1/* /aux2/", + "sync", + ) + machine.fail( + "${someContentIsShared "/aux1"}", + "${someContentIsShared "/aux2"}", + ) + machine.succeed("systemctl start beesd@aux1.service") - # assert that "Set Shared" column is nonzero - machine.wait_until_succeeds( - "${someContentIsShared "/aux1"}", - ) - machine.fail("${someContentIsShared "/aux2"}") + # assert that "Set Shared" column is nonzero + machine.wait_until_succeeds( + "${someContentIsShared "/aux1"}", + ) + machine.fail("${someContentIsShared "/aux2"}") - # assert that 16MB hash table size requested was honored - machine.succeed( - "[[ $(stat -c %s /aux1/.beeshome/beeshash.dat) = $(( 16 * 1024 * 1024)) ]]" - ) - ''; -}) + # assert that 16MB hash table size requested was honored + machine.succeed( + "[[ $(stat -c %s /aux1/.beeshome/beeshash.dat) = $(( 16 * 1024 * 1024)) ]]" + ) + ''; + } +) diff --git a/nixos/tests/benchexec.nix b/nixos/tests/benchexec.nix index 3fc9ebc2c35f59..218bfb5afba418 100644 --- a/nixos/tests/benchexec.nix +++ b/nixos/tests/benchexec.nix @@ -1,54 +1,64 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - user = "alice"; -in -{ - name = "benchexec"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + user = "alice"; + in + { + name = "benchexec"; - nodes.benchexec = { - imports = [ ./common/user-account.nix ]; + nodes.benchexec = { + imports = [ ./common/user-account.nix ]; - programs.benchexec = { - enable = true; - users = [ user ]; + programs.benchexec = { + enable = true; + users = [ user ]; + }; }; - }; - testScript = { ... }: - let - runexec = lib.getExe' pkgs.benchexec "runexec"; - echo = builtins.toString pkgs.benchexec; - test = lib.getExe (pkgs.writeShellApplication rec { - name = "test"; - meta.mainProgram = name; - text = "echo '${echo}'"; - }); - wd = "/tmp"; - stdout = "${wd}/runexec.out"; - stderr = "${wd}/runexec.err"; - in - '' - start_all() - machine.wait_for_unit("multi-user.target") - benchexec.succeed(''''\ - systemd-run \ - --property='StandardOutput=file:${stdout}' \ - --property='StandardError=file:${stderr}' \ - --unit=runexec --wait --user --machine='${user}@' \ - --working-directory ${wd} \ - '${runexec}' \ - --debug \ - --read-only-dir / \ - --hidden-dir /home \ - '${test}' \ - '''') - benchexec.succeed("grep -s '${echo}' ${wd}/output.log") - benchexec.succeed("test \"$(grep -Ec '((start|wall|cpu)time|memory)=' ${stdout})\" = 4") - benchexec.succeed("! grep -E '(WARNING|ERROR)' ${stderr}") - ''; + testScript = + { ... }: + let + runexec = lib.getExe' pkgs.benchexec "runexec"; + echo = builtins.toString pkgs.benchexec; + test = lib.getExe ( + pkgs.writeShellApplication rec { + name = "test"; + meta.mainProgram = name; + text = "echo '${echo}'"; + } + ); + wd = "/tmp"; + stdout = "${wd}/runexec.out"; + stderr = "${wd}/runexec.err"; + in + '' + start_all() + machine.wait_for_unit("multi-user.target") + benchexec.succeed(''''\ + systemd-run \ + --property='StandardOutput=file:${stdout}' \ + --property='StandardError=file:${stderr}' \ + --unit=runexec --wait --user --machine='${user}@' \ + --working-directory ${wd} \ + '${runexec}' \ + --debug \ + --read-only-dir / \ + --hidden-dir /home \ + '${test}' \ + '''') + benchexec.succeed("grep -s '${echo}' ${wd}/output.log") + benchexec.succeed("test \"$(grep -Ec '((start|wall|cpu)time|memory)=' ${stdout})\" = 4") + benchexec.succeed("! grep -E '(WARNING|ERROR)' ${stderr}") + ''; - interactive.nodes.benchexec.services.kmscon = { - enable = true; - fonts = [{ name = "Fira Code"; package = pkgs.fira-code; }]; - }; -}) + interactive.nodes.benchexec.services.kmscon = { + enable = true; + fonts = [ + { + name = "Fira Code"; + package = pkgs.fira-code; + } + ]; + }; + } +) diff --git a/nixos/tests/binary-cache.nix b/nixos/tests/binary-cache.nix index bc1c6fb9a2671c..3877075143afdf 100644 --- a/nixos/tests/binary-cache.nix +++ b/nixos/tests/binary-cache.nix @@ -1,60 +1,63 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: - -{ - name = "binary-cache"; - meta.maintainers = with lib.maintainers; [ thomasjm ]; - - nodes.machine = - { pkgs, ... }: { - imports = [ ../modules/installer/cd-dvd/channel.nix ]; - environment.systemPackages = [ pkgs.python3 ]; - system.extraDependencies = [ pkgs.hello.inputDerivation ]; - nix.extraOptions = '' - experimental-features = nix-command - ''; - }; - - testScript = '' - # Build the cache, then remove it from the store - cachePath = machine.succeed("nix-build --no-out-link -E 'with import {}; mkBinaryCache { rootPaths = [hello]; }'").strip() - machine.succeed("cp -r %s/. /tmp/cache" % cachePath) - machine.succeed("nix-store --delete " + cachePath) - - # Sanity test of cache structure - status, stdout = machine.execute("ls /tmp/cache") - cache_files = stdout.split() - assert ("nix-cache-info" in cache_files) - assert ("nar" in cache_files) - - # Nix store ping should work - machine.succeed("nix store ping --store file:///tmp/cache") - - # Cache should contain a .narinfo referring to "hello" - grepLogs = machine.succeed("grep -l 'StorePath: /nix/store/[[:alnum:]]*-hello-.*' /tmp/cache/*.narinfo") - - # Get the store path referenced by the .narinfo - narInfoFile = grepLogs.strip() - narInfoContents = machine.succeed("cat " + narInfoFile) - import re - match = re.match(r"^StorePath: (/nix/store/[a-z0-9]*-hello-.*)$", narInfoContents, re.MULTILINE) - if not match: raise Exception("Couldn't find hello store path in cache") - storePath = match[1] - - # Delete the store path - machine.succeed("nix-store --delete " + storePath) - machine.succeed("[ ! -d %s ] || exit 1" % storePath) - - # Should be able to build hello using the cache - logs = machine.succeed("nix-build -A hello '' --option require-sigs false --option trusted-substituters file:///tmp/cache --option substituters file:///tmp/cache 2>&1") - logLines = logs.split("\n") - if not "this path will be fetched" in logLines[0]: raise Exception("Unexpected first log line") - def shouldBe(got, desired): - if got != desired: raise Exception("Expected '%s' but got '%s'" % (desired, got)) - shouldBe(logLines[1], " " + storePath) - shouldBe(logLines[2], "copying path '%s' from 'file:///tmp/cache'..." % storePath) - shouldBe(logLines[3], storePath) - - # Store path should exist in the store now - machine.succeed("[ -d %s ] || exit 1" % storePath) - ''; -}) +import ./make-test-python.nix ( + { lib, pkgs, ... }: + + { + name = "binary-cache"; + meta.maintainers = with lib.maintainers; [ thomasjm ]; + + nodes.machine = + { pkgs, ... }: + { + imports = [ ../modules/installer/cd-dvd/channel.nix ]; + environment.systemPackages = [ pkgs.python3 ]; + system.extraDependencies = [ pkgs.hello.inputDerivation ]; + nix.extraOptions = '' + experimental-features = nix-command + ''; + }; + + testScript = '' + # Build the cache, then remove it from the store + cachePath = machine.succeed("nix-build --no-out-link -E 'with import {}; mkBinaryCache { rootPaths = [hello]; }'").strip() + machine.succeed("cp -r %s/. /tmp/cache" % cachePath) + machine.succeed("nix-store --delete " + cachePath) + + # Sanity test of cache structure + status, stdout = machine.execute("ls /tmp/cache") + cache_files = stdout.split() + assert ("nix-cache-info" in cache_files) + assert ("nar" in cache_files) + + # Nix store ping should work + machine.succeed("nix store ping --store file:///tmp/cache") + + # Cache should contain a .narinfo referring to "hello" + grepLogs = machine.succeed("grep -l 'StorePath: /nix/store/[[:alnum:]]*-hello-.*' /tmp/cache/*.narinfo") + + # Get the store path referenced by the .narinfo + narInfoFile = grepLogs.strip() + narInfoContents = machine.succeed("cat " + narInfoFile) + import re + match = re.match(r"^StorePath: (/nix/store/[a-z0-9]*-hello-.*)$", narInfoContents, re.MULTILINE) + if not match: raise Exception("Couldn't find hello store path in cache") + storePath = match[1] + + # Delete the store path + machine.succeed("nix-store --delete " + storePath) + machine.succeed("[ ! -d %s ] || exit 1" % storePath) + + # Should be able to build hello using the cache + logs = machine.succeed("nix-build -A hello '' --option require-sigs false --option trusted-substituters file:///tmp/cache --option substituters file:///tmp/cache 2>&1") + logLines = logs.split("\n") + if not "this path will be fetched" in logLines[0]: raise Exception("Unexpected first log line") + def shouldBe(got, desired): + if got != desired: raise Exception("Expected '%s' but got '%s'" % (desired, got)) + shouldBe(logLines[1], " " + storePath) + shouldBe(logLines[2], "copying path '%s' from 'file:///tmp/cache'..." % storePath) + shouldBe(logLines[3], storePath) + + # Store path should exist in the store now + machine.succeed("[ -d %s ] || exit 1" % storePath) + ''; + } +) diff --git a/nixos/tests/bind.nix b/nixos/tests/bind.nix index 95a9fc4e58bbf5..5eb75392a38218 100644 --- a/nixos/tests/bind.nix +++ b/nixos/tests/bind.nix @@ -1,24 +1,26 @@ import ./make-test-python.nix { name = "bind"; - nodes.machine = { pkgs, lib, ... }: { - services.bind.enable = true; - services.bind.extraOptions = "empty-zones-enable no;"; - services.bind.zones = lib.singleton { - name = "."; - master = true; - file = pkgs.writeText "root.zone" '' - $TTL 3600 - . IN SOA ns.example.org. admin.example.org. ( 1 3h 1h 1w 1d ) - . IN NS ns.example.org. + nodes.machine = + { pkgs, lib, ... }: + { + services.bind.enable = true; + services.bind.extraOptions = "empty-zones-enable no;"; + services.bind.zones = lib.singleton { + name = "."; + master = true; + file = pkgs.writeText "root.zone" '' + $TTL 3600 + . IN SOA ns.example.org. admin.example.org. ( 1 3h 1h 1w 1d ) + . IN NS ns.example.org. - ns.example.org. IN A 192.168.0.1 - ns.example.org. IN AAAA abcd::1 + ns.example.org. IN A 192.168.0.1 + ns.example.org. IN AAAA abcd::1 - 1.0.168.192.in-addr.arpa IN PTR ns.example.org. - ''; + 1.0.168.192.in-addr.arpa IN PTR ns.example.org. + ''; + }; }; - }; testScript = '' machine.wait_for_unit("bind.service") diff --git a/nixos/tests/bird.nix b/nixos/tests/bird.nix index 822a7caea9ba3a..9b52e1beccaef2 100644 --- a/nixos/tests/bird.nix +++ b/nixos/tests/bird.nix @@ -1,103 +1,110 @@ # This test does a basic functionality check for all bird variants and demonstrates a use # of the preCheckConfig option. -{ system ? builtins.currentSystem -, pkgs ? import ../.. { inherit system; config = { }; } +{ + system ? builtins.currentSystem, + pkgs ? import ../.. { + inherit system; + config = { }; + }, }: let inherit (import ../lib/testing-python.nix { inherit system pkgs; }) makeTest; inherit (pkgs.lib) optionalString; - makeBird2Host = hostId: { pkgs, ... }: { - virtualisation.vlans = [ 1 ]; + makeBird2Host = + hostId: + { pkgs, ... }: + { + virtualisation.vlans = [ 1 ]; - environment.systemPackages = with pkgs; [ jq ]; + environment.systemPackages = with pkgs; [ jq ]; - networking = { - useNetworkd = true; - useDHCP = false; - firewall.enable = false; - }; + networking = { + useNetworkd = true; + useDHCP = false; + firewall.enable = false; + }; - systemd.network.networks."01-eth1" = { - name = "eth1"; - networkConfig.Address = "10.0.0.${hostId}/24"; - }; + systemd.network.networks."01-eth1" = { + name = "eth1"; + networkConfig.Address = "10.0.0.${hostId}/24"; + }; - services.bird2 = { - enable = true; + services.bird2 = { + enable = true; - config = '' - log syslog all; + config = '' + log syslog all; - debug protocols all; + debug protocols all; - router id 10.0.0.${hostId}; + router id 10.0.0.${hostId}; - protocol device { - } + protocol device { + } - protocol kernel kernel4 { - ipv4 { - import none; - export all; - }; - } + protocol kernel kernel4 { + ipv4 { + import none; + export all; + }; + } - protocol static static4 { - ipv4; - include "static4.conf"; - } + protocol static static4 { + ipv4; + include "static4.conf"; + } - protocol ospf v2 ospf4 { - ipv4 { - export all; - }; - area 0 { - interface "eth1" { - hello 5; - wait 5; + protocol ospf v2 ospf4 { + ipv4 { + export all; }; - }; - } - - protocol kernel kernel6 { - ipv6 { - import none; - export all; - }; - } - - protocol static static6 { - ipv6; - include "static6.conf"; - } - - protocol ospf v3 ospf6 { - ipv6 { - export all; - }; - area 0 { - interface "eth1" { - hello 5; - wait 5; + area 0 { + interface "eth1" { + hello 5; + wait 5; + }; }; - }; - } - ''; - - preCheckConfig = '' - echo "route 1.2.3.4/32 blackhole;" > static4.conf - echo "route fd00::/128 blackhole;" > static6.conf - ''; - }; + } + + protocol kernel kernel6 { + ipv6 { + import none; + export all; + }; + } + + protocol static static6 { + ipv6; + include "static6.conf"; + } - systemd.tmpfiles.rules = [ - "f /etc/bird/static4.conf - - - - route 10.10.0.${hostId}/32 blackhole;" - "f /etc/bird/static6.conf - - - - route fdff::${hostId}/128 blackhole;" - ]; - }; + protocol ospf v3 ospf6 { + ipv6 { + export all; + }; + area 0 { + interface "eth1" { + hello 5; + wait 5; + }; + }; + } + ''; + + preCheckConfig = '' + echo "route 1.2.3.4/32 blackhole;" > static4.conf + echo "route fd00::/128 blackhole;" > static6.conf + ''; + }; + + systemd.tmpfiles.rules = [ + "f /etc/bird/static4.conf - - - - route 10.10.0.${hostId}/32 blackhole;" + "f /etc/bird/static6.conf - - - - route fdff::${hostId}/128 blackhole;" + ]; + }; in makeTest { name = "bird2"; diff --git a/nixos/tests/birdwatcher.nix b/nixos/tests/birdwatcher.nix index 5c41b4d0e4f3a6..1f90e840e441a9 100644 --- a/nixos/tests/birdwatcher.nix +++ b/nixos/tests/birdwatcher.nix @@ -1,7 +1,11 @@ # This test does a basic functionality check for birdwatcher -{ system ? builtins.currentSystem -, pkgs ? import ../.. { inherit system; config = { }; } +{ + system ? builtins.currentSystem, + pkgs ? import ../.. { + inherit system; + config = { }; + }, }: let diff --git a/nixos/tests/bitcoind.nix b/nixos/tests/bitcoind.nix index 7726a23d853e6a..d588e055b14ade 100644 --- a/nixos/tests/bitcoind.nix +++ b/nixos/tests/bitcoind.nix @@ -1,48 +1,57 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "bitcoind"; - meta = with pkgs.lib; { - maintainers = with maintainers; [ _1000101 ]; - }; - - nodes.machine = { ... }: { - services.bitcoind."mainnet" = { - enable = true; - rpc = { - port = 8332; - users.rpc.passwordHMAC = "acc2374e5f9ba9e62a5204d3686616cf$53abdba5e67a9005be6a27ca03a93ce09e58854bc2b871523a0d239a72968033"; - users.rpc2.passwordHMAC = "1495e4a3ad108187576c68f7f9b5ddc5$accce0881c74aa01bb8960ff3bdbd39f607fd33178147679e055a4ac35f53225"; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "bitcoind"; + meta = with pkgs.lib; { + maintainers = with maintainers; [ _1000101 ]; }; - environment.etc."test.blank".text = ""; - services.bitcoind."testnet" = { - enable = true; - configFile = "/etc/test.blank"; - testnet = true; - rpc = { - port = 18332; + nodes.machine = + { ... }: + { + services.bitcoind."mainnet" = { + enable = true; + rpc = { + port = 8332; + users.rpc.passwordHMAC = "acc2374e5f9ba9e62a5204d3686616cf$53abdba5e67a9005be6a27ca03a93ce09e58854bc2b871523a0d239a72968033"; + users.rpc2.passwordHMAC = "1495e4a3ad108187576c68f7f9b5ddc5$accce0881c74aa01bb8960ff3bdbd39f607fd33178147679e055a4ac35f53225"; + }; + }; + + environment.etc."test.blank".text = ""; + services.bitcoind."testnet" = { + enable = true; + configFile = "/etc/test.blank"; + testnet = true; + rpc = { + port = 18332; + }; + extraCmdlineOptions = [ + "-rpcuser=rpc" + "-rpcpassword=rpc" + "-rpcauth=rpc2:1495e4a3ad108187576c68f7f9b5ddc5$accce0881c74aa01bb8960ff3bdbd39f607fd33178147679e055a4ac35f53225" + ]; + }; }; - extraCmdlineOptions = [ "-rpcuser=rpc" "-rpcpassword=rpc" "-rpcauth=rpc2:1495e4a3ad108187576c68f7f9b5ddc5$accce0881c74aa01bb8960ff3bdbd39f607fd33178147679e055a4ac35f53225" ]; - }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("bitcoind-mainnet.service") - machine.wait_for_unit("bitcoind-testnet.service") + machine.wait_for_unit("bitcoind-mainnet.service") + machine.wait_for_unit("bitcoind-testnet.service") - machine.wait_until_succeeds( - 'curl --fail --user rpc:rpc --data-binary \'{"jsonrpc": "1.0", "id":"curltest", "method": "getblockchaininfo", "params": [] }\' -H \'content-type: text/plain;\' localhost:8332 | grep \'"chain":"main"\' ' - ) - machine.wait_until_succeeds( - 'curl --fail --user rpc2:rpc2 --data-binary \'{"jsonrpc": "1.0", "id":"curltest", "method": "getblockchaininfo", "params": [] }\' -H \'content-type: text/plain;\' localhost:8332 | grep \'"chain":"main"\' ' - ) - machine.wait_until_succeeds( - 'curl --fail --user rpc:rpc --data-binary \'{"jsonrpc": "1.0", "id":"curltest", "method": "getblockchaininfo", "params": [] }\' -H \'content-type: text/plain;\' localhost:18332 | grep \'"chain":"test"\' ' - ) - machine.wait_until_succeeds( - 'curl --fail --user rpc2:rpc2 --data-binary \'{"jsonrpc": "1.0", "id":"curltest", "method": "getblockchaininfo", "params": [] }\' -H \'content-type: text/plain;\' localhost:18332 | grep \'"chain":"test"\' ' - ) - ''; -}) + machine.wait_until_succeeds( + 'curl --fail --user rpc:rpc --data-binary \'{"jsonrpc": "1.0", "id":"curltest", "method": "getblockchaininfo", "params": [] }\' -H \'content-type: text/plain;\' localhost:8332 | grep \'"chain":"main"\' ' + ) + machine.wait_until_succeeds( + 'curl --fail --user rpc2:rpc2 --data-binary \'{"jsonrpc": "1.0", "id":"curltest", "method": "getblockchaininfo", "params": [] }\' -H \'content-type: text/plain;\' localhost:8332 | grep \'"chain":"main"\' ' + ) + machine.wait_until_succeeds( + 'curl --fail --user rpc:rpc --data-binary \'{"jsonrpc": "1.0", "id":"curltest", "method": "getblockchaininfo", "params": [] }\' -H \'content-type: text/plain;\' localhost:18332 | grep \'"chain":"test"\' ' + ) + machine.wait_until_succeeds( + 'curl --fail --user rpc2:rpc2 --data-binary \'{"jsonrpc": "1.0", "id":"curltest", "method": "getblockchaininfo", "params": [] }\' -H \'content-type: text/plain;\' localhost:18332 | grep \'"chain":"test"\' ' + ) + ''; + } +) diff --git a/nixos/tests/blockbook-frontend.nix b/nixos/tests/blockbook-frontend.nix index dca4f2f53cc10c..60bc59d8ec8db8 100644 --- a/nixos/tests/blockbook-frontend.nix +++ b/nixos/tests/blockbook-frontend.nix @@ -1,28 +1,33 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "blockbook-frontend"; - meta = with pkgs.lib; { - maintainers = with maintainers; [ _1000101 ]; - }; - - nodes.machine = { ... }: { - services.blockbook-frontend."test" = { - enable = true; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "blockbook-frontend"; + meta = with pkgs.lib; { + maintainers = with maintainers; [ _1000101 ]; }; - services.bitcoind.mainnet = { - enable = true; - rpc = { - port = 8030; - users.rpc.passwordHMAC = "acc2374e5f9ba9e62a5204d3686616cf$53abdba5e67a9005be6a27ca03a93ce09e58854bc2b871523a0d239a72968033"; + + nodes.machine = + { ... }: + { + services.blockbook-frontend."test" = { + enable = true; + }; + services.bitcoind.mainnet = { + enable = true; + rpc = { + port = 8030; + users.rpc.passwordHMAC = "acc2374e5f9ba9e62a5204d3686616cf$53abdba5e67a9005be6a27ca03a93ce09e58854bc2b871523a0d239a72968033"; + }; + }; }; - }; - }; - testScript = '' - start_all() - machine.wait_for_unit("blockbook-frontend-test.service") + testScript = '' + start_all() + machine.wait_for_unit("blockbook-frontend-test.service") - machine.wait_for_open_port(9030) + machine.wait_for_open_port(9030) - machine.succeed("curl -sSfL http://localhost:9030 | grep 'Blockbook'") - ''; -}) + machine.succeed("curl -sSfL http://localhost:9030 | grep 'Blockbook'") + ''; + } +) diff --git a/nixos/tests/blocky.nix b/nixos/tests/blocky.nix index 18e7f45e1c738c..bfbd57589a875c 100644 --- a/nixos/tests/blocky.nix +++ b/nixos/tests/blocky.nix @@ -2,26 +2,31 @@ import ./make-test-python.nix { name = "blocky"; nodes = { - server = { pkgs, ... }: { - environment.systemPackages = [ pkgs.dnsutils ]; - services.blocky = { - enable = true; + server = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.dnsutils ]; + services.blocky = { + enable = true; - settings = { - customDNS = { - mapping = { - "printer.lan" = "192.168.178.3,2001:0db8:85a3:08d3:1319:8a2e:0370:7344"; + settings = { + customDNS = { + mapping = { + "printer.lan" = "192.168.178.3,2001:0db8:85a3:08d3:1319:8a2e:0370:7344"; + }; }; + upstream = { + default = [ + "8.8.8.8" + "1.1.1.1" + ]; + }; + port = 53; + httpPort = 5000; + logLevel = "info"; }; - upstream = { - default = [ "8.8.8.8" "1.1.1.1" ]; - }; - port = 53; - httpPort = 5000; - logLevel = "info"; }; }; - }; }; testScript = '' diff --git a/nixos/tests/boot-stage1.nix b/nixos/tests/boot-stage1.nix index bc6caa8ee627da..c700b79b27fec5 100644 --- a/nixos/tests/boot-stage1.nix +++ b/nixos/tests/boot-stage1.nix @@ -1,164 +1,193 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "boot-stage1"; - - nodes.machine = { config, pkgs, lib, ... }: { - boot.extraModulePackages = let - compileKernelModule = name: source: pkgs.runCommandCC name rec { - inherit source; - kdev = config.boot.kernelPackages.kernel.dev; - kver = config.boot.kernelPackages.kernel.modDirVersion; - ksrc = "${kdev}/lib/modules/${kver}/build"; - hardeningDisable = [ "pic" ]; - nativeBuildInputs = kdev.moduleBuildDependencies; - } '' - echo "obj-m += $name.o" > Makefile - echo "$source" > "$name.c" - make -C "$ksrc" M=$(pwd) modules - install -vD "$name.ko" "$out/lib/modules/$kver/$name.ko" - ''; - - # This spawns a kthread which just waits until it gets a signal and - # terminates if that is the case. We want to make sure that nothing during - # the boot process kills any kthread by accident, like what happened in - # issue #15226. - kcanary = compileKernelModule "kcanary" '' - #include - #include - #include - #include - #include - #include - #include - #if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 10, 0) - #include - #endif - - MODULE_LICENSE("GPL"); - - struct task_struct *canaryTask; - - static int kcanary(void *nothing) - { - allow_signal(SIGINT); - allow_signal(SIGTERM); - allow_signal(SIGKILL); - while (!kthread_should_stop()) { - set_current_state(TASK_INTERRUPTIBLE); - schedule_timeout_interruptible(msecs_to_jiffies(100)); - if (signal_pending(current)) break; - } - return 0; - } - - static int kcanaryInit(void) - { - kthread_run(&kcanary, NULL, "kcanary"); - return 0; - } - - static void kcanaryExit(void) - { - kthread_stop(canaryTask); - } - - module_init(kcanaryInit); - module_exit(kcanaryExit); - ''; - - in lib.singleton kcanary; - - boot.initrd.kernelModules = [ "kcanary" ]; - - boot.initrd.extraUtilsCommands = let - compile = name: source: pkgs.runCommandCC name { inherit source; } '' - mkdir -p "$out/bin" - echo "$source" | gcc -Wall -o "$out/bin/$name" -xc - - ''; - - daemonize = name: source: compile name '' - #include - #include - - void runSource(void) { - ${source} - } - - int main(void) { - if (fork() > 0) return 0; - setsid(); - runSource(); - return 1; - } - ''; - - mkCmdlineCanary = { name, cmdline ? "", source ? "" }: (daemonize name '' - char *argv[] = {"${cmdline}", NULL}; - execvp("${name}-child", argv); - '') // { - child = compile "${name}-child" '' - #include - #include - - int main(void) { - ${source} - while (1) sleep(1); - return 1; - } +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "boot-stage1"; + + nodes.machine = + { + config, + pkgs, + lib, + ... + }: + { + boot.extraModulePackages = + let + compileKernelModule = + name: source: + pkgs.runCommandCC name + rec { + inherit source; + kdev = config.boot.kernelPackages.kernel.dev; + kver = config.boot.kernelPackages.kernel.modDirVersion; + ksrc = "${kdev}/lib/modules/${kver}/build"; + hardeningDisable = [ "pic" ]; + nativeBuildInputs = kdev.moduleBuildDependencies; + } + '' + echo "obj-m += $name.o" > Makefile + echo "$source" > "$name.c" + make -C "$ksrc" M=$(pwd) modules + install -vD "$name.ko" "$out/lib/modules/$kver/$name.ko" + ''; + + # This spawns a kthread which just waits until it gets a signal and + # terminates if that is the case. We want to make sure that nothing during + # the boot process kills any kthread by accident, like what happened in + # issue #15226. + kcanary = compileKernelModule "kcanary" '' + #include + #include + #include + #include + #include + #include + #include + #if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 10, 0) + #include + #endif + + MODULE_LICENSE("GPL"); + + struct task_struct *canaryTask; + + static int kcanary(void *nothing) + { + allow_signal(SIGINT); + allow_signal(SIGTERM); + allow_signal(SIGKILL); + while (!kthread_should_stop()) { + set_current_state(TASK_INTERRUPTIBLE); + schedule_timeout_interruptible(msecs_to_jiffies(100)); + if (signal_pending(current)) break; + } + return 0; + } + + static int kcanaryInit(void) + { + kthread_run(&kcanary, NULL, "kcanary"); + return 0; + } + + static void kcanaryExit(void) + { + kthread_stop(canaryTask); + } + + module_init(kcanaryInit); + module_exit(kcanaryExit); + ''; + + in + lib.singleton kcanary; + + boot.initrd.kernelModules = [ "kcanary" ]; + + boot.initrd.extraUtilsCommands = + let + compile = + name: source: + pkgs.runCommandCC name { inherit source; } '' + mkdir -p "$out/bin" + echo "$source" | gcc -Wall -o "$out/bin/$name" -xc - + ''; + + daemonize = + name: source: + compile name '' + #include + #include + + void runSource(void) { + ${source} + } + + int main(void) { + if (fork() > 0) return 0; + setsid(); + runSource(); + return 1; + } + ''; + + mkCmdlineCanary = + { + name, + cmdline ? "", + source ? "", + }: + (daemonize name '' + char *argv[] = {"${cmdline}", NULL}; + execvp("${name}-child", argv); + '') + // { + child = compile "${name}-child" '' + #include + #include + + int main(void) { + ${source} + while (1) sleep(1); + return 1; + } + ''; + }; + + copyCanaries = lib.concatMapStrings (canary: '' + ${lib.optionalString (canary ? child) '' + copy_bin_and_libs "${canary.child}/bin/${canary.child.name}" + ''} + copy_bin_and_libs "${canary}/bin/${canary.name}" + ''); + + in + copyCanaries [ + # Simple canary process which just sleeps forever and should be killed by + # stage 2. + (daemonize "canary1" "while (1) sleep(1);") + + # We want this canary process to try mimicking a kthread using a cmdline + # with a zero length so we can make sure that the process is properly + # killed in stage 1. + (mkCmdlineCanary { + name = "canary2"; + source = '' + FILE *f; + f = fopen("/run/canary2.pid", "w"); + fprintf(f, "%d\n", getpid()); + fclose(f); + ''; + }) + + # This canary process mimics a storage daemon, which we do NOT want to be + # killed before going into stage 2. For more on root storage daemons, see: + # https://www.freedesktop.org/wiki/Software/systemd/RootStorageDaemons/ + (mkCmdlineCanary { + name = "canary3"; + cmdline = "@canary3"; + }) + ]; + + boot.initrd.postMountCommands = '' + canary1 + canary2 + canary3 + # Make sure the pidfile of canary 2 is created so that we still can get + # its former pid after the killing spree starts next within stage 1. + while [ ! -s /run/canary2.pid ]; do sleep 0.1; done ''; }; - copyCanaries = lib.concatMapStrings (canary: '' - ${lib.optionalString (canary ? child) '' - copy_bin_and_libs "${canary.child}/bin/${canary.child.name}" - ''} - copy_bin_and_libs "${canary}/bin/${canary.name}" - ''); - - in copyCanaries [ - # Simple canary process which just sleeps forever and should be killed by - # stage 2. - (daemonize "canary1" "while (1) sleep(1);") - - # We want this canary process to try mimicking a kthread using a cmdline - # with a zero length so we can make sure that the process is properly - # killed in stage 1. - (mkCmdlineCanary { - name = "canary2"; - source = '' - FILE *f; - f = fopen("/run/canary2.pid", "w"); - fprintf(f, "%d\n", getpid()); - fclose(f); - ''; - }) - - # This canary process mimics a storage daemon, which we do NOT want to be - # killed before going into stage 2. For more on root storage daemons, see: - # https://www.freedesktop.org/wiki/Software/systemd/RootStorageDaemons/ - (mkCmdlineCanary { - name = "canary3"; - cmdline = "@canary3"; - }) - ]; - - boot.initrd.postMountCommands = '' - canary1 - canary2 - canary3 - # Make sure the pidfile of canary 2 is created so that we still can get - # its former pid after the killing spree starts next within stage 1. - while [ ! -s /run/canary2.pid ]; do sleep 0.1; done + testScript = '' + machine.wait_for_unit("multi-user.target") + machine.succeed("test -s /run/canary2.pid") + machine.fail("pgrep -a canary1") + machine.fail("kill -0 $(< /run/canary2.pid)") + machine.succeed('pgrep -a -f "^@canary3$"') + machine.succeed('pgrep -a -f "^\\[kcanary\\]$"') ''; - }; - - testScript = '' - machine.wait_for_unit("multi-user.target") - machine.succeed("test -s /run/canary2.pid") - machine.fail("pgrep -a canary1") - machine.fail("kill -0 $(< /run/canary2.pid)") - machine.succeed('pgrep -a -f "^@canary3$"') - machine.succeed('pgrep -a -f "^\\[kcanary\\]$"') - ''; - - meta.maintainers = with pkgs.lib.maintainers; [ aszlig ]; -}) + + meta.maintainers = with pkgs.lib.maintainers; [ aszlig ]; + } +) diff --git a/nixos/tests/boot.nix b/nixos/tests/boot.nix index 3ec8d3e5a3cf9d..11e88bd3d89123 100644 --- a/nixos/tests/boot.nix +++ b/nixos/tests/boot.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -9,36 +10,58 @@ let lib = pkgs.lib; qemu-common = import ../lib/qemu-common.nix { inherit lib pkgs; }; - mkStartCommand = { - memory ? 2048, - cdrom ? null, - usb ? null, - pxe ? null, - uboot ? false, - uefi ? false, - extraFlags ? [], - }: let - qemu = qemu-common.qemuBinary pkgs.qemu_test; - - flags = [ - "-m" (toString memory) - "-netdev" ("user,id=net0" + (lib.optionalString (pxe != null) ",tftp=${pxe},bootfile=netboot.ipxe")) - "-device" ("virtio-net-pci,netdev=net0" + (lib.optionalString (pxe != null && uefi) ",romfile=${pkgs.ipxe}/ipxe.efirom")) - ] ++ lib.optionals (cdrom != null) [ - "-cdrom" cdrom - ] ++ lib.optionals (usb != null) [ - "-device" "usb-ehci" - "-drive" "id=usbdisk,file=${usb},if=none,readonly" - "-device" "usb-storage,drive=usbdisk" - ] ++ lib.optionals (pxe != null) [ - "-boot" "order=n" - ] ++ lib.optionals uefi [ - "-drive" "if=pflash,format=raw,unit=0,readonly=on,file=${pkgs.OVMF.firmware}" - "-drive" "if=pflash,format=raw,unit=1,readonly=on,file=${pkgs.OVMF.variables}" - ] ++ extraFlags; - - flagsStr = lib.concatStringsSep " " flags; - in "${qemu} ${flagsStr}"; + mkStartCommand = + { + memory ? 2048, + cdrom ? null, + usb ? null, + pxe ? null, + uboot ? false, + uefi ? false, + extraFlags ? [ ], + }: + let + qemu = qemu-common.qemuBinary pkgs.qemu_test; + + flags = + [ + "-m" + (toString memory) + "-netdev" + ("user,id=net0" + (lib.optionalString (pxe != null) ",tftp=${pxe},bootfile=netboot.ipxe")) + "-device" + ( + "virtio-net-pci,netdev=net0" + + (lib.optionalString (pxe != null && uefi) ",romfile=${pkgs.ipxe}/ipxe.efirom") + ) + ] + ++ lib.optionals (cdrom != null) [ + "-cdrom" + cdrom + ] + ++ lib.optionals (usb != null) [ + "-device" + "usb-ehci" + "-drive" + "id=usbdisk,file=${usb},if=none,readonly" + "-device" + "usb-storage,drive=usbdisk" + ] + ++ lib.optionals (pxe != null) [ + "-boot" + "order=n" + ] + ++ lib.optionals uefi [ + "-drive" + "if=pflash,format=raw,unit=0,readonly=on,file=${pkgs.OVMF.firmware}" + "-drive" + "if=pflash,format=raw,unit=1,readonly=on,file=${pkgs.OVMF.variables}" + ] + ++ extraFlags; + + flagsStr = lib.concatStringsSep " " flags; + in + "${qemu} ${flagsStr}"; iso = (import ../lib/eval-config.nix { @@ -59,31 +82,33 @@ let ]; }).config.system.build.sdImage; - makeBootTest = name: config: + makeBootTest = + name: config: let startCommand = mkStartCommand config; in - makeTest { - name = "boot-" + name; - nodes = { }; - testScript = - '' - machine = create_machine("${startCommand}") - machine.start() - machine.wait_for_unit("multi-user.target") - machine.succeed("nix store verify --no-trust -r --option experimental-features nix-command /run/current-system") - - with subtest("Check whether the channel got installed correctly"): - machine.succeed("nix-instantiate --dry-run '' -A hello") - machine.succeed("nix-env --dry-run -iA nixos.procps") - - machine.shutdown() - ''; - }; + makeTest { + name = "boot-" + name; + nodes = { }; + testScript = '' + machine = create_machine("${startCommand}") + machine.start() + machine.wait_for_unit("multi-user.target") + machine.succeed("nix store verify --no-trust -r --option experimental-features nix-command /run/current-system") + + with subtest("Check whether the channel got installed correctly"): + machine.succeed("nix-instantiate --dry-run '' -A hello") + machine.succeed("nix-env --dry-run -iA nixos.procps") - makeNetbootTest = name: extraConfig: + machine.shutdown() + ''; + }; + + makeNetbootTest = + name: extraConfig: let - config = (import ../lib/eval-config.nix { + config = + (import ../lib/eval-config.nix { inherit system; modules = [ ../modules/installer/netboot/netboot.nix @@ -107,9 +132,12 @@ let config.system.build.netbootIpxeScript ]; }; - startCommand = mkStartCommand ({ - pxe = ipxeBootDir; - } // extraConfig); + startCommand = mkStartCommand ( + { + pxe = ipxeBootDir; + } + // extraConfig + ); in makeTest { name = "boot-netboot-" + name; @@ -145,24 +173,29 @@ in cdrom = "${iso}/iso/${iso.isoName}"; }; - biosUsb = makeBootTest "bios-usb" { - usb = "${iso}/iso/${iso.isoName}"; - }; + biosUsb = makeBootTest "bios-usb" { + usb = "${iso}/iso/${iso.isoName}"; + }; - biosNetboot = makeNetbootTest "bios" {}; + biosNetboot = makeNetbootTest "bios" { }; - ubootExtlinux = let + ubootExtlinux = + let sdImage = "${sd}/sd-image/${sd.imageName}"; mutableImage = "/tmp/linked-image.qcow2"; startCommand = mkStartCommand { extraFlags = [ - "-bios" "${pkgs.ubootQemuX86}/u-boot.rom" - "-machine" "type=pc,accel=tcg" - "-drive" "file=${mutableImage},if=virtio" + "-bios" + "${pkgs.ubootQemuX86}/u-boot.rom" + "-machine" + "type=pc,accel=tcg" + "-drive" + "file=${mutableImage},if=virtio" ]; }; - in makeTest { + in + makeTest { name = "boot-uboot-extlinux"; nodes = { }; testScript = '' diff --git a/nixos/tests/bootspec.nix b/nixos/tests/bootspec.nix index 14928b22062510..83a39d94d7e7a2 100644 --- a/nixos/tests/bootspec.nix +++ b/nixos/tests/bootspec.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -144,7 +145,6 @@ in ''; }; - # Check that specialisations create corresponding entries in bootspec. specialisation = makeTest { name = "bootspec-with-specialisation"; @@ -153,7 +153,7 @@ in nodes.machine = { imports = [ standard ]; environment.systemPackages = [ pkgs.jq ]; - specialisation.something.configuration = {}; + specialisation.something.configuration = { }; }; testScript = '' @@ -177,15 +177,17 @@ in name = "bootspec-with-extensions"; meta.maintainers = with pkgs.lib.maintainers; [ raitobezarius ]; - nodes.machine = { config, ... }: { - imports = [ standard ]; - environment.systemPackages = [ pkgs.jq ]; - boot.bootspec.extensions = { - "org.nix-tests.product" = { - osRelease = config.environment.etc."os-release".source; + nodes.machine = + { config, ... }: + { + imports = [ standard ]; + environment.systemPackages = [ pkgs.jq ]; + boot.bootspec.extensions = { + "org.nix-tests.product" = { + osRelease = config.environment.etc."os-release".source; + }; }; }; - }; testScript = '' machine.start() diff --git a/nixos/tests/borgmatic.nix b/nixos/tests/borgmatic.nix index 70ad43e8bd3581..be2542ed64ca89 100644 --- a/nixos/tests/borgmatic.nix +++ b/nixos/tests/borgmatic.nix @@ -1,24 +1,28 @@ -import ./make-test-python.nix ({ pkgs, ... }: -{ - name = "borgmatic"; - nodes.machine = { ... }: { - services.borgmatic = { - enable = true; - settings = { - source_directories = [ "/home" ]; - repositories = [ - { - label = "local"; - path = "/var/backup"; - } - ]; - keep_daily = 7; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "borgmatic"; + nodes.machine = + { ... }: + { + services.borgmatic = { + enable = true; + settings = { + source_directories = [ "/home" ]; + repositories = [ + { + label = "local"; + path = "/var/backup"; + } + ]; + keep_daily = 7; + }; + }; }; - }; - }; - testScript = '' - machine.succeed("borgmatic rcreate -e none") - machine.succeed("borgmatic") - ''; -}) + testScript = '' + machine.succeed("borgmatic rcreate -e none") + machine.succeed("borgmatic") + ''; + } +) diff --git a/nixos/tests/botamusique.nix b/nixos/tests/botamusique.nix index ecb79cb69867ef..c87224d52a9469 100644 --- a/nixos/tests/botamusique.nix +++ b/nixos/tests/botamusique.nix @@ -1,51 +1,55 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : - -{ - name = "botamusique"; - meta.maintainers = with lib.maintainers; [ hexa ]; - - nodes = { - machine = { config, ... }: { - networking.extraHosts = '' - 127.0.0.1 all.api.radio-browser.info - ''; - - services.murmur = { - enable = true; - registerName = "NixOS tests"; - }; - - services.botamusique = { - enable = true; - settings = { - server = { - channel = "NixOS tests"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + { + name = "botamusique"; + meta.maintainers = with lib.maintainers; [ hexa ]; + + nodes = { + machine = + { config, ... }: + { + networking.extraHosts = '' + 127.0.0.1 all.api.radio-browser.info + ''; + + services.murmur = { + enable = true; + registerName = "NixOS tests"; }; - bot = { - version = false; - auto_check_update = false; + + services.botamusique = { + enable = true; + settings = { + server = { + channel = "NixOS tests"; + }; + bot = { + version = false; + auto_check_update = false; + }; + }; }; }; - }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("murmur.service") - machine.wait_for_unit("botamusique.service") + machine.wait_for_unit("murmur.service") + machine.wait_for_unit("botamusique.service") - machine.sleep(10) + machine.sleep(10) - machine.wait_until_succeeds( - "journalctl -u murmur.service -e | grep -q '<1:botamusique(-1)> Authenticated'" - ) + machine.wait_until_succeeds( + "journalctl -u murmur.service -e | grep -q '<1:botamusique(-1)> Authenticated'" + ) - with subtest("Check systemd hardening"): - output = machine.execute("systemctl show botamusique.service")[1] - machine.log(output) - output = machine.execute("systemd-analyze security botamusique.service")[1] - machine.log(output) - ''; -}) + with subtest("Check systemd hardening"): + output = machine.execute("systemctl show botamusique.service")[1] + machine.log(output) + output = machine.execute("systemd-analyze security botamusique.service")[1] + machine.log(output) + ''; + } +) diff --git a/nixos/tests/bpf.nix b/nixos/tests/bpf.nix index 0020c7ee2d6933..8d871d276d424d 100644 --- a/nixos/tests/bpf.nix +++ b/nixos/tests/bpf.nix @@ -1,39 +1,44 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "bpf"; - meta.maintainers = with pkgs.lib.maintainers; [ martinetd ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "bpf"; + meta.maintainers = with pkgs.lib.maintainers; [ martinetd ]; - nodes.machine = { pkgs, ... }: { - programs.bcc.enable = true; - environment.systemPackages = with pkgs; [ bpftrace ]; - }; + nodes.machine = + { pkgs, ... }: + { + programs.bcc.enable = true; + environment.systemPackages = with pkgs; [ bpftrace ]; + }; - testScript = '' - ## bcc - # syscount -d 1 stops 1s after probe started so is good for that - print(machine.succeed("syscount -d 1")) + testScript = '' + ## bcc + # syscount -d 1 stops 1s after probe started so is good for that + print(machine.succeed("syscount -d 1")) - ## bpftrace - # list probes - machine.succeed("bpftrace -l") - # simple BEGIN probe (user probe on bpftrace itself) - print(machine.succeed("bpftrace -e 'BEGIN { print(\"ok\\n\"); exit(); }'")) - # tracepoint - print(machine.succeed("bpftrace -e 'tracepoint:syscalls:sys_enter_* { print(probe); exit() }'")) - # kprobe - print(machine.succeed("bpftrace -e 'kprobe:schedule { print(probe); exit() }'")) - # BTF - print(machine.succeed("bpftrace -e 'kprobe:schedule { " - " printf(\"tgid: %d\\n\", ((struct task_struct*) curtask)->tgid); exit() " - "}'")) - # module BTF (bpftrace >= 0.17) - # test is currently disabled on aarch64 as kfunc does not work there yet - # https://github.com/iovisor/bpftrace/issues/2496 - print(machine.succeed("uname -m | grep aarch64 || " - "bpftrace -e 'kfunc:nft_trans_alloc_gfp { " - " printf(\"portid: %d\\n\", args->ctx->portid); " - "} BEGIN { exit() }'")) - # glibc includes - print(machine.succeed("bpftrace -e '#include \n" - "BEGIN { printf(\"ok %d\\n\", EINVAL); exit(); }'")) - ''; -}) + ## bpftrace + # list probes + machine.succeed("bpftrace -l") + # simple BEGIN probe (user probe on bpftrace itself) + print(machine.succeed("bpftrace -e 'BEGIN { print(\"ok\\n\"); exit(); }'")) + # tracepoint + print(machine.succeed("bpftrace -e 'tracepoint:syscalls:sys_enter_* { print(probe); exit() }'")) + # kprobe + print(machine.succeed("bpftrace -e 'kprobe:schedule { print(probe); exit() }'")) + # BTF + print(machine.succeed("bpftrace -e 'kprobe:schedule { " + " printf(\"tgid: %d\\n\", ((struct task_struct*) curtask)->tgid); exit() " + "}'")) + # module BTF (bpftrace >= 0.17) + # test is currently disabled on aarch64 as kfunc does not work there yet + # https://github.com/iovisor/bpftrace/issues/2496 + print(machine.succeed("uname -m | grep aarch64 || " + "bpftrace -e 'kfunc:nft_trans_alloc_gfp { " + " printf(\"portid: %d\\n\", args->ctx->portid); " + "} BEGIN { exit() }'")) + # glibc includes + print(machine.succeed("bpftrace -e '#include \n" + "BEGIN { printf(\"ok %d\\n\", EINVAL); exit(); }'")) + ''; + } +) diff --git a/nixos/tests/bpftune.nix b/nixos/tests/bpftune.nix index c17bbcd1109202..454e27272d5b65 100644 --- a/nixos/tests/bpftune.nix +++ b/nixos/tests/bpftune.nix @@ -1,20 +1,25 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { - name = "bpftune"; + name = "bpftune"; - meta = { - maintainers = with lib.maintainers; [ nickcao ]; - }; + meta = { + maintainers = with lib.maintainers; [ nickcao ]; + }; - nodes = { - machine = { pkgs, ... }: { - services.bpftune.enable = true; + nodes = { + machine = + { pkgs, ... }: + { + services.bpftune.enable = true; + }; }; - }; - testScript = '' - machine.wait_for_unit("bpftune.service") - machine.wait_for_console_text("bpftune works") - ''; + testScript = '' + machine.wait_for_unit("bpftune.service") + machine.wait_for_console_text("bpftune works") + ''; -}) + } +) diff --git a/nixos/tests/breitbandmessung.nix b/nixos/tests/breitbandmessung.nix index 78df0d5017eb09..414fd09cfa542a 100644 --- a/nixos/tests/breitbandmessung.nix +++ b/nixos/tests/breitbandmessung.nix @@ -1,33 +1,41 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "breitbandmessung"; - meta.maintainers = with lib.maintainers; [ b4dm4n ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "breitbandmessung"; + meta.maintainers = with lib.maintainers; [ b4dm4n ]; - nodes.machine = { pkgs, ... }: { - imports = [ - ./common/user-account.nix - ./common/x11.nix - ]; + nodes.machine = + { pkgs, ... }: + { + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; - # increase screen size to make the whole program visible - virtualisation.resolution = { x = 1280; y = 1024; }; + # increase screen size to make the whole program visible + virtualisation.resolution = { + x = 1280; + y = 1024; + }; - test-support.displayManager.auto.user = "alice"; + test-support.displayManager.auto.user = "alice"; - environment.systemPackages = with pkgs; [ breitbandmessung ]; - environment.variables.XAUTHORITY = "/home/alice/.Xauthority"; + environment.systemPackages = with pkgs; [ breitbandmessung ]; + environment.variables.XAUTHORITY = "/home/alice/.Xauthority"; - # breitbandmessung is unfree - nixpkgs.config.allowUnfreePredicate = pkg: builtins.elem (lib.getName pkg) [ "breitbandmessung" ]; - }; + # breitbandmessung is unfree + nixpkgs.config.allowUnfreePredicate = pkg: builtins.elem (lib.getName pkg) [ "breitbandmessung" ]; + }; - enableOCR = true; + enableOCR = true; - testScript = '' - machine.wait_for_x() - machine.execute("su - alice -c breitbandmessung >&2 &") - machine.wait_for_window("Breitbandmessung") - machine.wait_for_text("Breitbandmessung") - machine.wait_for_text("Datenschutz") - machine.screenshot("breitbandmessung") - ''; -}) + testScript = '' + machine.wait_for_x() + machine.execute("su - alice -c breitbandmessung >&2 &") + machine.wait_for_window("Breitbandmessung") + machine.wait_for_text("Breitbandmessung") + machine.wait_for_text("Datenschutz") + machine.screenshot("breitbandmessung") + ''; + } +) diff --git a/nixos/tests/brscan5.nix b/nixos/tests/brscan5.nix index 9156a4cccfcfa1..f61228bac41e68 100644 --- a/nixos/tests/brscan5.nix +++ b/nixos/tests/brscan5.nix @@ -1,43 +1,53 @@ # integration tests for brscan5 sane driver # -import ./make-test-python.nix ({ pkgs, ...} : { - name = "brscan5"; - meta = with pkgs.lib.maintainers; { - maintainers = [ mattchrist ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "brscan5"; + meta = with pkgs.lib.maintainers; { + maintainers = [ mattchrist ]; + }; - nodes.machine = { pkgs, ... }: - { - nixpkgs.config.allowUnfree = true; - hardware.sane = { - enable = true; - brscan5 = { + nodes.machine = + { pkgs, ... }: + { + nixpkgs.config.allowUnfree = true; + hardware.sane = { enable = true; - netDevices = { - "a" = { model="ADS-1200"; nodename="BRW0080927AFBCE"; }; - "b" = { model="ADS-1200"; ip="192.168.1.2"; }; + brscan5 = { + enable = true; + netDevices = { + "a" = { + model = "ADS-1200"; + nodename = "BRW0080927AFBCE"; + }; + "b" = { + model = "ADS-1200"; + ip = "192.168.1.2"; + }; + }; }; }; }; - }; - testScript = '' - import re - # sane loads libsane-brother5.so.1 successfully, and scanimage doesn't die - strace = machine.succeed('strace scanimage -L 2>&1').split("\n") - regexp = 'openat\(.*libsane-brother5.so.1", O_RDONLY|O_CLOEXEC\) = \d\d*$' - assert len([x for x in strace if re.match(regexp,x)]) > 0 + testScript = '' + import re + # sane loads libsane-brother5.so.1 successfully, and scanimage doesn't die + strace = machine.succeed('strace scanimage -L 2>&1').split("\n") + regexp = 'openat\(.*libsane-brother5.so.1", O_RDONLY|O_CLOEXEC\) = \d\d*$' + assert len([x for x in strace if re.match(regexp,x)]) > 0 - # module creates a config - cfg = machine.succeed('cat /etc/opt/brother/scanner/brscan5/brsanenetdevice.cfg') - assert 'DEVICE=a , "ADS-1200" , 0x4f9:0x459 , NODENAME=BRW0080927AFBCE' in cfg - assert 'DEVICE=b , "ADS-1200" , 0x4f9:0x459 , IP-ADDRESS=192.168.1.2' in cfg + # module creates a config + cfg = machine.succeed('cat /etc/opt/brother/scanner/brscan5/brsanenetdevice.cfg') + assert 'DEVICE=a , "ADS-1200" , 0x4f9:0x459 , NODENAME=BRW0080927AFBCE' in cfg + assert 'DEVICE=b , "ADS-1200" , 0x4f9:0x459 , IP-ADDRESS=192.168.1.2' in cfg - # scanimage lists the two network scanners - scanimage = machine.succeed("scanimage -L") - print(scanimage) - assert """device `brother5:net1;dev0' is a Brother b ADS-1200""" in scanimage - assert """device `brother5:net1;dev1' is a Brother a ADS-1200""" in scanimage - ''; -}) + # scanimage lists the two network scanners + scanimage = machine.succeed("scanimage -L") + print(scanimage) + assert """device `brother5:net1;dev0' is a Brother b ADS-1200""" in scanimage + assert """device `brother5:net1;dev1' is a Brother a ADS-1200""" in scanimage + ''; + } +) diff --git a/nixos/tests/btrbk-no-timer.nix b/nixos/tests/btrbk-no-timer.nix index 4fcab8839c8920..c5bcb6edab6852 100644 --- a/nixos/tests/btrbk-no-timer.nix +++ b/nixos/tests/btrbk-no-timer.nix @@ -1,18 +1,21 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: +import ./make-test-python.nix ( + { lib, pkgs, ... }: { name = "btrbk-no-timer"; meta.maintainers = with lib.maintainers; [ oxalica ]; - nodes.machine = { ... }: { - environment.systemPackages = with pkgs; [ btrfs-progs ]; - services.btrbk.instances.local = { - onCalendar = null; - settings.volume."/mnt" = { - snapshot_dir = "btrbk/local"; - subvolume = "to_backup"; + nodes.machine = + { ... }: + { + environment.systemPackages = with pkgs; [ btrfs-progs ]; + services.btrbk.instances.local = { + onCalendar = null; + settings.volume."/mnt" = { + snapshot_dir = "btrbk/local"; + subvolume = "to_backup"; + }; }; }; - }; testScript = '' start_all() @@ -34,4 +37,5 @@ import ./make-test-python.nix ({ lib, pkgs, ... }: machine.start_job("btrbk-local.service") machine.wait_until_succeeds("cat /mnt/btrbk/local/*/bar | grep foo") ''; - }) + } +) diff --git a/nixos/tests/btrbk-section-order.nix b/nixos/tests/btrbk-section-order.nix index 6082de947f66fa..03762b3fee6bf5 100644 --- a/nixos/tests/btrbk-section-order.nix +++ b/nixos/tests/btrbk-section-order.nix @@ -6,51 +6,56 @@ # order-sensitive config format. # # Issue: https://github.com/NixOS/nixpkgs/issues/195660 -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "btrbk-section-order"; - meta.maintainers = with lib.maintainers; [ oxalica ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "btrbk-section-order"; + meta.maintainers = with lib.maintainers; [ oxalica ]; - nodes.machine = { ... }: { - services.btrbk.instances.local = { - onCalendar = null; - settings = { - timestamp_format = "long"; - target."ssh://global-target/".ssh_user = "root"; - volume."/btrfs" = { - snapshot_dir = "/volume-snapshots"; - target."ssh://volume-target/".ssh_user = "root"; - subvolume."@subvolume" = { - snapshot_dir = "/subvolume-snapshots"; - target."ssh://subvolume-target/".ssh_user = "root"; + nodes.machine = + { ... }: + { + services.btrbk.instances.local = { + onCalendar = null; + settings = { + timestamp_format = "long"; + target."ssh://global-target/".ssh_user = "root"; + volume."/btrfs" = { + snapshot_dir = "/volume-snapshots"; + target."ssh://volume-target/".ssh_user = "root"; + subvolume."@subvolume" = { + snapshot_dir = "/subvolume-snapshots"; + target."ssh://subvolume-target/".ssh_user = "root"; + }; + }; }; }; }; - }; - }; - testScript = '' - import difflib - machine.wait_for_unit("basic.target") - got = machine.succeed("cat /etc/btrbk/local.conf").strip() - expect = """ - backend btrfs-progs-sudo - stream_compress no - timestamp_format long - target ssh://global-target/ - ssh_user root - volume /btrfs - snapshot_dir /volume-snapshots - target ssh://volume-target/ - ssh_user root - subvolume @subvolume - snapshot_dir /subvolume-snapshots - target ssh://subvolume-target/ + testScript = '' + import difflib + machine.wait_for_unit("basic.target") + got = machine.succeed("cat /etc/btrbk/local.conf").strip() + expect = """ + backend btrfs-progs-sudo + stream_compress no + timestamp_format long + target ssh://global-target/ ssh_user root - """.strip() - print(got) - if got != expect: - diff = difflib.unified_diff(expect.splitlines(keepends=True), got.splitlines(keepends=True), fromfile="expected", tofile="got") - print("".join(diff)) - assert got == expect - ''; -}) + volume /btrfs + snapshot_dir /volume-snapshots + target ssh://volume-target/ + ssh_user root + subvolume @subvolume + snapshot_dir /subvolume-snapshots + target ssh://subvolume-target/ + ssh_user root + """.strip() + print(got) + if got != expect: + diff = difflib.unified_diff(expect.splitlines(keepends=True), got.splitlines(keepends=True), fromfile="expected", tofile="got") + print("".join(diff)) + assert got == expect + ''; + } +) diff --git a/nixos/tests/budgie.nix b/nixos/tests/budgie.nix index 9f24ea71de1d4a..5389a8d9da9d29 100644 --- a/nixos/tests/budgie.nix +++ b/nixos/tests/budgie.nix @@ -1,98 +1,104 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "budgie"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "budgie"; - meta.maintainers = lib.teams.budgie.members; + meta.maintainers = lib.teams.budgie.members; - nodes.machine = { ... }: { - imports = [ - ./common/user-account.nix - ]; + nodes.machine = + { ... }: + { + imports = [ + ./common/user-account.nix + ]; - services.xserver.enable = true; + services.xserver.enable = true; - services.xserver.displayManager = { - lightdm.enable = true; - autoLogin = { - enable = true; - user = "alice"; - }; - }; + services.xserver.displayManager = { + lightdm.enable = true; + autoLogin = { + enable = true; + user = "alice"; + }; + }; - # We don't ship gnome-text-editor in Budgie module, we add this line mainly - # to catch eval issues related to this option. - environment.budgie.excludePackages = [ pkgs.gnome-text-editor ]; + # We don't ship gnome-text-editor in Budgie module, we add this line mainly + # to catch eval issues related to this option. + environment.budgie.excludePackages = [ pkgs.gnome-text-editor ]; - services.xserver.desktopManager.budgie = { - enable = true; - extraPlugins = [ - pkgs.budgie-analogue-clock-applet - ]; - }; - }; + services.xserver.desktopManager.budgie = { + enable = true; + extraPlugins = [ + pkgs.budgie-analogue-clock-applet + ]; + }; + }; - testScript = { nodes, ... }: - let - user = nodes.machine.users.users.alice; - env = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${toString user.uid}/bus DISPLAY=:0"; - su = command: "su - ${user.name} -c '${env} ${command}'"; - in - '' - with subtest("Wait for login"): - # wait_for_x() checks graphical-session.target, which is expected to be - # inactive on Budgie before Budgie manages user session with systemd. - # https://github.com/BuddiesOfBudgie/budgie-desktop/blob/39e9f0895c978f76/src/session/budgie-desktop.in#L16 - # - # Previously this was unconditionally touched by xsessionWrapper but was - # changed in #233981 (we have Budgie:GNOME in XDG_CURRENT_DESKTOP). - # machine.wait_for_x() - machine.wait_until_succeeds('journalctl -t budgie-session-binary --grep "Entering running state"') - machine.wait_for_file("${user.home}/.Xauthority") - machine.succeed("xauth merge ${user.home}/.Xauthority") + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + env = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${toString user.uid}/bus DISPLAY=:0"; + su = command: "su - ${user.name} -c '${env} ${command}'"; + in + '' + with subtest("Wait for login"): + # wait_for_x() checks graphical-session.target, which is expected to be + # inactive on Budgie before Budgie manages user session with systemd. + # https://github.com/BuddiesOfBudgie/budgie-desktop/blob/39e9f0895c978f76/src/session/budgie-desktop.in#L16 + # + # Previously this was unconditionally touched by xsessionWrapper but was + # changed in #233981 (we have Budgie:GNOME in XDG_CURRENT_DESKTOP). + # machine.wait_for_x() + machine.wait_until_succeeds('journalctl -t budgie-session-binary --grep "Entering running state"') + machine.wait_for_file("${user.home}/.Xauthority") + machine.succeed("xauth merge ${user.home}/.Xauthority") - with subtest("Check that logging in has given the user ownership of devices"): - machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") + with subtest("Check that logging in has given the user ownership of devices"): + machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") - with subtest("Check if Budgie session components actually start"): - for i in ["budgie-daemon", "budgie-panel", "budgie-wm", "budgie-desktop-view", "gsd-media-keys"]: - machine.wait_until_succeeds(f"pgrep -f {i}") - # We don't check xwininfo for budgie-wm. - # See https://github.com/NixOS/nixpkgs/pull/216737#discussion_r1155312754 - machine.wait_for_window("budgie-daemon") - machine.wait_for_window("budgie-panel") + with subtest("Check if Budgie session components actually start"): + for i in ["budgie-daemon", "budgie-panel", "budgie-wm", "budgie-desktop-view", "gsd-media-keys"]: + machine.wait_until_succeeds(f"pgrep -f {i}") + # We don't check xwininfo for budgie-wm. + # See https://github.com/NixOS/nixpkgs/pull/216737#discussion_r1155312754 + machine.wait_for_window("budgie-daemon") + machine.wait_for_window("budgie-panel") - with subtest("Check if various environment variables are set"): - cmd = "xargs --null --max-args=1 echo < /proc/$(pgrep -xf /run/current-system/sw/bin/budgie-wm)/environ" - machine.succeed(f"{cmd} | grep 'XDG_CURRENT_DESKTOP' | grep 'Budgie:GNOME'") - machine.succeed(f"{cmd} | grep 'BUDGIE_PLUGIN_DATADIR' | grep '${pkgs.budgie-desktop-with-plugins.pname}'") + with subtest("Check if various environment variables are set"): + cmd = "xargs --null --max-args=1 echo < /proc/$(pgrep -xf /run/current-system/sw/bin/budgie-wm)/environ" + machine.succeed(f"{cmd} | grep 'XDG_CURRENT_DESKTOP' | grep 'Budgie:GNOME'") + machine.succeed(f"{cmd} | grep 'BUDGIE_PLUGIN_DATADIR' | grep '${pkgs.budgie-desktop-with-plugins.pname}'") - with subtest("Open run dialog"): - machine.send_key("alt-f2") - machine.wait_for_window("budgie-run-dialog") - machine.sleep(2) - machine.screenshot("run_dialog") - machine.send_key("esc") + with subtest("Open run dialog"): + machine.send_key("alt-f2") + machine.wait_for_window("budgie-run-dialog") + machine.sleep(2) + machine.screenshot("run_dialog") + machine.send_key("esc") - with subtest("Open Budgie Control Center"): - machine.succeed("${su "budgie-control-center >&2 &"}") - machine.wait_for_window("Budgie Control Center") + with subtest("Open Budgie Control Center"): + machine.succeed("${su "budgie-control-center >&2 &"}") + machine.wait_for_window("Budgie Control Center") - with subtest("Lock the screen"): - machine.succeed("${su "budgie-screensaver-command -l >&2 &"}") - machine.wait_until_succeeds("${su "budgie-screensaver-command -q"} | grep 'The screensaver is active'") - machine.sleep(2) - machine.send_chars("${user.password}", delay=0.5) - machine.screenshot("budgie_screensaver") - machine.send_chars("\n") - machine.wait_until_succeeds("${su "budgie-screensaver-command -q"} | grep 'The screensaver is inactive'") - machine.sleep(2) + with subtest("Lock the screen"): + machine.succeed("${su "budgie-screensaver-command -l >&2 &"}") + machine.wait_until_succeeds("${su "budgie-screensaver-command -q"} | grep 'The screensaver is active'") + machine.sleep(2) + machine.send_chars("${user.password}", delay=0.5) + machine.screenshot("budgie_screensaver") + machine.send_chars("\n") + machine.wait_until_succeeds("${su "budgie-screensaver-command -q"} | grep 'The screensaver is inactive'") + machine.sleep(2) - with subtest("Open GNOME terminal"): - machine.succeed("${su "gnome-terminal"}") - machine.wait_for_window("${user.name}@machine: ~") + with subtest("Open GNOME terminal"): + machine.succeed("${su "gnome-terminal"}") + machine.wait_for_window("${user.name}@machine: ~") - with subtest("Check if Budgie has ever coredumped"): - machine.fail("coredumpctl --json=short | grep budgie") - machine.sleep(10) - machine.screenshot("screen") - ''; -}) + with subtest("Check if Budgie has ever coredumped"): + machine.fail("coredumpctl --json=short | grep budgie") + machine.sleep(10) + machine.screenshot("screen") + ''; + } +) diff --git a/nixos/tests/buildbot.nix b/nixos/tests/buildbot.nix index 0f65ac21c83d6b..0f974594c275c8 100644 --- a/nixos/tests/buildbot.nix +++ b/nixos/tests/buildbot.nix @@ -1,110 +1,141 @@ # Test ensures buildbot master comes up correctly and workers can connect -import ./make-test-python.nix ({ pkgs, ... }: { - name = "buildbot"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "buildbot"; - nodes = { - bbmaster = { pkgs, ... }: { - services.buildbot-master = { - enable = true; + nodes = { + bbmaster = + { pkgs, ... }: + { + services.buildbot-master = { + enable = true; - # NOTE: use fake repo due to no internet in hydra ci - factorySteps = [ - "steps.Git(repourl='git://gitrepo/fakerepo.git', mode='incremental')" - "steps.ShellCommand(command=['bash', 'fakerepo.sh'])" - ]; - changeSource = [ - "changes.GitPoller('git://gitrepo/fakerepo.git', workdir='gitpoller-workdir', branch='master', pollInterval=300)" - ]; - }; - networking.firewall.allowedTCPPorts = [ 8010 8011 9989 ]; - environment.systemPackages = with pkgs; [ git buildbot-full ]; - }; + # NOTE: use fake repo due to no internet in hydra ci + factorySteps = [ + "steps.Git(repourl='git://gitrepo/fakerepo.git', mode='incremental')" + "steps.ShellCommand(command=['bash', 'fakerepo.sh'])" + ]; + changeSource = [ + "changes.GitPoller('git://gitrepo/fakerepo.git', workdir='gitpoller-workdir', branch='master', pollInterval=300)" + ]; + }; + networking.firewall.allowedTCPPorts = [ + 8010 + 8011 + 9989 + ]; + environment.systemPackages = with pkgs; [ + git + buildbot-full + ]; + }; - bbworker = { pkgs, ... }: { - services.buildbot-worker = { - enable = true; - masterUrl = "bbmaster:9989"; - }; - environment.systemPackages = with pkgs; [ git buildbot-worker ]; - }; + bbworker = + { pkgs, ... }: + { + services.buildbot-worker = { + enable = true; + masterUrl = "bbmaster:9989"; + }; + environment.systemPackages = with pkgs; [ + git + buildbot-worker + ]; + }; - gitrepo = { pkgs, ... }: { - services.openssh.enable = true; - networking.firewall.allowedTCPPorts = [ 22 9418 ]; - environment.systemPackages = with pkgs; [ git ]; - systemd.services.git-daemon = { - description = "Git daemon for the test"; - wantedBy = [ "multi-user.target" ]; - after = [ "network.target" "sshd.service" ]; + gitrepo = + { pkgs, ... }: + { + services.openssh.enable = true; + networking.firewall.allowedTCPPorts = [ + 22 + 9418 + ]; + environment.systemPackages = with pkgs; [ git ]; + systemd.services.git-daemon = { + description = "Git daemon for the test"; + wantedBy = [ "multi-user.target" ]; + after = [ + "network.target" + "sshd.service" + ]; - serviceConfig.Restart = "always"; - path = with pkgs; [ coreutils git openssh ]; - environment = { HOME = "/root"; }; - preStart = '' - git config --global user.name 'Nobody Fakeuser' - git config --global user.email 'nobody\@fakerepo.com' - rm -rvf /srv/repos/fakerepo.git /tmp/fakerepo - mkdir -pv /srv/repos/fakerepo ~/.ssh - ssh-keyscan -H gitrepo > ~/.ssh/known_hosts - cat ~/.ssh/known_hosts + serviceConfig.Restart = "always"; + path = with pkgs; [ + coreutils + git + openssh + ]; + environment = { + HOME = "/root"; + }; + preStart = '' + git config --global user.name 'Nobody Fakeuser' + git config --global user.email 'nobody\@fakerepo.com' + rm -rvf /srv/repos/fakerepo.git /tmp/fakerepo + mkdir -pv /srv/repos/fakerepo ~/.ssh + ssh-keyscan -H gitrepo > ~/.ssh/known_hosts + cat ~/.ssh/known_hosts - mkdir -p /src/repos/fakerepo - cd /srv/repos/fakerepo - rm -rf * - git init - echo -e '#!/bin/sh\necho fakerepo' > fakerepo.sh - cat fakerepo.sh - touch .git/git-daemon-export-ok - git add fakerepo.sh .git/git-daemon-export-ok - git commit -m fakerepo - ''; - script = '' - git daemon --verbose --export-all --base-path=/srv/repos --reuseaddr - ''; - }; + mkdir -p /src/repos/fakerepo + cd /srv/repos/fakerepo + rm -rf * + git init + echo -e '#!/bin/sh\necho fakerepo' > fakerepo.sh + cat fakerepo.sh + touch .git/git-daemon-export-ok + git add fakerepo.sh .git/git-daemon-export-ok + git commit -m fakerepo + ''; + script = '' + git daemon --verbose --export-all --base-path=/srv/repos --reuseaddr + ''; + }; + }; }; - }; - testScript = '' - gitrepo.wait_for_unit("git-daemon.service") - gitrepo.wait_for_unit("multi-user.target") + testScript = '' + gitrepo.wait_for_unit("git-daemon.service") + gitrepo.wait_for_unit("multi-user.target") - with subtest("Repo is accessible via git daemon"): - bbmaster.systemctl("start network-online.target") - bbmaster.wait_for_unit("network-online.target") - bbmaster.succeed("rm -rfv /tmp/fakerepo") - bbmaster.succeed("git clone git://gitrepo/fakerepo /tmp/fakerepo") + with subtest("Repo is accessible via git daemon"): + bbmaster.systemctl("start network-online.target") + bbmaster.wait_for_unit("network-online.target") + bbmaster.succeed("rm -rfv /tmp/fakerepo") + bbmaster.succeed("git clone git://gitrepo/fakerepo /tmp/fakerepo") - with subtest("Master service and worker successfully connect"): - bbmaster.wait_for_unit("buildbot-master.service") - bbmaster.wait_until_succeeds("curl --fail -s --head http://bbmaster:8010") - bbworker.systemctl("start network-online.target") - bbworker.wait_for_unit("network-online.target") - bbworker.succeed("nc -z bbmaster 8010") - bbworker.succeed("nc -z bbmaster 9989") - bbworker.wait_for_unit("buildbot-worker.service") + with subtest("Master service and worker successfully connect"): + bbmaster.wait_for_unit("buildbot-master.service") + bbmaster.wait_until_succeeds("curl --fail -s --head http://bbmaster:8010") + bbworker.systemctl("start network-online.target") + bbworker.wait_for_unit("network-online.target") + bbworker.succeed("nc -z bbmaster 8010") + bbworker.succeed("nc -z bbmaster 9989") + bbworker.wait_for_unit("buildbot-worker.service") - with subtest("Stop buildbot worker"): - bbmaster.succeed("systemctl -l --no-pager status buildbot-master") - bbmaster.succeed("systemctl stop buildbot-master") - bbworker.fail("nc -z bbmaster 8010") - bbworker.fail("nc -z bbmaster 9989") - bbworker.succeed("systemctl -l --no-pager status buildbot-worker") - bbworker.succeed("systemctl stop buildbot-worker") + with subtest("Stop buildbot worker"): + bbmaster.succeed("systemctl -l --no-pager status buildbot-master") + bbmaster.succeed("systemctl stop buildbot-master") + bbworker.fail("nc -z bbmaster 8010") + bbworker.fail("nc -z bbmaster 9989") + bbworker.succeed("systemctl -l --no-pager status buildbot-worker") + bbworker.succeed("systemctl stop buildbot-worker") - with subtest("Buildbot daemon mode works"): - bbmaster.succeed( - "buildbot create-master /tmp", - "mv -fv /tmp/master.cfg.sample /tmp/master.cfg", - "sed -i 's/8010/8011/' /tmp/master.cfg", - "buildbot start /tmp", - "nc -z bbmaster 8011", - ) - bbworker.wait_until_succeeds("curl --fail -s --head http://bbmaster:8011") - bbmaster.wait_until_succeeds("buildbot stop /tmp") - bbworker.fail("nc -z bbmaster 8011") - ''; + with subtest("Buildbot daemon mode works"): + bbmaster.succeed( + "buildbot create-master /tmp", + "mv -fv /tmp/master.cfg.sample /tmp/master.cfg", + "sed -i 's/8010/8011/' /tmp/master.cfg", + "buildbot start /tmp", + "nc -z bbmaster 8011", + ) + bbworker.wait_until_succeeds("curl --fail -s --head http://bbmaster:8011") + bbmaster.wait_until_succeeds("buildbot stop /tmp") + bbworker.fail("nc -z bbmaster 8011") + ''; - meta.maintainers = pkgs.lib.teams.buildbot.members; -}) + meta.maintainers = pkgs.lib.teams.buildbot.members; + } +) diff --git a/nixos/tests/buildkite-agents.nix b/nixos/tests/buildkite-agents.nix index a5abfdb5e2e5da..e8934dbaaa5c9d 100644 --- a/nixos/tests/buildkite-agents.nix +++ b/nixos/tests/buildkite-agents.nix @@ -1,29 +1,33 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: +import ./make-test-python.nix ( + { lib, pkgs, ... }: -{ - name = "buildkite-agent"; - meta.maintainers = with lib.maintainers; [ flokli ]; + { + name = "buildkite-agent"; + meta.maintainers = with lib.maintainers; [ flokli ]; - nodes.machine = { pkgs, ... }: { - services.buildkite-agents = { - one = { - privateSshKeyPath = (import ./ssh-keys.nix pkgs).snakeOilPrivateKey; - tokenPath = (pkgs.writeText "my-token" "5678"); + nodes.machine = + { pkgs, ... }: + { + services.buildkite-agents = { + one = { + privateSshKeyPath = (import ./ssh-keys.nix pkgs).snakeOilPrivateKey; + tokenPath = (pkgs.writeText "my-token" "5678"); + }; + two = { + tokenPath = (pkgs.writeText "my-token" "1234"); + }; + }; }; - two = { - tokenPath = (pkgs.writeText "my-token" "1234"); - }; - }; - }; - testScript = '' - start_all() - # we can't wait on the unit to start up, as we obviously can't connect to buildkite, - # but we can look whether files are set up correctly + testScript = '' + start_all() + # we can't wait on the unit to start up, as we obviously can't connect to buildkite, + # but we can look whether files are set up correctly - machine.wait_for_file("/var/lib/buildkite-agent-one/buildkite-agent.cfg") - machine.wait_for_file("/var/lib/buildkite-agent-one/.ssh/id_rsa") + machine.wait_for_file("/var/lib/buildkite-agent-one/buildkite-agent.cfg") + machine.wait_for_file("/var/lib/buildkite-agent-one/.ssh/id_rsa") - machine.wait_for_file("/var/lib/buildkite-agent-two/buildkite-agent.cfg") - ''; -}) + machine.wait_for_file("/var/lib/buildkite-agent-two/buildkite-agent.cfg") + ''; + } +) diff --git a/nixos/tests/c2fmzq.nix b/nixos/tests/c2fmzq.nix index 0dd89f6881dd97..90d816785e1ea2 100644 --- a/nixos/tests/c2fmzq.nix +++ b/nixos/tests/c2fmzq.nix @@ -1,82 +1,87 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "c2FmZQ"; - meta.maintainers = with lib.maintainers; [ hmenke ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "c2FmZQ"; + meta.maintainers = with lib.maintainers; [ hmenke ]; - nodes.machine = { - services.c2fmzq-server = { - enable = true; - port = 8080; - passphraseFile = builtins.toFile "pwfile" "hunter2"; # don't do this on real deployments - settings = { - verbose = 3; # debug - # make sure multiple freeform options evaluate - allow-new-accounts = true; - auto-approve-new-accounts = true; - licenses = false; + nodes.machine = { + services.c2fmzq-server = { + enable = true; + port = 8080; + passphraseFile = builtins.toFile "pwfile" "hunter2"; # don't do this on real deployments + settings = { + verbose = 3; # debug + # make sure multiple freeform options evaluate + allow-new-accounts = true; + auto-approve-new-accounts = true; + licenses = false; + }; }; - }; - environment = { - sessionVariables = { - C2FMZQ_PASSPHRASE = "lol"; - C2FMZQ_API_SERVER = "http://localhost:8080"; + environment = { + sessionVariables = { + C2FMZQ_PASSPHRASE = "lol"; + C2FMZQ_API_SERVER = "http://localhost:8080"; + }; + systemPackages = [ + pkgs.c2fmzq + (pkgs.writeScriptBin "c2FmZQ-client-wrapper" '' + #!${pkgs.expect}/bin/expect -f + spawn c2FmZQ-client {*}$argv + expect { + "Enter password:" { send "$env(PASSWORD)\r" } + "Type YES to confirm:" { send "YES\r" } + timeout { exit 1 } + eof { exit 0 } + } + interact + '') + ]; }; - systemPackages = [ - pkgs.c2fmzq - (pkgs.writeScriptBin "c2FmZQ-client-wrapper" '' - #!${pkgs.expect}/bin/expect -f - spawn c2FmZQ-client {*}$argv - expect { - "Enter password:" { send "$env(PASSWORD)\r" } - "Type YES to confirm:" { send "YES\r" } - timeout { exit 1 } - eof { exit 0 } - } - interact - '') - ]; }; - }; - testScript = { nodes, ... }: '' - machine.start() - machine.wait_for_unit("c2fmzq-server.service") - machine.wait_for_open_port(8080) + testScript = + { nodes, ... }: + '' + machine.start() + machine.wait_for_unit("c2fmzq-server.service") + machine.wait_for_open_port(8080) - with subtest("Create accounts for alice and bob"): - machine.succeed("PASSWORD=foobar c2FmZQ-client-wrapper -- -v 3 create-account alice@example.com") - machine.succeed("PASSWORD=fizzbuzz c2FmZQ-client-wrapper -- -v 3 create-account bob@example.com") + with subtest("Create accounts for alice and bob"): + machine.succeed("PASSWORD=foobar c2FmZQ-client-wrapper -- -v 3 create-account alice@example.com") + machine.succeed("PASSWORD=fizzbuzz c2FmZQ-client-wrapper -- -v 3 create-account bob@example.com") - with subtest("Log in as alice"): - machine.succeed("PASSWORD=foobar c2FmZQ-client-wrapper -- -v 3 login alice@example.com") - msg = machine.succeed("c2FmZQ-client -v 3 status") - assert "Logged in as alice@example.com" in msg, f"ERROR: Not logged in as alice:\n{msg}" + with subtest("Log in as alice"): + machine.succeed("PASSWORD=foobar c2FmZQ-client-wrapper -- -v 3 login alice@example.com") + msg = machine.succeed("c2FmZQ-client -v 3 status") + assert "Logged in as alice@example.com" in msg, f"ERROR: Not logged in as alice:\n{msg}" - with subtest("Create a new album, upload a file, and delete the uploaded file"): - machine.succeed("c2FmZQ-client -v 3 create-album 'Rarest Memes'") - machine.succeed("echo 'pls do not steal' > meme.txt") - machine.succeed("c2FmZQ-client -v 3 import meme.txt 'Rarest Memes'") - machine.succeed("c2FmZQ-client -v 3 sync") - machine.succeed("rm meme.txt") + with subtest("Create a new album, upload a file, and delete the uploaded file"): + machine.succeed("c2FmZQ-client -v 3 create-album 'Rarest Memes'") + machine.succeed("echo 'pls do not steal' > meme.txt") + machine.succeed("c2FmZQ-client -v 3 import meme.txt 'Rarest Memes'") + machine.succeed("c2FmZQ-client -v 3 sync") + machine.succeed("rm meme.txt") - with subtest("Share the album with bob"): - machine.succeed("c2FmZQ-client-wrapper -- -v 3 share 'Rarest Memes' bob@example.com") + with subtest("Share the album with bob"): + machine.succeed("c2FmZQ-client-wrapper -- -v 3 share 'Rarest Memes' bob@example.com") - with subtest("Log in as bob"): - machine.succeed("PASSWORD=fizzbuzz c2FmZQ-client-wrapper -- -v 3 login bob@example.com") - msg = machine.succeed("c2FmZQ-client -v 3 status") - assert "Logged in as bob@example.com" in msg, f"ERROR: Not logged in as bob:\n{msg}" + with subtest("Log in as bob"): + machine.succeed("PASSWORD=fizzbuzz c2FmZQ-client-wrapper -- -v 3 login bob@example.com") + msg = machine.succeed("c2FmZQ-client -v 3 status") + assert "Logged in as bob@example.com" in msg, f"ERROR: Not logged in as bob:\n{msg}" - with subtest("Download the shared file"): - machine.succeed("c2FmZQ-client -v 3 download 'shared/Rarest Memes/meme.txt'") - machine.succeed("c2FmZQ-client -v 3 export 'shared/Rarest Memes/meme.txt' .") - msg = machine.succeed("cat meme.txt") - assert "pls do not steal\n" == msg, f"File content is not the same:\n{msg}" + with subtest("Download the shared file"): + machine.succeed("c2FmZQ-client -v 3 download 'shared/Rarest Memes/meme.txt'") + machine.succeed("c2FmZQ-client -v 3 export 'shared/Rarest Memes/meme.txt' .") + msg = machine.succeed("cat meme.txt") + assert "pls do not steal\n" == msg, f"File content is not the same:\n{msg}" - with subtest("Test that PWA is served"): - msg = machine.succeed("curl -sSfL http://localhost:8080") - assert "c2FmZQ" in msg, f"Could not find 'c2FmZQ' in the output:\n{msg}" + with subtest("Test that PWA is served"): + msg = machine.succeed("curl -sSfL http://localhost:8080") + assert "c2FmZQ" in msg, f"Could not find 'c2FmZQ' in the output:\n{msg}" - with subtest("A setting with false value is properly passed"): - machine.succeed("systemctl show -p ExecStart --value c2fmzq-server.service | grep -F -- '--licenses=false'"); - ''; -}) + with subtest("A setting with false value is properly passed"): + machine.succeed("systemctl show -p ExecStart --value c2fmzq-server.service | grep -F -- '--licenses=false'"); + ''; + } +) diff --git a/nixos/tests/caddy.nix b/nixos/tests/caddy.nix index 0efe8f94e39dd7..57fe16f92d377f 100644 --- a/nixos/tests/caddy.nix +++ b/nixos/tests/caddy.nix @@ -1,103 +1,113 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "caddy"; - meta = with pkgs.lib.maintainers; { - maintainers = [ Br1ght0ne ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "caddy"; + meta = with pkgs.lib.maintainers; { + maintainers = [ Br1ght0ne ]; + }; - nodes = { - webserver = { pkgs, lib, ... }: { - services.caddy.enable = true; - services.caddy.extraConfig = '' - http://localhost { - encode gzip + nodes = { + webserver = + { pkgs, lib, ... }: + { + services.caddy.enable = true; + services.caddy.extraConfig = '' + http://localhost { + encode gzip - file_server - root * ${ - pkgs.runCommand "testdir" {} '' - mkdir "$out" - echo hello world > "$out/example.html" - '' - } - } - ''; - services.caddy.enableReload = true; + file_server + root * ${ + pkgs.runCommand "testdir" { } '' + mkdir "$out" + echo hello world > "$out/example.html" + '' + } + } + ''; + services.caddy.enableReload = true; - specialisation.config-reload.configuration = { - services.caddy.extraConfig = '' - http://localhost:8080 { - } - ''; - }; - specialisation.multiple-configs.configuration = { - services.caddy.virtualHosts = { - "http://localhost:8080" = { }; - "http://localhost:8081" = { }; - }; - }; - specialisation.rfc42.configuration = { - services.caddy.settings = { - apps.http.servers.default = { - listen = [ ":80" ]; - routes = [{ - handle = [{ - body = "hello world"; - handler = "static_response"; - status_code = 200; - }]; - }]; + specialisation.config-reload.configuration = { + services.caddy.extraConfig = '' + http://localhost:8080 { + } + ''; }; - }; - }; - specialisation.explicit-config-file.configuration = { - services.caddy.configFile = pkgs.writeText "Caddyfile" '' - localhost:80 + specialisation.multiple-configs.configuration = { + services.caddy.virtualHosts = { + "http://localhost:8080" = { }; + "http://localhost:8081" = { }; + }; + }; + specialisation.rfc42.configuration = { + services.caddy.settings = { + apps.http.servers.default = { + listen = [ ":80" ]; + routes = [ + { + handle = [ + { + body = "hello world"; + handler = "static_response"; + status_code = 200; + } + ]; + } + ]; + }; + }; + }; + specialisation.explicit-config-file.configuration = { + services.caddy.configFile = pkgs.writeText "Caddyfile" '' + localhost:80 - respond "hello world" - ''; - }; + respond "hello world" + ''; + }; + }; }; - }; - testScript = { nodes, ... }: - let - explicitConfigFile = "${nodes.webserver.system.build.toplevel}/specialisation/explicit-config-file"; - justReloadSystem = "${nodes.webserver.system.build.toplevel}/specialisation/config-reload"; - multipleConfigs = "${nodes.webserver.system.build.toplevel}/specialisation/multiple-configs"; - rfc42Config = "${nodes.webserver.system.build.toplevel}/specialisation/rfc42"; - in - '' - url = "http://localhost/example.html" - webserver.wait_for_unit("caddy") - webserver.wait_for_open_port(80) + testScript = + { nodes, ... }: + let + explicitConfigFile = "${nodes.webserver.system.build.toplevel}/specialisation/explicit-config-file"; + justReloadSystem = "${nodes.webserver.system.build.toplevel}/specialisation/config-reload"; + multipleConfigs = "${nodes.webserver.system.build.toplevel}/specialisation/multiple-configs"; + rfc42Config = "${nodes.webserver.system.build.toplevel}/specialisation/rfc42"; + in + '' + url = "http://localhost/example.html" + webserver.wait_for_unit("caddy") + webserver.wait_for_open_port(80) - with subtest("config is reloaded on nixos-rebuild switch"): - webserver.succeed( - "${justReloadSystem}/bin/switch-to-configuration test >&2" - ) - webserver.wait_for_open_port(8080) - webserver.fail("journalctl -u caddy | grep -q -i stopped") - webserver.succeed("journalctl -u caddy | grep -q -i reloaded") + with subtest("config is reloaded on nixos-rebuild switch"): + webserver.succeed( + "${justReloadSystem}/bin/switch-to-configuration test >&2" + ) + webserver.wait_for_open_port(8080) + webserver.fail("journalctl -u caddy | grep -q -i stopped") + webserver.succeed("journalctl -u caddy | grep -q -i reloaded") - with subtest("multiple configs are correctly merged"): - webserver.succeed( - "${multipleConfigs}/bin/switch-to-configuration test >&2" - ) - webserver.wait_for_open_port(8080) - webserver.wait_for_open_port(8081) + with subtest("multiple configs are correctly merged"): + webserver.succeed( + "${multipleConfigs}/bin/switch-to-configuration test >&2" + ) + webserver.wait_for_open_port(8080) + webserver.wait_for_open_port(8081) - with subtest("rfc42 settings config"): - webserver.succeed( - "${rfc42Config}/bin/switch-to-configuration test >&2" - ) - webserver.wait_for_open_port(80) - webserver.succeed("curl http://localhost | grep hello") + with subtest("rfc42 settings config"): + webserver.succeed( + "${rfc42Config}/bin/switch-to-configuration test >&2" + ) + webserver.wait_for_open_port(80) + webserver.succeed("curl http://localhost | grep hello") - with subtest("explicit configFile"): - webserver.succeed( - "${explicitConfigFile}/bin/switch-to-configuration test >&2" - ) - webserver.wait_for_open_port(80) - webserver.succeed("curl http://localhost | grep hello") - ''; -}) + with subtest("explicit configFile"): + webserver.succeed( + "${explicitConfigFile}/bin/switch-to-configuration test >&2" + ) + webserver.wait_for_open_port(80) + webserver.succeed("curl http://localhost | grep hello") + ''; + } +) diff --git a/nixos/tests/cadvisor.nix b/nixos/tests/cadvisor.nix index 70e068fcf21c4a..d558bc3007ec36 100644 --- a/nixos/tests/cadvisor.nix +++ b/nixos/tests/cadvisor.nix @@ -1,20 +1,26 @@ -import ./make-test-python.nix ({ lib, pkgs, ... } : { - name = "cadvisor"; - meta.maintainers = with lib.maintainers; [ offline ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "cadvisor"; + meta.maintainers = with lib.maintainers; [ offline ]; - nodes = { - machine = { ... }: { - services.cadvisor.enable = true; - }; + nodes = { + machine = + { ... }: + { + services.cadvisor.enable = true; + }; - influxdb = { lib, ... }: { - services.cadvisor.enable = true; - services.cadvisor.storageDriver = "influxdb"; - services.influxdb.enable = true; + influxdb = + { lib, ... }: + { + services.cadvisor.enable = true; + services.cadvisor.storageDriver = "influxdb"; + services.influxdb.enable = true; + }; }; - }; - testScript = '' + testScript = '' start_all() machine.wait_for_unit("cadvisor.service") machine.succeed("curl -f http://localhost:8080/containers/") @@ -29,4 +35,5 @@ import ./make-test-python.nix ({ lib, pkgs, ... } : { influxdb.wait_for_unit("cadvisor.service") influxdb.succeed("curl -f http://localhost:8080/containers/") ''; -}) + } +) diff --git a/nixos/tests/cage.nix b/nixos/tests/cage.nix index 3b49185124f3e9..e9c025e5102189 100644 --- a/nixos/tests/cage.nix +++ b/nixos/tests/cage.nix @@ -1,38 +1,44 @@ -import ./make-test-python.nix ({ pkgs, ...} : - -{ - name = "cage"; - meta = with pkgs.lib.maintainers; { - maintainers = [ matthewbauer ]; - }; - - nodes.machine = { ... }: +import ./make-test-python.nix ( + { pkgs, ... }: { - imports = [ ./common/user-account.nix ]; - - fonts.packages = with pkgs; [ dejavu_fonts ]; - - services.cage = { - enable = true; - user = "alice"; - program = "${pkgs.xterm}/bin/xterm"; + name = "cage"; + meta = with pkgs.lib.maintainers; { + maintainers = [ matthewbauer ]; }; - # Need to switch to a different GPU driver than the default one (-vga std) so that Cage can launch: - virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ]; - }; - - enableOCR = true; - - testScript = { nodes, ... }: let - user = nodes.machine.config.users.users.alice; - in '' - with subtest("Wait for cage to boot up"): - start_all() - machine.wait_for_file("/run/user/${toString user.uid}/wayland-0.lock") - machine.wait_until_succeeds("pgrep xterm") - machine.wait_for_text("alice@machine") - machine.screenshot("screen") - ''; -}) + nodes.machine = + { ... }: + + { + imports = [ ./common/user-account.nix ]; + + fonts.packages = with pkgs; [ dejavu_fonts ]; + + services.cage = { + enable = true; + user = "alice"; + program = "${pkgs.xterm}/bin/xterm"; + }; + + # Need to switch to a different GPU driver than the default one (-vga std) so that Cage can launch: + virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ]; + }; + + enableOCR = true; + + testScript = + { nodes, ... }: + let + user = nodes.machine.config.users.users.alice; + in + '' + with subtest("Wait for cage to boot up"): + start_all() + machine.wait_for_file("/run/user/${toString user.uid}/wayland-0.lock") + machine.wait_until_succeeds("pgrep xterm") + machine.wait_for_text("alice@machine") + machine.screenshot("screen") + ''; + } +) diff --git a/nixos/tests/cagebreak.nix b/nixos/tests/cagebreak.nix index 4d7664c1505f38..2c07833b142f57 100644 --- a/nixos/tests/cagebreak.nix +++ b/nixos/tests/cagebreak.nix @@ -1,63 +1,72 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : - -let - cagebreakConfigfile = pkgs.writeText "config" '' - workspaces 1 - escape C-t - bind t exec env DISPLAY=:0 ${pkgs.xterm}/bin/xterm -cm -pc - ''; -in -{ - name = "cagebreak"; - meta = with pkgs.lib.maintainers; { - maintainers = [ berbiche ]; - }; - - nodes.machine = { config, ... }: - { - # Automatically login on tty1 as a normal user: - imports = [ ./common/user-account.nix ]; - services.getty.autologinUser = "alice"; - programs.bash.loginShellInit = '' - if [ "$(tty)" = "/dev/tty1" ]; then - set -e - - mkdir -p ~/.config/cagebreak - cp -f ${cagebreakConfigfile} ~/.config/cagebreak/config - - cagebreak - fi +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + let + cagebreakConfigfile = pkgs.writeText "config" '' + workspaces 1 + escape C-t + bind t exec env DISPLAY=:0 ${pkgs.xterm}/bin/xterm -cm -pc ''; + in + { + name = "cagebreak"; + meta = with pkgs.lib.maintainers; { + maintainers = [ berbiche ]; + }; + + nodes.machine = + { config, ... }: + { + # Automatically login on tty1 as a normal user: + imports = [ ./common/user-account.nix ]; + services.getty.autologinUser = "alice"; + programs.bash.loginShellInit = '' + if [ "$(tty)" = "/dev/tty1" ]; then + set -e + + mkdir -p ~/.config/cagebreak + cp -f ${cagebreakConfigfile} ~/.config/cagebreak/config + + cagebreak + fi + ''; + + hardware.graphics.enable = true; + programs.xwayland.enable = true; + security.polkit.enable = true; + environment.systemPackages = [ + pkgs.cagebreak + pkgs.wayland-utils + ]; + + # Need to switch to a different GPU driver than the default one (-vga std) so that Cagebreak can launch: + virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ]; + }; + + enableOCR = true; + + testScript = + { nodes, ... }: + let + user = nodes.machine.config.users.users.alice; + XDG_RUNTIME_DIR = "/run/user/${toString user.uid}"; + in + '' + start_all() + machine.wait_for_unit("multi-user.target") + machine.wait_for_file("${XDG_RUNTIME_DIR}/wayland-0") + + with subtest("ensure wayland works with wayinfo from wallutils"): + print(machine.succeed("env XDG_RUNTIME_DIR=${XDG_RUNTIME_DIR} wayland-info")) - hardware.graphics.enable = true; - programs.xwayland.enable = true; - security.polkit.enable = true; - environment.systemPackages = [ pkgs.cagebreak pkgs.wayland-utils ]; - - # Need to switch to a different GPU driver than the default one (-vga std) so that Cagebreak can launch: - virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ]; - }; - - enableOCR = true; - - testScript = { nodes, ... }: let - user = nodes.machine.config.users.users.alice; - XDG_RUNTIME_DIR = "/run/user/${toString user.uid}"; - in '' - start_all() - machine.wait_for_unit("multi-user.target") - machine.wait_for_file("${XDG_RUNTIME_DIR}/wayland-0") - - with subtest("ensure wayland works with wayinfo from wallutils"): - print(machine.succeed("env XDG_RUNTIME_DIR=${XDG_RUNTIME_DIR} wayland-info")) - - # TODO: Fix the XWayland test (log the cagebreak output to debug): - # with subtest("ensure xwayland works with xterm"): - # machine.send_key("ctrl-t") - # machine.send_key("t") - # machine.wait_until_succeeds("pgrep xterm") - # machine.wait_for_text("${user.name}@machine") - # machine.screenshot("screen") - # machine.send_key("ctrl-d") - ''; -}) + # TODO: Fix the XWayland test (log the cagebreak output to debug): + # with subtest("ensure xwayland works with xterm"): + # machine.send_key("ctrl-t") + # machine.send_key("t") + # machine.wait_until_succeeds("pgrep xterm") + # machine.wait_for_text("${user.name}@machine") + # machine.screenshot("screen") + # machine.send_key("ctrl-d") + ''; + } +) diff --git a/nixos/tests/calibre-server.nix b/nixos/tests/calibre-server.nix index 4b1753aaa7049f..2a04dd8cfba45b 100644 --- a/nixos/tests/calibre-server.nix +++ b/nixos/tests/calibre-server.nix @@ -1,16 +1,23 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: let inherit (import ../lib/testing-python.nix { inherit system pkgs; }) makeTest; - inherit (pkgs.lib) concatStringsSep maintainers mapAttrs mkMerge - removeSuffix splitString; + inherit (pkgs.lib) + concatStringsSep + maintainers + mapAttrs + mkMerge + removeSuffix + splitString + ; tests = { default = { - calibreConfig = {}; + calibreConfig = { }; calibreScript = '' wait_for_unit("calibre-server.service") ''; @@ -26,7 +33,10 @@ let }; multipleLibraries = { calibreConfig = { - libraries = [ "/var/lib/calibre-data" "/var/lib/calibre-server" ]; + libraries = [ + "/var/lib/calibre-data" + "/var/lib/calibre-server" + ]; }; calibreScript = '' succeed("ls -la /var/lib/calibre-data") @@ -62,14 +72,15 @@ let }; }; in -mapAttrs - (test: testConfig: (makeTest ( +mapAttrs ( + test: testConfig: + (makeTest ( let nodeName = testConfig.nodeName or test; calibreConfig = { enable = true; libraries = [ "/var/lib/calibre-server" ]; - } // testConfig.calibreConfig or {}; + } // testConfig.calibreConfig or { }; librariesInitScript = path: '' ${nodeName}.execute("touch /tmp/test.epub") ${nodeName}.execute("zip -r /tmp/test.zip /tmp/test.epub") @@ -80,19 +91,26 @@ mapAttrs { name = "calibre-server-${test}"; - nodes.${nodeName} = mkMerge [{ - environment.systemPackages = [ pkgs.zip ]; - services.calibre-server = calibreConfig; - } testConfig.calibreProvider or { }]; + nodes.${nodeName} = mkMerge [ + { + environment.systemPackages = [ pkgs.zip ]; + services.calibre-server = calibreConfig; + } + testConfig.calibreProvider or { } + ]; testScript = '' ${nodeName}.start() ${concatStringsSep "\n" (map librariesInitScript calibreConfig.libraries)} - ${concatStringsSep "\n" (map (line: - if (builtins.substring 0 1 line == " " || builtins.substring 0 1 line == ")") - then line - else "${nodeName}.${line}" - ) (splitString "\n" (removeSuffix "\n" testConfig.calibreScript)))} + ${concatStringsSep "\n" ( + map ( + line: + if (builtins.substring 0 1 line == " " || builtins.substring 0 1 line == ")") then + line + else + "${nodeName}.${line}" + ) (splitString "\n" (removeSuffix "\n" testConfig.calibreScript)) + )} ${nodeName}.shutdown() ''; @@ -100,5 +118,5 @@ mapAttrs maintainers = [ gaelreyrol ]; }; } - ))) - tests + )) +) tests diff --git a/nixos/tests/calibre-web.nix b/nixos/tests/calibre-web.nix index aea9bca3ebe904..d14f1b54080961 100644 --- a/nixos/tests/calibre-web.nix +++ b/nixos/tests/calibre-web.nix @@ -1,42 +1,44 @@ import ./make-test-python.nix ( { pkgs, lib, ... }: - let - port = 3142; - defaultPort = 8083; - in - { - name = "calibre-web"; - meta.maintainers = with lib.maintainers; [ pborzenkov ]; + let + port = 3142; + defaultPort = 8083; + in + { + name = "calibre-web"; + meta.maintainers = with lib.maintainers; [ pborzenkov ]; - nodes = { - customized = { pkgs, ... }: { - services.calibre-web = { - enable = true; - listen.port = port; - options = { - calibreLibrary = "/tmp/books"; - reverseProxyAuth = { - enable = true; - header = "X-User"; - }; + nodes = { + customized = + { pkgs, ... }: + { + services.calibre-web = { + enable = true; + listen.port = port; + options = { + calibreLibrary = "/tmp/books"; + reverseProxyAuth = { + enable = true; + header = "X-User"; }; }; - environment.systemPackages = [ pkgs.calibre ]; }; + environment.systemPackages = [ pkgs.calibre ]; }; - testScript = '' - start_all() + }; + testScript = '' + start_all() - customized.succeed( - "mkdir /tmp/books && calibredb --library-path /tmp/books add -e --title test-book" - ) - customized.succeed("systemctl restart calibre-web") - customized.wait_for_unit("calibre-web.service") - customized.wait_for_open_port(${toString port}) - customized.succeed( - "curl --fail -H X-User:admin 'http://localhost:${toString port}' | grep test-book" - ) - ''; - } + customized.succeed( + "mkdir /tmp/books && calibredb --library-path /tmp/books add -e --title test-book" + ) + customized.succeed("systemctl restart calibre-web") + customized.wait_for_unit("calibre-web.service") + customized.wait_for_open_port(${toString port}) + customized.succeed( + "curl --fail -H X-User:admin 'http://localhost:${toString port}' | grep test-book" + ) + ''; + } ) diff --git a/nixos/tests/cassandra.nix b/nixos/tests/cassandra.nix index a19d525c3431ee..326fd8852455aa 100644 --- a/nixos/tests/cassandra.nix +++ b/nixos/tests/cassandra.nix @@ -1,27 +1,38 @@ -import ./make-test-python.nix ({ pkgs, lib, testPackage ? pkgs.cassandra, ... }: -let - clusterName = "NixOS Automated-Test Cluster"; +import ./make-test-python.nix ( + { + pkgs, + lib, + testPackage ? pkgs.cassandra, + ... + }: + let + clusterName = "NixOS Automated-Test Cluster"; - testRemoteAuth = lib.versionAtLeast testPackage.version "3.11"; - jmxRoles = [{ username = "me"; password = "password"; }]; - jmxRolesFile = ./cassandra-jmx-roles; - jmxAuthArgs = "-u ${(builtins.elemAt jmxRoles 0).username} -pw ${(builtins.elemAt jmxRoles 0).password}"; - jmxPort = 7200; # Non-standard port so it doesn't accidentally work - jmxPortStr = toString jmxPort; + testRemoteAuth = lib.versionAtLeast testPackage.version "3.11"; + jmxRoles = [ + { + username = "me"; + password = "password"; + } + ]; + jmxRolesFile = ./cassandra-jmx-roles; + jmxAuthArgs = "-u ${(builtins.elemAt jmxRoles 0).username} -pw ${(builtins.elemAt jmxRoles 0).password}"; + jmxPort = 7200; # Non-standard port so it doesn't accidentally work + jmxPortStr = toString jmxPort; - # Would usually be assigned to 512M. - # Set it to a different value, so that we can check whether our config - # actually changes it. - numMaxHeapSize = "400"; - getHeapLimitCommand = '' - nodetool info -p ${jmxPortStr} | grep "^Heap Memory" | awk '{print $NF}' - ''; - checkHeapLimitCommand = pkgs.writeShellScript "check-heap-limit.sh" '' - [ 1 -eq "$(echo "$(${getHeapLimitCommand}) < ${numMaxHeapSize}" | ${pkgs.bc}/bin/bc)" ] - ''; + # Would usually be assigned to 512M. + # Set it to a different value, so that we can check whether our config + # actually changes it. + numMaxHeapSize = "400"; + getHeapLimitCommand = '' + nodetool info -p ${jmxPortStr} | grep "^Heap Memory" | awk '{print $NF}' + ''; + checkHeapLimitCommand = pkgs.writeShellScript "check-heap-limit.sh" '' + [ 1 -eq "$(echo "$(${getHeapLimitCommand}) < ${numMaxHeapSize}" | ${pkgs.bc}/bin/bc)" ] + ''; - cassandraCfg = ipAddress: - { enable = true; + cassandraCfg = ipAddress: { + enable = true; inherit clusterName; listenAddress = ipAddress; rpcAddress = ipAddress; @@ -31,102 +42,121 @@ let heapNewSize = "100M"; inherit jmxPort; }; - nodeCfg = ipAddress: extra: {pkgs, config, ...}: rec { - environment.systemPackages = [ testPackage ]; - networking = { - firewall.allowedTCPPorts = [ 7000 9042 services.cassandra.jmxPort ]; - useDHCP = false; - interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = ipAddress; prefixLength = 24; } - ]; + nodeCfg = + ipAddress: extra: + { pkgs, config, ... }: + rec { + environment.systemPackages = [ testPackage ]; + networking = { + firewall.allowedTCPPorts = [ + 7000 + 9042 + services.cassandra.jmxPort + ]; + useDHCP = false; + interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = ipAddress; + prefixLength = 24; + } + ]; + }; + services.cassandra = cassandraCfg ipAddress // extra; + }; + in + { + name = "cassandra-${testPackage.version}"; + meta = { + maintainers = with lib.maintainers; [ johnazoidberg ]; }; - services.cassandra = cassandraCfg ipAddress // extra; - }; -in -{ - name = "cassandra-${testPackage.version}"; - meta = { - maintainers = with lib.maintainers; [ johnazoidberg ]; - }; - nodes = { - cass0 = nodeCfg "192.168.1.1" {}; - cass1 = nodeCfg "192.168.1.2" (lib.optionalAttrs testRemoteAuth { inherit jmxRoles; remoteJmx = true; }); - cass2 = nodeCfg "192.168.1.3" { jvmOpts = [ "-Dcassandra.replace_address=cass1" ]; }; - }; + nodes = { + cass0 = nodeCfg "192.168.1.1" { }; + cass1 = nodeCfg "192.168.1.2" ( + lib.optionalAttrs testRemoteAuth { + inherit jmxRoles; + remoteJmx = true; + } + ); + cass2 = nodeCfg "192.168.1.3" { jvmOpts = [ "-Dcassandra.replace_address=cass1" ]; }; + }; - testScript = '' - # Check configuration - with subtest("Timers exist"): - cass0.succeed("systemctl list-timers | grep cassandra-full-repair.timer") - cass0.succeed("systemctl list-timers | grep cassandra-incremental-repair.timer") + testScript = + '' + # Check configuration + with subtest("Timers exist"): + cass0.succeed("systemctl list-timers | grep cassandra-full-repair.timer") + cass0.succeed("systemctl list-timers | grep cassandra-incremental-repair.timer") - with subtest("Can connect via cqlsh"): - cass0.wait_for_unit("cassandra.service") - cass0.wait_until_succeeds("nc -z cass0 9042") - cass0.succeed("echo 'show version;' | cqlsh cass0") + with subtest("Can connect via cqlsh"): + cass0.wait_for_unit("cassandra.service") + cass0.wait_until_succeeds("nc -z cass0 9042") + cass0.succeed("echo 'show version;' | cqlsh cass0") - with subtest("Nodetool is operational"): - cass0.wait_for_unit("cassandra.service") - cass0.wait_until_succeeds("nc -z localhost ${jmxPortStr}") - cass0.succeed("nodetool status -p ${jmxPortStr} --resolve-ip | egrep '^UN[[:space:]]+cass0'") + with subtest("Nodetool is operational"): + cass0.wait_for_unit("cassandra.service") + cass0.wait_until_succeeds("nc -z localhost ${jmxPortStr}") + cass0.succeed("nodetool status -p ${jmxPortStr} --resolve-ip | egrep '^UN[[:space:]]+cass0'") - with subtest("Cluster name was set"): - cass0.wait_for_unit("cassandra.service") - cass0.wait_until_succeeds("nc -z localhost ${jmxPortStr}") - cass0.wait_until_succeeds( - "nodetool describecluster -p ${jmxPortStr} | grep 'Name: ${clusterName}'" - ) + with subtest("Cluster name was set"): + cass0.wait_for_unit("cassandra.service") + cass0.wait_until_succeeds("nc -z localhost ${jmxPortStr}") + cass0.wait_until_succeeds( + "nodetool describecluster -p ${jmxPortStr} | grep 'Name: ${clusterName}'" + ) - with subtest("Heap limit set correctly"): - # Nodetool takes a while until it can display info - cass0.wait_until_succeeds("nodetool info -p ${jmxPortStr}") - cass0.succeed("${checkHeapLimitCommand}") + with subtest("Heap limit set correctly"): + # Nodetool takes a while until it can display info + cass0.wait_until_succeeds("nodetool info -p ${jmxPortStr}") + cass0.succeed("${checkHeapLimitCommand}") - # Check cluster interaction - with subtest("Bring up cluster"): - cass1.wait_for_unit("cassandra.service") - cass1.wait_until_succeeds( - "nodetool -p ${jmxPortStr} ${jmxAuthArgs} status | egrep -c '^UN' | grep 2" - ) - cass0.succeed("nodetool status -p ${jmxPortStr} --resolve-ip | egrep '^UN[[:space:]]+cass1'") - '' + lib.optionalString testRemoteAuth '' - with subtest("Remote authenticated jmx"): - # Doesn't work if not enabled - cass0.wait_until_succeeds("nc -z localhost ${jmxPortStr}") - cass1.fail("nc -z 192.168.1.1 ${jmxPortStr}") - cass1.fail("nodetool -p ${jmxPortStr} -h 192.168.1.1 status") + # Check cluster interaction + with subtest("Bring up cluster"): + cass1.wait_for_unit("cassandra.service") + cass1.wait_until_succeeds( + "nodetool -p ${jmxPortStr} ${jmxAuthArgs} status | egrep -c '^UN' | grep 2" + ) + cass0.succeed("nodetool status -p ${jmxPortStr} --resolve-ip | egrep '^UN[[:space:]]+cass1'") + '' + + lib.optionalString testRemoteAuth '' + with subtest("Remote authenticated jmx"): + # Doesn't work if not enabled + cass0.wait_until_succeeds("nc -z localhost ${jmxPortStr}") + cass1.fail("nc -z 192.168.1.1 ${jmxPortStr}") + cass1.fail("nodetool -p ${jmxPortStr} -h 192.168.1.1 status") - # Works if enabled - cass1.wait_until_succeeds("nc -z localhost ${jmxPortStr}") - cass0.succeed("nodetool -p ${jmxPortStr} -h 192.168.1.2 ${jmxAuthArgs} status") - '' + '' - with subtest("Break and fix node"): - cass1.block() - cass0.wait_until_succeeds( - "nodetool status -p ${jmxPortStr} --resolve-ip | egrep -c '^DN[[:space:]]+cass1'" - ) - cass0.succeed("nodetool status -p ${jmxPortStr} | egrep -c '^UN' | grep 1") - cass1.unblock() - cass1.wait_until_succeeds( - "nodetool -p ${jmxPortStr} ${jmxAuthArgs} status | egrep -c '^UN' | grep 2" - ) - cass0.succeed("nodetool status -p ${jmxPortStr} | egrep -c '^UN' | grep 2") + # Works if enabled + cass1.wait_until_succeeds("nc -z localhost ${jmxPortStr}") + cass0.succeed("nodetool -p ${jmxPortStr} -h 192.168.1.2 ${jmxAuthArgs} status") + '' + + '' + with subtest("Break and fix node"): + cass1.block() + cass0.wait_until_succeeds( + "nodetool status -p ${jmxPortStr} --resolve-ip | egrep -c '^DN[[:space:]]+cass1'" + ) + cass0.succeed("nodetool status -p ${jmxPortStr} | egrep -c '^UN' | grep 1") + cass1.unblock() + cass1.wait_until_succeeds( + "nodetool -p ${jmxPortStr} ${jmxAuthArgs} status | egrep -c '^UN' | grep 2" + ) + cass0.succeed("nodetool status -p ${jmxPortStr} | egrep -c '^UN' | grep 2") - with subtest("Replace crashed node"): - cass1.block() # .crash() waits until it's fully shutdown - cass2.start() - cass0.wait_until_fails( - "nodetool status -p ${jmxPortStr} --resolve-ip | egrep '^UN[[:space:]]+cass1'" - ) + with subtest("Replace crashed node"): + cass1.block() # .crash() waits until it's fully shutdown + cass2.start() + cass0.wait_until_fails( + "nodetool status -p ${jmxPortStr} --resolve-ip | egrep '^UN[[:space:]]+cass1'" + ) - cass2.wait_for_unit("cassandra.service") - cass0.wait_until_succeeds( - "nodetool status -p ${jmxPortStr} --resolve-ip | egrep '^UN[[:space:]]+cass2'" - ) - ''; + cass2.wait_for_unit("cassandra.service") + cass0.wait_until_succeeds( + "nodetool status -p ${jmxPortStr} --resolve-ip | egrep '^UN[[:space:]]+cass2'" + ) + ''; - passthru = { - inherit testPackage; - }; -}) + passthru = { + inherit testPackage; + }; + } +) diff --git a/nixos/tests/castopod.nix b/nixos/tests/castopod.nix index 57e035354d23ef..3d62cc0711fedf 100644 --- a/nixos/tests/castopod.nix +++ b/nixos/tests/castopod.nix @@ -1,234 +1,250 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -{ - name = "castopod"; - meta = with lib.maintainers; { - maintainers = [ alexoundos ]; - }; - - nodes.castopod = { nodes, ... }: { - # otherwise 500 MiB file upload fails! - virtualisation.diskSize = 512 + 3 * 512; - - networking.firewall.allowedTCPPorts = [ 80 ]; - networking.extraHosts = - lib.strings.concatStringsSep "\n" - (lib.attrsets.mapAttrsToList - (name: _: "127.0.0.1 ${name}") - nodes.castopod.services.nginx.virtualHosts); - - services.castopod = { - enable = true; - database.createLocally = true; - localDomain = "castopod.example.com"; - maxUploadSize = "512M"; - }; - }; - - nodes.client = { nodes, pkgs, lib, ... }: - let - domain = nodes.castopod.services.castopod.localDomain; - - getIP = node: - (builtins.head node.networking.interfaces.eth1.ipv4.addresses).address; - - targetPodcastSize = 500 * 1024 * 1024; - lameMp3Bitrate = 348300; - lameMp3FileAdjust = -800; - targetPodcastDuration = toString - ((targetPodcastSize + lameMp3FileAdjust) / (lameMp3Bitrate / 8)); - bannerWidth = 3000; - banner = pkgs.runCommand "gen-castopod-cover.jpg" { } '' - ${pkgs.imagemagick}/bin/magick ` - `-background green -bordercolor white -gravity northwest xc:black ` - `-duplicate 99 ` - `-seed 1 -resize "%[fx:rand()*72+24]" ` - `-seed 0 -rotate "%[fx:rand()*360]" -border 6x6 -splice 16x36 ` - `-seed 0 -rotate "%[fx:floor(rand()*4)*90]" -resize "150x50!" ` - `+append -crop 10x1@ +repage -roll "+%[fx:(t%2)*72]+0" -append ` - `-resize ${toString bannerWidth} -quality 1 $out - ''; - - coverWidth = toString 3000; - cover = pkgs.runCommand "gen-castopod-banner.jpg" { } '' - ${pkgs.imagemagick}/bin/magick ` - `-background white -bordercolor white -gravity northwest xc:black ` - `-duplicate 99 ` - `-seed 1 -resize "%[fx:rand()*72+24]" ` - `-seed 0 -rotate "%[fx:rand()*360]" -border 6x6 -splice 36x36 ` - `-seed 0 -rotate "%[fx:floor(rand()*4)*90]" -resize "144x144!" ` - `+append -crop 10x1@ +repage -roll "+%[fx:(t%2)*72]+0" -append ` - `-resize ${coverWidth} -quality 1 $out - ''; - in - { - networking.extraHosts = - lib.strings.concatStringsSep "\n" - (lib.attrsets.mapAttrsToList - (name: _: "${getIP nodes.castopod} ${name}") - nodes.castopod.services.nginx.virtualHosts); - - environment.systemPackages = - let - username = "admin"; - email = "admin@${domain}"; - password = "Abcd1234"; - podcastTitle = "Some Title"; - episodeTitle = "Episode Title"; - browser-test = pkgs.writers.writePython3Bin "browser-test" - { - libraries = [ pkgs.python3Packages.selenium ]; - flakeIgnore = [ "E124" "E501" ]; - } '' - from selenium.webdriver.common.by import By - from selenium.webdriver import Firefox - from selenium.webdriver.firefox.options import Options - from selenium.webdriver.firefox.service import Service - from selenium.webdriver.support.ui import WebDriverWait - from selenium.webdriver.support import expected_conditions as EC - from subprocess import STDOUT - import logging - - selenium_logger = logging.getLogger("selenium") - selenium_logger.setLevel(logging.DEBUG) - selenium_logger.addHandler(logging.StreamHandler()) - - options = Options() - options.add_argument('--headless') - service = Service(log_output=STDOUT) - driver = Firefox(options=options, service=service) - driver = Firefox(options=options) - driver.implicitly_wait(30) - driver.set_page_load_timeout(60) - - # install ########################################################## - - driver.get('http://${domain}/cp-install') - - wait = WebDriverWait(driver, 20) - - wait.until(EC.title_contains("installer")) - - driver.find_element(By.CSS_SELECTOR, '#username').send_keys( - '${username}' - ) - driver.find_element(By.CSS_SELECTOR, '#email').send_keys( - '${email}' - ) - driver.find_element(By.CSS_SELECTOR, '#password').send_keys( - '${password}' - ) - driver.find_element(By.XPATH, - "//button[contains(., 'Finish install')]" - ).click() - - wait.until(EC.title_contains("Auth")) - - driver.find_element(By.CSS_SELECTOR, '#email').send_keys( - '${email}' - ) - driver.find_element(By.CSS_SELECTOR, '#password').send_keys( - '${password}' - ) - driver.find_element(By.XPATH, - "//button[contains(., 'Login')]" - ).click() - - wait.until(EC.title_contains("Admin dashboard")) - - # create podcast ################################################### - - driver.get('http://${domain}/admin/podcasts/new') - - wait.until(EC.title_contains("Create podcast")) - - driver.find_element(By.CSS_SELECTOR, '#cover').send_keys( - '${cover}' - ) - driver.find_element(By.CSS_SELECTOR, '#banner').send_keys( - '${banner}' - ) - driver.find_element(By.CSS_SELECTOR, '#title').send_keys( - '${podcastTitle}' - ) - driver.find_element(By.CSS_SELECTOR, '#handle').send_keys( - 'some_handle' - ) - driver.find_element(By.CSS_SELECTOR, '#description').send_keys( - 'Some description' - ) - driver.find_element(By.CSS_SELECTOR, '#owner_name').send_keys( - 'Owner Name' - ) - driver.find_element(By.CSS_SELECTOR, '#owner_email').send_keys( - 'owner@email.xyz' - ) - driver.find_element(By.XPATH, - "//button[contains(., 'Create podcast')]" - ).click() - - wait.until(EC.title_contains("${podcastTitle}")) - - driver.find_element(By.XPATH, - "//span[contains(., 'Add an episode')]" - ).click() - - wait.until(EC.title_contains("Add an episode")) - - # upload podcast ################################################### - - driver.find_element(By.CSS_SELECTOR, '#audio_file').send_keys( - '/tmp/podcast.mp3' - ) - driver.find_element(By.CSS_SELECTOR, '#cover').send_keys( - '${cover}' - ) - driver.find_element(By.CSS_SELECTOR, '#description').send_keys( - 'Episode description' - ) - driver.find_element(By.CSS_SELECTOR, '#title').send_keys( - '${episodeTitle}' - ) - driver.find_element(By.XPATH, - "//button[contains(., 'Create episode')]" - ).click() - - wait.until(EC.title_contains("${episodeTitle}")) - - driver.close() - driver.quit() - ''; - in - [ - pkgs.firefox-unwrapped - pkgs.geckodriver - browser-test - (pkgs.writeShellApplication { - name = "build-mp3"; - runtimeInputs = with pkgs; [ sox lame ]; - text = '' - out=/tmp/podcast.mp3 - sox -n -r 48000 -t wav - synth ${targetPodcastDuration} sine 440 ` - `| lame --noreplaygain --cbr -q 9 -b 320 - $out - FILESIZE="$(stat -c%s $out)" - [ "$FILESIZE" -gt 0 ] - [ "$FILESIZE" -le "${toString targetPodcastSize}" ] - ''; - }) - ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "castopod"; + meta = with lib.maintainers; { + maintainers = [ alexoundos ]; }; - testScript = '' - start_all() - castopod.wait_for_unit("castopod-setup.service") - castopod.wait_for_file("/run/phpfpm/castopod.sock") - castopod.wait_for_unit("nginx.service") - castopod.wait_for_open_port(80) - castopod.wait_until_succeeds("curl -sS -f http://castopod.example.com") - - client.succeed("build-mp3") - - with subtest("Create superadmin, log in, create and upload a podcast"): - client.succeed(\ - "PYTHONUNBUFFERED=1 systemd-cat -t browser-test browser-test") - ''; -}) + nodes.castopod = + { nodes, ... }: + { + # otherwise 500 MiB file upload fails! + virtualisation.diskSize = 512 + 3 * 512; + + networking.firewall.allowedTCPPorts = [ 80 ]; + networking.extraHosts = lib.strings.concatStringsSep "\n" ( + lib.attrsets.mapAttrsToList ( + name: _: "127.0.0.1 ${name}" + ) nodes.castopod.services.nginx.virtualHosts + ); + + services.castopod = { + enable = true; + database.createLocally = true; + localDomain = "castopod.example.com"; + maxUploadSize = "512M"; + }; + }; + + nodes.client = + { + nodes, + pkgs, + lib, + ... + }: + let + domain = nodes.castopod.services.castopod.localDomain; + + getIP = node: (builtins.head node.networking.interfaces.eth1.ipv4.addresses).address; + + targetPodcastSize = 500 * 1024 * 1024; + lameMp3Bitrate = 348300; + lameMp3FileAdjust = -800; + targetPodcastDuration = toString ((targetPodcastSize + lameMp3FileAdjust) / (lameMp3Bitrate / 8)); + bannerWidth = 3000; + banner = pkgs.runCommand "gen-castopod-cover.jpg" { } '' + ${pkgs.imagemagick}/bin/magick ` + `-background green -bordercolor white -gravity northwest xc:black ` + `-duplicate 99 ` + `-seed 1 -resize "%[fx:rand()*72+24]" ` + `-seed 0 -rotate "%[fx:rand()*360]" -border 6x6 -splice 16x36 ` + `-seed 0 -rotate "%[fx:floor(rand()*4)*90]" -resize "150x50!" ` + `+append -crop 10x1@ +repage -roll "+%[fx:(t%2)*72]+0" -append ` + `-resize ${toString bannerWidth} -quality 1 $out + ''; + + coverWidth = toString 3000; + cover = pkgs.runCommand "gen-castopod-banner.jpg" { } '' + ${pkgs.imagemagick}/bin/magick ` + `-background white -bordercolor white -gravity northwest xc:black ` + `-duplicate 99 ` + `-seed 1 -resize "%[fx:rand()*72+24]" ` + `-seed 0 -rotate "%[fx:rand()*360]" -border 6x6 -splice 36x36 ` + `-seed 0 -rotate "%[fx:floor(rand()*4)*90]" -resize "144x144!" ` + `+append -crop 10x1@ +repage -roll "+%[fx:(t%2)*72]+0" -append ` + `-resize ${coverWidth} -quality 1 $out + ''; + in + { + networking.extraHosts = lib.strings.concatStringsSep "\n" ( + lib.attrsets.mapAttrsToList ( + name: _: "${getIP nodes.castopod} ${name}" + ) nodes.castopod.services.nginx.virtualHosts + ); + + environment.systemPackages = + let + username = "admin"; + email = "admin@${domain}"; + password = "Abcd1234"; + podcastTitle = "Some Title"; + episodeTitle = "Episode Title"; + browser-test = + pkgs.writers.writePython3Bin "browser-test" + { + libraries = [ pkgs.python3Packages.selenium ]; + flakeIgnore = [ + "E124" + "E501" + ]; + } + '' + from selenium.webdriver.common.by import By + from selenium.webdriver import Firefox + from selenium.webdriver.firefox.options import Options + from selenium.webdriver.firefox.service import Service + from selenium.webdriver.support.ui import WebDriverWait + from selenium.webdriver.support import expected_conditions as EC + from subprocess import STDOUT + import logging + + selenium_logger = logging.getLogger("selenium") + selenium_logger.setLevel(logging.DEBUG) + selenium_logger.addHandler(logging.StreamHandler()) + + options = Options() + options.add_argument('--headless') + service = Service(log_output=STDOUT) + driver = Firefox(options=options, service=service) + driver = Firefox(options=options) + driver.implicitly_wait(30) + driver.set_page_load_timeout(60) + + # install ########################################################## + + driver.get('http://${domain}/cp-install') + + wait = WebDriverWait(driver, 20) + + wait.until(EC.title_contains("installer")) + + driver.find_element(By.CSS_SELECTOR, '#username').send_keys( + '${username}' + ) + driver.find_element(By.CSS_SELECTOR, '#email').send_keys( + '${email}' + ) + driver.find_element(By.CSS_SELECTOR, '#password').send_keys( + '${password}' + ) + driver.find_element(By.XPATH, + "//button[contains(., 'Finish install')]" + ).click() + + wait.until(EC.title_contains("Auth")) + + driver.find_element(By.CSS_SELECTOR, '#email').send_keys( + '${email}' + ) + driver.find_element(By.CSS_SELECTOR, '#password').send_keys( + '${password}' + ) + driver.find_element(By.XPATH, + "//button[contains(., 'Login')]" + ).click() + + wait.until(EC.title_contains("Admin dashboard")) + + # create podcast ################################################### + + driver.get('http://${domain}/admin/podcasts/new') + + wait.until(EC.title_contains("Create podcast")) + + driver.find_element(By.CSS_SELECTOR, '#cover').send_keys( + '${cover}' + ) + driver.find_element(By.CSS_SELECTOR, '#banner').send_keys( + '${banner}' + ) + driver.find_element(By.CSS_SELECTOR, '#title').send_keys( + '${podcastTitle}' + ) + driver.find_element(By.CSS_SELECTOR, '#handle').send_keys( + 'some_handle' + ) + driver.find_element(By.CSS_SELECTOR, '#description').send_keys( + 'Some description' + ) + driver.find_element(By.CSS_SELECTOR, '#owner_name').send_keys( + 'Owner Name' + ) + driver.find_element(By.CSS_SELECTOR, '#owner_email').send_keys( + 'owner@email.xyz' + ) + driver.find_element(By.XPATH, + "//button[contains(., 'Create podcast')]" + ).click() + + wait.until(EC.title_contains("${podcastTitle}")) + + driver.find_element(By.XPATH, + "//span[contains(., 'Add an episode')]" + ).click() + + wait.until(EC.title_contains("Add an episode")) + + # upload podcast ################################################### + + driver.find_element(By.CSS_SELECTOR, '#audio_file').send_keys( + '/tmp/podcast.mp3' + ) + driver.find_element(By.CSS_SELECTOR, '#cover').send_keys( + '${cover}' + ) + driver.find_element(By.CSS_SELECTOR, '#description').send_keys( + 'Episode description' + ) + driver.find_element(By.CSS_SELECTOR, '#title').send_keys( + '${episodeTitle}' + ) + driver.find_element(By.XPATH, + "//button[contains(., 'Create episode')]" + ).click() + + wait.until(EC.title_contains("${episodeTitle}")) + + driver.close() + driver.quit() + ''; + in + [ + pkgs.firefox-unwrapped + pkgs.geckodriver + browser-test + (pkgs.writeShellApplication { + name = "build-mp3"; + runtimeInputs = with pkgs; [ + sox + lame + ]; + text = '' + out=/tmp/podcast.mp3 + sox -n -r 48000 -t wav - synth ${targetPodcastDuration} sine 440 ` + `| lame --noreplaygain --cbr -q 9 -b 320 - $out + FILESIZE="$(stat -c%s $out)" + [ "$FILESIZE" -gt 0 ] + [ "$FILESIZE" -le "${toString targetPodcastSize}" ] + ''; + }) + ]; + }; + + testScript = '' + start_all() + castopod.wait_for_unit("castopod-setup.service") + castopod.wait_for_file("/run/phpfpm/castopod.sock") + castopod.wait_for_unit("nginx.service") + castopod.wait_for_open_port(80) + castopod.wait_until_succeeds("curl -sS -f http://castopod.example.com") + + client.succeed("build-mp3") + + with subtest("Create superadmin, log in, create and upload a podcast"): + client.succeed(\ + "PYTHONUNBUFFERED=1 systemd-cat -t browser-test browser-test") + ''; + } +) diff --git a/nixos/tests/ccache.nix b/nixos/tests/ccache.nix index a97ae050176768..a32d2a1e06aa11 100644 --- a/nixos/tests/ccache.nix +++ b/nixos/tests/ccache.nix @@ -1,24 +1,28 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "ccache"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ehmry ]; - }; - - nodes.machine = { ... }: { - imports = [ ../modules/profiles/minimal.nix ]; - environment.systemPackages = [ pkgs.hello ]; - programs.ccache = { - enable = true; - packageNames = [ "hello" ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "ccache"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ehmry ]; }; - }; - testScript = - '' + nodes.machine = + { ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; + environment.systemPackages = [ pkgs.hello ]; + programs.ccache = { + enable = true; + packageNames = [ "hello" ]; + }; + }; + + testScript = '' start_all() machine.wait_for_unit("multi-user.target") machine.succeed("nix-ccache --show-stats") machine.succeed("hello") machine.shutdown() ''; -}) + } +) diff --git a/nixos/tests/centrifugo.nix b/nixos/tests/centrifugo.nix index 8e940f74caa4b1..8ad44a011663c2 100644 --- a/nixos/tests/centrifugo.nix +++ b/nixos/tests/centrifugo.nix @@ -7,44 +7,51 @@ let "centrifugo3" ]; in -{ lib, ... }: { +{ lib, ... }: +{ name = "centrifugo"; meta.maintainers = [ lib.maintainers.tie ]; - nodes = lib.listToAttrs (lib.imap0 - (index: name: { + nodes = lib.listToAttrs ( + lib.imap0 (index: name: { inherit name; - value = { config, ... }: { - services.centrifugo = { - enable = true; - settings = { - inherit name; - port = centrifugoPort; - # See https://centrifugal.dev/docs/server/engines#redis-sharding - engine = "redis"; - # Connect to local Redis shard via Unix socket. - redis_address = - let toRedisAddresses = map (name: "${name}:${toString redisPort}"); in - toRedisAddresses (lib.take index nodes) ++ [ - "unix://${config.services.redis.servers.centrifugo.unixSocket}" - ] ++ toRedisAddresses (lib.drop (index + 1) nodes); - usage_stats_disable = true; - api_insecure = true; + value = + { config, ... }: + { + services.centrifugo = { + enable = true; + settings = { + inherit name; + port = centrifugoPort; + # See https://centrifugal.dev/docs/server/engines#redis-sharding + engine = "redis"; + # Connect to local Redis shard via Unix socket. + redis_address = + let + toRedisAddresses = map (name: "${name}:${toString redisPort}"); + in + toRedisAddresses (lib.take index nodes) + ++ [ + "unix://${config.services.redis.servers.centrifugo.unixSocket}" + ] + ++ toRedisAddresses (lib.drop (index + 1) nodes); + usage_stats_disable = true; + api_insecure = true; + }; + extraGroups = [ + config.services.redis.servers.centrifugo.user + ]; + }; + services.redis.servers.centrifugo = { + enable = true; + bind = null; # all interfaces + port = redisPort; + openFirewall = true; + settings.protected-mode = false; }; - extraGroups = [ - config.services.redis.servers.centrifugo.user - ]; - }; - services.redis.servers.centrifugo = { - enable = true; - bind = null; # all interfaces - port = redisPort; - openFirewall = true; - settings.protected-mode = false; }; - }; - }) - nodes); + }) nodes + ); testScript = '' import json diff --git a/nixos/tests/ceph-single-node-bluestore.nix b/nixos/tests/ceph-single-node-bluestore.nix index 8bd1a78244a291..3fcc65feaa8cff 100644 --- a/nixos/tests/ceph-single-node-bluestore.nix +++ b/nixos/tests/ceph-single-node-bluestore.nix @@ -1,204 +1,236 @@ -import ./make-test-python.nix ({pkgs, lib, ...}: - -let - cfg = { - clusterId = "066ae264-2a5d-4729-8001-6ad265f50b03"; - monA = { - name = "a"; - ip = "192.168.1.1"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + let + cfg = { + clusterId = "066ae264-2a5d-4729-8001-6ad265f50b03"; + monA = { + name = "a"; + ip = "192.168.1.1"; + }; + osd0 = { + name = "0"; + key = "AQBCEJNa3s8nHRAANvdsr93KqzBznuIWm2gOGg=="; + uuid = "55ba2294-3e24-478f-bee0-9dca4c231dd9"; + }; + osd1 = { + name = "1"; + key = "AQBEEJNac00kExAAXEgy943BGyOpVH1LLlHafQ=="; + uuid = "5e97a838-85b6-43b0-8950-cb56d554d1e5"; + }; + osd2 = { + name = "2"; + key = "AQAdyhZeIaUlARAAGRoidDAmS6Vkp546UFEf5w=="; + uuid = "ea999274-13d0-4dd5-9af9-ad25a324f72f"; + }; }; - osd0 = { - name = "0"; - key = "AQBCEJNa3s8nHRAANvdsr93KqzBznuIWm2gOGg=="; - uuid = "55ba2294-3e24-478f-bee0-9dca4c231dd9"; + generateCephConfig = + { daemonConfig }: + { + enable = true; + global = { + fsid = cfg.clusterId; + monHost = cfg.monA.ip; + monInitialMembers = cfg.monA.name; + }; + } + // daemonConfig; + + generateHost = + { + pkgs, + cephConfig, + networkConfig, + ... + }: + { + virtualisation = { + emptyDiskImages = [ + 20480 + 20480 + 20480 + ]; + vlans = [ 1 ]; + }; + + networking = networkConfig; + + environment.systemPackages = with pkgs; [ + bash + sudo + ceph + xfsprogs + ]; + + boot.kernelModules = [ "xfs" ]; + + services.ceph = cephConfig; + }; + + networkMonA = { + dhcpcd.enable = false; + interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = cfg.monA.ip; + prefixLength = 24; + } + ]; }; - osd1 = { - name = "1"; - key = "AQBEEJNac00kExAAXEgy943BGyOpVH1LLlHafQ=="; - uuid = "5e97a838-85b6-43b0-8950-cb56d554d1e5"; + cephConfigMonA = generateCephConfig { + daemonConfig = { + mon = { + enable = true; + daemons = [ cfg.monA.name ]; + }; + mgr = { + enable = true; + daemons = [ cfg.monA.name ]; + }; + osd = { + enable = true; + daemons = [ + cfg.osd0.name + cfg.osd1.name + cfg.osd2.name + ]; + }; + }; }; - osd2 = { - name = "2"; - key = "AQAdyhZeIaUlARAAGRoidDAmS6Vkp546UFEf5w=="; - uuid = "ea999274-13d0-4dd5-9af9-ad25a324f72f"; - }; - }; - generateCephConfig = { daemonConfig }: { - enable = true; - global = { - fsid = cfg.clusterId; - monHost = cfg.monA.ip; - monInitialMembers = cfg.monA.name; - }; - } // daemonConfig; - generateHost = { pkgs, cephConfig, networkConfig, ... }: { - virtualisation = { - emptyDiskImages = [ 20480 20480 20480 ]; - vlans = [ 1 ]; + # Following deployment is based on the manual deployment described here: + # https://docs.ceph.com/docs/master/install/manual-deployment/ + # For other ways to deploy a ceph cluster, look at the documentation at + # https://docs.ceph.com/docs/master/ + testscript = + { ... }: + '' + start_all() + + monA.wait_for_unit("network.target") + + # Bootstrap ceph-mon daemon + monA.succeed( + "sudo -u ceph ceph-authtool --create-keyring /tmp/ceph.mon.keyring --gen-key -n mon. --cap mon 'allow *'", + "sudo -u ceph ceph-authtool --create-keyring /etc/ceph/ceph.client.admin.keyring --gen-key -n client.admin --cap mon 'allow *' --cap osd 'allow *' --cap mds 'allow *' --cap mgr 'allow *'", + "sudo -u ceph ceph-authtool /tmp/ceph.mon.keyring --import-keyring /etc/ceph/ceph.client.admin.keyring", + "monmaptool --create --add ${cfg.monA.name} ${cfg.monA.ip} --fsid ${cfg.clusterId} /tmp/monmap", + "sudo -u ceph ceph-mon --mkfs -i ${cfg.monA.name} --monmap /tmp/monmap --keyring /tmp/ceph.mon.keyring", + "sudo -u ceph touch /var/lib/ceph/mon/ceph-${cfg.monA.name}/done", + "systemctl start ceph-mon-${cfg.monA.name}", + ) + monA.wait_for_unit("ceph-mon-${cfg.monA.name}") + monA.succeed("ceph mon enable-msgr2") + monA.succeed("ceph config set mon auth_allow_insecure_global_id_reclaim false") + + # Can't check ceph status until a mon is up + monA.succeed("ceph -s | grep 'mon: 1 daemons'") + + # Start the ceph-mgr daemon, after copying in the keyring + monA.succeed( + "sudo -u ceph mkdir -p /var/lib/ceph/mgr/ceph-${cfg.monA.name}/", + "ceph auth get-or-create mgr.${cfg.monA.name} mon 'allow profile mgr' osd 'allow *' mds 'allow *' > /var/lib/ceph/mgr/ceph-${cfg.monA.name}/keyring", + "systemctl start ceph-mgr-${cfg.monA.name}", + ) + monA.wait_for_unit("ceph-mgr-a") + monA.wait_until_succeeds("ceph -s | grep 'quorum ${cfg.monA.name}'") + monA.wait_until_succeeds("ceph -s | grep 'mgr: ${cfg.monA.name}(active,'") + + # Bootstrap OSDs + monA.succeed( + "mkdir -p /var/lib/ceph/osd/ceph-${cfg.osd0.name}", + "echo bluestore > /var/lib/ceph/osd/ceph-${cfg.osd0.name}/type", + "ln -sf /dev/vdb /var/lib/ceph/osd/ceph-${cfg.osd0.name}/block", + "mkdir -p /var/lib/ceph/osd/ceph-${cfg.osd1.name}", + "echo bluestore > /var/lib/ceph/osd/ceph-${cfg.osd1.name}/type", + "ln -sf /dev/vdc /var/lib/ceph/osd/ceph-${cfg.osd1.name}/block", + "mkdir -p /var/lib/ceph/osd/ceph-${cfg.osd2.name}", + "echo bluestore > /var/lib/ceph/osd/ceph-${cfg.osd2.name}/type", + "ln -sf /dev/vdd /var/lib/ceph/osd/ceph-${cfg.osd2.name}/block", + "ceph-authtool --create-keyring /var/lib/ceph/osd/ceph-${cfg.osd0.name}/keyring --name osd.${cfg.osd0.name} --add-key ${cfg.osd0.key}", + "ceph-authtool --create-keyring /var/lib/ceph/osd/ceph-${cfg.osd1.name}/keyring --name osd.${cfg.osd1.name} --add-key ${cfg.osd1.key}", + "ceph-authtool --create-keyring /var/lib/ceph/osd/ceph-${cfg.osd2.name}/keyring --name osd.${cfg.osd2.name} --add-key ${cfg.osd2.key}", + 'echo \'{"cephx_secret": "${cfg.osd0.key}"}\' | ceph osd new ${cfg.osd0.uuid} -i -', + 'echo \'{"cephx_secret": "${cfg.osd1.key}"}\' | ceph osd new ${cfg.osd1.uuid} -i -', + 'echo \'{"cephx_secret": "${cfg.osd2.key}"}\' | ceph osd new ${cfg.osd2.uuid} -i -', + ) + + # Initialize the OSDs with regular filestore + monA.succeed( + "ceph-osd -i ${cfg.osd0.name} --mkfs --osd-uuid ${cfg.osd0.uuid}", + "ceph-osd -i ${cfg.osd1.name} --mkfs --osd-uuid ${cfg.osd1.uuid}", + "ceph-osd -i ${cfg.osd2.name} --mkfs --osd-uuid ${cfg.osd2.uuid}", + "chown -R ceph:ceph /var/lib/ceph/osd", + "systemctl start ceph-osd-${cfg.osd0.name}", + "systemctl start ceph-osd-${cfg.osd1.name}", + "systemctl start ceph-osd-${cfg.osd2.name}", + ) + monA.wait_until_succeeds("ceph osd stat | grep -e '3 osds: 3 up[^,]*, 3 in'") + monA.wait_until_succeeds("ceph -s | grep 'mgr: ${cfg.monA.name}(active,'") + monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") + + monA.succeed( + "ceph osd pool create single-node-test 32 32", + "ceph osd pool ls | grep 'single-node-test'", + + # We need to enable an application on the pool, otherwise it will + # stay unhealthy in state POOL_APP_NOT_ENABLED. + # Creating a CephFS would do this automatically, but we haven't done that here. + # See: https://docs.ceph.com/en/reef/rados/operations/pools/#associating-a-pool-with-an-application + # We use the custom application name "nixos-test" for this. + "ceph osd pool application enable single-node-test nixos-test", + + "ceph osd pool rename single-node-test single-node-other-test", + "ceph osd pool ls | grep 'single-node-other-test'", + ) + monA.wait_until_succeeds("ceph -s | grep '2 pools, 33 pgs'") + monA.succeed( + "ceph osd getcrushmap -o crush", + "crushtool -d crush -o decrushed", + "sed 's/step chooseleaf firstn 0 type host/step chooseleaf firstn 0 type osd/' decrushed > modcrush", + "crushtool -c modcrush -o recrushed", + "ceph osd setcrushmap -i recrushed", + "ceph osd pool set single-node-other-test size 2", + ) + monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") + monA.wait_until_succeeds("ceph -s | grep '33 active+clean'") + monA.fail( + "ceph osd pool ls | grep 'multi-node-test'", + "ceph osd pool delete single-node-other-test single-node-other-test --yes-i-really-really-mean-it", + ) + + # Shut down ceph by stopping ceph.target. + monA.succeed("systemctl stop ceph.target") + + # Start it up + monA.succeed("systemctl start ceph.target") + monA.wait_for_unit("ceph-mon-${cfg.monA.name}") + monA.wait_for_unit("ceph-mgr-${cfg.monA.name}") + monA.wait_for_unit("ceph-osd-${cfg.osd0.name}") + monA.wait_for_unit("ceph-osd-${cfg.osd1.name}") + monA.wait_for_unit("ceph-osd-${cfg.osd2.name}") + + # Ensure the cluster comes back up again + monA.succeed("ceph -s | grep 'mon: 1 daemons'") + monA.wait_until_succeeds("ceph -s | grep 'quorum ${cfg.monA.name}'") + monA.wait_until_succeeds("ceph osd stat | grep -e '3 osds: 3 up[^,]*, 3 in'") + monA.wait_until_succeeds("ceph -s | grep 'mgr: ${cfg.monA.name}(active,'") + monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") + ''; + in + { + name = "basic-single-node-ceph-cluster-bluestore"; + meta = with pkgs.lib.maintainers; { + maintainers = [ lukegb ]; }; - networking = networkConfig; - - environment.systemPackages = with pkgs; [ - bash - sudo - ceph - xfsprogs - ]; - - boot.kernelModules = [ "xfs" ]; - - services.ceph = cephConfig; - }; - - networkMonA = { - dhcpcd.enable = false; - interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = cfg.monA.ip; prefixLength = 24; } - ]; - }; - cephConfigMonA = generateCephConfig { daemonConfig = { - mon = { - enable = true; - daemons = [ cfg.monA.name ]; - }; - mgr = { - enable = true; - daemons = [ cfg.monA.name ]; + nodes = { + monA = generateHost { + pkgs = pkgs; + cephConfig = cephConfigMonA; + networkConfig = networkMonA; + }; }; - osd = { - enable = true; - daemons = [ cfg.osd0.name cfg.osd1.name cfg.osd2.name ]; - }; - }; }; - - # Following deployment is based on the manual deployment described here: - # https://docs.ceph.com/docs/master/install/manual-deployment/ - # For other ways to deploy a ceph cluster, look at the documentation at - # https://docs.ceph.com/docs/master/ - testscript = { ... }: '' - start_all() - - monA.wait_for_unit("network.target") - - # Bootstrap ceph-mon daemon - monA.succeed( - "sudo -u ceph ceph-authtool --create-keyring /tmp/ceph.mon.keyring --gen-key -n mon. --cap mon 'allow *'", - "sudo -u ceph ceph-authtool --create-keyring /etc/ceph/ceph.client.admin.keyring --gen-key -n client.admin --cap mon 'allow *' --cap osd 'allow *' --cap mds 'allow *' --cap mgr 'allow *'", - "sudo -u ceph ceph-authtool /tmp/ceph.mon.keyring --import-keyring /etc/ceph/ceph.client.admin.keyring", - "monmaptool --create --add ${cfg.monA.name} ${cfg.monA.ip} --fsid ${cfg.clusterId} /tmp/monmap", - "sudo -u ceph ceph-mon --mkfs -i ${cfg.monA.name} --monmap /tmp/monmap --keyring /tmp/ceph.mon.keyring", - "sudo -u ceph touch /var/lib/ceph/mon/ceph-${cfg.monA.name}/done", - "systemctl start ceph-mon-${cfg.monA.name}", - ) - monA.wait_for_unit("ceph-mon-${cfg.monA.name}") - monA.succeed("ceph mon enable-msgr2") - monA.succeed("ceph config set mon auth_allow_insecure_global_id_reclaim false") - - # Can't check ceph status until a mon is up - monA.succeed("ceph -s | grep 'mon: 1 daemons'") - - # Start the ceph-mgr daemon, after copying in the keyring - monA.succeed( - "sudo -u ceph mkdir -p /var/lib/ceph/mgr/ceph-${cfg.monA.name}/", - "ceph auth get-or-create mgr.${cfg.monA.name} mon 'allow profile mgr' osd 'allow *' mds 'allow *' > /var/lib/ceph/mgr/ceph-${cfg.monA.name}/keyring", - "systemctl start ceph-mgr-${cfg.monA.name}", - ) - monA.wait_for_unit("ceph-mgr-a") - monA.wait_until_succeeds("ceph -s | grep 'quorum ${cfg.monA.name}'") - monA.wait_until_succeeds("ceph -s | grep 'mgr: ${cfg.monA.name}(active,'") - - # Bootstrap OSDs - monA.succeed( - "mkdir -p /var/lib/ceph/osd/ceph-${cfg.osd0.name}", - "echo bluestore > /var/lib/ceph/osd/ceph-${cfg.osd0.name}/type", - "ln -sf /dev/vdb /var/lib/ceph/osd/ceph-${cfg.osd0.name}/block", - "mkdir -p /var/lib/ceph/osd/ceph-${cfg.osd1.name}", - "echo bluestore > /var/lib/ceph/osd/ceph-${cfg.osd1.name}/type", - "ln -sf /dev/vdc /var/lib/ceph/osd/ceph-${cfg.osd1.name}/block", - "mkdir -p /var/lib/ceph/osd/ceph-${cfg.osd2.name}", - "echo bluestore > /var/lib/ceph/osd/ceph-${cfg.osd2.name}/type", - "ln -sf /dev/vdd /var/lib/ceph/osd/ceph-${cfg.osd2.name}/block", - "ceph-authtool --create-keyring /var/lib/ceph/osd/ceph-${cfg.osd0.name}/keyring --name osd.${cfg.osd0.name} --add-key ${cfg.osd0.key}", - "ceph-authtool --create-keyring /var/lib/ceph/osd/ceph-${cfg.osd1.name}/keyring --name osd.${cfg.osd1.name} --add-key ${cfg.osd1.key}", - "ceph-authtool --create-keyring /var/lib/ceph/osd/ceph-${cfg.osd2.name}/keyring --name osd.${cfg.osd2.name} --add-key ${cfg.osd2.key}", - 'echo \'{"cephx_secret": "${cfg.osd0.key}"}\' | ceph osd new ${cfg.osd0.uuid} -i -', - 'echo \'{"cephx_secret": "${cfg.osd1.key}"}\' | ceph osd new ${cfg.osd1.uuid} -i -', - 'echo \'{"cephx_secret": "${cfg.osd2.key}"}\' | ceph osd new ${cfg.osd2.uuid} -i -', - ) - - # Initialize the OSDs with regular filestore - monA.succeed( - "ceph-osd -i ${cfg.osd0.name} --mkfs --osd-uuid ${cfg.osd0.uuid}", - "ceph-osd -i ${cfg.osd1.name} --mkfs --osd-uuid ${cfg.osd1.uuid}", - "ceph-osd -i ${cfg.osd2.name} --mkfs --osd-uuid ${cfg.osd2.uuid}", - "chown -R ceph:ceph /var/lib/ceph/osd", - "systemctl start ceph-osd-${cfg.osd0.name}", - "systemctl start ceph-osd-${cfg.osd1.name}", - "systemctl start ceph-osd-${cfg.osd2.name}", - ) - monA.wait_until_succeeds("ceph osd stat | grep -e '3 osds: 3 up[^,]*, 3 in'") - monA.wait_until_succeeds("ceph -s | grep 'mgr: ${cfg.monA.name}(active,'") - monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") - - monA.succeed( - "ceph osd pool create single-node-test 32 32", - "ceph osd pool ls | grep 'single-node-test'", - - # We need to enable an application on the pool, otherwise it will - # stay unhealthy in state POOL_APP_NOT_ENABLED. - # Creating a CephFS would do this automatically, but we haven't done that here. - # See: https://docs.ceph.com/en/reef/rados/operations/pools/#associating-a-pool-with-an-application - # We use the custom application name "nixos-test" for this. - "ceph osd pool application enable single-node-test nixos-test", - - "ceph osd pool rename single-node-test single-node-other-test", - "ceph osd pool ls | grep 'single-node-other-test'", - ) - monA.wait_until_succeeds("ceph -s | grep '2 pools, 33 pgs'") - monA.succeed( - "ceph osd getcrushmap -o crush", - "crushtool -d crush -o decrushed", - "sed 's/step chooseleaf firstn 0 type host/step chooseleaf firstn 0 type osd/' decrushed > modcrush", - "crushtool -c modcrush -o recrushed", - "ceph osd setcrushmap -i recrushed", - "ceph osd pool set single-node-other-test size 2", - ) - monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") - monA.wait_until_succeeds("ceph -s | grep '33 active+clean'") - monA.fail( - "ceph osd pool ls | grep 'multi-node-test'", - "ceph osd pool delete single-node-other-test single-node-other-test --yes-i-really-really-mean-it", - ) - - # Shut down ceph by stopping ceph.target. - monA.succeed("systemctl stop ceph.target") - - # Start it up - monA.succeed("systemctl start ceph.target") - monA.wait_for_unit("ceph-mon-${cfg.monA.name}") - monA.wait_for_unit("ceph-mgr-${cfg.monA.name}") - monA.wait_for_unit("ceph-osd-${cfg.osd0.name}") - monA.wait_for_unit("ceph-osd-${cfg.osd1.name}") - monA.wait_for_unit("ceph-osd-${cfg.osd2.name}") - - # Ensure the cluster comes back up again - monA.succeed("ceph -s | grep 'mon: 1 daemons'") - monA.wait_until_succeeds("ceph -s | grep 'quorum ${cfg.monA.name}'") - monA.wait_until_succeeds("ceph osd stat | grep -e '3 osds: 3 up[^,]*, 3 in'") - monA.wait_until_succeeds("ceph -s | grep 'mgr: ${cfg.monA.name}(active,'") - monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") - ''; -in { - name = "basic-single-node-ceph-cluster-bluestore"; - meta = with pkgs.lib.maintainers; { - maintainers = [ lukegb ]; - }; - - nodes = { - monA = generateHost { pkgs = pkgs; cephConfig = cephConfigMonA; networkConfig = networkMonA; }; - }; - - testScript = testscript; -}) + + testScript = testscript; + } +) diff --git a/nixos/tests/ceph-single-node.nix b/nixos/tests/ceph-single-node.nix index c34ec511dc6d2e..de926d4729f6e4 100644 --- a/nixos/tests/ceph-single-node.nix +++ b/nixos/tests/ceph-single-node.nix @@ -1,215 +1,250 @@ -import ./make-test-python.nix ({pkgs, lib, ...}: - -let - cfg = { - clusterId = "066ae264-2a5d-4729-8001-6ad265f50b03"; - monA = { - name = "a"; - ip = "192.168.1.1"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + let + cfg = { + clusterId = "066ae264-2a5d-4729-8001-6ad265f50b03"; + monA = { + name = "a"; + ip = "192.168.1.1"; + }; + osd0 = { + name = "0"; + key = "AQBCEJNa3s8nHRAANvdsr93KqzBznuIWm2gOGg=="; + uuid = "55ba2294-3e24-478f-bee0-9dca4c231dd9"; + }; + osd1 = { + name = "1"; + key = "AQBEEJNac00kExAAXEgy943BGyOpVH1LLlHafQ=="; + uuid = "5e97a838-85b6-43b0-8950-cb56d554d1e5"; + }; + osd2 = { + name = "2"; + key = "AQAdyhZeIaUlARAAGRoidDAmS6Vkp546UFEf5w=="; + uuid = "ea999274-13d0-4dd5-9af9-ad25a324f72f"; + }; }; - osd0 = { - name = "0"; - key = "AQBCEJNa3s8nHRAANvdsr93KqzBznuIWm2gOGg=="; - uuid = "55ba2294-3e24-478f-bee0-9dca4c231dd9"; + generateCephConfig = + { daemonConfig }: + { + enable = true; + global = { + fsid = cfg.clusterId; + monHost = cfg.monA.ip; + monInitialMembers = cfg.monA.name; + }; + } + // daemonConfig; + + generateHost = + { + pkgs, + cephConfig, + networkConfig, + ... + }: + { + virtualisation = { + emptyDiskImages = [ + 20480 + 20480 + 20480 + ]; + vlans = [ 1 ]; + }; + + networking = networkConfig; + + environment.systemPackages = with pkgs; [ + bash + sudo + ceph + xfsprogs + ]; + + boot.kernelModules = [ "xfs" ]; + + services.ceph = cephConfig; + }; + + networkMonA = { + dhcpcd.enable = false; + interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = cfg.monA.ip; + prefixLength = 24; + } + ]; }; - osd1 = { - name = "1"; - key = "AQBEEJNac00kExAAXEgy943BGyOpVH1LLlHafQ=="; - uuid = "5e97a838-85b6-43b0-8950-cb56d554d1e5"; + cephConfigMonA = generateCephConfig { + daemonConfig = { + mon = { + enable = true; + daemons = [ cfg.monA.name ]; + }; + mgr = { + enable = true; + daemons = [ cfg.monA.name ]; + }; + osd = { + enable = true; + daemons = [ + cfg.osd0.name + cfg.osd1.name + cfg.osd2.name + ]; + }; + }; }; - osd2 = { - name = "2"; - key = "AQAdyhZeIaUlARAAGRoidDAmS6Vkp546UFEf5w=="; - uuid = "ea999274-13d0-4dd5-9af9-ad25a324f72f"; - }; - }; - generateCephConfig = { daemonConfig }: { - enable = true; - global = { - fsid = cfg.clusterId; - monHost = cfg.monA.ip; - monInitialMembers = cfg.monA.name; - }; - } // daemonConfig; - generateHost = { pkgs, cephConfig, networkConfig, ... }: { - virtualisation = { - emptyDiskImages = [ 20480 20480 20480 ]; - vlans = [ 1 ]; + # Following deployment is based on the manual deployment described here: + # https://docs.ceph.com/docs/master/install/manual-deployment/ + # For other ways to deploy a ceph cluster, look at the documentation at + # https://docs.ceph.com/docs/master/ + testscript = + { ... }: + '' + start_all() + + monA.wait_for_unit("network.target") + + # Bootstrap ceph-mon daemon + monA.succeed( + "sudo -u ceph ceph-authtool --create-keyring /tmp/ceph.mon.keyring --gen-key -n mon. --cap mon 'allow *'", + "sudo -u ceph ceph-authtool --create-keyring /etc/ceph/ceph.client.admin.keyring --gen-key -n client.admin --cap mon 'allow *' --cap osd 'allow *' --cap mds 'allow *' --cap mgr 'allow *'", + "sudo -u ceph ceph-authtool /tmp/ceph.mon.keyring --import-keyring /etc/ceph/ceph.client.admin.keyring", + "monmaptool --create --add ${cfg.monA.name} ${cfg.monA.ip} --fsid ${cfg.clusterId} /tmp/monmap", + "sudo -u ceph ceph-mon --mkfs -i ${cfg.monA.name} --monmap /tmp/monmap --keyring /tmp/ceph.mon.keyring", + "sudo -u ceph touch /var/lib/ceph/mon/ceph-${cfg.monA.name}/done", + "systemctl start ceph-mon-${cfg.monA.name}", + ) + monA.wait_for_unit("ceph-mon-${cfg.monA.name}") + monA.succeed("ceph mon enable-msgr2") + monA.succeed("ceph config set mon auth_allow_insecure_global_id_reclaim false") + + # Can't check ceph status until a mon is up + monA.succeed("ceph -s | grep 'mon: 1 daemons'") + + # Start the ceph-mgr daemon, after copying in the keyring + monA.succeed( + "sudo -u ceph mkdir -p /var/lib/ceph/mgr/ceph-${cfg.monA.name}/", + "ceph auth get-or-create mgr.${cfg.monA.name} mon 'allow profile mgr' osd 'allow *' mds 'allow *' > /var/lib/ceph/mgr/ceph-${cfg.monA.name}/keyring", + "systemctl start ceph-mgr-${cfg.monA.name}", + ) + monA.wait_for_unit("ceph-mgr-a") + monA.wait_until_succeeds("ceph -s | grep 'quorum ${cfg.monA.name}'") + monA.wait_until_succeeds("ceph -s | grep 'mgr: ${cfg.monA.name}(active,'") + + # Bootstrap OSDs + monA.succeed( + "mkfs.xfs /dev/vdb", + "mkfs.xfs /dev/vdc", + "mkfs.xfs /dev/vdd", + "mkdir -p /var/lib/ceph/osd/ceph-${cfg.osd0.name}", + "mount /dev/vdb /var/lib/ceph/osd/ceph-${cfg.osd0.name}", + "mkdir -p /var/lib/ceph/osd/ceph-${cfg.osd1.name}", + "mount /dev/vdc /var/lib/ceph/osd/ceph-${cfg.osd1.name}", + "mkdir -p /var/lib/ceph/osd/ceph-${cfg.osd2.name}", + "mount /dev/vdd /var/lib/ceph/osd/ceph-${cfg.osd2.name}", + "ceph-authtool --create-keyring /var/lib/ceph/osd/ceph-${cfg.osd0.name}/keyring --name osd.${cfg.osd0.name} --add-key ${cfg.osd0.key}", + "ceph-authtool --create-keyring /var/lib/ceph/osd/ceph-${cfg.osd1.name}/keyring --name osd.${cfg.osd1.name} --add-key ${cfg.osd1.key}", + "ceph-authtool --create-keyring /var/lib/ceph/osd/ceph-${cfg.osd2.name}/keyring --name osd.${cfg.osd2.name} --add-key ${cfg.osd2.key}", + 'echo \'{"cephx_secret": "${cfg.osd0.key}"}\' | ceph osd new ${cfg.osd0.uuid} -i -', + 'echo \'{"cephx_secret": "${cfg.osd1.key}"}\' | ceph osd new ${cfg.osd1.uuid} -i -', + 'echo \'{"cephx_secret": "${cfg.osd2.key}"}\' | ceph osd new ${cfg.osd2.uuid} -i -', + ) + + # Initialize the OSDs with regular filestore + monA.succeed( + "ceph-osd -i ${cfg.osd0.name} --mkfs --osd-uuid ${cfg.osd0.uuid}", + "ceph-osd -i ${cfg.osd1.name} --mkfs --osd-uuid ${cfg.osd1.uuid}", + "ceph-osd -i ${cfg.osd2.name} --mkfs --osd-uuid ${cfg.osd2.uuid}", + "chown -R ceph:ceph /var/lib/ceph/osd", + "systemctl start ceph-osd-${cfg.osd0.name}", + "systemctl start ceph-osd-${cfg.osd1.name}", + "systemctl start ceph-osd-${cfg.osd2.name}", + ) + monA.wait_until_succeeds("ceph osd stat | grep -e '3 osds: 3 up[^,]*, 3 in'") + monA.wait_until_succeeds("ceph -s | grep 'mgr: ${cfg.monA.name}(active,'") + monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") + + monA.succeed( + "ceph osd pool create single-node-test 32 32", + "ceph osd pool ls | grep 'single-node-test'", + + # We need to enable an application on the pool, otherwise it will + # stay unhealthy in state POOL_APP_NOT_ENABLED. + # Creating a CephFS would do this automatically, but we haven't done that here. + # See: https://docs.ceph.com/en/reef/rados/operations/pools/#associating-a-pool-with-an-application + # We use the custom application name "nixos-test" for this. + "ceph osd pool application enable single-node-test nixos-test", + + "ceph osd pool rename single-node-test single-node-other-test", + "ceph osd pool ls | grep 'single-node-other-test'", + ) + monA.wait_until_succeeds("ceph -s | grep '2 pools, 33 pgs'") + monA.succeed( + "ceph osd getcrushmap -o crush", + "crushtool -d crush -o decrushed", + "sed 's/step chooseleaf firstn 0 type host/step chooseleaf firstn 0 type osd/' decrushed > modcrush", + "crushtool -c modcrush -o recrushed", + "ceph osd setcrushmap -i recrushed", + "ceph osd pool set single-node-other-test size 2", + ) + monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") + monA.wait_until_succeeds("ceph -s | grep '33 active+clean'") + monA.fail( + "ceph osd pool ls | grep 'multi-node-test'", + "ceph osd pool delete single-node-other-test single-node-other-test --yes-i-really-really-mean-it", + ) + + # Shut down ceph by stopping ceph.target. + monA.succeed("systemctl stop ceph.target") + + # Start it up + monA.succeed("systemctl start ceph.target") + monA.wait_for_unit("ceph-mon-${cfg.monA.name}") + monA.wait_for_unit("ceph-mgr-${cfg.monA.name}") + monA.wait_for_unit("ceph-osd-${cfg.osd0.name}") + monA.wait_for_unit("ceph-osd-${cfg.osd1.name}") + monA.wait_for_unit("ceph-osd-${cfg.osd2.name}") + + # Ensure the cluster comes back up again + monA.succeed("ceph -s | grep 'mon: 1 daemons'") + monA.wait_until_succeeds("ceph -s | grep 'quorum ${cfg.monA.name}'") + monA.wait_until_succeeds("ceph osd stat | grep -e '3 osds: 3 up[^,]*, 3 in'") + monA.wait_until_succeeds("ceph -s | grep 'mgr: ${cfg.monA.name}(active,'") + monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") + + # Enable the dashboard and recheck health + monA.succeed( + "ceph mgr module enable dashboard", + "ceph config set mgr mgr/dashboard/ssl false", + # default is 8080 but it's better to be explicit + "ceph config set mgr mgr/dashboard/server_port 8080", + ) + monA.wait_for_open_port(8080) + monA.wait_until_succeeds("curl -q --fail http://localhost:8080") + monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") + ''; + in + { + name = "basic-single-node-ceph-cluster"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + lejonet + johanot + ]; }; - networking = networkConfig; - - environment.systemPackages = with pkgs; [ - bash - sudo - ceph - xfsprogs - ]; - - boot.kernelModules = [ "xfs" ]; - - services.ceph = cephConfig; - }; - - networkMonA = { - dhcpcd.enable = false; - interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = cfg.monA.ip; prefixLength = 24; } - ]; - }; - cephConfigMonA = generateCephConfig { daemonConfig = { - mon = { - enable = true; - daemons = [ cfg.monA.name ]; - }; - mgr = { - enable = true; - daemons = [ cfg.monA.name ]; + nodes = { + monA = generateHost { + pkgs = pkgs; + cephConfig = cephConfigMonA; + networkConfig = networkMonA; + }; }; - osd = { - enable = true; - daemons = [ cfg.osd0.name cfg.osd1.name cfg.osd2.name ]; - }; - }; }; - - # Following deployment is based on the manual deployment described here: - # https://docs.ceph.com/docs/master/install/manual-deployment/ - # For other ways to deploy a ceph cluster, look at the documentation at - # https://docs.ceph.com/docs/master/ - testscript = { ... }: '' - start_all() - - monA.wait_for_unit("network.target") - - # Bootstrap ceph-mon daemon - monA.succeed( - "sudo -u ceph ceph-authtool --create-keyring /tmp/ceph.mon.keyring --gen-key -n mon. --cap mon 'allow *'", - "sudo -u ceph ceph-authtool --create-keyring /etc/ceph/ceph.client.admin.keyring --gen-key -n client.admin --cap mon 'allow *' --cap osd 'allow *' --cap mds 'allow *' --cap mgr 'allow *'", - "sudo -u ceph ceph-authtool /tmp/ceph.mon.keyring --import-keyring /etc/ceph/ceph.client.admin.keyring", - "monmaptool --create --add ${cfg.monA.name} ${cfg.monA.ip} --fsid ${cfg.clusterId} /tmp/monmap", - "sudo -u ceph ceph-mon --mkfs -i ${cfg.monA.name} --monmap /tmp/monmap --keyring /tmp/ceph.mon.keyring", - "sudo -u ceph touch /var/lib/ceph/mon/ceph-${cfg.monA.name}/done", - "systemctl start ceph-mon-${cfg.monA.name}", - ) - monA.wait_for_unit("ceph-mon-${cfg.monA.name}") - monA.succeed("ceph mon enable-msgr2") - monA.succeed("ceph config set mon auth_allow_insecure_global_id_reclaim false") - - # Can't check ceph status until a mon is up - monA.succeed("ceph -s | grep 'mon: 1 daemons'") - - # Start the ceph-mgr daemon, after copying in the keyring - monA.succeed( - "sudo -u ceph mkdir -p /var/lib/ceph/mgr/ceph-${cfg.monA.name}/", - "ceph auth get-or-create mgr.${cfg.monA.name} mon 'allow profile mgr' osd 'allow *' mds 'allow *' > /var/lib/ceph/mgr/ceph-${cfg.monA.name}/keyring", - "systemctl start ceph-mgr-${cfg.monA.name}", - ) - monA.wait_for_unit("ceph-mgr-a") - monA.wait_until_succeeds("ceph -s | grep 'quorum ${cfg.monA.name}'") - monA.wait_until_succeeds("ceph -s | grep 'mgr: ${cfg.monA.name}(active,'") - - # Bootstrap OSDs - monA.succeed( - "mkfs.xfs /dev/vdb", - "mkfs.xfs /dev/vdc", - "mkfs.xfs /dev/vdd", - "mkdir -p /var/lib/ceph/osd/ceph-${cfg.osd0.name}", - "mount /dev/vdb /var/lib/ceph/osd/ceph-${cfg.osd0.name}", - "mkdir -p /var/lib/ceph/osd/ceph-${cfg.osd1.name}", - "mount /dev/vdc /var/lib/ceph/osd/ceph-${cfg.osd1.name}", - "mkdir -p /var/lib/ceph/osd/ceph-${cfg.osd2.name}", - "mount /dev/vdd /var/lib/ceph/osd/ceph-${cfg.osd2.name}", - "ceph-authtool --create-keyring /var/lib/ceph/osd/ceph-${cfg.osd0.name}/keyring --name osd.${cfg.osd0.name} --add-key ${cfg.osd0.key}", - "ceph-authtool --create-keyring /var/lib/ceph/osd/ceph-${cfg.osd1.name}/keyring --name osd.${cfg.osd1.name} --add-key ${cfg.osd1.key}", - "ceph-authtool --create-keyring /var/lib/ceph/osd/ceph-${cfg.osd2.name}/keyring --name osd.${cfg.osd2.name} --add-key ${cfg.osd2.key}", - 'echo \'{"cephx_secret": "${cfg.osd0.key}"}\' | ceph osd new ${cfg.osd0.uuid} -i -', - 'echo \'{"cephx_secret": "${cfg.osd1.key}"}\' | ceph osd new ${cfg.osd1.uuid} -i -', - 'echo \'{"cephx_secret": "${cfg.osd2.key}"}\' | ceph osd new ${cfg.osd2.uuid} -i -', - ) - - # Initialize the OSDs with regular filestore - monA.succeed( - "ceph-osd -i ${cfg.osd0.name} --mkfs --osd-uuid ${cfg.osd0.uuid}", - "ceph-osd -i ${cfg.osd1.name} --mkfs --osd-uuid ${cfg.osd1.uuid}", - "ceph-osd -i ${cfg.osd2.name} --mkfs --osd-uuid ${cfg.osd2.uuid}", - "chown -R ceph:ceph /var/lib/ceph/osd", - "systemctl start ceph-osd-${cfg.osd0.name}", - "systemctl start ceph-osd-${cfg.osd1.name}", - "systemctl start ceph-osd-${cfg.osd2.name}", - ) - monA.wait_until_succeeds("ceph osd stat | grep -e '3 osds: 3 up[^,]*, 3 in'") - monA.wait_until_succeeds("ceph -s | grep 'mgr: ${cfg.monA.name}(active,'") - monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") - - monA.succeed( - "ceph osd pool create single-node-test 32 32", - "ceph osd pool ls | grep 'single-node-test'", - - # We need to enable an application on the pool, otherwise it will - # stay unhealthy in state POOL_APP_NOT_ENABLED. - # Creating a CephFS would do this automatically, but we haven't done that here. - # See: https://docs.ceph.com/en/reef/rados/operations/pools/#associating-a-pool-with-an-application - # We use the custom application name "nixos-test" for this. - "ceph osd pool application enable single-node-test nixos-test", - - "ceph osd pool rename single-node-test single-node-other-test", - "ceph osd pool ls | grep 'single-node-other-test'", - ) - monA.wait_until_succeeds("ceph -s | grep '2 pools, 33 pgs'") - monA.succeed( - "ceph osd getcrushmap -o crush", - "crushtool -d crush -o decrushed", - "sed 's/step chooseleaf firstn 0 type host/step chooseleaf firstn 0 type osd/' decrushed > modcrush", - "crushtool -c modcrush -o recrushed", - "ceph osd setcrushmap -i recrushed", - "ceph osd pool set single-node-other-test size 2", - ) - monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") - monA.wait_until_succeeds("ceph -s | grep '33 active+clean'") - monA.fail( - "ceph osd pool ls | grep 'multi-node-test'", - "ceph osd pool delete single-node-other-test single-node-other-test --yes-i-really-really-mean-it", - ) - - # Shut down ceph by stopping ceph.target. - monA.succeed("systemctl stop ceph.target") - - # Start it up - monA.succeed("systemctl start ceph.target") - monA.wait_for_unit("ceph-mon-${cfg.monA.name}") - monA.wait_for_unit("ceph-mgr-${cfg.monA.name}") - monA.wait_for_unit("ceph-osd-${cfg.osd0.name}") - monA.wait_for_unit("ceph-osd-${cfg.osd1.name}") - monA.wait_for_unit("ceph-osd-${cfg.osd2.name}") - - # Ensure the cluster comes back up again - monA.succeed("ceph -s | grep 'mon: 1 daemons'") - monA.wait_until_succeeds("ceph -s | grep 'quorum ${cfg.monA.name}'") - monA.wait_until_succeeds("ceph osd stat | grep -e '3 osds: 3 up[^,]*, 3 in'") - monA.wait_until_succeeds("ceph -s | grep 'mgr: ${cfg.monA.name}(active,'") - monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") - - # Enable the dashboard and recheck health - monA.succeed( - "ceph mgr module enable dashboard", - "ceph config set mgr mgr/dashboard/ssl false", - # default is 8080 but it's better to be explicit - "ceph config set mgr mgr/dashboard/server_port 8080", - ) - monA.wait_for_open_port(8080) - monA.wait_until_succeeds("curl -q --fail http://localhost:8080") - monA.wait_until_succeeds("ceph -s | grep 'HEALTH_OK'") - ''; -in { - name = "basic-single-node-ceph-cluster"; - meta = with pkgs.lib.maintainers; { - maintainers = [ lejonet johanot ]; - }; - - nodes = { - monA = generateHost { pkgs = pkgs; cephConfig = cephConfigMonA; networkConfig = networkMonA; }; - }; - - testScript = testscript; -}) + + testScript = testscript; + } +) diff --git a/nixos/tests/certmgr.nix b/nixos/tests/certmgr.nix index 8f5b89487793ba..5f92e2cad96315 100644 --- a/nixos/tests/certmgr.nix +++ b/nixos/tests/certmgr.nix @@ -1,128 +1,180 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; let - mkSpec = { host, service ? null, action }: { - inherit action; - authority = { - file = { + mkSpec = + { + host, + service ? null, + action, + }: + { + inherit action; + authority = { + file = { + group = "nginx"; + owner = "nginx"; + path = "/var/ssl/${host}-ca.pem"; + }; + label = "www_ca"; + profile = "three-month"; + remote = "localhost:8888"; + }; + certificate = { group = "nginx"; owner = "nginx"; - path = "/var/ssl/${host}-ca.pem"; + path = "/var/ssl/${host}-cert.pem"; }; - label = "www_ca"; - profile = "three-month"; - remote = "localhost:8888"; - }; - certificate = { - group = "nginx"; - owner = "nginx"; - path = "/var/ssl/${host}-cert.pem"; - }; - private_key = { - group = "nginx"; - mode = "0600"; - owner = "nginx"; - path = "/var/ssl/${host}-key.pem"; - }; - request = { - CN = host; - hosts = [ host "www.${host}" ]; - key = { - algo = "rsa"; - size = 2048; + private_key = { + group = "nginx"; + mode = "0600"; + owner = "nginx"; + path = "/var/ssl/${host}-key.pem"; + }; + request = { + CN = host; + hosts = [ + host + "www.${host}" + ]; + key = { + algo = "rsa"; + size = 2048; + }; + names = [ + { + C = "US"; + L = "San Francisco"; + O = "Example, LLC"; + ST = "CA"; + } + ]; }; - names = [ - { - C = "US"; - L = "San Francisco"; - O = "Example, LLC"; - ST = "CA"; - } - ]; + inherit service; }; - inherit service; - }; - mkCertmgrTest = { svcManager, specs, testScript }: makeTest { - name = "certmgr-" + svcManager; - nodes = { - machine = { config, lib, pkgs, ... }: { - networking.firewall.allowedTCPPorts = with config.services; [ cfssl.port certmgr.metricsPort ]; - networking.extraHosts = "127.0.0.1 imp.example.org decl.example.org"; + mkCertmgrTest = + { + svcManager, + specs, + testScript, + }: + makeTest { + name = "certmgr-" + svcManager; + nodes = { + machine = + { + config, + lib, + pkgs, + ... + }: + { + networking.firewall.allowedTCPPorts = with config.services; [ + cfssl.port + certmgr.metricsPort + ]; + networking.extraHosts = "127.0.0.1 imp.example.org decl.example.org"; - services.cfssl.enable = true; - systemd.services.cfssl.after = [ "cfssl-init.service" "networking.target" ]; + services.cfssl.enable = true; + systemd.services.cfssl.after = [ + "cfssl-init.service" + "networking.target" + ]; - systemd.tmpfiles.rules = [ "d /var/ssl 777 root root" ]; + systemd.tmpfiles.rules = [ "d /var/ssl 777 root root" ]; - systemd.services.cfssl-init = { - description = "Initialize the cfssl CA"; - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - User = "cfssl"; - Type = "oneshot"; - WorkingDirectory = config.services.cfssl.dataDir; - }; - script = '' - ${pkgs.cfssl}/bin/cfssl genkey -initca ${pkgs.writeText "ca.json" (builtins.toJSON { - hosts = [ "ca.example.com" ]; - key = { - algo = "rsa"; size = 4096; }; - names = [ - { - C = "US"; - L = "San Francisco"; - O = "Internet Widgets, LLC"; - OU = "Certificate Authority"; - ST = "California"; - } - ]; - })} | ${pkgs.cfssl}/bin/cfssljson -bare ca - ''; - }; - - services.nginx = { - enable = true; - virtualHosts = lib.mkMerge (map (host: { - ${host} = { - sslCertificate = "/var/ssl/${host}-cert.pem"; - sslCertificateKey = "/var/ssl/${host}-key.pem"; - extraConfig = '' - ssl_protocols TLSv1 TLSv1.1 TLSv1.2; + systemd.services.cfssl-init = { + description = "Initialize the cfssl CA"; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + User = "cfssl"; + Type = "oneshot"; + WorkingDirectory = config.services.cfssl.dataDir; + }; + script = '' + ${pkgs.cfssl}/bin/cfssl genkey -initca ${ + pkgs.writeText "ca.json" ( + builtins.toJSON { + hosts = [ "ca.example.com" ]; + key = { + algo = "rsa"; + size = 4096; + }; + names = [ + { + C = "US"; + L = "San Francisco"; + O = "Internet Widgets, LLC"; + OU = "Certificate Authority"; + ST = "California"; + } + ]; + } + ) + } | ${pkgs.cfssl}/bin/cfssljson -bare ca ''; - onlySSL = true; - serverName = host; - root = pkgs.writeTextDir "index.html" "It works!"; }; - }) [ "imp.example.org" "decl.example.org" ]); - }; - systemd.services.nginx.wantedBy = lib.mkForce []; + services.nginx = { + enable = true; + virtualHosts = lib.mkMerge ( + map + (host: { + ${host} = { + sslCertificate = "/var/ssl/${host}-cert.pem"; + sslCertificateKey = "/var/ssl/${host}-key.pem"; + extraConfig = '' + ssl_protocols TLSv1 TLSv1.1 TLSv1.2; + ''; + onlySSL = true; + serverName = host; + root = pkgs.writeTextDir "index.html" "It works!"; + }; + }) + [ + "imp.example.org" + "decl.example.org" + ] + ); + }; - systemd.services.certmgr.after = [ "cfssl.service" ]; - services.certmgr = { - enable = true; - inherit svcManager; - inherit specs; - }; + systemd.services.nginx.wantedBy = lib.mkForce [ ]; + systemd.services.certmgr.after = [ "cfssl.service" ]; + services.certmgr = { + enable = true; + inherit svcManager; + inherit specs; + }; + + }; }; + inherit testScript; }; - inherit testScript; - }; in { systemd = mkCertmgrTest { svcManager = "systemd"; specs = { - decl = mkSpec { host = "decl.example.org"; service = "nginx"; action ="restart"; }; - imp = toString (pkgs.writeText "test.json" (builtins.toJSON ( - mkSpec { host = "imp.example.org"; service = "nginx"; action = "restart"; } - ))); + decl = mkSpec { + host = "decl.example.org"; + service = "nginx"; + action = "restart"; + }; + imp = toString ( + pkgs.writeText "test.json" ( + builtins.toJSON (mkSpec { + host = "imp.example.org"; + service = "nginx"; + action = "restart"; + }) + ) + ); }; testScript = '' machine.wait_for_unit("cfssl.service") @@ -144,7 +196,10 @@ in command = mkCertmgrTest { svcManager = "command"; specs = { - test = mkSpec { host = "command.example.org"; action = "touch /tmp/command.executed"; }; + test = mkSpec { + host = "command.example.org"; + action = "touch /tmp/command.executed"; + }; }; testScript = '' machine.wait_for_unit("cfssl.service") diff --git a/nixos/tests/cfssl.nix b/nixos/tests/cfssl.nix index e673df3131f8e7..fa81a241f812d6 100644 --- a/nixos/tests/cfssl.nix +++ b/nixos/tests/cfssl.nix @@ -1,67 +1,89 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "cfssl"; - - nodes.machine = { config, lib, pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: { - networking.firewall.allowedTCPPorts = [ config.services.cfssl.port ]; + name = "cfssl"; + + nodes.machine = + { + config, + lib, + pkgs, + ... + }: + { + networking.firewall.allowedTCPPorts = [ config.services.cfssl.port ]; - services.cfssl.enable = true; - systemd.services.cfssl.after = [ "cfssl-init.service" ]; + services.cfssl.enable = true; + systemd.services.cfssl.after = [ "cfssl-init.service" ]; - systemd.services.cfssl-init = { - description = "Initialize the cfssl CA"; - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - User = "cfssl"; - Type = "oneshot"; - WorkingDirectory = config.services.cfssl.dataDir; + systemd.services.cfssl-init = { + description = "Initialize the cfssl CA"; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + User = "cfssl"; + Type = "oneshot"; + WorkingDirectory = config.services.cfssl.dataDir; + }; + script = with pkgs; '' + ${cfssl}/bin/cfssl genkey -initca ${ + pkgs.writeText "ca.json" ( + builtins.toJSON { + hosts = [ "ca.example.com" ]; + key = { + algo = "rsa"; + size = 4096; + }; + names = [ + { + C = "US"; + L = "San Francisco"; + O = "Internet Widgets, LLC"; + OU = "Certificate Authority"; + ST = "California"; + } + ]; + } + ) + } | ${cfssl}/bin/cfssljson -bare ca + ''; + }; }; - script = with pkgs; '' - ${cfssl}/bin/cfssl genkey -initca ${pkgs.writeText "ca.json" (builtins.toJSON { - hosts = [ "ca.example.com" ]; - key = { - algo = "rsa"; size = 4096; }; + + testScript = + let + cfsslrequest = + with pkgs; + writeScript "cfsslrequest" '' + curl -f -X POST -H "Content-Type: application/json" -d @${csr} \ + http://localhost:8888/api/v1/cfssl/newkey | ${cfssl}/bin/cfssljson /tmp/certificate + ''; + csr = pkgs.writeText "csr.json" ( + builtins.toJSON { + CN = "www.example.com"; + hosts = [ + "example.com" + "www.example.com" + ]; + key = { + algo = "rsa"; + size = 2048; + }; names = [ { C = "US"; L = "San Francisco"; - O = "Internet Widgets, LLC"; - OU = "Certificate Authority"; + O = "Example Company, LLC"; + OU = "Operations"; ST = "California"; } ]; - })} | ${cfssl}/bin/cfssljson -bare ca + } + ); + in + '' + machine.wait_for_unit("cfssl.service") + machine.wait_until_succeeds("${cfsslrequest}") + machine.succeed("ls /tmp/certificate-key.pem") ''; - }; - }; - - testScript = - let - cfsslrequest = with pkgs; writeScript "cfsslrequest" '' - curl -f -X POST -H "Content-Type: application/json" -d @${csr} \ - http://localhost:8888/api/v1/cfssl/newkey | ${cfssl}/bin/cfssljson /tmp/certificate - ''; - csr = pkgs.writeText "csr.json" (builtins.toJSON { - CN = "www.example.com"; - hosts = [ "example.com" "www.example.com" ]; - key = { - algo = "rsa"; - size = 2048; - }; - names = [ - { - C = "US"; - L = "San Francisco"; - O = "Example Company, LLC"; - OU = "Operations"; - ST = "California"; - } - ]; - }); - in - '' - machine.wait_for_unit("cfssl.service") - machine.wait_until_succeeds("${cfsslrequest}") - machine.succeed("ls /tmp/certificate-key.pem") - ''; -}) + } +) diff --git a/nixos/tests/cgit.nix b/nixos/tests/cgit.nix index 073b141b14e73d..fce3dc16b854ee 100644 --- a/nixos/tests/cgit.nix +++ b/nixos/tests/cgit.nix @@ -1,103 +1,113 @@ -import ./make-test-python.nix ({ pkgs, ... }: -let - robotsTxt = pkgs.writeText "cgit-robots.txt" '' - User-agent: * - Disallow: / - ''; -in { - name = "cgit"; - meta = with pkgs.lib.maintainers; { - maintainers = [ schnusch ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + let + robotsTxt = pkgs.writeText "cgit-robots.txt" '' + User-agent: * + Disallow: / + ''; + in + { + name = "cgit"; + meta = with pkgs.lib.maintainers; { + maintainers = [ schnusch ]; + }; - nodes = { - server = { ... }: { - services.cgit."localhost" = { - enable = true; - package = pkgs.cgit.overrideAttrs ({ postInstall, ... }: { - postInstall = '' - ${postInstall} - cp ${robotsTxt} "$out/cgit/robots.txt" - ''; - }); - nginx.location = "/(c)git/"; - repos = { - some-repo = { - path = "/tmp/git/some-repo"; - desc = "some-repo description"; + nodes = { + server = + { ... }: + { + services.cgit."localhost" = { + enable = true; + package = pkgs.cgit.overrideAttrs ( + { postInstall, ... }: + { + postInstall = '' + ${postInstall} + cp ${robotsTxt} "$out/cgit/robots.txt" + ''; + } + ); + nginx.location = "/(c)git/"; + repos = { + some-repo = { + path = "/tmp/git/some-repo"; + desc = "some-repo description"; + }; + }; + settings = { + readme = [ + ":README.md" + ":date.txt" + ]; + }; }; - }; - settings = { - readme = [ - ":README.md" - ":date.txt" - ]; - }; - }; - environment.systemPackages = [ pkgs.git ]; + environment.systemPackages = [ pkgs.git ]; + }; }; - }; - testScript = { nodes, ... }: '' - start_all() + testScript = + { nodes, ... }: + '' + start_all() - server.wait_for_unit("nginx.service") - server.wait_for_unit("network.target") - server.wait_for_open_port(80) + server.wait_for_unit("nginx.service") + server.wait_for_unit("network.target") + server.wait_for_open_port(80) - server.succeed("curl -fsS http://localhost/%28c%29git/cgit.css") + server.succeed("curl -fsS http://localhost/%28c%29git/cgit.css") - server.succeed("curl -fsS http://localhost/%28c%29git/robots.txt | diff -u - ${robotsTxt}") + server.succeed("curl -fsS http://localhost/%28c%29git/robots.txt | diff -u - ${robotsTxt}") - server.succeed( - "curl -fsS http://localhost/%28c%29git/ | grep -F 'some-repo description'" - ) + server.succeed( + "curl -fsS http://localhost/%28c%29git/ | grep -F 'some-repo description'" + ) - server.fail("curl -fsS http://localhost/robots.txt") + server.fail("curl -fsS http://localhost/robots.txt") - server.succeed("sudo -u cgit ${pkgs.writeShellScript "setup-cgit-test-repo" '' - set -e - git init --bare -b master /tmp/git/some-repo - git init -b master reference - cd reference - git remote add origin /tmp/git/some-repo - { echo -n "cgit NixOS Test at "; date; } > date.txt - git add date.txt - git -c user.name=test -c user.email=test@localhost commit -m 'add date' - git push -u origin master - ''}") + server.succeed("sudo -u cgit ${pkgs.writeShellScript "setup-cgit-test-repo" '' + set -e + git init --bare -b master /tmp/git/some-repo + git init -b master reference + cd reference + git remote add origin /tmp/git/some-repo + { echo -n "cgit NixOS Test at "; date; } > date.txt + git add date.txt + git -c user.name=test -c user.email=test@localhost commit -m 'add date' + git push -u origin master + ''}") - # test web download - server.succeed( - "curl -fsS 'http://localhost/%28c%29git/some-repo/plain/date.txt?id=master' | diff -u reference/date.txt -" - ) + # test web download + server.succeed( + "curl -fsS 'http://localhost/%28c%29git/some-repo/plain/date.txt?id=master' | diff -u reference/date.txt -" + ) - # test http clone - server.succeed( - "git clone http://localhost/%28c%29git/some-repo && diff -u reference/date.txt some-repo/date.txt" - ) + # test http clone + server.succeed( + "git clone http://localhost/%28c%29git/some-repo && diff -u reference/date.txt some-repo/date.txt" + ) - # test list settings by greping for the fallback readme - server.succeed( - "curl -fsS 'http://localhost/%28c%29git/some-repo/about/' | grep -F 'cgit NixOS Test at'" - ) + # test list settings by greping for the fallback readme + server.succeed( + "curl -fsS 'http://localhost/%28c%29git/some-repo/about/' | grep -F 'cgit NixOS Test at'" + ) - # add real readme - server.succeed("sudo -u cgit ${pkgs.writeShellScript "cgit-commit-readme" '' - set -e - echo '# cgit NixOS test README' > reference/README.md - git -C reference add README.md - git -C reference -c user.name=test -c user.email=test@localhost commit -m 'add readme' - git -C reference push - ''}") + # add real readme + server.succeed("sudo -u cgit ${pkgs.writeShellScript "cgit-commit-readme" '' + set -e + echo '# cgit NixOS test README' > reference/README.md + git -C reference add README.md + git -C reference -c user.name=test -c user.email=test@localhost commit -m 'add readme' + git -C reference push + ''}") - # test list settings by greping for the real readme - server.succeed( - "curl -fsS 'http://localhost/%28c%29git/some-repo/about/' | grep -F '# cgit NixOS test README'" - ) - server.fail( - "curl -fsS 'http://localhost/%28c%29git/some-repo/about/' | grep -F 'cgit NixOS Test at'" - ) - ''; -}) + # test list settings by greping for the real readme + server.succeed( + "curl -fsS 'http://localhost/%28c%29git/some-repo/about/' | grep -F '# cgit NixOS test README'" + ) + server.fail( + "curl -fsS 'http://localhost/%28c%29git/some-repo/about/' | grep -F 'cgit NixOS Test at'" + ) + ''; + } +) diff --git a/nixos/tests/charliecloud.nix b/nixos/tests/charliecloud.nix index 28c3e2f2dbf73d..957ec6ea4374e7 100644 --- a/nixos/tests/charliecloud.nix +++ b/nixos/tests/charliecloud.nix @@ -1,43 +1,49 @@ # This test checks charliecloud image construction and run -import ./make-test-python.nix ({ pkgs, ...} : let +import ./make-test-python.nix ( + { pkgs, ... }: + let - dockerfile = pkgs.writeText "Dockerfile" '' - FROM nix - RUN mkdir /home /tmp - RUN touch /etc/passwd /etc/group - CMD ["true"] - ''; + dockerfile = pkgs.writeText "Dockerfile" '' + FROM nix + RUN mkdir /home /tmp + RUN touch /etc/passwd /etc/group + CMD ["true"] + ''; -in { - name = "charliecloud"; - meta = with pkgs.lib.maintainers; { - maintainers = [ bzizou ]; - }; + in + { + name = "charliecloud"; + meta = with pkgs.lib.maintainers; { + maintainers = [ bzizou ]; + }; - nodes = { - host = { ... }: { - environment.systemPackages = [ pkgs.charliecloud ]; - virtualisation.docker.enable = true; - users.users.alice = { - isNormalUser = true; - extraGroups = [ "docker" ]; - }; + nodes = { + host = + { ... }: + { + environment.systemPackages = [ pkgs.charliecloud ]; + virtualisation.docker.enable = true; + users.users.alice = { + isNormalUser = true; + extraGroups = [ "docker" ]; + }; + }; }; - }; - testScript = '' - host.start() - host.wait_for_unit("docker.service") - host.succeed( - 'su - alice -c "docker load --input=${pkgs.dockerTools.examples.nix}"' - ) - host.succeed( - "cp ${dockerfile} /home/alice/Dockerfile" - ) - host.succeed('su - alice -c "ch-build -t hello ."') - host.succeed('su - alice -c "ch-builder2tar hello /var/tmp"') - host.succeed('su - alice -c "ch-tar2dir /var/tmp/hello.tar.gz /var/tmp"') - host.succeed('su - alice -c "ch-run /var/tmp/hello -- echo Running_From_Container_OK"') - ''; -}) + testScript = '' + host.start() + host.wait_for_unit("docker.service") + host.succeed( + 'su - alice -c "docker load --input=${pkgs.dockerTools.examples.nix}"' + ) + host.succeed( + "cp ${dockerfile} /home/alice/Dockerfile" + ) + host.succeed('su - alice -c "ch-build -t hello ."') + host.succeed('su - alice -c "ch-builder2tar hello /var/tmp"') + host.succeed('su - alice -c "ch-tar2dir /var/tmp/hello.tar.gz /var/tmp"') + host.succeed('su - alice -c "ch-run /var/tmp/hello -- echo Running_From_Container_OK"') + ''; + } +) diff --git a/nixos/tests/chromium.nix b/nixos/tests/chromium.nix index cdfdcc9bcdd2dd..f7192ca228d02b 100644 --- a/nixos/tests/chromium.nix +++ b/nixos/tests/chromium.nix @@ -1,15 +1,17 @@ -{ system ? builtins.currentSystem -, config ? {} -, pkgs ? import ../.. { inherit system config; } -, channelMap ? { # Maps "channels" to packages - stable = pkgs.chromium; - beta = pkgs.chromiumBeta; - dev = pkgs.chromiumDev; - ungoogled = pkgs.ungoogled-chromium; +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, + channelMap ? { + # Maps "channels" to packages + stable = pkgs.chromium; + beta = pkgs.chromiumBeta; + dev = pkgs.chromiumDev; + ungoogled = pkgs.ungoogled-chromium; chrome-stable = pkgs.google-chrome; - chrome-beta = pkgs.google-chrome-beta; - chrome-dev = pkgs.google-chrome-dev; - } + chrome-beta = pkgs.google-chrome-beta; + chrome-dev = pkgs.google-chrome-dev; + }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -26,244 +28,264 @@ let Chromium startup notifier - + ''; in -mapAttrs (channel: chromiumPkg: makeTest { - name = "chromium-${channel}"; - meta = { - maintainers = with maintainers; [ aszlig primeos ]; - } // optionalAttrs (chromiumPkg.meta ? timeout) { - # https://github.com/NixOS/hydra/issues/591#issuecomment-435125621 - # Note: optionalAttrs is used since meta.timeout is not set for Google Chrome - inherit (chromiumPkg.meta) timeout; - }; - - enableOCR = true; - - nodes.machine = { ... }: { - imports = [ ./common/user-account.nix ./common/x11.nix ]; - virtualisation.memorySize = 2047; - test-support.displayManager.auto.user = user; - environment = { - systemPackages = [ chromiumPkg ]; - variables."XAUTHORITY" = "/home/alice/.Xauthority"; - }; - }; - - testScript = let - xdo = name: text: let - xdoScript = pkgs.writeText "${name}.xdo" text; - in "${pkgs.xdotool}/bin/xdotool ${xdoScript}"; - in '' - import shlex - import re - from contextlib import contextmanager - - - major_version = "${versions.major (getVersion chromiumPkg.name)}" - - - # Run as user alice - def ru(cmd): - return "su - ${user} -c " + shlex.quote(cmd) - - - def launch_browser(): - """Launches the web browser with the correct options.""" - # Determine the name of the binary: - pname = "${getName chromiumPkg.name}" - if pname.find("chromium") != -1: - binary = "chromium" # Same name for all channels and ungoogled-chromium - elif pname == "google-chrome": - binary = "google-chrome-stable" - elif pname == "google-chrome-dev": - binary = "google-chrome-unstable" - else: # For google-chrome-beta and as fallback: - binary = pname - # Add optional CLI options: - options = [] - if major_version > "95" and not pname.startswith("google-chrome"): - # Workaround to avoid a GPU crash: - options.append("--use-gl=swiftshader") - # Launch the process: - options.append("file://${startupHTML}") - machine.succeed(ru(f'ulimit -c unlimited; {binary} {shlex.join(options)} >&2 & disown')) - if binary.startswith("google-chrome"): - # Need to click away the first window: - machine.wait_for_text("Make Google Chrome the default browser") - machine.screenshot("google_chrome_default_browser_prompt") - machine.send_key("ret") - - - def create_new_win(): - """Creates a new Chromium window.""" - with machine.nested("Creating a new Chromium window"): +mapAttrs ( + channel: chromiumPkg: + makeTest { + name = "chromium-${channel}"; + meta = + { + maintainers = with maintainers; [ + aszlig + primeos + ]; + } + // optionalAttrs (chromiumPkg.meta ? timeout) { + # https://github.com/NixOS/hydra/issues/591#issuecomment-435125621 + # Note: optionalAttrs is used since meta.timeout is not set for Google Chrome + inherit (chromiumPkg.meta) timeout; + }; + + enableOCR = true; + + nodes.machine = + { ... }: + { + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; + virtualisation.memorySize = 2047; + test-support.displayManager.auto.user = user; + environment = { + systemPackages = [ chromiumPkg ]; + variables."XAUTHORITY" = "/home/alice/.Xauthority"; + }; + }; + + testScript = + let + xdo = + name: text: + let + xdoScript = pkgs.writeText "${name}.xdo" text; + in + "${pkgs.xdotool}/bin/xdotool ${xdoScript}"; + in + '' + import shlex + import re + from contextlib import contextmanager + + + major_version = "${versions.major (getVersion chromiumPkg.name)}" + + + # Run as user alice + def ru(cmd): + return "su - ${user} -c " + shlex.quote(cmd) + + + def launch_browser(): + """Launches the web browser with the correct options.""" + # Determine the name of the binary: + pname = "${getName chromiumPkg.name}" + if pname.find("chromium") != -1: + binary = "chromium" # Same name for all channels and ungoogled-chromium + elif pname == "google-chrome": + binary = "google-chrome-stable" + elif pname == "google-chrome-dev": + binary = "google-chrome-unstable" + else: # For google-chrome-beta and as fallback: + binary = pname + # Add optional CLI options: + options = [] + if major_version > "95" and not pname.startswith("google-chrome"): + # Workaround to avoid a GPU crash: + options.append("--use-gl=swiftshader") + # Launch the process: + options.append("file://${startupHTML}") + machine.succeed(ru(f'ulimit -c unlimited; {binary} {shlex.join(options)} >&2 & disown')) + if binary.startswith("google-chrome"): + # Need to click away the first window: + machine.wait_for_text("Make Google Chrome the default browser") + machine.screenshot("google_chrome_default_browser_prompt") + machine.send_key("ret") + + + def create_new_win(): + """Creates a new Chromium window.""" + with machine.nested("Creating a new Chromium window"): + machine.wait_until_succeeds( + ru( + "${xdo "create_new_win-select_main_window" '' + search --onlyvisible --name "startup done" + windowfocus --sync + windowactivate --sync + ''}" + ) + ) + machine.send_key("ctrl-n") + # Wait until the new window appears: + machine.wait_until_succeeds( + ru( + "${xdo "create_new_win-wait_for_window" '' + search --onlyvisible --name "New Tab" + windowfocus --sync + windowactivate --sync + ''}" + ) + ) + + + def close_new_tab_win(): + """Closes the Chromium window with the title "New Tab".""" machine.wait_until_succeeds( ru( - "${xdo "create_new_win-select_main_window" '' - search --onlyvisible --name "startup done" + "${xdo "close_new_tab_win-select_main_window" '' + search --onlyvisible --name "New Tab" windowfocus --sync windowactivate --sync ''}" ) ) - machine.send_key("ctrl-n") - # Wait until the new window appears: - machine.wait_until_succeeds( + machine.send_key("ctrl-w") + # Wait until the closed window disappears: + machine.wait_until_fails( ru( - "${xdo "create_new_win-wait_for_window" '' + "${xdo "close_new_tab_win-wait_for_close" '' search --onlyvisible --name "New Tab" - windowfocus --sync - windowactivate --sync ''}" ) ) - def close_new_tab_win(): - """Closes the Chromium window with the title "New Tab".""" + @contextmanager + def test_new_win(description, url, window_name): + create_new_win() + machine.wait_for_window("New Tab") + machine.send_chars(f"{url}\n") + machine.wait_for_window(window_name) + machine.screenshot(description) + machine.succeed( + ru( + "${xdo "copy-all" '' + key --delay 1000 Ctrl+a Ctrl+c + ''}" + ) + ) + clipboard = machine.succeed( + ru("${pkgs.xclip}/bin/xclip -o") + ) + if url == "chrome://gpu": + clipboard = "" # TODO: We cannot copy the text via Ctrl+a + print(f"{description} window content:\n{clipboard}") + with machine.nested(description): + yield clipboard + # Close the newly created window: + machine.send_key("ctrl-w") + + + machine.wait_for_x() + + launch_browser() + + machine.wait_for_text("startup done") machine.wait_until_succeeds( ru( - "${xdo "close_new_tab_win-select_main_window" '' - search --onlyvisible --name "New Tab" + "${xdo "check-startup" '' + search --sync --onlyvisible --name "startup done" + # close first start help popup + key -delay 1000 Escape windowfocus --sync windowactivate --sync ''}" ) ) - machine.send_key("ctrl-w") - # Wait until the closed window disappears: - machine.wait_until_fails( - ru( - "${xdo "close_new_tab_win-wait_for_close" '' - search --onlyvisible --name "New Tab" - ''}" - ) - ) - - @contextmanager - def test_new_win(description, url, window_name): create_new_win() - machine.wait_for_window("New Tab") - machine.send_chars(f"{url}\n") - machine.wait_for_window(window_name) - machine.screenshot(description) - machine.succeed( - ru( - "${xdo "copy-all" '' - key --delay 1000 Ctrl+a Ctrl+c - ''}" - ) - ) - clipboard = machine.succeed( - ru("${pkgs.xclip}/bin/xclip -o") - ) - if url == "chrome://gpu": - clipboard = "" # TODO: We cannot copy the text via Ctrl+a - print(f"{description} window content:\n{clipboard}") - with machine.nested(description): - yield clipboard - # Close the newly created window: - machine.send_key("ctrl-w") - - - machine.wait_for_x() - - launch_browser() - - machine.wait_for_text("startup done") - machine.wait_until_succeeds( - ru( - "${xdo "check-startup" '' - search --sync --onlyvisible --name "startup done" - # close first start help popup - key -delay 1000 Escape - windowfocus --sync - windowactivate --sync - ''}" - ) - ) - - create_new_win() - # Optional: Wait for the new tab page to fully load before taking the screenshot: - machine.wait_for_text("Web Store") - machine.screenshot("empty_windows") - close_new_tab_win() - - machine.screenshot("startup_done") - - with test_new_win("sandbox_info", "chrome://sandbox", "Sandbox Status") as clipboard: - filters = [ - "layer 1 sandbox.*namespace", - "pid namespaces.*yes", - "network namespaces.*yes", - "seccomp.*sandbox.*yes", - "you are adequately sandboxed", - ] - if not all( - re.search(filter, clipboard, flags=re.DOTALL | re.IGNORECASE) - for filter in filters - ): - assert False, f"sandbox not working properly: {clipboard}" - - machine.sleep(1) - machine.succeed( - ru( - "${xdo "find-window-after-copy" '' - search --onlyvisible --name "Sandbox Status" - ''}" + # Optional: Wait for the new tab page to fully load before taking the screenshot: + machine.wait_for_text("Web Store") + machine.screenshot("empty_windows") + close_new_tab_win() + + machine.screenshot("startup_done") + + with test_new_win("sandbox_info", "chrome://sandbox", "Sandbox Status") as clipboard: + filters = [ + "layer 1 sandbox.*namespace", + "pid namespaces.*yes", + "network namespaces.*yes", + "seccomp.*sandbox.*yes", + "you are adequately sandboxed", + ] + if not all( + re.search(filter, clipboard, flags=re.DOTALL | re.IGNORECASE) + for filter in filters + ): + assert False, f"sandbox not working properly: {clipboard}" + + machine.sleep(1) + machine.succeed( + ru( + "${xdo "find-window-after-copy" '' + search --onlyvisible --name "Sandbox Status" + ''}" + ) ) - ) - clipboard = machine.succeed( - ru( - "echo void | ${pkgs.xclip}/bin/xclip -i >&2" + clipboard = machine.succeed( + ru( + "echo void | ${pkgs.xclip}/bin/xclip -i >&2" + ) ) - ) - machine.succeed( - ru( - "${xdo "copy-sandbox-info" '' - key --delay 1000 Ctrl+a Ctrl+c - ''}" + machine.succeed( + ru( + "${xdo "copy-sandbox-info" '' + key --delay 1000 Ctrl+a Ctrl+c + ''}" + ) ) - ) - clipboard = machine.succeed( - ru("${pkgs.xclip}/bin/xclip -o") - ) - if not all( - re.search(filter, clipboard, flags=re.DOTALL | re.IGNORECASE) - for filter in filters - ): - assert False, f"copying twice in a row does not work properly: {clipboard}" + clipboard = machine.succeed( + ru("${pkgs.xclip}/bin/xclip -o") + ) + if not all( + re.search(filter, clipboard, flags=re.DOTALL | re.IGNORECASE) + for filter in filters + ): + assert False, f"copying twice in a row does not work properly: {clipboard}" - machine.screenshot("after_copy_from_chromium") + machine.screenshot("after_copy_from_chromium") - with test_new_win("gpu_info", "chrome://gpu", "GPU Internals"): - # To check the text rendering (catches regressions like #131074): - machine.wait_for_text("Graphics Feature Status") - # TODO: Fix copying all of the text to the clipboard + with test_new_win("gpu_info", "chrome://gpu", "GPU Internals"): + # To check the text rendering (catches regressions like #131074): + machine.wait_for_text("Graphics Feature Status") + # TODO: Fix copying all of the text to the clipboard - with test_new_win("version_info", "chrome://version", "About Version") as clipboard: - filters = [ - r"${chromiumPkg.version} \(Official Build", - ] - if not all( - re.search(filter, clipboard) for filter in filters - ): - assert False, "Version info not correct." + with test_new_win("version_info", "chrome://version", "About Version") as clipboard: + filters = [ + r"${chromiumPkg.version} \(Official Build", + ] + if not all( + re.search(filter, clipboard) for filter in filters + ): + assert False, "Version info not correct." - machine.shutdown() - ''; -}) channelMap + machine.shutdown() + ''; + } +) channelMap diff --git a/nixos/tests/chrony-ptp.nix b/nixos/tests/chrony-ptp.nix index b2634a8cfc5c6f..f4e23e61b0a3c0 100644 --- a/nixos/tests/chrony-ptp.nix +++ b/nixos/tests/chrony-ptp.nix @@ -1,28 +1,32 @@ -import ./make-test-python.nix ({ lib, ... }: -{ - name = "chrony-ptp"; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "chrony-ptp"; - meta = { - maintainers = with lib.maintainers; [ gkleen ]; - }; + meta = { + maintainers = with lib.maintainers; [ gkleen ]; + }; - nodes = { - qemuGuest = { lib, ... }: { - boot.kernelModules = [ "ptp_kvm" ]; + nodes = { + qemuGuest = + { lib, ... }: + { + boot.kernelModules = [ "ptp_kvm" ]; - services.chrony = { - enable = true; - extraConfig = '' - refclock PHC /dev/ptp_kvm poll 2 dpoll -2 offset 0 stratum 3 - ''; - }; + services.chrony = { + enable = true; + extraConfig = '' + refclock PHC /dev/ptp_kvm poll 2 dpoll -2 offset 0 stratum 3 + ''; + }; + }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - qemuGuest.wait_for_unit('multi-user.target') - qemuGuest.succeed('systemctl is-active chronyd.service') - ''; -}) + qemuGuest.wait_for_unit('multi-user.target') + qemuGuest.succeed('systemctl is-active chronyd.service') + ''; + } +) diff --git a/nixos/tests/chrony.nix b/nixos/tests/chrony.nix index 9582ab14bb8f12..e3999596fd225a 100644 --- a/nixos/tests/chrony.nix +++ b/nixos/tests/chrony.nix @@ -1,28 +1,30 @@ -import ./make-test-python.nix ({ lib, ... }: -{ - name = "chrony"; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "chrony"; - meta = { - maintainers = with lib.maintainers; [ fpletz ]; - }; + meta = { + maintainers = with lib.maintainers; [ fpletz ]; + }; - nodes = { - machine = { - services.chrony.enable = true; + nodes = { + machine = { + services.chrony.enable = true; - specialisation.hardened.configuration = { - services.chrony.enableMemoryLocking = true; - environment.memoryAllocator.provider = "graphene-hardened"; + specialisation.hardened.configuration = { + services.chrony.enableMemoryLocking = true; + environment.memoryAllocator.provider = "graphene-hardened"; + }; }; }; - }; - testScript = '' - machine.start() - machine.wait_for_unit('multi-user.target') - machine.succeed('systemctl is-active chronyd.service') - machine.succeed('/run/booted-system/specialisation/hardened/bin/switch-to-configuration test') - machine.succeed('systemctl restart chronyd.service') - machine.wait_for_unit('chronyd.service') - ''; -}) + testScript = '' + machine.start() + machine.wait_for_unit('multi-user.target') + machine.succeed('systemctl is-active chronyd.service') + machine.succeed('/run/booted-system/specialisation/hardened/bin/switch-to-configuration test') + machine.succeed('systemctl restart chronyd.service') + machine.wait_for_unit('chronyd.service') + ''; + } +) diff --git a/nixos/tests/cinnamon-wayland.nix b/nixos/tests/cinnamon-wayland.nix index cba0c9f60e8db7..1b472f863099f7 100644 --- a/nixos/tests/cinnamon-wayland.nix +++ b/nixos/tests/cinnamon-wayland.nix @@ -1,77 +1,84 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "cinnamon-wayland"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "cinnamon-wayland"; - meta.maintainers = lib.teams.cinnamon.members; + meta.maintainers = lib.teams.cinnamon.members; - nodes.machine = { nodes, ... }: { - imports = [ ./common/user-account.nix ]; - services.xserver.enable = true; - services.xserver.desktopManager.cinnamon.enable = true; - services.displayManager = { - autoLogin.enable = true; - autoLogin.user = nodes.machine.users.users.alice.name; - defaultSession = "cinnamon-wayland"; - }; + nodes.machine = + { nodes, ... }: + { + imports = [ ./common/user-account.nix ]; + services.xserver.enable = true; + services.xserver.desktopManager.cinnamon.enable = true; + services.displayManager = { + autoLogin.enable = true; + autoLogin.user = nodes.machine.users.users.alice.name; + defaultSession = "cinnamon-wayland"; + }; - # For the sessionPath subtest. - services.xserver.desktopManager.cinnamon.sessionPath = [ pkgs.gpaste ]; - }; + # For the sessionPath subtest. + services.xserver.desktopManager.cinnamon.sessionPath = [ pkgs.gpaste ]; + }; - enableOCR = true; + enableOCR = true; - testScript = { nodes, ... }: - let - user = nodes.machine.users.users.alice; - env = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${toString user.uid}/bus"; - su = command: "su - ${user.name} -c '${env} ${command}'"; + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + env = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${toString user.uid}/bus"; + su = command: "su - ${user.name} -c '${env} ${command}'"; - # Call javascript in cinnamon (the shell), returns a tuple (success, output), - # where `success` is true if the dbus call was successful and `output` is what - # the javascript evaluates to. - eval = name: su "gdbus call --session -d org.Cinnamon -o /org/Cinnamon -m org.Cinnamon.Eval ${name}"; - in - '' - machine.wait_for_unit("display-manager.service") + # Call javascript in cinnamon (the shell), returns a tuple (success, output), + # where `success` is true if the dbus call was successful and `output` is what + # the javascript evaluates to. + eval = + name: su "gdbus call --session -d org.Cinnamon -o /org/Cinnamon -m org.Cinnamon.Eval ${name}"; + in + '' + machine.wait_for_unit("display-manager.service") - with subtest("Wait for wayland server"): - machine.wait_for_file("/run/user/${toString user.uid}/wayland-0") + with subtest("Wait for wayland server"): + machine.wait_for_file("/run/user/${toString user.uid}/wayland-0") - with subtest("Check that logging in has given the user ownership of devices"): - machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") + with subtest("Check that logging in has given the user ownership of devices"): + machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") - with subtest("Wait for the Cinnamon shell"): - # Correct output should be (true, '2') - # https://github.com/linuxmint/cinnamon/blob/5.4.0/js/ui/main.js#L183-L187 - machine.wait_until_succeeds("${eval "Main.runState"} | grep -q 'true,..2'") + with subtest("Wait for the Cinnamon shell"): + # Correct output should be (true, '2') + # https://github.com/linuxmint/cinnamon/blob/5.4.0/js/ui/main.js#L183-L187 + machine.wait_until_succeeds("${eval "Main.runState"} | grep -q 'true,..2'") - with subtest("Check if Cinnamon components actually start"): - for i in ["csd-media-keys", "xapp-sn-watcher", "nemo-desktop"]: - machine.wait_until_succeeds(f"pgrep -f {i}") - machine.wait_until_succeeds("journalctl -b --grep 'Loaded applet menu@cinnamon.org'") - machine.wait_until_succeeds("journalctl -b --grep 'calendar@cinnamon.org: Calendar events supported'") + with subtest("Check if Cinnamon components actually start"): + for i in ["csd-media-keys", "xapp-sn-watcher", "nemo-desktop"]: + machine.wait_until_succeeds(f"pgrep -f {i}") + machine.wait_until_succeeds("journalctl -b --grep 'Loaded applet menu@cinnamon.org'") + machine.wait_until_succeeds("journalctl -b --grep 'calendar@cinnamon.org: Calendar events supported'") - with subtest("Check if sessionPath option actually works"): - machine.succeed("${eval "imports.gi.GIRepository.Repository.get_search_path\\(\\)"} | grep gpaste") + with subtest("Check if sessionPath option actually works"): + machine.succeed("${eval "imports.gi.GIRepository.Repository.get_search_path\\(\\)"} | grep gpaste") - with subtest("Open Cinnamon Settings"): - machine.succeed("${su "cinnamon-settings themes >&2 &"}") - machine.wait_until_succeeds("${eval "global.display.focus_window.wm_class"} | grep -i 'cinnamon-settings'") - machine.wait_for_text('(Style|Appearance|Color)') - machine.sleep(2) - machine.screenshot("cinnamon_settings") + with subtest("Open Cinnamon Settings"): + machine.succeed("${su "cinnamon-settings themes >&2 &"}") + machine.wait_until_succeeds("${eval "global.display.focus_window.wm_class"} | grep -i 'cinnamon-settings'") + machine.wait_for_text('(Style|Appearance|Color)') + machine.sleep(2) + machine.screenshot("cinnamon_settings") - with subtest("Check if screensaver works"): - # This is not supported at the moment. - # https://trello.com/b/HHs01Pab/cinnamon-wayland - machine.execute("${su "cinnamon-screensaver-command -l >&2 &"}") - machine.wait_until_succeeds("journalctl -b --grep 'cinnamon-screensaver is disabled in wayland sessions'") + with subtest("Check if screensaver works"): + # This is not supported at the moment. + # https://trello.com/b/HHs01Pab/cinnamon-wayland + machine.execute("${su "cinnamon-screensaver-command -l >&2 &"}") + machine.wait_until_succeeds("journalctl -b --grep 'cinnamon-screensaver is disabled in wayland sessions'") - with subtest("Open GNOME Terminal"): - machine.succeed("${su "dbus-launch gnome-terminal"}") - machine.wait_until_succeeds("${eval "global.display.focus_window.wm_class"} | grep -i 'gnome-terminal'") - machine.sleep(2) + with subtest("Open GNOME Terminal"): + machine.succeed("${su "dbus-launch gnome-terminal"}") + machine.wait_until_succeeds("${eval "global.display.focus_window.wm_class"} | grep -i 'gnome-terminal'") + machine.sleep(2) - with subtest("Check if Cinnamon has ever coredumped"): - machine.fail("coredumpctl --json=short | grep -E 'cinnamon|nemo'") - ''; -}) + with subtest("Check if Cinnamon has ever coredumped"): + machine.fail("coredumpctl --json=short | grep -E 'cinnamon|nemo'") + ''; + } +) diff --git a/nixos/tests/cinnamon.nix b/nixos/tests/cinnamon.nix index 57300c3e4b16bf..e52146568ae59f 100644 --- a/nixos/tests/cinnamon.nix +++ b/nixos/tests/cinnamon.nix @@ -1,92 +1,99 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "cinnamon"; - - meta.maintainers = lib.teams.cinnamon.members; - - nodes.machine = { ... }: { - imports = [ ./common/user-account.nix ]; - services.xserver.enable = true; - services.xserver.desktopManager.cinnamon.enable = true; - - # We don't ship gnome-text-editor in Cinnamon module, we add this line mainly - # to catch eval issues related to this option. - environment.cinnamon.excludePackages = [ pkgs.gnome-text-editor ]; - - # For the sessionPath subtest. - services.xserver.desktopManager.cinnamon.sessionPath = [ pkgs.gpaste ]; - }; - - enableOCR = true; - - testScript = { nodes, ... }: - let - user = nodes.machine.users.users.alice; - env = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${toString user.uid}/bus DISPLAY=:0"; - su = command: "su - ${user.name} -c '${env} ${command}'"; - - # Call javascript in cinnamon (the shell), returns a tuple (success, output), - # where `success` is true if the dbus call was successful and `output` is what - # the javascript evaluates to. - eval = name: su "gdbus call --session -d org.Cinnamon -o /org/Cinnamon -m org.Cinnamon.Eval ${name}"; - in - '' - machine.wait_for_unit("display-manager.service") - - with subtest("Test if we can see username in slick-greeter"): - machine.wait_for_text("${user.description}") - machine.screenshot("slick_greeter_lightdm") - - with subtest("Login with slick-greeter"): - machine.send_chars("${user.password}\n") - machine.wait_for_x() - machine.wait_for_file("${user.home}/.Xauthority") - machine.succeed("xauth merge ${user.home}/.Xauthority") - - with subtest("Check that logging in has given the user ownership of devices"): - machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") - - with subtest("Wait for the Cinnamon shell"): - # Correct output should be (true, '2') - # https://github.com/linuxmint/cinnamon/blob/5.4.0/js/ui/main.js#L183-L187 - machine.wait_until_succeeds("${eval "Main.runState"} | grep -q 'true,..2'") - - with subtest("Check if Cinnamon components actually start"): - for i in ["csd-media-keys", "cinnamon-killer-daemon", "xapp-sn-watcher", "nemo-desktop"]: - machine.wait_until_succeeds(f"pgrep -f {i}") - machine.wait_until_succeeds("journalctl -b --grep 'Loaded applet menu@cinnamon.org'") - machine.wait_until_succeeds("journalctl -b --grep 'calendar@cinnamon.org: Calendar events supported'") - - with subtest("Check if sessionPath option actually works"): - machine.succeed("${eval "imports.gi.GIRepository.Repository.get_search_path\\(\\)"} | grep gpaste") - - with subtest("Open Cinnamon Settings"): - machine.succeed("${su "cinnamon-settings themes >&2 &"}") - machine.wait_until_succeeds("${eval "global.display.focus_window.wm_class"} | grep -i 'cinnamon-settings'") - machine.wait_for_text('(Style|Appearance|Color)') - machine.sleep(2) - machine.screenshot("cinnamon_settings") - - with subtest("Lock the screen"): - machine.succeed("${su "cinnamon-screensaver-command -l >&2 &"}") - machine.wait_until_succeeds("${su "cinnamon-screensaver-command -q"} | grep 'The screensaver is active'") - machine.sleep(2) - machine.screenshot("cinnamon_screensaver") - machine.send_chars("${user.password}\n", delay=0.2) - machine.wait_until_succeeds("${su "cinnamon-screensaver-command -q"} | grep 'The screensaver is inactive'") - machine.sleep(2) - - with subtest("Open GNOME Terminal"): - machine.succeed("${su "gnome-terminal"}") - machine.wait_until_succeeds("${eval "global.display.focus_window.wm_class"} | grep -i 'gnome-terminal'") - machine.sleep(2) - - with subtest("Open virtual keyboard"): - machine.succeed("${su "dbus-send --print-reply --dest=org.Cinnamon /org/Cinnamon org.Cinnamon.ToggleKeyboard"}") - machine.wait_for_text('(Ctrl|Alt)') - machine.sleep(2) - machine.screenshot("cinnamon_virtual_keyboard") - - with subtest("Check if Cinnamon has ever coredumped"): - machine.fail("coredumpctl --json=short | grep -E 'cinnamon|nemo'") - ''; -}) +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "cinnamon"; + + meta.maintainers = lib.teams.cinnamon.members; + + nodes.machine = + { ... }: + { + imports = [ ./common/user-account.nix ]; + services.xserver.enable = true; + services.xserver.desktopManager.cinnamon.enable = true; + + # We don't ship gnome-text-editor in Cinnamon module, we add this line mainly + # to catch eval issues related to this option. + environment.cinnamon.excludePackages = [ pkgs.gnome-text-editor ]; + + # For the sessionPath subtest. + services.xserver.desktopManager.cinnamon.sessionPath = [ pkgs.gpaste ]; + }; + + enableOCR = true; + + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + env = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${toString user.uid}/bus DISPLAY=:0"; + su = command: "su - ${user.name} -c '${env} ${command}'"; + + # Call javascript in cinnamon (the shell), returns a tuple (success, output), + # where `success` is true if the dbus call was successful and `output` is what + # the javascript evaluates to. + eval = + name: su "gdbus call --session -d org.Cinnamon -o /org/Cinnamon -m org.Cinnamon.Eval ${name}"; + in + '' + machine.wait_for_unit("display-manager.service") + + with subtest("Test if we can see username in slick-greeter"): + machine.wait_for_text("${user.description}") + machine.screenshot("slick_greeter_lightdm") + + with subtest("Login with slick-greeter"): + machine.send_chars("${user.password}\n") + machine.wait_for_x() + machine.wait_for_file("${user.home}/.Xauthority") + machine.succeed("xauth merge ${user.home}/.Xauthority") + + with subtest("Check that logging in has given the user ownership of devices"): + machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") + + with subtest("Wait for the Cinnamon shell"): + # Correct output should be (true, '2') + # https://github.com/linuxmint/cinnamon/blob/5.4.0/js/ui/main.js#L183-L187 + machine.wait_until_succeeds("${eval "Main.runState"} | grep -q 'true,..2'") + + with subtest("Check if Cinnamon components actually start"): + for i in ["csd-media-keys", "cinnamon-killer-daemon", "xapp-sn-watcher", "nemo-desktop"]: + machine.wait_until_succeeds(f"pgrep -f {i}") + machine.wait_until_succeeds("journalctl -b --grep 'Loaded applet menu@cinnamon.org'") + machine.wait_until_succeeds("journalctl -b --grep 'calendar@cinnamon.org: Calendar events supported'") + + with subtest("Check if sessionPath option actually works"): + machine.succeed("${eval "imports.gi.GIRepository.Repository.get_search_path\\(\\)"} | grep gpaste") + + with subtest("Open Cinnamon Settings"): + machine.succeed("${su "cinnamon-settings themes >&2 &"}") + machine.wait_until_succeeds("${eval "global.display.focus_window.wm_class"} | grep -i 'cinnamon-settings'") + machine.wait_for_text('(Style|Appearance|Color)') + machine.sleep(2) + machine.screenshot("cinnamon_settings") + + with subtest("Lock the screen"): + machine.succeed("${su "cinnamon-screensaver-command -l >&2 &"}") + machine.wait_until_succeeds("${su "cinnamon-screensaver-command -q"} | grep 'The screensaver is active'") + machine.sleep(2) + machine.screenshot("cinnamon_screensaver") + machine.send_chars("${user.password}\n", delay=0.2) + machine.wait_until_succeeds("${su "cinnamon-screensaver-command -q"} | grep 'The screensaver is inactive'") + machine.sleep(2) + + with subtest("Open GNOME Terminal"): + machine.succeed("${su "gnome-terminal"}") + machine.wait_until_succeeds("${eval "global.display.focus_window.wm_class"} | grep -i 'gnome-terminal'") + machine.sleep(2) + + with subtest("Open virtual keyboard"): + machine.succeed("${su "dbus-send --print-reply --dest=org.Cinnamon /org/Cinnamon org.Cinnamon.ToggleKeyboard"}") + machine.wait_for_text('(Ctrl|Alt)') + machine.sleep(2) + machine.screenshot("cinnamon_virtual_keyboard") + + with subtest("Check if Cinnamon has ever coredumped"): + machine.fail("coredumpctl --json=short | grep -E 'cinnamon|nemo'") + ''; + } +) diff --git a/nixos/tests/cjdns.nix b/nixos/tests/cjdns.nix index dc5f371c74d834..7fdb30a0abe62a 100644 --- a/nixos/tests/cjdns.nix +++ b/nixos/tests/cjdns.nix @@ -5,7 +5,8 @@ let basicConfig = { ... }: - { services.cjdns.enable = true; + { + services.cjdns.enable = true; # Turning off DHCP isn't very realistic but makes # the sequence of address assignment less stochastic. @@ -17,16 +18,20 @@ let in -import ./make-test-python.nix ({ pkgs, ...} : { - name = "cjdns"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ehmry ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "cjdns"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ehmry ]; + }; - nodes = { # Alice finds peers over over ETHInterface. + nodes = { + # Alice finds peers over over ETHInterface. alice = { ... }: - { imports = [ basicConfig ]; + { + imports = [ basicConfig ]; services.cjdns.ETHInterface.bind = "eth1"; @@ -39,28 +44,33 @@ import ./make-test-python.nix ({ pkgs, ...} : { bob = { ... }: - { imports = [ basicConfig ]; + { + imports = [ basicConfig ]; networking.interfaces.eth1.ipv4.addresses = [ - { address = "192.168.0.2"; prefixLength = 24; } + { + address = "192.168.0.2"; + prefixLength = 24; + } ]; - services.cjdns = - { UDPInterface = - { bind = "0.0.0.0:1024"; - connectTo."192.168.0.1:1024" = - { password = carolPassword; - publicKey = carolPubKey; - }; - }; + services.cjdns = { + UDPInterface = { + bind = "0.0.0.0:1024"; + connectTo."192.168.0.1:1024" = { + password = carolPassword; + publicKey = carolPubKey; + }; }; + }; }; # Carol listens on ETHInterface and UDPInterface, # but knows neither Alice or Bob. carol = { ... }: - { imports = [ basicConfig ]; + { + imports = [ basicConfig ]; environment.etc."cjdns.keys".text = '' CJDNS_PRIVATE_KEY=${carolKey} @@ -68,21 +78,23 @@ import ./make-test-python.nix ({ pkgs, ...} : { ''; networking.interfaces.eth1.ipv4.addresses = [ - { address = "192.168.0.1"; prefixLength = 24; } + { + address = "192.168.0.1"; + prefixLength = 24; + } ]; - services.cjdns = - { authorizedPasswords = [ carolPassword ]; - ETHInterface.bind = "eth1"; - UDPInterface.bind = "192.168.0.1:1024"; - }; + services.cjdns = { + authorizedPasswords = [ carolPassword ]; + ETHInterface.bind = "eth1"; + UDPInterface.bind = "192.168.0.1:1024"; + }; networking.firewall.allowedUDPPorts = [ 1024 ]; }; }; - testScript = - '' + testScript = '' import re start_all() @@ -118,4 +130,5 @@ import ./make-test-python.nix ({ pkgs, ...} : { bob.succeed("curl --fail -g http://[{}]".format(alice_ip6)) ''; -}) + } +) diff --git a/nixos/tests/clatd.nix b/nixos/tests/clatd.nix index d0d504851ce4e5..d6aff7c0959526 100644 --- a/nixos/tests/clatd.nix +++ b/nixos/tests/clatd.nix @@ -26,211 +26,229 @@ # | Route: 192.0.2.0/24 via 100.64.0.1 # +------ -import ./make-test-python.nix ({ pkgs, lib, ... }: - -{ - name = "clatd"; - meta = with pkgs.lib.maintainers; { - maintainers = [ hax404 jmbaur ]; - }; - - nodes = { - # The server is configured with static IPv4 addresses. RFC 6052 Section 3.1 - # disallows the mapping of non-global IPv4 addresses like RFC 1918 into the - # Well-Known Prefix 64:ff9b::/96. TAYGA also does not allow the mapping of - # documentation space (RFC 5737). To circumvent this, 100.64.0.2/24 from - # RFC 6589 (Carrier Grade NAT) is used here. - # To reach the IPv4 address pool of the NAT64 gateway, there is a static - # route configured. In normal cases, where the router would also source NAT - # the pool addresses to one IPv4 addresses, this would not be needed. - server = { - virtualisation.vlans = [ - 2 # towards router +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + { + name = "clatd"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + hax404 + jmbaur ]; - networking = { - useDHCP = false; - interfaces.eth1 = lib.mkForce {}; - }; - systemd.network = { - enable = true; - networks."vlan1" = { - matchConfig.Name = "eth1"; - address = [ - "100.64.0.2/24" - ]; - routes = [ - { Destination = "192.0.2.0/24"; Gateway = "100.64.0.1"; } - ]; - }; - }; }; - # The router is configured with static IPv4 addresses towards the server - # and IPv6 addresses towards the client. DNS64 is exposed towards the - # client so clatd is able to auto-discover the PLAT prefix. For NAT64, the - # Well-Known prefix 64:ff9b::/96 is used. NAT64 is done with TAYGA which - # provides the tun-interface nat64 and does the translation over it. The - # IPv6 packets are sent to this interfaces and received as IPv4 packets and - # vice versa. As TAYGA only translates IPv6 addresses to dedicated IPv4 - # addresses, it needs a pool of IPv4 addresses which must be at least as - # big as the expected amount of clients. In this test, the packets from the - # pool are directly routed towards the client. In normal cases, there would - # be a second source NAT44 to map all clients behind one IPv4 address. - router = { - boot.kernel.sysctl = { - "net.ipv4.conf.all.forwarding" = 1; - "net.ipv6.conf.all.forwarding" = 1; + nodes = { + # The server is configured with static IPv4 addresses. RFC 6052 Section 3.1 + # disallows the mapping of non-global IPv4 addresses like RFC 1918 into the + # Well-Known Prefix 64:ff9b::/96. TAYGA also does not allow the mapping of + # documentation space (RFC 5737). To circumvent this, 100.64.0.2/24 from + # RFC 6589 (Carrier Grade NAT) is used here. + # To reach the IPv4 address pool of the NAT64 gateway, there is a static + # route configured. In normal cases, where the router would also source NAT + # the pool addresses to one IPv4 addresses, this would not be needed. + server = { + virtualisation.vlans = [ + 2 # towards router + ]; + networking = { + useDHCP = false; + interfaces.eth1 = lib.mkForce { }; + }; + systemd.network = { + enable = true; + networks."vlan1" = { + matchConfig.Name = "eth1"; + address = [ + "100.64.0.2/24" + ]; + routes = [ + { + Destination = "192.0.2.0/24"; + Gateway = "100.64.0.1"; + } + ]; + }; + }; }; - virtualisation.vlans = [ - 2 # towards server - 3 # towards client - ]; + # The router is configured with static IPv4 addresses towards the server + # and IPv6 addresses towards the client. DNS64 is exposed towards the + # client so clatd is able to auto-discover the PLAT prefix. For NAT64, the + # Well-Known prefix 64:ff9b::/96 is used. NAT64 is done with TAYGA which + # provides the tun-interface nat64 and does the translation over it. The + # IPv6 packets are sent to this interfaces and received as IPv4 packets and + # vice versa. As TAYGA only translates IPv6 addresses to dedicated IPv4 + # addresses, it needs a pool of IPv4 addresses which must be at least as + # big as the expected amount of clients. In this test, the packets from the + # pool are directly routed towards the client. In normal cases, there would + # be a second source NAT44 to map all clients behind one IPv4 address. + router = { + boot.kernel.sysctl = { + "net.ipv4.conf.all.forwarding" = 1; + "net.ipv6.conf.all.forwarding" = 1; + }; - networking = { - useDHCP = false; - useNetworkd = true; - firewall.enable = false; - interfaces.eth1 = lib.mkForce { - ipv4 = { - addresses = [ { address = "100.64.0.1"; prefixLength = 24; } ]; + virtualisation.vlans = [ + 2 # towards server + 3 # towards client + ]; + + networking = { + useDHCP = false; + useNetworkd = true; + firewall.enable = false; + interfaces.eth1 = lib.mkForce { + ipv4 = { + addresses = [ + { + address = "100.64.0.1"; + prefixLength = 24; + } + ]; + }; }; - }; - interfaces.eth2 = lib.mkForce { - ipv6 = { - addresses = [ { address = "2001:db8::1"; prefixLength = 64; } ]; + interfaces.eth2 = lib.mkForce { + ipv6 = { + addresses = [ + { + address = "2001:db8::1"; + prefixLength = 64; + } + ]; + }; }; }; - }; - systemd.network.networks."40-eth2" = { - networkConfig.IPv6SendRA = true; - ipv6Prefixes = [ { Prefix = "2001:db8::/64"; } ]; - ipv6PREF64Prefixes = [ { Prefix = "64:ff9b::/96"; } ]; - ipv6SendRAConfig = { - EmitDNS = true; - DNS = "_link_local"; + systemd.network.networks."40-eth2" = { + networkConfig.IPv6SendRA = true; + ipv6Prefixes = [ { Prefix = "2001:db8::/64"; } ]; + ipv6PREF64Prefixes = [ { Prefix = "64:ff9b::/96"; } ]; + ipv6SendRAConfig = { + EmitDNS = true; + DNS = "_link_local"; + }; }; - }; - services.resolved.extraConfig = '' - DNSStubListener=no - ''; - - networking.extraHosts = '' - 192.0.0.171 ipv4only.arpa - 192.0.0.170 ipv4only.arpa - ''; - - services.coredns = { - enable = true; - config = '' - .:53 { - bind :: - hosts /etc/hosts - dns64 64:ff9b::/96 - } + services.resolved.extraConfig = '' + DNSStubListener=no ''; - }; - services.tayga = { - enable = true; - ipv4 = { - address = "192.0.2.0"; - router = { - address = "192.0.2.1"; - }; - pool = { - address = "192.0.2.0"; - prefixLength = 24; - }; + networking.extraHosts = '' + 192.0.0.171 ipv4only.arpa + 192.0.0.170 ipv4only.arpa + ''; + + services.coredns = { + enable = true; + config = '' + .:53 { + bind :: + hosts /etc/hosts + dns64 64:ff9b::/96 + } + ''; }; - ipv6 = { - address = "2001:db8::1"; - router = { - address = "64:ff9b::1"; + + services.tayga = { + enable = true; + ipv4 = { + address = "192.0.2.0"; + router = { + address = "192.0.2.1"; + }; + pool = { + address = "192.0.2.0"; + prefixLength = 24; + }; }; - pool = { - address = "64:ff9b::"; - prefixLength = 96; + ipv6 = { + address = "2001:db8::1"; + router = { + address = "64:ff9b::1"; + }; + pool = { + address = "64:ff9b::"; + prefixLength = 96; + }; }; }; }; - }; - - # The client uses SLAAC to assign IPv6 addresses. To reach the IPv4-only - # server, the client starts the clat daemon which starts and configures the - # local IPv4 -> IPv6 translation via Tayga after discovering the PLAT - # prefix via DNS64. - client = { - virtualisation.vlans = [ - 3 # towards router - ]; - networking = { - useDHCP = false; - interfaces.eth1 = lib.mkForce {}; - }; + # The client uses SLAAC to assign IPv6 addresses. To reach the IPv4-only + # server, the client starts the clat daemon which starts and configures the + # local IPv4 -> IPv6 translation via Tayga after discovering the PLAT + # prefix via DNS64. + client = { + virtualisation.vlans = [ + 3 # towards router + ]; + + networking = { + useDHCP = false; + interfaces.eth1 = lib.mkForce { }; + }; - systemd.network = { - enable = true; - networks."vlan1" = { - matchConfig.Name = "eth1"; + systemd.network = { + enable = true; + networks."vlan1" = { + matchConfig.Name = "eth1"; - # NOTE: clatd does not actually use the PREF64 prefix discovered by - # systemd-networkd (nor does systemd-networkd do anything with it, - # yet), but we set this to confirm it works. See the test script - # below. - ipv6AcceptRAConfig.UsePREF64 = true; + # NOTE: clatd does not actually use the PREF64 prefix discovered by + # systemd-networkd (nor does systemd-networkd do anything with it, + # yet), but we set this to confirm it works. See the test script + # below. + ipv6AcceptRAConfig.UsePREF64 = true; + }; }; - }; - services.clatd = { - enable = true; - # NOTE: Perl's Net::DNS resolver does not seem to work well querying - # for AAAA records to systemd-resolved's default IPv4 bind address - # (127.0.0.53), so we add an IPv6 listener address to systemd-resolved - # and tell clatd to use that instead. - settings.dns64-servers = "::1"; - }; + services.clatd = { + enable = true; + # NOTE: Perl's Net::DNS resolver does not seem to work well querying + # for AAAA records to systemd-resolved's default IPv4 bind address + # (127.0.0.53), so we add an IPv6 listener address to systemd-resolved + # and tell clatd to use that instead. + settings.dns64-servers = "::1"; + }; - # Allow clatd to find dns server. See comment above. - services.resolved.extraConfig = '' - DNSStubListenerExtra=::1 - ''; + # Allow clatd to find dns server. See comment above. + services.resolved.extraConfig = '' + DNSStubListenerExtra=::1 + ''; - environment.systemPackages = [ pkgs.mtr ]; + environment.systemPackages = [ pkgs.mtr ]; + }; }; - }; - testScript = '' - import json + testScript = '' + import json - start_all() + start_all() - # wait for all machines to start up - for machine in client, router, server: - machine.wait_for_unit("network-online.target") + # wait for all machines to start up + for machine in client, router, server: + machine.wait_for_unit("network-online.target") - with subtest("Wait for tayga and clatd"): - router.wait_for_unit("tayga.service") - client.wait_for_unit("clatd.service") - # clatd checks if this system has IPv4 connectivity for 10 seconds - client.wait_until_succeeds( - 'journalctl -u clatd -e | grep -q "Starting up TAYGA, using config file"' - ) + with subtest("Wait for tayga and clatd"): + router.wait_for_unit("tayga.service") + client.wait_for_unit("clatd.service") + # clatd checks if this system has IPv4 connectivity for 10 seconds + client.wait_until_succeeds( + 'journalctl -u clatd -e | grep -q "Starting up TAYGA, using config file"' + ) - with subtest("networkd exports PREF64 prefix"): - assert json.loads(client.succeed("networkctl status eth1 --json=short"))[ - "NDisc" - ]["PREF64"][0]["Prefix"] == [0x0, 0x64, 0xFF, 0x9B] + ([0] * 12) + with subtest("networkd exports PREF64 prefix"): + assert json.loads(client.succeed("networkctl status eth1 --json=short"))[ + "NDisc" + ]["PREF64"][0]["Prefix"] == [0x0, 0x64, 0xFF, 0x9B] + ([0] * 12) - with subtest("Test ICMP"): - client.wait_until_succeeds("ping -c 3 100.64.0.2 >&2") + with subtest("Test ICMP"): + client.wait_until_succeeds("ping -c 3 100.64.0.2 >&2") - with subtest("Test ICMP and show a traceroute"): - client.wait_until_succeeds("mtr --show-ips --report-wide 100.64.0.2 >&2") + with subtest("Test ICMP and show a traceroute"): + client.wait_until_succeeds("mtr --show-ips --report-wide 100.64.0.2 >&2") - client.log(client.execute("systemd-analyze security clatd.service")[1]) - ''; -}) + client.log(client.execute("systemd-analyze security clatd.service")[1]) + ''; + } +) diff --git a/nixos/tests/clickhouse.nix b/nixos/tests/clickhouse.nix index 77d6a7ab8be423..80868c04e9e430 100644 --- a/nixos/tests/clickhouse.nix +++ b/nixos/tests/clickhouse.nix @@ -1,19 +1,21 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "clickhouse"; - meta.maintainers = with pkgs.lib.maintainers; [ ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "clickhouse"; + meta.maintainers = with pkgs.lib.maintainers; [ ]; - nodes.machine = { - services.clickhouse.enable = true; - virtualisation.memorySize = 4096; - }; + nodes.machine = { + services.clickhouse.enable = true; + virtualisation.memorySize = 4096; + }; - testScript = - let - # work around quote/substitution complexity by Nix, Perl, bash and SQL. - tableDDL = pkgs.writeText "ddl.sql" "CREATE TABLE `demo` (`value` FixedString(10)) engine = MergeTree PARTITION BY value ORDER BY tuple();"; - insertQuery = pkgs.writeText "insert.sql" "INSERT INTO `demo` (`value`) VALUES ('foo');"; - selectQuery = pkgs.writeText "select.sql" "SELECT * from `demo`"; - in + testScript = + let + # work around quote/substitution complexity by Nix, Perl, bash and SQL. + tableDDL = pkgs.writeText "ddl.sql" "CREATE TABLE `demo` (`value` FixedString(10)) engine = MergeTree PARTITION BY value ORDER BY tuple();"; + insertQuery = pkgs.writeText "insert.sql" "INSERT INTO `demo` (`value`) VALUES ('foo');"; + selectQuery = pkgs.writeText "select.sql" "SELECT * from `demo`"; + in '' machine.start() machine.wait_for_unit("clickhouse.service") @@ -29,4 +31,5 @@ import ./make-test-python.nix ({ pkgs, ... }: { "cat ${selectQuery} | clickhouse-client | grep foo" ) ''; -}) + } +) diff --git a/nixos/tests/cloud-init-hostname.nix b/nixos/tests/cloud-init-hostname.nix index 7c657cc9f6f98c..c3d71e8ef0d51d 100644 --- a/nixos/tests/cloud-init-hostname.nix +++ b/nixos/tests/cloud-init-hostname.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -27,17 +28,26 @@ let ''; }; -in makeTest { +in +makeTest { name = "cloud-init-hostname"; meta = with pkgs.lib.maintainers; { - maintainers = [ lewo illustris ]; + maintainers = [ + lewo + illustris + ]; }; - nodes.machine2 = { ... }: { - virtualisation.qemu.options = [ "-cdrom" "${metadataDrive}/metadata.iso" ]; - services.cloud-init.enable = true; - networking.hostName = ""; - }; + nodes.machine2 = + { ... }: + { + virtualisation.qemu.options = [ + "-cdrom" + "${metadataDrive}/metadata.iso" + ]; + services.cloud-init.enable = true; + networking.hostName = ""; + }; testScript = '' unnamed.wait_for_unit("cloud-final.service") diff --git a/nixos/tests/cloud-init.nix b/nixos/tests/cloud-init.nix index 0b4c5a55c80a6f..8ab0bbbd98512b 100644 --- a/nixos/tests/cloud-init.nix +++ b/nixos/tests/cloud-init.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -8,7 +9,9 @@ with pkgs.lib; let inherit (import ./ssh-keys.nix pkgs) - snakeOilPrivateKey snakeOilPublicKey; + snakeOilPrivateKey + snakeOilPublicKey + ; metadataDrive = pkgs.stdenv.mkDerivation { name = "metadata"; @@ -54,23 +57,31 @@ let - 'example.com' EOF ${pkgs.cdrkit}/bin/genisoimage -volid cidata -joliet -rock -o $out/metadata.iso $out/iso - ''; + ''; }; -in makeTest { +in +makeTest { name = "cloud-init"; - meta.maintainers = with pkgs.lib.maintainers; [ lewo illustris ]; - nodes.machine = { ... }: - { - virtualisation.qemu.options = [ "-cdrom" "${metadataDrive}/metadata.iso" ]; - services.cloud-init = { - enable = true; - network.enable = true; + meta.maintainers = with pkgs.lib.maintainers; [ + lewo + illustris + ]; + nodes.machine = + { ... }: + { + virtualisation.qemu.options = [ + "-cdrom" + "${metadataDrive}/metadata.iso" + ]; + services.cloud-init = { + enable = true; + network.enable = true; + }; + services.openssh.enable = true; + networking.hostName = ""; + networking.useDHCP = false; }; - services.openssh.enable = true; - networking.hostName = ""; - networking.useDHCP = false; - }; testScript = '' # To wait until cloud-init terminates its run unnamed.wait_for_unit("cloud-init-local.service") diff --git a/nixos/tests/cloudlog.nix b/nixos/tests/cloudlog.nix index c99951c1b22c22..b49d1929f80c4d 100644 --- a/nixos/tests/cloudlog.nix +++ b/nixos/tests/cloudlog.nix @@ -1,18 +1,21 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "cloudlog"; - meta = { - maintainers = with pkgs.lib.maintainers; [ melling ]; - }; - nodes = { - machine = { - services.mysql.package = pkgs.mariadb; - services.cloudlog.enable = true; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "cloudlog"; + meta = { + maintainers = with pkgs.lib.maintainers; [ melling ]; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("phpfpm-cloudlog") - machine.wait_for_open_port(80); - machine.wait_until_succeeds("curl -s -L --fail http://localhost | grep 'Login - Cloudlog'") - ''; -}) + nodes = { + machine = { + services.mysql.package = pkgs.mariadb; + services.cloudlog.enable = true; + }; + }; + testScript = '' + start_all() + machine.wait_for_unit("phpfpm-cloudlog") + machine.wait_for_open_port(80); + machine.wait_until_succeeds("curl -s -L --fail http://localhost | grep 'Login - Cloudlog'") + ''; + } +) diff --git a/nixos/tests/cntr.nix b/nixos/tests/cntr.nix index 2166fb8f9b0929..b7ae93f622ff73 100644 --- a/nixos/tests/cntr.nix +++ b/nixos/tests/cntr.nix @@ -1,28 +1,40 @@ # Test for cntr tool -{ system ? builtins.currentSystem, config ? { } -, pkgs ? import ../.. { inherit system config; }, lib ? pkgs.lib }: +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, + lib ? pkgs.lib, +}: let inherit (import ../lib/testing-python.nix { inherit system pkgs; }) makeTest; - mkOCITest = backend: + mkOCITest = + backend: makeTest { name = "cntr-${backend}"; - meta = { maintainers = with lib.maintainers; [ sorki mic92 ]; }; + meta = { + maintainers = with lib.maintainers; [ + sorki + mic92 + ]; + }; nodes = { - ${backend} = { pkgs, ... }: { - environment.systemPackages = [ pkgs.cntr ]; - virtualisation.oci-containers = { - inherit backend; - containers.nginx = { - image = "nginx-container"; - imageStream = pkgs.dockerTools.examples.nginxStream; - ports = [ "8181:80" ]; + ${backend} = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.cntr ]; + virtualisation.oci-containers = { + inherit backend; + containers.nginx = { + image = "nginx-container"; + imageStream = pkgs.dockerTools.examples.nginxStream; + ports = [ "8181:80" ]; + }; }; }; - }; }; testScript = '' @@ -44,18 +56,25 @@ let mkContainersTest = makeTest { name = "cntr-containers"; - meta = with pkgs.lib.maintainers; { maintainers = [ sorki mic92 ]; }; + meta = with pkgs.lib.maintainers; { + maintainers = [ + sorki + mic92 + ]; + }; - nodes.machine = { lib, ... }: { - environment.systemPackages = [ pkgs.cntr ]; - containers.test = { - autoStart = true; - privateNetwork = true; - hostAddress = "172.16.0.1"; - localAddress = "172.16.0.2"; - config = { }; + nodes.machine = + { lib, ... }: + { + environment.systemPackages = [ pkgs.cntr ]; + containers.test = { + autoStart = true; + privateNetwork = true; + hostAddress = "172.16.0.1"; + localAddress = "172.16.0.2"; + config = { }; + }; }; - }; testScript = '' machine.start() @@ -69,7 +88,11 @@ let assert "0" == machine.succeed("cat /tmp/exitcode").strip(), "non-zero exit code" ''; }; -in { +in +{ nixos-container = mkContainersTest; -} // (lib.foldl' (attrs: backend: attrs // { ${backend} = mkOCITest backend; }) - { } [ "docker" "podman" ]) +} +// (lib.foldl' (attrs: backend: attrs // { ${backend} = mkOCITest backend; }) { } [ + "docker" + "podman" +]) diff --git a/nixos/tests/cockpit.nix b/nixos/tests/cockpit.nix index e7165b97901410..6c90cccade72c2 100644 --- a/nixos/tests/cockpit.nix +++ b/nixos/tests/cockpit.nix @@ -4,118 +4,133 @@ import ./make-test-python.nix ( let user = "alice"; # from ./common/user-account.nix password = "foobar"; # from ./common/user-account.nix - in { + in + { name = "cockpit"; meta = { maintainers = with lib.maintainers; [ lucasew ]; }; nodes = { - server = { config, ... }: { - imports = [ ./common/user-account.nix ]; - security.polkit.enable = true; - users.users.${user} = { - extraGroups = [ "wheel" ]; - }; - services.cockpit = { - enable = true; - openFirewall = true; - settings = { - WebService = { - Origins = "https://server:9090"; + server = + { config, ... }: + { + imports = [ ./common/user-account.nix ]; + security.polkit.enable = true; + users.users.${user} = { + extraGroups = [ "wheel" ]; + }; + services.cockpit = { + enable = true; + openFirewall = true; + settings = { + WebService = { + Origins = "https://server:9090"; + }; }; }; }; - }; - client = { config, ... }: { - imports = [ ./common/user-account.nix ]; - environment.systemPackages = let - seleniumScript = pkgs.writers.writePython3Bin "selenium-script" { - libraries = with pkgs.python3Packages; [ selenium ]; - } '' - from selenium import webdriver - from selenium.webdriver.common.by import By - from selenium.webdriver.firefox.options import Options - from selenium.webdriver.support.ui import WebDriverWait - from selenium.webdriver.support import expected_conditions as EC - from time import sleep + client = + { config, ... }: + { + imports = [ ./common/user-account.nix ]; + environment.systemPackages = + let + seleniumScript = + pkgs.writers.writePython3Bin "selenium-script" + { + libraries = with pkgs.python3Packages; [ selenium ]; + } + '' + from selenium import webdriver + from selenium.webdriver.common.by import By + from selenium.webdriver.firefox.options import Options + from selenium.webdriver.support.ui import WebDriverWait + from selenium.webdriver.support import expected_conditions as EC + from time import sleep - def log(msg): - from sys import stderr - print(f"[*] {msg}", file=stderr) + def log(msg): + from sys import stderr + print(f"[*] {msg}", file=stderr) - log("Initializing") + log("Initializing") - options = Options() - options.add_argument("--headless") + options = Options() + options.add_argument("--headless") - service = webdriver.FirefoxService(executable_path="${lib.getExe pkgs.geckodriver}") # noqa: E501 - driver = webdriver.Firefox(options=options, service=service) + service = webdriver.FirefoxService(executable_path="${lib.getExe pkgs.geckodriver}") # noqa: E501 + driver = webdriver.Firefox(options=options, service=service) - driver.implicitly_wait(10) + driver.implicitly_wait(10) - log("Opening homepage") - driver.get("https://server:9090") + log("Opening homepage") + driver.get("https://server:9090") - wait = WebDriverWait(driver, 60) + wait = WebDriverWait(driver, 60) - def wait_elem(by, query): - wait.until(EC.presence_of_element_located((by, query))) + def wait_elem(by, query): + wait.until(EC.presence_of_element_located((by, query))) - def wait_title_contains(title): - wait.until(EC.title_contains(title)) + def wait_title_contains(title): + wait.until(EC.title_contains(title)) - def find_element(by, query): - return driver.find_element(by, query) + def find_element(by, query): + return driver.find_element(by, query) - def set_value(elem, value): - script = 'arguments[0].value = arguments[1]' - return driver.execute_script(script, elem, value) + def set_value(elem, value): + script = 'arguments[0].value = arguments[1]' + return driver.execute_script(script, elem, value) - log("Waiting for the homepage to load") + log("Waiting for the homepage to load") - # cockpit sets initial title as hostname - wait_title_contains("server") - wait_elem(By.CSS_SELECTOR, 'input#login-user-input') + # cockpit sets initial title as hostname + wait_title_contains("server") + wait_elem(By.CSS_SELECTOR, 'input#login-user-input') - log("Homepage loaded!") + log("Homepage loaded!") - log("Filling out username") - login_input = find_element(By.CSS_SELECTOR, 'input#login-user-input') - set_value(login_input, "${user}") + log("Filling out username") + login_input = find_element(By.CSS_SELECTOR, 'input#login-user-input') + set_value(login_input, "${user}") - log("Filling out password") - password_input = find_element(By.CSS_SELECTOR, 'input#login-password-input') - set_value(password_input, "${password}") + log("Filling out password") + password_input = find_element(By.CSS_SELECTOR, 'input#login-password-input') + set_value(password_input, "${password}") - log("Submitting credentials for login") - driver.find_element(By.CSS_SELECTOR, 'button#login-button').click() + log("Submitting credentials for login") + driver.find_element(By.CSS_SELECTOR, 'button#login-button').click() - # driver.implicitly_wait(1) - # driver.get("https://server:9090/system") + # driver.implicitly_wait(1) + # driver.get("https://server:9090/system") - log("Waiting dashboard to load") - wait_title_contains("${user}@server") + log("Waiting dashboard to load") + wait_title_contains("${user}@server") - log("Waiting for the frontend to initialize") - sleep(1) + log("Waiting for the frontend to initialize") + sleep(1) - log("Looking for that banner that tells about limited access") - container_iframe = find_element(By.CSS_SELECTOR, 'iframe.container-frame') - driver.switch_to.frame(container_iframe) + log("Looking for that banner that tells about limited access") + container_iframe = find_element(By.CSS_SELECTOR, 'iframe.container-frame') + driver.switch_to.frame(container_iframe) - assert "Web console is running in limited access mode" in driver.page_source + assert "Web console is running in limited access mode" in driver.page_source - driver.close() - ''; - in with pkgs; [ firefox-unwrapped geckodriver seleniumScript ]; - }; + driver.close() + ''; + in + with pkgs; + [ + firefox-unwrapped + geckodriver + seleniumScript + ]; + }; }; testScript = '' diff --git a/nixos/tests/cockroachdb.nix b/nixos/tests/cockroachdb.nix index 5b1e1a7dee1f94..6a9bfd99949f44 100644 --- a/nixos/tests/cockroachdb.nix +++ b/nixos/tests/cockroachdb.nix @@ -50,8 +50,15 @@ let # Creates a node. If 'joinNode' parameter, a string containing an IP address, # is non-null, then the CockroachDB server will attempt to join/connect to # the cluster node specified at that address. - makeNode = locality: myAddr: joinNode: - { nodes, pkgs, lib, config, ... }: + makeNode = + locality: myAddr: joinNode: + { + nodes, + pkgs, + lib, + config, + ... + }: { # Bank/TPC-C benchmarks take some memory to complete @@ -97,28 +104,31 @@ let ''; }; -in import ./make-test-python.nix ({ pkgs, ...} : { - name = "cockroachdb"; - meta.maintainers = with pkgs.lib.maintainers; - [ thoughtpolice ]; +in +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "cockroachdb"; + meta.maintainers = with pkgs.lib.maintainers; [ thoughtpolice ]; - nodes = { - node1 = makeNode "country=us,region=east,dc=1" "192.168.1.1" null; - node2 = makeNode "country=us,region=west,dc=2b" "192.168.1.2" "192.168.1.1"; - node3 = makeNode "country=eu,region=west,dc=2" "192.168.1.3" "192.168.1.1"; - }; + nodes = { + node1 = makeNode "country=us,region=east,dc=1" "192.168.1.1" null; + node2 = makeNode "country=us,region=west,dc=2b" "192.168.1.2" "192.168.1.1"; + node3 = makeNode "country=eu,region=west,dc=2" "192.168.1.3" "192.168.1.1"; + }; - # NOTE: All the nodes must start in order and you must NOT use startAll, because - # there's otherwise no way to guarantee that node1 will start before the others try - # to join it. - testScript = '' - for node in node1, node2, node3: - node.start() - node.wait_for_unit("cockroachdb") - node1.succeed( - "cockroach sql --host=192.168.1.1 --insecure -e 'SHOW ALL CLUSTER SETTINGS' 2>&1", - "cockroach workload init bank 'postgresql://root@192.168.1.1:26257?sslmode=disable'", - "cockroach workload run bank --duration=1m 'postgresql://root@192.168.1.1:26257?sslmode=disable'", - ) - ''; -}) + # NOTE: All the nodes must start in order and you must NOT use startAll, because + # there's otherwise no way to guarantee that node1 will start before the others try + # to join it. + testScript = '' + for node in node1, node2, node3: + node.start() + node.wait_for_unit("cockroachdb") + node1.succeed( + "cockroach sql --host=192.168.1.1 --insecure -e 'SHOW ALL CLUSTER SETTINGS' 2>&1", + "cockroach workload init bank 'postgresql://root@192.168.1.1:26257?sslmode=disable'", + "cockroach workload run bank --duration=1m 'postgresql://root@192.168.1.1:26257?sslmode=disable'", + ) + ''; + } +) diff --git a/nixos/tests/code-server.nix b/nixos/tests/code-server.nix index 7d523dfc617e3c..d58a0faee1044d 100644 --- a/nixos/tests/code-server.nix +++ b/nixos/tests/code-server.nix @@ -1,22 +1,26 @@ -import ./make-test-python.nix ({pkgs, lib, ...}: -{ - name = "code-server"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "code-server"; - nodes = { - machine = {pkgs, ...}: { - services.code-server = { - enable = true; - auth = "none"; - }; + nodes = { + machine = + { pkgs, ... }: + { + services.code-server = { + enable = true; + auth = "none"; + }; + }; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("code-server.service") - machine.wait_for_open_port(4444) - machine.succeed("curl -k --fail http://localhost:4444", timeout=10) - ''; + testScript = '' + start_all() + machine.wait_for_unit("code-server.service") + machine.wait_for_open_port(4444) + machine.succeed("curl -k --fail http://localhost:4444", timeout=10) + ''; - meta.maintainers = [ lib.maintainers.drupol ]; -}) + meta.maintainers = [ lib.maintainers.drupol ]; + } +) diff --git a/nixos/tests/coder.nix b/nixos/tests/coder.nix index fd1fa0cc3031fa..8bbba5d900c0c8 100644 --- a/nixos/tests/coder.nix +++ b/nixos/tests/coder.nix @@ -1,22 +1,25 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "coder"; - meta.maintainers = pkgs.coder.meta.maintainers; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "coder"; + meta.maintainers = pkgs.coder.meta.maintainers; - nodes.machine = - { pkgs, ... }: - { - services.coder = { - enable = true; - accessUrl = "http://localhost:3000"; + nodes.machine = + { pkgs, ... }: + { + services.coder = { + enable = true; + accessUrl = "http://localhost:3000"; + }; }; - }; - testScript = '' - machine.start() - machine.wait_for_unit("postgresql.service") - machine.wait_for_unit("coder.service") - machine.wait_for_open_port(3000) + testScript = '' + machine.start() + machine.wait_for_unit("postgresql.service") + machine.wait_for_unit("coder.service") + machine.wait_for_open_port(3000) - machine.succeed("curl --fail http://localhost:3000") - ''; -}) + machine.succeed("curl --fail http://localhost:3000") + ''; + } +) diff --git a/nixos/tests/collectd.nix b/nixos/tests/collectd.nix index 2480bdb5f917e6..31d4689f1efe5b 100644 --- a/nixos/tests/collectd.nix +++ b/nixos/tests/collectd.nix @@ -1,38 +1,41 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "collectd"; - meta = { }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "collectd"; + meta = { }; - nodes.machine = - { pkgs, lib, ... }: + nodes.machine = + { pkgs, lib, ... }: - { - services.collectd = { - enable = true; - extraConfig = lib.mkBefore '' - Interval 30 - ''; - plugins = { - rrdtool = '' - DataDir "/var/lib/collectd/rrd" + { + services.collectd = { + enable = true; + extraConfig = lib.mkBefore '' + Interval 30 ''; - load = ""; + plugins = { + rrdtool = '' + DataDir "/var/lib/collectd/rrd" + ''; + load = ""; + }; }; + environment.systemPackages = [ pkgs.rrdtool ]; }; - environment.systemPackages = [ pkgs.rrdtool ]; - }; - testScript = '' - machine.wait_for_unit("collectd.service") - hostname = machine.succeed("hostname").strip() - file = f"/var/lib/collectd/rrd/{hostname}/load/load.rrd" - machine.wait_for_file(file); - machine.succeed(f"rrdinfo {file} | logger") - # check that this file contains a shortterm metric - machine.succeed(f"rrdinfo {file} | grep -F 'ds[shortterm].min = '") - # check that interval was set before the plugins - machine.succeed(f"rrdinfo {file} | grep -F 'step = 30'") - # check that there are frequent updates - machine.succeed(f"cp {file} before") - machine.wait_until_fails(f"cmp before {file}") - ''; -}) + testScript = '' + machine.wait_for_unit("collectd.service") + hostname = machine.succeed("hostname").strip() + file = f"/var/lib/collectd/rrd/{hostname}/load/load.rrd" + machine.wait_for_file(file); + machine.succeed(f"rrdinfo {file} | logger") + # check that this file contains a shortterm metric + machine.succeed(f"rrdinfo {file} | grep -F 'ds[shortterm].min = '") + # check that interval was set before the plugins + machine.succeed(f"rrdinfo {file} | grep -F 'step = 30'") + # check that there are frequent updates + machine.succeed(f"cp {file} before") + machine.wait_until_fails(f"cmp before {file}") + ''; + } +) diff --git a/nixos/tests/common/acme/client/default.nix b/nixos/tests/common/acme/client/default.nix index f9b08b519dbeb3..50d7ae13096b31 100644 --- a/nixos/tests/common/acme/client/default.nix +++ b/nixos/tests/common/acme/client/default.nix @@ -3,7 +3,8 @@ let caCert = nodes.acme.test-support.acme.caCert; caDomain = nodes.acme.test-support.acme.caDomain; -in { +in +{ security.acme = { acceptTerms = true; defaults = { diff --git a/nixos/tests/common/acme/server/default.nix b/nixos/tests/common/acme/server/default.nix index 893c6924027f45..aaf6a8bd734898 100644 --- a/nixos/tests/common/acme/server/default.nix +++ b/nixos/tests/common/acme/server/default.nix @@ -49,7 +49,12 @@ # # Also make sure that whenever you use a resolver from a different test node # that it has to be started _before_ the ACME service. -{ config, pkgs, lib, ... }: +{ + config, + pkgs, + lib, + ... +}: let testCerts = import ./snakeoil-certs.nix; domain = testCerts.domain; @@ -68,7 +73,8 @@ let pebbleConfFile = pkgs.writeText "pebble.conf" (builtins.toJSON pebbleConf); -in { +in +{ imports = [ ../../resolver.nix ]; options.test-support.acme = { @@ -95,15 +101,22 @@ in { config = { test-support = { - resolver.enable = let - isLocalResolver = config.networking.nameservers == [ "127.0.0.1" ]; - in lib.mkOverride 900 isLocalResolver; + resolver.enable = + let + isLocalResolver = config.networking.nameservers == [ "127.0.0.1" ]; + in + lib.mkOverride 900 isLocalResolver; }; # This has priority 140, because modules/testing/test-instrumentation.nix # already overrides this with priority 150. networking.nameservers = lib.mkOverride 140 [ "127.0.0.1" ]; - networking.firewall.allowedTCPPorts = [ 80 443 15000 4002 ]; + networking.firewall.allowedTCPPorts = [ + 80 + 443 + 15000 + 4002 + ]; networking.extraHosts = '' 127.0.0.1 ${domain} diff --git a/nixos/tests/common/acme/server/generate-certs.nix b/nixos/tests/common/acme/server/generate-certs.nix index 4f38ca309b05bc..0cec8328270765 100644 --- a/nixos/tests/common/acme/server/generate-certs.nix +++ b/nixos/tests/common/acme/server/generate-certs.nix @@ -1,20 +1,23 @@ # Minica can provide a CA key and cert, plus a key # and cert for our fake CA server's Web Front End (WFE). { - pkgs ? import {}, + pkgs ? import { }, minica ? pkgs.minica, - mkDerivation ? pkgs.stdenv.mkDerivation + mkDerivation ? pkgs.stdenv.mkDerivation, }: let conf = import ./snakeoil-certs.nix; domain = conf.domain; -in mkDerivation { +in +mkDerivation { name = "test-certs"; - buildInputs = [ (minica.overrideAttrs (old: { - prePatch = '' - sed -i 's_NotAfter: time.Now().AddDate(2, 0, 30),_NotAfter: time.Now().AddDate(20, 0, 0),_' main.go - ''; - })) ]; + buildInputs = [ + (minica.overrideAttrs (old: { + prePatch = '' + sed -i 's_NotAfter: time.Now().AddDate(2, 0, 30),_NotAfter: time.Now().AddDate(20, 0, 0),_' main.go + ''; + })) + ]; dontUnpack = true; buildPhase = '' diff --git a/nixos/tests/common/acme/server/snakeoil-certs.nix b/nixos/tests/common/acme/server/snakeoil-certs.nix index 11c3f7fc9290c1..405627979feef7 100644 --- a/nixos/tests/common/acme/server/snakeoil-certs.nix +++ b/nixos/tests/common/acme/server/snakeoil-certs.nix @@ -1,6 +1,7 @@ let domain = "acme.test"; -in { +in +{ inherit domain; ca = { cert = ./ca.cert.pem; diff --git a/nixos/tests/common/auto-format-root-device.nix b/nixos/tests/common/auto-format-root-device.nix index fef8c70049913b..1fe0f680f5befc 100644 --- a/nixos/tests/common/auto-format-root-device.nix +++ b/nixos/tests/common/auto-format-root-device.nix @@ -5,7 +5,12 @@ # `virtualisation.fileSystems."/".autoFormat = true;` # instead. -{ lib, config, pkgs, ... }: +{ + lib, + config, + pkgs, + ... +}: let rootDevice = config.virtualisation.rootDevice; diff --git a/nixos/tests/common/auto.nix b/nixos/tests/common/auto.nix index cbd298de8f8157..1be1851a7f4b85 100644 --- a/nixos/tests/common/auto.nix +++ b/nixos/tests/common/auto.nix @@ -39,15 +39,15 @@ in # lightdm by default doesn't allow auto login for root, which is # required by some nixos tests. Override it here. security.pam.services.lightdm-autologin.text = lib.mkForce '' - auth requisite pam_nologin.so - auth required pam_succeed_if.so quiet - auth required pam_permit.so + auth requisite pam_nologin.so + auth required pam_succeed_if.so quiet + auth required pam_permit.so - account include lightdm + account include lightdm - password include lightdm + password include lightdm - session include lightdm + session include lightdm ''; }; } diff --git a/nixos/tests/common/ec2.nix b/nixos/tests/common/ec2.nix index 82922102f07b5e..8210e5914afbf3 100644 --- a/nixos/tests/common/ec2.nix +++ b/nixos/tests/common/ec2.nix @@ -3,70 +3,85 @@ with pkgs.lib; { - makeEc2Test = { name, image, userData, script, hostname ? "ec2-instance", sshPublicKey ? null, meta ? {} }: + makeEc2Test = + { + name, + image, + userData, + script, + hostname ? "ec2-instance", + sshPublicKey ? null, + meta ? { }, + }: let metaData = pkgs.stdenv.mkDerivation { name = "metadata"; - buildCommand = '' - mkdir -p $out/1.0/meta-data - ln -s ${pkgs.writeText "userData" userData} $out/1.0/user-data - echo "${hostname}" > $out/1.0/meta-data/hostname - echo "(unknown)" > $out/1.0/meta-data/ami-manifest-path - '' + optionalString (sshPublicKey != null) '' - mkdir -p $out/1.0/meta-data/public-keys/0 - ln -s ${pkgs.writeText "sshPublicKey" sshPublicKey} $out/1.0/meta-data/public-keys/0/openssh-key - ''; + buildCommand = + '' + mkdir -p $out/1.0/meta-data + ln -s ${pkgs.writeText "userData" userData} $out/1.0/user-data + echo "${hostname}" > $out/1.0/meta-data/hostname + echo "(unknown)" > $out/1.0/meta-data/ami-manifest-path + '' + + optionalString (sshPublicKey != null) '' + mkdir -p $out/1.0/meta-data/public-keys/0 + ln -s ${pkgs.writeText "sshPublicKey" sshPublicKey} $out/1.0/meta-data/public-keys/0/openssh-key + ''; }; indentLines = str: concatLines (map (s: " " + s) (splitString "\n" str)); - in makeTest { + in + makeTest { name = "ec2-" + name; - nodes = {}; - testScript = '' - import os - import subprocess - import tempfile + nodes = { }; + testScript = + '' + import os + import subprocess + import tempfile - image_dir = os.path.join( - os.environ.get("TMPDIR", tempfile.gettempdir()), "tmp", "vm-state-machine" - ) - os.makedirs(image_dir, mode=0o700, exist_ok=True) - disk_image = os.path.join(image_dir, "machine.qcow2") - subprocess.check_call( - [ - "qemu-img", - "create", - "-f", - "qcow2", - "-F", - "qcow2", - "-o", - "backing_file=${image}", - disk_image, - ] - ) - subprocess.check_call(["qemu-img", "resize", disk_image, "10G"]) + image_dir = os.path.join( + os.environ.get("TMPDIR", tempfile.gettempdir()), "tmp", "vm-state-machine" + ) + os.makedirs(image_dir, mode=0o700, exist_ok=True) + disk_image = os.path.join(image_dir, "machine.qcow2") + subprocess.check_call( + [ + "qemu-img", + "create", + "-f", + "qcow2", + "-F", + "qcow2", + "-o", + "backing_file=${image}", + disk_image, + ] + ) + subprocess.check_call(["qemu-img", "resize", disk_image, "10G"]) - # Note: we use net=169.0.0.0/8 rather than - # net=169.254.0.0/16 to prevent dhcpcd from getting horribly - # confused. (It would get a DHCP lease in the 169.254.* - # range, which it would then configure and promptly delete - # again when it deletes link-local addresses.) Ideally we'd - # turn off the DHCP server, but qemu does not have an option - # to do that. - start_command = ( - "qemu-kvm -m 1024" - + " -device virtio-net-pci,netdev=vlan0" - + " -netdev 'user,id=vlan0,net=169.0.0.0/8,guestfwd=tcp:169.254.169.254:80-cmd:${pkgs.micro-httpd}/bin/micro_httpd ${metaData}'" - + f" -drive file={disk_image},if=virtio,werror=report" - + " $QEMU_OPTS" - ) + # Note: we use net=169.0.0.0/8 rather than + # net=169.254.0.0/16 to prevent dhcpcd from getting horribly + # confused. (It would get a DHCP lease in the 169.254.* + # range, which it would then configure and promptly delete + # again when it deletes link-local addresses.) Ideally we'd + # turn off the DHCP server, but qemu does not have an option + # to do that. + start_command = ( + "qemu-kvm -m 1024" + + " -device virtio-net-pci,netdev=vlan0" + + " -netdev 'user,id=vlan0,net=169.0.0.0/8,guestfwd=tcp:169.254.169.254:80-cmd:${pkgs.micro-httpd}/bin/micro_httpd ${metaData}'" + + f" -drive file={disk_image},if=virtio,werror=report" + + " $QEMU_OPTS" + ) - machine = create_machine(start_command) - try: - '' + indentLines script + '' - finally: - machine.shutdown() - ''; + machine = create_machine(start_command) + try: + '' + + indentLines script + + '' + finally: + machine.shutdown() + ''; inherit meta; }; diff --git a/nixos/tests/common/resolver.nix b/nixos/tests/common/resolver.nix index 4d1b96a3a49717..76d720f1fb8597 100644 --- a/nixos/tests/common/resolver.nix +++ b/nixos/tests/common/resolver.nix @@ -3,7 +3,13 @@ # (except those that point to 127.0.0.1 or ::1) within the current test network # and delegates these zones using a fake root zone served by a BIND recursive # name server. -{ config, nodes, pkgs, lib, ... }: +{ + config, + nodes, + pkgs, + lib, + ... +}: { options.test-support.resolver.enable = lib.mkOption { @@ -28,115 +34,151 @@ networking.firewall.enable = false; services.bind.enable = true; services.bind.cacheNetworks = lib.mkForce [ "any" ]; - services.bind.forwarders = lib.mkForce []; + services.bind.forwarders = lib.mkForce [ ]; services.bind.zones = lib.singleton { name = "."; master = true; - file = let - addDot = zone: zone + lib.optionalString (!lib.hasSuffix "." zone) "."; - mkNsdZoneNames = zones: map addDot (lib.attrNames zones); - mkBindZoneNames = zones: map addDot (lib.attrNames zones); - getZones = cfg: mkNsdZoneNames cfg.services.nsd.zones - ++ mkBindZoneNames cfg.services.bind.zones; - - getZonesForNode = attrs: { - ip = attrs.config.networking.primaryIPAddress; - zones = lib.filter (zone: zone != ".") (getZones attrs.config); - }; - - zoneInfo = lib.mapAttrsToList (lib.const getZonesForNode) nodes; - - # A and AAAA resource records for all the definitions of - # networking.extraHosts except those for 127.0.0.1 or ::1. - # - # The result is an attribute set with keys being the host name and the - # values are either { ipv4 = ADDR; } or { ipv6 = ADDR; } where ADDR is - # the IP address for the corresponding key. - recordsFromExtraHosts = let - getHostsForNode = lib.const (n: n.config.networking.extraHosts); - allHostsList = lib.mapAttrsToList getHostsForNode nodes; - allHosts = lib.concatStringsSep "\n" allHostsList; - - reIp = "[a-fA-F0-9.:]+"; - reHost = "[a-zA-Z0-9.-]+"; - - matchAliases = str: let - matched = builtins.match "[ \t]+(${reHost})(.*)" str; - continue = lib.singleton (lib.head matched) - ++ matchAliases (lib.last matched); - in lib.optional (matched != null) continue; - - matchLine = str: let - result = builtins.match "[ \t]*(${reIp})[ \t]+(${reHost})(.*)" str; - in if result == null then null else { - ipAddr = lib.head result; - hosts = lib.singleton (lib.elemAt result 1) - ++ matchAliases (lib.last result); + file = + let + addDot = zone: zone + lib.optionalString (!lib.hasSuffix "." zone) "."; + mkNsdZoneNames = zones: map addDot (lib.attrNames zones); + mkBindZoneNames = zones: map addDot (lib.attrNames zones); + getZones = cfg: mkNsdZoneNames cfg.services.nsd.zones ++ mkBindZoneNames cfg.services.bind.zones; + + getZonesForNode = attrs: { + ip = attrs.config.networking.primaryIPAddress; + zones = lib.filter (zone: zone != ".") (getZones attrs.config); }; - skipLine = str: let - rest = builtins.match "[^\n]*\n(.*)" str; - in if rest == null then "" else lib.head rest; - - getEntries = str: acc: let - result = matchLine str; - next = getEntries (skipLine str); - newEntry = acc ++ lib.singleton result; - continue = if result == null then next acc else next newEntry; - in if str == "" then acc else continue; - - isIPv6 = str: builtins.match ".*:.*" str != null; - loopbackIps = [ "127.0.0.1" "::1" ]; - filterLoopback = lib.filter (e: !lib.elem e.ipAddr loopbackIps); - - allEntries = lib.concatMap (entry: map (host: { - inherit host; - ${if isIPv6 entry.ipAddr then "ipv6" else "ipv4"} = entry.ipAddr; - }) entry.hosts) (filterLoopback (getEntries (allHosts + "\n") [])); - - mkRecords = entry: let - records = lib.optional (entry ? ipv6) "AAAA ${entry.ipv6}" - ++ lib.optional (entry ? ipv4) "A ${entry.ipv4}"; - mkRecord = typeAndData: "${entry.host}. IN ${typeAndData}"; - in lib.concatMapStringsSep "\n" mkRecord records; - - in lib.concatMapStringsSep "\n" mkRecords allEntries; - - # All of the zones that are subdomains of existing zones. - # For example if there is only "example.com" the following zones would - # be 'subZones': - # - # * foo.example.com. - # * bar.example.com. - # - # While the following would *not* be 'subZones': - # - # * example.com. - # * com. - # - subZones = let - allZones = lib.concatMap (zi: zi.zones) zoneInfo; - isSubZoneOf = z1: z2: lib.hasSuffix z2 z1 && z1 != z2; - in lib.filter (z: lib.any (isSubZoneOf z) allZones) allZones; - - # All the zones without 'subZones'. - filteredZoneInfo = map (zi: zi // { - zones = lib.filter (x: !lib.elem x subZones) zi.zones; - }) zoneInfo; - - in pkgs.writeText "fake-root.zone" '' - $TTL 3600 - . IN SOA ns.fakedns. admin.fakedns. ( 1 3h 1h 1w 1d ) - ns.fakedns. IN A ${config.networking.primaryIPAddress} - . IN NS ns.fakedns. - ${lib.concatImapStrings (num: { ip, zones }: '' - ns${toString num}.fakedns. IN A ${ip} - ${lib.concatMapStrings (zone: '' - ${zone} IN NS ns${toString num}.fakedns. - '') zones} - '') (lib.filter (zi: zi.zones != []) filteredZoneInfo)} - ${recordsFromExtraHosts} - ''; + zoneInfo = lib.mapAttrsToList (lib.const getZonesForNode) nodes; + + # A and AAAA resource records for all the definitions of + # networking.extraHosts except those for 127.0.0.1 or ::1. + # + # The result is an attribute set with keys being the host name and the + # values are either { ipv4 = ADDR; } or { ipv6 = ADDR; } where ADDR is + # the IP address for the corresponding key. + recordsFromExtraHosts = + let + getHostsForNode = lib.const (n: n.config.networking.extraHosts); + allHostsList = lib.mapAttrsToList getHostsForNode nodes; + allHosts = lib.concatStringsSep "\n" allHostsList; + + reIp = "[a-fA-F0-9.:]+"; + reHost = "[a-zA-Z0-9.-]+"; + + matchAliases = + str: + let + matched = builtins.match "[ \t]+(${reHost})(.*)" str; + continue = lib.singleton (lib.head matched) ++ matchAliases (lib.last matched); + in + lib.optional (matched != null) continue; + + matchLine = + str: + let + result = builtins.match "[ \t]*(${reIp})[ \t]+(${reHost})(.*)" str; + in + if result == null then + null + else + { + ipAddr = lib.head result; + hosts = lib.singleton (lib.elemAt result 1) ++ matchAliases (lib.last result); + }; + + skipLine = + str: + let + rest = builtins.match "[^\n]*\n(.*)" str; + in + if rest == null then "" else lib.head rest; + + getEntries = + str: acc: + let + result = matchLine str; + next = getEntries (skipLine str); + newEntry = acc ++ lib.singleton result; + continue = if result == null then next acc else next newEntry; + in + if str == "" then acc else continue; + + isIPv6 = str: builtins.match ".*:.*" str != null; + loopbackIps = [ + "127.0.0.1" + "::1" + ]; + filterLoopback = lib.filter (e: !lib.elem e.ipAddr loopbackIps); + + allEntries = lib.concatMap ( + entry: + map (host: { + inherit host; + ${if isIPv6 entry.ipAddr then "ipv6" else "ipv4"} = entry.ipAddr; + }) entry.hosts + ) (filterLoopback (getEntries (allHosts + "\n") [ ])); + + mkRecords = + entry: + let + records = + lib.optional (entry ? ipv6) "AAAA ${entry.ipv6}" + ++ lib.optional (entry ? ipv4) "A ${entry.ipv4}"; + mkRecord = typeAndData: "${entry.host}. IN ${typeAndData}"; + in + lib.concatMapStringsSep "\n" mkRecord records; + + in + lib.concatMapStringsSep "\n" mkRecords allEntries; + + # All of the zones that are subdomains of existing zones. + # For example if there is only "example.com" the following zones would + # be 'subZones': + # + # * foo.example.com. + # * bar.example.com. + # + # While the following would *not* be 'subZones': + # + # * example.com. + # * com. + # + subZones = + let + allZones = lib.concatMap (zi: zi.zones) zoneInfo; + isSubZoneOf = z1: z2: lib.hasSuffix z2 z1 && z1 != z2; + in + lib.filter (z: lib.any (isSubZoneOf z) allZones) allZones; + + # All the zones without 'subZones'. + filteredZoneInfo = map ( + zi: + zi + // { + zones = lib.filter (x: !lib.elem x subZones) zi.zones; + } + ) zoneInfo; + + in + pkgs.writeText "fake-root.zone" '' + $TTL 3600 + . IN SOA ns.fakedns. admin.fakedns. ( 1 3h 1h 1w 1d ) + ns.fakedns. IN A ${config.networking.primaryIPAddress} + . IN NS ns.fakedns. + ${lib.concatImapStrings ( + num: + { ip, zones }: + '' + ns${toString num}.fakedns. IN A ${ip} + ${lib.concatMapStrings (zone: '' + ${zone} IN NS ns${toString num}.fakedns. + '') zones} + '' + ) (lib.filter (zi: zi.zones != [ ]) filteredZoneInfo)} + ${recordsFromExtraHosts} + ''; }; }; } diff --git a/nixos/tests/common/user-account.nix b/nixos/tests/common/user-account.nix index a57ee2d59ae36e..f9fed2efe1a59e 100644 --- a/nixos/tests/common/user-account.nix +++ b/nixos/tests/common/user-account.nix @@ -1,15 +1,16 @@ { ... }: -{ users.users.alice = - { isNormalUser = true; - description = "Alice Foobar"; - password = "foobar"; - uid = 1000; - }; +{ + users.users.alice = { + isNormalUser = true; + description = "Alice Foobar"; + password = "foobar"; + uid = 1000; + }; - users.users.bob = - { isNormalUser = true; - description = "Bob Foobar"; - password = "foobar"; - }; + users.users.bob = { + isNormalUser = true; + description = "Bob Foobar"; + password = "foobar"; + }; } diff --git a/nixos/tests/connman.nix b/nixos/tests/connman.nix index 348b2a895a632a..8ab00de106018b 100644 --- a/nixos/tests/connman.nix +++ b/nixos/tests/connman.nix @@ -1,59 +1,67 @@ -import ./make-test-python.nix ({ pkgs, lib, ...}: -{ - name = "connman"; - meta = with lib.maintainers; { - maintainers = [ rnhmjoj ]; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "connman"; + meta = with lib.maintainers; { + maintainers = [ rnhmjoj ]; + }; - # Router running radvd on VLAN 1 - nodes.router = { ... }: { - imports = [ ../modules/profiles/minimal.nix ]; + # Router running radvd on VLAN 1 + nodes.router = + { ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; - virtualisation.vlans = [ 1 ]; + virtualisation.vlans = [ 1 ]; - boot.kernel.sysctl."net.ipv6.conf.all.forwarding" = true; + boot.kernel.sysctl."net.ipv6.conf.all.forwarding" = true; - networking = { - useDHCP = false; - interfaces.eth1.ipv6.addresses = - [ { address = "fd12::1"; prefixLength = 64; } ]; - }; + networking = { + useDHCP = false; + interfaces.eth1.ipv6.addresses = [ + { + address = "fd12::1"; + prefixLength = 64; + } + ]; + }; - services.radvd = { - enable = true; - config = '' - interface eth1 { - AdvSendAdvert on; - AdvManagedFlag on; - AdvOtherConfigFlag on; - prefix fd12::/64 { - AdvAutonomous off; - }; + services.radvd = { + enable = true; + config = '' + interface eth1 { + AdvSendAdvert on; + AdvManagedFlag on; + AdvOtherConfigFlag on; + prefix fd12::/64 { + AdvAutonomous off; + }; + }; + ''; }; - ''; - }; - }; + }; - # Client running connman, connected to VLAN 1 - nodes.client = { ... }: { - virtualisation.vlans = [ 1 ]; + # Client running connman, connected to VLAN 1 + nodes.client = + { ... }: + { + virtualisation.vlans = [ 1 ]; - # add a virtual wlan interface - boot.kernelModules = [ "mac80211_hwsim" ]; - boot.extraModprobeConfig = '' - options mac80211_hwsim radios=1 - ''; + # add a virtual wlan interface + boot.kernelModules = [ "mac80211_hwsim" ]; + boot.extraModprobeConfig = '' + options mac80211_hwsim radios=1 + ''; - # Note: the overrides are needed because the wifi is - # disabled with mkVMOverride in qemu-vm.nix. - services.connman.enable = lib.mkOverride 0 true; - services.connman.networkInterfaceBlacklist = [ "eth0" ]; - networking.wireless.enable = lib.mkOverride 0 true; - networking.wireless.interfaces = [ "wlan0" ]; - }; + # Note: the overrides are needed because the wifi is + # disabled with mkVMOverride in qemu-vm.nix. + services.connman.enable = lib.mkOverride 0 true; + services.connman.networkInterfaceBlacklist = [ "eth0" ]; + networking.wireless.enable = lib.mkOverride 0 true; + networking.wireless.interfaces = [ "wlan0" ]; + }; - testScript = - '' + testScript = '' start_all() with subtest("Router is ready"): @@ -73,5 +81,5 @@ import ./make-test-python.nix ({ pkgs, lib, ...}: client.wait_until_succeeds("connmanctl tether wifi on nixos-test reproducibility | grep -q 'Enabled'") client.wait_until_succeeds("iw wlan0 info | grep -q nixos-test") ''; -}) - + } +) diff --git a/nixos/tests/consul-template.nix b/nixos/tests/consul-template.nix index cbffa94569e38b..015e09111b3d1e 100644 --- a/nixos/tests/consul-template.nix +++ b/nixos/tests/consul-template.nix @@ -1,36 +1,43 @@ -import ./make-test-python.nix ({ ... }: { - name = "consul-template"; +import ./make-test-python.nix ( + { ... }: + { + name = "consul-template"; - nodes.machine = { ... }: { - services.consul-template.instances.example.settings = { - template = [{ - contents = '' - {{ key "example" }} - ''; - perms = "0600"; - destination = "/example"; - }]; - }; + nodes.machine = + { ... }: + { + services.consul-template.instances.example.settings = { + template = [ + { + contents = '' + {{ key "example" }} + ''; + perms = "0600"; + destination = "/example"; + } + ]; + }; - services.consul = { - enable = true; - extraConfig = { - server = true; - bootstrap_expect = 1; - bind_addr = "127.0.0.1"; + services.consul = { + enable = true; + extraConfig = { + server = true; + bootstrap_expect = 1; + bind_addr = "127.0.0.1"; + }; + }; }; - }; - }; - testScript = '' - machine.wait_for_unit("consul.service") - machine.wait_for_open_port(8500) + testScript = '' + machine.wait_for_unit("consul.service") + machine.wait_for_open_port(8500) - machine.wait_for_unit("consul-template-example.service") + machine.wait_for_unit("consul-template-example.service") - machine.wait_until_succeeds('consul kv put example example') + machine.wait_until_succeeds('consul kv put example example') - machine.wait_for_file("/example") - machine.succeed('grep "example" /example') - ''; -}) + machine.wait_for_file("/example") + machine.succeed('grep "example" /example') + ''; + } +) diff --git a/nixos/tests/consul.nix b/nixos/tests/consul.nix index c819312068dc75..253d70f13b5988 100644 --- a/nixos/tests/consul.nix +++ b/nixos/tests/consul.nix @@ -1,44 +1,60 @@ -import ./make-test-python.nix ({pkgs, lib, ...}: - -let - # Settings for both servers and agents - webUi = true; - retry_interval = "1s"; - raft_multiplier = 1; - - defaultExtraConfig = { - inherit retry_interval; - performance = { - inherit raft_multiplier; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + let + # Settings for both servers and agents + webUi = true; + retry_interval = "1s"; + raft_multiplier = 1; + + defaultExtraConfig = { + inherit retry_interval; + performance = { + inherit raft_multiplier; + }; + }; + + allConsensusServerHosts = [ + "192.168.1.1" + "192.168.1.2" + "192.168.1.3" + ]; + + allConsensusClientHosts = [ + "192.168.2.1" + "192.168.2.2" + ]; + + firewallSettings = { + # See https://www.consul.io/docs/install/ports.html + allowedTCPPorts = [ + 8301 + 8302 + 8600 + 8500 + 8300 + ]; + allowedUDPPorts = [ + 8301 + 8302 + 8600 + ]; }; - }; - - allConsensusServerHosts = [ - "192.168.1.1" - "192.168.1.2" - "192.168.1.3" - ]; - - allConsensusClientHosts = [ - "192.168.2.1" - "192.168.2.2" - ]; - - firewallSettings = { - # See https://www.consul.io/docs/install/ports.html - allowedTCPPorts = [ 8301 8302 8600 8500 8300 ]; - allowedUDPPorts = [ 8301 8302 8600 ]; - }; - - client = index: { pkgs, ... }: - let - ip = builtins.elemAt allConsensusClientHosts index; - in + + client = + index: + { pkgs, ... }: + let + ip = builtins.elemAt allConsensusClientHosts index; + in { environment.systemPackages = [ pkgs.consul ]; networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = ip; prefixLength = 16; } + { + address = ip; + prefixLength = 16; + } ]; networking.firewall = firewallSettings; @@ -55,15 +71,20 @@ let }; }; - server = index: { pkgs, ... }: - let - numConsensusServers = builtins.length allConsensusServerHosts; - thisConsensusServerHost = builtins.elemAt allConsensusServerHosts index; - ip = thisConsensusServerHost; # since we already use IPs to identify servers - in + server = + index: + { pkgs, ... }: + let + numConsensusServers = builtins.length allConsensusServerHosts; + thisConsensusServerHost = builtins.elemAt allConsensusServerHosts index; + ip = thisConsensusServerHost; # since we already use IPs to identify servers + in { networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = ip; prefixLength = 16; } + { + address = ip; + prefixLength = 16; + } ]; networking.firewall = firewallSettings; @@ -85,159 +106,162 @@ let # If there's only 1 node in the network, we allow self-join; # otherwise, the node must not try to join itself, and join only the other servers. # See https://github.com/hashicorp/consul/issues/2868 - if numConsensusServers == 1 - then allConsensusServerHosts - else builtins.filter (h: h != thisConsensusServerHost) allConsensusServerHosts; + if numConsensusServers == 1 then + allConsensusServerHosts + else + builtins.filter (h: h != thisConsensusServerHost) allConsensusServerHosts; bind_addr = ip; }; }; }; -in { - name = "consul"; - - nodes = { - server1 = server 0; - server2 = server 1; - server3 = server 2; - - client1 = client 0; - client2 = client 1; - }; - - testScript = '' - servers = [server1, server2, server3] - machines = [server1, server2, server3, client1, client2] - - for m in machines: - m.wait_for_unit("consul.service") - - - def wait_for_healthy_servers(): - # See https://github.com/hashicorp/consul/issues/8118#issuecomment-645330040 - # for why the `Voter` column of `list-peers` has that info. - # TODO: The `grep true` relies on the fact that currently in - # the output like - # # consul operator raft list-peers - # Node ID Address State Voter RaftProtocol - # server3 ... 192.168.1.3:8300 leader true 3 - # server2 ... 192.168.1.2:8300 follower true 3 - # server1 ... 192.168.1.1:8300 follower false 3 - # `Voter`is the only boolean column. - # Change this to the more reliable way to be defined by - # https://github.com/hashicorp/consul/issues/8118 - # once that ticket is closed. - for m in machines: - m.wait_until_succeeds( - "[ $(consul operator raft list-peers | grep true | wc -l) == 3 ]" - ) - - - def wait_for_all_machines_alive(): - """ - Note that Serf-"alive" does not mean "Raft"-healthy; - see `wait_for_healthy_servers()` for that instead. - """ - for m in machines: - m.wait_until_succeeds("[ $(consul members | grep -o alive | wc -l) == 5 ]") - - - wait_for_healthy_servers() - # Also wait for clients to be alive. - wait_for_all_machines_alive() - - client1.succeed("consul kv put testkey 42") - client2.succeed("[ $(consul kv get testkey) == 42 ]") - - - def rolling_restart_test(proper_rolling_procedure=True): - """ - Tests that the cluster can tolearate failures of any single server, - following the recommended rolling upgrade procedure from - https://www.consul.io/docs/upgrading#standard-upgrades. - - Optionally, `proper_rolling_procedure=False` can be given - to wait only for each server to be back `Healthy`, not `Stable` - in the Raft consensus, see Consul setting `ServerStabilizationTime` and - https://github.com/hashicorp/consul/issues/8118#issuecomment-645330040. - """ - - for server in servers: - server.block() - server.systemctl("stop consul") - - # Make sure the stopped peer is recognized as being down - client1.wait_until_succeeds( - f"[ $(consul members | grep {server.name} | grep -o -E 'failed|left' | wc -l) == 1 ]" - ) - - # For each client, wait until they have connection again - # using `kv get -recurse` before issuing commands. - client1.wait_until_succeeds("consul kv get -recurse") - client2.wait_until_succeeds("consul kv get -recurse") - - # Do some consul actions while one server is down. - client1.succeed("consul kv put testkey 43") - client2.succeed("[ $(consul kv get testkey) == 43 ]") - client2.succeed("consul kv delete testkey") - - server.unblock() - server.systemctl("start consul") - - if proper_rolling_procedure: - # Wait for recovery. - wait_for_healthy_servers() - else: - # NOT proper rolling upgrade procedure, see above. - wait_for_all_machines_alive() - - # Wait for client connections. - client1.wait_until_succeeds("consul kv get -recurse") - client2.wait_until_succeeds("consul kv get -recurse") - - # Do some consul actions with server back up. - client1.succeed("consul kv put testkey 44") - client2.succeed("[ $(consul kv get testkey) == 44 ]") - client2.succeed("consul kv delete testkey") - - - def all_servers_crash_simultaneously_test(): - """ - Tests that the cluster will eventually come back after all - servers crash simultaneously. - """ - - for server in servers: - server.block() - server.systemctl("stop --no-block consul") - - for server in servers: - # --no-block is async, so ensure it has been stopped by now - server.wait_until_fails("systemctl is-active --quiet consul") - server.unblock() - server.systemctl("start consul") - - # Wait for recovery. - wait_for_healthy_servers() - - # Wait for client connections. - client1.wait_until_succeeds("consul kv get -recurse") - client2.wait_until_succeeds("consul kv get -recurse") - - # Do some consul actions with servers back up. - client1.succeed("consul kv put testkey 44") - client2.succeed("[ $(consul kv get testkey) == 44 ]") - client2.succeed("consul kv delete testkey") + in + { + name = "consul"; + + nodes = { + server1 = server 0; + server2 = server 1; + server3 = server 2; + + client1 = client 0; + client2 = client 1; + }; + + testScript = '' + servers = [server1, server2, server3] + machines = [server1, server2, server3, client1, client2] + + for m in machines: + m.wait_for_unit("consul.service") + + + def wait_for_healthy_servers(): + # See https://github.com/hashicorp/consul/issues/8118#issuecomment-645330040 + # for why the `Voter` column of `list-peers` has that info. + # TODO: The `grep true` relies on the fact that currently in + # the output like + # # consul operator raft list-peers + # Node ID Address State Voter RaftProtocol + # server3 ... 192.168.1.3:8300 leader true 3 + # server2 ... 192.168.1.2:8300 follower true 3 + # server1 ... 192.168.1.1:8300 follower false 3 + # `Voter`is the only boolean column. + # Change this to the more reliable way to be defined by + # https://github.com/hashicorp/consul/issues/8118 + # once that ticket is closed. + for m in machines: + m.wait_until_succeeds( + "[ $(consul operator raft list-peers | grep true | wc -l) == 3 ]" + ) + + + def wait_for_all_machines_alive(): + """ + Note that Serf-"alive" does not mean "Raft"-healthy; + see `wait_for_healthy_servers()` for that instead. + """ + for m in machines: + m.wait_until_succeeds("[ $(consul members | grep -o alive | wc -l) == 5 ]") + + + wait_for_healthy_servers() + # Also wait for clients to be alive. + wait_for_all_machines_alive() + + client1.succeed("consul kv put testkey 42") + client2.succeed("[ $(consul kv get testkey) == 42 ]") + + + def rolling_restart_test(proper_rolling_procedure=True): + """ + Tests that the cluster can tolearate failures of any single server, + following the recommended rolling upgrade procedure from + https://www.consul.io/docs/upgrading#standard-upgrades. + + Optionally, `proper_rolling_procedure=False` can be given + to wait only for each server to be back `Healthy`, not `Stable` + in the Raft consensus, see Consul setting `ServerStabilizationTime` and + https://github.com/hashicorp/consul/issues/8118#issuecomment-645330040. + """ + + for server in servers: + server.block() + server.systemctl("stop consul") + + # Make sure the stopped peer is recognized as being down + client1.wait_until_succeeds( + f"[ $(consul members | grep {server.name} | grep -o -E 'failed|left' | wc -l) == 1 ]" + ) + + # For each client, wait until they have connection again + # using `kv get -recurse` before issuing commands. + client1.wait_until_succeeds("consul kv get -recurse") + client2.wait_until_succeeds("consul kv get -recurse") + + # Do some consul actions while one server is down. + client1.succeed("consul kv put testkey 43") + client2.succeed("[ $(consul kv get testkey) == 43 ]") + client2.succeed("consul kv delete testkey") + + server.unblock() + server.systemctl("start consul") + + if proper_rolling_procedure: + # Wait for recovery. + wait_for_healthy_servers() + else: + # NOT proper rolling upgrade procedure, see above. + wait_for_all_machines_alive() + + # Wait for client connections. + client1.wait_until_succeeds("consul kv get -recurse") + client2.wait_until_succeeds("consul kv get -recurse") + + # Do some consul actions with server back up. + client1.succeed("consul kv put testkey 44") + client2.succeed("[ $(consul kv get testkey) == 44 ]") + client2.succeed("consul kv delete testkey") + + + def all_servers_crash_simultaneously_test(): + """ + Tests that the cluster will eventually come back after all + servers crash simultaneously. + """ + + for server in servers: + server.block() + server.systemctl("stop --no-block consul") + + for server in servers: + # --no-block is async, so ensure it has been stopped by now + server.wait_until_fails("systemctl is-active --quiet consul") + server.unblock() + server.systemctl("start consul") + + # Wait for recovery. + wait_for_healthy_servers() + + # Wait for client connections. + client1.wait_until_succeeds("consul kv get -recurse") + client2.wait_until_succeeds("consul kv get -recurse") + + # Do some consul actions with servers back up. + client1.succeed("consul kv put testkey 44") + client2.succeed("[ $(consul kv get testkey) == 44 ]") + client2.succeed("consul kv delete testkey") - # Run the tests. + # Run the tests. - print("rolling_restart_test()") - rolling_restart_test() - - print("all_servers_crash_simultaneously_test()") - all_servers_crash_simultaneously_test() + print("rolling_restart_test()") + rolling_restart_test() + + print("all_servers_crash_simultaneously_test()") + all_servers_crash_simultaneously_test() - print("rolling_restart_test(proper_rolling_procedure=False)") - rolling_restart_test(proper_rolling_procedure=False) - ''; -}) + print("rolling_restart_test(proper_rolling_procedure=False)") + rolling_restart_test(proper_rolling_procedure=False) + ''; + } +) diff --git a/nixos/tests/containers-bridge.nix b/nixos/tests/containers-bridge.nix index 3001db33ba5a3f..a8e9f574924fca 100644 --- a/nixos/tests/containers-bridge.nix +++ b/nixos/tests/containers-bridge.nix @@ -5,95 +5,110 @@ let containerIp6 = "fc00::2/7"; in -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "containers-bridge"; - meta = { - maintainers = with lib.maintainers; [ aristid aszlig kampfschlaefer ]; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-bridge"; + meta = { + maintainers = with lib.maintainers; [ + aristid + aszlig + kampfschlaefer + ]; + }; - nodes.machine = - { pkgs, ... }: - { imports = [ ../modules/installer/cd-dvd/channel.nix ]; - virtualisation.writableStore = true; + nodes.machine = + { pkgs, ... }: + { + imports = [ ../modules/installer/cd-dvd/channel.nix ]; + virtualisation.writableStore = true; - networking.bridges = { - br0 = { - interfaces = []; + networking.bridges = { + br0 = { + interfaces = [ ]; + }; }; - }; - networking.interfaces = { - br0 = { - ipv4.addresses = [{ address = hostIp; prefixLength = 24; }]; - ipv6.addresses = [{ address = hostIp6; prefixLength = 7; }]; + networking.interfaces = { + br0 = { + ipv4.addresses = [ + { + address = hostIp; + prefixLength = 24; + } + ]; + ipv6.addresses = [ + { + address = hostIp6; + prefixLength = 7; + } + ]; + }; }; - }; - containers.webserver = - { + containers.webserver = { autoStart = true; privateNetwork = true; hostBridge = "br0"; localAddress = containerIp; localAddress6 = containerIp6; - config = - { services.httpd.enable = true; - services.httpd.adminAddr = "foo@example.org"; - networking.firewall.allowedTCPPorts = [ 80 ]; - }; + config = { + services.httpd.enable = true; + services.httpd.adminAddr = "foo@example.org"; + networking.firewall.allowedTCPPorts = [ 80 ]; + }; }; - containers.web-noip = - { + containers.web-noip = { autoStart = true; privateNetwork = true; hostBridge = "br0"; - config = - { services.httpd.enable = true; - services.httpd.adminAddr = "foo@example.org"; - networking.firewall.allowedTCPPorts = [ 80 ]; - }; + config = { + services.httpd.enable = true; + services.httpd.adminAddr = "foo@example.org"; + networking.firewall.allowedTCPPorts = [ 80 ]; + }; }; + virtualisation.additionalPaths = [ pkgs.stdenv ]; + }; - virtualisation.additionalPaths = [ pkgs.stdenv ]; - }; - - testScript = '' - machine.wait_for_unit("default.target") - assert "webserver" in machine.succeed("nixos-container list") + testScript = '' + machine.wait_for_unit("default.target") + assert "webserver" in machine.succeed("nixos-container list") - with subtest("Start the webserver container"): - assert "up" in machine.succeed("nixos-container status webserver") + with subtest("Start the webserver container"): + assert "up" in machine.succeed("nixos-container status webserver") - with subtest("Bridges exist inside containers"): - machine.succeed( - "nixos-container run webserver -- ip link show eth0", - "nixos-container run web-noip -- ip link show eth0", - ) + with subtest("Bridges exist inside containers"): + machine.succeed( + "nixos-container run webserver -- ip link show eth0", + "nixos-container run web-noip -- ip link show eth0", + ) - ip = "${containerIp}".split("/")[0] - machine.succeed(f"ping -n -c 1 {ip}") - machine.succeed(f"curl --fail http://{ip}/ > /dev/null") + ip = "${containerIp}".split("/")[0] + machine.succeed(f"ping -n -c 1 {ip}") + machine.succeed(f"curl --fail http://{ip}/ > /dev/null") - ip6 = "${containerIp6}".split("/")[0] - machine.succeed(f"ping -n -c 1 {ip6}") - machine.succeed(f"curl --fail http://[{ip6}]/ > /dev/null") + ip6 = "${containerIp6}".split("/")[0] + machine.succeed(f"ping -n -c 1 {ip6}") + machine.succeed(f"curl --fail http://[{ip6}]/ > /dev/null") - with subtest( - "nixos-container show-ip works in case of an ipv4 address " - + "with subnetmask in CIDR notation." - ): - result = machine.succeed("nixos-container show-ip webserver").rstrip() - assert result == ip + with subtest( + "nixos-container show-ip works in case of an ipv4 address " + + "with subnetmask in CIDR notation." + ): + result = machine.succeed("nixos-container show-ip webserver").rstrip() + assert result == ip - with subtest("Stop the container"): - machine.succeed("nixos-container stop webserver") - machine.fail( - f"curl --fail --connect-timeout 2 http://{ip}/ > /dev/null", - f"curl --fail --connect-timeout 2 http://[{ip6}]/ > /dev/null", - ) + with subtest("Stop the container"): + machine.succeed("nixos-container stop webserver") + machine.fail( + f"curl --fail --connect-timeout 2 http://{ip}/ > /dev/null", + f"curl --fail --connect-timeout 2 http://[{ip6}]/ > /dev/null", + ) - # Destroying a declarative container should fail. - machine.fail("nixos-container destroy webserver") - ''; -}) + # Destroying a declarative container should fail. + machine.fail("nixos-container destroy webserver") + ''; + } +) diff --git a/nixos/tests/containers-custom-pkgs.nix b/nixos/tests/containers-custom-pkgs.nix index 57184787c85f64..74b1ea207b6832 100644 --- a/nixos/tests/containers-custom-pkgs.nix +++ b/nixos/tests/containers-custom-pkgs.nix @@ -1,34 +1,48 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: let +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let - customPkgs = pkgs.appendOverlays [ (self: super: { - hello = super.hello.overrideAttrs (old: { - name = "custom-hello"; - }); - }) ]; + customPkgs = pkgs.appendOverlays [ + (self: super: { + hello = super.hello.overrideAttrs (old: { + name = "custom-hello"; + }); + }) + ]; -in { - name = "containers-custom-pkgs"; - meta = { - maintainers = with lib.maintainers; [ erikarvstedt ]; - }; + in + { + name = "containers-custom-pkgs"; + meta = { + maintainers = with lib.maintainers; [ erikarvstedt ]; + }; - nodes.machine = { config, ... }: { - assertions = let - helloName = (builtins.head config.containers.test.config.system.extraDependencies).name; - in [ { - assertion = helloName == "custom-hello"; - message = "Unexpected value: ${helloName}"; - } ]; + nodes.machine = + { config, ... }: + { + assertions = + let + helloName = (builtins.head config.containers.test.config.system.extraDependencies).name; + in + [ + { + assertion = helloName == "custom-hello"; + message = "Unexpected value: ${helloName}"; + } + ]; - containers.test = { - autoStart = true; - config = { pkgs, config, ... }: { - nixpkgs.pkgs = customPkgs; - system.extraDependencies = [ pkgs.hello ]; + containers.test = { + autoStart = true; + config = + { pkgs, config, ... }: + { + nixpkgs.pkgs = customPkgs; + system.extraDependencies = [ pkgs.hello ]; + }; + }; }; - }; - }; - # This test only consists of evaluating the test machine - testScript = "pass"; -}) + # This test only consists of evaluating the test machine + testScript = "pass"; + } +) diff --git a/nixos/tests/containers-ephemeral.nix b/nixos/tests/containers-ephemeral.nix index cb4b7d4eba0fd6..5204ba67e26b8a 100644 --- a/nixos/tests/containers-ephemeral.nix +++ b/nixos/tests/containers-ephemeral.nix @@ -1,54 +1,59 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "containers-ephemeral"; - meta = { - maintainers = with lib.maintainers; [ patryk27 ]; - }; - - nodes.machine = { pkgs, ... }: { - virtualisation.writableStore = true; - - containers.webserver = { - ephemeral = true; - privateNetwork = true; - hostAddress = "10.231.136.1"; - localAddress = "10.231.136.2"; - config = { - services.nginx = { - enable = true; - virtualHosts.localhost = { - root = pkgs.runCommand "localhost" {} '' - mkdir "$out" - echo hello world > "$out/index.html" - ''; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-ephemeral"; + meta = { + maintainers = with lib.maintainers; [ patryk27 ]; + }; + + nodes.machine = + { pkgs, ... }: + { + virtualisation.writableStore = true; + + containers.webserver = { + ephemeral = true; + privateNetwork = true; + hostAddress = "10.231.136.1"; + localAddress = "10.231.136.2"; + config = { + services.nginx = { + enable = true; + virtualHosts.localhost = { + root = pkgs.runCommand "localhost" { } '' + mkdir "$out" + echo hello world > "$out/index.html" + ''; + }; + }; + networking.firewall.allowedTCPPorts = [ 80 ]; }; }; - networking.firewall.allowedTCPPorts = [ 80 ]; }; - }; - }; - testScript = '' - assert "webserver" in machine.succeed("nixos-container list") + testScript = '' + assert "webserver" in machine.succeed("nixos-container list") - machine.succeed("nixos-container start webserver") + machine.succeed("nixos-container start webserver") - with subtest("Container got its own root folder"): - machine.succeed("ls /run/nixos-containers/webserver") + with subtest("Container got its own root folder"): + machine.succeed("ls /run/nixos-containers/webserver") - with subtest("Container persistent directory is not created"): - machine.fail("ls /var/lib/nixos-containers/webserver") + with subtest("Container persistent directory is not created"): + machine.fail("ls /var/lib/nixos-containers/webserver") - # Since "start" returns after the container has reached - # multi-user.target, we should now be able to access it. - ip = machine.succeed("nixos-container show-ip webserver").rstrip() - machine.succeed(f"ping -n -c1 {ip}") - machine.succeed(f"curl --fail http://{ip}/ > /dev/null") + # Since "start" returns after the container has reached + # multi-user.target, we should now be able to access it. + ip = machine.succeed("nixos-container show-ip webserver").rstrip() + machine.succeed(f"ping -n -c1 {ip}") + machine.succeed(f"curl --fail http://{ip}/ > /dev/null") - with subtest("Stop the container"): - machine.succeed("nixos-container stop webserver") - machine.fail(f"curl --fail --connect-timeout 2 http://{ip}/ > /dev/null") + with subtest("Stop the container"): + machine.succeed("nixos-container stop webserver") + machine.fail(f"curl --fail --connect-timeout 2 http://{ip}/ > /dev/null") - with subtest("Container's root folder was removed"): - machine.fail("ls /run/nixos-containers/webserver") - ''; -}) + with subtest("Container's root folder was removed"): + machine.fail("ls /run/nixos-containers/webserver") + ''; + } +) diff --git a/nixos/tests/containers-extra_veth.nix b/nixos/tests/containers-extra_veth.nix index f3e62265f6c4f4..ed3b8099036b62 100644 --- a/nixos/tests/containers-extra_veth.nix +++ b/nixos/tests/containers-extra_veth.nix @@ -1,54 +1,77 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "containers-extra_veth"; - meta = { - maintainers = with lib.maintainers; [ kampfschlaefer ]; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-extra_veth"; + meta = { + maintainers = with lib.maintainers; [ kampfschlaefer ]; + }; - nodes.machine = - { pkgs, ... }: - { imports = [ ../modules/installer/cd-dvd/channel.nix ]; - virtualisation.writableStore = true; - virtualisation.vlans = []; + nodes.machine = + { pkgs, ... }: + { + imports = [ ../modules/installer/cd-dvd/channel.nix ]; + virtualisation.writableStore = true; + virtualisation.vlans = [ ]; - networking.useDHCP = false; - networking.bridges = { - br0 = { - interfaces = []; - }; - br1 = { interfaces = []; }; - }; - networking.interfaces = { - br0 = { - ipv4.addresses = [{ address = "192.168.0.1"; prefixLength = 24; }]; - ipv6.addresses = [{ address = "fc00::1"; prefixLength = 7; }]; + networking.useDHCP = false; + networking.bridges = { + br0 = { + interfaces = [ ]; + }; + br1 = { + interfaces = [ ]; + }; }; - br1 = { - ipv4.addresses = [{ address = "192.168.1.1"; prefixLength = 24; }]; + networking.interfaces = { + br0 = { + ipv4.addresses = [ + { + address = "192.168.0.1"; + prefixLength = 24; + } + ]; + ipv6.addresses = [ + { + address = "fc00::1"; + prefixLength = 7; + } + ]; + }; + br1 = { + ipv4.addresses = [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; + }; }; - }; - containers.webserver = - { + containers.webserver = { autoStart = true; privateNetwork = true; hostBridge = "br0"; localAddress = "192.168.0.100/24"; localAddress6 = "fc00::2/7"; extraVeths = { - veth1 = { hostBridge = "br1"; localAddress = "192.168.1.100/24"; }; - veth2 = { hostAddress = "192.168.2.1"; localAddress = "192.168.2.100"; }; - }; - config = - { - networking.firewall.allowedTCPPorts = [ 80 ]; + veth1 = { + hostBridge = "br1"; + localAddress = "192.168.1.100/24"; }; + veth2 = { + hostAddress = "192.168.2.1"; + localAddress = "192.168.2.100"; + }; + }; + config = { + networking.firewall.allowedTCPPorts = [ 80 ]; + }; }; - virtualisation.additionalPaths = [ pkgs.stdenv ]; - }; + virtualisation.additionalPaths = [ pkgs.stdenv ]; + }; - testScript = - '' + testScript = '' machine.wait_for_unit("default.target") assert "webserver" in machine.succeed("nixos-container list") @@ -88,4 +111,5 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: { with subtest("Destroying a declarative container should fail"): machine.fail("nixos-container destroy webserver") ''; -}) + } +) diff --git a/nixos/tests/containers-hosts.nix b/nixos/tests/containers-hosts.nix index 7bce7c997efee4..0e5f50f5292c1b 100644 --- a/nixos/tests/containers-hosts.nix +++ b/nixos/tests/containers-hosts.nix @@ -1,49 +1,55 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "containers-hosts"; - meta = { - maintainers = with lib.maintainers; [ montag451 ]; - }; - - nodes.machine = - { lib, ... }: - { - virtualisation.vlans = []; - - networking.bridges.br0.interfaces = []; - networking.interfaces.br0.ipv4.addresses = [ - { address = "10.11.0.254"; prefixLength = 24; } - ]; - - # Force /etc/hosts to be the only source for host name resolution - environment.etc."nsswitch.conf".text = lib.mkForce '' - hosts: files - ''; - - containers.simple = { - autoStart = true; - privateNetwork = true; - localAddress = "10.10.0.1"; - hostAddress = "10.10.0.254"; - - config = {}; - }; - - containers.netmask = { - autoStart = true; - privateNetwork = true; - hostBridge = "br0"; - localAddress = "10.11.0.1/24"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-hosts"; + meta = { + maintainers = with lib.maintainers; [ montag451 ]; + }; - config = {}; + nodes.machine = + { lib, ... }: + { + virtualisation.vlans = [ ]; + + networking.bridges.br0.interfaces = [ ]; + networking.interfaces.br0.ipv4.addresses = [ + { + address = "10.11.0.254"; + prefixLength = 24; + } + ]; + + # Force /etc/hosts to be the only source for host name resolution + environment.etc."nsswitch.conf".text = lib.mkForce '' + hosts: files + ''; + + containers.simple = { + autoStart = true; + privateNetwork = true; + localAddress = "10.10.0.1"; + hostAddress = "10.10.0.254"; + + config = { }; + }; + + containers.netmask = { + autoStart = true; + privateNetwork = true; + hostBridge = "br0"; + localAddress = "10.11.0.1/24"; + + config = { }; + }; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("default.target") + testScript = '' + start_all() + machine.wait_for_unit("default.target") - with subtest("Ping the containers using the entries added in /etc/hosts"): - for host in "simple.containers", "netmask.containers": - machine.succeed(f"ping -n -c 1 {host}") - ''; -}) + with subtest("Ping the containers using the entries added in /etc/hosts"): + for host in "simple.containers", "netmask.containers": + machine.succeed(f"ping -n -c 1 {host}") + ''; + } +) diff --git a/nixos/tests/containers-imperative.nix b/nixos/tests/containers-imperative.nix index c654c437880783..f1bd56519c6d2d 100644 --- a/nixos/tests/containers-imperative.nix +++ b/nixos/tests/containers-imperative.nix @@ -1,171 +1,197 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "containers-imperative"; - meta = { - maintainers = with lib.maintainers; [ aristid aszlig kampfschlaefer ]; - }; - - nodes.machine = - { config, pkgs, lib, ... }: - { imports = [ ../modules/installer/cd-dvd/channel.nix ]; - - # XXX: Sandbox setup fails while trying to hardlink files from the host's - # store file system into the prepared chroot directory. - nix.settings.sandbox = false; - nix.settings.substituters = []; # don't try to access cache.nixos.org - - virtualisation.memorySize = 2048; - virtualisation.writableStore = true; - # Make sure we always have all the required dependencies for creating a - # container available within the VM, because we don't have network access. - virtualisation.additionalPaths = let - emptyContainer = import ../lib/eval-config.nix { - modules = lib.singleton { - nixpkgs = { inherit (config.nixpkgs) localSystem; }; - - containers.foo.config = {}; - }; - - # The system is inherited from the host above. - # Set it to null, to remove the "legacy" entrypoint's non-hermetic default. - system = null; - }; - in with pkgs; [ - stdenv stdenvNoCC emptyContainer.config.containers.foo.path - libxslt desktop-file-utils texinfo docbook5 libxml2 - docbook_xsl_ns xorg.lndir documentation-highlighter - perlPackages.ConfigIniFiles +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-imperative"; + meta = { + maintainers = with lib.maintainers; [ + aristid + aszlig + kampfschlaefer ]; }; - testScript = let - tmpfilesContainerConfig = pkgs.writeText "container-config-tmpfiles" '' - { - systemd.tmpfiles.rules = [ "d /foo - - - - -" ]; - systemd.services.foo = { - serviceConfig.Type = "oneshot"; - script = "ls -al /foo"; - wantedBy = [ "multi-user.target" ]; - }; - } - ''; - brokenCfg = pkgs.writeText "broken.nix" '' - { - assertions = [ - { assertion = false; - message = "I never evaluate"; - } + nodes.machine = + { + config, + pkgs, + lib, + ... + }: + { + imports = [ ../modules/installer/cd-dvd/channel.nix ]; + + # XXX: Sandbox setup fails while trying to hardlink files from the host's + # store file system into the prepared chroot directory. + nix.settings.sandbox = false; + nix.settings.substituters = [ ]; # don't try to access cache.nixos.org + + virtualisation.memorySize = 2048; + virtualisation.writableStore = true; + # Make sure we always have all the required dependencies for creating a + # container available within the VM, because we don't have network access. + virtualisation.additionalPaths = + let + emptyContainer = import ../lib/eval-config.nix { + modules = lib.singleton { + nixpkgs = { inherit (config.nixpkgs) localSystem; }; + + containers.foo.config = { }; + }; + + # The system is inherited from the host above. + # Set it to null, to remove the "legacy" entrypoint's non-hermetic default. + system = null; + }; + in + with pkgs; + [ + stdenv + stdenvNoCC + emptyContainer.config.containers.foo.path + libxslt + desktop-file-utils + texinfo + docbook5 + libxml2 + docbook_xsl_ns + xorg.lndir + documentation-highlighter + perlPackages.ConfigIniFiles ]; - } + }; + + testScript = + let + tmpfilesContainerConfig = pkgs.writeText "container-config-tmpfiles" '' + { + systemd.tmpfiles.rules = [ "d /foo - - - - -" ]; + systemd.services.foo = { + serviceConfig.Type = "oneshot"; + script = "ls -al /foo"; + wantedBy = [ "multi-user.target" ]; + }; + } + ''; + brokenCfg = pkgs.writeText "broken.nix" '' + { + assertions = [ + { assertion = false; + message = "I never evaluate"; + } + ]; + } + ''; + in + '' + with subtest("Make sure we have a NixOS tree (required by ‘nixos-container create’)"): + machine.succeed("PAGER=cat nix-env -qa -A nixos.hello >&2") + + id1, id2 = None, None + + with subtest("Create some containers imperatively"): + id1 = machine.succeed("nixos-container create foo --ensure-unique-name").rstrip() + machine.log(f"created container {id1}") + + id2 = machine.succeed("nixos-container create foo --ensure-unique-name").rstrip() + machine.log(f"created container {id2}") + + assert id1 != id2 + + with subtest(f"Put the root of {id2} into a bind mount"): + machine.succeed( + f"mv /var/lib/nixos-containers/{id2} /id2-bindmount", + f"mount --bind /id2-bindmount /var/lib/nixos-containers/{id1}", + ) + + ip1 = machine.succeed(f"nixos-container show-ip {id1}").rstrip() + ip2 = machine.succeed(f"nixos-container show-ip {id2}").rstrip() + assert ip1 != ip2 + + with subtest( + "Create a directory and a file we can later check if it still exists " + + "after destruction of the container" + ): + machine.succeed("mkdir /nested-bindmount") + machine.succeed("echo important data > /nested-bindmount/dummy") + + with subtest( + "Create a directory with a dummy file and bind-mount it into both containers." + ): + for id in id1, id2: + important_path = f"/var/lib/nixos-containers/{id}/very/important/data" + machine.succeed( + f"mkdir -p {important_path}", + f"mount --bind /nested-bindmount {important_path}", + ) + + with subtest("Start one of them"): + machine.succeed(f"nixos-container start {id1}") + + with subtest("Execute commands via the root shell"): + assert "Linux" in machine.succeed(f"nixos-container run {id1} -- uname") + + with subtest("Execute a nix command via the root shell. (regression test for #40355)"): + machine.succeed( + f"nixos-container run {id1} -- nix-instantiate -E " + + '\'derivation { name = "empty"; builder = "false"; system = "false"; }\' ' + ) + + with subtest("Stop and start (regression test for #4989)"): + machine.succeed(f"nixos-container stop {id1}") + machine.succeed(f"nixos-container start {id1}") + + # clear serial backlog for next tests + machine.succeed("logger eat console backlog 3ea46eb2-7f82-4f70-b810-3f00e3dd4c4d") + machine.wait_for_console_text( + "eat console backlog 3ea46eb2-7f82-4f70-b810-3f00e3dd4c4d" + ) + + with subtest("Stop a container early"): + machine.succeed(f"nixos-container stop {id1}") + machine.succeed(f"nixos-container start {id1} >&2 &") + machine.wait_for_console_text("Stage 2") + machine.succeed(f"nixos-container stop {id1}") + machine.wait_for_console_text(f"Container {id1} exited successfully") + machine.succeed(f"nixos-container start {id1}") + + with subtest("Stop a container without machined (regression test for #109695)"): + machine.systemctl("stop systemd-machined") + machine.succeed(f"nixos-container stop {id1}") + machine.wait_for_console_text(f"Container {id1} has been shut down") + machine.succeed(f"nixos-container start {id1}") + + with subtest("tmpfiles are present"): + machine.log("creating container tmpfiles") + machine.succeed( + "nixos-container create tmpfiles --config-file ${tmpfilesContainerConfig}" + ) + machine.log("created, starting…") + machine.succeed("nixos-container start tmpfiles") + machine.log("done starting, investigating…") + machine.succeed( + "echo $(nixos-container run tmpfiles -- systemctl is-active foo.service) | grep -q active;" + ) + machine.succeed("nixos-container destroy tmpfiles") + + with subtest("Execute commands via the root shell"): + assert "Linux" in machine.succeed(f"nixos-container run {id1} -- uname") + + with subtest("Destroy the containers"): + for id in id1, id2: + machine.succeed(f"nixos-container destroy {id}") + + with subtest("Check whether destruction of any container has killed important data"): + machine.succeed("grep -qF 'important data' /nested-bindmount/dummy") + + with subtest("Ensure that the container path is gone"): + print(machine.succeed("ls -lsa /var/lib/nixos-containers")) + machine.succeed(f"test ! -e /var/lib/nixos-containers/{id1}") + + with subtest("Ensure that a failed container creation doesn'leave any state"): + machine.fail( + "nixos-container create b0rk --config-file ${brokenCfg}" + ) + machine.succeed("test ! -e /var/lib/nixos-containers/b0rk") ''; - in '' - with subtest("Make sure we have a NixOS tree (required by ‘nixos-container create’)"): - machine.succeed("PAGER=cat nix-env -qa -A nixos.hello >&2") - - id1, id2 = None, None - - with subtest("Create some containers imperatively"): - id1 = machine.succeed("nixos-container create foo --ensure-unique-name").rstrip() - machine.log(f"created container {id1}") - - id2 = machine.succeed("nixos-container create foo --ensure-unique-name").rstrip() - machine.log(f"created container {id2}") - - assert id1 != id2 - - with subtest(f"Put the root of {id2} into a bind mount"): - machine.succeed( - f"mv /var/lib/nixos-containers/{id2} /id2-bindmount", - f"mount --bind /id2-bindmount /var/lib/nixos-containers/{id1}", - ) - - ip1 = machine.succeed(f"nixos-container show-ip {id1}").rstrip() - ip2 = machine.succeed(f"nixos-container show-ip {id2}").rstrip() - assert ip1 != ip2 - - with subtest( - "Create a directory and a file we can later check if it still exists " - + "after destruction of the container" - ): - machine.succeed("mkdir /nested-bindmount") - machine.succeed("echo important data > /nested-bindmount/dummy") - - with subtest( - "Create a directory with a dummy file and bind-mount it into both containers." - ): - for id in id1, id2: - important_path = f"/var/lib/nixos-containers/{id}/very/important/data" - machine.succeed( - f"mkdir -p {important_path}", - f"mount --bind /nested-bindmount {important_path}", - ) - - with subtest("Start one of them"): - machine.succeed(f"nixos-container start {id1}") - - with subtest("Execute commands via the root shell"): - assert "Linux" in machine.succeed(f"nixos-container run {id1} -- uname") - - with subtest("Execute a nix command via the root shell. (regression test for #40355)"): - machine.succeed( - f"nixos-container run {id1} -- nix-instantiate -E " - + '\'derivation { name = "empty"; builder = "false"; system = "false"; }\' ' - ) - - with subtest("Stop and start (regression test for #4989)"): - machine.succeed(f"nixos-container stop {id1}") - machine.succeed(f"nixos-container start {id1}") - - # clear serial backlog for next tests - machine.succeed("logger eat console backlog 3ea46eb2-7f82-4f70-b810-3f00e3dd4c4d") - machine.wait_for_console_text( - "eat console backlog 3ea46eb2-7f82-4f70-b810-3f00e3dd4c4d" - ) - - with subtest("Stop a container early"): - machine.succeed(f"nixos-container stop {id1}") - machine.succeed(f"nixos-container start {id1} >&2 &") - machine.wait_for_console_text("Stage 2") - machine.succeed(f"nixos-container stop {id1}") - machine.wait_for_console_text(f"Container {id1} exited successfully") - machine.succeed(f"nixos-container start {id1}") - - with subtest("Stop a container without machined (regression test for #109695)"): - machine.systemctl("stop systemd-machined") - machine.succeed(f"nixos-container stop {id1}") - machine.wait_for_console_text(f"Container {id1} has been shut down") - machine.succeed(f"nixos-container start {id1}") - - with subtest("tmpfiles are present"): - machine.log("creating container tmpfiles") - machine.succeed( - "nixos-container create tmpfiles --config-file ${tmpfilesContainerConfig}" - ) - machine.log("created, starting…") - machine.succeed("nixos-container start tmpfiles") - machine.log("done starting, investigating…") - machine.succeed( - "echo $(nixos-container run tmpfiles -- systemctl is-active foo.service) | grep -q active;" - ) - machine.succeed("nixos-container destroy tmpfiles") - - with subtest("Execute commands via the root shell"): - assert "Linux" in machine.succeed(f"nixos-container run {id1} -- uname") - - with subtest("Destroy the containers"): - for id in id1, id2: - machine.succeed(f"nixos-container destroy {id}") - - with subtest("Check whether destruction of any container has killed important data"): - machine.succeed("grep -qF 'important data' /nested-bindmount/dummy") - - with subtest("Ensure that the container path is gone"): - print(machine.succeed("ls -lsa /var/lib/nixos-containers")) - machine.succeed(f"test ! -e /var/lib/nixos-containers/{id1}") - - with subtest("Ensure that a failed container creation doesn'leave any state"): - machine.fail( - "nixos-container create b0rk --config-file ${brokenCfg}" - ) - machine.succeed("test ! -e /var/lib/nixos-containers/b0rk") - ''; -}) + } +) diff --git a/nixos/tests/containers-ip.nix b/nixos/tests/containers-ip.nix index 034e5d660415ac..979fb365126d74 100644 --- a/nixos/tests/containers-ip.nix +++ b/nixos/tests/containers-ip.nix @@ -11,61 +11,72 @@ let }; }; -in import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "containers-ipv4-ipv6"; - meta = { - maintainers = with lib.maintainers; [ aristid aszlig kampfschlaefer ]; - }; +in +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-ipv4-ipv6"; + meta = { + maintainers = with lib.maintainers; [ + aristid + aszlig + kampfschlaefer + ]; + }; - nodes.machine = - { pkgs, ... }: { - virtualisation.writableStore = true; + nodes.machine = + { pkgs, ... }: + { + virtualisation.writableStore = true; - containers.webserver4 = webserverFor "10.231.136.1" "10.231.136.2"; - containers.webserver6 = webserverFor "fc00::2" "fc00::1"; - virtualisation.additionalPaths = [ pkgs.stdenv ]; - }; + containers.webserver4 = webserverFor "10.231.136.1" "10.231.136.2"; + containers.webserver6 = webserverFor "fc00::2" "fc00::1"; + virtualisation.additionalPaths = [ pkgs.stdenv ]; + }; - testScript = { nodes, ... }: '' - import time + testScript = + { nodes, ... }: + '' + import time - def curl_host(ip): - # put [] around ipv6 addresses for curl - host = ip if ":" not in ip else f"[{ip}]" - return f"curl --fail --connect-timeout 2 http://{host}/ > /dev/null" + def curl_host(ip): + # put [] around ipv6 addresses for curl + host = ip if ":" not in ip else f"[{ip}]" + return f"curl --fail --connect-timeout 2 http://{host}/ > /dev/null" - def get_ip(container): - # need to distinguish because show-ip won't work for ipv6 - if container == "webserver4": - ip = machine.succeed(f"nixos-container show-ip {container}").rstrip() - assert ip == "${nodes.machine.config.containers.webserver4.localAddress}" - return ip - return "${nodes.machine.config.containers.webserver6.localAddress}" + def get_ip(container): + # need to distinguish because show-ip won't work for ipv6 + if container == "webserver4": + ip = machine.succeed(f"nixos-container show-ip {container}").rstrip() + assert ip == "${nodes.machine.config.containers.webserver4.localAddress}" + return ip + return "${nodes.machine.config.containers.webserver6.localAddress}" - for container in "webserver4", "webserver6": - assert container in machine.succeed("nixos-container list") + for container in "webserver4", "webserver6": + assert container in machine.succeed("nixos-container list") - with subtest(f"Start container {container}"): - machine.succeed(f"nixos-container start {container}") - # wait 2s for container to start and network to be up - time.sleep(2) + with subtest(f"Start container {container}"): + machine.succeed(f"nixos-container start {container}") + # wait 2s for container to start and network to be up + time.sleep(2) - # Since "start" returns after the container has reached - # multi-user.target, we should now be able to access it. + # Since "start" returns after the container has reached + # multi-user.target, we should now be able to access it. - ip = get_ip(container) - with subtest(f"{container} reacts to pings and HTTP requests"): - machine.succeed(f"ping -n -c1 {ip}") - machine.succeed(curl_host(ip)) + ip = get_ip(container) + with subtest(f"{container} reacts to pings and HTTP requests"): + machine.succeed(f"ping -n -c1 {ip}") + machine.succeed(curl_host(ip)) - with subtest(f"Stop container {container}"): - machine.succeed(f"nixos-container stop {container}") - machine.fail(curl_host(ip)) + with subtest(f"Stop container {container}"): + machine.succeed(f"nixos-container stop {container}") + machine.fail(curl_host(ip)) - # Destroying a declarative container should fail. - machine.fail(f"nixos-container destroy {container}") - ''; -}) + # Destroying a declarative container should fail. + machine.fail(f"nixos-container destroy {container}") + ''; + } +) diff --git a/nixos/tests/containers-macvlans.nix b/nixos/tests/containers-macvlans.nix index a0cea8db4a1ab9..3ebfef9d0bc820 100644 --- a/nixos/tests/containers-macvlans.nix +++ b/nixos/tests/containers-macvlans.nix @@ -4,79 +4,97 @@ let containerIp2 = "192.168.1.254"; in -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "containers-macvlans"; - meta = { - maintainers = with lib.maintainers; [ montag451 ]; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-macvlans"; + meta = { + maintainers = with lib.maintainers; [ montag451 ]; + }; - nodes = { + nodes = { - machine1 = - { lib, ... }: - { - virtualisation.vlans = [ 1 ]; + machine1 = + { lib, ... }: + { + virtualisation.vlans = [ 1 ]; - # To be able to ping containers from the host, it is necessary - # to create a macvlan on the host on the VLAN 1 network. - networking.macvlans.mv-eth1-host = { - interface = "eth1"; - mode = "bridge"; - }; - networking.interfaces.eth1.ipv4.addresses = lib.mkForce []; - networking.interfaces.mv-eth1-host = { - ipv4.addresses = [ { address = "192.168.1.1"; prefixLength = 24; } ]; - }; + # To be able to ping containers from the host, it is necessary + # to create a macvlan on the host on the VLAN 1 network. + networking.macvlans.mv-eth1-host = { + interface = "eth1"; + mode = "bridge"; + }; + networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ ]; + networking.interfaces.mv-eth1-host = { + ipv4.addresses = [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; + }; - containers.test1 = { - autoStart = true; - macvlans = [ "eth1" ]; + containers.test1 = { + autoStart = true; + macvlans = [ "eth1" ]; - config = { - networking.interfaces.mv-eth1 = { - ipv4.addresses = [ { address = containerIp1; prefixLength = 24; } ]; + config = { + networking.interfaces.mv-eth1 = { + ipv4.addresses = [ + { + address = containerIp1; + prefixLength = 24; + } + ]; + }; }; }; - }; - containers.test2 = { - autoStart = true; - macvlans = [ "eth1" ]; + containers.test2 = { + autoStart = true; + macvlans = [ "eth1" ]; - config = { - networking.interfaces.mv-eth1 = { - ipv4.addresses = [ { address = containerIp2; prefixLength = 24; } ]; + config = { + networking.interfaces.mv-eth1 = { + ipv4.addresses = [ + { + address = containerIp2; + prefixLength = 24; + } + ]; + }; }; }; }; - }; - machine2 = - { ... }: - { - virtualisation.vlans = [ 1 ]; - }; + machine2 = + { ... }: + { + virtualisation.vlans = [ 1 ]; + }; - }; + }; - testScript = '' - start_all() - machine1.wait_for_unit("default.target") - machine2.wait_for_unit("default.target") + testScript = '' + start_all() + machine1.wait_for_unit("default.target") + machine2.wait_for_unit("default.target") - with subtest( - "Ping between containers to check that macvlans are created in bridge mode" - ): - machine1.succeed("nixos-container run test1 -- ping -n -c 1 ${containerIp2}") + with subtest( + "Ping between containers to check that macvlans are created in bridge mode" + ): + machine1.succeed("nixos-container run test1 -- ping -n -c 1 ${containerIp2}") - with subtest("Ping containers from the host (machine1)"): - machine1.succeed("ping -n -c 1 ${containerIp1}") - machine1.succeed("ping -n -c 1 ${containerIp2}") + with subtest("Ping containers from the host (machine1)"): + machine1.succeed("ping -n -c 1 ${containerIp1}") + machine1.succeed("ping -n -c 1 ${containerIp2}") - with subtest( - "Ping containers from the second machine to check that containers are reachable from the outside" - ): - machine2.succeed("ping -n -c 1 ${containerIp1}") - machine2.succeed("ping -n -c 1 ${containerIp2}") - ''; -}) + with subtest( + "Ping containers from the second machine to check that containers are reachable from the outside" + ): + machine2.succeed("ping -n -c 1 ${containerIp1}") + machine2.succeed("ping -n -c 1 ${containerIp2}") + ''; + } +) diff --git a/nixos/tests/containers-names.nix b/nixos/tests/containers-names.nix index 721f64990724e0..2ed047b62fe2e1 100644 --- a/nixos/tests/containers-names.nix +++ b/nixos/tests/containers-names.nix @@ -1,37 +1,44 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "containers-names"; - meta = { - maintainers = with lib.maintainers; [ patryk27 ]; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-names"; + meta = { + maintainers = with lib.maintainers; [ patryk27 ]; + }; - nodes.machine = { ... }: { - # We're using the newest kernel, so that we can test containers with long names. - # Please see https://github.com/NixOS/nixpkgs/issues/38509 for details. - boot.kernelPackages = pkgs.linuxPackages_latest; + nodes.machine = + { ... }: + { + # We're using the newest kernel, so that we can test containers with long names. + # Please see https://github.com/NixOS/nixpkgs/issues/38509 for details. + boot.kernelPackages = pkgs.linuxPackages_latest; - containers = let - container = subnet: { - autoStart = true; - privateNetwork = true; - hostAddress = "192.168.${subnet}.1"; - localAddress = "192.168.${subnet}.2"; - config = { }; - }; + containers = + let + container = subnet: { + autoStart = true; + privateNetwork = true; + hostAddress = "192.168.${subnet}.1"; + localAddress = "192.168.${subnet}.2"; + config = { }; + }; - in { - first = container "1"; - second = container "2"; - really-long-name = container "3"; - really-long-long-name-2 = container "4"; - }; - }; + in + { + first = container "1"; + second = container "2"; + really-long-name = container "3"; + really-long-long-name-2 = container "4"; + }; + }; - testScript = '' - machine.wait_for_unit("default.target") + testScript = '' + machine.wait_for_unit("default.target") - machine.succeed("ip link show | grep ve-first") - machine.succeed("ip link show | grep ve-second") - machine.succeed("ip link show | grep ve-really-lFYWO") - machine.succeed("ip link show | grep ve-really-l3QgY") - ''; -}) + machine.succeed("ip link show | grep ve-first") + machine.succeed("ip link show | grep ve-second") + machine.succeed("ip link show | grep ve-really-lFYWO") + machine.succeed("ip link show | grep ve-really-l3QgY") + ''; + } +) diff --git a/nixos/tests/containers-nested.nix b/nixos/tests/containers-nested.nix index 4a9fb8f01e2413..a274b64c443e39 100644 --- a/nixos/tests/containers-nested.nix +++ b/nixos/tests/containers-nested.nix @@ -1,30 +1,36 @@ # Test for NixOS' container nesting. -import ./make-test-python.nix ({ pkgs, ... }: { - name = "nested"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "nested"; - meta = with pkgs.lib.maintainers; { maintainers = [ sorki ]; }; + meta = with pkgs.lib.maintainers; { + maintainers = [ sorki ]; + }; - nodes.machine = { lib, ... }: - let - makeNested = subConf: { - containers.nested = { - autoStart = true; - privateNetwork = true; - config = subConf; + nodes.machine = + { lib, ... }: + let + makeNested = subConf: { + containers.nested = { + autoStart = true; + privateNetwork = true; + config = subConf; + }; }; - }; - in makeNested (makeNested { }); - - testScript = '' - machine.start() - machine.wait_for_unit("container@nested.service") - machine.succeed("systemd-run --pty --machine=nested -- machinectl list | grep nested") - print( - machine.succeed( - "systemd-run --pty --machine=nested -- systemd-run --pty --machine=nested -- systemctl status" - ) - ) - ''; -}) + in + makeNested (makeNested { }); + testScript = '' + machine.start() + machine.wait_for_unit("container@nested.service") + machine.succeed("systemd-run --pty --machine=nested -- machinectl list | grep nested") + print( + machine.succeed( + "systemd-run --pty --machine=nested -- systemd-run --pty --machine=nested -- systemctl status" + ) + ) + ''; + } +) diff --git a/nixos/tests/containers-physical_interfaces.nix b/nixos/tests/containers-physical_interfaces.nix index e203f88786a3ec..efe7982c676295 100644 --- a/nixos/tests/containers-physical_interfaces.nix +++ b/nixos/tests/containers-physical_interfaces.nix @@ -1,131 +1,153 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "containers-physical_interfaces"; - meta = { - maintainers = with lib.maintainers; [ kampfschlaefer ]; - }; - - nodes = { - server = { ... }: - { - virtualisation.vlans = [ 1 ]; - - containers.server = { - privateNetwork = true; - interfaces = [ "eth1" ]; - - config = { - networking.interfaces.eth1.ipv4.addresses = [ - { address = "10.10.0.1"; prefixLength = 24; } - ]; - networking.firewall.enable = false; - }; - }; - }; - bridged = { ... }: { - virtualisation.vlans = [ 1 ]; - - containers.bridged = { - privateNetwork = true; - interfaces = [ "eth1" ]; - - config = { - networking.bridges.br0.interfaces = [ "eth1" ]; - networking.interfaces.br0.ipv4.addresses = [ - { address = "10.10.0.2"; prefixLength = 24; } - ]; - networking.firewall.enable = false; - }; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-physical_interfaces"; + meta = { + maintainers = with lib.maintainers; [ kampfschlaefer ]; }; - bonded = { ... }: { - virtualisation.vlans = [ 1 ]; + nodes = { + server = + { ... }: + { + virtualisation.vlans = [ 1 ]; + + containers.server = { + privateNetwork = true; + interfaces = [ "eth1" ]; - containers.bonded = { - privateNetwork = true; - interfaces = [ "eth1" ]; + config = { + networking.interfaces.eth1.ipv4.addresses = [ + { + address = "10.10.0.1"; + prefixLength = 24; + } + ]; + networking.firewall.enable = false; + }; + }; + }; + bridged = + { ... }: + { + virtualisation.vlans = [ 1 ]; - config = { - networking.bonds.bond0 = { + containers.bridged = { + privateNetwork = true; interfaces = [ "eth1" ]; - driverOptions.mode = "active-backup"; + + config = { + networking.bridges.br0.interfaces = [ "eth1" ]; + networking.interfaces.br0.ipv4.addresses = [ + { + address = "10.10.0.2"; + prefixLength = 24; + } + ]; + networking.firewall.enable = false; + }; }; - networking.interfaces.bond0.ipv4.addresses = [ - { address = "10.10.0.3"; prefixLength = 24; } - ]; - networking.firewall.enable = false; }; - }; - }; - bridgedbond = { ... }: { - virtualisation.vlans = [ 1 ]; + bonded = + { ... }: + { + virtualisation.vlans = [ 1 ]; + + containers.bonded = { + privateNetwork = true; + interfaces = [ "eth1" ]; + + config = { + networking.bonds.bond0 = { + interfaces = [ "eth1" ]; + driverOptions.mode = "active-backup"; + }; + networking.interfaces.bond0.ipv4.addresses = [ + { + address = "10.10.0.3"; + prefixLength = 24; + } + ]; + networking.firewall.enable = false; + }; + }; + }; - containers.bridgedbond = { - privateNetwork = true; - interfaces = [ "eth1" ]; + bridgedbond = + { ... }: + { + virtualisation.vlans = [ 1 ]; - config = { - networking.bonds.bond0 = { + containers.bridgedbond = { + privateNetwork = true; interfaces = [ "eth1" ]; - driverOptions.mode = "active-backup"; + + config = { + networking.bonds.bond0 = { + interfaces = [ "eth1" ]; + driverOptions.mode = "active-backup"; + }; + networking.bridges.br0.interfaces = [ "bond0" ]; + networking.interfaces.br0.ipv4.addresses = [ + { + address = "10.10.0.4"; + prefixLength = 24; + } + ]; + networking.firewall.enable = false; + }; }; - networking.bridges.br0.interfaces = [ "bond0" ]; - networking.interfaces.br0.ipv4.addresses = [ - { address = "10.10.0.4"; prefixLength = 24; } - ]; - networking.firewall.enable = false; }; - }; }; - }; - - testScript = '' - start_all() - - with subtest("Prepare server"): - server.wait_for_unit("default.target") - server.succeed("ip link show dev eth1 >&2") - - with subtest("Simple physical interface is up"): - server.succeed("nixos-container start server") - server.wait_for_unit("container@server") - server.succeed( - "systemctl -M server list-dependencies network-addresses-eth1.service >&2" - ) - - # The other tests will ping this container on its ip. Here we just check - # that the device is present in the container. - server.succeed("nixos-container run server -- ip a show dev eth1 >&2") - - with subtest("Physical device in bridge in container can ping server"): - bridged.wait_for_unit("default.target") - bridged.succeed("nixos-container start bridged") - bridged.wait_for_unit("container@bridged") - bridged.succeed( - "systemctl -M bridged list-dependencies network-addresses-br0.service >&2", - "systemctl -M bridged status -n 30 -l network-addresses-br0.service", - "nixos-container run bridged -- ping -w 10 -c 1 -n 10.10.0.1", - ) - - with subtest("Physical device in bond in container can ping server"): - bonded.wait_for_unit("default.target") - bonded.succeed("nixos-container start bonded") - bonded.wait_for_unit("container@bonded") - bonded.succeed( - "systemctl -M bonded list-dependencies network-addresses-bond0 >&2", - "systemctl -M bonded status -n 30 -l network-addresses-bond0 >&2", - "nixos-container run bonded -- ping -w 10 -c 1 -n 10.10.0.1", - ) - - with subtest("Physical device in bond in bridge in container can ping server"): - bridgedbond.wait_for_unit("default.target") - bridgedbond.succeed("nixos-container start bridgedbond") - bridgedbond.wait_for_unit("container@bridgedbond") - bridgedbond.succeed( - "systemctl -M bridgedbond list-dependencies network-addresses-br0.service >&2", - "systemctl -M bridgedbond status -n 30 -l network-addresses-br0.service", - "nixos-container run bridgedbond -- ping -w 10 -c 1 -n 10.10.0.1", - ) - ''; -}) + + testScript = '' + start_all() + + with subtest("Prepare server"): + server.wait_for_unit("default.target") + server.succeed("ip link show dev eth1 >&2") + + with subtest("Simple physical interface is up"): + server.succeed("nixos-container start server") + server.wait_for_unit("container@server") + server.succeed( + "systemctl -M server list-dependencies network-addresses-eth1.service >&2" + ) + + # The other tests will ping this container on its ip. Here we just check + # that the device is present in the container. + server.succeed("nixos-container run server -- ip a show dev eth1 >&2") + + with subtest("Physical device in bridge in container can ping server"): + bridged.wait_for_unit("default.target") + bridged.succeed("nixos-container start bridged") + bridged.wait_for_unit("container@bridged") + bridged.succeed( + "systemctl -M bridged list-dependencies network-addresses-br0.service >&2", + "systemctl -M bridged status -n 30 -l network-addresses-br0.service", + "nixos-container run bridged -- ping -w 10 -c 1 -n 10.10.0.1", + ) + + with subtest("Physical device in bond in container can ping server"): + bonded.wait_for_unit("default.target") + bonded.succeed("nixos-container start bonded") + bonded.wait_for_unit("container@bonded") + bonded.succeed( + "systemctl -M bonded list-dependencies network-addresses-bond0 >&2", + "systemctl -M bonded status -n 30 -l network-addresses-bond0 >&2", + "nixos-container run bonded -- ping -w 10 -c 1 -n 10.10.0.1", + ) + + with subtest("Physical device in bond in bridge in container can ping server"): + bridgedbond.wait_for_unit("default.target") + bridgedbond.succeed("nixos-container start bridgedbond") + bridgedbond.wait_for_unit("container@bridgedbond") + bridgedbond.succeed( + "systemctl -M bridgedbond list-dependencies network-addresses-br0.service >&2", + "systemctl -M bridgedbond status -n 30 -l network-addresses-br0.service", + "nixos-container run bridgedbond -- ping -w 10 -c 1 -n 10.10.0.1", + ) + ''; + } +) diff --git a/nixos/tests/containers-portforward.nix b/nixos/tests/containers-portforward.nix index 1a9880fe93133f..be087dba48f045 100644 --- a/nixos/tests/containers-portforward.nix +++ b/nixos/tests/containers-portforward.nix @@ -5,34 +5,47 @@ let containerPort = 80; in -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "containers-portforward"; - meta = { - maintainers = with lib.maintainers; [ aristid aszlig kampfschlaefer ianwookim ]; - }; - - nodes.machine = - { pkgs, ... }: - { imports = [ ../modules/installer/cd-dvd/channel.nix ]; - virtualisation.writableStore = true; - - containers.webserver = - { privateNetwork = true; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-portforward"; + meta = { + maintainers = with lib.maintainers; [ + aristid + aszlig + kampfschlaefer + ianwookim + ]; + }; + + nodes.machine = + { pkgs, ... }: + { + imports = [ ../modules/installer/cd-dvd/channel.nix ]; + virtualisation.writableStore = true; + + containers.webserver = { + privateNetwork = true; hostAddress = hostIp; localAddress = containerIp; - forwardPorts = [ { protocol = "tcp"; hostPort = hostPort; containerPort = containerPort; } ]; - config = - { services.httpd.enable = true; - services.httpd.adminAddr = "foo@example.org"; - networking.firewall.allowedTCPPorts = [ 80 ]; - }; + forwardPorts = [ + { + protocol = "tcp"; + hostPort = hostPort; + containerPort = containerPort; + } + ]; + config = { + services.httpd.enable = true; + services.httpd.adminAddr = "foo@example.org"; + networking.firewall.allowedTCPPorts = [ 80 ]; + }; }; - virtualisation.additionalPaths = [ pkgs.stdenv ]; - }; + virtualisation.additionalPaths = [ pkgs.stdenv ]; + }; - testScript = - '' + testScript = '' container_list = machine.succeed("nixos-container list") assert "webserver" in container_list @@ -56,4 +69,5 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: { machine.fail("nixos-container destroy webserver") ''; -}) + } +) diff --git a/nixos/tests/containers-reloadable.nix b/nixos/tests/containers-reloadable.nix index 00d850cae2a171..74c6003da65980 100644 --- a/nixos/tests/containers-reloadable.nix +++ b/nixos/tests/containers-reloadable.nix @@ -1,57 +1,61 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -{ - name = "containers-reloadable"; - meta = { - maintainers = with lib.maintainers; [ danbst ]; - }; - - nodes = { - machine = { lib, ... }: { - containers.test1 = { - autoStart = true; - config.environment.etc.check.text = "client_base"; - }; - - # prevent make-test-python.nix to change IP - networking.interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [ ]; - - specialisation.c1.configuration = { - containers.test1.config = { - environment.etc.check.text = lib.mkForce "client_c1"; - services.httpd.enable = true; - services.httpd.adminAddr = "nixos@example.com"; - }; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-reloadable"; + meta = { + maintainers = with lib.maintainers; [ danbst ]; + }; - specialisation.c2.configuration = { - containers.test1.config = { - environment.etc.check.text = lib.mkForce "client_c2"; - services.nginx.enable = true; + nodes = { + machine = + { lib, ... }: + { + containers.test1 = { + autoStart = true; + config.environment.etc.check.text = "client_base"; + }; + + # prevent make-test-python.nix to change IP + networking.interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [ ]; + + specialisation.c1.configuration = { + containers.test1.config = { + environment.etc.check.text = lib.mkForce "client_c1"; + services.httpd.enable = true; + services.httpd.adminAddr = "nixos@example.com"; + }; + }; + + specialisation.c2.configuration = { + containers.test1.config = { + environment.etc.check.text = lib.mkForce "client_c2"; + services.nginx.enable = true; + }; + }; }; - }; }; - }; - - testScript = '' - machine.start() - machine.wait_for_unit("default.target") - - assert "client_base" in machine.succeed("nixos-container run test1 cat /etc/check") - - with subtest("httpd is available after activating config1"): - machine.succeed( - "/run/booted-system/specialisation/c1/bin/switch-to-configuration test >&2", - "[[ $(nixos-container run test1 cat /etc/check) == client_c1 ]] >&2", - "systemctl status httpd -M test1 >&2", - ) - - with subtest("httpd is not available any longer after switching to config2"): - machine.succeed( - "/run/booted-system/specialisation/c2/bin/switch-to-configuration test >&2", - "[[ $(nixos-container run test1 cat /etc/check) == client_c2 ]] >&2", - "systemctl status nginx -M test1 >&2", - ) - machine.fail("systemctl status httpd -M test1 >&2") - ''; - -}) + + testScript = '' + machine.start() + machine.wait_for_unit("default.target") + + assert "client_base" in machine.succeed("nixos-container run test1 cat /etc/check") + + with subtest("httpd is available after activating config1"): + machine.succeed( + "/run/booted-system/specialisation/c1/bin/switch-to-configuration test >&2", + "[[ $(nixos-container run test1 cat /etc/check) == client_c1 ]] >&2", + "systemctl status httpd -M test1 >&2", + ) + + with subtest("httpd is not available any longer after switching to config2"): + machine.succeed( + "/run/booted-system/specialisation/c2/bin/switch-to-configuration test >&2", + "[[ $(nixos-container run test1 cat /etc/check) == client_c2 ]] >&2", + "systemctl status nginx -M test1 >&2", + ) + machine.fail("systemctl status httpd -M test1 >&2") + ''; + + } +) diff --git a/nixos/tests/containers-require-bind-mounts.nix b/nixos/tests/containers-require-bind-mounts.nix index 5f986fd3e2803b..b5a861beacc917 100644 --- a/nixos/tests/containers-require-bind-mounts.nix +++ b/nixos/tests/containers-require-bind-mounts.nix @@ -1,35 +1,40 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "containers-require-bind-mounts"; - meta.maintainers = with lib.maintainers; [ kira-bruneau ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "containers-require-bind-mounts"; + meta.maintainers = with lib.maintainers; [ kira-bruneau ]; - nodes.machine = { - containers.require-bind-mounts = { - bindMounts = { "/srv/data" = {}; }; - config = {}; - }; + nodes.machine = { + containers.require-bind-mounts = { + bindMounts = { + "/srv/data" = { }; + }; + config = { }; + }; - virtualisation.fileSystems = { - "/srv/data" = { - fsType = "tmpfs"; - options = [ "noauto" ]; + virtualisation.fileSystems = { + "/srv/data" = { + fsType = "tmpfs"; + options = [ "noauto" ]; + }; }; }; - }; - - testScript = '' - machine.wait_for_unit("default.target") - assert "require-bind-mounts" in machine.succeed("nixos-container list") - assert "down" in machine.succeed("nixos-container status require-bind-mounts") - assert "inactive" in machine.fail("systemctl is-active srv-data.mount") + testScript = '' + machine.wait_for_unit("default.target") - with subtest("bind mount host paths must be mounted to run container"): - machine.succeed("nixos-container start require-bind-mounts") - assert "up" in machine.succeed("nixos-container status require-bind-mounts") - assert "active" in machine.succeed("systemctl status srv-data.mount") - - machine.succeed("systemctl stop srv-data.mount") + assert "require-bind-mounts" in machine.succeed("nixos-container list") assert "down" in machine.succeed("nixos-container status require-bind-mounts") assert "inactive" in machine.fail("systemctl is-active srv-data.mount") + + with subtest("bind mount host paths must be mounted to run container"): + machine.succeed("nixos-container start require-bind-mounts") + assert "up" in machine.succeed("nixos-container status require-bind-mounts") + assert "active" in machine.succeed("systemctl status srv-data.mount") + + machine.succeed("systemctl stop srv-data.mount") + assert "down" in machine.succeed("nixos-container status require-bind-mounts") + assert "inactive" in machine.fail("systemctl is-active srv-data.mount") ''; -}) + } +) diff --git a/nixos/tests/containers-restart_networking.nix b/nixos/tests/containers-restart_networking.nix index 568ca5ee3fede9..4a85bb3e648cb6 100644 --- a/nixos/tests/containers-restart_networking.nix +++ b/nixos/tests/containers-restart_networking.nix @@ -1,106 +1,126 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -{ - name = "containers-restart_networking"; - meta = { - maintainers = with lib.maintainers; [ kampfschlaefer ]; - }; - - nodes = { - client = { - virtualisation.vlans = [ 1 ]; - - networking.firewall.enable = false; - - containers.webserver = { - autoStart = true; - privateNetwork = true; - hostBridge = "br0"; - config = { - networking.firewall.enable = false; - networking.interfaces.eth0.ipv4.addresses = [ - { address = "192.168.1.122"; prefixLength = 24; } - ]; - }; - }; - - networking.bridges.br0 = { - interfaces = []; - rstp = false; - }; - - networking.interfaces.br0.ipv4.addresses = [ { address = "192.168.1.1"; prefixLength = 24; } ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-restart_networking"; + meta = { + maintainers = with lib.maintainers; [ kampfschlaefer ]; + }; - specialisation.eth1.configuration = { - networking.bridges.br0.interfaces = [ "eth1" ]; - networking.interfaces = { - eth1.ipv4.addresses = lib.mkForce [ ]; - eth1.ipv6.addresses = lib.mkForce [ ]; - br0.ipv4.addresses = [ { address = "192.168.1.2"; prefixLength = 24; } ]; + nodes = { + client = { + virtualisation.vlans = [ 1 ]; + + networking.firewall.enable = false; + + containers.webserver = { + autoStart = true; + privateNetwork = true; + hostBridge = "br0"; + config = { + networking.firewall.enable = false; + networking.interfaces.eth0.ipv4.addresses = [ + { + address = "192.168.1.122"; + prefixLength = 24; + } + ]; + }; }; - }; - specialisation.eth1-rstp.configuration = { networking.bridges.br0 = { - interfaces = [ "eth1" ]; - rstp = lib.mkForce true; + interfaces = [ ]; + rstp = false; }; - networking.interfaces = { - eth1.ipv4.addresses = lib.mkForce [ ]; - eth1.ipv6.addresses = lib.mkForce [ ]; - br0.ipv4.addresses = [ { address = "192.168.1.2"; prefixLength = 24; } ]; + networking.interfaces.br0.ipv4.addresses = [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; + + specialisation.eth1.configuration = { + networking.bridges.br0.interfaces = [ "eth1" ]; + networking.interfaces = { + eth1.ipv4.addresses = lib.mkForce [ ]; + eth1.ipv6.addresses = lib.mkForce [ ]; + br0.ipv4.addresses = [ + { + address = "192.168.1.2"; + prefixLength = 24; + } + ]; + }; + }; + + specialisation.eth1-rstp.configuration = { + networking.bridges.br0 = { + interfaces = [ "eth1" ]; + rstp = lib.mkForce true; + }; + + networking.interfaces = { + eth1.ipv4.addresses = lib.mkForce [ ]; + eth1.ipv6.addresses = lib.mkForce [ ]; + br0.ipv4.addresses = [ + { + address = "192.168.1.2"; + prefixLength = 24; + } + ]; + }; }; }; }; - }; - - testScript = '' - client.start() - - client.wait_for_unit("default.target") - - with subtest("Initial configuration connectivity check"): - client.succeed("ping 192.168.1.122 -c 1 -n >&2") - client.succeed("nixos-container run webserver -- ping -c 1 -n 192.168.1.1 >&2") - - client.fail("ip l show eth1 |grep 'master br0' >&2") - client.fail("grep eth1 /run/br0.interfaces >&2") - - with subtest("Bridged configuration without STP preserves connectivity"): - client.succeed( - "/run/booted-system/specialisation/eth1/bin/switch-to-configuration test >&2" - ) - - client.succeed( - "ping 192.168.1.122 -c 1 -n >&2", - "nixos-container run webserver -- ping -c 1 -n 192.168.1.2 >&2", - "ip l show eth1 |grep 'master br0' >&2", - "grep eth1 /run/br0.interfaces >&2", - ) - - # activating rstp needs another service, therefore the bridge will restart and the container will lose its connectivity - # with subtest("Bridged configuration with STP"): - # client.succeed("/run/booted-system/specialisation/eth1-rstp/bin/switch-to-configuration test >&2") - # client.execute("ip -4 a >&2") - # client.execute("ip l >&2") - # - # client.succeed( - # "ping 192.168.1.122 -c 1 -n >&2", - # "nixos-container run webserver -- ping -c 1 -n 192.168.1.2 >&2", - # "ip l show eth1 |grep 'master br0' >&2", - # "grep eth1 /run/br0.interfaces >&2", - # ) - - with subtest("Reverting to initial configuration preserves connectivity"): - client.succeed( - "/run/booted-system/bin/switch-to-configuration test >&2" - ) - - client.succeed("ping 192.168.1.122 -c 1 -n >&2") - client.succeed("nixos-container run webserver -- ping -c 1 -n 192.168.1.1 >&2") - - client.fail("ip l show eth1 |grep 'master br0' >&2") - client.fail("grep eth1 /run/br0.interfaces >&2") - ''; - -}) + + testScript = '' + client.start() + + client.wait_for_unit("default.target") + + with subtest("Initial configuration connectivity check"): + client.succeed("ping 192.168.1.122 -c 1 -n >&2") + client.succeed("nixos-container run webserver -- ping -c 1 -n 192.168.1.1 >&2") + + client.fail("ip l show eth1 |grep 'master br0' >&2") + client.fail("grep eth1 /run/br0.interfaces >&2") + + with subtest("Bridged configuration without STP preserves connectivity"): + client.succeed( + "/run/booted-system/specialisation/eth1/bin/switch-to-configuration test >&2" + ) + + client.succeed( + "ping 192.168.1.122 -c 1 -n >&2", + "nixos-container run webserver -- ping -c 1 -n 192.168.1.2 >&2", + "ip l show eth1 |grep 'master br0' >&2", + "grep eth1 /run/br0.interfaces >&2", + ) + + # activating rstp needs another service, therefore the bridge will restart and the container will lose its connectivity + # with subtest("Bridged configuration with STP"): + # client.succeed("/run/booted-system/specialisation/eth1-rstp/bin/switch-to-configuration test >&2") + # client.execute("ip -4 a >&2") + # client.execute("ip l >&2") + # + # client.succeed( + # "ping 192.168.1.122 -c 1 -n >&2", + # "nixos-container run webserver -- ping -c 1 -n 192.168.1.2 >&2", + # "ip l show eth1 |grep 'master br0' >&2", + # "grep eth1 /run/br0.interfaces >&2", + # ) + + with subtest("Reverting to initial configuration preserves connectivity"): + client.succeed( + "/run/booted-system/bin/switch-to-configuration test >&2" + ) + + client.succeed("ping 192.168.1.122 -c 1 -n >&2") + client.succeed("nixos-container run webserver -- ping -c 1 -n 192.168.1.1 >&2") + + client.fail("ip l show eth1 |grep 'master br0' >&2") + client.fail("grep eth1 /run/br0.interfaces >&2") + ''; + + } +) diff --git a/nixos/tests/containers-tmpfs.nix b/nixos/tests/containers-tmpfs.nix index cf5b81656afef3..668417df271e37 100644 --- a/nixos/tests/containers-tmpfs.nix +++ b/nixos/tests/containers-tmpfs.nix @@ -1,16 +1,18 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "containers-tmpfs"; - meta = { - maintainers = with lib.maintainers; [ patryk27 ]; - }; - - nodes.machine = - { pkgs, ... }: - { imports = [ ../modules/installer/cd-dvd/channel.nix ]; - virtualisation.writableStore = true; - - containers.tmpfs = - { +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-tmpfs"; + meta = { + maintainers = with lib.maintainers; [ patryk27 ]; + }; + + nodes.machine = + { pkgs, ... }: + { + imports = [ ../modules/installer/cd-dvd/channel.nix ]; + virtualisation.writableStore = true; + + containers.tmpfs = { autoStart = true; tmpfs = [ # Mount var as a tmpfs @@ -25,10 +27,10 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: { config = { }; }; - virtualisation.additionalPaths = [ pkgs.stdenv ]; - }; + virtualisation.additionalPaths = [ pkgs.stdenv ]; + }; - testScript = '' + testScript = '' machine.wait_for_unit("default.target") assert "tmpfs" in machine.succeed("nixos-container list") @@ -87,4 +89,5 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: { ) machine.fail(tmpfs_cmd("ls -l /var | grep -q test.file")) ''; -}) + } +) diff --git a/nixos/tests/containers-unified-hierarchy.nix b/nixos/tests/containers-unified-hierarchy.nix index 978d59e12c8a1d..5ea89d96dcfe33 100644 --- a/nixos/tests/containers-unified-hierarchy.nix +++ b/nixos/tests/containers-unified-hierarchy.nix @@ -1,21 +1,26 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "containers-unified-hierarchy"; - meta = { - maintainers = with lib.maintainers; [ farnoy ]; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "containers-unified-hierarchy"; + meta = { + maintainers = with lib.maintainers; [ farnoy ]; + }; - nodes.machine = { ... }: { - containers = { - test-container = { - autoStart = true; - config = { }; + nodes.machine = + { ... }: + { + containers = { + test-container = { + autoStart = true; + config = { }; + }; + }; }; - }; - }; - testScript = '' - machine.wait_for_unit("default.target") + testScript = '' + machine.wait_for_unit("default.target") - machine.succeed("echo 'stat -fc %T /sys/fs/cgroup/ | grep cgroup2fs' | nixos-container root-login test-container") - ''; -}) + machine.succeed("echo 'stat -fc %T /sys/fs/cgroup/ | grep cgroup2fs' | nixos-container root-login test-container") + ''; + } +) diff --git a/nixos/tests/convos.nix b/nixos/tests/convos.nix index 06d8d30fcb1487..f92ab49a298800 100644 --- a/nixos/tests/convos.nix +++ b/nixos/tests/convos.nix @@ -1,27 +1,28 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let + port = 3333; + in + { + name = "convos"; + meta.maintainers = with lib.maintainers; [ sgo ]; -let - port = 3333; -in -{ - name = "convos"; - meta.maintainers = with lib.maintainers; [ sgo ]; - - nodes = { - machine = - { pkgs, ... }: - { - services.convos = { - enable = true; - listenPort = port; + nodes = { + machine = + { pkgs, ... }: + { + services.convos = { + enable = true; + listenPort = port; + }; }; - }; - }; + }; - testScript = '' - machine.wait_for_unit("convos") - machine.wait_for_open_port(${toString port}) - machine.succeed("curl -f http://localhost:${toString port}/") - ''; -}) + testScript = '' + machine.wait_for_unit("convos") + machine.wait_for_open_port(${toString port}) + machine.succeed("curl -f http://localhost:${toString port}/") + ''; + } +) diff --git a/nixos/tests/corerad.nix b/nixos/tests/corerad.nix index dd2bec794a1a0a..3795cdd4175717 100644 --- a/nixos/tests/corerad.nix +++ b/nixos/tests/corerad.nix @@ -1,15 +1,21 @@ -import ./make-test-python.nix ( - { - name = "corerad"; - nodes = { - router = {config, pkgs, ...}: { +import ./make-test-python.nix ({ + name = "corerad"; + nodes = { + router = + { config, pkgs, ... }: + { config = { # This machine simulates a router with IPv6 forwarding and a static IPv6 address. boot.kernel.sysctl = { "net.ipv6.conf.all.forwarding" = true; }; networking.interfaces.eth1 = { - ipv6.addresses = [ { address = "fd00:dead:beef:dead::1"; prefixLength = 64; } ]; + ipv6.addresses = [ + { + address = "fd00:dead:beef:dead::1"; + prefixLength = 64; + } + ]; }; services.corerad = { enable = true; @@ -26,7 +32,7 @@ import ./make-test-python.nix ( { name = "eth1"; advertise = true; - prefix = [{ prefix = "::/64"; }]; + prefix = [ { prefix = "::/64"; } ]; } ]; debug = { @@ -37,7 +43,9 @@ import ./make-test-python.nix ( }; }; }; - client = {config, pkgs, ...}: { + client = + { config, pkgs, ... }: + { # Use IPv6 SLAAC from router advertisements, and install rdisc6 so we can # trigger one immediately. config = { @@ -49,44 +57,44 @@ import ./make-test-python.nix ( ]; }; }; - }; + }; - testScript = '' - start_all() + testScript = '' + start_all() - with subtest("Wait for CoreRAD and network ready"): - # Ensure networking is online and CoreRAD is ready. - router.systemctl("start network-online.target") - client.systemctl("start network-online.target") - router.wait_for_unit("network-online.target") - client.wait_for_unit("network-online.target") - router.wait_for_unit("corerad.service") + with subtest("Wait for CoreRAD and network ready"): + # Ensure networking is online and CoreRAD is ready. + router.systemctl("start network-online.target") + client.systemctl("start network-online.target") + router.wait_for_unit("network-online.target") + client.wait_for_unit("network-online.target") + router.wait_for_unit("corerad.service") - # Ensure the client can reach the router. - client.wait_until_succeeds("ping -c 1 fd00:dead:beef:dead::1") + # Ensure the client can reach the router. + client.wait_until_succeeds("ping -c 1 fd00:dead:beef:dead::1") - with subtest("Verify SLAAC on client"): - # Trigger a router solicitation and verify a SLAAC address is assigned from - # the prefix configured on the router. - client.wait_until_succeeds("rdisc6 -1 -r 10 eth1") - client.wait_until_succeeds( - "ip -6 addr show dev eth1 | grep -q 'fd00:dead:beef:dead:'" - ) + with subtest("Verify SLAAC on client"): + # Trigger a router solicitation and verify a SLAAC address is assigned from + # the prefix configured on the router. + client.wait_until_succeeds("rdisc6 -1 -r 10 eth1") + client.wait_until_succeeds( + "ip -6 addr show dev eth1 | grep -q 'fd00:dead:beef:dead:'" + ) - addrs = client.succeed("ip -6 addr show dev eth1") + addrs = client.succeed("ip -6 addr show dev eth1") - assert ( - "fd00:dead:beef:dead:" in addrs - ), "SLAAC prefix was not found in client addresses after router advertisement" - assert ( - "/64 scope global temporary" in addrs - ), "SLAAC temporary address was not configured on client after router advertisement" + assert ( + "fd00:dead:beef:dead:" in addrs + ), "SLAAC prefix was not found in client addresses after router advertisement" + assert ( + "/64 scope global temporary" in addrs + ), "SLAAC temporary address was not configured on client after router advertisement" - with subtest("Verify HTTP debug server is configured"): - out = router.succeed("curl -f localhost:9430/metrics") + with subtest("Verify HTTP debug server is configured"): + out = router.succeed("curl -f localhost:9430/metrics") - assert ( - "corerad_build_info" in out - ), "Build info metric was not found in Prometheus output" - ''; - }) + assert ( + "corerad_build_info" in out + ), "Build info metric was not found in Prometheus output" + ''; +}) diff --git a/nixos/tests/coturn.nix b/nixos/tests/coturn.nix index b3c96dba35f8ac..e090b45d4af649 100644 --- a/nixos/tests/coturn.nix +++ b/nixos/tests/coturn.nix @@ -1,22 +1,23 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "coturn"; - nodes = { - default = { - services.coturn.enable = true; - }; - secretsfile = { - boot.postBootCommands = '' - echo "some-very-secret-string" > /run/coturn-secret - ''; - services.coturn = { - enable = true; - static-auth-secret-file = "/run/coturn-secret"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "coturn"; + nodes = { + default = { + services.coturn.enable = true; + }; + secretsfile = { + boot.postBootCommands = '' + echo "some-very-secret-string" > /run/coturn-secret + ''; + services.coturn = { + enable = true; + static-auth-secret-file = "/run/coturn-secret"; + }; }; }; - }; - testScript = - '' + testScript = '' start_all() with subtest("by default works without configuration"): @@ -33,4 +34,5 @@ import ./make-test-python.nix ({ pkgs, ... }: { default.log(default.execute("systemd-analyze security coturn.service | grep -v '✓'")[1]) ''; -}) + } +) diff --git a/nixos/tests/couchdb.nix b/nixos/tests/couchdb.nix index cf6ca8e4548d1a..a3945915f98be5 100644 --- a/nixos/tests/couchdb.nix +++ b/nixos/tests/couchdb.nix @@ -1,57 +1,64 @@ let - makeNode = couchpkg: user: passwd: - { pkgs, ... } : + makeNode = + couchpkg: user: passwd: + { pkgs, ... }: - { environment.systemPackages = [ pkgs.jq ]; - services.couchdb.enable = true; - services.couchdb.package = couchpkg; - services.couchdb.adminUser = user; - services.couchdb.adminPass = passwd; - }; + { + environment.systemPackages = [ pkgs.jq ]; + services.couchdb.enable = true; + services.couchdb.package = couchpkg; + services.couchdb.adminUser = user; + services.couchdb.adminPass = passwd; + }; testuser = "testadmin"; testpass = "cowabunga"; testlogin = "${testuser}:${testpass}@"; in -import ./make-test-python.nix ({ pkgs, lib, ...}: -{ - name = "couchdb"; - meta.maintainers = [ ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "couchdb"; + meta.maintainers = [ ]; - nodes = { - couchdb3 = makeNode pkgs.couchdb3 testuser testpass; - }; + nodes = { + couchdb3 = makeNode pkgs.couchdb3 testuser testpass; + }; - testScript = let - curlJqCheck = login: action: path: jqexpr: result: - pkgs.writeScript "curl-jq-check-${action}-${path}.sh" '' - RESULT=$(curl -X ${action} http://${login}127.0.0.1:5984/${path} | jq -r '${jqexpr}') - echo $RESULT >&2 - if [ "$RESULT" != "${result}" ]; then - exit 1 - fi - ''; - in '' - start_all() + testScript = + let + curlJqCheck = + login: action: path: jqexpr: result: + pkgs.writeScript "curl-jq-check-${action}-${path}.sh" '' + RESULT=$(curl -X ${action} http://${login}127.0.0.1:5984/${path} | jq -r '${jqexpr}') + echo $RESULT >&2 + if [ "$RESULT" != "${result}" ]; then + exit 1 + fi + ''; + in + '' + start_all() - couchdb3.wait_for_unit("couchdb.service") - couchdb3.wait_until_succeeds( - "${curlJqCheck testlogin "GET" "" ".couchdb" "Welcome"}" - ) - couchdb3.wait_until_succeeds( - "${curlJqCheck testlogin "GET" "_all_dbs" ". | length" "0"}" - ) - couchdb3.succeed("${curlJqCheck testlogin "PUT" "foo" ".ok" "true"}") - couchdb3.succeed( - "${curlJqCheck testlogin "GET" "_all_dbs" ". | length" "1"}" - ) - couchdb3.succeed( - "${curlJqCheck testlogin "DELETE" "foo" ".ok" "true"}" - ) - couchdb3.succeed( - "${curlJqCheck testlogin "GET" "_all_dbs" ". | length" "0"}" - ) - couchdb3.succeed( - "${curlJqCheck testlogin "GET" "_node/couchdb@127.0.0.1" ".couchdb" "Welcome"}" - ) - ''; -}) + couchdb3.wait_for_unit("couchdb.service") + couchdb3.wait_until_succeeds( + "${curlJqCheck testlogin "GET" "" ".couchdb" "Welcome"}" + ) + couchdb3.wait_until_succeeds( + "${curlJqCheck testlogin "GET" "_all_dbs" ". | length" "0"}" + ) + couchdb3.succeed("${curlJqCheck testlogin "PUT" "foo" ".ok" "true"}") + couchdb3.succeed( + "${curlJqCheck testlogin "GET" "_all_dbs" ". | length" "1"}" + ) + couchdb3.succeed( + "${curlJqCheck testlogin "DELETE" "foo" ".ok" "true"}" + ) + couchdb3.succeed( + "${curlJqCheck testlogin "GET" "_all_dbs" ". | length" "0"}" + ) + couchdb3.succeed( + "${curlJqCheck testlogin "GET" "_node/couchdb@127.0.0.1" ".couchdb" "Welcome"}" + ) + ''; + } +) diff --git a/nixos/tests/cri-o.nix b/nixos/tests/cri-o.nix index 08e1e8f36b0651..216351bda8dbcf 100644 --- a/nixos/tests/cri-o.nix +++ b/nixos/tests/cri-o.nix @@ -1,19 +1,22 @@ # This test runs CRI-O and verifies via critest -import ./make-test-python.nix ({ pkgs, ... }: { - name = "cri-o"; - meta.maintainers = with pkgs.lib; teams.podman.members; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "cri-o"; + meta.maintainers = with pkgs.lib; teams.podman.members; - nodes = { - crio = { - virtualisation.cri-o.enable = true; + nodes = { + crio = { + virtualisation.cri-o.enable = true; + }; }; - }; - testScript = '' - start_all() - crio.wait_for_unit("crio.service") - crio.succeed( - "critest --ginkgo.focus='Runtime info' --runtime-endpoint unix:///var/run/crio/crio.sock" - ) - ''; -}) + testScript = '' + start_all() + crio.wait_for_unit("crio.service") + crio.succeed( + "critest --ginkgo.focus='Runtime info' --runtime-endpoint unix:///var/run/crio/crio.sock" + ) + ''; + } +) diff --git a/nixos/tests/croc.nix b/nixos/tests/croc.nix index 2e910f52526162..4b6d3f4d85a772 100644 --- a/nixos/tests/croc.nix +++ b/nixos/tests/croc.nix @@ -1,51 +1,59 @@ -import ./make-test-python.nix ({ pkgs, ... }: -let - client = { pkgs, ... }: { - environment.systemPackages = [ pkgs.croc ]; - }; - pass = "PassRelay"; -in { - name = "croc"; - meta = with pkgs.lib.maintainers; { - maintainers = [ equirosa SuperSandro2000 ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + let + client = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.croc ]; + }; + pass = "PassRelay"; + in + { + name = "croc"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + equirosa + SuperSandro2000 + ]; + }; - nodes = { - relay = { - services.croc = { - enable = true; - pass = pass; - openFirewall = true; + nodes = { + relay = { + services.croc = { + enable = true; + pass = pass; + openFirewall = true; + }; }; + sender = client; + receiver = client; }; - sender = client; - receiver = client; - }; - testScript = '' - start_all() + testScript = '' + start_all() - # wait until relay is up - relay.wait_for_unit("croc") - relay.wait_for_open_port(9009) - relay.wait_for_open_port(9010) - relay.wait_for_open_port(9011) - relay.wait_for_open_port(9012) - relay.wait_for_open_port(9013) + # wait until relay is up + relay.wait_for_unit("croc") + relay.wait_for_open_port(9009) + relay.wait_for_open_port(9010) + relay.wait_for_open_port(9011) + relay.wait_for_open_port(9012) + relay.wait_for_open_port(9013) - # generate testfiles and send them - sender.wait_for_unit("multi-user.target") - sender.execute("echo Hello World > testfile01.txt") - sender.execute("echo Hello Earth > testfile02.txt") - sender.execute( - "env CROC_SECRET=topSecret croc --pass ${pass} --relay relay send testfile01.txt testfile02.txt >&2 &" - ) + # generate testfiles and send them + sender.wait_for_unit("multi-user.target") + sender.execute("echo Hello World > testfile01.txt") + sender.execute("echo Hello Earth > testfile02.txt") + sender.execute( + "env CROC_SECRET=topSecret croc --pass ${pass} --relay relay send testfile01.txt testfile02.txt >&2 &" + ) - # receive the testfiles and check them - receiver.succeed( - "env CROC_SECRET=topSecret croc --pass ${pass} --yes --relay relay" - ) - assert "Hello World" in receiver.succeed("cat testfile01.txt") - assert "Hello Earth" in receiver.succeed("cat testfile02.txt") - ''; -}) + # receive the testfiles and check them + receiver.succeed( + "env CROC_SECRET=topSecret croc --pass ${pass} --yes --relay relay" + ) + assert "Hello World" in receiver.succeed("cat testfile01.txt") + assert "Hello Earth" in receiver.succeed("cat testfile02.txt") + ''; + } +) diff --git a/nixos/tests/cups-pdf.nix b/nixos/tests/cups-pdf.nix index 5602193b0408ae..727bc85fc26657 100644 --- a/nixos/tests/cups-pdf.nix +++ b/nixos/tests/cups-pdf.nix @@ -1,40 +1,47 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "cups-pdf"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "cups-pdf"; - nodes.machine = { pkgs, ... }: { - imports = [ ./common/user-account.nix ]; - environment.systemPackages = [ pkgs.poppler_utils ]; - fonts.packages = [ pkgs.dejavu_fonts ]; # yields more OCR-able pdf - services.printing.cups-pdf.enable = true; - services.printing.cups-pdf.instances = { - opt = {}; - noopt.installPrinter = false; - }; - hardware.printers.ensurePrinters = [{ - name = "noopt"; - model = "CUPS-PDF_noopt.ppd"; - deviceUri = "cups-pdf:/noopt"; - }]; - }; + nodes.machine = + { pkgs, ... }: + { + imports = [ ./common/user-account.nix ]; + environment.systemPackages = [ pkgs.poppler_utils ]; + fonts.packages = [ pkgs.dejavu_fonts ]; # yields more OCR-able pdf + services.printing.cups-pdf.enable = true; + services.printing.cups-pdf.instances = { + opt = { }; + noopt.installPrinter = false; + }; + hardware.printers.ensurePrinters = [ + { + name = "noopt"; + model = "CUPS-PDF_noopt.ppd"; + deviceUri = "cups-pdf:/noopt"; + } + ]; + }; - # we cannot check the files with pdftotext, due to - # https://github.com/alexivkin/CUPS-PDF-to-PDF/issues/7 - # we need `imagemagickBig` as it has ghostscript support + # we cannot check the files with pdftotext, due to + # https://github.com/alexivkin/CUPS-PDF-to-PDF/issues/7 + # we need `imagemagickBig` as it has ghostscript support - testScript = '' - from subprocess import run - machine.wait_for_unit("multi-user.target") - for name in ("opt", "noopt"): - text = f"test text {name}".upper() - machine.wait_until_succeeds(f"lpstat -v {name}") - machine.succeed(f"su - alice -c 'echo -e \"\n {text}\" | lp -d {name}'") - # wait until the pdf files are completely produced and readable by alice - machine.wait_until_succeeds(f"su - alice -c 'pdfinfo /var/spool/cups-pdf-{name}/users/alice/*.pdf'") - machine.succeed(f"cp /var/spool/cups-pdf-{name}/users/alice/*.pdf /tmp/{name}.pdf") - machine.copy_from_vm(f"/tmp/{name}.pdf", "") - run(f"${pkgs.imagemagickBig}/bin/convert -density 300 $out/{name}.pdf $out/{name}.jpeg", shell=True, check=True) - assert text.encode() in run(f"${lib.getExe pkgs.tesseract} $out/{name}.jpeg stdout", shell=True, check=True, capture_output=True).stdout - ''; + testScript = '' + from subprocess import run + machine.wait_for_unit("multi-user.target") + for name in ("opt", "noopt"): + text = f"test text {name}".upper() + machine.wait_until_succeeds(f"lpstat -v {name}") + machine.succeed(f"su - alice -c 'echo -e \"\n {text}\" | lp -d {name}'") + # wait until the pdf files are completely produced and readable by alice + machine.wait_until_succeeds(f"su - alice -c 'pdfinfo /var/spool/cups-pdf-{name}/users/alice/*.pdf'") + machine.succeed(f"cp /var/spool/cups-pdf-{name}/users/alice/*.pdf /tmp/{name}.pdf") + machine.copy_from_vm(f"/tmp/{name}.pdf", "") + run(f"${pkgs.imagemagickBig}/bin/convert -density 300 $out/{name}.pdf $out/{name}.jpeg", shell=True, check=True) + assert text.encode() in run(f"${lib.getExe pkgs.tesseract} $out/{name}.jpeg stdout", shell=True, check=True, capture_output=True).stdout + ''; - meta.maintainers = [ lib.maintainers.yarny ]; -}) + meta.maintainers = [ lib.maintainers.yarny ]; + } +) diff --git a/nixos/tests/curl-impersonate.nix b/nixos/tests/curl-impersonate.nix index 13eb54b5b2d0de..0846caeec6cb66 100644 --- a/nixos/tests/curl-impersonate.nix +++ b/nixos/tests/curl-impersonate.nix @@ -21,140 +21,182 @@ hostnames in /etc/hosts. */ -import ./make-test-python.nix ({ pkgs, lib, ... }: let - # Update with domains in TestImpersonate.TEST_URLS if needed from: - # https://github.com/lwthiker/curl-impersonate/blob/main/tests/test_impersonate.py - domains = [ - "www.wikimedia.org" - "www.wikipedia.org" - "www.mozilla.org" - "www.apache.org" - "www.kernel.org" - "git-scm.com" - ]; - - tls-certs = let - # Configure CA with X.509 v3 extensions that would be trusted by curl - ca-cert-conf = pkgs.writeText "curl-impersonate-ca.cnf" '' - basicConstraints = critical, CA:TRUE - subjectKeyIdentifier = hash - authorityKeyIdentifier = keyid:always, issuer:always - keyUsage = critical, cRLSign, digitalSignature, keyCertSign - ''; - - # Configure leaf certificate with X.509 v3 extensions that would be trusted - # by curl and set subject-alternative names for test domains - tls-cert-conf = pkgs.writeText "curl-impersonate-tls.cnf" '' - basicConstraints = critical, CA:FALSE - subjectKeyIdentifier = hash - authorityKeyIdentifier = keyid:always, issuer:always - keyUsage = critical, nonRepudiation, digitalSignature, keyEncipherment, keyAgreement - extendedKeyUsage = critical, serverAuth - subjectAltName = @alt_names - - [alt_names] - ${lib.concatStringsSep "\n" (lib.imap0 (idx: domain: "DNS.${toString idx} = ${domain}") domains)} - ''; - in pkgs.runCommand "curl-impersonate-test-certs" { - nativeBuildInputs = [ pkgs.openssl ]; - } '' - # create CA certificate and key - openssl req -newkey rsa:4096 -keyout ca-key.pem -out ca-csr.pem -nodes -subj '/CN=curl-impersonate-ca.nixos.test' - openssl x509 -req -sha512 -in ca-csr.pem -key ca-key.pem -out ca.pem -extfile ${ca-cert-conf} -days 36500 - openssl x509 -in ca.pem -text - - # create server certificate and key - openssl req -newkey rsa:4096 -keyout key.pem -out csr.pem -nodes -subj '/CN=curl-impersonate.nixos.test' - openssl x509 -req -sha512 -in csr.pem -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out cert.pem -extfile ${tls-cert-conf} -days 36500 - openssl x509 -in cert.pem -text - - # output CA cert and server cert and key - mkdir -p $out - cp key.pem cert.pem ca.pem $out - ''; - - # Test script - curl-impersonate-test = let - # Build miniature libcurl client used by test driver - minicurl = pkgs.runCommandCC "minicurl" { - buildInputs = [ pkgs.curl ]; - } '' - mkdir -p $out/bin - $CC -Wall -Werror -o $out/bin/minicurl ${pkgs.curl-impersonate.src}/tests/minicurl.c `curl-config --libs` - ''; - in pkgs.writeShellScript "curl-impersonate-test" '' - set -euxo pipefail - - # Test driver requirements - export PATH="${with pkgs; lib.makeBinPath [ - bash - coreutils - python3Packages.pytest - nghttp2 - tcpdump - ]}" - export PYTHONPATH="${with pkgs.python3Packages; makePythonPath [ - pyyaml - pytest-asyncio - dpkt - ts1-signatures - ]}" - - # Prepare test root prefix - mkdir -p usr/{bin,lib} - cp -rs ${pkgs.curl-impersonate}/* ${minicurl}/* usr/ - - cp -r ${pkgs.curl-impersonate.src}/tests ./ - - # Run tests - cd tests - pytest . --install-dir ../usr --capture-interface eth1 - ''; -in { - name = "curl-impersonate"; - - meta = with lib.maintainers; { - maintainers = [ ]; - }; - - nodes = { - web = { nodes, pkgs, lib, config, ... }: { - networking.firewall.allowedTCPPorts = [ 80 443 ]; - - services = { - nginx = { - enable = true; - virtualHosts."curl-impersonate.nixos.test" = { - default = true; - addSSL = true; - sslCertificate = "${tls-certs}/cert.pem"; - sslCertificateKey = "${tls-certs}/key.pem"; - }; - }; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + # Update with domains in TestImpersonate.TEST_URLS if needed from: + # https://github.com/lwthiker/curl-impersonate/blob/main/tests/test_impersonate.py + domains = [ + "www.wikimedia.org" + "www.wikipedia.org" + "www.mozilla.org" + "www.apache.org" + "www.kernel.org" + "git-scm.com" + ]; + + tls-certs = + let + # Configure CA with X.509 v3 extensions that would be trusted by curl + ca-cert-conf = pkgs.writeText "curl-impersonate-ca.cnf" '' + basicConstraints = critical, CA:TRUE + subjectKeyIdentifier = hash + authorityKeyIdentifier = keyid:always, issuer:always + keyUsage = critical, cRLSign, digitalSignature, keyCertSign + ''; + + # Configure leaf certificate with X.509 v3 extensions that would be trusted + # by curl and set subject-alternative names for test domains + tls-cert-conf = pkgs.writeText "curl-impersonate-tls.cnf" '' + basicConstraints = critical, CA:FALSE + subjectKeyIdentifier = hash + authorityKeyIdentifier = keyid:always, issuer:always + keyUsage = critical, nonRepudiation, digitalSignature, keyEncipherment, keyAgreement + extendedKeyUsage = critical, serverAuth + subjectAltName = @alt_names + + [alt_names] + ${lib.concatStringsSep "\n" (lib.imap0 (idx: domain: "DNS.${toString idx} = ${domain}") domains)} + ''; + in + pkgs.runCommand "curl-impersonate-test-certs" + { + nativeBuildInputs = [ pkgs.openssl ]; + } + '' + # create CA certificate and key + openssl req -newkey rsa:4096 -keyout ca-key.pem -out ca-csr.pem -nodes -subj '/CN=curl-impersonate-ca.nixos.test' + openssl x509 -req -sha512 -in ca-csr.pem -key ca-key.pem -out ca.pem -extfile ${ca-cert-conf} -days 36500 + openssl x509 -in ca.pem -text + + # create server certificate and key + openssl req -newkey rsa:4096 -keyout key.pem -out csr.pem -nodes -subj '/CN=curl-impersonate.nixos.test' + openssl x509 -req -sha512 -in csr.pem -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out cert.pem -extfile ${tls-cert-conf} -days 36500 + openssl x509 -in cert.pem -text + + # output CA cert and server cert and key + mkdir -p $out + cp key.pem cert.pem ca.pem $out + ''; + + # Test script + curl-impersonate-test = + let + # Build miniature libcurl client used by test driver + minicurl = + pkgs.runCommandCC "minicurl" + { + buildInputs = [ pkgs.curl ]; + } + '' + mkdir -p $out/bin + $CC -Wall -Werror -o $out/bin/minicurl ${pkgs.curl-impersonate.src}/tests/minicurl.c `curl-config --libs` + ''; + in + pkgs.writeShellScript "curl-impersonate-test" '' + set -euxo pipefail + + # Test driver requirements + export PATH="${ + with pkgs; + lib.makeBinPath [ + bash + coreutils + python3Packages.pytest + nghttp2 + tcpdump + ] + }" + export PYTHONPATH="${ + with pkgs.python3Packages; + makePythonPath [ + pyyaml + pytest-asyncio + dpkt + ts1-signatures + ] + }" + + # Prepare test root prefix + mkdir -p usr/{bin,lib} + cp -rs ${pkgs.curl-impersonate}/* ${minicurl}/* usr/ + + cp -r ${pkgs.curl-impersonate.src}/tests ./ + + # Run tests + cd tests + pytest . --install-dir ../usr --capture-interface eth1 + ''; + in + { + name = "curl-impersonate"; + + meta = with lib.maintainers; { + maintainers = [ ]; }; - curl = { nodes, pkgs, lib, config, ... }: { - networking.extraHosts = lib.concatStringsSep "\n" (map (domain: "${nodes.web.networking.primaryIPAddress} ${domain}") domains); + nodes = { + web = + { + nodes, + pkgs, + lib, + config, + ... + }: + { + networking.firewall.allowedTCPPorts = [ + 80 + 443 + ]; + + services = { + nginx = { + enable = true; + virtualHosts."curl-impersonate.nixos.test" = { + default = true; + addSSL = true; + sslCertificate = "${tls-certs}/cert.pem"; + sslCertificateKey = "${tls-certs}/key.pem"; + }; + }; + }; + }; - security.pki.certificateFiles = [ "${tls-certs}/ca.pem" ]; + curl = + { + nodes, + pkgs, + lib, + config, + ... + }: + { + networking.extraHosts = lib.concatStringsSep "\n" ( + map (domain: "${nodes.web.networking.primaryIPAddress} ${domain}") domains + ); + + security.pki.certificateFiles = [ "${tls-certs}/ca.pem" ]; + }; }; - }; - - testScript = { nodes, ... }: '' - start_all() - - with subtest("Wait for network"): - web.systemctl("start network-online.target") - curl.systemctl("start network-online.target") - web.wait_for_unit("network-online.target") - curl.wait_for_unit("network-online.target") - - with subtest("Wait for web server"): - web.wait_for_unit("nginx.service") - web.wait_for_open_port(443) - with subtest("Run curl-impersonate tests"): - curl.succeed("${curl-impersonate-test}") - ''; -}) + testScript = + { nodes, ... }: + '' + start_all() + + with subtest("Wait for network"): + web.systemctl("start network-online.target") + curl.systemctl("start network-online.target") + web.wait_for_unit("network-online.target") + curl.wait_for_unit("network-online.target") + + with subtest("Wait for web server"): + web.wait_for_unit("nginx.service") + web.wait_for_open_port(443) + + with subtest("Run curl-impersonate tests"): + curl.succeed("${curl-impersonate-test}") + ''; + } +) diff --git a/nixos/tests/custom-ca.nix b/nixos/tests/custom-ca.nix index 0fcdf81022d72c..b246f5b9ba5788 100644 --- a/nixos/tests/custom-ca.nix +++ b/nixos/tests/custom-ca.nix @@ -3,9 +3,10 @@ # WebKitGTK (via Midori). The test checks that certificates issued by a custom # trusted CA are accepted but those from an unknown CA are rejected. -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -13,183 +14,204 @@ with import ../lib/testing-python.nix { inherit system pkgs; }; let inherit (pkgs) lib; - makeCert = { caName, domain }: pkgs.runCommand "example-cert" - { buildInputs = [ pkgs.gnutls ]; } - '' - mkdir $out - - # CA cert template - cat >ca.template <server.template <ca.template <server.template < Tuple[int, str]: - """ - Run a shell command as a specific user. - """ - return machine.execute(f"sudo -u {user} {cmd}") - - - def wait_for_window_as(user: str, cls: str) -> None: - """ - Wait until a X11 window of a given user appears. - """ - - def window_is_visible(last_try: bool) -> bool: - ret, stdout = execute_as(user, f"xdotool search --onlyvisible --class {cls}") - if last_try: - machine.log(f"Last chance to match {cls} on the window list") - return ret == 0 - - with machine.nested("Waiting for a window to appear"): - retry(window_is_visible) - - - machine.start() - machine.wait_for_x() - - command = "${browser} ${testParams.args or ""}" - with subtest("Good certificate is trusted in ${browser}"): - execute_as( - "alice", f"{command} https://good.example.com >&2 &" - ) - wait_for_window_as("alice", "${browser}") - machine.sleep(4) - execute_as("alice", "xdotool key ctrl+r") # reload to be safe - machine.wait_for_text("It works!") - machine.screenshot("good${browser}") - execute_as("alice", "xdotool key ctrl+w") # close tab - - with subtest("Unknown CA is untrusted in ${browser}"): - execute_as("alice", f"{command} https://bad.example.com >&2 &") - machine.wait_for_text("${testParams.error}") - machine.screenshot("bad${browser}") - ''; - }; + testScript = '' + from typing import Tuple + def execute_as(user: str, cmd: str) -> Tuple[int, str]: + """ + Run a shell command as a specific user. + """ + return machine.execute(f"sudo -u {user} {cmd}") + + + def wait_for_window_as(user: str, cls: str) -> None: + """ + Wait until a X11 window of a given user appears. + """ + + def window_is_visible(last_try: bool) -> bool: + ret, stdout = execute_as(user, f"xdotool search --onlyvisible --class {cls}") + if last_try: + machine.log(f"Last chance to match {cls} on the window list") + return ret == 0 + + with machine.nested("Waiting for a window to appear"): + retry(window_is_visible) + + + machine.start() + machine.wait_for_x() + + command = "${browser} ${testParams.args or ""}" + with subtest("Good certificate is trusted in ${browser}"): + execute_as( + "alice", f"{command} https://good.example.com >&2 &" + ) + wait_for_window_as("alice", "${browser}") + machine.sleep(4) + execute_as("alice", "xdotool key ctrl+r") # reload to be safe + machine.wait_for_text("It works!") + machine.screenshot("good${browser}") + execute_as("alice", "xdotool key ctrl+w") # close tab + + with subtest("Unknown CA is untrusted in ${browser}"): + execute_as("alice", f"{command} https://bad.example.com >&2 &") + machine.wait_for_text("${testParams.error}") + machine.screenshot("bad${browser}") + ''; + }; in { curl = curlTest; -} // pkgs.lib.mapAttrs mkBrowserTest { - firefox = { error = "Security Risk"; }; - chromium = { error = "not private"; }; - qutebrowser = { args = "-T"; error = "Certificate error"; }; - midori = { args = "-p"; error = "Security"; }; +} +// pkgs.lib.mapAttrs mkBrowserTest { + firefox = { + error = "Security Risk"; + }; + chromium = { + error = "not private"; + }; + qutebrowser = { + args = "-T"; + error = "Certificate error"; + }; + midori = { + args = "-p"; + error = "Security"; + }; } diff --git a/nixos/tests/dae.nix b/nixos/tests/dae.nix index 4b856450d9e1da..127bbcb78813a0 100644 --- a/nixos/tests/dae.nix +++ b/nixos/tests/dae.nix @@ -1,33 +1,38 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { - name = "dae"; + name = "dae"; - meta = { - maintainers = with lib.maintainers; [ oluceps ]; - }; - - nodes.machine = { pkgs, ... }: { - environment.systemPackages = [ pkgs.curl ]; - services.nginx = { - enable = true; - statusPage = true; - }; - services.dae = { - enable = true; - config = '' - global { disable_waiting_network: true } - routing{} - ''; + meta = { + maintainers = with lib.maintainers; [ oluceps ]; }; - }; - testScript = '' - machine.wait_for_unit("nginx.service") - machine.wait_for_unit("dae.service") + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.curl ]; + services.nginx = { + enable = true; + statusPage = true; + }; + services.dae = { + enable = true; + config = '' + global { disable_waiting_network: true } + routing{} + ''; + }; + }; + + testScript = '' + machine.wait_for_unit("nginx.service") + machine.wait_for_unit("dae.service") - machine.wait_for_open_port(80) + machine.wait_for_open_port(80) - machine.succeed("curl --fail --max-time 10 http://localhost") - ''; + machine.succeed("curl --fail --max-time 10 http://localhost") + ''; -}) + } +) diff --git a/nixos/tests/darling-dmg.nix b/nixos/tests/darling-dmg.nix index 0a2ec82981228d..86cbdc4968c193 100644 --- a/nixos/tests/darling-dmg.nix +++ b/nixos/tests/darling-dmg.nix @@ -12,7 +12,7 @@ in name = "darling-dmg"; meta.maintainers = with lib.maintainers; [ Luflosi ]; - nodes.machine = {}; + nodes.machine = { }; testScript = '' start_all() diff --git a/nixos/tests/darling.nix b/nixos/tests/darling.nix index 5665b4c2ffef22..8514aac918ed4d 100644 --- a/nixos/tests/darling.nix +++ b/nixos/tests/darling.nix @@ -1,44 +1,52 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: -let - # Well, we _can_ cross-compile from Linux :) - hello = pkgs.runCommand "hello" { - sdk = "${pkgs.darling.sdk}/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk"; - nativeBuildInputs = with pkgs.llvmPackages_14; [ clang-unwrapped lld ]; - src = pkgs.writeText "hello.c" '' - #include - int main() { - printf("Hello, Darling!\n"); - return 0; - } - ''; - } '' - clang \ - -target x86_64-apple-darwin \ - -fuse-ld=lld \ - -nostdinc -nostdlib \ - -mmacosx-version-min=10.15 \ - --sysroot $sdk \ - -isystem $sdk/usr/include \ - -L $sdk/usr/lib -lSystem \ - $src -o $out - ''; -in -{ - name = "darling"; + let + # Well, we _can_ cross-compile from Linux :) + hello = + pkgs.runCommand "hello" + { + sdk = "${pkgs.darling.sdk}/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk"; + nativeBuildInputs = with pkgs.llvmPackages_14; [ + clang-unwrapped + lld + ]; + src = pkgs.writeText "hello.c" '' + #include + int main() { + printf("Hello, Darling!\n"); + return 0; + } + ''; + } + '' + clang \ + -target x86_64-apple-darwin \ + -fuse-ld=lld \ + -nostdinc -nostdlib \ + -mmacosx-version-min=10.15 \ + --sysroot $sdk \ + -isystem $sdk/usr/include \ + -L $sdk/usr/lib -lSystem \ + $src -o $out + ''; + in + { + name = "darling"; - meta.maintainers = with lib.maintainers; [ zhaofengli ]; + meta.maintainers = with lib.maintainers; [ zhaofengli ]; - nodes.machine = { - programs.darling.enable = true; - }; + nodes.machine = { + programs.darling.enable = true; + }; - testScript = '' - start_all() + testScript = '' + start_all() - # Darling holds stdout until the server is shutdown - machine.succeed("darling ${hello} >hello.out") - machine.succeed("grep Hello hello.out") - machine.succeed("darling shutdown") - ''; -}) + # Darling holds stdout until the server is shutdown + machine.succeed("darling ${hello} >hello.out") + machine.succeed("grep Hello hello.out") + machine.succeed("darling shutdown") + ''; + } +) diff --git a/nixos/tests/db-rest.nix b/nixos/tests/db-rest.nix index 9249da904acbe6..18843f33083716 100644 --- a/nixos/tests/db-rest.nix +++ b/nixos/tests/db-rest.nix @@ -1,107 +1,125 @@ -import ./make-test-python.nix ({ pkgs, ... }: -{ - name = "db-rest"; - meta.maintainers = with pkgs.lib.maintainers; [ marie ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "db-rest"; + meta.maintainers = with pkgs.lib.maintainers; [ marie ]; - nodes = { - database = { - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.10"; prefixLength = 24; } - ]; + nodes = { + database = { + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.10"; + prefixLength = 24; + } + ]; + }; + firewall.allowedTCPPorts = [ 31638 ]; }; - firewall.allowedTCPPorts = [ 31638 ]; - }; - - services.redis.servers.db-rest = { - enable = true; - bind = "0.0.0.0"; - requirePass = "choochoo"; - port = 31638; - }; - }; - - serverWithTcp = { pkgs, ... }: { - environment = { - etc = { - "db-rest/password-redis-db".text = '' - choochoo - ''; - }; - }; - - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.11"; prefixLength = 24; } - ]; - }; - firewall.allowedTCPPorts = [ 3000 ]; - }; - services.db-rest = { - enable = true; - host = "0.0.0.0"; - redis = { + services.redis.servers.db-rest = { enable = true; - createLocally = false; - host = "192.168.2.10"; + bind = "0.0.0.0"; + requirePass = "choochoo"; port = 31638; - passwordFile = "/etc/db-rest/password-redis-db"; - useSSL = false; }; }; - }; - serverWithUnixSocket = { pkgs, ... }: { - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.12"; prefixLength = 24; } - ]; + serverWithTcp = + { pkgs, ... }: + { + environment = { + etc = { + "db-rest/password-redis-db".text = '' + choochoo + ''; + }; + }; + + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.11"; + prefixLength = 24; + } + ]; + }; + firewall.allowedTCPPorts = [ 3000 ]; + }; + + services.db-rest = { + enable = true; + host = "0.0.0.0"; + redis = { + enable = true; + createLocally = false; + host = "192.168.2.10"; + port = 31638; + passwordFile = "/etc/db-rest/password-redis-db"; + useSSL = false; + }; + }; }; - firewall.allowedTCPPorts = [ 3000 ]; - }; - services.db-rest = { - enable = true; - host = "0.0.0.0"; - redis = { - enable = true; - createLocally = true; + serverWithUnixSocket = + { pkgs, ... }: + { + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.12"; + prefixLength = 24; + } + ]; + }; + firewall.allowedTCPPorts = [ 3000 ]; + }; + + services.db-rest = { + enable = true; + host = "0.0.0.0"; + redis = { + enable = true; + createLocally = true; + }; + }; }; - }; - }; - client = { - environment.systemPackages = [ pkgs.jq ]; - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.13"; prefixLength = 24; } - ]; + client = { + environment.systemPackages = [ pkgs.jq ]; + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.13"; + prefixLength = 24; + } + ]; + }; }; }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - with subtest("db-rest redis with TCP socket"): - database.wait_for_unit("redis-db-rest.service") - database.wait_for_open_port(31638) + with subtest("db-rest redis with TCP socket"): + database.wait_for_unit("redis-db-rest.service") + database.wait_for_open_port(31638) - serverWithTcp.wait_for_unit("db-rest.service") - serverWithTcp.wait_for_open_port(3000) + serverWithTcp.wait_for_unit("db-rest.service") + serverWithTcp.wait_for_open_port(3000) - client.succeed("curl --fail --get http://192.168.2.11:3000/stations --data-urlencode 'query=Köln Hbf' | jq -r '.\"8000207\".name' | grep 'Köln Hbf'") + client.succeed("curl --fail --get http://192.168.2.11:3000/stations --data-urlencode 'query=Köln Hbf' | jq -r '.\"8000207\".name' | grep 'Köln Hbf'") - with subtest("db-rest redis with Unix socket"): - serverWithUnixSocket.wait_for_unit("db-rest.service") - serverWithUnixSocket.wait_for_open_port(3000) + with subtest("db-rest redis with Unix socket"): + serverWithUnixSocket.wait_for_unit("db-rest.service") + serverWithUnixSocket.wait_for_open_port(3000) - client.succeed("curl --fail --get http://192.168.2.12:3000/stations --data-urlencode 'query=Köln Hbf' | jq -r '.\"8000207\".name' | grep 'Köln Hbf'") - ''; -}) + client.succeed("curl --fail --get http://192.168.2.12:3000/stations --data-urlencode 'query=Köln Hbf' | jq -r '.\"8000207\".name' | grep 'Köln Hbf'") + ''; + } +) diff --git a/nixos/tests/dconf.nix b/nixos/tests/dconf.nix index 192c075540a40c..933817917104b4 100644 --- a/nixos/tests/dconf.nix +++ b/nixos/tests/dconf.nix @@ -1,5 +1,5 @@ -import ./make-test-python.nix - ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: { name = "dconf"; @@ -7,23 +7,32 @@ import ./make-test-python.nix linsui ]; - nodes.machine = { config, pkgs, lib, ... }: { - users.extraUsers.alice = { isNormalUser = true; }; - programs.dconf = with lib.gvariant; { - enable = true; - profiles.user.databases = [ - { - settings = { - "test/not".locked = mkInt32 1; - "test/is".locked = "locked"; - }; - locks = [ - "/test/is/locked" - ]; - } - ]; + nodes.machine = + { + config, + pkgs, + lib, + ... + }: + { + users.extraUsers.alice = { + isNormalUser = true; + }; + programs.dconf = with lib.gvariant; { + enable = true; + profiles.user.databases = [ + { + settings = { + "test/not".locked = mkInt32 1; + "test/is".locked = "locked"; + }; + locks = [ + "/test/is/locked" + ]; + } + ]; + }; }; - }; testScript = '' machine.succeed("test $(dconf read -d /test/not/locked) == 1") @@ -31,4 +40,5 @@ import ./make-test-python.nix machine.fail("sudo -u alice dbus-run-session -- dconf write /test/is/locked \"@s 'unlocked'\"") machine.succeed("sudo -u alice dbus-run-session -- dconf write /test/not/locked \"@i 2\"") ''; - }) + } +) diff --git a/nixos/tests/deconz.nix b/nixos/tests/deconz.nix index cbe721ba492513..ceeabb6c261aac 100644 --- a/nixos/tests/deconz.nix +++ b/nixos/tests/deconz.nix @@ -1,28 +1,37 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - httpPort = 800; -in -{ - name = "deconz"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + httpPort = 800; + in + { + name = "deconz"; - meta.maintainers = with lib.maintainers; [ - bjornfor - ]; + meta.maintainers = with lib.maintainers; [ + bjornfor + ]; - nodes.machine = { config, pkgs, lib, ... }: { - nixpkgs.config.allowUnfree = true; - services.deconz = { - enable = true; - inherit httpPort; - extraArgs = [ - "--dbg-err=2" - "--dbg-info=2" - ]; - }; - }; + nodes.machine = + { + config, + pkgs, + lib, + ... + }: + { + nixpkgs.config.allowUnfree = true; + services.deconz = { + enable = true; + inherit httpPort; + extraArgs = [ + "--dbg-err=2" + "--dbg-info=2" + ]; + }; + }; - testScript = '' - machine.wait_for_unit("deconz.service") - machine.succeed("curl -sfL http://localhost:${toString httpPort}") - ''; -}) + testScript = '' + machine.wait_for_unit("deconz.service") + machine.succeed("curl -sfL http://localhost:${toString httpPort}") + ''; + } +) diff --git a/nixos/tests/deepin.nix b/nixos/tests/deepin.nix index d3ce79a535c13a..bf545c08f88681 100644 --- a/nixos/tests/deepin.nix +++ b/nixos/tests/deepin.nix @@ -1,51 +1,57 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "deepin"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "deepin"; - meta.maintainers = lib.teams.deepin.members; + meta.maintainers = lib.teams.deepin.members; - nodes.machine = { ... }: { - imports = [ - ./common/user-account.nix - ]; + nodes.machine = + { ... }: + { + imports = [ + ./common/user-account.nix + ]; - virtualisation.memorySize = 2048; + virtualisation.memorySize = 2048; - services.xserver.enable = true; + services.xserver.enable = true; - services.xserver.displayManager = { - lightdm.enable = true; - autoLogin = { - enable = true; - user = "alice"; + services.xserver.displayManager = { + lightdm.enable = true; + autoLogin = { + enable = true; + user = "alice"; + }; + }; + + services.xserver.desktopManager.deepin.enable = true; }; - }; - - services.xserver.desktopManager.deepin.enable = true; - }; - - testScript = { nodes, ... }: - let - user = nodes.machine.users.users.alice; - in - '' - with subtest("Wait for login"): - machine.wait_for_x() - machine.wait_for_file("${user.home}/.Xauthority") - machine.succeed("xauth merge ${user.home}/.Xauthority") - - with subtest("Check that logging in has given the user ownership of devices"): - machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") - - with subtest("Check if Deepin session components actually start"): - machine.wait_until_succeeds("pgrep -f dde-session-daemon") - machine.wait_for_window("dde-session-daemon") - machine.wait_until_succeeds("pgrep -f dde-desktop") - machine.wait_for_window("dde-desktop") - - with subtest("Open deepin-terminal"): - machine.succeed("su - ${user.name} -c 'DISPLAY=:0 deepin-terminal >&2 &'") - machine.wait_for_window("deepin-terminal") - machine.sleep(20) - machine.screenshot("screen") - ''; -}) + + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + in + '' + with subtest("Wait for login"): + machine.wait_for_x() + machine.wait_for_file("${user.home}/.Xauthority") + machine.succeed("xauth merge ${user.home}/.Xauthority") + + with subtest("Check that logging in has given the user ownership of devices"): + machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") + + with subtest("Check if Deepin session components actually start"): + machine.wait_until_succeeds("pgrep -f dde-session-daemon") + machine.wait_for_window("dde-session-daemon") + machine.wait_until_succeeds("pgrep -f dde-desktop") + machine.wait_for_window("dde-desktop") + + with subtest("Open deepin-terminal"): + machine.succeed("su - ${user.name} -c 'DISPLAY=:0 deepin-terminal >&2 &'") + machine.wait_for_window("deepin-terminal") + machine.sleep(20) + machine.screenshot("screen") + ''; + } +) diff --git a/nixos/tests/devpi-server.nix b/nixos/tests/devpi-server.nix index 2a16d49724dbcb..cec019e9d1c416 100644 --- a/nixos/tests/devpi-server.nix +++ b/nixos/tests/devpi-server.nix @@ -1,35 +1,43 @@ -import ./make-test-python.nix ({pkgs, ...}: let - server-port = 3141; -in { - name = "devpi-server"; - meta = with pkgs.lib.maintainers; { - maintainers = [cafkafk]; - }; - - nodes = { - devpi = {...}: { - services.devpi-server = { - enable = true; - host = "0.0.0.0"; - port = server-port; - openFirewall = true; - secretFile = pkgs.writeText "devpi-secret" "v263P+V3YGDYUyfYL/RBURw+tCPMDw94R/iCuBNJrDhaYrZYjpA6XPFVDDH8ViN20j77y2PHoMM/U0opNkVQ2g=="; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + let + server-port = 3141; + in + { + name = "devpi-server"; + meta = with pkgs.lib.maintainers; { + maintainers = [ cafkafk ]; }; - client1 = {...}: { - environment.systemPackages = with pkgs; [ - devpi-client - jq - ]; + nodes = { + devpi = + { ... }: + { + services.devpi-server = { + enable = true; + host = "0.0.0.0"; + port = server-port; + openFirewall = true; + secretFile = pkgs.writeText "devpi-secret" "v263P+V3YGDYUyfYL/RBURw+tCPMDw94R/iCuBNJrDhaYrZYjpA6XPFVDDH8ViN20j77y2PHoMM/U0opNkVQ2g=="; + }; + }; + + client1 = + { ... }: + { + environment.systemPackages = with pkgs; [ + devpi-client + jq + ]; + }; }; - }; - testScript = '' - start_all() - devpi.wait_for_unit("devpi-server.service") - devpi.wait_for_open_port(${builtins.toString server-port}) + testScript = '' + start_all() + devpi.wait_for_unit("devpi-server.service") + devpi.wait_for_open_port(${builtins.toString server-port}) - client1.succeed("devpi getjson http://devpi:${builtins.toString server-port}") - ''; -}) + client1.succeed("devpi getjson http://devpi:${builtins.toString server-port}") + ''; + } +) diff --git a/nixos/tests/dex-oidc.nix b/nixos/tests/dex-oidc.nix index d3baa4fbf24559..37718fdcdbdec9 100644 --- a/nixos/tests/dex-oidc.nix +++ b/nixos/tests/dex-oidc.nix @@ -1,79 +1,84 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "dex-oidc"; - meta.maintainers = with lib.maintainers; [ Flakebi ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "dex-oidc"; + meta.maintainers = with lib.maintainers; [ Flakebi ]; - nodes.machine = { pkgs, ... }: { - environment.systemPackages = with pkgs; [ jq ]; - services.dex = { - enable = true; - settings = { - issuer = "http://127.0.0.1:8080/dex"; - storage = { - type = "postgres"; - config.host = "/var/run/postgresql"; - }; - web.http = "127.0.0.1:8080"; - oauth2.skipApprovalScreen = true; - staticClients = [ - { - id = "oidcclient"; - name = "Client"; - redirectURIs = [ "https://example.com/callback" ]; - secretFile = "/etc/dex/oidcclient"; - } - ]; - connectors = [ - { - type = "mockPassword"; - id = "mock"; - name = "Example"; - config = { - username = "admin"; - password = "password"; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = with pkgs; [ jq ]; + services.dex = { + enable = true; + settings = { + issuer = "http://127.0.0.1:8080/dex"; + storage = { + type = "postgres"; + config.host = "/var/run/postgresql"; }; - } - ]; - }; - }; + web.http = "127.0.0.1:8080"; + oauth2.skipApprovalScreen = true; + staticClients = [ + { + id = "oidcclient"; + name = "Client"; + redirectURIs = [ "https://example.com/callback" ]; + secretFile = "/etc/dex/oidcclient"; + } + ]; + connectors = [ + { + type = "mockPassword"; + id = "mock"; + name = "Example"; + config = { + username = "admin"; + password = "password"; + }; + } + ]; + }; + }; - # This should not be set from nix but through other means to not leak the secret. - environment.etc."dex/oidcclient" = { - mode = "0400"; - user = "dex"; - text = "oidcclientsecret"; - }; + # This should not be set from nix but through other means to not leak the secret. + environment.etc."dex/oidcclient" = { + mode = "0400"; + user = "dex"; + text = "oidcclientsecret"; + }; - services.postgresql = { - enable = true; - ensureDatabases =[ "dex" ]; - ensureUsers = [ - { - name = "dex"; - ensureDBOwnership = true; - } - ]; - }; - }; + services.postgresql = { + enable = true; + ensureDatabases = [ "dex" ]; + ensureUsers = [ + { + name = "dex"; + ensureDBOwnership = true; + } + ]; + }; + }; - testScript = '' - with subtest("Web server gets ready"): - machine.wait_for_unit("dex.service", timeout=120) - # Wait until server accepts connections - machine.wait_until_succeeds("curl -fs 'localhost:8080/dex/auth/mock?client_id=oidcclient&response_type=code&redirect_uri=https://example.com/callback&scope=openid'", timeout=120) + testScript = '' + with subtest("Web server gets ready"): + machine.wait_for_unit("dex.service", timeout=120) + # Wait until server accepts connections + machine.wait_until_succeeds("curl -fs 'localhost:8080/dex/auth/mock?client_id=oidcclient&response_type=code&redirect_uri=https://example.com/callback&scope=openid'", timeout=120) - with subtest("Login"): - state = machine.succeed("curl -fs 'localhost:8080/dex/auth/mock?client_id=oidcclient&response_type=code&redirect_uri=https://example.com/callback&scope=openid' | sed -n 's/.*state=\\(.*\\)\">.*/\\1/p'").strip() - print(f"Got state {state}") - # Login request returns 303 with redirect_url that has code as query parameter: - # https://example.com/callback?code=kibsamwdupuy2iwqnlbqei3u6&state= - code = machine.succeed(f"curl -fs 'localhost:8080/dex/auth/mock/login?back=&state={state}' -d 'login=admin&password=password' -w '%{{redirect_url}}' | sed -n 's/.*code=\\(.*\\)&.*/\\1/p'") - print(f"Got approval code {code}") - bearer = machine.succeed(f"curl -fs localhost:8080/dex/token -u oidcclient:oidcclientsecret -d 'grant_type=authorization_code&redirect_uri=https://example.com/callback&code={code}' | jq .access_token -r").strip() - print(f"Got access token {bearer}") + with subtest("Login"): + state = machine.succeed("curl -fs 'localhost:8080/dex/auth/mock?client_id=oidcclient&response_type=code&redirect_uri=https://example.com/callback&scope=openid' | sed -n 's/.*state=\\(.*\\)\">.*/\\1/p'").strip() + print(f"Got state {state}") + # Login request returns 303 with redirect_url that has code as query parameter: + # https://example.com/callback?code=kibsamwdupuy2iwqnlbqei3u6&state= + code = machine.succeed(f"curl -fs 'localhost:8080/dex/auth/mock/login?back=&state={state}' -d 'login=admin&password=password' -w '%{{redirect_url}}' | sed -n 's/.*code=\\(.*\\)&.*/\\1/p'") + print(f"Got approval code {code}") + bearer = machine.succeed(f"curl -fs localhost:8080/dex/token -u oidcclient:oidcclientsecret -d 'grant_type=authorization_code&redirect_uri=https://example.com/callback&code={code}' | jq .access_token -r").strip() + print(f"Got access token {bearer}") - with subtest("Get userinfo"): - assert '"sub"' in machine.succeed( - f"curl -fs localhost:8080/dex/userinfo --oauth2-bearer {bearer}" - ) - ''; -}) + with subtest("Get userinfo"): + assert '"sub"' in machine.succeed( + f"curl -fs localhost:8080/dex/userinfo --oauth2-bearer {bearer}" + ) + ''; + } +) diff --git a/nixos/tests/dhparams.nix b/nixos/tests/dhparams.nix index 8d7082c1140014..9490ac70d54e39 100644 --- a/nixos/tests/dhparams.nix +++ b/nixos/tests/dhparams.nix @@ -1,130 +1,143 @@ import ./make-test-python.nix { name = "dhparams"; - nodes.machine = { pkgs, ... }: { - security.dhparams.enable = true; - environment.systemPackages = [ pkgs.openssl ]; - - specialisation = { - gen1.configuration = { config, ... }: { - security.dhparams.params = { - # Use low values here because we don't want the test to run for ages. - foo.bits = 1024; - # Also use the old format to make sure the type is coerced in the right - # way. - bar = 1025; - }; - - systemd.services.foo = { - description = "Check systemd Ordering"; - wantedBy = [ "multi-user.target" ]; - before = [ "shutdown.target" ]; - conflicts = [ "shutdown.target" ]; - unitConfig = { - # This is to make sure that the dhparams generation of foo occurs - # before this service so we need this service to start as early as - # possible to provoke a race condition. - DefaultDependencies = false; - - # We check later whether the service has been started or not. - ConditionPathExists = config.security.dhparams.params.foo.path; + nodes.machine = + { pkgs, ... }: + { + security.dhparams.enable = true; + environment.systemPackages = [ pkgs.openssl ]; + + specialisation = { + gen1.configuration = + { config, ... }: + { + security.dhparams.params = { + # Use low values here because we don't want the test to run for ages. + foo.bits = 1024; + # Also use the old format to make sure the type is coerced in the right + # way. + bar = 1025; + }; + + systemd.services.foo = { + description = "Check systemd Ordering"; + wantedBy = [ "multi-user.target" ]; + before = [ "shutdown.target" ]; + conflicts = [ "shutdown.target" ]; + unitConfig = { + # This is to make sure that the dhparams generation of foo occurs + # before this service so we need this service to start as early as + # possible to provoke a race condition. + DefaultDependencies = false; + + # We check later whether the service has been started or not. + ConditionPathExists = config.security.dhparams.params.foo.path; + }; + serviceConfig.Type = "oneshot"; + serviceConfig.RemainAfterExit = true; + # The reason we only provide an ExecStop here is to ensure that we don't + # accidentally trigger an error because a file system is not yet ready + # during very early startup (we might not even have the Nix store + # available, for example if future changes in NixOS use systemd mount + # units to do early file system initialisation). + serviceConfig.ExecStop = "${pkgs.coreutils}/bin/true"; + }; }; - serviceConfig.Type = "oneshot"; - serviceConfig.RemainAfterExit = true; - # The reason we only provide an ExecStop here is to ensure that we don't - # accidentally trigger an error because a file system is not yet ready - # during very early startup (we might not even have the Nix store - # available, for example if future changes in NixOS use systemd mount - # units to do early file system initialisation). - serviceConfig.ExecStop = "${pkgs.coreutils}/bin/true"; + gen2.configuration = { + security.dhparams.params.foo.bits = 1026; + }; + gen3.configuration = { }; + gen4.configuration = { + security.dhparams.stateful = false; + security.dhparams.params.foo2.bits = 1027; + security.dhparams.params.bar2.bits = 1028; + }; + gen5.configuration = { + security.dhparams.defaultBitSize = 1029; + security.dhparams.params.foo3 = { }; + security.dhparams.params.bar3 = { }; }; - }; - gen2.configuration = { - security.dhparams.params.foo.bits = 1026; - }; - gen3.configuration = {}; - gen4.configuration = { - security.dhparams.stateful = false; - security.dhparams.params.foo2.bits = 1027; - security.dhparams.params.bar2.bits = 1028; - }; - gen5.configuration = { - security.dhparams.defaultBitSize = 1029; - security.dhparams.params.foo3 = {}; - security.dhparams.params.bar3 = {}; }; }; - }; - - testScript = { nodes, ... }: let - getParamPath = gen: name: let - node = "gen${toString gen}"; - in nodes.machine.config.specialisation.${node}.configuration.security.dhparams.params.${name}.path; - - switchToGeneration = gen: let - switchCmd = "${nodes.machine.config.system.build.toplevel}/specialisation/gen${toString gen}/bin/switch-to-configuration test"; - in '' - with machine.nested("switch to generation ${toString gen}"): - machine.succeed("${switchCmd}") - ''; - - in '' - import re - - - def assert_param_bits(path, bits): - with machine.nested(f"check bit size of {path}"): - output = machine.succeed(f"openssl dhparam -in {path} -text") - pattern = re.compile(r"^\s*DH Parameters:\s+\((\d+)\s+bit\)\s*$", re.M) - match = pattern.match(output) - if match is None: - raise Exception("bla") - if match[1] != str(bits): - raise Exception(f"bit size should be {bits} but it is {match[1]} instead.") - - machine.wait_for_unit("multi-user.target") - ${switchToGeneration 1} - with subtest("verify startup order"): - machine.succeed("systemctl is-active foo.service") - - with subtest("check bit sizes of dhparam files"): - assert_param_bits("${getParamPath 1 "foo"}", 1024) - assert_param_bits("${getParamPath 1 "bar"}", 1025) - - ${switchToGeneration 2} - - with subtest("check whether bit size has changed"): - assert_param_bits("${getParamPath 2 "foo"}", 1026) - - with subtest("ensure that dhparams file for 'bar' was deleted"): - machine.fail("test -e ${getParamPath 1 "bar"}") - - ${switchToGeneration 3} - - with subtest("ensure that 'security.dhparams.path' has been deleted"): - machine.fail("test -e ${nodes.machine.config.specialisation.gen3.configuration.security.dhparams.path}") - - ${switchToGeneration 4} - - with subtest("check bit sizes dhparam files"): - assert_param_bits( - "${getParamPath 4 "foo2"}", 1027 - ) - assert_param_bits( - "${getParamPath 4 "bar2"}", 1028 - ) - - with subtest("check whether dhparam files are in the Nix store"): - machine.succeed( - "expr match ${getParamPath 4 "foo2"} ${builtins.storeDir}", - "expr match ${getParamPath 4 "bar2"} ${builtins.storeDir}", - ) - - ${switchToGeneration 5} - - with subtest("check whether defaultBitSize works as intended"): - assert_param_bits("${getParamPath 5 "foo3"}", 1029) - assert_param_bits("${getParamPath 5 "bar3"}", 1029) - ''; + testScript = + { nodes, ... }: + let + getParamPath = + gen: name: + let + node = "gen${toString gen}"; + in + nodes.machine.config.specialisation.${node}.configuration.security.dhparams.params.${name}.path; + + switchToGeneration = + gen: + let + switchCmd = "${nodes.machine.config.system.build.toplevel}/specialisation/gen${toString gen}/bin/switch-to-configuration test"; + in + '' + with machine.nested("switch to generation ${toString gen}"): + machine.succeed("${switchCmd}") + ''; + + in + '' + import re + + + def assert_param_bits(path, bits): + with machine.nested(f"check bit size of {path}"): + output = machine.succeed(f"openssl dhparam -in {path} -text") + pattern = re.compile(r"^\s*DH Parameters:\s+\((\d+)\s+bit\)\s*$", re.M) + match = pattern.match(output) + if match is None: + raise Exception("bla") + if match[1] != str(bits): + raise Exception(f"bit size should be {bits} but it is {match[1]} instead.") + + machine.wait_for_unit("multi-user.target") + ${switchToGeneration 1} + + with subtest("verify startup order"): + machine.succeed("systemctl is-active foo.service") + + with subtest("check bit sizes of dhparam files"): + assert_param_bits("${getParamPath 1 "foo"}", 1024) + assert_param_bits("${getParamPath 1 "bar"}", 1025) + + ${switchToGeneration 2} + + with subtest("check whether bit size has changed"): + assert_param_bits("${getParamPath 2 "foo"}", 1026) + + with subtest("ensure that dhparams file for 'bar' was deleted"): + machine.fail("test -e ${getParamPath 1 "bar"}") + + ${switchToGeneration 3} + + with subtest("ensure that 'security.dhparams.path' has been deleted"): + machine.fail("test -e ${nodes.machine.config.specialisation.gen3.configuration.security.dhparams.path}") + + ${switchToGeneration 4} + + with subtest("check bit sizes dhparam files"): + assert_param_bits( + "${getParamPath 4 "foo2"}", 1027 + ) + assert_param_bits( + "${getParamPath 4 "bar2"}", 1028 + ) + + with subtest("check whether dhparam files are in the Nix store"): + machine.succeed( + "expr match ${getParamPath 4 "foo2"} ${builtins.storeDir}", + "expr match ${getParamPath 4 "bar2"} ${builtins.storeDir}", + ) + + ${switchToGeneration 5} + + with subtest("check whether defaultBitSize works as intended"): + assert_param_bits("${getParamPath 5 "foo3"}", 1029) + assert_param_bits("${getParamPath 5 "bar3"}", 1029) + ''; } diff --git a/nixos/tests/disable-installer-tools.nix b/nixos/tests/disable-installer-tools.nix index 69f99122753a83..d794f7d3f86dbb 100644 --- a/nixos/tests/disable-installer-tools.nix +++ b/nixos/tests/disable-installer-tools.nix @@ -1,17 +1,22 @@ -import ./make-test-python.nix ({ pkgs, latestKernel ? false, ... }: +import ./make-test-python.nix ( + { + pkgs, + latestKernel ? false, + ... + }: -{ - name = "disable-installer-tools"; + { + name = "disable-installer-tools"; - nodes.machine = - { pkgs, lib, ... }: - { + nodes.machine = + { pkgs, lib, ... }: + { system.disableInstallerTools = true; boot.enableContainers = false; - environment.defaultPackages = []; - }; + environment.defaultPackages = [ ]; + }; - testScript = '' + testScript = '' machine.wait_for_unit("multi-user.target") machine.wait_until_succeeds("pgrep -f 'agetty.*tty1'") @@ -25,5 +30,6 @@ import ./make-test-python.nix ({ pkgs, latestKernel ? false, ... }: with subtest("perl should not be included"): machine.fail("which perl") - ''; -}) + ''; + } +) diff --git a/nixos/tests/discourse.nix b/nixos/tests/discourse.nix index 3e69a314905cca..3accebe8f31f05 100644 --- a/nixos/tests/discourse.nix +++ b/nixos/tests/discourse.nix @@ -4,7 +4,12 @@ # 3. replying to that message via email. import ./make-test-python.nix ( - { pkgs, lib, package ? pkgs.discourse, ... }: + { + pkgs, + lib, + package ? pkgs.discourse, + ... + }: let certs = import ./common/acme/server/snakeoil-certs.nix; clientDomain = "client.fake.domain"; @@ -76,7 +81,10 @@ import ./make-test-python.nix ( unicornTimeout = 900; }; - networking.firewall.allowedTCPPorts = [ 25 465 ]; + networking.firewall.allowedTCPPorts = [ + 25 + 465 + ]; }; nodes.client = @@ -155,13 +163,13 @@ import ./make-test-python.nix ( smtp.quit() ''; in - [ replyToEmail ]; + [ replyToEmail ]; networking.firewall.allowedTCPPorts = [ 25 ]; }; - - testScript = { nodes }: + testScript = + { nodes }: let request = builtins.toJSON { title = "Private message"; @@ -169,7 +177,8 @@ import ./make-test-python.nix ( target_recipients = admin.username; archetype = "private_message"; }; - in '' + in + '' discourse.start() client.start() @@ -199,4 +208,5 @@ import ./make-test-python.nix ( 'curl -sS -f https://${discourseDomain}/t/$(Test reply.

" then true else null end\' ' ) ''; - }) + } +) diff --git a/nixos/tests/dnscrypt-proxy2.nix b/nixos/tests/dnscrypt-proxy2.nix index a75a745d3553ce..eca17dfc78396c 100644 --- a/nixos/tests/dnscrypt-proxy2.nix +++ b/nixos/tests/dnscrypt-proxy2.nix @@ -1,38 +1,42 @@ -import ./make-test-python.nix ({ pkgs, ... }: let - localProxyPort = 43; -in { - name = "dnscrypt-proxy2"; - meta = with pkgs.lib.maintainers; { - maintainers = [ joachifm ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + let + localProxyPort = 43; + in + { + name = "dnscrypt-proxy2"; + meta = with pkgs.lib.maintainers; { + maintainers = [ joachifm ]; + }; - nodes = { - # A client running the recommended setup: DNSCrypt proxy as a forwarder - # for a caching DNS client. - client = - { ... }: - { - security.apparmor.enable = true; + nodes = { + # A client running the recommended setup: DNSCrypt proxy as a forwarder + # for a caching DNS client. + client = + { ... }: + { + security.apparmor.enable = true; - services.dnscrypt-proxy2.enable = true; - services.dnscrypt-proxy2.settings = { - listen_addresses = [ "127.0.0.1:${toString localProxyPort}" ]; - sources.public-resolvers = { - urls = [ "https://download.dnscrypt.info/resolvers-list/v2/public-resolvers.md" ]; - cache_file = "public-resolvers.md"; - minisign_key = "RWQf6LRCGA9i53mlYecO4IzT51TGPpvWucNSCh1CBM0QTaLn73Y7GFO3"; - refresh_delay = 72; - }; - }; + services.dnscrypt-proxy2.enable = true; + services.dnscrypt-proxy2.settings = { + listen_addresses = [ "127.0.0.1:${toString localProxyPort}" ]; + sources.public-resolvers = { + urls = [ "https://download.dnscrypt.info/resolvers-list/v2/public-resolvers.md" ]; + cache_file = "public-resolvers.md"; + minisign_key = "RWQf6LRCGA9i53mlYecO4IzT51TGPpvWucNSCh1CBM0QTaLn73Y7GFO3"; + refresh_delay = 72; + }; + }; - services.dnsmasq.enable = true; - services.dnsmasq.settings.server = [ "127.0.0.1#${toString localProxyPort}" ]; + services.dnsmasq.enable = true; + services.dnsmasq.settings.server = [ "127.0.0.1#${toString localProxyPort}" ]; + }; }; - }; - testScript = '' - client.wait_for_unit("dnsmasq") - client.wait_for_unit("dnscrypt-proxy2") - client.wait_until_succeeds("ss --numeric --udp --listening | grep -q ${toString localProxyPort}") - ''; -}) + testScript = '' + client.wait_for_unit("dnsmasq") + client.wait_for_unit("dnscrypt-proxy2") + client.wait_until_succeeds("ss --numeric --udp --listening | grep -q ${toString localProxyPort}") + ''; + } +) diff --git a/nixos/tests/dnsdist.nix b/nixos/tests/dnsdist.nix index 33f25d01941338..539d8d6c400849 100644 --- a/nixos/tests/dnsdist.nix +++ b/nixos/tests/dnsdist.nix @@ -64,7 +64,7 @@ in networking.firewall.allowedTCPPorts = [ 443 ]; networking.firewall.allowedUDPPorts = [ 443 ]; services.dnsdist.dnscrypt.enable = true; - services.dnsdist.dnscrypt.providerKey = pkgs.runCommand "dnscrypt-secret.key" {} '' + services.dnsdist.dnscrypt.providerKey = pkgs.runCommand "dnscrypt-secret.key" { } '' echo 'R70+xqm7AaDsPtDgpSjSG7KHvEqVf6u6PZ+E3cGPbOwUQdg6/ RIIpK6pHkINhrv7nxwIG5c7b/m5NJVT3A1AXQ==' | base64 -id > "$out" ''; @@ -74,14 +74,13 @@ in nodes.client = { services.dnscrypt-proxy2.enable = true; services.dnscrypt-proxy2.upstreamDefaults = false; - services.dnscrypt-proxy2.settings = - { server_names = [ "server" ]; - listen_addresses = [ "[::1]:53" ]; - cache = false; - # Computed using https://dnscrypt.info/stamps/ - static.server.stamp = - "sdns://AQAAAAAAAAAADzE5Mi4xNjguMS4yOjQ0MyAUQdg6_RIIpK6pHkINhrv7nxwIG5c7b_m5NJVT3A1AXRYyLmRuc2NyeXB0LWNlcnQuc2VydmVy"; - }; + services.dnscrypt-proxy2.settings = { + server_names = [ "server" ]; + listen_addresses = [ "[::1]:53" ]; + cache = false; + # Computed using https://dnscrypt.info/stamps/ + static.server.stamp = "sdns://AQAAAAAAAAAADzE5Mi4xNjguMS4yOjQ0MyAUQdg6_RIIpK6pHkINhrv7nxwIG5c7b_m5NJVT3A1AXRYyLmRuc2NyeXB0LWNlcnQuc2VydmVy"; + }; networking.nameservers = [ "::1" ]; }; diff --git a/nixos/tests/doas.nix b/nixos/tests/doas.nix index 2aa8b02caf574b..75c7f346735234 100644 --- a/nixos/tests/doas.nix +++ b/nixos/tests/doas.nix @@ -1,38 +1,95 @@ # Some tests to ensure doas is working properly. import ./make-test-python.nix ( - { lib, ... }: { + { lib, ... }: + { name = "doas"; meta.maintainers = with lib.maintainers; [ cole-h ]; nodes.machine = { ... }: - { - users.groups = { foobar = {}; barfoo = {}; baz = { gid = 1337; }; }; - users.users = { - test0 = { isNormalUser = true; extraGroups = [ "wheel" ]; }; - test1 = { isNormalUser = true; }; - test2 = { isNormalUser = true; extraGroups = [ "foobar" ]; }; - test3 = { isNormalUser = true; extraGroups = [ "barfoo" ]; }; - test4 = { isNormalUser = true; extraGroups = [ "baz" ]; }; - test5 = { isNormalUser = true; }; - test6 = { isNormalUser = true; }; - test7 = { isNormalUser = true; }; + { + users.groups = { + foobar = { }; + barfoo = { }; + baz = { + gid = 1337; }; - - security.doas = { - enable = true; - wheelNeedsPassword = false; - - extraRules = [ - { users = [ "test1" ]; groups = [ "foobar" ]; } - { users = [ "test2" ]; noPass = true; setEnv = [ "CORRECT" "HORSE=BATTERY" ]; } - { groups = [ "barfoo" 1337 ]; noPass = true; } - { users = [ "test5" ]; noPass = true; keepEnv = true; runAs = "test1"; } - { users = [ "test6" ]; noPass = true; keepEnv = true; setEnv = [ "-STAPLE" ]; } - { users = [ "test7" ]; noPass = true; setEnv = [ "-SSH_AUTH_SOCK" ]; } - ]; + }; + users.users = { + test0 = { + isNormalUser = true; + extraGroups = [ "wheel" ]; + }; + test1 = { + isNormalUser = true; + }; + test2 = { + isNormalUser = true; + extraGroups = [ "foobar" ]; + }; + test3 = { + isNormalUser = true; + extraGroups = [ "barfoo" ]; + }; + test4 = { + isNormalUser = true; + extraGroups = [ "baz" ]; }; + test5 = { + isNormalUser = true; + }; + test6 = { + isNormalUser = true; + }; + test7 = { + isNormalUser = true; + }; + }; + + security.doas = { + enable = true; + wheelNeedsPassword = false; + + extraRules = [ + { + users = [ "test1" ]; + groups = [ "foobar" ]; + } + { + users = [ "test2" ]; + noPass = true; + setEnv = [ + "CORRECT" + "HORSE=BATTERY" + ]; + } + { + groups = [ + "barfoo" + 1337 + ]; + noPass = true; + } + { + users = [ "test5" ]; + noPass = true; + keepEnv = true; + runAs = "test1"; + } + { + users = [ "test6" ]; + noPass = true; + keepEnv = true; + setEnv = [ "-STAPLE" ]; + } + { + users = [ "test7" ]; + noPass = true; + setEnv = [ "-SSH_AUTH_SOCK" ]; + } + ]; }; + }; testScript = '' with subtest("users in wheel group should have passwordless doas"): diff --git a/nixos/tests/docker-registry.nix b/nixos/tests/docker-registry.nix index 4f033fc30b191f..aeb95a564c0e78 100644 --- a/nixos/tests/docker-registry.nix +++ b/nixos/tests/docker-registry.nix @@ -1,61 +1,74 @@ # This test runs docker-registry and check if it works -import ./make-test-python.nix ({ pkgs, ...} : { - name = "docker-registry"; - meta = with pkgs.lib.maintainers; { - maintainers = [ globin ironpinguin cafkafk ]; - }; - - nodes = { - registry = { ... }: { - services.dockerRegistry.enable = true; - services.dockerRegistry.enableDelete = true; - services.dockerRegistry.port = 8080; - services.dockerRegistry.listenAddress = "0.0.0.0"; - services.dockerRegistry.enableGarbageCollect = true; - services.dockerRegistry.openFirewall = true; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "docker-registry"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + globin + ironpinguin + cafkafk + ]; }; - client1 = { ... }: { - virtualisation.docker.enable = true; - virtualisation.docker.extraOptions = "--insecure-registry registry:8080"; - }; + nodes = { + registry = + { ... }: + { + services.dockerRegistry.enable = true; + services.dockerRegistry.enableDelete = true; + services.dockerRegistry.port = 8080; + services.dockerRegistry.listenAddress = "0.0.0.0"; + services.dockerRegistry.enableGarbageCollect = true; + services.dockerRegistry.openFirewall = true; + }; + + client1 = + { ... }: + { + virtualisation.docker.enable = true; + virtualisation.docker.extraOptions = "--insecure-registry registry:8080"; + }; - client2 = { ... }: { - virtualisation.docker.enable = true; - virtualisation.docker.extraOptions = "--insecure-registry registry:8080"; + client2 = + { ... }: + { + virtualisation.docker.enable = true; + virtualisation.docker.extraOptions = "--insecure-registry registry:8080"; + }; }; - }; - - testScript = '' - client1.start() - client1.wait_for_unit("docker.service") - client1.succeed("tar cv --files-from /dev/null | docker import - scratch") - client1.succeed("docker tag scratch registry:8080/scratch") - - registry.start() - registry.wait_for_unit("docker-registry.service") - registry.wait_for_open_port(8080) - client1.succeed("docker push registry:8080/scratch") - - client2.start() - client2.wait_for_unit("docker.service") - client2.succeed("docker pull registry:8080/scratch") - client2.succeed("docker images | grep scratch") - - client2.succeed( - "curl -fsS -X DELETE registry:8080/v2/scratch/manifests/$(curl -fsS -I -H\"Accept: application/vnd.docker.distribution.manifest.v2+json\" registry:8080/v2/scratch/manifests/latest | grep Docker-Content-Digest | sed -e 's/Docker-Content-Digest: //' | tr -d '\\r')" - ) - - registry.systemctl("start docker-registry-garbage-collect.service") - registry.wait_until_fails("systemctl status docker-registry-garbage-collect.service") - registry.wait_for_unit("docker-registry.service") - - registry.fail("ls -l /var/lib/docker-registry/docker/registry/v2/blobs/sha256/*/*/data") - - client1.succeed("docker push registry:8080/scratch") - registry.succeed( - "ls -l /var/lib/docker-registry/docker/registry/v2/blobs/sha256/*/*/data" - ) - ''; -}) + + testScript = '' + client1.start() + client1.wait_for_unit("docker.service") + client1.succeed("tar cv --files-from /dev/null | docker import - scratch") + client1.succeed("docker tag scratch registry:8080/scratch") + + registry.start() + registry.wait_for_unit("docker-registry.service") + registry.wait_for_open_port(8080) + client1.succeed("docker push registry:8080/scratch") + + client2.start() + client2.wait_for_unit("docker.service") + client2.succeed("docker pull registry:8080/scratch") + client2.succeed("docker images | grep scratch") + + client2.succeed( + "curl -fsS -X DELETE registry:8080/v2/scratch/manifests/$(curl -fsS -I -H\"Accept: application/vnd.docker.distribution.manifest.v2+json\" registry:8080/v2/scratch/manifests/latest | grep Docker-Content-Digest | sed -e 's/Docker-Content-Digest: //' | tr -d '\\r')" + ) + + registry.systemctl("start docker-registry-garbage-collect.service") + registry.wait_until_fails("systemctl status docker-registry-garbage-collect.service") + registry.wait_for_unit("docker-registry.service") + + registry.fail("ls -l /var/lib/docker-registry/docker/registry/v2/blobs/sha256/*/*/data") + + client1.succeed("docker push registry:8080/scratch") + registry.succeed( + "ls -l /var/lib/docker-registry/docker/registry/v2/blobs/sha256/*/*/data" + ) + ''; + } +) diff --git a/nixos/tests/docker-rootless.nix b/nixos/tests/docker-rootless.nix index e2a926eb3cb0ed..2a97ccb35f919c 100644 --- a/nixos/tests/docker-rootless.nix +++ b/nixos/tests/docker-rootless.nix @@ -1,41 +1,51 @@ # This test runs docker and checks if simple container starts -import ./make-test-python.nix ({ lib, pkgs, ...} : { - name = "docker-rootless"; - meta = with pkgs.lib.maintainers; { - maintainers = [ abbradar ]; - }; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "docker-rootless"; + meta = with pkgs.lib.maintainers; { + maintainers = [ abbradar ]; + }; - nodes = { - machine = { pkgs, ... }: { - virtualisation.docker.rootless.enable = true; + nodes = { + machine = + { pkgs, ... }: + { + virtualisation.docker.rootless.enable = true; - users.users.alice = { - uid = 1000; - isNormalUser = true; - }; + users.users.alice = { + uid = 1000; + isNormalUser = true; + }; + }; }; - }; - testScript = { nodes, ... }: - let - user = nodes.machine.config.users.users.alice; - sudo = lib.concatStringsSep " " [ - "XDG_RUNTIME_DIR=/run/user/${toString user.uid}" - "DOCKER_HOST=unix:///run/user/${toString user.uid}/docker.sock" - "sudo" "--preserve-env=XDG_RUNTIME_DIR,DOCKER_HOST" "-u" "alice" - ]; - in '' - machine.wait_for_unit("multi-user.target") + testScript = + { nodes, ... }: + let + user = nodes.machine.config.users.users.alice; + sudo = lib.concatStringsSep " " [ + "XDG_RUNTIME_DIR=/run/user/${toString user.uid}" + "DOCKER_HOST=unix:///run/user/${toString user.uid}/docker.sock" + "sudo" + "--preserve-env=XDG_RUNTIME_DIR,DOCKER_HOST" + "-u" + "alice" + ]; + in + '' + machine.wait_for_unit("multi-user.target") - machine.succeed("loginctl enable-linger alice") - machine.wait_until_succeeds("${sudo} systemctl --user is-active docker.service") + machine.succeed("loginctl enable-linger alice") + machine.wait_until_succeeds("${sudo} systemctl --user is-active docker.service") - machine.succeed("tar cv --files-from /dev/null | ${sudo} docker import - scratchimg") - machine.succeed( - "${sudo} docker run -d --name=sleeping -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10" - ) - machine.succeed("${sudo} docker ps | grep sleeping") - machine.succeed("${sudo} docker stop sleeping") - ''; -}) + machine.succeed("tar cv --files-from /dev/null | ${sudo} docker import - scratchimg") + machine.succeed( + "${sudo} docker run -d --name=sleeping -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10" + ) + machine.succeed("${sudo} docker ps | grep sleeping") + machine.succeed("${sudo} docker stop sleeping") + ''; + } +) diff --git a/nixos/tests/docker-tools-cross.nix b/nixos/tests/docker-tools-cross.nix index 14cb14ceeaea9e..e2508be134f0a4 100644 --- a/nixos/tests/docker-tools-cross.nix +++ b/nixos/tests/docker-tools-cross.nix @@ -2,79 +2,83 @@ # tests that _include_ running the result are separate. That way, most people # can run the majority of the test suite without the extra setup. +import ./make-test-python.nix ( + { pkgs, ... }: + let -import ./make-test-python.nix ({ pkgs, ... }: -let + remoteSystem = + if pkgs.stdenv.hostPlatform.system == "aarch64-linux" then "x86_64-linux" else "aarch64-linux"; - remoteSystem = - if pkgs.stdenv.hostPlatform.system == "aarch64-linux" - then "x86_64-linux" - else "aarch64-linux"; + remoteCrossPkgs = + import ../.. # nixpkgs + { + # NOTE: This is the machine that runs the build - local from the + # 'perspective' of the build script. + localSystem = remoteSystem; - remoteCrossPkgs = import ../.. /*nixpkgs*/ { - # NOTE: This is the machine that runs the build - local from the - # 'perspective' of the build script. - localSystem = remoteSystem; + # NOTE: Since this file can't control where the test will be _run_ we don't + # cross-compile _to_ a different system but _from_ a different system + crossSystem = pkgs.stdenv.hostPlatform.system; + }; - # NOTE: Since this file can't control where the test will be _run_ we don't - # cross-compile _to_ a different system but _from_ a different system - crossSystem = pkgs.stdenv.hostPlatform.system; - }; - - hello1 = remoteCrossPkgs.dockerTools.buildImage { - name = "hello1"; - tag = "latest"; - copyToRoot = remoteCrossPkgs.buildEnv { - name = "image-root"; - pathsToLink = [ "/bin" ]; - paths = [ remoteCrossPkgs.hello ]; + hello1 = remoteCrossPkgs.dockerTools.buildImage { + name = "hello1"; + tag = "latest"; + copyToRoot = remoteCrossPkgs.buildEnv { + name = "image-root"; + pathsToLink = [ "/bin" ]; + paths = [ remoteCrossPkgs.hello ]; + }; }; - }; - hello2 = remoteCrossPkgs.dockerTools.buildLayeredImage { - name = "hello2"; - tag = "latest"; - contents = remoteCrossPkgs.hello; - }; + hello2 = remoteCrossPkgs.dockerTools.buildLayeredImage { + name = "hello2"; + tag = "latest"; + contents = remoteCrossPkgs.hello; + }; -in { - name = "docker-tools"; - meta = with pkgs.lib.maintainers; { - maintainers = [ roberth ]; - }; + in + { + name = "docker-tools"; + meta = with pkgs.lib.maintainers; { + maintainers = [ roberth ]; + }; - nodes = { - docker = { ... }: { - virtualisation = { - diskSize = 2048; - docker.enable = true; - }; + nodes = { + docker = + { ... }: + { + virtualisation = { + diskSize = 2048; + docker.enable = true; + }; + }; }; - }; - testScript = '' - docker.wait_for_unit("sockets.target") + testScript = '' + docker.wait_for_unit("sockets.target") - with subtest("Ensure cross compiled buildImage image can run."): - docker.succeed( - "docker load --input='${hello1}'" - ) - assert "Hello, world!" in docker.succeed( - "docker run --rm ${hello1.imageName} hello", - ) - docker.succeed( - "docker rmi ${hello1.imageName}", - ) + with subtest("Ensure cross compiled buildImage image can run."): + docker.succeed( + "docker load --input='${hello1}'" + ) + assert "Hello, world!" in docker.succeed( + "docker run --rm ${hello1.imageName} hello", + ) + docker.succeed( + "docker rmi ${hello1.imageName}", + ) - with subtest("Ensure cross compiled buildLayeredImage image can run."): - docker.succeed( - "docker load --input='${hello2}'" - ) - assert "Hello, world!" in docker.succeed( - "docker run --rm ${hello2.imageName} hello", - ) - docker.succeed( - "docker rmi ${hello2.imageName}", - ) - ''; -}) + with subtest("Ensure cross compiled buildLayeredImage image can run."): + docker.succeed( + "docker load --input='${hello2}'" + ) + assert "Hello, world!" in docker.succeed( + "docker run --rm ${hello2.imageName} hello", + ) + docker.succeed( + "docker rmi ${hello2.imageName}", + ) + ''; + } +) diff --git a/nixos/tests/docker-tools-overlay.nix b/nixos/tests/docker-tools-overlay.nix index 14e33899affc14..a1de0272703fa4 100644 --- a/nixos/tests/docker-tools-overlay.nix +++ b/nixos/tests/docker-tools-overlay.nix @@ -1,22 +1,26 @@ # this test creates a simple GNU image with docker tools and sees if it executes -import ./make-test-python.nix ({ pkgs, ... }: -{ - name = "docker-tools-overlay"; - meta = with pkgs.lib.maintainers; { - maintainers = [ lnl7 roberth ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "docker-tools-overlay"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + lnl7 + roberth + ]; + }; - nodes = { - docker = - { ... }: - { - virtualisation.docker.enable = true; - virtualisation.docker.storageDriver = "overlay2"; - }; - }; + nodes = { + docker = + { ... }: + { + virtualisation.docker.enable = true; + virtualisation.docker.storageDriver = "overlay2"; + }; + }; - testScript = '' + testScript = '' docker.wait_for_unit("sockets.target") docker.succeed( @@ -30,4 +34,5 @@ import ./make-test-python.nix ({ pkgs, ... }: # drw------- 99 0 0 100 Apr 14 11:36 /nix/store docker.succeed("docker run --rm -u 1000:1000 ${pkgs.dockerTools.examples.bash.imageName} bash --version") ''; -}) + } +) diff --git a/nixos/tests/docker-tools.nix b/nixos/tests/docker-tools.nix index 41bd4a621545f3..28d34d137f7d71 100644 --- a/nixos/tests/docker-tools.nix +++ b/nixos/tests/docker-tools.nix @@ -1,54 +1,60 @@ # this test creates a simple GNU image with docker tools and sees if it executes -import ./make-test-python.nix ({ pkgs, ... }: -let - # nixpkgs#214434: dockerTools.buildImage fails to unpack base images - # containing duplicate layers when those duplicate tarballs - # appear under the manifest's 'Layers'. Docker can generate images - # like this even though dockerTools does not. - repeatedLayerTestImage = - let - # Rootfs diffs for layers 1 and 2 are identical (and empty) - layer1 = pkgs.dockerTools.buildImage { name = "empty"; }; - layer2 = layer1.overrideAttrs (_: { fromImage = layer1; }); - repeatedRootfsDiffs = pkgs.runCommand "image-with-links.tar" { - nativeBuildInputs = [pkgs.jq]; - } '' - mkdir contents - tar -xf "${layer2}" -C contents - cd contents - first_rootfs=$(jq -r '.[0].Layers[0]' manifest.json) - second_rootfs=$(jq -r '.[0].Layers[1]' manifest.json) - target_rootfs=$(sha256sum "$first_rootfs" | cut -d' ' -f 1).tar - - # Replace duplicated rootfs diffs with symlinks to one tarball - chmod -R ug+w . - mv "$first_rootfs" "$target_rootfs" - rm "$second_rootfs" - ln -s "../$target_rootfs" "$first_rootfs" - ln -s "../$target_rootfs" "$second_rootfs" - - # Update manifest's layers to use the symlinks' target - cat manifest.json | \ - jq ".[0].Layers[0] = \"$target_rootfs\"" | - jq ".[0].Layers[1] = \"$target_rootfs\"" > manifest.json.new - mv manifest.json.new manifest.json - - tar --sort=name --hard-dereference -cf $out . +import ./make-test-python.nix ( + { pkgs, ... }: + let + # nixpkgs#214434: dockerTools.buildImage fails to unpack base images + # containing duplicate layers when those duplicate tarballs + # appear under the manifest's 'Layers'. Docker can generate images + # like this even though dockerTools does not. + repeatedLayerTestImage = + let + # Rootfs diffs for layers 1 and 2 are identical (and empty) + layer1 = pkgs.dockerTools.buildImage { name = "empty"; }; + layer2 = layer1.overrideAttrs (_: { + fromImage = layer1; + }); + repeatedRootfsDiffs = + pkgs.runCommand "image-with-links.tar" + { + nativeBuildInputs = [ pkgs.jq ]; + } + '' + mkdir contents + tar -xf "${layer2}" -C contents + cd contents + first_rootfs=$(jq -r '.[0].Layers[0]' manifest.json) + second_rootfs=$(jq -r '.[0].Layers[1]' manifest.json) + target_rootfs=$(sha256sum "$first_rootfs" | cut -d' ' -f 1).tar + + # Replace duplicated rootfs diffs with symlinks to one tarball + chmod -R ug+w . + mv "$first_rootfs" "$target_rootfs" + rm "$second_rootfs" + ln -s "../$target_rootfs" "$first_rootfs" + ln -s "../$target_rootfs" "$second_rootfs" + + # Update manifest's layers to use the symlinks' target + cat manifest.json | \ + jq ".[0].Layers[0] = \"$target_rootfs\"" | + jq ".[0].Layers[1] = \"$target_rootfs\"" > manifest.json.new + mv manifest.json.new manifest.json + + tar --sort=name --hard-dereference -cf $out . + ''; + in + pkgs.dockerTools.buildImage { + fromImage = repeatedRootfsDiffs; + name = "repeated-layer-test"; + tag = "latest"; + copyToRoot = pkgs.bash; + # A runAsRoot script is required to force previous layers to be unpacked + runAsRoot = '' + echo 'runAsRoot has run.' ''; - in pkgs.dockerTools.buildImage { - fromImage = repeatedRootfsDiffs; - name = "repeated-layer-test"; - tag = "latest"; - copyToRoot = pkgs.bash; - # A runAsRoot script is required to force previous layers to be unpacked - runAsRoot = '' - echo 'runAsRoot has run.' - ''; - }; + }; - chownTestImage = - pkgs.dockerTools.streamLayeredImage { + chownTestImage = pkgs.dockerTools.streamLayeredImage { name = "chown-test"; tag = "latest"; enableFakechroot = true; @@ -56,11 +62,15 @@ let touch /testfile chown 12345:12345 /testfile ''; - config.Cmd = [ "${pkgs.coreutils}/bin/stat" "-c" "%u:%g" "/testfile" ]; + config.Cmd = [ + "${pkgs.coreutils}/bin/stat" + "-c" + "%u:%g" + "/testfile" + ]; }; - nonRootTestImage = - pkgs.dockerTools.streamLayeredImage { + nonRootTestImage = pkgs.dockerTools.streamLayeredImage { name = "non-root-test"; tag = "latest"; uid = 1000; @@ -69,514 +79,526 @@ let gname = "user"; config = { User = "user"; - Cmd = [ "${pkgs.coreutils}/bin/stat" "-c" "%u:%g" "${pkgs.coreutils}/bin/stat" ]; + Cmd = [ + "${pkgs.coreutils}/bin/stat" + "-c" + "%u:%g" + "${pkgs.coreutils}/bin/stat" + ]; }; }; -in { - name = "docker-tools"; - meta = with pkgs.lib.maintainers; { - maintainers = [ lnl7 roberth ]; - }; - - nodes = { - docker = { ... }: { - virtualisation = { - diskSize = 3072; - docker.enable = true; - }; + in + { + name = "docker-tools"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + lnl7 + roberth + ]; + }; + + nodes = { + docker = + { ... }: + { + virtualisation = { + diskSize = 3072; + docker.enable = true; + }; + }; }; - }; - - testScript = with pkgs.dockerTools; '' - unix_time_second1 = "1970-01-01T00:00:01Z" - - docker.wait_for_unit("sockets.target") - - with subtest("includeStorePath"): - with subtest("assumption"): - docker.succeed("${examples.helloOnRoot} | docker load") - docker.succeed("docker run --rm hello | grep -i hello") - docker.succeed("docker image rm hello:latest") - - with subtest("includeStorePath = false; breaks example"): - docker.succeed("${examples.helloOnRootNoStore} | docker load") - docker.fail("docker run --rm hello | grep -i hello") - docker.succeed("docker image rm hello:latest") - with subtest("includeStorePath = false; breaks example (fakechroot)"): - docker.succeed("${examples.helloOnRootNoStoreFakechroot} | docker load") - docker.fail("docker run --rm hello | grep -i hello") - docker.succeed("docker image rm hello:latest") - - with subtest("Ensure ZERO paths are added to the store"): - docker.fail("${examples.helloOnRootNoStore} | ${pkgs.crane}/bin/crane export - - | tar t | grep 'nix/store/'") - with subtest("Ensure ZERO paths are added to the store (fakechroot)"): - docker.fail("${examples.helloOnRootNoStoreFakechroot} | ${pkgs.crane}/bin/crane export - - | tar t | grep 'nix/store/'") - - with subtest("includeStorePath = false; works with mounted store"): - docker.succeed("${examples.helloOnRootNoStore} | docker load") - docker.succeed("docker run --rm --volume ${builtins.storeDir}:${builtins.storeDir}:ro hello | grep -i hello") - docker.succeed("docker image rm hello:latest") - with subtest("includeStorePath = false; works with mounted store (fakechroot)"): - docker.succeed("${examples.helloOnRootNoStoreFakechroot} | docker load") - docker.succeed("docker run --rm --volume ${builtins.storeDir}:${builtins.storeDir}:ro hello | grep -i hello") - docker.succeed("docker image rm hello:latest") - - with subtest("Ensure Docker images use a stable date by default"): - docker.succeed( - "docker load --input='${examples.bash}'" - ) - assert unix_time_second1 in docker.succeed( - "docker inspect ${examples.bash.imageName} " - + "| ${pkgs.jq}/bin/jq -r .[].Created", - ) - - docker.succeed("docker run --rm ${examples.bash.imageName} bash --version") - # Check imageTag attribute matches image - docker.succeed("docker images --format '{{.Tag}}' | grep -F '${examples.bash.imageTag}'") - docker.succeed("docker rmi ${examples.bash.imageName}") - - # The remaining combinations - with subtest("Ensure imageTag attribute matches image"): - docker.succeed( - "docker load --input='${examples.bashNoTag}'" - ) - docker.succeed( - "docker images --format '{{.Tag}}' | grep -F '${examples.bashNoTag.imageTag}'" - ) - docker.succeed("docker rmi ${examples.bashNoTag.imageName}:${examples.bashNoTag.imageTag}") - - docker.succeed( - "docker load --input='${examples.bashNoTagLayered}'" - ) - docker.succeed( - "docker images --format '{{.Tag}}' | grep -F '${examples.bashNoTagLayered.imageTag}'" - ) - docker.succeed("docker rmi ${examples.bashNoTagLayered.imageName}:${examples.bashNoTagLayered.imageTag}") - - docker.succeed( - "${examples.bashNoTagStreamLayered} | docker load" - ) - docker.succeed( - "docker images --format '{{.Tag}}' | grep -F '${examples.bashNoTagStreamLayered.imageTag}'" - ) - docker.succeed( - "docker rmi ${examples.bashNoTagStreamLayered.imageName}:${examples.bashNoTagStreamLayered.imageTag}" - ) - - docker.succeed( - "docker load --input='${examples.nixLayered}'" - ) - docker.succeed("docker images --format '{{.Tag}}' | grep -F '${examples.nixLayered.imageTag}'") - docker.succeed("docker rmi ${examples.nixLayered.imageName}") - - with subtest("Check that images with alternative compression schemas load"): - docker.succeed( - "docker load --input='${examples.bashZstdCompressed}'", - "docker rmi ${examples.bashZstdCompressed.imageName}", - ) - docker.succeed( - "docker load --input='${examples.bashUncompressed}'", - "docker rmi ${examples.bashUncompressed.imageName}", - ) - docker.succeed( - "docker load --input='${examples.bashLayeredUncompressed}'", - "docker rmi ${examples.bashLayeredUncompressed.imageName}", - ) - docker.succeed( - "docker load --input='${examples.bashLayeredZstdCompressed}'", - "docker rmi ${examples.bashLayeredZstdCompressed.imageName}", - ) - - with subtest( - "Check if the nix store is correctly initialized by listing " - "dependencies of the installed Nix binary" - ): - docker.succeed( - "docker load --input='${examples.nix}'", - "docker run --rm ${examples.nix.imageName} nix-store -qR ${pkgs.nix}", - "docker rmi ${examples.nix.imageName}", - ) - - with subtest( - "Ensure (layered) nix store has correct permissions " - "and that the container starts when its process does not have uid 0" - ): - docker.succeed( - "docker load --input='${examples.bashLayeredWithUser}'", - "docker run -u somebody --rm ${examples.bashLayeredWithUser.imageName} ${pkgs.bash}/bin/bash -c 'test 755 == $(stat --format=%a /nix) && test 755 == $(stat --format=%a /nix/store)'", - "docker rmi ${examples.bashLayeredWithUser.imageName}", - ) - - with subtest("The nix binary symlinks are intact"): - docker.succeed( - "docker load --input='${examples.nix}'", - "docker run --rm ${examples.nix.imageName} ${pkgs.bash}/bin/bash -c 'test nix == $(readlink ${pkgs.nix}/bin/nix-daemon)'", - "docker rmi ${examples.nix.imageName}", - ) - - with subtest("The nix binary symlinks are intact when the image is layered"): - docker.succeed( - "docker load --input='${examples.nixLayered}'", - "docker run --rm ${examples.nixLayered.imageName} ${pkgs.bash}/bin/bash -c 'test nix == $(readlink ${pkgs.nix}/bin/nix-daemon)'", - "docker rmi ${examples.nixLayered.imageName}", - ) - - with subtest("The pullImage tool works"): - docker.succeed( - "docker load --input='${examples.testNixFromDockerHub}'", - "docker run --rm nix:2.2.1 nix-store --version", - "docker rmi nix:2.2.1", - ) - - with subtest("runAsRoot and entry point work"): - docker.succeed( - "docker load --input='${examples.nginx}'", - "docker run --name nginx -d -p 8000:80 ${examples.nginx.imageName}", - ) - docker.wait_until_succeeds("curl -f http://localhost:8000/") - docker.succeed( - "docker rm --force nginx", - "docker rmi '${examples.nginx.imageName}'", - ) - - with subtest("A pulled image can be used as base image"): - docker.succeed( - "docker load --input='${examples.onTopOfPulledImage}'", - "docker run --rm ontopofpulledimage hello", - "docker rmi ontopofpulledimage", - ) - - with subtest("Regression test for issue #34779"): - docker.succeed( - "docker load --input='${examples.runAsRootExtraCommands}'", - "docker run --rm runasrootextracommands cat extraCommands", - "docker run --rm runasrootextracommands cat runAsRoot", - "docker rmi '${examples.runAsRootExtraCommands.imageName}'", - ) - - with subtest("Ensure Docker images can use an unstable date"): - docker.succeed( - "docker load --input='${examples.unstableDate}'" - ) - assert unix_time_second1 not in docker.succeed( - "docker inspect ${examples.unstableDate.imageName} " - + "| ${pkgs.jq}/bin/jq -r .[].Created" - ) - - with subtest("Ensure Layered Docker images can use an unstable date"): - docker.succeed( - "docker load --input='${examples.unstableDateLayered}'" - ) - assert unix_time_second1 not in docker.succeed( - "docker inspect ${examples.unstableDateLayered.imageName} " - + "| ${pkgs.jq}/bin/jq -r .[].Created" - ) - - with subtest("Ensure Layered Docker images work"): - docker.succeed( - "docker load --input='${examples.layered-image}'", - "docker run --rm ${examples.layered-image.imageName}", - "docker run --rm ${examples.layered-image.imageName} cat extraCommands", - ) - - with subtest("Ensure images built on top of layered Docker images work"): - docker.succeed( - "docker load --input='${examples.layered-on-top}'", - "docker run --rm ${examples.layered-on-top.imageName}", - ) - - with subtest("Ensure layered images built on top of layered Docker images work"): - docker.succeed( - "docker load --input='${examples.layered-on-top-layered}'", - "docker run --rm ${examples.layered-on-top-layered.imageName}", - ) - - - def set_of_layers(image_name): - return set( - docker.succeed( - f"docker inspect {image_name} " - + "| ${pkgs.jq}/bin/jq -r '.[] | .RootFS.Layers | .[]'" - ).split() - ) - - - with subtest("Ensure layers are shared between images"): - docker.succeed( - "docker load --input='${examples.another-layered-image}'" - ) - layers1 = set_of_layers("${examples.layered-image.imageName}") - layers2 = set_of_layers("${examples.another-layered-image.imageName}") - assert bool(layers1 & layers2) - - with subtest("Ensure order of layers is correct"): - docker.succeed( - "docker load --input='${examples.layersOrder}'" - ) - - for index in 1, 2, 3: - assert f"layer{index}" in docker.succeed( - f"docker run --rm ${examples.layersOrder.imageName} cat /tmp/layer{index}" - ) - - with subtest("Ensure layers unpacked in correct order before runAsRoot runs"): - assert "abc" in docker.succeed( - "docker load --input='${examples.layersUnpackOrder}'", - "docker run --rm ${examples.layersUnpackOrder.imageName} cat /layer-order" - ) - - with subtest("Ensure repeated base layers handled by buildImage"): - docker.succeed( - "docker load --input='${repeatedLayerTestImage}'", - "docker run --rm ${repeatedLayerTestImage.imageName} /bin/bash -c 'exit 0'" - ) - - with subtest("Ensure environment variables are correctly inherited"): - docker.succeed( - "docker load --input='${examples.environmentVariables}'" - ) - out = docker.succeed("docker run --rm ${examples.environmentVariables.imageName} env") - env = out.splitlines() - assert "FROM_PARENT=true" in env, "envvars from the parent should be preserved" - assert "FROM_CHILD=true" in env, "envvars from the child should be preserved" - assert "LAST_LAYER=child" in env, "envvars from the child should take priority" - - with subtest("Ensure environment variables of layered images are correctly inherited"): - docker.succeed( - "docker load --input='${examples.environmentVariablesLayered}'" - ) - out = docker.succeed("docker run --rm ${examples.environmentVariablesLayered.imageName} env") - env = out.splitlines() - assert "FROM_PARENT=true" in env, "envvars from the parent should be preserved" - assert "FROM_CHILD=true" in env, "envvars from the child should be preserved" - assert "LAST_LAYER=child" in env, "envvars from the child should take priority" - - with subtest( - "Ensure inherited environment variables of layered images are correctly resolved" - ): - # Read environment variables as stored in image config - config = docker.succeed( - "tar -xOf ${examples.environmentVariablesLayered} manifest.json | ${pkgs.jq}/bin/jq -r .[].Config" - ).strip() - out = docker.succeed( - f"tar -xOf ${examples.environmentVariablesLayered} {config} | ${pkgs.jq}/bin/jq -r '.config.Env | .[]'" - ) - env = out.splitlines() - assert ( - sum(entry.startswith("LAST_LAYER") for entry in env) == 1 - ), "envvars overridden by child should be unique" - - with subtest("Ensure image with only 2 layers can be loaded"): - docker.succeed( - "docker load --input='${examples.two-layered-image}'" - ) - - with subtest( - "Ensure the bulk layer doesn't miss store paths (regression test for #78744)" - ): - docker.succeed( - "docker load --input='${pkgs.dockerTools.examples.bulk-layer}'", - # Ensure the two output paths (ls and hello) are in the layer - "docker run bulk-layer ls /bin/hello", - ) - - with subtest( - "Ensure the bulk layer with a base image respects the number of maxLayers" - ): - docker.succeed( - "docker load --input='${pkgs.dockerTools.examples.layered-bulk-layer}'", - # Ensure the image runs correctly - "docker run layered-bulk-layer ls /bin/hello", - ) - - # Ensure the image has the correct number of layers - assert len(set_of_layers("layered-bulk-layer")) == 4 - - with subtest("Ensure only minimal paths are added to the store"): - # TODO: make an example that has no store paths, for example by making - # busybox non-self-referential. - - # This check tests that buildLayeredImage can build images that don't need a store. - docker.succeed( - "docker load --input='${pkgs.dockerTools.examples.no-store-paths}'" - ) - - docker.succeed("docker run --rm no-store-paths ls / >/dev/console") - - # If busybox isn't self-referential, we need this line - # docker.fail("docker run --rm no-store-paths ls /nix/store >/dev/console") - # However, it currently is self-referential, so we check that it is the - # only store path. - docker.succeed("diff <(docker run --rm no-store-paths ls /nix/store) <(basename ${pkgs.pkgsStatic.busybox}) >/dev/console") - - with subtest("Ensure buildLayeredImage does not change store path contents."): - docker.succeed( - "docker load --input='${pkgs.dockerTools.examples.filesInStore}'", - "docker run --rm file-in-store nix-store --verify --check-contents", - "docker run --rm file-in-store |& grep 'some data'", - ) - - with subtest("Ensure cross compiled image can be loaded and has correct arch."): - docker.succeed( - "docker load --input='${pkgs.dockerTools.examples.cross}'", - ) - assert ( - docker.succeed( - "docker inspect ${pkgs.dockerTools.examples.cross.imageName} " - + "| ${pkgs.jq}/bin/jq -r .[].Architecture" - ).strip() - == "${if pkgs.stdenv.hostPlatform.system == "aarch64-linux" then "amd64" else "arm64"}" - ) - - with subtest("buildLayeredImage doesn't dereference /nix/store symlink layers"): - docker.succeed( - "docker load --input='${examples.layeredStoreSymlink}'", - "docker run --rm ${examples.layeredStoreSymlink.imageName} bash -c 'test -L ${examples.layeredStoreSymlink.passthru.symlink}'", - "docker rmi ${examples.layeredStoreSymlink.imageName}", - ) - - with subtest("buildImage supports registry/ prefix in image name"): - docker.succeed( - "docker load --input='${examples.prefixedImage}'" - ) - docker.succeed( - "docker images --format '{{.Repository}}' | grep -F '${examples.prefixedImage.imageName}'" - ) - - with subtest("buildLayeredImage supports registry/ prefix in image name"): - docker.succeed( - "docker load --input='${examples.prefixedLayeredImage}'" - ) - docker.succeed( - "docker images --format '{{.Repository}}' | grep -F '${examples.prefixedLayeredImage.imageName}'" - ) - - with subtest("buildLayeredImage supports running chown with fakeRootCommands"): - docker.succeed( - "docker load --input='${examples.layeredImageWithFakeRootCommands}'" - ) - docker.succeed( - "docker run --rm ${examples.layeredImageWithFakeRootCommands.imageName} sh -c 'stat -c '%u' /home/alice | grep -E ^1000$'" - ) - - with subtest("Ensure docker load on merged images loads all of the constituent images"): - docker.succeed( - "docker load --input='${examples.mergedBashAndRedis}'" - ) - docker.succeed( - "docker images --format '{{.Repository}}-{{.Tag}}' | grep -F '${examples.bash.imageName}-${examples.bash.imageTag}'" - ) - docker.succeed( - "docker images --format '{{.Repository}}-{{.Tag}}' | grep -F '${examples.redis.imageName}-${examples.redis.imageTag}'" - ) - docker.succeed("docker run --rm ${examples.bash.imageName} bash --version") - docker.succeed("docker run --rm ${examples.redis.imageName} redis-cli --version") - docker.succeed("docker rmi ${examples.bash.imageName}") - docker.succeed("docker rmi ${examples.redis.imageName}") - - with subtest( - "Ensure docker load on merged images loads all of the constituent images (missing tags)" - ): - docker.succeed( - "docker load --input='${examples.mergedBashNoTagAndRedis}'" - ) - docker.succeed( - "docker images --format '{{.Repository}}-{{.Tag}}' | grep -F '${examples.bashNoTag.imageName}-${examples.bashNoTag.imageTag}'" - ) - docker.succeed( - "docker images --format '{{.Repository}}-{{.Tag}}' | grep -F '${examples.redis.imageName}-${examples.redis.imageTag}'" - ) - # we need to explicitly specify the generated tag here - docker.succeed( - "docker run --rm ${examples.bashNoTag.imageName}:${examples.bashNoTag.imageTag} bash --version" - ) - docker.succeed("docker run --rm ${examples.redis.imageName} redis-cli --version") - docker.succeed("docker rmi ${examples.bashNoTag.imageName}:${examples.bashNoTag.imageTag}") - docker.succeed("docker rmi ${examples.redis.imageName}") - - with subtest("mergeImages preserves owners of the original images"): - docker.succeed( - "docker load --input='${examples.mergedBashFakeRoot}'" - ) - docker.succeed( - "docker run --rm ${examples.layeredImageWithFakeRootCommands.imageName} sh -c 'stat -c '%u' /home/alice | grep -E ^1000$'" - ) - - with subtest("The image contains store paths referenced by the fakeRootCommands output"): - docker.succeed( - "docker run --rm ${examples.layeredImageWithFakeRootCommands.imageName} /hello/bin/layeredImageWithFakeRootCommands-hello" - ) - - with subtest("mergeImage correctly deals with varying compression schemas in inputs"): - docker.succeed("docker load --input='${examples.mergeVaryingCompressor}'") - - for sub_image, tag in [ - ("${examples.redis.imageName}", "${examples.redis.imageTag}"), - ("${examples.bashUncompressed.imageName}", "${examples.bashUncompressed.imageTag}"), - ("${examples.bashZstdCompressed.imageName}", "${examples.bashZstdCompressed.imageTag}"), - ]: - docker.succeed(f"docker images --format '{{{{.Repository}}}}-{{{{.Tag}}}}' | grep -F '{sub_image}-{tag}'") - docker.succeed(f"docker rmi {sub_image}") - - - with subtest("exportImage produces a valid tarball"): - docker.succeed( - "tar -tf ${examples.exportBash} | grep '\./bin/bash' > /dev/null" - ) - - with subtest("layered image fakeRootCommands with fakechroot works"): - docker.succeed("${examples.imageViaFakeChroot} | docker load") - docker.succeed("docker run --rm image-via-fake-chroot | grep -i hello") - docker.succeed("docker image rm image-via-fake-chroot:latest") - - with subtest("Ensure bare paths in contents are loaded correctly"): - docker.succeed( - "docker load --input='${examples.build-image-with-path}'", - "docker run --rm build-image-with-path bash -c '[[ -e /hello.txt ]]'", - "docker rmi build-image-with-path", - ) - docker.succeed( - "${examples.layered-image-with-path} | docker load", - "docker run --rm layered-image-with-path bash -c '[[ -e /hello.txt ]]'", - "docker rmi layered-image-with-path", - ) - - with subtest("Ensure correct architecture is present in manifests."): - docker.succeed(""" - docker load --input='${examples.build-image-with-architecture}' - docker inspect build-image-with-architecture \ - | ${pkgs.jq}/bin/jq -er '.[] | select(.Architecture=="arm64").Architecture' - docker rmi build-image-with-architecture - """) - docker.succeed(""" - ${examples.layered-image-with-architecture} | docker load - docker inspect layered-image-with-architecture \ - | ${pkgs.jq}/bin/jq -er '.[] | select(.Architecture=="arm64").Architecture' - docker rmi layered-image-with-architecture - """) - - with subtest("etc"): - docker.succeed("${examples.etc} | docker load") - docker.succeed("docker run --rm etc | grep localhost") - docker.succeed("docker image rm etc:latest") - - with subtest("image-with-certs"): - docker.succeed("<${examples.image-with-certs} docker load") - docker.succeed("docker run --rm image-with-certs:latest test -r /etc/ssl/certs/ca-bundle.crt") - docker.succeed("docker run --rm image-with-certs:latest test -r /etc/ssl/certs/ca-certificates.crt") - docker.succeed("docker run --rm image-with-certs:latest test -r /etc/pki/tls/certs/ca-bundle.crt") - docker.succeed("docker image rm image-with-certs:latest") - - with subtest("streamLayeredImage: chown is persistent in fakeRootCommands"): - docker.succeed( - "${chownTestImage} | docker load", - "docker run --rm ${chownTestImage.imageName} | diff /dev/stdin <(echo 12345:12345)" - ) - - with subtest("streamLayeredImage: with non-root user"): - docker.succeed( - "${nonRootTestImage} | docker load", - "docker run --rm ${chownTestImage.imageName} | diff /dev/stdin <(echo 12345:12345)" - ) - ''; -}) + + testScript = with pkgs.dockerTools; '' + unix_time_second1 = "1970-01-01T00:00:01Z" + + docker.wait_for_unit("sockets.target") + + with subtest("includeStorePath"): + with subtest("assumption"): + docker.succeed("${examples.helloOnRoot} | docker load") + docker.succeed("docker run --rm hello | grep -i hello") + docker.succeed("docker image rm hello:latest") + + with subtest("includeStorePath = false; breaks example"): + docker.succeed("${examples.helloOnRootNoStore} | docker load") + docker.fail("docker run --rm hello | grep -i hello") + docker.succeed("docker image rm hello:latest") + with subtest("includeStorePath = false; breaks example (fakechroot)"): + docker.succeed("${examples.helloOnRootNoStoreFakechroot} | docker load") + docker.fail("docker run --rm hello | grep -i hello") + docker.succeed("docker image rm hello:latest") + + with subtest("Ensure ZERO paths are added to the store"): + docker.fail("${examples.helloOnRootNoStore} | ${pkgs.crane}/bin/crane export - - | tar t | grep 'nix/store/'") + with subtest("Ensure ZERO paths are added to the store (fakechroot)"): + docker.fail("${examples.helloOnRootNoStoreFakechroot} | ${pkgs.crane}/bin/crane export - - | tar t | grep 'nix/store/'") + + with subtest("includeStorePath = false; works with mounted store"): + docker.succeed("${examples.helloOnRootNoStore} | docker load") + docker.succeed("docker run --rm --volume ${builtins.storeDir}:${builtins.storeDir}:ro hello | grep -i hello") + docker.succeed("docker image rm hello:latest") + with subtest("includeStorePath = false; works with mounted store (fakechroot)"): + docker.succeed("${examples.helloOnRootNoStoreFakechroot} | docker load") + docker.succeed("docker run --rm --volume ${builtins.storeDir}:${builtins.storeDir}:ro hello | grep -i hello") + docker.succeed("docker image rm hello:latest") + + with subtest("Ensure Docker images use a stable date by default"): + docker.succeed( + "docker load --input='${examples.bash}'" + ) + assert unix_time_second1 in docker.succeed( + "docker inspect ${examples.bash.imageName} " + + "| ${pkgs.jq}/bin/jq -r .[].Created", + ) + + docker.succeed("docker run --rm ${examples.bash.imageName} bash --version") + # Check imageTag attribute matches image + docker.succeed("docker images --format '{{.Tag}}' | grep -F '${examples.bash.imageTag}'") + docker.succeed("docker rmi ${examples.bash.imageName}") + + # The remaining combinations + with subtest("Ensure imageTag attribute matches image"): + docker.succeed( + "docker load --input='${examples.bashNoTag}'" + ) + docker.succeed( + "docker images --format '{{.Tag}}' | grep -F '${examples.bashNoTag.imageTag}'" + ) + docker.succeed("docker rmi ${examples.bashNoTag.imageName}:${examples.bashNoTag.imageTag}") + + docker.succeed( + "docker load --input='${examples.bashNoTagLayered}'" + ) + docker.succeed( + "docker images --format '{{.Tag}}' | grep -F '${examples.bashNoTagLayered.imageTag}'" + ) + docker.succeed("docker rmi ${examples.bashNoTagLayered.imageName}:${examples.bashNoTagLayered.imageTag}") + + docker.succeed( + "${examples.bashNoTagStreamLayered} | docker load" + ) + docker.succeed( + "docker images --format '{{.Tag}}' | grep -F '${examples.bashNoTagStreamLayered.imageTag}'" + ) + docker.succeed( + "docker rmi ${examples.bashNoTagStreamLayered.imageName}:${examples.bashNoTagStreamLayered.imageTag}" + ) + + docker.succeed( + "docker load --input='${examples.nixLayered}'" + ) + docker.succeed("docker images --format '{{.Tag}}' | grep -F '${examples.nixLayered.imageTag}'") + docker.succeed("docker rmi ${examples.nixLayered.imageName}") + + with subtest("Check that images with alternative compression schemas load"): + docker.succeed( + "docker load --input='${examples.bashZstdCompressed}'", + "docker rmi ${examples.bashZstdCompressed.imageName}", + ) + docker.succeed( + "docker load --input='${examples.bashUncompressed}'", + "docker rmi ${examples.bashUncompressed.imageName}", + ) + docker.succeed( + "docker load --input='${examples.bashLayeredUncompressed}'", + "docker rmi ${examples.bashLayeredUncompressed.imageName}", + ) + docker.succeed( + "docker load --input='${examples.bashLayeredZstdCompressed}'", + "docker rmi ${examples.bashLayeredZstdCompressed.imageName}", + ) + + with subtest( + "Check if the nix store is correctly initialized by listing " + "dependencies of the installed Nix binary" + ): + docker.succeed( + "docker load --input='${examples.nix}'", + "docker run --rm ${examples.nix.imageName} nix-store -qR ${pkgs.nix}", + "docker rmi ${examples.nix.imageName}", + ) + + with subtest( + "Ensure (layered) nix store has correct permissions " + "and that the container starts when its process does not have uid 0" + ): + docker.succeed( + "docker load --input='${examples.bashLayeredWithUser}'", + "docker run -u somebody --rm ${examples.bashLayeredWithUser.imageName} ${pkgs.bash}/bin/bash -c 'test 755 == $(stat --format=%a /nix) && test 755 == $(stat --format=%a /nix/store)'", + "docker rmi ${examples.bashLayeredWithUser.imageName}", + ) + + with subtest("The nix binary symlinks are intact"): + docker.succeed( + "docker load --input='${examples.nix}'", + "docker run --rm ${examples.nix.imageName} ${pkgs.bash}/bin/bash -c 'test nix == $(readlink ${pkgs.nix}/bin/nix-daemon)'", + "docker rmi ${examples.nix.imageName}", + ) + + with subtest("The nix binary symlinks are intact when the image is layered"): + docker.succeed( + "docker load --input='${examples.nixLayered}'", + "docker run --rm ${examples.nixLayered.imageName} ${pkgs.bash}/bin/bash -c 'test nix == $(readlink ${pkgs.nix}/bin/nix-daemon)'", + "docker rmi ${examples.nixLayered.imageName}", + ) + + with subtest("The pullImage tool works"): + docker.succeed( + "docker load --input='${examples.testNixFromDockerHub}'", + "docker run --rm nix:2.2.1 nix-store --version", + "docker rmi nix:2.2.1", + ) + + with subtest("runAsRoot and entry point work"): + docker.succeed( + "docker load --input='${examples.nginx}'", + "docker run --name nginx -d -p 8000:80 ${examples.nginx.imageName}", + ) + docker.wait_until_succeeds("curl -f http://localhost:8000/") + docker.succeed( + "docker rm --force nginx", + "docker rmi '${examples.nginx.imageName}'", + ) + + with subtest("A pulled image can be used as base image"): + docker.succeed( + "docker load --input='${examples.onTopOfPulledImage}'", + "docker run --rm ontopofpulledimage hello", + "docker rmi ontopofpulledimage", + ) + + with subtest("Regression test for issue #34779"): + docker.succeed( + "docker load --input='${examples.runAsRootExtraCommands}'", + "docker run --rm runasrootextracommands cat extraCommands", + "docker run --rm runasrootextracommands cat runAsRoot", + "docker rmi '${examples.runAsRootExtraCommands.imageName}'", + ) + + with subtest("Ensure Docker images can use an unstable date"): + docker.succeed( + "docker load --input='${examples.unstableDate}'" + ) + assert unix_time_second1 not in docker.succeed( + "docker inspect ${examples.unstableDate.imageName} " + + "| ${pkgs.jq}/bin/jq -r .[].Created" + ) + + with subtest("Ensure Layered Docker images can use an unstable date"): + docker.succeed( + "docker load --input='${examples.unstableDateLayered}'" + ) + assert unix_time_second1 not in docker.succeed( + "docker inspect ${examples.unstableDateLayered.imageName} " + + "| ${pkgs.jq}/bin/jq -r .[].Created" + ) + + with subtest("Ensure Layered Docker images work"): + docker.succeed( + "docker load --input='${examples.layered-image}'", + "docker run --rm ${examples.layered-image.imageName}", + "docker run --rm ${examples.layered-image.imageName} cat extraCommands", + ) + + with subtest("Ensure images built on top of layered Docker images work"): + docker.succeed( + "docker load --input='${examples.layered-on-top}'", + "docker run --rm ${examples.layered-on-top.imageName}", + ) + + with subtest("Ensure layered images built on top of layered Docker images work"): + docker.succeed( + "docker load --input='${examples.layered-on-top-layered}'", + "docker run --rm ${examples.layered-on-top-layered.imageName}", + ) + + + def set_of_layers(image_name): + return set( + docker.succeed( + f"docker inspect {image_name} " + + "| ${pkgs.jq}/bin/jq -r '.[] | .RootFS.Layers | .[]'" + ).split() + ) + + + with subtest("Ensure layers are shared between images"): + docker.succeed( + "docker load --input='${examples.another-layered-image}'" + ) + layers1 = set_of_layers("${examples.layered-image.imageName}") + layers2 = set_of_layers("${examples.another-layered-image.imageName}") + assert bool(layers1 & layers2) + + with subtest("Ensure order of layers is correct"): + docker.succeed( + "docker load --input='${examples.layersOrder}'" + ) + + for index in 1, 2, 3: + assert f"layer{index}" in docker.succeed( + f"docker run --rm ${examples.layersOrder.imageName} cat /tmp/layer{index}" + ) + + with subtest("Ensure layers unpacked in correct order before runAsRoot runs"): + assert "abc" in docker.succeed( + "docker load --input='${examples.layersUnpackOrder}'", + "docker run --rm ${examples.layersUnpackOrder.imageName} cat /layer-order" + ) + + with subtest("Ensure repeated base layers handled by buildImage"): + docker.succeed( + "docker load --input='${repeatedLayerTestImage}'", + "docker run --rm ${repeatedLayerTestImage.imageName} /bin/bash -c 'exit 0'" + ) + + with subtest("Ensure environment variables are correctly inherited"): + docker.succeed( + "docker load --input='${examples.environmentVariables}'" + ) + out = docker.succeed("docker run --rm ${examples.environmentVariables.imageName} env") + env = out.splitlines() + assert "FROM_PARENT=true" in env, "envvars from the parent should be preserved" + assert "FROM_CHILD=true" in env, "envvars from the child should be preserved" + assert "LAST_LAYER=child" in env, "envvars from the child should take priority" + + with subtest("Ensure environment variables of layered images are correctly inherited"): + docker.succeed( + "docker load --input='${examples.environmentVariablesLayered}'" + ) + out = docker.succeed("docker run --rm ${examples.environmentVariablesLayered.imageName} env") + env = out.splitlines() + assert "FROM_PARENT=true" in env, "envvars from the parent should be preserved" + assert "FROM_CHILD=true" in env, "envvars from the child should be preserved" + assert "LAST_LAYER=child" in env, "envvars from the child should take priority" + + with subtest( + "Ensure inherited environment variables of layered images are correctly resolved" + ): + # Read environment variables as stored in image config + config = docker.succeed( + "tar -xOf ${examples.environmentVariablesLayered} manifest.json | ${pkgs.jq}/bin/jq -r .[].Config" + ).strip() + out = docker.succeed( + f"tar -xOf ${examples.environmentVariablesLayered} {config} | ${pkgs.jq}/bin/jq -r '.config.Env | .[]'" + ) + env = out.splitlines() + assert ( + sum(entry.startswith("LAST_LAYER") for entry in env) == 1 + ), "envvars overridden by child should be unique" + + with subtest("Ensure image with only 2 layers can be loaded"): + docker.succeed( + "docker load --input='${examples.two-layered-image}'" + ) + + with subtest( + "Ensure the bulk layer doesn't miss store paths (regression test for #78744)" + ): + docker.succeed( + "docker load --input='${pkgs.dockerTools.examples.bulk-layer}'", + # Ensure the two output paths (ls and hello) are in the layer + "docker run bulk-layer ls /bin/hello", + ) + + with subtest( + "Ensure the bulk layer with a base image respects the number of maxLayers" + ): + docker.succeed( + "docker load --input='${pkgs.dockerTools.examples.layered-bulk-layer}'", + # Ensure the image runs correctly + "docker run layered-bulk-layer ls /bin/hello", + ) + + # Ensure the image has the correct number of layers + assert len(set_of_layers("layered-bulk-layer")) == 4 + + with subtest("Ensure only minimal paths are added to the store"): + # TODO: make an example that has no store paths, for example by making + # busybox non-self-referential. + + # This check tests that buildLayeredImage can build images that don't need a store. + docker.succeed( + "docker load --input='${pkgs.dockerTools.examples.no-store-paths}'" + ) + + docker.succeed("docker run --rm no-store-paths ls / >/dev/console") + + # If busybox isn't self-referential, we need this line + # docker.fail("docker run --rm no-store-paths ls /nix/store >/dev/console") + # However, it currently is self-referential, so we check that it is the + # only store path. + docker.succeed("diff <(docker run --rm no-store-paths ls /nix/store) <(basename ${pkgs.pkgsStatic.busybox}) >/dev/console") + + with subtest("Ensure buildLayeredImage does not change store path contents."): + docker.succeed( + "docker load --input='${pkgs.dockerTools.examples.filesInStore}'", + "docker run --rm file-in-store nix-store --verify --check-contents", + "docker run --rm file-in-store |& grep 'some data'", + ) + + with subtest("Ensure cross compiled image can be loaded and has correct arch."): + docker.succeed( + "docker load --input='${pkgs.dockerTools.examples.cross}'", + ) + assert ( + docker.succeed( + "docker inspect ${pkgs.dockerTools.examples.cross.imageName} " + + "| ${pkgs.jq}/bin/jq -r .[].Architecture" + ).strip() + == "${if pkgs.stdenv.hostPlatform.system == "aarch64-linux" then "amd64" else "arm64"}" + ) + + with subtest("buildLayeredImage doesn't dereference /nix/store symlink layers"): + docker.succeed( + "docker load --input='${examples.layeredStoreSymlink}'", + "docker run --rm ${examples.layeredStoreSymlink.imageName} bash -c 'test -L ${examples.layeredStoreSymlink.passthru.symlink}'", + "docker rmi ${examples.layeredStoreSymlink.imageName}", + ) + + with subtest("buildImage supports registry/ prefix in image name"): + docker.succeed( + "docker load --input='${examples.prefixedImage}'" + ) + docker.succeed( + "docker images --format '{{.Repository}}' | grep -F '${examples.prefixedImage.imageName}'" + ) + + with subtest("buildLayeredImage supports registry/ prefix in image name"): + docker.succeed( + "docker load --input='${examples.prefixedLayeredImage}'" + ) + docker.succeed( + "docker images --format '{{.Repository}}' | grep -F '${examples.prefixedLayeredImage.imageName}'" + ) + + with subtest("buildLayeredImage supports running chown with fakeRootCommands"): + docker.succeed( + "docker load --input='${examples.layeredImageWithFakeRootCommands}'" + ) + docker.succeed( + "docker run --rm ${examples.layeredImageWithFakeRootCommands.imageName} sh -c 'stat -c '%u' /home/alice | grep -E ^1000$'" + ) + + with subtest("Ensure docker load on merged images loads all of the constituent images"): + docker.succeed( + "docker load --input='${examples.mergedBashAndRedis}'" + ) + docker.succeed( + "docker images --format '{{.Repository}}-{{.Tag}}' | grep -F '${examples.bash.imageName}-${examples.bash.imageTag}'" + ) + docker.succeed( + "docker images --format '{{.Repository}}-{{.Tag}}' | grep -F '${examples.redis.imageName}-${examples.redis.imageTag}'" + ) + docker.succeed("docker run --rm ${examples.bash.imageName} bash --version") + docker.succeed("docker run --rm ${examples.redis.imageName} redis-cli --version") + docker.succeed("docker rmi ${examples.bash.imageName}") + docker.succeed("docker rmi ${examples.redis.imageName}") + + with subtest( + "Ensure docker load on merged images loads all of the constituent images (missing tags)" + ): + docker.succeed( + "docker load --input='${examples.mergedBashNoTagAndRedis}'" + ) + docker.succeed( + "docker images --format '{{.Repository}}-{{.Tag}}' | grep -F '${examples.bashNoTag.imageName}-${examples.bashNoTag.imageTag}'" + ) + docker.succeed( + "docker images --format '{{.Repository}}-{{.Tag}}' | grep -F '${examples.redis.imageName}-${examples.redis.imageTag}'" + ) + # we need to explicitly specify the generated tag here + docker.succeed( + "docker run --rm ${examples.bashNoTag.imageName}:${examples.bashNoTag.imageTag} bash --version" + ) + docker.succeed("docker run --rm ${examples.redis.imageName} redis-cli --version") + docker.succeed("docker rmi ${examples.bashNoTag.imageName}:${examples.bashNoTag.imageTag}") + docker.succeed("docker rmi ${examples.redis.imageName}") + + with subtest("mergeImages preserves owners of the original images"): + docker.succeed( + "docker load --input='${examples.mergedBashFakeRoot}'" + ) + docker.succeed( + "docker run --rm ${examples.layeredImageWithFakeRootCommands.imageName} sh -c 'stat -c '%u' /home/alice | grep -E ^1000$'" + ) + + with subtest("The image contains store paths referenced by the fakeRootCommands output"): + docker.succeed( + "docker run --rm ${examples.layeredImageWithFakeRootCommands.imageName} /hello/bin/layeredImageWithFakeRootCommands-hello" + ) + + with subtest("mergeImage correctly deals with varying compression schemas in inputs"): + docker.succeed("docker load --input='${examples.mergeVaryingCompressor}'") + + for sub_image, tag in [ + ("${examples.redis.imageName}", "${examples.redis.imageTag}"), + ("${examples.bashUncompressed.imageName}", "${examples.bashUncompressed.imageTag}"), + ("${examples.bashZstdCompressed.imageName}", "${examples.bashZstdCompressed.imageTag}"), + ]: + docker.succeed(f"docker images --format '{{{{.Repository}}}}-{{{{.Tag}}}}' | grep -F '{sub_image}-{tag}'") + docker.succeed(f"docker rmi {sub_image}") + + + with subtest("exportImage produces a valid tarball"): + docker.succeed( + "tar -tf ${examples.exportBash} | grep '\./bin/bash' > /dev/null" + ) + + with subtest("layered image fakeRootCommands with fakechroot works"): + docker.succeed("${examples.imageViaFakeChroot} | docker load") + docker.succeed("docker run --rm image-via-fake-chroot | grep -i hello") + docker.succeed("docker image rm image-via-fake-chroot:latest") + + with subtest("Ensure bare paths in contents are loaded correctly"): + docker.succeed( + "docker load --input='${examples.build-image-with-path}'", + "docker run --rm build-image-with-path bash -c '[[ -e /hello.txt ]]'", + "docker rmi build-image-with-path", + ) + docker.succeed( + "${examples.layered-image-with-path} | docker load", + "docker run --rm layered-image-with-path bash -c '[[ -e /hello.txt ]]'", + "docker rmi layered-image-with-path", + ) + + with subtest("Ensure correct architecture is present in manifests."): + docker.succeed(""" + docker load --input='${examples.build-image-with-architecture}' + docker inspect build-image-with-architecture \ + | ${pkgs.jq}/bin/jq -er '.[] | select(.Architecture=="arm64").Architecture' + docker rmi build-image-with-architecture + """) + docker.succeed(""" + ${examples.layered-image-with-architecture} | docker load + docker inspect layered-image-with-architecture \ + | ${pkgs.jq}/bin/jq -er '.[] | select(.Architecture=="arm64").Architecture' + docker rmi layered-image-with-architecture + """) + + with subtest("etc"): + docker.succeed("${examples.etc} | docker load") + docker.succeed("docker run --rm etc | grep localhost") + docker.succeed("docker image rm etc:latest") + + with subtest("image-with-certs"): + docker.succeed("<${examples.image-with-certs} docker load") + docker.succeed("docker run --rm image-with-certs:latest test -r /etc/ssl/certs/ca-bundle.crt") + docker.succeed("docker run --rm image-with-certs:latest test -r /etc/ssl/certs/ca-certificates.crt") + docker.succeed("docker run --rm image-with-certs:latest test -r /etc/pki/tls/certs/ca-bundle.crt") + docker.succeed("docker image rm image-with-certs:latest") + + with subtest("streamLayeredImage: chown is persistent in fakeRootCommands"): + docker.succeed( + "${chownTestImage} | docker load", + "docker run --rm ${chownTestImage.imageName} | diff /dev/stdin <(echo 12345:12345)" + ) + + with subtest("streamLayeredImage: with non-root user"): + docker.succeed( + "${nonRootTestImage} | docker load", + "docker run --rm ${chownTestImage.imageName} | diff /dev/stdin <(echo 12345:12345)" + ) + ''; + } +) diff --git a/nixos/tests/docker.nix b/nixos/tests/docker.nix index 93baa198088baa..b7c4b269057302 100644 --- a/nixos/tests/docker.nix +++ b/nixos/tests/docker.nix @@ -1,14 +1,19 @@ # This test runs docker and checks if simple container starts -import ./make-test-python.nix ({ pkgs, ...} : { - name = "docker"; - meta = with pkgs.lib.maintainers; { - maintainers = [ nequissimus offline ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "docker"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + nequissimus + offline + ]; + }; - nodes = { - docker = - { pkgs, ... }: + nodes = { + docker = + { pkgs, ... }: { virtualisation.docker.enable = true; virtualisation.docker.autoPrune.enable = true; @@ -31,23 +36,24 @@ import ./make-test-python.nix ({ pkgs, ...} : { }; }; - testScript = '' - start_all() + testScript = '' + start_all() - docker.wait_for_unit("sockets.target") - docker.succeed("tar cv --files-from /dev/null | docker import - scratchimg") - docker.succeed( - "docker run -d --name=sleeping -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10" - ) - docker.succeed("docker ps | grep sleeping") - docker.succeed("sudo -u hasprivs docker ps") - docker.fail("sudo -u noprivs docker ps") - docker.succeed("docker stop sleeping") + docker.wait_for_unit("sockets.target") + docker.succeed("tar cv --files-from /dev/null | docker import - scratchimg") + docker.succeed( + "docker run -d --name=sleeping -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10" + ) + docker.succeed("docker ps | grep sleeping") + docker.succeed("sudo -u hasprivs docker ps") + docker.fail("sudo -u noprivs docker ps") + docker.succeed("docker stop sleeping") - # Must match version 4 times to ensure client and server git commits and versions are correct - docker.succeed('[ $(docker version | grep ${pkgs.docker.version} | wc -l) = "4" ]') - docker.succeed("systemctl restart systemd-sysctl") - docker.succeed("grep 1 /proc/sys/net/ipv4/conf/all/forwarding") - docker.succeed("grep 1 /proc/sys/net/ipv4/conf/default/forwarding") - ''; -}) + # Must match version 4 times to ensure client and server git commits and versions are correct + docker.succeed('[ $(docker version | grep ${pkgs.docker.version} | wc -l) = "4" ]') + docker.succeed("systemctl restart systemd-sysctl") + docker.succeed("grep 1 /proc/sys/net/ipv4/conf/all/forwarding") + docker.succeed("grep 1 /proc/sys/net/ipv4/conf/default/forwarding") + ''; + } +) diff --git a/nixos/tests/documize.nix b/nixos/tests/documize.nix index 3624c0c56769c6..1537047ad67998 100644 --- a/nixos/tests/documize.nix +++ b/nixos/tests/documize.nix @@ -1,62 +1,67 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : { - name = "documize"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; - - nodes.machine = { pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; - - services.documize = { - enable = true; - port = 3000; - dbtype = "postgresql"; - db = "host=localhost port=5432 sslmode=disable user=documize password=documize dbname=documize"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "documize"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; }; - systemd.services.documize-server = { - after = [ "postgresql.service" ]; - requires = [ "postgresql.service" ]; - }; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - services.postgresql = { - enable = true; - initialScript = pkgs.writeText "psql-init" '' - CREATE ROLE documize WITH LOGIN PASSWORD 'documize'; - CREATE DATABASE documize WITH OWNER documize; - ''; - }; - }; - - testScript = '' - start_all() - - machine.wait_for_unit("documize-server.service") - machine.wait_for_open_port(3000) - - dbhash = machine.succeed( - "curl -f localhost:3000 | grep 'property=\"dbhash' | grep -Po 'content=\"\\K[^\"]*'" - ) - - dbhash = dbhash.strip() - - machine.succeed( - ( - "curl -X POST" - " --data 'dbname=documize'" - " --data 'dbhash={}'" - " --data 'title=NixOS'" - " --data 'message=Docs'" - " --data 'firstname=Bob'" - " --data 'lastname=Foobar'" - " --data 'email=bob.foobar@nixos.org'" - " --data 'password=verysafe'" - " -f localhost:3000/api/setup" - ).format(dbhash) - ) - - machine.succeed( - 'test "$(curl -f localhost:3000/api/public/meta | jq ".title" | xargs echo)" = "NixOS"' - ) - ''; -}) + services.documize = { + enable = true; + port = 3000; + dbtype = "postgresql"; + db = "host=localhost port=5432 sslmode=disable user=documize password=documize dbname=documize"; + }; + + systemd.services.documize-server = { + after = [ "postgresql.service" ]; + requires = [ "postgresql.service" ]; + }; + + services.postgresql = { + enable = true; + initialScript = pkgs.writeText "psql-init" '' + CREATE ROLE documize WITH LOGIN PASSWORD 'documize'; + CREATE DATABASE documize WITH OWNER documize; + ''; + }; + }; + + testScript = '' + start_all() + + machine.wait_for_unit("documize-server.service") + machine.wait_for_open_port(3000) + + dbhash = machine.succeed( + "curl -f localhost:3000 | grep 'property=\"dbhash' | grep -Po 'content=\"\\K[^\"]*'" + ) + + dbhash = dbhash.strip() + + machine.succeed( + ( + "curl -X POST" + " --data 'dbname=documize'" + " --data 'dbhash={}'" + " --data 'title=NixOS'" + " --data 'message=Docs'" + " --data 'firstname=Bob'" + " --data 'lastname=Foobar'" + " --data 'email=bob.foobar@nixos.org'" + " --data 'password=verysafe'" + " -f localhost:3000/api/setup" + ).format(dbhash) + ) + + machine.succeed( + 'test "$(curl -f localhost:3000/api/public/meta | jq ".title" | xargs echo)" = "NixOS"' + ) + ''; + } +) diff --git a/nixos/tests/doh-proxy-rust.nix b/nixos/tests/doh-proxy-rust.nix index 8c743fe77e328c..f9c73edcb778b7 100644 --- a/nixos/tests/doh-proxy-rust.nix +++ b/nixos/tests/doh-proxy-rust.nix @@ -1,41 +1,48 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "doh-proxy-rust"; - meta.maintainers = with lib.maintainers; [ stephank ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "doh-proxy-rust"; + meta.maintainers = with lib.maintainers; [ stephank ]; - nodes = { - machine = { pkgs, lib, ... }: { - services.bind = { - enable = true; - extraOptions = "empty-zones-enable no;"; - zones = lib.singleton { - name = "."; - master = true; - file = pkgs.writeText "root.zone" '' - $TTL 3600 - . IN SOA ns.example.org. admin.example.org. ( 1 3h 1h 1w 1d ) - . IN NS ns.example.org. - ns.example.org. IN A 192.168.0.1 - ''; + nodes = { + machine = + { pkgs, lib, ... }: + { + services.bind = { + enable = true; + extraOptions = "empty-zones-enable no;"; + zones = lib.singleton { + name = "."; + master = true; + file = pkgs.writeText "root.zone" '' + $TTL 3600 + . IN SOA ns.example.org. admin.example.org. ( 1 3h 1h 1w 1d ) + . IN NS ns.example.org. + ns.example.org. IN A 192.168.0.1 + ''; + }; + }; + services.doh-proxy-rust = { + enable = true; + flags = [ + "--server-address=127.0.0.1:53" + ]; + }; }; - }; - services.doh-proxy-rust = { - enable = true; - flags = [ - "--server-address=127.0.0.1:53" - ]; - }; }; - }; - testScript = { nodes, ... }: '' - url = "http://localhost:3000/dns-query" - query = "AAABAAABAAAAAAAAAm5zB2V4YW1wbGUDb3JnAAABAAE=" # IN A ns.example.org. - bin_ip = r"$'\xC0\xA8\x00\x01'" # 192.168.0.1, as shell binary string + testScript = + { nodes, ... }: + '' + url = "http://localhost:3000/dns-query" + query = "AAABAAABAAAAAAAAAm5zB2V4YW1wbGUDb3JnAAABAAE=" # IN A ns.example.org. + bin_ip = r"$'\xC0\xA8\x00\x01'" # 192.168.0.1, as shell binary string - machine.wait_for_unit("bind.service") - machine.wait_for_unit("doh-proxy-rust.service") - machine.wait_for_open_port(53) - machine.wait_for_open_port(3000) - machine.succeed(f"curl --fail -H 'Accept: application/dns-message' '{url}?dns={query}' | grep -F {bin_ip}") - ''; -}) + machine.wait_for_unit("bind.service") + machine.wait_for_unit("doh-proxy-rust.service") + machine.wait_for_open_port(53) + machine.wait_for_open_port(3000) + machine.succeed(f"curl --fail -H 'Accept: application/dns-message' '{url}?dns={query}' | grep -F {bin_ip}") + ''; + } +) diff --git a/nixos/tests/dolibarr.nix b/nixos/tests/dolibarr.nix index 95557d317fab9f..5d7098f763f55a 100644 --- a/nixos/tests/dolibarr.nix +++ b/nixos/tests/dolibarr.nix @@ -1,59 +1,62 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "dolibarr"; - meta.maintainers = [ ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "dolibarr"; + meta.maintainers = [ ]; - nodes.machine = - { ... }: - { - services.dolibarr = { - enable = true; - domain = "localhost"; - nginx = { - forceSSL = false; - enableACME = false; + nodes.machine = + { ... }: + { + services.dolibarr = { + enable = true; + domain = "localhost"; + nginx = { + forceSSL = false; + enableACME = false; + }; }; - }; - networking.firewall.allowedTCPPorts = [ 80 ]; - }; + networking.firewall.allowedTCPPorts = [ 80 ]; + }; - testScript = '' - from html.parser import HTMLParser - start_all() + testScript = '' + from html.parser import HTMLParser + start_all() - csrf_token = None - class TokenParser(HTMLParser): - def handle_starttag(self, tag, attrs): - attrs = dict(attrs) # attrs is an assoc list originally - if tag == 'input' and attrs.get('name') == 'token': - csrf_token = attrs.get('value') - print(f'[+] Caught CSRF token: {csrf_token}') - def handle_endtag(self, tag): pass - def handle_data(self, data): pass + csrf_token = None + class TokenParser(HTMLParser): + def handle_starttag(self, tag, attrs): + attrs = dict(attrs) # attrs is an assoc list originally + if tag == 'input' and attrs.get('name') == 'token': + csrf_token = attrs.get('value') + print(f'[+] Caught CSRF token: {csrf_token}') + def handle_endtag(self, tag): pass + def handle_data(self, data): pass - machine.wait_for_unit("phpfpm-dolibarr.service") - machine.wait_for_unit("nginx.service") - machine.wait_for_open_port(80) - # Sanity checks on URLs. - # machine.succeed("curl -fL http://localhost/index.php") - # machine.succeed("curl -fL http://localhost/") - # Perform installation. - machine.succeed('curl -fL -X POST http://localhost/install/check.php -F selectlang=auto') - machine.succeed('curl -fL -X POST http://localhost/install/fileconf.php -F selectlang=auto') - # First time is to write the configuration file correctly. - machine.succeed('curl -fL -X POST http://localhost/install/step1.php -F "testpost=ok" -F "action=set" -F "selectlang=auto"') - # Now, we have a proper conf.php in $stateDir. - assert 'nixos' in machine.succeed("cat /var/lib/dolibarr/conf.php") - machine.succeed('curl -fL -X POST http://localhost/install/step2.php --data "testpost=ok&action=set&dolibarr_main_db_character_set=utf8&dolibarr_main_db_collation=utf8_unicode_ci&selectlang=auto"') - machine.succeed('curl -fL -X POST http://localhost/install/step4.php --data "testpost=ok&action=set&selectlang=auto"') - machine.succeed('curl -fL -X POST http://localhost/install/step5.php --data "testpost=ok&action=set&login=root&pass=hunter2&pass_verif=hunter2&selectlang=auto"') - # Now, we have installed the machine, let's verify we still have the right configuration. - assert 'nixos' in machine.succeed("cat /var/lib/dolibarr/conf.php") - # We do not want any redirect now as we have installed the machine. - machine.succeed('curl -f -X GET http://localhost') - # Test authentication to the webservice. - parser = TokenParser() - parser.feed(machine.succeed('curl -f -X GET http://localhost/index.php?mainmenu=login&username=root')) - machine.succeed(f'curl -f -X POST http://localhost/index.php?mainmenu=login&token={csrf_token}&username=root&password=hunter2') - ''; -}) + machine.wait_for_unit("phpfpm-dolibarr.service") + machine.wait_for_unit("nginx.service") + machine.wait_for_open_port(80) + # Sanity checks on URLs. + # machine.succeed("curl -fL http://localhost/index.php") + # machine.succeed("curl -fL http://localhost/") + # Perform installation. + machine.succeed('curl -fL -X POST http://localhost/install/check.php -F selectlang=auto') + machine.succeed('curl -fL -X POST http://localhost/install/fileconf.php -F selectlang=auto') + # First time is to write the configuration file correctly. + machine.succeed('curl -fL -X POST http://localhost/install/step1.php -F "testpost=ok" -F "action=set" -F "selectlang=auto"') + # Now, we have a proper conf.php in $stateDir. + assert 'nixos' in machine.succeed("cat /var/lib/dolibarr/conf.php") + machine.succeed('curl -fL -X POST http://localhost/install/step2.php --data "testpost=ok&action=set&dolibarr_main_db_character_set=utf8&dolibarr_main_db_collation=utf8_unicode_ci&selectlang=auto"') + machine.succeed('curl -fL -X POST http://localhost/install/step4.php --data "testpost=ok&action=set&selectlang=auto"') + machine.succeed('curl -fL -X POST http://localhost/install/step5.php --data "testpost=ok&action=set&login=root&pass=hunter2&pass_verif=hunter2&selectlang=auto"') + # Now, we have installed the machine, let's verify we still have the right configuration. + assert 'nixos' in machine.succeed("cat /var/lib/dolibarr/conf.php") + # We do not want any redirect now as we have installed the machine. + machine.succeed('curl -f -X GET http://localhost') + # Test authentication to the webservice. + parser = TokenParser() + parser.feed(machine.succeed('curl -f -X GET http://localhost/index.php?mainmenu=login&username=root')) + machine.succeed(f'curl -f -X POST http://localhost/index.php?mainmenu=login&token={csrf_token}&username=root&password=hunter2') + ''; + } +) diff --git a/nixos/tests/domination.nix b/nixos/tests/domination.nix index 04899c50653114..d37a7ba98be99b 100644 --- a/nixos/tests/domination.nix +++ b/nixos/tests/domination.nix @@ -1,22 +1,25 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "domination"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fgaz ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "domination"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fgaz ]; + }; - nodes.machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + nodes.machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; - environment.systemPackages = [ pkgs.domination ]; - }; + services.xserver.enable = true; + environment.systemPackages = [ pkgs.domination ]; + }; - enableOCR = true; + enableOCR = true; - testScript = - '' + testScript = '' machine.wait_for_x() # Add a dummy sound card, or an error reporting popup will appear, # covering the main window and preventing OCR @@ -26,4 +29,5 @@ import ./make-test-python.nix ({ pkgs, ... }: { machine.wait_for_text(r"(New Game|Start Server|Load Game|Help Manual|Join Game|About|Play Online)") machine.screenshot("screen") ''; -}) + } +) diff --git a/nixos/tests/dovecot.nix b/nixos/tests/dovecot.nix index 5439387807fd72..cd17234980f5a2 100644 --- a/nixos/tests/dovecot.nix +++ b/nixos/tests/dovecot.nix @@ -1,74 +1,86 @@ import ./make-test-python.nix { name = "dovecot"; - nodes.machine = { pkgs, ... }: { - imports = [ common/user-account.nix ]; - services.postfix.enable = true; - services.dovecot2 = { - enable = true; - protocols = [ "imap" "pop3" ]; - modules = [ pkgs.dovecot_pigeonhole ]; - mailUser = "vmail"; - mailGroup = "vmail"; - }; - environment.systemPackages = let - sendTestMail = pkgs.writeScriptBin "send-testmail" '' - #!${pkgs.runtimeShell} - exec sendmail -vt < ~alice/b'") - - with subtest("Logout"): - logout() - - # Why do I need to do this?? - machine.succeed("su alice -c ecryptfs-umount-private || true") - machine.sleep(1) - - with subtest("Check that the filesystem is not accessible"): - machine.fail("mount | grep ecryptfs") - machine.succeed("su alice -c 'test \! -f ~alice/a'") - machine.succeed("su alice -c 'test \! -f ~alice/b'") - - with subtest("Log alice once more"): - login_as_alice() - - with subtest("Check that the files are there"): - machine.sleep(1) - machine.succeed("su alice -c 'test -f ~alice/a'") - machine.succeed("su alice -c 'test -f ~alice/b'") - machine.succeed('test "$(cat ~alice/b)" = "c"') - - with subtest("Catch https://github.com/NixOS/nixpkgs/issues/16766"): - machine.succeed("su alice -c 'ls -lh ~alice/'") - - logout() - ''; -}) +import ./make-test-python.nix ( + { ... }: + { + name = "ecryptfs"; + + nodes.machine = + { pkgs, ... }: + { + imports = [ ./common/user-account.nix ]; + boot.kernelModules = [ "ecryptfs" ]; + security.pam.enableEcryptfs = true; + environment.systemPackages = with pkgs; [ keyutils ]; + }; + + testScript = '' + def login_as_alice(): + machine.wait_until_tty_matches("1", "login: ") + machine.send_chars("alice\n") + machine.wait_until_tty_matches("1", "Password: ") + machine.send_chars("foobar\n") + machine.wait_until_tty_matches("1", "alice\@machine") + + + def logout(): + machine.send_chars("logout\n") + machine.wait_until_tty_matches("1", "login: ") + + + machine.wait_for_unit("default.target") + + with subtest("Set alice up with a password and a home"): + machine.succeed("(echo foobar; echo foobar) | passwd alice") + machine.succeed("chown -R alice.users ~alice") + + with subtest("Migrate alice's home"): + out = machine.succeed("echo foobar | ecryptfs-migrate-home -u alice") + machine.log(f"ecryptfs-migrate-home said: {out}") + + with subtest("Log alice in (ecryptfs passwhrase is wrapped during first login)"): + login_as_alice() + machine.send_chars("logout\n") + machine.wait_until_tty_matches("1", "login: ") + + # Why do I need to do this?? + machine.succeed("su alice -c ecryptfs-umount-private || true") + machine.sleep(1) + + with subtest("check that encrypted home is not mounted"): + machine.fail("mount | grep ecryptfs") + + with subtest("Show contents of the user keyring"): + out = machine.succeed("su - alice -c 'keyctl list \@u'") + machine.log(f"keyctl unlink said: {out}") + + with subtest("Log alice again"): + login_as_alice() + + with subtest("Create some files in encrypted home"): + machine.succeed("su alice -c 'touch ~alice/a'") + machine.succeed("su alice -c 'echo c > ~alice/b'") + + with subtest("Logout"): + logout() + + # Why do I need to do this?? + machine.succeed("su alice -c ecryptfs-umount-private || true") + machine.sleep(1) + + with subtest("Check that the filesystem is not accessible"): + machine.fail("mount | grep ecryptfs") + machine.succeed("su alice -c 'test \! -f ~alice/a'") + machine.succeed("su alice -c 'test \! -f ~alice/b'") + + with subtest("Log alice once more"): + login_as_alice() + + with subtest("Check that the files are there"): + machine.sleep(1) + machine.succeed("su alice -c 'test -f ~alice/a'") + machine.succeed("su alice -c 'test -f ~alice/b'") + machine.succeed('test "$(cat ~alice/b)" = "c"') + + with subtest("Catch https://github.com/NixOS/nixpkgs/issues/16766"): + machine.succeed("su alice -c 'ls -lh ~alice/'") + + logout() + ''; + } +) diff --git a/nixos/tests/eintopf.nix b/nixos/tests/eintopf.nix index a1c05d65130415..6e3992677da26f 100644 --- a/nixos/tests/eintopf.nix +++ b/nixos/tests/eintopf.nix @@ -1,21 +1,26 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "eintopf"; - meta = with pkgs.lib.maintainers; { - maintainers = [ onny ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "eintopf"; + meta = with pkgs.lib.maintainers; { + maintainers = [ onny ]; + }; - nodes = { - eintopf = { config, pkgs, ... }: { - services.eintopf = { - enable = true; - }; + nodes = { + eintopf = + { config, pkgs, ... }: + { + services.eintopf = { + enable = true; + }; + }; }; - }; - testScript = '' - eintopf.start - eintopf.wait_for_unit("eintopf.service") - eintopf.wait_for_open_port(3333) - eintopf.succeed("curl -sSfL http://eintopf:3333 | grep 'Es sind keine Veranstaltungen eingetragen'") - ''; -}) + testScript = '' + eintopf.start + eintopf.wait_for_unit("eintopf.service") + eintopf.wait_for_open_port(3333) + eintopf.succeed("curl -sSfL http://eintopf:3333 | grep 'Es sind keine Veranstaltungen eingetragen'") + ''; + } +) diff --git a/nixos/tests/elk.nix b/nixos/tests/elk.nix index 87c82877fe109a..719480da2e724b 100644 --- a/nixos/tests/elk.nix +++ b/nixos/tests/elk.nix @@ -2,8 +2,9 @@ # cd path/to/nixpkgs # NIXPKGS_ALLOW_UNFREE=1 nix-build -A nixosTests.elk.unfree.ELK-7 -{ system ? builtins.currentSystem, - config ? {}, +{ + system ? builtins.currentSystem, + config ? { }, pkgs ? import ../.. { inherit system config; }, }: @@ -12,15 +13,20 @@ let esUrl = "http://localhost:9200"; - mkElkTest = name : elk : + mkElkTest = + name: elk: import ./make-test-python.nix ({ - inherit name; - meta = with pkgs.lib.maintainers; { - maintainers = [ offline basvandijk ]; - }; - nodes = { - one = - { pkgs, lib, ... }: { + inherit name; + meta = with pkgs.lib.maintainers; { + maintainers = [ + offline + basvandijk + ]; + }; + nodes = { + one = + { pkgs, lib, ... }: + { # Not giving the machine at least 2060MB results in elasticsearch failing with the following error: # # OpenJDK 64-Bit Server VM warning: @@ -77,16 +83,28 @@ let enable = true; package = elk.metricbeat; modules.system = { - metricsets = ["cpu" "load" "memory" "network" "process" "process_summary" "uptime" "socket_summary"]; + metricsets = [ + "cpu" + "load" + "memory" + "network" + "process" + "process_summary" + "uptime" + "socket_summary" + ]; enabled = true; period = "5s"; - processes = [".*"]; - cpu.metrics = ["percentages" "normalized_percentages"]; - core.metrics = ["percentages"]; + processes = [ ".*" ]; + cpu.metrics = [ + "percentages" + "normalized_percentages" + ]; + core.metrics = [ "percentages" ]; }; settings = { output.elasticsearch = { - hosts = ["127.0.0.1:9200"]; + hosts = [ "127.0.0.1:9200" ]; }; }; }; @@ -122,140 +140,145 @@ let elasticsearch-curator = { enable = elk ? elasticsearch-curator; actionYAML = '' - --- - actions: - 1: - action: delete_indices - description: >- - Delete indices older than 1 second (based on index name), for logstash- - prefixed indices. Ignore the error if the filter does not result in an - actionable list of indices (ignore_empty_list) and exit cleanly. - options: - allow_ilm_indices: true - ignore_empty_list: True - disable_action: False - filters: - - filtertype: pattern - kind: prefix - value: logstash- - - filtertype: age - source: name - direction: older - timestring: '%Y.%m.%d' - unit: seconds - unit_count: 1 + --- + actions: + 1: + action: delete_indices + description: >- + Delete indices older than 1 second (based on index name), for logstash- + prefixed indices. Ignore the error if the filter does not result in an + actionable list of indices (ignore_empty_list) and exit cleanly. + options: + allow_ilm_indices: true + ignore_empty_list: True + disable_action: False + filters: + - filtertype: pattern + kind: prefix + value: logstash- + - filtertype: age + source: name + direction: older + timestring: '%Y.%m.%d' + unit: seconds + unit_count: 1 ''; }; }; }; }; - passthru.elkPackages = elk; - testScript = - let - valueObject = lib.optionalString (lib.versionAtLeast elk.elasticsearch.version "7") ".value"; - in '' - import json + passthru.elkPackages = elk; + testScript = + let + valueObject = lib.optionalString (lib.versionAtLeast elk.elasticsearch.version "7") ".value"; + in + '' + import json - def expect_hits(message): - dictionary = {"query": {"match": {"message": message}}} - return ( - "curl --silent --show-error --fail-with-body '${esUrl}/_search' " - + "-H 'Content-Type: application/json' " - + "-d '{}' ".format(json.dumps(dictionary)) - + " | tee /dev/console" - + " | jq -es 'if . == [] then null else .[] | .hits.total${valueObject} > 0 end'" - ) + def expect_hits(message): + dictionary = {"query": {"match": {"message": message}}} + return ( + "curl --silent --show-error --fail-with-body '${esUrl}/_search' " + + "-H 'Content-Type: application/json' " + + "-d '{}' ".format(json.dumps(dictionary)) + + " | tee /dev/console" + + " | jq -es 'if . == [] then null else .[] | .hits.total${valueObject} > 0 end'" + ) - def expect_no_hits(message): - dictionary = {"query": {"match": {"message": message}}} - return ( - "curl --silent --show-error --fail-with-body '${esUrl}/_search' " - + "-H 'Content-Type: application/json' " - + "-d '{}' ".format(json.dumps(dictionary)) - + " | tee /dev/console" - + " | jq -es 'if . == [] then null else .[] | .hits.total${valueObject} == 0 end'" - ) + def expect_no_hits(message): + dictionary = {"query": {"match": {"message": message}}} + return ( + "curl --silent --show-error --fail-with-body '${esUrl}/_search' " + + "-H 'Content-Type: application/json' " + + "-d '{}' ".format(json.dumps(dictionary)) + + " | tee /dev/console" + + " | jq -es 'if . == [] then null else .[] | .hits.total${valueObject} == 0 end'" + ) - def has_metricbeat(): - dictionary = {"query": {"match": {"event.dataset": {"query": "system.cpu"}}}} - return ( - "curl --silent --show-error --fail-with-body '${esUrl}/_search' " - + "-H 'Content-Type: application/json' " - + "-d '{}' ".format(json.dumps(dictionary)) - + " | tee /dev/console" - + " | jq -es 'if . == [] then null else .[] | .hits.total${valueObject} > 0 end'" - ) + def has_metricbeat(): + dictionary = {"query": {"match": {"event.dataset": {"query": "system.cpu"}}}} + return ( + "curl --silent --show-error --fail-with-body '${esUrl}/_search' " + + "-H 'Content-Type: application/json' " + + "-d '{}' ".format(json.dumps(dictionary)) + + " | tee /dev/console" + + " | jq -es 'if . == [] then null else .[] | .hits.total${valueObject} > 0 end'" + ) - start_all() + start_all() - one.wait_for_unit("elasticsearch.service") - one.wait_for_open_port(9200) + one.wait_for_unit("elasticsearch.service") + one.wait_for_open_port(9200) - # Continue as long as the status is not "red". The status is probably - # "yellow" instead of "green" because we are using a single elasticsearch - # node which elasticsearch considers risky. - # - # TODO: extend this test with multiple elasticsearch nodes - # and see if the status turns "green". - one.wait_until_succeeds( - "curl --silent --show-error --fail-with-body '${esUrl}/_cluster/health'" - + " | jq -es 'if . == [] then null else .[] | .status != \"red\" end'" - ) + # Continue as long as the status is not "red". The status is probably + # "yellow" instead of "green" because we are using a single elasticsearch + # node which elasticsearch considers risky. + # + # TODO: extend this test with multiple elasticsearch nodes + # and see if the status turns "green". + one.wait_until_succeeds( + "curl --silent --show-error --fail-with-body '${esUrl}/_cluster/health'" + + " | jq -es 'if . == [] then null else .[] | .status != \"red\" end'" + ) - with subtest("Perform some simple logstash tests"): - one.wait_for_unit("logstash.service") - one.wait_until_succeeds("cat /tmp/logstash.out | grep flowers") - one.wait_until_succeeds("cat /tmp/logstash.out | grep -v dragons") + with subtest("Perform some simple logstash tests"): + one.wait_for_unit("logstash.service") + one.wait_until_succeeds("cat /tmp/logstash.out | grep flowers") + one.wait_until_succeeds("cat /tmp/logstash.out | grep -v dragons") - with subtest("Metricbeat is running"): - one.wait_for_unit("metricbeat.service") + with subtest("Metricbeat is running"): + one.wait_for_unit("metricbeat.service") - with subtest("Metricbeat metrics arrive in elasticsearch"): - one.wait_until_succeeds(has_metricbeat()) + with subtest("Metricbeat metrics arrive in elasticsearch"): + one.wait_until_succeeds(has_metricbeat()) - with subtest("Logstash messages arive in elasticsearch"): - one.wait_until_succeeds(expect_hits("flowers")) - one.wait_until_succeeds(expect_no_hits("dragons")) + with subtest("Logstash messages arive in elasticsearch"): + one.wait_until_succeeds(expect_hits("flowers")) + one.wait_until_succeeds(expect_no_hits("dragons")) - '' + lib.optionalString (elk ? journalbeat) '' - with subtest( - "A message logged to the journal is ingested by elasticsearch via journalbeat" - ): - one.wait_for_unit("journalbeat.service") - one.execute("echo 'Supercalifragilisticexpialidocious' | systemd-cat") - one.wait_until_succeeds( - expect_hits("Supercalifragilisticexpialidocious") - ) - '' + lib.optionalString (elk ? filebeat) '' - with subtest( - "A message logged to the journal is ingested by elasticsearch via filebeat" - ): - one.wait_for_unit("filebeat.service") - one.execute("echo 'Superdupercalifragilisticexpialidocious' | systemd-cat") - one.wait_until_succeeds( - expect_hits("Superdupercalifragilisticexpialidocious") - ) - one.execute( - "echo 'SuperdupercalifragilisticexpialidociousIndeed' >> /var/lib/filebeat/test" - ) - one.wait_until_succeeds( - expect_hits("SuperdupercalifragilisticexpialidociousIndeed") - ) - '' + lib.optionalString (elk ? elasticsearch-curator) '' - with subtest("Elasticsearch-curator works"): - one.systemctl("stop logstash") - one.systemctl("start elasticsearch-curator") - one.wait_until_succeeds( - '! curl --silent --show-error --fail-with-body "${esUrl}/_cat/indices" | grep logstash | grep ^' - ) - ''; - }) { inherit pkgs system; }; -in { + '' + + lib.optionalString (elk ? journalbeat) '' + with subtest( + "A message logged to the journal is ingested by elasticsearch via journalbeat" + ): + one.wait_for_unit("journalbeat.service") + one.execute("echo 'Supercalifragilisticexpialidocious' | systemd-cat") + one.wait_until_succeeds( + expect_hits("Supercalifragilisticexpialidocious") + ) + '' + + lib.optionalString (elk ? filebeat) '' + with subtest( + "A message logged to the journal is ingested by elasticsearch via filebeat" + ): + one.wait_for_unit("filebeat.service") + one.execute("echo 'Superdupercalifragilisticexpialidocious' | systemd-cat") + one.wait_until_succeeds( + expect_hits("Superdupercalifragilisticexpialidocious") + ) + one.execute( + "echo 'SuperdupercalifragilisticexpialidociousIndeed' >> /var/lib/filebeat/test" + ) + one.wait_until_succeeds( + expect_hits("SuperdupercalifragilisticexpialidociousIndeed") + ) + '' + + lib.optionalString (elk ? elasticsearch-curator) '' + with subtest("Elasticsearch-curator works"): + one.systemctl("stop logstash") + one.systemctl("start elasticsearch-curator") + one.wait_until_succeeds( + '! curl --silent --show-error --fail-with-body "${esUrl}/_cat/indices" | grep logstash | grep ^' + ) + ''; + }) { inherit pkgs system; }; +in +{ # We currently only package upstream binaries. # Feel free to package an SSPL licensed source-based package! # ELK-7 = mkElkTest "elk-7-oss" { @@ -268,9 +291,9 @@ in { unfree = lib.dontRecurseIntoAttrs { ELK-7 = mkElkTest "elk-7" { elasticsearch = pkgs.elasticsearch7; - logstash = pkgs.logstash7; - filebeat = pkgs.filebeat7; - metricbeat = pkgs.metricbeat7; + logstash = pkgs.logstash7; + filebeat = pkgs.filebeat7; + metricbeat = pkgs.metricbeat7; }; }; } diff --git a/nixos/tests/emacs-daemon.nix b/nixos/tests/emacs-daemon.nix index 310e93e19b0b41..db8a26e6db350a 100644 --- a/nixos/tests/emacs-daemon.nix +++ b/nixos/tests/emacs-daemon.nix @@ -1,27 +1,30 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "emacs-daemon"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "emacs-daemon"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; - enableOCR = true; + enableOCR = true; - nodes.machine = - { ... }: + nodes.machine = + { ... }: - { imports = [ ./common/x11.nix ]; - services.emacs = { - enable = true; - defaultEditor = true; - }; + { + imports = [ ./common/x11.nix ]; + services.emacs = { + enable = true; + defaultEditor = true; + }; - # Important to get the systemd service running for root - environment.variables.XDG_RUNTIME_DIR = "/run/user/0"; + # Important to get the systemd service running for root + environment.variables.XDG_RUNTIME_DIR = "/run/user/0"; - environment.variables.TEST_SYSTEM_VARIABLE = "system variable"; - }; + environment.variables.TEST_SYSTEM_VARIABLE = "system variable"; + }; - testScript = '' + testScript = '' machine.wait_for_unit("multi-user.target") # checks that the EDITOR environment variable is set @@ -45,4 +48,5 @@ import ./make-test-python.nix ({ pkgs, ...} : { machine.screenshot("emacsclient") ''; -}) + } +) diff --git a/nixos/tests/endlessh-go.nix b/nixos/tests/endlessh-go.nix index 70ec7d816612dc..0c2402af256819 100644 --- a/nixos/tests/endlessh-go.nix +++ b/nixos/tests/endlessh-go.nix @@ -1,62 +1,71 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -{ - name = "endlessh-go"; - meta.maintainers = with lib.maintainers; [ azahi ]; - - nodes = { - server = { ... }: { - services.endlessh-go = { - enable = true; - prometheus.enable = true; - openFirewall = true; - }; - - specialisation = { - unprivileged.configuration = { +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "endlessh-go"; + meta.maintainers = with lib.maintainers; [ azahi ]; + + nodes = { + server = + { ... }: + { services.endlessh-go = { - port = 2222; - prometheus.port = 9229; + enable = true; + prometheus.enable = true; + openFirewall = true; }; - }; - privileged.configuration = { - services.endlessh-go = { - port = 22; - prometheus.port = 92; + specialisation = { + unprivileged.configuration = { + services.endlessh-go = { + port = 2222; + prometheus.port = 9229; + }; + }; + + privileged.configuration = { + services.endlessh-go = { + port = 22; + prometheus.port = 92; + }; + }; }; }; - }; - }; - client = { pkgs, ... }: { - environment.systemPackages = with pkgs; [ curl netcat ]; + client = + { pkgs, ... }: + { + environment.systemPackages = with pkgs; [ + curl + netcat + ]; + }; }; - }; - - testScript = '' - def activate_specialisation(name: str): - server.succeed(f"/run/booted-system/specialisation/{name}/bin/switch-to-configuration test >&2") - - start_all() - - with subtest("Unprivileged"): - activate_specialisation("unprivileged") - server.wait_for_unit("endlessh-go.service") - server.wait_for_open_port(2222) - server.wait_for_open_port(9229) - server.fail("curl -sSf server:9229/metrics | grep -q endlessh_client_closed_count_total") - client.succeed("nc -dvW5 server 2222") - server.succeed("curl -sSf server:9229/metrics | grep -q endlessh_client_closed_count_total") - client.fail("curl -sSfm 5 server:9229/metrics") - - with subtest("Privileged"): - activate_specialisation("privileged") - server.wait_for_unit("endlessh-go.service") - server.wait_for_open_port(22) - server.wait_for_open_port(92) - server.fail("curl -sSf server:92/metrics | grep -q endlessh_client_closed_count_total") - client.succeed("nc -dvW5 server 22") - server.succeed("curl -sSf server:92/metrics | grep -q endlessh_client_closed_count_total") - client.fail("curl -sSfm 5 server:92/metrics") - ''; -}) + + testScript = '' + def activate_specialisation(name: str): + server.succeed(f"/run/booted-system/specialisation/{name}/bin/switch-to-configuration test >&2") + + start_all() + + with subtest("Unprivileged"): + activate_specialisation("unprivileged") + server.wait_for_unit("endlessh-go.service") + server.wait_for_open_port(2222) + server.wait_for_open_port(9229) + server.fail("curl -sSf server:9229/metrics | grep -q endlessh_client_closed_count_total") + client.succeed("nc -dvW5 server 2222") + server.succeed("curl -sSf server:9229/metrics | grep -q endlessh_client_closed_count_total") + client.fail("curl -sSfm 5 server:9229/metrics") + + with subtest("Privileged"): + activate_specialisation("privileged") + server.wait_for_unit("endlessh-go.service") + server.wait_for_open_port(22) + server.wait_for_open_port(92) + server.fail("curl -sSf server:92/metrics | grep -q endlessh_client_closed_count_total") + client.succeed("nc -dvW5 server 22") + server.succeed("curl -sSf server:92/metrics | grep -q endlessh_client_closed_count_total") + client.fail("curl -sSfm 5 server:92/metrics") + ''; + } +) diff --git a/nixos/tests/endlessh.nix b/nixos/tests/endlessh.nix index be742a749fdd88..696ef1b6013f56 100644 --- a/nixos/tests/endlessh.nix +++ b/nixos/tests/endlessh.nix @@ -1,43 +1,52 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -{ - name = "endlessh"; - meta.maintainers = with lib.maintainers; [ azahi ]; - - nodes = { - server = { ... }: { - services.endlessh = { - enable = true; - openFirewall = true; - }; - - specialisation = { - unprivileged.configuration.services.endlessh.port = 2222; - - privileged.configuration.services.endlessh.port = 22; - }; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "endlessh"; + meta.maintainers = with lib.maintainers; [ azahi ]; + + nodes = { + server = + { ... }: + { + services.endlessh = { + enable = true; + openFirewall = true; + }; + + specialisation = { + unprivileged.configuration.services.endlessh.port = 2222; + + privileged.configuration.services.endlessh.port = 22; + }; + }; + + client = + { pkgs, ... }: + { + environment.systemPackages = with pkgs; [ + curl + netcat + ]; + }; }; - client = { pkgs, ... }: { - environment.systemPackages = with pkgs; [ curl netcat ]; - }; - }; - - testScript = '' - def activate_specialisation(name: str): - server.succeed(f"/run/booted-system/specialisation/{name}/bin/switch-to-configuration test >&2") - - start_all() - - with subtest("Unprivileged"): - activate_specialisation("unprivileged") - server.wait_for_unit("endlessh.service") - server.wait_for_open_port(2222) - client.succeed("nc -dvW5 server 2222") - - with subtest("Privileged"): - activate_specialisation("privileged") - server.wait_for_unit("endlessh.service") - server.wait_for_open_port(22) - client.succeed("nc -dvW5 server 22") - ''; -}) + testScript = '' + def activate_specialisation(name: str): + server.succeed(f"/run/booted-system/specialisation/{name}/bin/switch-to-configuration test >&2") + + start_all() + + with subtest("Unprivileged"): + activate_specialisation("unprivileged") + server.wait_for_unit("endlessh.service") + server.wait_for_open_port(2222) + client.succeed("nc -dvW5 server 2222") + + with subtest("Privileged"): + activate_specialisation("privileged") + server.wait_for_unit("endlessh.service") + server.wait_for_open_port(22) + client.succeed("nc -dvW5 server 22") + ''; + } +) diff --git a/nixos/tests/engelsystem.nix b/nixos/tests/engelsystem.nix index 7be3b8a5a1fe20..69187973ada9b4 100644 --- a/nixos/tests/engelsystem.nix +++ b/nixos/tests/engelsystem.nix @@ -14,7 +14,10 @@ import ./make-test-python.nix ( domain = "engelsystem"; createDatabase = true; }; - networking.firewall.allowedTCPPorts = [ 80 443 ]; + networking.firewall.allowedTCPPorts = [ + 80 + 443 + ]; environment.systemPackages = with pkgs; [ xmlstarlet libxml2 @@ -38,4 +41,5 @@ import ./make-test-python.nix ( "test 'News - Engelsystem' = \"$(xml sel -T -t -c html/head/title news)\"" ) ''; - }) + } +) diff --git a/nixos/tests/enlightenment.nix b/nixos/tests/enlightenment.nix index ba917e18c09f41..f2fc23685dd6d5 100644 --- a/nixos/tests/enlightenment.nix +++ b/nixos/tests/enlightenment.nix @@ -1,98 +1,104 @@ -import ./make-test-python.nix ({ pkgs, ...} : -{ - name = "enlightenment"; - - meta = with pkgs.lib.maintainers; { - maintainers = [ romildo ]; - timeout = 600; - # OCR tests are flaky - broken = true; - }; - - nodes.machine = { ... }: +import ./make-test-python.nix ( + { pkgs, ... }: { - imports = [ ./common/user-account.nix ]; - services.xserver.enable = true; - services.xserver.desktopManager.enlightenment.enable = true; - services.xserver.displayManager = { - lightdm.enable = true; - autoLogin = { - enable = true; - user = "alice"; - }; + name = "enlightenment"; + + meta = with pkgs.lib.maintainers; { + maintainers = [ romildo ]; + timeout = 600; + # OCR tests are flaky + broken = true; }; - environment.systemPackages = [ pkgs.xdotool ]; - services.acpid.enable = true; - services.connman.enable = true; - services.connman.package = pkgs.connmanMinimal; - }; - - enableOCR = true; - - testScript = { nodes, ... }: let - user = nodes.machine.config.users.users.alice; - in '' - with subtest("Ensure x starts"): - machine.wait_for_x() - machine.wait_for_file("${user.home}/.Xauthority") - machine.succeed("xauth merge ${user.home}/.Xauthority") - - with subtest("Check that logging in has given the user ownership of devices"): - machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") - - with subtest("First time wizard"): - machine.wait_for_text("Default") # Language - machine.screenshot("wizard1") - machine.succeed("xdotool mousemove 512 740 click 1") # Next - machine.screenshot("wizard2") - - machine.wait_for_text("English") # Keyboard (default) - machine.screenshot("wizard3") - machine.succeed("xdotool mousemove 512 740 click 1") # Next - - machine.wait_for_text("Standard") # Profile (default) - machine.screenshot("wizard4") - machine.succeed("xdotool mousemove 512 740 click 1") # Next - - machine.wait_for_text("Title") # Sizing (default) - machine.screenshot("wizard5") - machine.succeed("xdotool mousemove 512 740 click 1") # Next - - machine.wait_for_text("clicked") # Windows Focus - machine.succeed("xdotool mousemove 512 370 click 1") # Click - machine.screenshot("wizard6") - machine.succeed("xdotool mousemove 512 740 click 1") # Next - - machine.wait_for_text("Connman") # Network Management (default) - machine.screenshot("wizard7") - machine.succeed("xdotool mousemove 512 740 click 1") # Next - - machine.wait_for_text("BlusZ") # Bluetooth Management (default) - machine.screenshot("wizard8") - machine.succeed("xdotool mousemove 512 740 click 1") # Next - - machine.wait_for_text("OpenGL") # Compositing (default) - machine.screenshot("wizard9") - machine.succeed("xdotool mousemove 512 740 click 1") # Next - - machine.wait_for_text("update") # Updates - machine.succeed("xdotool mousemove 512 495 click 1") # Disable - machine.screenshot("wizard10") - machine.succeed("xdotool mousemove 512 740 click 1") # Next - - machine.wait_for_text("taskbar") # Taskbar - machine.succeed("xdotool mousemove 480 410 click 1") # Enable - machine.screenshot("wizard11") - machine.succeed("xdotool mousemove 512 740 click 1") # Next - - machine.wait_for_text("Home") # The desktop - machine.screenshot("wizard12") - - with subtest("Run Terminology"): - machine.succeed("terminology >&2 &") - machine.sleep(5) - machine.send_chars("ls --color -alF\n") - machine.sleep(2) - machine.screenshot("terminology") - ''; -}) + + nodes.machine = + { ... }: + { + imports = [ ./common/user-account.nix ]; + services.xserver.enable = true; + services.xserver.desktopManager.enlightenment.enable = true; + services.xserver.displayManager = { + lightdm.enable = true; + autoLogin = { + enable = true; + user = "alice"; + }; + }; + environment.systemPackages = [ pkgs.xdotool ]; + services.acpid.enable = true; + services.connman.enable = true; + services.connman.package = pkgs.connmanMinimal; + }; + + enableOCR = true; + + testScript = + { nodes, ... }: + let + user = nodes.machine.config.users.users.alice; + in + '' + with subtest("Ensure x starts"): + machine.wait_for_x() + machine.wait_for_file("${user.home}/.Xauthority") + machine.succeed("xauth merge ${user.home}/.Xauthority") + + with subtest("Check that logging in has given the user ownership of devices"): + machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") + + with subtest("First time wizard"): + machine.wait_for_text("Default") # Language + machine.screenshot("wizard1") + machine.succeed("xdotool mousemove 512 740 click 1") # Next + machine.screenshot("wizard2") + + machine.wait_for_text("English") # Keyboard (default) + machine.screenshot("wizard3") + machine.succeed("xdotool mousemove 512 740 click 1") # Next + + machine.wait_for_text("Standard") # Profile (default) + machine.screenshot("wizard4") + machine.succeed("xdotool mousemove 512 740 click 1") # Next + + machine.wait_for_text("Title") # Sizing (default) + machine.screenshot("wizard5") + machine.succeed("xdotool mousemove 512 740 click 1") # Next + + machine.wait_for_text("clicked") # Windows Focus + machine.succeed("xdotool mousemove 512 370 click 1") # Click + machine.screenshot("wizard6") + machine.succeed("xdotool mousemove 512 740 click 1") # Next + + machine.wait_for_text("Connman") # Network Management (default) + machine.screenshot("wizard7") + machine.succeed("xdotool mousemove 512 740 click 1") # Next + + machine.wait_for_text("BlusZ") # Bluetooth Management (default) + machine.screenshot("wizard8") + machine.succeed("xdotool mousemove 512 740 click 1") # Next + + machine.wait_for_text("OpenGL") # Compositing (default) + machine.screenshot("wizard9") + machine.succeed("xdotool mousemove 512 740 click 1") # Next + + machine.wait_for_text("update") # Updates + machine.succeed("xdotool mousemove 512 495 click 1") # Disable + machine.screenshot("wizard10") + machine.succeed("xdotool mousemove 512 740 click 1") # Next + + machine.wait_for_text("taskbar") # Taskbar + machine.succeed("xdotool mousemove 480 410 click 1") # Enable + machine.screenshot("wizard11") + machine.succeed("xdotool mousemove 512 740 click 1") # Next + + machine.wait_for_text("Home") # The desktop + machine.screenshot("wizard12") + + with subtest("Run Terminology"): + machine.succeed("terminology >&2 &") + machine.sleep(5) + machine.send_chars("ls --color -alF\n") + machine.sleep(2) + machine.screenshot("terminology") + ''; + } +) diff --git a/nixos/tests/envfs.nix b/nixos/tests/envfs.nix index 3f9cd1edb595af..9e728698ebc3ef 100644 --- a/nixos/tests/envfs.nix +++ b/nixos/tests/envfs.nix @@ -1,42 +1,44 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -let - pythonShebang = pkgs.writeScript "python-shebang" '' - #!/usr/bin/python - print("OK") - ''; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let + pythonShebang = pkgs.writeScript "python-shebang" '' + #!/usr/bin/python + print("OK") + ''; - bashShebang = pkgs.writeScript "bash-shebang" '' - #!/usr/bin/bash - echo "OK" - ''; -in -{ - name = "envfs"; - nodes.machine.services.envfs.enable = true; + bashShebang = pkgs.writeScript "bash-shebang" '' + #!/usr/bin/bash + echo "OK" + ''; + in + { + name = "envfs"; + nodes.machine.services.envfs.enable = true; - testScript = '' - start_all() - machine.wait_until_succeeds("mountpoint -q /usr/bin/") - machine.succeed( - "PATH=${pkgs.coreutils}/bin /usr/bin/cp --version", - # check fallback paths - "PATH= /usr/bin/sh --version", - "PATH= /usr/bin/env --version", - "PATH= test -e /usr/bin/sh", - "PATH= test -e /usr/bin/env", - # no stat - "! test -e /usr/bin/cp", - # also picks up PATH that was set after execve - "! /usr/bin/hello", - "PATH=${pkgs.hello}/bin /usr/bin/hello", - ) + testScript = '' + start_all() + machine.wait_until_succeeds("mountpoint -q /usr/bin/") + machine.succeed( + "PATH=${pkgs.coreutils}/bin /usr/bin/cp --version", + # check fallback paths + "PATH= /usr/bin/sh --version", + "PATH= /usr/bin/env --version", + "PATH= test -e /usr/bin/sh", + "PATH= test -e /usr/bin/env", + # no stat + "! test -e /usr/bin/cp", + # also picks up PATH that was set after execve + "! /usr/bin/hello", + "PATH=${pkgs.hello}/bin /usr/bin/hello", + ) - out = machine.succeed("PATH=${pkgs.python3}/bin ${pythonShebang}") - print(out) - assert out == "OK\n" + out = machine.succeed("PATH=${pkgs.python3}/bin ${pythonShebang}") + print(out) + assert out == "OK\n" - out = machine.succeed("PATH=${pkgs.bash}/bin ${bashShebang}") - print(out) - assert out == "OK\n" - ''; -}) + out = machine.succeed("PATH=${pkgs.bash}/bin ${bashShebang}") + print(out) + assert out == "OK\n" + ''; + } +) diff --git a/nixos/tests/envoy.nix b/nixos/tests/envoy.nix index 1e4bfe626398e4..d669b2bb718ffc 100644 --- a/nixos/tests/envoy.nix +++ b/nixos/tests/envoy.nix @@ -1,54 +1,62 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : { - name = "envoy"; - meta = with pkgs.lib.maintainers; { - maintainers = [ cameronnemo ]; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "envoy"; + meta = with pkgs.lib.maintainers; { + maintainers = [ cameronnemo ]; + }; - nodes.machine = { pkgs, ... }: { - services.envoy.enable = true; - services.envoy.settings = { - admin = { - access_log_path = "/dev/null"; - address = { - socket_address = { - protocol = "TCP"; - address = "127.0.0.1"; - port_value = 80; + nodes.machine = + { pkgs, ... }: + { + services.envoy.enable = true; + services.envoy.settings = { + admin = { + access_log_path = "/dev/null"; + address = { + socket_address = { + protocol = "TCP"; + address = "127.0.0.1"; + port_value = 80; + }; + }; + }; + static_resources = { + listeners = [ ]; + clusters = [ ]; }; }; - }; - static_resources = { - listeners = []; - clusters = []; - }; - }; - specialisation = { - withoutConfigValidation.configuration = { ... }: { - services.envoy = { - requireValidConfig = false; - settings.admin.access_log_path = lib.mkForce "/var/log/envoy/access.log"; + specialisation = { + withoutConfigValidation.configuration = + { ... }: + { + services.envoy = { + requireValidConfig = false; + settings.admin.access_log_path = lib.mkForce "/var/log/envoy/access.log"; + }; + }; }; }; - }; - }; - testScript = { nodes, ... }: - let - specialisations = "${nodes.machine.system.build.toplevel}/specialisation"; - in - '' - machine.start() + testScript = + { nodes, ... }: + let + specialisations = "${nodes.machine.system.build.toplevel}/specialisation"; + in + '' + machine.start() - with subtest("envoy.service starts and responds with ready"): - machine.wait_for_unit("envoy.service") - machine.wait_for_open_port(80) - machine.wait_until_succeeds("curl -fsS localhost:80/ready") + with subtest("envoy.service starts and responds with ready"): + machine.wait_for_unit("envoy.service") + machine.wait_for_open_port(80) + machine.wait_until_succeeds("curl -fsS localhost:80/ready") - with subtest("envoy.service works with config path not available at eval time"): - machine.succeed('${specialisations}/withoutConfigValidation/bin/switch-to-configuration test') - machine.wait_for_unit("envoy.service") - machine.wait_for_open_port(80) - machine.wait_until_succeeds("curl -fsS localhost:80/ready") - machine.succeed('test -f /var/log/envoy/access.log') - ''; -}) + with subtest("envoy.service works with config path not available at eval time"): + machine.succeed('${specialisations}/withoutConfigValidation/bin/switch-to-configuration test') + machine.wait_for_unit("envoy.service") + machine.wait_for_open_port(80) + machine.wait_until_succeeds("curl -fsS localhost:80/ready") + machine.succeed('test -f /var/log/envoy/access.log') + ''; + } +) diff --git a/nixos/tests/ergo.nix b/nixos/tests/ergo.nix index b49e0c9dfed73b..fadf4458990631 100644 --- a/nixos/tests/ergo.nix +++ b/nixos/tests/ergo.nix @@ -1,18 +1,23 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "ergo"; - meta = with pkgs.lib.maintainers; { - maintainers = [ mmahut ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "ergo"; + meta = with pkgs.lib.maintainers; { + maintainers = [ mmahut ]; + }; - nodes = { - machine = { ... }: { - services.ergo.enable = true; - services.ergo.api.keyHash = "324dcf027dd4a30a932c441f365a25e86b173defa4b8e58948253471b81b72cf"; + nodes = { + machine = + { ... }: + { + services.ergo.enable = true; + services.ergo.api.keyHash = "324dcf027dd4a30a932c441f365a25e86b173defa4b8e58948253471b81b72cf"; + }; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("ergo.service") - ''; -}) + testScript = '' + start_all() + machine.wait_for_unit("ergo.service") + ''; + } +) diff --git a/nixos/tests/ergochat.nix b/nixos/tests/ergochat.nix index 2e9dc55e648e6b..6dd9efbb2ccf32 100644 --- a/nixos/tests/ergochat.nix +++ b/nixos/tests/ergochat.nix @@ -9,89 +9,100 @@ let iiDir = "/tmp/irc"; in -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "ergochat"; - nodes = { - "${server}" = { - networking.firewall.allowedTCPPorts = [ ircPort ]; - services.ergochat = { - enable = true; - settings.server.motd = pkgs.writeText "ergo.motd" '' - The default MOTD doesn't contain the word "nixos" in it. - This one does. - ''; - }; - }; - } // lib.listToAttrs (builtins.map (client: lib.nameValuePair client { - imports = [ - ./common/user-account.nix - ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "ergochat"; + nodes = + { + "${server}" = { + networking.firewall.allowedTCPPorts = [ ircPort ]; + services.ergochat = { + enable = true; + settings.server.motd = pkgs.writeText "ergo.motd" '' + The default MOTD doesn't contain the word "nixos" in it. + This one does. + ''; + }; + }; + } + // lib.listToAttrs ( + builtins.map ( + client: + lib.nameValuePair client { + imports = [ + ./common/user-account.nix + ]; - systemd.services.ii = { - requires = [ "network.target" ]; - wantedBy = [ "default.target" ]; + systemd.services.ii = { + requires = [ "network.target" ]; + wantedBy = [ "default.target" ]; - serviceConfig = { - Type = "simple"; - ExecPreStartPre = "mkdir -p ${iiDir}"; - ExecStart = '' - ${lib.getBin pkgs.ii}/bin/ii -n ${client} -s ${server} -i ${iiDir} - ''; - User = "alice"; - }; - }; - }) clients); + serviceConfig = { + Type = "simple"; + ExecPreStartPre = "mkdir -p ${iiDir}"; + ExecStart = '' + ${lib.getBin pkgs.ii}/bin/ii -n ${client} -s ${server} -i ${iiDir} + ''; + User = "alice"; + }; + }; + } + ) clients + ); - testScript = - let - msg = client: "Hello, my name is ${client}"; - clientScript = client: [ - '' - ${client}.wait_for_unit("network.target") - ${client}.systemctl("start ii") - ${client}.wait_for_unit("ii") - ${client}.wait_for_file("${iiDir}/${server}/out") - '' - # look for the custom text in the MOTD. - '' - ${client}.wait_until_succeeds("grep 'nixos' ${iiDir}/${server}/out") - '' - # wait until first PING from server arrives before joining, - # so we don't try it too early - '' - ${client}.wait_until_succeeds("grep 'PING' ${iiDir}/${server}/out") - '' - # join ${channel} - '' - ${client}.succeed("echo '/j #${channel}' > ${iiDir}/${server}/in") - ${client}.wait_for_file("${iiDir}/${server}/#${channel}/in") - '' - # send a greeting - '' - ${client}.succeed( - "echo '${msg client}' > ${iiDir}/${server}/#${channel}/in" - ) - '' - # check that all greetings arrived on all clients - ] ++ builtins.map (other: '' - ${client}.succeed( - "grep '${msg other}$' ${iiDir}/${server}/#${channel}/out" - ) - '') clients; + testScript = + let + msg = client: "Hello, my name is ${client}"; + clientScript = + client: + [ + '' + ${client}.wait_for_unit("network.target") + ${client}.systemctl("start ii") + ${client}.wait_for_unit("ii") + ${client}.wait_for_file("${iiDir}/${server}/out") + '' + # look for the custom text in the MOTD. + '' + ${client}.wait_until_succeeds("grep 'nixos' ${iiDir}/${server}/out") + '' + # wait until first PING from server arrives before joining, + # so we don't try it too early + '' + ${client}.wait_until_succeeds("grep 'PING' ${iiDir}/${server}/out") + '' + # join ${channel} + '' + ${client}.succeed("echo '/j #${channel}' > ${iiDir}/${server}/in") + ${client}.wait_for_file("${iiDir}/${server}/#${channel}/in") + '' + # send a greeting + '' + ${client}.succeed( + "echo '${msg client}' > ${iiDir}/${server}/#${channel}/in" + ) + '' + # check that all greetings arrived on all clients + ] + ++ builtins.map (other: '' + ${client}.succeed( + "grep '${msg other}$' ${iiDir}/${server}/#${channel}/out" + ) + '') clients; - # foldl', but requires a non-empty list instead of a start value - reduce = f: list: - builtins.foldl' f (builtins.head list) (builtins.tail list); - in '' - start_all() - ${server}.systemctl("status ergochat") - ${server}.wait_for_open_port(${toString ircPort}) + # foldl', but requires a non-empty list instead of a start value + reduce = f: list: builtins.foldl' f (builtins.head list) (builtins.tail list); + in + '' + start_all() + ${server}.systemctl("status ergochat") + ${server}.wait_for_open_port(${toString ircPort}) - # run clientScript for all clients so that every list - # entry is executed by every client before advancing - # to the next one. - '' + lib.concatStrings - (reduce - (lib.zipListsWith (cs: c: cs + c)) - (builtins.map clientScript clients)); -}) + # run clientScript for all clients so that every list + # entry is executed by every client before advancing + # to the next one. + '' + + lib.concatStrings (reduce (lib.zipListsWith (cs: c: cs + c)) (builtins.map clientScript clients)); + } +) diff --git a/nixos/tests/eris-server.nix b/nixos/tests/eris-server.nix index b9d2b57401e0a2..795be7f5086cb2 100644 --- a/nixos/tests/eris-server.nix +++ b/nixos/tests/eris-server.nix @@ -1,23 +1,29 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "eris-server"; - meta.maintainers = with lib.maintainers; [ ehmry ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "eris-server"; + meta.maintainers = with lib.maintainers; [ ehmry ]; - nodes.server = { - environment.systemPackages = [ pkgs.eris-go pkgs.eriscmd ]; - services.eris-server = { - enable = true; - decode = true; - listenHttp = "[::1]:80"; - backends = [ "badger+file:///var/cache/eris.badger?get&put" ]; - mountpoint = "/eris"; + nodes.server = { + environment.systemPackages = [ + pkgs.eris-go + pkgs.eriscmd + ]; + services.eris-server = { + enable = true; + decode = true; + listenHttp = "[::1]:80"; + backends = [ "badger+file:///var/cache/eris.badger?get&put" ]; + mountpoint = "/eris"; + }; }; - }; - testScript = '' - start_all() - server.wait_for_unit("eris-server.service") - server.wait_for_open_port(5683) - server.wait_for_open_port(80) - server.succeed("eriscmd get http://[::1] $(echo 'Hail ERIS!' | eriscmd put coap+tcp://[::1]:5683)") - ''; -}) + testScript = '' + start_all() + server.wait_for_unit("eris-server.service") + server.wait_for_open_port(5683) + server.wait_for_open_port(80) + server.succeed("eriscmd get http://[::1] $(echo 'Hail ERIS!' | eriscmd put coap+tcp://[::1]:5683)") + ''; + } +) diff --git a/nixos/tests/esphome.nix b/nixos/tests/esphome.nix index 5a318b65a72317..4fe0a9303ce874 100644 --- a/nixos/tests/esphome.nix +++ b/nixos/tests/esphome.nix @@ -1,40 +1,44 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: -let - testPort = 6052; - unixSocket = "/run/esphome/esphome.sock"; -in -{ - name = "esphome"; - meta.maintainers = with lib.maintainers; [ oddlama ]; + let + testPort = 6052; + unixSocket = "/run/esphome/esphome.sock"; + in + { + name = "esphome"; + meta.maintainers = with lib.maintainers; [ oddlama ]; - nodes = { - esphomeTcp = { ... }: - { - services.esphome = { - enable = true; - port = testPort; - address = "0.0.0.0"; - openFirewall = true; + nodes = { + esphomeTcp = + { ... }: + { + services.esphome = { + enable = true; + port = testPort; + address = "0.0.0.0"; + openFirewall = true; + }; }; - }; - esphomeUnix = { ... }: - { - services.esphome = { - enable = true; - enableUnixSocket = true; + esphomeUnix = + { ... }: + { + services.esphome = { + enable = true; + enableUnixSocket = true; + }; }; - }; - }; + }; - testScript = '' - esphomeTcp.wait_for_unit("esphome.service") - esphomeTcp.wait_for_open_port(${toString testPort}) - esphomeTcp.succeed("curl --fail http://localhost:${toString testPort}/") + testScript = '' + esphomeTcp.wait_for_unit("esphome.service") + esphomeTcp.wait_for_open_port(${toString testPort}) + esphomeTcp.succeed("curl --fail http://localhost:${toString testPort}/") - esphomeUnix.wait_for_unit("esphome.service") - esphomeUnix.wait_for_file("${unixSocket}") - esphomeUnix.succeed("curl --fail --unix-socket ${unixSocket} http://localhost/") - ''; -}) + esphomeUnix.wait_for_unit("esphome.service") + esphomeUnix.wait_for_file("${unixSocket}") + esphomeUnix.succeed("curl --fail --unix-socket ${unixSocket} http://localhost/") + ''; + } +) diff --git a/nixos/tests/etcd/etcd-cluster.nix b/nixos/tests/etcd/etcd-cluster.nix index 734d56dbc2233a..7ab3e43425937b 100644 --- a/nixos/tests/etcd/etcd-cluster.nix +++ b/nixos/tests/etcd/etcd-cluster.nix @@ -1,157 +1,178 @@ # This test runs simple etcd cluster -import ../make-test-python.nix ({ pkgs, ... } : let - - runWithOpenSSL = file: cmd: pkgs.runCommand file { - buildInputs = [ pkgs.openssl ]; - } cmd; - - ca_key = runWithOpenSSL "ca-key.pem" "openssl genrsa -out $out 2048"; - ca_pem = runWithOpenSSL "ca.pem" '' - openssl req \ - -x509 -new -nodes -key ${ca_key} \ - -days 10000 -out $out -subj "/CN=etcd-ca" - ''; - etcd_key = runWithOpenSSL "etcd-key.pem" "openssl genrsa -out $out 2048"; - etcd_csr = runWithOpenSSL "etcd.csr" '' - openssl req \ - -new -key ${etcd_key} \ - -out $out -subj "/CN=etcd" \ - -config ${openssl_cnf} - ''; - etcd_cert = runWithOpenSSL "etcd.pem" '' - openssl x509 \ - -req -in ${etcd_csr} \ - -CA ${ca_pem} -CAkey ${ca_key} \ - -CAcreateserial -out $out \ - -days 365 -extensions v3_req \ - -extfile ${openssl_cnf} - ''; - - etcd_client_key = runWithOpenSSL "etcd-client-key.pem" - "openssl genrsa -out $out 2048"; - - etcd_client_csr = runWithOpenSSL "etcd-client-key.pem" '' - openssl req \ - -new -key ${etcd_client_key} \ - -out $out -subj "/CN=etcd-client" \ - -config ${client_openssl_cnf} - ''; - - etcd_client_cert = runWithOpenSSL "etcd-client.crt" '' - openssl x509 \ - -req -in ${etcd_client_csr} \ - -CA ${ca_pem} -CAkey ${ca_key} -CAcreateserial \ - -out $out -days 365 -extensions v3_req \ - -extfile ${client_openssl_cnf} - ''; - - openssl_cnf = pkgs.writeText "openssl.cnf" '' - ions = v3_req - distinguished_name = req_distinguished_name - [req_distinguished_name] - [ v3_req ] - basicConstraints = CA:FALSE - keyUsage = digitalSignature, keyEncipherment - extendedKeyUsage = serverAuth, clientAuth - subjectAltName = @alt_names - [alt_names] - DNS.1 = node1 - DNS.2 = node2 - DNS.3 = node3 - IP.1 = 127.0.0.1 - ''; - - client_openssl_cnf = pkgs.writeText "client-openssl.cnf" '' - ions = v3_req - distinguished_name = req_distinguished_name - [req_distinguished_name] - [ v3_req ] - basicConstraints = CA:FALSE - keyUsage = digitalSignature, keyEncipherment - extendedKeyUsage = clientAuth - ''; - - nodeConfig = { - services = { - etcd = { - enable = true; - keyFile = etcd_key; - certFile = etcd_cert; - trustedCaFile = ca_pem; - clientCertAuth = true; - listenClientUrls = ["https://127.0.0.1:2379"]; - listenPeerUrls = ["https://0.0.0.0:2380"]; +import ../make-test-python.nix ( + { pkgs, ... }: + let + + runWithOpenSSL = + file: cmd: + pkgs.runCommand file { + buildInputs = [ pkgs.openssl ]; + } cmd; + + ca_key = runWithOpenSSL "ca-key.pem" "openssl genrsa -out $out 2048"; + ca_pem = runWithOpenSSL "ca.pem" '' + openssl req \ + -x509 -new -nodes -key ${ca_key} \ + -days 10000 -out $out -subj "/CN=etcd-ca" + ''; + etcd_key = runWithOpenSSL "etcd-key.pem" "openssl genrsa -out $out 2048"; + etcd_csr = runWithOpenSSL "etcd.csr" '' + openssl req \ + -new -key ${etcd_key} \ + -out $out -subj "/CN=etcd" \ + -config ${openssl_cnf} + ''; + etcd_cert = runWithOpenSSL "etcd.pem" '' + openssl x509 \ + -req -in ${etcd_csr} \ + -CA ${ca_pem} -CAkey ${ca_key} \ + -CAcreateserial -out $out \ + -days 365 -extensions v3_req \ + -extfile ${openssl_cnf} + ''; + + etcd_client_key = runWithOpenSSL "etcd-client-key.pem" "openssl genrsa -out $out 2048"; + + etcd_client_csr = runWithOpenSSL "etcd-client-key.pem" '' + openssl req \ + -new -key ${etcd_client_key} \ + -out $out -subj "/CN=etcd-client" \ + -config ${client_openssl_cnf} + ''; + + etcd_client_cert = runWithOpenSSL "etcd-client.crt" '' + openssl x509 \ + -req -in ${etcd_client_csr} \ + -CA ${ca_pem} -CAkey ${ca_key} -CAcreateserial \ + -out $out -days 365 -extensions v3_req \ + -extfile ${client_openssl_cnf} + ''; + + openssl_cnf = pkgs.writeText "openssl.cnf" '' + ions = v3_req + distinguished_name = req_distinguished_name + [req_distinguished_name] + [ v3_req ] + basicConstraints = CA:FALSE + keyUsage = digitalSignature, keyEncipherment + extendedKeyUsage = serverAuth, clientAuth + subjectAltName = @alt_names + [alt_names] + DNS.1 = node1 + DNS.2 = node2 + DNS.3 = node3 + IP.1 = 127.0.0.1 + ''; + + client_openssl_cnf = pkgs.writeText "client-openssl.cnf" '' + ions = v3_req + distinguished_name = req_distinguished_name + [req_distinguished_name] + [ v3_req ] + basicConstraints = CA:FALSE + keyUsage = digitalSignature, keyEncipherment + extendedKeyUsage = clientAuth + ''; + + nodeConfig = { + services = { + etcd = { + enable = true; + keyFile = etcd_key; + certFile = etcd_cert; + trustedCaFile = ca_pem; + clientCertAuth = true; + listenClientUrls = [ "https://127.0.0.1:2379" ]; + listenPeerUrls = [ "https://0.0.0.0:2380" ]; + }; }; - }; - - environment.variables = { - ETCD_CERT_FILE = "${etcd_client_cert}"; - ETCD_KEY_FILE = "${etcd_client_key}"; - ETCD_CA_FILE = "${ca_pem}"; - ETCDCTL_ENDPOINTS = "https://127.0.0.1:2379"; - ETCDCTL_CACERT = "${ca_pem}"; - ETCDCTL_CERT = "${etcd_cert}"; - ETCDCTL_KEY = "${etcd_key}"; - }; - networking.firewall.allowedTCPPorts = [ 2380 ]; - }; -in { - name = "etcd-cluster"; - - meta = with pkgs.lib.maintainers; { - maintainers = [ offline ]; - }; - - nodes = { - node1 = { ... }: { - require = [nodeConfig]; - services.etcd = { - initialCluster = ["node1=https://node1:2380" "node2=https://node2:2380"]; - initialAdvertisePeerUrls = ["https://node1:2380"]; + environment.variables = { + ETCD_CERT_FILE = "${etcd_client_cert}"; + ETCD_KEY_FILE = "${etcd_client_key}"; + ETCD_CA_FILE = "${ca_pem}"; + ETCDCTL_ENDPOINTS = "https://127.0.0.1:2379"; + ETCDCTL_CACERT = "${ca_pem}"; + ETCDCTL_CERT = "${etcd_cert}"; + ETCDCTL_KEY = "${etcd_key}"; }; + + networking.firewall.allowedTCPPorts = [ 2380 ]; }; + in + { + name = "etcd-cluster"; - node2 = { ... }: { - require = [nodeConfig]; - services.etcd = { - initialCluster = ["node1=https://node1:2380" "node2=https://node2:2380"]; - initialAdvertisePeerUrls = ["https://node2:2380"]; - }; + meta = with pkgs.lib.maintainers; { + maintainers = [ offline ]; }; - node3 = { ... }: { - require = [nodeConfig]; - services.etcd = { - initialCluster = ["node1=https://node1:2380" "node2=https://node2:2380" "node3=https://node3:2380"]; - initialAdvertisePeerUrls = ["https://node3:2380"]; - initialClusterState = "existing"; - }; + nodes = { + node1 = + { ... }: + { + require = [ nodeConfig ]; + services.etcd = { + initialCluster = [ + "node1=https://node1:2380" + "node2=https://node2:2380" + ]; + initialAdvertisePeerUrls = [ "https://node1:2380" ]; + }; + }; + + node2 = + { ... }: + { + require = [ nodeConfig ]; + services.etcd = { + initialCluster = [ + "node1=https://node1:2380" + "node2=https://node2:2380" + ]; + initialAdvertisePeerUrls = [ "https://node2:2380" ]; + }; + }; + + node3 = + { ... }: + { + require = [ nodeConfig ]; + services.etcd = { + initialCluster = [ + "node1=https://node1:2380" + "node2=https://node2:2380" + "node3=https://node3:2380" + ]; + initialAdvertisePeerUrls = [ "https://node3:2380" ]; + initialClusterState = "existing"; + }; + }; }; - }; - - testScript = '' - with subtest("should start etcd cluster"): - node1.start() - node2.start() - node1.wait_for_unit("etcd.service") - node2.wait_for_unit("etcd.service") - node2.wait_until_succeeds("etcdctl endpoint status") - node1.succeed("etcdctl put /foo/bar 'Hello world'") - node2.succeed("etcdctl get /foo/bar | grep 'Hello world'") - - with subtest("should add another member"): - node1.wait_until_succeeds("etcdctl member add node3 --peer-urls=https://node3:2380") - node3.start() - node3.wait_for_unit("etcd.service") - node3.wait_until_succeeds("etcdctl member list | grep 'node3'") - node3.succeed("etcdctl endpoint status") - - with subtest("should survive member crash"): - node3.crash() - node1.succeed("etcdctl endpoint status") - node1.succeed("etcdctl put /foo/bar 'Hello degraded world'") - node1.succeed("etcdctl get /foo/bar | grep 'Hello degraded world'") - ''; -}) + + testScript = '' + with subtest("should start etcd cluster"): + node1.start() + node2.start() + node1.wait_for_unit("etcd.service") + node2.wait_for_unit("etcd.service") + node2.wait_until_succeeds("etcdctl endpoint status") + node1.succeed("etcdctl put /foo/bar 'Hello world'") + node2.succeed("etcdctl get /foo/bar | grep 'Hello world'") + + with subtest("should add another member"): + node1.wait_until_succeeds("etcdctl member add node3 --peer-urls=https://node3:2380") + node3.start() + node3.wait_for_unit("etcd.service") + node3.wait_until_succeeds("etcdctl member list | grep 'node3'") + node3.succeed("etcdctl endpoint status") + + with subtest("should survive member crash"): + node3.crash() + node1.succeed("etcdctl endpoint status") + node1.succeed("etcdctl put /foo/bar 'Hello degraded world'") + node1.succeed("etcdctl get /foo/bar | grep 'Hello degraded world'") + ''; + } +) diff --git a/nixos/tests/etcd/etcd.nix b/nixos/tests/etcd/etcd.nix index 1ffa5b1009759b..74a46dddac44e8 100644 --- a/nixos/tests/etcd/etcd.nix +++ b/nixos/tests/etcd/etcd.nix @@ -1,25 +1,30 @@ # This test runs simple etcd node -import ../make-test-python.nix ({ pkgs, ... } : { - name = "etcd"; - meta = with pkgs.lib.maintainers; { - maintainers = [ offline ]; - }; +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "etcd"; + meta = with pkgs.lib.maintainers; { + maintainers = [ offline ]; + }; - nodes = { - node = { ... }: { - services.etcd.enable = true; + nodes = { + node = + { ... }: + { + services.etcd.enable = true; + }; }; - }; - testScript = '' - with subtest("should start etcd node"): - node.start() - node.wait_for_unit("etcd.service") - # Add additional wait for actual readiness - node.wait_until_succeeds("etcdctl endpoint health") + testScript = '' + with subtest("should start etcd node"): + node.start() + node.wait_for_unit("etcd.service") + # Add additional wait for actual readiness + node.wait_until_succeeds("etcdctl endpoint health") - with subtest("should write and read some values to etcd"): - node.succeed("etcdctl put /foo/bar 'Hello world'") - node.succeed("etcdctl get /foo/bar | grep 'Hello world'") - ''; -}) + with subtest("should write and read some values to etcd"): + node.succeed("etcdctl put /foo/bar 'Hello world'") + node.succeed("etcdctl get /foo/bar | grep 'Hello world'") + ''; + } +) diff --git a/nixos/tests/etebase-server.nix b/nixos/tests/etebase-server.nix index 49bfccf359e2a1..110338ef8915f4 100644 --- a/nixos/tests/etebase-server.nix +++ b/nixos/tests/etebase-server.nix @@ -1,21 +1,23 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -let - dataDir = "/var/lib/foobar"; + let + dataDir = "/var/lib/foobar"; -in { + in + { name = "etebase-server"; meta = with pkgs.lib.maintainers; { maintainers = [ felschr ]; }; - nodes.machine = { pkgs, ... }: + nodes.machine = + { pkgs, ... }: { services.etebase-server = { inherit dataDir; enable = true; - settings.global.secret_file = - toString (pkgs.writeText "secret" "123456"); + settings.global.secret_file = toString (pkgs.writeText "secret" "123456"); }; }; diff --git a/nixos/tests/etesync-dav.nix b/nixos/tests/etesync-dav.nix index f49152c60991f8..c8f86a84e371a4 100644 --- a/nixos/tests/etesync-dav.nix +++ b/nixos/tests/etesync-dav.nix @@ -1,16 +1,22 @@ -import ./make-test-python.nix ({ pkgs, ... }: { +import ./make-test-python.nix ( + { pkgs, ... }: + { - name = "etesync-dav"; - meta = with pkgs.lib.maintainers; { - maintainers = [ _3699n ]; - }; + name = "etesync-dav"; + meta = with pkgs.lib.maintainers; { + maintainers = [ _3699n ]; + }; - nodes.machine = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.curl pkgs.etesync-dav ]; - }; + nodes.machine = + { config, pkgs, ... }: + { + environment.systemPackages = [ + pkgs.curl + pkgs.etesync-dav + ]; + }; - testScript = - '' + testScript = '' machine.wait_for_unit("multi-user.target") machine.succeed("etesync-dav --version") machine.execute("etesync-dav >&2 &") @@ -18,4 +24,5 @@ import ./make-test-python.nix ({ pkgs, ... }: { with subtest("Check that the web interface is accessible"): assert "Add User" in machine.succeed("curl -s http://localhost:37358/.web/add/") ''; -}) + } +) diff --git a/nixos/tests/evcc.nix b/nixos/tests/evcc.nix index 7ebdc6a6f5ab98..1988ed3f1a9b36 100644 --- a/nixos/tests/evcc.nix +++ b/nixos/tests/evcc.nix @@ -1,96 +1,107 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : +import ./make-test-python.nix ( + { pkgs, lib, ... }: -{ - name = "evcc"; - meta.maintainers = with lib.maintainers; [ hexa ]; + { + name = "evcc"; + meta.maintainers = with lib.maintainers; [ hexa ]; - nodes = { - machine = { config, ... }: { - services.evcc = { - enable = true; - settings = { - network = { - schema = "http"; - host = "localhost"; - port = 7070; - }; + nodes = { + machine = + { config, ... }: + { + services.evcc = { + enable = true; + settings = { + network = { + schema = "http"; + host = "localhost"; + port = 7070; + }; - log = "info"; + log = "info"; - site = { - title = "NixOS Test"; - meters = { - grid = "grid"; - pv = "pv"; - }; - }; + site = { + title = "NixOS Test"; + meters = { + grid = "grid"; + pv = "pv"; + }; + }; - meters = [ { - type = "custom"; - name = "grid"; - power = { - source = "script"; - cmd = "/bin/sh -c 'echo -4500'"; - }; - } { - type = "custom"; - name = "pv"; - power = { - source = "script"; - cmd = "/bin/sh -c 'echo 7500'"; - }; - } ]; + meters = [ + { + type = "custom"; + name = "grid"; + power = { + source = "script"; + cmd = "/bin/sh -c 'echo -4500'"; + }; + } + { + type = "custom"; + name = "pv"; + power = { + source = "script"; + cmd = "/bin/sh -c 'echo 7500'"; + }; + } + ]; - chargers = [ { - name = "dummy-charger"; - type = "custom"; - status = { - source = "script"; - cmd = "/bin/sh -c 'echo charger status A'"; - }; - enabled = { - source = "script"; - cmd = "/bin/sh -c 'echo charger enabled state false'"; - }; - enable = { - source = "script"; - cmd = "/bin/sh -c 'echo set charger enabled state true'"; - }; - maxcurrent = { - source = "script"; - cmd = "/bin/sh -c 'echo set charger max current 7200'"; - }; - } ]; + chargers = [ + { + name = "dummy-charger"; + type = "custom"; + status = { + source = "script"; + cmd = "/bin/sh -c 'echo charger status A'"; + }; + enabled = { + source = "script"; + cmd = "/bin/sh -c 'echo charger enabled state false'"; + }; + enable = { + source = "script"; + cmd = "/bin/sh -c 'echo set charger enabled state true'"; + }; + maxcurrent = { + source = "script"; + cmd = "/bin/sh -c 'echo set charger max current 7200'"; + }; + } + ]; - loadpoints = [ { - title = "Dummy"; - charger = "dummy-charger"; - } ]; + loadpoints = [ + { + title = "Dummy"; + charger = "dummy-charger"; + } + ]; + }; + }; }; - }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("evcc.service") - machine.wait_for_open_port(7070) + machine.wait_for_unit("evcc.service") + machine.wait_for_open_port(7070) - with subtest("Check package version propagates into frontend"): - machine.fail( - "curl --fail http://localhost:7070 | grep '0.0.1-alpha'" - ) - machine.succeed( - "curl --fail http://localhost:7070 | grep '${pkgs.evcc.version}'" - ) + with subtest("Check package version propagates into frontend"): + machine.fail( + "curl --fail http://localhost:7070 | grep '0.0.1-alpha'" + ) + machine.succeed( + "curl --fail http://localhost:7070 | grep '${pkgs.evcc.version}'" + ) - with subtest("Check journal for errors"): - _, output = machine.execute("journalctl -o cat -u evcc.service") - assert "FATAL" not in output + with subtest("Check journal for errors"): + _, output = machine.execute("journalctl -o cat -u evcc.service") + assert "FATAL" not in output - with subtest("Check systemd hardening"): - _, output = machine.execute("systemd-analyze security evcc.service | grep -v '✓'") - machine.log(output) - ''; -}) + with subtest("Check systemd hardening"): + _, output = machine.execute("systemd-analyze security evcc.service | grep -v '✓'") + machine.log(output) + ''; + } +) diff --git a/nixos/tests/fail2ban.nix b/nixos/tests/fail2ban.nix index c3708575b702bc..fc12b7aede5645 100644 --- a/nixos/tests/fail2ban.nix +++ b/nixos/tests/fail2ban.nix @@ -1,18 +1,21 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "fail2ban"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "fail2ban"; - nodes.machine = _: { - services.fail2ban = { - enable = true; - bantime-increment.enable = true; - }; + nodes.machine = _: { + services.fail2ban = { + enable = true; + bantime-increment.enable = true; + }; - services.openssh.enable = true; - }; + services.openssh.enable = true; + }; - testScript = '' - machine.wait_for_unit("multi-user.target") + testScript = '' + machine.wait_for_unit("multi-user.target") - machine.wait_for_unit("fail2ban") - ''; -}) + machine.wait_for_unit("fail2ban") + ''; + } +) diff --git a/nixos/tests/fakeroute.nix b/nixos/tests/fakeroute.nix index 37b174524ab816..24919d6b242c3e 100644 --- a/nixos/tests/fakeroute.nix +++ b/nixos/tests/fakeroute.nix @@ -1,22 +1,27 @@ -import ./make-test-python.nix ({ lib, pkgs, ...} : { - name = "fakeroute"; - meta.maintainers = with lib.maintainers; [ rnhmjoj ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "fakeroute"; + meta.maintainers = with lib.maintainers; [ rnhmjoj ]; - nodes.machine = { ... }: { - imports = [ ../modules/profiles/minimal.nix ]; - services.fakeroute.enable = true; - services.fakeroute.route = - [ "216.102.187.130" "4.0.1.122" - "198.116.142.34" "63.199.8.242" - ]; - environment.systemPackages = [ pkgs.traceroute ]; - }; + nodes.machine = + { ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; + services.fakeroute.enable = true; + services.fakeroute.route = [ + "216.102.187.130" + "4.0.1.122" + "198.116.142.34" + "63.199.8.242" + ]; + environment.systemPackages = [ pkgs.traceroute ]; + }; - testScript = - '' + testScript = '' start_all() machine.wait_for_unit("fakeroute.service") machine.succeed("traceroute 127.0.0.1 | grep -q 216.102.187.130") ''; -}) - + } +) diff --git a/nixos/tests/fancontrol.nix b/nixos/tests/fancontrol.nix index ecb93609744634..da2d5fbd840536 100644 --- a/nixos/tests/fancontrol.nix +++ b/nixos/tests/fancontrol.nix @@ -1,34 +1,39 @@ -import ./make-test-python.nix ({ pkgs, ... } : { - name = "fancontrol"; - meta = with pkgs.lib.maintainers; { - maintainers = [ evils ]; - }; - - nodes.machine = { ... }: { - imports = [ ../modules/profiles/minimal.nix ]; - hardware.fancontrol.enable = true; - hardware.fancontrol.config = '' - INTERVAL=42 - DEVPATH=hwmon1=devices/platform/dummy - DEVNAME=hwmon1=dummy - FCTEMPS=hwmon1/device/pwm1=hwmon1/device/temp1_input - FCFANS=hwmon1/device/pwm1=hwmon1/device/fan1_input - MINTEMP=hwmon1/device/pwm1=25 - MAXTEMP=hwmon1/device/pwm1=65 - MINSTART=hwmon1/device/pwm1=150 - MINSTOP=hwmon1/device/pwm1=0 - ''; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "fancontrol"; + meta = with pkgs.lib.maintainers; { + maintainers = [ evils ]; }; - # This configuration cannot be valid for the test VM, so it's expected to get an 'outdated' error. - testScript = '' - start_all() - # can't wait for unit fancontrol.service because it doesn't become active due to invalid config - # fancontrol.service is WantedBy multi-user.target - machine.wait_for_unit("multi-user.target") - machine.succeed( - "journalctl -eu fancontrol | tee /dev/stderr | grep 'Configuration appears to be outdated'" - ) - machine.shutdown() - ''; -}) + nodes.machine = + { ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; + hardware.fancontrol.enable = true; + hardware.fancontrol.config = '' + INTERVAL=42 + DEVPATH=hwmon1=devices/platform/dummy + DEVNAME=hwmon1=dummy + FCTEMPS=hwmon1/device/pwm1=hwmon1/device/temp1_input + FCFANS=hwmon1/device/pwm1=hwmon1/device/fan1_input + MINTEMP=hwmon1/device/pwm1=25 + MAXTEMP=hwmon1/device/pwm1=65 + MINSTART=hwmon1/device/pwm1=150 + MINSTOP=hwmon1/device/pwm1=0 + ''; + }; + + # This configuration cannot be valid for the test VM, so it's expected to get an 'outdated' error. + testScript = '' + start_all() + # can't wait for unit fancontrol.service because it doesn't become active due to invalid config + # fancontrol.service is WantedBy multi-user.target + machine.wait_for_unit("multi-user.target") + machine.succeed( + "journalctl -eu fancontrol | tee /dev/stderr | grep 'Configuration appears to be outdated'" + ) + machine.shutdown() + ''; + } +) diff --git a/nixos/tests/fanout.nix b/nixos/tests/fanout.nix index c36d34dcce0bed..a6ee1b8120b646 100644 --- a/nixos/tests/fanout.nix +++ b/nixos/tests/fanout.nix @@ -1,30 +1,38 @@ -{ system ? builtins.currentSystem -, config ? {} -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: -import ./make-test-python.nix ({lib, pkgs, ...}: { - name = "fanout"; - meta.maintainers = [ lib.maintainers.therishidesai ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "fanout"; + meta.maintainers = [ lib.maintainers.therishidesai ]; - nodes = let - cfg = { ... }: { - services.fanout = { - enable = true; - fanoutDevices = 2; - bufferSize = 8192; + nodes = + let + cfg = + { ... }: + { + services.fanout = { + enable = true; + fanoutDevices = 2; + bufferSize = 8192; + }; + }; + in + { + machine = cfg; }; - }; - in { - machine = cfg; - }; - testScript = '' - start_all() + testScript = '' + start_all() - # mDNS. - machine.wait_for_unit("multi-user.target") + # mDNS. + machine.wait_for_unit("multi-user.target") - machine.succeed("test -c /dev/fanout0") - machine.succeed("test -c /dev/fanout1") - ''; -}) + machine.succeed("test -c /dev/fanout0") + machine.succeed("test -c /dev/fanout1") + ''; + } +) diff --git a/nixos/tests/fastnetmon-advanced.nix b/nixos/tests/fastnetmon-advanced.nix index b2d2713a921103..1582280cb5df81 100644 --- a/nixos/tests/fastnetmon-advanced.nix +++ b/nixos/tests/fastnetmon-advanced.nix @@ -5,61 +5,67 @@ meta.maintainers = lib.teams.wdz.members; nodes = { - bird = { ... }: { - networking.firewall.allowedTCPPorts = [ 179 ]; - services.bird2 = { - enable = true; - config = '' - router id 192.168.1.1; + bird = + { ... }: + { + networking.firewall.allowedTCPPorts = [ 179 ]; + services.bird2 = { + enable = true; + config = '' + router id 192.168.1.1; - protocol bgp fnm { - local 192.168.1.1 as 64513; - neighbor 192.168.1.2 as 64514; - multihop; - ipv4 { - import all; - export none; - }; - } - ''; - }; - }; - fnm = { ... }: { - networking.firewall.allowedTCPPorts = [ 179 ]; - services.fastnetmon-advanced = { - enable = true; - settings = { - networks_list = [ "172.23.42.0/24" ]; - gobgp = true; - gobgp_flow_spec_announces = true; + protocol bgp fnm { + local 192.168.1.1 as 64513; + neighbor 192.168.1.2 as 64514; + multihop; + ipv4 { + import all; + export none; + }; + } + ''; }; - bgpPeers = { - bird = { - local_asn = 64514; - remote_asn = 64513; - local_address = "192.168.1.2"; - remote_address = "192.168.1.1"; + }; + fnm = + { ... }: + { + networking.firewall.allowedTCPPorts = [ 179 ]; + services.fastnetmon-advanced = { + enable = true; + settings = { + networks_list = [ "172.23.42.0/24" ]; + gobgp = true; + gobgp_flow_spec_announces = true; + }; + bgpPeers = { + bird = { + local_asn = 64514; + remote_asn = 64513; + local_address = "192.168.1.2"; + remote_address = "192.168.1.1"; - description = "Bird"; - ipv4_unicast = true; - multihop = true; - active = true; + description = "Bird"; + ipv4_unicast = true; + multihop = true; + active = true; + }; }; }; }; - }; }; - testScript = { nodes, ... }: '' - start_all() - fnm.wait_for_unit("fastnetmon.service") - bird.wait_for_unit("bird2.service") + testScript = + { nodes, ... }: + '' + start_all() + fnm.wait_for_unit("fastnetmon.service") + bird.wait_for_unit("bird2.service") - fnm.wait_until_succeeds('journalctl -eu fastnetmon.service | grep "BGP daemon restarted correctly"') - fnm.wait_until_succeeds("journalctl -eu gobgp.service | grep BGP_FSM_OPENCONFIRM") - bird.wait_until_succeeds("birdc show protocol fnm | grep Estab") - fnm.wait_until_succeeds('journalctl -eu fastnetmon.service | grep "API server listening"') - fnm.succeed("fcli set blackhole 172.23.42.123") - bird.succeed("birdc show route | grep 172.23.42.123") - ''; + fnm.wait_until_succeeds('journalctl -eu fastnetmon.service | grep "BGP daemon restarted correctly"') + fnm.wait_until_succeeds("journalctl -eu gobgp.service | grep BGP_FSM_OPENCONFIRM") + bird.wait_until_succeeds("birdc show protocol fnm | grep Estab") + fnm.wait_until_succeeds('journalctl -eu fastnetmon.service | grep "API server listening"') + fnm.succeed("fcli set blackhole 172.23.42.123") + bird.succeed("birdc show route | grep 172.23.42.123") + ''; } diff --git a/nixos/tests/fenics.nix b/nixos/tests/fenics.nix index 1d182cfc449982..593b3953ffa929 100644 --- a/nixos/tests/fenics.nix +++ b/nixos/tests/fenics.nix @@ -1,49 +1,53 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -let - fenicsScript = pkgs.writeScript "poisson.py" '' - #!/usr/bin/env python - from dolfin import * + let + fenicsScript = pkgs.writeScript "poisson.py" '' + #!/usr/bin/env python + from dolfin import * - mesh = UnitSquareMesh(4, 4) - V = FunctionSpace(mesh, "Lagrange", 1) + mesh = UnitSquareMesh(4, 4) + V = FunctionSpace(mesh, "Lagrange", 1) - def boundary(x): - return x[0] < DOLFIN_EPS or x[0] > 1.0 - DOLFIN_EPS + def boundary(x): + return x[0] < DOLFIN_EPS or x[0] > 1.0 - DOLFIN_EPS - u0 = Constant(0.0) - bc = DirichletBC(V, u0, boundary) + u0 = Constant(0.0) + bc = DirichletBC(V, u0, boundary) - u = TrialFunction(V) - v = TestFunction(V) - f = Expression("10*exp(-(pow(x[0] - 0.5, 2) + pow(x[1] - 0.5, 2)) / 0.02)", degree=2) - g = Expression("sin(5*x[0])", degree=2) - a = inner(grad(u), grad(v))*dx - L = f*v*dx + g*v*ds + u = TrialFunction(V) + v = TestFunction(V) + f = Expression("10*exp(-(pow(x[0] - 0.5, 2) + pow(x[1] - 0.5, 2)) / 0.02)", degree=2) + g = Expression("sin(5*x[0])", degree=2) + a = inner(grad(u), grad(v))*dx + L = f*v*dx + g*v*ds - u = Function(V) - solve(a == L, u, bc) - print(u) - ''; -in -{ - name = "fenics"; - meta = { - maintainers = with pkgs.lib.maintainers; [ knedlsepp ]; - }; + u = Function(V) + solve(a == L, u, bc) + print(u) + ''; + in + { + name = "fenics"; + meta = { + maintainers = with pkgs.lib.maintainers; [ knedlsepp ]; + }; - nodes = { - fenicsnode = { pkgs, ... }: { - environment.systemPackages = with pkgs; [ - gcc - (python3.withPackages (ps: with ps; [ fenics ])) - ]; + nodes = { + fenicsnode = + { pkgs, ... }: + { + environment.systemPackages = with pkgs; [ + gcc + (python3.withPackages (ps: with ps; [ fenics ])) + ]; + }; }; - }; - testScript = - { nodes, ... }: - '' - start_all() - fenicsnode.succeed("${fenicsScript}") - ''; -}) + testScript = + { nodes, ... }: + '' + start_all() + fenicsnode.succeed("${fenicsScript}") + ''; + } +) diff --git a/nixos/tests/ferm.nix b/nixos/tests/ferm.nix index 87c67ac623479e..b0a3a828384b3b 100644 --- a/nixos/tests/ferm.nix +++ b/nixos/tests/ferm.nix @@ -1,21 +1,32 @@ +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "ferm"; + meta = with pkgs.lib.maintainers; { + maintainers = [ mic92 ]; + }; -import ./make-test-python.nix ({ pkgs, ...} : { - name = "ferm"; - meta = with pkgs.lib.maintainers; { - maintainers = [ mic92 ]; - }; - - nodes = - { client = + nodes = { + client = { pkgs, ... }: with pkgs.lib; { networking = { dhcpcd.enable = false; - interfaces.eth1.ipv6.addresses = mkOverride 0 [ { address = "fd00::2"; prefixLength = 64; } ]; - interfaces.eth1.ipv4.addresses = mkOverride 0 [ { address = "192.168.1.2"; prefixLength = 24; } ]; + interfaces.eth1.ipv6.addresses = mkOverride 0 [ + { + address = "fd00::2"; + prefixLength = 64; + } + ]; + interfaces.eth1.ipv4.addresses = mkOverride 0 [ + { + address = "192.168.1.2"; + prefixLength = 24; + } + ]; }; - }; + }; server = { pkgs, ... }: with pkgs.lib; @@ -24,8 +35,18 @@ import ./make-test-python.nix ({ pkgs, ...} : { dhcpcd.enable = false; useNetworkd = true; useDHCP = false; - interfaces.eth1.ipv6.addresses = mkOverride 0 [ { address = "fd00::1"; prefixLength = 64; } ]; - interfaces.eth1.ipv4.addresses = mkOverride 0 [ { address = "192.168.1.1"; prefixLength = 24; } ]; + interfaces.eth1.ipv6.addresses = mkOverride 0 [ + { + address = "fd00::1"; + prefixLength = 64; + } + ]; + interfaces.eth1.ipv4.addresses = mkOverride 0 [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; }; services = { @@ -51,8 +72,7 @@ import ./make-test-python.nix ({ pkgs, ...} : { }; }; - testScript = - '' + testScript = '' start_all() client.systemctl("start network-online.target") @@ -74,4 +94,5 @@ import ./make-test-python.nix ({ pkgs, ...} : { client.fail("curl --fail -g http://192.168.1.1:8080/status") client.fail("curl --fail -g http://[fd00::1]:8080/status") ''; -}) + } +) diff --git a/nixos/tests/filesender.nix b/nixos/tests/filesender.nix index 346e315956fb9a..5c4c1a738243a4 100644 --- a/nixos/tests/filesender.nix +++ b/nixos/tests/filesender.nix @@ -1,137 +1,148 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "filesender"; - meta = { - maintainers = with lib.maintainers; [ nhnn ]; - broken = pkgs.stdenv.hostPlatform.isAarch64; # selenium.common.exceptions.WebDriverException: Message: Unsupported platform/architecture combination: linux/aarch64 - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "filesender"; + meta = { + maintainers = with lib.maintainers; [ nhnn ]; + broken = pkgs.stdenv.hostPlatform.isAarch64; # selenium.common.exceptions.WebDriverException: Message: Unsupported platform/architecture combination: linux/aarch64 + }; - nodes.filesender = { ... }: let - format = pkgs.formats.php { }; - in { - networking.firewall.allowedTCPPorts = [ 80 ]; + nodes.filesender = + { ... }: + let + format = pkgs.formats.php { }; + in + { + networking.firewall.allowedTCPPorts = [ 80 ]; - services.filesender.enable = true; - services.filesender.localDomain = "filesender"; - services.filesender.settings = { - auth_sp_saml_authentication_source = "default"; - auth_sp_saml_uid_attribute = "uid"; - storage_filesystem_path = "/tmp"; - site_url = "http://filesender"; - force_ssl = false; - admin = ""; - admin_email = "admin@localhost"; - email_reply_to = "noreply@localhost"; - }; - services.simplesamlphp.filesender = { - settings = { - baseurlpath = "http://filesender/saml"; - "module.enable".exampleauth = true; - }; - authSources = { - admin = [ "core:AdminPassword" ]; - default = format.lib.mkMixedArray [ "exampleauth:UserPass" ] { - "user:password" = { - uid = [ "user" ]; - cn = [ "user" ]; - mail = [ "user@nixos.org" ]; + services.filesender.enable = true; + services.filesender.localDomain = "filesender"; + services.filesender.settings = { + auth_sp_saml_authentication_source = "default"; + auth_sp_saml_uid_attribute = "uid"; + storage_filesystem_path = "/tmp"; + site_url = "http://filesender"; + force_ssl = false; + admin = ""; + admin_email = "admin@localhost"; + email_reply_to = "noreply@localhost"; + }; + services.simplesamlphp.filesender = { + settings = { + baseurlpath = "http://filesender/saml"; + "module.enable".exampleauth = true; + }; + authSources = { + admin = [ "core:AdminPassword" ]; + default = format.lib.mkMixedArray [ "exampleauth:UserPass" ] { + "user:password" = { + uid = [ "user" ]; + cn = [ "user" ]; + mail = [ "user@nixos.org" ]; + }; + }; }; }; }; - }; - }; - nodes.client = - { pkgs - , nodes - , ... - }: - let - filesenderIP = (builtins.head (nodes.filesender.networking.interfaces.eth1.ipv4.addresses)).address; - in - { - networking.hosts.${filesenderIP} = [ "filesender" ]; + nodes.client = + { + pkgs, + nodes, + ... + }: + let + filesenderIP = (builtins.head (nodes.filesender.networking.interfaces.eth1.ipv4.addresses)).address; + in + { + networking.hosts.${filesenderIP} = [ "filesender" ]; - environment.systemPackages = - let - username = "user"; - password = "password"; - browser-test = - pkgs.writers.writePython3Bin "browser-test" - { - libraries = [ pkgs.python3Packages.selenium ]; - flakeIgnore = [ "E124" "E501" ]; - } '' - from selenium.webdriver.common.by import By - from selenium.webdriver import Firefox - from selenium.webdriver.firefox.options import Options - from selenium.webdriver.firefox.firefox_profile import FirefoxProfile - from selenium.webdriver.firefox.service import Service - from selenium.webdriver.support.ui import WebDriverWait - from selenium.webdriver.support import expected_conditions as EC - from subprocess import STDOUT - import string - import random - import logging - import time - selenium_logger = logging.getLogger("selenium") - selenium_logger.setLevel(logging.DEBUG) - selenium_logger.addHandler(logging.StreamHandler()) - profile = FirefoxProfile() - profile.set_preference("browser.download.folderList", 2) - profile.set_preference("browser.download.manager.showWhenStarting", False) - profile.set_preference("browser.download.dir", "/tmp/firefox") - profile.set_preference("browser.helperApps.neverAsk.saveToDisk", "text/plain;text/txt") - options = Options() - options.profile = profile - options.add_argument('--headless') - service = Service(log_output=STDOUT) - driver = Firefox(options=options) - driver.set_window_size(1024, 768) - driver.implicitly_wait(30) - driver.get('http://filesender/') - wait = WebDriverWait(driver, 20) - wait.until(EC.title_contains("FileSender")) - driver.find_element(By.ID, "btn_logon").click() - wait.until(EC.title_contains("Enter your username and password")) - driver.find_element(By.ID, 'username').send_keys( - '${username}' - ) - driver.find_element(By.ID, 'password').send_keys( - '${password}' - ) - driver.find_element(By.ID, "submit_button").click() - wait.until(EC.title_contains("FileSender")) - wait.until(EC.presence_of_element_located((By.ID, "topmenu_logoff"))) - test_string = "".join(random.choices(string.ascii_uppercase + string.digits, k=20)) - with open("/tmp/test_file.txt", "w") as file: - file.write(test_string) - driver.find_element(By.ID, "files").send_keys("/tmp/test_file.txt") - time.sleep(2) - driver.find_element(By.CSS_SELECTOR, '.start').click() - wait.until(EC.presence_of_element_located((By.CSS_SELECTOR, ".download_link"))) - download_link = driver.find_element(By.CSS_SELECTOR, '.download_link > textarea').get_attribute('value').strip() - driver.get(download_link) - wait.until(EC.presence_of_element_located((By.CSS_SELECTOR, ".download"))) - driver.find_element(By.CSS_SELECTOR, '.download').click() - wait.until(EC.presence_of_element_located((By.CSS_SELECTOR, ".ui-dialog-buttonset > button:nth-child(2)"))) - driver.find_element(By.CSS_SELECTOR, ".ui-dialog-buttonset > button:nth-child(2)").click() - driver.close() - driver.quit() - ''; - in - [ - pkgs.firefox-unwrapped - pkgs.geckodriver - browser-test - ]; - }; + environment.systemPackages = + let + username = "user"; + password = "password"; + browser-test = + pkgs.writers.writePython3Bin "browser-test" + { + libraries = [ pkgs.python3Packages.selenium ]; + flakeIgnore = [ + "E124" + "E501" + ]; + } + '' + from selenium.webdriver.common.by import By + from selenium.webdriver import Firefox + from selenium.webdriver.firefox.options import Options + from selenium.webdriver.firefox.firefox_profile import FirefoxProfile + from selenium.webdriver.firefox.service import Service + from selenium.webdriver.support.ui import WebDriverWait + from selenium.webdriver.support import expected_conditions as EC + from subprocess import STDOUT + import string + import random + import logging + import time + selenium_logger = logging.getLogger("selenium") + selenium_logger.setLevel(logging.DEBUG) + selenium_logger.addHandler(logging.StreamHandler()) + profile = FirefoxProfile() + profile.set_preference("browser.download.folderList", 2) + profile.set_preference("browser.download.manager.showWhenStarting", False) + profile.set_preference("browser.download.dir", "/tmp/firefox") + profile.set_preference("browser.helperApps.neverAsk.saveToDisk", "text/plain;text/txt") + options = Options() + options.profile = profile + options.add_argument('--headless') + service = Service(log_output=STDOUT) + driver = Firefox(options=options) + driver.set_window_size(1024, 768) + driver.implicitly_wait(30) + driver.get('http://filesender/') + wait = WebDriverWait(driver, 20) + wait.until(EC.title_contains("FileSender")) + driver.find_element(By.ID, "btn_logon").click() + wait.until(EC.title_contains("Enter your username and password")) + driver.find_element(By.ID, 'username').send_keys( + '${username}' + ) + driver.find_element(By.ID, 'password').send_keys( + '${password}' + ) + driver.find_element(By.ID, "submit_button").click() + wait.until(EC.title_contains("FileSender")) + wait.until(EC.presence_of_element_located((By.ID, "topmenu_logoff"))) + test_string = "".join(random.choices(string.ascii_uppercase + string.digits, k=20)) + with open("/tmp/test_file.txt", "w") as file: + file.write(test_string) + driver.find_element(By.ID, "files").send_keys("/tmp/test_file.txt") + time.sleep(2) + driver.find_element(By.CSS_SELECTOR, '.start').click() + wait.until(EC.presence_of_element_located((By.CSS_SELECTOR, ".download_link"))) + download_link = driver.find_element(By.CSS_SELECTOR, '.download_link > textarea').get_attribute('value').strip() + driver.get(download_link) + wait.until(EC.presence_of_element_located((By.CSS_SELECTOR, ".download"))) + driver.find_element(By.CSS_SELECTOR, '.download').click() + wait.until(EC.presence_of_element_located((By.CSS_SELECTOR, ".ui-dialog-buttonset > button:nth-child(2)"))) + driver.find_element(By.CSS_SELECTOR, ".ui-dialog-buttonset > button:nth-child(2)").click() + driver.close() + driver.quit() + ''; + in + [ + pkgs.firefox-unwrapped + pkgs.geckodriver + browser-test + ]; + }; - testScript = '' - start_all() - filesender.wait_for_file("/run/phpfpm/filesender.sock") - filesender.wait_for_open_port(80) - if "If you have received an invitation to access this site as a guest" not in client.wait_until_succeeds("curl -sS -f http://filesender"): - raise Exception("filesender returned invalid html") - client.succeed("browser-test") - ''; -}) + testScript = '' + start_all() + filesender.wait_for_file("/run/phpfpm/filesender.sock") + filesender.wait_for_open_port(80) + if "If you have received an invitation to access this site as a guest" not in client.wait_until_succeeds("curl -sS -f http://filesender"): + raise Exception("filesender returned invalid html") + client.succeed("browser-test") + ''; + } +) diff --git a/nixos/tests/firefly-iii.nix b/nixos/tests/firefly-iii.nix index f8e4ca4bfe2b4a..290d0771100256 100644 --- a/nixos/tests/firefly-iii.nix +++ b/nixos/tests/firefly-iii.nix @@ -1,111 +1,119 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -let - db-pass = "Test2Test2"; - app-key = "TestTestTestTestTestTestTestTest"; -in -{ - name = "firefly-iii"; - meta.maintainers = [ lib.maintainers.savyajha ]; + let + db-pass = "Test2Test2"; + app-key = "TestTestTestTestTestTestTestTest"; + in + { + name = "firefly-iii"; + meta.maintainers = [ lib.maintainers.savyajha ]; - nodes.fireflySqlite = { config, ... }: { - environment.etc = { - "firefly-iii-appkey".text = app-key; - }; - services.firefly-iii = { - enable = true; - enableNginx = true; - settings = { - APP_KEY_FILE = "/etc/firefly-iii-appkey"; - LOG_CHANNEL = "stdout"; - SITE_OWNER = "mail@example.com"; + nodes.fireflySqlite = + { config, ... }: + { + environment.etc = { + "firefly-iii-appkey".text = app-key; + }; + services.firefly-iii = { + enable = true; + enableNginx = true; + settings = { + APP_KEY_FILE = "/etc/firefly-iii-appkey"; + LOG_CHANNEL = "stdout"; + SITE_OWNER = "mail@example.com"; + }; + }; }; - }; - }; - nodes.fireflyPostgresql = { config, pkgs, ... }: { - environment.etc = { - "firefly-iii-appkey".text = app-key; - "postgres-pass".text = db-pass; - }; - services.firefly-iii = { - enable = true; - enableNginx = true; - settings = { - APP_KEY_FILE = "/etc/firefly-iii-appkey"; - LOG_CHANNEL = "stdout"; - SITE_OWNER = "mail@example.com"; - DB_CONNECTION = "pgsql"; - DB_DATABASE = "firefly"; - DB_USERNAME = "firefly"; - DB_PASSWORD_FILE = "/etc/postgres-pass"; - PGSQL_SCHEMA = "firefly"; + nodes.fireflyPostgresql = + { config, pkgs, ... }: + { + environment.etc = { + "firefly-iii-appkey".text = app-key; + "postgres-pass".text = db-pass; + }; + services.firefly-iii = { + enable = true; + enableNginx = true; + settings = { + APP_KEY_FILE = "/etc/firefly-iii-appkey"; + LOG_CHANNEL = "stdout"; + SITE_OWNER = "mail@example.com"; + DB_CONNECTION = "pgsql"; + DB_DATABASE = "firefly"; + DB_USERNAME = "firefly"; + DB_PASSWORD_FILE = "/etc/postgres-pass"; + PGSQL_SCHEMA = "firefly"; + }; + }; + + services.postgresql = { + enable = true; + package = pkgs.postgresql_16; + authentication = '' + local all postgres peer + local firefly firefly password + ''; + initialScript = pkgs.writeText "firefly-init.sql" '' + CREATE USER "firefly" WITH LOGIN PASSWORD '${db-pass}'; + CREATE DATABASE "firefly" WITH OWNER "firefly"; + \c firefly + CREATE SCHEMA AUTHORIZATION firefly; + ''; + }; }; - }; - services.postgresql = { - enable = true; - package = pkgs.postgresql_16; - authentication = '' - local all postgres peer - local firefly firefly password - ''; - initialScript = pkgs.writeText "firefly-init.sql" '' - CREATE USER "firefly" WITH LOGIN PASSWORD '${db-pass}'; - CREATE DATABASE "firefly" WITH OWNER "firefly"; - \c firefly - CREATE SCHEMA AUTHORIZATION firefly; - ''; - }; - }; + nodes.fireflyMysql = + { config, pkgs, ... }: + { + environment.etc = { + "firefly-iii-appkey".text = app-key; + "mysql-pass".text = db-pass; + }; + services.firefly-iii = { + enable = true; + enableNginx = true; + settings = { + APP_KEY_FILE = "/etc/firefly-iii-appkey"; + LOG_CHANNEL = "stdout"; + SITE_OWNER = "mail@example.com"; + DB_CONNECTION = "mysql"; + DB_DATABASE = "firefly"; + DB_USERNAME = "firefly"; + DB_PASSWORD_FILE = "/etc/mysql-pass"; + DB_SOCKET = "/run/mysqld/mysqld.sock"; + }; + }; - nodes.fireflyMysql = { config, pkgs, ... }: { - environment.etc = { - "firefly-iii-appkey".text = app-key; - "mysql-pass".text = db-pass; - }; - services.firefly-iii = { - enable = true; - enableNginx = true; - settings = { - APP_KEY_FILE = "/etc/firefly-iii-appkey"; - LOG_CHANNEL = "stdout"; - SITE_OWNER = "mail@example.com"; - DB_CONNECTION = "mysql"; - DB_DATABASE = "firefly"; - DB_USERNAME = "firefly"; - DB_PASSWORD_FILE = "/etc/mysql-pass"; - DB_SOCKET = "/run/mysqld/mysqld.sock"; + services.mysql = { + enable = true; + package = pkgs.mariadb; + initialScript = pkgs.writeText "firefly-init.sql" '' + create database firefly DEFAULT CHARACTER SET utf8mb4; + create user 'firefly'@'localhost' identified by '${db-pass}'; + grant all on firefly.* to 'firefly'@'localhost'; + ''; + settings.mysqld.character-set-server = "utf8mb4"; + }; }; - }; - - services.mysql = { - enable = true; - package = pkgs.mariadb; - initialScript = pkgs.writeText "firefly-init.sql" '' - create database firefly DEFAULT CHARACTER SET utf8mb4; - create user 'firefly'@'localhost' identified by '${db-pass}'; - grant all on firefly.* to 'firefly'@'localhost'; - ''; - settings.mysqld.character-set-server = "utf8mb4"; - }; - }; - testScript = '' - fireflySqlite.wait_for_unit("phpfpm-firefly-iii.service") - fireflySqlite.wait_for_unit("nginx.service") - fireflySqlite.succeed("curl -fvvv -Ls http://localhost/ | grep 'Firefly III'") - fireflySqlite.succeed("curl -fvvv -Ls http://localhost/v1/js/app.js") - fireflySqlite.succeed("systemctl start firefly-iii-cron.service") - fireflyPostgresql.wait_for_unit("phpfpm-firefly-iii.service") - fireflyPostgresql.wait_for_unit("nginx.service") - fireflyPostgresql.wait_for_unit("postgresql.service") - fireflyPostgresql.succeed("curl -fvvv -Ls http://localhost/ | grep 'Firefly III'") - fireflyPostgresql.succeed("systemctl start firefly-iii-cron.service") - fireflyMysql.wait_for_unit("phpfpm-firefly-iii.service") - fireflyMysql.wait_for_unit("nginx.service") - fireflyMysql.wait_for_unit("mysql.service") - fireflyMysql.succeed("curl -fvvv -Ls http://localhost/ | grep 'Firefly III'") - fireflyMysql.succeed("systemctl start firefly-iii-cron.service") - ''; -}) + testScript = '' + fireflySqlite.wait_for_unit("phpfpm-firefly-iii.service") + fireflySqlite.wait_for_unit("nginx.service") + fireflySqlite.succeed("curl -fvvv -Ls http://localhost/ | grep 'Firefly III'") + fireflySqlite.succeed("curl -fvvv -Ls http://localhost/v1/js/app.js") + fireflySqlite.succeed("systemctl start firefly-iii-cron.service") + fireflyPostgresql.wait_for_unit("phpfpm-firefly-iii.service") + fireflyPostgresql.wait_for_unit("nginx.service") + fireflyPostgresql.wait_for_unit("postgresql.service") + fireflyPostgresql.succeed("curl -fvvv -Ls http://localhost/ | grep 'Firefly III'") + fireflyPostgresql.succeed("systemctl start firefly-iii-cron.service") + fireflyMysql.wait_for_unit("phpfpm-firefly-iii.service") + fireflyMysql.wait_for_unit("nginx.service") + fireflyMysql.wait_for_unit("mysql.service") + fireflyMysql.succeed("curl -fvvv -Ls http://localhost/ | grep 'Firefly III'") + fireflyMysql.succeed("systemctl start firefly-iii-cron.service") + ''; + } +) diff --git a/nixos/tests/firefoxpwa.nix b/nixos/tests/firefoxpwa.nix index 374d67b01ac609..546534d1f05e8d 100644 --- a/nixos/tests/firefoxpwa.nix +++ b/nixos/tests/firefoxpwa.nix @@ -1,36 +1,41 @@ -import ./make-test-python.nix ({ lib, ... }: - -{ - name = "firefoxpwa"; - meta.maintainers = with lib.maintainers; [ camillemndn ]; - - nodes.machine = - { pkgs, ... }: - { - imports = [ ./common/x11.nix ]; - environment.systemPackages = with pkgs; [ firefoxpwa jq ]; - - programs.firefox = { - enable = true; - nativeMessagingHosts.packages = [ pkgs.firefoxpwa ]; +import ./make-test-python.nix ( + { lib, ... }: + + { + name = "firefoxpwa"; + meta.maintainers = with lib.maintainers; [ camillemndn ]; + + nodes.machine = + { pkgs, ... }: + { + imports = [ ./common/x11.nix ]; + environment.systemPackages = with pkgs; [ + firefoxpwa + jq + ]; + + programs.firefox = { + enable = true; + nativeMessagingHosts.packages = [ pkgs.firefoxpwa ]; + }; + + services.jellyfin.enable = true; }; - services.jellyfin.enable = true; - }; - - enableOCR = true; + enableOCR = true; - testScript = '' - machine.start() + testScript = '' + machine.start() - with subtest("Install a progressive web app"): - machine.wait_for_unit("jellyfin.service") - machine.wait_for_open_port(8096) - machine.succeed("firefoxpwa site install http://localhost:8096/web/manifest.json >&2") + with subtest("Install a progressive web app"): + machine.wait_for_unit("jellyfin.service") + machine.wait_for_open_port(8096) + machine.succeed("firefoxpwa site install http://localhost:8096/web/manifest.json >&2") - with subtest("Launch the progressive web app"): - machine.succeed("firefoxpwa site launch $(jq -r < ~/.local/share/firefoxpwa/config.json '.sites | keys[0]') >&2") - machine.wait_for_window("Jellyfin") - machine.wait_for_text("Jellyfin") - ''; -}) + with subtest("Launch the progressive web app"): + machine.succeed("firefoxpwa site launch $(jq -r < ~/.local/share/firefoxpwa/config.json '.sites | keys[0]') >&2") + machine.wait_for_window("Jellyfin") + machine.wait_for_text("Jellyfin") + ''; + } +) diff --git a/nixos/tests/firejail.nix b/nixos/tests/firejail.nix index 6c42c37b2813a9..24ec4dbe2a7e56 100644 --- a/nixos/tests/firejail.nix +++ b/nixos/tests/firejail.nix @@ -1,91 +1,95 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "firejail"; - meta = with pkgs.lib.maintainers; { - maintainers = [ sgo ]; - }; - - nodes.machine = { ... }: { - imports = [ ./common/user-account.nix ]; - - programs.firejail = { - enable = true; - wrappedBinaries = { - bash-jailed = "${pkgs.bash}/bin/bash"; - bash-jailed2 = { - executable = "${pkgs.bash}/bin/bash"; - extraArgs = [ "--private=~/firejail-home" ]; - }; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "firejail"; + meta = with pkgs.lib.maintainers; { + maintainers = [ sgo ]; }; - systemd.services.setupFirejailTest = { - wantedBy = [ "multi-user.target" ]; - before = [ "multi-user.target" ]; + nodes.machine = + { ... }: + { + imports = [ ./common/user-account.nix ]; + + programs.firejail = { + enable = true; + wrappedBinaries = { + bash-jailed = "${pkgs.bash}/bin/bash"; + bash-jailed2 = { + executable = "${pkgs.bash}/bin/bash"; + extraArgs = [ "--private=~/firejail-home" ]; + }; + }; + }; - environment = { - HOME = "/home/alice"; - }; + systemd.services.setupFirejailTest = { + wantedBy = [ "multi-user.target" ]; + before = [ "multi-user.target" ]; - unitConfig = { - type = "oneshot"; - RemainAfterExit = true; - user = "alice"; - }; + environment = { + HOME = "/home/alice"; + }; - script = '' - cd $HOME + unitConfig = { + type = "oneshot"; + RemainAfterExit = true; + user = "alice"; + }; - mkdir .password-store && echo s3cret > .password-store/secret - mkdir my-secrets && echo s3cret > my-secrets/secret + script = '' + cd $HOME - echo publ1c > public + mkdir .password-store && echo s3cret > .password-store/secret + mkdir my-secrets && echo s3cret > my-secrets/secret - mkdir -p .config/firejail - echo 'blacklist ''${HOME}/my-secrets' > .config/firejail/globals.local - ''; - }; - }; - - testScript = '' - start_all() - machine.wait_for_unit("multi-user.target") - - # Test path acl with wrapper - machine.succeed("sudo -u alice bash-jailed -c 'cat ~/public' | grep -q publ1c") - machine.fail( - "sudo -u alice bash-jailed -c 'cat ~/.password-store/secret' | grep -q s3cret" - ) - machine.fail("sudo -u alice bash-jailed -c 'cat ~/my-secrets/secret' | grep -q s3cret") - - # Test extraArgs - machine.succeed("sudo -u alice mkdir /home/alice/firejail-home") - machine.succeed("sudo -u alice bash-jailed2 -c 'echo test > /home/alice/foo'") - machine.fail("sudo -u alice cat /home/alice/foo") - machine.succeed("sudo -u alice cat /home/alice/firejail-home/foo | grep test") - - # Test path acl with firejail executable - machine.succeed("sudo -u alice firejail -- bash -c 'cat ~/public' | grep -q publ1c") - machine.fail( - "sudo -u alice firejail -- bash -c 'cat ~/.password-store/secret' | grep -q s3cret" - ) - machine.fail( - "sudo -u alice firejail -- bash -c 'cat ~/my-secrets/secret' | grep -q s3cret" - ) - - # Disabling profiles - machine.succeed( - "sudo -u alice bash -c 'firejail --noprofile -- cat ~/.password-store/secret' | grep -q s3cret" - ) - - # CVE-2020-17367 - machine.fail( - "sudo -u alice firejail --private-tmp id --output=/tmp/vuln1 && cat /tmp/vuln1" - ) - - # CVE-2020-17368 - machine.fail( - "sudo -u alice firejail --private-tmp --output=/tmp/foo 'bash -c $(id>/tmp/vuln2;echo id)' && cat /tmp/vuln2" - ) - ''; -}) + echo publ1c > public + + mkdir -p .config/firejail + echo 'blacklist ''${HOME}/my-secrets' > .config/firejail/globals.local + ''; + }; + }; + testScript = '' + start_all() + machine.wait_for_unit("multi-user.target") + + # Test path acl with wrapper + machine.succeed("sudo -u alice bash-jailed -c 'cat ~/public' | grep -q publ1c") + machine.fail( + "sudo -u alice bash-jailed -c 'cat ~/.password-store/secret' | grep -q s3cret" + ) + machine.fail("sudo -u alice bash-jailed -c 'cat ~/my-secrets/secret' | grep -q s3cret") + + # Test extraArgs + machine.succeed("sudo -u alice mkdir /home/alice/firejail-home") + machine.succeed("sudo -u alice bash-jailed2 -c 'echo test > /home/alice/foo'") + machine.fail("sudo -u alice cat /home/alice/foo") + machine.succeed("sudo -u alice cat /home/alice/firejail-home/foo | grep test") + + # Test path acl with firejail executable + machine.succeed("sudo -u alice firejail -- bash -c 'cat ~/public' | grep -q publ1c") + machine.fail( + "sudo -u alice firejail -- bash -c 'cat ~/.password-store/secret' | grep -q s3cret" + ) + machine.fail( + "sudo -u alice firejail -- bash -c 'cat ~/my-secrets/secret' | grep -q s3cret" + ) + + # Disabling profiles + machine.succeed( + "sudo -u alice bash -c 'firejail --noprofile -- cat ~/.password-store/secret' | grep -q s3cret" + ) + + # CVE-2020-17367 + machine.fail( + "sudo -u alice firejail --private-tmp id --output=/tmp/vuln1 && cat /tmp/vuln1" + ) + + # CVE-2020-17368 + machine.fail( + "sudo -u alice firejail --private-tmp --output=/tmp/foo 'bash -c $(id>/tmp/vuln2;echo id)' && cat /tmp/vuln2" + ) + ''; + } +) diff --git a/nixos/tests/firewall.nix b/nixos/tests/firewall.nix index 89f4878fd47f22..378f9b6a7c86c6 100644 --- a/nixos/tests/firewall.nix +++ b/nixos/tests/firewall.nix @@ -1,31 +1,60 @@ # Test the firewall module. -import ./make-test-python.nix ( { pkgs, nftables, ... } : { - name = "firewall" + pkgs.lib.optionalString nftables "-nftables"; - meta = with pkgs.lib.maintainers; { - maintainers = [ rvfg garyguo ]; - }; +import ./make-test-python.nix ( + { pkgs, nftables, ... }: + { + name = "firewall" + pkgs.lib.optionalString nftables "-nftables"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + rvfg + garyguo + ]; + }; - nodes = - { walled = + nodes = { + walled = { ... }: - { networking.firewall = { + { + networking.firewall = { enable = true; logRefusedPackets = true; # Syntax smoke test, not actually verified otherwise - allowedTCPPorts = [ 25 993 8005 ]; + allowedTCPPorts = [ + 25 + 993 + 8005 + ]; allowedTCPPortRanges = [ - { from = 980; to = 1000; } - { from = 990; to = 1010; } - { from = 8000; to = 8010; } + { + from = 980; + to = 1000; + } + { + from = 990; + to = 1010; + } + { + from = 8000; + to = 8010; + } ]; interfaces.eth0 = { allowedTCPPorts = [ 10003 ]; - allowedTCPPortRanges = [ { from = 10000; to = 10005; } ]; + allowedTCPPortRanges = [ + { + from = 10000; + to = 10005; + } + ]; }; interfaces.eth3 = { allowedUDPPorts = [ 10003 ]; - allowedUDPPortRanges = [ { from = 10000; to = 10005; } ]; + allowedUDPPortRanges = [ + { + from = 10000; + to = 10005; + } + ]; }; }; networking.nftables.enable = nftables; @@ -39,47 +68,52 @@ import ./make-test-python.nix ( { pkgs, nftables, ... } : { attacker = { ... }: - { services.httpd.enable = true; + { + services.httpd.enable = true; services.httpd.adminAddr = "foo@example.org"; networking.firewall.enable = false; }; }; - testScript = { nodes, ... }: let - unit = if nftables then "nftables" else "firewall"; - in '' - start_all() + testScript = + { nodes, ... }: + let + unit = if nftables then "nftables" else "firewall"; + in + '' + start_all() - walled.wait_for_unit("${unit}") - walled.wait_for_unit("httpd") - attacker.wait_for_unit("network.target") + walled.wait_for_unit("${unit}") + walled.wait_for_unit("httpd") + attacker.wait_for_unit("network.target") - # Local connections should still work. - walled.succeed("curl -v http://localhost/ >&2") + # Local connections should still work. + walled.succeed("curl -v http://localhost/ >&2") - # Connections to the firewalled machine should fail, but ping should succeed. - attacker.fail("curl --fail --connect-timeout 2 http://walled/ >&2") - attacker.succeed("ping -c 1 walled >&2") + # Connections to the firewalled machine should fail, but ping should succeed. + attacker.fail("curl --fail --connect-timeout 2 http://walled/ >&2") + attacker.succeed("ping -c 1 walled >&2") - # Outgoing connections/pings should still work. - walled.succeed("curl -v http://attacker/ >&2") - walled.succeed("ping -c 1 attacker >&2") + # Outgoing connections/pings should still work. + walled.succeed("curl -v http://attacker/ >&2") + walled.succeed("ping -c 1 attacker >&2") - # Open tcp port 80 at runtime - walled.succeed("nixos-firewall-tool open tcp 80") - attacker.succeed("curl -v http://walled/ >&2") + # Open tcp port 80 at runtime + walled.succeed("nixos-firewall-tool open tcp 80") + attacker.succeed("curl -v http://walled/ >&2") - # Reset the firewall - walled.succeed("nixos-firewall-tool reset") - attacker.fail("curl --fail --connect-timeout 2 http://walled/ >&2") + # Reset the firewall + walled.succeed("nixos-firewall-tool reset") + attacker.fail("curl --fail --connect-timeout 2 http://walled/ >&2") - # If we stop the firewall, then connections should succeed. - walled.stop_job("${unit}") - attacker.succeed("curl -v http://walled/ >&2") + # If we stop the firewall, then connections should succeed. + walled.stop_job("${unit}") + attacker.succeed("curl -v http://walled/ >&2") - # Check whether activation of a new configuration reloads the firewall. - walled.succeed( - "/run/booted-system/specialisation/different-config/bin/switch-to-configuration test 2>&1 | grep -qF ${unit}.service" - ) - ''; -}) + # Check whether activation of a new configuration reloads the firewall. + walled.succeed( + "/run/booted-system/specialisation/different-config/bin/switch-to-configuration test 2>&1 | grep -qF ${unit}.service" + ) + ''; + } +) diff --git a/nixos/tests/fish.nix b/nixos/tests/fish.nix index c9a1bef51478e2..5a0c4143a4caa8 100644 --- a/nixos/tests/fish.nix +++ b/nixos/tests/fish.nix @@ -1,21 +1,22 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "fish"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "fish"; - nodes.machine = - { pkgs, ... }: + nodes.machine = + { pkgs, ... }: - { - programs.fish.enable = true; - environment.systemPackages = with pkgs; [ - coreutils - procps # kill collides with coreutils' to test https://github.com/NixOS/nixpkgs/issues/56432 - ]; - # TODO: remove if/when #267880 is merged and this is a default - services.logrotate.enable = false; - }; + { + programs.fish.enable = true; + environment.systemPackages = with pkgs; [ + coreutils + procps # kill collides with coreutils' to test https://github.com/NixOS/nixpkgs/issues/56432 + ]; + # TODO: remove if/when #267880 is merged and this is a default + services.logrotate.enable = false; + }; - testScript = - '' + testScript = '' start_all() machine.wait_for_file("/etc/fish/generated_completions/coreutils.fish") machine.wait_for_file("/etc/fish/generated_completions/kill.fish") @@ -23,4 +24,5 @@ import ./make-test-python.nix ({ pkgs, ... }: { "fish -ic 'echo $fish_complete_path' | grep -q '/share/fish/completions /etc/fish/generated_completions /root/.local/share/fish/generated_completions$'" ) ''; -}) + } +) diff --git a/nixos/tests/flannel.nix b/nixos/tests/flannel.nix index 7615732c20cac9..738558e64afca8 100644 --- a/nixos/tests/flannel.nix +++ b/nixos/tests/flannel.nix @@ -1,57 +1,66 @@ -import ./make-test-python.nix ({ lib, ...} : { - name = "flannel"; - - meta = with lib.maintainers; { - maintainers = [ offline ]; - }; - - nodes = let - flannelConfig = { pkgs, ... } : { - services.flannel = { - enable = true; - backend = { - Type = "udp"; - Port = 8285; - }; - network = "10.1.0.0/16"; - iface = "eth1"; - etcd.endpoints = ["http://etcd:2379"]; - }; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "flannel"; - networking.firewall.allowedUDPPorts = [ 8285 ]; + meta = with lib.maintainers; { + maintainers = [ offline ]; }; - in { - etcd = { ... }: { - services = { - etcd = { - enable = true; - listenClientUrls = ["http://0.0.0.0:2379"]; # requires ip-address for binding - listenPeerUrls = ["http://0.0.0.0:2380"]; # requires ip-address for binding - advertiseClientUrls = ["http://etcd:2379"]; - initialAdvertisePeerUrls = ["http://etcd:2379"]; - initialCluster = ["etcd=http://etcd:2379"]; - }; - }; - networking.firewall.allowedTCPPorts = [ 2379 ]; - }; + nodes = + let + flannelConfig = + { pkgs, ... }: + { + services.flannel = { + enable = true; + backend = { + Type = "udp"; + Port = 8285; + }; + network = "10.1.0.0/16"; + iface = "eth1"; + etcd.endpoints = [ "http://etcd:2379" ]; + }; - node1 = flannelConfig; - node2 = flannelConfig; - }; + networking.firewall.allowedUDPPorts = [ 8285 ]; + }; + in + { + etcd = + { ... }: + { + services = { + etcd = { + enable = true; + listenClientUrls = [ "http://0.0.0.0:2379" ]; # requires ip-address for binding + listenPeerUrls = [ "http://0.0.0.0:2380" ]; # requires ip-address for binding + advertiseClientUrls = [ "http://etcd:2379" ]; + initialAdvertisePeerUrls = [ "http://etcd:2379" ]; + initialCluster = [ "etcd=http://etcd:2379" ]; + }; + }; + + networking.firewall.allowedTCPPorts = [ 2379 ]; + }; + + node1 = flannelConfig; + node2 = flannelConfig; + }; - testScript = '' - start_all() + testScript = '' + start_all() - node1.wait_for_unit("flannel.service") - node2.wait_for_unit("flannel.service") + node1.wait_for_unit("flannel.service") + node2.wait_for_unit("flannel.service") - node1.wait_until_succeeds("ip l show dev flannel0") - ip1 = node1.succeed("ip -4 addr show flannel0 | grep -oP '(?<=inet).*(?=/)'") - node2.wait_until_succeeds("ip l show dev flannel0") - ip2 = node2.succeed("ip -4 addr show flannel0 | grep -oP '(?<=inet).*(?=/)'") + node1.wait_until_succeeds("ip l show dev flannel0") + ip1 = node1.succeed("ip -4 addr show flannel0 | grep -oP '(?<=inet).*(?=/)'") + node2.wait_until_succeeds("ip l show dev flannel0") + ip2 = node2.succeed("ip -4 addr show flannel0 | grep -oP '(?<=inet).*(?=/)'") - node1.wait_until_succeeds(f"ping -c 1 {ip2}") - node2.wait_until_succeeds(f"ping -c 1 {ip1}") - ''; -}) + node1.wait_until_succeeds(f"ping -c 1 {ip2}") + node2.wait_until_succeeds(f"ping -c 1 {ip1}") + ''; + } +) diff --git a/nixos/tests/flood.nix b/nixos/tests/flood.nix index 075d37e62835f4..ca3ef1d919a5bb 100644 --- a/nixos/tests/flood.nix +++ b/nixos/tests/flood.nix @@ -1,27 +1,32 @@ -import ./make-test-python.nix ({ pkgs, ... }: -let - port = 3001; -in -{ - name = "flood"; - meta = { - maintainers = with pkgs.lib.maintainers; [ thiagokokada ]; - }; - - nodes.machine = { pkgs, ... }: { - services.flood = { - inherit port; - enable = true; - openFirewall = true; - extraArgs = [ "--baseuri=/" ]; +import ./make-test-python.nix ( + { pkgs, ... }: + let + port = 3001; + in + { + name = "flood"; + meta = { + maintainers = with pkgs.lib.maintainers; [ thiagokokada ]; }; - }; - testScript = /* python */ '' - machine.start() - machine.wait_for_unit("flood.service") - machine.wait_for_open_port(${toString port}) + nodes.machine = + { pkgs, ... }: + { + services.flood = { + inherit port; + enable = true; + openFirewall = true; + extraArgs = [ "--baseuri=/" ]; + }; + }; + + testScript = # python + '' + machine.start() + machine.wait_for_unit("flood.service") + machine.wait_for_open_port(${toString port}) - machine.succeed("curl --fail http://localhost:${toString port}") - ''; -}) + machine.succeed("curl --fail http://localhost:${toString port}") + ''; + } +) diff --git a/nixos/tests/fluentd.nix b/nixos/tests/fluentd.nix index 150638f246f26d..aa56db49dc536a 100644 --- a/nixos/tests/fluentd.nix +++ b/nixos/tests/fluentd.nix @@ -1,49 +1,58 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "fluentd"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "fluentd"; - nodes.machine = { pkgs, ... }: { - services.fluentd = { - enable = true; - config = '' - - @type http - port 9880 - + nodes.machine = + { pkgs, ... }: + { + services.fluentd = { + enable = true; + config = '' + + @type http + port 9880 + - - type copy - - @type file - format json - path /tmp/fluentd - symlink_path /tmp/current-log - - - @type stdout - - - ''; - }; - }; + + type copy + + @type file + format json + path /tmp/fluentd + symlink_path /tmp/current-log + + + @type stdout + + + ''; + }; + }; - testScript = let - testMessage = "an example log message"; + testScript = + let + testMessage = "an example log message"; - payload = pkgs.writeText "test-message.json" (builtins.toJSON { - inherit testMessage; - }); - in '' - machine.start() - machine.wait_for_unit("fluentd.service") - machine.wait_for_open_port(9880) + payload = pkgs.writeText "test-message.json" ( + builtins.toJSON { + inherit testMessage; + } + ); + in + '' + machine.start() + machine.wait_for_unit("fluentd.service") + machine.wait_for_open_port(9880) - machine.succeed( - "curl -fsSL -X POST -H 'Content-type: application/json' -d @${payload} http://localhost:9880/test.tag" - ) + machine.succeed( + "curl -fsSL -X POST -H 'Content-type: application/json' -d @${payload} http://localhost:9880/test.tag" + ) - # blocking flush - machine.succeed("systemctl stop fluentd") + # blocking flush + machine.succeed("systemctl stop fluentd") - machine.succeed("grep '${testMessage}' /tmp/current-log") - ''; -}) + machine.succeed("grep '${testMessage}' /tmp/current-log") + ''; + } +) diff --git a/nixos/tests/fluidd.nix b/nixos/tests/fluidd.nix index 82a2c1e4049f3e..94463fc74e4907 100644 --- a/nixos/tests/fluidd.nix +++ b/nixos/tests/fluidd.nix @@ -1,19 +1,23 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "fluidd"; - meta.maintainers = with lib.maintainers; [ vtuan10 ]; + { + name = "fluidd"; + meta.maintainers = with lib.maintainers; [ vtuan10 ]; - nodes.machine = { pkgs, ... }: { - services.fluidd = { - enable = true; - }; - }; + nodes.machine = + { pkgs, ... }: + { + services.fluidd = { + enable = true; + }; + }; - testScript = '' - machine.start() - machine.wait_for_unit("nginx.service") - machine.wait_for_open_port(80) - machine.succeed("curl -sSfL http://localhost/ | grep 'fluidd'") - ''; -}) + testScript = '' + machine.start() + machine.wait_for_unit("nginx.service") + machine.wait_for_open_port(80) + machine.succeed("curl -sSfL http://localhost/ | grep 'fluidd'") + ''; + } +) diff --git a/nixos/tests/fontconfig-default-fonts.nix b/nixos/tests/fontconfig-default-fonts.nix index 293dc43f91f386..ce7f33201638ec 100644 --- a/nixos/tests/fontconfig-default-fonts.nix +++ b/nixos/tests/fontconfig-default-fonts.nix @@ -1,32 +1,36 @@ -import ./make-test-python.nix ({ lib, ... }: -{ - name = "fontconfig-default-fonts"; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "fontconfig-default-fonts"; - meta.maintainers = with lib.maintainers; [ - jtojnar - ]; - - nodes.machine = { config, pkgs, ... }: { - fonts.enableDefaultPackages = true; # Background fonts - fonts.packages = with pkgs; [ - noto-fonts-color-emoji - cantarell-fonts - twitter-color-emoji - source-code-pro - gentium + meta.maintainers = with lib.maintainers; [ + jtojnar ]; - fonts.fontconfig.defaultFonts = { - serif = [ "Gentium Plus" ]; - sansSerif = [ "Cantarell" ]; - monospace = [ "Source Code Pro" ]; - emoji = [ "Twitter Color Emoji" ]; - }; - }; - testScript = '' - machine.succeed("fc-match serif | grep '\"Gentium Plus\"'") - machine.succeed("fc-match sans-serif | grep '\"Cantarell\"'") - machine.succeed("fc-match monospace | grep '\"Source Code Pro\"'") - machine.succeed("fc-match emoji | grep '\"Twitter Color Emoji\"'") - ''; -}) + nodes.machine = + { config, pkgs, ... }: + { + fonts.enableDefaultPackages = true; # Background fonts + fonts.packages = with pkgs; [ + noto-fonts-color-emoji + cantarell-fonts + twitter-color-emoji + source-code-pro + gentium + ]; + fonts.fontconfig.defaultFonts = { + serif = [ "Gentium Plus" ]; + sansSerif = [ "Cantarell" ]; + monospace = [ "Source Code Pro" ]; + emoji = [ "Twitter Color Emoji" ]; + }; + }; + + testScript = '' + machine.succeed("fc-match serif | grep '\"Gentium Plus\"'") + machine.succeed("fc-match sans-serif | grep '\"Cantarell\"'") + machine.succeed("fc-match monospace | grep '\"Source Code Pro\"'") + machine.succeed("fc-match emoji | grep '\"Twitter Color Emoji\"'") + ''; + } +) diff --git a/nixos/tests/forgejo.nix b/nixos/tests/forgejo.nix index 5e6f19e56df05e..392b380b21c98e 100644 --- a/nixos/tests/forgejo.nix +++ b/nixos/tests/forgejo.nix @@ -1,7 +1,8 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../.. { inherit system config; } -, forgejoPackage ? pkgs.forgejo +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, + forgejoPackage ? pkgs.forgejo, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -44,225 +45,247 @@ let metricSecret = "fakesecret"; - supportedDbTypes = [ "mysql" "postgres" "sqlite3" ]; - makeForgejoTest = type: nameValuePair type (makeTest { - name = "forgejo-${type}"; - meta.maintainers = with maintainers; [ bendlas emilylange ]; - - nodes = { - server = { config, pkgs, ... }: { - virtualisation.memorySize = 2047; - services.forgejo = { - enable = true; - package = forgejoPackage; - database = { inherit type; }; - settings.service.DISABLE_REGISTRATION = true; - settings."repository.signing".SIGNING_KEY = signingPrivateKeyId; - settings.actions.ENABLED = true; - settings.repository = { - ENABLE_PUSH_CREATE_USER = true; - DEFAULT_PUSH_CREATE_PRIVATE = false; - }; - settings.metrics.ENABLED = true; - secrets.metrics.TOKEN = pkgs.writeText "metrics_secret" metricSecret; - }; - environment.systemPackages = [ config.services.forgejo.package pkgs.gnupg pkgs.jq pkgs.file pkgs.htmlq ]; - services.openssh.enable = true; - - specialisation.runner = { - inheritParentConfig = true; - configuration.services.gitea-actions-runner = { - package = pkgs.forgejo-runner; - instances."test" = { + supportedDbTypes = [ + "mysql" + "postgres" + "sqlite3" + ]; + makeForgejoTest = + type: + nameValuePair type (makeTest { + name = "forgejo-${type}"; + meta.maintainers = with maintainers; [ + bendlas + emilylange + ]; + + nodes = { + server = + { config, pkgs, ... }: + { + virtualisation.memorySize = 2047; + services.forgejo = { enable = true; - name = "ci"; - url = "http://localhost:3000"; - labels = [ - # type ":host" does not depend on docker/podman/lxc - "native:host" - ]; - tokenFile = "/var/lib/forgejo/runner_token"; + package = forgejoPackage; + database = { inherit type; }; + settings.service.DISABLE_REGISTRATION = true; + settings."repository.signing".SIGNING_KEY = signingPrivateKeyId; + settings.actions.ENABLED = true; + settings.repository = { + ENABLE_PUSH_CREATE_USER = true; + DEFAULT_PUSH_CREATE_PRIVATE = false; + }; + settings.metrics.ENABLED = true; + secrets.metrics.TOKEN = pkgs.writeText "metrics_secret" metricSecret; + }; + environment.systemPackages = [ + config.services.forgejo.package + pkgs.gnupg + pkgs.jq + pkgs.file + pkgs.htmlq + ]; + services.openssh.enable = true; + + specialisation.runner = { + inheritParentConfig = true; + configuration.services.gitea-actions-runner = { + package = pkgs.forgejo-runner; + instances."test" = { + enable = true; + name = "ci"; + url = "http://localhost:3000"; + labels = [ + # type ":host" does not depend on docker/podman/lxc + "native:host" + ]; + tokenFile = "/var/lib/forgejo/runner_token"; + }; + }; + }; + specialisation.dump = { + inheritParentConfig = true; + configuration.services.forgejo.dump = { + enable = true; + type = "tar.zst"; + file = "dump.tar.zst"; + }; }; }; - }; - specialisation.dump = { - inheritParentConfig = true; - configuration.services.forgejo.dump = { - enable = true; - type = "tar.zst"; - file = "dump.tar.zst"; + client = + { ... }: + { + programs.git = { + enable = true; + config = { + user.email = "test@localhost"; + user.name = "test"; + init.defaultBranch = "main"; + }; + }; + programs.ssh.extraConfig = '' + Host * + StrictHostKeyChecking no + IdentityFile ~/.ssh/privk + ''; }; - }; }; - client = { ... }: { - programs.git = { - enable = true; - config = { - user.email = "test@localhost"; - user.name = "test"; - init.defaultBranch = "main"; - }; - }; - programs.ssh.extraConfig = '' - Host * - StrictHostKeyChecking no - IdentityFile ~/.ssh/privk + + testScript = + { nodes, ... }: + let + inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; + serverSystem = nodes.server.system.build.toplevel; + dumpFile = + with nodes.server.specialisation.dump.configuration.services.forgejo.dump; + "${backupDir}/${file}"; + remoteUri = "forgejo@server:test/repo"; + remoteUriCheckoutAction = "forgejo@server:test/checkout"; + in + '' + import json + + start_all() + + client.succeed("mkdir -p ~/.ssh") + client.succeed("(umask 0077; cat ${snakeOilPrivateKey} > ~/.ssh/privk)") + + client.succeed("mkdir /tmp/repo") + client.succeed("git -C /tmp/repo init") + client.succeed("echo 'hello world' > /tmp/repo/testfile") + client.succeed("git -C /tmp/repo add .") + client.succeed("git -C /tmp/repo commit -m 'Initial import'") + client.succeed("git -C /tmp/repo remote add origin ${remoteUri}") + + server.wait_for_unit("forgejo.service") + server.wait_for_open_port(3000) + server.wait_for_open_port(22) + server.succeed("curl --fail http://localhost:3000/") + + server.succeed( + "su -l forgejo -c 'gpg --homedir /var/lib/forgejo/data/home/.gnupg " + + "--import ${toString (pkgs.writeText "forgejo.key" signingPrivateKey)}'" + ) + + assert "BEGIN PGP PUBLIC KEY BLOCK" in server.succeed("curl http://localhost:3000/api/v1/signing-key.gpg") + + api_version = json.loads(server.succeed("curl http://localhost:3000/api/forgejo/v1/version")).get("version") + assert "development" != api_version and "${forgejoPackage.version}+gitea-" in api_version, ( + "/api/forgejo/v1/version should not return 'development' " + + f"but should contain a forgejo+gitea compatibility version string. Got '{api_version}' instead." + ) + + server.succeed( + "curl --fail http://localhost:3000/user/sign_up | grep 'Registration is disabled. " + + "Please contact your site administrator.'" + ) + server.succeed( + "su -l forgejo -c 'GITEA_WORK_DIR=/var/lib/forgejo gitea admin user create " + + "--username test --password totallysafe --email test@localhost --must-change-password=false'" + ) + + api_token = server.succeed( + "curl --fail -X POST http://test:totallysafe@localhost:3000/api/v1/users/test/tokens " + + "-H 'Accept: application/json' -H 'Content-Type: application/json' -d " + + "'{\"name\":\"token\",\"scopes\":[\"all\"]}' | jq '.sha1' | xargs echo -n" + ) + + server.succeed( + "curl --fail -X POST http://localhost:3000/api/v1/user/repos " + + "-H 'Accept: application/json' -H 'Content-Type: application/json' " + + f"-H 'Authorization: token {api_token}'" + + ' -d \'{"auto_init":false, "description":"string", "license":"mit", "name":"repo", "private":false}\''' + ) + + server.succeed( + "curl --fail -X POST http://localhost:3000/api/v1/user/keys " + + "-H 'Accept: application/json' -H 'Content-Type: application/json' " + + f"-H 'Authorization: token {api_token}'" + + ' -d \'{"key":"${snakeOilPublicKey}","read_only":true,"title":"SSH"}\''' + ) + + client.succeed("git -C /tmp/repo push origin main") + + client.succeed("git clone ${remoteUri} /tmp/repo-clone") + print(client.succeed("ls -lash /tmp/repo-clone")) + assert "hello world" == client.succeed("cat /tmp/repo-clone/testfile").strip() + + with subtest("Testing git protocol version=2 over ssh"): + git_protocol = client.succeed("GIT_TRACE2_EVENT=true GIT_TRACE2_EVENT_NESTING=3 git -C /tmp/repo-clone fetch |& grep negotiated-version") + version = json.loads(git_protocol).get("value") + assert version == "2", f"git did not negotiate protocol version 2, but version {version} instead." + + server.wait_until_succeeds( + 'test "$(curl http://localhost:3000/api/v1/repos/test/repo/commits ' + + '-H "Accept: application/json" | jq length)" = "1"', + timeout=10 + ) + + with subtest("Testing /metrics endpoint with token from cfg.secrets"): + server.fail("curl --fail http://localhost:3000/metrics") + server.succeed('curl --fail http://localhost:3000/metrics -H "Authorization: Bearer ${metricSecret}"') + + with subtest("Testing runner registration and action workflow"): + server.succeed( + "su -l forgejo -c 'GITEA_WORK_DIR=/var/lib/forgejo gitea actions generate-runner-token' | sed 's/^/TOKEN=/' | tee /var/lib/forgejo/runner_token" + ) + server.succeed("${serverSystem}/specialisation/runner/bin/switch-to-configuration test") + server.wait_for_unit("gitea-runner-test.service") + server.succeed("journalctl -o cat -u gitea-runner-test.service | grep -q 'Runner registered successfully'") + + # enable actions feature for this repository, defaults to disabled + server.succeed( + "curl --fail -X PATCH http://localhost:3000/api/v1/repos/test/repo " + + "-H 'Accept: application/json' -H 'Content-Type: application/json' " + + f"-H 'Authorization: token {api_token}'" + + ' -d \'{"has_actions":true}\''' + ) + + # mirror "actions/checkout" action + client.succeed("cp -R ${checkoutActionSource}/ /tmp/checkout") + client.succeed("git -C /tmp/checkout init") + client.succeed("git -C /tmp/checkout add .") + client.succeed("git -C /tmp/checkout commit -m 'Initial import'") + client.succeed("git -C /tmp/checkout remote add origin ${remoteUriCheckoutAction}") + client.succeed("git -C /tmp/checkout push origin main") + + # push workflow to initial repo + client.succeed("mkdir -p /tmp/repo/.forgejo/workflows") + client.succeed("cp ${pkgs.writeText "dummy-workflow.yml" actionsWorkflowYaml} /tmp/repo/.forgejo/workflows/") + client.succeed("git -C /tmp/repo add .") + client.succeed("git -C /tmp/repo commit -m 'Add dummy workflow'") + client.succeed("git -C /tmp/repo push origin main") + + def poll_workflow_action_status(_) -> bool: + output = server.succeed( + "curl --fail http://localhost:3000/test/repo/actions | " + + 'htmlq ".flex-item-leading span" --attribute "data-tooltip-content"' + ).strip() + + # values taken from https://codeberg.org/forgejo/forgejo/src/commit/af47c583b4fb3190fa4c4c414500f9941cc02389/options/locale/locale_en-US.ini#L3649-L3661 + if output in [ "Failure", "Canceled", "Skipped", "Blocked" ]: + raise Exception(f"Workflow status is '{output}', which we consider failed.") + server.log(f"Command returned '{output}', which we consider failed.") + + elif output in [ "Unknown", "Waiting", "Running", "" ]: + server.log(f"Workflow status is '{output}'. Waiting some more...") + return False + + elif output in [ "Success" ]: + return True + + raise Exception(f"Workflow status is '{output}', which we don't know. Value mappings likely need updating.") + + with server.nested("Waiting for the workflow run to be successful"): + retry(poll_workflow_action_status) + + with subtest("Testing backup service"): + server.succeed("${serverSystem}/specialisation/dump/bin/switch-to-configuration test") + server.systemctl("start forgejo-dump") + assert "Zstandard compressed data" in server.succeed("file ${dumpFile}") + server.copy_from_vm("${dumpFile}") ''; - }; - }; - - testScript = { nodes, ... }: - let - inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; - serverSystem = nodes.server.system.build.toplevel; - dumpFile = with nodes.server.specialisation.dump.configuration.services.forgejo.dump; "${backupDir}/${file}"; - remoteUri = "forgejo@server:test/repo"; - remoteUriCheckoutAction = "forgejo@server:test/checkout"; - in - '' - import json - - start_all() - - client.succeed("mkdir -p ~/.ssh") - client.succeed("(umask 0077; cat ${snakeOilPrivateKey} > ~/.ssh/privk)") - - client.succeed("mkdir /tmp/repo") - client.succeed("git -C /tmp/repo init") - client.succeed("echo 'hello world' > /tmp/repo/testfile") - client.succeed("git -C /tmp/repo add .") - client.succeed("git -C /tmp/repo commit -m 'Initial import'") - client.succeed("git -C /tmp/repo remote add origin ${remoteUri}") - - server.wait_for_unit("forgejo.service") - server.wait_for_open_port(3000) - server.wait_for_open_port(22) - server.succeed("curl --fail http://localhost:3000/") - - server.succeed( - "su -l forgejo -c 'gpg --homedir /var/lib/forgejo/data/home/.gnupg " - + "--import ${toString (pkgs.writeText "forgejo.key" signingPrivateKey)}'" - ) - - assert "BEGIN PGP PUBLIC KEY BLOCK" in server.succeed("curl http://localhost:3000/api/v1/signing-key.gpg") - - api_version = json.loads(server.succeed("curl http://localhost:3000/api/forgejo/v1/version")).get("version") - assert "development" != api_version and "${forgejoPackage.version}+gitea-" in api_version, ( - "/api/forgejo/v1/version should not return 'development' " - + f"but should contain a forgejo+gitea compatibility version string. Got '{api_version}' instead." - ) - - server.succeed( - "curl --fail http://localhost:3000/user/sign_up | grep 'Registration is disabled. " - + "Please contact your site administrator.'" - ) - server.succeed( - "su -l forgejo -c 'GITEA_WORK_DIR=/var/lib/forgejo gitea admin user create " - + "--username test --password totallysafe --email test@localhost --must-change-password=false'" - ) - - api_token = server.succeed( - "curl --fail -X POST http://test:totallysafe@localhost:3000/api/v1/users/test/tokens " - + "-H 'Accept: application/json' -H 'Content-Type: application/json' -d " - + "'{\"name\":\"token\",\"scopes\":[\"all\"]}' | jq '.sha1' | xargs echo -n" - ) - - server.succeed( - "curl --fail -X POST http://localhost:3000/api/v1/user/repos " - + "-H 'Accept: application/json' -H 'Content-Type: application/json' " - + f"-H 'Authorization: token {api_token}'" - + ' -d \'{"auto_init":false, "description":"string", "license":"mit", "name":"repo", "private":false}\''' - ) - - server.succeed( - "curl --fail -X POST http://localhost:3000/api/v1/user/keys " - + "-H 'Accept: application/json' -H 'Content-Type: application/json' " - + f"-H 'Authorization: token {api_token}'" - + ' -d \'{"key":"${snakeOilPublicKey}","read_only":true,"title":"SSH"}\''' - ) - - client.succeed("git -C /tmp/repo push origin main") - - client.succeed("git clone ${remoteUri} /tmp/repo-clone") - print(client.succeed("ls -lash /tmp/repo-clone")) - assert "hello world" == client.succeed("cat /tmp/repo-clone/testfile").strip() - - with subtest("Testing git protocol version=2 over ssh"): - git_protocol = client.succeed("GIT_TRACE2_EVENT=true GIT_TRACE2_EVENT_NESTING=3 git -C /tmp/repo-clone fetch |& grep negotiated-version") - version = json.loads(git_protocol).get("value") - assert version == "2", f"git did not negotiate protocol version 2, but version {version} instead." - - server.wait_until_succeeds( - 'test "$(curl http://localhost:3000/api/v1/repos/test/repo/commits ' - + '-H "Accept: application/json" | jq length)" = "1"', - timeout=10 - ) - - with subtest("Testing /metrics endpoint with token from cfg.secrets"): - server.fail("curl --fail http://localhost:3000/metrics") - server.succeed('curl --fail http://localhost:3000/metrics -H "Authorization: Bearer ${metricSecret}"') - - with subtest("Testing runner registration and action workflow"): - server.succeed( - "su -l forgejo -c 'GITEA_WORK_DIR=/var/lib/forgejo gitea actions generate-runner-token' | sed 's/^/TOKEN=/' | tee /var/lib/forgejo/runner_token" - ) - server.succeed("${serverSystem}/specialisation/runner/bin/switch-to-configuration test") - server.wait_for_unit("gitea-runner-test.service") - server.succeed("journalctl -o cat -u gitea-runner-test.service | grep -q 'Runner registered successfully'") - - # enable actions feature for this repository, defaults to disabled - server.succeed( - "curl --fail -X PATCH http://localhost:3000/api/v1/repos/test/repo " - + "-H 'Accept: application/json' -H 'Content-Type: application/json' " - + f"-H 'Authorization: token {api_token}'" - + ' -d \'{"has_actions":true}\''' - ) - - # mirror "actions/checkout" action - client.succeed("cp -R ${checkoutActionSource}/ /tmp/checkout") - client.succeed("git -C /tmp/checkout init") - client.succeed("git -C /tmp/checkout add .") - client.succeed("git -C /tmp/checkout commit -m 'Initial import'") - client.succeed("git -C /tmp/checkout remote add origin ${remoteUriCheckoutAction}") - client.succeed("git -C /tmp/checkout push origin main") - - # push workflow to initial repo - client.succeed("mkdir -p /tmp/repo/.forgejo/workflows") - client.succeed("cp ${pkgs.writeText "dummy-workflow.yml" actionsWorkflowYaml} /tmp/repo/.forgejo/workflows/") - client.succeed("git -C /tmp/repo add .") - client.succeed("git -C /tmp/repo commit -m 'Add dummy workflow'") - client.succeed("git -C /tmp/repo push origin main") - - def poll_workflow_action_status(_) -> bool: - output = server.succeed( - "curl --fail http://localhost:3000/test/repo/actions | " - + 'htmlq ".flex-item-leading span" --attribute "data-tooltip-content"' - ).strip() - - # values taken from https://codeberg.org/forgejo/forgejo/src/commit/af47c583b4fb3190fa4c4c414500f9941cc02389/options/locale/locale_en-US.ini#L3649-L3661 - if output in [ "Failure", "Canceled", "Skipped", "Blocked" ]: - raise Exception(f"Workflow status is '{output}', which we consider failed.") - server.log(f"Command returned '{output}', which we consider failed.") - - elif output in [ "Unknown", "Waiting", "Running", "" ]: - server.log(f"Workflow status is '{output}'. Waiting some more...") - return False - - elif output in [ "Success" ]: - return True - - raise Exception(f"Workflow status is '{output}', which we don't know. Value mappings likely need updating.") - - with server.nested("Waiting for the workflow run to be successful"): - retry(poll_workflow_action_status) - - with subtest("Testing backup service"): - server.succeed("${serverSystem}/specialisation/dump/bin/switch-to-configuration test") - server.systemctl("start forgejo-dump") - assert "Zstandard compressed data" in server.succeed("file ${dumpFile}") - server.copy_from_vm("${dumpFile}") - ''; - }); + }); in listToAttrs (map makeForgejoTest supportedDbTypes) diff --git a/nixos/tests/freenet.nix b/nixos/tests/freenet.nix index 96dbb4caa12932..8f6caf8160ca07 100644 --- a/nixos/tests/freenet.nix +++ b/nixos/tests/freenet.nix @@ -1,19 +1,24 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "freenet"; - meta = with pkgs.lib.maintainers; { - maintainers = [ nagy ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "freenet"; + meta = with pkgs.lib.maintainers; { + maintainers = [ nagy ]; + }; - nodes = { - machine = { ... }: { - services.freenet.enable = true; + nodes = { + machine = + { ... }: + { + services.freenet.enable = true; + }; }; - }; - testScript = '' - machine.wait_for_unit("freenet.service") - machine.wait_for_open_port(8888) - machine.wait_until_succeeds("curl -sfL http://localhost:8888/ | grep Freenet") - machine.succeed("systemctl stop freenet") - ''; -}) + testScript = '' + machine.wait_for_unit("freenet.service") + machine.wait_for_open_port(8888) + machine.wait_until_succeeds("curl -sfL http://localhost:8888/ | grep Freenet") + machine.succeed("systemctl stop freenet") + ''; + } +) diff --git a/nixos/tests/freeswitch.nix b/nixos/tests/freeswitch.nix index bfb7339ec3c0df..91f25244c9a423 100644 --- a/nixos/tests/freeswitch.nix +++ b/nixos/tests/freeswitch.nix @@ -1,29 +1,34 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "freeswitch"; - meta = with pkgs.lib.maintainers; { - maintainers = [ misuzu ]; - }; - nodes = { - node0 = { config, lib, ... }: { - networking.useDHCP = false; - networking.interfaces.eth1 = { - ipv4.addresses = [ - { - address = "192.168.0.1"; - prefixLength = 24; - } - ]; - }; - services.freeswitch = { - enable = true; - enableReload = true; - configTemplate = "${config.services.freeswitch.package}/share/freeswitch/conf/minimal"; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "freeswitch"; + meta = with pkgs.lib.maintainers; { + maintainers = [ misuzu ]; }; - }; - testScript = '' - node0.wait_for_unit("freeswitch.service") - # Wait for SIP port to be open - node0.wait_for_open_port(5060) - ''; -}) + nodes = { + node0 = + { config, lib, ... }: + { + networking.useDHCP = false; + networking.interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.0.1"; + prefixLength = 24; + } + ]; + }; + services.freeswitch = { + enable = true; + enableReload = true; + configTemplate = "${config.services.freeswitch.package}/share/freeswitch/conf/minimal"; + }; + }; + }; + testScript = '' + node0.wait_for_unit("freeswitch.service") + # Wait for SIP port to be open + node0.wait_for_open_port(5060) + ''; + } +) diff --git a/nixos/tests/freetube.nix b/nixos/tests/freetube.nix index c886f1ee116e30..1d4b59a0310274 100644 --- a/nixos/tests/freetube.nix +++ b/nixos/tests/freetube.nix @@ -1,43 +1,56 @@ let tests = { - wayland = { pkgs, ... }: { - imports = [ ./common/wayland-cage.nix ]; - services.cage.program = "${pkgs.freetube}/bin/freetube"; - virtualisation.memorySize = 2047; - environment.variables.NIXOS_OZONE_WL = "1"; - environment.variables.DISPLAY = "do not use"; - }; - xorg = { pkgs, ... }: { - imports = [ ./common/user-account.nix ./common/x11.nix ]; - virtualisation.memorySize = 2047; - services.xserver.enable = true; - services.xserver.displayManager.sessionCommands = '' - ${pkgs.freetube}/bin/freetube - ''; - test-support.displayManager.auto.user = "alice"; - }; + wayland = + { pkgs, ... }: + { + imports = [ ./common/wayland-cage.nix ]; + services.cage.program = "${pkgs.freetube}/bin/freetube"; + virtualisation.memorySize = 2047; + environment.variables.NIXOS_OZONE_WL = "1"; + environment.variables.DISPLAY = "do not use"; + }; + xorg = + { pkgs, ... }: + { + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; + virtualisation.memorySize = 2047; + services.xserver.enable = true; + services.xserver.displayManager.sessionCommands = '' + ${pkgs.freetube}/bin/freetube + ''; + test-support.displayManager.auto.user = "alice"; + }; }; - mkTest = name: machine: - import ./make-test-python.nix ({ pkgs, ... }: { - inherit name; - nodes = { "${name}" = machine; }; - meta.maintainers = with pkgs.lib.maintainers; [ kirillrdy ]; - # time-out on ofborg - meta.broken = pkgs.stdenv.hostPlatform.isAarch64; - enableOCR = true; + mkTest = + name: machine: + import ./make-test-python.nix ( + { pkgs, ... }: + { + inherit name; + nodes = { + "${name}" = machine; + }; + meta.maintainers = with pkgs.lib.maintainers; [ kirillrdy ]; + # time-out on ofborg + meta.broken = pkgs.stdenv.hostPlatform.isAarch64; + enableOCR = true; - testScript = '' - start_all() - machine.wait_for_unit('graphical.target') - machine.wait_for_text('Your Subscription list is currently empty') - machine.send_key("ctrl-r") - machine.wait_for_text('Your Subscription list is currently empty') - machine.screenshot("main.png") - machine.send_key("ctrl-comma") - machine.wait_for_text('Data', timeout=60) - machine.screenshot("preferences.png") - ''; - }); + testScript = '' + start_all() + machine.wait_for_unit('graphical.target') + machine.wait_for_text('Your Subscription list is currently empty') + machine.send_key("ctrl-r") + machine.wait_for_text('Your Subscription list is currently empty') + machine.screenshot("main.png") + machine.send_key("ctrl-comma") + machine.wait_for_text('Data', timeout=60) + machine.screenshot("preferences.png") + ''; + } + ); in builtins.mapAttrs (k: v: mkTest k v) tests diff --git a/nixos/tests/freshrss-extensions.nix b/nixos/tests/freshrss-extensions.nix index f3e893b3b5a870..3de954260fdc27 100644 --- a/nixos/tests/freshrss-extensions.nix +++ b/nixos/tests/freshrss-extensions.nix @@ -1,19 +1,24 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "freshrss"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "freshrss"; - nodes.machine = { pkgs, ... }: { - services.freshrss = { - enable = true; - baseUrl = "http://localhost"; - authType = "none"; - extensions = [ pkgs.freshrss-extensions.youtube ]; - }; - }; + nodes.machine = + { pkgs, ... }: + { + services.freshrss = { + enable = true; + baseUrl = "http://localhost"; + authType = "none"; + extensions = [ pkgs.freshrss-extensions.youtube ]; + }; + }; - testScript = '' - machine.wait_for_unit("multi-user.target") - machine.wait_for_open_port(80) - response = machine.succeed("curl -vvv -s http://127.0.0.1:80/i/?c=extension") - assert 'YouTube Video Feed' in response, "Extension not present in extensions page." - ''; -}) + testScript = '' + machine.wait_for_unit("multi-user.target") + machine.wait_for_open_port(80) + response = machine.succeed("curl -vvv -s http://127.0.0.1:80/i/?c=extension") + assert 'YouTube Video Feed' in response, "Extension not present in extensions page." + ''; + } +) diff --git a/nixos/tests/freshrss-http-auth.nix b/nixos/tests/freshrss-http-auth.nix index d0ec3da316896d..4fcacc22d30834 100644 --- a/nixos/tests/freshrss-http-auth.nix +++ b/nixos/tests/freshrss-http-auth.nix @@ -1,20 +1,25 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "freshrss"; - meta.maintainers = with lib.maintainers; [ mattchrist ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "freshrss"; + meta.maintainers = with lib.maintainers; [ mattchrist ]; - nodes.machine = { pkgs, ... }: { - services.freshrss = { - enable = true; - baseUrl = "http://localhost"; - dataDir = "/srv/freshrss"; - authType = "http_auth"; - }; - }; + nodes.machine = + { pkgs, ... }: + { + services.freshrss = { + enable = true; + baseUrl = "http://localhost"; + dataDir = "/srv/freshrss"; + authType = "http_auth"; + }; + }; - testScript = '' - machine.wait_for_unit("multi-user.target") - machine.wait_for_open_port(80) - response = machine.succeed("curl -vvv -s -H 'Host: freshrss' -H 'Remote-User: testuser' http://127.0.0.1:80/i/") - assert 'Account: testuser' in response, "http_auth method didn't work." - ''; -}) + testScript = '' + machine.wait_for_unit("multi-user.target") + machine.wait_for_open_port(80) + response = machine.succeed("curl -vvv -s -H 'Host: freshrss' -H 'Remote-User: testuser' http://127.0.0.1:80/i/") + assert 'Account: testuser' in response, "http_auth method didn't work." + ''; + } +) diff --git a/nixos/tests/freshrss-none-auth.nix b/nixos/tests/freshrss-none-auth.nix index fd63470386a05a..0dc484dd535a13 100644 --- a/nixos/tests/freshrss-none-auth.nix +++ b/nixos/tests/freshrss-none-auth.nix @@ -1,19 +1,24 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "freshrss"; - meta.maintainers = with lib.maintainers; [ mattchrist ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "freshrss"; + meta.maintainers = with lib.maintainers; [ mattchrist ]; - nodes.machine = { pkgs, ... }: { - services.freshrss = { - enable = true; - baseUrl = "http://localhost"; - authType = "none"; - }; - }; + nodes.machine = + { pkgs, ... }: + { + services.freshrss = { + enable = true; + baseUrl = "http://localhost"; + authType = "none"; + }; + }; - testScript = '' - machine.wait_for_unit("multi-user.target") - machine.wait_for_open_port(80) - response = machine.succeed("curl -vvv -s http://127.0.0.1:80/i/") - assert 'Main stream · FreshRSS' in response, "FreshRSS stream page didn't load successfully" - ''; -}) + testScript = '' + machine.wait_for_unit("multi-user.target") + machine.wait_for_open_port(80) + response = machine.succeed("curl -vvv -s http://127.0.0.1:80/i/") + assert 'Main stream · FreshRSS' in response, "FreshRSS stream page didn't load successfully" + ''; + } +) diff --git a/nixos/tests/freshrss-pgsql.nix b/nixos/tests/freshrss-pgsql.nix index c685f4a8159b8f..678633dea1d622 100644 --- a/nixos/tests/freshrss-pgsql.nix +++ b/nixos/tests/freshrss-pgsql.nix @@ -1,46 +1,54 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "freshrss"; - meta.maintainers = with lib.maintainers; [ etu stunkymonkey ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "freshrss"; + meta.maintainers = with lib.maintainers; [ + etu + stunkymonkey + ]; - nodes.machine = { pkgs, ... }: { - services.freshrss = { - enable = true; - baseUrl = "http://localhost"; - passwordFile = pkgs.writeText "password" "secret"; - dataDir = "/srv/freshrss"; - database = { - type = "pgsql"; - port = 5432; - user = "freshrss"; - passFile = pkgs.writeText "db-password" "db-secret"; - }; - }; + nodes.machine = + { pkgs, ... }: + { + services.freshrss = { + enable = true; + baseUrl = "http://localhost"; + passwordFile = pkgs.writeText "password" "secret"; + dataDir = "/srv/freshrss"; + database = { + type = "pgsql"; + port = 5432; + user = "freshrss"; + passFile = pkgs.writeText "db-password" "db-secret"; + }; + }; - services.postgresql = { - enable = true; - ensureDatabases = [ "freshrss" ]; - ensureUsers = [ - { - name = "freshrss"; - ensureDBOwnership = true; - } - ]; - initialScript = pkgs.writeText "postgresql-password" '' - CREATE ROLE freshrss WITH LOGIN PASSWORD 'db-secret' CREATEDB; - ''; - }; + services.postgresql = { + enable = true; + ensureDatabases = [ "freshrss" ]; + ensureUsers = [ + { + name = "freshrss"; + ensureDBOwnership = true; + } + ]; + initialScript = pkgs.writeText "postgresql-password" '' + CREATE ROLE freshrss WITH LOGIN PASSWORD 'db-secret' CREATEDB; + ''; + }; - systemd.services."freshrss-config" = { - requires = [ "postgresql.service" ]; - after = [ "postgresql.service" ]; - }; - }; + systemd.services."freshrss-config" = { + requires = [ "postgresql.service" ]; + after = [ "postgresql.service" ]; + }; + }; - testScript = '' - machine.wait_for_unit("multi-user.target") - machine.wait_for_open_port(5432) - machine.wait_for_open_port(80) - response = machine.succeed("curl -vvv -s -H 'Host: freshrss' http://127.0.0.1:80/i/") - assert 'Login · FreshRSS' in response, "Login page didn't load successfully" - ''; -}) + testScript = '' + machine.wait_for_unit("multi-user.target") + machine.wait_for_open_port(5432) + machine.wait_for_open_port(80) + response = machine.succeed("curl -vvv -s -H 'Host: freshrss' http://127.0.0.1:80/i/") + assert 'Login · FreshRSS' in response, "Login page didn't load successfully" + ''; + } +) diff --git a/nixos/tests/freshrss-sqlite.nix b/nixos/tests/freshrss-sqlite.nix index b821c98a7e7ac5..c72ab93ca73ddb 100644 --- a/nixos/tests/freshrss-sqlite.nix +++ b/nixos/tests/freshrss-sqlite.nix @@ -1,20 +1,28 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "freshrss"; - meta.maintainers = with lib.maintainers; [ etu stunkymonkey ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "freshrss"; + meta.maintainers = with lib.maintainers; [ + etu + stunkymonkey + ]; - nodes.machine = { pkgs, ... }: { - services.freshrss = { - enable = true; - baseUrl = "http://localhost"; - passwordFile = pkgs.writeText "password" "secret"; - dataDir = "/srv/freshrss"; - }; - }; + nodes.machine = + { pkgs, ... }: + { + services.freshrss = { + enable = true; + baseUrl = "http://localhost"; + passwordFile = pkgs.writeText "password" "secret"; + dataDir = "/srv/freshrss"; + }; + }; - testScript = '' - machine.wait_for_unit("multi-user.target") - machine.wait_for_open_port(80) - response = machine.succeed("curl -vvv -s -H 'Host: freshrss' http://127.0.0.1:80/i/") - assert 'Login · FreshRSS' in response, "Login page didn't load successfully" - ''; -}) + testScript = '' + machine.wait_for_unit("multi-user.target") + machine.wait_for_open_port(80) + response = machine.succeed("curl -vvv -s -H 'Host: freshrss' http://127.0.0.1:80/i/") + assert 'Login · FreshRSS' in response, "Login page didn't load successfully" + ''; + } +) diff --git a/nixos/tests/frigate.nix b/nixos/tests/frigate.nix index ecbc68d3643162..156d8d8cf9168d 100644 --- a/nixos/tests/frigate.nix +++ b/nixos/tests/frigate.nix @@ -1,72 +1,76 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : +import ./make-test-python.nix ( + { pkgs, lib, ... }: -{ - name = "frigate"; - meta.maintainers = with lib.maintainers; [ hexa ]; + { + name = "frigate"; + meta.maintainers = with lib.maintainers; [ hexa ]; - nodes = { - machine = { - services.frigate = { - enable = true; + nodes = { + machine = { + services.frigate = { + enable = true; - hostname = "localhost"; + hostname = "localhost"; - settings = { - mqtt.enabled = false; + settings = { + mqtt.enabled = false; - cameras.test = { - ffmpeg = { - input_args = "-fflags nobuffer -strict experimental -fflags +genpts+discardcorrupt -r 10 -use_wallclock_as_timestamps 1"; - inputs = [ { - path = "http://127.0.0.1:8080"; - roles = [ - "record" + cameras.test = { + ffmpeg = { + input_args = "-fflags nobuffer -strict experimental -fflags +genpts+discardcorrupt -r 10 -use_wallclock_as_timestamps 1"; + inputs = [ + { + path = "http://127.0.0.1:8080"; + roles = [ + "record" + ]; + } ]; - } ]; + }; }; - }; - record.enabled = true; + record.enabled = true; + }; }; - }; - systemd.services.video-stream = { - description = "Start a test stream that frigate can capture"; - before = [ - "frigate.service" - ]; - wantedBy = [ - "multi-user.target" - ]; - serviceConfig = { - DynamicUser = true; - ExecStart = "${lib.getExe pkgs.ffmpeg-headless} -re -f lavfi -i smptebars=size=1280x720:rate=5 -f mpegts -listen 1 http://0.0.0.0:8080"; - Restart = "always"; + systemd.services.video-stream = { + description = "Start a test stream that frigate can capture"; + before = [ + "frigate.service" + ]; + wantedBy = [ + "multi-user.target" + ]; + serviceConfig = { + DynamicUser = true; + ExecStart = "${lib.getExe pkgs.ffmpeg-headless} -re -f lavfi -i smptebars=size=1280x720:rate=5 -f mpegts -listen 1 http://0.0.0.0:8080"; + Restart = "always"; + }; }; - }; - environment.systemPackages = with pkgs; [ httpie ]; + environment.systemPackages = with pkgs; [ httpie ]; + }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - # wait until frigate is up - machine.wait_for_unit("frigate.service") - machine.wait_for_open_port(5001) + # wait until frigate is up + machine.wait_for_unit("frigate.service") + machine.wait_for_open_port(5001) - # extract admin password from logs - machine.wait_until_succeeds("journalctl -u frigate.service -o cat | grep -q 'Password: '") - password = machine.execute("journalctl -u frigate.service -o cat | grep -oP '([a-f0-9]{32})'")[1] + # extract admin password from logs + machine.wait_until_succeeds("journalctl -u frigate.service -o cat | grep -q 'Password: '") + password = machine.execute("journalctl -u frigate.service -o cat | grep -oP '([a-f0-9]{32})'")[1] - # login and store session - machine.log(machine.succeed(f"http --check-status --session=frigate post http://localhost/api/login user=admin password={password}")) + # login and store session + machine.log(machine.succeed(f"http --check-status --session=frigate post http://localhost/api/login user=admin password={password}")) - # make authenticated api requested - machine.log(machine.succeed("http --check-status --session=frigate get http://localhost/api/version")) + # make authenticated api requested + machine.log(machine.succeed("http --check-status --session=frigate get http://localhost/api/version")) - # wait for a recording to appear - machine.wait_for_file("/var/cache/frigate/test@*.mp4") - ''; -}) + # wait for a recording to appear + machine.wait_for_file("/var/cache/frigate/test@*.mp4") + ''; + } +) diff --git a/nixos/tests/frp.nix b/nixos/tests/frp.nix index 717e8718721cec..8771ab8ad224c8 100644 --- a/nixos/tests/frp.nix +++ b/nixos/tests/frp.nix @@ -1,85 +1,87 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "frp"; - meta.maintainers = with lib.maintainers; [ zaldnoay ]; - nodes = { - frps = { - networking = { - useNetworkd = true; - useDHCP = false; - firewall.enable = false; - }; - - systemd.network.networks."01-eth1" = { - name = "eth1"; - networkConfig.Address = "10.0.0.1/24"; - }; - - services.frp = { - enable = true; - role = "server"; - settings = { - bindPort = 7000; - vhostHTTPPort = 80; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "frp"; + meta.maintainers = with lib.maintainers; [ zaldnoay ]; + nodes = { + frps = { + networking = { + useNetworkd = true; + useDHCP = false; + firewall.enable = false; }; - }; - }; + systemd.network.networks."01-eth1" = { + name = "eth1"; + networkConfig.Address = "10.0.0.1/24"; + }; - frpc = { - networking = { - useNetworkd = true; - useDHCP = false; + services.frp = { + enable = true; + role = "server"; + settings = { + bindPort = 7000; + vhostHTTPPort = 80; + }; + }; }; - systemd.network.networks."01-eth1" = { - name = "eth1"; - networkConfig.Address = "10.0.0.2/24"; - }; + frpc = { + networking = { + useNetworkd = true; + useDHCP = false; + }; - services.httpd = { - enable = true; - adminAddr = "admin@example.com"; - virtualHosts."test-appication" = - let - testdir = pkgs.writeTextDir "web/index.php" " /home/alice/world") - logout() - # Wait for logout to be processed - machine.sleep(1) - - with subtest("File should not be readable without being logged in as alice"): - machine.fail("cat /home/alice/world") - - with subtest("File should be readable again as alice"): - login_as_alice() - machine.succeed("cat /home/alice/world") - logout() - ''; -}) +import ./make-test-python.nix ( + { ... }: + { + name = "fscrypt"; + + nodes.machine = + { pkgs, ... }: + { + imports = [ ./common/user-account.nix ]; + security.pam.enableFscrypt = true; + }; + + testScript = '' + def login_as_alice(): + machine.wait_until_tty_matches("1", "login: ") + machine.send_chars("alice\n") + machine.wait_until_tty_matches("1", "Password: ") + machine.send_chars("foobar\n") + machine.wait_until_tty_matches("1", "alice\@machine") + + + def logout(): + machine.send_chars("logout\n") + machine.wait_until_tty_matches("1", "login: ") + + + machine.wait_for_unit("default.target") + + with subtest("Enable fscrypt on filesystem"): + machine.succeed("tune2fs -O encrypt /dev/vda") + machine.succeed("fscrypt setup --quiet --force --time=1ms") + + with subtest("Set up alice with an fscrypt-enabled home directory"): + machine.succeed("(echo foobar; echo foobar) | passwd alice") + machine.succeed("chown -R alice.users ~alice") + machine.succeed("echo foobar | fscrypt encrypt --skip-unlock --source=pam_passphrase --user=alice /home/alice") + + with subtest("Create file as alice"): + login_as_alice() + machine.succeed("echo hello > /home/alice/world") + logout() + # Wait for logout to be processed + machine.sleep(1) + + with subtest("File should not be readable without being logged in as alice"): + machine.fail("cat /home/alice/world") + + with subtest("File should be readable again as alice"): + login_as_alice() + machine.succeed("cat /home/alice/world") + logout() + ''; + } +) diff --git a/nixos/tests/ft2-clone.nix b/nixos/tests/ft2-clone.nix index 813e258cd2becd..012432bb3f8420 100644 --- a/nixos/tests/ft2-clone.nix +++ b/nixos/tests/ft2-clone.nix @@ -1,20 +1,23 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "ft2-clone"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fgaz ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "ft2-clone"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fgaz ]; + }; - nodes.machine = { pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; - environment.systemPackages = [ pkgs.ft2-clone ]; - }; + nodes.machine = + { pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; + environment.systemPackages = [ pkgs.ft2-clone ]; + }; - enableOCR = true; + enableOCR = true; - testScript = - '' + testScript = '' machine.wait_for_x() # Add a dummy sound card, or the program won't start machine.execute("modprobe snd-dummy") @@ -26,4 +29,5 @@ import ./make-test-python.nix ({ pkgs, ... }: { machine.wait_for_text(r"(Songlen|Repstart|Time|About|Nibbles|Help)") machine.screenshot("screen") ''; -}) + } +) diff --git a/nixos/tests/garage/basic.nix b/nixos/tests/garage/basic.nix index 88d747ea33b9f4..c6264d2cbc9fad 100644 --- a/nixos/tests/garage/basic.nix +++ b/nixos/tests/garage/basic.nix @@ -1,98 +1,106 @@ args@{ mkNode, ver, ... }: -(import ../make-test-python.nix ({ pkgs, ...} : { - name = "garage-basic"; - meta = { - maintainers = with pkgs.lib.maintainers; [ raitobezarius ]; - }; - - nodes = { - single_node = mkNode { replicationMode = "none"; }; - }; - - testScript = '' - from typing import List - from dataclasses import dataclass - import re - - start_all() - - cur_version_regex = re.compile('Current cluster layout version: (?P\d*)') - key_creation_regex = re.compile('Key name: (?P.*)\nKey ID: (?P.*)\nSecret key: (?P.*)') - - @dataclass - class S3Key: - key_name: str - key_id: str - secret_key: str - - @dataclass - class GarageNode: - node_id: str - host: str - - def get_node_fqn(machine: Machine) -> GarageNode: - node_id, host = machine.succeed("garage node id").split('@') - return GarageNode(node_id=node_id, host=host) - - def get_node_id(machine: Machine) -> str: - return get_node_fqn(machine).node_id - - def get_layout_version(machine: Machine) -> int: - version_data = machine.succeed("garage layout show") - m = cur_version_regex.search(version_data) - if m and m.group('ver') is not None: - return int(m.group('ver')) + 1 - else: - raise ValueError('Cannot find current layout version') - - def apply_garage_layout(machine: Machine, layouts: List[str]): - for layout in layouts: - machine.succeed(f"garage layout assign {layout}") - version = get_layout_version(machine) - machine.succeed(f"garage layout apply --version {version}") - - def create_api_key(machine: Machine, key_name: str) -> S3Key: - output = machine.succeed(f"garage key ${if ver == "0_8" then "new --name" else "create"} {key_name}") - m = key_creation_regex.match(output) - if not m or not m.group('key_id') or not m.group('secret_key'): - raise ValueError('Cannot parse API key data') - return S3Key(key_name=key_name, key_id=m.group('key_id'), secret_key=m.group('secret_key')) - - def get_api_key(machine: Machine, key_pattern: str) -> S3Key: - output = machine.succeed(f"garage key info {key_pattern}") - m = key_creation_regex.match(output) - if not m or not m.group('key_name') or not m.group('key_id') or not m.group('secret_key'): - raise ValueError('Cannot parse API key data') - return S3Key(key_name=m.group('key_name'), key_id=m.group('key_id'), secret_key=m.group('secret_key')) - - def test_bucket_writes(node): - node.succeed("garage bucket create test-bucket") - s3_key = create_api_key(node, "test-api-key") - node.succeed("garage bucket allow --read --write test-bucket --key test-api-key") - other_s3_key = get_api_key(node, 'test-api-key') - assert other_s3_key.secret_key == other_s3_key.secret_key - node.succeed( - f"mc alias set test-garage http://[::1]:3900 {s3_key.key_id} {s3_key.secret_key} --api S3v4" - ) - node.succeed("echo test | mc pipe test-garage/test-bucket/test.txt") - assert node.succeed("mc cat test-garage/test-bucket/test.txt").strip() == "test" - - def test_bucket_over_http(node, bucket='test-bucket', url=None): - if url is None: - url = f"{bucket}.web.garage" - - node.succeed(f'garage bucket website --allow {bucket}') - node.succeed(f'echo hello world | mc pipe test-garage/{bucket}/index.html') - assert (node.succeed(f"curl -H 'Host: {url}' http://localhost:3902")).strip() == 'hello world' - - with subtest("Garage works as a single-node S3 storage"): - single_node.wait_for_unit("garage.service") - single_node.wait_for_open_port(3900) - # Now Garage is initialized. - single_node_id = get_node_id(single_node) - apply_garage_layout(single_node, [f'-z qemutest -c ${if ver == "0_8" then "1" else "1G"} "{single_node_id}"']) - # Now Garage is operational. - test_bucket_writes(single_node) - test_bucket_over_http(single_node) - ''; -})) args +(import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "garage-basic"; + meta = { + maintainers = with pkgs.lib.maintainers; [ raitobezarius ]; + }; + + nodes = { + single_node = mkNode { replicationMode = "none"; }; + }; + + testScript = '' + from typing import List + from dataclasses import dataclass + import re + + start_all() + + cur_version_regex = re.compile('Current cluster layout version: (?P\d*)') + key_creation_regex = re.compile('Key name: (?P.*)\nKey ID: (?P.*)\nSecret key: (?P.*)') + + @dataclass + class S3Key: + key_name: str + key_id: str + secret_key: str + + @dataclass + class GarageNode: + node_id: str + host: str + + def get_node_fqn(machine: Machine) -> GarageNode: + node_id, host = machine.succeed("garage node id").split('@') + return GarageNode(node_id=node_id, host=host) + + def get_node_id(machine: Machine) -> str: + return get_node_fqn(machine).node_id + + def get_layout_version(machine: Machine) -> int: + version_data = machine.succeed("garage layout show") + m = cur_version_regex.search(version_data) + if m and m.group('ver') is not None: + return int(m.group('ver')) + 1 + else: + raise ValueError('Cannot find current layout version') + + def apply_garage_layout(machine: Machine, layouts: List[str]): + for layout in layouts: + machine.succeed(f"garage layout assign {layout}") + version = get_layout_version(machine) + machine.succeed(f"garage layout apply --version {version}") + + def create_api_key(machine: Machine, key_name: str) -> S3Key: + output = machine.succeed(f"garage key ${ + if ver == "0_8" then "new --name" else "create" + } {key_name}") + m = key_creation_regex.match(output) + if not m or not m.group('key_id') or not m.group('secret_key'): + raise ValueError('Cannot parse API key data') + return S3Key(key_name=key_name, key_id=m.group('key_id'), secret_key=m.group('secret_key')) + + def get_api_key(machine: Machine, key_pattern: str) -> S3Key: + output = machine.succeed(f"garage key info {key_pattern}") + m = key_creation_regex.match(output) + if not m or not m.group('key_name') or not m.group('key_id') or not m.group('secret_key'): + raise ValueError('Cannot parse API key data') + return S3Key(key_name=m.group('key_name'), key_id=m.group('key_id'), secret_key=m.group('secret_key')) + + def test_bucket_writes(node): + node.succeed("garage bucket create test-bucket") + s3_key = create_api_key(node, "test-api-key") + node.succeed("garage bucket allow --read --write test-bucket --key test-api-key") + other_s3_key = get_api_key(node, 'test-api-key') + assert other_s3_key.secret_key == other_s3_key.secret_key + node.succeed( + f"mc alias set test-garage http://[::1]:3900 {s3_key.key_id} {s3_key.secret_key} --api S3v4" + ) + node.succeed("echo test | mc pipe test-garage/test-bucket/test.txt") + assert node.succeed("mc cat test-garage/test-bucket/test.txt").strip() == "test" + + def test_bucket_over_http(node, bucket='test-bucket', url=None): + if url is None: + url = f"{bucket}.web.garage" + + node.succeed(f'garage bucket website --allow {bucket}') + node.succeed(f'echo hello world | mc pipe test-garage/{bucket}/index.html') + assert (node.succeed(f"curl -H 'Host: {url}' http://localhost:3902")).strip() == 'hello world' + + with subtest("Garage works as a single-node S3 storage"): + single_node.wait_for_unit("garage.service") + single_node.wait_for_open_port(3900) + # Now Garage is initialized. + single_node_id = get_node_id(single_node) + apply_garage_layout(single_node, [f'-z qemutest -c ${ + if ver == "0_8" then "1" else "1G" + } "{single_node_id}"']) + # Now Garage is operational. + test_bucket_writes(single_node) + test_bucket_over_http(single_node) + ''; + } +)) + args diff --git a/nixos/tests/garage/default.nix b/nixos/tests/garage/default.nix index b7f9bb4b865bdf..cd2824d26ecd5e 100644 --- a/nixos/tests/garage/default.nix +++ b/nixos/tests/garage/default.nix @@ -1,17 +1,30 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../../.. { inherit system config; }, }: with pkgs.lib; let - mkNode = package: { replicationMode, publicV6Address ? "::1" }: { pkgs, ... }: { - networking.interfaces.eth1.ipv6.addresses = [{ - address = publicV6Address; - prefixLength = 64; - }]; + mkNode = + package: + { + replicationMode, + publicV6Address ? "::1", + }: + { pkgs, ... }: + { + networking.interfaces.eth1.ipv6.addresses = [ + { + address = publicV6Address; + prefixLength = 64; + } + ]; - networking.firewall.allowedTCPPorts = [ 3901 3902 ]; + networking.firewall.allowedTCPPorts = [ + 3901 + 3902 + ]; services.garage = { enable = true; @@ -42,12 +55,22 @@ let virtualisation.diskSize = 2 * 1024; }; in - foldl - (matrix: ver: matrix // { - "basic${toString ver}" = import ./basic.nix { inherit system pkgs ver; mkNode = mkNode pkgs."garage_${ver}"; }; - "with-3node-replication${toString ver}" = import ./with-3node-replication.nix { inherit system pkgs ver; mkNode = mkNode pkgs."garage_${ver}"; }; - }) - {} +foldl + ( + matrix: ver: + matrix + // { + "basic${toString ver}" = import ./basic.nix { + inherit system pkgs ver; + mkNode = mkNode pkgs."garage_${ver}"; + }; + "with-3node-replication${toString ver}" = import ./with-3node-replication.nix { + inherit system pkgs ver; + mkNode = mkNode pkgs."garage_${ver}"; + }; + } + ) + { } [ "0_8" "0_9" diff --git a/nixos/tests/garage/with-3node-replication.nix b/nixos/tests/garage/with-3node-replication.nix index 266a1082893f79..a2f4189603b041 100644 --- a/nixos/tests/garage/with-3node-replication.nix +++ b/nixos/tests/garage/with-3node-replication.nix @@ -1,121 +1,138 @@ args@{ mkNode, ver, ... }: -(import ../make-test-python.nix ({ pkgs, ...} : -{ - name = "garage-3node-replication"; - meta = { - maintainers = with pkgs.lib.maintainers; [ raitobezarius ]; - }; - - nodes = { - node1 = mkNode { replicationMode = "3"; publicV6Address = "fc00:1::1"; }; - node2 = mkNode { replicationMode = "3"; publicV6Address = "fc00:1::2"; }; - node3 = mkNode { replicationMode = "3"; publicV6Address = "fc00:1::3"; }; - node4 = mkNode { replicationMode = "3"; publicV6Address = "fc00:1::4"; }; - }; - - testScript = '' - from typing import List - from dataclasses import dataclass - import re - start_all() - - cur_version_regex = re.compile('Current cluster layout version: (?P\d*)') - key_creation_regex = re.compile('Key name: (?P.*)\nKey ID: (?P.*)\nSecret key: (?P.*)') - - @dataclass - class S3Key: - key_name: str - key_id: str - secret_key: str - - @dataclass - class GarageNode: - node_id: str - host: str - - def get_node_fqn(machine: Machine) -> GarageNode: - node_id, host = machine.succeed("garage node id").split('@') - return GarageNode(node_id=node_id, host=host) - - def get_node_id(machine: Machine) -> str: - return get_node_fqn(machine).node_id - - def get_layout_version(machine: Machine) -> int: - version_data = machine.succeed("garage layout show") - m = cur_version_regex.search(version_data) - if m and m.group('ver') is not None: - return int(m.group('ver')) + 1 - else: - raise ValueError('Cannot find current layout version') - - def apply_garage_layout(machine: Machine, layouts: List[str]): - for layout in layouts: - machine.succeed(f"garage layout assign {layout}") - version = get_layout_version(machine) - machine.succeed(f"garage layout apply --version {version}") - - def create_api_key(machine: Machine, key_name: str) -> S3Key: - output = machine.succeed(f"garage key ${if ver == "0_8" then "new --name" else "create"} {key_name}") - m = key_creation_regex.match(output) - if not m or not m.group('key_id') or not m.group('secret_key'): - raise ValueError('Cannot parse API key data') - return S3Key(key_name=key_name, key_id=m.group('key_id'), secret_key=m.group('secret_key')) - - def get_api_key(machine: Machine, key_pattern: str) -> S3Key: - output = machine.succeed(f"garage key info {key_pattern}") - m = key_creation_regex.match(output) - if not m or not m.group('key_name') or not m.group('key_id') or not m.group('secret_key'): - raise ValueError('Cannot parse API key data') - return S3Key(key_name=m.group('key_name'), key_id=m.group('key_id'), secret_key=m.group('secret_key')) - - def test_bucket_writes(node): - node.succeed("garage bucket create test-bucket") - s3_key = create_api_key(node, "test-api-key") - node.succeed("garage bucket allow --read --write test-bucket --key test-api-key") - other_s3_key = get_api_key(node, 'test-api-key') - assert other_s3_key.secret_key == other_s3_key.secret_key - node.succeed( - f"mc alias set test-garage http://[::1]:3900 {s3_key.key_id} {s3_key.secret_key} --api S3v4" - ) - node.succeed("echo test | mc pipe test-garage/test-bucket/test.txt") - assert node.succeed("mc cat test-garage/test-bucket/test.txt").strip() == "test" - - def test_bucket_over_http(node, bucket='test-bucket', url=None): - if url is None: - url = f"{bucket}.web.garage" - - node.succeed(f'garage bucket website --allow {bucket}') - node.succeed(f'echo hello world | mc pipe test-garage/{bucket}/index.html') - assert (node.succeed(f"curl -H 'Host: {url}' http://localhost:3902")).strip() == 'hello world' - - with subtest("Garage works as a multi-node S3 storage"): - nodes = ('node1', 'node2', 'node3', 'node4') - rev_machines = {m.name: m for m in machines} - def get_machine(key): return rev_machines[key] - for key in nodes: - node = get_machine(key) - node.wait_for_unit("garage.service") - node.wait_for_open_port(3900) - - # Garage is initialized on all nodes. - node_ids = {key: get_node_fqn(get_machine(key)) for key in nodes} - - for key in nodes: - for other_key in nodes: - if other_key != key: - other_id = node_ids[other_key] - get_machine(key).succeed(f"garage node connect {other_id.node_id}@{other_id.host}") - - # Provide multiple zones for the nodes. - zones = ["nixcon", "nixcon", "paris_meetup", "fosdem"] - apply_garage_layout(node1, - [ - f'{ndata.node_id} -z {zones[index]} -c ${if ver == "0_8" then "1" else "1G"}' - for index, ndata in enumerate(node_ids.values()) - ]) - # Now Garage is operational. - test_bucket_writes(node1) - for node in nodes: - test_bucket_over_http(get_machine(node)) - ''; -})) args +(import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "garage-3node-replication"; + meta = { + maintainers = with pkgs.lib.maintainers; [ raitobezarius ]; + }; + + nodes = { + node1 = mkNode { + replicationMode = "3"; + publicV6Address = "fc00:1::1"; + }; + node2 = mkNode { + replicationMode = "3"; + publicV6Address = "fc00:1::2"; + }; + node3 = mkNode { + replicationMode = "3"; + publicV6Address = "fc00:1::3"; + }; + node4 = mkNode { + replicationMode = "3"; + publicV6Address = "fc00:1::4"; + }; + }; + + testScript = '' + from typing import List + from dataclasses import dataclass + import re + start_all() + + cur_version_regex = re.compile('Current cluster layout version: (?P\d*)') + key_creation_regex = re.compile('Key name: (?P.*)\nKey ID: (?P.*)\nSecret key: (?P.*)') + + @dataclass + class S3Key: + key_name: str + key_id: str + secret_key: str + + @dataclass + class GarageNode: + node_id: str + host: str + + def get_node_fqn(machine: Machine) -> GarageNode: + node_id, host = machine.succeed("garage node id").split('@') + return GarageNode(node_id=node_id, host=host) + + def get_node_id(machine: Machine) -> str: + return get_node_fqn(machine).node_id + + def get_layout_version(machine: Machine) -> int: + version_data = machine.succeed("garage layout show") + m = cur_version_regex.search(version_data) + if m and m.group('ver') is not None: + return int(m.group('ver')) + 1 + else: + raise ValueError('Cannot find current layout version') + + def apply_garage_layout(machine: Machine, layouts: List[str]): + for layout in layouts: + machine.succeed(f"garage layout assign {layout}") + version = get_layout_version(machine) + machine.succeed(f"garage layout apply --version {version}") + + def create_api_key(machine: Machine, key_name: str) -> S3Key: + output = machine.succeed(f"garage key ${ + if ver == "0_8" then "new --name" else "create" + } {key_name}") + m = key_creation_regex.match(output) + if not m or not m.group('key_id') or not m.group('secret_key'): + raise ValueError('Cannot parse API key data') + return S3Key(key_name=key_name, key_id=m.group('key_id'), secret_key=m.group('secret_key')) + + def get_api_key(machine: Machine, key_pattern: str) -> S3Key: + output = machine.succeed(f"garage key info {key_pattern}") + m = key_creation_regex.match(output) + if not m or not m.group('key_name') or not m.group('key_id') or not m.group('secret_key'): + raise ValueError('Cannot parse API key data') + return S3Key(key_name=m.group('key_name'), key_id=m.group('key_id'), secret_key=m.group('secret_key')) + + def test_bucket_writes(node): + node.succeed("garage bucket create test-bucket") + s3_key = create_api_key(node, "test-api-key") + node.succeed("garage bucket allow --read --write test-bucket --key test-api-key") + other_s3_key = get_api_key(node, 'test-api-key') + assert other_s3_key.secret_key == other_s3_key.secret_key + node.succeed( + f"mc alias set test-garage http://[::1]:3900 {s3_key.key_id} {s3_key.secret_key} --api S3v4" + ) + node.succeed("echo test | mc pipe test-garage/test-bucket/test.txt") + assert node.succeed("mc cat test-garage/test-bucket/test.txt").strip() == "test" + + def test_bucket_over_http(node, bucket='test-bucket', url=None): + if url is None: + url = f"{bucket}.web.garage" + + node.succeed(f'garage bucket website --allow {bucket}') + node.succeed(f'echo hello world | mc pipe test-garage/{bucket}/index.html') + assert (node.succeed(f"curl -H 'Host: {url}' http://localhost:3902")).strip() == 'hello world' + + with subtest("Garage works as a multi-node S3 storage"): + nodes = ('node1', 'node2', 'node3', 'node4') + rev_machines = {m.name: m for m in machines} + def get_machine(key): return rev_machines[key] + for key in nodes: + node = get_machine(key) + node.wait_for_unit("garage.service") + node.wait_for_open_port(3900) + + # Garage is initialized on all nodes. + node_ids = {key: get_node_fqn(get_machine(key)) for key in nodes} + + for key in nodes: + for other_key in nodes: + if other_key != key: + other_id = node_ids[other_key] + get_machine(key).succeed(f"garage node connect {other_id.node_id}@{other_id.host}") + + # Provide multiple zones for the nodes. + zones = ["nixcon", "nixcon", "paris_meetup", "fosdem"] + apply_garage_layout(node1, + [ + f'{ndata.node_id} -z {zones[index]} -c ${if ver == "0_8" then "1" else "1G"}' + for index, ndata in enumerate(node_ids.values()) + ]) + # Now Garage is operational. + test_bucket_writes(node1) + for node in nodes: + test_bucket_over_http(get_machine(node)) + ''; + } +)) + args diff --git a/nixos/tests/gemstash.nix b/nixos/tests/gemstash.nix index bc152e42e92eb8..1b87228e9e63cf 100644 --- a/nixos/tests/gemstash.nix +++ b/nixos/tests/gemstash.nix @@ -1,21 +1,29 @@ -{ system ? builtins.currentSystem, config ? { } -, pkgs ? import ../.. { inherit system config; } }: +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, +}: with import ../lib/testing-python.nix { inherit system pkgs; }; with pkgs.lib; -let common_meta = { maintainers = [ maintainers.viraptor ]; }; +let + common_meta = { + maintainers = [ maintainers.viraptor ]; + }; in { gemstash_works = makeTest { name = "gemstash-works"; meta = common_meta; - nodes.machine = { config, pkgs, ... }: { - services.gemstash = { - enable = true; + nodes.machine = + { config, pkgs, ... }: + { + services.gemstash = { + enable = true; + }; }; - }; # gemstash responds to http requests testScript = '' @@ -30,15 +38,17 @@ in name = "gemstash-custom-port"; meta = common_meta; - nodes.machine = { config, pkgs, ... }: { - services.gemstash = { - enable = true; - openFirewall = true; - settings = { - bind = "tcp://0.0.0.0:12345"; + nodes.machine = + { config, pkgs, ... }: + { + services.gemstash = { + enable = true; + openFirewall = true; + settings = { + bind = "tcp://0.0.0.0:12345"; + }; }; }; - }; # gemstash responds to http requests testScript = '' diff --git a/nixos/tests/geoserver.nix b/nixos/tests/geoserver.nix index 4f6f2b209d07f6..3e9416961e90a2 100644 --- a/nixos/tests/geoserver.nix +++ b/nixos/tests/geoserver.nix @@ -8,9 +8,12 @@ let # - wps-jdbc needs a running (Postrgres) db server. blacklist = [ "wps-jdbc" ]; - blacklistedToNull = n: v: if ! builtins.elem n blacklist then v else null; - getNonBlackistedExtensionsAsList = ps: builtins.filter (x: x != null) (lib.attrsets.mapAttrsToList blacklistedToNull ps); - geoserverWithAllExtensions = pkgs.geoserver.withExtensions (ps: getNonBlackistedExtensionsAsList ps); + blacklistedToNull = n: v: if !builtins.elem n blacklist then v else null; + getNonBlackistedExtensionsAsList = + ps: builtins.filter (x: x != null) (lib.attrsets.mapAttrsToList blacklistedToNull ps); + geoserverWithAllExtensions = pkgs.geoserver.withExtensions ( + ps: getNonBlackistedExtensionsAsList ps + ); in { @@ -20,15 +23,17 @@ in }; nodes = { - machine = { pkgs, ... }: { - virtualisation.diskSize = 2 * 1024; - - environment.systemPackages = [ - geoserver - geoserverWithImporterExtension - geoserverWithAllExtensions - ]; - }; + machine = + { pkgs, ... }: + { + virtualisation.diskSize = 2 * 1024; + + environment.systemPackages = [ + geoserver + geoserverWithImporterExtension + geoserverWithAllExtensions + ]; + }; }; testScript = '' diff --git a/nixos/tests/gerrit.nix b/nixos/tests/gerrit.nix index 4630f941294830..86e4cf90ed734b 100644 --- a/nixos/tests/gerrit.nix +++ b/nixos/tests/gerrit.nix @@ -1,45 +1,57 @@ -import ./make-test-python.nix ({ pkgs, ... }: - -{ - name = "gerrit"; - - meta = with pkgs.lib.maintainers; { - maintainers = [ flokli zimbatm ]; - }; - - nodes = { - server = - { config, pkgs, ... }: { - networking.firewall.allowedTCPPorts = [ 80 2222 ]; - - - services.gerrit = { - enable = true; - serverId = "aa76c84b-50b0-4711-a0a0-1ee30e45bbd0"; - listenAddress = "[::]:80"; - jvmHeapLimit = "1g"; - - builtinPlugins = [ "hooks" "webhooks" ]; - settings = { - gerrit.canonicalWebUrl = "http://server"; - sshd.listenAddress = "[::]:2222"; - sshd.advertisedAddress = "[::]:2222"; +import ./make-test-python.nix ( + { pkgs, ... }: + + { + name = "gerrit"; + + meta = with pkgs.lib.maintainers; { + maintainers = [ + flokli + zimbatm + ]; + }; + + nodes = { + server = + { config, pkgs, ... }: + { + networking.firewall.allowedTCPPorts = [ + 80 + 2222 + ]; + + services.gerrit = { + enable = true; + serverId = "aa76c84b-50b0-4711-a0a0-1ee30e45bbd0"; + listenAddress = "[::]:80"; + jvmHeapLimit = "1g"; + + builtinPlugins = [ + "hooks" + "webhooks" + ]; + settings = { + gerrit.canonicalWebUrl = "http://server"; + sshd.listenAddress = "[::]:2222"; + sshd.advertisedAddress = "[::]:2222"; + }; }; }; - }; - - client = - { ... }: { - }; - }; - - testScript = '' - start_all() - server.wait_for_unit("gerrit.service") - server.wait_for_open_port(80) - client.succeed("curl http://server") - - server.wait_for_open_port(2222) - client.succeed("nc -z server 2222") - ''; -}) + + client = + { ... }: + { + }; + }; + + testScript = '' + start_all() + server.wait_for_unit("gerrit.service") + server.wait_for_open_port(80) + client.succeed("curl http://server") + + server.wait_for_open_port(2222) + client.succeed("nc -z server 2222") + ''; + } +) diff --git a/nixos/tests/geth.nix b/nixos/tests/geth.nix index 7f7315271088ef..984b46935b865e 100644 --- a/nixos/tests/geth.nix +++ b/nixos/tests/geth.nix @@ -1,45 +1,50 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "geth"; - meta = with pkgs.lib; { - maintainers = with maintainers; [bachp ]; - }; - - nodes.machine = { ... }: { - services.geth."mainnet" = { - enable = true; - http = { - enable = true; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "geth"; + meta = with pkgs.lib; { + maintainers = with maintainers; [ bachp ]; }; - services.geth."testnet" = { - enable = true; - port = 30304; - network = "holesky"; - http = { - enable = true; - port = 18545; - }; - authrpc = { - enable = true; - port = 18551; + + nodes.machine = + { ... }: + { + services.geth."mainnet" = { + enable = true; + http = { + enable = true; + }; + }; + services.geth."testnet" = { + enable = true; + port = 30304; + network = "holesky"; + http = { + enable = true; + port = 18545; + }; + authrpc = { + enable = true; + port = 18551; + }; + }; }; - }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("geth-mainnet.service") - machine.wait_for_unit("geth-testnet.service") - machine.wait_for_open_port(8545) - machine.wait_for_open_port(18545) + machine.wait_for_unit("geth-mainnet.service") + machine.wait_for_unit("geth-testnet.service") + machine.wait_for_open_port(8545) + machine.wait_for_open_port(18545) - machine.succeed( - 'geth attach --exec "eth.blockNumber" http://localhost:8545 | grep \'^0$\' ' - ) + machine.succeed( + 'geth attach --exec "eth.blockNumber" http://localhost:8545 | grep \'^0$\' ' + ) - machine.succeed( - 'geth attach --exec "eth.blockNumber" http://localhost:18545 | grep \'^0$\' ' - ) - ''; -}) + machine.succeed( + 'geth attach --exec "eth.blockNumber" http://localhost:18545 | grep \'^0$\' ' + ) + ''; + } +) diff --git a/nixos/tests/ghostunnel.nix b/nixos/tests/ghostunnel.nix index 91a7b7085f67b8..bd16a802e60d72 100644 --- a/nixos/tests/ghostunnel.nix +++ b/nixos/tests/ghostunnel.nix @@ -1,104 +1,116 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "ghostunnel"; - nodes = { - backend = { pkgs, ... }: { - services.nginx.enable = true; - services.nginx.virtualHosts."backend".root = pkgs.runCommand "webroot" {} '' - mkdir $out - echo hi >$out/hi.txt - ''; - networking.firewall.allowedTCPPorts = [ 80 ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "ghostunnel"; + nodes = { + backend = + { pkgs, ... }: + { + services.nginx.enable = true; + services.nginx.virtualHosts."backend".root = pkgs.runCommand "webroot" { } '' + mkdir $out + echo hi >$out/hi.txt + ''; + networking.firewall.allowedTCPPorts = [ 80 ]; + }; + service = + { ... }: + { + services.ghostunnel.enable = true; + services.ghostunnel.servers."plain-old" = { + listen = "0.0.0.0:443"; + cert = "/root/service-cert.pem"; + key = "/root/service-key.pem"; + disableAuthentication = true; + target = "backend:80"; + unsafeTarget = true; + }; + services.ghostunnel.servers."client-cert" = { + listen = "0.0.0.0:1443"; + cert = "/root/service-cert.pem"; + key = "/root/service-key.pem"; + cacert = "/root/ca.pem"; + target = "backend:80"; + allowCN = [ "client" ]; + unsafeTarget = true; + }; + networking.firewall.allowedTCPPorts = [ + 443 + 1443 + ]; + }; + client = + { pkgs, ... }: + { + environment.systemPackages = [ + pkgs.curl + ]; + }; }; - service = { ... }: { - services.ghostunnel.enable = true; - services.ghostunnel.servers."plain-old" = { - listen = "0.0.0.0:443"; - cert = "/root/service-cert.pem"; - key = "/root/service-key.pem"; - disableAuthentication = true; - target = "backend:80"; - unsafeTarget = true; - }; - services.ghostunnel.servers."client-cert" = { - listen = "0.0.0.0:1443"; - cert = "/root/service-cert.pem"; - key = "/root/service-key.pem"; - cacert = "/root/ca.pem"; - target = "backend:80"; - allowCN = ["client"]; - unsafeTarget = true; - }; - networking.firewall.allowedTCPPorts = [ 443 1443 ]; - }; - client = { pkgs, ... }: { - environment.systemPackages = [ - pkgs.curl - ]; - }; - }; - testScript = '' + testScript = '' - # prepare certificates + # prepare certificates - def cmd(command): - print(f"+{command}") - r = os.system(command) - if r != 0: - raise Exception(f"Command {command} failed with exit code {r}") + def cmd(command): + print(f"+{command}") + r = os.system(command) + if r != 0: + raise Exception(f"Command {command} failed with exit code {r}") - # Create CA - cmd("${pkgs.openssl}/bin/openssl genrsa -out ca-key.pem 4096") - cmd("${pkgs.openssl}/bin/openssl req -new -x509 -days 365 -key ca-key.pem -sha256 -subj '/C=NL/ST=Zuid-Holland/L=The Hague/O=Stevige Balken en Planken B.V./OU=OpSec/CN=Certificate Authority' -out ca.pem") + # Create CA + cmd("${pkgs.openssl}/bin/openssl genrsa -out ca-key.pem 4096") + cmd("${pkgs.openssl}/bin/openssl req -new -x509 -days 365 -key ca-key.pem -sha256 -subj '/C=NL/ST=Zuid-Holland/L=The Hague/O=Stevige Balken en Planken B.V./OU=OpSec/CN=Certificate Authority' -out ca.pem") - # Create service - cmd("${pkgs.openssl}/bin/openssl genrsa -out service-key.pem 4096") - cmd("${pkgs.openssl}/bin/openssl req -subj '/CN=service' -sha256 -new -key service-key.pem -out service.csr") - cmd("echo subjectAltName = DNS:service,IP:127.0.0.1 >> extfile.cnf") - cmd("echo extendedKeyUsage = serverAuth >> extfile.cnf") - cmd("${pkgs.openssl}/bin/openssl x509 -req -days 365 -sha256 -in service.csr -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out service-cert.pem -extfile extfile.cnf") + # Create service + cmd("${pkgs.openssl}/bin/openssl genrsa -out service-key.pem 4096") + cmd("${pkgs.openssl}/bin/openssl req -subj '/CN=service' -sha256 -new -key service-key.pem -out service.csr") + cmd("echo subjectAltName = DNS:service,IP:127.0.0.1 >> extfile.cnf") + cmd("echo extendedKeyUsage = serverAuth >> extfile.cnf") + cmd("${pkgs.openssl}/bin/openssl x509 -req -days 365 -sha256 -in service.csr -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out service-cert.pem -extfile extfile.cnf") - # Create client - cmd("${pkgs.openssl}/bin/openssl genrsa -out client-key.pem 4096") - cmd("${pkgs.openssl}/bin/openssl req -subj '/CN=client' -new -key client-key.pem -out client.csr") - cmd("echo extendedKeyUsage = clientAuth > extfile-client.cnf") - cmd("${pkgs.openssl}/bin/openssl x509 -req -days 365 -sha256 -in client.csr -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out client-cert.pem -extfile extfile-client.cnf") + # Create client + cmd("${pkgs.openssl}/bin/openssl genrsa -out client-key.pem 4096") + cmd("${pkgs.openssl}/bin/openssl req -subj '/CN=client' -new -key client-key.pem -out client.csr") + cmd("echo extendedKeyUsage = clientAuth > extfile-client.cnf") + cmd("${pkgs.openssl}/bin/openssl x509 -req -days 365 -sha256 -in client.csr -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out client-cert.pem -extfile extfile-client.cnf") - cmd("ls -al") + cmd("ls -al") - start_all() + start_all() - # Configuration - service.copy_from_host("ca.pem", "/root/ca.pem") - service.copy_from_host("service-cert.pem", "/root/service-cert.pem") - service.copy_from_host("service-key.pem", "/root/service-key.pem") - client.copy_from_host("ca.pem", "/root/ca.pem") - client.copy_from_host("service-cert.pem", "/root/service-cert.pem") - client.copy_from_host("client-cert.pem", "/root/client-cert.pem") - client.copy_from_host("client-key.pem", "/root/client-key.pem") + # Configuration + service.copy_from_host("ca.pem", "/root/ca.pem") + service.copy_from_host("service-cert.pem", "/root/service-cert.pem") + service.copy_from_host("service-key.pem", "/root/service-key.pem") + client.copy_from_host("ca.pem", "/root/ca.pem") + client.copy_from_host("service-cert.pem", "/root/service-cert.pem") + client.copy_from_host("client-cert.pem", "/root/client-cert.pem") + client.copy_from_host("client-key.pem", "/root/client-key.pem") - backend.wait_for_unit("nginx.service") - service.wait_for_unit("multi-user.target") - service.wait_for_unit("multi-user.target") - client.wait_for_unit("multi-user.target") + backend.wait_for_unit("nginx.service") + service.wait_for_unit("multi-user.target") + service.wait_for_unit("multi-user.target") + client.wait_for_unit("multi-user.target") - # Check assumptions before the real test - client.succeed("bash -c 'diff <(curl -v --no-progress-meter http://backend/hi.txt) <(echo hi)'") + # Check assumptions before the real test + client.succeed("bash -c 'diff <(curl -v --no-progress-meter http://backend/hi.txt) <(echo hi)'") - # Plain old simple TLS can connect, ignoring cert - client.succeed("bash -c 'diff <(curl -v --no-progress-meter --insecure https://service/hi.txt) <(echo hi)'") + # Plain old simple TLS can connect, ignoring cert + client.succeed("bash -c 'diff <(curl -v --no-progress-meter --insecure https://service/hi.txt) <(echo hi)'") - # Plain old simple TLS provides correct signature with its cert - client.succeed("bash -c 'diff <(curl -v --no-progress-meter --cacert /root/ca.pem https://service/hi.txt) <(echo hi)'") + # Plain old simple TLS provides correct signature with its cert + client.succeed("bash -c 'diff <(curl -v --no-progress-meter --cacert /root/ca.pem https://service/hi.txt) <(echo hi)'") - # Client can authenticate with certificate - client.succeed("bash -c 'diff <(curl -v --no-progress-meter --cert /root/client-cert.pem --key /root/client-key.pem --cacert /root/ca.pem https://service:1443/hi.txt) <(echo hi)'") + # Client can authenticate with certificate + client.succeed("bash -c 'diff <(curl -v --no-progress-meter --cert /root/client-cert.pem --key /root/client-key.pem --cacert /root/ca.pem https://service:1443/hi.txt) <(echo hi)'") - # Client must authenticate with certificate - client.fail("bash -c 'diff <(curl -v --no-progress-meter --cacert /root/ca.pem https://service:1443/hi.txt) <(echo hi)'") - ''; + # Client must authenticate with certificate + client.fail("bash -c 'diff <(curl -v --no-progress-meter --cacert /root/ca.pem https://service:1443/hi.txt) <(echo hi)'") + ''; - meta.maintainers = with pkgs.lib.maintainers; [ - roberth - ]; -}) + meta.maintainers = with pkgs.lib.maintainers; [ + roberth + ]; + } +) diff --git a/nixos/tests/git/hub.nix b/nixos/tests/git/hub.nix index 4f3189861a0046..43ae2b7ab30b9e 100644 --- a/nixos/tests/git/hub.nix +++ b/nixos/tests/git/hub.nix @@ -1,17 +1,20 @@ -import ../make-test-python.nix ({ pkgs, ...} : { - name = "hub"; - meta = with pkgs.lib.maintainers; { - maintainers = [ nequissimus ]; - }; - - nodes.hub = { pkgs, ... }: - { - environment.systemPackages = [ pkgs.hub ]; +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "hub"; + meta = with pkgs.lib.maintainers; { + maintainers = [ nequissimus ]; }; - testScript = - '' + nodes.hub = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.hub ]; + }; + + testScript = '' assert "git version ${pkgs.git.version}\nhub version ${pkgs.hub.version}\n" in hub.succeed("hub version") assert "These GitHub commands are provided by hub" in hub.succeed("hub help") ''; -}) + } +) diff --git a/nixos/tests/gitdaemon.nix b/nixos/tests/gitdaemon.nix index 2211960b457f88..41a29168bda449 100644 --- a/nixos/tests/gitdaemon.nix +++ b/nixos/tests/gitdaemon.nix @@ -1,78 +1,83 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -let - hashes = pkgs.writeText "hashes" '' - b5bb9d8014a0f9b1d61e21e796d78dccdf1352f23cd32812f4850b878ae4944c /project/bar - ''; -in { - name = "gitdaemon"; + let + hashes = pkgs.writeText "hashes" '' + b5bb9d8014a0f9b1d61e21e796d78dccdf1352f23cd32812f4850b878ae4944c /project/bar + ''; + in + { + name = "gitdaemon"; - meta = with pkgs.lib.maintainers; { - maintainers = [ tilpner ]; - }; + meta = with pkgs.lib.maintainers; { + maintainers = [ tilpner ]; + }; - nodes = { - server = - { config, ... }: { - networking.firewall.allowedTCPPorts = [ config.services.gitDaemon.port ]; + nodes = { + server = + { config, ... }: + { + networking.firewall.allowedTCPPorts = [ config.services.gitDaemon.port ]; - environment.systemPackages = [ pkgs.git ]; + environment.systemPackages = [ pkgs.git ]; - systemd.tmpfiles.rules = [ - # type path mode user group age arg - " d /git 0755 git git - -" - ]; + systemd.tmpfiles.rules = [ + # type path mode user group age arg + " d /git 0755 git git - -" + ]; - services.gitDaemon = { - enable = true; - basePath = "/git"; + services.gitDaemon = { + enable = true; + basePath = "/git"; + }; }; - }; - client = - { pkgs, ... }: { - environment.systemPackages = [ pkgs.git ]; - }; - }; + client = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.git ]; + }; + }; - testScript = '' - start_all() + testScript = '' + start_all() - with subtest("create project.git"): - server.succeed( - "git init --bare /git/project.git", - "touch /git/project.git/git-daemon-export-ok", - ) + with subtest("create project.git"): + server.succeed( + "git init --bare /git/project.git", + "touch /git/project.git/git-daemon-export-ok", + ) - with subtest("add file to project.git"): - server.succeed( - "git clone /git/project.git /project", - "echo foo > /project/bar", - "git config --global user.email 'you@example.com'", - "git config --global user.name 'Your Name'", - "git -C /project add bar", - "git -C /project commit -m 'quux'", - "git -C /project push", - "rm -r /project", - ) + with subtest("add file to project.git"): + server.succeed( + "git clone /git/project.git /project", + "echo foo > /project/bar", + "git config --global user.email 'you@example.com'", + "git config --global user.name 'Your Name'", + "git -C /project add bar", + "git -C /project commit -m 'quux'", + "git -C /project push", + "rm -r /project", + ) - # Change user/group to default daemon user/group from module - # to avoid "fatal: detected dubious ownership in repository at '/git/project.git'" - server.succeed("chown git:git -R /git/project.git") + # Change user/group to default daemon user/group from module + # to avoid "fatal: detected dubious ownership in repository at '/git/project.git'" + server.succeed("chown git:git -R /git/project.git") - with subtest("git daemon starts"): - server.wait_for_unit("git-daemon.service") + with subtest("git daemon starts"): + server.wait_for_unit("git-daemon.service") - server.systemctl("start network-online.target") - client.systemctl("start network-online.target") - server.wait_for_unit("network-online.target") - client.wait_for_unit("network-online.target") + server.systemctl("start network-online.target") + client.systemctl("start network-online.target") + server.wait_for_unit("network-online.target") + client.wait_for_unit("network-online.target") - with subtest("client can clone project.git"): - client.succeed( - "git clone git://server/project.git /project", - "sha256sum -c ${hashes}", - ) - ''; -}) + with subtest("client can clone project.git"): + client.succeed( + "git clone git://server/project.git /project", + "sha256sum -c ${hashes}", + ) + ''; + } +) diff --git a/nixos/tests/gitea.nix b/nixos/tests/gitea.nix index f62c72bddddca1..255ff3485e5a19 100644 --- a/nixos/tests/gitea.nix +++ b/nixos/tests/gitea.nix @@ -1,7 +1,8 @@ -{ system ? builtins.currentSystem, - config ? {}, +{ + system ? builtins.currentSystem, + config ? { }, giteaPackage ? pkgs.gitea, - pkgs ? import ../.. { inherit system config; } + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -23,143 +24,166 @@ let ''; signingPrivateKeyId = "4D642DE8B678C79D"; - supportedDbTypes = [ "mysql" "postgres" "sqlite3" ]; - makeGiteaTest = type: nameValuePair type (makeTest { - name = "${giteaPackage.pname}-${type}"; - meta.maintainers = with maintainers; [ aanderse kolaente ma27 ]; - - nodes = { - server = { config, pkgs, ... }: { - virtualisation.memorySize = 2047; - services.gitea = { - enable = true; - database = { inherit type; }; - package = giteaPackage; - metricsTokenFile = (pkgs.writeText "metrics_secret" "fakesecret").outPath; - settings.service.DISABLE_REGISTRATION = true; - settings."repository.signing".SIGNING_KEY = signingPrivateKeyId; - settings.actions.ENABLED = true; - settings.metrics.ENABLED = true; - }; - environment.systemPackages = [ giteaPackage pkgs.gnupg pkgs.jq ]; - services.openssh.enable = true; - - specialisation.runner = { - inheritParentConfig = true; - - configuration.services.gitea-actions-runner.instances."test" = { - enable = true; - name = "ci"; - url = "http://localhost:3000"; - labels = [ - # don't require docker/podman - "native:host" + supportedDbTypes = [ + "mysql" + "postgres" + "sqlite3" + ]; + makeGiteaTest = + type: + nameValuePair type (makeTest { + name = "${giteaPackage.pname}-${type}"; + meta.maintainers = with maintainers; [ + aanderse + kolaente + ma27 + ]; + + nodes = { + server = + { config, pkgs, ... }: + { + virtualisation.memorySize = 2047; + services.gitea = { + enable = true; + database = { inherit type; }; + package = giteaPackage; + metricsTokenFile = (pkgs.writeText "metrics_secret" "fakesecret").outPath; + settings.service.DISABLE_REGISTRATION = true; + settings."repository.signing".SIGNING_KEY = signingPrivateKeyId; + settings.actions.ENABLED = true; + settings.metrics.ENABLED = true; + }; + environment.systemPackages = [ + giteaPackage + pkgs.gnupg + pkgs.jq ]; - tokenFile = "/var/lib/gitea/runner_token"; + services.openssh.enable = true; + + specialisation.runner = { + inheritParentConfig = true; + + configuration.services.gitea-actions-runner.instances."test" = { + enable = true; + name = "ci"; + url = "http://localhost:3000"; + labels = [ + # don't require docker/podman + "native:host" + ]; + tokenFile = "/var/lib/gitea/runner_token"; + }; + }; + }; + client1 = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.git ]; + }; + client2 = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.git ]; }; - }; - }; - client1 = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.git ]; - }; - client2 = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.git ]; }; - }; - - testScript = { nodes, ... }: let - inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; - serverSystem = nodes.server.system.build.toplevel; - in '' - GIT_SSH_COMMAND = "ssh -i $HOME/.ssh/privk -o StrictHostKeyChecking=no" - REPO = "gitea@server:test/repo" - PRIVK = "${snakeOilPrivateKey}" - - start_all() - - client1.succeed("mkdir /tmp/repo") - client1.succeed("mkdir -p $HOME/.ssh") - client1.succeed(f"cat {PRIVK} > $HOME/.ssh/privk") - client1.succeed("chmod 0400 $HOME/.ssh/privk") - client1.succeed("git -C /tmp/repo init") - client1.succeed("echo hello world > /tmp/repo/testfile") - client1.succeed("git -C /tmp/repo add .") - client1.succeed("git config --global user.email test@localhost") - client1.succeed("git config --global user.name test") - client1.succeed("git -C /tmp/repo commit -m 'Initial import'") - client1.succeed(f"git -C /tmp/repo remote add origin {REPO}") - - server.wait_for_unit("gitea.service") - server.wait_for_open_port(3000) - server.wait_for_open_port(22) - server.succeed("curl --fail http://localhost:3000/") - - server.succeed( - "su -l gitea -c 'gpg --homedir /var/lib/gitea/data/home/.gnupg " - + "--import ${toString (pkgs.writeText "gitea.key" signingPrivateKey)}'" - ) - - assert "BEGIN PGP PUBLIC KEY BLOCK" in server.succeed("curl http://localhost:3000/api/v1/signing-key.gpg") - - server.succeed( - "curl --fail http://localhost:3000/user/sign_up | grep 'Registration is disabled. " - + "Please contact your site administrator.'" - ) - server.succeed( - "su -l gitea -c 'GITEA_WORK_DIR=/var/lib/gitea gitea admin user create " - + "--username test --password totallysafe --email test@localhost'" - ) - - api_token = server.succeed( - "curl --fail -X POST http://test:totallysafe@localhost:3000/api/v1/users/test/tokens " - + "-H 'Accept: application/json' -H 'Content-Type: application/json' -d " - + "'{\"name\":\"token\",\"scopes\":[\"all\"]}' | jq '.sha1' | xargs echo -n" - ) - - server.succeed( - "curl --fail -X POST http://localhost:3000/api/v1/user/repos " - + "-H 'Accept: application/json' -H 'Content-Type: application/json' " - + f"-H 'Authorization: token {api_token}'" - + ' -d \'{"auto_init":false, "description":"string", "license":"mit", "name":"repo", "private":false}\''' - ) - - server.succeed( - "curl --fail -X POST http://localhost:3000/api/v1/user/keys " - + "-H 'Accept: application/json' -H 'Content-Type: application/json' " - + f"-H 'Authorization: token {api_token}'" - + ' -d \'{"key":"${snakeOilPublicKey}","read_only":true,"title":"SSH"}\''' - ) - - client1.succeed( - f"GIT_SSH_COMMAND='{GIT_SSH_COMMAND}' git -C /tmp/repo push origin master" - ) - - client2.succeed("mkdir -p $HOME/.ssh") - client2.succeed(f"cat {PRIVK} > $HOME/.ssh/privk") - client2.succeed("chmod 0400 $HOME/.ssh/privk") - client2.succeed(f"GIT_SSH_COMMAND='{GIT_SSH_COMMAND}' git clone {REPO}") - client2.succeed('test "$(cat repo/testfile | xargs echo -n)" = "hello world"') - - server.wait_until_succeeds( - 'test "$(curl http://localhost:3000/api/v1/repos/test/repo/commits ' - + '-H "Accept: application/json" | jq length)" = "1"' - ) - - with subtest("Testing metrics endpoint"): - server.succeed('curl ' - + '-H "Authorization: Bearer fakesecret" ' - + 'http://localhost:3000/metrics ' - + '| grep gitea_accesses') - - with subtest("Testing runner registration"): + + testScript = + { nodes, ... }: + let + inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; + serverSystem = nodes.server.system.build.toplevel; + in + '' + GIT_SSH_COMMAND = "ssh -i $HOME/.ssh/privk -o StrictHostKeyChecking=no" + REPO = "gitea@server:test/repo" + PRIVK = "${snakeOilPrivateKey}" + + start_all() + + client1.succeed("mkdir /tmp/repo") + client1.succeed("mkdir -p $HOME/.ssh") + client1.succeed(f"cat {PRIVK} > $HOME/.ssh/privk") + client1.succeed("chmod 0400 $HOME/.ssh/privk") + client1.succeed("git -C /tmp/repo init") + client1.succeed("echo hello world > /tmp/repo/testfile") + client1.succeed("git -C /tmp/repo add .") + client1.succeed("git config --global user.email test@localhost") + client1.succeed("git config --global user.name test") + client1.succeed("git -C /tmp/repo commit -m 'Initial import'") + client1.succeed(f"git -C /tmp/repo remote add origin {REPO}") + + server.wait_for_unit("gitea.service") + server.wait_for_open_port(3000) + server.wait_for_open_port(22) + server.succeed("curl --fail http://localhost:3000/") + + server.succeed( + "su -l gitea -c 'gpg --homedir /var/lib/gitea/data/home/.gnupg " + + "--import ${toString (pkgs.writeText "gitea.key" signingPrivateKey)}'" + ) + + assert "BEGIN PGP PUBLIC KEY BLOCK" in server.succeed("curl http://localhost:3000/api/v1/signing-key.gpg") + + server.succeed( + "curl --fail http://localhost:3000/user/sign_up | grep 'Registration is disabled. " + + "Please contact your site administrator.'" + ) + server.succeed( + "su -l gitea -c 'GITEA_WORK_DIR=/var/lib/gitea gitea admin user create " + + "--username test --password totallysafe --email test@localhost'" + ) + + api_token = server.succeed( + "curl --fail -X POST http://test:totallysafe@localhost:3000/api/v1/users/test/tokens " + + "-H 'Accept: application/json' -H 'Content-Type: application/json' -d " + + "'{\"name\":\"token\",\"scopes\":[\"all\"]}' | jq '.sha1' | xargs echo -n" + ) + + server.succeed( + "curl --fail -X POST http://localhost:3000/api/v1/user/repos " + + "-H 'Accept: application/json' -H 'Content-Type: application/json' " + + f"-H 'Authorization: token {api_token}'" + + ' -d \'{"auto_init":false, "description":"string", "license":"mit", "name":"repo", "private":false}\''' + ) + server.succeed( - "su -l gitea -c 'GITEA_WORK_DIR=/var/lib/gitea gitea actions generate-runner-token' | sed 's/^/TOKEN=/' | tee /var/lib/gitea/runner_token" + "curl --fail -X POST http://localhost:3000/api/v1/user/keys " + + "-H 'Accept: application/json' -H 'Content-Type: application/json' " + + f"-H 'Authorization: token {api_token}'" + + ' -d \'{"key":"${snakeOilPublicKey}","read_only":true,"title":"SSH"}\''' ) - server.succeed("${serverSystem}/specialisation/runner/bin/switch-to-configuration test") - server.wait_for_unit("gitea-runner-test.service") - server.succeed("journalctl -o cat -u gitea-runner-test.service | grep -q 'Runner registered successfully'") - ''; - }); + + client1.succeed( + f"GIT_SSH_COMMAND='{GIT_SSH_COMMAND}' git -C /tmp/repo push origin master" + ) + + client2.succeed("mkdir -p $HOME/.ssh") + client2.succeed(f"cat {PRIVK} > $HOME/.ssh/privk") + client2.succeed("chmod 0400 $HOME/.ssh/privk") + client2.succeed(f"GIT_SSH_COMMAND='{GIT_SSH_COMMAND}' git clone {REPO}") + client2.succeed('test "$(cat repo/testfile | xargs echo -n)" = "hello world"') + + server.wait_until_succeeds( + 'test "$(curl http://localhost:3000/api/v1/repos/test/repo/commits ' + + '-H "Accept: application/json" | jq length)" = "1"' + ) + + with subtest("Testing metrics endpoint"): + server.succeed('curl ' + + '-H "Authorization: Bearer fakesecret" ' + + 'http://localhost:3000/metrics ' + + '| grep gitea_accesses') + + with subtest("Testing runner registration"): + server.succeed( + "su -l gitea -c 'GITEA_WORK_DIR=/var/lib/gitea gitea actions generate-runner-token' | sed 's/^/TOKEN=/' | tee /var/lib/gitea/runner_token" + ) + server.succeed("${serverSystem}/specialisation/runner/bin/switch-to-configuration test") + server.wait_for_unit("gitea-runner-test.service") + server.succeed("journalctl -o cat -u gitea-runner-test.service | grep -q 'Runner registered successfully'") + ''; + }); in listToAttrs (map makeGiteaTest supportedDbTypes) diff --git a/nixos/tests/github-runner.nix b/nixos/tests/github-runner.nix index f3e4b70fa5d3df..ffc0dbcc374b43 100644 --- a/nixos/tests/github-runner.nix +++ b/nixos/tests/github-runner.nix @@ -1,45 +1,49 @@ -import ./make-test-python.nix ({ pkgs, ... }: -{ - name = "github-runner"; - meta = with pkgs.lib.maintainers; { - maintainers = [ veehaitch ]; - }; - nodes.machine = { pkgs, ... }: { - services.github-runners.test = { - enable = true; - url = "https://github.com/yaxitech"; - tokenFile = builtins.toFile "github-runner.token" "not-so-secret"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "github-runner"; + meta = with pkgs.lib.maintainers; { + maintainers = [ veehaitch ]; }; - - services.github-runners.test-disabled = { - enable = false; - url = "https://github.com/yaxitech"; - tokenFile = builtins.toFile "github-runner.token" "not-so-secret"; - }; - - systemd.services.dummy-github-com = { - wantedBy = [ "multi-user.target" ]; - before = [ "github-runner-test.service" ]; - script = "${pkgs.netcat}/bin/nc -Fl 443 | true && touch /tmp/registration-connect"; - }; - networking.hosts."127.0.0.1" = [ "api.github.com" ]; - }; - - testScript = '' - start_all() - - machine.wait_for_unit("dummy-github-com") - - try: - machine.wait_for_unit("github-runner-test") - except Exception: - pass - - out = machine.succeed("journalctl -u github-runner-test") - assert "Self-hosted runner registration" in out, "did not read runner registration header" - - machine.wait_until_succeeds("test -f /tmp/registration-connect") - - machine.fail("systemctl list-unit-files | grep test-disabled") - ''; -}) + nodes.machine = + { pkgs, ... }: + { + services.github-runners.test = { + enable = true; + url = "https://github.com/yaxitech"; + tokenFile = builtins.toFile "github-runner.token" "not-so-secret"; + }; + + services.github-runners.test-disabled = { + enable = false; + url = "https://github.com/yaxitech"; + tokenFile = builtins.toFile "github-runner.token" "not-so-secret"; + }; + + systemd.services.dummy-github-com = { + wantedBy = [ "multi-user.target" ]; + before = [ "github-runner-test.service" ]; + script = "${pkgs.netcat}/bin/nc -Fl 443 | true && touch /tmp/registration-connect"; + }; + networking.hosts."127.0.0.1" = [ "api.github.com" ]; + }; + + testScript = '' + start_all() + + machine.wait_for_unit("dummy-github-com") + + try: + machine.wait_for_unit("github-runner-test") + except Exception: + pass + + out = machine.succeed("journalctl -u github-runner-test") + assert "Self-hosted runner registration" in out, "did not read runner registration header" + + machine.wait_until_succeeds("test -f /tmp/registration-connect") + + machine.fail("systemctl list-unit-files | grep test-disabled") + ''; + } +) diff --git a/nixos/tests/gitlab.nix b/nixos/tests/gitlab.nix index a099a8201ae502..da27cfbbc195c9 100644 --- a/nixos/tests/gitlab.nix +++ b/nixos/tests/gitlab.nix @@ -26,150 +26,179 @@ let bobUserId = "3"; bobPassword = "XwkkBbl2SiIwabQzgcoaTbhsotijEEtF"; bobProjectId = "2"; -in { +in +{ name = "gitlab"; - meta.maintainers = with lib.maintainers; [ globin yayayayaka ]; + meta.maintainers = with lib.maintainers; [ + globin + yayayayaka + ]; nodes = { - gitlab = { ... }: { - imports = [ common/user-account.nix ]; - - environment.systemPackages = with pkgs; [ git ]; - - virtualisation.memorySize = 6144; - virtualisation.cores = 4; - virtualisation.useNixStoreImage = true; - virtualisation.writableStore = false; - - systemd.services.gitlab.serviceConfig.Restart = lib.mkForce "no"; - systemd.services.gitlab-workhorse.serviceConfig.Restart = lib.mkForce "no"; - systemd.services.gitaly.serviceConfig.Restart = lib.mkForce "no"; - systemd.services.gitlab-sidekiq.serviceConfig.Restart = lib.mkForce "no"; - - services.nginx = { - enable = true; - recommendedProxySettings = true; - virtualHosts = { - localhost = { - locations."/".proxyPass = "http://unix:/run/gitlab/gitlab-workhorse.socket"; - }; - }; - }; + gitlab = + { ... }: + { + imports = [ common/user-account.nix ]; - services.openssh.enable = true; + environment.systemPackages = with pkgs; [ git ]; - services.dovecot2 = { - enable = true; - enableImap = true; - }; + virtualisation.memorySize = 6144; + virtualisation.cores = 4; + virtualisation.useNixStoreImage = true; + virtualisation.writableStore = false; - systemd.services.gitlab-backup.environment.BACKUP = "dump"; + systemd.services.gitlab.serviceConfig.Restart = lib.mkForce "no"; + systemd.services.gitlab-workhorse.serviceConfig.Restart = lib.mkForce "no"; + systemd.services.gitaly.serviceConfig.Restart = lib.mkForce "no"; + systemd.services.gitlab-sidekiq.serviceConfig.Restart = lib.mkForce "no"; - services.gitlab = { - enable = true; - databasePasswordFile = pkgs.writeText "dbPassword" "xo0daiF4"; - initialRootPasswordFile = pkgs.writeText "rootPassword" initialRootPassword; - smtp.enable = true; - pages = { + services.nginx = { enable = true; - settings.pages-domain = "localhost"; - }; - extraConfig = { - incoming_email = { - enabled = true; - mailbox = "inbox"; - address = "alice@localhost"; - user = "alice"; - password = "foobar"; - host = "localhost"; - port = 143; + recommendedProxySettings = true; + virtualHosts = { + localhost = { + locations."/".proxyPass = "http://unix:/run/gitlab/gitlab-workhorse.socket"; + }; }; }; - secrets = { - secretFile = pkgs.writeText "secret" "Aig5zaic"; - otpFile = pkgs.writeText "otpsecret" "Riew9mue"; - dbFile = pkgs.writeText "dbsecret" "we2quaeZ"; - jwsFile = pkgs.runCommand "oidcKeyBase" {} "${pkgs.openssl}/bin/openssl genrsa 2048 > $out"; + + services.openssh.enable = true; + + services.dovecot2 = { + enable = true; + enableImap = true; }; - # reduce memory usage - sidekiq.concurrency = 1; - puma.workers = 2; + systemd.services.gitlab-backup.environment.BACKUP = "dump"; + + services.gitlab = { + enable = true; + databasePasswordFile = pkgs.writeText "dbPassword" "xo0daiF4"; + initialRootPasswordFile = pkgs.writeText "rootPassword" initialRootPassword; + smtp.enable = true; + pages = { + enable = true; + settings.pages-domain = "localhost"; + }; + extraConfig = { + incoming_email = { + enabled = true; + mailbox = "inbox"; + address = "alice@localhost"; + user = "alice"; + password = "foobar"; + host = "localhost"; + port = 143; + }; + }; + secrets = { + secretFile = pkgs.writeText "secret" "Aig5zaic"; + otpFile = pkgs.writeText "otpsecret" "Riew9mue"; + dbFile = pkgs.writeText "dbsecret" "we2quaeZ"; + jwsFile = pkgs.runCommand "oidcKeyBase" { } "${pkgs.openssl}/bin/openssl genrsa 2048 > $out"; + }; + + # reduce memory usage + sidekiq.concurrency = 1; + puma.workers = 2; + }; }; - }; }; - testScript = { nodes, ... }: + testScript = + { nodes, ... }: let - auth = pkgs.writeText "auth.json" (builtins.toJSON { - grant_type = "password"; - username = "root"; - password = initialRootPassword; - }); - - createUserAlice = pkgs.writeText "create-user-alice.json" (builtins.toJSON rec { - username = aliceUsername; - name = username; - email = "alice@localhost"; - password = alicePassword; - skip_confirmation = true; - }); - - createUserBob = pkgs.writeText "create-user-bob.json" (builtins.toJSON rec { - username = bobUsername; - name = username; - email = "bob@localhost"; - password = bobPassword; - skip_confirmation = true; - }); - - aliceAuth = pkgs.writeText "alice-auth.json" (builtins.toJSON { - grant_type = "password"; - username = aliceUsername; - password = alicePassword; - }); - - bobAuth = pkgs.writeText "bob-auth.json" (builtins.toJSON { - grant_type = "password"; - username = bobUsername; - password = bobPassword; - }); - - aliceAddSSHKey = pkgs.writeText "alice-add-ssh-key.json" (builtins.toJSON { - id = aliceUserId; - title = "snakeoil@nixos"; - key = snakeOilPublicKey; - }); - - createProjectAlice = pkgs.writeText "create-project-alice.json" (builtins.toJSON { - name = aliceProjectName; - visibility = "public"; - }); - - putFile = pkgs.writeText "put-file.json" (builtins.toJSON { - branch = "master"; - author_email = "author@example.com"; - author_name = "Firstname Lastname"; - content = "some content"; - commit_message = "create a new file"; - }); - - mergeRequest = pkgs.writeText "merge-request.json" (builtins.toJSON { - id = bobProjectId; - target_project_id = aliceProjectId; - source_branch = "master"; - target_branch = "master"; - title = "Add some other file"; - }); - - newIssue = pkgs.writeText "new-issue.json" (builtins.toJSON { - title = "useful issue title"; - }); - - closeIssue = pkgs.writeText "close-issue.json" (builtins.toJSON { - issue_iid = 1; - state_event = "close"; - }); + auth = pkgs.writeText "auth.json" ( + builtins.toJSON { + grant_type = "password"; + username = "root"; + password = initialRootPassword; + } + ); + + createUserAlice = pkgs.writeText "create-user-alice.json" ( + builtins.toJSON rec { + username = aliceUsername; + name = username; + email = "alice@localhost"; + password = alicePassword; + skip_confirmation = true; + } + ); + + createUserBob = pkgs.writeText "create-user-bob.json" ( + builtins.toJSON rec { + username = bobUsername; + name = username; + email = "bob@localhost"; + password = bobPassword; + skip_confirmation = true; + } + ); + + aliceAuth = pkgs.writeText "alice-auth.json" ( + builtins.toJSON { + grant_type = "password"; + username = aliceUsername; + password = alicePassword; + } + ); + + bobAuth = pkgs.writeText "bob-auth.json" ( + builtins.toJSON { + grant_type = "password"; + username = bobUsername; + password = bobPassword; + } + ); + + aliceAddSSHKey = pkgs.writeText "alice-add-ssh-key.json" ( + builtins.toJSON { + id = aliceUserId; + title = "snakeoil@nixos"; + key = snakeOilPublicKey; + } + ); + + createProjectAlice = pkgs.writeText "create-project-alice.json" ( + builtins.toJSON { + name = aliceProjectName; + visibility = "public"; + } + ); + + putFile = pkgs.writeText "put-file.json" ( + builtins.toJSON { + branch = "master"; + author_email = "author@example.com"; + author_name = "Firstname Lastname"; + content = "some content"; + commit_message = "create a new file"; + } + ); + + mergeRequest = pkgs.writeText "merge-request.json" ( + builtins.toJSON { + id = bobProjectId; + target_project_id = aliceProjectId; + source_branch = "master"; + target_branch = "master"; + title = "Add some other file"; + } + ); + + newIssue = pkgs.writeText "new-issue.json" ( + builtins.toJSON { + title = "useful issue title"; + } + ); + + closeIssue = pkgs.writeText "close-issue.json" ( + builtins.toJSON { + issue_iid = 1; + state_event = "close"; + } + ); # Wait for all GitLab services to be fully started. waitForServices = '' @@ -185,238 +214,243 @@ in { # The actual test of GitLab. Only push data to GitLab if # `doSetup` is is true. - test = doSetup: '' - GIT_SSH_COMMAND = "ssh -o StrictHostKeyChecking=accept-new -o UserKnownHostsFile=/dev/null" - - gitlab.succeed( - "curl -isSf http://gitlab | grep -i location | grep http://gitlab/users/sign_in" - ) - gitlab.succeed( - "${pkgs.sudo}/bin/sudo -u gitlab -H gitlab-rake gitlab:check 1>&2" - ) - gitlab.succeed( - "echo \"Authorization: Bearer $(curl -X POST -H 'Content-Type: application/json' -d @${auth} http://gitlab/oauth/token | ${pkgs.jq}/bin/jq -r '.access_token')\" >/tmp/headers" - ) - '' + lib.optionalString doSetup '' - with subtest("Create user Alice"): - gitlab.succeed( - """[ "$(curl -o /dev/null -w '%{http_code}' -X POST -H 'Content-Type: application/json' -H @/tmp/headers -d @${createUserAlice} http://gitlab/api/v4/users)" = "201" ]""" - ) - gitlab.succeed( - "echo \"Authorization: Bearer $(curl -X POST -H 'Content-Type: application/json' -d @${aliceAuth} http://gitlab/oauth/token | ${pkgs.jq}/bin/jq -r '.access_token')\" >/tmp/headers-alice" - ) - - with subtest("Create user Bob"): - gitlab.succeed( - """ [ "$(curl -o /dev/null -w '%{http_code}' -X POST -H 'Content-Type: application/json' -H @/tmp/headers -d @${createUserBob} http://gitlab/api/v4/users)" = "201" ]""" - ) - gitlab.succeed( - "echo \"Authorization: Bearer $(curl -X POST -H 'Content-Type: application/json' -d @${bobAuth} http://gitlab/oauth/token | ${pkgs.jq}/bin/jq -r '.access_token')\" >/tmp/headers-bob" - ) - - with subtest("Setup Git and SSH for Alice"): - gitlab.succeed("git config --global user.name Alice") - gitlab.succeed("git config --global user.email alice@nixos.invalid") - gitlab.succeed("mkdir -m 700 /root/.ssh") - gitlab.succeed("cat ${snakeOilPrivateKey} > /root/.ssh/id_ecdsa") - gitlab.succeed("chmod 600 /root/.ssh/id_ecdsa") - gitlab.succeed( - """ - [ "$(curl \ - -o /dev/null \ - -w '%{http_code}' \ - -X POST \ - -H 'Content-Type: application/json' \ - -H @/tmp/headers-alice -d @${aliceAddSSHKey} \ - http://gitlab/api/v4/user/keys)" = "201" ] - """ - ) - - with subtest("Create a new repository"): - # Alice creates a new repository - gitlab.succeed( - """ - [ "$(curl \ - -o /dev/null \ - -w '%{http_code}' \ - -X POST \ - -H 'Content-Type: application/json' \ - -H @/tmp/headers-alice \ - -d @${createProjectAlice} \ - http://gitlab/api/v4/projects)" = "201" ] - """ - ) - - # Alice commits an initial commit - gitlab.succeed( - """ - [ "$(curl \ - -o /dev/null \ - -w '%{http_code}' \ - -X POST \ - -H 'Content-Type: application/json' \ - -H @/tmp/headers-alice \ - -d @${putFile} \ - http://gitlab/api/v4/projects/${aliceProjectId}/repository/files/some-file.txt)" = "201" ]""" - ) - - with subtest("git clone over HTTP"): - gitlab.succeed( - """git clone http://gitlab/alice/${aliceProjectName}.git clone-via-http""", - timeout=15 - ) - - with subtest("Push a commit via SSH"): - gitlab.succeed( - f"""GIT_SSH_COMMAND="{GIT_SSH_COMMAND}" git clone gitlab@gitlab:alice/${aliceProjectName}.git""", - timeout=15 - ) - gitlab.succeed( - """echo "a commit sent over ssh" > ${aliceProjectName}/ssh.txt""" - ) - gitlab.succeed( - """ - cd ${aliceProjectName} || exit 1 - git add . - """ - ) - gitlab.succeed( - """ - cd ${aliceProjectName} || exit 1 - git commit -m "Add a commit to be sent over ssh" - """ - ) - gitlab.succeed( - f""" - cd ${aliceProjectName} || exit 1 - GIT_SSH_COMMAND="{GIT_SSH_COMMAND}" git push --set-upstream origin master - """, - timeout=15 - ) - - with subtest("Fork a project"): - # Bob forks Alice's project - gitlab.succeed( - """ - [ "$(curl \ - -o /dev/null \ - -w '%{http_code}' \ - -X POST \ - -H 'Content-Type: application/json' \ - -H @/tmp/headers-bob \ - http://gitlab/api/v4/projects/${aliceProjectId}/fork)" = "201" ] - """ - ) - - # Bob creates a commit - gitlab.wait_until_succeeds( - """ - [ "$(curl \ - -o /dev/null \ - -w '%{http_code}' \ - -X POST \ - -H 'Content-Type: application/json' \ - -H @/tmp/headers-bob \ - -d @${putFile} \ - http://gitlab/api/v4/projects/${bobProjectId}/repository/files/some-other-file.txt)" = "201" ] - """ - ) - - with subtest("Create a Merge Request"): - # Bob opens a merge request against Alice's repository - gitlab.wait_until_succeeds( - """ - [ "$(curl \ - -o /dev/null \ - -w '%{http_code}' \ - -X POST \ - -H 'Content-Type: application/json' \ - -H @/tmp/headers-bob \ - -d @${mergeRequest} \ - http://gitlab/api/v4/projects/${bobProjectId}/merge_requests)" = "201" ] - """ - ) - - # Alice merges the MR - gitlab.wait_until_succeeds( - """ - [ "$(curl \ - -o /dev/null \ - -w '%{http_code}' \ - -X PUT \ - -H 'Content-Type: application/json' \ - -H @/tmp/headers-alice \ - -d @${mergeRequest} \ - http://gitlab/api/v4/projects/${aliceProjectId}/merge_requests/1/merge)" = "200" ] - """ - ) - - with subtest("Create an Issue"): - # Bob opens an issue on Alice's repository - gitlab.succeed( - """[ "$(curl \ - -o /dev/null \ - -w '%{http_code}' \ - -X POST \ - -H 'Content-Type: application/json' \ - -H @/tmp/headers-bob \ - -d @${newIssue} \ - http://gitlab/api/v4/projects/${aliceProjectId}/issues)" = "201" ] - """ - ) - - # Alice closes the issue - gitlab.wait_until_succeeds( - """ - [ "$(curl \ - -o /dev/null \ - -w '%{http_code}' \ - -X PUT \ - -H 'Content-Type: application/json' \ - -H @/tmp/headers-alice -d @${closeIssue} http://gitlab/api/v4/projects/${aliceProjectId}/issues/1)" = "200" ] - """ - ) - '' + '' - with subtest("Download archive.tar.gz"): - gitlab.succeed( - """ - [ "$(curl \ - -o /dev/null \ - -w '%{http_code}' \ - -H @/tmp/headers-alice \ - http://gitlab/api/v4/projects/${aliceProjectId}/repository/archive.tar.gz)" = "200" ] - """ - ) - gitlab.succeed( - """ - curl \ - -H @/tmp/headers-alice \ - http://gitlab/api/v4/projects/${aliceProjectId}/repository/archive.tar.gz > /tmp/archive.tar.gz - """ - ) - gitlab.succeed("test -s /tmp/archive.tar.gz") - - with subtest("Download archive.tar.bz2"): - gitlab.succeed( - """ - [ "$(curl \ - -o /dev/null \ - -w '%{http_code}' \ - -H @/tmp/headers-alice \ - http://gitlab/api/v4/projects/${aliceProjectId}/repository/archive.tar.bz2)" = "200" ] - """ - ) - gitlab.succeed( - """ - curl \ - -H @/tmp/headers-alice \ - http://gitlab/api/v4/projects/${aliceProjectId}/repository/archive.tar.bz2 > /tmp/archive.tar.bz2 - """ - ) - gitlab.succeed("test -s /tmp/archive.tar.bz2") - ''; - - in '' + test = + doSetup: + '' + GIT_SSH_COMMAND = "ssh -o StrictHostKeyChecking=accept-new -o UserKnownHostsFile=/dev/null" + + gitlab.succeed( + "curl -isSf http://gitlab | grep -i location | grep http://gitlab/users/sign_in" + ) + gitlab.succeed( + "${pkgs.sudo}/bin/sudo -u gitlab -H gitlab-rake gitlab:check 1>&2" + ) + gitlab.succeed( + "echo \"Authorization: Bearer $(curl -X POST -H 'Content-Type: application/json' -d @${auth} http://gitlab/oauth/token | ${pkgs.jq}/bin/jq -r '.access_token')\" >/tmp/headers" + ) + '' + + lib.optionalString doSetup '' + with subtest("Create user Alice"): + gitlab.succeed( + """[ "$(curl -o /dev/null -w '%{http_code}' -X POST -H 'Content-Type: application/json' -H @/tmp/headers -d @${createUserAlice} http://gitlab/api/v4/users)" = "201" ]""" + ) + gitlab.succeed( + "echo \"Authorization: Bearer $(curl -X POST -H 'Content-Type: application/json' -d @${aliceAuth} http://gitlab/oauth/token | ${pkgs.jq}/bin/jq -r '.access_token')\" >/tmp/headers-alice" + ) + + with subtest("Create user Bob"): + gitlab.succeed( + """ [ "$(curl -o /dev/null -w '%{http_code}' -X POST -H 'Content-Type: application/json' -H @/tmp/headers -d @${createUserBob} http://gitlab/api/v4/users)" = "201" ]""" + ) + gitlab.succeed( + "echo \"Authorization: Bearer $(curl -X POST -H 'Content-Type: application/json' -d @${bobAuth} http://gitlab/oauth/token | ${pkgs.jq}/bin/jq -r '.access_token')\" >/tmp/headers-bob" + ) + + with subtest("Setup Git and SSH for Alice"): + gitlab.succeed("git config --global user.name Alice") + gitlab.succeed("git config --global user.email alice@nixos.invalid") + gitlab.succeed("mkdir -m 700 /root/.ssh") + gitlab.succeed("cat ${snakeOilPrivateKey} > /root/.ssh/id_ecdsa") + gitlab.succeed("chmod 600 /root/.ssh/id_ecdsa") + gitlab.succeed( + """ + [ "$(curl \ + -o /dev/null \ + -w '%{http_code}' \ + -X POST \ + -H 'Content-Type: application/json' \ + -H @/tmp/headers-alice -d @${aliceAddSSHKey} \ + http://gitlab/api/v4/user/keys)" = "201" ] + """ + ) + + with subtest("Create a new repository"): + # Alice creates a new repository + gitlab.succeed( + """ + [ "$(curl \ + -o /dev/null \ + -w '%{http_code}' \ + -X POST \ + -H 'Content-Type: application/json' \ + -H @/tmp/headers-alice \ + -d @${createProjectAlice} \ + http://gitlab/api/v4/projects)" = "201" ] + """ + ) + + # Alice commits an initial commit + gitlab.succeed( + """ + [ "$(curl \ + -o /dev/null \ + -w '%{http_code}' \ + -X POST \ + -H 'Content-Type: application/json' \ + -H @/tmp/headers-alice \ + -d @${putFile} \ + http://gitlab/api/v4/projects/${aliceProjectId}/repository/files/some-file.txt)" = "201" ]""" + ) + + with subtest("git clone over HTTP"): + gitlab.succeed( + """git clone http://gitlab/alice/${aliceProjectName}.git clone-via-http""", + timeout=15 + ) + + with subtest("Push a commit via SSH"): + gitlab.succeed( + f"""GIT_SSH_COMMAND="{GIT_SSH_COMMAND}" git clone gitlab@gitlab:alice/${aliceProjectName}.git""", + timeout=15 + ) + gitlab.succeed( + """echo "a commit sent over ssh" > ${aliceProjectName}/ssh.txt""" + ) + gitlab.succeed( + """ + cd ${aliceProjectName} || exit 1 + git add . + """ + ) + gitlab.succeed( + """ + cd ${aliceProjectName} || exit 1 + git commit -m "Add a commit to be sent over ssh" + """ + ) + gitlab.succeed( + f""" + cd ${aliceProjectName} || exit 1 + GIT_SSH_COMMAND="{GIT_SSH_COMMAND}" git push --set-upstream origin master + """, + timeout=15 + ) + + with subtest("Fork a project"): + # Bob forks Alice's project + gitlab.succeed( + """ + [ "$(curl \ + -o /dev/null \ + -w '%{http_code}' \ + -X POST \ + -H 'Content-Type: application/json' \ + -H @/tmp/headers-bob \ + http://gitlab/api/v4/projects/${aliceProjectId}/fork)" = "201" ] + """ + ) + + # Bob creates a commit + gitlab.wait_until_succeeds( + """ + [ "$(curl \ + -o /dev/null \ + -w '%{http_code}' \ + -X POST \ + -H 'Content-Type: application/json' \ + -H @/tmp/headers-bob \ + -d @${putFile} \ + http://gitlab/api/v4/projects/${bobProjectId}/repository/files/some-other-file.txt)" = "201" ] + """ + ) + + with subtest("Create a Merge Request"): + # Bob opens a merge request against Alice's repository + gitlab.wait_until_succeeds( + """ + [ "$(curl \ + -o /dev/null \ + -w '%{http_code}' \ + -X POST \ + -H 'Content-Type: application/json' \ + -H @/tmp/headers-bob \ + -d @${mergeRequest} \ + http://gitlab/api/v4/projects/${bobProjectId}/merge_requests)" = "201" ] + """ + ) + + # Alice merges the MR + gitlab.wait_until_succeeds( + """ + [ "$(curl \ + -o /dev/null \ + -w '%{http_code}' \ + -X PUT \ + -H 'Content-Type: application/json' \ + -H @/tmp/headers-alice \ + -d @${mergeRequest} \ + http://gitlab/api/v4/projects/${aliceProjectId}/merge_requests/1/merge)" = "200" ] + """ + ) + + with subtest("Create an Issue"): + # Bob opens an issue on Alice's repository + gitlab.succeed( + """[ "$(curl \ + -o /dev/null \ + -w '%{http_code}' \ + -X POST \ + -H 'Content-Type: application/json' \ + -H @/tmp/headers-bob \ + -d @${newIssue} \ + http://gitlab/api/v4/projects/${aliceProjectId}/issues)" = "201" ] + """ + ) + + # Alice closes the issue + gitlab.wait_until_succeeds( + """ + [ "$(curl \ + -o /dev/null \ + -w '%{http_code}' \ + -X PUT \ + -H 'Content-Type: application/json' \ + -H @/tmp/headers-alice -d @${closeIssue} http://gitlab/api/v4/projects/${aliceProjectId}/issues/1)" = "200" ] + """ + ) + '' + + '' + with subtest("Download archive.tar.gz"): + gitlab.succeed( + """ + [ "$(curl \ + -o /dev/null \ + -w '%{http_code}' \ + -H @/tmp/headers-alice \ + http://gitlab/api/v4/projects/${aliceProjectId}/repository/archive.tar.gz)" = "200" ] + """ + ) + gitlab.succeed( + """ + curl \ + -H @/tmp/headers-alice \ + http://gitlab/api/v4/projects/${aliceProjectId}/repository/archive.tar.gz > /tmp/archive.tar.gz + """ + ) + gitlab.succeed("test -s /tmp/archive.tar.gz") + + with subtest("Download archive.tar.bz2"): + gitlab.succeed( + """ + [ "$(curl \ + -o /dev/null \ + -w '%{http_code}' \ + -H @/tmp/headers-alice \ + http://gitlab/api/v4/projects/${aliceProjectId}/repository/archive.tar.bz2)" = "200" ] + """ + ) + gitlab.succeed( + """ + curl \ + -H @/tmp/headers-alice \ + http://gitlab/api/v4/projects/${aliceProjectId}/repository/archive.tar.bz2 > /tmp/archive.tar.bz2 + """ + ) + gitlab.succeed("test -s /tmp/archive.tar.bz2") + ''; + + in + '' gitlab.start() '' + waitForServices diff --git a/nixos/tests/gitolite-fcgiwrap.nix b/nixos/tests/gitolite-fcgiwrap.nix index 43d65faebbee27..9560c5c349137f 100644 --- a/nixos/tests/gitolite-fcgiwrap.nix +++ b/nixos/tests/gitolite-fcgiwrap.nix @@ -1,98 +1,98 @@ import ./make-test-python.nix ( { pkgs, ... }: - let - user = "gitolite-admin"; - password = "some_password"; - - # not used but needed to setup gitolite - adminPublicKey = '' - ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO7urFhAA90BTpGuEHeWWTY3W/g9PBxXNxfWhfbrm4Le root@client - ''; - in - { - name = "gitolite-fcgiwrap"; - - meta = with pkgs.lib.maintainers; { - maintainers = [ bbigras ]; + let + user = "gitolite-admin"; + password = "some_password"; + + # not used but needed to setup gitolite + adminPublicKey = '' + ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO7urFhAA90BTpGuEHeWWTY3W/g9PBxXNxfWhfbrm4Le root@client + ''; + in + { + name = "gitolite-fcgiwrap"; + + meta = with pkgs.lib.maintainers; { + maintainers = [ bbigras ]; + }; + + nodes = { + + server = + { config, ... }: + { + networking.firewall.allowedTCPPorts = [ 80 ]; + + services.fcgiwrap.instances.gitolite = { + process.user = "gitolite"; + process.group = "gitolite"; + socket = { inherit (config.services.nginx) user group; }; + }; + + services.gitolite = { + enable = true; + adminPubkey = adminPublicKey; + }; + + services.nginx = { + enable = true; + recommendedProxySettings = true; + virtualHosts."server".locations."/git".extraConfig = '' + # turn off gzip as git objects are already well compressed + gzip off; + + # use file based basic authentication + auth_basic "Git Repository Authentication"; + auth_basic_user_file /etc/gitolite/htpasswd; + + # common FastCGI parameters are required + include ${config.services.nginx.package}/conf/fastcgi_params; + + # strip the CGI program prefix + fastcgi_split_path_info ^(/git)(.*)$; + fastcgi_param PATH_INFO $fastcgi_path_info; + + # pass authenticated user login(mandatory) to Gitolite + fastcgi_param REMOTE_USER $remote_user; + + # pass git repository root directory and hosting user directory + # these env variables can be set in a wrapper script + fastcgi_param GIT_HTTP_EXPORT_ALL ""; + fastcgi_param GIT_PROJECT_ROOT /var/lib/gitolite/repositories; + fastcgi_param GITOLITE_HTTP_HOME /var/lib/gitolite; + fastcgi_param SCRIPT_FILENAME ${pkgs.gitolite}/bin/gitolite-shell; + + # use Unix domain socket or inet socket + fastcgi_pass unix:${config.services.fcgiwrap.instances.gitolite.socket.address}; + ''; + }; + + # WARNING: DON'T DO THIS IN PRODUCTION! + # This puts unhashed secrets directly into the Nix store for ease of testing. + environment.etc."gitolite/htpasswd".source = pkgs.runCommand "htpasswd" { } '' + ${pkgs.apacheHttpd}/bin/htpasswd -bc "$out" ${user} ${password} + ''; }; - nodes = { - - server = - { config, ... }: - { - networking.firewall.allowedTCPPorts = [ 80 ]; - - services.fcgiwrap.instances.gitolite = { - process.user = "gitolite"; - process.group = "gitolite"; - socket = { inherit (config.services.nginx) user group; }; - }; - - services.gitolite = { - enable = true; - adminPubkey = adminPublicKey; - }; - - services.nginx = { - enable = true; - recommendedProxySettings = true; - virtualHosts."server".locations."/git".extraConfig = '' - # turn off gzip as git objects are already well compressed - gzip off; - - # use file based basic authentication - auth_basic "Git Repository Authentication"; - auth_basic_user_file /etc/gitolite/htpasswd; - - # common FastCGI parameters are required - include ${config.services.nginx.package}/conf/fastcgi_params; - - # strip the CGI program prefix - fastcgi_split_path_info ^(/git)(.*)$; - fastcgi_param PATH_INFO $fastcgi_path_info; - - # pass authenticated user login(mandatory) to Gitolite - fastcgi_param REMOTE_USER $remote_user; - - # pass git repository root directory and hosting user directory - # these env variables can be set in a wrapper script - fastcgi_param GIT_HTTP_EXPORT_ALL ""; - fastcgi_param GIT_PROJECT_ROOT /var/lib/gitolite/repositories; - fastcgi_param GITOLITE_HTTP_HOME /var/lib/gitolite; - fastcgi_param SCRIPT_FILENAME ${pkgs.gitolite}/bin/gitolite-shell; - - # use Unix domain socket or inet socket - fastcgi_pass unix:${config.services.fcgiwrap.instances.gitolite.socket.address}; - ''; - }; - - # WARNING: DON'T DO THIS IN PRODUCTION! - # This puts unhashed secrets directly into the Nix store for ease of testing. - environment.etc."gitolite/htpasswd".source = pkgs.runCommand "htpasswd" {} '' - ${pkgs.apacheHttpd}/bin/htpasswd -bc "$out" ${user} ${password} - ''; - }; - - client = - { pkgs, ... }: - { - environment.systemPackages = [ pkgs.git ]; - }; + client = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.git ]; }; + }; - testScript = '' - start_all() + testScript = '' + start_all() - server.wait_for_unit("gitolite-init.service") - server.wait_for_unit("nginx.service") - server.wait_for_file("/run/fcgiwrap-gitolite.sock") + server.wait_for_unit("gitolite-init.service") + server.wait_for_unit("nginx.service") + server.wait_for_file("/run/fcgiwrap-gitolite.sock") - client.wait_for_unit("multi-user.target") - client.succeed( - "git clone http://${user}:${password}@server/git/gitolite-admin.git" - ) - ''; - } + client.wait_for_unit("multi-user.target") + client.succeed( + "git clone http://${user}:${password}@server/git/gitolite-admin.git" + ) + ''; + } ) diff --git a/nixos/tests/gitolite.nix b/nixos/tests/gitolite.nix index 9b3af59e4fbd8e..af2aa327c0167f 100644 --- a/nixos/tests/gitolite.nix +++ b/nixos/tests/gitolite.nix @@ -1,138 +1,144 @@ -import ./make-test-python.nix ({ pkgs, ...}: - -let - adminPrivateKey = pkgs.writeText "id_ed25519" '' - -----BEGIN OPENSSH PRIVATE KEY----- - b3BlbnNzaC1rZXktdjEAAAAABG5vbmUAAAAEbm9uZQAAAAAAAAABAAAAMwAAAAtzc2gtZW - QyNTUxOQAAACDu7qxYQAPdAU6RrhB3llk2N1v4PTwcVzcX1oX265uC3gAAAJBJiYxDSYmM - QwAAAAtzc2gtZWQyNTUxOQAAACDu7qxYQAPdAU6RrhB3llk2N1v4PTwcVzcX1oX265uC3g - AAAEDE1W6vMwSEUcF1r7Hyypm/+sCOoDmKZgPxi3WOa1mD2u7urFhAA90BTpGuEHeWWTY3 - W/g9PBxXNxfWhfbrm4LeAAAACGJmb0BtaW5pAQIDBAU= - -----END OPENSSH PRIVATE KEY----- - ''; - - adminPublicKey = '' - ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO7urFhAA90BTpGuEHeWWTY3W/g9PBxXNxfWhfbrm4Le root@client - ''; - - alicePrivateKey = pkgs.writeText "id_ed25519" '' - -----BEGIN OPENSSH PRIVATE KEY----- - b3BlbnNzaC1rZXktdjEAAAAABG5vbmUAAAAEbm9uZQAAAAAAAAABAAAAMwAAAAtzc2gtZW - QyNTUxOQAAACBbeWvHh/AWGWI6EIc1xlSihyXtacNQ9KeztlW/VUy8wQAAAJAwVQ5VMFUO - VQAAAAtzc2gtZWQyNTUxOQAAACBbeWvHh/AWGWI6EIc1xlSihyXtacNQ9KeztlW/VUy8wQ - AAAEB7lbfkkdkJoE+4TKHPdPQWBKLSx+J54Eg8DaTr+3KoSlt5a8eH8BYZYjoQhzXGVKKH - Je1pw1D0p7O2Vb9VTLzBAAAACGJmb0BtaW5pAQIDBAU= - -----END OPENSSH PRIVATE KEY----- - ''; - - alicePublicKey = pkgs.writeText "id_ed25519.pub" '' - ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIFt5a8eH8BYZYjoQhzXGVKKHJe1pw1D0p7O2Vb9VTLzB alice@client - ''; - - bobPrivateKey = pkgs.writeText "id_ed25519" '' - -----BEGIN OPENSSH PRIVATE KEY----- - b3BlbnNzaC1rZXktdjEAAAAABG5vbmUAAAAEbm9uZQAAAAAAAAABAAAAMwAAAAtzc2gtZW - QyNTUxOQAAACCWTaJ1D9Xjxy6759FvQ9oXTes1lmWBciXPkEeqTikBMAAAAJDQBmNV0AZj - VQAAAAtzc2gtZWQyNTUxOQAAACCWTaJ1D9Xjxy6759FvQ9oXTes1lmWBciXPkEeqTikBMA - AAAEDM1IYYFUwk/IVxauha9kuR6bbRtT3gZ6ZA0GLb9txb/pZNonUP1ePHLrvn0W9D2hdN - 6zWWZYFyJc+QR6pOKQEwAAAACGJmb0BtaW5pAQIDBAU= - -----END OPENSSH PRIVATE KEY----- - ''; - - bobPublicKey = pkgs.writeText "id_ed25519.pub" '' - ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJZNonUP1ePHLrvn0W9D2hdN6zWWZYFyJc+QR6pOKQEw bob@client - ''; - - gitoliteAdminConfSnippet = pkgs.writeText "gitolite-admin-conf-snippet" '' - repo alice-project - RW+ = alice - ''; -in -{ - name = "gitolite"; - - meta = with pkgs.lib.maintainers; { - maintainers = [ bjornfor ]; - }; - - nodes = { - - server = - { ... }: - { - services.gitolite = { - enable = true; - adminPubkey = adminPublicKey; +import ./make-test-python.nix ( + { pkgs, ... }: + + let + adminPrivateKey = pkgs.writeText "id_ed25519" '' + -----BEGIN OPENSSH PRIVATE KEY----- + b3BlbnNzaC1rZXktdjEAAAAABG5vbmUAAAAEbm9uZQAAAAAAAAABAAAAMwAAAAtzc2gtZW + QyNTUxOQAAACDu7qxYQAPdAU6RrhB3llk2N1v4PTwcVzcX1oX265uC3gAAAJBJiYxDSYmM + QwAAAAtzc2gtZWQyNTUxOQAAACDu7qxYQAPdAU6RrhB3llk2N1v4PTwcVzcX1oX265uC3g + AAAEDE1W6vMwSEUcF1r7Hyypm/+sCOoDmKZgPxi3WOa1mD2u7urFhAA90BTpGuEHeWWTY3 + W/g9PBxXNxfWhfbrm4LeAAAACGJmb0BtaW5pAQIDBAU= + -----END OPENSSH PRIVATE KEY----- + ''; + + adminPublicKey = '' + ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO7urFhAA90BTpGuEHeWWTY3W/g9PBxXNxfWhfbrm4Le root@client + ''; + + alicePrivateKey = pkgs.writeText "id_ed25519" '' + -----BEGIN OPENSSH PRIVATE KEY----- + b3BlbnNzaC1rZXktdjEAAAAABG5vbmUAAAAEbm9uZQAAAAAAAAABAAAAMwAAAAtzc2gtZW + QyNTUxOQAAACBbeWvHh/AWGWI6EIc1xlSihyXtacNQ9KeztlW/VUy8wQAAAJAwVQ5VMFUO + VQAAAAtzc2gtZWQyNTUxOQAAACBbeWvHh/AWGWI6EIc1xlSihyXtacNQ9KeztlW/VUy8wQ + AAAEB7lbfkkdkJoE+4TKHPdPQWBKLSx+J54Eg8DaTr+3KoSlt5a8eH8BYZYjoQhzXGVKKH + Je1pw1D0p7O2Vb9VTLzBAAAACGJmb0BtaW5pAQIDBAU= + -----END OPENSSH PRIVATE KEY----- + ''; + + alicePublicKey = pkgs.writeText "id_ed25519.pub" '' + ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIFt5a8eH8BYZYjoQhzXGVKKHJe1pw1D0p7O2Vb9VTLzB alice@client + ''; + + bobPrivateKey = pkgs.writeText "id_ed25519" '' + -----BEGIN OPENSSH PRIVATE KEY----- + b3BlbnNzaC1rZXktdjEAAAAABG5vbmUAAAAEbm9uZQAAAAAAAAABAAAAMwAAAAtzc2gtZW + QyNTUxOQAAACCWTaJ1D9Xjxy6759FvQ9oXTes1lmWBciXPkEeqTikBMAAAAJDQBmNV0AZj + VQAAAAtzc2gtZWQyNTUxOQAAACCWTaJ1D9Xjxy6759FvQ9oXTes1lmWBciXPkEeqTikBMA + AAAEDM1IYYFUwk/IVxauha9kuR6bbRtT3gZ6ZA0GLb9txb/pZNonUP1ePHLrvn0W9D2hdN + 6zWWZYFyJc+QR6pOKQEwAAAACGJmb0BtaW5pAQIDBAU= + -----END OPENSSH PRIVATE KEY----- + ''; + + bobPublicKey = pkgs.writeText "id_ed25519.pub" '' + ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJZNonUP1ePHLrvn0W9D2hdN6zWWZYFyJc+QR6pOKQEw bob@client + ''; + + gitoliteAdminConfSnippet = pkgs.writeText "gitolite-admin-conf-snippet" '' + repo alice-project + RW+ = alice + ''; + in + { + name = "gitolite"; + + meta = with pkgs.lib.maintainers; { + maintainers = [ bjornfor ]; + }; + + nodes = { + + server = + { ... }: + { + services.gitolite = { + enable = true; + adminPubkey = adminPublicKey; + }; + services.openssh.enable = true; }; - services.openssh.enable = true; - }; - - client = - { pkgs, ... }: - { - environment.systemPackages = [ pkgs.git ]; - programs.ssh.extraConfig = '' - Host * - UserKnownHostsFile /dev/null - StrictHostKeyChecking no - # there's nobody around that can input password - PreferredAuthentications publickey - ''; - users.users.alice = { isNormalUser = true; }; - users.users.bob = { isNormalUser = true; }; - }; - - }; - - testScript = '' - start_all() - - with subtest("can setup ssh keys on system"): - client.succeed( - "mkdir -p ~root/.ssh", - "cp ${adminPrivateKey} ~root/.ssh/id_ed25519", - "chmod 600 ~root/.ssh/id_ed25519", - ) - client.succeed( - "sudo -u alice mkdir -p ~alice/.ssh", - "sudo -u alice cp ${alicePrivateKey} ~alice/.ssh/id_ed25519", - "sudo -u alice chmod 600 ~alice/.ssh/id_ed25519", - ) - client.succeed( - "sudo -u bob mkdir -p ~bob/.ssh", - "sudo -u bob cp ${bobPrivateKey} ~bob/.ssh/id_ed25519", - "sudo -u bob chmod 600 ~bob/.ssh/id_ed25519", - ) - - with subtest("gitolite server starts"): - server.wait_for_unit("gitolite-init.service") - server.wait_for_unit("sshd.service") - client.succeed("ssh -n gitolite@server info") - - with subtest("admin can clone and configure gitolite-admin.git"): - client.succeed( - "git clone gitolite@server:gitolite-admin.git", - "git config --global user.name 'System Administrator'", - "git config --global user.email root\@domain.example", - "cp ${alicePublicKey} gitolite-admin/keydir/alice.pub", - "cp ${bobPublicKey} gitolite-admin/keydir/bob.pub", - "(cd gitolite-admin && git add . && git commit -m 'Add keys for alice, bob' && git push)", - "cat ${gitoliteAdminConfSnippet} >> gitolite-admin/conf/gitolite.conf", - "(cd gitolite-admin && git add . && git commit -m 'Add repo for alice' && git push)", - ) - - with subtest("non-admins cannot clone gitolite-admin.git"): - client.fail("sudo -i -u alice git clone gitolite@server:gitolite-admin.git") - client.fail("sudo -i -u bob git clone gitolite@server:gitolite-admin.git") - - with subtest("non-admins can clone testing.git"): - client.succeed("sudo -i -u alice git clone gitolite@server:testing.git") - client.succeed("sudo -i -u bob git clone gitolite@server:testing.git") - - with subtest("alice can clone alice-project.git"): - client.succeed("sudo -i -u alice git clone gitolite@server:alice-project.git") - - with subtest("bob cannot clone alice-project.git"): - client.fail("sudo -i -u bob git clone gitolite@server:alice-project.git") - ''; -}) + + client = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.git ]; + programs.ssh.extraConfig = '' + Host * + UserKnownHostsFile /dev/null + StrictHostKeyChecking no + # there's nobody around that can input password + PreferredAuthentications publickey + ''; + users.users.alice = { + isNormalUser = true; + }; + users.users.bob = { + isNormalUser = true; + }; + }; + + }; + + testScript = '' + start_all() + + with subtest("can setup ssh keys on system"): + client.succeed( + "mkdir -p ~root/.ssh", + "cp ${adminPrivateKey} ~root/.ssh/id_ed25519", + "chmod 600 ~root/.ssh/id_ed25519", + ) + client.succeed( + "sudo -u alice mkdir -p ~alice/.ssh", + "sudo -u alice cp ${alicePrivateKey} ~alice/.ssh/id_ed25519", + "sudo -u alice chmod 600 ~alice/.ssh/id_ed25519", + ) + client.succeed( + "sudo -u bob mkdir -p ~bob/.ssh", + "sudo -u bob cp ${bobPrivateKey} ~bob/.ssh/id_ed25519", + "sudo -u bob chmod 600 ~bob/.ssh/id_ed25519", + ) + + with subtest("gitolite server starts"): + server.wait_for_unit("gitolite-init.service") + server.wait_for_unit("sshd.service") + client.succeed("ssh -n gitolite@server info") + + with subtest("admin can clone and configure gitolite-admin.git"): + client.succeed( + "git clone gitolite@server:gitolite-admin.git", + "git config --global user.name 'System Administrator'", + "git config --global user.email root\@domain.example", + "cp ${alicePublicKey} gitolite-admin/keydir/alice.pub", + "cp ${bobPublicKey} gitolite-admin/keydir/bob.pub", + "(cd gitolite-admin && git add . && git commit -m 'Add keys for alice, bob' && git push)", + "cat ${gitoliteAdminConfSnippet} >> gitolite-admin/conf/gitolite.conf", + "(cd gitolite-admin && git add . && git commit -m 'Add repo for alice' && git push)", + ) + + with subtest("non-admins cannot clone gitolite-admin.git"): + client.fail("sudo -i -u alice git clone gitolite@server:gitolite-admin.git") + client.fail("sudo -i -u bob git clone gitolite@server:gitolite-admin.git") + + with subtest("non-admins can clone testing.git"): + client.succeed("sudo -i -u alice git clone gitolite@server:testing.git") + client.succeed("sudo -i -u bob git clone gitolite@server:testing.git") + + with subtest("alice can clone alice-project.git"): + client.succeed("sudo -i -u alice git clone gitolite@server:alice-project.git") + + with subtest("bob cannot clone alice-project.git"): + client.fail("sudo -i -u bob git clone gitolite@server:alice-project.git") + ''; + } +) diff --git a/nixos/tests/glusterfs.nix b/nixos/tests/glusterfs.nix index ef09264a021671..8beed8e4a91fbd 100644 --- a/nixos/tests/glusterfs.nix +++ b/nixos/tests/glusterfs.nix @@ -1,68 +1,75 @@ -import ./make-test-python.nix ({pkgs, lib, ...}: +import ./make-test-python.nix ( + { pkgs, lib, ... }: -let - client = { pkgs, ... } : { - environment.systemPackages = [ pkgs.glusterfs ]; - virtualisation.fileSystems = - { "/gluster" = - { device = "server1:/gv0"; + let + client = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.glusterfs ]; + virtualisation.fileSystems = { + "/gluster" = { + device = "server1:/gv0"; fsType = "glusterfs"; }; + }; }; - }; - server = { pkgs, ... } : { - networking.firewall.enable = false; - services.glusterfs.enable = true; + server = + { pkgs, ... }: + { + networking.firewall.enable = false; + services.glusterfs.enable = true; - # create a mount point for the volume - boot.initrd.postDeviceCommands = '' - ${pkgs.e2fsprogs}/bin/mkfs.ext4 -L data /dev/vdb - ''; + # create a mount point for the volume + boot.initrd.postDeviceCommands = '' + ${pkgs.e2fsprogs}/bin/mkfs.ext4 -L data /dev/vdb + ''; - virtualisation.emptyDiskImages = [ 1024 ]; + virtualisation.emptyDiskImages = [ 1024 ]; - virtualisation.fileSystems = - { "/data" = - { device = "/dev/disk/by-label/data"; + virtualisation.fileSystems = { + "/data" = { + device = "/dev/disk/by-label/data"; fsType = "ext4"; }; + }; }; - }; -in { - name = "glusterfs"; + in + { + name = "glusterfs"; - nodes = { - server1 = server; - server2 = server; - client1 = client; - client2 = client; - }; + nodes = { + server1 = server; + server2 = server; + client1 = client; + client2 = client; + }; - testScript = '' - server1.wait_for_unit("glusterd.service") - server2.wait_for_unit("glusterd.service") + testScript = '' + server1.wait_for_unit("glusterd.service") + server2.wait_for_unit("glusterd.service") - server1.wait_until_succeeds("gluster peer status") - server2.wait_until_succeeds("gluster peer status") + server1.wait_until_succeeds("gluster peer status") + server2.wait_until_succeeds("gluster peer status") - # establish initial contact - server1.succeed("gluster peer probe server2") - server1.succeed("gluster peer probe server1") + # establish initial contact + server1.succeed("gluster peer probe server2") + server1.succeed("gluster peer probe server1") - server1.succeed("gluster peer status | grep Connected") + server1.succeed("gluster peer status | grep Connected") - # create volumes - server1.succeed("mkdir -p /data/vg0") - server2.succeed("mkdir -p /data/vg0") - server1.succeed("gluster volume create gv0 server1:/data/vg0 server2:/data/vg0") - server1.succeed("gluster volume start gv0") + # create volumes + server1.succeed("mkdir -p /data/vg0") + server2.succeed("mkdir -p /data/vg0") + server1.succeed("gluster volume create gv0 server1:/data/vg0 server2:/data/vg0") + server1.succeed("gluster volume start gv0") - # test clients - client1.wait_for_unit("gluster.mount") - client2.wait_for_unit("gluster.mount") + # test clients + client1.wait_for_unit("gluster.mount") + client2.wait_for_unit("gluster.mount") - client1.succeed("echo test > /gluster/file1") - client2.succeed("grep test /gluster/file1") - ''; -}) + client1.succeed("echo test > /gluster/file1") + client2.succeed("grep test /gluster/file1") + ''; + } +) diff --git a/nixos/tests/gnome-extensions.nix b/nixos/tests/gnome-extensions.nix index 109fdf6b0846c6..9fb868f824546d 100644 --- a/nixos/tests/gnome-extensions.nix +++ b/nixos/tests/gnome-extensions.nix @@ -1,150 +1,155 @@ import ./make-test-python.nix ( -{ pkgs, lib, ...}: -{ - name = "gnome-extensions"; - meta.maintainers = [ ]; - - nodes.machine = - { pkgs, ... }: - { - imports = [ ./common/user-account.nix ]; - - # Install all extensions - environment.systemPackages = lib.filter (e: e ? extensionUuid) (lib.attrValues pkgs.gnomeExtensions); - - # Some extensions are broken, but that's kind of the point of a testing VM - nixpkgs.config.allowBroken = true; - # There are some aliases which throw exceptions; ignore them. - # Also prevent duplicate extensions under different names. - nixpkgs.config.allowAliases = false; - - # Configure GDM - services.xserver.enable = true; - services.xserver.displayManager = { - gdm = { - enable = true; - debug = true; - wayland = true; - }; - autoLogin = { - enable = true; - user = "alice"; + { pkgs, lib, ... }: + { + name = "gnome-extensions"; + meta.maintainers = [ ]; + + nodes.machine = + { pkgs, ... }: + { + imports = [ ./common/user-account.nix ]; + + # Install all extensions + environment.systemPackages = lib.filter (e: e ? extensionUuid) ( + lib.attrValues pkgs.gnomeExtensions + ); + + # Some extensions are broken, but that's kind of the point of a testing VM + nixpkgs.config.allowBroken = true; + # There are some aliases which throw exceptions; ignore them. + # Also prevent duplicate extensions under different names. + nixpkgs.config.allowAliases = false; + + # Configure GDM + services.xserver.enable = true; + services.xserver.displayManager = { + gdm = { + enable = true; + debug = true; + wayland = true; + }; + autoLogin = { + enable = true; + user = "alice"; + }; }; - }; - # Configure Gnome - services.xserver.desktopManager.gnome.enable = true; - services.xserver.desktopManager.gnome.debug = true; - - systemd.user.services = { - "org.gnome.Shell@wayland" = { - serviceConfig = { - ExecStart = [ - # Clear the list before overriding it. - "" - # Eval API is now internal so Shell needs to run in unsafe mode. - # TODO: improve test driver so that it supports openqa-like manipulation - # that would allow us to drop this mess. - "${pkgs.gnome-shell}/bin/gnome-shell --unsafe-mode" - ]; + # Configure Gnome + services.xserver.desktopManager.gnome.enable = true; + services.xserver.desktopManager.gnome.debug = true; + + systemd.user.services = { + "org.gnome.Shell@wayland" = { + serviceConfig = { + ExecStart = [ + # Clear the list before overriding it. + "" + # Eval API is now internal so Shell needs to run in unsafe mode. + # TODO: improve test driver so that it supports openqa-like manipulation + # that would allow us to drop this mess. + "${pkgs.gnome-shell}/bin/gnome-shell --unsafe-mode" + ]; + }; }; }; + }; - }; - - testScript = { nodes, ... }: let - # Keep line widths somewhat manageable - user = nodes.machine.users.users.alice; - uid = toString user.uid; - bus = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${uid}/bus"; - # Run a command in the appropriate user environment - run = command: "su - ${user.name} -c '${bus} ${command}'"; - - # Call javascript in gnome shell, returns a tuple (success, output), where - # `success` is true if the dbus call was successful and output is what the - # javascript evaluates to. - eval = command: run "gdbus call --session -d org.gnome.Shell -o /org/gnome/Shell -m org.gnome.Shell.Eval ${command}"; - - # False when startup is done - startingUp = eval "Main.layoutManager._startingUp"; - - # Extensions to keep always enabled together - # Those are extensions that are usually always on for many users, and that we expect to work - # well together with most others without conflicts - alwaysOnExtensions = map (name: pkgs.gnomeExtensions.${name}.extensionUuid) [ - "applications-menu" - "user-themes" - ]; - - # Extensions to enable and disable individually - # Extensions like dash-to-dock and dash-to-panel cannot be enabled at the same time. - testExtensions = map (name: pkgs.gnomeExtensions.${name}.extensionUuid) [ - "appindicator" - "dash-to-dock" - "dash-to-panel" - "ddterm" - "gsconnect" - "system-monitor-next" - "desktop-icons-ng-ding" - "workspace-indicator" - "vitals" - ]; - in - '' - with subtest("Login to GNOME with GDM"): - # wait for gdm to start - machine.wait_for_unit("display-manager.service") - # wait for the wayland server - machine.wait_for_file("/run/user/${uid}/wayland-0") - # wait for alice to be logged in - machine.wait_for_unit("default.target", "${user.name}") - # check that logging in has given the user ownership of devices - assert "alice" in machine.succeed("getfacl -p /dev/snd/timer") - - with subtest("Wait for GNOME Shell"): - # correct output should be (true, 'false') - machine.wait_until_succeeds( - "${startingUp} | grep -q 'true,..false'" - ) - - # Close the Activities view so that Shell can correctly track the focused window. - machine.send_key("esc") - # # Disable extension version validation (only use for manual testing) - # machine.succeed( - # "${run "gsettings set org.gnome.shell disable-extension-version-validation true"}" - # ) - - # Assert that some extension is in a specific state - def checkState(target, extension): - state = machine.succeed( - f"${run "gnome-extensions info {extension}"} | grep '^ State: .*$'" - ) - assert target in state, f"{state} instead of {target}" - - def checkExtension(extension, disable): - with subtest(f"Enable extension '{extension}'"): - # Check that the extension is properly initialized; skip out of date ones - state = machine.succeed( - f"${run "gnome-extensions info {extension}"} | grep '^ State: .*$'" + testScript = + { nodes, ... }: + let + # Keep line widths somewhat manageable + user = nodes.machine.users.users.alice; + uid = toString user.uid; + bus = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${uid}/bus"; + # Run a command in the appropriate user environment + run = command: "su - ${user.name} -c '${bus} ${command}'"; + + # Call javascript in gnome shell, returns a tuple (success, output), where + # `success` is true if the dbus call was successful and output is what the + # javascript evaluates to. + eval = + command: + run "gdbus call --session -d org.gnome.Shell -o /org/gnome/Shell -m org.gnome.Shell.Eval ${command}"; + + # False when startup is done + startingUp = eval "Main.layoutManager._startingUp"; + + # Extensions to keep always enabled together + # Those are extensions that are usually always on for many users, and that we expect to work + # well together with most others without conflicts + alwaysOnExtensions = map (name: pkgs.gnomeExtensions.${name}.extensionUuid) [ + "applications-menu" + "user-themes" + ]; + + # Extensions to enable and disable individually + # Extensions like dash-to-dock and dash-to-panel cannot be enabled at the same time. + testExtensions = map (name: pkgs.gnomeExtensions.${name}.extensionUuid) [ + "appindicator" + "dash-to-dock" + "dash-to-panel" + "ddterm" + "gsconnect" + "system-monitor-next" + "desktop-icons-ng-ding" + "workspace-indicator" + "vitals" + ]; + in + '' + with subtest("Login to GNOME with GDM"): + # wait for gdm to start + machine.wait_for_unit("display-manager.service") + # wait for the wayland server + machine.wait_for_file("/run/user/${uid}/wayland-0") + # wait for alice to be logged in + machine.wait_for_unit("default.target", "${user.name}") + # check that logging in has given the user ownership of devices + assert "alice" in machine.succeed("getfacl -p /dev/snd/timer") + + with subtest("Wait for GNOME Shell"): + # correct output should be (true, 'false') + machine.wait_until_succeeds( + "${startingUp} | grep -q 'true,..false'" ) - if "OUT OF DATE" in state: - machine.log(f"Extension {extension} will be skipped because out of date") - return - - assert "INITIALIZED" in state, f"{state} instead of INITIALIZED" - - # Enable and optionally disable - machine.succeed(f"${run "gnome-extensions enable {extension}"}") - checkState("ACTIVE", extension) + # Close the Activities view so that Shell can correctly track the focused window. + machine.send_key("esc") + # # Disable extension version validation (only use for manual testing) + # machine.succeed( + # "${run "gsettings set org.gnome.shell disable-extension-version-validation true"}" + # ) - if disable: - machine.succeed(f"${run "gnome-extensions disable {extension}"}") - checkState("INACTIVE", extension) - '' - + lib.concatLines (map (e: ''checkExtension("${e}", False)'') alwaysOnExtensions) - + lib.concatLines (map (e: ''checkExtension("${e}", True)'') testExtensions) - ; -} + # Assert that some extension is in a specific state + def checkState(target, extension): + state = machine.succeed( + f"${run "gnome-extensions info {extension}"} | grep '^ State: .*$'" + ) + assert target in state, f"{state} instead of {target}" + + def checkExtension(extension, disable): + with subtest(f"Enable extension '{extension}'"): + # Check that the extension is properly initialized; skip out of date ones + state = machine.succeed( + f"${run "gnome-extensions info {extension}"} | grep '^ State: .*$'" + ) + if "OUT OF DATE" in state: + machine.log(f"Extension {extension} will be skipped because out of date") + return + + assert "INITIALIZED" in state, f"{state} instead of INITIALIZED" + + # Enable and optionally disable + + machine.succeed(f"${run "gnome-extensions enable {extension}"}") + checkState("ACTIVE", extension) + + if disable: + machine.succeed(f"${run "gnome-extensions disable {extension}"}") + checkState("INACTIVE", extension) + '' + + lib.concatLines (map (e: ''checkExtension("${e}", False)'') alwaysOnExtensions) + + lib.concatLines (map (e: ''checkExtension("${e}", True)'') testExtensions); + } ) diff --git a/nixos/tests/gnome-flashback.nix b/nixos/tests/gnome-flashback.nix index e0a1d256c8c204..b96245b4461e22 100644 --- a/nixos/tests/gnome-flashback.nix +++ b/nixos/tests/gnome-flashback.nix @@ -1,53 +1,61 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : { - name = "gnome-flashback"; - meta.maintainers = lib.teams.gnome.members ++ [ lib.maintainers.chpatrick ]; - - nodes.machine = { nodes, ... }: - let - user = nodes.machine.users.users.alice; - in - - { imports = [ ./common/user-account.nix ]; - - services.xserver.enable = true; - - services.xserver.displayManager = { - gdm.enable = true; - gdm.debug = true; - }; - - services.displayManager.autoLogin = { - enable = true; - user = user.name; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "gnome-flashback"; + meta.maintainers = lib.teams.gnome.members ++ [ lib.maintainers.chpatrick ]; + + nodes.machine = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + in + + { + imports = [ ./common/user-account.nix ]; + + services.xserver.enable = true; + + services.xserver.displayManager = { + gdm.enable = true; + gdm.debug = true; + }; + + services.displayManager.autoLogin = { + enable = true; + user = user.name; + }; + + services.xserver.desktopManager.gnome.enable = true; + services.xserver.desktopManager.gnome.debug = true; + services.xserver.desktopManager.gnome.flashback.enableMetacity = true; + services.displayManager.defaultSession = "gnome-flashback-metacity"; }; - services.xserver.desktopManager.gnome.enable = true; - services.xserver.desktopManager.gnome.debug = true; - services.xserver.desktopManager.gnome.flashback.enableMetacity = true; - services.displayManager.defaultSession = "gnome-flashback-metacity"; - }; - - testScript = { nodes, ... }: let - user = nodes.machine.users.users.alice; - uid = toString user.uid; - xauthority = "/run/user/${uid}/gdm/Xauthority"; - in '' - with subtest("Login to GNOME Flashback with GDM"): - machine.wait_for_x() - machine.wait_until_succeeds('journalctl -t gnome-session-binary --grep "Entering running state"') - # Wait for alice to be logged in" - machine.wait_for_unit("default.target", "${user.name}") - machine.wait_for_file("${xauthority}") - machine.succeed("xauth merge ${xauthority}") - # Check that logging in has given the user ownership of devices - assert "alice" in machine.succeed("getfacl -p /dev/snd/timer") - - with subtest("Wait for Metacity"): - machine.wait_until_succeeds("pgrep metacity") - - with subtest("Regression test for #233920"): - machine.wait_until_succeeds("pgrep -fa gnome-flashback-media-keys") - machine.sleep(20) - machine.screenshot("screen") - ''; -}) + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + uid = toString user.uid; + xauthority = "/run/user/${uid}/gdm/Xauthority"; + in + '' + with subtest("Login to GNOME Flashback with GDM"): + machine.wait_for_x() + machine.wait_until_succeeds('journalctl -t gnome-session-binary --grep "Entering running state"') + # Wait for alice to be logged in" + machine.wait_for_unit("default.target", "${user.name}") + machine.wait_for_file("${xauthority}") + machine.succeed("xauth merge ${xauthority}") + # Check that logging in has given the user ownership of devices + assert "alice" in machine.succeed("getfacl -p /dev/snd/timer") + + with subtest("Wait for Metacity"): + machine.wait_until_succeeds("pgrep metacity") + + with subtest("Regression test for #233920"): + machine.wait_until_succeeds("pgrep -fa gnome-flashback-media-keys") + machine.sleep(20) + machine.screenshot("screen") + ''; + } +) diff --git a/nixos/tests/gnome-xorg.nix b/nixos/tests/gnome-xorg.nix index 45538ef4eab407..b605781ce40f36 100644 --- a/nixos/tests/gnome-xorg.nix +++ b/nixos/tests/gnome-xorg.nix @@ -1,100 +1,111 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : { - name = "gnome-xorg"; - meta = { - maintainers = lib.teams.gnome.members; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "gnome-xorg"; + meta = { + maintainers = lib.teams.gnome.members; + }; - nodes.machine = { nodes, ... }: let - user = nodes.machine.users.users.alice; - in + nodes.machine = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + in - { imports = [ ./common/user-account.nix ]; + { + imports = [ ./common/user-account.nix ]; - services.xserver.enable = true; + services.xserver.enable = true; - services.xserver.displayManager = { - gdm.enable = true; - gdm.debug = true; - }; + services.xserver.displayManager = { + gdm.enable = true; + gdm.debug = true; + }; - services.displayManager.autoLogin = { - enable = true; - user = user.name; - }; + services.displayManager.autoLogin = { + enable = true; + user = user.name; + }; - services.xserver.desktopManager.gnome.enable = true; - services.xserver.desktopManager.gnome.debug = true; - services.displayManager.defaultSession = "gnome-xorg"; - - systemd.user.services = { - "org.gnome.Shell@x11" = { - serviceConfig = { - ExecStart = [ - # Clear the list before overriding it. - "" - # Eval API is now internal so Shell needs to run in unsafe mode. - # TODO: improve test driver so that it supports openqa-like manipulation - # that would allow us to drop this mess. - "${pkgs.gnome-shell}/bin/gnome-shell --unsafe-mode" - ]; + services.xserver.desktopManager.gnome.enable = true; + services.xserver.desktopManager.gnome.debug = true; + services.displayManager.defaultSession = "gnome-xorg"; + + systemd.user.services = { + "org.gnome.Shell@x11" = { + serviceConfig = { + ExecStart = [ + # Clear the list before overriding it. + "" + # Eval API is now internal so Shell needs to run in unsafe mode. + # TODO: improve test driver so that it supports openqa-like manipulation + # that would allow us to drop this mess. + "${pkgs.gnome-shell}/bin/gnome-shell --unsafe-mode" + ]; + }; }; }; - }; - }; + }; - testScript = { nodes, ... }: let - user = nodes.machine.users.users.alice; - uid = toString user.uid; - bus = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${uid}/bus"; - xauthority = "/run/user/${uid}/gdm/Xauthority"; - display = "DISPLAY=:0.0"; - env = "${bus} XAUTHORITY=${xauthority} ${display}"; - # Run a command in the appropriate user environment - run = command: "su - ${user.name} -c '${bus} ${command}'"; - - # Call javascript in gnome shell, returns a tuple (success, output), where - # `success` is true if the dbus call was successful and output is what the - # javascript evaluates to. - eval = command: run "gdbus call --session -d org.gnome.Shell -o /org/gnome/Shell -m org.gnome.Shell.Eval ${command}"; - - # False when startup is done - startingUp = eval "Main.layoutManager._startingUp"; - - # Start Console - launchConsole = run "gapplication launch org.gnome.Console"; - - # Hopefully Console's wm class - wmClass = eval "global.display.focus_window.wm_class"; - in '' - with subtest("Login to GNOME Xorg with GDM"): - machine.wait_for_x() - # Wait for alice to be logged in" - machine.wait_for_unit("default.target", "${user.name}") - machine.wait_for_file("${xauthority}") - machine.succeed("xauth merge ${xauthority}") - # Check that logging in has given the user ownership of devices - assert "alice" in machine.succeed("getfacl -p /dev/snd/timer") - - with subtest("Wait for GNOME Shell"): - # correct output should be (true, 'false') - machine.wait_until_succeeds( - "${startingUp} | grep -q 'true,..false'" - ) - - with subtest("Open Console"): - # Close the Activities view so that Shell can correctly track the focused window. - machine.send_key("esc") - - machine.succeed( - "${launchConsole}" - ) - # correct output should be (true, '"kgx"') - # For some reason, this deviates from Wayland. - machine.wait_until_succeeds( - "${wmClass} | grep -q 'true,...kgx'" - ) - machine.sleep(20) - machine.screenshot("screen") - ''; -}) + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + uid = toString user.uid; + bus = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${uid}/bus"; + xauthority = "/run/user/${uid}/gdm/Xauthority"; + display = "DISPLAY=:0.0"; + env = "${bus} XAUTHORITY=${xauthority} ${display}"; + # Run a command in the appropriate user environment + run = command: "su - ${user.name} -c '${bus} ${command}'"; + + # Call javascript in gnome shell, returns a tuple (success, output), where + # `success` is true if the dbus call was successful and output is what the + # javascript evaluates to. + eval = + command: + run "gdbus call --session -d org.gnome.Shell -o /org/gnome/Shell -m org.gnome.Shell.Eval ${command}"; + + # False when startup is done + startingUp = eval "Main.layoutManager._startingUp"; + + # Start Console + launchConsole = run "gapplication launch org.gnome.Console"; + + # Hopefully Console's wm class + wmClass = eval "global.display.focus_window.wm_class"; + in + '' + with subtest("Login to GNOME Xorg with GDM"): + machine.wait_for_x() + # Wait for alice to be logged in" + machine.wait_for_unit("default.target", "${user.name}") + machine.wait_for_file("${xauthority}") + machine.succeed("xauth merge ${xauthority}") + # Check that logging in has given the user ownership of devices + assert "alice" in machine.succeed("getfacl -p /dev/snd/timer") + + with subtest("Wait for GNOME Shell"): + # correct output should be (true, 'false') + machine.wait_until_succeeds( + "${startingUp} | grep -q 'true,..false'" + ) + + with subtest("Open Console"): + # Close the Activities view so that Shell can correctly track the focused window. + machine.send_key("esc") + + machine.succeed( + "${launchConsole}" + ) + # correct output should be (true, '"kgx"') + # For some reason, this deviates from Wayland. + machine.wait_until_succeeds( + "${wmClass} | grep -q 'true,...kgx'" + ) + machine.sleep(20) + machine.screenshot("screen") + ''; + } +) diff --git a/nixos/tests/gnome.nix b/nixos/tests/gnome.nix index 9a296b93682c4e..08213e41f98d9b 100644 --- a/nixos/tests/gnome.nix +++ b/nixos/tests/gnome.nix @@ -1,94 +1,103 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : { - name = "gnome"; - meta.maintainers = lib.teams.gnome.members; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "gnome"; + meta.maintainers = lib.teams.gnome.members; - nodes.machine = - { ... }: + nodes.machine = + { ... }: - { imports = [ ./common/user-account.nix ]; + { + imports = [ ./common/user-account.nix ]; - services.xserver.enable = true; + services.xserver.enable = true; - services.xserver.displayManager = { - gdm.enable = true; - gdm.debug = true; - }; + services.xserver.displayManager = { + gdm.enable = true; + gdm.debug = true; + }; - services.displayManager.autoLogin = { - enable = true; - user = "alice"; - }; + services.displayManager.autoLogin = { + enable = true; + user = "alice"; + }; - services.xserver.desktopManager.gnome.enable = true; - services.xserver.desktopManager.gnome.debug = true; - - systemd.user.services = { - "org.gnome.Shell@wayland" = { - serviceConfig = { - ExecStart = [ - # Clear the list before overriding it. - "" - # Eval API is now internal so Shell needs to run in unsafe mode. - # TODO: improve test driver so that it supports openqa-like manipulation - # that would allow us to drop this mess. - "${pkgs.gnome-shell}/bin/gnome-shell --unsafe-mode" - ]; + services.xserver.desktopManager.gnome.enable = true; + services.xserver.desktopManager.gnome.debug = true; + + systemd.user.services = { + "org.gnome.Shell@wayland" = { + serviceConfig = { + ExecStart = [ + # Clear the list before overriding it. + "" + # Eval API is now internal so Shell needs to run in unsafe mode. + # TODO: improve test driver so that it supports openqa-like manipulation + # that would allow us to drop this mess. + "${pkgs.gnome-shell}/bin/gnome-shell --unsafe-mode" + ]; + }; }; }; + }; - }; - - testScript = { nodes, ... }: let - # Keep line widths somewhat manageable - user = nodes.machine.users.users.alice; - uid = toString user.uid; - bus = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${uid}/bus"; - # Run a command in the appropriate user environment - run = command: "su - ${user.name} -c '${bus} ${command}'"; - - # Call javascript in gnome shell, returns a tuple (success, output), where - # `success` is true if the dbus call was successful and output is what the - # javascript evaluates to. - eval = command: run "gdbus call --session -d org.gnome.Shell -o /org/gnome/Shell -m org.gnome.Shell.Eval ${command}"; - - # False when startup is done - startingUp = eval "Main.layoutManager._startingUp"; - - # Start Console - launchConsole = run "gapplication launch org.gnome.Console"; - - # Hopefully Console's wm class - wmClass = eval "global.display.focus_window.wm_class"; - in '' - with subtest("Login to GNOME with GDM"): - # wait for gdm to start - machine.wait_for_unit("display-manager.service") - # wait for the wayland server - machine.wait_for_file("/run/user/${uid}/wayland-0") - # wait for alice to be logged in - machine.wait_for_unit("default.target", "${user.name}") - # check that logging in has given the user ownership of devices - assert "alice" in machine.succeed("getfacl -p /dev/snd/timer") - - with subtest("Wait for GNOME Shell"): - # correct output should be (true, 'false') - machine.wait_until_succeeds( - "${startingUp} | grep -q 'true,..false'" - ) - - with subtest("Open Console"): - # Close the Activities view so that Shell can correctly track the focused window. - machine.send_key("esc") - - machine.succeed( - "${launchConsole}" - ) - # correct output should be (true, '"org.gnome.Console"') - machine.wait_until_succeeds( - "${wmClass} | grep -q 'true,...org.gnome.Console'" - ) - machine.sleep(20) - machine.screenshot("screen") - ''; -}) + testScript = + { nodes, ... }: + let + # Keep line widths somewhat manageable + user = nodes.machine.users.users.alice; + uid = toString user.uid; + bus = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${uid}/bus"; + # Run a command in the appropriate user environment + run = command: "su - ${user.name} -c '${bus} ${command}'"; + + # Call javascript in gnome shell, returns a tuple (success, output), where + # `success` is true if the dbus call was successful and output is what the + # javascript evaluates to. + eval = + command: + run "gdbus call --session -d org.gnome.Shell -o /org/gnome/Shell -m org.gnome.Shell.Eval ${command}"; + + # False when startup is done + startingUp = eval "Main.layoutManager._startingUp"; + + # Start Console + launchConsole = run "gapplication launch org.gnome.Console"; + + # Hopefully Console's wm class + wmClass = eval "global.display.focus_window.wm_class"; + in + '' + with subtest("Login to GNOME with GDM"): + # wait for gdm to start + machine.wait_for_unit("display-manager.service") + # wait for the wayland server + machine.wait_for_file("/run/user/${uid}/wayland-0") + # wait for alice to be logged in + machine.wait_for_unit("default.target", "${user.name}") + # check that logging in has given the user ownership of devices + assert "alice" in machine.succeed("getfacl -p /dev/snd/timer") + + with subtest("Wait for GNOME Shell"): + # correct output should be (true, 'false') + machine.wait_until_succeeds( + "${startingUp} | grep -q 'true,..false'" + ) + + with subtest("Open Console"): + # Close the Activities view so that Shell can correctly track the focused window. + machine.send_key("esc") + + machine.succeed( + "${launchConsole}" + ) + # correct output should be (true, '"org.gnome.Console"') + machine.wait_until_succeeds( + "${wmClass} | grep -q 'true,...org.gnome.Console'" + ) + machine.sleep(20) + machine.screenshot("screen") + ''; + } +) diff --git a/nixos/tests/gns3-server.nix b/nixos/tests/gns3-server.nix index e37d751f5f6400..309b83053b8d8b 100644 --- a/nixos/tests/gns3-server.nix +++ b/nixos/tests/gns3-server.nix @@ -1,55 +1,62 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "gns3-server"; - meta.maintainers = [ lib.maintainers.anthonyroussel ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "gns3-server"; + meta.maintainers = [ lib.maintainers.anthonyroussel ]; - nodes.machine = - { ... }: - let - tls-cert = pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' - openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -days 365 \ - -subj '/CN=localhost' - install -D -t $out key.pem cert.pem - ''; - in { - services.gns3-server = { - enable = true; - auth = { - enable = true; - user = "user"; - passwordFile = pkgs.writeText "gns3-auth-password-file" "password"; - }; - ssl = { + nodes.machine = + { ... }: + let + tls-cert = pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' + openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -days 365 \ + -subj '/CN=localhost' + install -D -t $out key.pem cert.pem + ''; + in + { + services.gns3-server = { enable = true; - certFile = "${tls-cert}/cert.pem"; - keyFile = "${tls-cert}/key.pem"; + auth = { + enable = true; + user = "user"; + passwordFile = pkgs.writeText "gns3-auth-password-file" "password"; + }; + ssl = { + enable = true; + certFile = "${tls-cert}/cert.pem"; + keyFile = "${tls-cert}/key.pem"; + }; + dynamips.enable = true; + ubridge.enable = true; + vpcs.enable = true; }; - dynamips.enable = true; - ubridge.enable = true; - vpcs.enable = true; - }; - security.pki.certificateFiles = [ "${tls-cert}/cert.pem" ]; - }; + security.pki.certificateFiles = [ "${tls-cert}/cert.pem" ]; + }; - testScript = let - createProject = pkgs.writeText "createProject.json" (builtins.toJSON { - name = "test_project"; - }); - in - '' - start_all() + testScript = + let + createProject = pkgs.writeText "createProject.json" ( + builtins.toJSON { + name = "test_project"; + } + ); + in + '' + start_all() - machine.wait_for_unit("gns3-server.service") - machine.wait_for_open_port(3080) + machine.wait_for_unit("gns3-server.service") + machine.wait_for_open_port(3080) - with subtest("server is listening"): - machine.succeed("curl -sSfL -u user:password https://localhost:3080/v2/version") + with subtest("server is listening"): + machine.succeed("curl -sSfL -u user:password https://localhost:3080/v2/version") - with subtest("create dummy project"): - machine.succeed("curl -sSfL -u user:password https://localhost:3080/v2/projects -d @${createProject}") + with subtest("create dummy project"): + machine.succeed("curl -sSfL -u user:password https://localhost:3080/v2/projects -d @${createProject}") - with subtest("logging works"): - log_path = "/var/log/gns3/server.log" - machine.wait_for_file(log_path) - ''; -}) + with subtest("logging works"): + log_path = "/var/log/gns3/server.log" + machine.wait_for_file(log_path) + ''; + } +) diff --git a/nixos/tests/gnupg.nix b/nixos/tests/gnupg.nix index 68110c9d6d5496..897c94aba5076c 100644 --- a/nixos/tests/gnupg.nix +++ b/nixos/tests/gnupg.nix @@ -1,48 +1,52 @@ -import ./make-test-python.nix ({ pkgs, lib, ...}: - -{ - name = "gnupg"; - meta = with lib.maintainers; { - maintainers = [ rnhmjoj ]; - }; - - # server for testing SSH - nodes.server = { ... }: { - imports = [ ../modules/profiles/minimal.nix ]; - - users.users.alice.isNormalUser = true; - services.openssh.enable = true; - }; - - # machine for testing GnuPG - nodes.machine = { pkgs, ... }: { - imports = [ ../modules/profiles/minimal.nix ]; - - users.users.alice.isNormalUser = true; - services.getty.autologinUser = "alice"; - - environment.shellInit = '' - # preset a key passphrase in gpg-agent - preset_key() { - # find all keys - case "$1" in - ssh) grips=$(awk '/^[0-9A-F]/{print $1}' "''${GNUPGHOME:-$HOME/.gnupg}/sshcontrol") ;; - pgp) grips=$(gpg --with-keygrip --list-secret-keys | awk '/Keygrip/{print $3}') ;; - esac - - # try to preset the passphrase for each key found - for grip in $grips; do - "$(gpgconf --list-dirs libexecdir)/gpg-preset-passphrase" -c -P "$2" "$grip" - done - } - ''; - - programs.gnupg.agent.enable = true; - programs.gnupg.agent.enableSSHSupport = true; - }; - - testScript = - '' +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + { + name = "gnupg"; + meta = with lib.maintainers; { + maintainers = [ rnhmjoj ]; + }; + + # server for testing SSH + nodes.server = + { ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; + + users.users.alice.isNormalUser = true; + services.openssh.enable = true; + }; + + # machine for testing GnuPG + nodes.machine = + { pkgs, ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; + + users.users.alice.isNormalUser = true; + services.getty.autologinUser = "alice"; + + environment.shellInit = '' + # preset a key passphrase in gpg-agent + preset_key() { + # find all keys + case "$1" in + ssh) grips=$(awk '/^[0-9A-F]/{print $1}' "''${GNUPGHOME:-$HOME/.gnupg}/sshcontrol") ;; + pgp) grips=$(gpg --with-keygrip --list-secret-keys | awk '/Keygrip/{print $3}') ;; + esac + + # try to preset the passphrase for each key found + for grip in $grips; do + "$(gpgconf --list-dirs libexecdir)/gpg-preset-passphrase" -c -P "$2" "$grip" + done + } + ''; + + programs.gnupg.agent.enable = true; + programs.gnupg.agent.enableSSHSupport = true; + }; + + testScript = '' import shlex @@ -119,4 +123,5 @@ import ./make-test-python.nix ({ pkgs, lib, ...}: server.wait_for_open_port(22) machine.succeed(as_alice("ssh -i alice -o StrictHostKeyChecking=no server exit")) ''; -}) + } +) diff --git a/nixos/tests/go-camo.nix b/nixos/tests/go-camo.nix index 513964c31c4333..f53d5417ce7464 100644 --- a/nixos/tests/go-camo.nix +++ b/nixos/tests/go-camo.nix @@ -1,30 +1,36 @@ -{ system ? builtins.currentSystem, config ? { } -, pkgs ? import ../.. { inherit system config; } }: +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, +}: with import ../lib/testing-python.nix { inherit system pkgs; }; { - gocamo_file_key = let + gocamo_file_key = + let key_val = "12345678"; in makeTest { - name = "go-camo-file-key"; - meta = { - maintainers = [ pkgs.lib.maintainers.viraptor ]; - }; - - nodes.machine = { config, pkgs, ... }: { - services.go-camo = { - enable = true; - keyFile = pkgs.writeText "foo" key_val; + name = "go-camo-file-key"; + meta = { + maintainers = [ pkgs.lib.maintainers.viraptor ]; }; - }; - # go-camo responds to http requests - testScript = '' - machine.wait_for_unit("go-camo.service") - machine.wait_for_open_port(8080) - machine.succeed("curl http://localhost:8080") - ''; - }; + nodes.machine = + { config, pkgs, ... }: + { + services.go-camo = { + enable = true; + keyFile = pkgs.writeText "foo" key_val; + }; + }; + + # go-camo responds to http requests + testScript = '' + machine.wait_for_unit("go-camo.service") + machine.wait_for_open_port(8080) + machine.succeed("curl http://localhost:8080") + ''; + }; } diff --git a/nixos/tests/go-neb.nix b/nixos/tests/go-neb.nix index 4bd03dcf3c6b4f..38cf89c2a35269 100644 --- a/nixos/tests/go-neb.nix +++ b/nixos/tests/go-neb.nix @@ -1,44 +1,53 @@ -import ./make-test-python.nix ({ pkgs, ... }: -{ - name = "go-neb"; - meta = with pkgs.lib.maintainers; { - maintainers = [ hexa maralorn ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "go-neb"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + hexa + maralorn + ]; + }; - nodes = { - server = { - services.go-neb = { - enable = true; - baseUrl = "http://localhost"; - secretFile = pkgs.writeText "secrets" "ACCESS_TOKEN=changeme"; - config = { - clients = [ { - UserId = "@test:localhost"; - AccessToken = "$ACCESS_TOKEN"; - HomeServerUrl = "http://localhost"; - Sync = false; - AutoJoinRooms = false; - DisplayName = "neverbeseen"; - } ]; - services = [ { - ID = "wikipedia_service"; - Type = "wikipedia"; - UserID = "@test:localhost"; - Config = { }; - } ]; + nodes = { + server = { + services.go-neb = { + enable = true; + baseUrl = "http://localhost"; + secretFile = pkgs.writeText "secrets" "ACCESS_TOKEN=changeme"; + config = { + clients = [ + { + UserId = "@test:localhost"; + AccessToken = "$ACCESS_TOKEN"; + HomeServerUrl = "http://localhost"; + Sync = false; + AutoJoinRooms = false; + DisplayName = "neverbeseen"; + } + ]; + services = [ + { + ID = "wikipedia_service"; + Type = "wikipedia"; + UserID = "@test:localhost"; + Config = { }; + } + ]; + }; }; }; }; - }; - testScript = '' - start_all() - server.wait_for_unit("go-neb.service") - server.wait_until_succeeds("curl -fL http://localhost:4050/services/hooks/d2lraXBlZGlhX3NlcnZpY2U") - server.succeed( - "journalctl -eu go-neb -o cat | grep -q service_id=wikipedia_service", - "grep -q changeme /var/run/go-neb/config.yaml", - ) - ''; + testScript = '' + start_all() + server.wait_for_unit("go-neb.service") + server.wait_until_succeeds("curl -fL http://localhost:4050/services/hooks/d2lraXBlZGlhX3NlcnZpY2U") + server.succeed( + "journalctl -eu go-neb -o cat | grep -q service_id=wikipedia_service", + "grep -q changeme /var/run/go-neb/config.yaml", + ) + ''; -}) + } +) diff --git a/nixos/tests/gobgpd.nix b/nixos/tests/gobgpd.nix index 775f65d1199f37..029b486b7cc608 100644 --- a/nixos/tests/gobgpd.nix +++ b/nixos/tests/gobgpd.nix @@ -1,71 +1,87 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: let - ifAddr = node: iface: (pkgs.lib.head node.config.networking.interfaces.${iface}.ipv4.addresses).address; - in { + ifAddr = + node: iface: (pkgs.lib.head node.config.networking.interfaces.${iface}.ipv4.addresses).address; + in + { name = "gobgpd"; - meta = with pkgs.lib.maintainers; { maintainers = [ higebu ]; }; + meta = with pkgs.lib.maintainers; { + maintainers = [ higebu ]; + }; nodes = { - node1 = { nodes, ... }: { - environment.systemPackages = [ pkgs.gobgp ]; - networking.firewall.allowedTCPPorts = [ 179 ]; - services.gobgpd = { - enable = true; - settings = { - global = { - config = { - as = 64512; - router-id = "192.168.255.1"; + node1 = + { nodes, ... }: + { + environment.systemPackages = [ pkgs.gobgp ]; + networking.firewall.allowedTCPPorts = [ 179 ]; + services.gobgpd = { + enable = true; + settings = { + global = { + config = { + as = 64512; + router-id = "192.168.255.1"; + }; }; + neighbors = [ + { + config = { + neighbor-address = ifAddr nodes.node2 "eth1"; + peer-as = 64513; + }; + } + ]; }; - neighbors = [{ - config = { - neighbor-address = ifAddr nodes.node2 "eth1"; - peer-as = 64513; - }; - }]; }; }; - }; - node2 = { nodes, ... }: { - environment.systemPackages = [ pkgs.gobgp ]; - networking.firewall.allowedTCPPorts = [ 179 ]; - services.gobgpd = { - enable = true; - settings = { - global = { - config = { - as = 64513; - router-id = "192.168.255.2"; + node2 = + { nodes, ... }: + { + environment.systemPackages = [ pkgs.gobgp ]; + networking.firewall.allowedTCPPorts = [ 179 ]; + services.gobgpd = { + enable = true; + settings = { + global = { + config = { + as = 64513; + router-id = "192.168.255.2"; + }; }; + neighbors = [ + { + config = { + neighbor-address = ifAddr nodes.node1 "eth1"; + peer-as = 64512; + }; + } + ]; }; - neighbors = [{ - config = { - neighbor-address = ifAddr nodes.node1 "eth1"; - peer-as = 64512; - }; - }]; }; }; - }; }; - testScript = { nodes, ... }: let - addr1 = ifAddr nodes.node1 "eth1"; - addr2 = ifAddr nodes.node2 "eth1"; - in + testScript = + { nodes, ... }: + let + addr1 = ifAddr nodes.node1 "eth1"; + addr2 = ifAddr nodes.node2 "eth1"; + in '' - start_all() + start_all() - for node in node1, node2: - with subtest("should start gobgpd node"): - node.wait_for_unit("gobgpd.service") - with subtest("should open port 179"): - node.wait_for_open_port(179) + for node in node1, node2: + with subtest("should start gobgpd node"): + node.wait_for_unit("gobgpd.service") + with subtest("should open port 179"): + node.wait_for_open_port(179) - with subtest("should show neighbors by gobgp cli and BGP state should be ESTABLISHED"): - node1.wait_until_succeeds("gobgp neighbor ${addr2} | grep -q ESTABLISHED") - node2.wait_until_succeeds("gobgp neighbor ${addr1} | grep -q ESTABLISHED") - ''; - }) + with subtest("should show neighbors by gobgp cli and BGP state should be ESTABLISHED"): + node1.wait_until_succeeds("gobgp neighbor ${addr2} | grep -q ESTABLISHED") + node2.wait_until_succeeds("gobgp neighbor ${addr1} | grep -q ESTABLISHED") + ''; + } +) diff --git a/nixos/tests/gocd-agent.nix b/nixos/tests/gocd-agent.nix index 9301a88ec05d83..d717299d55c7fa 100644 --- a/nixos/tests/gocd-agent.nix +++ b/nixos/tests/gocd-agent.nix @@ -9,40 +9,46 @@ let header = "Accept: application/vnd.go.cd.v2+json"; in -import ./make-test-python.nix ({ pkgs, ...} : { - name = "gocd-agent"; - meta = with pkgs.lib.maintainers; { - maintainers = [ grahamc swarren83 ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "gocd-agent"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + grahamc + swarren83 + ]; - # gocd agent needs to register with the autoregister key created on first server startup, - # but NixOS module doesn't seem to allow to pass during runtime currently - broken = true; - }; + # gocd agent needs to register with the autoregister key created on first server startup, + # but NixOS module doesn't seem to allow to pass during runtime currently + broken = true; + }; - nodes = { - agent = - { ... }: - { - virtualisation.memorySize = 2046; - services.gocd-agent = { - enable = true; + nodes = { + agent = + { ... }: + { + virtualisation.memorySize = 2046; + services.gocd-agent = { + enable = true; + }; + services.gocd-server = { + enable = true; + }; }; - services.gocd-server = { - enable = true; - }; - }; - }; + }; - testScript = '' - start_all() - agent.wait_for_unit("gocd-server") - agent.wait_for_open_port(8153) - agent.wait_for_unit("gocd-agent") - agent.wait_until_succeeds( - "curl ${serverUrl} -H '${header}' | ${pkgs.jq}/bin/jq -e ._embedded.agents[0].uuid" - ) - agent.succeed( - "curl ${serverUrl} -H '${header}' | ${pkgs.jq}/bin/jq -e ._embedded.agents[0].agent_state | grep Idle" - ) - ''; -}) + testScript = '' + start_all() + agent.wait_for_unit("gocd-server") + agent.wait_for_open_port(8153) + agent.wait_for_unit("gocd-agent") + agent.wait_until_succeeds( + "curl ${serverUrl} -H '${header}' | ${pkgs.jq}/bin/jq -e ._embedded.agents[0].uuid" + ) + agent.succeed( + "curl ${serverUrl} -H '${header}' | ${pkgs.jq}/bin/jq -e ._embedded.agents[0].agent_state | grep Idle" + ) + ''; + } +) diff --git a/nixos/tests/gocd-server.nix b/nixos/tests/gocd-server.nix index aff651c5278fb6..95b126c55a52f7 100644 --- a/nixos/tests/gocd-server.nix +++ b/nixos/tests/gocd-server.nix @@ -2,27 +2,29 @@ # 1. GoCD server starts # 2. GoCD server responds -import ./make-test-python.nix ({ pkgs, ...} : +import ./make-test-python.nix ( + { pkgs, ... }: -{ - name = "gocd-server"; - meta = with pkgs.lib.maintainers; { - maintainers = [ swarren83 ]; - }; + { + name = "gocd-server"; + meta = with pkgs.lib.maintainers; { + maintainers = [ swarren83 ]; + }; - nodes = { - server = - { ... }: - { - virtualisation.memorySize = 2046; - services.gocd-server.enable = true; - }; - }; + nodes = { + server = + { ... }: + { + virtualisation.memorySize = 2046; + services.gocd-server.enable = true; + }; + }; - testScript = '' - server.start() - server.wait_for_unit("gocd-server") - server.wait_for_open_port(8153) - server.wait_until_succeeds("curl -s -f localhost:8153/go") - ''; -}) + testScript = '' + server.start() + server.wait_for_unit("gocd-server") + server.wait_for_open_port(8153) + server.wait_until_succeeds("curl -s -f localhost:8153/go") + ''; + } +) diff --git a/nixos/tests/gollum.nix b/nixos/tests/gollum.nix index 44d373e35262b4..ab937bc990bb14 100644 --- a/nixos/tests/gollum.nix +++ b/nixos/tests/gollum.nix @@ -1,14 +1,21 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "gollum"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "gollum"; - nodes = { - webserver = { pkgs, lib, ... }: { - services.gollum.enable = true; + nodes = { + webserver = + { pkgs, lib, ... }: + { + services.gollum.enable = true; + }; }; - }; - testScript = { nodes, ... }: '' - webserver.wait_for_unit("gollum") - webserver.wait_for_open_port(${toString nodes.webserver.services.gollum.port}) - ''; -}) + testScript = + { nodes, ... }: + '' + webserver.wait_for_unit("gollum") + webserver.wait_for_open_port(${toString nodes.webserver.services.gollum.port}) + ''; + } +) diff --git a/nixos/tests/gonic.nix b/nixos/tests/gonic.nix index adf0f511a9cf7e..47d432d6354af1 100644 --- a/nixos/tests/gonic.nix +++ b/nixos/tests/gonic.nix @@ -1,26 +1,31 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "gonic"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "gonic"; - nodes.machine = { ... }: { - systemd.tmpfiles.settings = { - "10-gonic" = { - "/tmp/music"."d" = {}; - "/tmp/podcast"."d" = {}; - "/tmp/playlists"."d" = {}; + nodes.machine = + { ... }: + { + systemd.tmpfiles.settings = { + "10-gonic" = { + "/tmp/music"."d" = { }; + "/tmp/podcast"."d" = { }; + "/tmp/playlists"."d" = { }; + }; + }; + services.gonic = { + enable = true; + settings = { + music-path = [ "/tmp/music" ]; + podcast-path = "/tmp/podcast"; + playlists-path = "/tmp/playlists"; + }; + }; }; - }; - services.gonic = { - enable = true; - settings = { - music-path = [ "/tmp/music" ]; - podcast-path = "/tmp/podcast"; - playlists-path = "/tmp/playlists"; - }; - }; - }; - testScript = '' - machine.wait_for_unit("gonic") - machine.wait_for_open_port(4747) - ''; -}) + testScript = '' + machine.wait_for_unit("gonic") + machine.wait_for_open_port(4747) + ''; + } +) diff --git a/nixos/tests/google-oslogin/default.nix b/nixos/tests/google-oslogin/default.nix index cd05af6b9ed7a6..ace33802289a0e 100644 --- a/nixos/tests/google-oslogin/default.nix +++ b/nixos/tests/google-oslogin/default.nix @@ -1,7 +1,10 @@ -import ../make-test-python.nix ({ pkgs, ... } : -let - inherit (import ./../ssh-keys.nix pkgs) - snakeOilPrivateKey snakeOilPublicKey; +import ../make-test-python.nix ( + { pkgs, ... }: + let + inherit (import ./../ssh-keys.nix pkgs) + snakeOilPrivateKey + snakeOilPublicKey + ; # don't check host keys or known hosts, use the snakeoil ssh key ssh-config = builtins.toFile "ssh.conf" '' @@ -9,65 +12,67 @@ let StrictHostKeyChecking=no IdentityFile=~/.ssh/id_snakeoil ''; -in { - name = "google-oslogin"; - meta = with pkgs.lib.maintainers; { - maintainers = [ flokli ]; - }; + in + { + name = "google-oslogin"; + meta = with pkgs.lib.maintainers; { + maintainers = [ flokli ]; + }; - nodes = { - # the server provides both the the mocked google metadata server and the ssh server - server = (import ./server.nix pkgs); + nodes = { + # the server provides both the the mocked google metadata server and the ssh server + server = (import ./server.nix pkgs); - client = { ... }: {}; - }; - testScript = '' - MOCKUSER = "mockuser_nixos_org" - MOCKADMIN = "mockadmin_nixos_org" - start_all() + client = { ... }: { }; + }; + testScript = '' + MOCKUSER = "mockuser_nixos_org" + MOCKADMIN = "mockadmin_nixos_org" + start_all() - server.wait_for_unit("mock-google-metadata.service") - server.wait_for_open_port(80) + server.wait_for_unit("mock-google-metadata.service") + server.wait_for_open_port(80) - # mockserver should return a non-expired ssh key for both mockuser and mockadmin - server.succeed( - f'${pkgs.google-guest-oslogin}/bin/google_authorized_keys {MOCKUSER} | grep -q "${snakeOilPublicKey}"' - ) - server.succeed( - f'${pkgs.google-guest-oslogin}/bin/google_authorized_keys {MOCKADMIN} | grep -q "${snakeOilPublicKey}"' - ) + # mockserver should return a non-expired ssh key for both mockuser and mockadmin + server.succeed( + f'${pkgs.google-guest-oslogin}/bin/google_authorized_keys {MOCKUSER} | grep -q "${snakeOilPublicKey}"' + ) + server.succeed( + f'${pkgs.google-guest-oslogin}/bin/google_authorized_keys {MOCKADMIN} | grep -q "${snakeOilPublicKey}"' + ) - # install snakeoil ssh key on the client, and provision .ssh/config file - client.succeed("mkdir -p ~/.ssh") - client.succeed( - "cat ${snakeOilPrivateKey} > ~/.ssh/id_snakeoil" - ) - client.succeed("chmod 600 ~/.ssh/id_snakeoil") - client.succeed("cp ${ssh-config} ~/.ssh/config") + # install snakeoil ssh key on the client, and provision .ssh/config file + client.succeed("mkdir -p ~/.ssh") + client.succeed( + "cat ${snakeOilPrivateKey} > ~/.ssh/id_snakeoil" + ) + client.succeed("chmod 600 ~/.ssh/id_snakeoil") + client.succeed("cp ${ssh-config} ~/.ssh/config") - client.wait_for_unit("network.target") - server.wait_for_unit("sshd.service") + client.wait_for_unit("network.target") + server.wait_for_unit("sshd.service") - # we should not be able to connect as non-existing user - client.fail("ssh ghost@server 'true'") + # we should not be able to connect as non-existing user + client.fail("ssh ghost@server 'true'") - # we should be able to connect as mockuser - client.succeed(f"ssh {MOCKUSER}@server 'true'") - # but we shouldn't be able to sudo - client.fail( - f"ssh {MOCKUSER}@server '/run/wrappers/bin/sudo /run/current-system/sw/bin/id' | grep -q 'root'" - ) + # we should be able to connect as mockuser + client.succeed(f"ssh {MOCKUSER}@server 'true'") + # but we shouldn't be able to sudo + client.fail( + f"ssh {MOCKUSER}@server '/run/wrappers/bin/sudo /run/current-system/sw/bin/id' | grep -q 'root'" + ) - # we should also be able to log in as mockadmin - client.succeed(f"ssh {MOCKADMIN}@server 'true'") - # pam_oslogin_admin.so should now have generated a sudoers file - server.succeed( - f"find /run/google-sudoers.d | grep -q '/run/google-sudoers.d/{MOCKADMIN}'" - ) + # we should also be able to log in as mockadmin + client.succeed(f"ssh {MOCKADMIN}@server 'true'") + # pam_oslogin_admin.so should now have generated a sudoers file + server.succeed( + f"find /run/google-sudoers.d | grep -q '/run/google-sudoers.d/{MOCKADMIN}'" + ) - # and we should be able to sudo - client.succeed( - f"ssh {MOCKADMIN}@server '/run/wrappers/bin/sudo /run/current-system/sw/bin/id' | grep -q 'root'" - ) - ''; - }) + # and we should be able to sudo + client.succeed( + f"ssh {MOCKADMIN}@server '/run/wrappers/bin/sudo /run/current-system/sw/bin/id' | grep -q 'root'" + ) + ''; + } +) diff --git a/nixos/tests/google-oslogin/server.nix b/nixos/tests/google-oslogin/server.nix index 3df41155c92d4f..cd63056781789e 100644 --- a/nixos/tests/google-oslogin/server.nix +++ b/nixos/tests/google-oslogin/server.nix @@ -1,8 +1,11 @@ { pkgs, ... }: let inherit (import ./../ssh-keys.nix pkgs) - snakeOilPrivateKey snakeOilPublicKey; -in { + snakeOilPrivateKey + snakeOilPublicKey + ; +in +{ networking.firewall.allowedTCPPorts = [ 80 ]; systemd.services.mock-google-metadata = { @@ -23,5 +26,10 @@ in { security.googleOsLogin.enable = true; # Mock google service - networking.interfaces.lo.ipv4.addresses = [ { address = "169.254.169.254"; prefixLength = 32; } ]; + networking.interfaces.lo.ipv4.addresses = [ + { + address = "169.254.169.254"; + prefixLength = 32; + } + ]; } diff --git a/nixos/tests/goss.nix b/nixos/tests/goss.nix index 2e77b2734464f4..1bf9feda8ba3fb 100644 --- a/nixos/tests/goss.nix +++ b/nixos/tests/goss.nix @@ -1,49 +1,52 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "goss"; - meta.maintainers = [ lib.maintainers.anthonyroussel ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "goss"; + meta.maintainers = [ lib.maintainers.anthonyroussel ]; - nodes.machine = { - environment.systemPackages = [ pkgs.jq ]; + nodes.machine = { + environment.systemPackages = [ pkgs.jq ]; - services.goss = { - enable = true; + services.goss = { + enable = true; - environment = { - GOSS_FMT = "json"; - }; - - settings = { - addr."tcp://localhost:8080" = { - reachable = true; - local-address = "127.0.0.1"; + environment = { + GOSS_FMT = "json"; }; - command."check-goss-version" = { - exec = "${lib.getExe pkgs.goss} --version"; - exit-status = 0; - }; - dns.localhost.resolvable = true; - file."/nix" = { - filetype = "directory"; - exists = true; + + settings = { + addr."tcp://localhost:8080" = { + reachable = true; + local-address = "127.0.0.1"; + }; + command."check-goss-version" = { + exec = "${lib.getExe pkgs.goss} --version"; + exit-status = 0; + }; + dns.localhost.resolvable = true; + file."/nix" = { + filetype = "directory"; + exists = true; + }; + group.root.exists = true; + kernel-param."kernel.ostype".value = "Linux"; + user.root.exists = true; }; - group.root.exists = true; - kernel-param."kernel.ostype".value = "Linux"; - user.root.exists = true; }; }; - }; - testScript = '' - import json + testScript = '' + import json - machine.wait_for_unit("goss.service") - machine.wait_for_open_port(8080) + machine.wait_for_unit("goss.service") + machine.wait_for_open_port(8080) - with subtest("returns health status"): - result = json.loads(machine.succeed("curl -sS http://localhost:8080/healthz")) + with subtest("returns health status"): + result = json.loads(machine.succeed("curl -sS http://localhost:8080/healthz")) - assert len(result["results"]) == 8, f".results should be an array of 10 items, was {result['results']!r}" - assert result["summary"]["failed-count"] == 0, f".summary.failed-count should be zero, was {result['summary']['failed-count']}" - assert result["summary"]["test-count"] == 8, f".summary.test-count should be 10, was {result['summary']['test-count']}" + assert len(result["results"]) == 8, f".results should be an array of 10 items, was {result['results']!r}" + assert result["summary"]["failed-count"] == 0, f".summary.failed-count should be zero, was {result['summary']['failed-count']}" + assert result["summary"]["test-count"] == 8, f".summary.test-count should be 10, was {result['summary']['test-count']}" ''; -}) + } +) diff --git a/nixos/tests/gotify-server.nix b/nixos/tests/gotify-server.nix index 495b1c8e3443c4..55f5fe6468f5e2 100644 --- a/nixos/tests/gotify-server.nix +++ b/nixos/tests/gotify-server.nix @@ -1,52 +1,57 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : { - name = "gotify-server"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; - - nodes.machine = { pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; - - services.gotify = { - enable = true; - environment = { - GOTIFY_SERVER_PORT = 3000; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "gotify-server"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; }; - }; - - testScript = '' - machine.start() - - machine.wait_for_unit("gotify-server.service") - machine.wait_for_open_port(3000) - - token = machine.succeed( - "curl --fail -sS -X POST localhost:3000/application -F name=nixos " - + '-H "Authorization: Basic $(echo -ne "admin:admin" | base64 --wrap 0)" ' - + "| jq .token | xargs echo -n" - ) - - usertoken = machine.succeed( - "curl --fail -sS -X POST localhost:3000/client -F name=nixos " - + '-H "Authorization: Basic $(echo -ne "admin:admin" | base64 --wrap 0)" ' - + "| jq .token | xargs echo -n" - ) - - machine.succeed( - f"curl --fail -sS -X POST 'localhost:3000/message?token={token}' -H 'Accept: application/json' " - + "-F title=Gotify -F message=Works" - ) - - title = machine.succeed( - f"curl --fail -sS 'localhost:3000/message?since=0&token={usertoken}' | jq '.messages|.[0]|.title' | xargs echo -n" - ) - - assert title == "Gotify" - - # Ensure that the UI responds with a successful code and that the - # response is not empty - result = machine.succeed("curl -fsS localhost:3000") - assert result, "HTTP response from localhost:3000 must not be empty!" - ''; -}) + + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; + + services.gotify = { + enable = true; + environment = { + GOTIFY_SERVER_PORT = 3000; + }; + }; + }; + + testScript = '' + machine.start() + + machine.wait_for_unit("gotify-server.service") + machine.wait_for_open_port(3000) + + token = machine.succeed( + "curl --fail -sS -X POST localhost:3000/application -F name=nixos " + + '-H "Authorization: Basic $(echo -ne "admin:admin" | base64 --wrap 0)" ' + + "| jq .token | xargs echo -n" + ) + + usertoken = machine.succeed( + "curl --fail -sS -X POST localhost:3000/client -F name=nixos " + + '-H "Authorization: Basic $(echo -ne "admin:admin" | base64 --wrap 0)" ' + + "| jq .token | xargs echo -n" + ) + + machine.succeed( + f"curl --fail -sS -X POST 'localhost:3000/message?token={token}' -H 'Accept: application/json' " + + "-F title=Gotify -F message=Works" + ) + + title = machine.succeed( + f"curl --fail -sS 'localhost:3000/message?since=0&token={usertoken}' | jq '.messages|.[0]|.title' | xargs echo -n" + ) + + assert title == "Gotify" + + # Ensure that the UI responds with a successful code and that the + # response is not empty + result = machine.succeed("curl -fsS localhost:3000") + assert result, "HTTP response from localhost:3000 must not be empty!" + ''; + } +) diff --git a/nixos/tests/grafana-agent.nix b/nixos/tests/grafana-agent.nix index a9f34d8cea31a6..05e3764583f387 100644 --- a/nixos/tests/grafana-agent.nix +++ b/nixos/tests/grafana-agent.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: +import ./make-test-python.nix ( + { lib, pkgs, ... }: let nodes = { @@ -29,4 +30,5 @@ import ./make-test-python.nix ({ lib, pkgs, ... }: ) machine.shutdown() ''; - }) + } +) diff --git a/nixos/tests/grafana/basic.nix b/nixos/tests/grafana/basic.nix index fae6bd4dbbcfb4..7c772801600345 100644 --- a/nixos/tests/grafana/basic.nix +++ b/nixos/tests/grafana/basic.nix @@ -1,142 +1,157 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: +import ../make-test-python.nix ( + { lib, pkgs, ... }: -let - inherit (lib) mkMerge nameValuePair maintainers; + let + inherit (lib) mkMerge nameValuePair maintainers; - baseGrafanaConf = { - services.grafana = { - enable = true; - settings = { - analytics.reporting_enabled = false; - - server = { - http_addr = "::1"; - domain = "localhost"; - }; - - security = { - admin_user = "testadmin"; - admin_password = "snakeoilpwd"; + baseGrafanaConf = { + services.grafana = { + enable = true; + settings = { + analytics.reporting_enabled = false; + + server = { + http_addr = "::1"; + domain = "localhost"; + }; + + security = { + admin_user = "testadmin"; + admin_password = "snakeoilpwd"; + }; }; }; }; - }; - extraNodeConfs = { - sqlite = {}; + extraNodeConfs = { + sqlite = { }; + + socket = + { config, ... }: + { + services.grafana.settings.server = { + protocol = "socket"; + socket = "/run/grafana/sock"; + socket_gid = config.users.groups.nginx.gid; + }; + + users.users.grafana.extraGroups = [ "nginx" ]; + + services.nginx = { + enable = true; + recommendedProxySettings = true; + virtualHosts."_".locations."/".proxyPass = "http://unix:/run/grafana/sock"; + }; + }; - socket = { config, ... }: { - services.grafana.settings.server = { - protocol = "socket"; - socket = "/run/grafana/sock"; - socket_gid = config.users.groups.nginx.gid; + declarativePlugins = { + services.grafana.declarativePlugins = [ pkgs.grafanaPlugins.grafana-clock-panel ]; }; - users.users.grafana.extraGroups = [ "nginx" ]; - - services.nginx = { - enable = true; - recommendedProxySettings = true; - virtualHosts."_".locations."/".proxyPass = "http://unix:/run/grafana/sock"; + postgresql = { + services.grafana.settings.database = { + host = "[::1]:5432"; + user = "grafana"; + }; + services.postgresql = { + enable = true; + ensureDatabases = [ "grafana" ]; + ensureUsers = [ + { + name = "grafana"; + ensureDBOwnership = true; + } + ]; + }; + systemd.services.grafana.after = [ "postgresql.service" ]; }; - }; - - declarativePlugins = { - services.grafana.declarativePlugins = [ pkgs.grafanaPlugins.grafana-clock-panel ]; - }; - postgresql = { - services.grafana.settings.database = { - host = "[::1]:5432"; - user = "grafana"; - }; - services.postgresql = { - enable = true; - ensureDatabases = [ "grafana" ]; - ensureUsers = [{ - name = "grafana"; - ensureDBOwnership = true; - }]; + mysql = { + services.grafana.settings.database.user = "grafana"; + services.mysql = { + enable = true; + ensureDatabases = [ "grafana" ]; + ensureUsers = [ + { + name = "grafana"; + ensurePermissions."grafana.*" = "ALL PRIVILEGES"; + } + ]; + package = pkgs.mariadb; + }; + systemd.services.grafana.after = [ "mysql.service" ]; }; - systemd.services.grafana.after = [ "postgresql.service" ]; }; - mysql = { - services.grafana.settings.database.user = "grafana"; - services.mysql = { - enable = true; - ensureDatabases = [ "grafana" ]; - ensureUsers = [{ - name = "grafana"; - ensurePermissions."grafana.*" = "ALL PRIVILEGES"; - }]; - package = pkgs.mariadb; - }; - systemd.services.grafana.after = [ "mysql.service" ]; + nodes = builtins.mapAttrs ( + _: val: + mkMerge [ + val + baseGrafanaConf + ] + ) extraNodeConfs; + in + { + name = "grafana-basic"; + + meta = with maintainers; { + maintainers = [ willibutz ]; }; - }; - - nodes = builtins.mapAttrs (_: val: mkMerge [ val baseGrafanaConf ]) extraNodeConfs; -in { - name = "grafana-basic"; - - meta = with maintainers; { - maintainers = [ willibutz ]; - }; - - inherit nodes; - - testScript = '' - start_all() - - with subtest("Declarative plugins installed"): - declarativePlugins.wait_for_unit("grafana.service") - declarativePlugins.wait_for_open_port(3000, addr="::1") - declarativePlugins.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/plugins | grep grafana-clock-panel" - ) - declarativePlugins.shutdown() - - with subtest("Successful API query as admin user with sqlite db"): - sqlite.wait_for_unit("grafana.service") - sqlite.wait_for_open_port(3000) - print(sqlite.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/org/users -i" - )) - sqlite.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/org/users | grep admin\@localhost" - ) - sqlite.shutdown() - - with subtest("Successful API query as admin user with sqlite db listening on socket"): - socket.wait_for_unit("grafana.service") - socket.wait_for_open_port(80) - print(socket.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]/api/org/users -i" - )) - socket.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]/api/org/users | grep admin\@localhost" - ) - socket.shutdown() - - with subtest("Successful API query as admin user with postgresql db"): - postgresql.wait_for_unit("grafana.service") - postgresql.wait_for_unit("postgresql.service") - postgresql.wait_for_open_port(3000) - postgresql.wait_for_open_port(5432) - postgresql.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/org/users | grep admin\@localhost" - ) - postgresql.shutdown() - - with subtest("Successful API query as admin user with mysql db"): - mysql.wait_for_unit("grafana.service") - mysql.wait_for_unit("mysql.service") - mysql.wait_for_open_port(3000) - mysql.wait_for_open_port(3306) - mysql.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/org/users | grep admin\@localhost" - ) - mysql.shutdown() - ''; -}) + + inherit nodes; + + testScript = '' + start_all() + + with subtest("Declarative plugins installed"): + declarativePlugins.wait_for_unit("grafana.service") + declarativePlugins.wait_for_open_port(3000, addr="::1") + declarativePlugins.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/plugins | grep grafana-clock-panel" + ) + declarativePlugins.shutdown() + + with subtest("Successful API query as admin user with sqlite db"): + sqlite.wait_for_unit("grafana.service") + sqlite.wait_for_open_port(3000) + print(sqlite.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/org/users -i" + )) + sqlite.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/org/users | grep admin\@localhost" + ) + sqlite.shutdown() + + with subtest("Successful API query as admin user with sqlite db listening on socket"): + socket.wait_for_unit("grafana.service") + socket.wait_for_open_port(80) + print(socket.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]/api/org/users -i" + )) + socket.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]/api/org/users | grep admin\@localhost" + ) + socket.shutdown() + + with subtest("Successful API query as admin user with postgresql db"): + postgresql.wait_for_unit("grafana.service") + postgresql.wait_for_unit("postgresql.service") + postgresql.wait_for_open_port(3000) + postgresql.wait_for_open_port(5432) + postgresql.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/org/users | grep admin\@localhost" + ) + postgresql.shutdown() + + with subtest("Successful API query as admin user with mysql db"): + mysql.wait_for_unit("grafana.service") + mysql.wait_for_unit("mysql.service") + mysql.wait_for_open_port(3000) + mysql.wait_for_open_port(3306) + mysql.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/org/users | grep admin\@localhost" + ) + mysql.shutdown() + ''; + } +) diff --git a/nixos/tests/grafana/default.nix b/nixos/tests/grafana/default.nix index 9c262257180015..3342ae05fd9655 100644 --- a/nixos/tests/grafana/default.nix +++ b/nixos/tests/grafana/default.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../../.. { inherit system config; }, }: { diff --git a/nixos/tests/grafana/provision/default.nix b/nixos/tests/grafana/provision/default.nix index 4a137638800b66..3c19aa18937561 100644 --- a/nixos/tests/grafana/provision/default.nix +++ b/nixos/tests/grafana/provision/default.nix @@ -1,217 +1,250 @@ -import ../../make-test-python.nix ({ lib, pkgs, ... }: - -let - inherit (lib) mkMerge maintainers; - - baseGrafanaConf = { - services.grafana = { - enable = true; - provision.enable = true; - settings = { - analytics.reporting_enabled = false; - - server = { - http_addr = "::1"; - domain = "localhost"; - }; +import ../../make-test-python.nix ( + { lib, pkgs, ... }: + + let + inherit (lib) mkMerge maintainers; + + baseGrafanaConf = { + services.grafana = { + enable = true; + provision.enable = true; + settings = { + analytics.reporting_enabled = false; + + server = { + http_addr = "::1"; + domain = "localhost"; + }; - security = { - admin_user = "testadmin"; - admin_password = "$__file{${pkgs.writeText "pwd" "snakeoilpwd"}}"; + security = { + admin_user = "testadmin"; + admin_password = "$__file{${pkgs.writeText "pwd" "snakeoilpwd"}}"; + }; }; }; - }; - - systemd.tmpfiles.rules = - let - dashboard = pkgs.writeText "test.json" (builtins.readFile ./test_dashboard.json); - in - [ - "d /var/lib/grafana/dashboards 0700 grafana grafana -" - "C+ /var/lib/grafana/dashboards/test.json - - - - ${dashboard}" - ]; - }; - - extraNodeConfs = { - provisionNix = { - services.grafana.provision = { - datasources.settings = { - apiVersion = 1; - datasources = [{ - name = "Test Datasource"; - type = "testdata"; - access = "proxy"; - uid = "test_datasource"; - }]; - }; - - dashboards.settings = { - apiVersion = 1; - providers = [{ - name = "default"; - options.path = "/var/lib/grafana/dashboards"; - }]; - }; - alerting = { - rules.settings = { - groups = [{ - name = "test_rule_group"; - folder = "test_folder"; - interval = "60s"; - rules = [{ - uid = "test_rule"; - title = "Test Rule"; - condition = "A"; - data = [{ - refId = "A"; - datasourceUid = "-100"; - model = { - conditions = [{ - evaluator = { - params = [ 3 ]; - type = "git"; - }; - operator.type = "and"; - query.params = [ "A" ]; - reducer.type = "last"; - type = "query"; - }]; - datasource = { - type = "__expr__"; - uid = "-100"; - }; - expression = "1==0"; - intervalMs = 1000; - maxDataPoints = 43200; - refId = "A"; - type = "math"; - }; - }]; - for = "60s"; - }]; - }]; - }; + systemd.tmpfiles.rules = + let + dashboard = pkgs.writeText "test.json" (builtins.readFile ./test_dashboard.json); + in + [ + "d /var/lib/grafana/dashboards 0700 grafana grafana -" + "C+ /var/lib/grafana/dashboards/test.json - - - - ${dashboard}" + ]; + }; - contactPoints.settings = { - contactPoints = [{ - name = "Test Contact Point"; - receivers = [{ - uid = "test_contact_point"; - type = "prometheus-alertmanager"; - settings.url = "http://localhost:9000"; - }]; - }]; + extraNodeConfs = { + provisionNix = { + services.grafana.provision = { + datasources.settings = { + apiVersion = 1; + datasources = [ + { + name = "Test Datasource"; + type = "testdata"; + access = "proxy"; + uid = "test_datasource"; + } + ]; }; - policies.settings = { - policies = [{ - receiver = "Test Contact Point"; - }]; + dashboards.settings = { + apiVersion = 1; + providers = [ + { + name = "default"; + options.path = "/var/lib/grafana/dashboards"; + } + ]; }; - templates.settings = { - templates = [{ - name = "Test Template"; - template = "Test message"; - }]; + alerting = { + rules.settings = { + groups = [ + { + name = "test_rule_group"; + folder = "test_folder"; + interval = "60s"; + rules = [ + { + uid = "test_rule"; + title = "Test Rule"; + condition = "A"; + data = [ + { + refId = "A"; + datasourceUid = "-100"; + model = { + conditions = [ + { + evaluator = { + params = [ 3 ]; + type = "git"; + }; + operator.type = "and"; + query.params = [ "A" ]; + reducer.type = "last"; + type = "query"; + } + ]; + datasource = { + type = "__expr__"; + uid = "-100"; + }; + expression = "1==0"; + intervalMs = 1000; + maxDataPoints = 43200; + refId = "A"; + type = "math"; + }; + } + ]; + for = "60s"; + } + ]; + } + ]; + }; + + contactPoints.settings = { + contactPoints = [ + { + name = "Test Contact Point"; + receivers = [ + { + uid = "test_contact_point"; + type = "prometheus-alertmanager"; + settings.url = "http://localhost:9000"; + } + ]; + } + ]; + }; + + policies.settings = { + policies = [ + { + receiver = "Test Contact Point"; + } + ]; + }; + + templates.settings = { + templates = [ + { + name = "Test Template"; + template = "Test message"; + } + ]; + }; + + muteTimings.settings = { + muteTimes = [ + { + name = "Test Mute Timing"; + } + ]; + }; }; + }; + }; - muteTimings.settings = { - muteTimes = [{ - name = "Test Mute Timing"; - }]; + provisionYaml = { + services.grafana.provision = { + datasources.path = ./datasources.yaml; + dashboards.path = ./dashboards.yaml; + alerting = { + rules.path = ./rules.yaml; + contactPoints.path = ./contact-points.yaml; + policies.path = ./policies.yaml; + templates.path = ./templates.yaml; + muteTimings.path = ./mute-timings.yaml; }; }; }; - }; - provisionYaml = { - services.grafana.provision = { - datasources.path = ./datasources.yaml; - dashboards.path = ./dashboards.yaml; - alerting = { - rules.path = ./rules.yaml; - contactPoints.path = ./contact-points.yaml; - policies.path = ./policies.yaml; - templates.path = ./templates.yaml; - muteTimings.path = ./mute-timings.yaml; + provisionYamlDirs = + let + mkdir = p: pkgs.writeTextDir (baseNameOf p) (builtins.readFile p); + in + { + services.grafana.provision = { + datasources.path = mkdir ./datasources.yaml; + dashboards.path = mkdir ./dashboards.yaml; + alerting = { + rules.path = mkdir ./rules.yaml; + contactPoints.path = mkdir ./contact-points.yaml; + policies.path = mkdir ./policies.yaml; + templates.path = mkdir ./templates.yaml; + muteTimings.path = mkdir ./mute-timings.yaml; + }; + }; }; - }; }; - provisionYamlDirs = let - mkdir = p: pkgs.writeTextDir (baseNameOf p) (builtins.readFile p); - in { - services.grafana.provision = { - datasources.path = mkdir ./datasources.yaml; - dashboards.path = mkdir ./dashboards.yaml; - alerting = { - rules.path = mkdir ./rules.yaml; - contactPoints.path = mkdir ./contact-points.yaml; - policies.path = mkdir ./policies.yaml; - templates.path = mkdir ./templates.yaml; - muteTimings.path = mkdir ./mute-timings.yaml; - }; - }; + nodes = builtins.mapAttrs ( + _: val: + mkMerge [ + val + baseGrafanaConf + ] + ) extraNodeConfs; + in + { + name = "grafana-provision"; + + meta = with maintainers; { + maintainers = [ willibutz ]; }; - }; - - nodes = builtins.mapAttrs (_: val: mkMerge [ val baseGrafanaConf ]) extraNodeConfs; -in { - name = "grafana-provision"; - - meta = with maintainers; { - maintainers = [ willibutz ]; - }; - - inherit nodes; - - testScript = '' - start_all() - - nodeNix = ("Nix (new format)", provisionNix) - nodeYaml = ("Nix (YAML)", provisionYaml) - nodeYamlDir = ("Nix (YAML in dirs)", provisionYamlDirs) - - for description, machine in [nodeNix, nodeYaml, nodeYamlDir]: - with subtest(f"Should start provision node: {description}"): - machine.wait_for_unit("grafana.service") - machine.wait_for_open_port(3000, addr="::1") - - with subtest(f"Successful datasource provision with {description}"): - machine.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/datasources/uid/test_datasource | grep Test\ Datasource" - ) - - with subtest(f"Successful dashboard provision with {description}"): - machine.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/dashboards/uid/test_dashboard | grep Test\ Dashboard" - ) - - with subtest(f"Successful rule provision with {description}"): - machine.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/v1/provisioning/alert-rules/test_rule | grep Test\ Rule" - ) - - with subtest(f"Successful contact point provision with {description}"): - machine.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/v1/provisioning/contact-points | grep Test\ Contact\ Point" - ) - - with subtest(f"Successful policy provision with {description}"): - machine.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/v1/provisioning/policies | grep Test\ Contact\ Point" - ) - - with subtest(f"Successful template provision with {description}"): - machine.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/v1/provisioning/templates | grep Test\ Template" - ) - - with subtest("Successful mute timings provision with {description}"): - machine.succeed( - "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/v1/provisioning/mute-timings | grep Test\ Mute\ Timing" - ) - ''; -}) + + inherit nodes; + + testScript = '' + start_all() + + nodeNix = ("Nix (new format)", provisionNix) + nodeYaml = ("Nix (YAML)", provisionYaml) + nodeYamlDir = ("Nix (YAML in dirs)", provisionYamlDirs) + + for description, machine in [nodeNix, nodeYaml, nodeYamlDir]: + with subtest(f"Should start provision node: {description}"): + machine.wait_for_unit("grafana.service") + machine.wait_for_open_port(3000, addr="::1") + + with subtest(f"Successful datasource provision with {description}"): + machine.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/datasources/uid/test_datasource | grep Test\ Datasource" + ) + + with subtest(f"Successful dashboard provision with {description}"): + machine.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/dashboards/uid/test_dashboard | grep Test\ Dashboard" + ) + + with subtest(f"Successful rule provision with {description}"): + machine.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/v1/provisioning/alert-rules/test_rule | grep Test\ Rule" + ) + + with subtest(f"Successful contact point provision with {description}"): + machine.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/v1/provisioning/contact-points | grep Test\ Contact\ Point" + ) + + with subtest(f"Successful policy provision with {description}"): + machine.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/v1/provisioning/policies | grep Test\ Contact\ Point" + ) + + with subtest(f"Successful template provision with {description}"): + machine.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/v1/provisioning/templates | grep Test\ Template" + ) + + with subtest("Successful mute timings provision with {description}"): + machine.succeed( + "curl -sSfN -u testadmin:snakeoilpwd http://[::1]:3000/api/v1/provisioning/mute-timings | grep Test\ Mute\ Timing" + ) + ''; + } +) diff --git a/nixos/tests/graphite.nix b/nixos/tests/graphite.nix index de6cd8a50e179d..1791cb38fc62c4 100644 --- a/nixos/tests/graphite.nix +++ b/nixos/tests/graphite.nix @@ -1,36 +1,39 @@ -import ./make-test-python.nix ({ pkgs, ... } : -{ - name = "graphite"; - nodes = { - one = - { ... }: { - time.timeZone = "UTC"; - services.graphite = { - web = { - enable = true; - extraConfig = '' - SECRET_KEY = "abcd"; - ''; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "graphite"; + nodes = { + one = + { ... }: + { + time.timeZone = "UTC"; + services.graphite = { + web = { + enable = true; + extraConfig = '' + SECRET_KEY = "abcd"; + ''; + }; + carbon.enableCache = true; + seyren.enable = false; # Implicitly requires openssl-1.0.2u which is marked insecure }; - carbon.enableCache = true; - seyren.enable = false; # Implicitly requires openssl-1.0.2u which is marked insecure }; - }; - }; + }; - testScript = '' - start_all() - one.wait_for_unit("default.target") - one.wait_for_unit("graphiteWeb.service") - one.wait_for_unit("carbonCache.service") - # The services above are of type "simple". systemd considers them active immediately - # even if they're still in preStart (which takes quite long for graphiteWeb). - # Wait for ports to open so we're sure the services are up and listening. - one.wait_for_open_port(8080) - one.wait_for_open_port(2003) - one.succeed('echo "foo 1 `date +%s`" | nc -N localhost 2003') - one.wait_until_succeeds( - "curl 'http://localhost:8080/metrics/find/?query=foo&format=treejson' --silent | grep foo >&2" - ) - ''; -}) + testScript = '' + start_all() + one.wait_for_unit("default.target") + one.wait_for_unit("graphiteWeb.service") + one.wait_for_unit("carbonCache.service") + # The services above are of type "simple". systemd considers them active immediately + # even if they're still in preStart (which takes quite long for graphiteWeb). + # Wait for ports to open so we're sure the services are up and listening. + one.wait_for_open_port(8080) + one.wait_for_open_port(2003) + one.succeed('echo "foo 1 `date +%s`" | nc -N localhost 2003') + one.wait_until_succeeds( + "curl 'http://localhost:8080/metrics/find/?query=foo&format=treejson' --silent | grep foo >&2" + ) + ''; + } +) diff --git a/nixos/tests/graylog.nix b/nixos/tests/graylog.nix index b52c2976a73f85..7766ad9a6a0576 100644 --- a/nixos/tests/graylog.nix +++ b/nixos/tests/graylog.nix @@ -1,127 +1,140 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "graylog"; - meta.maintainers = [ ]; - - nodes.machine = { pkgs, ... }: { - virtualisation.memorySize = 4096; - virtualisation.diskSize = 1024 * 6; - - services.mongodb.enable = true; - services.elasticsearch.enable = true; - services.elasticsearch.extraConf = '' - network.publish_host: 127.0.0.1 - network.bind_host: 127.0.0.1 - ''; - - services.graylog = { - enable = true; - passwordSecret = "YGhZ59wXMrYOojx5xdgEpBpDw2N6FbhM4lTtaJ1KPxxmKrUvSlDbtWArwAWMQ5LKx1ojHEVrQrBMVRdXbRyZLqffoUzHfssc"; - elasticsearchHosts = [ "http://localhost:9200" ]; - - # `echo -n "nixos" | shasum -a 256` - rootPasswordSha2 = "6ed332bcfa615381511d4d5ba44a293bb476f368f7e9e304f0dff50230d1a85b"; - }; - - environment.systemPackages = [ pkgs.jq ]; - - systemd.services.graylog.path = [ pkgs.netcat ]; - systemd.services.graylog.preStart = '' - until nc -z localhost 9200; do - sleep 2 - done - ''; - }; - - testScript = let - payloads.login = pkgs.writeText "login.json" (builtins.toJSON { - host = "127.0.0.1:9000"; - username = "admin"; - password = "nixos"; - }); - - payloads.input = pkgs.writeText "input.json" (builtins.toJSON { - title = "Demo"; - global = false; - type = "org.graylog2.inputs.gelf.udp.GELFUDPInput"; - node = "@node@"; - configuration = { - bind_address = "0.0.0.0"; - decompress_size_limit = 8388608; - number_worker_threads = 1; - override_source = null; - port = 12201; - recv_buffer_size = 262144; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "graylog"; + meta.maintainers = [ ]; + + nodes.machine = + { pkgs, ... }: + { + virtualisation.memorySize = 4096; + virtualisation.diskSize = 1024 * 6; + + services.mongodb.enable = true; + services.elasticsearch.enable = true; + services.elasticsearch.extraConf = '' + network.publish_host: 127.0.0.1 + network.bind_host: 127.0.0.1 + ''; + + services.graylog = { + enable = true; + passwordSecret = "YGhZ59wXMrYOojx5xdgEpBpDw2N6FbhM4lTtaJ1KPxxmKrUvSlDbtWArwAWMQ5LKx1ojHEVrQrBMVRdXbRyZLqffoUzHfssc"; + elasticsearchHosts = [ "http://localhost:9200" ]; + + # `echo -n "nixos" | shasum -a 256` + rootPasswordSha2 = "6ed332bcfa615381511d4d5ba44a293bb476f368f7e9e304f0dff50230d1a85b"; + }; + + environment.systemPackages = [ pkgs.jq ]; + + systemd.services.graylog.path = [ pkgs.netcat ]; + systemd.services.graylog.preStart = '' + until nc -z localhost 9200; do + sleep 2 + done + ''; }; - }); - - payloads.gelf_message = pkgs.writeText "gelf.json" (builtins.toJSON { - host = "example.org"; - short_message = "A short message"; - full_message = "A long message"; - version = "1.1"; - level = 5; - facility = "Test"; - }); - in '' - machine.start() - machine.wait_for_unit("graylog.service") - - machine.wait_until_succeeds( - "journalctl -o cat -u graylog.service | grep 'Started REST API at <127.0.0.1:9000>'" - ) - - machine.wait_for_open_port(9000) - machine.succeed("curl -sSfL http://127.0.0.1:9000/") - - machine.wait_until_succeeds( - "journalctl -o cat -u graylog.service | grep 'Graylog server up and running'" - ) - - session = machine.succeed( - "curl -X POST " - + "-sSfL http://127.0.0.1:9000/api/system/sessions " - + "-d $(cat ${payloads.login}) " - + "-H 'Content-Type: application/json' " - + "-H 'Accept: application/json' " - + "-H 'x-requested-by: cli' " - + "| jq .session_id | xargs echo" - ).rstrip() - - machine.succeed( - "curl -X POST " - + f"-sSfL http://127.0.0.1:9000/api/system/inputs -u {session}:session " - + '-d $(cat ${payloads.input} | sed -e "s,@node@,$(cat /var/lib/graylog/server/node-id),") ' - + "-H 'Accept: application/json' " - + "-H 'Content-Type: application/json' " - + "-H 'x-requested-by: cli' " - ) - - machine.wait_until_succeeds( - "journalctl -o cat -u graylog.service | grep -E 'Input \[GELF UDP/Demo/[[:alnum:]]{24}\] is now RUNNING'" - ) - - machine.wait_until_succeeds( - "test \"$(curl -sSfL 'http://127.0.0.1:9000/api/cluster/inputstates' " - + f"-u {session}:session " - + "-H 'Accept: application/json' " - + "-H 'Content-Type: application/json' " - + "-H 'x-requested-by: cli'" - + "| jq 'to_entries[]|.value|.[0]|.state' | xargs echo" - + ')" = "RUNNING"' - ) - - machine.succeed( - "echo -n $(cat ${payloads.gelf_message}) | nc -w10 -u 127.0.0.1 12201" - ) - - machine.succeed( - 'test "$(curl -X GET ' - + "-sSfL 'http://127.0.0.1:9000/api/search/universal/relative?query=*' " - + f"-u {session}:session " - + "-H 'Accept: application/json' " - + "-H 'Content-Type: application/json' " - + "-H 'x-requested-by: cli'" - + ' | jq \'.total_results\' | xargs echo)" = "1"' - ) - ''; -}) + + testScript = + let + payloads.login = pkgs.writeText "login.json" ( + builtins.toJSON { + host = "127.0.0.1:9000"; + username = "admin"; + password = "nixos"; + } + ); + + payloads.input = pkgs.writeText "input.json" ( + builtins.toJSON { + title = "Demo"; + global = false; + type = "org.graylog2.inputs.gelf.udp.GELFUDPInput"; + node = "@node@"; + configuration = { + bind_address = "0.0.0.0"; + decompress_size_limit = 8388608; + number_worker_threads = 1; + override_source = null; + port = 12201; + recv_buffer_size = 262144; + }; + } + ); + + payloads.gelf_message = pkgs.writeText "gelf.json" ( + builtins.toJSON { + host = "example.org"; + short_message = "A short message"; + full_message = "A long message"; + version = "1.1"; + level = 5; + facility = "Test"; + } + ); + in + '' + machine.start() + machine.wait_for_unit("graylog.service") + + machine.wait_until_succeeds( + "journalctl -o cat -u graylog.service | grep 'Started REST API at <127.0.0.1:9000>'" + ) + + machine.wait_for_open_port(9000) + machine.succeed("curl -sSfL http://127.0.0.1:9000/") + + machine.wait_until_succeeds( + "journalctl -o cat -u graylog.service | grep 'Graylog server up and running'" + ) + + session = machine.succeed( + "curl -X POST " + + "-sSfL http://127.0.0.1:9000/api/system/sessions " + + "-d $(cat ${payloads.login}) " + + "-H 'Content-Type: application/json' " + + "-H 'Accept: application/json' " + + "-H 'x-requested-by: cli' " + + "| jq .session_id | xargs echo" + ).rstrip() + + machine.succeed( + "curl -X POST " + + f"-sSfL http://127.0.0.1:9000/api/system/inputs -u {session}:session " + + '-d $(cat ${payloads.input} | sed -e "s,@node@,$(cat /var/lib/graylog/server/node-id),") ' + + "-H 'Accept: application/json' " + + "-H 'Content-Type: application/json' " + + "-H 'x-requested-by: cli' " + ) + + machine.wait_until_succeeds( + "journalctl -o cat -u graylog.service | grep -E 'Input \[GELF UDP/Demo/[[:alnum:]]{24}\] is now RUNNING'" + ) + + machine.wait_until_succeeds( + "test \"$(curl -sSfL 'http://127.0.0.1:9000/api/cluster/inputstates' " + + f"-u {session}:session " + + "-H 'Accept: application/json' " + + "-H 'Content-Type: application/json' " + + "-H 'x-requested-by: cli'" + + "| jq 'to_entries[]|.value|.[0]|.state' | xargs echo" + + ')" = "RUNNING"' + ) + + machine.succeed( + "echo -n $(cat ${payloads.gelf_message}) | nc -w10 -u 127.0.0.1 12201" + ) + + machine.succeed( + 'test "$(curl -X GET ' + + "-sSfL 'http://127.0.0.1:9000/api/search/universal/relative?query=*' " + + f"-u {session}:session " + + "-H 'Accept: application/json' " + + "-H 'Content-Type: application/json' " + + "-H 'x-requested-by: cli'" + + ' | jq \'.total_results\' | xargs echo)" = "1"' + ) + ''; + } +) diff --git a/nixos/tests/greetd-no-shadow.nix b/nixos/tests/greetd-no-shadow.nix index 382218ffa948f6..0bbf4faa3d9c0e 100644 --- a/nixos/tests/greetd-no-shadow.nix +++ b/nixos/tests/greetd-no-shadow.nix @@ -1,34 +1,40 @@ -import ./make-test-python.nix ({ pkgs, latestKernel ? false, ... }: -{ - name = "greetd-no-shadow"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; +import ./make-test-python.nix ( + { + pkgs, + latestKernel ? false, + ... + }: + { + name = "greetd-no-shadow"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; - nodes.machine = - { pkgs, lib, ... }: { + nodes.machine = + { pkgs, lib, ... }: + { - users.users.alice = { - isNormalUser = true; - group = "alice"; - password = "foobar"; - }; - users.groups.alice = {}; + users.users.alice = { + isNormalUser = true; + group = "alice"; + password = "foobar"; + }; + users.groups.alice = { }; - # This means login(1) breaks, so we must use greetd/agreety instead. - security.shadow.enable = false; + # This means login(1) breaks, so we must use greetd/agreety instead. + security.shadow.enable = false; - services.greetd = { - enable = true; - settings = { - default_session = { - command = "${pkgs.greetd.greetd}/bin/agreety --cmd bash"; + services.greetd = { + enable = true; + settings = { + default_session = { + command = "${pkgs.greetd.greetd}/bin/agreety --cmd bash"; + }; }; }; }; - }; - testScript = '' + testScript = '' machine.start() machine.wait_for_unit("multi-user.target") @@ -45,5 +51,6 @@ import ./make-test-python.nix ({ pkgs, latestKernel ? false, ... }: machine.wait_until_succeeds("pgrep -u alice bash") machine.send_chars("touch done\n") machine.wait_for_file("/home/alice/done") - ''; -}) + ''; + } +) diff --git a/nixos/tests/grocy.nix b/nixos/tests/grocy.nix index 48bbc9f7d3fa2f..0cfaf1e7fc583b 100644 --- a/nixos/tests/grocy.nix +++ b/nixos/tests/grocy.nix @@ -1,73 +1,78 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "grocy"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ma27 ]; - }; - - nodes.machine = { pkgs, ... }: { - services.grocy = { - enable = true; - hostName = "localhost"; - nginx.enableSSL = false; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "grocy"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ma27 ]; }; - environment.systemPackages = [ pkgs.jq ]; - }; - testScript = '' - from base64 import b64encode - from urllib.parse import quote + nodes.machine = + { pkgs, ... }: + { + services.grocy = { + enable = true; + hostName = "localhost"; + nginx.enableSSL = false; + }; + environment.systemPackages = [ pkgs.jq ]; + }; + + testScript = '' + from base64 import b64encode + from urllib.parse import quote - machine.start() - machine.wait_for_open_port(80) - machine.wait_for_unit("multi-user.target") + machine.start() + machine.wait_for_open_port(80) + machine.wait_for_unit("multi-user.target") - machine.succeed("curl -sSf http://localhost") + machine.succeed("curl -sSf http://localhost") - machine.succeed( - "curl -c cookies -sSf -X POST http://localhost/login -d 'username=admin&password=admin'" - ) + machine.succeed( + "curl -c cookies -sSf -X POST http://localhost/login -d 'username=admin&password=admin'" + ) - cookie = machine.succeed( - "grep -v '^#' cookies | awk '{ print $7 }' | sed -e '/^$/d' | perl -pe 'chomp'" - ) + cookie = machine.succeed( + "grep -v '^#' cookies | awk '{ print $7 }' | sed -e '/^$/d' | perl -pe 'chomp'" + ) - machine.succeed( - f"curl -sSf -X POST http://localhost/api/objects/tasks -b 'grocy_session={cookie}' " - + '-d \'{"assigned_to_user_id":1,"name":"Test Task","due_date":"1970-01-01"}\''' - + " --header 'Content-Type: application/json'" - ) + machine.succeed( + f"curl -sSf -X POST http://localhost/api/objects/tasks -b 'grocy_session={cookie}' " + + '-d \'{"assigned_to_user_id":1,"name":"Test Task","due_date":"1970-01-01"}\''' + + " --header 'Content-Type: application/json'" + ) - task_name = machine.succeed( - f"curl -sSf http://localhost/api/tasks -b 'grocy_session={cookie}' --header 'Accept: application/json' | jq '.[].name' | xargs echo | perl -pe 'chomp'" - ) + task_name = machine.succeed( + f"curl -sSf http://localhost/api/tasks -b 'grocy_session={cookie}' --header 'Accept: application/json' | jq '.[].name' | xargs echo | perl -pe 'chomp'" + ) - assert task_name == "Test Task" + assert task_name == "Test Task" - machine.succeed("curl -sSI http://localhost/api/tasks 2>&1 | grep '401 Unauthorized'") + machine.succeed("curl -sSI http://localhost/api/tasks 2>&1 | grep '401 Unauthorized'") - file_name = "test.txt" - file_name_base64 = b64encode(file_name.encode('ascii')).decode('ascii') - file_name_base64_urlencode = quote(file_name_base64) + file_name = "test.txt" + file_name_base64 = b64encode(file_name.encode('ascii')).decode('ascii') + file_name_base64_urlencode = quote(file_name_base64) - machine.succeed( - f"echo Sample equipment manual > /tmp/{file_name}" - ) + machine.succeed( + f"echo Sample equipment manual > /tmp/{file_name}" + ) - machine.succeed( - f"curl -sSf -X 'PUT' -b 'grocy_session={cookie}' " - + f" 'http://localhost/api/files/equipmentmanuals/{file_name_base64_urlencode}' " - + " --header 'Accept: */*' " - + " --header 'Content-Type: application/octet-stream' " - + f" --data-binary '@/tmp/{file_name}' " - ) + machine.succeed( + f"curl -sSf -X 'PUT' -b 'grocy_session={cookie}' " + + f" 'http://localhost/api/files/equipmentmanuals/{file_name_base64_urlencode}' " + + " --header 'Accept: */*' " + + " --header 'Content-Type: application/octet-stream' " + + f" --data-binary '@/tmp/{file_name}' " + ) - machine.succeed( - f"curl -sSf -X 'GET' -b 'grocy_session={cookie}' " - + f" 'http://localhost/api/files/equipmentmanuals/{file_name_base64_urlencode}' " - + " --header 'Accept: application/octet-stream' " - + f" | cmp /tmp/{file_name}" - ) + machine.succeed( + f"curl -sSf -X 'GET' -b 'grocy_session={cookie}' " + + f" 'http://localhost/api/files/equipmentmanuals/{file_name_base64_urlencode}' " + + " --header 'Accept: application/octet-stream' " + + f" | cmp /tmp/{file_name}" + ) - machine.shutdown() - ''; -}) + machine.shutdown() + ''; + } +) diff --git a/nixos/tests/grow-partition.nix b/nixos/tests/grow-partition.nix index 344910848dca80..c8eef519fb5c46 100644 --- a/nixos/tests/grow-partition.nix +++ b/nixos/tests/grow-partition.nix @@ -4,37 +4,44 @@ let rootFslabel = "external"; rootFsDevice = "/dev/disk/by-label/${rootFslabel}"; - externalModule = partitionTableType: { config, lib, pkgs, ... }: { - virtualisation.directBoot.enable = false; - virtualisation.mountHostNixStore = false; - virtualisation.useEFIBoot = partitionTableType == "efi"; - - # This stops the qemu-vm module from overriding the fileSystems option - # with virtualisation.fileSystems. - virtualisation.fileSystems = lib.mkForce { }; - - - boot.loader.grub.enable = true; - boot.loader.grub.efiSupport = partitionTableType == "efi"; - boot.loader.grub.efiInstallAsRemovable = partitionTableType == "efi"; - boot.loader.grub.device = if partitionTableType == "efi" then "nodev" else "/dev/vda"; - - boot.growPartition = true; - - fileSystems = { - "/".device = rootFsDevice; - }; - - system.build.diskImage = import ../lib/make-disk-image.nix { - inherit config lib pkgs; - label = rootFslabel; - inherit partitionTableType; - format = "raw"; - bootSize = "128M"; - additionalSpace = "0M"; - copyChannel = false; + externalModule = + partitionTableType: + { + config, + lib, + pkgs, + ... + }: + { + virtualisation.directBoot.enable = false; + virtualisation.mountHostNixStore = false; + virtualisation.useEFIBoot = partitionTableType == "efi"; + + # This stops the qemu-vm module from overriding the fileSystems option + # with virtualisation.fileSystems. + virtualisation.fileSystems = lib.mkForce { }; + + boot.loader.grub.enable = true; + boot.loader.grub.efiSupport = partitionTableType == "efi"; + boot.loader.grub.efiInstallAsRemovable = partitionTableType == "efi"; + boot.loader.grub.device = if partitionTableType == "efi" then "nodev" else "/dev/vda"; + + boot.growPartition = true; + + fileSystems = { + "/".device = rootFsDevice; + }; + + system.build.diskImage = import ../lib/make-disk-image.nix { + inherit config lib pkgs; + label = rootFslabel; + inherit partitionTableType; + format = "raw"; + bootSize = "128M"; + additionalSpace = "0M"; + copyChannel = false; + }; }; - }; in { name = "grow-partition"; @@ -48,36 +55,38 @@ in hybrid = externalModule "hybrid"; }; - - testScript = { nodes, ... }: - lib.concatLines (lib.mapAttrsToList (name: node: '' - import os - import subprocess - import tempfile - import shutil - - tmp_disk_image = tempfile.NamedTemporaryFile() - - shutil.copyfile("${node.system.build.diskImage}/nixos.img", tmp_disk_image.name) - - subprocess.run([ - "${node.virtualisation.qemu.package}/bin/qemu-img", - "resize", - "-f", - "raw", - tmp_disk_image.name, - "+32M", - ]) - - # Set NIX_DISK_IMAGE so that the qemu script finds the right disk image. - os.environ['NIX_DISK_IMAGE'] = tmp_disk_image.name - - ${name}.wait_for_unit("growpart.service") - systemd_growpart_logs = ${name}.succeed("journalctl --boot --unit growpart.service") - assert "CHANGED" in systemd_growpart_logs - ${name}.succeed("systemctl restart growpart.service") - systemd_growpart_logs = ${name}.succeed("journalctl --boot --unit growpart.service") - assert "NOCHANGE" in systemd_growpart_logs - - '') nodes); + testScript = + { nodes, ... }: + lib.concatLines ( + lib.mapAttrsToList (name: node: '' + import os + import subprocess + import tempfile + import shutil + + tmp_disk_image = tempfile.NamedTemporaryFile() + + shutil.copyfile("${node.system.build.diskImage}/nixos.img", tmp_disk_image.name) + + subprocess.run([ + "${node.virtualisation.qemu.package}/bin/qemu-img", + "resize", + "-f", + "raw", + tmp_disk_image.name, + "+32M", + ]) + + # Set NIX_DISK_IMAGE so that the qemu script finds the right disk image. + os.environ['NIX_DISK_IMAGE'] = tmp_disk_image.name + + ${name}.wait_for_unit("growpart.service") + systemd_growpart_logs = ${name}.succeed("journalctl --boot --unit growpart.service") + assert "CHANGED" in systemd_growpart_logs + ${name}.succeed("systemctl restart growpart.service") + systemd_growpart_logs = ${name}.succeed("journalctl --boot --unit growpart.service") + assert "NOCHANGE" in systemd_growpart_logs + + '') nodes + ); } diff --git a/nixos/tests/guacamole-server.nix b/nixos/tests/guacamole-server.nix index 48194fddfb2292..41830778d836c0 100644 --- a/nixos/tests/guacamole-server.nix +++ b/nixos/tests/guacamole-server.nix @@ -1,21 +1,25 @@ -import ./make-test-python.nix ({pkgs, lib, ...}: -{ - name = "guacamole-server"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "guacamole-server"; - nodes = { - machine = {pkgs, ...}: { - services.guacamole-server = { - enable = true; - host = "0.0.0.0"; - }; + nodes = { + machine = + { pkgs, ... }: + { + services.guacamole-server = { + enable = true; + host = "0.0.0.0"; + }; + }; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("guacamole-server.service") - machine.wait_for_open_port(4822) - ''; + testScript = '' + start_all() + machine.wait_for_unit("guacamole-server.service") + machine.wait_for_open_port(4822) + ''; - meta.maintainers = [ lib.maintainers.drupol ]; -}) + meta.maintainers = [ lib.maintainers.drupol ]; + } +) diff --git a/nixos/tests/guix/basic.nix b/nixos/tests/guix/basic.nix index 9b943b8965e604..14eb3ca8df487d 100644 --- a/nixos/tests/guix/basic.nix +++ b/nixos/tests/guix/basic.nix @@ -5,38 +5,43 @@ # So this test is what it is: a basic test while trying to use Guix as much as # we possibly can (including the API) without triggering its download alarm. -import ../make-test-python.nix ({ lib, pkgs, ... }: { - name = "guix-basic"; - meta.maintainers = with lib.maintainers; [ foo-dogsquared ]; - - nodes.machine = { config, ... }: { - environment.etc."guix/scripts".source = ./scripts; - services.guix = { - enable = true; - gc.enable = true; - }; - }; - - testScript = '' - import pathlib - - machine.wait_for_unit("multi-user.target") - machine.wait_for_unit("guix-daemon.service") - machine.succeed("systemctl start guix-gc.service") - - # Can't do much here since the environment has restricted network access. - with subtest("Guix basic package management"): - machine.succeed("guix build --dry-run --verbosity=0 hello") - machine.succeed("guix show hello") - - # This is to see if the Guix API is usable and mostly working. - with subtest("Guix API scripting"): - scripts_dir = pathlib.Path("/etc/guix/scripts") - - text_msg = "Hello there, NixOS!" - text_store_file = machine.succeed(f"guix repl -- {scripts_dir}/create-file-to-store.scm '{text_msg}'") - assert machine.succeed(f"cat {text_store_file}") == text_msg - - machine.succeed(f"guix repl -- {scripts_dir}/add-existing-files-to-store.scm {scripts_dir}") - ''; -}) +import ../make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "guix-basic"; + meta.maintainers = with lib.maintainers; [ foo-dogsquared ]; + + nodes.machine = + { config, ... }: + { + environment.etc."guix/scripts".source = ./scripts; + services.guix = { + enable = true; + gc.enable = true; + }; + }; + + testScript = '' + import pathlib + + machine.wait_for_unit("multi-user.target") + machine.wait_for_unit("guix-daemon.service") + machine.succeed("systemctl start guix-gc.service") + + # Can't do much here since the environment has restricted network access. + with subtest("Guix basic package management"): + machine.succeed("guix build --dry-run --verbosity=0 hello") + machine.succeed("guix show hello") + + # This is to see if the Guix API is usable and mostly working. + with subtest("Guix API scripting"): + scripts_dir = pathlib.Path("/etc/guix/scripts") + + text_msg = "Hello there, NixOS!" + text_store_file = machine.succeed(f"guix repl -- {scripts_dir}/create-file-to-store.scm '{text_msg}'") + assert machine.succeed(f"cat {text_store_file}") == text_msg + + machine.succeed(f"guix repl -- {scripts_dir}/add-existing-files-to-store.scm {scripts_dir}") + ''; + } +) diff --git a/nixos/tests/guix/default.nix b/nixos/tests/guix/default.nix index a017668c05a757..8bfd744fd07049 100644 --- a/nixos/tests/guix/default.nix +++ b/nixos/tests/guix/default.nix @@ -1,5 +1,6 @@ -{ system ? builtins.currentSystem -, pkgs ? import ../../.. { inherit system; } +{ + system ? builtins.currentSystem, + pkgs ? import ../../.. { inherit system; }, }: { diff --git a/nixos/tests/guix/publish.nix b/nixos/tests/guix/publish.nix index 4a1e49fea903c1..95445dd00949c3 100644 --- a/nixos/tests/guix/publish.nix +++ b/nixos/tests/guix/publish.nix @@ -2,95 +2,117 @@ # bonus, we'll also test a feature of the substitute server being able to # advertise its service to the local network with Avahi. -import ../make-test-python.nix ({ pkgs, lib, ... }: let - publishPort = 8181; - inherit (builtins) toString; -in { - name = "guix-publish"; - - meta.maintainers = with lib.maintainers; [ foo-dogsquared ]; - - nodes = let - commonConfig = { config, ... }: { - # We'll be using '--advertise' flag with the - # substitute server which requires Avahi. - services.avahi = { - enable = true; - nssmdns4 = true; - publish = { - enable = true; - userServices = true; - }; +import ../make-test-python.nix ( + { pkgs, lib, ... }: + let + publishPort = 8181; + inherit (builtins) toString; + in + { + name = "guix-publish"; + + meta.maintainers = with lib.maintainers; [ foo-dogsquared ]; + + nodes = + let + commonConfig = + { config, ... }: + { + # We'll be using '--advertise' flag with the + # substitute server which requires Avahi. + services.avahi = { + enable = true; + nssmdns4 = true; + publish = { + enable = true; + userServices = true; + }; + }; + }; + in + { + server = + { + config, + lib, + pkgs, + ... + }: + { + imports = [ commonConfig ]; + + services.guix = { + enable = true; + publish = { + enable = true; + port = publishPort; + + generateKeyPair = true; + extraArgs = [ "--advertise" ]; + }; + }; + + networking.firewall.allowedTCPPorts = [ publishPort ]; + }; + + client = + { + config, + lib, + pkgs, + ... + }: + { + imports = [ commonConfig ]; + + services.guix = { + enable = true; + + # Force to only get all substitutes from the local server. We don't + # have anything in the Guix store directory and we cannot get + # anything from the official substitute servers anyways. + substituters.urls = [ "http://server.local:${toString publishPort}" ]; + + extraArgs = [ + # Enable autodiscovery of the substitute servers in the local + # network. This machine shouldn't need to import the signing key from + # the substitute server since it is automatically done anyways. + "--discover=yes" + ]; + }; + }; }; - }; - in { - server = { config, lib, pkgs, ... }: { - imports = [ commonConfig ]; - - services.guix = { - enable = true; - publish = { - enable = true; - port = publishPort; - - generateKeyPair = true; - extraArgs = [ "--advertise" ]; - }; - }; - - networking.firewall.allowedTCPPorts = [ publishPort ]; - }; - - client = { config, lib, pkgs, ... }: { - imports = [ commonConfig ]; - - services.guix = { - enable = true; - - # Force to only get all substitutes from the local server. We don't - # have anything in the Guix store directory and we cannot get - # anything from the official substitute servers anyways. - substituters.urls = [ "http://server.local:${toString publishPort}" ]; - - extraArgs = [ - # Enable autodiscovery of the substitute servers in the local - # network. This machine shouldn't need to import the signing key from - # the substitute server since it is automatically done anyways. - "--discover=yes" - ]; - }; - }; - }; - testScript = '' - import pathlib + testScript = '' + import pathlib - start_all() + start_all() - scripts_dir = pathlib.Path("/etc/guix/scripts") + scripts_dir = pathlib.Path("/etc/guix/scripts") - for machine in machines: - machine.wait_for_unit("multi-user.target") - machine.wait_for_unit("guix-daemon.service") - machine.wait_for_unit("avahi-daemon.service") + for machine in machines: + machine.wait_for_unit("multi-user.target") + machine.wait_for_unit("guix-daemon.service") + machine.wait_for_unit("avahi-daemon.service") - server.wait_for_unit("guix-publish.service") - server.wait_for_open_port(${toString publishPort}) - server.succeed("curl http://localhost:${toString publishPort}/") + server.wait_for_unit("guix-publish.service") + server.wait_for_open_port(${toString publishPort}) + server.succeed("curl http://localhost:${toString publishPort}/") - # Now it's the client turn to make use of it. - substitute_server = "http://server.local:${toString publishPort}" - client.systemctl("start network-online.target") - client.wait_for_unit("network-online.target") - response = client.succeed(f"curl {substitute_server}") - assert "Guix Substitute Server" in response + # Now it's the client turn to make use of it. + substitute_server = "http://server.local:${toString publishPort}" + client.systemctl("start network-online.target") + client.wait_for_unit("network-online.target") + response = client.succeed(f"curl {substitute_server}") + assert "Guix Substitute Server" in response - # Authorizing the server to be used as a substitute server. - client.succeed(f"curl -O {substitute_server}/signing-key.pub") - client.succeed("guix archive --authorize < ./signing-key.pub") + # Authorizing the server to be used as a substitute server. + client.succeed(f"curl -O {substitute_server}/signing-key.pub") + client.succeed("guix archive --authorize < ./signing-key.pub") - # Since we're using the substitute server with the `--advertise` flag, we - # might as well check it. - client.succeed("avahi-browse --resolve --terminate _guix_publish._tcp | grep '_guix_publish._tcp'") - ''; -}) + # Since we're using the substitute server with the `--advertise` flag, we + # might as well check it. + client.succeed("avahi-browse --resolve --terminate _guix_publish._tcp | grep '_guix_publish._tcp'") + ''; + } +) diff --git a/nixos/tests/gvisor.nix b/nixos/tests/gvisor.nix index 5c9447b07118dd..905abaeedc62eb 100644 --- a/nixos/tests/gvisor.nix +++ b/nixos/tests/gvisor.nix @@ -1,43 +1,48 @@ # This test runs a container through gvisor and checks if simple container starts -import ./make-test-python.nix ({ pkgs, ... }: { - name = "gvisor"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "gvisor"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; - nodes = { - gvisor = - { pkgs, ... }: - { - virtualisation.docker = { - enable = true; - extraOptions = "--add-runtime runsc=${pkgs.gvisor}/bin/runsc"; - }; + nodes = { + gvisor = + { pkgs, ... }: + { + virtualisation.docker = { + enable = true; + extraOptions = "--add-runtime runsc=${pkgs.gvisor}/bin/runsc"; + }; - networking = { - dhcpcd.enable = false; - defaultGateway = "192.168.1.1"; - interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = "192.168.1.2"; prefixLength = 24; } - ]; + networking = { + dhcpcd.enable = false; + defaultGateway = "192.168.1.1"; + interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = "192.168.1.2"; + prefixLength = 24; + } + ]; + }; }; - }; - }; - - testScript = '' - start_all() + }; - gvisor.wait_for_unit("network.target") - gvisor.wait_for_unit("sockets.target") + testScript = '' + start_all() - # Test the Docker runtime - gvisor.succeed("tar cv --files-from /dev/null | docker import - scratchimg") - gvisor.succeed( - "docker run -d --name=sleeping --runtime=runsc -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10" - ) - gvisor.succeed("docker ps | grep sleeping") - gvisor.succeed("docker stop sleeping") - ''; -}) + gvisor.wait_for_unit("network.target") + gvisor.wait_for_unit("sockets.target") + # Test the Docker runtime + gvisor.succeed("tar cv --files-from /dev/null | docker import - scratchimg") + gvisor.succeed( + "docker run -d --name=sleeping --runtime=runsc -v /nix/store:/nix/store -v /run/current-system/sw/bin:/bin scratchimg /bin/sleep 10" + ) + gvisor.succeed("docker ps | grep sleeping") + gvisor.succeed("docker stop sleeping") + ''; + } +) diff --git a/nixos/tests/hadoop/hadoop.nix b/nixos/tests/hadoop/hadoop.nix index cc631bb4681063..e4db1953d36947 100644 --- a/nixos/tests/hadoop/hadoop.nix +++ b/nixos/tests/hadoop/hadoop.nix @@ -1,256 +1,302 @@ # This test is very comprehensive. It tests whether all hadoop services work well with each other. # Run this when updating the Hadoop package or making significant changes to the hadoop module. # For a more basic test, see hdfs.nix and yarn.nix -import ../make-test-python.nix ({ package, ... }: { - name = "hadoop-combined"; +import ../make-test-python.nix ( + { package, ... }: + { + name = "hadoop-combined"; - nodes = - let - coreSite = { - "fs.defaultFS" = "hdfs://ns1"; - }; - hdfsSite = { - # HA Quorum Journal Manager configuration - "dfs.nameservices" = "ns1"; - "dfs.ha.namenodes.ns1" = "nn1,nn2"; - "dfs.namenode.shared.edits.dir.ns1" = "qjournal://jn1:8485;jn2:8485;jn3:8485/ns1"; - "dfs.namenode.rpc-address.ns1.nn1" = "nn1:8020"; - "dfs.namenode.rpc-address.ns1.nn2" = "nn2:8020"; - "dfs.namenode.servicerpc-address.ns1.nn1" = "nn1:8022"; - "dfs.namenode.servicerpc-address.ns1.nn2" = "nn2:8022"; - "dfs.namenode.http-address.ns1.nn1" = "nn1:9870"; - "dfs.namenode.http-address.ns1.nn2" = "nn2:9870"; + nodes = + let + coreSite = { + "fs.defaultFS" = "hdfs://ns1"; + }; + hdfsSite = { + # HA Quorum Journal Manager configuration + "dfs.nameservices" = "ns1"; + "dfs.ha.namenodes.ns1" = "nn1,nn2"; + "dfs.namenode.shared.edits.dir.ns1" = "qjournal://jn1:8485;jn2:8485;jn3:8485/ns1"; + "dfs.namenode.rpc-address.ns1.nn1" = "nn1:8020"; + "dfs.namenode.rpc-address.ns1.nn2" = "nn2:8020"; + "dfs.namenode.servicerpc-address.ns1.nn1" = "nn1:8022"; + "dfs.namenode.servicerpc-address.ns1.nn2" = "nn2:8022"; + "dfs.namenode.http-address.ns1.nn1" = "nn1:9870"; + "dfs.namenode.http-address.ns1.nn2" = "nn2:9870"; - # Automatic failover configuration - "dfs.client.failover.proxy.provider.ns1" = "org.apache.hadoop.hdfs.server.namenode.ha.ConfiguredFailoverProxyProvider"; - "dfs.ha.automatic-failover.enabled.ns1" = "true"; - "dfs.ha.fencing.methods" = "shell(true)"; - "ha.zookeeper.quorum" = "zk1:2181"; - }; - yarnSite = { - "yarn.resourcemanager.zk-address" = "zk1:2181"; - "yarn.resourcemanager.ha.enabled" = "true"; - "yarn.resourcemanager.ha.rm-ids" = "rm1,rm2"; - "yarn.resourcemanager.hostname.rm1" = "rm1"; - "yarn.resourcemanager.hostname.rm2" = "rm2"; - "yarn.resourcemanager.ha.automatic-failover.enabled" = "true"; - "yarn.resourcemanager.cluster-id" = "cluster1"; - # yarn.resourcemanager.webapp.address needs to be defined even though yarn.resourcemanager.hostname is set. This shouldn't be necessary, but there's a bug in - # hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-web-proxy/src/main/java/org/apache/hadoop/yarn/server/webproxy/amfilter/AmFilterInitializer.java:70 - # that causes AM containers to fail otherwise. - "yarn.resourcemanager.webapp.address.rm1" = "rm1:8088"; - "yarn.resourcemanager.webapp.address.rm2" = "rm2:8088"; - }; - in - { - zk1 = { ... }: { - services.zookeeper.enable = true; - networking.firewall.allowedTCPPorts = [ 2181 ]; - }; + # Automatic failover configuration + "dfs.client.failover.proxy.provider.ns1" = + "org.apache.hadoop.hdfs.server.namenode.ha.ConfiguredFailoverProxyProvider"; + "dfs.ha.automatic-failover.enabled.ns1" = "true"; + "dfs.ha.fencing.methods" = "shell(true)"; + "ha.zookeeper.quorum" = "zk1:2181"; + }; + yarnSite = { + "yarn.resourcemanager.zk-address" = "zk1:2181"; + "yarn.resourcemanager.ha.enabled" = "true"; + "yarn.resourcemanager.ha.rm-ids" = "rm1,rm2"; + "yarn.resourcemanager.hostname.rm1" = "rm1"; + "yarn.resourcemanager.hostname.rm2" = "rm2"; + "yarn.resourcemanager.ha.automatic-failover.enabled" = "true"; + "yarn.resourcemanager.cluster-id" = "cluster1"; + # yarn.resourcemanager.webapp.address needs to be defined even though yarn.resourcemanager.hostname is set. This shouldn't be necessary, but there's a bug in + # hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-web-proxy/src/main/java/org/apache/hadoop/yarn/server/webproxy/amfilter/AmFilterInitializer.java:70 + # that causes AM containers to fail otherwise. + "yarn.resourcemanager.webapp.address.rm1" = "rm1:8088"; + "yarn.resourcemanager.webapp.address.rm2" = "rm2:8088"; + }; + in + { + zk1 = + { ... }: + { + services.zookeeper.enable = true; + networking.firewall.allowedTCPPorts = [ 2181 ]; + }; - # HDFS cluster - nn1 = { ... }: { - services.hadoop = { - inherit package coreSite hdfsSite; - hdfs.namenode = { - enable = true; - openFirewall = true; + # HDFS cluster + nn1 = + { ... }: + { + services.hadoop = { + inherit package coreSite hdfsSite; + hdfs.namenode = { + enable = true; + openFirewall = true; + }; + hdfs.zkfc.enable = true; + }; }; - hdfs.zkfc.enable = true; - }; - }; - nn2 = { ... }: { - services.hadoop = { - inherit package coreSite hdfsSite; - hdfs.namenode = { - enable = true; - openFirewall = true; + nn2 = + { ... }: + { + services.hadoop = { + inherit package coreSite hdfsSite; + hdfs.namenode = { + enable = true; + openFirewall = true; + }; + hdfs.zkfc.enable = true; + }; }; - hdfs.zkfc.enable = true; - }; - }; - jn1 = { ... }: { - services.hadoop = { - inherit package coreSite hdfsSite; - hdfs.journalnode = { - enable = true; - openFirewall = true; + jn1 = + { ... }: + { + services.hadoop = { + inherit package coreSite hdfsSite; + hdfs.journalnode = { + enable = true; + openFirewall = true; + }; + }; }; - }; - }; - jn2 = { ... }: { - services.hadoop = { - inherit package coreSite hdfsSite; - hdfs.journalnode = { - enable = true; - openFirewall = true; + jn2 = + { ... }: + { + services.hadoop = { + inherit package coreSite hdfsSite; + hdfs.journalnode = { + enable = true; + openFirewall = true; + }; + }; }; - }; - }; - jn3 = { ... }: { - services.hadoop = { - inherit package coreSite hdfsSite; - hdfs.journalnode = { - enable = true; - openFirewall = true; + jn3 = + { ... }: + { + services.hadoop = { + inherit package coreSite hdfsSite; + hdfs.journalnode = { + enable = true; + openFirewall = true; + }; + }; }; - }; - }; - dn1 = { ... }: { - virtualisation.diskSize = 4096; - services.hadoop = { - inherit package coreSite hdfsSite; - hdfs.datanode = { - enable = true; - openFirewall = true; + dn1 = + { ... }: + { + virtualisation.diskSize = 4096; + services.hadoop = { + inherit package coreSite hdfsSite; + hdfs.datanode = { + enable = true; + openFirewall = true; + }; + }; }; - }; - }; - # YARN cluster - rm1 = { options, ... }: { - services.hadoop = { - inherit package coreSite hdfsSite yarnSite; - yarn.resourcemanager = { - enable = true; - openFirewall = true; + # YARN cluster + rm1 = + { options, ... }: + { + services.hadoop = { + inherit + package + coreSite + hdfsSite + yarnSite + ; + yarn.resourcemanager = { + enable = true; + openFirewall = true; + }; + }; }; - }; - }; - rm2 = { options, ... }: { - services.hadoop = { - inherit package coreSite hdfsSite yarnSite; - yarn.resourcemanager = { - enable = true; - openFirewall = true; + rm2 = + { options, ... }: + { + services.hadoop = { + inherit + package + coreSite + hdfsSite + yarnSite + ; + yarn.resourcemanager = { + enable = true; + openFirewall = true; + }; + }; }; - }; - }; - nm1 = { options, ... }: { - virtualisation.memorySize = 2048; - services.hadoop = { - inherit package coreSite hdfsSite yarnSite; - yarn.nodemanager = { - enable = true; - openFirewall = true; + nm1 = + { options, ... }: + { + virtualisation.memorySize = 2048; + services.hadoop = { + inherit + package + coreSite + hdfsSite + yarnSite + ; + yarn.nodemanager = { + enable = true; + openFirewall = true; + }; + }; + }; + client = + { options, ... }: + { + services.hadoop = { + gatewayRole.enable = true; + inherit + package + coreSite + hdfsSite + yarnSite + ; + }; }; - }; - }; - client = { options, ... }: { - services.hadoop = { - gatewayRole.enable = true; - inherit package coreSite hdfsSite yarnSite; - }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - #### HDFS tests #### + #### HDFS tests #### - zk1.wait_for_unit("network.target") - jn1.wait_for_unit("network.target") - jn2.wait_for_unit("network.target") - jn3.wait_for_unit("network.target") - nn1.wait_for_unit("network.target") - nn2.wait_for_unit("network.target") - dn1.wait_for_unit("network.target") + zk1.wait_for_unit("network.target") + jn1.wait_for_unit("network.target") + jn2.wait_for_unit("network.target") + jn3.wait_for_unit("network.target") + nn1.wait_for_unit("network.target") + nn2.wait_for_unit("network.target") + dn1.wait_for_unit("network.target") - zk1.wait_for_unit("zookeeper") - jn1.wait_for_unit("hdfs-journalnode") - jn2.wait_for_unit("hdfs-journalnode") - jn3.wait_for_unit("hdfs-journalnode") + zk1.wait_for_unit("zookeeper") + jn1.wait_for_unit("hdfs-journalnode") + jn2.wait_for_unit("hdfs-journalnode") + jn3.wait_for_unit("hdfs-journalnode") - zk1.wait_for_open_port(2181) - jn1.wait_for_open_port(8480) - jn1.wait_for_open_port(8485) - jn2.wait_for_open_port(8480) - jn2.wait_for_open_port(8485) + zk1.wait_for_open_port(2181) + jn1.wait_for_open_port(8480) + jn1.wait_for_open_port(8485) + jn2.wait_for_open_port(8480) + jn2.wait_for_open_port(8485) - # Namenodes must be stopped before initializing the cluster - nn1.succeed("systemctl stop hdfs-namenode") - nn2.succeed("systemctl stop hdfs-namenode") - nn1.succeed("systemctl stop hdfs-zkfc") - nn2.succeed("systemctl stop hdfs-zkfc") + # Namenodes must be stopped before initializing the cluster + nn1.succeed("systemctl stop hdfs-namenode") + nn2.succeed("systemctl stop hdfs-namenode") + nn1.succeed("systemctl stop hdfs-zkfc") + nn2.succeed("systemctl stop hdfs-zkfc") - # Initialize zookeeper for failover controller - nn1.succeed("sudo -u hdfs systemd-cat hdfs zkfc -formatZK") + # Initialize zookeeper for failover controller + nn1.succeed("sudo -u hdfs systemd-cat hdfs zkfc -formatZK") - # Format NN1 and start it - nn1.succeed("sudo -u hdfs systemd-cat hadoop namenode -format") - nn1.succeed("systemctl start hdfs-namenode") - nn1.wait_for_open_port(9870) - nn1.wait_for_open_port(8022) - nn1.wait_for_open_port(8020) + # Format NN1 and start it + nn1.succeed("sudo -u hdfs systemd-cat hadoop namenode -format") + nn1.succeed("systemctl start hdfs-namenode") + nn1.wait_for_open_port(9870) + nn1.wait_for_open_port(8022) + nn1.wait_for_open_port(8020) - # Bootstrap NN2 from NN1 and start it - nn2.succeed("sudo -u hdfs systemd-cat hdfs namenode -bootstrapStandby") - nn2.succeed("systemctl start hdfs-namenode") - nn2.wait_for_open_port(9870) - nn2.wait_for_open_port(8022) - nn2.wait_for_open_port(8020) - nn1.succeed("systemd-cat netstat -tulpne") + # Bootstrap NN2 from NN1 and start it + nn2.succeed("sudo -u hdfs systemd-cat hdfs namenode -bootstrapStandby") + nn2.succeed("systemctl start hdfs-namenode") + nn2.wait_for_open_port(9870) + nn2.wait_for_open_port(8022) + nn2.wait_for_open_port(8020) + nn1.succeed("systemd-cat netstat -tulpne") - # Start failover controllers - nn1.succeed("systemctl start hdfs-zkfc") - nn2.succeed("systemctl start hdfs-zkfc") + # Start failover controllers + nn1.succeed("systemctl start hdfs-zkfc") + nn2.succeed("systemctl start hdfs-zkfc") - # DN should have started by now, but confirm anyway - dn1.wait_for_unit("hdfs-datanode") - # Print states of namenodes - client.succeed("sudo -u hdfs systemd-cat hdfs haadmin -getAllServiceState") - # Wait for cluster to exit safemode - client.succeed("sudo -u hdfs hdfs dfsadmin -safemode wait") - client.succeed("sudo -u hdfs systemd-cat hdfs haadmin -getAllServiceState") - # test R/W - client.succeed("echo testfilecontents | sudo -u hdfs hdfs dfs -put - /testfile") - assert "testfilecontents" in client.succeed("sudo -u hdfs hdfs dfs -cat /testfile") + # DN should have started by now, but confirm anyway + dn1.wait_for_unit("hdfs-datanode") + # Print states of namenodes + client.succeed("sudo -u hdfs systemd-cat hdfs haadmin -getAllServiceState") + # Wait for cluster to exit safemode + client.succeed("sudo -u hdfs hdfs dfsadmin -safemode wait") + client.succeed("sudo -u hdfs systemd-cat hdfs haadmin -getAllServiceState") + # test R/W + client.succeed("echo testfilecontents | sudo -u hdfs hdfs dfs -put - /testfile") + assert "testfilecontents" in client.succeed("sudo -u hdfs hdfs dfs -cat /testfile") - # Test NN failover - nn1.succeed("systemctl stop hdfs-namenode") - assert "active" in client.succeed("sudo -u hdfs hdfs haadmin -getAllServiceState") - client.succeed("sudo -u hdfs systemd-cat hdfs haadmin -getAllServiceState") - assert "testfilecontents" in client.succeed("sudo -u hdfs hdfs dfs -cat /testfile") + # Test NN failover + nn1.succeed("systemctl stop hdfs-namenode") + assert "active" in client.succeed("sudo -u hdfs hdfs haadmin -getAllServiceState") + client.succeed("sudo -u hdfs systemd-cat hdfs haadmin -getAllServiceState") + assert "testfilecontents" in client.succeed("sudo -u hdfs hdfs dfs -cat /testfile") - nn1.succeed("systemctl start hdfs-namenode") - nn1.wait_for_open_port(9870) - nn1.wait_for_open_port(8022) - nn1.wait_for_open_port(8020) - assert "standby" in client.succeed("sudo -u hdfs hdfs haadmin -getAllServiceState") - client.succeed("sudo -u hdfs systemd-cat hdfs haadmin -getAllServiceState") + nn1.succeed("systemctl start hdfs-namenode") + nn1.wait_for_open_port(9870) + nn1.wait_for_open_port(8022) + nn1.wait_for_open_port(8020) + assert "standby" in client.succeed("sudo -u hdfs hdfs haadmin -getAllServiceState") + client.succeed("sudo -u hdfs systemd-cat hdfs haadmin -getAllServiceState") - #### YARN tests #### + #### YARN tests #### - rm1.wait_for_unit("network.target") - rm2.wait_for_unit("network.target") - nm1.wait_for_unit("network.target") + rm1.wait_for_unit("network.target") + rm2.wait_for_unit("network.target") + nm1.wait_for_unit("network.target") - rm1.wait_for_unit("yarn-resourcemanager") - rm1.wait_for_open_port(8088) - rm2.wait_for_unit("yarn-resourcemanager") - rm2.wait_for_open_port(8088) + rm1.wait_for_unit("yarn-resourcemanager") + rm1.wait_for_open_port(8088) + rm2.wait_for_unit("yarn-resourcemanager") + rm2.wait_for_open_port(8088) - nm1.wait_for_unit("yarn-nodemanager") - nm1.wait_for_open_port(8042) - nm1.wait_for_open_port(8040) - client.wait_until_succeeds("yarn node -list | grep Nodes:1") - client.succeed("sudo -u yarn systemd-cat yarn rmadmin -getAllServiceState") - client.succeed("sudo -u yarn systemd-cat yarn node -list") + nm1.wait_for_unit("yarn-nodemanager") + nm1.wait_for_open_port(8042) + nm1.wait_for_open_port(8040) + client.wait_until_succeeds("yarn node -list | grep Nodes:1") + client.succeed("sudo -u yarn systemd-cat yarn rmadmin -getAllServiceState") + client.succeed("sudo -u yarn systemd-cat yarn node -list") - # Test RM failover - rm1.succeed("systemctl stop yarn-resourcemanager") - assert "standby" not in client.succeed("sudo -u yarn yarn rmadmin -getAllServiceState") - client.succeed("sudo -u yarn systemd-cat yarn rmadmin -getAllServiceState") - rm1.succeed("systemctl start yarn-resourcemanager") - rm1.wait_for_unit("yarn-resourcemanager") - rm1.wait_for_open_port(8088) - assert "standby" in client.succeed("sudo -u yarn yarn rmadmin -getAllServiceState") - client.succeed("sudo -u yarn systemd-cat yarn rmadmin -getAllServiceState") + # Test RM failover + rm1.succeed("systemctl stop yarn-resourcemanager") + assert "standby" not in client.succeed("sudo -u yarn yarn rmadmin -getAllServiceState") + client.succeed("sudo -u yarn systemd-cat yarn rmadmin -getAllServiceState") + rm1.succeed("systemctl start yarn-resourcemanager") + rm1.wait_for_unit("yarn-resourcemanager") + rm1.wait_for_open_port(8088) + assert "standby" in client.succeed("sudo -u yarn yarn rmadmin -getAllServiceState") + client.succeed("sudo -u yarn systemd-cat yarn rmadmin -getAllServiceState") - assert "Estimated value of Pi is" in client.succeed("HADOOP_USER_NAME=hdfs yarn jar $(readlink $(which yarn) | sed -r 's~bin/yarn~share/hadoop/mapreduce/hadoop-mapreduce-examples-*.jar~g') pi 2 10") - assert "SUCCEEDED" in client.succeed("yarn application -list -appStates FINISHED") - ''; -}) + assert "Estimated value of Pi is" in client.succeed("HADOOP_USER_NAME=hdfs yarn jar $(readlink $(which yarn) | sed -r 's~bin/yarn~share/hadoop/mapreduce/hadoop-mapreduce-examples-*.jar~g') pi 2 10") + assert "SUCCEEDED" in client.succeed("yarn application -list -appStates FINISHED") + ''; + } +) diff --git a/nixos/tests/hadoop/hbase.nix b/nixos/tests/hadoop/hbase.nix index 0416345682a898..efc85c869bf916 100644 --- a/nixos/tests/hadoop/hbase.nix +++ b/nixos/tests/hadoop/hbase.nix @@ -1,109 +1,135 @@ # Test a minimal hbase cluster { pkgs, ... }: -import ../make-test-python.nix ({ hadoop ? pkgs.hadoop, hbase ? pkgs.hbase, ... }: -with pkgs.lib; -{ - name = "hadoop-hbase"; +import ../make-test-python.nix ( + { + hadoop ? pkgs.hadoop, + hbase ? pkgs.hbase, + ... + }: + with pkgs.lib; + { + name = "hadoop-hbase"; - nodes = let - coreSite = { - "fs.defaultFS" = "hdfs://namenode:8020"; - }; - defOpts = { - enable = true; - openFirewall = true; - }; - zookeeperQuorum = "zookeeper"; - in { - zookeeper = { ... }: { - services.zookeeper.enable = true; - networking.firewall.allowedTCPPorts = [ 2181 ]; - }; - namenode = { ... }: { - services.hadoop = { - hdfs = { - namenode = defOpts // { formatOnInit = true; }; + nodes = + let + coreSite = { + "fs.defaultFS" = "hdfs://namenode:8020"; }; - inherit coreSite; - }; - }; - datanode = { ... }: { - virtualisation.diskSize = 8192; - services.hadoop = { - hdfs.datanode = defOpts; - inherit coreSite; - }; - }; - - master = { ... }:{ - services.hadoop = { - inherit coreSite; - hbase = { - inherit zookeeperQuorum; - master = defOpts // { initHDFS = true; }; - }; - }; - }; - regionserver = { ... }:{ - services.hadoop = { - inherit coreSite; - hbase = { - inherit zookeeperQuorum; - regionServer = defOpts; - }; - }; - }; - thrift = { ... }:{ - services.hadoop = { - inherit coreSite; - hbase = { - inherit zookeeperQuorum; - thrift = defOpts; - }; - }; - }; - rest = { ... }:{ - services.hadoop = { - inherit coreSite; - hbase = { - inherit zookeeperQuorum; - rest = defOpts; + defOpts = { + enable = true; + openFirewall = true; }; + zookeeperQuorum = "zookeeper"; + in + { + zookeeper = + { ... }: + { + services.zookeeper.enable = true; + networking.firewall.allowedTCPPorts = [ 2181 ]; + }; + namenode = + { ... }: + { + services.hadoop = { + hdfs = { + namenode = defOpts // { + formatOnInit = true; + }; + }; + inherit coreSite; + }; + }; + datanode = + { ... }: + { + virtualisation.diskSize = 8192; + services.hadoop = { + hdfs.datanode = defOpts; + inherit coreSite; + }; + }; + + master = + { ... }: + { + services.hadoop = { + inherit coreSite; + hbase = { + inherit zookeeperQuorum; + master = defOpts // { + initHDFS = true; + }; + }; + }; + }; + regionserver = + { ... }: + { + services.hadoop = { + inherit coreSite; + hbase = { + inherit zookeeperQuorum; + regionServer = defOpts; + }; + }; + }; + thrift = + { ... }: + { + services.hadoop = { + inherit coreSite; + hbase = { + inherit zookeeperQuorum; + thrift = defOpts; + }; + }; + }; + rest = + { ... }: + { + services.hadoop = { + inherit coreSite; + hbase = { + inherit zookeeperQuorum; + rest = defOpts; + }; + }; + }; }; - }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - # wait for HDFS cluster - namenode.wait_for_unit("hdfs-namenode") - namenode.wait_for_unit("network.target") - namenode.wait_for_open_port(8020) - namenode.wait_for_open_port(9870) - datanode.wait_for_unit("hdfs-datanode") - datanode.wait_for_unit("network.target") - datanode.wait_for_open_port(9864) - datanode.wait_for_open_port(9866) - datanode.wait_for_open_port(9867) + # wait for HDFS cluster + namenode.wait_for_unit("hdfs-namenode") + namenode.wait_for_unit("network.target") + namenode.wait_for_open_port(8020) + namenode.wait_for_open_port(9870) + datanode.wait_for_unit("hdfs-datanode") + datanode.wait_for_unit("network.target") + datanode.wait_for_open_port(9864) + datanode.wait_for_open_port(9866) + datanode.wait_for_open_port(9867) - # wait for ZK - zookeeper.wait_for_unit("zookeeper") - zookeeper.wait_for_open_port(2181) + # wait for ZK + zookeeper.wait_for_unit("zookeeper") + zookeeper.wait_for_open_port(2181) - # wait for HBase to start up - master.wait_for_unit("hbase-master") - regionserver.wait_for_unit("hbase-regionserver") + # wait for HBase to start up + master.wait_for_unit("hbase-master") + regionserver.wait_for_unit("hbase-regionserver") - assert "1 active master, 0 backup masters, 1 servers" in master.succeed("echo status | HADOOP_USER_NAME=hbase hbase shell -n") - regionserver.wait_until_succeeds("echo \"create 't1','f1'\" | HADOOP_USER_NAME=hbase hbase shell -n") - assert "NAME => 'f1'" in regionserver.succeed("echo \"describe 't1'\" | HADOOP_USER_NAME=hbase hbase shell -n") + assert "1 active master, 0 backup masters, 1 servers" in master.succeed("echo status | HADOOP_USER_NAME=hbase hbase shell -n") + regionserver.wait_until_succeeds("echo \"create 't1','f1'\" | HADOOP_USER_NAME=hbase hbase shell -n") + assert "NAME => 'f1'" in regionserver.succeed("echo \"describe 't1'\" | HADOOP_USER_NAME=hbase hbase shell -n") - rest.wait_for_open_port(8080) - assert "${hbase.version}" in regionserver.succeed("curl http://rest:8080/version/cluster") + rest.wait_for_open_port(8080) + assert "${hbase.version}" in regionserver.succeed("curl http://rest:8080/version/cluster") - thrift.wait_for_open_port(9090) - ''; + thrift.wait_for_open_port(9090) + ''; - meta.maintainers = with maintainers; [ illustris ]; -}) + meta.maintainers = with maintainers; [ illustris ]; + } +) diff --git a/nixos/tests/hadoop/hdfs.nix b/nixos/tests/hadoop/hdfs.nix index 65686b3715598e..45206eefa6c2bb 100644 --- a/nixos/tests/hadoop/hdfs.nix +++ b/nixos/tests/hadoop/hdfs.nix @@ -1,83 +1,102 @@ # Test a minimal HDFS cluster with no HA -import ../make-test-python.nix ({ package, lib, ... }: -{ - name = "hadoop-hdfs"; +import ../make-test-python.nix ( + { package, lib, ... }: + { + name = "hadoop-hdfs"; - nodes = let - coreSite = { - "fs.defaultFS" = "hdfs://namenode:8020"; - "hadoop.proxyuser.httpfs.groups" = "*"; - "hadoop.proxyuser.httpfs.hosts" = "*"; - }; - in { - namenode = { pkgs, ... }: { - services.hadoop = { - inherit package; - hdfs = { - namenode = { - enable = true; - openFirewall = true; - formatOnInit = true; + nodes = + let + coreSite = { + "fs.defaultFS" = "hdfs://namenode:8020"; + "hadoop.proxyuser.httpfs.groups" = "*"; + "hadoop.proxyuser.httpfs.hosts" = "*"; + }; + in + { + namenode = + { pkgs, ... }: + { + services.hadoop = { + inherit package; + hdfs = { + namenode = { + enable = true; + openFirewall = true; + formatOnInit = true; + }; + httpfs = { + # The NixOS hadoop module only support webHDFS on 3.3 and newer + enable = lib.mkIf (lib.versionAtLeast package.version "3.3") true; + openFirewall = true; + }; + }; + inherit coreSite; + }; }; - httpfs = { - # The NixOS hadoop module only support webHDFS on 3.3 and newer - enable = lib.mkIf (lib.versionAtLeast package.version "3.3") true; - openFirewall = true; + datanode = + { pkgs, ... }: + { + services.hadoop = { + inherit package; + hdfs.datanode = { + enable = true; + openFirewall = true; + dataDirs = [ + { + type = "DISK"; + path = "/tmp/dn1"; + } + ]; + }; + inherit coreSite; + }; }; - }; - inherit coreSite; - }; - }; - datanode = { pkgs, ... }: { - services.hadoop = { - inherit package; - hdfs.datanode = { - enable = true; - openFirewall = true; - dataDirs = [{ - type = "DISK"; - path = "/tmp/dn1"; - }]; - }; - inherit coreSite; }; - }; - }; - testScript = '' - start_all() + testScript = + '' + start_all() - namenode.wait_for_unit("hdfs-namenode") - namenode.wait_for_unit("network.target") - namenode.wait_for_open_port(8020) - namenode.succeed("systemd-cat ss -tulpne") - namenode.succeed("systemd-cat cat /etc/hadoop*/hdfs-site.xml") - namenode.wait_for_open_port(9870) + namenode.wait_for_unit("hdfs-namenode") + namenode.wait_for_unit("network.target") + namenode.wait_for_open_port(8020) + namenode.succeed("systemd-cat ss -tulpne") + namenode.succeed("systemd-cat cat /etc/hadoop*/hdfs-site.xml") + namenode.wait_for_open_port(9870) - datanode.wait_for_unit("hdfs-datanode") - datanode.wait_for_unit("network.target") - '' + (if lib.versionAtLeast package.version "3" then '' - datanode.wait_for_open_port(9864) - datanode.wait_for_open_port(9866) - datanode.wait_for_open_port(9867) + datanode.wait_for_unit("hdfs-datanode") + datanode.wait_for_unit("network.target") + '' + + ( + if lib.versionAtLeast package.version "3" then + '' + datanode.wait_for_open_port(9864) + datanode.wait_for_open_port(9866) + datanode.wait_for_open_port(9867) - datanode.succeed("curl -f http://datanode:9864") - '' else '' - datanode.wait_for_open_port(50075) - datanode.wait_for_open_port(50010) - datanode.wait_for_open_port(50020) + datanode.succeed("curl -f http://datanode:9864") + '' + else + '' + datanode.wait_for_open_port(50075) + datanode.wait_for_open_port(50010) + datanode.wait_for_open_port(50020) - datanode.succeed("curl -f http://datanode:50075") - '' ) + '' - namenode.succeed("curl -f http://namenode:9870") + datanode.succeed("curl -f http://datanode:50075") + '' + ) + + '' + namenode.succeed("curl -f http://namenode:9870") - datanode.succeed("sudo -u hdfs hdfs dfsadmin -safemode wait") - datanode.succeed("echo testfilecontents | sudo -u hdfs hdfs dfs -put - /testfile") - assert "testfilecontents" in datanode.succeed("sudo -u hdfs hdfs dfs -cat /testfile") + datanode.succeed("sudo -u hdfs hdfs dfsadmin -safemode wait") + datanode.succeed("echo testfilecontents | sudo -u hdfs hdfs dfs -put - /testfile") + assert "testfilecontents" in datanode.succeed("sudo -u hdfs hdfs dfs -cat /testfile") - '' + lib.optionalString (lib.versionAtLeast package.version "3.3" ) '' - namenode.wait_for_unit("hdfs-httpfs") - namenode.wait_for_open_port(14000) - assert "testfilecontents" in datanode.succeed("curl -f \"http://namenode:14000/webhdfs/v1/testfile?user.name=hdfs&op=OPEN\" 2>&1") - ''; -}) + '' + + lib.optionalString (lib.versionAtLeast package.version "3.3") '' + namenode.wait_for_unit("hdfs-httpfs") + namenode.wait_for_open_port(14000) + assert "testfilecontents" in datanode.succeed("curl -f \"http://namenode:14000/webhdfs/v1/testfile?user.name=hdfs&op=OPEN\" 2>&1") + ''; + } +) diff --git a/nixos/tests/hadoop/yarn.nix b/nixos/tests/hadoop/yarn.nix index 08c8ff857d8c25..c1a03e7ec7bd37 100644 --- a/nixos/tests/hadoop/yarn.nix +++ b/nixos/tests/hadoop/yarn.nix @@ -1,45 +1,52 @@ # This only tests if YARN is able to start its services -import ../make-test-python.nix ({ package, ... }: { - name = "hadoop-yarn"; +import ../make-test-python.nix ( + { package, ... }: + { + name = "hadoop-yarn"; - nodes = { - resourcemanager = { ... }: { - services.hadoop = { - inherit package; - yarn.resourcemanager = { - enable = true; - openFirewall = true; + nodes = { + resourcemanager = + { ... }: + { + services.hadoop = { + inherit package; + yarn.resourcemanager = { + enable = true; + openFirewall = true; + }; + }; }; - }; - }; - nodemanager = { options, lib, ... }: { - services.hadoop = { - inherit package; - yarn.nodemanager = { - enable = true; - openFirewall = true; - }; - yarnSite = { - "yarn.resourcemanager.hostname" = "resourcemanager"; - "yarn.nodemanager.log-dirs" = "/tmp/userlogs"; + nodemanager = + { options, lib, ... }: + { + services.hadoop = { + inherit package; + yarn.nodemanager = { + enable = true; + openFirewall = true; + }; + yarnSite = { + "yarn.resourcemanager.hostname" = "resourcemanager"; + "yarn.nodemanager.log-dirs" = "/tmp/userlogs"; + }; + }; }; - }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - resourcemanager.wait_for_unit("yarn-resourcemanager") - resourcemanager.wait_for_unit("network.target") - resourcemanager.wait_for_open_port(8031) - resourcemanager.wait_for_open_port(8088) + resourcemanager.wait_for_unit("yarn-resourcemanager") + resourcemanager.wait_for_unit("network.target") + resourcemanager.wait_for_open_port(8031) + resourcemanager.wait_for_open_port(8088) - nodemanager.wait_for_unit("yarn-nodemanager") - nodemanager.wait_for_unit("network.target") - nodemanager.wait_for_open_port(8042) + nodemanager.wait_for_unit("yarn-nodemanager") + nodemanager.wait_for_unit("network.target") + nodemanager.wait_for_open_port(8042) - resourcemanager.succeed("curl -f http://localhost:8088") - nodemanager.succeed("curl -f http://localhost:8042") - ''; -}) + resourcemanager.succeed("curl -f http://localhost:8088") + nodemanager.succeed("curl -f http://localhost:8042") + ''; + } +) diff --git a/nixos/tests/haka.nix b/nixos/tests/haka.nix index dd65a6bcf115a6..20a161bd8400e2 100644 --- a/nixos/tests/haka.nix +++ b/nixos/tests/haka.nix @@ -1,24 +1,27 @@ # This test runs haka and probes it with hakactl -import ./make-test-python.nix ({ pkgs, ...} : { - name = "haka"; - meta = with pkgs.lib.maintainers; { - maintainers = [ tvestelind ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "haka"; + meta = with pkgs.lib.maintainers; { + maintainers = [ tvestelind ]; + }; - nodes = { - haka = - { ... }: + nodes = { + haka = + { ... }: { services.haka.enable = true; }; }; - testScript = '' - start_all() + testScript = '' + start_all() - haka.wait_for_unit("haka.service") - haka.succeed("hakactl status") - haka.succeed("hakactl stop") - ''; -}) + haka.wait_for_unit("haka.service") + haka.succeed("hakactl status") + haka.succeed("hakactl stop") + ''; + } +) diff --git a/nixos/tests/haproxy.nix b/nixos/tests/haproxy.nix index 17309387375778..b3cc19696d7c8f 100644 --- a/nixos/tests/haproxy.nix +++ b/nixos/tests/haproxy.nix @@ -1,124 +1,140 @@ -import ./make-test-python.nix ({ lib, pkgs, ...}: { - name = "haproxy"; - nodes = { - server = { ... }: { - services.haproxy = { - enable = true; - config = '' - global - limited-quic - - defaults - mode http - timeout connect 10s - timeout client 10s - timeout server 10s - - log /dev/log local0 debug err - option logasap - option httplog - option httpslog - - backend http_server - server httpd [::1]:8000 alpn http/1.1 - - frontend http - bind :80 - bind :443 ssl strict-sni crt /etc/ssl/fullchain.pem alpn h2,http/1.1 - bind quic4@:443 ssl strict-sni crt /etc/ssl/fullchain.pem alpn h3 allow-0rtt - - http-after-response add-header alt-svc 'h3=":443"; ma=60' if { ssl_fc } - - http-request use-service prometheus-exporter if { path /metrics } - use_backend http_server - - frontend http-cert-auth - bind :8443 ssl strict-sni crt /etc/ssl/fullchain.pem verify required ca-file /etc/ssl/cacert.crt - bind quic4@:8443 ssl strict-sni crt /etc/ssl/fullchain.pem verify required ca-file /etc/ssl/cacert.crt alpn h3 - - use_backend http_server - ''; - }; - services.httpd = { - enable = true; - virtualHosts.localhost = { - documentRoot = pkgs.writeTextDir "index.txt" "We are all good!"; - adminAddr = "notme@yourhost.local"; - listen = [{ - ip = "::1"; - port = 8000; - }]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "haproxy"; + nodes = { + server = + { ... }: + { + services.haproxy = { + enable = true; + config = '' + global + limited-quic + + defaults + mode http + timeout connect 10s + timeout client 10s + timeout server 10s + + log /dev/log local0 debug err + option logasap + option httplog + option httpslog + + backend http_server + server httpd [::1]:8000 alpn http/1.1 + + frontend http + bind :80 + bind :443 ssl strict-sni crt /etc/ssl/fullchain.pem alpn h2,http/1.1 + bind quic4@:443 ssl strict-sni crt /etc/ssl/fullchain.pem alpn h3 allow-0rtt + + http-after-response add-header alt-svc 'h3=":443"; ma=60' if { ssl_fc } + + http-request use-service prometheus-exporter if { path /metrics } + use_backend http_server + + frontend http-cert-auth + bind :8443 ssl strict-sni crt /etc/ssl/fullchain.pem verify required ca-file /etc/ssl/cacert.crt + bind quic4@:8443 ssl strict-sni crt /etc/ssl/fullchain.pem verify required ca-file /etc/ssl/cacert.crt alpn h3 + + use_backend http_server + ''; + }; + services.httpd = { + enable = true; + virtualHosts.localhost = { + documentRoot = pkgs.writeTextDir "index.txt" "We are all good!"; + adminAddr = "notme@yourhost.local"; + listen = [ + { + ip = "::1"; + port = 8000; + } + ]; + }; + }; + networking.firewall.allowedTCPPorts = [ + 80 + 443 + 8443 + ]; + networking.firewall.allowedUDPPorts = [ + 443 + 8443 + ]; + }; + client = + { ... }: + { + environment.systemPackages = [ pkgs.curlHTTP3 ]; }; - }; - networking.firewall.allowedTCPPorts = [ 80 443 8443 ]; - networking.firewall.allowedUDPPorts = [ 443 8443 ]; - }; - client = { ... }: { - environment.systemPackages = [ pkgs.curlHTTP3 ]; }; - }; - testScript = '' - # Helpers - def cmd(command): - print(f"+{command}") - r = os.system(command) - if r != 0: - raise Exception(f"Command {command} failed with exit code {r}") - - def openssl(command): - cmd(f"${pkgs.openssl}/bin/openssl {command}") - - # Generate CA. - openssl("req -new -newkey rsa:4096 -nodes -x509 -days 7 -subj '/C=ZZ/ST=Cloud/L=Unspecified/O=NixOS/OU=Tests/CN=CA Certificate' -keyout cacert.key -out cacert.crt") - - # Generate and sign Server. - openssl("req -newkey rsa:4096 -nodes -subj '/CN=server/OU=Tests/O=NixOS' -keyout server.key -out server.csr") - openssl("x509 -req -in server.csr -out server.crt -CA cacert.crt -CAkey cacert.key -days 7") - cmd("cat server.crt server.key > fullchain.pem") - - # Generate and sign Client. - openssl("req -newkey rsa:4096 -nodes -subj '/CN=client/OU=Tests/O=NixOS' -keyout client.key -out client.csr") - openssl("x509 -req -in client.csr -out client.crt -CA cacert.crt -CAkey cacert.key -days 7") - cmd("cat client.crt client.key > client.pem") - - # Start the actual test. - start_all() - server.copy_from_host("fullchain.pem", "/etc/ssl/fullchain.pem") - server.copy_from_host("cacert.crt", "/etc/ssl/cacert.crt") - server.succeed("chmod 0644 /etc/ssl/fullchain.pem /etc/ssl/cacert.crt") - - client.copy_from_host("cacert.crt", "/etc/ssl/cacert.crt") - client.copy_from_host("client.pem", "/root/client.pem") - - server.wait_for_unit("multi-user.target") - server.wait_for_unit("haproxy.service") - server.wait_for_unit("httpd.service") - - assert "We are all good!" in client.succeed("curl -f http://server/index.txt") - assert "haproxy_process_pool_allocated_bytes" in client.succeed("curl -f http://server/metrics") - - with subtest("https"): - assert "We are all good!" in client.succeed("curl -f --cacert /etc/ssl/cacert.crt https://server/index.txt") - - with subtest("https-cert-auth"): - # Client must succeed in authenticating with the right certificate. - assert "We are all good!" in client.succeed("curl -f --cacert /etc/ssl/cacert.crt --cert-type pem --cert /root/client.pem https://server:8443/index.txt") - # Client must fail without certificate. - client.fail("curl --cacert /etc/ssl/cacert.crt https://server:8443/index.txt") - - with subtest("h3"): - assert "We are all good!" in client.succeed("curl -f --http3-only --cacert /etc/ssl/cacert.crt https://server/index.txt") - - with subtest("h3-cert-auth"): - # Client must succeed in authenticating with the right certificate. - assert "We are all good!" in client.succeed("curl -f --http3-only --cacert /etc/ssl/cacert.crt --cert-type pem --cert /root/client.pem https://server:8443/index.txt") - # Client must fail without certificate. - client.fail("curl -f --http3-only --cacert /etc/ssl/cacert.crt https://server:8443/index.txt") - - with subtest("reload"): - server.succeed("systemctl reload haproxy") - # wait some time to ensure the following request hits the reloaded haproxy - server.sleep(5) - assert "We are all good!" in client.succeed("curl -f http://server/index.txt") - ''; -}) + testScript = '' + # Helpers + def cmd(command): + print(f"+{command}") + r = os.system(command) + if r != 0: + raise Exception(f"Command {command} failed with exit code {r}") + + def openssl(command): + cmd(f"${pkgs.openssl}/bin/openssl {command}") + + # Generate CA. + openssl("req -new -newkey rsa:4096 -nodes -x509 -days 7 -subj '/C=ZZ/ST=Cloud/L=Unspecified/O=NixOS/OU=Tests/CN=CA Certificate' -keyout cacert.key -out cacert.crt") + + # Generate and sign Server. + openssl("req -newkey rsa:4096 -nodes -subj '/CN=server/OU=Tests/O=NixOS' -keyout server.key -out server.csr") + openssl("x509 -req -in server.csr -out server.crt -CA cacert.crt -CAkey cacert.key -days 7") + cmd("cat server.crt server.key > fullchain.pem") + + # Generate and sign Client. + openssl("req -newkey rsa:4096 -nodes -subj '/CN=client/OU=Tests/O=NixOS' -keyout client.key -out client.csr") + openssl("x509 -req -in client.csr -out client.crt -CA cacert.crt -CAkey cacert.key -days 7") + cmd("cat client.crt client.key > client.pem") + + # Start the actual test. + start_all() + server.copy_from_host("fullchain.pem", "/etc/ssl/fullchain.pem") + server.copy_from_host("cacert.crt", "/etc/ssl/cacert.crt") + server.succeed("chmod 0644 /etc/ssl/fullchain.pem /etc/ssl/cacert.crt") + + client.copy_from_host("cacert.crt", "/etc/ssl/cacert.crt") + client.copy_from_host("client.pem", "/root/client.pem") + + server.wait_for_unit("multi-user.target") + server.wait_for_unit("haproxy.service") + server.wait_for_unit("httpd.service") + + assert "We are all good!" in client.succeed("curl -f http://server/index.txt") + assert "haproxy_process_pool_allocated_bytes" in client.succeed("curl -f http://server/metrics") + + with subtest("https"): + assert "We are all good!" in client.succeed("curl -f --cacert /etc/ssl/cacert.crt https://server/index.txt") + + with subtest("https-cert-auth"): + # Client must succeed in authenticating with the right certificate. + assert "We are all good!" in client.succeed("curl -f --cacert /etc/ssl/cacert.crt --cert-type pem --cert /root/client.pem https://server:8443/index.txt") + # Client must fail without certificate. + client.fail("curl --cacert /etc/ssl/cacert.crt https://server:8443/index.txt") + + with subtest("h3"): + assert "We are all good!" in client.succeed("curl -f --http3-only --cacert /etc/ssl/cacert.crt https://server/index.txt") + + with subtest("h3-cert-auth"): + # Client must succeed in authenticating with the right certificate. + assert "We are all good!" in client.succeed("curl -f --http3-only --cacert /etc/ssl/cacert.crt --cert-type pem --cert /root/client.pem https://server:8443/index.txt") + # Client must fail without certificate. + client.fail("curl -f --http3-only --cacert /etc/ssl/cacert.crt https://server:8443/index.txt") + + with subtest("reload"): + server.succeed("systemctl reload haproxy") + # wait some time to ensure the following request hits the reloaded haproxy + server.sleep(5) + assert "We are all good!" in client.succeed("curl -f http://server/index.txt") + ''; + } +) diff --git a/nixos/tests/hardened.nix b/nixos/tests/hardened.nix index 0c43e3523dacfd..7e1301b8099add 100644 --- a/nixos/tests/hardened.nix +++ b/nixos/tests/hardened.nix @@ -1,100 +1,113 @@ -import ./make-test-python.nix ({ pkgs, ... } : { - name = "hardened"; - meta = with pkgs.lib.maintainers; { - maintainers = [ joachifm ]; - }; - - nodes.machine = - { lib, pkgs, config, ... }: - { users.users.alice = { isNormalUser = true; extraGroups = [ "proc" ]; }; - users.users.sybil = { isNormalUser = true; group = "wheel"; }; - imports = [ ../modules/profiles/hardened.nix ]; - environment.memoryAllocator.provider = "graphene-hardened"; - nix.settings.sandbox = false; - virtualisation.emptyDiskImages = [ 4096 ]; - boot.initrd.postDeviceCommands = '' - ${pkgs.dosfstools}/bin/mkfs.vfat -n EFISYS /dev/vdb - ''; - virtualisation.fileSystems = { - "/efi" = { - device = "/dev/disk/by-label/EFISYS"; - fsType = "vfat"; - options = [ "noauto" ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "hardened"; + meta = with pkgs.lib.maintainers; { + maintainers = [ joachifm ]; + }; + + nodes.machine = + { + lib, + pkgs, + config, + ... + }: + { + users.users.alice = { + isNormalUser = true; + extraGroups = [ "proc" ]; + }; + users.users.sybil = { + isNormalUser = true; + group = "wheel"; }; + imports = [ ../modules/profiles/hardened.nix ]; + environment.memoryAllocator.provider = "graphene-hardened"; + nix.settings.sandbox = false; + virtualisation.emptyDiskImages = [ 4096 ]; + boot.initrd.postDeviceCommands = '' + ${pkgs.dosfstools}/bin/mkfs.vfat -n EFISYS /dev/vdb + ''; + virtualisation.fileSystems = { + "/efi" = { + device = "/dev/disk/by-label/EFISYS"; + fsType = "vfat"; + options = [ "noauto" ]; + }; + }; + boot.extraModulePackages = pkgs.lib.optional (pkgs.lib.versionOlder config.boot.kernelPackages.kernel.version "5.6") config.boot.kernelPackages.wireguard; + boot.kernelModules = [ "wireguard" ]; }; - boot.extraModulePackages = - pkgs.lib.optional (pkgs.lib.versionOlder config.boot.kernelPackages.kernel.version "5.6") - config.boot.kernelPackages.wireguard; - boot.kernelModules = [ "wireguard" ]; - }; - testScript = - let - hardened-malloc-tests = pkgs.graphene-hardened-malloc.ld-preload-tests; - in - '' - machine.wait_for_unit("multi-user.target") + testScript = + let + hardened-malloc-tests = pkgs.graphene-hardened-malloc.ld-preload-tests; + in + '' + machine.wait_for_unit("multi-user.target") - with subtest("AppArmor profiles are loaded"): - machine.succeed("systemctl status apparmor.service") + with subtest("AppArmor profiles are loaded"): + machine.succeed("systemctl status apparmor.service") - # AppArmor securityfs - with subtest("AppArmor securityfs is mounted"): - machine.succeed("mountpoint -q /sys/kernel/security") - machine.succeed("cat /sys/kernel/security/apparmor/profiles") + # AppArmor securityfs + with subtest("AppArmor securityfs is mounted"): + machine.succeed("mountpoint -q /sys/kernel/security") + machine.succeed("cat /sys/kernel/security/apparmor/profiles") - # Test loading out-of-tree modules - with subtest("Out-of-tree modules can be loaded"): - machine.succeed("grep -Fq wireguard /proc/modules") + # Test loading out-of-tree modules + with subtest("Out-of-tree modules can be loaded"): + machine.succeed("grep -Fq wireguard /proc/modules") - # Test kernel module hardening - with subtest("No more kernel modules can be loaded"): - # note: this better a be module we normally wouldn't load ... - machine.wait_for_unit("disable-kernel-module-loading.service") - machine.fail("modprobe dccp") + # Test kernel module hardening + with subtest("No more kernel modules can be loaded"): + # note: this better a be module we normally wouldn't load ... + machine.wait_for_unit("disable-kernel-module-loading.service") + machine.fail("modprobe dccp") - # Test userns - with subtest("User namespaces are restricted"): - machine.succeed("unshare --user true") - machine.fail("su -l alice -c 'unshare --user true'") + # Test userns + with subtest("User namespaces are restricted"): + machine.succeed("unshare --user true") + machine.fail("su -l alice -c 'unshare --user true'") - # Test dmesg restriction - with subtest("Regular users cannot access dmesg"): - machine.fail("su -l alice -c dmesg") + # Test dmesg restriction + with subtest("Regular users cannot access dmesg"): + machine.fail("su -l alice -c dmesg") - # Test access to kcore - with subtest("Kcore is inaccessible as root"): - machine.fail("cat /proc/kcore") + # Test access to kcore + with subtest("Kcore is inaccessible as root"): + machine.fail("cat /proc/kcore") - # Test deferred mount - with subtest("Deferred mounts work"): - machine.fail("mountpoint -q /efi") # was deferred - machine.execute("mkdir -p /efi") - machine.succeed("mount /dev/disk/by-label/EFISYS /efi") - machine.succeed("mountpoint -q /efi") # now mounted + # Test deferred mount + with subtest("Deferred mounts work"): + machine.fail("mountpoint -q /efi") # was deferred + machine.execute("mkdir -p /efi") + machine.succeed("mount /dev/disk/by-label/EFISYS /efi") + machine.succeed("mountpoint -q /efi") # now mounted - # Test Nix dæmon usage - with subtest("nix-daemon cannot be used by all users"): - machine.fail("su -l nobody -s /bin/sh -c 'nix --extra-experimental-features nix-command ping-store'") - machine.succeed("su -l alice -c 'nix --extra-experimental-features nix-command ping-store'") + # Test Nix dæmon usage + with subtest("nix-daemon cannot be used by all users"): + machine.fail("su -l nobody -s /bin/sh -c 'nix --extra-experimental-features nix-command ping-store'") + machine.succeed("su -l alice -c 'nix --extra-experimental-features nix-command ping-store'") - # Test kernel image protection - with subtest("The kernel image is protected"): - machine.fail("systemctl hibernate") - machine.fail("systemctl kexec") + # Test kernel image protection + with subtest("The kernel image is protected"): + machine.fail("systemctl hibernate") + machine.fail("systemctl kexec") - with subtest("The hardened memory allocator works"): - machine.succeed("${hardened-malloc-tests}/bin/run-tests") - ''; -}) + with subtest("The hardened memory allocator works"): + machine.succeed("${hardened-malloc-tests}/bin/run-tests") + ''; + } +) diff --git a/nixos/tests/harmonia.nix b/nixos/tests/harmonia.nix index d97f0fb89ede40..c58f24af25c999 100644 --- a/nixos/tests/harmonia.nix +++ b/nixos/tests/harmonia.nix @@ -7,7 +7,9 @@ harmonia = { services.harmonia = { enable = true; - signKeyPaths = [(pkgs.writeText "cache-key" "cache.example.com-1:9FhO0w+7HjZrhvmzT1VlAZw4OSAlFGTgC24Seg3tmPl4gZBdwZClzTTHr9cVzJpwsRSYLTu7hEAQe3ljy92CWg==")]; + signKeyPaths = [ + (pkgs.writeText "cache-key" "cache.example.com-1:9FhO0w+7HjZrhvmzT1VlAZw4OSAlFGTgC24Seg3tmPl4gZBdwZClzTTHr9cVzJpwsRSYLTu7hEAQe3ljy92CWg==") + ]; settings.priority = 35; }; @@ -15,26 +17,30 @@ system.extraDependencies = [ pkgs.emptyFile ]; # check that extra-allowed-users is effective for harmonia - nix.settings.allowed-users = []; + nix.settings.allowed-users = [ ]; }; client01 = { nix.settings = { substituters = lib.mkForce [ "http://harmonia:5000" ]; - trusted-public-keys = lib.mkForce [ "cache.example.com-1:eIGQXcGQpc00x6/XFcyacLEUmC07u4RAEHt5Y8vdglo=" ]; + trusted-public-keys = lib.mkForce [ + "cache.example.com-1:eIGQXcGQpc00x6/XFcyacLEUmC07u4RAEHt5Y8vdglo=" + ]; }; }; }; - testScript = { nodes, ... }: '' - start_all() + testScript = + { nodes, ... }: + '' + start_all() - harmonia.wait_for_unit("harmonia.service") + harmonia.wait_for_unit("harmonia.service") - client01.wait_until_succeeds("curl -f http://harmonia:5000/nix-cache-info | grep '${toString nodes.harmonia.services.harmonia.settings.priority}' >&2") - client01.succeed("curl -f http://harmonia:5000/version | grep '${nodes.harmonia.services.harmonia.package.version}' >&2") + client01.wait_until_succeeds("curl -f http://harmonia:5000/nix-cache-info | grep '${toString nodes.harmonia.services.harmonia.settings.priority}' >&2") + client01.succeed("curl -f http://harmonia:5000/version | grep '${nodes.harmonia.services.harmonia.package.version}' >&2") - client01.succeed("cat /etc/nix/nix.conf >&2") - client01.succeed("nix-store --realise ${pkgs.emptyFile} --store /root/other-store") - ''; + client01.succeed("cat /etc/nix/nix.conf >&2") + client01.succeed("nix-store --realise ${pkgs.emptyFile} --store /root/other-store") + ''; } diff --git a/nixos/tests/haste-server.nix b/nixos/tests/haste-server.nix index 9097c992c5483d..9c076155f2fcf9 100644 --- a/nixos/tests/haste-server.nix +++ b/nixos/tests/haste-server.nix @@ -1,18 +1,21 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: { name = "haste-server"; meta.maintainers = with lib.maintainers; [ mkg20001 ]; - nodes.machine = { pkgs, ... }: { - environment.systemPackages = with pkgs; [ - curl - jq - ]; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = with pkgs; [ + curl + jq + ]; - services.haste-server = { - enable = true; + services.haste-server = { + enable = true; + }; }; - }; testScript = '' machine.wait_for_unit("haste-server") @@ -20,4 +23,5 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: machine.succeed('curl -s -X POST http://localhost:7777/documents -d "Hello World!" > bla') machine.succeed('curl http://localhost:7777/raw/$(cat bla | jq -r .key) | grep "Hello World"') ''; - }) + } +) diff --git a/nixos/tests/hbase.nix b/nixos/tests/hbase.nix index 7d8e32f81603e8..12afa3a2d22104 100644 --- a/nixos/tests/hbase.nix +++ b/nixos/tests/hbase.nix @@ -1,30 +1,39 @@ -import ./make-test-python.nix ({ pkgs, lib, package ? pkgs.hbase, ... }: -{ - name = "hbase-standalone"; +import ./make-test-python.nix ( + { + pkgs, + lib, + package ? pkgs.hbase, + ... + }: + { + name = "hbase-standalone"; - meta = with lib.maintainers; { - maintainers = [ illustris ]; - }; + meta = with lib.maintainers; { + maintainers = [ illustris ]; + }; - nodes = { - hbase = { pkgs, ... }: { - services.hbase-standalone = { - enable = true; - inherit package; - # Needed for standalone mode in hbase 2+ - # This setting and standalone mode are not suitable for production - settings."hbase.unsafe.stream.capability.enforce" = "false"; - }; - environment.systemPackages = with pkgs; [ - package - ]; + nodes = { + hbase = + { pkgs, ... }: + { + services.hbase-standalone = { + enable = true; + inherit package; + # Needed for standalone mode in hbase 2+ + # This setting and standalone mode are not suitable for production + settings."hbase.unsafe.stream.capability.enforce" = "false"; + }; + environment.systemPackages = with pkgs; [ + package + ]; + }; }; - }; - testScript = '' - start_all() - hbase.wait_for_unit("hbase.service") - hbase.wait_until_succeeds("echo \"create 't1','f1'\" | sudo -u hbase hbase shell -n") - assert "NAME => 'f1'" in hbase.succeed("echo \"describe 't1'\" | sudo -u hbase hbase shell -n") - ''; -}) + testScript = '' + start_all() + hbase.wait_for_unit("hbase.service") + hbase.wait_until_succeeds("echo \"create 't1','f1'\" | sudo -u hbase hbase shell -n") + assert "NAME => 'f1'" in hbase.succeed("echo \"describe 't1'\" | sudo -u hbase hbase shell -n") + ''; + } +) diff --git a/nixos/tests/hddfancontrol.nix b/nixos/tests/hddfancontrol.nix index b5fa7ccb2c19be..159ffacab42e8f 100644 --- a/nixos/tests/hddfancontrol.nix +++ b/nixos/tests/hddfancontrol.nix @@ -1,44 +1,51 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "hddfancontrol"; - meta = with pkgs.lib.maintainers; { - maintainers = [ benley ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "hddfancontrol"; + meta = with pkgs.lib.maintainers; { + maintainers = [ benley ]; + }; - nodes.machine = { ... }: { - imports = [ ../modules/profiles/minimal.nix ]; + nodes.machine = + { ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; - services.hddfancontrol.enable = true; - services.hddfancontrol.disks = ["/dev/vda"]; - services.hddfancontrol.pwmPaths = ["/test/hwmon1/pwm1"]; - services.hddfancontrol.extraArgs = ["--pwm-start-value=32" - "--pwm-stop-value=0"]; + services.hddfancontrol.enable = true; + services.hddfancontrol.disks = [ "/dev/vda" ]; + services.hddfancontrol.pwmPaths = [ "/test/hwmon1/pwm1" ]; + services.hddfancontrol.extraArgs = [ + "--pwm-start-value=32" + "--pwm-stop-value=0" + ]; - systemd.services.hddfancontrol_fixtures = { - description = "Install test fixtures for hddfancontrol"; - serviceConfig = { - Type = "oneshot"; - }; - script = '' - mkdir -p /test/hwmon1 - echo 255 > /test/hwmon1/pwm1 - echo 2 > /test/hwmon1/pwm1_enable - ''; - wantedBy = ["hddfancontrol.service"]; - before = ["hddfancontrol.service"]; - }; + systemd.services.hddfancontrol_fixtures = { + description = "Install test fixtures for hddfancontrol"; + serviceConfig = { + Type = "oneshot"; + }; + script = '' + mkdir -p /test/hwmon1 + echo 255 > /test/hwmon1/pwm1 + echo 2 > /test/hwmon1/pwm1_enable + ''; + wantedBy = [ "hddfancontrol.service" ]; + before = [ "hddfancontrol.service" ]; + }; - systemd.services.hddfancontrol.serviceConfig.ReadWritePaths = "/test"; - }; + systemd.services.hddfancontrol.serviceConfig.ReadWritePaths = "/test"; + }; - # hddfancontrol.service will fail to start because qemu /dev/vda doesn't have - # any thermal interfaces, but it should ensure that fans appear to be running - # before it aborts. - testScript = '' - start_all() - machine.wait_for_unit("multi-user.target") - machine.succeed("journalctl -eu hddfancontrol.service|grep 'Setting fan speed'") - machine.shutdown() + # hddfancontrol.service will fail to start because qemu /dev/vda doesn't have + # any thermal interfaces, but it should ensure that fans appear to be running + # before it aborts. + testScript = '' + start_all() + machine.wait_for_unit("multi-user.target") + machine.succeed("journalctl -eu hddfancontrol.service|grep 'Setting fan speed'") + machine.shutdown() - ''; + ''; -}) + } +) diff --git a/nixos/tests/headscale.nix b/nixos/tests/headscale.nix index 15f7c7be2ae5f0..cb5ce26b7944e3 100644 --- a/nixos/tests/headscale.nix +++ b/nixos/tests/headscale.nix @@ -1,66 +1,72 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: let - tls-cert = - pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' - openssl req \ - -x509 -newkey rsa:4096 -sha256 -days 365 \ - -nodes -out cert.pem -keyout key.pem \ - -subj '/CN=headscale' -addext "subjectAltName=DNS:headscale" + tls-cert = pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' + openssl req \ + -x509 -newkey rsa:4096 -sha256 -days 365 \ + -nodes -out cert.pem -keyout key.pem \ + -subj '/CN=headscale' -addext "subjectAltName=DNS:headscale" - mkdir -p $out - cp key.pem cert.pem $out - ''; - in { + mkdir -p $out + cp key.pem cert.pem $out + ''; + in + { name = "headscale"; meta.maintainers = with lib.maintainers; [ misterio77 ]; - nodes = let - headscalePort = 8080; - stunPort = 3478; - peer = { - services.tailscale.enable = true; - security.pki.certificateFiles = [ "${tls-cert}/cert.pem" ]; - }; - in { - peer1 = peer; - peer2 = peer; + nodes = + let + headscalePort = 8080; + stunPort = 3478; + peer = { + services.tailscale.enable = true; + security.pki.certificateFiles = [ "${tls-cert}/cert.pem" ]; + }; + in + { + peer1 = peer; + peer2 = peer; - headscale = { - services = { - headscale = { - enable = true; - port = headscalePort; - settings = { - server_url = "https://headscale"; - ip_prefixes = [ "100.64.0.0/10" ]; - derp.server = { - enabled = true; - region_id = 999; - stun_listen_addr = "0.0.0.0:${toString stunPort}"; + headscale = { + services = { + headscale = { + enable = true; + port = headscalePort; + settings = { + server_url = "https://headscale"; + ip_prefixes = [ "100.64.0.0/10" ]; + derp.server = { + enabled = true; + region_id = 999; + stun_listen_addr = "0.0.0.0:${toString stunPort}"; + }; + dns.base_domain = "tailnet"; }; - dns.base_domain = "tailnet"; }; - }; - nginx = { - enable = true; - virtualHosts.headscale = { - addSSL = true; - sslCertificate = "${tls-cert}/cert.pem"; - sslCertificateKey = "${tls-cert}/key.pem"; - locations."/" = { - proxyPass = "http://127.0.0.1:${toString headscalePort}"; - proxyWebsockets = true; + nginx = { + enable = true; + virtualHosts.headscale = { + addSSL = true; + sslCertificate = "${tls-cert}/cert.pem"; + sslCertificateKey = "${tls-cert}/key.pem"; + locations."/" = { + proxyPass = "http://127.0.0.1:${toString headscalePort}"; + proxyWebsockets = true; + }; }; }; }; + networking.firewall = { + allowedTCPPorts = [ + 80 + 443 + ]; + allowedUDPPorts = [ stunPort ]; + }; + environment.systemPackages = [ pkgs.headscale ]; }; - networking.firewall = { - allowedTCPPorts = [ 80 443 ]; - allowedUDPPorts = [ stunPort ]; - }; - environment.systemPackages = [ pkgs.headscale ]; }; - }; testScript = '' start_all() @@ -80,4 +86,5 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: peer1.wait_until_succeeds("tailscale ping peer2") peer2.wait_until_succeeds("tailscale ping peer1.tailnet") ''; - }) + } +) diff --git a/nixos/tests/hedgedoc.nix b/nixos/tests/hedgedoc.nix index 16e0dc14e947b2..aa1be7421d5ef5 100644 --- a/nixos/tests/hedgedoc.nix +++ b/nixos/tests/hedgedoc.nix @@ -1,96 +1,104 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -{ - name = "hedgedoc"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "hedgedoc"; - meta = with lib.maintainers; { - maintainers = [ willibutz ]; - }; - - nodes = { - hedgedocSqlite = { ... }: { - services.hedgedoc.enable = true; + meta = with lib.maintainers; { + maintainers = [ willibutz ]; }; - hedgedocPostgresWithTCPSocket = { ... }: { - systemd.services.hedgedoc.after = [ "postgresql.service" ]; - services = { - hedgedoc = { - enable = true; - settings.db = { - dialect = "postgres"; - user = "hedgedoc"; - password = "$DB_PASSWORD"; - host = "localhost"; - port = 5432; - database = "hedgedocdb"; - }; - - /* - * Do not use pkgs.writeText for secrets as - * they will end up in the world-readable Nix store. - */ - environmentFile = pkgs.writeText "hedgedoc-env" '' - DB_PASSWORD=snakeoilpassword - ''; + nodes = { + hedgedocSqlite = + { ... }: + { + services.hedgedoc.enable = true; }; - postgresql = { - enable = true; - initialScript = pkgs.writeText "pg-init-script.sql" '' - CREATE ROLE hedgedoc LOGIN PASSWORD 'snakeoilpassword'; - CREATE DATABASE hedgedocdb OWNER hedgedoc; - ''; - }; - }; - }; - hedgedocPostgresWithUNIXSocket = { ... }: { - systemd.services.hedgedoc.after = [ "postgresql.service" ]; - services = { - hedgedoc = { - enable = true; - settings.db = { - dialect = "postgres"; - user = "hedgedoc"; - password = "$DB_PASSWORD"; - host = "/run/postgresql"; - database = "hedgedocdb"; - }; + hedgedocPostgresWithTCPSocket = + { ... }: + { + systemd.services.hedgedoc.after = [ "postgresql.service" ]; + services = { + hedgedoc = { + enable = true; + settings.db = { + dialect = "postgres"; + user = "hedgedoc"; + password = "$DB_PASSWORD"; + host = "localhost"; + port = 5432; + database = "hedgedocdb"; + }; - environmentFile = pkgs.writeText "hedgedoc-env" '' - DB_PASSWORD=snakeoilpassword - ''; + /* + Do not use pkgs.writeText for secrets as + they will end up in the world-readable Nix store. + */ + environmentFile = pkgs.writeText "hedgedoc-env" '' + DB_PASSWORD=snakeoilpassword + ''; + }; + postgresql = { + enable = true; + initialScript = pkgs.writeText "pg-init-script.sql" '' + CREATE ROLE hedgedoc LOGIN PASSWORD 'snakeoilpassword'; + CREATE DATABASE hedgedocdb OWNER hedgedoc; + ''; + }; + }; }; - postgresql = { - enable = true; - initialScript = pkgs.writeText "pg-init-script.sql" '' - CREATE ROLE hedgedoc LOGIN PASSWORD 'snakeoilpassword'; - CREATE DATABASE hedgedocdb OWNER hedgedoc; - ''; + + hedgedocPostgresWithUNIXSocket = + { ... }: + { + systemd.services.hedgedoc.after = [ "postgresql.service" ]; + services = { + hedgedoc = { + enable = true; + settings.db = { + dialect = "postgres"; + user = "hedgedoc"; + password = "$DB_PASSWORD"; + host = "/run/postgresql"; + database = "hedgedocdb"; + }; + + environmentFile = pkgs.writeText "hedgedoc-env" '' + DB_PASSWORD=snakeoilpassword + ''; + }; + postgresql = { + enable = true; + initialScript = pkgs.writeText "pg-init-script.sql" '' + CREATE ROLE hedgedoc LOGIN PASSWORD 'snakeoilpassword'; + CREATE DATABASE hedgedocdb OWNER hedgedoc; + ''; + }; + }; }; - }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - with subtest("HedgeDoc sqlite"): - hedgedocSqlite.wait_for_unit("hedgedoc.service") - hedgedocSqlite.wait_for_open_port(3000) - hedgedocSqlite.wait_until_succeeds("curl -sSf http://localhost:3000/new") + with subtest("HedgeDoc sqlite"): + hedgedocSqlite.wait_for_unit("hedgedoc.service") + hedgedocSqlite.wait_for_open_port(3000) + hedgedocSqlite.wait_until_succeeds("curl -sSf http://localhost:3000/new") - with subtest("HedgeDoc postgres with TCP socket"): - hedgedocPostgresWithTCPSocket.wait_for_unit("postgresql.service") - hedgedocPostgresWithTCPSocket.wait_for_unit("hedgedoc.service") - hedgedocPostgresWithTCPSocket.wait_for_open_port(5432) - hedgedocPostgresWithTCPSocket.wait_for_open_port(3000) - hedgedocPostgresWithTCPSocket.wait_until_succeeds("curl -sSf http://localhost:3000/new") + with subtest("HedgeDoc postgres with TCP socket"): + hedgedocPostgresWithTCPSocket.wait_for_unit("postgresql.service") + hedgedocPostgresWithTCPSocket.wait_for_unit("hedgedoc.service") + hedgedocPostgresWithTCPSocket.wait_for_open_port(5432) + hedgedocPostgresWithTCPSocket.wait_for_open_port(3000) + hedgedocPostgresWithTCPSocket.wait_until_succeeds("curl -sSf http://localhost:3000/new") - with subtest("HedgeDoc postgres with UNIX socket"): - hedgedocPostgresWithUNIXSocket.wait_for_unit("postgresql.service") - hedgedocPostgresWithUNIXSocket.wait_for_unit("hedgedoc.service") - hedgedocPostgresWithUNIXSocket.wait_for_open_port(5432) - hedgedocPostgresWithUNIXSocket.wait_for_open_port(3000) - hedgedocPostgresWithUNIXSocket.wait_until_succeeds("curl -sSf http://localhost:3000/new") - ''; -}) + with subtest("HedgeDoc postgres with UNIX socket"): + hedgedocPostgresWithUNIXSocket.wait_for_unit("postgresql.service") + hedgedocPostgresWithUNIXSocket.wait_for_unit("hedgedoc.service") + hedgedocPostgresWithUNIXSocket.wait_for_open_port(5432) + hedgedocPostgresWithUNIXSocket.wait_for_open_port(3000) + hedgedocPostgresWithUNIXSocket.wait_until_succeeds("curl -sSf http://localhost:3000/new") + ''; + } +) diff --git a/nixos/tests/herbstluftwm.nix b/nixos/tests/herbstluftwm.nix index 2a8b391947e745..84e6985803c37b 100644 --- a/nixos/tests/herbstluftwm.nix +++ b/nixos/tests/herbstluftwm.nix @@ -1,37 +1,45 @@ -import ./make-test-python.nix ({ lib, ...} : { - name = "herbstluftwm"; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "herbstluftwm"; - meta = { - maintainers = with lib.maintainers; [ thibautmarty ]; - }; + meta = { + maintainers = with lib.maintainers; [ thibautmarty ]; + }; - nodes.machine = { pkgs, lib, ... }: { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - services.displayManager.defaultSession = lib.mkForce "none+herbstluftwm"; - services.xserver.windowManager.herbstluftwm.enable = true; - environment.systemPackages = [ pkgs.dzen2 ]; # needed for upstream provided panel - }; + nodes.machine = + { pkgs, lib, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + services.displayManager.defaultSession = lib.mkForce "none+herbstluftwm"; + services.xserver.windowManager.herbstluftwm.enable = true; + environment.systemPackages = [ pkgs.dzen2 ]; # needed for upstream provided panel + }; - testScript = '' - with subtest("ensure x starts"): - machine.wait_for_x() - machine.wait_for_file("/home/alice/.Xauthority") - machine.succeed("xauth merge ~alice/.Xauthority") + testScript = '' + with subtest("ensure x starts"): + machine.wait_for_x() + machine.wait_for_file("/home/alice/.Xauthority") + machine.succeed("xauth merge ~alice/.Xauthority") - with subtest("ensure client is available"): - machine.succeed("herbstclient --version") + with subtest("ensure client is available"): + machine.succeed("herbstclient --version") - with subtest("ensure keybindings are set"): - machine.wait_until_succeeds("herbstclient list_keybinds | grep xterm") + with subtest("ensure keybindings are set"): + machine.wait_until_succeeds("herbstclient list_keybinds | grep xterm") - with subtest("ensure panel starts"): - machine.wait_for_window("dzen title") + with subtest("ensure panel starts"): + machine.wait_for_window("dzen title") - with subtest("ensure we can open a new terminal"): - machine.send_key("alt-ret") - machine.wait_for_window(r"alice.*?machine") - machine.sleep(2) - machine.screenshot("terminal") - ''; -}) + with subtest("ensure we can open a new terminal"): + machine.send_key("alt-ret") + machine.wait_for_window(r"alice.*?machine") + machine.sleep(2) + machine.screenshot("terminal") + ''; + } +) diff --git a/nixos/tests/hibernate.nix b/nixos/tests/hibernate.nix index 6de287f63e0817..1bd22923858793 100644 --- a/nixos/tests/hibernate.nix +++ b/nixos/tests/hibernate.nix @@ -1,9 +1,10 @@ # Test whether hibernation from partition works. -{ system ? builtins.currentSystem -, config ? {} -, pkgs ? import ../.. { inherit system config; } -, systemdStage1 ? false +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, + systemdStage1 ? false, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -12,21 +13,33 @@ makeTest { name = "hibernate"; nodes = { - machine = { config, lib, pkgs, ... }: { - imports = [ - ./common/auto-format-root-device.nix - ]; + machine = + { + config, + lib, + pkgs, + ... + }: + { + imports = [ + ./common/auto-format-root-device.nix + ]; - systemd.services.backdoor.conflicts = [ "sleep.target" ]; - powerManagement.resumeCommands = "systemctl --no-block restart backdoor.service"; + systemd.services.backdoor.conflicts = [ "sleep.target" ]; + powerManagement.resumeCommands = "systemctl --no-block restart backdoor.service"; - virtualisation.emptyDiskImages = [ (2 * config.virtualisation.memorySize) ]; - virtualisation.useNixStoreImage = true; + virtualisation.emptyDiskImages = [ (2 * config.virtualisation.memorySize) ]; + virtualisation.useNixStoreImage = true; - swapDevices = lib.mkOverride 0 [ { device = "/dev/vdc"; options = [ "x-systemd.makefs" ]; } ]; - boot.initrd.systemd.enable = systemdStage1; - virtualisation.useEFIBoot = true; - }; + swapDevices = lib.mkOverride 0 [ + { + device = "/dev/vdc"; + options = [ "x-systemd.makefs" ]; + } + ]; + boot.initrd.systemd.enable = systemdStage1; + virtualisation.useEFIBoot = true; + }; }; testScript = '' diff --git a/nixos/tests/hitch/default.nix b/nixos/tests/hitch/default.nix index 4283b9f7dffbe5..9d0386dac3d59b 100644 --- a/nixos/tests/hitch/default.nix +++ b/nixos/tests/hitch/default.nix @@ -1,28 +1,30 @@ -import ../make-test-python.nix ({ pkgs, ... }: -{ - name = "hitch"; - meta = with pkgs.lib.maintainers; { - maintainers = [ jflanglois ]; - }; - nodes.machine = { pkgs, ... }: { - environment.systemPackages = [ pkgs.curl ]; - services.hitch = { - enable = true; - backend = "[127.0.0.1]:80"; - pem-files = [ - ./example.pem - ]; +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "hitch"; + meta = with pkgs.lib.maintainers; { + maintainers = [ jflanglois ]; }; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.curl ]; + services.hitch = { + enable = true; + backend = "[127.0.0.1]:80"; + pem-files = [ + ./example.pem + ]; + }; - services.httpd = { - enable = true; - virtualHosts.localhost.documentRoot = ./example; - adminAddr = "noone@testing.nowhere"; - }; - }; + services.httpd = { + enable = true; + virtualHosts.localhost.documentRoot = ./example; + adminAddr = "noone@testing.nowhere"; + }; + }; - testScript = - '' + testScript = '' start_all() machine.wait_for_unit("multi-user.target") @@ -30,4 +32,5 @@ import ../make-test-python.nix ({ pkgs, ... }: machine.wait_for_open_port(443) assert "We are all good!" in machine.succeed("curl -fk https://localhost:443/index.txt") ''; -}) + } +) diff --git a/nixos/tests/hledger-web.nix b/nixos/tests/hledger-web.nix index 09941ca5c517c0..fcb3c7f656aa35 100644 --- a/nixos/tests/hledger-web.nix +++ b/nixos/tests/hledger-web.nix @@ -1,50 +1,56 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - journal = pkgs.writeText "test.journal" '' - 2010/01/10 Loan - assets:cash 500$ - income:loan -500$ - 2010/01/10 NixOS Foundation donation - expenses:donation 250$ - assets:cash -250$ - ''; -in -rec { - name = "hledger-web"; - meta.maintainers = with lib.maintainers; [ marijanp ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + journal = pkgs.writeText "test.journal" '' + 2010/01/10 Loan + assets:cash 500$ + income:loan -500$ + 2010/01/10 NixOS Foundation donation + expenses:donation 250$ + assets:cash -250$ + ''; + in + rec { + name = "hledger-web"; + meta.maintainers = with lib.maintainers; [ marijanp ]; - nodes = rec { - server = { config, pkgs, ... }: { - services.hledger-web = { - host = "127.0.0.1"; - port = 5000; - enable = true; - allow = "edit"; - }; - networking.firewall.allowedTCPPorts = [ config.services.hledger-web.port ]; - systemd.services.hledger-web.preStart = '' - ln -s ${journal} /var/lib/hledger-web/.hledger.journal - ''; + nodes = rec { + server = + { config, pkgs, ... }: + { + services.hledger-web = { + host = "127.0.0.1"; + port = 5000; + enable = true; + allow = "edit"; + }; + networking.firewall.allowedTCPPorts = [ config.services.hledger-web.port ]; + systemd.services.hledger-web.preStart = '' + ln -s ${journal} /var/lib/hledger-web/.hledger.journal + ''; + }; + apiserver = + { ... }: + { + imports = [ server ]; + services.hledger-web.serveApi = true; + }; }; - apiserver = { ... }: { - imports = [ server ]; - services.hledger-web.serveApi = true; - }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - server.wait_for_unit("hledger-web.service") - server.wait_for_open_port(5000) - with subtest("Check if web UI is accessible"): - page = server.succeed("curl -L http://127.0.0.1:5000") - assert ".hledger.journal" in page + server.wait_for_unit("hledger-web.service") + server.wait_for_open_port(5000) + with subtest("Check if web UI is accessible"): + page = server.succeed("curl -L http://127.0.0.1:5000") + assert ".hledger.journal" in page - apiserver.wait_for_unit("hledger-web.service") - apiserver.wait_for_open_port(5000) - with subtest("Check if the JSON API is served"): - transactions = apiserver.succeed("curl -L http://127.0.0.1:5000/transactions") - assert "NixOS Foundation donation" in transactions - ''; -}) + apiserver.wait_for_unit("hledger-web.service") + apiserver.wait_for_open_port(5000) + with subtest("Check if the JSON API is served"): + transactions = apiserver.succeed("curl -L http://127.0.0.1:5000/transactions") + assert "NixOS Foundation donation" in transactions + ''; + } +) diff --git a/nixos/tests/hockeypuck.nix b/nixos/tests/hockeypuck.nix index 675d6b226ad203..bc24ceb4b70ff2 100644 --- a/nixos/tests/hockeypuck.nix +++ b/nixos/tests/hockeypuck.nix @@ -1,63 +1,72 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -let - gpgKeyring = (pkgs.runCommand "gpg-keyring" { buildInputs = [ pkgs.gnupg ]; } '' - mkdir -p $out - export GNUPGHOME=$out - cat > foo <OpenPGP Keyserver" in response, "HTML title not found" - - # Copy the keyring - machine.succeed("cp -R ${gpgKeyring} /tmp/GNUPGHOME") - - # Extract our GPG key id - keyId = machine.succeed("GNUPGHOME=/tmp/GNUPGHOME gpg --list-keys | grep dsa1024 --after-context=1 | grep -v dsa1024").strip() - - # Send the key to our local keyserver - machine.succeed("GNUPGHOME=/tmp/GNUPGHOME gpg --keyserver hkp://127.0.0.1:11371 --send-keys " + keyId) - - # Receive the key from our local keyserver to a separate directory - machine.succeed("GNUPGHOME=$(mktemp -d) gpg --keyserver hkp://127.0.0.1:11371 --recv-keys " + keyId) - ''; -}) +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let + gpgKeyring = ( + pkgs.runCommand "gpg-keyring" { buildInputs = [ pkgs.gnupg ]; } '' + mkdir -p $out + export GNUPGHOME=$out + cat > foo <OpenPGP Keyserver" in response, "HTML title not found" + + # Copy the keyring + machine.succeed("cp -R ${gpgKeyring} /tmp/GNUPGHOME") + + # Extract our GPG key id + keyId = machine.succeed("GNUPGHOME=/tmp/GNUPGHOME gpg --list-keys | grep dsa1024 --after-context=1 | grep -v dsa1024").strip() + + # Send the key to our local keyserver + machine.succeed("GNUPGHOME=/tmp/GNUPGHOME gpg --keyserver hkp://127.0.0.1:11371 --send-keys " + keyId) + + # Receive the key from our local keyserver to a separate directory + machine.succeed("GNUPGHOME=$(mktemp -d) gpg --keyserver hkp://127.0.0.1:11371 --recv-keys " + keyId) + ''; + } +) diff --git a/nixos/tests/home-assistant.nix b/nixos/tests/home-assistant.nix index 7b4e67192f29b5..8d2acec1c9c031 100644 --- a/nixos/tests/home-assistant.nix +++ b/nixos/tests/home-assistant.nix @@ -5,244 +5,261 @@ let configDir = "/var/lib/foobar"; -in { +in +{ name = "home-assistant"; meta.maintainers = lib.teams.home-assistant.members; - nodes.hass = { pkgs, ... }: { - services.postgresql = { - enable = true; - ensureDatabases = [ "hass" ]; - ensureUsers = [{ - name = "hass"; - ensureDBOwnership = true; - }]; - }; + nodes.hass = + { pkgs, ... }: + { + services.postgresql = { + enable = true; + ensureDatabases = [ "hass" ]; + ensureUsers = [ + { + name = "hass"; + ensureDBOwnership = true; + } + ]; + }; - services.home-assistant = { - enable = true; - inherit configDir; + services.home-assistant = { + enable = true; + inherit configDir; + + # provide dependencies through package overrides + package = ( + pkgs.home-assistant.override { + extraPackages = + ps: with ps; [ + colorama + ]; + extraComponents = [ + # test char-tty device allow propagation into the service + "zha" + ]; + } + ); + + # provide component dependencies explicitly from the module + extraComponents = [ + "mqtt" + ]; - # provide dependencies through package overrides - package = (pkgs.home-assistant.override { - extraPackages = ps: with ps; [ - colorama + # provide package for postgresql support + extraPackages = + python3Packages: with python3Packages; [ + psycopg2 + ]; + + # test loading custom components + customComponents = with pkgs.home-assistant-custom-components; [ + prometheus_sensor + # tests loading multiple components from a single package + spook ]; - extraComponents = [ - # test char-tty device allow propagation into the service - "zha" - ]; - }); - - # provide component dependencies explicitly from the module - extraComponents = [ - "mqtt" - ]; - - # provide package for postgresql support - extraPackages = python3Packages: with python3Packages; [ - psycopg2 - ]; - - # test loading custom components - customComponents = with pkgs.home-assistant-custom-components; [ - prometheus_sensor - # tests loading multiple components from a single package - spook - ]; - - # test loading lovelace modules - customLovelaceModules = with pkgs.home-assistant-custom-lovelace-modules; [ - mini-graph-card - ]; - - config = { - homeassistant = { - name = "Home"; - time_zone = "UTC"; - latitude = "0.0"; - longitude = "0.0"; - elevation = 0; - }; - # configure the recorder component to use the postgresql db - recorder.db_url = "postgresql://@/hass"; - - # we can't load default_config, because the updater requires - # network access and would cause an error, so load frontend - # here explicitly. - # https://www.home-assistant.io/integrations/frontend/ - frontend = {}; - - # include some popular integrations, that absolutely shouldn't break - knx = {}; - shelly = {}; - zha = {}; - - # set up a wake-on-lan switch to test capset capability required - # for the ping suid wrapper - # https://www.home-assistant.io/integrations/wake_on_lan/ - switch = [ { - platform = "wake_on_lan"; - mac = "00:11:22:33:44:55"; - host = "127.0.0.1"; - } ]; - - # test component-based capability assignment (CAP_NET_BIND_SERVICE) - # https://www.home-assistant.io/integrations/emulated_hue/ - emulated_hue = { - host_ip = "127.0.0.1"; - listen_port = 80; + # test loading lovelace modules + customLovelaceModules = with pkgs.home-assistant-custom-lovelace-modules; [ + mini-graph-card + ]; + + config = { + homeassistant = { + name = "Home"; + time_zone = "UTC"; + latitude = "0.0"; + longitude = "0.0"; + elevation = 0; + }; + + # configure the recorder component to use the postgresql db + recorder.db_url = "postgresql://@/hass"; + + # we can't load default_config, because the updater requires + # network access and would cause an error, so load frontend + # here explicitly. + # https://www.home-assistant.io/integrations/frontend/ + frontend = { }; + + # include some popular integrations, that absolutely shouldn't break + knx = { }; + shelly = { }; + zha = { }; + + # set up a wake-on-lan switch to test capset capability required + # for the ping suid wrapper + # https://www.home-assistant.io/integrations/wake_on_lan/ + switch = [ + { + platform = "wake_on_lan"; + mac = "00:11:22:33:44:55"; + host = "127.0.0.1"; + } + ]; + + # test component-based capability assignment (CAP_NET_BIND_SERVICE) + # https://www.home-assistant.io/integrations/emulated_hue/ + emulated_hue = { + host_ip = "127.0.0.1"; + listen_port = 80; + }; + + # https://www.home-assistant.io/integrations/logger/ + logger = { + default = "info"; + }; }; - # https://www.home-assistant.io/integrations/logger/ - logger = { - default = "info"; + # configure the sample lovelace dashboard + lovelaceConfig = { + title = "My Awesome Home"; + views = [ + { + title = "Example"; + cards = [ + { + type = "markdown"; + title = "Lovelace"; + content = "Welcome to your **Lovelace UI**."; + } + ]; + } + ]; }; + lovelaceConfigWritable = true; }; - # configure the sample lovelace dashboard - lovelaceConfig = { - title = "My Awesome Home"; - views = [{ - title = "Example"; - cards = [{ - type = "markdown"; - title = "Lovelace"; - content = "Welcome to your **Lovelace UI**."; - }]; - }]; + # Cause a configuration change inside `configuration.yml` and verify that the process is being reloaded. + specialisation.differentName = { + inheritParentConfig = true; + configuration.services.home-assistant.config.homeassistant.name = lib.mkForce "Test Home"; }; - lovelaceConfigWritable = true; - }; - - # Cause a configuration change inside `configuration.yml` and verify that the process is being reloaded. - specialisation.differentName = { - inheritParentConfig = true; - configuration.services.home-assistant.config.homeassistant.name = lib.mkForce "Test Home"; - }; - # Cause a configuration change that requires a service restart as we added a new runtime dependency - specialisation.newFeature = { - inheritParentConfig = true; - configuration.services.home-assistant.config.prometheus = {}; - }; + # Cause a configuration change that requires a service restart as we added a new runtime dependency + specialisation.newFeature = { + inheritParentConfig = true; + configuration.services.home-assistant.config.prometheus = { }; + }; - specialisation.removeCustomThings = { - inheritParentConfig = true; - configuration.services.home-assistant = { - customComponents = lib.mkForce []; - customLovelaceModules = lib.mkForce []; + specialisation.removeCustomThings = { + inheritParentConfig = true; + configuration.services.home-assistant = { + customComponents = lib.mkForce [ ]; + customLovelaceModules = lib.mkForce [ ]; + }; }; }; - }; - testScript = { nodes, ... }: let - system = nodes.hass.system.build.toplevel; - in - '' - import json + testScript = + { nodes, ... }: + let + system = nodes.hass.system.build.toplevel; + in + '' + import json - start_all() + start_all() - def get_journal_cursor() -> str: - exit, out = hass.execute("journalctl -u home-assistant.service -n1 -o json-pretty --output-fields=__CURSOR") - assert exit == 0 - return json.loads(out)["__CURSOR"] + def get_journal_cursor() -> str: + exit, out = hass.execute("journalctl -u home-assistant.service -n1 -o json-pretty --output-fields=__CURSOR") + assert exit == 0 + return json.loads(out)["__CURSOR"] - def get_journal_since(cursor) -> str: - exit, out = hass.execute(f"journalctl --after-cursor='{cursor}' -u home-assistant.service") - assert exit == 0 - return out + def get_journal_since(cursor) -> str: + exit, out = hass.execute(f"journalctl --after-cursor='{cursor}' -u home-assistant.service") + assert exit == 0 + return out - def get_unit_property(property) -> str: - exit, out = hass.execute(f"systemctl show --property={property} home-assistant.service") - assert exit == 0 - return out + def get_unit_property(property) -> str: + exit, out = hass.execute(f"systemctl show --property={property} home-assistant.service") + assert exit == 0 + return out - def wait_for_homeassistant(cursor): - hass.wait_until_succeeds(f"journalctl --after-cursor='{cursor}' -u home-assistant.service | grep -q 'Home Assistant initialized in'") + def wait_for_homeassistant(cursor): + hass.wait_until_succeeds(f"journalctl --after-cursor='{cursor}' -u home-assistant.service | grep -q 'Home Assistant initialized in'") - hass.wait_for_unit("home-assistant.service") - cursor = get_journal_cursor() + hass.wait_for_unit("home-assistant.service") + cursor = get_journal_cursor() - with subtest("Check that YAML configuration file is in place"): - hass.succeed("test -L ${configDir}/configuration.yaml") + with subtest("Check that YAML configuration file is in place"): + hass.succeed("test -L ${configDir}/configuration.yaml") - with subtest("Check the lovelace config is copied because lovelaceConfigWritable = true"): - hass.succeed("test -f ${configDir}/ui-lovelace.yaml") + with subtest("Check the lovelace config is copied because lovelaceConfigWritable = true"): + hass.succeed("test -f ${configDir}/ui-lovelace.yaml") - with subtest("Check that Home Assistant's web interface and API can be reached"): - wait_for_homeassistant(cursor) - hass.wait_for_open_port(8123) - hass.succeed("curl --fail http://localhost:8123/lovelace") + with subtest("Check that Home Assistant's web interface and API can be reached"): + wait_for_homeassistant(cursor) + hass.wait_for_open_port(8123) + hass.succeed("curl --fail http://localhost:8123/lovelace") - with subtest("Check that custom components get installed"): - hass.succeed("test -f ${configDir}/custom_components/prometheus_sensor/manifest.json") - for integration in ("prometheus_sensor", "spook", "spook_inverse"): - hass.wait_until_succeeds(f"journalctl -u home-assistant.service | grep -q 'We found a custom integration {integration} which has not been tested by Home Assistant'") + with subtest("Check that custom components get installed"): + hass.succeed("test -f ${configDir}/custom_components/prometheus_sensor/manifest.json") + for integration in ("prometheus_sensor", "spook", "spook_inverse"): + hass.wait_until_succeeds(f"journalctl -u home-assistant.service | grep -q 'We found a custom integration {integration} which has not been tested by Home Assistant'") - with subtest("Check that lovelace modules are referenced and fetchable"): - hass.succeed("grep -q 'mini-graph-card-bundle.js' '${configDir}/configuration.yaml'") - hass.succeed("curl --fail http://localhost:8123/local/nixos-lovelace-modules/mini-graph-card-bundle.js") + with subtest("Check that lovelace modules are referenced and fetchable"): + hass.succeed("grep -q 'mini-graph-card-bundle.js' '${configDir}/configuration.yaml'") + hass.succeed("curl --fail http://localhost:8123/local/nixos-lovelace-modules/mini-graph-card-bundle.js") - with subtest("Check that optional dependencies are in the PYTHONPATH"): - env = get_unit_property("Environment") - python_path = env.split("PYTHONPATH=")[1].split()[0] - for package in ["colorama", "paho-mqtt", "psycopg2"]: - assert package in python_path, f"{package} not in PYTHONPATH" + with subtest("Check that optional dependencies are in the PYTHONPATH"): + env = get_unit_property("Environment") + python_path = env.split("PYTHONPATH=")[1].split()[0] + for package in ["colorama", "paho-mqtt", "psycopg2"]: + assert package in python_path, f"{package} not in PYTHONPATH" - with subtest("Check that declaratively configured components get setup"): - journal = get_journal_since(cursor) - for domain in ["emulated_hue", "wake_on_lan"]: - assert f"Setup of domain {domain} took" in journal, f"{domain} setup missing" + with subtest("Check that declaratively configured components get setup"): + journal = get_journal_since(cursor) + for domain in ["emulated_hue", "wake_on_lan"]: + assert f"Setup of domain {domain} took" in journal, f"{domain} setup missing" - with subtest("Check that capabilities are passed for emulated_hue to bind to port 80"): - hass.wait_for_open_port(80) - hass.succeed("curl --fail http://localhost:80/description.xml") + with subtest("Check that capabilities are passed for emulated_hue to bind to port 80"): + hass.wait_for_open_port(80) + hass.succeed("curl --fail http://localhost:80/description.xml") - with subtest("Check extra components are considered in systemd unit hardening"): - hass.succeed("systemctl show -p DeviceAllow home-assistant.service | grep -q char-ttyUSB") + with subtest("Check extra components are considered in systemd unit hardening"): + hass.succeed("systemctl show -p DeviceAllow home-assistant.service | grep -q char-ttyUSB") - with subtest("Check service restart from SIGHUP"): - pid = hass.succeed("systemctl show --property=MainPID home-assistant.service") - cursor = get_journal_cursor() - hass.succeed("${system}/specialisation/differentName/bin/switch-to-configuration test") - wait_for_homeassistant(cursor) - new_pid = hass.succeed("systemctl show --property=MainPID home-assistant.service") - assert pid != new_pid, "The PID of the process must change after sending SIGHUP" + with subtest("Check service restart from SIGHUP"): + pid = hass.succeed("systemctl show --property=MainPID home-assistant.service") + cursor = get_journal_cursor() + hass.succeed("${system}/specialisation/differentName/bin/switch-to-configuration test") + wait_for_homeassistant(cursor) + new_pid = hass.succeed("systemctl show --property=MainPID home-assistant.service") + assert pid != new_pid, "The PID of the process must change after sending SIGHUP" - with subtest("Check service restarts when dependencies change"): - pid = new_pid - cursor = get_journal_cursor() - hass.succeed("${system}/specialisation/newFeature/bin/switch-to-configuration test") - wait_for_homeassistant(cursor) - new_pid = hass.succeed("systemctl show --property=MainPID home-assistant.service") - assert pid != new_pid, "The PID of the process must change when its PYTHONPATH changess" + with subtest("Check service restarts when dependencies change"): + pid = new_pid + cursor = get_journal_cursor() + hass.succeed("${system}/specialisation/newFeature/bin/switch-to-configuration test") + wait_for_homeassistant(cursor) + new_pid = hass.succeed("systemctl show --property=MainPID home-assistant.service") + assert pid != new_pid, "The PID of the process must change when its PYTHONPATH changess" - with subtest("Check that new components get setup after restart"): - journal = get_journal_since(cursor) - for domain in ["prometheus"]: - assert f"Setup of domain {domain} took" in journal, f"{domain} setup missing" + with subtest("Check that new components get setup after restart"): + journal = get_journal_since(cursor) + for domain in ["prometheus"]: + assert f"Setup of domain {domain} took" in journal, f"{domain} setup missing" - with subtest("Check custom components and custom lovelace modules get removed"): - cursor = get_journal_cursor() - hass.succeed("${system}/specialisation/removeCustomThings/bin/switch-to-configuration test") - hass.fail("grep -q 'mini-graph-card-bundle.js' '${configDir}/ui-lovelace.yaml'") - for integration in ("prometheus_sensor", "spook", "spook_inverse"): - hass.fail(f"test -f ${configDir}/custom_components/{integration}/manifest.json") - wait_for_homeassistant(cursor) - - with subtest("Check that no errors were logged"): - hass.fail("journalctl -u home-assistant -o cat | grep -q ERROR") + with subtest("Check custom components and custom lovelace modules get removed"): + cursor = get_journal_cursor() + hass.succeed("${system}/specialisation/removeCustomThings/bin/switch-to-configuration test") + hass.fail("grep -q 'mini-graph-card-bundle.js' '${configDir}/ui-lovelace.yaml'") + for integration in ("prometheus_sensor", "spook", "spook_inverse"): + hass.fail(f"test -f ${configDir}/custom_components/{integration}/manifest.json") + wait_for_homeassistant(cursor) + + with subtest("Check that no errors were logged"): + hass.fail("journalctl -u home-assistant -o cat | grep -q ERROR") - with subtest("Check systemd unit hardening"): - hass.log(hass.succeed("systemctl cat home-assistant.service")) - hass.log(hass.succeed("systemd-analyze security home-assistant.service")) - ''; + with subtest("Check systemd unit hardening"): + hass.log(hass.succeed("systemctl cat home-assistant.service")) + hass.log(hass.succeed("systemd-analyze security home-assistant.service")) + ''; } diff --git a/nixos/tests/homepage-dashboard.nix b/nixos/tests/homepage-dashboard.nix index dd36473e8ac024..622c5a6e0d1a5a 100644 --- a/nixos/tests/homepage-dashboard.nix +++ b/nixos/tests/homepage-dashboard.nix @@ -1,36 +1,43 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "homepage-dashboard"; - meta.maintainers = with lib.maintainers; [ jnsgruk ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "homepage-dashboard"; + meta.maintainers = with lib.maintainers; [ jnsgruk ]; - nodes.unmanaged_conf = { pkgs, ... }: { - services.homepage-dashboard.enable = true; - }; + nodes.unmanaged_conf = + { pkgs, ... }: + { + services.homepage-dashboard.enable = true; + }; - nodes.managed_conf = { pkgs, ... }: { - services.homepage-dashboard = { - enable = true; - settings.title = "custom"; - }; - }; + nodes.managed_conf = + { pkgs, ... }: + { + services.homepage-dashboard = { + enable = true; + settings.title = "custom"; + }; + }; - testScript = '' - # Ensure the services are started on unmanaged machine - unmanaged_conf.wait_for_unit("homepage-dashboard.service") - unmanaged_conf.wait_for_open_port(8082) - unmanaged_conf.succeed("curl --fail http://localhost:8082/") + testScript = '' + # Ensure the services are started on unmanaged machine + unmanaged_conf.wait_for_unit("homepage-dashboard.service") + unmanaged_conf.wait_for_open_port(8082) + unmanaged_conf.succeed("curl --fail http://localhost:8082/") - # Ensure that /etc/homepage-dashboard doesn't exist, and boilerplate - # configs are copied into place. - unmanaged_conf.fail("test -d /etc/homepage-dashboard") - unmanaged_conf.succeed("test -f /var/lib/private/homepage-dashboard/settings.yaml") + # Ensure that /etc/homepage-dashboard doesn't exist, and boilerplate + # configs are copied into place. + unmanaged_conf.fail("test -d /etc/homepage-dashboard") + unmanaged_conf.succeed("test -f /var/lib/private/homepage-dashboard/settings.yaml") - # Ensure the services are started on managed machine - managed_conf.wait_for_unit("homepage-dashboard.service") - managed_conf.wait_for_open_port(8082) - managed_conf.succeed("curl --fail http://localhost:8082/") + # Ensure the services are started on managed machine + managed_conf.wait_for_unit("homepage-dashboard.service") + managed_conf.wait_for_open_port(8082) + managed_conf.succeed("curl --fail http://localhost:8082/") - # Ensure /etc/homepage-dashboard is created and unmanaged conf location isn't. - managed_conf.succeed("test -d /etc/homepage-dashboard") - managed_conf.fail("test -f /var/lib/private/homepage-dashboard/settings.yaml") - ''; -}) + # Ensure /etc/homepage-dashboard is created and unmanaged conf location isn't. + managed_conf.succeed("test -d /etc/homepage-dashboard") + managed_conf.fail("test -f /var/lib/private/homepage-dashboard/settings.yaml") + ''; + } +) diff --git a/nixos/tests/honk.nix b/nixos/tests/honk.nix index 71d86a5924393d..bc552f6dff40e0 100644 --- a/nixos/tests/honk.nix +++ b/nixos/tests/honk.nix @@ -4,16 +4,18 @@ name = "honk-server"; nodes = { - machine = { pkgs, ... }: { - services.honk = { - enable = true; - host = "0.0.0.0"; - port = 8080; - username = "username"; - passwordFile = "${pkgs.writeText "honk-password" "secure"}"; - servername = "servername"; + machine = + { pkgs, ... }: + { + services.honk = { + enable = true; + host = "0.0.0.0"; + port = 8080; + username = "username"; + passwordFile = "${pkgs.writeText "honk-password" "secure"}"; + servername = "servername"; + }; }; - }; }; testScript = '' diff --git a/nixos/tests/hound.nix b/nixos/tests/hound.nix index a9b036deb0dda8..75400eca232bda 100644 --- a/nixos/tests/hound.nix +++ b/nixos/tests/hound.nix @@ -1,59 +1,64 @@ # Test whether `houndd` indexes nixpkgs -import ./make-test-python.nix ({ pkgs, ... } : { - name = "hound"; - meta = with pkgs.lib.maintainers; { - maintainers = [ grahamc ]; - }; - nodes.machine = { pkgs, ... }: { - services.hound = { - enable = true; - config = '' - { - "max-concurrent-indexers": 1, - "dbpath": "/var/lib/hound/data", - "repos": { - "nix": { - "url": "file:///var/lib/hound/my-git" - } - } - } - ''; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "hound"; + meta = with pkgs.lib.maintainers; { + maintainers = [ grahamc ]; }; + nodes.machine = + { pkgs, ... }: + { + services.hound = { + enable = true; + config = '' + { + "max-concurrent-indexers": 1, + "dbpath": "/var/lib/hound/data", + "repos": { + "nix": { + "url": "file:///var/lib/hound/my-git" + } + } + } + ''; + }; - systemd.services.houndseed = { - description = "seed hound with a git repo"; - requiredBy = [ "hound.service" ]; - before = [ "hound.service" ]; + systemd.services.houndseed = { + description = "seed hound with a git repo"; + requiredBy = [ "hound.service" ]; + before = [ "hound.service" ]; - serviceConfig = { - User = "hound"; - Group = "hound"; - WorkingDirectory = "/var/lib/hound"; + serviceConfig = { + User = "hound"; + Group = "hound"; + WorkingDirectory = "/var/lib/hound"; + }; + path = [ pkgs.git ]; + script = '' + git config --global user.email "you@example.com" + git config --global user.name "Your Name" + git init my-git --bare + git init my-git-clone + cd my-git-clone + echo 'hi nix!' > hello + git add hello + git commit -m "hello there :)" + git remote add origin /var/lib/hound/my-git + git push origin master + ''; + }; }; - path = [ pkgs.git ]; - script = '' - git config --global user.email "you@example.com" - git config --global user.name "Your Name" - git init my-git --bare - git init my-git-clone - cd my-git-clone - echo 'hi nix!' > hello - git add hello - git commit -m "hello there :)" - git remote add origin /var/lib/hound/my-git - git push origin master - ''; - }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("network.target") - machine.wait_for_unit("hound.service") - machine.wait_for_open_port(6080) - machine.wait_until_succeeds( - "curl -f http://127.0.0.1:6080/api/v1/search\?stats\=fosho\&repos\=\*\&rng=%3A20\&q\=hi\&files\=\&i=nope | grep 'Filename' | grep 'hello'" - ) - ''; -}) + machine.wait_for_unit("network.target") + machine.wait_for_unit("hound.service") + machine.wait_for_open_port(6080) + machine.wait_until_succeeds( + "curl -f http://127.0.0.1:6080/api/v1/search\?stats\=fosho\&repos\=\*\&rng=%3A20\&q\=hi\&files\=\&i=nope | grep 'Filename' | grep 'hello'" + ) + ''; + } +) diff --git a/nixos/tests/hydra/common.nix b/nixos/tests/hydra/common.nix index f31518b1e2a20f..0e58e49b1bcdc1 100644 --- a/nixos/tests/hydra/common.nix +++ b/nixos/tests/hydra/common.nix @@ -1,41 +1,49 @@ { system, ... }: { - baseConfig = { pkgs, ... }: let - trivialJob = pkgs.writeTextDir "trivial.nix" '' - { trivial = builtins.derivation { - name = "trivial"; - system = "${system}"; - builder = "/bin/sh"; - allowSubstitutes = false; - preferLocalBuild = true; - args = ["-c" "echo success > $out; exit 0"]; - }; - } - ''; - - createTrivialProject = pkgs.stdenv.mkDerivation { - name = "create-trivial-project"; - dontUnpack = true; - nativeBuildInputs = [ pkgs.makeWrapper ]; - installPhase = "install -m755 -D ${./create-trivial-project.sh} $out/bin/create-trivial-project.sh"; - postFixup = '' - wrapProgram "$out/bin/create-trivial-project.sh" --prefix PATH ":" ${pkgs.lib.makeBinPath [ pkgs.curl ]} --set EXPR_PATH ${trivialJob} - ''; - }; - in { - virtualisation.memorySize = 2048; - time.timeZone = "UTC"; - environment.systemPackages = [ createTrivialProject pkgs.jq ]; - services.hydra = { - enable = true; - # Hydra needs those settings to start up, so we add something not harmfull. - hydraURL = "example.com"; - notificationSender = "example@example.com"; - extraConfig = '' - email_notification = 1 + baseConfig = + { pkgs, ... }: + let + trivialJob = pkgs.writeTextDir "trivial.nix" '' + { trivial = builtins.derivation { + name = "trivial"; + system = "${system}"; + builder = "/bin/sh"; + allowSubstitutes = false; + preferLocalBuild = true; + args = ["-c" "echo success > $out; exit 0"]; + }; + } ''; + + createTrivialProject = pkgs.stdenv.mkDerivation { + name = "create-trivial-project"; + dontUnpack = true; + nativeBuildInputs = [ pkgs.makeWrapper ]; + installPhase = "install -m755 -D ${./create-trivial-project.sh} $out/bin/create-trivial-project.sh"; + postFixup = '' + wrapProgram "$out/bin/create-trivial-project.sh" --prefix PATH ":" ${ + pkgs.lib.makeBinPath [ pkgs.curl ] + } --set EXPR_PATH ${trivialJob} + ''; + }; + in + { + virtualisation.memorySize = 2048; + time.timeZone = "UTC"; + environment.systemPackages = [ + createTrivialProject + pkgs.jq + ]; + services.hydra = { + enable = true; + # Hydra needs those settings to start up, so we add something not harmfull. + hydraURL = "example.com"; + notificationSender = "example@example.com"; + extraConfig = '' + email_notification = 1 + ''; + }; + services.postfix.enable = true; + nix.settings.substituters = [ ]; }; - services.postfix.enable = true; - nix.settings.substituters = []; - }; } diff --git a/nixos/tests/hydra/default.nix b/nixos/tests/hydra/default.nix index 0f5092f196538e..4016f881953976 100644 --- a/nixos/tests/hydra/default.nix +++ b/nixos/tests/hydra/default.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../../.. { inherit system config; }, }: with import ../../lib/testing-python.nix { inherit system pkgs; }; @@ -14,45 +15,50 @@ let inherit (pkgs) hydra; }; - makeHydraTest = with pkgs.lib; name: package: makeTest { - name = "hydra-${name}"; - meta = with pkgs.lib.maintainers; { - maintainers = [ lewo ]; - }; + makeHydraTest = + with pkgs.lib; + name: package: + makeTest { + name = "hydra-${name}"; + meta = with pkgs.lib.maintainers; { + maintainers = [ lewo ]; + }; - nodes.machine = { pkgs, lib, ... }: { - imports = [ baseConfig ]; - services.hydra = { inherit package; }; - }; + nodes.machine = + { pkgs, lib, ... }: + { + imports = [ baseConfig ]; + services.hydra = { inherit package; }; + }; - testScript = '' - # let the system boot up - machine.wait_for_unit("multi-user.target") - # test whether the database is running - machine.wait_for_unit("postgresql.service") - # test whether the actual hydra daemons are running - machine.wait_for_unit("hydra-init.service") - machine.require_unit_state("hydra-queue-runner.service") - machine.require_unit_state("hydra-evaluator.service") - machine.require_unit_state("hydra-notify.service") - - machine.succeed("hydra-create-user admin --role admin --password admin") - - # create a project with a trivial job - machine.wait_for_open_port(3000) - - # make sure the build as been successfully built - machine.succeed("create-trivial-project.sh") - - machine.wait_until_succeeds( - 'curl -L -s http://localhost:3000/build/1 -H "Accept: application/json" | jq .buildstatus | xargs test 0 -eq' - ) - - machine.wait_until_succeeds( - 'journalctl -eu hydra-notify.service -o cat | grep -q "sending mail notification to hydra@localhost"' - ) - ''; - }; + testScript = '' + # let the system boot up + machine.wait_for_unit("multi-user.target") + # test whether the database is running + machine.wait_for_unit("postgresql.service") + # test whether the actual hydra daemons are running + machine.wait_for_unit("hydra-init.service") + machine.require_unit_state("hydra-queue-runner.service") + machine.require_unit_state("hydra-evaluator.service") + machine.require_unit_state("hydra-notify.service") + + machine.succeed("hydra-create-user admin --role admin --password admin") + + # create a project with a trivial job + machine.wait_for_open_port(3000) + + # make sure the build as been successfully built + machine.succeed("create-trivial-project.sh") + + machine.wait_until_succeeds( + 'curl -L -s http://localhost:3000/build/1 -H "Accept: application/json" | jq .buildstatus | xargs test 0 -eq' + ) + + machine.wait_until_succeeds( + 'journalctl -eu hydra-notify.service -o cat | grep -q "sending mail notification to hydra@localhost"' + ) + ''; + }; in diff --git a/nixos/tests/i3wm.nix b/nixos/tests/i3wm.nix index c02ce86db8b203..9dfde33aff8a34 100644 --- a/nixos/tests/i3wm.nix +++ b/nixos/tests/i3wm.nix @@ -1,46 +1,56 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "i3wm"; - meta = with pkgs.lib.maintainers; { - maintainers = [ aszlig ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "i3wm"; + meta = with pkgs.lib.maintainers; { + maintainers = [ aszlig ]; + }; - nodes.machine = { lib, ... }: { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - services.displayManager.defaultSession = lib.mkForce "none+i3"; - services.xserver.windowManager.i3.enable = true; - }; + nodes.machine = + { lib, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + services.displayManager.defaultSession = lib.mkForce "none+i3"; + services.xserver.windowManager.i3.enable = true; + }; - testScript = { ... }: '' - with subtest("ensure x starts"): - machine.wait_for_x() - machine.wait_for_file("/home/alice/.Xauthority") - machine.succeed("xauth merge ~alice/.Xauthority") + testScript = + { ... }: + '' + with subtest("ensure x starts"): + machine.wait_for_x() + machine.wait_for_file("/home/alice/.Xauthority") + machine.succeed("xauth merge ~alice/.Xauthority") - with subtest("ensure we get first configuration window"): - machine.wait_for_window(r".*?first configuration.*?") - machine.sleep(2) - machine.screenshot("started") + with subtest("ensure we get first configuration window"): + machine.wait_for_window(r".*?first configuration.*?") + machine.sleep(2) + machine.screenshot("started") - with subtest("ensure we generate and save a config"): - # press return to indicate we want to gen a new config - machine.send_key("\n") - machine.sleep(2) - machine.screenshot("preconfig") - # press alt then return to indicate we want to use alt as our Mod key - machine.send_key("alt") - machine.send_key("\n") - machine.sleep(2) - # make sure the config file is created before we continue - machine.wait_for_file("/home/alice/.config/i3/config") - machine.screenshot("postconfig") - machine.sleep(2) + with subtest("ensure we generate and save a config"): + # press return to indicate we want to gen a new config + machine.send_key("\n") + machine.sleep(2) + machine.screenshot("preconfig") + # press alt then return to indicate we want to use alt as our Mod key + machine.send_key("alt") + machine.send_key("\n") + machine.sleep(2) + # make sure the config file is created before we continue + machine.wait_for_file("/home/alice/.config/i3/config") + machine.screenshot("postconfig") + machine.sleep(2) - with subtest("ensure we can open a new terminal"): - machine.send_key("alt-ret") - machine.sleep(2) - machine.wait_for_window(r"alice.*?machine") - machine.sleep(2) - machine.screenshot("terminal") - ''; -}) + with subtest("ensure we can open a new terminal"): + machine.send_key("alt-ret") + machine.sleep(2) + machine.wait_for_window(r"alice.*?machine") + machine.sleep(2) + machine.screenshot("terminal") + ''; + } +) diff --git a/nixos/tests/icingaweb2.nix b/nixos/tests/icingaweb2.nix index 9d05e9fe139044..2039fbcb2bcd85 100644 --- a/nixos/tests/icingaweb2.nix +++ b/nixos/tests/icingaweb2.nix @@ -1,71 +1,76 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "icingaweb2"; - meta = { - maintainers = pkgs.lib.teams.helsinki-systems.members; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "icingaweb2"; + meta = { + maintainers = pkgs.lib.teams.helsinki-systems.members; + }; - nodes = { - icingaweb2 = { config, pkgs, ... }: { - services.icingaweb2 = { - enable = true; + nodes = { + icingaweb2 = + { config, pkgs, ... }: + { + services.icingaweb2 = { + enable = true; - modulePackages = with pkgs.icingaweb2Modules; { - particles = theme-particles; - spring = theme-spring; - }; + modulePackages = with pkgs.icingaweb2Modules; { + particles = theme-particles; + spring = theme-spring; + }; - modules = { - doc.enable = true; - migrate.enable = true; - setup.enable = true; - test.enable = true; - translation.enable = true; - }; + modules = { + doc.enable = true; + migrate.enable = true; + setup.enable = true; + test.enable = true; + translation.enable = true; + }; - generalConfig = { - global = { - module_path = "${pkgs.icingaweb2}/modules"; - }; - }; + generalConfig = { + global = { + module_path = "${pkgs.icingaweb2}/modules"; + }; + }; - authentications = { - icingaweb = { - backend = "external"; - }; - }; + authentications = { + icingaweb = { + backend = "external"; + }; + }; - groupBackends = { - icingaweb = { - backend = "db"; - resource = "icingaweb_db"; - }; - }; + groupBackends = { + icingaweb = { + backend = "db"; + resource = "icingaweb_db"; + }; + }; - resources = { - # Not used, so no DB server needed - icingaweb_db = { - type = "db"; - db = "mysql"; - host = "localhost"; - username = "icingaweb2"; - password = "icingaweb2"; - dbname = "icingaweb2"; - }; - }; + resources = { + # Not used, so no DB server needed + icingaweb_db = { + type = "db"; + db = "mysql"; + host = "localhost"; + username = "icingaweb2"; + password = "icingaweb2"; + dbname = "icingaweb2"; + }; + }; - roles = { - Administrators = { - users = "*"; - permissions = "*"; + roles = { + Administrators = { + users = "*"; + permissions = "*"; + }; + }; }; }; - }; }; - }; - testScript = '' - start_all() - icingaweb2.wait_for_unit("multi-user.target") - icingaweb2.succeed("curl -sSf http://icingaweb2/authentication/login") - ''; -}) + testScript = '' + start_all() + icingaweb2.wait_for_unit("multi-user.target") + icingaweb2.succeed("curl -sSf http://icingaweb2/authentication/login") + ''; + } +) diff --git a/nixos/tests/ifm.nix b/nixos/tests/ifm.nix index 60901cb3f73719..a1bc8e23a8974f 100644 --- a/nixos/tests/ifm.nix +++ b/nixos/tests/ifm.nix @@ -1,36 +1,38 @@ -import ./make-test-python.nix ({ pkgs, ...} : +import ./make-test-python.nix ( + { pkgs, ... }: -{ - name = "ifm"; - meta = with pkgs.lib.maintainers; { - maintainers = [ litchipi ]; - }; + { + name = "ifm"; + meta = with pkgs.lib.maintainers; { + maintainers = [ litchipi ]; + }; - nodes = { - server = rec { - services.ifm = { - enable = true; - port = 9001; - dataDir = "/data"; - }; + nodes = { + server = rec { + services.ifm = { + enable = true; + port = 9001; + dataDir = "/data"; + }; - system.activationScripts.ifm-setup-dir = '' - mkdir -p ${services.ifm.dataDir} - chmod u+w,g+w,o+w ${services.ifm.dataDir} - ''; + system.activationScripts.ifm-setup-dir = '' + mkdir -p ${services.ifm.dataDir} + chmod u+w,g+w,o+w ${services.ifm.dataDir} + ''; + }; }; - }; - testScript = '' - start_all() - server.wait_for_unit("ifm.service") - server.wait_for_open_port(9001) - server.succeed("curl --fail http://localhost:9001") + testScript = '' + start_all() + server.wait_for_unit("ifm.service") + server.wait_for_open_port(9001) + server.succeed("curl --fail http://localhost:9001") - server.succeed("echo \"testfile\" > testfile && shasum testfile >> checksums") - server.succeed("curl --fail http://localhost:9001 -X POST -F \"api=upload\" -F \"dir=\" -F \"file=@testfile\" | grep \"OK\""); - server.succeed("rm testfile") - server.succeed("curl --fail http://localhost:9001 -X POST -F \"api=download\" -F \"filename=testfile\" -F \"dir=\" --output testfile"); - server.succeed("shasum testfile >> checksums && shasum --check checksums") - ''; -}) + server.succeed("echo \"testfile\" > testfile && shasum testfile >> checksums") + server.succeed("curl --fail http://localhost:9001 -X POST -F \"api=upload\" -F \"dir=\" -F \"file=@testfile\" | grep \"OK\""); + server.succeed("rm testfile") + server.succeed("curl --fail http://localhost:9001 -X POST -F \"api=download\" -F \"filename=testfile\" -F \"dir=\" --output testfile"); + server.succeed("shasum testfile >> checksums && shasum --check checksums") + ''; + } +) diff --git a/nixos/tests/iftop.nix b/nixos/tests/iftop.nix index 933f115a8a5ad3..3b4fedbbb94033 100644 --- a/nixos/tests/iftop.nix +++ b/nixos/tests/iftop.nix @@ -1,31 +1,33 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: -{ - name = "iftop"; - meta.maintainers = with lib.maintainers; [ ma27 ]; + { + name = "iftop"; + meta.maintainers = with lib.maintainers; [ ma27 ]; - nodes = { - withIftop = { - imports = [ ./common/user-account.nix ]; - programs.iftop.enable = true; + nodes = { + withIftop = { + imports = [ ./common/user-account.nix ]; + programs.iftop.enable = true; + }; + withoutIftop = { + imports = [ ./common/user-account.nix ]; + environment.systemPackages = [ pkgs.iftop ]; + }; }; - withoutIftop = { - imports = [ ./common/user-account.nix ]; - environment.systemPackages = [ pkgs.iftop ]; - }; - }; - testScript = '' - with subtest("machine with iftop enabled"): - withIftop.wait_for_unit("default.target") - # limit to eth1 (eth0 is the test driver's control interface) - # and don't try name lookups - withIftop.succeed("su -l alice -c 'iftop -t -s 1 -n -i eth1'") + testScript = '' + with subtest("machine with iftop enabled"): + withIftop.wait_for_unit("default.target") + # limit to eth1 (eth0 is the test driver's control interface) + # and don't try name lookups + withIftop.succeed("su -l alice -c 'iftop -t -s 1 -n -i eth1'") - with subtest("machine without iftop"): - withoutIftop.wait_for_unit("default.target") - # check that iftop is there but user alice lacks capabilitie - withoutIftop.succeed("iftop -t -s 1 -n -i eth1") - withoutIftop.fail("su -l alice -c 'iftop -t -s 1 -n -i eth1'") - ''; -}) + with subtest("machine without iftop"): + withoutIftop.wait_for_unit("default.target") + # check that iftop is there but user alice lacks capabilitie + withoutIftop.succeed("iftop -t -s 1 -n -i eth1") + withoutIftop.fail("su -l alice -c 'iftop -t -s 1 -n -i eth1'") + ''; + } +) diff --git a/nixos/tests/image-contents.nix b/nixos/tests/image-contents.nix index 858f7d8c68f40b..473032cec73e71 100644 --- a/nixos/tests/image-contents.nix +++ b/nixos/tests/image-contents.nix @@ -1,8 +1,9 @@ # Tests the contents attribute of nixos/lib/make-disk-image.nix # including its user, group, and mode attributes. -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -11,38 +12,42 @@ with pkgs.lib; with import common/ec2.nix { inherit makeTest pkgs; }; let - config = (import ../lib/eval-config.nix { - inherit system; - modules = [ - ../modules/testing/test-instrumentation.nix - ../modules/profiles/qemu-guest.nix - { - fileSystems."/".device = "/dev/disk/by-label/nixos"; - boot.loader.grub.device = "/dev/vda"; - boot.loader.timeout = 0; - } - ]; - }).config; - image = (import ../lib/make-disk-image.nix { - inherit pkgs config; - lib = pkgs.lib; - format = "qcow2"; - contents = [ - { - source = pkgs.writeText "testFile" "contents"; - target = "/testFile"; - user = "1234"; - group = "5678"; - mode = "755"; - } - { - source = ./.; - target = "/testDir"; - } - ]; - }) + "/nixos.qcow2"; + config = + (import ../lib/eval-config.nix { + inherit system; + modules = [ + ../modules/testing/test-instrumentation.nix + ../modules/profiles/qemu-guest.nix + { + fileSystems."/".device = "/dev/disk/by-label/nixos"; + boot.loader.grub.device = "/dev/vda"; + boot.loader.timeout = 0; + } + ]; + }).config; + image = + (import ../lib/make-disk-image.nix { + inherit pkgs config; + lib = pkgs.lib; + format = "qcow2"; + contents = [ + { + source = pkgs.writeText "testFile" "contents"; + target = "/testFile"; + user = "1234"; + group = "5678"; + mode = "755"; + } + { + source = ./.; + target = "/testDir"; + } + ]; + }) + + "/nixos.qcow2"; -in makeEc2Test { +in +makeEc2Test { name = "image-contents"; inherit image; userData = null; diff --git a/nixos/tests/incron.nix b/nixos/tests/incron.nix index d016360ba0ef81..adbea25b9bde9d 100644 --- a/nixos/tests/incron.nix +++ b/nixos/tests/incron.nix @@ -1,52 +1,55 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: - -{ - name = "incron"; - meta.maintainers = [ lib.maintainers.aanderse ]; - - nodes.machine = - { ... }: - { services.incron.enable = true; - services.incron.extraPackages = [ pkgs.coreutils ]; - services.incron.systab = '' - /test IN_CREATE,IN_MODIFY,IN_CLOSE_WRITE,IN_MOVED_FROM,IN_MOVED_TO echo "$@/$# $%" >> /root/incron.log - ''; - - # ensure the directory to be monitored exists before incron is started - systemd.tmpfiles.settings.incron-test = { - "/test".d = { }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + { + name = "incron"; + meta.maintainers = [ lib.maintainers.aanderse ]; + + nodes.machine = + { ... }: + { + services.incron.enable = true; + services.incron.extraPackages = [ pkgs.coreutils ]; + services.incron.systab = '' + /test IN_CREATE,IN_MODIFY,IN_CLOSE_WRITE,IN_MOVED_FROM,IN_MOVED_TO echo "$@/$# $%" >> /root/incron.log + ''; + + # ensure the directory to be monitored exists before incron is started + systemd.tmpfiles.settings.incron-test = { + "/test".d = { }; + }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("multi-user.target") - machine.wait_for_unit("incron.service") + machine.wait_for_unit("multi-user.target") + machine.wait_for_unit("incron.service") - machine.succeed("test -d /test") - # create some activity for incron to monitor - machine.succeed("touch /test/file") - machine.succeed("echo foo >> /test/file") - machine.succeed("mv /test/file /root") - machine.succeed("mv /root/file /test") + machine.succeed("test -d /test") + # create some activity for incron to monitor + machine.succeed("touch /test/file") + machine.succeed("echo foo >> /test/file") + machine.succeed("mv /test/file /root") + machine.succeed("mv /root/file /test") - machine.sleep(1) + machine.sleep(1) - # touch /test/file - machine.succeed("grep '/test/file IN_CREATE' /root/incron.log") + # touch /test/file + machine.succeed("grep '/test/file IN_CREATE' /root/incron.log") - # echo foo >> /test/file - machine.succeed("grep '/test/file IN_MODIFY' /root/incron.log") - machine.succeed("grep '/test/file IN_CLOSE_WRITE' /root/incron.log") + # echo foo >> /test/file + machine.succeed("grep '/test/file IN_MODIFY' /root/incron.log") + machine.succeed("grep '/test/file IN_CLOSE_WRITE' /root/incron.log") - # mv /test/file /root - machine.succeed("grep '/test/file IN_MOVED_FROM' /root/incron.log") + # mv /test/file /root + machine.succeed("grep '/test/file IN_MOVED_FROM' /root/incron.log") - # mv /root/file /test - machine.succeed("grep '/test/file IN_MOVED_TO' /root/incron.log") + # mv /root/file /test + machine.succeed("grep '/test/file IN_MOVED_TO' /root/incron.log") - # ensure something unexpected is not present - machine.fail("grep 'IN_OPEN' /root/incron.log") - ''; -}) + # ensure something unexpected is not present + machine.fail("grep 'IN_OPEN' /root/incron.log") + ''; + } +) diff --git a/nixos/tests/influxdb.nix b/nixos/tests/influxdb.nix index 03026f8404be5d..87b1192c3062f4 100644 --- a/nixos/tests/influxdb.nix +++ b/nixos/tests/influxdb.nix @@ -1,40 +1,45 @@ # This test runs influxdb and checks if influxdb is up and running -import ./make-test-python.nix ({ pkgs, ...} : { - name = "influxdb"; - meta = with pkgs.lib.maintainers; { - maintainers = [ offline ]; - }; - - nodes = { - one = { ... }: { - services.influxdb.enable = true; - environment.systemPackages = [ pkgs.httpie ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "influxdb"; + meta = with pkgs.lib.maintainers; { + maintainers = [ offline ]; }; - }; - testScript = '' - import shlex + nodes = { + one = + { ... }: + { + services.influxdb.enable = true; + environment.systemPackages = [ pkgs.httpie ]; + }; + }; + + testScript = '' + import shlex - start_all() + start_all() - one.wait_for_unit("influxdb.service") + one.wait_for_unit("influxdb.service") - # create database - one.succeed( - "curl -XPOST http://localhost:8086/query --data-urlencode 'q=CREATE DATABASE test'" - ) + # create database + one.succeed( + "curl -XPOST http://localhost:8086/query --data-urlencode 'q=CREATE DATABASE test'" + ) - # write some points and run simple query - out = one.succeed( - "curl -XPOST 'http://localhost:8086/write?db=test' --data-binary 'cpu_load_short,host=server01,region=us-west value=0.64 1434055562000000000'" - ) + # write some points and run simple query + out = one.succeed( + "curl -XPOST 'http://localhost:8086/write?db=test' --data-binary 'cpu_load_short,host=server01,region=us-west value=0.64 1434055562000000000'" + ) - qv = "SELECT value FROM cpu_load_short WHERE region='us-west'" - cmd = f'curl -GET "http://localhost:8086/query?db=test" --data-urlencode {shlex.quote("q="+ qv)}' - out = one.succeed(cmd) + qv = "SELECT value FROM cpu_load_short WHERE region='us-west'" + cmd = f'curl -GET "http://localhost:8086/query?db=test" --data-urlencode {shlex.quote("q="+ qv)}' + out = one.succeed(cmd) - assert "2015-06-11T20:46:02Z" in out - assert "0.64" in out - ''; -}) + assert "2015-06-11T20:46:02Z" in out + assert "0.64" in out + ''; + } +) diff --git a/nixos/tests/influxdb2.nix b/nixos/tests/influxdb2.nix index 1631ac1d940810..3646960c156908 100644 --- a/nixos/tests/influxdb2.nix +++ b/nixos/tests/influxdb2.nix @@ -1,225 +1,241 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "influxdb2"; - meta = with pkgs.lib.maintainers; { - maintainers = [ offline ]; - }; - - nodes.machine = { lib, ... }: { - environment.systemPackages = [ pkgs.influxdb2-cli ]; - # Make sure that the service is restarted immediately if tokens need to be rewritten - # without relying on any Restart=on-failure behavior - systemd.services.influxdb2.serviceConfig.RestartSec = 6000; - services.influxdb2.enable = true; - services.influxdb2.provision = { - enable = true; - initialSetup = { - organization = "default"; - bucket = "default"; - passwordFile = pkgs.writeText "admin-pw" "ExAmPl3PA55W0rD"; - tokenFile = pkgs.writeText "admin-token" "verysecureadmintoken"; - }; - organizations.someorg = { - buckets.somebucket = {}; - auths.sometoken = { - description = "some auth token"; - readBuckets = ["somebucket"]; - writeBuckets = ["somebucket"]; - }; - }; - users.someuser.passwordFile = pkgs.writeText "tmp-pw" "abcgoiuhaoga"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "influxdb2"; + meta = with pkgs.lib.maintainers; { + maintainers = [ offline ]; }; - specialisation.withModifications.configuration = { ... }: { - services.influxdb2.provision = { - organizations.someorg.buckets.somebucket.present = false; - organizations.someorg.auths.sometoken.present = false; - users.someuser.present = false; - - organizations.myorg = { - description = "Myorg description"; - buckets.mybucket = { - description = "Mybucket description"; + nodes.machine = + { lib, ... }: + { + environment.systemPackages = [ pkgs.influxdb2-cli ]; + # Make sure that the service is restarted immediately if tokens need to be rewritten + # without relying on any Restart=on-failure behavior + systemd.services.influxdb2.serviceConfig.RestartSec = 6000; + services.influxdb2.enable = true; + services.influxdb2.provision = { + enable = true; + initialSetup = { + organization = "default"; + bucket = "default"; + passwordFile = pkgs.writeText "admin-pw" "ExAmPl3PA55W0rD"; + tokenFile = pkgs.writeText "admin-token" "verysecureadmintoken"; }; - auths.mytoken = { - operator = true; - description = "operator token"; - tokenFile = pkgs.writeText "tmp-tok" "someusertoken"; + organizations.someorg = { + buckets.somebucket = { }; + auths.sometoken = { + description = "some auth token"; + readBuckets = [ "somebucket" ]; + writeBuckets = [ "somebucket" ]; + }; }; + users.someuser.passwordFile = pkgs.writeText "tmp-pw" "abcgoiuhaoga"; }; - users.myuser.passwordFile = pkgs.writeText "tmp-pw" "abcgoiuhaoga"; - }; - }; - - specialisation.withParentDelete.configuration = { ... }: { - services.influxdb2.provision = { - organizations.someorg.present = false; - # Deleting the parent implies: - #organizations.someorg.buckets.somebucket.present = false; - #organizations.someorg.auths.sometoken.present = false; - }; - }; - specialisation.withNewTokens.configuration = { ... }: { - services.influxdb2.provision = { - organizations.default = { - auths.operator = { - operator = true; - description = "new optoken"; - tokenFile = pkgs.writeText "tmp-tok" "newoptoken"; + specialisation.withModifications.configuration = + { ... }: + { + services.influxdb2.provision = { + organizations.someorg.buckets.somebucket.present = false; + organizations.someorg.auths.sometoken.present = false; + users.someuser.present = false; + + organizations.myorg = { + description = "Myorg description"; + buckets.mybucket = { + description = "Mybucket description"; + }; + auths.mytoken = { + operator = true; + description = "operator token"; + tokenFile = pkgs.writeText "tmp-tok" "someusertoken"; + }; + }; + users.myuser.passwordFile = pkgs.writeText "tmp-pw" "abcgoiuhaoga"; + }; }; - auths.allaccess = { - operator = true; - description = "new allaccess"; - tokenFile = pkgs.writeText "tmp-tok" "newallaccess"; + + specialisation.withParentDelete.configuration = + { ... }: + { + services.influxdb2.provision = { + organizations.someorg.present = false; + # Deleting the parent implies: + #organizations.someorg.buckets.somebucket.present = false; + #organizations.someorg.auths.sometoken.present = false; + }; }; - auths.specifics = { - description = "new specifics"; - readPermissions = ["users" "tasks"]; - writePermissions = ["tasks"]; - tokenFile = pkgs.writeText "tmp-tok" "newspecificstoken"; + + specialisation.withNewTokens.configuration = + { ... }: + { + services.influxdb2.provision = { + organizations.default = { + auths.operator = { + operator = true; + description = "new optoken"; + tokenFile = pkgs.writeText "tmp-tok" "newoptoken"; + }; + auths.allaccess = { + operator = true; + description = "new allaccess"; + tokenFile = pkgs.writeText "tmp-tok" "newallaccess"; + }; + auths.specifics = { + description = "new specifics"; + readPermissions = [ + "users" + "tasks" + ]; + writePermissions = [ "tasks" ]; + tokenFile = pkgs.writeText "tmp-tok" "newspecificstoken"; + }; + }; + }; }; - }; }; - }; - }; - - testScript = { nodes, ... }: - let - specialisations = "${nodes.machine.system.build.toplevel}/specialisation"; - tokenArg = "--token verysecureadmintoken"; - in '' - def assert_contains(haystack, needle): - if needle not in haystack: - print("The haystack that will cause the following exception is:") - print("---") - print(haystack) - print("---") - raise Exception(f"Expected string '{needle}' was not found") - - def assert_lacks(haystack, needle): - if needle in haystack: - print("The haystack that will cause the following exception is:") - print("---") - print(haystack, end="") - print("---") - raise Exception(f"Unexpected string '{needle}' was found") - - machine.wait_for_unit("influxdb2.service") - - machine.fail("curl --fail -X POST 'http://localhost:8086/api/v2/signin' -u admin:wrongpassword") - machine.succeed("curl --fail -X POST 'http://localhost:8086/api/v2/signin' -u admin:ExAmPl3PA55W0rD") - - out = machine.succeed("influx org list ${tokenArg}") - assert_contains(out, "default") - assert_lacks(out, "myorg") - assert_contains(out, "someorg") - - out = machine.succeed("influx bucket list ${tokenArg} --org default") - assert_contains(out, "default") - - machine.fail("influx bucket list ${tokenArg} --org myorg") - - out = machine.succeed("influx bucket list ${tokenArg} --org someorg") - assert_contains(out, "somebucket") - - out = machine.succeed("influx user list ${tokenArg}") - assert_contains(out, "admin") - assert_lacks(out, "myuser") - assert_contains(out, "someuser") - - out = machine.succeed("influx auth list ${tokenArg}") - assert_lacks(out, "operator token") - assert_contains(out, "some auth token") - - with subtest("withModifications"): - machine.succeed('${specialisations}/withModifications/bin/switch-to-configuration test') - machine.wait_for_unit("influxdb2.service") - out = machine.succeed("influx org list ${tokenArg}") - assert_contains(out, "default") - assert_contains(out, "myorg") - assert_contains(out, "someorg") - - out = machine.succeed("influx bucket list ${tokenArg} --org myorg") - assert_contains(out, "mybucket") + testScript = + { nodes, ... }: + let + specialisations = "${nodes.machine.system.build.toplevel}/specialisation"; + tokenArg = "--token verysecureadmintoken"; + in + '' + def assert_contains(haystack, needle): + if needle not in haystack: + print("The haystack that will cause the following exception is:") + print("---") + print(haystack) + print("---") + raise Exception(f"Expected string '{needle}' was not found") + + def assert_lacks(haystack, needle): + if needle in haystack: + print("The haystack that will cause the following exception is:") + print("---") + print(haystack, end="") + print("---") + raise Exception(f"Unexpected string '{needle}' was found") - out = machine.succeed("influx bucket list ${tokenArg} --org someorg") - assert_lacks(out, "somebucket") - - out = machine.succeed("influx user list ${tokenArg}") - assert_contains(out, "admin") - assert_contains(out, "myuser") - assert_lacks(out, "someuser") - - out = machine.succeed("influx auth list ${tokenArg}") - assert_contains(out, "operator token") - assert_lacks(out, "some auth token") - - # Make sure the user token is also usable - machine.succeed("influx auth list --token someusertoken") - - with subtest("keepsUnrelated"): - machine.succeed('${nodes.machine.system.build.toplevel}/bin/switch-to-configuration test') machine.wait_for_unit("influxdb2.service") + machine.fail("curl --fail -X POST 'http://localhost:8086/api/v2/signin' -u admin:wrongpassword") + machine.succeed("curl --fail -X POST 'http://localhost:8086/api/v2/signin' -u admin:ExAmPl3PA55W0rD") + out = machine.succeed("influx org list ${tokenArg}") assert_contains(out, "default") - assert_contains(out, "myorg") + assert_lacks(out, "myorg") assert_contains(out, "someorg") out = machine.succeed("influx bucket list ${tokenArg} --org default") assert_contains(out, "default") - out = machine.succeed("influx bucket list ${tokenArg} --org myorg") - assert_contains(out, "mybucket") + machine.fail("influx bucket list ${tokenArg} --org myorg") out = machine.succeed("influx bucket list ${tokenArg} --org someorg") assert_contains(out, "somebucket") out = machine.succeed("influx user list ${tokenArg}") assert_contains(out, "admin") - assert_contains(out, "myuser") + assert_lacks(out, "myuser") assert_contains(out, "someuser") out = machine.succeed("influx auth list ${tokenArg}") - assert_contains(out, "operator token") + assert_lacks(out, "operator token") assert_contains(out, "some auth token") - with subtest("withParentDelete"): - machine.succeed('${specialisations}/withParentDelete/bin/switch-to-configuration test') - machine.wait_for_unit("influxdb2.service") + with subtest("withModifications"): + machine.succeed('${specialisations}/withModifications/bin/switch-to-configuration test') + machine.wait_for_unit("influxdb2.service") - out = machine.succeed("influx org list ${tokenArg}") - assert_contains(out, "default") - assert_contains(out, "myorg") - assert_lacks(out, "someorg") + out = machine.succeed("influx org list ${tokenArg}") + assert_contains(out, "default") + assert_contains(out, "myorg") + assert_contains(out, "someorg") - out = machine.succeed("influx bucket list ${tokenArg} --org default") - assert_contains(out, "default") + out = machine.succeed("influx bucket list ${tokenArg} --org myorg") + assert_contains(out, "mybucket") - out = machine.succeed("influx bucket list ${tokenArg} --org myorg") - assert_contains(out, "mybucket") + out = machine.succeed("influx bucket list ${tokenArg} --org someorg") + assert_lacks(out, "somebucket") - machine.fail("influx bucket list ${tokenArg} --org someorg") + out = machine.succeed("influx user list ${tokenArg}") + assert_contains(out, "admin") + assert_contains(out, "myuser") + assert_lacks(out, "someuser") - out = machine.succeed("influx user list ${tokenArg}") - assert_contains(out, "admin") - assert_contains(out, "myuser") - assert_contains(out, "someuser") + out = machine.succeed("influx auth list ${tokenArg}") + assert_contains(out, "operator token") + assert_lacks(out, "some auth token") - out = machine.succeed("influx auth list ${tokenArg}") - assert_contains(out, "operator token") - assert_lacks(out, "some auth token") + # Make sure the user token is also usable + machine.succeed("influx auth list --token someusertoken") - with subtest("withNewTokens"): - machine.succeed('${specialisations}/withNewTokens/bin/switch-to-configuration test') - machine.wait_for_unit("influxdb2.service") + with subtest("keepsUnrelated"): + machine.succeed('${nodes.machine.system.build.toplevel}/bin/switch-to-configuration test') + machine.wait_for_unit("influxdb2.service") - out = machine.succeed("influx auth list ${tokenArg}") - assert_contains(out, "operator token") - assert_contains(out, "some auth token") - assert_contains(out, "new optoken") - assert_contains(out, "new allaccess") - assert_contains(out, "new specifics") - ''; -}) + out = machine.succeed("influx org list ${tokenArg}") + assert_contains(out, "default") + assert_contains(out, "myorg") + assert_contains(out, "someorg") + + out = machine.succeed("influx bucket list ${tokenArg} --org default") + assert_contains(out, "default") + + out = machine.succeed("influx bucket list ${tokenArg} --org myorg") + assert_contains(out, "mybucket") + + out = machine.succeed("influx bucket list ${tokenArg} --org someorg") + assert_contains(out, "somebucket") + + out = machine.succeed("influx user list ${tokenArg}") + assert_contains(out, "admin") + assert_contains(out, "myuser") + assert_contains(out, "someuser") + + out = machine.succeed("influx auth list ${tokenArg}") + assert_contains(out, "operator token") + assert_contains(out, "some auth token") + + with subtest("withParentDelete"): + machine.succeed('${specialisations}/withParentDelete/bin/switch-to-configuration test') + machine.wait_for_unit("influxdb2.service") + + out = machine.succeed("influx org list ${tokenArg}") + assert_contains(out, "default") + assert_contains(out, "myorg") + assert_lacks(out, "someorg") + + out = machine.succeed("influx bucket list ${tokenArg} --org default") + assert_contains(out, "default") + + out = machine.succeed("influx bucket list ${tokenArg} --org myorg") + assert_contains(out, "mybucket") + + machine.fail("influx bucket list ${tokenArg} --org someorg") + + out = machine.succeed("influx user list ${tokenArg}") + assert_contains(out, "admin") + assert_contains(out, "myuser") + assert_contains(out, "someuser") + + out = machine.succeed("influx auth list ${tokenArg}") + assert_contains(out, "operator token") + assert_lacks(out, "some auth token") + + with subtest("withNewTokens"): + machine.succeed('${specialisations}/withNewTokens/bin/switch-to-configuration test') + machine.wait_for_unit("influxdb2.service") + + out = machine.succeed("influx auth list ${tokenArg}") + assert_contains(out, "operator token") + assert_contains(out, "some auth token") + assert_contains(out, "new optoken") + assert_contains(out, "new allaccess") + assert_contains(out, "new specifics") + ''; + } +) diff --git a/nixos/tests/initrd-luks-empty-passphrase.nix b/nixos/tests/initrd-luks-empty-passphrase.nix index a846c120415d9f..2b981e009f7929 100644 --- a/nixos/tests/initrd-luks-empty-passphrase.nix +++ b/nixos/tests/initrd-luks-empty-passphrase.nix @@ -1,105 +1,113 @@ -{ system ? builtins.currentSystem -, config ? {} -, pkgs ? import ../.. {inherit system config; } -, systemdStage1 ? false }: -import ./make-test-python.nix ({ lib, pkgs, ... }: let +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, + systemdStage1 ? false, +}: +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let - keyfile = pkgs.writeText "luks-keyfile" '' - MIGHAoGBAJ4rGTSo/ldyjQypd0kuS7k2OSsmQYzMH6TNj3nQ/vIUjDn7fqa3slt2 - gV6EK3TmTbGc4tzC1v4SWx2m+2Bjdtn4Fs4wiBwn1lbRdC6i5ZYCqasTWIntWn+6 - FllUkMD5oqjOR/YcboxG8Z3B5sJuvTP9llsF+gnuveWih9dpbBr7AgEC - ''; + keyfile = pkgs.writeText "luks-keyfile" '' + MIGHAoGBAJ4rGTSo/ldyjQypd0kuS7k2OSsmQYzMH6TNj3nQ/vIUjDn7fqa3slt2 + gV6EK3TmTbGc4tzC1v4SWx2m+2Bjdtn4Fs4wiBwn1lbRdC6i5ZYCqasTWIntWn+6 + FllUkMD5oqjOR/YcboxG8Z3B5sJuvTP9llsF+gnuveWih9dpbBr7AgEC + ''; -in { - name = "initrd-luks-empty-passphrase"; + in + { + name = "initrd-luks-empty-passphrase"; - nodes.machine = { pkgs, ... }: { - imports = lib.optionals (!systemdStage1) [ ./common/auto-format-root-device.nix ]; + nodes.machine = + { pkgs, ... }: + { + imports = lib.optionals (!systemdStage1) [ ./common/auto-format-root-device.nix ]; - virtualisation = { - emptyDiskImages = [ 512 ]; - useBootLoader = true; - useEFIBoot = true; - # This requires to have access - # to a host Nix store as - # the new root device is /dev/vdb - # an empty 512MiB drive, containing no Nix store. - mountHostNixStore = true; - fileSystems."/".autoFormat = lib.mkIf systemdStage1 true; - }; + virtualisation = { + emptyDiskImages = [ 512 ]; + useBootLoader = true; + useEFIBoot = true; + # This requires to have access + # to a host Nix store as + # the new root device is /dev/vdb + # an empty 512MiB drive, containing no Nix store. + mountHostNixStore = true; + fileSystems."/".autoFormat = lib.mkIf systemdStage1 true; + }; - boot.loader.systemd-boot.enable = true; - boot.initrd.systemd = lib.mkIf systemdStage1 { - enable = true; - emergencyAccess = true; - }; - environment.systemPackages = with pkgs; [ cryptsetup ]; + boot.loader.systemd-boot.enable = true; + boot.initrd.systemd = lib.mkIf systemdStage1 { + enable = true; + emergencyAccess = true; + }; + environment.systemPackages = with pkgs; [ cryptsetup ]; - specialisation.boot-luks-wrong-keyfile.configuration = { - boot.initrd.luks.devices = lib.mkVMOverride { - cryptroot = { - device = "/dev/vdb"; - keyFile = "/etc/cryptroot.key"; - tryEmptyPassphrase = true; - fallbackToPassword = !systemdStage1; + specialisation.boot-luks-wrong-keyfile.configuration = { + boot.initrd.luks.devices = lib.mkVMOverride { + cryptroot = { + device = "/dev/vdb"; + keyFile = "/etc/cryptroot.key"; + tryEmptyPassphrase = true; + fallbackToPassword = !systemdStage1; + }; + }; + virtualisation.rootDevice = "/dev/mapper/cryptroot"; + boot.initrd.secrets."/etc/cryptroot.key" = keyfile; }; - }; - virtualisation.rootDevice = "/dev/mapper/cryptroot"; - boot.initrd.secrets."/etc/cryptroot.key" = keyfile; - }; - specialisation.boot-luks-missing-keyfile.configuration = { - boot.initrd.luks.devices = lib.mkVMOverride { - cryptroot = { - device = "/dev/vdb"; - keyFile = "/etc/cryptroot.key"; - tryEmptyPassphrase = true; - fallbackToPassword = !systemdStage1; + specialisation.boot-luks-missing-keyfile.configuration = { + boot.initrd.luks.devices = lib.mkVMOverride { + cryptroot = { + device = "/dev/vdb"; + keyFile = "/etc/cryptroot.key"; + tryEmptyPassphrase = true; + fallbackToPassword = !systemdStage1; + }; + }; + virtualisation.rootDevice = "/dev/mapper/cryptroot"; }; }; - virtualisation.rootDevice = "/dev/mapper/cryptroot"; - }; - }; - testScript = '' - # Encrypt key with empty key so boot should try keyfile and then fallback to empty passphrase + testScript = '' + # Encrypt key with empty key so boot should try keyfile and then fallback to empty passphrase - def grub_select_boot_luks_wrong_key_file(): - """ - Selects "boot-luks" from the GRUB menu - to trigger a login request. - """ - machine.send_monitor_command("sendkey down") - machine.send_monitor_command("sendkey down") - machine.send_monitor_command("sendkey ret") + def grub_select_boot_luks_wrong_key_file(): + """ + Selects "boot-luks" from the GRUB menu + to trigger a login request. + """ + machine.send_monitor_command("sendkey down") + machine.send_monitor_command("sendkey down") + machine.send_monitor_command("sendkey ret") - def grub_select_boot_luks_missing_key_file(): - """ - Selects "boot-luks" from the GRUB menu - to trigger a login request. - """ - machine.send_monitor_command("sendkey down") - machine.send_monitor_command("sendkey ret") + def grub_select_boot_luks_missing_key_file(): + """ + Selects "boot-luks" from the GRUB menu + to trigger a login request. + """ + machine.send_monitor_command("sendkey down") + machine.send_monitor_command("sendkey ret") - # Create encrypted volume - machine.wait_for_unit("multi-user.target") - machine.succeed("echo "" | cryptsetup luksFormat /dev/vdb --batch-mode") - machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks-wrong-keyfile.conf") - machine.succeed("sync") - machine.crash() + # Create encrypted volume + machine.wait_for_unit("multi-user.target") + machine.succeed("echo "" | cryptsetup luksFormat /dev/vdb --batch-mode") + machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks-wrong-keyfile.conf") + machine.succeed("sync") + machine.crash() - # Check if rootfs is on /dev/mapper/cryptroot - machine.wait_for_unit("multi-user.target") - assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") + # Check if rootfs is on /dev/mapper/cryptroot + machine.wait_for_unit("multi-user.target") + assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") - # Choose boot-luks-missing-keyfile specialisation - machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks-missing-keyfile.conf") - machine.succeed("sync") - machine.crash() + # Choose boot-luks-missing-keyfile specialisation + machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks-missing-keyfile.conf") + machine.succeed("sync") + machine.crash() - # Check if rootfs is on /dev/mapper/cryptroot - machine.wait_for_unit("multi-user.target") - assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") - ''; -}) + # Check if rootfs is on /dev/mapper/cryptroot + machine.wait_for_unit("multi-user.target") + assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") + ''; + } +) diff --git a/nixos/tests/initrd-network-openvpn/default.nix b/nixos/tests/initrd-network-openvpn/default.nix index 69db7dd1037f74..f685e46dc467b3 100644 --- a/nixos/tests/initrd-network-openvpn/default.nix +++ b/nixos/tests/initrd-network-openvpn/default.nix @@ -1,132 +1,136 @@ -{ system ? builtins.currentSystem -, config ? {} -, pkgs ? import ../.. { inherit system config; } -, systemdStage1 ? false +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, + systemdStage1 ? false, }: -import ../make-test-python.nix ({ lib, ...}: +import ../make-test-python.nix ( + { lib, ... }: -{ - name = "initrd-network-openvpn"; - - nodes = - let - - # Inlining of the shared secret for the - # OpenVPN server and client - secretblock = '' - secret [inline] - - ${lib.readFile ./shared.key} - + { + name = "initrd-network-openvpn"; + + nodes = + let + + # Inlining of the shared secret for the + # OpenVPN server and client + secretblock = '' + secret [inline] + + ${lib.readFile ./shared.key} + ''; - in - { - - # Minimal test case to check a successful boot, even with invalid config - minimalboot = - { ... }: - { - boot.initrd.systemd.enable = systemdStage1; - boot.initrd.network = { - enable = true; - openvpn = { + in + { + + # Minimal test case to check a successful boot, even with invalid config + minimalboot = + { ... }: + { + boot.initrd.systemd.enable = systemdStage1; + boot.initrd.network = { enable = true; - configuration = builtins.toFile "initrd.ovpn" ""; + openvpn = { + enable = true; + configuration = builtins.toFile "initrd.ovpn" ""; + }; }; }; - }; - - # initrd VPN client - ovpnclient = - { ... }: - { - virtualisation.useBootLoader = true; - virtualisation.vlans = [ 1 ]; - - boot.initrd = { - systemd.enable = systemdStage1; - systemd.extraBin.nc = "${pkgs.busybox}/bin/nc"; - systemd.services.nc = { - requiredBy = ["initrd.target"]; - after = ["network.target"]; - serviceConfig = { - ExecStart = "/bin/nc -p 1234 -lke /bin/echo TESTVALUE"; - Type = "oneshot"; + + # initrd VPN client + ovpnclient = + { ... }: + { + virtualisation.useBootLoader = true; + virtualisation.vlans = [ 1 ]; + + boot.initrd = { + systemd.enable = systemdStage1; + systemd.extraBin.nc = "${pkgs.busybox}/bin/nc"; + systemd.services.nc = { + requiredBy = [ "initrd.target" ]; + after = [ "network.target" ]; + serviceConfig = { + ExecStart = "/bin/nc -p 1234 -lke /bin/echo TESTVALUE"; + Type = "oneshot"; + }; }; - }; - # This command does not fork to keep the VM in the state where - # only the initramfs is loaded - preLVMCommands = lib.mkIf (!systemdStage1) - '' + # This command does not fork to keep the VM in the state where + # only the initramfs is loaded + preLVMCommands = lib.mkIf (!systemdStage1) '' /bin/nc -p 1234 -lke /bin/echo TESTVALUE ''; - network = { - enable = true; + network = { + enable = true; - # Work around udhcpc only getting a lease on eth0 - postCommands = lib.mkIf (!systemdStage1) - '' + # Work around udhcpc only getting a lease on eth0 + postCommands = lib.mkIf (!systemdStage1) '' /bin/ip addr add 192.168.1.2/24 dev eth1 ''; - # Example configuration for OpenVPN - # This is the main reason for this test - openvpn = { - enable = true; - configuration = "${./initrd.ovpn}"; + # Example configuration for OpenVPN + # This is the main reason for this test + openvpn = { + enable = true; + configuration = "${./initrd.ovpn}"; + }; }; }; }; - }; - - # VPN server and gateway for ovpnclient between vlan 1 and 2 - ovpnserver = - { ... }: - { - virtualisation.vlans = [ 1 2 ]; - - # Enable NAT and forward port 12345 to port 1234 - networking.nat = { - enable = true; - internalInterfaces = [ "tun0" ]; - externalInterface = "eth2"; - forwardPorts = [ { destination = "10.8.0.2:1234"; - sourcePort = 12345; } ]; - }; - # Trust tun0 and allow the VPN Server to be reached - networking.firewall = { - trustedInterfaces = [ "tun0" ]; - allowedUDPPorts = [ 1194 ]; + # VPN server and gateway for ovpnclient between vlan 1 and 2 + ovpnserver = + { ... }: + { + virtualisation.vlans = [ + 1 + 2 + ]; + + # Enable NAT and forward port 12345 to port 1234 + networking.nat = { + enable = true; + internalInterfaces = [ "tun0" ]; + externalInterface = "eth2"; + forwardPorts = [ + { + destination = "10.8.0.2:1234"; + sourcePort = 12345; + } + ]; + }; + + # Trust tun0 and allow the VPN Server to be reached + networking.firewall = { + trustedInterfaces = [ "tun0" ]; + allowedUDPPorts = [ 1194 ]; + }; + + # Minimal OpenVPN server configuration + services.openvpn.servers.testserver = { + config = '' + dev tun0 + ifconfig 10.8.0.1 10.8.0.2 + cipher AES-256-CBC + ${secretblock} + ''; + }; }; - # Minimal OpenVPN server configuration - services.openvpn.servers.testserver = + # Client that resides in the "external" VLAN + testclient = + { ... }: { - config = '' - dev tun0 - ifconfig 10.8.0.1 10.8.0.2 - cipher AES-256-CBC - ${secretblock} - ''; + virtualisation.vlans = [ 2 ]; }; - }; - - # Client that resides in the "external" VLAN - testclient = - { ... }: - { - virtualisation.vlans = [ 2 ]; - }; - }; - + }; - testScript = - '' + testScript = '' # Minimal test case, checks whether enabling (with invalid config) harms # the boot process with subtest("Check for successful boot with broken openvpn config"): @@ -162,4 +166,5 @@ import ../make-test-python.nix ({ lib, ...}: # Check that ovpnclient is reachable from testclient over the gateway testclient.succeed("nc -w 2 192.168.2.3 12345 | grep -q TESTVALUE") ''; -}) + } +) diff --git a/nixos/tests/initrd-network-ssh/default.nix b/nixos/tests/initrd-network-ssh/default.nix index 17b6c21ff1e995..c67ead716e0f30 100644 --- a/nixos/tests/initrd-network-ssh/default.nix +++ b/nixos/tests/initrd-network-ssh/default.nix @@ -1,73 +1,76 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: +import ../make-test-python.nix ( + { lib, pkgs, ... }: -{ - name = "initrd-network-ssh"; - meta.maintainers = with lib.maintainers; [ willibutz emily ]; + { + name = "initrd-network-ssh"; + meta.maintainers = with lib.maintainers; [ + willibutz + emily + ]; - nodes = { - server = - { config, ... }: - { - boot.kernelParams = [ - "ip=${config.networking.primaryIPAddress}:::255.255.255.0::eth1:none" - ]; - boot.initrd.network = { - enable = true; - ssh = { + nodes = { + server = + { config, ... }: + { + boot.kernelParams = [ + "ip=${config.networking.primaryIPAddress}:::255.255.255.0::eth1:none" + ]; + boot.initrd.network = { enable = true; - authorizedKeys = [ (lib.readFile ./id_ed25519.pub) ]; - port = 22; - hostKeys = [ ./ssh_host_ed25519_key ]; + ssh = { + enable = true; + authorizedKeys = [ (lib.readFile ./id_ed25519.pub) ]; + port = 22; + hostKeys = [ ./ssh_host_ed25519_key ]; + }; }; + boot.initrd.preLVMCommands = '' + while true; do + if [ -f fnord ]; then + poweroff + fi + sleep 1 + done + ''; }; - boot.initrd.preLVMCommands = '' - while true; do - if [ -f fnord ]; then - poweroff - fi - sleep 1 - done - ''; - }; - client = - { config, ... }: - { - environment.etc = { - knownHosts = { - text = lib.concatStrings [ - "server," - "${toString (lib.head (lib.splitString " " ( - toString (lib.elemAt (lib.splitString "\n" config.networking.extraHosts) 2) - )))} " - "${lib.readFile ./ssh_host_ed25519_key.pub}" - ]; - }; - sshKey = { - source = ./id_ed25519; - mode = "0600"; + client = + { config, ... }: + { + environment.etc = { + knownHosts = { + text = lib.concatStrings [ + "server," + "${toString (lib.head (lib.splitString " " (toString (lib.elemAt (lib.splitString "\n" config.networking.extraHosts) 2))))} " + "${lib.readFile ./ssh_host_ed25519_key.pub}" + ]; + }; + sshKey = { + source = ./id_ed25519; + mode = "0600"; + }; }; }; - }; - }; + }; - testScript = '' - start_all() - client.wait_for_unit("network.target") + testScript = '' + start_all() + client.wait_for_unit("network.target") - def ssh_is_up(_) -> bool: - status, _ = client.execute("nc -z server 22") - return status == 0 + def ssh_is_up(_) -> bool: + status, _ = client.execute("nc -z server 22") + return status == 0 - with client.nested("waiting for SSH server to come up"): - retry(ssh_is_up) + with client.nested("waiting for SSH server to come up"): + retry(ssh_is_up) - client.succeed( - "ssh -i /etc/sshKey -o UserKnownHostsFile=/etc/knownHosts server 'touch /fnord'" - ) - client.shutdown() - ''; -}) + client.succeed( + "ssh -i /etc/sshKey -o UserKnownHostsFile=/etc/knownHosts server 'touch /fnord'" + ) + client.shutdown() + ''; + } +) diff --git a/nixos/tests/initrd-network-ssh/generate-keys.nix b/nixos/tests/initrd-network-ssh/generate-keys.nix index 3d7978890ab08a..b82a79ce5e2ea8 100644 --- a/nixos/tests/initrd-network-ssh/generate-keys.nix +++ b/nixos/tests/initrd-network-ssh/generate-keys.nix @@ -1,6 +1,7 @@ -with import ../../.. {}; +with import ../../.. { }; -runCommand "gen-keys" { +runCommand "gen-keys" + { buildInputs = [ openssh ]; } '' diff --git a/nixos/tests/initrd-network.nix b/nixos/tests/initrd-network.nix index abbc3d0fce822b..7e86f7f87075f2 100644 --- a/nixos/tests/initrd-network.nix +++ b/nixos/tests/initrd-network.nix @@ -1,33 +1,35 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : { - name = "initrd-network"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "initrd-network"; - meta.maintainers = [ ]; + meta.maintainers = [ ]; - nodes.machine = { ... }: { - imports = [ ../modules/profiles/minimal.nix ]; - boot.initrd.network.enable = true; - boot.initrd.network.postCommands = - '' - ip addr show - ip route show - ip addr | grep 10.0.2.15 || exit 1 - ping -c1 10.0.2.2 || exit 1 - ''; - # Check if cleanup was done correctly - boot.initrd.postMountCommands = lib.mkAfter - '' - ip addr show - ip route show - ip addr | grep 10.0.2.15 && exit 1 - ping -c1 10.0.2.2 && exit 1 - ''; - }; + nodes.machine = + { ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; + boot.initrd.network.enable = true; + boot.initrd.network.postCommands = '' + ip addr show + ip route show + ip addr | grep 10.0.2.15 || exit 1 + ping -c1 10.0.2.2 || exit 1 + ''; + # Check if cleanup was done correctly + boot.initrd.postMountCommands = lib.mkAfter '' + ip addr show + ip route show + ip addr | grep 10.0.2.15 && exit 1 + ping -c1 10.0.2.2 && exit 1 + ''; + }; - testScript = - '' + testScript = '' start_all() machine.wait_for_unit("multi-user.target") machine.succeed("ip addr show >&2") machine.succeed("ip route show >&2") ''; -}) + } +) diff --git a/nixos/tests/initrd-secrets-changing.nix b/nixos/tests/initrd-secrets-changing.nix index d6f9ef9ced83a5..1fa71a28872f06 100644 --- a/nixos/tests/initrd-secrets-changing.nix +++ b/nixos/tests/initrd-secrets-changing.nix @@ -1,8 +1,9 @@ -{ system ? builtins.currentSystem -, config ? {} -, pkgs ? import ../.. { inherit system config; } -, lib ? pkgs.lib -, testing ? import ../lib/testing-python.nix { inherit system pkgs; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, + lib ? pkgs.lib, + testing ? import ../lib/testing-python.nix { inherit system pkgs; }, }: let @@ -13,24 +14,26 @@ in testing.makeTest { name = "initrd-secrets-changing"; - nodes.machine = { ... }: { - virtualisation.useBootLoader = true; + nodes.machine = + { ... }: + { + virtualisation.useBootLoader = true; - boot.loader.grub.device = "/dev/vda"; + boot.loader.grub.device = "/dev/vda"; - boot.initrd.secrets = { - "/test" = secret1InStore; - "/run/keys/test" = secret1InStore; - }; - boot.initrd.postMountCommands = "cp /test /mnt-root/secret-from-initramfs"; + boot.initrd.secrets = { + "/test" = secret1InStore; + "/run/keys/test" = secret1InStore; + }; + boot.initrd.postMountCommands = "cp /test /mnt-root/secret-from-initramfs"; - specialisation.secrets2System.configuration = { - boot.initrd.secrets = lib.mkForce { - "/test" = secret2InStore; - "/run/keys/test" = secret2InStore; + specialisation.secrets2System.configuration = { + boot.initrd.secrets = lib.mkForce { + "/test" = secret2InStore; + "/run/keys/test" = secret2InStore; + }; }; }; - }; testScript = '' start_all() diff --git a/nixos/tests/initrd-secrets.nix b/nixos/tests/initrd-secrets.nix index dbbdd835884918..6a506a1fb0b4e1 100644 --- a/nixos/tests/initrd-secrets.nix +++ b/nixos/tests/initrd-secrets.nix @@ -1,41 +1,55 @@ -{ system ? builtins.currentSystem -, config ? {} -, pkgs ? import ../.. { inherit system config; } -, lib ? pkgs.lib -, testing ? import ../lib/testing-python.nix { inherit system pkgs; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, + lib ? pkgs.lib, + testing ? import ../lib/testing-python.nix { inherit system pkgs; }, }: let secretInStore = pkgs.writeText "topsecret" "iamasecret"; - testWithCompressor = compressor: testing.makeTest { - name = "initrd-secrets-${compressor}"; + testWithCompressor = + compressor: + testing.makeTest { + name = "initrd-secrets-${compressor}"; - meta.maintainers = [ ]; + meta.maintainers = [ ]; - nodes.machine = { ... }: { - virtualisation.useBootLoader = true; - boot.initrd.secrets = { - "/test" = secretInStore; + nodes.machine = + { ... }: + { + virtualisation.useBootLoader = true; + boot.initrd.secrets = { + "/test" = secretInStore; - # This should *not* need to be copied in postMountCommands - "/run/keys/test" = secretInStore; - }; - boot.initrd.postMountCommands = '' - cp /test /mnt-root/secret-from-initramfs + # This should *not* need to be copied in postMountCommands + "/run/keys/test" = secretInStore; + }; + boot.initrd.postMountCommands = '' + cp /test /mnt-root/secret-from-initramfs + ''; + boot.initrd.compressor = compressor; + # zstd compression is only supported from 5.9 onwards. Remove when 5.10 becomes default. + boot.kernelPackages = pkgs.linuxPackages_latest; + }; + + testScript = '' + start_all() + machine.wait_for_unit("multi-user.target") + machine.succeed( + "cmp ${secretInStore} /secret-from-initramfs", + "cmp ${secretInStore} /run/keys/test", + ) ''; - boot.initrd.compressor = compressor; - # zstd compression is only supported from 5.9 onwards. Remove when 5.10 becomes default. - boot.kernelPackages = pkgs.linuxPackages_latest; }; - - testScript = '' - start_all() - machine.wait_for_unit("multi-user.target") - machine.succeed( - "cmp ${secretInStore} /secret-from-initramfs", - "cmp ${secretInStore} /run/keys/test", - ) - ''; - }; -in lib.flip lib.genAttrs testWithCompressor [ - "cat" "gzip" "bzip2" "xz" "lzma" "lzop" "pigz" "pixz" "zstd" +in +lib.flip lib.genAttrs testWithCompressor [ + "cat" + "gzip" + "bzip2" + "xz" + "lzma" + "lzop" + "pigz" + "pixz" + "zstd" ] diff --git a/nixos/tests/input-remapper.nix b/nixos/tests/input-remapper.nix index 2ef55a01b2905d..4937274aa6926b 100644 --- a/nixos/tests/input-remapper.nix +++ b/nixos/tests/input-remapper.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: { name = "input-remapper"; @@ -6,8 +7,11 @@ import ./make-test-python.nix ({ pkgs, ... }: maintainers = with pkgs.lib.maintainers; [ LunNova ]; }; - nodes.machine = { config, ... }: - let user = config.users.users.sybil; in + nodes.machine = + { config, ... }: + let + user = config.users.users.sybil; + in { imports = [ ./common/user-account.nix @@ -16,7 +20,10 @@ import ./make-test-python.nix ({ pkgs, ... }: services.xserver.enable = true; services.input-remapper.enable = true; - users.users.sybil = { isNormalUser = true; group = "wheel"; }; + users.users.sybil = { + isNormalUser = true; + group = "wheel"; + }; test-support.displayManager.auto.user = user.name; # workaround for pkexec not working in the test environment # Error creating textual authentication agent: @@ -26,28 +33,33 @@ import ./make-test-python.nix ({ pkgs, ... }: # to allow the program to run, we replace pkexec with sudo # and turn on passwordless sudo # this is not correct in general but good enough for this test - security.sudo = { enable = true; wheelNeedsPassword = false; }; - security.wrappers.pkexec = pkgs.lib.mkForce - { - setuid = true; - owner = "root"; - group = "root"; - source = "${pkgs.sudo}/bin/sudo"; - }; + security.sudo = { + enable = true; + wheelNeedsPassword = false; + }; + security.wrappers.pkexec = pkgs.lib.mkForce { + setuid = true; + owner = "root"; + group = "root"; + source = "${pkgs.sudo}/bin/sudo"; + }; }; enableOCR = true; - testScript = { nodes, ... }: '' - start_all() - machine.wait_for_x() + testScript = + { nodes, ... }: + '' + start_all() + machine.wait_for_x() - machine.succeed("systemctl status input-remapper.service") - machine.execute("su - sybil -c input-remapper-gtk >&2 &") + machine.succeed("systemctl status input-remapper.service") + machine.execute("su - sybil -c input-remapper-gtk >&2 &") - machine.wait_for_text("Input Remapper") - machine.wait_for_text("Device") - machine.wait_for_text("Presets") - machine.wait_for_text("Editor") - ''; - }) + machine.wait_for_text("Input Remapper") + machine.wait_for_text("Device") + machine.wait_for_text("Presets") + machine.wait_for_text("Editor") + ''; + } +) diff --git a/nixos/tests/inspircd.nix b/nixos/tests/inspircd.nix index f4d82054011cbb..b3dc09dd752161 100644 --- a/nixos/tests/inspircd.nix +++ b/nixos/tests/inspircd.nix @@ -9,85 +9,96 @@ let iiDir = "/tmp/irc"; in -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "inspircd"; - nodes = { - "${server}" = { - networking.firewall.allowedTCPPorts = [ ircPort ]; - services.inspircd = { - enable = true; - package = pkgs.inspircdMinimal; - config = '' - - - ''; - }; - }; - } // lib.listToAttrs (builtins.map (client: lib.nameValuePair client { - imports = [ - ./common/user-account.nix - ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "inspircd"; + nodes = + { + "${server}" = { + networking.firewall.allowedTCPPorts = [ ircPort ]; + services.inspircd = { + enable = true; + package = pkgs.inspircdMinimal; + config = '' + + + ''; + }; + }; + } + // lib.listToAttrs ( + builtins.map ( + client: + lib.nameValuePair client { + imports = [ + ./common/user-account.nix + ]; - systemd.services.ii = { - requires = [ "network.target" ]; - wantedBy = [ "default.target" ]; + systemd.services.ii = { + requires = [ "network.target" ]; + wantedBy = [ "default.target" ]; - serviceConfig = { - Type = "simple"; - ExecPreStartPre = "mkdir -p ${iiDir}"; - ExecStart = '' - ${lib.getBin pkgs.ii}/bin/ii -n ${client} -s ${server} -i ${iiDir} - ''; - User = "alice"; - }; - }; - }) clients); + serviceConfig = { + Type = "simple"; + ExecPreStartPre = "mkdir -p ${iiDir}"; + ExecStart = '' + ${lib.getBin pkgs.ii}/bin/ii -n ${client} -s ${server} -i ${iiDir} + ''; + User = "alice"; + }; + }; + } + ) clients + ); - testScript = - let - msg = client: "Hello, my name is ${client}"; - clientScript = client: [ - '' - ${client}.wait_for_unit("network.target") - ${client}.systemctl("start ii") - ${client}.wait_for_unit("ii") - ${client}.wait_for_file("${iiDir}/${server}/out") - '' - # wait until first PING from server arrives before joining, - # so we don't try it too early - '' - ${client}.wait_until_succeeds("grep 'PING' ${iiDir}/${server}/out") - '' - # join ${channel} - '' - ${client}.succeed("echo '/j #${channel}' > ${iiDir}/${server}/in") - ${client}.wait_for_file("${iiDir}/${server}/#${channel}/in") - '' - # send a greeting - '' - ${client}.succeed( - "echo '${msg client}' > ${iiDir}/${server}/#${channel}/in" - ) - '' - # check that all greetings arrived on all clients - ] ++ builtins.map (other: '' - ${client}.succeed( - "grep '${msg other}$' ${iiDir}/${server}/#${channel}/out" - ) - '') clients; + testScript = + let + msg = client: "Hello, my name is ${client}"; + clientScript = + client: + [ + '' + ${client}.wait_for_unit("network.target") + ${client}.systemctl("start ii") + ${client}.wait_for_unit("ii") + ${client}.wait_for_file("${iiDir}/${server}/out") + '' + # wait until first PING from server arrives before joining, + # so we don't try it too early + '' + ${client}.wait_until_succeeds("grep 'PING' ${iiDir}/${server}/out") + '' + # join ${channel} + '' + ${client}.succeed("echo '/j #${channel}' > ${iiDir}/${server}/in") + ${client}.wait_for_file("${iiDir}/${server}/#${channel}/in") + '' + # send a greeting + '' + ${client}.succeed( + "echo '${msg client}' > ${iiDir}/${server}/#${channel}/in" + ) + '' + # check that all greetings arrived on all clients + ] + ++ builtins.map (other: '' + ${client}.succeed( + "grep '${msg other}$' ${iiDir}/${server}/#${channel}/out" + ) + '') clients; - # foldl', but requires a non-empty list instead of a start value - reduce = f: list: - builtins.foldl' f (builtins.head list) (builtins.tail list); - in '' - start_all() - ${server}.wait_for_open_port(${toString ircPort}) + # foldl', but requires a non-empty list instead of a start value + reduce = f: list: builtins.foldl' f (builtins.head list) (builtins.tail list); + in + '' + start_all() + ${server}.wait_for_open_port(${toString ircPort}) - # run clientScript for all clients so that every list - # entry is executed by every client before advancing - # to the next one. - '' + lib.concatStrings - (reduce - (lib.zipListsWith (cs: c: cs + c)) - (builtins.map clientScript clients)); -}) + # run clientScript for all clients so that every list + # entry is executed by every client before advancing + # to the next one. + '' + + lib.concatStrings (reduce (lib.zipListsWith (cs: c: cs + c)) (builtins.map clientScript clients)); + } +) diff --git a/nixos/tests/installed-tests/default.nix b/nixos/tests/installed-tests/default.nix index b1ddfe3dcbd800..f2cb02e66929fe 100644 --- a/nixos/tests/installed-tests/default.nix +++ b/nixos/tests/installed-tests/default.nix @@ -1,9 +1,10 @@ # NixOS tests for gnome-desktop-testing-runner using software # See https://github.com/NixOS/nixpkgs/issues/34987 -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../../.. { inherit system config; }, }: with import ../../lib/testing-python.nix { inherit system pkgs; }; @@ -14,99 +15,104 @@ let callInstalledTest = pkgs.newScope { inherit makeInstalledTest; }; makeInstalledTest = - { # Package to test. Needs to have an installedTests output - tested + { + # Package to test. Needs to have an installedTests output + tested, # Config to inject into machine - , testConfig ? {} + testConfig ? { }, # Test script snippet to inject before gnome-desktop-testing-runner begins. # This is useful for extra setup the environment may need before the runner begins. - , preTestScript ? "" + preTestScript ? "", # Does test need X11? - , withX11 ? false + withX11 ? false, # Extra flags to pass to gnome-desktop-testing-runner. - , testRunnerFlags ? [] + testRunnerFlags ? [ ], # Extra attributes to pass to makeTest. # They will be recursively merged into the attrset created by this function. - , ... + ... }@args: - makeTest - (recursiveUpdate + makeTest ( + recursiveUpdate rec { name = tested.name; meta = { - maintainers = tested.meta.maintainers or []; + maintainers = tested.meta.maintainers or [ ]; }; - nodes.machine = { ... }: { - imports = [ - testConfig - ] ++ optional withX11 ../common/x11.nix; + nodes.machine = + { ... }: + { + imports = [ + testConfig + ] ++ optional withX11 ../common/x11.nix; - environment.systemPackages = with pkgs; [ gnome-desktop-testing ]; + environment.systemPackages = with pkgs; [ gnome-desktop-testing ]; - # The installed tests need to be added to the test VM’s closure. - # Otherwise, their dependencies might not actually be registered - # as valid paths in the VM’s Nix store database, - # and `nix-store --query` commands run as part of the tests - # (for example when building Flatpak runtimes) will fail. - environment.variables.TESTED_PACKAGE_INSTALLED_TESTS = "${tested.installedTests}/share"; - }; + # The installed tests need to be added to the test VM’s closure. + # Otherwise, their dependencies might not actually be registered + # as valid paths in the VM’s Nix store database, + # and `nix-store --query` commands run as part of the tests + # (for example when building Flatpak runtimes) will fail. + environment.variables.TESTED_PACKAGE_INSTALLED_TESTS = "${tested.installedTests}/share"; + }; testScript = optionalString withX11 '' machine.wait_for_x() - '' + - optionalString (preTestScript != "") '' + '' + + optionalString (preTestScript != "") '' ${preTestScript} - '' + '' + + '' machine.succeed( "gnome-desktop-testing-runner ${escapeShellArgs testRunnerFlags} -d '${tested.installedTests}/share'" ) ''; } - (removeAttrs args [ - "tested" - "testConfig" - "preTestScript" - "withX11" - "testRunnerFlags" - ]) - ); + ( + removeAttrs args [ + "tested" + "testConfig" + "preTestScript" + "withX11" + "testRunnerFlags" + ] + ) + ); in { - appstream = callInstalledTest ./appstream.nix {}; - appstream-qt = callInstalledTest ./appstream-qt.nix {}; - colord = callInstalledTest ./colord.nix {}; - flatpak = callInstalledTest ./flatpak.nix {}; - flatpak-builder = callInstalledTest ./flatpak-builder.nix {}; - fwupd = callInstalledTest ./fwupd.nix {}; - gcab = callInstalledTest ./gcab.nix {}; - gdk-pixbuf = callInstalledTest ./gdk-pixbuf.nix {}; - geocode-glib = callInstalledTest ./geocode-glib.nix {}; - gjs = callInstalledTest ./gjs.nix {}; - glib-networking = callInstalledTest ./glib-networking.nix {}; - gnome-photos = callInstalledTest ./gnome-photos.nix {}; - graphene = callInstalledTest ./graphene.nix {}; - gsconnect = callInstalledTest ./gsconnect.nix {}; - json-glib = callInstalledTest ./json-glib.nix {}; - ibus = callInstalledTest ./ibus.nix {}; - libgdata = callInstalledTest ./libgdata.nix {}; - glib-testing = callInstalledTest ./glib-testing.nix {}; - libjcat = callInstalledTest ./libjcat.nix {}; - libxmlb = callInstalledTest ./libxmlb.nix {}; - malcontent = callInstalledTest ./malcontent.nix {}; - ostree = callInstalledTest ./ostree.nix {}; - pipewire = callInstalledTest ./pipewire.nix {}; - upower = callInstalledTest ./upower.nix {}; - xdg-desktop-portal = callInstalledTest ./xdg-desktop-portal.nix {}; + appstream = callInstalledTest ./appstream.nix { }; + appstream-qt = callInstalledTest ./appstream-qt.nix { }; + colord = callInstalledTest ./colord.nix { }; + flatpak = callInstalledTest ./flatpak.nix { }; + flatpak-builder = callInstalledTest ./flatpak-builder.nix { }; + fwupd = callInstalledTest ./fwupd.nix { }; + gcab = callInstalledTest ./gcab.nix { }; + gdk-pixbuf = callInstalledTest ./gdk-pixbuf.nix { }; + geocode-glib = callInstalledTest ./geocode-glib.nix { }; + gjs = callInstalledTest ./gjs.nix { }; + glib-networking = callInstalledTest ./glib-networking.nix { }; + gnome-photos = callInstalledTest ./gnome-photos.nix { }; + graphene = callInstalledTest ./graphene.nix { }; + gsconnect = callInstalledTest ./gsconnect.nix { }; + json-glib = callInstalledTest ./json-glib.nix { }; + ibus = callInstalledTest ./ibus.nix { }; + libgdata = callInstalledTest ./libgdata.nix { }; + glib-testing = callInstalledTest ./glib-testing.nix { }; + libjcat = callInstalledTest ./libjcat.nix { }; + libxmlb = callInstalledTest ./libxmlb.nix { }; + malcontent = callInstalledTest ./malcontent.nix { }; + ostree = callInstalledTest ./ostree.nix { }; + pipewire = callInstalledTest ./pipewire.nix { }; + upower = callInstalledTest ./upower.nix { }; + xdg-desktop-portal = callInstalledTest ./xdg-desktop-portal.nix { }; } diff --git a/nixos/tests/installed-tests/flatpak-builder.nix b/nixos/tests/installed-tests/flatpak-builder.nix index fd3df6bdea8f5b..322a4b841378d6 100644 --- a/nixos/tests/installed-tests/flatpak-builder.nix +++ b/nixos/tests/installed-tests/flatpak-builder.nix @@ -10,9 +10,14 @@ makeInstalledTest { extraPortals = with pkgs; [ xdg-desktop-portal-gtk ]; config.common.default = "gtk"; }; - environment.systemPackages = with pkgs; [ flatpak-builder ] ++ flatpak-builder.installedTestsDependencies; + environment.systemPackages = + with pkgs; + [ flatpak-builder ] ++ flatpak-builder.installedTestsDependencies; virtualisation.diskSize = 2048; }; - testRunnerFlags = [ "--timeout" "3600" ]; + testRunnerFlags = [ + "--timeout" + "3600" + ]; } diff --git a/nixos/tests/installed-tests/flatpak.nix b/nixos/tests/installed-tests/flatpak.nix index fa191202f52d49..370fa2f123fa16 100644 --- a/nixos/tests/installed-tests/flatpak.nix +++ b/nixos/tests/installed-tests/flatpak.nix @@ -9,10 +9,17 @@ makeInstalledTest { xdg.portal.extraPortals = [ pkgs.xdg-desktop-portal-gtk ]; xdg.portal.config.common.default = "gtk"; services.flatpak.enable = true; - environment.systemPackages = with pkgs; [ gnupg ostree python3 ]; + environment.systemPackages = with pkgs; [ + gnupg + ostree + python3 + ]; virtualisation.memorySize = 2047; virtualisation.diskSize = 3072; }; - testRunnerFlags = [ "--timeout" "3600" ]; + testRunnerFlags = [ + "--timeout" + "3600" + ]; } diff --git a/nixos/tests/installed-tests/gdk-pixbuf.nix b/nixos/tests/installed-tests/gdk-pixbuf.nix index a86c20b0fbeb07..ecc29f8e6f1511 100644 --- a/nixos/tests/installed-tests/gdk-pixbuf.nix +++ b/nixos/tests/installed-tests/gdk-pixbuf.nix @@ -9,5 +9,8 @@ makeInstalledTest { virtualisation.memorySize = if pkgs.stdenv.hostPlatform.isi686 then 2047 else 4096; }; - testRunnerFlags = [ "--timeout" "1800" ]; + testRunnerFlags = [ + "--timeout" + "1800" + ]; } diff --git a/nixos/tests/installed-tests/gnome-photos.nix b/nixos/tests/installed-tests/gnome-photos.nix index 010ad970240268..ded6edcaf45eb0 100644 --- a/nixos/tests/installed-tests/gnome-photos.nix +++ b/nixos/tests/installed-tests/gnome-photos.nix @@ -13,7 +13,10 @@ makeInstalledTest { (stdenv.mkDerivation { name = "desktop-gsettings"; dontUnpack = true; - nativeBuildInputs = [ glib wrapGAppsHook3 ]; + nativeBuildInputs = [ + glib + wrapGAppsHook3 + ]; buildInputs = [ gsettings-desktop-schemas ]; installPhase = '' runHook preInstall diff --git a/nixos/tests/installer-systemd-stage-1.nix b/nixos/tests/installer-systemd-stage-1.nix index 3b5e0ed8e7bbae..d007b3caf397f9 100644 --- a/nixos/tests/installer-systemd-stage-1.nix +++ b/nixos/tests/installer-systemd-stage-1.nix @@ -1,12 +1,17 @@ -{ system ? builtins.currentSystem -, config ? {} -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: { # Some of these tests don't work with systemd stage 1 yet. Uncomment # them when fixed. - inherit (import ./installer.nix { inherit system config pkgs; systemdStage1 = true; }) + inherit + (import ./installer.nix { + inherit system config pkgs; + systemdStage1 = true; + }) # bcache bcachefsSimple bcachefsEncrypted diff --git a/nixos/tests/installer.nix b/nixos/tests/installer.nix index d4caf3ceaf1fb0..ab2b5a61f12df8 100644 --- a/nixos/tests/installer.nix +++ b/nixos/tests/installer.nix @@ -1,7 +1,8 @@ -{ system ? builtins.currentSystem, - config ? {}, +{ + system ? builtins.currentSystem, + config ? { }, pkgs ? import ../.. { inherit system config; }, - systemdStage1 ? false + systemdStage1 ? false, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -10,18 +11,28 @@ with pkgs.lib; let # The configuration to install. - makeConfig = { bootLoader, grubDevice, grubIdentifier, grubUseEfi - , extraConfig, forceGrubReinstallCount ? 0, withTestInstrumentation ? true - , clevisTest - }: + makeConfig = + { + bootLoader, + grubDevice, + grubIdentifier, + grubUseEfi, + extraConfig, + forceGrubReinstallCount ? 0, + withTestInstrumentation ? true, + clevisTest, + }: pkgs.writeText "configuration.nix" '' { config, lib, pkgs, modulesPath, ... }: { imports = [ ./hardware-configuration.nix - ${if !withTestInstrumentation - then "" # Still included, but via installer/flake.nix - else ""} + ${ + if !withTestInstrumentation then + "" # Still included, but via installer/flake.nix + else + "" + } ]; networking.hostName = "thatworked"; @@ -35,14 +46,19 @@ let ${optionalString (bootLoader == "grub") '' boot.loader.grub.extraConfig = "serial; terminal_output serial"; - ${if grubUseEfi then '' - boot.loader.grub.device = "nodev"; - boot.loader.grub.efiSupport = true; - boot.loader.grub.efiInstallAsRemovable = true; # XXX: needed for OVMF? - '' else '' - boot.loader.grub.device = "${grubDevice}"; - boot.loader.grub.fsIdentifier = "${grubIdentifier}"; - ''} + ${ + if grubUseEfi then + '' + boot.loader.grub.device = "nodev"; + boot.loader.grub.efiSupport = true; + boot.loader.grub.efiInstallAsRemovable = true; # XXX: needed for OVMF? + '' + else + '' + boot.loader.grub.device = "${grubDevice}"; + boot.loader.grub.fsIdentifier = "${grubIdentifier}"; + '' + } boot.loader.grub.configurationLimit = 100 + ${toString forceGrubReinstallCount}; ''} @@ -60,7 +76,7 @@ let clevis = { enable = true; useTang = true; }; network.enable = true; }; - ''} + ''} users.users.alice = { isNormalUser = true; @@ -70,20 +86,31 @@ let hardware.enableAllFirmware = lib.mkForce false; - ${replaceStrings ["\n"] ["\n "] extraConfig} + ${replaceStrings [ "\n" ] [ "\n " ] extraConfig} } ''; - # The test script boots a NixOS VM, installs NixOS on an empty hard # disk, and then reboot from the hard disk. It's parameterized with # a test script fragment `createPartitions', which must create # partitions and filesystems. - testScriptFun = { bootLoader, createPartitions, grubDevice, grubUseEfi, grubIdentifier - , postInstallCommands, postBootCommands, extraConfig - , testSpecialisationConfig, testFlakeSwitch, testByAttrSwitch, clevisTest, clevisFallbackTest - , disableFileSystems - }: + testScriptFun = + { + bootLoader, + createPartitions, + grubDevice, + grubUseEfi, + grubIdentifier, + postInstallCommands, + postBootCommands, + extraConfig, + testSpecialisationConfig, + testFlakeSwitch, + testByAttrSwitch, + clevisTest, + clevisFallbackTest, + disableFileSystems, + }: let startTarget = '' ${optionalString clevisTest "tpm.start()"} @@ -91,53 +118,54 @@ let ${postBootCommands} target.wait_for_unit("multi-user.target") ''; - in '' + in + '' ${optionalString clevisTest '' - import os - import subprocess - - tpm_folder = os.environ['NIX_BUILD_TOP'] - - class Tpm: - def __init__(self): - self.start() - - def start(self): - self.proc = subprocess.Popen(["${pkgs.swtpm}/bin/swtpm", - "socket", - "--tpmstate", f"dir={tpm_folder}/swtpm", - "--ctrl", f"type=unixio,path={tpm_folder}/swtpm-sock", - "--tpm2" - ]) - - # Check whether starting swtpm failed - try: - exit_code = self.proc.wait(timeout=0.2) - if exit_code is not None and exit_code != 0: - raise Exception("failed to start swtpm") - except subprocess.TimeoutExpired: - pass - - """Check whether the swtpm process exited due to an error""" - def check(self): - exit_code = self.proc.poll() - if exit_code is not None and exit_code != 0: - raise Exception("swtpm process died") - - - os.mkdir(f"{tpm_folder}/swtpm") - tpm = Tpm() - tpm.check() + import os + import subprocess + + tpm_folder = os.environ['NIX_BUILD_TOP'] + + class Tpm: + def __init__(self): + self.start() + + def start(self): + self.proc = subprocess.Popen(["${pkgs.swtpm}/bin/swtpm", + "socket", + "--tpmstate", f"dir={tpm_folder}/swtpm", + "--ctrl", f"type=unixio,path={tpm_folder}/swtpm-sock", + "--tpm2" + ]) + + # Check whether starting swtpm failed + try: + exit_code = self.proc.wait(timeout=0.2) + if exit_code is not None and exit_code != 0: + raise Exception("failed to start swtpm") + except subprocess.TimeoutExpired: + pass + + """Check whether the swtpm process exited due to an error""" + def check(self): + exit_code = self.proc.poll() + if exit_code is not None and exit_code != 0: + raise Exception("swtpm process died") + + + os.mkdir(f"{tpm_folder}/swtpm") + tpm = Tpm() + tpm.check() ''} installer.start() ${optionalString clevisTest '' - tang.start() - tang.wait_for_unit("sockets.target") - tang.systemctl("start network-online.target") - tang.wait_for_unit("network-online.target") - installer.systemctl("start network-online.target") - installer.wait_for_unit("network-online.target") + tang.start() + tang.wait_for_unit("sockets.target") + tang.systemctl("start network-online.target") + tang.wait_for_unit("network-online.target") + installer.systemctl("start network-online.target") + installer.wait_for_unit("network-online.target") ''} installer.wait_for_unit("multi-user.target") @@ -153,10 +181,17 @@ let installer.succeed("nixos-generate-config ${optionalString disableFileSystems "--no-filesystems"} --root /mnt") installer.succeed("cat /mnt/etc/nixos/hardware-configuration.nix >&2") installer.copy_from_host( - "${ makeConfig { - inherit bootLoader grubDevice grubIdentifier - grubUseEfi extraConfig clevisTest; - } + "${ + makeConfig { + inherit + bootLoader + grubDevice + grubIdentifier + grubUseEfi + extraConfig + clevisTest + ; + } }", "/mnt/etc/nixos/configuration.nix", ) @@ -207,9 +242,11 @@ let with subtest("Assert that /boot get mounted"): target.wait_for_unit("local-fs.target") - ${if bootLoader == "grub" - then ''target.succeed("test -e /boot/grub")'' - else ''target.succeed("test -e /boot/loader/loader.conf")'' + ${ + if bootLoader == "grub" then + ''target.succeed("test -e /boot/grub")'' + else + ''target.succeed("test -e /boot/loader/loader.conf")'' } with subtest("Check whether /root has correct permissions"): @@ -237,11 +274,18 @@ let # we're not using copy_from_host here because the installer image # doesn't know about the host-guest sharing mechanism. target.copy_from_host_via_shell( - "${ makeConfig { - inherit bootLoader grubDevice grubIdentifier - grubUseEfi extraConfig clevisTest; - forceGrubReinstallCount = 1; - } + "${ + makeConfig { + inherit + bootLoader + grubDevice + grubIdentifier + grubUseEfi + extraConfig + clevisTest + ; + forceGrubReinstallCount = 1; + } }", "/etc/nixos/configuration.nix", ) @@ -263,11 +307,18 @@ let # we're not using copy_from_host here because the installer image # doesn't know about the host-guest sharing mechanism. target.copy_from_host_via_shell( - "${ makeConfig { - inherit bootLoader grubDevice grubIdentifier - grubUseEfi extraConfig clevisTest; - forceGrubReinstallCount = 2; - } + "${ + makeConfig { + inherit + bootLoader + grubDevice + grubIdentifier + grubUseEfi + extraConfig + clevisTest + ; + forceGrubReinstallCount = 2; + } }", "/etc/nixos/configuration.nix", ) @@ -324,11 +375,20 @@ let rm /etc/nixos/configuration.nix """) target.copy_from_host_via_shell( - "${makeConfig { - inherit bootLoader grubDevice grubIdentifier grubUseEfi extraConfig clevisTest; - forceGrubReinstallCount = 1; - withTestInstrumentation = false; - }}", + "${ + makeConfig { + inherit + bootLoader + grubDevice + grubIdentifier + grubUseEfi + extraConfig + clevisTest + ; + forceGrubReinstallCount = 1; + withTestInstrumentation = false; + } + }", "/root/my-config/configuration.nix", ) target.copy_from_host_via_shell( @@ -413,10 +473,19 @@ let mv -v /root/my-config/hardware-configuration.nix /etc/nixos/ """) target.copy_from_host_via_shell( - "${makeConfig { - inherit bootLoader grubDevice grubIdentifier grubUseEfi extraConfig clevisTest; - forceGrubReinstallCount = 1; - }}", + "${ + makeConfig { + inherit + bootLoader + grubDevice + grubIdentifier + grubUseEfi + extraConfig + clevisTest + ; + forceGrubReinstallCount = 1; + } + }", "/etc/nixos/configuration.nix", ) @@ -440,11 +509,20 @@ let rm /etc/nixos/configuration.nix """) target.copy_from_host_via_shell( - "${makeConfig { - inherit bootLoader grubDevice grubIdentifier grubUseEfi extraConfig clevisTest; - forceGrubReinstallCount = 1; - withTestInstrumentation = false; - }}", + "${ + makeConfig { + inherit + bootLoader + grubDevice + grubIdentifier + grubUseEfi + extraConfig + clevisTest + ; + forceGrubReinstallCount = 1; + withTestInstrumentation = false; + } + }", "/root/my-config/configuration.nix", ) target.copy_from_host_via_shell( @@ -540,166 +618,201 @@ let target.shutdown() ''; - - makeInstallerTest = name: - { createPartitions - , postInstallCommands ? "", postBootCommands ? "" - , extraConfig ? "" - , extraInstallerConfig ? {} - , bootLoader ? "grub" # either "grub" or "systemd-boot" - , grubDevice ? "/dev/vda", grubIdentifier ? "uuid", grubUseEfi ? false - , enableOCR ? false, meta ? {} - , testSpecialisationConfig ? false - , testFlakeSwitch ? false - , testByAttrSwitch ? false - , clevisTest ? false - , clevisFallbackTest ? false - , disableFileSystems ? false + makeInstallerTest = + name: + { + createPartitions, + postInstallCommands ? "", + postBootCommands ? "", + extraConfig ? "", + extraInstallerConfig ? { }, + bootLoader ? "grub", # either "grub" or "systemd-boot" + grubDevice ? "/dev/vda", + grubIdentifier ? "uuid", + grubUseEfi ? false, + enableOCR ? false, + meta ? { }, + testSpecialisationConfig ? false, + testFlakeSwitch ? false, + testByAttrSwitch ? false, + clevisTest ? false, + clevisFallbackTest ? false, + disableFileSystems ? false, }: let isEfi = bootLoader == "systemd-boot" || (bootLoader == "grub" && grubUseEfi); - in makeTest { + in + makeTest { inherit enableOCR; name = "installer-" + name; meta = { # put global maintainers here, individuals go into makeInstallerTest fkt call - maintainers = (meta.maintainers or []); + maintainers = (meta.maintainers or [ ]); # non-EFI tests can only run on x86 - platforms = if isEfi then platforms.linux else [ "x86_64-linux" "i686-linux" ]; + platforms = + if isEfi then + platforms.linux + else + [ + "x86_64-linux" + "i686-linux" + ]; }; - nodes = let - commonConfig = { - # builds stuff in the VM, needs more juice - virtualisation.diskSize = 8 * 1024; - virtualisation.cores = 8; - virtualisation.memorySize = 2048; - - # both installer and target need to use the same drive - virtualisation.diskImage = "./target.qcow2"; - - # and the same TPM options - virtualisation.qemu.options = mkIf (clevisTest) [ - "-chardev socket,id=chrtpm,path=$NIX_BUILD_TOP/swtpm-sock" - "-tpmdev emulator,id=tpm0,chardev=chrtpm" - "-device tpm-tis,tpmdev=tpm0" - ]; - }; - in { - # The configuration of the system used to run "nixos-install". - installer = { - imports = [ - commonConfig - ../modules/profiles/installation-device.nix - ../modules/profiles/base.nix - extraInstallerConfig - ./common/auto-format-root-device.nix - ]; - - # In systemdStage1, also automatically format the device backing the - # root filesystem. - virtualisation.fileSystems."/".autoFormat = systemdStage1; - - boot.initrd.systemd.enable = systemdStage1; - - # Use a small /dev/vdb as the root disk for the - # installer. This ensures the target disk (/dev/vda) is - # the same during and after installation. - virtualisation.emptyDiskImages = [ 512 ]; - virtualisation.rootDevice = "/dev/vdb"; - - hardware.enableAllFirmware = mkForce false; - - # The test cannot access the network, so any packages we - # need must be included in the VM. - system.extraDependencies = with pkgs; [ - bintools - brotli - brotli.dev - brotli.lib - desktop-file-utils - docbook5 - docbook_xsl_ns - kbd.dev - kmod.dev - libarchive.dev - libxml2.bin - libxslt.bin - nixos-artwork.wallpapers.simple-dark-gray-bottom - ntp - perlPackages.ConfigIniFiles - perlPackages.FileSlurp - perlPackages.JSON - perlPackages.ListCompare - perlPackages.XMLLibXML - # make-options-doc/default.nix - (python3.withPackages (p: [ p.mistune ])) - shared-mime-info - sudo - switch-to-configuration-ng - texinfo - unionfs-fuse - xorg.lndir - - # add curl so that rather than seeing the test attempt to download - # curl's tarball, we see what it's trying to download - curl - ] - ++ optionals (bootLoader == "grub") (let - zfsSupport = extraInstallerConfig.boot.supportedFilesystems.zfs or false; - in [ - (pkgs.grub2.override { inherit zfsSupport; }) - (pkgs.grub2_efi.override { inherit zfsSupport; }) - pkgs.nixos-artwork.wallpapers.simple-dark-gray-bootloader - pkgs.perlPackages.FileCopyRecursive - pkgs.perlPackages.XMLSAX - pkgs.perlPackages.XMLSAXBase - ]) - ++ optionals (bootLoader == "systemd-boot") [ - pkgs.zstd.bin - pkgs.mypy - pkgs.bootspec - ] - ++ optionals clevisTest [ pkgs.klibc ]; - - nix.settings = { - substituters = mkForce []; - hashed-mirrors = null; - connect-timeout = 1; + nodes = + let + commonConfig = { + # builds stuff in the VM, needs more juice + virtualisation.diskSize = 8 * 1024; + virtualisation.cores = 8; + virtualisation.memorySize = 2048; + + # both installer and target need to use the same drive + virtualisation.diskImage = "./target.qcow2"; + + # and the same TPM options + virtualisation.qemu.options = mkIf (clevisTest) [ + "-chardev socket,id=chrtpm,path=$NIX_BUILD_TOP/swtpm-sock" + "-tpmdev emulator,id=tpm0,chardev=chrtpm" + "-device tpm-tis,tpmdev=tpm0" + ]; + }; + in + { + # The configuration of the system used to run "nixos-install". + installer = { + imports = [ + commonConfig + ../modules/profiles/installation-device.nix + ../modules/profiles/base.nix + extraInstallerConfig + ./common/auto-format-root-device.nix + ]; + + # In systemdStage1, also automatically format the device backing the + # root filesystem. + virtualisation.fileSystems."/".autoFormat = systemdStage1; + + boot.initrd.systemd.enable = systemdStage1; + + # Use a small /dev/vdb as the root disk for the + # installer. This ensures the target disk (/dev/vda) is + # the same during and after installation. + virtualisation.emptyDiskImages = [ 512 ]; + virtualisation.rootDevice = "/dev/vdb"; + + hardware.enableAllFirmware = mkForce false; + + # The test cannot access the network, so any packages we + # need must be included in the VM. + system.extraDependencies = + with pkgs; + [ + bintools + brotli + brotli.dev + brotli.lib + desktop-file-utils + docbook5 + docbook_xsl_ns + kbd.dev + kmod.dev + libarchive.dev + libxml2.bin + libxslt.bin + nixos-artwork.wallpapers.simple-dark-gray-bottom + ntp + perlPackages.ConfigIniFiles + perlPackages.FileSlurp + perlPackages.JSON + perlPackages.ListCompare + perlPackages.XMLLibXML + # make-options-doc/default.nix + (python3.withPackages (p: [ p.mistune ])) + shared-mime-info + sudo + switch-to-configuration-ng + texinfo + unionfs-fuse + xorg.lndir + + # add curl so that rather than seeing the test attempt to download + # curl's tarball, we see what it's trying to download + curl + ] + ++ optionals (bootLoader == "grub") ( + let + zfsSupport = extraInstallerConfig.boot.supportedFilesystems.zfs or false; + in + [ + (pkgs.grub2.override { inherit zfsSupport; }) + (pkgs.grub2_efi.override { inherit zfsSupport; }) + pkgs.nixos-artwork.wallpapers.simple-dark-gray-bootloader + pkgs.perlPackages.FileCopyRecursive + pkgs.perlPackages.XMLSAX + pkgs.perlPackages.XMLSAXBase + ] + ) + ++ optionals (bootLoader == "systemd-boot") [ + pkgs.zstd.bin + pkgs.mypy + pkgs.bootspec + ] + ++ optionals clevisTest [ pkgs.klibc ]; + + nix.settings = { + substituters = mkForce [ ]; + hashed-mirrors = null; + connect-timeout = 1; + }; }; - }; - - target = { - imports = [ commonConfig ]; - virtualisation.useBootLoader = true; - virtualisation.useEFIBoot = isEfi; - virtualisation.useDefaultFilesystems = false; - virtualisation.efi.keepVariables = false; - virtualisation.fileSystems."/" = { - device = "/dev/disk/by-label/this-is-not-real-and-will-never-be-used"; - fsType = "ext4"; + target = { + imports = [ commonConfig ]; + virtualisation.useBootLoader = true; + virtualisation.useEFIBoot = isEfi; + virtualisation.useDefaultFilesystems = false; + virtualisation.efi.keepVariables = false; + + virtualisation.fileSystems."/" = { + device = "/dev/disk/by-label/this-is-not-real-and-will-never-be-used"; + fsType = "ext4"; + }; }; - }; - } // optionalAttrs clevisTest { - tang = { - services.tang = { - enable = true; - listenStream = [ "80" ]; - ipAddressAllow = [ "192.168.1.0/24" ]; + } + // optionalAttrs clevisTest { + tang = { + services.tang = { + enable = true; + listenStream = [ "80" ]; + ipAddressAllow = [ "192.168.1.0/24" ]; + }; + networking.firewall.allowedTCPPorts = [ 80 ]; }; - networking.firewall.allowedTCPPorts = [ 80 ]; }; - }; testScript = testScriptFun { - inherit bootLoader createPartitions postInstallCommands postBootCommands - grubDevice grubIdentifier grubUseEfi extraConfig - testSpecialisationConfig testFlakeSwitch testByAttrSwitch clevisTest clevisFallbackTest - disableFileSystems; + inherit + bootLoader + createPartitions + postInstallCommands + postBootCommands + grubDevice + grubIdentifier + grubUseEfi + extraConfig + testSpecialisationConfig + testFlakeSwitch + testByAttrSwitch + clevisTest + clevisFallbackTest + disableFileSystems + ; }; }; - makeLuksRootTest = name: luksFormatOpts: makeInstallerTest name { + makeLuksRootTest = + name: luksFormatOpts: + makeInstallerTest name { createPartitions = '' installer.succeed( "flock /dev/vda parted --script /dev/vda -- mklabel msdos" @@ -800,152 +913,189 @@ let }; # disable zfs so we can support latest kernel if needed no-zfs-module = { - nixpkgs.overlays = [(final: super: { - zfs = super.zfs.overrideAttrs(_: {meta.platforms = [];});} - )]; + nixpkgs.overlays = [ + (final: super: { + zfs = super.zfs.overrideAttrs (_: { + meta.platforms = [ ]; + }); + }) + ]; }; - mkClevisBcachefsTest = { fallback ? false }: makeInstallerTest "clevis-bcachefs${optionalString fallback "-fallback"}" { - clevisTest = true; - clevisFallbackTest = fallback; - enableOCR = fallback; - extraInstallerConfig = { - imports = [ no-zfs-module ]; - boot.supportedFilesystems = [ "bcachefs" ]; - environment.systemPackages = with pkgs; [ keyutils clevis ]; - }; - createPartitions = '' - installer.succeed( - "flock /dev/vda parted --script /dev/vda -- mklabel msdos" - + " mkpart primary ext2 1M 100MB" - + " mkpart primary linux-swap 100M 1024M" - + " mkpart primary 1024M -1s", - "udevadm settle", - "mkswap /dev/vda2 -L swap", - "swapon -L swap", - "keyctl link @u @s", - "echo -n password | mkfs.bcachefs -L root --encrypted /dev/vda3", - "echo -n password | bcachefs unlock /dev/vda3", - "echo -n password | mount -t bcachefs /dev/vda3 /mnt", - "mkfs.ext3 -L boot /dev/vda1", - "mkdir -p /mnt/boot", - "mount LABEL=boot /mnt/boot", - "udevadm settle") - ''; - extraConfig = '' - boot.initrd.clevis.devices."/dev/vda3".secretFile = "/etc/nixos/clevis-secret.jwe"; - - # We override what nixos-generate-config has generated because we do - # not know the UUID in advance. - fileSystems."/" = lib.mkForce { device = "/dev/vda3"; fsType = "bcachefs"; }; - ''; - postBootCommands = optionalString fallback '' - target.wait_for_text("enter passphrase for") - target.send_chars("password\n") - ''; - }; + mkClevisBcachefsTest = + { + fallback ? false, + }: + makeInstallerTest "clevis-bcachefs${optionalString fallback "-fallback"}" { + clevisTest = true; + clevisFallbackTest = fallback; + enableOCR = fallback; + extraInstallerConfig = { + imports = [ no-zfs-module ]; + boot.supportedFilesystems = [ "bcachefs" ]; + environment.systemPackages = with pkgs; [ + keyutils + clevis + ]; + }; + createPartitions = '' + installer.succeed( + "flock /dev/vda parted --script /dev/vda -- mklabel msdos" + + " mkpart primary ext2 1M 100MB" + + " mkpart primary linux-swap 100M 1024M" + + " mkpart primary 1024M -1s", + "udevadm settle", + "mkswap /dev/vda2 -L swap", + "swapon -L swap", + "keyctl link @u @s", + "echo -n password | mkfs.bcachefs -L root --encrypted /dev/vda3", + "echo -n password | bcachefs unlock /dev/vda3", + "echo -n password | mount -t bcachefs /dev/vda3 /mnt", + "mkfs.ext3 -L boot /dev/vda1", + "mkdir -p /mnt/boot", + "mount LABEL=boot /mnt/boot", + "udevadm settle") + ''; + extraConfig = '' + boot.initrd.clevis.devices."/dev/vda3".secretFile = "/etc/nixos/clevis-secret.jwe"; - mkClevisLuksTest = { fallback ? false }: makeInstallerTest "clevis-luks${optionalString fallback "-fallback"}" { - clevisTest = true; - clevisFallbackTest = fallback; - enableOCR = fallback; - extraInstallerConfig = { - environment.systemPackages = with pkgs; [ clevis ]; + # We override what nixos-generate-config has generated because we do + # not know the UUID in advance. + fileSystems."/" = lib.mkForce { device = "/dev/vda3"; fsType = "bcachefs"; }; + ''; + postBootCommands = optionalString fallback '' + target.wait_for_text("enter passphrase for") + target.send_chars("password\n") + ''; }; - createPartitions = '' - installer.succeed( - "flock /dev/vda parted --script /dev/vda -- mklabel msdos" - + " mkpart primary ext2 1M 100MB" - + " mkpart primary linux-swap 100M 1024M" - + " mkpart primary 1024M -1s", - "udevadm settle", - "mkswap /dev/vda2 -L swap", - "swapon -L swap", - "modprobe dm_mod dm_crypt", - "echo -n password | cryptsetup luksFormat -q /dev/vda3 -", - "echo -n password | cryptsetup luksOpen --key-file - /dev/vda3 crypt-root", - "mkfs.ext3 -L nixos /dev/mapper/crypt-root", - "mount LABEL=nixos /mnt", - "mkfs.ext3 -L boot /dev/vda1", - "mkdir -p /mnt/boot", - "mount LABEL=boot /mnt/boot", - "udevadm settle") - ''; - extraConfig = '' - boot.initrd.clevis.devices."crypt-root".secretFile = "/etc/nixos/clevis-secret.jwe"; - ''; - postBootCommands = optionalString fallback '' - ${if systemdStage1 then '' - target.wait_for_text("Please enter") - '' else '' - target.wait_for_text("Passphrase for") - ''} - target.send_chars("password\n") - ''; - }; - mkClevisZfsTest = { fallback ? false, parentDataset ? false }: makeInstallerTest "clevis-zfs${optionalString parentDataset "-parent-dataset"}${optionalString fallback "-fallback"}" { - clevisTest = true; - clevisFallbackTest = fallback; - enableOCR = fallback; - extraInstallerConfig = { - boot.supportedFilesystems = [ "zfs" ]; - environment.systemPackages = with pkgs; [ clevis ]; + mkClevisLuksTest = + { + fallback ? false, + }: + makeInstallerTest "clevis-luks${optionalString fallback "-fallback"}" { + clevisTest = true; + clevisFallbackTest = fallback; + enableOCR = fallback; + extraInstallerConfig = { + environment.systemPackages = with pkgs; [ clevis ]; + }; + createPartitions = '' + installer.succeed( + "flock /dev/vda parted --script /dev/vda -- mklabel msdos" + + " mkpart primary ext2 1M 100MB" + + " mkpart primary linux-swap 100M 1024M" + + " mkpart primary 1024M -1s", + "udevadm settle", + "mkswap /dev/vda2 -L swap", + "swapon -L swap", + "modprobe dm_mod dm_crypt", + "echo -n password | cryptsetup luksFormat -q /dev/vda3 -", + "echo -n password | cryptsetup luksOpen --key-file - /dev/vda3 crypt-root", + "mkfs.ext3 -L nixos /dev/mapper/crypt-root", + "mount LABEL=nixos /mnt", + "mkfs.ext3 -L boot /dev/vda1", + "mkdir -p /mnt/boot", + "mount LABEL=boot /mnt/boot", + "udevadm settle") + ''; + extraConfig = '' + boot.initrd.clevis.devices."crypt-root".secretFile = "/etc/nixos/clevis-secret.jwe"; + ''; + postBootCommands = optionalString fallback '' + ${ + if systemdStage1 then + '' + target.wait_for_text("Please enter") + '' + else + '' + target.wait_for_text("Passphrase for") + '' + } + target.send_chars("password\n") + ''; }; - createPartitions = '' - installer.succeed( - "flock /dev/vda parted --script /dev/vda -- mklabel msdos" - + " mkpart primary ext2 1M 100MB" - + " mkpart primary linux-swap 100M 1024M" - + " mkpart primary 1024M -1s", - "udevadm settle", - "mkswap /dev/vda2 -L swap", - "swapon -L swap", - '' + optionalString (!parentDataset) '' - "zpool create -O mountpoint=legacy rpool /dev/vda3", - "echo -n password | zfs create" - + " -o encryption=aes-256-gcm -o keyformat=passphrase rpool/root", - '' + optionalString (parentDataset) '' - "echo -n password | zpool create -O mountpoint=none -O encryption=on -O keyformat=passphrase rpool /dev/vda3", - "zfs create -o mountpoint=legacy rpool/root", - '' + - '' - "mount -t zfs rpool/root /mnt", - "mkfs.ext3 -L boot /dev/vda1", - "mkdir -p /mnt/boot", - "mount LABEL=boot /mnt/boot", - "udevadm settle") - ''; - extraConfig = optionalString (!parentDataset) '' - boot.initrd.clevis.devices."rpool/root".secretFile = "/etc/nixos/clevis-secret.jwe"; - '' + optionalString (parentDataset) '' - boot.initrd.clevis.devices."rpool".secretFile = "/etc/nixos/clevis-secret.jwe"; - '' + - '' - boot.zfs.requestEncryptionCredentials = true; - - # Using by-uuid overrides the default of by-id, and is unique - # to the qemu disks, as they don't produce by-id paths for - # some reason. - boot.zfs.devNodes = "/dev/disk/by-uuid/"; - networking.hostId = "00000000"; - ''; - postBootCommands = optionalString fallback '' - ${if systemdStage1 then '' - target.wait_for_text("Enter key for rpool/root") - '' else '' - target.wait_for_text("Key load error") - ''} - target.send_chars("password\n") - ''; - }; + mkClevisZfsTest = + { + fallback ? false, + parentDataset ? false, + }: + makeInstallerTest + "clevis-zfs${optionalString parentDataset "-parent-dataset"}${optionalString fallback "-fallback"}" + { + clevisTest = true; + clevisFallbackTest = fallback; + enableOCR = fallback; + extraInstallerConfig = { + boot.supportedFilesystems = [ "zfs" ]; + environment.systemPackages = with pkgs; [ clevis ]; + }; + createPartitions = + '' + installer.succeed( + "flock /dev/vda parted --script /dev/vda -- mklabel msdos" + + " mkpart primary ext2 1M 100MB" + + " mkpart primary linux-swap 100M 1024M" + + " mkpart primary 1024M -1s", + "udevadm settle", + "mkswap /dev/vda2 -L swap", + "swapon -L swap", + '' + + optionalString (!parentDataset) '' + "zpool create -O mountpoint=legacy rpool /dev/vda3", + "echo -n password | zfs create" + + " -o encryption=aes-256-gcm -o keyformat=passphrase rpool/root", + '' + + optionalString (parentDataset) '' + "echo -n password | zpool create -O mountpoint=none -O encryption=on -O keyformat=passphrase rpool /dev/vda3", + "zfs create -o mountpoint=legacy rpool/root", + '' + + '' + "mount -t zfs rpool/root /mnt", + "mkfs.ext3 -L boot /dev/vda1", + "mkdir -p /mnt/boot", + "mount LABEL=boot /mnt/boot", + "udevadm settle") + ''; + extraConfig = + optionalString (!parentDataset) '' + boot.initrd.clevis.devices."rpool/root".secretFile = "/etc/nixos/clevis-secret.jwe"; + '' + + optionalString (parentDataset) '' + boot.initrd.clevis.devices."rpool".secretFile = "/etc/nixos/clevis-secret.jwe"; + '' + + '' + boot.zfs.requestEncryptionCredentials = true; + + + # Using by-uuid overrides the default of by-id, and is unique + # to the qemu disks, as they don't produce by-id paths for + # some reason. + boot.zfs.devNodes = "/dev/disk/by-uuid/"; + networking.hostId = "00000000"; + ''; + postBootCommands = optionalString fallback '' + ${ + if systemdStage1 then + '' + target.wait_for_text("Enter key for rpool/root") + '' + else + '' + target.wait_for_text("Key load error") + '' + } + target.send_chars("password\n") + ''; + }; -in { +in +{ # !!! `parted mkpart' seems to silently create overlapping partitions. - # The (almost) simplest partitioning scheme: a swap partition and # one big filesystem partition. simple = makeInstallerTest "simple" simple-test-config; @@ -957,7 +1107,9 @@ in { switchFromByAttrToFlake = makeInstallerTest "switch-from-by-attr-to-flake" simple-test-config-from-by-attr-to-flake; # Test cloned configurations with the simple grub configuration - simpleSpecialised = makeInstallerTest "simpleSpecialised" (simple-test-config // specialisation-test-extraconfig); + simpleSpecialised = makeInstallerTest "simpleSpecialised" ( + simple-test-config // specialisation-test-extraconfig + ); # Simple GPT/UEFI configuration using systemd-boot with 3 partitions: ESP, swap & root filesystem simpleUefiSystemdBoot = makeInstallerTest "simpleUefiSystemdBoot" { @@ -984,7 +1136,9 @@ in { simpleUefiGrub = makeInstallerTest "simpleUefiGrub" simple-uefi-grub-config; # Test cloned configurations with the uefi grub configuration - simpleUefiGrubSpecialisation = makeInstallerTest "simpleUefiGrubSpecialisation" (simple-uefi-grub-config // specialisation-test-extraconfig); + simpleUefiGrubSpecialisation = makeInstallerTest "simpleUefiGrubSpecialisation" ( + simple-uefi-grub-config // specialisation-test-extraconfig + ); # Same as the previous, but now with a separate /boot partition. separateBoot = makeInstallerTest "separateBoot" { @@ -1536,7 +1690,8 @@ in { ) ''; }; -} // { +} +// { clevisBcachefs = mkClevisBcachefsTest { }; clevisBcachefsFallback = mkClevisBcachefsTest { fallback = true; }; clevisLuks = mkClevisLuksTest { }; @@ -1544,8 +1699,12 @@ in { clevisZfs = mkClevisZfsTest { }; clevisZfsFallback = mkClevisZfsTest { fallback = true; }; clevisZfsParentDataset = mkClevisZfsTest { parentDataset = true; }; - clevisZfsParentDatasetFallback = mkClevisZfsTest { parentDataset = true; fallback = true; }; -} // optionalAttrs systemdStage1 { + clevisZfsParentDatasetFallback = mkClevisZfsTest { + parentDataset = true; + fallback = true; + }; +} +// optionalAttrs systemdStage1 { stratisRoot = makeInstallerTest "stratisRoot" { createPartitions = '' installer.succeed( @@ -1568,51 +1727,57 @@ in { ) ''; bootLoader = "systemd-boot"; - extraInstallerConfig = { modulesPath, ...}: { - config = { - services.stratis.enable = true; - environment.systemPackages = [ - pkgs.stratis-cli - pkgs.thin-provisioning-tools - pkgs.lvm2.bin - pkgs.stratisd.initrd - ]; + extraInstallerConfig = + { modulesPath, ... }: + { + config = { + services.stratis.enable = true; + environment.systemPackages = [ + pkgs.stratis-cli + pkgs.thin-provisioning-tools + pkgs.lvm2.bin + pkgs.stratisd.initrd + ]; + }; }; - }; }; - gptAutoRoot = let - rootPartType = { - ia32 = "44479540-F297-41B2-9AF7-D131D5F0458A"; - x64 = "4F68BCE3-E8CD-4DB1-96E7-FBCAF984B709"; - arm = "69DAD710-2CE4-4E3C-B16C-21A1D49ABED3"; - aa64 = "B921B045-1DF0-41C3-AF44-4C6F280D3FAE"; - }.${pkgs.stdenv.hostPlatform.efiArch}; - in makeInstallerTest "gptAutoRoot" { - disableFileSystems = true; - createPartitions = '' - installer.succeed( - "sgdisk --zap-all /dev/vda", - "sgdisk --new=1:0:+100M --typecode=0:ef00 /dev/vda", # /boot - "sgdisk --new=2:0:+1G --typecode=0:8200 /dev/vda", # swap - "sgdisk --new=3:0:+5G --typecode=0:${rootPartType} /dev/vda", # / - "udevadm settle", + gptAutoRoot = + let + rootPartType = + { + ia32 = "44479540-F297-41B2-9AF7-D131D5F0458A"; + x64 = "4F68BCE3-E8CD-4DB1-96E7-FBCAF984B709"; + arm = "69DAD710-2CE4-4E3C-B16C-21A1D49ABED3"; + aa64 = "B921B045-1DF0-41C3-AF44-4C6F280D3FAE"; + } + .${pkgs.stdenv.hostPlatform.efiArch}; + in + makeInstallerTest "gptAutoRoot" { + disableFileSystems = true; + createPartitions = '' + installer.succeed( + "sgdisk --zap-all /dev/vda", + "sgdisk --new=1:0:+100M --typecode=0:ef00 /dev/vda", # /boot + "sgdisk --new=2:0:+1G --typecode=0:8200 /dev/vda", # swap + "sgdisk --new=3:0:+5G --typecode=0:${rootPartType} /dev/vda", # / + "udevadm settle", - "mkfs.vfat /dev/vda1", - "mkswap /dev/vda2 -L swap", - "swapon -L swap", - "mkfs.ext4 -L root /dev/vda3", - "udevadm settle", + "mkfs.vfat /dev/vda1", + "mkswap /dev/vda2 -L swap", + "swapon -L swap", + "mkfs.ext4 -L root /dev/vda3", + "udevadm settle", - "mount /dev/vda3 /mnt", - "mkdir -p /mnt/boot", - "mount /dev/vda1 /mnt/boot" - ) - ''; - bootLoader = "systemd-boot"; - extraConfig = '' - boot.initrd.systemd.root = "gpt-auto"; - boot.initrd.supportedFilesystems = ["ext4"]; - ''; - }; + "mount /dev/vda3 /mnt", + "mkdir -p /mnt/boot", + "mount /dev/vda1 /mnt/boot" + ) + ''; + bootLoader = "systemd-boot"; + extraConfig = '' + boot.initrd.systemd.root = "gpt-auto"; + boot.initrd.supportedFilesystems = ["ext4"]; + ''; + }; } diff --git a/nixos/tests/installer/byAttrNoChannel.nix b/nixos/tests/installer/byAttrNoChannel.nix index 03293cd4a0e35d..4d6c70a69aa67c 100644 --- a/nixos/tests/installer/byAttrNoChannel.nix +++ b/nixos/tests/installer/byAttrNoChannel.nix @@ -4,12 +4,14 @@ let nixpkgs = "@nixpkgs@"; in -{ evalConfig ? import "${nixpkgs}/nixos/lib/eval-config.nix" }: +{ + evalConfig ? import "${nixpkgs}/nixos/lib/eval-config.nix", +}: evalConfig { modules = [ ./configuration.nix - ( import "${nixpkgs}/nixos/modules/testing/test-instrumentation.nix" ) + (import "${nixpkgs}/nixos/modules/testing/test-instrumentation.nix") { # Disable nix channels nix.channel.enable = false; diff --git a/nixos/tests/installer/byAttrWithChannel.nix b/nixos/tests/installer/byAttrWithChannel.nix index 951231dcba3e71..cc13a12d3c9f70 100644 --- a/nixos/tests/installer/byAttrWithChannel.nix +++ b/nixos/tests/installer/byAttrWithChannel.nix @@ -1,10 +1,12 @@ # This file gets copied into the installation -{ evalConfig ? import }: +{ + evalConfig ? import , +}: evalConfig { modules = [ ./configuration.nix - ( import ) + (import ) ]; } diff --git a/nixos/tests/installer/flake.nix b/nixos/tests/installer/flake.nix index 4bbef44e34fc9f..6b468d2ff70f2b 100644 --- a/nixos/tests/installer/flake.nix +++ b/nixos/tests/installer/flake.nix @@ -4,17 +4,19 @@ # To keep things simple, we'll use an absolute path dependency here. inputs.nixpkgs.url = "@nixpkgs@"; - outputs = { nixpkgs, ... }: { + outputs = + { nixpkgs, ... }: + { - nixosConfigurations.xyz = nixpkgs.lib.nixosSystem { - modules = [ - ./configuration.nix - ( nixpkgs + "/nixos/modules/testing/test-instrumentation.nix" ) - { - # We don't need nix-channel anymore - nix.channel.enable = false; - } - ]; + nixosConfigurations.xyz = nixpkgs.lib.nixosSystem { + modules = [ + ./configuration.nix + (nixpkgs + "/nixos/modules/testing/test-instrumentation.nix") + { + # We don't need nix-channel anymore + nix.channel.enable = false; + } + ]; + }; }; - }; } diff --git a/nixos/tests/intune.nix b/nixos/tests/intune.nix index 41bf638d76610c..eeb55f053f8a4f 100644 --- a/nixos/tests/intune.nix +++ b/nixos/tests/intune.nix @@ -1,56 +1,66 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "intune"; - meta = { - maintainers = with pkgs.lib.maintainers; [ rhysmdnz ]; - }; - enableOCR = true; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "intune"; + meta = { + maintainers = with pkgs.lib.maintainers; [ rhysmdnz ]; + }; + enableOCR = true; - nodes.machine = - { nodes, ... }: - let user = nodes.machine.users.users.alice; - in { - services.intune.enable=true; - services.gnome.gnome-keyring.enable = true; - imports = [ ./common/user-account.nix ./common/x11.nix ]; - test-support.displayManager.auto.user = user.name; - environment = { - variables.DBUS_SESSION_BUS_ADDRESS = "unix:path=/run/user/${builtins.toString user.uid}/bus"; + nodes.machine = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + in + { + services.intune.enable = true; + services.gnome.gnome-keyring.enable = true; + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; + test-support.displayManager.auto.user = user.name; + environment = { + variables.DBUS_SESSION_BUS_ADDRESS = "unix:path=/run/user/${builtins.toString user.uid}/bus"; + }; + }; + nodes.pam = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + in + { + services.intune.enable = true; + imports = [ ./common/user-account.nix ]; }; - }; - nodes.pam = - { nodes, ... }: - let user = nodes.machine.users.users.alice; - in { - services.intune.enable=true; - imports = [ ./common/user-account.nix ]; - }; - testScript = '' - start_all() + testScript = '' + start_all() - # Check System Daemons successfully start - machine.succeed("systemctl start microsoft-identity-device-broker.service") - machine.succeed("systemctl start intune-daemon.service") + # Check System Daemons successfully start + machine.succeed("systemctl start microsoft-identity-device-broker.service") + machine.succeed("systemctl start intune-daemon.service") - # Check User Daemons and intune-portal execurtable works - # Going any further than starting it would require internet access and a microsoft account - machine.wait_for_x() - # TODO: This needs an unlocked user keychain before it will work - #machine.succeed("su - alice -c 'systemctl start --user microsoft-identity-broker.service'") - machine.succeed("su - alice -c 'systemctl start --user intune-agent.service'") - machine.succeed("su - alice -c intune-portal >&2 &") - machine.wait_for_text("Intune Agent") + # Check User Daemons and intune-portal execurtable works + # Going any further than starting it would require internet access and a microsoft account + machine.wait_for_x() + # TODO: This needs an unlocked user keychain before it will work + #machine.succeed("su - alice -c 'systemctl start --user microsoft-identity-broker.service'") + machine.succeed("su - alice -c 'systemctl start --user intune-agent.service'") + machine.succeed("su - alice -c intune-portal >&2 &") + machine.wait_for_text("Intune Agent") - # Check logging in creates password file - def login_as_alice(): - pam.wait_until_tty_matches("1", "login: ") - pam.send_chars("alice\n") - pam.wait_until_tty_matches("1", "Password: ") - pam.send_chars("foobar\n") - pam.wait_until_tty_matches("1", "alice\@pam") + # Check logging in creates password file + def login_as_alice(): + pam.wait_until_tty_matches("1", "login: ") + pam.send_chars("alice\n") + pam.wait_until_tty_matches("1", "Password: ") + pam.send_chars("foobar\n") + pam.wait_until_tty_matches("1", "alice\@pam") - pam.wait_for_unit("multi-user.target") - login_as_alice() - pam.wait_for_file("/run/intune/1000/pwquality") - ''; -}) + pam.wait_for_unit("multi-user.target") + login_as_alice() + pam.wait_for_file("/run/intune/1000/pwquality") + ''; + } +) diff --git a/nixos/tests/invidious.nix b/nixos/tests/invidious.nix index 05b43c55560602..d4817cac4ebf8d 100644 --- a/nixos/tests/invidious.nix +++ b/nixos/tests/invidious.nix @@ -1,145 +1,154 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "invidious"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "invidious"; - meta = with pkgs.lib.maintainers; { - maintainers = [ sbruder ]; - }; - - nodes = { - postgres-tcp = { config, pkgs, ... }: { - services.postgresql = { - enable = true; - initialScript = pkgs.writeText "init-postgres-with-password" '' - CREATE USER invidious WITH PASSWORD 'correct horse battery staple'; - CREATE DATABASE invidious WITH OWNER invidious; - ''; - enableTCPIP = true; - authentication = '' - host invidious invidious samenet scram-sha-256 - ''; - }; - networking.firewall.allowedTCPPorts = [ config.services.postgresql.settings.port ]; + meta = with pkgs.lib.maintainers; { + maintainers = [ sbruder ]; }; - machine = { lib, pkgs, ... }: { - services.invidious = { - enable = true; - }; - specialisation = { - nginx.configuration = { - services.invidious = { - nginx.enable = true; - domain = "invidious.example.com"; - }; - services.nginx.virtualHosts."invidious.example.com" = { - forceSSL = false; - enableACME = false; - }; - networking.hosts."127.0.0.1" = [ "invidious.example.com" ]; - }; - nginx-sig-helper.configuration = { - services.invidious = { - nginx.enable = true; - domain = "invidious.example.com"; - sig-helper.enable = true; - settings.log_level = "Trace"; - }; - services.nginx.virtualHosts."invidious.example.com" = { - forceSSL = false; - enableACME = false; + nodes = { + postgres-tcp = + { config, pkgs, ... }: + { + services.postgresql = { + enable = true; + initialScript = pkgs.writeText "init-postgres-with-password" '' + CREATE USER invidious WITH PASSWORD 'correct horse battery staple'; + CREATE DATABASE invidious WITH OWNER invidious; + ''; + enableTCPIP = true; + authentication = '' + host invidious invidious samenet scram-sha-256 + ''; }; - networking.hosts."127.0.0.1" = [ "invidious.example.com" ]; + networking.firewall.allowedTCPPorts = [ config.services.postgresql.settings.port ]; }; - nginx-scale.configuration = { + machine = + { lib, pkgs, ... }: + { services.invidious = { - nginx.enable = true; - domain = "invidious.example.com"; - serviceScale = 3; - }; - services.nginx.virtualHosts."invidious.example.com" = { - forceSSL = false; - enableACME = false; + enable = true; }; - networking.hosts."127.0.0.1" = [ "invidious.example.com" ]; - }; - nginx-scale-ytproxy.configuration = { - services.invidious = { - nginx.enable = true; - http3-ytproxy.enable = true; - domain = "invidious.example.com"; - serviceScale = 3; - }; - services.nginx.virtualHosts."invidious.example.com" = { - forceSSL = false; - enableACME = false; - }; - networking.hosts."127.0.0.1" = [ "invidious.example.com" ]; - }; - postgres-tcp.configuration = { - services.invidious = { - database = { - createLocally = false; - host = "postgres-tcp"; - passwordFile = toString (pkgs.writeText "database-password" "correct horse battery staple"); + + specialisation = { + nginx.configuration = { + services.invidious = { + nginx.enable = true; + domain = "invidious.example.com"; + }; + services.nginx.virtualHosts."invidious.example.com" = { + forceSSL = false; + enableACME = false; + }; + networking.hosts."127.0.0.1" = [ "invidious.example.com" ]; + }; + nginx-sig-helper.configuration = { + services.invidious = { + nginx.enable = true; + domain = "invidious.example.com"; + sig-helper.enable = true; + settings.log_level = "Trace"; + }; + services.nginx.virtualHosts."invidious.example.com" = { + forceSSL = false; + enableACME = false; + }; + networking.hosts."127.0.0.1" = [ "invidious.example.com" ]; + }; + nginx-scale.configuration = { + services.invidious = { + nginx.enable = true; + domain = "invidious.example.com"; + serviceScale = 3; + }; + services.nginx.virtualHosts."invidious.example.com" = { + forceSSL = false; + enableACME = false; + }; + networking.hosts."127.0.0.1" = [ "invidious.example.com" ]; + }; + nginx-scale-ytproxy.configuration = { + services.invidious = { + nginx.enable = true; + http3-ytproxy.enable = true; + domain = "invidious.example.com"; + serviceScale = 3; + }; + services.nginx.virtualHosts."invidious.example.com" = { + forceSSL = false; + enableACME = false; + }; + networking.hosts."127.0.0.1" = [ "invidious.example.com" ]; + }; + postgres-tcp.configuration = { + services.invidious = { + database = { + createLocally = false; + host = "postgres-tcp"; + passwordFile = toString (pkgs.writeText "database-password" "correct horse battery staple"); + }; + }; }; }; }; - }; }; - }; - testScript = { nodes, ... }: '' - def curl_assert_status_code(url, code, form=None): - assert int(machine.succeed(f"curl -s -o /dev/null -w %{{http_code}} {'-F ' + form + ' ' if form else '''}{url}")) == code + testScript = + { nodes, ... }: + '' + def curl_assert_status_code(url, code, form=None): + assert int(machine.succeed(f"curl -s -o /dev/null -w %{{http_code}} {'-F ' + form + ' ' if form else '''}{url}")) == code - def activate_specialisation(name: str): - machine.succeed(f"${nodes.machine.system.build.toplevel}/specialisation/{name}/bin/switch-to-configuration test >&2") + def activate_specialisation(name: str): + machine.succeed(f"${nodes.machine.system.build.toplevel}/specialisation/{name}/bin/switch-to-configuration test >&2") - url = "http://localhost:${toString nodes.machine.services.invidious.port}" - port = ${toString nodes.machine.services.invidious.port} + url = "http://localhost:${toString nodes.machine.services.invidious.port}" + port = ${toString nodes.machine.services.invidious.port} - # start postgres vm now - postgres_tcp.start() + # start postgres vm now + postgres_tcp.start() - machine.wait_for_open_port(port) - curl_assert_status_code(f"{url}/search", 200) + machine.wait_for_open_port(port) + curl_assert_status_code(f"{url}/search", 200) - activate_specialisation("nginx") - machine.wait_for_open_port(80) - curl_assert_status_code("http://invidious.example.com/search", 200) + activate_specialisation("nginx") + machine.wait_for_open_port(80) + curl_assert_status_code("http://invidious.example.com/search", 200) - activate_specialisation("nginx-scale") - machine.wait_for_open_port(80) - # this depends on nginx round-robin behaviour for the upstream servers - curl_assert_status_code("http://invidious.example.com/search", 200) - curl_assert_status_code("http://invidious.example.com/search", 200) - curl_assert_status_code("http://invidious.example.com/search", 200) - machine.succeed("journalctl -eu invidious.service | grep -o '200 GET /search'") - machine.succeed("journalctl -eu invidious-1.service | grep -o '200 GET /search'") - machine.succeed("journalctl -eu invidious-2.service | grep -o '200 GET /search'") + activate_specialisation("nginx-scale") + machine.wait_for_open_port(80) + # this depends on nginx round-robin behaviour for the upstream servers + curl_assert_status_code("http://invidious.example.com/search", 200) + curl_assert_status_code("http://invidious.example.com/search", 200) + curl_assert_status_code("http://invidious.example.com/search", 200) + machine.succeed("journalctl -eu invidious.service | grep -o '200 GET /search'") + machine.succeed("journalctl -eu invidious-1.service | grep -o '200 GET /search'") + machine.succeed("journalctl -eu invidious-2.service | grep -o '200 GET /search'") - activate_specialisation("nginx-scale-ytproxy") - machine.wait_for_unit("http3-ytproxy.service") - machine.wait_for_open_port(80) - machine.wait_until_succeeds("ls /run/http3-ytproxy/socket/http-proxy.sock") - curl_assert_status_code("http://invidious.example.com/search", 200) - # this should error out as no internet connectivity is available in the test - curl_assert_status_code("http://invidious.example.com/vi/dQw4w9WgXcQ/mqdefault.jpg", 502) - machine.succeed("journalctl -eu http3-ytproxy.service | grep -o 'dQw4w9WgXcQ'") + activate_specialisation("nginx-scale-ytproxy") + machine.wait_for_unit("http3-ytproxy.service") + machine.wait_for_open_port(80) + machine.wait_until_succeeds("ls /run/http3-ytproxy/socket/http-proxy.sock") + curl_assert_status_code("http://invidious.example.com/search", 200) + # this should error out as no internet connectivity is available in the test + curl_assert_status_code("http://invidious.example.com/vi/dQw4w9WgXcQ/mqdefault.jpg", 502) + machine.succeed("journalctl -eu http3-ytproxy.service | grep -o 'dQw4w9WgXcQ'") - activate_specialisation("nginx-sig-helper") - machine.wait_for_unit("invidious-sig-helper.service") - # we can't really test the sig helper that well without internet connection... - # invidious does connect to the sig helper though and crashes when the sig helper is not available - machine.wait_for_open_port(80) - curl_assert_status_code("http://invidious.example.com/search", 200) - machine.succeed("journalctl -eu invidious.service | grep -o \"SigHelper: Using helper at 'tcp://127.0.0.1:2999'\"") + activate_specialisation("nginx-sig-helper") + machine.wait_for_unit("invidious-sig-helper.service") + # we can't really test the sig helper that well without internet connection... + # invidious does connect to the sig helper though and crashes when the sig helper is not available + machine.wait_for_open_port(80) + curl_assert_status_code("http://invidious.example.com/search", 200) + machine.succeed("journalctl -eu invidious.service | grep -o \"SigHelper: Using helper at 'tcp://127.0.0.1:2999'\"") - postgres_tcp.wait_for_unit("postgresql.service") - activate_specialisation("postgres-tcp") - machine.wait_for_open_port(port) - curl_assert_status_code(f"{url}/search", 200) - ''; -}) + postgres_tcp.wait_for_unit("postgresql.service") + activate_specialisation("postgres-tcp") + machine.wait_for_open_port(port) + curl_assert_status_code(f"{url}/search", 200) + ''; + } +) diff --git a/nixos/tests/invoiceplane.nix b/nixos/tests/invoiceplane.nix index 0b517071719967..b028d46cf6c709 100644 --- a/nixos/tests/invoiceplane.nix +++ b/nixos/tests/invoiceplane.nix @@ -1,106 +1,118 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -{ - name = "invoiceplane"; - meta = with pkgs.lib.maintainers; { - maintainers = [ - onny - ]; - }; + { + name = "invoiceplane"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + onny + ]; + }; - nodes = { - invoiceplane_caddy = { ... }: { - services.invoiceplane.webserver = "caddy"; - services.invoiceplane.sites = { - "site1.local" = { - database.name = "invoiceplane1"; - database.createLocally = true; - enable = true; - }; - "site2.local" = { - database.name = "invoiceplane2"; - database.createLocally = true; - enable = true; + nodes = { + invoiceplane_caddy = + { ... }: + { + services.invoiceplane.webserver = "caddy"; + services.invoiceplane.sites = { + "site1.local" = { + database.name = "invoiceplane1"; + database.createLocally = true; + enable = true; + }; + "site2.local" = { + database.name = "invoiceplane2"; + database.createLocally = true; + enable = true; + }; + }; + + networking.firewall.allowedTCPPorts = [ 80 ]; + networking.hosts."127.0.0.1" = [ + "site1.local" + "site2.local" + ]; }; - }; - networking.firewall.allowedTCPPorts = [ 80 ]; - networking.hosts."127.0.0.1" = [ "site1.local" "site2.local" ]; - }; + invoiceplane_nginx = + { ... }: + { + services.invoiceplane.webserver = "nginx"; + services.invoiceplane.sites = { + "site1.local" = { + database.name = "invoiceplane1"; + database.createLocally = true; + enable = true; + }; + "site2.local" = { + database.name = "invoiceplane2"; + database.createLocally = true; + enable = true; + }; + }; - invoiceplane_nginx = { ... }: { - services.invoiceplane.webserver = "nginx"; - services.invoiceplane.sites = { - "site1.local" = { - database.name = "invoiceplane1"; - database.createLocally = true; - enable = true; - }; - "site2.local" = { - database.name = "invoiceplane2"; - database.createLocally = true; - enable = true; + networking.firewall.allowedTCPPorts = [ 80 ]; + networking.hosts."127.0.0.1" = [ + "site1.local" + "site2.local" + ]; }; - }; - - networking.firewall.allowedTCPPorts = [ 80 ]; - networking.hosts."127.0.0.1" = [ "site1.local" "site2.local" ]; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - invoiceplane_caddy.wait_for_unit("caddy") - invoiceplane_nginx.wait_for_unit("nginx") + invoiceplane_caddy.wait_for_unit("caddy") + invoiceplane_nginx.wait_for_unit("nginx") - site_names = ["site1.local", "site2.local"] + site_names = ["site1.local", "site2.local"] - machines = [invoiceplane_caddy, invoiceplane_nginx] + machines = [invoiceplane_caddy, invoiceplane_nginx] - for machine in machines: - machine.wait_for_open_port(80) - machine.wait_for_open_port(3306) + for machine in machines: + machine.wait_for_open_port(80) + machine.wait_for_open_port(3306) - for site_name in site_names: - machine.wait_for_unit(f"phpfpm-invoiceplane-{site_name}") + for site_name in site_names: + machine.wait_for_unit(f"phpfpm-invoiceplane-{site_name}") - with subtest("Website returns welcome screen"): - assert "Please install InvoicePlane" in machine.succeed(f"curl -L {site_name}") + with subtest("Website returns welcome screen"): + assert "Please install InvoicePlane" in machine.succeed(f"curl -L {site_name}") - with subtest("Finish InvoicePlane setup"): - machine.succeed( - f"curl -sSfL --cookie-jar cjar {site_name}/setup/language" - ) - csrf_token = machine.succeed( - "grep ip_csrf_cookie cjar | cut -f 7 | tr -d '\n'" - ) - machine.succeed( - f"curl -sSfL --cookie cjar --cookie-jar cjar -d '_ip_csrf={csrf_token}&ip_lang=english&btn_continue=Continue' {site_name}/setup/language" - ) - csrf_token = machine.succeed( - "grep ip_csrf_cookie cjar | cut -f 7 | tr -d '\n'" - ) - machine.succeed( - f"curl -sSfL --cookie cjar --cookie-jar cjar -d '_ip_csrf={csrf_token}&btn_continue=Continue' {site_name}/setup/prerequisites" - ) - csrf_token = machine.succeed( - "grep ip_csrf_cookie cjar | cut -f 7 | tr -d '\n'" - ) - machine.succeed( - f"curl -sSfL --cookie cjar --cookie-jar cjar -d '_ip_csrf={csrf_token}&btn_continue=Continue' {site_name}/setup/configure_database" - ) - csrf_token = machine.succeed( - "grep ip_csrf_cookie cjar | cut -f 7 | tr -d '\n'" - ) - machine.succeed( - f"curl -sSfl --cookie cjar --cookie-jar cjar -d '_ip_csrf={csrf_token}&btn_continue=Continue' {site_name}/setup/install_tables" - ) - csrf_token = machine.succeed( - "grep ip_csrf_cookie cjar | cut -f 7 | tr -d '\n'" - ) - machine.succeed( - f"curl -sSfl --cookie cjar --cookie-jar cjar -d '_ip_csrf={csrf_token}&btn_continue=Continue' {site_name}/setup/upgrade_tables" - ) - ''; -}) + with subtest("Finish InvoicePlane setup"): + machine.succeed( + f"curl -sSfL --cookie-jar cjar {site_name}/setup/language" + ) + csrf_token = machine.succeed( + "grep ip_csrf_cookie cjar | cut -f 7 | tr -d '\n'" + ) + machine.succeed( + f"curl -sSfL --cookie cjar --cookie-jar cjar -d '_ip_csrf={csrf_token}&ip_lang=english&btn_continue=Continue' {site_name}/setup/language" + ) + csrf_token = machine.succeed( + "grep ip_csrf_cookie cjar | cut -f 7 | tr -d '\n'" + ) + machine.succeed( + f"curl -sSfL --cookie cjar --cookie-jar cjar -d '_ip_csrf={csrf_token}&btn_continue=Continue' {site_name}/setup/prerequisites" + ) + csrf_token = machine.succeed( + "grep ip_csrf_cookie cjar | cut -f 7 | tr -d '\n'" + ) + machine.succeed( + f"curl -sSfL --cookie cjar --cookie-jar cjar -d '_ip_csrf={csrf_token}&btn_continue=Continue' {site_name}/setup/configure_database" + ) + csrf_token = machine.succeed( + "grep ip_csrf_cookie cjar | cut -f 7 | tr -d '\n'" + ) + machine.succeed( + f"curl -sSfl --cookie cjar --cookie-jar cjar -d '_ip_csrf={csrf_token}&btn_continue=Continue' {site_name}/setup/install_tables" + ) + csrf_token = machine.succeed( + "grep ip_csrf_cookie cjar | cut -f 7 | tr -d '\n'" + ) + machine.succeed( + f"curl -sSfl --cookie cjar --cookie-jar cjar -d '_ip_csrf={csrf_token}&btn_continue=Continue' {site_name}/setup/upgrade_tables" + ) + ''; + } +) diff --git a/nixos/tests/iodine.nix b/nixos/tests/iodine.nix index 41fb2e7778d42b..573f6d7aebeba3 100644 --- a/nixos/tests/iodine.nix +++ b/nixos/tests/iodine.nix @@ -1,64 +1,66 @@ import ./make-test-python.nix ( - { pkgs, ... }: let + { pkgs, ... }: + let domain = "whatever.example.com"; password = "false;foo;exit;withspecialcharacters"; in - { - name = "iodine"; - nodes = { - server = - { ... }: + { + name = "iodine"; + nodes = { + server = + { ... }: - { - networking.firewall = { - allowedUDPPorts = [ 53 ]; - trustedInterfaces = [ "dns0" ]; - }; - boot.kernel.sysctl = { - "net.ipv4.ip_forward" = 1; - "net.ipv6.ip_forward" = 1; - }; + { + networking.firewall = { + allowedUDPPorts = [ 53 ]; + trustedInterfaces = [ "dns0" ]; + }; + boot.kernel.sysctl = { + "net.ipv4.ip_forward" = 1; + "net.ipv6.ip_forward" = 1; + }; - services.iodine.server = { - enable = true; - ip = "10.53.53.1/24"; - passwordFile = "${builtins.toFile "password" password}"; - inherit domain; - }; + services.iodine.server = { + enable = true; + ip = "10.53.53.1/24"; + passwordFile = "${builtins.toFile "password" password}"; + inherit domain; + }; - # test resource: accessible only via tunnel - services.openssh = { - enable = true; - openFirewall = false; - }; - }; + # test resource: accessible only via tunnel + services.openssh = { + enable = true; + openFirewall = false; + }; + }; - client = - { ... }: { - services.iodine.clients.testClient = { - # test that ProtectHome is "read-only" - passwordFile = "/root/pw"; - relay = "server"; - server = domain; - }; - systemd.tmpfiles.rules = [ - "f /root/pw 0666 root root - ${password}" - ]; - environment.systemPackages = [ - pkgs.nagiosPluginsOfficial - ]; + client = + { ... }: + { + services.iodine.clients.testClient = { + # test that ProtectHome is "read-only" + passwordFile = "/root/pw"; + relay = "server"; + server = domain; }; + systemd.tmpfiles.rules = [ + "f /root/pw 0666 root root - ${password}" + ]; + environment.systemPackages = [ + pkgs.nagiosPluginsOfficial + ]; + }; - }; + }; - testScript = '' - start_all() + testScript = '' + start_all() - server.wait_for_unit("sshd") - server.wait_for_unit("iodined") - client.wait_for_unit("iodine-testClient") + server.wait_for_unit("sshd") + server.wait_for_unit("iodined") + client.wait_for_unit("iodine-testClient") - client.succeed("check_ssh -H 10.53.53.1") - ''; - } + client.succeed("check_ssh -H 10.53.53.1") + ''; + } ) diff --git a/nixos/tests/ipv6.nix b/nixos/tests/ipv6.nix index 8fa7eec8ffb2a8..cc0bf895c5e362 100644 --- a/nixos/tests/ipv6.nix +++ b/nixos/tests/ipv6.nix @@ -1,21 +1,22 @@ # Test of IPv6 functionality in NixOS, including whether router # solicication/advertisement using radvd works. -import ./make-test-python.nix ({ pkgs, lib, ...} : { - name = "ipv6"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; - - nodes = - { +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "ipv6"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; + + nodes = { # We use lib.mkForce here to remove the interface configuration # provided by makeTest, so that the interfaces are all configured # implicitly. # This client should use privacy extensions fully, having a # completely-default network configuration. - client_defaults.networking.interfaces = lib.mkForce {}; + client_defaults.networking.interfaces = lib.mkForce { }; # Both of these clients should obtain temporary addresses, but # not use them as the default source IP. We thus run the same @@ -24,7 +25,7 @@ import ./make-test-python.nix ({ pkgs, lib, ...} : { # Here, by using an altered default value for the global setting... client_global_setting = { - networking.interfaces = lib.mkForce {}; + networking.interfaces = lib.mkForce { }; networking.tempAddresses = "enabled"; }; # and here, by setting this on the interface explicitly. @@ -35,30 +36,29 @@ import ./make-test-python.nix ({ pkgs, lib, ...} : { }; }; - server = - { services.httpd.enable = true; - services.httpd.adminAddr = "foo@example.org"; - networking.firewall.allowedTCPPorts = [ 80 ]; - # disable testing driver's default IPv6 address. - networking.interfaces.eth1.ipv6.addresses = lib.mkForce [ ]; - }; + server = { + services.httpd.enable = true; + services.httpd.adminAddr = "foo@example.org"; + networking.firewall.allowedTCPPorts = [ 80 ]; + # disable testing driver's default IPv6 address. + networking.interfaces.eth1.ipv6.addresses = lib.mkForce [ ]; + }; router = { ... }: - { services.radvd.enable = true; - services.radvd.config = - '' - interface eth1 { - AdvSendAdvert on; - # ULA prefix (RFC 4193). - prefix fd60:cc69:b537:1::/64 { }; - }; - ''; + { + services.radvd.enable = true; + services.radvd.config = '' + interface eth1 { + AdvSendAdvert on; + # ULA prefix (RFC 4193). + prefix fd60:cc69:b537:1::/64 { }; + }; + ''; }; }; - testScript = - '' + testScript = '' import re # Start the router first so that it respond to router solicitations. @@ -129,4 +129,5 @@ import ./make-test-python.nix ({ pkgs, lib, ...} : { # But using the EUI-64 one. client.succeed(f"ip route get 2001:db8:: | grep 'src {ip}'") ''; -}) + } +) diff --git a/nixos/tests/iscsi-multipath-root.nix b/nixos/tests/iscsi-multipath-root.nix index 494a539b57e006..56f9e1ae7cc185 100644 --- a/nixos/tests/iscsi-multipath-root.nix +++ b/nixos/tests/iscsi-multipath-root.nix @@ -11,257 +11,288 @@ import ./make-test-python.nix ( }; nodes = { - target = { config, pkgs, lib, ... }: { - virtualisation.vlans = [ 1 2 ]; - services.target = { - enable = true; - config = { - fabric_modules = [ ]; - storage_objects = [ - { - dev = "/dev/vdb"; - name = "test"; - plugin = "block"; - write_back = true; - wwn = "92b17c3f-6b40-4168-b082-ceeb7b495522"; - } - ]; - targets = [ - { - fabric = "iscsi"; - tpgs = [ - { - enable = true; - attributes = { - authentication = 0; - generate_node_acls = 1; - }; - luns = [ - { - alias = "94dfe06967"; - alua_tg_pt_gp_name = "default_tg_pt_gp"; - index = 0; - storage_object = "/backstores/block/test"; - } - ]; - node_acls = [ - { - mapped_luns = [ - { - alias = "d42f5bdf8a"; - index = 0; - tpg_lun = 0; - write_protect = false; - } - ]; - node_wwn = initiatorName; - } - ]; - portals = [ - { - ip_address = "0.0.0.0"; - iser = false; - offload = false; - port = 3260; - } - ]; - tag = 1; - } - ]; - wwn = targetName; - } - ]; + target = + { + config, + pkgs, + lib, + ... + }: + { + virtualisation.vlans = [ + 1 + 2 + ]; + services.target = { + enable = true; + config = { + fabric_modules = [ ]; + storage_objects = [ + { + dev = "/dev/vdb"; + name = "test"; + plugin = "block"; + write_back = true; + wwn = "92b17c3f-6b40-4168-b082-ceeb7b495522"; + } + ]; + targets = [ + { + fabric = "iscsi"; + tpgs = [ + { + enable = true; + attributes = { + authentication = 0; + generate_node_acls = 1; + }; + luns = [ + { + alias = "94dfe06967"; + alua_tg_pt_gp_name = "default_tg_pt_gp"; + index = 0; + storage_object = "/backstores/block/test"; + } + ]; + node_acls = [ + { + mapped_luns = [ + { + alias = "d42f5bdf8a"; + index = 0; + tpg_lun = 0; + write_protect = false; + } + ]; + node_wwn = initiatorName; + } + ]; + portals = [ + { + ip_address = "0.0.0.0"; + iser = false; + offload = false; + port = 3260; + } + ]; + tag = 1; + } + ]; + wwn = targetName; + } + ]; + }; }; + + networking.firewall.allowedTCPPorts = [ 3260 ]; + networking.firewall.allowedUDPPorts = [ 3260 ]; + + virtualisation.memorySize = 2048; + virtualisation.emptyDiskImages = [ 2048 ]; }; - networking.firewall.allowedTCPPorts = [ 3260 ]; - networking.firewall.allowedUDPPorts = [ 3260 ]; - - virtualisation.memorySize = 2048; - virtualisation.emptyDiskImages = [ 2048 ]; - }; - - initiatorAuto = { nodes, config, pkgs, ... }: { - virtualisation.vlans = [ 1 2 ]; - - services.multipath = { - enable = true; - defaults = '' - find_multipaths yes - user_friendly_names yes - ''; - pathGroups = [ - { - alias = 123456; - wwid = "3600140592b17c3f6b404168b082ceeb7"; - } + initiatorAuto = + { + nodes, + config, + pkgs, + ... + }: + { + virtualisation.vlans = [ + 1 + 2 ]; - }; - services.openiscsi = { - enable = true; - enableAutoLoginOut = true; - discoverPortal = "target"; - name = initiatorName; - }; + services.multipath = { + enable = true; + defaults = '' + find_multipaths yes + user_friendly_names yes + ''; + pathGroups = [ + { + alias = 123456; + wwid = "3600140592b17c3f6b404168b082ceeb7"; + } + ]; + }; - environment.systemPackages = with pkgs; [ - xfsprogs - ]; + services.openiscsi = { + enable = true; + enableAutoLoginOut = true; + discoverPortal = "target"; + name = initiatorName; + }; - environment.etc."initiator-root-disk-closure".source = nodes.initiatorRootDisk.config.system.build.toplevel; + environment.systemPackages = with pkgs; [ + xfsprogs + ]; - nix.settings = { - substituters = lib.mkForce [ ]; - hashed-mirrors = null; - connect-timeout = 1; - }; - }; + environment.etc."initiator-root-disk-closure".source = + nodes.initiatorRootDisk.config.system.build.toplevel; - initiatorRootDisk = { config, pkgs, modulesPath, lib, ... }: { - boot.initrd.network.enable = true; - boot.loader.grub.enable = false; + nix.settings = { + substituters = lib.mkForce [ ]; + hashed-mirrors = null; + connect-timeout = 1; + }; + }; - boot.kernelParams = lib.mkOverride 5 ( - [ + initiatorRootDisk = + { + config, + pkgs, + modulesPath, + lib, + ... + }: + { + boot.initrd.network.enable = true; + boot.loader.grub.enable = false; + + boot.kernelParams = lib.mkOverride 5 ([ "boot.shell_on_fail" "console=tty1" "ip=192.168.1.1:::255.255.255.0::ens9:none" "ip=192.168.2.1:::255.255.255.0::ens10:none" - ] - ); - - # defaults to true, puts some code in the initrd that tries to mount an overlayfs on /nix/store - virtualisation.writableStore = false; - virtualisation.vlans = [ 1 2 ]; - - services.multipath = { - enable = true; - defaults = '' - find_multipaths yes - user_friendly_names yes - ''; - pathGroups = [ - { - alias = 123456; - wwid = "3600140592b17c3f6b404168b082ceeb7"; - } + ]); + + # defaults to true, puts some code in the initrd that tries to mount an overlayfs on /nix/store + virtualisation.writableStore = false; + virtualisation.vlans = [ + 1 + 2 ]; - }; - fileSystems = lib.mkOverride 5 { - "/" = { - fsType = "xfs"; - device = "/dev/mapper/123456"; - options = [ "_netdev" ]; + services.multipath = { + enable = true; + defaults = '' + find_multipaths yes + user_friendly_names yes + ''; + pathGroups = [ + { + alias = 123456; + wwid = "3600140592b17c3f6b404168b082ceeb7"; + } + ]; + }; + + fileSystems = lib.mkOverride 5 { + "/" = { + fsType = "xfs"; + device = "/dev/mapper/123456"; + options = [ "_netdev" ]; + }; }; - }; - boot.initrd.extraFiles."etc/multipath/wwids".source = pkgs.writeText "wwids" "/3600140592b17c3f6b404168b082ceeb7/"; + boot.initrd.extraFiles."etc/multipath/wwids".source = + pkgs.writeText "wwids" "/3600140592b17c3f6b404168b082ceeb7/"; - boot.iscsi-initiator = { - discoverPortal = "target"; - name = initiatorName; - target = targetName; - extraIscsiCommands = '' - iscsiadm -m discovery -o update -t sendtargets -p 192.168.2.3 --login - ''; + boot.iscsi-initiator = { + discoverPortal = "target"; + name = initiatorName; + target = targetName; + extraIscsiCommands = '' + iscsiadm -m discovery -o update -t sendtargets -p 192.168.2.3 --login + ''; + }; }; - }; }; - testScript = { nodes, ... }: '' - target.start() - target.wait_for_unit("iscsi-target.service") - - initiatorAuto.start() - - initiatorAuto.wait_for_unit("iscsid.service") - initiatorAuto.wait_for_unit("iscsi.service") - initiatorAuto.get_unit_info("iscsi") - - # Expecting this to fail since we should already know about 192.168.1.3 - initiatorAuto.fail("iscsiadm -m discovery -o update -t sendtargets -p 192.168.1.3 --login") - # Expecting this to succeed since we don't yet know about 192.168.2.3 - initiatorAuto.succeed("iscsiadm -m discovery -o update -t sendtargets -p 192.168.2.3 --login") - - # /dev/sda is provided by iscsi on target - initiatorAuto.succeed("set -x; while ! test -e /dev/sda; do sleep 1; done") - - initiatorAuto.succeed("mkfs.xfs /dev/sda") - initiatorAuto.succeed("mkdir /mnt") - - # Start by verifying /dev/sda and /dev/sdb are both the same disk - initiatorAuto.succeed("mount /dev/sda /mnt") - initiatorAuto.succeed("touch /mnt/hi") - initiatorAuto.succeed("umount /mnt") - - initiatorAuto.succeed("mount /dev/sdb /mnt") - initiatorAuto.succeed("test -e /mnt/hi") - initiatorAuto.succeed("umount /mnt") - - initiatorAuto.succeed("systemctl restart multipathd") - initiatorAuto.succeed("systemd-cat multipath -ll") - - # Install our RootDisk machine to 123456, the alias to the device that multipath is now managing - initiatorAuto.succeed("mount /dev/mapper/123456 /mnt") - initiatorAuto.succeed("mkdir -p /mnt/etc/{multipath,iscsi}") - initiatorAuto.succeed("cp -r /etc/multipath/wwids /mnt/etc/multipath/wwids") - initiatorAuto.succeed("cp -r /etc/iscsi/{nodes,send_targets} /mnt/etc/iscsi") - initiatorAuto.succeed( - "nixos-install --no-bootloader --no-root-passwd --system /etc/initiator-root-disk-closure" - ) - initiatorAuto.succeed("umount /mnt") - initiatorAuto.shutdown() - - initiatorRootDisk.start() - initiatorRootDisk.wait_for_unit("multi-user.target") - initiatorRootDisk.wait_for_unit("iscsid") - - # Log in over both nodes - initiatorRootDisk.fail("iscsiadm -m discovery -o update -t sendtargets -p 192.168.1.3 --login") - initiatorRootDisk.fail("iscsiadm -m discovery -o update -t sendtargets -p 192.168.2.3 --login") - initiatorRootDisk.succeed("systemctl restart multipathd") - initiatorRootDisk.succeed("systemd-cat multipath -ll") - - # Verify we can write and sync the root disk - initiatorRootDisk.succeed("mkdir /scratch") - initiatorRootDisk.succeed("touch /scratch/both-up") - initiatorRootDisk.succeed("sync /scratch") - - # Verify we can write to the root with ens9 (sda, 192.168.1.3) down - initiatorRootDisk.succeed("ip link set ens9 down") - initiatorRootDisk.succeed("touch /scratch/ens9-down") - initiatorRootDisk.succeed("sync /scratch") - initiatorRootDisk.succeed("ip link set ens9 up") - - # todo: better way to wait until multipath notices the link is back - initiatorRootDisk.succeed("sleep 5") - initiatorRootDisk.succeed("touch /scratch/both-down") - initiatorRootDisk.succeed("sync /scratch") - - # Verify we can write to the root with ens10 (sdb, 192.168.2.3) down - initiatorRootDisk.succeed("ip link set ens10 down") - initiatorRootDisk.succeed("touch /scratch/ens10-down") - initiatorRootDisk.succeed("sync /scratch") - initiatorRootDisk.succeed("ip link set ens10 up") - initiatorRootDisk.succeed("touch /scratch/ens10-down") - initiatorRootDisk.succeed("sync /scratch") - - initiatorRootDisk.succeed("ip link set ens9 up") - initiatorRootDisk.succeed("ip link set ens10 up") - initiatorRootDisk.shutdown() - - # Verify we can boot with the target's eth1 down, forcing - # it to multipath via the second link - target.succeed("ip link set eth1 down") - initiatorRootDisk.start() - initiatorRootDisk.wait_for_unit("multi-user.target") - initiatorRootDisk.wait_for_unit("iscsid") - initiatorRootDisk.succeed("test -e /scratch/both-up") - ''; + testScript = + { nodes, ... }: + '' + target.start() + target.wait_for_unit("iscsi-target.service") + + initiatorAuto.start() + + initiatorAuto.wait_for_unit("iscsid.service") + initiatorAuto.wait_for_unit("iscsi.service") + initiatorAuto.get_unit_info("iscsi") + + # Expecting this to fail since we should already know about 192.168.1.3 + initiatorAuto.fail("iscsiadm -m discovery -o update -t sendtargets -p 192.168.1.3 --login") + # Expecting this to succeed since we don't yet know about 192.168.2.3 + initiatorAuto.succeed("iscsiadm -m discovery -o update -t sendtargets -p 192.168.2.3 --login") + + # /dev/sda is provided by iscsi on target + initiatorAuto.succeed("set -x; while ! test -e /dev/sda; do sleep 1; done") + + initiatorAuto.succeed("mkfs.xfs /dev/sda") + initiatorAuto.succeed("mkdir /mnt") + + # Start by verifying /dev/sda and /dev/sdb are both the same disk + initiatorAuto.succeed("mount /dev/sda /mnt") + initiatorAuto.succeed("touch /mnt/hi") + initiatorAuto.succeed("umount /mnt") + + initiatorAuto.succeed("mount /dev/sdb /mnt") + initiatorAuto.succeed("test -e /mnt/hi") + initiatorAuto.succeed("umount /mnt") + + initiatorAuto.succeed("systemctl restart multipathd") + initiatorAuto.succeed("systemd-cat multipath -ll") + + # Install our RootDisk machine to 123456, the alias to the device that multipath is now managing + initiatorAuto.succeed("mount /dev/mapper/123456 /mnt") + initiatorAuto.succeed("mkdir -p /mnt/etc/{multipath,iscsi}") + initiatorAuto.succeed("cp -r /etc/multipath/wwids /mnt/etc/multipath/wwids") + initiatorAuto.succeed("cp -r /etc/iscsi/{nodes,send_targets} /mnt/etc/iscsi") + initiatorAuto.succeed( + "nixos-install --no-bootloader --no-root-passwd --system /etc/initiator-root-disk-closure" + ) + initiatorAuto.succeed("umount /mnt") + initiatorAuto.shutdown() + + initiatorRootDisk.start() + initiatorRootDisk.wait_for_unit("multi-user.target") + initiatorRootDisk.wait_for_unit("iscsid") + + # Log in over both nodes + initiatorRootDisk.fail("iscsiadm -m discovery -o update -t sendtargets -p 192.168.1.3 --login") + initiatorRootDisk.fail("iscsiadm -m discovery -o update -t sendtargets -p 192.168.2.3 --login") + initiatorRootDisk.succeed("systemctl restart multipathd") + initiatorRootDisk.succeed("systemd-cat multipath -ll") + + # Verify we can write and sync the root disk + initiatorRootDisk.succeed("mkdir /scratch") + initiatorRootDisk.succeed("touch /scratch/both-up") + initiatorRootDisk.succeed("sync /scratch") + + # Verify we can write to the root with ens9 (sda, 192.168.1.3) down + initiatorRootDisk.succeed("ip link set ens9 down") + initiatorRootDisk.succeed("touch /scratch/ens9-down") + initiatorRootDisk.succeed("sync /scratch") + initiatorRootDisk.succeed("ip link set ens9 up") + + # todo: better way to wait until multipath notices the link is back + initiatorRootDisk.succeed("sleep 5") + initiatorRootDisk.succeed("touch /scratch/both-down") + initiatorRootDisk.succeed("sync /scratch") + + # Verify we can write to the root with ens10 (sdb, 192.168.2.3) down + initiatorRootDisk.succeed("ip link set ens10 down") + initiatorRootDisk.succeed("touch /scratch/ens10-down") + initiatorRootDisk.succeed("sync /scratch") + initiatorRootDisk.succeed("ip link set ens10 up") + initiatorRootDisk.succeed("touch /scratch/ens10-down") + initiatorRootDisk.succeed("sync /scratch") + + initiatorRootDisk.succeed("ip link set ens9 up") + initiatorRootDisk.succeed("ip link set ens10 up") + initiatorRootDisk.shutdown() + + # Verify we can boot with the target's eth1 down, forcing + # it to multipath via the second link + target.succeed("ip link set eth1 down") + initiatorRootDisk.start() + initiatorRootDisk.wait_for_unit("multi-user.target") + initiatorRootDisk.wait_for_unit("iscsid") + initiatorRootDisk.succeed("test -e /scratch/both-up") + ''; } ) - - diff --git a/nixos/tests/iscsi-root.nix b/nixos/tests/iscsi-root.nix index 6953b6ce9a0650..ab0ab9f89e9b77 100644 --- a/nixos/tests/iscsi-root.nix +++ b/nixos/tests/iscsi-root.nix @@ -1,161 +1,182 @@ import ./make-test-python.nix ( { pkgs, lib, ... }: - let - initiatorName = "iqn.2020-08.org.linux-iscsi.initiatorhost:example"; - targetName = "iqn.2003-01.org.linux-iscsi.target.x8664:sn.acf8fd9c23af"; - in - { - name = "iscsi"; - meta = { - maintainers = lib.teams.deshaw.members - ++ lib.teams.helsinki-systems.members; - }; - - nodes = { - target = { config, pkgs, lib, ... }: { - services.target = { - enable = true; - config = { - fabric_modules = []; - storage_objects = [ - { - dev = "/dev/vdb"; - name = "test"; - plugin = "block"; - write_back = true; - wwn = "92b17c3f-6b40-4168-b082-ceeb7b495522"; - } - ]; - targets = [ - { - fabric = "iscsi"; - tpgs = [ - { - enable = true; - attributes = { - authentication = 0; - generate_node_acls = 1; - }; - luns = [ - { - alias = "94dfe06967"; - alua_tg_pt_gp_name = "default_tg_pt_gp"; - index = 0; - storage_object = "/backstores/block/test"; - } - ]; - node_acls = [ - { - mapped_luns = [ - { - alias = "d42f5bdf8a"; - index = 0; - tpg_lun = 0; - write_protect = false; - } - ]; - node_wwn = initiatorName; - } - ]; - portals = [ - { - ip_address = "[::]"; - iser = false; - offload = false; - port = 3260; - } - ]; - tag = 1; - } - ]; - wwn = targetName; - } - ]; - }; + let + initiatorName = "iqn.2020-08.org.linux-iscsi.initiatorhost:example"; + targetName = "iqn.2003-01.org.linux-iscsi.target.x8664:sn.acf8fd9c23af"; + in + { + name = "iscsi"; + meta = { + maintainers = lib.teams.deshaw.members ++ lib.teams.helsinki-systems.members; + }; + + nodes = { + target = + { + config, + pkgs, + lib, + ... + }: + { + services.target = { + enable = true; + config = { + fabric_modules = [ ]; + storage_objects = [ + { + dev = "/dev/vdb"; + name = "test"; + plugin = "block"; + write_back = true; + wwn = "92b17c3f-6b40-4168-b082-ceeb7b495522"; + } + ]; + targets = [ + { + fabric = "iscsi"; + tpgs = [ + { + enable = true; + attributes = { + authentication = 0; + generate_node_acls = 1; + }; + luns = [ + { + alias = "94dfe06967"; + alua_tg_pt_gp_name = "default_tg_pt_gp"; + index = 0; + storage_object = "/backstores/block/test"; + } + ]; + node_acls = [ + { + mapped_luns = [ + { + alias = "d42f5bdf8a"; + index = 0; + tpg_lun = 0; + write_protect = false; + } + ]; + node_wwn = initiatorName; + } + ]; + portals = [ + { + ip_address = "[::]"; + iser = false; + offload = false; + port = 3260; + } + ]; + tag = 1; + } + ]; + wwn = targetName; + } + ]; }; + }; - networking.firewall.allowedTCPPorts = [ 3260 ]; - networking.firewall.allowedUDPPorts = [ 3260 ]; + networking.firewall.allowedTCPPorts = [ 3260 ]; + networking.firewall.allowedUDPPorts = [ 3260 ]; - virtualisation.memorySize = 2048; - virtualisation.emptyDiskImages = [ 2048 ]; - }; + virtualisation.memorySize = 2048; + virtualisation.emptyDiskImages = [ 2048 ]; + }; - initiatorAuto = { nodes, config, pkgs, ... }: { - services.openiscsi = { - enable = true; - enableAutoLoginOut = true; - discoverPortal = "target"; - name = initiatorName; - }; + initiatorAuto = + { + nodes, + config, + pkgs, + ... + }: + { + services.openiscsi = { + enable = true; + enableAutoLoginOut = true; + discoverPortal = "target"; + name = initiatorName; + }; - environment.systemPackages = with pkgs; [ - xfsprogs - ]; + environment.systemPackages = with pkgs; [ + xfsprogs + ]; - system.extraDependencies = [ nodes.initiatorRootDisk.system.build.toplevel ]; + system.extraDependencies = [ nodes.initiatorRootDisk.system.build.toplevel ]; - nix.settings = { - substituters = lib.mkForce []; - hashed-mirrors = null; - connect-timeout = 1; - }; + nix.settings = { + substituters = lib.mkForce [ ]; + hashed-mirrors = null; + connect-timeout = 1; }; + }; - initiatorRootDisk = { config, pkgs, modulesPath, lib, ... }: { - boot.loader.grub.enable = false; - boot.kernelParams = lib.mkOverride 5 ( - [ - "boot.shell_on_fail" - "console=tty1" - "ip=${config.networking.primaryIPAddress}:::255.255.255.0::eth1:none" - ] - ); - - # defaults to true, puts some code in the initrd that tries to mount an overlayfs on /nix/store - virtualisation.writableStore = false; - - fileSystems = lib.mkOverride 5 { - "/" = { - fsType = "xfs"; - device = "/dev/sda"; - options = [ "_netdev" ]; - }; + initiatorRootDisk = + { + config, + pkgs, + modulesPath, + lib, + ... + }: + { + boot.loader.grub.enable = false; + boot.kernelParams = lib.mkOverride 5 ([ + "boot.shell_on_fail" + "console=tty1" + "ip=${config.networking.primaryIPAddress}:::255.255.255.0::eth1:none" + ]); + + # defaults to true, puts some code in the initrd that tries to mount an overlayfs on /nix/store + virtualisation.writableStore = false; + + fileSystems = lib.mkOverride 5 { + "/" = { + fsType = "xfs"; + device = "/dev/sda"; + options = [ "_netdev" ]; }; + }; - boot.iscsi-initiator = { - discoverPortal = "target"; - name = initiatorName; - target = targetName; - }; + boot.iscsi-initiator = { + discoverPortal = "target"; + name = initiatorName; + target = targetName; }; }; - - testScript = { nodes, ... }: '' - target.start() - target.wait_for_unit("iscsi-target.service") - - initiatorAuto.start() - - initiatorAuto.wait_for_unit("iscsid.service") - initiatorAuto.wait_for_unit("iscsi.service") - initiatorAuto.get_unit_info("iscsi") - - initiatorAuto.succeed("set -x; while ! test -e /dev/sda; do sleep 1; done") - - initiatorAuto.succeed("mkfs.xfs /dev/sda") - initiatorAuto.succeed("mkdir /mnt && mount /dev/sda /mnt") - initiatorAuto.succeed( - "nixos-install --no-bootloader --no-root-passwd --system ${nodes.initiatorRootDisk.config.system.build.toplevel}" - ) - initiatorAuto.succeed("umount /mnt && rmdir /mnt") - initiatorAuto.shutdown() - - initiatorRootDisk.start() - initiatorRootDisk.wait_for_unit("multi-user.target") - initiatorRootDisk.wait_for_unit("iscsid") - initiatorRootDisk.succeed("touch test") - initiatorRootDisk.shutdown() - ''; - } + }; + + testScript = + { nodes, ... }: + '' + target.start() + target.wait_for_unit("iscsi-target.service") + + initiatorAuto.start() + + initiatorAuto.wait_for_unit("iscsid.service") + initiatorAuto.wait_for_unit("iscsi.service") + initiatorAuto.get_unit_info("iscsi") + + initiatorAuto.succeed("set -x; while ! test -e /dev/sda; do sleep 1; done") + + initiatorAuto.succeed("mkfs.xfs /dev/sda") + initiatorAuto.succeed("mkdir /mnt && mount /dev/sda /mnt") + initiatorAuto.succeed( + "nixos-install --no-bootloader --no-root-passwd --system ${nodes.initiatorRootDisk.config.system.build.toplevel}" + ) + initiatorAuto.succeed("umount /mnt && rmdir /mnt") + initiatorAuto.shutdown() + + initiatorRootDisk.start() + initiatorRootDisk.wait_for_unit("multi-user.target") + initiatorRootDisk.wait_for_unit("iscsid") + initiatorRootDisk.succeed("touch test") + initiatorRootDisk.shutdown() + ''; + } ) diff --git a/nixos/tests/isolate.nix b/nixos/tests/isolate.nix index 327231be1cd4a0..c6f83240ad0877 100644 --- a/nixos/tests/isolate.nix +++ b/nixos/tests/isolate.nix @@ -1,38 +1,40 @@ -import ./make-test-python.nix ({ lib, ... }: -{ - name = "isolate"; - meta.maintainers = with lib.maintainers; [ virchau13 ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "isolate"; + meta.maintainers = with lib.maintainers; [ virchau13 ]; - nodes.machine = - { ... }: - { - security.isolate = { - enable = true; + nodes.machine = + { ... }: + { + security.isolate = { + enable = true; + }; }; - }; - testScript = '' - bash_path = machine.succeed('realpath $(which bash)').strip() - sleep_path = machine.succeed('realpath $(which sleep)').strip() - def sleep_test(walltime, sleeptime): - return f'isolate --no-default-dirs --wall-time {walltime} ' + \ - f'--dir=/box={box_path} --dir=/nix=/nix --run -- ' + \ - f"{bash_path} -c 'exec -a sleep {sleep_path} {sleeptime}'" + testScript = '' + bash_path = machine.succeed('realpath $(which bash)').strip() + sleep_path = machine.succeed('realpath $(which sleep)').strip() + def sleep_test(walltime, sleeptime): + return f'isolate --no-default-dirs --wall-time {walltime} ' + \ + f'--dir=/box={box_path} --dir=/nix=/nix --run -- ' + \ + f"{bash_path} -c 'exec -a sleep {sleep_path} {sleeptime}'" - def sleep_test_cg(walltime, sleeptime): - return f'isolate --cg --no-default-dirs --wall-time {walltime} ' + \ - f'--dir=/box={box_path} --dir=/nix=/nix --processes=2 --run -- ' + \ - f"{bash_path} -c '( exec -a sleep {sleep_path} {sleeptime} )'" + def sleep_test_cg(walltime, sleeptime): + return f'isolate --cg --no-default-dirs --wall-time {walltime} ' + \ + f'--dir=/box={box_path} --dir=/nix=/nix --processes=2 --run -- ' + \ + f"{bash_path} -c '( exec -a sleep {sleep_path} {sleeptime} )'" - with subtest("without cgroups"): - box_path = machine.succeed('isolate --init').strip() - machine.succeed(sleep_test(1, 0.5)) - machine.fail(sleep_test(0.5, 1)) - machine.succeed('isolate --cleanup') - with subtest("with cgroups"): - box_path = machine.succeed('isolate --cg --init').strip() - machine.succeed(sleep_test_cg(1, 0.5)) - machine.fail(sleep_test_cg(0.5, 1)) - machine.succeed('isolate --cg --cleanup') - ''; -}) + with subtest("without cgroups"): + box_path = machine.succeed('isolate --init').strip() + machine.succeed(sleep_test(1, 0.5)) + machine.fail(sleep_test(0.5, 1)) + machine.succeed('isolate --cleanup') + with subtest("with cgroups"): + box_path = machine.succeed('isolate --cg --init').strip() + machine.succeed(sleep_test_cg(1, 0.5)) + machine.fail(sleep_test_cg(0.5, 1)) + machine.succeed('isolate --cg --cleanup') + ''; + } +) diff --git a/nixos/tests/isso.nix b/nixos/tests/isso.nix index 4ec8b5ec3593dd..f3af293bf75bb0 100644 --- a/nixos/tests/isso.nix +++ b/nixos/tests/isso.nix @@ -1,30 +1,36 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "isso"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "isso"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; - nodes.machine = { config, pkgs, ... }: { - services.isso = { - enable = true; - settings = { - general = { - dbpath = "/var/lib/isso/comments.db"; - host = "http://localhost"; + nodes.machine = + { config, pkgs, ... }: + { + services.isso = { + enable = true; + settings = { + general = { + dbpath = "/var/lib/isso/comments.db"; + host = "http://localhost"; + }; + }; }; }; - }; - }; - testScript = let - port = 8080; - in - '' - machine.wait_for_unit("isso.service") + testScript = + let + port = 8080; + in + '' + machine.wait_for_unit("isso.service") - machine.wait_for_open_port(${toString port}) + machine.wait_for_open_port(${toString port}) - machine.succeed("curl --fail http://localhost:${toString port}/?uri") - machine.succeed("curl --fail http://localhost:${toString port}/js/embed.min.js") - ''; -}) + machine.succeed("curl --fail http://localhost:${toString port}/?uri") + machine.succeed("curl --fail http://localhost:${toString port}/js/embed.min.js") + ''; + } +) diff --git a/nixos/tests/jackett.nix b/nixos/tests/jackett.nix index 4e65cb61d17a77..11931c7c96bdd1 100644 --- a/nixos/tests/jackett.nix +++ b/nixos/tests/jackett.nix @@ -1,21 +1,25 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -let - jackettPort = 9117; -in { - name = "jackett"; - meta.maintainers = with lib.maintainers; [ etu ]; + let + jackettPort = 9117; + in + { + name = "jackett"; + meta.maintainers = with lib.maintainers; [ etu ]; - nodes.machine = - { pkgs, ... }: { - services.jackett.enable = true; - services.jackett.port = jackettPort; - }; + nodes.machine = + { pkgs, ... }: + { + services.jackett.enable = true; + services.jackett.port = jackettPort; + }; - testScript = '' - machine.start() - machine.wait_for_unit("jackett.service") - machine.wait_for_open_port(${toString jackettPort}) - machine.succeed("curl --fail http://localhost:${toString jackettPort}/") - ''; -}) + testScript = '' + machine.start() + machine.wait_for_unit("jackett.service") + machine.wait_for_open_port(${toString jackettPort}) + machine.succeed("curl --fail http://localhost:${toString jackettPort}/") + ''; + } +) diff --git a/nixos/tests/jellyfin.nix b/nixos/tests/jellyfin.nix index 7d3097b586299d..2b879ff83751c1 100644 --- a/nixos/tests/jellyfin.nix +++ b/nixos/tests/jellyfin.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: +import ./make-test-python.nix ( + { lib, pkgs, ... }: { name = "jellyfin"; @@ -16,9 +17,11 @@ import ./make-test-python.nix ({ lib, pkgs, ... }: testScript = let payloads = { - auth = pkgs.writeText "auth.json" (builtins.toJSON { - Username = "jellyfin"; - }); + auth = pkgs.writeText "auth.json" ( + builtins.toJSON { + Username = "jellyfin"; + } + ); empty = pkgs.writeText "empty.json" (builtins.toJSON { }); }; in @@ -152,4 +155,5 @@ import ./make-test-python.nix ({ lib, pkgs, ... }: if duration.strip() != "5.000000": raise Exception("Downloaded video has wrong duration") ''; - }) + } +) diff --git a/nixos/tests/jenkins-cli.nix b/nixos/tests/jenkins-cli.nix index f25e1604da330a..fdd2767cf04195 100644 --- a/nixos/tests/jenkins-cli.nix +++ b/nixos/tests/jenkins-cli.nix @@ -1,30 +1,33 @@ -import ./make-test-python.nix ({ pkgs, ...} : rec { - name = "jenkins-cli"; - meta = with pkgs.lib.maintainers; { - maintainers = [ pamplemousse ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + rec { + name = "jenkins-cli"; + meta = with pkgs.lib.maintainers; { + maintainers = [ pamplemousse ]; + }; - nodes = { - machine = - { ... }: - { - services.jenkins = { - enable = true; - withCLI = true; + nodes = { + machine = + { ... }: + { + services.jenkins = { + enable = true; + withCLI = true; + }; }; - }; - }; + }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("jenkins") + machine.wait_for_unit("jenkins") - assert "JENKINS_URL" in machine.succeed("env") - assert "http://0.0.0.0:8080" in machine.succeed("echo $JENKINS_URL") + assert "JENKINS_URL" in machine.succeed("env") + assert "http://0.0.0.0:8080" in machine.succeed("echo $JENKINS_URL") - machine.succeed( - "jenkins-cli -auth admin:$(cat /var/lib/jenkins/secrets/initialAdminPassword)" - ) - ''; -}) + machine.succeed( + "jenkins-cli -auth admin:$(cat /var/lib/jenkins/secrets/initialAdminPassword)" + ) + ''; + } +) diff --git a/nixos/tests/jibri.nix b/nixos/tests/jibri.nix index 2046ea86d5acf2..d42e82bf1f47a0 100644 --- a/nixos/tests/jibri.nix +++ b/nixos/tests/jibri.nix @@ -1,66 +1,74 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "jibri"; - meta = with pkgs.lib; { - maintainers = teams.jitsi.members; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "jibri"; + meta = with pkgs.lib; { + maintainers = teams.jitsi.members; + }; - nodes.machine = { config, pkgs, ... }: { - virtualisation.memorySize = 5120; + nodes.machine = + { config, pkgs, ... }: + { + virtualisation.memorySize = 5120; - services.jitsi-meet = { - enable = true; - hostName = "machine"; - jibri.enable = true; - }; - services.jibri.ignoreCert = true; - services.jitsi-videobridge.openFirewall = true; + services.jitsi-meet = { + enable = true; + hostName = "machine"; + jibri.enable = true; + }; + services.jibri.ignoreCert = true; + services.jitsi-videobridge.openFirewall = true; - networking.firewall.allowedTCPPorts = [ 80 443 ]; + networking.firewall.allowedTCPPorts = [ + 80 + 443 + ]; - services.nginx.virtualHosts.machine = { - enableACME = true; - forceSSL = true; - }; + services.nginx.virtualHosts.machine = { + enableACME = true; + forceSSL = true; + }; - security.acme.defaults.email = "me@example.org"; - security.acme.acceptTerms = true; - security.acme.defaults.server = "https://example.com"; # self-signed only - }; + security.acme.defaults.email = "me@example.org"; + security.acme.acceptTerms = true; + security.acme.defaults.server = "https://example.com"; # self-signed only + }; - testScript = '' - machine.wait_for_unit("jitsi-videobridge2.service") - machine.wait_for_unit("jicofo.service") - machine.wait_for_unit("nginx.service") - machine.wait_for_unit("prosody.service") - machine.wait_for_unit("jibri.service") + testScript = '' + machine.wait_for_unit("jitsi-videobridge2.service") + machine.wait_for_unit("jicofo.service") + machine.wait_for_unit("nginx.service") + machine.wait_for_unit("prosody.service") + machine.wait_for_unit("jibri.service") - machine.wait_until_succeeds( - "journalctl -b -u prosody -o cat | grep -q 'Authenticated as focus@auth.machine'", timeout=31 - ) - machine.wait_until_succeeds( - "journalctl -b -u prosody -o cat | grep -q 'Authenticated as jvb@auth.machine'", timeout=32 - ) - machine.wait_until_succeeds( - "journalctl -b -u prosody -o cat | grep -q 'Authenticated as jibri@auth.machine'", timeout=33 - ) - machine.wait_until_succeeds( - "cat /var/log/jitsi/jibri/log.0.txt | grep -q 'Joined MUC: jibribrewery@internal.auth.machine'", timeout=34 - ) + machine.wait_until_succeeds( + "journalctl -b -u prosody -o cat | grep -q 'Authenticated as focus@auth.machine'", timeout=31 + ) + machine.wait_until_succeeds( + "journalctl -b -u prosody -o cat | grep -q 'Authenticated as jvb@auth.machine'", timeout=32 + ) + machine.wait_until_succeeds( + "journalctl -b -u prosody -o cat | grep -q 'Authenticated as jibri@auth.machine'", timeout=33 + ) + machine.wait_until_succeeds( + "cat /var/log/jitsi/jibri/log.0.txt | grep -q 'Joined MUC: jibribrewery@internal.auth.machine'", timeout=34 + ) - assert '"busyStatus":"IDLE","health":{"healthStatus":"HEALTHY"' in machine.succeed( - "curl -X GET http://machine:2222/jibri/api/v1.0/health" - ) - machine.succeed( - """curl -H "Content-Type: application/json" -X POST http://localhost:2222/jibri/api/v1.0/startService -d '{"sessionId": "RecordTest","callParams":{"callUrlInfo":{"baseUrl": "https://machine","callName": "TestCall"}},"callLoginParams":{"domain": "recorder.machine", "username": "recorder", "password": "'"$(cat /var/lib/jitsi-meet/jibri-recorder-secret)"'" },"sinkType": "file"}'""" - ) - machine.wait_until_succeeds( - "cat /var/log/jitsi/jibri/log.0.txt | grep -q 'File recording service transitioning from state Starting up to Running'", timeout=35 - ) - machine.succeed( - """sleep 15 && curl -H "Content-Type: application/json" -X POST http://localhost:2222/jibri/api/v1.0/stopService -d '{"sessionId": "RecordTest","callParams":{"callUrlInfo":{"baseUrl": "https://machine","callName": "TestCall"}},"callLoginParams":{"domain": "recorder.machine", "username": "recorder", "password": "'"$(cat /var/lib/jitsi-meet/jibri-recorder-secret)"'" },"sinkType": "file"}'""" - ) - machine.wait_until_succeeds( - "cat /var/log/jitsi/jibri/log.0.txt | grep -q 'Finalize script finished with exit value 0'", timeout=36 - ) - ''; -}) + assert '"busyStatus":"IDLE","health":{"healthStatus":"HEALTHY"' in machine.succeed( + "curl -X GET http://machine:2222/jibri/api/v1.0/health" + ) + machine.succeed( + """curl -H "Content-Type: application/json" -X POST http://localhost:2222/jibri/api/v1.0/startService -d '{"sessionId": "RecordTest","callParams":{"callUrlInfo":{"baseUrl": "https://machine","callName": "TestCall"}},"callLoginParams":{"domain": "recorder.machine", "username": "recorder", "password": "'"$(cat /var/lib/jitsi-meet/jibri-recorder-secret)"'" },"sinkType": "file"}'""" + ) + machine.wait_until_succeeds( + "cat /var/log/jitsi/jibri/log.0.txt | grep -q 'File recording service transitioning from state Starting up to Running'", timeout=35 + ) + machine.succeed( + """sleep 15 && curl -H "Content-Type: application/json" -X POST http://localhost:2222/jibri/api/v1.0/stopService -d '{"sessionId": "RecordTest","callParams":{"callUrlInfo":{"baseUrl": "https://machine","callName": "TestCall"}},"callLoginParams":{"domain": "recorder.machine", "username": "recorder", "password": "'"$(cat /var/lib/jitsi-meet/jibri-recorder-secret)"'" },"sinkType": "file"}'""" + ) + machine.wait_until_succeeds( + "cat /var/log/jitsi/jibri/log.0.txt | grep -q 'Finalize script finished with exit value 0'", timeout=36 + ) + ''; + } +) diff --git a/nixos/tests/jirafeau.nix b/nixos/tests/jirafeau.nix index dbfaf515e25769..ba15b837d10f7c 100644 --- a/nixos/tests/jirafeau.nix +++ b/nixos/tests/jirafeau.nix @@ -1,20 +1,24 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "jirafeau"; - meta.maintainers = with lib.maintainers; [ davidtwco ]; + { + name = "jirafeau"; + meta.maintainers = with lib.maintainers; [ davidtwco ]; - nodes.machine = { pkgs, ... }: { - services.jirafeau = { - enable = true; - }; - }; + nodes.machine = + { pkgs, ... }: + { + services.jirafeau = { + enable = true; + }; + }; - testScript = '' - machine.start() - machine.wait_for_unit("phpfpm-jirafeau.service") - machine.wait_for_unit("nginx.service") - machine.wait_for_open_port(80) - machine.succeed("curl -sSfL http://localhost/ | grep 'Jirafeau'") - ''; -}) + testScript = '' + machine.start() + machine.wait_for_unit("phpfpm-jirafeau.service") + machine.wait_for_unit("nginx.service") + machine.wait_for_open_port(80) + machine.succeed("curl -sSfL http://localhost/ | grep 'Jirafeau'") + ''; + } +) diff --git a/nixos/tests/jitsi-meet.nix b/nixos/tests/jitsi-meet.nix index fc6654f2c076cb..a9934700ecf34e 100644 --- a/nixos/tests/jitsi-meet.nix +++ b/nixos/tests/jitsi-meet.nix @@ -1,68 +1,80 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "jitsi-meet"; - meta = with pkgs.lib; { - maintainers = teams.jitsi.members; - }; - - nodes = { - client = { nodes, pkgs, ... }: { +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "jitsi-meet"; + meta = with pkgs.lib; { + maintainers = teams.jitsi.members; }; - server = { config, pkgs, ... }: { - services.jitsi-meet = { - enable = true; - hostName = "server"; - }; - services.jitsi-videobridge.openFirewall = true; - networking.firewall.allowedTCPPorts = [ 80 443 ]; + nodes = { + client = + { nodes, pkgs, ... }: + { + }; + server = + { config, pkgs, ... }: + { + services.jitsi-meet = { + enable = true; + hostName = "server"; + }; + services.jitsi-videobridge.openFirewall = true; - services.nginx.virtualHosts.server = { - enableACME = true; - forceSSL = true; - }; + networking.firewall.allowedTCPPorts = [ + 80 + 443 + ]; - security.acme.acceptTerms = true; - security.acme.defaults.email = "me@example.org"; - security.acme.defaults.server = "https://example.com"; # self-signed only + services.nginx.virtualHosts.server = { + enableACME = true; + forceSSL = true; + }; - specialisation.caddy = { - inheritParentConfig = true; - configuration = { - services.jitsi-meet = { - caddy.enable = true; - nginx.enable = false; + security.acme.acceptTerms = true; + security.acme.defaults.email = "me@example.org"; + security.acme.defaults.server = "https://example.com"; # self-signed only + + specialisation.caddy = { + inheritParentConfig = true; + configuration = { + services.jitsi-meet = { + caddy.enable = true; + nginx.enable = false; + }; + services.caddy.virtualHosts.${config.services.jitsi-meet.hostName}.extraConfig = '' + tls internal + ''; + }; }; - services.caddy.virtualHosts.${config.services.jitsi-meet.hostName}.extraConfig = '' - tls internal - ''; }; - }; }; - }; - testScript = { nodes, ... }: '' - server.wait_for_unit("jitsi-videobridge2.service") - server.wait_for_unit("jicofo.service") - server.wait_for_unit("nginx.service") - server.wait_for_unit("prosody.service") + testScript = + { nodes, ... }: + '' + server.wait_for_unit("jitsi-videobridge2.service") + server.wait_for_unit("jicofo.service") + server.wait_for_unit("nginx.service") + server.wait_for_unit("prosody.service") - server.wait_until_succeeds( - "journalctl -b -u prosody -o cat | grep -q 'Authenticated as focus@auth.server'" - ) - server.wait_until_succeeds( - "journalctl -b -u prosody -o cat | grep -q 'Authenticated as jvb@auth.server'" - ) + server.wait_until_succeeds( + "journalctl -b -u prosody -o cat | grep -q 'Authenticated as focus@auth.server'" + ) + server.wait_until_succeeds( + "journalctl -b -u prosody -o cat | grep -q 'Authenticated as jvb@auth.server'" + ) - client.wait_for_unit("network.target") + client.wait_for_unit("network.target") - def client_curl(): - assert "Jitsi Meet" in client.succeed("curl -sSfkL http://server/") + def client_curl(): + assert "Jitsi Meet" in client.succeed("curl -sSfkL http://server/") - client_curl() - - with subtest("Testing backup service"): - server.succeed("${nodes.server.system.build.toplevel}/specialisation/caddy/bin/switch-to-configuration test") - server.wait_for_unit("caddy.service") client_curl() - ''; -}) + + with subtest("Testing backup service"): + server.succeed("${nodes.server.system.build.toplevel}/specialisation/caddy/bin/switch-to-configuration test") + server.wait_for_unit("caddy.service") + client_curl() + ''; + } +) diff --git a/nixos/tests/jool.nix b/nixos/tests/jool.nix index 37a4ad6ce01113..3bbfc946901140 100644 --- a/nixos/tests/jool.nix +++ b/nixos/tests/jool.nix @@ -44,7 +44,10 @@ in # Border relay nodes.relay = { - virtualisation.vlans = [ 1 2 ]; + virtualisation.vlans = [ + 1 + 2 + ]; # Enable packet routing boot.kernel.sysctl = { @@ -54,8 +57,18 @@ in networking.useDHCP = false; networking.interfaces = lib.mkVMOverride { - eth1.ipv6.addresses = [ { address = "fd::198.51.100.1"; prefixLength = 120; } ]; - eth2.ipv4.addresses = [ { address = "192.0.2.1"; prefixLength = 24; } ]; + eth1.ipv6.addresses = [ + { + address = "fd::198.51.100.1"; + prefixLength = 120; + } + ]; + eth2.ipv4.addresses = [ + { + address = "192.0.2.1"; + prefixLength = 24; + } + ]; }; networking.jool.enable = true; @@ -64,25 +77,51 @@ in # IPv6 only node nodes.alice = { - imports = [ ipv6Only (webserver 6 "Hello, Bob!") ]; + imports = [ + ipv6Only + (webserver 6 "Hello, Bob!") + ]; virtualisation.vlans = [ 1 ]; networking.interfaces.eth1.ipv6 = { - addresses = [ { address = "fd::198.51.100.8"; prefixLength = 120; } ]; - routes = [ { address = "fd::192.0.2.0"; prefixLength = 120; - via = "fd::198.51.100.1"; } ]; + addresses = [ + { + address = "fd::198.51.100.8"; + prefixLength = 120; + } + ]; + routes = [ + { + address = "fd::192.0.2.0"; + prefixLength = 120; + via = "fd::198.51.100.1"; + } + ]; }; }; # IPv4 only node nodes.bob = { - imports = [ ipv4Only (webserver 4 "Hello, Alice!") ]; + imports = [ + ipv4Only + (webserver 4 "Hello, Alice!") + ]; virtualisation.vlans = [ 2 ]; networking.interfaces.eth1.ipv4 = { - addresses = [ { address = "192.0.2.16"; prefixLength = 24; } ]; - routes = [ { address = "198.51.100.0"; prefixLength = 24; - via = "192.0.2.1"; } ]; + addresses = [ + { + address = "192.0.2.16"; + prefixLength = 24; + } + ]; + routes = [ + { + address = "198.51.100.0"; + prefixLength = 24; + via = "192.0.2.1"; + } + ]; }; }; @@ -125,7 +164,10 @@ in # Router nodes.router = { - virtualisation.vlans = [ 1 2 ]; + virtualisation.vlans = [ + 1 + 2 + ]; # Enable packet routing boot.kernel.sysctl = { @@ -135,26 +177,53 @@ in networking.useDHCP = false; networking.interfaces = lib.mkVMOverride { - eth1.ipv6.addresses = [ { address = "2001:db8::1"; prefixLength = 96; } ]; - eth2.ipv4.addresses = [ { address = "203.0.113.1"; prefixLength = 24; } ]; + eth1.ipv6.addresses = [ + { + address = "2001:db8::1"; + prefixLength = 96; + } + ]; + eth2.ipv4.addresses = [ + { + address = "203.0.113.1"; + prefixLength = 24; + } + ]; }; networking.jool.enable = true; networking.jool.nat64.default = { bib = [ - { # forward HTTP 203.0.113.1 (router) → 2001:db8::9 (homeserver) - "protocol" = "TCP"; + { + # forward HTTP 203.0.113.1 (router) → 2001:db8::9 (homeserver) + "protocol" = "TCP"; "ipv4 address" = "203.0.113.1#80"; "ipv6 address" = "2001:db8::9#80"; } ]; pool4 = [ # Ports for dynamic translation - { protocol = "TCP"; prefix = "203.0.113.1/32"; "port range" = "40001-65535"; } - { protocol = "UDP"; prefix = "203.0.113.1/32"; "port range" = "40001-65535"; } - { protocol = "ICMP"; prefix = "203.0.113.1/32"; "port range" = "40001-65535"; } + { + protocol = "TCP"; + prefix = "203.0.113.1/32"; + "port range" = "40001-65535"; + } + { + protocol = "UDP"; + prefix = "203.0.113.1/32"; + "port range" = "40001-65535"; + } + { + protocol = "ICMP"; + prefix = "203.0.113.1/32"; + "port range" = "40001-65535"; + } # Ports for static BIB entries - { protocol = "TCP"; prefix = "203.0.113.1/32"; "port range" = "80"; } + { + protocol = "TCP"; + prefix = "203.0.113.1/32"; + "port range" = "80"; + } ]; }; }; @@ -165,37 +234,61 @@ in virtualisation.vlans = [ 1 ]; networking.interfaces.eth1.ipv6 = { - addresses = lib.mkForce [ { address = "2001:db8::8"; prefixLength = 96; } ]; - routes = lib.mkForce [ { - address = "64:ff9b::"; - prefixLength = 96; - via = "2001:db8::1"; - } ]; + addresses = lib.mkForce [ + { + address = "2001:db8::8"; + prefixLength = 96; + } + ]; + routes = lib.mkForce [ + { + address = "64:ff9b::"; + prefixLength = 96; + via = "2001:db8::1"; + } + ]; }; }; # LAN server (IPv6 only) nodes.homeserver = { - imports = [ ipv6Only (webserver 6 "Hello from IPv6!") ]; + imports = [ + ipv6Only + (webserver 6 "Hello from IPv6!") + ]; virtualisation.vlans = [ 1 ]; networking.interfaces.eth1.ipv6 = { - addresses = lib.mkForce [ { address = "2001:db8::9"; prefixLength = 96; } ]; - routes = lib.mkForce [ { - address = "64:ff9b::"; - prefixLength = 96; - via = "2001:db8::1"; - } ]; + addresses = lib.mkForce [ + { + address = "2001:db8::9"; + prefixLength = 96; + } + ]; + routes = lib.mkForce [ + { + address = "64:ff9b::"; + prefixLength = 96; + via = "2001:db8::1"; + } + ]; }; }; # WAN server (IPv4 only) nodes.server = { - imports = [ ipv4Only (webserver 4 "Hello from IPv4!") ]; + imports = [ + ipv4Only + (webserver 4 "Hello from IPv4!") + ]; virtualisation.vlans = [ 2 ]; - networking.interfaces.eth1.ipv4.addresses = - [ { address = "203.0.113.16"; prefixLength = 24; } ]; + networking.interfaces.eth1.ipv4.addresses = [ + { + address = "203.0.113.16"; + prefixLength = 24; + } + ]; }; testScript = '' diff --git a/nixos/tests/jotta-cli.nix b/nixos/tests/jotta-cli.nix index 0df23ee2cba5c2..27f576f93a538e 100644 --- a/nixos/tests/jotta-cli.nix +++ b/nixos/tests/jotta-cli.nix @@ -1,25 +1,33 @@ -import ./make-test-python.nix ({ pkgs, ... }: { +import ./make-test-python.nix ( + { pkgs, ... }: + { - name = "jotta-cli"; - meta.maintainers = with pkgs.lib.maintainers; [ evenbrenden ]; + name = "jotta-cli"; + meta.maintainers = with pkgs.lib.maintainers; [ evenbrenden ]; - nodes.machine = { pkgs, ... }: { - services.jotta-cli.enable = true; - imports = [ ./common/user-account.nix ]; - }; + nodes.machine = + { pkgs, ... }: + { + services.jotta-cli.enable = true; + imports = [ ./common/user-account.nix ]; + }; - testScript = { nodes, ... }: - let uid = toString nodes.machine.users.users.alice.uid; - in '' - machine.start() + testScript = + { nodes, ... }: + let + uid = toString nodes.machine.users.users.alice.uid; + in + '' + machine.start() - machine.succeed("loginctl enable-linger alice") - machine.wait_for_unit("user@${uid}.service") + machine.succeed("loginctl enable-linger alice") + machine.wait_for_unit("user@${uid}.service") - machine.wait_for_unit("jottad.service", "alice") - machine.wait_for_open_unix_socket("/run/user/${uid}/jottad/jottad.socket") + machine.wait_for_unit("jottad.service", "alice") + machine.wait_for_open_unix_socket("/run/user/${uid}/jottad/jottad.socket") - # "jotta-cli version" should fail if jotta-cli cannot connect to jottad - machine.succeed('XDG_RUNTIME_DIR=/run/user/${uid} su alice -c "jotta-cli version"') - ''; -}) + # "jotta-cli version" should fail if jotta-cli cannot connect to jottad + machine.succeed('XDG_RUNTIME_DIR=/run/user/${uid} su alice -c "jotta-cli version"') + ''; + } +) diff --git a/nixos/tests/kanidm.nix b/nixos/tests/kanidm.nix index abbc8dc8a4769d..b3b4e0213cbfa3 100644 --- a/nixos/tests/kanidm.nix +++ b/nixos/tests/kanidm.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: let certs = import ./common/acme/server/snakeoil-certs.nix; serverDomain = certs.domain; @@ -16,58 +17,72 @@ import ./make-test-python.nix ({ pkgs, ... }: in { name = "kanidm"; - meta.maintainers = with pkgs.lib.maintainers; [ Flakebi oddlama ]; - - nodes.server = { pkgs, ... }: { - services.kanidm = { - enableServer = true; - serverSettings = { - origin = "https://${serverDomain}"; - domain = serverDomain; - bindaddress = "[::]:443"; - ldapbindaddress = "[::1]:636"; - tls_chain = "${certsPath}/snakeoil.crt"; - tls_key = "${certsPath}/snakeoil.key"; + meta.maintainers = with pkgs.lib.maintainers; [ + Flakebi + oddlama + ]; + + nodes.server = + { pkgs, ... }: + { + services.kanidm = { + enableServer = true; + serverSettings = { + origin = "https://${serverDomain}"; + domain = serverDomain; + bindaddress = "[::]:443"; + ldapbindaddress = "[::1]:636"; + tls_chain = "${certsPath}/snakeoil.crt"; + tls_key = "${certsPath}/snakeoil.key"; + }; }; - }; - security.pki.certificateFiles = [ certs.ca.cert ]; + security.pki.certificateFiles = [ certs.ca.cert ]; - networking.hosts."::1" = [ serverDomain ]; - networking.firewall.allowedTCPPorts = [ 443 ]; + networking.hosts."::1" = [ serverDomain ]; + networking.firewall.allowedTCPPorts = [ 443 ]; - users.users.kanidm.shell = pkgs.bashInteractive; + users.users.kanidm.shell = pkgs.bashInteractive; - environment.systemPackages = with pkgs; [ kanidm openldap ripgrep ]; - }; + environment.systemPackages = with pkgs; [ + kanidm + openldap + ripgrep + ]; + }; - nodes.client = { nodes, ... }: { - services.kanidm = { - enableClient = true; - clientSettings = { - uri = "https://${serverDomain}"; - verify_ca = true; - verify_hostnames = true; - }; - enablePam = true; - unixSettings = { - pam_allowed_login_groups = [ "shell" ]; + nodes.client = + { nodes, ... }: + { + services.kanidm = { + enableClient = true; + clientSettings = { + uri = "https://${serverDomain}"; + verify_ca = true; + verify_hostnames = true; + }; + enablePam = true; + unixSettings = { + pam_allowed_login_groups = [ "shell" ]; + }; }; - }; - networking.hosts."${nodes.server.networking.primaryIPAddress}" = [ serverDomain ]; + networking.hosts."${nodes.server.networking.primaryIPAddress}" = [ serverDomain ]; - security.pki.certificateFiles = [ certs.ca.cert ]; - }; + security.pki.certificateFiles = [ certs.ca.cert ]; + }; - testScript = { nodes, ... }: + testScript = + { nodes, ... }: let - ldapBaseDN = builtins.concatStringsSep "," (map (s: "dc=" + s) (pkgs.lib.splitString "." serverDomain)); + ldapBaseDN = builtins.concatStringsSep "," ( + map (s: "dc=" + s) (pkgs.lib.splitString "." serverDomain) + ); # We need access to the config file in the test script. - filteredConfig = pkgs.lib.converge - (pkgs.lib.filterAttrsRecursive (_: v: v != null)) - nodes.server.services.kanidm.serverSettings; + filteredConfig = pkgs.lib.converge (pkgs.lib.filterAttrsRecursive ( + _: v: v != null + )) nodes.server.services.kanidm.serverSettings; serverConfigFile = (pkgs.formats.toml { }).generate "server.toml" filteredConfig; in '' @@ -133,4 +148,5 @@ import ./make-test-python.nix ({ pkgs, ... }: server.shutdown() client.shutdown() ''; - }) + } +) diff --git a/nixos/tests/karma.nix b/nixos/tests/karma.nix index 5ac2983b8aa3ee..2e80aa97fbb589 100644 --- a/nixos/tests/karma.nix +++ b/nixos/tests/karma.nix @@ -1,84 +1,89 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "karma"; - nodes = { - server = { ... }: { - services.prometheus.alertmanager = { - enable = true; - logLevel = "debug"; - port = 9093; - openFirewall = true; - configuration = { - global = { - resolve_timeout = "1m"; - }; - route = { - # Root route node - receiver = "test"; - group_by = ["..."]; - continue = false; - group_wait = "1s"; - group_interval="15s"; - repeat_interval = "24h"; - }; - receivers = [ - { - name = "test"; - webhook_configs = [ +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "karma"; + nodes = { + server = + { ... }: + { + services.prometheus.alertmanager = { + enable = true; + logLevel = "debug"; + port = 9093; + openFirewall = true; + configuration = { + global = { + resolve_timeout = "1m"; + }; + route = { + # Root route node + receiver = "test"; + group_by = [ "..." ]; + continue = false; + group_wait = "1s"; + group_interval = "15s"; + repeat_interval = "24h"; + }; + receivers = [ { - url = "http://localhost:1234"; - send_resolved = true; - max_alerts = 0; + name = "test"; + webhook_configs = [ + { + url = "http://localhost:1234"; + send_resolved = true; + max_alerts = 0; + } + ]; } ]; - } - ]; - }; - }; - services.karma = { - enable = true; - openFirewall = true; - settings = { - listen = { - address = "0.0.0.0"; - port = 8081; + }; }; - alertmanager = { - servers = [ - { - name = "alertmanager"; - uri = "https://127.0.0.1:9093"; - } - ]; + services.karma = { + enable = true; + openFirewall = true; + settings = { + listen = { + address = "0.0.0.0"; + port = 8081; + }; + alertmanager = { + servers = [ + { + name = "alertmanager"; + uri = "https://127.0.0.1:9093"; + } + ]; + }; + karma.name = "test-dashboard"; + log.config = true; + log.requests = true; + log.timestamp = true; + }; }; - karma.name = "test-dashboard"; - log.config = true; - log.requests = true; - log.timestamp = true; }; - }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - with subtest("Wait for server to come up"): + with subtest("Wait for server to come up"): - server.wait_for_unit("alertmanager.service") - server.wait_for_unit("karma.service") + server.wait_for_unit("alertmanager.service") + server.wait_for_unit("karma.service") - server.sleep(5) # wait for both services to settle + server.sleep(5) # wait for both services to settle - server.wait_for_open_port(9093) - server.wait_for_open_port(8081) + server.wait_for_open_port(9093) + server.wait_for_open_port(8081) - with subtest("Test alertmanager readiness"): - server.succeed("curl -s http://127.0.0.1:9093/-/ready") + with subtest("Test alertmanager readiness"): + server.succeed("curl -s http://127.0.0.1:9093/-/ready") - # Karma only starts serving the dashboard once it has established connectivity to all alertmanagers in its config - # Therefore, this will fail if karma isn't able to reach alertmanager - server.succeed("curl -s http://127.0.0.1:8081") + # Karma only starts serving the dashboard once it has established connectivity to all alertmanagers in its config + # Therefore, this will fail if karma isn't able to reach alertmanager + server.succeed("curl -s http://127.0.0.1:8081") - server.shutdown() - ''; -}) + server.shutdown() + ''; + } +) diff --git a/nixos/tests/kavita.nix b/nixos/tests/kavita.nix index bb55e1fb29d434..f9f51ebb80f867 100644 --- a/nixos/tests/kavita.nix +++ b/nixos/tests/kavita.nix @@ -1,42 +1,47 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "kavita"; - meta = with pkgs.lib.maintainers; { - maintainers = [ misterio77 ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "kavita"; + meta = with pkgs.lib.maintainers; { + maintainers = [ misterio77 ]; + }; - nodes = { - kavita = { config, pkgs, ... }: { - services.kavita = { - enable = true; - tokenKeyFile = builtins.toFile "kavita.key" "d26ba694b455271a8872415830fb7b5c58f8da98f9ef7f58b2ca4c34bd406512"; - }; + nodes = { + kavita = + { config, pkgs, ... }: + { + services.kavita = { + enable = true; + tokenKeyFile = builtins.toFile "kavita.key" "d26ba694b455271a8872415830fb7b5c58f8da98f9ef7f58b2ca4c34bd406512"; + }; + }; }; - }; - testScript = - let - regUrl = "http://kavita:5000/api/Account/register"; - loginUrl = "http://kavita:5000/api/Account/login"; - localeUrl = "http://kavita:5000/api/locale"; - in - '' - import json + testScript = + let + regUrl = "http://kavita:5000/api/Account/register"; + loginUrl = "http://kavita:5000/api/Account/login"; + localeUrl = "http://kavita:5000/api/locale"; + in + '' + import json - kavita.start - kavita.wait_for_unit("kavita.service") + kavita.start + kavita.wait_for_unit("kavita.service") - # Check that static assets are working - kavita.wait_until_succeeds("curl http://kavita:5000/site.webmanifest | grep Kavita") + # Check that static assets are working + kavita.wait_until_succeeds("curl http://kavita:5000/site.webmanifest | grep Kavita") - # Check that registration is working - kavita.succeed("""curl -fX POST ${regUrl} --json '{"username": "foo", "password": "correcthorsebatterystaple"}'""") - # But only for the first one - kavita.fail("""curl -fX POST ${regUrl} --json '{"username": "foo", "password": "correcthorsebatterystaple"}'""") + # Check that registration is working + kavita.succeed("""curl -fX POST ${regUrl} --json '{"username": "foo", "password": "correcthorsebatterystaple"}'""") + # But only for the first one + kavita.fail("""curl -fX POST ${regUrl} --json '{"username": "foo", "password": "correcthorsebatterystaple"}'""") - # Log in and retrieve token - session = json.loads(kavita.succeed("""curl -fX POST ${loginUrl} --json '{"username": "foo", "password": "correcthorsebatterystaple"}'""")) - # Check list of locales - locales = json.loads(kavita.succeed(f"curl -fX GET ${localeUrl} -H 'Authorization: Bearer {session['token']}'")) - assert len(locales) > 0, "expected a list of locales" - ''; -}) + # Log in and retrieve token + session = json.loads(kavita.succeed("""curl -fX POST ${loginUrl} --json '{"username": "foo", "password": "correcthorsebatterystaple"}'""")) + # Check list of locales + locales = json.loads(kavita.succeed(f"curl -fX GET ${localeUrl} -H 'Authorization: Bearer {session['token']}'")) + assert len(locales) > 0, "expected a list of locales" + ''; + } +) diff --git a/nixos/tests/kbd-setfont-decompress.nix b/nixos/tests/kbd-setfont-decompress.nix index 810ef39cc11a3b..07ecf2c8979dec 100644 --- a/nixos/tests/kbd-setfont-decompress.nix +++ b/nixos/tests/kbd-setfont-decompress.nix @@ -1,21 +1,23 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -{ - name = "kbd-setfont-decompress"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "kbd-setfont-decompress"; - meta.maintainers = with lib.maintainers; [ oxalica ]; + meta.maintainers = with lib.maintainers; [ oxalica ]; - nodes.machine = { ... }: {}; + nodes.machine = { ... }: { }; - testScript = '' - machine.succeed("gzip -cd ${pkgs.terminus_font}/share/consolefonts/ter-v16b.psf.gz >font.psf") - machine.succeed("gzip font.psf.gz") - machine.succeed("bzip2 font.psf.bz2") - machine.succeed("xz font.psf.xz") - machine.succeed("zstd font.psf.zst") - # setfont returns 0 even on error. - assert machine.succeed("PATH= ${pkgs.kbd}/bin/setfont font.psf.gz 2>&1") == "" - assert machine.succeed("PATH= ${pkgs.kbd}/bin/setfont font.psf.bz2 2>&1") == "" - assert machine.succeed("PATH= ${pkgs.kbd}/bin/setfont font.psf.xz 2>&1") == "" - assert machine.succeed("PATH= ${pkgs.kbd}/bin/setfont font.psf.zst 2>&1") == "" - ''; -}) + testScript = '' + machine.succeed("gzip -cd ${pkgs.terminus_font}/share/consolefonts/ter-v16b.psf.gz >font.psf") + machine.succeed("gzip font.psf.gz") + machine.succeed("bzip2 font.psf.bz2") + machine.succeed("xz font.psf.xz") + machine.succeed("zstd font.psf.zst") + # setfont returns 0 even on error. + assert machine.succeed("PATH= ${pkgs.kbd}/bin/setfont font.psf.gz 2>&1") == "" + assert machine.succeed("PATH= ${pkgs.kbd}/bin/setfont font.psf.bz2 2>&1") == "" + assert machine.succeed("PATH= ${pkgs.kbd}/bin/setfont font.psf.xz 2>&1") == "" + assert machine.succeed("PATH= ${pkgs.kbd}/bin/setfont font.psf.zst 2>&1") == "" + ''; + } +) diff --git a/nixos/tests/kbd-update-search-paths-patch.nix b/nixos/tests/kbd-update-search-paths-patch.nix index 746a809c4cdf7e..da2cf99b44a693 100644 --- a/nixos/tests/kbd-update-search-paths-patch.nix +++ b/nixos/tests/kbd-update-search-paths-patch.nix @@ -1,19 +1,24 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "kbd-update-search-paths-patch"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "kbd-update-search-paths-patch"; - nodes.machine = { pkgs, options, ... }: { - console = { - packages = options.console.packages.default ++ [ pkgs.terminus_font ]; - }; - }; + nodes.machine = + { pkgs, options, ... }: + { + console = { + packages = options.console.packages.default ++ [ pkgs.terminus_font ]; + }; + }; - testScript = '' - command = "${pkgs.kbd}/bin/setfont ter-112n 2>&1" - (status, out) = machine.execute(command) - import re - pattern = re.compile(r".*Unable to find file:.*") - match = pattern.match(out) - if match: - raise Exception("command `{}` failed".format(command)) - ''; -}) + testScript = '' + command = "${pkgs.kbd}/bin/setfont ter-112n 2>&1" + (status, out) = machine.execute(command) + import re + pattern = re.compile(r".*Unable to find file:.*") + match = pattern.match(out) + if match: + raise Exception("command `{}` failed".format(command)) + ''; + } +) diff --git a/nixos/tests/kea.nix b/nixos/tests/kea.nix index 653e280ec8b7ea..51db35bede69a1 100644 --- a/nixos/tests/kea.nix +++ b/nixos/tests/kea.nix @@ -5,209 +5,230 @@ # that the nameserver can resolve the clients fqdn to the correct IP # address. -import ./make-test-python.nix ({ pkgs, lib, ...}: { - meta.maintainers = with lib.maintainers; [ hexa ]; - - name = "kea"; - - nodes = { - router = { config, pkgs, ... }: { - virtualisation.vlans = [ 1 ]; - - networking = { - useDHCP = false; - firewall.allowedUDPPorts = [ 67 ]; - }; - - systemd.network = { - enable = true; - networks = { - "01-eth1" = { - name = "eth1"; - networkConfig = { - Address = "10.0.0.1/29"; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + meta.maintainers = with lib.maintainers; [ hexa ]; + + name = "kea"; + + nodes = { + router = + { config, pkgs, ... }: + { + virtualisation.vlans = [ 1 ]; + + networking = { + useDHCP = false; + firewall.allowedUDPPorts = [ 67 ]; }; - }; - }; - - services.kea.dhcp4 = { - enable = true; - settings = { - valid-lifetime = 3600; - renew-timer = 900; - rebind-timer = 1800; - - lease-database = { - type = "memfile"; - persist = true; - name = "/var/lib/kea/dhcp4.leases"; + + systemd.network = { + enable = true; + networks = { + "01-eth1" = { + name = "eth1"; + networkConfig = { + Address = "10.0.0.1/29"; + }; + }; + }; }; - control-socket = { - socket-type = "unix"; - socket-name = "/run/kea/dhcp4.sock"; + services.kea.dhcp4 = { + enable = true; + settings = { + valid-lifetime = 3600; + renew-timer = 900; + rebind-timer = 1800; + + lease-database = { + type = "memfile"; + persist = true; + name = "/var/lib/kea/dhcp4.leases"; + }; + + control-socket = { + socket-type = "unix"; + socket-name = "/run/kea/dhcp4.sock"; + }; + + interfaces-config = { + dhcp-socket-type = "raw"; + interfaces = [ + "eth1" + ]; + }; + + subnet4 = [ + { + id = 1; + subnet = "10.0.0.0/29"; + pools = [ + { + pool = "10.0.0.3 - 10.0.0.3"; + } + ]; + } + ]; + + # Enable communication between dhcp4 and a local dhcp-ddns + # instance. + # https://kea.readthedocs.io/en/kea-2.2.0/arm/dhcp4-srv.html#ddns-for-dhcpv4 + dhcp-ddns = { + enable-updates = true; + }; + + ddns-send-updates = true; + ddns-qualifying-suffix = "lan.nixos.test."; + }; }; - interfaces-config = { - dhcp-socket-type = "raw"; - interfaces = [ - "eth1" - ]; + services.kea.dhcp-ddns = { + enable = true; + settings = { + forward-ddns = { + # Configure updates of a forward zone named `lan.nixos.test` + # hosted at the nameserver at 10.0.0.2 + # https://kea.readthedocs.io/en/kea-2.2.0/arm/ddns.html#adding-forward-dns-servers + ddns-domains = [ + { + name = "lan.nixos.test."; + # Use a TSIG key in production! + key-name = ""; + dns-servers = [ + { + ip-address = "10.0.0.2"; + port = 53; + } + ]; + } + ]; + }; + }; }; - subnet4 = [ { - id = 1; - subnet = "10.0.0.0/29"; - pools = [ { - pool = "10.0.0.3 - 10.0.0.3"; - } ]; - } ]; - - # Enable communication between dhcp4 and a local dhcp-ddns - # instance. - # https://kea.readthedocs.io/en/kea-2.2.0/arm/dhcp4-srv.html#ddns-for-dhcpv4 - dhcp-ddns = { - enable-updates = true; + services.kea.ctrl-agent = { + enable = true; + settings = { + http-host = "127.0.0.1"; + http-port = 8000; + control-sockets.dhcp4 = { + socket-type = "unix"; + socket-name = "/run/kea/dhcp4.sock"; + }; + }; }; - ddns-send-updates = true; - ddns-qualifying-suffix = "lan.nixos.test."; - }; - }; - - services.kea.dhcp-ddns = { - enable = true; - settings = { - forward-ddns = { - # Configure updates of a forward zone named `lan.nixos.test` - # hosted at the nameserver at 10.0.0.2 - # https://kea.readthedocs.io/en/kea-2.2.0/arm/ddns.html#adding-forward-dns-servers - ddns-domains = [ { - name = "lan.nixos.test."; - # Use a TSIG key in production! - key-name = ""; - dns-servers = [ { - ip-address = "10.0.0.2"; - port = 53; - } ]; - } ]; + services.prometheus.exporters.kea = { + enable = true; + controlSocketPaths = [ + "http://127.0.0.1:8000" + ]; }; }; - }; - - services.kea.ctrl-agent = { - enable = true; - settings = { - http-host = "127.0.0.1"; - http-port = 8000; - control-sockets.dhcp4 = { - socket-type = "unix"; - socket-name = "/run/kea/dhcp4.sock"; + + nameserver = + { config, pkgs, ... }: + { + virtualisation.vlans = [ 1 ]; + + networking = { + useDHCP = false; + firewall.allowedUDPPorts = [ 53 ]; }; - }; - }; - - services.prometheus.exporters.kea = { - enable = true; - controlSocketPaths = [ - "http://127.0.0.1:8000" - ]; - }; - }; - nameserver = { config, pkgs, ... }: { - virtualisation.vlans = [ 1 ]; - - networking = { - useDHCP = false; - firewall.allowedUDPPorts = [ 53 ]; - }; - - systemd.network = { - enable = true; - networks = { - "01-eth1" = { - name = "eth1"; - networkConfig = { - Address = "10.0.0.2/29"; + systemd.network = { + enable = true; + networks = { + "01-eth1" = { + name = "eth1"; + networkConfig = { + Address = "10.0.0.2/29"; + }; + }; }; }; - }; - }; - - services.resolved.enable = false; - - # Set up an authoritative nameserver, serving the `lan.nixos.test` - # zone and configure an ACL that allows dynamic updates from - # the router's ip address. - # This ACL is likely insufficient for production usage. Please - # use TSIG keys. - services.knot = let - zone = pkgs.writeTextDir "lan.nixos.test.zone" '' - @ SOA ns.nixos.test nox.nixos.test 0 86400 7200 3600000 172800 - @ NS nameserver - nameserver A 10.0.0.3 - router A 10.0.0.1 - ''; - zonesDir = pkgs.buildEnv { - name = "knot-zones"; - paths = [ zone ]; - }; - in { - enable = true; - extraArgs = [ - "-v" - ]; - settings = { - server.listen = [ - "0.0.0.0@53" - ]; - - log.syslog.any = "info"; - - acl.dhcp_ddns = { - address = "10.0.0.1"; - action = "update"; - }; - template.default = { - storage = zonesDir; - zonefile-sync = "-1"; - zonefile-load = "difference-no-serial"; - journal-content = "all"; - }; + services.resolved.enable = false; + + # Set up an authoritative nameserver, serving the `lan.nixos.test` + # zone and configure an ACL that allows dynamic updates from + # the router's ip address. + # This ACL is likely insufficient for production usage. Please + # use TSIG keys. + services.knot = + let + zone = pkgs.writeTextDir "lan.nixos.test.zone" '' + @ SOA ns.nixos.test nox.nixos.test 0 86400 7200 3600000 172800 + @ NS nameserver + nameserver A 10.0.0.3 + router A 10.0.0.1 + ''; + zonesDir = pkgs.buildEnv { + name = "knot-zones"; + paths = [ zone ]; + }; + in + { + enable = true; + extraArgs = [ + "-v" + ]; + settings = { + server.listen = [ + "0.0.0.0@53" + ]; + + log.syslog.any = "info"; + + acl.dhcp_ddns = { + address = "10.0.0.1"; + action = "update"; + }; + + template.default = { + storage = zonesDir; + zonefile-sync = "-1"; + zonefile-load = "difference-no-serial"; + journal-content = "all"; + }; + + zone."lan.nixos.test" = { + file = "lan.nixos.test.zone"; + acl = [ + "dhcp_ddns" + ]; + }; + }; + }; - zone."lan.nixos.test" = { - file = "lan.nixos.test.zone"; - acl = [ - "dhcp_ddns" - ]; - }; }; - }; - - }; - client = { config, pkgs, ... }: { - virtualisation.vlans = [ 1 ]; - systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; - networking = { - useNetworkd = true; - useDHCP = false; - firewall.enable = false; - interfaces.eth1.useDHCP = true; - }; + client = + { config, pkgs, ... }: + { + virtualisation.vlans = [ 1 ]; + systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; + networking = { + useNetworkd = true; + useDHCP = false; + firewall.enable = false; + interfaces.eth1.useDHCP = true; + }; + }; }; - }; - testScript = { ... }: '' - start_all() - router.wait_for_unit("kea-dhcp4-server.service") - client.wait_for_unit("systemd-networkd-wait-online.service") - client.wait_until_succeeds("ping -c 5 10.0.0.1") - router.wait_until_succeeds("ping -c 5 10.0.0.3") - nameserver.wait_until_succeeds("kdig +short client.lan.nixos.test @10.0.0.2 | grep -q 10.0.0.3") - router.log(router.execute("curl 127.0.0.1:9547")[1]) - router.succeed("curl --no-buffer 127.0.0.1:9547 | grep -qE '^kea_dhcp4_addresses_assigned_total.*1.0$'") - ''; -}) + testScript = + { ... }: + '' + start_all() + router.wait_for_unit("kea-dhcp4-server.service") + client.wait_for_unit("systemd-networkd-wait-online.service") + client.wait_until_succeeds("ping -c 5 10.0.0.1") + router.wait_until_succeeds("ping -c 5 10.0.0.3") + nameserver.wait_until_succeeds("kdig +short client.lan.nixos.test @10.0.0.2 | grep -q 10.0.0.3") + router.log(router.execute("curl 127.0.0.1:9547")[1]) + router.succeed("curl --no-buffer 127.0.0.1:9547 | grep -qE '^kea_dhcp4_addresses_assigned_total.*1.0$'") + ''; + } +) diff --git a/nixos/tests/keepassxc.nix b/nixos/tests/keepassxc.nix index d487d87fbacbd0..c2d68e29b79833 100644 --- a/nixos/tests/keepassxc.nix +++ b/nixos/tests/keepassxc.nix @@ -1,88 +1,94 @@ -import ./make-test-python.nix ({ pkgs, ...} : - -{ - name = "keepassxc"; - meta = with pkgs.lib.maintainers; { - maintainers = [ turion ]; - timeout = 1800; - }; - - nodes.machine = { ... }: +import ./make-test-python.nix ( + { pkgs, ... }: { - imports = [ - ./common/user-account.nix - ./common/x11.nix - ]; - - services.xserver.enable = true; - - # for better OCR - environment.etc."icewm/prefoverride".text = '' - ColorActiveTitleBar = "rgb:FF/FF/FF" - ''; - - # Regression test for https://github.com/NixOS/nixpkgs/issues/163482 - qt = { - enable = true; - platformTheme = "gnome"; - style = "adwaita-dark"; + name = "keepassxc"; + meta = with pkgs.lib.maintainers; { + maintainers = [ turion ]; + timeout = 1800; }; - test-support.displayManager.auto.user = "alice"; - environment.systemPackages = with pkgs; [ - keepassxc - xdotool - ]; - }; - - enableOCR = true; - - testScript = { nodes, ... }: let - aliceDo = cmd: ''machine.succeed("su - alice -c '${cmd}' >&2 &");''; - in '' - with subtest("Ensure X starts"): - start_all() - machine.wait_for_x() - - with subtest("Can create database and entry with CLI"): - ${aliceDo "keepassxc-cli db-create --set-key-file foo.keyfile foo.kdbx"} - ${aliceDo "keepassxc-cli add --no-password -k foo.keyfile foo.kdbx bar"} - - with subtest("Ensure KeePassXC starts"): - # start KeePassXC window - ${aliceDo "keepassxc >&2 &"} - - machine.wait_for_text("KeePassXC ${pkgs.keepassxc.version}") - machine.screenshot("KeePassXC") - - with subtest("Can open existing database"): - machine.send_key("ctrl-o") - machine.sleep(5) - # Regression #163482: keepassxc did not crash - machine.succeed("ps -e | grep keepassxc") - machine.wait_for_text("Open database") - machine.send_key("ret") - - # Wait for the enter password screen to appear. - machine.wait_for_text("/home/alice/foo.kdbx") - - # Click on "I have key file" button to open keyfile dialog - machine.send_key("tab") - machine.send_key("tab") - machine.send_key("tab") - machine.send_key("ret") - - # Select keyfile - machine.wait_for_text("Select key file") - machine.send_chars("/home/alice/foo.keyfile") - machine.send_key("ret") - - # Open database - machine.wait_for_text("foo.kdbx \\[Locked] - KeePassXC") - machine.send_key("ret") - - # Database is unlocked (doesn't have "[Locked]" in the title anymore) - machine.wait_for_text("foo.kdbx - KeePassXC") - ''; -}) + nodes.machine = + { ... }: + + { + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; + + services.xserver.enable = true; + + # for better OCR + environment.etc."icewm/prefoverride".text = '' + ColorActiveTitleBar = "rgb:FF/FF/FF" + ''; + + # Regression test for https://github.com/NixOS/nixpkgs/issues/163482 + qt = { + enable = true; + platformTheme = "gnome"; + style = "adwaita-dark"; + }; + + test-support.displayManager.auto.user = "alice"; + environment.systemPackages = with pkgs; [ + keepassxc + xdotool + ]; + }; + + enableOCR = true; + + testScript = + { nodes, ... }: + let + aliceDo = cmd: ''machine.succeed("su - alice -c '${cmd}' >&2 &");''; + in + '' + with subtest("Ensure X starts"): + start_all() + machine.wait_for_x() + + with subtest("Can create database and entry with CLI"): + ${aliceDo "keepassxc-cli db-create --set-key-file foo.keyfile foo.kdbx"} + ${aliceDo "keepassxc-cli add --no-password -k foo.keyfile foo.kdbx bar"} + + with subtest("Ensure KeePassXC starts"): + # start KeePassXC window + ${aliceDo "keepassxc >&2 &"} + + machine.wait_for_text("KeePassXC ${pkgs.keepassxc.version}") + machine.screenshot("KeePassXC") + + with subtest("Can open existing database"): + machine.send_key("ctrl-o") + machine.sleep(5) + # Regression #163482: keepassxc did not crash + machine.succeed("ps -e | grep keepassxc") + machine.wait_for_text("Open database") + machine.send_key("ret") + + # Wait for the enter password screen to appear. + machine.wait_for_text("/home/alice/foo.kdbx") + + # Click on "I have key file" button to open keyfile dialog + machine.send_key("tab") + machine.send_key("tab") + machine.send_key("tab") + machine.send_key("ret") + + # Select keyfile + machine.wait_for_text("Select key file") + machine.send_chars("/home/alice/foo.keyfile") + machine.send_key("ret") + + # Open database + machine.wait_for_text("foo.kdbx \\[Locked] - KeePassXC") + machine.send_key("ret") + + # Database is unlocked (doesn't have "[Locked]" in the title anymore) + machine.wait_for_text("foo.kdbx - KeePassXC") + ''; + } +) diff --git a/nixos/tests/kerberos/default.nix b/nixos/tests/kerberos/default.nix index e21d25c519b571..26c6ad33d8a781 100644 --- a/nixos/tests/kerberos/default.nix +++ b/nixos/tests/kerberos/default.nix @@ -1,5 +1,6 @@ -{ system ? builtins.currentSystem -, pkgs ? import ../../.. { inherit system; } +{ + system ? builtins.currentSystem, + pkgs ? import ../../.. { inherit system; }, }: { mit = import ./mit.nix { inherit system pkgs; }; diff --git a/nixos/tests/kerberos/heimdal.nix b/nixos/tests/kerberos/heimdal.nix index 098080a84592e7..e97e8797e05b96 100644 --- a/nixos/tests/kerberos/heimdal.nix +++ b/nixos/tests/kerberos/heimdal.nix @@ -1,47 +1,65 @@ -import ../make-test-python.nix ({pkgs, ...}: { - name = "kerberos_server-heimdal"; +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "kerberos_server-heimdal"; - nodes.machine = { config, libs, pkgs, ...}: - { services.kerberos_server = - { enable = true; - settings.realms = { - "FOO.BAR".acl = [{principal = "admin"; access = ["add" "cpw"];}]; - }; - }; - security.krb5 = { - enable = true; - package = pkgs.heimdal; - settings = { - libdefaults = { - default_realm = "FOO.BAR"; + nodes.machine = + { + config, + libs, + pkgs, + ... + }: + { + services.kerberos_server = { + enable = true; + settings.realms = { + "FOO.BAR".acl = [ + { + principal = "admin"; + access = [ + "add" + "cpw" + ]; + } + ]; + }; }; - realms = { - "FOO.BAR" = { - admin_server = "machine"; - kdc = "machine"; + security.krb5 = { + enable = true; + package = pkgs.heimdal; + settings = { + libdefaults = { + default_realm = "FOO.BAR"; + }; + realms = { + "FOO.BAR" = { + admin_server = "machine"; + kdc = "machine"; + }; + }; }; }; }; - }; - }; - testScript = '' - machine.succeed( - "kadmin -l init --realm-max-ticket-life='8 day' --realm-max-renewable-life='10 day' FOO.BAR", - "systemctl restart kadmind.service kdc.service", - ) + testScript = '' + machine.succeed( + "kadmin -l init --realm-max-ticket-life='8 day' --realm-max-renewable-life='10 day' FOO.BAR", + "systemctl restart kadmind.service kdc.service", + ) - for unit in ["kadmind", "kdc", "kpasswdd"]: - machine.wait_for_unit(f"{unit}.service") + for unit in ["kadmind", "kdc", "kpasswdd"]: + machine.wait_for_unit(f"{unit}.service") - machine.succeed( - "kadmin -l add --password=admin_pw --use-defaults admin", - "kadmin -l ext_keytab --keytab=admin.keytab admin", - "kadmin -p admin -K admin.keytab add --password=alice_pw --use-defaults alice", - "kadmin -l ext_keytab --keytab=alice.keytab alice", - "kinit -kt alice.keytab alice", - ) - ''; + machine.succeed( + "kadmin -l add --password=admin_pw --use-defaults admin", + "kadmin -l ext_keytab --keytab=admin.keytab admin", + "kadmin -p admin -K admin.keytab add --password=alice_pw --use-defaults alice", + "kadmin -l ext_keytab --keytab=alice.keytab alice", + "kinit -kt alice.keytab alice", + ) + ''; - meta.maintainers = [ pkgs.lib.maintainers.dblsaiko ]; -}) + meta.maintainers = [ pkgs.lib.maintainers.dblsaiko ]; + } +) diff --git a/nixos/tests/kerberos/mit.nix b/nixos/tests/kerberos/mit.nix index 172261f95fe6b8..6c1f0920107725 100644 --- a/nixos/tests/kerberos/mit.nix +++ b/nixos/tests/kerberos/mit.nix @@ -1,46 +1,66 @@ -import ../make-test-python.nix ({pkgs, ...}: { - name = "kerberos_server-mit"; +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "kerberos_server-mit"; - nodes.machine = { config, libs, pkgs, ...}: - { services.kerberos_server = - { enable = true; - settings.realms = { - "FOO.BAR".acl = [{principal = "admin"; access = ["add" "cpw"];}]; - }; - }; - security.krb5 = { - enable = true; - package = pkgs.krb5; - settings = { - libdefaults = { - default_realm = "FOO.BAR"; + nodes.machine = + { + config, + libs, + pkgs, + ... + }: + { + services.kerberos_server = { + enable = true; + settings.realms = { + "FOO.BAR".acl = [ + { + principal = "admin"; + access = [ + "add" + "cpw" + ]; + } + ]; + }; }; - realms = { - "FOO.BAR" = { - admin_server = "machine"; - kdc = "machine"; + security.krb5 = { + enable = true; + package = pkgs.krb5; + settings = { + libdefaults = { + default_realm = "FOO.BAR"; + }; + realms = { + "FOO.BAR" = { + admin_server = "machine"; + kdc = "machine"; + }; + }; }; }; + users.extraUsers.alice = { + isNormalUser = true; + }; }; - }; - users.extraUsers.alice = { isNormalUser = true; }; - }; - testScript = '' - machine.succeed( - "kdb5_util create -s -r FOO.BAR -P master_key", - "systemctl restart kadmind.service kdc.service", - ) + testScript = '' + machine.succeed( + "kdb5_util create -s -r FOO.BAR -P master_key", + "systemctl restart kadmind.service kdc.service", + ) - for unit in ["kadmind", "kdc"]: - machine.wait_for_unit(f"{unit}.service") + for unit in ["kadmind", "kdc"]: + machine.wait_for_unit(f"{unit}.service") - machine.succeed( - "kadmin.local add_principal -pw admin_pw admin", - "kadmin -p admin -w admin_pw addprinc -pw alice_pw alice", - "echo alice_pw | sudo -u alice kinit", - ) - ''; + machine.succeed( + "kadmin.local add_principal -pw admin_pw admin", + "kadmin -p admin -w admin_pw addprinc -pw alice_pw alice", + "echo alice_pw | sudo -u alice kinit", + ) + ''; - meta.maintainers = [ pkgs.lib.maintainers.dblsaiko ]; -}) + meta.maintainers = [ pkgs.lib.maintainers.dblsaiko ]; + } +) diff --git a/nixos/tests/kernel-generic.nix b/nixos/tests/kernel-generic.nix index 0171a1e79e1f17..fca4b4f4fe8002 100644 --- a/nixos/tests/kernel-generic.nix +++ b/nixos/tests/kernel-generic.nix @@ -1,28 +1,38 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }@args: with pkgs.lib; let - testsForLinuxPackages = linuxPackages: (import ./make-test-python.nix ({ pkgs, ... }: { - name = "kernel-${linuxPackages.kernel.version}"; - meta = with pkgs.lib.maintainers; { - maintainers = [ nequissimus atemu ma27 ]; - }; - - nodes.machine = { ... }: + testsForLinuxPackages = + linuxPackages: + (import ./make-test-python.nix ( + { pkgs, ... }: { - boot.kernelPackages = linuxPackages; - }; - - testScript = - '' - assert "Linux" in machine.succeed("uname -s") - assert "${linuxPackages.kernel.modDirVersion}" in machine.succeed("uname -a") - ''; - }) args); + name = "kernel-${linuxPackages.kernel.version}"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + nequissimus + atemu + ma27 + ]; + }; + + nodes.machine = + { ... }: + { + boot.kernelPackages = linuxPackages; + }; + + testScript = '' + assert "Linux" in machine.succeed("uname -s") + assert "${linuxPackages.kernel.modDirVersion}" in machine.succeed("uname -a") + ''; + } + ) args); kernels = pkgs.linuxKernel.vanillaPackages // { inherit (pkgs.linuxKernel.packages) linux_5_4_hardened @@ -38,10 +48,13 @@ let linux_rt_6_6 linux_libre - linux_testing; + linux_testing + ; }; -in mapAttrs (_: lP: testsForLinuxPackages lP) kernels // { +in +mapAttrs (_: lP: testsForLinuxPackages lP) kernels +// { passthru = { inherit testsForLinuxPackages; diff --git a/nixos/tests/kernel-latest-ath-user-regd.nix b/nixos/tests/kernel-latest-ath-user-regd.nix index 09e1da9d2affe4..ede82d7d340a82 100644 --- a/nixos/tests/kernel-latest-ath-user-regd.nix +++ b/nixos/tests/kernel-latest-ath-user-regd.nix @@ -1,17 +1,20 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "kernel-latest-ath-user-regd"; - meta = with pkgs.lib.maintainers; { - maintainers = [ veehaitch ]; - }; - - nodes.machine = { pkgs, ... }: - { - boot.kernelPackages = pkgs.linuxPackages_latest; - networking.wireless.athUserRegulatoryDomain = true; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "kernel-latest-ath-user-regd"; + meta = with pkgs.lib.maintainers; { + maintainers = [ veehaitch ]; }; - testScript = - '' + nodes.machine = + { pkgs, ... }: + { + boot.kernelPackages = pkgs.linuxPackages_latest; + networking.wireless.athUserRegulatoryDomain = true; + }; + + testScript = '' assert "CONFIG_ATH_USER_REGD=y" in machine.succeed("zcat /proc/config.gz") ''; -}) + } +) diff --git a/nixos/tests/kernel-rust.nix b/nixos/tests/kernel-rust.nix index f32d433260616f..27fd29353d4d35 100644 --- a/nixos/tests/kernel-rust.nix +++ b/nixos/tests/kernel-rust.nix @@ -1,45 +1,65 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: let - inherit (pkgs.lib) const filterAttrs mapAttrs meta; + inherit (pkgs.lib) + const + filterAttrs + mapAttrs + meta + ; - kernelRustTest = kernelPackages: import ./make-test-python.nix ({ lib, ... }: { - name = "kernel-rust"; - meta.maintainers = with lib.maintainers; [ blitz ma27 ]; - nodes.machine = { config, ... }: { - boot = { - inherit kernelPackages; - extraModulePackages = [ config.boot.kernelPackages.rust-out-of-tree-module ]; - kernelPatches = [ + kernelRustTest = + kernelPackages: + import ./make-test-python.nix ( + { lib, ... }: + { + name = "kernel-rust"; + meta.maintainers = with lib.maintainers; [ + blitz + ma27 + ]; + nodes.machine = + { config, ... }: { - name = "Rust Support"; - patch = null; - features = { - rust = true; + boot = { + inherit kernelPackages; + extraModulePackages = [ config.boot.kernelPackages.rust-out-of-tree-module ]; + kernelPatches = [ + { + name = "Rust Support"; + patch = null; + features = { + rust = true; + }; + } + ]; }; - } - ]; - }; - }; - testScript = '' - machine.wait_for_unit("default.target") - machine.succeed("modprobe rust_out_of_tree") - ''; - }); + }; + testScript = '' + machine.wait_for_unit("default.target") + machine.succeed("modprobe rust_out_of_tree") + ''; + } + ); - kernels = { - inherit (pkgs.linuxKernel.packages) linux_testing; - } - // filterAttrs - (const (x: let - inherit (builtins.tryEval ( - x.rust-out-of-tree-module or null != null - )) success value; - available = - meta.availableOn pkgs.stdenv.hostPlatform x.rust-out-of-tree-module; - in success && value && available)) - pkgs.linuxKernel.vanillaPackages; -in mapAttrs (const kernelRustTest) kernels + kernels = + { + inherit (pkgs.linuxKernel.packages) linux_testing; + } + // filterAttrs (const ( + x: + let + inherit (builtins.tryEval (x.rust-out-of-tree-module or null != null)) + success + value + ; + available = meta.availableOn pkgs.stdenv.hostPlatform x.rust-out-of-tree-module; + in + success && value && available + )) pkgs.linuxKernel.vanillaPackages; +in +mapAttrs (const kernelRustTest) kernels diff --git a/nixos/tests/keter.nix b/nixos/tests/keter.nix index 1cc2ffbde0a08f..d42b30d869d960 100644 --- a/nixos/tests/keter.nix +++ b/nixos/tests/keter.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: let port = 81; in @@ -8,36 +9,39 @@ import ./make-test-python.nix ({ pkgs, ... }: maintainers = [ jappie ]; }; + nodes.machine = + { config, pkgs, ... }: + { + services.keter = { + enable = true; - nodes.machine = { config, pkgs, ... }: { - services.keter = { - enable = true; - - globalKeterConfig = { - cli-port = 123; # just adding this to test the freeform - listeners = [{ - host = "*4"; - inherit port; - }]; - }; - bundle = { - appName = "test-bundle"; - domain = "localhost"; - executable = pkgs.writeShellScript "run" '' - ${pkgs.python3}/bin/python -m http.server $PORT - ''; + globalKeterConfig = { + cli-port = 123; # just adding this to test the freeform + listeners = [ + { + host = "*4"; + inherit port; + } + ]; + }; + bundle = { + appName = "test-bundle"; + domain = "localhost"; + executable = pkgs.writeShellScript "run" '' + ${pkgs.python3}/bin/python -m http.server $PORT + ''; + }; }; }; - }; - testScript = - '' - machine.wait_for_unit("keter.service") + testScript = '' + machine.wait_for_unit("keter.service") - machine.wait_for_open_port(${toString port}) - machine.wait_for_console_text("Activating app test-bundle with hosts: localhost") + machine.wait_for_open_port(${toString port}) + machine.wait_for_console_text("Activating app test-bundle with hosts: localhost") - machine.succeed("curl --fail http://localhost:${toString port}/") - ''; - }) + machine.succeed("curl --fail http://localhost:${toString port}/") + ''; + } +) diff --git a/nixos/tests/kexec.nix b/nixos/tests/kexec.nix index 4d1be497b8bacf..06bd65405f6f77 100644 --- a/nixos/tests/kexec.nix +++ b/nixos/tests/kexec.nix @@ -1,50 +1,62 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "kexec"; - meta = with lib.maintainers; { - maintainers = [ flokli lassulus ]; - }; - - nodes = { - node1 = { ... }: { - virtualisation.vlans = [ ]; - virtualisation.memorySize = 4 * 1024; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "kexec"; + meta = with lib.maintainers; { + maintainers = [ + flokli + lassulus + ]; }; - node2 = { modulesPath, ... }: { - virtualisation.vlans = [ ]; - environment.systemPackages = [ pkgs.hello ]; - imports = [ - "${modulesPath}/installer/netboot/netboot-minimal.nix" - "${modulesPath}/testing/test-instrumentation.nix" - "${modulesPath}/profiles/qemu-guest.nix" - ]; + nodes = { + node1 = + { ... }: + { + virtualisation.vlans = [ ]; + virtualisation.memorySize = 4 * 1024; + }; + + node2 = + { modulesPath, ... }: + { + virtualisation.vlans = [ ]; + environment.systemPackages = [ pkgs.hello ]; + imports = [ + "${modulesPath}/installer/netboot/netboot-minimal.nix" + "${modulesPath}/testing/test-instrumentation.nix" + "${modulesPath}/profiles/qemu-guest.nix" + ]; + }; }; - }; - testScript = { nodes, ... }: '' - # Test whether reboot via kexec works. - node1.wait_for_unit("multi-user.target") - node1.succeed('kexec --load /run/current-system/kernel --initrd /run/current-system/initrd --command-line "$(&2 &", check_return=False) - node1.connected = False - node1.connect() - node1.wait_for_unit("multi-user.target") + testScript = + { nodes, ... }: + '' + # Test whether reboot via kexec works. + node1.wait_for_unit("multi-user.target") + node1.succeed('kexec --load /run/current-system/kernel --initrd /run/current-system/initrd --command-line "$(&2 &", check_return=False) + node1.connected = False + node1.connect() + node1.wait_for_unit("multi-user.target") - # Check if the machine with netboot-minimal.nix profile boots up - node2.wait_for_unit("multi-user.target") - node2.shutdown() + # Check if the machine with netboot-minimal.nix profile boots up + node2.wait_for_unit("multi-user.target") + node2.shutdown() - # Kexec node1 to the toplevel of node2 via the kexec-boot script - node1.succeed('touch /run/foo') - node1.fail('hello') - node1.execute('${nodes.node2.system.build.kexecTree}/kexec-boot', check_output=False) - node1.connected = False - node1.connect() - node1.wait_for_unit("multi-user.target") - node1.succeed('! test -e /run/foo') - node1.succeed('hello') - node1.succeed('[ "$(hostname)" = "node2" ]') + # Kexec node1 to the toplevel of node2 via the kexec-boot script + node1.succeed('touch /run/foo') + node1.fail('hello') + node1.execute('${nodes.node2.system.build.kexecTree}/kexec-boot', check_output=False) + node1.connected = False + node1.connect() + node1.wait_for_unit("multi-user.target") + node1.succeed('! test -e /run/foo') + node1.succeed('hello') + node1.succeed('[ "$(hostname)" = "node2" ]') - node1.shutdown() - ''; -}) + node1.shutdown() + ''; + } +) diff --git a/nixos/tests/keycloak.nix b/nixos/tests/keycloak.nix index baed9419061dfc..28b47661f3d886 100644 --- a/nixos/tests/keycloak.nix +++ b/nixos/tests/keycloak.nix @@ -6,176 +6,184 @@ let certs = import ./common/acme/server/snakeoil-certs.nix; frontendUrl = "https://${certs.domain}"; - keycloakTest = databaseType: import ./make-test-python.nix ( - { pkgs, ... }: - let - initialAdminPassword = "h4Iho\"JFn't2>iQIR9"; - adminPasswordFile = pkgs.writeText "admin-password" "${initialAdminPassword}"; - in - { - name = "keycloak"; - meta = with pkgs.lib.maintainers; { - maintainers = [ talyz ]; - }; - - nodes = { - keycloak = { config, ... }: { - virtualisation.memorySize = 2047; - - security.pki.certificateFiles = [ - certs.ca.cert - ]; - - networking.extraHosts = '' - 127.0.0.1 ${certs.domain} - ''; + keycloakTest = + databaseType: + import ./make-test-python.nix ( + { pkgs, ... }: + let + initialAdminPassword = "h4Iho\"JFn't2>iQIR9"; + adminPasswordFile = pkgs.writeText "admin-password" "${initialAdminPassword}"; + in + { + name = "keycloak"; + meta = with pkgs.lib.maintainers; { + maintainers = [ talyz ]; + }; - services.keycloak = { - enable = true; - settings = { - hostname = certs.domain; - }; - inherit initialAdminPassword; - sslCertificate = "${certs.${certs.domain}.cert}"; - sslCertificateKey = "${certs.${certs.domain}.key}"; - database = { - type = databaseType; - username = "bogus"; - name = "also bogus"; - passwordFile = "${pkgs.writeText "dbPassword" ''wzf6\"vO"Cb\nP>p#6;c&o?eu=q'THE'''H''''E''}"; + nodes = { + keycloak = + { config, ... }: + { + virtualisation.memorySize = 2047; + + security.pki.certificateFiles = [ + certs.ca.cert + ]; + + networking.extraHosts = '' + 127.0.0.1 ${certs.domain} + ''; + + services.keycloak = { + enable = true; + settings = { + hostname = certs.domain; + }; + inherit initialAdminPassword; + sslCertificate = "${certs.${certs.domain}.cert}"; + sslCertificateKey = "${certs.${certs.domain}.key}"; + database = { + type = databaseType; + username = "bogus"; + name = "also bogus"; + passwordFile = "${pkgs.writeText "dbPassword" ''wzf6\"vO"Cb\nP>p#6;c&o?eu=q'THE'''H''''E''}"; + }; + plugins = with config.services.keycloak.package.plugins; [ + keycloak-discord + keycloak-metrics-spi + ]; + }; + environment.systemPackages = with pkgs; [ + htmlq + jq + ]; }; - plugins = with config.services.keycloak.package.plugins; [ - keycloak-discord - keycloak-metrics-spi - ]; - }; - environment.systemPackages = with pkgs; [ - htmlq - jq - ]; }; - }; - - testScript = - let - client = { - clientId = "test-client"; - name = "test-client"; - redirectUris = [ "urn:ietf:wg:oauth:2.0:oob" ]; - }; - - user = { - firstName = "Chuck"; - lastName = "Testa"; - username = "chuck.testa"; - email = "chuck.testa@example.com"; - }; - - password = "password1234"; - - realm = { - enabled = true; - realm = "test-realm"; - clients = [ client ]; - users = [ - ( - user // { - enabled = true; - credentials = [{ - type = "password"; - temporary = false; - value = password; - }]; - } - ) - ]; - }; - - realmDataJson = pkgs.writeText "realm-data.json" (builtins.toJSON realm); - - jqCheckUserinfo = pkgs.writeText "check-userinfo.jq" '' - if { - "firstName": .given_name, - "lastName": .family_name, - "username": .preferred_username, - "email": .email - } != ${builtins.toJSON user} then - error("Wrong user info!") - else - empty - end + + testScript = + let + client = { + clientId = "test-client"; + name = "test-client"; + redirectUris = [ "urn:ietf:wg:oauth:2.0:oob" ]; + }; + + user = { + firstName = "Chuck"; + lastName = "Testa"; + username = "chuck.testa"; + email = "chuck.testa@example.com"; + }; + + password = "password1234"; + + realm = { + enabled = true; + realm = "test-realm"; + clients = [ client ]; + users = [ + ( + user + // { + enabled = true; + credentials = [ + { + type = "password"; + temporary = false; + value = password; + } + ]; + } + ) + ]; + }; + + realmDataJson = pkgs.writeText "realm-data.json" (builtins.toJSON realm); + + jqCheckUserinfo = pkgs.writeText "check-userinfo.jq" '' + if { + "firstName": .given_name, + "lastName": .family_name, + "username": .preferred_username, + "email": .email + } != ${builtins.toJSON user} then + error("Wrong user info!") + else + empty + end + ''; + in + '' + keycloak.start() + keycloak.wait_for_unit("keycloak.service") + keycloak.wait_for_open_port(443) + keycloak.wait_until_succeeds("curl -sSf ${frontendUrl}") + + ### Realm Setup ### + + # Get an admin interface access token + keycloak.succeed(""" + curl -sSf -d 'client_id=admin-cli' \ + -d 'username=admin' \ + -d "password=$(<${adminPasswordFile})" \ + -d 'grant_type=password' \ + '${frontendUrl}/realms/master/protocol/openid-connect/token' \ + | jq -r '"Authorization: bearer " + .access_token' >admin_auth_header + """) + + # Register the metrics SPI + keycloak.succeed( + """${pkgs.jre}/bin/keytool -import -alias snakeoil -file ${certs.ca.cert} -storepass aaaaaa -keystore cacert.jks -noprompt""", + """KC_OPTS='-Djavax.net.ssl.trustStore=cacert.jks -Djavax.net.ssl.trustStorePassword=aaaaaa' kcadm.sh config credentials --server '${frontendUrl}' --realm master --user admin --password "$(<${adminPasswordFile})" """, + """KC_OPTS='-Djavax.net.ssl.trustStore=cacert.jks -Djavax.net.ssl.trustStorePassword=aaaaaa' kcadm.sh update events/config -s 'eventsEnabled=true' -s 'adminEventsEnabled=true' -s 'eventsListeners+=metrics-listener'""", + """curl -sSf '${frontendUrl}/realms/master/metrics' | grep '^keycloak_admin_event_UPDATE'""" + ) + + # Publish the realm, including a test OIDC client and user + keycloak.succeed( + "curl -sSf -H @admin_auth_header -X POST -H 'Content-Type: application/json' -d @${realmDataJson} '${frontendUrl}/admin/realms/'" + ) + + # Generate and save the client secret. To do this we need + # Keycloak's internal id for the client. + keycloak.succeed( + "curl -sSf -H @admin_auth_header '${frontendUrl}/admin/realms/${realm.realm}/clients?clientId=${client.name}' | jq -r '.[].id' >client_id", + "curl -sSf -H @admin_auth_header -X POST '${frontendUrl}/admin/realms/${realm.realm}/clients/'$(client_secret", + ) + + + ### Authentication Testing ### + + # Start the login process by sending an initial request to the + # OIDC authentication endpoint, saving the returned page. Tidy + # up the HTML (XmlStarlet is picky) and extract the login form + # post url. + keycloak.succeed( + "curl -sSf -c cookie '${frontendUrl}/realms/${realm.realm}/protocol/openid-connect/auth?client_id=${client.name}&redirect_uri=urn%3Aietf%3Awg%3Aoauth%3A2.0%3Aoob&scope=openid+email&response_type=code&response_mode=query&nonce=qw4o89g3qqm' >login_form", + "htmlq '#kc-form-login' --attribute action --filename login_form --output form_post_url" + ) + + # Post the login form and save the response. Once again tidy up + # the HTML, then extract the authorization code. + keycloak.succeed( + "curl -sSf -L -b cookie -d 'username=${user.username}' -d 'password=${password}' -d 'credentialId=' \"$(auth_code_html", + "htmlq '#code' --attribute value --filename auth_code_html --output auth_code" + ) + + # Exchange the authorization code for an access token. + keycloak.succeed( + "curl -sSf -d grant_type=authorization_code -d code=$(auth_header" + ) + + # Use the access token on the OIDC userinfo endpoint and check + # that the returned user info matches what we initialized the + # realm with. + keycloak.succeed( + "curl -sSf -H @auth_header '${frontendUrl}/realms/${realm.realm}/protocol/openid-connect/userinfo' | jq -f ${jqCheckUserinfo}" + ) ''; - in '' - keycloak.start() - keycloak.wait_for_unit("keycloak.service") - keycloak.wait_for_open_port(443) - keycloak.wait_until_succeeds("curl -sSf ${frontendUrl}") - - ### Realm Setup ### - - # Get an admin interface access token - keycloak.succeed(""" - curl -sSf -d 'client_id=admin-cli' \ - -d 'username=admin' \ - -d "password=$(<${adminPasswordFile})" \ - -d 'grant_type=password' \ - '${frontendUrl}/realms/master/protocol/openid-connect/token' \ - | jq -r '"Authorization: bearer " + .access_token' >admin_auth_header - """) - - # Register the metrics SPI - keycloak.succeed( - """${pkgs.jre}/bin/keytool -import -alias snakeoil -file ${certs.ca.cert} -storepass aaaaaa -keystore cacert.jks -noprompt""", - """KC_OPTS='-Djavax.net.ssl.trustStore=cacert.jks -Djavax.net.ssl.trustStorePassword=aaaaaa' kcadm.sh config credentials --server '${frontendUrl}' --realm master --user admin --password "$(<${adminPasswordFile})" """, - """KC_OPTS='-Djavax.net.ssl.trustStore=cacert.jks -Djavax.net.ssl.trustStorePassword=aaaaaa' kcadm.sh update events/config -s 'eventsEnabled=true' -s 'adminEventsEnabled=true' -s 'eventsListeners+=metrics-listener'""", - """curl -sSf '${frontendUrl}/realms/master/metrics' | grep '^keycloak_admin_event_UPDATE'""" - ) - - # Publish the realm, including a test OIDC client and user - keycloak.succeed( - "curl -sSf -H @admin_auth_header -X POST -H 'Content-Type: application/json' -d @${realmDataJson} '${frontendUrl}/admin/realms/'" - ) - - # Generate and save the client secret. To do this we need - # Keycloak's internal id for the client. - keycloak.succeed( - "curl -sSf -H @admin_auth_header '${frontendUrl}/admin/realms/${realm.realm}/clients?clientId=${client.name}' | jq -r '.[].id' >client_id", - "curl -sSf -H @admin_auth_header -X POST '${frontendUrl}/admin/realms/${realm.realm}/clients/'$(client_secret", - ) - - - ### Authentication Testing ### - - # Start the login process by sending an initial request to the - # OIDC authentication endpoint, saving the returned page. Tidy - # up the HTML (XmlStarlet is picky) and extract the login form - # post url. - keycloak.succeed( - "curl -sSf -c cookie '${frontendUrl}/realms/${realm.realm}/protocol/openid-connect/auth?client_id=${client.name}&redirect_uri=urn%3Aietf%3Awg%3Aoauth%3A2.0%3Aoob&scope=openid+email&response_type=code&response_mode=query&nonce=qw4o89g3qqm' >login_form", - "htmlq '#kc-form-login' --attribute action --filename login_form --output form_post_url" - ) - - # Post the login form and save the response. Once again tidy up - # the HTML, then extract the authorization code. - keycloak.succeed( - "curl -sSf -L -b cookie -d 'username=${user.username}' -d 'password=${password}' -d 'credentialId=' \"$(auth_code_html", - "htmlq '#code' --attribute value --filename auth_code_html --output auth_code" - ) - - # Exchange the authorization code for an access token. - keycloak.succeed( - "curl -sSf -d grant_type=authorization_code -d code=$(auth_header" - ) - - # Use the access token on the OIDC userinfo endpoint and check - # that the returned user info matches what we initialized the - # realm with. - keycloak.succeed( - "curl -sSf -H @auth_header '${frontendUrl}/realms/${realm.realm}/protocol/openid-connect/userinfo' | jq -f ${jqCheckUserinfo}" - ) - ''; - } - ); + } + ); in { postgres = keycloakTest "postgresql"; diff --git a/nixos/tests/keyd.nix b/nixos/tests/keyd.nix index bfc4558b64bb47..7dc07568be0c60 100644 --- a/nixos/tests/keyd.nix +++ b/nixos/tests/keyd.nix @@ -1,7 +1,8 @@ # The test template is taken from the `./keymap.nix` -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -25,53 +26,66 @@ let mv ${resultFile}.tmp ${resultFile} ''; + mkKeyboardTest = + name: + { default, test }: + with pkgs.lib; + makeTest { + inherit name; - mkKeyboardTest = name: { default, test }: with pkgs.lib; makeTest { - inherit name; - - nodes.machine = { - services.keyd = { - enable = true; - keyboards = { inherit default; }; + nodes.machine = { + services.keyd = { + enable = true; + keyboards = { inherit default; }; + }; }; - }; - testScript = '' - import shlex + testScript = '' + import shlex - machine.wait_for_unit("keyd.service") + machine.wait_for_unit("keyd.service") - def run_test_case(cmd, test_case_name, inputs, expected): - with subtest(test_case_name): - assert len(inputs) == len(expected) - machine.execute("rm -f ${readyFile} ${resultFile}") - # set up process that expects all the keys to be entered - machine.succeed( - "{} {} {} {} >&2 &".format( - cmd, - "${testReader}", - len(inputs), - shlex.quote("".join(expected)), - ) - ) - # wait for reader to be ready - machine.wait_for_file("${readyFile}") - # send all keys - for key in inputs: - machine.send_key(key) - # wait for result and check - machine.wait_for_file("${resultFile}") - machine.succeed("grep -q 'PASS:' ${resultFile}") - test = ${builtins.toJSON test} - run_test_case("openvt -sw --", "${name}", test["press"], test["expect"]) - ''; - }; + def run_test_case(cmd, test_case_name, inputs, expected): + with subtest(test_case_name): + assert len(inputs) == len(expected) + machine.execute("rm -f ${readyFile} ${resultFile}") + # set up process that expects all the keys to be entered + machine.succeed( + "{} {} {} {} >&2 &".format( + cmd, + "${testReader}", + len(inputs), + shlex.quote("".join(expected)), + ) + ) + # wait for reader to be ready + machine.wait_for_file("${readyFile}") + # send all keys + for key in inputs: + machine.send_key(key) + # wait for result and check + machine.wait_for_file("${resultFile}") + machine.succeed("grep -q 'PASS:' ${resultFile}") + test = ${builtins.toJSON test} + run_test_case("openvt -sw --", "${name}", test["press"], test["expect"]) + ''; + }; in pkgs.lib.mapAttrs mkKeyboardTest { swap-ab_and_ctrl-as-shift = { - test.press = [ "a" "ctrl-b" "c" "alt_r-h" ]; - test.expect = [ "b" "A" "c" "q" ]; + test.press = [ + "a" + "ctrl-b" + "c" + "alt_r-h" + ]; + test.expect = [ + "b" + "A" + "c" + "q" + ]; default = { settings.main = { diff --git a/nixos/tests/keymap.nix b/nixos/tests/keymap.nix index 3542dea58f7f37..55c08a004a4e25 100644 --- a/nixos/tests/keymap.nix +++ b/nixos/tests/keymap.nix @@ -1,12 +1,13 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; let - readyFile = "/tmp/readerReady"; + readyFile = "/tmp/readerReady"; resultFile = "/tmp/readerResult"; testReader = pkgs.writeScript "test-input-reader" '' @@ -25,82 +26,110 @@ let mv ${resultFile}.tmp ${resultFile} ''; + mkKeyboardTest = + layout: + { + extraConfig ? { }, + tests, + }: + with pkgs.lib; + makeTest { + name = "keymap-${layout}"; + + nodes.machine.console.keyMap = mkOverride 900 layout; + nodes.machine.services.xserver.desktopManager.xterm.enable = false; + nodes.machine.services.xserver.xkb.layout = mkOverride 900 layout; + nodes.machine.imports = [ + ./common/x11.nix + extraConfig + ]; + + testScript = '' + import json + import shlex + + + def run_test_case(cmd, inputs, expected): + assert len(inputs) == len(expected) + machine.execute("rm -f ${readyFile} ${resultFile}") + + # set up process that expects all the keys to be entered + machine.succeed( + "${pkgs.systemd}/bin/systemd-cat -t input-test-reader -- {} {} {} &".format( + cmd, + "${testReader}", + shlex.quote("".join(expected)), + ) + ) + + # wait for reader to be ready + machine.wait_for_file("${readyFile}") + + # send all keys + for key in inputs: + machine.send_key(key) + + # wait for result and check + machine.wait_for_file("${resultFile}") + machine.succeed("grep -q 'PASS:' ${resultFile}") + + + with open("${pkgs.writeText "tests.json" (builtins.toJSON tests)}") as json_file: + tests = json.load(json_file) + + # These environments used to run in the opposite order, causing the + # following error at openvt startup. + # + # openvt: Couldn't deallocate console 1 + # + # This error did not appear in successful runs. + # I don't know the exact cause, but I it seems that openvt and X are + # fighting over the virtual terminal. This does not appear to be a problem + # when the X test runs first. + keymap_environments = { + "Xorg Keymap": "env DISPLAY=:0 xterm -title testterm -class testterm -fullscreen -e", + "VT Keymap": "openvt -c 2 -sw --", + } + + machine.wait_for_x() + + for test_case_name, test_data in tests.items(): + for keymap_env_name, command in keymap_environments.items(): + with subtest(f"{test_case_name} - {keymap_env_name}"): + run_test_case( + command, + test_data["qwerty"], + test_data["expect"], + ) + ''; + }; - mkKeyboardTest = layout: { extraConfig ? {}, tests }: with pkgs.lib; makeTest { - name = "keymap-${layout}"; - - nodes.machine.console.keyMap = mkOverride 900 layout; - nodes.machine.services.xserver.desktopManager.xterm.enable = false; - nodes.machine.services.xserver.xkb.layout = mkOverride 900 layout; - nodes.machine.imports = [ ./common/x11.nix extraConfig ]; - - testScript = '' - import json - import shlex - - - def run_test_case(cmd, inputs, expected): - assert len(inputs) == len(expected) - machine.execute("rm -f ${readyFile} ${resultFile}") - - # set up process that expects all the keys to be entered - machine.succeed( - "${pkgs.systemd}/bin/systemd-cat -t input-test-reader -- {} {} {} &".format( - cmd, - "${testReader}", - shlex.quote("".join(expected)), - ) - ) - - # wait for reader to be ready - machine.wait_for_file("${readyFile}") - - # send all keys - for key in inputs: - machine.send_key(key) - - # wait for result and check - machine.wait_for_file("${resultFile}") - machine.succeed("grep -q 'PASS:' ${resultFile}") - - - with open("${pkgs.writeText "tests.json" (builtins.toJSON tests)}") as json_file: - tests = json.load(json_file) - - # These environments used to run in the opposite order, causing the - # following error at openvt startup. - # - # openvt: Couldn't deallocate console 1 - # - # This error did not appear in successful runs. - # I don't know the exact cause, but I it seems that openvt and X are - # fighting over the virtual terminal. This does not appear to be a problem - # when the X test runs first. - keymap_environments = { - "Xorg Keymap": "env DISPLAY=:0 xterm -title testterm -class testterm -fullscreen -e", - "VT Keymap": "openvt -c 2 -sw --", - } - - machine.wait_for_x() - - for test_case_name, test_data in tests.items(): - for keymap_env_name, command in keymap_environments.items(): - with subtest(f"{test_case_name} - {keymap_env_name}"): - run_test_case( - command, - test_data["qwerty"], - test_data["expect"], - ) - ''; - }; - -in pkgs.lib.mapAttrs mkKeyboardTest { +in +pkgs.lib.mapAttrs mkKeyboardTest { azerty = { tests = { - azqw.qwerty = [ "q" "w" ]; - azqw.expect = [ "a" "z" ]; - altgr.qwerty = [ "alt_r-2" "alt_r-3" "alt_r-4" "alt_r-5" "alt_r-6" ]; - altgr.expect = [ "~" "#" "{" "[" "|" ]; + azqw.qwerty = [ + "q" + "w" + ]; + azqw.expect = [ + "a" + "z" + ]; + altgr.qwerty = [ + "alt_r-2" + "alt_r-3" + "alt_r-4" + "alt_r-5" + "alt_r-6" + ]; + altgr.expect = [ + "~" + "#" + "{" + "[" + "|" + ]; }; extraConfig.console.keyMap = "fr"; @@ -109,12 +138,32 @@ in pkgs.lib.mapAttrs mkKeyboardTest { bone = { tests = { - layer1.qwerty = [ "f" "j" ]; - layer1.expect = [ "e" "n" ]; - layer2.qwerty = [ "shift-f" "shift-j" "shift-6" ]; - layer2.expect = [ "E" "N" "$" ]; - layer3.qwerty = [ "caps_lock-d" "caps_lock-f" ]; - layer3.expect = [ "{" "}" ]; + layer1.qwerty = [ + "f" + "j" + ]; + layer1.expect = [ + "e" + "n" + ]; + layer2.qwerty = [ + "shift-f" + "shift-j" + "shift-6" + ]; + layer2.expect = [ + "E" + "N" + "$" + ]; + layer3.qwerty = [ + "caps_lock-d" + "caps_lock-f" + ]; + layer3.expect = [ + "{" + "}" + ]; }; extraConfig.console.keyMap = "bone"; @@ -124,8 +173,26 @@ in pkgs.lib.mapAttrs mkKeyboardTest { colemak = { tests = { - homerow.qwerty = [ "a" "s" "d" "f" "j" "k" "l" "semicolon" ]; - homerow.expect = [ "a" "r" "s" "t" "n" "e" "i" "o" ]; + homerow.qwerty = [ + "a" + "s" + "d" + "f" + "j" + "k" + "l" + "semicolon" + ]; + homerow.expect = [ + "a" + "r" + "s" + "t" + "n" + "e" + "i" + "o" + ]; }; extraConfig.console.keyMap = "colemak"; @@ -135,10 +202,40 @@ in pkgs.lib.mapAttrs mkKeyboardTest { dvorak = { tests = { - homerow.qwerty = [ "a" "s" "d" "f" "j" "k" "l" "semicolon" ]; - homerow.expect = [ "a" "o" "e" "u" "h" "t" "n" "s" ]; - symbols.qwerty = [ "q" "w" "e" "minus" "equal" ]; - symbols.expect = [ "'" "," "." "[" "]" ]; + homerow.qwerty = [ + "a" + "s" + "d" + "f" + "j" + "k" + "l" + "semicolon" + ]; + homerow.expect = [ + "a" + "o" + "e" + "u" + "h" + "t" + "n" + "s" + ]; + symbols.qwerty = [ + "q" + "w" + "e" + "minus" + "equal" + ]; + symbols.expect = [ + "'" + "," + "." + "[" + "]" + ]; }; extraConfig.console.keyMap = "dvorak"; @@ -148,13 +245,78 @@ in pkgs.lib.mapAttrs mkKeyboardTest { dvorak-programmer = { tests = { - homerow.qwerty = [ "a" "s" "d" "f" "j" "k" "l" "semicolon" ]; - homerow.expect = [ "a" "o" "e" "u" "h" "t" "n" "s" ]; - numbers.qwerty = map (x: "shift-${x}") - [ "1" "2" "3" "4" "5" "6" "7" "8" "9" "0" "minus" ]; - numbers.expect = [ "%" "7" "5" "3" "1" "9" "0" "2" "4" "6" "8" ]; - symbols.qwerty = [ "1" "2" "3" "4" "5" "6" "7" "8" "9" "0" "minus" ]; - symbols.expect = [ "&" "[" "{" "}" "(" "=" "*" ")" "+" "]" "!" ]; + homerow.qwerty = [ + "a" + "s" + "d" + "f" + "j" + "k" + "l" + "semicolon" + ]; + homerow.expect = [ + "a" + "o" + "e" + "u" + "h" + "t" + "n" + "s" + ]; + numbers.qwerty = map (x: "shift-${x}") [ + "1" + "2" + "3" + "4" + "5" + "6" + "7" + "8" + "9" + "0" + "minus" + ]; + numbers.expect = [ + "%" + "7" + "5" + "3" + "1" + "9" + "0" + "2" + "4" + "6" + "8" + ]; + symbols.qwerty = [ + "1" + "2" + "3" + "4" + "5" + "6" + "7" + "8" + "9" + "0" + "minus" + ]; + symbols.expect = [ + "&" + "[" + "{" + "}" + "(" + "=" + "*" + ")" + "+" + "]" + "!" + ]; }; extraConfig.console.keyMap = "dvorak-programmer"; @@ -164,12 +326,32 @@ in pkgs.lib.mapAttrs mkKeyboardTest { neo = { tests = { - layer1.qwerty = [ "f" "j" ]; - layer1.expect = [ "e" "n" ]; - layer2.qwerty = [ "shift-f" "shift-j" "shift-6" ]; - layer2.expect = [ "E" "N" "$" ]; - layer3.qwerty = [ "caps_lock-d" "caps_lock-f" ]; - layer3.expect = [ "{" "}" ]; + layer1.qwerty = [ + "f" + "j" + ]; + layer1.expect = [ + "e" + "n" + ]; + layer2.qwerty = [ + "shift-f" + "shift-j" + "shift-6" + ]; + layer2.expect = [ + "E" + "N" + "$" + ]; + layer3.qwerty = [ + "caps_lock-d" + "caps_lock-f" + ]; + layer3.expect = [ + "{" + "}" + ]; }; extraConfig.console.keyMap = "neo"; @@ -179,11 +361,30 @@ in pkgs.lib.mapAttrs mkKeyboardTest { qwertz = { tests = { - zy.qwerty = [ "z" "y" ]; - zy.expect = [ "y" "z" ]; - altgr.qwerty = map (x: "alt_r-${x}") - [ "q" "less" "7" "8" "9" "0" ]; - altgr.expect = [ "@" "|" "{" "[" "]" "}" ]; + zy.qwerty = [ + "z" + "y" + ]; + zy.expect = [ + "y" + "z" + ]; + altgr.qwerty = map (x: "alt_r-${x}") [ + "q" + "less" + "7" + "8" + "9" + "0" + ]; + altgr.expect = [ + "@" + "|" + "{" + "[" + "]" + "}" + ]; }; extraConfig.console.keyMap = "de"; @@ -192,30 +393,57 @@ in pkgs.lib.mapAttrs mkKeyboardTest { custom = { tests = { - us.qwerty = [ "a" "b" "g" "d" "z" "shift-2" "shift-3" ]; - us.expect = [ "a" "b" "g" "d" "z" "@" "#" ]; - greek.qwerty = map (x: "alt_r-${x}") - [ "a" "b" "g" "d" "z" ]; - greek.expect = [ "α" "β" "γ" "δ" "ζ" ]; + us.qwerty = [ + "a" + "b" + "g" + "d" + "z" + "shift-2" + "shift-3" + ]; + us.expect = [ + "a" + "b" + "g" + "d" + "z" + "@" + "#" + ]; + greek.qwerty = map (x: "alt_r-${x}") [ + "a" + "b" + "g" + "d" + "z" + ]; + greek.expect = [ + "α" + "β" + "γ" + "δ" + "ζ" + ]; }; extraConfig.console.useXkbConfig = true; extraConfig.services.xserver.xkb.layout = "us-greek"; - extraConfig.services.xserver.xkb.extraLayouts.us-greek = - { description = "US layout with alt-gr greek"; - languages = [ "eng" ]; - symbolsFile = pkgs.writeText "us-greek" '' - xkb_symbols "us-greek" - { - include "us(basic)" - include "level3(ralt_switch)" - key { [ a, A, Greek_alpha ] }; - key { [ b, B, Greek_beta ] }; - key { [ g, G, Greek_gamma ] }; - key { [ d, D, Greek_delta ] }; - key { [ z, Z, Greek_zeta ] }; - }; - ''; - }; + extraConfig.services.xserver.xkb.extraLayouts.us-greek = { + description = "US layout with alt-gr greek"; + languages = [ "eng" ]; + symbolsFile = pkgs.writeText "us-greek" '' + xkb_symbols "us-greek" + { + include "us(basic)" + include "level3(ralt_switch)" + key { [ a, A, Greek_alpha ] }; + key { [ b, B, Greek_beta ] }; + key { [ g, G, Greek_gamma ] }; + key { [ d, D, Greek_delta ] }; + key { [ z, Z, Greek_zeta ] }; + }; + ''; + }; }; } diff --git a/nixos/tests/knot.nix b/nixos/tests/knot.nix index 4441fed6ef5079..10ab1390696f70 100644 --- a/nixos/tests/knot.nix +++ b/nixos/tests/knot.nix @@ -1,10 +1,11 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : -let - common = { - networking.firewall.enable = false; - networking.useDHCP = false; - }; - exampleZone = pkgs.writeTextDir "example.com.zone" '' +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + common = { + networking.firewall.enable = false; + networking.useDHCP = false; + }; + exampleZone = pkgs.writeTextDir "example.com.zone" '' @ SOA ns.example.com. noc.example.com. 2019031301 86400 7200 3600000 172800 @ NS ns1 @ NS ns2 @@ -15,208 +16,239 @@ let www A 192.0.2.1 www AAAA 2001:DB8::1 sub NS ns.example.com. - ''; - delegatedZone = pkgs.writeTextDir "sub.example.com.zone" '' + ''; + delegatedZone = pkgs.writeTextDir "sub.example.com.zone" '' @ SOA ns.example.com. noc.example.com. 2019031301 86400 7200 3600000 172800 @ NS ns1.example.com. @ NS ns2.example.com. @ A 192.0.2.2 @ AAAA 2001:DB8::2 - ''; - - knotZonesEnv = pkgs.buildEnv { - name = "knot-zones"; - paths = [ exampleZone delegatedZone ]; - }; - # DO NOT USE pkgs.writeText IN PRODUCTION. This put secrets in the nix store! - tsigFile = pkgs.writeText "tsig.conf" '' - key: - - id: xfr_key - algorithm: hmac-sha256 - secret: zOYgOgnzx3TGe5J5I/0kxd7gTcxXhLYMEq3Ek3fY37s= - ''; -in { - name = "knot"; - meta = with pkgs.lib.maintainers; { - maintainers = [ hexa ]; - }; - - - nodes = { - primary = { lib, ... }: { - imports = [ common ]; - - # trigger sched_setaffinity syscall - virtualisation.cores = 2; - - networking.interfaces.eth1 = { - ipv4.addresses = lib.mkForce [ - { address = "192.168.0.1"; prefixLength = 24; } - ]; - ipv6.addresses = lib.mkForce [ - { address = "fd00::1"; prefixLength = 64; } - ]; - }; - services.knot.enable = true; - services.knot.extraArgs = [ "-v" ]; - services.knot.keyFiles = [ tsigFile ]; - services.knot.settings = { - server = { - listen = [ - "0.0.0.0@53" - "::@53" - ]; - listen-quic = [ - "0.0.0.0@853" - "::@853" - ]; - automatic-acl = true; - }; - - acl.secondary_acl = { - address = "192.168.0.2"; - key = "xfr_key"; - action = "transfer"; - }; - - remote.secondary.address = "192.168.0.2@53"; - - template.default = { - storage = knotZonesEnv; - notify = [ "secondary" ]; - acl = [ "secondary_acl" ]; - dnssec-signing = true; - # Input-only zone files - # https://www.knot-dns.cz/docs/2.8/html/operation.html#example-3 - # prevents modification of the zonefiles, since the zonefiles are immutable - zonefile-sync = -1; - zonefile-load = "difference"; - journal-content = "changes"; - }; - - zone = { - "example.com".file = "example.com.zone"; - "sub.example.com".file = "sub.example.com.zone"; - }; - - log.syslog.any = "info"; - }; + ''; + + knotZonesEnv = pkgs.buildEnv { + name = "knot-zones"; + paths = [ + exampleZone + delegatedZone + ]; + }; + # DO NOT USE pkgs.writeText IN PRODUCTION. This put secrets in the nix store! + tsigFile = pkgs.writeText "tsig.conf" '' + key: + - id: xfr_key + algorithm: hmac-sha256 + secret: zOYgOgnzx3TGe5J5I/0kxd7gTcxXhLYMEq3Ek3fY37s= + ''; + in + { + name = "knot"; + meta = with pkgs.lib.maintainers; { + maintainers = [ hexa ]; }; - secondary = { lib, ... }: { - imports = [ common ]; - networking.interfaces.eth1 = { - ipv4.addresses = lib.mkForce [ - { address = "192.168.0.2"; prefixLength = 24; } - ]; - ipv6.addresses = lib.mkForce [ - { address = "fd00::2"; prefixLength = 64; } - ]; - }; - services.knot.enable = true; - services.knot.keyFiles = [ tsigFile ]; - services.knot.extraArgs = [ "-v" ]; - services.knot.settings = { - server = { - automatic-acl = true; - }; - - xdp = { - listen = [ - "eth1" - ]; - tcp = true; - }; - - remote.primary = { - address = "192.168.0.1@53"; - key = "xfr_key"; - }; - - remote.primary-quic = { - address = "192.168.0.1@853"; - key = "xfr_key"; - quic = true; - }; - - template.default = { - # zonefileless setup - # https://www.knot-dns.cz/docs/2.8/html/operation.html#example-2 - zonefile-sync = "-1"; - zonefile-load = "none"; - journal-content = "all"; + nodes = { + primary = + { lib, ... }: + { + imports = [ common ]; + + # trigger sched_setaffinity syscall + virtualisation.cores = 2; + + networking.interfaces.eth1 = { + ipv4.addresses = lib.mkForce [ + { + address = "192.168.0.1"; + prefixLength = 24; + } + ]; + ipv6.addresses = lib.mkForce [ + { + address = "fd00::1"; + prefixLength = 64; + } + ]; + }; + services.knot.enable = true; + services.knot.extraArgs = [ "-v" ]; + services.knot.keyFiles = [ tsigFile ]; + services.knot.settings = { + server = { + listen = [ + "0.0.0.0@53" + "::@53" + ]; + listen-quic = [ + "0.0.0.0@853" + "::@853" + ]; + automatic-acl = true; + }; + + acl.secondary_acl = { + address = "192.168.0.2"; + key = "xfr_key"; + action = "transfer"; + }; + + remote.secondary.address = "192.168.0.2@53"; + + template.default = { + storage = knotZonesEnv; + notify = [ "secondary" ]; + acl = [ "secondary_acl" ]; + dnssec-signing = true; + # Input-only zone files + # https://www.knot-dns.cz/docs/2.8/html/operation.html#example-3 + # prevents modification of the zonefiles, since the zonefiles are immutable + zonefile-sync = -1; + zonefile-load = "difference"; + journal-content = "changes"; + }; + + zone = { + "example.com".file = "example.com.zone"; + "sub.example.com".file = "sub.example.com.zone"; + }; + + log.syslog.any = "info"; + }; }; - zone = { - "example.com" = { - master = "primary"; - file = "example.com.zone"; + secondary = + { lib, ... }: + { + imports = [ common ]; + networking.interfaces.eth1 = { + ipv4.addresses = lib.mkForce [ + { + address = "192.168.0.2"; + prefixLength = 24; + } + ]; + ipv6.addresses = lib.mkForce [ + { + address = "fd00::2"; + prefixLength = 64; + } + ]; }; - "sub.example.com" = { - master = "primary-quic"; - file = "sub.example.com.zone"; + services.knot.enable = true; + services.knot.keyFiles = [ tsigFile ]; + services.knot.extraArgs = [ "-v" ]; + services.knot.settings = { + server = { + automatic-acl = true; + }; + + xdp = { + listen = [ + "eth1" + ]; + tcp = true; + }; + + remote.primary = { + address = "192.168.0.1@53"; + key = "xfr_key"; + }; + + remote.primary-quic = { + address = "192.168.0.1@853"; + key = "xfr_key"; + quic = true; + }; + + template.default = { + # zonefileless setup + # https://www.knot-dns.cz/docs/2.8/html/operation.html#example-2 + zonefile-sync = "-1"; + zonefile-load = "none"; + journal-content = "all"; + }; + + zone = { + "example.com" = { + master = "primary"; + file = "example.com.zone"; + }; + "sub.example.com" = { + master = "primary-quic"; + file = "sub.example.com.zone"; + }; + }; + + log.syslog.any = "debug"; }; }; - - log.syslog.any = "debug"; - }; - }; - client = { lib, nodes, ... }: { - imports = [ common ]; - networking.interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.0.3"; prefixLength = 24; } - ]; - ipv6.addresses = [ - { address = "fd00::3"; prefixLength = 64; } - ]; - }; - environment.systemPackages = [ pkgs.knot-dns ]; + client = + { lib, nodes, ... }: + { + imports = [ common ]; + networking.interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.0.3"; + prefixLength = 24; + } + ]; + ipv6.addresses = [ + { + address = "fd00::3"; + prefixLength = 64; + } + ]; + }; + environment.systemPackages = [ pkgs.knot-dns ]; + }; }; - }; - testScript = { nodes, ... }: let - primary4 = (lib.head nodes.primary.config.networking.interfaces.eth1.ipv4.addresses).address; - primary6 = (lib.head nodes.primary.config.networking.interfaces.eth1.ipv6.addresses).address; + testScript = + { nodes, ... }: + let + primary4 = (lib.head nodes.primary.config.networking.interfaces.eth1.ipv4.addresses).address; + primary6 = (lib.head nodes.primary.config.networking.interfaces.eth1.ipv6.addresses).address; - secondary4 = (lib.head nodes.secondary.config.networking.interfaces.eth1.ipv4.addresses).address; - secondary6 = (lib.head nodes.secondary.config.networking.interfaces.eth1.ipv6.addresses).address; - in '' - import re + secondary4 = (lib.head nodes.secondary.config.networking.interfaces.eth1.ipv4.addresses).address; + secondary6 = (lib.head nodes.secondary.config.networking.interfaces.eth1.ipv6.addresses).address; + in + '' + import re - start_all() + start_all() - client.wait_for_unit("network.target") - primary.wait_for_unit("knot.service") - secondary.wait_for_unit("knot.service") + client.wait_for_unit("network.target") + primary.wait_for_unit("knot.service") + secondary.wait_for_unit("knot.service") - for zone in ("example.com.", "sub.example.com."): - secondary.wait_until_succeeds( - f"knotc zone-status {zone} | grep -q 'serial: 2019031302'" - ) + for zone in ("example.com.", "sub.example.com."): + secondary.wait_until_succeeds( + f"knotc zone-status {zone} | grep -q 'serial: 2019031302'" + ) - def test(host, query_type, query, pattern): - out = client.succeed(f"khost -t {query_type} {query} {host}").strip() - client.log(f"{host} replied with: {out}") - assert re.search(pattern, out), f'Did not match "{pattern}"' + def test(host, query_type, query, pattern): + out = client.succeed(f"khost -t {query_type} {query} {host}").strip() + client.log(f"{host} replied with: {out}") + assert re.search(pattern, out), f'Did not match "{pattern}"' - for host in ("${primary4}", "${primary6}", "${secondary4}", "${secondary6}"): - with subtest(f"Interrogate {host}"): - test(host, "SOA", "example.com", r"start of authority.*noc\.example\.com\.") - test(host, "A", "example.com", r"has no [^ ]+ record") - test(host, "AAAA", "example.com", r"has no [^ ]+ record") + for host in ("${primary4}", "${primary6}", "${secondary4}", "${secondary6}"): + with subtest(f"Interrogate {host}"): + test(host, "SOA", "example.com", r"start of authority.*noc\.example\.com\.") + test(host, "A", "example.com", r"has no [^ ]+ record") + test(host, "AAAA", "example.com", r"has no [^ ]+ record") - test(host, "A", "www.example.com", r"address 192.0.2.1$") - test(host, "AAAA", "www.example.com", r"address 2001:db8::1$") + test(host, "A", "www.example.com", r"address 192.0.2.1$") + test(host, "AAAA", "www.example.com", r"address 2001:db8::1$") - test(host, "NS", "sub.example.com", r"nameserver is ns\d\.example\.com.$") - test(host, "A", "sub.example.com", r"address 192.0.2.2$") - test(host, "AAAA", "sub.example.com", r"address 2001:db8::2$") + test(host, "NS", "sub.example.com", r"nameserver is ns\d\.example\.com.$") + test(host, "A", "sub.example.com", r"address 192.0.2.2$") + test(host, "AAAA", "sub.example.com", r"address 2001:db8::2$") - test(host, "RRSIG", "www.example.com", r"RR set signature is") - test(host, "DNSKEY", "example.com", r"DNSSEC key is") + test(host, "RRSIG", "www.example.com", r"RR set signature is") + test(host, "DNSKEY", "example.com", r"DNSSEC key is") - primary.log(primary.succeed("systemd-analyze security knot.service | grep -v '✓'")) - ''; -}) + primary.log(primary.succeed("systemd-analyze security knot.service | grep -v '✓'")) + ''; + } +) diff --git a/nixos/tests/krb5/example-config.nix b/nixos/tests/krb5/example-config.nix index 33bed481b39fc1..5a7e75732d3259 100644 --- a/nixos/tests/krb5/example-config.nix +++ b/nixos/tests/krb5/example-config.nix @@ -1,118 +1,127 @@ # Verifies that the configuration suggested in (non-deprecated) example values # will result in the expected output. -import ../make-test-python.nix ({ pkgs, ...} : { - name = "krb5-with-example-config"; - meta = with pkgs.lib.maintainers; { - maintainers = [ eqyiel dblsaiko ]; - }; +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "krb5-with-example-config"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + eqyiel + dblsaiko + ]; + }; - nodes.machine = - { pkgs, ... }: { - security.krb5 = { - enable = true; - package = pkgs.krb5; - settings = { - includedir = [ - "/etc/krb5.conf.d" - ]; - include = [ - "/etc/krb5-extra.conf" - ]; - libdefaults = { - default_realm = "ATHENA.MIT.EDU"; - }; - realms = { - "ATHENA.MIT.EDU" = { - admin_server = "athena.mit.edu"; - kdc = [ - "athena01.mit.edu" - "athena02.mit.edu" - ]; + nodes.machine = + { pkgs, ... }: + { + security.krb5 = { + enable = true; + package = pkgs.krb5; + settings = { + includedir = [ + "/etc/krb5.conf.d" + ]; + include = [ + "/etc/krb5-extra.conf" + ]; + libdefaults = { + default_realm = "ATHENA.MIT.EDU"; }; - }; - domain_realm = { - "example.com" = "EXAMPLE.COM"; - ".example.com" = "EXAMPLE.COM"; - }; - capaths = { - "ATHENA.MIT.EDU" = { - "EXAMPLE.COM" = "."; + realms = { + "ATHENA.MIT.EDU" = { + admin_server = "athena.mit.edu"; + kdc = [ + "athena01.mit.edu" + "athena02.mit.edu" + ]; + }; }; - "EXAMPLE.COM" = { - "ATHENA.MIT.EDU" = "."; + domain_realm = { + "example.com" = "EXAMPLE.COM"; + ".example.com" = "EXAMPLE.COM"; }; - }; - appdefaults = { - pam = { - debug = false; - ticket_lifetime = 36000; - renew_lifetime = 36000; - max_timeout = 30; - timeout_shift = 2; - initial_timeout = 1; + capaths = { + "ATHENA.MIT.EDU" = { + "EXAMPLE.COM" = "."; + }; + "EXAMPLE.COM" = { + "ATHENA.MIT.EDU" = "."; + }; + }; + appdefaults = { + pam = { + debug = false; + ticket_lifetime = 36000; + renew_lifetime = 36000; + max_timeout = 30; + timeout_shift = 2; + initial_timeout = 1; + }; + }; + plugins.ccselect.disable = "k5identity"; + logging = { + kdc = "SYSLOG:NOTICE"; + admin_server = "SYSLOG:NOTICE"; + default = "SYSLOG:NOTICE"; }; - }; - plugins.ccselect.disable = "k5identity"; - logging = { - kdc = "SYSLOG:NOTICE"; - admin_server = "SYSLOG:NOTICE"; - default = "SYSLOG:NOTICE"; }; }; }; - }; - testScript = - let snapshot = pkgs.writeText "krb5-with-example-config.conf" '' - [appdefaults] - pam = { - debug = false - initial_timeout = 1 - max_timeout = 30 - renew_lifetime = 36000 - ticket_lifetime = 36000 - timeout_shift = 2 - } + testScript = + let + snapshot = pkgs.writeText "krb5-with-example-config.conf" '' + [appdefaults] + pam = { + debug = false + initial_timeout = 1 + max_timeout = 30 + renew_lifetime = 36000 + ticket_lifetime = 36000 + timeout_shift = 2 + } - [capaths] - ATHENA.MIT.EDU = { - EXAMPLE.COM = . - } - EXAMPLE.COM = { - ATHENA.MIT.EDU = . - } + [capaths] + ATHENA.MIT.EDU = { + EXAMPLE.COM = . + } + EXAMPLE.COM = { + ATHENA.MIT.EDU = . + } - [domain_realm] - .example.com = EXAMPLE.COM - example.com = EXAMPLE.COM + [domain_realm] + .example.com = EXAMPLE.COM + example.com = EXAMPLE.COM - [libdefaults] - default_realm = ATHENA.MIT.EDU + [libdefaults] + default_realm = ATHENA.MIT.EDU - [logging] - admin_server = SYSLOG:NOTICE - default = SYSLOG:NOTICE - kdc = SYSLOG:NOTICE + [logging] + admin_server = SYSLOG:NOTICE + default = SYSLOG:NOTICE + kdc = SYSLOG:NOTICE - [plugins] - ccselect = { - disable = k5identity - } + [plugins] + ccselect = { + disable = k5identity + } - [realms] - ATHENA.MIT.EDU = { - admin_server = athena.mit.edu - kdc = athena01.mit.edu - kdc = athena02.mit.edu - } + [realms] + ATHENA.MIT.EDU = { + admin_server = athena.mit.edu + kdc = athena01.mit.edu + kdc = athena02.mit.edu + } - include /etc/krb5-extra.conf - includedir /etc/krb5.conf.d - ''; - in '' - machine.succeed( - "diff /etc/krb5.conf ${snapshot}" - ) - ''; -}) + include /etc/krb5-extra.conf + includedir /etc/krb5.conf.d + ''; + in + '' + machine.succeed( + "diff /etc/krb5.conf ${snapshot}" + ) + ''; + } +) diff --git a/nixos/tests/ksm.nix b/nixos/tests/ksm.nix index 026d2ee85a24aa..73ef3bdc8eb0e5 100644 --- a/nixos/tests/ksm.nix +++ b/nixos/tests/ksm.nix @@ -1,22 +1,25 @@ -import ./make-test-python.nix ({ lib, ...} : +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "ksm"; - meta = with lib.maintainers; { - maintainers = [ rnhmjoj ]; - }; + { + name = "ksm"; + meta = with lib.maintainers; { + maintainers = [ rnhmjoj ]; + }; - nodes.machine = { ... }: { - imports = [ ../modules/profiles/minimal.nix ]; + nodes.machine = + { ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; - hardware.ksm.enable = true; - hardware.ksm.sleep = 300; - }; + hardware.ksm.enable = true; + hardware.ksm.sleep = 300; + }; - testScript = - '' + testScript = '' machine.start() machine.wait_until_succeeds("test $(

Hello world

' > page.html") machine.execute("Ladybird file://$(pwd)/page.html >&2 &") @@ -25,4 +28,5 @@ import ./make-test-python.nix ({ pkgs, ... }: { machine.wait_for_text("Hello world") machine.screenshot("screen") ''; -}) + } +) diff --git a/nixos/tests/languagetool.nix b/nixos/tests/languagetool.nix index e4ab2a47064e68..35ab59b5d8610d 100644 --- a/nixos/tests/languagetool.nix +++ b/nixos/tests/languagetool.nix @@ -1,19 +1,26 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let port = 8082; -in { - name = "languagetool"; - meta = with lib.maintainers; { maintainers = [ fbeffa ]; }; - - nodes.machine = { ... }: - { - services.languagetool.enable = true; - services.languagetool.port = port; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + port = 8082; + in + { + name = "languagetool"; + meta = with lib.maintainers; { + maintainers = [ fbeffa ]; }; - testScript = '' - machine.start() - machine.wait_for_unit("languagetool.service") - machine.wait_for_open_port(${toString port}) - machine.wait_until_succeeds('curl -d "language=en-US" -d "text=a simple test" http://localhost:${toString port}/v2/check') - ''; -}) + nodes.machine = + { ... }: + { + services.languagetool.enable = true; + services.languagetool.port = port; + }; + + testScript = '' + machine.start() + machine.wait_for_unit("languagetool.service") + machine.wait_for_open_port(${toString port}) + machine.wait_until_succeeds('curl -d "language=en-US" -d "text=a simple test" http://localhost:${toString port}/v2/check') + ''; + } +) diff --git a/nixos/tests/lanraragi.nix b/nixos/tests/lanraragi.nix index 7a4a1a489bdffc..21a065845c64b4 100644 --- a/nixos/tests/lanraragi.nix +++ b/nixos/tests/lanraragi.nix @@ -1,38 +1,44 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "lanraragi"; - meta.maintainers = with lib.maintainers; [ tomasajt ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "lanraragi"; + meta.maintainers = with lib.maintainers; [ tomasajt ]; - nodes = { - machine1 = { pkgs, ... }: { - services.lanraragi.enable = true; - }; - machine2 = { pkgs, ... }: { - services.lanraragi = { - enable = true; - passwordFile = pkgs.writeText "lrr-test-pass" '' - Ultra-secure-p@ssword-"with-spec1al\chars - ''; - port = 4000; - redis = { - port = 4001; - passwordFile = pkgs.writeText "redis-lrr-test-pass" '' - 123-redis-PASS - ''; + nodes = { + machine1 = + { pkgs, ... }: + { + services.lanraragi.enable = true; + }; + machine2 = + { pkgs, ... }: + { + services.lanraragi = { + enable = true; + passwordFile = pkgs.writeText "lrr-test-pass" '' + Ultra-secure-p@ssword-"with-spec1al\chars + ''; + port = 4000; + redis = { + port = 4001; + passwordFile = pkgs.writeText "redis-lrr-test-pass" '' + 123-redis-PASS + ''; + }; + }; }; - }; }; - }; - - testScript = '' - start_all() - machine1.wait_for_unit("lanraragi.service") - machine1.wait_until_succeeds("curl -f localhost:3000") - machine1.succeed("[ $(curl -o /dev/null -X post 'http://localhost:3000/login' --data-raw 'password=kamimamita' -w '%{http_code}') -eq 302 ]") + testScript = '' + start_all() - machine2.wait_for_unit("lanraragi.service") - machine2.wait_until_succeeds("curl -f localhost:4000") - machine2.succeed("[ $(curl -o /dev/null -X post 'http://localhost:4000/login' --data-raw 'password=Ultra-secure-p@ssword-\"with-spec1al\\chars' -w '%{http_code}') -eq 302 ]") - ''; -}) + machine1.wait_for_unit("lanraragi.service") + machine1.wait_until_succeeds("curl -f localhost:3000") + machine1.succeed("[ $(curl -o /dev/null -X post 'http://localhost:3000/login' --data-raw 'password=kamimamita' -w '%{http_code}') -eq 302 ]") + machine2.wait_for_unit("lanraragi.service") + machine2.wait_until_succeeds("curl -f localhost:4000") + machine2.succeed("[ $(curl -o /dev/null -X post 'http://localhost:4000/login' --data-raw 'password=Ultra-secure-p@ssword-\"with-spec1al\\chars' -w '%{http_code}') -eq 302 ]") + ''; + } +) diff --git a/nixos/tests/leaps.nix b/nixos/tests/leaps.nix index 5cc387c86a4523..92847d83eaebbd 100644 --- a/nixos/tests/leaps.nix +++ b/nixos/tests/leaps.nix @@ -1,27 +1,26 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -{ - name = "leaps"; - meta = with pkgs.lib.maintainers; { - maintainers = [ qknight ]; - }; + { + name = "leaps"; + meta = with pkgs.lib.maintainers; { + maintainers = [ qknight ]; + }; - nodes = - { + nodes = { client = { }; - server = - { services.leaps = { - enable = true; - port = 6666; - path = "/leaps/"; - }; - networking.firewall.enable = false; + server = { + services.leaps = { + enable = true; + port = 6666; + path = "/leaps/"; }; + networking.firewall.enable = false; + }; }; - testScript = - '' + testScript = '' start_all() server.wait_for_open_port(6666) client.wait_for_unit("network.target") @@ -29,4 +28,5 @@ import ./make-test-python.nix ({ pkgs, ... }: "${pkgs.curl}/bin/curl -f http://server:6666/leaps/" ) ''; -}) + } +) diff --git a/nixos/tests/legit.nix b/nixos/tests/legit.nix index a71fb1743c76f8..405c69a52fade9 100644 --- a/nixos/tests/legit.nix +++ b/nixos/tests/legit.nix @@ -1,54 +1,59 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -let - port = 5000; - scanPath = "/var/lib/legit"; -in -{ - name = "legit-web"; - meta.maintainers = [ lib.maintainers.ratsclub ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let + port = 5000; + scanPath = "/var/lib/legit"; + in + { + name = "legit-web"; + meta.maintainers = [ lib.maintainers.ratsclub ]; - nodes = { - server = { config, pkgs, ... }: { - services.legit = { - enable = true; - settings = { - server.port = 5000; - repo = { inherit scanPath; }; - }; - }; + nodes = { + server = + { config, pkgs, ... }: + { + services.legit = { + enable = true; + settings = { + server.port = 5000; + repo = { inherit scanPath; }; + }; + }; - environment.systemPackages = [ pkgs.git ]; + environment.systemPackages = [ pkgs.git ]; + }; }; - }; - testScript = { nodes, ... }: - let - strPort = builtins.toString port; - in - '' - start_all() + testScript = + { nodes, ... }: + let + strPort = builtins.toString port; + in + '' + start_all() - server.wait_for_unit("network.target") - server.wait_for_unit("legit.service") + server.wait_for_unit("network.target") + server.wait_for_unit("legit.service") - server.wait_until_succeeds( - "curl -f http://localhost:${strPort}" - ) + server.wait_until_succeeds( + "curl -f http://localhost:${strPort}" + ) - server.succeed("${pkgs.writeShellScript "setup-legit-test-repo" '' - set -e - git init --bare -b master ${scanPath}/some-repo - git init -b master reference - cd reference - git remote add origin ${scanPath}/some-repo - date > date.txt - git add date.txt - git -c user.name=test -c user.email=test@localhost commit -m 'add date' - git push -u origin master - ''}") + server.succeed("${pkgs.writeShellScript "setup-legit-test-repo" '' + set -e + git init --bare -b master ${scanPath}/some-repo + git init -b master reference + cd reference + git remote add origin ${scanPath}/some-repo + date > date.txt + git add date.txt + git -c user.name=test -c user.email=test@localhost commit -m 'add date' + git push -u origin master + ''}") - server.wait_until_succeeds( - "curl -f http://localhost:${strPort}/some-repo" - ) - ''; -}) + server.wait_until_succeeds( + "curl -f http://localhost:${strPort}/some-repo" + ) + ''; + } +) diff --git a/nixos/tests/lemmy.nix b/nixos/tests/lemmy.nix index 66bdaffbe29e35..5dc8cf10731667 100644 --- a/nixos/tests/lemmy.nix +++ b/nixos/tests/lemmy.nix @@ -1,100 +1,104 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - uiPort = 1234; - backendPort = 5678; - lemmyNodeName = "server"; -in -{ - name = "lemmy"; - meta = with lib.maintainers; { maintainers = [ mightyiam ]; }; - - nodes = { - client = { }; - - "${lemmyNodeName}" = { - services.lemmy = { - enable = true; - ui.port = uiPort; - database.createLocally = true; - settings = { - hostname = "http://${lemmyNodeName}"; - port = backendPort; - # Without setup, the /feeds/* and /nodeinfo/* API endpoints won't return 200 - setup = { - admin_username = "mightyiam"; - site_name = "Lemmy FTW"; - admin_email = "mightyiam@example.com"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + uiPort = 1234; + backendPort = 5678; + lemmyNodeName = "server"; + in + { + name = "lemmy"; + meta = with lib.maintainers; { + maintainers = [ mightyiam ]; + }; + + nodes = { + client = { }; + + "${lemmyNodeName}" = { + services.lemmy = { + enable = true; + ui.port = uiPort; + database.createLocally = true; + settings = { + hostname = "http://${lemmyNodeName}"; + port = backendPort; + # Without setup, the /feeds/* and /nodeinfo/* API endpoints won't return 200 + setup = { + admin_username = "mightyiam"; + site_name = "Lemmy FTW"; + admin_email = "mightyiam@example.com"; + }; }; + adminPasswordFile = /etc/lemmy-admin-password.txt; + caddy.enable = true; }; - adminPasswordFile = /etc/lemmy-admin-password.txt; - caddy.enable = true; - }; - environment.etc."lemmy-admin-password.txt".text = "ThisIsWhatIUseEverywhereTryIt"; + environment.etc."lemmy-admin-password.txt".text = "ThisIsWhatIUseEverywhereTryIt"; - networking.firewall.allowedTCPPorts = [ 80 ]; + networking.firewall.allowedTCPPorts = [ 80 ]; - # pict-rs seems to need more than 1025114112 bytes - virtualisation.memorySize = 2000; + # pict-rs seems to need more than 1025114112 bytes + virtualisation.memorySize = 2000; + }; }; - }; - - testScript = '' - server = ${lemmyNodeName} - - with subtest("the merged config is secure"): - server.wait_for_unit("lemmy.service") - config_permissions = server.succeed("stat --format %A /run/lemmy/config.hjson").rstrip() - assert config_permissions == "-rw-------", f"merged config permissions {config_permissions} are insecure" - directory_permissions = server.succeed("stat --format %A /run/lemmy").rstrip() - assert directory_permissions[5] == directory_permissions[8] == "-", "merged config can be replaced" - - with subtest("the backend starts and responds"): - server.wait_for_open_port(${toString backendPort}) - # wait until succeeds, it just needs few seconds for migrations, but lets give it 50s max - server.wait_until_succeeds("curl --fail localhost:${toString backendPort}/api/v3/site", 50) - - with subtest("the UI starts and responds"): - server.wait_for_unit("lemmy-ui.service") - server.wait_for_open_port(${toString uiPort}) - server.succeed("curl --fail localhost:${toString uiPort}") - - with subtest("Lemmy-UI responds through the caddy reverse proxy"): - server.systemctl("start network-online.target") - server.wait_for_unit("network-online.target") - server.wait_for_unit("caddy.service") - server.wait_for_open_port(80) - body = server.execute("curl --fail --location ${lemmyNodeName}")[1] - assert "Lemmy" in body, f"String Lemmy not found in response for ${lemmyNodeName}: \n{body}" - - with subtest("the server is exposed externally"): - client.systemctl("start network-online.target") - client.wait_for_unit("network-online.target") - client.succeed("curl -v --fail ${lemmyNodeName}") - - with subtest("caddy correctly routes backend requests"): - # Make sure we are not hitting frontend - server.execute("systemctl stop lemmy-ui.service") - - def assert_http_code(url, expected_http_code, extra_curl_args=""): - _, http_code = server.execute(f'curl --location --silent -o /dev/null {extra_curl_args} --fail --write-out "%{{http_code}}" {url}') - assert http_code == str(expected_http_code), f"expected http code {expected_http_code}, got {http_code}" - - # Caddy responds with HTTP code 502 if it cannot handle the requested path - assert_http_code("${lemmyNodeName}/obviously-wrong-path/", 502) - - assert_http_code("${lemmyNodeName}/static/js/client.js", 200) - assert_http_code("${lemmyNodeName}/api/v3/site", 200) - - # A 404 confirms that the request goes to the backend - # No path can return 200 until after we upload an image to pict-rs - assert_http_code("${lemmyNodeName}/pictrs/", 404) - - assert_http_code("${lemmyNodeName}/feeds/all.xml", 200) - assert_http_code("${lemmyNodeName}/nodeinfo/2.0.json", 200) - - assert_http_code("${lemmyNodeName}/some-other-made-up-path/", 404, "-X POST") - assert_http_code("${lemmyNodeName}/some-other-path", 404, "-H 'Accept: application/activity+json'") - assert_http_code("${lemmyNodeName}/some-other-path", 404, "-H 'Accept: application/ld+json; profile=\"https://www.w3.org/ns/activitystreams\"'") - ''; -}) + + testScript = '' + server = ${lemmyNodeName} + + with subtest("the merged config is secure"): + server.wait_for_unit("lemmy.service") + config_permissions = server.succeed("stat --format %A /run/lemmy/config.hjson").rstrip() + assert config_permissions == "-rw-------", f"merged config permissions {config_permissions} are insecure" + directory_permissions = server.succeed("stat --format %A /run/lemmy").rstrip() + assert directory_permissions[5] == directory_permissions[8] == "-", "merged config can be replaced" + + with subtest("the backend starts and responds"): + server.wait_for_open_port(${toString backendPort}) + # wait until succeeds, it just needs few seconds for migrations, but lets give it 50s max + server.wait_until_succeeds("curl --fail localhost:${toString backendPort}/api/v3/site", 50) + + with subtest("the UI starts and responds"): + server.wait_for_unit("lemmy-ui.service") + server.wait_for_open_port(${toString uiPort}) + server.succeed("curl --fail localhost:${toString uiPort}") + + with subtest("Lemmy-UI responds through the caddy reverse proxy"): + server.systemctl("start network-online.target") + server.wait_for_unit("network-online.target") + server.wait_for_unit("caddy.service") + server.wait_for_open_port(80) + body = server.execute("curl --fail --location ${lemmyNodeName}")[1] + assert "Lemmy" in body, f"String Lemmy not found in response for ${lemmyNodeName}: \n{body}" + + with subtest("the server is exposed externally"): + client.systemctl("start network-online.target") + client.wait_for_unit("network-online.target") + client.succeed("curl -v --fail ${lemmyNodeName}") + + with subtest("caddy correctly routes backend requests"): + # Make sure we are not hitting frontend + server.execute("systemctl stop lemmy-ui.service") + + def assert_http_code(url, expected_http_code, extra_curl_args=""): + _, http_code = server.execute(f'curl --location --silent -o /dev/null {extra_curl_args} --fail --write-out "%{{http_code}}" {url}') + assert http_code == str(expected_http_code), f"expected http code {expected_http_code}, got {http_code}" + + # Caddy responds with HTTP code 502 if it cannot handle the requested path + assert_http_code("${lemmyNodeName}/obviously-wrong-path/", 502) + + assert_http_code("${lemmyNodeName}/static/js/client.js", 200) + assert_http_code("${lemmyNodeName}/api/v3/site", 200) + + # A 404 confirms that the request goes to the backend + # No path can return 200 until after we upload an image to pict-rs + assert_http_code("${lemmyNodeName}/pictrs/", 404) + + assert_http_code("${lemmyNodeName}/feeds/all.xml", 200) + assert_http_code("${lemmyNodeName}/nodeinfo/2.0.json", 200) + + assert_http_code("${lemmyNodeName}/some-other-made-up-path/", 404, "-X POST") + assert_http_code("${lemmyNodeName}/some-other-path", 404, "-H 'Accept: application/activity+json'") + assert_http_code("${lemmyNodeName}/some-other-path", 404, "-H 'Accept: application/ld+json; profile=\"https://www.w3.org/ns/activitystreams\"'") + ''; + } +) diff --git a/nixos/tests/libinput.nix b/nixos/tests/libinput.nix index b002492b166570..32858c80da8501 100644 --- a/nixos/tests/libinput.nix +++ b/nixos/tests/libinput.nix @@ -1,38 +1,41 @@ -import ./make-test-python.nix ({ ... }: +import ./make-test-python.nix ( + { ... }: -{ - name = "libinput"; + { + name = "libinput"; - nodes.machine = { ... }: - { - imports = [ - ./common/x11.nix - ./common/user-account.nix - ]; + nodes.machine = + { ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; - test-support.displayManager.auto.user = "alice"; + test-support.displayManager.auto.user = "alice"; - services.libinput = { - enable = true; - mouse = { - naturalScrolling = true; - leftHanded = true; - middleEmulation = false; - horizontalScrolling = false; + services.libinput = { + enable = true; + mouse = { + naturalScrolling = true; + leftHanded = true; + middleEmulation = false; + horizontalScrolling = false; + }; }; }; - }; - testScript = '' - def expect_xserver_option(option, value): - machine.succeed(f"""cat /var/log/X.0.log | grep -F 'Option "{option}" "{value}"'""") + testScript = '' + def expect_xserver_option(option, value): + machine.succeed(f"""cat /var/log/X.0.log | grep -F 'Option "{option}" "{value}"'""") - machine.start() - machine.wait_for_x() - machine.succeed("""cat /var/log/X.0.log | grep -F "Using input driver 'libinput'" """) - expect_xserver_option("NaturalScrolling", "on") - expect_xserver_option("LeftHanded", "on") - expect_xserver_option("MiddleEmulation", "off") - expect_xserver_option("HorizontalScrolling", "off") - ''; -}) + machine.start() + machine.wait_for_x() + machine.succeed("""cat /var/log/X.0.log | grep -F "Using input driver 'libinput'" """) + expect_xserver_option("NaturalScrolling", "on") + expect_xserver_option("LeftHanded", "on") + expect_xserver_option("MiddleEmulation", "off") + expect_xserver_option("HorizontalScrolling", "off") + ''; + } +) diff --git a/nixos/tests/librenms.nix b/nixos/tests/librenms.nix index 14035a01ce87dd..05821dfa100067 100644 --- a/nixos/tests/librenms.nix +++ b/nixos/tests/librenms.nix @@ -1,104 +1,106 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: - -let - api_token = "f87f42114e44b63ad1b9e3c3d33d6fbe"; # random md5 hash - wrong_api_token = "e68ba041fcf1eab923a7a6de3af5f726"; # another random md5 hash -in -{ - name = "librenms"; - meta.maintainers = lib.teams.wdz.members; - - nodes.librenms = { - time.timeZone = "Europe/Berlin"; - - environment.systemPackages = with pkgs; [ - curl - jq - ]; - - services.librenms = { - enable = true; - hostname = "librenms"; - database = { - createLocally = true; - host = "localhost"; - database = "librenms"; - username = "librenms"; - passwordFile = pkgs.writeText "librenms-db-pass" "librenmsdbpass"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + let + api_token = "f87f42114e44b63ad1b9e3c3d33d6fbe"; # random md5 hash + wrong_api_token = "e68ba041fcf1eab923a7a6de3af5f726"; # another random md5 hash + in + { + name = "librenms"; + meta.maintainers = lib.teams.wdz.members; + + nodes.librenms = { + time.timeZone = "Europe/Berlin"; + + environment.systemPackages = with pkgs; [ + curl + jq + ]; + + services.librenms = { + enable = true; + hostname = "librenms"; + database = { + createLocally = true; + host = "localhost"; + database = "librenms"; + username = "librenms"; + passwordFile = pkgs.writeText "librenms-db-pass" "librenmsdbpass"; + }; + nginx = { + default = true; + }; + enableOneMinutePolling = true; + settings = { + enable_billing = true; + }; }; - nginx = { - default = true; - }; - enableOneMinutePolling = true; - settings = { - enable_billing = true; - }; - }; - # systemd oneshot to create a dummy admin user and a API token for testing - systemd.services.lnms-api-init = { - description = "LibreNMS API init"; - after = [ "librenms-setup.service" ]; - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - Type = "oneshot"; - RemainAfterExit = true; - User = "root"; - Group = "root"; + # systemd oneshot to create a dummy admin user and a API token for testing + systemd.services.lnms-api-init = { + description = "LibreNMS API init"; + after = [ "librenms-setup.service" ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + Type = "oneshot"; + RemainAfterExit = true; + User = "root"; + Group = "root"; + }; + script = '' + API_USER_NAME=api + API_TOKEN=${api_token} # random md5 hash + + # seeding database to get the admin roles + ${pkgs.librenms}/artisan db:seed --force --no-interaction + + # we don't need to know the password, it just has to exist + API_USER_PASS=$(${pkgs.pwgen}/bin/pwgen -s 64 1) + ${pkgs.librenms}/artisan user:add $API_USER_NAME -r admin -p $API_USER_PASS + API_USER_ID=$(${pkgs.mariadb}/bin/mysql -D librenms -N -B -e "SELECT user_id FROM users WHERE username = '$API_USER_NAME';") + + ${pkgs.mariadb}/bin/mysql -D librenms -e "INSERT INTO api_tokens (user_id, token_hash, description) VALUES ($API_USER_ID, '$API_TOKEN', 'API User')" + ''; }; - script = '' - API_USER_NAME=api - API_TOKEN=${api_token} # random md5 hash - - # seeding database to get the admin roles - ${pkgs.librenms}/artisan db:seed --force --no-interaction - - # we don't need to know the password, it just has to exist - API_USER_PASS=$(${pkgs.pwgen}/bin/pwgen -s 64 1) - ${pkgs.librenms}/artisan user:add $API_USER_NAME -r admin -p $API_USER_PASS - API_USER_ID=$(${pkgs.mariadb}/bin/mysql -D librenms -N -B -e "SELECT user_id FROM users WHERE username = '$API_USER_NAME';") - - ${pkgs.mariadb}/bin/mysql -D librenms -e "INSERT INTO api_tokens (user_id, token_hash, description) VALUES ($API_USER_ID, '$API_TOKEN', 'API User')" - ''; }; - }; - nodes.snmphost = { + nodes.snmphost = { - services.snmpd = { - enable = true; - openFirewall = true; + services.snmpd = { + enable = true; + openFirewall = true; - configText = '' - com2sec readonly default public + configText = '' + com2sec readonly default public - group MyROGroup v2c readonly - view all included .1 80 - access MyROGroup "" any noauth exact all none none + group MyROGroup v2c readonly + view all included .1 80 + access MyROGroup "" any noauth exact all none none - syslocation Testcity, Testcountry - syscontact Testi mc Test - ''; + syslocation Testcity, Testcountry + syscontact Testi mc Test + ''; + }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - snmphost.wait_for_unit("snmpd.service") + snmphost.wait_for_unit("snmpd.service") - librenms.wait_for_unit("lnms-api-init.service") - librenms.wait_for_open_port(80) + librenms.wait_for_unit("lnms-api-init.service") + librenms.wait_for_open_port(80) - # Test that we can authenticate against the API - librenms.succeed("curl --fail -H 'X-Auth-Token: ${api_token}' http://localhost/api/v0") - librenms.fail("curl --fail -H 'X-Auth-Token: ${wrong_api_token}' http://localhost/api/v0") + # Test that we can authenticate against the API + librenms.succeed("curl --fail -H 'X-Auth-Token: ${api_token}' http://localhost/api/v0") + librenms.fail("curl --fail -H 'X-Auth-Token: ${wrong_api_token}' http://localhost/api/v0") - # add snmphost as a device - librenms.succeed("curl --fail -X POST -d '{\"hostname\":\"snmphost\",\"version\":\"v2c\",\"community\":\"public\"}' -H 'X-Auth-Token: ${api_token}' http://localhost/api/v0/devices") + # add snmphost as a device + librenms.succeed("curl --fail -X POST -d '{\"hostname\":\"snmphost\",\"version\":\"v2c\",\"community\":\"public\"}' -H 'X-Auth-Token: ${api_token}' http://localhost/api/v0/devices") - # wait until snmphost gets polled - librenms.wait_until_succeeds("test $(curl -H 'X-Auth-Token: ${api_token}' http://localhost/api/v0/devices/snmphost | jq -Mr .devices[0].last_polled) != 'null'") - ''; -}) + # wait until snmphost gets polled + librenms.wait_until_succeeds("test $(curl -H 'X-Auth-Token: ${api_token}' http://localhost/api/v0/devices/snmphost | jq -Mr .devices[0].last_polled) != 'null'") + ''; + } +) diff --git a/nixos/tests/libresprite.nix b/nixos/tests/libresprite.nix index 17bdfe7853aaf6..d0391178875051 100644 --- a/nixos/tests/libresprite.nix +++ b/nixos/tests/libresprite.nix @@ -1,25 +1,28 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "libresprite"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fgaz ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "libresprite"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fgaz ]; + }; - nodes.machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + nodes.machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; - environment.systemPackages = [ - pkgs.imagemagick - pkgs.libresprite - ]; - }; + services.xserver.enable = true; + environment.systemPackages = [ + pkgs.imagemagick + pkgs.libresprite + ]; + }; - enableOCR = true; + enableOCR = true; - testScript = - '' + testScript = '' machine.wait_for_x() machine.succeed("convert -font DejaVu-Sans +antialias label:'IT WORKS' image.png") machine.execute("libresprite image.png >&2 &") @@ -27,4 +30,5 @@ import ./make-test-python.nix ({ pkgs, ... }: { machine.wait_for_text("IT WORKS") machine.screenshot("screen") ''; -}) + } +) diff --git a/nixos/tests/libreswan-nat.nix b/nixos/tests/libreswan-nat.nix index 973e304f9e3a36..a8729f3dab2c1b 100644 --- a/nixos/tests/libreswan-nat.nix +++ b/nixos/tests/libreswan-nat.nix @@ -32,20 +32,28 @@ let # Common IPsec configuration baseTunnel = { services.libreswan.enable = true; - environment.etc."ipsec.d/tunnel.secrets" = - { text = ''@server %any : PSK "j1JbIi9WY07rxwcNQ6nbyThKCf9DGxWOyokXIQcAQUnafsNTUJxfsxwk9WYK8fHj"''; - mode = "600"; - }; + environment.etc."ipsec.d/tunnel.secrets" = { + text = ''@server %any : PSK "j1JbIi9WY07rxwcNQ6nbyThKCf9DGxWOyokXIQcAQUnafsNTUJxfsxwk9WYK8fHj"''; + mode = "600"; + }; }; # Helpers to add a static IP address on an interface setAddress4 = iface: addr: { - networking.interfaces.${iface}.ipv4.addresses = - lib.mkVMOverride [ { address = addr; prefixLength = 24; } ]; + networking.interfaces.${iface}.ipv4.addresses = lib.mkVMOverride [ + { + address = addr; + prefixLength = 24; + } + ]; }; setAddress6 = iface: addr: { - networking.interfaces.${iface}.ipv6.addresses = - lib.mkVMOverride [ { address = addr; prefixLength = 64; } ]; + networking.interfaces.${iface}.ipv6.addresses = lib.mkVMOverride [ + { + address = addr; + prefixLength = 64; + } + ]; }; in @@ -56,21 +64,26 @@ in maintainers = [ rnhmjoj ]; }; - nodes.router = { pkgs, ... }: lib.mkMerge [ - baseNetwork - (setAddress4 "eth1" "203.0.113.1") - (setAddress4 "eth2" "192.168.1.1") - { - virtualisation.vlans = [ 1 2 ]; - environment.systemPackages = [ pkgs.tcpdump ]; - networking.nat = { - enable = true; - externalInterface = "eth1"; - internalInterfaces = [ "eth2" ]; - }; - networking.firewall.trustedInterfaces = [ "eth2" ]; - } - ]; + nodes.router = + { pkgs, ... }: + lib.mkMerge [ + baseNetwork + (setAddress4 "eth1" "203.0.113.1") + (setAddress4 "eth2" "192.168.1.1") + { + virtualisation.vlans = [ + 1 + 2 + ]; + environment.systemPackages = [ pkgs.tcpdump ]; + networking.nat = { + enable = true; + externalInterface = "eth1"; + internalInterfaces = [ "eth2" ]; + }; + networking.firewall.trustedInterfaces = [ "eth2" ]; + } + ]; nodes.inner = lib.mkMerge [ baseNetwork @@ -84,8 +97,14 @@ in (setAddress4 "eth1" "203.0.113.2") (setAddress6 "eth2" "2001:db8::1") { - virtualisation.vlans = [ 1 3 ]; - networking.firewall.allowedUDPPorts = [ 500 4500 ]; + virtualisation.vlans = [ + 1 + 3 + ]; + networking.firewall.allowedUDPPorts = [ + 500 + 4500 + ]; networking.firewall.allowedTCPPorts = [ 993 ]; # see https://github.com/NixOS/nixpkgs/pull/310857 @@ -172,67 +191,66 @@ in } ]; - testScript = - '' - def client_to_host(machine, msg: str): - """ - Sends a message from client to server - """ - machine.execute("nc -lu :: 1234 >/tmp/msg &") - client.sleep(1) - client.succeed(f"echo '{msg}' | nc -uw 0 {machine.name} 1234") - client.sleep(1) - machine.succeed(f"grep '{msg}' /tmp/msg") - - - def eavesdrop(): - """ - Starts eavesdropping on the router - """ - match = "udp port 1234" - router.execute(f"tcpdump -i eth1 -c 1 -Avv {match} >/tmp/log &") - - - start_all() - - with subtest("Network is up"): - client.wait_until_succeeds("ping -c1 server") - client.succeed("systemctl restart ipsec") - server.succeed("systemctl restart ipsec") - - with subtest("Router can eavesdrop cleartext traffic"): - eavesdrop() - client_to_host(server, "I secretly love turnip") - router.sleep(1) - router.succeed("grep turnip /tmp/log") - - with subtest("Libreswan is ready"): - client.wait_for_unit("ipsec") - server.wait_for_unit("ipsec") - client.succeed("ipsec checkconfig") - server.succeed("ipsec checkconfig") - - with subtest("Client can't ping VPN host"): - client.fail("ping -c1 inner") - - with subtest("Client can start the tunnel"): - client.succeed("ipsec start tunnel") - client.succeed("ip -6 addr show lo | grep -q 2001:db8:0:0:c") - - with subtest("Client can ping VPN host"): - client.wait_until_succeeds("ping -c1 2001:db8::1") - client.succeed("ping -c1 inner") - - with subtest("Eve no longer can eavesdrop"): - eavesdrop() - client_to_host(inner, "Just kidding, I actually like rhubarb") - router.sleep(1) - router.fail("grep rhubarb /tmp/log") - - with subtest("TCP fallback is available"): - server.succeed("iptables -I nixos-fw -p udp -j DROP") - client.succeed("ipsec restart") - client.execute("ipsec start tunnel") - client.wait_until_succeeds("ping -c1 inner") - ''; + testScript = '' + def client_to_host(machine, msg: str): + """ + Sends a message from client to server + """ + machine.execute("nc -lu :: 1234 >/tmp/msg &") + client.sleep(1) + client.succeed(f"echo '{msg}' | nc -uw 0 {machine.name} 1234") + client.sleep(1) + machine.succeed(f"grep '{msg}' /tmp/msg") + + + def eavesdrop(): + """ + Starts eavesdropping on the router + """ + match = "udp port 1234" + router.execute(f"tcpdump -i eth1 -c 1 -Avv {match} >/tmp/log &") + + + start_all() + + with subtest("Network is up"): + client.wait_until_succeeds("ping -c1 server") + client.succeed("systemctl restart ipsec") + server.succeed("systemctl restart ipsec") + + with subtest("Router can eavesdrop cleartext traffic"): + eavesdrop() + client_to_host(server, "I secretly love turnip") + router.sleep(1) + router.succeed("grep turnip /tmp/log") + + with subtest("Libreswan is ready"): + client.wait_for_unit("ipsec") + server.wait_for_unit("ipsec") + client.succeed("ipsec checkconfig") + server.succeed("ipsec checkconfig") + + with subtest("Client can't ping VPN host"): + client.fail("ping -c1 inner") + + with subtest("Client can start the tunnel"): + client.succeed("ipsec start tunnel") + client.succeed("ip -6 addr show lo | grep -q 2001:db8:0:0:c") + + with subtest("Client can ping VPN host"): + client.wait_until_succeeds("ping -c1 2001:db8::1") + client.succeed("ping -c1 inner") + + with subtest("Eve no longer can eavesdrop"): + eavesdrop() + client_to_host(inner, "Just kidding, I actually like rhubarb") + router.sleep(1) + router.fail("grep rhubarb /tmp/log") + + with subtest("TCP fallback is available"): + server.succeed("iptables -I nixos-fw -p udp -j DROP") + client.succeed("ipsec restart") + client.execute("ipsec start tunnel") + client.wait_until_succeeds("ping -c1 inner") + ''; } diff --git a/nixos/tests/libreswan.nix b/nixos/tests/libreswan.nix index 1a25c1e6d9af74..9e850b554baf6c 100644 --- a/nixos/tests/libreswan.nix +++ b/nixos/tests/libreswan.nix @@ -10,19 +10,18 @@ let # IPsec tunnel between Alice and Bob tunnelConfig = { services.libreswan.enable = true; - services.libreswan.connections.tunnel = - '' - leftid=@alice - left=fd::a - rightid=@bob - right=fd::b - authby=secret - auto=add - ''; - environment.etc."ipsec.d/tunnel.secrets" = - { text = ''@alice @bob : PSK "j1JbIi9WY07rxwcNQ6nbyThKCf9DGxWOyokXIQcAQUnafsNTUJxfsxwk9WYK8fHj"''; - mode = "600"; - }; + services.libreswan.connections.tunnel = '' + leftid=@alice + left=fd::a + rightid=@bob + right=fd::b + authby=secret + auto=add + ''; + environment.etc."ipsec.d/tunnel.secrets" = { + text = ''@alice @bob : PSK "j1JbIi9WY07rxwcNQ6nbyThKCf9DGxWOyokXIQcAQUnafsNTUJxfsxwk9WYK8fHj"''; + mode = "600"; + }; }; # Common network setup @@ -35,20 +34,29 @@ let ''; # remove all automatic addresses useDHCP = false; - interfaces.eth1.ipv4.addresses = lib.mkVMOverride []; - interfaces.eth2.ipv4.addresses = lib.mkVMOverride []; - interfaces.eth1.ipv6.addresses = lib.mkVMOverride []; - interfaces.eth2.ipv6.addresses = lib.mkVMOverride []; + interfaces.eth1.ipv4.addresses = lib.mkVMOverride [ ]; + interfaces.eth2.ipv4.addresses = lib.mkVMOverride [ ]; + interfaces.eth1.ipv6.addresses = lib.mkVMOverride [ ]; + interfaces.eth2.ipv6.addresses = lib.mkVMOverride [ ]; # open a port for testing firewall.allowedUDPPorts = [ 1234 ]; }; # Adds an address and route from a to b via Eve addRoute = a: b: { - interfaces.eth1.ipv6.addresses = - [ { address = a; prefixLength = 64; } ]; - interfaces.eth1.ipv6.routes = - [ { address = b; prefixLength = 128; via = "fd::e"; } ]; + interfaces.eth1.ipv6.addresses = [ + { + address = a; + prefixLength = 64; + } + ]; + interfaces.eth1.ipv6.routes = [ + { + address = b; + prefixLength = 128; + via = "fd::e"; + } + ]; }; in @@ -60,79 +68,97 @@ in }; # Our protagonist - nodes.alice = { ... }: { - virtualisation.vlans = [ 1 ]; - networking = baseNetwork // addRoute "fd::a" "fd::b"; - } // tunnelConfig; + nodes.alice = + { ... }: + { + virtualisation.vlans = [ 1 ]; + networking = baseNetwork // addRoute "fd::a" "fd::b"; + } + // tunnelConfig; # Her best friend - nodes.bob = { ... }: { - virtualisation.vlans = [ 2 ]; - networking = baseNetwork // addRoute "fd::b" "fd::a"; - } // tunnelConfig; + nodes.bob = + { ... }: + { + virtualisation.vlans = [ 2 ]; + networking = baseNetwork // addRoute "fd::b" "fd::a"; + } + // tunnelConfig; # The malicious network operator - nodes.eve = { ... }: { - virtualisation.vlans = [ 1 2 ]; - networking = lib.mkMerge - [ baseNetwork - { interfaces.br0.ipv6.addresses = - [ { address = "fd::e"; prefixLength = 64; } ]; - bridges.br0.interfaces = [ "eth1" "eth2" ]; + nodes.eve = + { ... }: + { + virtualisation.vlans = [ + 1 + 2 + ]; + networking = lib.mkMerge [ + baseNetwork + { + interfaces.br0.ipv6.addresses = [ + { + address = "fd::e"; + prefixLength = 64; + } + ]; + bridges.br0.interfaces = [ + "eth1" + "eth2" + ]; } ]; - environment.systemPackages = [ pkgs.tcpdump ]; - boot.kernel.sysctl."net.ipv6.conf.all.forwarding" = true; - }; - - testScript = - '' - def alice_to_bob(msg: str): - """ - Sends a message as Alice to Bob - """ - bob.execute("nc -lu ::0 1234 >/tmp/msg &") - alice.sleep(1) - alice.succeed(f"echo '{msg}' | nc -uw 0 bob 1234") - bob.succeed(f"grep '{msg}' /tmp/msg") - - - def eavesdrop(): - """ - Starts eavesdropping on Alice and Bob - """ - match = "src host alice and dst host bob" - eve.execute(f"tcpdump -i br0 -c 1 -Avv {match} >/tmp/log &") - - - start_all() - - with subtest("Network is up"): - alice.wait_until_succeeds("ping -c1 bob") - alice.succeed("systemctl restart ipsec") - bob.succeed("systemctl restart ipsec") - - with subtest("Eve can eavesdrop cleartext traffic"): - eavesdrop() - alice_to_bob("I secretly love turnip") - eve.sleep(1) - eve.succeed("grep turnip /tmp/log") - - with subtest("Libreswan is ready"): - alice.wait_for_unit("ipsec") - bob.wait_for_unit("ipsec") - alice.succeed("ipsec checkconfig") - - with subtest("Alice and Bob can start the tunnel"): - alice.execute("ipsec start tunnel >&2 &") - bob.succeed("ipsec start tunnel") - # apparently this is needed to "wake" the tunnel - bob.execute("ping -c1 alice") - - with subtest("Eve no longer can eavesdrop"): - eavesdrop() - alice_to_bob("Just kidding, I actually like rhubarb") - eve.sleep(1) - eve.fail("grep rhubarb /tmp/log") - ''; + environment.systemPackages = [ pkgs.tcpdump ]; + boot.kernel.sysctl."net.ipv6.conf.all.forwarding" = true; + }; + + testScript = '' + def alice_to_bob(msg: str): + """ + Sends a message as Alice to Bob + """ + bob.execute("nc -lu ::0 1234 >/tmp/msg &") + alice.sleep(1) + alice.succeed(f"echo '{msg}' | nc -uw 0 bob 1234") + bob.succeed(f"grep '{msg}' /tmp/msg") + + + def eavesdrop(): + """ + Starts eavesdropping on Alice and Bob + """ + match = "src host alice and dst host bob" + eve.execute(f"tcpdump -i br0 -c 1 -Avv {match} >/tmp/log &") + + + start_all() + + with subtest("Network is up"): + alice.wait_until_succeeds("ping -c1 bob") + alice.succeed("systemctl restart ipsec") + bob.succeed("systemctl restart ipsec") + + with subtest("Eve can eavesdrop cleartext traffic"): + eavesdrop() + alice_to_bob("I secretly love turnip") + eve.sleep(1) + eve.succeed("grep turnip /tmp/log") + + with subtest("Libreswan is ready"): + alice.wait_for_unit("ipsec") + bob.wait_for_unit("ipsec") + alice.succeed("ipsec checkconfig") + + with subtest("Alice and Bob can start the tunnel"): + alice.execute("ipsec start tunnel >&2 &") + bob.succeed("ipsec start tunnel") + # apparently this is needed to "wake" the tunnel + bob.execute("ping -c1 alice") + + with subtest("Eve no longer can eavesdrop"): + eavesdrop() + alice_to_bob("Just kidding, I actually like rhubarb") + eve.sleep(1) + eve.fail("grep rhubarb /tmp/log") + ''; } diff --git a/nixos/tests/libuiohook.nix b/nixos/tests/libuiohook.nix index 66c5033d96886a..bd0cdcc7696aa2 100644 --- a/nixos/tests/libuiohook.nix +++ b/nixos/tests/libuiohook.nix @@ -1,21 +1,35 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "libuiohook"; - meta = with lib.maintainers; { maintainers = [ anoa ]; }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "libuiohook"; + meta = with lib.maintainers; { + maintainers = [ anoa ]; + }; - nodes.client = { nodes, ... }: - let user = nodes.client.config.users.users.alice; - in { - imports = [ ./common/user-account.nix ./common/x11.nix ]; + nodes.client = + { nodes, ... }: + let + user = nodes.client.config.users.users.alice; + in + { + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; environment.systemPackages = [ pkgs.libuiohook.test ]; test-support.displayManager.auto.user = user.name; }; - testScript = { nodes, ... }: - let user = nodes.client.config.users.users.alice; - in '' - client.wait_for_x() - client.succeed("su - alice -c ${pkgs.libuiohook.test}/share/uiohook_tests >&2 &") - ''; -}) + testScript = + { nodes, ... }: + let + user = nodes.client.config.users.users.alice; + in + '' + client.wait_for_x() + client.succeed("su - alice -c ${pkgs.libuiohook.test}/share/uiohook_tests >&2 &") + ''; + } +) diff --git a/nixos/tests/libvirtd.nix b/nixos/tests/libvirtd.nix index 0b068d5a2f08b5..3f996cdcde4ac4 100644 --- a/nixos/tests/libvirtd.nix +++ b/nixos/tests/libvirtd.nix @@ -1,73 +1,78 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "libvirtd"; - meta.maintainers = with pkgs.lib.maintainers; [ fpletz ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "libvirtd"; + meta.maintainers = with pkgs.lib.maintainers; [ fpletz ]; - nodes = { - virthost = - { pkgs, ... }: - { - virtualisation = { - cores = 2; - memorySize = 2048; + nodes = { + virthost = + { pkgs, ... }: + { + virtualisation = { + cores = 2; + memorySize = 2048; - libvirtd.enable = true; - libvirtd.hooks.qemu.is_working = "${pkgs.writeShellScript "testHook.sh" '' - touch /tmp/qemu_hook_is_working - ''}"; - libvirtd.nss.enable = true; - }; - boot.supportedFilesystems = [ "zfs" ]; - networking.hostId = "deadbeef"; # needed for zfs - security.polkit.enable = true; - environment.systemPackages = with pkgs; [ virt-manager ]; + libvirtd.enable = true; + libvirtd.hooks.qemu.is_working = "${pkgs.writeShellScript "testHook.sh" '' + touch /tmp/qemu_hook_is_working + ''}"; + libvirtd.nss.enable = true; + }; + boot.supportedFilesystems = [ "zfs" ]; + networking.hostId = "deadbeef"; # needed for zfs + security.polkit.enable = true; + environment.systemPackages = with pkgs; [ virt-manager ]; - # This adds `resolve` to the `hosts` line of /etc/nsswitch.conf; NSS modules placed after it - # will not be consulted. Therefore this tests that the libvirtd NSS modules will be - # be placed early enough for name resolution to work. - services.resolved.enable = true; - }; - }; + # This adds `resolve` to the `hosts` line of /etc/nsswitch.conf; NSS modules placed after it + # will not be consulted. Therefore this tests that the libvirtd NSS modules will be + # be placed early enough for name resolution to work. + services.resolved.enable = true; + }; + }; - testScript = let - nixosInstallISO = (import ../release.nix {}).iso_minimal.${pkgs.stdenv.hostPlatform.system}; - virshShutdownCmd = if pkgs.stdenv.hostPlatform.isx86_64 then "shutdown" else "destroy"; - in '' - start_all() + testScript = + let + nixosInstallISO = (import ../release.nix { }).iso_minimal.${pkgs.stdenv.hostPlatform.system}; + virshShutdownCmd = if pkgs.stdenv.hostPlatform.isx86_64 then "shutdown" else "destroy"; + in + '' + start_all() - virthost.wait_for_unit("multi-user.target") + virthost.wait_for_unit("multi-user.target") - with subtest("enable default network"): - virthost.succeed("virsh net-start default") - virthost.succeed("virsh net-autostart default") - virthost.succeed("virsh net-info default") + with subtest("enable default network"): + virthost.succeed("virsh net-start default") + virthost.succeed("virsh net-autostart default") + virthost.succeed("virsh net-info default") - with subtest("check if partition disk pools works with parted"): - virthost.succeed("fallocate -l100m /tmp/foo; losetup /dev/loop0 /tmp/foo; echo 'label: dos' | sfdisk /dev/loop0") - virthost.succeed("virsh pool-create-as foo disk --source-dev /dev/loop0 --target /dev") - virthost.succeed("virsh vol-create-as foo loop0p1 25MB") - virthost.succeed("virsh vol-create-as foo loop0p2 50MB") + with subtest("check if partition disk pools works with parted"): + virthost.succeed("fallocate -l100m /tmp/foo; losetup /dev/loop0 /tmp/foo; echo 'label: dos' | sfdisk /dev/loop0") + virthost.succeed("virsh pool-create-as foo disk --source-dev /dev/loop0 --target /dev") + virthost.succeed("virsh vol-create-as foo loop0p1 25MB") + virthost.succeed("virsh vol-create-as foo loop0p2 50MB") - with subtest("check if virsh zfs pools work"): - virthost.succeed("fallocate -l100m /tmp/zfs; losetup /dev/loop1 /tmp/zfs;") - virthost.succeed("zpool create zfs_loop /dev/loop1") - virthost.succeed("virsh pool-define-as --name zfs_storagepool --source-name zfs_loop --type zfs") - virthost.succeed("virsh pool-start zfs_storagepool") - virthost.succeed("virsh vol-create-as zfs_storagepool disk1 25MB") + with subtest("check if virsh zfs pools work"): + virthost.succeed("fallocate -l100m /tmp/zfs; losetup /dev/loop1 /tmp/zfs;") + virthost.succeed("zpool create zfs_loop /dev/loop1") + virthost.succeed("virsh pool-define-as --name zfs_storagepool --source-name zfs_loop --type zfs") + virthost.succeed("virsh pool-start zfs_storagepool") + virthost.succeed("virsh vol-create-as zfs_storagepool disk1 25MB") - with subtest("check if nixos install iso boots, network and autostart works"): - virthost.succeed( - "virt-install -n nixos --osinfo nixos-unstable --memory 1024 --graphics none --disk `find ${nixosInstallISO}/iso -type f | head -n1`,readonly=on --import --noautoconsole --autostart" - ) - virthost.succeed("virsh domstate nixos | grep running") - virthost.wait_until_succeeds("ping -c 1 nixos") - virthost.succeed("virsh ${virshShutdownCmd} nixos") - virthost.wait_until_succeeds("virsh domstate nixos | grep 'shut off'") - virthost.shutdown() - virthost.wait_for_unit("multi-user.target") - virthost.wait_until_succeeds("ping -c 1 nixos") + with subtest("check if nixos install iso boots, network and autostart works"): + virthost.succeed( + "virt-install -n nixos --osinfo nixos-unstable --memory 1024 --graphics none --disk `find ${nixosInstallISO}/iso -type f | head -n1`,readonly=on --import --noautoconsole --autostart" + ) + virthost.succeed("virsh domstate nixos | grep running") + virthost.wait_until_succeeds("ping -c 1 nixos") + virthost.succeed("virsh ${virshShutdownCmd} nixos") + virthost.wait_until_succeeds("virsh domstate nixos | grep 'shut off'") + virthost.shutdown() + virthost.wait_for_unit("multi-user.target") + virthost.wait_until_succeeds("ping -c 1 nixos") - with subtest("test if hooks are linked and run"): - virthost.succeed("ls /var/lib/libvirt/hooks/qemu.d/is_working") - virthost.succeed("ls /tmp/qemu_hook_is_working") - ''; -}) + with subtest("test if hooks are linked and run"): + virthost.succeed("ls /var/lib/libvirt/hooks/qemu.d/is_working") + virthost.succeed("ls /tmp/qemu_hook_is_working") + ''; + } +) diff --git a/nixos/tests/lidarr.nix b/nixos/tests/lidarr.nix index 8230dda53736c7..411d4a782390ca 100644 --- a/nixos/tests/lidarr.nix +++ b/nixos/tests/lidarr.nix @@ -1,18 +1,22 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "lidarr"; - meta.maintainers = with lib.maintainers; [ etu ]; + { + name = "lidarr"; + meta.maintainers = with lib.maintainers; [ etu ]; - nodes.machine = - { pkgs, ... }: - { services.lidarr.enable = true; }; + nodes.machine = + { pkgs, ... }: + { + services.lidarr.enable = true; + }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("lidarr.service") - machine.wait_for_open_port(8686) - machine.succeed("curl --fail http://localhost:8686/") - ''; -}) + machine.wait_for_unit("lidarr.service") + machine.wait_for_open_port(8686) + machine.succeed("curl --fail http://localhost:8686/") + ''; + } +) diff --git a/nixos/tests/lightdm.nix b/nixos/tests/lightdm.nix index 730983a8041344..8490f0a6ffaa94 100644 --- a/nixos/tests/lightdm.nix +++ b/nixos/tests/lightdm.nix @@ -1,28 +1,36 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "lightdm"; - meta = with pkgs.lib.maintainers; { - maintainers = [ aszlig ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "lightdm"; + meta = with pkgs.lib.maintainers; { + maintainers = [ aszlig ]; + }; - nodes.machine = { ... }: { - imports = [ ./common/user-account.nix ]; - services.xserver.enable = true; - services.xserver.displayManager.lightdm.enable = true; - services.displayManager.defaultSession = "none+icewm"; - services.xserver.windowManager.icewm.enable = true; - }; + nodes.machine = + { ... }: + { + imports = [ ./common/user-account.nix ]; + services.xserver.enable = true; + services.xserver.displayManager.lightdm.enable = true; + services.displayManager.defaultSession = "none+icewm"; + services.xserver.windowManager.icewm.enable = true; + }; - enableOCR = true; + enableOCR = true; - testScript = { nodes, ... }: let - user = nodes.machine.config.users.users.alice; - in '' - start_all() - machine.wait_for_text("${user.description}") - machine.screenshot("lightdm") - machine.send_chars("${user.password}\n") - machine.wait_for_file("${user.home}/.Xauthority") - machine.succeed("xauth merge ${user.home}/.Xauthority") - machine.wait_for_window("^IceWM ") - ''; -}) + testScript = + { nodes, ... }: + let + user = nodes.machine.config.users.users.alice; + in + '' + start_all() + machine.wait_for_text("${user.description}") + machine.screenshot("lightdm") + machine.send_chars("${user.password}\n") + machine.wait_for_file("${user.home}/.Xauthority") + machine.succeed("xauth merge ${user.home}/.Xauthority") + machine.wait_for_window("^IceWM ") + ''; + } +) diff --git a/nixos/tests/lighttpd.nix b/nixos/tests/lighttpd.nix index daef1584a45c71..271dc19ef68cb7 100644 --- a/nixos/tests/lighttpd.nix +++ b/nixos/tests/lighttpd.nix @@ -1,22 +1,25 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "lighttpd"; - meta.maintainers = with lib.maintainers; [ bjornfor ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "lighttpd"; + meta.maintainers = with lib.maintainers; [ bjornfor ]; - nodes = { - server = { - services.lighttpd.enable = true; - services.lighttpd.document-root = pkgs.runCommand "document-root" {} '' - mkdir -p "$out" - echo "hello nixos test" > "$out/file.txt" - ''; + nodes = { + server = { + services.lighttpd.enable = true; + services.lighttpd.document-root = pkgs.runCommand "document-root" { } '' + mkdir -p "$out" + echo "hello nixos test" > "$out/file.txt" + ''; + }; }; - }; - testScript = '' - start_all() - server.wait_for_unit("lighttpd.service") - res = server.succeed("curl --fail http://localhost/file.txt") - assert "hello nixos test" in res, f"bad server response: '{res}'" - server.succeed("systemctl reload lighttpd") - ''; -}) + testScript = '' + start_all() + server.wait_for_unit("lighttpd.service") + res = server.succeed("curl --fail http://localhost/file.txt") + assert "hello nixos test" in res, f"bad server response: '{res}'" + server.succeed("systemctl reload lighttpd") + ''; + } +) diff --git a/nixos/tests/limesurvey.nix b/nixos/tests/limesurvey.nix index 87e9fe1cdc1490..af6092b40193f3 100644 --- a/nixos/tests/limesurvey.nix +++ b/nixos/tests/limesurvey.nix @@ -1,28 +1,33 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "limesurvey"; - meta.maintainers = [ lib.maintainers.aanderse ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "limesurvey"; + meta.maintainers = [ lib.maintainers.aanderse ]; - nodes.machine = { ... }: { - services.limesurvey = { - enable = true; - virtualHost = { - hostName = "example.local"; - adminAddr = "root@example.local"; - }; - encryptionKeyFile = pkgs.writeText "key" (lib.strings.replicate 32 "0"); - encryptionNonceFile = pkgs.writeText "nonce" (lib.strings.replicate 24 "0"); - }; + nodes.machine = + { ... }: + { + services.limesurvey = { + enable = true; + virtualHost = { + hostName = "example.local"; + adminAddr = "root@example.local"; + }; + encryptionKeyFile = pkgs.writeText "key" (lib.strings.replicate 32 "0"); + encryptionNonceFile = pkgs.writeText "nonce" (lib.strings.replicate 24 "0"); + }; - # limesurvey won't work without a dot in the hostname - networking.hosts."127.0.0.1" = [ "example.local" ]; - }; + # limesurvey won't work without a dot in the hostname + networking.hosts."127.0.0.1" = [ "example.local" ]; + }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("phpfpm-limesurvey.service") - assert "The following surveys are available" in machine.succeed( - "curl -f http://example.local/" - ) - ''; -}) + machine.wait_for_unit("phpfpm-limesurvey.service") + assert "The following surveys are available" in machine.succeed( + "curl -f http://example.local/" + ) + ''; + } +) diff --git a/nixos/tests/listmonk.nix b/nixos/tests/listmonk.nix index 938c36026a7f88..31c2a59b8b65e5 100644 --- a/nixos/tests/listmonk.nix +++ b/nixos/tests/listmonk.nix @@ -1,76 +1,83 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "listmonk"; - meta.maintainers = with lib.maintainers; [ raitobezarius ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "listmonk"; + meta.maintainers = with lib.maintainers; [ raitobezarius ]; - nodes.machine = { pkgs, ... }: { - services.mailhog.enable = true; - services.listmonk = { - enable = true; - settings = { - admin_username = "listmonk"; - admin_password = "hunter2"; + nodes.machine = + { pkgs, ... }: + { + services.mailhog.enable = true; + services.listmonk = { + enable = true; + settings = { + admin_username = "listmonk"; + admin_password = "hunter2"; + }; + database = { + createLocally = true; + # https://github.com/knadh/listmonk/blob/174a48f252a146d7e69dab42724e3329dbe25ebe/internal/messenger/email/email.go#L18-L27 + settings.smtp = [ + { + enabled = true; + host = "localhost"; + port = 1025; + tls_type = "none"; + } + ]; + }; + }; }; - database = { - createLocally = true; - # https://github.com/knadh/listmonk/blob/174a48f252a146d7e69dab42724e3329dbe25ebe/internal/messenger/email/email.go#L18-L27 - settings.smtp = [ { - enabled = true; - host = "localhost"; - port = 1025; - tls_type = "none"; - }]; - }; - }; - }; - testScript = '' - import json + testScript = '' + import json - start_all() + start_all() - basic_auth = "listmonk:hunter2" - def generate_listmonk_request(type, url, data=None): - if data is None: data = {} - json_data = json.dumps(data) - return f'curl -u "{basic_auth}" -X {type} "http://localhost:9000/api/{url}" -H "Content-Type: application/json; charset=utf-8" --data-raw \'{json_data}\''' + basic_auth = "listmonk:hunter2" + def generate_listmonk_request(type, url, data=None): + if data is None: data = {} + json_data = json.dumps(data) + return f'curl -u "{basic_auth}" -X {type} "http://localhost:9000/api/{url}" -H "Content-Type: application/json; charset=utf-8" --data-raw \'{json_data}\''' - machine.wait_for_unit("mailhog.service") - machine.wait_for_unit("postgresql.service") - machine.wait_for_unit("listmonk.service") - machine.wait_for_open_port(1025) - machine.wait_for_open_port(8025) - machine.wait_for_open_port(9000) - machine.succeed("[[ -f /var/lib/listmonk/.db_settings_initialized ]]") + machine.wait_for_unit("mailhog.service") + machine.wait_for_unit("postgresql.service") + machine.wait_for_unit("listmonk.service") + machine.wait_for_open_port(1025) + machine.wait_for_open_port(8025) + machine.wait_for_open_port(9000) + machine.succeed("[[ -f /var/lib/listmonk/.db_settings_initialized ]]") - assert json.loads(machine.succeed(generate_listmonk_request("GET", 'health')))['data'], 'Health endpoint returned unexpected value' + assert json.loads(machine.succeed(generate_listmonk_request("GET", 'health')))['data'], 'Health endpoint returned unexpected value' - # A sample subscriber is guaranteed to exist at install-time - # A sample transactional template is guaranteed to exist at install-time - subscribers = json.loads(machine.succeed(generate_listmonk_request('GET', "subscribers")))['data']['results'] - templates = json.loads(machine.succeed(generate_listmonk_request('GET', "templates")))['data'] - tx_template = templates[2] + # A sample subscriber is guaranteed to exist at install-time + # A sample transactional template is guaranteed to exist at install-time + subscribers = json.loads(machine.succeed(generate_listmonk_request('GET', "subscribers")))['data']['results'] + templates = json.loads(machine.succeed(generate_listmonk_request('GET', "templates")))['data'] + tx_template = templates[2] - # Test transactional endpoint - print(machine.succeed( - generate_listmonk_request('POST', 'tx', data={'subscriber_id': subscribers[0]['id'], 'template_id': tx_template['id']}) - )) + # Test transactional endpoint + print(machine.succeed( + generate_listmonk_request('POST', 'tx', data={'subscriber_id': subscribers[0]['id'], 'template_id': tx_template['id']}) + )) - assert 'Welcome Anon Doe' in machine.succeed( - "curl --fail http://localhost:8025/api/v2/messages" - ), "Failed to find Welcome John Doe inside the messages API endpoint" + assert 'Welcome Anon Doe' in machine.succeed( + "curl --fail http://localhost:8025/api/v2/messages" + ), "Failed to find Welcome John Doe inside the messages API endpoint" - # Test campaign endpoint - # Based on https://github.com/knadh/listmonk/blob/174a48f252a146d7e69dab42724e3329dbe25ebe/cmd/campaigns.go#L549 as docs do not exist. - campaign_data = json.loads(machine.succeed( - generate_listmonk_request('POST', 'campaigns/1/test', data={'template_id': templates[0]['id'], 'subscribers': ['john@example.com'], 'name': 'Test', 'subject': 'NixOS is great', 'lists': [1], 'messenger': 'email'}) - )) + # Test campaign endpoint + # Based on https://github.com/knadh/listmonk/blob/174a48f252a146d7e69dab42724e3329dbe25ebe/cmd/campaigns.go#L549 as docs do not exist. + campaign_data = json.loads(machine.succeed( + generate_listmonk_request('POST', 'campaigns/1/test', data={'template_id': templates[0]['id'], 'subscribers': ['john@example.com'], 'name': 'Test', 'subject': 'NixOS is great', 'lists': [1], 'messenger': 'email'}) + )) - assert campaign_data['data'] # This is a boolean asserting if the test was successful or not: https://github.com/knadh/listmonk/blob/174a48f252a146d7e69dab42724e3329dbe25ebe/cmd/campaigns.go#L626 + assert campaign_data['data'] # This is a boolean asserting if the test was successful or not: https://github.com/knadh/listmonk/blob/174a48f252a146d7e69dab42724e3329dbe25ebe/cmd/campaigns.go#L626 - messages = json.loads(machine.succeed( - "curl --fail http://localhost:8025/api/v2/messages" - )) + messages = json.loads(machine.succeed( + "curl --fail http://localhost:8025/api/v2/messages" + )) - assert messages['total'] == 2 - ''; -}) + assert messages['total'] == 2 + ''; + } +) diff --git a/nixos/tests/litestream.nix b/nixos/tests/litestream.nix index a281d8538694cf..24fe804f3a9e8f 100644 --- a/nixos/tests/litestream.nix +++ b/nixos/tests/litestream.nix @@ -1,101 +1,114 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "litestream"; - meta = with pkgs.lib.maintainers; { - maintainers = [ jwygoda ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "litestream"; + meta = with pkgs.lib.maintainers; { + maintainers = [ jwygoda ]; + }; - nodes.machine = - { pkgs, ... }: - { services.litestream = { - enable = true; - settings = { - dbs = [ - { - path = "/var/lib/grafana/data/grafana.db"; - replicas = [{ - url = "sftp://foo:bar@127.0.0.1:22/home/foo/grafana"; - }]; - } - ]; + nodes.machine = + { pkgs, ... }: + { + services.litestream = { + enable = true; + settings = { + dbs = [ + { + path = "/var/lib/grafana/data/grafana.db"; + replicas = [ + { + url = "sftp://foo:bar@127.0.0.1:22/home/foo/grafana"; + } + ]; + } + ]; + }; }; - }; - systemd.services.grafana.serviceConfig.ExecStartPost = "+" + pkgs.writeShellScript "grant-grafana-permissions" '' - timeout=10 + systemd.services.grafana.serviceConfig.ExecStartPost = + "+" + + pkgs.writeShellScript "grant-grafana-permissions" '' + timeout=10 - while [ ! -f /var/lib/grafana/data/grafana.db ]; - do - if [ "$timeout" == 0 ]; then - echo "ERROR: Timeout while waiting for /var/lib/grafana/data/grafana.db." - exit 1 - fi + while [ ! -f /var/lib/grafana/data/grafana.db ]; + do + if [ "$timeout" == 0 ]; then + echo "ERROR: Timeout while waiting for /var/lib/grafana/data/grafana.db." + exit 1 + fi - sleep 1 + sleep 1 - ((timeout--)) - done + ((timeout--)) + done - find /var/lib/grafana -type d -exec chmod -v 775 {} \; - find /var/lib/grafana -type f -exec chmod -v 660 {} \; - ''; - services.openssh = { - enable = true; - allowSFTP = true; - listenAddresses = [ { addr = "127.0.0.1"; port = 22; } ]; - }; - services.grafana = { - enable = true; - settings = { - security = { - admin_user = "admin"; - admin_password = "admin"; - }; + find /var/lib/grafana -type d -exec chmod -v 775 {} \; + find /var/lib/grafana -type f -exec chmod -v 660 {} \; + ''; + services.openssh = { + enable = true; + allowSFTP = true; + listenAddresses = [ + { + addr = "127.0.0.1"; + port = 22; + } + ]; + }; + services.grafana = { + enable = true; + settings = { + security = { + admin_user = "admin"; + admin_password = "admin"; + }; - server = { - http_addr = "localhost"; - http_port = 3000; - }; + server = { + http_addr = "localhost"; + http_port = 3000; + }; - database = { - type = "sqlite3"; - path = "/var/lib/grafana/data/grafana.db"; - wal = true; + database = { + type = "sqlite3"; + path = "/var/lib/grafana/data/grafana.db"; + wal = true; + }; }; }; + users.users.foo = { + isNormalUser = true; + password = "bar"; + }; + users.users.litestream.extraGroups = [ "grafana" ]; }; - users.users.foo = { - isNormalUser = true; - password = "bar"; - }; - users.users.litestream.extraGroups = [ "grafana" ]; - }; - testScript = '' - start_all() - machine.wait_until_succeeds("test -d /home/foo/grafana") - machine.wait_for_open_port(3000) - machine.succeed(""" - curl -sSfN -X PUT -H "Content-Type: application/json" -d '{ - "oldPassword": "admin", - "newPassword": "newpass", - "confirmNew": "newpass" - }' http://admin:admin@127.0.0.1:3000/api/user/password - """) - # https://litestream.io/guides/systemd/#simulating-a-disaster - machine.systemctl("stop litestream.service") - machine.succeed( - "rm -f /var/lib/grafana/data/grafana.db " - "/var/lib/grafana/data/grafana.db-shm " - "/var/lib/grafana/data/grafana.db-wal" - ) - machine.succeed( - "litestream restore /var/lib/grafana/data/grafana.db " - "&& chown grafana:grafana /var/lib/grafana/data/grafana.db " - "&& chmod 660 /var/lib/grafana/data/grafana.db" - ) - machine.systemctl("restart grafana.service") - machine.wait_for_open_port(3000) - machine.succeed( - "curl -sSfN -u admin:newpass http://127.0.0.1:3000/api/org/users | grep admin\@localhost" - ) - ''; -}) + testScript = '' + start_all() + machine.wait_until_succeeds("test -d /home/foo/grafana") + machine.wait_for_open_port(3000) + machine.succeed(""" + curl -sSfN -X PUT -H "Content-Type: application/json" -d '{ + "oldPassword": "admin", + "newPassword": "newpass", + "confirmNew": "newpass" + }' http://admin:admin@127.0.0.1:3000/api/user/password + """) + # https://litestream.io/guides/systemd/#simulating-a-disaster + machine.systemctl("stop litestream.service") + machine.succeed( + "rm -f /var/lib/grafana/data/grafana.db " + "/var/lib/grafana/data/grafana.db-shm " + "/var/lib/grafana/data/grafana.db-wal" + ) + machine.succeed( + "litestream restore /var/lib/grafana/data/grafana.db " + "&& chown grafana:grafana /var/lib/grafana/data/grafana.db " + "&& chmod 660 /var/lib/grafana/data/grafana.db" + ) + machine.systemctl("restart grafana.service") + machine.wait_for_open_port(3000) + machine.succeed( + "curl -sSfN -u admin:newpass http://127.0.0.1:3000/api/org/users | grep admin\@localhost" + ) + ''; + } +) diff --git a/nixos/tests/livebook-service.nix b/nixos/tests/livebook-service.nix index 2d699efb1e3ee7..140b056c48d4bf 100644 --- a/nixos/tests/livebook-service.nix +++ b/nixos/tests/livebook-service.nix @@ -1,42 +1,48 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "livebook-service"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "livebook-service"; - nodes = { - machine = { config, pkgs, ... }: { - imports = [ - ./common/user-account.nix - ]; + nodes = { + machine = + { config, pkgs, ... }: + { + imports = [ + ./common/user-account.nix + ]; - services.livebook = { - enableUserService = true; - environment = { - LIVEBOOK_PORT = 20123; + services.livebook = { + enableUserService = true; + environment = { + LIVEBOOK_PORT = 20123; + }; + environmentFile = pkgs.writeText "livebook.env" '' + LIVEBOOK_PASSWORD = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" + ''; + }; }; - environmentFile = pkgs.writeText "livebook.env" '' - LIVEBOOK_PASSWORD = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" - ''; - }; }; - }; - testScript = { nodes, ... }: - let - user = nodes.machine.users.users.alice; - sudo = lib.concatStringsSep " " [ - "XDG_RUNTIME_DIR=/run/user/${toString user.uid}" - "sudo" - "--preserve-env=XDG_RUNTIME_DIR" - "-u" - "alice" - ]; - in - '' - machine.wait_for_unit("multi-user.target") + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + sudo = lib.concatStringsSep " " [ + "XDG_RUNTIME_DIR=/run/user/${toString user.uid}" + "sudo" + "--preserve-env=XDG_RUNTIME_DIR" + "-u" + "alice" + ]; + in + '' + machine.wait_for_unit("multi-user.target") - machine.succeed("loginctl enable-linger alice") - machine.wait_until_succeeds("${sudo} systemctl --user is-active livebook.service") - machine.wait_for_open_port(20123, timeout=10) + machine.succeed("loginctl enable-linger alice") + machine.wait_until_succeeds("${sudo} systemctl --user is-active livebook.service") + machine.wait_for_open_port(20123, timeout=10) - machine.succeed("curl -L localhost:20123 | grep 'Type password'") - ''; -}) + machine.succeed("curl -L localhost:20123 | grep 'Type password'") + ''; + } +) diff --git a/nixos/tests/lldap.nix b/nixos/tests/lldap.nix index d6c3a865aa04a6..610bda27b1cc14 100644 --- a/nixos/tests/lldap.nix +++ b/nixos/tests/lldap.nix @@ -1,26 +1,31 @@ -import ./make-test-python.nix ({ ... }: { - name = "lldap"; +import ./make-test-python.nix ( + { ... }: + { + name = "lldap"; - nodes.machine = { pkgs, ... }: { - services.lldap = { - enable = true; - settings = { - verbose = true; - ldap_base_dn = "dc=example,dc=com"; + nodes.machine = + { pkgs, ... }: + { + services.lldap = { + enable = true; + settings = { + verbose = true; + ldap_base_dn = "dc=example,dc=com"; + }; + }; + environment.systemPackages = [ pkgs.openldap ]; }; - }; - environment.systemPackages = [ pkgs.openldap ]; - }; - testScript = '' - machine.wait_for_unit("lldap.service") - machine.wait_for_open_port(3890) - machine.wait_for_open_port(17170) + testScript = '' + machine.wait_for_unit("lldap.service") + machine.wait_for_open_port(3890) + machine.wait_for_open_port(17170) - machine.succeed("curl --location --fail http://localhost:17170/") + machine.succeed("curl --location --fail http://localhost:17170/") - print( - machine.succeed('ldapsearch -H ldap://localhost:3890 -D uid=admin,ou=people,dc=example,dc=com -b "ou=people,dc=example,dc=com" -w password') - ) - ''; -}) + print( + machine.succeed('ldapsearch -H ldap://localhost:3890 -D uid=admin,ou=people,dc=example,dc=com -b "ou=people,dc=example,dc=com" -w password') + ) + ''; + } +) diff --git a/nixos/tests/locate.nix b/nixos/tests/locate.nix index e8ba41812a8f56..ce66d7fd3afc42 100644 --- a/nixos/tests/locate.nix +++ b/nixos/tests/locate.nix @@ -1,6 +1,9 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: - let inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; - in { +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let + inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; + in + { name = "locate"; meta.maintainers = with pkgs.lib.maintainers; [ chkno ]; @@ -59,4 +62,5 @@ import ./make-test-python.nix ({ lib, pkgs, ... }: # We shouldn't be able to see files on the other machine a.fail("locate file-on-b-machine") ''; - }) + } +) diff --git a/nixos/tests/login.nix b/nixos/tests/login.nix index e3b1b877940ac2..acfb270193abf2 100644 --- a/nixos/tests/login.nix +++ b/nixos/tests/login.nix @@ -1,17 +1,23 @@ -import ./make-test-python.nix ({ pkgs, latestKernel ? false, ... }: +import ./make-test-python.nix ( + { + pkgs, + latestKernel ? false, + ... + }: -{ - name = "login"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; - - nodes.machine = - { pkgs, lib, ... }: - { boot.kernelPackages = lib.mkIf latestKernel pkgs.linuxPackages_latest; + { + name = "login"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; }; - testScript = '' + nodes.machine = + { pkgs, lib, ... }: + { + boot.kernelPackages = lib.mkIf latestKernel pkgs.linuxPackages_latest; + }; + + testScript = '' machine.start(allow_reboot = True) machine.wait_for_unit("multi-user.target") @@ -63,5 +69,6 @@ import ./make-test-python.nix ({ pkgs, latestKernel ? false, ... }: assert boot_id2 != "" assert boot_id1 != boot_id2 - ''; -}) + ''; + } +) diff --git a/nixos/tests/logrotate.nix b/nixos/tests/logrotate.nix index 8d5887abec941e..1efbcc4cfed5d2 100644 --- a/nixos/tests/logrotate.nix +++ b/nixos/tests/logrotate.nix @@ -1,82 +1,94 @@ # Test logrotate service works and is enabled by default let - importTest = { ... }: { - services.logrotate.settings.import = { - olddir = false; + importTest = + { ... }: + { + services.logrotate.settings.import = { + olddir = false; + }; }; - }; in -import ./make-test-python.nix ({ pkgs, ... }: rec { - name = "logrotate"; - meta = with pkgs.lib.maintainers; { - maintainers = [ martinetd ]; - }; - - nodes = { - defaultMachine = { ... }: { - services.logrotate.enable = true; - }; - failingMachine = { ... }: { - services.logrotate = { - enable = true; - configFile = pkgs.writeText "logrotate.conf" '' - # self-written config file - su notarealuser notagroupeither - ''; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + rec { + name = "logrotate"; + meta = with pkgs.lib.maintainers; { + maintainers = [ martinetd ]; }; - machine = { config, ... }: { - imports = [ importTest ]; - services.logrotate = { - enable = true; - settings = { - # remove default frequency header and add another - header = { - frequency = null; - delaycompress = true; - }; - # extra global setting... affecting nothing - last_line = { - global = true; - priority = 2000; - shred = true; - }; - # using mail somewhere should add --mail to logrotate invocation - sendmail = { - mail = "user@domain.tld"; - }; - # postrotate should be suffixed by 'endscript' - postrotate = { - postrotate = "touch /dev/null"; - }; - # check checkConfig works as expected: there is nothing to check here - # except that the file build passes - checkConf = { - su = "root utmp"; - createolddir = "0750 root utmp"; - create = "root utmp"; - "create " = "0750 root utmp"; - }; - # multiple paths should be aggregated - multipath = { - files = [ "file1" "file2" ]; + nodes = { + defaultMachine = + { ... }: + { + services.logrotate.enable = true; + }; + failingMachine = + { ... }: + { + services.logrotate = { + enable = true; + configFile = pkgs.writeText "logrotate.conf" '' + # self-written config file + su notarealuser notagroupeither + ''; }; - # overriding imported path should keep existing attributes - # (e.g. olddir is still set) - import = { - notifempty = true; + }; + machine = + { config, ... }: + { + imports = [ importTest ]; + + services.logrotate = { + enable = true; + settings = { + # remove default frequency header and add another + header = { + frequency = null; + delaycompress = true; + }; + # extra global setting... affecting nothing + last_line = { + global = true; + priority = 2000; + shred = true; + }; + # using mail somewhere should add --mail to logrotate invocation + sendmail = { + mail = "user@domain.tld"; + }; + # postrotate should be suffixed by 'endscript' + postrotate = { + postrotate = "touch /dev/null"; + }; + # check checkConfig works as expected: there is nothing to check here + # except that the file build passes + checkConf = { + su = "root utmp"; + createolddir = "0750 root utmp"; + create = "root utmp"; + "create " = "0750 root utmp"; + }; + # multiple paths should be aggregated + multipath = { + files = [ + "file1" + "file2" + ]; + }; + # overriding imported path should keep existing attributes + # (e.g. olddir is still set) + import = { + notifempty = true; + }; + }; }; }; - }; }; - }; - testScript = - '' + testScript = '' with subtest("whether logrotate works"): # we must rotate once first to create logrotate stamp defaultMachine.succeed("systemctl start logrotate.service") @@ -130,4 +142,5 @@ import ./make-test-python.nix ({ pkgs, ... }: rec { machine.log(machine.execute("systemd-analyze security logrotate.service | grep -v ✓")[1]) ''; -}) + } +) diff --git a/nixos/tests/loki.nix b/nixos/tests/loki.nix index 470f80e9db635e..81103a5ee4cae6 100644 --- a/nixos/tests/loki.nix +++ b/nixos/tests/loki.nix @@ -1,56 +1,60 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: +import ./make-test-python.nix ( + { lib, pkgs, ... }: -{ - name = "loki"; + { + name = "loki"; - meta = with lib.maintainers; { - maintainers = [ willibutz ]; - }; - - nodes.machine = { ... }: { - services.loki = { - enable = true; - configFile = "${pkgs.grafana-loki.src}/cmd/loki/loki-local-config.yaml"; + meta = with lib.maintainers; { + maintainers = [ willibutz ]; }; - services.promtail = { - enable = true; - configuration = { - server = { - http_listen_port = 9080; - grpc_listen_port = 0; + + nodes.machine = + { ... }: + { + services.loki = { + enable = true; + configFile = "${pkgs.grafana-loki.src}/cmd/loki/loki-local-config.yaml"; }; - clients = [ { url = "http://localhost:3100/loki/api/v1/push"; } ]; - scrape_configs = [ - { - job_name = "system"; - static_configs = [ + services.promtail = { + enable = true; + configuration = { + server = { + http_listen_port = 9080; + grpc_listen_port = 0; + }; + clients = [ { url = "http://localhost:3100/loki/api/v1/push"; } ]; + scrape_configs = [ { - targets = [ "localhost" ]; - labels = { - job = "varlogs"; - __path__ = "/var/log/*log"; - }; + job_name = "system"; + static_configs = [ + { + targets = [ "localhost" ]; + labels = { + job = "varlogs"; + __path__ = "/var/log/*log"; + }; + } + ]; } ]; - } - ]; + }; + }; }; - }; - }; - testScript = '' - machine.start - machine.wait_for_unit("loki.service") - machine.wait_for_unit("promtail.service") - machine.wait_for_open_port(3100) - machine.wait_for_open_port(9080) - machine.succeed("echo 'Loki Ingestion Test' > /var/log/testlog") - # should not have access to journal unless specified - machine.fail( - "systemctl show --property=SupplementaryGroups promtail | grep -q systemd-journal" - ) - machine.wait_until_succeeds( - "${pkgs.grafana-loki}/bin/logcli --addr='http://localhost:3100' query --no-labels '{job=\"varlogs\",filename=\"/var/log/testlog\"}' | grep -q 'Loki Ingestion Test'" - ) - ''; -}) + testScript = '' + machine.start + machine.wait_for_unit("loki.service") + machine.wait_for_unit("promtail.service") + machine.wait_for_open_port(3100) + machine.wait_for_open_port(9080) + machine.succeed("echo 'Loki Ingestion Test' > /var/log/testlog") + # should not have access to journal unless specified + machine.fail( + "systemctl show --property=SupplementaryGroups promtail | grep -q systemd-journal" + ) + machine.wait_until_succeeds( + "${pkgs.grafana-loki}/bin/logcli --addr='http://localhost:3100' query --no-labels '{job=\"varlogs\",filename=\"/var/log/testlog\"}' | grep -q 'Loki Ingestion Test'" + ) + ''; + } +) diff --git a/nixos/tests/lomiri-system-settings.nix b/nixos/tests/lomiri-system-settings.nix index fac5184847520c..407e58eb784707 100644 --- a/nixos/tests/lomiri-system-settings.nix +++ b/nixos/tests/lomiri-system-settings.nix @@ -1,99 +1,165 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "lomiri-system-settings-standalone"; - meta.maintainers = lib.teams.lomiri.members; - - nodes.machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; - - services.xserver.enable = true; - - environment = { - systemPackages = with pkgs.lomiri; [ - suru-icon-theme - lomiri-system-settings - ]; - variables = { - UITK_ICON_THEME = "suru"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "lomiri-system-settings-standalone"; + meta.maintainers = lib.teams.lomiri.members; + + nodes.machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; + + services.xserver.enable = true; + + environment = { + systemPackages = with pkgs.lomiri; [ + suru-icon-theme + lomiri-system-settings + ]; + variables = { + UITK_ICON_THEME = "suru"; + }; + }; + + i18n.supportedLocales = [ "all" ]; + + fonts.packages = with pkgs; [ + # Intended font & helps with OCR + ubuntu-classic + ]; + + services.upower.enable = true; }; - }; - - i18n.supportedLocales = [ "all" ]; - - fonts.packages = with pkgs; [ - # Intended font & helps with OCR - ubuntu-classic - ]; - - services.upower.enable = true; - }; - - enableOCR = true; - - testScript = let - settingsPages = [ - # Base pages - { name = "wifi"; type = "internal"; element = "networks"; } - { name = "bluetooth"; type = "internal"; element = "discoverable|None detected"; } - # only text we can really look for with VPN is on a button, OCR on CI struggles with it - { name = "vpn"; type = "internal"; element = "Add|Manual|Configuration"; skipOCR = true; } - { name = "appearance"; type = "internal"; element = "Background image|blur effects"; } - { name = "desktop"; type = "internal"; element = "workspaces|Icon size"; } - { name = "sound"; type = "internal"; element = "Silent Mode|Message sound"; } - { name = "language"; type = "internal"; element = "Display language|External keyboard"; } - { name = "notification"; type = "internal"; element = "Apps that notify"; } - { name = "gestures"; type = "internal"; element = "Edge drag"; } - { name = "mouse"; type = "internal"; element = "Cursor speed|Wheel scrolling speed"; } - { name = "timedate"; type = "internal"; element = "Time zone|Set the time and date"; } - - # External plugins - { name = "security-privacy"; type = "external"; element = "Locking|unlocking|permissions"; elementLocalised = "Sperren|Entsperren|Berechtigungen"; } - ]; - in - '' - machine.wait_for_x() - - with subtest("lomiri system settings launches"): - machine.execute("lomiri-system-settings >&2 &") - machine.wait_for_text("System Settings") - machine.screenshot("lss_open") - - # Move focus to start of plugins list for following list of tests - machine.send_key("tab") - machine.send_key("tab") - machine.screenshot("lss_focus") - - # tab through & open all sub-menus, to make sure none of them fail - '' + (lib.strings.concatMapStringsSep "\n" (page: '' - machine.send_key("tab") - machine.send_key("kp_enter") - '' - + lib.optionalString (!(page.skipOCR or false)) '' - with subtest("lomiri system settings ${page.name} works"): - machine.wait_for_text(r"(${page.element})") - machine.screenshot("lss_page_${page.name}") - '') settingsPages) + '' - - machine.execute("pkill -f lomiri-system-settings") - - with subtest("lomiri system settings localisation works"): - machine.execute("env LANG=de_DE.UTF-8 lomiri-system-settings >&2 &") - machine.wait_for_text("Systemeinstellungen") - machine.screenshot("lss_localised_open") - - # Move focus to start of plugins list for following list of tests - machine.send_key("tab") - machine.send_key("tab") - machine.screenshot("lss_focus_localised") - - '' + (lib.strings.concatMapStringsSep "\n" (page: '' - machine.send_key("tab") - machine.send_key("kp_enter") - '' + lib.optionalString (page.type == "external") '' - with subtest("lomiri system settings ${page.name} localisation works"): - machine.wait_for_text(r"(${page.elementLocalised})") - machine.screenshot("lss_localised_page_${page.name}") - '') settingsPages) + '' - ''; -}) + + enableOCR = true; + + testScript = + let + settingsPages = [ + # Base pages + { + name = "wifi"; + type = "internal"; + element = "networks"; + } + { + name = "bluetooth"; + type = "internal"; + element = "discoverable|None detected"; + } + # only text we can really look for with VPN is on a button, OCR on CI struggles with it + { + name = "vpn"; + type = "internal"; + element = "Add|Manual|Configuration"; + skipOCR = true; + } + { + name = "appearance"; + type = "internal"; + element = "Background image|blur effects"; + } + { + name = "desktop"; + type = "internal"; + element = "workspaces|Icon size"; + } + { + name = "sound"; + type = "internal"; + element = "Silent Mode|Message sound"; + } + { + name = "language"; + type = "internal"; + element = "Display language|External keyboard"; + } + { + name = "notification"; + type = "internal"; + element = "Apps that notify"; + } + { + name = "gestures"; + type = "internal"; + element = "Edge drag"; + } + { + name = "mouse"; + type = "internal"; + element = "Cursor speed|Wheel scrolling speed"; + } + { + name = "timedate"; + type = "internal"; + element = "Time zone|Set the time and date"; + } + + # External plugins + { + name = "security-privacy"; + type = "external"; + element = "Locking|unlocking|permissions"; + elementLocalised = "Sperren|Entsperren|Berechtigungen"; + } + ]; + in + '' + machine.wait_for_x() + + with subtest("lomiri system settings launches"): + machine.execute("lomiri-system-settings >&2 &") + machine.wait_for_text("System Settings") + machine.screenshot("lss_open") + + # Move focus to start of plugins list for following list of tests + machine.send_key("tab") + machine.send_key("tab") + machine.screenshot("lss_focus") + + # tab through & open all sub-menus, to make sure none of them fail + '' + + (lib.strings.concatMapStringsSep "\n" ( + page: + '' + machine.send_key("tab") + machine.send_key("kp_enter") + '' + + lib.optionalString (!(page.skipOCR or false)) '' + with subtest("lomiri system settings ${page.name} works"): + machine.wait_for_text(r"(${page.element})") + machine.screenshot("lss_page_${page.name}") + '' + ) settingsPages) + + '' + + machine.execute("pkill -f lomiri-system-settings") + + with subtest("lomiri system settings localisation works"): + machine.execute("env LANG=de_DE.UTF-8 lomiri-system-settings >&2 &") + machine.wait_for_text("Systemeinstellungen") + machine.screenshot("lss_localised_open") + + # Move focus to start of plugins list for following list of tests + machine.send_key("tab") + machine.send_key("tab") + machine.screenshot("lss_focus_localised") + + '' + + (lib.strings.concatMapStringsSep "\n" ( + page: + '' + machine.send_key("tab") + machine.send_key("kp_enter") + '' + + lib.optionalString (page.type == "external") '' + with subtest("lomiri system settings ${page.name} localisation works"): + machine.wait_for_text(r"(${page.elementLocalised})") + machine.screenshot("lss_localised_page_${page.name}") + '' + ) settingsPages) + + ''''; + } +) diff --git a/nixos/tests/lorri/default.nix b/nixos/tests/lorri/default.nix index e9e26c03f6ca14..a9ad5645673321 100644 --- a/nixos/tests/lorri/default.nix +++ b/nixos/tests/lorri/default.nix @@ -1,10 +1,12 @@ import ../make-test-python.nix { name = "lorri"; - nodes.machine = { pkgs, ... }: { - imports = [ ../../modules/profiles/minimal.nix ]; - environment.systemPackages = [ pkgs.lorri ]; - }; + nodes.machine = + { pkgs, ... }: + { + imports = [ ../../modules/profiles/minimal.nix ]; + environment.systemPackages = [ pkgs.lorri ]; + }; testScript = '' # Copy files over diff --git a/nixos/tests/luks.nix b/nixos/tests/luks.nix index da1d0c63b95dfc..15489343b707ae 100644 --- a/nixos/tests/luks.nix +++ b/nixos/tests/luks.nix @@ -1,73 +1,81 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "luks"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "luks"; - nodes.machine = { pkgs, ... }: { - imports = [ ./common/auto-format-root-device.nix ]; + nodes.machine = + { pkgs, ... }: + { + imports = [ ./common/auto-format-root-device.nix ]; - # Use systemd-boot - virtualisation = { - emptyDiskImages = [ 512 512 ]; - useBootLoader = true; - useEFIBoot = true; - # To boot off the encrypted disk, we need to have a init script which comes from the Nix store - mountHostNixStore = true; - }; - boot.loader.systemd-boot.enable = true; + # Use systemd-boot + virtualisation = { + emptyDiskImages = [ + 512 + 512 + ]; + useBootLoader = true; + useEFIBoot = true; + # To boot off the encrypted disk, we need to have a init script which comes from the Nix store + mountHostNixStore = true; + }; + boot.loader.systemd-boot.enable = true; - boot.kernelParams = lib.mkOverride 5 [ "console=tty1" ]; + boot.kernelParams = lib.mkOverride 5 [ "console=tty1" ]; - environment.systemPackages = with pkgs; [ cryptsetup ]; + environment.systemPackages = with pkgs; [ cryptsetup ]; - specialisation = rec { - boot-luks.configuration = { - boot.initrd.luks.devices = lib.mkVMOverride { - # We have two disks and only type one password - key reuse is in place - cryptroot.device = "/dev/vdb"; - cryptroot2.device = "/dev/vdc"; + specialisation = rec { + boot-luks.configuration = { + boot.initrd.luks.devices = lib.mkVMOverride { + # We have two disks and only type one password - key reuse is in place + cryptroot.device = "/dev/vdb"; + cryptroot2.device = "/dev/vdc"; + }; + virtualisation.rootDevice = "/dev/mapper/cryptroot"; + }; + boot-luks-custom-keymap.configuration = lib.mkMerge [ + boot-luks.configuration + { + console.keyMap = "neo"; + } + ]; }; - virtualisation.rootDevice = "/dev/mapper/cryptroot"; }; - boot-luks-custom-keymap.configuration = lib.mkMerge [ - boot-luks.configuration - { - console.keyMap = "neo"; - } - ]; - }; - }; - enableOCR = true; + enableOCR = true; - testScript = '' - # Create encrypted volume - machine.wait_for_unit("multi-user.target") - machine.succeed("echo -n supersecret | cryptsetup luksFormat -q --iter-time=1 /dev/vdb -") - machine.succeed("echo -n supersecret | cryptsetup luksFormat -q --iter-time=1 /dev/vdc -") + testScript = '' + # Create encrypted volume + machine.wait_for_unit("multi-user.target") + machine.succeed("echo -n supersecret | cryptsetup luksFormat -q --iter-time=1 /dev/vdb -") + machine.succeed("echo -n supersecret | cryptsetup luksFormat -q --iter-time=1 /dev/vdc -") - # Boot from the encrypted disk - machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks.conf") - machine.succeed("sync") - machine.crash() + # Boot from the encrypted disk + machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks.conf") + machine.succeed("sync") + machine.crash() - # Boot and decrypt the disk - machine.start() - machine.wait_for_text("Passphrase for") - machine.send_chars("supersecret\n") - machine.wait_for_unit("multi-user.target") + # Boot and decrypt the disk + machine.start() + machine.wait_for_text("Passphrase for") + machine.send_chars("supersecret\n") + machine.wait_for_unit("multi-user.target") - assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") + assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") - # Boot from the encrypted disk with custom keymap - machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks-custom-keymap.conf") - machine.succeed("sync") - machine.crash() + # Boot from the encrypted disk with custom keymap + machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks-custom-keymap.conf") + machine.succeed("sync") + machine.crash() - # Boot and decrypt the disk - machine.start() - machine.wait_for_text("Passphrase for") - machine.send_chars("havfkhfrkfl\n") - machine.wait_for_unit("multi-user.target") + # Boot and decrypt the disk + machine.start() + machine.wait_for_text("Passphrase for") + machine.send_chars("havfkhfrkfl\n") + machine.wait_for_unit("multi-user.target") - assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") - ''; -}) + assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") + ''; + } +) diff --git a/nixos/tests/lvm2/default.nix b/nixos/tests/lvm2/default.nix index 346ec6739501d9..0e4ec8d27fda06 100644 --- a/nixos/tests/lvm2/default.nix +++ b/nixos/tests/lvm2/default.nix @@ -1,49 +1,79 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../../.. { inherit system config; } -, lib ? pkgs.lib -, kernelVersionsToTest ? [ "4.19" "5.4" "5.10" "5.15" "6.1" "latest" ] +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../../.. { inherit system config; }, + lib ? pkgs.lib, + kernelVersionsToTest ? [ + "4.19" + "5.4" + "5.10" + "5.15" + "6.1" + "latest" + ], }: # For quickly running a test, the nixosTests.lvm2.lvm-thinpool-linux-latest attribute is recommended let - tests = let callTest = p: lib.flip (import p) { inherit system pkgs; }; in { - thinpool = { test = callTest ./thinpool.nix; kernelFilter = lib.id; }; - # we would like to test all versions, but the kernel module currently does not compile against the other versions - vdo = { test = callTest ./vdo.nix; kernelFilter = lib.filter (v: v == "latest"); }; + tests = + let + callTest = p: lib.flip (import p) { inherit system pkgs; }; + in + { + thinpool = { + test = callTest ./thinpool.nix; + kernelFilter = lib.id; + }; + # we would like to test all versions, but the kernel module currently does not compile against the other versions + vdo = { + test = callTest ./vdo.nix; + kernelFilter = lib.filter (v: v == "latest"); + }; - - # systemd in stage 1 - raid-sd-stage-1 = { - test = callTest ./systemd-stage-1.nix; - kernelFilter = lib.id; - flavour = "raid"; - }; - thinpool-sd-stage-1 = { - test = callTest ./systemd-stage-1.nix; - kernelFilter = lib.id; - flavour = "thinpool"; - }; - vdo-sd-stage-1 = { - test = callTest ./systemd-stage-1.nix; - kernelFilter = lib.filter (v: v == "latest"); - flavour = "vdo"; + # systemd in stage 1 + raid-sd-stage-1 = { + test = callTest ./systemd-stage-1.nix; + kernelFilter = lib.id; + flavour = "raid"; + }; + thinpool-sd-stage-1 = { + test = callTest ./systemd-stage-1.nix; + kernelFilter = lib.id; + flavour = "thinpool"; + }; + vdo-sd-stage-1 = { + test = callTest ./systemd-stage-1.nix; + kernelFilter = lib.filter (v: v == "latest"); + flavour = "vdo"; + }; }; - }; in lib.listToAttrs ( - lib.filter (x: x.value != {}) ( - lib.flip lib.concatMap kernelVersionsToTest (version: + lib.filter (x: x.value != { }) ( + lib.flip lib.concatMap kernelVersionsToTest ( + version: let v' = lib.replaceStrings [ "." ] [ "_" ] version; - mkXfsFlags = lib.optionalString (lib.versionOlder version "5.10") " -m bigtime=0 -m inobtcount=0 " - + lib.optionalString (lib.versionOlder version "5.19") " -i nrext64=0 "; + mkXfsFlags = + lib.optionalString (lib.versionOlder version "5.10") " -m bigtime=0 -m inobtcount=0 " + + lib.optionalString (lib.versionOlder version "5.19") " -i nrext64=0 "; in - lib.flip lib.mapAttrsToList tests (name: t: - lib.nameValuePair "lvm-${name}-linux-${v'}" (lib.optionalAttrs (builtins.elem version (t.kernelFilter kernelVersionsToTest)) (t.test ({ - kernelPackages = pkgs."linuxPackages_${v'}"; - inherit mkXfsFlags; - } // builtins.removeAttrs t [ "test" "kernelFilter" ]))) + lib.flip lib.mapAttrsToList tests ( + name: t: + lib.nameValuePair "lvm-${name}-linux-${v'}" ( + lib.optionalAttrs (builtins.elem version (t.kernelFilter kernelVersionsToTest)) ( + t.test ( + { + kernelPackages = pkgs."linuxPackages_${v'}"; + inherit mkXfsFlags; + } + // builtins.removeAttrs t [ + "test" + "kernelFilter" + ] + ) + ) + ) ) ) ) diff --git a/nixos/tests/lvm2/systemd-stage-1.nix b/nixos/tests/lvm2/systemd-stage-1.nix index fe57a615a9555c..9eb7a6797e3824 100644 --- a/nixos/tests/lvm2/systemd-stage-1.nix +++ b/nixos/tests/lvm2/systemd-stage-1.nix @@ -1,116 +1,136 @@ -{ kernelPackages ? null, flavour, mkXfsFlags ? "" }: let - preparationCode = { - raid = '' - machine.succeed("vgcreate test_vg /dev/vdb /dev/vdc") - machine.succeed("lvcreate -L 512M --type raid0 test_vg -n test_lv") - ''; - - thinpool = '' - machine.succeed("vgcreate test_vg /dev/vdb") - machine.succeed("lvcreate -L 512M -T test_vg/test_thin_pool") - machine.succeed("lvcreate -n test_lv -V 16G --thinpool test_thin_pool test_vg") - ''; - - vdo = '' - machine.succeed("vgcreate test_vg /dev/vdb") - machine.succeed("lvcreate --type vdo -n test_lv -L 6G -V 12G test_vg/vdo_pool_lv") - ''; - }.${flavour}; - - extraConfig = { - raid = { - boot.initrd.kernelModules = [ - "dm-raid" - "raid0" - ]; - }; - - thinpool = { - services.lvm = { - boot.thin.enable = true; - dmeventd.enable = true; +{ + kernelPackages ? null, + flavour, + mkXfsFlags ? "", +}: +let + preparationCode = + { + raid = '' + machine.succeed("vgcreate test_vg /dev/vdb /dev/vdc") + machine.succeed("lvcreate -L 512M --type raid0 test_vg -n test_lv") + ''; + + thinpool = '' + machine.succeed("vgcreate test_vg /dev/vdb") + machine.succeed("lvcreate -L 512M -T test_vg/test_thin_pool") + machine.succeed("lvcreate -n test_lv -V 16G --thinpool test_thin_pool test_vg") + ''; + + vdo = '' + machine.succeed("vgcreate test_vg /dev/vdb") + machine.succeed("lvcreate --type vdo -n test_lv -L 6G -V 12G test_vg/vdo_pool_lv") + ''; + } + .${flavour}; + + extraConfig = + { + raid = { + boot.initrd.kernelModules = [ + "dm-raid" + "raid0" + ]; }; - }; - vdo = { - services.lvm = { - boot.vdo.enable = true; - dmeventd.enable = true; + thinpool = { + services.lvm = { + boot.thin.enable = true; + dmeventd.enable = true; + }; }; - }; - }.${flavour}; - extraCheck = { - raid = '' - "test_lv" in machine.succeed("lvs --select segtype=raid0") - ''; + vdo = { + services.lvm = { + boot.vdo.enable = true; + dmeventd.enable = true; + }; + }; + } + .${flavour}; + + extraCheck = + { + raid = '' + "test_lv" in machine.succeed("lvs --select segtype=raid0") + ''; + + thinpool = '' + "test_lv" in machine.succeed("lvs --select segtype=thin-pool") + ''; + + vdo = '' + "test_lv" in machine.succeed("lvs --select segtype=vdo") + ''; + } + .${flavour}; + +in +import ../make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "lvm2-${flavour}-systemd-stage-1"; + meta.maintainers = lib.teams.helsinki-systems.members; + + nodes.machine = + { pkgs, lib, ... }: + { + imports = [ extraConfig ]; + # Use systemd-boot + virtualisation = { + emptyDiskImages = [ + 8192 + 8192 + ]; + useBootLoader = true; + useEFIBoot = true; + # To boot off the LVM disk, we need to have a init script which comes from the Nix store. + mountHostNixStore = true; + }; + boot.loader.systemd-boot.enable = true; + boot.loader.efi.canTouchEfiVariables = true; + + environment.systemPackages = with pkgs; [ xfsprogs ]; + boot = { + initrd.systemd = { + enable = true; + emergencyAccess = true; + }; + initrd.services.lvm.enable = true; + kernelPackages = lib.mkIf (kernelPackages != null) kernelPackages; + }; - thinpool = '' - "test_lv" in machine.succeed("lvs --select segtype=thin-pool") - ''; + specialisation.boot-lvm.configuration.virtualisation = { + useDefaultFilesystems = false; + fileSystems = { + "/" = { + device = "/dev/test_vg/test_lv"; + fsType = "xfs"; + }; + }; - vdo = '' - "test_lv" in machine.succeed("lvs --select segtype=vdo") - ''; - }.${flavour}; - -in import ../make-test-python.nix ({ pkgs, lib, ... }: { - name = "lvm2-${flavour}-systemd-stage-1"; - meta.maintainers = lib.teams.helsinki-systems.members; - - nodes.machine = { pkgs, lib, ... }: { - imports = [ extraConfig ]; - # Use systemd-boot - virtualisation = { - emptyDiskImages = [ 8192 8192 ]; - useBootLoader = true; - useEFIBoot = true; - # To boot off the LVM disk, we need to have a init script which comes from the Nix store. - mountHostNixStore = true; - }; - boot.loader.systemd-boot.enable = true; - boot.loader.efi.canTouchEfiVariables = true; - - environment.systemPackages = with pkgs; [ xfsprogs ]; - boot = { - initrd.systemd = { - enable = true; - emergencyAccess = true; - }; - initrd.services.lvm.enable = true; - kernelPackages = lib.mkIf (kernelPackages != null) kernelPackages; - }; - - specialisation.boot-lvm.configuration.virtualisation = { - useDefaultFilesystems = false; - fileSystems = { - "/" = { - device = "/dev/test_vg/test_lv"; - fsType = "xfs"; + rootDevice = "/dev/test_vg/test_lv"; }; }; - rootDevice = "/dev/test_vg/test_lv"; - }; - }; - - testScript = '' - machine.wait_for_unit("multi-user.target") - # Create a VG for the root - ${preparationCode} - machine.succeed("mkfs.xfs ${mkXfsFlags} /dev/test_vg/test_lv") - machine.succeed("mkdir -p /mnt && mount /dev/test_vg/test_lv /mnt && echo hello > /mnt/test && umount /mnt") - - # Boot from LVM - machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-lvm.conf") - machine.succeed("sync") - machine.crash() - machine.wait_for_unit("multi-user.target") - - # Ensure we have successfully booted from LVM - assert "(initrd)" in machine.succeed("systemd-analyze") # booted with systemd in stage 1 - assert "/dev/mapper/test_vg-test_lv on / type xfs" in machine.succeed("mount") - assert "hello" in machine.succeed("cat /test") - ${extraCheck} - ''; -}) + testScript = '' + machine.wait_for_unit("multi-user.target") + # Create a VG for the root + ${preparationCode} + machine.succeed("mkfs.xfs ${mkXfsFlags} /dev/test_vg/test_lv") + machine.succeed("mkdir -p /mnt && mount /dev/test_vg/test_lv /mnt && echo hello > /mnt/test && umount /mnt") + + # Boot from LVM + machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-lvm.conf") + machine.succeed("sync") + machine.crash() + machine.wait_for_unit("multi-user.target") + + # Ensure we have successfully booted from LVM + assert "(initrd)" in machine.succeed("systemd-analyze") # booted with systemd in stage 1 + assert "/dev/mapper/test_vg-test_lv on / type xfs" in machine.succeed("mount") + assert "hello" in machine.succeed("cat /test") + ${extraCheck} + ''; + } +) diff --git a/nixos/tests/lvm2/thinpool.nix b/nixos/tests/lvm2/thinpool.nix index 325bb87460b715..bf9b7160abc284 100644 --- a/nixos/tests/lvm2/thinpool.nix +++ b/nixos/tests/lvm2/thinpool.nix @@ -1,35 +1,46 @@ -{ kernelPackages ? null, mkXfsFlags ? "" }: -import ../make-test-python.nix ({ pkgs, lib, ... }: { - name = "lvm2-thinpool"; - meta.maintainers = lib.teams.helsinki-systems.members; +{ + kernelPackages ? null, + mkXfsFlags ? "", +}: +import ../make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "lvm2-thinpool"; + meta.maintainers = lib.teams.helsinki-systems.members; - nodes.machine = { pkgs, lib, ... }: { - virtualisation.emptyDiskImages = [ 4096 ]; - services.lvm = { - boot.thin.enable = true; - dmeventd.enable = true; - }; - environment.systemPackages = with pkgs; [ xfsprogs ]; - environment.etc."lvm/lvm.conf".text = '' - activation/thin_pool_autoextend_percent = 10 - activation/thin_pool_autoextend_threshold = 80 - ''; - boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; - }; + nodes.machine = + { pkgs, lib, ... }: + { + virtualisation.emptyDiskImages = [ 4096 ]; + services.lvm = { + boot.thin.enable = true; + dmeventd.enable = true; + }; + environment.systemPackages = with pkgs; [ xfsprogs ]; + environment.etc."lvm/lvm.conf".text = '' + activation/thin_pool_autoextend_percent = 10 + activation/thin_pool_autoextend_threshold = 80 + ''; + boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; + }; - testScript = let - mkXfsFlags = lib.optionalString (lib.versionOlder kernelPackages.kernel.version "5.10") " -m bigtime=0 -m inobtcount=0 " - + lib.optionalString (lib.versionOlder kernelPackages.kernel.version "5.19") " -i nrext64=0 "; - in '' - machine.succeed("vgcreate test_vg /dev/vdb") - machine.succeed("lvcreate -L 512M -T test_vg/test_thin_pool") - machine.succeed("lvcreate -n test_lv -V 16G --thinpool test_thin_pool test_vg") - machine.succeed("mkfs.xfs ${mkXfsFlags} /dev/test_vg/test_lv") - machine.succeed("mkdir /mnt; mount /dev/test_vg/test_lv /mnt") - assert "/dev/mapper/test_vg-test_lv" == machine.succeed("findmnt -no SOURCE /mnt").strip() - machine.succeed("dd if=/dev/zero of=/mnt/empty.file bs=1M count=1024") - machine.succeed("journalctl -u dm-event.service | grep \"successfully resized\"") - machine.succeed("umount /mnt") - machine.succeed("vgchange -a n") - ''; -}) + testScript = + let + mkXfsFlags = + lib.optionalString (lib.versionOlder kernelPackages.kernel.version "5.10") " -m bigtime=0 -m inobtcount=0 " + + lib.optionalString (lib.versionOlder kernelPackages.kernel.version "5.19") " -i nrext64=0 "; + in + '' + machine.succeed("vgcreate test_vg /dev/vdb") + machine.succeed("lvcreate -L 512M -T test_vg/test_thin_pool") + machine.succeed("lvcreate -n test_lv -V 16G --thinpool test_thin_pool test_vg") + machine.succeed("mkfs.xfs ${mkXfsFlags} /dev/test_vg/test_lv") + machine.succeed("mkdir /mnt; mount /dev/test_vg/test_lv /mnt") + assert "/dev/mapper/test_vg-test_lv" == machine.succeed("findmnt -no SOURCE /mnt").strip() + machine.succeed("dd if=/dev/zero of=/mnt/empty.file bs=1M count=1024") + machine.succeed("journalctl -u dm-event.service | grep \"successfully resized\"") + machine.succeed("umount /mnt") + machine.succeed("vgchange -a n") + ''; + } +) diff --git a/nixos/tests/lvm2/vdo.nix b/nixos/tests/lvm2/vdo.nix index 2b4a3df5159e88..ee65aa7d828f04 100644 --- a/nixos/tests/lvm2/vdo.nix +++ b/nixos/tests/lvm2/vdo.nix @@ -1,27 +1,35 @@ -{ kernelPackages ? null, mkXfsFlags ? "" }: -import ../make-test-python.nix ({ pkgs, lib, ... }: { - name = "lvm2-vdo"; - meta.maintainers = [ ]; +{ + kernelPackages ? null, + mkXfsFlags ? "", +}: +import ../make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "lvm2-vdo"; + meta.maintainers = [ ]; - nodes.machine = { pkgs, lib, ... }: { - # Minimum required size for VDO volume: 5063921664 bytes - virtualisation.emptyDiskImages = [ 8192 ]; - services.lvm = { - boot.vdo.enable = true; - dmeventd.enable = true; - }; - environment.systemPackages = with pkgs; [ xfsprogs ]; - boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; - }; + nodes.machine = + { pkgs, lib, ... }: + { + # Minimum required size for VDO volume: 5063921664 bytes + virtualisation.emptyDiskImages = [ 8192 ]; + services.lvm = { + boot.vdo.enable = true; + dmeventd.enable = true; + }; + environment.systemPackages = with pkgs; [ xfsprogs ]; + boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; + }; - testScript = '' - machine.succeed("vgcreate test_vg /dev/vdb") - machine.succeed("lvcreate --type vdo -n vdo_lv -L 6G -V 12G test_vg/vdo_pool_lv") - machine.succeed("mkfs.xfs ${mkXfsFlags} -K /dev/test_vg/vdo_lv") - machine.succeed("mkdir /mnt; mount /dev/test_vg/vdo_lv /mnt") - assert "/dev/mapper/test_vg-vdo_lv" == machine.succeed("findmnt -no SOURCE /mnt").strip() - machine.succeed("umount /mnt") - machine.succeed("vdostats") - machine.succeed("vgchange -a n") - ''; -}) + testScript = '' + machine.succeed("vgcreate test_vg /dev/vdb") + machine.succeed("lvcreate --type vdo -n vdo_lv -L 6G -V 12G test_vg/vdo_pool_lv") + machine.succeed("mkfs.xfs ${mkXfsFlags} -K /dev/test_vg/vdo_lv") + machine.succeed("mkdir /mnt; mount /dev/test_vg/vdo_lv /mnt") + assert "/dev/mapper/test_vg-vdo_lv" == machine.succeed("findmnt -no SOURCE /mnt").strip() + machine.succeed("umount /mnt") + machine.succeed("vdostats") + machine.succeed("vgchange -a n") + ''; + } +) diff --git a/nixos/tests/lxd-image-server.nix b/nixos/tests/lxd-image-server.nix index 619542bdd9456b..4b0b1259f40464 100644 --- a/nixos/tests/lxd-image-server.nix +++ b/nixos/tests/lxd-image-server.nix @@ -1,94 +1,102 @@ -import ./make-test-python.nix ({ pkgs, lib, ... } : - -let - lxd-image = import ../release.nix { - configuration = { - # Building documentation makes the test unnecessarily take a longer time: - documentation.enable = lib.mkForce false; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + let + lxd-image = import ../release.nix { + configuration = { + # Building documentation makes the test unnecessarily take a longer time: + documentation.enable = lib.mkForce false; + }; }; - }; - - lxd-image-metadata = lxd-image.lxdContainerMeta.${pkgs.stdenv.hostPlatform.system}; - lxd-image-rootfs = lxd-image.lxdContainerImage.${pkgs.stdenv.hostPlatform.system}; - -in { - name = "lxd-image-server"; - - meta = with pkgs.lib.maintainers; { - maintainers = [ mkg20001 patryk27 ]; - }; - - nodes.machine = { lib, ... }: { - virtualisation = { - cores = 2; - memorySize = 2048; - diskSize = 4096; + lxd-image-metadata = lxd-image.lxdContainerMeta.${pkgs.stdenv.hostPlatform.system}; + lxd-image-rootfs = lxd-image.lxdContainerImage.${pkgs.stdenv.hostPlatform.system}; - lxc.lxcfs.enable = true; - lxd.enable = true; - }; - - security.pki.certificates = [ - (builtins.readFile ./common/acme/server/ca.cert.pem) - ]; + in + { + name = "lxd-image-server"; - services.nginx = { - enable = true; + meta = with pkgs.lib.maintainers; { + maintainers = [ + mkg20001 + patryk27 + ]; }; - services.lxd-image-server = { - enable = true; - nginx = { - enable = true; - domain = "acme.test"; + nodes.machine = + { lib, ... }: + { + virtualisation = { + cores = 2; + + memorySize = 2048; + diskSize = 4096; + + lxc.lxcfs.enable = true; + lxd.enable = true; + }; + + security.pki.certificates = [ + (builtins.readFile ./common/acme/server/ca.cert.pem) + ]; + + services.nginx = { + enable = true; + }; + + services.lxd-image-server = { + enable = true; + nginx = { + enable = true; + domain = "acme.test"; + }; + }; + + services.nginx.virtualHosts."acme.test" = { + enableACME = false; + sslCertificate = ./common/acme/server/acme.test.cert.pem; + sslCertificateKey = ./common/acme/server/acme.test.key.pem; + }; + + networking.hosts = { + "::1" = [ "acme.test" ]; + }; }; - }; - services.nginx.virtualHosts."acme.test" = { - enableACME = false; - sslCertificate = ./common/acme/server/acme.test.cert.pem; - sslCertificateKey = ./common/acme/server/acme.test.key.pem; - }; - - networking.hosts = { - "::1" = [ "acme.test" ]; - }; - }; - - testScript = '' - machine.wait_for_unit("sockets.target") - machine.wait_for_unit("lxd.service") - machine.wait_for_file("/var/lib/lxd/unix.socket") - - # Wait for lxd to settle - machine.succeed("lxd waitready") - - # lxd expects the pool's directory to already exist - machine.succeed("mkdir /var/lxd-pool") - - machine.succeed( - "lxd init --minimal" - ) - - machine.succeed( - "lxc image import ${lxd-image-metadata}/*/*.tar.xz ${lxd-image-rootfs}/*/*.tar.xz --alias nixos" - ) - - loc = "/var/www/simplestreams/images/iats/nixos/amd64/default/v1" - - with subtest("push image to server"): - machine.succeed("lxc launch nixos test") - machine.sleep(5) - machine.succeed("lxc stop -f test") - machine.succeed("lxc publish --public test --alias=testimg") - machine.succeed("lxc image export testimg") - machine.succeed("ls >&2") - machine.succeed("mkdir -p " + loc) - machine.succeed("mv *.tar.gz " + loc) - - with subtest("pull image from server"): - machine.succeed("lxc remote add img https://acme.test --protocol=simplestreams") - machine.succeed("lxc image list img: >&2") - ''; -}) + testScript = '' + machine.wait_for_unit("sockets.target") + machine.wait_for_unit("lxd.service") + machine.wait_for_file("/var/lib/lxd/unix.socket") + + # Wait for lxd to settle + machine.succeed("lxd waitready") + + # lxd expects the pool's directory to already exist + machine.succeed("mkdir /var/lxd-pool") + + machine.succeed( + "lxd init --minimal" + ) + + machine.succeed( + "lxc image import ${lxd-image-metadata}/*/*.tar.xz ${lxd-image-rootfs}/*/*.tar.xz --alias nixos" + ) + + loc = "/var/www/simplestreams/images/iats/nixos/amd64/default/v1" + + with subtest("push image to server"): + machine.succeed("lxc launch nixos test") + machine.sleep(5) + machine.succeed("lxc stop -f test") + machine.succeed("lxc publish --public test --alias=testimg") + machine.succeed("lxc image export testimg") + machine.succeed("ls >&2") + machine.succeed("mkdir -p " + loc) + machine.succeed("mv *.tar.gz " + loc) + + with subtest("pull image from server"): + machine.succeed("lxc remote add img https://acme.test --protocol=simplestreams") + machine.succeed("lxc image list img: >&2") + ''; + } +) diff --git a/nixos/tests/lxd/container.nix b/nixos/tests/lxd/container.nix index c04ae42afb8c2a..d5506194cfa49d 100644 --- a/nixos/tests/lxd/container.nix +++ b/nixos/tests/lxd/container.nix @@ -1,128 +1,133 @@ -import ../make-test-python.nix ({ pkgs, lib, ... } : - -let - releases = import ../../release.nix { - configuration = { - # Building documentation makes the test unnecessarily take a longer time: - documentation.enable = lib.mkForce false; - - # Our tests require `grep` & friends: - environment.systemPackages = with pkgs; [ busybox ]; +import ../make-test-python.nix ( + { pkgs, lib, ... }: + + let + releases = import ../../release.nix { + configuration = { + # Building documentation makes the test unnecessarily take a longer time: + documentation.enable = lib.mkForce false; + + # Our tests require `grep` & friends: + environment.systemPackages = with pkgs; [ busybox ]; + }; }; - }; - lxd-image-metadata = releases.lxdContainerMeta.${pkgs.stdenv.hostPlatform.system}; - lxd-image-rootfs = releases.lxdContainerImage.${pkgs.stdenv.hostPlatform.system}; - lxd-image-rootfs-squashfs = releases.lxdContainerImageSquashfs.${pkgs.stdenv.hostPlatform.system}; + lxd-image-metadata = releases.lxdContainerMeta.${pkgs.stdenv.hostPlatform.system}; + lxd-image-rootfs = releases.lxdContainerImage.${pkgs.stdenv.hostPlatform.system}; + lxd-image-rootfs-squashfs = releases.lxdContainerImageSquashfs.${pkgs.stdenv.hostPlatform.system}; -in { - name = "lxd-container"; + in + { + name = "lxd-container"; - nodes.machine = { lib, ... }: { - virtualisation = { - diskSize = 6144; + nodes.machine = + { lib, ... }: + { + virtualisation = { + diskSize = 6144; - # Since we're testing `limits.cpu`, we've gotta have a known number of - # cores to lean on - cores = 2; + # Since we're testing `limits.cpu`, we've gotta have a known number of + # cores to lean on + cores = 2; - # Ditto, for `limits.memory` - memorySize = 512; + # Ditto, for `limits.memory` + memorySize = 512; - lxc.lxcfs.enable = true; - lxd.enable = true; - }; - }; - - testScript = '' - def instance_is_up(_) -> bool: - status, _ = machine.execute("lxc exec container --disable-stdin --force-interactive /run/current-system/sw/bin/true") - return status == 0 - - machine.wait_for_unit("sockets.target") - machine.wait_for_unit("lxd.service") - machine.wait_for_file("/var/lib/lxd/unix.socket") - - # Wait for lxd to settle - machine.succeed("lxd waitready") - - # no preseed should mean no service - machine.fail("systemctl status lxd-preseed.service") - - machine.succeed("lxd init --minimal") - - machine.succeed( - "lxc image import ${lxd-image-metadata}/*/*.tar.xz ${lxd-image-rootfs}/*/*.tar.xz --alias nixos" - ) - - with subtest("Container can be managed"): - machine.succeed("lxc launch nixos container") - with machine.nested("Waiting for instance to start and be usable"): - retry(instance_is_up) - machine.succeed("echo true | lxc exec container /run/current-system/sw/bin/bash -") - machine.succeed("lxc delete -f container") - - with subtest("Squashfs image is functional"): - machine.succeed( - "lxc image import ${lxd-image-metadata}/*/*.tar.xz ${lxd-image-rootfs-squashfs}/nixos-lxc-image-${pkgs.stdenv.hostPlatform.system}.squashfs --alias nixos-squashfs" - ) - machine.succeed("lxc launch nixos-squashfs container") - with machine.nested("Waiting for instance to start and be usable"): - retry(instance_is_up) - machine.succeed("echo true | lxc exec container /run/current-system/sw/bin/bash -") - machine.succeed("lxc delete -f container") - - with subtest("Container is mounted with lxcfs inside"): - machine.succeed("lxc launch nixos container") - with machine.nested("Waiting for instance to start and be usable"): - retry(instance_is_up) + lxc.lxcfs.enable = true; + lxd.enable = true; + }; + }; - ## ---------- ## - ## limits.cpu ## + testScript = '' + def instance_is_up(_) -> bool: + status, _ = machine.execute("lxc exec container --disable-stdin --force-interactive /run/current-system/sw/bin/true") + return status == 0 - machine.succeed("lxc config set container limits.cpu 1") - machine.succeed("lxc restart container") - with machine.nested("Waiting for instance to start and be usable"): - retry(instance_is_up) + machine.wait_for_unit("sockets.target") + machine.wait_for_unit("lxd.service") + machine.wait_for_file("/var/lib/lxd/unix.socket") - assert ( - "1" - == machine.succeed("lxc exec container grep -- -c ^processor /proc/cpuinfo").strip() - ) + # Wait for lxd to settle + machine.succeed("lxd waitready") - machine.succeed("lxc config set container limits.cpu 2") - machine.succeed("lxc restart container") - with machine.nested("Waiting for instance to start and be usable"): - retry(instance_is_up) + # no preseed should mean no service + machine.fail("systemctl status lxd-preseed.service") - assert ( - "2" - == machine.succeed("lxc exec container grep -- -c ^processor /proc/cpuinfo").strip() - ) + machine.succeed("lxd init --minimal") - ## ------------- ## - ## limits.memory ## + machine.succeed( + "lxc image import ${lxd-image-metadata}/*/*.tar.xz ${lxd-image-rootfs}/*/*.tar.xz --alias nixos" + ) - machine.succeed("lxc config set container limits.memory 64MB") - machine.succeed("lxc restart container") - with machine.nested("Waiting for instance to start and be usable"): + with subtest("Container can be managed"): + machine.succeed("lxc launch nixos container") + with machine.nested("Waiting for instance to start and be usable"): retry(instance_is_up) - - assert ( - "MemTotal: 62500 kB" - == machine.succeed("lxc exec container grep -- MemTotal /proc/meminfo").strip() - ) - - machine.succeed("lxc config set container limits.memory 128MB") - machine.succeed("lxc restart container") - with machine.nested("Waiting for instance to start and be usable"): + machine.succeed("echo true | lxc exec container /run/current-system/sw/bin/bash -") + machine.succeed("lxc delete -f container") + + with subtest("Squashfs image is functional"): + machine.succeed( + "lxc image import ${lxd-image-metadata}/*/*.tar.xz ${lxd-image-rootfs-squashfs}/nixos-lxc-image-${pkgs.stdenv.hostPlatform.system}.squashfs --alias nixos-squashfs" + ) + machine.succeed("lxc launch nixos-squashfs container") + with machine.nested("Waiting for instance to start and be usable"): retry(instance_is_up) - - assert ( - "MemTotal: 125000 kB" - == machine.succeed("lxc exec container grep -- MemTotal /proc/meminfo").strip() - ) - - machine.succeed("lxc delete -f container") - ''; -}) + machine.succeed("echo true | lxc exec container /run/current-system/sw/bin/bash -") + machine.succeed("lxc delete -f container") + + with subtest("Container is mounted with lxcfs inside"): + machine.succeed("lxc launch nixos container") + with machine.nested("Waiting for instance to start and be usable"): + retry(instance_is_up) + + ## ---------- ## + ## limits.cpu ## + + machine.succeed("lxc config set container limits.cpu 1") + machine.succeed("lxc restart container") + with machine.nested("Waiting for instance to start and be usable"): + retry(instance_is_up) + + assert ( + "1" + == machine.succeed("lxc exec container grep -- -c ^processor /proc/cpuinfo").strip() + ) + + machine.succeed("lxc config set container limits.cpu 2") + machine.succeed("lxc restart container") + with machine.nested("Waiting for instance to start and be usable"): + retry(instance_is_up) + + assert ( + "2" + == machine.succeed("lxc exec container grep -- -c ^processor /proc/cpuinfo").strip() + ) + + ## ------------- ## + ## limits.memory ## + + machine.succeed("lxc config set container limits.memory 64MB") + machine.succeed("lxc restart container") + with machine.nested("Waiting for instance to start and be usable"): + retry(instance_is_up) + + assert ( + "MemTotal: 62500 kB" + == machine.succeed("lxc exec container grep -- MemTotal /proc/meminfo").strip() + ) + + machine.succeed("lxc config set container limits.memory 128MB") + machine.succeed("lxc restart container") + with machine.nested("Waiting for instance to start and be usable"): + retry(instance_is_up) + + assert ( + "MemTotal: 125000 kB" + == machine.succeed("lxc exec container grep -- MemTotal /proc/meminfo").strip() + ) + + machine.succeed("lxc delete -f container") + ''; + } +) diff --git a/nixos/tests/lxd/default.nix b/nixos/tests/lxd/default.nix index 20afdd5e48bbe3..8e8b073bdda698 100644 --- a/nixos/tests/lxd/default.nix +++ b/nixos/tests/lxd/default.nix @@ -1,12 +1,13 @@ { system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../../.. {inherit system config;}, + config ? { }, + pkgs ? import ../../.. { inherit system config; }, handleTestOn, -}: { - container = import ./container.nix {inherit system pkgs;}; - nftables = import ./nftables.nix {inherit system pkgs;}; - preseed = import ./preseed.nix {inherit system pkgs;}; - ui = import ./ui.nix {inherit system pkgs;}; - virtual-machine = handleTestOn ["x86_64-linux"] ./virtual-machine.nix { inherit system pkgs; }; +}: +{ + container = import ./container.nix { inherit system pkgs; }; + nftables = import ./nftables.nix { inherit system pkgs; }; + preseed = import ./preseed.nix { inherit system pkgs; }; + ui = import ./ui.nix { inherit system pkgs; }; + virtual-machine = handleTestOn [ "x86_64-linux" ] ./virtual-machine.nix { inherit system pkgs; }; } diff --git a/nixos/tests/lxd/nftables.nix b/nixos/tests/lxd/nftables.nix index d419f9b66af138..4e68a27e9f1174 100644 --- a/nixos/tests/lxd/nftables.nix +++ b/nixos/tests/lxd/nftables.nix @@ -5,42 +5,47 @@ # iptables to nftables requires a full reboot, which is a bit hard inside NixOS # tests. -import ../make-test-python.nix ({ pkgs, lib, ...} : { - name = "lxd-nftables"; +import ../make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "lxd-nftables"; - nodes.machine = { lib, ... }: { - virtualisation = { - lxd.enable = true; - }; + nodes.machine = + { lib, ... }: + { + virtualisation = { + lxd.enable = true; + }; - networking = { - firewall.enable = false; - nftables.enable = true; - nftables.tables."filter".family = "inet"; - nftables.tables."filter".content = '' - chain incoming { - type filter hook input priority 0; - policy accept; - } + networking = { + firewall.enable = false; + nftables.enable = true; + nftables.tables."filter".family = "inet"; + nftables.tables."filter".content = '' + chain incoming { + type filter hook input priority 0; + policy accept; + } - chain forward { - type filter hook forward priority 0; - policy accept; - } + chain forward { + type filter hook forward priority 0; + policy accept; + } - chain output { - type filter hook output priority 0; - policy accept; - } - ''; - }; - }; + chain output { + type filter hook output priority 0; + policy accept; + } + ''; + }; + }; - testScript = '' - machine.wait_for_unit("network.target") + testScript = '' + machine.wait_for_unit("network.target") - with subtest("When nftables are enabled, lxd doesn't depend on iptables anymore"): - machine.succeed("lsmod | grep nf_tables") - machine.fail("lsmod | grep ip_tables") - ''; -}) + with subtest("When nftables are enabled, lxd doesn't depend on iptables anymore"): + machine.succeed("lsmod | grep nf_tables") + machine.fail("lsmod | grep ip_tables") + ''; + } +) diff --git a/nixos/tests/lxd/preseed.nix b/nixos/tests/lxd/preseed.nix index 2e0ff33d521fe4..5214da911709f5 100644 --- a/nixos/tests/lxd/preseed.nix +++ b/nixos/tests/lxd/preseed.nix @@ -1,67 +1,71 @@ -import ../make-test-python.nix ({ pkgs, lib, ... } : +import ../make-test-python.nix ( + { pkgs, lib, ... }: -{ - name = "lxd-preseed"; + { + name = "lxd-preseed"; - nodes.machine = { lib, ... }: { - virtualisation = { - diskSize = 4096; + nodes.machine = + { lib, ... }: + { + virtualisation = { + diskSize = 4096; - lxc.lxcfs.enable = true; - lxd.enable = true; + lxc.lxcfs.enable = true; + lxd.enable = true; - lxd.preseed = { - networks = [ - { - name = "nixostestbr0"; - type = "bridge"; - config = { - "ipv4.address" = "10.0.100.1/24"; - "ipv4.nat" = "true"; - }; - } - ]; - profiles = [ - { - name = "nixostest_default"; - devices = { - eth0 = { - name = "eth0"; - network = "nixostestbr0"; - type = "nic"; - }; - root = { - path = "/"; - pool = "default"; - size = "35GiB"; - type = "disk"; - }; - }; - } - ]; - storage_pools = [ - { - name = "nixostest_pool"; - driver = "dir"; - } - ]; + lxd.preseed = { + networks = [ + { + name = "nixostestbr0"; + type = "bridge"; + config = { + "ipv4.address" = "10.0.100.1/24"; + "ipv4.nat" = "true"; + }; + } + ]; + profiles = [ + { + name = "nixostest_default"; + devices = { + eth0 = { + name = "eth0"; + network = "nixostestbr0"; + type = "nic"; + }; + root = { + path = "/"; + pool = "default"; + size = "35GiB"; + type = "disk"; + }; + }; + } + ]; + storage_pools = [ + { + name = "nixostest_pool"; + driver = "dir"; + } + ]; + }; + }; }; - }; - }; - testScript = '' - def wait_for_preseed(_) -> bool: - _, output = machine.systemctl("is-active lxd-preseed.service") - return ("inactive" in output) + testScript = '' + def wait_for_preseed(_) -> bool: + _, output = machine.systemctl("is-active lxd-preseed.service") + return ("inactive" in output) - machine.wait_for_unit("sockets.target") - machine.wait_for_unit("lxd.service") - with machine.nested("Waiting for preseed to complete"): - retry(wait_for_preseed) + machine.wait_for_unit("sockets.target") + machine.wait_for_unit("lxd.service") + with machine.nested("Waiting for preseed to complete"): + retry(wait_for_preseed) - with subtest("Verify preseed resources created"): - machine.succeed("lxc profile show nixostest_default") - machine.succeed("lxc network info nixostestbr0") - machine.succeed("lxc storage show nixostest_pool") - ''; -}) + with subtest("Verify preseed resources created"): + machine.succeed("lxc profile show nixostest_default") + machine.succeed("lxc network info nixostestbr0") + machine.succeed("lxc storage show nixostest_pool") + ''; + } +) diff --git a/nixos/tests/lxd/ui.nix b/nixos/tests/lxd/ui.nix index f96c3d74d93cd1..16fe96ea0870c8 100644 --- a/nixos/tests/lxd/ui.nix +++ b/nixos/tests/lxd/ui.nix @@ -1,62 +1,74 @@ -import ../make-test-python.nix ({ pkgs, ... }: { - name = "lxd-ui"; - - nodes.machine = { lib, ... }: { - virtualisation = { - lxd.enable = true; - lxd.ui.enable = true; - }; - - environment.systemPackages = - let - seleniumScript = pkgs.writers.writePython3Bin "selenium-script" - { - libraries = with pkgs.python3Packages; [ selenium ]; - } '' - from selenium import webdriver - from selenium.webdriver.common.by import By - from selenium.webdriver.firefox.options import Options - from selenium.webdriver.support.ui import WebDriverWait - - options = Options() - options.add_argument("--headless") - service = webdriver.FirefoxService(executable_path="${lib.getExe pkgs.geckodriver}") # noqa: E501 - - driver = webdriver.Firefox(options=options, service=service) - driver.implicitly_wait(10) - driver.get("https://localhost:8443/ui") - - wait = WebDriverWait(driver, 60) - - assert len(driver.find_elements(By.CLASS_NAME, "l-application")) > 0 - assert len(driver.find_elements(By.CLASS_NAME, "l-navigation__drawer")) > 0 - - driver.close() - ''; - in - with pkgs; [ curl firefox-unwrapped geckodriver seleniumScript ]; - }; - - - testScript = '' - machine.wait_for_unit("sockets.target") - machine.wait_for_unit("lxd.service") - machine.wait_for_file("/var/lib/lxd/unix.socket") - - # Wait for lxd to settle - machine.succeed("lxd waitready") - - # Configure LXC listen address - machine.succeed("lxc config set core.https_address :8443") - machine.succeed("systemctl restart lxd") - - # Check that the LXD_UI environment variable is populated in the systemd unit - machine.succeed("cat /etc/systemd/system/lxd.service | grep 'LXD_UI'") - - # Ensure the endpoint returns an HTML page with 'LXD UI' in the title - machine.succeed("curl -kLs https://localhost:8443/ui | grep 'LXD UI'") - - # Ensure the application is actually rendered by the Javascript - machine.succeed("PYTHONUNBUFFERED=1 selenium-script") - ''; -}) +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "lxd-ui"; + + nodes.machine = + { lib, ... }: + { + virtualisation = { + lxd.enable = true; + lxd.ui.enable = true; + }; + + environment.systemPackages = + let + seleniumScript = + pkgs.writers.writePython3Bin "selenium-script" + { + libraries = with pkgs.python3Packages; [ selenium ]; + } + '' + from selenium import webdriver + from selenium.webdriver.common.by import By + from selenium.webdriver.firefox.options import Options + from selenium.webdriver.support.ui import WebDriverWait + + options = Options() + options.add_argument("--headless") + service = webdriver.FirefoxService(executable_path="${lib.getExe pkgs.geckodriver}") # noqa: E501 + + driver = webdriver.Firefox(options=options, service=service) + driver.implicitly_wait(10) + driver.get("https://localhost:8443/ui") + + wait = WebDriverWait(driver, 60) + + assert len(driver.find_elements(By.CLASS_NAME, "l-application")) > 0 + assert len(driver.find_elements(By.CLASS_NAME, "l-navigation__drawer")) > 0 + + driver.close() + ''; + in + with pkgs; + [ + curl + firefox-unwrapped + geckodriver + seleniumScript + ]; + }; + + testScript = '' + machine.wait_for_unit("sockets.target") + machine.wait_for_unit("lxd.service") + machine.wait_for_file("/var/lib/lxd/unix.socket") + + # Wait for lxd to settle + machine.succeed("lxd waitready") + + # Configure LXC listen address + machine.succeed("lxc config set core.https_address :8443") + machine.succeed("systemctl restart lxd") + + # Check that the LXD_UI environment variable is populated in the systemd unit + machine.succeed("cat /etc/systemd/system/lxd.service | grep 'LXD_UI'") + + # Ensure the endpoint returns an HTML page with 'LXD UI' in the title + machine.succeed("curl -kLs https://localhost:8443/ui | grep 'LXD UI'") + + # Ensure the application is actually rendered by the Javascript + machine.succeed("PYTHONUNBUFFERED=1 selenium-script") + ''; + } +) diff --git a/nixos/tests/lxd/virtual-machine.nix b/nixos/tests/lxd/virtual-machine.nix index 14c5e8a82aa8fe..feebe3833e7142 100644 --- a/nixos/tests/lxd/virtual-machine.nix +++ b/nixos/tests/lxd/virtual-machine.nix @@ -1,60 +1,65 @@ -import ../make-test-python.nix ({ pkgs, lib, ... }: +import ../make-test-python.nix ( + { pkgs, lib, ... }: -let - releases = import ../../release.nix { - configuration = { - # Building documentation makes the test unnecessarily take a longer time: - documentation.enable = lib.mkForce false; + let + releases = import ../../release.nix { + configuration = { + # Building documentation makes the test unnecessarily take a longer time: + documentation.enable = lib.mkForce false; - # Our tests require `grep` & friends: - environment.systemPackages = with pkgs; [busybox]; + # Our tests require `grep` & friends: + environment.systemPackages = with pkgs; [ busybox ]; + }; }; - }; - lxd-image-metadata = releases.lxdVirtualMachineImageMeta.${pkgs.stdenv.hostPlatform.system}; - lxd-image-disk = releases.lxdVirtualMachineImage.${pkgs.stdenv.hostPlatform.system}; + lxd-image-metadata = releases.lxdVirtualMachineImageMeta.${pkgs.stdenv.hostPlatform.system}; + lxd-image-disk = releases.lxdVirtualMachineImage.${pkgs.stdenv.hostPlatform.system}; - instance-name = "instance1"; -in { - name = "lxd-virtual-machine"; + instance-name = "instance1"; + in + { + name = "lxd-virtual-machine"; - nodes.machine = {lib, ...}: { - virtualisation = { - diskSize = 4096; + nodes.machine = + { lib, ... }: + { + virtualisation = { + diskSize = 4096; - cores = 2; + cores = 2; - # Ensure we have enough memory for the nested virtual machine - memorySize = 1024; + # Ensure we have enough memory for the nested virtual machine + memorySize = 1024; - lxc.lxcfs.enable = true; - lxd.enable = true; - }; - }; + lxc.lxcfs.enable = true; + lxd.enable = true; + }; + }; - testScript = '' - def instance_is_up(_) -> bool: - status, _ = machine.execute("lxc exec ${instance-name} --disable-stdin --force-interactive /run/current-system/sw/bin/true") - return status == 0 + testScript = '' + def instance_is_up(_) -> bool: + status, _ = machine.execute("lxc exec ${instance-name} --disable-stdin --force-interactive /run/current-system/sw/bin/true") + return status == 0 - machine.wait_for_unit("sockets.target") - machine.wait_for_unit("lxd.service") - machine.wait_for_file("/var/lib/lxd/unix.socket") + machine.wait_for_unit("sockets.target") + machine.wait_for_unit("lxd.service") + machine.wait_for_file("/var/lib/lxd/unix.socket") - # Wait for lxd to settle - machine.succeed("lxd waitready") + # Wait for lxd to settle + machine.succeed("lxd waitready") - machine.succeed("lxd init --minimal") + machine.succeed("lxd init --minimal") - with subtest("virtual-machine image can be imported"): - machine.succeed("lxc image import ${lxd-image-metadata}/*/*.tar.xz ${lxd-image-disk}/nixos.qcow2 --alias nixos") + with subtest("virtual-machine image can be imported"): + machine.succeed("lxc image import ${lxd-image-metadata}/*/*.tar.xz ${lxd-image-disk}/nixos.qcow2 --alias nixos") - with subtest("virtual-machine can be launched and become available"): - machine.succeed("lxc launch nixos ${instance-name} --vm --config limits.memory=512MB --config security.secureboot=false") - with machine.nested("Waiting for instance to start and be usable"): - retry(instance_is_up) + with subtest("virtual-machine can be launched and become available"): + machine.succeed("lxc launch nixos ${instance-name} --vm --config limits.memory=512MB --config security.secureboot=false") + with machine.nested("Waiting for instance to start and be usable"): + retry(instance_is_up) - with subtest("lxd-agent is started"): - machine.succeed("lxc exec ${instance-name} systemctl is-active lxd-agent") - ''; -}) + with subtest("lxd-agent is started"): + machine.succeed("lxc exec ${instance-name} systemctl is-active lxd-agent") + ''; + } +) diff --git a/nixos/tests/maddy/tls.nix b/nixos/tests/maddy/tls.nix index 44da4cf2a3cf2f..fcef0989754311 100644 --- a/nixos/tests/maddy/tls.nix +++ b/nixos/tests/maddy/tls.nix @@ -1,94 +1,112 @@ -import ../make-test-python.nix ({ pkgs, ... }: -let - certs = import ../common/acme/server/snakeoil-certs.nix; - domain = certs.domain; -in { - name = "maddy-tls"; - meta = with pkgs.lib.maintainers; { maintainers = [ onny ]; }; +import ../make-test-python.nix ( + { pkgs, ... }: + let + certs = import ../common/acme/server/snakeoil-certs.nix; + domain = certs.domain; + in + { + name = "maddy-tls"; + meta = with pkgs.lib.maintainers; { + maintainers = [ onny ]; + }; - nodes = { - server = { options, ... }: { - services.maddy = { - enable = true; - hostname = domain; - primaryDomain = domain; - openFirewall = true; - ensureAccounts = [ "postmaster@${domain}" ]; - ensureCredentials = { - # Do not use this in production. This will make passwords world-readable - # in the Nix store - "postmaster@${domain}".passwordFile = "${pkgs.writeText "postmaster" "test"}"; - }; - tls = { - loader = "file"; - certificates = [{ - certPath = "${certs.${domain}.cert}"; - keyPath = "${certs.${domain}.key}"; - }]; + nodes = { + server = + { options, ... }: + { + services.maddy = { + enable = true; + hostname = domain; + primaryDomain = domain; + openFirewall = true; + ensureAccounts = [ "postmaster@${domain}" ]; + ensureCredentials = { + # Do not use this in production. This will make passwords world-readable + # in the Nix store + "postmaster@${domain}".passwordFile = "${pkgs.writeText "postmaster" "test"}"; + }; + tls = { + loader = "file"; + certificates = [ + { + certPath = "${certs.${domain}.cert}"; + keyPath = "${certs.${domain}.key}"; + } + ]; + }; + # Enable TLS listeners. Configuring this via the module is not yet + # implemented. + config = + builtins.replaceStrings + [ + "imap tcp://0.0.0.0:143" + "submission tcp://0.0.0.0:587" + ] + [ + "imap tls://0.0.0.0:993 tcp://0.0.0.0:143" + "submission tls://0.0.0.0:465 tcp://0.0.0.0:587" + ] + options.services.maddy.config.default; + }; + # Not covered by openFirewall yet + networking.firewall.allowedTCPPorts = [ + 993 + 465 + ]; }; - # Enable TLS listeners. Configuring this via the module is not yet - # implemented. - config = builtins.replaceStrings [ - "imap tcp://0.0.0.0:143" - "submission tcp://0.0.0.0:587" - ] [ - "imap tls://0.0.0.0:993 tcp://0.0.0.0:143" - "submission tls://0.0.0.0:465 tcp://0.0.0.0:587" - ] options.services.maddy.config.default; - }; - # Not covered by openFirewall yet - networking.firewall.allowedTCPPorts = [ 993 465 ]; - }; - client = { nodes, ... }: { - security.pki.certificateFiles = [ - certs.ca.cert - ]; - networking.extraHosts = '' - ${nodes.server.networking.primaryIPAddress} ${domain} - ''; - environment.systemPackages = [ - (pkgs.writers.writePython3Bin "send-testmail" { } '' - import smtplib - import ssl - from email.mime.text import MIMEText + client = + { nodes, ... }: + { + security.pki.certificateFiles = [ + certs.ca.cert + ]; + networking.extraHosts = '' + ${nodes.server.networking.primaryIPAddress} ${domain} + ''; + environment.systemPackages = [ + (pkgs.writers.writePython3Bin "send-testmail" { } '' + import smtplib + import ssl + from email.mime.text import MIMEText - context = ssl.create_default_context() - msg = MIMEText("Hello World") - msg['Subject'] = 'Test' - msg['From'] = "postmaster@${domain}" - msg['To'] = "postmaster@${domain}" - with smtplib.SMTP_SSL(host='${domain}', port=465, context=context) as smtp: - smtp.login('postmaster@${domain}', 'test') - smtp.sendmail( - 'postmaster@${domain}', 'postmaster@${domain}', msg.as_string() - ) - '') - (pkgs.writers.writePython3Bin "test-imap" { } '' - import imaplib + context = ssl.create_default_context() + msg = MIMEText("Hello World") + msg['Subject'] = 'Test' + msg['From'] = "postmaster@${domain}" + msg['To'] = "postmaster@${domain}" + with smtplib.SMTP_SSL(host='${domain}', port=465, context=context) as smtp: + smtp.login('postmaster@${domain}', 'test') + smtp.sendmail( + 'postmaster@${domain}', 'postmaster@${domain}', msg.as_string() + ) + '') + (pkgs.writers.writePython3Bin "test-imap" { } '' + import imaplib - with imaplib.IMAP4_SSL('${domain}') as imap: - imap.login('postmaster@${domain}', 'test') - imap.select() - status, refs = imap.search(None, 'ALL') - assert status == 'OK' - assert len(refs) == 1 - status, msg = imap.fetch(refs[0], 'BODY[TEXT]') - assert status == 'OK' - assert msg[0][1].strip() == b"Hello World" - '') - ]; + with imaplib.IMAP4_SSL('${domain}') as imap: + imap.login('postmaster@${domain}', 'test') + imap.select() + status, refs = imap.search(None, 'ALL') + assert status == 'OK' + assert len(refs) == 1 + status, msg = imap.fetch(refs[0], 'BODY[TEXT]') + assert status == 'OK' + assert msg[0][1].strip() == b"Hello World" + '') + ]; + }; }; - }; - testScript = '' - start_all() - server.wait_for_unit("maddy.service") - server.wait_for_open_port(143) - server.wait_for_open_port(993) - server.wait_for_open_port(587) - server.wait_for_open_port(465) - client.succeed("send-testmail") - client.succeed("test-imap") - ''; -}) + testScript = '' + start_all() + server.wait_for_unit("maddy.service") + server.wait_for_open_port(143) + server.wait_for_open_port(993) + server.wait_for_open_port(587) + server.wait_for_open_port(465) + client.succeed("send-testmail") + client.succeed("test-imap") + ''; + } +) diff --git a/nixos/tests/maddy/unencrypted.nix b/nixos/tests/maddy/unencrypted.nix index 2420d461e4e7c3..0e66d4059549df 100644 --- a/nixos/tests/maddy/unencrypted.nix +++ b/nixos/tests/maddy/unencrypted.nix @@ -1,60 +1,69 @@ -import ../make-test-python.nix ({ pkgs, ... }: { - name = "maddy-unencrypted"; - meta = with pkgs.lib.maintainers; { maintainers = [ onny ]; }; +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "maddy-unencrypted"; + meta = with pkgs.lib.maintainers; { + maintainers = [ onny ]; + }; - nodes = { - server = { ... }: { - services.maddy = { - enable = true; - hostname = "server"; - primaryDomain = "server"; - openFirewall = true; - ensureAccounts = [ "postmaster@server" ]; - ensureCredentials = { - # Do not use this in production. This will make passwords world-readable - # in the Nix store - "postmaster@server".passwordFile = "${pkgs.writeText "postmaster" "test"}"; + nodes = { + server = + { ... }: + { + services.maddy = { + enable = true; + hostname = "server"; + primaryDomain = "server"; + openFirewall = true; + ensureAccounts = [ "postmaster@server" ]; + ensureCredentials = { + # Do not use this in production. This will make passwords world-readable + # in the Nix store + "postmaster@server".passwordFile = "${pkgs.writeText "postmaster" "test"}"; + }; + }; }; - }; - }; - client = { ... }: { - environment.systemPackages = [ - (pkgs.writers.writePython3Bin "send-testmail" { } '' - import smtplib - from email.mime.text import MIMEText + client = + { ... }: + { + environment.systemPackages = [ + (pkgs.writers.writePython3Bin "send-testmail" { } '' + import smtplib + from email.mime.text import MIMEText - msg = MIMEText("Hello World") - msg['Subject'] = 'Test' - msg['From'] = "postmaster@server" - msg['To'] = "postmaster@server" - with smtplib.SMTP('server', 587) as smtp: - smtp.login('postmaster@server', 'test') - smtp.sendmail('postmaster@server', 'postmaster@server', msg.as_string()) - '') - (pkgs.writers.writePython3Bin "test-imap" { } '' - import imaplib + msg = MIMEText("Hello World") + msg['Subject'] = 'Test' + msg['From'] = "postmaster@server" + msg['To'] = "postmaster@server" + with smtplib.SMTP('server', 587) as smtp: + smtp.login('postmaster@server', 'test') + smtp.sendmail('postmaster@server', 'postmaster@server', msg.as_string()) + '') + (pkgs.writers.writePython3Bin "test-imap" { } '' + import imaplib - with imaplib.IMAP4('server') as imap: - imap.login('postmaster@server', 'test') - imap.select() - status, refs = imap.search(None, 'ALL') - assert status == 'OK' - assert len(refs) == 1 - status, msg = imap.fetch(refs[0], 'BODY[TEXT]') - assert status == 'OK' - assert msg[0][1].strip() == b"Hello World" - '') - ]; + with imaplib.IMAP4('server') as imap: + imap.login('postmaster@server', 'test') + imap.select() + status, refs = imap.search(None, 'ALL') + assert status == 'OK' + assert len(refs) == 1 + status, msg = imap.fetch(refs[0], 'BODY[TEXT]') + assert status == 'OK' + assert msg[0][1].strip() == b"Hello World" + '') + ]; + }; }; - }; - testScript = '' - start_all() - server.wait_for_unit("maddy.service") - server.wait_for_open_port(143) - server.wait_for_open_port(587) - client.succeed("send-testmail") - client.succeed("test-imap") - ''; -}) + testScript = '' + start_all() + server.wait_for_unit("maddy.service") + server.wait_for_open_port(143) + server.wait_for_open_port(587) + client.succeed("send-testmail") + client.succeed("test-imap") + ''; + } +) diff --git a/nixos/tests/maestral.nix b/nixos/tests/maestral.nix index 52cc32cd0f4bbc..aa510897d0d759 100644 --- a/nixos/tests/maestral.nix +++ b/nixos/tests/maestral.nix @@ -1,76 +1,83 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "maestral"; - meta = with pkgs.lib.maintainers; { - maintainers = [ peterhoeg ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "maestral"; + meta = with pkgs.lib.maintainers; { + maintainers = [ peterhoeg ]; + }; - nodes = - let - common = attrs: - pkgs.lib.recursiveUpdate - { + nodes = + let + common = + attrs: + pkgs.lib.recursiveUpdate { imports = [ ./common/user-account.nix ]; systemd.user.services.maestral = { description = "Maestral Dropbox Client"; serviceConfig.Type = "exec"; }; - } - attrs; + } attrs; - in - { - cli = { ... }: common { - systemd.user.services.maestral = { - wantedBy = [ "default.target" ]; - serviceConfig.ExecStart = "${pkgs.maestral}/bin/maestral start --foreground"; - }; - }; + in + { + cli = + { ... }: + common { + systemd.user.services.maestral = { + wantedBy = [ "default.target" ]; + serviceConfig.ExecStart = "${pkgs.maestral}/bin/maestral start --foreground"; + }; + }; - gui = { ... }: common { - services.xserver = { - enable = true; - desktopManager.plasma5.enable = true; - desktopManager.plasma5.runUsingSystemd = true; - }; + gui = + { ... }: + common { + services.xserver = { + enable = true; + desktopManager.plasma5.enable = true; + desktopManager.plasma5.runUsingSystemd = true; + }; - services.displayManager = { - sddm.enable = true; - defaultSession = "plasma"; - autoLogin = { - enable = true; - user = "alice"; - }; - }; + services.displayManager = { + sddm.enable = true; + defaultSession = "plasma"; + autoLogin = { + enable = true; + user = "alice"; + }; + }; - systemd.user.services = { - maestral = { - wantedBy = [ "graphical-session.target" ]; - serviceConfig.ExecStart = "${pkgs.maestral-gui}/bin/maestral_qt"; + systemd.user.services = { + maestral = { + wantedBy = [ "graphical-session.target" ]; + serviceConfig.ExecStart = "${pkgs.maestral-gui}/bin/maestral_qt"; + }; + # PowerDevil doesn't like our VM + plasma-powerdevil.enable = false; + }; }; - # PowerDevil doesn't like our VM - plasma-powerdevil.enable = false; - }; }; - }; - testScript = { nodes, ... }: - let - user = nodes.cli.users.users.alice; - in - '' - start_all() + testScript = + { nodes, ... }: + let + user = nodes.cli.users.users.alice; + in + '' + start_all() - with subtest("CLI"): - # we need SOME way to give the user an active login session - cli.execute("loginctl enable-linger ${user.name}") - cli.systemctl("start user@${toString user.uid}") - cli.wait_for_unit("maestral.service", "${user.name}") + with subtest("CLI"): + # we need SOME way to give the user an active login session + cli.execute("loginctl enable-linger ${user.name}") + cli.systemctl("start user@${toString user.uid}") + cli.wait_for_unit("maestral.service", "${user.name}") - with subtest("GUI"): - gui.wait_for_x() - gui.wait_for_file("/tmp/xauth_*") - gui.succeed("xauth merge /tmp/xauth_*") - gui.wait_for_window("^Desktop ") - gui.wait_for_unit("maestral.service", "${user.name}") - ''; -}) + with subtest("GUI"): + gui.wait_for_x() + gui.wait_for_file("/tmp/xauth_*") + gui.succeed("xauth merge /tmp/xauth_*") + gui.wait_for_window("^Desktop ") + gui.wait_for_unit("maestral.service", "${user.name}") + ''; + } +) diff --git a/nixos/tests/magic-wormhole-mailbox-server.nix b/nixos/tests/magic-wormhole-mailbox-server.nix index 54088ac60f2844..c6979db791f28d 100644 --- a/nixos/tests/magic-wormhole-mailbox-server.nix +++ b/nixos/tests/magic-wormhole-mailbox-server.nix @@ -1,38 +1,47 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "magic-wormhole-mailbox-server"; - meta = with pkgs.lib.maintainers; { - maintainers = [ mmahut ]; - }; - - nodes = { - server = { ... }: { - networking.firewall.allowedTCPPorts = [ 4000 ]; - services.magic-wormhole-mailbox-server.enable = true; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "magic-wormhole-mailbox-server"; + meta = with pkgs.lib.maintainers; { + maintainers = [ mmahut ]; }; - client_alice = { ... }: { - networking.firewall.enable = false; - environment.systemPackages = [ pkgs.magic-wormhole ]; - }; + nodes = { + server = + { ... }: + { + networking.firewall.allowedTCPPorts = [ 4000 ]; + services.magic-wormhole-mailbox-server.enable = true; + }; + + client_alice = + { ... }: + { + networking.firewall.enable = false; + environment.systemPackages = [ pkgs.magic-wormhole ]; + }; - client_bob = { ... }: { - environment.systemPackages = [ pkgs.magic-wormhole ]; + client_bob = + { ... }: + { + environment.systemPackages = [ pkgs.magic-wormhole ]; + }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - # Start the wormhole relay server - server.wait_for_unit("magic-wormhole-mailbox-server.service") - server.wait_for_open_port(4000) + # Start the wormhole relay server + server.wait_for_unit("magic-wormhole-mailbox-server.service") + server.wait_for_open_port(4000) - # Create a secret file and send it to Bob - client_alice.succeed("echo mysecret > secretfile") - client_alice.succeed("wormhole --relay-url=ws://server:4000/v1 send -0 secretfile >&2 &") + # Create a secret file and send it to Bob + client_alice.succeed("echo mysecret > secretfile") + client_alice.succeed("wormhole --relay-url=ws://server:4000/v1 send -0 secretfile >&2 &") - # Retrieve a secret file from Alice and check its content - client_bob.succeed("wormhole --relay-url=ws://server:4000/v1 receive -0 --accept-file") - client_bob.succeed("grep mysecret secretfile") - ''; -}) + # Retrieve a secret file from Alice and check its content + client_bob.succeed("wormhole --relay-url=ws://server:4000/v1 receive -0 --accept-file") + client_bob.succeed("grep mysecret secretfile") + ''; + } +) diff --git a/nixos/tests/magnetico.nix b/nixos/tests/magnetico.nix index ee84aacaf7a74c..279d19d8777820 100644 --- a/nixos/tests/magnetico.nix +++ b/nixos/tests/magnetico.nix @@ -1,29 +1,31 @@ -import ./make-test-python.nix ({ pkgs, ...} : +import ./make-test-python.nix ( + { pkgs, ... }: -let - port = 8081; -in -{ - name = "magnetico"; - meta = with pkgs.lib.maintainers; { - maintainers = [ rnhmjoj ]; - }; + let + port = 8081; + in + { + name = "magnetico"; + meta = with pkgs.lib.maintainers; { + maintainers = [ rnhmjoj ]; + }; - nodes.machine = { ... }: { - imports = [ ../modules/profiles/minimal.nix ]; + nodes.machine = + { ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; - networking.firewall.allowedTCPPorts = [ 9000 ]; + networking.firewall.allowedTCPPorts = [ 9000 ]; - services.magnetico = { - enable = true; - crawler.port = 9000; - web.port = port; - web.credentials.user = "$2y$12$P88ZF6soFthiiAeXnz64aOWDsY3Dw7Yw8fZ6GtiqFNjknD70zDmNe"; - }; - }; + services.magnetico = { + enable = true; + crawler.port = 9000; + web.port = port; + web.credentials.user = "$2y$12$P88ZF6soFthiiAeXnz64aOWDsY3Dw7Yw8fZ6GtiqFNjknD70zDmNe"; + }; + }; - testScript = - '' + testScript = '' start_all() machine.wait_for_unit("magneticod") machine.wait_for_unit("magneticow") @@ -38,4 +40,5 @@ in ) machine.shutdown() ''; -}) + } +) diff --git a/nixos/tests/mailcatcher.nix b/nixos/tests/mailcatcher.nix index 627ef56617e9bc..312f8ed102bff1 100644 --- a/nixos/tests/mailcatcher.nix +++ b/nixos/tests/mailcatcher.nix @@ -1,35 +1,37 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "mailcatcher"; - meta.maintainers = [ lib.maintainers.aanderse ]; + { + name = "mailcatcher"; + meta.maintainers = [ lib.maintainers.aanderse ]; - nodes.machine = - { pkgs, ... }: - { - services.mailcatcher.enable = true; + nodes.machine = + { pkgs, ... }: + { + services.mailcatcher.enable = true; - programs.msmtp = { - enable = true; - accounts.default = { - host = "localhost"; - port = 1025; + programs.msmtp = { + enable = true; + accounts.default = { + host = "localhost"; + port = 1025; + }; }; - }; - environment.systemPackages = [ pkgs.mailutils ]; - }; + environment.systemPackages = [ pkgs.mailutils ]; + }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("mailcatcher.service") - machine.wait_for_open_port(1025) - machine.succeed( - 'echo "this is the body of the email" | mail -s "subject" root@example.org' - ) - assert "this is the body of the email" in machine.succeed( - "curl -f http://localhost:1080/messages/1.source" - ) - ''; -}) + machine.wait_for_unit("mailcatcher.service") + machine.wait_for_open_port(1025) + machine.succeed( + 'echo "this is the body of the email" | mail -s "subject" root@example.org' + ) + assert "this is the body of the email" in machine.succeed( + "curl -f http://localhost:1080/messages/1.source" + ) + ''; + } +) diff --git a/nixos/tests/mailman.nix b/nixos/tests/mailman.nix index f9b43861a12f6a..d4e09148a9dd12 100644 --- a/nixos/tests/mailman.nix +++ b/nixos/tests/mailman.nix @@ -1,73 +1,86 @@ import ./make-test-python.nix { name = "mailman"; - nodes.machine = { pkgs, ... }: { - environment.systemPackages = with pkgs; [ mailutils ]; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = with pkgs; [ mailutils ]; - services.mailman.enable = true; - services.mailman.serve.enable = true; - services.mailman.siteOwner = "postmaster@example.com"; - services.mailman.webHosts = [ "example.com" ]; + services.mailman.enable = true; + services.mailman.serve.enable = true; + services.mailman.siteOwner = "postmaster@example.com"; + services.mailman.webHosts = [ "example.com" ]; - services.postfix.enable = true; - services.postfix.destination = [ "example.com" "example.net" ]; - services.postfix.relayDomains = [ "hash:/var/lib/mailman/data/postfix_domains" ]; - services.postfix.config.local_recipient_maps = [ "hash:/var/lib/mailman/data/postfix_lmtp" "proxy:unix:passwd.byname" ]; - services.postfix.config.transport_maps = [ "hash:/var/lib/mailman/data/postfix_lmtp" ]; + services.postfix.enable = true; + services.postfix.destination = [ + "example.com" + "example.net" + ]; + services.postfix.relayDomains = [ "hash:/var/lib/mailman/data/postfix_domains" ]; + services.postfix.config.local_recipient_maps = [ + "hash:/var/lib/mailman/data/postfix_lmtp" + "proxy:unix:passwd.byname" + ]; + services.postfix.config.transport_maps = [ "hash:/var/lib/mailman/data/postfix_lmtp" ]; - users.users.user = { isNormalUser = true; }; + users.users.user = { + isNormalUser = true; + }; - virtualisation.memorySize = 2048; + virtualisation.memorySize = 2048; - specialisation.restApiPassFileSystem.configuration = { - services.mailman.restApiPassFile = "/var/lib/mailman/pass"; + specialisation.restApiPassFileSystem.configuration = { + services.mailman.restApiPassFile = "/var/lib/mailman/pass"; + }; }; - }; - testScript = { nodes, ... }: let - restApiPassFileSystem = "${nodes.machine.system.build.toplevel}/specialisation/restApiPassFileSystem"; - in '' - def check_mail(_) -> bool: - status, _ = machine.execute("grep -q hello /var/spool/mail/user/new/*") - return status == 0 + testScript = + { nodes, ... }: + let + restApiPassFileSystem = "${nodes.machine.system.build.toplevel}/specialisation/restApiPassFileSystem"; + in + '' + def check_mail(_) -> bool: + status, _ = machine.execute("grep -q hello /var/spool/mail/user/new/*") + return status == 0 - def try_api(_) -> bool: - status, _ = machine.execute("curl -s http://localhost:8001/") - return status == 0 + def try_api(_) -> bool: + status, _ = machine.execute("curl -s http://localhost:8001/") + return status == 0 - def wait_for_api(): - with machine.nested("waiting for Mailman REST API to be available"): - retry(try_api) + def wait_for_api(): + with machine.nested("waiting for Mailman REST API to be available"): + retry(try_api) - machine.wait_for_unit("mailman.service") - wait_for_api() + machine.wait_for_unit("mailman.service") + wait_for_api() - with subtest("subscription and delivery"): - creds = machine.succeed("su -s /bin/sh -c 'mailman info' mailman | grep '^REST credentials: ' | sed 's/^REST credentials: //'").strip() - machine.succeed(f"curl --fail-with-body -sLSu {creds} -d mail_host=example.com http://localhost:8001/3.1/domains") - machine.succeed(f"curl --fail-with-body -sLSu {creds} -d fqdn_listname=list@example.com http://localhost:8001/3.1/lists") - machine.succeed(f"curl --fail-with-body -sLSu {creds} -d list_id=list.example.com -d subscriber=root@example.com -d pre_confirmed=True -d pre_verified=True -d send_welcome_message=False http://localhost:8001/3.1/members") - machine.succeed(f"curl --fail-with-body -sLSu {creds} -d list_id=list.example.com -d subscriber=user@example.net -d pre_confirmed=True -d pre_verified=True -d send_welcome_message=False http://localhost:8001/3.1/members") - machine.succeed("mail -a 'From: root@example.com' -s hello list@example.com < /dev/null") - with machine.nested("waiting for mail from list"): - retry(check_mail) + with subtest("subscription and delivery"): + creds = machine.succeed("su -s /bin/sh -c 'mailman info' mailman | grep '^REST credentials: ' | sed 's/^REST credentials: //'").strip() + machine.succeed(f"curl --fail-with-body -sLSu {creds} -d mail_host=example.com http://localhost:8001/3.1/domains") + machine.succeed(f"curl --fail-with-body -sLSu {creds} -d fqdn_listname=list@example.com http://localhost:8001/3.1/lists") + machine.succeed(f"curl --fail-with-body -sLSu {creds} -d list_id=list.example.com -d subscriber=root@example.com -d pre_confirmed=True -d pre_verified=True -d send_welcome_message=False http://localhost:8001/3.1/members") + machine.succeed(f"curl --fail-with-body -sLSu {creds} -d list_id=list.example.com -d subscriber=user@example.net -d pre_confirmed=True -d pre_verified=True -d send_welcome_message=False http://localhost:8001/3.1/members") + machine.succeed("mail -a 'From: root@example.com' -s hello list@example.com < /dev/null") + with machine.nested("waiting for mail from list"): + retry(check_mail) - with subtest("Postorius"): - machine.succeed("curl --fail-with-body -sILS http://localhost/") + with subtest("Postorius"): + machine.succeed("curl --fail-with-body -sILS http://localhost/") - with subtest("restApiPassFile"): - machine.succeed("echo secretpassword > /var/lib/mailman/pass") - machine.succeed("${restApiPassFileSystem}/bin/switch-to-configuration test >&2") - machine.succeed("grep secretpassword /etc/mailman.cfg") - machine.succeed("su -s /bin/sh -c 'mailman info' mailman | grep secretpassword") - wait_for_api() - machine.succeed("curl --fail-with-body -sLSu restadmin:secretpassword http://localhost:8001/3.1/domains") - machine.succeed("curl --fail-with-body -sILS http://localhost/") + with subtest("restApiPassFile"): + machine.succeed("echo secretpassword > /var/lib/mailman/pass") + machine.succeed("${restApiPassFileSystem}/bin/switch-to-configuration test >&2") + machine.succeed("grep secretpassword /etc/mailman.cfg") + machine.succeed("su -s /bin/sh -c 'mailman info' mailman | grep secretpassword") + wait_for_api() + machine.succeed("curl --fail-with-body -sLSu restadmin:secretpassword http://localhost:8001/3.1/domains") + machine.succeed("curl --fail-with-body -sILS http://localhost/") - with subtest("service locking"): - machine.fail("su -s /bin/sh -c 'mailman start' mailman") - machine.execute("systemctl kill --signal=SIGKILL mailman") - machine.succeed("systemctl restart mailman") - wait_for_api() - ''; + with subtest("service locking"): + machine.fail("su -s /bin/sh -c 'mailman start' mailman") + machine.execute("systemctl kill --signal=SIGKILL mailman") + machine.succeed("systemctl restart mailman") + wait_for_api() + ''; } diff --git a/nixos/tests/make-test-python.nix b/nixos/tests/make-test-python.nix index 28569f1d2955ac..ec8a286607a030 100644 --- a/nixos/tests/make-test-python.nix +++ b/nixos/tests/make-test-python.nix @@ -1,9 +1,25 @@ -f: { +f: +{ system ? builtins.currentSystem, - pkgs ? import ../.. { inherit system; config = {}; overlays = []; }, + pkgs ? import ../.. { + inherit system; + config = { }; + overlays = [ ]; + }, ... -} @ args: +}@args: with import ../lib/testing-python.nix { inherit system pkgs; }; -makeTest (if pkgs.lib.isFunction f then f (args // { inherit pkgs; inherit (pkgs) lib; }) else f) +makeTest ( + if pkgs.lib.isFunction f then + f ( + args + // { + inherit pkgs; + inherit (pkgs) lib; + } + ) + else + f +) diff --git a/nixos/tests/man.nix b/nixos/tests/man.nix index 1ff5af4e805911..510a46a46ec9d8 100644 --- a/nixos/tests/man.nix +++ b/nixos/tests/man.nix @@ -1,100 +1,111 @@ +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + manImplementations = [ + "mandoc" + "man-db" + ]; -import ./make-test-python.nix ({ pkgs, lib, ... }: let - manImplementations = [ - "mandoc" - "man-db" - ]; - - machineNames = builtins.map machineSafe manImplementations; + machineNames = builtins.map machineSafe manImplementations; - makeConfig = useImpl: { - # Note: mandoc currently can't index symlinked section directories. - # So if a man section comes from one package exclusively (e. g. - # 1p from man-pages-posix and 2 from man-pages), it isn't searchable. - environment.systemPackages = [ - pkgs.man-pages - pkgs.openssl - pkgs.libunwind - ]; + makeConfig = useImpl: { + # Note: mandoc currently can't index symlinked section directories. + # So if a man section comes from one package exclusively (e. g. + # 1p from man-pages-posix and 2 from man-pages), it isn't searchable. + environment.systemPackages = [ + pkgs.man-pages + pkgs.openssl + pkgs.libunwind + ]; - documentation = { - enable = true; - nixos.enable = lib.mkForce true; - dev.enable = true; - man = { + documentation = { enable = true; - generateCaches = true; - } // lib.listToAttrs (builtins.map (impl: { - name = impl; - value = { - enable = useImpl == impl; - }; - }) manImplementations); + nixos.enable = lib.mkForce true; + dev.enable = true; + man = + { + enable = true; + generateCaches = true; + } + // lib.listToAttrs ( + builtins.map (impl: { + name = impl; + value = { + enable = useImpl == impl; + }; + }) manImplementations + ); + }; }; - }; - machineSafe = builtins.replaceStrings [ "-" ] [ "_" ]; -in { - name = "man"; - meta.maintainers = [ lib.maintainers.sternenseemann ]; + machineSafe = builtins.replaceStrings [ "-" ] [ "_" ]; + in + { + name = "man"; + meta.maintainers = [ lib.maintainers.sternenseemann ]; - nodes = lib.listToAttrs (builtins.map (i: { - name = machineSafe i; - value = makeConfig i; - }) manImplementations); + nodes = lib.listToAttrs ( + builtins.map (i: { + name = machineSafe i; + value = makeConfig i; + }) manImplementations + ); - testScript = '' - import re - start_all() + testScript = + '' + import re + start_all() - def match_man_k(page, section, haystack): - """ - Check if the man page {page}({section}) occurs in - the output of `man -k` given as haystack. Note: - This is not super reliable, e. g. it can't deal - with man pages that are in multiple sections. - """ + def match_man_k(page, section, haystack): + """ + Check if the man page {page}({section}) occurs in + the output of `man -k` given as haystack. Note: + This is not super reliable, e. g. it can't deal + with man pages that are in multiple sections. + """ - for line in haystack.split("\n"): - # man -k can look like this: - # page(3) - bla - # page (3) - bla - # pagea, pageb (3, 3P) - foo - # pagea, pageb, pagec(3) - bar - pages = line.split("(")[0] - sections = re.search("\\([a-zA-Z1-9, ]+\\)", line) - if sections is None: - continue - else: - sections = sections.group(0)[1:-1] + for line in haystack.split("\n"): + # man -k can look like this: + # page(3) - bla + # page (3) - bla + # pagea, pageb (3, 3P) - foo + # pagea, pageb, pagec(3) - bar + pages = line.split("(")[0] + sections = re.search("\\([a-zA-Z1-9, ]+\\)", line) + if sections is None: + continue + else: + sections = sections.group(0)[1:-1] - if page in pages and f'{section}' in sections: - return True + if page in pages and f'{section}' in sections: + return True - return False + return False - '' + lib.concatMapStrings (machine: '' - with subtest("Test direct man page lookups in ${machine}"): - # man works - ${machine}.succeed("man man > /dev/null") - # devman works - ${machine}.succeed("man 3 libunwind > /dev/null") - # NixOS configuration man page is installed - ${machine}.succeed("man configuration.nix > /dev/null") + '' + + lib.concatMapStrings (machine: '' + with subtest("Test direct man page lookups in ${machine}"): + # man works + ${machine}.succeed("man man > /dev/null") + # devman works + ${machine}.succeed("man 3 libunwind > /dev/null") + # NixOS configuration man page is installed + ${machine}.succeed("man configuration.nix > /dev/null") - with subtest("Test generateCaches via man -k in ${machine}"): - expected = [ - ("openssl", "ssl", 3), - ("unwind", "libunwind", 3), - ("user", "useradd", 8), - ("user", "userdel", 8), - ("mem", "free", 3), - ("mem", "free", 1), - ] + with subtest("Test generateCaches via man -k in ${machine}"): + expected = [ + ("openssl", "ssl", 3), + ("unwind", "libunwind", 3), + ("user", "useradd", 8), + ("user", "userdel", 8), + ("mem", "free", 3), + ("mem", "free", 1), + ] - for (keyword, page, section) in expected: - matches = ${machine}.succeed(f"man -k {keyword}") - if not match_man_k(page, section, matches): - raise Exception(f"{page}({section}) missing in matches: {matches}") - '') machineNames; -}) + for (keyword, page, section) in expected: + matches = ${machine}.succeed(f"man -k {keyword}") + if not match_man_k(page, section, matches): + raise Exception(f"{page}({section}) missing in matches: {matches}") + '') machineNames; + } +) diff --git a/nixos/tests/mate-wayland.nix b/nixos/tests/mate-wayland.nix index 73f94ababc4931..1e660087ec99e2 100644 --- a/nixos/tests/mate-wayland.nix +++ b/nixos/tests/mate-wayland.nix @@ -1,60 +1,66 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "mate-wayland"; - - meta.maintainers = lib.teams.mate.members; - - nodes.machine = { ... }: { - imports = [ - ./common/user-account.nix - ]; - - services.xserver.enable = true; - services.displayManager = { - sddm.enable = true; # https://github.com/canonical/lightdm/issues/63 - sddm.wayland.enable = true; - defaultSession = "MATE"; - autoLogin = { - enable = true; - user = "alice"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "mate-wayland"; + + meta.maintainers = lib.teams.mate.members; + + nodes.machine = + { ... }: + { + imports = [ + ./common/user-account.nix + ]; + + services.xserver.enable = true; + services.displayManager = { + sddm.enable = true; # https://github.com/canonical/lightdm/issues/63 + sddm.wayland.enable = true; + defaultSession = "MATE"; + autoLogin = { + enable = true; + user = "alice"; + }; + }; + services.xserver.desktopManager.mate.enableWaylandSession = true; + + # Need to switch to a different GPU driver than the default one (-vga std) so that wayfire can launch: + virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ]; }; - }; - services.xserver.desktopManager.mate.enableWaylandSession = true; - - # Need to switch to a different GPU driver than the default one (-vga std) so that wayfire can launch: - virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ]; - }; - - enableOCR = true; - - testScript = { nodes, ... }: - let - user = nodes.machine.users.users.alice; - in - '' - machine.wait_for_unit("display-manager.service") - - with subtest("Wait for Wayland server"): - machine.wait_for_file("/run/user/${toString user.uid}/wayland-1") - - with subtest("Check if MATE session components actually start"): - for i in ["wayfire", "mate-panel", "mate-wayland.sh", "mate-wayland-components.sh"]: - machine.wait_until_succeeds(f"pgrep -f {i}") - # It is expected that this applet doesn't work in Wayland - machine.wait_for_text('WorkspaceSwitcherApplet') - - with subtest("Check if various environment variables are set"): - cmd = "xargs --null --max-args=1 echo < /proc/$(pgrep -xf mate-panel)/environ" - machine.succeed(f"{cmd} | grep 'XDG_SESSION_TYPE' | grep 'wayland'") - machine.succeed(f"{cmd} | grep 'XDG_SESSION_DESKTOP' | grep 'MATE'") - machine.succeed(f"{cmd} | grep 'MATE_PANEL_APPLETS_DIR' | grep '${pkgs.mate.mate-panel-with-applets.pname}'") - - with subtest("Check if Wayfire config is properly configured"): - for i in ["button_style = mate", "firedecor", "mate-wayland-components.sh"]: - machine.wait_until_succeeds(f"cat /home/${user.name}/.config/mate/wayfire.ini | grep '{i}'") - - with subtest("Check if Wayfire has ever coredumped"): - machine.fail("coredumpctl --json=short | grep wayfire") - machine.sleep(10) - machine.screenshot("screen") - ''; -}) + + enableOCR = true; + + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + in + '' + machine.wait_for_unit("display-manager.service") + + with subtest("Wait for Wayland server"): + machine.wait_for_file("/run/user/${toString user.uid}/wayland-1") + + with subtest("Check if MATE session components actually start"): + for i in ["wayfire", "mate-panel", "mate-wayland.sh", "mate-wayland-components.sh"]: + machine.wait_until_succeeds(f"pgrep -f {i}") + # It is expected that this applet doesn't work in Wayland + machine.wait_for_text('WorkspaceSwitcherApplet') + + with subtest("Check if various environment variables are set"): + cmd = "xargs --null --max-args=1 echo < /proc/$(pgrep -xf mate-panel)/environ" + machine.succeed(f"{cmd} | grep 'XDG_SESSION_TYPE' | grep 'wayland'") + machine.succeed(f"{cmd} | grep 'XDG_SESSION_DESKTOP' | grep 'MATE'") + machine.succeed(f"{cmd} | grep 'MATE_PANEL_APPLETS_DIR' | grep '${pkgs.mate.mate-panel-with-applets.pname}'") + + with subtest("Check if Wayfire config is properly configured"): + for i in ["button_style = mate", "firedecor", "mate-wayland-components.sh"]: + machine.wait_until_succeeds(f"cat /home/${user.name}/.config/mate/wayfire.ini | grep '{i}'") + + with subtest("Check if Wayfire has ever coredumped"): + machine.fail("coredumpctl --json=short | grep wayfire") + machine.sleep(10) + machine.screenshot("screen") + ''; + } +) diff --git a/nixos/tests/mate.nix b/nixos/tests/mate.nix index 0cadd6d0d5bff0..d0847be5ffa9b6 100644 --- a/nixos/tests/mate.nix +++ b/nixos/tests/mate.nix @@ -1,86 +1,92 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "mate"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "mate"; - meta = { - maintainers = lib.teams.mate.members; - }; + meta = { + maintainers = lib.teams.mate.members; + }; - nodes.machine = { ... }: { - imports = [ - ./common/user-account.nix - ]; + nodes.machine = + { ... }: + { + imports = [ + ./common/user-account.nix + ]; - services.xserver.enable = true; + services.xserver.enable = true; - services.xserver.displayManager = { - lightdm.enable = true; - autoLogin = { - enable = true; - user = "alice"; - }; - }; + services.xserver.displayManager = { + lightdm.enable = true; + autoLogin = { + enable = true; + user = "alice"; + }; + }; - services.xserver.desktopManager.mate.enable = true; - }; + services.xserver.desktopManager.mate.enable = true; + }; - enableOCR = true; + enableOCR = true; - testScript = { nodes, ... }: - let - user = nodes.machine.users.users.alice; - env = "DISPLAY=:0.0 DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${toString user.uid}/bus"; - in - '' - with subtest("Wait for login"): - machine.wait_for_x() - machine.wait_for_file("${user.home}/.Xauthority") - machine.succeed("xauth merge ${user.home}/.Xauthority") + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + env = "DISPLAY=:0.0 DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${toString user.uid}/bus"; + in + '' + with subtest("Wait for login"): + machine.wait_for_x() + machine.wait_for_file("${user.home}/.Xauthority") + machine.succeed("xauth merge ${user.home}/.Xauthority") - with subtest("Check that logging in has given the user ownership of devices"): - machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") + with subtest("Check that logging in has given the user ownership of devices"): + machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") - with subtest("Check if MATE session components actually start"): - machine.wait_until_succeeds("pgrep marco") - machine.wait_for_window("marco") - machine.wait_until_succeeds("pgrep mate-panel") - machine.wait_for_window("Top Panel") - machine.wait_for_window("Bottom Panel") - machine.wait_until_succeeds("pgrep caja") - machine.wait_for_window("Caja") - machine.wait_for_text('(Applications|Places|System)') - machine.wait_for_text('(Computer|Home|Trash)') + with subtest("Check if MATE session components actually start"): + machine.wait_until_succeeds("pgrep marco") + machine.wait_for_window("marco") + machine.wait_until_succeeds("pgrep mate-panel") + machine.wait_for_window("Top Panel") + machine.wait_for_window("Bottom Panel") + machine.wait_until_succeeds("pgrep caja") + machine.wait_for_window("Caja") + machine.wait_for_text('(Applications|Places|System)') + machine.wait_for_text('(Computer|Home|Trash)') - with subtest("Check if various environment variables are set"): - machine.succeed("xargs --null --max-args=1 echo < /proc/$(pgrep -xf marco)/environ | grep 'XDG_CURRENT_DESKTOP' | grep 'MATE'") - # From mate-panel-with-applets packaging - machine.succeed("xargs --null --max-args=1 echo < /proc/$(pgrep -xf mate-panel)/environ | grep 'MATE_PANEL_APPLETS_DIR' | grep '${pkgs.mate.mate-panel-with-applets.pname}'") + with subtest("Check if various environment variables are set"): + machine.succeed("xargs --null --max-args=1 echo < /proc/$(pgrep -xf marco)/environ | grep 'XDG_CURRENT_DESKTOP' | grep 'MATE'") + # From mate-panel-with-applets packaging + machine.succeed("xargs --null --max-args=1 echo < /proc/$(pgrep -xf mate-panel)/environ | grep 'MATE_PANEL_APPLETS_DIR' | grep '${pkgs.mate.mate-panel-with-applets.pname}'") - with subtest("Check if applets are built with in-process support"): - # This is needed for Wayland support - machine.fail("pgrep -fa clock-applet") + with subtest("Check if applets are built with in-process support"): + # This is needed for Wayland support + machine.fail("pgrep -fa clock-applet") - with subtest("Lock the screen"): - machine.wait_until_succeeds("su - ${user.name} -c '${env} mate-screensaver-command -q' | grep 'The screensaver is inactive'") - machine.succeed("su - ${user.name} -c '${env} mate-screensaver-command -l >&2 &'") - machine.wait_until_succeeds("su - ${user.name} -c '${env} mate-screensaver-command -q' | grep 'The screensaver is active'") - machine.sleep(2) - machine.send_chars("${user.password}", delay=0.2) - machine.wait_for_text("${user.description}") - machine.screenshot("screensaver") - machine.send_chars("\n") - machine.wait_until_succeeds("su - ${user.name} -c '${env} mate-screensaver-command -q' | grep 'The screensaver is inactive'") + with subtest("Lock the screen"): + machine.wait_until_succeeds("su - ${user.name} -c '${env} mate-screensaver-command -q' | grep 'The screensaver is inactive'") + machine.succeed("su - ${user.name} -c '${env} mate-screensaver-command -l >&2 &'") + machine.wait_until_succeeds("su - ${user.name} -c '${env} mate-screensaver-command -q' | grep 'The screensaver is active'") + machine.sleep(2) + machine.send_chars("${user.password}", delay=0.2) + machine.wait_for_text("${user.description}") + machine.screenshot("screensaver") + machine.send_chars("\n") + machine.wait_until_succeeds("su - ${user.name} -c '${env} mate-screensaver-command -q' | grep 'The screensaver is inactive'") - with subtest("Open MATE control center"): - machine.succeed("su - ${user.name} -c '${env} mate-control-center >&2 &'") - machine.wait_for_window("Control Center") - machine.wait_for_text('(Groups|Administration|Hardware)') + with subtest("Open MATE control center"): + machine.succeed("su - ${user.name} -c '${env} mate-control-center >&2 &'") + machine.wait_for_window("Control Center") + machine.wait_for_text('(Groups|Administration|Hardware)') - with subtest("Open MATE terminal"): - machine.succeed("su - ${user.name} -c '${env} mate-terminal >&2 &'") - machine.wait_for_window("Terminal") + with subtest("Open MATE terminal"): + machine.succeed("su - ${user.name} -c '${env} mate-terminal >&2 &'") + machine.wait_for_window("Terminal") - with subtest("Check if MATE has ever coredumped"): - machine.fail("coredumpctl --json=short | grep -E 'mate|marco|caja'") - machine.screenshot("screen") - ''; -}) + with subtest("Check if MATE has ever coredumped"): + machine.fail("coredumpctl --json=short | grep -E 'mate|marco|caja'") + machine.screenshot("screen") + ''; + } +) diff --git a/nixos/tests/matomo.nix b/nixos/tests/matomo.nix index cf54f71b738fce..f4097db6805dba 100644 --- a/nixos/tests/matomo.nix +++ b/nixos/tests/matomo.nix @@ -1,54 +1,79 @@ -{ system ? builtins.currentSystem, config ? { } -, pkgs ? import ../.. { inherit system config; } }: +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, +}: with import ../lib/testing-python.nix { inherit system pkgs; }; with pkgs.lib; let - matomoTest = package: - makeTest { - name = "matomo"; + matomoTest = + package: + makeTest { + name = "matomo"; - nodes.machine = { config, pkgs, ... }: { - services.matomo = { - package = package; - enable = true; - nginx = { - forceSSL = false; - enableACME = false; + nodes.machine = + { config, pkgs, ... }: + { + services.matomo = { + package = package; + enable = true; + nginx = { + forceSSL = false; + enableACME = false; + }; + }; + services.mysql = { + enable = true; + package = pkgs.mariadb; + }; + services.nginx.enable = true; }; - }; - services.mysql = { - enable = true; - package = pkgs.mariadb; - }; - services.nginx.enable = true; - }; - testScript = '' - start_all() - machine.wait_for_unit("mysql.service") - machine.wait_for_unit("phpfpm-matomo.service") - machine.wait_for_unit("nginx.service") + testScript = '' + start_all() + machine.wait_for_unit("mysql.service") + machine.wait_for_unit("phpfpm-matomo.service") + machine.wait_for_unit("nginx.service") - # without the grep the command does not produce valid utf-8 for some reason - with subtest("welcome screen loads"): - machine.succeed( - "curl -sSfL http://localhost/ | grep 'Matomo[^<]*Installation'" - ) - ''; - }; -in { + # without the grep the command does not produce valid utf-8 for some reason + with subtest("welcome screen loads"): + machine.succeed( + "curl -sSfL http://localhost/ | grep '<title>Matomo[^<]*Installation'" + ) + ''; + }; +in +{ matomo = matomoTest pkgs.matomo // { name = "matomo"; - meta.maintainers = with maintainers; [ florianjacob mmilata twey boozedog ]; + meta.maintainers = with maintainers; [ + florianjacob + mmilata + twey + boozedog + ]; }; matomo-beta = matomoTest pkgs.matomo-beta // { name = "matomo-beta"; - meta.maintainers = with maintainers; [ florianjacob mmilata twey boozedog ]; + meta.maintainers = with maintainers; [ + florianjacob + mmilata + twey + boozedog + ]; }; matomo_5 = matomoTest pkgs.matomo_5 // { name = "matomo-5"; - meta.maintainers = with maintainers; [ florianjacob mmilata twey boozedog ] ++ lib.teams.flyingcircus.members; + meta.maintainers = + with maintainers; + [ + florianjacob + mmilata + twey + boozedog + ] + ++ lib.teams.flyingcircus.members; }; } diff --git a/nixos/tests/matrix/appservice-irc.nix b/nixos/tests/matrix/appservice-irc.nix index 41a6b005064fdb..a44712cb987253 100644 --- a/nixos/tests/matrix/appservice-irc.nix +++ b/nixos/tests/matrix/appservice-irc.nix @@ -1,72 +1,79 @@ { pkgs, ... }: - let - homeserverUrl = "http://homeserver:8008"; - in - { - name = "matrix-appservice-irc"; - meta = { - maintainers = pkgs.matrix-appservice-irc.meta.maintainers; - }; - - nodes = { - homeserver = { - # We'll switch to this once the config is copied into place - specialisation.running.configuration = { - services.matrix-synapse = { - enable = true; - settings = { - database.name = "sqlite3"; - app_service_config_files = [ "/registration.yml" ]; +let + homeserverUrl = "http://homeserver:8008"; +in +{ + name = "matrix-appservice-irc"; + meta = { + maintainers = pkgs.matrix-appservice-irc.meta.maintainers; + }; + + nodes = { + homeserver = { + # We'll switch to this once the config is copied into place + specialisation.running.configuration = { + services.matrix-synapse = { + enable = true; + settings = { + database.name = "sqlite3"; + app_service_config_files = [ "/registration.yml" ]; - enable_registration = true; + enable_registration = true; - # don't use this in production, always use some form of verification - enable_registration_without_verification = true; + # don't use this in production, always use some form of verification + enable_registration_without_verification = true; - listeners = [ { + listeners = [ + { # The default but tls=false bind_addresses = [ "0.0.0.0" ]; port = 8008; - resources = [ { - "compress" = true; - "names" = [ "client" ]; - } { - "compress" = false; - "names" = [ "federation" ]; - } ]; + resources = [ + { + "compress" = true; + "names" = [ "client" ]; + } + { + "compress" = false; + "names" = [ "federation" ]; + } + ]; tls = false; type = "http"; - } ]; - }; + } + ]; }; - - networking.firewall.allowedTCPPorts = [ 8008 ]; }; + + networking.firewall.allowedTCPPorts = [ 8008 ]; }; + }; - ircd = { - services.ngircd = { - enable = true; - config = '' - [Global] - Name = ircd.ircd - Info = Server Info Text - AdminInfo1 = _ - - [Channel] - Name = #test - Topic = a cool place - - [Options] - PAM = no - ''; - }; - networking.firewall.allowedTCPPorts = [ 6667 ]; + ircd = { + services.ngircd = { + enable = true; + config = '' + [Global] + Name = ircd.ircd + Info = Server Info Text + AdminInfo1 = _ + + [Channel] + Name = #test + Topic = a cool place + + [Options] + PAM = no + ''; }; + networking.firewall.allowedTCPPorts = [ 6667 ]; + }; - appservice = { pkgs, ... }: { + appservice = + { pkgs, ... }: + { services.matrix-appservice-irc = { enable = true; registrationUrl = "http://appservice:8009"; @@ -95,18 +102,21 @@ networking.firewall.allowedTCPPorts = [ 8009 ]; }; - client = { pkgs, ... }: { + client = + { pkgs, ... }: + { environment.systemPackages = [ (pkgs.writers.writePython3Bin "do_test" - { - libraries = [ pkgs.python3Packages.matrix-nio ]; - flakeIgnore = [ - # We don't live in the dark ages anymore. - # Languages like Python that are whitespace heavy will overrun - # 79 characters.. - "E501" - ]; - } '' + { + libraries = [ pkgs.python3Packages.matrix-nio ]; + flakeIgnore = [ + # We don't live in the dark ages anymore. + # Languages like Python that are whitespace heavy will overrun + # 79 characters.. + "E501" + ]; + } + '' import sys import socket import functools @@ -195,39 +205,39 @@ ) ]; }; - }; - - testScript = '' - import pathlib - import os - - start_all() - - ircd.wait_for_unit("ngircd.service") - ircd.wait_for_open_port(6667) - - with subtest("start the appservice"): - appservice.wait_for_unit("matrix-appservice-irc.service") - appservice.wait_for_open_port(8009) - appservice.wait_for_file("/var/lib/matrix-appservice-irc/media-signingkey.jwk") - appservice.wait_for_open_port(11111) - - with subtest("copy the registration file"): - appservice.copy_from_vm("/var/lib/matrix-appservice-irc/registration.yml") - homeserver.copy_from_host( - str(pathlib.Path(os.environ.get("out", os.getcwd())) / "registration.yml"), "/" - ) - homeserver.succeed("chmod 444 /registration.yml") - - with subtest("start the homeserver"): - homeserver.succeed( - "/run/current-system/specialisation/running/bin/switch-to-configuration test >&2" - ) - - homeserver.wait_for_unit("matrix-synapse.service") - homeserver.wait_for_open_port(8008) - - with subtest("ensure messages can be exchanged"): - client.succeed("do_test ${homeserverUrl} >&2") - ''; - } + }; + + testScript = '' + import pathlib + import os + + start_all() + + ircd.wait_for_unit("ngircd.service") + ircd.wait_for_open_port(6667) + + with subtest("start the appservice"): + appservice.wait_for_unit("matrix-appservice-irc.service") + appservice.wait_for_open_port(8009) + appservice.wait_for_file("/var/lib/matrix-appservice-irc/media-signingkey.jwk") + appservice.wait_for_open_port(11111) + + with subtest("copy the registration file"): + appservice.copy_from_vm("/var/lib/matrix-appservice-irc/registration.yml") + homeserver.copy_from_host( + str(pathlib.Path(os.environ.get("out", os.getcwd())) / "registration.yml"), "/" + ) + homeserver.succeed("chmod 444 /registration.yml") + + with subtest("start the homeserver"): + homeserver.succeed( + "/run/current-system/specialisation/running/bin/switch-to-configuration test >&2" + ) + + homeserver.wait_for_unit("matrix-synapse.service") + homeserver.wait_for_open_port(8008) + + with subtest("ensure messages can be exchanged"): + client.succeed("do_test ${homeserverUrl} >&2") + ''; +} diff --git a/nixos/tests/matrix/conduit.nix b/nixos/tests/matrix/conduit.nix index 2b81c23598eba1..b38549b23ab45f 100644 --- a/nixos/tests/matrix/conduit.nix +++ b/nixos/tests/matrix/conduit.nix @@ -1,4 +1,5 @@ -import ../make-test-python.nix ({ pkgs, ... }: +import ../make-test-python.nix ( + { pkgs, ... }: let name = "conduit"; in @@ -27,11 +28,11 @@ import ../make-test-python.nix ({ pkgs, ... }: }; networking.firewall.allowedTCPPorts = [ 80 ]; }; - client = { pkgs, ... }: { - environment.systemPackages = [ - ( - pkgs.writers.writePython3Bin "do_test" - { libraries = [ pkgs.python3Packages.matrix-nio ]; } '' + client = + { pkgs, ... }: + { + environment.systemPackages = [ + (pkgs.writers.writePython3Bin "do_test" { libraries = [ pkgs.python3Packages.matrix-nio ]; } '' import asyncio from nio import AsyncClient @@ -78,10 +79,9 @@ import ../make-test-python.nix ({ pkgs, ... }: await client.close() asyncio.get_event_loop().run_until_complete(main()) - '' - ) - ]; - }; + '') + ]; + }; }; testScript = '' @@ -94,4 +94,5 @@ import ../make-test-python.nix ({ pkgs, ... }: with subtest("ensure messages can be exchanged"): client.succeed("do_test") ''; - }) + } +) diff --git a/nixos/tests/matrix/dendrite.nix b/nixos/tests/matrix/dendrite.nix index 82e71d912130dc..9796423a5bb744 100644 --- a/nixos/tests/matrix/dendrite.nix +++ b/nixos/tests/matrix/dendrite.nix @@ -1,101 +1,102 @@ import ../make-test-python.nix ( { pkgs, ... }: - let - homeserverUrl = "http://homeserver:8008"; - - private_key = pkgs.runCommand "matrix_key.pem" { - buildInputs = [ pkgs.dendrite ]; - } "generate-keys --private-key $out"; - in - { - name = "dendrite"; - meta = with pkgs.lib; { - maintainers = teams.matrix.members; - }; - - nodes = { - homeserver = { pkgs, ... }: { - services.dendrite = { - enable = true; - loadCredential = [ "test_private_key:${private_key}" ]; - openRegistration = true; - settings = { - global.server_name = "test-dendrite-server.com"; - global.private_key = "$CREDENTIALS_DIRECTORY/test_private_key"; - client_api.registration_disabled = false; - }; + let + homeserverUrl = "http://homeserver:8008"; + + private_key = pkgs.runCommand "matrix_key.pem" { + buildInputs = [ pkgs.dendrite ]; + } "generate-keys --private-key $out"; + in + { + name = "dendrite"; + meta = with pkgs.lib; { + maintainers = teams.matrix.members; + }; + + nodes = { + homeserver = + { pkgs, ... }: + { + services.dendrite = { + enable = true; + loadCredential = [ "test_private_key:${private_key}" ]; + openRegistration = true; + settings = { + global.server_name = "test-dendrite-server.com"; + global.private_key = "$CREDENTIALS_DIRECTORY/test_private_key"; + client_api.registration_disabled = false; }; - - networking.firewall.allowedTCPPorts = [ 8008 ]; }; - client = { pkgs, ... }: { - environment.systemPackages = [ - ( - pkgs.writers.writePython3Bin "do_test" - { libraries = [ pkgs.python3Packages.matrix-nio ]; } '' - import asyncio + networking.firewall.allowedTCPPorts = [ 8008 ]; + }; - from nio import AsyncClient + client = + { pkgs, ... }: + { + environment.systemPackages = [ + (pkgs.writers.writePython3Bin "do_test" { libraries = [ pkgs.python3Packages.matrix-nio ]; } '' + import asyncio + from nio import AsyncClient - async def main() -> None: - # Connect to dendrite - client = AsyncClient("http://homeserver:8008", "alice") - # Register as user alice - response = await client.register("alice", "my-secret-password") + async def main() -> None: + # Connect to dendrite + client = AsyncClient("http://homeserver:8008", "alice") - # Log in as user alice - response = await client.login("my-secret-password") + # Register as user alice + response = await client.register("alice", "my-secret-password") - # Create a new room - response = await client.room_create(federate=False) - room_id = response.room_id + # Log in as user alice + response = await client.login("my-secret-password") - # Join the room - response = await client.join(room_id) + # Create a new room + response = await client.room_create(federate=False) + room_id = response.room_id - # Send a message to the room - response = await client.room_send( - room_id=room_id, - message_type="m.room.message", - content={ - "msgtype": "m.text", - "body": "Hello world!" - } - ) + # Join the room + response = await client.join(room_id) - # Sync responses - response = await client.sync(timeout=30000) + # Send a message to the room + response = await client.room_send( + room_id=room_id, + message_type="m.room.message", + content={ + "msgtype": "m.text", + "body": "Hello world!" + } + ) - # Check the message was received by dendrite - last_message = response.rooms.join[room_id].timeline.events[-1].body - assert last_message == "Hello world!" + # Sync responses + response = await client.sync(timeout=30000) - # Leave the room - response = await client.room_leave(room_id) + # Check the message was received by dendrite + last_message = response.rooms.join[room_id].timeline.events[-1].body + assert last_message == "Hello world!" - # Close the client - await client.close() + # Leave the room + response = await client.room_leave(room_id) - asyncio.get_event_loop().run_until_complete(main()) - '' - ) - ]; - }; + # Close the client + await client.close() + + asyncio.get_event_loop().run_until_complete(main()) + '') + ]; }; + }; - testScript = '' - start_all() + testScript = '' + start_all() - with subtest("start the homeserver"): - homeserver.wait_for_unit("dendrite.service") - homeserver.wait_for_open_port(8008) + with subtest("start the homeserver"): + homeserver.wait_for_unit("dendrite.service") + homeserver.wait_for_open_port(8008) - with subtest("ensure messages can be exchanged"): - client.succeed("do_test") - ''; + with subtest("ensure messages can be exchanged"): + client.succeed("do_test") + ''; - } + } ) diff --git a/nixos/tests/matrix/mautrix-meta-postgres.nix b/nixos/tests/matrix/mautrix-meta-postgres.nix index c9a45788afaf64..99ed56477df32f 100644 --- a/nixos/tests/matrix/mautrix-meta-postgres.nix +++ b/nixos/tests/matrix/mautrix-meta-postgres.nix @@ -1,4 +1,5 @@ -import ../make-test-python.nix ({ pkgs, ... }: +import ../make-test-python.nix ( + { pkgs, ... }: let homeserverDomain = "server"; homeserverUrl = "http://server:8008"; @@ -13,145 +14,158 @@ import ../make-test-python.nix ({ pkgs, ... }: meta.maintainers = pkgs.mautrix-meta.meta.maintainers; nodes = { - server = { config, pkgs, ... }: { - services.postgresql = { - enable = true; - - ensureUsers = [ - { - name = "mautrix-meta-instagram"; - ensureDBOwnership = true; - } - ]; - - ensureDatabases = [ - "mautrix-meta-instagram" - ]; - }; - - systemd.services.mautrix-meta-instagram = { - wants = [ "postgres.service" ]; - after = [ "postgres.service" ]; - }; - - services.matrix-synapse = { - enable = true; - settings = { - database.name = "sqlite3"; + server = + { config, pkgs, ... }: + { + services.postgresql = { + enable = true; + + ensureUsers = [ + { + name = "mautrix-meta-instagram"; + ensureDBOwnership = true; + } + ]; - enable_registration = true; + ensureDatabases = [ + "mautrix-meta-instagram" + ]; + }; - # don't use this in production, always use some form of verification - enable_registration_without_verification = true; + systemd.services.mautrix-meta-instagram = { + wants = [ "postgres.service" ]; + after = [ "postgres.service" ]; + }; - listeners = [ { - # The default but tls=false - bind_addresses = [ - "0.0.0.0" + services.matrix-synapse = { + enable = true; + settings = { + database.name = "sqlite3"; + + enable_registration = true; + + # don't use this in production, always use some form of verification + enable_registration_without_verification = true; + + listeners = [ + { + # The default but tls=false + bind_addresses = [ + "0.0.0.0" + ]; + port = 8008; + resources = [ + { + "compress" = true; + "names" = [ "client" ]; + } + { + "compress" = false; + "names" = [ "federation" ]; + } + ]; + tls = false; + type = "http"; + } ]; - port = 8008; - resources = [ { - "compress" = true; - "names" = [ "client" ]; - } { - "compress" = false; - "names" = [ "federation" ]; - } ]; - tls = false; - type = "http"; - } ]; + }; }; - }; - services.mautrix-meta.instances.instagram = { - enable = true; + services.mautrix-meta.instances.instagram = { + enable = true; - environmentFile = pkgs.writeText ''my-secrets'' '' - AS_TOKEN=${asToken} - HS_TOKEN=${hsToken} - ''; + environmentFile = pkgs.writeText ''my-secrets'' '' + AS_TOKEN=${asToken} + HS_TOKEN=${hsToken} + ''; - settings = { - homeserver = { - address = homeserverUrl; - domain = homeserverDomain; - }; + settings = { + homeserver = { + address = homeserverUrl; + domain = homeserverDomain; + }; - appservice = { - port = 8009; + appservice = { + port = 8009; - as_token = "$AS_TOKEN"; - hs_token = "$HS_TOKEN"; + as_token = "$AS_TOKEN"; + hs_token = "$HS_TOKEN"; - database = { - type = "postgres"; - uri = "postgres:///mautrix-meta-instagram?host=/var/run/postgresql"; + database = { + type = "postgres"; + uri = "postgres:///mautrix-meta-instagram?host=/var/run/postgresql"; + }; + + bot.username = botUserName; }; - bot.username = botUserName; + bridge.permissions."@${userName}:server" = "user"; }; - - bridge.permissions."@${userName}:server" = "user"; }; - }; - - networking.firewall.allowedTCPPorts = [ 8008 8009 ]; - }; - - client = { pkgs, ... }: { - environment.systemPackages = [ - (pkgs.writers.writePython3Bin "do_test" - { - libraries = [ pkgs.python3Packages.matrix-nio ]; - flakeIgnore = [ - # We don't live in the dark ages anymore. - # Languages like Python that are whitespace heavy will overrun - # 79 characters.. - "E501" - ]; - } '' - import sys - import functools - import asyncio - - from nio import AsyncClient, RoomMessageNotice, RoomCreateResponse, RoomInviteResponse - - - async def message_callback(matrix: AsyncClient, msg: str, _r, e): - print("Received matrix text message: ", e) - assert msg in e.body - exit(0) # Success! - - - async def run(homeserver: str): - matrix = AsyncClient(homeserver) - response = await matrix.register("${userName}", "foobar") - print("Matrix register response: ", response) - - # Open a DM with the bridge bot - response = await matrix.room_create() - print("Matrix create room response:", response) - assert isinstance(response, RoomCreateResponse) - room_id = response.room_id - - response = await matrix.room_invite(room_id, "@${botUserName}:${homeserverDomain}") - assert isinstance(response, RoomInviteResponse) - - callback = functools.partial( - message_callback, matrix, "Hello, I'm an Instagram bridge bot." - ) - matrix.add_event_callback(callback, RoomMessageNotice) - - print("Waiting for matrix message...") - await matrix.sync_forever(timeout=30000) + networking.firewall.allowedTCPPorts = [ + 8008 + 8009 + ]; + }; - if __name__ == "__main__": - asyncio.run(run(sys.argv[1])) - '' - ) - ]; - }; + client = + { pkgs, ... }: + { + environment.systemPackages = [ + (pkgs.writers.writePython3Bin "do_test" + { + libraries = [ pkgs.python3Packages.matrix-nio ]; + flakeIgnore = [ + # We don't live in the dark ages anymore. + # Languages like Python that are whitespace heavy will overrun + # 79 characters.. + "E501" + ]; + } + '' + import sys + import functools + import asyncio + + from nio import AsyncClient, RoomMessageNotice, RoomCreateResponse, RoomInviteResponse + + + async def message_callback(matrix: AsyncClient, msg: str, _r, e): + print("Received matrix text message: ", e) + assert msg in e.body + exit(0) # Success! + + + async def run(homeserver: str): + matrix = AsyncClient(homeserver) + response = await matrix.register("${userName}", "foobar") + print("Matrix register response: ", response) + + # Open a DM with the bridge bot + response = await matrix.room_create() + print("Matrix create room response:", response) + assert isinstance(response, RoomCreateResponse) + room_id = response.room_id + + response = await matrix.room_invite(room_id, "@${botUserName}:${homeserverDomain}") + assert isinstance(response, RoomInviteResponse) + + callback = functools.partial( + message_callback, matrix, "Hello, I'm an Instagram bridge bot." + ) + matrix.add_event_callback(callback, RoomMessageNotice) + + print("Waiting for matrix message...") + await matrix.sync_forever(timeout=30000) + + + if __name__ == "__main__": + asyncio.run(run(sys.argv[1])) + '' + ) + ]; + }; }; testScript = '' @@ -218,4 +232,5 @@ import ../make-test-python.nix ({ pkgs, ... }: assert as_token_registration == expected_as_token, f"as_token in registration should match the one specified (is: {as_token_registration}, expected: {expected_as_token})" assert hs_token_registration == expected_hs_token, f"hs_token in registration should match the one specified (is: {hs_token_registration}, expected: {expected_hs_token})" ''; - }) + } +) diff --git a/nixos/tests/matrix/mautrix-meta-sqlite.nix b/nixos/tests/matrix/mautrix-meta-sqlite.nix index b5e580620049a1..ddd38e8f0b0082 100644 --- a/nixos/tests/matrix/mautrix-meta-sqlite.nix +++ b/nixos/tests/matrix/mautrix-meta-sqlite.nix @@ -1,4 +1,5 @@ -import ../make-test-python.nix ({ pkgs, ... }: +import ../make-test-python.nix ( + { pkgs, ... }: let homeserverDomain = "server"; homeserverUrl = "http://server:8008"; @@ -11,159 +12,170 @@ import ../make-test-python.nix ({ pkgs, ... }: meta.maintainers = pkgs.mautrix-meta.meta.maintainers; nodes = { - server = { config, pkgs, ... }: { - services.matrix-synapse = { - enable = true; - settings = { - database.name = "sqlite3"; - - enable_registration = true; - - # don't use this in production, always use some form of verification - enable_registration_without_verification = true; - - listeners = [ { - # The default but tls=false - bind_addresses = [ - "0.0.0.0" + server = + { config, pkgs, ... }: + { + services.matrix-synapse = { + enable = true; + settings = { + database.name = "sqlite3"; + + enable_registration = true; + + # don't use this in production, always use some form of verification + enable_registration_without_verification = true; + + listeners = [ + { + # The default but tls=false + bind_addresses = [ + "0.0.0.0" + ]; + port = 8008; + resources = [ + { + "compress" = true; + "names" = [ "client" ]; + } + { + "compress" = false; + "names" = [ "federation" ]; + } + ]; + tls = false; + type = "http"; + } ]; - port = 8008; - resources = [ { - "compress" = true; - "names" = [ "client" ]; - } { - "compress" = false; - "names" = [ "federation" ]; - } ]; - tls = false; - type = "http"; - } ]; + }; }; - }; - services.mautrix-meta.instances.facebook = { - enable = true; + services.mautrix-meta.instances.facebook = { + enable = true; - settings = { - homeserver = { - address = homeserverUrl; - domain = homeserverDomain; - }; + settings = { + homeserver = { + address = homeserverUrl; + domain = homeserverDomain; + }; - appservice = { - port = 8009; + appservice = { + port = 8009; - bot.username = facebookBotUsername; - }; + bot.username = facebookBotUsername; + }; - bridge.permissions."@${username}:server" = "user"; + bridge.permissions."@${username}:server" = "user"; + }; }; - }; - services.mautrix-meta.instances.instagram = { - enable = true; + services.mautrix-meta.instances.instagram = { + enable = true; - settings = { - homeserver = { - address = homeserverUrl; - domain = homeserverDomain; - }; + settings = { + homeserver = { + address = homeserverUrl; + domain = homeserverDomain; + }; - appservice = { - port = 8010; + appservice = { + port = 8010; - bot.username = instagramBotUsername; - }; + bot.username = instagramBotUsername; + }; - bridge.permissions."@${username}:server" = "user"; + bridge.permissions."@${username}:server" = "user"; + }; }; + + networking.firewall.allowedTCPPorts = [ 8008 ]; }; - networking.firewall.allowedTCPPorts = [ 8008 ]; - }; - - client = { pkgs, ... }: { - environment.systemPackages = [ - (pkgs.writers.writePython3Bin "register_user" - { - libraries = [ pkgs.python3Packages.matrix-nio ]; - flakeIgnore = [ - # We don't live in the dark ages anymore. - # Languages like Python that are whitespace heavy will overrun - # 79 characters.. - "E501" - ]; - } '' - import sys - import asyncio - - from nio import AsyncClient - - - async def run(username: str, homeserver: str): - matrix = AsyncClient(homeserver) - - response = await matrix.register(username, "foobar") - print("Matrix register response: ", response) - - - if __name__ == "__main__": - asyncio.run(run(sys.argv[1], sys.argv[2])) - '' - ) - (pkgs.writers.writePython3Bin "do_test" - { - libraries = [ pkgs.python3Packages.matrix-nio ]; - flakeIgnore = [ - # We don't live in the dark ages anymore. - # Languages like Python that are whitespace heavy will overrun - # 79 characters.. - "E501" - ]; - } '' - import sys - import functools - import asyncio - - from nio import AsyncClient, RoomMessageNotice, RoomCreateResponse, RoomInviteResponse - - - async def message_callback(matrix: AsyncClient, msg: str, _r, e): - print("Received matrix text message: ", e) - assert msg in e.body - exit(0) # Success! - - - async def run(username: str, bot_username: str, homeserver: str): - matrix = AsyncClient(homeserver, f"@{username}:${homeserverDomain}") - - response = await matrix.login("foobar") - print("Matrix login response: ", response) - - # Open a DM with the bridge bot - response = await matrix.room_create() - print("Matrix create room response:", response) - assert isinstance(response, RoomCreateResponse) - room_id = response.room_id - - response = await matrix.room_invite(room_id, f"@{bot_username}:${homeserverDomain}") - assert isinstance(response, RoomInviteResponse) - - callback = functools.partial( - message_callback, matrix, "Hello, I'm an Instagram bridge bot." - ) - matrix.add_event_callback(callback, RoomMessageNotice) - - print("Waiting for matrix message...") - await matrix.sync_forever(timeout=30000) - - - if __name__ == "__main__": - asyncio.run(run(sys.argv[1], sys.argv[2], sys.argv[3])) - '' - ) - ]; - }; + client = + { pkgs, ... }: + { + environment.systemPackages = [ + (pkgs.writers.writePython3Bin "register_user" + { + libraries = [ pkgs.python3Packages.matrix-nio ]; + flakeIgnore = [ + # We don't live in the dark ages anymore. + # Languages like Python that are whitespace heavy will overrun + # 79 characters.. + "E501" + ]; + } + '' + import sys + import asyncio + + from nio import AsyncClient + + + async def run(username: str, homeserver: str): + matrix = AsyncClient(homeserver) + + response = await matrix.register(username, "foobar") + print("Matrix register response: ", response) + + + if __name__ == "__main__": + asyncio.run(run(sys.argv[1], sys.argv[2])) + '' + ) + (pkgs.writers.writePython3Bin "do_test" + { + libraries = [ pkgs.python3Packages.matrix-nio ]; + flakeIgnore = [ + # We don't live in the dark ages anymore. + # Languages like Python that are whitespace heavy will overrun + # 79 characters.. + "E501" + ]; + } + '' + import sys + import functools + import asyncio + + from nio import AsyncClient, RoomMessageNotice, RoomCreateResponse, RoomInviteResponse + + + async def message_callback(matrix: AsyncClient, msg: str, _r, e): + print("Received matrix text message: ", e) + assert msg in e.body + exit(0) # Success! + + + async def run(username: str, bot_username: str, homeserver: str): + matrix = AsyncClient(homeserver, f"@{username}:${homeserverDomain}") + + response = await matrix.login("foobar") + print("Matrix login response: ", response) + + # Open a DM with the bridge bot + response = await matrix.room_create() + print("Matrix create room response:", response) + assert isinstance(response, RoomCreateResponse) + room_id = response.room_id + + response = await matrix.room_invite(room_id, f"@{bot_username}:${homeserverDomain}") + assert isinstance(response, RoomInviteResponse) + + callback = functools.partial( + message_callback, matrix, "Hello, I'm an Instagram bridge bot." + ) + matrix.add_event_callback(callback, RoomMessageNotice) + + print("Waiting for matrix message...") + await matrix.sync_forever(timeout=30000) + + + if __name__ == "__main__": + asyncio.run(run(sys.argv[1], sys.argv[2], sys.argv[3])) + '' + ) + ]; + }; }; testScript = '' @@ -244,4 +256,5 @@ import ../make-test-python.nix ({ pkgs, ... }: client.succeed("do_test ${username} ${instagramBotUsername} ${homeserverUrl} >&2") client.succeed("do_test ${username} ${facebookBotUsername} ${homeserverUrl} >&2") ''; - }) + } +) diff --git a/nixos/tests/matrix/mjolnir.nix b/nixos/tests/matrix/mjolnir.nix index 265b13821ebd83..67a53d045c2e14 100644 --- a/nixos/tests/matrix/mjolnir.nix +++ b/nixos/tests/matrix/mjolnir.nix @@ -2,11 +2,11 @@ import ../make-test-python.nix ( { pkgs, ... }: let # Set up SSL certs for Synapse to be happy. - runWithOpenSSL = file: cmd: pkgs.runCommand file - { + runWithOpenSSL = + file: cmd: + pkgs.runCommand file { buildInputs = [ pkgs.openssl ]; - } - cmd; + } cmd; ca_key = runWithOpenSSL "ca-key.pem" "openssl genrsa -out $out 2048"; ca_pem = runWithOpenSSL "ca.pem" '' @@ -35,110 +35,121 @@ import ../make-test-python.nix ( }; nodes = { - homeserver = { pkgs, ... }: { - services.matrix-synapse = { - enable = true; - settings = { - database.name = "sqlite3"; - tls_certificate_path = "${cert}"; - tls_private_key_path = "${key}"; - enable_registration = true; - enable_registration_without_verification = true; - registration_shared_secret = "supersecret-registration"; - - listeners = [ { - # The default but tls=false - bind_addresses = [ - "0.0.0.0" + homeserver = + { pkgs, ... }: + { + services.matrix-synapse = { + enable = true; + settings = { + database.name = "sqlite3"; + tls_certificate_path = "${cert}"; + tls_private_key_path = "${key}"; + enable_registration = true; + enable_registration_without_verification = true; + registration_shared_secret = "supersecret-registration"; + + listeners = [ + { + # The default but tls=false + bind_addresses = [ + "0.0.0.0" + ]; + port = 8448; + resources = [ + { + compress = true; + names = [ "client" ]; + } + { + compress = false; + names = [ "federation" ]; + } + ]; + tls = false; + type = "http"; + x_forwarded = false; + } ]; - port = 8448; - resources = [ { - compress = true; - names = [ "client" ]; - } { - compress = false; - names = [ "federation" ]; - } ]; - tls = false; - type = "http"; - x_forwarded = false; - } ]; + }; }; + + networking.firewall.allowedTCPPorts = [ 8448 ]; + + environment.systemPackages = [ + (pkgs.writeShellScriptBin "register_mjolnir_user" '' + exec ${pkgs.matrix-synapse}/bin/register_new_matrix_user \ + -u mjolnir \ + -p mjolnir-password \ + --admin \ + --shared-secret supersecret-registration \ + http://localhost:8448 + '') + (pkgs.writeShellScriptBin "register_moderator_user" '' + exec ${pkgs.matrix-synapse}/bin/register_new_matrix_user \ + -u moderator \ + -p moderator-password \ + --no-admin \ + --shared-secret supersecret-registration \ + http://localhost:8448 + '') + ]; }; - networking.firewall.allowedTCPPorts = [ 8448 ]; - - environment.systemPackages = [ - (pkgs.writeShellScriptBin "register_mjolnir_user" '' - exec ${pkgs.matrix-synapse}/bin/register_new_matrix_user \ - -u mjolnir \ - -p mjolnir-password \ - --admin \ - --shared-secret supersecret-registration \ - http://localhost:8448 - '' - ) - (pkgs.writeShellScriptBin "register_moderator_user" '' - exec ${pkgs.matrix-synapse}/bin/register_new_matrix_user \ - -u moderator \ - -p moderator-password \ - --no-admin \ - --shared-secret supersecret-registration \ - http://localhost:8448 - '' - ) - ]; - }; - - mjolnir = { pkgs, ... }: { - services.mjolnir = { - enable = true; - homeserverUrl = "http://homeserver:8448"; - pantalaimon = { + mjolnir = + { pkgs, ... }: + { + services.mjolnir = { enable = true; - username = "mjolnir"; - passwordFile = pkgs.writeText "password.txt" "mjolnir-password"; - # otherwise mjolnir tries to connect to ::1, which is not listened by pantalaimon - options.listenAddress = "127.0.0.1"; + homeserverUrl = "http://homeserver:8448"; + pantalaimon = { + enable = true; + username = "mjolnir"; + passwordFile = pkgs.writeText "password.txt" "mjolnir-password"; + # otherwise mjolnir tries to connect to ::1, which is not listened by pantalaimon + options.listenAddress = "127.0.0.1"; + }; + managementRoom = "#moderators:homeserver"; }; - managementRoom = "#moderators:homeserver"; }; - }; - client = { pkgs, ... }: { - environment.systemPackages = [ - (pkgs.writers.writePython3Bin "create_management_room_and_invite_mjolnir" - { libraries = with pkgs.python3Packages; [ - (matrix-nio.override { withOlm = true; }) - ]; - } '' - import asyncio - - from nio import ( - AsyncClient, - EnableEncryptionBuilder - ) + client = + { pkgs, ... }: + { + environment.systemPackages = [ + (pkgs.writers.writePython3Bin "create_management_room_and_invite_mjolnir" + { + libraries = with pkgs.python3Packages; [ + (matrix-nio.override { withOlm = true; }) + ]; + } + '' + import asyncio + + from nio import ( + AsyncClient, + EnableEncryptionBuilder + ) - async def main() -> None: - client = AsyncClient("http://homeserver:8448", "moderator") + async def main() -> None: + client = AsyncClient("http://homeserver:8448", "moderator") - await client.login("moderator-password") + await client.login("moderator-password") - room = await client.room_create( - name="Moderators", - alias="moderators", - initial_state=[EnableEncryptionBuilder().as_dict()], - ) + room = await client.room_create( + name="Moderators", + alias="moderators", + initial_state=[EnableEncryptionBuilder().as_dict()], + ) - await client.join(room.room_id) - await client.room_invite(room.room_id, "@mjolnir:homeserver") + await client.join(room.room_id) + await client.room_invite(room.room_id, "@mjolnir:homeserver") - asyncio.run(main()) - '' - ) - ]; - }; + asyncio.run(main()) + '' + ) + ]; + }; }; testScript = '' diff --git a/nixos/tests/matrix/pantalaimon.nix b/nixos/tests/matrix/pantalaimon.nix index b5d649e6517aa5..6ff4cf8cda064e 100644 --- a/nixos/tests/matrix/pantalaimon.nix +++ b/nixos/tests/matrix/pantalaimon.nix @@ -4,11 +4,11 @@ import ../make-test-python.nix ( pantalaimonInstanceName = "testing"; # Set up SSL certs for Synapse to be happy. - runWithOpenSSL = file: cmd: pkgs.runCommand file - { + runWithOpenSSL = + file: cmd: + pkgs.runCommand file { buildInputs = [ pkgs.openssl ]; - } - cmd; + } cmd; ca_key = runWithOpenSSL "ca-key.pem" "openssl genrsa -out $out 2048"; ca_pem = runWithOpenSSL "ca.pem" '' @@ -36,45 +36,52 @@ import ../make-test-python.nix ( maintainers = teams.matrix.members; }; - nodes.machine = { pkgs, ... }: { - services.pantalaimon-headless.instances.${pantalaimonInstanceName} = { - homeserver = "https://localhost:8448"; - listenAddress = "0.0.0.0"; - listenPort = 8888; - logLevel = "debug"; - ssl = false; - }; + nodes.machine = + { pkgs, ... }: + { + services.pantalaimon-headless.instances.${pantalaimonInstanceName} = { + homeserver = "https://localhost:8448"; + listenAddress = "0.0.0.0"; + listenPort = 8888; + logLevel = "debug"; + ssl = false; + }; - services.matrix-synapse = { - enable = true; - settings = { - listeners = [ { - port = 8448; - bind_addresses = [ - "127.0.0.1" - "::1" + services.matrix-synapse = { + enable = true; + settings = { + listeners = [ + { + port = 8448; + bind_addresses = [ + "127.0.0.1" + "::1" + ]; + type = "http"; + tls = true; + x_forwarded = false; + resources = [ + { + names = [ + "client" + ]; + compress = true; + } + { + names = [ + "federation" + ]; + compress = false; + } + ]; + } ]; - type = "http"; - tls = true; - x_forwarded = false; - resources = [ { - names = [ - "client" - ]; - compress = true; - } { - names = [ - "federation" - ]; - compress = false; - } ]; - } ]; - database.name = "sqlite3"; - tls_certificate_path = "${cert}"; - tls_private_key_path = "${key}"; + database.name = "sqlite3"; + tls_certificate_path = "${cert}"; + tls_private_key_path = "${key}"; + }; }; }; - }; testScript = '' start_all() diff --git a/nixos/tests/matrix/synapse-workers.nix b/nixos/tests/matrix/synapse-workers.nix index e90301aeae9e4a..10b72da70d43a9 100644 --- a/nixos/tests/matrix/synapse-workers.nix +++ b/nixos/tests/matrix/synapse-workers.nix @@ -1,50 +1,55 @@ -import ../make-test-python.nix ({ pkgs, ... }: { - name = "matrix-synapse-workers"; - meta = with pkgs.lib; { - maintainers = teams.matrix.members; - }; +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "matrix-synapse-workers"; + meta = with pkgs.lib; { + maintainers = teams.matrix.members; + }; - nodes = { - homeserver = - { pkgs - , nodes - , ... - }: { - services.postgresql = { - enable = true; - initialScript = pkgs.writeText "synapse-init.sql" '' - CREATE ROLE "matrix-synapse" WITH LOGIN PASSWORD 'synapse'; - CREATE DATABASE "matrix-synapse" WITH OWNER "matrix-synapse" - TEMPLATE template0 - LC_COLLATE = "C" - LC_CTYPE = "C"; - ''; - }; + nodes = { + homeserver = + { + pkgs, + nodes, + ... + }: + { + services.postgresql = { + enable = true; + initialScript = pkgs.writeText "synapse-init.sql" '' + CREATE ROLE "matrix-synapse" WITH LOGIN PASSWORD 'synapse'; + CREATE DATABASE "matrix-synapse" WITH OWNER "matrix-synapse" + TEMPLATE template0 + LC_COLLATE = "C" + LC_CTYPE = "C"; + ''; + }; - services.matrix-synapse = { - enable = true; - settings = { - database = { - name = "psycopg2"; - args.password = "synapse"; - }; - enable_registration = true; - enable_registration_without_verification = true; + services.matrix-synapse = { + enable = true; + settings = { + database = { + name = "psycopg2"; + args.password = "synapse"; + }; + enable_registration = true; + enable_registration_without_verification = true; - federation_sender_instances = [ "federation_sender" ]; - }; - configureRedisLocally = true; - workers = { - "federation_sender" = { }; + federation_sender_instances = [ "federation_sender" ]; + }; + configureRedisLocally = true; + workers = { + "federation_sender" = { }; + }; }; }; - }; - }; + }; - testScript = '' - start_all() + testScript = '' + start_all() - homeserver.wait_for_unit("matrix-synapse.service"); - homeserver.wait_for_unit("matrix-synapse-worker-federation_sender.service"); - ''; -}) + homeserver.wait_for_unit("matrix-synapse.service"); + homeserver.wait_for_unit("matrix-synapse-worker-federation_sender.service"); + ''; + } +) diff --git a/nixos/tests/matrix/synapse.nix b/nixos/tests/matrix/synapse.nix index 8c10a575ffbd30..96454491a7a485 100644 --- a/nixos/tests/matrix/synapse.nix +++ b/nixos/tests/matrix/synapse.nix @@ -1,218 +1,248 @@ -import ../make-test-python.nix ({ pkgs, ... } : let - - ca_key = mailerCerts.ca.key; - ca_pem = mailerCerts.ca.cert; - - bundle = pkgs.runCommand "bundle" { - nativeBuildInputs = [ pkgs.minica ]; - } '' - minica -ca-cert ${ca_pem} -ca-key ${ca_key} \ - -domains localhost - install -Dm444 -t $out localhost/{key,cert}.pem - ''; - - mailerCerts = import ../common/acme/server/snakeoil-certs.nix; - mailerDomain = mailerCerts.domain; - registrationSharedSecret = "unsecure123"; - testUser = "alice"; - testPassword = "alicealice"; - testEmail = "alice@example.com"; - - listeners = [ { - port = 8448; - bind_addresses = [ - "127.0.0.1" - "::1" +import ../make-test-python.nix ( + { pkgs, ... }: + let + + ca_key = mailerCerts.ca.key; + ca_pem = mailerCerts.ca.cert; + + bundle = + pkgs.runCommand "bundle" + { + nativeBuildInputs = [ pkgs.minica ]; + } + '' + minica -ca-cert ${ca_pem} -ca-key ${ca_key} \ + -domains localhost + install -Dm444 -t $out localhost/{key,cert}.pem + ''; + + mailerCerts = import ../common/acme/server/snakeoil-certs.nix; + mailerDomain = mailerCerts.domain; + registrationSharedSecret = "unsecure123"; + testUser = "alice"; + testPassword = "alicealice"; + testEmail = "alice@example.com"; + + listeners = [ + { + port = 8448; + bind_addresses = [ + "127.0.0.1" + "::1" + ]; + type = "http"; + tls = true; + x_forwarded = false; + resources = [ + { + names = [ + "client" + ]; + compress = true; + } + { + names = [ + "federation" + ]; + compress = false; + } + ]; + } ]; - type = "http"; - tls = true; - x_forwarded = false; - resources = [ { - names = [ - "client" - ]; - compress = true; - } { - names = [ - "federation" - ]; - compress = false; - } ]; - } ]; - -in { - - name = "matrix-synapse"; - meta = with pkgs.lib; { - maintainers = teams.matrix.members; - }; - - nodes = { - # Since 0.33.0, matrix-synapse doesn't allow underscores in server names - serverpostgres = { pkgs, nodes, config, ... }: let - mailserverIP = nodes.mailserver.config.networking.primaryIPAddress; - in - { - services.matrix-synapse = { - enable = true; - settings = { - inherit listeners; - database = { - name = "psycopg2"; - args.password = "synapse"; - }; - redis = { - enabled = true; - host = "localhost"; - port = config.services.redis.servers.matrix-synapse.port; + + in + { + + name = "matrix-synapse"; + meta = with pkgs.lib; { + maintainers = teams.matrix.members; + }; + + nodes = { + # Since 0.33.0, matrix-synapse doesn't allow underscores in server names + serverpostgres = + { + pkgs, + nodes, + config, + ... + }: + let + mailserverIP = nodes.mailserver.config.networking.primaryIPAddress; + in + { + services.matrix-synapse = { + enable = true; + settings = { + inherit listeners; + database = { + name = "psycopg2"; + args.password = "synapse"; + }; + redis = { + enabled = true; + host = "localhost"; + port = config.services.redis.servers.matrix-synapse.port; + }; + tls_certificate_path = "${bundle}/cert.pem"; + tls_private_key_path = "${bundle}/key.pem"; + registration_shared_secret = registrationSharedSecret; + public_baseurl = "https://example.com"; + email = { + smtp_host = mailerDomain; + smtp_port = 25; + require_transport_security = true; + notif_from = "matrix <matrix@${mailerDomain}>"; + app_name = "Matrix"; + }; + }; }; - tls_certificate_path = "${bundle}/cert.pem"; - tls_private_key_path = "${bundle}/key.pem"; - registration_shared_secret = registrationSharedSecret; - public_baseurl = "https://example.com"; - email = { - smtp_host = mailerDomain; - smtp_port = 25; - require_transport_security = true; - notif_from = "matrix <matrix@${mailerDomain}>"; - app_name = "Matrix"; + services.postgresql = { + enable = true; + + # The database name and user are configured by the following options: + # - services.matrix-synapse.database_name + # - services.matrix-synapse.database_user + # + # The values used here represent the default values of the module. + initialScript = pkgs.writeText "synapse-init.sql" '' + CREATE ROLE "matrix-synapse" WITH LOGIN PASSWORD 'synapse'; + CREATE DATABASE "matrix-synapse" WITH OWNER "matrix-synapse" + TEMPLATE template0 + LC_COLLATE = "C" + LC_CTYPE = "C"; + ''; }; - }; - }; - services.postgresql = { - enable = true; - - # The database name and user are configured by the following options: - # - services.matrix-synapse.database_name - # - services.matrix-synapse.database_user - # - # The values used here represent the default values of the module. - initialScript = pkgs.writeText "synapse-init.sql" '' - CREATE ROLE "matrix-synapse" WITH LOGIN PASSWORD 'synapse'; - CREATE DATABASE "matrix-synapse" WITH OWNER "matrix-synapse" - TEMPLATE template0 - LC_COLLATE = "C" - LC_CTYPE = "C"; - ''; - }; - services.redis.servers.matrix-synapse = { - enable = true; - port = 6380; - }; + services.redis.servers.matrix-synapse = { + enable = true; + port = 6380; + }; - networking.extraHosts = '' - ${mailserverIP} ${mailerDomain} - ''; - - security.pki.certificateFiles = [ - mailerCerts.ca.cert ca_pem - ]; - - environment.systemPackages = let - sendTestMailStarttls = pkgs.writeScriptBin "send-testmail-starttls" '' - #!${pkgs.python3.interpreter} - import smtplib - import ssl - - ctx = ssl.create_default_context() - - with smtplib.SMTP('${mailerDomain}') as smtp: - smtp.ehlo() - smtp.starttls(context=ctx) - smtp.ehlo() - smtp.sendmail('matrix@${mailerDomain}', '${testEmail}', 'Subject: Test STARTTLS\n\nTest data.') - smtp.quit() - ''; - - obtainTokenAndRegisterEmail = let - # adding the email through the API is quite complicated as it involves more than one step and some - # client-side calculation - insertEmailForAlice = pkgs.writeText "alice-email.sql" '' - INSERT INTO user_threepids (user_id, medium, address, validated_at, added_at) VALUES ('${testUser}@serverpostgres', 'email', '${testEmail}', '1629149927271', '1629149927270'); + networking.extraHosts = '' + ${mailserverIP} ${mailerDomain} ''; - in - pkgs.writeScriptBin "obtain-token-and-register-email" '' - #!${pkgs.runtimeShell} - set -o errexit - set -o pipefail - set -o nounset - su postgres -c "psql -d matrix-synapse -f ${insertEmailForAlice}" - curl --fail -XPOST 'https://localhost:8448/_matrix/client/r0/account/password/email/requestToken' -d '{"email":"${testEmail}","client_secret":"foobar","send_attempt":1}' -v - ''; - in [ sendTestMailStarttls pkgs.matrix-synapse obtainTokenAndRegisterEmail ]; - }; - # test mail delivery - mailserver = args: let - in - { - security.pki.certificateFiles = [ - mailerCerts.ca.cert - ]; - - networking.firewall.enable = false; - - services.postfix = { - enable = true; - hostname = "${mailerDomain}"; - # open relay for subnet - networksStyle = "subnet"; - enableSubmission = true; - tlsTrustedAuthorities = "${mailerCerts.ca.cert}"; - sslCert = "${mailerCerts.${mailerDomain}.cert}"; - sslKey = "${mailerCerts.${mailerDomain}.key}"; - - # blackhole transport - transport = "example.com discard:silently"; - - config = { - debug_peer_level = "10"; - smtpd_relay_restrictions = [ - "permit_mynetworks" "reject_unauth_destination" + security.pki.certificateFiles = [ + mailerCerts.ca.cert + ca_pem ]; - # disable obsolete protocols, something old versions of twisted are still using - smtpd_tls_protocols = "TLSv1.3, TLSv1.2, !TLSv1.1, !TLSv1, !SSLv2, !SSLv3"; - smtp_tls_protocols = "TLSv1.3, TLSv1.2, !TLSv1.1, !TLSv1, !SSLv2, !SSLv3"; - smtpd_tls_mandatory_protocols = "TLSv1.3, TLSv1.2, !TLSv1.1, !TLSv1, !SSLv2, !SSLv3"; - smtp_tls_mandatory_protocols = "TLSv1.3, TLSv1.2, !TLSv1.1, !TLSv1, !SSLv2, !SSLv3"; + environment.systemPackages = + let + sendTestMailStarttls = pkgs.writeScriptBin "send-testmail-starttls" '' + #!${pkgs.python3.interpreter} + import smtplib + import ssl + + ctx = ssl.create_default_context() + + with smtplib.SMTP('${mailerDomain}') as smtp: + smtp.ehlo() + smtp.starttls(context=ctx) + smtp.ehlo() + smtp.sendmail('matrix@${mailerDomain}', '${testEmail}', 'Subject: Test STARTTLS\n\nTest data.') + smtp.quit() + ''; + + obtainTokenAndRegisterEmail = + let + # adding the email through the API is quite complicated as it involves more than one step and some + # client-side calculation + insertEmailForAlice = pkgs.writeText "alice-email.sql" '' + INSERT INTO user_threepids (user_id, medium, address, validated_at, added_at) VALUES ('${testUser}@serverpostgres', 'email', '${testEmail}', '1629149927271', '1629149927270'); + ''; + in + pkgs.writeScriptBin "obtain-token-and-register-email" '' + #!${pkgs.runtimeShell} + set -o errexit + set -o pipefail + set -o nounset + su postgres -c "psql -d matrix-synapse -f ${insertEmailForAlice}" + curl --fail -XPOST 'https://localhost:8448/_matrix/client/r0/account/password/email/requestToken' -d '{"email":"${testEmail}","client_secret":"foobar","send_attempt":1}' -v + ''; + in + [ + sendTestMailStarttls + pkgs.matrix-synapse + obtainTokenAndRegisterEmail + ]; }; - }; - }; - serversqlite = args: { - services.matrix-synapse = { - enable = true; - settings = { - inherit listeners; - database.name = "sqlite3"; - tls_certificate_path = "${bundle}/cert.pem"; - tls_private_key_path = "${bundle}/key.pem"; + # test mail delivery + mailserver = + args: + let + in + { + security.pki.certificateFiles = [ + mailerCerts.ca.cert + ]; + + networking.firewall.enable = false; + + services.postfix = { + enable = true; + hostname = "${mailerDomain}"; + # open relay for subnet + networksStyle = "subnet"; + enableSubmission = true; + tlsTrustedAuthorities = "${mailerCerts.ca.cert}"; + sslCert = "${mailerCerts.${mailerDomain}.cert}"; + sslKey = "${mailerCerts.${mailerDomain}.key}"; + + # blackhole transport + transport = "example.com discard:silently"; + + config = { + debug_peer_level = "10"; + smtpd_relay_restrictions = [ + "permit_mynetworks" + "reject_unauth_destination" + ]; + + # disable obsolete protocols, something old versions of twisted are still using + smtpd_tls_protocols = "TLSv1.3, TLSv1.2, !TLSv1.1, !TLSv1, !SSLv2, !SSLv3"; + smtp_tls_protocols = "TLSv1.3, TLSv1.2, !TLSv1.1, !TLSv1, !SSLv2, !SSLv3"; + smtpd_tls_mandatory_protocols = "TLSv1.3, TLSv1.2, !TLSv1.1, !TLSv1, !SSLv2, !SSLv3"; + smtp_tls_mandatory_protocols = "TLSv1.3, TLSv1.2, !TLSv1.1, !TLSv1, !SSLv2, !SSLv3"; + }; + }; + }; + + serversqlite = args: { + services.matrix-synapse = { + enable = true; + settings = { + inherit listeners; + database.name = "sqlite3"; + tls_certificate_path = "${bundle}/cert.pem"; + tls_private_key_path = "${bundle}/key.pem"; + }; }; }; }; - }; - - testScript = '' - start_all() - mailserver.wait_for_unit("postfix.service") - serverpostgres.succeed("send-testmail-starttls") - serverpostgres.wait_for_unit("matrix-synapse.service") - serverpostgres.wait_until_succeeds( - "curl --fail -L --cacert ${ca_pem} https://localhost:8448/" - ) - serverpostgres.wait_until_succeeds( - "journalctl -u matrix-synapse.service | grep -q 'Connected to redis'" - ) - serverpostgres.require_unit_state("postgresql.service") - serverpostgres.succeed("REQUESTS_CA_BUNDLE=${ca_pem} register_new_matrix_user -u ${testUser} -p ${testPassword} -a -k ${registrationSharedSecret} https://localhost:8448/") - serverpostgres.succeed("obtain-token-and-register-email") - serversqlite.wait_for_unit("matrix-synapse.service") - serversqlite.wait_until_succeeds( - "curl --fail -L --cacert ${ca_pem} https://localhost:8448/" - ) - serversqlite.succeed("[ -e /var/lib/matrix-synapse/homeserver.db ]") - ''; - -}) + + testScript = '' + start_all() + mailserver.wait_for_unit("postfix.service") + serverpostgres.succeed("send-testmail-starttls") + serverpostgres.wait_for_unit("matrix-synapse.service") + serverpostgres.wait_until_succeeds( + "curl --fail -L --cacert ${ca_pem} https://localhost:8448/" + ) + serverpostgres.wait_until_succeeds( + "journalctl -u matrix-synapse.service | grep -q 'Connected to redis'" + ) + serverpostgres.require_unit_state("postgresql.service") + serverpostgres.succeed("REQUESTS_CA_BUNDLE=${ca_pem} register_new_matrix_user -u ${testUser} -p ${testPassword} -a -k ${registrationSharedSecret} https://localhost:8448/") + serverpostgres.succeed("obtain-token-and-register-email") + serversqlite.wait_for_unit("matrix-synapse.service") + serversqlite.wait_until_succeeds( + "curl --fail -L --cacert ${ca_pem} https://localhost:8448/" + ) + serversqlite.succeed("[ -e /var/lib/matrix-synapse/homeserver.db ]") + ''; + + } +) diff --git a/nixos/tests/matter-server.nix b/nixos/tests/matter-server.nix index c646e9840d1944..3337ea3cf66ad2 100644 --- a/nixos/tests/matter-server.nix +++ b/nixos/tests/matter-server.nix @@ -1,45 +1,50 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : - -let - chipVersion = pkgs.python311Packages.home-assistant-chip-core.version; -in - -{ - name = "matter-server"; - meta.maintainers = with lib.maintainers; [ leonm1 ]; - - nodes = { - machine = { config, ... }: { - services.matter-server = { - enable = true; - port = 1234; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + let + chipVersion = pkgs.python311Packages.home-assistant-chip-core.version; + in + + { + name = "matter-server"; + meta.maintainers = with lib.maintainers; [ leonm1 ]; + + nodes = { + machine = + { config, ... }: + { + services.matter-server = { + enable = true; + port = 1234; + }; + }; }; - }; - testScript = /* python */ '' - start_all() + testScript = # python + '' + start_all() - machine.wait_for_unit("matter-server.service") - machine.wait_for_open_port(1234) + machine.wait_for_unit("matter-server.service") + machine.wait_for_open_port(1234) - with subtest("Check websocket server initialized"): - output = machine.succeed("echo \"\" | ${pkgs.websocat}/bin/websocat ws://localhost:1234/ws") - machine.log(output) + with subtest("Check websocket server initialized"): + output = machine.succeed("echo \"\" | ${pkgs.websocat}/bin/websocat ws://localhost:1234/ws") + machine.log(output) - assert '"sdk_version": "${chipVersion}"' in output, ( - 'CHIP version \"${chipVersion}\" not present in websocket message' - ) + assert '"sdk_version": "${chipVersion}"' in output, ( + 'CHIP version \"${chipVersion}\" not present in websocket message' + ) - assert '"fabric_id": 1' in output, ( - "fabric_id not propagated to server" - ) + assert '"fabric_id": 1' in output, ( + "fabric_id not propagated to server" + ) - with subtest("Check storage directory is created"): - machine.succeed("ls /var/lib/matter-server/chip.json") + with subtest("Check storage directory is created"): + machine.succeed("ls /var/lib/matter-server/chip.json") - with subtest("Check systemd hardening"): - _, output = machine.execute("systemd-analyze security matter-server.service | grep -v '✓'") - machine.log(output) - ''; -}) + with subtest("Check systemd hardening"): + _, output = machine.execute("systemd-analyze security matter-server.service | grep -v '✓'") + machine.log(output) + ''; + } +) diff --git a/nixos/tests/mattermost.nix b/nixos/tests/mattermost.nix index e11201f05357da..04df954eef1a66 100644 --- a/nixos/tests/mattermost.nix +++ b/nixos/tests/mattermost.nix @@ -1,140 +1,151 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - host = "smoke.test"; - port = "8065"; - url = "http://${host}:${port}"; - siteName = "NixOS Smoke Tests, Inc."; - - makeMattermost = mattermostConfig: - { config, ... }: { - environment.systemPackages = [ - pkgs.mattermost - pkgs.curl - pkgs.jq - ]; - networking.hosts = { - "127.0.0.1" = [ host ]; - }; - services.mattermost = lib.recursiveUpdate { - enable = true; - inherit siteName; - listenAddress = "0.0.0.0:${port}"; - siteUrl = url; - extraConfig = { - SupportSettings.AboutLink = "https://nixos.org"; - }; - } mattermostConfig; - }; -in -{ - name = "mattermost"; - - nodes = { - mutable = makeMattermost { - mutableConfig = true; - extraConfig.SupportSettings.HelpLink = "https://search.nixos.org"; - }; - mostlyMutable = makeMattermost { - mutableConfig = true; - preferNixConfig = true; - plugins = let - mattermostDemoPlugin = pkgs.fetchurl { - url = "https://github.com/mattermost/mattermost-plugin-demo/releases/download/v0.9.0/com.mattermost.demo-plugin-0.9.0.tar.gz"; - sha256 = "1h4qi34gcxcx63z8wiqcf2aaywmvv8lys5g8gvsk13kkqhlmag25"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + host = "smoke.test"; + port = "8065"; + url = "http://${host}:${port}"; + siteName = "NixOS Smoke Tests, Inc."; + + makeMattermost = + mattermostConfig: + { config, ... }: + { + environment.systemPackages = [ + pkgs.mattermost + pkgs.curl + pkgs.jq + ]; + networking.hosts = { + "127.0.0.1" = [ host ]; }; - in [ - mattermostDemoPlugin - ]; - }; - immutable = makeMattermost { - mutableConfig = false; - extraConfig.SupportSettings.HelpLink = "https://search.nixos.org"; - }; - environmentFile = makeMattermost { - mutableConfig = false; - extraConfig.SupportSettings.AboutLink = "https://example.org"; - environmentFile = pkgs.writeText "mattermost-env" '' - MM_SUPPORTSETTINGS_ABOUTLINK=https://nixos.org - ''; - }; - }; - - testScript = let - expectConfig = jqExpression: pkgs.writeShellScript "expect-config" '' - set -euo pipefail - echo "Expecting config to match: "${lib.escapeShellArg jqExpression} >&2 - curl ${lib.escapeShellArg url} >/dev/null - config="$(curl ${lib.escapeShellArg "${url}/api/v4/config/client?format=old"})" - echo "Config: $(echo "$config" | ${pkgs.jq}/bin/jq)" >&2 - [[ "$(echo "$config" | ${pkgs.jq}/bin/jq -r ${lib.escapeShellArg ".SiteName == $siteName and .Version == ($mattermostName / $sep)[-1] and (${jqExpression})"} --arg siteName ${lib.escapeShellArg siteName} --arg mattermostName ${lib.escapeShellArg pkgs.mattermost.name} --arg sep '-')" = "true" ]] - ''; - - setConfig = jqExpression: pkgs.writeShellScript "set-config" '' - set -euo pipefail - mattermostConfig=/var/lib/mattermost/config/config.json - newConfig="$(${pkgs.jq}/bin/jq -r ${lib.escapeShellArg jqExpression} $mattermostConfig)" - rm -f $mattermostConfig - echo "$newConfig" > "$mattermostConfig" - ''; - + services.mattermost = lib.recursiveUpdate { + enable = true; + inherit siteName; + listenAddress = "0.0.0.0:${port}"; + siteUrl = url; + extraConfig = { + SupportSettings.AboutLink = "https://nixos.org"; + }; + } mattermostConfig; + }; in - '' - start_all() - - ## Mutable node tests ## - mutable.wait_for_unit("mattermost.service") - mutable.wait_for_open_port(8065) - - # Get the initial config - mutable.succeed("${expectConfig ''.AboutLink == "https://nixos.org" and .HelpLink == "https://search.nixos.org"''}") - - # Edit the config - mutable.succeed("${setConfig ''.SupportSettings.AboutLink = "https://mattermost.com"''}") - mutable.succeed("${setConfig ''.SupportSettings.HelpLink = "https://nixos.org/nixos/manual"''}") - mutable.systemctl("restart mattermost.service") - mutable.wait_for_open_port(8065) - - # AboutLink and HelpLink should be changed - mutable.succeed("${expectConfig ''.AboutLink == "https://mattermost.com" and .HelpLink == "https://nixos.org/nixos/manual"''}") - - ## Mostly mutable node tests ## - mostlyMutable.wait_for_unit("mattermost.service") - mostlyMutable.wait_for_open_port(8065) + { + name = "mattermost"; - # Get the initial config - mostlyMutable.succeed("${expectConfig ''.AboutLink == "https://nixos.org"''}") - - # Edit the config - mostlyMutable.succeed("${setConfig ''.SupportSettings.AboutLink = "https://mattermost.com"''}") - mostlyMutable.succeed("${setConfig ''.SupportSettings.HelpLink = "https://nixos.org/nixos/manual"''}") - mostlyMutable.systemctl("restart mattermost.service") - mostlyMutable.wait_for_open_port(8065) - - # AboutLink should be overridden by NixOS configuration; HelpLink should be what we set above - mostlyMutable.succeed("${expectConfig ''.AboutLink == "https://nixos.org" and .HelpLink == "https://nixos.org/nixos/manual"''}") - - ## Immutable node tests ## - immutable.wait_for_unit("mattermost.service") - immutable.wait_for_open_port(8065) - - # Get the initial config - immutable.succeed("${expectConfig ''.AboutLink == "https://nixos.org" and .HelpLink == "https://search.nixos.org"''}") - - # Edit the config - immutable.succeed("${setConfig ''.SupportSettings.AboutLink = "https://mattermost.com"''}") - immutable.succeed("${setConfig ''.SupportSettings.HelpLink = "https://nixos.org/nixos/manual"''}") - immutable.systemctl("restart mattermost.service") - immutable.wait_for_open_port(8065) - - # Our edits should be ignored on restart - immutable.succeed("${expectConfig ''.AboutLink == "https://nixos.org" and .HelpLink == "https://search.nixos.org"''}") - - - ## Environment File node tests ## - environmentFile.wait_for_unit("mattermost.service") - environmentFile.wait_for_open_port(8065) + nodes = { + mutable = makeMattermost { + mutableConfig = true; + extraConfig.SupportSettings.HelpLink = "https://search.nixos.org"; + }; + mostlyMutable = makeMattermost { + mutableConfig = true; + preferNixConfig = true; + plugins = + let + mattermostDemoPlugin = pkgs.fetchurl { + url = "https://github.com/mattermost/mattermost-plugin-demo/releases/download/v0.9.0/com.mattermost.demo-plugin-0.9.0.tar.gz"; + sha256 = "1h4qi34gcxcx63z8wiqcf2aaywmvv8lys5g8gvsk13kkqhlmag25"; + }; + in + [ + mattermostDemoPlugin + ]; + }; + immutable = makeMattermost { + mutableConfig = false; + extraConfig.SupportSettings.HelpLink = "https://search.nixos.org"; + }; + environmentFile = makeMattermost { + mutableConfig = false; + extraConfig.SupportSettings.AboutLink = "https://example.org"; + environmentFile = pkgs.writeText "mattermost-env" '' + MM_SUPPORTSETTINGS_ABOUTLINK=https://nixos.org + ''; + }; + }; - # Settings in the environment file should override settings set otherwise - environmentFile.succeed("${expectConfig ''.AboutLink == "https://nixos.org"''}") - ''; -}) + testScript = + let + expectConfig = + jqExpression: + pkgs.writeShellScript "expect-config" '' + set -euo pipefail + echo "Expecting config to match: "${lib.escapeShellArg jqExpression} >&2 + curl ${lib.escapeShellArg url} >/dev/null + config="$(curl ${lib.escapeShellArg "${url}/api/v4/config/client?format=old"})" + echo "Config: $(echo "$config" | ${pkgs.jq}/bin/jq)" >&2 + [[ "$(echo "$config" | ${pkgs.jq}/bin/jq -r ${lib.escapeShellArg ".SiteName == $siteName and .Version == ($mattermostName / $sep)[-1] and (${jqExpression})"} --arg siteName ${lib.escapeShellArg siteName} --arg mattermostName ${lib.escapeShellArg pkgs.mattermost.name} --arg sep '-')" = "true" ]] + ''; + + setConfig = + jqExpression: + pkgs.writeShellScript "set-config" '' + set -euo pipefail + mattermostConfig=/var/lib/mattermost/config/config.json + newConfig="$(${pkgs.jq}/bin/jq -r ${lib.escapeShellArg jqExpression} $mattermostConfig)" + rm -f $mattermostConfig + echo "$newConfig" > "$mattermostConfig" + ''; + + in + '' + start_all() + + ## Mutable node tests ## + mutable.wait_for_unit("mattermost.service") + mutable.wait_for_open_port(8065) + + # Get the initial config + mutable.succeed("${expectConfig ''.AboutLink == "https://nixos.org" and .HelpLink == "https://search.nixos.org"''}") + + # Edit the config + mutable.succeed("${setConfig ''.SupportSettings.AboutLink = "https://mattermost.com"''}") + mutable.succeed("${setConfig ''.SupportSettings.HelpLink = "https://nixos.org/nixos/manual"''}") + mutable.systemctl("restart mattermost.service") + mutable.wait_for_open_port(8065) + + # AboutLink and HelpLink should be changed + mutable.succeed("${expectConfig ''.AboutLink == "https://mattermost.com" and .HelpLink == "https://nixos.org/nixos/manual"''}") + + ## Mostly mutable node tests ## + mostlyMutable.wait_for_unit("mattermost.service") + mostlyMutable.wait_for_open_port(8065) + + # Get the initial config + mostlyMutable.succeed("${expectConfig ''.AboutLink == "https://nixos.org"''}") + + # Edit the config + mostlyMutable.succeed("${setConfig ''.SupportSettings.AboutLink = "https://mattermost.com"''}") + mostlyMutable.succeed("${setConfig ''.SupportSettings.HelpLink = "https://nixos.org/nixos/manual"''}") + mostlyMutable.systemctl("restart mattermost.service") + mostlyMutable.wait_for_open_port(8065) + + # AboutLink should be overridden by NixOS configuration; HelpLink should be what we set above + mostlyMutable.succeed("${expectConfig ''.AboutLink == "https://nixos.org" and .HelpLink == "https://nixos.org/nixos/manual"''}") + + ## Immutable node tests ## + immutable.wait_for_unit("mattermost.service") + immutable.wait_for_open_port(8065) + + # Get the initial config + immutable.succeed("${expectConfig ''.AboutLink == "https://nixos.org" and .HelpLink == "https://search.nixos.org"''}") + + # Edit the config + immutable.succeed("${setConfig ''.SupportSettings.AboutLink = "https://mattermost.com"''}") + immutable.succeed("${setConfig ''.SupportSettings.HelpLink = "https://nixos.org/nixos/manual"''}") + immutable.systemctl("restart mattermost.service") + immutable.wait_for_open_port(8065) + + # Our edits should be ignored on restart + immutable.succeed("${expectConfig ''.AboutLink == "https://nixos.org" and .HelpLink == "https://search.nixos.org"''}") + + + ## Environment File node tests ## + environmentFile.wait_for_unit("mattermost.service") + environmentFile.wait_for_open_port(8065) + + # Settings in the environment file should override settings set otherwise + environmentFile.succeed("${expectConfig ''.AboutLink == "https://nixos.org"''}") + ''; + } +) diff --git a/nixos/tests/mealie.nix b/nixos/tests/mealie.nix index 810d47ecd2ec4f..57bff29731d8a3 100644 --- a/nixos/tests/mealie.nix +++ b/nixos/tests/mealie.nix @@ -1,24 +1,29 @@ -import ./make-test-python.nix ({ pkgs, ...} : +import ./make-test-python.nix ( + { pkgs, ... }: -{ - name = "mealie"; - meta = with pkgs.lib.maintainers; { - maintainers = [ litchipi anoa ]; - }; + { + name = "mealie"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + litchipi + anoa + ]; + }; - nodes = { - server = { - services.mealie = { - enable = true; - port = 9001; + nodes = { + server = { + services.mealie = { + enable = true; + port = 9001; + }; }; }; - }; - testScript = '' - start_all() - server.wait_for_unit("mealie.service") - server.wait_for_open_port(9001) - server.succeed("curl --fail http://localhost:9001") - ''; -}) + testScript = '' + start_all() + server.wait_for_unit("mealie.service") + server.wait_for_open_port(9001) + server.succeed("curl --fail http://localhost:9001") + ''; + } +) diff --git a/nixos/tests/mediatomb.nix b/nixos/tests/mediatomb.nix index 5718a9a4a29927..cf359d5928dfb5 100644 --- a/nixos/tests/mediatomb.nix +++ b/nixos/tests/mediatomb.nix @@ -27,10 +27,11 @@ import ./make-test-python.nix { ]; }; - client = {}; + client = { }; }; - testScript = { nodes, ... }: + testScript = + { nodes, ... }: let serverIP = nodes.server.networking.primaryIPAddress; serverIPv6 = nodes.server.networking.primaryIPv6Address; diff --git a/nixos/tests/mediawiki.nix b/nixos/tests/mediawiki.nix index e30cc55ff61602..eefb80a03c659f 100644 --- a/nixos/tests/mediawiki.nix +++ b/nixos/tests/mediawiki.nix @@ -1,6 +1,6 @@ { system ? builtins.currentSystem, - config ? {}, + config ? { }, pkgs ? import ../.. { inherit system config; }, }: @@ -60,19 +60,21 @@ in nodes.machine = { services.mediawiki.webserver = "none"; }; - testScript = { nodes, ... }: '' - start_all() - machine.wait_for_unit("phpfpm-mediawiki.service") - env = ( - "SCRIPT_NAME=/index.php", - "SCRIPT_FILENAME=${nodes.machine.services.mediawiki.finalPackage}/share/mediawiki/index.php", - "REMOTE_ADDR=127.0.0.1", - 'QUERY_STRING=title=Main_Page', - "REQUEST_METHOD=GET", - ); - page = machine.succeed(f"{' '.join(env)} ${pkgs.fcgi}/bin/cgi-fcgi -bind -connect ${nodes.machine.services.phpfpm.pools.mediawiki.socket}") - assert "MediaWiki has been installed" in page, f"no 'MediaWiki has been installed' in:\n{page}" - ''; + testScript = + { nodes, ... }: + '' + start_all() + machine.wait_for_unit("phpfpm-mediawiki.service") + env = ( + "SCRIPT_NAME=/index.php", + "SCRIPT_FILENAME=${nodes.machine.services.mediawiki.finalPackage}/share/mediawiki/index.php", + "REMOTE_ADDR=127.0.0.1", + 'QUERY_STRING=title=Main_Page', + "REQUEST_METHOD=GET", + ); + page = machine.succeed(f"{' '.join(env)} ${pkgs.fcgi}/bin/cgi-fcgi -bind -connect ${nodes.machine.services.phpfpm.pools.mediawiki.socket}") + assert "MediaWiki has been installed" in page, f"no 'MediaWiki has been installed' in:\n{page}" + ''; }; nginx = testLib.makeTest { diff --git a/nixos/tests/meilisearch.nix b/nixos/tests/meilisearch.nix index c31dcb0559dbbf..a73abbba3a48c4 100644 --- a/nixos/tests/meilisearch.nix +++ b/nixos/tests/meilisearch.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: let listenAddress = "127.0.0.1"; listenPort = 7700; @@ -9,17 +10,23 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: url = "https://github.com/meilisearch/meilisearch/raw/v0.23.1/datasets/movies/movies.json"; sha256 = "1r3srld63dpmg9yrmysm6xl175661j5cspi93mk5q2wf8xwn50c5"; }; - in { + in + { name = "meilisearch"; meta.maintainers = with lib.maintainers; [ Br1ght0ne ]; - nodes.machine = { ... }: { - environment.systemPackages = with pkgs; [ curl jq ]; - services.meilisearch = { - enable = true; - inherit listenAddress listenPort; + nodes.machine = + { ... }: + { + environment.systemPackages = with pkgs; [ + curl + jq + ]; + services.meilisearch = { + enable = true; + inherit listenAddress listenPort; + }; }; - }; testScript = '' import json @@ -58,4 +65,5 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: print(response) assert len(response["hits"]) >= 1, "no results found" ''; - }) + } +) diff --git a/nixos/tests/memcached.nix b/nixos/tests/memcached.nix index 6549995110d790..c3f8734e320ce0 100644 --- a/nixos/tests/memcached.nix +++ b/nixos/tests/memcached.nix @@ -1,24 +1,32 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "memcached"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "memcached"; - nodes.machine = { - imports = [ ../modules/profiles/minimal.nix ]; - services.memcached.enable = true; - }; + nodes.machine = { + imports = [ ../modules/profiles/minimal.nix ]; + services.memcached.enable = true; + }; - testScript = let - testScript = pkgs.writers.writePython3 "test_memcache" { - libraries = with pkgs.python3Packages; [ memcached ]; - } '' - import memcache - c = memcache.Client(['localhost:11211']) - c.set('key', 'value') - assert 'value' == c.get('key') - ''; - in '' - machine.start() - machine.wait_for_unit("memcached.service") - machine.wait_for_open_port(11211) - machine.succeed("${testScript}") - ''; -}) + testScript = + let + testScript = + pkgs.writers.writePython3 "test_memcache" + { + libraries = with pkgs.python3Packages; [ memcached ]; + } + '' + import memcache + c = memcache.Client(['localhost:11211']) + c.set('key', 'value') + assert 'value' == c.get('key') + ''; + in + '' + machine.start() + machine.wait_for_unit("memcached.service") + machine.wait_for_open_port(11211) + machine.succeed("${testScript}") + ''; + } +) diff --git a/nixos/tests/merecat.nix b/nixos/tests/merecat.nix index 9d8f66165ee90d..072d8dd933de56 100644 --- a/nixos/tests/merecat.nix +++ b/nixos/tests/merecat.nix @@ -1,28 +1,35 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "merecat"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fgaz ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "merecat"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fgaz ]; + }; - nodes.machine = { config, pkgs, ... }: { - services.merecat = { - enable = true; - settings = { - hostname = "localhost"; - virtual-host = true; - directory = toString (pkgs.runCommand "merecat-webdir" {} '' - mkdir -p $out/foo.localhost $out/bar.localhost - echo '<h1>Hello foo</h1>' > $out/foo.localhost/index.html - echo '<h1>Hello bar</h1>' > $out/bar.localhost/index.html - ''); + nodes.machine = + { config, pkgs, ... }: + { + services.merecat = { + enable = true; + settings = { + hostname = "localhost"; + virtual-host = true; + directory = toString ( + pkgs.runCommand "merecat-webdir" { } '' + mkdir -p $out/foo.localhost $out/bar.localhost + echo '<h1>Hello foo</h1>' > $out/foo.localhost/index.html + echo '<h1>Hello bar</h1>' > $out/bar.localhost/index.html + '' + ); + }; + }; }; - }; - }; - testScript = '' - machine.wait_for_unit("merecat") - machine.wait_for_open_port(80) - machine.succeed("curl --fail foo.localhost | grep 'Hello foo'") - machine.succeed("curl --fail bar.localhost | grep 'Hello bar'") - ''; -}) + testScript = '' + machine.wait_for_unit("merecat") + machine.wait_for_open_port(80) + machine.succeed("curl --fail foo.localhost | grep 'Hello foo'") + machine.succeed("curl --fail bar.localhost | grep 'Hello bar'") + ''; + } +) diff --git a/nixos/tests/metabase.nix b/nixos/tests/metabase.nix index 1b25071902e97e..f86c51b108fcb3 100644 --- a/nixos/tests/metabase.nix +++ b/nixos/tests/metabase.nix @@ -1,19 +1,24 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "metabase"; - meta = with pkgs.lib.maintainers; { - maintainers = [ mmahut ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "metabase"; + meta = with pkgs.lib.maintainers; { + maintainers = [ mmahut ]; + }; - nodes = { - machine = { ... }: { - services.metabase.enable = true; + nodes = { + machine = + { ... }: + { + services.metabase.enable = true; + }; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("metabase.service") - machine.wait_for_open_port(3000) - machine.wait_until_succeeds("curl -fL http://localhost:3000/setup | grep Metabase") - ''; -}) + testScript = '' + start_all() + machine.wait_for_unit("metabase.service") + machine.wait_for_open_port(3000) + machine.wait_until_succeeds("curl -fL http://localhost:3000/setup | grep Metabase") + ''; + } +) diff --git a/nixos/tests/mihomo.nix b/nixos/tests/mihomo.nix index a456facb4367c0..4e16750a63b5a8 100644 --- a/nixos/tests/mihomo.nix +++ b/nixos/tests/mihomo.nix @@ -1,46 +1,49 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "mihomo"; - meta.maintainers = with pkgs.lib.maintainers; [ Guanran928 ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "mihomo"; + meta.maintainers = with pkgs.lib.maintainers; [ Guanran928 ]; - nodes.machine = { - environment.systemPackages = [ pkgs.curl ]; + nodes.machine = { + environment.systemPackages = [ pkgs.curl ]; - services.nginx = { - enable = true; - statusPage = true; - }; + services.nginx = { + enable = true; + statusPage = true; + }; - services.mihomo = { - enable = true; - configFile = pkgs.writeTextFile { - name = "config.yaml"; - text = '' - mixed-port: 7890 - external-controller: 127.0.0.1:9090 - authentication: - - "user:supersecret" - ''; + services.mihomo = { + enable = true; + configFile = pkgs.writeTextFile { + name = "config.yaml"; + text = '' + mixed-port: 7890 + external-controller: 127.0.0.1:9090 + authentication: + - "user:supersecret" + ''; + }; }; }; - }; - testScript = '' - # Wait until it starts - machine.wait_for_unit("nginx.service") - machine.wait_for_unit("mihomo.service") - machine.wait_for_open_port(80) - machine.wait_for_open_port(7890) - machine.wait_for_open_port(9090) + testScript = '' + # Wait until it starts + machine.wait_for_unit("nginx.service") + machine.wait_for_unit("mihomo.service") + machine.wait_for_open_port(80) + machine.wait_for_open_port(7890) + machine.wait_for_open_port(9090) - # Proxy - machine.succeed("curl --fail --max-time 10 --proxy http://user:supersecret@localhost:7890 http://localhost") - machine.succeed("curl --fail --max-time 10 --proxy socks5://user:supersecret@localhost:7890 http://localhost") - machine.fail("curl --fail --max-time 10 --proxy http://user:supervillain@localhost:7890 http://localhost") - machine.fail("curl --fail --max-time 10 --proxy socks5://user:supervillain@localhost:7890 http://localhost") + # Proxy + machine.succeed("curl --fail --max-time 10 --proxy http://user:supersecret@localhost:7890 http://localhost") + machine.succeed("curl --fail --max-time 10 --proxy socks5://user:supersecret@localhost:7890 http://localhost") + machine.fail("curl --fail --max-time 10 --proxy http://user:supervillain@localhost:7890 http://localhost") + machine.fail("curl --fail --max-time 10 --proxy socks5://user:supervillain@localhost:7890 http://localhost") - # Web UI - result = machine.succeed("curl --fail http://localhost:9090") - target = '{"hello":"mihomo"}\n' - assert result == target, f"{result!r} != {target!r}" - ''; -}) + # Web UI + result = machine.succeed("curl --fail http://localhost:9090") + target = '{"hello":"mihomo"}\n' + assert result == target, f"{result!r} != {target!r}" + ''; + } +) diff --git a/nixos/tests/mimir.nix b/nixos/tests/mimir.nix index f1b30d261472b9..981990b93a1d36 100644 --- a/nixos/tests/mimir.nix +++ b/nixos/tests/mimir.nix @@ -1,50 +1,55 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "mimir"; - nodes = { - server = { ... }: { - environment.systemPackages = [ pkgs.jq ]; - services.mimir.enable = true; - services.mimir.configuration = { - ingester.ring.replication_factor = 1; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "mimir"; + nodes = { + server = + { ... }: + { + environment.systemPackages = [ pkgs.jq ]; + services.mimir.enable = true; + services.mimir.configuration = { + ingester.ring.replication_factor = 1; + }; - services.telegraf.enable = true; - services.telegraf.extraConfig = { - agent.interval = "1s"; - agent.flush_interval = "1s"; - inputs.exec = { - commands = [ - "${pkgs.coreutils}/bin/echo 'foo i=42i'" - ]; - data_format = "influx"; - }; - outputs = { - http = { - # test remote write - url = "http://localhost:8080/api/v1/push"; + services.telegraf.enable = true; + services.telegraf.extraConfig = { + agent.interval = "1s"; + agent.flush_interval = "1s"; + inputs.exec = { + commands = [ + "${pkgs.coreutils}/bin/echo 'foo i=42i'" + ]; + data_format = "influx"; + }; + outputs = { + http = { + # test remote write + url = "http://localhost:8080/api/v1/push"; - # Data format to output. - data_format = "prometheusremotewrite"; + # Data format to output. + data_format = "prometheusremotewrite"; - headers = { - Content-Type = "application/x-protobuf"; - Content-Encoding = "snappy"; - X-Scope-OrgID = "nixos"; - X-Prometheus-Remote-Write-Version = "0.1.0"; + headers = { + Content-Type = "application/x-protobuf"; + Content-Encoding = "snappy"; + X-Scope-OrgID = "nixos"; + X-Prometheus-Remote-Write-Version = "0.1.0"; + }; + }; }; }; }; - }; }; - }; - testScript = '' - start_all() - server.wait_for_unit("mimir.service") - server.wait_for_unit("telegraf.service") - server.wait_for_open_port(8080) - server.wait_until_succeeds( - "curl -H 'X-Scope-OrgID: nixos' http://127.0.0.1:8080/prometheus/api/v1/label/host/values | jq -r '.data[0]' | grep server" - ) - ''; -}) + testScript = '' + start_all() + server.wait_for_unit("mimir.service") + server.wait_for_unit("telegraf.service") + server.wait_for_open_port(8080) + server.wait_until_succeeds( + "curl -H 'X-Scope-OrgID: nixos' http://127.0.0.1:8080/prometheus/api/v1/label/host/values | jq -r '.data[0]' | grep server" + ) + ''; + } +) diff --git a/nixos/tests/mindustry.nix b/nixos/tests/mindustry.nix index b3f5423c601b34..3ec5fb32a0d3d5 100644 --- a/nixos/tests/mindustry.nix +++ b/nixos/tests/mindustry.nix @@ -1,22 +1,25 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "mindustry"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fgaz ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "mindustry"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fgaz ]; + }; - nodes.machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + nodes.machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; - environment.systemPackages = [ pkgs.mindustry ]; - }; + services.xserver.enable = true; + environment.systemPackages = [ pkgs.mindustry ]; + }; - enableOCR = true; + enableOCR = true; - testScript = - '' + testScript = '' machine.wait_for_x() machine.execute("mindustry >&2 &") machine.wait_for_window("Mindustry") @@ -25,4 +28,5 @@ import ./make-test-python.nix ({ pkgs, ... }: { machine.wait_for_text(r"(Play|Database|Editor|Mods|Settings|Quit)") machine.screenshot("screen") ''; -}) + } +) diff --git a/nixos/tests/minecraft.nix b/nixos/tests/minecraft.nix index 1c34f04b4df223..5f75669900a240 100644 --- a/nixos/tests/minecraft.nix +++ b/nixos/tests/minecraft.nix @@ -1,11 +1,21 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "minecraft"; - meta = with lib.maintainers; { maintainers = [ nequissimus ]; }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "minecraft"; + meta = with lib.maintainers; { + maintainers = [ nequissimus ]; + }; - nodes.client = { nodes, ... }: - let user = nodes.client.config.users.users.alice; - in { - imports = [ ./common/user-account.nix ./common/x11.nix ]; + nodes.client = + { nodes, ... }: + let + user = nodes.client.config.users.users.alice; + in + { + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; environment.systemPackages = [ pkgs.minecraft ]; @@ -14,15 +24,19 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: { test-support.displayManager.auto.user = user.name; }; - enableOCR = true; + enableOCR = true; - testScript = { nodes, ... }: - let user = nodes.client.config.users.users.alice; - in '' - client.wait_for_x() - client.execute("su - alice -c minecraft-launcher >&2 &") - client.wait_for_text("Create a new Microsoft account") - client.sleep(10) - client.screenshot("launcher") - ''; -}) + testScript = + { nodes, ... }: + let + user = nodes.client.config.users.users.alice; + in + '' + client.wait_for_x() + client.execute("su - alice -c minecraft-launcher >&2 &") + client.wait_for_text("Create a new Microsoft account") + client.sleep(10) + client.screenshot("launcher") + ''; + } +) diff --git a/nixos/tests/minidlna.nix b/nixos/tests/minidlna.nix index 32721819634e3c..a1add4ba483668 100644 --- a/nixos/tests/minidlna.nix +++ b/nixos/tests/minidlna.nix @@ -1,40 +1,42 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "minidlna"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "minidlna"; - nodes = { - server = - { ... }: - { - imports = [ ../modules/profiles/minimal.nix ]; - services.minidlna.enable = true; - services.minidlna.openFirewall = true; - services.minidlna.settings = { - log_level = "error"; - media_dir = [ - "PV,/tmp/stuff" - ]; - friendly_name = "rpi3"; - root_container = "B"; - notify_interval = 60; - album_art_names = [ - "Cover.jpg/cover.jpg/AlbumArtSmall.jpg/albumartsmall.jpg" - "AlbumArt.jpg/albumart.jpg/Album.jpg/album.jpg" - "Folder.jpg/folder.jpg/Thumb.jpg/thumb.jpg" - ]; + nodes = { + server = + { ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; + services.minidlna.enable = true; + services.minidlna.openFirewall = true; + services.minidlna.settings = { + log_level = "error"; + media_dir = [ + "PV,/tmp/stuff" + ]; + friendly_name = "rpi3"; + root_container = "B"; + notify_interval = 60; + album_art_names = [ + "Cover.jpg/cover.jpg/AlbumArtSmall.jpg/albumartsmall.jpg" + "AlbumArt.jpg/albumart.jpg/Album.jpg/album.jpg" + "Folder.jpg/folder.jpg/Thumb.jpg/thumb.jpg" + ]; + }; }; - }; - client = { ... }: { }; - }; + client = { ... }: { }; + }; - testScript = - '' - start_all() - server.succeed("mkdir -p /tmp/stuff && chown minidlna: /tmp/stuff") - server.wait_for_unit("minidlna") - server.wait_for_open_port(8200) - # requests must be made *by IP* to avoid triggering minidlna's - # DNS-rebinding protection - server.succeed("curl --fail http://$(getent ahostsv4 localhost | head -n1 | cut -f 1 -d ' '):8200/") - client.succeed("curl --fail http://$(getent ahostsv4 server | head -n1 | cut -f 1 -d ' '):8200/") - ''; -}) + testScript = '' + start_all() + server.succeed("mkdir -p /tmp/stuff && chown minidlna: /tmp/stuff") + server.wait_for_unit("minidlna") + server.wait_for_open_port(8200) + # requests must be made *by IP* to avoid triggering minidlna's + # DNS-rebinding protection + server.succeed("curl --fail http://$(getent ahostsv4 localhost | head -n1 | cut -f 1 -d ' '):8200/") + client.succeed("curl --fail http://$(getent ahostsv4 server | head -n1 | cut -f 1 -d ' '):8200/") + ''; + } +) diff --git a/nixos/tests/miniflux.nix b/nixos/tests/miniflux.nix index 2adf9010051cba..f349a7a2c45cd3 100644 --- a/nixos/tests/miniflux.nix +++ b/nixos/tests/miniflux.nix @@ -1,121 +1,132 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: -let - port = 3142; - username = "alice"; - password = "correcthorsebatterystaple"; - defaultPort = 8080; - defaultUsername = "admin"; - defaultPassword = "password"; - adminCredentialsFile = pkgs.writeText "admin-credentials" '' - ADMIN_USERNAME=${defaultUsername} - ADMIN_PASSWORD=${defaultPassword} - ''; - customAdminCredentialsFile = pkgs.writeText "admin-credentials" '' - ADMIN_USERNAME=${username} - ADMIN_PASSWORD=${password} - ''; - postgresPassword = "correcthorsebatterystaple"; - postgresPasswordFile = pkgs.writeText "pgpass" '' - *:*:*:*:${postgresPassword} - ''; + let + port = 3142; + username = "alice"; + password = "correcthorsebatterystaple"; + defaultPort = 8080; + defaultUsername = "admin"; + defaultPassword = "password"; + adminCredentialsFile = pkgs.writeText "admin-credentials" '' + ADMIN_USERNAME=${defaultUsername} + ADMIN_PASSWORD=${defaultPassword} + ''; + customAdminCredentialsFile = pkgs.writeText "admin-credentials" '' + ADMIN_USERNAME=${username} + ADMIN_PASSWORD=${password} + ''; + postgresPassword = "correcthorsebatterystaple"; + postgresPasswordFile = pkgs.writeText "pgpass" '' + *:*:*:*:${postgresPassword} + ''; -in -{ - name = "miniflux"; - meta.maintainers = [ ]; + in + { + name = "miniflux"; + meta.maintainers = [ ]; - nodes = { - default = - { ... }: - { - security.apparmor.enable = true; - services.miniflux = { - enable = true; - inherit adminCredentialsFile; + nodes = { + default = + { ... }: + { + security.apparmor.enable = true; + services.miniflux = { + enable = true; + inherit adminCredentialsFile; + }; }; - }; - withoutSudo = - { ... }: - { - security.apparmor.enable = true; - services.miniflux = { - enable = true; - inherit adminCredentialsFile; + withoutSudo = + { ... }: + { + security.apparmor.enable = true; + services.miniflux = { + enable = true; + inherit adminCredentialsFile; + }; + security.sudo.enable = false; }; - security.sudo.enable = false; - }; - customized = - { ... }: - { - security.apparmor.enable = true; - services.miniflux = { - enable = true; - config = { - CLEANUP_FREQUENCY = "48"; - LISTEN_ADDR = "localhost:${toString port}"; + customized = + { ... }: + { + security.apparmor.enable = true; + services.miniflux = { + enable = true; + config = { + CLEANUP_FREQUENCY = "48"; + LISTEN_ADDR = "localhost:${toString port}"; + }; + adminCredentialsFile = customAdminCredentialsFile; }; - adminCredentialsFile = customAdminCredentialsFile; }; - }; - postgresTcp = { config, pkgs, lib, ... }: { - services.postgresql = { - enable = true; - initialScript = pkgs.writeText "init-postgres" '' - CREATE USER miniflux WITH PASSWORD '${postgresPassword}'; - CREATE DATABASE miniflux WITH OWNER miniflux; - ''; - enableTCPIP = true; - authentication = '' - host sameuser miniflux samenet scram-sha-256 - ''; - }; - systemd.services.postgresql.postStart = lib.mkAfter '' - $PSQL -tAd miniflux -c 'CREATE EXTENSION hstore;' - ''; - networking.firewall.allowedTCPPorts = [ config.services.postgresql.settings.port ]; - }; - externalDb = { ... }: { - security.apparmor.enable = true; - services.miniflux = { - enable = true; - createDatabaseLocally = false; - inherit adminCredentialsFile; - config = { - DATABASE_URL = "user=miniflux host=postgresTcp dbname=miniflux sslmode=disable"; - PGPASSFILE = "/run/miniflux/pgpass"; + postgresTcp = + { + config, + pkgs, + lib, + ... + }: + { + services.postgresql = { + enable = true; + initialScript = pkgs.writeText "init-postgres" '' + CREATE USER miniflux WITH PASSWORD '${postgresPassword}'; + CREATE DATABASE miniflux WITH OWNER miniflux; + ''; + enableTCPIP = true; + authentication = '' + host sameuser miniflux samenet scram-sha-256 + ''; + }; + systemd.services.postgresql.postStart = lib.mkAfter '' + $PSQL -tAd miniflux -c 'CREATE EXTENSION hstore;' + ''; + networking.firewall.allowedTCPPorts = [ config.services.postgresql.settings.port ]; + }; + externalDb = + { ... }: + { + security.apparmor.enable = true; + services.miniflux = { + enable = true; + createDatabaseLocally = false; + inherit adminCredentialsFile; + config = { + DATABASE_URL = "user=miniflux host=postgresTcp dbname=miniflux sslmode=disable"; + PGPASSFILE = "/run/miniflux/pgpass"; + }; + }; + systemd.services.miniflux.preStart = '' + cp ${postgresPasswordFile} /run/miniflux/pgpass + chmod 600 /run/miniflux/pgpass + ''; }; - }; - systemd.services.miniflux.preStart = '' - cp ${postgresPasswordFile} /run/miniflux/pgpass - chmod 600 /run/miniflux/pgpass - ''; }; - }; - testScript = '' - def runTest(machine, port, user): - machine.wait_for_unit("miniflux.service") - machine.wait_for_open_port(port) - machine.succeed(f"curl --fail 'http://localhost:{port}/healthcheck' | grep OK") - machine.succeed( - f"curl 'http://localhost:{port}/v1/me' -u '{user}' -H Content-Type:application/json | grep '\"is_admin\":true'" - ) - machine.fail('journalctl -b --no-pager --grep "^audit: .*apparmor=\\"DENIED\\""') + testScript = '' + def runTest(machine, port, user): + machine.wait_for_unit("miniflux.service") + machine.wait_for_open_port(port) + machine.succeed(f"curl --fail 'http://localhost:{port}/healthcheck' | grep OK") + machine.succeed( + f"curl 'http://localhost:{port}/v1/me' -u '{user}' -H Content-Type:application/json | grep '\"is_admin\":true'" + ) + machine.fail('journalctl -b --no-pager --grep "^audit: .*apparmor=\\"DENIED\\""') - default.start() - withoutSudo.start() - customized.start() - postgresTcp.start() + default.start() + withoutSudo.start() + customized.start() + postgresTcp.start() - runTest(default, ${toString defaultPort}, "${defaultUsername}:${defaultPassword}") - runTest(withoutSudo, ${toString defaultPort}, "${defaultUsername}:${defaultPassword}") - runTest(customized, ${toString port}, "${username}:${password}") + runTest(default, ${toString defaultPort}, "${defaultUsername}:${defaultPassword}") + runTest(withoutSudo, ${toString defaultPort}, "${defaultUsername}:${defaultPassword}") + runTest(customized, ${toString port}, "${username}:${password}") - postgresTcp.wait_for_unit("postgresql.service") - externalDb.start() - runTest(externalDb, ${toString defaultPort}, "${defaultUsername}:${defaultPassword}") - ''; -}) + postgresTcp.wait_for_unit("postgresql.service") + externalDb.start() + runTest(externalDb, ${toString defaultPort}, "${defaultUsername}:${defaultPassword}") + ''; + } +) diff --git a/nixos/tests/miriway.nix b/nixos/tests/miriway.nix index 94373bb75a9157..14546dd03dff37 100644 --- a/nixos/tests/miriway.nix +++ b/nixos/tests/miriway.nix @@ -1,123 +1,130 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "miriway"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "miriway"; - meta = { - maintainers = with lib.maintainers; [ OPNA2608 ]; - }; + meta = { + maintainers = with lib.maintainers; [ OPNA2608 ]; + }; - nodes.machine = { config, ... }: { - imports = [ - ./common/auto.nix - ./common/user-account.nix - ]; + nodes.machine = + { config, ... }: + { + imports = [ + ./common/auto.nix + ./common/user-account.nix + ]; - # Seems to very rarely get interrupted by oom-killer - virtualisation.memorySize = 2047; + # Seems to very rarely get interrupted by oom-killer + virtualisation.memorySize = 2047; - test-support.displayManager.auto = { - enable = true; - user = "alice"; - }; + test-support.displayManager.auto = { + enable = true; + user = "alice"; + }; - services.xserver.enable = true; - services.displayManager.defaultSession = lib.mkForce "miriway"; + services.xserver.enable = true; + services.displayManager.defaultSession = lib.mkForce "miriway"; - programs.miriway = { - enable = true; - config = '' - add-wayland-extensions=all - enable-x11= + programs.miriway = { + enable = true; + config = '' + add-wayland-extensions=all + enable-x11= - ctrl-alt=t:foot --maximized - ctrl-alt=a:env WINIT_UNIX_BACKEND=x11 WAYLAND_DISPLAY= alacritty --option window.startup_mode=\"maximized\" + ctrl-alt=t:foot --maximized + ctrl-alt=a:env WINIT_UNIX_BACKEND=x11 WAYLAND_DISPLAY= alacritty --option window.startup_mode=\"maximized\" - shell-component=dbus-update-activation-environment --systemd DISPLAY WAYLAND_DISPLAY + shell-component=dbus-update-activation-environment --systemd DISPLAY WAYLAND_DISPLAY - shell-component=foot --maximized - ''; - }; + shell-component=foot --maximized + ''; + }; - environment = { - shellAliases = { - test-wayland = "wayland-info | tee /tmp/test-wayland.out && touch /tmp/test-wayland-exit-ok"; - test-x11 = "glinfo | tee /tmp/test-x11.out && touch /tmp/test-x11-exit-ok"; - }; + environment = { + shellAliases = { + test-wayland = "wayland-info | tee /tmp/test-wayland.out && touch /tmp/test-wayland-exit-ok"; + test-x11 = "glinfo | tee /tmp/test-x11.out && touch /tmp/test-x11-exit-ok"; + }; - systemPackages = with pkgs; [ - mesa-demos - wayland-utils - foot - alacritty - ]; - - # To help with OCR - etc."xdg/foot/foot.ini".text = lib.generators.toINI { } { - main = { - font = "inconsolata:size=16"; - }; - colors = rec { - foreground = "000000"; - background = "ffffff"; - regular2 = foreground; - }; - }; - etc."xdg/alacritty/alacritty.yml".text = lib.generators.toYAML { } { - font = rec { - normal.family = "Inconsolata"; - bold.family = normal.family; - italic.family = normal.family; - bold_italic.family = normal.family; - size = 16; - }; - colors = rec { - primary = { - foreground = "0x000000"; - background = "0xffffff"; + systemPackages = with pkgs; [ + mesa-demos + wayland-utils + foot + alacritty + ]; + + # To help with OCR + etc."xdg/foot/foot.ini".text = lib.generators.toINI { } { + main = { + font = "inconsolata:size=16"; + }; + colors = rec { + foreground = "000000"; + background = "ffffff"; + regular2 = foreground; + }; }; - normal = { - green = primary.foreground; + etc."xdg/alacritty/alacritty.yml".text = lib.generators.toYAML { } { + font = rec { + normal.family = "Inconsolata"; + bold.family = normal.family; + italic.family = normal.family; + bold_italic.family = normal.family; + size = 16; + }; + colors = rec { + primary = { + foreground = "0x000000"; + background = "0xffffff"; + }; + normal = { + green = primary.foreground; + }; + }; }; }; + + fonts.packages = [ pkgs.inconsolata ]; }; - }; - fonts.packages = [ pkgs.inconsolata ]; - }; - - enableOCR = true; - - testScript = { nodes, ... }: '' - start_all() - machine.wait_for_unit("multi-user.target") - - # Wait for Miriway to complete startup - machine.wait_for_file("/run/user/1000/wayland-0") - machine.succeed("pgrep miriway-shell") - machine.screenshot("miriway_launched") - - # Test Wayland - # We let Miriway start the first terminal, as we might get stuck if it's not ready to process the first keybind - # machine.send_key("ctrl-alt-t") - machine.wait_for_text(r"(alice|machine)") - machine.send_chars("test-wayland\n") - machine.wait_for_file("/tmp/test-wayland-exit-ok") - machine.copy_from_vm("/tmp/test-wayland.out") - machine.screenshot("foot_wayland_info") - # Only succeeds when a mouse is moved inside an interactive session? - # machine.send_chars("exit\n") - # machine.wait_until_fails("pgrep foot") - machine.succeed("pkill foot") - - # Test XWayland - machine.send_key("ctrl-alt-a") - machine.wait_for_text(r"(alice|machine)") - machine.send_chars("test-x11\n") - machine.wait_for_file("/tmp/test-x11-exit-ok") - machine.copy_from_vm("/tmp/test-x11.out") - machine.screenshot("alacritty_glinfo") - # Only succeeds when a mouse is moved inside an interactive session? - # machine.send_chars("exit\n") - # machine.wait_until_fails("pgrep alacritty") - machine.succeed("pkill alacritty") - ''; -}) + enableOCR = true; + + testScript = + { nodes, ... }: + '' + start_all() + machine.wait_for_unit("multi-user.target") + + # Wait for Miriway to complete startup + machine.wait_for_file("/run/user/1000/wayland-0") + machine.succeed("pgrep miriway-shell") + machine.screenshot("miriway_launched") + + # Test Wayland + # We let Miriway start the first terminal, as we might get stuck if it's not ready to process the first keybind + # machine.send_key("ctrl-alt-t") + machine.wait_for_text(r"(alice|machine)") + machine.send_chars("test-wayland\n") + machine.wait_for_file("/tmp/test-wayland-exit-ok") + machine.copy_from_vm("/tmp/test-wayland.out") + machine.screenshot("foot_wayland_info") + # Only succeeds when a mouse is moved inside an interactive session? + # machine.send_chars("exit\n") + # machine.wait_until_fails("pgrep foot") + machine.succeed("pkill foot") + + # Test XWayland + machine.send_key("ctrl-alt-a") + machine.wait_for_text(r"(alice|machine)") + machine.send_chars("test-x11\n") + machine.wait_for_file("/tmp/test-x11-exit-ok") + machine.copy_from_vm("/tmp/test-x11.out") + machine.screenshot("alacritty_glinfo") + # Only succeeds when a mouse is moved inside an interactive session? + # machine.send_chars("exit\n") + # machine.wait_until_fails("pgrep alacritty") + machine.succeed("pkill alacritty") + ''; + } +) diff --git a/nixos/tests/misc.nix b/nixos/tests/misc.nix index 1d296accf121fa..5734b900f15234 100644 --- a/nixos/tests/misc.nix +++ b/nixos/tests/misc.nix @@ -1,49 +1,77 @@ # Miscellaneous small tests that don't warrant their own VM run. -import ./make-test-python.nix ({ lib, pkgs, ...} : let - foo = pkgs.writeText "foo" "Hello World"; -in { - name = "misc"; - meta.maintainers = with lib.maintainers; [ eelco ]; - - nodes.machine = - { lib, ... }: - { swapDevices = lib.mkOverride 0 - [ { device = "/root/swapfile"; size = 128; } ]; - environment.variables.EDITOR = lib.mkOverride 0 "emacs"; - documentation.nixos.enable = lib.mkOverride 0 true; - systemd.tmpfiles.rules = [ "d /tmp 1777 root root 10d" ]; - systemd.tmpfiles.settings."10-test"."/tmp/somefile".d = {}; - virtualisation.fileSystems = { "/tmp2" = - { fsType = "tmpfs"; - options = [ "mode=1777" "noauto" ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let + foo = pkgs.writeText "foo" "Hello World"; + in + { + name = "misc"; + meta.maintainers = with lib.maintainers; [ eelco ]; + + nodes.machine = + { lib, ... }: + { + swapDevices = lib.mkOverride 0 [ + { + device = "/root/swapfile"; + size = 128; + } + ]; + environment.variables.EDITOR = lib.mkOverride 0 "emacs"; + documentation.nixos.enable = lib.mkOverride 0 true; + systemd.tmpfiles.rules = [ "d /tmp 1777 root root 10d" ]; + systemd.tmpfiles.settings."10-test"."/tmp/somefile".d = { }; + virtualisation.fileSystems = { + "/tmp2" = { + fsType = "tmpfs"; + options = [ + "mode=1777" + "noauto" + ]; + }; + # Tests https://discourse.nixos.org/t/how-to-make-a-derivations-executables-have-the-s-permission/8555 + "/user-mount/point" = { + device = "/user-mount/source"; + fsType = "none"; + options = [ + "bind" + "rw" + "user" + "noauto" + ]; + }; + "/user-mount/denied-point" = { + device = "/user-mount/denied-source"; + fsType = "none"; + options = [ + "bind" + "rw" + "noauto" + ]; + }; }; - # Tests https://discourse.nixos.org/t/how-to-make-a-derivations-executables-have-the-s-permission/8555 - "/user-mount/point" = { - device = "/user-mount/source"; - fsType = "none"; - options = [ "bind" "rw" "user" "noauto" ]; + systemd.automounts = lib.singleton { + wantedBy = [ "multi-user.target" ]; + where = "/tmp2"; }; - "/user-mount/denied-point" = { - device = "/user-mount/denied-source"; - fsType = "none"; - options = [ "bind" "rw" "noauto" ]; + users.users.sybil = { + isNormalUser = true; + group = "wheel"; }; - }; - systemd.automounts = lib.singleton - { wantedBy = [ "multi-user.target" ]; - where = "/tmp2"; + users.users.alice = { + isNormalUser = true; }; - users.users.sybil = { isNormalUser = true; group = "wheel"; }; - users.users.alice = { isNormalUser = true; }; - security.sudo = { enable = true; wheelNeedsPassword = false; }; - boot.kernel.sysctl."vm.swappiness" = 1; - boot.kernelParams = [ "vsyscall=emulate" ]; - system.extraDependencies = [ foo ]; - }; - - testScript = - '' + security.sudo = { + enable = true; + wheelNeedsPassword = false; + }; + boot.kernel.sysctl."vm.swappiness" = 1; + boot.kernelParams = [ "vsyscall=emulate" ]; + system.extraDependencies = [ foo ]; + }; + + testScript = '' with subtest("nixos-version"): machine.succeed("[ `nixos-version | wc -w` = 2 ]") @@ -139,4 +167,5 @@ in { with subtest("Test boot parameters"): assert "vsyscall=emulate" in machine.succeed("cat /proc/cmdline") ''; -}) + } +) diff --git a/nixos/tests/mobilizon.nix b/nixos/tests/mobilizon.nix index 2b070ca9d96091..c456242e1b3167 100644 --- a/nixos/tests/mobilizon.nix +++ b/nixos/tests/mobilizon.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: let certs = import ./common/acme/server/snakeoil-certs.nix; mobilizonDomain = certs.domain; @@ -7,7 +8,10 @@ import ./make-test-python.nix ({ lib, ... }: { name = "mobilizon"; - meta.maintainers = with lib.maintainers; [ minijackson erictapen ]; + meta.maintainers = with lib.maintainers; [ + minijackson + erictapen + ]; nodes.server = { ... }: @@ -41,4 +45,5 @@ import ./make-test-python.nix ({ lib, ... }: server.wait_for_open_port(${toString port}) server.succeed("curl --fail https://${mobilizonDomain}/") ''; - }) + } +) diff --git a/nixos/tests/mod_perl.nix b/nixos/tests/mod_perl.nix index f29d79ea6206ac..677f2bcbc969fe 100644 --- a/nixos/tests/mod_perl.nix +++ b/nixos/tests/mod_perl.nix @@ -1,53 +1,65 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "mod_perl"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "mod_perl"; - meta = with pkgs.lib.maintainers; { - maintainers = [ sgo ]; - }; + meta = with pkgs.lib.maintainers; { + maintainers = [ sgo ]; + }; - nodes.machine = { config, lib, pkgs, ... }: { - services.httpd = { - enable = true; - adminAddr = "admin@localhost"; - virtualHosts."modperl" = - let - inc = pkgs.writeTextDir "ModPerlTest.pm" '' - package ModPerlTest; - use strict; - use Apache2::RequestRec (); - use Apache2::RequestIO (); - use Apache2::Const -compile => qw(OK); - sub handler { - my $r = shift; - $r->content_type('text/plain'); - print "Hello mod_perl!\n"; - return Apache2::Const::OK; - } - 1; - ''; - startup = pkgs.writeScript "startup.pl" '' - use lib "${inc}", - split ":","${with pkgs.perl.pkgs; makeFullPerlPath ([ mod_perl2 ])}"; - 1; - ''; - in - { - extraConfig = '' - PerlRequire ${startup} - ''; - locations."/modperl" = { - extraConfig = '' - SetHandler perl-script - PerlResponseHandler ModPerlTest - ''; - }; + nodes.machine = + { + config, + lib, + pkgs, + ... + }: + { + services.httpd = { + enable = true; + adminAddr = "admin@localhost"; + virtualHosts."modperl" = + let + inc = pkgs.writeTextDir "ModPerlTest.pm" '' + package ModPerlTest; + use strict; + use Apache2::RequestRec (); + use Apache2::RequestIO (); + use Apache2::Const -compile => qw(OK); + sub handler { + my $r = shift; + $r->content_type('text/plain'); + print "Hello mod_perl!\n"; + return Apache2::Const::OK; + } + 1; + ''; + startup = pkgs.writeScript "startup.pl" '' + use lib "${inc}", + split ":","${with pkgs.perl.pkgs; makeFullPerlPath ([ mod_perl2 ])}"; + 1; + ''; + in + { + extraConfig = '' + PerlRequire ${startup} + ''; + locations."/modperl" = { + extraConfig = '' + SetHandler perl-script + PerlResponseHandler ModPerlTest + ''; + }; + }; + enablePerl = true; }; - enablePerl = true; - }; - }; - testScript = { ... }: '' - machine.wait_for_unit("httpd.service") - response = machine.succeed("curl -fvvv -s http://127.0.0.1:80/modperl") - assert "Hello mod_perl!" in response, "/modperl handler did not respond" - ''; -}) + }; + testScript = + { ... }: + '' + machine.wait_for_unit("httpd.service") + response = machine.succeed("curl -fvvv -s http://127.0.0.1:80/modperl") + assert "Hello mod_perl!" in response, "/modperl handler did not respond" + ''; + } +) diff --git a/nixos/tests/molly-brown.nix b/nixos/tests/molly-brown.nix index bfc036e81ba040..72e42c4a5be84d 100644 --- a/nixos/tests/molly-brown.nix +++ b/nixos/tests/molly-brown.nix @@ -1,18 +1,25 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: - let testString = "NixOS Gemini test successful"; - in { + let + testString = "NixOS Gemini test successful"; + in + { name = "molly-brown"; - meta = with pkgs.lib.maintainers; { maintainers = [ ehmry ]; }; + meta = with pkgs.lib.maintainers; { + maintainers = [ ehmry ]; + }; nodes = { - geminiServer = { config, pkgs, ... }: + geminiServer = + { config, pkgs, ... }: let inherit (config.networking) hostName; cfg = config.services.molly-brown; - in { + in + { environment.systemPackages = [ (pkgs.writeScriptBin "test-gemini" '' @@ -68,4 +75,5 @@ import ./make-test-python.nix ({ pkgs, ... }: geminiServer.succeed("test-gemini") ''; - }) + } +) diff --git a/nixos/tests/mollysocket.nix b/nixos/tests/mollysocket.nix index 5135d79fcba9b9..ccfc20fdda6b23 100644 --- a/nixos/tests/mollysocket.nix +++ b/nixos/tests/mollysocket.nix @@ -1,25 +1,30 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: -let - port = 1234; -in { - name = "mollysocket"; - meta.maintainers = with lib.maintainers; [ dotlambda ]; + let + port = 1234; + in + { + name = "mollysocket"; + meta.maintainers = with lib.maintainers; [ dotlambda ]; - nodes.mollysocket = { ... }: { - services.mollysocket = { - enable = true; - settings = { - inherit port; + nodes.mollysocket = + { ... }: + { + services.mollysocket = { + enable = true; + settings = { + inherit port; + }; + }; }; - }; - }; - testScript = '' - mollysocket.wait_for_unit("mollysocket.service") - mollysocket.wait_for_open_port(${toString port}) + testScript = '' + mollysocket.wait_for_unit("mollysocket.service") + mollysocket.wait_for_open_port(${toString port}) - out = mollysocket.succeed("curl --fail http://127.0.0.1:${toString port}") - assert "Version ${pkgs.mollysocket.version}" in out - ''; -}) + out = mollysocket.succeed("curl --fail http://127.0.0.1:${toString port}") + assert "Version ${pkgs.mollysocket.version}" in out + ''; + } +) diff --git a/nixos/tests/monetdb.nix b/nixos/tests/monetdb.nix index acbf01f7697564..53c732338554c9 100644 --- a/nixos/tests/monetdb.nix +++ b/nixos/tests/monetdb.nix @@ -1,57 +1,60 @@ -import ./make-test-python.nix ({ pkgs, ...} : - let creds = pkgs.writeText ".monetdb" '' - user=monetdb - password=monetdb - ''; - createUser = pkgs.writeText "createUser.sql" '' - CREATE USER "voc" WITH PASSWORD 'voc' NAME 'VOC Explorer' SCHEMA "sys"; - CREATE SCHEMA "voc" AUTHORIZATION "voc"; - ALTER USER "voc" SET SCHEMA "voc"; - ''; - credsVoc = pkgs.writeText ".monetdb" '' - user=voc - password=voc - ''; - transaction = pkgs.writeText "transaction" '' - START TRANSACTION; - CREATE TABLE test (id int, data varchar(30)); - ROLLBACK; - ''; - vocData = pkgs.fetchzip { - url = "https://dev.monetdb.org/Assets/VOC/voc_dump.zip"; - hash = "sha256-sQ5acTsSAiXQfOgt2PhN7X7Z9TZGZtLrPPxgQT2pCGQ="; - }; - onboardPeople = pkgs.writeText "onboardPeople" '' - CREATE VIEW onboard_people AS - SELECT * FROM ( - SELECT 'craftsmen' AS type, craftsmen.* FROM craftsmen - UNION ALL - SELECT 'impotenten' AS type, impotenten.* FROM impotenten - UNION ALL - SELECT 'passengers' AS type, passengers.* FROM passengers - UNION ALL - SELECT 'seafarers' AS type, seafarers.* FROM seafarers - UNION ALL - SELECT 'soldiers' AS type, soldiers.* FROM soldiers - UNION ALL - SELECT 'total' AS type, total.* FROM total - ) AS onboard_people_table; - SELECT type, COUNT(*) AS total - FROM onboard_people GROUP BY type ORDER BY type; - ''; - onboardExpected = pkgs.lib.strings.replaceStrings ["\n"] ["\\n"] '' - +------------+-------+ - | type | total | - +============+=======+ - | craftsmen | 2349 | - | impotenten | 938 | - | passengers | 2813 | - | seafarers | 4468 | - | soldiers | 4177 | - | total | 2467 | - +------------+-------+ - ''; - in { +import ./make-test-python.nix ( + { pkgs, ... }: + let + creds = pkgs.writeText ".monetdb" '' + user=monetdb + password=monetdb + ''; + createUser = pkgs.writeText "createUser.sql" '' + CREATE USER "voc" WITH PASSWORD 'voc' NAME 'VOC Explorer' SCHEMA "sys"; + CREATE SCHEMA "voc" AUTHORIZATION "voc"; + ALTER USER "voc" SET SCHEMA "voc"; + ''; + credsVoc = pkgs.writeText ".monetdb" '' + user=voc + password=voc + ''; + transaction = pkgs.writeText "transaction" '' + START TRANSACTION; + CREATE TABLE test (id int, data varchar(30)); + ROLLBACK; + ''; + vocData = pkgs.fetchzip { + url = "https://dev.monetdb.org/Assets/VOC/voc_dump.zip"; + hash = "sha256-sQ5acTsSAiXQfOgt2PhN7X7Z9TZGZtLrPPxgQT2pCGQ="; + }; + onboardPeople = pkgs.writeText "onboardPeople" '' + CREATE VIEW onboard_people AS + SELECT * FROM ( + SELECT 'craftsmen' AS type, craftsmen.* FROM craftsmen + UNION ALL + SELECT 'impotenten' AS type, impotenten.* FROM impotenten + UNION ALL + SELECT 'passengers' AS type, passengers.* FROM passengers + UNION ALL + SELECT 'seafarers' AS type, seafarers.* FROM seafarers + UNION ALL + SELECT 'soldiers' AS type, soldiers.* FROM soldiers + UNION ALL + SELECT 'total' AS type, total.* FROM total + ) AS onboard_people_table; + SELECT type, COUNT(*) AS total + FROM onboard_people GROUP BY type ORDER BY type; + ''; + onboardExpected = pkgs.lib.strings.replaceStrings [ "\n" ] [ "\\n" ] '' + +------------+-------+ + | type | total | + +============+=======+ + | craftsmen | 2349 | + | impotenten | 938 | + | passengers | 2813 | + | seafarers | 4468 | + | soldiers | 4177 | + | total | 2467 | + +------------+-------+ + ''; + in + { name = "monetdb"; meta = with pkgs.lib.maintainers; { maintainers = [ StillerHarpo ]; @@ -73,5 +76,6 @@ import ./make-test-python.nix ({ pkgs, ...} : assert "8131" in machine.succeed("mclient -d voc -s \"SELECT count(*) FROM voyages\"") assert "${onboardExpected}" in machine.succeed("mclient -d voc ${onboardPeople}") - ''; - }) + ''; + } +) diff --git a/nixos/tests/mongodb.nix b/nixos/tests/mongodb.nix index d82d5080e69c2e..a42ba0abf4239e 100644 --- a/nixos/tests/mongodb.nix +++ b/nixos/tests/mongodb.nix @@ -1,6 +1,7 @@ # This test start mongodb, runs a query using mongo shell -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: let testQuery = pkgs.writeScript "nixtest.js" '' db.greetings.insert({ "greeting": "hello" }); @@ -24,26 +25,35 @@ import ./make-test-python.nix ({ pkgs, ... }: node.wait_for_closed_port(27017) ''; - in { + in + { name = "mongodb"; meta = with pkgs.lib.maintainers; { - maintainers = [ bluescreen303 offline phile314 ]; + maintainers = [ + bluescreen303 + offline + phile314 + ]; }; nodes = { - node = {...}: { - environment.systemPackages = with pkgs; [ - # remember to update mongodb.passthru.tests if you change this - mongodb-7_0 - ]; - }; + node = + { ... }: + { + environment.systemPackages = with pkgs; [ + # remember to update mongodb.passthru.tests if you change this + mongodb-7_0 + ]; + }; }; - testScript = '' - node.start() - '' + testScript = + '' + node.start() + '' + runMongoDBTest pkgs.mongodb-7_0 + '' node.shutdown() ''; - }) + } +) diff --git a/nixos/tests/moodle.nix b/nixos/tests/moodle.nix index 8fd011e0cb21fd..4bf1c5e6c702dc 100644 --- a/nixos/tests/moodle.nix +++ b/nixos/tests/moodle.nix @@ -1,22 +1,26 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "moodle"; - meta.maintainers = [ lib.maintainers.aanderse ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "moodle"; + meta.maintainers = [ lib.maintainers.aanderse ]; - nodes.machine = - { ... }: - { services.moodle.enable = true; - services.moodle.virtualHost.hostName = "localhost"; - services.moodle.virtualHost.adminAddr = "root@example.com"; - services.moodle.initialPassword = "correcthorsebatterystaple"; + nodes.machine = + { ... }: + { + services.moodle.enable = true; + services.moodle.virtualHost.hostName = "localhost"; + services.moodle.virtualHost.adminAddr = "root@example.com"; + services.moodle.initialPassword = "correcthorsebatterystaple"; - # Ensure the virtual machine has enough memory to avoid errors like: - # Fatal error: Out of memory (allocated 152047616) (tried to allocate 33554440 bytes) - virtualisation.memorySize = 2000; - }; + # Ensure the virtual machine has enough memory to avoid errors like: + # Fatal error: Out of memory (allocated 152047616) (tried to allocate 33554440 bytes) + virtualisation.memorySize = 2000; + }; - testScript = '' - start_all() - machine.wait_for_unit("phpfpm-moodle.service", timeout=1800) - machine.wait_until_succeeds("curl http://localhost/ | grep 'You are not logged in'") - ''; -}) + testScript = '' + start_all() + machine.wait_for_unit("phpfpm-moodle.service", timeout=1800) + machine.wait_until_succeeds("curl http://localhost/ | grep 'You are not logged in'") + ''; + } +) diff --git a/nixos/tests/moonraker.nix b/nixos/tests/moonraker.nix index b0a93a4a608b4f..7eb43b68d1ee36 100644 --- a/nixos/tests/moonraker.nix +++ b/nixos/tests/moonraker.nix @@ -1,45 +1,53 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "moonraker"; - meta = with pkgs.lib.maintainers; { - maintainers = [ zhaofengli ]; - }; - - nodes = { - printer = { config, pkgs, ... }: { - security.polkit.enable = true; - - services.moonraker = { - enable = true; - allowSystemControl = true; - - settings = { - authorization = { - trusted_clients = [ "127.0.0.0/8" "::1/128" ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "moonraker"; + meta = with pkgs.lib.maintainers; { + maintainers = [ zhaofengli ]; + }; + + nodes = { + printer = + { config, pkgs, ... }: + { + security.polkit.enable = true; + + services.moonraker = { + enable = true; + allowSystemControl = true; + + settings = { + authorization = { + trusted_clients = [ + "127.0.0.0/8" + "::1/128" + ]; + }; + }; }; - }; - }; - services.klipper = { - enable = true; + services.klipper = { + enable = true; - user = "moonraker"; - group = "moonraker"; + user = "moonraker"; + group = "moonraker"; - # No mcu configured so won't even enter `ready` state - settings = {}; - }; + # No mcu configured so won't even enter `ready` state + settings = { }; + }; + }; }; - }; - testScript = '' - printer.start() + testScript = '' + printer.start() - printer.wait_for_unit("klipper.service") - printer.wait_for_unit("moonraker.service") - printer.wait_until_succeeds("curl http://localhost:7125/printer/info | grep -v 'Not Found' >&2", timeout=30) + printer.wait_for_unit("klipper.service") + printer.wait_for_unit("moonraker.service") + printer.wait_until_succeeds("curl http://localhost:7125/printer/info | grep -v 'Not Found' >&2", timeout=30) - with subtest("Check that we can perform system-level operations"): - printer.succeed("curl -X POST http://localhost:7125/machine/services/stop?service=klipper | grep ok >&2") - printer.wait_until_succeeds("systemctl --no-pager show klipper.service | grep ActiveState=inactive", timeout=10) - ''; -}) + with subtest("Check that we can perform system-level operations"): + printer.succeed("curl -X POST http://localhost:7125/machine/services/stop?service=klipper | grep ok >&2") + printer.wait_until_succeeds("systemctl --no-pager show klipper.service | grep ActiveState=inactive", timeout=10) + ''; + } +) diff --git a/nixos/tests/moosefs.nix b/nixos/tests/moosefs.nix index 0dc08748b82817..ca351c3a885547 100644 --- a/nixos/tests/moosefs.nix +++ b/nixos/tests/moosefs.nix @@ -1,89 +1,100 @@ -import ./make-test-python.nix ({ pkgs, ... } : +import ./make-test-python.nix ( + { pkgs, ... }: -let - master = { pkgs, ... } : { - # data base is stored in memory - # server crashes with default memory size - virtualisation.memorySize = 1024; + let + master = + { pkgs, ... }: + { + # data base is stored in memory + # server crashes with default memory size + virtualisation.memorySize = 1024; - services.moosefs.master = { - enable = true; - openFirewall = true; - exports = [ - "* / rw,alldirs,admin,maproot=0:0" - "* . rw" - ]; - }; - }; + services.moosefs.master = { + enable = true; + openFirewall = true; + exports = [ + "* / rw,alldirs,admin,maproot=0:0" + "* . rw" + ]; + }; + }; - chunkserver = { pkgs, ... } : { - virtualisation.emptyDiskImages = [ 4096 ]; - boot.initrd.postDeviceCommands = '' - ${pkgs.e2fsprogs}/bin/mkfs.ext4 -L data /dev/vdb - ''; + chunkserver = + { pkgs, ... }: + { + virtualisation.emptyDiskImages = [ 4096 ]; + boot.initrd.postDeviceCommands = '' + ${pkgs.e2fsprogs}/bin/mkfs.ext4 -L data /dev/vdb + ''; - fileSystems = pkgs.lib.mkVMOverride { - "/data" = { - device = "/dev/disk/by-label/data"; - fsType = "ext4"; - }; - }; + fileSystems = pkgs.lib.mkVMOverride { + "/data" = { + device = "/dev/disk/by-label/data"; + fsType = "ext4"; + }; + }; - services.moosefs = { - masterHost = "master"; - chunkserver = { - openFirewall = true; - enable = true; - hdds = [ "~/data" ]; + services.moosefs = { + masterHost = "master"; + chunkserver = { + openFirewall = true; + enable = true; + hdds = [ "~/data" ]; + }; + }; }; - }; - }; - metalogger = { pkgs, ... } : { - services.moosefs = { - masterHost = "master"; - metalogger.enable = true; - }; - }; + metalogger = + { pkgs, ... }: + { + services.moosefs = { + masterHost = "master"; + metalogger.enable = true; + }; + }; - client = { pkgs, ... } : { - services.moosefs.client.enable = true; - }; + client = + { pkgs, ... }: + { + services.moosefs.client.enable = true; + }; -in { - name = "moosefs"; + in + { + name = "moosefs"; - nodes= { - inherit master; - inherit metalogger; - chunkserver1 = chunkserver; - chunkserver2 = chunkserver; - client1 = client; - client2 = client; - }; + nodes = { + inherit master; + inherit metalogger; + chunkserver1 = chunkserver; + chunkserver2 = chunkserver; + client1 = client; + client2 = client; + }; - testScript = '' - # prepare master server - master.start() - master.wait_for_unit("multi-user.target") - master.succeed("mfsmaster-init") - master.succeed("systemctl restart mfs-master") - master.wait_for_unit("mfs-master.service") + testScript = '' + # prepare master server + master.start() + master.wait_for_unit("multi-user.target") + master.succeed("mfsmaster-init") + master.succeed("systemctl restart mfs-master") + master.wait_for_unit("mfs-master.service") - metalogger.wait_for_unit("mfs-metalogger.service") + metalogger.wait_for_unit("mfs-metalogger.service") - for chunkserver in [chunkserver1, chunkserver2]: - chunkserver.wait_for_unit("multi-user.target") - chunkserver.succeed("chown moosefs:moosefs /data") - chunkserver.succeed("systemctl restart mfs-chunkserver") - chunkserver.wait_for_unit("mfs-chunkserver.service") + for chunkserver in [chunkserver1, chunkserver2]: + chunkserver.wait_for_unit("multi-user.target") + chunkserver.succeed("chown moosefs:moosefs /data") + chunkserver.succeed("systemctl restart mfs-chunkserver") + chunkserver.wait_for_unit("mfs-chunkserver.service") - for client in [client1, client2]: - client.wait_for_unit("multi-user.target") - client.succeed("mkdir /moosefs") - client.succeed("mount -t moosefs master:/ /moosefs") + for client in [client1, client2]: + client.wait_for_unit("multi-user.target") + client.succeed("mkdir /moosefs") + client.succeed("mount -t moosefs master:/ /moosefs") - client1.succeed("echo test > /moosefs/file") - client2.succeed("grep test /moosefs/file") - ''; -}) + client1.succeed("echo test > /moosefs/file") + client2.succeed("grep test /moosefs/file") + ''; + } +) diff --git a/nixos/tests/morph-browser.nix b/nixos/tests/morph-browser.nix index 65ad4d85cc12e1..ec526e31c3c392 100644 --- a/nixos/tests/morph-browser.nix +++ b/nixos/tests/morph-browser.nix @@ -1,36 +1,39 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "morph-browser-standalone"; - meta.maintainers = lib.teams.lomiri.members; - - nodes.machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; - - services.xserver.enable = true; - - environment = { - systemPackages = with pkgs.lomiri; [ - suru-icon-theme - morph-browser - ]; - variables = { - UITK_ICON_THEME = "suru"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "morph-browser-standalone"; + meta.maintainers = lib.teams.lomiri.members; + + nodes.machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; + + services.xserver.enable = true; + + environment = { + systemPackages = with pkgs.lomiri; [ + suru-icon-theme + morph-browser + ]; + variables = { + UITK_ICON_THEME = "suru"; + }; + }; + + i18n.supportedLocales = [ "all" ]; + + fonts.packages = with pkgs; [ + # Intended font & helps with OCR + ubuntu-classic + ]; }; - }; - i18n.supportedLocales = [ "all" ]; + enableOCR = true; - fonts.packages = with pkgs; [ - # Intended font & helps with OCR - ubuntu-classic - ]; - }; - - enableOCR = true; - - testScript = - '' + testScript = '' machine.wait_for_x() with subtest("morph browser launches"): @@ -50,4 +53,5 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: { machine.wait_for_text(r"Web-Browser|Neuer|Seiten|Lesezeichen") machine.screenshot("morph_localised") ''; -}) + } +) diff --git a/nixos/tests/morty.nix b/nixos/tests/morty.nix index 9909596820d318..4ec44e31d487ef 100644 --- a/nixos/tests/morty.nix +++ b/nixos/tests/morty.nix @@ -1,30 +1,33 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -{ - name = "morty"; - meta = with pkgs.lib.maintainers; { - maintainers = [ leenaars ]; - }; + { + name = "morty"; + meta = with pkgs.lib.maintainers; { + maintainers = [ leenaars ]; + }; - nodes = - { mortyProxyWithKey = + nodes = { + mortyProxyWithKey = - { ... }: - { services.morty = { - enable = true; - key = "78a9cd0cfee20c672f78427efb2a2a96036027f0"; - port = 3001; + { ... }: + { + services.morty = { + enable = true; + key = "78a9cd0cfee20c672f78427efb2a2a96036027f0"; + port = 3001; + }; }; - }; }; - testScript = - { ... }: - '' - mortyProxyWithKey.wait_for_unit("default.target") - mortyProxyWithKey.wait_for_open_port(3001) - mortyProxyWithKey.succeed("curl -fL 127.0.0.1:3001 | grep MortyProxy") - ''; + testScript = + { ... }: + '' + mortyProxyWithKey.wait_for_unit("default.target") + mortyProxyWithKey.wait_for_open_port(3001) + mortyProxyWithKey.succeed("curl -fL 127.0.0.1:3001 | grep MortyProxy") + ''; -}) + } +) diff --git a/nixos/tests/mosquitto.nix b/nixos/tests/mosquitto.nix index eca29292721fde..30c7e3bcd32c0f 100644 --- a/nixos/tests/mosquitto.nix +++ b/nixos/tests/mosquitto.nix @@ -1,213 +1,229 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: - -let - port = 1888; - tlsPort = 1889; - anonPort = 1890; - password = "VERY_secret"; - hashedPassword = "$7$101$/WJc4Mp+I+uYE9sR$o7z9rD1EYXHPwEP5GqQj6A7k4W1yVbePlb8TqNcuOLV9WNCiDgwHOB0JHC1WCtdkssqTBduBNUnUGd6kmZvDSw=="; - topic = "test/foo"; - - snakeOil = pkgs.runCommand "snakeoil-certs" { - buildInputs = [ pkgs.gnutls.bin ]; - caTemplate = pkgs.writeText "snakeoil-ca.template" '' - cn = server - expiration_days = -1 - cert_signing_key - ca - ''; - certTemplate = pkgs.writeText "snakeoil-cert.template" '' - cn = server - expiration_days = -1 - tls_www_server - encryption_key - signing_key - ''; - userCertTemplate = pkgs.writeText "snakeoil-user-cert.template" '' - organization = snakeoil - cn = client1 - expiration_days = -1 - tls_www_client - encryption_key - signing_key - ''; - } '' - mkdir "$out" - - certtool -p --bits 2048 --outfile "$out/ca.key" - certtool -s --template "$caTemplate" --load-privkey "$out/ca.key" \ - --outfile "$out/ca.crt" - certtool -p --bits 2048 --outfile "$out/server.key" - certtool -c --template "$certTemplate" \ - --load-ca-privkey "$out/ca.key" \ - --load-ca-certificate "$out/ca.crt" \ - --load-privkey "$out/server.key" \ - --outfile "$out/server.crt" - - certtool -p --bits 2048 --outfile "$out/client1.key" - certtool -c --template "$userCertTemplate" \ - --load-privkey "$out/client1.key" \ - --load-ca-privkey "$out/ca.key" \ - --load-ca-certificate "$out/ca.crt" \ - --outfile "$out/client1.crt" - ''; - -in { - name = "mosquitto"; - meta = with pkgs.lib; { - maintainers = with maintainers; [ peterhoeg ]; - }; - - nodes = let - client = { pkgs, ... }: { - environment.systemPackages = with pkgs; [ mosquitto ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + let + port = 1888; + tlsPort = 1889; + anonPort = 1890; + password = "VERY_secret"; + hashedPassword = "$7$101$/WJc4Mp+I+uYE9sR$o7z9rD1EYXHPwEP5GqQj6A7k4W1yVbePlb8TqNcuOLV9WNCiDgwHOB0JHC1WCtdkssqTBduBNUnUGd6kmZvDSw=="; + topic = "test/foo"; + + snakeOil = + pkgs.runCommand "snakeoil-certs" + { + buildInputs = [ pkgs.gnutls.bin ]; + caTemplate = pkgs.writeText "snakeoil-ca.template" '' + cn = server + expiration_days = -1 + cert_signing_key + ca + ''; + certTemplate = pkgs.writeText "snakeoil-cert.template" '' + cn = server + expiration_days = -1 + tls_www_server + encryption_key + signing_key + ''; + userCertTemplate = pkgs.writeText "snakeoil-user-cert.template" '' + organization = snakeoil + cn = client1 + expiration_days = -1 + tls_www_client + encryption_key + signing_key + ''; + } + '' + mkdir "$out" + + certtool -p --bits 2048 --outfile "$out/ca.key" + certtool -s --template "$caTemplate" --load-privkey "$out/ca.key" \ + --outfile "$out/ca.crt" + certtool -p --bits 2048 --outfile "$out/server.key" + certtool -c --template "$certTemplate" \ + --load-ca-privkey "$out/ca.key" \ + --load-ca-certificate "$out/ca.crt" \ + --load-privkey "$out/server.key" \ + --outfile "$out/server.crt" + + certtool -p --bits 2048 --outfile "$out/client1.key" + certtool -c --template "$userCertTemplate" \ + --load-privkey "$out/client1.key" \ + --load-ca-privkey "$out/ca.key" \ + --load-ca-certificate "$out/ca.crt" \ + --outfile "$out/client1.crt" + ''; + + in + { + name = "mosquitto"; + meta = with pkgs.lib; { + maintainers = with maintainers; [ peterhoeg ]; }; - in { - server = { pkgs, ... }: { - networking.firewall.allowedTCPPorts = [ port tlsPort anonPort ]; - networking.useNetworkd = true; - services.mosquitto = { - enable = true; - settings = { - sys_interval = 1; - }; - listeners = [ - { - inherit port; - users = { - password_store = { - inherit password; - }; - password_file = { - passwordFile = pkgs.writeText "mqtt-password" password; - }; - hashed_store = { - inherit hashedPassword; - }; - hashed_file = { - hashedPasswordFile = pkgs.writeText "mqtt-hashed-password" hashedPassword; - }; - reader = { - inherit password; - acl = [ - "read ${topic}" - "read $SYS/#" # so we always have something to read - ]; - }; - writer = { - inherit password; - acl = [ "write ${topic}" ]; - }; - }; - } + nodes = + let + client = + { pkgs, ... }: { - port = tlsPort; - users.client1 = { - acl = [ "read $SYS/#" ]; - }; - settings = { - cafile = "${snakeOil}/ca.crt"; - certfile = "${snakeOil}/server.crt"; - keyfile = "${snakeOil}/server.key"; - require_certificate = true; - use_identity_as_username = true; - }; - } + environment.systemPackages = with pkgs; [ mosquitto ]; + }; + in + { + server = + { pkgs, ... }: { - port = anonPort; - omitPasswordAuth = true; - settings.allow_anonymous = true; - acl = [ "pattern read #" ]; - users = { - anonWriter = { - password = "<ignored>" + password; - acl = [ "write ${topic}" ]; + networking.firewall.allowedTCPPorts = [ + port + tlsPort + anonPort + ]; + networking.useNetworkd = true; + services.mosquitto = { + enable = true; + settings = { + sys_interval = 1; }; + listeners = [ + { + inherit port; + users = { + password_store = { + inherit password; + }; + password_file = { + passwordFile = pkgs.writeText "mqtt-password" password; + }; + hashed_store = { + inherit hashedPassword; + }; + hashed_file = { + hashedPasswordFile = pkgs.writeText "mqtt-hashed-password" hashedPassword; + }; + + reader = { + inherit password; + acl = [ + "read ${topic}" + "read $SYS/#" # so we always have something to read + ]; + }; + writer = { + inherit password; + acl = [ "write ${topic}" ]; + }; + }; + } + { + port = tlsPort; + users.client1 = { + acl = [ "read $SYS/#" ]; + }; + settings = { + cafile = "${snakeOil}/ca.crt"; + certfile = "${snakeOil}/server.crt"; + keyfile = "${snakeOil}/server.key"; + require_certificate = true; + use_identity_as_username = true; + }; + } + { + port = anonPort; + omitPasswordAuth = true; + settings.allow_anonymous = true; + acl = [ "pattern read #" ]; + users = { + anonWriter = { + password = "<ignored>" + password; + acl = [ "write ${topic}" ]; + }; + }; + } + ]; }; - } - ]; + }; + + client1 = client; + client2 = client; }; - }; - client1 = client; - client2 = client; - }; - - testScript = '' - def mosquitto_cmd(binary, user, topic, port): - return ( - "mosquitto_{} " - "-V mqttv311 " - "-h server " - "-p {} " - "-u {} " - "-P '${password}' " - "-t '{}'" - ).format(binary, port, user, topic) - - - def publish(args, user, topic="${topic}", port=${toString port}): - return "{} {}".format(mosquitto_cmd("pub", user, topic, port), args) - - def subscribe(args, user, topic="${topic}", port=${toString port}): - return "{} -W 5 -C 1 {}".format(mosquitto_cmd("sub", user, topic, port), args) - - def parallel(*fns): - from threading import Thread - threads = [ Thread(target=fn) for fn in fns ] - for t in threads: t.start() - for t in threads: t.join() - - def wait_uuid(uuid): - server.wait_for_console_text(uuid) - return None - - - start_all() - server.wait_for_unit("mosquitto.service") - - with subtest("check passwords"): - client1.succeed(publish("-m test", "password_store")) - client1.succeed(publish("-m test", "password_file")) - client1.succeed(publish("-m test", "hashed_store")) - client1.succeed(publish("-m test", "hashed_file")) - - with subtest("check acl"): - client1.succeed(subscribe("", "reader", topic="$SYS/#")) - client1.fail(subscribe("", "writer", topic="$SYS/#")) - - parallel( - lambda: client1.succeed(subscribe("-i 3688cdd7-aa07-42a4-be22-cb9352917e40", "reader")), - lambda: [ - wait_uuid("3688cdd7-aa07-42a4-be22-cb9352917e40"), - client2.succeed(publish("-m test", "writer")) - ]) - - parallel( - lambda: client1.fail(subscribe("-i 24ff16a2-ae33-4a51-9098-1b417153c712", "reader")), - lambda: [ - wait_uuid("24ff16a2-ae33-4a51-9098-1b417153c712"), - client2.succeed(publish("-m test", "reader")) - ]) - - with subtest("check tls"): - client1.succeed( - subscribe( - "--cafile ${snakeOil}/ca.crt " - "--cert ${snakeOil}/client1.crt " - "--key ${snakeOil}/client1.key", - topic="$SYS/#", - port=${toString tlsPort}, - user="no_such_user")) - - with subtest("check omitPasswordAuth"): - parallel( - lambda: client1.succeed(subscribe("-i fd56032c-d9cb-4813-a3b4-6be0e04c8fc3", - "anonReader", port=${toString anonPort})), - lambda: [ - wait_uuid("fd56032c-d9cb-4813-a3b4-6be0e04c8fc3"), - client2.succeed(publish("-m test", "anonWriter", port=${toString anonPort})) - ]) - ''; -}) + testScript = '' + def mosquitto_cmd(binary, user, topic, port): + return ( + "mosquitto_{} " + "-V mqttv311 " + "-h server " + "-p {} " + "-u {} " + "-P '${password}' " + "-t '{}'" + ).format(binary, port, user, topic) + + + def publish(args, user, topic="${topic}", port=${toString port}): + return "{} {}".format(mosquitto_cmd("pub", user, topic, port), args) + + def subscribe(args, user, topic="${topic}", port=${toString port}): + return "{} -W 5 -C 1 {}".format(mosquitto_cmd("sub", user, topic, port), args) + + def parallel(*fns): + from threading import Thread + threads = [ Thread(target=fn) for fn in fns ] + for t in threads: t.start() + for t in threads: t.join() + + def wait_uuid(uuid): + server.wait_for_console_text(uuid) + return None + + + start_all() + server.wait_for_unit("mosquitto.service") + + with subtest("check passwords"): + client1.succeed(publish("-m test", "password_store")) + client1.succeed(publish("-m test", "password_file")) + client1.succeed(publish("-m test", "hashed_store")) + client1.succeed(publish("-m test", "hashed_file")) + + with subtest("check acl"): + client1.succeed(subscribe("", "reader", topic="$SYS/#")) + client1.fail(subscribe("", "writer", topic="$SYS/#")) + + parallel( + lambda: client1.succeed(subscribe("-i 3688cdd7-aa07-42a4-be22-cb9352917e40", "reader")), + lambda: [ + wait_uuid("3688cdd7-aa07-42a4-be22-cb9352917e40"), + client2.succeed(publish("-m test", "writer")) + ]) + + parallel( + lambda: client1.fail(subscribe("-i 24ff16a2-ae33-4a51-9098-1b417153c712", "reader")), + lambda: [ + wait_uuid("24ff16a2-ae33-4a51-9098-1b417153c712"), + client2.succeed(publish("-m test", "reader")) + ]) + + with subtest("check tls"): + client1.succeed( + subscribe( + "--cafile ${snakeOil}/ca.crt " + "--cert ${snakeOil}/client1.crt " + "--key ${snakeOil}/client1.key", + topic="$SYS/#", + port=${toString tlsPort}, + user="no_such_user")) + + with subtest("check omitPasswordAuth"): + parallel( + lambda: client1.succeed(subscribe("-i fd56032c-d9cb-4813-a3b4-6be0e04c8fc3", + "anonReader", port=${toString anonPort})), + lambda: [ + wait_uuid("fd56032c-d9cb-4813-a3b4-6be0e04c8fc3"), + client2.succeed(publish("-m test", "anonWriter", port=${toString anonPort})) + ]) + ''; + } +) diff --git a/nixos/tests/mpv.nix b/nixos/tests/mpv.nix index c2e151c2247604..6ec24ae78cd454 100644 --- a/nixos/tests/mpv.nix +++ b/nixos/tests/mpv.nix @@ -1,26 +1,28 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -let - port = toString 4321; -in -{ - name = "mpv"; - meta.maintainers = with lib.maintainers; [ zopieux ]; + let + port = toString 4321; + in + { + name = "mpv"; + meta.maintainers = with lib.maintainers; [ zopieux ]; - nodes.machine = - { pkgs, ... }: - { - environment.systemPackages = [ - pkgs.curl - (pkgs.mpv.override { - scripts = [ pkgs.mpvScripts.simple-mpv-webui ]; - }) - ]; - }; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = [ + pkgs.curl + (pkgs.mpv.override { + scripts = [ pkgs.mpvScripts.simple-mpv-webui ]; + }) + ]; + }; - testScript = '' - machine.execute("set -m; mpv --script-opts=webui-port=${port} --idle=yes >&2 &") - machine.wait_for_open_port(${port}) - assert "<title>simple-mpv-webui" in machine.succeed("curl -s localhost:${port}") - ''; -}) + testScript = '' + machine.execute("set -m; mpv --script-opts=webui-port=${port} --idle=yes >&2 &") + machine.wait_for_open_port(${port}) + assert "<title>simple-mpv-webui" in machine.succeed("curl -s localhost:${port}") + ''; + } +) diff --git a/nixos/tests/mtp.nix b/nixos/tests/mtp.nix index 8f0835d75d3fea..b4efef0318aa19 100644 --- a/nixos/tests/mtp.nix +++ b/nixos/tests/mtp.nix @@ -1,109 +1,121 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "mtp"; - meta = with pkgs.lib.maintainers; { - maintainers = [ matthewcroughan nixinator ]; - }; - - nodes = +import ./make-test-python.nix ( + { pkgs, ... }: { - client = { config, pkgs, ... }: { - # DBUS runs only once a user session is created, which means a user has to - # login. Here, we log in as root. Once logged in, the gvfs-daemon service runs - # as UID 0 in User-0.service - services.getty.autologinUser = "root"; + name = "mtp"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + matthewcroughan + nixinator + ]; + }; - # XDG_RUNTIME_DIR is needed for running systemd-user services such as - # gvfs-daemon as root. - environment.variables.XDG_RUNTIME_DIR = "/run/user/0"; + nodes = { + client = + { config, pkgs, ... }: + { + # DBUS runs only once a user session is created, which means a user has to + # login. Here, we log in as root. Once logged in, the gvfs-daemon service runs + # as UID 0 in User-0.service + services.getty.autologinUser = "root"; - environment.systemPackages = with pkgs; [ usbutils glib jmtpfs tree ]; - services.gvfs.enable = true; + # XDG_RUNTIME_DIR is needed for running systemd-user services such as + # gvfs-daemon as root. + environment.variables.XDG_RUNTIME_DIR = "/run/user/0"; - # Creates a usb-mtp device inside the VM, which is mapped to the host's - # /tmp folder, it is able to write files to this location, but only has - # permissions to read its own creations. - virtualisation.qemu.options = [ - "-usb" - "-device usb-mtp,rootdir=/tmp,readonly=false" - ]; - }; - }; + environment.systemPackages = with pkgs; [ + usbutils + glib + jmtpfs + tree + ]; + services.gvfs.enable = true; + # Creates a usb-mtp device inside the VM, which is mapped to the host's + # /tmp folder, it is able to write files to this location, but only has + # permissions to read its own creations. + virtualisation.qemu.options = [ + "-usb" + "-device usb-mtp,rootdir=/tmp,readonly=false" + ]; + }; + }; - testScript = { nodes, ... }: - let - # Creates a list of QEMU MTP devices matching USB ID (46f4:0004). This - # value can be sourced in a shell script. This is so we can loop over the - # devices we find, as this test may want to use more than one MTP device - # in future. - mtpDevices = pkgs.writeScript "mtpDevices.sh" '' - export mtpDevices=$(lsusb -d 46f4:0004 | awk {'print $2","$4'} | sed 's/[:-]/ /g') - ''; - # Qemu is only capable of creating an MTP device with Picture Transfer - # Protocol. This means that gvfs must use gphoto2:// rather than mtp:// - # when mounting. - # https://github.com/qemu/qemu/blob/970bc16f60937bcfd334f14c614bd4407c247961/hw/usb/dev-mtp.c#L278 - gvfs = rec { - mountAllMtpDevices = pkgs.writeScript "mountAllMtpDevices.sh" '' - set -e - source ${mtpDevices} - for i in $mtpDevices - do - gio mount "gphoto2://[usb:$i]/" - done - ''; - unmountAllMtpDevices = pkgs.writeScript "unmountAllMtpDevices.sh" '' - set -e - source ${mtpDevices} - for i in $mtpDevices - do - gio mount -u "gphoto2://[usb:$i]/" - done - ''; - # gvfsTest: - # 1. Creates a 10M test file - # 2. Copies it to the device using GIO tools - # 3. Checks for corruption with `diff` - # 4. Removes the file, then unmounts the disks. - gvfsTest = pkgs.writeScript "gvfsTest.sh" '' - set -e - source ${mtpDevices} - ${mountAllMtpDevices} - dd if=/dev/urandom of=testFile10M bs=1M count=10 - for i in $mtpDevices - do - gio copy ./testFile10M gphoto2://[usb:$i]/ - ls -lah /run/user/0/gvfs/*/testFile10M - gio remove gphoto2://[usb:$i]/testFile10M - done - ${unmountAllMtpDevices} + testScript = + { nodes, ... }: + let + # Creates a list of QEMU MTP devices matching USB ID (46f4:0004). This + # value can be sourced in a shell script. This is so we can loop over the + # devices we find, as this test may want to use more than one MTP device + # in future. + mtpDevices = pkgs.writeScript "mtpDevices.sh" '' + export mtpDevices=$(lsusb -d 46f4:0004 | awk {'print $2","$4'} | sed 's/[:-]/ /g') ''; - }; - jmtpfs = { - # jmtpfsTest: - # 1. Mounts the device on a dir named `phone` using jmtpfs - # 2. Puts the current Nixpkgs libmtp version into a file - # 3. Checks for corruption with `diff` - # 4. Prints the directory tree - jmtpfsTest = pkgs.writeScript "jmtpfsTest.sh" '' - set -e - mkdir phone - jmtpfs phone - echo "${pkgs.libmtp.version}" > phone/tmp/testFile - echo "${pkgs.libmtp.version}" > testFile - diff phone/tmp/testFile testFile - tree phone - ''; - }; - in - # Using >&2 allows the results of the scripts to be printed to the terminal - # when building this test with Nix. Scripts would otherwise complete - # silently. - '' - start_all() - client.wait_for_unit("multi-user.target") - client.wait_for_unit("dbus.service") - client.succeed("${gvfs.gvfsTest} >&2") - client.succeed("${jmtpfs.jmtpfsTest} >&2") - ''; -}) + # Qemu is only capable of creating an MTP device with Picture Transfer + # Protocol. This means that gvfs must use gphoto2:// rather than mtp:// + # when mounting. + # https://github.com/qemu/qemu/blob/970bc16f60937bcfd334f14c614bd4407c247961/hw/usb/dev-mtp.c#L278 + gvfs = rec { + mountAllMtpDevices = pkgs.writeScript "mountAllMtpDevices.sh" '' + set -e + source ${mtpDevices} + for i in $mtpDevices + do + gio mount "gphoto2://[usb:$i]/" + done + ''; + unmountAllMtpDevices = pkgs.writeScript "unmountAllMtpDevices.sh" '' + set -e + source ${mtpDevices} + for i in $mtpDevices + do + gio mount -u "gphoto2://[usb:$i]/" + done + ''; + # gvfsTest: + # 1. Creates a 10M test file + # 2. Copies it to the device using GIO tools + # 3. Checks for corruption with `diff` + # 4. Removes the file, then unmounts the disks. + gvfsTest = pkgs.writeScript "gvfsTest.sh" '' + set -e + source ${mtpDevices} + ${mountAllMtpDevices} + dd if=/dev/urandom of=testFile10M bs=1M count=10 + for i in $mtpDevices + do + gio copy ./testFile10M gphoto2://[usb:$i]/ + ls -lah /run/user/0/gvfs/*/testFile10M + gio remove gphoto2://[usb:$i]/testFile10M + done + ${unmountAllMtpDevices} + ''; + }; + jmtpfs = { + # jmtpfsTest: + # 1. Mounts the device on a dir named `phone` using jmtpfs + # 2. Puts the current Nixpkgs libmtp version into a file + # 3. Checks for corruption with `diff` + # 4. Prints the directory tree + jmtpfsTest = pkgs.writeScript "jmtpfsTest.sh" '' + set -e + mkdir phone + jmtpfs phone + echo "${pkgs.libmtp.version}" > phone/tmp/testFile + echo "${pkgs.libmtp.version}" > testFile + diff phone/tmp/testFile testFile + tree phone + ''; + }; + in + # Using >&2 allows the results of the scripts to be printed to the terminal + # when building this test with Nix. Scripts would otherwise complete + # silently. + '' + start_all() + client.wait_for_unit("multi-user.target") + client.wait_for_unit("dbus.service") + client.succeed("${gvfs.gvfsTest} >&2") + client.succeed("${jmtpfs.jmtpfsTest} >&2") + ''; + } +) diff --git a/nixos/tests/multipass.nix b/nixos/tests/multipass.nix index 0980e9195f5aa1..da63a7a41fbbcf 100644 --- a/nixos/tests/multipass.nix +++ b/nixos/tests/multipass.nix @@ -1,37 +1,41 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: - -let - multipass-image = import ../release.nix { - configuration = { - # Building documentation makes the test unnecessarily take a longer time: - documentation.enable = lib.mkForce false; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + let + multipass-image = import ../release.nix { + configuration = { + # Building documentation makes the test unnecessarily take a longer time: + documentation.enable = lib.mkForce false; + }; }; - }; -in -{ - name = "multipass"; + in + { + name = "multipass"; - meta.maintainers = [ lib.maintainers.jnsgruk ]; + meta.maintainers = [ lib.maintainers.jnsgruk ]; - nodes.machine = { lib, ... }: { - virtualisation = { - cores = 1; - memorySize = 1024; - diskSize = 4096; + nodes.machine = + { lib, ... }: + { + virtualisation = { + cores = 1; + memorySize = 1024; + diskSize = 4096; - multipass.enable = true; - }; - }; + multipass.enable = true; + }; + }; - testScript = '' - machine.wait_for_unit("sockets.target") - machine.wait_for_unit("multipass.service") - machine.wait_for_file("/var/lib/multipass/data/multipassd/network/multipass_subnet") + testScript = '' + machine.wait_for_unit("sockets.target") + machine.wait_for_unit("multipass.service") + machine.wait_for_file("/var/lib/multipass/data/multipassd/network/multipass_subnet") - # Wait for Multipass to settle - machine.sleep(1) + # Wait for Multipass to settle + machine.sleep(1) - machine.succeed("multipass list") - ''; -}) + machine.succeed("multipass list") + ''; + } +) diff --git a/nixos/tests/mumble.nix b/nixos/tests/mumble.nix index 12fa00b79bbf8d..c8bbe473c2b1cc 100644 --- a/nixos/tests/mumble.nix +++ b/nixos/tests/mumble.nix @@ -1,89 +1,95 @@ -import ./make-test-python.nix ({ pkgs, ...} : +import ./make-test-python.nix ( + { pkgs, ... }: -let - client = { pkgs, ... }: { - imports = [ ./common/x11.nix ]; - environment.systemPackages = [ pkgs.mumble ]; - }; + let + client = + { pkgs, ... }: + { + imports = [ ./common/x11.nix ]; + environment.systemPackages = [ pkgs.mumble ]; + }; - # outside of tests, this file should obviously not come from the nix store - envFile = pkgs.writeText "nixos-test-mumble-murmurd.env" '' - MURMURD_PASSWORD=testpassword - ''; + # outside of tests, this file should obviously not come from the nix store + envFile = pkgs.writeText "nixos-test-mumble-murmurd.env" '' + MURMURD_PASSWORD=testpassword + ''; -in -{ - name = "mumble"; - meta = with pkgs.lib.maintainers; { - maintainers = [ thoughtpolice ]; - }; - - nodes = { - server = { config, ... }: { - security.apparmor.enable = true; - services.murmur.enable = true; - services.murmur.registerName = "NixOS tests"; - services.murmur.password = "$MURMURD_PASSWORD"; - services.murmur.environmentFile = envFile; - networking.firewall.allowedTCPPorts = [ config.services.murmur.port ]; + in + { + name = "mumble"; + meta = with pkgs.lib.maintainers; { + maintainers = [ thoughtpolice ]; }; - client1 = client; - client2 = client; - }; + nodes = { + server = + { config, ... }: + { + security.apparmor.enable = true; + services.murmur.enable = true; + services.murmur.registerName = "NixOS tests"; + services.murmur.password = "$MURMURD_PASSWORD"; + services.murmur.environmentFile = envFile; + networking.firewall.allowedTCPPorts = [ config.services.murmur.port ]; + }; + + client1 = client; + client2 = client; + }; - testScript = '' - start_all() + testScript = '' + start_all() - server.wait_for_unit("murmur.service") - client1.wait_for_x() - client2.wait_for_x() + server.wait_for_unit("murmur.service") + client1.wait_for_x() + client2.wait_for_x() - client1.execute("mumble mumble://client1:testpassword\@server/test >&2 &") - client2.execute("mumble mumble://client2:testpassword\@server/test >&2 &") + client1.execute("mumble mumble://client1:testpassword\@server/test >&2 &") + client2.execute("mumble mumble://client2:testpassword\@server/test >&2 &") - # cancel client audio configuration - client1.wait_for_window(r"Audio Tuning Wizard") - client2.wait_for_window(r"Audio Tuning Wizard") - server.sleep(5) # wait because mumble is slow to register event handlers - client1.send_key("esc") - client2.send_key("esc") + # cancel client audio configuration + client1.wait_for_window(r"Audio Tuning Wizard") + client2.wait_for_window(r"Audio Tuning Wizard") + server.sleep(5) # wait because mumble is slow to register event handlers + client1.send_key("esc") + client2.send_key("esc") - # cancel client cert configuration - client1.wait_for_window(r"Certificate Management") - client2.wait_for_window(r"Certificate Management") - server.sleep(5) # wait because mumble is slow to register event handlers - client1.send_key("esc") - client2.send_key("esc") + # cancel client cert configuration + client1.wait_for_window(r"Certificate Management") + client2.wait_for_window(r"Certificate Management") + server.sleep(5) # wait because mumble is slow to register event handlers + client1.send_key("esc") + client2.send_key("esc") - # accept server certificate - client1.wait_for_window(r"^Mumble$") - client2.wait_for_window(r"^Mumble$") - server.sleep(5) # wait because mumble is slow to register event handlers - client1.send_chars("y") - client2.send_chars("y") - server.sleep(5) # wait because mumble is slow to register event handlers + # accept server certificate + client1.wait_for_window(r"^Mumble$") + client2.wait_for_window(r"^Mumble$") + server.sleep(5) # wait because mumble is slow to register event handlers + client1.send_chars("y") + client2.send_chars("y") + server.sleep(5) # wait because mumble is slow to register event handlers - # sometimes the wrong of the 2 windows is focused, we switch focus and try pressing "y" again - client1.send_key("alt-tab") - client2.send_key("alt-tab") - server.sleep(5) # wait because mumble is slow to register event handlers - client1.send_chars("y") - client2.send_chars("y") + # sometimes the wrong of the 2 windows is focused, we switch focus and try pressing "y" again + client1.send_key("alt-tab") + client2.send_key("alt-tab") + server.sleep(5) # wait because mumble is slow to register event handlers + client1.send_chars("y") + client2.send_chars("y") - # Find clients in logs - server.wait_until_succeeds( - "journalctl -eu murmur -o cat | grep -q 'client1.\+Authenticated'" - ) - server.wait_until_succeeds( - "journalctl -eu murmur -o cat | grep -q 'client2.\+Authenticated'" - ) + # Find clients in logs + server.wait_until_succeeds( + "journalctl -eu murmur -o cat | grep -q 'client1.\+Authenticated'" + ) + server.wait_until_succeeds( + "journalctl -eu murmur -o cat | grep -q 'client2.\+Authenticated'" + ) - server.sleep(5) # wait to get screenshot - client1.screenshot("screen1") - client2.screenshot("screen2") + server.sleep(5) # wait to get screenshot + client1.screenshot("screen1") + client2.screenshot("screen2") - # check if apparmor denied anything - server.fail('journalctl -b --no-pager --grep "^audit: .*apparmor=\\"DENIED\\""') - ''; -}) + # check if apparmor denied anything + server.fail('journalctl -b --no-pager --grep "^audit: .*apparmor=\\"DENIED\\""') + ''; + } +) diff --git a/nixos/tests/munin.nix b/nixos/tests/munin.nix index 7b7bf6f41c046f..b28562bbaa2efd 100644 --- a/nixos/tests/munin.nix +++ b/nixos/tests/munin.nix @@ -1,15 +1,17 @@ # This test runs basic munin setup with node and cron job running on the same # machine. -import ./make-test-python.nix ({ pkgs, ...} : { - name = "munin"; - meta = with pkgs.lib.maintainers; { - maintainers = [ domenkozar ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "munin"; + meta = with pkgs.lib.maintainers; { + maintainers = [ domenkozar ]; + }; - nodes = { - one = - { config, ... }: + nodes = { + one = + { config, ... }: { services = { munin-node = { @@ -18,11 +20,11 @@ import ./make-test-python.nix ({ pkgs, ...} : { disabledPlugins = [ "apc_nis" ]; }; munin-cron = { - enable = true; - hosts = '' - [${config.networking.hostName}] - address localhost - ''; + enable = true; + hosts = '' + [${config.networking.hostName}] + address localhost + ''; }; }; @@ -31,16 +33,17 @@ import ./make-test-python.nix ({ pkgs, ...} : { }; }; - testScript = '' - start_all() + testScript = '' + start_all() - with subtest("ensure munin-node starts and listens on 4949"): - one.wait_for_unit("munin-node.service") - one.wait_for_open_port(4949) + with subtest("ensure munin-node starts and listens on 4949"): + one.wait_for_unit("munin-node.service") + one.wait_for_open_port(4949) - with subtest("ensure munin-cron output is correct"): - one.wait_for_file("/var/lib/munin/one/one-uptime-uptime-g.rrd") - one.wait_for_file("/var/www/munin/one/index.html") - one.wait_for_file("/var/www/munin/one/one/diskstat_iops_vda-day.png", timeout=60) - ''; -}) + with subtest("ensure munin-cron output is correct"): + one.wait_for_file("/var/lib/munin/one/one-uptime-uptime-g.rrd") + one.wait_for_file("/var/www/munin/one/index.html") + one.wait_for_file("/var/www/munin/one/one/diskstat_iops_vda-day.png", timeout=60) + ''; + } +) diff --git a/nixos/tests/musescore.nix b/nixos/tests/musescore.nix index 559c91ed8e5501..f34f4514dc65e2 100644 --- a/nixos/tests/musescore.nix +++ b/nixos/tests/musescore.nix @@ -1,93 +1,98 @@ -import ./make-test-python.nix ({ pkgs, ...} : +import ./make-test-python.nix ( + { pkgs, ... }: -let - # Make sure we don't have to go through the startup tutorial - customMuseScoreConfig = pkgs.writeText "MuseScore4.ini" '' - [application] - hasCompletedFirstLaunchSetup=true + let + # Make sure we don't have to go through the startup tutorial + customMuseScoreConfig = pkgs.writeText "MuseScore4.ini" '' + [application] + hasCompletedFirstLaunchSetup=true - [project] - preferredScoreCreationMode=1 + [project] + preferredScoreCreationMode=1 ''; -in -{ - name = "musescore"; - meta = with pkgs.lib.maintainers; { - maintainers = [ turion ]; - }; + in + { + name = "musescore"; + meta = with pkgs.lib.maintainers; { + maintainers = [ turion ]; + }; - nodes.machine = { ... }: + nodes.machine = + { ... }: - { - imports = [ - ./common/x11.nix - ]; + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; - environment.systemPackages = with pkgs; [ - musescore - pdfgrep - ]; - }; + services.xserver.enable = true; + environment.systemPackages = with pkgs; [ + musescore + pdfgrep + ]; + }; - enableOCR = true; + enableOCR = true; - testScript = { ... }: '' - start_all() - machine.wait_for_x() + testScript = + { ... }: + '' + start_all() + machine.wait_for_x() - # Inject custom settings - machine.succeed("mkdir -p /root/.config/MuseScore/") - machine.succeed( - "cp ${customMuseScoreConfig} /root/.config/MuseScore/MuseScore4.ini" - ) + # Inject custom settings + machine.succeed("mkdir -p /root/.config/MuseScore/") + machine.succeed( + "cp ${customMuseScoreConfig} /root/.config/MuseScore/MuseScore4.ini" + ) - # Start MuseScore window - machine.execute("env XDG_RUNTIME_DIR=$PWD DISPLAY=:0.0 mscore >&2 &") + # Start MuseScore window + machine.execute("env XDG_RUNTIME_DIR=$PWD DISPLAY=:0.0 mscore >&2 &") - # Wait until MuseScore has launched - machine.wait_for_window("MuseScore Studio") + # Wait until MuseScore has launched + machine.wait_for_window("MuseScore Studio") - machine.screenshot("MuseScore0") + machine.screenshot("MuseScore0") - # Create a new score - machine.send_key("ctrl-n") + # Create a new score + machine.send_key("ctrl-n") - # Wait until the creation wizard appears - machine.wait_for_window("New score") + # Wait until the creation wizard appears + machine.wait_for_window("New score") - machine.screenshot("MuseScore1") + machine.screenshot("MuseScore1") - machine.send_key("tab") - machine.send_key("tab") - machine.send_key("ret") + machine.send_key("tab") + machine.send_key("tab") + machine.send_key("ret") - machine.sleep(2) + machine.sleep(2) - machine.send_key("tab") - # Type the beginning of https://de.wikipedia.org/wiki/Alle_meine_Entchen - machine.send_chars("cdef6gg5aaaa7g") - machine.sleep(1) + machine.send_key("tab") + # Type the beginning of https://de.wikipedia.org/wiki/Alle_meine_Entchen + machine.send_chars("cdef6gg5aaaa7g") + machine.sleep(1) - machine.screenshot("MuseScore2") + machine.screenshot("MuseScore2") - # Go to the export dialogue and create a PDF - machine.send_key("ctrl-p") + # Go to the export dialogue and create a PDF + machine.send_key("ctrl-p") - # Wait until the Print dialogue appears. - machine.wait_for_window("Print") + # Wait until the Print dialogue appears. + machine.wait_for_window("Print") - machine.screenshot("MuseScore4") - machine.send_key("alt-p") - machine.sleep(1) + machine.screenshot("MuseScore4") + machine.send_key("alt-p") + machine.sleep(1) - machine.screenshot("MuseScore5") + machine.screenshot("MuseScore5") - # Wait until PDF is exported - machine.wait_for_file('"/root/Untitled score.pdf"') + # Wait until PDF is exported + machine.wait_for_file('"/root/Untitled score.pdf"') - ## Check that it contains the title of the score - machine.succeed('pdfgrep "Untitled score" "/root/Untitled score.pdf"') - machine.copy_from_vm("/root/Untitled score.pdf") - ''; -}) + ## Check that it contains the title of the score + machine.succeed('pdfgrep "Untitled score" "/root/Untitled score.pdf"') + machine.copy_from_vm("/root/Untitled score.pdf") + ''; + } +) diff --git a/nixos/tests/mutable-users.nix b/nixos/tests/mutable-users.nix index ef83923f3e2329..e4e35f2d722093 100644 --- a/nixos/tests/mutable-users.nix +++ b/nixos/tests/mutable-users.nix @@ -1,73 +1,76 @@ # Mutable users tests. -import ./make-test-python.nix ({ pkgs, ...} : { - name = "mutable-users"; - meta = with pkgs.lib.maintainers; { - maintainers = [ gleber ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "mutable-users"; + meta = with pkgs.lib.maintainers; { + maintainers = [ gleber ]; + }; - nodes = { - machine = { - specialisation.immutable.configuration = { - users.mutableUsers = false; - }; + nodes = { + machine = { + specialisation.immutable.configuration = { + users.mutableUsers = false; + }; - specialisation.mutable.configuration = { - users.mutableUsers = true; - users.users.dry-test.isNormalUser = true; + specialisation.mutable.configuration = { + users.mutableUsers = true; + users.users.dry-test.isNormalUser = true; + }; }; }; - }; - testScript = '' - machine.start() - machine.wait_for_unit("default.target") + testScript = '' + machine.start() + machine.wait_for_unit("default.target") - # Machine starts in immutable mode. Add a user and test if reactivating - # configuration removes the user. - with subtest("Machine in immutable mode"): - assert "foobar" not in machine.succeed("cat /etc/passwd") - machine.succeed("sudo useradd foobar") - assert "foobar" in machine.succeed("cat /etc/passwd") - machine.succeed( - "/run/booted-system/specialisation/immutable/bin/switch-to-configuration test" - ) - assert "foobar" not in machine.succeed("cat /etc/passwd") + # Machine starts in immutable mode. Add a user and test if reactivating + # configuration removes the user. + with subtest("Machine in immutable mode"): + assert "foobar" not in machine.succeed("cat /etc/passwd") + machine.succeed("sudo useradd foobar") + assert "foobar" in machine.succeed("cat /etc/passwd") + machine.succeed( + "/run/booted-system/specialisation/immutable/bin/switch-to-configuration test" + ) + assert "foobar" not in machine.succeed("cat /etc/passwd") - # In immutable mode passwd is not wrapped, while in mutable mode it is - # wrapped. - with subtest("Password is wrapped in mutable mode"): - assert "/run/current-system/" in machine.succeed("which passwd") - machine.succeed( - "/run/booted-system/specialisation/mutable/bin/switch-to-configuration test" - ) - assert "/run/wrappers/" in machine.succeed("which passwd") + # In immutable mode passwd is not wrapped, while in mutable mode it is + # wrapped. + with subtest("Password is wrapped in mutable mode"): + assert "/run/current-system/" in machine.succeed("which passwd") + machine.succeed( + "/run/booted-system/specialisation/mutable/bin/switch-to-configuration test" + ) + assert "/run/wrappers/" in machine.succeed("which passwd") - with subtest("dry-activation does not change files"): - machine.succeed('test -e /home/dry-test') # home was created - machine.succeed('rm -rf /home/dry-test') + with subtest("dry-activation does not change files"): + machine.succeed('test -e /home/dry-test') # home was created + machine.succeed('rm -rf /home/dry-test') - files_to_check = ['/etc/group', - '/etc/passwd', - '/etc/shadow', - '/etc/subuid', - '/etc/subgid', - '/var/lib/nixos/uid-map', - '/var/lib/nixos/gid-map', - '/var/lib/nixos/declarative-groups', - '/var/lib/nixos/declarative-users' - ] - expected_hashes = {} - expected_stats = {} - for file in files_to_check: - expected_hashes[file] = machine.succeed(f"sha256sum {file}") - expected_stats[file] = machine.succeed(f"stat {file}") + files_to_check = ['/etc/group', + '/etc/passwd', + '/etc/shadow', + '/etc/subuid', + '/etc/subgid', + '/var/lib/nixos/uid-map', + '/var/lib/nixos/gid-map', + '/var/lib/nixos/declarative-groups', + '/var/lib/nixos/declarative-users' + ] + expected_hashes = {} + expected_stats = {} + for file in files_to_check: + expected_hashes[file] = machine.succeed(f"sha256sum {file}") + expected_stats[file] = machine.succeed(f"stat {file}") - machine.succeed("/run/booted-system/specialisation/mutable/bin/switch-to-configuration dry-activate") + machine.succeed("/run/booted-system/specialisation/mutable/bin/switch-to-configuration dry-activate") - machine.fail('test -e /home/dry-test') # home was not recreated - for file in files_to_check: - assert machine.succeed(f"sha256sum {file}") == expected_hashes[file] - assert machine.succeed(f"stat {file}") == expected_stats[file] - ''; -}) + machine.fail('test -e /home/dry-test') # home was not recreated + for file in files_to_check: + assert machine.succeed(f"sha256sum {file}") == expected_hashes[file] + assert machine.succeed(f"stat {file}") == expected_stats[file] + ''; + } +) diff --git a/nixos/tests/mycelium/default.nix b/nixos/tests/mycelium/default.nix index 956a822a21860f..82ec074f77c441 100644 --- a/nixos/tests/mycelium/default.nix +++ b/nixos/tests/mycelium/default.nix @@ -1,46 +1,56 @@ -import ../make-test-python.nix ({ lib, ... }: let - peer1-ip = "538:f40f:1c51:9bd9:9569:d3f6:d0a1:b2df"; - peer2-ip = "5b6:6776:fee0:c1f3:db00:b6a8:d013:d38f"; -in +import ../make-test-python.nix ( + { lib, ... }: + let + peer1-ip = "538:f40f:1c51:9bd9:9569:d3f6:d0a1:b2df"; + peer2-ip = "5b6:6776:fee0:c1f3:db00:b6a8:d013:d38f"; + in { name = "mycelium"; meta.maintainers = with lib.maintainers; [ lassulus ]; nodes = { - peer1 = { config, pkgs, ... }: { - virtualisation.vlans = [ 1 ]; - networking.interfaces.eth1.ipv4.addresses = [{ - address = "192.168.1.11"; - prefixLength = 24; - }]; - - services.mycelium = { - enable = true; - addHostedPublicNodes = false; - openFirewall = true; - keyFile = ./peer1.key; - peers = [ - "quic://192.168.1.12:9651" - "tcp://192.168.1.12:9651" + peer1 = + { config, pkgs, ... }: + { + virtualisation.vlans = [ 1 ]; + networking.interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.1.11"; + prefixLength = 24; + } ]; + + services.mycelium = { + enable = true; + addHostedPublicNodes = false; + openFirewall = true; + keyFile = ./peer1.key; + peers = [ + "quic://192.168.1.12:9651" + "tcp://192.168.1.12:9651" + ]; + }; }; - }; - - peer2 = { config, pkgs, ... }: { - virtualisation.vlans = [ 1 ]; - networking.interfaces.eth1.ipv4.addresses = [{ - address = "192.168.1.12"; - prefixLength = 24; - }]; - - services.mycelium = { - enable = true; - addHostedPublicNodes = false; - openFirewall = true; - keyFile = ./peer2.key; + + peer2 = + { config, pkgs, ... }: + { + virtualisation.vlans = [ 1 ]; + networking.interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.1.12"; + prefixLength = 24; + } + ]; + + services.mycelium = { + enable = true; + addHostedPublicNodes = false; + openFirewall = true; + keyFile = ./peer2.key; + }; }; - }; }; testScript = '' @@ -57,4 +67,5 @@ in peer1.succeed("ping -c5 ${peer2-ip}") peer2.succeed("ping -c5 ${peer1-ip}") ''; - }) + } +) diff --git a/nixos/tests/mympd.nix b/nixos/tests/mympd.nix index ac6a896966e6b4..20c5603da69d86 100644 --- a/nixos/tests/mympd.nix +++ b/nixos/tests/mympd.nix @@ -1,27 +1,30 @@ -import ./make-test-python.nix ({pkgs, lib, ... }: { - name = "mympd"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "mympd"; - nodes.mympd = { - services.mympd = { - enable = true; - settings = { - http_port = 8081; + nodes.mympd = { + services.mympd = { + enable = true; + settings = { + http_port = 8081; + }; }; - }; - services.mpd.enable = true; - }; + services.mpd.enable = true; + }; - testScript = '' - start_all(); - machine.wait_for_unit("mympd.service"); + testScript = '' + start_all(); + machine.wait_for_unit("mympd.service"); - # Ensure that mympd can connect to mpd - machine.wait_until_succeeds( - "journalctl -eu mympd -o cat | grep 'Connected to MPD'" - ) + # Ensure that mympd can connect to mpd + machine.wait_until_succeeds( + "journalctl -eu mympd -o cat | grep 'Connected to MPD'" + ) - # Ensure that the web server is working - machine.succeed("curl http://localhost:8081 --compressed | grep -o myMPD") - ''; -}) + # Ensure that the web server is working + machine.succeed("curl http://localhost:8081 --compressed | grep -o myMPD") + ''; + } +) diff --git a/nixos/tests/mysql/common.nix b/nixos/tests/mysql/common.nix index 079eff163b1cf6..17e961021f14f6 100644 --- a/nixos/tests/mysql/common.nix +++ b/nixos/tests/mysql/common.nix @@ -1,10 +1,14 @@ -{ lib, pkgs }: { - mariadbPackages = lib.filterAttrs (n: _: lib.hasPrefix "mariadb" n) (import ../../../pkgs/servers/sql/mariadb pkgs); +{ lib, pkgs }: +{ + mariadbPackages = lib.filterAttrs (n: _: lib.hasPrefix "mariadb" n) ( + import ../../../pkgs/servers/sql/mariadb pkgs + ); mysqlPackages = { inherit (pkgs) mysql80; }; perconaPackages = { inherit (pkgs) percona-server_8_0 percona-server_8_4; }; - mkTestName = pkg: "mariadb_${builtins.replaceStrings ["."] [""] (lib.versions.majorMinor pkg.version)}"; + mkTestName = + pkg: "mariadb_${builtins.replaceStrings [ "." ] [ "" ] (lib.versions.majorMinor pkg.version)}"; } diff --git a/nixos/tests/mysql/mysql-backup.nix b/nixos/tests/mysql/mysql-backup.nix index 451f5c04ce4678..4579ddcbaee8fb 100644 --- a/nixos/tests/mysql/mysql-backup.nix +++ b/nixos/tests/mysql/mysql-backup.nix @@ -1,8 +1,8 @@ { system ? builtins.currentSystem, - config ? {}, + config ? { }, pkgs ? import ../../.. { inherit system config; }, - lib ? pkgs.lib + lib ? pkgs.lib, }: let @@ -10,59 +10,71 @@ let makeTest = import ./../make-test-python.nix; - makeBackupTest = { - package, - name ? mkTestName package - }: makeTest { - name = "${name}-backup"; + makeBackupTest = + { + package, + name ? mkTestName package, + }: + makeTest { + name = "${name}-backup"; - nodes = { - master = { pkgs, ... }: { - services.mysql = { - inherit package; - enable = true; - initialDatabases = [ { name = "testdb"; schema = ./testdb.sql; } ]; - }; + nodes = { + master = + { pkgs, ... }: + { + services.mysql = { + inherit package; + enable = true; + initialDatabases = [ + { + name = "testdb"; + schema = ./testdb.sql; + } + ]; + }; - services.mysqlBackup = { - enable = true; - databases = [ "doesnotexist" "testdb" ]; - }; + services.mysqlBackup = { + enable = true; + databases = [ + "doesnotexist" + "testdb" + ]; + }; + }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - # Delete backup file that may be left over from a previous test run. - # This is not needed on Hydra but useful for repeated local test runs. - master.execute("rm -f /var/backup/mysql/testdb.gz") + # Delete backup file that may be left over from a previous test run. + # This is not needed on Hydra but useful for repeated local test runs. + master.execute("rm -f /var/backup/mysql/testdb.gz") - # Need to have mysql started so that it can be populated with data. - master.wait_for_unit("mysql.service") + # Need to have mysql started so that it can be populated with data. + master.wait_for_unit("mysql.service") - # Wait for testdb to be fully populated (5 rows). - master.wait_until_succeeds( - "mysql -u root -D testdb -N -B -e 'select count(id) from tests' | grep -q 5" - ) + # Wait for testdb to be fully populated (5 rows). + master.wait_until_succeeds( + "mysql -u root -D testdb -N -B -e 'select count(id) from tests' | grep -q 5" + ) - # Do a backup and wait for it to start - master.start_job("mysql-backup.service") + # Do a backup and wait for it to start + master.start_job("mysql-backup.service") - # wait for backup to fail, because of database 'doesnotexist' - master.wait_until_fails("systemctl is-active -q mysql-backup.service") + # wait for backup to fail, because of database 'doesnotexist' + master.wait_until_fails("systemctl is-active -q mysql-backup.service") - # wait for backup file and check that data appears in backup - master.wait_for_file("/var/backup/mysql/testdb.gz") - master.succeed( - "${pkgs.gzip}/bin/zcat /var/backup/mysql/testdb.gz | grep hello" - ) + # wait for backup file and check that data appears in backup + master.wait_for_file("/var/backup/mysql/testdb.gz") + master.succeed( + "${pkgs.gzip}/bin/zcat /var/backup/mysql/testdb.gz | grep hello" + ) - # Check that a failed backup is logged - master.succeed( - "journalctl -u mysql-backup.service | grep 'fail.*doesnotexist' > /dev/null" - ) - ''; - }; + # Check that a failed backup is logged + master.succeed( + "journalctl -u mysql-backup.service | grep 'fail.*doesnotexist' > /dev/null" + ) + ''; + }; in - lib.mapAttrs (_: package: makeBackupTest { inherit package; }) mariadbPackages +lib.mapAttrs (_: package: makeBackupTest { inherit package; }) mariadbPackages diff --git a/nixos/tests/mysql/mysql-replication.nix b/nixos/tests/mysql/mysql-replication.nix index 83da1e7b6cb88e..d1ccb7c8c92449 100644 --- a/nixos/tests/mysql/mysql-replication.nix +++ b/nixos/tests/mysql/mysql-replication.nix @@ -1,8 +1,8 @@ { system ? builtins.currentSystem, - config ? {}, + config ? { }, pkgs ? import ../../.. { inherit system config; }, - lib ? pkgs.lib + lib ? pkgs.lib, }: let @@ -13,89 +13,100 @@ let makeTest = import ./../make-test-python.nix; - makeReplicationTest = { - package, - name ? mkTestName package, - }: makeTest { - name = "${name}-replication"; - meta = { - maintainers = lib.teams.helsinki-systems.members; - }; - - nodes = { - primary = { - services.mysql = { - inherit package; - enable = true; - replication.role = "master"; - replication.slaveHost = "%"; - replication.masterUser = replicateUser; - replication.masterPassword = replicatePassword; - initialDatabases = [ { name = "testdb"; schema = ./testdb.sql; } ]; - }; - networking.firewall.allowedTCPPorts = [ 3306 ]; + makeReplicationTest = + { + package, + name ? mkTestName package, + }: + makeTest { + name = "${name}-replication"; + meta = { + maintainers = lib.teams.helsinki-systems.members; }; - secondary1 = { nodes, ... }: { - services.mysql = { - inherit package; - enable = true; - replication.role = "slave"; - replication.serverId = 2; - replication.masterHost = nodes.primary.networking.hostName; - replication.masterUser = replicateUser; - replication.masterPassword = replicatePassword; + nodes = { + primary = { + services.mysql = { + inherit package; + enable = true; + replication.role = "master"; + replication.slaveHost = "%"; + replication.masterUser = replicateUser; + replication.masterPassword = replicatePassword; + initialDatabases = [ + { + name = "testdb"; + schema = ./testdb.sql; + } + ]; + }; + networking.firewall.allowedTCPPorts = [ 3306 ]; }; - }; - secondary2 = { nodes, ... }: { - services.mysql = { - inherit package; - enable = true; - replication.role = "slave"; - replication.serverId = 3; - replication.masterHost = nodes.primary.networking.hostName; - replication.masterUser = replicateUser; - replication.masterPassword = replicatePassword; - }; + secondary1 = + { nodes, ... }: + { + services.mysql = { + inherit package; + enable = true; + replication.role = "slave"; + replication.serverId = 2; + replication.masterHost = nodes.primary.networking.hostName; + replication.masterUser = replicateUser; + replication.masterPassword = replicatePassword; + }; + }; + + secondary2 = + { nodes, ... }: + { + services.mysql = { + inherit package; + enable = true; + replication.role = "slave"; + replication.serverId = 3; + replication.masterHost = nodes.primary.networking.hostName; + replication.masterUser = replicateUser; + replication.masterPassword = replicatePassword; + }; + }; }; - }; - testScript = '' - primary.start() - primary.wait_for_unit("mysql") - primary.wait_for_open_port(3306) - # Wait for testdb to be fully populated (5 rows). - primary.wait_until_succeeds( - "sudo -u mysql mysql -u mysql -D testdb -N -B -e 'select count(id) from tests' | grep -q 5" - ) + testScript = '' + primary.start() + primary.wait_for_unit("mysql") + primary.wait_for_open_port(3306) + # Wait for testdb to be fully populated (5 rows). + primary.wait_until_succeeds( + "sudo -u mysql mysql -u mysql -D testdb -N -B -e 'select count(id) from tests' | grep -q 5" + ) - secondary1.start() - secondary2.start() - secondary1.wait_for_unit("mysql") - secondary1.wait_for_open_port(3306) - secondary2.wait_for_unit("mysql") - secondary2.wait_for_open_port(3306) + secondary1.start() + secondary2.start() + secondary1.wait_for_unit("mysql") + secondary1.wait_for_open_port(3306) + secondary2.wait_for_unit("mysql") + secondary2.wait_for_open_port(3306) - # wait for replications to finish - secondary1.wait_until_succeeds( - "sudo -u mysql mysql -u mysql -D testdb -N -B -e 'select count(id) from tests' | grep -q 5" - ) - secondary2.wait_until_succeeds( - "sudo -u mysql mysql -u mysql -D testdb -N -B -e 'select count(id) from tests' | grep -q 5" - ) + # wait for replications to finish + secondary1.wait_until_succeeds( + "sudo -u mysql mysql -u mysql -D testdb -N -B -e 'select count(id) from tests' | grep -q 5" + ) + secondary2.wait_until_succeeds( + "sudo -u mysql mysql -u mysql -D testdb -N -B -e 'select count(id) from tests' | grep -q 5" + ) - secondary2.succeed("systemctl stop mysql") - primary.succeed( - "echo 'insert into testdb.tests values (123, 456);' | sudo -u mysql mysql -u mysql -N" - ) - secondary2.succeed("systemctl start mysql") - secondary2.wait_for_unit("mysql") - secondary2.wait_for_open_port(3306) - secondary2.wait_until_succeeds( - "echo 'select * from testdb.tests where Id = 123;' | sudo -u mysql mysql -u mysql -N | grep 456" - ) - ''; - }; + secondary2.succeed("systemctl stop mysql") + primary.succeed( + "echo 'insert into testdb.tests values (123, 456);' | sudo -u mysql mysql -u mysql -N" + ) + secondary2.succeed("systemctl start mysql") + secondary2.wait_for_unit("mysql") + secondary2.wait_for_open_port(3306) + secondary2.wait_until_succeeds( + "echo 'select * from testdb.tests where Id = 123;' | sudo -u mysql mysql -u mysql -N | grep 456" + ) + ''; + }; in - lib.mapAttrs (_: package: makeReplicationTest { inherit package; }) mariadbPackages +lib.mapAttrs (_: package: makeReplicationTest { inherit package; }) mariadbPackages diff --git a/nixos/tests/mysql/mysql.nix b/nixos/tests/mysql/mysql.nix index 093da4f46aa10e..2935c02e1c46f4 100644 --- a/nixos/tests/mysql/mysql.nix +++ b/nixos/tests/mysql/mysql.nix @@ -1,151 +1,186 @@ { system ? builtins.currentSystem, - config ? {}, + config ? { }, pkgs ? import ../../.. { inherit system config; }, - lib ? pkgs.lib + lib ? pkgs.lib, }: let - inherit (import ./common.nix { inherit pkgs lib; }) mkTestName mariadbPackages mysqlPackages perconaPackages; + inherit (import ./common.nix { inherit pkgs lib; }) + mkTestName + mariadbPackages + mysqlPackages + perconaPackages + ; makeTest = import ./../make-test-python.nix; # Setup common users - makeMySQLTest = { - package, - name ? mkTestName package, - useSocketAuth ? true, - hasMroonga ? true, - hasRocksDB ? pkgs.stdenv.hostPlatform.is64bit - }: makeTest { - inherit name; - meta = { - maintainers = lib.teams.helsinki-systems.members; - }; + makeMySQLTest = + { + package, + name ? mkTestName package, + useSocketAuth ? true, + hasMroonga ? true, + hasRocksDB ? pkgs.stdenv.hostPlatform.is64bit, + }: + makeTest { + inherit name; + meta = { + maintainers = lib.teams.helsinki-systems.members; + }; - nodes = { - ${name} = - { pkgs, ... }: { + nodes = { + ${name} = + { pkgs, ... }: + { - users = { - groups.testusers = { }; + users = { + groups.testusers = { }; - users.testuser = { - isSystemUser = true; - group = "testusers"; - }; + users.testuser = { + isSystemUser = true; + group = "testusers"; + }; - users.testuser2 = { - isSystemUser = true; - group = "testusers"; + users.testuser2 = { + isSystemUser = true; + group = "testusers"; + }; }; - }; - services.mysql = { - enable = true; - initialDatabases = [ - { name = "testdb3"; schema = ./testdb.sql; } - ]; - # note that using pkgs.writeText here is generally not a good idea, - # as it will store the password in world-readable /nix/store ;) - initialScript = pkgs.writeText "mysql-init.sql" (if (!useSocketAuth) then '' - CREATE USER 'testuser3'@'localhost' IDENTIFIED BY 'secure'; - GRANT ALL PRIVILEGES ON testdb3.* TO 'testuser3'@'localhost'; - '' else '' - ALTER USER root@localhost IDENTIFIED WITH unix_socket; - DELETE FROM mysql.user WHERE password = ''' AND plugin = '''; - DELETE FROM mysql.user WHERE user = '''; - FLUSH PRIVILEGES; - ''); + services.mysql = { + enable = true; + initialDatabases = [ + { + name = "testdb3"; + schema = ./testdb.sql; + } + ]; + # note that using pkgs.writeText here is generally not a good idea, + # as it will store the password in world-readable /nix/store ;) + initialScript = pkgs.writeText "mysql-init.sql" ( + if (!useSocketAuth) then + '' + CREATE USER 'testuser3'@'localhost' IDENTIFIED BY 'secure'; + GRANT ALL PRIVILEGES ON testdb3.* TO 'testuser3'@'localhost'; + '' + else + '' + ALTER USER root@localhost IDENTIFIED WITH unix_socket; + DELETE FROM mysql.user WHERE password = ''' AND plugin = '''; + DELETE FROM mysql.user WHERE user = '''; + FLUSH PRIVILEGES; + '' + ); - ensureDatabases = [ "testdb" "testdb2" ]; - ensureUsers = [{ - name = "testuser"; - ensurePermissions = { - "testdb.*" = "ALL PRIVILEGES"; - }; - } { - name = "testuser2"; - ensurePermissions = { - "testdb2.*" = "ALL PRIVILEGES"; - }; - }]; - package = package; - settings = { - mysqld = { - plugin-load-add = lib.optional hasMroonga "ha_mroonga.so" - ++ lib.optional hasRocksDB "ha_rocksdb.so"; + ensureDatabases = [ + "testdb" + "testdb2" + ]; + ensureUsers = [ + { + name = "testuser"; + ensurePermissions = { + "testdb.*" = "ALL PRIVILEGES"; + }; + } + { + name = "testuser2"; + ensurePermissions = { + "testdb2.*" = "ALL PRIVILEGES"; + }; + } + ]; + package = package; + settings = { + mysqld = { + plugin-load-add = + lib.optional hasMroonga "ha_mroonga.so" + ++ lib.optional hasRocksDB "ha_rocksdb.so"; + }; }; }; }; - }; - }; - - testScript = '' - start_all() + }; - machine = ${name} - machine.wait_for_unit("mysql") - machine.succeed( - "echo 'use testdb; create table tests (test_id INT, PRIMARY KEY (test_id));' | sudo -u testuser mysql -u testuser" - ) - machine.succeed( - "echo 'use testdb; insert into tests values (42);' | sudo -u testuser mysql -u testuser" - ) - # Ensure testuser2 is not able to insert into testdb as mysql testuser2 - machine.fail( - "echo 'use testdb; insert into tests values (23);' | sudo -u testuser2 mysql -u testuser2" - ) - # Ensure testuser2 is not able to authenticate as mysql testuser - machine.fail( - "echo 'use testdb; insert into tests values (23);' | sudo -u testuser2 mysql -u testuser" - ) - machine.succeed( - "echo 'use testdb; select test_id from tests;' | sudo -u testuser mysql -u testuser -N | grep 42" - ) + testScript = '' + start_all() - ${lib.optionalString hasMroonga '' - # Check if Mroonga plugin works + machine = ${name} + machine.wait_for_unit("mysql") machine.succeed( - "echo 'use testdb; create table mroongadb (test_id INT, PRIMARY KEY (test_id)) ENGINE = Mroonga;' | sudo -u testuser mysql -u testuser" + "echo 'use testdb; create table tests (test_id INT, PRIMARY KEY (test_id));' | sudo -u testuser mysql -u testuser" ) machine.succeed( - "echo 'use testdb; insert into mroongadb values (25);' | sudo -u testuser mysql -u testuser" + "echo 'use testdb; insert into tests values (42);' | sudo -u testuser mysql -u testuser" ) - machine.succeed( - "echo 'use testdb; select test_id from mroongadb;' | sudo -u testuser mysql -u testuser -N | grep 25" + # Ensure testuser2 is not able to insert into testdb as mysql testuser2 + machine.fail( + "echo 'use testdb; insert into tests values (23);' | sudo -u testuser2 mysql -u testuser2" ) - machine.succeed( - "echo 'use testdb; drop table mroongadb;' | sudo -u testuser mysql -u testuser" - ) - ''} - - ${lib.optionalString hasRocksDB '' - # Check if RocksDB plugin works - machine.succeed( - "echo 'use testdb; create table rocksdb (test_id INT, PRIMARY KEY (test_id)) ENGINE = RocksDB;' | sudo -u testuser mysql -u testuser" - ) - machine.succeed( - "echo 'use testdb; insert into rocksdb values (28);' | sudo -u testuser mysql -u testuser" + # Ensure testuser2 is not able to authenticate as mysql testuser + machine.fail( + "echo 'use testdb; insert into tests values (23);' | sudo -u testuser2 mysql -u testuser" ) machine.succeed( - "echo 'use testdb; select test_id from rocksdb;' | sudo -u testuser mysql -u testuser -N | grep 28" + "echo 'use testdb; select test_id from tests;' | sudo -u testuser mysql -u testuser -N | grep 42" ) - machine.succeed( - "echo 'use testdb; drop table rocksdb;' | sudo -u testuser mysql -u testuser" - ) - ''} - ''; - }; + + ${lib.optionalString hasMroonga '' + # Check if Mroonga plugin works + machine.succeed( + "echo 'use testdb; create table mroongadb (test_id INT, PRIMARY KEY (test_id)) ENGINE = Mroonga;' | sudo -u testuser mysql -u testuser" + ) + machine.succeed( + "echo 'use testdb; insert into mroongadb values (25);' | sudo -u testuser mysql -u testuser" + ) + machine.succeed( + "echo 'use testdb; select test_id from mroongadb;' | sudo -u testuser mysql -u testuser -N | grep 25" + ) + machine.succeed( + "echo 'use testdb; drop table mroongadb;' | sudo -u testuser mysql -u testuser" + ) + ''} + + ${lib.optionalString hasRocksDB '' + # Check if RocksDB plugin works + machine.succeed( + "echo 'use testdb; create table rocksdb (test_id INT, PRIMARY KEY (test_id)) ENGINE = RocksDB;' | sudo -u testuser mysql -u testuser" + ) + machine.succeed( + "echo 'use testdb; insert into rocksdb values (28);' | sudo -u testuser mysql -u testuser" + ) + machine.succeed( + "echo 'use testdb; select test_id from rocksdb;' | sudo -u testuser mysql -u testuser -N | grep 28" + ) + machine.succeed( + "echo 'use testdb; drop table rocksdb;' | sudo -u testuser mysql -u testuser" + ) + ''} + ''; + }; in - lib.mapAttrs (_: package: makeMySQLTest { +lib.mapAttrs ( + _: package: + makeMySQLTest { inherit package; - hasRocksDB = false; hasMroonga = false; useSocketAuth = false; - }) mysqlPackages - // (lib.mapAttrs (_: package: makeMySQLTest { + hasRocksDB = false; + hasMroonga = false; + useSocketAuth = false; + } +) mysqlPackages +// (lib.mapAttrs ( + _: package: + makeMySQLTest { inherit package; - }) mariadbPackages) - // (lib.mapAttrs (_: package: makeMySQLTest { + } +) mariadbPackages) +// (lib.mapAttrs ( + _: package: + makeMySQLTest { inherit package; - name = builtins.replaceStrings ["-"] ["_"] package.pname; - hasMroonga = false; useSocketAuth = false; - }) perconaPackages) + name = builtins.replaceStrings [ "-" ] [ "_" ] package.pname; + hasMroonga = false; + useSocketAuth = false; + } +) perconaPackages) diff --git a/nixos/tests/n8n.nix b/nixos/tests/n8n.nix index 0a12192d5c7124..e5d730563c67b8 100644 --- a/nixos/tests/n8n.nix +++ b/nixos/tests/n8n.nix @@ -1,25 +1,30 @@ -import ./make-test-python.nix ({ lib, ... }: -let - port = 5678; - webhookUrl = "http://example.com"; -in -{ - name = "n8n"; - meta.maintainers = with lib.maintainers; [ freezeboy k900 ]; +import ./make-test-python.nix ( + { lib, ... }: + let + port = 5678; + webhookUrl = "http://example.com"; + in + { + name = "n8n"; + meta.maintainers = with lib.maintainers; [ + freezeboy + k900 + ]; - nodes.machine = - { pkgs, ... }: - { - services.n8n = { - enable = true; - webhookUrl = webhookUrl; + nodes.machine = + { pkgs, ... }: + { + services.n8n = { + enable = true; + webhookUrl = webhookUrl; + }; }; - }; - testScript = '' - machine.wait_for_unit("n8n.service") - machine.wait_for_console_text("Editor is now accessible via") - machine.succeed("curl --fail -vvv http://localhost:${toString port}/") - machine.succeed("grep -qF ${webhookUrl} /etc/systemd/system/n8n.service") - ''; -}) + testScript = '' + machine.wait_for_unit("n8n.service") + machine.wait_for_console_text("Editor is now accessible via") + machine.succeed("curl --fail -vvv http://localhost:${toString port}/") + machine.succeed("grep -qF ${webhookUrl} /etc/systemd/system/n8n.service") + ''; + } +) diff --git a/nixos/tests/nagios.nix b/nixos/tests/nagios.nix index b6e45fc103afd1..9dd58215be1ffc 100644 --- a/nixos/tests/nagios.nix +++ b/nixos/tests/nagios.nix @@ -1,16 +1,19 @@ import ./make-test-python.nix ( - { pkgs, ... }: { + { pkgs, ... }: + { name = "nagios"; meta = with pkgs.lib.maintainers; { maintainers = [ symphorien ]; }; - nodes.machine = { lib, ... }: let - writer = pkgs.writeShellScript "write" '' - set -x - echo "$@" >> /tmp/notifications - ''; - in + nodes.machine = + { lib, ... }: + let + writer = pkgs.writeShellScript "write" '' + set -x + echo "$@" >> /tmp/notifications + ''; + in { # tested service services.sshd.enable = true; @@ -20,97 +23,102 @@ import ./make-test-python.nix ( # make state transitions faster extraConfig.interval_length = "5"; objectDefs = - (map (x: "${pkgs.nagios}/etc/objects/${x}.cfg") [ "templates" "timeperiods" "commands" ]) ++ [ - ( - pkgs.writeText "objects.cfg" '' - # notifications are written to /tmp/notifications - define command { - command_name notify-host-by-file - command_line ${writer} "$HOSTNAME is $HOSTSTATE$" - } - define command { - command_name notify-service-by-file - command_line ${writer} "$SERVICEDESC$ is $SERVICESTATE$" - } + (map (x: "${pkgs.nagios}/etc/objects/${x}.cfg") [ + "templates" + "timeperiods" + "commands" + ]) + ++ [ + (pkgs.writeText "objects.cfg" '' + # notifications are written to /tmp/notifications + define command { + command_name notify-host-by-file + command_line ${writer} "$HOSTNAME is $HOSTSTATE$" + } + define command { + command_name notify-service-by-file + command_line ${writer} "$SERVICEDESC$ is $SERVICESTATE$" + } - # nagios boilerplate - define contact { - contact_name alice - alias alice - host_notifications_enabled 1 - service_notifications_enabled 1 - service_notification_period 24x7 - host_notification_period 24x7 - service_notification_options w,u,c,r,f,s - host_notification_options d,u,r,f,s - service_notification_commands notify-service-by-file - host_notification_commands notify-host-by-file - email foo@example.com - } - define contactgroup { - contactgroup_name admins - alias Admins - members alice - } - define hostgroup{ - hostgroup_name allhosts - alias All hosts - } + # nagios boilerplate + define contact { + contact_name alice + alias alice + host_notifications_enabled 1 + service_notifications_enabled 1 + service_notification_period 24x7 + host_notification_period 24x7 + service_notification_options w,u,c,r,f,s + host_notification_options d,u,r,f,s + service_notification_commands notify-service-by-file + host_notification_commands notify-host-by-file + email foo@example.com + } + define contactgroup { + contactgroup_name admins + alias Admins + members alice + } + define hostgroup{ + hostgroup_name allhosts + alias All hosts + } - # monitored objects - define host { - use generic-host - host_name localhost - alias localhost - address localhost - hostgroups allhosts - contact_groups admins - # make state transitions faster. - max_check_attempts 2 - check_interval 1 - retry_interval 1 - } - define service { - use generic-service - host_name localhost - service_description ssh - check_command check_ssh - # make state transitions faster. - max_check_attempts 2 - check_interval 1 - retry_interval 1 - } - '' - ) + # monitored objects + define host { + use generic-host + host_name localhost + alias localhost + address localhost + hostgroups allhosts + contact_groups admins + # make state transitions faster. + max_check_attempts 2 + check_interval 1 + retry_interval 1 + } + define service { + use generic-service + host_name localhost + service_description ssh + check_command check_ssh + # make state transitions faster. + max_check_attempts 2 + check_interval 1 + retry_interval 1 + } + '') ]; }; }; - testScript = { ... }: '' - with subtest("ensure sshd starts"): - machine.wait_for_unit("sshd.service") + testScript = + { ... }: + '' + with subtest("ensure sshd starts"): + machine.wait_for_unit("sshd.service") - with subtest("ensure nagios starts"): - machine.wait_for_file("/var/log/nagios/current") + with subtest("ensure nagios starts"): + machine.wait_for_file("/var/log/nagios/current") - def assert_notify(text): - machine.wait_for_file("/tmp/notifications") - real = machine.succeed("cat /tmp/notifications").strip() - print(f"got {real!r}, expected {text!r}") - assert text == real + def assert_notify(text): + machine.wait_for_file("/tmp/notifications") + real = machine.succeed("cat /tmp/notifications").strip() + print(f"got {real!r}, expected {text!r}") + assert text == real - with subtest("ensure we get a notification when sshd is down"): - machine.succeed("systemctl stop sshd") - assert_notify("ssh is CRITICAL") + with subtest("ensure we get a notification when sshd is down"): + machine.succeed("systemctl stop sshd") + assert_notify("ssh is CRITICAL") - with subtest("ensure tests can succeed"): - machine.succeed("systemctl start sshd") - machine.succeed("rm /tmp/notifications") - assert_notify("ssh is OK") - ''; + with subtest("ensure tests can succeed"): + machine.succeed("systemctl start sshd") + machine.succeed("rm /tmp/notifications") + assert_notify("ssh is OK") + ''; } ) diff --git a/nixos/tests/nar-serve.nix b/nixos/tests/nar-serve.nix index f6197567b822a8..fde57eb4f670d4 100644 --- a/nixos/tests/nar-serve.nix +++ b/nixos/tests/nar-serve.nix @@ -3,9 +3,10 @@ import ./make-test-python.nix ( { name = "nar-serve"; meta.maintainers = [ lib.maintainers.rizary ]; - nodes = - { - server = { pkgs, ... }: { + nodes = { + server = + { pkgs, ... }: + { services.nginx = { enable = true; virtualHosts.default.root = "/var/www"; @@ -25,7 +26,7 @@ import ./make-test-python.nix ( # virtualisation.diskSize = 2 * 1024; }; - }; + }; testScript = '' import os diff --git a/nixos/tests/nat.nix b/nixos/tests/nat.nix index a00febf766ae35..670edc420078ac 100644 --- a/nixos/tests/nat.nix +++ b/nixos/tests/nat.nix @@ -11,28 +11,35 @@ # # The client is behind the nat (read: protected by the nat) and the server is on the external network, attempting to access services behind the NAT. -import ./make-test-python.nix ({ pkgs, lib, withFirewall ? false, nftables ? false, ... }: +import ./make-test-python.nix ( + { + pkgs, + lib, + withFirewall ? false, + nftables ? false, + ... + }: let unit = if nftables then "nftables" else (if withFirewall then "firewall" else "nat"); routerAlternativeExternalIp = "192.168.2.234"; makeNginxConfig = hostname: { - enable = true; - virtualHosts."${hostname}" = { - root = "/etc"; - locations."/".index = "hostname"; - listen = [ - { - addr = "0.0.0.0"; - port = 80; - } - { - addr = "0.0.0.0"; - port = 8080; - } - ]; - }; + enable = true; + virtualHosts."${hostname}" = { + root = "/etc"; + locations."/".index = "hostname"; + listen = [ + { + addr = "0.0.0.0"; + port = 80; + } + { + addr = "0.0.0.0"; + port = 8080; + } + ]; + }; }; makeCommonConfig = hostname: { @@ -51,78 +58,94 @@ import ./make-test-python.nix ({ pkgs, lib, withFirewall ? false, nftables ? fal networking.useDHCP = false; environment.systemPackages = [ - (pkgs.writeScriptBin "check-connection" - '' - #!/usr/bin/env bash - - set -e - - if [[ "$2" == "" || "$3" == "" || "$1" == "--help" || "$1" == "-h" ]]; - then - echo "check-connection <target-address> <target-hostname> <[expect-success|expect-failure]>" - exit 1 - fi - - ADDRESS="$1" - HOSTNAME="$2" - - function test_icmp() { timeout 3 ping -c 1 $ADDRESS; } - function test_http() { [[ `timeout 3 curl $ADDRESS` == "$HOSTNAME" ]]; } - function test_ftp() { timeout 3 curl ftp://$ADDRESS; } - - if [[ "$3" == "expect-success" ]]; - then - test_icmp; test_http; test_ftp - else - ! test_icmp; ! test_http; ! test_ftp - fi - '' - ) - (pkgs.writeScriptBin "check-last-clients-ip" - '' - #!/usr/bin/env bash - set -e - - [[ `cat /var/log/nginx/access.log | tail -n1 | awk '{print $1}'` == "$1" ]] - '' - ) + (pkgs.writeScriptBin "check-connection" '' + #!/usr/bin/env bash + + set -e + + if [[ "$2" == "" || "$3" == "" || "$1" == "--help" || "$1" == "-h" ]]; + then + echo "check-connection <target-address> <target-hostname> <[expect-success|expect-failure]>" + exit 1 + fi + + ADDRESS="$1" + HOSTNAME="$2" + + function test_icmp() { timeout 3 ping -c 1 $ADDRESS; } + function test_http() { [[ `timeout 3 curl $ADDRESS` == "$HOSTNAME" ]]; } + function test_ftp() { timeout 3 curl ftp://$ADDRESS; } + + if [[ "$3" == "expect-success" ]]; + then + test_icmp; test_http; test_ftp + else + ! test_icmp; ! test_http; ! test_ftp + fi + '') + (pkgs.writeScriptBin "check-last-clients-ip" '' + #!/usr/bin/env bash + set -e + + [[ `cat /var/log/nginx/access.log | tail -n1 | awk '{print $1}'` == "$1" ]] + '') ]; }; + in # VLANS: # 1 -- simulates the internal network # 2 -- simulates the external network - in { - name = "nat" + (lib.optionalString nftables "Nftables") - + (if withFirewall then "WithFirewall" else "Standalone"); + name = + "nat" + + (lib.optionalString nftables "Nftables") + + (if withFirewall then "WithFirewall" else "Standalone"); meta = with pkgs.lib.maintainers; { - maintainers = [ tne rob ]; + maintainers = [ + tne + rob + ]; }; - nodes = - { client = - { pkgs, nodes, ... }: - lib.mkMerge [ - ( makeCommonConfig "client" ) - { virtualisation.vlans = [ 1 ]; - networking.defaultGateway = - (pkgs.lib.head nodes.router.networking.interfaces.eth1.ipv4.addresses).address; - networking.nftables.enable = nftables; - networking.firewall.enable = false; - } - ]; - - router = - { nodes, ... }: lib.mkMerge [ - ( makeCommonConfig "router" ) - { virtualisation.vlans = [ 1 2 ]; + nodes = { + client = + { pkgs, nodes, ... }: + lib.mkMerge [ + (makeCommonConfig "client") + { + virtualisation.vlans = [ 1 ]; + networking.defaultGateway = + (pkgs.lib.head nodes.router.networking.interfaces.eth1.ipv4.addresses).address; + networking.nftables.enable = nftables; + networking.firewall.enable = false; + } + ]; + + router = + { nodes, ... }: + lib.mkMerge [ + (makeCommonConfig "router") + { + virtualisation.vlans = [ + 1 + 2 + ]; networking.firewall = { enable = withFirewall; filterForward = nftables; - allowedTCPPorts = [ 21 80 8080 ]; + allowedTCPPorts = [ + 21 + 80 + 8080 + ]; # For FTP passive mode - allowedTCPPortRanges = [ { from = 51000; to = 51999; } ]; + allowedTCPPortRanges = [ + { + from = 51000; + to = 51999; + } + ]; }; networking.nftables.enable = nftables; networking.nat = @@ -148,13 +171,19 @@ import ./make-test-python.nix ({ pkgs, lib, withFirewall ? false, nftables ? fal ]; }; - networking.interfaces.eth2.ipv4.addresses = - lib.mkOrder 10000 [ { address = routerAlternativeExternalIp; prefixLength = 24; } ]; + networking.interfaces.eth2.ipv4.addresses = lib.mkOrder 10000 [ + { + address = routerAlternativeExternalIp; + prefixLength = 24; + } + ]; - services.nginx.virtualHosts.router.listen = lib.mkOrder (-1) [ { - addr = routerAlternativeExternalIp; - port = 8080; - } ]; + services.nginx.virtualHosts.router.listen = lib.mkOrder (-1) [ + { + addr = routerAlternativeExternalIp; + port = 8080; + } + ]; specialisation.no-nat.configuration = { networking.nat.enable = lib.mkForce false; @@ -162,24 +191,28 @@ import ./make-test-python.nix ({ pkgs, lib, withFirewall ? false, nftables ? fal } ]; - server = - { nodes, ... }: lib.mkMerge [ - ( makeCommonConfig "server" ) - { virtualisation.vlans = [ 2 ]; - networking.firewall.enable = false; + server = + { nodes, ... }: + lib.mkMerge [ + (makeCommonConfig "server") + { + virtualisation.vlans = [ 2 ]; + networking.firewall.enable = false; - networking.defaultGateway = - (pkgs.lib.head nodes.router.networking.interfaces.eth2.ipv4.addresses).address; - } - ]; - }; + networking.defaultGateway = + (pkgs.lib.head nodes.router.networking.interfaces.eth2.ipv4.addresses).address; + } + ]; + }; testScript = - { nodes, ... }: let + { nodes, ... }: + let clientIp = (pkgs.lib.head nodes.client.networking.interfaces.eth1.ipv4.addresses).address; serverIp = (pkgs.lib.head nodes.server.networking.interfaces.eth1.ipv4.addresses).address; routerIp = (pkgs.lib.head nodes.router.networking.interfaces.eth2.ipv4.addresses).address; - in '' + in + '' def wait_for_machine(m): m.wait_for_unit("network.target") m.wait_for_unit("nginx.service") @@ -275,4 +308,5 @@ import ./make-test-python.nix ({ pkgs, lib, withFirewall ? false, nftables ? fal server.succeed('[[ `timeout 3 curl http://${routerIp}:8080` == "router" ]]') router.succeed('[[ `timeout 3 curl http://${routerIp}:8080` == "router" ]]') ''; -}) + } +) diff --git a/nixos/tests/nats.nix b/nixos/tests/nats.nix index c650904e53bf7d..b62b9201101a20 100644 --- a/nixos/tests/nats.nix +++ b/nixos/tests/nats.nix @@ -5,59 +5,76 @@ let password = "password"; topic = "foo.bar"; -in import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "nats"; - meta = with pkgs.lib; { maintainers = with maintainers; [ c0deaddict ]; }; - - nodes = let - client = { pkgs, ... }: { - environment.systemPackages = with pkgs; [ natscli ]; +in +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "nats"; + meta = with pkgs.lib; { + maintainers = with maintainers; [ c0deaddict ]; }; - in { - server = { pkgs, ... }: { - networking.firewall.allowedTCPPorts = [ port ]; - services.nats = { - inherit port; - enable = true; - settings = { - authorization = { - users = [{ - user = username; - inherit password; - }]; + + nodes = + let + client = + { pkgs, ... }: + { + environment.systemPackages = with pkgs; [ natscli ]; }; - }; + in + { + server = + { pkgs, ... }: + { + networking.firewall.allowedTCPPorts = [ port ]; + services.nats = { + inherit port; + enable = true; + settings = { + authorization = { + users = [ + { + user = username; + inherit password; + } + ]; + }; + }; + }; + }; + + client1 = client; + client2 = client; }; - }; - client1 = client; - client2 = client; - }; - - testScript = let file = "/tmp/msg"; - in '' - def nats_cmd(*args): - return ( - "nats " - "--server=nats://server:${toString port} " - "--user=${username} " - "--password=${password} " - "{}" - ).format(" ".join(args)) - - def parallel(*fns): - from threading import Thread - threads = [ Thread(target=fn) for fn in fns ] - for t in threads: t.start() - for t in threads: t.join() - - start_all() - server.wait_for_unit("nats.service") - - with subtest("pub sub"): - parallel( - lambda: client1.succeed(nats_cmd("sub", "--count", "1", "${topic}")), - lambda: client2.succeed("sleep 2 && {}".format(nats_cmd("pub", "${topic}", "hello"))), - ) - ''; -}) + testScript = + let + file = "/tmp/msg"; + in + '' + def nats_cmd(*args): + return ( + "nats " + "--server=nats://server:${toString port} " + "--user=${username} " + "--password=${password} " + "{}" + ).format(" ".join(args)) + + def parallel(*fns): + from threading import Thread + threads = [ Thread(target=fn) for fn in fns ] + for t in threads: t.start() + for t in threads: t.join() + + start_all() + server.wait_for_unit("nats.service") + + with subtest("pub sub"): + parallel( + lambda: client1.succeed(nats_cmd("sub", "--count", "1", "${topic}")), + lambda: client2.succeed("sleep 2 && {}".format(nats_cmd("pub", "${topic}", "hello"))), + ) + ''; + } +) diff --git a/nixos/tests/navidrome.nix b/nixos/tests/navidrome.nix index 7315aef624017b..b6afad8e56c757 100644 --- a/nixos/tests/navidrome.nix +++ b/nixos/tests/navidrome.nix @@ -1,12 +1,17 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "navidrome"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "navidrome"; - nodes.machine = { ... }: { - services.navidrome.enable = true; - }; + nodes.machine = + { ... }: + { + services.navidrome.enable = true; + }; - testScript = '' - machine.wait_for_unit("navidrome") - machine.wait_for_open_port(4533) - ''; -}) + testScript = '' + machine.wait_for_unit("navidrome") + machine.wait_for_open_port(4533) + ''; + } +) diff --git a/nixos/tests/nbd.nix b/nixos/tests/nbd.nix index b4aaf29ee4e50d..7905a4a6127ee2 100644 --- a/nixos/tests/nbd.nix +++ b/nixos/tests/nbd.nix @@ -1,68 +1,80 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: let listenPort = 30123; testString = "It works!"; - mkCreateSmallFileService = { path, loop ? false }: { - script = '' - ${pkgs.coreutils}/bin/dd if=/dev/zero of=${path} bs=1K count=100 - ${pkgs.lib.optionalString loop - "${pkgs.util-linux}/bin/losetup --find ${path}"} - ''; - serviceConfig = { - Type = "oneshot"; + mkCreateSmallFileService = + { + path, + loop ? false, + }: + { + script = '' + ${pkgs.coreutils}/bin/dd if=/dev/zero of=${path} bs=1K count=100 + ${pkgs.lib.optionalString loop "${pkgs.util-linux}/bin/losetup --find ${path}"} + ''; + serviceConfig = { + Type = "oneshot"; + }; + wantedBy = [ "multi-user.target" ]; + before = [ "nbd-server.service" ]; }; - wantedBy = [ "multi-user.target" ]; - before = [ "nbd-server.service" ]; - }; in { name = "nbd"; nodes = { - server = { config, pkgs, ... }: { - # Create some small files of zeros to use as the ndb disks - ## `vault-pub.disk` is accessible from any IP - systemd.services.create-pub-file = - mkCreateSmallFileService { path = "/vault-pub.disk"; }; - ## `vault-priv.disk` is accessible only from localhost. - ## It's also a loopback device to test exporting /dev/... - systemd.services.create-priv-file = - mkCreateSmallFileService { path = "/vault-priv.disk"; loop = true; }; - ## `aaa.disk` is just here because "[aaa]" sorts before - ## "[generic]" lexicographically, and nbd-server breaks if - ## "[generic]" isn't the first section. - systemd.services.create-aaa-file = - mkCreateSmallFileService { path = "/aaa.disk"; }; + server = + { config, pkgs, ... }: + { + # Create some small files of zeros to use as the ndb disks + ## `vault-pub.disk` is accessible from any IP + systemd.services.create-pub-file = mkCreateSmallFileService { path = "/vault-pub.disk"; }; + ## `vault-priv.disk` is accessible only from localhost. + ## It's also a loopback device to test exporting /dev/... + systemd.services.create-priv-file = mkCreateSmallFileService { + path = "/vault-priv.disk"; + loop = true; + }; + ## `aaa.disk` is just here because "[aaa]" sorts before + ## "[generic]" lexicographically, and nbd-server breaks if + ## "[generic]" isn't the first section. + systemd.services.create-aaa-file = mkCreateSmallFileService { path = "/aaa.disk"; }; - # Needed only for nbd-client used in the tests. - environment.systemPackages = [ pkgs.nbd ]; + # Needed only for nbd-client used in the tests. + environment.systemPackages = [ pkgs.nbd ]; - # Open the nbd port in the firewall - networking.firewall.allowedTCPPorts = [ listenPort ]; + # Open the nbd port in the firewall + networking.firewall.allowedTCPPorts = [ listenPort ]; - # Run the nbd server and expose the small file created above - services.nbd.server = { - enable = true; - exports = { - aaa = { - path = "/aaa.disk"; - }; - vault-pub = { - path = "/vault-pub.disk"; - }; - vault-priv = { - path = "/dev/loop0"; - allowAddresses = [ "127.0.0.1" "::1" ]; + # Run the nbd server and expose the small file created above + services.nbd.server = { + enable = true; + exports = { + aaa = { + path = "/aaa.disk"; + }; + vault-pub = { + path = "/vault-pub.disk"; + }; + vault-priv = { + path = "/dev/loop0"; + allowAddresses = [ + "127.0.0.1" + "::1" + ]; + }; }; + listenAddress = "0.0.0.0"; + listenPort = listenPort; }; - listenAddress = "0.0.0.0"; - listenPort = listenPort; }; - }; - client = { config, pkgs, ... }: { - programs.nbd.enable = true; - }; + client = + { config, pkgs, ... }: + { + programs.nbd.enable = true; + }; }; testScript = '' @@ -100,4 +112,5 @@ import ./make-test-python.nix ({ pkgs, ... }: raise Exception(f"Read the wrong string from nbd disk. Expected: '{testString}'. Found: '{foundString}'") server.succeed("nbd-client -d /dev/nbd0") ''; - }) + } +) diff --git a/nixos/tests/ncdns.nix b/nixos/tests/ncdns.nix index 3ce39ed3cb55c7..48f17ed16b855b 100644 --- a/nixos/tests/ncdns.nix +++ b/nixos/tests/ncdns.nix @@ -1,93 +1,97 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -let - fakeReply = pkgs.writeText "namecoin-reply.json" '' - { "error": null, - "id": 1, - "result": { - "address": "T31q8ucJ4dI1xzhxQ5QispfECld5c7Xw", - "expired": false, - "expires_in": 2248, - "height": 438155, - "name": "d/test", - "txid": "db61c0b2540ba0c1a2c8cc92af703a37002e7566ecea4dbf8727c7191421edfb", - "value": "{\"ip\": \"1.2.3.4\", \"email\": \"root@test.bit\",\"info\": \"Fake record\"}", - "vout": 0 - } - } - ''; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let + fakeReply = pkgs.writeText "namecoin-reply.json" '' + { "error": null, + "id": 1, + "result": { + "address": "T31q8ucJ4dI1xzhxQ5QispfECld5c7Xw", + "expired": false, + "expires_in": 2248, + "height": 438155, + "name": "d/test", + "txid": "db61c0b2540ba0c1a2c8cc92af703a37002e7566ecea4dbf8727c7191421edfb", + "value": "{\"ip\": \"1.2.3.4\", \"email\": \"root@test.bit\",\"info\": \"Fake record\"}", + "vout": 0 + } + } + ''; - # Disabled because DNSSEC does not currently validate, - # see https://github.com/namecoin/ncdns/issues/127 - dnssec = false; + # Disabled because DNSSEC does not currently validate, + # see https://github.com/namecoin/ncdns/issues/127 + dnssec = false; -in + in -{ - name = "ncdns"; - meta = with pkgs.lib.maintainers; { - maintainers = [ rnhmjoj ]; - }; + { + name = "ncdns"; + meta = with pkgs.lib.maintainers; { + maintainers = [ rnhmjoj ]; + }; - nodes.server = { ... }: { - networking.nameservers = [ "::1" ]; + nodes.server = + { ... }: + { + networking.nameservers = [ "::1" ]; - services.namecoind.rpc = { - address = "::1"; - user = "namecoin"; - password = "secret"; - port = 8332; - }; + services.namecoind.rpc = { + address = "::1"; + user = "namecoin"; + password = "secret"; + port = 8332; + }; - # Fake namecoin RPC server because we can't - # run a full node in a test. - systemd.services.namecoind = { - wantedBy = [ "multi-user.target" ]; - script = '' - while true; do - echo -e "HTTP/1.1 200 OK\n\n $(<${fakeReply})\n" \ - | ${pkgs.netcat}/bin/nc -N -l ::1 8332 - done - ''; - }; + # Fake namecoin RPC server because we can't + # run a full node in a test. + systemd.services.namecoind = { + wantedBy = [ "multi-user.target" ]; + script = '' + while true; do + echo -e "HTTP/1.1 200 OK\n\n $(<${fakeReply})\n" \ + | ${pkgs.netcat}/bin/nc -N -l ::1 8332 + done + ''; + }; - services.ncdns = { - enable = true; - dnssec.enable = dnssec; - identity.hostname = "example.com"; - identity.hostmaster = "root@example.com"; - identity.address = "1.0.0.1"; - }; + services.ncdns = { + enable = true; + dnssec.enable = dnssec; + identity.hostname = "example.com"; + identity.hostmaster = "root@example.com"; + identity.address = "1.0.0.1"; + }; - services.pdns-recursor.enable = true; - services.pdns-recursor.resolveNamecoin = true; + services.pdns-recursor.enable = true; + services.pdns-recursor.resolveNamecoin = true; - environment.systemPackages = [ pkgs.dnsutils ]; - }; + environment.systemPackages = [ pkgs.dnsutils ]; + }; - testScript = - (lib.optionalString dnssec '' - with subtest("DNSSEC keys have been generated"): - server.wait_for_unit("ncdns") - server.wait_for_file("/var/lib/ncdns/bit.key") - server.wait_for_file("/var/lib/ncdns/bit-zone.key") + testScript = + (lib.optionalString dnssec '' + with subtest("DNSSEC keys have been generated"): + server.wait_for_unit("ncdns") + server.wait_for_file("/var/lib/ncdns/bit.key") + server.wait_for_file("/var/lib/ncdns/bit-zone.key") - with subtest("DNSKEY bit record is present"): - server.wait_for_unit("pdns-recursor") - server.wait_for_open_port(53) - server.succeed("host -t DNSKEY bit") - '') + - '' - with subtest("can resolve a .bit name"): - server.wait_for_unit("namecoind") - server.wait_for_unit("ncdns") - server.wait_for_open_port(8332) - assert "1.2.3.4" in server.succeed("dig @localhost -p 5333 test.bit") + with subtest("DNSKEY bit record is present"): + server.wait_for_unit("pdns-recursor") + server.wait_for_open_port(53) + server.succeed("host -t DNSKEY bit") + '') + + '' + with subtest("can resolve a .bit name"): + server.wait_for_unit("namecoind") + server.wait_for_unit("ncdns") + server.wait_for_open_port(8332) + assert "1.2.3.4" in server.succeed("dig @localhost -p 5333 test.bit") - with subtest("SOA record has identity information"): - assert "example.com" in server.succeed("dig SOA @localhost -p 5333 bit") + with subtest("SOA record has identity information"): + assert "example.com" in server.succeed("dig SOA @localhost -p 5333 bit") - with subtest("bit. zone forwarding works"): - server.wait_for_unit("pdns-recursor") - assert "1.2.3.4" in server.succeed("host test.bit") - ''; -}) + with subtest("bit. zone forwarding works"): + server.wait_for_unit("pdns-recursor") + assert "1.2.3.4" in server.succeed("host test.bit") + ''; + } +) diff --git a/nixos/tests/ndppd.nix b/nixos/tests/ndppd.nix index e79e2a097b4063..23f1826cc3f712 100644 --- a/nixos/tests/ndppd.nix +++ b/nixos/tests/ndppd.nix @@ -1,60 +1,74 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : { - name = "ndppd"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fpletz ]; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "ndppd"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fpletz ]; + }; - nodes = { - upstream = { pkgs, ... }: { - environment.systemPackages = [ pkgs.tcpdump ]; - networking.useDHCP = false; - networking.interfaces = { - eth1 = { - ipv6.addresses = [ - { address = "fd23::1"; prefixLength = 112; } - ]; - ipv6.routes = [ - { address = "fd42::"; - prefixLength = 112; - } - ]; + nodes = { + upstream = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.tcpdump ]; + networking.useDHCP = false; + networking.interfaces = { + eth1 = { + ipv6.addresses = [ + { + address = "fd23::1"; + prefixLength = 112; + } + ]; + ipv6.routes = [ + { + address = "fd42::"; + prefixLength = 112; + } + ]; + }; + }; }; - }; - }; - server = { pkgs, ... }: { - boot.kernel.sysctl = { - "net.ipv6.conf.all.forwarding" = "1"; - "net.ipv6.conf.default.forwarding" = "1"; - }; - environment.systemPackages = [ pkgs.tcpdump ]; - networking.useDHCP = false; - networking.interfaces = { - eth1 = { - ipv6.addresses = [ - { address = "fd23::2"; prefixLength = 112; } - ]; + server = + { pkgs, ... }: + { + boot.kernel.sysctl = { + "net.ipv6.conf.all.forwarding" = "1"; + "net.ipv6.conf.default.forwarding" = "1"; + }; + environment.systemPackages = [ pkgs.tcpdump ]; + networking.useDHCP = false; + networking.interfaces = { + eth1 = { + ipv6.addresses = [ + { + address = "fd23::2"; + prefixLength = 112; + } + ]; + }; + }; + services.ndppd = { + enable = true; + proxies.eth1.rules."fd42::/112" = { }; + }; + containers.client = { + autoStart = true; + privateNetwork = true; + hostAddress = "192.168.255.1"; + localAddress = "192.168.255.2"; + hostAddress6 = "fd42::1"; + localAddress6 = "fd42::2"; + config = { }; + }; }; - }; - services.ndppd = { - enable = true; - proxies.eth1.rules."fd42::/112" = {}; - }; - containers.client = { - autoStart = true; - privateNetwork = true; - hostAddress = "192.168.255.1"; - localAddress = "192.168.255.2"; - hostAddress6 = "fd42::1"; - localAddress6 = "fd42::2"; - config = {}; - }; }; - }; - testScript = '' - start_all() - server.wait_for_unit("multi-user.target") - upstream.wait_for_unit("multi-user.target") - upstream.wait_until_succeeds("ping -c5 fd42::2") - ''; -}) + testScript = '' + start_all() + server.wait_for_unit("multi-user.target") + upstream.wait_for_unit("multi-user.target") + upstream.wait_until_succeeds("ping -c5 fd42::2") + ''; + } +) diff --git a/nixos/tests/nebula.nix b/nixos/tests/nebula.nix index 124be233219642..b3096424a614a8 100644 --- a/nixos/tests/nebula.nix +++ b/nixos/tests/nebula.nix @@ -1,312 +1,413 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: let - - # We'll need to be able to trade cert files between nodes via scp. - inherit (import ./ssh-keys.nix pkgs) - snakeOilPrivateKey snakeOilPublicKey; - - makeNebulaNode = { config, ... }: name: extraConfig: lib.mkMerge [ - { - # Expose nebula for doing cert signing. - environment.systemPackages = [ pkgs.nebula ]; - users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; - services.openssh.enable = true; - networking.firewall.enable = true; # Implicitly true, but let's make sure. - networking.interfaces.eth1.useDHCP = false; - - services.nebula.networks.smoke = { - # Note that these paths won't exist when the machine is first booted. - ca = "/etc/nebula/ca.crt"; - cert = "/etc/nebula/${name}.crt"; - key = "/etc/nebula/${name}.key"; - listen = { - host = "0.0.0.0"; - port = if (config.services.nebula.networks.smoke.isLighthouse || config.services.nebula.networks.smoke.isRelay) then 4242 else 0; - }; - }; - } - extraConfig - ]; - -in -{ - name = "nebula"; - - nodes = { - - lighthouse = { ... } @ args: - makeNebulaNode args "lighthouse" { - networking.interfaces.eth1.ipv4.addresses = lib.mkForce [{ - address = "192.168.1.1"; - prefixLength = 24; - }]; - - services.nebula.networks.smoke = { - isLighthouse = true; - isRelay = true; - firewall = { - outbound = [ { port = "any"; proto = "any"; host = "any"; } ]; - inbound = [ { port = "any"; proto = "any"; host = "any"; } ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + + # We'll need to be able to trade cert files between nodes via scp. + inherit (import ./ssh-keys.nix pkgs) + snakeOilPrivateKey + snakeOilPublicKey + ; + + makeNebulaNode = + { config, ... }: + name: extraConfig: + lib.mkMerge [ + { + # Expose nebula for doing cert signing. + environment.systemPackages = [ pkgs.nebula ]; + users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; + services.openssh.enable = true; + networking.firewall.enable = true; # Implicitly true, but let's make sure. + networking.interfaces.eth1.useDHCP = false; + + services.nebula.networks.smoke = { + # Note that these paths won't exist when the machine is first booted. + ca = "/etc/nebula/ca.crt"; + cert = "/etc/nebula/${name}.crt"; + key = "/etc/nebula/${name}.key"; + listen = { + host = "0.0.0.0"; + port = + if + ( + config.services.nebula.networks.smoke.isLighthouse || config.services.nebula.networks.smoke.isRelay + ) + then + 4242 + else + 0; + }; + }; + } + extraConfig + ]; + + in + { + name = "nebula"; + + nodes = { + + lighthouse = + { ... }@args: + makeNebulaNode args "lighthouse" { + networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; + + services.nebula.networks.smoke = { + isLighthouse = true; + isRelay = true; + firewall = { + outbound = [ + { + port = "any"; + proto = "any"; + host = "any"; + } + ]; + inbound = [ + { + port = "any"; + proto = "any"; + host = "any"; + } + ]; + }; }; }; - }; - - allowAny = { ... } @ args: - makeNebulaNode args "allowAny" { - networking.interfaces.eth1.ipv4.addresses = lib.mkForce [{ - address = "192.168.1.2"; - prefixLength = 24; - }]; - - services.nebula.networks.smoke = { - staticHostMap = { "10.0.100.1" = [ "192.168.1.1:4242" ]; }; - isLighthouse = false; - lighthouses = [ "10.0.100.1" ]; - relays = [ "10.0.100.1" ]; - firewall = { - outbound = [ { port = "any"; proto = "any"; host = "any"; } ]; - inbound = [ { port = "any"; proto = "any"; host = "any"; } ]; + + allowAny = + { ... }@args: + makeNebulaNode args "allowAny" { + networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ + { + address = "192.168.1.2"; + prefixLength = 24; + } + ]; + + services.nebula.networks.smoke = { + staticHostMap = { + "10.0.100.1" = [ "192.168.1.1:4242" ]; + }; + isLighthouse = false; + lighthouses = [ "10.0.100.1" ]; + relays = [ "10.0.100.1" ]; + firewall = { + outbound = [ + { + port = "any"; + proto = "any"; + host = "any"; + } + ]; + inbound = [ + { + port = "any"; + proto = "any"; + host = "any"; + } + ]; + }; }; }; - }; - - allowFromLighthouse = { ... } @ args: - makeNebulaNode args "allowFromLighthouse" { - networking.interfaces.eth1.ipv4.addresses = lib.mkForce [{ - address = "192.168.1.3"; - prefixLength = 24; - }]; - - services.nebula.networks.smoke = { - staticHostMap = { "10.0.100.1" = [ "192.168.1.1:4242" ]; }; - isLighthouse = false; - lighthouses = [ "10.0.100.1" ]; - relays = [ "10.0.100.1" ]; - firewall = { - outbound = [ { port = "any"; proto = "any"; host = "any"; } ]; - inbound = [ { port = "any"; proto = "any"; host = "lighthouse"; } ]; + + allowFromLighthouse = + { ... }@args: + makeNebulaNode args "allowFromLighthouse" { + networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ + { + address = "192.168.1.3"; + prefixLength = 24; + } + ]; + + services.nebula.networks.smoke = { + staticHostMap = { + "10.0.100.1" = [ "192.168.1.1:4242" ]; + }; + isLighthouse = false; + lighthouses = [ "10.0.100.1" ]; + relays = [ "10.0.100.1" ]; + firewall = { + outbound = [ + { + port = "any"; + proto = "any"; + host = "any"; + } + ]; + inbound = [ + { + port = "any"; + proto = "any"; + host = "lighthouse"; + } + ]; + }; }; }; - }; - - allowToLighthouse = { ... } @ args: - makeNebulaNode args "allowToLighthouse" { - networking.interfaces.eth1.ipv4.addresses = lib.mkForce [{ - address = "192.168.1.4"; - prefixLength = 24; - }]; - - services.nebula.networks.smoke = { - enable = true; - staticHostMap = { "10.0.100.1" = [ "192.168.1.1:4242" ]; }; - isLighthouse = false; - lighthouses = [ "10.0.100.1" ]; - relays = [ "10.0.100.1" ]; - firewall = { - outbound = [ { port = "any"; proto = "any"; host = "lighthouse"; } ]; - inbound = [ { port = "any"; proto = "any"; host = "any"; } ]; + + allowToLighthouse = + { ... }@args: + makeNebulaNode args "allowToLighthouse" { + networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ + { + address = "192.168.1.4"; + prefixLength = 24; + } + ]; + + services.nebula.networks.smoke = { + enable = true; + staticHostMap = { + "10.0.100.1" = [ "192.168.1.1:4242" ]; + }; + isLighthouse = false; + lighthouses = [ "10.0.100.1" ]; + relays = [ "10.0.100.1" ]; + firewall = { + outbound = [ + { + port = "any"; + proto = "any"; + host = "lighthouse"; + } + ]; + inbound = [ + { + port = "any"; + proto = "any"; + host = "any"; + } + ]; + }; }; }; - }; - - disabled = { ... } @ args: - makeNebulaNode args "disabled" { - networking.interfaces.eth1.ipv4.addresses = lib.mkForce [{ - address = "192.168.1.5"; - prefixLength = 24; - }]; - - services.nebula.networks.smoke = { - enable = false; - staticHostMap = { "10.0.100.1" = [ "192.168.1.1:4242" ]; }; - isLighthouse = false; - lighthouses = [ "10.0.100.1" ]; - relays = [ "10.0.100.1" ]; - firewall = { - outbound = [ { port = "any"; proto = "any"; host = "lighthouse"; } ]; - inbound = [ { port = "any"; proto = "any"; host = "any"; } ]; + + disabled = + { ... }@args: + makeNebulaNode args "disabled" { + networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ + { + address = "192.168.1.5"; + prefixLength = 24; + } + ]; + + services.nebula.networks.smoke = { + enable = false; + staticHostMap = { + "10.0.100.1" = [ "192.168.1.1:4242" ]; + }; + isLighthouse = false; + lighthouses = [ "10.0.100.1" ]; + relays = [ "10.0.100.1" ]; + firewall = { + outbound = [ + { + port = "any"; + proto = "any"; + host = "lighthouse"; + } + ]; + inbound = [ + { + port = "any"; + proto = "any"; + host = "any"; + } + ]; + }; }; }; - }; - - }; - - testScript = let - - setUpPrivateKey = name: '' - ${name}.start() - ${name}.succeed( - "mkdir -p /root/.ssh", - "chmod 700 /root/.ssh", - "cat '${snakeOilPrivateKey}' > /root/.ssh/id_snakeoil", - "chmod 600 /root/.ssh/id_snakeoil", - "mkdir -p /root" - ) - ''; - - # From what I can tell, StrictHostKeyChecking=no is necessary for ssh to work between machines. - sshOpts = "-oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null -oIdentityFile=/root/.ssh/id_snakeoil"; - - restartAndCheckNebula = name: ip: '' - ${name}.systemctl("restart nebula@smoke.service") - ${name}.succeed("ping -c5 ${ip}") - ''; - - # Create a keypair on the client node, then use the public key to sign a cert on the lighthouse. - signKeysFor = name: ip: '' - lighthouse.wait_for_unit("sshd.service") - ${name}.wait_for_unit("sshd.service") - ${name}.succeed( - "mkdir -p /etc/nebula", - "nebula-cert keygen -out-key /etc/nebula/${name}.key -out-pub /etc/nebula/${name}.pub", - "scp ${sshOpts} /etc/nebula/${name}.pub root@192.168.1.1:/root/${name}.pub", - ) - lighthouse.succeed( - 'nebula-cert sign -ca-crt /etc/nebula/ca.crt -ca-key /etc/nebula/ca.key -name "${name}" -groups "${name}" -ip "${ip}" -in-pub /root/${name}.pub -out-crt /root/${name}.crt' - ) - ${name}.succeed( - "scp ${sshOpts} root@192.168.1.1:/root/${name}.crt /etc/nebula/${name}.crt", - "scp ${sshOpts} root@192.168.1.1:/etc/nebula/ca.crt /etc/nebula/ca.crt", - '(id nebula-smoke >/dev/null && chown -R nebula-smoke:nebula-smoke /etc/nebula) || true' - ) - ''; - - getPublicIp = node: '' - ${node}.succeed("ip --brief addr show eth1 | awk '{print $3}' | tail -n1 | cut -d/ -f1").strip() - ''; - - # Never do this for anything security critical! (Thankfully it's just a test.) - # Restart Nebula right after the mutual block and/or restore so the state is fresh. - blockTrafficBetween = nodeA: nodeB: '' - node_a = ${getPublicIp nodeA} - node_b = ${getPublicIp nodeB} - ${nodeA}.succeed("iptables -I INPUT -s " + node_b + " -j DROP") - ${nodeB}.succeed("iptables -I INPUT -s " + node_a + " -j DROP") - ${nodeA}.systemctl("restart nebula@smoke.service") - ${nodeB}.systemctl("restart nebula@smoke.service") - ''; - allowTrafficBetween = nodeA: nodeB: '' - node_a = ${getPublicIp nodeA} - node_b = ${getPublicIp nodeB} - ${nodeA}.succeed("iptables -D INPUT -s " + node_b + " -j DROP") - ${nodeB}.succeed("iptables -D INPUT -s " + node_a + " -j DROP") - ${nodeA}.systemctl("restart nebula@smoke.service") - ${nodeB}.systemctl("restart nebula@smoke.service") - ''; - in '' - # Create the certificate and sign the lighthouse's keys. - ${setUpPrivateKey "lighthouse"} - lighthouse.succeed( - "mkdir -p /etc/nebula", - 'nebula-cert ca -name "Smoke Test" -out-crt /etc/nebula/ca.crt -out-key /etc/nebula/ca.key', - 'nebula-cert sign -ca-crt /etc/nebula/ca.crt -ca-key /etc/nebula/ca.key -name "lighthouse" -groups "lighthouse" -ip "10.0.100.1/24" -out-crt /etc/nebula/lighthouse.crt -out-key /etc/nebula/lighthouse.key', - 'chown -R nebula-smoke:nebula-smoke /etc/nebula' - ) - - # Reboot the lighthouse and verify that the nebula service comes up on boot. - # Since rebooting takes a while, we'll just restart the service on the other nodes. - lighthouse.shutdown() - lighthouse.start() - lighthouse.wait_for_unit("nebula@smoke.service") - lighthouse.succeed("ping -c5 10.0.100.1") - - # Create keys for allowAny's nebula service and test that it comes up. - ${setUpPrivateKey "allowAny"} - ${signKeysFor "allowAny" "10.0.100.2/24"} - ${restartAndCheckNebula "allowAny" "10.0.100.2"} - - # Create keys for allowFromLighthouse's nebula service and test that it comes up. - ${setUpPrivateKey "allowFromLighthouse"} - ${signKeysFor "allowFromLighthouse" "10.0.100.3/24"} - ${restartAndCheckNebula "allowFromLighthouse" "10.0.100.3"} - - # Create keys for allowToLighthouse's nebula service and test that it comes up. - ${setUpPrivateKey "allowToLighthouse"} - ${signKeysFor "allowToLighthouse" "10.0.100.4/24"} - ${restartAndCheckNebula "allowToLighthouse" "10.0.100.4"} - - # Create keys for disabled's nebula service and test that it does not come up. - ${setUpPrivateKey "disabled"} - ${signKeysFor "disabled" "10.0.100.5/24"} - disabled.fail("systemctl status nebula@smoke.service") - disabled.fail("ping -c5 10.0.100.5") - - # The lighthouse can ping allowAny and allowFromLighthouse but not disabled - lighthouse.succeed("ping -c3 10.0.100.2") - lighthouse.succeed("ping -c3 10.0.100.3") - lighthouse.fail("ping -c3 10.0.100.5") - - # allowAny can ping the lighthouse, but not allowFromLighthouse because of its inbound firewall - allowAny.succeed("ping -c3 10.0.100.1") - allowAny.fail("ping -c3 10.0.100.3") - - # allowFromLighthouse can ping the lighthouse and allowAny - allowFromLighthouse.succeed("ping -c3 10.0.100.1") - allowFromLighthouse.succeed("ping -c3 10.0.100.2") - - # block allowFromLighthouse <-> allowAny, and allowFromLighthouse -> allowAny should still work. - ${blockTrafficBetween "allowFromLighthouse" "allowAny"} - allowFromLighthouse.succeed("ping -c10 10.0.100.2") - ${allowTrafficBetween "allowFromLighthouse" "allowAny"} - allowFromLighthouse.succeed("ping -c10 10.0.100.2") - - # allowToLighthouse can ping the lighthouse but not allowAny or allowFromLighthouse - allowToLighthouse.succeed("ping -c3 10.0.100.1") - allowToLighthouse.fail("ping -c3 10.0.100.2") - allowToLighthouse.fail("ping -c3 10.0.100.3") - - # allowAny can ping allowFromLighthouse now that allowFromLighthouse pinged it first - allowAny.succeed("ping -c3 10.0.100.3") - - # block allowAny <-> allowFromLighthouse, and allowAny -> allowFromLighthouse should still work. - ${blockTrafficBetween "allowAny" "allowFromLighthouse"} - allowFromLighthouse.succeed("ping -c10 10.0.100.2") - allowAny.succeed("ping -c10 10.0.100.3") - ${allowTrafficBetween "allowAny" "allowFromLighthouse"} - allowFromLighthouse.succeed("ping -c10 10.0.100.2") - allowAny.succeed("ping -c10 10.0.100.3") - - # allowToLighthouse can ping allowAny if allowAny pings it first - allowAny.succeed("ping -c3 10.0.100.4") - allowToLighthouse.succeed("ping -c3 10.0.100.2") - - # block allowToLighthouse <-> allowAny, and allowAny <-> allowToLighthouse should still work. - ${blockTrafficBetween "allowAny" "allowToLighthouse"} - allowAny.succeed("ping -c10 10.0.100.4") - allowToLighthouse.succeed("ping -c10 10.0.100.2") - ${allowTrafficBetween "allowAny" "allowToLighthouse"} - allowAny.succeed("ping -c10 10.0.100.4") - allowToLighthouse.succeed("ping -c10 10.0.100.2") - - # block lighthouse <-> allowFromLighthouse and allowAny <-> allowFromLighthouse; allowFromLighthouse won't get to allowAny - ${blockTrafficBetween "allowFromLighthouse" "lighthouse"} - ${blockTrafficBetween "allowFromLighthouse" "allowAny"} - allowFromLighthouse.fail("ping -c3 10.0.100.2") - ${allowTrafficBetween "allowFromLighthouse" "lighthouse"} - ${allowTrafficBetween "allowFromLighthouse" "allowAny"} - allowFromLighthouse.succeed("ping -c3 10.0.100.2") - - # block lighthouse <-> allowAny, allowAny <-> allowFromLighthouse, and allowAny <-> allowToLighthouse; it won't get to allowFromLighthouse or allowToLighthouse - ${blockTrafficBetween "allowAny" "lighthouse"} - ${blockTrafficBetween "allowAny" "allowFromLighthouse"} - ${blockTrafficBetween "allowAny" "allowToLighthouse"} - allowFromLighthouse.fail("ping -c3 10.0.100.2") - allowAny.fail("ping -c3 10.0.100.3") - allowAny.fail("ping -c3 10.0.100.4") - ${allowTrafficBetween "allowAny" "lighthouse"} - ${allowTrafficBetween "allowAny" "allowFromLighthouse"} - ${allowTrafficBetween "allowAny" "allowToLighthouse"} - allowFromLighthouse.succeed("ping -c3 10.0.100.2") - allowAny.succeed("ping -c3 10.0.100.3") - allowAny.succeed("ping -c3 10.0.100.4") - - # block lighthouse <-> allowToLighthouse and allowToLighthouse <-> allowAny; it won't get to allowAny - ${blockTrafficBetween "allowToLighthouse" "lighthouse"} - ${blockTrafficBetween "allowToLighthouse" "allowAny"} - allowAny.fail("ping -c3 10.0.100.4") - allowToLighthouse.fail("ping -c3 10.0.100.2") - ${allowTrafficBetween "allowToLighthouse" "lighthouse"} - ${allowTrafficBetween "allowToLighthouse" "allowAny"} - allowAny.succeed("ping -c3 10.0.100.4") - allowToLighthouse.succeed("ping -c3 10.0.100.2") - ''; -}) + + }; + + testScript = + let + + setUpPrivateKey = name: '' + ${name}.start() + ${name}.succeed( + "mkdir -p /root/.ssh", + "chmod 700 /root/.ssh", + "cat '${snakeOilPrivateKey}' > /root/.ssh/id_snakeoil", + "chmod 600 /root/.ssh/id_snakeoil", + "mkdir -p /root" + ) + ''; + + # From what I can tell, StrictHostKeyChecking=no is necessary for ssh to work between machines. + sshOpts = "-oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null -oIdentityFile=/root/.ssh/id_snakeoil"; + + restartAndCheckNebula = name: ip: '' + ${name}.systemctl("restart nebula@smoke.service") + ${name}.succeed("ping -c5 ${ip}") + ''; + + # Create a keypair on the client node, then use the public key to sign a cert on the lighthouse. + signKeysFor = name: ip: '' + lighthouse.wait_for_unit("sshd.service") + ${name}.wait_for_unit("sshd.service") + ${name}.succeed( + "mkdir -p /etc/nebula", + "nebula-cert keygen -out-key /etc/nebula/${name}.key -out-pub /etc/nebula/${name}.pub", + "scp ${sshOpts} /etc/nebula/${name}.pub root@192.168.1.1:/root/${name}.pub", + ) + lighthouse.succeed( + 'nebula-cert sign -ca-crt /etc/nebula/ca.crt -ca-key /etc/nebula/ca.key -name "${name}" -groups "${name}" -ip "${ip}" -in-pub /root/${name}.pub -out-crt /root/${name}.crt' + ) + ${name}.succeed( + "scp ${sshOpts} root@192.168.1.1:/root/${name}.crt /etc/nebula/${name}.crt", + "scp ${sshOpts} root@192.168.1.1:/etc/nebula/ca.crt /etc/nebula/ca.crt", + '(id nebula-smoke >/dev/null && chown -R nebula-smoke:nebula-smoke /etc/nebula) || true' + ) + ''; + + getPublicIp = node: '' + ${node}.succeed("ip --brief addr show eth1 | awk '{print $3}' | tail -n1 | cut -d/ -f1").strip() + ''; + + # Never do this for anything security critical! (Thankfully it's just a test.) + # Restart Nebula right after the mutual block and/or restore so the state is fresh. + blockTrafficBetween = nodeA: nodeB: '' + node_a = ${getPublicIp nodeA} + node_b = ${getPublicIp nodeB} + ${nodeA}.succeed("iptables -I INPUT -s " + node_b + " -j DROP") + ${nodeB}.succeed("iptables -I INPUT -s " + node_a + " -j DROP") + ${nodeA}.systemctl("restart nebula@smoke.service") + ${nodeB}.systemctl("restart nebula@smoke.service") + ''; + allowTrafficBetween = nodeA: nodeB: '' + node_a = ${getPublicIp nodeA} + node_b = ${getPublicIp nodeB} + ${nodeA}.succeed("iptables -D INPUT -s " + node_b + " -j DROP") + ${nodeB}.succeed("iptables -D INPUT -s " + node_a + " -j DROP") + ${nodeA}.systemctl("restart nebula@smoke.service") + ${nodeB}.systemctl("restart nebula@smoke.service") + ''; + in + '' + # Create the certificate and sign the lighthouse's keys. + ${setUpPrivateKey "lighthouse"} + lighthouse.succeed( + "mkdir -p /etc/nebula", + 'nebula-cert ca -name "Smoke Test" -out-crt /etc/nebula/ca.crt -out-key /etc/nebula/ca.key', + 'nebula-cert sign -ca-crt /etc/nebula/ca.crt -ca-key /etc/nebula/ca.key -name "lighthouse" -groups "lighthouse" -ip "10.0.100.1/24" -out-crt /etc/nebula/lighthouse.crt -out-key /etc/nebula/lighthouse.key', + 'chown -R nebula-smoke:nebula-smoke /etc/nebula' + ) + + # Reboot the lighthouse and verify that the nebula service comes up on boot. + # Since rebooting takes a while, we'll just restart the service on the other nodes. + lighthouse.shutdown() + lighthouse.start() + lighthouse.wait_for_unit("nebula@smoke.service") + lighthouse.succeed("ping -c5 10.0.100.1") + + # Create keys for allowAny's nebula service and test that it comes up. + ${setUpPrivateKey "allowAny"} + ${signKeysFor "allowAny" "10.0.100.2/24"} + ${restartAndCheckNebula "allowAny" "10.0.100.2"} + + # Create keys for allowFromLighthouse's nebula service and test that it comes up. + ${setUpPrivateKey "allowFromLighthouse"} + ${signKeysFor "allowFromLighthouse" "10.0.100.3/24"} + ${restartAndCheckNebula "allowFromLighthouse" "10.0.100.3"} + + # Create keys for allowToLighthouse's nebula service and test that it comes up. + ${setUpPrivateKey "allowToLighthouse"} + ${signKeysFor "allowToLighthouse" "10.0.100.4/24"} + ${restartAndCheckNebula "allowToLighthouse" "10.0.100.4"} + + # Create keys for disabled's nebula service and test that it does not come up. + ${setUpPrivateKey "disabled"} + ${signKeysFor "disabled" "10.0.100.5/24"} + disabled.fail("systemctl status nebula@smoke.service") + disabled.fail("ping -c5 10.0.100.5") + + # The lighthouse can ping allowAny and allowFromLighthouse but not disabled + lighthouse.succeed("ping -c3 10.0.100.2") + lighthouse.succeed("ping -c3 10.0.100.3") + lighthouse.fail("ping -c3 10.0.100.5") + + # allowAny can ping the lighthouse, but not allowFromLighthouse because of its inbound firewall + allowAny.succeed("ping -c3 10.0.100.1") + allowAny.fail("ping -c3 10.0.100.3") + + # allowFromLighthouse can ping the lighthouse and allowAny + allowFromLighthouse.succeed("ping -c3 10.0.100.1") + allowFromLighthouse.succeed("ping -c3 10.0.100.2") + + # block allowFromLighthouse <-> allowAny, and allowFromLighthouse -> allowAny should still work. + ${blockTrafficBetween "allowFromLighthouse" "allowAny"} + allowFromLighthouse.succeed("ping -c10 10.0.100.2") + ${allowTrafficBetween "allowFromLighthouse" "allowAny"} + allowFromLighthouse.succeed("ping -c10 10.0.100.2") + + # allowToLighthouse can ping the lighthouse but not allowAny or allowFromLighthouse + allowToLighthouse.succeed("ping -c3 10.0.100.1") + allowToLighthouse.fail("ping -c3 10.0.100.2") + allowToLighthouse.fail("ping -c3 10.0.100.3") + + # allowAny can ping allowFromLighthouse now that allowFromLighthouse pinged it first + allowAny.succeed("ping -c3 10.0.100.3") + + # block allowAny <-> allowFromLighthouse, and allowAny -> allowFromLighthouse should still work. + ${blockTrafficBetween "allowAny" "allowFromLighthouse"} + allowFromLighthouse.succeed("ping -c10 10.0.100.2") + allowAny.succeed("ping -c10 10.0.100.3") + ${allowTrafficBetween "allowAny" "allowFromLighthouse"} + allowFromLighthouse.succeed("ping -c10 10.0.100.2") + allowAny.succeed("ping -c10 10.0.100.3") + + # allowToLighthouse can ping allowAny if allowAny pings it first + allowAny.succeed("ping -c3 10.0.100.4") + allowToLighthouse.succeed("ping -c3 10.0.100.2") + + # block allowToLighthouse <-> allowAny, and allowAny <-> allowToLighthouse should still work. + ${blockTrafficBetween "allowAny" "allowToLighthouse"} + allowAny.succeed("ping -c10 10.0.100.4") + allowToLighthouse.succeed("ping -c10 10.0.100.2") + ${allowTrafficBetween "allowAny" "allowToLighthouse"} + allowAny.succeed("ping -c10 10.0.100.4") + allowToLighthouse.succeed("ping -c10 10.0.100.2") + + # block lighthouse <-> allowFromLighthouse and allowAny <-> allowFromLighthouse; allowFromLighthouse won't get to allowAny + ${blockTrafficBetween "allowFromLighthouse" "lighthouse"} + ${blockTrafficBetween "allowFromLighthouse" "allowAny"} + allowFromLighthouse.fail("ping -c3 10.0.100.2") + ${allowTrafficBetween "allowFromLighthouse" "lighthouse"} + ${allowTrafficBetween "allowFromLighthouse" "allowAny"} + allowFromLighthouse.succeed("ping -c3 10.0.100.2") + + # block lighthouse <-> allowAny, allowAny <-> allowFromLighthouse, and allowAny <-> allowToLighthouse; it won't get to allowFromLighthouse or allowToLighthouse + ${blockTrafficBetween "allowAny" "lighthouse"} + ${blockTrafficBetween "allowAny" "allowFromLighthouse"} + ${blockTrafficBetween "allowAny" "allowToLighthouse"} + allowFromLighthouse.fail("ping -c3 10.0.100.2") + allowAny.fail("ping -c3 10.0.100.3") + allowAny.fail("ping -c3 10.0.100.4") + ${allowTrafficBetween "allowAny" "lighthouse"} + ${allowTrafficBetween "allowAny" "allowFromLighthouse"} + ${allowTrafficBetween "allowAny" "allowToLighthouse"} + allowFromLighthouse.succeed("ping -c3 10.0.100.2") + allowAny.succeed("ping -c3 10.0.100.3") + allowAny.succeed("ping -c3 10.0.100.4") + + # block lighthouse <-> allowToLighthouse and allowToLighthouse <-> allowAny; it won't get to allowAny + ${blockTrafficBetween "allowToLighthouse" "lighthouse"} + ${blockTrafficBetween "allowToLighthouse" "allowAny"} + allowAny.fail("ping -c3 10.0.100.4") + allowToLighthouse.fail("ping -c3 10.0.100.2") + ${allowTrafficBetween "allowToLighthouse" "lighthouse"} + ${allowTrafficBetween "allowToLighthouse" "allowAny"} + allowAny.succeed("ping -c3 10.0.100.4") + allowToLighthouse.succeed("ping -c3 10.0.100.2") + ''; + } +) diff --git a/nixos/tests/networking-proxy.nix b/nixos/tests/networking-proxy.nix index 72f33c78bd0ecd..4592bffec9e3db 100644 --- a/nixos/tests/networking-proxy.nix +++ b/nixos/tests/networking-proxy.nix @@ -3,68 +3,73 @@ # TODO: use a real proxy node and put this test into networking.nix # TODO: test whether nix tools work as expected behind a proxy -let default-config = { - imports = [ ./common/user-account.nix ]; +let + default-config = { + imports = [ ./common/user-account.nix ]; - services.xserver.enable = false; + services.xserver.enable = false; - }; -in import ./make-test-python.nix ({ pkgs, ...} : { - name = "networking-proxy"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; }; +in +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "networking-proxy"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; + + nodes = { + # no proxy + machine = + { ... }: + + default-config; + + # proxy default + machine2 = + { ... }: - nodes = { - # no proxy - machine = - { ... }: - - default-config; - - # proxy default - machine2 = - { ... }: - - default-config // { - networking.proxy.default = "http://user:pass@host:port"; - }; - - # specific proxy options - machine3 = - { ... }: - - default-config // - { - networking.proxy = { - # useless because overridden by the next options - default = "http://user:pass@host:port"; - # advanced proxy setup - httpProxy = "123-http://user:pass@http-host:port"; - httpsProxy = "456-http://user:pass@https-host:port"; - rsyncProxy = "789-http://user:pass@rsync-host:port"; - ftpProxy = "101112-http://user:pass@ftp-host:port"; - noProxy = "131415-127.0.0.1,localhost,.localdomain"; + default-config + // { + networking.proxy.default = "http://user:pass@host:port"; }; - }; - - # mix default + proxy options - machine4 = - { ... }: - - default-config // { - networking.proxy = { - # open for all *_proxy env var - default = "000-http://user:pass@default-host:port"; - # except for those 2 - rsyncProxy = "123-http://user:pass@http-host:port"; - noProxy = "131415-127.0.0.1,localhost,.localdomain"; + + # specific proxy options + machine3 = + { ... }: + + default-config + // { + networking.proxy = { + # useless because overridden by the next options + default = "http://user:pass@host:port"; + # advanced proxy setup + httpProxy = "123-http://user:pass@http-host:port"; + httpsProxy = "456-http://user:pass@https-host:port"; + rsyncProxy = "789-http://user:pass@rsync-host:port"; + ftpProxy = "101112-http://user:pass@ftp-host:port"; + noProxy = "131415-127.0.0.1,localhost,.localdomain"; + }; + }; + + # mix default + proxy options + machine4 = + { ... }: + + default-config + // { + networking.proxy = { + # open for all *_proxy env var + default = "000-http://user:pass@default-host:port"; + # except for those 2 + rsyncProxy = "123-http://user:pass@http-host:port"; + noProxy = "131415-127.0.0.1,localhost,.localdomain"; + }; }; - }; }; - testScript = - '' + testScript = '' from typing import Dict, Optional @@ -131,4 +136,5 @@ in import ./make-test-python.nix ({ pkgs, ...} : { assert "000" in env["ftp_proxy"] assert "131415" in env["no_proxy"] ''; -}) + } +) diff --git a/nixos/tests/networking/networkd-and-scripted.nix b/nixos/tests/networking/networkd-and-scripted.nix index 96347b0fdf2ecf..b7ed834f1f66de 100644 --- a/nixos/tests/networking/networkd-and-scripted.nix +++ b/nixos/tests/networking/networkd-and-scripted.nix @@ -1,22 +1,26 @@ -{ system ? builtins.currentSystem -, config ? {} -, pkgs ? import ../.. { inherit system config; } -# bool: whether to use networkd in the tests -, networkd }: +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, + # bool: whether to use networkd in the tests + networkd, +}: with import ../../lib/testing-python.nix { inherit system pkgs; }; let lib = pkgs.lib; router = import ./router.nix { inherit networkd; }; - clientConfig = extraConfig: lib.recursiveUpdate { - networking.useDHCP = false; - networking.useNetworkd = networkd; - } extraConfig; + clientConfig = + extraConfig: + lib.recursiveUpdate { + networking.useDHCP = false; + networking.useNetworkd = networkd; + } extraConfig; testCases = { loopback = { name = "Loopback"; - nodes.client = clientConfig {}; + nodes.client = clientConfig { }; testScript = '' start_all() client.wait_for_unit("network.target") @@ -32,53 +36,73 @@ let virtualisation.interfaces.enp1s0.vlan = 1; virtualisation.interfaces.enp2s0.vlan = 2; networking = { - defaultGateway = { address = "192.168.1.1"; interface = "enp1s0"; }; - defaultGateway6 = { address = "fd00:1234:5678:1::1"; interface = "enp1s0"; }; + defaultGateway = { + address = "192.168.1.1"; + interface = "enp1s0"; + }; + defaultGateway6 = { + address = "fd00:1234:5678:1::1"; + interface = "enp1s0"; + }; interfaces.enp1s0.ipv4.addresses = [ - { address = "192.168.1.2"; prefixLength = 24; } - { address = "192.168.1.3"; prefixLength = 32; } - { address = "192.168.1.10"; prefixLength = 32; } + { + address = "192.168.1.2"; + prefixLength = 24; + } + { + address = "192.168.1.3"; + prefixLength = 32; + } + { + address = "192.168.1.10"; + prefixLength = 32; + } ]; interfaces.enp2s0.ipv4.addresses = [ - { address = "192.168.2.2"; prefixLength = 24; } + { + address = "192.168.2.2"; + prefixLength = 24; + } ]; }; }; testScript = '' - start_all() - - client.wait_for_unit("network.target") - router.systemctl("start network-online.target") - router.wait_for_unit("network-online.target") - - with subtest("Make sure DHCP server is not started"): - client.fail("systemctl status kea-dhcp4-server.service") - client.fail("systemctl status kea-dhcp6-server.service") - - with subtest("Test vlan 1"): - client.wait_until_succeeds("ping -c 1 192.168.1.1") - router.wait_until_succeeds("ping -c 1 192.168.1.2") - router.wait_until_succeeds("ping -c 1 192.168.1.3") - router.wait_until_succeeds("ping -c 1 192.168.1.10") - - with subtest("Test vlan 2"): - client.wait_until_succeeds("ping -c 1 192.168.2.1") - router.wait_until_succeeds("ping -c 1 192.168.2.2") + start_all() - with subtest("Test default gateway"): - client.wait_until_succeeds("ping -c 1 192.168.3.1") - client.wait_until_succeeds("ping -c 1 fd00:1234:5678:3::1") - ''; + client.wait_for_unit("network.target") + router.systemctl("start network-online.target") + router.wait_for_unit("network-online.target") + + with subtest("Make sure DHCP server is not started"): + client.fail("systemctl status kea-dhcp4-server.service") + client.fail("systemctl status kea-dhcp6-server.service") + + with subtest("Test vlan 1"): + client.wait_until_succeeds("ping -c 1 192.168.1.1") + router.wait_until_succeeds("ping -c 1 192.168.1.2") + router.wait_until_succeeds("ping -c 1 192.168.1.3") + router.wait_until_succeeds("ping -c 1 192.168.1.10") + + with subtest("Test vlan 2"): + client.wait_until_succeeds("ping -c 1 192.168.2.1") + router.wait_until_succeeds("ping -c 1 192.168.2.2") + + with subtest("Test default gateway"): + client.wait_until_succeeds("ping -c 1 192.168.3.1") + client.wait_until_succeeds("ping -c 1 fd00:1234:5678:3::1") + ''; }; routeType = { name = "RouteType"; nodes.client = clientConfig { networking = { - interfaces.eth1.ipv4.routes = [{ - address = "192.168.1.127"; - prefixLength = 32; - type = "local"; - }]; + interfaces.eth1.ipv4.routes = [ + { + address = "192.168.1.127"; + prefixLength = 32; + type = "local"; + } + ]; }; }; testScript = '' @@ -95,7 +119,7 @@ let networking.interfaces = lib.mkForce { # Make sure DHCP defaults correctly even when some unrelated config # is set on the interface (nothing, in this case). - enp1s0 = {}; + enp1s0 = { }; }; networking.useNetworkd = networkd; virtualisation.interfaces.enp1s0.vlan = 1; @@ -120,39 +144,39 @@ let }; }; testScript = '' - router.start() - router.systemctl("start network-online.target") - router.wait_for_unit("network-online.target") - - client.start() - client.wait_for_unit("network.target") - - with subtest("Wait until we have an ip address on each interface"): - client.wait_until_succeeds("ip addr show dev enp1s0 | grep -q '192.168.1'") - client.wait_until_succeeds("ip addr show dev enp1s0 | grep -q 'fd00:1234:5678:1:'") - client.wait_until_succeeds("ip addr show dev enp2s0 | grep -q '192.168.2'") - client.wait_until_succeeds("ip addr show dev enp2s0 | grep -q 'fd00:1234:5678:2:'") - - with subtest("Wait until we have received the nameservers"): - if "${builtins.toJSON networkd}" == "true": - client.wait_until_succeeds("resolvectl status enp2s0 | grep -q 2001:db8::1") - client.wait_until_succeeds("resolvectl status enp2s0 | grep -q 192.168.2.1") - else: - client.wait_until_succeeds("resolvconf -l | grep -q 2001:db8::1") - client.wait_until_succeeds("resolvconf -l | grep -q 192.168.2.1") - - with subtest("Test vlan 1"): - client.wait_until_succeeds("ping -c 1 192.168.1.1") - client.wait_until_succeeds("ping -c 1 fd00:1234:5678:1::1") - router.wait_until_succeeds("ping -c 1 192.168.1.2") - router.wait_until_succeeds("ping -c 1 fd00:1234:5678:1::2") + router.start() + router.systemctl("start network-online.target") + router.wait_for_unit("network-online.target") - with subtest("Test vlan 2"): - client.wait_until_succeeds("ping -c 1 192.168.2.1") - client.wait_until_succeeds("ping -c 1 fd00:1234:5678:2::1") - router.wait_until_succeeds("ping -c 1 192.168.2.2") - router.wait_until_succeeds("ping -c 1 fd00:1234:5678:2::2") - ''; + client.start() + client.wait_for_unit("network.target") + + with subtest("Wait until we have an ip address on each interface"): + client.wait_until_succeeds("ip addr show dev enp1s0 | grep -q '192.168.1'") + client.wait_until_succeeds("ip addr show dev enp1s0 | grep -q 'fd00:1234:5678:1:'") + client.wait_until_succeeds("ip addr show dev enp2s0 | grep -q '192.168.2'") + client.wait_until_succeeds("ip addr show dev enp2s0 | grep -q 'fd00:1234:5678:2:'") + + with subtest("Wait until we have received the nameservers"): + if "${builtins.toJSON networkd}" == "true": + client.wait_until_succeeds("resolvectl status enp2s0 | grep -q 2001:db8::1") + client.wait_until_succeeds("resolvectl status enp2s0 | grep -q 192.168.2.1") + else: + client.wait_until_succeeds("resolvconf -l | grep -q 2001:db8::1") + client.wait_until_succeeds("resolvconf -l | grep -q 192.168.2.1") + + with subtest("Test vlan 1"): + client.wait_until_succeeds("ping -c 1 192.168.1.1") + client.wait_until_succeeds("ping -c 1 fd00:1234:5678:1::1") + router.wait_until_succeeds("ping -c 1 192.168.1.2") + router.wait_until_succeeds("ping -c 1 fd00:1234:5678:1::2") + + with subtest("Test vlan 2"): + client.wait_until_succeeds("ping -c 1 192.168.2.1") + client.wait_until_succeeds("ping -c 1 fd00:1234:5678:2::1") + router.wait_until_succeeds("ping -c 1 192.168.2.2") + router.wait_until_succeeds("ping -c 1 fd00:1234:5678:2::2") + ''; }; dhcpOneIf = { name = "OneInterfaceDHCP"; @@ -168,48 +192,59 @@ let }; }; testScript = '' - start_all() + start_all() - with subtest("Wait for networking to come up"): - client.wait_for_unit("network.target") - router.wait_for_unit("network.target") + with subtest("Wait for networking to come up"): + client.wait_for_unit("network.target") + router.wait_for_unit("network.target") - with subtest("Wait until we have an ip address on each interface"): - client.wait_until_succeeds("ip addr show dev enp1s0 | grep -q '192.168.1'") + with subtest("Wait until we have an ip address on each interface"): + client.wait_until_succeeds("ip addr show dev enp1s0 | grep -q '192.168.1'") - with subtest("ensure MTU is set"): - assert "mtu 1343" in client.succeed("ip link show dev enp1s0") + with subtest("ensure MTU is set"): + assert "mtu 1343" in client.succeed("ip link show dev enp1s0") - with subtest("Test vlan 1"): - client.wait_until_succeeds("ping -c 1 192.168.1.1") - router.wait_until_succeeds("ping -c 1 192.168.1.2") + with subtest("Test vlan 1"): + client.wait_until_succeeds("ping -c 1 192.168.1.1") + router.wait_until_succeeds("ping -c 1 192.168.1.2") - with subtest("Test vlan 2"): - client.wait_until_succeeds("ping -c 1 192.168.2.1") - client.fail("ping -c 1 192.168.2.2") + with subtest("Test vlan 2"): + client.wait_until_succeeds("ping -c 1 192.168.2.1") + client.fail("ping -c 1 192.168.2.2") - router.wait_until_succeeds("ping -c 1 192.168.2.1") - router.fail("ping -c 1 192.168.2.2") - ''; + router.wait_until_succeeds("ping -c 1 192.168.2.1") + router.fail("ping -c 1 192.168.2.2") + ''; }; - bond = let - node = address: clientConfig { - virtualisation.interfaces.enp1s0.vlan = 1; - virtualisation.interfaces.enp2s0.vlan = 2; - networking = { - bonds.bond0 = { - interfaces = [ "enp1s0" "enp2s0" ]; - driverOptions.mode = "802.3ad"; + bond = + let + node = + address: + clientConfig { + virtualisation.interfaces.enp1s0.vlan = 1; + virtualisation.interfaces.enp2s0.vlan = 2; + networking = { + bonds.bond0 = { + interfaces = [ + "enp1s0" + "enp2s0" + ]; + driverOptions.mode = "802.3ad"; + }; + interfaces.bond0.ipv4.addresses = lib.mkOverride 0 [ + { + inherit address; + prefixLength = 30; + } + ]; + }; }; - interfaces.bond0.ipv4.addresses = lib.mkOverride 0 - [ { inherit address; prefixLength = 30; } ]; - }; - }; - in { - name = "Bond"; - nodes.client1 = node "192.168.1.1"; - nodes.client2 = node "192.168.1.2"; - testScript = '' + in + { + name = "Bond"; + nodes.client1 = node "192.168.1.1"; + nodes.client2 = node "192.168.1.2"; + testScript = '' start_all() with subtest("Wait for networking to come up"): @@ -227,34 +262,57 @@ let for client in client1, client2: client.succeed('grep -q "Bonding Mode: IEEE 802.3ad Dynamic link aggregation" /proc/net/bonding/bond0') ''; - }; - bridge = let - node = { address, vlan }: { pkgs, ... }: { - virtualisation.interfaces.enp1s0.vlan = vlan; - networking = { - useNetworkd = networkd; - useDHCP = false; - interfaces.enp1s0.ipv4.addresses = [ { inherit address; prefixLength = 24; } ]; - }; }; - in { - name = "Bridge"; - nodes.client1 = node { address = "192.168.1.2"; vlan = 1; }; - nodes.client2 = node { address = "192.168.1.3"; vlan = 2; }; - nodes.router = { - virtualisation.interfaces.enp1s0.vlan = 1; - virtualisation.interfaces.enp2s0.vlan = 2; - networking = { - useNetworkd = networkd; - useDHCP = false; - bridges.bridge.interfaces = [ "enp1s0" "enp2s0" ]; - interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [ ]; - interfaces.eth2.ipv4.addresses = lib.mkOverride 0 [ ]; - interfaces.bridge.ipv4.addresses = lib.mkOverride 0 - [ { address = "192.168.1.1"; prefixLength = 24; } ]; + bridge = + let + node = + { address, vlan }: + { pkgs, ... }: + { + virtualisation.interfaces.enp1s0.vlan = vlan; + networking = { + useNetworkd = networkd; + useDHCP = false; + interfaces.enp1s0.ipv4.addresses = [ + { + inherit address; + prefixLength = 24; + } + ]; + }; + }; + in + { + name = "Bridge"; + nodes.client1 = node { + address = "192.168.1.2"; + vlan = 1; }; - }; - testScript = '' + nodes.client2 = node { + address = "192.168.1.3"; + vlan = 2; + }; + nodes.router = { + virtualisation.interfaces.enp1s0.vlan = 1; + virtualisation.interfaces.enp2s0.vlan = 2; + networking = { + useNetworkd = networkd; + useDHCP = false; + bridges.bridge.interfaces = [ + "enp1s0" + "enp2s0" + ]; + interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [ ]; + interfaces.eth2.ipv4.addresses = lib.mkOverride 0 [ ]; + interfaces.bridge.ipv4.addresses = lib.mkOverride 0 [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; + }; + }; + testScript = '' start_all() with subtest("Wait for networking to come up"): @@ -274,84 +332,105 @@ let router.wait_until_succeeds("ping -c 1 192.168.1.2") router.wait_until_succeeds("ping -c 1 192.168.1.3") ''; - }; + }; macvlan = { name = "MACVLAN"; nodes.router = router; - nodes.client = { pkgs, ... }: { - environment.systemPackages = [ pkgs.iptables ]; # to debug firewall rules - virtualisation.interfaces.enp1s0.vlan = 1; - networking = { - useNetworkd = networkd; - useDHCP = false; - firewall.logReversePathDrops = true; # to debug firewall rules - # reverse path filtering rules for the macvlan interface seem - # to be incorrect, causing the test to fail. Disable temporarily. - firewall.checkReversePath = false; - macvlans.macvlan.interface = "enp1s0"; - interfaces.enp1s0.useDHCP = true; - interfaces.macvlan.useDHCP = true; + nodes.client = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.iptables ]; # to debug firewall rules + virtualisation.interfaces.enp1s0.vlan = 1; + networking = { + useNetworkd = networkd; + useDHCP = false; + firewall.logReversePathDrops = true; # to debug firewall rules + # reverse path filtering rules for the macvlan interface seem + # to be incorrect, causing the test to fail. Disable temporarily. + firewall.checkReversePath = false; + macvlans.macvlan.interface = "enp1s0"; + interfaces.enp1s0.useDHCP = true; + interfaces.macvlan.useDHCP = true; + }; }; - }; testScript = '' - start_all() - - with subtest("Wait for networking to come up"): - client.wait_for_unit("network.target") - router.wait_for_unit("network.target") - - with subtest("Wait until we have an ip address on each interface"): - client.wait_until_succeeds("ip addr show dev enp1s0 | grep -q '192.168.1'") - client.wait_until_succeeds("ip addr show dev macvlan | grep -q '192.168.1'") - - with subtest("Print lots of diagnostic information"): - router.log("**********************************************") - router.succeed("ip addr >&2") - router.succeed("ip route >&2") - router.execute("iptables-save >&2") - client.log("==============================================") - client.succeed("ip addr >&2") - client.succeed("ip route >&2") - client.execute("iptables-save >&2") - client.log("##############################################") - - with subtest("Test macvlan creates routable ips"): - client.wait_until_succeeds("ping -c 1 192.168.1.1") - client.wait_until_succeeds("ping -c 1 192.168.1.2") - client.wait_until_succeeds("ping -c 1 192.168.1.3") + start_all() - router.wait_until_succeeds("ping -c 1 192.168.1.1") - router.wait_until_succeeds("ping -c 1 192.168.1.2") - router.wait_until_succeeds("ping -c 1 192.168.1.3") - ''; + with subtest("Wait for networking to come up"): + client.wait_for_unit("network.target") + router.wait_for_unit("network.target") + + with subtest("Wait until we have an ip address on each interface"): + client.wait_until_succeeds("ip addr show dev enp1s0 | grep -q '192.168.1'") + client.wait_until_succeeds("ip addr show dev macvlan | grep -q '192.168.1'") + + with subtest("Print lots of diagnostic information"): + router.log("**********************************************") + router.succeed("ip addr >&2") + router.succeed("ip route >&2") + router.execute("iptables-save >&2") + client.log("==============================================") + client.succeed("ip addr >&2") + client.succeed("ip route >&2") + client.execute("iptables-save >&2") + client.log("##############################################") + + with subtest("Test macvlan creates routable ips"): + client.wait_until_succeeds("ping -c 1 192.168.1.1") + client.wait_until_succeeds("ping -c 1 192.168.1.2") + client.wait_until_succeeds("ping -c 1 192.168.1.3") + + router.wait_until_succeeds("ping -c 1 192.168.1.1") + router.wait_until_succeeds("ping -c 1 192.168.1.2") + router.wait_until_succeeds("ping -c 1 192.168.1.3") + ''; }; fou = { name = "foo-over-udp"; nodes.machine = clientConfig { virtualisation.interfaces.enp1s0.vlan = 1; networking = { - interfaces.enp1s0.ipv4.addresses = [ { address = "192.168.1.1"; prefixLength = 24; } ]; + interfaces.enp1s0.ipv4.addresses = [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; fooOverUDP = { - fou1 = { port = 9001; }; - fou2 = { port = 9002; protocol = 41; }; - fou3 = lib.mkIf (!networkd) - { port = 9003; local.address = "192.168.1.1"; }; - fou4 = lib.mkIf (!networkd) - { port = 9004; local = { address = "192.168.1.1"; dev = "enp1s0"; }; }; + fou1 = { + port = 9001; + }; + fou2 = { + port = 9002; + protocol = 41; + }; + fou3 = lib.mkIf (!networkd) { + port = 9003; + local.address = "192.168.1.1"; + }; + fou4 = lib.mkIf (!networkd) { + port = 9004; + local = { + address = "192.168.1.1"; + dev = "enp1s0"; + }; + }; }; }; systemd.services = { fou3-fou-encap.after = lib.optional (!networkd) "network-addresses-enp1s0.service"; }; }; - testScript = '' + testScript = + '' import json machine.wait_for_unit("network.target") fous = json.loads(machine.succeed("ip -json fou show")) assert {"port": 9001, "gue": None, "family": "inet"} in fous, "fou1 exists" assert {"port": 9002, "ipproto": 41, "family": "inet"} in fous, "fou2 exists" - '' + lib.optionalString (!networkd) '' + '' + + lib.optionalString (!networkd) '' assert { "port": 9003, "gue": None, @@ -367,50 +446,83 @@ let } in fous, "fou4 exists" ''; }; - sit = let - node = { address4, remote, address6 }: { pkgs, ... }: { - virtualisation.interfaces.enp1s0.vlan = 1; - networking = { - useNetworkd = networkd; - useDHCP = false; - sits.sit = { - inherit remote; - local = address4; - dev = "enp1s0"; - }; - interfaces.enp1s0.ipv4.addresses = lib.mkOverride 0 - [ { address = address4; prefixLength = 24; } ]; - interfaces.sit.ipv6.addresses = lib.mkOverride 0 - [ { address = address6; prefixLength = 64; } ]; - }; - }; - in { - name = "Sit"; - # note on firewalling: the two nodes are explicitly asymmetric. - # client1 sends SIT packets in UDP, but accepts only proto-41 incoming. - # client2 does the reverse, sending in proto-41 and accepting only UDP incoming. - # that way we'll notice when either SIT itself or FOU breaks. - nodes.client1 = args@{ pkgs, ... }: - lib.mkMerge [ - (node { address4 = "192.168.1.1"; remote = "192.168.1.2"; address6 = "fc00::1"; } args) + sit = + let + node = { - networking = { - firewall.extraCommands = "iptables -A INPUT -p 41 -j ACCEPT"; - sits.sit.encapsulation = { type = "fou"; port = 9001; }; - }; - } - ]; - nodes.client2 = args@{ pkgs, ... }: - lib.mkMerge [ - (node { address4 = "192.168.1.2"; remote = "192.168.1.1"; address6 = "fc00::2"; } args) + address4, + remote, + address6, + }: + { pkgs, ... }: { + virtualisation.interfaces.enp1s0.vlan = 1; networking = { - firewall.allowedUDPPorts = [ 9001 ]; - fooOverUDP.fou1 = { port = 9001; protocol = 41; }; + useNetworkd = networkd; + useDHCP = false; + sits.sit = { + inherit remote; + local = address4; + dev = "enp1s0"; + }; + interfaces.enp1s0.ipv4.addresses = lib.mkOverride 0 [ + { + address = address4; + prefixLength = 24; + } + ]; + interfaces.sit.ipv6.addresses = lib.mkOverride 0 [ + { + address = address6; + prefixLength = 64; + } + ]; }; - } - ]; - testScript = '' + }; + in + { + name = "Sit"; + # note on firewalling: the two nodes are explicitly asymmetric. + # client1 sends SIT packets in UDP, but accepts only proto-41 incoming. + # client2 does the reverse, sending in proto-41 and accepting only UDP incoming. + # that way we'll notice when either SIT itself or FOU breaks. + nodes.client1 = + args@{ pkgs, ... }: + lib.mkMerge [ + (node { + address4 = "192.168.1.1"; + remote = "192.168.1.2"; + address6 = "fc00::1"; + } args) + { + networking = { + firewall.extraCommands = "iptables -A INPUT -p 41 -j ACCEPT"; + sits.sit.encapsulation = { + type = "fou"; + port = 9001; + }; + }; + } + ]; + nodes.client2 = + args@{ pkgs, ... }: + lib.mkMerge [ + (node { + address4 = "192.168.1.2"; + remote = "192.168.1.1"; + address6 = "fc00::2"; + } args) + { + networking = { + firewall.allowedUDPPorts = [ 9001 ]; + fooOverUDP.fou1 = { + port = 9001; + protocol = 41; + }; + }; + } + ]; + testScript = '' start_all() with subtest("Wait for networking to be configured"): @@ -428,92 +540,130 @@ let client2.wait_until_succeeds("ping -c 1 fc00::1") client2.wait_until_succeeds("ping -c 1 fc00::2") ''; - }; - gre = let - node = { ... }: { - networking = { - useNetworkd = networkd; - useDHCP = false; - firewall.extraCommands = "ip6tables -A nixos-fw -p gre -j nixos-fw-accept"; - }; }; - in { - name = "GRE"; - nodes.client1 = args@{ pkgs, ... }: - lib.mkMerge [ - (node args) + gre = + let + node = + { ... }: { - virtualisation.vlans = [ 1 2 4 ]; networking = { - greTunnels = { - greTunnel = { - local = "192.168.2.1"; - remote = "192.168.2.2"; - dev = "eth2"; - ttl = 225; - type = "tap"; - }; - gre6Tunnel = { - local = "fd00:1234:5678:4::1"; - remote = "fd00:1234:5678:4::2"; - dev = "eth3"; - ttl = 255; - type = "tun6"; + useNetworkd = networkd; + useDHCP = false; + firewall.extraCommands = "ip6tables -A nixos-fw -p gre -j nixos-fw-accept"; + }; + }; + in + { + name = "GRE"; + nodes.client1 = + args@{ pkgs, ... }: + lib.mkMerge [ + (node args) + { + virtualisation.vlans = [ + 1 + 2 + 4 + ]; + networking = { + greTunnels = { + greTunnel = { + local = "192.168.2.1"; + remote = "192.168.2.2"; + dev = "eth2"; + ttl = 225; + type = "tap"; + }; + gre6Tunnel = { + local = "fd00:1234:5678:4::1"; + remote = "fd00:1234:5678:4::2"; + dev = "eth3"; + ttl = 255; + type = "tun6"; + }; }; + bridges.bridge.interfaces = [ + "greTunnel" + "eth1" + ]; + interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [ ]; + interfaces.eth1.ipv6.addresses = lib.mkOverride 0 [ ]; + interfaces.bridge.ipv4.addresses = lib.mkOverride 0 [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; + interfaces.eth3.ipv6.addresses = [ + { + address = "fd00:1234:5678:4::1"; + prefixLength = 64; + } + ]; + interfaces.gre6Tunnel.ipv6.addresses = lib.mkOverride 0 [ + { + address = "fc00::1"; + prefixLength = 64; + } + ]; }; - bridges.bridge.interfaces = [ "greTunnel" "eth1" ]; - interfaces.eth1.ipv4.addresses = lib.mkOverride 0 []; - interfaces.eth1.ipv6.addresses = lib.mkOverride 0 []; - interfaces.bridge.ipv4.addresses = lib.mkOverride 0 [ - { address = "192.168.1.1"; prefixLength = 24; } - ]; - interfaces.eth3.ipv6.addresses = [ - { address = "fd00:1234:5678:4::1"; prefixLength = 64; } - ]; - interfaces.gre6Tunnel.ipv6.addresses = lib.mkOverride 0 [ - { address = "fc00::1"; prefixLength = 64; } + } + ]; + nodes.client2 = + args@{ pkgs, ... }: + lib.mkMerge [ + (node args) + { + virtualisation.vlans = [ + 2 + 3 + 4 ]; - }; - } - ]; - nodes.client2 = args@{ pkgs, ... }: - lib.mkMerge [ - (node args) - { - virtualisation.vlans = [ 2 3 4 ]; - networking = { - greTunnels = { - greTunnel = { - local = "192.168.2.2"; - remote = "192.168.2.1"; - dev = "eth1"; - ttl = 225; - type = "tap"; - }; - gre6Tunnel = { - local = "fd00:1234:5678:4::2"; - remote = "fd00:1234:5678:4::1"; - dev = "eth3"; - ttl = 255; - type = "tun6"; + networking = { + greTunnels = { + greTunnel = { + local = "192.168.2.2"; + remote = "192.168.2.1"; + dev = "eth1"; + ttl = 225; + type = "tap"; + }; + gre6Tunnel = { + local = "fd00:1234:5678:4::2"; + remote = "fd00:1234:5678:4::1"; + dev = "eth3"; + ttl = 255; + type = "tun6"; + }; }; + bridges.bridge.interfaces = [ + "greTunnel" + "eth2" + ]; + interfaces.eth2.ipv4.addresses = lib.mkOverride 0 [ ]; + interfaces.eth2.ipv6.addresses = lib.mkOverride 0 [ ]; + interfaces.bridge.ipv4.addresses = lib.mkOverride 0 [ + { + address = "192.168.1.2"; + prefixLength = 24; + } + ]; + interfaces.eth3.ipv6.addresses = [ + { + address = "fd00:1234:5678:4::2"; + prefixLength = 64; + } + ]; + interfaces.gre6Tunnel.ipv6.addresses = lib.mkOverride 0 [ + { + address = "fc00::2"; + prefixLength = 64; + } + ]; }; - bridges.bridge.interfaces = [ "greTunnel" "eth2" ]; - interfaces.eth2.ipv4.addresses = lib.mkOverride 0 []; - interfaces.eth2.ipv6.addresses = lib.mkOverride 0 []; - interfaces.bridge.ipv4.addresses = lib.mkOverride 0 [ - { address = "192.168.1.2"; prefixLength = 24; } - ]; - interfaces.eth3.ipv6.addresses = [ - { address = "fd00:1234:5678:4::2"; prefixLength = 64; } - ]; - interfaces.gre6Tunnel.ipv6.addresses = lib.mkOverride 0 [ - { address = "fc00::2"; prefixLength = 64; } - ]; - }; - } - ]; - testScript = '' + } + ]; + testScript = '' import json start_all() @@ -541,27 +691,33 @@ let links = json.loads(client2.succeed("ip -details -json link show gre6Tunnel")) assert links[0]['linkinfo']['info_data']['ttl'] == 255, "ttl not set for gre6Tunnel" ''; - }; - vlan = let - node = address: { - networking = { - useNetworkd = networkd; - useDHCP = false; - vlans.vlan = { - id = 1; - interface = "eth0"; + }; + vlan = + let + node = address: { + networking = { + useNetworkd = networkd; + useDHCP = false; + vlans.vlan = { + id = 1; + interface = "eth0"; + }; + interfaces.eth0.ipv4.addresses = lib.mkOverride 0 [ ]; + interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [ ]; + interfaces.vlan.ipv4.addresses = lib.mkOverride 0 [ + { + inherit address; + prefixLength = 24; + } + ]; }; - interfaces.eth0.ipv4.addresses = lib.mkOverride 0 [ ]; - interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [ ]; - interfaces.vlan.ipv4.addresses = lib.mkOverride 0 - [ { inherit address; prefixLength = 24; } ]; }; - }; - in { - name = "vlan"; - nodes.client1 = node "192.168.1.1"; - nodes.client2 = node "192.168.1.2"; - testScript = '' + in + { + name = "vlan"; + nodes.client1 = node "192.168.1.1"; + nodes.client2 = node "192.168.1.2"; + testScript = '' start_all() with subtest("Wait for networking to be configured"): @@ -572,8 +728,9 @@ let client1.succeed("ip addr show dev vlan >&2") client2.succeed("ip addr show dev vlan >&2") ''; - }; - vlan-ping = let + }; + vlan-ping = + let baseIP = number: "10.10.10.${number}"; vlanIP = number: "10.1.1.${number}"; baseInterface = "enp1s0"; @@ -583,20 +740,34 @@ let networking = { #useNetworkd = networkd; useDHCP = false; - vlans.${vlanInterface} = { id = 42; interface = baseInterface; }; - interfaces.${baseInterface}.ipv4.addresses = lib.mkOverride 0 [{ address = baseIP number; prefixLength = 24; }]; - interfaces.${vlanInterface}.ipv4.addresses = lib.mkOverride 0 [{ address = vlanIP number; prefixLength = 24; }]; + vlans.${vlanInterface} = { + id = 42; + interface = baseInterface; + }; + interfaces.${baseInterface}.ipv4.addresses = lib.mkOverride 0 [ + { + address = baseIP number; + prefixLength = 24; + } + ]; + interfaces.${vlanInterface}.ipv4.addresses = lib.mkOverride 0 [ + { + address = vlanIP number; + prefixLength = 24; + } + ]; }; }; serverNodeNum = "1"; clientNodeNum = "2"; - in { - name = "vlan-ping"; - nodes.server = node serverNodeNum; - nodes.client = node clientNodeNum; - testScript = '' + in + { + name = "vlan-ping"; + nodes.server = node serverNodeNum; + nodes.client = node clientNodeNum; + testScript = '' start_all() with subtest("Wait for networking to be configured"): @@ -611,78 +782,99 @@ let client.succeed("ping -I ${vlanInterface} -c 1 ${vlanIP serverNodeNum}") server.succeed("ping -I ${vlanInterface} -c 1 ${vlanIP clientNodeNum}") ''; - }; + }; virtual = { name = "Virtual"; nodes.machine = { networking.useNetworkd = networkd; networking.useDHCP = false; networking.interfaces.tap0 = { - ipv4.addresses = [ { address = "192.168.1.1"; prefixLength = 24; } ]; - ipv6.addresses = [ { address = "2001:1470:fffd:2096::"; prefixLength = 64; } ]; + ipv4.addresses = [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; + ipv6.addresses = [ + { + address = "2001:1470:fffd:2096::"; + prefixLength = 64; + } + ]; virtual = true; mtu = 1342; macAddress = "02:de:ad:be:ef:01"; }; networking.interfaces.tun0 = { - ipv4.addresses = [ { address = "192.168.1.2"; prefixLength = 24; } ]; - ipv6.addresses = [ { address = "2001:1470:fffd:2097::"; prefixLength = 64; } ]; + ipv4.addresses = [ + { + address = "192.168.1.2"; + prefixLength = 24; + } + ]; + ipv6.addresses = [ + { + address = "2001:1470:fffd:2097::"; + prefixLength = 64; + } + ]; virtual = true; mtu = 1343; }; }; - testScript = '' - targetList = """ - tap0: tap persist user 0 - tun0: tun persist user 0 - """.strip() + testScript = + '' + targetList = """ + tap0: tap persist user 0 + tun0: tun persist user 0 + """.strip() - with subtest("Wait for networking to come up"): - machine.start() - machine.wait_for_unit("network.target") - - with subtest("Test interfaces set up"): - list = machine.succeed("ip tuntap list | sort").strip() - assert ( - list == targetList - ), """ - The list of virtual interfaces does not match the expected one: - Result: - {} - Expected: - {} - """.format( - list, targetList - ) - with subtest("Test MTU and MAC Address are configured"): - machine.wait_until_succeeds("ip link show dev tap0 | grep 'mtu 1342'") - machine.wait_until_succeeds("ip link show dev tun0 | grep 'mtu 1343'") - assert "02:de:ad:be:ef:01" in machine.succeed("ip link show dev tap0") - '' # network-addresses-* only exist in scripted networking - + lib.optionalString (!networkd) '' - with subtest("Test interfaces' addresses clean up"): - machine.succeed("systemctl stop network-addresses-tap0") - machine.sleep(10) - machine.succeed("systemctl stop network-addresses-tun0") - machine.sleep(10) - residue = machine.succeed("ip tuntap list | sort").strip() - assert ( - residue == targetList - ), "Some virtual interface has been removed:\n{}".format(residue) - assert "192.168.1.1" not in machine.succeed("ip address show dev tap0"), "tap0 interface address has not been removed" - assert "192.168.1.2" not in machine.succeed("ip address show dev tun0"), "tun0 interface address has not been removed" - - with subtest("Test interfaces clean up"): - machine.succeed("systemctl stop tap0-netdev") - machine.sleep(10) - machine.succeed("systemctl stop tun0-netdev") - machine.sleep(10) - residue = machine.succeed("ip tuntap list") - assert ( - residue == "" - ), "Some virtual interface has not been properly cleaned:\n{}".format(residue) - ''; + with subtest("Wait for networking to come up"): + machine.start() + machine.wait_for_unit("network.target") + + with subtest("Test interfaces set up"): + list = machine.succeed("ip tuntap list | sort").strip() + assert ( + list == targetList + ), """ + The list of virtual interfaces does not match the expected one: + Result: + {} + Expected: + {} + """.format( + list, targetList + ) + with subtest("Test MTU and MAC Address are configured"): + machine.wait_until_succeeds("ip link show dev tap0 | grep 'mtu 1342'") + machine.wait_until_succeeds("ip link show dev tun0 | grep 'mtu 1343'") + assert "02:de:ad:be:ef:01" in machine.succeed("ip link show dev tap0") + '' # network-addresses-* only exist in scripted networking + + lib.optionalString (!networkd) '' + with subtest("Test interfaces' addresses clean up"): + machine.succeed("systemctl stop network-addresses-tap0") + machine.sleep(10) + machine.succeed("systemctl stop network-addresses-tun0") + machine.sleep(10) + residue = machine.succeed("ip tuntap list | sort").strip() + assert ( + residue == targetList + ), "Some virtual interface has been removed:\n{}".format(residue) + assert "192.168.1.1" not in machine.succeed("ip address show dev tap0"), "tap0 interface address has not been removed" + assert "192.168.1.2" not in machine.succeed("ip address show dev tun0"), "tun0 interface address has not been removed" + + with subtest("Test interfaces clean up"): + machine.succeed("systemctl stop tap0-netdev") + machine.sleep(10) + machine.succeed("systemctl stop tun0-netdev") + machine.sleep(10) + residue = machine.succeed("ip tuntap list") + assert ( + residue == "" + ), "Some virtual interface has not been properly cleaned:\n{}".format(residue) + ''; }; privacy = { name = "Privacy"; @@ -740,33 +932,33 @@ let }; }; testScript = '' - start_all() + start_all() - client.wait_for_unit("network.target") - client_with_privacy.wait_for_unit("network.target") - router.systemctl("start network-online.target") - router.wait_for_unit("network-online.target") + client.wait_for_unit("network.target") + client_with_privacy.wait_for_unit("network.target") + router.systemctl("start network-online.target") + router.wait_for_unit("network-online.target") - with subtest("Wait until we have an ip address"): - client_with_privacy.wait_until_succeeds( - "ip addr show dev enp1s0 | grep -q 'fd00:1234:5678:1:'" - ) - client.wait_until_succeeds("ip addr show dev enp1s0 | grep -q 'fd00:1234:5678:1:'") + with subtest("Wait until we have an ip address"): + client_with_privacy.wait_until_succeeds( + "ip addr show dev enp1s0 | grep -q 'fd00:1234:5678:1:'" + ) + client.wait_until_succeeds("ip addr show dev enp1s0 | grep -q 'fd00:1234:5678:1:'") - with subtest("Test vlan 1"): - client_with_privacy.wait_until_succeeds("ping -c 1 fd00:1234:5678:1::1") - client.wait_until_succeeds("ping -c 1 fd00:1234:5678:1::1") + with subtest("Test vlan 1"): + client_with_privacy.wait_until_succeeds("ping -c 1 fd00:1234:5678:1::1") + client.wait_until_succeeds("ping -c 1 fd00:1234:5678:1::1") - with subtest("Test address used is temporary"): - client_with_privacy.wait_until_succeeds( - "! ip route get fd00:1234:5678:1::1 | grep -q ':[a-f0-9]*ff:fe[a-f0-9]*:'" - ) + with subtest("Test address used is temporary"): + client_with_privacy.wait_until_succeeds( + "! ip route get fd00:1234:5678:1::1 | grep -q ':[a-f0-9]*ff:fe[a-f0-9]*:'" + ) - with subtest("Test address used is EUI-64"): - client.wait_until_succeeds( - "ip route get fd00:1234:5678:1::1 | grep -q ':[a-f0-9]*ff:fe[a-f0-9]*:'" - ) - ''; + with subtest("Test address used is EUI-64"): + client.wait_until_succeeds( + "ip route get fd00:1234:5678:1::1 | grep -q ':[a-f0-9]*ff:fe[a-f0-9]*:'" + ) + ''; }; routes = { name = "routes"; @@ -774,103 +966,134 @@ let networking.useNetworkd = networkd; networking.useDHCP = false; networking.interfaces.eth0 = { - ipv4.addresses = [ { address = "192.168.1.2"; prefixLength = 24; } ]; - ipv6.addresses = [ { address = "2001:1470:fffd:2097::"; prefixLength = 64; } ]; + ipv4.addresses = [ + { + address = "192.168.1.2"; + prefixLength = 24; + } + ]; + ipv6.addresses = [ + { + address = "2001:1470:fffd:2097::"; + prefixLength = 64; + } + ]; ipv6.routes = [ - { address = "fdfd:b3f0::"; prefixLength = 48; } - { address = "2001:1470:fffd:2098::"; prefixLength = 64; via = "fdfd:b3f0::1"; } + { + address = "fdfd:b3f0::"; + prefixLength = 48; + } + { + address = "2001:1470:fffd:2098::"; + prefixLength = 64; + via = "fdfd:b3f0::1"; + } ]; ipv4.routes = [ - { address = "10.0.0.0"; prefixLength = 16; options = { - mtu = "1500"; - # Explicitly set scope because iproute and systemd-networkd - # disagree on what the scope should be - # if the type is the default "unicast" - scope = "link"; - }; } - { address = "192.168.2.0"; prefixLength = 24; via = "192.168.1.1"; } + { + address = "10.0.0.0"; + prefixLength = 16; + options = { + mtu = "1500"; + # Explicitly set scope because iproute and systemd-networkd + # disagree on what the scope should be + # if the type is the default "unicast" + scope = "link"; + }; + } + { + address = "192.168.2.0"; + prefixLength = 24; + via = "192.168.1.1"; + } ]; }; virtualisation.vlans = [ ]; }; - testScript = '' - targetIPv4Table = [ - "10.0.0.0/16 proto static scope link mtu 1500", - "192.168.1.0/24 proto kernel scope link src 192.168.1.2", - "192.168.2.0/24 via 192.168.1.1 proto static", - ] - - targetIPv6Table = [ - "2001:1470:fffd:2097::/64 proto kernel metric 256 pref medium", - "2001:1470:fffd:2098::/64 via fdfd:b3f0::1 proto static metric 1024 pref medium", - "fdfd:b3f0::/48 proto static metric 1024 pref medium", - ] - - machine.start() - machine.wait_for_unit("network.target") - - with subtest("test routing tables"): - ipv4Table = machine.succeed("ip -4 route list dev eth0 | head -n3").strip() - ipv6Table = machine.succeed("ip -6 route list dev eth0 | head -n3").strip() - assert [ - l.strip() for l in ipv4Table.splitlines() - ] == targetIPv4Table, """ - The IPv4 routing table does not match the expected one: - Result: - {} - Expected: - {} - """.format( - ipv4Table, targetIPv4Table - ) - assert [ - l.strip() for l in ipv6Table.splitlines() - ] == targetIPv6Table, """ - The IPv6 routing table does not match the expected one: - Result: - {} - Expected: - {} - """.format( - ipv6Table, targetIPv6Table - ) + testScript = + '' + targetIPv4Table = [ + "10.0.0.0/16 proto static scope link mtu 1500", + "192.168.1.0/24 proto kernel scope link src 192.168.1.2", + "192.168.2.0/24 via 192.168.1.1 proto static", + ] + + targetIPv6Table = [ + "2001:1470:fffd:2097::/64 proto kernel metric 256 pref medium", + "2001:1470:fffd:2098::/64 via fdfd:b3f0::1 proto static metric 1024 pref medium", + "fdfd:b3f0::/48 proto static metric 1024 pref medium", + ] + + machine.start() + machine.wait_for_unit("network.target") - '' + lib.optionalString (!networkd) '' - with subtest("test clean-up of the tables"): - machine.succeed("systemctl stop network-addresses-eth0") - ipv4Residue = machine.succeed("ip -4 route list dev eth0 | head -n-3").strip() - ipv6Residue = machine.succeed("ip -6 route list dev eth0 | head -n-3").strip() - assert ( - ipv4Residue == "" - ), "The IPv4 routing table has not been properly cleaned:\n{}".format(ipv4Residue) - assert ( - ipv6Residue == "" - ), "The IPv6 routing table has not been properly cleaned:\n{}".format(ipv6Residue) - ''; + with subtest("test routing tables"): + ipv4Table = machine.succeed("ip -4 route list dev eth0 | head -n3").strip() + ipv6Table = machine.succeed("ip -6 route list dev eth0 | head -n3").strip() + assert [ + l.strip() for l in ipv4Table.splitlines() + ] == targetIPv4Table, """ + The IPv4 routing table does not match the expected one: + Result: + {} + Expected: + {} + """.format( + ipv4Table, targetIPv4Table + ) + assert [ + l.strip() for l in ipv6Table.splitlines() + ] == targetIPv6Table, """ + The IPv6 routing table does not match the expected one: + Result: + {} + Expected: + {} + """.format( + ipv6Table, targetIPv6Table + ) + + '' + + lib.optionalString (!networkd) '' + with subtest("test clean-up of the tables"): + machine.succeed("systemctl stop network-addresses-eth0") + ipv4Residue = machine.succeed("ip -4 route list dev eth0 | head -n-3").strip() + ipv6Residue = machine.succeed("ip -6 route list dev eth0 | head -n-3").strip() + assert ( + ipv4Residue == "" + ), "The IPv4 routing table has not been properly cleaned:\n{}".format(ipv4Residue) + assert ( + ipv6Residue == "" + ), "The IPv6 routing table has not been properly cleaned:\n{}".format(ipv6Residue) + ''; }; - rename = if networkd then { - name = "RenameInterface"; - nodes.machine = { - virtualisation.vlans = [ 1 ]; - networking = { - useNetworkd = networkd; - useDHCP = false; - }; - systemd.network.links."10-custom_name" = { - matchConfig.MACAddress = "52:54:00:12:01:01"; - linkConfig.Name = "custom_name"; + rename = + if networkd then + { + name = "RenameInterface"; + nodes.machine = { + virtualisation.vlans = [ 1 ]; + networking = { + useNetworkd = networkd; + useDHCP = false; + }; + systemd.network.links."10-custom_name" = { + matchConfig.MACAddress = "52:54:00:12:01:01"; + linkConfig.Name = "custom_name"; + }; + }; + testScript = '' + machine.succeed("udevadm settle") + print(machine.succeed("ip link show dev custom_name")) + ''; + } + else + { + name = "RenameInterface"; + nodes = { }; + testScript = ""; }; - }; - testScript = '' - machine.succeed("udevadm settle") - print(machine.succeed("ip link show dev custom_name")) - ''; - } else { - name = "RenameInterface"; - nodes = { }; - testScript = ""; - }; # even with disabled networkd, systemd.network.links should work # (as it's handled by udev, not networkd) link = { @@ -896,49 +1119,69 @@ let assert "mtu 1442" in client.succeed("ip l show dev foo") ''; }; - wlanInterface = let - testMac = "06:00:00:00:02:00"; - in { - name = "WlanInterface"; - nodes.machine = { - boot.kernelModules = [ "mac80211_hwsim" ]; - networking.wlanInterfaces = { - wlan0 = { device = "wlan0"; }; - wap0 = { device = "wlan0"; mac = testMac; }; + wlanInterface = + let + testMac = "06:00:00:00:02:00"; + in + { + name = "WlanInterface"; + nodes.machine = { + boot.kernelModules = [ "mac80211_hwsim" ]; + networking.wlanInterfaces = { + wlan0 = { + device = "wlan0"; + }; + wap0 = { + device = "wlan0"; + mac = testMac; + }; + }; }; + testScript = '' + machine.start() + machine.wait_for_unit("network.target") + machine.wait_until_succeeds("ip address show wap0 | grep -q ${testMac}") + machine.fail("ip address show wlan0 | grep -q ${testMac}") + ''; }; - testScript = '' - machine.start() - machine.wait_for_unit("network.target") - machine.wait_until_succeeds("ip address show wap0 | grep -q ${testMac}") - machine.fail("ip address show wlan0 | grep -q ${testMac}") - ''; - }; - naughtyInterfaceNames = let - ifnames = [ - # flags of ip-address - "home" "temporary" "optimistic" - "bridge_slave" "flush" - # flags of ip-route - "up" "type" "nomaster" "address" - # other - "very_loong_name" "lowerUpper" "-" - ]; - in { - name = "naughtyInterfaceNames"; - nodes.machine = { - networking.useNetworkd = networkd; - networking.bridges = lib.listToAttrs - (lib.flip builtins.map ifnames - (name: { inherit name; value.interfaces = []; })); + naughtyInterfaceNames = + let + ifnames = [ + # flags of ip-address + "home" + "temporary" + "optimistic" + "bridge_slave" + "flush" + # flags of ip-route + "up" + "type" + "nomaster" + "address" + # other + "very_loong_name" + "lowerUpper" + "-" + ]; + in + { + name = "naughtyInterfaceNames"; + nodes.machine = { + networking.useNetworkd = networkd; + networking.bridges = lib.listToAttrs ( + lib.flip builtins.map ifnames (name: { + inherit name; + value.interfaces = [ ]; + }) + ); + }; + testScript = '' + machine.start() + machine.wait_for_unit("network.target") + for ifname in ${builtins.toJSON ifnames}: + machine.wait_until_succeeds(f"ip link show dev '{ifname}' | grep -q '{ifname}'") + ''; }; - testScript = '' - machine.start() - machine.wait_for_unit("network.target") - for ifname in ${builtins.toJSON ifnames}: - machine.wait_until_succeeds(f"ip link show dev '{ifname}' | grep -q '{ifname}'") - ''; - }; caseSensitiveRenaming = { name = "CaseSensitiveRenaming"; nodes.machine = { @@ -956,6 +1199,13 @@ let }; }; -in lib.mapAttrs (lib.const (attrs: makeTest (attrs // { - name = "${attrs.name}-Networking-${if networkd then "Networkd" else "Scripted"}"; -}))) testCases +in +lib.mapAttrs (lib.const ( + attrs: + makeTest ( + attrs + // { + name = "${attrs.name}-Networking-${if networkd then "Networkd" else "Scripted"}"; + } + ) +)) testCases diff --git a/nixos/tests/networking/router.nix b/nixos/tests/networking/router.nix index fab21c9e786245..082f2bc7d22785 100644 --- a/nixos/tests/networking/router.nix +++ b/nixos/tests/networking/router.nix @@ -1,83 +1,113 @@ -{ networkd }: { config, pkgs, ... }: - let - inherit (pkgs) lib; - qemu-common = import ../../lib/qemu-common.nix { inherit lib pkgs; }; - vlanIfs = lib.range 1 (lib.length config.virtualisation.vlans); - in { - environment.systemPackages = [ pkgs.iptables ]; # to debug firewall rules - virtualisation.vlans = [ 1 2 3 ]; - boot.kernel.sysctl."net.ipv6.conf.all.forwarding" = true; - networking = { - useDHCP = false; - useNetworkd = networkd; - firewall.checkReversePath = true; - firewall.allowedUDPPorts = [ 547 ]; - interfaces = lib.mkOverride 0 (lib.listToAttrs (lib.forEach vlanIfs (n: - lib.nameValuePair "eth${toString n}" { - ipv4.addresses = [ { address = "192.168.${toString n}.1"; prefixLength = 24; } ]; - ipv6.addresses = [ { address = "fd00:1234:5678:${toString n}::1"; prefixLength = 64; } ]; - }))); - }; - services.kea = { - dhcp4 = { - enable = true; - settings = { - interfaces-config = { - interfaces = map (n: "eth${toString n}") vlanIfs; - dhcp-socket-type = "raw"; - service-sockets-require-all = true; - service-sockets-max-retries = 5; - service-sockets-retry-wait-time = 2500; - }; - subnet4 = map (n: { - id = n; - subnet = "192.168.${toString n}.0/24"; - pools = [{ pool = "192.168.${toString n}.3 - 192.168.${toString n}.254"; }]; - option-data = [ - { data = "192.168.${toString n}.1"; name = "routers"; } - { data = "192.168.${toString n}.1"; name = "domain-name-servers"; } +{ networkd }: +{ config, pkgs, ... }: +let + inherit (pkgs) lib; + qemu-common = import ../../lib/qemu-common.nix { inherit lib pkgs; }; + vlanIfs = lib.range 1 (lib.length config.virtualisation.vlans); +in +{ + environment.systemPackages = [ pkgs.iptables ]; # to debug firewall rules + virtualisation.vlans = [ + 1 + 2 + 3 + ]; + boot.kernel.sysctl."net.ipv6.conf.all.forwarding" = true; + networking = { + useDHCP = false; + useNetworkd = networkd; + firewall.checkReversePath = true; + firewall.allowedUDPPorts = [ 547 ]; + interfaces = lib.mkOverride 0 ( + lib.listToAttrs ( + lib.forEach vlanIfs ( + n: + lib.nameValuePair "eth${toString n}" { + ipv4.addresses = [ + { + address = "192.168.${toString n}.1"; + prefixLength = 24; + } + ]; + ipv6.addresses = [ + { + address = "fd00:1234:5678:${toString n}::1"; + prefixLength = 64; + } ]; + } + ) + ) + ); + }; + services.kea = { + dhcp4 = { + enable = true; + settings = { + interfaces-config = { + interfaces = map (n: "eth${toString n}") vlanIfs; + dhcp-socket-type = "raw"; + service-sockets-require-all = true; + service-sockets-max-retries = 5; + service-sockets-retry-wait-time = 2500; + }; + subnet4 = map (n: { + id = n; + subnet = "192.168.${toString n}.0/24"; + pools = [ { pool = "192.168.${toString n}.3 - 192.168.${toString n}.254"; } ]; + option-data = [ + { + data = "192.168.${toString n}.1"; + name = "routers"; + } + { + data = "192.168.${toString n}.1"; + name = "domain-name-servers"; + } + ]; - reservations = [{ + reservations = [ + { hw-address = qemu-common.qemuNicMac n 1; hostname = "client${toString n}"; ip-address = "192.168.${toString n}.2"; - }]; - }) vlanIfs; - }; + } + ]; + }) vlanIfs; }; - dhcp6 = { - enable = true; - settings = { - interfaces-config = { - interfaces = map (n: "eth${toString n}") vlanIfs; - service-sockets-require-all = true; - service-sockets-max-retries = 5; - service-sockets-retry-wait-time = 2500; - }; - - subnet6 = map (n: { - id = n; - subnet = "fd00:1234:5678:${toString n}::/64"; - interface = "eth${toString n}"; - pools = [{ pool = "fd00:1234:5678:${toString n}::2-fd00:1234:5678:${toString n}::2"; }]; - }) vlanIfs; + }; + dhcp6 = { + enable = true; + settings = { + interfaces-config = { + interfaces = map (n: "eth${toString n}") vlanIfs; + service-sockets-require-all = true; + service-sockets-max-retries = 5; + service-sockets-retry-wait-time = 2500; }; + + subnet6 = map (n: { + id = n; + subnet = "fd00:1234:5678:${toString n}::/64"; + interface = "eth${toString n}"; + pools = [ { pool = "fd00:1234:5678:${toString n}::2-fd00:1234:5678:${toString n}::2"; } ]; + }) vlanIfs; }; }; - services.radvd = { - enable = true; - config = lib.flip lib.concatMapStrings vlanIfs (n: '' - interface eth${toString n} { - AdvSendAdvert on; - AdvManagedFlag on; - AdvOtherConfigFlag on; - RDNSS 2001:db8::1 {}; + }; + services.radvd = { + enable = true; + config = lib.flip lib.concatMapStrings vlanIfs (n: '' + interface eth${toString n} { + AdvSendAdvert on; + AdvManagedFlag on; + AdvOtherConfigFlag on; + RDNSS 2001:db8::1 {}; - prefix fd00:1234:5678:${toString n}::/64 { - AdvAutonomous off; - }; + prefix fd00:1234:5678:${toString n}::/64 { + AdvAutonomous off; }; - ''); - }; - } + }; + ''); + }; +} diff --git a/nixos/tests/nextcloud/basic.nix b/nixos/tests/nextcloud/basic.nix index bea08e32311046..f8306503d85fd4 100644 --- a/nixos/tests/nextcloud/basic.nix +++ b/nixos/tests/nextcloud/basic.nix @@ -1,75 +1,111 @@ -{ name, pkgs, testBase, system,... }: +{ + name, + pkgs, + testBase, + system, + ... +}: with import ../../lib/testing-python.nix { inherit system pkgs; }; -runTest ({ config, ... }: { - inherit name; - meta = with pkgs.lib.maintainers; { - maintainers = [ globin eqyiel ma27 ]; - }; +runTest ( + { config, ... }: + { + inherit name; + meta = with pkgs.lib.maintainers; { + maintainers = [ + globin + eqyiel + ma27 + ]; + }; - imports = [ testBase ]; + imports = [ testBase ]; - nodes = { - # The only thing the client needs to do is download a file. - client = { ... }: { - services.davfs2.enable = true; - systemd.tmpfiles.settings.nextcloud = { - "/tmp/davfs2-secrets"."f+" = { - mode = "0600"; - argument = "http://nextcloud/remote.php/dav/files/${config.adminuser} ${config.adminuser} ${config.adminpass}"; + nodes = { + # The only thing the client needs to do is download a file. + client = + { ... }: + { + services.davfs2.enable = true; + systemd.tmpfiles.settings.nextcloud = { + "/tmp/davfs2-secrets"."f+" = { + mode = "0600"; + argument = "http://nextcloud/remote.php/dav/files/${config.adminuser} ${config.adminuser} ${config.adminpass}"; + }; + }; + virtualisation.fileSystems = { + "/mnt/dav" = { + device = "http://nextcloud/remote.php/dav/files/${config.adminuser}"; + fsType = "davfs"; + options = + let + davfs2Conf = (pkgs.writeText "davfs2.conf" "secrets /tmp/davfs2-secrets"); + in + [ + "conf=${davfs2Conf}" + "x-systemd.automount" + "noauto" + ]; + }; + }; }; - }; - virtualisation.fileSystems = { - "/mnt/dav" = { - device = "http://nextcloud/remote.php/dav/files/${config.adminuser}"; - fsType = "davfs"; - options = let - davfs2Conf = (pkgs.writeText "davfs2.conf" "secrets /tmp/davfs2-secrets"); - in [ "conf=${davfs2Conf}" "x-systemd.automount" "noauto"]; - }; - }; - }; - nextcloud = { config, pkgs, ... }: { - systemd.tmpfiles.rules = [ - "d /var/lib/nextcloud-data 0750 nextcloud nginx - -" - ]; + nextcloud = + { config, pkgs, ... }: + { + systemd.tmpfiles.rules = [ + "d /var/lib/nextcloud-data 0750 nextcloud nginx - -" + ]; - services.nextcloud = { - enable = true; - datadir = "/var/lib/nextcloud-data"; - autoUpdateApps = { - enable = true; - startAt = "20:00"; - }; - phpExtraExtensions = all: [ all.bz2 ]; - }; + services.nextcloud = { + enable = true; + datadir = "/var/lib/nextcloud-data"; + autoUpdateApps = { + enable = true; + startAt = "20:00"; + }; + phpExtraExtensions = all: [ all.bz2 ]; + }; - specialisation.withoutMagick.configuration = { - services.nextcloud.enableImagemagick = false; - }; + specialisation.withoutMagick.configuration = { + services.nextcloud.enableImagemagick = false; + }; + }; }; - }; - test-helpers.extraTests = { nodes, ... }: let - findInClosure = what: drv: pkgs.runCommand "find-in-closure" { exportReferencesGraph = [ "graph" drv ]; inherit what; } '' - test -e graph - grep "$what" graph >$out || true - ''; - nexcloudWithImagick = findInClosure "imagick" nodes.nextcloud.system.build.vm; - nextcloudWithoutImagick = findInClosure "imagick" nodes.nextcloud.specialisation.withoutMagick.configuration.system.build.vm; - in '' - with subtest("File is in proper nextcloud home"): - nextcloud.succeed("test -f ${nodes.nextcloud.services.nextcloud.datadir}/data/root/files/test-shared-file") + test-helpers.extraTests = + { nodes, ... }: + let + findInClosure = + what: drv: + pkgs.runCommand "find-in-closure" + { + exportReferencesGraph = [ + "graph" + drv + ]; + inherit what; + } + '' + test -e graph + grep "$what" graph >$out || true + ''; + nexcloudWithImagick = findInClosure "imagick" nodes.nextcloud.system.build.vm; + nextcloudWithoutImagick = findInClosure "imagick" nodes.nextcloud.specialisation.withoutMagick.configuration.system.build.vm; + in + '' + with subtest("File is in proper nextcloud home"): + nextcloud.succeed("test -f ${nodes.nextcloud.services.nextcloud.datadir}/data/root/files/test-shared-file") - with subtest("Closure checks"): - assert open("${nexcloudWithImagick}").read() != "" - assert open("${nextcloudWithoutImagick}").read() == "" + with subtest("Closure checks"): + assert open("${nexcloudWithImagick}").read() != "" + assert open("${nextcloudWithoutImagick}").read() == "" - with subtest("Davfs2"): - assert "hi" in client.succeed("cat /mnt/dav/test-shared-file") + with subtest("Davfs2"): + assert "hi" in client.succeed("cat /mnt/dav/test-shared-file") - with subtest("Ensure SSE is disabled by default"): - nextcloud.succeed("grep -vE '^HBEGIN:oc_encryption_module' /var/lib/nextcloud-data/data/root/files/test-shared-file") - ''; -}) + with subtest("Ensure SSE is disabled by default"): + nextcloud.succeed("grep -vE '^HBEGIN:oc_encryption_module' /var/lib/nextcloud-data/data/root/files/test-shared-file") + ''; + } +) diff --git a/nixos/tests/nextcloud/with-declarative-redis-and-secrets.nix b/nixos/tests/nextcloud/with-declarative-redis-and-secrets.nix index 80041ed481b453..6b0dd71f85ef2a 100644 --- a/nixos/tests/nextcloud/with-declarative-redis-and-secrets.nix +++ b/nixos/tests/nextcloud/with-declarative-redis-and-secrets.nix @@ -1,85 +1,102 @@ -{ name, pkgs, testBase, system, ... }: +{ + name, + pkgs, + testBase, + system, + ... +}: with import ../../lib/testing-python.nix { inherit system pkgs; }; -runTest ({ config, ... }: let inherit (config) adminuser; in { - inherit name; - meta = with pkgs.lib.maintainers; { - maintainers = [ eqyiel ma27 ]; - }; +runTest ( + { config, ... }: + let + inherit (config) adminuser; + in + { + inherit name; + meta = with pkgs.lib.maintainers; { + maintainers = [ + eqyiel + ma27 + ]; + }; - imports = [ testBase ]; + imports = [ testBase ]; - nodes = { - nextcloud = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; - services.nextcloud = { - caching = { - apcu = false; - redis = true; - memcached = false; - }; - # This test also validates that we can use an "external" database - database.createLocally = false; - config = { - dbtype = "pgsql"; - dbname = "nextcloud"; - dbuser = adminuser; - dbpassFile = config.services.nextcloud.config.adminpassFile; - }; + nodes = { + nextcloud = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; + services.nextcloud = { + caching = { + apcu = false; + redis = true; + memcached = false; + }; + # This test also validates that we can use an "external" database + database.createLocally = false; + config = { + dbtype = "pgsql"; + dbname = "nextcloud"; + dbuser = adminuser; + dbpassFile = config.services.nextcloud.config.adminpassFile; + }; - secretFile = "/etc/nextcloud-secrets.json"; + secretFile = "/etc/nextcloud-secrets.json"; - settings = { - allow_local_remote_servers = true; - redis = { - dbindex = 0; - timeout = 1.5; - # password handled via secretfile below + settings = { + allow_local_remote_servers = true; + redis = { + dbindex = 0; + timeout = 1.5; + # password handled via secretfile below + }; + }; + configureRedis = true; }; - }; - configureRedis = true; - }; - services.redis.servers."nextcloud" = { - enable = true; - port = 6379; - requirePass = "secret"; - }; + services.redis.servers."nextcloud" = { + enable = true; + port = 6379; + requirePass = "secret"; + }; - systemd.services.nextcloud-setup= { - requires = ["postgresql.service"]; - after = [ "postgresql.service" ]; - }; + systemd.services.nextcloud-setup = { + requires = [ "postgresql.service" ]; + after = [ "postgresql.service" ]; + }; - services.postgresql = { - enable = true; - package = pkgs.postgresql_14; - }; - systemd.services.postgresql.postStart = pkgs.lib.mkAfter '' - password=$(cat ${config.services.nextcloud.config.dbpassFile}) - ${config.services.postgresql.package}/bin/psql <<EOF - CREATE ROLE ${adminuser} WITH LOGIN PASSWORD '$password' CREATEDB; - CREATE DATABASE nextcloud; - GRANT ALL PRIVILEGES ON DATABASE nextcloud TO ${adminuser}; - EOF - ''; + services.postgresql = { + enable = true; + package = pkgs.postgresql_14; + }; + systemd.services.postgresql.postStart = pkgs.lib.mkAfter '' + password=$(cat ${config.services.nextcloud.config.dbpassFile}) + ${config.services.postgresql.package}/bin/psql <<EOF + CREATE ROLE ${adminuser} WITH LOGIN PASSWORD '$password' CREATEDB; + CREATE DATABASE nextcloud; + GRANT ALL PRIVILEGES ON DATABASE nextcloud TO ${adminuser}; + EOF + ''; - # This file is meant to contain secret options which should - # not go into the nix store. Here it is just used to set the - # redis password. - environment.etc."nextcloud-secrets.json".text = '' - { - "redis": { - "password": "secret" - } - } - ''; + # This file is meant to contain secret options which should + # not go into the nix store. Here it is just used to set the + # redis password. + environment.etc."nextcloud-secrets.json".text = '' + { + "redis": { + "password": "secret" + } + } + ''; + }; }; - }; - test-helpers.extraTests = '' - with subtest("non-empty redis cache"): - # redis cache should not be empty - nextcloud.fail('test 0 -lt "$(redis-cli --pass secret --json KEYS "*" | jq "len")"') - ''; -}) + test-helpers.extraTests = '' + with subtest("non-empty redis cache"): + # redis cache should not be empty + nextcloud.fail('test 0 -lt "$(redis-cli --pass secret --json KEYS "*" | jq "len")"') + ''; + } +) diff --git a/nixos/tests/nextcloud/with-mysql-and-memcached.nix b/nixos/tests/nextcloud/with-mysql-and-memcached.nix index b903f8d0fe9529..110047fe661024 100644 --- a/nixos/tests/nextcloud/with-mysql-and-memcached.nix +++ b/nixos/tests/nextcloud/with-mysql-and-memcached.nix @@ -1,37 +1,50 @@ -{ name, pkgs, testBase, system, ... }: +{ + name, + pkgs, + testBase, + system, + ... +}: with import ../../lib/testing-python.nix { inherit system pkgs; }; -runTest ({ config, ... }: { - inherit name; - meta = with pkgs.lib.maintainers; { - maintainers = [ eqyiel ]; - }; +runTest ( + { config, ... }: + { + inherit name; + meta = with pkgs.lib.maintainers; { + maintainers = [ eqyiel ]; + }; - imports = [ testBase ]; + imports = [ testBase ]; - nodes = { - nextcloud = { config, pkgs, ... }: { - services.nextcloud = { - caching = { - apcu = true; - redis = false; - memcached = true; - }; - config.dbtype = "mysql"; - }; + nodes = { + nextcloud = + { config, pkgs, ... }: + { + services.nextcloud = { + caching = { + apcu = true; + redis = false; + memcached = true; + }; + config.dbtype = "mysql"; + }; - services.memcached.enable = true; + services.memcached.enable = true; + }; }; - }; - test-helpers.init = let - configureMemcached = pkgs.writeScript "configure-memcached" '' - nextcloud-occ config:system:set memcached_servers 0 0 --value 127.0.0.1 --type string - nextcloud-occ config:system:set memcached_servers 0 1 --value 11211 --type integer - nextcloud-occ config:system:set memcache.local --value '\OC\Memcache\APCu' --type string - nextcloud-occ config:system:set memcache.distributed --value '\OC\Memcache\Memcached' --type string - ''; - in '' - nextcloud.succeed("${configureMemcached}") - ''; -}) + test-helpers.init = + let + configureMemcached = pkgs.writeScript "configure-memcached" '' + nextcloud-occ config:system:set memcached_servers 0 0 --value 127.0.0.1 --type string + nextcloud-occ config:system:set memcached_servers 0 1 --value 11211 --type integer + nextcloud-occ config:system:set memcache.local --value '\OC\Memcache\APCu' --type string + nextcloud-occ config:system:set memcache.distributed --value '\OC\Memcache\Memcached' --type string + ''; + in + '' + nextcloud.succeed("${configureMemcached}") + ''; + } +) diff --git a/nixos/tests/nextcloud/with-objectstore.nix b/nixos/tests/nextcloud/with-objectstore.nix index fc26760b8babde..48e1edea67ba33 100644 --- a/nixos/tests/nextcloud/with-objectstore.nix +++ b/nixos/tests/nextcloud/with-objectstore.nix @@ -1,96 +1,113 @@ -{ name, pkgs, testBase, system, ... }: +{ + name, + pkgs, + testBase, + system, + ... +}: with import ../../lib/testing-python.nix { inherit system pkgs; }; -runTest ({ config, lib, ... }: let - accessKey = "BKIKJAA5BMMU2RHO6IBB"; - secretKey = "V7f1CwQqAcwo80UEIJEjc5gVQUSSx5ohQ9GSrr12"; - - rootCredentialsFile = pkgs.writeText "minio-credentials-full" '' - MINIO_ROOT_USER=${accessKey} - MINIO_ROOT_PASSWORD=${secretKey} - ''; -in { - inherit name; - meta = with pkgs.lib.maintainers; { - maintainers = [ onny ma27 ]; - }; - - imports = [ testBase ]; - - nodes = { - nextcloud = { config, pkgs, ... }: { - networking.firewall.allowedTCPPorts = [ 9000 ]; - environment.systemPackages = [ pkgs.minio-client ]; - - services.nextcloud.config.objectstore.s3 = { - enable = true; - bucket = "nextcloud"; - autocreate = true; - key = accessKey; - secretFile = "${pkgs.writeText "secretKey" secretKey}"; - hostname = "nextcloud"; - useSsl = false; - port = 9000; - usePathStyle = true; - region = "us-east-1"; - }; - - services.minio = { - enable = true; - listenAddress = "0.0.0.0:9000"; - consoleAddress = "0.0.0.0:9001"; - inherit rootCredentialsFile; - }; +runTest ( + { config, lib, ... }: + let + accessKey = "BKIKJAA5BMMU2RHO6IBB"; + secretKey = "V7f1CwQqAcwo80UEIJEjc5gVQUSSx5ohQ9GSrr12"; + + rootCredentialsFile = pkgs.writeText "minio-credentials-full" '' + MINIO_ROOT_USER=${accessKey} + MINIO_ROOT_PASSWORD=${secretKey} + ''; + in + { + inherit name; + meta = with pkgs.lib.maintainers; { + maintainers = [ + onny + ma27 + ]; }; - }; - - test-helpers.init = '' - nextcloud.wait_for_open_port(9000) - ''; - - test-helpers.extraTests = { nodes, ... }: '' - with subtest("File is not on the filesystem"): - nextcloud.succeed("test ! -e ${nodes.nextcloud.services.nextcloud.home}/data/root/files/test-shared-file") - - with subtest("Check if file is in S3"): - nextcloud.succeed( - "mc config host add minio http://localhost:9000 ${accessKey} ${secretKey} --api s3v4" - ) - files = nextcloud.succeed('mc ls minio/nextcloud|sort').strip().split('\n') - - # Cannot assert an exact number here, nc27 writes more stuff initially into S3. - # For now let's assume it's always the most recently added file. - assert len(files) > 0, f""" - Expected to have at least one object in minio/nextcloud. But `mc ls` gave output: - - '{files}' - """ - - import re - ptrn = re.compile("^\[[A-Z0-9 :-]+\] +(?P<details>[A-Za-z0-9 :]+)$") - match = ptrn.match(files[-1].strip()) - assert match, "Cannot match mc client output!" - size, type_, file = tuple(match.group('details').split(' ')) - - assert size == "3B", f""" - Expected size of uploaded file to be 3 bytes, got {size} - """ - - assert type_ == 'STANDARD', f""" - Expected type of bucket entry to be a file, i.e. 'STANDARD'. Got {type_} - """ - - assert file.startswith('urn:oid'), """ - Expected filename to start with 'urn:oid', instead got '{file}. - """ - - with subtest("Test download from S3"): - client.succeed( - "env AWS_ACCESS_KEY_ID=${accessKey} AWS_SECRET_ACCESS_KEY=${secretKey} " - + f"${lib.getExe pkgs.awscli2} s3 cp s3://nextcloud/{file} test --endpoint-url http://nextcloud:9000 " - + "--region us-east-1" - ) - - client.succeed("test hi = $(cat test)") - ''; -}) + + imports = [ testBase ]; + + nodes = { + nextcloud = + { config, pkgs, ... }: + { + networking.firewall.allowedTCPPorts = [ 9000 ]; + environment.systemPackages = [ pkgs.minio-client ]; + + services.nextcloud.config.objectstore.s3 = { + enable = true; + bucket = "nextcloud"; + autocreate = true; + key = accessKey; + secretFile = "${pkgs.writeText "secretKey" secretKey}"; + hostname = "nextcloud"; + useSsl = false; + port = 9000; + usePathStyle = true; + region = "us-east-1"; + }; + + services.minio = { + enable = true; + listenAddress = "0.0.0.0:9000"; + consoleAddress = "0.0.0.0:9001"; + inherit rootCredentialsFile; + }; + }; + }; + + test-helpers.init = '' + nextcloud.wait_for_open_port(9000) + ''; + + test-helpers.extraTests = + { nodes, ... }: + '' + with subtest("File is not on the filesystem"): + nextcloud.succeed("test ! -e ${nodes.nextcloud.services.nextcloud.home}/data/root/files/test-shared-file") + + with subtest("Check if file is in S3"): + nextcloud.succeed( + "mc config host add minio http://localhost:9000 ${accessKey} ${secretKey} --api s3v4" + ) + files = nextcloud.succeed('mc ls minio/nextcloud|sort').strip().split('\n') + + # Cannot assert an exact number here, nc27 writes more stuff initially into S3. + # For now let's assume it's always the most recently added file. + assert len(files) > 0, f""" + Expected to have at least one object in minio/nextcloud. But `mc ls` gave output: + + '{files}' + """ + + import re + ptrn = re.compile("^\[[A-Z0-9 :-]+\] +(?P<details>[A-Za-z0-9 :]+)$") + match = ptrn.match(files[-1].strip()) + assert match, "Cannot match mc client output!" + size, type_, file = tuple(match.group('details').split(' ')) + + assert size == "3B", f""" + Expected size of uploaded file to be 3 bytes, got {size} + """ + + assert type_ == 'STANDARD', f""" + Expected type of bucket entry to be a file, i.e. 'STANDARD'. Got {type_} + """ + + assert file.startswith('urn:oid'), """ + Expected filename to start with 'urn:oid', instead got '{file}. + """ + + with subtest("Test download from S3"): + client.succeed( + "env AWS_ACCESS_KEY_ID=${accessKey} AWS_SECRET_ACCESS_KEY=${secretKey} " + + f"${lib.getExe pkgs.awscli2} s3 cp s3://nextcloud/{file} test --endpoint-url http://nextcloud:9000 " + + "--region us-east-1" + ) + + client.succeed("test hi = $(cat test)") + ''; + } +) diff --git a/nixos/tests/nextcloud/with-postgresql-and-redis.nix b/nixos/tests/nextcloud/with-postgresql-and-redis.nix index 24c17f70932d36..43d8a74b3db827 100644 --- a/nixos/tests/nextcloud/with-postgresql-and-redis.nix +++ b/nixos/tests/nextcloud/with-postgresql-and-redis.nix @@ -1,60 +1,81 @@ -{ name, pkgs, testBase, system, ... }: +{ + name, + pkgs, + testBase, + system, + ... +}: with import ../../lib/testing-python.nix { inherit system pkgs; }; -runTest ({ config, ... }: { - inherit name; - meta = with pkgs.lib.maintainers; { - maintainers = [ eqyiel ma27 ]; - }; - - imports = [ testBase ]; - - nodes = { - nextcloud = { config, pkgs, lib, ... }: { - services.nextcloud = { - caching = { - apcu = false; - redis = true; - memcached = false; - }; - config.dbtype = "pgsql"; - notify_push = { - enable = true; - logLevel = "debug"; - }; - extraAppsEnable = true; - extraApps = with config.services.nextcloud.package.packages.apps; { - inherit notify_push notes; - }; - settings.trusted_proxies = [ "::1" ]; - }; +runTest ( + { config, ... }: + { + inherit name; + meta = with pkgs.lib.maintainers; { + maintainers = [ + eqyiel + ma27 + ]; + }; + + imports = [ testBase ]; + + nodes = { + nextcloud = + { + config, + pkgs, + lib, + ... + }: + { + services.nextcloud = { + caching = { + apcu = false; + redis = true; + memcached = false; + }; + config.dbtype = "pgsql"; + notify_push = { + enable = true; + logLevel = "debug"; + }; + extraAppsEnable = true; + extraApps = with config.services.nextcloud.package.packages.apps; { + inherit notify_push notes; + }; + settings.trusted_proxies = [ "::1" ]; + }; - services.redis.servers."nextcloud".enable = true; - services.redis.servers."nextcloud".port = 6379; + services.redis.servers."nextcloud".enable = true; + services.redis.servers."nextcloud".port = 6379; + }; }; - }; - - test-helpers.init = let - configureRedis = pkgs.writeScript "configure-redis" '' - nextcloud-occ config:system:set redis 'host' --value 'localhost' --type string - nextcloud-occ config:system:set redis 'port' --value 6379 --type integer - nextcloud-occ config:system:set memcache.local --value '\OC\Memcache\Redis' --type string - nextcloud-occ config:system:set memcache.locking --value '\OC\Memcache\Redis' --type string + + test-helpers.init = + let + configureRedis = pkgs.writeScript "configure-redis" '' + nextcloud-occ config:system:set redis 'host' --value 'localhost' --type string + nextcloud-occ config:system:set redis 'port' --value 6379 --type integer + nextcloud-occ config:system:set memcache.local --value '\OC\Memcache\Redis' --type string + nextcloud-occ config:system:set memcache.locking --value '\OC\Memcache\Redis' --type string + ''; + in + '' + nextcloud.succeed("${configureRedis}") + ''; + + test-helpers.extraTests = '' + with subtest("notify-push"): + client.execute("${pkgs.lib.getExe pkgs.nextcloud-notify_push.passthru.test_client} http://nextcloud ${config.adminuser} ${config.adminpass} >&2 &") + nextcloud.wait_until_succeeds("journalctl -u nextcloud-notify_push | grep -q \"Sending ping to ${config.adminuser}\"") + + with subtest("Redis is used for caching"): + # redis cache should not be empty + nextcloud.fail('test "[]" = "$(redis-cli --json KEYS "*")"') + + with subtest("No code is returned when requesting PHP files (regression test)"): + nextcloud.fail("curl -f http://nextcloud/nix-apps/notes/lib/AppInfo/Application.php") ''; - in '' - nextcloud.succeed("${configureRedis}") - ''; - - test-helpers.extraTests = '' - with subtest("notify-push"): - client.execute("${pkgs.lib.getExe pkgs.nextcloud-notify_push.passthru.test_client} http://nextcloud ${config.adminuser} ${config.adminpass} >&2 &") - nextcloud.wait_until_succeeds("journalctl -u nextcloud-notify_push | grep -q \"Sending ping to ${config.adminuser}\"") - - with subtest("Redis is used for caching"): - # redis cache should not be empty - nextcloud.fail('test "[]" = "$(redis-cli --json KEYS "*")"') - - with subtest("No code is returned when requesting PHP files (regression test)"): - nextcloud.fail("curl -f http://nextcloud/nix-apps/notes/lib/AppInfo/Application.php") - ''; -}) + } +) diff --git a/nixos/tests/nexus.nix b/nixos/tests/nexus.nix index 87bb4d2eb58abd..9c3e65daf3176c 100644 --- a/nixos/tests/nexus.nix +++ b/nixos/tests/nexus.nix @@ -3,30 +3,34 @@ # 2. nexus service can startup on server (creating database and all other initial stuff) # 3. the web application is reachable via HTTP -import ./make-test-python.nix ({ pkgs, ...} : { - name = "nexus"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ironpinguin ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "nexus"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ironpinguin ]; + }; - nodes = { + nodes = { - server = - { ... }: - { virtualisation.memorySize = 2047; # qemu-system-i386 has a 2047M limit - virtualisation.diskSize = 8192; + server = + { ... }: + { + virtualisation.memorySize = 2047; # qemu-system-i386 has a 2047M limit + virtualisation.diskSize = 8192; - services.nexus.enable = true; - }; + services.nexus.enable = true; + }; - }; + }; - testScript = '' - start_all() + testScript = '' + start_all() - server.wait_for_unit("nexus") - server.wait_for_open_port(8081) + server.wait_for_unit("nexus") + server.wait_for_open_port(8081) - server.succeed("curl -f 127.0.0.1:8081") - ''; -}) + server.succeed("curl -f 127.0.0.1:8081") + ''; + } +) diff --git a/nixos/tests/nfs/default.nix b/nixos/tests/nfs/default.nix index 6bc803c91b4607..09c8a174237058 100644 --- a/nixos/tests/nfs/default.nix +++ b/nixos/tests/nfs/default.nix @@ -1,9 +1,12 @@ -{ version ? 4 -, system ? builtins.currentSystem -, pkgs ? import ../../.. { inherit system; } -}: { +{ + version ? 4, + system ? builtins.currentSystem, + pkgs ? import ../../.. { inherit system; }, +}: +{ simple = import ./simple.nix { inherit version system pkgs; }; -} // pkgs.lib.optionalAttrs (version == 4) { +} +// pkgs.lib.optionalAttrs (version == 4) { # TODO: Test kerberos + nfsv3 kerberos = import ./kerberos.nix { inherit version system pkgs; }; } diff --git a/nixos/tests/nfs/kerberos.nix b/nixos/tests/nfs/kerberos.nix index 5944b53319a0b6..f9720cfb87e264 100644 --- a/nixos/tests/nfs/kerberos.nix +++ b/nixos/tests/nfs/kerberos.nix @@ -1,85 +1,95 @@ -import ../make-test-python.nix ({ pkgs, lib, ... }: - -let - security.krb5 = { - enable = true; - settings = { - domain_realm."nfs.test" = "NFS.TEST"; - libdefaults.default_realm = "NFS.TEST"; - realms."NFS.TEST" = { - admin_server = "server.nfs.test"; - kdc = "server.nfs.test"; +import ../make-test-python.nix ( + { pkgs, lib, ... }: + + let + security.krb5 = { + enable = true; + settings = { + domain_realm."nfs.test" = "NFS.TEST"; + libdefaults.default_realm = "NFS.TEST"; + realms."NFS.TEST" = { + admin_server = "server.nfs.test"; + kdc = "server.nfs.test"; + }; }; }; - }; - hosts = - '' + hosts = '' 192.168.1.1 client.nfs.test 192.168.1.2 server.nfs.test ''; - users = { - users.alice = { + users = { + users.alice = { isNormalUser = true; name = "alice"; uid = 1000; }; - }; - -in - -{ - name = "nfsv4-with-kerberos"; - - nodes = { - client = { lib, ... }: - { inherit security users; - - networking.extraHosts = hosts; - networking.domain = "nfs.test"; - networking.hostName = "client"; + }; - virtualisation.fileSystems = - { "/data" = { - device = "server.nfs.test:/"; - fsType = "nfs"; - options = [ "nfsvers=4" "sec=krb5p" "noauto" ]; + in + + { + name = "nfsv4-with-kerberos"; + + nodes = { + client = + { lib, ... }: + { + inherit security users; + + networking.extraHosts = hosts; + networking.domain = "nfs.test"; + networking.hostName = "client"; + + virtualisation.fileSystems = { + "/data" = { + device = "server.nfs.test:/"; + fsType = "nfs"; + options = [ + "nfsvers=4" + "sec=krb5p" + "noauto" + ]; }; }; - }; - - server = { lib, ...}: - { inherit security users; - - networking.extraHosts = hosts; - networking.domain = "nfs.test"; - networking.hostName = "server"; - - networking.firewall.allowedTCPPorts = [ - 111 # rpc - 2049 # nfs - 88 # kerberos - 749 # kerberos admin - ]; - - services.kerberos_server.enable = true; - services.kerberos_server.realms = - { "NFS.TEST".acl = - [ { access = "all"; principal = "admin/admin"; } ]; + }; + + server = + { lib, ... }: + { + inherit security users; + + networking.extraHosts = hosts; + networking.domain = "nfs.test"; + networking.hostName = "server"; + + networking.firewall.allowedTCPPorts = [ + 111 # rpc + 2049 # nfs + 88 # kerberos + 749 # kerberos admin + ]; + + services.kerberos_server.enable = true; + services.kerberos_server.realms = { + "NFS.TEST".acl = [ + { + access = "all"; + principal = "admin/admin"; + } + ]; }; - services.nfs.server.enable = true; - services.nfs.server.createMountPoints = true; - services.nfs.server.exports = - '' + services.nfs.server.enable = true; + services.nfs.server.createMountPoints = true; + services.nfs.server.exports = '' /data *(rw,no_root_squash,fsid=0,sec=krb5p) ''; - }; - }; + }; + }; - testScript = - '' + testScript = '' server.succeed("mkdir -p /data/alice") server.succeed("chown alice:users /data/alice") @@ -132,5 +142,6 @@ in assert ids == expected, f"ids incorrect: got {ids} expected {expected}" ''; - meta.maintainers = [ lib.maintainers.dblsaiko ]; -}) + meta.maintainers = [ lib.maintainers.dblsaiko ]; + } +) diff --git a/nixos/tests/nfs/simple.nix b/nixos/tests/nfs/simple.nix index 077c1d41093567..a36270dda535fc 100644 --- a/nixos/tests/nfs/simple.nix +++ b/nixos/tests/nfs/simple.nix @@ -1,46 +1,51 @@ -import ../make-test-python.nix ({ pkgs, version ? 4, ... }: - -let - - client = - { pkgs, ... }: - { virtualisation.fileSystems = - { "/data" = - { # nfs4 exports the export with fsid=0 as a virtual root directory - device = if (version == 4) then "server:/" else "server:/data"; - fsType = "nfs"; - options = [ "vers=${toString version}" ]; - }; +import ../make-test-python.nix ( + { + pkgs, + version ? 4, + ... + }: + + let + + client = + { pkgs, ... }: + { + virtualisation.fileSystems = { + "/data" = { + # nfs4 exports the export with fsid=0 as a virtual root directory + device = if (version == 4) then "server:/" else "server:/data"; + fsType = "nfs"; + options = [ "vers=${toString version}" ]; + }; }; - networking.firewall.enable = false; # FIXME: only open statd - }; + networking.firewall.enable = false; # FIXME: only open statd + }; -in + in -{ - name = "nfs"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; + { + name = "nfs"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; - nodes = - { client1 = client; + nodes = { + client1 = client; client2 = client; server = { ... }: - { services.nfs.server.enable = true; - services.nfs.server.exports = - '' - /data 192.168.1.0/255.255.255.0(rw,no_root_squash,no_subtree_check,fsid=0) - ''; + { + services.nfs.server.enable = true; + services.nfs.server.exports = '' + /data 192.168.1.0/255.255.255.0(rw,no_root_squash,no_subtree_check,fsid=0) + ''; services.nfs.server.createMountPoints = true; networking.firewall.enable = false; # FIXME: figure out what ports need to be allowed }; }; - testScript = - '' + testScript = '' import time server.wait_for_unit("nfs-server") @@ -92,4 +97,5 @@ in # FIXME: regressed in kernel 6.1.28, temporarily disabled while investigating # assert duration < 30, f"shutdown took too long ({duration} seconds)" ''; -}) + } +) diff --git a/nixos/tests/nghttpx.nix b/nixos/tests/nghttpx.nix index 11cac332827dc1..15acb81b12c18a 100644 --- a/nixos/tests/nghttpx.nix +++ b/nixos/tests/nghttpx.nix @@ -1,8 +1,10 @@ let nginxRoot = "/run/nginx"; in - import ./make-test-python.nix ({...}: { - name = "nghttpx"; +import ./make-test-python.nix ( + { ... }: + { + name = "nghttpx"; nodes = { webserver = { networking.firewall.allowedTCPPorts = [ 80 ]; @@ -26,7 +28,8 @@ in services.nghttpx = { enable = true; frontends = [ - { server = { + { + server = { host = "*"; port = 80; }; @@ -37,7 +40,8 @@ in } ]; backends = [ - { server = { + { + server = { host = "webserver"; port = 80; }; @@ -48,7 +52,7 @@ in }; }; - client = {}; + client = { }; }; testScript = '' @@ -58,4 +62,5 @@ in proxy.wait_for_open_port(80) client.wait_until_succeeds("curl -s --fail http://proxy/hello-world.txt") ''; - }) + } +) diff --git a/nixos/tests/nginx-auth.nix b/nixos/tests/nginx-auth.nix index a85426dda87178..eb04b257194117 100644 --- a/nixos/tests/nginx-auth.nix +++ b/nixos/tests/nginx-auth.nix @@ -1,47 +1,54 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "nginx-auth"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "nginx-auth"; - nodes = { - webserver = { pkgs, lib, ... }: { - services.nginx = let - root = pkgs.runCommand "testdir" {} '' - mkdir "$out" - echo hello world > "$out/index.html" - ''; - in { - enable = true; + nodes = { + webserver = + { pkgs, lib, ... }: + { + services.nginx = + let + root = pkgs.runCommand "testdir" { } '' + mkdir "$out" + echo hello world > "$out/index.html" + ''; + in + { + enable = true; - virtualHosts.lockedroot = { - inherit root; - basicAuth.alice = "pwofa"; - }; + virtualHosts.lockedroot = { + inherit root; + basicAuth.alice = "pwofa"; + }; - virtualHosts.lockedsubdir = { - inherit root; - locations."/sublocation/" = { - alias = "${root}/"; - basicAuth.bob = "pwofb"; - }; + virtualHosts.lockedsubdir = { + inherit root; + locations."/sublocation/" = { + alias = "${root}/"; + basicAuth.bob = "pwofb"; + }; + }; + }; }; - }; }; - }; - testScript = '' - webserver.wait_for_unit("nginx") - webserver.wait_for_open_port(80) + testScript = '' + webserver.wait_for_unit("nginx") + webserver.wait_for_open_port(80) - webserver.fail("curl --fail --resolve lockedroot:80:127.0.0.1 http://lockedroot") - webserver.succeed( - "curl --fail --resolve lockedroot:80:127.0.0.1 http://alice:pwofa@lockedroot" - ) + webserver.fail("curl --fail --resolve lockedroot:80:127.0.0.1 http://lockedroot") + webserver.succeed( + "curl --fail --resolve lockedroot:80:127.0.0.1 http://alice:pwofa@lockedroot" + ) - webserver.succeed("curl --fail --resolve lockedsubdir:80:127.0.0.1 http://lockedsubdir") - webserver.fail( - "curl --fail --resolve lockedsubdir:80:127.0.0.1 http://lockedsubdir/sublocation/index.html" - ) - webserver.succeed( - "curl --fail --resolve lockedsubdir:80:127.0.0.1 http://bob:pwofb@lockedsubdir/sublocation/index.html" - ) - ''; -}) + webserver.succeed("curl --fail --resolve lockedsubdir:80:127.0.0.1 http://lockedsubdir") + webserver.fail( + "curl --fail --resolve lockedsubdir:80:127.0.0.1 http://lockedsubdir/sublocation/index.html" + ) + webserver.succeed( + "curl --fail --resolve lockedsubdir:80:127.0.0.1 http://bob:pwofb@lockedsubdir/sublocation/index.html" + ) + ''; + } +) diff --git a/nixos/tests/nginx-etag-compression.nix b/nixos/tests/nginx-etag-compression.nix index 67493ae299841d..b012c8b1c15ccb 100644 --- a/nixos/tests/nginx-etag-compression.nix +++ b/nixos/tests/nginx-etag-compression.nix @@ -1,45 +1,49 @@ import ./make-test-python.nix { name = "nginx-etag-compression"; - nodes.machine = { pkgs, lib, ... }: { - services.nginx = { - enable = true; - recommendedGzipSettings = true; - virtualHosts.default = { - root = pkgs.runCommandLocal "testdir" {} '' - mkdir "$out" - cat > "$out/index.html" <<EOF - Hello, world! - Hello, world! - Hello, world! - Hello, world! - Hello, world! - Hello, world! - Hello, world! - Hello, world! - EOF - ${pkgs.gzip}/bin/gzip -k "$out/index.html" - ''; + nodes.machine = + { pkgs, lib, ... }: + { + services.nginx = { + enable = true; + recommendedGzipSettings = true; + virtualHosts.default = { + root = pkgs.runCommandLocal "testdir" { } '' + mkdir "$out" + cat > "$out/index.html" <<EOF + Hello, world! + Hello, world! + Hello, world! + Hello, world! + Hello, world! + Hello, world! + Hello, world! + Hello, world! + EOF + ${pkgs.gzip}/bin/gzip -k "$out/index.html" + ''; + }; }; }; - }; - testScript = { nodes, ... }: '' - machine.wait_for_unit("nginx") - machine.wait_for_open_port(80) + testScript = + { nodes, ... }: + '' + machine.wait_for_unit("nginx") + machine.wait_for_open_port(80) - etag_plain = machine.succeed("curl -s -w'%header{etag}' -o/dev/null -H 'Accept-encoding:' http://127.0.0.1/") - etag_gzip = machine.succeed("curl -s -w'%header{etag}' -o/dev/null -H 'Accept-encoding:gzip' http://127.0.0.1/") + etag_plain = machine.succeed("curl -s -w'%header{etag}' -o/dev/null -H 'Accept-encoding:' http://127.0.0.1/") + etag_gzip = machine.succeed("curl -s -w'%header{etag}' -o/dev/null -H 'Accept-encoding:gzip' http://127.0.0.1/") - with subtest("different representations have different etags"): - assert etag_plain != etag_gzip, f"etags should differ: {etag_plain} == {etag_gzip}" + with subtest("different representations have different etags"): + assert etag_plain != etag_gzip, f"etags should differ: {etag_plain} == {etag_gzip}" - with subtest("etag for uncompressed response is reproducible"): - etag_plain_repeat = machine.succeed("curl -s -w'%header{etag}' -o/dev/null -H 'Accept-encoding:' http://127.0.0.1/") - assert etag_plain == etag_plain_repeat, f"etags should be the same: {etag_plain} != {etag_plain_repeat}" + with subtest("etag for uncompressed response is reproducible"): + etag_plain_repeat = machine.succeed("curl -s -w'%header{etag}' -o/dev/null -H 'Accept-encoding:' http://127.0.0.1/") + assert etag_plain == etag_plain_repeat, f"etags should be the same: {etag_plain} != {etag_plain_repeat}" - with subtest("etag for compressed response is reproducible"): - etag_gzip_repeat = machine.succeed("curl -s -w'%header{etag}' -o/dev/null -H 'Accept-encoding:gzip' http://127.0.0.1/") - assert etag_gzip == etag_gzip_repeat, f"etags should be the same: {etag_gzip} != {etag_gzip_repeat}" - ''; + with subtest("etag for compressed response is reproducible"): + etag_gzip_repeat = machine.succeed("curl -s -w'%header{etag}' -o/dev/null -H 'Accept-encoding:gzip' http://127.0.0.1/") + assert etag_gzip == etag_gzip_repeat, f"etags should be the same: {etag_gzip} != {etag_gzip_repeat}" + ''; } diff --git a/nixos/tests/nginx-etag.nix b/nixos/tests/nginx-etag.nix index 6f45eacf8b41a3..e1154466d796c9 100644 --- a/nixos/tests/nginx-etag.nix +++ b/nixos/tests/nginx-etag.nix @@ -2,87 +2,105 @@ import ./make-test-python.nix { name = "nginx-etag"; nodes = { - server = { pkgs, lib, ... }: { - networking.firewall.enable = false; - services.nginx.enable = true; - services.nginx.virtualHosts.server = { - root = pkgs.runCommandLocal "testdir" {} '' - mkdir "$out" - cat > "$out/test.js" <<EOF - document.getElementById('foobar').setAttribute('foo', 'bar'); - EOF - cat > "$out/index.html" <<EOF - <!DOCTYPE html> - <div id="foobar">test</div> - <script src="test.js"></script> - EOF - ''; - }; - - specialisation.pass-checks.configuration = { + server = + { pkgs, lib, ... }: + { + networking.firewall.enable = false; + services.nginx.enable = true; services.nginx.virtualHosts.server = { - root = lib.mkForce (pkgs.runCommandLocal "testdir2" {} '' + root = pkgs.runCommandLocal "testdir" { } '' mkdir "$out" cat > "$out/test.js" <<EOF - document.getElementById('foobar').setAttribute('foo', 'yay'); + document.getElementById('foobar').setAttribute('foo', 'bar'); EOF cat > "$out/index.html" <<EOF <!DOCTYPE html> <div id="foobar">test</div> <script src="test.js"></script> EOF - ''); + ''; + }; + + specialisation.pass-checks.configuration = { + services.nginx.virtualHosts.server = { + root = lib.mkForce ( + pkgs.runCommandLocal "testdir2" { } '' + mkdir "$out" + cat > "$out/test.js" <<EOF + document.getElementById('foobar').setAttribute('foo', 'yay'); + EOF + cat > "$out/index.html" <<EOF + <!DOCTYPE html> + <div id="foobar">test</div> + <script src="test.js"></script> + EOF + '' + ); + }; }; }; - }; - client = { pkgs, lib, ... }: { - environment.systemPackages = let - testRunner = pkgs.writers.writePython3Bin "test-runner" { - libraries = [ pkgs.python3Packages.selenium ]; - } '' - import os - import time + client = + { pkgs, lib, ... }: + { + environment.systemPackages = + let + testRunner = + pkgs.writers.writePython3Bin "test-runner" + { + libraries = [ pkgs.python3Packages.selenium ]; + } + '' + import os + import time - from selenium.webdriver import Firefox - from selenium.webdriver.firefox.options import Options + from selenium.webdriver import Firefox + from selenium.webdriver.firefox.options import Options - options = Options() - options.add_argument('--headless') - driver = Firefox(options=options) + options = Options() + options.add_argument('--headless') + driver = Firefox(options=options) - driver.implicitly_wait(20) - driver.get('http://server/') - driver.find_element('xpath', '//div[@foo="bar"]') - open('/tmp/passed_stage1', 'w') + driver.implicitly_wait(20) + driver.get('http://server/') + driver.find_element('xpath', '//div[@foo="bar"]') + open('/tmp/passed_stage1', 'w') - while not os.path.exists('/tmp/proceed'): - time.sleep(0.5) + while not os.path.exists('/tmp/proceed'): + time.sleep(0.5) - driver.get('http://server/') - driver.find_element('xpath', '//div[@foo="yay"]') - open('/tmp/passed', 'w') - ''; - in [ pkgs.firefox-unwrapped pkgs.geckodriver testRunner ]; - }; + driver.get('http://server/') + driver.find_element('xpath', '//div[@foo="yay"]') + open('/tmp/passed', 'w') + ''; + in + [ + pkgs.firefox-unwrapped + pkgs.geckodriver + testRunner + ]; + }; }; - testScript = { nodes, ... }: let - inherit (nodes.server.config.system.build) toplevel; - newSystem = "${toplevel}/specialisation/pass-checks"; - in '' - start_all() + testScript = + { nodes, ... }: + let + inherit (nodes.server.config.system.build) toplevel; + newSystem = "${toplevel}/specialisation/pass-checks"; + in + '' + start_all() - server.wait_for_unit("nginx.service") - client.wait_for_unit("multi-user.target") - client.execute("test-runner >&2 &") - client.wait_for_file("/tmp/passed_stage1") + server.wait_for_unit("nginx.service") + client.wait_for_unit("multi-user.target") + client.execute("test-runner >&2 &") + client.wait_for_file("/tmp/passed_stage1") - server.succeed( - "${newSystem}/bin/switch-to-configuration test >&2" - ) - client.succeed("touch /tmp/proceed") + server.succeed( + "${newSystem}/bin/switch-to-configuration test >&2" + ) + client.succeed("touch /tmp/proceed") - client.wait_for_file("/tmp/passed") - ''; + client.wait_for_file("/tmp/passed") + ''; } diff --git a/nixos/tests/nginx-globalredirect.nix b/nixos/tests/nginx-globalredirect.nix index 5f5f4f344d8257..42dda6ccaab57f 100644 --- a/nixos/tests/nginx-globalredirect.nix +++ b/nixos/tests/nginx-globalredirect.nix @@ -1,24 +1,29 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "nginx-globalredirect"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "nginx-globalredirect"; - nodes = { - webserver = { pkgs, lib, ... }: { - services.nginx = { - enable = true; - virtualHosts.localhost = { - globalRedirect = "other.example.com"; - # Add an exception - locations."/noredirect".return = "200 'foo'"; + nodes = { + webserver = + { pkgs, lib, ... }: + { + services.nginx = { + enable = true; + virtualHosts.localhost = { + globalRedirect = "other.example.com"; + # Add an exception + locations."/noredirect".return = "200 'foo'"; + }; + }; }; - }; }; - }; - testScript = '' - webserver.wait_for_unit("nginx") - webserver.wait_for_open_port(80) + testScript = '' + webserver.wait_for_unit("nginx") + webserver.wait_for_open_port(80) - webserver.succeed("curl --fail -si http://localhost/alf | grep '^Location:.*/alf'") - webserver.fail("curl --fail -si http://localhost/noredirect | grep '^Location:'") - ''; -}) + webserver.succeed("curl --fail -si http://localhost/alf | grep '^Location:.*/alf'") + webserver.fail("curl --fail -si http://localhost/noredirect | grep '^Location:'") + ''; + } +) diff --git a/nixos/tests/nginx-http3.nix b/nixos/tests/nginx-http3.nix index 22f7f61f10ce68..d9f4b072f25eca 100644 --- a/nixos/tests/nginx-http3.nix +++ b/nixos/tests/nginx-http3.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -14,19 +15,23 @@ in builtins.listToAttrs ( builtins.map - (nginxPackage: - { - name = pkgs.lib.getName nginxPackage; - value = makeTest { - name = "nginx-http3-${pkgs.lib.getName nginxPackage}"; - meta.maintainers = with pkgs.lib.maintainers; [ izorkin ]; - - nodes = { - server = { lib, pkgs, ... }: { + (nginxPackage: { + name = pkgs.lib.getName nginxPackage; + value = makeTest { + name = "nginx-http3-${pkgs.lib.getName nginxPackage}"; + meta.maintainers = with pkgs.lib.maintainers; [ izorkin ]; + + nodes = { + server = + { lib, pkgs, ... }: + { networking = { interfaces.eth1 = { ipv4.addresses = [ - { address = "192.168.2.101"; prefixLength = 24; } + { + address = "192.168.2.101"; + prefixLength = 24; + } ]; }; extraHosts = hosts; @@ -51,25 +56,32 @@ builtins.listToAttrs ( http3_hq = false; quic = true; reuseport = true; - root = lib.mkForce (pkgs.runCommandLocal "testdir" {} '' - mkdir "$out" - cat > "$out/index.html" <<EOF - <html><body>Hello World!</body></html> - EOF - cat > "$out/example.txt" <<EOF - Check http3 protocol. - EOF - ''); + root = lib.mkForce ( + pkgs.runCommandLocal "testdir" { } '' + mkdir "$out" + cat > "$out/index.html" <<EOF + <html><body>Hello World!</body></html> + EOF + cat > "$out/example.txt" <<EOF + Check http3 protocol. + EOF + '' + ); }; }; }; - client = { pkgs, ... }: { + client = + { pkgs, ... }: + { environment.systemPackages = [ pkgs.curlHTTP3 ]; networking = { interfaces.eth1 = { ipv4.addresses = [ - { address = "192.168.2.201"; prefixLength = 24; } + { + address = "192.168.2.201"; + prefixLength = 24; + } ]; }; extraHosts = hosts; @@ -79,35 +91,37 @@ builtins.listToAttrs ( (builtins.readFile ./common/acme/server/ca.cert.pem) ]; }; - }; - - testScript = '' - start_all() - - server.wait_for_unit("nginx") - server.wait_for_open_port(443) - - # Check http connections - client.succeed("curl --verbose --http3-only https://acme.test | grep 'Hello World!'") - - # Check downloadings - client.succeed("curl --verbose --http3-only https://acme.test/example.txt --output /tmp/example.txt") - client.succeed("cat /tmp/example.txt | grep 'Check http3 protocol.'") - - # Check header reading - client.succeed("curl --verbose --http3-only --head https://acme.test | grep 'content-type'") - client.succeed("curl --verbose --http3-only --head https://acme.test | grep 'HTTP/3 200'") - client.succeed("curl --verbose --http3-only --head https://acme.test/error | grep 'HTTP/3 404'") - - # Check change User-Agent - client.succeed("curl --verbose --http3-only --user-agent 'Curl test 3.0' https://acme.test") - server.succeed("cat /var/log/nginx/access.log | grep 'Curl test 3.0'") - - server.shutdown() - client.shutdown() - ''; }; - } - ) - [ pkgs.angieQuic pkgs.nginxQuic ] + + testScript = '' + start_all() + + server.wait_for_unit("nginx") + server.wait_for_open_port(443) + + # Check http connections + client.succeed("curl --verbose --http3-only https://acme.test | grep 'Hello World!'") + + # Check downloadings + client.succeed("curl --verbose --http3-only https://acme.test/example.txt --output /tmp/example.txt") + client.succeed("cat /tmp/example.txt | grep 'Check http3 protocol.'") + + # Check header reading + client.succeed("curl --verbose --http3-only --head https://acme.test | grep 'content-type'") + client.succeed("curl --verbose --http3-only --head https://acme.test | grep 'HTTP/3 200'") + client.succeed("curl --verbose --http3-only --head https://acme.test/error | grep 'HTTP/3 404'") + + # Check change User-Agent + client.succeed("curl --verbose --http3-only --user-agent 'Curl test 3.0' https://acme.test") + server.succeed("cat /var/log/nginx/access.log | grep 'Curl test 3.0'") + + server.shutdown() + client.shutdown() + ''; + }; + }) + [ + pkgs.angieQuic + pkgs.nginxQuic + ] ) diff --git a/nixos/tests/nginx-modsecurity.nix b/nixos/tests/nginx-modsecurity.nix index 3c41da3e8d9bc5..892180f1cf7309 100644 --- a/nixos/tests/nginx-modsecurity.nix +++ b/nixos/tests/nginx-modsecurity.nix @@ -1,39 +1,51 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "nginx-modsecurity"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "nginx-modsecurity"; - nodes.machine = { config, lib, pkgs, ... }: { - services.nginx = { - enable = true; - additionalModules = [ pkgs.nginxModules.modsecurity ]; - virtualHosts.localhost = - let modsecurity_conf = pkgs.writeText "modsecurity.conf" '' - SecRuleEngine On - SecDefaultAction "phase:1,log,auditlog,deny,status:403" - SecDefaultAction "phase:2,log,auditlog,deny,status:403" - SecRule REQUEST_METHOD "HEAD" "id:100, phase:1, block" - SecRule REQUEST_FILENAME "secret.html" "id:101, phase:2, block" - ''; - testroot = pkgs.runCommand "testroot" {} '' - mkdir -p $out - echo "<html><body>Hello World!</body></html>" > $out/index.html - echo "s3cret" > $out/secret.html - ''; - in { - root = testroot; - extraConfig = '' - modsecurity on; - modsecurity_rules_file ${modsecurity_conf}; - ''; + nodes.machine = + { + config, + lib, + pkgs, + ... + }: + { + services.nginx = { + enable = true; + additionalModules = [ pkgs.nginxModules.modsecurity ]; + virtualHosts.localhost = + let + modsecurity_conf = pkgs.writeText "modsecurity.conf" '' + SecRuleEngine On + SecDefaultAction "phase:1,log,auditlog,deny,status:403" + SecDefaultAction "phase:2,log,auditlog,deny,status:403" + SecRule REQUEST_METHOD "HEAD" "id:100, phase:1, block" + SecRule REQUEST_FILENAME "secret.html" "id:101, phase:2, block" + ''; + testroot = pkgs.runCommand "testroot" { } '' + mkdir -p $out + echo "<html><body>Hello World!</body></html>" > $out/index.html + echo "s3cret" > $out/secret.html + ''; + in + { + root = testroot; + extraConfig = '' + modsecurity on; + modsecurity_rules_file ${modsecurity_conf}; + ''; + }; + }; }; - }; - }; - testScript = '' - machine.wait_for_unit("nginx") + testScript = '' + machine.wait_for_unit("nginx") - response = machine.wait_until_succeeds("curl -fvvv -s http://127.0.0.1/") - assert "Hello World!" in response + response = machine.wait_until_succeeds("curl -fvvv -s http://127.0.0.1/") + assert "Hello World!" in response - machine.fail("curl -fvvv -X HEAD -s http://127.0.0.1/") - machine.fail("curl -fvvv -s http://127.0.0.1/secret.html") - ''; -}) + machine.fail("curl -fvvv -X HEAD -s http://127.0.0.1/") + machine.fail("curl -fvvv -s http://127.0.0.1/secret.html") + ''; + } +) diff --git a/nixos/tests/nginx-moreheaders.nix b/nixos/tests/nginx-moreheaders.nix index 560dcf9ce0b823..34bbb211dc9d34 100644 --- a/nixos/tests/nginx-moreheaders.nix +++ b/nixos/tests/nginx-moreheaders.nix @@ -2,26 +2,28 @@ import ./make-test-python.nix { name = "nginx-more-headers"; nodes = { - webserver = { pkgs, ... }: { - services.nginx = { - enable = true; + webserver = + { pkgs, ... }: + { + services.nginx = { + enable = true; - virtualHosts.test = { - locations = { - "/".return = "200 blub"; - "/some" = { - return = "200 blub"; - extraConfig = '' - more_set_headers "Referrer-Policy: no-referrer"; - ''; + virtualHosts.test = { + locations = { + "/".return = "200 blub"; + "/some" = { + return = "200 blub"; + extraConfig = '' + more_set_headers "Referrer-Policy: no-referrer"; + ''; + }; }; + extraConfig = '' + more_set_headers "X-Powered-By: nixos"; + ''; }; - extraConfig = '' - more_set_headers "X-Powered-By: nixos"; - ''; }; }; - }; }; testScript = '' diff --git a/nixos/tests/nginx-njs.nix b/nixos/tests/nginx-njs.nix index 72be16384f1b3d..7e9e911ee02f34 100644 --- a/nixos/tests/nginx-njs.nix +++ b/nixos/tests/nginx-njs.nix @@ -1,27 +1,37 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "nginx-njs"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "nginx-njs"; - nodes.machine = { config, lib, pkgs, ... }: { - services.nginx = { - enable = true; - additionalModules = [ pkgs.nginxModules.njs ]; - commonHttpConfig = '' - js_import http from ${builtins.toFile "http.js" '' - function hello(r) { - r.return(200, "Hello world!"); - } - export default {hello}; - ''}; - ''; - virtualHosts."localhost".locations."/".extraConfig = '' - js_content http.hello; - ''; - }; - }; - testScript = '' - machine.wait_for_unit("nginx") + nodes.machine = + { + config, + lib, + pkgs, + ... + }: + { + services.nginx = { + enable = true; + additionalModules = [ pkgs.nginxModules.njs ]; + commonHttpConfig = '' + js_import http from ${builtins.toFile "http.js" '' + function hello(r) { + r.return(200, "Hello world!"); + } + export default {hello}; + ''}; + ''; + virtualHosts."localhost".locations."/".extraConfig = '' + js_content http.hello; + ''; + }; + }; + testScript = '' + machine.wait_for_unit("nginx") - response = machine.wait_until_succeeds("curl -fvvv -s http://127.0.0.1/") - assert "Hello world!" == response, f"Expected 'Hello world!', got '{response}'" - ''; -}) + response = machine.wait_until_succeeds("curl -fvvv -s http://127.0.0.1/") + assert "Hello world!" == response, f"Expected 'Hello world!', got '{response}'" + ''; + } +) diff --git a/nixos/tests/nginx-proxyprotocol/default.nix b/nixos/tests/nginx-proxyprotocol/default.nix index 2ff7debfcbe255..a94a258db33178 100644 --- a/nixos/tests/nginx-proxyprotocol/default.nix +++ b/nixos/tests/nginx-proxyprotocol/default.nix @@ -1,148 +1,164 @@ let certs = import ./snakeoil-certs.nix; in -import ../make-test-python.nix ({ pkgs, ... }: { - name = "nginx-proxyprotocol"; +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "nginx-proxyprotocol"; - meta = { - maintainers = with pkgs.lib.maintainers; [ raitobezarius ]; - }; - - nodes = { - webserver = { pkgs, lib, ... }: { - environment.systemPackages = [ pkgs.netcat ]; - security.pki.certificateFiles = [ - certs.ca.cert - ]; + meta = { + maintainers = with pkgs.lib.maintainers; [ raitobezarius ]; + }; - networking.extraHosts = '' - 127.0.0.5 proxy.test.nix - 127.0.0.5 noproxy.test.nix - 127.0.0.3 direct-nossl.test.nix - 127.0.0.4 unsecure-nossl.test.nix - 127.0.0.2 direct-noproxy.test.nix - 127.0.0.1 direct-proxy.test.nix - ''; - services.nginx = { - enable = true; - defaultListen = [ - { addr = "127.0.0.1"; proxyProtocol = true; ssl = true; } - { addr = "127.0.0.2"; } - { addr = "127.0.0.3"; ssl = false; } - { addr = "127.0.0.4"; ssl = false; proxyProtocol = true; } - ]; - commonHttpConfig = '' - log_format pcombined '(proxy_protocol=$proxy_protocol_addr) - (remote_addr=$remote_addr) - (realip=$realip_remote_addr) - (upstream=) - (remote_user=$remote_user) [$time_local] ' - '"$request" $status $body_bytes_sent ' - '"$http_referer" "$http_user_agent"'; - access_log /var/log/nginx/access.log pcombined; - error_log /var/log/nginx/error.log; - ''; - virtualHosts = - let - commonConfig = { - locations."/".return = "200 '$remote_addr'"; - extraConfig = '' - set_real_ip_from 127.0.0.5/32; - real_ip_header proxy_protocol; - ''; - }; - in + nodes = { + webserver = + { pkgs, lib, ... }: { - "*.test.nix" = commonConfig // { - sslCertificate = certs."*.test.nix".cert; - sslCertificateKey = certs."*.test.nix".key; - forceSSL = true; + environment.systemPackages = [ pkgs.netcat ]; + security.pki.certificateFiles = [ + certs.ca.cert + ]; + + networking.extraHosts = '' + 127.0.0.5 proxy.test.nix + 127.0.0.5 noproxy.test.nix + 127.0.0.3 direct-nossl.test.nix + 127.0.0.4 unsecure-nossl.test.nix + 127.0.0.2 direct-noproxy.test.nix + 127.0.0.1 direct-proxy.test.nix + ''; + services.nginx = { + enable = true; + defaultListen = [ + { + addr = "127.0.0.1"; + proxyProtocol = true; + ssl = true; + } + { addr = "127.0.0.2"; } + { + addr = "127.0.0.3"; + ssl = false; + } + { + addr = "127.0.0.4"; + ssl = false; + proxyProtocol = true; + } + ]; + commonHttpConfig = '' + log_format pcombined '(proxy_protocol=$proxy_protocol_addr) - (remote_addr=$remote_addr) - (realip=$realip_remote_addr) - (upstream=) - (remote_user=$remote_user) [$time_local] ' + '"$request" $status $body_bytes_sent ' + '"$http_referer" "$http_user_agent"'; + access_log /var/log/nginx/access.log pcombined; + error_log /var/log/nginx/error.log; + ''; + virtualHosts = + let + commonConfig = { + locations."/".return = "200 '$remote_addr'"; + extraConfig = '' + set_real_ip_from 127.0.0.5/32; + real_ip_header proxy_protocol; + ''; + }; + in + { + "*.test.nix" = commonConfig // { + sslCertificate = certs."*.test.nix".cert; + sslCertificateKey = certs."*.test.nix".key; + forceSSL = true; + }; + "direct-nossl.test.nix" = commonConfig; + "unsecure-nossl.test.nix" = commonConfig // { + extraConfig = '' + real_ip_header proxy_protocol; + ''; + }; + }; }; - "direct-nossl.test.nix" = commonConfig; - "unsecure-nossl.test.nix" = commonConfig // { - extraConfig = '' - real_ip_header proxy_protocol; + + services.sniproxy = { + enable = true; + config = '' + error_log { + syslog daemon + } + access_log { + syslog daemon + } + listener 127.0.0.5:443 { + protocol tls + source 127.0.0.5 + } + table { + ^proxy\.test\.nix$ 127.0.0.1 proxy_protocol + ^noproxy\.test\.nix$ 127.0.0.2 + } ''; }; }; - }; - - services.sniproxy = { - enable = true; - config = '' - error_log { - syslog daemon - } - access_log { - syslog daemon - } - listener 127.0.0.5:443 { - protocol tls - source 127.0.0.5 - } - table { - ^proxy\.test\.nix$ 127.0.0.1 proxy_protocol - ^noproxy\.test\.nix$ 127.0.0.2 - } - ''; - }; }; - }; - testScript = '' - def check_origin_ip(src_ip: str, dst_url: str, failure: bool = False, proxy_protocol: bool = False, expected_ip: str | None = None): - check = webserver.fail if failure else webserver.succeed - if expected_ip is None: - expected_ip = src_ip + testScript = '' + def check_origin_ip(src_ip: str, dst_url: str, failure: bool = False, proxy_protocol: bool = False, expected_ip: str | None = None): + check = webserver.fail if failure else webserver.succeed + if expected_ip is None: + expected_ip = src_ip - return check(f"curl {'--haproxy-protocol' if proxy_protocol else '''} --interface {src_ip} --fail -L {dst_url} | grep '{expected_ip}'") + return check(f"curl {'--haproxy-protocol' if proxy_protocol else '''} --interface {src_ip} --fail -L {dst_url} | grep '{expected_ip}'") - webserver.wait_for_unit("nginx") - webserver.wait_for_unit("sniproxy") - # This should be closed by virtue of ssl = true; - webserver.wait_for_closed_port(80, "127.0.0.1") - # This should be open by virtue of no explicit ssl - webserver.wait_for_open_port(80, "127.0.0.2") - # This should be open by virtue of ssl = true; - webserver.wait_for_open_port(443, "127.0.0.1") - # This should be open by virtue of no explicit ssl - webserver.wait_for_open_port(443, "127.0.0.2") - # This should be open by sniproxy - webserver.wait_for_open_port(443, "127.0.0.5") - # This should be closed by sniproxy - webserver.wait_for_closed_port(80, "127.0.0.5") + webserver.wait_for_unit("nginx") + webserver.wait_for_unit("sniproxy") + # This should be closed by virtue of ssl = true; + webserver.wait_for_closed_port(80, "127.0.0.1") + # This should be open by virtue of no explicit ssl + webserver.wait_for_open_port(80, "127.0.0.2") + # This should be open by virtue of ssl = true; + webserver.wait_for_open_port(443, "127.0.0.1") + # This should be open by virtue of no explicit ssl + webserver.wait_for_open_port(443, "127.0.0.2") + # This should be open by sniproxy + webserver.wait_for_open_port(443, "127.0.0.5") + # This should be closed by sniproxy + webserver.wait_for_closed_port(80, "127.0.0.5") - # Sanity checks for the NGINX module - # direct-HTTP connection to NGINX without TLS, this checks that ssl = false; works well. - check_origin_ip("127.0.0.10", "http://direct-nossl.test.nix/") - # webserver.execute("openssl s_client -showcerts -connect direct-noproxy.test.nix:443") - # direct-HTTP connection to NGINX with TLS - check_origin_ip("127.0.0.10", "http://direct-noproxy.test.nix/") - check_origin_ip("127.0.0.10", "https://direct-noproxy.test.nix/") - # Well, sniproxy is not listening on 80 and cannot redirect - check_origin_ip("127.0.0.10", "http://proxy.test.nix/", failure=True) - check_origin_ip("127.0.0.10", "http://noproxy.test.nix/", failure=True) + # Sanity checks for the NGINX module + # direct-HTTP connection to NGINX without TLS, this checks that ssl = false; works well. + check_origin_ip("127.0.0.10", "http://direct-nossl.test.nix/") + # webserver.execute("openssl s_client -showcerts -connect direct-noproxy.test.nix:443") + # direct-HTTP connection to NGINX with TLS + check_origin_ip("127.0.0.10", "http://direct-noproxy.test.nix/") + check_origin_ip("127.0.0.10", "https://direct-noproxy.test.nix/") + # Well, sniproxy is not listening on 80 and cannot redirect + check_origin_ip("127.0.0.10", "http://proxy.test.nix/", failure=True) + check_origin_ip("127.0.0.10", "http://noproxy.test.nix/", failure=True) - # Actual PROXY protocol related tests - # Connecting through sniproxy should passthrough the originating IP address. - check_origin_ip("127.0.0.10", "https://proxy.test.nix/") - # Connecting through sniproxy to a non-PROXY protocol enabled listener should not pass the originating IP address. - check_origin_ip("127.0.0.10", "https://noproxy.test.nix/", expected_ip="127.0.0.5") + # Actual PROXY protocol related tests + # Connecting through sniproxy should passthrough the originating IP address. + check_origin_ip("127.0.0.10", "https://proxy.test.nix/") + # Connecting through sniproxy to a non-PROXY protocol enabled listener should not pass the originating IP address. + check_origin_ip("127.0.0.10", "https://noproxy.test.nix/", expected_ip="127.0.0.5") - # Attack tests against spoofing - # Let's try to spoof our IP address by connecting direct-y to the PROXY protocol listener. - # FIXME(RaitoBezarius): rewrite it using Python + (Scapy|something else) as this is too much broken unfortunately. - # Or wait for upstream curl patch. - # def generate_attacker_request(original_ip: str, target_ip: str, dst_url: str): - # return f"""PROXY TCP4 {original_ip} {target_ip} 80 80 - # GET / HTTP/1.1 - # Host: {dst_url} + # Attack tests against spoofing + # Let's try to spoof our IP address by connecting direct-y to the PROXY protocol listener. + # FIXME(RaitoBezarius): rewrite it using Python + (Scapy|something else) as this is too much broken unfortunately. + # Or wait for upstream curl patch. + # def generate_attacker_request(original_ip: str, target_ip: str, dst_url: str): + # return f"""PROXY TCP4 {original_ip} {target_ip} 80 80 + # GET / HTTP/1.1 + # Host: {dst_url} - # """ - # def spoof(original_ip: str, target_ip: str, dst_url: str, tls: bool = False, expect_failure: bool = True): - # method = webserver.fail if expect_failure else webserver.succeed - # port = 443 if tls else 80 - # print(webserver.execute(f"cat <<EOF | nc {target_ip} {port}\n{generate_attacker_request(original_ip, target_ip, dst_url)}\nEOF")) - # return method(f"cat <<EOF | nc {target_ip} {port} | grep {original_ip}\n{generate_attacker_request(original_ip, target_ip, dst_url)}\nEOF") + # """ + # def spoof(original_ip: str, target_ip: str, dst_url: str, tls: bool = False, expect_failure: bool = True): + # method = webserver.fail if expect_failure else webserver.succeed + # port = 443 if tls else 80 + # print(webserver.execute(f"cat <<EOF | nc {target_ip} {port}\n{generate_attacker_request(original_ip, target_ip, dst_url)}\nEOF")) + # return method(f"cat <<EOF | nc {target_ip} {port} | grep {original_ip}\n{generate_attacker_request(original_ip, target_ip, dst_url)}\nEOF") - # check_origin_ip("127.0.0.10", "http://unsecure-nossl.test.nix", proxy_protocol=True) - # spoof("1.1.1.1", "127.0.0.4", "direct-nossl.test.nix") - # spoof("1.1.1.1", "127.0.0.4", "unsecure-nossl.test.nix", expect_failure=False) - ''; -}) + # check_origin_ip("127.0.0.10", "http://unsecure-nossl.test.nix", proxy_protocol=True) + # spoof("1.1.1.1", "127.0.0.4", "direct-nossl.test.nix") + # spoof("1.1.1.1", "127.0.0.4", "unsecure-nossl.test.nix", expect_failure=False) + ''; + } +) diff --git a/nixos/tests/nginx-proxyprotocol/generate-certs.nix b/nixos/tests/nginx-proxyprotocol/generate-certs.nix index b2315062035e38..c8e6a5dc31217d 100644 --- a/nixos/tests/nginx-proxyprotocol/generate-certs.nix +++ b/nixos/tests/nginx-proxyprotocol/generate-certs.nix @@ -1,23 +1,27 @@ # Minica can provide a CA key and cert, plus a key # and cert for our fake CA server's Web Front End (WFE). { - pkgs ? import <nixpkgs> {}, + pkgs ? import <nixpkgs> { }, minica ? pkgs.minica, runCommandCC ? pkgs.runCommandCC, }: let conf = import ./snakeoil-certs.nix; domain = conf.domain; - domainSanitized = pkgs.lib.replaceStrings ["*"] ["_"] domain; + domainSanitized = pkgs.lib.replaceStrings [ "*" ] [ "_" ] domain; in - runCommandCC "generate-tests-certs" { - buildInputs = [ (minica.overrideAttrs (old: { - postPatch = '' - sed -i 's_NotAfter: time.Now().AddDate(2, 0, 30),_NotAfter: time.Now().AddDate(20, 0, 0),_' main.go - ''; - })) ]; +runCommandCC "generate-tests-certs" + { + buildInputs = [ + (minica.overrideAttrs (old: { + postPatch = '' + sed -i 's_NotAfter: time.Now().AddDate(2, 0, 30),_NotAfter: time.Now().AddDate(20, 0, 0),_' main.go + ''; + })) + ]; - } '' + } + '' minica \ --ca-key ca.key.pem \ --ca-cert ca.cert.pem \ diff --git a/nixos/tests/nginx-proxyprotocol/snakeoil-certs.nix b/nixos/tests/nginx-proxyprotocol/snakeoil-certs.nix index 61af6351ca6558..3468c2c041a8ae 100644 --- a/nixos/tests/nginx-proxyprotocol/snakeoil-certs.nix +++ b/nixos/tests/nginx-proxyprotocol/snakeoil-certs.nix @@ -1,7 +1,8 @@ let domain = "*.test.nix"; domainSanitized = "_.test.nix"; -in { +in +{ inherit domain; ca = { cert = ./ca.cert.pem; diff --git a/nixos/tests/nginx-pubhtml.nix b/nixos/tests/nginx-pubhtml.nix index bff24c99d41a43..2eb0b82722863c 100644 --- a/nixos/tests/nginx-pubhtml.nix +++ b/nixos/tests/nginx-pubhtml.nix @@ -1,14 +1,16 @@ import ./make-test-python.nix { name = "nginx-pubhtml"; - nodes.machine = { pkgs, ... }: { - systemd.services.nginx.serviceConfig.ProtectHome = "read-only"; - services.nginx.enable = true; - services.nginx.virtualHosts.localhost = { - locations."~ ^/\\~([a-z0-9_]+)(/.*)?$".alias = "/home/$1/public_html$2"; + nodes.machine = + { pkgs, ... }: + { + systemd.services.nginx.serviceConfig.ProtectHome = "read-only"; + services.nginx.enable = true; + services.nginx.virtualHosts.localhost = { + locations."~ ^/\\~([a-z0-9_]+)(/.*)?$".alias = "/home/$1/public_html$2"; + }; + users.users.foo.isNormalUser = true; }; - users.users.foo.isNormalUser = true; - }; testScript = '' machine.wait_for_unit("nginx") diff --git a/nixos/tests/nginx-redirectcode.nix b/nixos/tests/nginx-redirectcode.nix index f60434a21a85d8..fd0062a7b786f1 100644 --- a/nixos/tests/nginx-redirectcode.nix +++ b/nixos/tests/nginx-redirectcode.nix @@ -1,25 +1,30 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "nginx-redirectcode"; - meta.maintainers = with lib.maintainers; [ misterio77 ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "nginx-redirectcode"; + meta.maintainers = with lib.maintainers; [ misterio77 ]; - nodes = { - webserver = { pkgs, lib, ... }: { - services.nginx = { - enable = true; - virtualHosts.localhost = { - globalRedirect = "example.com/foo"; - # With 308 (and 307), the method and body are to be kept when following it - redirectCode = 308; + nodes = { + webserver = + { pkgs, lib, ... }: + { + services.nginx = { + enable = true; + virtualHosts.localhost = { + globalRedirect = "example.com/foo"; + # With 308 (and 307), the method and body are to be kept when following it + redirectCode = 308; + }; + }; }; - }; }; - }; - testScript = '' - webserver.wait_for_unit("nginx") - webserver.wait_for_open_port(80) + testScript = '' + webserver.wait_for_unit("nginx") + webserver.wait_for_open_port(80) - # Check the status code - webserver.succeed("curl -si http://localhost | grep '^HTTP/[0-9.]\+ 308 Permanent Redirect'") - ''; -}) + # Check the status code + webserver.succeed("curl -si http://localhost | grep '^HTTP/[0-9.]\+ 308 Permanent Redirect'") + ''; + } +) diff --git a/nixos/tests/nginx-status-page.nix b/nixos/tests/nginx-status-page.nix index ff2c0940379c7f..2007db205f077d 100644 --- a/nixos/tests/nginx-status-page.nix +++ b/nixos/tests/nginx-status-page.nix @@ -1,72 +1,81 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "nginx-status-page"; - meta = with pkgs.lib.maintainers; { - maintainers = [ h7x4 ]; - }; - - nodes = { - webserver = { ... }: { - virtualisation.vlans = [ 1 ]; - - networking = { - useNetworkd = true; - useDHCP = false; - firewall.enable = false; - }; - - systemd.network.networks."01-eth1" = { - name = "eth1"; - networkConfig.Address = "10.0.0.1/24"; - }; - - services.nginx = { - enable = true; - statusPage = true; - virtualHosts."localhost".locations."/index.html".return = "200 'hello world\n'"; - }; - - environment.systemPackages = with pkgs; [ curl ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "nginx-status-page"; + meta = with pkgs.lib.maintainers; { + maintainers = [ h7x4 ]; }; - client = { ... }: { - virtualisation.vlans = [ 1 ]; - - networking = { - useNetworkd = true; - useDHCP = false; - firewall.enable = false; - }; - - systemd.network.networks."01-eth1" = { - name = "eth1"; - networkConfig.Address = "10.0.0.2/24"; - }; - - environment.systemPackages = with pkgs; [ curl ]; + nodes = { + webserver = + { ... }: + { + virtualisation.vlans = [ 1 ]; + + networking = { + useNetworkd = true; + useDHCP = false; + firewall.enable = false; + }; + + systemd.network.networks."01-eth1" = { + name = "eth1"; + networkConfig.Address = "10.0.0.1/24"; + }; + + services.nginx = { + enable = true; + statusPage = true; + virtualHosts."localhost".locations."/index.html".return = "200 'hello world\n'"; + }; + + environment.systemPackages = with pkgs; [ curl ]; + }; + + client = + { ... }: + { + virtualisation.vlans = [ 1 ]; + + networking = { + useNetworkd = true; + useDHCP = false; + firewall.enable = false; + }; + + systemd.network.networks."01-eth1" = { + name = "eth1"; + networkConfig.Address = "10.0.0.2/24"; + }; + + environment.systemPackages = with pkgs; [ curl ]; + }; }; - }; - testScript = { nodes, ... }: '' - start_all() + testScript = + { nodes, ... }: + '' + start_all() - webserver.wait_for_unit("nginx") - webserver.wait_for_open_port(80) + webserver.wait_for_unit("nginx") + webserver.wait_for_open_port(80) - def expect_http_code(node, code, url): - http_code = node.succeed(f"curl -w '%{{http_code}}' '{url}'") - assert http_code.split("\n")[-1].strip() == code, \ - f"expected {code} but got following response:\n{http_code}" + def expect_http_code(node, code, url): + http_code = node.succeed(f"curl -w '%{{http_code}}' '{url}'") + assert http_code.split("\n")[-1].strip() == code, \ + f"expected {code} but got following response:\n{http_code}" - with subtest("localhost can access status page"): - expect_http_code(webserver, "200", "http://localhost/nginx_status") + with subtest("localhost can access status page"): + expect_http_code(webserver, "200", "http://localhost/nginx_status") - with subtest("localhost can access other page"): - expect_http_code(webserver, "200", "http://localhost/index.html") + with subtest("localhost can access other page"): + expect_http_code(webserver, "200", "http://localhost/index.html") - with subtest("client can not access status page"): - expect_http_code(client, "403", "http://10.0.0.1/nginx_status") + with subtest("client can not access status page"): + expect_http_code(client, "403", "http://10.0.0.1/nginx_status") - with subtest("client can access other page"): - expect_http_code(client, "200", "http://10.0.0.1/index.html") - ''; -}) + with subtest("client can access other page"): + expect_http_code(client, "200", "http://10.0.0.1/index.html") + ''; + } +) diff --git a/nixos/tests/nginx-tmpdir.nix b/nixos/tests/nginx-tmpdir.nix index f26f992ffe1bea..80e99922215543 100644 --- a/nixos/tests/nginx-tmpdir.nix +++ b/nixos/tests/nginx-tmpdir.nix @@ -1,10 +1,12 @@ let dst-dir = "/run/nginx-test-tmpdir-uploads"; in - import ./make-test-python.nix { - name = "nginx-tmpdir"; +import ./make-test-python.nix { + name = "nginx-tmpdir"; - nodes.machine = { pkgs, ... }: { + nodes.machine = + { pkgs, ... }: + { environment.etc."tmpfiles.d/nginx-uploads.conf".text = "d ${dst-dir} 0755 nginx nginx 1d"; # overwrite the tmp.conf with a short age, there will be a duplicate line info from systemd-tmpfiles in the log @@ -29,32 +31,32 @@ in }; }; - testScript = '' - machine.wait_for_unit("nginx") - machine.wait_for_open_port(80) + testScript = '' + machine.wait_for_unit("nginx") + machine.wait_for_open_port(80) - with subtest("Needed prerequisite --http-client-body-temp-path=/tmp/nginx_client_body and private temp"): - machine.succeed("touch /tmp/systemd-private-*-nginx.service-*/tmp/nginx_client_body") + with subtest("Needed prerequisite --http-client-body-temp-path=/tmp/nginx_client_body and private temp"): + machine.succeed("touch /tmp/systemd-private-*-nginx.service-*/tmp/nginx_client_body") - with subtest("Working upload of test setup"): - machine.succeed("curl -X PUT http://localhost/upload/test1 --fail --data-raw 'Raw data 1'") - machine.succeed('test "$(cat ${dst-dir}/test1)" = "Raw data 1"') + with subtest("Working upload of test setup"): + machine.succeed("curl -X PUT http://localhost/upload/test1 --fail --data-raw 'Raw data 1'") + machine.succeed('test "$(cat ${dst-dir}/test1)" = "Raw data 1"') - # let the tmpfiles clean service do its job - machine.succeed("touch /tmp/touched") - machine.wait_until_succeeds( - "sleep 15 && systemctl start systemd-tmpfiles-clean.service && [ ! -f /tmp/touched ]", - timeout=150 - ) + # let the tmpfiles clean service do its job + machine.succeed("touch /tmp/touched") + machine.wait_until_succeeds( + "sleep 15 && systemctl start systemd-tmpfiles-clean.service && [ ! -f /tmp/touched ]", + timeout=150 + ) - with subtest("Working upload after cleaning"): - machine.succeed("curl -X PUT http://localhost/upload/test2 --fail --data-raw 'Raw data 2'") - machine.succeed('test "$(cat ${dst-dir}/test2)" = "Raw data 2"') + with subtest("Working upload after cleaning"): + machine.succeed("curl -X PUT http://localhost/upload/test2 --fail --data-raw 'Raw data 2'") + machine.succeed('test "$(cat ${dst-dir}/test2)" = "Raw data 2"') - # manually remove the nginx temp dir - machine.succeed("rm -r --interactive=never /tmp/systemd-private-*-nginx.service-*/tmp/nginx_client_body") + # manually remove the nginx temp dir + machine.succeed("rm -r --interactive=never /tmp/systemd-private-*-nginx.service-*/tmp/nginx_client_body") - with subtest("Broken upload after manual temp dir removal"): - machine.fail("curl -X PUT http://localhost/upload/test3 --fail --data-raw 'Raw data 3'") - ''; - } + with subtest("Broken upload after manual temp dir removal"): + machine.fail("curl -X PUT http://localhost/upload/test3 --fail --data-raw 'Raw data 3'") + ''; +} diff --git a/nixos/tests/nginx-unix-socket.nix b/nixos/tests/nginx-unix-socket.nix index 4640eaa171bdf0..020a1a7cd97a09 100644 --- a/nixos/tests/nginx-unix-socket.nix +++ b/nixos/tests/nginx-unix-socket.nix @@ -1,27 +1,31 @@ -import ./make-test-python.nix ({ pkgs, ... }: -let - nginxSocketPath = "/var/run/nginx/test.sock"; -in -{ - name = "nginx-unix-socket"; +import ./make-test-python.nix ( + { pkgs, ... }: + let + nginxSocketPath = "/var/run/nginx/test.sock"; + in + { + name = "nginx-unix-socket"; - nodes = { - webserver = { pkgs, lib, ... }: { - services.nginx = { - enable = true; - virtualHosts.localhost = { - serverName = "localhost"; - listen = [{ addr = "unix:${nginxSocketPath}"; }]; - locations."/test".return = "200 'foo'"; + nodes = { + webserver = + { pkgs, lib, ... }: + { + services.nginx = { + enable = true; + virtualHosts.localhost = { + serverName = "localhost"; + listen = [ { addr = "unix:${nginxSocketPath}"; } ]; + locations."/test".return = "200 'foo'"; + }; + }; }; - }; }; - }; - testScript = '' - webserver.wait_for_unit("nginx") - webserver.wait_for_open_unix_socket("${nginxSocketPath}") + testScript = '' + webserver.wait_for_unit("nginx") + webserver.wait_for_open_unix_socket("${nginxSocketPath}") - webserver.succeed("curl --fail --silent --unix-socket '${nginxSocketPath}' http://localhost/test | grep '^foo$'") - ''; -}) + webserver.succeed("curl --fail --silent --unix-socket '${nginxSocketPath}' http://localhost/test | grep '^foo$'") + ''; + } +) diff --git a/nixos/tests/nginx-variants.nix b/nixos/tests/nginx-variants.nix index 8c24052aacce39..905c94730d7301 100644 --- a/nixos/tests/nginx-variants.nix +++ b/nixos/tests/nginx-variants.nix @@ -1,19 +1,21 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; builtins.listToAttrs ( builtins.map - (nginxPackage: - { - name = pkgs.lib.getName nginxPackage; - value = makeTest { - name = "nginx-variant-${pkgs.lib.getName nginxPackage}"; + (nginxPackage: { + name = pkgs.lib.getName nginxPackage; + value = makeTest { + name = "nginx-variant-${pkgs.lib.getName nginxPackage}"; - nodes.machine = { pkgs, ... }: { + nodes.machine = + { pkgs, ... }: + { services.nginx = { enable = true; virtualHosts.localhost.locations."/".return = "200 'foo'"; @@ -21,13 +23,21 @@ builtins.listToAttrs ( }; }; - testScript = '' - machine.wait_for_unit("nginx") - machine.wait_for_open_port(80) - machine.succeed('test "$(curl -fvvv http://localhost/)" = foo') - ''; - }; - } - ) - [ pkgs.angie pkgs.angieQuic pkgs.nginxStable pkgs.nginxMainline pkgs.nginxQuic pkgs.nginxShibboleth pkgs.openresty pkgs.tengine ] + testScript = '' + machine.wait_for_unit("nginx") + machine.wait_for_open_port(80) + machine.succeed('test "$(curl -fvvv http://localhost/)" = foo') + ''; + }; + }) + [ + pkgs.angie + pkgs.angieQuic + pkgs.nginxStable + pkgs.nginxMainline + pkgs.nginxQuic + pkgs.nginxShibboleth + pkgs.openresty + pkgs.tengine + ] ) diff --git a/nixos/tests/nimdow.nix b/nixos/tests/nimdow.nix index 0656ef04be4834..d71fcf35acd8fb 100644 --- a/nixos/tests/nimdow.nix +++ b/nixos/tests/nimdow.nix @@ -1,25 +1,35 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "nimdow"; - meta = with pkgs.lib.maintainers; { - maintainers = [ marcusramberg ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "nimdow"; + meta = with pkgs.lib.maintainers; { + maintainers = [ marcusramberg ]; + }; - nodes.machine = { lib, ... }: { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - services.displayManager.defaultSession = lib.mkForce "none+nimdow"; - services.xserver.windowManager.nimdow.enable = true; - }; + nodes.machine = + { lib, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + services.displayManager.defaultSession = lib.mkForce "none+nimdow"; + services.xserver.windowManager.nimdow.enable = true; + }; - testScript = { ... }: '' - with subtest("ensure x starts"): - machine.wait_for_x() - machine.wait_for_file("/home/alice/.Xauthority") - machine.succeed("xauth merge ~alice/.Xauthority") + testScript = + { ... }: + '' + with subtest("ensure x starts"): + machine.wait_for_x() + machine.wait_for_file("/home/alice/.Xauthority") + machine.succeed("xauth merge ~alice/.Xauthority") - with subtest("ensure we can open a new terminal"): - machine.send_key("meta_l-ret") - machine.wait_for_window(r"alice.*?machine") - machine.screenshot("terminal") - ''; -}) + with subtest("ensure we can open a new terminal"): + machine.send_key("meta_l-ret") + machine.wait_for_window(r"alice.*?machine") + machine.screenshot("terminal") + ''; + } +) diff --git a/nixos/tests/nitter.nix b/nixos/tests/nitter.nix index 114f1aac7c7af8..22466ec53a0985 100644 --- a/nixos/tests/nitter.nix +++ b/nixos/tests/nitter.nix @@ -1,33 +1,35 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -let - # In a real deployment this should naturally not common from the nix store - # and be seeded via agenix or as a non-nix managed file. - # - # These credentials are from the nitter wiki and are expired. We must provide - # credentials in the correct format, otherwise nitter fails to start. They - # must not be valid, as unauthorized errors are handled gracefully. - guestAccountFile = pkgs.writeText "guest_accounts.jsonl" '' - {"oauth_token":"1719213587296620928-BsXY2RIJEw7fjxoNwbBemgjJhueK0m","oauth_token_secret":"N0WB0xhL4ng6WTN44aZO82SUJjz7ssI3hHez2CUhTiYqy"} - ''; -in -{ - name = "nitter"; - meta.maintainers = with pkgs.lib.maintainers; [ erdnaxe ]; + let + # In a real deployment this should naturally not common from the nix store + # and be seeded via agenix or as a non-nix managed file. + # + # These credentials are from the nitter wiki and are expired. We must provide + # credentials in the correct format, otherwise nitter fails to start. They + # must not be valid, as unauthorized errors are handled gracefully. + guestAccountFile = pkgs.writeText "guest_accounts.jsonl" '' + {"oauth_token":"1719213587296620928-BsXY2RIJEw7fjxoNwbBemgjJhueK0m","oauth_token_secret":"N0WB0xhL4ng6WTN44aZO82SUJjz7ssI3hHez2CUhTiYqy"} + ''; + in + { + name = "nitter"; + meta.maintainers = with pkgs.lib.maintainers; [ erdnaxe ]; - nodes.machine = { - services.nitter = { - enable = true; - # Test CAP_NET_BIND_SERVICE - server.port = 80; - # Provide dummy guest accounts - guestAccounts = guestAccountFile; + nodes.machine = { + services.nitter = { + enable = true; + # Test CAP_NET_BIND_SERVICE + server.port = 80; + # Provide dummy guest accounts + guestAccounts = guestAccountFile; + }; }; - }; - testScript = '' - machine.wait_for_unit("nitter.service") - machine.wait_for_open_port(80) - machine.succeed("curl --fail http://localhost:80/") - ''; -}) + testScript = '' + machine.wait_for_unit("nitter.service") + machine.wait_for_open_port(80) + machine.succeed("curl --fail http://localhost:80/") + ''; + } +) diff --git a/nixos/tests/nix-config.nix b/nixos/tests/nix-config.nix index 907e886def3512..18fa3ae347aa8d 100644 --- a/nixos/tests/nix-config.nix +++ b/nixos/tests/nix-config.nix @@ -1,18 +1,22 @@ -import ./make-test-python.nix ({ pkgs, ... }: -{ - name = "nix-config"; - nodes.machine = { pkgs, ... }: { - nix.settings = { - nix-path = [ "nonextra=/etc/value.nix" ]; - extra-nix-path = [ "extra=/etc/value.nix" ]; - }; - environment.etc."value.nix".text = "42"; - }; - testScript = '' - start_all() - machine.wait_for_unit("nix-daemon.socket") - # regression test for the workaround for https://github.com/NixOS/nix/issues/9487 - print(machine.succeed("nix-instantiate --find-file extra")) - print(machine.succeed("nix-instantiate --find-file nonextra")) - ''; -}) +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "nix-config"; + nodes.machine = + { pkgs, ... }: + { + nix.settings = { + nix-path = [ "nonextra=/etc/value.nix" ]; + extra-nix-path = [ "extra=/etc/value.nix" ]; + }; + environment.etc."value.nix".text = "42"; + }; + testScript = '' + start_all() + machine.wait_for_unit("nix-daemon.socket") + # regression test for the workaround for https://github.com/NixOS/nix/issues/9487 + print(machine.succeed("nix-instantiate --find-file extra")) + print(machine.succeed("nix-instantiate --find-file nonextra")) + ''; + } +) diff --git a/nixos/tests/nix-ld.nix b/nixos/tests/nix-ld.nix index 9b851f88617a05..03f5c5e89fbf3f 100644 --- a/nixos/tests/nix-ld.nix +++ b/nixos/tests/nix-ld.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: let inherit (import ../lib/testing-python.nix { inherit system pkgs; }) makeTest; diff --git a/nixos/tests/nix-serve-ssh.nix b/nixos/tests/nix-serve-ssh.nix index 1eb8d5b395b1f9..554ea5a69f20b3 100644 --- a/nixos/tests/nix-serve-ssh.nix +++ b/nixos/tests/nix-serve-ssh.nix @@ -1,45 +1,50 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let inherit (import ./ssh-keys.nix pkgs) - snakeOilPrivateKey snakeOilPublicKey; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + inherit (import ./ssh-keys.nix pkgs) + snakeOilPrivateKey + snakeOilPublicKey + ; ssh-config = builtins.toFile "ssh.conf" '' UserKnownHostsFile=/dev/null StrictHostKeyChecking=no ''; -in - { name = "nix-ssh-serve"; - meta.maintainers = [ lib.maintainers.shlevy ]; - nodes = - { server.nix.sshServe = - { enable = true; - keys = [ snakeOilPublicKey ]; - protocol = "ssh-ng"; - }; - server.nix.package = pkgs.nix; - client.nix.package = pkgs.nix; - }; - testScript = '' - start_all() + in + { + name = "nix-ssh-serve"; + meta.maintainers = [ lib.maintainers.shlevy ]; + nodes = { + server.nix.sshServe = { + enable = true; + keys = [ snakeOilPublicKey ]; + protocol = "ssh-ng"; + }; + server.nix.package = pkgs.nix; + client.nix.package = pkgs.nix; + }; + testScript = '' + start_all() - client.succeed("mkdir -m 700 /root/.ssh") - client.succeed( - "cat ${ssh-config} > /root/.ssh/config" - ) - client.succeed( - "cat ${snakeOilPrivateKey} > /root/.ssh/id_ecdsa" - ) - client.succeed("chmod 600 /root/.ssh/id_ecdsa") + client.succeed("mkdir -m 700 /root/.ssh") + client.succeed( + "cat ${ssh-config} > /root/.ssh/config" + ) + client.succeed( + "cat ${snakeOilPrivateKey} > /root/.ssh/id_ecdsa" + ) + client.succeed("chmod 600 /root/.ssh/id_ecdsa") - client.succeed("nix-store --add /etc/machine-id > mach-id-path") + client.succeed("nix-store --add /etc/machine-id > mach-id-path") - server.wait_for_unit("sshd") + server.wait_for_unit("sshd") - client.fail("diff /root/other-store$(cat mach-id-path) /etc/machine-id") - # Currently due to shared store this is a noop :( - client.succeed("nix copy --experimental-features 'nix-command' --to ssh-ng://nix-ssh@server $(cat mach-id-path)") - client.succeed( - "nix-store --realise $(cat mach-id-path) --store /root/other-store --substituters ssh-ng://nix-ssh@server" - ) - client.succeed("diff /root/other-store$(cat mach-id-path) /etc/machine-id") - ''; - } + client.fail("diff /root/other-store$(cat mach-id-path) /etc/machine-id") + # Currently due to shared store this is a noop :( + client.succeed("nix copy --experimental-features 'nix-command' --to ssh-ng://nix-ssh@server $(cat mach-id-path)") + client.succeed( + "nix-store --realise $(cat mach-id-path) --store /root/other-store --substituters ssh-ng://nix-ssh@server" + ) + client.succeed("diff /root/other-store$(cat mach-id-path) /etc/machine-id") + ''; + } ) diff --git a/nixos/tests/nix-serve.nix b/nixos/tests/nix-serve.nix index c41bc505e96350..d3b4668540a13b 100644 --- a/nixos/tests/nix-serve.nix +++ b/nixos/tests/nix-serve.nix @@ -1,22 +1,26 @@ { config, ... }: { name = "nix-serve"; - nodes.machine = { pkgs, ... }: { - services.nix-serve.enable = true; - environment.systemPackages = [ - pkgs.hello - ]; - }; - testScript = let - pkgHash = builtins.head ( - builtins.match "${builtins.storeDir}/([^-]+).+" (toString config.node.pkgs.hello) - ); - in '' - start_all() - machine.wait_for_unit("nix-serve.service") - machine.wait_for_open_port(5000) - machine.succeed( - "curl --fail -g http://0.0.0.0:5000/nar/${pkgHash}.nar -o /tmp/hello.nar" - ) - ''; + nodes.machine = + { pkgs, ... }: + { + services.nix-serve.enable = true; + environment.systemPackages = [ + pkgs.hello + ]; + }; + testScript = + let + pkgHash = builtins.head ( + builtins.match "${builtins.storeDir}/([^-]+).+" (toString config.node.pkgs.hello) + ); + in + '' + start_all() + machine.wait_for_unit("nix-serve.service") + machine.wait_for_open_port(5000) + machine.succeed( + "curl --fail -g http://0.0.0.0:5000/nar/${pkgHash}.nar -o /tmp/hello.nar" + ) + ''; } diff --git a/nixos/tests/nix/misc.nix b/nixos/tests/nix/misc.nix index 6a22ffe0d901fb..be23d4e450e3a9 100644 --- a/nixos/tests/nix/misc.nix +++ b/nixos/tests/nix/misc.nix @@ -8,57 +8,65 @@ let lix = testsForPackage { nixPackage = pkgs.lix; }; }; - testsForPackage = args: lib.recurseIntoAttrs { - # If the attribute is not named 'test' - # You will break all the universe on the release-*.nix side of things. - # `discoverTests` relies on `test` existence to perform a `callTest`. - test = testMiscFeatures args; - passthru.override = args': testsForPackage (args // args'); - }; - - testMiscFeatures = { nixPackage, ... }: pkgs.testers.nixosTest ( - let - foo = pkgs.writeText "foo" "Hello World"; - in { - name = "${nixPackage.pname}-misc"; - meta.maintainers = with lib.maintainers; [ raitobezarius artturin ]; + testsForPackage = + args: + lib.recurseIntoAttrs { + # If the attribute is not named 'test' + # You will break all the universe on the release-*.nix side of things. + # `discoverTests` relies on `test` existence to perform a `callTest`. + test = testMiscFeatures args; + passthru.override = args': testsForPackage (args // args'); + }; - nodes.machine = - { lib, ... }: + testMiscFeatures = + { nixPackage, ... }: + pkgs.testers.nixosTest ( + let + foo = pkgs.writeText "foo" "Hello World"; + in { - system.extraDependencies = [ foo ]; + name = "${nixPackage.pname}-misc"; + meta.maintainers = with lib.maintainers; [ + raitobezarius + artturin + ]; + + nodes.machine = + { lib, ... }: + { + system.extraDependencies = [ foo ]; - nix.package = nixPackage; - }; + nix.package = nixPackage; + }; - testScript = - '' - import json + testScript = '' + import json - def get_path_info(path): - result = machine.succeed(f"nix --option experimental-features nix-command path-info --json {path}") - parsed = json.loads(result) - return parsed + def get_path_info(path): + result = machine.succeed(f"nix --option experimental-features nix-command path-info --json {path}") + parsed = json.loads(result) + return parsed - with subtest("nix-db"): - out = "${foo}" - info = get_path_info(out) - print(info) + with subtest("nix-db"): + out = "${foo}" + info = get_path_info(out) + print(info) - pathinfo = info[0] if isinstance(info, list) else info[out] + pathinfo = info[0] if isinstance(info, list) else info[out] - if ( - pathinfo["narHash"] - != "sha256-BdMdnb/0eWy3EddjE83rdgzWWpQjfWPAj3zDIFMD3Ck=" - ): - raise Exception("narHash not set") + if ( + pathinfo["narHash"] + != "sha256-BdMdnb/0eWy3EddjE83rdgzWWpQjfWPAj3zDIFMD3Ck=" + ): + raise Exception("narHash not set") - if pathinfo["narSize"] != 128: - raise Exception("narSize not set") + if pathinfo["narSize"] != 128: + raise Exception("narSize not set") - with subtest("nix-db"): - machine.succeed("nix-store -qR /run/current-system | grep nixos-") - ''; - }); - in - tests + with subtest("nix-db"): + machine.succeed("nix-store -qR /run/current-system | grep nixos-") + ''; + } + ); +in +tests diff --git a/nixos/tests/nixops/default.nix b/nixos/tests/nixops/default.nix index 6468b8c3822492..f389cd0d0b51af 100644 --- a/nixos/tests/nixops/default.nix +++ b/nixos/tests/nixops/default.nix @@ -14,82 +14,98 @@ let # inherit testsForPackage; }; - testsForPackage = args: lib.recurseIntoAttrs { - legacyNetwork = testLegacyNetwork args; - passthru.override = args': testsForPackage (args // args'); - }; + testsForPackage = + args: + lib.recurseIntoAttrs { + legacyNetwork = testLegacyNetwork args; + passthru.override = args': testsForPackage (args // args'); + }; - testLegacyNetwork = { nixopsPkg, ... }: pkgs.testers.nixosTest ({ - name = "nixops-legacy-network"; - nodes = { - deployer = { config, lib, nodes, pkgs, ... }: { - imports = [ ../../modules/installer/cd-dvd/channel.nix ]; - environment.systemPackages = [ nixopsPkg ]; - nix.settings.substituters = lib.mkForce [ ]; - users.users.person.isNormalUser = true; - virtualisation.writableStore = true; - virtualisation.additionalPaths = [ - pkgs.hello - pkgs.figlet - ]; - virtualisation.memorySize = 2048; - - # TODO: make this efficient, https://github.com/NixOS/nixpkgs/issues/180529 - system.includeBuildDependencies = true; + testLegacyNetwork = + { nixopsPkg, ... }: + pkgs.testers.nixosTest ({ + name = "nixops-legacy-network"; + nodes = { + deployer = + { + config, + lib, + nodes, + pkgs, + ... + }: + { + imports = [ ../../modules/installer/cd-dvd/channel.nix ]; + environment.systemPackages = [ nixopsPkg ]; + nix.settings.substituters = lib.mkForce [ ]; + users.users.person.isNormalUser = true; + virtualisation.writableStore = true; + virtualisation.additionalPaths = [ + pkgs.hello + pkgs.figlet + ]; + virtualisation.memorySize = 2048; + + # TODO: make this efficient, https://github.com/NixOS/nixpkgs/issues/180529 + system.includeBuildDependencies = true; + }; + server = + { lib, ... }: + { + imports = [ ./legacy/base-configuration.nix ]; + }; }; - server = { lib, ... }: { - imports = [ ./legacy/base-configuration.nix ]; - }; - }; - testScript = { nodes }: - let - deployerSetup = pkgs.writeScript "deployerSetup" '' - #!${pkgs.runtimeShell} - set -eux -o pipefail - cp --no-preserve=mode -r ${./legacy} unicorn - cp --no-preserve=mode ${../ssh-keys.nix} unicorn/ssh-keys.nix - mkdir -p ~/.ssh - cp ${snakeOilPrivateKey} ~/.ssh/id_ed25519 - chmod 0400 ~/.ssh/id_ed25519 + testScript = + { nodes }: + let + deployerSetup = pkgs.writeScript "deployerSetup" '' + #!${pkgs.runtimeShell} + set -eux -o pipefail + cp --no-preserve=mode -r ${./legacy} unicorn + cp --no-preserve=mode ${../ssh-keys.nix} unicorn/ssh-keys.nix + mkdir -p ~/.ssh + cp ${snakeOilPrivateKey} ~/.ssh/id_ed25519 + chmod 0400 ~/.ssh/id_ed25519 + ''; + serverNetworkJSON = pkgs.writeText "server-network.json" ( + builtins.toJSON nodes.server.system.build.networkConfig + ); + in + '' + import shlex + + def deployer_do(cmd): + cmd = shlex.quote(cmd) + return deployer.succeed(f"su person -l -c {cmd} &>/dev/console") + + start_all() + + deployer_do("cat /etc/hosts") + + deployer_do("${deployerSetup}") + deployer_do("cp ${serverNetworkJSON} unicorn/server-network.json") + + # Establish that ssh works, regardless of nixops + # Easy way to accept the server host key too. + server.wait_for_open_port(22) + deployer.wait_for_unit("network.target") + + # Put newlines on console, to flush the console reader's line buffer + # in case nixops' last output did not end in a newline, as is the case + # with a status line (if implemented?) + deployer.succeed("while sleep 60s; do echo [60s passed]; done >&2 &") + + deployer_do("cd ~/unicorn; ssh -oStrictHostKeyChecking=accept-new root@server echo hi") + + # Create and deploy + deployer_do("cd ~/unicorn; nixops create") + + deployer_do("cd ~/unicorn; nixops deploy --confirm") + + deployer_do("cd ~/unicorn; nixops ssh server 'hello | figlet'") ''; - serverNetworkJSON = pkgs.writeText "server-network.json" - (builtins.toJSON nodes.server.system.build.networkConfig); - in - '' - import shlex - - def deployer_do(cmd): - cmd = shlex.quote(cmd) - return deployer.succeed(f"su person -l -c {cmd} &>/dev/console") - - start_all() - - deployer_do("cat /etc/hosts") - - deployer_do("${deployerSetup}") - deployer_do("cp ${serverNetworkJSON} unicorn/server-network.json") - - # Establish that ssh works, regardless of nixops - # Easy way to accept the server host key too. - server.wait_for_open_port(22) - deployer.wait_for_unit("network.target") - - # Put newlines on console, to flush the console reader's line buffer - # in case nixops' last output did not end in a newline, as is the case - # with a status line (if implemented?) - deployer.succeed("while sleep 60s; do echo [60s passed]; done >&2 &") - - deployer_do("cd ~/unicorn; ssh -oStrictHostKeyChecking=accept-new root@server echo hi") - - # Create and deploy - deployer_do("cd ~/unicorn; nixops create") - - deployer_do("cd ~/unicorn; nixops deploy --confirm") - - deployer_do("cd ~/unicorn; nixops ssh server 'hello | figlet'") - ''; - }); + }); inherit (import ../ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; diff --git a/nixos/tests/nixops/legacy/base-configuration.nix b/nixos/tests/nixops/legacy/base-configuration.nix index 7f1c07a5c4a901..f7c15f3fe1ff0e 100644 --- a/nixos/tests/nixops/legacy/base-configuration.nix +++ b/nixos/tests/nixops/legacy/base-configuration.nix @@ -1,14 +1,21 @@ -{ lib, modulesPath, pkgs, ... }: +{ + lib, + modulesPath, + pkgs, + ... +}: let ssh-keys = - if builtins.pathExists ../../ssh-keys.nix - then # Outside sandbox + if builtins.pathExists ../../ssh-keys.nix then # Outside sandbox ../../ssh-keys.nix - else # In sandbox + # In sandbox + else ./ssh-keys.nix; inherit (import ssh-keys pkgs) - snakeOilPrivateKey snakeOilPublicKey; + snakeOilPrivateKey + snakeOilPublicKey + ; in { imports = [ @@ -26,6 +33,12 @@ in users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; - security.pam.services.sshd.limits = - [{ domain = "*"; item = "memlock"; type = "-"; value = 1024; }]; + security.pam.services.sshd.limits = [ + { + domain = "*"; + item = "memlock"; + type = "-"; + value = 1024; + } + ]; } diff --git a/nixos/tests/nixops/legacy/nixops.nix b/nixos/tests/nixops/legacy/nixops.nix index 795dc2a7182542..c610ce8b159d2c 100644 --- a/nixos/tests/nixops/legacy/nixops.nix +++ b/nixos/tests/nixops/legacy/nixops.nix @@ -4,12 +4,17 @@ # NB this is not really what makes it a legacy network; lack of flakes is. storage.legacy = { }; }; - server = { lib, pkgs, ... }: { - deployment.targetEnv = "none"; - imports = [ - ./base-configuration.nix - (lib.modules.importJSON ./server-network.json) - ]; - environment.systemPackages = [ pkgs.hello pkgs.figlet ]; - }; + server = + { lib, pkgs, ... }: + { + deployment.targetEnv = "none"; + imports = [ + ./base-configuration.nix + (lib.modules.importJSON ./server-network.json) + ]; + environment.systemPackages = [ + pkgs.hello + pkgs.figlet + ]; + }; } diff --git a/nixos/tests/nixos-generate-config.nix b/nixos/tests/nixos-generate-config.nix index e1c2f29e067322..6109e50e8b5ede 100644 --- a/nixos/tests/nixos-generate-config.nix +++ b/nixos/tests/nixos-generate-config.nix @@ -1,41 +1,46 @@ -import ./make-test-python.nix ({ lib, ... } : { - name = "nixos-generate-config"; - meta.maintainers = with lib.maintainers; [ basvandijk ]; - nodes.machine = { - system.nixos-generate-config.configuration = '' - # OVERRIDDEN - { config, pkgs, ... }: { - imports = [ ./hardware-configuration.nix ]; - $bootLoaderConfig - $desktopConfiguration - } - ''; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "nixos-generate-config"; + meta.maintainers = with lib.maintainers; [ basvandijk ]; + nodes.machine = { + system.nixos-generate-config.configuration = '' + # OVERRIDDEN + { config, pkgs, ... }: { + imports = [ ./hardware-configuration.nix ]; + $bootLoaderConfig + $desktopConfiguration + } + ''; - system.nixos-generate-config.desktopConfiguration = ['' - # DESKTOP - services.xserver.displayManager.gdm.enable = true; - services.xserver.desktopManager.gnome.enable = true; - '']; - }; - testScript = '' - start_all() - machine.wait_for_unit("multi-user.target") - machine.succeed("nixos-generate-config") + system.nixos-generate-config.desktopConfiguration = [ + '' + # DESKTOP + services.xserver.displayManager.gdm.enable = true; + services.xserver.desktopManager.gnome.enable = true; + '' + ]; + }; + testScript = '' + start_all() + machine.wait_for_unit("multi-user.target") + machine.succeed("nixos-generate-config") - # Test if the configuration really is overridden - machine.succeed("grep 'OVERRIDDEN' /etc/nixos/configuration.nix") + # Test if the configuration really is overridden + machine.succeed("grep 'OVERRIDDEN' /etc/nixos/configuration.nix") - # Test if desktop configuration really is overridden - machine.succeed("grep 'DESKTOP' /etc/nixos/configuration.nix") + # Test if desktop configuration really is overridden + machine.succeed("grep 'DESKTOP' /etc/nixos/configuration.nix") - # Test of if the Perl variable $bootLoaderConfig is spliced correctly: - machine.succeed( - "grep 'boot\\.loader\\.grub\\.enable = true;' /etc/nixos/configuration.nix" - ) + # Test of if the Perl variable $bootLoaderConfig is spliced correctly: + machine.succeed( + "grep 'boot\\.loader\\.grub\\.enable = true;' /etc/nixos/configuration.nix" + ) - # Test if the Perl variable $desktopConfiguration is spliced correctly - machine.succeed( - "grep 'services\\.xserver\\.desktopManager\\.gnome\\.enable = true;' /etc/nixos/configuration.nix" - ) - ''; -}) + # Test if the Perl variable $desktopConfiguration is spliced correctly + machine.succeed( + "grep 'services\\.xserver\\.desktopManager\\.gnome\\.enable = true;' /etc/nixos/configuration.nix" + ) + ''; + } +) diff --git a/nixos/tests/nixos-test-driver/busybox.nix b/nixos/tests/nixos-test-driver/busybox.nix index 426f4494436e2f..935945a3c6f147 100644 --- a/nixos/tests/nixos-test-driver/busybox.nix +++ b/nixos/tests/nixos-test-driver/busybox.nix @@ -2,11 +2,14 @@ name = "Test that basic tests work when busybox is installed"; nodes = { - machine = ({ pkgs, ... }: { - environment.systemPackages = [ - pkgs.busybox - ]; - }); + machine = ( + { pkgs, ... }: + { + environment.systemPackages = [ + pkgs.busybox + ]; + } + ); }; testScript = '' diff --git a/nixos/tests/nixos-test-driver/extra-python-packages.nix b/nixos/tests/nixos-test-driver/extra-python-packages.nix index 1146bedd996f80..6c187e60559130 100644 --- a/nixos/tests/nixos-test-driver/extra-python-packages.nix +++ b/nixos/tests/nixos-test-driver/extra-python-packages.nix @@ -1,4 +1,5 @@ -import ../make-test-python.nix ({ ... }: +import ../make-test-python.nix ( + { ... }: { name = "extra-python-packages"; @@ -10,4 +11,5 @@ import ../make-test-python.nix ({ ... }: import numpy as np assert str(np.zeros(4) == "array([0., 0., 0., 0.])") ''; - }) + } +) diff --git a/nixos/tests/nixos-test-driver/lib-extend.nix b/nixos/tests/nixos-test-driver/lib-extend.nix index 4fb7cf494aed60..31ec2db9dfc6a1 100644 --- a/nixos/tests/nixos-test-driver/lib-extend.nix +++ b/nixos/tests/nixos-test-driver/lib-extend.nix @@ -1,19 +1,25 @@ { pkgs, ... }: let - patchedPkgs = pkgs.extend (new: old: { - lib = old.lib.extend (self: super: { - sorry_dave = "sorry dave"; - }); - }); + patchedPkgs = pkgs.extend ( + new: old: { + lib = old.lib.extend ( + self: super: { + sorry_dave = "sorry dave"; + } + ); + } + ); testBody = { name = "demo lib overlay"; nodes = { - machine = { lib, ... }: { - environment.etc."got-lib-overlay".text = lib.sorry_dave; - }; + machine = + { lib, ... }: + { + environment.etc."got-lib-overlay".text = lib.sorry_dave; + }; }; # We don't need to run an actual test. Instead we build the `machine` configuration @@ -25,7 +31,8 @@ let inherit (patchedPkgs.testers) nixosTest runNixOSTest; evaluationNixosTest = nixosTest testBody; evaluationRunNixOSTest = runNixOSTest testBody; -in { +in +{ nixosTest = evaluationNixosTest.driver.nodes.machine.system.build.toplevel; runNixOSTest = evaluationRunNixOSTest.driver.nodes.machine.system.build.toplevel; } diff --git a/nixos/tests/nixos-test-driver/timeout.nix b/nixos/tests/nixos-test-driver/timeout.nix index 29bd85d2498ea7..d793f29be9207a 100644 --- a/nixos/tests/nixos-test-driver/timeout.nix +++ b/nixos/tests/nixos-test-driver/timeout.nix @@ -3,8 +3,11 @@ globalTimeout = 5; nodes = { - machine = ({ pkgs, ... }: { - }); + machine = ( + { pkgs, ... }: + { + } + ); }; testScript = '' diff --git a/nixos/tests/nixseparatedebuginfod.nix b/nixos/tests/nixseparatedebuginfod.nix index 7c192a73c70642..bb9f8c9f43bee0 100644 --- a/nixos/tests/nixseparatedebuginfod.nix +++ b/nixos/tests/nixseparatedebuginfod.nix @@ -1,80 +1,84 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - secret-key = "key-name:/COlMSRbehSh6YSruJWjL+R0JXQUKuPEn96fIb+pLokEJUjcK/2Gv8Ai96D7JGay5gDeUTx5wdpPgNvum9YtwA=="; - public-key = "key-name:BCVI3Cv9hr/AIveg+yRmsuYA3lE8ecHaT4Db7pvWLcA="; -in -{ - name = "nixseparatedebuginfod"; - /* A binary cache with debug info and source for nix */ - nodes.cache = { pkgs, ... }: { - services.nix-serve = { - enable = true; - secretKeyFile = builtins.toFile "secret-key" secret-key; - openFirewall = true; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + secret-key = "key-name:/COlMSRbehSh6YSruJWjL+R0JXQUKuPEn96fIb+pLokEJUjcK/2Gv8Ai96D7JGay5gDeUTx5wdpPgNvum9YtwA=="; + public-key = "key-name:BCVI3Cv9hr/AIveg+yRmsuYA3lE8ecHaT4Db7pvWLcA="; + in + { + name = "nixseparatedebuginfod"; + # A binary cache with debug info and source for nix + nodes.cache = + { pkgs, ... }: + { + services.nix-serve = { + enable = true; + secretKeyFile = builtins.toFile "secret-key" secret-key; + openFirewall = true; + }; + system.extraDependencies = [ + pkgs.nix.debug + pkgs.nix.src + pkgs.sl + ]; + }; + # the machine where we need the debuginfo + nodes.machine = { + imports = [ + ../modules/installer/cd-dvd/channel.nix + ]; + services.nixseparatedebuginfod.enable = true; + nix.settings = { + substituters = lib.mkForce [ "http://cache:5000" ]; + trusted-public-keys = [ public-key ]; + }; + environment.systemPackages = [ + pkgs.valgrind + pkgs.gdb + (pkgs.writeShellScriptBin "wait_for_indexation" '' + set -x + while debuginfod-find debuginfo /run/current-system/sw/bin/nix |& grep 'File too large'; do + sleep 1; + done + '') + ]; }; - system.extraDependencies = [ - pkgs.nix.debug - pkgs.nix.src - pkgs.sl - ]; - }; - /* the machine where we need the debuginfo */ - nodes.machine = { - imports = [ - ../modules/installer/cd-dvd/channel.nix - ]; - services.nixseparatedebuginfod.enable = true; - nix.settings = { - substituters = lib.mkForce [ "http://cache:5000" ]; - trusted-public-keys = [ public-key ]; - }; - environment.systemPackages = [ - pkgs.valgrind - pkgs.gdb - (pkgs.writeShellScriptBin "wait_for_indexation" '' - set -x - while debuginfod-find debuginfo /run/current-system/sw/bin/nix |& grep 'File too large'; do - sleep 1; - done - '') - ]; - }; - testScript = '' - start_all() - cache.wait_for_unit("nix-serve.service") - cache.wait_for_open_port(5000) - machine.wait_for_unit("nixseparatedebuginfod.service") - machine.wait_for_open_port(1949) + testScript = '' + start_all() + cache.wait_for_unit("nix-serve.service") + cache.wait_for_open_port(5000) + machine.wait_for_unit("nixseparatedebuginfod.service") + machine.wait_for_open_port(1949) - with subtest("show the config to debug the test"): - machine.succeed("nix --extra-experimental-features nix-command show-config |& logger") - machine.succeed("cat /etc/nix/nix.conf |& logger") - with subtest("check that the binary cache works"): - machine.succeed("nix-store -r ${pkgs.sl}") + with subtest("show the config to debug the test"): + machine.succeed("nix --extra-experimental-features nix-command show-config |& logger") + machine.succeed("cat /etc/nix/nix.conf |& logger") + with subtest("check that the binary cache works"): + machine.succeed("nix-store -r ${pkgs.sl}") - # nixseparatedebuginfod needs .drv to associate executable -> source - # on regular systems this would be provided by nixos-rebuild - machine.succeed("nix-instantiate '<nixpkgs>' -A nix") + # nixseparatedebuginfod needs .drv to associate executable -> source + # on regular systems this would be provided by nixos-rebuild + machine.succeed("nix-instantiate '<nixpkgs>' -A nix") - machine.succeed("timeout 600 wait_for_indexation") + machine.succeed("timeout 600 wait_for_indexation") - # test debuginfod-find - machine.succeed("debuginfod-find debuginfo /run/current-system/sw/bin/nix") + # test debuginfod-find + machine.succeed("debuginfod-find debuginfo /run/current-system/sw/bin/nix") - # test that gdb can fetch source - out = machine.succeed("gdb /run/current-system/sw/bin/nix --batch -x ${builtins.toFile "commands" '' - start - l - ''}") - print(out) - assert 'int main(' in out + # test that gdb can fetch source + out = machine.succeed("gdb /run/current-system/sw/bin/nix --batch -x ${builtins.toFile "commands" '' + start + l + ''}") + print(out) + assert 'int main(' in out - # test that valgrind can display location information - # this relies on the fact that valgrind complains about nix - # libgc helps in this regard, and we also ask valgrind to show leak kinds - # which are usually false positives. - out = machine.succeed("valgrind --leak-check=full --show-leak-kinds=all nix-env --version 2>&1") - print(out) - assert 'main.cc' in out - ''; -}) + # test that valgrind can display location information + # this relies on the fact that valgrind complains about nix + # libgc helps in this regard, and we also ask valgrind to show leak kinds + # which are usually false positives. + out = machine.succeed("valgrind --leak-check=full --show-leak-kinds=all nix-env --version 2>&1") + print(out) + assert 'main.cc' in out + ''; + } +) diff --git a/nixos/tests/node-red.nix b/nixos/tests/node-red.nix index 5f5960d6829599..bb95246367c841 100644 --- a/nixos/tests/node-red.nix +++ b/nixos/tests/node-red.nix @@ -1,31 +1,38 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "nodered"; - meta = with pkgs.lib.maintainers; { - maintainers = [ matthewcroughan ]; - }; - - nodes = { - client = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.curl ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "nodered"; + meta = with pkgs.lib.maintainers; { + maintainers = [ matthewcroughan ]; }; - nodered = { config, pkgs, ... }: { - services.node-red = { - enable = true; - openFirewall = true; - }; + + nodes = { + client = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.curl ]; + }; + nodered = + { config, pkgs, ... }: + { + services.node-red = { + enable = true; + openFirewall = true; + }; + }; }; - }; - testScript = '' - start_all() - nodered.wait_for_unit("node-red.service") - nodered.wait_for_open_port(1880) + testScript = '' + start_all() + nodered.wait_for_unit("node-red.service") + nodered.wait_for_open_port(1880) - client.wait_for_unit("multi-user.target") + client.wait_for_unit("multi-user.target") - with subtest("Check that the Node-RED webserver can be reached."): - assert "<title>Node-RED" in client.succeed( - "curl -sSf http:/nodered:1880/ | grep title" - ) - ''; -}) + with subtest("Check that the Node-RED webserver can be reached."): + assert "Node-RED" in client.succeed( + "curl -sSf http:/nodered:1880/ | grep title" + ) + ''; + } +) diff --git a/nixos/tests/nomad.nix b/nixos/tests/nomad.nix index 51b11a8fef909e..ee94b5301d0efc 100644 --- a/nixos/tests/nomad.nix +++ b/nixos/tests/nomad.nix @@ -1,72 +1,79 @@ import ./make-test-python.nix ( - { lib, ... }: { + { lib, ... }: + { name = "nomad"; nodes = { - default_server = { pkgs, lib, ... }: { - networking = { - interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [{ - address = "192.168.1.1"; - prefixLength = 16; - }]; - }; + default_server = + { pkgs, lib, ... }: + { + networking = { + interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [ + { + address = "192.168.1.1"; + prefixLength = 16; + } + ]; + }; - environment.etc."nomad.custom.json".source = - (pkgs.formats.json { }).generate "nomad.custom.json" { + environment.etc."nomad.custom.json".source = (pkgs.formats.json { }).generate "nomad.custom.json" { region = "universe"; datacenter = "earth"; }; - services.nomad = { - enable = true; + services.nomad = { + enable = true; - settings = { - server = { - enabled = true; - bootstrap_expect = 1; + settings = { + server = { + enabled = true; + bootstrap_expect = 1; + }; }; - }; - extraSettingsPaths = [ "/etc/nomad.custom.json" ]; - enableDocker = false; - }; - }; - - custom_state_dir_server = { pkgs, lib, ... }: { - networking = { - interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [{ - address = "192.168.1.1"; - prefixLength = 16; - }]; + extraSettingsPaths = [ "/etc/nomad.custom.json" ]; + enableDocker = false; + }; }; - environment.etc."nomad.custom.json".source = - (pkgs.formats.json { }).generate "nomad.custom.json" { + custom_state_dir_server = + { pkgs, lib, ... }: + { + networking = { + interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [ + { + address = "192.168.1.1"; + prefixLength = 16; + } + ]; + }; + + environment.etc."nomad.custom.json".source = (pkgs.formats.json { }).generate "nomad.custom.json" { region = "universe"; datacenter = "earth"; }; - services.nomad = { - enable = true; - dropPrivileges = false; + services.nomad = { + enable = true; + dropPrivileges = false; - settings = { - data_dir = "/nomad/data/dir"; - server = { - enabled = true; - bootstrap_expect = 1; + settings = { + data_dir = "/nomad/data/dir"; + server = { + enabled = true; + bootstrap_expect = 1; + }; }; - }; - extraSettingsPaths = [ "/etc/nomad.custom.json" ]; - enableDocker = false; - }; + extraSettingsPaths = [ "/etc/nomad.custom.json" ]; + enableDocker = false; + }; - systemd.services.nomad.serviceConfig.ExecStartPre = "${pkgs.writeShellScript "mk_data_dir" '' - set -euxo pipefail + systemd.services.nomad.serviceConfig.ExecStartPre = "${pkgs.writeShellScript "mk_data_dir" '' + set -euxo pipefail - ${pkgs.coreutils}/bin/mkdir -p /nomad/data/dir - ''}"; - }; + ${pkgs.coreutils}/bin/mkdir -p /nomad/data/dir + ''}"; + }; }; testScript = '' diff --git a/nixos/tests/non-default-filesystems.nix b/nixos/tests/non-default-filesystems.nix index 98abe1cbc17576..11bf2070464f79 100644 --- a/nixos/tests/non-default-filesystems.nix +++ b/nixos/tests/non-default-filesystems.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -9,84 +10,90 @@ with pkgs.lib; bind = makeTest { name = "non-default-filesystem-bind"; - nodes.machine = { ... }: { - virtualisation.writableStore = false; + nodes.machine = + { ... }: + { + virtualisation.writableStore = false; - virtualisation.fileSystems."/test-bind-dir/bind" = { - device = "/"; - neededForBoot = true; - options = [ "bind" ]; - }; + virtualisation.fileSystems."/test-bind-dir/bind" = { + device = "/"; + neededForBoot = true; + options = [ "bind" ]; + }; - virtualisation.fileSystems."/test-bind-file/bind" = { - depends = [ "/nix/store" ]; - device = builtins.toFile "empty" ""; - neededForBoot = true; - options = [ "bind" ]; + virtualisation.fileSystems."/test-bind-file/bind" = { + depends = [ "/nix/store" ]; + device = builtins.toFile "empty" ""; + neededForBoot = true; + options = [ "bind" ]; + }; }; - }; testScript = '' machine.wait_for_unit("multi-user.target") ''; }; - btrfs = makeTest - { - name = "non-default-filesystems-btrfs"; - - nodes.machine = - { config, pkgs, lib, ... }: - let - disk = config.virtualisation.rootDevice; - in - { - virtualisation.rootDevice = "/dev/vda"; - virtualisation.useDefaultFilesystems = false; - - boot.initrd.availableKernelModules = [ "btrfs" ]; - boot.supportedFilesystems = [ "btrfs" ]; - - boot.initrd.postDeviceCommands = '' - FSTYPE=$(blkid -o value -s TYPE ${disk} || true) - if test -z "$FSTYPE"; then - modprobe btrfs - ${pkgs.btrfs-progs}/bin/mkfs.btrfs ${disk} - - mkdir /nixos - mount -t btrfs ${disk} /nixos - - ${pkgs.btrfs-progs}/bin/btrfs subvolume create /nixos/root - ${pkgs.btrfs-progs}/bin/btrfs subvolume create /nixos/home - - umount /nixos - fi - ''; - - virtualisation.fileSystems = { - "/" = { - device = disk; - fsType = "btrfs"; - options = [ "subvol=/root" ]; - }; - - "/home" = { - device = disk; - fsType = "btrfs"; - options = [ "subvol=/home" ]; - }; + btrfs = makeTest { + name = "non-default-filesystems-btrfs"; + + nodes.machine = + { + config, + pkgs, + lib, + ... + }: + let + disk = config.virtualisation.rootDevice; + in + { + virtualisation.rootDevice = "/dev/vda"; + virtualisation.useDefaultFilesystems = false; + + boot.initrd.availableKernelModules = [ "btrfs" ]; + boot.supportedFilesystems = [ "btrfs" ]; + + boot.initrd.postDeviceCommands = '' + FSTYPE=$(blkid -o value -s TYPE ${disk} || true) + if test -z "$FSTYPE"; then + modprobe btrfs + ${pkgs.btrfs-progs}/bin/mkfs.btrfs ${disk} + + mkdir /nixos + mount -t btrfs ${disk} /nixos + + ${pkgs.btrfs-progs}/bin/btrfs subvolume create /nixos/root + ${pkgs.btrfs-progs}/bin/btrfs subvolume create /nixos/home + + umount /nixos + fi + ''; + + virtualisation.fileSystems = { + "/" = { + device = disk; + fsType = "btrfs"; + options = [ "subvol=/root" ]; + }; + + "/home" = { + device = disk; + fsType = "btrfs"; + options = [ "subvol=/home" ]; }; }; + }; - testScript = '' - machine.wait_for_unit("multi-user.target") + testScript = '' + machine.wait_for_unit("multi-user.target") - with subtest("BTRFS filesystems are mounted correctly"): - print("output of \"grep -E '/dev/vda' /proc/mounts\":\n" + machine.execute("grep -E '/dev/vda' /proc/mounts")[1]) - machine.succeed("grep -E '/dev/vda / btrfs rw,.*subvolid=[0-9]+,subvol=/root 0 0' /proc/mounts") - machine.succeed("grep -E '/dev/vda /home btrfs rw,.*subvolid=[0-9]+,subvol=/home 0 0' /proc/mounts") - ''; - }; + with subtest("BTRFS filesystems are mounted correctly"): + print("output of \"grep -E '/dev/vda' /proc/mounts\":\n" + machine.execute("grep -E '/dev/vda' /proc/mounts")[1]) + machine.succeed("grep -E '/dev/vda / btrfs rw,.*subvolid=[0-9]+,subvol=/root 0 0' /proc/mounts") + machine.succeed("grep -E '/dev/vda /home btrfs rw,.*subvolid=[0-9]+,subvol=/home 0 0' /proc/mounts") + ''; + }; erofs = let @@ -98,10 +105,12 @@ with pkgs.lib; meta.maintainers = with maintainers; [ nikstur ]; nodes.machine = _: { - virtualisation.qemu.drives = [{ - name = "non-default-filesystem"; - file = fsImage; - }]; + virtualisation.qemu.drives = [ + { + name = "non-default-filesystem"; + file = fsImage; + } + ]; virtualisation.fileSystems."/non-default" = { device = "/dev/vdb"; @@ -142,11 +151,13 @@ with pkgs.lib; meta.maintainers = with maintainers; [ nikstur ]; nodes.machine = { - virtualisation.qemu.drives = [{ - name = "non-default-filesystem"; - file = fsImage; - deviceExtraOpts.serial = "non-default"; - }]; + virtualisation.qemu.drives = [ + { + name = "non-default-filesystem"; + file = fsImage; + deviceExtraOpts.serial = "non-default"; + } + ]; virtualisation.fileSystems."/non-default" = { device = "/dev/disk/by-id/virtio-non-default"; diff --git a/nixos/tests/noto-fonts-cjk-qt-default-weight.nix b/nixos/tests/noto-fonts-cjk-qt-default-weight.nix index c2e0cb3adaebdd..44d9cf8083c18e 100644 --- a/nixos/tests/noto-fonts-cjk-qt-default-weight.nix +++ b/nixos/tests/noto-fonts-cjk-qt-default-weight.nix @@ -1,30 +1,37 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "noto-fonts-cjk-qt"; - meta.maintainers = with lib.maintainers; [ oxalica ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "noto-fonts-cjk-qt"; + meta.maintainers = with lib.maintainers; [ oxalica ]; - nodes.machine = { - imports = [ ./common/x11.nix ]; - fonts = { - enableDefaultPackages = false; - fonts = [ pkgs.noto-fonts-cjk-sans ]; + nodes.machine = { + imports = [ ./common/x11.nix ]; + fonts = { + enableDefaultPackages = false; + fonts = [ pkgs.noto-fonts-cjk-sans ]; + }; }; - }; - testScript = - let - script = pkgs.writers.writePython3 "qt-default-weight" { - libraries = [ pkgs.python3Packages.pyqt6 ]; - } '' - from PyQt6.QtWidgets import QApplication - from PyQt6.QtGui import QFont, QRawFont + testScript = + let + script = + pkgs.writers.writePython3 "qt-default-weight" + { + libraries = [ pkgs.python3Packages.pyqt6 ]; + } + '' + from PyQt6.QtWidgets import QApplication + from PyQt6.QtGui import QFont, QRawFont - app = QApplication([]) - f = QRawFont.fromFont(QFont("Noto Sans CJK SC", 20)) + app = QApplication([]) + f = QRawFont.fromFont(QFont("Noto Sans CJK SC", 20)) - assert f.styleName() == "Regular", f.styleName() + assert f.styleName() == "Regular", f.styleName() + ''; + in + '' + machine.wait_for_x() + machine.succeed("${script}") ''; - in '' - machine.wait_for_x() - machine.succeed("${script}") - ''; -}) + } +) diff --git a/nixos/tests/noto-fonts.nix b/nixos/tests/noto-fonts.nix index b871f5f5172941..2d204131dcf9a0 100644 --- a/nixos/tests/noto-fonts.nix +++ b/nixos/tests/noto-fonts.nix @@ -1,42 +1,59 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "noto-fonts"; - meta.maintainers = with lib.maintainers; [ nickcao midchildan ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "noto-fonts"; + meta.maintainers = with lib.maintainers; [ + nickcao + midchildan + ]; - nodes.machine = { - imports = [ ./common/x11.nix ]; - environment.systemPackages = [ pkgs.gedit ]; - fonts = { - enableDefaultPackages = false; - fonts = with pkgs;[ - noto-fonts - noto-fonts-cjk-sans - noto-fonts-cjk-serif - noto-fonts-color-emoji - ]; - fontconfig.defaultFonts = { - serif = [ "Noto Serif" "Noto Serif CJK SC" ]; - sansSerif = [ "Noto Sans" "Noto Sans CJK SC" ]; - monospace = [ "Noto Sans Mono" "Noto Sans Mono CJK SC" ]; - emoji = [ "Noto Color Emoji" ]; + nodes.machine = { + imports = [ ./common/x11.nix ]; + environment.systemPackages = [ pkgs.gedit ]; + fonts = { + enableDefaultPackages = false; + fonts = with pkgs; [ + noto-fonts + noto-fonts-cjk-sans + noto-fonts-cjk-serif + noto-fonts-color-emoji + ]; + fontconfig.defaultFonts = { + serif = [ + "Noto Serif" + "Noto Serif CJK SC" + ]; + sansSerif = [ + "Noto Sans" + "Noto Sans CJK SC" + ]; + monospace = [ + "Noto Sans Mono" + "Noto Sans Mono CJK SC" + ]; + emoji = [ "Noto Color Emoji" ]; + }; }; }; - }; - testScript = - # extracted from http://www.clagnut.com/blog/2380/ - let testText = builtins.toFile "test.txt" '' - the quick brown fox jumps over the lazy dog - 視野無限廣,窗外有藍天 - Eĥoŝanĝo ĉiuĵaŭde. - いろはにほへと ちりぬるを わかよたれそ つねならむ うゐのおくやま けふこえて あさきゆめみし ゑひもせす - 다람쥐 헌 쳇바퀴에 타고파 - 中国智造,慧及全球 - ''; in - '' - machine.wait_for_x() - machine.succeed("gedit ${testText} >&2 &") - machine.wait_for_window(".* - gedit") - machine.sleep(10) - machine.screenshot("screen") - ''; -}) + testScript = + # extracted from http://www.clagnut.com/blog/2380/ + let + testText = builtins.toFile "test.txt" '' + the quick brown fox jumps over the lazy dog + 視野無限廣,窗外有藍天 + Eĥoŝanĝo ĉiuĵaŭde. + いろはにほへと ちりぬるを わかよたれそ つねならむ うゐのおくやま けふこえて あさきゆめみし ゑひもせす + 다람쥐 헌 쳇바퀴에 타고파 + 中国智造,慧及全球 + ''; + in + '' + machine.wait_for_x() + machine.succeed("gedit ${testText} >&2 &") + machine.wait_for_window(".* - gedit") + machine.sleep(10) + machine.screenshot("screen") + ''; + } +) diff --git a/nixos/tests/novacomd.nix b/nixos/tests/novacomd.nix index d47d212fb2ecaf..2bbe3005605551 100644 --- a/nixos/tests/novacomd.nix +++ b/nixos/tests/novacomd.nix @@ -1,28 +1,33 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "novacomd"; - meta = with pkgs.lib.maintainers; { - maintainers = [ dtzWill ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "novacomd"; + meta = with pkgs.lib.maintainers; { + maintainers = [ dtzWill ]; + }; - nodes.machine = { ... }: { - services.novacomd.enable = true; - }; + nodes.machine = + { ... }: + { + services.novacomd.enable = true; + }; - testScript = '' - machine.wait_for_unit("novacomd.service") + testScript = '' + machine.wait_for_unit("novacomd.service") - with subtest("Make sure the daemon is really listening"): - machine.wait_for_open_port(6968) - machine.succeed("novacom -l") + with subtest("Make sure the daemon is really listening"): + machine.wait_for_open_port(6968) + machine.succeed("novacom -l") - with subtest("Stop the daemon, double-check novacom fails if daemon isn't working"): - machine.stop_job("novacomd") - machine.fail("novacom -l") + with subtest("Stop the daemon, double-check novacom fails if daemon isn't working"): + machine.stop_job("novacomd") + machine.fail("novacom -l") - with subtest("Make sure the daemon starts back up again"): - machine.start_job("novacomd") - # make sure the daemon is really listening - machine.wait_for_open_port(6968) - machine.succeed("novacom -l") - ''; -}) + with subtest("Make sure the daemon starts back up again"): + machine.start_job("novacomd") + # make sure the daemon is really listening + machine.wait_for_open_port(6968) + machine.succeed("novacom -l") + ''; + } +) diff --git a/nixos/tests/npmrc.nix b/nixos/tests/npmrc.nix index dbf24d372feb4a..0377124433f99d 100644 --- a/nixos/tests/npmrc.nix +++ b/nixos/tests/npmrc.nix @@ -1,22 +1,24 @@ -import ./make-test-python.nix ({ ... }: -let - machineName = "machine"; - settingName = "prefix"; - settingValue = "/some/path"; -in -{ - name = "npmrc"; +import ./make-test-python.nix ( + { ... }: + let + machineName = "machine"; + settingName = "prefix"; + settingValue = "/some/path"; + in + { + name = "npmrc"; - nodes."${machineName}".programs.npm = { - enable = true; - npmrc = '' - ${settingName} = ${settingValue} - ''; - }; + nodes."${machineName}".programs.npm = { + enable = true; + npmrc = '' + ${settingName} = ${settingValue} + ''; + }; - testScript = '' - ${machineName}.start() + testScript = '' + ${machineName}.start() - assert ${machineName}.succeed("npm config get ${settingName}") == "${settingValue}\n" - ''; -}) + assert ${machineName}.succeed("npm config get ${settingName}") == "${settingValue}\n" + ''; + } +) diff --git a/nixos/tests/nscd.nix b/nixos/tests/nscd.nix index 356c6d2e2a5401..393c97f6109530 100644 --- a/nixos/tests/nscd.nix +++ b/nixos/tests/nscd.nix @@ -1,142 +1,151 @@ -import ./make-test-python.nix ({ pkgs, ... }: -let - # build a getent that itself doesn't see anything in /etc/hosts and - # /etc/nsswitch.conf, by using libredirect to steer its own requests to - # /dev/null. - # This means is /has/ to go via nscd to actuallly resolve any of the - # additionally configured hosts. - getent' = pkgs.writeScript "getent-without-etc-hosts" '' - export NIX_REDIRECTS=/etc/hosts=/dev/null:/etc/nsswitch.conf=/dev/null - export LD_PRELOAD=${pkgs.libredirect}/lib/libredirect.so - exec getent $@ - ''; -in -{ - name = "nscd"; - - nodes.machine = { pkgs, ... }: { - imports = [ common/user-account.nix ]; - networking.extraHosts = '' - 2001:db8::1 somehost.test - 192.0.2.1 somehost.test +import ./make-test-python.nix ( + { pkgs, ... }: + let + # build a getent that itself doesn't see anything in /etc/hosts and + # /etc/nsswitch.conf, by using libredirect to steer its own requests to + # /dev/null. + # This means is /has/ to go via nscd to actuallly resolve any of the + # additionally configured hosts. + getent' = pkgs.writeScript "getent-without-etc-hosts" '' + export NIX_REDIRECTS=/etc/hosts=/dev/null:/etc/nsswitch.conf=/dev/null + export LD_PRELOAD=${pkgs.libredirect}/lib/libredirect.so + exec getent $@ ''; - - systemd.services.sockdump = { - wantedBy = [ "multi-user.target" ]; - path = [ - # necessary for bcc to unpack kernel headers and invoke modprobe - pkgs.gnutar - pkgs.xz.bin - pkgs.kmod - ]; - environment.PYTHONUNBUFFERED = "1"; - - serviceConfig = { - ExecStart = "${pkgs.sockdump}/bin/sockdump /var/run/nscd/socket"; - Restart = "on-failure"; - RestartSec = "1"; - Type = "simple"; + in + { + name = "nscd"; + + nodes.machine = + { pkgs, ... }: + { + imports = [ common/user-account.nix ]; + networking.extraHosts = '' + 2001:db8::1 somehost.test + 192.0.2.1 somehost.test + ''; + + systemd.services.sockdump = { + wantedBy = [ "multi-user.target" ]; + path = [ + # necessary for bcc to unpack kernel headers and invoke modprobe + pkgs.gnutar + pkgs.xz.bin + pkgs.kmod + ]; + environment.PYTHONUNBUFFERED = "1"; + + serviceConfig = { + ExecStart = "${pkgs.sockdump}/bin/sockdump /var/run/nscd/socket"; + Restart = "on-failure"; + RestartSec = "1"; + Type = "simple"; + }; + }; + + specialisation = { + withGlibcNscd.configuration = + { ... }: + { + services.nscd.enableNsncd = false; + }; + withUnscd.configuration = + { ... }: + { + services.nscd.enableNsncd = false; + services.nscd.package = pkgs.unscd; + }; + }; }; - }; - specialisation = { - withGlibcNscd.configuration = { ... }: { - services.nscd.enableNsncd = false; - }; - withUnscd.configuration = { ... }: { - services.nscd.enableNsncd = false; - services.nscd.package = pkgs.unscd; - }; - }; - }; - - testScript = { nodes, ... }: - let - specialisations = "${nodes.machine.system.build.toplevel}/specialisation"; - in - '' - # Regression test for https://github.com/NixOS/nixpkgs/issues/50273 - def test_dynamic_user(): - with subtest("DynamicUser actually allocates a user"): - assert "iamatest" in machine.succeed( - "systemd-run --pty --property=Type=oneshot --property=DynamicUser=yes --property=User=iamatest whoami" - ) - - # Test resolution of somehost.test with getent', to make sure we go via - # nscd protocol - def test_host_lookups(): - with subtest("host lookups via nscd protocol"): - # ahosts - output = machine.succeed("${getent'} ahosts somehost.test") - assert "192.0.2.1" in output - assert "2001:db8::1" in output - - # ahostsv4 - output = machine.succeed("${getent'} ahostsv4 somehost.test") - assert "192.0.2.1" in output - assert "2001:db8::1" not in output - - # ahostsv6 - output = machine.succeed("${getent'} ahostsv6 somehost.test") - assert "192.0.2.1" not in output - assert "2001:db8::1" in output - - # reverse lookups (hosts) - assert "somehost.test" in machine.succeed("${getent'} hosts 2001:db8::1") - assert "somehost.test" in machine.succeed("${getent'} hosts 192.0.2.1") - - - # Test host resolution via nss modules works - # We rely on nss-myhostname in this case, which resolves *.localhost and - # _gateway. - # We don't need to use getent' here, as non-glibc nss modules can only be - # discovered via nscd. - def test_nss_myhostname(): - with subtest("nss-myhostname provides hostnames (ahosts)"): - # ahosts - output = machine.succeed("getent ahosts foobar.localhost") - assert "::1" in output - assert "127.0.0.1" in output - - # ahostsv4 - output = machine.succeed("getent ahostsv4 foobar.localhost") - assert "::1" not in output - assert "127.0.0.1" in output - - # ahostsv6 - output = machine.succeed("getent ahostsv6 foobar.localhost") - assert "::1" in output - assert "127.0.0.1" not in output - - start_all() - machine.wait_for_unit("default.target") - - # give sockdump some time to finish attaching. - machine.sleep(5) - - # Test all tests with glibc-nscd. - test_dynamic_user() - test_host_lookups() - test_nss_myhostname() - - with subtest("glibc-nscd"): - machine.succeed('${specialisations}/withGlibcNscd/bin/switch-to-configuration test') - machine.wait_for_unit("default.target") - - test_dynamic_user() - test_host_lookups() - test_nss_myhostname() - - with subtest("unscd"): - machine.succeed('${specialisations}/withUnscd/bin/switch-to-configuration test') - machine.wait_for_unit("default.target") - - # known to fail, unscd doesn't load external NSS modules - # test_dynamic_user() - - test_host_lookups() - - # known to fail, unscd doesn't load external NSS modules - # test_nss_myhostname() - ''; -}) + testScript = + { nodes, ... }: + let + specialisations = "${nodes.machine.system.build.toplevel}/specialisation"; + in + '' + # Regression test for https://github.com/NixOS/nixpkgs/issues/50273 + def test_dynamic_user(): + with subtest("DynamicUser actually allocates a user"): + assert "iamatest" in machine.succeed( + "systemd-run --pty --property=Type=oneshot --property=DynamicUser=yes --property=User=iamatest whoami" + ) + + # Test resolution of somehost.test with getent', to make sure we go via + # nscd protocol + def test_host_lookups(): + with subtest("host lookups via nscd protocol"): + # ahosts + output = machine.succeed("${getent'} ahosts somehost.test") + assert "192.0.2.1" in output + assert "2001:db8::1" in output + + # ahostsv4 + output = machine.succeed("${getent'} ahostsv4 somehost.test") + assert "192.0.2.1" in output + assert "2001:db8::1" not in output + + # ahostsv6 + output = machine.succeed("${getent'} ahostsv6 somehost.test") + assert "192.0.2.1" not in output + assert "2001:db8::1" in output + + # reverse lookups (hosts) + assert "somehost.test" in machine.succeed("${getent'} hosts 2001:db8::1") + assert "somehost.test" in machine.succeed("${getent'} hosts 192.0.2.1") + + + # Test host resolution via nss modules works + # We rely on nss-myhostname in this case, which resolves *.localhost and + # _gateway. + # We don't need to use getent' here, as non-glibc nss modules can only be + # discovered via nscd. + def test_nss_myhostname(): + with subtest("nss-myhostname provides hostnames (ahosts)"): + # ahosts + output = machine.succeed("getent ahosts foobar.localhost") + assert "::1" in output + assert "127.0.0.1" in output + + # ahostsv4 + output = machine.succeed("getent ahostsv4 foobar.localhost") + assert "::1" not in output + assert "127.0.0.1" in output + + # ahostsv6 + output = machine.succeed("getent ahostsv6 foobar.localhost") + assert "::1" in output + assert "127.0.0.1" not in output + + start_all() + machine.wait_for_unit("default.target") + + # give sockdump some time to finish attaching. + machine.sleep(5) + + # Test all tests with glibc-nscd. + test_dynamic_user() + test_host_lookups() + test_nss_myhostname() + + with subtest("glibc-nscd"): + machine.succeed('${specialisations}/withGlibcNscd/bin/switch-to-configuration test') + machine.wait_for_unit("default.target") + + test_dynamic_user() + test_host_lookups() + test_nss_myhostname() + + with subtest("unscd"): + machine.succeed('${specialisations}/withUnscd/bin/switch-to-configuration test') + machine.wait_for_unit("default.target") + + # known to fail, unscd doesn't load external NSS modules + # test_dynamic_user() + + test_host_lookups() + + # known to fail, unscd doesn't load external NSS modules + # test_nss_myhostname() + ''; + } +) diff --git a/nixos/tests/nsd.nix b/nixos/tests/nsd.nix index eea5a82f6f927e..b77e28d8050437 100644 --- a/nixos/tests/nsd.nix +++ b/nixos/tests/nsd.nix @@ -1,109 +1,136 @@ let - common = { pkgs, ... }: { - networking.firewall.enable = false; - networking.useDHCP = false; - # for a host utility with IPv6 support - environment.systemPackages = [ pkgs.bind ]; - }; -in import ./make-test-python.nix ({ pkgs, ...} : { - name = "nsd"; - meta = with pkgs.lib.maintainers; { - maintainers = [ aszlig ]; - }; - - nodes = { - clientv4 = { lib, nodes, ... }: { - imports = [ common ]; - networking.nameservers = lib.mkForce [ - (lib.head nodes.server.config.networking.interfaces.eth1.ipv4.addresses).address - ]; - networking.interfaces.eth1.ipv4.addresses = [ - { address = "192.168.0.2"; prefixLength = 24; } - ]; + common = + { pkgs, ... }: + { + networking.firewall.enable = false; + networking.useDHCP = false; + # for a host utility with IPv6 support + environment.systemPackages = [ pkgs.bind ]; }; - - clientv6 = { lib, nodes, ... }: { - imports = [ common ]; - networking.nameservers = lib.mkForce [ - (lib.head nodes.server.config.networking.interfaces.eth1.ipv6.addresses).address - ]; - networking.interfaces.eth1.ipv4.addresses = [ - { address = "dead:beef::2"; prefixLength = 24; } - ]; +in +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "nsd"; + meta = with pkgs.lib.maintainers; { + maintainers = [ aszlig ]; }; - server = { lib, ... }: { - imports = [ common ]; - networking.interfaces.eth1.ipv4.addresses = [ - { address = "192.168.0.1"; prefixLength = 24; } - ]; - networking.interfaces.eth1.ipv6.addresses = [ - { address = "dead:beef::1"; prefixLength = 64; } - ]; - services.nsd.enable = true; - services.nsd.rootServer = true; - services.nsd.interfaces = lib.mkForce []; - services.nsd.keys."tsig.example.com." = { - algorithm = "hmac-sha256"; - keyFile = pkgs.writeTextFile { name = "tsig.example.com."; text = "aR3FJA92+bxRSyosadsJ8Aeeav5TngQW/H/EF9veXbc="; }; - }; - services.nsd.zones."example.com.".data = '' - @ SOA ns.example.com noc.example.com 666 7200 3600 1209600 3600 - ipv4 A 1.2.3.4 - ipv6 AAAA abcd::eeff - deleg NS ns.example.com - ns A 192.168.0.1 - ns AAAA dead:beef::1 - ''; - services.nsd.zones."example.com.".provideXFR = [ "0.0.0.0 tsig.example.com." ]; - services.nsd.zones."deleg.example.com.".data = '' - @ SOA ns.example.com noc.example.com 666 7200 3600 1209600 3600 - @ A 9.8.7.6 - @ AAAA fedc::bbaa - ''; - services.nsd.zones.".".data = '' - @ SOA ns.example.com noc.example.com 666 7200 3600 1209600 3600 - root A 1.8.7.4 - root AAAA acbd::4 - ''; + nodes = { + clientv4 = + { lib, nodes, ... }: + { + imports = [ common ]; + networking.nameservers = lib.mkForce [ + (lib.head nodes.server.config.networking.interfaces.eth1.ipv4.addresses).address + ]; + networking.interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.0.2"; + prefixLength = 24; + } + ]; + }; + + clientv6 = + { lib, nodes, ... }: + { + imports = [ common ]; + networking.nameservers = lib.mkForce [ + (lib.head nodes.server.config.networking.interfaces.eth1.ipv6.addresses).address + ]; + networking.interfaces.eth1.ipv4.addresses = [ + { + address = "dead:beef::2"; + prefixLength = 24; + } + ]; + }; + + server = + { lib, ... }: + { + imports = [ common ]; + networking.interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.0.1"; + prefixLength = 24; + } + ]; + networking.interfaces.eth1.ipv6.addresses = [ + { + address = "dead:beef::1"; + prefixLength = 64; + } + ]; + services.nsd.enable = true; + services.nsd.rootServer = true; + services.nsd.interfaces = lib.mkForce [ ]; + services.nsd.keys."tsig.example.com." = { + algorithm = "hmac-sha256"; + keyFile = pkgs.writeTextFile { + name = "tsig.example.com."; + text = "aR3FJA92+bxRSyosadsJ8Aeeav5TngQW/H/EF9veXbc="; + }; + }; + services.nsd.zones."example.com.".data = '' + @ SOA ns.example.com noc.example.com 666 7200 3600 1209600 3600 + ipv4 A 1.2.3.4 + ipv6 AAAA abcd::eeff + deleg NS ns.example.com + ns A 192.168.0.1 + ns AAAA dead:beef::1 + ''; + services.nsd.zones."example.com.".provideXFR = [ "0.0.0.0 tsig.example.com." ]; + services.nsd.zones."deleg.example.com.".data = '' + @ SOA ns.example.com noc.example.com 666 7200 3600 1209600 3600 + @ A 9.8.7.6 + @ AAAA fedc::bbaa + ''; + services.nsd.zones.".".data = '' + @ SOA ns.example.com noc.example.com 666 7200 3600 1209600 3600 + root A 1.8.7.4 + root AAAA acbd::4 + ''; + }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - clientv4.wait_for_unit("network.target") - clientv6.wait_for_unit("network.target") - server.wait_for_unit("nsd.service") + clientv4.wait_for_unit("network.target") + clientv6.wait_for_unit("network.target") + server.wait_for_unit("nsd.service") - with subtest("server tsig.example.com."): - expected_tsig = " secret: \"aR3FJA92+bxRSyosadsJ8Aeeav5TngQW/H/EF9veXbc=\"\n" - tsig=server.succeed("cat /var/lib/nsd/private/tsig.example.com.") - assert expected_tsig == tsig, f"Expected /var/lib/nsd/private/tsig.example.com. to contain '{expected_tsig}', but found '{tsig}'" + with subtest("server tsig.example.com."): + expected_tsig = " secret: \"aR3FJA92+bxRSyosadsJ8Aeeav5TngQW/H/EF9veXbc=\"\n" + tsig=server.succeed("cat /var/lib/nsd/private/tsig.example.com.") + assert expected_tsig == tsig, f"Expected /var/lib/nsd/private/tsig.example.com. to contain '{expected_tsig}', but found '{tsig}'" - def assert_host(type, rr, query, expected): - self = clientv4 if type == 4 else clientv6 - out = self.succeed(f"host -{type} -t {rr} {query}").rstrip() - self.log(f"output: {out}") - import re - assert re.search( - expected, out - ), f"DNS IPv{type} query on {query} gave '{out}' instead of '{expected}'" + def assert_host(type, rr, query, expected): + self = clientv4 if type == 4 else clientv6 + out = self.succeed(f"host -{type} -t {rr} {query}").rstrip() + self.log(f"output: {out}") + import re + assert re.search( + expected, out + ), f"DNS IPv{type} query on {query} gave '{out}' instead of '{expected}'" - for ipv in 4, 6: - with subtest(f"IPv{ipv}"): - assert_host(ipv, "a", "example.com", "has no [^ ]+ record") - assert_host(ipv, "aaaa", "example.com", "has no [^ ]+ record") + for ipv in 4, 6: + with subtest(f"IPv{ipv}"): + assert_host(ipv, "a", "example.com", "has no [^ ]+ record") + assert_host(ipv, "aaaa", "example.com", "has no [^ ]+ record") - assert_host(ipv, "soa", "example.com", "SOA.*?noc\.example\.com") - assert_host(ipv, "a", "ipv4.example.com", "address 1.2.3.4$") - assert_host(ipv, "aaaa", "ipv6.example.com", "address abcd::eeff$") + assert_host(ipv, "soa", "example.com", "SOA.*?noc\.example\.com") + assert_host(ipv, "a", "ipv4.example.com", "address 1.2.3.4$") + assert_host(ipv, "aaaa", "ipv6.example.com", "address abcd::eeff$") - assert_host(ipv, "a", "deleg.example.com", "address 9.8.7.6$") - assert_host(ipv, "aaaa", "deleg.example.com", "address fedc::bbaa$") + assert_host(ipv, "a", "deleg.example.com", "address 9.8.7.6$") + assert_host(ipv, "aaaa", "deleg.example.com", "address fedc::bbaa$") - assert_host(ipv, "a", "root", "address 1.8.7.4$") - assert_host(ipv, "aaaa", "root", "address acbd::4$") - ''; -}) + assert_host(ipv, "a", "root", "address 1.8.7.4$") + assert_host(ipv, "aaaa", "root", "address acbd::4$") + ''; + } +) diff --git a/nixos/tests/ntfy-sh-migration.nix b/nixos/tests/ntfy-sh-migration.nix index de6660052d6798..74ba58d98ebb7d 100644 --- a/nixos/tests/ntfy-sh-migration.nix +++ b/nixos/tests/ntfy-sh-migration.nix @@ -10,40 +10,42 @@ import ./make-test-python.nix { name = "ntfy-sh"; - nodes.machine = { - lib, - pkgs, - ... - }: { - environment.etc."ntfy-sh-dynamic-user.conf".text = '' - [Service] - Group=new-ntfy-sh - User=new-ntfy-sh - DynamicUser=true - ''; - - services.ntfy-sh.enable = true; - services.ntfy-sh.settings.base-url = "http://localhost:2586"; - - systemd.services.ntfy-sh.serviceConfig = { - DynamicUser = lib.mkForce false; - ExecStartPre = [ - "${pkgs.coreutils}/bin/id" - "${pkgs.coreutils}/bin/ls -lahd /var/lib/ntfy-sh/" - "${pkgs.coreutils}/bin/ls -lah /var/lib/ntfy-sh/" - ]; - Group = lib.mkForce "old-ntfy-sh"; - User = lib.mkForce "old-ntfy-sh"; + nodes.machine = + { + lib, + pkgs, + ... + }: + { + environment.etc."ntfy-sh-dynamic-user.conf".text = '' + [Service] + Group=new-ntfy-sh + User=new-ntfy-sh + DynamicUser=true + ''; + + services.ntfy-sh.enable = true; + services.ntfy-sh.settings.base-url = "http://localhost:2586"; + + systemd.services.ntfy-sh.serviceConfig = { + DynamicUser = lib.mkForce false; + ExecStartPre = [ + "${pkgs.coreutils}/bin/id" + "${pkgs.coreutils}/bin/ls -lahd /var/lib/ntfy-sh/" + "${pkgs.coreutils}/bin/ls -lah /var/lib/ntfy-sh/" + ]; + Group = lib.mkForce "old-ntfy-sh"; + User = lib.mkForce "old-ntfy-sh"; + }; + + users.users.old-ntfy-sh = { + isSystemUser = true; + group = "old-ntfy-sh"; + }; + + users.groups.old-ntfy-sh = { }; }; - users.users.old-ntfy-sh = { - isSystemUser = true; - group = "old-ntfy-sh"; - }; - - users.groups.old-ntfy-sh = {}; - }; - testScript = '' import json diff --git a/nixos/tests/ntfy-sh.nix b/nixos/tests/ntfy-sh.nix index ec2e645bacb5b9..b0dba5f0647bb5 100644 --- a/nixos/tests/ntfy-sh.nix +++ b/nixos/tests/ntfy-sh.nix @@ -1,10 +1,12 @@ import ./make-test-python.nix { name = "ntfy-sh"; - nodes.machine = { ... }: { - services.ntfy-sh.enable = true; - services.ntfy-sh.settings.base-url = "http://localhost:2586"; - }; + nodes.machine = + { ... }: + { + services.ntfy-sh.enable = true; + services.ntfy-sh.settings.base-url = "http://localhost:2586"; + }; testScript = '' import json diff --git a/nixos/tests/ntpd-rs.nix b/nixos/tests/ntpd-rs.nix index 6f3c80e87f072d..2907c755832409 100644 --- a/nixos/tests/ntpd-rs.nix +++ b/nixos/tests/ntpd-rs.nix @@ -1,51 +1,55 @@ -import ./make-test-python.nix ({ lib, ... }: -{ - name = "ntpd-rs"; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "ntpd-rs"; - meta = { - maintainers = with lib.maintainers; [ fpletz ]; - }; + meta = { + maintainers = with lib.maintainers; [ fpletz ]; + }; - nodes = { - client = { - services.ntpd-rs = { - enable = true; - metrics.enable = true; - useNetworkingTimeServers = false; - settings = { - source = [ - { - mode = "server"; - address = "server"; - } - ]; - synchronization = { - minimum-agreeing-sources = 1; + nodes = { + client = { + services.ntpd-rs = { + enable = true; + metrics.enable = true; + useNetworkingTimeServers = false; + settings = { + source = [ + { + mode = "server"; + address = "server"; + } + ]; + synchronization = { + minimum-agreeing-sources = 1; + }; }; }; }; - }; - server = { - networking.firewall.allowedUDPPorts = [ 123 ]; - services.ntpd-rs = { - enable = true; - metrics.enable = true; - settings = { - server = [ - { listen = "[::]:123"; } - ]; + server = { + networking.firewall.allowedUDPPorts = [ 123 ]; + services.ntpd-rs = { + enable = true; + metrics.enable = true; + settings = { + server = [ + { listen = "[::]:123"; } + ]; + }; }; }; }; - }; - testScript = { nodes, ... }: '' - start_all() + testScript = + { nodes, ... }: + '' + start_all() - for machine in (server, client): - machine.wait_for_unit('multi-user.target') - machine.succeed('systemctl is-active ntpd-rs.service') - machine.succeed('systemctl is-active ntpd-rs-metrics.service') - machine.succeed('curl http://localhost:9975/metrics | grep ntp_uptime_seconds') - ''; -}) + for machine in (server, client): + machine.wait_for_unit('multi-user.target') + machine.succeed('systemctl is-active ntpd-rs.service') + machine.succeed('systemctl is-active ntpd-rs-metrics.service') + machine.succeed('curl http://localhost:9975/metrics | grep ntp_uptime_seconds') + ''; + } +) diff --git a/nixos/tests/nvmetcfg.nix b/nixos/tests/nvmetcfg.nix index 169e5e9d7b0c9a..6f937251bb3533 100644 --- a/nixos/tests/nvmetcfg.nix +++ b/nixos/tests/nvmetcfg.nix @@ -1,43 +1,54 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "nvmetcfg"; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "nvmetcfg"; - meta = { - maintainers = with lib.maintainers; [ nickcao ]; - }; - - nodes = { - server = { pkgs, ... }: { - boot.kernelModules = [ "nvmet" ]; - environment.systemPackages = [ pkgs.nvmetcfg ]; - networking.firewall.allowedTCPPorts = [ 4420 ]; - virtualisation.emptyDiskImages = [ 512 ]; + meta = { + maintainers = with lib.maintainers; [ nickcao ]; }; - client = { pkgs, ... }: { - boot.kernelModules = [ "nvme-fabrics" ]; - environment.systemPackages = [ pkgs.nvme-cli ]; + + nodes = { + server = + { pkgs, ... }: + { + boot.kernelModules = [ "nvmet" ]; + environment.systemPackages = [ pkgs.nvmetcfg ]; + networking.firewall.allowedTCPPorts = [ 4420 ]; + virtualisation.emptyDiskImages = [ 512 ]; + }; + client = + { pkgs, ... }: + { + boot.kernelModules = [ "nvme-fabrics" ]; + environment.systemPackages = [ pkgs.nvme-cli ]; + }; }; - }; - testScript = let subsystem = "nqn.2014-08.org.nixos:server"; in '' - import json + testScript = + let + subsystem = "nqn.2014-08.org.nixos:server"; + in + '' + import json - with subtest("Create subsystem and namespace"): - server.succeed("nvmet subsystem add ${subsystem}") - server.succeed("nvmet namespace add ${subsystem} 1 /dev/vdb") + with subtest("Create subsystem and namespace"): + server.succeed("nvmet subsystem add ${subsystem}") + server.succeed("nvmet namespace add ${subsystem} 1 /dev/vdb") - with subtest("Bind subsystem to port"): - server.wait_for_unit("network-online.target") - server.succeed("nvmet port add 1 tcp [::]:4420") - server.succeed("nvmet port add-subsystem 1 ${subsystem}") + with subtest("Bind subsystem to port"): + server.wait_for_unit("network-online.target") + server.succeed("nvmet port add 1 tcp [::]:4420") + server.succeed("nvmet port add-subsystem 1 ${subsystem}") - with subtest("Discover and connect to available subsystems"): - client.wait_for_unit("network-online.target") - assert "subnqn: ${subsystem}" in client.succeed("nvme discover --transport=tcp --traddr=server --trsvcid=4420") - client.succeed("nvme connect-all --transport=tcp --traddr=server --trsvcid=4420") + with subtest("Discover and connect to available subsystems"): + client.wait_for_unit("network-online.target") + assert "subnqn: ${subsystem}" in client.succeed("nvme discover --transport=tcp --traddr=server --trsvcid=4420") + client.succeed("nvme connect-all --transport=tcp --traddr=server --trsvcid=4420") - with subtest("Write to the connected subsystem"): - devices = json.loads(client.succeed("lsblk --nvme --paths --json"))["blockdevices"] - assert len(devices) == 1 - client.succeed(f"dd if=/dev/zero of={devices[0]['name']} bs=1M count=64") - ''; -}) + with subtest("Write to the connected subsystem"): + devices = json.loads(client.succeed("lsblk --nvme --paths --json"))["blockdevices"] + assert len(devices) == 1 + client.succeed(f"dd if=/dev/zero of={devices[0]['name']} bs=1M count=64") + ''; + } +) diff --git a/nixos/tests/nzbget.nix b/nixos/tests/nzbget.nix index e45031d5629c43..0fd80c6d554a2a 100644 --- a/nixos/tests/nzbget.nix +++ b/nixos/tests/nzbget.nix @@ -1,46 +1,56 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "nzbget"; - meta = with pkgs.lib.maintainers; { - maintainers = [ aanderse flokli ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "nzbget"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + aanderse + flokli + ]; + }; - nodes = { - server = { ... }: { - services.nzbget.enable = true; + nodes = { + server = + { ... }: + { + services.nzbget.enable = true; - # provide some test settings - services.nzbget.settings = { - "MainDir" = "/var/lib/nzbget"; - "DirectRename" = true; - "DiskSpace" = 0; - "Server1.Name" = "this is a test"; - }; + # provide some test settings + services.nzbget.settings = { + "MainDir" = "/var/lib/nzbget"; + "DirectRename" = true; + "DiskSpace" = 0; + "Server1.Name" = "this is a test"; + }; - # hack, don't add (unfree) unrar to nzbget's path, - # so we can run this test in CI - systemd.services.nzbget.path = pkgs.lib.mkForce [ pkgs.p7zip ]; + # hack, don't add (unfree) unrar to nzbget's path, + # so we can run this test in CI + systemd.services.nzbget.path = pkgs.lib.mkForce [ pkgs.p7zip ]; + }; }; - }; - testScript = { nodes, ... }: '' - start_all() + testScript = + { nodes, ... }: + '' + start_all() - server.wait_for_unit("nzbget.service") - server.wait_for_unit("network.target") - server.wait_for_open_port(6789) - assert "This file is part of nzbget" in server.succeed( - "curl -f -s -u nzbget:tegbzn6789 http://127.0.0.1:6789" - ) - server.succeed( - "${pkgs.nzbget}/bin/nzbget -n -o Control_iP=127.0.0.1 -o Control_port=6789 -o Control_password=tegbzn6789 -V" - ) + server.wait_for_unit("nzbget.service") + server.wait_for_unit("network.target") + server.wait_for_open_port(6789) + assert "This file is part of nzbget" in server.succeed( + "curl -f -s -u nzbget:tegbzn6789 http://127.0.0.1:6789" + ) + server.succeed( + "${pkgs.nzbget}/bin/nzbget -n -o Control_iP=127.0.0.1 -o Control_port=6789 -o Control_password=tegbzn6789 -V" + ) - config = server.succeed("${nodes.server.systemd.services.nzbget.serviceConfig.ExecStart} --printconfig") + config = server.succeed("${nodes.server.systemd.services.nzbget.serviceConfig.ExecStart} --printconfig") - # confirm the test settings are applied - assert 'MainDir = "/var/lib/nzbget"' in config - assert 'DirectRename = "yes"' in config - assert 'DiskSpace = "0"' in config - assert 'Server1.Name = "this is a test"' in config - ''; -}) + # confirm the test settings are applied + assert 'MainDir = "/var/lib/nzbget"' in config + assert 'DirectRename = "yes"' in config + assert 'DiskSpace = "0"' in config + assert 'Server1.Name = "this is a test"' in config + ''; + } +) diff --git a/nixos/tests/nzbhydra2.nix b/nixos/tests/nzbhydra2.nix index 6262a50b4be0e2..9f6f2e98423a1b 100644 --- a/nixos/tests/nzbhydra2.nix +++ b/nixos/tests/nzbhydra2.nix @@ -1,9 +1,14 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: { name = "nzbhydra2"; meta.maintainers = with lib.maintainers; [ matteopacini ]; - nodes.machine = { pkgs, ... }: { services.nzbhydra2.enable = true; }; + nodes.machine = + { pkgs, ... }: + { + services.nzbhydra2.enable = true; + }; testScript = '' machine.start() @@ -11,4 +16,5 @@ import ./make-test-python.nix ({ lib, ... }: machine.wait_for_open_port(5076) machine.succeed("curl --fail http://localhost:5076/") ''; - }) + } +) diff --git a/nixos/tests/ocsinventory-agent.nix b/nixos/tests/ocsinventory-agent.nix index 67b0c8c911036c..b2cfba6dcb22d8 100644 --- a/nixos/tests/ocsinventory-agent.nix +++ b/nixos/tests/ocsinventory-agent.nix @@ -1,33 +1,38 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "ocsinventory-agent"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "ocsinventory-agent"; - nodes.machine = { pkgs, ... }: { - services.ocsinventory-agent = { - enable = true; - settings = { - debug = true; - local = "/var/lib/ocsinventory-agent/reports"; - tag = "MY_INVENTORY_TAG"; + nodes.machine = + { pkgs, ... }: + { + services.ocsinventory-agent = { + enable = true; + settings = { + debug = true; + local = "/var/lib/ocsinventory-agent/reports"; + tag = "MY_INVENTORY_TAG"; + }; + }; }; - }; - }; - testScript = '' - path = "/var/lib/ocsinventory-agent/reports" + testScript = '' + path = "/var/lib/ocsinventory-agent/reports" - # Run the agent to generate the inventory file in offline mode - start_all() - machine.succeed("mkdir -p {}".format(path)) - machine.wait_for_unit("ocsinventory-agent.service") - machine.wait_until_succeeds("journalctl -u ocsinventory-agent.service | grep 'Inventory saved in'") + # Run the agent to generate the inventory file in offline mode + start_all() + machine.succeed("mkdir -p {}".format(path)) + machine.wait_for_unit("ocsinventory-agent.service") + machine.wait_until_succeeds("journalctl -u ocsinventory-agent.service | grep 'Inventory saved in'") - # Fetch the path to the generated inventory file - report_file = machine.succeed("find {}/*.ocs -type f | head -n1".format(path)) + # Fetch the path to the generated inventory file + report_file = machine.succeed("find {}/*.ocs -type f | head -n1".format(path)) - with subtest("Check the tag value"): - tag = machine.succeed( - "${pkgs.libxml2}/bin/xmllint --xpath 'string(/REQUEST/CONTENT/ACCOUNTINFO/KEYVALUE)' {}".format(report_file) - ).rstrip() - assert tag == "MY_INVENTORY_TAG", f"tag is not valid, was '{tag}'" - ''; -}) + with subtest("Check the tag value"): + tag = machine.succeed( + "${pkgs.libxml2}/bin/xmllint --xpath 'string(/REQUEST/CONTENT/ACCOUNTINFO/KEYVALUE)' {}".format(report_file) + ).rstrip() + assert tag == "MY_INVENTORY_TAG", f"tag is not valid, was '{tag}'" + ''; + } +) diff --git a/nixos/tests/octoprint.nix b/nixos/tests/octoprint.nix index 15a2d677d4cf8b..9473797d504754 100644 --- a/nixos/tests/octoprint.nix +++ b/nixos/tests/octoprint.nix @@ -1,61 +1,69 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: - -let - apikey = "testapikey"; -in -{ - name = "octoprint"; - meta.maintainers = with lib.maintainers; [ gador ]; - - nodes.machine = { pkgs, ... }: { - environment.systemPackages = with pkgs; [ jq ]; - services.octoprint = { - enable = true; - extraConfig = { - server = { - firstRun = false; - }; - api = { - enabled = true; - key = apikey; - }; - plugins = { - # these need internet access and pollute the output with connection failed errors - _disabled = [ "softwareupdate" "announcements" "pluginmanager" ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + let + apikey = "testapikey"; + in + { + name = "octoprint"; + meta.maintainers = with lib.maintainers; [ gador ]; + + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = with pkgs; [ jq ]; + services.octoprint = { + enable = true; + extraConfig = { + server = { + firstRun = false; + }; + api = { + enabled = true; + key = apikey; + }; + plugins = { + # these need internet access and pollute the output with connection failed errors + _disabled = [ + "softwareupdate" + "announcements" + "pluginmanager" + ]; + }; + }; }; }; - }; - }; - - testScript = '' - import json - - @polling_condition - def octoprint_running(): - machine.succeed("pgrep octoprint") - - with subtest("Wait for octoprint service to start"): - machine.wait_for_unit("octoprint.service") - machine.wait_until_succeeds("pgrep octoprint") - - with subtest("Wait for final boot"): - # this appears whe octoprint is almost finished starting - machine.wait_for_file("/var/lib/octoprint/uploads") - - # octoprint takes some time to start. This makes sure we'll retry just in case it takes longer - # retry-all-errors in necessary, since octoprint will report a 404 error when not yet ready - curl_cmd = "curl --retry-all-errors --connect-timeout 5 --max-time 10 --retry 5 --retry-delay 0 \ - --retry-max-time 40 -X GET --header 'X-API-Key: ${apikey}' " - - # used to fail early, in case octoprint first starts and then crashes - with octoprint_running: # type: ignore[union-attr] - with subtest("Check for web interface"): - machine.wait_until_succeeds("curl -s localhost:5000") - - with subtest("Check API"): - version = json.loads(machine.succeed(curl_cmd + "localhost:5000/api/version")) - server = json.loads(machine.succeed(curl_cmd + "localhost:5000/api/server")) - assert version["server"] == str("${pkgs.octoprint.version}") - assert server["safemode"] == None - ''; -}) + + testScript = '' + import json + + @polling_condition + def octoprint_running(): + machine.succeed("pgrep octoprint") + + with subtest("Wait for octoprint service to start"): + machine.wait_for_unit("octoprint.service") + machine.wait_until_succeeds("pgrep octoprint") + + with subtest("Wait for final boot"): + # this appears whe octoprint is almost finished starting + machine.wait_for_file("/var/lib/octoprint/uploads") + + # octoprint takes some time to start. This makes sure we'll retry just in case it takes longer + # retry-all-errors in necessary, since octoprint will report a 404 error when not yet ready + curl_cmd = "curl --retry-all-errors --connect-timeout 5 --max-time 10 --retry 5 --retry-delay 0 \ + --retry-max-time 40 -X GET --header 'X-API-Key: ${apikey}' " + + # used to fail early, in case octoprint first starts and then crashes + with octoprint_running: # type: ignore[union-attr] + with subtest("Check for web interface"): + machine.wait_until_succeeds("curl -s localhost:5000") + + with subtest("Check API"): + version = json.loads(machine.succeed(curl_cmd + "localhost:5000/api/version")) + server = json.loads(machine.succeed(curl_cmd + "localhost:5000/api/server")) + assert version["server"] == str("${pkgs.octoprint.version}") + assert server["safemode"] == None + ''; + } +) diff --git a/nixos/tests/oddjobd.nix b/nixos/tests/oddjobd.nix index cc2d4079eebc91..853d8e68d5e2bb 100644 --- a/nixos/tests/oddjobd.nix +++ b/nixos/tests/oddjobd.nix @@ -1,23 +1,28 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "oddjobd"; - meta.maintainers = [ lib.maintainers.anthonyroussel ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "oddjobd"; + meta.maintainers = [ lib.maintainers.anthonyroussel ]; - nodes.machine = { ... } : { - environment.systemPackages = [ - pkgs.oddjob - ]; + nodes.machine = + { ... }: + { + environment.systemPackages = [ + pkgs.oddjob + ]; - programs.oddjobd.enable = true; - }; + programs.oddjobd.enable = true; + }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("oddjobd.service") - machine.wait_for_file("/run/oddjobd.pid") + machine.wait_for_unit("oddjobd.service") + machine.wait_for_file("/run/oddjobd.pid") - with subtest("send oddjob listall request"): - result = machine.succeed("oddjob_request -s com.redhat.oddjob -o /com/redhat/oddjob -i com.redhat.oddjob listall") - assert ('(service="com.redhat.oddjob",object="/com/redhat/oddjob",interface="com.redhat.oddjob",method="listall")' in result) - ''; -}) + with subtest("send oddjob listall request"): + result = machine.succeed("oddjob_request -s com.redhat.oddjob -o /com/redhat/oddjob -i com.redhat.oddjob listall") + assert ('(service="com.redhat.oddjob",object="/com/redhat/oddjob",interface="com.redhat.oddjob",method="listall")' in result) + ''; + } +) diff --git a/nixos/tests/odoo.nix b/nixos/tests/odoo.nix index d3764cbc9f0b92..54120b234364a1 100644 --- a/nixos/tests/odoo.nix +++ b/nixos/tests/odoo.nix @@ -1,28 +1,39 @@ -import ./make-test-python.nix ({ pkgs, lib, package ? pkgs.odoo, ...} : { - name = "odoo"; - meta.maintainers = with lib.maintainers; [ mkg20001 ]; +import ./make-test-python.nix ( + { + pkgs, + lib, + package ? pkgs.odoo, + ... + }: + { + name = "odoo"; + meta.maintainers = with lib.maintainers; [ mkg20001 ]; - nodes = { - server = { ... }: { - services.nginx = { - enable = true; - recommendedProxySettings = true; - }; + nodes = { + server = + { ... }: + { + services.nginx = { + enable = true; + recommendedProxySettings = true; + }; - services.odoo = { - enable = true; - package = package; - autoInit = true; - autoInitExtraFlags = [ "--without-demo=all" ]; - domain = "localhost"; - }; + services.odoo = { + enable = true; + package = package; + autoInit = true; + autoInitExtraFlags = [ "--without-demo=all" ]; + domain = "localhost"; + }; + }; }; - }; - testScript = { nodes, ... }: - '' - server.wait_for_unit("odoo.service") - server.wait_until_succeeds("curl -s http://localhost:8069/web/database/selector | grep 'Odoo'") - server.succeed("curl -s http://localhost/web/database/selector | grep 'Odoo'") - ''; -}) + testScript = + { nodes, ... }: + '' + server.wait_for_unit("odoo.service") + server.wait_until_succeeds("curl -s http://localhost:8069/web/database/selector | grep 'Odoo'") + server.succeed("curl -s http://localhost/web/database/selector | grep 'Odoo'") + ''; + } +) diff --git a/nixos/tests/oh-my-zsh.nix b/nixos/tests/oh-my-zsh.nix index 1d5227e36236d8..25c4e8ebfe977f 100644 --- a/nixos/tests/oh-my-zsh.nix +++ b/nixos/tests/oh-my-zsh.nix @@ -1,18 +1,22 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "oh-my-zsh"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "oh-my-zsh"; - nodes.machine = { pkgs, ... }: + nodes.machine = + { pkgs, ... }: - { - programs.zsh = { - enable = true; - ohMyZsh.enable = true; + { + programs.zsh = { + enable = true; + ohMyZsh.enable = true; + }; }; - }; - testScript = '' - start_all() - machine.succeed("touch ~/.zshrc") - machine.succeed("zsh -c 'source /etc/zshrc && echo $ZSH | grep oh-my-zsh-${pkgs.oh-my-zsh.version}'") - ''; -}) + testScript = '' + start_all() + machine.succeed("touch ~/.zshrc") + machine.succeed("zsh -c 'source /etc/zshrc && echo $ZSH | grep oh-my-zsh-${pkgs.oh-my-zsh.version}'") + ''; + } +) diff --git a/nixos/tests/ombi.nix b/nixos/tests/ombi.nix index fb3a37c978e3b5..eeeaba5e2d0eca 100644 --- a/nixos/tests/ombi.nix +++ b/nixos/tests/ombi.nix @@ -1,16 +1,20 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "ombi"; - meta.maintainers = with lib.maintainers; [ woky ]; + { + name = "ombi"; + meta.maintainers = with lib.maintainers; [ woky ]; - nodes.machine = - { pkgs, ... }: - { services.ombi.enable = true; }; + nodes.machine = + { pkgs, ... }: + { + services.ombi.enable = true; + }; - testScript = '' - machine.wait_for_unit("ombi.service") - machine.wait_for_open_port(5000) - machine.succeed("curl --fail http://localhost:5000/") - ''; -}) + testScript = '' + machine.wait_for_unit("ombi.service") + machine.wait_for_open_port(5000) + machine.succeed("curl --fail http://localhost:5000/") + ''; + } +) diff --git a/nixos/tests/openarena.nix b/nixos/tests/openarena.nix index 4dfe71a9a1e955..6ac38729d3f1ea 100644 --- a/nixos/tests/openarena.nix +++ b/nixos/tests/openarena.nix @@ -1,35 +1,42 @@ -import ./make-test-python.nix ({ pkgs, ...} : - -let - client = - { pkgs, ... }: - - { imports = [ ./common/x11.nix ]; - hardware.graphics.enable = true; - environment.systemPackages = [ pkgs.openarena ]; +import ./make-test-python.nix ( + { pkgs, ... }: + + let + client = + { pkgs, ... }: + + { + imports = [ ./common/x11.nix ]; + hardware.graphics.enable = true; + environment.systemPackages = [ pkgs.openarena ]; + }; + + in + { + name = "openarena"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fpletz ]; }; -in { - name = "openarena"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fpletz ]; - }; - - nodes = - { server = - { services.openarena = { - enable = true; - extraFlags = [ "+set g_gametype 0" "+map oa_dm7" "+addbot Angelyss" "+addbot Arachna" ]; - openPorts = true; - }; + nodes = { + server = { + services.openarena = { + enable = true; + extraFlags = [ + "+set g_gametype 0" + "+map oa_dm7" + "+addbot Angelyss" + "+addbot Arachna" + ]; + openPorts = true; }; + }; client1 = client; client2 = client; }; - testScript = - '' + testScript = '' start_all() server.wait_for_unit("openarena") @@ -68,4 +75,5 @@ in { client2.screenshot("screen_client2_3") ''; -}) + } +) diff --git a/nixos/tests/openldap.nix b/nixos/tests/openldap.nix index 47d6a91843f115..f66aaec780486d 100644 --- a/nixos/tests/openldap.nix +++ b/nixos/tests/openldap.nix @@ -1,156 +1,177 @@ -import ./make-test-python.nix ({ pkgs, ... }: let - dbContents = '' - dn: dc=example - objectClass: domain - dc: example +import ./make-test-python.nix ( + { pkgs, ... }: + let + dbContents = '' + dn: dc=example + objectClass: domain + dc: example - dn: ou=users,dc=example - objectClass: organizationalUnit - ou: users - ''; + dn: ou=users,dc=example + objectClass: organizationalUnit + ou: users + ''; - ldifConfig = '' - dn: cn=config - cn: config - objectClass: olcGlobal - olcLogLevel: stats + ldifConfig = '' + dn: cn=config + cn: config + objectClass: olcGlobal + olcLogLevel: stats - dn: cn=schema,cn=config - cn: schema - objectClass: olcSchemaConfig + dn: cn=schema,cn=config + cn: schema + objectClass: olcSchemaConfig - include: file://${pkgs.openldap}/etc/schema/core.ldif - include: file://${pkgs.openldap}/etc/schema/cosine.ldif - include: file://${pkgs.openldap}/etc/schema/inetorgperson.ldif + include: file://${pkgs.openldap}/etc/schema/core.ldif + include: file://${pkgs.openldap}/etc/schema/cosine.ldif + include: file://${pkgs.openldap}/etc/schema/inetorgperson.ldif - dn: olcDatabase={0}config,cn=config - olcDatabase: {0}config - objectClass: olcDatabaseConfig - olcRootDN: cn=root,cn=config - olcRootPW: configpassword + dn: olcDatabase={0}config,cn=config + olcDatabase: {0}config + objectClass: olcDatabaseConfig + olcRootDN: cn=root,cn=config + olcRootPW: configpassword - dn: olcDatabase={1}mdb,cn=config - objectClass: olcDatabaseConfig - objectClass: olcMdbConfig - olcDatabase: {1}mdb - olcDbDirectory: /var/db/openldap - olcDbIndex: objectClass eq - olcSuffix: dc=example - olcRootDN: cn=root,dc=example - olcRootPW: notapassword - ''; + dn: olcDatabase={1}mdb,cn=config + objectClass: olcDatabaseConfig + objectClass: olcMdbConfig + olcDatabase: {1}mdb + olcDbDirectory: /var/db/openldap + olcDbIndex: objectClass eq + olcSuffix: dc=example + olcRootDN: cn=root,dc=example + olcRootPW: notapassword + ''; - ldapClientConfig = { - enable = true; - loginPam = false; - nsswitch = false; - server = "ldap://"; - base = "dc=example"; - }; + ldapClientConfig = { + enable = true; + loginPam = false; + nsswitch = false; + server = "ldap://"; + base = "dc=example"; + }; -in { - name = "openldap"; + in + { + name = "openldap"; - nodes.machine = { pkgs, ... }: { - environment.etc."openldap/root_password".text = "notapassword"; + nodes.machine = + { pkgs, ... }: + { + environment.etc."openldap/root_password".text = "notapassword"; - users.ldap = ldapClientConfig; + users.ldap = ldapClientConfig; - services.openldap = { - enable = true; - urlList = [ "ldapi:///" "ldap://" ]; - settings = { - children = { - "cn=schema".includes = [ - "${pkgs.openldap}/etc/schema/core.ldif" - "${pkgs.openldap}/etc/schema/cosine.ldif" - "${pkgs.openldap}/etc/schema/inetorgperson.ldif" - "${pkgs.openldap}/etc/schema/nis.ldif" + services.openldap = { + enable = true; + urlList = [ + "ldapi:///" + "ldap://" ]; - "olcDatabase={0}config" = { - attrs = { - objectClass = [ "olcDatabaseConfig" ]; - olcDatabase = "{0}config"; - olcRootDN = "cn=root,cn=config"; - olcRootPW = "configpassword"; - }; - }; - "olcDatabase={1}mdb" = { - # This tests string, base64 and path values, as well as lists of string values - attrs = { - objectClass = [ "olcDatabaseConfig" "olcMdbConfig" ]; - olcDatabase = "{1}mdb"; - olcDbDirectory = "/var/lib/openldap/db"; - olcSuffix = "dc=example"; - olcRootDN = { - # cn=root,dc=example - base64 = "Y249cm9vdCxkYz1leGFtcGxl"; + settings = { + children = { + "cn=schema".includes = [ + "${pkgs.openldap}/etc/schema/core.ldif" + "${pkgs.openldap}/etc/schema/cosine.ldif" + "${pkgs.openldap}/etc/schema/inetorgperson.ldif" + "${pkgs.openldap}/etc/schema/nis.ldif" + ]; + "olcDatabase={0}config" = { + attrs = { + objectClass = [ "olcDatabaseConfig" ]; + olcDatabase = "{0}config"; + olcRootDN = "cn=root,cn=config"; + olcRootPW = "configpassword"; + }; }; - olcRootPW = { - path = "/etc/openldap/root_password"; + "olcDatabase={1}mdb" = { + # This tests string, base64 and path values, as well as lists of string values + attrs = { + objectClass = [ + "olcDatabaseConfig" + "olcMdbConfig" + ]; + olcDatabase = "{1}mdb"; + olcDbDirectory = "/var/lib/openldap/db"; + olcSuffix = "dc=example"; + olcRootDN = { + # cn=root,dc=example + base64 = "Y249cm9vdCxkYz1leGFtcGxl"; + }; + olcRootPW = { + path = "/etc/openldap/root_password"; + }; + }; }; }; }; }; - }; - }; - specialisation = { - declarativeContents.configuration = { ... }: { - services.openldap.declarativeContents."dc=example" = dbContents; - }; - mutableConfig.configuration = { ... }: { - services.openldap = { - declarativeContents."dc=example" = dbContents; - mutableConfig = true; - }; - }; - manualConfigDir = { - inheritParentConfig = false; - configuration = { ... }: { - users.ldap = ldapClientConfig; - services.openldap = { - enable = true; - configDir = "/var/db/slapd.d"; + specialisation = { + declarativeContents.configuration = + { ... }: + { + services.openldap.declarativeContents."dc=example" = dbContents; + }; + mutableConfig.configuration = + { ... }: + { + services.openldap = { + declarativeContents."dc=example" = dbContents; + mutableConfig = true; + }; + }; + manualConfigDir = { + inheritParentConfig = false; + configuration = + { ... }: + { + users.ldap = ldapClientConfig; + services.openldap = { + enable = true; + configDir = "/var/db/slapd.d"; + }; + }; }; }; }; - }; - }; - testScript = { nodes, ... }: let - specializations = "${nodes.machine.system.build.toplevel}/specialisation"; - changeRootPw = '' - dn: olcDatabase={1}mdb,cn=config - changetype: modify - replace: olcRootPW - olcRootPW: foobar - ''; - in '' - # Test startup with empty DB - machine.wait_for_unit("openldap.service") + testScript = + { nodes, ... }: + let + specializations = "${nodes.machine.system.build.toplevel}/specialisation"; + changeRootPw = '' + dn: olcDatabase={1}mdb,cn=config + changetype: modify + replace: olcRootPW + olcRootPW: foobar + ''; + in + '' + # Test startup with empty DB + machine.wait_for_unit("openldap.service") - with subtest("declarative contents"): - machine.succeed('${specializations}/declarativeContents/bin/switch-to-configuration test') - machine.wait_for_unit("openldap.service") - machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w notapassword') - machine.fail('ldapmodify -D cn=root,cn=config -w configpassword -f ${pkgs.writeText "rootpw.ldif" changeRootPw}') + with subtest("declarative contents"): + machine.succeed('${specializations}/declarativeContents/bin/switch-to-configuration test') + machine.wait_for_unit("openldap.service") + machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w notapassword') + machine.fail('ldapmodify -D cn=root,cn=config -w configpassword -f ${pkgs.writeText "rootpw.ldif" changeRootPw}') - with subtest("mutable config"): - machine.succeed('${specializations}/mutableConfig/bin/switch-to-configuration test') - machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w notapassword') - machine.succeed('ldapmodify -D cn=root,cn=config -w configpassword -f ${pkgs.writeText "rootpw.ldif" changeRootPw}') - machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w foobar') + with subtest("mutable config"): + machine.succeed('${specializations}/mutableConfig/bin/switch-to-configuration test') + machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w notapassword') + machine.succeed('ldapmodify -D cn=root,cn=config -w configpassword -f ${pkgs.writeText "rootpw.ldif" changeRootPw}') + machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w foobar') - with subtest("manual config dir"): - machine.succeed( - 'mkdir /var/db/slapd.d /var/db/openldap', - 'slapadd -F /var/db/slapd.d -n0 -l ${pkgs.writeText "config.ldif" ldifConfig}', - 'slapadd -F /var/db/slapd.d -n1 -l ${pkgs.writeText "contents.ldif" dbContents}', - 'chown -R openldap:openldap /var/db/slapd.d /var/db/openldap', - '${specializations}/manualConfigDir/bin/switch-to-configuration test', - ) - machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w notapassword') - machine.succeed('ldapmodify -D cn=root,cn=config -w configpassword -f ${pkgs.writeText "rootpw.ldif" changeRootPw}') - machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w foobar') - ''; -}) + with subtest("manual config dir"): + machine.succeed( + 'mkdir /var/db/slapd.d /var/db/openldap', + 'slapadd -F /var/db/slapd.d -n0 -l ${pkgs.writeText "config.ldif" ldifConfig}', + 'slapadd -F /var/db/slapd.d -n1 -l ${pkgs.writeText "contents.ldif" dbContents}', + 'chown -R openldap:openldap /var/db/slapd.d /var/db/openldap', + '${specializations}/manualConfigDir/bin/switch-to-configuration test', + ) + machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w notapassword') + machine.succeed('ldapmodify -D cn=root,cn=config -w configpassword -f ${pkgs.writeText "rootpw.ldif" changeRootPw}') + machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w foobar') + ''; + } +) diff --git a/nixos/tests/openresty-lua.nix b/nixos/tests/openresty-lua.nix index e3629e9ca40a6e..7141ef181039e5 100644 --- a/nixos/tests/openresty-lua.nix +++ b/nixos/tests/openresty-lua.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: let luaLibs = [ pkgs.lua.pkgs.markdown @@ -14,65 +15,68 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: }; nodes = { - webserver = { pkgs, lib, ... }: { - networking = { - extraHosts = '' - 127.0.0.1 default.test - 127.0.0.1 sandbox.test - ''; - }; - services.nginx = { - enable = true; - package = pkgs.openresty; + webserver = + { pkgs, lib, ... }: + { + networking = { + extraHosts = '' + 127.0.0.1 default.test + 127.0.0.1 sandbox.test + ''; + }; + services.nginx = { + enable = true; + package = pkgs.openresty; - commonHttpConfig = '' - lua_package_path '${luaPath};;'; - ''; + commonHttpConfig = '' + lua_package_path '${luaPath};;'; + ''; - virtualHosts."default.test" = { - default = true; - locations."/" = { - extraConfig = '' - default_type text/html; - access_by_lua ' - local markdown = require "markdown" - markdown("source") - '; - ''; + virtualHosts."default.test" = { + default = true; + locations."/" = { + extraConfig = '' + default_type text/html; + access_by_lua ' + local markdown = require "markdown" + markdown("source") + '; + ''; + }; }; - }; - virtualHosts."sandbox.test" = { - locations."/test1-write" = { - extraConfig = '' - content_by_lua_block { - local create = os.execute('${pkgs.coreutils}/bin/mkdir /tmp/test1-read') - local create = os.execute('${pkgs.coreutils}/bin/touch /tmp/test1-read/foo.txt') - local echo = os.execute('${pkgs.coreutils}/bin/echo worked > /tmp/test1-read/foo.txt') - } - ''; - }; - locations."/test1-read" = { - root = "/tmp"; - }; - locations."/test2-write" = { - extraConfig = '' - content_by_lua_block { - local create = os.execute('${pkgs.coreutils}/bin/mkdir /var/web/test2-read') - local create = os.execute('${pkgs.coreutils}/bin/touch /var/web/test2-read/bar.txt') - local echo = os.execute('${pkgs.coreutils}/bin/echo error-worked > /var/web/test2-read/bar.txt') - } - ''; - }; - locations."/test2-read" = { - root = "/var/web"; + virtualHosts."sandbox.test" = { + locations."/test1-write" = { + extraConfig = '' + content_by_lua_block { + local create = os.execute('${pkgs.coreutils}/bin/mkdir /tmp/test1-read') + local create = os.execute('${pkgs.coreutils}/bin/touch /tmp/test1-read/foo.txt') + local echo = os.execute('${pkgs.coreutils}/bin/echo worked > /tmp/test1-read/foo.txt') + } + ''; + }; + locations."/test1-read" = { + root = "/tmp"; + }; + locations."/test2-write" = { + extraConfig = '' + content_by_lua_block { + local create = os.execute('${pkgs.coreutils}/bin/mkdir /var/web/test2-read') + local create = os.execute('${pkgs.coreutils}/bin/touch /var/web/test2-read/bar.txt') + local echo = os.execute('${pkgs.coreutils}/bin/echo error-worked > /var/web/test2-read/bar.txt') + } + ''; + }; + locations."/test2-read" = { + root = "/var/web"; + }; }; }; }; - }; }; - testScript = { nodes, ... }: + testScript = + { nodes, ... }: '' url = "http://localhost" @@ -97,4 +101,5 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: "curl -vvv -s http://sandbox.test/test2-read/bar.txt" ) ''; - }) + } +) diff --git a/nixos/tests/opensearch.nix b/nixos/tests/opensearch.nix index 7d37583464cb01..a8794340f3062c 100644 --- a/nixos/tests/opensearch.nix +++ b/nixos/tests/opensearch.nix @@ -1,7 +1,9 @@ let - opensearchTest = extraSettings: + opensearchTest = + extraSettings: import ./make-test-python.nix ( - { pkgs, lib, ... }: { + { pkgs, lib, ... }: + { name = "opensearch"; meta.maintainers = with pkgs.lib.maintainers; [ shyim ]; @@ -22,10 +24,11 @@ let "curl --fail localhost:9200" ) ''; - }); + } + ); in { - opensearch = opensearchTest {}; + opensearch = opensearchTest { }; opensearchCustomPathAndUser = opensearchTest { services.opensearch.dataDir = "/var/opensearch_test"; services.opensearch.user = "open_search"; diff --git a/nixos/tests/opensmtpd-rspamd.nix b/nixos/tests/opensmtpd-rspamd.nix index e413a2050bd61d..58b0e3b3414dcd 100644 --- a/nixos/tests/opensmtpd-rspamd.nix +++ b/nixos/tests/opensmtpd-rspamd.nix @@ -2,118 +2,144 @@ import ./make-test-python.nix { name = "opensmtpd-rspamd"; nodes = { - smtp1 = { pkgs, ... }: { - imports = [ common/user-account.nix ]; - networking = { - firewall.allowedTCPPorts = [ 25 143 ]; - useDHCP = false; - interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = "192.168.1.1"; prefixLength = 24; } - ]; - }; - environment.systemPackages = [ pkgs.opensmtpd ]; - services.opensmtpd = { - enable = true; - extraServerArgs = [ "-v" ]; - serverConfiguration = '' - listen on 0.0.0.0 - action dovecot_deliver mda \ - "${pkgs.dovecot}/libexec/dovecot/deliver -d %{user.username}" - match from any for local action dovecot_deliver + smtp1 = + { pkgs, ... }: + { + imports = [ common/user-account.nix ]; + networking = { + firewall.allowedTCPPorts = [ + 25 + 143 + ]; + useDHCP = false; + interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; + }; + environment.systemPackages = [ pkgs.opensmtpd ]; + services.opensmtpd = { + enable = true; + extraServerArgs = [ "-v" ]; + serverConfiguration = '' + listen on 0.0.0.0 + action dovecot_deliver mda \ + "${pkgs.dovecot}/libexec/dovecot/deliver -d %{user.username}" + match from any for local action dovecot_deliver - action do_relay relay - # DO NOT DO THIS IN PRODUCTION! - # Setting up authentication requires a certificate which is painful in - # a test environment, but THIS WOULD BE DANGEROUS OUTSIDE OF A - # WELL-CONTROLLED ENVIRONMENT! - match from any for any action do_relay - ''; - }; - services.dovecot2 = { - enable = true; - enableImap = true; - mailLocation = "maildir:~/mail"; - protocols = [ "imap" ]; + action do_relay relay + # DO NOT DO THIS IN PRODUCTION! + # Setting up authentication requires a certificate which is painful in + # a test environment, but THIS WOULD BE DANGEROUS OUTSIDE OF A + # WELL-CONTROLLED ENVIRONMENT! + match from any for any action do_relay + ''; + }; + services.dovecot2 = { + enable = true; + enableImap = true; + mailLocation = "maildir:~/mail"; + protocols = [ "imap" ]; + }; }; - }; - smtp2 = { pkgs, ... }: { - imports = [ common/user-account.nix ]; - networking = { - firewall.allowedTCPPorts = [ 25 143 ]; - useDHCP = false; - interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = "192.168.1.2"; prefixLength = 24; } - ]; - }; - environment.systemPackages = [ pkgs.opensmtpd ]; - services.rspamd = { - enable = true; - locals."worker-normal.inc".text = '' - bind_socket = "127.0.0.1:11333"; - ''; - }; - services.opensmtpd = { - enable = true; - extraServerArgs = [ "-v" ]; - serverConfiguration = '' - filter rspamd proc-exec "${pkgs.opensmtpd-filter-rspamd}/bin/filter-rspamd" - listen on 0.0.0.0 filter rspamd - action dovecot_deliver mda \ - "${pkgs.dovecot}/libexec/dovecot/deliver -d %{user.username}" - match from any for local action dovecot_deliver - ''; + smtp2 = + { pkgs, ... }: + { + imports = [ common/user-account.nix ]; + networking = { + firewall.allowedTCPPorts = [ + 25 + 143 + ]; + useDHCP = false; + interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = "192.168.1.2"; + prefixLength = 24; + } + ]; + }; + environment.systemPackages = [ pkgs.opensmtpd ]; + services.rspamd = { + enable = true; + locals."worker-normal.inc".text = '' + bind_socket = "127.0.0.1:11333"; + ''; + }; + services.opensmtpd = { + enable = true; + extraServerArgs = [ "-v" ]; + serverConfiguration = '' + filter rspamd proc-exec "${pkgs.opensmtpd-filter-rspamd}/bin/filter-rspamd" + listen on 0.0.0.0 filter rspamd + action dovecot_deliver mda \ + "${pkgs.dovecot}/libexec/dovecot/deliver -d %{user.username}" + match from any for local action dovecot_deliver + ''; + }; + services.dovecot2 = { + enable = true; + enableImap = true; + mailLocation = "maildir:~/mail"; + protocols = [ "imap" ]; + }; }; - services.dovecot2 = { - enable = true; - enableImap = true; - mailLocation = "maildir:~/mail"; - protocols = [ "imap" ]; - }; - }; - client = { pkgs, ... }: { - networking = { - useDHCP = false; - interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = "192.168.1.3"; prefixLength = 24; } - ]; - }; - environment.systemPackages = let - sendTestMail = pkgs.writeScriptBin "send-a-test-mail" '' - #!${pkgs.python3.interpreter} - import smtplib, sys + client = + { pkgs, ... }: + { + networking = { + useDHCP = false; + interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = "192.168.1.3"; + prefixLength = 24; + } + ]; + }; + environment.systemPackages = + let + sendTestMail = pkgs.writeScriptBin "send-a-test-mail" '' + #!${pkgs.python3.interpreter} + import smtplib, sys - with smtplib.SMTP('192.168.1.1') as smtp: - smtp.sendmail('alice@[192.168.1.1]', 'bob@[192.168.1.2]', """ - From: alice@smtp1 - To: bob@smtp2 - Subject: Test + with smtplib.SMTP('192.168.1.1') as smtp: + smtp.sendmail('alice@[192.168.1.1]', 'bob@[192.168.1.2]', """ + From: alice@smtp1 + To: bob@smtp2 + Subject: Test - Hello World - Here goes the spam test - XJS*C4JDBQADN1.NSBN3*2IDNEN*GTUBE-STANDARD-ANTI-UBE-TEST-EMAIL*C.34X - """) - ''; + Hello World + Here goes the spam test + XJS*C4JDBQADN1.NSBN3*2IDNEN*GTUBE-STANDARD-ANTI-UBE-TEST-EMAIL*C.34X + """) + ''; - checkMailBounced = pkgs.writeScriptBin "check-mail-bounced" '' - #!${pkgs.python3.interpreter} - import imaplib + checkMailBounced = pkgs.writeScriptBin "check-mail-bounced" '' + #!${pkgs.python3.interpreter} + import imaplib - with imaplib.IMAP4('192.168.1.1', 143) as imap: - imap.login('alice', 'foobar') - imap.select() - status, refs = imap.search(None, 'ALL') - assert status == 'OK' - assert len(refs) == 1 - status, msg = imap.fetch(refs[0], 'BODY[TEXT]') - assert status == 'OK' - content = msg[0][1] - print("===> content:", content) - assert b"An error has occurred while attempting to deliver a message" in content - ''; - in [ sendTestMail checkMailBounced ]; - }; + with imaplib.IMAP4('192.168.1.1', 143) as imap: + imap.login('alice', 'foobar') + imap.select() + status, refs = imap.search(None, 'ALL') + assert status == 'OK' + assert len(refs) == 1 + status, msg = imap.fetch(refs[0], 'BODY[TEXT]') + assert status == 'OK' + content = msg[0][1] + print("===> content:", content) + assert b"An error has occurred while attempting to deliver a message" in content + ''; + in + [ + sendTestMail + checkMailBounced + ]; + }; }; testScript = '' diff --git a/nixos/tests/opensmtpd.nix b/nixos/tests/opensmtpd.nix index d32f82ed33b8c1..6e848354c103d0 100644 --- a/nixos/tests/opensmtpd.nix +++ b/nixos/tests/opensmtpd.nix @@ -2,103 +2,126 @@ import ./make-test-python.nix { name = "opensmtpd"; nodes = { - smtp1 = { pkgs, ... }: { - imports = [ common/user-account.nix ]; - networking = { - firewall.allowedTCPPorts = [ 25 ]; - useDHCP = false; - interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = "192.168.1.1"; prefixLength = 24; } - ]; + smtp1 = + { pkgs, ... }: + { + imports = [ common/user-account.nix ]; + networking = { + firewall.allowedTCPPorts = [ 25 ]; + useDHCP = false; + interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; + }; + environment.systemPackages = [ pkgs.opensmtpd ]; + services.opensmtpd = { + enable = true; + extraServerArgs = [ "-v" ]; + serverConfiguration = '' + listen on 0.0.0.0 + action do_relay relay + # DO NOT DO THIS IN PRODUCTION! + # Setting up authentication requires a certificate which is painful in + # a test environment, but THIS WOULD BE DANGEROUS OUTSIDE OF A + # WELL-CONTROLLED ENVIRONMENT! + match from any for any action do_relay + ''; + }; }; - environment.systemPackages = [ pkgs.opensmtpd ]; - services.opensmtpd = { - enable = true; - extraServerArgs = [ "-v" ]; - serverConfiguration = '' - listen on 0.0.0.0 - action do_relay relay - # DO NOT DO THIS IN PRODUCTION! - # Setting up authentication requires a certificate which is painful in - # a test environment, but THIS WOULD BE DANGEROUS OUTSIDE OF A - # WELL-CONTROLLED ENVIRONMENT! - match from any for any action do_relay - ''; - }; - }; - smtp2 = { pkgs, ... }: { - imports = [ common/user-account.nix ]; - networking = { - firewall.allowedTCPPorts = [ 25 143 ]; - useDHCP = false; - interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = "192.168.1.2"; prefixLength = 24; } - ]; - }; - environment.systemPackages = [ pkgs.opensmtpd ]; - services.opensmtpd = { - enable = true; - extraServerArgs = [ "-v" ]; - serverConfiguration = '' - listen on 0.0.0.0 - action dovecot_deliver mda \ - "${pkgs.dovecot}/libexec/dovecot/deliver -d %{user.username}" - match from any for local action dovecot_deliver - ''; - }; - services.dovecot2 = { - enable = true; - enableImap = true; - mailLocation = "maildir:~/mail"; - protocols = [ "imap" ]; + smtp2 = + { pkgs, ... }: + { + imports = [ common/user-account.nix ]; + networking = { + firewall.allowedTCPPorts = [ + 25 + 143 + ]; + useDHCP = false; + interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = "192.168.1.2"; + prefixLength = 24; + } + ]; + }; + environment.systemPackages = [ pkgs.opensmtpd ]; + services.opensmtpd = { + enable = true; + extraServerArgs = [ "-v" ]; + serverConfiguration = '' + listen on 0.0.0.0 + action dovecot_deliver mda \ + "${pkgs.dovecot}/libexec/dovecot/deliver -d %{user.username}" + match from any for local action dovecot_deliver + ''; + }; + services.dovecot2 = { + enable = true; + enableImap = true; + mailLocation = "maildir:~/mail"; + protocols = [ "imap" ]; + }; }; - }; - client = { pkgs, ... }: { - networking = { - useDHCP = false; - interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = "192.168.1.3"; prefixLength = 24; } - ]; - }; - environment.systemPackages = let - sendTestMail = pkgs.writeScriptBin "send-a-test-mail" '' - #!${pkgs.python3.interpreter} - import smtplib, sys + client = + { pkgs, ... }: + { + networking = { + useDHCP = false; + interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = "192.168.1.3"; + prefixLength = 24; + } + ]; + }; + environment.systemPackages = + let + sendTestMail = pkgs.writeScriptBin "send-a-test-mail" '' + #!${pkgs.python3.interpreter} + import smtplib, sys - with smtplib.SMTP('192.168.1.1') as smtp: - smtp.sendmail('alice@[192.168.1.1]', 'bob@[192.168.1.2]', """ - From: alice@smtp1 - To: bob@smtp2 - Subject: Test + with smtplib.SMTP('192.168.1.1') as smtp: + smtp.sendmail('alice@[192.168.1.1]', 'bob@[192.168.1.2]', """ + From: alice@smtp1 + To: bob@smtp2 + Subject: Test - Hello World - """) - ''; + Hello World + """) + ''; - checkMailLanded = pkgs.writeScriptBin "check-mail-landed" '' - #!${pkgs.python3.interpreter} - import imaplib + checkMailLanded = pkgs.writeScriptBin "check-mail-landed" '' + #!${pkgs.python3.interpreter} + import imaplib - with imaplib.IMAP4('192.168.1.2', 143) as imap: - imap.login('bob', 'foobar') - imap.select() - status, refs = imap.search(None, 'ALL') - assert status == 'OK' - assert len(refs) == 1 - status, msg = imap.fetch(refs[0], 'BODY[TEXT]') - assert status == 'OK' - content = msg[0][1] - print("===> content:", content) - split = content.split(b'\r\n') - print("===> split:", split) - lastline = split[-3] - print("===> lastline:", lastline) - assert lastline.strip() == b'Hello World' - ''; - in [ sendTestMail checkMailLanded ]; - }; + with imaplib.IMAP4('192.168.1.2', 143) as imap: + imap.login('bob', 'foobar') + imap.select() + status, refs = imap.search(None, 'ALL') + assert status == 'OK' + assert len(refs) == 1 + status, msg = imap.fetch(refs[0], 'BODY[TEXT]') + assert status == 'OK' + content = msg[0][1] + print("===> content:", content) + split = content.split(b'\r\n') + print("===> split:", split) + lastline = split[-3] + print("===> lastline:", lastline) + assert lastline.strip() == b'Hello World' + ''; + in + [ + sendTestMail + checkMailLanded + ]; + }; }; testScript = '' diff --git a/nixos/tests/opensnitch.nix b/nixos/tests/opensnitch.nix index a1af07647f7126..4781cc485dbe06 100644 --- a/nixos/tests/opensnitch.nix +++ b/nixos/tests/opensnitch.nix @@ -1,62 +1,68 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "opensnitch"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "opensnitch"; - meta = with pkgs.lib.maintainers; { - maintainers = [ onny ]; - }; + meta = with pkgs.lib.maintainers; { + maintainers = [ onny ]; + }; - nodes = { - server = - { ... }: { - networking.firewall.allowedTCPPorts = [ 80 ]; - services.caddy = { - enable = true; - virtualHosts."localhost".extraConfig = '' - respond "Hello, world!" - ''; + nodes = { + server = + { ... }: + { + networking.firewall.allowedTCPPorts = [ 80 ]; + services.caddy = { + enable = true; + virtualHosts."localhost".extraConfig = '' + respond "Hello, world!" + ''; + }; }; - }; - clientBlocked = - { ... }: { - services.opensnitch = { - enable = true; - settings.DefaultAction = "deny"; + clientBlocked = + { ... }: + { + services.opensnitch = { + enable = true; + settings.DefaultAction = "deny"; + }; }; - }; - clientAllowed = - { ... }: { - services.opensnitch = { - enable = true; - settings.DefaultAction = "deny"; - rules = { - curl = { - name = "curl"; - enabled = true; - action = "allow"; - duration = "always"; - operator = { - type ="simple"; - sensitive = false; - operand = "process.path"; - data = "${pkgs.curl}/bin/curl"; + clientAllowed = + { ... }: + { + services.opensnitch = { + enable = true; + settings.DefaultAction = "deny"; + rules = { + curl = { + name = "curl"; + enabled = true; + action = "allow"; + duration = "always"; + operator = { + type = "simple"; + sensitive = false; + operand = "process.path"; + data = "${pkgs.curl}/bin/curl"; + }; }; }; }; }; - }; - }; + }; - testScript = '' - start_all() - server.wait_for_unit("caddy.service") - server.wait_for_open_port(80) + testScript = '' + start_all() + server.wait_for_unit("caddy.service") + server.wait_for_open_port(80) - clientBlocked.wait_for_unit("opensnitchd.service") - clientBlocked.fail("curl http://server") + clientBlocked.wait_for_unit("opensnitchd.service") + clientBlocked.fail("curl http://server") - clientAllowed.wait_for_unit("opensnitchd.service") - clientAllowed.succeed("curl http://server") - ''; -}) + clientAllowed.wait_for_unit("opensnitchd.service") + clientAllowed.succeed("curl http://server") + ''; + } +) diff --git a/nixos/tests/openstack-image.nix b/nixos/tests/openstack-image.nix index 0b57dfb8e7eb55..8fcfde974668f9 100644 --- a/nixos/tests/openstack-image.nix +++ b/nixos/tests/openstack-image.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -9,34 +10,37 @@ with pkgs.lib; with import common/ec2.nix { inherit makeTest pkgs; }; let - image = (import ../lib/eval-config.nix { - inherit system; - modules = [ - ../maintainers/scripts/openstack/openstack-image.nix - ../modules/testing/test-instrumentation.nix - ../modules/profiles/qemu-guest.nix - { - # Needed by nixos-rebuild due to lack of network access. - system.extraDependencies = with pkgs; [ - stdenv - ]; - } - ]; - }).config.system.build.openstackImage + "/nixos.qcow2"; + image = + (import ../lib/eval-config.nix { + inherit system; + modules = [ + ../maintainers/scripts/openstack/openstack-image.nix + ../modules/testing/test-instrumentation.nix + ../modules/profiles/qemu-guest.nix + { + # Needed by nixos-rebuild due to lack of network access. + system.extraDependencies = with pkgs; [ + stdenv + ]; + } + ]; + }).config.system.build.openstackImage + + "/nixos.qcow2"; sshKeys = import ./ssh-keys.nix pkgs; snakeOilPrivateKey = sshKeys.snakeOilPrivateKey.text; snakeOilPrivateKeyFile = pkgs.writeText "private-key" snakeOilPrivateKey; snakeOilPublicKey = sshKeys.snakeOilPublicKey; -in { +in +{ metadata = makeEc2Test { name = "openstack-ec2-metadata"; inherit image; sshPublicKey = snakeOilPublicKey; userData = '' SSH_HOST_ED25519_KEY_PUB:${snakeOilPublicKey} - SSH_HOST_ED25519_KEY:${replaceStrings ["\n"] ["|"] snakeOilPrivateKey} + SSH_HOST_ED25519_KEY:${replaceStrings [ "\n" ] [ "|" ] snakeOilPrivateKey} ''; script = '' machine.start() diff --git a/nixos/tests/opentabletdriver.nix b/nixos/tests/opentabletdriver.nix index a71a007c411007..b7bdb16bf005d7 100644 --- a/nixos/tests/opentabletdriver.nix +++ b/nixos/tests/opentabletdriver.nix @@ -1,23 +1,26 @@ -import ./make-test-python.nix ( { pkgs, ... }: let - testUser = "alice"; -in { - name = "opentabletdriver"; - meta = { - maintainers = with pkgs.lib.maintainers; [ thiagokokada ]; - }; - - nodes.machine = { pkgs, ... }: - { - imports = [ - ./common/user-account.nix - ./common/x11.nix - ]; - test-support.displayManager.auto.user = testUser; - hardware.opentabletdriver.enable = true; +import ./make-test-python.nix ( + { pkgs, ... }: + let + testUser = "alice"; + in + { + name = "opentabletdriver"; + meta = { + maintainers = with pkgs.lib.maintainers; [ thiagokokada ]; }; - testScript = - '' + nodes.machine = + { pkgs, ... }: + { + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; + test-support.displayManager.auto.user = testUser; + hardware.opentabletdriver.enable = true; + }; + + testScript = '' machine.start() machine.wait_for_x() @@ -29,4 +32,5 @@ in { # Needs to run as the same user that started the service machine.succeed("su - ${testUser} -c 'otd detect'") ''; -}) + } +) diff --git a/nixos/tests/opentelemetry-collector.nix b/nixos/tests/opentelemetry-collector.nix index 98e597cf807b52..1d8d4ea815c407 100644 --- a/nixos/tests/opentelemetry-collector.nix +++ b/nixos/tests/opentelemetry-collector.nix @@ -1,78 +1,87 @@ -import ./make-test-python.nix ({ pkgs, ...} : let - port = 4318; -in { - name = "opentelemetry-collector"; - meta = with pkgs.lib.maintainers; { - maintainers = [ tylerjl ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + let + port = 4318; + in + { + name = "opentelemetry-collector"; + meta = with pkgs.lib.maintainers; { + maintainers = [ tylerjl ]; + }; - nodes.machine = { ... }: { - networking.firewall.allowedTCPPorts = [ port ]; - services.opentelemetry-collector = { - enable = true; - settings = { - exporters.logging.verbosity = "detailed"; - receivers.otlp.protocols = { - http.endpoint = "0.0.0.0:${toString port}"; - }; - service = { - pipelines.logs = { - receivers = [ "otlp" ]; - exporters = [ "logging" ]; + nodes.machine = + { ... }: + { + networking.firewall.allowedTCPPorts = [ port ]; + services.opentelemetry-collector = { + enable = true; + settings = { + exporters.logging.verbosity = "detailed"; + receivers.otlp.protocols = { + http.endpoint = "0.0.0.0:${toString port}"; + }; + service = { + pipelines.logs = { + receivers = [ "otlp" ]; + exporters = [ "logging" ]; + }; + }; }; }; + virtualisation.forwardPorts = [ + { + host.port = port; + guest.port = port; + } + ]; }; - }; - virtualisation.forwardPorts = [{ - host.port = port; - guest.port = port; - }]; - }; - extraPythonPackages = p: [ - p.requests - p.types-requests - ]; + extraPythonPackages = p: [ + p.requests + p.types-requests + ]; - # Send a log event through the OTLP pipeline and check for its - # presence in the collector logs. - testScript = /* python */ '' - import requests - import time + # Send a log event through the OTLP pipeline and check for its + # presence in the collector logs. + testScript = # python + '' + import requests + import time - from uuid import uuid4 + from uuid import uuid4 - flag = str(uuid4()) + flag = str(uuid4()) - machine.wait_for_unit("opentelemetry-collector.service") - machine.wait_for_open_port(${toString port}) + machine.wait_for_unit("opentelemetry-collector.service") + machine.wait_for_open_port(${toString port}) - event = { - "resourceLogs": [ - { - "resource": {"attributes": []}, - "scopeLogs": [ - { - "logRecords": [ - { - "timeUnixNano": str(time.time_ns()), - "severityNumber": 9, - "severityText": "Info", - "name": "logTest", - "body": { - "stringValue": flag + event = { + "resourceLogs": [ + { + "resource": {"attributes": []}, + "scopeLogs": [ + { + "logRecords": [ + { + "timeUnixNano": str(time.time_ns()), + "severityNumber": 9, + "severityText": "Info", + "name": "logTest", + "body": { + "stringValue": flag + }, + "attributes": [] }, - "attributes": [] - }, - ] - } - ] - } - ] - } + ] + } + ] + } + ] + } - response = requests.post("http://localhost:${toString port}/v1/logs", json=event) - assert response.status_code == 200 - assert flag in machine.execute("journalctl -u opentelemetry-collector")[-1] - ''; -}) + response = requests.post("http://localhost:${toString port}/v1/logs", json=event) + assert response.status_code == 200 + assert flag in machine.execute("journalctl -u opentelemetry-collector")[-1] + ''; + } +) diff --git a/nixos/tests/openvscode-server.nix b/nixos/tests/openvscode-server.nix index cbff8e09c5938e..eaef459530ba39 100644 --- a/nixos/tests/openvscode-server.nix +++ b/nixos/tests/openvscode-server.nix @@ -1,22 +1,26 @@ -import ./make-test-python.nix ({pkgs, lib, ...}: -{ - name = "openvscode-server"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "openvscode-server"; - nodes = { - machine = {pkgs, ...}: { - services.openvscode-server = { - enable = true; - withoutConnectionToken = true; - }; + nodes = { + machine = + { pkgs, ... }: + { + services.openvscode-server = { + enable = true; + withoutConnectionToken = true; + }; + }; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("openvscode-server.service") - machine.wait_for_open_port(3000) - machine.succeed("curl -k --fail http://localhost:3000", timeout=10) - ''; + testScript = '' + start_all() + machine.wait_for_unit("openvscode-server.service") + machine.wait_for_open_port(3000) + machine.succeed("curl -k --fail http://localhost:3000", timeout=10) + ''; - meta.maintainers = [ lib.maintainers.drupol ]; -}) + meta.maintainers = [ lib.maintainers.drupol ]; + } +) diff --git a/nixos/tests/orangefs.nix b/nixos/tests/orangefs.nix index 4e67a7fb8efec2..d388826dbf62ac 100644 --- a/nixos/tests/orangefs.nix +++ b/nixos/tests/orangefs.nix @@ -1,82 +1,91 @@ -import ./make-test-python.nix ({ ... } : +import ./make-test-python.nix ( + { ... }: -let - server = { pkgs, ... } : { - networking.firewall.allowedTCPPorts = [ 3334 ]; - boot.initrd.postDeviceCommands = '' - ${pkgs.e2fsprogs}/bin/mkfs.ext4 -L data /dev/vdb - ''; + let + server = + { pkgs, ... }: + { + networking.firewall.allowedTCPPorts = [ 3334 ]; + boot.initrd.postDeviceCommands = '' + ${pkgs.e2fsprogs}/bin/mkfs.ext4 -L data /dev/vdb + ''; - virtualisation.emptyDiskImages = [ 4096 ]; + virtualisation.emptyDiskImages = [ 4096 ]; - virtualisation.fileSystems = - { "/data" = - { device = "/dev/disk/by-label/data"; + virtualisation.fileSystems = { + "/data" = { + device = "/dev/disk/by-label/data"; fsType = "ext4"; }; - }; + }; - services.orangefs.server = { - enable = true; - dataStorageSpace = "/data/storage"; - metadataStorageSpace = "/data/meta"; - servers = { - server1 = "tcp://server1:3334"; - server2 = "tcp://server2:3334"; + services.orangefs.server = { + enable = true; + dataStorageSpace = "/data/storage"; + metadataStorageSpace = "/data/meta"; + servers = { + server1 = "tcp://server1:3334"; + server2 = "tcp://server2:3334"; + }; + }; }; - }; - }; - client = { lib, ... } : { - networking.firewall.enable = true; + client = + { lib, ... }: + { + networking.firewall.enable = true; - services.orangefs.client = { - enable = true; - fileSystems = [{ - target = "tcp://server1:3334/orangefs"; - mountPoint = "/orangefs"; - }]; - }; - }; + services.orangefs.client = { + enable = true; + fileSystems = [ + { + target = "tcp://server1:3334/orangefs"; + mountPoint = "/orangefs"; + } + ]; + }; + }; -in { - name = "orangefs"; + in + { + name = "orangefs"; - nodes = { - server1 = server; - server2 = server; + nodes = { + server1 = server; + server2 = server; - client1 = client; - client2 = client; - }; + client1 = client; + client2 = client; + }; - testScript = '' - # format storage - for server in server1, server2: - server.start() - server.wait_for_unit("multi-user.target") - server.succeed("mkdir -p /data/storage /data/meta") - server.succeed("chown orangefs:orangefs /data/storage /data/meta") - server.succeed("chmod 0770 /data/storage /data/meta") - server.succeed( - "sudo -g orangefs -u orangefs pvfs2-server -f /etc/orangefs/server.conf" - ) + testScript = '' + # format storage + for server in server1, server2: + server.start() + server.wait_for_unit("multi-user.target") + server.succeed("mkdir -p /data/storage /data/meta") + server.succeed("chown orangefs:orangefs /data/storage /data/meta") + server.succeed("chmod 0770 /data/storage /data/meta") + server.succeed( + "sudo -g orangefs -u orangefs pvfs2-server -f /etc/orangefs/server.conf" + ) - # start services after storage is formatted on all machines - for server in server1, server2: - server.succeed("systemctl start orangefs-server.service") + # start services after storage is formatted on all machines + for server in server1, server2: + server.succeed("systemctl start orangefs-server.service") - with subtest("clients can reach and mount the FS"): - for client in client1, client2: - client.start() - client.wait_for_unit("orangefs-client.service") - # Both servers need to be reachable - client.succeed("pvfs2-check-server -h server1 -f orangefs -n tcp -p 3334") - client.succeed("pvfs2-check-server -h server2 -f orangefs -n tcp -p 3334") - client.wait_for_unit("orangefs.mount") + with subtest("clients can reach and mount the FS"): + for client in client1, client2: + client.start() + client.wait_for_unit("orangefs-client.service") + # Both servers need to be reachable + client.succeed("pvfs2-check-server -h server1 -f orangefs -n tcp -p 3334") + client.succeed("pvfs2-check-server -h server2 -f orangefs -n tcp -p 3334") + client.wait_for_unit("orangefs.mount") - with subtest("R/W test between clients"): - client1.succeed("echo test > /orangefs/file1") - client2.succeed("grep test /orangefs/file1") - ''; -}) + with subtest("R/W test between clients"): + client1.succeed("echo test > /orangefs/file1") + client2.succeed("grep test /orangefs/file1") + ''; + } +) diff --git a/nixos/tests/os-prober.nix b/nixos/tests/os-prober.nix index 18b646c8089046..529bd9df48a75e 100644 --- a/nixos/tests/os-prober.nix +++ b/nixos/tests/os-prober.nix @@ -1,141 +1,151 @@ -import ./make-test-python.nix ({pkgs, lib, ...}: -let - # A filesystem image with a (presumably) bootable debian - debianImage = pkgs.vmTools.diskImageFuns.debian11i386 { - # os-prober cannot detect systems installed on disks without a partition table - # so we create the disk ourselves - createRootFS = with pkgs; '' - ${parted}/bin/parted --script /dev/vda mklabel msdos - ${parted}/sbin/parted --script /dev/vda -- mkpart primary ext2 1M -1s - mkdir /mnt - ${e2fsprogs}/bin/mkfs.ext4 -O '^metadata_csum_seed' /dev/vda1 - ${util-linux}/bin/mount -t ext4 /dev/vda1 /mnt +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + # A filesystem image with a (presumably) bootable debian + debianImage = pkgs.vmTools.diskImageFuns.debian11i386 { + # os-prober cannot detect systems installed on disks without a partition table + # so we create the disk ourselves + createRootFS = with pkgs; '' + ${parted}/bin/parted --script /dev/vda mklabel msdos + ${parted}/sbin/parted --script /dev/vda -- mkpart primary ext2 1M -1s + mkdir /mnt + ${e2fsprogs}/bin/mkfs.ext4 -O '^metadata_csum_seed' /dev/vda1 + ${util-linux}/bin/mount -t ext4 /dev/vda1 /mnt - if test -e /mnt/.debug; then - exec ${bash}/bin/sh - fi - touch /mnt/.debug + if test -e /mnt/.debug; then + exec ${bash}/bin/sh + fi + touch /mnt/.debug - mkdir /mnt/proc /mnt/dev /mnt/sys - ''; - extraPackages = [ - # /etc/os-release - "base-files" - # make the disk bootable-looking - "grub2" "linux-image-686" - ]; - # install grub - postInstall = '' - ln -sf /proc/self/mounts > /etc/mtab - PATH=/usr/bin:/bin:/usr/sbin:/sbin $chroot /mnt \ - grub-install /dev/vda --force - PATH=/usr/bin:/bin:/usr/sbin:/sbin $chroot /mnt \ - update-grub - ''; - }; - - # a part of the configuration of the test vm - simpleConfig = { - boot.loader.grub = { - enable = true; - useOSProber = true; - device = "/dev/vda"; - # vda is a filesystem without partition table - forceInstall = true; + mkdir /mnt/proc /mnt/dev /mnt/sys + ''; + extraPackages = [ + # /etc/os-release + "base-files" + # make the disk bootable-looking + "grub2" + "linux-image-686" + ]; + # install grub + postInstall = '' + ln -sf /proc/self/mounts > /etc/mtab + PATH=/usr/bin:/bin:/usr/sbin:/sbin $chroot /mnt \ + grub-install /dev/vda --force + PATH=/usr/bin:/bin:/usr/sbin:/sbin $chroot /mnt \ + update-grub + ''; }; - nix.settings = { - substituters = lib.mkForce []; - hashed-mirrors = null; - connect-timeout = 1; + + # a part of the configuration of the test vm + simpleConfig = { + boot.loader.grub = { + enable = true; + useOSProber = true; + device = "/dev/vda"; + # vda is a filesystem without partition table + forceInstall = true; + }; + nix.settings = { + substituters = lib.mkForce [ ]; + hashed-mirrors = null; + connect-timeout = 1; + }; + # save some memory + documentation.enable = false; }; - # save some memory - documentation.enable = false; - }; - # /etc/nixos/configuration.nix for the vm - configFile = pkgs.writeText "configuration.nix" '' - {config, pkgs, lib, ...}: ({ - imports = - [ ./hardware-configuration.nix - - ]; - } // lib.importJSON ${ - pkgs.writeText "simpleConfig.json" (builtins.toJSON simpleConfig) - }) - ''; -in { - name = "os-prober"; + # /etc/nixos/configuration.nix for the vm + configFile = pkgs.writeText "configuration.nix" '' + {config, pkgs, lib, ...}: ({ + imports = + [ ./hardware-configuration.nix + + ]; + } // lib.importJSON ${pkgs.writeText "simpleConfig.json" (builtins.toJSON simpleConfig)}) + ''; + in + { + name = "os-prober"; - nodes.machine = { config, pkgs, ... }: (simpleConfig // { - imports = [ ../modules/profiles/installation-device.nix - ../modules/profiles/base.nix ]; - virtualisation.memorySize = 1300; - # To add the secondary disk: - virtualisation.qemu.options = [ "-drive index=2,file=${debianImage}/disk-image.qcow2,read-only,if=virtio" ]; + nodes.machine = + { config, pkgs, ... }: + ( + simpleConfig + // { + imports = [ + ../modules/profiles/installation-device.nix + ../modules/profiles/base.nix + ]; + virtualisation.memorySize = 1300; + # To add the secondary disk: + virtualisation.qemu.options = [ + "-drive index=2,file=${debianImage}/disk-image.qcow2,read-only,if=virtio" + ]; - # The test cannot access the network, so any packages - # nixos-rebuild needs must be included in the VM. - system.extraDependencies = with pkgs; - [ - bintools - brotli - brotli.dev - brotli.lib - desktop-file-utils - docbook5 - docbook_xsl_ns - grub2 - nixos-artwork.wallpapers.simple-dark-gray-bootloader - perlPackages.FileCopyRecursive - perlPackages.XMLSAX - perlPackages.XMLSAXBase - kbd - kbd.dev - kmod.dev - libarchive - libarchive.dev - libxml2.bin - libxslt.bin - nixos-artwork.wallpapers.simple-dark-gray-bottom - perlPackages.ConfigIniFiles - perlPackages.FileSlurp - perlPackages.JSON - perlPackages.ListCompare - perlPackages.XMLLibXML - # make-options-doc/default.nix - (python3.withPackages (p: [ p.mistune ])) - shared-mime-info - sudo - switch-to-configuration-ng - texinfo - unionfs-fuse - xorg.lndir - os-prober + # The test cannot access the network, so any packages + # nixos-rebuild needs must be included in the VM. + system.extraDependencies = with pkgs; [ + bintools + brotli + brotli.dev + brotli.lib + desktop-file-utils + docbook5 + docbook_xsl_ns + grub2 + nixos-artwork.wallpapers.simple-dark-gray-bootloader + perlPackages.FileCopyRecursive + perlPackages.XMLSAX + perlPackages.XMLSAXBase + kbd + kbd.dev + kmod.dev + libarchive + libarchive.dev + libxml2.bin + libxslt.bin + nixos-artwork.wallpapers.simple-dark-gray-bottom + perlPackages.ConfigIniFiles + perlPackages.FileSlurp + perlPackages.JSON + perlPackages.ListCompare + perlPackages.XMLLibXML + # make-options-doc/default.nix + (python3.withPackages (p: [ p.mistune ])) + shared-mime-info + sudo + switch-to-configuration-ng + texinfo + unionfs-fuse + xorg.lndir + os-prober - # add curl so that rather than seeing the test attempt to download - # curl's tarball, we see what it's trying to download - curl - ]; - }); + # add curl so that rather than seeing the test attempt to download + # curl's tarball, we see what it's trying to download + curl + ]; + } + ); - testScript = '' - machine.start() - machine.succeed("udevadm settle") - machine.wait_for_unit("multi-user.target") - print(machine.succeed("lsblk")) + testScript = '' + machine.start() + machine.succeed("udevadm settle") + machine.wait_for_unit("multi-user.target") + print(machine.succeed("lsblk")) - # check that os-prober works standalone - machine.succeed( - "${pkgs.os-prober}/bin/os-prober | grep /dev/vdb1" - ) + # check that os-prober works standalone + machine.succeed( + "${pkgs.os-prober}/bin/os-prober | grep /dev/vdb1" + ) - # rebuild and test that debian is available in the grub menu - machine.succeed("nixos-generate-config") - machine.copy_from_host( - "${configFile}", - "/etc/nixos/configuration.nix", - ) - machine.succeed("nixos-rebuild boot --show-trace >&2") + # rebuild and test that debian is available in the grub menu + machine.succeed("nixos-generate-config") + machine.copy_from_host( + "${configFile}", + "/etc/nixos/configuration.nix", + ) + machine.succeed("nixos-rebuild boot --show-trace >&2") - machine.succeed("egrep 'menuentry.*debian' /boot/grub/grub.cfg") - ''; -}) + machine.succeed("egrep 'menuentry.*debian' /boot/grub/grub.cfg") + ''; + } +) diff --git a/nixos/tests/osquery.nix b/nixos/tests/osquery.nix index e98e7c1baf0484..5faf2f34374050 100644 --- a/nixos/tests/osquery.nix +++ b/nixos/tests/osquery.nix @@ -1,52 +1,60 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: - -let - config_refresh = "10"; - nullvalue = "NULL"; - utc = false; -in -{ - name = "osquery"; - meta.maintainers = with lib.maintainers; [ znewman01 lewo ]; - - nodes.machine = { config, pkgs, ... }: { - services.osquery = { - enable = true; - - settings.options = { inherit nullvalue utc; }; - flags = { - inherit config_refresh; - nullvalue = "IGNORED"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + + let + config_refresh = "10"; + nullvalue = "NULL"; + utc = false; + in + { + name = "osquery"; + meta.maintainers = with lib.maintainers; [ + znewman01 + lewo + ]; + + nodes.machine = + { config, pkgs, ... }: + { + services.osquery = { + enable = true; + + settings.options = { inherit nullvalue utc; }; + flags = { + inherit config_refresh; + nullvalue = "IGNORED"; + }; + }; }; - }; - }; - - testScript = { nodes, ... }: - let - cfg = nodes.machine.services.osquery; - in - '' - machine.start() - machine.wait_for_unit("osqueryd.service") - - # Stop the osqueryd service so that we can use osqueryi to check information stored in the database. - machine.wait_until_succeeds("systemctl stop osqueryd.service") - - # osqueryd was able to query information about the host. - machine.succeed("echo 'SELECT address FROM etc_hosts LIMIT 1;' | osqueryi | tee /dev/console | grep -q '127.0.0.1'") - - # osquery binaries respect configuration from the Nix config option. - machine.succeed("echo 'SELECT value FROM osquery_flags WHERE name = \"utc\";' | osqueryi | tee /dev/console | grep -q ${lib.boolToString utc}") - - # osquery binaries respect configuration from the Nix flags option. - machine.succeed("echo 'SELECT value FROM osquery_flags WHERE name = \"config_refresh\";' | osqueryi | tee /dev/console | grep -q ${config_refresh}") - - # Demonstrate that osquery binaries prefer configuration plugin options over CLI flags. - # https://osquery.readthedocs.io/en/latest/deployment/configuration/#options. - machine.succeed("echo 'SELECT value FROM osquery_flags WHERE name = \"nullvalue\";' | osqueryi | tee /dev/console | grep -q ${nullvalue}") - - # Module creates directories for default database_path and pidfile flag values. - machine.succeed("test -d $(dirname ${cfg.flags.database_path})") - machine.succeed("test -d $(dirname ${cfg.flags.pidfile})") - ''; -}) + + testScript = + { nodes, ... }: + let + cfg = nodes.machine.services.osquery; + in + '' + machine.start() + machine.wait_for_unit("osqueryd.service") + + # Stop the osqueryd service so that we can use osqueryi to check information stored in the database. + machine.wait_until_succeeds("systemctl stop osqueryd.service") + + # osqueryd was able to query information about the host. + machine.succeed("echo 'SELECT address FROM etc_hosts LIMIT 1;' | osqueryi | tee /dev/console | grep -q '127.0.0.1'") + + # osquery binaries respect configuration from the Nix config option. + machine.succeed("echo 'SELECT value FROM osquery_flags WHERE name = \"utc\";' | osqueryi | tee /dev/console | grep -q ${lib.boolToString utc}") + + # osquery binaries respect configuration from the Nix flags option. + machine.succeed("echo 'SELECT value FROM osquery_flags WHERE name = \"config_refresh\";' | osqueryi | tee /dev/console | grep -q ${config_refresh}") + + # Demonstrate that osquery binaries prefer configuration plugin options over CLI flags. + # https://osquery.readthedocs.io/en/latest/deployment/configuration/#options. + machine.succeed("echo 'SELECT value FROM osquery_flags WHERE name = \"nullvalue\";' | osqueryi | tee /dev/console | grep -q ${nullvalue}") + + # Module creates directories for default database_path and pidfile flag values. + machine.succeed("test -d $(dirname ${cfg.flags.database_path})") + machine.succeed("test -d $(dirname ${cfg.flags.pidfile})") + ''; + } +) diff --git a/nixos/tests/osrm-backend.nix b/nixos/tests/osrm-backend.nix index b0e65a2ae1c108..3044504308889c 100644 --- a/nixos/tests/osrm-backend.nix +++ b/nixos/tests/osrm-backend.nix @@ -1,57 +1,66 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - port = 5000; -in { - name = "osrm-backend"; - meta.maintainers = [ lib.maintainers.erictapen ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + port = 5000; + in + { + name = "osrm-backend"; + meta.maintainers = [ lib.maintainers.erictapen ]; - nodes.machine = { config, pkgs, ... }:{ + nodes.machine = + { config, pkgs, ... }: + { - services.osrm = { - enable = true; - inherit port; - dataFile = let - filename = "monaco"; - osrm-data = pkgs.stdenv.mkDerivation { - name = "osrm-data"; + services.osrm = { + enable = true; + inherit port; + dataFile = + let + filename = "monaco"; + osrm-data = pkgs.stdenv.mkDerivation { + name = "osrm-data"; - buildInputs = [ pkgs.osrm-backend ]; + buildInputs = [ pkgs.osrm-backend ]; - # This is a pbf file of monaco, downloaded at 2019-01-04 from - # http://download.geofabrik.de/europe/monaco-latest.osm.pbf - # as apparently no provider of OSM files guarantees immutability, - # this is hosted as a gist on GitHub. - src = pkgs.fetchgit { - url = "https://gist.github.com/erictapen/01e39f73a6c856eac53ba809a94cdb83"; - rev = "9b1ff0f24deb40e5cf7df51f843dbe860637b8ce"; - sha256 = "1scqhmrfnpwsy5i2a9jpggqnvfgj4hv9p4qyvc79321pzkbv59nx"; - }; + # This is a pbf file of monaco, downloaded at 2019-01-04 from + # http://download.geofabrik.de/europe/monaco-latest.osm.pbf + # as apparently no provider of OSM files guarantees immutability, + # this is hosted as a gist on GitHub. + src = pkgs.fetchgit { + url = "https://gist.github.com/erictapen/01e39f73a6c856eac53ba809a94cdb83"; + rev = "9b1ff0f24deb40e5cf7df51f843dbe860637b8ce"; + sha256 = "1scqhmrfnpwsy5i2a9jpggqnvfgj4hv9p4qyvc79321pzkbv59nx"; + }; - buildCommand = '' - cp $src/${filename}.osm.pbf . - ${pkgs.osrm-backend}/bin/osrm-extract -p ${pkgs.osrm-backend}/share/osrm/profiles/car.lua ${filename}.osm.pbf - ${pkgs.osrm-backend}/bin/osrm-partition ${filename}.osrm - ${pkgs.osrm-backend}/bin/osrm-customize ${filename}.osrm - mkdir -p $out - cp ${filename}* $out/ - ''; + buildCommand = '' + cp $src/${filename}.osm.pbf . + ${pkgs.osrm-backend}/bin/osrm-extract -p ${pkgs.osrm-backend}/share/osrm/profiles/car.lua ${filename}.osm.pbf + ${pkgs.osrm-backend}/bin/osrm-partition ${filename}.osrm + ${pkgs.osrm-backend}/bin/osrm-customize ${filename}.osrm + mkdir -p $out + cp ${filename}* $out/ + ''; + }; + in + "${osrm-data}/${filename}.osrm"; }; - in "${osrm-data}/${filename}.osrm"; - }; - environment.systemPackages = [ pkgs.jq ]; - }; + environment.systemPackages = [ pkgs.jq ]; + }; - testScript = let - query = "http://localhost:${toString port}/route/v1/driving/7.41720,43.73304;7.42463,43.73886?steps=true"; - in '' - machine.wait_for_unit("osrm.service") - machine.wait_for_open_port(${toString port}) - assert "Boulevard Rainier III" in machine.succeed( - "curl --fail --silent '${query}' | jq .waypoints[0].name" - ) - assert "Avenue de la Costa" in machine.succeed( - "curl --fail --silent '${query}' | jq .waypoints[1].name" - ) - ''; -}) + testScript = + let + query = "http://localhost:${toString port}/route/v1/driving/7.41720,43.73304;7.42463,43.73886?steps=true"; + in + '' + machine.wait_for_unit("osrm.service") + machine.wait_for_open_port(${toString port}) + assert "Boulevard Rainier III" in machine.succeed( + "curl --fail --silent '${query}' | jq .waypoints[0].name" + ) + assert "Avenue de la Costa" in machine.succeed( + "curl --fail --silent '${query}' | jq .waypoints[1].name" + ) + ''; + } +) diff --git a/nixos/tests/outline.nix b/nixos/tests/outline.nix index c7a34c5d6f85ee..52f46f53387848 100644 --- a/nixos/tests/outline.nix +++ b/nixos/tests/outline.nix @@ -1,43 +1,45 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - accessKey = "BKIKJAA5BMMU2RHO6IBB"; - secretKey = "V7f1CwQqAcwo80UEIJEjc5gVQUSSx5ohQ9GSrr12"; - secretKeyFile = pkgs.writeText "outline-secret-key" '' - ${secretKey} - ''; - rootCredentialsFile = pkgs.writeText "minio-credentials-full" '' - MINIO_ROOT_USER=${accessKey} - MINIO_ROOT_PASSWORD=${secretKey} - ''; -in -{ - name = "outline"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + accessKey = "BKIKJAA5BMMU2RHO6IBB"; + secretKey = "V7f1CwQqAcwo80UEIJEjc5gVQUSSx5ohQ9GSrr12"; + secretKeyFile = pkgs.writeText "outline-secret-key" '' + ${secretKey} + ''; + rootCredentialsFile = pkgs.writeText "minio-credentials-full" '' + MINIO_ROOT_USER=${accessKey} + MINIO_ROOT_PASSWORD=${secretKey} + ''; + in + { + name = "outline"; - meta.maintainers = lib.teams.cyberus.members; + meta.maintainers = lib.teams.cyberus.members; - nodes = { - outline = { pkgs, config, ... }: { - nixpkgs.config.allowUnfree = true; - environment.systemPackages = [ pkgs.minio-client ]; - services.outline = { - enable = true; - forceHttps = false; - storage = { - inherit accessKey secretKeyFile; - uploadBucketUrl = "http://localhost:9000"; - uploadBucketName = "outline"; - region = config.services.minio.region; + nodes = { + outline = + { pkgs, config, ... }: + { + nixpkgs.config.allowUnfree = true; + environment.systemPackages = [ pkgs.minio-client ]; + services.outline = { + enable = true; + forceHttps = false; + storage = { + inherit accessKey secretKeyFile; + uploadBucketUrl = "http://localhost:9000"; + uploadBucketName = "outline"; + region = config.services.minio.region; + }; + }; + services.minio = { + enable = true; + inherit rootCredentialsFile; + }; }; - }; - services.minio = { - enable = true; - inherit rootCredentialsFile; - }; }; - }; - testScript = - '' + testScript = '' machine.wait_for_unit("minio.service") machine.wait_for_open_port(9000) @@ -51,4 +53,5 @@ in outline.wait_for_open_port(3000) outline.succeed("curl --fail http://localhost:3000/") ''; -}) + } +) diff --git a/nixos/tests/overlayfs.nix b/nixos/tests/overlayfs.nix index 6dab6760c5b990..cd4843229943f9 100644 --- a/nixos/tests/overlayfs.nix +++ b/nixos/tests/overlayfs.nix @@ -1,47 +1,52 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "overlayfs"; - meta.maintainers = with pkgs.lib.maintainers; [ bachp ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "overlayfs"; + meta.maintainers = with pkgs.lib.maintainers; [ bachp ]; - nodes.machine = { pkgs, ... }: { - virtualisation.emptyDiskImages = [ 512 ]; - networking.hostId = "deadbeef"; - environment.systemPackages = with pkgs; [ parted ]; - }; + nodes.machine = + { pkgs, ... }: + { + virtualisation.emptyDiskImages = [ 512 ]; + networking.hostId = "deadbeef"; + environment.systemPackages = with pkgs; [ parted ]; + }; - testScript = '' - machine.succeed("ls /dev") + testScript = '' + machine.succeed("ls /dev") - machine.succeed("mkdir -p /tmp/mnt") + machine.succeed("mkdir -p /tmp/mnt") - # Test ext4 + overlayfs - machine.succeed( - 'mkfs.ext4 -F -L overlay-ext4 /dev/vdb', - 'mount -t ext4 /dev/vdb /tmp/mnt', - 'mkdir -p /tmp/mnt/upper /tmp/mnt/lower /tmp/mnt/work /tmp/mnt/merged', - # Setup some existing files - 'echo Replace > /tmp/mnt/lower/replace.txt', - 'echo Append > /tmp/mnt/lower/append.txt', - 'echo Overwrite > /tmp/mnt/lower/overwrite.txt', - 'mount -t overlay overlay -o lowerdir=/tmp/mnt/lower,upperdir=/tmp/mnt/upper,workdir=/tmp/mnt/work /tmp/mnt/merged', - # Test new - 'echo New > /tmp/mnt/merged/new.txt', - '[[ "$(cat /tmp/mnt/merged/new.txt)" == New ]]', - # Test replace - '[[ "$(cat /tmp/mnt/merged/replace.txt)" == Replace ]]', - 'echo Replaced > /tmp/mnt/merged/replace-tmp.txt', - 'mv /tmp/mnt/merged/replace-tmp.txt /tmp/mnt/merged/replace.txt', - '[[ "$(cat /tmp/mnt/merged/replace.txt)" == Replaced ]]', - # Overwrite - '[[ "$(cat /tmp/mnt/merged/overwrite.txt)" == Overwrite ]]', - 'echo Overwritten > /tmp/mnt/merged/overwrite.txt', - '[[ "$(cat /tmp/mnt/merged/overwrite.txt)" == Overwritten ]]', - # Test append - '[[ "$(cat /tmp/mnt/merged/append.txt)" == Append ]]', - 'echo ed >> /tmp/mnt/merged/append.txt', - '[[ "$(cat /tmp/mnt/merged/append.txt)" == "Append\ned" ]]', - 'umount /tmp/mnt/merged', - 'umount /tmp/mnt', - 'udevadm settle', - ) - ''; -}) + # Test ext4 + overlayfs + machine.succeed( + 'mkfs.ext4 -F -L overlay-ext4 /dev/vdb', + 'mount -t ext4 /dev/vdb /tmp/mnt', + 'mkdir -p /tmp/mnt/upper /tmp/mnt/lower /tmp/mnt/work /tmp/mnt/merged', + # Setup some existing files + 'echo Replace > /tmp/mnt/lower/replace.txt', + 'echo Append > /tmp/mnt/lower/append.txt', + 'echo Overwrite > /tmp/mnt/lower/overwrite.txt', + 'mount -t overlay overlay -o lowerdir=/tmp/mnt/lower,upperdir=/tmp/mnt/upper,workdir=/tmp/mnt/work /tmp/mnt/merged', + # Test new + 'echo New > /tmp/mnt/merged/new.txt', + '[[ "$(cat /tmp/mnt/merged/new.txt)" == New ]]', + # Test replace + '[[ "$(cat /tmp/mnt/merged/replace.txt)" == Replace ]]', + 'echo Replaced > /tmp/mnt/merged/replace-tmp.txt', + 'mv /tmp/mnt/merged/replace-tmp.txt /tmp/mnt/merged/replace.txt', + '[[ "$(cat /tmp/mnt/merged/replace.txt)" == Replaced ]]', + # Overwrite + '[[ "$(cat /tmp/mnt/merged/overwrite.txt)" == Overwrite ]]', + 'echo Overwritten > /tmp/mnt/merged/overwrite.txt', + '[[ "$(cat /tmp/mnt/merged/overwrite.txt)" == Overwritten ]]', + # Test append + '[[ "$(cat /tmp/mnt/merged/append.txt)" == Append ]]', + 'echo ed >> /tmp/mnt/merged/append.txt', + '[[ "$(cat /tmp/mnt/merged/append.txt)" == "Append\ned" ]]', + 'umount /tmp/mnt/merged', + 'umount /tmp/mnt', + 'udevadm settle', + ) + ''; + } +) diff --git a/nixos/tests/owncast.nix b/nixos/tests/owncast.nix index 73aac4e704751c..a081cd5b544d39 100644 --- a/nixos/tests/owncast.nix +++ b/nixos/tests/owncast.nix @@ -1,44 +1,75 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "owncast"; - meta = with pkgs.lib.maintainers; { maintainers = [ MayNiklas ]; }; - - nodes = { - client = { pkgs, ... }: with pkgs.lib; { - networking = { - dhcpcd.enable = false; - interfaces.eth1.ipv6.addresses = mkOverride 0 [ { address = "fd00::2"; prefixLength = 64; } ]; - interfaces.eth1.ipv4.addresses = mkOverride 0 [ { address = "192.168.1.2"; prefixLength = 24; } ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "owncast"; + meta = with pkgs.lib.maintainers; { + maintainers = [ MayNiklas ]; }; - server = { pkgs, ... }: with pkgs.lib; { - networking = { - dhcpcd.enable = false; - useNetworkd = true; - useDHCP = false; - interfaces.eth1.ipv6.addresses = mkOverride 0 [ { address = "fd00::1"; prefixLength = 64; } ]; - interfaces.eth1.ipv4.addresses = mkOverride 0 [ { address = "192.168.1.1"; prefixLength = 24; } ]; - firewall.allowedTCPPorts = [ 8080 ]; - }; + nodes = { + client = + { pkgs, ... }: + with pkgs.lib; + { + networking = { + dhcpcd.enable = false; + interfaces.eth1.ipv6.addresses = mkOverride 0 [ + { + address = "fd00::2"; + prefixLength = 64; + } + ]; + interfaces.eth1.ipv4.addresses = mkOverride 0 [ + { + address = "192.168.1.2"; + prefixLength = 24; + } + ]; + }; + }; + server = + { pkgs, ... }: + with pkgs.lib; + { + networking = { + dhcpcd.enable = false; + useNetworkd = true; + useDHCP = false; + interfaces.eth1.ipv6.addresses = mkOverride 0 [ + { + address = "fd00::1"; + prefixLength = 64; + } + ]; + interfaces.eth1.ipv4.addresses = mkOverride 0 [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; + + firewall.allowedTCPPorts = [ 8080 ]; + }; - services.owncast = { - enable = true; - listen = "0.0.0.0"; - }; + services.owncast = { + enable = true; + listen = "0.0.0.0"; + }; + }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - client.systemctl("start network-online.target") - server.systemctl("start network-online.target") - client.wait_for_unit("network-online.target") - server.wait_for_unit("network-online.target") - server.wait_for_unit("owncast.service") - server.wait_until_succeeds("ss -ntl | grep -q 8080") + client.systemctl("start network-online.target") + server.systemctl("start network-online.target") + client.wait_for_unit("network-online.target") + server.wait_for_unit("network-online.target") + server.wait_for_unit("owncast.service") + server.wait_until_succeeds("ss -ntl | grep -q 8080") - client.succeed("curl http://192.168.1.1:8080/api/status") - client.succeed("curl http://[fd00::1]:8080/api/status") - ''; -}) + client.succeed("curl http://192.168.1.1:8080/api/status") + client.succeed("curl http://[fd00::1]:8080/api/status") + ''; + } +) diff --git a/nixos/tests/pacemaker.nix b/nixos/tests/pacemaker.nix index 68455761495373..6b711ad945520a 100644 --- a/nixos/tests/pacemaker.nix +++ b/nixos/tests/pacemaker.nix @@ -1,110 +1,118 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: rec { - name = "pacemaker"; - meta = with pkgs.lib.maintainers; { - maintainers = [ astro ]; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + rec { + name = "pacemaker"; + meta = with pkgs.lib.maintainers; { + maintainers = [ astro ]; + }; - nodes = - let - node = i: { - networking.interfaces.eth1.ipv4.addresses = [ { - address = "192.168.0.${toString i}"; - prefixLength = 24; - } ]; + nodes = + let + node = i: { + networking.interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.0.${toString i}"; + prefixLength = 24; + } + ]; - services.corosync = { - enable = true; - clusterName = "zentralwerk-network"; - nodelist = lib.imap (i: name: { - nodeid = i; - inherit name; - ring_addrs = [ - (builtins.head nodes.${name}.networking.interfaces.eth1.ipv4.addresses).address - ]; - }) (builtins.attrNames nodes); - }; - environment.etc."corosync/authkey" = { - source = builtins.toFile "authkey" - # minimum length: 128 bytes - "testtesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttest"; - mode = "0400"; - }; + services.corosync = { + enable = true; + clusterName = "zentralwerk-network"; + nodelist = lib.imap (i: name: { + nodeid = i; + inherit name; + ring_addrs = [ + (builtins.head nodes.${name}.networking.interfaces.eth1.ipv4.addresses).address + ]; + }) (builtins.attrNames nodes); + }; + environment.etc."corosync/authkey" = { + source = + builtins.toFile "authkey" + # minimum length: 128 bytes + "testtesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttest"; + mode = "0400"; + }; - services.pacemaker.enable = true; + services.pacemaker.enable = true; - # used for pacemaker resource - systemd.services.ha-cat = { - description = "Highly available netcat"; - serviceConfig.ExecStart = "${pkgs.netcat}/bin/nc -l discard"; + # used for pacemaker resource + systemd.services.ha-cat = { + description = "Highly available netcat"; + serviceConfig.ExecStart = "${pkgs.netcat}/bin/nc -l discard"; + }; }; + in + { + node1 = node 1; + node2 = node 2; + node3 = node 3; }; - in { - node1 = node 1; - node2 = node 2; - node3 = node 3; - }; - # sets up pacemaker with resources configuration, then crashes a - # node and waits for service restart on another node - testScript = - let - resources = builtins.toFile "cib-resources.xml" '' - - - - - - - - - - ''; - in '' - import re - import time + # sets up pacemaker with resources configuration, then crashes a + # node and waits for service restart on another node + testScript = + let + resources = builtins.toFile "cib-resources.xml" '' + + + + + + + + + + ''; + in + '' + import re + import time - start_all() + start_all() - ${lib.concatMapStrings (node: '' - ${node}.wait_until_succeeds("corosync-quorumtool") - ${node}.wait_for_unit("pacemaker.service") - '') (builtins.attrNames nodes)} + ${lib.concatMapStrings (node: '' + ${node}.wait_until_succeeds("corosync-quorumtool") + ${node}.wait_for_unit("pacemaker.service") + '') (builtins.attrNames nodes)} - # No STONITH device - node1.succeed("crm_attribute -t crm_config -n stonith-enabled -v false") - # Configure the cat resource - node1.succeed("cibadmin --replace --scope resources --xml-file ${resources}") + # No STONITH device + node1.succeed("crm_attribute -t crm_config -n stonith-enabled -v false") + # Configure the cat resource + node1.succeed("cibadmin --replace --scope resources --xml-file ${resources}") - # wait until the service is started - while True: - output = node1.succeed("crm_resource -r cat --locate") - match = re.search("is running on: (.+)", output) - if match: - for machine in machines: - if machine.name == match.group(1): - current_node = machine - break - time.sleep(1) + # wait until the service is started + while True: + output = node1.succeed("crm_resource -r cat --locate") + match = re.search("is running on: (.+)", output) + if match: + for machine in machines: + if machine.name == match.group(1): + current_node = machine + break + time.sleep(1) - current_node.log("Service running here!") - current_node.crash() + current_node.log("Service running here!") + current_node.crash() - # pick another node that's still up - for machine in machines: - if machine.booted: - check_node = machine - # find where the service has been started next - while True: - output = check_node.succeed("crm_resource -r cat --locate") - match = re.search("is running on: (.+)", output) - # output will remain the old current_node until the crash is detected by pacemaker - if match and match.group(1) != current_node.name: - for machine in machines: - if machine.name == match.group(1): - next_node = machine - break - time.sleep(1) + # pick another node that's still up + for machine in machines: + if machine.booted: + check_node = machine + # find where the service has been started next + while True: + output = check_node.succeed("crm_resource -r cat --locate") + match = re.search("is running on: (.+)", output) + # output will remain the old current_node until the crash is detected by pacemaker + if match and match.group(1) != current_node.name: + for machine in machines: + if machine.name == match.group(1): + next_node = machine + break + time.sleep(1) - next_node.log("Service migrated here!") - ''; -}) + next_node.log("Service migrated here!") + ''; + } +) diff --git a/nixos/tests/packagekit.nix b/nixos/tests/packagekit.nix index 5769c6c9a8d45e..1dc248217b1106 100644 --- a/nixos/tests/packagekit.nix +++ b/nixos/tests/packagekit.nix @@ -1,25 +1,30 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "packagekit"; - meta = with pkgs.lib.maintainers; { - maintainers = [ peterhoeg ]; - }; - - nodes.machine = { ... }: { - environment.systemPackages = with pkgs; [ dbus ]; - services.packagekit = { - enable = true; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "packagekit"; + meta = with pkgs.lib.maintainers; { + maintainers = [ peterhoeg ]; }; - }; - testScript = '' - start_all() + nodes.machine = + { ... }: + { + environment.systemPackages = with pkgs; [ dbus ]; + services.packagekit = { + enable = true; + }; + }; + + testScript = '' + start_all() - # send a dbus message to activate the service - machine.succeed( - "dbus-send --system --type=method_call --print-reply --dest=org.freedesktop.PackageKit /org/freedesktop/PackageKit org.freedesktop.DBus.Introspectable.Introspect" - ) + # send a dbus message to activate the service + machine.succeed( + "dbus-send --system --type=method_call --print-reply --dest=org.freedesktop.PackageKit /org/freedesktop/PackageKit org.freedesktop.DBus.Introspectable.Introspect" + ) - # so now it should be running - machine.wait_for_unit("packagekit.service") - ''; -}) + # so now it should be running + machine.wait_for_unit("packagekit.service") + ''; + } +) diff --git a/nixos/tests/pam/pam-oath-login.nix b/nixos/tests/pam/pam-oath-login.nix index dd6ef4a0abcb8e..25602b72d35c7a 100644 --- a/nixos/tests/pam/pam-oath-login.nix +++ b/nixos/tests/pam/pam-oath-login.nix @@ -1,108 +1,109 @@ -import ../make-test-python.nix ({ ... }: - -let - oathSnakeoilSecret = "cdd4083ef8ff1fa9178c6d46bfb1a3"; - - # With HOTP mode the password is calculated based on a counter of - # how many passwords have been made. In this env, we'll always be on - # the 0th counter, so the password is static. - # - # Generated in nix-shell -p oath-toolkit - # via: oathtool -v -d6 -w10 cdd4083ef8ff1fa9178c6d46bfb1a3 - # and picking a the first 4: - oathSnakeOilPassword1 = "143349"; - oathSnakeOilPassword2 = "801753"; - - alicePassword = "foobar"; - # Generated via: mkpasswd -m sha-512 and passing in "foobar" - hashedAlicePassword = "$6$MsMrE1q.1HrCgTS$Vq2e/uILzYjSN836TobAyN9xh9oi7EmCmucnZID25qgPoibkw8qTCugiAPnn4eCGvn1A.7oEBFJaaGUaJsQQY."; - -in -{ - name = "pam-oath-login"; - - nodes.machine = - { ... }: - { - security.pam.oath = { - enable = true; - }; - - users.users.alice = { - isNormalUser = true; - name = "alice"; - uid = 1000; - hashedPassword = hashedAlicePassword; - extraGroups = [ "wheel" ]; - createHome = true; - home = "/home/alice"; - }; +import ../make-test-python.nix ( + { ... }: + + let + oathSnakeoilSecret = "cdd4083ef8ff1fa9178c6d46bfb1a3"; + + # With HOTP mode the password is calculated based on a counter of + # how many passwords have been made. In this env, we'll always be on + # the 0th counter, so the password is static. + # + # Generated in nix-shell -p oath-toolkit + # via: oathtool -v -d6 -w10 cdd4083ef8ff1fa9178c6d46bfb1a3 + # and picking a the first 4: + oathSnakeOilPassword1 = "143349"; + oathSnakeOilPassword2 = "801753"; + + alicePassword = "foobar"; + # Generated via: mkpasswd -m sha-512 and passing in "foobar" + hashedAlicePassword = "$6$MsMrE1q.1HrCgTS$Vq2e/uILzYjSN836TobAyN9xh9oi7EmCmucnZID25qgPoibkw8qTCugiAPnn4eCGvn1A.7oEBFJaaGUaJsQQY."; + + in + { + name = "pam-oath-login"; + + nodes.machine = + { ... }: + { + security.pam.oath = { + enable = true; + }; + users.users.alice = { + isNormalUser = true; + name = "alice"; + uid = 1000; + hashedPassword = hashedAlicePassword; + extraGroups = [ "wheel" ]; + createHome = true; + home = "/home/alice"; + }; - systemd.services.setupOathSnakeoilFile = { - wantedBy = [ "default.target" ]; - before = [ "default.target" ]; - unitConfig = { - type = "oneshot"; - RemainAfterExit = true; + systemd.services.setupOathSnakeoilFile = { + wantedBy = [ "default.target" ]; + before = [ "default.target" ]; + unitConfig = { + type = "oneshot"; + RemainAfterExit = true; + }; + script = '' + touch /etc/users.oath + chmod 600 /etc/users.oath + chown root /etc/users.oath + echo "HOTP/E/6 alice - ${oathSnakeoilSecret}" > /etc/users.oath + ''; }; - script = '' - touch /etc/users.oath - chmod 600 /etc/users.oath - chown root /etc/users.oath - echo "HOTP/E/6 alice - ${oathSnakeoilSecret}" > /etc/users.oath - ''; }; - }; - testScript = '' - def switch_to_tty(tty_number): - machine.fail(f"pgrep -f 'agetty.*tty{tty_number}'") - machine.send_key(f"alt-f{tty_number}") - machine.wait_until_succeeds(f"[ $(fgconsole) = {tty_number} ]") - machine.wait_for_unit(f"getty@tty{tty_number}.service") - machine.wait_until_succeeds(f"pgrep -f 'agetty.*tty{tty_number}'") + testScript = '' + def switch_to_tty(tty_number): + machine.fail(f"pgrep -f 'agetty.*tty{tty_number}'") + machine.send_key(f"alt-f{tty_number}") + machine.wait_until_succeeds(f"[ $(fgconsole) = {tty_number} ]") + machine.wait_for_unit(f"getty@tty{tty_number}.service") + machine.wait_until_succeeds(f"pgrep -f 'agetty.*tty{tty_number}'") - def enter_user_alice(tty_number): - machine.wait_until_tty_matches(tty_number, "login: ") - machine.send_chars("alice\n") - machine.wait_until_tty_matches(tty_number, "login: alice") - machine.wait_until_succeeds("pgrep login") - machine.wait_until_tty_matches(tty_number, "One-time password") + def enter_user_alice(tty_number): + machine.wait_until_tty_matches(tty_number, "login: ") + machine.send_chars("alice\n") + machine.wait_until_tty_matches(tty_number, "login: alice") + machine.wait_until_succeeds("pgrep login") + machine.wait_until_tty_matches(tty_number, "One-time password") - machine.wait_for_unit("multi-user.target") - machine.wait_until_succeeds("pgrep -f 'agetty.*tty1'") - machine.screenshot("postboot") + machine.wait_for_unit("multi-user.target") + machine.wait_until_succeeds("pgrep -f 'agetty.*tty1'") + machine.screenshot("postboot") - with subtest("Invalid password"): - switch_to_tty("2") - enter_user_alice("2") + with subtest("Invalid password"): + switch_to_tty("2") + enter_user_alice("2") - machine.send_chars("${oathSnakeOilPassword1}\n") - machine.wait_until_tty_matches("2", "Password: ") - machine.send_chars("blorg\n") - machine.wait_until_tty_matches("2", "Login incorrect") + machine.send_chars("${oathSnakeOilPassword1}\n") + machine.wait_until_tty_matches("2", "Password: ") + machine.send_chars("blorg\n") + machine.wait_until_tty_matches("2", "Login incorrect") - with subtest("Invalid oath token"): - switch_to_tty("3") - enter_user_alice("3") + with subtest("Invalid oath token"): + switch_to_tty("3") + enter_user_alice("3") - machine.send_chars("000000\n") - machine.wait_until_tty_matches("3", "Login incorrect") - machine.wait_until_tty_matches("3", "login:") + machine.send_chars("000000\n") + machine.wait_until_tty_matches("3", "Login incorrect") + machine.wait_until_tty_matches("3", "login:") - with subtest("Happy path: Both passwords are mandatory to get us in"): - switch_to_tty("4") - enter_user_alice("4") + with subtest("Happy path: Both passwords are mandatory to get us in"): + switch_to_tty("4") + enter_user_alice("4") - machine.send_chars("${oathSnakeOilPassword2}\n") - machine.wait_until_tty_matches("4", "Password: ") - machine.send_chars("${alicePassword}\n") + machine.send_chars("${oathSnakeOilPassword2}\n") + machine.wait_until_tty_matches("4", "Password: ") + machine.send_chars("${alicePassword}\n") - machine.wait_until_succeeds("pgrep -u alice bash") - machine.send_chars("touch done4\n") - machine.wait_for_file("/home/alice/done4") + machine.wait_until_succeeds("pgrep -u alice bash") + machine.send_chars("touch done4\n") + machine.wait_for_file("/home/alice/done4") ''; -}) + } +) diff --git a/nixos/tests/pam/pam-u2f.nix b/nixos/tests/pam/pam-u2f.nix index caa56c30bbce98..c889cb9ee2fadb 100644 --- a/nixos/tests/pam/pam-u2f.nix +++ b/nixos/tests/pam/pam-u2f.nix @@ -1,30 +1,31 @@ -import ../make-test-python.nix ({ ... }: +import ../make-test-python.nix ( + { ... }: -{ - name = "pam-u2f"; + { + name = "pam-u2f"; - nodes.machine = - { ... }: - { - security.pam.u2f = { - enable = true; - control = "required"; - settings = { - cue = true; - debug = true; - interactive = true; - origin = "nixos-test"; - # Freeform option - userpresence = 1; + nodes.machine = + { ... }: + { + security.pam.u2f = { + enable = true; + control = "required"; + settings = { + cue = true; + debug = true; + interactive = true; + origin = "nixos-test"; + # Freeform option + userpresence = 1; + }; }; }; - }; - testScript = - '' + testScript = '' machine.wait_for_unit("multi-user.target") machine.succeed( 'egrep "auth required .*/lib/security/pam_u2f.so.*cue.*debug.*interactive.*origin=nixos-test.*userpresence=1" /etc/pam.d/ -R' ) ''; -}) + } +) diff --git a/nixos/tests/pam/pam-ussh.nix b/nixos/tests/pam/pam-ussh.nix index ba0570dbf97d2f..c5eefd12aa3b92 100644 --- a/nixos/tests/pam/pam-ussh.nix +++ b/nixos/tests/pam/pam-ussh.nix @@ -1,62 +1,74 @@ -import ../make-test-python.nix ({ pkgs, lib, ... }: +import ../make-test-python.nix ( + { pkgs, lib, ... }: -let - testOnlySSHCredentials = pkgs.runCommand "pam-ussh-test-ca" { - nativeBuildInputs = [ pkgs.openssh ]; - } '' - mkdir $out - ssh-keygen -t ed25519 -N "" -f $out/ca + let + testOnlySSHCredentials = + pkgs.runCommand "pam-ussh-test-ca" + { + nativeBuildInputs = [ pkgs.openssh ]; + } + '' + mkdir $out + ssh-keygen -t ed25519 -N "" -f $out/ca - ssh-keygen -t ed25519 -N "" -f $out/alice - ssh-keygen -s $out/ca -I "alice user key" -n "alice,root" -V 19700101:forever $out/alice.pub + ssh-keygen -t ed25519 -N "" -f $out/alice + ssh-keygen -s $out/ca -I "alice user key" -n "alice,root" -V 19700101:forever $out/alice.pub - ssh-keygen -t ed25519 -N "" -f $out/bob - ssh-keygen -s $out/ca -I "bob user key" -n "bob" -V 19700101:forever $out/bob.pub - ''; - makeTestScript = user: pkgs.writeShellScript "pam-ussh-${user}-test-script" '' - set -euo pipefail + ssh-keygen -t ed25519 -N "" -f $out/bob + ssh-keygen -s $out/ca -I "bob user key" -n "bob" -V 19700101:forever $out/bob.pub + ''; + makeTestScript = + user: + pkgs.writeShellScript "pam-ussh-${user}-test-script" '' + set -euo pipefail - eval $(${pkgs.openssh}/bin/ssh-agent) + eval $(${pkgs.openssh}/bin/ssh-agent) - mkdir -p $HOME/.ssh - chmod 700 $HOME/.ssh - cp ${testOnlySSHCredentials}/${user}{,.pub,-cert.pub} $HOME/.ssh - chmod 600 $HOME/.ssh/${user} - chmod 644 $HOME/.ssh/${user}{,-cert}.pub + mkdir -p $HOME/.ssh + chmod 700 $HOME/.ssh + cp ${testOnlySSHCredentials}/${user}{,.pub,-cert.pub} $HOME/.ssh + chmod 600 $HOME/.ssh/${user} + chmod 644 $HOME/.ssh/${user}{,-cert}.pub - set -x + set -x - ${pkgs.openssh}/bin/ssh-add $HOME/.ssh/${user} - ${pkgs.openssh}/bin/ssh-add -l &>2 + ${pkgs.openssh}/bin/ssh-add $HOME/.ssh/${user} + ${pkgs.openssh}/bin/ssh-add -l &>2 - exec sudo id -u -n - ''; -in { - name = "pam-ussh"; - meta.maintainers = with lib.maintainers; [ lukegb ]; + exec sudo id -u -n + ''; + in + { + name = "pam-ussh"; + meta.maintainers = with lib.maintainers; [ lukegb ]; - machine = - { ... }: - { - users.users.alice = { isNormalUser = true; extraGroups = [ "wheel" ]; }; - users.users.bob = { isNormalUser = true; extraGroups = [ "wheel" ]; }; + machine = + { ... }: + { + users.users.alice = { + isNormalUser = true; + extraGroups = [ "wheel" ]; + }; + users.users.bob = { + isNormalUser = true; + extraGroups = [ "wheel" ]; + }; - security.pam.ussh = { - enable = true; - authorizedPrincipals = "root"; - caFile = "${testOnlySSHCredentials}/ca.pub"; - }; + security.pam.ussh = { + enable = true; + authorizedPrincipals = "root"; + caFile = "${testOnlySSHCredentials}/ca.pub"; + }; - security.sudo = { - enable = true; - extraConfig = '' - Defaults lecture="never" - ''; + security.sudo = { + enable = true; + extraConfig = '' + Defaults lecture="never" + ''; + }; }; - }; - testScript = - '' + testScript = '' with subtest("alice should be allowed to escalate to root"): machine.succeed( 'su -c "${makeTestScript "alice"}" -l alice | grep root' @@ -67,4 +79,5 @@ in { 'su -c "${makeTestScript "bob"}" -l bob | grep root' ) ''; -}) + } +) diff --git a/nixos/tests/pam/zfs-key.nix b/nixos/tests/pam/zfs-key.nix index 4f54c287e91a12..2a494eaa57022c 100644 --- a/nixos/tests/pam/zfs-key.nix +++ b/nixos/tests/pam/zfs-key.nix @@ -1,4 +1,5 @@ -import ../make-test-python.nix ({ ... }: +import ../make-test-python.nix ( + { ... }: let userPassword = "password"; @@ -8,7 +9,8 @@ import ../make-test-python.nix ({ ... }: name = "pam-zfs-key"; nodes.machine = - { ... }: { + { ... }: + { boot.supportedFilesystems = [ "zfs" ]; networking.hostId = "12345678"; @@ -27,7 +29,8 @@ import ../make-test-python.nix ({ ... }: }; }; - testScript = { nodes, ... }: + testScript = + { nodes, ... }: let homes = nodes.machine.security.pam.zfs.homes; pool = builtins.head (builtins.split "/" homes); diff --git a/nixos/tests/parsedmarc/default.nix b/nixos/tests/parsedmarc/default.nix index 1feadcb7f39b0e..41464b90e15b30 100644 --- a/nixos/tests/parsedmarc/default.nix +++ b/nixos/tests/parsedmarc/default.nix @@ -12,7 +12,8 @@ let sha256 = "0dq64cj49711kbja27pjl2hy0d3azrjxg91kqrh40x46fkn1dwkx"; }; - sendEmail = address: + sendEmail = + address: pkgs.writeScriptBin "send-email" '' #!${pkgs.python3.interpreter} import smtplib @@ -52,52 +53,166 @@ let ''; in { - localMail = makeTest - { - name = "parsedmarc-local-mail"; + localMail = makeTest { + name = "parsedmarc-local-mail"; + meta = with lib.maintainers; { + maintainers = [ talyz ]; + }; + + nodes.parsedmarc = + { nodes, ... }: + { + virtualisation.memorySize = 2048; + + services.postfix = { + enableSubmission = true; + enableSubmissions = true; + submissionsOptions = { + smtpd_sasl_auth_enable = "yes"; + smtpd_client_restrictions = "permit"; + }; + }; + + services.parsedmarc = { + enable = true; + provision = { + geoIp = false; + localMail = { + enable = true; + hostname = "localhost"; + }; + }; + }; + + environment.systemPackages = [ + (sendEmail "dmarc@localhost") + pkgs.jq + ]; + }; + + testScript = + { nodes }: + let + esPort = toString nodes.parsedmarc.config.services.elasticsearch.port; + valueObject = lib.optionalString (lib.versionAtLeast nodes.parsedmarc.config.services.elasticsearch.package.version "7") ".value"; + in + '' + parsedmarc.start() + parsedmarc.wait_for_unit("postfix.service") + parsedmarc.wait_for_unit("dovecot2.service") + parsedmarc.wait_for_unit("parsedmarc.service") + parsedmarc.wait_until_succeeds( + "curl -sS -f http://localhost:${esPort}" + ) + + parsedmarc.fail( + "curl -sS -f http://localhost:${esPort}/_search?q=report_id:2940" + + " | tee /dev/console" + + " | jq -es 'if . == [] then null else .[] | .hits.total${valueObject} > 0 end'" + ) + parsedmarc.succeed("send-email") + parsedmarc.wait_until_succeeds( + "curl -sS -f http://localhost:${esPort}/_search?q=report_id:2940" + + " | tee /dev/console" + + " | jq -es 'if . == [] then null else .[] | .hits.total${valueObject} > 0 end'" + ) + ''; + }; + + externalMail = + let + certs = import ../common/acme/server/snakeoil-certs.nix; + mailDomain = certs.domain; + parsedmarcDomain = "parsedmarc.fake.domain"; + in + makeTest { + name = "parsedmarc-external-mail"; meta = with lib.maintainers; { maintainers = [ talyz ]; }; - nodes.parsedmarc = - { nodes, ... }: - { - virtualisation.memorySize = 2048; - - services.postfix = { - enableSubmission = true; - enableSubmissions = true; - submissionsOptions = { - smtpd_sasl_auth_enable = "yes"; - smtpd_client_restrictions = "permit"; + nodes = { + parsedmarc = + { nodes, ... }: + { + virtualisation.memorySize = 2048; + + security.pki.certificateFiles = [ + certs.ca.cert + ]; + + networking.extraHosts = '' + 127.0.0.1 ${parsedmarcDomain} + ${nodes.mail.config.networking.primaryIPAddress} ${mailDomain} + ''; + + services.parsedmarc = { + enable = true; + provision.geoIp = false; + settings.imap = { + host = mailDomain; + port = 993; + ssl = true; + user = "alice"; + password = "${pkgs.writeText "imap-password" "foobar"}"; + }; }; + + environment.systemPackages = [ + pkgs.jq + ]; }; - services.parsedmarc = { - enable = true; - provision = { - geoIp = false; - localMail = { - enable = true; - hostname = "localhost"; + mail = + { nodes, ... }: + { + imports = [ ../common/user-account.nix ]; + + networking.extraHosts = '' + 127.0.0.1 ${mailDomain} + ${nodes.parsedmarc.config.networking.primaryIPAddress} ${parsedmarcDomain} + ''; + + services.dovecot2 = { + enable = true; + protocols = [ "imap" ]; + sslCACert = "${certs.ca.cert}"; + sslServerCert = "${certs.${mailDomain}.cert}"; + sslServerKey = "${certs.${mailDomain}.key}"; + }; + + services.postfix = { + enable = true; + origin = mailDomain; + config = { + myhostname = mailDomain; + mydestination = mailDomain; + }; + enableSubmission = true; + enableSubmissions = true; + submissionsOptions = { + smtpd_sasl_auth_enable = "yes"; + smtpd_client_restrictions = "permit"; }; }; - }; + environment.systemPackages = [ (sendEmail "alice@${mailDomain}") ]; - environment.systemPackages = [ - (sendEmail "dmarc@localhost") - pkgs.jq - ]; - }; + networking.firewall.allowedTCPPorts = [ 993 ]; + }; + }; - testScript = { nodes }: + testScript = + { nodes }: let esPort = toString nodes.parsedmarc.config.services.elasticsearch.port; valueObject = lib.optionalString (lib.versionAtLeast nodes.parsedmarc.config.services.elasticsearch.package.version "7") ".value"; - in '' + in + '' + mail.start() + mail.wait_for_unit("postfix.service") + mail.wait_for_unit("dovecot2.service") + parsedmarc.start() - parsedmarc.wait_for_unit("postfix.service") - parsedmarc.wait_for_unit("dovecot2.service") parsedmarc.wait_for_unit("parsedmarc.service") parsedmarc.wait_until_succeeds( "curl -sS -f http://localhost:${esPort}" @@ -108,7 +223,7 @@ in + " | tee /dev/console" + " | jq -es 'if . == [] then null else .[] | .hits.total${valueObject} > 0 end'" ) - parsedmarc.succeed("send-email") + mail.succeed("send-email") parsedmarc.wait_until_succeeds( "curl -sS -f http://localhost:${esPort}/_search?q=report_id:2940" + " | tee /dev/console" @@ -116,115 +231,4 @@ in ) ''; }; - - externalMail = - let - certs = import ../common/acme/server/snakeoil-certs.nix; - mailDomain = certs.domain; - parsedmarcDomain = "parsedmarc.fake.domain"; - in - makeTest { - name = "parsedmarc-external-mail"; - meta = with lib.maintainers; { - maintainers = [ talyz ]; - }; - - nodes = { - parsedmarc = - { nodes, ... }: - { - virtualisation.memorySize = 2048; - - security.pki.certificateFiles = [ - certs.ca.cert - ]; - - networking.extraHosts = '' - 127.0.0.1 ${parsedmarcDomain} - ${nodes.mail.config.networking.primaryIPAddress} ${mailDomain} - ''; - - services.parsedmarc = { - enable = true; - provision.geoIp = false; - settings.imap = { - host = mailDomain; - port = 993; - ssl = true; - user = "alice"; - password = "${pkgs.writeText "imap-password" "foobar"}"; - }; - }; - - environment.systemPackages = [ - pkgs.jq - ]; - }; - - mail = - { nodes, ... }: - { - imports = [ ../common/user-account.nix ]; - - networking.extraHosts = '' - 127.0.0.1 ${mailDomain} - ${nodes.parsedmarc.config.networking.primaryIPAddress} ${parsedmarcDomain} - ''; - - services.dovecot2 = { - enable = true; - protocols = [ "imap" ]; - sslCACert = "${certs.ca.cert}"; - sslServerCert = "${certs.${mailDomain}.cert}"; - sslServerKey = "${certs.${mailDomain}.key}"; - }; - - services.postfix = { - enable = true; - origin = mailDomain; - config = { - myhostname = mailDomain; - mydestination = mailDomain; - }; - enableSubmission = true; - enableSubmissions = true; - submissionsOptions = { - smtpd_sasl_auth_enable = "yes"; - smtpd_client_restrictions = "permit"; - }; - }; - environment.systemPackages = [ (sendEmail "alice@${mailDomain}") ]; - - networking.firewall.allowedTCPPorts = [ 993 ]; - }; - }; - - testScript = { nodes }: - let - esPort = toString nodes.parsedmarc.config.services.elasticsearch.port; - valueObject = lib.optionalString (lib.versionAtLeast nodes.parsedmarc.config.services.elasticsearch.package.version "7") ".value"; - in '' - mail.start() - mail.wait_for_unit("postfix.service") - mail.wait_for_unit("dovecot2.service") - - parsedmarc.start() - parsedmarc.wait_for_unit("parsedmarc.service") - parsedmarc.wait_until_succeeds( - "curl -sS -f http://localhost:${esPort}" - ) - - parsedmarc.fail( - "curl -sS -f http://localhost:${esPort}/_search?q=report_id:2940" - + " | tee /dev/console" - + " | jq -es 'if . == [] then null else .[] | .hits.total${valueObject} > 0 end'" - ) - mail.succeed("send-email") - parsedmarc.wait_until_succeeds( - "curl -sS -f http://localhost:${esPort}/_search?q=report_id:2940" - + " | tee /dev/console" - + " | jq -es 'if . == [] then null else .[] | .hits.total${valueObject} > 0 end'" - ) - ''; - }; } diff --git a/nixos/tests/pass-secret-service.nix b/nixos/tests/pass-secret-service.nix index cdbdaa52dbc0a8..9e85dd30610b47 100644 --- a/nixos/tests/pass-secret-service.nix +++ b/nixos/tests/pass-secret-service.nix @@ -1,68 +1,75 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "pass-secret-service"; - meta.maintainers = [ lib.maintainers.aidalgol ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "pass-secret-service"; + meta.maintainers = [ lib.maintainers.aidalgol ]; - nodes.machine = { nodes, pkgs, ... }: - { - imports = [ ./common/user-account.nix ]; + nodes.machine = + { nodes, pkgs, ... }: + { + imports = [ ./common/user-account.nix ]; - services.passSecretService.enable = true; + services.passSecretService.enable = true; - environment.systemPackages = [ - # Create a script that tries to make a request to the D-Bus secrets API. - (pkgs.writers.writePython3Bin "secrets-dbus-init" - { - libraries = [ pkgs.python3Packages.secretstorage ]; - } '' - import secretstorage - print("Initializing dbus connection...") - connection = secretstorage.dbus_init() - print("Requesting default collection...") - collection = secretstorage.get_default_collection(connection) - print("Done! dbus-org.freedesktop.secrets should now be active.") - '') - pkgs.pass - ]; + environment.systemPackages = [ + # Create a script that tries to make a request to the D-Bus secrets API. + (pkgs.writers.writePython3Bin "secrets-dbus-init" + { + libraries = [ pkgs.python3Packages.secretstorage ]; + } + '' + import secretstorage + print("Initializing dbus connection...") + connection = secretstorage.dbus_init() + print("Requesting default collection...") + collection = secretstorage.get_default_collection(connection) + print("Done! dbus-org.freedesktop.secrets should now be active.") + '' + ) + pkgs.pass + ]; - programs.gnupg = { - agent.enable = true; - dirmngr.enable = true; + programs.gnupg = { + agent.enable = true; + dirmngr.enable = true; + }; }; - }; - # Some of the commands are run via a virtual console because they need to be - # run under a real login session, with D-Bus running in the environment. - testScript = { nodes, ... }: - let - user = nodes.machine.config.users.users.alice; - gpg-uid = "alice@example.net"; - gpg-pw = "foobar9000"; - ready-file = "/tmp/secrets-dbus-init.done"; - in - '' - # Initialise the pass(1) storage. - machine.succeed(""" - sudo -u alice gpg --pinentry-mode loopback --batch --passphrase ${gpg-pw} \ - --quick-gen-key ${gpg-uid} \ - """) - machine.succeed("sudo -u alice pass init ${gpg-uid}") + # Some of the commands are run via a virtual console because they need to be + # run under a real login session, with D-Bus running in the environment. + testScript = + { nodes, ... }: + let + user = nodes.machine.config.users.users.alice; + gpg-uid = "alice@example.net"; + gpg-pw = "foobar9000"; + ready-file = "/tmp/secrets-dbus-init.done"; + in + '' + # Initialise the pass(1) storage. + machine.succeed(""" + sudo -u alice gpg --pinentry-mode loopback --batch --passphrase ${gpg-pw} \ + --quick-gen-key ${gpg-uid} \ + """) + machine.succeed("sudo -u alice pass init ${gpg-uid}") - with subtest("Service is not running on login"): - machine.wait_until_tty_matches("1", "login: ") - machine.send_chars("alice\n") - machine.wait_until_tty_matches("1", "login: alice") - machine.wait_until_succeeds("pgrep login") - machine.wait_until_tty_matches("1", "Password: ") - machine.send_chars("${user.password}\n") - machine.wait_until_succeeds("pgrep -u alice bash") + with subtest("Service is not running on login"): + machine.wait_until_tty_matches("1", "login: ") + machine.send_chars("alice\n") + machine.wait_until_tty_matches("1", "login: alice") + machine.wait_until_succeeds("pgrep login") + machine.wait_until_tty_matches("1", "Password: ") + machine.send_chars("${user.password}\n") + machine.wait_until_succeeds("pgrep -u alice bash") - _, output = machine.systemctl("status dbus-org.freedesktop.secrets --no-pager", "alice") - assert "Active: inactive (dead)" in output + _, output = machine.systemctl("status dbus-org.freedesktop.secrets --no-pager", "alice") + assert "Active: inactive (dead)" in output - with subtest("Service starts after a client tries to talk to the D-Bus API"): - machine.send_chars("secrets-dbus-init; touch ${ready-file}\n") - machine.wait_for_file("${ready-file}") - _, output = machine.systemctl("status dbus-org.freedesktop.secrets --no-pager", "alice") - assert "Active: active (running)" in output - ''; -}) + with subtest("Service starts after a client tries to talk to the D-Bus API"): + machine.send_chars("secrets-dbus-init; touch ${ready-file}\n") + machine.wait_for_file("${ready-file}") + _, output = machine.systemctl("status dbus-org.freedesktop.secrets --no-pager", "alice") + assert "Active: active (running)" in output + ''; + } +) diff --git a/nixos/tests/patroni.nix b/nixos/tests/patroni.nix index 68fce4051553ec..63f8413e41f9ed 100644 --- a/nixos/tests/patroni.nix +++ b/nixos/tests/patroni.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: let nodesIps = [ @@ -7,16 +8,25 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: "192.168.1.3" ]; - createNode = index: { pkgs, ... }: + createNode = + index: + { pkgs, ... }: let ip = builtins.elemAt nodesIps index; # since we already use IPs to identify servers in { networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = ip; prefixLength = 16; } + { + address = ip; + prefixLength = 16; + } ]; - networking.firewall.allowedTCPPorts = [ 5432 8008 5010 ]; + networking.firewall.allowedTCPPorts = [ + 5432 + 8008 + 5010 + ]; environment.systemPackages = [ pkgs.jq ]; @@ -27,7 +37,7 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: postgresqlPackage = pkgs.postgresql_14.withPackages (p: [ p.pg_safeupdate ]); scope = "cluster1"; - name = "node${toString(index + 1)}"; + name = "node${toString (index + 1)}"; nodeIp = ip; otherNodesIps = builtins.filter (h: h != ip) nodesIps; softwareWatchdog = true; @@ -97,55 +107,65 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: node2 = createNode 1; node3 = createNode 2; - etcd = { pkgs, ... }: { + etcd = + { pkgs, ... }: + { - networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = "192.168.1.4"; prefixLength = 16; } - ]; + networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = "192.168.1.4"; + prefixLength = 16; + } + ]; - services.etcd = { - enable = true; - listenClientUrls = [ "http://192.168.1.4:2379" ]; - }; - - networking.firewall.allowedTCPPorts = [ 2379 ]; - }; - - client = { pkgs, ... }: { - environment.systemPackages = [ pkgs.postgresql_14 ]; + services.etcd = { + enable = true; + listenClientUrls = [ "http://192.168.1.4:2379" ]; + }; - networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = "192.168.2.1"; prefixLength = 16; } - ]; + networking.firewall.allowedTCPPorts = [ 2379 ]; + }; - services.haproxy = { - enable = true; - config = '' - global - maxconn 100 - - defaults - log global - mode tcp - retries 2 - timeout client 30m - timeout connect 4s - timeout server 30m - timeout check 5s - - listen cluster1 - bind 127.0.0.1:5432 - option httpchk - http-check expect status 200 - default-server inter 3s fall 3 rise 2 on-marked-down shutdown-sessions - ${builtins.concatStringsSep "\n" (map (ip: "server postgresql_${ip}_5432 ${ip}:5432 maxconn 100 check port 8008") nodesIps)} - ''; + client = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.postgresql_14 ]; + + networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = "192.168.2.1"; + prefixLength = 16; + } + ]; + + services.haproxy = { + enable = true; + config = '' + global + maxconn 100 + + defaults + log global + mode tcp + retries 2 + timeout client 30m + timeout connect 4s + timeout server 30m + timeout check 5s + + listen cluster1 + bind 127.0.0.1:5432 + option httpchk + http-check expect status 200 + default-server inter 3s fall 3 rise 2 on-marked-down shutdown-sessions + ${builtins.concatStringsSep "\n" ( + map (ip: "server postgresql_${ip}_5432 ${ip}:5432 maxconn 100 check port 8008") nodesIps + )} + ''; + }; }; - }; }; - - testScript = '' nodes = [node1, node2, node3] @@ -203,4 +223,5 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: # Execute some queries with the node back up. run_dummy_queries() ''; - }) + } +) diff --git a/nixos/tests/pdns-recursor.nix b/nixos/tests/pdns-recursor.nix index 14f1b7ea8a35f4..42a227ae8eb5fd 100644 --- a/nixos/tests/pdns-recursor.nix +++ b/nixos/tests/pdns-recursor.nix @@ -1,15 +1,20 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "powerdns-recursor"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "powerdns-recursor"; - nodes.server = { ... }: { - services.pdns-recursor.enable = true; - services.pdns-recursor.exportHosts= true; - networking.hosts."192.0.2.1" = [ "example.com" ]; - }; + nodes.server = + { ... }: + { + services.pdns-recursor.enable = true; + services.pdns-recursor.exportHosts = true; + networking.hosts."192.0.2.1" = [ "example.com" ]; + }; - testScript = '' - server.wait_for_unit("pdns-recursor") - server.wait_for_open_port(53) - assert "192.0.2.1" in server.succeed("host example.com localhost") - ''; -}) + testScript = '' + server.wait_for_unit("pdns-recursor") + server.wait_for_open_port(53) + assert "192.0.2.1" in server.succeed("host example.com localhost") + ''; + } +) diff --git a/nixos/tests/peerflix.nix b/nixos/tests/peerflix.nix index 4800413783b1b3..b53f1b114abe95 100644 --- a/nixos/tests/peerflix.nix +++ b/nixos/tests/peerflix.nix @@ -1,23 +1,26 @@ # This test runs peerflix and checks if peerflix starts -import ./make-test-python.nix ({ pkgs, ...} : { - name = "peerflix"; - meta = with pkgs.lib.maintainers; { - maintainers = [ offline ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "peerflix"; + meta = with pkgs.lib.maintainers; { + maintainers = [ offline ]; + }; - nodes = { - peerflix = - { ... }: + nodes = { + peerflix = + { ... }: { services.peerflix.enable = true; }; }; - testScript = '' - start_all() + testScript = '' + start_all() - peerflix.wait_for_unit("peerflix.service") - peerflix.wait_until_succeeds("curl -f localhost:9000") - ''; -}) + peerflix.wait_for_unit("peerflix.service") + peerflix.wait_until_succeeds("curl -f localhost:9000") + ''; + } +) diff --git a/nixos/tests/peroxide.nix b/nixos/tests/peroxide.nix index 12e196484164b9..3508942d2970e1 100644 --- a/nixos/tests/peroxide.nix +++ b/nixos/tests/peroxide.nix @@ -1,16 +1,20 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "peroxide"; - meta.maintainers = with lib.maintainers; [ aidalgol ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "peroxide"; + meta.maintainers = with lib.maintainers; [ aidalgol ]; - nodes.machine = - { config, pkgs, ... }: { - networking.hostName = "nixos"; - services.peroxide.enable = true; - }; + nodes.machine = + { config, pkgs, ... }: + { + networking.hostName = "nixos"; + services.peroxide.enable = true; + }; - testScript = '' - machine.wait_for_unit("peroxide.service") - machine.wait_for_open_port(1143) # IMAP - machine.wait_for_open_port(1025) # SMTP - ''; -}) + testScript = '' + machine.wait_for_unit("peroxide.service") + machine.wait_for_open_port(1143) # IMAP + machine.wait_for_open_port(1025) # SMTP + ''; + } +) diff --git a/nixos/tests/pgadmin4.nix b/nixos/tests/pgadmin4.nix index b726a3eb3b9462..0a87d053f324ee 100644 --- a/nixos/tests/pgadmin4.nix +++ b/nixos/tests/pgadmin4.nix @@ -1,80 +1,88 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: -{ - name = "pgadmin4"; - meta.maintainers = with lib.maintainers; [ mkg20001 gador ]; + { + name = "pgadmin4"; + meta.maintainers = with lib.maintainers; [ + mkg20001 + gador + ]; - nodes = { - machine = { pkgs, ... }: { + nodes = { + machine = + { pkgs, ... }: + { - imports = [ ./common/user-account.nix ]; + imports = [ ./common/user-account.nix ]; - environment.systemPackages = with pkgs; [ - wget - curl - pgadmin4-desktopmode - ]; + environment.systemPackages = with pkgs; [ + wget + curl + pgadmin4-desktopmode + ]; - services.postgresql = { - enable = true; - authentication = '' - host all all localhost trust - ''; - }; + services.postgresql = { + enable = true; + authentication = '' + host all all localhost trust + ''; + }; - services.pgadmin = { - port = 5051; - enable = true; - initialEmail = "bruh@localhost.de"; - initialPasswordFile = pkgs.writeText "pw" "bruh2012!"; - }; - }; - machine2 = { pkgs, ... }: { + services.pgadmin = { + port = 5051; + enable = true; + initialEmail = "bruh@localhost.de"; + initialPasswordFile = pkgs.writeText "pw" "bruh2012!"; + }; + }; + machine2 = + { pkgs, ... }: + { - imports = [ ./common/user-account.nix ]; + imports = [ ./common/user-account.nix ]; - services.postgresql = { - enable = true; - }; + services.postgresql = { + enable = true; + }; - services.pgadmin = { - enable = true; - initialEmail = "bruh@localhost.de"; - initialPasswordFile = pkgs.writeText "pw" "bruh2012!"; - minimumPasswordLength = 12; - }; + services.pgadmin = { + enable = true; + initialEmail = "bruh@localhost.de"; + initialPasswordFile = pkgs.writeText "pw" "bruh2012!"; + minimumPasswordLength = 12; + }; + }; }; - }; - - testScript = '' - with subtest("Check pgadmin module"): - machine.wait_for_unit("postgresql") - machine.wait_for_unit("pgadmin") - machine.wait_until_succeeds("curl -sS localhost:5051") - machine.wait_until_succeeds("curl -sS localhost:5051/login | grep \"pgAdmin 4\" > /dev/null") - # check for missing support files (css, js etc). Should catch not-generated files during build. See e.g. https://github.com/NixOS/nixpkgs/pull/229184 - machine.succeed("wget -nv --level=1 --spider --recursive localhost:5051/login") - # test idempotenceny - machine.systemctl("restart pgadmin.service") - machine.wait_for_unit("pgadmin") - machine.wait_until_succeeds("curl -sS localhost:5051") - machine.wait_until_succeeds("curl -sS localhost:5051/login | grep \"pgAdmin 4\" > /dev/null") + testScript = '' + with subtest("Check pgadmin module"): + machine.wait_for_unit("postgresql") + machine.wait_for_unit("pgadmin") + machine.wait_until_succeeds("curl -sS localhost:5051") + machine.wait_until_succeeds("curl -sS localhost:5051/login | grep \"pgAdmin 4\" > /dev/null") + # check for missing support files (css, js etc). Should catch not-generated files during build. See e.g. https://github.com/NixOS/nixpkgs/pull/229184 + machine.succeed("wget -nv --level=1 --spider --recursive localhost:5051/login") + # test idempotenceny + machine.systemctl("restart pgadmin.service") + machine.wait_for_unit("pgadmin") + machine.wait_until_succeeds("curl -sS localhost:5051") + machine.wait_until_succeeds("curl -sS localhost:5051/login | grep \"pgAdmin 4\" > /dev/null") - # pgadmin4 module saves the configuration to /etc/pgadmin/config_system.py - # pgadmin4-desktopmode tries to read that as well. This normally fails with a PermissionError, as the config file - # is owned by the user of the pgadmin module. With the check-system-config-dir.patch this will just throw a warning - # but will continue and not read the file. - # If we run pgadmin4-desktopmode as root (something one really shouldn't do), it can read the config file and fail, - # because of the wrong config for desktopmode. - with subtest("Check pgadmin standalone desktop mode"): - machine.execute("sudo -u alice pgadmin4 >&2 &", timeout=60) - machine.wait_until_succeeds("curl -sS localhost:5050") - machine.wait_until_succeeds("curl -sS localhost:5050/browser/ | grep \"pgAdmin 4\" > /dev/null") - machine.succeed("wget -nv --level=1 --spider --recursive localhost:5050/browser") + # pgadmin4 module saves the configuration to /etc/pgadmin/config_system.py + # pgadmin4-desktopmode tries to read that as well. This normally fails with a PermissionError, as the config file + # is owned by the user of the pgadmin module. With the check-system-config-dir.patch this will just throw a warning + # but will continue and not read the file. + # If we run pgadmin4-desktopmode as root (something one really shouldn't do), it can read the config file and fail, + # because of the wrong config for desktopmode. + with subtest("Check pgadmin standalone desktop mode"): + machine.execute("sudo -u alice pgadmin4 >&2 &", timeout=60) + machine.wait_until_succeeds("curl -sS localhost:5050") + machine.wait_until_succeeds("curl -sS localhost:5050/browser/ | grep \"pgAdmin 4\" > /dev/null") + machine.succeed("wget -nv --level=1 --spider --recursive localhost:5050/browser") - with subtest("Check pgadmin minimum password length"): - machine2.wait_for_unit("postgresql") - machine2.wait_for_console_text("Password must be at least 12 characters long") - ''; -}) + with subtest("Check pgadmin minimum password length"): + machine2.wait_for_unit("postgresql") + machine2.wait_for_console_text("Password must be at least 12 characters long") + ''; + } +) diff --git a/nixos/tests/pgbouncer.nix b/nixos/tests/pgbouncer.nix index 8d11c4b3f4bf55..7951ad0fb084e0 100644 --- a/nixos/tests/pgbouncer.nix +++ b/nixos/tests/pgbouncer.nix @@ -1,57 +1,62 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "pgbouncer"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "pgbouncer"; - meta = with lib.maintainers; { - maintainers = [ _1000101 ]; - }; - - nodes = { - one = { pkgs, ... }: { - systemd.services.postgresql = { - postStart = '' - ${pkgs.postgresql}/bin/psql -U postgres -c "ALTER ROLE testuser WITH LOGIN PASSWORD 'testpass'"; - ${pkgs.postgresql}/bin/psql -U postgres -c "ALTER DATABASE testdb OWNER TO testuser;"; - ''; - }; + meta = with lib.maintainers; { + maintainers = [ _1000101 ]; + }; - services = { - postgresql = { - enable = true; - ensureDatabases = [ "testdb" ]; - ensureUsers = [{ name = "testuser"; }]; - authentication = '' - local testdb testuser scram-sha-256 - ''; - }; + nodes = { + one = + { pkgs, ... }: + { + systemd.services.postgresql = { + postStart = '' + ${pkgs.postgresql}/bin/psql -U postgres -c "ALTER ROLE testuser WITH LOGIN PASSWORD 'testpass'"; + ${pkgs.postgresql}/bin/psql -U postgres -c "ALTER DATABASE testdb OWNER TO testuser;"; + ''; + }; - pgbouncer = { - enable = true; - openFirewall = true; - settings = { - pgbouncer = { - listen_addr = "localhost"; - auth_type = "scram-sha-256"; - auth_file = builtins.toFile "pgbouncer-users.txt" '' - "testuser" "testpass" + services = { + postgresql = { + enable = true; + ensureDatabases = [ "testdb" ]; + ensureUsers = [ { name = "testuser"; } ]; + authentication = '' + local testdb testuser scram-sha-256 ''; }; - databases = { - test = "host=/run/postgresql port=5432 auth_user=testuser dbname=testdb"; + + pgbouncer = { + enable = true; + openFirewall = true; + settings = { + pgbouncer = { + listen_addr = "localhost"; + auth_type = "scram-sha-256"; + auth_file = builtins.toFile "pgbouncer-users.txt" '' + "testuser" "testpass" + ''; + }; + databases = { + test = "host=/run/postgresql port=5432 auth_user=testuser dbname=testdb"; + }; + }; }; }; }; - }; }; - }; - testScript = '' - start_all() - one.wait_for_unit("default.target") - one.require_unit_state("pgbouncer.service", "active") + testScript = '' + start_all() + one.wait_for_unit("default.target") + one.require_unit_state("pgbouncer.service", "active") - # Test if we can make a query through PgBouncer - one.wait_until_succeeds( - "psql 'postgres://testuser:testpass@localhost:6432/test' -c 'SELECT 1;'" - ) - ''; -}) + # Test if we can make a query through PgBouncer + one.wait_until_succeeds( + "psql 'postgres://testuser:testpass@localhost:6432/test' -c 'SELECT 1;'" + ) + ''; + } +) diff --git a/nixos/tests/pghero.nix b/nixos/tests/pghero.nix index bce32da0088622..1673877f90c527 100644 --- a/nixos/tests/pghero.nix +++ b/nixos/tests/pghero.nix @@ -3,37 +3,42 @@ let pgheroUser = "pghero"; pgheroPass = "pghero"; in -{ lib, ... }: { +{ lib, ... }: +{ name = "pghero"; meta.maintainers = [ lib.maintainers.tie ]; - nodes.machine = { config, ... }: { - services.postgresql = { - enable = true; - # This test uses default peer authentication (socket and its directory is - # world-readably by default), so we essentially test that we can connect - # with DynamicUser= set. - ensureUsers = [{ - name = "pghero"; - ensureClauses.superuser = true; - }]; - }; - services.pghero = { - enable = true; - listenAddress = "[::]:${toString pgheroPort}"; - settings = { - databases = { - postgres.url = "<%= ENV['POSTGRES_DATABASE_URL'] %>"; - nulldb.url = "nulldb:///"; - }; + nodes.machine = + { config, ... }: + { + services.postgresql = { + enable = true; + # This test uses default peer authentication (socket and its directory is + # world-readably by default), so we essentially test that we can connect + # with DynamicUser= set. + ensureUsers = [ + { + name = "pghero"; + ensureClauses.superuser = true; + } + ]; }; - environment = { - PGHERO_USERNAME = pgheroUser; - PGHERO_PASSWORD = pgheroPass; - POSTGRES_DATABASE_URL = "postgresql:///postgres?host=/run/postgresql"; + services.pghero = { + enable = true; + listenAddress = "[::]:${toString pgheroPort}"; + settings = { + databases = { + postgres.url = "<%= ENV['POSTGRES_DATABASE_URL'] %>"; + nulldb.url = "nulldb:///"; + }; + }; + environment = { + PGHERO_USERNAME = pgheroUser; + PGHERO_PASSWORD = pgheroPass; + POSTGRES_DATABASE_URL = "postgresql:///postgres?host=/run/postgresql"; + }; }; }; - }; testScript = '' pgheroPort = ${toString pgheroPort} diff --git a/nixos/tests/pgmanage.nix b/nixos/tests/pgmanage.nix index 6e72b32eca3699..a28a3ce44766fe 100644 --- a/nixos/tests/pgmanage.nix +++ b/nixos/tests/pgmanage.nix @@ -1,41 +1,46 @@ -import ./make-test-python.nix ({ pkgs, ... } : -let - role = "test"; - password = "secret"; - conn = "local"; -in -{ - name = "pgmanage"; - meta = with pkgs.lib.maintainers; { - maintainers = [ basvandijk ]; - }; - nodes = { - one = { config, pkgs, ... }: { - services = { - postgresql = { - enable = true; - initialScript = pkgs.writeText "pg-init-script" '' - CREATE ROLE ${role} SUPERUSER LOGIN PASSWORD '${password}'; - ''; - }; - pgmanage = { - enable = true; - connections = { - ${conn} = "hostaddr=127.0.0.1 port=${toString config.services.postgresql.settings.port} dbname=postgres"; +import ./make-test-python.nix ( + { pkgs, ... }: + let + role = "test"; + password = "secret"; + conn = "local"; + in + { + name = "pgmanage"; + meta = with pkgs.lib.maintainers; { + maintainers = [ basvandijk ]; + }; + nodes = { + one = + { config, pkgs, ... }: + { + services = { + postgresql = { + enable = true; + initialScript = pkgs.writeText "pg-init-script" '' + CREATE ROLE ${role} SUPERUSER LOGIN PASSWORD '${password}'; + ''; + }; + pgmanage = { + enable = true; + connections = { + ${conn} = + "hostaddr=127.0.0.1 port=${toString config.services.postgresql.settings.port} dbname=postgres"; + }; + }; }; }; - }; }; - }; - testScript = '' - start_all() - one.wait_for_unit("default.target") - one.require_unit_state("pgmanage.service", "active") + testScript = '' + start_all() + one.wait_for_unit("default.target") + one.require_unit_state("pgmanage.service", "active") - # Test if we can log in. - one.wait_until_succeeds( - "curl 'http://localhost:8080/pgmanage/auth' --data 'action=login&connname=${conn}&username=${role}&password=${password}' --fail" - ) - ''; -}) + # Test if we can log in. + one.wait_until_succeeds( + "curl 'http://localhost:8080/pgmanage/auth' --data 'action=login&connname=${conn}&username=${role}&password=${password}' --fail" + ) + ''; + } +) diff --git a/nixos/tests/phosh.nix b/nixos/tests/phosh.nix index 64d6889aaf741f..9a93f64b0ac444 100644 --- a/nixos/tests/phosh.nix +++ b/nixos/tests/phosh.nix @@ -1,79 +1,88 @@ -import ./make-test-python.nix ({ pkgs, ...}: let - pin = "1234"; -in { - name = "phosh"; - meta = with pkgs.lib.maintainers; { - maintainers = [ zhaofengli ]; - }; - - nodes = { - phone = { config, pkgs, ... }: { - users.users.nixos = { - isNormalUser = true; - password = pin; - }; - - services.xserver.desktopManager.phosh = { - enable = true; - user = "nixos"; - group = "users"; - - phocConfig = { - outputs.Virtual-1 = { - scale = 2; +import ./make-test-python.nix ( + { pkgs, ... }: + let + pin = "1234"; + in + { + name = "phosh"; + meta = with pkgs.lib.maintainers; { + maintainers = [ zhaofengli ]; + }; + + nodes = { + phone = + { config, pkgs, ... }: + { + users.users.nixos = { + isNormalUser = true; + password = pin; }; - }; - }; - environment.systemPackages = [ - pkgs.phosh-mobile-settings - ]; + services.xserver.desktopManager.phosh = { + enable = true; + user = "nixos"; + group = "users"; - systemd.services.phosh = { - environment = { - # Accelerated graphics fail on phoc 0.20 (wlroots 0.15) - "WLR_RENDERER" = "pixman"; - }; - }; + phocConfig = { + outputs.Virtual-1 = { + scale = 2; + }; + }; + }; - virtualisation.resolution = { x = 720; y = 1440; }; - virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci,xres=720,yres=1440" ]; + environment.systemPackages = [ + pkgs.phosh-mobile-settings + ]; + + systemd.services.phosh = { + environment = { + # Accelerated graphics fail on phoc 0.20 (wlroots 0.15) + "WLR_RENDERER" = "pixman"; + }; + }; + + virtualisation.resolution = { + x = 720; + y = 1440; + }; + virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci,xres=720,yres=1440" ]; + }; }; - }; - enableOCR = true; + enableOCR = true; - testScript = '' - import time + testScript = '' + import time - start_all() - phone.wait_for_unit("phosh.service") + start_all() + phone.wait_for_unit("phosh.service") - with subtest("Check that we can see the lock screen info page"): - # Saturday, January 1 - phone.succeed("timedatectl set-time '2022-01-01 07:00'") + with subtest("Check that we can see the lock screen info page"): + # Saturday, January 1 + phone.succeed("timedatectl set-time '2022-01-01 07:00'") - phone.wait_for_text("Saturday") - phone.screenshot("01lockinfo") + phone.wait_for_text("Saturday") + phone.screenshot("01lockinfo") - with subtest("Check that we can unlock the screen"): - phone.send_chars("${pin}", delay=0.2) - time.sleep(1) - phone.screenshot("02unlock") + with subtest("Check that we can unlock the screen"): + phone.send_chars("${pin}", delay=0.2) + time.sleep(1) + phone.screenshot("02unlock") - phone.send_chars("\n") + phone.send_chars("\n") - phone.wait_for_text("All Apps") - phone.screenshot("03launcher") + phone.wait_for_text("All Apps") + phone.screenshot("03launcher") - with subtest("Check the on-screen keyboard shows"): - phone.send_chars("mobile setting", delay=0.2) - phone.wait_for_text("123") # A button on the OSK - phone.screenshot("04osk") + with subtest("Check the on-screen keyboard shows"): + phone.send_chars("mobile setting", delay=0.2) + phone.wait_for_text("123") # A button on the OSK + phone.screenshot("04osk") - with subtest("Check mobile-phosh-settings starts"): - phone.send_chars("\n") - phone.wait_for_text("Tweak advanced mobile settings"); - phone.screenshot("05settings") - ''; -}) + with subtest("Check mobile-phosh-settings starts"): + phone.send_chars("\n") + phone.wait_for_text("Tweak advanced mobile settings"); + phone.screenshot("05settings") + ''; + } +) diff --git a/nixos/tests/photonvision.nix b/nixos/tests/photonvision.nix index 2cadaa4bc02e4c..6893e77d15548e 100644 --- a/nixos/tests/photonvision.nix +++ b/nixos/tests/photonvision.nix @@ -1,21 +1,24 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -{ - name = "photonvision"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "photonvision"; - nodes = { - machine = { pkgs, ... }: { - services.photonvision = { - enable = true; - }; + nodes = { + machine = + { pkgs, ... }: + { + services.photonvision = { + enable = true; + }; + }; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("photonvision.service") - machine.wait_for_open_port(5800) - ''; - - meta.maintainers = with lib.maintainers; [ max-niederman ]; -}) + testScript = '' + start_all() + machine.wait_for_unit("photonvision.service") + machine.wait_for_open_port(5800) + ''; + meta.maintainers = with lib.maintainers; [ max-niederman ]; + } +) diff --git a/nixos/tests/photoprism.nix b/nixos/tests/photoprism.nix index a77ab59f5c9a23..b8c86c9ac20a57 100644 --- a/nixos/tests/photoprism.nix +++ b/nixos/tests/photoprism.nix @@ -1,23 +1,28 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "photoprism"; - meta.maintainers = with lib.maintainers; [ stunkymonkey ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "photoprism"; + meta.maintainers = with lib.maintainers; [ stunkymonkey ]; - nodes.machine = { pkgs, ... }: { - services.photoprism = { - enable = true; - port = 8080; - originalsPath = "/media/photos/"; - passwordFile = pkgs.writeText "password" "secret"; - }; - environment.extraInit = '' - mkdir -p /media/photos - ''; - }; + nodes.machine = + { pkgs, ... }: + { + services.photoprism = { + enable = true; + port = 8080; + originalsPath = "/media/photos/"; + passwordFile = pkgs.writeText "password" "secret"; + }; + environment.extraInit = '' + mkdir -p /media/photos + ''; + }; - testScript = '' - machine.wait_for_unit("multi-user.target") - machine.wait_for_open_port(8080) - response = machine.succeed("curl -vvv -s -H 'Host: photoprism' http://127.0.0.1:8080/library/login") - assert 'PhotoPrism' in response, "Login page didn't load successfully" - ''; -}) + testScript = '' + machine.wait_for_unit("multi-user.target") + machine.wait_for_open_port(8080) + response = machine.succeed("curl -vvv -s -H 'Host: photoprism' http://127.0.0.1:8080/library/login") + assert 'PhotoPrism' in response, "Login page didn't load successfully" + ''; + } +) diff --git a/nixos/tests/php/default.nix b/nixos/tests/php/default.nix index c0386385753f51..9d9f23d6f051ba 100644 --- a/nixos/tests/php/default.nix +++ b/nixos/tests/php/default.nix @@ -1,7 +1,8 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../../.. { inherit system config; } -, php ? pkgs.php +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../../.. { inherit system config; }, + php ? pkgs.php, }: let @@ -10,7 +11,16 @@ let }; in { - fpm = import ./fpm.nix { inherit system pkgs; php = php'; }; - httpd = import ./httpd.nix { inherit system pkgs; php = php'; }; - pcre = import ./pcre.nix { inherit system pkgs; php = php'; }; + fpm = import ./fpm.nix { + inherit system pkgs; + php = php'; + }; + httpd = import ./httpd.nix { + inherit system pkgs; + php = php'; + }; + pcre = import ./pcre.nix { + inherit system pkgs; + php = php'; + }; } diff --git a/nixos/tests/php/httpd.nix b/nixos/tests/php/httpd.nix index b6dfbeeaed5274..8bdf72dd0c8a6e 100644 --- a/nixos/tests/php/httpd.nix +++ b/nixos/tests/php/httpd.nix @@ -1,34 +1,51 @@ -import ../make-test-python.nix ({ pkgs, lib, php, ... }: { - name = "php-${php.version}-httpd-test"; - meta.maintainers = lib.teams.php.members; +import ../make-test-python.nix ( + { + pkgs, + lib, + php, + ... + }: + { + name = "php-${php.version}-httpd-test"; + meta.maintainers = lib.teams.php.members; - nodes.machine = { config, lib, pkgs, ... }: { - services.httpd = { - enable = true; - adminAddr = "admin@phpfpm"; - virtualHosts."phpfpm" = - let - testdir = pkgs.writeTextDir "web/index.php" " - Require all granted -
+ + Require all granted + + ''; + }; + }; + testScript = + let + # PCRE JIT SEAlloc feature does not play well with fork() + # The feature needs to either be disabled or PHP configured correctly + # More information in https://bugs.php.net/bug.php?id=78927 and https://bugs.php.net/bug.php?id=78630 + pcreJitSeallocForkIssue = pkgs.writeText "pcre-jit-sealloc-issue.php" '' + /tmp/machine-id") - client.succeed("diff /tmp/machine-id /etc/machine-id") + # check whether paste matches what we sent + client.succeed(f"curl {raw_url} > /tmp/machine-id") + client.succeed("diff /tmp/machine-id /etc/machine-id") - # remove paste and check that it's not available any more - client.succeed(f"curl {removal_link}") - client.fail(f"curl --fail {raw_url}") + # remove paste and check that it's not available any more + client.succeed(f"curl {removal_link}") + client.fail(f"curl --fail {raw_url}") - server.log(server.execute("systemd-analyze security pinnwand | grep '✗'")[1]) - ''; -}) + server.log(server.execute("systemd-analyze security pinnwand | grep '✗'")[1]) + ''; + } +) diff --git a/nixos/tests/plantuml-server.nix b/nixos/tests/plantuml-server.nix index 460c30919aecf4..b0885ea2630d23 100644 --- a/nixos/tests/plantuml-server.nix +++ b/nixos/tests/plantuml-server.nix @@ -1,20 +1,25 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "plantuml-server"; - meta.maintainers = with lib.maintainers; [ anthonyroussel ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "plantuml-server"; + meta.maintainers = with lib.maintainers; [ anthonyroussel ]; - nodes.machine = { pkgs, ... }: { - environment.systemPackages = [ pkgs.curl ]; - services.plantuml-server.enable = true; - }; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.curl ]; + services.plantuml-server.enable = true; + }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("plantuml-server.service") - machine.wait_for_open_port(8080) + machine.wait_for_unit("plantuml-server.service") + machine.wait_for_open_port(8080) - with subtest("Generate chart"): - chart_id = machine.succeed("curl -sSf http://localhost:8080/plantuml/coder -d 'Alice -> Bob'") - machine.succeed("curl -sSf http://localhost:8080/plantuml/txt/{}".format(chart_id)) - ''; -}) + with subtest("Generate chart"): + chart_id = machine.succeed("curl -sSf http://localhost:8080/plantuml/coder -d 'Alice -> Bob'") + machine.succeed("curl -sSf http://localhost:8080/plantuml/txt/{}".format(chart_id)) + ''; + } +) diff --git a/nixos/tests/plasma-bigscreen.nix b/nixos/tests/plasma-bigscreen.nix index 050937f33442d4..4a14564364ac9c 100644 --- a/nixos/tests/plasma-bigscreen.nix +++ b/nixos/tests/plasma-bigscreen.nix @@ -1,35 +1,43 @@ -import ./make-test-python.nix ({ pkgs, ...} : - -{ - name = "plasma-bigscreen"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ttuegel k900 ]; - }; - - nodes.machine = { ... }: +import ./make-test-python.nix ( + { pkgs, ... }: { - imports = [ ./common/user-account.nix ]; - services.xserver.enable = true; - services.displayManager.sddm.enable = true; - services.displayManager.defaultSession = "plasma-bigscreen-x11"; - services.xserver.desktopManager.plasma5.bigscreen.enable = true; - services.displayManager.autoLogin = { - enable = true; - user = "alice"; + name = "plasma-bigscreen"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + ttuegel + k900 + ]; }; - users.users.alice.extraGroups = ["uinput"]; - }; + nodes.machine = + { ... }: + + { + imports = [ ./common/user-account.nix ]; + services.xserver.enable = true; + services.displayManager.sddm.enable = true; + services.displayManager.defaultSession = "plasma-bigscreen-x11"; + services.xserver.desktopManager.plasma5.bigscreen.enable = true; + services.displayManager.autoLogin = { + enable = true; + user = "alice"; + }; + + users.users.alice.extraGroups = [ "uinput" ]; + }; - testScript = { nodes, ... }: '' - with subtest("Wait for login"): - start_all() - machine.wait_for_file("/tmp/xauth_*") - machine.succeed("xauth merge /tmp/xauth_*") + testScript = + { nodes, ... }: + '' + with subtest("Wait for login"): + start_all() + machine.wait_for_file("/tmp/xauth_*") + machine.succeed("xauth merge /tmp/xauth_*") - with subtest("Check plasmashell started"): - machine.wait_until_succeeds("pgrep plasmashell") - machine.wait_for_window("Plasma Big Screen") - ''; -}) + with subtest("Check plasmashell started"): + machine.wait_until_succeeds("pgrep plasmashell") + machine.wait_for_window("Plasma Big Screen") + ''; + } +) diff --git a/nixos/tests/plasma5-systemd-start.nix b/nixos/tests/plasma5-systemd-start.nix index 891d4df2409f2d..9f21c21714b015 100644 --- a/nixos/tests/plasma5-systemd-start.nix +++ b/nixos/tests/plasma5-systemd-start.nix @@ -1,43 +1,48 @@ -import ./make-test-python.nix ({ pkgs, ...} : - -{ - name = "plasma5-systemd-start"; - meta = with pkgs.lib.maintainers; { - maintainers = [ oxalica ]; - }; - - nodes.machine = { ... }: +import ./make-test-python.nix ( + { pkgs, ... }: { - imports = [ ./common/user-account.nix ]; - services.xserver = { - enable = true; - desktopManager.plasma5.enable = true; - desktopManager.plasma5.runUsingSystemd = true; + name = "plasma5-systemd-start"; + meta = with pkgs.lib.maintainers; { + maintainers = [ oxalica ]; }; - services.displayManager = { - sddm.enable = true; - defaultSession = "plasma"; - autoLogin = { - enable = true; - user = "alice"; + nodes.machine = + { ... }: + + { + imports = [ ./common/user-account.nix ]; + services.xserver = { + enable = true; + desktopManager.plasma5.enable = true; + desktopManager.plasma5.runUsingSystemd = true; + }; + + services.displayManager = { + sddm.enable = true; + defaultSession = "plasma"; + autoLogin = { + enable = true; + user = "alice"; + }; + }; }; - }; - }; - testScript = { nodes, ... }: '' - with subtest("Wait for login"): - start_all() - machine.wait_for_file("/tmp/xauth_*") - machine.succeed("xauth merge /tmp/xauth_*") + testScript = + { nodes, ... }: + '' + with subtest("Wait for login"): + start_all() + machine.wait_for_file("/tmp/xauth_*") + machine.succeed("xauth merge /tmp/xauth_*") - with subtest("Check plasmashell started"): - machine.wait_until_succeeds("pgrep plasmashell") - machine.wait_for_window("^Desktop ") + with subtest("Check plasmashell started"): + machine.wait_until_succeeds("pgrep plasmashell") + machine.wait_for_window("^Desktop ") - status, result = machine.systemctl('--no-pager show plasma-plasmashell.service', user='alice') - assert status == 0, 'Service not found' - assert 'ActiveState=active' in result.split('\n'), 'Systemd service not active' - ''; -}) + status, result = machine.systemctl('--no-pager show plasma-plasmashell.service', user='alice') + assert status == 0, 'Service not found' + assert 'ActiveState=active' in result.split('\n'), 'Systemd service not active' + ''; + } +) diff --git a/nixos/tests/plasma5.nix b/nixos/tests/plasma5.nix index b4e10581219cde..d333df24eb8d26 100644 --- a/nixos/tests/plasma5.nix +++ b/nixos/tests/plasma5.nix @@ -1,66 +1,72 @@ -import ./make-test-python.nix ({ pkgs, ...} : - -{ - name = "plasma5"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ttuegel ]; - }; - - nodes.machine = { ... }: +import ./make-test-python.nix ( + { pkgs, ... }: { - imports = [ ./common/user-account.nix ]; - services.xserver.enable = true; - services.displayManager.sddm.enable = true; - services.displayManager.defaultSession = "plasma"; - services.xserver.desktopManager.plasma5.enable = true; - environment.plasma5.excludePackages = [ pkgs.plasma5Packages.elisa ]; - services.displayManager.autoLogin = { - enable = true; - user = "alice"; + name = "plasma5"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ttuegel ]; }; - }; - testScript = { nodes, ... }: let - user = nodes.machine.users.users.alice; - xdo = "${pkgs.xdotool}/bin/xdotool"; - in '' - with subtest("Wait for login"): - start_all() - machine.wait_for_file("/tmp/xauth_*") - machine.succeed("xauth merge /tmp/xauth_*") + nodes.machine = + { ... }: + + { + imports = [ ./common/user-account.nix ]; + services.xserver.enable = true; + services.displayManager.sddm.enable = true; + services.displayManager.defaultSession = "plasma"; + services.xserver.desktopManager.plasma5.enable = true; + environment.plasma5.excludePackages = [ pkgs.plasma5Packages.elisa ]; + services.displayManager.autoLogin = { + enable = true; + user = "alice"; + }; + }; + + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + xdo = "${pkgs.xdotool}/bin/xdotool"; + in + '' + with subtest("Wait for login"): + start_all() + machine.wait_for_file("/tmp/xauth_*") + machine.succeed("xauth merge /tmp/xauth_*") - with subtest("Check plasmashell started"): - machine.wait_until_succeeds("pgrep plasmashell") - machine.wait_for_window("^Desktop ") + with subtest("Check plasmashell started"): + machine.wait_until_succeeds("pgrep plasmashell") + machine.wait_for_window("^Desktop ") - with subtest("Check that KDED is running"): - machine.succeed("pgrep kded5") + with subtest("Check that KDED is running"): + machine.succeed("pgrep kded5") - with subtest("Check that logging in has given the user ownership of devices"): - machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") + with subtest("Check that logging in has given the user ownership of devices"): + machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") - with subtest("Ensure Elisa is not installed"): - machine.fail("which elisa") + with subtest("Ensure Elisa is not installed"): + machine.fail("which elisa") - machine.succeed("su - ${user.name} -c 'xauth merge /tmp/xauth_*'") + machine.succeed("su - ${user.name} -c 'xauth merge /tmp/xauth_*'") - with subtest("Run Dolphin"): - machine.execute("su - ${user.name} -c 'DISPLAY=:0.0 dolphin >&2 &'") - machine.wait_for_window(" Dolphin") + with subtest("Run Dolphin"): + machine.execute("su - ${user.name} -c 'DISPLAY=:0.0 dolphin >&2 &'") + machine.wait_for_window(" Dolphin") - with subtest("Run Konsole"): - machine.execute("su - ${user.name} -c 'DISPLAY=:0.0 konsole >&2 &'") - machine.wait_for_window("Konsole") + with subtest("Run Konsole"): + machine.execute("su - ${user.name} -c 'DISPLAY=:0.0 konsole >&2 &'") + machine.wait_for_window("Konsole") - with subtest("Run systemsettings"): - machine.execute("su - ${user.name} -c 'DISPLAY=:0.0 systemsettings5 >&2 &'") - machine.wait_for_window("Settings") + with subtest("Run systemsettings"): + machine.execute("su - ${user.name} -c 'DISPLAY=:0.0 systemsettings5 >&2 &'") + machine.wait_for_window("Settings") - with subtest("Wait to get a screenshot"): - machine.execute( - "${xdo} key Alt+F1 sleep 10" - ) - machine.screenshot("screen") - ''; -}) + with subtest("Wait to get a screenshot"): + machine.execute( + "${xdo} key Alt+F1 sleep 10" + ) + machine.screenshot("screen") + ''; + } +) diff --git a/nixos/tests/plasma6.nix b/nixos/tests/plasma6.nix index 7c8fba130e681c..afdb965d5d89eb 100644 --- a/nixos/tests/plasma6.nix +++ b/nixos/tests/plasma6.nix @@ -1,64 +1,70 @@ -import ./make-test-python.nix ({ pkgs, ...} : - -{ - name = "plasma6"; - meta = with pkgs.lib.maintainers; { - maintainers = [ k900 ]; - }; - - nodes.machine = { ... }: +import ./make-test-python.nix ( + { pkgs, ... }: { - imports = [ ./common/user-account.nix ]; - services.xserver.enable = true; - services.displayManager.sddm.enable = true; - # FIXME: this should be testing Wayland - services.displayManager.defaultSession = "plasmax11"; - services.desktopManager.plasma6.enable = true; - environment.plasma6.excludePackages = [ pkgs.kdePackages.elisa ]; - services.displayManager.autoLogin = { - enable = true; - user = "alice"; + name = "plasma6"; + meta = with pkgs.lib.maintainers; { + maintainers = [ k900 ]; }; - }; - testScript = { nodes, ... }: let - user = nodes.machine.users.users.alice; - xdo = "${pkgs.xdotool}/bin/xdotool"; - in '' - with subtest("Wait for login"): - start_all() - machine.wait_for_file("/tmp/xauth_*") - machine.succeed("xauth merge /tmp/xauth_*") + nodes.machine = + { ... }: + + { + imports = [ ./common/user-account.nix ]; + services.xserver.enable = true; + services.displayManager.sddm.enable = true; + # FIXME: this should be testing Wayland + services.displayManager.defaultSession = "plasmax11"; + services.desktopManager.plasma6.enable = true; + environment.plasma6.excludePackages = [ pkgs.kdePackages.elisa ]; + services.displayManager.autoLogin = { + enable = true; + user = "alice"; + }; + }; + + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + xdo = "${pkgs.xdotool}/bin/xdotool"; + in + '' + with subtest("Wait for login"): + start_all() + machine.wait_for_file("/tmp/xauth_*") + machine.succeed("xauth merge /tmp/xauth_*") - with subtest("Check plasmashell started"): - machine.wait_until_succeeds("pgrep plasmashell") - machine.wait_for_window("^Desktop ") + with subtest("Check plasmashell started"): + machine.wait_until_succeeds("pgrep plasmashell") + machine.wait_for_window("^Desktop ") - with subtest("Check that KDED is running"): - machine.succeed("pgrep kded6") + with subtest("Check that KDED is running"): + machine.succeed("pgrep kded6") - with subtest("Ensure Elisa is not installed"): - machine.fail("which elisa") + with subtest("Ensure Elisa is not installed"): + machine.fail("which elisa") - machine.succeed("su - ${user.name} -c 'xauth merge /tmp/xauth_*'") + machine.succeed("su - ${user.name} -c 'xauth merge /tmp/xauth_*'") - with subtest("Run Dolphin"): - machine.execute("su - ${user.name} -c 'DISPLAY=:0.0 dolphin >&2 &'") - machine.wait_for_window(" Dolphin") + with subtest("Run Dolphin"): + machine.execute("su - ${user.name} -c 'DISPLAY=:0.0 dolphin >&2 &'") + machine.wait_for_window(" Dolphin") - with subtest("Run Konsole"): - machine.execute("su - ${user.name} -c 'DISPLAY=:0.0 konsole >&2 &'") - machine.wait_for_window("Konsole") + with subtest("Run Konsole"): + machine.execute("su - ${user.name} -c 'DISPLAY=:0.0 konsole >&2 &'") + machine.wait_for_window("Konsole") - with subtest("Run systemsettings"): - machine.execute("su - ${user.name} -c 'DISPLAY=:0.0 systemsettings >&2 &'") - machine.wait_for_window("Settings") + with subtest("Run systemsettings"): + machine.execute("su - ${user.name} -c 'DISPLAY=:0.0 systemsettings >&2 &'") + machine.wait_for_window("Settings") - with subtest("Wait to get a screenshot"): - machine.execute( - "${xdo} key Alt+F1 sleep 10" - ) - machine.screenshot("screen") - ''; -}) + with subtest("Wait to get a screenshot"): + machine.execute( + "${xdo} key Alt+F1 sleep 10" + ) + machine.screenshot("screen") + ''; + } +) diff --git a/nixos/tests/plausible.nix b/nixos/tests/plausible.nix index 4f1ba137f41bd7..2076667797dbb0 100644 --- a/nixos/tests/plausible.nix +++ b/nixos/tests/plausible.nix @@ -1,31 +1,36 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "plausible"; - meta = { - maintainers = lib.teams.cyberus.members; - }; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "plausible"; + meta = { + maintainers = lib.teams.cyberus.members; + }; - nodes.machine = { pkgs, ... }: { - virtualisation.memorySize = 4096; - services.plausible = { - enable = true; - server = { - baseUrl = "http://localhost:8000"; - secretKeybaseFile = "${pkgs.writeText "dont-try-this-at-home" "nannannannannannannannannannannannannannannannannannannan_batman!"}"; + nodes.machine = + { pkgs, ... }: + { + virtualisation.memorySize = 4096; + services.plausible = { + enable = true; + server = { + baseUrl = "http://localhost:8000"; + secretKeybaseFile = "${pkgs.writeText "dont-try-this-at-home" "nannannannannannannannannannannannannannannannannannannan_batman!"}"; + }; + }; }; - }; - }; - testScript = '' - start_all() - machine.wait_for_unit("plausible.service") - machine.wait_for_open_port(8000) + testScript = '' + start_all() + machine.wait_for_unit("plausible.service") + machine.wait_for_open_port(8000) - # Ensure that the software does not make not make the machine - # listen on any public interfaces by default. - machine.fail("ss -tlpn 'src = 0.0.0.0 or src = [::]' | grep LISTEN") + # Ensure that the software does not make not make the machine + # listen on any public interfaces by default. + machine.fail("ss -tlpn 'src = 0.0.0.0 or src = [::]' | grep LISTEN") - machine.succeed("curl -f localhost:8000 >&2") + machine.succeed("curl -f localhost:8000 >&2") - machine.succeed("curl -f localhost:8000/js/script.js >&2") - ''; -}) + machine.succeed("curl -f localhost:8000/js/script.js >&2") + ''; + } +) diff --git a/nixos/tests/please.nix b/nixos/tests/please.nix index af825ae4b9b3c6..9efd9649ec0f32 100644 --- a/nixos/tests/please.nix +++ b/nixos/tests/please.nix @@ -1,66 +1,68 @@ -import ./make-test-python.nix ({ lib, ... }: -{ - name = "please"; - meta.maintainers = with lib.maintainers; [ azahi ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "please"; + meta.maintainers = with lib.maintainers; [ azahi ]; - nodes.machine = - { ... }: - { - users.users = lib.mkMerge [ - (lib.listToAttrs (map - (n: lib.nameValuePair n { isNormalUser = true; }) - (lib.genList (x: "user${toString x}") 6))) - { - user0.extraGroups = [ "wheel" ]; - } - ]; + nodes.machine = + { ... }: + { + users.users = lib.mkMerge [ + (lib.listToAttrs ( + map (n: lib.nameValuePair n { isNormalUser = true; }) (lib.genList (x: "user${toString x}") 6) + )) + { + user0.extraGroups = [ "wheel" ]; + } + ]; - security.please = { - enable = true; - wheelNeedsPassword = false; - settings = { - user2_run_true_as_root = { - name = "user2"; - target = "root"; - rule = "/run/current-system/sw/bin/true"; - require_pass = false; - }; - user4_edit_etc_hosts_as_root = { - name = "user4"; - type = "edit"; - target = "root"; - rule = "/etc/hosts"; - editmode = 644; - require_pass = false; + security.please = { + enable = true; + wheelNeedsPassword = false; + settings = { + user2_run_true_as_root = { + name = "user2"; + target = "root"; + rule = "/run/current-system/sw/bin/true"; + require_pass = false; + }; + user4_edit_etc_hosts_as_root = { + name = "user4"; + type = "edit"; + target = "root"; + rule = "/etc/hosts"; + editmode = 644; + require_pass = false; + }; }; }; }; - }; - testScript = '' - with subtest("root: can run anything by default"): - machine.succeed('please true') - with subtest("root: can edit anything by default"): - machine.succeed('EDITOR=cat pleaseedit /etc/hosts') + testScript = '' + with subtest("root: can run anything by default"): + machine.succeed('please true') + with subtest("root: can edit anything by default"): + machine.succeed('EDITOR=cat pleaseedit /etc/hosts') - with subtest("user0: can run as root because it's in the wheel group"): - machine.succeed('su - user0 -c "please -u root true"') - with subtest("user1: cannot run as root because it's not in the wheel group"): - machine.fail('su - user1 -c "please -u root true"') + with subtest("user0: can run as root because it's in the wheel group"): + machine.succeed('su - user0 -c "please -u root true"') + with subtest("user1: cannot run as root because it's not in the wheel group"): + machine.fail('su - user1 -c "please -u root true"') - with subtest("user0: can edit as root"): - machine.succeed('su - user0 -c "EDITOR=cat pleaseedit /etc/hosts"') - with subtest("user1: cannot edit as root"): - machine.fail('su - user1 -c "EDITOR=cat pleaseedit /etc/hosts"') + with subtest("user0: can edit as root"): + machine.succeed('su - user0 -c "EDITOR=cat pleaseedit /etc/hosts"') + with subtest("user1: cannot edit as root"): + machine.fail('su - user1 -c "EDITOR=cat pleaseedit /etc/hosts"') - with subtest("user2: can run 'true' as root"): - machine.succeed('su - user2 -c "please -u root true"') - with subtest("user3: cannot run 'true' as root"): - machine.fail('su - user3 -c "please -u root true"') + with subtest("user2: can run 'true' as root"): + machine.succeed('su - user2 -c "please -u root true"') + with subtest("user3: cannot run 'true' as root"): + machine.fail('su - user3 -c "please -u root true"') - with subtest("user4: can edit /etc/hosts"): - machine.succeed('su - user4 -c "EDITOR=cat pleaseedit /etc/hosts"') - with subtest("user5: cannot edit /etc/hosts"): - machine.fail('su - user5 -c "EDITOR=cat pleaseedit /etc/hosts"') - ''; -}) + with subtest("user4: can edit /etc/hosts"): + machine.succeed('su - user4 -c "EDITOR=cat pleaseedit /etc/hosts"') + with subtest("user5: cannot edit /etc/hosts"): + machine.fail('su - user5 -c "EDITOR=cat pleaseedit /etc/hosts"') + ''; + } +) diff --git a/nixos/tests/pleroma.nix b/nixos/tests/pleroma.nix index 8a765c9193291a..79746678206b6c 100644 --- a/nixos/tests/pleroma.nix +++ b/nixos/tests/pleroma.nix @@ -23,236 +23,260 @@ secret. **DO NOT DO THIS IN A REAL WORLD DEPLOYMENT**. */ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: let - send-toot = pkgs.writeScriptBin "send-toot" '' - set -eux - # toot is using the requests library internally. This library - # sadly embed its own certificate store instead of relying on the - # system one. Overriding this pretty bad default behaviour. - export REQUESTS_CA_BUNDLE=/etc/ssl/certs/ca-certificates.crt + send-toot = pkgs.writeScriptBin "send-toot" '' + set -eux + # toot is using the requests library internally. This library + # sadly embed its own certificate store instead of relying on the + # system one. Overriding this pretty bad default behaviour. + export REQUESTS_CA_BUNDLE=/etc/ssl/certs/ca-certificates.crt - toot login_cli -i "pleroma.nixos.test" -e "jamy@nixos.test" -p 'jamy-password' - echo "Login OK" + toot login_cli -i "pleroma.nixos.test" -e "jamy@nixos.test" -p 'jamy-password' + echo "Login OK" - # Send a toot then verify it's part of the public timeline - toot post "hello world Jamy here" - echo "Send toot OK" - toot timeline -1 | grep -F -q "hello world Jamy here" - echo "Get toot from timeline OK" + # Send a toot then verify it's part of the public timeline + toot post "hello world Jamy here" + echo "Send toot OK" + toot timeline -1 | grep -F -q "hello world Jamy here" + echo "Get toot from timeline OK" - # Test file upload - echo "y" | ${pkgs.toot}/bin/toot upload <(dd if=/dev/zero bs=1024 count=1024 status=none) \ - | grep -F -q "https://pleroma.nixos.test/media" + # Test file upload + echo "y" | ${pkgs.toot}/bin/toot upload <(dd if=/dev/zero bs=1024 count=1024 status=none) \ + | grep -F -q "https://pleroma.nixos.test/media" - echo "=====================================================" - echo "= SUCCESS =" - echo "= =" - echo "= We were able to sent a toot + a upload and =" - echo "= retrieve both of them in the public timeline. =" - echo "=====================================================" - ''; + echo "=====================================================" + echo "= SUCCESS =" + echo "= =" + echo "= We were able to sent a toot + a upload and =" + echo "= retrieve both of them in the public timeline. =" + echo "=====================================================" + ''; - provision-db = pkgs.writeScriptBin "provision-db" '' - set -eux - sudo -u postgres psql -f ${db-seed} - ''; + provision-db = pkgs.writeScriptBin "provision-db" '' + set -eux + sudo -u postgres psql -f ${db-seed} + ''; - test-db-passwd = "SccZOvTGM//BMrpoQj68JJkjDkMGb4pHv2cECWiI+XhVe3uGJTLI0vFV/gDlZ5jJ"; + test-db-passwd = "SccZOvTGM//BMrpoQj68JJkjDkMGb4pHv2cECWiI+XhVe3uGJTLI0vFV/gDlZ5jJ"; - /* For this NixOS test, we *had* to store this secret to the store. - Keep in mind the store is world-readable, it's the worst place - possible to store *any* secret. **DO NOT DO THIS IN A REAL WORLD - DEPLOYMENT**.*/ - db-seed = pkgs.writeText "provision.psql" '' - CREATE USER pleroma WITH ENCRYPTED PASSWORD '${test-db-passwd}'; - CREATE DATABASE pleroma OWNER pleroma; - \c pleroma; - --Extensions made by ecto.migrate that need superuser access - CREATE EXTENSION IF NOT EXISTS citext; - CREATE EXTENSION IF NOT EXISTS pg_trgm; - CREATE EXTENSION IF NOT EXISTS "uuid-ossp"; - ''; + /* + For this NixOS test, we *had* to store this secret to the store. + Keep in mind the store is world-readable, it's the worst place + possible to store *any* secret. **DO NOT DO THIS IN A REAL WORLD + DEPLOYMENT**. + */ + db-seed = pkgs.writeText "provision.psql" '' + CREATE USER pleroma WITH ENCRYPTED PASSWORD '${test-db-passwd}'; + CREATE DATABASE pleroma OWNER pleroma; + \c pleroma; + --Extensions made by ecto.migrate that need superuser access + CREATE EXTENSION IF NOT EXISTS citext; + CREATE EXTENSION IF NOT EXISTS pg_trgm; + CREATE EXTENSION IF NOT EXISTS "uuid-ossp"; + ''; - pleroma-conf = '' - import Config + pleroma-conf = '' + import Config - config :pleroma, Pleroma.Web.Endpoint, - url: [host: "pleroma.nixos.test", scheme: "https", port: 443], - http: [ip: {127, 0, 0, 1}, port: 4000] + config :pleroma, Pleroma.Web.Endpoint, + url: [host: "pleroma.nixos.test", scheme: "https", port: 443], + http: [ip: {127, 0, 0, 1}, port: 4000] - config :pleroma, :instance, - name: "NixOS test pleroma server", - email: "pleroma@nixos.test", - notify_email: "pleroma@nixos.test", - limit: 5000, - registrations_open: true + config :pleroma, :instance, + name: "NixOS test pleroma server", + email: "pleroma@nixos.test", + notify_email: "pleroma@nixos.test", + limit: 5000, + registrations_open: true - config :pleroma, :media_proxy, - enabled: false, - redirect_on_failure: true - #base_url: "https://cache.pleroma.social" + config :pleroma, :media_proxy, + enabled: false, + redirect_on_failure: true + #base_url: "https://cache.pleroma.social" - config :pleroma, Pleroma.Repo, - adapter: Ecto.Adapters.Postgres, - username: "pleroma", - password: "${test-db-passwd}", - database: "pleroma", - hostname: "localhost", - pool_size: 10, - prepare: :named, - parameters: [ - plan_cache_mode: "force_custom_plan" - ] + config :pleroma, Pleroma.Repo, + adapter: Ecto.Adapters.Postgres, + username: "pleroma", + password: "${test-db-passwd}", + database: "pleroma", + hostname: "localhost", + pool_size: 10, + prepare: :named, + parameters: [ + plan_cache_mode: "force_custom_plan" + ] - config :pleroma, :database, rum_enabled: false - config :pleroma, :instance, static_dir: "/var/lib/pleroma/static" - config :pleroma, Pleroma.Uploaders.Local, uploads: "/var/lib/pleroma/uploads" - config :pleroma, configurable_from_database: false - ''; + config :pleroma, :database, rum_enabled: false + config :pleroma, :instance, static_dir: "/var/lib/pleroma/static" + config :pleroma, Pleroma.Uploaders.Local, uploads: "/var/lib/pleroma/uploads" + config :pleroma, configurable_from_database: false + ''; - /* For this NixOS test, we *had* to store this secret to the store. - Keep in mind the store is world-readable, it's the worst place - possible to store *any* secret. **DO NOT DO THIS IN A REAL WORLD - DEPLOYMENT**. - In a real-word deployment, you'd handle this either by: - - manually upload your pleroma secrets to /var/lib/pleroma/secrets.exs - - use a deployment tool such as morph or NixOps to deploy your secrets. - */ - pleroma-conf-secret = pkgs.writeText "secrets.exs" '' - import Config + /* + For this NixOS test, we *had* to store this secret to the store. + Keep in mind the store is world-readable, it's the worst place + possible to store *any* secret. **DO NOT DO THIS IN A REAL WORLD + DEPLOYMENT**. + In a real-word deployment, you'd handle this either by: + - manually upload your pleroma secrets to /var/lib/pleroma/secrets.exs + - use a deployment tool such as morph or NixOps to deploy your secrets. + */ + pleroma-conf-secret = pkgs.writeText "secrets.exs" '' + import Config - config :joken, default_signer: "PS69/wMW7X6FIQPABt9lwvlZvgrJIncfiAMrK9J5mjVus/7/NJJi1DsDA1OghBE5" + config :joken, default_signer: "PS69/wMW7X6FIQPABt9lwvlZvgrJIncfiAMrK9J5mjVus/7/NJJi1DsDA1OghBE5" - config :pleroma, Pleroma.Web.Endpoint, - secret_key_base: "NvfmU7lYaQrmmxt4NACm0AaAfN9t6WxsrX0NCB4awkGHvr1S7jyshlEmrjaPFhhq", - signing_salt: "3L41+BuJ" + config :pleroma, Pleroma.Web.Endpoint, + secret_key_base: "NvfmU7lYaQrmmxt4NACm0AaAfN9t6WxsrX0NCB4awkGHvr1S7jyshlEmrjaPFhhq", + signing_salt: "3L41+BuJ" - config :web_push_encryption, :vapid_details, - subject: "mailto:pleroma@nixos.test", - public_key: "BKjfNX9-UqAcncaNqERQtF7n9pKrB0-MO-juv6U5E5XQr_Tg5D-f8AlRjduAguDpyAngeDzG8MdrTejMSL4VF30", - private_key: "k7o9onKMQrgMjMb6l4fsxSaXO0BTNAer5MVSje3q60k" - ''; + config :web_push_encryption, :vapid_details, + subject: "mailto:pleroma@nixos.test", + public_key: "BKjfNX9-UqAcncaNqERQtF7n9pKrB0-MO-juv6U5E5XQr_Tg5D-f8AlRjduAguDpyAngeDzG8MdrTejMSL4VF30", + private_key: "k7o9onKMQrgMjMb6l4fsxSaXO0BTNAer5MVSje3q60k" + ''; - /* For this NixOS test, we *had* to store this secret to the store. - Keep in mind the store is world-readable, it's the worst place - possible to store *any* secret. **DO NOT DO THIS IN A REAL WORLD - DEPLOYMENT**. - In a real-word deployment, you'd handle this either by: - - manually upload your pleroma secrets to /var/lib/pleroma/secrets.exs - - use a deployment tool such as morph or NixOps to deploy your secrets. + /* + For this NixOS test, we *had* to store this secret to the store. + Keep in mind the store is world-readable, it's the worst place + possible to store *any* secret. **DO NOT DO THIS IN A REAL WORLD + DEPLOYMENT**. + In a real-word deployment, you'd handle this either by: + - manually upload your pleroma secrets to /var/lib/pleroma/secrets.exs + - use a deployment tool such as morph or NixOps to deploy your secrets. */ - provision-secrets = pkgs.writeScriptBin "provision-secrets" '' - set -eux - cp "${pleroma-conf-secret}" "/var/lib/pleroma/secrets.exs" - chown pleroma:pleroma /var/lib/pleroma/secrets.exs - ''; + provision-secrets = pkgs.writeScriptBin "provision-secrets" '' + set -eux + cp "${pleroma-conf-secret}" "/var/lib/pleroma/secrets.exs" + chown pleroma:pleroma /var/lib/pleroma/secrets.exs + ''; - /* For this NixOS test, we *had* to store this secret to the store. - Keep in mind the store is world-readable, it's the worst place - possible to store *any* secret. **DO NOT DO THIS IN A REAL WORLD - DEPLOYMENT**. - */ - provision-user = pkgs.writeScriptBin "provision-user" '' - set -eux + /* + For this NixOS test, we *had* to store this secret to the store. + Keep in mind the store is world-readable, it's the worst place + possible to store *any* secret. **DO NOT DO THIS IN A REAL WORLD + DEPLOYMENT**. + */ + provision-user = pkgs.writeScriptBin "provision-user" '' + set -eux - # Waiting for pleroma to be up. - timeout 5m bash -c 'while [[ "$(curl -s -o /dev/null -w '%{http_code}' https://pleroma.nixos.test/api/v1/instance)" != "200" ]]; do sleep 2; done' - # Toremove the RELEASE_COOKIE bit when https://github.com/NixOS/nixpkgs/issues/166229 gets fixed. - RELEASE_COOKIE="/var/lib/pleroma/.cookie" \ - pleroma_ctl user new jamy jamy@nixos.test --password 'jamy-password' --moderator --admin -y - ''; + # Waiting for pleroma to be up. + timeout 5m bash -c 'while [[ "$(curl -s -o /dev/null -w '%{http_code}' https://pleroma.nixos.test/api/v1/instance)" != "200" ]]; do sleep 2; done' + # Toremove the RELEASE_COOKIE bit when https://github.com/NixOS/nixpkgs/issues/166229 gets fixed. + RELEASE_COOKIE="/var/lib/pleroma/.cookie" \ + pleroma_ctl user new jamy jamy@nixos.test --password 'jamy-password' --moderator --admin -y + ''; - tls-cert = pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' - mkdir -p $out - openssl req -x509 \ - -subj '/CN=pleroma.nixos.test/' -days 49710 \ - -addext 'subjectAltName = DNS:pleroma.nixos.test' \ - -keyout "$out/key.pem" -newkey ed25519 \ - -out "$out/cert.pem" -noenc - ''; + tls-cert = pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' + mkdir -p $out + openssl req -x509 \ + -subj '/CN=pleroma.nixos.test/' -days 49710 \ + -addext 'subjectAltName = DNS:pleroma.nixos.test' \ + -keyout "$out/key.pem" -newkey ed25519 \ + -out "$out/cert.pem" -noenc + ''; - hosts = nodes: '' - ${nodes.pleroma.networking.primaryIPAddress} pleroma.nixos.test - ${nodes.client.networking.primaryIPAddress} client.nixos.test - ''; - in { - name = "pleroma"; - nodes = { - client = { nodes, pkgs, config, ... }: { - security.pki.certificateFiles = [ "${tls-cert}/cert.pem" ]; - networking.extraHosts = hosts nodes; - environment.systemPackages = [ - pkgs.toot - send-toot - ]; - }; - pleroma = { nodes, pkgs, config, ... }: { - security.pki.certificateFiles = [ "${tls-cert}/cert.pem" ]; - networking.extraHosts = hosts nodes; - networking.firewall.enable = false; - environment.systemPackages = [ - provision-db - provision-secrets - provision-user - ]; - services = { - pleroma = { - enable = true; - configs = [ - pleroma-conf + hosts = nodes: '' + ${nodes.pleroma.networking.primaryIPAddress} pleroma.nixos.test + ${nodes.client.networking.primaryIPAddress} client.nixos.test + ''; + in + { + name = "pleroma"; + nodes = { + client = + { + nodes, + pkgs, + config, + ... + }: + { + security.pki.certificateFiles = [ "${tls-cert}/cert.pem" ]; + networking.extraHosts = hosts nodes; + environment.systemPackages = [ + pkgs.toot + send-toot ]; }; - postgresql = { - enable = true; - package = pkgs.postgresql_13; - }; - nginx = { - enable = true; - virtualHosts."pleroma.nixos.test" = { - addSSL = true; - sslCertificate = "${tls-cert}/cert.pem"; - sslCertificateKey = "${tls-cert}/key.pem"; - locations."/" = { - proxyPass = "http://127.0.0.1:4000"; - extraConfig = '' - add_header 'Access-Control-Allow-Origin' '*' always; - add_header 'Access-Control-Allow-Methods' 'POST, PUT, DELETE, GET, PATCH, OPTIONS' always; - add_header 'Access-Control-Allow-Headers' 'Authorization, Content-Type, Idempotency-Key' always; - add_header 'Access-Control-Expose-Headers' 'Link, X-RateLimit-Reset, X-RateLimit-Limit, X-RateLimit-Remaining, X-Request-Id' always; - if ($request_method = OPTIONS) { - return 204; - } - add_header X-XSS-Protection "1; mode=block"; - add_header X-Permitted-Cross-Domain-Policies none; - add_header X-Frame-Options DENY; - add_header X-Content-Type-Options nosniff; - add_header Referrer-Policy same-origin; - add_header X-Download-Options noopen; - proxy_http_version 1.1; - proxy_set_header Upgrade $http_upgrade; - proxy_set_header Connection "upgrade"; - proxy_set_header Host $host; - client_max_body_size 16m; - ''; + pleroma = + { + nodes, + pkgs, + config, + ... + }: + { + security.pki.certificateFiles = [ "${tls-cert}/cert.pem" ]; + networking.extraHosts = hosts nodes; + networking.firewall.enable = false; + environment.systemPackages = [ + provision-db + provision-secrets + provision-user + ]; + services = { + pleroma = { + enable = true; + configs = [ + pleroma-conf + ]; + }; + postgresql = { + enable = true; + package = pkgs.postgresql_13; + }; + nginx = { + enable = true; + virtualHosts."pleroma.nixos.test" = { + addSSL = true; + sslCertificate = "${tls-cert}/cert.pem"; + sslCertificateKey = "${tls-cert}/key.pem"; + locations."/" = { + proxyPass = "http://127.0.0.1:4000"; + extraConfig = '' + add_header 'Access-Control-Allow-Origin' '*' always; + add_header 'Access-Control-Allow-Methods' 'POST, PUT, DELETE, GET, PATCH, OPTIONS' always; + add_header 'Access-Control-Allow-Headers' 'Authorization, Content-Type, Idempotency-Key' always; + add_header 'Access-Control-Expose-Headers' 'Link, X-RateLimit-Reset, X-RateLimit-Limit, X-RateLimit-Remaining, X-Request-Id' always; + if ($request_method = OPTIONS) { + return 204; + } + add_header X-XSS-Protection "1; mode=block"; + add_header X-Permitted-Cross-Domain-Policies none; + add_header X-Frame-Options DENY; + add_header X-Content-Type-Options nosniff; + add_header Referrer-Policy same-origin; + add_header X-Download-Options noopen; + proxy_http_version 1.1; + proxy_set_header Upgrade $http_upgrade; + proxy_set_header Connection "upgrade"; + proxy_set_header Host $host; + client_max_body_size 16m; + ''; + }; + }; }; }; }; - }; }; - }; - testScript = { nodes, ... }: '' - pleroma.wait_for_unit("postgresql.service") - pleroma.wait_until_succeeds("ls /var/lib/pleroma") - pleroma.succeed("provision-db") - pleroma.wait_for_file("/var/lib/pleroma") - pleroma.succeed("provision-secrets") - pleroma.systemctl("restart pleroma.service") - pleroma.wait_for_unit("pleroma.service") - pleroma.succeed("provision-user") - client.succeed("send-toot") - ''; + testScript = + { nodes, ... }: + '' + pleroma.wait_for_unit("postgresql.service") + pleroma.wait_until_succeeds("ls /var/lib/pleroma") + pleroma.succeed("provision-db") + pleroma.wait_for_file("/var/lib/pleroma") + pleroma.succeed("provision-secrets") + pleroma.systemctl("restart pleroma.service") + pleroma.wait_for_unit("pleroma.service") + pleroma.succeed("provision-user") + client.succeed("send-toot") + ''; - meta.timeout = 600; -}) + meta.timeout = 600; + } +) diff --git a/nixos/tests/plikd.nix b/nixos/tests/plikd.nix index 97c254a5f7b05a..05a1c6017d2d69 100644 --- a/nixos/tests/plikd.nix +++ b/nixos/tests/plikd.nix @@ -1,27 +1,33 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "plikd"; - meta = with lib.maintainers; { - maintainers = [ freezeboy ]; - }; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "plikd"; + meta = with lib.maintainers; { + maintainers = [ freezeboy ]; + }; - nodes.machine = { pkgs, ... }: let - in { - services.plikd.enable = true; - environment.systemPackages = [ pkgs.plik ]; - }; + nodes.machine = + { pkgs, ... }: + let + in + { + services.plikd.enable = true; + environment.systemPackages = [ pkgs.plik ]; + }; - testScript = '' - # Service basic test - machine.wait_for_unit("plikd") + testScript = '' + # Service basic test + machine.wait_for_unit("plikd") - # Network test - machine.wait_for_open_port(8080) - machine.succeed("curl --fail -v http://localhost:8080") + # Network test + machine.wait_for_open_port(8080) + machine.succeed("curl --fail -v http://localhost:8080") - # Application test - machine.execute("echo test > /tmp/data.txt") - machine.succeed("plik --server http://localhost:8080 /tmp/data.txt | grep curl") + # Application test + machine.execute("echo test > /tmp/data.txt") + machine.succeed("plik --server http://localhost:8080 /tmp/data.txt | grep curl") - machine.succeed("diff data.txt /tmp/data.txt") - ''; -}) + machine.succeed("diff data.txt /tmp/data.txt") + ''; + } +) diff --git a/nixos/tests/plotinus.nix b/nixos/tests/plotinus.nix index 2bb2b705eb7e9e..97041012756a5e 100644 --- a/nixos/tests/plotinus.nix +++ b/nixos/tests/plotinus.nix @@ -1,32 +1,36 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "plotinus"; - meta = { - maintainers = pkgs.plotinus.meta.maintainers; - timeout = 600; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "plotinus"; + meta = { + maintainers = pkgs.plotinus.meta.maintainers; + timeout = 600; + }; - nodes.machine = - { pkgs, ... }: + nodes.machine = + { pkgs, ... }: - { imports = [ ./common/x11.nix ]; - programs.plotinus.enable = true; - environment.systemPackages = [ - pkgs.gnome-pomodoro - pkgs.xdotool - ]; - }; + { + imports = [ ./common/x11.nix ]; + programs.plotinus.enable = true; + environment.systemPackages = [ + pkgs.gnome-pomodoro + pkgs.xdotool + ]; + }; - testScript = '' - machine.wait_for_x() - machine.succeed("gnome-pomodoro >&2 &") - machine.wait_for_window("Pomodoro", timeout=120) - machine.succeed( - "xdotool search --sync --onlyvisible --class gnome-pomodoro " - + "windowfocus --sync key --clearmodifiers --delay 1 'ctrl+shift+p'" - ) - machine.sleep(5) # wait for the popup - machine.screenshot("popup") - machine.succeed("xdotool key --delay 100 p r e f e r e n c e s Return") - machine.wait_for_window("Preferences", timeout=120) - ''; -}) + testScript = '' + machine.wait_for_x() + machine.succeed("gnome-pomodoro >&2 &") + machine.wait_for_window("Pomodoro", timeout=120) + machine.succeed( + "xdotool search --sync --onlyvisible --class gnome-pomodoro " + + "windowfocus --sync key --clearmodifiers --delay 1 'ctrl+shift+p'" + ) + machine.sleep(5) # wait for the popup + machine.screenshot("popup") + machine.succeed("xdotool key --delay 100 p r e f e r e n c e s Return") + machine.wait_for_window("Preferences", timeout=120) + ''; + } +) diff --git a/nixos/tests/podgrab.nix b/nixos/tests/podgrab.nix index dc9dfebaf49bd9..05c2fd7260162d 100644 --- a/nixos/tests/podgrab.nix +++ b/nixos/tests/podgrab.nix @@ -2,33 +2,40 @@ let defaultPort = 8080; customPort = 4242; in -import ./make-test-python.nix ({ pkgs, ... }: { - name = "podgrab"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "podgrab"; - nodes = { - default = { ... }: { - services.podgrab.enable = true; - }; + nodes = { + default = + { ... }: + { + services.podgrab.enable = true; + }; - customized = { ... }: { - services.podgrab = { - enable = true; - port = customPort; - }; + customized = + { ... }: + { + services.podgrab = { + enable = true; + port = customPort; + }; + }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - default.wait_for_unit("podgrab") - default.wait_for_open_port(${toString defaultPort}) - default.succeed("curl --fail http://localhost:${toString defaultPort}") + default.wait_for_unit("podgrab") + default.wait_for_open_port(${toString defaultPort}) + default.succeed("curl --fail http://localhost:${toString defaultPort}") - customized.wait_for_unit("podgrab") - customized.wait_for_open_port(${toString customPort}) - customized.succeed("curl --fail http://localhost:${toString customPort}") - ''; + customized.wait_for_unit("podgrab") + customized.wait_for_open_port(${toString customPort}) + customized.succeed("curl --fail http://localhost:${toString customPort}") + ''; - meta.maintainers = with pkgs.lib.maintainers; [ ambroisie ]; -}) + meta.maintainers = with pkgs.lib.maintainers; [ ambroisie ]; + } +) diff --git a/nixos/tests/podman/default.nix b/nixos/tests/podman/default.nix index f57523cf58886f..164f769b1fb08c 100644 --- a/nixos/tests/podman/default.nix +++ b/nixos/tests/podman/default.nix @@ -23,43 +23,51 @@ import ../make-test-python.nix ( }; nodes = { - rootful = { pkgs, ... }: { - virtualisation.podman.enable = true; - - # hack to ensure that podman built with and without zfs in extraPackages is cached - boot.supportedFilesystems = [ "zfs" ]; - networking.hostId = "00000000"; - }; - rootless = { pkgs, ... }: { - virtualisation.podman.enable = true; - - users.users.alice = { - isNormalUser = true; + rootful = + { pkgs, ... }: + { + virtualisation.podman.enable = true; + + # hack to ensure that podman built with and without zfs in extraPackages is cached + boot.supportedFilesystems = [ "zfs" ]; + networking.hostId = "00000000"; }; - }; - dns = { pkgs, ... }: { - virtualisation.podman.enable = true; + rootless = + { pkgs, ... }: + { + virtualisation.podman.enable = true; + + users.users.alice = { + isNormalUser = true; + }; + }; + dns = + { pkgs, ... }: + { + virtualisation.podman.enable = true; - virtualisation.podman.defaultNetwork.settings.dns_enabled = true; - }; - docker = { pkgs, ... }: { - virtualisation.podman.enable = true; + virtualisation.podman.defaultNetwork.settings.dns_enabled = true; + }; + docker = + { pkgs, ... }: + { + virtualisation.podman.enable = true; - virtualisation.podman.dockerSocket.enable = true; + virtualisation.podman.dockerSocket.enable = true; - environment.systemPackages = [ - pkgs.docker-client - ]; + environment.systemPackages = [ + pkgs.docker-client + ]; - users.users.alice = { - isNormalUser = true; - extraGroups = [ "podman" ]; - }; + users.users.alice = { + isNormalUser = true; + extraGroups = [ "podman" ]; + }; - users.users.mallory = { - isNormalUser = true; + users.users.mallory = { + isNormalUser = true; + }; }; - }; }; testScript = '' diff --git a/nixos/tests/podman/tls-ghostunnel.nix b/nixos/tests/podman/tls-ghostunnel.nix index 52c31dc21f1014..fb4a43fd4a8985 100644 --- a/nixos/tests/podman/tls-ghostunnel.nix +++ b/nixos/tests/podman/tls-ghostunnel.nix @@ -1,38 +1,37 @@ -/* - This test runs podman as a backend for the Docker CLI. - */ +# This test runs podman as a backend for the Docker CLI. import ../make-test-python.nix ( { pkgs, lib, ... }: - let gen-ca = pkgs.writeScript "gen-ca" '' - # Create CA - PATH="${pkgs.openssl}/bin:$PATH" - openssl genrsa -out ca-key.pem 4096 - openssl req -new -x509 -days 365 -key ca-key.pem -sha256 -subj '/C=NL/ST=Zuid-Holland/L=The Hague/O=Stevige Balken en Planken B.V./OU=OpSec/CN=Certificate Authority' -out ca.pem - - # Create service - openssl genrsa -out podman-key.pem 4096 - openssl req -subj '/CN=podman' -sha256 -new -key podman-key.pem -out service.csr - echo subjectAltName = DNS:podman,IP:127.0.0.1 >> extfile.cnf - echo extendedKeyUsage = serverAuth >> extfile.cnf - openssl x509 -req -days 365 -sha256 -in service.csr -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out podman-cert.pem -extfile extfile.cnf - - # Create client - openssl genrsa -out client-key.pem 4096 - openssl req -subj '/CN=client' -new -key client-key.pem -out client.csr - echo extendedKeyUsage = clientAuth > extfile-client.cnf - openssl x509 -req -days 365 -sha256 -in client.csr -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out client-cert.pem -extfile extfile-client.cnf - - # Create CA 2 - PATH="${pkgs.openssl}/bin:$PATH" - openssl genrsa -out ca-2-key.pem 4096 - openssl req -new -x509 -days 365 -key ca-2-key.pem -sha256 -subj '/C=NL/ST=Zuid-Holland/L=The Hague/O=Stevige Balken en Planken B.V./OU=OpSec/CN=Certificate Authority' -out ca-2.pem - - # Create client signed by CA 2 - openssl genrsa -out client-2-key.pem 4096 - openssl req -subj '/CN=client' -new -key client-2-key.pem -out client-2.csr - echo extendedKeyUsage = clientAuth > extfile-client.cnf - openssl x509 -req -days 365 -sha256 -in client-2.csr -CA ca-2.pem -CAkey ca-2-key.pem -CAcreateserial -out client-2-cert.pem -extfile extfile-client.cnf + let + gen-ca = pkgs.writeScript "gen-ca" '' + # Create CA + PATH="${pkgs.openssl}/bin:$PATH" + openssl genrsa -out ca-key.pem 4096 + openssl req -new -x509 -days 365 -key ca-key.pem -sha256 -subj '/C=NL/ST=Zuid-Holland/L=The Hague/O=Stevige Balken en Planken B.V./OU=OpSec/CN=Certificate Authority' -out ca.pem + + # Create service + openssl genrsa -out podman-key.pem 4096 + openssl req -subj '/CN=podman' -sha256 -new -key podman-key.pem -out service.csr + echo subjectAltName = DNS:podman,IP:127.0.0.1 >> extfile.cnf + echo extendedKeyUsage = serverAuth >> extfile.cnf + openssl x509 -req -days 365 -sha256 -in service.csr -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out podman-cert.pem -extfile extfile.cnf + + # Create client + openssl genrsa -out client-key.pem 4096 + openssl req -subj '/CN=client' -new -key client-key.pem -out client.csr + echo extendedKeyUsage = clientAuth > extfile-client.cnf + openssl x509 -req -days 365 -sha256 -in client.csr -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out client-cert.pem -extfile extfile-client.cnf + + # Create CA 2 + PATH="${pkgs.openssl}/bin:$PATH" + openssl genrsa -out ca-2-key.pem 4096 + openssl req -new -x509 -days 365 -key ca-2-key.pem -sha256 -subj '/C=NL/ST=Zuid-Holland/L=The Hague/O=Stevige Balken en Planken B.V./OU=OpSec/CN=Certificate Authority' -out ca-2.pem + + # Create client signed by CA 2 + openssl genrsa -out client-2-key.pem 4096 + openssl req -subj '/CN=client' -new -key client-2-key.pem -out client-2.csr + echo extendedKeyUsage = clientAuth > extfile-client.cnf + openssl x509 -req -days 365 -sha256 -in client-2.csr -CA ca-2.pem -CAkey ca-2-key.pem -CAcreateserial -out client-2-cert.pem -extfile extfile-client.cnf ''; in @@ -65,20 +64,22 @@ import ../make-test-python.nix ( isNormalUser = true; home = "/home/alice"; description = "Alice Foobar"; - extraGroups = ["podman"]; + extraGroups = [ "podman" ]; }; }; - client = { ... }: { - environment.systemPackages = [ - # Installs the docker _client_ only - # Normally, you'd want `virtualisation.docker.enable = true;`. - pkgs.docker-client - ]; - environment.variables.DOCKER_HOST = "podman:2376"; - environment.variables.DOCKER_TLS_VERIFY = "1"; - }; + client = + { ... }: + { + environment.systemPackages = [ + # Installs the docker _client_ only + # Normally, you'd want `virtualisation.docker.enable = true;`. + pkgs.docker-client + ]; + environment.variables.DOCKER_HOST = "podman:2376"; + environment.variables.DOCKER_TLS_VERIFY = "1"; + }; }; testScript = '' diff --git a/nixos/tests/polaris.nix b/nixos/tests/polaris.nix index bb105d600032f6..3a530996d63ab0 100644 --- a/nixos/tests/polaris.nix +++ b/nixos/tests/polaris.nix @@ -1,29 +1,32 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "polaris"; - meta.maintainers = with lib.maintainers; [ pbsds ]; + { + name = "polaris"; + meta.maintainers = with lib.maintainers; [ pbsds ]; - nodes.machine = - { pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; - services.polaris = { - enable = true; - port = 5050; - settings.users = [ - { - name = "test_user"; - password = "very_secret_password"; - admin = true; - } - ]; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; + services.polaris = { + enable = true; + port = 5050; + settings.users = [ + { + name = "test_user"; + password = "very_secret_password"; + admin = true; + } + ]; + }; }; - }; - testScript = '' - machine.wait_for_unit("polaris.service") - machine.wait_for_open_port(5050) - machine.succeed("curl http://localhost:5050/api/version") - machine.succeed("curl -X GET http://localhost:5050/api/initial_setup -H 'accept: application/json' | jq -e '.has_any_users == true'") - ''; -}) + testScript = '' + machine.wait_for_unit("polaris.service") + machine.wait_for_open_port(5050) + machine.succeed("curl http://localhost:5050/api/version") + machine.succeed("curl -X GET http://localhost:5050/api/initial_setup -H 'accept: application/json' | jq -e '.has_any_users == true'") + ''; + } +) diff --git a/nixos/tests/pomerium.nix b/nixos/tests/pomerium.nix index d0204488e8efd8..f9a8c2c2a1ed74 100644 --- a/nixos/tests/pomerium.nix +++ b/nixos/tests/pomerium.nix @@ -1,109 +1,143 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "pomerium"; - meta = with lib.maintainers; { - maintainers = [ lukegb devusb ]; - }; - - nodes = let base = myIP: { pkgs, lib, ... }: { - virtualisation.vlans = [ 1 ]; - networking = { - dhcpcd.enable = false; - firewall.allowedTCPPorts = [ 80 443 ]; - hosts = { - "192.168.1.1" = [ "pomerium" "pom-auth" ]; - "192.168.1.2" = [ "backend" "dummy-oidc" ]; - }; - interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ - { address = myIP; prefixLength = 24; } +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "pomerium"; + meta = with lib.maintainers; { + maintainers = [ + lukegb + devusb ]; }; - }; in { - pomerium = { pkgs, lib, ... }: { - imports = [ (base "192.168.1.1") ]; - environment.systemPackages = with pkgs; [ chromium ]; - services.pomerium = { - enable = true; - settings = { - address = ":80"; - insecure_server = true; - authenticate_service_url = "http://pom-auth"; - idp_provider = "oidc"; - idp_scopes = [ "oidc" ]; - idp_client_id = "dummy"; - idp_provider_url = "http://dummy-oidc"; + nodes = + let + base = + myIP: + { pkgs, lib, ... }: + { + virtualisation.vlans = [ 1 ]; + networking = { + dhcpcd.enable = false; + firewall.allowedTCPPorts = [ + 80 + 443 + ]; + hosts = { + "192.168.1.1" = [ + "pomerium" + "pom-auth" + ]; + "192.168.1.2" = [ + "backend" + "dummy-oidc" + ]; + }; + interfaces.eth1.ipv4.addresses = pkgs.lib.mkOverride 0 [ + { + address = myIP; + prefixLength = 24; + } + ]; + }; + }; + in + { + pomerium = + { pkgs, lib, ... }: + { + imports = [ (base "192.168.1.1") ]; + environment.systemPackages = with pkgs; [ chromium ]; + services.pomerium = { + enable = true; + settings = { + address = ":80"; + insecure_server = true; + authenticate_service_url = "http://pom-auth"; - policy = [{ - from = "https://my.website"; - to = "http://192.168.1.2"; - allow_public_unauthenticated_access = true; - preserve_host_header = true; - } { - from = "https://login.required"; - to = "http://192.168.1.2"; - allowed_domains = [ "my.domain" ]; - preserve_host_header = true; - }]; - }; - secretsFile = pkgs.writeText "pomerium-secrets" '' - # 12345678901234567890123456789012 in base64 - COOKIE_SECRET=MTIzNDU2Nzg5MDEyMzQ1Njc4OTAxMjM0NTY3ODkwMTI= - IDP_CLIENT_SECRET=dummy - ''; - }; - }; - backend = { pkgs, lib, ... }: { - imports = [ (base "192.168.1.2") ]; - services.nginx.enable = true; - services.nginx.virtualHosts."my.website" = { - root = pkgs.runCommand "testdir" {} '' - mkdir "$out" - echo hello world > "$out/index.html" - ''; - }; - services.nginx.virtualHosts."dummy-oidc" = { - root = pkgs.runCommand "testdir" {} '' - mkdir -p "$out/.well-known" - cat <"$out/.well-known/openid-configuration" - { - "issuer": "http://dummy-oidc", - "authorization_endpoint": "http://dummy-oidc/auth.txt", - "token_endpoint": "http://dummy-oidc/token", - "jwks_uri": "http://dummy-oidc/jwks.json", - "userinfo_endpoint": "http://dummy-oidc/userinfo", - "id_token_signing_alg_values_supported": ["RS256"] - } - EOF - echo hello I am login page >"$out/auth.txt" - ''; + idp_provider = "oidc"; + idp_scopes = [ "oidc" ]; + idp_client_id = "dummy"; + idp_provider_url = "http://dummy-oidc"; + + policy = [ + { + from = "https://my.website"; + to = "http://192.168.1.2"; + allow_public_unauthenticated_access = true; + preserve_host_header = true; + } + { + from = "https://login.required"; + to = "http://192.168.1.2"; + allowed_domains = [ "my.domain" ]; + preserve_host_header = true; + } + ]; + }; + secretsFile = pkgs.writeText "pomerium-secrets" '' + # 12345678901234567890123456789012 in base64 + COOKIE_SECRET=MTIzNDU2Nzg5MDEyMzQ1Njc4OTAxMjM0NTY3ODkwMTI= + IDP_CLIENT_SECRET=dummy + ''; + }; + }; + backend = + { pkgs, lib, ... }: + { + imports = [ (base "192.168.1.2") ]; + services.nginx.enable = true; + services.nginx.virtualHosts."my.website" = { + root = pkgs.runCommand "testdir" { } '' + mkdir "$out" + echo hello world > "$out/index.html" + ''; + }; + services.nginx.virtualHosts."dummy-oidc" = { + root = pkgs.runCommand "testdir" { } '' + mkdir -p "$out/.well-known" + cat <"$out/.well-known/openid-configuration" + { + "issuer": "http://dummy-oidc", + "authorization_endpoint": "http://dummy-oidc/auth.txt", + "token_endpoint": "http://dummy-oidc/token", + "jwks_uri": "http://dummy-oidc/jwks.json", + "userinfo_endpoint": "http://dummy-oidc/userinfo", + "id_token_signing_alg_values_supported": ["RS256"] + } + EOF + echo hello I am login page >"$out/auth.txt" + ''; + }; + }; }; - }; - }; - testScript = { ... }: '' - backend.wait_for_unit("nginx") - backend.wait_for_open_port(80) + testScript = + { ... }: + '' + backend.wait_for_unit("nginx") + backend.wait_for_open_port(80) - pomerium.wait_for_unit("pomerium") - pomerium.wait_for_open_port(80) + pomerium.wait_for_unit("pomerium") + pomerium.wait_for_open_port(80) - with subtest("no authentication required"): - pomerium.succeed( - "curl --resolve my.website:80:127.0.0.1 http://my.website | grep 'hello world'" - ) + with subtest("no authentication required"): + pomerium.succeed( + "curl --resolve my.website:80:127.0.0.1 http://my.website | grep 'hello world'" + ) - with subtest("login required"): - pomerium.succeed( - "curl -I --resolve login.required:80:127.0.0.1 http://login.required | grep pom-auth" - ) - pomerium.succeed( - "curl -L --resolve login.required:80:127.0.0.1 http://login.required | grep 'hello I am login page'" - ) + with subtest("login required"): + pomerium.succeed( + "curl -I --resolve login.required:80:127.0.0.1 http://login.required | grep pom-auth" + ) + pomerium.succeed( + "curl -L --resolve login.required:80:127.0.0.1 http://login.required | grep 'hello I am login page'" + ) - with subtest("ui"): - pomerium.succeed( - # check for a string that only appears if the UI is displayed correctly - "chromium --no-sandbox --headless --disable-gpu --dump-dom --host-resolver-rules='MAP login.required 127.0.0.1:80' http://login.required/.pomerium | grep 'User Details Not Available'" - ) - ''; -}) + with subtest("ui"): + pomerium.succeed( + # check for a string that only appears if the UI is displayed correctly + "chromium --no-sandbox --headless --disable-gpu --dump-dom --host-resolver-rules='MAP login.required 127.0.0.1:80' http://login.required/.pomerium | grep 'User Details Not Available'" + ) + ''; + } +) diff --git a/nixos/tests/portunus.nix b/nixos/tests/portunus.nix index 6fcae7e1c4cead..5bfe990943b547 100644 --- a/nixos/tests/portunus.nix +++ b/nixos/tests/portunus.nix @@ -1,18 +1,20 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "portunus"; - meta.maintainers = with lib.maintainers; [ SuperSandro2000 ]; + { + name = "portunus"; + meta.maintainers = with lib.maintainers; [ SuperSandro2000 ]; - nodes.machine = _: { - services.portunus = { - enable = true; - ldap.suffix = "dc=example,dc=org"; + nodes.machine = _: { + services.portunus = { + enable = true; + ldap.suffix = "dc=example,dc=org"; + }; }; - }; - testScript = '' - machine.wait_for_unit("portunus.service") - machine.succeed("curl --fail -vvv http://localhost:8080/") - ''; -}) + testScript = '' + machine.wait_for_unit("portunus.service") + machine.succeed("curl --fail -vvv http://localhost:8080/") + ''; + } +) diff --git a/nixos/tests/postfix-raise-smtpd-tls-security-level.nix b/nixos/tests/postfix-raise-smtpd-tls-security-level.nix index 2a6c85a3a9202f..e9366f96f878ca 100644 --- a/nixos/tests/postfix-raise-smtpd-tls-security-level.nix +++ b/nixos/tests/postfix-raise-smtpd-tls-security-level.nix @@ -1,38 +1,42 @@ import ./make-test-python.nix { name = "postfix"; - nodes.machine = { pkgs, ... }: { - imports = [ common/user-account.nix ]; - services.postfix = { - enable = true; - enableSubmissions = true; - submissionsOptions = { - smtpd_tls_security_level = "none"; + nodes.machine = + { pkgs, ... }: + { + imports = [ common/user-account.nix ]; + services.postfix = { + enable = true; + enableSubmissions = true; + submissionsOptions = { + smtpd_tls_security_level = "none"; + }; }; - }; - environment.systemPackages = let - checkConfig = pkgs.writeScriptBin "check-config" '' - #!${pkgs.python3.interpreter} - import sys + environment.systemPackages = + let + checkConfig = pkgs.writeScriptBin "check-config" '' + #!${pkgs.python3.interpreter} + import sys - state = 1 - success = False + state = 1 + success = False - with open("/etc/postfix/master.cf") as masterCf: - for line in masterCf: - if state == 1 and line.startswith("submissions"): - state = 2 - elif state == 2 and line.startswith(" ") and "smtpd_tls_security_level=encrypt" in line: - success = True - elif state == 2 and not line.startswith(" "): - state == 3 - if not success: - sys.exit(1) - ''; + with open("/etc/postfix/master.cf") as masterCf: + for line in masterCf: + if state == 1 and line.startswith("submissions"): + state = 2 + elif state == 2 and line.startswith(" ") and "smtpd_tls_security_level=encrypt" in line: + success = True + elif state == 2 and not line.startswith(" "): + state == 3 + if not success: + sys.exit(1) + ''; - in [ checkConfig ]; - }; + in + [ checkConfig ]; + }; testScript = '' machine.wait_for_unit("postfix.service") diff --git a/nixos/tests/postfix.nix b/nixos/tests/postfix.nix index 1dbe6a4c519344..674a7656079ff6 100644 --- a/nixos/tests/postfix.nix +++ b/nixos/tests/postfix.nix @@ -5,68 +5,76 @@ in import ./make-test-python.nix { name = "postfix"; - nodes.machine = { pkgs, ... }: { - imports = [ common/user-account.nix ]; - services.postfix = { - enable = true; - enableSubmission = true; - enableSubmissions = true; - tlsTrustedAuthorities = "${certs.ca.cert}"; - sslCert = "${certs.${domain}.cert}"; - sslKey = "${certs.${domain}.key}"; - submissionsOptions = { + nodes.machine = + { pkgs, ... }: + { + imports = [ common/user-account.nix ]; + services.postfix = { + enable = true; + enableSubmission = true; + enableSubmissions = true; + tlsTrustedAuthorities = "${certs.ca.cert}"; + sslCert = "${certs.${domain}.cert}"; + sslKey = "${certs.${domain}.key}"; + submissionsOptions = { smtpd_sasl_auth_enable = "yes"; smtpd_client_restrictions = "permit"; milter_macro_daemon_name = "ORIGINATING"; + }; }; - }; - security.pki.certificateFiles = [ - certs.ca.cert - ]; + security.pki.certificateFiles = [ + certs.ca.cert + ]; - networking.extraHosts = '' - 127.0.0.1 ${domain} - ''; + networking.extraHosts = '' + 127.0.0.1 ${domain} + ''; - environment.systemPackages = let - sendTestMail = pkgs.writeScriptBin "send-testmail" '' - #!${pkgs.python3.interpreter} - import smtplib + environment.systemPackages = + let + sendTestMail = pkgs.writeScriptBin "send-testmail" '' + #!${pkgs.python3.interpreter} + import smtplib - with smtplib.SMTP('${domain}') as smtp: - smtp.sendmail('root@localhost', 'alice@localhost', 'Subject: Test\n\nTest data.') - smtp.quit() - ''; + with smtplib.SMTP('${domain}') as smtp: + smtp.sendmail('root@localhost', 'alice@localhost', 'Subject: Test\n\nTest data.') + smtp.quit() + ''; - sendTestMailStarttls = pkgs.writeScriptBin "send-testmail-starttls" '' - #!${pkgs.python3.interpreter} - import smtplib - import ssl + sendTestMailStarttls = pkgs.writeScriptBin "send-testmail-starttls" '' + #!${pkgs.python3.interpreter} + import smtplib + import ssl - ctx = ssl.create_default_context() + ctx = ssl.create_default_context() - with smtplib.SMTP('${domain}') as smtp: - smtp.ehlo() - smtp.starttls(context=ctx) - smtp.ehlo() - smtp.sendmail('root@localhost', 'alice@localhost', 'Subject: Test STARTTLS\n\nTest data.') - smtp.quit() - ''; + with smtplib.SMTP('${domain}') as smtp: + smtp.ehlo() + smtp.starttls(context=ctx) + smtp.ehlo() + smtp.sendmail('root@localhost', 'alice@localhost', 'Subject: Test STARTTLS\n\nTest data.') + smtp.quit() + ''; - sendTestMailSmtps = pkgs.writeScriptBin "send-testmail-smtps" '' - #!${pkgs.python3.interpreter} - import smtplib - import ssl + sendTestMailSmtps = pkgs.writeScriptBin "send-testmail-smtps" '' + #!${pkgs.python3.interpreter} + import smtplib + import ssl - ctx = ssl.create_default_context() + ctx = ssl.create_default_context() - with smtplib.SMTP_SSL(host='${domain}', context=ctx) as smtp: - smtp.sendmail('root@localhost', 'alice@localhost', 'Subject: Test SMTPS\n\nTest data.') - smtp.quit() - ''; - in [ sendTestMail sendTestMailStarttls sendTestMailSmtps ]; - }; + with smtplib.SMTP_SSL(host='${domain}', context=ctx) as smtp: + smtp.sendmail('root@localhost', 'alice@localhost', 'Subject: Test SMTPS\n\nTest data.') + smtp.quit() + ''; + in + [ + sendTestMail + sendTestMailStarttls + sendTestMailSmtps + ]; + }; testScript = '' machine.wait_for_unit("postfix.service") diff --git a/nixos/tests/postfixadmin.nix b/nixos/tests/postfixadmin.nix index b2712f4699aea2..9162de429482da 100644 --- a/nixos/tests/postfixadmin.nix +++ b/nixos/tests/postfixadmin.nix @@ -1,31 +1,36 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "postfixadmin"; - meta = with pkgs.lib.maintainers; { - maintainers = [ globin ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "postfixadmin"; + meta = with pkgs.lib.maintainers; { + maintainers = [ globin ]; + }; - nodes = { - postfixadmin = { config, pkgs, ... }: { - services.postfixadmin = { - enable = true; - hostName = "postfixadmin"; - setupPasswordFile = pkgs.writeText "insecure-test-setup-pw-file" "$2y$10$r0p63YCjd9rb9nHrV9UtVuFgGTmPDLKu.0UIJoQTkWCZZze2iuB1m"; - }; - services.nginx.virtualHosts.postfixadmin = { - forceSSL = false; - enableACME = false; - }; + nodes = { + postfixadmin = + { config, pkgs, ... }: + { + services.postfixadmin = { + enable = true; + hostName = "postfixadmin"; + setupPasswordFile = pkgs.writeText "insecure-test-setup-pw-file" "$2y$10$r0p63YCjd9rb9nHrV9UtVuFgGTmPDLKu.0UIJoQTkWCZZze2iuB1m"; + }; + services.nginx.virtualHosts.postfixadmin = { + forceSSL = false; + enableACME = false; + }; + }; }; - }; - testScript = '' - postfixadmin.start - postfixadmin.wait_for_unit("postgresql.service") - postfixadmin.wait_for_unit("phpfpm-postfixadmin.service") - postfixadmin.wait_for_unit("nginx.service") - postfixadmin.succeed( - "curl -sSfL http://postfixadmin/setup.php -X POST -F 'setup_password=not production'" - ) - postfixadmin.succeed("curl -sSfL http://postfixadmin/ | grep 'Mail admins login here'") - ''; -}) + testScript = '' + postfixadmin.start + postfixadmin.wait_for_unit("postgresql.service") + postfixadmin.wait_for_unit("phpfpm-postfixadmin.service") + postfixadmin.wait_for_unit("nginx.service") + postfixadmin.succeed( + "curl -sSfL http://postfixadmin/setup.php -X POST -F 'setup_password=not production'" + ) + postfixadmin.succeed("curl -sSfL http://postfixadmin/ | grep 'Mail admins login here'") + ''; + } +) diff --git a/nixos/tests/power-profiles-daemon.nix b/nixos/tests/power-profiles-daemon.nix index 8a54d8e8bab875..a1f10afda9e60e 100644 --- a/nixos/tests/power-profiles-daemon.nix +++ b/nixos/tests/power-profiles-daemon.nix @@ -1,57 +1,64 @@ -import ./make-test-python.nix ({ pkgs, ... }: - -{ - name = "power-profiles-daemon"; - meta = with pkgs.lib.maintainers; { - maintainers = [ mvnetbiz ]; - }; - nodes.machine = { pkgs, ... }: { - security.polkit.enable = true; - services.power-profiles-daemon.enable = true; - environment.systemPackages = [ pkgs.glib pkgs.power-profiles-daemon ]; - }; - - testScript = '' - def get_profile(): - return machine.succeed( - """gdbus call --system --dest org.freedesktop.UPower.PowerProfiles --object-path /org/freedesktop/UPower/PowerProfiles \ - --method org.freedesktop.DBus.Properties.Get 'org.freedesktop.UPower.PowerProfiles' 'ActiveProfile' - """ - ) - - - def set_profile(profile): - return machine.succeed( - """gdbus call --system --dest org.freedesktop.UPower.PowerProfiles --object-path /org/freedesktop/UPower/PowerProfiles \ - --method org.freedesktop.DBus.Properties.Set 'org.freedesktop.UPower.PowerProfiles' 'ActiveProfile' "<'{profile}'>" - """.format( - profile=profile - ) - ) - - - machine.wait_for_unit("multi-user.target") - - set_profile("power-saver") - profile = get_profile() - if not "power-saver" in profile: - raise Exception("Unable to set power-saver profile") - - - set_profile("balanced") - profile = get_profile() - if not "balanced" in profile: - raise Exception("Unable to set balanced profile") - - # test powerprofilectl CLI - machine.succeed("powerprofilesctl set power-saver") - profile = get_profile() - if not "power-saver" in profile: - raise Exception("Unable to set power-saver profile with powerprofilectl") - - machine.succeed("powerprofilesctl set balanced") - profile = get_profile() - if not "balanced" in profile: - raise Exception("Unable to set balanced profile with powerprofilectl") - ''; -}) +import ./make-test-python.nix ( + { pkgs, ... }: + + { + name = "power-profiles-daemon"; + meta = with pkgs.lib.maintainers; { + maintainers = [ mvnetbiz ]; + }; + nodes.machine = + { pkgs, ... }: + { + security.polkit.enable = true; + services.power-profiles-daemon.enable = true; + environment.systemPackages = [ + pkgs.glib + pkgs.power-profiles-daemon + ]; + }; + + testScript = '' + def get_profile(): + return machine.succeed( + """gdbus call --system --dest org.freedesktop.UPower.PowerProfiles --object-path /org/freedesktop/UPower/PowerProfiles \ + --method org.freedesktop.DBus.Properties.Get 'org.freedesktop.UPower.PowerProfiles' 'ActiveProfile' + """ + ) + + + def set_profile(profile): + return machine.succeed( + """gdbus call --system --dest org.freedesktop.UPower.PowerProfiles --object-path /org/freedesktop/UPower/PowerProfiles \ + --method org.freedesktop.DBus.Properties.Set 'org.freedesktop.UPower.PowerProfiles' 'ActiveProfile' "<'{profile}'>" + """.format( + profile=profile + ) + ) + + + machine.wait_for_unit("multi-user.target") + + set_profile("power-saver") + profile = get_profile() + if not "power-saver" in profile: + raise Exception("Unable to set power-saver profile") + + + set_profile("balanced") + profile = get_profile() + if not "balanced" in profile: + raise Exception("Unable to set balanced profile") + + # test powerprofilectl CLI + machine.succeed("powerprofilesctl set power-saver") + profile = get_profile() + if not "power-saver" in profile: + raise Exception("Unable to set power-saver profile with powerprofilectl") + + machine.succeed("powerprofilesctl set balanced") + profile = get_profile() + if not "balanced" in profile: + raise Exception("Unable to set balanced profile with powerprofilectl") + ''; + } +) diff --git a/nixos/tests/powerdns-admin.nix b/nixos/tests/powerdns-admin.nix index d326d74a982611..1f9354927acdc1 100644 --- a/nixos/tests/powerdns-admin.nix +++ b/nixos/tests/powerdns-admin.nix @@ -1,7 +1,8 @@ # Test powerdns-admin -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -13,33 +14,43 @@ let CAPTCHA_ENABLE = False ''; - makeAppTest = name: configs: makeTest { - name = "powerdns-admin-${name}"; - meta = with pkgs.lib.maintainers; { - maintainers = [ Flakebi zhaofengli ]; - }; - - nodes.server = { pkgs, config, ... }: mkMerge ([ - { - services.powerdns-admin = { - enable = true; - secretKeyFile = "/etc/powerdns-admin/secret"; - saltFile = "/etc/powerdns-admin/salt"; - }; - # It's insecure to have secrets in the world-readable nix store, but this is just a test - environment.etc."powerdns-admin/secret".text = "secret key"; - environment.etc."powerdns-admin/salt".text = "salt"; - environment.systemPackages = [ - (pkgs.writeShellScriptBin "run-test" config.system.build.testScript) + makeAppTest = + name: configs: + makeTest { + name = "powerdns-admin-${name}"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + Flakebi + zhaofengli ]; - } - ] ++ configs); + }; - testScript = '' - server.wait_for_unit("powerdns-admin.service") - server.wait_until_succeeds("run-test", timeout=10) - ''; - }; + nodes.server = + { pkgs, config, ... }: + mkMerge ( + [ + { + services.powerdns-admin = { + enable = true; + secretKeyFile = "/etc/powerdns-admin/secret"; + saltFile = "/etc/powerdns-admin/salt"; + }; + # It's insecure to have secrets in the world-readable nix store, but this is just a test + environment.etc."powerdns-admin/secret".text = "secret key"; + environment.etc."powerdns-admin/salt".text = "salt"; + environment.systemPackages = [ + (pkgs.writeShellScriptBin "run-test" config.system.build.testScript) + ]; + } + ] + ++ configs + ); + + testScript = '' + server.wait_for_unit("powerdns-admin.service") + server.wait_until_succeeds("run-test", timeout=10) + ''; + }; matrix = { backend = { @@ -95,7 +106,10 @@ let }; listen = { tcp = { - services.powerdns-admin.extraArgs = [ "-b" "127.0.0.1:8000" ]; + services.powerdns-admin.extraArgs = [ + "-b" + "127.0.0.1:8000" + ]; system.build.testScript = '' set -euxo pipefail curl -sSf http://127.0.0.1:8000/ @@ -124,7 +138,10 @@ let ''; }; unix = { - services.powerdns-admin.extraArgs = [ "-b" "unix:/run/powerdns-admin/http.sock" ]; + services.powerdns-admin.extraArgs = [ + "-b" + "unix:/run/powerdns-admin/http.sock" + ]; system.build.testScript = '' curl -sSf --unix-socket /run/powerdns-admin/http.sock http://somehost/ ''; @@ -132,8 +149,18 @@ let }; }; in -with matrix; { - postgresql = makeAppTest "postgresql" [ backend.postgresql listen.tcp ]; - mysql = makeAppTest "mysql" [ backend.mysql listen.tcp ]; - unix-listener = makeAppTest "unix-listener" [ backend.postgresql listen.unix ]; +with matrix; +{ + postgresql = makeAppTest "postgresql" [ + backend.postgresql + listen.tcp + ]; + mysql = makeAppTest "mysql" [ + backend.mysql + listen.tcp + ]; + unix-listener = makeAppTest "unix-listener" [ + backend.postgresql + listen.unix + ]; } diff --git a/nixos/tests/powerdns.nix b/nixos/tests/powerdns.nix index 599d5ea67efe64..9ca6e597b6be8c 100644 --- a/nixos/tests/powerdns.nix +++ b/nixos/tests/powerdns.nix @@ -2,61 +2,71 @@ # generic MySQL backend (gmysql) to connect to a # MariaDB server using UNIX sockets authentication. -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "powerdns"; - - nodes.server = { ... }: { - services.powerdns.enable = true; - services.powerdns.extraConfig = '' - launch=gmysql - gmysql-user=pdns - zone-cache-refresh-interval=0 - ''; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "powerdns"; + + nodes.server = + { ... }: + { + services.powerdns.enable = true; + services.powerdns.extraConfig = '' + launch=gmysql + gmysql-user=pdns + zone-cache-refresh-interval=0 + ''; - services.mysql = { - enable = true; - package = pkgs.mariadb; - ensureDatabases = [ "powerdns" ]; - ensureUsers = lib.singleton - { name = "pdns"; - ensurePermissions = { "powerdns.*" = "ALL PRIVILEGES"; }; + services.mysql = { + enable = true; + package = pkgs.mariadb; + ensureDatabases = [ "powerdns" ]; + ensureUsers = lib.singleton { + name = "pdns"; + ensurePermissions = { + "powerdns.*" = "ALL PRIVILEGES"; + }; + }; }; - }; - - environment.systemPackages = with pkgs; - [ dnsutils powerdns mariadb ]; - }; - - testScript = '' - with subtest("PowerDNS database exists"): - server.wait_for_unit("mysql") - server.succeed("echo 'SHOW DATABASES;' | sudo -u pdns mysql -u pdns >&2") - - with subtest("Loading the MySQL schema works"): - server.succeed( - "sudo -u pdns mysql -u pdns -D powerdns <" - "${pkgs.powerdns}/share/doc/pdns/schema.mysql.sql" - ) - - with subtest("PowerDNS server starts"): - server.wait_for_unit("pdns") - server.succeed("dig version.bind txt chaos @127.0.0.1 >&2") - - with subtest("Adding an example zone works"): - # Extract configuration file needed by pdnsutil - pdnsutil = "sudo -u pdns pdnsutil " - server.succeed(f"{pdnsutil} create-zone example.com ns1.example.com") - server.succeed(f"{pdnsutil} add-record example.com ns1 A 192.168.1.2") - - with subtest("Querying the example zone works"): - reply = server.succeed("dig +noall +answer ns1.example.com @127.0.0.1") - assert ( - "192.168.1.2" in reply - ), f"""" - The reply does not contain the expected IP address: - Expected: - ns1.example.com. 3600 IN A 192.168.1.2 - Reply: - {reply}""" - ''; -}) + + environment.systemPackages = with pkgs; [ + dnsutils + powerdns + mariadb + ]; + }; + + testScript = '' + with subtest("PowerDNS database exists"): + server.wait_for_unit("mysql") + server.succeed("echo 'SHOW DATABASES;' | sudo -u pdns mysql -u pdns >&2") + + with subtest("Loading the MySQL schema works"): + server.succeed( + "sudo -u pdns mysql -u pdns -D powerdns <" + "${pkgs.powerdns}/share/doc/pdns/schema.mysql.sql" + ) + + with subtest("PowerDNS server starts"): + server.wait_for_unit("pdns") + server.succeed("dig version.bind txt chaos @127.0.0.1 >&2") + + with subtest("Adding an example zone works"): + # Extract configuration file needed by pdnsutil + pdnsutil = "sudo -u pdns pdnsutil " + server.succeed(f"{pdnsutil} create-zone example.com ns1.example.com") + server.succeed(f"{pdnsutil} add-record example.com ns1 A 192.168.1.2") + + with subtest("Querying the example zone works"): + reply = server.succeed("dig +noall +answer ns1.example.com @127.0.0.1") + assert ( + "192.168.1.2" in reply + ), f"""" + The reply does not contain the expected IP address: + Expected: + ns1.example.com. 3600 IN A 192.168.1.2 + Reply: + {reply}""" + ''; + } +) diff --git a/nixos/tests/pppd.nix b/nixos/tests/pppd.nix index d599f918036f7f..e6e581c5d05f7a 100644 --- a/nixos/tests/pppd.nix +++ b/nixos/tests/pppd.nix @@ -4,56 +4,61 @@ import ./make-test-python.nix ( text = ''"flynn" * "reindeerflotilla" *''; mode = "0640"; }; - in { + in + { name = "pppd"; nodes = { - server = {config, pkgs, ...}: { - config = { - # Run a PPPoE access concentrator server. It will spawn an - # appropriate PPP server process when a PPPoE client sets up a - # PPPoE session. - systemd.services.pppoe-server = { - restartTriggers = [ - config.environment.etc."ppp/pppoe-server-options".source - config.environment.etc."ppp/chap-secrets".source - ]; - after = ["network.target"]; - serviceConfig = { - ExecStart = "${pkgs.rpPPPoE}/sbin/pppoe-server -F -O /etc/ppp/pppoe-server-options -q ${pkgs.ppp}/sbin/pppd -I eth1 -L 192.0.2.1 -R 192.0.2.2"; + server = + { config, pkgs, ... }: + { + config = { + # Run a PPPoE access concentrator server. It will spawn an + # appropriate PPP server process when a PPPoE client sets up a + # PPPoE session. + systemd.services.pppoe-server = { + restartTriggers = [ + config.environment.etc."ppp/pppoe-server-options".source + config.environment.etc."ppp/chap-secrets".source + ]; + after = [ "network.target" ]; + serviceConfig = { + ExecStart = "${pkgs.rpPPPoE}/sbin/pppoe-server -F -O /etc/ppp/pppoe-server-options -q ${pkgs.ppp}/sbin/pppd -I eth1 -L 192.0.2.1 -R 192.0.2.2"; + }; + wantedBy = [ "multi-user.target" ]; + }; + environment.etc = { + "ppp/pppoe-server-options".text = '' + lcp-echo-interval 10 + lcp-echo-failure 2 + plugin pppoe.so + require-chap + nobsdcomp + noccp + novj + ''; + "ppp/chap-secrets" = chap-secrets; }; - wantedBy = ["multi-user.target"]; - }; - environment.etc = { - "ppp/pppoe-server-options".text = '' - lcp-echo-interval 10 - lcp-echo-failure 2 - plugin pppoe.so - require-chap - nobsdcomp - noccp - novj - ''; - "ppp/chap-secrets" = chap-secrets; }; }; - }; - client = {config, pkgs, ...}: { - services.pppd = { - enable = true; - peers.test = { - config = '' - plugin pppoe.so eth1 - name "flynn" - noipdefault - persist - noauth - debug - ''; + client = + { config, pkgs, ... }: + { + services.pppd = { + enable = true; + peers.test = { + config = '' + plugin pppoe.so eth1 + name "flynn" + noipdefault + persist + noauth + debug + ''; + }; }; + environment.etc."ppp/chap-secrets" = chap-secrets; }; - environment.etc."ppp/chap-secrets" = chap-secrets; - }; }; testScript = '' @@ -61,4 +66,5 @@ import ./make-test-python.nix ( client.wait_until_succeeds("ping -c1 -W1 192.0.2.1") server.wait_until_succeeds("ping -c1 -W1 192.0.2.2") ''; - }) + } +) diff --git a/nixos/tests/predictable-interface-names.nix b/nixos/tests/predictable-interface-names.nix index 9ac4f8211e6b19..62cafb1c2c482a 100644 --- a/nixos/tests/predictable-interface-names.nix +++ b/nixos/tests/predictable-interface-names.nix @@ -1,60 +1,87 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: let inherit (import ../lib/testing-python.nix { inherit system pkgs; }) makeTest; testCombinations = pkgs.lib.cartesianProduct { - predictable = [true false]; - withNetworkd = [true false]; - systemdStage1 = [true false]; + predictable = [ + true + false + ]; + withNetworkd = [ + true + false + ]; + systemdStage1 = [ + true + false + ]; }; -in pkgs.lib.listToAttrs (builtins.map ({ predictable, withNetworkd, systemdStage1 }: { - name = pkgs.lib.optionalString (!predictable) "un" + "predictable" - + pkgs.lib.optionalString withNetworkd "Networkd" - + pkgs.lib.optionalString systemdStage1 "SystemdStage1"; - value = makeTest { - name = pkgs.lib.optionalString (!predictable) "un" + "predictableInterfaceNames" - + pkgs.lib.optionalString withNetworkd "-with-networkd" - + pkgs.lib.optionalString systemdStage1 "-systemd-stage-1"; - meta = {}; +in +pkgs.lib.listToAttrs ( + builtins.map ( + { + predictable, + withNetworkd, + systemdStage1, + }: + { + name = + pkgs.lib.optionalString (!predictable) "un" + + "predictable" + + pkgs.lib.optionalString withNetworkd "Networkd" + + pkgs.lib.optionalString systemdStage1 "SystemdStage1"; + value = makeTest { + name = + pkgs.lib.optionalString (!predictable) "un" + + "predictableInterfaceNames" + + pkgs.lib.optionalString withNetworkd "-with-networkd" + + pkgs.lib.optionalString systemdStage1 "-systemd-stage-1"; + meta = { }; - nodes.machine = { lib, ... }: let - script = '' - ip link - if ${lib.optionalString predictable "!"} ip link show eth0; then - echo Success - else - exit 1 - fi - ''; - in { - networking.usePredictableInterfaceNames = lib.mkForce predictable; - networking.useNetworkd = withNetworkd; - networking.dhcpcd.enable = !withNetworkd; - networking.useDHCP = !withNetworkd; + nodes.machine = + { lib, ... }: + let + script = '' + ip link + if ${lib.optionalString predictable "!"} ip link show eth0; then + echo Success + else + exit 1 + fi + ''; + in + { + networking.usePredictableInterfaceNames = lib.mkForce predictable; + networking.useNetworkd = withNetworkd; + networking.dhcpcd.enable = !withNetworkd; + networking.useDHCP = !withNetworkd; - # Check if predictable interface names are working in stage-1 - boot.initrd.postDeviceCommands = lib.mkIf (!systemdStage1) script; + # Check if predictable interface names are working in stage-1 + boot.initrd.postDeviceCommands = lib.mkIf (!systemdStage1) script; - boot.initrd.systemd = lib.mkIf systemdStage1 { - enable = true; - initrdBin = [ pkgs.iproute2 ]; - services.systemd-udev-settle.wantedBy = ["initrd.target"]; - services.check-interfaces = { - requiredBy = ["initrd.target"]; - after = ["systemd-udev-settle.service"]; - serviceConfig.Type = "oneshot"; - path = [ pkgs.iproute2 ]; - inherit script; - }; - }; - }; + boot.initrd.systemd = lib.mkIf systemdStage1 { + enable = true; + initrdBin = [ pkgs.iproute2 ]; + services.systemd-udev-settle.wantedBy = [ "initrd.target" ]; + services.check-interfaces = { + requiredBy = [ "initrd.target" ]; + after = [ "systemd-udev-settle.service" ]; + serviceConfig.Type = "oneshot"; + path = [ pkgs.iproute2 ]; + inherit script; + }; + }; + }; - testScript = '' - print(machine.succeed("ip link")) - machine.${if predictable then "fail" else "succeed"}("ip link show eth0") - ''; - }; -}) testCombinations) + testScript = '' + print(machine.succeed("ip link")) + machine.${if predictable then "fail" else "succeed"}("ip link show eth0") + ''; + }; + } + ) testCombinations +) diff --git a/nixos/tests/printing.nix b/nixos/tests/printing.nix index 5f719a5d97c100..5fee5c6a498905 100644 --- a/nixos/tests/printing.nix +++ b/nixos/tests/printing.nix @@ -1,128 +1,141 @@ # Test printing via CUPS. import ./make-test-python.nix ( -{ pkgs -, socket ? true # whether to use socket activation -, listenTcp ? true # whether to open port 631 on client -, ... -}: - -let - inherit (pkgs) lib; -in - -{ - name = "printing"; - meta = with lib.maintainers; { - maintainers = [ domenkozar matthewbauer ]; - }; - - nodes.server = { ... }: { - services.printing = { - enable = true; - stateless = true; - startWhenNeeded = socket; - listenAddresses = [ "*:631" ]; - defaultShared = true; - openFirewall = true; - extraConf = '' - - Order allow,deny - Allow from all - - ''; + { + pkgs, + socket ? true, # whether to use socket activation + listenTcp ? true, # whether to open port 631 on client + ... + }: + + let + inherit (pkgs) lib; + in + + { + name = "printing"; + meta = with lib.maintainers; { + maintainers = [ + domenkozar + matthewbauer + ]; }; - # Add a HP Deskjet printer connected via USB to the server. - hardware.printers.ensurePrinters = [{ - name = "DeskjetLocal"; - deviceUri = "usb://foobar/printers/foobar"; - model = "drv:///sample.drv/deskjet.ppd"; - }]; - }; - - nodes.client = { lib, ... }: { - services.printing.enable = true; - services.printing.startWhenNeeded = socket; - services.printing.listenAddresses = lib.mkIf (!listenTcp) []; - # Add printer to the client as well, via IPP. - hardware.printers.ensurePrinters = [{ - name = "DeskjetRemote"; - deviceUri = "ipp://server/printers/DeskjetLocal"; - model = "drv:///sample.drv/deskjet.ppd"; - }]; - hardware.printers.ensureDefaultPrinter = "DeskjetRemote"; - }; - - testScript = '' - import os - import re - - start_all() - - with subtest("Make sure that cups is up on both sides and printers are set up"): - server.wait_for_unit("ensure-printers.service") - client.wait_for_unit("ensure-printers.service") - - assert "scheduler is running" in client.succeed("lpstat -r") - - with subtest("UNIX socket is used for connections"): - assert "/var/run/cups/cups.sock" in client.succeed("lpstat -H") - - with subtest("HTTP server is available too"): - ${lib.optionalString listenTcp ''client.succeed("curl --fail http://localhost:631/")''} - client.succeed(f"curl --fail http://{server.name}:631/") - server.fail(f"curl --fail --connect-timeout 2 http://{client.name}:631/") - - with subtest("LP status checks"): - assert "DeskjetRemote accepting requests" in client.succeed("lpstat -a") - assert "DeskjetLocal accepting requests" in client.succeed( - f"lpstat -h {server.name}:631 -a" - ) - client.succeed("cupsdisable DeskjetRemote") - out = client.succeed("lpq") - print(out) - assert re.search( - "DeskjetRemote is not ready.*no entries", - client.succeed("lpq"), - flags=re.DOTALL, - ) - client.succeed("cupsenable DeskjetRemote") - assert re.match( - "DeskjetRemote is ready.*no entries", client.succeed("lpq"), flags=re.DOTALL - ) - - # Test printing various file types. - for file in [ - "${pkgs.groff.doc}/share/doc/*/examples/mom/penguin.pdf", - "${pkgs.groff.doc}/share/doc/*/meref.ps", - "${pkgs.cups.out}/share/doc/cups/images/cups.png", - "${pkgs.pcre.doc}/share/doc/pcre/pcre.txt", - ]: - file_name = os.path.basename(file) - with subtest(f"print {file_name}"): - # Print the file on the client. - print(client.succeed("lpq")) - client.succeed(f"lp {file}") - client.wait_until_succeeds( - f"lpq; lpq | grep -q -E 'active.*root.*{file_name}'" - ) - - # Ensure that a raw PCL file appeared in the server's queue - # (showing that the right filters have been applied). Of - # course, since there is no actual USB printer attached, the - # file will stay in the queue forever. - server.wait_for_file("/var/spool/cups/d*-001") - server.wait_until_succeeds(f"lpq -a | grep -q -E '{file_name}'") - - # Delete the job on the client. It should disappear on the - # server as well. - client.succeed("lprm") - client.wait_until_succeeds("lpq -a | grep -q -E 'no entries'") - - retry(lambda _: "no entries" in server.succeed("lpq -a")) - - # The queue is empty already, so this should be safe. - # Otherwise, pairs of "c*"-"d*-001" files might persist. - server.execute("rm /var/spool/cups/*") - ''; -}) + + nodes.server = + { ... }: + { + services.printing = { + enable = true; + stateless = true; + startWhenNeeded = socket; + listenAddresses = [ "*:631" ]; + defaultShared = true; + openFirewall = true; + extraConf = '' + + Order allow,deny + Allow from all + + ''; + }; + # Add a HP Deskjet printer connected via USB to the server. + hardware.printers.ensurePrinters = [ + { + name = "DeskjetLocal"; + deviceUri = "usb://foobar/printers/foobar"; + model = "drv:///sample.drv/deskjet.ppd"; + } + ]; + }; + + nodes.client = + { lib, ... }: + { + services.printing.enable = true; + services.printing.startWhenNeeded = socket; + services.printing.listenAddresses = lib.mkIf (!listenTcp) [ ]; + # Add printer to the client as well, via IPP. + hardware.printers.ensurePrinters = [ + { + name = "DeskjetRemote"; + deviceUri = "ipp://server/printers/DeskjetLocal"; + model = "drv:///sample.drv/deskjet.ppd"; + } + ]; + hardware.printers.ensureDefaultPrinter = "DeskjetRemote"; + }; + + testScript = '' + import os + import re + + start_all() + + with subtest("Make sure that cups is up on both sides and printers are set up"): + server.wait_for_unit("ensure-printers.service") + client.wait_for_unit("ensure-printers.service") + + assert "scheduler is running" in client.succeed("lpstat -r") + + with subtest("UNIX socket is used for connections"): + assert "/var/run/cups/cups.sock" in client.succeed("lpstat -H") + + with subtest("HTTP server is available too"): + ${lib.optionalString listenTcp ''client.succeed("curl --fail http://localhost:631/")''} + client.succeed(f"curl --fail http://{server.name}:631/") + server.fail(f"curl --fail --connect-timeout 2 http://{client.name}:631/") + + with subtest("LP status checks"): + assert "DeskjetRemote accepting requests" in client.succeed("lpstat -a") + assert "DeskjetLocal accepting requests" in client.succeed( + f"lpstat -h {server.name}:631 -a" + ) + client.succeed("cupsdisable DeskjetRemote") + out = client.succeed("lpq") + print(out) + assert re.search( + "DeskjetRemote is not ready.*no entries", + client.succeed("lpq"), + flags=re.DOTALL, + ) + client.succeed("cupsenable DeskjetRemote") + assert re.match( + "DeskjetRemote is ready.*no entries", client.succeed("lpq"), flags=re.DOTALL + ) + + # Test printing various file types. + for file in [ + "${pkgs.groff.doc}/share/doc/*/examples/mom/penguin.pdf", + "${pkgs.groff.doc}/share/doc/*/meref.ps", + "${pkgs.cups.out}/share/doc/cups/images/cups.png", + "${pkgs.pcre.doc}/share/doc/pcre/pcre.txt", + ]: + file_name = os.path.basename(file) + with subtest(f"print {file_name}"): + # Print the file on the client. + print(client.succeed("lpq")) + client.succeed(f"lp {file}") + client.wait_until_succeeds( + f"lpq; lpq | grep -q -E 'active.*root.*{file_name}'" + ) + + # Ensure that a raw PCL file appeared in the server's queue + # (showing that the right filters have been applied). Of + # course, since there is no actual USB printer attached, the + # file will stay in the queue forever. + server.wait_for_file("/var/spool/cups/d*-001") + server.wait_until_succeeds(f"lpq -a | grep -q -E '{file_name}'") + + # Delete the job on the client. It should disappear on the + # server as well. + client.succeed("lprm") + client.wait_until_succeeds("lpq -a | grep -q -E 'no entries'") + + retry(lambda _: "no entries" in server.succeed("lpq -a")) + + # The queue is empty already, so this should be safe. + # Otherwise, pairs of "c*"-"d*-001" files might persist. + server.execute("rm /var/spool/cups/*") + ''; + } +) diff --git a/nixos/tests/private-gpt.nix b/nixos/tests/private-gpt.nix index 1c90101d29575a..f6bfda38aabf1b 100644 --- a/nixos/tests/private-gpt.nix +++ b/nixos/tests/private-gpt.nix @@ -1,27 +1,31 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - mainPort = "8001"; -in -{ - name = "private-gpt"; - meta = with lib.maintainers; { - maintainers = [ ]; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + mainPort = "8001"; + in + { + name = "private-gpt"; + meta = with lib.maintainers; { + maintainers = [ ]; + }; - nodes = { - machine = { ... }: { - services.private-gpt = { - enable = true; - }; + nodes = { + machine = + { ... }: + { + services.private-gpt = { + enable = true; + }; + }; }; - }; - testScript = '' - machine.start() + testScript = '' + machine.start() - machine.wait_for_unit("private-gpt.service") - machine.wait_for_open_port(${mainPort}) + machine.wait_for_unit("private-gpt.service") + machine.wait_for_open_port(${mainPort}) - machine.succeed("curl http://127.0.0.1:${mainPort}") - ''; -}) + machine.succeed("curl http://127.0.0.1:${mainPort}") + ''; + } +) diff --git a/nixos/tests/privoxy.nix b/nixos/tests/privoxy.nix index 2a18d332c8778d..0c0cb6ab2e3175 100644 --- a/nixos/tests/privoxy.nix +++ b/nixos/tests/privoxy.nix @@ -1,11 +1,10 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: - -let - # Note: For some reason Privoxy can't issue valid - # certificates if the CA is generated using gnutls :( - certs = pkgs.runCommand "example-certs" - { buildInputs = [ pkgs.openssl ]; } - '' +import ./make-test-python.nix ( + { lib, pkgs, ... }: + + let + # Note: For some reason Privoxy can't issue valid + # certificates if the CA is generated using gnutls :( + certs = pkgs.runCommand "example-certs" { buildInputs = [ pkgs.openssl ]; } '' mkdir $out # generate CA keypair @@ -25,65 +24,94 @@ let -CAkey $out/ca.key -CAcreateserial -out $out/server.crt \ -days 500 -sha256 ''; -in - -{ - name = "privoxy"; - meta = with lib.maintainers; { - maintainers = [ rnhmjoj ]; - }; - - nodes.machine = { ... }: { - services.nginx.enable = true; - services.nginx.virtualHosts."example.com" = { - addSSL = true; - sslCertificate = "${certs}/server.crt"; - sslCertificateKey = "${certs}/server.key"; - locations."/".root = pkgs.writeTextFile - { name = "bad-day"; - destination = "/how-are-you/index.html"; - text = "I've had a bad day!\n"; - }; - locations."/ads".extraConfig = '' - return 200 "Hot Nixpkgs PRs in your area. Click here!\n"; - ''; - }; + in - services.privoxy = { - enable = true; - inspectHttps = true; - settings = { - ca-cert-file = "${certs}/ca.crt"; - ca-key-file = "${certs}/ca.key"; - debug = 65536; - }; - userActions = '' - {+filter{positive}} - example.com - - {+block{Fake ads}} - example.com/ads - ''; - userFilters = '' - FILTER: positive This is a filter example. - s/bad/great/ig - ''; + { + name = "privoxy"; + meta = with lib.maintainers; { + maintainers = [ rnhmjoj ]; }; - security.pki.certificateFiles = [ "${certs}/ca.crt" ]; + nodes.machine = + { ... }: + { + services.nginx.enable = true; + services.nginx.virtualHosts."example.com" = { + addSSL = true; + sslCertificate = "${certs}/server.crt"; + sslCertificateKey = "${certs}/server.key"; + locations."/".root = pkgs.writeTextFile { + name = "bad-day"; + destination = "/how-are-you/index.html"; + text = "I've had a bad day!\n"; + }; + locations."/ads".extraConfig = '' + return 200 "Hot Nixpkgs PRs in your area. Click here!\n"; + ''; + }; - networking.hosts."::1" = [ "example.com" ]; - networking.proxy.httpProxy = "http://localhost:8118"; - networking.proxy.httpsProxy = "http://localhost:8118"; - }; + services.privoxy = { + enable = true; + inspectHttps = true; + settings = { + ca-cert-file = "${certs}/ca.crt"; + ca-key-file = "${certs}/ca.key"; + debug = 65536; + }; + userActions = '' + {+filter{positive}} + example.com + + {+block{Fake ads}} + example.com/ads + ''; + userFilters = '' + FILTER: positive This is a filter example. + s/bad/great/ig + ''; + }; + + security.pki.certificateFiles = [ "${certs}/ca.crt" ]; + + networking.hosts."::1" = [ "example.com" ]; + networking.proxy.httpProxy = "http://localhost:8118"; + networking.proxy.httpsProxy = "http://localhost:8118"; + }; - nodes.machine_socks4 = { ... }: { services.privoxy = { enable = true; settings.forward-socks4 = "/ 127.0.0.1:9050 ."; }; }; - nodes.machine_socks4a = { ... }: { services.privoxy = { enable = true; settings.forward-socks4a = "/ 127.0.0.1:9050 ."; }; }; - nodes.machine_socks5 = { ... }: { services.privoxy = { enable = true; settings.forward-socks5 = "/ 127.0.0.1:9050 ."; }; }; - nodes.machine_socks5t = { ... }: { services.privoxy = { enable = true; settings.forward-socks5t = "/ 127.0.0.1:9050 ."; }; }; + nodes.machine_socks4 = + { ... }: + { + services.privoxy = { + enable = true; + settings.forward-socks4 = "/ 127.0.0.1:9050 ."; + }; + }; + nodes.machine_socks4a = + { ... }: + { + services.privoxy = { + enable = true; + settings.forward-socks4a = "/ 127.0.0.1:9050 ."; + }; + }; + nodes.machine_socks5 = + { ... }: + { + services.privoxy = { + enable = true; + settings.forward-socks5 = "/ 127.0.0.1:9050 ."; + }; + }; + nodes.machine_socks5t = + { ... }: + { + services.privoxy = { + enable = true; + settings.forward-socks5t = "/ 127.0.0.1:9050 ."; + }; + }; - testScript = - '' + testScript = '' with subtest("Privoxy is running"): machine.wait_for_unit("privoxy") machine.wait_for_open_port(8118) @@ -123,4 +151,5 @@ in # In issue #265654, instead privoxy segfaulted causing curl to exit with "Empty reply from server". m.succeed("http_proxy=http://localhost:8118 curl -v http://does-not-exist/ 2>&1 | grep 'HTTP/1.1 503'") ''; -}) + } +) diff --git a/nixos/tests/prometheus/alertmanager.nix b/nixos/tests/prometheus/alertmanager.nix index 6301db6df62e3c..51151cbab53422 100644 --- a/nixos/tests/prometheus/alertmanager.nix +++ b/nixos/tests/prometheus/alertmanager.nix @@ -1,152 +1,160 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: +import ../make-test-python.nix ( + { lib, pkgs, ... }: -{ - name = "prometheus-alertmanager"; + { + name = "prometheus-alertmanager"; - nodes = { - prometheus = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; + nodes = { + prometheus = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; + networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; - services.prometheus = { - enable = true; - globalConfig.scrape_interval = "2s"; + services.prometheus = { + enable = true; + globalConfig.scrape_interval = "2s"; - alertmanagers = [ - { - scheme = "http"; - static_configs = [ + alertmanagers = [ { - targets = [ - "alertmanager:${toString config.services.prometheus.alertmanager.port}" + scheme = "http"; + static_configs = [ + { + targets = [ + "alertmanager:${toString config.services.prometheus.alertmanager.port}" + ]; + } ]; } ]; - } - ]; - - rules = [ - '' - groups: - - name: test - rules: - - alert: InstanceDown - expr: up == 0 - for: 5s - labels: - severity: page - annotations: - summary: "Instance {{ $labels.instance }} down" - '' - ]; - - scrapeConfigs = [ - { - job_name = "alertmanager"; - static_configs = [ + + rules = [ + '' + groups: + - name: test + rules: + - alert: InstanceDown + expr: up == 0 + for: 5s + labels: + severity: page + annotations: + summary: "Instance {{ $labels.instance }} down" + '' + ]; + + scrapeConfigs = [ { - targets = [ - "alertmanager:${toString config.services.prometheus.alertmanager.port}" + job_name = "alertmanager"; + static_configs = [ + { + targets = [ + "alertmanager:${toString config.services.prometheus.alertmanager.port}" + ]; + } ]; } - ]; - } - { - job_name = "node"; - static_configs = [ { - targets = [ - "node:${toString config.services.prometheus.exporters.node.port}" + job_name = "node"; + static_configs = [ + { + targets = [ + "node:${toString config.services.prometheus.exporters.node.port}" + ]; + } ]; } ]; - } - ]; - }; - }; - - alertmanager = { config, pkgs, ... }: { - services.prometheus.alertmanager = { - enable = true; - openFirewall = true; - - configuration = { - global = { - resolve_timeout = "1m"; - }; - - route = { - # Root route node - receiver = "test"; - group_by = ["..."]; - continue = false; - group_wait = "1s"; - group_interval = "15s"; - repeat_interval = "24h"; }; + }; - receivers = [ - { - name = "test"; - webhook_configs = [ + alertmanager = + { config, pkgs, ... }: + { + services.prometheus.alertmanager = { + enable = true; + openFirewall = true; + + configuration = { + global = { + resolve_timeout = "1m"; + }; + + route = { + # Root route node + receiver = "test"; + group_by = [ "..." ]; + continue = false; + group_wait = "1s"; + group_interval = "15s"; + repeat_interval = "24h"; + }; + + receivers = [ { - url = "http://logger:6725"; - send_resolved = true; - max_alerts = 0; + name = "test"; + webhook_configs = [ + { + url = "http://logger:6725"; + send_resolved = true; + max_alerts = 0; + } + ]; } ]; - } - ]; + }; + }; }; - }; - }; - logger = { config, pkgs, ... }: { - networking.firewall.allowedTCPPorts = [ 6725 ]; + logger = + { config, pkgs, ... }: + { + networking.firewall.allowedTCPPorts = [ 6725 ]; - services.prometheus.alertmanagerWebhookLogger.enable = true; + services.prometheus.alertmanagerWebhookLogger.enable = true; + }; }; - }; - testScript = '' - alertmanager.wait_for_unit("alertmanager") - alertmanager.wait_for_open_port(9093) - alertmanager.wait_until_succeeds("curl -s http://127.0.0.1:9093/-/ready") - #alertmanager.wait_until_succeeds("journalctl -o cat -u alertmanager.service | grep 'version=${pkgs.prometheus-alertmanager.version}'") + testScript = '' + alertmanager.wait_for_unit("alertmanager") + alertmanager.wait_for_open_port(9093) + alertmanager.wait_until_succeeds("curl -s http://127.0.0.1:9093/-/ready") + #alertmanager.wait_until_succeeds("journalctl -o cat -u alertmanager.service | grep 'version=${pkgs.prometheus-alertmanager.version}'") - logger.wait_for_unit("alertmanager-webhook-logger") - logger.wait_for_open_port(6725) + logger.wait_for_unit("alertmanager-webhook-logger") + logger.wait_for_open_port(6725) - prometheus.wait_for_unit("prometheus") - prometheus.wait_for_open_port(9090) + prometheus.wait_for_unit("prometheus") + prometheus.wait_for_open_port(9090) - prometheus.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(up\{job=\"alertmanager\"\}==1)' | " - + "jq '.data.result[0].value[1]' | grep '\"1\"'" - ) + prometheus.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(up\{job=\"alertmanager\"\}==1)' | " + + "jq '.data.result[0].value[1]' | grep '\"1\"'" + ) - prometheus.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=sum(alertmanager_build_info)%20by%20(version)' | " - + "jq '.data.result[0].metric.version' | grep '\"${pkgs.prometheus-alertmanager.version}\"'" - ) + prometheus.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=sum(alertmanager_build_info)%20by%20(version)' | " + + "jq '.data.result[0].metric.version' | grep '\"${pkgs.prometheus-alertmanager.version}\"'" + ) - prometheus.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(up\{job=\"node\"\}!=1)' | " - + "jq '.data.result[0].value[1]' | grep '\"1\"'" - ) + prometheus.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(up\{job=\"node\"\}!=1)' | " + + "jq '.data.result[0].value[1]' | grep '\"1\"'" + ) - prometheus.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=alertmanager_notifications_total\{integration=\"webhook\"\}' | " - + "jq '.data.result[0].value[1]' | grep -v '\"0\"'" - ) + prometheus.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=alertmanager_notifications_total\{integration=\"webhook\"\}' | " + + "jq '.data.result[0].value[1]' | grep -v '\"0\"'" + ) - logger.wait_until_succeeds( - "journalctl -o cat -u alertmanager-webhook-logger.service | grep '\"alertname\":\"InstanceDown\"'" - ) + logger.wait_until_succeeds( + "journalctl -o cat -u alertmanager-webhook-logger.service | grep '\"alertname\":\"InstanceDown\"'" + ) - logger.log(logger.succeed("systemd-analyze security alertmanager-webhook-logger.service | grep -v '✓'")) + logger.log(logger.succeed("systemd-analyze security alertmanager-webhook-logger.service | grep -v '✓'")) - alertmanager.log(alertmanager.succeed("systemd-analyze security alertmanager.service | grep -v '✓'")) - ''; -}) + alertmanager.log(alertmanager.succeed("systemd-analyze security alertmanager.service | grep -v '✓'")) + ''; + } +) diff --git a/nixos/tests/prometheus/config-reload.nix b/nixos/tests/prometheus/config-reload.nix index 786668c624ea92..60f5bc6a1d237d 100644 --- a/nixos/tests/prometheus/config-reload.nix +++ b/nixos/tests/prometheus/config-reload.nix @@ -1,116 +1,120 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: +import ../make-test-python.nix ( + { lib, pkgs, ... }: -{ - name = "prometheus-config-reload"; + { + name = "prometheus-config-reload"; - nodes = { - prometheus = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; + nodes = { + prometheus = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; + networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; - services.prometheus = { - enable = true; - enableReload = true; - globalConfig.scrape_interval = "2s"; - scrapeConfigs = [ - { - job_name = "prometheus"; - static_configs = [ + services.prometheus = { + enable = true; + enableReload = true; + globalConfig.scrape_interval = "2s"; + scrapeConfigs = [ { - targets = [ - "prometheus:${toString config.services.prometheus.port}" + job_name = "prometheus"; + static_configs = [ + { + targets = [ + "prometheus:${toString config.services.prometheus.port}" + ]; + } ]; } ]; - } - ]; - }; + }; - specialisation = { - "prometheus-config-change" = { - configuration = { - environment.systemPackages = [ pkgs.yq ]; + specialisation = { + "prometheus-config-change" = { + configuration = { + environment.systemPackages = [ pkgs.yq ]; - # This configuration just adds a new prometheus job - # to scrape the node_exporter metrics of the s3 machine. - services.prometheus = { - scrapeConfigs = [ - { - job_name = "node"; - static_configs = [ + # This configuration just adds a new prometheus job + # to scrape the node_exporter metrics of the s3 machine. + services.prometheus = { + scrapeConfigs = [ { - targets = [ "node:${toString config.services.prometheus.exporters.node.port}" ]; + job_name = "node"; + static_configs = [ + { + targets = [ "node:${toString config.services.prometheus.exporters.node.port}" ]; + } + ]; } ]; - } - ]; + }; + }; }; }; }; - }; }; - }; - testScript = '' - prometheus.wait_for_unit("prometheus") - prometheus.wait_for_open_port(9090) + testScript = '' + prometheus.wait_for_unit("prometheus") + prometheus.wait_for_open_port(9090) - # Check if switching to a NixOS configuration that changes the prometheus - # configuration reloads (instead of restarts) prometheus before the switch - # finishes successfully: - with subtest("config change reloads prometheus"): - import json - # We check if prometheus has finished reloading by looking for the message - # "Completed loading of configuration file" in the journal between the start - # and finish of switching to the new NixOS configuration. - # - # To mark the start we record the journal cursor before starting the switch: - cursor_before_switching = json.loads( - prometheus.succeed("journalctl -n1 -o json --output-fields=__CURSOR") - )["__CURSOR"] + # Check if switching to a NixOS configuration that changes the prometheus + # configuration reloads (instead of restarts) prometheus before the switch + # finishes successfully: + with subtest("config change reloads prometheus"): + import json + # We check if prometheus has finished reloading by looking for the message + # "Completed loading of configuration file" in the journal between the start + # and finish of switching to the new NixOS configuration. + # + # To mark the start we record the journal cursor before starting the switch: + cursor_before_switching = json.loads( + prometheus.succeed("journalctl -n1 -o json --output-fields=__CURSOR") + )["__CURSOR"] - # Now we switch: - prometheus_config_change = prometheus.succeed( - "readlink /run/current-system/specialisation/prometheus-config-change" - ).strip() - prometheus.succeed(prometheus_config_change + "/bin/switch-to-configuration test") + # Now we switch: + prometheus_config_change = prometheus.succeed( + "readlink /run/current-system/specialisation/prometheus-config-change" + ).strip() + prometheus.succeed(prometheus_config_change + "/bin/switch-to-configuration test") - # Next we retrieve all logs since the start of switching: - logs_after_starting_switching = prometheus.succeed( - """ - journalctl --after-cursor='{cursor_before_switching}' -o json --output-fields=MESSAGE - """.format( - cursor_before_switching=cursor_before_switching - ) - ) + # Next we retrieve all logs since the start of switching: + logs_after_starting_switching = prometheus.succeed( + """ + journalctl --after-cursor='{cursor_before_switching}' -o json --output-fields=MESSAGE + """.format( + cursor_before_switching=cursor_before_switching + ) + ) - # Finally we check if the message "Completed loading of configuration file" - # occurs before the "finished switching to system configuration" message: - finished_switching_msg = ( - "finished switching to system configuration " + prometheus_config_change - ) - reloaded_before_switching_finished = False - finished_switching = False - for log_line in logs_after_starting_switching.split("\n"): - msg = json.loads(log_line)["MESSAGE"] - if "Completed loading of configuration file" in msg: - reloaded_before_switching_finished = True - if msg == finished_switching_msg: - finished_switching = True - break + # Finally we check if the message "Completed loading of configuration file" + # occurs before the "finished switching to system configuration" message: + finished_switching_msg = ( + "finished switching to system configuration " + prometheus_config_change + ) + reloaded_before_switching_finished = False + finished_switching = False + for log_line in logs_after_starting_switching.split("\n"): + msg = json.loads(log_line)["MESSAGE"] + if "Completed loading of configuration file" in msg: + reloaded_before_switching_finished = True + if msg == finished_switching_msg: + finished_switching = True + break - assert reloaded_before_switching_finished - assert finished_switching + assert reloaded_before_switching_finished + assert finished_switching - # Check if the reloaded config includes the new node job: - prometheus.succeed( - """ - curl -sf http://127.0.0.1:9090/api/v1/status/config \ - | jq -r .data.yaml \ - | yq '.scrape_configs | any(.job_name == "node")' \ - | grep true - """ - ) - ''; -}) + # Check if the reloaded config includes the new node job: + prometheus.succeed( + """ + curl -sf http://127.0.0.1:9090/api/v1/status/config \ + | jq -r .data.yaml \ + | yq '.scrape_configs | any(.job_name == "node")' \ + | grep true + """ + ) + ''; + } +) diff --git a/nixos/tests/prometheus/default.nix b/nixos/tests/prometheus/default.nix index 133922a453c05b..ea6c61c85b8042 100644 --- a/nixos/tests/prometheus/default.nix +++ b/nixos/tests/prometheus/default.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../../.. { inherit system config; }, }: { diff --git a/nixos/tests/prometheus/federation.nix b/nixos/tests/prometheus/federation.nix index 0f05166c8f5dab..15f84b2d88afb0 100644 --- a/nixos/tests/prometheus/federation.nix +++ b/nixos/tests/prometheus/federation.nix @@ -1,213 +1,227 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: +import ../make-test-python.nix ( + { lib, pkgs, ... }: -{ - name = "prometheus-federation"; + { + name = "prometheus-federation"; - nodes = { - global1 = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; + nodes = { + global1 = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; + networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; - services.prometheus = { - enable = true; - globalConfig.scrape_interval = "2s"; + services.prometheus = { + enable = true; + globalConfig.scrape_interval = "2s"; - scrapeConfigs = [ - { - job_name = "federate"; - honor_labels = true; - metrics_path = "/federate"; - - params = { - "match[]" = [ - "{job=\"node\"}" - "{job=\"prometheus\"}" - ]; - }; - - static_configs = [ + scrapeConfigs = [ { - targets = [ - "prometheus1:${toString config.services.prometheus.port}" - "prometheus2:${toString config.services.prometheus.port}" + job_name = "federate"; + honor_labels = true; + metrics_path = "/federate"; + + params = { + "match[]" = [ + "{job=\"node\"}" + "{job=\"prometheus\"}" + ]; + }; + + static_configs = [ + { + targets = [ + "prometheus1:${toString config.services.prometheus.port}" + "prometheus2:${toString config.services.prometheus.port}" + ]; + } ]; } - ]; - } - { - job_name = "prometheus"; - static_configs = [ { - targets = [ - "global1:${toString config.services.prometheus.port}" - "global2:${toString config.services.prometheus.port}" + job_name = "prometheus"; + static_configs = [ + { + targets = [ + "global1:${toString config.services.prometheus.port}" + "global2:${toString config.services.prometheus.port}" + ]; + } ]; } ]; - } - ]; - }; - }; + }; + }; - global2 = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; + global2 = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; + networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; - services.prometheus = { - enable = true; - globalConfig.scrape_interval = "2s"; + services.prometheus = { + enable = true; + globalConfig.scrape_interval = "2s"; - scrapeConfigs = [ - { - job_name = "federate"; - honor_labels = true; - metrics_path = "/federate"; - - params = { - "match[]" = [ - "{job=\"node\"}" - "{job=\"prometheus\"}" - ]; - }; - - static_configs = [ + scrapeConfigs = [ { - targets = [ - "prometheus1:${toString config.services.prometheus.port}" - "prometheus2:${toString config.services.prometheus.port}" + job_name = "federate"; + honor_labels = true; + metrics_path = "/federate"; + + params = { + "match[]" = [ + "{job=\"node\"}" + "{job=\"prometheus\"}" + ]; + }; + + static_configs = [ + { + targets = [ + "prometheus1:${toString config.services.prometheus.port}" + "prometheus2:${toString config.services.prometheus.port}" + ]; + } ]; } - ]; - } - { - job_name = "prometheus"; - static_configs = [ { - targets = [ - "global1:${toString config.services.prometheus.port}" - "global2:${toString config.services.prometheus.port}" + job_name = "prometheus"; + static_configs = [ + { + targets = [ + "global1:${toString config.services.prometheus.port}" + "global2:${toString config.services.prometheus.port}" + ]; + } ]; } ]; - } - ]; - }; - }; + }; + }; - prometheus1 = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; + prometheus1 = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; + networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; - services.prometheus = { - enable = true; - globalConfig.scrape_interval = "2s"; + services.prometheus = { + enable = true; + globalConfig.scrape_interval = "2s"; - scrapeConfigs = [ - { - job_name = "node"; - static_configs = [ + scrapeConfigs = [ { - targets = [ - "node1:${toString config.services.prometheus.exporters.node.port}" + job_name = "node"; + static_configs = [ + { + targets = [ + "node1:${toString config.services.prometheus.exporters.node.port}" + ]; + } ]; } - ]; - } - { - job_name = "prometheus"; - static_configs = [ { - targets = [ - "prometheus1:${toString config.services.prometheus.port}" + job_name = "prometheus"; + static_configs = [ + { + targets = [ + "prometheus1:${toString config.services.prometheus.port}" + ]; + } ]; } ]; - } - ]; - }; - }; + }; + }; - prometheus2 = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; + prometheus2 = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; + networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; - services.prometheus = { - enable = true; - globalConfig.scrape_interval = "2s"; + services.prometheus = { + enable = true; + globalConfig.scrape_interval = "2s"; - scrapeConfigs = [ - { - job_name = "node"; - static_configs = [ + scrapeConfigs = [ { - targets = [ - "node2:${toString config.services.prometheus.exporters.node.port}" + job_name = "node"; + static_configs = [ + { + targets = [ + "node2:${toString config.services.prometheus.exporters.node.port}" + ]; + } ]; } - ]; - } - { - job_name = "prometheus"; - static_configs = [ { - targets = [ - "prometheus2:${toString config.services.prometheus.port}" + job_name = "prometheus"; + static_configs = [ + { + targets = [ + "prometheus2:${toString config.services.prometheus.port}" + ]; + } ]; } ]; - } - ]; - }; + }; + }; + + node1 = + { config, pkgs, ... }: + { + services.prometheus.exporters.node = { + enable = true; + openFirewall = true; + }; + }; + + node2 = + { config, pkgs, ... }: + { + services.prometheus.exporters.node = { + enable = true; + openFirewall = true; + }; + }; }; - node1 = { config, pkgs, ... }: { - services.prometheus.exporters.node = { - enable = true; - openFirewall = true; - }; - }; - - node2 = { config, pkgs, ... }: { - services.prometheus.exporters.node = { - enable = true; - openFirewall = true; - }; - }; - }; - - testScript = '' - for machine in node1, node2: - machine.wait_for_unit("prometheus-node-exporter") - machine.wait_for_open_port(9100) - - for machine in prometheus1, prometheus2, global1, global2: - machine.wait_for_unit("prometheus") - machine.wait_for_open_port(9090) - - # Verify both servers got the same data from the exporter - for machine in prometheus1, prometheus2: - machine.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(up\{job=\"node\"\})' | " - + "jq '.data.result[0].value[1]' | grep '\"1\"'" - ) - machine.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(prometheus_build_info)' | " - + "jq '.data.result[0].value[1]' | grep '\"1\"'" - ) - - for machine in global1, global2: - machine.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(up\{job=\"node\"\})' | " - + "jq '.data.result[0].value[1]' | grep '\"2\"'" - ) - - machine.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(prometheus_build_info)' | " - + "jq '.data.result[0].value[1]' | grep '\"4\"'" - ) - ''; -}) + testScript = '' + for machine in node1, node2: + machine.wait_for_unit("prometheus-node-exporter") + machine.wait_for_open_port(9100) + + for machine in prometheus1, prometheus2, global1, global2: + machine.wait_for_unit("prometheus") + machine.wait_for_open_port(9090) + + # Verify both servers got the same data from the exporter + for machine in prometheus1, prometheus2: + machine.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(up\{job=\"node\"\})' | " + + "jq '.data.result[0].value[1]' | grep '\"1\"'" + ) + machine.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(prometheus_build_info)' | " + + "jq '.data.result[0].value[1]' | grep '\"1\"'" + ) + + for machine in global1, global2: + machine.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(up\{job=\"node\"\})' | " + + "jq '.data.result[0].value[1]' | grep '\"2\"'" + ) + + machine.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(prometheus_build_info)' | " + + "jq '.data.result[0].value[1]' | grep '\"4\"'" + ) + ''; + } +) diff --git a/nixos/tests/prometheus/prometheus-pair.nix b/nixos/tests/prometheus/prometheus-pair.nix index 3ac70ca0403ec6..98860fa6bf95f9 100644 --- a/nixos/tests/prometheus/prometheus-pair.nix +++ b/nixos/tests/prometheus/prometheus-pair.nix @@ -1,87 +1,93 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: +import ../make-test-python.nix ( + { lib, pkgs, ... }: -{ - name = "prometheus-pair"; + { + name = "prometheus-pair"; - nodes = { - prometheus1 = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; + nodes = { + prometheus1 = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; + networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; - services.prometheus = { - enable = true; - globalConfig.scrape_interval = "2s"; - scrapeConfigs = [ - { - job_name = "prometheus"; - static_configs = [ + services.prometheus = { + enable = true; + globalConfig.scrape_interval = "2s"; + scrapeConfigs = [ { - targets = [ - "prometheus1:${toString config.services.prometheus.port}" - "prometheus2:${toString config.services.prometheus.port}" + job_name = "prometheus"; + static_configs = [ + { + targets = [ + "prometheus1:${toString config.services.prometheus.port}" + "prometheus2:${toString config.services.prometheus.port}" + ]; + } ]; } ]; - } - ]; - }; - }; + }; + }; - prometheus2 = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; + prometheus2 = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; + networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; - services.prometheus = { - enable = true; - globalConfig.scrape_interval = "2s"; - scrapeConfigs = [ - { - job_name = "prometheus"; - static_configs = [ + services.prometheus = { + enable = true; + globalConfig.scrape_interval = "2s"; + scrapeConfigs = [ { - targets = [ - "prometheus1:${toString config.services.prometheus.port}" - "prometheus2:${toString config.services.prometheus.port}" + job_name = "prometheus"; + static_configs = [ + { + targets = [ + "prometheus1:${toString config.services.prometheus.port}" + "prometheus2:${toString config.services.prometheus.port}" + ]; + } ]; } ]; - } - ]; - }; + }; + }; }; - }; - testScript = '' - for machine in prometheus1, prometheus2: - machine.wait_for_unit("prometheus") - machine.wait_for_open_port(9090) - machine.wait_until_succeeds("journalctl -o cat -u prometheus.service | grep 'version=${pkgs.prometheus.version}'") - machine.wait_until_succeeds("curl -sSf http://localhost:9090/-/healthy") + testScript = '' + for machine in prometheus1, prometheus2: + machine.wait_for_unit("prometheus") + machine.wait_for_open_port(9090) + machine.wait_until_succeeds("journalctl -o cat -u prometheus.service | grep 'version=${pkgs.prometheus.version}'") + machine.wait_until_succeeds("curl -sSf http://localhost:9090/-/healthy") - # Prometheii ready - run some queries - for machine in prometheus1, prometheus2: - machine.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=prometheus_build_info\{instance=\"prometheus1:9090\",version=\"${pkgs.prometheus.version}\"\}' | " - + "jq '.data.result[0].value[1]' | grep '\"1\"'" - ) + # Prometheii ready - run some queries + for machine in prometheus1, prometheus2: + machine.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=prometheus_build_info\{instance=\"prometheus1:9090\",version=\"${pkgs.prometheus.version}\"\}' | " + + "jq '.data.result[0].value[1]' | grep '\"1\"'" + ) - machine.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=prometheus_build_info\{instance=\"prometheus1:9090\"\}' | " - + "jq '.data.result[0].value[1]' | grep '\"1\"'" - ) + machine.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=prometheus_build_info\{instance=\"prometheus1:9090\"\}' | " + + "jq '.data.result[0].value[1]' | grep '\"1\"'" + ) - machine.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=sum(prometheus_build_info)%20by%20(version)' | " - + "jq '.data.result[0].metric.version' | grep '\"${pkgs.prometheus.version}\"'" - ) + machine.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=sum(prometheus_build_info)%20by%20(version)' | " + + "jq '.data.result[0].metric.version' | grep '\"${pkgs.prometheus.version}\"'" + ) - machine.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=sum(prometheus_build_info)%20by%20(version)' | " - + "jq '.data.result[0].value[1]' | grep '\"2\"'" - ) + machine.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=sum(prometheus_build_info)%20by%20(version)' | " + + "jq '.data.result[0].value[1]' | grep '\"2\"'" + ) - prometheus1.log(prometheus1.succeed("systemd-analyze security prometheus.service | grep -v '✓'")) - ''; -}) + prometheus1.log(prometheus1.succeed("systemd-analyze security prometheus.service | grep -v '✓'")) + ''; + } +) diff --git a/nixos/tests/prometheus/pushgateway.nix b/nixos/tests/prometheus/pushgateway.nix index 261c41598eb02e..1b42c965ca500d 100644 --- a/nixos/tests/prometheus/pushgateway.nix +++ b/nixos/tests/prometheus/pushgateway.nix @@ -1,96 +1,104 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: +import ../make-test-python.nix ( + { lib, pkgs, ... }: -{ - name = "prometheus-pushgateway"; + { + name = "prometheus-pushgateway"; - nodes = { - prometheus = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; + nodes = { + prometheus = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; + networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; - services.prometheus = { - enable = true; - globalConfig.scrape_interval = "2s"; + services.prometheus = { + enable = true; + globalConfig.scrape_interval = "2s"; - scrapeConfigs = [ - { - job_name = "pushgateway"; - static_configs = [ + scrapeConfigs = [ { - targets = [ - "pushgateway:9091" + job_name = "pushgateway"; + static_configs = [ + { + targets = [ + "pushgateway:9091" + ]; + } ]; } ]; - } - ]; - }; + }; + }; + + pushgateway = + { config, pkgs, ... }: + { + networking.firewall.allowedTCPPorts = [ 9091 ]; + + services.prometheus.pushgateway = { + enable = true; + }; + }; + + client = + { config, pkgs, ... }: + { + }; }; - pushgateway = { config, pkgs, ... }: { - networking.firewall.allowedTCPPorts = [ 9091 ]; - - services.prometheus.pushgateway = { - enable = true; - }; - }; - - client = { config, pkgs, ... }: { - }; - }; - - testScript = '' - pushgateway.wait_for_unit("pushgateway") - pushgateway.wait_for_open_port(9091) - pushgateway.wait_until_succeeds("curl -s http://127.0.0.1:9091/-/ready") - pushgateway.wait_until_succeeds("journalctl -o cat -u pushgateway.service | grep 'version=${pkgs.prometheus-pushgateway.version}'") - - prometheus.wait_for_unit("prometheus") - prometheus.wait_for_open_port(9090) - - prometheus.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(up\{job=\"pushgateway\"\})' | " - + "jq '.data.result[0].value[1]' | grep '\"1\"'" - ) - - prometheus.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=sum(pushgateway_build_info)%20by%20(version)' | " - + "jq '.data.result[0].metric.version' | grep '\"${pkgs.prometheus-pushgateway.version}\"'" - ) - - client.wait_for_unit("network-online.target") - - # Add a metric and check in Prometheus - client.wait_until_succeeds( - "echo 'some_metric 3.14' | curl --data-binary @- http://pushgateway:9091/metrics/job/some_job" - ) - - prometheus.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=some_metric' | " - + "jq '.data.result[0].value[1]' | grep '\"3.14\"'" - ) - - prometheus.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=absent(some_metric)' | " - + "jq '.data.result[0].value[1]' | grep 'null'" - ) - - # Delete the metric, check not in Prometheus - client.wait_until_succeeds( - "curl -X DELETE http://pushgateway:9091/metrics/job/some_job" - ) - - prometheus.wait_until_fails( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=some_metric' | " - + "jq '.data.result[0].value[1]' | grep '\"3.14\"'" - ) - - prometheus.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=absent(some_metric)' | " - + "jq '.data.result[0].value[1]' | grep '\"1\"'" - ) - - pushgateway.log(pushgateway.succeed("systemd-analyze security pushgateway.service | grep -v '✓'")) - ''; -}) + testScript = '' + pushgateway.wait_for_unit("pushgateway") + pushgateway.wait_for_open_port(9091) + pushgateway.wait_until_succeeds("curl -s http://127.0.0.1:9091/-/ready") + pushgateway.wait_until_succeeds("journalctl -o cat -u pushgateway.service | grep 'version=${pkgs.prometheus-pushgateway.version}'") + + prometheus.wait_for_unit("prometheus") + prometheus.wait_for_open_port(9090) + + prometheus.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=count(up\{job=\"pushgateway\"\})' | " + + "jq '.data.result[0].value[1]' | grep '\"1\"'" + ) + + prometheus.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=sum(pushgateway_build_info)%20by%20(version)' | " + + "jq '.data.result[0].metric.version' | grep '\"${pkgs.prometheus-pushgateway.version}\"'" + ) + + client.wait_for_unit("network-online.target") + + # Add a metric and check in Prometheus + client.wait_until_succeeds( + "echo 'some_metric 3.14' | curl --data-binary @- http://pushgateway:9091/metrics/job/some_job" + ) + + prometheus.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=some_metric' | " + + "jq '.data.result[0].value[1]' | grep '\"3.14\"'" + ) + + prometheus.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=absent(some_metric)' | " + + "jq '.data.result[0].value[1]' | grep 'null'" + ) + + # Delete the metric, check not in Prometheus + client.wait_until_succeeds( + "curl -X DELETE http://pushgateway:9091/metrics/job/some_job" + ) + + prometheus.wait_until_fails( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=some_metric' | " + + "jq '.data.result[0].value[1]' | grep '\"3.14\"'" + ) + + prometheus.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=absent(some_metric)' | " + + "jq '.data.result[0].value[1]' | grep '\"1\"'" + ) + + pushgateway.log(pushgateway.succeed("systemd-analyze security pushgateway.service | grep -v '✓'")) + ''; + } +) diff --git a/nixos/tests/prometheus/remote-write.nix b/nixos/tests/prometheus/remote-write.nix index 24092b9fb88dad..86c14901a6b0b6 100644 --- a/nixos/tests/prometheus/remote-write.nix +++ b/nixos/tests/prometheus/remote-write.nix @@ -1,73 +1,81 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: +import ../make-test-python.nix ( + { lib, pkgs, ... }: -{ - name = "prometheus-remote-write"; + { + name = "prometheus-remote-write"; - nodes = { - receiver = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; + nodes = { + receiver = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; + networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; - services.prometheus = { - enable = true; - globalConfig.scrape_interval = "2s"; + services.prometheus = { + enable = true; + globalConfig.scrape_interval = "2s"; - extraFlags = [ "--web.enable-remote-write-receiver" ]; - }; - }; + extraFlags = [ "--web.enable-remote-write-receiver" ]; + }; + }; - prometheus = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; + prometheus = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; + networking.firewall.allowedTCPPorts = [ config.services.prometheus.port ]; - services.prometheus = { - enable = true; - globalConfig.scrape_interval = "2s"; + services.prometheus = { + enable = true; + globalConfig.scrape_interval = "2s"; - remoteWrite = [ - { - url = "http://receiver:9090/api/v1/write"; - } - ]; + remoteWrite = [ + { + url = "http://receiver:9090/api/v1/write"; + } + ]; - scrapeConfigs = [ - { - job_name = "node"; - static_configs = [ + scrapeConfigs = [ { - targets = [ - "node:${toString config.services.prometheus.exporters.node.port}" + job_name = "node"; + static_configs = [ + { + targets = [ + "node:${toString config.services.prometheus.exporters.node.port}" + ]; + } ]; } ]; - } - ]; - }; - }; + }; + }; - node = { config, pkgs, ... }: { - services.prometheus.exporters.node = { - enable = true; - openFirewall = true; - }; + node = + { config, pkgs, ... }: + { + services.prometheus.exporters.node = { + enable = true; + openFirewall = true; + }; + }; }; - }; - testScript = '' - node.wait_for_unit("prometheus-node-exporter") - node.wait_for_open_port(9100) + testScript = '' + node.wait_for_unit("prometheus-node-exporter") + node.wait_for_open_port(9100) - for machine in prometheus, receiver: - machine.wait_for_unit("prometheus") - machine.wait_for_open_port(9090) + for machine in prometheus, receiver: + machine.wait_for_unit("prometheus") + machine.wait_for_open_port(9090) - # Verify both servers got the same data from the exporter - for machine in prometheus, receiver: - machine.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=node_exporter_build_info\{instance=\"node:9100\"\}' | " - + "jq '.data.result[0].value[1]' | grep '\"1\"'" - ) - ''; -}) + # Verify both servers got the same data from the exporter + for machine in prometheus, receiver: + machine.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:9090/api/v1/query?query=node_exporter_build_info\{instance=\"node:9100\"\}' | " + + "jq '.data.result[0].value[1]' | grep '\"1\"'" + ) + ''; + } +) diff --git a/nixos/tests/prowlarr.nix b/nixos/tests/prowlarr.nix index a1450972502ed2..859ce58b3b1ba6 100644 --- a/nixos/tests/prowlarr.nix +++ b/nixos/tests/prowlarr.nix @@ -1,18 +1,22 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "prowlarr"; - meta.maintainers = with lib.maintainers; [ ]; + { + name = "prowlarr"; + meta.maintainers = with lib.maintainers; [ ]; - nodes.machine = - { pkgs, ... }: - { services.prowlarr.enable = true; }; + nodes.machine = + { pkgs, ... }: + { + services.prowlarr.enable = true; + }; - testScript = '' - machine.wait_for_unit("prowlarr.service") - machine.wait_for_open_port(9696) - response = machine.succeed("curl --fail http://localhost:9696/") - assert 'Prowlarr' in response, "Login page didn't load successfully" - machine.succeed("[ -d /var/lib/prowlarr ]") - ''; -}) + testScript = '' + machine.wait_for_unit("prowlarr.service") + machine.wait_for_open_port(9696) + response = machine.succeed("curl --fail http://localhost:9696/") + assert 'Prowlarr' in response, "Login page didn't load successfully" + machine.succeed("[ -d /var/lib/prowlarr ]") + ''; + } +) diff --git a/nixos/tests/proxy.nix b/nixos/tests/proxy.nix index ce7131b09a8ab6..beba1d8435923a 100644 --- a/nixos/tests/proxy.nix +++ b/nixos/tests/proxy.nix @@ -1,90 +1,100 @@ -import ./make-test-python.nix ({ pkgs, ...} : - -let - backend = { pkgs, ... }: { - services.httpd = { - enable = true; - adminAddr = "foo@example.org"; - virtualHosts.localhost.documentRoot = "${pkgs.valgrind.doc}/share/doc/valgrind/html"; - }; - networking.firewall.allowedTCPPorts = [ 80 ]; - }; -in { - name = "proxy"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; - - nodes = { - proxy = { nodes, ... }: { - services.httpd = { - enable = true; - adminAddr = "bar@example.org"; - extraModules = [ "proxy_balancer" "lbmethod_byrequests" ]; - extraConfig = '' - ExtendedStatus on - ''; - virtualHosts.localhost = { - extraConfig = '' - - Require all granted - SetHandler server-status - - - - Require all granted - BalancerMember http://${nodes.backend1.config.networking.hostName} retry=0 - BalancerMember http://${nodes.backend2.config.networking.hostName} retry=0 - - - ProxyStatus full - ProxyPass /server-status ! - ProxyPass / balancer://cluster/ - ProxyPassReverse / balancer://cluster/ - - # For testing; don't want to wait forever for dead backend servers. - ProxyTimeout 5 - ''; +import ./make-test-python.nix ( + { pkgs, ... }: + + let + backend = + { pkgs, ... }: + { + services.httpd = { + enable = true; + adminAddr = "foo@example.org"; + virtualHosts.localhost.documentRoot = "${pkgs.valgrind.doc}/share/doc/valgrind/html"; }; + networking.firewall.allowedTCPPorts = [ 80 ]; }; - networking.firewall.allowedTCPPorts = [ 80 ]; + in + { + name = "proxy"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; }; - backend1 = backend; - backend2 = backend; + nodes = { + proxy = + { nodes, ... }: + { + services.httpd = { + enable = true; + adminAddr = "bar@example.org"; + extraModules = [ + "proxy_balancer" + "lbmethod_byrequests" + ]; + extraConfig = '' + ExtendedStatus on + ''; + virtualHosts.localhost = { + extraConfig = '' + + Require all granted + SetHandler server-status + + + + Require all granted + BalancerMember http://${nodes.backend1.config.networking.hostName} retry=0 + BalancerMember http://${nodes.backend2.config.networking.hostName} retry=0 + + + ProxyStatus full + ProxyPass /server-status ! + ProxyPass / balancer://cluster/ + ProxyPassReverse / balancer://cluster/ + + # For testing; don't want to wait forever for dead backend servers. + ProxyTimeout 5 + ''; + }; + }; + networking.firewall.allowedTCPPorts = [ 80 ]; + }; + + backend1 = backend; + backend2 = backend; - client = { ... }: { }; - }; + client = { ... }: { }; + }; - testScript = '' - start_all() + testScript = '' + start_all() - proxy.wait_for_unit("httpd") - backend1.wait_for_unit("httpd") - backend2.wait_for_unit("httpd") - client.wait_for_unit("network.target") + proxy.wait_for_unit("httpd") + backend1.wait_for_unit("httpd") + backend2.wait_for_unit("httpd") + client.wait_for_unit("network.target") - # With the back-ends up, the proxy should work. - client.succeed("curl --fail http://proxy/") + # With the back-ends up, the proxy should work. + client.succeed("curl --fail http://proxy/") - client.succeed("curl --fail http://proxy/server-status") + client.succeed("curl --fail http://proxy/server-status") - # Block the first back-end. - backend1.block() + # Block the first back-end. + backend1.block() - # The proxy should still work. - client.succeed("curl --fail http://proxy/") - client.succeed("curl --fail http://proxy/") + # The proxy should still work. + client.succeed("curl --fail http://proxy/") + client.succeed("curl --fail http://proxy/") - # Block the second back-end. - backend2.block() + # Block the second back-end. + backend2.block() - # Now the proxy should fail as well. - client.fail("curl --fail http://proxy/") + # Now the proxy should fail as well. + client.fail("curl --fail http://proxy/") - # But if the second back-end comes back, the proxy should start - # working again. - backend2.unblock() - client.succeed("curl --fail http://proxy/") - ''; -}) + # But if the second back-end comes back, the proxy should start + # working again. + backend2.unblock() + client.succeed("curl --fail http://proxy/") + ''; + } +) diff --git a/nixos/tests/pt2-clone.nix b/nixos/tests/pt2-clone.nix index 57a8495a3296ad..98df2e8cbac37b 100644 --- a/nixos/tests/pt2-clone.nix +++ b/nixos/tests/pt2-clone.nix @@ -1,22 +1,25 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "pt2-clone"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fgaz ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "pt2-clone"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fgaz ]; + }; - nodes.machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + nodes.machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; - environment.systemPackages = [ pkgs.pt2-clone ]; - }; + services.xserver.enable = true; + environment.systemPackages = [ pkgs.pt2-clone ]; + }; - enableOCR = true; + enableOCR = true; - testScript = - '' + testScript = '' machine.wait_for_x() # Add a dummy sound card, or the program won't start machine.execute("modprobe snd-dummy") @@ -30,5 +33,5 @@ import ./make-test-python.nix ({ pkgs, ... }: { raise Exception("Program did not start successfully") machine.screenshot("screen") ''; -}) - + } +) diff --git a/nixos/tests/public-inbox.nix b/nixos/tests/public-inbox.nix index 4d06d3e1738eed..36f67b09a4c6ad 100644 --- a/nixos/tests/public-inbox.nix +++ b/nixos/tests/public-inbox.nix @@ -1,230 +1,246 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - orga = "example"; - domain = "${orga}.localdomain"; - - tls-cert = pkgs.runCommand "selfSignedCert" { buildInputs = [ pkgs.openssl ]; } '' - openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -days 36500 \ - -subj '/CN=machine.${domain}' - install -D -t $out key.pem cert.pem - ''; -in -{ - name = "public-inbox"; - - meta.maintainers = with pkgs.lib.maintainers; [ julm ]; - - nodes.machine = { config, pkgs, nodes, ... }: let - inherit (config.services) gitolite public-inbox; - # Git repositories paths in Gitolite. - # Only their baseNameOf is used for configuring public-inbox. - repositories = [ - "user/repo1" - "user/repo2" - ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + orga = "example"; + domain = "${orga}.localdomain"; + + tls-cert = pkgs.runCommand "selfSignedCert" { buildInputs = [ pkgs.openssl ]; } '' + openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -days 36500 \ + -subj '/CN=machine.${domain}' + install -D -t $out key.pem cert.pem + ''; in { - virtualisation.diskSize = 1 * 1024; - virtualisation.memorySize = 1 * 1024; - networking.domain = domain; - - security.pki.certificateFiles = [ "${tls-cert}/cert.pem" ]; - # If using security.acme: - #security.acme.certs."${domain}".postRun = '' - # systemctl try-restart public-inbox-nntpd public-inbox-imapd - #''; - - services.public-inbox = { - enable = true; - postfix.enable = true; - openFirewall = true; - settings.publicinbox = { - css = [ "href=https://machine.${domain}/style/light.css" ]; - nntpserver = [ "nntps://machine.${domain}" ]; - wwwlisting = "match=domain"; - }; - mda = { - enable = true; - args = [ "--no-precheck" ]; # Allow Bcc: - }; - http = { - enable = true; - port = "/run/public-inbox-http.sock"; - #port = 8080; - args = ["-W0"]; - mounts = [ - "https://machine.${domain}/inbox" - ]; - }; - nntp = { - enable = true; - #port = 563; - args = ["-W0"]; - cert = "${tls-cert}/cert.pem"; - key = "${tls-cert}/key.pem"; - }; - imap = { - enable = true; - #port = 993; - args = ["-W0"]; - cert = "${tls-cert}/cert.pem"; - key = "${tls-cert}/key.pem"; - }; - inboxes = lib.recursiveUpdate (lib.genAttrs (map baseNameOf repositories) (repo: { - address = [ - # Routed to the "public-inbox:" transport in services.postfix.transport - "${repo}@${domain}" + name = "public-inbox"; + + meta.maintainers = with pkgs.lib.maintainers; [ julm ]; + + nodes.machine = + { + config, + pkgs, + nodes, + ... + }: + let + inherit (config.services) gitolite public-inbox; + # Git repositories paths in Gitolite. + # Only their baseNameOf is used for configuring public-inbox. + repositories = [ + "user/repo1" + "user/repo2" ]; - description = '' - ${repo}@${domain} : - discussions about ${repo}. - ''; - url = "https://machine.${domain}/inbox/${repo}"; - newsgroup = "inbox.comp.${orga}.${repo}"; - coderepo = [ repo ]; - })) + in { - repo2 = { - hide = [ - "imap" # FIXME: doesn't work for IMAP as of public-inbox 1.6.1 - "manifest" - "www" - ]; + virtualisation.diskSize = 1 * 1024; + virtualisation.memorySize = 1 * 1024; + networking.domain = domain; + + security.pki.certificateFiles = [ "${tls-cert}/cert.pem" ]; + # If using security.acme: + #security.acme.certs."${domain}".postRun = '' + # systemctl try-restart public-inbox-nntpd public-inbox-imapd + #''; + + services.public-inbox = { + enable = true; + postfix.enable = true; + openFirewall = true; + settings.publicinbox = { + css = [ "href=https://machine.${domain}/style/light.css" ]; + nntpserver = [ "nntps://machine.${domain}" ]; + wwwlisting = "match=domain"; + }; + mda = { + enable = true; + args = [ "--no-precheck" ]; # Allow Bcc: + }; + http = { + enable = true; + port = "/run/public-inbox-http.sock"; + #port = 8080; + args = [ "-W0" ]; + mounts = [ + "https://machine.${domain}/inbox" + ]; + }; + nntp = { + enable = true; + #port = 563; + args = [ "-W0" ]; + cert = "${tls-cert}/cert.pem"; + key = "${tls-cert}/key.pem"; + }; + imap = { + enable = true; + #port = 993; + args = [ "-W0" ]; + cert = "${tls-cert}/cert.pem"; + key = "${tls-cert}/key.pem"; + }; + inboxes = + lib.recursiveUpdate + (lib.genAttrs (map baseNameOf repositories) (repo: { + address = [ + # Routed to the "public-inbox:" transport in services.postfix.transport + "${repo}@${domain}" + ]; + description = '' + ${repo}@${domain} : + discussions about ${repo}. + ''; + url = "https://machine.${domain}/inbox/${repo}"; + newsgroup = "inbox.comp.${orga}.${repo}"; + coderepo = [ repo ]; + })) + { + repo2 = { + hide = [ + "imap" # FIXME: doesn't work for IMAP as of public-inbox 1.6.1 + "manifest" + "www" + ]; + }; + }; + settings.coderepo = lib.listToAttrs ( + map ( + path: + lib.nameValuePair (baseNameOf path) { + dir = "/var/lib/gitolite/repositories/${path}.git"; + cgitUrl = "https://git.${domain}/${path}.git"; + } + ) repositories + ); }; + + # Use gitolite to store Git repositories listed in coderepo entries + services.gitolite = { + enable = true; + adminPubkey = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJmoTOQnGqX+//us5oye8UuE+tQBx9QEM7PN13jrwgqY root@localhost"; + }; + systemd.services.public-inbox-httpd = { + serviceConfig.SupplementaryGroups = [ gitolite.group ]; + }; + + # Use nginx as a reverse proxy for public-inbox-httpd + services.nginx = { + enable = true; + recommendedGzipSettings = true; + recommendedOptimisation = true; + recommendedTlsSettings = true; + recommendedProxySettings = true; + virtualHosts."machine.${domain}" = { + forceSSL = true; + sslCertificate = "${tls-cert}/cert.pem"; + sslCertificateKey = "${tls-cert}/key.pem"; + locations."/".return = "302 /inbox"; + locations."= /inbox".return = "302 /inbox/"; + locations."/inbox".proxyPass = "http://unix:${public-inbox.http.port}:/inbox"; + # If using TCP instead of a Unix socket: + #locations."/inbox".proxyPass = "http://127.0.0.1:${toString public-inbox.http.port}/inbox"; + # Referred to by settings.publicinbox.css + # See http://public-inbox.org/meta/_/text/color/ + locations."= /style/light.css".alias = pkgs.writeText "light.css" '' + * { background:#fff; color:#000 } + + a { color:#00f; text-decoration:none } + a:visited { color:#808 } + + *.q { color:#008 } + + *.add { color:#060 } + *.del {color:#900 } + *.head { color:#000 } + *.hunk { color:#960 } + + .hl.num { color:#f30 } /* number */ + .hl.esc { color:#f0f } /* escape character */ + .hl.str { color:#f30 } /* string */ + .hl.ppc { color:#c3c } /* preprocessor */ + .hl.pps { color:#f30 } /* preprocessor string */ + .hl.slc { color:#099 } /* single-line comment */ + .hl.com { color:#099 } /* multi-line comment */ + /* .hl.opt { color:#ccc } */ /* operator */ + /* .hl.ipl { color:#ccc } */ /* interpolation */ + + /* keyword groups kw[a-z] */ + .hl.kwa { color:#f90 } + .hl.kwb { color:#060 } + .hl.kwc { color:#f90 } + /* .hl.kwd { color:#ccc } */ + ''; + }; + }; + + services.postfix = { + enable = true; + setSendmail = true; + #sslCert = "${tls-cert}/cert.pem"; + #sslKey = "${tls-cert}/key.pem"; + recipientDelimiter = "+"; + }; + + environment.systemPackages = [ + pkgs.mailutils + pkgs.openssl + ]; + }; - settings.coderepo = lib.listToAttrs (map (path: lib.nameValuePair (baseNameOf path) { - dir = "/var/lib/gitolite/repositories/${path}.git"; - cgitUrl = "https://git.${domain}/${path}.git"; - }) repositories); - }; - - # Use gitolite to store Git repositories listed in coderepo entries - services.gitolite = { - enable = true; - adminPubkey = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJmoTOQnGqX+//us5oye8UuE+tQBx9QEM7PN13jrwgqY root@localhost"; - }; - systemd.services.public-inbox-httpd = { - serviceConfig.SupplementaryGroups = [ gitolite.group ]; - }; - - # Use nginx as a reverse proxy for public-inbox-httpd - services.nginx = { - enable = true; - recommendedGzipSettings = true; - recommendedOptimisation = true; - recommendedTlsSettings = true; - recommendedProxySettings = true; - virtualHosts."machine.${domain}" = { - forceSSL = true; - sslCertificate = "${tls-cert}/cert.pem"; - sslCertificateKey = "${tls-cert}/key.pem"; - locations."/".return = "302 /inbox"; - locations."= /inbox".return = "302 /inbox/"; - locations."/inbox".proxyPass = "http://unix:${public-inbox.http.port}:/inbox"; - # If using TCP instead of a Unix socket: - #locations."/inbox".proxyPass = "http://127.0.0.1:${toString public-inbox.http.port}/inbox"; - # Referred to by settings.publicinbox.css - # See http://public-inbox.org/meta/_/text/color/ - locations."= /style/light.css".alias = pkgs.writeText "light.css" '' - * { background:#fff; color:#000 } - - a { color:#00f; text-decoration:none } - a:visited { color:#808 } - - *.q { color:#008 } - - *.add { color:#060 } - *.del {color:#900 } - *.head { color:#000 } - *.hunk { color:#960 } - - .hl.num { color:#f30 } /* number */ - .hl.esc { color:#f0f } /* escape character */ - .hl.str { color:#f30 } /* string */ - .hl.ppc { color:#c3c } /* preprocessor */ - .hl.pps { color:#f30 } /* preprocessor string */ - .hl.slc { color:#099 } /* single-line comment */ - .hl.com { color:#099 } /* multi-line comment */ - /* .hl.opt { color:#ccc } */ /* operator */ - /* .hl.ipl { color:#ccc } */ /* interpolation */ - - /* keyword groups kw[a-z] */ - .hl.kwa { color:#f90 } - .hl.kwb { color:#060 } - .hl.kwc { color:#f90 } - /* .hl.kwd { color:#ccc } */ - ''; - }; - }; - - services.postfix = { - enable = true; - setSendmail = true; - #sslCert = "${tls-cert}/cert.pem"; - #sslKey = "${tls-cert}/key.pem"; - recipientDelimiter = "+"; - }; - - environment.systemPackages = [ - pkgs.mailutils - pkgs.openssl - ]; - - }; - - testScript = '' - start_all() - machine.wait_for_unit("multi-user.target") - machine.wait_for_unit("public-inbox-init.service") - - # Very basic check that Gitolite can work; - # Gitolite is not needed for the rest of this testScript - machine.wait_for_unit("gitolite-init.service") - - # List inboxes through public-inbox-httpd - machine.wait_for_unit("nginx.service") - machine.succeed("curl -L https://machine.${domain} | grep repo1@${domain}") - # The repo2 inbox is hidden - machine.fail("curl -L https://machine.${domain} | grep repo2@${domain}") - machine.wait_for_unit("public-inbox-httpd.service") - - # Send a mail and read it through public-inbox-httpd - # Must work too when using a recipientDelimiter. - machine.wait_for_unit("postfix.service") - machine.succeed("mail -t <${pkgs.writeText "mail" '' - Subject: Testing mail - From: root@localhost - To: repo1+extension@${domain} - Message-ID: - Content-Type: text/plain; charset=utf-8 - Content-Disposition: inline - - This is a testing mail. - ''}") - machine.sleep(10) - machine.succeed("curl -L 'https://machine.${domain}/inbox/repo1/repo1@root-1/T/#u' | grep 'This is a testing mail.'") - - # Read a mail through public-inbox-imapd - machine.wait_for_open_port(993) - machine.wait_for_unit("public-inbox-imapd.service") - machine.succeed("openssl s_client -ign_eof -crlf -connect machine.${domain}:993 <${pkgs.writeText "imap-commands" '' - tag login anonymous@${domain} anonymous - tag SELECT INBOX.comp.${orga}.repo1.0 - tag FETCH 1 (BODY[HEADER]) - tag LOGOUT - ''} | grep '^Message-ID: '") - - # TODO: Read a mail through public-inbox-nntpd - #machine.wait_for_open_port(563) - #machine.wait_for_unit("public-inbox-nntpd.service") - - # Delete a mail. - # Note that the use of an extension not listed in the addresses - # require to use --all - machine.succeed("curl -L https://machine.${domain}/inbox/repo1/repo1@root-1/raw | sudo -u public-inbox public-inbox-learn rm --all") - machine.fail("curl -L https://machine.${domain}/inbox/repo1/repo1@root-1/T/#u | grep 'This is a testing mail.'") - - # Compact the database - machine.succeed("sudo -u public-inbox public-inbox-compact --all") - ''; -}) + + testScript = '' + start_all() + machine.wait_for_unit("multi-user.target") + machine.wait_for_unit("public-inbox-init.service") + + # Very basic check that Gitolite can work; + # Gitolite is not needed for the rest of this testScript + machine.wait_for_unit("gitolite-init.service") + + # List inboxes through public-inbox-httpd + machine.wait_for_unit("nginx.service") + machine.succeed("curl -L https://machine.${domain} | grep repo1@${domain}") + # The repo2 inbox is hidden + machine.fail("curl -L https://machine.${domain} | grep repo2@${domain}") + machine.wait_for_unit("public-inbox-httpd.service") + + # Send a mail and read it through public-inbox-httpd + # Must work too when using a recipientDelimiter. + machine.wait_for_unit("postfix.service") + machine.succeed("mail -t <${pkgs.writeText "mail" '' + Subject: Testing mail + From: root@localhost + To: repo1+extension@${domain} + Message-ID: + Content-Type: text/plain; charset=utf-8 + Content-Disposition: inline + + This is a testing mail. + ''}") + machine.sleep(10) + machine.succeed("curl -L 'https://machine.${domain}/inbox/repo1/repo1@root-1/T/#u' | grep 'This is a testing mail.'") + + # Read a mail through public-inbox-imapd + machine.wait_for_open_port(993) + machine.wait_for_unit("public-inbox-imapd.service") + machine.succeed("openssl s_client -ign_eof -crlf -connect machine.${domain}:993 <${pkgs.writeText "imap-commands" '' + tag login anonymous@${domain} anonymous + tag SELECT INBOX.comp.${orga}.repo1.0 + tag FETCH 1 (BODY[HEADER]) + tag LOGOUT + ''} | grep '^Message-ID: '") + + # TODO: Read a mail through public-inbox-nntpd + #machine.wait_for_open_port(563) + #machine.wait_for_unit("public-inbox-nntpd.service") + + # Delete a mail. + # Note that the use of an extension not listed in the addresses + # require to use --all + machine.succeed("curl -L https://machine.${domain}/inbox/repo1/repo1@root-1/raw | sudo -u public-inbox public-inbox-learn rm --all") + machine.fail("curl -L https://machine.${domain}/inbox/repo1/repo1@root-1/T/#u | grep 'This is a testing mail.'") + + # Compact the database + machine.succeed("sudo -u public-inbox public-inbox-compact --all") + ''; + } +) diff --git a/nixos/tests/pufferpanel.nix b/nixos/tests/pufferpanel.nix index e7b09c13f90bdd..e0613b43b7de41 100644 --- a/nixos/tests/pufferpanel.nix +++ b/nixos/tests/pufferpanel.nix @@ -1,74 +1,79 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "pufferpanel"; - meta.maintainers = [ lib.maintainers.tie ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "pufferpanel"; + meta.maintainers = [ lib.maintainers.tie ]; - nodes.machine = { pkgs, ... }: { - environment.systemPackages = [ pkgs.pufferpanel ]; - services.pufferpanel = { - enable = true; - extraPackages = [ pkgs.netcat ]; - environment = { - PUFFER_PANEL_REGISTRATIONENABLED = "false"; - PUFFER_PANEL_SETTINGS_COMPANYNAME = "NixOS"; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.pufferpanel ]; + services.pufferpanel = { + enable = true; + extraPackages = [ pkgs.netcat ]; + environment = { + PUFFER_PANEL_REGISTRATIONENABLED = "false"; + PUFFER_PANEL_SETTINGS_COMPANYNAME = "NixOS"; + }; + }; }; - }; - }; - testScript = '' - import shlex - import json + testScript = '' + import shlex + import json - curl = "curl --fail-with-body --silent" - baseURL = "http://localhost:8080" - adminName = "admin" - adminEmail = "admin@nixos.org" - adminPass = "admin" - adminCreds = json.dumps({ - "email": adminEmail, - "password": adminPass, - }) - stopCode = 9 # SIGKILL - serverPort = 1337 - serverDefinition = json.dumps({ - "name": "netcat", - "node": 0, - "users": [ - adminName, - ], - "type": "netcat", - "run": { - "stopCode": stopCode, - "command": f"nc -l {serverPort}", - }, - "environment": { - "type": "standard", - }, - }) + curl = "curl --fail-with-body --silent" + baseURL = "http://localhost:8080" + adminName = "admin" + adminEmail = "admin@nixos.org" + adminPass = "admin" + adminCreds = json.dumps({ + "email": adminEmail, + "password": adminPass, + }) + stopCode = 9 # SIGKILL + serverPort = 1337 + serverDefinition = json.dumps({ + "name": "netcat", + "node": 0, + "users": [ + adminName, + ], + "type": "netcat", + "run": { + "stopCode": stopCode, + "command": f"nc -l {serverPort}", + }, + "environment": { + "type": "standard", + }, + }) - start_all() + start_all() - machine.wait_for_unit("pufferpanel.service") - machine.wait_for_open_port(5657) # SFTP - machine.wait_for_open_port(8080) # HTTP + machine.wait_for_unit("pufferpanel.service") + machine.wait_for_open_port(5657) # SFTP + machine.wait_for_open_port(8080) # HTTP - # Note that PufferPanel does not initialize database unless necessary. - # /api/config endpoint creates database file and triggers migrations. - # On success, we run a command to create administrator user that we use to - # interact with HTTP API. - resp = json.loads(machine.succeed(f"{curl} {baseURL}/api/config")) - assert resp["branding"]["name"] == "NixOS", "Invalid company name in configuration" - assert resp["registrationEnabled"] == False, "Expected registration to be disabled" + # Note that PufferPanel does not initialize database unless necessary. + # /api/config endpoint creates database file and triggers migrations. + # On success, we run a command to create administrator user that we use to + # interact with HTTP API. + resp = json.loads(machine.succeed(f"{curl} {baseURL}/api/config")) + assert resp["branding"]["name"] == "NixOS", "Invalid company name in configuration" + assert resp["registrationEnabled"] == False, "Expected registration to be disabled" - machine.succeed(f"pufferpanel --workDir /var/lib/pufferpanel user add --admin --name {adminName} --email {adminEmail} --password {adminPass}") + machine.succeed(f"pufferpanel --workDir /var/lib/pufferpanel user add --admin --name {adminName} --email {adminEmail} --password {adminPass}") - resp = json.loads(machine.succeed(f"{curl} -d '{adminCreds}' {baseURL}/auth/login")) - assert "servers.admin" in resp["scopes"], "User is not administrator" - token = resp["session"] - authHeader = shlex.quote(f"Authorization: Bearer {token}") + resp = json.loads(machine.succeed(f"{curl} -d '{adminCreds}' {baseURL}/auth/login")) + assert "servers.admin" in resp["scopes"], "User is not administrator" + token = resp["session"] + authHeader = shlex.quote(f"Authorization: Bearer {token}") - resp = json.loads(machine.succeed(f"{curl} -H {authHeader} -H 'Content-Type: application/json' -d '{serverDefinition}' {baseURL}/api/servers")) - serverID = resp["id"] - machine.succeed(f"{curl} -X POST -H {authHeader} {baseURL}/proxy/daemon/server/{serverID}/start") - machine.wait_for_open_port(serverPort) - ''; -}) + resp = json.loads(machine.succeed(f"{curl} -H {authHeader} -H 'Content-Type: application/json' -d '{serverDefinition}' {baseURL}/api/servers")) + serverID = resp["id"] + machine.succeed(f"{curl} -X POST -H {authHeader} {baseURL}/proxy/daemon/server/{serverID}/start") + machine.wait_for_open_port(serverPort) + ''; + } +) diff --git a/nixos/tests/pulseaudio.nix b/nixos/tests/pulseaudio.nix index ccc33f28bc6d55..04bb8612dd6284 100644 --- a/nixos/tests/pulseaudio.nix +++ b/nixos/tests/pulseaudio.nix @@ -1,14 +1,19 @@ let - mkTest = { systemWide ? false , fullVersion ? false }: - import ./make-test-python.nix ({ pkgs, lib, ... }: + mkTest = + { + systemWide ? false, + fullVersion ? false, + }: + import ./make-test-python.nix ( + { pkgs, lib, ... }: let testFile = pkgs.fetchurl { - url = - "https://file-examples.com/storage/fe5947fd2362fc197a3c2df/2017/11/file_example_MP3_700KB.mp3"; + url = "https://file-examples.com/storage/fe5947fd2362fc197a3c2df/2017/11/file_example_MP3_700KB.mp3"; hash = "sha256-+iggJW8s0/LfA/okfXsB550/55Q0Sq3OoIzuBrzOPJQ="; }; - makeTestPlay = key: + makeTestPlay = + key: { sox, alsa-utils }: pkgs.writeScriptBin key '' set -euxo pipefail @@ -21,60 +26,83 @@ let testPlay = { inherit (pkgs) sox alsa-utils; }; testPlay32 = { inherit (pkgs.pkgsi686Linux) sox alsa-utils; }; }; - in { + in + { name = "pulseaudio${lib.optionalString fullVersion "Full"}${lib.optionalString systemWide "-systemWide"}"; meta = with pkgs.lib.maintainers; { maintainers = [ synthetica ] ++ pkgs.pulseaudio.meta.maintainers; }; - nodes.machine = { ... }: + nodes.machine = + { ... }: { imports = [ ./common/wayland-cage.nix ]; - hardware.pulseaudio = { - enable = true; - support32Bit = true; - inherit systemWide; - } // lib.optionalAttrs fullVersion { - package = pkgs.pulseaudioFull; - }; + hardware.pulseaudio = + { + enable = true; + support32Bit = true; + inherit systemWide; + } + // lib.optionalAttrs fullVersion { + package = pkgs.pulseaudioFull; + }; - environment.systemPackages = [ testers.testPlay pkgs.pavucontrol ] - ++ lib.optional pkgs.stdenv.hostPlatform.isx86_64 testers.testPlay32; - } // lib.optionalAttrs systemWide { + environment.systemPackages = [ + testers.testPlay + pkgs.pavucontrol + ] ++ lib.optional pkgs.stdenv.hostPlatform.isx86_64 testers.testPlay32; + } + // lib.optionalAttrs systemWide { users.users.alice.extraGroups = [ "pulse-access" ]; systemd.services.pulseaudio.wantedBy = [ "multi-user.target" ]; }; enableOCR = true; - testScript = { ... }: '' - machine.wait_until_succeeds("pgrep xterm") - machine.wait_for_text("alice@machine") + testScript = + { ... }: + '' + machine.wait_until_succeeds("pgrep xterm") + machine.wait_for_text("alice@machine") - machine.send_chars("testPlay \n") - machine.wait_for_file("/tmp/testPlay_success") - ${lib.optionalString pkgs.stdenv.hostPlatform.isx86_64 '' - machine.send_chars("testPlay32 \n") - machine.wait_for_file("/tmp/testPlay32_success") - ''} - machine.screenshot("testPlay") + machine.send_chars("testPlay \n") + machine.wait_for_file("/tmp/testPlay_success") + ${lib.optionalString pkgs.stdenv.hostPlatform.isx86_64 '' + machine.send_chars("testPlay32 \n") + machine.wait_for_file("/tmp/testPlay32_success") + ''} + machine.screenshot("testPlay") - ${lib.optionalString (!systemWide) '' - machine.send_chars("pacmd info && touch /tmp/pacmd_success\n") - machine.wait_for_file("/tmp/pacmd_success") - ''} + ${lib.optionalString (!systemWide) '' + machine.send_chars("pacmd info && touch /tmp/pacmd_success\n") + machine.wait_for_file("/tmp/pacmd_success") + ''} - # Pavucontrol only loads when Pulseaudio is running. If it isn't, the - # text "Dummy Output" (sound device name) will never show. - machine.send_chars("pavucontrol\n") - machine.wait_for_text("Dummy Output") - machine.screenshot("Pavucontrol") - ''; - }); -in builtins.mapAttrs (key: val: mkTest val) { - user = { systemWide = false; fullVersion = false; }; - system = { systemWide = true; fullVersion = false; }; - userFull = { systemWide = false; fullVersion = true; }; - systemFull = { systemWide = true; fullVersion = true; }; + # Pavucontrol only loads when Pulseaudio is running. If it isn't, the + # text "Dummy Output" (sound device name) will never show. + machine.send_chars("pavucontrol\n") + machine.wait_for_text("Dummy Output") + machine.screenshot("Pavucontrol") + ''; + } + ); +in +builtins.mapAttrs (key: val: mkTest val) { + user = { + systemWide = false; + fullVersion = false; + }; + system = { + systemWide = true; + fullVersion = false; + }; + userFull = { + systemWide = false; + fullVersion = true; + }; + systemFull = { + systemWide = true; + fullVersion = true; + }; } diff --git a/nixos/tests/pykms.nix b/nixos/tests/pykms.nix index 14d776a2f113e2..e7df338a9fc261 100644 --- a/nixos/tests/pykms.nix +++ b/nixos/tests/pykms.nix @@ -1,14 +1,23 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: { name = "pykms-test"; meta.maintainers = with pkgs.lib.maintainers; [ zopieux ]; - nodes.machine = { config, lib, pkgs, ... }: { - services.pykms.enable = true; - }; + nodes.machine = + { + config, + lib, + pkgs, + ... + }: + { + services.pykms.enable = true; + }; testScript = '' machine.wait_for_unit("pykms.service") machine.succeed("${pkgs.pykms}/bin/client") ''; - }) + } +) diff --git a/nixos/tests/pyload.nix b/nixos/tests/pyload.nix index f913e822b2ff3f..9f87faec2b2c26 100644 --- a/nixos/tests/pyload.nix +++ b/nixos/tests/pyload.nix @@ -1,33 +1,38 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "pyload"; - meta.maintainers = with lib.maintainers; [ ambroisie ]; - - nodes = { - machine = { ... }: { - services.pyload = { - enable = true; - - listenAddress = "0.0.0.0"; - port = 9876; - }; - - networking.firewall.allowedTCPPorts = [ 9876 ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "pyload"; + meta.maintainers = with lib.maintainers; [ ambroisie ]; + + nodes = { + machine = + { ... }: + { + services.pyload = { + enable = true; + + listenAddress = "0.0.0.0"; + port = 9876; + }; + + networking.firewall.allowedTCPPorts = [ 9876 ]; + }; + + client = { }; }; - client = { }; - }; - - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("pyload.service") + machine.wait_for_unit("pyload.service") - with subtest("Web interface accessible locally"): - machine.wait_until_succeeds("curl -fs localhost:9876") + with subtest("Web interface accessible locally"): + machine.wait_until_succeeds("curl -fs localhost:9876") - client.wait_for_unit("network.target") + client.wait_for_unit("network.target") - with subtest("Web interface accessible from a different machine"): - client.wait_until_succeeds("curl -fs machine:9876") - ''; -}) + with subtest("Web interface accessible from a different machine"): + client.wait_until_succeeds("curl -fs machine:9876") + ''; + } +) diff --git a/nixos/tests/qboot.nix b/nixos/tests/qboot.nix index 29d999be58e5bc..822f74ed26655e 100644 --- a/nixos/tests/qboot.nix +++ b/nixos/tests/qboot.nix @@ -1,13 +1,17 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "qboot"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "qboot"; - nodes.machine = { ... }: { - virtualisation.bios = pkgs.qboot; - }; + nodes.machine = + { ... }: + { + virtualisation.bios = pkgs.qboot; + }; - testScript = - '' + testScript = '' start_all() machine.wait_for_unit("multi-user.target") ''; -}) + } +) diff --git a/nixos/tests/qemu-vm-external-disk-image.nix b/nixos/tests/qemu-vm-external-disk-image.nix index c481159511a028..94cbbfd8843715 100644 --- a/nixos/tests/qemu-vm-external-disk-image.nix +++ b/nixos/tests/qemu-vm-external-disk-image.nix @@ -11,66 +11,82 @@ let rootFslabel = "external"; rootFsDevice = "/dev/disk/by-label/${rootFslabel}"; - externalModule = { config, lib, pkgs, ... }: { - boot.loader.systemd-boot.enable = true; + externalModule = + { + config, + lib, + pkgs, + ... + }: + { + boot.loader.systemd-boot.enable = true; - fileSystems = { - "/".device = rootFsDevice; - }; + fileSystems = { + "/".device = rootFsDevice; + }; - system.build.diskImage = import ../lib/make-disk-image.nix { - inherit config lib pkgs; - label = rootFslabel; - partitionTableType = "efi"; - format = "qcow2"; - bootSize = "32M"; - additionalSpace = "0M"; - copyChannel = false; + system.build.diskImage = import ../lib/make-disk-image.nix { + inherit config lib pkgs; + label = rootFslabel; + partitionTableType = "efi"; + format = "qcow2"; + bootSize = "32M"; + additionalSpace = "0M"; + copyChannel = false; + }; }; - }; in { name = "qemu-vm-external-disk-image"; meta.maintainers = with lib.maintainers; [ nikstur ]; - nodes.machine = { config, lib, pkgs, ... }: { - virtualisation.directBoot.enable = false; - virtualisation.mountHostNixStore = false; - virtualisation.useEFIBoot = true; + nodes.machine = + { + config, + lib, + pkgs, + ... + }: + { + virtualisation.directBoot.enable = false; + virtualisation.mountHostNixStore = false; + virtualisation.useEFIBoot = true; - # This stops the qemu-vm module from overriding the fileSystems option - # with virtualisation.fileSystems. - virtualisation.fileSystems = lib.mkForce { }; + # This stops the qemu-vm module from overriding the fileSystems option + # with virtualisation.fileSystems. + virtualisation.fileSystems = lib.mkForce { }; - imports = [ externalModule ]; - }; + imports = [ externalModule ]; + }; - testScript = { nodes, ... }: '' - import os - import subprocess - import tempfile + testScript = + { nodes, ... }: + '' + import os + import subprocess + import tempfile - tmp_disk_image = tempfile.NamedTemporaryFile() + tmp_disk_image = tempfile.NamedTemporaryFile() - subprocess.run([ - "${nodes.machine.virtualisation.qemu.package}/bin/qemu-img", - "create", - "-f", - "qcow2", - "-b", - "${nodes.machine.system.build.diskImage}/nixos.qcow2", - "-F", - "qcow2", - tmp_disk_image.name, - ]) + subprocess.run([ + "${nodes.machine.virtualisation.qemu.package}/bin/qemu-img", + "create", + "-f", + "qcow2", + "-b", + "${nodes.machine.system.build.diskImage}/nixos.qcow2", + "-F", + "qcow2", + tmp_disk_image.name, + ]) - # Set NIX_DISK_IMAGE so that the qemu script finds the right disk image. - os.environ['NIX_DISK_IMAGE'] = tmp_disk_image.name + # Set NIX_DISK_IMAGE so that the qemu script finds the right disk image. + os.environ['NIX_DISK_IMAGE'] = tmp_disk_image.name - machine.succeed("findmnt --kernel --source ${rootFsDevice} --target /") + machine.succeed("findmnt --kernel --source ${rootFsDevice} --target /") - # Make sure systemd boot didn't clobber this - machine.succeed("[ ! -e /homeless-shelter ]") - ''; + # Make sure systemd boot didn't clobber this + machine.succeed("[ ! -e /homeless-shelter ]") + ''; } diff --git a/nixos/tests/qemu-vm-restrictnetwork.nix b/nixos/tests/qemu-vm-restrictnetwork.nix index 49aefcc099bda8..9249f0cc126958 100644 --- a/nixos/tests/qemu-vm-restrictnetwork.nix +++ b/nixos/tests/qemu-vm-restrictnetwork.nix @@ -2,13 +2,17 @@ import ./make-test-python.nix ({ name = "qemu-vm-restrictnetwork"; nodes = { - unrestricted = { config, pkgs, ... }: { - virtualisation.restrictNetwork = false; - }; + unrestricted = + { config, pkgs, ... }: + { + virtualisation.restrictNetwork = false; + }; - restricted = { config, pkgs, ... }: { - virtualisation.restrictNetwork = true; - }; + restricted = + { config, pkgs, ... }: + { + virtualisation.restrictNetwork = true; + }; }; testScript = '' @@ -34,5 +38,5 @@ import ./make-test-python.nix ({ # 10.0.2.2 is the gateway mapping to the host's loopback interface. unrestricted.succeed("curl -s http://10.0.2.2:8000") restricted.fail("curl -s http://10.0.2.2:8000") - ''; + ''; }) diff --git a/nixos/tests/qemu-vm-store.nix b/nixos/tests/qemu-vm-store.nix index 9fb9f4baaafc46..1824ef5591599b 100644 --- a/nixos/tests/qemu-vm-store.nix +++ b/nixos/tests/qemu-vm-store.nix @@ -1,4 +1,5 @@ -{ lib, ... }: { +{ lib, ... }: +{ name = "qemu-vm-store"; diff --git a/nixos/tests/qgis.nix b/nixos/tests/qgis.nix index e8149e4885627e..1a7b75891b96d2 100644 --- a/nixos/tests/qgis.nix +++ b/nixos/tests/qgis.nix @@ -1,4 +1,10 @@ -import ./make-test-python.nix ({ pkgs, lib, package, ... }: +import ./make-test-python.nix ( + { + pkgs, + lib, + package, + ... + }: let qgisPackage = package.override { withServer = true; }; testScript = pkgs.writeTextFile { @@ -13,61 +19,65 @@ import ./make-test-python.nix ({ pkgs, lib, package, ... }: }; nodes = { - machine = { config, pkgs, ... }: + machine = + { config, pkgs, ... }: - let - qgisServerUser = config.services.nginx.user; - qgisServerSocket = "/run/qgis_mapserv.socket"; - in - { - virtualisation.diskSize = 2 * 1024; + let + qgisServerUser = config.services.nginx.user; + qgisServerSocket = "/run/qgis_mapserv.socket"; + in + { + virtualisation.diskSize = 2 * 1024; - imports = [ ./common/x11.nix ]; - environment.systemPackages = [ - qgisPackage - ]; + imports = [ ./common/x11.nix ]; + environment.systemPackages = [ + qgisPackage + ]; - systemd.sockets.qgis-server = { - listenStreams = [ qgisServerSocket ]; - socketConfig = { - Accept = false; - SocketUser = qgisServerUser; - SocketMode = 0600; + systemd.sockets.qgis-server = { + listenStreams = [ qgisServerSocket ]; + socketConfig = { + Accept = false; + SocketUser = qgisServerUser; + SocketMode = 600; + }; + wantedBy = [ + "sockets.target" + "qgis-server.service" + ]; + before = [ "qgis-server.service" ]; }; - wantedBy = ["sockets.target" "qgis-server.service"]; - before = [ "qgis-server.service" ]; - }; - systemd.services.qgis-server = { - description = "QGIS server"; - serviceConfig = { - User = qgisServerUser; - StandardOutput = "null"; - StandardError = "journal"; - StandardInput = "socket"; - Environment = [ - "QT_QPA_PLATFORM_PLUGIN_PATH=${pkgs.libsForQt5.qt5.qtbase}/${pkgs.libsForQt5.qt5.qtbase.qtPluginPrefix}/platforms" - "QGIS_SERVER_LOG_LEVEL=0" - "QGIS_SERVER_LOG_STDERR=1" - ]; - ExecStart = "${qgisPackage}/lib/cgi-bin/qgis_mapserv.fcgi"; + systemd.services.qgis-server = { + description = "QGIS server"; + serviceConfig = { + User = qgisServerUser; + StandardOutput = "null"; + StandardError = "journal"; + StandardInput = "socket"; + Environment = [ + "QT_QPA_PLATFORM_PLUGIN_PATH=${pkgs.libsForQt5.qt5.qtbase}/${pkgs.libsForQt5.qt5.qtbase.qtPluginPrefix}/platforms" + "QGIS_SERVER_LOG_LEVEL=0" + "QGIS_SERVER_LOG_STDERR=1" + ]; + ExecStart = "${qgisPackage}/lib/cgi-bin/qgis_mapserv.fcgi"; + }; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; }; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - }; - services.nginx = { - enable = true; - virtualHosts."qgis" = { - locations."~".extraConfig = '' - gzip off; - include ${pkgs.nginx}/conf/fastcgi_params; - include ${pkgs.nginx}/conf/fastcgi.conf; - fastcgi_pass unix:${qgisServerSocket}; - ''; + services.nginx = { + enable = true; + virtualHosts."qgis" = { + locations."~".extraConfig = '' + gzip off; + include ${pkgs.nginx}/conf/fastcgi_params; + include ${pkgs.nginx}/conf/fastcgi.conf; + fastcgi_pass unix:${qgisServerSocket}; + ''; + }; }; }; - }; }; testScript = '' @@ -83,4 +93,5 @@ import ./make-test-python.nix ({ pkgs, lib, package, ... }: machine.succeed("curl --head http://localhost | grep 'Server:.*${qgisPackage.version}'") machine.succeed("curl http://localhost/index.json | grep 'Landing page as JSON'") ''; - }) + } +) diff --git a/nixos/tests/qownnotes.nix b/nixos/tests/qownnotes.nix index 3390ba6d902534..710492f59bf5ed 100644 --- a/nixos/tests/qownnotes.nix +++ b/nixos/tests/qownnotes.nix @@ -1,82 +1,88 @@ -import ./make-test-python.nix ({ lib, pkgs, ...} : - -{ - name = "qownnotes"; - meta.maintainers = [ lib.maintainers.pbek ]; - - nodes.machine = { ... }: +import ./make-test-python.nix ( + { lib, pkgs, ... }: { - imports = [ - ./common/user-account.nix - ./common/x11.nix - ]; - - test-support.displayManager.auto.user = "alice"; - environment.systemPackages = [ - pkgs.qownnotes - pkgs.xdotool - ]; - }; - - enableOCR = true; - - # https://nixos.org/manual/nixos/stable/#ssec-machine-objects - testScript = { nodes, ... }: let - aliceDo = cmd: ''machine.succeed("su - alice -c '${cmd}' >&2 &");''; - in '' - with subtest("Ensure X starts"): - start_all() - machine.wait_for_x() - - with subtest("Check QOwnNotes version on CLI"): - ${aliceDo "qownnotes --version"} - - machine.wait_for_console_text("QOwnNotes ${pkgs.qownnotes.version}") - - with subtest("Ensure QOwnNotes starts"): - # start QOwnNotes window - ${aliceDo "qownnotes"} - - machine.wait_for_text("Welcome to QOwnNotes") - machine.screenshot("QOwnNotes-Welcome") - - with subtest("Finish first-run wizard"): - # The wizard should show up now - machine.wait_for_text("Note folder") - machine.send_key("ret") - machine.wait_for_console_text("Note path '/home/alice/Notes' was now created.") - machine.wait_for_text("Panel layout") - machine.send_key("ret") - machine.wait_for_text("Nextcloud") - machine.send_key("ret") - machine.wait_for_text("App metric") - machine.send_key("ret") - - # Doesn't work for non-root - #machine.wait_for_window("QOwnNotes - ${pkgs.qownnotes.version}") - - # OCR doesn't seem to be able any more to handle the main window - #machine.wait_for_text("QOwnNotes - ${pkgs.qownnotes.version}") - - # The main window should now show up - machine.wait_for_open_port(22222) - machine.wait_for_console_text("QOwnNotes server listening on port 22222") - - machine.screenshot("QOwnNotes-DemoNote") - - with subtest("Create a new note"): - machine.send_key("ctrl-n") - machine.sleep(1) - machine.send_chars("This is a NixOS test!\n") - machine.wait_until_succeeds("find /home/alice/Notes -type f | grep -qi 'Note 2'") - - # OCR doesn't seem to be able any more to handle the main window - #machine.wait_for_text("This is a NixOS test!") - - # Doesn't work for non-root - #machine.wait_for_window("- QOwnNotes - ${pkgs.qownnotes.version}") - - machine.screenshot("QOwnNotes-NewNote") - ''; -}) + name = "qownnotes"; + meta.maintainers = [ lib.maintainers.pbek ]; + + nodes.machine = + { ... }: + + { + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; + + test-support.displayManager.auto.user = "alice"; + environment.systemPackages = [ + pkgs.qownnotes + pkgs.xdotool + ]; + }; + + enableOCR = true; + + # https://nixos.org/manual/nixos/stable/#ssec-machine-objects + testScript = + { nodes, ... }: + let + aliceDo = cmd: ''machine.succeed("su - alice -c '${cmd}' >&2 &");''; + in + '' + with subtest("Ensure X starts"): + start_all() + machine.wait_for_x() + + with subtest("Check QOwnNotes version on CLI"): + ${aliceDo "qownnotes --version"} + + machine.wait_for_console_text("QOwnNotes ${pkgs.qownnotes.version}") + + with subtest("Ensure QOwnNotes starts"): + # start QOwnNotes window + ${aliceDo "qownnotes"} + + machine.wait_for_text("Welcome to QOwnNotes") + machine.screenshot("QOwnNotes-Welcome") + + with subtest("Finish first-run wizard"): + # The wizard should show up now + machine.wait_for_text("Note folder") + machine.send_key("ret") + machine.wait_for_console_text("Note path '/home/alice/Notes' was now created.") + machine.wait_for_text("Panel layout") + machine.send_key("ret") + machine.wait_for_text("Nextcloud") + machine.send_key("ret") + machine.wait_for_text("App metric") + machine.send_key("ret") + + # Doesn't work for non-root + #machine.wait_for_window("QOwnNotes - ${pkgs.qownnotes.version}") + + # OCR doesn't seem to be able any more to handle the main window + #machine.wait_for_text("QOwnNotes - ${pkgs.qownnotes.version}") + + # The main window should now show up + machine.wait_for_open_port(22222) + machine.wait_for_console_text("QOwnNotes server listening on port 22222") + + machine.screenshot("QOwnNotes-DemoNote") + + with subtest("Create a new note"): + machine.send_key("ctrl-n") + machine.sleep(1) + machine.send_chars("This is a NixOS test!\n") + machine.wait_until_succeeds("find /home/alice/Notes -type f | grep -qi 'Note 2'") + + # OCR doesn't seem to be able any more to handle the main window + #machine.wait_for_text("This is a NixOS test!") + + # Doesn't work for non-root + #machine.wait_for_window("- QOwnNotes - ${pkgs.qownnotes.version}") + + machine.screenshot("QOwnNotes-NewNote") + ''; + } +) diff --git a/nixos/tests/qtile/default.nix b/nixos/tests/qtile/default.nix index 718063fa8bb507..547a53dcf12341 100644 --- a/nixos/tests/qtile/default.nix +++ b/nixos/tests/qtile/default.nix @@ -1,45 +1,54 @@ -import ../make-test-python.nix ({ lib, ...} : { - name = "qtile"; - - meta = { - maintainers = with lib.maintainers; [ sigmanificient ]; - }; - - nodes.machine = { pkgs, lib, ... }: let - # We create a custom Qtile configuration file that adds a widget from - # qtile-extras to the bar. This ensure that the qtile-extras package - # also works, and that extraPackages behave as expected. - - config-deriv = pkgs.callPackage ./config.nix { }; - in { - imports = [ ../common/x11.nix ../common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - - services.xserver.windowManager.qtile = { - enable = true; - configFile = "${config-deriv}/config.py"; - extraPackages = ps: [ ps.qtile-extras ]; - }; - - services.displayManager.defaultSession = lib.mkForce "qtile"; - - environment.systemPackages = [ pkgs.kitty ]; - }; +import ../make-test-python.nix ( + { lib, ... }: + { + name = "qtile"; - testScript = '' - with subtest("ensure x starts"): - machine.wait_for_x() - machine.wait_for_file("/home/alice/.Xauthority") - machine.succeed("xauth merge ~alice/.Xauthority") - - with subtest("ensure client is available"): - machine.succeed("qtile --version") + meta = { + maintainers = with lib.maintainers; [ sigmanificient ]; + }; - with subtest("ensure we can open a new terminal"): - machine.sleep(2) - machine.send_key("meta_l-ret") - machine.wait_for_window(r"alice.*?machine") - machine.sleep(2) - machine.screenshot("terminal") - ''; -}) + nodes.machine = + { pkgs, lib, ... }: + let + # We create a custom Qtile configuration file that adds a widget from + # qtile-extras to the bar. This ensure that the qtile-extras package + # also works, and that extraPackages behave as expected. + + config-deriv = pkgs.callPackage ./config.nix { }; + in + { + imports = [ + ../common/x11.nix + ../common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + + services.xserver.windowManager.qtile = { + enable = true; + configFile = "${config-deriv}/config.py"; + extraPackages = ps: [ ps.qtile-extras ]; + }; + + services.displayManager.defaultSession = lib.mkForce "qtile"; + + environment.systemPackages = [ pkgs.kitty ]; + }; + + testScript = '' + with subtest("ensure x starts"): + machine.wait_for_x() + machine.wait_for_file("/home/alice/.Xauthority") + machine.succeed("xauth merge ~alice/.Xauthority") + + with subtest("ensure client is available"): + machine.succeed("qtile --version") + + with subtest("ensure we can open a new terminal"): + machine.sleep(2) + machine.send_key("meta_l-ret") + machine.wait_for_window(r"alice.*?machine") + machine.sleep(2) + machine.screenshot("terminal") + ''; + } +) diff --git a/nixos/tests/quake3.nix b/nixos/tests/quake3.nix index 947476c7ebc1ab..cade2991de6132 100644 --- a/nixos/tests/quake3.nix +++ b/nixos/tests/quake3.nix @@ -1,53 +1,60 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : +import ./make-test-python.nix ( + { pkgs, lib, ... }: -let + let - # Build Quake with coverage instrumentation. - overrides = pkgs: - { + # Build Quake with coverage instrumentation. + overrides = pkgs: { quake3game = pkgs.quake3game.override (args: { stdenv = pkgs.stdenvAdapters.addCoverageInstrumentation args.stdenv; }); }; - # Only allow the demo data to be used (only if it's unfreeRedistributable). - unfreePredicate = pkg: let - allowPackageNames = [ "quake3-demodata" "quake3-pointrelease" ]; - allowLicenses = [ lib.licenses.unfreeRedistributable ]; - in lib.elem pkg.pname allowPackageNames && - lib.elem (pkg.meta.license or null) allowLicenses; - - client = - { pkgs, ... }: - - { imports = [ ./common/x11.nix ]; - hardware.graphics.enable = true; - environment.systemPackages = [ pkgs.quake3demo ]; - nixpkgs.config.packageOverrides = overrides; - nixpkgs.config.allowUnfreePredicate = unfreePredicate; + # Only allow the demo data to be used (only if it's unfreeRedistributable). + unfreePredicate = + pkg: + let + allowPackageNames = [ + "quake3-demodata" + "quake3-pointrelease" + ]; + allowLicenses = [ lib.licenses.unfreeRedistributable ]; + in + lib.elem pkg.pname allowPackageNames && lib.elem (pkg.meta.license or null) allowLicenses; + + client = + { pkgs, ... }: + + { + imports = [ ./common/x11.nix ]; + hardware.graphics.enable = true; + environment.systemPackages = [ pkgs.quake3demo ]; + nixpkgs.config.packageOverrides = overrides; + nixpkgs.config.allowUnfreePredicate = unfreePredicate; + }; + + in + + rec { + name = "quake3"; + meta = with lib.maintainers; { + maintainers = [ domenkozar ]; }; -in + # TODO: lcov doesn't work atm + #makeCoverageReport = true; -rec { - name = "quake3"; - meta = with lib.maintainers; { - maintainers = [ domenkozar ]; - }; - - # TODO: lcov doesn't work atm - #makeCoverageReport = true; - - nodes = - { server = + nodes = { + server = { pkgs, ... }: - { systemd.services.quake3-server = - { wantedBy = [ "multi-user.target" ]; - script = - "${pkgs.quake3demo}/bin/quake3-server +set g_gametype 0 " + - "+map q3dm7 +addbot grunt +addbot daemia 2> /tmp/log"; - }; + { + systemd.services.quake3-server = { + wantedBy = [ "multi-user.target" ]; + script = + "${pkgs.quake3demo}/bin/quake3-server +set g_gametype 0 " + + "+map q3dm7 +addbot grunt +addbot daemia 2> /tmp/log"; + }; nixpkgs.config.packageOverrides = overrides; nixpkgs.config.allowUnfreePredicate = unfreePredicate; networking.firewall.allowedUDPPorts = [ 27960 ]; @@ -57,8 +64,7 @@ rec { client2 = client; }; - testScript = - '' + testScript = '' start_all() server.wait_for_unit("quake3-server") @@ -92,4 +98,5 @@ rec { server.stop_job("quake3-server") ''; -}) + } +) diff --git a/nixos/tests/quicktun.nix b/nixos/tests/quicktun.nix index a5a63245711749..62b441f3fd7809 100644 --- a/nixos/tests/quicktun.nix +++ b/nixos/tests/quicktun.nix @@ -1,18 +1,22 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -{ - name = "quicktun"; - meta.maintainers = with lib.maintainers; [ h7x4 ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "quicktun"; + meta.maintainers = with lib.maintainers; [ h7x4 ]; - nodes = { - machine = { ... }: { - services.quicktun."test-tunnel" = { - protocol = "raw"; - }; + nodes = { + machine = + { ... }: + { + services.quicktun."test-tunnel" = { + protocol = "raw"; + }; + }; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("quicktun-test-tunnel.service") - ''; -}) + testScript = '' + start_all() + machine.wait_for_unit("quicktun-test-tunnel.service") + ''; + } +) diff --git a/nixos/tests/quickwit.nix b/nixos/tests/quickwit.nix index 7e617c63d79738..0dddd547fd0604 100644 --- a/nixos/tests/quickwit.nix +++ b/nixos/tests/quickwit.nix @@ -1,103 +1,106 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: +import ./make-test-python.nix ( + { lib, pkgs, ... }: -let - # Define an example Quickwit index schema, - # and some `exampleDocs` below, to test if ingesting - # and querying works as expected. - index_yaml = '' - version: 0.7 - index_id: example_server_logs - doc_mapping: - mode: dynamic - field_mappings: - - name: datetime - type: datetime - fast: true - input_formats: - - iso8601 - output_format: iso8601 - fast_precision: seconds - fast: true - - name: git - type: text - tokenizer: raw - - name: hostname - type: text - tokenizer: raw - - name: level - type: text - tokenizer: raw - - name: message - type: text - - name: location - type: text - - name: source - type: text - timestamp_field: datetime + let + # Define an example Quickwit index schema, + # and some `exampleDocs` below, to test if ingesting + # and querying works as expected. + index_yaml = '' + version: 0.7 + index_id: example_server_logs + doc_mapping: + mode: dynamic + field_mappings: + - name: datetime + type: datetime + fast: true + input_formats: + - iso8601 + output_format: iso8601 + fast_precision: seconds + fast: true + - name: git + type: text + tokenizer: raw + - name: hostname + type: text + tokenizer: raw + - name: level + type: text + tokenizer: raw + - name: message + type: text + - name: location + type: text + - name: source + type: text + timestamp_field: datetime - search_settings: - default_search_fields: [message] + search_settings: + default_search_fields: [message] - indexing_settings: - commit_timeout_secs: 10 - ''; + indexing_settings: + commit_timeout_secs: 10 + ''; - exampleDocs = '' - {"datetime":"2024-05-03T02:36:41.017674444Z","git":"e6e1f087ce12065e44ed3b87b50784e6f9bcc2f9","hostname":"machine-1","level":"Info","message":"Processing request done","location":"path/to/server.c:6442:32","source":""} - {"datetime":"2024-05-04T02:36:41.017674444Z","git":"e6e1f087ce12065e44ed3b87b50784e6f9bcc2f9","hostname":"machine-1","level":"Info","message":"Got exception processing request: HTTP 404","location":"path/to/server.c:6444:32","source":""} - {"datetime":"2024-05-05T02:36:41.017674444Z","git":"e6e1f087ce12065e44ed3b87b50784e6f9bcc2f9","hostname":"machine-1","level":"Info","message":"Got exception processing request: HTTP 404","location":"path/to/server.c:6444:32","source":""} - {"datetime":"2024-05-06T02:36:41.017674444Z","git":"e6e1f087ce12065e44ed3b87b50784e6f9bcc2f9","hostname":"machine-2","level":"Info","message":"Got exception processing request: HTTP 404","location":"path/to/server.c:6444:32","source":""} - ''; -in -{ - name = "quickwit"; - meta.maintainers = [ pkgs.lib.maintainers.happysalada ]; + exampleDocs = '' + {"datetime":"2024-05-03T02:36:41.017674444Z","git":"e6e1f087ce12065e44ed3b87b50784e6f9bcc2f9","hostname":"machine-1","level":"Info","message":"Processing request done","location":"path/to/server.c:6442:32","source":""} + {"datetime":"2024-05-04T02:36:41.017674444Z","git":"e6e1f087ce12065e44ed3b87b50784e6f9bcc2f9","hostname":"machine-1","level":"Info","message":"Got exception processing request: HTTP 404","location":"path/to/server.c:6444:32","source":""} + {"datetime":"2024-05-05T02:36:41.017674444Z","git":"e6e1f087ce12065e44ed3b87b50784e6f9bcc2f9","hostname":"machine-1","level":"Info","message":"Got exception processing request: HTTP 404","location":"path/to/server.c:6444:32","source":""} + {"datetime":"2024-05-06T02:36:41.017674444Z","git":"e6e1f087ce12065e44ed3b87b50784e6f9bcc2f9","hostname":"machine-2","level":"Info","message":"Got exception processing request: HTTP 404","location":"path/to/server.c:6444:32","source":""} + ''; + in + { + name = "quickwit"; + meta.maintainers = [ pkgs.lib.maintainers.happysalada ]; - nodes = { - quickwit = { config, pkgs, ... }: { - services.quickwit.enable = true; + nodes = { + quickwit = + { config, pkgs, ... }: + { + services.quickwit.enable = true; + }; }; - }; - testScript = - '' - quickwit.wait_for_unit("quickwit") - quickwit.wait_for_open_port(7280) - quickwit.wait_for_open_port(7281) + testScript = '' + quickwit.wait_for_unit("quickwit") + quickwit.wait_for_open_port(7280) + quickwit.wait_for_open_port(7281) - quickwit.wait_until_succeeds( - "journalctl -o cat -u quickwit.service | grep 'version: ${pkgs.quickwit.version}'" - ) + quickwit.wait_until_succeeds( + "journalctl -o cat -u quickwit.service | grep 'version: ${pkgs.quickwit.version}'" + ) - quickwit.wait_until_succeeds( - "journalctl -o cat -u quickwit.service | grep 'transitioned to ready state'" - ) + quickwit.wait_until_succeeds( + "journalctl -o cat -u quickwit.service | grep 'transitioned to ready state'" + ) - with subtest("verify UI installed"): - machine.succeed("curl -sSf http://127.0.0.1:7280/ui/") + with subtest("verify UI installed"): + machine.succeed("curl -sSf http://127.0.0.1:7280/ui/") - with subtest("injest and query data"): - import json + with subtest("injest and query data"): + import json - # Test CLI ingestion - print(machine.succeed('${pkgs.quickwit}/bin/quickwit index create --index-config ${pkgs.writeText "index.yaml" index_yaml}')) - # Important to use `--wait`, otherwise the queries below race with index processing. - print(machine.succeed('${pkgs.quickwit}/bin/quickwit index ingest --index example_server_logs --input-path ${pkgs.writeText "exampleDocs.json" exampleDocs} --wait')) + # Test CLI ingestion + print(machine.succeed('${pkgs.quickwit}/bin/quickwit index create --index-config ${pkgs.writeText "index.yaml" index_yaml}')) + # Important to use `--wait`, otherwise the queries below race with index processing. + print(machine.succeed('${pkgs.quickwit}/bin/quickwit index ingest --index example_server_logs --input-path ${pkgs.writeText "exampleDocs.json" exampleDocs} --wait')) - # Test CLI query - cli_query_output = machine.succeed('${pkgs.quickwit}/bin/quickwit index search --index example_server_logs --query "exception"') - print(cli_query_output) + # Test CLI query + cli_query_output = machine.succeed('${pkgs.quickwit}/bin/quickwit index search --index example_server_logs --query "exception"') + print(cli_query_output) - # Assert query result is as expected. - num_hits = len(json.loads(cli_query_output)["hits"]) - assert num_hits == 3, f"cli_query_output contains unexpected number of results: {num_hits}" + # Assert query result is as expected. + num_hits = len(json.loads(cli_query_output)["hits"]) + assert num_hits == 3, f"cli_query_output contains unexpected number of results: {num_hits}" - # Test API query - api_query_output = machine.succeed('curl --fail http://127.0.0.1:7280/api/v1/example_server_logs/search?query=exception') - print(api_query_output) + # Test API query + api_query_output = machine.succeed('curl --fail http://127.0.0.1:7280/api/v1/example_server_logs/search?query=exception') + print(api_query_output) - quickwit.log(quickwit.succeed( - "systemd-analyze security quickwit.service | grep -v '✓'" - )) - ''; -}) + quickwit.log(quickwit.succeed( + "systemd-analyze security quickwit.service | grep -v '✓'" + )) + ''; + } +) diff --git a/nixos/tests/quorum.nix b/nixos/tests/quorum.nix index dd0d1540e8455f..1a38ad4346585c 100644 --- a/nixos/tests/quorum.nix +++ b/nixos/tests/quorum.nix @@ -1,103 +1,105 @@ -import ./make-test-python.nix ({ pkgs, ... }: -let - keystore = { - address = "9377bc3936de934c497e22917b81aa8774ac3bb0"; - crypto = { - cipher = "aes-128-ctr"; - ciphertext = "ad8341d8ef225650403fd366c955f41095e438dd966a3c84b3d406818c1e366c"; - cipherparams = { - iv = "2a09f7a72fd6dff7c43150ff437e6ac2"; +import ./make-test-python.nix ( + { pkgs, ... }: + let + keystore = { + address = "9377bc3936de934c497e22917b81aa8774ac3bb0"; + crypto = { + cipher = "aes-128-ctr"; + ciphertext = "ad8341d8ef225650403fd366c955f41095e438dd966a3c84b3d406818c1e366c"; + cipherparams = { + iv = "2a09f7a72fd6dff7c43150ff437e6ac2"; + }; + kdf = "scrypt"; + kdfparams = { + dklen = 32; + n = 262144; + p = 1; + r = 8; + salt = "d1a153845bb80cd6274c87c5bac8ac09fdfac5ff131a6f41b5ed319667f12027"; + }; + mac = "a9621ad88fa1d042acca6fc2fcd711f7e05bfbadea3f30f379235570c8e270d3"; }; - kdf = "scrypt"; - kdfparams = { - dklen = 32; - n = 262144; - p = 1; - r = 8; - salt = "d1a153845bb80cd6274c87c5bac8ac09fdfac5ff131a6f41b5ed319667f12027"; - }; - mac = "a9621ad88fa1d042acca6fc2fcd711f7e05bfbadea3f30f379235570c8e270d3"; + id = "89e847a3-1527-42f6-a321-77de0a14ce02"; + version = 3; + }; + keystore-file = pkgs.writeText "keystore-file" (builtins.toJSON keystore); + in + { + name = "quorum"; + meta = with pkgs.lib.maintainers; { + maintainers = [ mmahut ]; }; - id = "89e847a3-1527-42f6-a321-77de0a14ce02"; - version = 3; - }; - keystore-file = pkgs.writeText "keystore-file" (builtins.toJSON keystore); -in -{ - name = "quorum"; - meta = with pkgs.lib.maintainers; { - maintainers = [ mmahut ]; - }; - nodes = { - machine = { ... }: { - services.quorum = { - enable = true; - permissioned = false; - staticNodes = [ "enode://dd333ec28f0a8910c92eb4d336461eea1c20803eed9cf2c056557f986e720f8e693605bba2f4e8f289b1162e5ac7c80c914c7178130711e393ca76abc1d92f57@0.0.0.0:30303?discport=0" ]; - genesis = { - alloc = { - "189d23d201b03ae1cf9113672df29a5d672aefa3" = { - balance = "0x446c3b15f9926687d2c40534fdb564000000000000"; - }; - "44b07d2c28b8ed8f02b45bd84ac7d9051b3349e6" = { - balance = "0x446c3b15f9926687d2c40534fdb564000000000000"; - }; - "4c1ccd426833b9782729a212c857f2f03b7b4c0d" = { - balance = "0x446c3b15f9926687d2c40534fdb564000000000000"; - }; - "7ae555d0f6faad7930434abdaac2274fd86ab516" = { - balance = "0x446c3b15f9926687d2c40534fdb564000000000000"; - }; - c1056df7c02b6f1a353052eaf0533cc7cb743b52 = { - balance = "0x446c3b15f9926687d2c40534fdb564000000000000"; - }; - }; - coinbase = "0x0000000000000000000000000000000000000000"; - config = { - byzantiumBlock = 1; - chainId = 10; - eip150Block = 1; - eip150Hash = - "0x0000000000000000000000000000000000000000000000000000000000000000"; - eip155Block = 1; - eip158Block = 1; - homesteadBlock = 1; - isQuorum = true; - istanbul = { - epoch = 30000; - policy = 0; + nodes = { + machine = + { ... }: + { + services.quorum = { + enable = true; + permissioned = false; + staticNodes = [ + "enode://dd333ec28f0a8910c92eb4d336461eea1c20803eed9cf2c056557f986e720f8e693605bba2f4e8f289b1162e5ac7c80c914c7178130711e393ca76abc1d92f57@0.0.0.0:30303?discport=0" + ]; + genesis = { + alloc = { + "189d23d201b03ae1cf9113672df29a5d672aefa3" = { + balance = "0x446c3b15f9926687d2c40534fdb564000000000000"; + }; + "44b07d2c28b8ed8f02b45bd84ac7d9051b3349e6" = { + balance = "0x446c3b15f9926687d2c40534fdb564000000000000"; + }; + "4c1ccd426833b9782729a212c857f2f03b7b4c0d" = { + balance = "0x446c3b15f9926687d2c40534fdb564000000000000"; + }; + "7ae555d0f6faad7930434abdaac2274fd86ab516" = { + balance = "0x446c3b15f9926687d2c40534fdb564000000000000"; + }; + c1056df7c02b6f1a353052eaf0533cc7cb743b52 = { + balance = "0x446c3b15f9926687d2c40534fdb564000000000000"; + }; + }; + coinbase = "0x0000000000000000000000000000000000000000"; + config = { + byzantiumBlock = 1; + chainId = 10; + eip150Block = 1; + eip150Hash = "0x0000000000000000000000000000000000000000000000000000000000000000"; + eip155Block = 1; + eip158Block = 1; + homesteadBlock = 1; + isQuorum = true; + istanbul = { + epoch = 30000; + policy = 0; + }; + }; + difficulty = "0x1"; + extraData = "0x0000000000000000000000000000000000000000000000000000000000000000f8aff869944c1ccd426833b9782729a212c857f2f03b7b4c0d94189d23d201b03ae1cf9113672df29a5d672aefa39444b07d2c28b8ed8f02b45bd84ac7d9051b3349e694c1056df7c02b6f1a353052eaf0533cc7cb743b52947ae555d0f6faad7930434abdaac2274fd86ab516b8410000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000c0"; + gasLimit = "0xe0000000"; + gasUsed = "0x0"; + mixHash = "0x63746963616c2062797a616e74696e65206661756c7420746f6c6572616e6365"; + nonce = "0x0"; + number = "0x0"; + parentHash = "0x0000000000000000000000000000000000000000000000000000000000000000"; + timestamp = "0x5cffc201"; }; }; - difficulty = "0x1"; - extraData = - "0x0000000000000000000000000000000000000000000000000000000000000000f8aff869944c1ccd426833b9782729a212c857f2f03b7b4c0d94189d23d201b03ae1cf9113672df29a5d672aefa39444b07d2c28b8ed8f02b45bd84ac7d9051b3349e694c1056df7c02b6f1a353052eaf0533cc7cb743b52947ae555d0f6faad7930434abdaac2274fd86ab516b8410000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000c0"; - gasLimit = "0xe0000000"; - gasUsed = "0x0"; - mixHash = - "0x63746963616c2062797a616e74696e65206661756c7420746f6c6572616e6365"; - nonce = "0x0"; - number = "0x0"; - parentHash = - "0x0000000000000000000000000000000000000000000000000000000000000000"; - timestamp = "0x5cffc201"; - }; - }; + }; }; - }; - testScript = '' - start_all() - machine.succeed("mkdir -p /var/lib/quorum/keystore") - machine.succeed( - 'cp ${keystore-file} /var/lib/quorum/keystore/UTC--2020-03-23T11-08-34.144812212Z--${keystore.address}' - ) - machine.succeed( - "echo fe2725c4e8f7617764b845e8d939a65c664e7956eb47ed7d934573f16488efc1 > /var/lib/quorum/nodekey" - ) - machine.succeed("systemctl restart quorum") - machine.wait_for_unit("quorum.service") - machine.sleep(15) - machine.succeed('geth attach /var/lib/quorum/geth.ipc --exec "eth.accounts" | grep ${keystore.address}') - ''; -}) + testScript = '' + start_all() + machine.succeed("mkdir -p /var/lib/quorum/keystore") + machine.succeed( + 'cp ${keystore-file} /var/lib/quorum/keystore/UTC--2020-03-23T11-08-34.144812212Z--${keystore.address}' + ) + machine.succeed( + "echo fe2725c4e8f7617764b845e8d939a65c664e7956eb47ed7d934573f16488efc1 > /var/lib/quorum/nodekey" + ) + machine.succeed("systemctl restart quorum") + machine.wait_for_unit("quorum.service") + machine.sleep(15) + machine.succeed('geth attach /var/lib/quorum/geth.ipc --exec "eth.accounts" | grep ${keystore.address}') + ''; + } +) diff --git a/nixos/tests/rabbitmq.nix b/nixos/tests/rabbitmq.nix index 4b8921662b7f43..52513b424bb4a7 100644 --- a/nixos/tests/rabbitmq.nix +++ b/nixos/tests/rabbitmq.nix @@ -1,61 +1,63 @@ # This test runs rabbitmq and checks if rabbitmq is up and running. -import ./make-test-python.nix ({ pkgs, ... }: -let - # in real life, you would keep this out of your repo and deploy it to a safe - # location using safe means. - configKeyPath = pkgs.writeText "fake-config-key" "hOjWzSEn2Z7cHzKOcf6i183O2NdjurSuoMDIIv01"; -in -{ - name = "rabbitmq"; - meta = with pkgs.lib.maintainers; { - maintainers = [ offline ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + let + # in real life, you would keep this out of your repo and deploy it to a safe + # location using safe means. + configKeyPath = pkgs.writeText "fake-config-key" "hOjWzSEn2Z7cHzKOcf6i183O2NdjurSuoMDIIv01"; + in + { + name = "rabbitmq"; + meta = with pkgs.lib.maintainers; { + maintainers = [ offline ]; + }; - nodes.machine = { - services.rabbitmq = { - enable = true; - managementPlugin.enable = true; + nodes.machine = { + services.rabbitmq = { + enable = true; + managementPlugin.enable = true; - # To encrypt: - # rabbitmqctl --quiet encode --cipher blowfish_cfb64 --hash sha256 \ - # --iterations 10000 '<<"dJT8isYu6t0Xb6u56rPglSj1vK51SlNVlXfwsRxw">>' \ - # "hOjWzSEn2Z7cHzKOcf6i183O2NdjurSuoMDIIv01" ; - config = '' - [ { rabbit - , [ {default_user, <<"alice">>} - , { default_pass - , {encrypted,<<"oKKxyTze9PYmsEfl6FG1MxIUhxY7WPQL7HBoMPRC/1ZOdOZbtr9+DxjWW3e1D5SL48n3D9QOsGD0cOgYG7Qdvb7Txrepw8w=">>} - } - , {config_entry_decoder - , [ {passphrase, {file, <<"${configKeyPath}">>}} - , {cipher, blowfish_cfb64} - , {hash, sha256} - , {iterations, 10000} - ] - } - % , {rabbitmq_management, [{path_prefix, "/_queues"}]} - ] - } - ]. - ''; + # To encrypt: + # rabbitmqctl --quiet encode --cipher blowfish_cfb64 --hash sha256 \ + # --iterations 10000 '<<"dJT8isYu6t0Xb6u56rPglSj1vK51SlNVlXfwsRxw">>' \ + # "hOjWzSEn2Z7cHzKOcf6i183O2NdjurSuoMDIIv01" ; + config = '' + [ { rabbit + , [ {default_user, <<"alice">>} + , { default_pass + , {encrypted,<<"oKKxyTze9PYmsEfl6FG1MxIUhxY7WPQL7HBoMPRC/1ZOdOZbtr9+DxjWW3e1D5SL48n3D9QOsGD0cOgYG7Qdvb7Txrepw8w=">>} + } + , {config_entry_decoder + , [ {passphrase, {file, <<"${configKeyPath}">>}} + , {cipher, blowfish_cfb64} + , {hash, sha256} + , {iterations, 10000} + ] + } + % , {rabbitmq_management, [{path_prefix, "/_queues"}]} + ] + } + ]. + ''; + }; + # Ensure there is sufficient extra disk space for rabbitmq to be happy + virtualisation.diskSize = 1024; }; - # Ensure there is sufficient extra disk space for rabbitmq to be happy - virtualisation.diskSize = 1024; - }; - testScript = '' - machine.start() + testScript = '' + machine.start() - machine.wait_for_unit("rabbitmq.service") - machine.wait_until_succeeds( - 'su -s ${pkgs.runtimeShell} rabbitmq -c "rabbitmqctl status"' - ) - machine.wait_for_open_port(15672) + machine.wait_for_unit("rabbitmq.service") + machine.wait_until_succeeds( + 'su -s ${pkgs.runtimeShell} rabbitmq -c "rabbitmqctl status"' + ) + machine.wait_for_open_port(15672) - # The password is the plaintext that was encrypted with rabbitmqctl encode above. - machine.wait_until_succeeds( - '${pkgs.rabbitmq-java-client}/bin/PerfTest --time 10 --uri amqp://alice:dJT8isYu6t0Xb6u56rPglSj1vK51SlNVlXfwsRxw@localhost' - ) - ''; -}) + # The password is the plaintext that was encrypted with rabbitmqctl encode above. + machine.wait_until_succeeds( + '${pkgs.rabbitmq-java-client}/bin/PerfTest --time 10 --uri amqp://alice:dJT8isYu6t0Xb6u56rPglSj1vK51SlNVlXfwsRxw@localhost' + ) + ''; + } +) diff --git a/nixos/tests/radarr.nix b/nixos/tests/radarr.nix index bf9eb11c2b1263..ac093beeb7909b 100644 --- a/nixos/tests/radarr.nix +++ b/nixos/tests/radarr.nix @@ -1,16 +1,20 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "radarr"; - meta.maintainers = with lib.maintainers; [ etu ]; + { + name = "radarr"; + meta.maintainers = with lib.maintainers; [ etu ]; - nodes.machine = - { pkgs, ... }: - { services.radarr.enable = true; }; + nodes.machine = + { pkgs, ... }: + { + services.radarr.enable = true; + }; - testScript = '' - machine.wait_for_unit("radarr.service") - machine.wait_for_open_port(7878) - machine.succeed("curl --fail http://localhost:7878/") - ''; -}) + testScript = '' + machine.wait_for_unit("radarr.service") + machine.wait_for_open_port(7878) + machine.succeed("curl --fail http://localhost:7878/") + ''; + } +) diff --git a/nixos/tests/radicale.nix b/nixos/tests/radicale.nix index 868b28085a6758..96c17a657b3afe 100644 --- a/nixos/tests/radicale.nix +++ b/nixos/tests/radicale.nix @@ -1,95 +1,100 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: +import ./make-test-python.nix ( + { lib, pkgs, ... }: -let - user = "someuser"; - password = "some_password"; - port = "5232"; - filesystem_folder = "/data/radicale"; + let + user = "someuser"; + password = "some_password"; + port = "5232"; + filesystem_folder = "/data/radicale"; - cli = "${lib.getExe pkgs.calendar-cli} --caldav-user ${user} --caldav-pass ${password}"; -in { - name = "radicale3"; - meta.maintainers = with lib.maintainers; [ dotlambda ]; + cli = "${lib.getExe pkgs.calendar-cli} --caldav-user ${user} --caldav-pass ${password}"; + in + { + name = "radicale3"; + meta.maintainers = with lib.maintainers; [ dotlambda ]; - nodes.machine = { pkgs, ... }: { - services.radicale = { - enable = true; - settings = { - auth = { - type = "htpasswd"; - htpasswd_filename = "/etc/radicale/users"; - htpasswd_encryption = "bcrypt"; - }; - storage = { - inherit filesystem_folder; - hook = "git add -A && (git diff --cached --quiet || git commit -m 'Changes by '%(user)s)"; - }; - logging.level = "info"; - }; - rights = { - principal = { - user = ".+"; - collection = "{user}"; - permissions = "RW"; - }; - calendars = { - user = ".+"; - collection = "{user}/[^/]+"; - permissions = "rw"; + nodes.machine = + { pkgs, ... }: + { + services.radicale = { + enable = true; + settings = { + auth = { + type = "htpasswd"; + htpasswd_filename = "/etc/radicale/users"; + htpasswd_encryption = "bcrypt"; + }; + storage = { + inherit filesystem_folder; + hook = "git add -A && (git diff --cached --quiet || git commit -m 'Changes by '%(user)s)"; + }; + logging.level = "info"; + }; + rights = { + principal = { + user = ".+"; + collection = "{user}"; + permissions = "RW"; + }; + calendars = { + user = ".+"; + collection = "{user}/[^/]+"; + permissions = "rw"; + }; + }; }; + systemd.services.radicale.path = [ pkgs.git ]; + environment.systemPackages = [ pkgs.git ]; + systemd.tmpfiles.rules = [ "d ${filesystem_folder} 0750 radicale radicale -" ]; + # WARNING: DON'T DO THIS IN PRODUCTION! + # This puts unhashed secrets directly into the Nix store for ease of testing. + environment.etc."radicale/users".source = pkgs.runCommand "htpasswd" { } '' + ${pkgs.apacheHttpd}/bin/htpasswd -bcB "$out" ${user} ${password} + ''; }; - }; - systemd.services.radicale.path = [ pkgs.git ]; - environment.systemPackages = [ pkgs.git ]; - systemd.tmpfiles.rules = [ "d ${filesystem_folder} 0750 radicale radicale -" ]; - # WARNING: DON'T DO THIS IN PRODUCTION! - # This puts unhashed secrets directly into the Nix store for ease of testing. - environment.etc."radicale/users".source = pkgs.runCommand "htpasswd" {} '' - ${pkgs.apacheHttpd}/bin/htpasswd -bcB "$out" ${user} ${password} - ''; - }; - testScript = '' - machine.wait_for_unit("radicale.service") - machine.wait_for_open_port(${port}) + testScript = '' + machine.wait_for_unit("radicale.service") + machine.wait_for_open_port(${port}) - machine.succeed("sudo -u radicale git -C ${filesystem_folder} init") - machine.succeed( - "sudo -u radicale git -C ${filesystem_folder} config --local user.email radicale@example.com" - ) - machine.succeed( - "sudo -u radicale git -C ${filesystem_folder} config --local user.name radicale" - ) + machine.succeed("sudo -u radicale git -C ${filesystem_folder} init") + machine.succeed( + "sudo -u radicale git -C ${filesystem_folder} config --local user.email radicale@example.com" + ) + machine.succeed( + "sudo -u radicale git -C ${filesystem_folder} config --local user.name radicale" + ) - with subtest("Test calendar and event creation"): - machine.succeed( - "${cli} --caldav-url http://localhost:${port}/${user} calendar create cal" - ) - machine.succeed("test -d ${filesystem_folder}/collection-root/${user}/cal") - machine.succeed('test -z "$(ls ${filesystem_folder}/collection-root/${user}/cal)"') - machine.succeed( - "${cli} --caldav-url http://localhost:${port}/${user}/cal calendar add 2021-04-23 testevent" - ) - machine.succeed('test -n "$(ls ${filesystem_folder}/collection-root/${user}/cal)"') - (status, stdout) = machine.execute( - "sudo -u radicale git -C ${filesystem_folder} log --format=oneline | wc -l" - ) - assert status == 0, "git log failed" - assert stdout == "3\n", "there should be exactly 3 commits" + with subtest("Test calendar and event creation"): + machine.succeed( + "${cli} --caldav-url http://localhost:${port}/${user} calendar create cal" + ) + machine.succeed("test -d ${filesystem_folder}/collection-root/${user}/cal") + machine.succeed('test -z "$(ls ${filesystem_folder}/collection-root/${user}/cal)"') + machine.succeed( + "${cli} --caldav-url http://localhost:${port}/${user}/cal calendar add 2021-04-23 testevent" + ) + machine.succeed('test -n "$(ls ${filesystem_folder}/collection-root/${user}/cal)"') + (status, stdout) = machine.execute( + "sudo -u radicale git -C ${filesystem_folder} log --format=oneline | wc -l" + ) + assert status == 0, "git log failed" + assert stdout == "3\n", "there should be exactly 3 commits" - with subtest("Test rights file"): - machine.fail( - "${cli} --caldav-url http://localhost:${port}/${user} calendar create sub/cal" - ) - machine.fail( - "${cli} --caldav-url http://localhost:${port}/otheruser calendar create cal" - ) + with subtest("Test rights file"): + machine.fail( + "${cli} --caldav-url http://localhost:${port}/${user} calendar create sub/cal" + ) + machine.fail( + "${cli} --caldav-url http://localhost:${port}/otheruser calendar create cal" + ) - with subtest("Test web interface"): - machine.succeed("curl --fail http://${user}:${password}@localhost:${port}/.web/") + with subtest("Test web interface"): + machine.succeed("curl --fail http://${user}:${password}@localhost:${port}/.web/") - with subtest("Test security"): - output = machine.succeed("systemd-analyze security radicale.service") - machine.log(output) - assert output[-9:-1] == "SAFE :-}" - ''; -}) + with subtest("Test security"): + output = machine.succeed("systemd-analyze security radicale.service") + machine.log(output) + assert output[-9:-1] == "SAFE :-}" + ''; + } +) diff --git a/nixos/tests/radicle.nix b/nixos/tests/radicle.nix index b68cb7d716c233..397a3b5a7b8f1a 100644 --- a/nixos/tests/radicle.nix +++ b/nixos/tests/radicle.nix @@ -10,43 +10,54 @@ let seed-ssh-keys = import ./ssh-keys.nix pkgs; seed-tls-certs = import common/acme/server/snakeoil-certs.nix; - commonHostConfig = { nodes, config, pkgs, ... }: { - environment.systemPackages = [ - config.services.radicle.package - pkgs.curl - pkgs.gitMinimal - pkgs.jq - ]; - environment.etc."gitconfig".text = '' - [init] - defaultBranch = main - [user] - email = root@${config.networking.hostName} - name = ${config.networking.hostName} - ''; - networking = { - extraHosts = '' - ${nodes.seed.networking.primaryIPAddress} ${nodes.seed.services.radicle.httpd.nginx.serverName} + commonHostConfig = + { + nodes, + config, + pkgs, + ... + }: + { + environment.systemPackages = [ + config.services.radicle.package + pkgs.curl + pkgs.gitMinimal + pkgs.jq + ]; + environment.etc."gitconfig".text = '' + [init] + defaultBranch = main + [user] + email = root@${config.networking.hostName} + name = ${config.networking.hostName} ''; + networking = { + extraHosts = '' + ${nodes.seed.networking.primaryIPAddress} ${nodes.seed.services.radicle.httpd.nginx.serverName} + ''; + }; + security.pki.certificateFiles = [ + seed-tls-certs.ca.cert + ]; }; - security.pki.certificateFiles = [ - seed-tls-certs.ca.cert - ]; - }; - radicleConfig = { nodes, ... }: alias: - pkgs.writeText "config.json" (builtins.toJSON { - preferredSeeds = [ - "${seed-nid}@seed:${toString nodes.seed.services.radicle.node.listenPort}" - ]; - node = { - inherit alias; - relay = "never"; - seedingPolicy = { - default = "block"; + radicleConfig = + { nodes, ... }: + alias: + pkgs.writeText "config.json" ( + builtins.toJSON { + preferredSeeds = [ + "${seed-nid}@seed:${toString nodes.seed.services.radicle.node.listenPort}" + ]; + node = { + inherit alias; + relay = "never"; + seedingPolicy = { + default = "block"; + }; }; - }; - }); + } + ); in { @@ -60,43 +71,45 @@ in }; nodes = { - seed = { pkgs, config, ... }: { - imports = [ commonHostConfig ]; + seed = + { pkgs, config, ... }: + { + imports = [ commonHostConfig ]; - services.radicle = { - enable = true; - privateKeyFile = seed-ssh-keys.snakeOilEd25519PrivateKey; - publicKey = seed-ssh-keys.snakeOilEd25519PublicKey; - node = { - openFirewall = true; - }; - httpd = { + services.radicle = { enable = true; - nginx = { - serverName = seed-tls-certs.domain; - addSSL = true; - sslCertificate = seed-tls-certs.${seed-tls-certs.domain}.cert; - sslCertificateKey = seed-tls-certs.${seed-tls-certs.domain}.key; - }; - }; - settings = { - preferredSeeds = []; + privateKeyFile = seed-ssh-keys.snakeOilEd25519PrivateKey; + publicKey = seed-ssh-keys.snakeOilEd25519PublicKey; node = { - relay = "always"; - seedingPolicy = { - default = "allow"; - scope = "all"; + openFirewall = true; + }; + httpd = { + enable = true; + nginx = { + serverName = seed-tls-certs.domain; + addSSL = true; + sslCertificate = seed-tls-certs.${seed-tls-certs.domain}.cert; + sslCertificateKey = seed-tls-certs.${seed-tls-certs.domain}.key; + }; + }; + settings = { + preferredSeeds = [ ]; + node = { + relay = "always"; + seedingPolicy = { + default = "allow"; + scope = "all"; + }; }; }; }; - }; - services.nginx = { - enable = true; - }; + services.nginx = { + enable = true; + }; - networking.firewall.allowedTCPPorts = [ 443 ]; - }; + networking.firewall.allowedTCPPorts = [ 443 ]; + }; alice = { imports = [ commonHostConfig ]; @@ -107,101 +120,103 @@ in }; }; - testScript = { nodes, ... }@args: '' - start_all() - - with subtest("seed can run radicle-node"): - # The threshold and/or hardening may have to be changed with new features/checks - print(seed.succeed("systemd-analyze security radicle-node.service --threshold=10 --no-pager")) - seed.wait_for_unit("radicle-node.service") - seed.wait_for_open_port(${toString nodes.seed.services.radicle.node.listenPort}) - - with subtest("seed can run radicle-httpd"): - # The threshold and/or hardening may have to be changed with new features/checks - print(seed.succeed("systemd-analyze security radicle-httpd.service --threshold=10 --no-pager")) - seed.wait_for_unit("radicle-httpd.service") - seed.wait_for_open_port(${toString nodes.seed.services.radicle.httpd.listenPort}) - seed.wait_for_open_port(443) - assert alice.succeed("curl -sS 'https://${nodes.seed.services.radicle.httpd.nginx.serverName}/api/v1' | jq -r .nid") == "${seed-nid}\n" - assert bob.succeed("curl -sS 'https://${nodes.seed.services.radicle.httpd.nginx.serverName}/api/v1' | jq -r .nid") == "${seed-nid}\n" - - with subtest("alice can create a Node ID"): - alice.succeed("rad auth --alias alice --stdin /tmp/repo/testfile", - "git -C /tmp/repo add .", - "git -C /tmp/repo commit -m init" - ) - with subtest("alice can create a Repository ID"): - alice.succeed( - "cd /tmp/repo && rad init --name repo --description descr --default-branch main --public" - ) - alice_repo_rid=alice.succeed("cd /tmp/repo && rad inspect --rid").rstrip("\n") - with subtest("alice can send a repository to the seed"): - alice.succeed(f"rad sync --seed ${seed-nid} {alice_repo_rid}") - - with subtest(f"seed can receive the repository {alice_repo_rid}"): - seed.wait_until_succeeds("test 1 = \"$(rad-system stats | jq .local.repos)\"") - - with subtest("bob can create a Node ID"): - bob.succeed("rad auth --alias bob --stdin /tmp/repo/testfile", - "git -C /tmp/repo add .", - "git -C /tmp/repo commit -m 'hello to bob'", - "git -C /tmp/repo push rad main" - ) - with subtest("bob can sync bob's repository from the seed"): - bob.succeed( - "cd /tmp/repo && rad sync --seed ${seed-nid}", - "cd /tmp/repo && git pull" - ) - assert bob.succeed("cat /tmp/repo/testfile") == "hello bob\n" - - with subtest("bob can push a patch"): - bob.succeed( - "echo hello alice > /tmp/repo/testfile", - "git -C /tmp/repo checkout -b for-alice", - "git -C /tmp/repo add .", - "git -C /tmp/repo commit -m 'hello to alice'", - "git -C /tmp/repo push -o patch.message='hello for alice' rad HEAD:refs/patches" - ) - - bob_repo_patch1_pid=bob.succeed("cd /tmp/repo && git branch --remotes | sed -ne 's:^ *rad/patches/::'p").rstrip("\n") - with subtest("alice can receive the patch"): - alice.wait_until_succeeds("test 1 = \"$(rad stats | jq .local.patches)\"") - alice.succeed( - f"cd /tmp/repo && rad patch show {bob_repo_patch1_pid} | grep 'opened by bob'", - f"cd /tmp/repo && rad patch checkout {bob_repo_patch1_pid}" - ) - assert alice.succeed("cat /tmp/repo/testfile") == "hello alice\n" - with subtest("alice can comment the patch"): - alice.succeed( - f"cd /tmp/repo && rad patch comment {bob_repo_patch1_pid} -m thank-you" - ) - with subtest("alice can merge the patch"): - alice.succeed( - "git -C /tmp/repo checkout main", - f"git -C /tmp/repo merge patch/{bob_repo_patch1_pid[:7]}", - "git -C /tmp/repo push rad main", - "cd /tmp/repo && rad patch list | grep -qxF 'Nothing to show.'" - ) - ''; + testScript = + { nodes, ... }@args: + '' + start_all() + + with subtest("seed can run radicle-node"): + # The threshold and/or hardening may have to be changed with new features/checks + print(seed.succeed("systemd-analyze security radicle-node.service --threshold=10 --no-pager")) + seed.wait_for_unit("radicle-node.service") + seed.wait_for_open_port(${toString nodes.seed.services.radicle.node.listenPort}) + + with subtest("seed can run radicle-httpd"): + # The threshold and/or hardening may have to be changed with new features/checks + print(seed.succeed("systemd-analyze security radicle-httpd.service --threshold=10 --no-pager")) + seed.wait_for_unit("radicle-httpd.service") + seed.wait_for_open_port(${toString nodes.seed.services.radicle.httpd.listenPort}) + seed.wait_for_open_port(443) + assert alice.succeed("curl -sS 'https://${nodes.seed.services.radicle.httpd.nginx.serverName}/api/v1' | jq -r .nid") == "${seed-nid}\n" + assert bob.succeed("curl -sS 'https://${nodes.seed.services.radicle.httpd.nginx.serverName}/api/v1' | jq -r .nid") == "${seed-nid}\n" + + with subtest("alice can create a Node ID"): + alice.succeed("rad auth --alias alice --stdin /tmp/repo/testfile", + "git -C /tmp/repo add .", + "git -C /tmp/repo commit -m init" + ) + with subtest("alice can create a Repository ID"): + alice.succeed( + "cd /tmp/repo && rad init --name repo --description descr --default-branch main --public" + ) + alice_repo_rid=alice.succeed("cd /tmp/repo && rad inspect --rid").rstrip("\n") + with subtest("alice can send a repository to the seed"): + alice.succeed(f"rad sync --seed ${seed-nid} {alice_repo_rid}") + + with subtest(f"seed can receive the repository {alice_repo_rid}"): + seed.wait_until_succeeds("test 1 = \"$(rad-system stats | jq .local.repos)\"") + + with subtest("bob can create a Node ID"): + bob.succeed("rad auth --alias bob --stdin /tmp/repo/testfile", + "git -C /tmp/repo add .", + "git -C /tmp/repo commit -m 'hello to bob'", + "git -C /tmp/repo push rad main" + ) + with subtest("bob can sync bob's repository from the seed"): + bob.succeed( + "cd /tmp/repo && rad sync --seed ${seed-nid}", + "cd /tmp/repo && git pull" + ) + assert bob.succeed("cat /tmp/repo/testfile") == "hello bob\n" + + with subtest("bob can push a patch"): + bob.succeed( + "echo hello alice > /tmp/repo/testfile", + "git -C /tmp/repo checkout -b for-alice", + "git -C /tmp/repo add .", + "git -C /tmp/repo commit -m 'hello to alice'", + "git -C /tmp/repo push -o patch.message='hello for alice' rad HEAD:refs/patches" + ) + + bob_repo_patch1_pid=bob.succeed("cd /tmp/repo && git branch --remotes | sed -ne 's:^ *rad/patches/::'p").rstrip("\n") + with subtest("alice can receive the patch"): + alice.wait_until_succeeds("test 1 = \"$(rad stats | jq .local.patches)\"") + alice.succeed( + f"cd /tmp/repo && rad patch show {bob_repo_patch1_pid} | grep 'opened by bob'", + f"cd /tmp/repo && rad patch checkout {bob_repo_patch1_pid}" + ) + assert alice.succeed("cat /tmp/repo/testfile") == "hello alice\n" + with subtest("alice can comment the patch"): + alice.succeed( + f"cd /tmp/repo && rad patch comment {bob_repo_patch1_pid} -m thank-you" + ) + with subtest("alice can merge the patch"): + alice.succeed( + "git -C /tmp/repo checkout main", + f"git -C /tmp/repo merge patch/{bob_repo_patch1_pid[:7]}", + "git -C /tmp/repo push rad main", + "cd /tmp/repo && rad patch list | grep -qxF 'Nothing to show.'" + ) + ''; } diff --git a/nixos/tests/ragnarwm.nix b/nixos/tests/ragnarwm.nix index 6dc08a805ab126..d944fac4b910ce 100644 --- a/nixos/tests/ragnarwm.nix +++ b/nixos/tests/ragnarwm.nix @@ -1,32 +1,40 @@ -import ./make-test-python.nix ({ lib, ...} : { - name = "ragnarwm"; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "ragnarwm"; - meta = { - maintainers = with lib.maintainers; [ sigmanificient ]; - }; + meta = { + maintainers = with lib.maintainers; [ sigmanificient ]; + }; - nodes.machine = { pkgs, lib, ... }: { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - services.displayManager.defaultSession = lib.mkForce "ragnar"; - services.xserver.windowManager.ragnarwm.enable = true; + nodes.machine = + { pkgs, lib, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + services.displayManager.defaultSession = lib.mkForce "ragnar"; + services.xserver.windowManager.ragnarwm.enable = true; - # Setup the default terminal of Ragnar - environment.systemPackages = [ pkgs.alacritty ]; - }; + # Setup the default terminal of Ragnar + environment.systemPackages = [ pkgs.alacritty ]; + }; - testScript = '' - with subtest("ensure x starts"): - machine.wait_for_x() - machine.wait_for_file("/home/alice/.Xauthority") - machine.succeed("xauth merge ~alice/.Xauthority") + testScript = '' + with subtest("ensure x starts"): + machine.wait_for_x() + machine.wait_for_file("/home/alice/.Xauthority") + machine.succeed("xauth merge ~alice/.Xauthority") - with subtest("ensure we can open a new terminal"): - # Sleeping a bit before the test, as it may help for sending keys - machine.sleep(2) - machine.send_key("meta_l-ret") - machine.wait_for_window(r"alice.*?machine") - machine.sleep(2) - machine.screenshot("terminal") - ''; -}) + with subtest("ensure we can open a new terminal"): + # Sleeping a bit before the test, as it may help for sending keys + machine.sleep(2) + machine.send_key("meta_l-ret") + machine.wait_for_window(r"alice.*?machine") + machine.sleep(2) + machine.screenshot("terminal") + ''; + } +) diff --git a/nixos/tests/rasdaemon.nix b/nixos/tests/rasdaemon.nix index 7f30a3b81ab557..7eeb8b0aa6a13e 100644 --- a/nixos/tests/rasdaemon.nix +++ b/nixos/tests/rasdaemon.nix @@ -1,27 +1,30 @@ -import ./make-test-python.nix ({ pkgs, ... } : { - name = "rasdaemon"; - meta = with pkgs.lib.maintainers; { - maintainers = [ evils ]; - }; - - nodes.machine = { pkgs, ... }: { - imports = [ ../modules/profiles/minimal.nix ]; - hardware.rasdaemon = { - enable = true; - # should be enabled by default, just making sure - record = true; - # nonsense label - labels = '' - vendor: none - product: none - model: none - DIMM_0: 0.0.0; - ''; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "rasdaemon"; + meta = with pkgs.lib.maintainers; { + maintainers = [ evils ]; }; - }; - testScript = - '' + nodes.machine = + { pkgs, ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; + hardware.rasdaemon = { + enable = true; + # should be enabled by default, just making sure + record = true; + # nonsense label + labels = '' + vendor: none + product: none + model: none + DIMM_0: 0.0.0; + ''; + }; + }; + + testScript = '' start_all() machine.wait_for_unit("multi-user.target") # confirm rasdaemon is running and has a valid database @@ -31,4 +34,5 @@ import ./make-test-python.nix ({ pkgs, ... } : { machine.succeed("grep -q 'vendor: none' /etc/ras/dimm_labels.d/labels >&2") machine.shutdown() ''; -}) + } +) diff --git a/nixos/tests/readarr.nix b/nixos/tests/readarr.nix index 7c144e2ee02f5e..d6d5fdd586b5a3 100644 --- a/nixos/tests/readarr.nix +++ b/nixos/tests/readarr.nix @@ -1,14 +1,19 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "readarr"; - meta.maintainers = with lib.maintainers; [ jocelynthode ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "readarr"; + meta.maintainers = with lib.maintainers; [ jocelynthode ]; - nodes.machine = - { pkgs, ... }: - { services.readarr.enable = true; }; + nodes.machine = + { pkgs, ... }: + { + services.readarr.enable = true; + }; - testScript = '' - machine.wait_for_unit("readarr.service") - machine.wait_for_open_port(8787) - machine.succeed("curl --fail http://localhost:8787/") - ''; -}) + testScript = '' + machine.wait_for_unit("readarr.service") + machine.wait_for_open_port(8787) + machine.succeed("curl --fail http://localhost:8787/") + ''; + } +) diff --git a/nixos/tests/realm.nix b/nixos/tests/realm.nix index b39b0e0a161c7d..826dab61dbf2eb 100644 --- a/nixos/tests/realm.nix +++ b/nixos/tests/realm.nix @@ -1,39 +1,44 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "realm"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "realm"; - meta = { - maintainers = with lib.maintainers; [ ocfox ]; - }; - - nodes.machine = { pkgs, ... }: { - services.nginx = { - enable = true; - statusPage = true; + meta = { + maintainers = with lib.maintainers; [ ocfox ]; }; - # realm need DNS resolv server to run or use config.dns.nameserver - services.resolved.enable = true; - services.realm = { - enable = true; - config = { - endpoints = [ - { - listen = "0.0.0.0:1000"; - remote = "127.0.0.1:80"; - } - ]; + nodes.machine = + { pkgs, ... }: + { + services.nginx = { + enable = true; + statusPage = true; + }; + # realm need DNS resolv server to run or use config.dns.nameserver + services.resolved.enable = true; + + services.realm = { + enable = true; + config = { + endpoints = [ + { + listen = "0.0.0.0:1000"; + remote = "127.0.0.1:80"; + } + ]; + }; + }; }; - }; - }; - testScript = '' - machine.wait_for_unit("nginx.service") - machine.wait_for_unit("realm.service") + testScript = '' + machine.wait_for_unit("nginx.service") + machine.wait_for_unit("realm.service") - machine.wait_for_open_port(80) - machine.wait_for_open_port(1000) + machine.wait_for_open_port(80) + machine.wait_for_open_port(1000) - machine.succeed("curl --fail http://localhost:1000/") - ''; + machine.succeed("curl --fail http://localhost:1000/") + ''; -}) + } +) diff --git a/nixos/tests/redmine.nix b/nixos/tests/redmine.nix index 16fb2e2c64a610..1a002abfbfff5c 100644 --- a/nixos/tests/redmine.nix +++ b/nixos/tests/redmine.nix @@ -1,45 +1,61 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; with pkgs.lib; let - redmineTest = { name, type }: makeTest { - name = "redmine-${name}"; - nodes.machine = { config, pkgs, ... }: { - services.redmine = { - enable = true; - package = pkgs.redmine; - database.type = type; - plugins = { - redmine_env_auth = pkgs.fetchurl { - url = "https://github.com/Intera/redmine_env_auth/archive/0.7.zip"; - sha256 = "1xb8lyarc7mpi86yflnlgyllh9hfwb9z304f19dx409gqpia99sc"; + redmineTest = + { name, type }: + makeTest { + name = "redmine-${name}"; + nodes.machine = + { config, pkgs, ... }: + { + services.redmine = { + enable = true; + package = pkgs.redmine; + database.type = type; + plugins = { + redmine_env_auth = pkgs.fetchurl { + url = "https://github.com/Intera/redmine_env_auth/archive/0.7.zip"; + sha256 = "1xb8lyarc7mpi86yflnlgyllh9hfwb9z304f19dx409gqpia99sc"; + }; + }; + themes = { + dkuk-redmine_alex_skin = pkgs.fetchurl { + url = "https://bitbucket.org/dkuk/redmine_alex_skin/get/1842ef675ef3.zip"; + sha256 = "0hrin9lzyi50k4w2bd2b30vrf1i4fi1c0gyas5801wn8i7kpm9yl"; + }; + }; }; }; - themes = { - dkuk-redmine_alex_skin = pkgs.fetchurl { - url = "https://bitbucket.org/dkuk/redmine_alex_skin/get/1842ef675ef3.zip"; - sha256 = "0hrin9lzyi50k4w2bd2b30vrf1i4fi1c0gyas5801wn8i7kpm9yl"; - }; - }; - }; - }; - testScript = '' - start_all() - machine.wait_for_unit("redmine.service") - machine.wait_for_open_port(3000) - machine.succeed("curl --fail http://localhost:3000/") - ''; - } // { - meta.maintainers = [ maintainers.aanderse ]; + testScript = '' + start_all() + machine.wait_for_unit("redmine.service") + machine.wait_for_open_port(3000) + machine.succeed("curl --fail http://localhost:3000/") + ''; + } + // { + meta.maintainers = [ maintainers.aanderse ]; + }; +in +{ + sqlite3 = redmineTest { + name = "sqlite3"; + type = "sqlite3"; + }; + mysql = redmineTest { + name = "mysql"; + type = "mysql2"; + }; + pgsql = redmineTest { + name = "pgsql"; + type = "postgresql"; }; -in { - sqlite3 = redmineTest { name = "sqlite3"; type = "sqlite3"; }; - mysql = redmineTest { name = "mysql"; type = "mysql2"; }; - pgsql = redmineTest { name = "pgsql"; type = "postgresql"; }; } diff --git a/nixos/tests/restart-by-activation-script.nix b/nixos/tests/restart-by-activation-script.nix index fdab892b721830..cf89aa341adab3 100644 --- a/nixos/tests/restart-by-activation-script.nix +++ b/nixos/tests/restart-by-activation-script.nix @@ -1,75 +1,81 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "restart-by-activation-script"; - meta = with pkgs.lib.maintainers; { - maintainers = [ das_j ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "restart-by-activation-script"; + meta = with pkgs.lib.maintainers; { + maintainers = [ das_j ]; + }; - nodes.machine = { pkgs, ... }: { - imports = [ ../modules/profiles/minimal.nix ]; + nodes.machine = + { pkgs, ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; - system.switch.enable = true; + system.switch.enable = true; - systemd.services.restart-me = { - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - Type = "oneshot"; - RemainAfterExit = true; - ExecStart = "${pkgs.coreutils}/bin/true"; - }; - }; + systemd.services.restart-me = { + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + Type = "oneshot"; + RemainAfterExit = true; + ExecStart = "${pkgs.coreutils}/bin/true"; + }; + }; - systemd.services.reload-me = { - wantedBy = [ "multi-user.target" ]; - serviceConfig = rec { - Type = "oneshot"; - RemainAfterExit = true; - ExecStart = "${pkgs.coreutils}/bin/true"; - ExecReload = ExecStart; - }; - }; + systemd.services.reload-me = { + wantedBy = [ "multi-user.target" ]; + serviceConfig = rec { + Type = "oneshot"; + RemainAfterExit = true; + ExecStart = "${pkgs.coreutils}/bin/true"; + ExecReload = ExecStart; + }; + }; - system.activationScripts.test = { - supportsDryActivation = true; - text = '' - if [ -e /test-the-activation-script ]; then - if [ "$NIXOS_ACTION" != dry-activate ]; then - touch /activation-was-run - echo restart-me.service > /run/nixos/activation-restart-list - echo reload-me.service > /run/nixos/activation-reload-list - else - echo restart-me.service > /run/nixos/dry-activation-restart-list - echo reload-me.service > /run/nixos/dry-activation-reload-list - fi - fi - ''; - }; - }; + system.activationScripts.test = { + supportsDryActivation = true; + text = '' + if [ -e /test-the-activation-script ]; then + if [ "$NIXOS_ACTION" != dry-activate ]; then + touch /activation-was-run + echo restart-me.service > /run/nixos/activation-restart-list + echo reload-me.service > /run/nixos/activation-reload-list + else + echo restart-me.service > /run/nixos/dry-activation-restart-list + echo reload-me.service > /run/nixos/dry-activation-reload-list + fi + fi + ''; + }; + }; - testScript = /* python */ '' - machine.wait_for_unit("multi-user.target") + testScript = # python + '' + machine.wait_for_unit("multi-user.target") - with subtest("nothing happens when the activation script does nothing"): - out = machine.succeed("/run/current-system/bin/switch-to-configuration dry-activate 2>&1") - assert 'restart' not in out - assert 'reload' not in out - out = machine.succeed("/run/current-system/bin/switch-to-configuration test") - assert 'restart' not in out - assert 'reload' not in out + with subtest("nothing happens when the activation script does nothing"): + out = machine.succeed("/run/current-system/bin/switch-to-configuration dry-activate 2>&1") + assert 'restart' not in out + assert 'reload' not in out + out = machine.succeed("/run/current-system/bin/switch-to-configuration test") + assert 'restart' not in out + assert 'reload' not in out - machine.succeed("touch /test-the-activation-script") + machine.succeed("touch /test-the-activation-script") - with subtest("dry activation"): - out = machine.succeed("/run/current-system/bin/switch-to-configuration dry-activate 2>&1") - assert 'would restart the following units: restart-me.service' in out - assert 'would reload the following units: reload-me.service' in out - machine.fail("test -f /run/nixos/dry-activation-restart-list") - machine.fail("test -f /run/nixos/dry-activation-reload-list") + with subtest("dry activation"): + out = machine.succeed("/run/current-system/bin/switch-to-configuration dry-activate 2>&1") + assert 'would restart the following units: restart-me.service' in out + assert 'would reload the following units: reload-me.service' in out + machine.fail("test -f /run/nixos/dry-activation-restart-list") + machine.fail("test -f /run/nixos/dry-activation-reload-list") - with subtest("real activation"): - out = machine.succeed("/run/current-system/bin/switch-to-configuration test 2>&1") - assert 'restarting the following units: restart-me.service' in out - assert 'reloading the following units: reload-me.service' in out - machine.fail("test -f /run/nixos/activation-restart-list") - machine.fail("test -f /run/nixos/activation-reload-list") - ''; -}) + with subtest("real activation"): + out = machine.succeed("/run/current-system/bin/switch-to-configuration test 2>&1") + assert 'restarting the following units: restart-me.service' in out + assert 'reloading the following units: reload-me.service' in out + machine.fail("test -f /run/nixos/activation-restart-list") + machine.fail("test -f /run/nixos/activation-reload-list") + ''; + } +) diff --git a/nixos/tests/restic-rest-server.nix b/nixos/tests/restic-rest-server.nix index 1d38ddbe513c96..ecca1bf83af3e0 100644 --- a/nixos/tests/restic-rest-server.nix +++ b/nixos/tests/restic-rest-server.nix @@ -51,7 +51,14 @@ import ./make-test-python.nix ( server = { services.restic.backups = { remotebackup = { - inherit passwordFile paths exclude pruneOpts backupPrepareCommand backupCleanupCommand; + inherit + passwordFile + paths + exclude + pruneOpts + backupPrepareCommand + backupCleanupCommand + ; repository = remoteRepository; initialize = true; timerConfig = null; # has no effect here, just checking that it doesn't break the service diff --git a/nixos/tests/rke2/default.nix b/nixos/tests/rke2/default.nix index e8a5f382b735f7..90415a262acffa 100644 --- a/nixos/tests/rke2/default.nix +++ b/nixos/tests/rke2/default.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem -, pkgs ? import ../../.. { inherit system; } -, lib ? pkgs.lib +{ + system ? builtins.currentSystem, + pkgs ? import ../../.. { inherit system; }, + lib ? pkgs.lib, }: let allRKE2 = lib.filterAttrs (n: _: lib.strings.hasPrefix "rke2" n) pkgs; diff --git a/nixos/tests/rke2/multi-node.nix b/nixos/tests/rke2/multi-node.nix index ddf0b60f6fba47..57447388290b09 100644 --- a/nixos/tests/rke2/multi-node.nix +++ b/nixos/tests/rke2/multi-node.nix @@ -1,13 +1,29 @@ -import ../make-test-python.nix ({ pkgs, lib, rke2, ... }: +import ../make-test-python.nix ( + { + pkgs, + lib, + rke2, + ... + }: let pauseImage = pkgs.dockerTools.streamLayeredImage { name = "test.local/pause"; tag = "local"; contents = pkgs.buildEnv { name = "rke2-pause-image-env"; - paths = with pkgs; [ tini bashInteractive coreutils socat ]; + paths = with pkgs; [ + tini + bashInteractive + coreutils + socat + ]; }; - config.Entrypoint = [ "/bin/tini" "--" "/bin/sleep" "inf" ]; + config.Entrypoint = [ + "/bin/tini" + "--" + "/bin/sleep" + "inf" + ]; }; # A daemonset that responds 'server' on port 8000 networkTestDaemonset = pkgs.writeText "test.yml" '' @@ -43,134 +59,152 @@ import ../make-test-python.nix ({ pkgs, lib, rke2, ... }: meta.maintainers = rke2.meta.maintainers; nodes = { - server1 = { pkgs, ... }: { - networking.firewall.enable = false; - networking.useDHCP = false; - networking.defaultGateway = "192.168.1.1"; - networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkForce [ - { address = "192.168.1.1"; prefixLength = 24; } - ]; - - virtualisation.memorySize = 1536; - virtualisation.diskSize = 4096; - - services.rke2 = { - enable = true; - role = "server"; - inherit tokenFile; - inherit agentTokenFile; - nodeName = "${rke2.name}-server1"; - package = rke2; - nodeIP = "192.168.1.1"; - disable = [ - "rke2-coredns" - "rke2-metrics-server" - "rke2-ingress-nginx" + server1 = + { pkgs, ... }: + { + networking.firewall.enable = false; + networking.useDHCP = false; + networking.defaultGateway = "192.168.1.1"; + networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkForce [ + { + address = "192.168.1.1"; + prefixLength = 24; + } ]; - extraFlags = [ - "--cluster-reset" - ]; - }; - }; - server2 = { pkgs, ... }: { - networking.firewall.enable = false; - networking.useDHCP = false; - networking.defaultGateway = "192.168.1.2"; - networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkForce [ - { address = "192.168.1.2"; prefixLength = 24; } - ]; + virtualisation.memorySize = 1536; + virtualisation.diskSize = 4096; + + services.rke2 = { + enable = true; + role = "server"; + inherit tokenFile; + inherit agentTokenFile; + nodeName = "${rke2.name}-server1"; + package = rke2; + nodeIP = "192.168.1.1"; + disable = [ + "rke2-coredns" + "rke2-metrics-server" + "rke2-ingress-nginx" + ]; + extraFlags = [ + "--cluster-reset" + ]; + }; + }; - virtualisation.memorySize = 1536; - virtualisation.diskSize = 4096; - - services.rke2 = { - enable = true; - role = "server"; - serverAddr = "https://192.168.1.1:6443"; - inherit tokenFile; - inherit agentTokenFile; - nodeName = "${rke2.name}-server2"; - package = rke2; - nodeIP = "192.168.1.2"; - disable = [ - "rke2-coredns" - "rke2-metrics-server" - "rke2-ingress-nginx" + server2 = + { pkgs, ... }: + { + networking.firewall.enable = false; + networking.useDHCP = false; + networking.defaultGateway = "192.168.1.2"; + networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkForce [ + { + address = "192.168.1.2"; + prefixLength = 24; + } ]; + + virtualisation.memorySize = 1536; + virtualisation.diskSize = 4096; + + services.rke2 = { + enable = true; + role = "server"; + serverAddr = "https://192.168.1.1:6443"; + inherit tokenFile; + inherit agentTokenFile; + nodeName = "${rke2.name}-server2"; + package = rke2; + nodeIP = "192.168.1.2"; + disable = [ + "rke2-coredns" + "rke2-metrics-server" + "rke2-ingress-nginx" + ]; + }; }; - }; - agent1 = { pkgs, ... }: { - networking.firewall.enable = false; - networking.useDHCP = false; - networking.defaultGateway = "192.168.1.3"; - networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkForce [ - { address = "192.168.1.3"; prefixLength = 24; } - ]; + agent1 = + { pkgs, ... }: + { + networking.firewall.enable = false; + networking.useDHCP = false; + networking.defaultGateway = "192.168.1.3"; + networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkForce [ + { + address = "192.168.1.3"; + prefixLength = 24; + } + ]; - virtualisation.memorySize = 1536; - virtualisation.diskSize = 4096; - - services.rke2 = { - enable = true; - role = "agent"; - tokenFile = agentTokenFile; - serverAddr = "https://192.168.1.2:6443"; - nodeName = "${rke2.name}-agent1"; - package = rke2; - nodeIP = "192.168.1.3"; + virtualisation.memorySize = 1536; + virtualisation.diskSize = 4096; + + services.rke2 = { + enable = true; + role = "agent"; + tokenFile = agentTokenFile; + serverAddr = "https://192.168.1.2:6443"; + nodeName = "${rke2.name}-agent1"; + package = rke2; + nodeIP = "192.168.1.3"; + }; }; - }; }; - testScript = let - kubectl = "${pkgs.kubectl}/bin/kubectl --kubeconfig=/etc/rancher/rke2/rke2.yaml"; - ctr = "${pkgs.containerd}/bin/ctr -a /run/k3s/containerd/containerd.sock"; - jq = "${pkgs.jq}/bin/jq"; - ping = "${pkgs.iputils}/bin/ping"; - in '' - machines = [server1, server2, agent1] - - for machine in machines: - machine.start() - machine.wait_for_unit("rke2") - - # wait for the agent to show up - server1.succeed("${kubectl} get node ${rke2.name}-agent1") - - for machine in machines: - machine.succeed("${pauseImage} | ${ctr} image import -") - - server1.succeed("${kubectl} cluster-info") - server1.wait_until_succeeds("${kubectl} get serviceaccount default") - - # Now create a pod on each node via a daemonset and verify they can talk to each other. - server1.succeed("${kubectl} apply -f ${networkTestDaemonset}") - server1.wait_until_succeeds( - f'[ "$(${kubectl} get ds test -o json | ${jq} .status.numberReady)" -eq {len(machines)} ]' - ) - - # Get pod IPs - pods = server1.succeed("${kubectl} get po -o json | ${jq} '.items[].metadata.name' -r").splitlines() - pod_ips = [ - server1.succeed(f"${kubectl} get po {n} -o json | ${jq} '.status.podIP' -cr").strip() for n in pods - ] - - # Verify each server can ping each pod ip - for pod_ip in pod_ips: - server1.succeed(f"${ping} -c 1 {pod_ip}") - agent1.succeed(f"${ping} -c 1 {pod_ip}") - - # Verify the pods can talk to each other - resp = server1.wait_until_succeeds(f"${kubectl} exec {pods[0]} -- socat TCP:{pod_ips[1]}:8000 -") - assert resp.strip() == "server" - resp = server1.wait_until_succeeds(f"${kubectl} exec {pods[1]} -- socat TCP:{pod_ips[0]}:8000 -") - assert resp.strip() == "server" - - # Cleanup - server1.succeed("${kubectl} delete -f ${networkTestDaemonset}") - for machine in machines: - machine.shutdown() - ''; - }) + testScript = + let + kubectl = "${pkgs.kubectl}/bin/kubectl --kubeconfig=/etc/rancher/rke2/rke2.yaml"; + ctr = "${pkgs.containerd}/bin/ctr -a /run/k3s/containerd/containerd.sock"; + jq = "${pkgs.jq}/bin/jq"; + ping = "${pkgs.iputils}/bin/ping"; + in + '' + machines = [server1, server2, agent1] + + for machine in machines: + machine.start() + machine.wait_for_unit("rke2") + + # wait for the agent to show up + server1.succeed("${kubectl} get node ${rke2.name}-agent1") + + for machine in machines: + machine.succeed("${pauseImage} | ${ctr} image import -") + + server1.succeed("${kubectl} cluster-info") + server1.wait_until_succeeds("${kubectl} get serviceaccount default") + + # Now create a pod on each node via a daemonset and verify they can talk to each other. + server1.succeed("${kubectl} apply -f ${networkTestDaemonset}") + server1.wait_until_succeeds( + f'[ "$(${kubectl} get ds test -o json | ${jq} .status.numberReady)" -eq {len(machines)} ]' + ) + + # Get pod IPs + pods = server1.succeed("${kubectl} get po -o json | ${jq} '.items[].metadata.name' -r").splitlines() + pod_ips = [ + server1.succeed(f"${kubectl} get po {n} -o json | ${jq} '.status.podIP' -cr").strip() for n in pods + ] + + # Verify each server can ping each pod ip + for pod_ip in pod_ips: + server1.succeed(f"${ping} -c 1 {pod_ip}") + agent1.succeed(f"${ping} -c 1 {pod_ip}") + + # Verify the pods can talk to each other + resp = server1.wait_until_succeeds(f"${kubectl} exec {pods[0]} -- socat TCP:{pod_ips[1]}:8000 -") + assert resp.strip() == "server" + resp = server1.wait_until_succeeds(f"${kubectl} exec {pods[1]} -- socat TCP:{pod_ips[0]}:8000 -") + assert resp.strip() == "server" + + # Cleanup + server1.succeed("${kubectl} delete -f ${networkTestDaemonset}") + for machine in machines: + machine.shutdown() + ''; + } +) diff --git a/nixos/tests/rke2/single-node.nix b/nixos/tests/rke2/single-node.nix index 5a512eacca0f19..32a90e17f58fc3 100644 --- a/nixos/tests/rke2/single-node.nix +++ b/nixos/tests/rke2/single-node.nix @@ -1,13 +1,28 @@ -import ../make-test-python.nix ({ pkgs, lib, rke2, ... }: +import ../make-test-python.nix ( + { + pkgs, + lib, + rke2, + ... + }: let pauseImage = pkgs.dockerTools.streamLayeredImage { name = "test.local/pause"; tag = "local"; contents = pkgs.buildEnv { name = "rke2-pause-image-env"; - paths = with pkgs; [ tini (hiPrio coreutils) busybox ]; + paths = with pkgs; [ + tini + (hiPrio coreutils) + busybox + ]; }; - config.Entrypoint = [ "/bin/tini" "--" "/bin/sleep" "inf" ]; + config.Entrypoint = [ + "/bin/tini" + "--" + "/bin/sleep" + "inf" + ]; }; testPodYaml = pkgs.writeText "test.yaml" '' apiVersion: v1 @@ -26,50 +41,58 @@ import ../make-test-python.nix ({ pkgs, lib, rke2, ... }: name = "${rke2.name}-single-node"; meta.maintainers = rke2.meta.maintainers; - nodes.machine = { pkgs, ... }: { - networking.firewall.enable = false; - networking.useDHCP = false; - networking.defaultGateway = "192.168.1.1"; - networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkForce [ - { address = "192.168.1.1"; prefixLength = 24; } - ]; + nodes.machine = + { pkgs, ... }: + { + networking.firewall.enable = false; + networking.useDHCP = false; + networking.defaultGateway = "192.168.1.1"; + networking.interfaces.eth1.ipv4.addresses = pkgs.lib.mkForce [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; - virtualisation.memorySize = 1536; - virtualisation.diskSize = 4096; + virtualisation.memorySize = 1536; + virtualisation.diskSize = 4096; - services.rke2 = { - enable = true; - role = "server"; - package = rke2; - nodeIP = "192.168.1.1"; - disable = [ - "rke2-coredns" - "rke2-metrics-server" - "rke2-ingress-nginx" - ]; - extraFlags = [ - "--cluster-reset" - ]; + services.rke2 = { + enable = true; + role = "server"; + package = rke2; + nodeIP = "192.168.1.1"; + disable = [ + "rke2-coredns" + "rke2-metrics-server" + "rke2-ingress-nginx" + ]; + extraFlags = [ + "--cluster-reset" + ]; + }; }; - }; - testScript = let - kubectl = "${pkgs.kubectl}/bin/kubectl --kubeconfig=/etc/rancher/rke2/rke2.yaml"; - ctr = "${pkgs.containerd}/bin/ctr -a /run/k3s/containerd/containerd.sock"; - in '' - start_all() + testScript = + let + kubectl = "${pkgs.kubectl}/bin/kubectl --kubeconfig=/etc/rancher/rke2/rke2.yaml"; + ctr = "${pkgs.containerd}/bin/ctr -a /run/k3s/containerd/containerd.sock"; + in + '' + start_all() - machine.wait_for_unit("rke2") - machine.succeed("${kubectl} cluster-info") - machine.wait_until_succeeds( - "${pauseImage} | ${ctr} -n k8s.io image import -" - ) + machine.wait_for_unit("rke2") + machine.succeed("${kubectl} cluster-info") + machine.wait_until_succeeds( + "${pauseImage} | ${ctr} -n k8s.io image import -" + ) - machine.wait_until_succeeds("${kubectl} get serviceaccount default") - machine.succeed("${kubectl} apply -f ${testPodYaml}") - machine.succeed("${kubectl} wait --for 'condition=Ready' pod/test") - machine.succeed("${kubectl} delete -f ${testPodYaml}") + machine.wait_until_succeeds("${kubectl} get serviceaccount default") + machine.succeed("${kubectl} apply -f ${testPodYaml}") + machine.succeed("${kubectl} wait --for 'condition=Ready' pod/test") + machine.succeed("${kubectl} delete -f ${testPodYaml}") - machine.shutdown() - ''; - }) + machine.shutdown() + ''; + } +) diff --git a/nixos/tests/rkvm/default.nix b/nixos/tests/rkvm/default.nix index 22425948d8bf91..3c126f41f9293c 100644 --- a/nixos/tests/rkvm/default.nix +++ b/nixos/tests/rkvm/default.nix @@ -1,104 +1,113 @@ -import ../make-test-python.nix ({ pkgs, ... }: -let - # Generated with - # - # nix shell .#rkvm --command "rkvm-certificate-gen --ip-addresses 10.0.0.1 cert.pem key.pem" - # - snakeoil-cert = ./cert.pem; - snakeoil-key = ./key.pem; -in -{ - name = "rkvm"; - - nodes = { - server = { pkgs, ... }: { - imports = [ ../common/user-account.nix ]; - - virtualisation.vlans = [ 1 ]; - - networking = { - useNetworkd = true; - useDHCP = false; - firewall.enable = false; - }; - - systemd.network.networks."01-eth1" = { - name = "eth1"; - networkConfig.Address = "10.0.0.1/24"; - }; - - services.getty.autologinUser = "alice"; - - services.rkvm.server = { - enable = true; - settings = { - certificate = snakeoil-cert; - key = snakeoil-key; - password = "snakeoil"; - switch-keys = [ "left-alt" "right-alt" ]; +import ../make-test-python.nix ( + { pkgs, ... }: + let + # Generated with + # + # nix shell .#rkvm --command "rkvm-certificate-gen --ip-addresses 10.0.0.1 cert.pem key.pem" + # + snakeoil-cert = ./cert.pem; + snakeoil-key = ./key.pem; + in + { + name = "rkvm"; + + nodes = { + server = + { pkgs, ... }: + { + imports = [ ../common/user-account.nix ]; + + virtualisation.vlans = [ 1 ]; + + networking = { + useNetworkd = true; + useDHCP = false; + firewall.enable = false; + }; + + systemd.network.networks."01-eth1" = { + name = "eth1"; + networkConfig.Address = "10.0.0.1/24"; + }; + + services.getty.autologinUser = "alice"; + + services.rkvm.server = { + enable = true; + settings = { + certificate = snakeoil-cert; + key = snakeoil-key; + password = "snakeoil"; + switch-keys = [ + "left-alt" + "right-alt" + ]; + }; + }; }; - }; - }; - - client = { pkgs, ... }: { - imports = [ ../common/user-account.nix ]; - - virtualisation.vlans = [ 1 ]; - - networking = { - useNetworkd = true; - useDHCP = false; - firewall.enable = false; - }; - - systemd.network.networks."01-eth1" = { - name = "eth1"; - networkConfig.Address = "10.0.0.2/24"; - }; - - services.getty.autologinUser = "alice"; - services.rkvm.client = { - enable = true; - settings = { - server = "10.0.0.1:5258"; - certificate = snakeoil-cert; - key = snakeoil-key; - password = "snakeoil"; + client = + { pkgs, ... }: + { + imports = [ ../common/user-account.nix ]; + + virtualisation.vlans = [ 1 ]; + + networking = { + useNetworkd = true; + useDHCP = false; + firewall.enable = false; + }; + + systemd.network.networks."01-eth1" = { + name = "eth1"; + networkConfig.Address = "10.0.0.2/24"; + }; + + services.getty.autologinUser = "alice"; + + services.rkvm.client = { + enable = true; + settings = { + server = "10.0.0.1:5258"; + certificate = snakeoil-cert; + key = snakeoil-key; + password = "snakeoil"; + }; + }; }; - }; }; - }; - testScript = '' - server.wait_for_unit("getty@tty1.service") - server.wait_until_succeeds("pgrep -f 'agetty.*tty1'") - server.wait_for_unit("rkvm-server") - server.wait_for_open_port(5258) + testScript = '' + server.wait_for_unit("getty@tty1.service") + server.wait_until_succeeds("pgrep -f 'agetty.*tty1'") + server.wait_for_unit("rkvm-server") + server.wait_for_open_port(5258) - client.wait_for_unit("getty@tty1.service") - client.wait_until_succeeds("pgrep -f 'agetty.*tty1'") - client.wait_for_unit("rkvm-client") + client.wait_for_unit("getty@tty1.service") + client.wait_until_succeeds("pgrep -f 'agetty.*tty1'") + client.wait_for_unit("rkvm-client") - server.sleep(1) + server.sleep(1) - # Switch to client - server.send_key("alt-alt_r", delay=0.2) - server.send_chars("echo 'hello client' > /tmp/test.txt\n") + # Switch to client + server.send_key("alt-alt_r", delay=0.2) + server.send_chars("echo 'hello client' > /tmp/test.txt\n") - # Switch to server - server.send_key("alt-alt_r", delay=0.2) - server.send_chars("echo 'hello server' > /tmp/test.txt\n") + # Switch to server + server.send_key("alt-alt_r", delay=0.2) + server.send_chars("echo 'hello server' > /tmp/test.txt\n") - server.sleep(1) + server.sleep(1) - client.systemctl("stop rkvm-client.service") - server.systemctl("stop rkvm-server.service") + client.systemctl("stop rkvm-client.service") + server.systemctl("stop rkvm-server.service") - server_file = server.succeed("cat /tmp/test.txt") - assert server_file.strip() == "hello server" + server_file = server.succeed("cat /tmp/test.txt") + assert server_file.strip() == "hello server" - client_file = client.succeed("cat /tmp/test.txt") - assert client_file.strip() == "hello client" - ''; -}) + client_file = client.succeed("cat /tmp/test.txt") + assert client_file.strip() == "hello client" + ''; + } +) diff --git a/nixos/tests/robustirc-bridge.nix b/nixos/tests/robustirc-bridge.nix index 8493fd6282128c..31b4240f983649 100644 --- a/nixos/tests/robustirc-bridge.nix +++ b/nixos/tests/robustirc-bridge.nix @@ -1,14 +1,15 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -{ - name = "robustirc-bridge"; - meta = with pkgs.lib.maintainers; { - maintainers = [ hax404 ]; - }; + { + name = "robustirc-bridge"; + meta = with pkgs.lib.maintainers; { + maintainers = [ hax404 ]; + }; - nodes = - { bridge = - { services.robustirc-bridge = { + nodes = { + bridge = { + services.robustirc-bridge = { enable = true; extraFlags = [ "-listen localhost:6667" @@ -18,12 +19,12 @@ import ./make-test-python.nix ({ pkgs, ... }: }; }; - testScript = - '' + testScript = '' start_all() bridge.wait_for_unit("robustirc-bridge.service") bridge.wait_for_open_port(1080) bridge.wait_for_open_port(6667) ''; -}) + } +) diff --git a/nixos/tests/rosenpass.nix b/nixos/tests/rosenpass.nix index 5ef6e55f537461..cb0937b58971cb 100644 --- a/nixos/tests/rosenpass.nix +++ b/nixos/tests/rosenpass.nix @@ -1,214 +1,223 @@ -import ./make-test-python.nix ({ pkgs, ... }: -let - deviceName = "rp0"; - - server = { - ip = "fe80::1"; - wg = { - public = "mQufmDFeQQuU/fIaB2hHgluhjjm1ypK4hJr1cW3WqAw="; - secret = "4N5Y1dldqrpsbaEiY8O0XBUGUFf8vkvtBtm8AoOX7Eo="; - listen = 10000; +import ./make-test-python.nix ( + { pkgs, ... }: + let + deviceName = "rp0"; + + server = { + ip = "fe80::1"; + wg = { + public = "mQufmDFeQQuU/fIaB2hHgluhjjm1ypK4hJr1cW3WqAw="; + secret = "4N5Y1dldqrpsbaEiY8O0XBUGUFf8vkvtBtm8AoOX7Eo="; + listen = 10000; + }; }; - }; - client = { - ip = "fe80::2"; - wg = { - public = "Mb3GOlT7oS+F3JntVKiaD7SpHxLxNdtEmWz/9FMnRFU="; - secret = "uC5dfGMv7Oxf5UDfdPkj6rZiRZT2dRWp5x8IQxrNcUE="; + client = { + ip = "fe80::2"; + wg = { + public = "Mb3GOlT7oS+F3JntVKiaD7SpHxLxNdtEmWz/9FMnRFU="; + secret = "uC5dfGMv7Oxf5UDfdPkj6rZiRZT2dRWp5x8IQxrNcUE="; + }; }; - }; -in -{ - name = "rosenpass"; - - nodes = - let - shared = peer: { config, modulesPath, ... }: { - imports = [ "${modulesPath}/services/networking/rosenpass.nix" ]; + in + { + name = "rosenpass"; + + nodes = + let + shared = + peer: + { config, modulesPath, ... }: + { + imports = [ "${modulesPath}/services/networking/rosenpass.nix" ]; + + boot.kernelModules = [ "wireguard" ]; + + services.rosenpass = { + enable = true; + defaultDevice = deviceName; + settings = { + verbosity = "Verbose"; + public_key = "/etc/rosenpass/pqpk"; + secret_key = "/etc/rosenpass/pqsk"; + }; + }; - boot.kernelModules = [ "wireguard" ]; + networking.firewall.allowedUDPPorts = [ 9999 ]; + + systemd.network = { + enable = true; + networks."rosenpass" = { + matchConfig.Name = deviceName; + networkConfig.IPv4Forwarding = true; + networkConfig.IPv6Forwarding = true; + address = [ "${peer.ip}/64" ]; + }; + + netdevs."10-rp0" = { + netdevConfig = { + Kind = "wireguard"; + Name = deviceName; + }; + wireguardConfig.PrivateKeyFile = "/etc/wireguard/wgsk"; + }; + }; - services.rosenpass = { - enable = true; - defaultDevice = deviceName; - settings = { - verbosity = "Verbose"; - public_key = "/etc/rosenpass/pqpk"; - secret_key = "/etc/rosenpass/pqsk"; + environment.etc."wireguard/wgsk" = { + text = peer.wg.secret; + user = "systemd-network"; + group = "systemd-network"; + }; }; - }; - - networking.firewall.allowedUDPPorts = [ 9999 ]; - - systemd.network = { - enable = true; - networks."rosenpass" = { - matchConfig.Name = deviceName; - networkConfig.IPv4Forwarding = true; - networkConfig.IPv6Forwarding = true; - address = [ "${peer.ip}/64" ]; + in + { + server = { + imports = [ (shared server) ]; + + networking.firewall.allowedUDPPorts = [ server.wg.listen ]; + + systemd.network.netdevs."10-${deviceName}" = { + wireguardConfig.ListenPort = server.wg.listen; + wireguardPeers = [ + { + AllowedIPs = [ "::/0" ]; + PublicKey = client.wg.public; + } + ]; }; - netdevs."10-rp0" = { - netdevConfig = { - Kind = "wireguard"; - Name = deviceName; - }; - wireguardConfig.PrivateKeyFile = "/etc/wireguard/wgsk"; + services.rosenpass.settings = { + listen = [ "0.0.0.0:9999" ]; + peers = [ + { + public_key = "/etc/rosenpass/peers/client/pqpk"; + peer = client.wg.public; + } + ]; }; }; + client = { + imports = [ (shared client) ]; - environment.etc."wireguard/wgsk" = { - text = peer.wg.secret; - user = "systemd-network"; - group = "systemd-network"; - }; - }; - in - { - server = { - imports = [ (shared server) ]; - - networking.firewall.allowedUDPPorts = [ server.wg.listen ]; - - systemd.network.netdevs."10-${deviceName}" = { - wireguardConfig.ListenPort = server.wg.listen; - wireguardPeers = [ + systemd.network.netdevs."10-${deviceName}".wireguardPeers = [ { AllowedIPs = [ "::/0" ]; - PublicKey = client.wg.public; + PublicKey = server.wg.public; + Endpoint = "server:${builtins.toString server.wg.listen}"; } ]; - }; - services.rosenpass.settings = { - listen = [ "0.0.0.0:9999" ]; - peers = [ + services.rosenpass.settings.peers = [ { - public_key = "/etc/rosenpass/peers/client/pqpk"; - peer = client.wg.public; + public_key = "/etc/rosenpass/peers/server/pqpk"; + endpoint = "server:9999"; + peer = server.wg.public; } ]; }; }; - client = { - imports = [ (shared client) ]; - - systemd.network.netdevs."10-${deviceName}".wireguardPeers = [ - { - AllowedIPs = [ "::/0" ]; - PublicKey = server.wg.public; - Endpoint = "server:${builtins.toString server.wg.listen}"; - } - ]; - - services.rosenpass.settings.peers = [ - { - public_key = "/etc/rosenpass/peers/server/pqpk"; - endpoint = "server:9999"; - peer = server.wg.public; - } - ]; - }; - }; - testScript = { ... }: '' - from os import system + testScript = + { ... }: + '' + from os import system - # Full path to rosenpass in the store, to avoid fiddling with `$PATH`. - rosenpass = "${pkgs.rosenpass}/bin/rosenpass" + # Full path to rosenpass in the store, to avoid fiddling with `$PATH`. + rosenpass = "${pkgs.rosenpass}/bin/rosenpass" - # Path in `/etc` where keys will be placed. - etc = "/etc/rosenpass" + # Path in `/etc` where keys will be placed. + etc = "/etc/rosenpass" - start_all() + start_all() - for machine in [server, client]: - machine.wait_for_unit("multi-user.target") - - # Gently stop Rosenpass to avoid crashes during key generation/distribution. - for machine in [server, client]: - machine.execute("systemctl stop rosenpass.service") - - for (name, machine, remote) in [("server", server, client), ("client", client, server)]: - pk, sk = f"{name}.pqpk", f"{name}.pqsk" - system(f"{rosenpass} gen-keys --force --secret-key {sk} --public-key {pk}") - machine.copy_from_host(sk, f"{etc}/pqsk") - machine.copy_from_host(pk, f"{etc}/pqpk") - remote.copy_from_host(pk, f"{etc}/peers/{name}/pqpk") + for machine in [server, client]: + machine.wait_for_unit("multi-user.target") - for machine in [server, client]: - machine.execute("systemctl start rosenpass.service") + # Gently stop Rosenpass to avoid crashes during key generation/distribution. + for machine in [server, client]: + machine.execute("systemctl stop rosenpass.service") - for machine in [server, client]: - machine.wait_for_unit("rosenpass.service") + for (name, machine, remote) in [("server", server, client), ("client", client, server)]: + pk, sk = f"{name}.pqpk", f"{name}.pqsk" + system(f"{rosenpass} gen-keys --force --secret-key {sk} --public-key {pk}") + machine.copy_from_host(sk, f"{etc}/pqsk") + machine.copy_from_host(pk, f"{etc}/pqpk") + remote.copy_from_host(pk, f"{etc}/peers/{name}/pqpk") - with subtest("ping"): - client.succeed("ping -c 2 -i 0.5 ${server.ip}%${deviceName}") + for machine in [server, client]: + machine.execute("systemctl start rosenpass.service") - with subtest("preshared-keys"): - # Rosenpass works by setting the WireGuard preshared key at regular intervals. - # Thus, if it is not active, then no key will be set, and the output of `wg show` will contain "none". - # Otherwise, if it is active, then the key will be set and "none" will not be found in the output of `wg show`. for machine in [server, client]: - machine.wait_until_succeeds("wg show all preshared-keys | grep --invert-match none", timeout=5) - ''; - - # NOTE: Below configuration is for "interactive" (=developing/debugging) only. - interactive.nodes = - let - inherit (import ./ssh-keys.nix pkgs) snakeOilPublicKey snakeOilPrivateKey; - - sshAndKeyGeneration = { - services.openssh.enable = true; - users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; - environment.systemPackages = [ - (pkgs.writeShellApplication { - name = "gen-keys"; - runtimeInputs = [ pkgs.rosenpass ]; - text = '' - HOST="$(hostname)" - if [ "$HOST" == "server" ] - then - PEER="client" - else - PEER="server" - fi - - # Generate keypair. - mkdir -vp /etc/rosenpass/peers/$PEER - rosenpass gen-keys --force --secret-key /etc/rosenpass/pqsk --public-key /etc/rosenpass/pqpk - - # Set up SSH key. - mkdir -p /root/.ssh - cp ${snakeOilPrivateKey} /root/.ssh/id_ecdsa - chmod 0400 /root/.ssh/id_ecdsa - - # Copy public key to other peer. - # shellcheck disable=SC2029 - ssh -o StrictHostKeyChecking=no $PEER "mkdir -pv /etc/rosenpass/peers/$HOST" - scp /etc/rosenpass/pqpk "$PEER:/etc/rosenpass/peers/$HOST/pqpk" - ''; - }) - ]; - }; + machine.wait_for_unit("rosenpass.service") + + with subtest("ping"): + client.succeed("ping -c 2 -i 0.5 ${server.ip}%${deviceName}") + + with subtest("preshared-keys"): + # Rosenpass works by setting the WireGuard preshared key at regular intervals. + # Thus, if it is not active, then no key will be set, and the output of `wg show` will contain "none". + # Otherwise, if it is active, then the key will be set and "none" will not be found in the output of `wg show`. + for machine in [server, client]: + machine.wait_until_succeeds("wg show all preshared-keys | grep --invert-match none", timeout=5) + ''; + + # NOTE: Below configuration is for "interactive" (=developing/debugging) only. + interactive.nodes = + let + inherit (import ./ssh-keys.nix pkgs) snakeOilPublicKey snakeOilPrivateKey; + + sshAndKeyGeneration = { + services.openssh.enable = true; + users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; + environment.systemPackages = [ + (pkgs.writeShellApplication { + name = "gen-keys"; + runtimeInputs = [ pkgs.rosenpass ]; + text = '' + HOST="$(hostname)" + if [ "$HOST" == "server" ] + then + PEER="client" + else + PEER="server" + fi + + # Generate keypair. + mkdir -vp /etc/rosenpass/peers/$PEER + rosenpass gen-keys --force --secret-key /etc/rosenpass/pqsk --public-key /etc/rosenpass/pqpk + + # Set up SSH key. + mkdir -p /root/.ssh + cp ${snakeOilPrivateKey} /root/.ssh/id_ecdsa + chmod 0400 /root/.ssh/id_ecdsa + + # Copy public key to other peer. + # shellcheck disable=SC2029 + ssh -o StrictHostKeyChecking=no $PEER "mkdir -pv /etc/rosenpass/peers/$HOST" + scp /etc/rosenpass/pqpk "$PEER:/etc/rosenpass/peers/$HOST/pqpk" + ''; + }) + ]; + }; - # Use kmscon - # to provide a slightly nicer console, and while we're at it, - # also use a nice font. - # With kmscon, we can for example zoom in/out using [Ctrl] + [+] - # and [Ctrl] + [-] - niceConsoleAndAutologin.services.kmscon = { - enable = true; - autologinUser = "root"; - fonts = [{ - name = "Fira Code"; - package = pkgs.fira-code; - }]; + # Use kmscon + # to provide a slightly nicer console, and while we're at it, + # also use a nice font. + # With kmscon, we can for example zoom in/out using [Ctrl] + [+] + # and [Ctrl] + [-] + niceConsoleAndAutologin.services.kmscon = { + enable = true; + autologinUser = "root"; + fonts = [ + { + name = "Fira Code"; + package = pkgs.fira-code; + } + ]; + }; + in + { + server = sshAndKeyGeneration // niceConsoleAndAutologin; + client = sshAndKeyGeneration // niceConsoleAndAutologin; }; - in - { - server = sshAndKeyGeneration // niceConsoleAndAutologin; - client = sshAndKeyGeneration // niceConsoleAndAutologin; - }; -}) + } +) diff --git a/nixos/tests/roundcube.nix b/nixos/tests/roundcube.nix index 763f10a7a2dda2..1f82e9c7a902cf 100644 --- a/nixos/tests/roundcube.nix +++ b/nixos/tests/roundcube.nix @@ -1,31 +1,40 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "roundcube"; - meta = with pkgs.lib.maintainers; { - maintainers = [ globin ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "roundcube"; + meta = with pkgs.lib.maintainers; { + maintainers = [ globin ]; + }; - nodes = { - roundcube = { config, pkgs, ... }: { - services.roundcube = { - enable = true; - hostName = "roundcube"; - database.password = "not production"; - package = pkgs.roundcube.withPlugins (plugins: [ plugins.persistent_login ]); - plugins = [ "persistent_login" ]; - dicts = with pkgs.aspellDicts; [ en fr de ]; - }; - services.nginx.virtualHosts.roundcube = { - forceSSL = false; - enableACME = false; - }; + nodes = { + roundcube = + { config, pkgs, ... }: + { + services.roundcube = { + enable = true; + hostName = "roundcube"; + database.password = "not production"; + package = pkgs.roundcube.withPlugins (plugins: [ plugins.persistent_login ]); + plugins = [ "persistent_login" ]; + dicts = with pkgs.aspellDicts; [ + en + fr + de + ]; + }; + services.nginx.virtualHosts.roundcube = { + forceSSL = false; + enableACME = false; + }; + }; }; - }; - testScript = '' - roundcube.start - roundcube.wait_for_unit("postgresql.service") - roundcube.wait_for_unit("phpfpm-roundcube.service") - roundcube.wait_for_unit("nginx.service") - roundcube.succeed("curl -sSfL http://roundcube/ | grep 'Keep me logged in'") - ''; -}) + testScript = '' + roundcube.start + roundcube.wait_for_unit("postgresql.service") + roundcube.wait_for_unit("phpfpm-roundcube.service") + roundcube.wait_for_unit("nginx.service") + roundcube.succeed("curl -sSfL http://roundcube/ | grep 'Keep me logged in'") + ''; + } +) diff --git a/nixos/tests/rshim.nix b/nixos/tests/rshim.nix index bb5cce028ae796..474018732e1651 100644 --- a/nixos/tests/rshim.nix +++ b/nixos/tests/rshim.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -11,15 +12,19 @@ with pkgs.lib; name = "rshim"; meta.maintainers = with maintainers; [ nikstur ]; - nodes.machine = { config, pkgs, ... }: { - services.rshim.enable = true; - }; + nodes.machine = + { config, pkgs, ... }: + { + services.rshim.enable = true; + }; - testScript = { nodes, ... }: '' - machine.start() - machine.wait_for_unit("multi-user.target") + testScript = + { nodes, ... }: + '' + machine.start() + machine.wait_for_unit("multi-user.target") - print(machine.succeed("systemctl status rshim.service")) - ''; + print(machine.succeed("systemctl status rshim.service")) + ''; }; } diff --git a/nixos/tests/rspamd-trainer.nix b/nixos/tests/rspamd-trainer.nix index 9c157903d24b64..fdb05bb8b00d53 100644 --- a/nixos/tests/rspamd-trainer.nix +++ b/nixos/tests/rspamd-trainer.nix @@ -1,155 +1,168 @@ -import ./make-test-python.nix ({ pkgs, ... }: -let - certs = import ./common/acme/server/snakeoil-certs.nix; - domain = certs.domain; -in { - name = "rspamd-trainer"; - meta = with pkgs.lib.maintainers; { maintainers = [ onny ]; }; - - nodes = { - machine = { options, config, ... }: { +import ./make-test-python.nix ( + { pkgs, ... }: + let + certs = import ./common/acme/server/snakeoil-certs.nix; + domain = certs.domain; + in + { + name = "rspamd-trainer"; + meta = with pkgs.lib.maintainers; { + maintainers = [ onny ]; + }; - security.pki.certificateFiles = [ - certs.ca.cert - ]; + nodes = { + machine = + { options, config, ... }: + { - networking.extraHosts = '' - 127.0.0.1 ${domain} - ''; + security.pki.certificateFiles = [ + certs.ca.cert + ]; - services.rspamd-trainer = { - enable = true; - settings = { - HOST = domain; - USERNAME = "spam@${domain}"; - INBOXPREFIX = "INBOX/"; - }; - secrets = [ - # Do not use this in production. This will make passwords - # world-readable in the Nix store - "${pkgs.writeText "secrets" '' - PASSWORD = test123 - ''}" - ]; - }; - - services.maddy = { - enable = true; - hostname = domain; - primaryDomain = domain; - ensureAccounts = [ "spam@${domain}" ]; - ensureCredentials = { - # Do not use this in production. This will make passwords world-readable - # in the Nix store - "spam@${domain}".passwordFile = "${pkgs.writeText "postmaster" "test123"}"; - }; - tls = { - loader = "file"; - certificates = [{ - certPath = "${certs.${domain}.cert}"; - keyPath = "${certs.${domain}.key}"; - }]; - }; - config = builtins.replaceStrings [ - "imap tcp://0.0.0.0:143" - "submission tcp://0.0.0.0:587" - ] [ - "imap tls://0.0.0.0:993 tcp://0.0.0.0:143" - "submission tls://0.0.0.0:465 tcp://0.0.0.0:587" - ] options.services.maddy.config.default; - }; - - services.rspamd = { - enable = true; - locals = { - "redis.conf".text = '' - servers = "${config.services.redis.servers.rspamd.unixSocket}"; + networking.extraHosts = '' + 127.0.0.1 ${domain} ''; - "classifier-bayes.conf".text = '' - backend = "redis"; - autolearn = true; - ''; - }; - }; - - services.redis.servers.rspamd = { - enable = true; - port = 0; - unixSocket = "/run/redis-rspamd/redis.sock"; - user = config.services.rspamd.user; - }; - - environment.systemPackages = [ - (pkgs.writers.writePython3Bin "send-testmail" { } '' - import smtplib - import ssl - from email.mime.text import MIMEText - context = ssl.create_default_context() - msg = MIMEText("Hello World") - msg['Subject'] = 'Test' - msg['From'] = "spam@${domain}" - msg['To'] = "spam@${domain}" - with smtplib.SMTP_SSL(host='${domain}', port=465, context=context) as smtp: - smtp.login('spam@${domain}', 'test123') - smtp.sendmail( - 'spam@${domain}', 'spam@${domain}', msg.as_string() - ) - '') - (pkgs.writers.writePython3Bin "create-mail-dirs" { } '' - import imaplib - with imaplib.IMAP4_SSL('${domain}') as imap: - imap.login('spam@${domain}', 'test123') - imap.create("\"INBOX/report_spam\"") - imap.create("\"INBOX/report_ham\"") - imap.create("\"INBOX/report_spam_reply\"") - imap.select("INBOX") - imap.copy("1", "\"INBOX/report_ham\"") - imap.logout() - '') - (pkgs.writers.writePython3Bin "test-imap" { } '' - import imaplib - with imaplib.IMAP4_SSL('${domain}') as imap: - imap.login('spam@${domain}', 'test123') - imap.select("INBOX/learned_ham") - status, refs = imap.search(None, 'ALL') - assert status == 'OK' - assert len(refs) == 1 - status, msg = imap.fetch(refs[0], 'BODY[TEXT]') - assert status == 'OK' - assert msg[0][1].strip() == b"Hello World" - imap.logout() - '') - ]; + services.rspamd-trainer = { + enable = true; + settings = { + HOST = domain; + USERNAME = "spam@${domain}"; + INBOXPREFIX = "INBOX/"; + }; + secrets = [ + # Do not use this in production. This will make passwords + # world-readable in the Nix store + "${pkgs.writeText "secrets" '' + PASSWORD = test123 + ''}" + ]; + }; + + services.maddy = { + enable = true; + hostname = domain; + primaryDomain = domain; + ensureAccounts = [ "spam@${domain}" ]; + ensureCredentials = { + # Do not use this in production. This will make passwords world-readable + # in the Nix store + "spam@${domain}".passwordFile = "${pkgs.writeText "postmaster" "test123"}"; + }; + tls = { + loader = "file"; + certificates = [ + { + certPath = "${certs.${domain}.cert}"; + keyPath = "${certs.${domain}.key}"; + } + ]; + }; + config = + builtins.replaceStrings + [ + "imap tcp://0.0.0.0:143" + "submission tcp://0.0.0.0:587" + ] + [ + "imap tls://0.0.0.0:993 tcp://0.0.0.0:143" + "submission tls://0.0.0.0:465 tcp://0.0.0.0:587" + ] + options.services.maddy.config.default; + }; + + services.rspamd = { + enable = true; + locals = { + "redis.conf".text = '' + servers = "${config.services.redis.servers.rspamd.unixSocket}"; + ''; + "classifier-bayes.conf".text = '' + backend = "redis"; + autolearn = true; + ''; + }; + }; + + services.redis.servers.rspamd = { + enable = true; + port = 0; + unixSocket = "/run/redis-rspamd/redis.sock"; + user = config.services.rspamd.user; + }; + + environment.systemPackages = [ + (pkgs.writers.writePython3Bin "send-testmail" { } '' + import smtplib + import ssl + from email.mime.text import MIMEText + context = ssl.create_default_context() + msg = MIMEText("Hello World") + msg['Subject'] = 'Test' + msg['From'] = "spam@${domain}" + msg['To'] = "spam@${domain}" + with smtplib.SMTP_SSL(host='${domain}', port=465, context=context) as smtp: + smtp.login('spam@${domain}', 'test123') + smtp.sendmail( + 'spam@${domain}', 'spam@${domain}', msg.as_string() + ) + '') + (pkgs.writers.writePython3Bin "create-mail-dirs" { } '' + import imaplib + with imaplib.IMAP4_SSL('${domain}') as imap: + imap.login('spam@${domain}', 'test123') + imap.create("\"INBOX/report_spam\"") + imap.create("\"INBOX/report_ham\"") + imap.create("\"INBOX/report_spam_reply\"") + imap.select("INBOX") + imap.copy("1", "\"INBOX/report_ham\"") + imap.logout() + '') + (pkgs.writers.writePython3Bin "test-imap" { } '' + import imaplib + with imaplib.IMAP4_SSL('${domain}') as imap: + imap.login('spam@${domain}', 'test123') + imap.select("INBOX/learned_ham") + status, refs = imap.search(None, 'ALL') + assert status == 'OK' + assert len(refs) == 1 + status, msg = imap.fetch(refs[0], 'BODY[TEXT]') + assert status == 'OK' + assert msg[0][1].strip() == b"Hello World" + imap.logout() + '') + ]; + }; }; - }; - - testScript = { nodes }: '' - start_all() - machine.wait_for_unit("maddy.service") - machine.wait_for_open_port(143) - machine.wait_for_open_port(993) - machine.wait_for_open_port(587) - machine.wait_for_open_port(465) - - # Send test mail to spam@domain - machine.succeed("send-testmail") - - # Create mail directories required for rspamd-trainer and copy mail from - # INBOX into INBOX/report_ham - machine.succeed("create-mail-dirs") - - # Start rspamd-trainer. It should read mail from INBOX/report_ham - machine.wait_for_unit("rspamd.service") - machine.wait_for_unit("redis-rspamd.service") - machine.wait_for_file("/run/rspamd/rspamd.sock") - machine.succeed("systemctl start rspamd-trainer.service") - - # Check if mail got processed by rspamd-trainer successfully and check for - # it in INBOX/learned_ham - machine.succeed("test-imap") - ''; -}) + testScript = + { nodes }: + '' + start_all() + machine.wait_for_unit("maddy.service") + machine.wait_for_open_port(143) + machine.wait_for_open_port(993) + machine.wait_for_open_port(587) + machine.wait_for_open_port(465) + + # Send test mail to spam@domain + machine.succeed("send-testmail") + + # Create mail directories required for rspamd-trainer and copy mail from + # INBOX into INBOX/report_ham + machine.succeed("create-mail-dirs") + + # Start rspamd-trainer. It should read mail from INBOX/report_ham + machine.wait_for_unit("rspamd.service") + machine.wait_for_unit("redis-rspamd.service") + machine.wait_for_file("/run/rspamd/rspamd.sock") + machine.succeed("systemctl start rspamd-trainer.service") + + # Check if mail got processed by rspamd-trainer successfully and check for + # it in INBOX/learned_ham + machine.succeed("test-imap") + ''; + } +) diff --git a/nixos/tests/rspamd.nix b/nixos/tests/rspamd.nix index 26895fbad3f3b5..603b59a52e4ba7 100644 --- a/nixos/tests/rspamd.nix +++ b/nixos/tests/rspamd.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -20,32 +21,34 @@ let '[[ "$(stat -c %a ${socket})" == "${mode}" ]]', ) ''; - simple = name: enableIPv6: makeTest { - name = "rspamd-${name}"; - nodes.machine = { - services.rspamd.enable = true; - networking.enableIPv6 = enableIPv6; + simple = + name: enableIPv6: + makeTest { + name = "rspamd-${name}"; + nodes.machine = { + services.rspamd.enable = true; + networking.enableIPv6 = enableIPv6; + }; + testScript = '' + start_all() + machine.wait_for_unit("multi-user.target") + machine.wait_for_open_port(11334) + machine.wait_for_unit("rspamd.service") + machine.succeed("id rspamd >/dev/null") + ${checkSocket "/run/rspamd/rspamd.sock" "rspamd" "rspamd" "660"} + machine.sleep(10) + machine.log(machine.succeed("cat /etc/rspamd/rspamd.conf")) + machine.log( + machine.succeed("grep 'CONFDIR/worker-controller.inc' /etc/rspamd/rspamd.conf") + ) + machine.log(machine.succeed("grep 'CONFDIR/worker-normal.inc' /etc/rspamd/rspamd.conf")) + machine.log(machine.succeed("systemctl cat rspamd.service")) + machine.log(machine.succeed("curl http://localhost:11334/auth")) + machine.log(machine.succeed("curl http://127.0.0.1:11334/auth")) + ${optionalString enableIPv6 ''machine.log(machine.succeed("curl http://[::1]:11334/auth"))''} + # would not reformat + ''; }; - testScript = '' - start_all() - machine.wait_for_unit("multi-user.target") - machine.wait_for_open_port(11334) - machine.wait_for_unit("rspamd.service") - machine.succeed("id rspamd >/dev/null") - ${checkSocket "/run/rspamd/rspamd.sock" "rspamd" "rspamd" "660" } - machine.sleep(10) - machine.log(machine.succeed("cat /etc/rspamd/rspamd.conf")) - machine.log( - machine.succeed("grep 'CONFDIR/worker-controller.inc' /etc/rspamd/rspamd.conf") - ) - machine.log(machine.succeed("grep 'CONFDIR/worker-normal.inc' /etc/rspamd/rspamd.conf")) - machine.log(machine.succeed("systemctl cat rspamd.service")) - machine.log(machine.succeed("curl http://localhost:11334/auth")) - machine.log(machine.succeed("curl http://127.0.0.1:11334/auth")) - ${optionalString enableIPv6 ''machine.log(machine.succeed("curl http://[::1]:11334/auth"))''} - # would not reformat - ''; - }; in { simple = simple "simple" true; @@ -55,26 +58,30 @@ in nodes.machine = { services.rspamd = { enable = true; - workers.normal.bindSockets = [{ - socket = "/run/rspamd/rspamd.sock"; - mode = "0600"; - owner = "rspamd"; - group = "rspamd"; - }]; - workers.controller.bindSockets = [{ - socket = "/run/rspamd/rspamd-worker.sock"; - mode = "0666"; - owner = "rspamd"; - group = "rspamd"; - }]; + workers.normal.bindSockets = [ + { + socket = "/run/rspamd/rspamd.sock"; + mode = "0600"; + owner = "rspamd"; + group = "rspamd"; + } + ]; + workers.controller.bindSockets = [ + { + socket = "/run/rspamd/rspamd-worker.sock"; + mode = "0666"; + owner = "rspamd"; + group = "rspamd"; + } + ]; }; }; testScript = '' ${initMachine} machine.wait_for_file("/run/rspamd/rspamd.sock") - ${checkSocket "/run/rspamd/rspamd.sock" "rspamd" "rspamd" "600" } - ${checkSocket "/run/rspamd/rspamd-worker.sock" "rspamd" "rspamd" "666" } + ${checkSocket "/run/rspamd/rspamd.sock" "rspamd" "rspamd" "600"} + ${checkSocket "/run/rspamd/rspamd-worker.sock" "rspamd" "rspamd" "666"} machine.log(machine.succeed("cat /etc/rspamd/rspamd.conf")) machine.log( machine.succeed("grep 'CONFDIR/worker-controller.inc' /etc/rspamd/rspamd.conf") @@ -94,18 +101,22 @@ in nodes.machine = { services.rspamd = { enable = true; - workers.normal.bindSockets = [{ - socket = "/run/rspamd/rspamd.sock"; - mode = "0600"; - owner = "rspamd"; - group = "rspamd"; - }]; - workers.controller.bindSockets = [{ - socket = "/run/rspamd/rspamd-worker.sock"; - mode = "0666"; - owner = "rspamd"; - group = "rspamd"; - }]; + workers.normal.bindSockets = [ + { + socket = "/run/rspamd/rspamd.sock"; + mode = "0600"; + owner = "rspamd"; + group = "rspamd"; + } + ]; + workers.controller.bindSockets = [ + { + socket = "/run/rspamd/rspamd-worker.sock"; + mode = "0666"; + owner = "rspamd"; + group = "rspamd"; + } + ]; workers.controller2 = { type = "controller"; bindSockets = [ "0.0.0.0:11335" ]; @@ -121,8 +132,8 @@ in testScript = '' ${initMachine} machine.wait_for_file("/run/rspamd/rspamd.sock") - ${checkSocket "/run/rspamd/rspamd.sock" "rspamd" "rspamd" "600" } - ${checkSocket "/run/rspamd/rspamd-worker.sock" "rspamd" "rspamd" "666" } + ${checkSocket "/run/rspamd/rspamd.sock" "rspamd" "rspamd" "600"} + ${checkSocket "/run/rspamd/rspamd-worker.sock" "rspamd" "rspamd" "666"} machine.log(machine.succeed("cat /etc/rspamd/rspamd.conf")) machine.log( machine.succeed("grep 'CONFDIR/worker-controller.inc' /etc/rspamd/rspamd.conf") @@ -170,7 +181,8 @@ in services.rspamd = { enable = true; locals = { - "antivirus.conf" = mkIf false { text = '' + "antivirus.conf" = mkIf false { + text = '' clamav { action = "reject"; symbol = "CLAM_VIRUS"; @@ -178,7 +190,8 @@ in log_clean = true; servers = "/run/clamav/clamd.ctl"; } - '';}; + ''; + }; "redis.conf" = { enable = false; text = '' @@ -232,7 +245,7 @@ in machine.fail("cat /etc/rspamd/local.d/redis.conf >&2") # Verify that antivirus.conf was not written machine.fail("cat /etc/rspamd/local.d/antivirus.conf >&2") - ${checkSocket "/run/rspamd/rspamd.sock" "rspamd" "rspamd" "660" } + ${checkSocket "/run/rspamd/rspamd.sock" "rspamd" "rspamd" "660"} machine.log( machine.succeed("curl --unix-socket /run/rspamd/rspamd.sock http://localhost/ping") ) @@ -280,7 +293,7 @@ in }; services.postfix = { enable = true; - destination = ["example.com"]; + destination = [ "example.com" ]; }; services.rspamd = { enable = true; @@ -292,7 +305,7 @@ in ${initMachine} machine.wait_for_open_port(11334) machine.wait_for_open_port(25) - ${checkSocket "/run/rspamd/rspamd-milter.sock" "rspamd" "postfix" "660" } + ${checkSocket "/run/rspamd/rspamd-milter.sock" "rspamd" "postfix" "660"} machine.log(machine.succeed("rspamc -h 127.0.0.1:11334 stat")) machine.log( machine.succeed( diff --git a/nixos/tests/rss2email.nix b/nixos/tests/rss2email.nix index 60b27b95fabe4a..490d08943734c9 100644 --- a/nixos/tests/rss2email.nix +++ b/nixos/tests/rss2email.nix @@ -2,54 +2,63 @@ import ./make-test-python.nix { name = "rss2email"; nodes = { - server = { pkgs, ... }: { - imports = [ common/user-account.nix ]; - services.nginx = { - enable = true; - virtualHosts."127.0.0.1".root = ./common/webroot; - }; - services.rss2email = { - enable = true; - to = "alice@localhost"; - interval = "1"; - config.from = "test@example.org"; - feeds = { - nixos = { url = "http://127.0.0.1/news-rss.xml"; }; + server = + { pkgs, ... }: + { + imports = [ common/user-account.nix ]; + services.nginx = { + enable = true; + virtualHosts."127.0.0.1".root = ./common/webroot; }; - }; - services.opensmtpd = { - enable = true; - extraServerArgs = [ "-v" ]; - serverConfiguration = '' - listen on 127.0.0.1 - action dovecot_deliver mda \ - "${pkgs.dovecot}/libexec/dovecot/deliver -d %{user.username}" - match from any for local action dovecot_deliver - ''; - }; - services.dovecot2 = { - enable = true; - enableImap = true; - mailLocation = "maildir:~/mail"; - protocols = [ "imap" ]; - }; - environment.systemPackages = let - checkMailLanded = pkgs.writeScriptBin "check-mail-landed" '' - #!${pkgs.python3.interpreter} - import imaplib + services.rss2email = { + enable = true; + to = "alice@localhost"; + interval = "1"; + config.from = "test@example.org"; + feeds = { + nixos = { + url = "http://127.0.0.1/news-rss.xml"; + }; + }; + }; + services.opensmtpd = { + enable = true; + extraServerArgs = [ "-v" ]; + serverConfiguration = '' + listen on 127.0.0.1 + action dovecot_deliver mda \ + "${pkgs.dovecot}/libexec/dovecot/deliver -d %{user.username}" + match from any for local action dovecot_deliver + ''; + }; + services.dovecot2 = { + enable = true; + enableImap = true; + mailLocation = "maildir:~/mail"; + protocols = [ "imap" ]; + }; + environment.systemPackages = + let + checkMailLanded = pkgs.writeScriptBin "check-mail-landed" '' + #!${pkgs.python3.interpreter} + import imaplib - with imaplib.IMAP4('127.0.0.1', 143) as imap: - imap.login('alice', 'foobar') - imap.select() - status, refs = imap.search(None, 'ALL') - print("=====> Result of search for all:", status, refs) - assert status == 'OK' - assert len(refs) > 0 - status, msg = imap.fetch(refs[0], 'BODY[TEXT]') - assert status == 'OK' - ''; - in [ pkgs.opensmtpd checkMailLanded ]; - }; + with imaplib.IMAP4('127.0.0.1', 143) as imap: + imap.login('alice', 'foobar') + imap.select() + status, refs = imap.search(None, 'ALL') + print("=====> Result of search for all:", status, refs) + assert status == 'OK' + assert len(refs) > 0 + status, msg = imap.fetch(refs[0], 'BODY[TEXT]') + assert status == 'OK' + ''; + in + [ + pkgs.opensmtpd + checkMailLanded + ]; + }; }; testScript = '' diff --git a/nixos/tests/rstudio-server.nix b/nixos/tests/rstudio-server.nix index dd5fe3e5b4400e..03a173fe32f269 100644 --- a/nixos/tests/rstudio-server.nix +++ b/nixos/tests/rstudio-server.nix @@ -1,18 +1,36 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: { name = "rstudio-server-test"; - meta.maintainers = with pkgs.lib.maintainers; [ jbedo cfhammill ]; + meta.maintainers = with pkgs.lib.maintainers; [ + jbedo + cfhammill + ]; - nodes.machine = { config, lib, pkgs, ... }: { - services.rstudio-server.enable = true; - }; + nodes.machine = + { + config, + lib, + pkgs, + ... + }: + { + services.rstudio-server.enable = true; + }; - nodes.customPackageMachine = { config, lib, pkgs, ... }: { - services.rstudio-server = { - enable = true; - package = pkgs.rstudioServerWrapper.override { packages = [ pkgs.rPackages.ggplot2 ]; }; + nodes.customPackageMachine = + { + config, + lib, + pkgs, + ... + }: + { + services.rstudio-server = { + enable = true; + package = pkgs.rstudioServerWrapper.override { packages = [ pkgs.rPackages.ggplot2 ]; }; + }; }; - }; testScript = '' machine.wait_for_unit("rstudio-server.service") @@ -21,4 +39,5 @@ import ./make-test-python.nix ({ pkgs, ... }: customPackageMachine.wait_for_unit("rstudio-server.service") customPackageMachine.succeed("curl -f -vvv -s http://127.0.0.1:8787") ''; - }) + } +) diff --git a/nixos/tests/rsyncd.nix b/nixos/tests/rsyncd.nix index 44464e42f28d46..b75b3e0111439d 100644 --- a/nixos/tests/rsyncd.nix +++ b/nixos/tests/rsyncd.nix @@ -1,36 +1,43 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "rsyncd"; - meta.maintainers = with pkgs.lib.maintainers; [ ehmry ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "rsyncd"; + meta.maintainers = with pkgs.lib.maintainers; [ ehmry ]; - nodes = let - mkNode = socketActivated: - { config, ... }: { - networking.firewall.allowedTCPPorts = [ config.services.rsyncd.port ]; - services.rsyncd = { - enable = true; - inherit socketActivated; - settings = { - global = { - "reverse lookup" = false; - "forward lookup" = false; - }; - tmp = { - path = "/nix/store"; - comment = "test module"; + nodes = + let + mkNode = + socketActivated: + { config, ... }: + { + networking.firewall.allowedTCPPorts = [ config.services.rsyncd.port ]; + services.rsyncd = { + enable = true; + inherit socketActivated; + settings = { + global = { + "reverse lookup" = false; + "forward lookup" = false; + }; + tmp = { + path = "/nix/store"; + comment = "test module"; + }; + }; }; }; - }; + in + { + a = mkNode false; + b = mkNode true; }; - in { - a = mkNode false; - b = mkNode true; - }; - testScript = '' - start_all() - a.wait_for_unit("rsync") - b.wait_for_unit("sockets.target") - b.succeed("rsync a::") - a.succeed("rsync b::") - ''; -}) + testScript = '' + start_all() + a.wait_for_unit("rsync") + b.wait_for_unit("sockets.target") + b.succeed("rsync a::") + a.succeed("rsync b::") + ''; + } +) diff --git a/nixos/tests/rsyslogd.nix b/nixos/tests/rsyslogd.nix index 049acdcd439345..99703f18d6a728 100644 --- a/nixos/tests/rsyslogd.nix +++ b/nixos/tests/rsyslogd.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -11,10 +12,12 @@ with pkgs.lib; name = "rsyslogd-test1"; meta.maintainers = [ pkgs.lib.maintainers.aanderse ]; - nodes.machine = { config, pkgs, ... }: { - services.rsyslogd.enable = true; - services.journald.forwardToSyslog = false; - }; + nodes.machine = + { config, pkgs, ... }: + { + services.rsyslogd.enable = true; + services.journald.forwardToSyslog = false; + }; # ensure rsyslogd isn't receiving messages from journald if explicitly disabled testScript = '' @@ -27,9 +30,11 @@ with pkgs.lib; name = "rsyslogd-test2"; meta.maintainers = [ pkgs.lib.maintainers.aanderse ]; - nodes.machine = { config, pkgs, ... }: { - services.rsyslogd.enable = true; - }; + nodes.machine = + { config, pkgs, ... }: + { + services.rsyslogd.enable = true; + }; # ensure rsyslogd is receiving messages from journald testScript = '' diff --git a/nixos/tests/rtorrent.nix b/nixos/tests/rtorrent.nix index 77e78b549a96fa..ca680380374a34 100644 --- a/nixos/tests/rtorrent.nix +++ b/nixos/tests/rtorrent.nix @@ -1,25 +1,30 @@ -import ./make-test-python.nix ({ pkgs, ... }: -let - port = 50001; -in -{ - name = "rtorrent"; - meta = { - maintainers = with pkgs.lib.maintainers; [ thiagokokada ]; - }; - - nodes.machine = { pkgs, ... }: { - services.rtorrent = { - inherit port; - enable = true; +import ./make-test-python.nix ( + { pkgs, ... }: + let + port = 50001; + in + { + name = "rtorrent"; + meta = { + maintainers = with pkgs.lib.maintainers; [ thiagokokada ]; }; - }; - testScript = /* python */ '' - machine.start() - machine.wait_for_unit("rtorrent.service") - machine.wait_for_open_port(${toString port}) + nodes.machine = + { pkgs, ... }: + { + services.rtorrent = { + inherit port; + enable = true; + }; + }; + + testScript = # python + '' + machine.start() + machine.wait_for_unit("rtorrent.service") + machine.wait_for_open_port(${toString port}) - machine.succeed("nc -z localhost ${toString port}") - ''; -}) + machine.succeed("nc -z localhost ${toString port}") + ''; + } +) diff --git a/nixos/tests/rxe.nix b/nixos/tests/rxe.nix index 10753c4ed0c854..f05b5a7dd37499 100644 --- a/nixos/tests/rxe.nix +++ b/nixos/tests/rxe.nix @@ -1,47 +1,53 @@ -import ./make-test-python.nix ({ ... } : - -let - node = { pkgs, ... } : { - networking = { - firewall = { - allowedUDPPorts = [ 4791 ]; # open RoCE port - allowedTCPPorts = [ 4800 ]; # port for test utils +import ./make-test-python.nix ( + { ... }: + + let + node = + { pkgs, ... }: + { + networking = { + firewall = { + allowedUDPPorts = [ 4791 ]; # open RoCE port + allowedTCPPorts = [ 4800 ]; # port for test utils + }; + rxe = { + enable = true; + interfaces = [ "eth1" ]; + }; + }; + + environment.systemPackages = with pkgs; [ + rdma-core + screen + ]; }; - rxe = { - enable = true; - interfaces = [ "eth1" ]; - }; - }; - - environment.systemPackages = with pkgs; [ rdma-core screen ]; - }; - -in { - name = "rxe"; - - nodes = { - server = node; - client = node; - }; - testScript = '' - # Test if rxe interface comes up - server.wait_for_unit("default.target") - server.succeed("systemctl status rxe.service") - server.succeed("ibv_devices | grep rxe_eth1") - - client.wait_for_unit("default.target") - - # ping pong tests - for proto in "rc", "uc", "ud", "srq": - server.succeed( - "screen -dmS {0}_pingpong ibv_{0}_pingpong -p 4800 -s 1024 -g0".format(proto) - ) - client.succeed("sleep 2; ibv_{}_pingpong -p 4800 -s 1024 -g0 server".format(proto)) - - server.succeed("screen -dmS rping rping -s -a server -C 10") - client.succeed("sleep 2; rping -c -a server -C 10") - ''; -}) + in + { + name = "rxe"; + nodes = { + server = node; + client = node; + }; + testScript = '' + # Test if rxe interface comes up + server.wait_for_unit("default.target") + server.succeed("systemctl status rxe.service") + server.succeed("ibv_devices | grep rxe_eth1") + + client.wait_for_unit("default.target") + + # ping pong tests + for proto in "rc", "uc", "ud", "srq": + server.succeed( + "screen -dmS {0}_pingpong ibv_{0}_pingpong -p 4800 -s 1024 -g0".format(proto) + ) + client.succeed("sleep 2; ibv_{}_pingpong -p 4800 -s 1024 -g0 server".format(proto)) + + server.succeed("screen -dmS rping rping -s -a server -C 10") + client.succeed("sleep 2; rping -c -a server -C 10") + ''; + } +) diff --git a/nixos/tests/sabnzbd.nix b/nixos/tests/sabnzbd.nix index 64cb655b43157d..5aa466267a5dbe 100644 --- a/nixos/tests/sabnzbd.nix +++ b/nixos/tests/sabnzbd.nix @@ -1,25 +1,30 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "sabnzbd"; - meta = with pkgs.lib; { - maintainers = with maintainers; [ jojosch ]; - }; - - nodes.machine = { pkgs, ... }: { - services.sabnzbd = { - enable = true; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "sabnzbd"; + meta = with pkgs.lib; { + maintainers = with maintainers; [ jojosch ]; }; - # unrar is unfree - nixpkgs.config.allowUnfreePredicate = pkg: builtins.elem (lib.getName pkg) [ "unrar" ]; - }; + nodes.machine = + { pkgs, ... }: + { + services.sabnzbd = { + enable = true; + }; + + # unrar is unfree + nixpkgs.config.allowUnfreePredicate = pkg: builtins.elem (lib.getName pkg) [ "unrar" ]; + }; - testScript = '' - machine.wait_for_unit("sabnzbd.service") - machine.wait_until_succeeds( - "curl --fail -L http://localhost:8080/" - ) - _, out = machine.execute("grep SABCTools /var/lib/sabnzbd/logs/sabnzbd.log") - machine.log(out) - machine.fail("grep 'SABCTools disabled: no correct version found!' /var/lib/sabnzbd/logs/sabnzbd.log") - ''; -}) + testScript = '' + machine.wait_for_unit("sabnzbd.service") + machine.wait_until_succeeds( + "curl --fail -L http://localhost:8080/" + ) + _, out = machine.execute("grep SABCTools /var/lib/sabnzbd/logs/sabnzbd.log") + machine.log(out) + machine.fail("grep 'SABCTools disabled: no correct version found!' /var/lib/sabnzbd/logs/sabnzbd.log") + ''; + } +) diff --git a/nixos/tests/samba-wsdd.nix b/nixos/tests/samba-wsdd.nix index 666a626d1b4a50..2efc3058ee96eb 100644 --- a/nixos/tests/samba-wsdd.nix +++ b/nixos/tests/samba-wsdd.nix @@ -1,42 +1,48 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -{ - name = "samba-wsdd"; - meta.maintainers = with pkgs.lib.maintainers; [ izorkin ]; + { + name = "samba-wsdd"; + meta.maintainers = with pkgs.lib.maintainers; [ izorkin ]; - nodes = { - client_wsdd = { pkgs, ... }: { - services.samba-wsdd = { - enable = true; - openFirewall = true; - interface = "eth1"; - workgroup = "WORKGROUP"; - hostname = "CLIENT-WSDD"; - discovery = true; - extraOptions = [ "--no-host" ]; - }; - }; + nodes = { + client_wsdd = + { pkgs, ... }: + { + services.samba-wsdd = { + enable = true; + openFirewall = true; + interface = "eth1"; + workgroup = "WORKGROUP"; + hostname = "CLIENT-WSDD"; + discovery = true; + extraOptions = [ "--no-host" ]; + }; + }; - server_wsdd = { ... }: { - services.samba-wsdd = { - enable = true; - openFirewall = true; - interface = "eth1"; - workgroup = "WORKGROUP"; - hostname = "SERVER-WSDD"; - }; + server_wsdd = + { ... }: + { + services.samba-wsdd = { + enable = true; + openFirewall = true; + interface = "eth1"; + workgroup = "WORKGROUP"; + hostname = "SERVER-WSDD"; + }; + }; }; - }; - testScript = '' - client_wsdd.start() - client_wsdd.wait_for_unit("samba-wsdd") + testScript = '' + client_wsdd.start() + client_wsdd.wait_for_unit("samba-wsdd") - server_wsdd.start() - server_wsdd.wait_for_unit("samba-wsdd") + server_wsdd.start() + server_wsdd.wait_for_unit("samba-wsdd") - client_wsdd.wait_until_succeeds( - "echo list | ${pkgs.libressl.nc}/bin/nc -N -U /run/wsdd/wsdd.sock | grep -i SERVER-WSDD" - ) - ''; -}) + client_wsdd.wait_until_succeeds( + "echo list | ${pkgs.libressl.nc}/bin/nc -N -U /run/wsdd/wsdd.sock | grep -i SERVER-WSDD" + ) + ''; + } +) diff --git a/nixos/tests/samba.nix b/nixos/tests/samba.nix index 2501fea2d37688..96f63730b61305 100644 --- a/nixos/tests/samba.nix +++ b/nixos/tests/samba.nix @@ -1,47 +1,50 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "samba"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "samba"; - meta.maintainers = [ lib.maintainers.anthonyroussel ]; + meta.maintainers = [ lib.maintainers.anthonyroussel ]; - nodes = { - client = - { ... }: - { - virtualisation.fileSystems = { - "/public" = { - fsType = "cifs"; - device = "//server/public"; - options = [ "guest" ]; + nodes = { + client = + { ... }: + { + virtualisation.fileSystems = { + "/public" = { + fsType = "cifs"; + device = "//server/public"; + options = [ "guest" ]; + }; }; }; - }; - server = - { ... }: - { - services.samba = { - enable = true; - openFirewall = true; - settings = { - "public" = { - "path" = "/public"; - "read only" = true; - "browseable" = "yes"; - "guest ok" = "yes"; - "comment" = "Public samba share."; + server = + { ... }: + { + services.samba = { + enable = true; + openFirewall = true; + settings = { + "public" = { + "path" = "/public"; + "read only" = true; + "browseable" = "yes"; + "guest ok" = "yes"; + "comment" = "Public samba share."; + }; }; }; }; - }; - }; + }; - testScript = '' - server.start() - server.wait_for_unit("samba.target") - server.succeed("mkdir -p /public; echo bar > /public/foo") + testScript = '' + server.start() + server.wait_for_unit("samba.target") + server.succeed("mkdir -p /public; echo bar > /public/foo") - client.start() - client.wait_for_unit("remote-fs.target") - client.succeed("[[ $(cat /public/foo) = bar ]]") - ''; -}) + client.start() + client.wait_for_unit("remote-fs.target") + client.succeed("[[ $(cat /public/foo) = bar ]]") + ''; + } +) diff --git a/nixos/tests/sane.nix b/nixos/tests/sane.nix index cba1b4d1dc4da9..117831e5c7ab25 100644 --- a/nixos/tests/sane.nix +++ b/nixos/tests/sane.nix @@ -1,85 +1,94 @@ -import ./make-test-python.nix ({ pkgs, ... }: -/* - SANE NixOS test - =============== - SANE is intrisically tied to hardware, so testing it is not straightforward. - However: - - a fake webcam can be created with v4l2loopback - - sane has a backend (v4l) to use a webcam as a scanner - This test creates a webcam /dev/video0, streams a still image with some text - through this webcam, uses SANE to scan from the webcam, and uses OCR to check - that the expected text was scanned. -*/ -let - text = "66263666188646651519653683416"; - fontsConf = pkgs.makeFontsConf { - fontDirectories = [ - pkgs.dejavu_fonts.minimal - ]; - }; - # an image with black on white text spelling "${text}" - # for some reason, the test fails if it's jpg instead of png - # the font is quite large to make OCR easier - image = pkgs.runCommand "image.png" - { - # only imagemagickBig can render text - nativeBuildInputs = [ pkgs.imagemagickBig ]; - FONTCONFIG_FILE = fontsConf; - } '' - magick -pointsize 100 label:${text} $out - ''; -in -{ - name = "sane"; - nodes.machine = { pkgs, config, ... }: { - boot = { - # create /dev/video0 as a fake webcam whose content is filled by ffmpeg - extraModprobeConfig = '' - options v4l2loopback devices=1 max_buffers=2 exclusive_caps=1 card_label=VirtualCam - ''; - kernelModules = [ "v4l2loopback" ]; - extraModulePackages = [ config.boot.kernelPackages.v4l2loopback ]; +import ./make-test-python.nix ( + { pkgs, ... }: + /* + SANE NixOS test + =============== + SANE is intrisically tied to hardware, so testing it is not straightforward. + However: + - a fake webcam can be created with v4l2loopback + - sane has a backend (v4l) to use a webcam as a scanner + This test creates a webcam /dev/video0, streams a still image with some text + through this webcam, uses SANE to scan from the webcam, and uses OCR to check + that the expected text was scanned. + */ + let + text = "66263666188646651519653683416"; + fontsConf = pkgs.makeFontsConf { + fontDirectories = [ + pkgs.dejavu_fonts.minimal + ]; }; - systemd.services.fake-webcam = { - wantedBy = [ "multi-user.target" ]; - description = "fill /dev/video0 with ${image}"; - /* HACK: /dev/video0 is a v4l2 only device, it misses one single v4l1 - ioctl, VIDIOCSPICT. But sane only supports v4l1, so it will log that this - ioctl failed, and assume that the pixel format is Y8 (gray). So we tell - ffmpeg to produce this pixel format. - */ - serviceConfig.ExecStart = [ "${pkgs.ffmpeg}/bin/ffmpeg -framerate 30 -re -stream_loop -1 -i ${image} -f v4l2 -pix_fmt gray /dev/video0" ]; - }; - hardware.sane.enable = true; - system.extraDependencies = [ image ]; - environment.systemPackages = [ - pkgs.fswebcam - pkgs.tesseract - pkgs.v4l-utils - ]; - environment.variables.SANE_DEBUG_V4L = "128"; - }; - testScript = '' - start_all() - machine.wait_for_unit("fake-webcam.service") + # an image with black on white text spelling "${text}" + # for some reason, the test fails if it's jpg instead of png + # the font is quite large to make OCR easier + image = + pkgs.runCommand "image.png" + { + # only imagemagickBig can render text + nativeBuildInputs = [ pkgs.imagemagickBig ]; + FONTCONFIG_FILE = fontsConf; + } + '' + magick -pointsize 100 label:${text} $out + ''; + in + { + name = "sane"; + nodes.machine = + { pkgs, config, ... }: + { + boot = { + # create /dev/video0 as a fake webcam whose content is filled by ffmpeg + extraModprobeConfig = '' + options v4l2loopback devices=1 max_buffers=2 exclusive_caps=1 card_label=VirtualCam + ''; + kernelModules = [ "v4l2loopback" ]; + extraModulePackages = [ config.boot.kernelPackages.v4l2loopback ]; + }; + systemd.services.fake-webcam = { + wantedBy = [ "multi-user.target" ]; + description = "fill /dev/video0 with ${image}"; + /* + HACK: /dev/video0 is a v4l2 only device, it misses one single v4l1 + ioctl, VIDIOCSPICT. But sane only supports v4l1, so it will log that this + ioctl failed, and assume that the pixel format is Y8 (gray). So we tell + ffmpeg to produce this pixel format. + */ + serviceConfig.ExecStart = [ + "${pkgs.ffmpeg}/bin/ffmpeg -framerate 30 -re -stream_loop -1 -i ${image} -f v4l2 -pix_fmt gray /dev/video0" + ]; + }; + hardware.sane.enable = true; + system.extraDependencies = [ image ]; + environment.systemPackages = [ + pkgs.fswebcam + pkgs.tesseract + pkgs.v4l-utils + ]; + environment.variables.SANE_DEBUG_V4L = "128"; + }; + testScript = '' + start_all() + machine.wait_for_unit("fake-webcam.service") - # the device only appears when ffmpeg starts producing frames - machine.wait_until_succeeds("scanimage -L | grep /dev/video0") + # the device only appears when ffmpeg starts producing frames + machine.wait_until_succeeds("scanimage -L | grep /dev/video0") - machine.succeed("scanimage -L >&2") + machine.succeed("scanimage -L >&2") - with subtest("debugging: /dev/video0 works"): - machine.succeed("v4l2-ctl --all >&2") - machine.succeed("fswebcam --no-banner /tmp/webcam.jpg") - machine.copy_from_vm("/tmp/webcam.jpg", "webcam") + with subtest("debugging: /dev/video0 works"): + machine.succeed("v4l2-ctl --all >&2") + machine.succeed("fswebcam --no-banner /tmp/webcam.jpg") + machine.copy_from_vm("/tmp/webcam.jpg", "webcam") - # scan with the webcam - machine.succeed("scanimage -o /tmp/scan.png >&2") - machine.copy_from_vm("/tmp/scan.png", "scan") + # scan with the webcam + machine.succeed("scanimage -o /tmp/scan.png >&2") + machine.copy_from_vm("/tmp/scan.png", "scan") - # the image should contain "${text}" - output = machine.succeed("tesseract /tmp/scan.png -") - print(output) - assert "${text}" in output, f"expected text ${text} was not found, OCR found {output!r}" - ''; -}) + # the image should contain "${text}" + output = machine.succeed("tesseract /tmp/scan.png -") + print(output) + assert "${text}" in output, f"expected text ${text} was not found, OCR found {output!r}" + ''; + } +) diff --git a/nixos/tests/sanoid.nix b/nixos/tests/sanoid.nix index 1575634e628423..227a95e9471d48 100644 --- a/nixos/tests/sanoid.nix +++ b/nixos/tests/sanoid.nix @@ -1,133 +1,148 @@ -import ./make-test-python.nix ({ pkgs, ... }: let - inherit (import ./ssh-keys.nix pkgs) - snakeOilPrivateKey snakeOilPublicKey; - - commonConfig = { pkgs, ... }: { - virtualisation.emptyDiskImages = [ 2048 ]; - boot.supportedFilesystems = [ "zfs" ]; - environment.systemPackages = [ pkgs.parted ]; - }; -in { - name = "sanoid"; - meta = with pkgs.lib.maintainers; { - maintainers = [ lopsided98 ]; - }; - - nodes = { - source = { ... }: { - imports = [ commonConfig ]; - networking.hostId = "daa82e91"; - - programs.ssh.extraConfig = '' - UserKnownHostsFile=/dev/null - StrictHostKeyChecking=no - ''; - - services.sanoid = { - enable = true; - templates.test = { - hourly = 12; - daily = 1; - monthly = 1; - yearly = 1; - - autosnap = true; - }; - datasets."pool/sanoid".use_template = [ "test" ]; - datasets."pool/compat".useTemplate = [ "test" ]; - extraArgs = [ "--verbose" ]; +import ./make-test-python.nix ( + { pkgs, ... }: + let + inherit (import ./ssh-keys.nix pkgs) + snakeOilPrivateKey + snakeOilPublicKey + ; + + commonConfig = + { pkgs, ... }: + { + virtualisation.emptyDiskImages = [ 2048 ]; + boot.supportedFilesystems = [ "zfs" ]; + environment.systemPackages = [ pkgs.parted ]; }; + in + { + name = "sanoid"; + meta = with pkgs.lib.maintainers; { + maintainers = [ lopsided98 ]; + }; - services.syncoid = { - enable = true; - sshKey = "/var/lib/syncoid/id_ecdsa"; - commands = { - # Sync snapshot taken by sanoid - "pool/sanoid" = { - target = "root@target:pool/sanoid"; - extraArgs = [ "--no-sync-snap" "--create-bookmark" ]; + nodes = { + source = + { ... }: + { + imports = [ commonConfig ]; + networking.hostId = "daa82e91"; + + programs.ssh.extraConfig = '' + UserKnownHostsFile=/dev/null + StrictHostKeyChecking=no + ''; + + services.sanoid = { + enable = true; + templates.test = { + hourly = 12; + daily = 1; + monthly = 1; + yearly = 1; + + autosnap = true; + }; + datasets."pool/sanoid".use_template = [ "test" ]; + datasets."pool/compat".useTemplate = [ "test" ]; + extraArgs = [ "--verbose" ]; }; - # Take snapshot and sync - "pool/syncoid".target = "root@target:pool/syncoid"; - - # Test pool without parent (regression test for https://github.com/NixOS/nixpkgs/pull/180111) - "pool".target = "root@target:pool/full-pool"; - # Test backward compatible options (regression test for https://github.com/NixOS/nixpkgs/issues/181561) - "pool/compat" = { - target = "root@target:pool/compat"; - extraArgs = [ "--no-sync-snap" ]; + services.syncoid = { + enable = true; + sshKey = "/var/lib/syncoid/id_ecdsa"; + commands = { + # Sync snapshot taken by sanoid + "pool/sanoid" = { + target = "root@target:pool/sanoid"; + extraArgs = [ + "--no-sync-snap" + "--create-bookmark" + ]; + }; + # Take snapshot and sync + "pool/syncoid".target = "root@target:pool/syncoid"; + + # Test pool without parent (regression test for https://github.com/NixOS/nixpkgs/pull/180111) + "pool".target = "root@target:pool/full-pool"; + + # Test backward compatible options (regression test for https://github.com/NixOS/nixpkgs/issues/181561) + "pool/compat" = { + target = "root@target:pool/compat"; + extraArgs = [ "--no-sync-snap" ]; + }; + }; }; }; - }; + target = + { ... }: + { + imports = [ commonConfig ]; + networking.hostId = "dcf39d36"; + + services.openssh.enable = true; + users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; + }; }; - target = { ... }: { - imports = [ commonConfig ]; - networking.hostId = "dcf39d36"; - services.openssh.enable = true; - users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; - }; - }; - - testScript = '' - source.succeed( - "mkdir /mnt", - "parted --script /dev/vdb -- mklabel msdos mkpart primary 1024M -1s", - "udevadm settle", - "zpool create pool -R /mnt /dev/vdb1", - "zfs create pool/sanoid", - "zfs create pool/compat", - "zfs create pool/syncoid", - "udevadm settle", - ) - target.succeed( - "mkdir /mnt", - "parted --script /dev/vdb -- mklabel msdos mkpart primary 1024M -1s", - "udevadm settle", - "zpool create pool -R /mnt /dev/vdb1", - "udevadm settle", - ) - - source.succeed( - "mkdir -m 700 -p /var/lib/syncoid", - "cat '${snakeOilPrivateKey}' > /var/lib/syncoid/id_ecdsa", - "chmod 600 /var/lib/syncoid/id_ecdsa", - "chown -R syncoid:syncoid /var/lib/syncoid/", - ) - - assert len(source.succeed("zfs allow pool")) == 0, "Pool shouldn't have delegated permissions set before snapshotting" - assert len(source.succeed("zfs allow pool/sanoid")) == 0, "Sanoid dataset shouldn't have delegated permissions set before snapshotting" - assert len(source.succeed("zfs allow pool/syncoid")) == 0, "Syncoid dataset shouldn't have delegated permissions set before snapshotting" - - # Take snapshot with sanoid - source.succeed("touch /mnt/pool/sanoid/test.txt") - source.succeed("touch /mnt/pool/compat/test.txt") - source.systemctl("start --wait sanoid.service") - - assert len(source.succeed("zfs allow pool")) == 0, "Pool shouldn't have delegated permissions set after snapshotting" - assert len(source.succeed("zfs allow pool/sanoid")) == 0, "Sanoid dataset shouldn't have delegated permissions set after snapshotting" - assert len(source.succeed("zfs allow pool/syncoid")) == 0, "Syncoid dataset shouldn't have delegated permissions set after snapshotting" - - # Sync snapshots - target.wait_for_open_port(22) - source.succeed("touch /mnt/pool/syncoid/test.txt") - source.systemctl("start --wait syncoid-pool-sanoid.service") - target.succeed("cat /mnt/pool/sanoid/test.txt") - source.systemctl("start --wait syncoid-pool-syncoid.service") - source.systemctl("start --wait syncoid-pool-syncoid.service") - target.succeed("cat /mnt/pool/syncoid/test.txt") - - assert(len(source.succeed("zfs list -H -t snapshot pool/syncoid").splitlines()) == 1), "Syncoid should only retain one sync snapshot" - - source.systemctl("start --wait syncoid-pool.service") - target.succeed("[[ -d /mnt/pool/full-pool/syncoid ]]") - - source.systemctl("start --wait syncoid-pool-compat.service") - target.succeed("cat /mnt/pool/compat/test.txt") - - assert len(source.succeed("zfs allow pool")) == 0, "Pool shouldn't have delegated permissions set after syncing snapshots" - assert len(source.succeed("zfs allow pool/sanoid")) == 0, "Sanoid dataset shouldn't have delegated permissions set after syncing snapshots" - assert len(source.succeed("zfs allow pool/syncoid")) == 0, "Syncoid dataset shouldn't have delegated permissions set after syncing snapshots" - ''; -}) + testScript = '' + source.succeed( + "mkdir /mnt", + "parted --script /dev/vdb -- mklabel msdos mkpart primary 1024M -1s", + "udevadm settle", + "zpool create pool -R /mnt /dev/vdb1", + "zfs create pool/sanoid", + "zfs create pool/compat", + "zfs create pool/syncoid", + "udevadm settle", + ) + target.succeed( + "mkdir /mnt", + "parted --script /dev/vdb -- mklabel msdos mkpart primary 1024M -1s", + "udevadm settle", + "zpool create pool -R /mnt /dev/vdb1", + "udevadm settle", + ) + + source.succeed( + "mkdir -m 700 -p /var/lib/syncoid", + "cat '${snakeOilPrivateKey}' > /var/lib/syncoid/id_ecdsa", + "chmod 600 /var/lib/syncoid/id_ecdsa", + "chown -R syncoid:syncoid /var/lib/syncoid/", + ) + + assert len(source.succeed("zfs allow pool")) == 0, "Pool shouldn't have delegated permissions set before snapshotting" + assert len(source.succeed("zfs allow pool/sanoid")) == 0, "Sanoid dataset shouldn't have delegated permissions set before snapshotting" + assert len(source.succeed("zfs allow pool/syncoid")) == 0, "Syncoid dataset shouldn't have delegated permissions set before snapshotting" + + # Take snapshot with sanoid + source.succeed("touch /mnt/pool/sanoid/test.txt") + source.succeed("touch /mnt/pool/compat/test.txt") + source.systemctl("start --wait sanoid.service") + + assert len(source.succeed("zfs allow pool")) == 0, "Pool shouldn't have delegated permissions set after snapshotting" + assert len(source.succeed("zfs allow pool/sanoid")) == 0, "Sanoid dataset shouldn't have delegated permissions set after snapshotting" + assert len(source.succeed("zfs allow pool/syncoid")) == 0, "Syncoid dataset shouldn't have delegated permissions set after snapshotting" + + # Sync snapshots + target.wait_for_open_port(22) + source.succeed("touch /mnt/pool/syncoid/test.txt") + source.systemctl("start --wait syncoid-pool-sanoid.service") + target.succeed("cat /mnt/pool/sanoid/test.txt") + source.systemctl("start --wait syncoid-pool-syncoid.service") + source.systemctl("start --wait syncoid-pool-syncoid.service") + target.succeed("cat /mnt/pool/syncoid/test.txt") + + assert(len(source.succeed("zfs list -H -t snapshot pool/syncoid").splitlines()) == 1), "Syncoid should only retain one sync snapshot" + + source.systemctl("start --wait syncoid-pool.service") + target.succeed("[[ -d /mnt/pool/full-pool/syncoid ]]") + + source.systemctl("start --wait syncoid-pool-compat.service") + target.succeed("cat /mnt/pool/compat/test.txt") + + assert len(source.succeed("zfs allow pool")) == 0, "Pool shouldn't have delegated permissions set after syncing snapshots" + assert len(source.succeed("zfs allow pool/sanoid")) == 0, "Sanoid dataset shouldn't have delegated permissions set after syncing snapshots" + assert len(source.succeed("zfs allow pool/syncoid")) == 0, "Syncoid dataset shouldn't have delegated permissions set after syncing snapshots" + ''; + } +) diff --git a/nixos/tests/scaphandre.nix b/nixos/tests/scaphandre.nix index f0a411748503b5..9ca191ab794b57 100644 --- a/nixos/tests/scaphandre.nix +++ b/nixos/tests/scaphandre.nix @@ -2,17 +2,21 @@ import ./make-test-python.nix { name = "scaphandre"; nodes = { - scaphandre = { pkgs, ... } : { - boot.kernelModules = [ "intel_rapl_common" ]; + scaphandre = + { pkgs, ... }: + { + boot.kernelModules = [ "intel_rapl_common" ]; - environment.systemPackages = [ pkgs.scaphandre ]; - }; + environment.systemPackages = [ pkgs.scaphandre ]; + }; }; - testScript = { nodes, ... } : '' - scaphandre.start() - scaphandre.wait_until_succeeds( - "scaphandre stdout -t 4", - ) - ''; + testScript = + { nodes, ... }: + '' + scaphandre.start() + scaphandre.wait_until_succeeds( + "scaphandre stdout -t 4", + ) + ''; } diff --git a/nixos/tests/schleuder.nix b/nixos/tests/schleuder.nix index e57ef66bb8f9da..05e22de056bd8e 100644 --- a/nixos/tests/schleuder.nix +++ b/nixos/tests/schleuder.nix @@ -4,119 +4,133 @@ let in import ./make-test-python.nix { name = "schleuder"; - nodes.machine = { pkgs, ... }: { - imports = [ ./common/user-account.nix ]; - services.postfix = { - enable = true; - enableSubmission = true; - tlsTrustedAuthorities = "${certs.ca.cert}"; - sslCert = "${certs.${domain}.cert}"; - sslKey = "${certs.${domain}.key}"; - inherit domain; - destination = [ domain ]; - localRecipients = [ "root" "alice" "bob" ]; - }; - services.schleuder = { - enable = true; - # Don't do it like this in production! The point of this setting - # is to allow loading secrets from _outside_ the world-readable - # Nix store. - extraSettingsFile = pkgs.writeText "schleuder-api-keys.yml" '' - api: - valid_api_keys: - - fnord - ''; - lists = [ "security@${domain}" ]; - settings.api = { - tls_cert_file = "${certs.${domain}.cert}"; - tls_key_file = "${certs.${domain}.key}"; + nodes.machine = + { pkgs, ... }: + { + imports = [ ./common/user-account.nix ]; + services.postfix = { + enable = true; + enableSubmission = true; + tlsTrustedAuthorities = "${certs.ca.cert}"; + sslCert = "${certs.${domain}.cert}"; + sslKey = "${certs.${domain}.key}"; + inherit domain; + destination = [ domain ]; + localRecipients = [ + "root" + "alice" + "bob" + ]; + }; + services.schleuder = { + enable = true; + # Don't do it like this in production! The point of this setting + # is to allow loading secrets from _outside_ the world-readable + # Nix store. + extraSettingsFile = pkgs.writeText "schleuder-api-keys.yml" '' + api: + valid_api_keys: + - fnord + ''; + lists = [ "security@${domain}" ]; + settings.api = { + tls_cert_file = "${certs.${domain}.cert}"; + tls_key_file = "${certs.${domain}.key}"; + }; }; - }; - environment.systemPackages = [ - pkgs.gnupg - pkgs.msmtp - (pkgs.writeScriptBin "do-test" '' - #!${pkgs.runtimeShell} - set -exuo pipefail + environment.systemPackages = [ + pkgs.gnupg + pkgs.msmtp + (pkgs.writeScriptBin "do-test" '' + #!${pkgs.runtimeShell} + set -exuo pipefail - # Generate a GPG key with no passphrase and export it - sudo -u alice gpg --passphrase-fd 0 --batch --yes --quick-generate-key 'alice@${domain}' rsa4096 sign,encr < <(echo) - sudo -u alice gpg --armor --export alice@${domain} > alice.asc - # Create a new mailing list with alice as the owner, and alice's key - schleuder-cli list new security@${domain} alice@${domain} alice.asc + # Generate a GPG key with no passphrase and export it + sudo -u alice gpg --passphrase-fd 0 --batch --yes --quick-generate-key 'alice@${domain}' rsa4096 sign,encr < <(echo) + sudo -u alice gpg --armor --export alice@${domain} > alice.asc + # Create a new mailing list with alice as the owner, and alice's key + schleuder-cli list new security@${domain} alice@${domain} alice.asc - # Send an email from a non-member of the list. Use --auto-from so we don't have to specify who it's from twice. - msmtp --auto-from security@${domain} --host=${domain} --port=25 --tls --tls-starttls < list.asc + # Find the fingerprint of the mailing list key + read list_key_fp address < <(schleuder-cli keys list security@${domain} | grep security@) + schleuder-cli keys export security@${domain} $list_key_fp > list.asc - # Import the key into alice's keyring, so we can verify it as well as decrypting - sudo -u alice gpg --import decrypted - # And check that the text matches. - grep "big security problem" decrypted - '') + # Import the key into alice's keyring, so we can verify it as well as decrypting + sudo -u alice gpg --import decrypted + # And check that the text matches. + grep "big security problem" decrypted + '') - # For debugging: - # pkgs.vim pkgs.openssl pkgs.sqliteinteractive - ]; + # For debugging: + # pkgs.vim pkgs.openssl pkgs.sqliteinteractive + ]; - security.pki.certificateFiles = [ certs.ca.cert ]; + security.pki.certificateFiles = [ certs.ca.cert ]; - # Since we don't have internet here, use dnsmasq to provide MX records from /etc/hosts - services.dnsmasq = { - enable = true; - settings.selfmx = true; - }; + # Since we don't have internet here, use dnsmasq to provide MX records from /etc/hosts + services.dnsmasq = { + enable = true; + settings.selfmx = true; + }; - networking.extraHosts = '' - 127.0.0.1 ${domain} - ''; + networking.extraHosts = '' + 127.0.0.1 ${domain} + ''; - # schleuder-cli's config is not quite optimal in several ways: - # - A fingerprint _must_ be pinned, it doesn't even have an option - # to trust the PKI - # - It compares certificate fingerprints rather than key - # fingerprints, so renewals break the pin (though that's not - # relevant for this test) - # - It compares them as strings, which means we need to match the - # expected format exactly. This means removing the :s and - # lowercasing it. - # Refs: - # https://0xacab.org/schleuder/schleuder-cli/-/issues/16 - # https://0xacab.org/schleuder/schleuder-cli/-/blob/f8895b9f47083d8c7b99a2797c93f170f3c6a3c0/lib/schleuder-cli/helper.rb#L230-238 - systemd.tmpfiles.rules = let cliconfig = pkgs.runCommand "schleuder-cli.yml" - { - nativeBuildInputs = [ pkgs.jq pkgs.openssl ]; - } '' - fp=$(openssl x509 -in ${certs.${domain}.cert} -noout -fingerprint -sha256 | cut -d = -f 2 | tr -d : | tr 'A-Z' 'a-z') - cat > $out < $out < /dev/null - ret=$? - if [ "$ret" -ne "0" ]; then - break - fi - done - return $ret - } - ping_all() { - ret=0 - for as in "$@" - do - scion ping "$as,127.0.0.1" -c 3 - ret=$? - if [ "$ret" -ne "0" ]; then - break - fi - done - return $ret - } - for i in $(seq 0 $timeout); do - sleep 1 - wait_for_all $addresses || continue - ping_all $addresses && exit 0 - done - exit 1 - ''; - in - '' - # List of AS instances - machines = [scion01, scion02, scion03, scion04, scion05] + testScript = + let + pingAll = pkgs.writeShellScript "ping-all-scion.sh" '' + addresses="42-ffaa:1:1 42-ffaa:1:2 42-ffaa:1:3 42-ffaa:1:4 42-ffaa:1:5" + timeout=100 + wait_for_all() { + ret=0 + for as in "$@" + do + scion showpaths $as --no-probe > /dev/null + ret=$? + if [ "$ret" -ne "0" ]; then + break + fi + done + return $ret + } + ping_all() { + ret=0 + for as in "$@" + do + scion ping "$as,127.0.0.1" -c 3 + ret=$? + if [ "$ret" -ne "0" ]; then + break + fi + done + return $ret + } + for i in $(seq 0 $timeout); do + sleep 1 + wait_for_all $addresses || continue + ping_all $addresses && exit 0 + done + exit 1 + ''; + in + '' + # List of AS instances + machines = [scion01, scion02, scion03, scion04, scion05] - # Functions to avoid many for loops - def start(allow_reboot=False): - for i in machines: - i.start(allow_reboot=allow_reboot) + # Functions to avoid many for loops + def start(allow_reboot=False): + for i in machines: + i.start(allow_reboot=allow_reboot) - def wait_for_unit(service_name): - for i in machines: - i.wait_for_unit(service_name) + def wait_for_unit(service_name): + for i in machines: + i.wait_for_unit(service_name) - def succeed(command): - for i in machines: - i.succeed(command) + def succeed(command): + for i in machines: + i.succeed(command) - def reboot(): - for i in machines: - i.reboot() + def reboot(): + for i in machines: + i.reboot() - def crash(): - for i in machines: - i.crash() + def crash(): + for i in machines: + i.crash() - # Start all machines, allowing reboot for later - start(allow_reboot=True) + # Start all machines, allowing reboot for later + start(allow_reboot=True) - # Wait for scion-control.service on all instances - wait_for_unit("scion-control.service") + # Wait for scion-control.service on all instances + wait_for_unit("scion-control.service") - # Ensure cert is valid against TRC - succeed("scion-pki certificate verify --trc /etc/scion/certs/*.trc /etc/scion/crypto/as/*.pem >&2") + # Ensure cert is valid against TRC + succeed("scion-pki certificate verify --trc /etc/scion/certs/*.trc /etc/scion/crypto/as/*.pem >&2") - # Execute pingAll command on all instances - succeed("${pingAll} >&2") + # Execute pingAll command on all instances + succeed("${pingAll} >&2") - # Execute ICMP pings across scion-ip-gateway - scion04.succeed("ping -c 3 172.16.100.1 >&2") - scion05.succeed("ping -c 3 172.16.1.1 >&2") + # Execute ICMP pings across scion-ip-gateway + scion04.succeed("ping -c 3 172.16.100.1 >&2") + scion05.succeed("ping -c 3 172.16.1.1 >&2") - # Restart all scion services and ping again to test robustness - succeed("systemctl restart scion-* >&2") - succeed("${pingAll} >&2") + # Restart all scion services and ping again to test robustness + succeed("systemctl restart scion-* >&2") + succeed("${pingAll} >&2") - # Reboot machines, wait for service, and ping again - reboot() - wait_for_unit("scion-control.service") - succeed("${pingAll} >&2") + # Reboot machines, wait for service, and ping again + reboot() + wait_for_unit("scion-control.service") + succeed("${pingAll} >&2") - # Crash, start, wait for service, and ping again - crash() - start() - wait_for_unit("scion-control.service") - succeed("pkill -9 scion-* >&2") - wait_for_unit("scion-control.service") - succeed("${pingAll} >&2") - ''; -}) + # Crash, start, wait for service, and ping again + crash() + start() + wait_for_unit("scion-control.service") + succeed("pkill -9 scion-* >&2") + wait_for_unit("scion-control.service") + succeed("${pingAll} >&2") + ''; + } +) diff --git a/nixos/tests/scrutiny.nix b/nixos/tests/scrutiny.nix index 4ac1b47952e089..a81dd60d851836 100644 --- a/nixos/tests/scrutiny.nix +++ b/nixos/tests/scrutiny.nix @@ -1,66 +1,83 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "scrutiny"; - meta.maintainers = with lib.maintainers; [ jnsgruk ]; + { + name = "scrutiny"; + meta.maintainers = with lib.maintainers; [ jnsgruk ]; - nodes = { - machine = { self, pkgs, lib, ... }: { - services = { - scrutiny.enable = true; - scrutiny.collector.enable = true; - }; + nodes = { + machine = + { + self, + pkgs, + lib, + ... + }: + { + services = { + scrutiny.enable = true; + scrutiny.collector.enable = true; + }; - environment.systemPackages = - let - seleniumScript = pkgs.writers.writePython3Bin "selenium-script" - { - libraries = with pkgs.python3Packages; [ selenium ]; - } '' - from selenium import webdriver - from selenium.webdriver.common.by import By - from selenium.webdriver.firefox.options import Options - from selenium.webdriver.support.ui import WebDriverWait - from selenium.webdriver.support import expected_conditions as EC + environment.systemPackages = + let + seleniumScript = + pkgs.writers.writePython3Bin "selenium-script" + { + libraries = with pkgs.python3Packages; [ selenium ]; + } + '' + from selenium import webdriver + from selenium.webdriver.common.by import By + from selenium.webdriver.firefox.options import Options + from selenium.webdriver.support.ui import WebDriverWait + from selenium.webdriver.support import expected_conditions as EC - options = Options() - options.add_argument("--headless") - service = webdriver.FirefoxService(executable_path="${lib.getExe pkgs.geckodriver}") # noqa: E501 + options = Options() + options.add_argument("--headless") + service = webdriver.FirefoxService(executable_path="${lib.getExe pkgs.geckodriver}") # noqa: E501 - driver = webdriver.Firefox(options=options, service=service) - driver.implicitly_wait(10) - driver.get("http://localhost:8080/web/dashboard") + driver = webdriver.Firefox(options=options, service=service) + driver.implicitly_wait(10) + driver.get("http://localhost:8080/web/dashboard") - wait = WebDriverWait(driver, 10).until( - EC.text_to_be_present_in_element( - (By.TAG_NAME, "body"), "Drive health at a glance") - ) + wait = WebDriverWait(driver, 10).until( + EC.text_to_be_present_in_element( + (By.TAG_NAME, "body"), "Drive health at a glance") + ) - body_text = driver.find_element(By.TAG_NAME, "body").text - assert "Temperature history for each device" in body_text + body_text = driver.find_element(By.TAG_NAME, "body").text + assert "Temperature history for each device" in body_text - driver.close() - ''; - in - with pkgs; [ curl firefox-unwrapped geckodriver seleniumScript ]; + driver.close() + ''; + in + with pkgs; + [ + curl + firefox-unwrapped + geckodriver + seleniumScript + ]; + }; }; - }; - # This is the test code that will check if our service is running correctly: - testScript = '' - start_all() + # This is the test code that will check if our service is running correctly: + testScript = '' + start_all() - # Wait for Scrutiny to be available - machine.wait_for_unit("scrutiny") - machine.wait_for_open_port(8080) + # Wait for Scrutiny to be available + machine.wait_for_unit("scrutiny") + machine.wait_for_open_port(8080) - # Ensure the API responds as we expect - output = machine.succeed("curl localhost:8080/api/health") - assert output == '{"success":true}' + # Ensure the API responds as we expect + output = machine.succeed("curl localhost:8080/api/health") + assert output == '{"success":true}' - # Start the collector service to send some metrics - collect = machine.succeed("systemctl start scrutiny-collector.service") + # Start the collector service to send some metrics + collect = machine.succeed("systemctl start scrutiny-collector.service") - # Ensure the application is actually rendered by the Javascript - machine.succeed("PYTHONUNBUFFERED=1 selenium-script") - ''; -}) + # Ensure the application is actually rendered by the Javascript + machine.succeed("PYTHONUNBUFFERED=1 selenium-script") + ''; + } +) diff --git a/nixos/tests/sddm.nix b/nixos/tests/sddm.nix index 3ca105cf9713d5..aaf271dab5b8f2 100644 --- a/nixos/tests/sddm.nix +++ b/nixos/tests/sddm.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -12,27 +13,32 @@ let default = { name = "sddm"; - nodes.machine = { ... }: { - imports = [ ./common/user-account.nix ]; - services.xserver.enable = true; - services.displayManager.sddm.enable = true; - services.displayManager.defaultSession = "none+icewm"; - services.xserver.windowManager.icewm.enable = true; - }; + nodes.machine = + { ... }: + { + imports = [ ./common/user-account.nix ]; + services.xserver.enable = true; + services.displayManager.sddm.enable = true; + services.displayManager.defaultSession = "none+icewm"; + services.xserver.windowManager.icewm.enable = true; + }; enableOCR = true; - testScript = { nodes, ... }: let - user = nodes.machine.users.users.alice; - in '' - start_all() - machine.wait_for_text("(?i)select your user") - machine.screenshot("sddm") - machine.send_chars("${user.password}\n") - machine.wait_for_file("/tmp/xauth_*") - machine.succeed("xauth merge /tmp/xauth_*") - machine.wait_for_window("^IceWM ") - ''; + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + in + '' + start_all() + machine.wait_for_text("(?i)select your user") + machine.screenshot("sddm") + machine.send_chars("${user.password}\n") + machine.wait_for_file("/tmp/xauth_*") + machine.succeed("xauth merge /tmp/xauth_*") + machine.wait_for_window("^IceWM ") + ''; }; autoLogin = { @@ -41,27 +47,31 @@ let maintainers = [ ttuegel ]; }; - nodes.machine = { ... }: { - imports = [ ./common/user-account.nix ]; - services.xserver.enable = true; - services.displayManager = { - sddm.enable = true; - autoLogin = { - enable = true; - user = "alice"; + nodes.machine = + { ... }: + { + imports = [ ./common/user-account.nix ]; + services.xserver.enable = true; + services.displayManager = { + sddm.enable = true; + autoLogin = { + enable = true; + user = "alice"; + }; }; + services.displayManager.defaultSession = "none+icewm"; + services.xserver.windowManager.icewm.enable = true; }; - services.displayManager.defaultSession = "none+icewm"; - services.xserver.windowManager.icewm.enable = true; - }; - testScript = { nodes, ... }: '' - start_all() - machine.wait_for_file("/tmp/xauth_*") - machine.succeed("xauth merge /tmp/xauth_*") - machine.wait_for_window("^IceWM ") - ''; + testScript = + { nodes, ... }: + '' + start_all() + machine.wait_for_file("/tmp/xauth_*") + machine.succeed("xauth merge /tmp/xauth_*") + machine.wait_for_window("^IceWM ") + ''; }; }; in - lib.mapAttrs (lib.const makeTest) tests +lib.mapAttrs (lib.const makeTest) tests diff --git a/nixos/tests/seafile.nix b/nixos/tests/seafile.nix index 7784d5fddaedd1..54aa582149d58c 100644 --- a/nixos/tests/seafile.nix +++ b/nixos/tests/seafile.nix @@ -1,43 +1,57 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: let - client = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.seafile-shared pkgs.curl ]; - }; - in { + client = + { config, pkgs, ... }: + { + environment.systemPackages = [ + pkgs.seafile-shared + pkgs.curl + ]; + }; + in + { name = "seafile"; meta = with pkgs.lib.maintainers; { - maintainers = [ kampfschlaefer schmittlauch ]; + maintainers = [ + kampfschlaefer + schmittlauch + ]; }; nodes = { - server = { config, pkgs, ... }: { - services.seafile = { - enable = true; - ccnetSettings.General.SERVICE_URL = "http://server"; - seafileSettings.fileserver.host = "unix:/run/seafile/server.sock"; - adminEmail = "admin@example.com"; - initialAdminPassword = "seafile_password"; - }; - services.nginx = { - enable = true; - virtualHosts."server" = { - locations."/".proxyPass = "http://unix:/run/seahub/gunicorn.sock"; - locations."/seafhttp" = { - proxyPass = "http://unix:/run/seafile/server.sock"; - extraConfig = '' - rewrite ^/seafhttp(.*)$ $1 break; - client_max_body_size 0; - proxy_connect_timeout 36000s; - proxy_read_timeout 36000s; - proxy_send_timeout 36000s; - send_timeout 36000s; - proxy_http_version 1.1; - ''; + server = + { config, pkgs, ... }: + { + services.seafile = { + enable = true; + ccnetSettings.General.SERVICE_URL = "http://server"; + seafileSettings.fileserver.host = "unix:/run/seafile/server.sock"; + adminEmail = "admin@example.com"; + initialAdminPassword = "seafile_password"; + }; + services.nginx = { + enable = true; + virtualHosts."server" = { + locations."/".proxyPass = "http://unix:/run/seahub/gunicorn.sock"; + locations."/seafhttp" = { + proxyPass = "http://unix:/run/seafile/server.sock"; + extraConfig = '' + rewrite ^/seafhttp(.*)$ $1 break; + client_max_body_size 0; + proxy_connect_timeout 36000s; + proxy_read_timeout 36000s; + proxy_send_timeout 36000s; + send_timeout 36000s; + proxy_http_version 1.1; + ''; + }; }; }; + networking.firewall = { + allowedTCPPorts = [ 80 ]; + }; }; - networking.firewall = { allowedTCPPorts = [ 80 ]; }; - }; client1 = client pkgs; client2 = client pkgs; }; @@ -113,4 +127,5 @@ import ./make-test-python.nix ({ pkgs, ... }: client2.succeed('[ `cat test01/first_file` = "bla" ]') ''; - }) + } +) diff --git a/nixos/tests/seatd.nix b/nixos/tests/seatd.nix index 9178492fdb0ef6..8ba79ca495843e 100644 --- a/nixos/tests/seatd.nix +++ b/nixos/tests/seatd.nix @@ -1,51 +1,58 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: -let - seatd-test = pkgs.writeShellApplication { - name = "seatd-client-pid"; - text = '' - journalctl -u seatd --no-pager -b | while read -r line; do - case "$line" in - *"New client connected"*) - line="''${line##*pid: }" - pid="''${line%%,*}" - ;; - *"Opened client"*) - echo "$pid" - exit - esac - done; - ''; - }; -in -{ - name = "seatd"; - meta.maintainers = with lib.maintainers; [ sinanmohd ]; + let + seatd-test = pkgs.writeShellApplication { + name = "seatd-client-pid"; + text = '' + journalctl -u seatd --no-pager -b | while read -r line; do + case "$line" in + *"New client connected"*) + line="''${line##*pid: }" + pid="''${line%%,*}" + ;; + *"Opened client"*) + echo "$pid" + exit + esac + done; + ''; + }; + in + { + name = "seatd"; + meta.maintainers = with lib.maintainers; [ sinanmohd ]; - nodes.machine = { ... }: { - imports = [ ./common/user-account.nix ]; - services.getty.autologinUser = "alice"; - users.users.alice.extraGroups = [ "seat" "wheel" ]; + nodes.machine = + { ... }: + { + imports = [ ./common/user-account.nix ]; + services.getty.autologinUser = "alice"; + users.users.alice.extraGroups = [ + "seat" + "wheel" + ]; - fonts.enableDefaultPackages = true; - environment.systemPackages = with pkgs; [ - dwl - foot - seatd-test - ]; + fonts.enableDefaultPackages = true; + environment.systemPackages = with pkgs; [ + dwl + foot + seatd-test + ]; - programs.bash.loginShellInit = '' - [ "$(tty)" = "/dev/tty1" ] && - dwl -s 'foot touch /tmp/foot_started' - ''; + programs.bash.loginShellInit = '' + [ "$(tty)" = "/dev/tty1" ] && + dwl -s 'foot touch /tmp/foot_started' + ''; - hardware.graphics.enable = true; - virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ]; - services.seatd.enable = true; - }; + hardware.graphics.enable = true; + virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ]; + services.seatd.enable = true; + }; - testScript = '' - machine.wait_for_file("/tmp/foot_started") - machine.succeed("test $(seatd-client-pid) = $(pgrep dwl)") - ''; -}) + testScript = '' + machine.wait_for_file("/tmp/foot_started") + machine.succeed("test $(seatd-client-pid) = $(pgrep dwl)") + ''; + } +) diff --git a/nixos/tests/service-runner.nix b/nixos/tests/service-runner.nix index 79d96f739a6c83..42d87c384234d9 100644 --- a/nixos/tests/service-runner.nix +++ b/nixos/tests/service-runner.nix @@ -1,36 +1,43 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "service-runner"; - meta = with pkgs.lib.maintainers; { - maintainers = [ roberth ]; - }; - - nodes = { - machine = { pkgs, lib, ... }: { - services.nginx.enable = true; - services.nginx.virtualHosts.machine.root = pkgs.runCommand "webroot" {} '' - mkdir $out - echo 'yay' >$out/index.html - ''; - systemd.services.nginx.enable = false; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "service-runner"; + meta = with pkgs.lib.maintainers; { + maintainers = [ roberth ]; }; - }; + nodes = { + machine = + { pkgs, lib, ... }: + { + services.nginx.enable = true; + services.nginx.virtualHosts.machine.root = pkgs.runCommand "webroot" { } '' + mkdir $out + echo 'yay' >$out/index.html + ''; + systemd.services.nginx.enable = false; + }; - testScript = { nodes, ... }: '' - url = "http://localhost/index.html" + }; - with subtest("check systemd.services.nginx.runner"): - machine.fail(f"curl {url}") - machine.succeed( - """ - mkdir -p /run/nginx /var/log/nginx /var/cache/nginx - ${nodes.machine.config.systemd.services.nginx.runner} >&2 & - echo $!>my-nginx.pid - """ - ) - machine.wait_for_open_port(80) - machine.succeed(f"curl -f {url}") - machine.succeed("kill -INT $(cat my-nginx.pid)") - machine.wait_for_closed_port(80) - ''; -}) + testScript = + { nodes, ... }: + '' + url = "http://localhost/index.html" + + with subtest("check systemd.services.nginx.runner"): + machine.fail(f"curl {url}") + machine.succeed( + """ + mkdir -p /run/nginx /var/log/nginx /var/cache/nginx + ${nodes.machine.config.systemd.services.nginx.runner} >&2 & + echo $!>my-nginx.pid + """ + ) + machine.wait_for_open_port(80) + machine.succeed(f"curl -f {url}") + machine.succeed("kill -INT $(cat my-nginx.pid)") + machine.wait_for_closed_port(80) + ''; + } +) diff --git a/nixos/tests/sftpgo.nix b/nixos/tests/sftpgo.nix index a5bb1981d2c3c7..e3f7491a90d883 100644 --- a/nixos/tests/sftpgo.nix +++ b/nixos/tests/sftpgo.nix @@ -10,14 +10,13 @@ # # Additional test coverage for the remaining protocols (i.e. ftp, http and webdav) # would be a nice to have for the future. -{ pkgs, lib, ... }: +{ pkgs, lib, ... }: let inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; # Returns an attributeset of users who are not system users. - normalUsers = config: - lib.filterAttrs (name: user: user.isNormalUser) config.users.users; + normalUsers = config: lib.filterAttrs (name: user: user.isNormalUser) config.users.users; # Returns true if a user is a member of the given group isMemberOf = @@ -26,7 +25,7 @@ let groupName: # users.users attrset user: - lib.any (x: x == user.name) config.users.groups.${groupName}.members; + lib.any (x: x == user.name) config.users.groups.${groupName}.members; # Generates a valid SFTPGo user configuration for a given user # Will be converted to JSON and loaded on application startup. @@ -51,25 +50,28 @@ let # Supported for local filesystem only. If one or more of the specified folders are not # inside the dataprovider they will be automatically created. # You have to create the folder on the filesystem yourself - virtual_folders = - lib.optional (isMemberOf config sharedFolderName user) { - name = sharedFolderName; - mapped_path = "${config.services.sftpgo.dataDir}/${sharedFolderName}"; - virtual_path = "/${sharedFolderName}"; - }; + virtual_folders = lib.optional (isMemberOf config sharedFolderName user) { + name = sharedFolderName; + mapped_path = "${config.services.sftpgo.dataDir}/${sharedFolderName}"; + virtual_path = "/${sharedFolderName}"; + }; # Defines the ACL on the virtual filesystem permissions = - lib.recursiveUpdate { - "/" = [ "list" ]; # read-only top level directory - "/private" = [ "*" ]; # private subdirectory, not shared with others - } (lib.optionalAttrs (isMemberOf config "shared" user) { - "/shared" = [ "*" ]; - }); + lib.recursiveUpdate + { + "/" = [ "list" ]; # read-only top level directory + "/private" = [ "*" ]; # private subdirectory, not shared with others + } + ( + lib.optionalAttrs (isMemberOf config "shared" user) { + "/shared" = [ "*" ]; + } + ); filters = { - allowed_ip = []; - denied_ip = []; + allowed_ip = [ ]; + denied_ip = [ ]; web_client = [ "password-change-disabled" "password-reset-disabled" @@ -87,28 +89,31 @@ let # Generates a json file containing a static configuration # of users and folders to import to SFTPGo. - loadDataJson = config: pkgs.writeText "users-and-folders.json" (builtins.toJSON { - users = - lib.mapAttrsToList (name: user: generateUserAttrSet config user) (normalUsers config); - - folders = [ - { - name = sharedFolderName; - description = "shared folder"; - - # 0: local filesystem - # 1: AWS S3 compatible - # 2: Google Cloud Storage - filesystem.provider = 0; - - # Mapped path on the local filesystem - mapped_path = "${config.services.sftpgo.dataDir}/${sharedFolderName}"; - - # All users in the matching group gain access - users = config.users.groups.${sharedFolderName}.members; + loadDataJson = + config: + pkgs.writeText "users-and-folders.json" ( + builtins.toJSON { + users = lib.mapAttrsToList (name: user: generateUserAttrSet config user) (normalUsers config); + + folders = [ + { + name = sharedFolderName; + description = "shared folder"; + + # 0: local filesystem + # 1: AWS S3 compatible + # 2: Google Cloud Storage + filesystem.provider = 0; + + # Mapped path on the local filesystem + mapped_path = "${config.services.sftpgo.dataDir}/${sharedFolderName}"; + + # All users in the matching group gain access + users = config.users.groups.${sharedFolderName}.members; + } + ]; } - ]; - }); + ); # Generated Host Key for connecting to SFTPGo's sftp subsystem. snakeOilHostKey = pkgs.writeText "sftpgo_ed25519_host_key" '' @@ -147,236 +152,264 @@ in meta.maintainers = with lib.maintainers; [ yayayayaka ]; nodes = { - server = { nodes, ... }: { - networking.firewall.allowedTCPPorts = [ sftpPort httpPort ]; - - # nodes.server.configure postgresql database - services.postgresql = { - enable = true; - ensureDatabases = [ "sftpgo" ]; - ensureUsers = [{ - name = "sftpgo"; - ensureDBOwnership = true; - }]; - }; - - services.sftpgo = { - enable = true; + server = + { nodes, ... }: + { + networking.firewall.allowedTCPPorts = [ + sftpPort + httpPort + ]; - loadDataFile = (loadDataJson nodes.server); + # nodes.server.configure postgresql database + services.postgresql = { + enable = true; + ensureDatabases = [ "sftpgo" ]; + ensureUsers = [ + { + name = "sftpgo"; + ensureDBOwnership = true; + } + ]; + }; - settings = { - data_provider = { - driver = "postgresql"; - name = "sftpgo"; - username = "sftpgo"; - host = "/run/postgresql"; - port = 5432; + services.sftpgo = { + enable = true; - # Enables the possibility to create an initial admin user on first startup. - create_default_admin = true; - }; + loadDataFile = (loadDataJson nodes.server); - httpd.bindings = [ - { - address = ""; # listen on all interfaces - port = httpPort; - enable_https = false; + settings = { + data_provider = { + driver = "postgresql"; + name = "sftpgo"; + username = "sftpgo"; + host = "/run/postgresql"; + port = 5432; - enable_web_client = true; - enable_web_admin = true; - } - ]; + # Enables the possibility to create an initial admin user on first startup. + create_default_admin = true; + }; - # Enable sftpd - sftpd = { - bindings = [{ - address = ""; # listen on all interfaces - port = sftpPort; - }]; - host_keys = [ snakeOilHostKey ]; - password_authentication = false; - keyboard_interactive_authentication = false; + httpd.bindings = [ + { + address = ""; # listen on all interfaces + port = httpPort; + enable_https = false; + + enable_web_client = true; + enable_web_admin = true; + } + ]; + + # Enable sftpd + sftpd = { + bindings = [ + { + address = ""; # listen on all interfaces + port = sftpPort; + } + ]; + host_keys = [ snakeOilHostKey ]; + password_authentication = false; + keyboard_interactive_authentication = false; + }; }; }; - }; - systemd.services.sftpgo = { - after = [ "postgresql.service"]; - environment = { - # Update existing users - SFTPGO_LOADDATA_MODE = "0"; - SFTPGO_DEFAULT_ADMIN_USERNAME = adminUsername; + systemd.services.sftpgo = { + after = [ "postgresql.service" ]; + environment = { + # Update existing users + SFTPGO_LOADDATA_MODE = "0"; + SFTPGO_DEFAULT_ADMIN_USERNAME = adminUsername; - # This will end up in cleartext in the systemd service. - # Don't use this approach in production! - SFTPGO_DEFAULT_ADMIN_PASSWORD = adminPassword; + # This will end up in cleartext in the systemd service. + # Don't use this approach in production! + SFTPGO_DEFAULT_ADMIN_PASSWORD = adminPassword; + }; }; - }; - # Sets up the folder hierarchy on the local filesystem - systemd.tmpfiles.rules = - let - sftpgoUser = nodes.server.services.sftpgo.user; - sftpgoGroup = nodes.server.services.sftpgo.group; - statePath = nodes.server.services.sftpgo.dataDir; - in [ - # Create state directory - "d ${statePath} 0750 ${sftpgoUser} ${sftpgoGroup} -" - "d ${statePath}/users 0750 ${sftpgoUser} ${sftpgoGroup} -" - - # Created shared folder directories - "d ${statePath}/${sharedFolderName} 2770 ${sftpgoUser} ${sharedFolderName} -" - ] - ++ lib.mapAttrsToList (name: user: - # Create private user directories - '' - d ${statePath}/users/${user.name} 0700 ${sftpgoUser} ${sftpgoGroup} - - d ${statePath}/users/${user.name}/private 0700 ${sftpgoUser} ${sftpgoGroup} - - '' - ) (normalUsers nodes.server); - - users.users = - let - commonAttrs = { - isNormalUser = true; - openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; - }; - in { - # SFTPGo admin user - admin = commonAttrs // { - password = adminPassword; - }; + # Sets up the folder hierarchy on the local filesystem + systemd.tmpfiles.rules = + let + sftpgoUser = nodes.server.services.sftpgo.user; + sftpgoGroup = nodes.server.services.sftpgo.group; + statePath = nodes.server.services.sftpgo.dataDir; + in + [ + # Create state directory + "d ${statePath} 0750 ${sftpgoUser} ${sftpgoGroup} -" + "d ${statePath}/users 0750 ${sftpgoUser} ${sftpgoGroup} -" + + # Created shared folder directories + "d ${statePath}/${sharedFolderName} 2770 ${sftpgoUser} ${sharedFolderName} -" + ] + ++ lib.mapAttrsToList ( + name: user: + # Create private user directories + '' + d ${statePath}/users/${user.name} 0700 ${sftpgoUser} ${sftpgoGroup} - + d ${statePath}/users/${user.name}/private 0700 ${sftpgoUser} ${sftpgoGroup} - + '') (normalUsers nodes.server); + + users.users = + let + commonAttrs = { + isNormalUser = true; + openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; + }; + in + { + # SFTPGo admin user + admin = commonAttrs // { + password = adminPassword; + }; - # Alice and bob share folders with each other - alice = commonAttrs // { - password = alicePassword; - extraGroups = [ sharedFolderName ]; - }; + # Alice and bob share folders with each other + alice = commonAttrs // { + password = alicePassword; + extraGroups = [ sharedFolderName ]; + }; - bob = commonAttrs // { - password = bobPassword; - extraGroups = [ sharedFolderName ]; - }; + bob = commonAttrs // { + password = bobPassword; + extraGroups = [ sharedFolderName ]; + }; - # Eve has no shared folders - eve = commonAttrs // { - password = evePassword; + # Eve has no shared folders + eve = commonAttrs // { + password = evePassword; + }; }; - }; - users.groups.${sharedFolderName} = {}; - - specialisation = { - # A specialisation for asserting that SFTPGo can bind to privileged ports. - privilegedPorts.configuration = { ... }: { - networking.firewall.allowedTCPPorts = [ 22 80 ]; - services.sftpgo = { - settings = { - sftpd.bindings = lib.mkForce [{ - address = ""; - port = 22; - }]; - - httpd.bindings = lib.mkForce [{ - address = ""; - port = 80; - }]; + users.groups.${sharedFolderName} = { }; + + specialisation = { + # A specialisation for asserting that SFTPGo can bind to privileged ports. + privilegedPorts.configuration = + { ... }: + { + networking.firewall.allowedTCPPorts = [ + 22 + 80 + ]; + services.sftpgo = { + settings = { + sftpd.bindings = lib.mkForce [ + { + address = ""; + port = 22; + } + ]; + + httpd.bindings = lib.mkForce [ + { + address = ""; + port = 80; + } + ]; + }; + }; }; - }; }; }; - }; - client = { nodes, ... }: { - # Add the SFTPGo host key to the global known_hosts file - programs.ssh.knownHosts = - let - commonAttrs = { - publicKey = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIE61C7pTXfnLG2u9So+ijNTKaSOg009UrquqNL3fpEu1"; + client = + { nodes, ... }: + { + # Add the SFTPGo host key to the global known_hosts file + programs.ssh.knownHosts = + let + commonAttrs = { + publicKey = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIE61C7pTXfnLG2u9So+ijNTKaSOg009UrquqNL3fpEu1"; + }; + in + { + "server" = commonAttrs; + "[server]:2022" = commonAttrs; }; - in { - "server" = commonAttrs; - "[server]:2022" = commonAttrs; - }; }; }; - testScript = { nodes, ... }: let - # A function to generate test cases for wheter - # a specified username is expected to access the shared folder. - accessSharedFoldersSubtest = - { # The username to run as - username - # Whether the tests are expected to succeed or not - , shouldSucceed ? true - }: '' - with subtest("Test whether ${username} can access shared folders"): - client.${if shouldSucceed then "succeed" else "fail"}("sftp -P ${toString sftpPort} -b ${ - pkgs.writeText "${username}-ls-${sharedFolderName}" '' + testScript = + { nodes, ... }: + let + # A function to generate test cases for wheter + # a specified username is expected to access the shared folder. + accessSharedFoldersSubtest = + { + # The username to run as + username, + # Whether the tests are expected to succeed or not + shouldSucceed ? true, + }: + '' + with subtest("Test whether ${username} can access shared folders"): + client.${ + if shouldSucceed then "succeed" else "fail" + }("sftp -P ${toString sftpPort} -b ${pkgs.writeText "${username}-ls-${sharedFolderName}" '' ls ${sharedFolderName} - '' - } ${username}@server") - ''; + ''} ${username}@server") + ''; statePath = nodes.server.services.sftpgo.dataDir; - in '' - start_all() + in + '' + start_all() - client.wait_for_unit("default.target") - server.wait_for_unit("sftpgo.service") + client.wait_for_unit("default.target") + server.wait_for_unit("sftpgo.service") - with subtest("web client"): - client.wait_until_succeeds("curl -sSf http://server:${toString httpPort}/web/client/login") + with subtest("web client"): + client.wait_until_succeeds("curl -sSf http://server:${toString httpPort}/web/client/login") - # Ensure sftpgo found the static folder - client.wait_until_succeeds("curl -o /dev/null -sSf http://server:${toString httpPort}/static/favicon.ico") + # Ensure sftpgo found the static folder + client.wait_until_succeeds("curl -o /dev/null -sSf http://server:${toString httpPort}/static/favicon.ico") - with subtest("Setup SSH keys"): - client.succeed("mkdir -m 700 /root/.ssh") - client.succeed("cat ${snakeOilPrivateKey} > /root/.ssh/id_ecdsa") - client.succeed("chmod 600 /root/.ssh/id_ecdsa") + with subtest("Setup SSH keys"): + client.succeed("mkdir -m 700 /root/.ssh") + client.succeed("cat ${snakeOilPrivateKey} > /root/.ssh/id_ecdsa") + client.succeed("chmod 600 /root/.ssh/id_ecdsa") - with subtest("Copy a file over sftp"): - client.wait_until_succeeds("scp -P ${toString sftpPort} ${toString testFile} alice@server:/private/${testFile.name}") - server.succeed("test -s ${statePath}/users/alice/private/${testFile.name}") + with subtest("Copy a file over sftp"): + client.wait_until_succeeds("scp -P ${toString sftpPort} ${toString testFile} alice@server:/private/${testFile.name}") + server.succeed("test -s ${statePath}/users/alice/private/${testFile.name}") - # The configured ACL should prevent uploading files to the root directory - client.fail("scp -P ${toString sftpPort} ${toString testFile} alice@server:/") + # The configured ACL should prevent uploading files to the root directory + client.fail("scp -P ${toString sftpPort} ${toString testFile} alice@server:/") - with subtest("Attempting an interactive SSH sessions must fail"): - client.fail("ssh -p ${toString sftpPort} alice@server") + with subtest("Attempting an interactive SSH sessions must fail"): + client.fail("ssh -p ${toString sftpPort} alice@server") - ${accessSharedFoldersSubtest { - username = "alice"; - shouldSucceed = true; - }} + ${accessSharedFoldersSubtest { + username = "alice"; + shouldSucceed = true; + }} - ${accessSharedFoldersSubtest { - username = "bob"; - shouldSucceed = true; - }} + ${accessSharedFoldersSubtest { + username = "bob"; + shouldSucceed = true; + }} - ${accessSharedFoldersSubtest { - username = "eve"; - shouldSucceed = false; - }} + ${accessSharedFoldersSubtest { + username = "eve"; + shouldSucceed = false; + }} - with subtest("Test sharing files"): - # Alice uploads a file to shared folder - client.succeed("scp -P ${toString sftpPort} ${toString sharedFile} alice@server:/${sharedFolderName}/${sharedFile.name}") - server.succeed("test -s ${statePath}/${sharedFolderName}/${sharedFile.name}") + with subtest("Test sharing files"): + # Alice uploads a file to shared folder + client.succeed("scp -P ${toString sftpPort} ${toString sharedFile} alice@server:/${sharedFolderName}/${sharedFile.name}") + server.succeed("test -s ${statePath}/${sharedFolderName}/${sharedFile.name}") - # Bob downloads the file from shared folder - client.succeed("scp -P ${toString sftpPort} bob@server:/shared/${sharedFile.name} ${sharedFile.name}") - client.succeed("test -s ${sharedFile.name}") + # Bob downloads the file from shared folder + client.succeed("scp -P ${toString sftpPort} bob@server:/shared/${sharedFile.name} ${sharedFile.name}") + client.succeed("test -s ${sharedFile.name}") - # Eve should not get the file from shared folder - client.fail("scp -P ${toString sftpPort} eve@server:/shared/${sharedFile.name}") + # Eve should not get the file from shared folder + client.fail("scp -P ${toString sftpPort} eve@server:/shared/${sharedFile.name}") - server.succeed("/run/current-system/specialisation/privilegedPorts/bin/switch-to-configuration test") + server.succeed("/run/current-system/specialisation/privilegedPorts/bin/switch-to-configuration test") - client.wait_until_succeeds("sftp -P 22 -b ${pkgs.writeText "get-hello-world.txt" '' - get /private/${testFile.name} - ''} alice@server") - ''; + client.wait_until_succeeds("sftp -P 22 -b ${pkgs.writeText "get-hello-world.txt" '' + get /private/${testFile.name} + ''} alice@server") + ''; } diff --git a/nixos/tests/sfxr-qt.nix b/nixos/tests/sfxr-qt.nix index cca3e5f3ea7654..d3696a57604174 100644 --- a/nixos/tests/sfxr-qt.nix +++ b/nixos/tests/sfxr-qt.nix @@ -1,22 +1,25 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "sfxr-qt"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fgaz ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "sfxr-qt"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fgaz ]; + }; - machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; - environment.systemPackages = [ pkgs.sfxr-qt ]; - }; + services.xserver.enable = true; + environment.systemPackages = [ pkgs.sfxr-qt ]; + }; - enableOCR = true; + enableOCR = true; - testScript = - '' + testScript = '' machine.wait_for_x() # Add a dummy sound card, or the program won't start machine.execute("modprobe snd-dummy") @@ -28,4 +31,5 @@ import ./make-test-python.nix ({ pkgs, ... }: { machine.wait_for_text("requency") machine.screenshot("screen") ''; -}) + } +) diff --git a/nixos/tests/sgt-puzzles.nix b/nixos/tests/sgt-puzzles.nix index 4c5210bfce7782..e5a92690854b2f 100644 --- a/nixos/tests/sgt-puzzles.nix +++ b/nixos/tests/sgt-puzzles.nix @@ -1,34 +1,38 @@ -import ./make-test-python.nix ({ pkgs, ...} : -{ - name = "sgt-puzzles"; - meta = with pkgs.lib.maintainers; { - maintainers = [ tomfitzhenry ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "sgt-puzzles"; + meta = with pkgs.lib.maintainers; { + maintainers = [ tomfitzhenry ]; + }; - nodes.machine = { ... }: + nodes.machine = + { ... }: - { - imports = [ - ./common/x11.nix - ]; + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; - environment.systemPackages = with pkgs; [ - sgt-puzzles - ]; - }; + services.xserver.enable = true; + environment.systemPackages = with pkgs; [ + sgt-puzzles + ]; + }; - enableOCR = true; + enableOCR = true; - testScript = { nodes, ... }: - '' - start_all() - machine.wait_for_x() + testScript = + { nodes, ... }: + '' + start_all() + machine.wait_for_x() - machine.execute("mines >&2 &") + machine.execute("mines >&2 &") - machine.wait_for_window("Mines") - machine.wait_for_text("Marked") - machine.screenshot("mines") - ''; -}) + machine.wait_for_window("Mines") + machine.wait_for_text("Marked") + machine.screenshot("mines") + ''; + } +) diff --git a/nixos/tests/shadow.nix b/nixos/tests/shadow.nix index a027af7e450b5d..dba18f12763934 100644 --- a/nixos/tests/shadow.nix +++ b/nixos/tests/shadow.nix @@ -6,167 +6,175 @@ let hashed_bcrypt = "$2b$05$8xIEflrk2RxQtcVXbGIxs.Vl0x7dF1/JSv3cyX6JJt0npzkTCWvxK"; # fnord hashed_yeshash = "$y$j9T$d8Z4EAf8P1SvM/aDFbxMS0$VnTXMp/Hnc7QdCBEaLTq5ZFOAFo2/PM0/xEAFuOE88."; # fnord hashed_sha512crypt = "$6$ymzs8WINZ5wGwQcV$VC2S0cQiX8NVukOLymysTPn4v1zJoJp3NGyhnqyv/dAf4NWZsBWYveQcj6gEJr4ZUjRBRjM0Pj1L8TCQ8hUUp0"; # meow -in import ./make-test-python.nix ({ pkgs, ... }: { - name = "shadow"; - meta = with pkgs.lib.maintainers; { maintainers = [ nequissimus ]; }; +in +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "shadow"; + meta = with pkgs.lib.maintainers; { + maintainers = [ nequissimus ]; + }; - nodes.shadow = { pkgs, ... }: { - environment.systemPackages = [ pkgs.shadow ]; + nodes.shadow = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.shadow ]; - users = { - mutableUsers = true; - users.emma = { - isNormalUser = true; - password = password1; - shell = pkgs.bash; - }; - users.layla = { - isNormalUser = true; - password = password2; - shell = pkgs.shadow; - }; - users.ash = { - isNormalUser = true; - password = password4; - shell = pkgs.bash; - }; - users.berta = { - isNormalUser = true; - hashedPasswordFile = (pkgs.writeText "hashed_bcrypt" hashed_bcrypt).outPath; - shell = pkgs.bash; + users = { + mutableUsers = true; + users.emma = { + isNormalUser = true; + password = password1; + shell = pkgs.bash; + }; + users.layla = { + isNormalUser = true; + password = password2; + shell = pkgs.shadow; + }; + users.ash = { + isNormalUser = true; + password = password4; + shell = pkgs.bash; + }; + users.berta = { + isNormalUser = true; + hashedPasswordFile = (pkgs.writeText "hashed_bcrypt" hashed_bcrypt).outPath; + shell = pkgs.bash; + }; + users.yesim = { + isNormalUser = true; + hashedPassword = hashed_yeshash; + shell = pkgs.bash; + }; + users.leo = { + isNormalUser = true; + initialHashedPassword = "!"; + hashedPassword = hashed_sha512crypt; # should take precedence over initialHashedPassword + shell = pkgs.bash; + }; + }; }; - users.yesim = { - isNormalUser = true; - hashedPassword = hashed_yeshash; - shell = pkgs.bash; - }; - users.leo = { - isNormalUser = true; - initialHashedPassword = "!"; - hashedPassword = hashed_sha512crypt; # should take precedence over initialHashedPassword - shell = pkgs.bash; - }; - }; - }; - testScript = '' - shadow.wait_for_unit("multi-user.target") - shadow.wait_until_succeeds("pgrep -f 'agetty.*tty1'") + testScript = '' + shadow.wait_for_unit("multi-user.target") + shadow.wait_until_succeeds("pgrep -f 'agetty.*tty1'") - with subtest("Normal login"): - shadow.send_key("alt-f2") - shadow.wait_until_succeeds("[ $(fgconsole) = 2 ]") - shadow.wait_for_unit("getty@tty2.service") - shadow.wait_until_succeeds("pgrep -f 'agetty.*tty2'") - shadow.wait_until_tty_matches("2", "login: ") - shadow.send_chars("emma\n") - shadow.wait_until_tty_matches("2", "login: emma") - shadow.wait_until_succeeds("pgrep login") - shadow.sleep(2) - shadow.send_chars("${password1}\n") - shadow.send_chars("whoami > /tmp/1\n") - shadow.wait_for_file("/tmp/1") - assert "emma" in shadow.succeed("cat /tmp/1") + with subtest("Normal login"): + shadow.send_key("alt-f2") + shadow.wait_until_succeeds("[ $(fgconsole) = 2 ]") + shadow.wait_for_unit("getty@tty2.service") + shadow.wait_until_succeeds("pgrep -f 'agetty.*tty2'") + shadow.wait_until_tty_matches("2", "login: ") + shadow.send_chars("emma\n") + shadow.wait_until_tty_matches("2", "login: emma") + shadow.wait_until_succeeds("pgrep login") + shadow.sleep(2) + shadow.send_chars("${password1}\n") + shadow.send_chars("whoami > /tmp/1\n") + shadow.wait_for_file("/tmp/1") + assert "emma" in shadow.succeed("cat /tmp/1") - with subtest("Switch user"): - shadow.send_chars("su - ash\n") - shadow.sleep(2) - shadow.send_chars("${password4}\n") - shadow.sleep(2) - shadow.send_chars("whoami > /tmp/3\n") - shadow.wait_for_file("/tmp/3") - assert "ash" in shadow.succeed("cat /tmp/3") + with subtest("Switch user"): + shadow.send_chars("su - ash\n") + shadow.sleep(2) + shadow.send_chars("${password4}\n") + shadow.sleep(2) + shadow.send_chars("whoami > /tmp/3\n") + shadow.wait_for_file("/tmp/3") + assert "ash" in shadow.succeed("cat /tmp/3") - with subtest("Change password"): - shadow.send_key("alt-f3") - shadow.wait_until_succeeds("[ $(fgconsole) = 3 ]") - shadow.wait_for_unit("getty@tty3.service") - shadow.wait_until_succeeds("pgrep -f 'agetty.*tty3'") - shadow.wait_until_tty_matches("3", "login: ") - shadow.send_chars("emma\n") - shadow.wait_until_tty_matches("3", "login: emma") - shadow.wait_until_succeeds("pgrep login") - shadow.sleep(2) - shadow.send_chars("${password1}\n") - shadow.send_chars("passwd\n") - shadow.sleep(2) - shadow.send_chars("${password1}\n") - shadow.sleep(2) - shadow.send_chars("${password3}\n") - shadow.sleep(2) - shadow.send_chars("${password3}\n") - shadow.sleep(2) - shadow.send_key("alt-f4") - shadow.wait_until_succeeds("[ $(fgconsole) = 4 ]") - shadow.wait_for_unit("getty@tty4.service") - shadow.wait_until_succeeds("pgrep -f 'agetty.*tty4'") - shadow.wait_until_tty_matches("4", "login: ") - shadow.send_chars("emma\n") - shadow.wait_until_tty_matches("4", "login: emma") - shadow.wait_until_succeeds("pgrep login") - shadow.sleep(2) - shadow.send_chars("${password1}\n") - shadow.wait_until_tty_matches("4", "Login incorrect") - shadow.wait_until_tty_matches("4", "login:") - shadow.send_chars("emma\n") - shadow.wait_until_tty_matches("4", "login: emma") - shadow.wait_until_succeeds("pgrep login") - shadow.sleep(2) - shadow.send_chars("${password3}\n") - shadow.send_chars("whoami > /tmp/2\n") - shadow.wait_for_file("/tmp/2") - assert "emma" in shadow.succeed("cat /tmp/2") + with subtest("Change password"): + shadow.send_key("alt-f3") + shadow.wait_until_succeeds("[ $(fgconsole) = 3 ]") + shadow.wait_for_unit("getty@tty3.service") + shadow.wait_until_succeeds("pgrep -f 'agetty.*tty3'") + shadow.wait_until_tty_matches("3", "login: ") + shadow.send_chars("emma\n") + shadow.wait_until_tty_matches("3", "login: emma") + shadow.wait_until_succeeds("pgrep login") + shadow.sleep(2) + shadow.send_chars("${password1}\n") + shadow.send_chars("passwd\n") + shadow.sleep(2) + shadow.send_chars("${password1}\n") + shadow.sleep(2) + shadow.send_chars("${password3}\n") + shadow.sleep(2) + shadow.send_chars("${password3}\n") + shadow.sleep(2) + shadow.send_key("alt-f4") + shadow.wait_until_succeeds("[ $(fgconsole) = 4 ]") + shadow.wait_for_unit("getty@tty4.service") + shadow.wait_until_succeeds("pgrep -f 'agetty.*tty4'") + shadow.wait_until_tty_matches("4", "login: ") + shadow.send_chars("emma\n") + shadow.wait_until_tty_matches("4", "login: emma") + shadow.wait_until_succeeds("pgrep login") + shadow.sleep(2) + shadow.send_chars("${password1}\n") + shadow.wait_until_tty_matches("4", "Login incorrect") + shadow.wait_until_tty_matches("4", "login:") + shadow.send_chars("emma\n") + shadow.wait_until_tty_matches("4", "login: emma") + shadow.wait_until_succeeds("pgrep login") + shadow.sleep(2) + shadow.send_chars("${password3}\n") + shadow.send_chars("whoami > /tmp/2\n") + shadow.wait_for_file("/tmp/2") + assert "emma" in shadow.succeed("cat /tmp/2") - with subtest("Groups"): - assert "foobar" not in shadow.succeed("groups emma") - shadow.succeed("groupadd foobar") - shadow.succeed("usermod -a -G foobar emma") - assert "foobar" in shadow.succeed("groups emma") + with subtest("Groups"): + assert "foobar" not in shadow.succeed("groups emma") + shadow.succeed("groupadd foobar") + shadow.succeed("usermod -a -G foobar emma") + assert "foobar" in shadow.succeed("groups emma") - with subtest("nologin shell"): - shadow.send_key("alt-f5") - shadow.wait_until_succeeds("[ $(fgconsole) = 5 ]") - shadow.wait_for_unit("getty@tty5.service") - shadow.wait_until_succeeds("pgrep -f 'agetty.*tty5'") - shadow.wait_until_tty_matches("5", "login: ") - shadow.send_chars("layla\n") - shadow.wait_until_tty_matches("5", "login: layla") - shadow.wait_until_succeeds("pgrep login") - shadow.send_chars("${password2}\n") - shadow.wait_until_tty_matches("5", "login:") + with subtest("nologin shell"): + shadow.send_key("alt-f5") + shadow.wait_until_succeeds("[ $(fgconsole) = 5 ]") + shadow.wait_for_unit("getty@tty5.service") + shadow.wait_until_succeeds("pgrep -f 'agetty.*tty5'") + shadow.wait_until_tty_matches("5", "login: ") + shadow.send_chars("layla\n") + shadow.wait_until_tty_matches("5", "login: layla") + shadow.wait_until_succeeds("pgrep login") + shadow.send_chars("${password2}\n") + shadow.wait_until_tty_matches("5", "login:") - with subtest("check alternate password hashes"): - shadow.send_key("alt-f6") - shadow.wait_until_succeeds("[ $(fgconsole) = 6 ]") - for u in ["berta", "yesim"]: - shadow.wait_for_unit("getty@tty6.service") - shadow.wait_until_succeeds("pgrep -f 'agetty.*tty6'") - shadow.wait_until_tty_matches("6", "login: ") - shadow.send_chars(f"{u}\n") - shadow.wait_until_tty_matches("6", f"login: {u}") - shadow.wait_until_succeeds("pgrep login") - shadow.sleep(2) - shadow.send_chars("fnord\n") - shadow.send_chars(f"whoami > /tmp/{u}\n") - shadow.wait_for_file(f"/tmp/{u}") - print(shadow.succeed(f"cat /tmp/{u}")) - assert u in shadow.succeed(f"cat /tmp/{u}") - shadow.send_chars("logout\n") + with subtest("check alternate password hashes"): + shadow.send_key("alt-f6") + shadow.wait_until_succeeds("[ $(fgconsole) = 6 ]") + for u in ["berta", "yesim"]: + shadow.wait_for_unit("getty@tty6.service") + shadow.wait_until_succeeds("pgrep -f 'agetty.*tty6'") + shadow.wait_until_tty_matches("6", "login: ") + shadow.send_chars(f"{u}\n") + shadow.wait_until_tty_matches("6", f"login: {u}") + shadow.wait_until_succeeds("pgrep login") + shadow.sleep(2) + shadow.send_chars("fnord\n") + shadow.send_chars(f"whoami > /tmp/{u}\n") + shadow.wait_for_file(f"/tmp/{u}") + print(shadow.succeed(f"cat /tmp/{u}")) + assert u in shadow.succeed(f"cat /tmp/{u}") + shadow.send_chars("logout\n") - with subtest("Ensure hashedPassword does not get overridden by initialHashedPassword"): - shadow.send_key("alt-f6") - shadow.wait_until_succeeds("[ $(fgconsole) = 6 ]") - shadow.wait_for_unit("getty@tty6.service") - shadow.wait_until_succeeds("pgrep -f 'agetty.*tty6'") - shadow.wait_until_tty_matches("6", "login: ") - shadow.send_chars("leo\n") - shadow.wait_until_tty_matches("6", "login: leo") - shadow.wait_until_succeeds("pgrep login") - shadow.sleep(2) - shadow.send_chars("meow\n") - shadow.send_chars("whoami > /tmp/leo\n") - shadow.wait_for_file("/tmp/leo") - assert "leo" in shadow.succeed("cat /tmp/leo") - shadow.send_chars("logout\n") - ''; -}) + with subtest("Ensure hashedPassword does not get overridden by initialHashedPassword"): + shadow.send_key("alt-f6") + shadow.wait_until_succeeds("[ $(fgconsole) = 6 ]") + shadow.wait_for_unit("getty@tty6.service") + shadow.wait_until_succeeds("pgrep -f 'agetty.*tty6'") + shadow.wait_until_tty_matches("6", "login: ") + shadow.send_chars("leo\n") + shadow.wait_until_tty_matches("6", "login: leo") + shadow.wait_until_succeeds("pgrep login") + shadow.sleep(2) + shadow.send_chars("meow\n") + shadow.send_chars("whoami > /tmp/leo\n") + shadow.wait_for_file("/tmp/leo") + assert "leo" in shadow.succeed("cat /tmp/leo") + shadow.send_chars("logout\n") + ''; + } +) diff --git a/nixos/tests/shadowsocks/common.nix b/nixos/tests/shadowsocks/common.nix index 82a63771b03abf..e81eccb3f3b3c6 100644 --- a/nixos/tests/shadowsocks/common.nix +++ b/nixos/tests/shadowsocks/common.nix @@ -1,9 +1,12 @@ -{ name -, plugin ? null -, pluginOpts ? "" +{ + name, + plugin ? null, + pluginOpts ? "", }: -import ../make-test-python.nix ({ pkgs, lib, ... }: { +import ../make-test-python.nix ( + { pkgs, lib, ... }: + { inherit name; meta = { maintainers = with lib.maintainers; [ hmenke ]; @@ -14,23 +17,28 @@ import ../make-test-python.nix ({ pkgs, lib, ... }: { boot.kernel.sysctl."net.ipv4.ip_forward" = "1"; networking.useDHCP = false; networking.interfaces.eth1.ipv4.addresses = [ - { address = "192.168.0.1"; prefixLength = 24; } + { + address = "192.168.0.1"; + prefixLength = 24; + } ]; networking.firewall.rejectPackets = true; networking.firewall.allowedTCPPorts = [ 8488 ]; networking.firewall.allowedUDPPorts = [ 8488 ]; - services.shadowsocks = { - enable = true; - encryptionMethod = "chacha20-ietf-poly1305"; - password = "pa$$w0rd"; - localAddress = [ "0.0.0.0" ]; - port = 8488; - fastOpen = false; - mode = "tcp_and_udp"; - } // lib.optionalAttrs (plugin != null) { - inherit plugin; - pluginOpts = "server;${pluginOpts}"; - }; + services.shadowsocks = + { + enable = true; + encryptionMethod = "chacha20-ietf-poly1305"; + password = "pa$$w0rd"; + localAddress = [ "0.0.0.0" ]; + port = 8488; + fastOpen = false; + mode = "tcp_and_udp"; + } + // lib.optionalAttrs (plugin != null) { + inherit plugin; + pluginOpts = "server;${pluginOpts}"; + }; services.nginx = { enable = true; virtualHosts.server = { @@ -42,7 +50,10 @@ import ../make-test-python.nix ({ pkgs, lib, ... }: { client = { networking.useDHCP = false; networking.interfaces.eth1.ipv4.addresses = [ - { address = "192.168.0.2"; prefixLength = 24; } + { + address = "192.168.0.2"; + prefixLength = 24; + } ]; systemd.services.shadowsocks-client = { description = "connect to shadowsocks"; diff --git a/nixos/tests/shadowsocks/default.nix b/nixos/tests/shadowsocks/default.nix index 37a8c3c9d0d3bc..3587ffb0edc503 100644 --- a/nixos/tests/shadowsocks/default.nix +++ b/nixos/tests/shadowsocks/default.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../../.. { inherit system config; }, }: { diff --git a/nixos/tests/shattered-pixel-dungeon.nix b/nixos/tests/shattered-pixel-dungeon.nix index cabf192c6002f7..dadd9991e29e3d 100644 --- a/nixos/tests/shattered-pixel-dungeon.nix +++ b/nixos/tests/shattered-pixel-dungeon.nix @@ -1,27 +1,30 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "shattered-pixel-dungeon"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fgaz ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "shattered-pixel-dungeon"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fgaz ]; + }; - nodes.machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + nodes.machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; - environment.systemPackages = [ pkgs.shattered-pixel-dungeon ]; - }; + services.xserver.enable = true; + environment.systemPackages = [ pkgs.shattered-pixel-dungeon ]; + }; - enableOCR = true; + enableOCR = true; - testScript = - '' + testScript = '' machine.wait_for_x() machine.execute("shattered-pixel-dungeon >&2 &") machine.wait_for_window(r"Shattered Pixel Dungeon") machine.wait_for_text("Enter") machine.screenshot("screen") ''; -}) - + } +) diff --git a/nixos/tests/shiori.nix b/nixos/tests/shiori.nix index ba9b42235df282..f25807e900f978 100644 --- a/nixos/tests/shiori.nix +++ b/nixos/tests/shiori.nix @@ -1,81 +1,90 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: { name = "shiori"; meta.maintainers = with lib.maintainers; [ minijackson ]; - nodes.machine = { ... }: { services.shiori.enable = true; }; + nodes.machine = + { ... }: + { + services.shiori.enable = true; + }; - testScript = let - authJSON = pkgs.writeText "auth.json" (builtins.toJSON { - username = "shiori"; - password = "gopher"; - owner = true; - }); + testScript = + let + authJSON = pkgs.writeText "auth.json" ( + builtins.toJSON { + username = "shiori"; + password = "gopher"; + owner = true; + } + ); - insertBookmark = { - url = "http://example.org"; - title = "Example Bookmark"; - }; + insertBookmark = { + url = "http://example.org"; + title = "Example Bookmark"; + }; - insertBookmarkJSON = - pkgs.writeText "insertBookmark.json" (builtins.toJSON insertBookmark); - in '' - #import json + insertBookmarkJSON = pkgs.writeText "insertBookmark.json" (builtins.toJSON insertBookmark); + in + '' + #import json - machine.wait_for_unit("shiori.service") - machine.wait_for_open_port(8080) - machine.succeed("curl --fail http://localhost:8080/") - machine.succeed("curl --fail --location http://localhost:8080/ | grep -i shiori") + machine.wait_for_unit("shiori.service") + machine.wait_for_open_port(8080) + machine.succeed("curl --fail http://localhost:8080/") + machine.succeed("curl --fail --location http://localhost:8080/ | grep -i shiori") - # The test code below no longer works because the API authentication has changed. + # The test code below no longer works because the API authentication has changed. - #with subtest("login"): - # auth_json = machine.succeed( - # "curl --fail --location http://localhost:8080/api/login " - # "-X POST -H 'Content-Type:application/json' -d @${authJSON}" - # ) - # auth_ret = json.loads(auth_json) - # session_id = auth_ret["session"] + #with subtest("login"): + # auth_json = machine.succeed( + # "curl --fail --location http://localhost:8080/api/login " + # "-X POST -H 'Content-Type:application/json' -d @${authJSON}" + # ) + # auth_ret = json.loads(auth_json) + # session_id = auth_ret["session"] - #with subtest("bookmarks"): - # with subtest("first use no bookmarks"): - # bookmarks_json = machine.succeed( - # ( - # "curl --fail --location http://localhost:8080/api/bookmarks " - # "-H 'X-Session-Id:{}'" - # ).format(session_id) - # ) + #with subtest("bookmarks"): + # with subtest("first use no bookmarks"): + # bookmarks_json = machine.succeed( + # ( + # "curl --fail --location http://localhost:8080/api/bookmarks " + # "-H 'X-Session-Id:{}'" + # ).format(session_id) + # ) - # if json.loads(bookmarks_json)["bookmarks"] != []: - # raise Exception("Shiori have a bookmark on first use") + # if json.loads(bookmarks_json)["bookmarks"] != []: + # raise Exception("Shiori have a bookmark on first use") - # with subtest("insert bookmark"): - # machine.succeed( - # ( - # "curl --fail --location http://localhost:8080/api/bookmarks " - # "-X POST -H 'X-Session-Id:{}' " - # "-H 'Content-Type:application/json' -d @${insertBookmarkJSON}" - # ).format(session_id) - # ) + # with subtest("insert bookmark"): + # machine.succeed( + # ( + # "curl --fail --location http://localhost:8080/api/bookmarks " + # "-X POST -H 'X-Session-Id:{}' " + # "-H 'Content-Type:application/json' -d @${insertBookmarkJSON}" + # ).format(session_id) + # ) - # with subtest("get inserted bookmark"): - # bookmarks_json = machine.succeed( - # ( - # "curl --fail --location http://localhost:8080/api/bookmarks " - # "-H 'X-Session-Id:{}'" - # ).format(session_id) - # ) + # with subtest("get inserted bookmark"): + # bookmarks_json = machine.succeed( + # ( + # "curl --fail --location http://localhost:8080/api/bookmarks " + # "-H 'X-Session-Id:{}'" + # ).format(session_id) + # ) - # bookmarks = json.loads(bookmarks_json)["bookmarks"] - # if len(bookmarks) != 1: - # raise Exception("Shiori didn't save the bookmark") + # bookmarks = json.loads(bookmarks_json)["bookmarks"] + # if len(bookmarks) != 1: + # raise Exception("Shiori didn't save the bookmark") - # bookmark = bookmarks[0] - # if ( - # bookmark["url"] != "${insertBookmark.url}" - # or bookmark["title"] != "${insertBookmark.title}" - # ): - # raise Exception("Inserted bookmark doesn't have same URL or title") - ''; - }) + # bookmark = bookmarks[0] + # if ( + # bookmark["url"] != "${insertBookmark.url}" + # or bookmark["title"] != "${insertBookmark.title}" + # ): + # raise Exception("Inserted bookmark doesn't have same URL or title") + ''; + } +) diff --git a/nixos/tests/signal-desktop.nix b/nixos/tests/signal-desktop.nix index f146804a958de9..22b21f4bcecfdc 100644 --- a/nixos/tests/signal-desktop.nix +++ b/nixos/tests/signal-desktop.nix @@ -1,69 +1,82 @@ -import ./make-test-python.nix ({ pkgs, ...} : +import ./make-test-python.nix ( + { pkgs, ... }: -let - sqlcipher-signal = pkgs.writeShellScriptBin "sqlcipher" '' - set -eu + let + sqlcipher-signal = pkgs.writeShellScriptBin "sqlcipher" '' + set -eu - readonly CFG=~/.config/Signal/config.json - readonly KEY="$(${pkgs.jq}/bin/jq --raw-output '.key' $CFG)" - readonly DB="$1" - readonly SQL="SELECT * FROM sqlite_master where type='table'" - ${pkgs.sqlcipher}/bin/sqlcipher "$DB" "PRAGMA key = \"x'$KEY'\"; $SQL" - ''; -in { - name = "signal-desktop"; - meta = with pkgs.lib.maintainers; { - maintainers = [ flokli primeos ]; - }; + readonly CFG=~/.config/Signal/config.json + readonly KEY="$(${pkgs.jq}/bin/jq --raw-output '.key' $CFG)" + readonly DB="$1" + readonly SQL="SELECT * FROM sqlite_master where type='table'" + ${pkgs.sqlcipher}/bin/sqlcipher "$DB" "PRAGMA key = \"x'$KEY'\"; $SQL" + ''; + in + { + name = "signal-desktop"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + flokli + primeos + ]; + }; - nodes.machine = { ... }: + nodes.machine = + { ... }: - { - imports = [ - ./common/user-account.nix - ./common/x11.nix - ]; + { + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; - services.xserver.enable = true; - test-support.displayManager.auto.user = "alice"; - environment.systemPackages = with pkgs; [ - signal-desktop file sqlite sqlcipher-signal - ]; - }; + services.xserver.enable = true; + test-support.displayManager.auto.user = "alice"; + environment.systemPackages = with pkgs; [ + signal-desktop + file + sqlite + sqlcipher-signal + ]; + }; - enableOCR = true; + enableOCR = true; - testScript = { nodes, ... }: let - user = nodes.machine.config.users.users.alice; - in '' - start_all() - machine.wait_for_x() + testScript = + { nodes, ... }: + let + user = nodes.machine.config.users.users.alice; + in + '' + start_all() + machine.wait_for_x() - # start signal desktop - machine.execute("su - alice -c signal-desktop >&2 &") + # start signal desktop + machine.execute("su - alice -c signal-desktop >&2 &") - # Wait for the Signal window to appear. Since usually the tests - # are run sandboxed and therefore with no internet, we can not wait - # for the message "Link your phone ...". Nor should we wait for - # the "Failed to connect to server" message, because when manually - # running this test it will be not sandboxed. - machine.wait_for_text("Signal") - machine.wait_for_text("File Edit View Window Help") - machine.screenshot("signal_desktop") + # Wait for the Signal window to appear. Since usually the tests + # are run sandboxed and therefore with no internet, we can not wait + # for the message "Link your phone ...". Nor should we wait for + # the "Failed to connect to server" message, because when manually + # running this test it will be not sandboxed. + machine.wait_for_text("Signal") + machine.wait_for_text("File Edit View Window Help") + machine.screenshot("signal_desktop") - # Test if the database is encrypted to prevent these issues: - # - https://github.com/NixOS/nixpkgs/issues/108772 - # - https://github.com/NixOS/nixpkgs/pull/117555 - print(machine.succeed("su - alice -c 'file ~/.config/Signal/sql/db.sqlite'")) - machine.fail( - "su - alice -c 'file ~/.config/Signal/sql/db.sqlite' | grep -e SQLite -e database" - ) - # Only SQLCipher should be able to read the encrypted DB: - machine.fail( - "su - alice -c 'sqlite3 ~/.config/Signal/sql/db.sqlite .tables'" - ) - print(machine.succeed( - "su - alice -c 'sqlcipher ~/.config/Signal/sql/db.sqlite'" - )) - ''; -}) + # Test if the database is encrypted to prevent these issues: + # - https://github.com/NixOS/nixpkgs/issues/108772 + # - https://github.com/NixOS/nixpkgs/pull/117555 + print(machine.succeed("su - alice -c 'file ~/.config/Signal/sql/db.sqlite'")) + machine.fail( + "su - alice -c 'file ~/.config/Signal/sql/db.sqlite' | grep -e SQLite -e database" + ) + # Only SQLCipher should be able to read the encrypted DB: + machine.fail( + "su - alice -c 'sqlite3 ~/.config/Signal/sql/db.sqlite .tables'" + ) + print(machine.succeed( + "su - alice -c 'sqlcipher ~/.config/Signal/sql/db.sqlite'" + )) + ''; + } +) diff --git a/nixos/tests/silverbullet.nix b/nixos/tests/silverbullet.nix index e7e3cf53655830..a14e59cccf484a 100644 --- a/nixos/tests/silverbullet.nix +++ b/nixos/tests/silverbullet.nix @@ -1,47 +1,59 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "silverbullet"; - meta.maintainers = with lib.maintainers; [ aorith ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "silverbullet"; + meta.maintainers = with lib.maintainers; [ aorith ]; - nodes.simple = { ... }: { - services.silverbullet.enable = true; - }; + nodes.simple = + { ... }: + { + services.silverbullet.enable = true; + }; - nodes.configured = { pkgs, ... }: { - users.users.test.isNormalUser = true; - users.groups.test = { }; + nodes.configured = + { pkgs, ... }: + { + users.users.test.isNormalUser = true; + users.groups.test = { }; - services.silverbullet = { - enable = true; - package = pkgs.silverbullet; - listenPort = 3001; - listenAddress = "localhost"; - spaceDir = "/home/test/silverbullet"; - user = "test"; - group = "test"; - envFile = pkgs.writeText "silverbullet.env" '' - SB_USER=user:password - SB_AUTH_TOKEN=test - ''; - extraArgs = [ "--reindex" "--db /home/test/silverbullet/custom.db" ]; - }; - }; + services.silverbullet = { + enable = true; + package = pkgs.silverbullet; + listenPort = 3001; + listenAddress = "localhost"; + spaceDir = "/home/test/silverbullet"; + user = "test"; + group = "test"; + envFile = pkgs.writeText "silverbullet.env" '' + SB_USER=user:password + SB_AUTH_TOKEN=test + ''; + extraArgs = [ + "--reindex" + "--db /home/test/silverbullet/custom.db" + ]; + }; + }; - testScript = { nodes, ... }: '' - PORT = ${builtins.toString nodes.simple.services.silverbullet.listenPort} - ADDRESS = "${nodes.simple.services.silverbullet.listenAddress}" - SPACEDIR = "${nodes.simple.services.silverbullet.spaceDir}" - simple.wait_for_unit("silverbullet.service") - simple.wait_for_open_port(PORT) - simple.succeed(f"curl --max-time 5 -s -v -o /dev/null --fail http://{ADDRESS}:{PORT}/") - simple.succeed(f"test -d '{SPACEDIR}'") + testScript = + { nodes, ... }: + '' + PORT = ${builtins.toString nodes.simple.services.silverbullet.listenPort} + ADDRESS = "${nodes.simple.services.silverbullet.listenAddress}" + SPACEDIR = "${nodes.simple.services.silverbullet.spaceDir}" + simple.wait_for_unit("silverbullet.service") + simple.wait_for_open_port(PORT) + simple.succeed(f"curl --max-time 5 -s -v -o /dev/null --fail http://{ADDRESS}:{PORT}/") + simple.succeed(f"test -d '{SPACEDIR}'") - PORT = ${builtins.toString nodes.configured.services.silverbullet.listenPort} - ADDRESS = "${nodes.configured.services.silverbullet.listenAddress}" - SPACEDIR = "${nodes.configured.services.silverbullet.spaceDir}" - configured.wait_for_unit("silverbullet.service") - configured.wait_for_open_port(PORT) - assert int(configured.succeed(f"curl --max-time 5 -s -o /dev/null -w '%{{http_code}}' -XPUT -d 'test' --fail http://{ADDRESS}:{PORT}/test.md -H'Authorization: Bearer test'")) == 200 - assert int(configured.fail(f"curl --max-time 5 -s -o /dev/null -w '%{{http_code}}' -XPUT -d 'test' --fail http://{ADDRESS}:{PORT}/test.md -H'Authorization: Bearer wrong'")) == 401 - configured.succeed(f"test -d '{SPACEDIR}'") - ''; -}) + PORT = ${builtins.toString nodes.configured.services.silverbullet.listenPort} + ADDRESS = "${nodes.configured.services.silverbullet.listenAddress}" + SPACEDIR = "${nodes.configured.services.silverbullet.spaceDir}" + configured.wait_for_unit("silverbullet.service") + configured.wait_for_open_port(PORT) + assert int(configured.succeed(f"curl --max-time 5 -s -o /dev/null -w '%{{http_code}}' -XPUT -d 'test' --fail http://{ADDRESS}:{PORT}/test.md -H'Authorization: Bearer test'")) == 200 + assert int(configured.fail(f"curl --max-time 5 -s -o /dev/null -w '%{{http_code}}' -XPUT -d 'test' --fail http://{ADDRESS}:{PORT}/test.md -H'Authorization: Bearer wrong'")) == 401 + configured.succeed(f"test -d '{SPACEDIR}'") + ''; + } +) diff --git a/nixos/tests/simple.nix b/nixos/tests/simple.nix index afd49d481a65d5..ab9cf1d9768fea 100644 --- a/nixos/tests/simple.nix +++ b/nixos/tests/simple.nix @@ -1,17 +1,21 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "simple"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "simple"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; - nodes.machine = { ... }: { - imports = [ ../modules/profiles/minimal.nix ]; - }; + nodes.machine = + { ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; + }; - testScript = - '' + testScript = '' start_all() machine.wait_for_unit("multi-user.target") machine.shutdown() ''; -}) + } +) diff --git a/nixos/tests/slimserver.nix b/nixos/tests/slimserver.nix index abc0cd2ef18127..ac166b109c841d 100644 --- a/nixos/tests/slimserver.nix +++ b/nixos/tests/slimserver.nix @@ -1,18 +1,21 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "slimserver"; - meta.maintainers = with pkgs.lib.maintainers; [ adamcstephens ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "slimserver"; + meta.maintainers = with pkgs.lib.maintainers; [ adamcstephens ]; - nodes.machine = { ... }: { - services.slimserver.enable = true; - services.squeezelite = { - enable = true; - extraArguments = "-s 127.0.0.1 -d slimproto=info"; - }; - boot.kernelModules = ["snd-dummy"]; - }; + nodes.machine = + { ... }: + { + services.slimserver.enable = true; + services.squeezelite = { + enable = true; + extraArguments = "-s 127.0.0.1 -d slimproto=info"; + }; + boot.kernelModules = [ "snd-dummy" ]; + }; - testScript = - '' + testScript = '' import json rpc_get_player = { "id": 1, @@ -43,4 +46,5 @@ import ./make-test-python.nix ({ pkgs, ...} : { player_id = machine.succeed(f"curl http://localhost:9000/jsonrpc.js -g -X POST -d '{json.dumps(rpc_get_player)}'") assert player_mac == json.loads(player_id)["result"]["_id"], "squeezelite player not found" ''; -}) + } +) diff --git a/nixos/tests/slurm.nix b/nixos/tests/slurm.nix index f35eaf9c8e7842..02fe38c6ecfeb6 100644 --- a/nixos/tests/slurm.nix +++ b/nixos/tests/slurm.nix @@ -1,5 +1,6 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -let +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let slurmconfig = { services.slurm = { controlMachine = "control"; @@ -17,152 +18,160 @@ let ]; }; - mpitest = let - mpitestC = pkgs.writeText "mpitest.c" '' - #include - #include - #include + mpitest = + let + mpitestC = pkgs.writeText "mpitest.c" '' + #include + #include + #include - int - main (int argc, char *argv[]) - { - int rank, size, length; - char name[512]; + int + main (int argc, char *argv[]) + { + int rank, size, length; + char name[512]; - MPI_Init (&argc, &argv); - MPI_Comm_rank (MPI_COMM_WORLD, &rank); - MPI_Comm_size (MPI_COMM_WORLD, &size); - MPI_Get_processor_name (name, &length); + MPI_Init (&argc, &argv); + MPI_Comm_rank (MPI_COMM_WORLD, &rank); + MPI_Comm_size (MPI_COMM_WORLD, &size); + MPI_Get_processor_name (name, &length); - if ( rank == 0 ) printf("size=%d\n", size); + if ( rank == 0 ) printf("size=%d\n", size); - printf ("%s: hello world from process %d of %d\n", name, rank, size); + printf ("%s: hello world from process %d of %d\n", name, rank, size); - MPI_Finalize (); + MPI_Finalize (); - return EXIT_SUCCESS; - } + return EXIT_SUCCESS; + } + ''; + in + pkgs.runCommand "mpitest" { } '' + mkdir -p $out/bin + ${lib.getDev pkgs.mpi}/bin/mpicc ${mpitestC} -o $out/bin/mpitest ''; - in pkgs.runCommand "mpitest" {} '' - mkdir -p $out/bin - ${lib.getDev pkgs.mpi}/bin/mpicc ${mpitestC} -o $out/bin/mpitest - ''; -in { - name = "slurm"; + in + { + name = "slurm"; - meta.maintainers = [ lib.maintainers.markuskowa ]; + meta.maintainers = [ lib.maintainers.markuskowa ]; - nodes = - let - computeNode = - { ...}: + nodes = + let + computeNode = + { ... }: + { + imports = [ slurmconfig ]; + # TODO slurmd port and slurmctld port should be configurations and + # automatically allowed by the firewall. + services.slurm = { + client.enable = true; + }; + }; + in { - imports = [ slurmconfig ]; - # TODO slurmd port and slurmctld port should be configurations and - # automatically allowed by the firewall. - services.slurm = { - client.enable = true; - }; - }; - in { - control = - { ...}: - { - imports = [ slurmconfig ]; - services.slurm = { - server.enable = true; - }; - }; + control = + { ... }: + { + imports = [ slurmconfig ]; + services.slurm = { + server.enable = true; + }; + }; - submit = - { ...}: - { - imports = [ slurmconfig ]; - services.slurm = { - enableStools = true; - }; - }; + submit = + { ... }: + { + imports = [ slurmconfig ]; + services.slurm = { + enableStools = true; + }; + }; - dbd = - { pkgs, ... } : - let - passFile = pkgs.writeText "dbdpassword" "password123"; - in { - networking.firewall.enable = false; - systemd.tmpfiles.rules = [ - "f /etc/munge/munge.key 0400 munge munge - mungeverryweakkeybuteasytointegratoinatest" - ]; - services.slurm.dbdserver = { - enable = true; - storagePassFile = "${passFile}"; - }; - services.mysql = { - enable = true; - package = pkgs.mariadb; - initialScript = pkgs.writeText "mysql-init.sql" '' - CREATE USER 'slurm'@'localhost' IDENTIFIED BY 'password123'; - GRANT ALL PRIVILEGES ON slurm_acct_db.* TO 'slurm'@'localhost'; - ''; - ensureDatabases = [ "slurm_acct_db" ]; - ensureUsers = [{ - ensurePermissions = { "slurm_acct_db.*" = "ALL PRIVILEGES"; }; - name = "slurm"; - }]; - settings.mysqld = { - # recommendations from: https://slurm.schedmd.com/accounting.html#mysql-configuration - innodb_buffer_pool_size="1024M"; - innodb_log_file_size="64M"; - innodb_lock_wait_timeout=900; + dbd = + { pkgs, ... }: + let + passFile = pkgs.writeText "dbdpassword" "password123"; + in + { + networking.firewall.enable = false; + systemd.tmpfiles.rules = [ + "f /etc/munge/munge.key 0400 munge munge - mungeverryweakkeybuteasytointegratoinatest" + ]; + services.slurm.dbdserver = { + enable = true; + storagePassFile = "${passFile}"; + }; + services.mysql = { + enable = true; + package = pkgs.mariadb; + initialScript = pkgs.writeText "mysql-init.sql" '' + CREATE USER 'slurm'@'localhost' IDENTIFIED BY 'password123'; + GRANT ALL PRIVILEGES ON slurm_acct_db.* TO 'slurm'@'localhost'; + ''; + ensureDatabases = [ "slurm_acct_db" ]; + ensureUsers = [ + { + ensurePermissions = { + "slurm_acct_db.*" = "ALL PRIVILEGES"; + }; + name = "slurm"; + } + ]; + settings.mysqld = { + # recommendations from: https://slurm.schedmd.com/accounting.html#mysql-configuration + innodb_buffer_pool_size = "1024M"; + innodb_log_file_size = "64M"; + innodb_lock_wait_timeout = 900; + }; + }; }; - }; + + node1 = computeNode; + node2 = computeNode; + node3 = computeNode; }; - node1 = computeNode; - node2 = computeNode; - node3 = computeNode; - }; - - - testScript = - '' - start_all() - - # Make sure DBD is up after DB initialzation - with subtest("can_start_slurmdbd"): - dbd.succeed("systemctl restart slurmdbd") - dbd.wait_for_unit("slurmdbd.service") - dbd.wait_for_open_port(6819) - - # there needs to be an entry for the current - # cluster in the database before slurmctld is restarted - with subtest("add_account"): - control.succeed("sacctmgr -i add cluster default") - # check for cluster entry - control.succeed("sacctmgr list cluster | awk '{ print $1 }' | grep default") - - with subtest("can_start_slurmctld"): - control.succeed("systemctl restart slurmctld") - control.wait_for_unit("slurmctld.service") - - with subtest("can_start_slurmd"): - for node in [node1, node2, node3]: - node.succeed("systemctl restart slurmd.service") - node.wait_for_unit("slurmd") - - # Test that the cluster works and can distribute jobs; - - with subtest("run_distributed_command"): - # Run `hostname` on 3 nodes of the partition (so on all the 3 nodes). - # The output must contain the 3 different names - submit.succeed("srun -N 3 hostname | sort | uniq | wc -l | xargs test 3 -eq") - - with subtest("check_slurm_dbd"): - # find the srun job from above in the database - control.succeed("sleep 5") - control.succeed("sacct | grep hostname") - - with subtest("run_PMIx_mpitest"): - submit.succeed("srun -N 3 --mpi=pmix mpitest | grep size=3") - ''; -}) + testScript = '' + start_all() + + # Make sure DBD is up after DB initialzation + with subtest("can_start_slurmdbd"): + dbd.succeed("systemctl restart slurmdbd") + dbd.wait_for_unit("slurmdbd.service") + dbd.wait_for_open_port(6819) + + # there needs to be an entry for the current + # cluster in the database before slurmctld is restarted + with subtest("add_account"): + control.succeed("sacctmgr -i add cluster default") + # check for cluster entry + control.succeed("sacctmgr list cluster | awk '{ print $1 }' | grep default") + + with subtest("can_start_slurmctld"): + control.succeed("systemctl restart slurmctld") + control.wait_for_unit("slurmctld.service") + + with subtest("can_start_slurmd"): + for node in [node1, node2, node3]: + node.succeed("systemctl restart slurmd.service") + node.wait_for_unit("slurmd") + + # Test that the cluster works and can distribute jobs; + + with subtest("run_distributed_command"): + # Run `hostname` on 3 nodes of the partition (so on all the 3 nodes). + # The output must contain the 3 different names + submit.succeed("srun -N 3 hostname | sort | uniq | wc -l | xargs test 3 -eq") + + with subtest("check_slurm_dbd"): + # find the srun job from above in the database + control.succeed("sleep 5") + control.succeed("sacct | grep hostname") + + with subtest("run_PMIx_mpitest"): + submit.succeed("srun -N 3 --mpi=pmix mpitest | grep size=3") + ''; + } +) diff --git a/nixos/tests/smokeping.nix b/nixos/tests/smokeping.nix index fe1ecad9969b00..9aa25ee49d6dce 100644 --- a/nixos/tests/smokeping.nix +++ b/nixos/tests/smokeping.nix @@ -1,42 +1,45 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "smokeping"; - meta = with pkgs.lib.maintainers; { - maintainers = [ cransom ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "smokeping"; + meta = with pkgs.lib.maintainers; { + maintainers = [ cransom ]; + }; - nodes = { - sm = - { ... }: - { - networking.domain = "example.com"; # FQDN: sm.example.com - services.smokeping = { - enable = true; - mailHost = "127.0.0.2"; - probeConfig = '' - + FPing - binary = /run/wrappers/bin/fping - offset = 0% - ''; + nodes = { + sm = + { ... }: + { + networking.domain = "example.com"; # FQDN: sm.example.com + services.smokeping = { + enable = true; + mailHost = "127.0.0.2"; + probeConfig = '' + + FPing + binary = /run/wrappers/bin/fping + offset = 0% + ''; + }; }; - }; - }; + }; - testScript = '' - start_all() - sm.wait_for_unit("smokeping") - sm.wait_for_unit("nginx") - sm.wait_for_file("/var/lib/smokeping/data/Local/LocalMachine.rrd") - sm.succeed("curl -s -f localhost/smokeping.fcgi?target=Local") - # Check that there's a helpful page without explicit path as well. - sm.succeed("curl -s -f localhost") - sm.succeed("ls /var/lib/smokeping/cache/Local/LocalMachine_mini.png") - sm.succeed("ls /var/lib/smokeping/cache/index.html") + testScript = '' + start_all() + sm.wait_for_unit("smokeping") + sm.wait_for_unit("nginx") + sm.wait_for_file("/var/lib/smokeping/data/Local/LocalMachine.rrd") + sm.succeed("curl -s -f localhost/smokeping.fcgi?target=Local") + # Check that there's a helpful page without explicit path as well. + sm.succeed("curl -s -f localhost") + sm.succeed("ls /var/lib/smokeping/cache/Local/LocalMachine_mini.png") + sm.succeed("ls /var/lib/smokeping/cache/index.html") - # stop and start the service like nixos-rebuild would do - # see https://github.com/NixOS/nixpkgs/issues/265953) - sm.succeed("systemctl stop smokeping") - sm.succeed("systemctl start smokeping") - # ensure all services restarted properly - sm.succeed("systemctl --failed | grep -q '0 loaded units listed'") - ''; -}) + # stop and start the service like nixos-rebuild would do + # see https://github.com/NixOS/nixpkgs/issues/265953) + sm.succeed("systemctl stop smokeping") + sm.succeed("systemctl start smokeping") + # ensure all services restarted properly + sm.succeed("systemctl --failed | grep -q '0 loaded units listed'") + ''; + } +) diff --git a/nixos/tests/snapcast.nix b/nixos/tests/snapcast.nix index 9b62e4724e7571..569a50ff39c141 100644 --- a/nixos/tests/snapcast.nix +++ b/nixos/tests/snapcast.nix @@ -1,90 +1,93 @@ -import ./make-test-python.nix ({ pkgs, ...} : +import ./make-test-python.nix ( + { pkgs, ... }: -let - port = 10004; - tcpPort = 10005; - httpPort = 10080; - tcpStreamPort = 10006; - bufferSize = 742; -in { - name = "snapcast"; - meta = with pkgs.lib.maintainers; { - maintainers = [ hexa ]; - }; + let + port = 10004; + tcpPort = 10005; + httpPort = 10080; + tcpStreamPort = 10006; + bufferSize = 742; + in + { + name = "snapcast"; + meta = with pkgs.lib.maintainers; { + maintainers = [ hexa ]; + }; - nodes = { - server = { - services.snapserver = { - enable = true; - port = port; - tcp.port = tcpPort; - http.port = httpPort; - openFirewall = true; - buffer = bufferSize; - streams = { - mpd = { - type = "pipe"; - location = "/run/snapserver/mpd"; - query.mode = "create"; - }; - bluetooth = { - type = "pipe"; - location = "/run/snapserver/bluetooth"; - }; - tcp = { - type = "tcp"; - location = "127.0.0.1:${toString tcpStreamPort}"; - }; - meta = { - type = "meta"; - location = "/mpd/bluetooth/tcp"; + nodes = { + server = { + services.snapserver = { + enable = true; + port = port; + tcp.port = tcpPort; + http.port = httpPort; + openFirewall = true; + buffer = bufferSize; + streams = { + mpd = { + type = "pipe"; + location = "/run/snapserver/mpd"; + query.mode = "create"; + }; + bluetooth = { + type = "pipe"; + location = "/run/snapserver/bluetooth"; + }; + tcp = { + type = "tcp"; + location = "127.0.0.1:${toString tcpStreamPort}"; + }; + meta = { + type = "meta"; + location = "/mpd/bluetooth/tcp"; + }; }; }; + environment.systemPackages = [ pkgs.snapcast ]; + }; + client = { + environment.systemPackages = [ pkgs.snapcast ]; }; - environment.systemPackages = [ pkgs.snapcast ]; - }; - client = { - environment.systemPackages = [ pkgs.snapcast ]; }; - }; - testScript = '' - import json + testScript = '' + import json - get_rpc_version = {"id": "1", "jsonrpc": "2.0", "method": "Server.GetRPCVersion"} + get_rpc_version = {"id": "1", "jsonrpc": "2.0", "method": "Server.GetRPCVersion"} - start_all() + start_all() - server.wait_for_unit("snapserver.service") - server.wait_until_succeeds("ss -ntl | grep -q ${toString port}") - server.wait_until_succeeds("ss -ntl | grep -q ${toString tcpPort}") - server.wait_until_succeeds("ss -ntl | grep -q ${toString httpPort}") - server.wait_until_succeeds("ss -ntl | grep -q ${toString tcpStreamPort}") + server.wait_for_unit("snapserver.service") + server.wait_until_succeeds("ss -ntl | grep -q ${toString port}") + server.wait_until_succeeds("ss -ntl | grep -q ${toString tcpPort}") + server.wait_until_succeeds("ss -ntl | grep -q ${toString httpPort}") + server.wait_until_succeeds("ss -ntl | grep -q ${toString tcpStreamPort}") - with subtest("check that pipes are created"): - server.succeed("test -p /run/snapserver/mpd") - server.succeed("test -p /run/snapserver/bluetooth") + with subtest("check that pipes are created"): + server.succeed("test -p /run/snapserver/mpd") + server.succeed("test -p /run/snapserver/bluetooth") - with subtest("test tcp json-rpc"): - server.succeed(f"echo '{json.dumps(get_rpc_version)}' | nc -w 1 localhost ${toString tcpPort}") + with subtest("test tcp json-rpc"): + server.succeed(f"echo '{json.dumps(get_rpc_version)}' | nc -w 1 localhost ${toString tcpPort}") - with subtest("test http json-rpc"): - server.succeed( - "curl --fail http://localhost:${toString httpPort}/jsonrpc -d '{json.dumps(get_rpc_version)}'" - ) + with subtest("test http json-rpc"): + server.succeed( + "curl --fail http://localhost:${toString httpPort}/jsonrpc -d '{json.dumps(get_rpc_version)}'" + ) - with subtest("test a ipv6 connection"): - server.execute("systemd-run --unit=snapcast-local-client snapclient -h ::1 -p ${toString port}") - server.wait_until_succeeds( - "journalctl -o cat -u snapserver.service | grep -q 'Hello from'" - ) - server.wait_until_succeeds("journalctl -o cat -u snapcast-local-client | grep -q 'buffer: ${toString bufferSize}'") + with subtest("test a ipv6 connection"): + server.execute("systemd-run --unit=snapcast-local-client snapclient -h ::1 -p ${toString port}") + server.wait_until_succeeds( + "journalctl -o cat -u snapserver.service | grep -q 'Hello from'" + ) + server.wait_until_succeeds("journalctl -o cat -u snapcast-local-client | grep -q 'buffer: ${toString bufferSize}'") - with subtest("test a connection"): - client.execute("systemd-run --unit=snapcast-client snapclient -h server -p ${toString port}") - server.wait_until_succeeds( - "journalctl -o cat -u snapserver.service | grep -q 'Hello from'" - ) - client.wait_until_succeeds("journalctl -o cat -u snapcast-client | grep -q 'buffer: ${toString bufferSize}'") - ''; -}) + with subtest("test a connection"): + client.execute("systemd-run --unit=snapcast-client snapclient -h server -p ${toString port}") + server.wait_until_succeeds( + "journalctl -o cat -u snapserver.service | grep -q 'Hello from'" + ) + client.wait_until_succeeds("journalctl -o cat -u snapcast-client | grep -q 'buffer: ${toString bufferSize}'") + ''; + } +) diff --git a/nixos/tests/snapper.nix b/nixos/tests/snapper.nix index 0369419930f157..683d2f58ea3cf2 100644 --- a/nixos/tests/snapper.nix +++ b/nixos/tests/snapper.nix @@ -1,38 +1,45 @@ -import ./make-test-python.nix ({ ... }: -{ - name = "snapper"; +import ./make-test-python.nix ( + { ... }: + { + name = "snapper"; - nodes.machine = { pkgs, lib, ... }: { - boot.initrd.postDeviceCommands = '' - ${pkgs.btrfs-progs}/bin/mkfs.btrfs -f -L aux /dev/vdb - ''; + nodes.machine = + { pkgs, lib, ... }: + { + boot.initrd.postDeviceCommands = '' + ${pkgs.btrfs-progs}/bin/mkfs.btrfs -f -L aux /dev/vdb + ''; - virtualisation.emptyDiskImages = [ 4096 ]; + virtualisation.emptyDiskImages = [ 4096 ]; - virtualisation.fileSystems = { - "/home" = { - device = "/dev/disk/by-label/aux"; - fsType = "btrfs"; + virtualisation.fileSystems = { + "/home" = { + device = "/dev/disk/by-label/aux"; + fsType = "btrfs"; + }; + }; + services.snapper.configs.home.SUBVOLUME = "/home"; + services.snapper.filters = "/nix"; }; - }; - services.snapper.configs.home.SUBVOLUME = "/home"; - services.snapper.filters = "/nix"; - }; - testScript = { nodes, ... }: let - inherit (nodes.machine.services.snapper) snapshotRootOnBoot; - in '' - machine.succeed("btrfs subvolume create /home/.snapshots") - machine.succeed("snapper -c home list") - machine.succeed("snapper -c home create --description empty") - machine.succeed("echo test > /home/file") - machine.succeed("snapper -c home create --description file") - machine.succeed("snapper -c home status 1..2") - machine.succeed("snapper -c home undochange 1..2") - machine.fail("ls /home/file") - machine.succeed("snapper -c home delete 2") - machine.succeed("systemctl --wait start snapper-timeline.service") - machine.succeed("systemctl --wait start snapper-cleanup.service") - machine.${if snapshotRootOnBoot then "succeed" else "fail"}("systemctl cat snapper-boot.service") - ''; -}) + testScript = + { nodes, ... }: + let + inherit (nodes.machine.services.snapper) snapshotRootOnBoot; + in + '' + machine.succeed("btrfs subvolume create /home/.snapshots") + machine.succeed("snapper -c home list") + machine.succeed("snapper -c home create --description empty") + machine.succeed("echo test > /home/file") + machine.succeed("snapper -c home create --description file") + machine.succeed("snapper -c home status 1..2") + machine.succeed("snapper -c home undochange 1..2") + machine.fail("ls /home/file") + machine.succeed("snapper -c home delete 2") + machine.succeed("systemctl --wait start snapper-timeline.service") + machine.succeed("systemctl --wait start snapper-cleanup.service") + machine.${if snapshotRootOnBoot then "succeed" else "fail"}("systemctl cat snapper-boot.service") + ''; + } +) diff --git a/nixos/tests/snmpd.nix b/nixos/tests/snmpd.nix index 9248a6b390101e..24d414e03d4d02 100644 --- a/nixos/tests/snmpd.nix +++ b/nixos/tests/snmpd.nix @@ -1,23 +1,26 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "snmpd"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "snmpd"; - nodes.snmpd = { - environment.systemPackages = with pkgs; [ - net-snmp - ]; + nodes.snmpd = { + environment.systemPackages = with pkgs; [ + net-snmp + ]; - services.snmpd = { - enable = true; - configText = '' - rocommunity public - ''; + services.snmpd = { + enable = true; + configText = '' + rocommunity public + ''; + }; }; - }; - testScript = '' - start_all(); - machine.wait_for_unit("snmpd.service") - machine.succeed("snmpwalk -v 2c -c public localhost | grep SNMPv2-MIB::sysName.0"); - ''; + testScript = '' + start_all(); + machine.wait_for_unit("snmpd.service") + machine.succeed("snmpwalk -v 2c -c public localhost | grep SNMPv2-MIB::sysName.0"); + ''; -}) + } +) diff --git a/nixos/tests/soapui.nix b/nixos/tests/soapui.nix index 3a2d11a167562e..834369f9dcc72c 100644 --- a/nixos/tests/soapui.nix +++ b/nixos/tests/soapui.nix @@ -1,24 +1,29 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "soapui"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "soapui"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; - nodes.machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + nodes.machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; + services.xserver.enable = true; - environment.systemPackages = [ pkgs.soapui ]; - }; + environment.systemPackages = [ pkgs.soapui ]; + }; - testScript = '' - machine.wait_for_x() - machine.succeed("soapui >&2 &") - machine.wait_for_window(r"SoapUI \d+\.\d+\.\d+") - machine.sleep(1) - machine.screenshot("soapui") - ''; -}) + testScript = '' + machine.wait_for_x() + machine.succeed("soapui >&2 &") + machine.wait_for_window(r"SoapUI \d+\.\d+\.\d+") + machine.sleep(1) + machine.screenshot("soapui") + ''; + } +) diff --git a/nixos/tests/soft-serve.nix b/nixos/tests/soft-serve.nix index 1c4cb4c95819ee..1fa365c93ef147 100644 --- a/nixos/tests/soft-serve.nix +++ b/nixos/tests/soft-serve.nix @@ -1,102 +1,110 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; - sshPort = 8231; - httpPort = 8232; - statsPort = 8233; - gitPort = 8418; -in -{ - name = "soft-serve"; - meta.maintainers = with lib.maintainers; [ dadada ]; - nodes = { - client = { pkgs, ... }: { - environment.systemPackages = with pkgs; [ - curl - git - openssh - ]; - environment.etc.sshKey = { - source = snakeOilPrivateKey; - mode = "0600"; - }; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; + sshPort = 8231; + httpPort = 8232; + statsPort = 8233; + gitPort = 8418; + in + { + name = "soft-serve"; + meta.maintainers = with lib.maintainers; [ dadada ]; + nodes = { + client = + { pkgs, ... }: + { + environment.systemPackages = with pkgs; [ + curl + git + openssh + ]; + environment.etc.sshKey = { + source = snakeOilPrivateKey; + mode = "0600"; + }; + }; - server = - { config, ... }: - { - services.soft-serve = { - enable = true; - settings = { - name = "TestServer"; - ssh.listen_addr = ":${toString sshPort}"; - git.listen_addr = ":${toString gitPort}"; - http.listen_addr = ":${toString httpPort}"; - stats.listen_addr = ":${toString statsPort}"; - initial_admin_keys = [ snakeOilPublicKey ]; + server = + { config, ... }: + { + services.soft-serve = { + enable = true; + settings = { + name = "TestServer"; + ssh.listen_addr = ":${toString sshPort}"; + git.listen_addr = ":${toString gitPort}"; + http.listen_addr = ":${toString httpPort}"; + stats.listen_addr = ":${toString statsPort}"; + initial_admin_keys = [ snakeOilPublicKey ]; + }; }; + networking.firewall.allowedTCPPorts = [ + sshPort + httpPort + statsPort + ]; }; - networking.firewall.allowedTCPPorts = [ sshPort httpPort statsPort ]; - }; - }; + }; - testScript = - { ... }: - '' - SSH_PORT = ${toString sshPort} - HTTP_PORT = ${toString httpPort} - STATS_PORT = ${toString statsPort} - KEY = "${snakeOilPublicKey}" - SSH_KEY = "/etc/sshKey" - SSH_COMMAND = f"ssh -p {SSH_PORT} -i {SSH_KEY} -o StrictHostKeyChecking=no" - TEST_DIR = "/tmp/test" - GIT = f"git -C {TEST_DIR}" + testScript = + { ... }: + '' + SSH_PORT = ${toString sshPort} + HTTP_PORT = ${toString httpPort} + STATS_PORT = ${toString statsPort} + KEY = "${snakeOilPublicKey}" + SSH_KEY = "/etc/sshKey" + SSH_COMMAND = f"ssh -p {SSH_PORT} -i {SSH_KEY} -o StrictHostKeyChecking=no" + TEST_DIR = "/tmp/test" + GIT = f"git -C {TEST_DIR}" - for machine in client, server: - machine.wait_for_unit("network.target") + for machine in client, server: + machine.wait_for_unit("network.target") - server.wait_for_unit("soft-serve.service") - server.wait_for_open_port(SSH_PORT) + server.wait_for_unit("soft-serve.service") + server.wait_for_open_port(SSH_PORT) - with subtest("Get info"): - status, test = client.execute(f"{SSH_COMMAND} server info") - if status != 0: - raise Exception("Failed to get SSH info") - key = " ".join(KEY.split(" ")[0:2]) - if not key in test: - raise Exception("Admin key must be configured correctly") + with subtest("Get info"): + status, test = client.execute(f"{SSH_COMMAND} server info") + if status != 0: + raise Exception("Failed to get SSH info") + key = " ".join(KEY.split(" ")[0:2]) + if not key in test: + raise Exception("Admin key must be configured correctly") - with subtest("Create user"): - client.succeed(f"{SSH_COMMAND} server user create beatrice") - client.succeed(f"{SSH_COMMAND} server user info beatrice") + with subtest("Create user"): + client.succeed(f"{SSH_COMMAND} server user create beatrice") + client.succeed(f"{SSH_COMMAND} server user info beatrice") - with subtest("Create repo"): - client.succeed(f"git init {TEST_DIR}") - client.succeed(f"{GIT} config --global user.email you@example.com") - client.succeed(f"touch {TEST_DIR}/foo") - client.succeed(f"{GIT} add foo") - client.succeed(f"{GIT} commit --allow-empty -m test") - client.succeed(f"{GIT} remote add origin git@server:test") - client.succeed(f"GIT_SSH_COMMAND='{SSH_COMMAND}' {GIT} push -u origin master") - client.execute("rm -r /tmp/test") + with subtest("Create repo"): + client.succeed(f"git init {TEST_DIR}") + client.succeed(f"{GIT} config --global user.email you@example.com") + client.succeed(f"touch {TEST_DIR}/foo") + client.succeed(f"{GIT} add foo") + client.succeed(f"{GIT} commit --allow-empty -m test") + client.succeed(f"{GIT} remote add origin git@server:test") + client.succeed(f"GIT_SSH_COMMAND='{SSH_COMMAND}' {GIT} push -u origin master") + client.execute("rm -r /tmp/test") - server.wait_for_open_port(HTTP_PORT) + server.wait_for_open_port(HTTP_PORT) - with subtest("Clone over HTTP"): - client.succeed(f"curl --connect-timeout 10 http://server:{HTTP_PORT}/") - client.succeed(f"git clone http://server:{HTTP_PORT}/test /tmp/test") - client.execute("rm -r /tmp/test") + with subtest("Clone over HTTP"): + client.succeed(f"curl --connect-timeout 10 http://server:{HTTP_PORT}/") + client.succeed(f"git clone http://server:{HTTP_PORT}/test /tmp/test") + client.execute("rm -r /tmp/test") - with subtest("Clone over SSH"): - client.succeed(f"GIT_SSH_COMMAND='{SSH_COMMAND}' git clone git@server:test /tmp/test") - client.execute("rm -r /tmp/test") + with subtest("Clone over SSH"): + client.succeed(f"GIT_SSH_COMMAND='{SSH_COMMAND}' git clone git@server:test /tmp/test") + client.execute("rm -r /tmp/test") - with subtest("Get stats over HTTP"): - server.wait_for_open_port(STATS_PORT) - status, test = client.execute(f"curl --connect-timeout 10 http://server:{STATS_PORT}/metrics") - if status != 0: - raise Exception("Failed to get metrics from status port") - if not "go_gc_duration_seconds_count" in test: - raise Exception("Metrics did not contain key 'go_gc_duration_seconds_count'") - ''; -}) + with subtest("Get stats over HTTP"): + server.wait_for_open_port(STATS_PORT) + status, test = client.execute(f"curl --connect-timeout 10 http://server:{STATS_PORT}/metrics") + if status != 0: + raise Exception("Failed to get metrics from status port") + if not "go_gc_duration_seconds_count" in test: + raise Exception("Metrics did not contain key 'go_gc_duration_seconds_count'") + ''; + } +) diff --git a/nixos/tests/sogo.nix b/nixos/tests/sogo.nix index 84d219659bdb25..a3ad3bd5b7ac2b 100644 --- a/nixos/tests/sogo.nix +++ b/nixos/tests/sogo.nix @@ -1,58 +1,65 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "sogo"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "sogo"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; - nodes = { - sogo = { config, pkgs, ... }: { - services.nginx.enable = true; + nodes = { + sogo = + { config, pkgs, ... }: + { + services.nginx.enable = true; - services.mysql = { - enable = true; - package = pkgs.mariadb; - ensureDatabases = [ "sogo" ]; - ensureUsers = [{ - name = "sogo"; - ensurePermissions = { - "sogo.*" = "ALL PRIVILEGES"; + services.mysql = { + enable = true; + package = pkgs.mariadb; + ensureDatabases = [ "sogo" ]; + ensureUsers = [ + { + name = "sogo"; + ensurePermissions = { + "sogo.*" = "ALL PRIVILEGES"; + }; + } + ]; }; - }]; - }; - services.sogo = { - enable = true; - timezone = "Europe/Berlin"; - extraConfig = '' - WOWorkersCount = 1; + services.sogo = { + enable = true; + timezone = "Europe/Berlin"; + extraConfig = '' + WOWorkersCount = 1; - SOGoUserSources = ( - { - type = sql; - userPasswordAlgorithm = md5; - viewURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_users"; - canAuthenticate = YES; - id = users; - } - ); + SOGoUserSources = ( + { + type = sql; + userPasswordAlgorithm = md5; + viewURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_users"; + canAuthenticate = YES; + id = users; + } + ); - SOGoProfileURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_user_profile"; - OCSFolderInfoURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_folder_info"; - OCSSessionsFolderURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_sessions_folder"; - OCSEMailAlarmsFolderURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_alarms_folder"; - OCSStoreURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_store"; - OCSAclURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_acl"; - OCSCacheFolderURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_cache_folder"; - ''; - }; + SOGoProfileURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_user_profile"; + OCSFolderInfoURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_folder_info"; + OCSSessionsFolderURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_sessions_folder"; + OCSEMailAlarmsFolderURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_alarms_folder"; + OCSStoreURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_store"; + OCSAclURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_acl"; + OCSCacheFolderURL = "mysql://sogo@%2Frun%2Fmysqld%2Fmysqld.sock/sogo/sogo_cache_folder"; + ''; + }; + }; }; - }; - testScript = '' - start_all() - sogo.wait_for_unit("multi-user.target") - sogo.wait_for_open_port(20000) - sogo.wait_for_open_port(80) - sogo.succeed("curl -sSfL http://sogo/SOGo") - ''; -}) + testScript = '' + start_all() + sogo.wait_for_unit("multi-user.target") + sogo.wait_for_open_port(20000) + sogo.wait_for_open_port(80) + sogo.succeed("curl -sSfL http://sogo/SOGo") + ''; + } +) diff --git a/nixos/tests/soju.nix b/nixos/tests/soju.nix index f13c447fb5f6b8..71f457b142043d 100644 --- a/nixos/tests/soju.nix +++ b/nixos/tests/soju.nix @@ -1,31 +1,35 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - certs = import ./common/acme/server/snakeoil-certs.nix; - domain = certs.domain; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + certs = import ./common/acme/server/snakeoil-certs.nix; + domain = certs.domain; - user = "testuser"; - pass = "hunter2"; -in -{ - name = "soju"; - meta.maintainers = [ ]; + user = "testuser"; + pass = "hunter2"; + in + { + name = "soju"; + meta.maintainers = [ ]; - nodes.machine = { ... }: { - services.soju = { - enable = true; - adminSocket.enable = true; - hostName = domain; - tlsCertificate = certs.${domain}.cert; - tlsCertificateKey = certs.${domain}.key; - }; - }; + nodes.machine = + { ... }: + { + services.soju = { + enable = true; + adminSocket.enable = true; + hostName = domain; + tlsCertificate = certs.${domain}.cert; + tlsCertificateKey = certs.${domain}.key; + }; + }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("soju") - machine.wait_for_file("/run/soju/admin") + machine.wait_for_unit("soju") + machine.wait_for_file("/run/soju/admin") - machine.succeed("sojuctl user create -username ${user} -password ${pass}") - ''; -}) + machine.succeed("sojuctl user create -username ${user} -password ${pass}") + ''; + } +) diff --git a/nixos/tests/solanum.nix b/nixos/tests/solanum.nix index 1ecf91bce40bc3..be3f4bfd45ae37 100644 --- a/nixos/tests/solanum.nix +++ b/nixos/tests/solanum.nix @@ -9,89 +9,100 @@ let iiDir = "/tmp/irc"; in -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "solanum"; - nodes = { - "${server}" = { - networking.firewall.allowedTCPPorts = [ ircPort ]; - services.solanum = { - enable = true; - motd = '' - The default MOTD doesn't contain the word "nixos" in it. - This one does. - ''; - }; - }; - } // lib.listToAttrs (builtins.map (client: lib.nameValuePair client { - imports = [ - ./common/user-account.nix - ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "solanum"; + nodes = + { + "${server}" = { + networking.firewall.allowedTCPPorts = [ ircPort ]; + services.solanum = { + enable = true; + motd = '' + The default MOTD doesn't contain the word "nixos" in it. + This one does. + ''; + }; + }; + } + // lib.listToAttrs ( + builtins.map ( + client: + lib.nameValuePair client { + imports = [ + ./common/user-account.nix + ]; - systemd.services.ii = { - requires = [ "network.target" ]; - wantedBy = [ "default.target" ]; + systemd.services.ii = { + requires = [ "network.target" ]; + wantedBy = [ "default.target" ]; - serviceConfig = { - Type = "simple"; - ExecPreStartPre = "mkdir -p ${iiDir}"; - ExecStart = '' - ${lib.getBin pkgs.ii}/bin/ii -n ${client} -s ${server} -i ${iiDir} - ''; - User = "alice"; - }; - }; - }) clients); + serviceConfig = { + Type = "simple"; + ExecPreStartPre = "mkdir -p ${iiDir}"; + ExecStart = '' + ${lib.getBin pkgs.ii}/bin/ii -n ${client} -s ${server} -i ${iiDir} + ''; + User = "alice"; + }; + }; + } + ) clients + ); - testScript = - let - msg = client: "Hello, my name is ${client}"; - clientScript = client: [ - '' - ${client}.wait_for_unit("network.target") - ${client}.systemctl("start ii") - ${client}.wait_for_unit("ii") - ${client}.wait_for_file("${iiDir}/${server}/out") - '' - # look for the custom text in the MOTD. - '' - ${client}.wait_until_succeeds("grep 'nixos' ${iiDir}/${server}/out") - '' - # wait until first PING from server arrives before joining, - # so we don't try it too early - '' - ${client}.wait_until_succeeds("grep 'PING' ${iiDir}/${server}/out") - '' - # join ${channel} - '' - ${client}.succeed("echo '/j #${channel}' > ${iiDir}/${server}/in") - ${client}.wait_for_file("${iiDir}/${server}/#${channel}/in") - '' - # send a greeting - '' - ${client}.succeed( - "echo '${msg client}' > ${iiDir}/${server}/#${channel}/in" - ) - '' - # check that all greetings arrived on all clients - ] ++ builtins.map (other: '' - ${client}.succeed( - "grep '${msg other}$' ${iiDir}/${server}/#${channel}/out" - ) - '') clients; + testScript = + let + msg = client: "Hello, my name is ${client}"; + clientScript = + client: + [ + '' + ${client}.wait_for_unit("network.target") + ${client}.systemctl("start ii") + ${client}.wait_for_unit("ii") + ${client}.wait_for_file("${iiDir}/${server}/out") + '' + # look for the custom text in the MOTD. + '' + ${client}.wait_until_succeeds("grep 'nixos' ${iiDir}/${server}/out") + '' + # wait until first PING from server arrives before joining, + # so we don't try it too early + '' + ${client}.wait_until_succeeds("grep 'PING' ${iiDir}/${server}/out") + '' + # join ${channel} + '' + ${client}.succeed("echo '/j #${channel}' > ${iiDir}/${server}/in") + ${client}.wait_for_file("${iiDir}/${server}/#${channel}/in") + '' + # send a greeting + '' + ${client}.succeed( + "echo '${msg client}' > ${iiDir}/${server}/#${channel}/in" + ) + '' + # check that all greetings arrived on all clients + ] + ++ builtins.map (other: '' + ${client}.succeed( + "grep '${msg other}$' ${iiDir}/${server}/#${channel}/out" + ) + '') clients; - # foldl', but requires a non-empty list instead of a start value - reduce = f: list: - builtins.foldl' f (builtins.head list) (builtins.tail list); - in '' - start_all() - ${server}.systemctl("status solanum") - ${server}.wait_for_open_port(${toString ircPort}) + # foldl', but requires a non-empty list instead of a start value + reduce = f: list: builtins.foldl' f (builtins.head list) (builtins.tail list); + in + '' + start_all() + ${server}.systemctl("status solanum") + ${server}.wait_for_open_port(${toString ircPort}) - # run clientScript for all clients so that every list - # entry is executed by every client before advancing - # to the next one. - '' + lib.concatStrings - (reduce - (lib.zipListsWith (cs: c: cs + c)) - (builtins.map clientScript clients)); -}) + # run clientScript for all clients so that every list + # entry is executed by every client before advancing + # to the next one. + '' + + lib.concatStrings (reduce (lib.zipListsWith (cs: c: cs + c)) (builtins.map clientScript clients)); + } +) diff --git a/nixos/tests/sonarr.nix b/nixos/tests/sonarr.nix index 57e6b72db3a35d..e9d6bdf625940b 100644 --- a/nixos/tests/sonarr.nix +++ b/nixos/tests/sonarr.nix @@ -1,16 +1,20 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "sonarr"; - meta.maintainers = with lib.maintainers; [ etu ]; + { + name = "sonarr"; + meta.maintainers = with lib.maintainers; [ etu ]; - nodes.machine = - { pkgs, ... }: - { services.sonarr.enable = true; }; + nodes.machine = + { pkgs, ... }: + { + services.sonarr.enable = true; + }; - testScript = '' - machine.wait_for_unit("sonarr.service") - machine.wait_for_open_port(8989) - machine.succeed("curl --fail http://localhost:8989/") - ''; -}) + testScript = '' + machine.wait_for_unit("sonarr.service") + machine.wait_for_open_port(8989) + machine.succeed("curl --fail http://localhost:8989/") + ''; + } +) diff --git a/nixos/tests/sonic-server.nix b/nixos/tests/sonic-server.nix index bb98047619b2b3..bef0316d66f066 100644 --- a/nixos/tests/sonic-server.nix +++ b/nixos/tests/sonic-server.nix @@ -1,22 +1,27 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "sonic-server"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "sonic-server"; - meta = { - maintainers = with lib.maintainers; [ anthonyroussel ]; - }; + meta = { + maintainers = with lib.maintainers; [ anthonyroussel ]; + }; - nodes.machine = { pkgs, ... }: { - services.sonic-server.enable = true; - }; + nodes.machine = + { pkgs, ... }: + { + services.sonic-server.enable = true; + }; - testScript = '' - machine.start() + testScript = '' + machine.start() - machine.wait_for_unit("sonic-server.service") - machine.wait_for_open_port(1491) + machine.wait_for_unit("sonic-server.service") + machine.wait_for_open_port(1491) - with subtest("Check control mode"): - result = machine.succeed('(echo START control; sleep 1; echo PING; echo QUIT) | nc localhost 1491').splitlines() - assert result[2] == "PONG", f"expected 'PONG', got '{result[2]}'" - ''; -}) + with subtest("Check control mode"): + result = machine.succeed('(echo START control; sleep 1; echo PING; echo QUIT) | nc localhost 1491').splitlines() + assert result[2] == "PONG", f"expected 'PONG', got '{result[2]}'" + ''; + } +) diff --git a/nixos/tests/sourcehut/builds.nix b/nixos/tests/sourcehut/builds.nix index f1f928ecc3d0a7..71d5b32384532b 100644 --- a/nixos/tests/sourcehut/builds.nix +++ b/nixos/tests/sourcehut/builds.nix @@ -1,54 +1,66 @@ -import ../make-test-python.nix ({ pkgs, lib, ... }: -let - domain = "sourcehut.localdomain"; -in -{ - name = "sourcehut"; - - meta.maintainers = with pkgs.lib.maintainers; [ tomberek nessdoor ]; - - nodes.machine = { config, pkgs, nodes, ... }: { - imports = [ - ./nodes/common.nix +import ../make-test-python.nix ( + { pkgs, lib, ... }: + let + domain = "sourcehut.localdomain"; + in + { + name = "sourcehut"; + + meta.maintainers = with pkgs.lib.maintainers; [ + tomberek + nessdoor ]; - networking.domain = domain; - networking.extraHosts = '' - ${config.networking.primaryIPAddress} builds.${domain} - ${config.networking.primaryIPAddress} meta.${domain} - ''; + nodes.machine = + { + config, + pkgs, + nodes, + ... + }: + { + imports = [ + ./nodes/common.nix + ]; - services.sourcehut = { - builds = { - enable = true; - # FIXME: see why it does not seem to activate fully. - #enableWorker = true; - images = { }; - }; + networking.domain = domain; + networking.extraHosts = '' + ${config.networking.primaryIPAddress} builds.${domain} + ${config.networking.primaryIPAddress} meta.${domain} + ''; + + services.sourcehut = { + builds = { + enable = true; + # FIXME: see why it does not seem to activate fully. + #enableWorker = true; + images = { }; + }; - settings."builds.sr.ht" = { - oauth-client-secret = pkgs.writeText "buildsrht-oauth-client-secret" "2260e9c4d9b8dcedcef642860e0504bc"; - oauth-client-id = "299db9f9c2013170"; + settings."builds.sr.ht" = { + oauth-client-secret = pkgs.writeText "buildsrht-oauth-client-secret" "2260e9c4d9b8dcedcef642860e0504bc"; + oauth-client-id = "299db9f9c2013170"; + }; + }; }; - }; - }; - - testScript = '' - start_all() - machine.wait_for_unit("multi-user.target") - - with subtest("Check whether meta comes up"): - machine.wait_for_unit("metasrht-api.service") - machine.wait_for_unit("metasrht.service") - machine.wait_for_unit("metasrht-webhooks.service") - machine.wait_for_open_port(5000) - machine.succeed("curl -sL http://localhost:5000 | grep meta.${domain}") - machine.succeed("curl -sL http://meta.${domain} | grep meta.${domain}") - - with subtest("Check whether builds comes up"): - machine.wait_for_unit("buildsrht.service") - machine.wait_for_open_port(5002) - machine.succeed("curl -sL http://localhost:5002 | grep builds.${domain}") - #machine.wait_for_unit("buildsrht-worker.service") - ''; -}) + + testScript = '' + start_all() + machine.wait_for_unit("multi-user.target") + + with subtest("Check whether meta comes up"): + machine.wait_for_unit("metasrht-api.service") + machine.wait_for_unit("metasrht.service") + machine.wait_for_unit("metasrht-webhooks.service") + machine.wait_for_open_port(5000) + machine.succeed("curl -sL http://localhost:5000 | grep meta.${domain}") + machine.succeed("curl -sL http://meta.${domain} | grep meta.${domain}") + + with subtest("Check whether builds comes up"): + machine.wait_for_unit("buildsrht.service") + machine.wait_for_open_port(5002) + machine.succeed("curl -sL http://localhost:5002 | grep builds.${domain}") + #machine.wait_for_unit("buildsrht-worker.service") + ''; + } +) diff --git a/nixos/tests/sourcehut/git.nix b/nixos/tests/sourcehut/git.nix index ed184d5d551800..7f50752c7eb8ca 100644 --- a/nixos/tests/sourcehut/git.nix +++ b/nixos/tests/sourcehut/git.nix @@ -1,96 +1,108 @@ -import ../make-test-python.nix ({ pkgs, lib, ... }: -let - domain = "sourcehut.localdomain"; -in -{ - name = "sourcehut"; +import ../make-test-python.nix ( + { pkgs, lib, ... }: + let + domain = "sourcehut.localdomain"; + in + { + name = "sourcehut"; - meta.maintainers = with pkgs.lib.maintainers; [ tomberek nessdoor ]; - - nodes.machine = { config, pkgs, nodes, ... }: { - imports = [ - ./nodes/common.nix + meta.maintainers = with pkgs.lib.maintainers; [ + tomberek + nessdoor ]; - networking.domain = domain; - networking.extraHosts = '' - ${config.networking.primaryIPAddress} git.${domain} - ${config.networking.primaryIPAddress} meta.${domain} - ''; + nodes.machine = + { + config, + pkgs, + nodes, + ... + }: + { + imports = [ + ./nodes/common.nix + ]; - services.sourcehut = { - git.enable = true; - settings."git.sr.ht" = { - oauth-client-secret = pkgs.writeText "gitsrht-oauth-client-secret" "3597288dc2c716e567db5384f493b09d"; - oauth-client-id = "d07cb713d920702e"; - }; - }; + networking.domain = domain; + networking.extraHosts = '' + ${config.networking.primaryIPAddress} git.${domain} + ${config.networking.primaryIPAddress} meta.${domain} + ''; - environment.systemPackages = with pkgs; [ - git - ]; - }; + services.sourcehut = { + git.enable = true; + settings."git.sr.ht" = { + oauth-client-secret = pkgs.writeText "gitsrht-oauth-client-secret" "3597288dc2c716e567db5384f493b09d"; + oauth-client-id = "d07cb713d920702e"; + }; + }; - testScript = - let - userName = "nixos-test"; - userPass = "AutoNixosTestPwd"; - hutConfig = pkgs.writeText "hut-config" '' - instance "${domain}" { - # Will be replaced at runtime with the generated token - access-token "OAUTH-TOKEN" - } - ''; - sshConfig = pkgs.writeText "ssh-config" '' - Host git.${domain} - IdentityFile = ~/.ssh/id_rsa - ''; - in - '' - start_all() - machine.wait_for_unit("multi-user.target") - machine.wait_for_unit("sshd.service") + environment.systemPackages = with pkgs; [ + git + ]; + }; - with subtest("Check whether meta comes up"): - machine.wait_for_unit("metasrht-api.service") - machine.wait_for_unit("metasrht.service") - machine.wait_for_unit("metasrht-webhooks.service") - machine.wait_for_open_port(5000) - machine.succeed("curl -sL http://localhost:5000 | grep meta.${domain}") - machine.succeed("curl -sL http://meta.${domain} | grep meta.${domain}") + testScript = + let + userName = "nixos-test"; + userPass = "AutoNixosTestPwd"; + hutConfig = pkgs.writeText "hut-config" '' + instance "${domain}" { + # Will be replaced at runtime with the generated token + access-token "OAUTH-TOKEN" + } + ''; + sshConfig = pkgs.writeText "ssh-config" '' + Host git.${domain} + IdentityFile = ~/.ssh/id_rsa + ''; + in + '' + start_all() + machine.wait_for_unit("multi-user.target") + machine.wait_for_unit("sshd.service") - with subtest("Create a new user account and OAuth access key"): - machine.succeed("echo ${userPass} | metasrht-manageuser -ps -e ${userName}@${domain}\ - -t active_paying ${userName}"); - (_, token) = machine.execute("srht-gen-oauth-tok -i ${domain} -q ${userName} ${userPass}") - token = token.strip().replace("/", r"\\/") # Escape slashes in token before passing it to sed - machine.execute("mkdir -p ~/.config/hut/") - machine.execute("sed s/OAUTH-TOKEN/" + token + "/ ${hutConfig} > ~/.config/hut/config") + with subtest("Check whether meta comes up"): + machine.wait_for_unit("metasrht-api.service") + machine.wait_for_unit("metasrht.service") + machine.wait_for_unit("metasrht-webhooks.service") + machine.wait_for_open_port(5000) + machine.succeed("curl -sL http://localhost:5000 | grep meta.${domain}") + machine.succeed("curl -sL http://meta.${domain} | grep meta.${domain}") - with subtest("Check whether git comes up"): - machine.wait_for_unit("gitsrht-api.service") - machine.wait_for_unit("gitsrht.service") - machine.wait_for_unit("gitsrht-webhooks.service") - machine.succeed("curl -sL http://git.${domain} | grep git.${domain}") + with subtest("Create a new user account and OAuth access key"): + machine.succeed("echo ${userPass} | metasrht-manageuser -ps -e ${userName}@${domain}\ + -t active_paying ${userName}"); + (_, token) = machine.execute("srht-gen-oauth-tok -i ${domain} -q ${userName} ${userPass}") + token = token.strip().replace("/", r"\\/") # Escape slashes in token before passing it to sed + machine.execute("mkdir -p ~/.config/hut/") + machine.execute("sed s/OAUTH-TOKEN/" + token + "/ ${hutConfig} > ~/.config/hut/config") - with subtest("Add an SSH key for Git access"): - machine.execute("ssh-keygen -q -N \"\" -t rsa -f ~/.ssh/id_rsa") - machine.execute("cat ${sshConfig} > ~/.ssh/config") - machine.succeed("hut meta ssh-key create ~/.ssh/id_rsa.pub") + with subtest("Check whether git comes up"): + machine.wait_for_unit("gitsrht-api.service") + machine.wait_for_unit("gitsrht.service") + machine.wait_for_unit("gitsrht-webhooks.service") + machine.succeed("curl -sL http://git.${domain} | grep git.${domain}") - with subtest("Create a new repo and push contents to it"): - machine.execute("git init test") - machine.execute("echo \"Hello world!\" > test/hello.txt") - machine.execute("cd test && git add .") - machine.execute("cd test && git commit -m \"Initial commit\"") - machine.execute("cd test && git tag v0.1") - machine.succeed("cd test && git remote add origin gitsrht@git.${domain}:~${userName}/test") - machine.execute("( echo -n 'git.${domain} '; cat /etc/ssh/ssh_host_ed25519_key.pub ) > ~/.ssh/known_hosts") - machine.succeed("hut git create test") - machine.succeed("cd test && git push --tags --set-upstream origin master") + with subtest("Add an SSH key for Git access"): + machine.execute("ssh-keygen -q -N \"\" -t rsa -f ~/.ssh/id_rsa") + machine.execute("cat ${sshConfig} > ~/.ssh/config") + machine.succeed("hut meta ssh-key create ~/.ssh/id_rsa.pub") - with subtest("Verify that the repo is downloadable and its contents match the original"): - machine.succeed("curl https://git.${domain}/~${userName}/test/archive/v0.1.tar.gz | tar -xz") - machine.succeed("diff test-v0.1/hello.txt test/hello.txt") - ''; -}) + with subtest("Create a new repo and push contents to it"): + machine.execute("git init test") + machine.execute("echo \"Hello world!\" > test/hello.txt") + machine.execute("cd test && git add .") + machine.execute("cd test && git commit -m \"Initial commit\"") + machine.execute("cd test && git tag v0.1") + machine.succeed("cd test && git remote add origin gitsrht@git.${domain}:~${userName}/test") + machine.execute("( echo -n 'git.${domain} '; cat /etc/ssh/ssh_host_ed25519_key.pub ) > ~/.ssh/known_hosts") + machine.succeed("hut git create test") + machine.succeed("cd test && git push --tags --set-upstream origin master") + + with subtest("Verify that the repo is downloadable and its contents match the original"): + machine.succeed("curl https://git.${domain}/~${userName}/test/archive/v0.1.tar.gz | tar -xz") + machine.succeed("diff test-v0.1/hello.txt test/hello.txt") + ''; + } +) diff --git a/nixos/tests/sourcehut/nodes/common.nix b/nixos/tests/sourcehut/nodes/common.nix index 1326a9e900576f..54660a4dade571 100644 --- a/nixos/tests/sourcehut/nodes/common.nix +++ b/nixos/tests/sourcehut/nodes/common.nix @@ -1,4 +1,9 @@ -{ config, pkgs, nodes, ... }: +{ + config, + pkgs, + nodes, + ... +}: let domain = config.networking.domain; @@ -41,23 +46,25 @@ in smtp-from = "root+hut@${domain}"; # WARNING: take care to keep pgp-privkey outside the Nix store in production, # or use LoadCredentialEncrypted= - pgp-privkey = toString (pkgs.writeText "sourcehut.pgp-privkey" '' - -----BEGIN PGP PRIVATE KEY BLOCK----- + pgp-privkey = toString ( + pkgs.writeText "sourcehut.pgp-privkey" '' + -----BEGIN PGP PRIVATE KEY BLOCK----- - lFgEZrFBKRYJKwYBBAHaRw8BAQdAS1Ffiytk0h0z0jfaT3qyiDUV/plVIUwOg1Yr - AXP2YmsAAP0W6QMC3G2G41rzCGLeSHeGibor1+XuxvcwUpVdW7ge+BH/tDZuaXhv - cy90ZXN0cy9zb3VyY2VodXQgPHJvb3QraHV0QHNvdXJjZWh1dC5sb2NhbGRvbWFp - bj6IkwQTFgoAOxYhBMISh2Z08FCi969cq9R2wSP9QF2bBQJmsUEpAhsDBQsJCAcC - AiICBhUKCQgLAgQWAgMBAh4HAheAAAoJENR2wSP9QF2b4JMA+wQLdxVcod/ppyvH - QguGqqhkpk8KquCddOuFnQVAfHFWAQCK5putVk4mGzsoLTbOJCSGRC4pjEktZawQ - MTqJmnOuC5xdBGaxQSkSCisGAQQBl1UBBQEBB0Aed6UYJyighTY+KuPNQ439st3x - x04T1j58sx3AnKgYewMBCAcAAP9WLB79HO1zFRqTCnk7GIEWWogMFKVpazeBUNu9 - h9rzCA2+iHgEGBYKACAWIQTCEodmdPBQovevXKvUdsEj/UBdmwUCZrFBKQIbDAAK - CRDUdsEj/UBdmwgJAQDVk/px/pSzqreSeDLzxlb6dOo+N1KcicsJ0akhSJUcvwD9 - EPhpEDZu/UBKchAutOhWwz+y6pyoF4Vt7XG+jbJQtA4= - =KaQc - -----END PGP PRIVATE KEY BLOCK----- - ''); + lFgEZrFBKRYJKwYBBAHaRw8BAQdAS1Ffiytk0h0z0jfaT3qyiDUV/plVIUwOg1Yr + AXP2YmsAAP0W6QMC3G2G41rzCGLeSHeGibor1+XuxvcwUpVdW7ge+BH/tDZuaXhv + cy90ZXN0cy9zb3VyY2VodXQgPHJvb3QraHV0QHNvdXJjZWh1dC5sb2NhbGRvbWFp + bj6IkwQTFgoAOxYhBMISh2Z08FCi969cq9R2wSP9QF2bBQJmsUEpAhsDBQsJCAcC + AiICBhUKCQgLAgQWAgMBAh4HAheAAAoJENR2wSP9QF2b4JMA+wQLdxVcod/ppyvH + QguGqqhkpk8KquCddOuFnQVAfHFWAQCK5putVk4mGzsoLTbOJCSGRC4pjEktZawQ + MTqJmnOuC5xdBGaxQSkSCisGAQQBl1UBBQEBB0Aed6UYJyighTY+KuPNQ439st3x + x04T1j58sx3AnKgYewMBCAcAAP9WLB79HO1zFRqTCnk7GIEWWogMFKVpazeBUNu9 + h9rzCA2+iHgEGBYKACAWIQTCEodmdPBQovevXKvUdsEj/UBdmwUCZrFBKQIbDAAK + CRDUdsEj/UBdmwgJAQDVk/px/pSzqreSeDLzxlb6dOo+N1KcicsJ0akhSJUcvwD9 + EPhpEDZu/UBKchAutOhWwz+y6pyoF4Vt7XG+jbJQtA4= + =KaQc + -----END PGP PRIVATE KEY BLOCK----- + '' + ); pgp-pubkey = pkgs.writeText "sourcehut.pgp-pubkey" '' -----BEGIN PGP PUBLIC KEY BLOCK----- @@ -78,7 +85,10 @@ in }; }; - networking.firewall.allowedTCPPorts = [ 80 443 ]; + networking.firewall.allowedTCPPorts = [ + 80 + 443 + ]; security.pki.certificateFiles = [ "${tls-cert}/cert.pem" ]; services.nginx = { enable = true; diff --git a/nixos/tests/spacecookie.nix b/nixos/tests/spacecookie.nix index a640657d8a6b68..696cdee902c41c 100644 --- a/nixos/tests/spacecookie.nix +++ b/nixos/tests/spacecookie.nix @@ -1,11 +1,13 @@ let - gopherRoot = "/tmp/gopher"; - gopherHost = "gopherd"; + gopherRoot = "/tmp/gopher"; + gopherHost = "gopherd"; gopherClient = "client"; - fileContent = "Hello Gopher!\n"; - fileName = "file.txt"; + fileContent = "Hello Gopher!\n"; + fileName = "file.txt"; in - import ./make-test-python.nix ({...}: { +import ./make-test-python.nix ( + { ... }: + { name = "spacecookie"; nodes = { ${gopherHost} = { @@ -26,7 +28,7 @@ in }; }; - ${gopherClient} = {}; + ${gopherClient} = { }; }; testScript = '' @@ -53,4 +55,5 @@ in if not (["0", "1"] == dirEntries): raise Exception("Unexpected directory response") ''; - }) + } +) diff --git a/nixos/tests/spark/default.nix b/nixos/tests/spark/default.nix index 034e9711bed527..9c6725d460e946 100644 --- a/nixos/tests/spark/default.nix +++ b/nixos/tests/spark/default.nix @@ -6,43 +6,56 @@ let default = testsForPackage { sparkPackage = pkgs.spark; }; }; - testsForPackage = args: lib.recurseIntoAttrs { - sparkCluster = testSparkCluster args; - passthru.override = args': testsForPackage (args // args'); - }; - testSparkCluster = { sparkPackage, ... }: pkgs.testers.nixosTest ({ - name = "spark"; + testsForPackage = + args: + lib.recurseIntoAttrs { + sparkCluster = testSparkCluster args; + passthru.override = args': testsForPackage (args // args'); + }; + testSparkCluster = + { sparkPackage, ... }: + pkgs.testers.nixosTest ({ + name = "spark"; - nodes = { - worker = { nodes, pkgs, ... }: { - services.spark = { - package = sparkPackage; - worker = { - enable = true; - master = "master:7077"; + nodes = { + worker = + { nodes, pkgs, ... }: + { + services.spark = { + package = sparkPackage; + worker = { + enable = true; + master = "master:7077"; + }; + }; + virtualisation.memorySize = 2048; }; - }; - virtualisation.memorySize = 2048; - }; - master = { config, pkgs, ... }: { - services.spark = { - package = sparkPackage; - master = { - enable = true; - bind = "0.0.0.0"; + master = + { config, pkgs, ... }: + { + services.spark = { + package = sparkPackage; + master = { + enable = true; + bind = "0.0.0.0"; + }; + }; + networking.firewall.allowedTCPPorts = [ + 22 + 7077 + 8080 + ]; }; - }; - networking.firewall.allowedTCPPorts = [ 22 7077 8080 ]; }; - }; - testScript = '' - master.wait_for_unit("spark-master.service") - worker.wait_for_unit("spark-worker.service") - worker.copy_from_host( "${./spark_sample.py}", "/spark_sample.py" ) - assert "Spark Master at spark://" in worker.succeed("curl -sSfkL http://master:8080/") - worker.succeed("spark-submit --version | systemd-cat") - worker.succeed("spark-submit --master spark://master:7077 --executor-memory 512m --executor-cores 1 /spark_sample.py") - ''; - }); -in tests + testScript = '' + master.wait_for_unit("spark-master.service") + worker.wait_for_unit("spark-worker.service") + worker.copy_from_host( "${./spark_sample.py}", "/spark_sample.py" ) + assert "<title>Spark Master at spark://" in worker.succeed("curl -sSfkL http://master:8080/") + worker.succeed("spark-submit --version | systemd-cat") + worker.succeed("spark-submit --master spark://master:7077 --executor-memory 512m --executor-cores 1 /spark_sample.py") + ''; + }); +in +tests diff --git a/nixos/tests/sqlite3-to-mysql.nix b/nixos/tests/sqlite3-to-mysql.nix index f18a442157e7b2..25ffa13ba4f522 100644 --- a/nixos/tests/sqlite3-to-mysql.nix +++ b/nixos/tests/sqlite3-to-mysql.nix @@ -1,65 +1,70 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: -/* - This test suite replaces the typical pytestCheckHook function in - sqlite3-to-mysql due to the need of a running mysql instance. -*/ + /* + This test suite replaces the typical pytestCheckHook function in + sqlite3-to-mysql due to the need of a running mysql instance. + */ -{ - name = "sqlite3-to-mysql"; - meta.maintainers = with lib.maintainers; [ gador ]; + { + name = "sqlite3-to-mysql"; + meta.maintainers = with lib.maintainers; [ gador ]; - nodes.machine = { pkgs, ... }: { - environment.systemPackages = with pkgs; [ - sqlite3-to-mysql - # create one coherent python environment - (python3.withPackages - (ps: sqlite3-to-mysql.propagatedBuildInputs ++ - [ - python3Packages.pytest - python3Packages.pytest-mock - python3Packages.pytest-timeout - python3Packages.factory-boy - python3Packages.docker # only needed so import does not fail - sqlite3-to-mysql - ]) - ) - ]; - services.mysql = { - package = pkgs.mariadb; - enable = true; - # from https://github.com/techouse/sqlite3-to-mysql/blob/master/tests/conftest.py - # and https://github.com/techouse/sqlite3-to-mysql/blob/master/.github/workflows/test.yml - initialScript = pkgs.writeText "mysql-init.sql" '' - create database test_db DEFAULT CHARACTER SET utf8mb4; - create user tester identified by 'testpass'; - grant all on test_db.* to tester; - create user tester@localhost identified by 'testpass'; - grant all on test_db.* to tester@localhost; - ''; - settings = { - mysqld = { - character-set-server = "utf8mb4"; - collation-server = "utf8mb4_unicode_ci"; - log_warnings = 1; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = with pkgs; [ + sqlite3-to-mysql + # create one coherent python environment + (python3.withPackages ( + ps: + sqlite3-to-mysql.propagatedBuildInputs + ++ [ + python3Packages.pytest + python3Packages.pytest-mock + python3Packages.pytest-timeout + python3Packages.factory-boy + python3Packages.docker # only needed so import does not fail + sqlite3-to-mysql + ] + )) + ]; + services.mysql = { + package = pkgs.mariadb; + enable = true; + # from https://github.com/techouse/sqlite3-to-mysql/blob/master/tests/conftest.py + # and https://github.com/techouse/sqlite3-to-mysql/blob/master/.github/workflows/test.yml + initialScript = pkgs.writeText "mysql-init.sql" '' + create database test_db DEFAULT CHARACTER SET utf8mb4; + create user tester identified by 'testpass'; + grant all on test_db.* to tester; + create user tester@localhost identified by 'testpass'; + grant all on test_db.* to tester@localhost; + ''; + settings = { + mysqld = { + character-set-server = "utf8mb4"; + collation-server = "utf8mb4_unicode_ci"; + log_warnings = 1; + }; + }; }; }; - }; - }; - testScript = '' - machine.wait_for_unit("mysql") + testScript = '' + machine.wait_for_unit("mysql") - machine.succeed( - "sqlite3mysql --version | grep ${pkgs.sqlite3-to-mysql.version}" - ) + machine.succeed( + "sqlite3mysql --version | grep ${pkgs.sqlite3-to-mysql.version}" + ) - # invalid_database_name: assert '1045 (28000): Access denied' in "1044 (42000): Access denied [...] - # invalid_database_user: does not return non-zero exit for some reason - # test_version: has problems importing sqlite3_to_mysql and determining the version - machine.succeed( - "cd ${pkgs.sqlite3-to-mysql.src} \ - && pytest -v --no-docker -k \"not test_invalid_database_name and not test_invalid_database_user and not test_version\"" - ) - ''; -}) + # invalid_database_name: assert '1045 (28000): Access denied' in "1044 (42000): Access denied [...] + # invalid_database_user: does not return non-zero exit for some reason + # test_version: has problems importing sqlite3_to_mysql and determining the version + machine.succeed( + "cd ${pkgs.sqlite3-to-mysql.src} \ + && pytest -v --no-docker -k \"not test_invalid_database_name and not test_invalid_database_user and not test_version\"" + ) + ''; + } +) diff --git a/nixos/tests/ssh-agent-auth.nix b/nixos/tests/ssh-agent-auth.nix index fee40afd615392..4bfe453586f929 100644 --- a/nixos/tests/ssh-agent-auth.nix +++ b/nixos/tests/ssh-agent-auth.nix @@ -1,55 +1,65 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: +import ./make-test-python.nix ( + { lib, pkgs, ... }: let inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; - in { + in + { name = "ssh-agent-auth"; meta.maintainers = with lib.maintainers; [ nicoo ]; - nodes = let nodeConfig = n: { ... }: { - users.users = { - admin = { - isNormalUser = true; - extraGroups = [ "wheel" ]; - openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; - }; - foo.isNormalUser = true; - }; + nodes = + let + nodeConfig = + n: + { ... }: + { + users.users = { + admin = { + isNormalUser = true; + extraGroups = [ "wheel" ]; + openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; + }; + foo.isNormalUser = true; + }; - security.pam.sshAgentAuth = { - # Must be specified, as nixpkgs CI expects everything to eval without warning - authorizedKeysFiles = [ "/etc/ssh/authorized_keys.d/%u" ]; - enable = true; - }; - security.${lib.replaceStrings [ "_" ] [ "-" ] n} = { - enable = true; - wheelNeedsPassword = true; # We are checking `pam_ssh_agent_auth(8)` works for a sudoer - }; + security.pam.sshAgentAuth = { + # Must be specified, as nixpkgs CI expects everything to eval without warning + authorizedKeysFiles = [ "/etc/ssh/authorized_keys.d/%u" ]; + enable = true; + }; + security.${lib.replaceStrings [ "_" ] [ "-" ] n} = { + enable = true; + wheelNeedsPassword = true; # We are checking `pam_ssh_agent_auth(8)` works for a sudoer + }; - # Necessary for pam_ssh_agent_auth >_>' - services.openssh.enable = true; - }; - in lib.genAttrs [ "sudo" "sudo_rs" ] nodeConfig; + # Necessary for pam_ssh_agent_auth >_>' + services.openssh.enable = true; + }; + in + lib.genAttrs [ "sudo" "sudo_rs" ] nodeConfig; - testScript = let - privateKeyPath = "/home/admin/.ssh/id_ecdsa"; - userScript = pkgs.writeShellScript "test-script" '' - set -e - ssh-add -q ${privateKeyPath} + testScript = + let + privateKeyPath = "/home/admin/.ssh/id_ecdsa"; + userScript = pkgs.writeShellScript "test-script" '' + set -e + ssh-add -q ${privateKeyPath} - # faketty needed to ensure `sudo` doesn't write to the controlling PTY, - # which would break the test-driver's line-oriented protocol. - ${lib.getExe pkgs.faketty} sudo -u foo -- id -un - ''; - in '' - for vm in (sudo, sudo_rs): - sudo_impl = vm.name.replace("_", "-") - with subtest(f"wheel user can auth with ssh-agent for {sudo_impl}"): - vm.copy_from_host("${snakeOilPrivateKey}", "${privateKeyPath}") - vm.succeed("chmod -R 0700 /home/admin") - vm.succeed("chown -R admin:users /home/admin") + # faketty needed to ensure `sudo` doesn't write to the controlling PTY, + # which would break the test-driver's line-oriented protocol. + ${lib.getExe pkgs.faketty} sudo -u foo -- id -un + ''; + in + '' + for vm in (sudo, sudo_rs): + sudo_impl = vm.name.replace("_", "-") + with subtest(f"wheel user can auth with ssh-agent for {sudo_impl}"): + vm.copy_from_host("${snakeOilPrivateKey}", "${privateKeyPath}") + vm.succeed("chmod -R 0700 /home/admin") + vm.succeed("chown -R admin:users /home/admin") - # Run `userScript` in an environment with an SSH-agent available - assert vm.succeed("sudo -u admin -- ssh-agent ${userScript} 2>&1").strip() == "foo" - ''; + # Run `userScript` in an environment with an SSH-agent available + assert vm.succeed("sudo -u admin -- ssh-agent ${userScript} 2>&1").strip() == "foo" + ''; } ) diff --git a/nixos/tests/ssh-audit.nix b/nixos/tests/ssh-audit.nix index 25772aba3ea08d..3e0c33c6850f10 100644 --- a/nixos/tests/ssh-audit.nix +++ b/nixos/tests/ssh-audit.nix @@ -1,11 +1,13 @@ import ./make-test-python.nix ( - {pkgs, ...}: let + { pkgs, ... }: + let sshKeys = import (pkgs.path + "/nixos/tests/ssh-keys.nix") pkgs; sshUsername = "any-user"; serverName = "server"; clientName = "client"; sshAuditPort = 2222; - in { + in + { name = "ssh"; nodes = { diff --git a/nixos/tests/ssh-keys.nix b/nixos/tests/ssh-keys.nix index 675f3a0b439474..2c25778a208546 100644 --- a/nixos/tests/ssh-keys.nix +++ b/nixos/tests/ssh-keys.nix @@ -1,5 +1,5 @@ -pkgs: -{ snakeOilPrivateKey = pkgs.writeText "privkey.snakeoil" '' +pkgs: { + snakeOilPrivateKey = pkgs.writeText "privkey.snakeoil" '' -----BEGIN EC PRIVATE KEY----- MHcCAQEEIHQf/khLvYrQ8IOika5yqtWvI0oquHlpRLTZiJy5dRJmoAoGCCqGSM49 AwEHoUQDQgAEKF0DYGbBwbj06tA3fd/+yP44cvmwmHBWXZCKbS+RQlAKvLXMWkpN diff --git a/nixos/tests/sslh.nix b/nixos/tests/sslh.nix index 30ffd389d4422c..16a74eadb56acf 100644 --- a/nixos/tests/sslh.nix +++ b/nixos/tests/sslh.nix @@ -2,49 +2,64 @@ import ./make-test-python.nix { name = "sslh"; nodes = { - server = { pkgs, lib, ... }: { - networking.firewall.allowedTCPPorts = [ 443 ]; - networking.interfaces.eth1.ipv6.addresses = [ - { - address = "fe00:aa:bb:cc::2"; - prefixLength = 64; - } - ]; - services.sslh = { - enable = true; - settings.transparent = true; - settings.protocols = [ - { name = "ssh"; service = "ssh"; host = "localhost"; port = "22"; probe = "builtin"; } - { name = "http"; host = "localhost"; port = "80"; probe = "builtin"; } + server = + { pkgs, lib, ... }: + { + networking.firewall.allowedTCPPorts = [ 443 ]; + networking.interfaces.eth1.ipv6.addresses = [ + { + address = "fe00:aa:bb:cc::2"; + prefixLength = 64; + } ]; - }; - services.openssh.enable = true; - users.users.root.openssh.authorizedKeys.keyFiles = [ ./initrd-network-ssh/id_ed25519.pub ]; - services.nginx = { - enable = true; - virtualHosts."localhost" = { - addSSL = false; - default = true; - root = pkgs.runCommand "testdir" {} '' - mkdir "$out" - echo hello world > "$out/index.html" - ''; + services.sslh = { + enable = true; + settings.transparent = true; + settings.protocols = [ + { + name = "ssh"; + service = "ssh"; + host = "localhost"; + port = "22"; + probe = "builtin"; + } + { + name = "http"; + host = "localhost"; + port = "80"; + probe = "builtin"; + } + ]; + }; + services.openssh.enable = true; + users.users.root.openssh.authorizedKeys.keyFiles = [ ./initrd-network-ssh/id_ed25519.pub ]; + services.nginx = { + enable = true; + virtualHosts."localhost" = { + addSSL = false; + default = true; + root = pkgs.runCommand "testdir" { } '' + mkdir "$out" + echo hello world > "$out/index.html" + ''; + }; }; }; - }; - client = { ... }: { - networking.interfaces.eth1.ipv6.addresses = [ - { - address = "fe00:aa:bb:cc::1"; - prefixLength = 64; - } - ]; - networking.hosts."fe00:aa:bb:cc::2" = [ "server" ]; - environment.etc.sshKey = { - source = ./initrd-network-ssh/id_ed25519; # dont use this anywhere else - mode = "0600"; + client = + { ... }: + { + networking.interfaces.eth1.ipv6.addresses = [ + { + address = "fe00:aa:bb:cc::1"; + prefixLength = 64; + } + ]; + networking.hosts."fe00:aa:bb:cc::2" = [ "server" ]; + environment.etc.sshKey = { + source = ./initrd-network-ssh/id_ed25519; # dont use this anywhere else + mode = "0600"; + }; }; - }; }; testScript = '' diff --git a/nixos/tests/sssd-ldap.nix b/nixos/tests/sssd-ldap.nix index 60f3b1a415dafa..9bc991f6ddcea9 100644 --- a/nixos/tests/sssd-ldap.nix +++ b/nixos/tests/sssd-ldap.nix @@ -9,165 +9,175 @@ let testPassword = "foobar"; testNewPassword = "barfoo"; in -import ./make-test-python.nix ({ pkgs, ... }: { - name = "sssd-ldap"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "sssd-ldap"; - meta = with pkgs.lib.maintainers; { - maintainers = [ bbigras s1341 ]; - }; + meta = with pkgs.lib.maintainers; { + maintainers = [ + bbigras + s1341 + ]; + }; - nodes.machine = { pkgs, ... }: { - security.pam.services.systemd-user.makeHomeDir = true; - environment.etc."cert.pem".text = builtins.readFile ./common/acme/server/acme.test.cert.pem; - environment.etc."key.pem".text = builtins.readFile ./common/acme/server/acme.test.key.pem; - services.openldap = { - enable = true; - urlList = [ "ldap:///" "ldaps:///" ]; - settings = { - attrs = { - olcTLSCACertificateFile = "/etc/cert.pem"; - olcTLSCertificateFile = "/etc/cert.pem"; - olcTLSCertificateKeyFile = "/etc/key.pem"; - olcTLSCipherSuite = "HIGH:MEDIUM:+3DES:+RC4:+aNULL"; - olcTLSCRLCheck = "none"; - olcTLSVerifyClient = "never"; - olcTLSProtocolMin = "3.1"; - }; - children = { - "cn=schema".includes = [ - "${pkgs.openldap}/etc/schema/core.ldif" - "${pkgs.openldap}/etc/schema/cosine.ldif" - "${pkgs.openldap}/etc/schema/inetorgperson.ldif" - "${pkgs.openldap}/etc/schema/nis.ldif" + nodes.machine = + { pkgs, ... }: + { + security.pam.services.systemd-user.makeHomeDir = true; + environment.etc."cert.pem".text = builtins.readFile ./common/acme/server/acme.test.cert.pem; + environment.etc."key.pem".text = builtins.readFile ./common/acme/server/acme.test.key.pem; + services.openldap = { + enable = true; + urlList = [ + "ldap:///" + "ldaps:///" ]; - "olcDatabase={1}mdb" = { + settings = { attrs = { - objectClass = [ "olcDatabaseConfig" "olcMdbConfig" ]; - olcDatabase = "{1}mdb"; - olcDbDirectory = "/var/lib/openldap/db"; - olcSuffix = dbSuffix; - olcRootDN = "cn=${ldapRootUser},${dbSuffix}"; - olcRootPW = ldapRootPassword; - olcAccess = [ - /* - custom access rules for userPassword attributes - */ - '' - {0}to attrs=userPassword - by self write - by anonymous auth - by * none'' - - /* - allow read on anything else - */ - '' - {1}to * - by * read'' + olcTLSCACertificateFile = "/etc/cert.pem"; + olcTLSCertificateFile = "/etc/cert.pem"; + olcTLSCertificateKeyFile = "/etc/key.pem"; + olcTLSCipherSuite = "HIGH:MEDIUM:+3DES:+RC4:+aNULL"; + olcTLSCRLCheck = "none"; + olcTLSVerifyClient = "never"; + olcTLSProtocolMin = "3.1"; + }; + children = { + "cn=schema".includes = [ + "${pkgs.openldap}/etc/schema/core.ldif" + "${pkgs.openldap}/etc/schema/cosine.ldif" + "${pkgs.openldap}/etc/schema/inetorgperson.ldif" + "${pkgs.openldap}/etc/schema/nis.ldif" ]; + "olcDatabase={1}mdb" = { + attrs = { + objectClass = [ + "olcDatabaseConfig" + "olcMdbConfig" + ]; + olcDatabase = "{1}mdb"; + olcDbDirectory = "/var/lib/openldap/db"; + olcSuffix = dbSuffix; + olcRootDN = "cn=${ldapRootUser},${dbSuffix}"; + olcRootPW = ldapRootPassword; + olcAccess = [ + # custom access rules for userPassword attributes + '' + {0}to attrs=userPassword + by self write + by anonymous auth + by * none'' + + # allow read on anything else + '' + {1}to * + by * read'' + ]; + }; + }; }; }; - }; - }; - declarativeContents = { - ${dbSuffix} = '' - dn: ${dbSuffix} - objectClass: top - objectClass: dcObject - objectClass: organization - o: ${dbDomain} + declarativeContents = { + ${dbSuffix} = '' + dn: ${dbSuffix} + objectClass: top + objectClass: dcObject + objectClass: organization + o: ${dbDomain} - dn: ou=posix,${dbSuffix} - objectClass: top - objectClass: organizationalUnit + dn: ou=posix,${dbSuffix} + objectClass: top + objectClass: organizationalUnit - dn: ou=accounts,ou=posix,${dbSuffix} - objectClass: top - objectClass: organizationalUnit + dn: ou=accounts,ou=posix,${dbSuffix} + objectClass: top + objectClass: organizationalUnit - dn: uid=${testUser},ou=accounts,ou=posix,${dbSuffix} - objectClass: person - objectClass: posixAccount - userPassword: ${testPassword} - homeDirectory: /home/${testUser} - uidNumber: 1234 - gidNumber: 1234 - cn: "" - sn: "" - ''; - }; - }; + dn: uid=${testUser},ou=accounts,ou=posix,${dbSuffix} + objectClass: person + objectClass: posixAccount + userPassword: ${testPassword} + homeDirectory: /home/${testUser} + uidNumber: 1234 + gidNumber: 1234 + cn: "" + sn: "" + ''; + }; + }; - services.sssd = { - enable = true; - # just for testing purposes, don't put this into the Nix store in production! - environmentFile = "${pkgs.writeText "ldap-root" "LDAP_BIND_PW=${ldapRootPassword}"}"; - config = '' - [sssd] - config_file_version = 2 - services = nss, pam, sudo - domains = ${dbDomain} + services.sssd = { + enable = true; + # just for testing purposes, don't put this into the Nix store in production! + environmentFile = "${pkgs.writeText "ldap-root" "LDAP_BIND_PW=${ldapRootPassword}"}"; + config = '' + [sssd] + config_file_version = 2 + services = nss, pam, sudo + domains = ${dbDomain} - [domain/${dbDomain}] - auth_provider = ldap - id_provider = ldap - ldap_uri = ldaps://127.0.0.1:636 - ldap_tls_reqcert = allow - ldap_tls_cacert = /etc/cert.pem - ldap_search_base = ${dbSuffix} - ldap_default_bind_dn = cn=${ldapRootUser},${dbSuffix} - ldap_default_authtok_type = password - ldap_default_authtok = $LDAP_BIND_PW - ''; - }; - }; + [domain/${dbDomain}] + auth_provider = ldap + id_provider = ldap + ldap_uri = ldaps://127.0.0.1:636 + ldap_tls_reqcert = allow + ldap_tls_cacert = /etc/cert.pem + ldap_search_base = ${dbSuffix} + ldap_default_bind_dn = cn=${ldapRootUser},${dbSuffix} + ldap_default_authtok_type = password + ldap_default_authtok = $LDAP_BIND_PW + ''; + }; + }; - testScript = '' - machine.start() - machine.wait_for_unit("openldap.service") - machine.wait_for_unit("sssd.service") - result = machine.execute("getent passwd ${testUser}") - if result[0] == 0: - assert "${testUser}" in result[1] - else: - machine.wait_for_console_text("Backend is online") - machine.succeed("getent passwd ${testUser}") + testScript = '' + machine.start() + machine.wait_for_unit("openldap.service") + machine.wait_for_unit("sssd.service") + result = machine.execute("getent passwd ${testUser}") + if result[0] == 0: + assert "${testUser}" in result[1] + else: + machine.wait_for_console_text("Backend is online") + machine.succeed("getent passwd ${testUser}") - with subtest("Log in as ${testUser}"): - machine.wait_until_tty_matches("1", "login: ") - machine.send_chars("${testUser}\n") - machine.wait_until_tty_matches("1", "login: ${testUser}") - machine.wait_until_succeeds("pgrep login") - machine.wait_until_tty_matches("1", "Password: ") - machine.send_chars("${testPassword}\n") - machine.wait_until_succeeds("pgrep -u ${testUser} bash") - machine.send_chars("touch done\n") - machine.wait_for_file("/home/${testUser}/done") + with subtest("Log in as ${testUser}"): + machine.wait_until_tty_matches("1", "login: ") + machine.send_chars("${testUser}\n") + machine.wait_until_tty_matches("1", "login: ${testUser}") + machine.wait_until_succeeds("pgrep login") + machine.wait_until_tty_matches("1", "Password: ") + machine.send_chars("${testPassword}\n") + machine.wait_until_succeeds("pgrep -u ${testUser} bash") + machine.send_chars("touch done\n") + machine.wait_for_file("/home/${testUser}/done") - with subtest("Change ${testUser}'s password"): - machine.send_chars("passwd\n") - machine.wait_until_tty_matches("1", "Current Password: ") - machine.send_chars("${testPassword}\n") - machine.wait_until_tty_matches("1", "New Password: ") - machine.send_chars("${testNewPassword}\n") - machine.wait_until_tty_matches("1", "Reenter new Password: ") - machine.send_chars("${testNewPassword}\n") - machine.wait_until_tty_matches("1", "passwd: password updated successfully") + with subtest("Change ${testUser}'s password"): + machine.send_chars("passwd\n") + machine.wait_until_tty_matches("1", "Current Password: ") + machine.send_chars("${testPassword}\n") + machine.wait_until_tty_matches("1", "New Password: ") + machine.send_chars("${testNewPassword}\n") + machine.wait_until_tty_matches("1", "Reenter new Password: ") + machine.send_chars("${testNewPassword}\n") + machine.wait_until_tty_matches("1", "passwd: password updated successfully") - with subtest("Log in as ${testUser} with new password in virtual console 2"): - machine.send_key("alt-f2") - machine.wait_until_succeeds("[ $(fgconsole) = 2 ]") - machine.wait_for_unit("getty@tty2.service") - machine.wait_until_succeeds("pgrep -f 'agetty.*tty2'") + with subtest("Log in as ${testUser} with new password in virtual console 2"): + machine.send_key("alt-f2") + machine.wait_until_succeeds("[ $(fgconsole) = 2 ]") + machine.wait_for_unit("getty@tty2.service") + machine.wait_until_succeeds("pgrep -f 'agetty.*tty2'") - machine.wait_until_tty_matches("2", "login: ") - machine.send_chars("${testUser}\n") - machine.wait_until_tty_matches("2", "login: ${testUser}") - machine.wait_until_succeeds("pgrep login") - machine.wait_until_tty_matches("2", "Password: ") - machine.send_chars("${testNewPassword}\n") - machine.wait_until_succeeds("pgrep -u ${testUser} bash") - machine.send_chars("touch done2\n") - machine.wait_for_file("/home/${testUser}/done2") - ''; -}) + machine.wait_until_tty_matches("2", "login: ") + machine.send_chars("${testUser}\n") + machine.wait_until_tty_matches("2", "login: ${testUser}") + machine.wait_until_succeeds("pgrep login") + machine.wait_until_tty_matches("2", "Password: ") + machine.send_chars("${testNewPassword}\n") + machine.wait_until_succeeds("pgrep -u ${testUser} bash") + machine.send_chars("touch done2\n") + machine.wait_for_file("/home/${testUser}/done2") + ''; + } +) diff --git a/nixos/tests/sssd.nix b/nixos/tests/sssd.nix index c8d356e074ad5c..5622eadf4e16d6 100644 --- a/nixos/tests/sssd.nix +++ b/nixos/tests/sssd.nix @@ -1,18 +1,22 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -{ - name = "sssd"; - meta = with pkgs.lib.maintainers; { - maintainers = [ bbigras ]; - }; - nodes.machine = { pkgs, ... }: { - services.sssd.enable = true; - }; + { + name = "sssd"; + meta = with pkgs.lib.maintainers; { + maintainers = [ bbigras ]; + }; + nodes.machine = + { pkgs, ... }: + { + services.sssd.enable = true; + }; - testScript = '' + testScript = '' start_all() machine.wait_for_unit("multi-user.target") machine.wait_for_unit("sssd.service") machine.succeed("sssctl config-check") ''; -}) + } +) diff --git a/nixos/tests/stalwart-mail.nix b/nixos/tests/stalwart-mail.nix index 173b4fce4ad5dd..fb5b9f7fc593e0 100644 --- a/nixos/tests/stalwart-mail.nix +++ b/nixos/tests/stalwart-mail.nix @@ -6,115 +6,126 @@ let certs = import ./common/acme/server/snakeoil-certs.nix; domain = certs.domain; -in import ./make-test-python.nix ({ lib, ... }: { - name = "stalwart-mail"; - - nodes.main = { pkgs, ... }: { - security.pki.certificateFiles = [ certs.ca.cert ]; - - services.stalwart-mail = { - enable = true; - settings = { - server.hostname = domain; - - certificate."snakeoil" = { - cert = "%{file:${certs.${domain}.cert}}%"; - private-key = "%{file:${certs.${domain}.key}}%"; - }; - - server.tls = { - certificate = "snakeoil"; +in +import ./make-test-python.nix ( + { lib, ... }: + { + name = "stalwart-mail"; + + nodes.main = + { pkgs, ... }: + { + security.pki.certificateFiles = [ certs.ca.cert ]; + + services.stalwart-mail = { enable = true; - implicit = false; - }; - - server.listener = { - "smtp-submission" = { - bind = [ "[::]:587" ]; - protocol = "smtp"; - }; - - "imap" = { - bind = [ "[::]:143" ]; - protocol = "imap"; + settings = { + server.hostname = domain; + + certificate."snakeoil" = { + cert = "%{file:${certs.${domain}.cert}}%"; + private-key = "%{file:${certs.${domain}.key}}%"; + }; + + server.tls = { + certificate = "snakeoil"; + enable = true; + implicit = false; + }; + + server.listener = { + "smtp-submission" = { + bind = [ "[::]:587" ]; + protocol = "smtp"; + }; + + "imap" = { + bind = [ "[::]:143" ]; + protocol = "imap"; + }; + }; + + session.auth.mechanisms = "[plain]"; + session.auth.directory = "'in-memory'"; + storage.directory = "in-memory"; + + session.rcpt.directory = "'in-memory'"; + queue.outbound.next-hop = "'local'"; + + directory."in-memory" = { + type = "memory"; + principals = [ + { + class = "individual"; + name = "alice"; + secret = "foobar"; + email = [ "alice@${domain}" ]; + } + { + class = "individual"; + name = "bob"; + secret = "foobar"; + email = [ "bob@${domain}" ]; + } + ]; + }; }; }; - session.auth.mechanisms = "[plain]"; - session.auth.directory = "'in-memory'"; - storage.directory = "in-memory"; - - session.rcpt.directory = "'in-memory'"; - queue.outbound.next-hop = "'local'"; - - directory."in-memory" = { - type = "memory"; - principals = [ - { - class = "individual"; - name = "alice"; - secret = "foobar"; - email = [ "alice@${domain}" ]; - } - { - class = "individual"; - name = "bob"; - secret = "foobar"; - email = [ "bob@${domain}" ]; - } - ]; - }; + environment.systemPackages = [ + (pkgs.writers.writePython3Bin "test-smtp-submission" { } '' + from smtplib import SMTP + + with SMTP('localhost', 587) as smtp: + smtp.starttls() + smtp.login('alice', 'foobar') + smtp.sendmail( + 'alice@${domain}', + 'bob@${domain}', + """ + From: alice@${domain} + To: bob@${domain} + Subject: Some test message + + This is a test message. + """.strip() + ) + '') + + (pkgs.writers.writePython3Bin "test-imap-read" { } '' + from imaplib import IMAP4 + + with IMAP4('localhost') as imap: + imap.starttls() + status, [caps] = imap.login('bob', 'foobar') + assert status == 'OK' + imap.select() + status, [ref] = imap.search(None, 'ALL') + assert status == 'OK' + [msgId] = ref.split() + status, msg = imap.fetch(msgId, 'BODY[TEXT]') + assert status == 'OK' + assert msg[0][1].strip() == b'This is a test message.' + '') + ]; }; - }; - environment.systemPackages = [ - (pkgs.writers.writePython3Bin "test-smtp-submission" { } '' - from smtplib import SMTP - - with SMTP('localhost', 587) as smtp: - smtp.starttls() - smtp.login('alice', 'foobar') - smtp.sendmail( - 'alice@${domain}', - 'bob@${domain}', - """ - From: alice@${domain} - To: bob@${domain} - Subject: Some test message - - This is a test message. - """.strip() - ) - '') - - (pkgs.writers.writePython3Bin "test-imap-read" { } '' - from imaplib import IMAP4 - - with IMAP4('localhost') as imap: - imap.starttls() - status, [caps] = imap.login('bob', 'foobar') - assert status == 'OK' - imap.select() - status, [ref] = imap.search(None, 'ALL') - assert status == 'OK' - [msgId] = ref.split() - status, msg = imap.fetch(msgId, 'BODY[TEXT]') - assert status == 'OK' - assert msg[0][1].strip() == b'This is a test message.' - '') - ]; - }; - - testScript = /* python */ '' - main.wait_for_unit("stalwart-mail.service") - main.wait_for_open_port(587) - main.wait_for_open_port(143) - - main.succeed("test-smtp-submission") - main.succeed("test-imap-read") - ''; - - meta = { - maintainers = with lib.maintainers; [ happysalada pacien onny ]; - }; -}) + testScript = # python + '' + main.wait_for_unit("stalwart-mail.service") + main.wait_for_open_port(587) + main.wait_for_open_port(143) + + main.succeed("test-smtp-submission") + main.succeed("test-imap-read") + ''; + + meta = { + maintainers = with lib.maintainers; [ + happysalada + pacien + onny + ]; + }; + } +) diff --git a/nixos/tests/starship.nix b/nixos/tests/starship.nix index 48a4be6caf1760..23e103fc000e11 100644 --- a/nixos/tests/starship.nix +++ b/nixos/tests/starship.nix @@ -1,42 +1,53 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "starship"; - meta.maintainers = pkgs.starship.meta.maintainers; - - nodes.machine = { - programs = { - fish.enable = true; - zsh.enable = true; - - starship = { - enable = true; - settings.format = "<starship>"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "starship"; + meta.maintainers = pkgs.starship.meta.maintainers; + + nodes.machine = { + programs = { + fish.enable = true; + zsh.enable = true; + + starship = { + enable = true; + settings.format = "<starship>"; + }; }; + + environment.systemPackages = + map + ( + shell: + pkgs.writeScriptBin "expect-${shell}" '' + #!${pkgs.expect}/bin/expect -f + + spawn env TERM=xterm ${shell} -i + + expect "<starship>" { + send "exit\n" + } timeout { + send_user "\n${shell} failed to display Starship\n" + exit 1 + } + + expect eof + '' + ) + [ + "bash" + "fish" + "zsh" + ]; }; - environment.systemPackages = map - (shell: pkgs.writeScriptBin "expect-${shell}" '' - #!${pkgs.expect}/bin/expect -f - - spawn env TERM=xterm ${shell} -i - - expect "<starship>" { - send "exit\n" - } timeout { - send_user "\n${shell} failed to display Starship\n" - exit 1 - } - - expect eof - '') - [ "bash" "fish" "zsh" ]; - }; - - testScript = '' - start_all() - machine.wait_for_unit("default.target") - - machine.succeed("expect-bash") - machine.succeed("expect-fish") - machine.succeed("expect-zsh") - ''; -}) + testScript = '' + start_all() + machine.wait_for_unit("default.target") + + machine.succeed("expect-bash") + machine.succeed("expect-fish") + machine.succeed("expect-zsh") + ''; + } +) diff --git a/nixos/tests/stratis/default.nix b/nixos/tests/stratis/default.nix index 42daadd5fcaac0..3a3452e63f09b1 100644 --- a/nixos/tests/stratis/default.nix +++ b/nixos/tests/stratis/default.nix @@ -1,5 +1,6 @@ -{ system ? builtins.currentSystem -, pkgs ? import ../../.. { inherit system; } +{ + system ? builtins.currentSystem, + pkgs ? import ../../.. { inherit system; }, }: { diff --git a/nixos/tests/stratis/encryption.nix b/nixos/tests/stratis/encryption.nix index 81b5f92b4ac4a8..719d8dd2584129 100644 --- a/nixos/tests/stratis/encryption.nix +++ b/nixos/tests/stratis/encryption.nix @@ -1,4 +1,5 @@ -import ../make-test-python.nix ({ pkgs, ... }: +import ../make-test-python.nix ( + { pkgs, ... }: { name = "stratis"; @@ -6,10 +7,12 @@ import ../make-test-python.nix ({ pkgs, ... }: maintainers = [ nickcao ]; }; - nodes.machine = { pkgs, ... }: { - services.stratis.enable = true; - virtualisation.emptyDiskImages = [ 2048 ]; - }; + nodes.machine = + { pkgs, ... }: + { + services.stratis.enable = true; + virtualisation.emptyDiskImages = [ 2048 ]; + }; testScript = let @@ -29,4 +32,5 @@ import ../make-test-python.nix ({ pkgs, ... }: machine.succeed("stratis pool stop --name testpool") machine.succeed("stratis pool start --name testpool --unlock-method keyring") ''; - }) + } +) diff --git a/nixos/tests/stratis/simple.nix b/nixos/tests/stratis/simple.nix index 543789f59c0525..7cd28f8aee6182 100644 --- a/nixos/tests/stratis/simple.nix +++ b/nixos/tests/stratis/simple.nix @@ -1,4 +1,5 @@ -import ../make-test-python.nix ({ pkgs, ... }: +import ../make-test-python.nix ( + { pkgs, ... }: { name = "stratis"; @@ -6,10 +7,17 @@ import ../make-test-python.nix ({ pkgs, ... }: maintainers = [ nickcao ]; }; - nodes.machine = { pkgs, ... }: { - services.stratis.enable = true; - virtualisation.emptyDiskImages = [ 2048 1024 1024 1024 ]; - }; + nodes.machine = + { pkgs, ... }: + { + services.stratis.enable = true; + virtualisation.emptyDiskImages = [ + 2048 + 1024 + 1024 + 1024 + ]; + }; testScript = '' machine.wait_for_unit("stratisd") @@ -36,4 +44,5 @@ import ../make-test-python.nix ({ pkgs, ... }: assert "test2" in machine.succeed("cat /mnt/testfs1/test1") assert "test1" in machine.succeed("cat /mnt/testfs2/test1") ''; - }) + } +) diff --git a/nixos/tests/strongswan-swanctl.nix b/nixos/tests/strongswan-swanctl.nix index 0cf181ee62a56c..a36757bf9eaa8b 100644 --- a/nixos/tests/strongswan-swanctl.nix +++ b/nixos/tests/strongswan-swanctl.nix @@ -16,133 +16,150 @@ # See the NixOS manual for how to run this test: # https://nixos.org/nixos/manual/index.html#sec-running-nixos-tests-interactively -import ./make-test-python.nix ({ pkgs, ...} : +import ./make-test-python.nix ( + { pkgs, ... }: -let - allowESP = "iptables --insert INPUT --protocol ESP --jump ACCEPT"; + let + allowESP = "iptables --insert INPUT --protocol ESP --jump ACCEPT"; - # Shared VPN settings: - vlan0 = "192.168.0.0/24"; - carolIp = "192.168.1.2"; - moonIp = "192.168.1.3"; - version = 2; - secret = "0sFpZAZqEN6Ti9sqt4ZP5EWcqx"; - esp_proposals = [ "aes128gcm128-x25519" ]; - proposals = [ "aes128-sha256-x25519" ]; -in { - name = "strongswan-swanctl"; - meta.maintainers = with pkgs.lib.maintainers; [ basvandijk ]; - nodes = { + # Shared VPN settings: + vlan0 = "192.168.0.0/24"; + carolIp = "192.168.1.2"; + moonIp = "192.168.1.3"; + version = 2; + secret = "0sFpZAZqEN6Ti9sqt4ZP5EWcqx"; + esp_proposals = [ "aes128gcm128-x25519" ]; + proposals = [ "aes128-sha256-x25519" ]; + in + { + name = "strongswan-swanctl"; + meta.maintainers = with pkgs.lib.maintainers; [ basvandijk ]; + nodes = { - alice = { ... } : { - virtualisation.vlans = [ 0 ]; - networking = { - dhcpcd.enable = false; - defaultGateway = "192.168.0.3"; - }; - }; - - moon = { config, ...} : - let strongswan = config.services.strongswan-swanctl.package; - in { - virtualisation.vlans = [ 0 1 ]; - networking = { - dhcpcd.enable = false; - firewall = { - allowedUDPPorts = [ 4500 500 ]; - extraCommands = allowESP; - }; - nat = { - enable = true; - internalIPs = [ vlan0 ]; - internalInterfaces = [ "eth1" ]; - externalIP = moonIp; - externalInterface = "eth2"; + alice = + { ... }: + { + virtualisation.vlans = [ 0 ]; + networking = { + dhcpcd.enable = false; + defaultGateway = "192.168.0.3"; }; }; - environment.systemPackages = [ strongswan ]; - services.strongswan-swanctl = { - enable = true; - swanctl = { - connections = { - rw = { - local_addrs = [ moonIp ]; - local.main = { - auth = "psk"; - }; - remote.main = { - auth = "psk"; - }; - children = { - net = { - local_ts = [ vlan0 ]; - updown = "${strongswan}/libexec/ipsec/_updown iptables"; - inherit esp_proposals; + + moon = + { config, ... }: + let + strongswan = config.services.strongswan-swanctl.package; + in + { + virtualisation.vlans = [ + 0 + 1 + ]; + networking = { + dhcpcd.enable = false; + firewall = { + allowedUDPPorts = [ + 4500 + 500 + ]; + extraCommands = allowESP; + }; + nat = { + enable = true; + internalIPs = [ vlan0 ]; + internalInterfaces = [ "eth1" ]; + externalIP = moonIp; + externalInterface = "eth2"; + }; + }; + environment.systemPackages = [ strongswan ]; + services.strongswan-swanctl = { + enable = true; + swanctl = { + connections = { + rw = { + local_addrs = [ moonIp ]; + local.main = { + auth = "psk"; + }; + remote.main = { + auth = "psk"; + }; + children = { + net = { + local_ts = [ vlan0 ]; + updown = "${strongswan}/libexec/ipsec/_updown iptables"; + inherit esp_proposals; + }; }; + inherit version; + inherit proposals; }; - inherit version; - inherit proposals; }; - }; - secrets = { - ike.carol = { - id.main = carolIp; - inherit secret; + secrets = { + ike.carol = { + id.main = carolIp; + inherit secret; + }; }; }; }; }; - }; - carol = { config, ...} : - let strongswan = config.services.strongswan-swanctl.package; - in { - virtualisation.vlans = [ 1 ]; - networking = { - dhcpcd.enable = false; - firewall.extraCommands = allowESP; - }; - environment.systemPackages = [ strongswan ]; - services.strongswan-swanctl = { - enable = true; - swanctl = { - connections = { - home = { - local_addrs = [ carolIp ]; - remote_addrs = [ moonIp ]; - local.main = { - auth = "psk"; - id = carolIp; - }; - remote.main = { - auth = "psk"; - id = moonIp; - }; - children = { - home = { - remote_ts = [ vlan0 ]; - start_action = "trap"; - updown = "${strongswan}/libexec/ipsec/_updown iptables"; - inherit esp_proposals; + carol = + { config, ... }: + let + strongswan = config.services.strongswan-swanctl.package; + in + { + virtualisation.vlans = [ 1 ]; + networking = { + dhcpcd.enable = false; + firewall.extraCommands = allowESP; + }; + environment.systemPackages = [ strongswan ]; + services.strongswan-swanctl = { + enable = true; + swanctl = { + connections = { + home = { + local_addrs = [ carolIp ]; + remote_addrs = [ moonIp ]; + local.main = { + auth = "psk"; + id = carolIp; }; + remote.main = { + auth = "psk"; + id = moonIp; + }; + children = { + home = { + remote_ts = [ vlan0 ]; + start_action = "trap"; + updown = "${strongswan}/libexec/ipsec/_updown iptables"; + inherit esp_proposals; + }; + }; + inherit version; + inherit proposals; }; - inherit version; - inherit proposals; }; - }; - secrets = { - ike.moon = { - id.main = moonIp; - inherit secret; + secrets = { + ike.moon = { + id.main = moonIp; + inherit secret; + }; }; }; }; }; - }; - }; - testScript = '' - start_all() - carol.wait_until_succeeds("ping -c 1 alice") - ''; -}) + }; + testScript = '' + start_all() + carol.wait_until_succeeds("ping -c 1 alice") + ''; + } +) diff --git a/nixos/tests/stub-ld.nix b/nixos/tests/stub-ld.nix index f34e082cfd2289..c6d045f60c0573 100644 --- a/nixos/tests/stub-ld.nix +++ b/nixos/tests/stub-ld.nix @@ -1,73 +1,88 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "stub-ld"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "stub-ld"; - nodes.machine = { lib, ... }: - { - environment.stub-ld.enable = true; + nodes.machine = + { lib, ... }: + { + environment.stub-ld.enable = true; - specialisation.nostub = { - inheritParentConfig = true; + specialisation.nostub = { + inheritParentConfig = true; - configuration = { ... }: { - environment.stub-ld.enable = lib.mkForce false; + configuration = + { ... }: + { + environment.stub-ld.enable = lib.mkForce false; + }; }; }; - }; - testScript = let - libDir = pkgs.stdenv.hostPlatform.libDir; - ldsoBasename = lib.last (lib.splitString "/" pkgs.stdenv.cc.bintools.dynamicLinker); + testScript = + let + libDir = pkgs.stdenv.hostPlatform.libDir; + ldsoBasename = lib.last (lib.splitString "/" pkgs.stdenv.cc.bintools.dynamicLinker); - check32 = pkgs.stdenv.hostPlatform.isx86_64; - pkgs32 = pkgs.pkgsi686Linux; + check32 = pkgs.stdenv.hostPlatform.isx86_64; + pkgs32 = pkgs.pkgsi686Linux; - libDir32 = pkgs32.stdenv.hostPlatform.libDir; - ldsoBasename32 = lib.last (lib.splitString "/" pkgs32.stdenv.cc.bintools.dynamicLinker); + libDir32 = pkgs32.stdenv.hostPlatform.libDir; + ldsoBasename32 = lib.last (lib.splitString "/" pkgs32.stdenv.cc.bintools.dynamicLinker); - test-exec = builtins.mapAttrs (n: v: pkgs.runCommand "test-exec-${n}" { src = pkgs.fetchurl v; } "mkdir -p $out;cd $out;tar -xzf $src") { - x86_64-linux.url = "https://github.com/rustic-rs/rustic/releases/download/v0.6.1/rustic-v0.6.1-x86_64-unknown-linux-gnu.tar.gz"; - x86_64-linux.hash = "sha256-3zySzx8MKFprMOi++yr2ZGASE0aRfXHQuG3SN+kWUCI="; - i686-linux.url = "https://github.com/rustic-rs/rustic/releases/download/v0.6.1/rustic-v0.6.1-i686-unknown-linux-gnu.tar.gz"; - i686-linux.hash = "sha256-fWNiATFeg0B2pfB5zndlnzGn7Ztl8diVS1rFLEDnSLU="; - aarch64-linux.url = "https://github.com/rustic-rs/rustic/releases/download/v0.6.1/rustic-v0.6.1-aarch64-unknown-linux-gnu.tar.gz"; - aarch64-linux.hash = "sha256-hnldbd2cctQIAhIKoEZLIWY8H3jiFBClkNy2UlyyvAs="; - }; - exec-name = "rustic"; + test-exec = + builtins.mapAttrs + ( + n: v: + pkgs.runCommand "test-exec-${n}" { src = pkgs.fetchurl v; } "mkdir -p $out;cd $out;tar -xzf $src" + ) + { + x86_64-linux.url = "https://github.com/rustic-rs/rustic/releases/download/v0.6.1/rustic-v0.6.1-x86_64-unknown-linux-gnu.tar.gz"; + x86_64-linux.hash = "sha256-3zySzx8MKFprMOi++yr2ZGASE0aRfXHQuG3SN+kWUCI="; + i686-linux.url = "https://github.com/rustic-rs/rustic/releases/download/v0.6.1/rustic-v0.6.1-i686-unknown-linux-gnu.tar.gz"; + i686-linux.hash = "sha256-fWNiATFeg0B2pfB5zndlnzGn7Ztl8diVS1rFLEDnSLU="; + aarch64-linux.url = "https://github.com/rustic-rs/rustic/releases/download/v0.6.1/rustic-v0.6.1-aarch64-unknown-linux-gnu.tar.gz"; + aarch64-linux.hash = "sha256-hnldbd2cctQIAhIKoEZLIWY8H3jiFBClkNy2UlyyvAs="; + }; + exec-name = "rustic"; - if32 = pythonStatement: if check32 then pythonStatement else "pass"; - in - '' - machine.start() - machine.wait_for_unit("multi-user.target") + if32 = pythonStatement: if check32 then pythonStatement else "pass"; + in + '' + machine.start() + machine.wait_for_unit("multi-user.target") - with subtest("Check for stub (enabled, initial)"): - machine.succeed('test -L /${libDir}/${ldsoBasename}') - ${if32 "machine.succeed('test -L /${libDir32}/${ldsoBasename32}')"} + with subtest("Check for stub (enabled, initial)"): + machine.succeed('test -L /${libDir}/${ldsoBasename}') + ${if32 "machine.succeed('test -L /${libDir32}/${ldsoBasename32}')"} - with subtest("Try FHS executable"): - machine.copy_from_host('${test-exec.${pkgs.stdenv.hostPlatform.system}}','test-exec') - machine.succeed('if test-exec/${exec-name} 2>outfile; then false; else [ $? -eq 127 ];fi') - machine.succeed('grep -qi nixos outfile') - ${if32 "machine.copy_from_host('${test-exec.${pkgs32.stdenv.hostPlatform.system}}','test-exec32')"} - ${if32 "machine.succeed('if test-exec32/${exec-name} 2>outfile32; then false; else [ $? -eq 127 ];fi')"} - ${if32 "machine.succeed('grep -qi nixos outfile32')"} + with subtest("Try FHS executable"): + machine.copy_from_host('${test-exec.${pkgs.stdenv.hostPlatform.system}}','test-exec') + machine.succeed('if test-exec/${exec-name} 2>outfile; then false; else [ $? -eq 127 ];fi') + machine.succeed('grep -qi nixos outfile') + ${if32 "machine.copy_from_host('${ + test-exec.${pkgs32.stdenv.hostPlatform.system} + }','test-exec32')"} + ${if32 "machine.succeed('if test-exec32/${exec-name} 2>outfile32; then false; else [ $? -eq 127 ];fi')"} + ${if32 "machine.succeed('grep -qi nixos outfile32')"} - with subtest("Disable stub"): - machine.succeed("/run/booted-system/specialisation/nostub/bin/switch-to-configuration test") + with subtest("Disable stub"): + machine.succeed("/run/booted-system/specialisation/nostub/bin/switch-to-configuration test") - with subtest("Check for stub (disabled)"): - machine.fail('test -e /${libDir}/${ldsoBasename}') - ${if32 "machine.fail('test -e /${libDir32}/${ldsoBasename32}')"} + with subtest("Check for stub (disabled)"): + machine.fail('test -e /${libDir}/${ldsoBasename}') + ${if32 "machine.fail('test -e /${libDir32}/${ldsoBasename32}')"} - with subtest("Create file in stub location (to be overwritten)"): - machine.succeed('mkdir -p /${libDir};touch /${libDir}/${ldsoBasename}') - ${if32 "machine.succeed('mkdir -p /${libDir32};touch /${libDir32}/${ldsoBasename32}')"} + with subtest("Create file in stub location (to be overwritten)"): + machine.succeed('mkdir -p /${libDir};touch /${libDir}/${ldsoBasename}') + ${if32 "machine.succeed('mkdir -p /${libDir32};touch /${libDir32}/${ldsoBasename32}')"} - with subtest("Re-enable stub"): - machine.succeed("/run/booted-system/bin/switch-to-configuration test") + with subtest("Re-enable stub"): + machine.succeed("/run/booted-system/bin/switch-to-configuration test") - with subtest("Check for stub (enabled, final)"): - machine.succeed('test -L /${libDir}/${ldsoBasename}') - ${if32 "machine.succeed('test -L /${libDir32}/${ldsoBasename32}')"} - ''; -}) + with subtest("Check for stub (enabled, final)"): + machine.succeed('test -L /${libDir}/${ldsoBasename}') + ${if32 "machine.succeed('test -L /${libDir32}/${ldsoBasename32}')"} + ''; + } +) diff --git a/nixos/tests/stunnel.nix b/nixos/tests/stunnel.nix index f8cfa0414761d6..0d817ccf7fb5af 100644 --- a/nixos/tests/stunnel.nix +++ b/nixos/tests/stunnel.nix @@ -1,5 +1,8 @@ -{ system ? builtins.currentSystem, config ? { } -, pkgs ? import ../.. { inherit system config; } }: +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, +}: with import ../lib/testing-python.nix { inherit system pkgs; }; with pkgs.lib; @@ -16,35 +19,42 @@ let group = "stunnel"; }; }; - makeCert = { config, pkgs, ... }: { - systemd.services.create-test-cert = { - wantedBy = [ "sysinit.target" ]; - before = [ "sysinit.target" "shutdown.target" ]; - conflicts = [ "shutdown.target" ]; - unitConfig.DefaultDependencies = false; - serviceConfig.Type = "oneshot"; - script = '' - ${pkgs.openssl}/bin/openssl req -batch -x509 -newkey rsa -nodes -out /test-cert.pem -keyout /test-key.pem -subj /CN=${config.networking.hostName} - ( umask 077; cat /test-key.pem /test-cert.pem > /test-key-and-cert.pem ) - chown stunnel /test-key.pem /test-key-and-cert.pem - ''; - }; - }; - serverCommon = { pkgs, ... }: { - networking.firewall.allowedTCPPorts = [ 443 ]; - services.stunnel.servers.https = { - accept = "443"; - connect = 80; - cert = "/test-key-and-cert.pem"; + makeCert = + { config, pkgs, ... }: + { + systemd.services.create-test-cert = { + wantedBy = [ "sysinit.target" ]; + before = [ + "sysinit.target" + "shutdown.target" + ]; + conflicts = [ "shutdown.target" ]; + unitConfig.DefaultDependencies = false; + serviceConfig.Type = "oneshot"; + script = '' + ${pkgs.openssl}/bin/openssl req -batch -x509 -newkey rsa -nodes -out /test-cert.pem -keyout /test-key.pem -subj /CN=${config.networking.hostName} + ( umask 077; cat /test-key.pem /test-cert.pem > /test-key-and-cert.pem ) + chown stunnel /test-key.pem /test-key-and-cert.pem + ''; + }; }; - systemd.services.simple-webserver = { - wantedBy = [ "multi-user.target" ]; - script = '' - cd /etc/webroot - ${pkgs.python3}/bin/python -m http.server 80 - ''; + serverCommon = + { pkgs, ... }: + { + networking.firewall.allowedTCPPorts = [ 443 ]; + services.stunnel.servers.https = { + accept = "443"; + connect = 80; + cert = "/test-key-and-cert.pem"; + }; + systemd.services.simple-webserver = { + wantedBy = [ "multi-user.target" ]; + script = '' + cd /etc/webroot + ${pkgs.python3}/bin/python -m http.server 80 + ''; + }; }; - }; copyCert = src: dest: filename: '' from shlex import quote ${src}.wait_for_file("/test-key-and-cert.pem") @@ -52,14 +62,19 @@ let ${dest}.succeed("echo %s > ${filename}" % quote(server_cert)) ''; -in { +in +{ basicServer = makeTest { name = "basicServer"; nodes = { client = { }; server = { - imports = [ makeCert serverCommon stunnelCommon ]; + imports = [ + makeCert + serverCommon + stunnelCommon + ]; environment.etc."webroot/index.html".text = "well met"; }; }; @@ -104,7 +119,11 @@ in { }; }; server = { - imports = [ makeCert serverCommon stunnelCommon ]; + imports = [ + makeCert + serverCommon + stunnelCommon + ]; environment.etc."webroot/index.html".text = "hello there"; }; }; @@ -136,7 +155,10 @@ in { nodes = rec { client = { - imports = [ makeCert stunnelCommon ]; + imports = [ + makeCert + stunnelCommon + ]; services.stunnel.clients.authenticated-https = { accept = "80"; connect = "server:443"; @@ -148,7 +170,11 @@ in { }; wrongclient = client; server = { - imports = [ makeCert serverCommon stunnelCommon ]; + imports = [ + makeCert + serverCommon + stunnelCommon + ]; services.stunnel.servers.https = { CAFile = "/authorized-client-certs.crt"; verifyPeer = true; diff --git a/nixos/tests/sudo-rs.nix b/nixos/tests/sudo-rs.nix index 753e00686e956c..b57eca1990550a 100644 --- a/nixos/tests/sudo-rs.nix +++ b/nixos/tests/sudo-rs.nix @@ -4,7 +4,9 @@ let inherit (pkgs.lib) mkIf optionalString; password = "helloworld"; in - import ./make-test-python.nix ({ lib, pkgs, ...} : { +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { name = "sudo-rs"; meta.maintainers = pkgs.sudo-rs.meta.maintainers; @@ -12,14 +14,38 @@ in { lib, ... }: { environment.systemPackages = [ pkgs.faketty ]; - users.groups = { foobar = {}; barfoo = {}; baz = { gid = 1337; }; }; + users.groups = { + foobar = { }; + barfoo = { }; + baz = { + gid = 1337; + }; + }; users.users = { - test0 = { isNormalUser = true; extraGroups = [ "wheel" ]; }; - test1 = { isNormalUser = true; password = password; }; - test2 = { isNormalUser = true; extraGroups = [ "foobar" ]; password = password; }; - test3 = { isNormalUser = true; extraGroups = [ "barfoo" ]; }; - test4 = { isNormalUser = true; extraGroups = [ "baz" ]; }; - test5 = { isNormalUser = true; }; + test0 = { + isNormalUser = true; + extraGroups = [ "wheel" ]; + }; + test1 = { + isNormalUser = true; + password = password; + }; + test2 = { + isNormalUser = true; + extraGroups = [ "foobar" ]; + password = password; + }; + test3 = { + isNormalUser = true; + extraGroups = [ "barfoo" ]; + }; + test4 = { + isNormalUser = true; + extraGroups = [ "baz" ]; + }; + test5 = { + isNormalUser = true; + }; }; security.sudo-rs = { @@ -31,65 +57,113 @@ in # errors being detected by the visudo checks. # These should not create any entries - { users = [ "notest1" ]; commands = [ ]; } - { commands = [ { command = "ALL"; options = [ ]; } ]; } + { + users = [ "notest1" ]; + commands = [ ]; + } + { + commands = [ + { + command = "ALL"; + options = [ ]; + } + ]; + } # Test defining commands with the options syntax, though not setting any options - { users = [ "notest2" ]; commands = [ { command = "ALL"; options = [ ]; } ]; } - + { + users = [ "notest2" ]; + commands = [ + { + command = "ALL"; + options = [ ]; + } + ]; + } # CONFIGURATION FOR TEST CASES - { users = [ "test1" ]; groups = [ "foobar" ]; commands = [ "ALL" ]; } - { groups = [ "barfoo" 1337 ]; commands = [ { command = "ALL"; options = [ "NOPASSWD" ]; } ]; } - { users = [ "test5" ]; commands = [ { command = "ALL"; options = [ "NOPASSWD" ]; } ]; runAs = "test1:barfoo"; } + { + users = [ "test1" ]; + groups = [ "foobar" ]; + commands = [ "ALL" ]; + } + { + groups = [ + "barfoo" + 1337 + ]; + commands = [ + { + command = "ALL"; + options = [ "NOPASSWD" ]; + } + ]; + } + { + users = [ "test5" ]; + commands = [ + { + command = "ALL"; + options = [ "NOPASSWD" ]; + } + ]; + runAs = "test1:barfoo"; + } ]; }; }; - nodes.strict = { ... }: { - environment.systemPackages = [ pkgs.faketty ]; - users.users = { - admin = { isNormalUser = true; extraGroups = [ "wheel" ]; }; - noadmin = { isNormalUser = true; }; - }; + nodes.strict = + { ... }: + { + environment.systemPackages = [ pkgs.faketty ]; + users.users = { + admin = { + isNormalUser = true; + extraGroups = [ "wheel" ]; + }; + noadmin = { + isNormalUser = true; + }; + }; - security.sudo-rs = { - enable = true; - wheelNeedsPassword = false; - execWheelOnly = true; + security.sudo-rs = { + enable = true; + wheelNeedsPassword = false; + execWheelOnly = true; + }; }; - }; - testScript = - '' - with subtest("users in wheel group should have passwordless sudo"): - machine.succeed('faketty -- su - test0 -c "sudo -u root true"') + testScript = '' + with subtest("users in wheel group should have passwordless sudo"): + machine.succeed('faketty -- su - test0 -c "sudo -u root true"') - with subtest("test1 user should have sudo with password"): - machine.succeed('faketty -- su - test1 -c "echo ${password} | sudo -S -u root true"') + with subtest("test1 user should have sudo with password"): + machine.succeed('faketty -- su - test1 -c "echo ${password} | sudo -S -u root true"') - with subtest("test1 user should not be able to use sudo without password"): - machine.fail('faketty -- su - test1 -c "sudo -n -u root true"') + with subtest("test1 user should not be able to use sudo without password"): + machine.fail('faketty -- su - test1 -c "sudo -n -u root true"') - with subtest("users in group 'foobar' should be able to use sudo with password"): - machine.succeed('faketty -- su - test2 -c "echo ${password} | sudo -S -u root true"') + with subtest("users in group 'foobar' should be able to use sudo with password"): + machine.succeed('faketty -- su - test2 -c "echo ${password} | sudo -S -u root true"') - with subtest("users in group 'barfoo' should be able to use sudo without password"): - machine.succeed("sudo -u test3 sudo -n -u root true") + with subtest("users in group 'barfoo' should be able to use sudo without password"): + machine.succeed("sudo -u test3 sudo -n -u root true") - with subtest("users in group 'baz' (GID 1337)"): - machine.succeed("sudo -u test4 sudo -n -u root echo true") + with subtest("users in group 'baz' (GID 1337)"): + machine.succeed("sudo -u test4 sudo -n -u root echo true") - with subtest("test5 user should be able to run commands under test1"): - machine.succeed("sudo -u test5 sudo -n -u test1 true") + with subtest("test5 user should be able to run commands under test1"): + machine.succeed("sudo -u test5 sudo -n -u test1 true") - with subtest("test5 user should not be able to run commands under root"): - machine.fail("sudo -u test5 sudo -n -u root true 2>/dev/null") + with subtest("test5 user should not be able to run commands under root"): + machine.fail("sudo -u test5 sudo -n -u root true 2>/dev/null") - with subtest("users in wheel should be able to run sudo despite execWheelOnly"): - strict.succeed('faketty -- su - admin -c "sudo -u root true"') + with subtest("users in wheel should be able to run sudo despite execWheelOnly"): + strict.succeed('faketty -- su - admin -c "sudo -u root true"') - with subtest("non-wheel users should be unable to run sudo thanks to execWheelOnly"): - strict.fail('faketty -- su - noadmin -c "sudo --help"') - ''; - }) + with subtest("non-wheel users should be unable to run sudo thanks to execWheelOnly"): + strict.fail('faketty -- su - noadmin -c "sudo --help"') + ''; + } +) diff --git a/nixos/tests/sudo.nix b/nixos/tests/sudo.nix index 1fe478f0bff14b..77accf8e82fb98 100644 --- a/nixos/tests/sudo.nix +++ b/nixos/tests/sudo.nix @@ -3,21 +3,47 @@ let password = "helloworld"; in - import ./make-test-python.nix ({ lib, pkgs, ...} : { +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { name = "sudo"; meta.maintainers = pkgs.sudo.meta.maintainers; nodes.machine = { lib, ... }: { - users.groups = { foobar = {}; barfoo = {}; baz = { gid = 1337; }; }; + users.groups = { + foobar = { }; + barfoo = { }; + baz = { + gid = 1337; + }; + }; users.users = { - test0 = { isNormalUser = true; extraGroups = [ "wheel" ]; }; - test1 = { isNormalUser = true; password = password; }; - test2 = { isNormalUser = true; extraGroups = [ "foobar" ]; password = password; }; - test3 = { isNormalUser = true; extraGroups = [ "barfoo" ]; }; - test4 = { isNormalUser = true; extraGroups = [ "baz" ]; }; - test5 = { isNormalUser = true; }; + test0 = { + isNormalUser = true; + extraGroups = [ "wheel" ]; + }; + test1 = { + isNormalUser = true; + password = password; + }; + test2 = { + isNormalUser = true; + extraGroups = [ "foobar" ]; + password = password; + }; + test3 = { + isNormalUser = true; + extraGroups = [ "barfoo" ]; + }; + test4 = { + isNormalUser = true; + extraGroups = [ "baz" ]; + }; + test5 = { + isNormalUser = true; + }; }; security.sudo = { @@ -34,70 +60,124 @@ in # errors being detected by the visudo checks. # These should not create any entries - { users = [ "notest1" ]; commands = [ ]; } - { commands = [ { command = "ALL"; options = [ ]; } ]; } + { + users = [ "notest1" ]; + commands = [ ]; + } + { + commands = [ + { + command = "ALL"; + options = [ ]; + } + ]; + } # Test defining commands with the options syntax, though not setting any options - { users = [ "notest2" ]; commands = [ { command = "ALL"; options = [ ]; } ]; } - + { + users = [ "notest2" ]; + commands = [ + { + command = "ALL"; + options = [ ]; + } + ]; + } # CONFIGURATION FOR TEST CASES - { users = [ "test1" ]; groups = [ "foobar" ]; commands = [ "ALL" ]; } - { groups = [ "barfoo" 1337 ]; commands = [ { command = "ALL"; options = [ "NOPASSWD" "NOSETENV" ]; } ]; } - { users = [ "test5" ]; commands = [ { command = "ALL"; options = [ "NOPASSWD" "SETENV" ]; } ]; runAs = "test1:barfoo"; } + { + users = [ "test1" ]; + groups = [ "foobar" ]; + commands = [ "ALL" ]; + } + { + groups = [ + "barfoo" + 1337 + ]; + commands = [ + { + command = "ALL"; + options = [ + "NOPASSWD" + "NOSETENV" + ]; + } + ]; + } + { + users = [ "test5" ]; + commands = [ + { + command = "ALL"; + options = [ + "NOPASSWD" + "SETENV" + ]; + } + ]; + runAs = "test1:barfoo"; + } ]; }; }; - nodes.strict = { ... }: { - users.users = { - admin = { isNormalUser = true; extraGroups = [ "wheel" ]; }; - noadmin = { isNormalUser = true; }; - }; + nodes.strict = + { ... }: + { + users.users = { + admin = { + isNormalUser = true; + extraGroups = [ "wheel" ]; + }; + noadmin = { + isNormalUser = true; + }; + }; - security.sudo = { - enable = true; - wheelNeedsPassword = false; - execWheelOnly = true; + security.sudo = { + enable = true; + wheelNeedsPassword = false; + execWheelOnly = true; + }; }; - }; - testScript = - '' - with subtest("users in wheel group should have passwordless sudo"): - machine.succeed('su - test0 -c "sudo -u root true"') + testScript = '' + with subtest("users in wheel group should have passwordless sudo"): + machine.succeed('su - test0 -c "sudo -u root true"') - with subtest("test1 user should have sudo with password"): - machine.succeed('su - test1 -c "echo ${password} | sudo -S -u root true"') + with subtest("test1 user should have sudo with password"): + machine.succeed('su - test1 -c "echo ${password} | sudo -S -u root true"') - with subtest("test1 user should not be able to use sudo without password"): - machine.fail('su - test1 -c "sudo -n -u root true"') + with subtest("test1 user should not be able to use sudo without password"): + machine.fail('su - test1 -c "sudo -n -u root true"') - with subtest("users in group 'foobar' should be able to use sudo with password"): - machine.succeed('su - test2 -c "echo ${password} | sudo -S -u root true"') + with subtest("users in group 'foobar' should be able to use sudo with password"): + machine.succeed('su - test2 -c "echo ${password} | sudo -S -u root true"') - with subtest("users in group 'barfoo' should be able to use sudo without password"): - machine.succeed("sudo -u test3 sudo -n -u root true") + with subtest("users in group 'barfoo' should be able to use sudo without password"): + machine.succeed("sudo -u test3 sudo -n -u root true") - with subtest("users in group 'baz' (GID 1337)"): - machine.succeed("sudo -u test4 sudo -n -u root echo true") + with subtest("users in group 'baz' (GID 1337)"): + machine.succeed("sudo -u test4 sudo -n -u root echo true") - with subtest("test5 user should be able to run commands under test1"): - machine.succeed("sudo -u test5 sudo -n -u test1 true") + with subtest("test5 user should be able to run commands under test1"): + machine.succeed("sudo -u test5 sudo -n -u test1 true") - with subtest("test5 user should not be able to run commands under root"): - machine.fail("sudo -u test5 sudo -n -u root true") + with subtest("test5 user should not be able to run commands under root"): + machine.fail("sudo -u test5 sudo -n -u root true") - with subtest("test5 user should be able to keep their environment"): - machine.succeed("sudo -u test5 sudo -n -E -u test1 true") + with subtest("test5 user should be able to keep their environment"): + machine.succeed("sudo -u test5 sudo -n -E -u test1 true") - with subtest("users in group 'barfoo' should not be able to keep their environment"): - machine.fail("sudo -u test3 sudo -n -E -u root true") + with subtest("users in group 'barfoo' should not be able to keep their environment"): + machine.fail("sudo -u test3 sudo -n -E -u root true") - with subtest("users in wheel should be able to run sudo despite execWheelOnly"): - strict.succeed('su - admin -c "sudo -u root true"') + with subtest("users in wheel should be able to run sudo despite execWheelOnly"): + strict.succeed('su - admin -c "sudo -u root true"') - with subtest("non-wheel users should be unable to run sudo thanks to execWheelOnly"): - strict.fail('su - noadmin -c "sudo --help"') - ''; - }) + with subtest("non-wheel users should be unable to run sudo thanks to execWheelOnly"): + strict.fail('su - noadmin -c "sudo --help"') + ''; + } +) diff --git a/nixos/tests/sunshine.nix b/nixos/tests/sunshine.nix index a1207bfa49f76d..96ba81d6206833 100644 --- a/nixos/tests/sunshine.nix +++ b/nixos/tests/sunshine.nix @@ -1,70 +1,77 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "sunshine"; - meta = { - # test is flaky on aarch64 - broken = pkgs.stdenv.hostPlatform.isAarch64; - maintainers = [ lib.maintainers.devusb ]; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "sunshine"; + meta = { + # test is flaky on aarch64 + broken = pkgs.stdenv.hostPlatform.isAarch64; + maintainers = [ lib.maintainers.devusb ]; + }; - nodes.sunshine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + nodes.sunshine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - services.sunshine = { - enable = true; - openFirewall = true; - settings = { - capture = "x11"; - encoder = "software"; - output_name = 0; - }; - }; + services.sunshine = { + enable = true; + openFirewall = true; + settings = { + capture = "x11"; + encoder = "software"; + output_name = 0; + }; + }; - environment.systemPackages = with pkgs; [ - gxmessage - ]; + environment.systemPackages = with pkgs; [ + gxmessage + ]; - }; + }; - nodes.moonlight = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + nodes.moonlight = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - environment.systemPackages = with pkgs; [ - moonlight-qt - ]; + environment.systemPackages = with pkgs; [ + moonlight-qt + ]; - }; + }; - enableOCR = true; + enableOCR = true; - testScript = '' - # start the tests, wait for sunshine to be up - start_all() - sunshine.wait_for_open_port(48010,"localhost") + testScript = '' + # start the tests, wait for sunshine to be up + start_all() + sunshine.wait_for_open_port(48010,"localhost") - # set the admin username/password, restart sunshine - sunshine.execute("sunshine --creds sunshine sunshine") - sunshine.systemctl("restart sunshine","root") - sunshine.wait_for_open_port(48010,"localhost") + # set the admin username/password, restart sunshine + sunshine.execute("sunshine --creds sunshine sunshine") + sunshine.systemctl("restart sunshine","root") + sunshine.wait_for_open_port(48010,"localhost") - # initiate pairing from moonlight - moonlight.execute("moonlight pair sunshine --pin 1234 >&2 & disown") - moonlight.wait_for_console_text("Executing request") + # initiate pairing from moonlight + moonlight.execute("moonlight pair sunshine --pin 1234 >&2 & disown") + moonlight.wait_for_console_text("Executing request") - # respond to pairing request from sunshine - sunshine.succeed("curl --insecure -u sunshine:sunshine -d '{\"pin\": \"1234\"}' https://localhost:47990/api/pin") + # respond to pairing request from sunshine + sunshine.succeed("curl --insecure -u sunshine:sunshine -d '{\"pin\": \"1234\"}' https://localhost:47990/api/pin") - # close moonlight once pairing complete - moonlight.send_key("kp_enter") + # close moonlight once pairing complete + moonlight.send_key("kp_enter") - # put words on the sunshine screen for moonlight to see - sunshine.execute("gxmessage 'hello world' -center -font 'sans 75' >&2 & disown") + # put words on the sunshine screen for moonlight to see + sunshine.execute("gxmessage 'hello world' -center -font 'sans 75' >&2 & disown") - # connect to sunshine from moonlight and look for the words - moonlight.execute("moonlight --video-decoder software stream sunshine 'Desktop' >&2 & disown") - moonlight.wait_for_text("hello world") - ''; -}) + # connect to sunshine from moonlight and look for the words + moonlight.execute("moonlight --video-decoder software stream sunshine 'Desktop' >&2 & disown") + moonlight.wait_for_text("hello world") + ''; + } +) diff --git a/nixos/tests/suwayomi-server.nix b/nixos/tests/suwayomi-server.nix index 36072028380b8a..7f7da9c3d831b3 100644 --- a/nixos/tests/suwayomi-server.nix +++ b/nixos/tests/suwayomi-server.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem -, pkgs -, lib ? pkgs.lib +{ + system ? builtins.currentSystem, + pkgs, + lib ? pkgs.lib, }: let inherit (import ../lib/testing-python.nix { inherit system pkgs; }) makeTest; @@ -8,12 +9,14 @@ let baseTestConfig = { meta.maintainers = with lib.maintainers; [ ratcornu ]; - nodes.machine = { pkgs, ... }: { - services.suwayomi-server = { - enable = true; - settings.server.port = 1234; + nodes.machine = + { pkgs, ... }: + { + services.suwayomi-server = { + enable = true; + settings.server.port = 1234; + }; }; - }; testScript = '' machine.wait_for_unit("suwayomi-server.service") machine.wait_for_open_port(1234) @@ -23,24 +26,30 @@ let in { - without-auth = makeTest (recursiveUpdate baseTestConfig { - name = "suwayomi-server-without-auth"; - }); + without-auth = makeTest ( + recursiveUpdate baseTestConfig { + name = "suwayomi-server-without-auth"; + } + ); - with-auth = makeTest (recursiveUpdate baseTestConfig { - name = "suwayomi-server-with-auth"; + with-auth = makeTest ( + recursiveUpdate baseTestConfig { + name = "suwayomi-server-with-auth"; - nodes.machine = { pkgs, ... }: { - services.suwayomi-server = { - enable = true; + nodes.machine = + { pkgs, ... }: + { + services.suwayomi-server = { + enable = true; - settings.server = { - port = 1234; - basicAuthEnabled = true; - basicAuthUsername = "alice"; - basicAuthPasswordFile = pkgs.writeText "snakeoil-pass.txt" "pass"; + settings.server = { + port = 1234; + basicAuthEnabled = true; + basicAuthUsername = "alice"; + basicAuthPasswordFile = pkgs.writeText "snakeoil-pass.txt" "pass"; + }; + }; }; - }; - }; - }); + } + ); } diff --git a/nixos/tests/swap-file-btrfs.nix b/nixos/tests/swap-file-btrfs.nix index 35b9fb4fa50ac7..eaea9ad00125ea 100644 --- a/nixos/tests/swap-file-btrfs.nix +++ b/nixos/tests/swap-file-btrfs.nix @@ -1,50 +1,52 @@ -import ./make-test-python.nix ({ lib, ... }: -{ - name = "swap-file-btrfs"; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "swap-file-btrfs"; - meta.maintainers = with lib.maintainers; [ oxalica ]; + meta.maintainers = with lib.maintainers; [ oxalica ]; - nodes.machine = - { pkgs, ... }: - { - virtualisation.useDefaultFilesystems = false; + nodes.machine = + { pkgs, ... }: + { + virtualisation.useDefaultFilesystems = false; - virtualisation.rootDevice = "/dev/vda"; + virtualisation.rootDevice = "/dev/vda"; - boot.initrd.postDeviceCommands = '' - ${pkgs.btrfs-progs}/bin/mkfs.btrfs --label root /dev/vda - ''; + boot.initrd.postDeviceCommands = '' + ${pkgs.btrfs-progs}/bin/mkfs.btrfs --label root /dev/vda + ''; - virtualisation.fileSystems = { - "/" = { - device = "/dev/disk/by-label/root"; - fsType = "btrfs"; + virtualisation.fileSystems = { + "/" = { + device = "/dev/disk/by-label/root"; + fsType = "btrfs"; + }; }; + + swapDevices = [ + { + device = "/var/swapfile"; + size = 1; # 1MiB. + } + ]; }; - swapDevices = [ - { - device = "/var/swapfile"; - size = 1; # 1MiB. - } - ]; - }; - - testScript = '' - machine.wait_for_unit('var-swapfile.swap') - # Ensure the swap file creation script ran to completion without failing when creating the swap file - machine.fail("systemctl is-failed --quiet mkswap-var-swapfile.service") - machine.succeed("stat --file-system --format=%T /var/swapfile | grep btrfs") - # First run. Auto creation. - machine.succeed("swapon --show | grep /var/swapfile") - - machine.shutdown() - machine.start() - - # Second run. Use it as-is. - machine.wait_for_unit('var-swapfile.swap') - # Ensure the swap file creation script ran to completion without failing when the swap file already exists - machine.fail("systemctl is-failed --quiet mkswap-var-swapfile.service") - machine.succeed("swapon --show | grep /var/swapfile") - ''; -}) + testScript = '' + machine.wait_for_unit('var-swapfile.swap') + # Ensure the swap file creation script ran to completion without failing when creating the swap file + machine.fail("systemctl is-failed --quiet mkswap-var-swapfile.service") + machine.succeed("stat --file-system --format=%T /var/swapfile | grep btrfs") + # First run. Auto creation. + machine.succeed("swapon --show | grep /var/swapfile") + + machine.shutdown() + machine.start() + + # Second run. Use it as-is. + machine.wait_for_unit('var-swapfile.swap') + # Ensure the swap file creation script ran to completion without failing when the swap file already exists + machine.fail("systemctl is-failed --quiet mkswap-var-swapfile.service") + machine.succeed("swapon --show | grep /var/swapfile") + ''; + } +) diff --git a/nixos/tests/swap-partition.nix b/nixos/tests/swap-partition.nix index ddcaeb95453e17..db04bbf559b56c 100644 --- a/nixos/tests/swap-partition.nix +++ b/nixos/tests/swap-partition.nix @@ -1,48 +1,55 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -{ - name = "swap-partition"; - - nodes.machine = - { config, pkgs, lib, ... }: - { - virtualisation.useDefaultFilesystems = false; - - virtualisation.rootDevice = "/dev/vda1"; - - boot.initrd.postDeviceCommands = '' - if ! test -b /dev/vda1; then - ${pkgs.parted}/bin/parted --script /dev/vda -- mklabel msdos - ${pkgs.parted}/bin/parted --script /dev/vda -- mkpart primary 1MiB -250MiB - ${pkgs.parted}/bin/parted --script /dev/vda -- mkpart primary -250MiB 100% - sync - fi - - FSTYPE=$(blkid -o value -s TYPE /dev/vda1 || true) - if test -z "$FSTYPE"; then - ${pkgs.e2fsprogs}/bin/mke2fs -t ext4 -L root /dev/vda1 - ${pkgs.util-linux}/bin/mkswap --label swap /dev/vda2 - fi - ''; - - virtualisation.fileSystems = { - "/" = { - device = "/dev/disk/by-label/root"; - fsType = "ext4"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "swap-partition"; + + nodes.machine = + { + config, + pkgs, + lib, + ... + }: + { + virtualisation.useDefaultFilesystems = false; + + virtualisation.rootDevice = "/dev/vda1"; + + boot.initrd.postDeviceCommands = '' + if ! test -b /dev/vda1; then + ${pkgs.parted}/bin/parted --script /dev/vda -- mklabel msdos + ${pkgs.parted}/bin/parted --script /dev/vda -- mkpart primary 1MiB -250MiB + ${pkgs.parted}/bin/parted --script /dev/vda -- mkpart primary -250MiB 100% + sync + fi + + FSTYPE=$(blkid -o value -s TYPE /dev/vda1 || true) + if test -z "$FSTYPE"; then + ${pkgs.e2fsprogs}/bin/mke2fs -t ext4 -L root /dev/vda1 + ${pkgs.util-linux}/bin/mkswap --label swap /dev/vda2 + fi + ''; + + virtualisation.fileSystems = { + "/" = { + device = "/dev/disk/by-label/root"; + fsType = "ext4"; + }; }; + + swapDevices = [ + { + device = "/dev/disk/by-label/swap"; + } + ]; }; - swapDevices = [ - { - device = "/dev/disk/by-label/swap"; - } - ]; - }; - - testScript = '' - machine.wait_for_unit("multi-user.target") - - with subtest("Swap is active"): - # Doesn't matter if the numbers reported by `free` are slightly off due to unit conversions. - machine.succeed("free -h | grep -E 'Swap:\s+2[45][0-9]Mi'") - ''; -}) + testScript = '' + machine.wait_for_unit("multi-user.target") + + with subtest("Swap is active"): + # Doesn't matter if the numbers reported by `free` are slightly off due to unit conversions. + machine.succeed("free -h | grep -E 'Swap:\s+2[45][0-9]Mi'") + ''; + } +) diff --git a/nixos/tests/swap-random-encryption.nix b/nixos/tests/swap-random-encryption.nix index 9e919db65dde8b..c48452412534e1 100644 --- a/nixos/tests/swap-random-encryption.nix +++ b/nixos/tests/swap-random-encryption.nix @@ -1,80 +1,87 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -{ - name = "swap-random-encryption"; - - nodes.machine = - { config, pkgs, lib, ... }: - { - environment.systemPackages = [ pkgs.cryptsetup ]; - - virtualisation.useDefaultFilesystems = false; - - virtualisation.rootDevice = "/dev/vda1"; - - boot.initrd.postDeviceCommands = '' - if ! test -b /dev/vda1; then - ${pkgs.parted}/bin/parted --script /dev/vda -- mklabel msdos - ${pkgs.parted}/bin/parted --script /dev/vda -- mkpart primary 1MiB -250MiB - ${pkgs.parted}/bin/parted --script /dev/vda -- mkpart primary -250MiB 100% - sync - fi - - FSTYPE=$(blkid -o value -s TYPE /dev/vda1 || true) - if test -z "$FSTYPE"; then - ${pkgs.e2fsprogs}/bin/mke2fs -t ext4 -L root /dev/vda1 - fi - ''; - - virtualisation.fileSystems = { - "/" = { - device = "/dev/disk/by-label/root"; - fsType = "ext4"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "swap-random-encryption"; + + nodes.machine = + { + config, + pkgs, + lib, + ... + }: + { + environment.systemPackages = [ pkgs.cryptsetup ]; + + virtualisation.useDefaultFilesystems = false; + + virtualisation.rootDevice = "/dev/vda1"; + + boot.initrd.postDeviceCommands = '' + if ! test -b /dev/vda1; then + ${pkgs.parted}/bin/parted --script /dev/vda -- mklabel msdos + ${pkgs.parted}/bin/parted --script /dev/vda -- mkpart primary 1MiB -250MiB + ${pkgs.parted}/bin/parted --script /dev/vda -- mkpart primary -250MiB 100% + sync + fi + + FSTYPE=$(blkid -o value -s TYPE /dev/vda1 || true) + if test -z "$FSTYPE"; then + ${pkgs.e2fsprogs}/bin/mke2fs -t ext4 -L root /dev/vda1 + fi + ''; + + virtualisation.fileSystems = { + "/" = { + device = "/dev/disk/by-label/root"; + fsType = "ext4"; + }; }; + + swapDevices = [ + { + device = "/dev/vda2"; + + randomEncryption = { + enable = true; + cipher = "aes-xts-plain64"; + keySize = 512; + sectorSize = 4096; + }; + } + ]; }; - swapDevices = [ - { - device = "/dev/vda2"; + testScript = '' + machine.wait_for_unit("multi-user.target") - randomEncryption = { - enable = true; - cipher = "aes-xts-plain64"; - keySize = 512; - sectorSize = 4096; - }; - } - ]; - }; - - testScript = '' - machine.wait_for_unit("multi-user.target") - - with subtest("Swap is active"): - # Doesn't matter if the numbers reported by `free` are slightly off due to unit conversions. - machine.succeed("free -h | grep -E 'Swap:\s+2[45][0-9]Mi'") - - with subtest("Swap device has 4k sector size"): - import json - result = json.loads(machine.succeed("lsblk -Jo PHY-SEC,LOG-SEC /dev/mapper/dev-vda2")) - block_devices = result["blockdevices"] - if len(block_devices) != 1: - raise Exception ("lsblk output did not report exactly one block device") - - swapDevice = block_devices[0]; - if not (swapDevice["phy-sec"] == 4096 and swapDevice["log-sec"] == 4096): - raise Exception ("swap device does not have the sector size specified in the configuration") - - with subtest("Swap encrypt has assigned cipher and keysize"): - import re - - results = machine.succeed("cryptsetup status dev-vda2").splitlines() - - cipher_pattern = re.compile(r"\s*cipher:\s+aes-xts-plain64\s*") - if not any(cipher_pattern.fullmatch(line) for line in results): - raise Exception ("swap device encryption does not use the cipher specified in the configuration") - - key_size_pattern = re.compile(r"\s*keysize:\s+512\s+bits\s*") - if not any(key_size_pattern.fullmatch(line) for line in results): - raise Exception ("swap device encryption does not use the key size specified in the configuration") - ''; -}) + with subtest("Swap is active"): + # Doesn't matter if the numbers reported by `free` are slightly off due to unit conversions. + machine.succeed("free -h | grep -E 'Swap:\s+2[45][0-9]Mi'") + + with subtest("Swap device has 4k sector size"): + import json + result = json.loads(machine.succeed("lsblk -Jo PHY-SEC,LOG-SEC /dev/mapper/dev-vda2")) + block_devices = result["blockdevices"] + if len(block_devices) != 1: + raise Exception ("lsblk output did not report exactly one block device") + + swapDevice = block_devices[0]; + if not (swapDevice["phy-sec"] == 4096 and swapDevice["log-sec"] == 4096): + raise Exception ("swap device does not have the sector size specified in the configuration") + + with subtest("Swap encrypt has assigned cipher and keysize"): + import re + + results = machine.succeed("cryptsetup status dev-vda2").splitlines() + + cipher_pattern = re.compile(r"\s*cipher:\s+aes-xts-plain64\s*") + if not any(cipher_pattern.fullmatch(line) for line in results): + raise Exception ("swap device encryption does not use the cipher specified in the configuration") + + key_size_pattern = re.compile(r"\s*keysize:\s+512\s+bits\s*") + if not any(key_size_pattern.fullmatch(line) for line in results): + raise Exception ("swap device encryption does not use the key size specified in the configuration") + ''; + } +) diff --git a/nixos/tests/sway.nix b/nixos/tests/sway.nix index 185c5b1b0aa90f..13fa5dacbd925c 100644 --- a/nixos/tests/sway.nix +++ b/nixos/tests/sway.nix @@ -1,193 +1,207 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "sway"; - meta = { - maintainers = with lib.maintainers; [ primeos synthetica ]; - }; - - # testScriptWithTypes:49: error: Cannot call function of unknown type - # (machine.succeed if succeed else machine.execute)( - # ^ - # Found 1 error in 1 file (checked 1 source file) - skipTypeCheck = true; - - nodes.machine = { config, ... }: { - # Automatically login on tty1 as a normal user: - imports = [ ./common/user-account.nix ]; - services.getty.autologinUser = "alice"; - - environment = { - # For glinfo and wayland-info: - systemPackages = with pkgs; [ mesa-demos wayland-utils alacritty ]; - # Use a fixed SWAYSOCK path (for swaymsg): - variables = { - "SWAYSOCK" = "/tmp/sway-ipc.sock"; - # TODO: Investigate if we can get hardware acceleration to work (via - # virtio-gpu and Virgil). We currently have to use the Pixman software - # renderer since the GLES2 renderer doesn't work inside the VM (even - # with WLR_RENDERER_ALLOW_SOFTWARE): - # "WLR_RENDERER_ALLOW_SOFTWARE" = "1"; - "WLR_RENDERER" = "pixman"; - }; - # For convenience: - shellAliases = { - test-x11 = "glinfo | tee /tmp/test-x11.out && touch /tmp/test-x11-exit-ok"; - test-wayland = "wayland-info | tee /tmp/test-wayland.out && touch /tmp/test-wayland-exit-ok"; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "sway"; + meta = { + maintainers = with lib.maintainers; [ + primeos + synthetica + ]; + }; - # To help with OCR: - etc."xdg/foot/foot.ini".text = lib.generators.toINI { } { - main = { - font = "inconsolata:size=14"; + # testScriptWithTypes:49: error: Cannot call function of unknown type + # (machine.succeed if succeed else machine.execute)( + # ^ + # Found 1 error in 1 file (checked 1 source file) + skipTypeCheck = true; + + nodes.machine = + { config, ... }: + { + # Automatically login on tty1 as a normal user: + imports = [ ./common/user-account.nix ]; + services.getty.autologinUser = "alice"; + + environment = { + # For glinfo and wayland-info: + systemPackages = with pkgs; [ + mesa-demos + wayland-utils + alacritty + ]; + # Use a fixed SWAYSOCK path (for swaymsg): + variables = { + "SWAYSOCK" = "/tmp/sway-ipc.sock"; + # TODO: Investigate if we can get hardware acceleration to work (via + # virtio-gpu and Virgil). We currently have to use the Pixman software + # renderer since the GLES2 renderer doesn't work inside the VM (even + # with WLR_RENDERER_ALLOW_SOFTWARE): + # "WLR_RENDERER_ALLOW_SOFTWARE" = "1"; + "WLR_RENDERER" = "pixman"; + }; + # For convenience: + shellAliases = { + test-x11 = "glinfo | tee /tmp/test-x11.out && touch /tmp/test-x11-exit-ok"; + test-wayland = "wayland-info | tee /tmp/test-wayland.out && touch /tmp/test-wayland-exit-ok"; + }; + + # To help with OCR: + etc."xdg/foot/foot.ini".text = lib.generators.toINI { } { + main = { + font = "inconsolata:size=14"; + }; + colors = rec { + foreground = "000000"; + background = "ffffff"; + regular2 = foreground; + }; + }; + + etc."gpg-agent.conf".text = '' + pinentry-timeout 86400 + ''; }; - colors = rec { - foreground = "000000"; - background = "ffffff"; - regular2 = foreground; - }; - }; - etc."gpg-agent.conf".text = '' - pinentry-timeout 86400 - ''; - }; + fonts.packages = [ pkgs.inconsolata ]; + + # Automatically configure and start Sway when logging in on tty1: + programs.bash.loginShellInit = '' + if [ "$(tty)" = "/dev/tty1" ]; then + set -e + + mkdir -p ~/.config/sway + sed s/Mod4/Mod1/ /etc/sway/config > ~/.config/sway/config - fonts.packages = [ pkgs.inconsolata ]; + sway --validate + sway && touch /tmp/sway-exit-ok + fi + ''; - # Automatically configure and start Sway when logging in on tty1: - programs.bash.loginShellInit = '' - if [ "$(tty)" = "/dev/tty1" ]; then - set -e + programs.sway.enable = true; - mkdir -p ~/.config/sway - sed s/Mod4/Mod1/ /etc/sway/config > ~/.config/sway/config + # To test pinentry via gpg-agent: + programs.gnupg.agent.enable = true; - sway --validate - sway && touch /tmp/sway-exit-ok - fi - ''; - - programs.sway.enable = true; - - # To test pinentry via gpg-agent: - programs.gnupg.agent.enable = true; - - # Need to switch to a different GPU driver than the default one (-vga std) so that Sway can launch: - virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ]; - }; - - testScript = { nodes, ... }: '' - import shlex - import json - - q = shlex.quote - NODE_GROUPS = ["nodes", "floating_nodes"] - - - def swaymsg(command: str = "", succeed=True, type="command"): - assert command != "" or type != "command", "Must specify command or type" - shell = q(f"swaymsg -t {q(type)} -- {q(command)}") - with machine.nested( - f"sending swaymsg {shell!r}" + " (allowed to fail)" * (not succeed) - ): - ret = (machine.succeed if succeed else machine.execute)( - f"su - alice -c {shell}" - ) - - # execute also returns a status code, but disregard. - if not succeed: - _, ret = ret - - if not succeed and not ret: - return None - - parsed = json.loads(ret) - return parsed - - - def walk(tree): - yield tree - for group in NODE_GROUPS: - for node in tree.get(group, []): - yield from walk(node) - - - def wait_for_window(pattern): - def func(last_chance): - nodes = (node["name"] for node in walk(swaymsg(type="get_tree"))) - - if last_chance: - nodes = list(nodes) - machine.log(f"Last call! Current list of windows: {nodes}") - - return any(pattern in name for name in nodes) - - retry(func) - - start_all() - machine.wait_for_unit("multi-user.target") - - # To check the version: - print(machine.succeed("sway --version")) - - # Wait for Sway to complete startup: - machine.wait_for_file("/run/user/1000/wayland-1") - machine.wait_for_file("/tmp/sway-ipc.sock") - - # Test XWayland (foot does not support X): - swaymsg("exec WINIT_UNIX_BACKEND=x11 WAYLAND_DISPLAY= alacritty") - wait_for_window("alice@machine") - machine.send_chars("test-x11\n") - machine.wait_for_file("/tmp/test-x11-exit-ok") - print(machine.succeed("cat /tmp/test-x11.out")) - machine.copy_from_vm("/tmp/test-x11.out") - machine.screenshot("alacritty_glinfo") - machine.succeed("pkill alacritty") - - # Start a terminal (foot) on workspace 3: - machine.send_key("alt-3") - machine.sleep(3) - machine.send_key("alt-ret") - wait_for_window("alice@machine") - machine.send_chars("test-wayland\n") - machine.wait_for_file("/tmp/test-wayland-exit-ok") - print(machine.succeed("cat /tmp/test-wayland.out")) - machine.copy_from_vm("/tmp/test-wayland.out") - machine.screenshot("foot_wayland_info") - machine.send_key("alt-shift-q") - machine.wait_until_fails("pgrep foot") - - # Test gpg-agent starting pinentry-gnome3 via D-Bus (tests if - # $WAYLAND_DISPLAY is correctly imported into the D-Bus user env): - swaymsg("exec mkdir -p ~/.gnupg") - swaymsg("exec cp /etc/gpg-agent.conf ~/.gnupg") - - swaymsg("exec DISPLAY=INVALID gpg --no-tty --yes --quick-generate-key test", succeed=False) - machine.wait_until_succeeds("pgrep --exact gpg") - wait_for_window("gpg") - machine.succeed("pgrep --exact gpg") - machine.screenshot("gpg_pinentry") - machine.send_key("alt-shift-q") - machine.wait_until_fails("pgrep --exact gpg") - - # Test swaynag: - def get_height(): - return [node['rect']['height'] for node in walk(swaymsg(type="get_tree")) if node['focused']][0] - - before = get_height() - machine.send_key("alt-shift-e") - retry(lambda _: get_height() < before) - machine.screenshot("sway_exit") - - swaymsg("exec swaylock") - machine.wait_until_succeeds("pgrep -x swaylock") - machine.sleep(3) - machine.send_chars("${nodes.machine.config.users.users.alice.password}") - machine.send_key("ret") - machine.wait_until_fails("pgrep -x swaylock") - - # Exit Sway and verify process exit status 0: - swaymsg("exit", succeed=False) - machine.wait_until_fails("pgrep -x sway") - machine.wait_for_file("/tmp/sway-exit-ok") - ''; -}) + # Need to switch to a different GPU driver than the default one (-vga std) so that Sway can launch: + virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ]; + }; + + testScript = + { nodes, ... }: + '' + import shlex + import json + + q = shlex.quote + NODE_GROUPS = ["nodes", "floating_nodes"] + + + def swaymsg(command: str = "", succeed=True, type="command"): + assert command != "" or type != "command", "Must specify command or type" + shell = q(f"swaymsg -t {q(type)} -- {q(command)}") + with machine.nested( + f"sending swaymsg {shell!r}" + " (allowed to fail)" * (not succeed) + ): + ret = (machine.succeed if succeed else machine.execute)( + f"su - alice -c {shell}" + ) + + # execute also returns a status code, but disregard. + if not succeed: + _, ret = ret + + if not succeed and not ret: + return None + + parsed = json.loads(ret) + return parsed + + + def walk(tree): + yield tree + for group in NODE_GROUPS: + for node in tree.get(group, []): + yield from walk(node) + + + def wait_for_window(pattern): + def func(last_chance): + nodes = (node["name"] for node in walk(swaymsg(type="get_tree"))) + + if last_chance: + nodes = list(nodes) + machine.log(f"Last call! Current list of windows: {nodes}") + + return any(pattern in name for name in nodes) + + retry(func) + + start_all() + machine.wait_for_unit("multi-user.target") + + # To check the version: + print(machine.succeed("sway --version")) + + # Wait for Sway to complete startup: + machine.wait_for_file("/run/user/1000/wayland-1") + machine.wait_for_file("/tmp/sway-ipc.sock") + + # Test XWayland (foot does not support X): + swaymsg("exec WINIT_UNIX_BACKEND=x11 WAYLAND_DISPLAY= alacritty") + wait_for_window("alice@machine") + machine.send_chars("test-x11\n") + machine.wait_for_file("/tmp/test-x11-exit-ok") + print(machine.succeed("cat /tmp/test-x11.out")) + machine.copy_from_vm("/tmp/test-x11.out") + machine.screenshot("alacritty_glinfo") + machine.succeed("pkill alacritty") + + # Start a terminal (foot) on workspace 3: + machine.send_key("alt-3") + machine.sleep(3) + machine.send_key("alt-ret") + wait_for_window("alice@machine") + machine.send_chars("test-wayland\n") + machine.wait_for_file("/tmp/test-wayland-exit-ok") + print(machine.succeed("cat /tmp/test-wayland.out")) + machine.copy_from_vm("/tmp/test-wayland.out") + machine.screenshot("foot_wayland_info") + machine.send_key("alt-shift-q") + machine.wait_until_fails("pgrep foot") + + # Test gpg-agent starting pinentry-gnome3 via D-Bus (tests if + # $WAYLAND_DISPLAY is correctly imported into the D-Bus user env): + swaymsg("exec mkdir -p ~/.gnupg") + swaymsg("exec cp /etc/gpg-agent.conf ~/.gnupg") + + swaymsg("exec DISPLAY=INVALID gpg --no-tty --yes --quick-generate-key test", succeed=False) + machine.wait_until_succeeds("pgrep --exact gpg") + wait_for_window("gpg") + machine.succeed("pgrep --exact gpg") + machine.screenshot("gpg_pinentry") + machine.send_key("alt-shift-q") + machine.wait_until_fails("pgrep --exact gpg") + + # Test swaynag: + def get_height(): + return [node['rect']['height'] for node in walk(swaymsg(type="get_tree")) if node['focused']][0] + + before = get_height() + machine.send_key("alt-shift-e") + retry(lambda _: get_height() < before) + machine.screenshot("sway_exit") + + swaymsg("exec swaylock") + machine.wait_until_succeeds("pgrep -x swaylock") + machine.sleep(3) + machine.send_chars("${nodes.machine.config.users.users.alice.password}") + machine.send_key("ret") + machine.wait_until_fails("pgrep -x swaylock") + + # Exit Sway and verify process exit status 0: + swaymsg("exit", succeed=False) + machine.wait_until_fails("pgrep -x sway") + machine.wait_for_file("/tmp/sway-exit-ok") + ''; + } +) diff --git a/nixos/tests/sympa.nix b/nixos/tests/sympa.nix index 80daa4134f75a0..fea12926cdad18 100644 --- a/nixos/tests/sympa.nix +++ b/nixos/tests/sympa.nix @@ -1,35 +1,38 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "sympa"; - meta.maintainers = with lib.maintainers; [ mmilata ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "sympa"; + meta.maintainers = with lib.maintainers; [ mmilata ]; - nodes.machine = - { ... }: - { + nodes.machine = + { ... }: + { - services.sympa = { - enable = true; - domains = { - "lists.example.org" = { - webHost = "localhost"; + services.sympa = { + enable = true; + domains = { + "lists.example.org" = { + webHost = "localhost"; + }; + }; + listMasters = [ "bob@example.org" ]; + web.enable = true; + web.https = false; + database = { + type = "PostgreSQL"; + createLocally = true; }; - }; - listMasters = [ "bob@example.org" ]; - web.enable = true; - web.https = false; - database = { - type = "PostgreSQL"; - createLocally = true; }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("sympa.service") - machine.wait_for_unit("wwsympa.service") - assert "Mailing lists service" in machine.succeed( - "curl --fail --insecure -L http://localhost/" - ) - ''; -}) + machine.wait_for_unit("sympa.service") + machine.wait_for_unit("wwsympa.service") + assert "Mailing lists service" in machine.succeed( + "curl --fail --insecure -L http://localhost/" + ) + ''; + } +) diff --git a/nixos/tests/syncthing-init.nix b/nixos/tests/syncthing-init.nix index 97fcf2ad28d10a..a4401805dcb2a5 100644 --- a/nixos/tests/syncthing-init.nix +++ b/nixos/tests/syncthing-init.nix @@ -1,31 +1,35 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: let +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let - testId = "7CFNTQM-IMTJBHJ-3UWRDIU-ZGQJFR6-VCXZ3NB-XUH3KZO-N52ITXR-LAIYUAU"; + testId = "7CFNTQM-IMTJBHJ-3UWRDIU-ZGQJFR6-VCXZ3NB-XUH3KZO-N52ITXR-LAIYUAU"; -in { - name = "syncthing-init"; - meta.maintainers = with pkgs.lib.maintainers; [ lassulus ]; + in + { + name = "syncthing-init"; + meta.maintainers = with pkgs.lib.maintainers; [ lassulus ]; - nodes.machine = { - services.syncthing = { - enable = true; - settings.devices.testDevice = { - id = testId; + nodes.machine = { + services.syncthing = { + enable = true; + settings.devices.testDevice = { + id = testId; + }; + settings.folders.testFolder = { + path = "/tmp/test"; + devices = [ "testDevice" ]; + }; + settings.gui.user = "guiUser"; }; - settings.folders.testFolder = { - path = "/tmp/test"; - devices = [ "testDevice" ]; - }; - settings.gui.user = "guiUser"; }; - }; - testScript = '' - machine.wait_for_unit("syncthing-init.service") - config = machine.succeed("cat /var/lib/syncthing/.config/syncthing/config.xml") + testScript = '' + machine.wait_for_unit("syncthing-init.service") + config = machine.succeed("cat /var/lib/syncthing/.config/syncthing/config.xml") - assert "testFolder" in config - assert "${testId}" in config - assert "guiUser" in config - ''; -}) + assert "testFolder" in config + assert "${testId}" in config + assert "guiUser" in config + ''; + } +) diff --git a/nixos/tests/syncthing-many-devices.nix b/nixos/tests/syncthing-many-devices.nix index 2251bf07745337..44bd15e29d91a8 100644 --- a/nixos/tests/syncthing-many-devices.nix +++ b/nixos/tests/syncthing-many-devices.nix @@ -1,203 +1,225 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: +import ./make-test-python.nix ( + { lib, pkgs, ... }: -# This nixosTest is supposed to check the following: -# -# - Whether syncthing's API handles multiple requests for many devices, see -# https://github.com/NixOS/nixpkgs/issues/260262 -# -# - Whether syncthing-init.service generated bash script removes devices and -# folders that are not present in the user's configuration, which is partly -# injected into the script. See also: -# https://github.com/NixOS/nixpkgs/issues/259256 -# + # This nixosTest is supposed to check the following: + # + # - Whether syncthing's API handles multiple requests for many devices, see + # https://github.com/NixOS/nixpkgs/issues/260262 + # + # - Whether syncthing-init.service generated bash script removes devices and + # folders that are not present in the user's configuration, which is partly + # injected into the script. See also: + # https://github.com/NixOS/nixpkgs/issues/259256 + # -let - # Just a long path not to copy paste - configPath = "/var/lib/syncthing/.config/syncthing/config.xml"; + let + # Just a long path not to copy paste + configPath = "/var/lib/syncthing/.config/syncthing/config.xml"; - # We will iterate this and more attribute sets defined here, later in the - # testScript. Start with this, and distinguish these settings from other - # settings, as we check these differently with xmllint, due to the ID. - settingsWithId = { - devices = { - # All of the device IDs used here were generated by the following command: - # - # (${pkgs.syncthing}/bin/syncthing generate --home /tmp/foo\ - # | grep ID: | sed 's/.*ID: *//') && rm -rf /tmp/foo - # - # See also discussion at: - # https://forum.syncthing.net/t/how-to-generate-dummy-device-ids/20927/8 - test_device1.id = "IVTZ5XF-EF3GKFT-GS4AZLG-IT6H2ZP-6WK75SF-AFXQXJJ-BNRZ4N6-XPDKVAU"; - test_device2.id = "5C35H56-Z2GFF4F-F3IVD4B-GJYVWIE-SMDBJZN-GI66KWP-52JIQGN-4AVLYAM"; - test_device3.id = "XKLSKHE-BZOHV7B-WQZACEF-GTH36NP-6JSBB6L-RXS3M7C-EEVWO2L-C5B4OAJ"; - test_device4.id = "APN5Q7J-35GZETO-5KCLF35-ZA7KBWK-HGWPBNG-FERF24R-UTLGMEX-4VJ6PQX"; - test_device5.id = "D4YXQEE-5MK6LIK-BRU5QWM-ZRXJCK2-N3RQBJE-23JKTQQ-LYGDPHF-RFPZIQX"; - test_device6.id = "TKMCH64-T44VSLI-6FN2YLF-URBZOBR-ATO4DYX-GEDRIII-CSMRQAI-UAQMDQG"; - test_device7.id = "472EEBG-Q4PZCD4-4CX6PGF-XS3FSQ2-UFXBZVB-PGNXWLX-7FKBLER-NJ3EMAR"; - test_device8.id = "HW6KUMK-WTBG24L-2HZQXLO-TGJSG2M-2JG3FHX-5OGYRUJ-T6L5NN7-L364QAZ"; - test_device9.id = "YAE24AP-7LSVY4T-J74ZSEM-A2IK6RB-FGA35TP-AG4CSLU-ED4UYYY-2J2TDQU"; - test_device10.id = "277XFSB-OFMQOBI-3XGNGUE-Y7FWRV3-QQDADIY-QIIPQ26-EOGTYKW-JP2EXAI"; - test_device11.id = "2WWXVTN-Q3QWAAY-XFORMRM-2FDI5XZ-OGN33BD-XOLL42R-DHLT2ML-QYXDQAU"; + # We will iterate this and more attribute sets defined here, later in the + # testScript. Start with this, and distinguish these settings from other + # settings, as we check these differently with xmllint, due to the ID. + settingsWithId = { + devices = { + # All of the device IDs used here were generated by the following command: + # + # (${pkgs.syncthing}/bin/syncthing generate --home /tmp/foo\ + # | grep ID: | sed 's/.*ID: *//') && rm -rf /tmp/foo + # + # See also discussion at: + # https://forum.syncthing.net/t/how-to-generate-dummy-device-ids/20927/8 + test_device1.id = "IVTZ5XF-EF3GKFT-GS4AZLG-IT6H2ZP-6WK75SF-AFXQXJJ-BNRZ4N6-XPDKVAU"; + test_device2.id = "5C35H56-Z2GFF4F-F3IVD4B-GJYVWIE-SMDBJZN-GI66KWP-52JIQGN-4AVLYAM"; + test_device3.id = "XKLSKHE-BZOHV7B-WQZACEF-GTH36NP-6JSBB6L-RXS3M7C-EEVWO2L-C5B4OAJ"; + test_device4.id = "APN5Q7J-35GZETO-5KCLF35-ZA7KBWK-HGWPBNG-FERF24R-UTLGMEX-4VJ6PQX"; + test_device5.id = "D4YXQEE-5MK6LIK-BRU5QWM-ZRXJCK2-N3RQBJE-23JKTQQ-LYGDPHF-RFPZIQX"; + test_device6.id = "TKMCH64-T44VSLI-6FN2YLF-URBZOBR-ATO4DYX-GEDRIII-CSMRQAI-UAQMDQG"; + test_device7.id = "472EEBG-Q4PZCD4-4CX6PGF-XS3FSQ2-UFXBZVB-PGNXWLX-7FKBLER-NJ3EMAR"; + test_device8.id = "HW6KUMK-WTBG24L-2HZQXLO-TGJSG2M-2JG3FHX-5OGYRUJ-T6L5NN7-L364QAZ"; + test_device9.id = "YAE24AP-7LSVY4T-J74ZSEM-A2IK6RB-FGA35TP-AG4CSLU-ED4UYYY-2J2TDQU"; + test_device10.id = "277XFSB-OFMQOBI-3XGNGUE-Y7FWRV3-QQDADIY-QIIPQ26-EOGTYKW-JP2EXAI"; + test_device11.id = "2WWXVTN-Q3QWAAY-XFORMRM-2FDI5XZ-OGN33BD-XOLL42R-DHLT2ML-QYXDQAU"; + }; + # Generates a few folders with IDs and paths as written... + folders = lib.pipe 6 [ + (builtins.genList (x: { + name = "/var/lib/syncthing/test_folder${builtins.toString x}"; + value = { + id = "DontDeleteMe${builtins.toString x}"; + }; + })) + builtins.listToAttrs + ]; }; - # Generates a few folders with IDs and paths as written... - folders = lib.pipe 6 [ - (builtins.genList (x: { - name = "/var/lib/syncthing/test_folder${builtins.toString x}"; - value = { - id = "DontDeleteMe${builtins.toString x}"; - }; - })) - builtins.listToAttrs - ]; - }; - # Non default options that we check later if were applied - settingsWithoutId = { - options = { - autoUpgradeIntervalH = 0; - urAccepted = -1; + # Non default options that we check later if were applied + settingsWithoutId = { + options = { + autoUpgradeIntervalH = 0; + urAccepted = -1; + }; + gui = { + theme = "dark"; + }; }; - gui = { - theme = "dark"; + # Used later when checking whether settings were set in config.xml: + checkSettingWithId = + { + t, # t for type + id, + not ? false, + }: + '' + print("Searching for a ${t} with id ${id}") + configVal_${t} = machine.succeed( + "${pkgs.libxml2}/bin/xmllint " + "--xpath 'string(//${t}[@id=\"${id}\"]/@id)' ${configPath}" + ) + print("${t}.id = {}".format(configVal_${t})) + assert "${id}" ${if not then "not" else ""} in configVal_${t} + ''; + # Same as checkSettingWithId, but for 'options' and 'gui' + checkSettingWithoutId = + { + t, # t for type + n, # n for name + v, # v for value + not ? false, + }: + '' + print("checking whether setting ${t}.${n} is set to ${v}") + configVal_${t}_${n} = machine.succeed( + "${pkgs.libxml2}/bin/xmllint " + "--xpath 'string(/configuration/${t}/${n})' ${configPath}" + ) + print("${t}.${n} = {}".format(configVal_${t}_${n})) + assert "${v}" ${if not then "not" else ""} in configVal_${t}_${n} + ''; + # Removes duplication a bit to define this function for the IDs to delete - + # we check whether they were added after our script ran, and before the + # systemd unit's bash script ran, and afterwards - whether the systemd unit + # worked. + checkSettingsToDelete = + { + not, + }: + lib.pipe IDsToDelete [ + (lib.mapAttrsToList ( + t: id: + checkSettingWithId { + inherit t id; + inherit not; + } + )) + lib.concatStrings + ]; + # These IDs are added to syncthing using the API, similarly to how the + # generated systemd unit's bash script does it. Only we add it and expect the + # systemd unit bash script to remove them when executed. + IDsToDelete = { + # Also created using the syncthing generate command above + device = "LZ2CTHT-3W2M7BC-CMKDFZL-DLUQJFS-WJR73PA-NZGODWG-DZBHCHI-OXTQXAK"; + # Intentionally this is a substring of the IDs of the 'test_folder's, as + # explained in: https://github.com/NixOS/nixpkgs/issues/259256 + folder = "DeleteMe"; }; - }; - # Used later when checking whether settings were set in config.xml: - checkSettingWithId = { t # t for type - , id - , not ? false - }: '' - print("Searching for a ${t} with id ${id}") - configVal_${t} = machine.succeed( - "${pkgs.libxml2}/bin/xmllint " - "--xpath 'string(//${t}[@id=\"${id}\"]/@id)' ${configPath}" - ) - print("${t}.id = {}".format(configVal_${t})) - assert "${id}" ${if not then "not" else ""} in configVal_${t} - ''; - # Same as checkSettingWithId, but for 'options' and 'gui' - checkSettingWithoutId = { t # t for type - , n # n for name - , v # v for value - , not ? false - }: '' - print("checking whether setting ${t}.${n} is set to ${v}") - configVal_${t}_${n} = machine.succeed( - "${pkgs.libxml2}/bin/xmllint " - "--xpath 'string(/configuration/${t}/${n})' ${configPath}" - ) - print("${t}.${n} = {}".format(configVal_${t}_${n})) - assert "${v}" ${if not then "not" else ""} in configVal_${t}_${n} - ''; - # Removes duplication a bit to define this function for the IDs to delete - - # we check whether they were added after our script ran, and before the - # systemd unit's bash script ran, and afterwards - whether the systemd unit - # worked. - checkSettingsToDelete = { - not - }: lib.pipe IDsToDelete [ - (lib.mapAttrsToList (t: id: - checkSettingWithId { - inherit t id; - inherit not; - } - )) - lib.concatStrings - ]; - # These IDs are added to syncthing using the API, similarly to how the - # generated systemd unit's bash script does it. Only we add it and expect the - # systemd unit bash script to remove them when executed. - IDsToDelete = { - # Also created using the syncthing generate command above - device = "LZ2CTHT-3W2M7BC-CMKDFZL-DLUQJFS-WJR73PA-NZGODWG-DZBHCHI-OXTQXAK"; - # Intentionally this is a substring of the IDs of the 'test_folder's, as - # explained in: https://github.com/NixOS/nixpkgs/issues/259256 - folder = "DeleteMe"; - }; - addDeviceToDeleteScript = pkgs.writers.writeBash "syncthing-add-device-to-delete.sh" '' - set -euo pipefail + addDeviceToDeleteScript = pkgs.writers.writeBash "syncthing-add-device-to-delete.sh" '' + set -euo pipefail - export RUNTIME_DIRECTORY=/tmp + export RUNTIME_DIRECTORY=/tmp - curl() { - # get the api key by parsing the config.xml - while - ! ${pkgs.libxml2}/bin/xmllint \ - --xpath 'string(configuration/gui/apikey)' \ - ${configPath} \ - >"$RUNTIME_DIRECTORY/api_key" - do sleep 1; done + curl() { + # get the api key by parsing the config.xml + while + ! ${pkgs.libxml2}/bin/xmllint \ + --xpath 'string(configuration/gui/apikey)' \ + ${configPath} \ + >"$RUNTIME_DIRECTORY/api_key" + do sleep 1; done - (printf "X-API-Key: "; cat "$RUNTIME_DIRECTORY/api_key") >"$RUNTIME_DIRECTORY/headers" + (printf "X-API-Key: "; cat "$RUNTIME_DIRECTORY/api_key") >"$RUNTIME_DIRECTORY/headers" - ${pkgs.curl}/bin/curl -sSLk -H "@$RUNTIME_DIRECTORY/headers" \ - --retry 1000 --retry-delay 1 --retry-all-errors \ - "$@" - } - curl -d ${lib.escapeShellArg (builtins.toJSON { deviceID = IDsToDelete.device;})} \ - -X POST 127.0.0.1:8384/rest/config/devices - curl -d ${lib.escapeShellArg (builtins.toJSON { id = IDsToDelete.folder;})} \ - -X POST 127.0.0.1:8384/rest/config/folders - ''; -in { - name = "syncthing-init"; - meta.maintainers = with lib.maintainers; [ doronbehar ]; + ${pkgs.curl}/bin/curl -sSLk -H "@$RUNTIME_DIRECTORY/headers" \ + --retry 1000 --retry-delay 1 --retry-all-errors \ + "$@" + } + curl -d ${lib.escapeShellArg (builtins.toJSON { deviceID = IDsToDelete.device; })} \ + -X POST 127.0.0.1:8384/rest/config/devices + curl -d ${lib.escapeShellArg (builtins.toJSON { id = IDsToDelete.folder; })} \ + -X POST 127.0.0.1:8384/rest/config/folders + ''; + in + { + name = "syncthing-init"; + meta.maintainers = with lib.maintainers; [ doronbehar ]; - nodes.machine = { - services.syncthing = { - enable = true; - overrideDevices = true; - overrideFolders = true; - settings = settingsWithoutId // settingsWithId; + nodes.machine = { + services.syncthing = { + enable = true; + overrideDevices = true; + overrideFolders = true; + settings = settingsWithoutId // settingsWithId; + }; }; - }; - testScript = '' - machine.wait_for_unit("syncthing-init.service") - '' + (lib.pipe settingsWithId [ - # Check that folders and devices were added properly and that all IDs exist - (lib.mapAttrsRecursive (path: id: - checkSettingWithId { - # plural -> solitary - t = (lib.removeSuffix "s" (builtins.elemAt path 0)); - inherit id; - } - )) - # Get all the values we applied the above function upon - (lib.collect builtins.isString) - lib.concatStrings - ]) + (lib.pipe settingsWithoutId [ - # Check that all other syncthing.settings were added properly with correct - # values - (lib.mapAttrsRecursive (path: value: - checkSettingWithoutId { - t = (builtins.elemAt path 0); - n = (builtins.elemAt path 1); - v = (builtins.toString value); - } - )) - # Get all the values we applied the above function upon - (lib.collect builtins.isString) - lib.concatStrings - ]) + '' - # Run the script on the machine - machine.succeed("${addDeviceToDeleteScript}") - '' + (checkSettingsToDelete { - not = false; - }) + '' - # Useful for debugging later - machine.copy_from_vm("${configPath}", "before") + testScript = + '' + machine.wait_for_unit("syncthing-init.service") + '' + + (lib.pipe settingsWithId [ + # Check that folders and devices were added properly and that all IDs exist + (lib.mapAttrsRecursive ( + path: id: + checkSettingWithId { + # plural -> solitary + t = (lib.removeSuffix "s" (builtins.elemAt path 0)); + inherit id; + } + )) + # Get all the values we applied the above function upon + (lib.collect builtins.isString) + lib.concatStrings + ]) + + (lib.pipe settingsWithoutId [ + # Check that all other syncthing.settings were added properly with correct + # values + (lib.mapAttrsRecursive ( + path: value: + checkSettingWithoutId { + t = (builtins.elemAt path 0); + n = (builtins.elemAt path 1); + v = (builtins.toString value); + } + )) + # Get all the values we applied the above function upon + (lib.collect builtins.isString) + lib.concatStrings + ]) + + '' + # Run the script on the machine + machine.succeed("${addDeviceToDeleteScript}") + '' + + (checkSettingsToDelete { + not = false; + }) + + '' + # Useful for debugging later + machine.copy_from_vm("${configPath}", "before") - machine.systemctl("restart syncthing-init.service") - machine.wait_for_unit("syncthing-init.service") - '' + (checkSettingsToDelete { - not = true; - }) + '' - # Useful for debugging later - machine.copy_from_vm("${configPath}", "after") + machine.systemctl("restart syncthing-init.service") + machine.wait_for_unit("syncthing-init.service") + '' + + (checkSettingsToDelete { + not = true; + }) + + '' + # Useful for debugging later + machine.copy_from_vm("${configPath}", "after") - # Copy the systemd unit's bash script, to inspect it for debugging. - mergeScript = machine.succeed( - "systemctl cat syncthing-init.service | " - "${pkgs.initool}/bin/initool g - Service ExecStart --value-only" - ).strip() # strip from new lines - machine.copy_from_vm(mergeScript, "") - ''; -}) + # Copy the systemd unit's bash script, to inspect it for debugging. + mergeScript = machine.succeed( + "systemctl cat syncthing-init.service | " + "${pkgs.initool}/bin/initool g - Service ExecStart --value-only" + ).strip() # strip from new lines + machine.copy_from_vm(mergeScript, "") + ''; + } +) diff --git a/nixos/tests/syncthing-no-settings.nix b/nixos/tests/syncthing-no-settings.nix index fee122b5e35c0c..904f3eb37356fc 100644 --- a/nixos/tests/syncthing-no-settings.nix +++ b/nixos/tests/syncthing-no-settings.nix @@ -1,18 +1,26 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "syncthing"; - meta.maintainers = with pkgs.lib.maintainers; [ chkno ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "syncthing"; + meta.maintainers = with pkgs.lib.maintainers; [ chkno ]; - nodes = { - a = { - environment.systemPackages = with pkgs; [ curl libxml2 syncthing ]; - services.syncthing = { - enable = true; + nodes = { + a = { + environment.systemPackages = with pkgs; [ + curl + libxml2 + syncthing + ]; + services.syncthing = { + enable = true; + }; }; }; - }; - # Test that indeed a syncthing-init.service systemd service is not created. - # - testScript = /* python */ '' - a.succeed("systemctl list-unit-files | awk '$1 == \"syncthing-init.service\" {exit 1;}'") - ''; -}) + # Test that indeed a syncthing-init.service systemd service is not created. + # + testScript = # python + '' + a.succeed("systemctl list-unit-files | awk '$1 == \"syncthing-init.service\" {exit 1;}'") + ''; + } +) diff --git a/nixos/tests/syncthing-relay.nix b/nixos/tests/syncthing-relay.nix index cab9bcafe9d5c7..9b44155415d29e 100644 --- a/nixos/tests/syncthing-relay.nix +++ b/nixos/tests/syncthing-relay.nix @@ -1,26 +1,29 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "syncthing-relay"; - meta.maintainers = with pkgs.lib.maintainers; [ ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "syncthing-relay"; + meta.maintainers = with pkgs.lib.maintainers; [ ]; - nodes.machine = { - environment.systemPackages = [ pkgs.jq ]; - services.syncthing.relay = { - enable = true; - providedBy = "nixos-test"; - pools = []; # Don't connect to any pool while testing. - port = 12345; - statusPort = 12346; + nodes.machine = { + environment.systemPackages = [ pkgs.jq ]; + services.syncthing.relay = { + enable = true; + providedBy = "nixos-test"; + pools = [ ]; # Don't connect to any pool while testing. + port = 12345; + statusPort = 12346; + }; }; - }; - testScript = '' - machine.wait_for_unit("syncthing-relay.service") - machine.wait_for_open_port(12345) - machine.wait_for_open_port(12346) + testScript = '' + machine.wait_for_unit("syncthing-relay.service") + machine.wait_for_open_port(12345) + machine.wait_for_open_port(12346) - out = machine.succeed( - "curl -sSf http://localhost:12346/status | jq -r '.options.\"provided-by\"'" - ) - assert "nixos-test" in out - ''; -}) + out = machine.succeed( + "curl -sSf http://localhost:12346/status | jq -r '.options.\"provided-by\"'" + ) + assert "nixos-test" in out + ''; + } +) diff --git a/nixos/tests/syncthing.nix b/nixos/tests/syncthing.nix index aff1d87441308d..f3e2614a0b8373 100644 --- a/nixos/tests/syncthing.nix +++ b/nixos/tests/syncthing.nix @@ -1,65 +1,72 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "syncthing"; - meta.maintainers = with pkgs.lib.maintainers; [ chkno ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "syncthing"; + meta.maintainers = with pkgs.lib.maintainers; [ chkno ]; - nodes = rec { - a = { - environment.systemPackages = with pkgs; [ curl libxml2 syncthing ]; - services.syncthing = { - enable = true; - openDefaultPorts = true; + nodes = rec { + a = { + environment.systemPackages = with pkgs; [ + curl + libxml2 + syncthing + ]; + services.syncthing = { + enable = true; + openDefaultPorts = true; + }; }; + b = a; }; - b = a; - }; - testScript = '' - import json - import shlex + testScript = '' + import json + import shlex - confdir = "/var/lib/syncthing/.config/syncthing" + confdir = "/var/lib/syncthing/.config/syncthing" - def addPeer(host, name, deviceID): - APIKey = host.succeed( - "xmllint --xpath 'string(configuration/gui/apikey)' %s/config.xml" % confdir - ).strip() - oldConf = host.succeed( - "curl -Ssf -H 'X-API-Key: %s' 127.0.0.1:8384/rest/config" % APIKey - ) - conf = json.loads(oldConf) - conf["devices"].append({"deviceID": deviceID, "id": name}) - conf["folders"].append( - { - "devices": [{"deviceID": deviceID}], - "id": "foo", - "path": "/var/lib/syncthing/foo", - "rescanIntervalS": 1, - } - ) - newConf = json.dumps(conf) - host.succeed( - "curl -Ssf -H 'X-API-Key: %s' 127.0.0.1:8384/rest/config -X PUT -d %s" - % (APIKey, shlex.quote(newConf)) - ) + def addPeer(host, name, deviceID): + APIKey = host.succeed( + "xmllint --xpath 'string(configuration/gui/apikey)' %s/config.xml" % confdir + ).strip() + oldConf = host.succeed( + "curl -Ssf -H 'X-API-Key: %s' 127.0.0.1:8384/rest/config" % APIKey + ) + conf = json.loads(oldConf) + conf["devices"].append({"deviceID": deviceID, "id": name}) + conf["folders"].append( + { + "devices": [{"deviceID": deviceID}], + "id": "foo", + "path": "/var/lib/syncthing/foo", + "rescanIntervalS": 1, + } + ) + newConf = json.dumps(conf) + host.succeed( + "curl -Ssf -H 'X-API-Key: %s' 127.0.0.1:8384/rest/config -X PUT -d %s" + % (APIKey, shlex.quote(newConf)) + ) - start_all() - a.wait_for_unit("syncthing.service") - b.wait_for_unit("syncthing.service") - a.wait_for_open_port(22000) - b.wait_for_open_port(22000) + start_all() + a.wait_for_unit("syncthing.service") + b.wait_for_unit("syncthing.service") + a.wait_for_open_port(22000) + b.wait_for_open_port(22000) - aDeviceID = a.succeed("syncthing -home=%s -device-id" % confdir).strip() - bDeviceID = b.succeed("syncthing -home=%s -device-id" % confdir).strip() - addPeer(a, "b", bDeviceID) - addPeer(b, "a", aDeviceID) + aDeviceID = a.succeed("syncthing -home=%s -device-id" % confdir).strip() + bDeviceID = b.succeed("syncthing -home=%s -device-id" % confdir).strip() + addPeer(a, "b", bDeviceID) + addPeer(b, "a", aDeviceID) - a.wait_for_file("/var/lib/syncthing/foo") - b.wait_for_file("/var/lib/syncthing/foo") - a.succeed("echo a2b > /var/lib/syncthing/foo/a2b") - b.succeed("echo b2a > /var/lib/syncthing/foo/b2a") - a.wait_for_file("/var/lib/syncthing/foo/b2a") - b.wait_for_file("/var/lib/syncthing/foo/a2b") - ''; -}) + a.wait_for_file("/var/lib/syncthing/foo") + b.wait_for_file("/var/lib/syncthing/foo") + a.succeed("echo a2b > /var/lib/syncthing/foo/a2b") + b.succeed("echo b2a > /var/lib/syncthing/foo/b2a") + a.wait_for_file("/var/lib/syncthing/foo/b2a") + b.wait_for_file("/var/lib/syncthing/foo/a2b") + ''; + } +) diff --git a/nixos/tests/sysinit-reactivation.nix b/nixos/tests/sysinit-reactivation.nix index 1a0caecb610a39..335d7ad8d4ca73 100644 --- a/nixos/tests/sysinit-reactivation.nix +++ b/nixos/tests/sysinit-reactivation.nix @@ -21,8 +21,7 @@ let }; systemd.tmpfiles.settings.test = lib.mkForce { - "/run/${generation}-needed-by-pre-sysinit-after-tmpfiles".f.user = - "${generation}-tmpfiles-user"; + "/run/${generation}-needed-by-pre-sysinit-after-tmpfiles".f.user = "${generation}-tmpfiles-user"; }; }; }; @@ -34,74 +33,88 @@ in meta.maintainers = with lib.maintainers; [ nikstur ]; - nodes.machine = { config, lib, pkgs, ... }: { - systemd.services.pre-sysinit-before-tmpfiles = { - wantedBy = [ "sysinit.target" ]; - requiredBy = [ "sysinit-reactivation.target" ]; - before = [ "systemd-tmpfiles-setup.service" "systemd-tmpfiles-resetup.service" ]; - unitConfig.DefaultDependencies = false; - serviceConfig.Type = "oneshot"; - serviceConfig.RemainAfterExit = true; - environment.USER = "tmpfiles-user"; - script = "${pkgs.shadow}/bin/useradd $USER"; - }; + nodes.machine = + { + config, + lib, + pkgs, + ... + }: + { + systemd.services.pre-sysinit-before-tmpfiles = { + wantedBy = [ "sysinit.target" ]; + requiredBy = [ "sysinit-reactivation.target" ]; + before = [ + "systemd-tmpfiles-setup.service" + "systemd-tmpfiles-resetup.service" + ]; + unitConfig.DefaultDependencies = false; + serviceConfig.Type = "oneshot"; + serviceConfig.RemainAfterExit = true; + environment.USER = "tmpfiles-user"; + script = "${pkgs.shadow}/bin/useradd $USER"; + }; - systemd.services.pre-sysinit-after-tmpfiles = { - wantedBy = [ "sysinit.target" ]; - requiredBy = [ "sysinit-reactivation.target" ]; - after = [ "systemd-tmpfiles-setup.service" "systemd-tmpfiles-resetup.service" ]; - unitConfig.DefaultDependencies = false; - serviceConfig.Type = "oneshot"; - serviceConfig.RemainAfterExit = true; - environment = { - NEEDED_PATH = "/run/needed-by-pre-sysinit-after-tmpfiles"; - PATH_TO_CREATE = "/run/needed-by-post-sysinit"; + systemd.services.pre-sysinit-after-tmpfiles = { + wantedBy = [ "sysinit.target" ]; + requiredBy = [ "sysinit-reactivation.target" ]; + after = [ + "systemd-tmpfiles-setup.service" + "systemd-tmpfiles-resetup.service" + ]; + unitConfig.DefaultDependencies = false; + serviceConfig.Type = "oneshot"; + serviceConfig.RemainAfterExit = true; + environment = { + NEEDED_PATH = "/run/needed-by-pre-sysinit-after-tmpfiles"; + PATH_TO_CREATE = "/run/needed-by-post-sysinit"; + }; + script = '' + if [[ -e $NEEDED_PATH ]]; then + touch $PATH_TO_CREATE + fi + ''; }; - script = '' - if [[ -e $NEEDED_PATH ]]; then - touch $PATH_TO_CREATE - fi - ''; - }; - systemd.services.post-sysinit = { - wantedBy = [ "default.target" ]; - serviceConfig.Type = "oneshot"; - serviceConfig.RemainAfterExit = true; - environment = { - NEEDED_PATH = "/run/needed-by-post-sysinit"; - PATH_TO_CREATE = "/run/created-by-post-sysinit"; + systemd.services.post-sysinit = { + wantedBy = [ "default.target" ]; + serviceConfig.Type = "oneshot"; + serviceConfig.RemainAfterExit = true; + environment = { + NEEDED_PATH = "/run/needed-by-post-sysinit"; + PATH_TO_CREATE = "/run/created-by-post-sysinit"; + }; + script = '' + if [[ -e $NEEDED_PATH ]]; then + touch $PATH_TO_CREATE + fi + ''; }; - script = '' - if [[ -e $NEEDED_PATH ]]; then - touch $PATH_TO_CREATE - fi - ''; - }; - systemd.tmpfiles.settings.test = { - "/run/needed-by-pre-sysinit-after-tmpfiles".f.user = - "tmpfiles-user"; - }; + systemd.tmpfiles.settings.test = { + "/run/needed-by-pre-sysinit-after-tmpfiles".f.user = "tmpfiles-user"; + }; - specialisation = lib.mkMerge [ - (makeGeneration "second") - (makeGeneration "third") - ]; - }; + specialisation = lib.mkMerge [ + (makeGeneration "second") + (makeGeneration "third") + ]; + }; - testScript = { nodes, ... }: '' - def switch(generation): - toplevel = "${nodes.machine.system.build.toplevel}"; - machine.succeed(f"{toplevel}/specialisation/{generation}/bin/switch-to-configuration switch") + testScript = + { nodes, ... }: + '' + def switch(generation): + toplevel = "${nodes.machine.system.build.toplevel}"; + machine.succeed(f"{toplevel}/specialisation/{generation}/bin/switch-to-configuration switch") - machine.wait_for_unit("default.target") - machine.succeed("test -e /run/created-by-post-sysinit") + machine.wait_for_unit("default.target") + machine.succeed("test -e /run/created-by-post-sysinit") - switch("second") - machine.succeed("test -e /run/second-created-by-post-sysinit") + switch("second") + machine.succeed("test -e /run/second-created-by-post-sysinit") - switch("third") - machine.succeed("test -e /run/third-created-by-post-sysinit") - ''; + switch("third") + machine.succeed("test -e /run/third-created-by-post-sysinit") + ''; } diff --git a/nixos/tests/systemd-analyze.nix b/nixos/tests/systemd-analyze.nix index 37c20d5fe5b65e..3b1365c0b4cf61 100644 --- a/nixos/tests/systemd-analyze.nix +++ b/nixos/tests/systemd-analyze.nix @@ -1,45 +1,52 @@ -import ./make-test-python.nix ({ pkgs, latestKernel ? false, ... }: - -{ - name = "systemd-analyze"; - meta = with pkgs.lib.maintainers; { - maintainers = [ raskin ]; - }; - - nodes.machine = - { pkgs, lib, ... }: - { boot.kernelPackages = lib.mkIf latestKernel pkgs.linuxPackages_latest; +import ./make-test-python.nix ( + { + pkgs, + latestKernel ? false, + ... + }: + + { + name = "systemd-analyze"; + meta = with pkgs.lib.maintainers; { + maintainers = [ raskin ]; }; - testScript = '' - machine.wait_for_unit("multi-user.target") - - # We create a special output directory to copy it as a whole - with subtest("Prepare output dir"): - machine.succeed("mkdir systemd-analyze") - - - # Save the output into a file with given name inside the common - # output directory - def run_systemd_analyze(args, name): - tgt_dir = "systemd-analyze" - machine.succeed( - "systemd-analyze {} > {}/{} 2> {}/{}.err".format( - " ".join(args), tgt_dir, name, tgt_dir, name - ) - ) - - - with subtest("Print statistics"): - run_systemd_analyze(["blame"], "blame.txt") - run_systemd_analyze(["critical-chain"], "critical-chain.txt") - run_systemd_analyze(["dot"], "dependencies.dot") - run_systemd_analyze(["plot"], "systemd-analyze.svg") - - # We copy the main graph into the $out (toplevel), and we also copy - # the entire output directory with additional data - with subtest("Copying the resulting data into $out"): - machine.copy_from_vm("systemd-analyze/", "") - machine.copy_from_vm("systemd-analyze/systemd-analyze.svg", "") - ''; -}) + nodes.machine = + { pkgs, lib, ... }: + { + boot.kernelPackages = lib.mkIf latestKernel pkgs.linuxPackages_latest; + }; + + testScript = '' + machine.wait_for_unit("multi-user.target") + + # We create a special output directory to copy it as a whole + with subtest("Prepare output dir"): + machine.succeed("mkdir systemd-analyze") + + + # Save the output into a file with given name inside the common + # output directory + def run_systemd_analyze(args, name): + tgt_dir = "systemd-analyze" + machine.succeed( + "systemd-analyze {} > {}/{} 2> {}/{}.err".format( + " ".join(args), tgt_dir, name, tgt_dir, name + ) + ) + + + with subtest("Print statistics"): + run_systemd_analyze(["blame"], "blame.txt") + run_systemd_analyze(["critical-chain"], "critical-chain.txt") + run_systemd_analyze(["dot"], "dependencies.dot") + run_systemd_analyze(["plot"], "systemd-analyze.svg") + + # We copy the main graph into the $out (toplevel), and we also copy + # the entire output directory with additional data + with subtest("Copying the resulting data into $out"): + machine.copy_from_vm("systemd-analyze/", "") + machine.copy_from_vm("systemd-analyze/systemd-analyze.svg", "") + ''; + } +) diff --git a/nixos/tests/systemd-binfmt.nix b/nixos/tests/systemd-binfmt.nix index a5e46a455d3259..33d6cdf51de2f7 100644 --- a/nixos/tests/systemd-binfmt.nix +++ b/nixos/tests/systemd-binfmt.nix @@ -1,34 +1,40 @@ # Teach the kernel how to run armv7l and aarch64-linux binaries, # and run GNU Hello for these architectures. -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; let - expectArgv0 = xpkgs: xpkgs.runCommandCC "expect-argv0" { - src = pkgs.writeText "expect-argv0.c" '' - #include <stdio.h> - #include <string.h> + expectArgv0 = + xpkgs: + xpkgs.runCommandCC "expect-argv0" + { + src = pkgs.writeText "expect-argv0.c" '' + #include <stdio.h> + #include <string.h> - int main(int argc, char **argv) { - fprintf(stderr, "Our argv[0] is %s\n", argv[0]); + int main(int argc, char **argv) { + fprintf(stderr, "Our argv[0] is %s\n", argv[0]); - if (strcmp(argv[0], argv[1])) { - fprintf(stderr, "ERROR: argv[0] is %s, should be %s\n", argv[0], argv[1]); - return 1; - } + if (strcmp(argv[0], argv[1])) { + fprintf(stderr, "ERROR: argv[0] is %s, should be %s\n", argv[0], argv[1]); + return 1; + } - return 0; + return 0; + } + ''; } - ''; - } '' - $CC -o $out $src - ''; -in { + '' + $CC -o $out $src + ''; +in +{ basic = makeTest { name = "systemd-binfmt"; nodes.machine = { @@ -38,20 +44,22 @@ in { ]; }; - testScript = let - helloArmv7l = pkgs.pkgsCross.armv7l-hf-multiplatform.hello; - helloAarch64 = pkgs.pkgsCross.aarch64-multiplatform.hello; - in '' - machine.start() + testScript = + let + helloArmv7l = pkgs.pkgsCross.armv7l-hf-multiplatform.hello; + helloAarch64 = pkgs.pkgsCross.aarch64-multiplatform.hello; + in + '' + machine.start() - assert "world" in machine.succeed( - "${helloArmv7l}/bin/hello" - ) + assert "world" in machine.succeed( + "${helloArmv7l}/bin/hello" + ) - assert "world" in machine.succeed( - "${helloAarch64}/bin/hello" - ) - ''; + assert "world" in machine.succeed( + "${helloAarch64}/bin/hello" + ) + ''; }; preserveArgvZero = makeTest { @@ -61,12 +69,14 @@ in { "aarch64-linux" ]; }; - testScript = let - testAarch64 = expectArgv0 pkgs.pkgsCross.aarch64-multiplatform; - in '' - machine.start() - machine.succeed("exec -a meow ${testAarch64} meow") - ''; + testScript = + let + testAarch64 = expectArgv0 pkgs.pkgsCross.aarch64-multiplatform; + in + '' + machine.start() + machine.succeed("exec -a meow ${testAarch64} meow") + ''; }; ldPreload = makeTest { @@ -76,37 +86,42 @@ in { "aarch64-linux" ]; }; - testScript = let - helloAarch64 = pkgs.pkgsCross.aarch64-multiplatform.hello; - libredirectAarch64 = pkgs.pkgsCross.aarch64-multiplatform.libredirect; - in '' - machine.start() + testScript = + let + helloAarch64 = pkgs.pkgsCross.aarch64-multiplatform.hello; + libredirectAarch64 = pkgs.pkgsCross.aarch64-multiplatform.libredirect; + in + '' + machine.start() - assert "error" not in machine.succeed( - "LD_PRELOAD='${libredirectAarch64}/lib/libredirect.so' ${helloAarch64}/bin/hello 2>&1" - ).lower() - ''; + assert "error" not in machine.succeed( + "LD_PRELOAD='${libredirectAarch64}/lib/libredirect.so' ${helloAarch64}/bin/hello 2>&1" + ).lower() + ''; }; chroot = makeTest { name = "systemd-binfmt-chroot"; - nodes.machine = { pkgs, lib, ... }: { - boot.binfmt.emulatedSystems = [ - "aarch64-linux" "wasm32-wasi" - ]; - boot.binfmt.preferStaticEmulators = true; + nodes.machine = + { pkgs, lib, ... }: + { + boot.binfmt.emulatedSystems = [ + "aarch64-linux" + "wasm32-wasi" + ]; + boot.binfmt.preferStaticEmulators = true; - environment.systemPackages = [ - (pkgs.writeShellScriptBin "test-chroot" '' - set -euo pipefail - mkdir -p /tmp/chroot - cp ${lib.getExe' pkgs.pkgsCross.aarch64-multiplatform.pkgsStatic.busybox "busybox"} /tmp/chroot/busybox - cp ${lib.getExe pkgs.pkgsCross.wasi32.yaml2json} /tmp/chroot/yaml2json # wasi binaries that build are hard to come by - chroot /tmp/chroot /busybox uname -m | grep aarch64 - echo 42 | chroot /tmp/chroot /yaml2json | grep 42 - '') - ]; - }; + environment.systemPackages = [ + (pkgs.writeShellScriptBin "test-chroot" '' + set -euo pipefail + mkdir -p /tmp/chroot + cp ${lib.getExe' pkgs.pkgsCross.aarch64-multiplatform.pkgsStatic.busybox "busybox"} /tmp/chroot/busybox + cp ${lib.getExe pkgs.pkgsCross.wasi32.yaml2json} /tmp/chroot/yaml2json # wasi binaries that build are hard to come by + chroot /tmp/chroot /busybox uname -m | grep aarch64 + echo 42 | chroot /tmp/chroot /yaml2json | grep 42 + '') + ]; + }; testScript = '' machine.start() machine.succeed("test-chroot") diff --git a/nixos/tests/systemd-boot.nix b/nixos/tests/systemd-boot.nix index 812d6088ed4e2b..570cd6b9340911 100644 --- a/nixos/tests/systemd-boot.nix +++ b/nixos/tests/systemd-boot.nix @@ -343,10 +343,12 @@ in name = "systemd-boot-edk2-uefi-shell"; meta.maintainers = with pkgs.lib.maintainers; [ iFreilicht ]; - nodes.machine = { ... }: { - imports = [ common ]; - boot.loader.systemd-boot.edk2-uefi-shell.enable = true; - }; + nodes.machine = + { ... }: + { + imports = [ common ]; + boot.loader.systemd-boot.edk2-uefi-shell.enable = true; + }; testScript = '' machine.succeed("test -e /boot/loader/entries/edk2-uefi-shell.conf") @@ -358,21 +360,23 @@ in name = "systemd-boot-windows"; meta.maintainers = with pkgs.lib.maintainers; [ iFreilicht ]; - nodes.machine = { ... }: { - imports = [ common ]; - boot.loader.systemd-boot.windows = { - "7" = { - efiDeviceHandle = "HD0c1"; - sortKey = "before_all_others"; - }; - "Ten".efiDeviceHandle = "FS0"; - "11" = { - title = "Title with-_-punctuation ...?!"; - efiDeviceHandle = "HD0d4"; - sortKey = "zzz"; + nodes.machine = + { ... }: + { + imports = [ common ]; + boot.loader.systemd-boot.windows = { + "7" = { + efiDeviceHandle = "HD0c1"; + sortKey = "before_all_others"; + }; + "Ten".efiDeviceHandle = "FS0"; + "11" = { + title = "Title with-_-punctuation ...?!"; + efiDeviceHandle = "HD0d4"; + sortKey = "zzz"; + }; }; }; - }; testScript = '' machine.succeed("test -e /boot/efi/edk2-uefi-shell/shell.efi") diff --git a/nixos/tests/systemd-bpf.nix b/nixos/tests/systemd-bpf.nix index e11347a2a817a1..2820218b228679 100644 --- a/nixos/tests/systemd-bpf.nix +++ b/nixos/tests/systemd-bpf.nix @@ -1,42 +1,51 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "systemd-bpf"; - meta = with lib.maintainers; { - maintainers = [ veehaitch ]; - }; - nodes = { - node1 = { - virtualisation.vlans = [ 1 ]; - networking = { - useNetworkd = true; - useDHCP = false; - firewall.enable = false; - interfaces.eth1.ipv4.addresses = [ - { address = "192.168.1.1"; prefixLength = 24; } - ]; - }; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "systemd-bpf"; + meta = with lib.maintainers; { + maintainers = [ veehaitch ]; }; + nodes = { + node1 = { + virtualisation.vlans = [ 1 ]; + networking = { + useNetworkd = true; + useDHCP = false; + firewall.enable = false; + interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.1.1"; + prefixLength = 24; + } + ]; + }; + }; - node2 = { - virtualisation.vlans = [ 1 ]; - networking = { - useNetworkd = true; - useDHCP = false; - firewall.enable = false; - interfaces.eth1.ipv4.addresses = [ - { address = "192.168.1.2"; prefixLength = 24; } - ]; + node2 = { + virtualisation.vlans = [ 1 ]; + networking = { + useNetworkd = true; + useDHCP = false; + firewall.enable = false; + interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.1.2"; + prefixLength = 24; + } + ]; + }; }; }; - }; - testScript = '' - start_all() - node1.wait_for_unit("systemd-networkd-wait-online.service") - node2.wait_for_unit("systemd-networkd-wait-online.service") + testScript = '' + start_all() + node1.wait_for_unit("systemd-networkd-wait-online.service") + node2.wait_for_unit("systemd-networkd-wait-online.service") - with subtest("test RestrictNetworkInterfaces= works"): - node1.succeed("ping -c 5 192.168.1.2") - node1.succeed("systemd-run -t -p RestrictNetworkInterfaces='eth1' ping -c 5 192.168.1.2") - node1.fail("systemd-run -t -p RestrictNetworkInterfaces='lo' ping -c 5 192.168.1.2") - ''; -}) + with subtest("test RestrictNetworkInterfaces= works"): + node1.succeed("ping -c 5 192.168.1.2") + node1.succeed("systemd-run -t -p RestrictNetworkInterfaces='eth1' ping -c 5 192.168.1.2") + node1.fail("systemd-run -t -p RestrictNetworkInterfaces='lo' ping -c 5 192.168.1.2") + ''; + } +) diff --git a/nixos/tests/systemd-confinement/default.nix b/nixos/tests/systemd-confinement/default.nix index 4ca37b3b9126e1..905a2272c0fb89 100644 --- a/nixos/tests/systemd-confinement/default.nix +++ b/nixos/tests/systemd-confinement/default.nix @@ -1,272 +1,344 @@ import ../make-test-python.nix { name = "systemd-confinement"; - nodes.machine = { pkgs, lib, ... }: let - testLib = pkgs.python3Packages.buildPythonPackage { - name = "confinement-testlib"; - unpackPhase = '' - cat > setup.py <<EOF - from setuptools import setup - setup(name='confinement-testlib', py_modules=["checkperms"]) - EOF - cp ${./checkperms.py} checkperms.py - ''; - }; + nodes.machine = + { pkgs, lib, ... }: + let + testLib = pkgs.python3Packages.buildPythonPackage { + name = "confinement-testlib"; + unpackPhase = '' + cat > setup.py <<EOF + from setuptools import setup + setup(name='confinement-testlib', py_modules=["checkperms"]) + EOF + cp ${./checkperms.py} checkperms.py + ''; + }; - mkTest = name: testScript: pkgs.writers.writePython3 "${name}.py" { - libraries = [ pkgs.python3Packages.pytest testLib ]; - } '' - # This runs our test script by using pytest's assertion rewriting, so - # that whenever we use "assert <something>", the actual values are - # printed rather than getting a generic AssertionError or the need to - # pass an explicit assertion error message. - import ast - from pathlib import Path - from _pytest.assertion.rewrite import rewrite_asserts + mkTest = + name: testScript: + pkgs.writers.writePython3 "${name}.py" + { + libraries = [ + pkgs.python3Packages.pytest + testLib + ]; + } + '' + # This runs our test script by using pytest's assertion rewriting, so + # that whenever we use "assert <something>", the actual values are + # printed rather than getting a generic AssertionError or the need to + # pass an explicit assertion error message. + import ast + from pathlib import Path + from _pytest.assertion.rewrite import rewrite_asserts - script = Path('${pkgs.writeText "${name}-main.py" '' - import errno, os, pytest, signal - from subprocess import run - from checkperms import Accessibility, assert_permissions + script = Path('${pkgs.writeText "${name}-main.py" '' + import errno, os, pytest, signal + from subprocess import run + from checkperms import Accessibility, assert_permissions - ${testScript} - ''}') # noqa - filename = str(script) - source = script.read_bytes() + ${testScript} + ''}') # noqa + filename = str(script) + source = script.read_bytes() - tree = ast.parse(source, filename=filename) - rewrite_asserts(tree, source, filename) - exec(compile(tree, filename, 'exec', dont_inherit=True)) - ''; + tree = ast.parse(source, filename=filename) + rewrite_asserts(tree, source, filename) + exec(compile(tree, filename, 'exec', dont_inherit=True)) + ''; - mkTestStep = num: { - description, - testScript, - config ? {}, - serviceName ? "test${toString num}", - rawUnit ? null, - }: { - systemd.packages = lib.optional (rawUnit != null) (pkgs.writeTextFile { - name = serviceName; - destination = "/etc/systemd/system/${serviceName}.service"; - text = rawUnit; - }); + mkTestStep = + num: + { + description, + testScript, + config ? { }, + serviceName ? "test${toString num}", + rawUnit ? null, + }: + { + systemd.packages = lib.optional (rawUnit != null) ( + pkgs.writeTextFile { + name = serviceName; + destination = "/etc/systemd/system/${serviceName}.service"; + text = rawUnit; + } + ); - systemd.services.${serviceName} = { - inherit description; - requiredBy = [ "multi-user.target" ]; - confinement = (config.confinement or {}) // { enable = true; }; - serviceConfig = (config.serviceConfig or {}) // { - ExecStart = mkTest serviceName testScript; - Type = "oneshot"; + systemd.services.${serviceName} = + { + inherit description; + requiredBy = [ "multi-user.target" ]; + confinement = (config.confinement or { }) // { + enable = true; + }; + serviceConfig = (config.serviceConfig or { }) // { + ExecStart = mkTest serviceName testScript; + Type = "oneshot"; + }; + } + // removeAttrs config [ + "confinement" + "serviceConfig" + ]; }; - } // removeAttrs config [ "confinement" "serviceConfig" ]; - }; - parametrisedTests = lib.concatMap ({ user, privateTmp }: let - withTmp = if privateTmp then "with PrivateTmp" else "without PrivateTmp"; + parametrisedTests = + lib.concatMap + ( + { user, privateTmp }: + let + withTmp = if privateTmp then "with PrivateTmp" else "without PrivateTmp"; - serviceConfig = if user == "static-user" then { - User = "chroot-testuser"; - Group = "chroot-testgroup"; - } else if user == "dynamic-user" then { - DynamicUser = true; - } else {}; + serviceConfig = + if user == "static-user" then + { + User = "chroot-testuser"; + Group = "chroot-testgroup"; + } + else if user == "dynamic-user" then + { + DynamicUser = true; + } + else + { }; - in [ - { description = "${user}, chroot-only confinement ${withTmp}"; - config = { - confinement.mode = "chroot-only"; - # Only set if privateTmp is true to ensure that the default is false. - serviceConfig = serviceConfig // lib.optionalAttrs privateTmp { - PrivateTmp = true; - }; - }; - testScript = if user == "root" then '' - assert os.getuid() == 0 - assert os.getgid() == 0 + in + [ + { + description = "${user}, chroot-only confinement ${withTmp}"; + config = { + confinement.mode = "chroot-only"; + # Only set if privateTmp is true to ensure that the default is false. + serviceConfig = + serviceConfig + // lib.optionalAttrs privateTmp { + PrivateTmp = true; + }; + }; + testScript = + if user == "root" then + '' + assert os.getuid() == 0 + assert os.getgid() == 0 - assert_permissions({ - 'bin': Accessibility.READABLE, - 'nix': Accessibility.READABLE, - 'run': Accessibility.READABLE, - ${lib.optionalString privateTmp "'tmp': Accessibility.STICKY,"} - ${lib.optionalString privateTmp "'var': Accessibility.READABLE,"} - ${lib.optionalString privateTmp "'var/tmp': Accessibility.STICKY,"} - }) - '' else '' - assert os.getuid() != 0 - assert os.getgid() != 0 + assert_permissions({ + 'bin': Accessibility.READABLE, + 'nix': Accessibility.READABLE, + 'run': Accessibility.READABLE, + ${lib.optionalString privateTmp "'tmp': Accessibility.STICKY,"} + ${lib.optionalString privateTmp "'var': Accessibility.READABLE,"} + ${lib.optionalString privateTmp "'var/tmp': Accessibility.STICKY,"} + }) + '' + else + '' + assert os.getuid() != 0 + assert os.getgid() != 0 - assert_permissions({ - 'bin': Accessibility.READABLE, - 'nix': Accessibility.READABLE, - 'run': Accessibility.READABLE, - ${lib.optionalString privateTmp "'tmp': Accessibility.STICKY,"} - ${lib.optionalString privateTmp "'var': Accessibility.READABLE,"} - ${lib.optionalString privateTmp "'var/tmp': Accessibility.STICKY,"} - }) - ''; - } - { description = "${user}, full APIVFS confinement ${withTmp}"; - config = { - # Only set if privateTmp is false to ensure that the default is true. - serviceConfig = serviceConfig // lib.optionalAttrs (!privateTmp) { - PrivateTmp = false; - }; - }; - testScript = if user == "root" then '' - assert os.getuid() == 0 - assert os.getgid() == 0 + assert_permissions({ + 'bin': Accessibility.READABLE, + 'nix': Accessibility.READABLE, + 'run': Accessibility.READABLE, + ${lib.optionalString privateTmp "'tmp': Accessibility.STICKY,"} + ${lib.optionalString privateTmp "'var': Accessibility.READABLE,"} + ${lib.optionalString privateTmp "'var/tmp': Accessibility.STICKY,"} + }) + ''; + } + { + description = "${user}, full APIVFS confinement ${withTmp}"; + config = { + # Only set if privateTmp is false to ensure that the default is true. + serviceConfig = + serviceConfig + // lib.optionalAttrs (!privateTmp) { + PrivateTmp = false; + }; + }; + testScript = + if user == "root" then + '' + assert os.getuid() == 0 + assert os.getgid() == 0 - assert_permissions({ - 'bin': Accessibility.READABLE, - 'nix': Accessibility.READABLE, - ${lib.optionalString privateTmp "'tmp': Accessibility.STICKY,"} - 'run': Accessibility.WRITABLE, + assert_permissions({ + 'bin': Accessibility.READABLE, + 'nix': Accessibility.READABLE, + ${lib.optionalString privateTmp "'tmp': Accessibility.STICKY,"} + 'run': Accessibility.WRITABLE, - 'proc': Accessibility.SPECIAL, - 'sys': Accessibility.SPECIAL, - 'dev': Accessibility.WRITABLE, + 'proc': Accessibility.SPECIAL, + 'sys': Accessibility.SPECIAL, + 'dev': Accessibility.WRITABLE, - ${lib.optionalString privateTmp "'var': Accessibility.READABLE,"} - ${lib.optionalString privateTmp "'var/tmp': Accessibility.STICKY,"} - }) - '' else '' - assert os.getuid() != 0 - assert os.getgid() != 0 + ${lib.optionalString privateTmp "'var': Accessibility.READABLE,"} + ${lib.optionalString privateTmp "'var/tmp': Accessibility.STICKY,"} + }) + '' + else + '' + assert os.getuid() != 0 + assert os.getgid() != 0 - assert_permissions({ - 'bin': Accessibility.READABLE, - 'nix': Accessibility.READABLE, - ${lib.optionalString privateTmp "'tmp': Accessibility.STICKY,"} - 'run': Accessibility.STICKY, + assert_permissions({ + 'bin': Accessibility.READABLE, + 'nix': Accessibility.READABLE, + ${lib.optionalString privateTmp "'tmp': Accessibility.STICKY,"} + 'run': Accessibility.STICKY, - 'proc': Accessibility.SPECIAL, - 'sys': Accessibility.SPECIAL, - 'dev': Accessibility.SPECIAL, - 'dev/shm': Accessibility.STICKY, - 'dev/mqueue': Accessibility.STICKY, + 'proc': Accessibility.SPECIAL, + 'sys': Accessibility.SPECIAL, + 'dev': Accessibility.SPECIAL, + 'dev/shm': Accessibility.STICKY, + 'dev/mqueue': Accessibility.STICKY, - ${lib.optionalString privateTmp "'var': Accessibility.READABLE,"} - ${lib.optionalString privateTmp "'var/tmp': Accessibility.STICKY,"} - }) - ''; - } - ]) (lib.cartesianProduct { - user = [ "root" "dynamic-user" "static-user" ]; - privateTmp = [ true false ]; - }); + ${lib.optionalString privateTmp "'var': Accessibility.READABLE,"} + ${lib.optionalString privateTmp "'var/tmp': Accessibility.STICKY,"} + }) + ''; + } + ] + ) + ( + lib.cartesianProduct { + user = [ + "root" + "dynamic-user" + "static-user" + ]; + privateTmp = [ + true + false + ]; + } + ); - in { - imports = lib.imap1 mkTestStep (parametrisedTests ++ [ - { description = "existence of bind-mounted /etc"; - config.serviceConfig.BindReadOnlyPaths = [ "/etc" ]; - testScript = '' - assert Path('/etc/passwd').read_text() - ''; - } - (let - symlink = pkgs.runCommand "symlink" { - target = pkgs.writeText "symlink-target" "got me"; - } "ln -s \"$target\" \"$out\""; - in { - description = "check if symlinks are properly bind-mounted"; - config.confinement.packages = lib.singleton symlink; - testScript = '' - assert Path('${symlink}').read_text() == 'got me' - ''; - }) - { description = "check if StateDirectory works"; - config.serviceConfig.User = "chroot-testuser"; - config.serviceConfig.Group = "chroot-testgroup"; - config.serviceConfig.StateDirectory = "testme"; + in + { + imports = lib.imap1 mkTestStep ( + parametrisedTests + ++ [ + { + description = "existence of bind-mounted /etc"; + config.serviceConfig.BindReadOnlyPaths = [ "/etc" ]; + testScript = '' + assert Path('/etc/passwd').read_text() + ''; + } + ( + let + symlink = pkgs.runCommand "symlink" { + target = pkgs.writeText "symlink-target" "got me"; + } "ln -s \"$target\" \"$out\""; + in + { + description = "check if symlinks are properly bind-mounted"; + config.confinement.packages = lib.singleton symlink; + testScript = '' + assert Path('${symlink}').read_text() == 'got me' + ''; + } + ) + { + description = "check if StateDirectory works"; + config.serviceConfig.User = "chroot-testuser"; + config.serviceConfig.Group = "chroot-testgroup"; + config.serviceConfig.StateDirectory = "testme"; - # We restart on purpose here since we want to check whether the state - # directory actually persists. - config.serviceConfig.Restart = "on-failure"; - config.serviceConfig.RestartMode = "direct"; + # We restart on purpose here since we want to check whether the state + # directory actually persists. + config.serviceConfig.Restart = "on-failure"; + config.serviceConfig.RestartMode = "direct"; - testScript = '' - assert not Path('/tmp/canary').exists() - Path('/tmp/canary').touch() + testScript = '' + assert not Path('/tmp/canary').exists() + Path('/tmp/canary').touch() - if (foo := Path('/var/lib/testme/foo')).exists(): - assert Path('/var/lib/testme/foo').read_text() == 'works' - else: - Path('/var/lib/testme/foo').write_text('works') - print('<4>Exiting with failure to check persistence on restart.') - raise SystemExit(1) - ''; - } - { description = "check if /bin/sh works"; - testScript = '' - assert Path('/bin/sh').exists() + if (foo := Path('/var/lib/testme/foo')).exists(): + assert Path('/var/lib/testme/foo').read_text() == 'works' + else: + Path('/var/lib/testme/foo').write_text('works') + print('<4>Exiting with failure to check persistence on restart.') + raise SystemExit(1) + ''; + } + { + description = "check if /bin/sh works"; + testScript = '' + assert Path('/bin/sh').exists() - result = run( - ['/bin/sh', '-c', 'echo -n bar'], - capture_output=True, - check=True, - ) - assert result.stdout == b'bar' - ''; - } - { description = "check if suppressing /bin/sh works"; - config.confinement.binSh = null; - testScript = '' - assert not Path('/bin/sh').exists() - with pytest.raises(FileNotFoundError): - run(['/bin/sh', '-c', 'echo foo']) - ''; - } - { description = "check if we can set /bin/sh to something different"; - config.confinement.binSh = "${pkgs.hello}/bin/hello"; - testScript = '' - assert Path('/bin/sh').exists() - result = run( - ['/bin/sh', '-g', 'foo'], - capture_output=True, - check=True, - ) - assert result.stdout == b'foo\n' - ''; - } - { description = "check if only Exec* dependencies are included"; - config.environment.FOOBAR = pkgs.writeText "foobar" "eek"; - testScript = '' - with pytest.raises(FileNotFoundError): - Path(os.environ['FOOBAR']).read_text() - ''; - } - { description = "check if fullUnit includes all dependencies"; - config.environment.FOOBAR = pkgs.writeText "foobar" "eek"; - config.confinement.fullUnit = true; - testScript = '' - assert Path(os.environ['FOOBAR']).read_text() == 'eek' - ''; - } - { description = "check if shipped unit file still works"; - config.confinement.mode = "chroot-only"; - rawUnit = '' - [Service] - SystemCallFilter=~kill - SystemCallErrorNumber=ELOOP - ''; - testScript = '' - with pytest.raises(OSError) as excinfo: - os.kill(os.getpid(), signal.SIGKILL) - assert excinfo.value.errno == errno.ELOOP - ''; - } - ]); + result = run( + ['/bin/sh', '-c', 'echo -n bar'], + capture_output=True, + check=True, + ) + assert result.stdout == b'bar' + ''; + } + { + description = "check if suppressing /bin/sh works"; + config.confinement.binSh = null; + testScript = '' + assert not Path('/bin/sh').exists() + with pytest.raises(FileNotFoundError): + run(['/bin/sh', '-c', 'echo foo']) + ''; + } + { + description = "check if we can set /bin/sh to something different"; + config.confinement.binSh = "${pkgs.hello}/bin/hello"; + testScript = '' + assert Path('/bin/sh').exists() + result = run( + ['/bin/sh', '-g', 'foo'], + capture_output=True, + check=True, + ) + assert result.stdout == b'foo\n' + ''; + } + { + description = "check if only Exec* dependencies are included"; + config.environment.FOOBAR = pkgs.writeText "foobar" "eek"; + testScript = '' + with pytest.raises(FileNotFoundError): + Path(os.environ['FOOBAR']).read_text() + ''; + } + { + description = "check if fullUnit includes all dependencies"; + config.environment.FOOBAR = pkgs.writeText "foobar" "eek"; + config.confinement.fullUnit = true; + testScript = '' + assert Path(os.environ['FOOBAR']).read_text() == 'eek' + ''; + } + { + description = "check if shipped unit file still works"; + config.confinement.mode = "chroot-only"; + rawUnit = '' + [Service] + SystemCallFilter=~kill + SystemCallErrorNumber=ELOOP + ''; + testScript = '' + with pytest.raises(OSError) as excinfo: + os.kill(os.getpid(), signal.SIGKILL) + assert excinfo.value.errno == errno.ELOOP + ''; + } + ] + ); - config.users.groups.chroot-testgroup = {}; - config.users.users.chroot-testuser = { - isSystemUser = true; - description = "Chroot Test User"; - group = "chroot-testgroup"; + config.users.groups.chroot-testgroup = { }; + config.users.users.chroot-testuser = { + isSystemUser = true; + description = "Chroot Test User"; + group = "chroot-testgroup"; + }; }; - }; testScript = '' machine.wait_for_unit("multi-user.target") diff --git a/nixos/tests/systemd-coredump.nix b/nixos/tests/systemd-coredump.nix index 62137820878bda..06888682e138c0 100644 --- a/nixos/tests/systemd-coredump.nix +++ b/nixos/tests/systemd-coredump.nix @@ -1,44 +1,48 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -let + let - crasher = pkgs.writeCBin "crasher" "int main;"; + crasher = pkgs.writeCBin "crasher" "int main;"; - commonConfig = { - systemd.services.crasher.serviceConfig = { - ExecStart = "${crasher}/bin/crasher"; - StateDirectory = "crasher"; - WorkingDirectory = "%S/crasher"; - Restart = "no"; + commonConfig = { + systemd.services.crasher.serviceConfig = { + ExecStart = "${crasher}/bin/crasher"; + StateDirectory = "crasher"; + WorkingDirectory = "%S/crasher"; + Restart = "no"; + }; }; - }; -in + in -{ - name = "systemd-coredump"; - meta = with pkgs.lib.maintainers; { - maintainers = [ squalus ]; - }; - - nodes.machine1 = { pkgs, lib, ... }: commonConfig; - nodes.machine2 = { pkgs, lib, ... }: lib.recursiveUpdate commonConfig { - systemd.coredump.enable = false; - systemd.package = pkgs.systemd.override { - withCoredump = false; + { + name = "systemd-coredump"; + meta = with pkgs.lib.maintainers; { + maintainers = [ squalus ]; }; - }; - - testScript = '' - with subtest("systemd-coredump enabled"): - machine1.wait_for_unit("multi-user.target") - machine1.wait_for_unit("systemd-coredump.socket") - machine1.systemctl("start crasher"); - machine1.wait_until_succeeds("coredumpctl list | grep crasher", timeout=10) - machine1.fail("stat /var/lib/crasher/core") - - with subtest("systemd-coredump disabled"): - machine2.systemctl("start crasher"); - machine2.wait_until_succeeds("stat /var/lib/crasher/core", timeout=10) - ''; -}) + + nodes.machine1 = { pkgs, lib, ... }: commonConfig; + nodes.machine2 = + { pkgs, lib, ... }: + lib.recursiveUpdate commonConfig { + systemd.coredump.enable = false; + systemd.package = pkgs.systemd.override { + withCoredump = false; + }; + }; + + testScript = '' + with subtest("systemd-coredump enabled"): + machine1.wait_for_unit("multi-user.target") + machine1.wait_for_unit("systemd-coredump.socket") + machine1.systemctl("start crasher"); + machine1.wait_until_succeeds("coredumpctl list | grep crasher", timeout=10) + machine1.fail("stat /var/lib/crasher/core") + + with subtest("systemd-coredump disabled"): + machine2.systemctl("start crasher"); + machine2.wait_until_succeeds("stat /var/lib/crasher/core", timeout=10) + ''; + } +) diff --git a/nixos/tests/systemd-credentials-tpm2.nix b/nixos/tests/systemd-credentials-tpm2.nix index bf74183122368c..085d05d4b9264f 100644 --- a/nixos/tests/systemd-credentials-tpm2.nix +++ b/nixos/tests/systemd-credentials-tpm2.nix @@ -1,69 +1,73 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -{ - name = "systemd-credentials-tpm2"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "systemd-credentials-tpm2"; - meta = { - maintainers = with pkgs.lib.maintainers; [ tmarkus ]; - }; + meta = { + maintainers = with pkgs.lib.maintainers; [ tmarkus ]; + }; - nodes.machine = { pkgs, ... }: { - virtualisation.tpm.enable = true; - environment.systemPackages = with pkgs; [ diffutils ]; - }; + nodes.machine = + { pkgs, ... }: + { + virtualisation.tpm.enable = true; + environment.systemPackages = with pkgs; [ diffutils ]; + }; - testScript = '' - CRED_NAME = "testkey" - CRED_RAW_FILE = f"/root/{CRED_NAME}" - CRED_FILE = f"/root/{CRED_NAME}.cred" + testScript = '' + CRED_NAME = "testkey" + CRED_RAW_FILE = f"/root/{CRED_NAME}" + CRED_FILE = f"/root/{CRED_NAME}.cred" - def systemd_run(machine, cmd): - machine.log(f"Executing command (via systemd-run): \"{cmd}\"") + def systemd_run(machine, cmd): + machine.log(f"Executing command (via systemd-run): \"{cmd}\"") - (status, out) = machine.execute( " ".join([ - "systemd-run", - "--service-type=exec", - "--quiet", - "--wait", - "-E PATH=\"$PATH\"", - "-p StandardOutput=journal", - "-p StandardError=journal", - f"-p LoadCredentialEncrypted={CRED_NAME}:{CRED_FILE}", - f"$SHELL -c '{cmd}'" - ]) ) + (status, out) = machine.execute( " ".join([ + "systemd-run", + "--service-type=exec", + "--quiet", + "--wait", + "-E PATH=\"$PATH\"", + "-p StandardOutput=journal", + "-p StandardError=journal", + f"-p LoadCredentialEncrypted={CRED_NAME}:{CRED_FILE}", + f"$SHELL -c '{cmd}'" + ]) ) - if status != 0: - raise Exception(f"systemd_run failed (status {status})") + if status != 0: + raise Exception(f"systemd_run failed (status {status})") - machine.log("systemd-run finished successfully") + machine.log("systemd-run finished successfully") - machine.wait_for_unit("multi-user.target") + machine.wait_for_unit("multi-user.target") - with subtest("Check whether TPM device exists"): - machine.succeed("test -e /dev/tpm0") - machine.succeed("test -e /dev/tpmrm0") + with subtest("Check whether TPM device exists"): + machine.succeed("test -e /dev/tpm0") + machine.succeed("test -e /dev/tpmrm0") - with subtest("Check whether systemd-creds detects TPM2 correctly"): - cmd = "systemd-creds has-tpm2" - machine.log(f"Running \"{cmd}\"") - (status, _) = machine.execute(cmd) + with subtest("Check whether systemd-creds detects TPM2 correctly"): + cmd = "systemd-creds has-tpm2" + machine.log(f"Running \"{cmd}\"") + (status, _) = machine.execute(cmd) - # Check exit code equals 0 or 1 (1 means firmware support is missing, which is OK here) - if status != 0 and status != 1: - raise Exception("systemd-creds failed to detect TPM2") + # Check exit code equals 0 or 1 (1 means firmware support is missing, which is OK here) + if status != 0 and status != 1: + raise Exception("systemd-creds failed to detect TPM2") - with subtest("Encrypt credential using systemd-creds"): - machine.succeed(f"dd if=/dev/urandom of={CRED_RAW_FILE} bs=1k count=16") - machine.succeed(f"systemd-creds --with-key=host+tpm2 encrypt --name=testkey {CRED_RAW_FILE} {CRED_FILE}") + with subtest("Encrypt credential using systemd-creds"): + machine.succeed(f"dd if=/dev/urandom of={CRED_RAW_FILE} bs=1k count=16") + machine.succeed(f"systemd-creds --with-key=host+tpm2 encrypt --name=testkey {CRED_RAW_FILE} {CRED_FILE}") - with subtest("Write provided credential and check for equality"): - CRED_OUT_FILE = f"/root/{CRED_NAME}.out" - systemd_run(machine, f"systemd-creds cat testkey > {CRED_OUT_FILE}") - machine.succeed(f"cmp --silent -- {CRED_RAW_FILE} {CRED_OUT_FILE}") + with subtest("Write provided credential and check for equality"): + CRED_OUT_FILE = f"/root/{CRED_NAME}.out" + systemd_run(machine, f"systemd-creds cat testkey > {CRED_OUT_FILE}") + machine.succeed(f"cmp --silent -- {CRED_RAW_FILE} {CRED_OUT_FILE}") - with subtest("Check whether systemd service can see credential in systemd-creds list"): - systemd_run(machine, f"systemd-creds list | grep {CRED_NAME}") + with subtest("Check whether systemd service can see credential in systemd-creds list"): + systemd_run(machine, f"systemd-creds list | grep {CRED_NAME}") - with subtest("Check whether systemd service can access credential in $CREDENTIALS_DIRECTORY"): - systemd_run(machine, f"cmp --silent -- $CREDENTIALS_DIRECTORY/{CRED_NAME} {CRED_RAW_FILE}") - ''; -}) + with subtest("Check whether systemd service can access credential in $CREDENTIALS_DIRECTORY"): + systemd_run(machine, f"cmp --silent -- $CREDENTIALS_DIRECTORY/{CRED_NAME} {CRED_RAW_FILE}") + ''; + } +) diff --git a/nixos/tests/systemd-cryptenroll.nix b/nixos/tests/systemd-cryptenroll.nix index 034aae1d5e9559..c8773888c086bb 100644 --- a/nixos/tests/systemd-cryptenroll.nix +++ b/nixos/tests/systemd-cryptenroll.nix @@ -1,41 +1,45 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "systemd-cryptenroll"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ymatsiuk ]; - }; - - nodes.machine = { pkgs, lib, ... }: { - environment.systemPackages = [ pkgs.cryptsetup ]; - virtualisation = { - emptyDiskImages = [ 512 ]; - tpm.enable = true; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "systemd-cryptenroll"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ymatsiuk ]; }; - }; - testScript = '' - machine.start() + nodes.machine = + { pkgs, lib, ... }: + { + environment.systemPackages = [ pkgs.cryptsetup ]; + virtualisation = { + emptyDiskImages = [ 512 ]; + tpm.enable = true; + }; + }; - # Verify the TPM device is available and accessible by systemd-cryptenroll - machine.succeed("test -e /dev/tpm0") - machine.succeed("test -e /dev/tpmrm0") - machine.succeed("systemd-cryptenroll --tpm2-device=list") + testScript = '' + machine.start() - # Create LUKS partition - machine.succeed("echo -n lukspass | cryptsetup luksFormat -q /dev/vdb -") - # Enroll new LUKS key and bind it to Secure Boot state - # For more details on PASSWORD variable, check the following issue: - # https://github.com/systemd/systemd/issues/20955 - machine.succeed("PASSWORD=lukspass systemd-cryptenroll --tpm2-device=auto --tpm2-pcrs=7 /dev/vdb") - # Add LUKS partition to /etc/crypttab to test auto unlock - machine.succeed("echo 'luks /dev/vdb - tpm2-device=auto' >> /etc/crypttab") + # Verify the TPM device is available and accessible by systemd-cryptenroll + machine.succeed("test -e /dev/tpm0") + machine.succeed("test -e /dev/tpmrm0") + machine.succeed("systemd-cryptenroll --tpm2-device=list") - machine.shutdown() - machine.start() + # Create LUKS partition + machine.succeed("echo -n lukspass | cryptsetup luksFormat -q /dev/vdb -") + # Enroll new LUKS key and bind it to Secure Boot state + # For more details on PASSWORD variable, check the following issue: + # https://github.com/systemd/systemd/issues/20955 + machine.succeed("PASSWORD=lukspass systemd-cryptenroll --tpm2-device=auto --tpm2-pcrs=7 /dev/vdb") + # Add LUKS partition to /etc/crypttab to test auto unlock + machine.succeed("echo 'luks /dev/vdb - tpm2-device=auto' >> /etc/crypttab") - # Test LUKS partition automatic unlock on boot - machine.wait_for_unit("systemd-cryptsetup@luks.service") - # Wipe TPM2 slot - machine.succeed("systemd-cryptenroll --wipe-slot=tpm2 /dev/vdb") - ''; -}) + machine.shutdown() + machine.start() + # Test LUKS partition automatic unlock on boot + machine.wait_for_unit("systemd-cryptsetup@luks.service") + # Wipe TPM2 slot + machine.succeed("systemd-cryptenroll --wipe-slot=tpm2 /dev/vdb") + ''; + } +) diff --git a/nixos/tests/systemd-escaping.nix b/nixos/tests/systemd-escaping.nix index 29d2ed1aa35232..1eeb7dbe6090da 100644 --- a/nixos/tests/systemd-escaping.nix +++ b/nixos/tests/systemd-escaping.nix @@ -1,45 +1,63 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -let - echoAll = pkgs.writeScript "echo-all" '' - #! ${pkgs.runtimeShell} - for s in "$@"; do - printf '%s\n' "$s" - done - ''; - # deliberately using a local empty file instead of pkgs.emptyFile to have - # a non-store path in the test - args = [ "a%Nything" "lang=\${LANG}" ";" "/bin/sh -c date" ./empty-file 4.2 23 ]; -in -{ - name = "systemd-escaping"; + let + echoAll = pkgs.writeScript "echo-all" '' + #! ${pkgs.runtimeShell} + for s in "$@"; do + printf '%s\n' "$s" + done + ''; + # deliberately using a local empty file instead of pkgs.emptyFile to have + # a non-store path in the test + args = [ + "a%Nything" + "lang=\${LANG}" + ";" + "/bin/sh -c date" + ./empty-file + 4.2 + 23 + ]; + in + { + name = "systemd-escaping"; - nodes.machine = { pkgs, lib, utils, ... }: { - systemd.services.echo = - assert !(builtins.tryEval (utils.escapeSystemdExecArgs [ [] ])).success; - assert !(builtins.tryEval (utils.escapeSystemdExecArgs [ {} ])).success; - assert !(builtins.tryEval (utils.escapeSystemdExecArgs [ null ])).success; - assert !(builtins.tryEval (utils.escapeSystemdExecArgs [ false ])).success; - assert !(builtins.tryEval (utils.escapeSystemdExecArgs [ (_:_) ])).success; - { description = "Echo to the journal"; - serviceConfig.Type = "oneshot"; - serviceConfig.ExecStart = '' - ${echoAll} ${utils.escapeSystemdExecArgs args} - ''; + nodes.machine = + { + pkgs, + lib, + utils, + ... + }: + { + systemd.services.echo = + assert !(builtins.tryEval (utils.escapeSystemdExecArgs [ [ ] ])).success; + assert !(builtins.tryEval (utils.escapeSystemdExecArgs [ { } ])).success; + assert !(builtins.tryEval (utils.escapeSystemdExecArgs [ null ])).success; + assert !(builtins.tryEval (utils.escapeSystemdExecArgs [ false ])).success; + assert !(builtins.tryEval (utils.escapeSystemdExecArgs [ (_: _) ])).success; + { + description = "Echo to the journal"; + serviceConfig.Type = "oneshot"; + serviceConfig.ExecStart = '' + ${echoAll} ${utils.escapeSystemdExecArgs args} + ''; + }; }; - }; - testScript = '' - machine.wait_for_unit("multi-user.target") - machine.succeed("systemctl start echo.service") - # skip the first 'Starting <service> ...' line - logs = machine.succeed("journalctl -u echo.service -o cat").splitlines()[1:] - assert "a%Nything" == logs[0] - assert "lang=''${LANG}" == logs[1] - assert ";" == logs[2] - assert "/bin/sh -c date" == logs[3] - assert "/nix/store/ij3gw72f4n5z4dz6nnzl1731p9kmjbwr-empty-file" == logs[4] - assert "4.2" in logs[5] # toString produces extra fractional digits! - assert "23" == logs[6] - ''; -}) + testScript = '' + machine.wait_for_unit("multi-user.target") + machine.succeed("systemctl start echo.service") + # skip the first 'Starting <service> ...' line + logs = machine.succeed("journalctl -u echo.service -o cat").splitlines()[1:] + assert "a%Nything" == logs[0] + assert "lang=''${LANG}" == logs[1] + assert ";" == logs[2] + assert "/bin/sh -c date" == logs[3] + assert "/nix/store/ij3gw72f4n5z4dz6nnzl1731p9kmjbwr-empty-file" == logs[4] + assert "4.2" in logs[5] # toString produces extra fractional digits! + assert "23" == logs[6] + ''; + } +) diff --git a/nixos/tests/systemd-homed.nix b/nixos/tests/systemd-homed.nix index 5e723f67694521..b31f66cdd1c804 100644 --- a/nixos/tests/systemd-homed.nix +++ b/nixos/tests/systemd-homed.nix @@ -1,99 +1,103 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - password = "foobarfoo"; - newPass = "barfoobar"; -in -{ - name = "systemd-homed"; - nodes.machine = { config, pkgs, ... }: { - services.homed.enable = true; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + password = "foobarfoo"; + newPass = "barfoobar"; + in + { + name = "systemd-homed"; + nodes.machine = + { config, pkgs, ... }: + { + services.homed.enable = true; - users.users.test-normal-user = { - extraGroups = [ "wheel" ]; - isNormalUser = true; - initialPassword = password; - }; - }; - testScript = '' - def switchTTY(number): - machine.send_key(f"alt-f{number}") - machine.wait_until_succeeds(f"[ $(fgconsole) = {number} ]") - machine.wait_for_unit(f"getty@tty{number}.service") - machine.wait_until_succeeds(f"pgrep -f 'agetty.*tty{number}'") + users.users.test-normal-user = { + extraGroups = [ "wheel" ]; + isNormalUser = true; + initialPassword = password; + }; + }; + testScript = '' + def switchTTY(number): + machine.send_key(f"alt-f{number}") + machine.wait_until_succeeds(f"[ $(fgconsole) = {number} ]") + machine.wait_for_unit(f"getty@tty{number}.service") + machine.wait_until_succeeds(f"pgrep -f 'agetty.*tty{number}'") - machine.wait_for_unit("multi-user.target") + machine.wait_for_unit("multi-user.target") - # Smoke test to make sure the pam changes didn't break regular users. - machine.wait_until_succeeds("pgrep -f 'agetty.*tty1'") - with subtest("login as regular user"): - switchTTY(2) - machine.wait_until_tty_matches("2", "login: ") - machine.send_chars("test-normal-user\n") - machine.wait_until_tty_matches("2", "login: test-normal-user") - machine.wait_until_tty_matches("2", "Password: ") - machine.send_chars("${password}\n") - machine.wait_until_succeeds("pgrep -u test-normal-user bash") - machine.send_chars("whoami > /tmp/1\n") - machine.wait_for_file("/tmp/1") - assert "test-normal-user" in machine.succeed("cat /tmp/1") - - with subtest("create homed encrypted user"): - # TODO: Figure out how to pass password manually. - # - # This environment variable is used for homed internal testing - # and is not documented. - machine.succeed("NEWPASSWORD=${password} homectl create --shell=/run/current-system/sw/bin/bash --storage=luks -G wheel test-homed-user") - - with subtest("login as homed user"): - switchTTY(3) - machine.wait_until_tty_matches("3", "login: ") - machine.send_chars("test-homed-user\n") - machine.wait_until_tty_matches("3", "login: test-homed-user") - machine.wait_until_tty_matches("3", "Password: ") - machine.send_chars("${password}\n") - machine.wait_until_succeeds("pgrep -t tty3 -u test-homed-user bash") - machine.send_chars("whoami > /tmp/2\n") - machine.wait_for_file("/tmp/2") - assert "test-homed-user" in machine.succeed("cat /tmp/2") + # Smoke test to make sure the pam changes didn't break regular users. + machine.wait_until_succeeds("pgrep -f 'agetty.*tty1'") + with subtest("login as regular user"): + switchTTY(2) + machine.wait_until_tty_matches("2", "login: ") + machine.send_chars("test-normal-user\n") + machine.wait_until_tty_matches("2", "login: test-normal-user") + machine.wait_until_tty_matches("2", "Password: ") + machine.send_chars("${password}\n") + machine.wait_until_succeeds("pgrep -u test-normal-user bash") + machine.send_chars("whoami > /tmp/1\n") + machine.wait_for_file("/tmp/1") + assert "test-normal-user" in machine.succeed("cat /tmp/1") - with subtest("change homed user password"): - switchTTY(4) - machine.wait_until_tty_matches("4", "login: ") - machine.send_chars("test-homed-user\n") - machine.wait_until_tty_matches("4", "login: test-homed-user") - machine.wait_until_tty_matches("4", "Password: ") - machine.send_chars("${password}\n") - machine.wait_until_succeeds("pgrep -t tty4 -u test-homed-user bash") - machine.send_chars("passwd\n") - # homed does it in a weird order, it asks for new passes, then it asks - # for the old one. - machine.sleep(2) - machine.send_chars("${newPass}\n") - machine.sleep(2) - machine.send_chars("${newPass}\n") - machine.sleep(4) - machine.send_chars("${password}\n") - machine.wait_until_fails("pgrep -t tty4 passwd") + with subtest("create homed encrypted user"): + # TODO: Figure out how to pass password manually. + # + # This environment variable is used for homed internal testing + # and is not documented. + machine.succeed("NEWPASSWORD=${password} homectl create --shell=/run/current-system/sw/bin/bash --storage=luks -G wheel test-homed-user") - @polling_condition - def not_logged_in_tty5(): - machine.fail("pgrep -t tty5 bash") + with subtest("login as homed user"): + switchTTY(3) + machine.wait_until_tty_matches("3", "login: ") + machine.send_chars("test-homed-user\n") + machine.wait_until_tty_matches("3", "login: test-homed-user") + machine.wait_until_tty_matches("3", "Password: ") + machine.send_chars("${password}\n") + machine.wait_until_succeeds("pgrep -t tty3 -u test-homed-user bash") + machine.send_chars("whoami > /tmp/2\n") + machine.wait_for_file("/tmp/2") + assert "test-homed-user" in machine.succeed("cat /tmp/2") - switchTTY(5) - with not_logged_in_tty5: # type: ignore[union-attr] - machine.wait_until_tty_matches("5", "login: ") + with subtest("change homed user password"): + switchTTY(4) + machine.wait_until_tty_matches("4", "login: ") machine.send_chars("test-homed-user\n") - machine.wait_until_tty_matches("5", "login: test-homed-user") - machine.wait_until_tty_matches("5", "Password: ") + machine.wait_until_tty_matches("4", "login: test-homed-user") + machine.wait_until_tty_matches("4", "Password: ") + machine.send_chars("${password}\n") + machine.wait_until_succeeds("pgrep -t tty4 -u test-homed-user bash") + machine.send_chars("passwd\n") + # homed does it in a weird order, it asks for new passes, then it asks + # for the old one. + machine.sleep(2) + machine.send_chars("${newPass}\n") + machine.sleep(2) + machine.send_chars("${newPass}\n") + machine.sleep(4) machine.send_chars("${password}\n") - machine.wait_until_tty_matches("5", "Password incorrect or not sufficient for authentication of user test-homed-user.") - machine.wait_until_tty_matches("5", "Sorry, try again: ") - machine.send_chars("${newPass}\n") - machine.send_chars("whoami > /tmp/4\n") - machine.wait_for_file("/tmp/4") - assert "test-homed-user" in machine.succeed("cat /tmp/4") + machine.wait_until_fails("pgrep -t tty4 passwd") + + @polling_condition + def not_logged_in_tty5(): + machine.fail("pgrep -t tty5 bash") + + switchTTY(5) + with not_logged_in_tty5: # type: ignore[union-attr] + machine.wait_until_tty_matches("5", "login: ") + machine.send_chars("test-homed-user\n") + machine.wait_until_tty_matches("5", "login: test-homed-user") + machine.wait_until_tty_matches("5", "Password: ") + machine.send_chars("${password}\n") + machine.wait_until_tty_matches("5", "Password incorrect or not sufficient for authentication of user test-homed-user.") + machine.wait_until_tty_matches("5", "Sorry, try again: ") + machine.send_chars("${newPass}\n") + machine.send_chars("whoami > /tmp/4\n") + machine.wait_for_file("/tmp/4") + assert "test-homed-user" in machine.succeed("cat /tmp/4") - with subtest("homed user should be in wheel according to NSS"): - machine.succeed("userdbctl group wheel -s io.systemd.NameServiceSwitch | grep test-homed-user") - ''; -}) + with subtest("homed user should be in wheel according to NSS"): + machine.succeed("userdbctl group wheel -s io.systemd.NameServiceSwitch | grep test-homed-user") + ''; + } +) diff --git a/nixos/tests/systemd-initrd-bridge.nix b/nixos/tests/systemd-initrd-bridge.nix index f48a46ff2b9396..7ca3a6a93a0065 100644 --- a/nixos/tests/systemd-initrd-bridge.nix +++ b/nixos/tests/systemd-initrd-bridge.nix @@ -1,63 +1,80 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "systemd-initrd-bridge"; - meta.maintainers = [ lib.maintainers.majiir ]; - - # Tests bridge interface configuration in systemd-initrd. - # - # The 'a' and 'b' nodes are connected to a 'bridge' node through different - # links. The 'bridge' node configures a bridge across them. It waits forever - # in initrd (stage 1) with networking enabled. 'a' and 'b' ping 'bridge' to - # test connectivity with the bridge interface. Then, 'a' pings 'b' to test - # the bridge itself. - - nodes = { - bridge = { config, lib, ... }: { - boot.initrd.systemd.enable = true; - boot.initrd.network.enable = true; - boot.initrd.systemd.services.boot-blocker = { - before = [ "initrd.target" ]; - wantedBy = [ "initrd.target" ]; - script = "sleep infinity"; - serviceConfig.Type = "oneshot"; - }; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "systemd-initrd-bridge"; + meta.maintainers = [ lib.maintainers.majiir ]; - networking.primaryIPAddress = "192.168.1.${toString config.virtualisation.test.nodeNumber}"; + # Tests bridge interface configuration in systemd-initrd. + # + # The 'a' and 'b' nodes are connected to a 'bridge' node through different + # links. The 'bridge' node configures a bridge across them. It waits forever + # in initrd (stage 1) with networking enabled. 'a' and 'b' ping 'bridge' to + # test connectivity with the bridge interface. Then, 'a' pings 'b' to test + # the bridge itself. - virtualisation.vlans = [ 1 2 ]; - networking.bridges.br0.interfaces = [ "eth1" "eth2" ]; + nodes = { + bridge = + { config, lib, ... }: + { + boot.initrd.systemd.enable = true; + boot.initrd.network.enable = true; + boot.initrd.systemd.services.boot-blocker = { + before = [ "initrd.target" ]; + wantedBy = [ "initrd.target" ]; + script = "sleep infinity"; + serviceConfig.Type = "oneshot"; + }; - networking.interfaces = { - eth1.ipv4.addresses = lib.mkForce []; - eth2.ipv4.addresses = lib.mkForce []; - br0.ipv4.addresses = [{ - address = config.networking.primaryIPAddress; - prefixLength = 24; - }]; - }; - }; + networking.primaryIPAddress = "192.168.1.${toString config.virtualisation.test.nodeNumber}"; - a = { - virtualisation.vlans = [ 1 ]; - }; + virtualisation.vlans = [ + 1 + 2 + ]; + networking.bridges.br0.interfaces = [ + "eth1" + "eth2" + ]; + + networking.interfaces = { + eth1.ipv4.addresses = lib.mkForce [ ]; + eth2.ipv4.addresses = lib.mkForce [ ]; + br0.ipv4.addresses = [ + { + address = config.networking.primaryIPAddress; + prefixLength = 24; + } + ]; + }; + }; + + a = { + virtualisation.vlans = [ 1 ]; + }; - b = { config, ... }: { - virtualisation.vlans = [ 2 ]; - networking.primaryIPAddress = lib.mkForce "192.168.1.${toString config.virtualisation.test.nodeNumber}"; - networking.interfaces.eth1.ipv4.addresses = lib.mkForce [{ - address = config.networking.primaryIPAddress; - prefixLength = 24; - }]; + b = + { config, ... }: + { + virtualisation.vlans = [ 2 ]; + networking.primaryIPAddress = lib.mkForce "192.168.1.${toString config.virtualisation.test.nodeNumber}"; + networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ + { + address = config.networking.primaryIPAddress; + prefixLength = 24; + } + ]; + }; }; - }; - testScript = '' - start_all() - a.wait_for_unit("network.target") - b.wait_for_unit("network.target") + testScript = '' + start_all() + a.wait_for_unit("network.target") + b.wait_for_unit("network.target") - a.succeed("ping -n -w 10 -c 1 bridge >&2") - b.succeed("ping -n -w 10 -c 1 bridge >&2") + a.succeed("ping -n -w 10 -c 1 bridge >&2") + b.succeed("ping -n -w 10 -c 1 bridge >&2") - a.succeed("ping -n -w 10 -c 1 b >&2") - ''; -}) + a.succeed("ping -n -w 10 -c 1 b >&2") + ''; + } +) diff --git a/nixos/tests/systemd-initrd-btrfs-raid.nix b/nixos/tests/systemd-initrd-btrfs-raid.nix index 9196033789cb80..75f9879628fae9 100644 --- a/nixos/tests/systemd-initrd-btrfs-raid.nix +++ b/nixos/tests/systemd-initrd-btrfs-raid.nix @@ -1,47 +1,55 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "systemd-initrd-btrfs-raid"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "systemd-initrd-btrfs-raid"; - nodes.machine = { pkgs, ... }: { - # Use systemd-boot - virtualisation = { - emptyDiskImages = [ 512 512 ]; - useBootLoader = true; - # Booting off the BTRFS RAID requires an available init script from the Nix store - mountHostNixStore = true; - useEFIBoot = true; - }; - boot.loader.systemd-boot.enable = true; - boot.loader.efi.canTouchEfiVariables = true; + nodes.machine = + { pkgs, ... }: + { + # Use systemd-boot + virtualisation = { + emptyDiskImages = [ + 512 + 512 + ]; + useBootLoader = true; + # Booting off the BTRFS RAID requires an available init script from the Nix store + mountHostNixStore = true; + useEFIBoot = true; + }; + boot.loader.systemd-boot.enable = true; + boot.loader.efi.canTouchEfiVariables = true; - environment.systemPackages = with pkgs; [ btrfs-progs ]; - boot.initrd.systemd = { - enable = true; - emergencyAccess = true; - }; + environment.systemPackages = with pkgs; [ btrfs-progs ]; + boot.initrd.systemd = { + enable = true; + emergencyAccess = true; + }; - specialisation.boot-btrfs-raid.configuration = { - fileSystems = lib.mkVMOverride { - "/".fsType = lib.mkForce "btrfs"; + specialisation.boot-btrfs-raid.configuration = { + fileSystems = lib.mkVMOverride { + "/".fsType = lib.mkForce "btrfs"; + }; + virtualisation.rootDevice = "/dev/vdb"; + }; }; - virtualisation.rootDevice = "/dev/vdb"; - }; - }; - testScript = '' - # Create RAID - machine.succeed("mkfs.btrfs -d raid0 /dev/vdb /dev/vdc") - machine.succeed("mkdir -p /mnt && mount /dev/vdb /mnt && echo hello > /mnt/test && umount /mnt") + testScript = '' + # Create RAID + machine.succeed("mkfs.btrfs -d raid0 /dev/vdb /dev/vdc") + machine.succeed("mkdir -p /mnt && mount /dev/vdb /mnt && echo hello > /mnt/test && umount /mnt") - # Boot from the RAID - machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-btrfs-raid.conf") - machine.succeed("sync") - machine.crash() - machine.wait_for_unit("multi-user.target") + # Boot from the RAID + machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-btrfs-raid.conf") + machine.succeed("sync") + machine.crash() + machine.wait_for_unit("multi-user.target") - # Ensure we have successfully booted from the RAID - assert "(initrd)" in machine.succeed("systemd-analyze") # booted with systemd in stage 1 - assert "/dev/vdb on / type btrfs" in machine.succeed("mount") - assert "hello" in machine.succeed("cat /test") - assert "Total devices 2" in machine.succeed("btrfs filesystem show") - ''; -}) + # Ensure we have successfully booted from the RAID + assert "(initrd)" in machine.succeed("systemd-analyze") # booted with systemd in stage 1 + assert "/dev/vdb on / type btrfs" in machine.succeed("mount") + assert "hello" in machine.succeed("cat /test") + assert "Total devices 2" in machine.succeed("btrfs filesystem show") + ''; + } +) diff --git a/nixos/tests/systemd-initrd-luks-fido2.nix b/nixos/tests/systemd-initrd-luks-fido2.nix index 4441ad061ee423..e681525c99f874 100644 --- a/nixos/tests/systemd-initrd-luks-fido2.nix +++ b/nixos/tests/systemd-initrd-luks-fido2.nix @@ -1,47 +1,55 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "systemd-initrd-luks-fido2"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "systemd-initrd-luks-fido2"; - nodes.machine = { pkgs, config, ... }: { - # Use systemd-boot - virtualisation = { - emptyDiskImages = [ 512 ]; - useBootLoader = true; - # Booting off the encrypted disk requires having a Nix store available for the init script - mountHostNixStore = true; - useEFIBoot = true; - qemu.options = [ "-device pci-ohci,id=usb-bus" "-device canokey,bus=usb-bus.0,file=/tmp/canokey-file" ]; - }; - boot.loader.systemd-boot.enable = true; + nodes.machine = + { pkgs, config, ... }: + { + # Use systemd-boot + virtualisation = { + emptyDiskImages = [ 512 ]; + useBootLoader = true; + # Booting off the encrypted disk requires having a Nix store available for the init script + mountHostNixStore = true; + useEFIBoot = true; + qemu.options = [ + "-device pci-ohci,id=usb-bus" + "-device canokey,bus=usb-bus.0,file=/tmp/canokey-file" + ]; + }; + boot.loader.systemd-boot.enable = true; - boot.initrd.systemd.enable = true; + boot.initrd.systemd.enable = true; - environment.systemPackages = with pkgs; [ cryptsetup ]; + environment.systemPackages = with pkgs; [ cryptsetup ]; - specialisation.boot-luks.configuration = { - boot.initrd.luks.devices = lib.mkVMOverride { - cryptroot = { - device = "/dev/vdb"; - crypttabExtraOpts = [ "fido2-device=auto" ]; + specialisation.boot-luks.configuration = { + boot.initrd.luks.devices = lib.mkVMOverride { + cryptroot = { + device = "/dev/vdb"; + crypttabExtraOpts = [ "fido2-device=auto" ]; + }; + }; + virtualisation.rootDevice = "/dev/mapper/cryptroot"; + virtualisation.fileSystems."/".autoFormat = true; }; }; - virtualisation.rootDevice = "/dev/mapper/cryptroot"; - virtualisation.fileSystems."/".autoFormat = true; - }; - }; - testScript = '' - # Create encrypted volume - machine.wait_for_unit("multi-user.target") - machine.succeed("echo -n supersecret | cryptsetup luksFormat -q --iter-time=1 /dev/vdb -") - machine.succeed("PASSWORD=supersecret SYSTEMD_LOG_LEVEL=debug systemd-cryptenroll --fido2-device=auto /dev/vdb |& systemd-cat") + testScript = '' + # Create encrypted volume + machine.wait_for_unit("multi-user.target") + machine.succeed("echo -n supersecret | cryptsetup luksFormat -q --iter-time=1 /dev/vdb -") + machine.succeed("PASSWORD=supersecret SYSTEMD_LOG_LEVEL=debug systemd-cryptenroll --fido2-device=auto /dev/vdb |& systemd-cat") - # Boot from the encrypted disk - machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks.conf") - machine.succeed("sync") - machine.crash() + # Boot from the encrypted disk + machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks.conf") + machine.succeed("sync") + machine.crash() - # Boot and decrypt the disk - machine.wait_for_unit("multi-user.target") - assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") - ''; -}) + # Boot and decrypt the disk + machine.wait_for_unit("multi-user.target") + assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") + ''; + } +) diff --git a/nixos/tests/systemd-initrd-luks-keyfile.nix b/nixos/tests/systemd-initrd-luks-keyfile.nix index 617c003484b9d6..22794c0dcd8526 100644 --- a/nixos/tests/systemd-initrd-luks-keyfile.nix +++ b/nixos/tests/systemd-initrd-luks-keyfile.nix @@ -1,56 +1,62 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: let - - keyfile = pkgs.writeText "luks-keyfile" '' - MIGHAoGBAJ4rGTSo/ldyjQypd0kuS7k2OSsmQYzMH6TNj3nQ/vIUjDn7fqa3slt2 - gV6EK3TmTbGc4tzC1v4SWx2m+2Bjdtn4Fs4wiBwn1lbRdC6i5ZYCqasTWIntWn+6 - FllUkMD5oqjOR/YcboxG8Z3B5sJuvTP9llsF+gnuveWih9dpbBr7AgEC - ''; - -in { - name = "systemd-initrd-luks-keyfile"; - - nodes.machine = { pkgs, ... }: { - # Use systemd-boot - virtualisation = { - emptyDiskImages = [ 512 ]; - useBootLoader = true; - # Necessary to boot off the encrypted disk because it requires a init script coming from the Nix store - mountHostNixStore = true; - useEFIBoot = true; - }; - boot.loader.systemd-boot.enable = true; - - environment.systemPackages = with pkgs; [ cryptsetup ]; - boot.initrd.systemd = { - enable = true; - emergencyAccess = true; - }; - - specialisation.boot-luks.configuration = { - boot.initrd.luks.devices = lib.mkVMOverride { - cryptroot = { - device = "/dev/vdb"; - keyFile = "/etc/cryptroot.key"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let + + keyfile = pkgs.writeText "luks-keyfile" '' + MIGHAoGBAJ4rGTSo/ldyjQypd0kuS7k2OSsmQYzMH6TNj3nQ/vIUjDn7fqa3slt2 + gV6EK3TmTbGc4tzC1v4SWx2m+2Bjdtn4Fs4wiBwn1lbRdC6i5ZYCqasTWIntWn+6 + FllUkMD5oqjOR/YcboxG8Z3B5sJuvTP9llsF+gnuveWih9dpbBr7AgEC + ''; + + in + { + name = "systemd-initrd-luks-keyfile"; + + nodes.machine = + { pkgs, ... }: + { + # Use systemd-boot + virtualisation = { + emptyDiskImages = [ 512 ]; + useBootLoader = true; + # Necessary to boot off the encrypted disk because it requires a init script coming from the Nix store + mountHostNixStore = true; + useEFIBoot = true; + }; + boot.loader.systemd-boot.enable = true; + + environment.systemPackages = with pkgs; [ cryptsetup ]; + boot.initrd.systemd = { + enable = true; + emergencyAccess = true; + }; + + specialisation.boot-luks.configuration = { + boot.initrd.luks.devices = lib.mkVMOverride { + cryptroot = { + device = "/dev/vdb"; + keyFile = "/etc/cryptroot.key"; + }; + }; + virtualisation.rootDevice = "/dev/mapper/cryptroot"; + virtualisation.fileSystems."/".autoFormat = true; + boot.initrd.secrets."/etc/cryptroot.key" = keyfile; }; }; - virtualisation.rootDevice = "/dev/mapper/cryptroot"; - virtualisation.fileSystems."/".autoFormat = true; - boot.initrd.secrets."/etc/cryptroot.key" = keyfile; - }; - }; - - testScript = '' - # Create encrypted volume - machine.wait_for_unit("multi-user.target") - machine.succeed("cryptsetup luksFormat -q --iter-time=1 -d ${keyfile} /dev/vdb") - - # Boot from the encrypted disk - machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks.conf") - machine.succeed("sync") - machine.crash() - - # Boot and decrypt the disk - machine.wait_for_unit("multi-user.target") - assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") - ''; -}) + + testScript = '' + # Create encrypted volume + machine.wait_for_unit("multi-user.target") + machine.succeed("cryptsetup luksFormat -q --iter-time=1 -d ${keyfile} /dev/vdb") + + # Boot from the encrypted disk + machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks.conf") + machine.succeed("sync") + machine.crash() + + # Boot and decrypt the disk + machine.wait_for_unit("multi-user.target") + assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") + ''; + } +) diff --git a/nixos/tests/systemd-initrd-luks-password.nix b/nixos/tests/systemd-initrd-luks-password.nix index 66b5022d87fdc4..941926f981924f 100644 --- a/nixos/tests/systemd-initrd-luks-password.nix +++ b/nixos/tests/systemd-initrd-luks-password.nix @@ -1,56 +1,64 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "systemd-initrd-luks-password"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "systemd-initrd-luks-password"; - nodes.machine = { pkgs, ... }: { - # Use systemd-boot - virtualisation = { - emptyDiskImages = [ 512 512 ]; - useBootLoader = true; - # Booting off the encrypted disk requires an available init script - mountHostNixStore = true; - useEFIBoot = true; - }; - boot.loader.systemd-boot.enable = true; + nodes.machine = + { pkgs, ... }: + { + # Use systemd-boot + virtualisation = { + emptyDiskImages = [ + 512 + 512 + ]; + useBootLoader = true; + # Booting off the encrypted disk requires an available init script + mountHostNixStore = true; + useEFIBoot = true; + }; + boot.loader.systemd-boot.enable = true; - environment.systemPackages = with pkgs; [ cryptsetup ]; - boot.initrd.systemd = { - enable = true; - emergencyAccess = true; - }; + environment.systemPackages = with pkgs; [ cryptsetup ]; + boot.initrd.systemd = { + enable = true; + emergencyAccess = true; + }; - specialisation.boot-luks.configuration = { - boot.initrd.luks.devices = lib.mkVMOverride { - # We have two disks and only type one password - key reuse is in place - cryptroot.device = "/dev/vdb"; - cryptroot2.device = "/dev/vdc"; + specialisation.boot-luks.configuration = { + boot.initrd.luks.devices = lib.mkVMOverride { + # We have two disks and only type one password - key reuse is in place + cryptroot.device = "/dev/vdb"; + cryptroot2.device = "/dev/vdc"; + }; + virtualisation.rootDevice = "/dev/mapper/cryptroot"; + virtualisation.fileSystems."/".autoFormat = true; + # test mounting device unlocked in initrd after switching root + virtualisation.fileSystems."/cryptroot2".device = "/dev/mapper/cryptroot2"; + }; }; - virtualisation.rootDevice = "/dev/mapper/cryptroot"; - virtualisation.fileSystems."/".autoFormat = true; - # test mounting device unlocked in initrd after switching root - virtualisation.fileSystems."/cryptroot2".device = "/dev/mapper/cryptroot2"; - }; - }; - testScript = '' - # Create encrypted volume - machine.wait_for_unit("multi-user.target") - machine.succeed("echo -n supersecret | cryptsetup luksFormat -q --iter-time=1 /dev/vdb -") - machine.succeed("echo -n supersecret | cryptsetup luksFormat -q --iter-time=1 /dev/vdc -") - machine.succeed("echo -n supersecret | cryptsetup luksOpen -q /dev/vdc cryptroot2") - machine.succeed("mkfs.ext4 /dev/mapper/cryptroot2") + testScript = '' + # Create encrypted volume + machine.wait_for_unit("multi-user.target") + machine.succeed("echo -n supersecret | cryptsetup luksFormat -q --iter-time=1 /dev/vdb -") + machine.succeed("echo -n supersecret | cryptsetup luksFormat -q --iter-time=1 /dev/vdc -") + machine.succeed("echo -n supersecret | cryptsetup luksOpen -q /dev/vdc cryptroot2") + machine.succeed("mkfs.ext4 /dev/mapper/cryptroot2") - # Boot from the encrypted disk - machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks.conf") - machine.succeed("sync") - machine.crash() + # Boot from the encrypted disk + machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks.conf") + machine.succeed("sync") + machine.crash() - # Boot and decrypt the disk - machine.start() - machine.wait_for_console_text("Please enter passphrase for disk cryptroot") - machine.send_console("supersecret\n") - machine.wait_for_unit("multi-user.target") + # Boot and decrypt the disk + machine.start() + machine.wait_for_console_text("Please enter passphrase for disk cryptroot") + machine.send_console("supersecret\n") + machine.wait_for_unit("multi-user.target") - assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount"), "/dev/mapper/cryptroot do not appear in mountpoints list" - assert "/dev/mapper/cryptroot2 on /cryptroot2 type ext4" in machine.succeed("mount") - ''; -}) + assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount"), "/dev/mapper/cryptroot do not appear in mountpoints list" + assert "/dev/mapper/cryptroot2 on /cryptroot2 type ext4" in machine.succeed("mount") + ''; + } +) diff --git a/nixos/tests/systemd-initrd-luks-tpm2.nix b/nixos/tests/systemd-initrd-luks-tpm2.nix index e292acfd1c5f98..a6c52435ee0344 100644 --- a/nixos/tests/systemd-initrd-luks-tpm2.nix +++ b/nixos/tests/systemd-initrd-luks-tpm2.nix @@ -1,50 +1,55 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "systemd-initrd-luks-tpm2"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "systemd-initrd-luks-tpm2"; - nodes.machine = { pkgs, ... }: { - # Use systemd-boot - virtualisation = { - emptyDiskImages = [ 512 ]; - useBootLoader = true; - # Booting off the TPM2-encrypted device requires an available init script - mountHostNixStore = true; - useEFIBoot = true; - tpm.enable = true; - }; - boot.loader.systemd-boot.enable = true; + nodes.machine = + { pkgs, ... }: + { + # Use systemd-boot + virtualisation = { + emptyDiskImages = [ 512 ]; + useBootLoader = true; + # Booting off the TPM2-encrypted device requires an available init script + mountHostNixStore = true; + useEFIBoot = true; + tpm.enable = true; + }; + boot.loader.systemd-boot.enable = true; - boot.initrd.availableKernelModules = [ "tpm_tis" ]; + boot.initrd.availableKernelModules = [ "tpm_tis" ]; - environment.systemPackages = with pkgs; [ cryptsetup ]; - boot.initrd.systemd = { - enable = true; - }; + environment.systemPackages = with pkgs; [ cryptsetup ]; + boot.initrd.systemd = { + enable = true; + }; - specialisation.boot-luks.configuration = { - boot.initrd.luks.devices = lib.mkVMOverride { - cryptroot = { - device = "/dev/vdb"; - crypttabExtraOpts = [ "tpm2-device=auto" ]; + specialisation.boot-luks.configuration = { + boot.initrd.luks.devices = lib.mkVMOverride { + cryptroot = { + device = "/dev/vdb"; + crypttabExtraOpts = [ "tpm2-device=auto" ]; + }; + }; + virtualisation.rootDevice = "/dev/mapper/cryptroot"; + virtualisation.fileSystems."/".autoFormat = true; }; }; - virtualisation.rootDevice = "/dev/mapper/cryptroot"; - virtualisation.fileSystems."/".autoFormat = true; - }; - }; - testScript = '' - # Create encrypted volume - machine.wait_for_unit("multi-user.target") - machine.succeed("echo -n supersecret | cryptsetup luksFormat -q --iter-time=1 /dev/vdb -") - machine.succeed("PASSWORD=supersecret SYSTEMD_LOG_LEVEL=debug systemd-cryptenroll --tpm2-pcrs= --tpm2-device=auto /dev/vdb |& systemd-cat") + testScript = '' + # Create encrypted volume + machine.wait_for_unit("multi-user.target") + machine.succeed("echo -n supersecret | cryptsetup luksFormat -q --iter-time=1 /dev/vdb -") + machine.succeed("PASSWORD=supersecret SYSTEMD_LOG_LEVEL=debug systemd-cryptenroll --tpm2-pcrs= --tpm2-device=auto /dev/vdb |& systemd-cat") - # Boot from the encrypted disk - machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks.conf") - machine.succeed("sync") - machine.crash() + # Boot from the encrypted disk + machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-luks.conf") + machine.succeed("sync") + machine.crash() - # Boot and decrypt the disk - machine.wait_for_unit("multi-user.target") - assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") - ''; -}) + # Boot and decrypt the disk + machine.wait_for_unit("multi-user.target") + assert "/dev/mapper/cryptroot on / type ext4" in machine.succeed("mount") + ''; + } +) diff --git a/nixos/tests/systemd-initrd-modprobe.nix b/nixos/tests/systemd-initrd-modprobe.nix index e563552a645fda..e5aee51ade7f8e 100644 --- a/nixos/tests/systemd-initrd-modprobe.nix +++ b/nixos/tests/systemd-initrd-modprobe.nix @@ -1,24 +1,29 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "systemd-initrd-modprobe"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "systemd-initrd-modprobe"; - nodes.machine = { pkgs, ... }: { - testing.initrdBackdoor = true; - boot.initrd.systemd.enable = true; - boot.initrd.kernelModules = [ "tcp_hybla" ]; # Load module in initrd. - boot.extraModprobeConfig = '' - options tcp_hybla rtt0=42 - ''; - }; + nodes.machine = + { pkgs, ... }: + { + testing.initrdBackdoor = true; + boot.initrd.systemd.enable = true; + boot.initrd.kernelModules = [ "tcp_hybla" ]; # Load module in initrd. + boot.extraModprobeConfig = '' + options tcp_hybla rtt0=42 + ''; + }; - testScript = '' - machine.wait_for_unit("initrd.target") - rtt = machine.succeed("cat /sys/module/tcp_hybla/parameters/rtt0") - assert int(rtt) == 42, "Parameter should be respected for initrd kernel modules" + testScript = '' + machine.wait_for_unit("initrd.target") + rtt = machine.succeed("cat /sys/module/tcp_hybla/parameters/rtt0") + assert int(rtt) == 42, "Parameter should be respected for initrd kernel modules" - # Make sure it sticks in stage 2 - machine.switch_root() - machine.wait_for_unit("multi-user.target") - rtt = machine.succeed("cat /sys/module/tcp_hybla/parameters/rtt0") - assert int(rtt) == 42, "Parameter should be respected for initrd kernel modules" - ''; -}) + # Make sure it sticks in stage 2 + machine.switch_root() + machine.wait_for_unit("multi-user.target") + rtt = machine.succeed("cat /sys/module/tcp_hybla/parameters/rtt0") + assert int(rtt) == 42, "Parameter should be respected for initrd kernel modules" + ''; + } +) diff --git a/nixos/tests/systemd-initrd-networkd-ssh.nix b/nixos/tests/systemd-initrd-networkd-ssh.nix index d4c168f40e29d9..9805689be4aacc 100644 --- a/nixos/tests/systemd-initrd-networkd-ssh.nix +++ b/nixos/tests/systemd-initrd-networkd-ssh.nix @@ -1,60 +1,64 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "systemd-initrd-network-ssh"; - meta.maintainers = [ lib.maintainers.elvishjerricco ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "systemd-initrd-network-ssh"; + meta.maintainers = [ lib.maintainers.elvishjerricco ]; - nodes = { - server = { config, pkgs, ... }: { - testing.initrdBackdoor = true; - boot.initrd.systemd.enable = true; - boot.initrd.systemd.contents."/etc/msg".text = "foo"; - boot.initrd.network = { - enable = true; - ssh = { - enable = true; - authorizedKeys = [ (lib.readFile ./initrd-network-ssh/id_ed25519.pub) ]; - port = 22; - hostKeys = [ ./initrd-network-ssh/ssh_host_ed25519_key ]; + nodes = { + server = + { config, pkgs, ... }: + { + testing.initrdBackdoor = true; + boot.initrd.systemd.enable = true; + boot.initrd.systemd.contents."/etc/msg".text = "foo"; + boot.initrd.network = { + enable = true; + ssh = { + enable = true; + authorizedKeys = [ (lib.readFile ./initrd-network-ssh/id_ed25519.pub) ]; + port = 22; + hostKeys = [ ./initrd-network-ssh/ssh_host_ed25519_key ]; + }; + }; }; - }; - }; - client = { config, ... }: { - environment.etc = { - knownHosts = { - text = lib.concatStrings [ - "server," - "${ - toString (lib.head (lib.splitString " " (toString - (lib.elemAt (lib.splitString "\n" config.networking.extraHosts) 2)))) - } " - "${lib.readFile ./initrd-network-ssh/ssh_host_ed25519_key.pub}" - ]; - }; - sshKey = { - source = ./initrd-network-ssh/id_ed25519; - mode = "0600"; + client = + { config, ... }: + { + environment.etc = { + knownHosts = { + text = lib.concatStrings [ + "server," + "${toString (lib.head (lib.splitString " " (toString (lib.elemAt (lib.splitString "\n" config.networking.extraHosts) 2))))} " + "${lib.readFile ./initrd-network-ssh/ssh_host_ed25519_key.pub}" + ]; + }; + sshKey = { + source = ./initrd-network-ssh/id_ed25519; + mode = "0600"; + }; + }; }; - }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - def ssh_is_up(_) -> bool: - status, _ = client.execute("nc -z server 22") - return status == 0 + def ssh_is_up(_) -> bool: + status, _ = client.execute("nc -z server 22") + return status == 0 - client.wait_for_unit("network.target") - with client.nested("waiting for SSH server to come up"): - retry(ssh_is_up) + client.wait_for_unit("network.target") + with client.nested("waiting for SSH server to come up"): + retry(ssh_is_up) - msg = client.succeed( - "ssh -i /etc/sshKey -o UserKnownHostsFile=/etc/knownHosts server 'cat /etc/msg'" - ) - assert "foo" in msg + msg = client.succeed( + "ssh -i /etc/sshKey -o UserKnownHostsFile=/etc/knownHosts server 'cat /etc/msg'" + ) + assert "foo" in msg - server.switch_root() - server.wait_for_unit("multi-user.target") - ''; -}) + server.switch_root() + server.wait_for_unit("multi-user.target") + ''; + } +) diff --git a/nixos/tests/systemd-initrd-networkd.nix b/nixos/tests/systemd-initrd-networkd.nix index 691f4300d7a23b..86accd21d93557 100644 --- a/nixos/tests/systemd-initrd-networkd.nix +++ b/nixos/tests/systemd-initrd-networkd.nix @@ -1,7 +1,8 @@ -{ system ? builtins.currentSystem -, config ? {} -, pkgs ? import ../.. { inherit system config; } -, lib ? pkgs.lib +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, + lib ? pkgs.lib, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -15,47 +16,61 @@ let network.wait-online.timeout = 10; network.wait-online.anyInterface = true; targets.network-online.requiredBy = [ "initrd.target" ]; - services.systemd-networkd-wait-online.requiredBy = - [ "network-online.target" ]; - initrdBin = [ pkgs.iproute2 pkgs.iputils pkgs.gnugrep ]; + services.systemd-networkd-wait-online.requiredBy = [ "network-online.target" ]; + initrdBin = [ + pkgs.iproute2 + pkgs.iputils + pkgs.gnugrep + ]; }; testing.initrdBackdoor = true; boot.initrd.network.enable = true; }; - mkFlushTest = flush: script: makeTest { - name = "systemd-initrd-network-${lib.optionalString (!flush) "no-"}flush"; - meta.maintainers = [ elvishjerricco ]; + mkFlushTest = + flush: script: + makeTest { + name = "systemd-initrd-network-${lib.optionalString (!flush) "no-"}flush"; + meta.maintainers = [ elvishjerricco ]; - nodes.machine = { - imports = [ common ]; + nodes.machine = { + imports = [ common ]; - boot.initrd.network.flushBeforeStage2 = flush; - systemd.services.check-flush = { - requiredBy = ["multi-user.target"]; - before = [ "network-pre.target" "multi-user.target" "shutdown.target" ]; - conflicts = [ "shutdown.target" ]; - wants = ["network-pre.target"]; - unitConfig.DefaultDependencies = false; - serviceConfig.Type = "oneshot"; - path = [ pkgs.iproute2 pkgs.iputils pkgs.gnugrep ]; - inherit script; + boot.initrd.network.flushBeforeStage2 = flush; + systemd.services.check-flush = { + requiredBy = [ "multi-user.target" ]; + before = [ + "network-pre.target" + "multi-user.target" + "shutdown.target" + ]; + conflicts = [ "shutdown.target" ]; + wants = [ "network-pre.target" ]; + unitConfig.DefaultDependencies = false; + serviceConfig.Type = "oneshot"; + path = [ + pkgs.iproute2 + pkgs.iputils + pkgs.gnugrep + ]; + inherit script; + }; }; - }; - testScript = '' - machine.wait_for_unit("network-online.target") - machine.succeed( - "ip addr | grep 10.0.2.15", - "ping -c1 10.0.2.2", - ) - machine.switch_root() + testScript = '' + machine.wait_for_unit("network-online.target") + machine.succeed( + "ip addr | grep 10.0.2.15", + "ping -c1 10.0.2.2", + ) + machine.switch_root() - machine.wait_for_unit("multi-user.target") - ''; - }; + machine.wait_for_unit("multi-user.target") + ''; + }; -in { +in +{ basic = makeTest { name = "systemd-initrd-network"; meta.maintainers = [ elvishjerricco ]; diff --git a/nixos/tests/systemd-initrd-simple.nix b/nixos/tests/systemd-initrd-simple.nix index b61cb8ddae7b27..7a379404bbc223 100644 --- a/nixos/tests/systemd-initrd-simple.nix +++ b/nixos/tests/systemd-initrd-simple.nix @@ -1,50 +1,55 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "systemd-initrd-simple"; - - nodes.machine = { pkgs, ... }: { - testing.initrdBackdoor = true; - boot.initrd.systemd.enable = true; - virtualisation.fileSystems."/".autoResize = true; - }; - - testScript = '' - import subprocess - - with subtest("testing initrd backdoor"): - machine.wait_for_unit("initrd.target") - machine.succeed("systemctl status initrd-fs.target") - machine.switch_root() - - with subtest("handover to stage-2 systemd works"): - machine.wait_for_unit("multi-user.target") - machine.succeed("systemd-analyze | grep -q '(initrd)'") # direct handover - machine.succeed("touch /testfile") # / is writable - machine.fail("touch /nix/store/testfile") # /nix/store is not writable - # Special filesystems are mounted by systemd - machine.succeed("[ -e /run/booted-system ]") # /run - machine.succeed("[ -e /sys/class ]") # /sys - machine.succeed("[ -e /dev/null ]") # /dev - machine.succeed("[ -e /proc/1 ]") # /proc - # stage-2-init mounted more special filesystems - machine.succeed("[ -e /dev/shm ]") # /dev/shm - machine.succeed("[ -e /dev/pts/ptmx ]") # /dev/pts - machine.succeed("[ -e /run/keys ]") # /run/keys - # /nixos-closure didn't leak into stage-2 - machine.succeed("[ ! -e /nixos-closure ]") - - with subtest("groups work"): - machine.fail("journalctl -b 0 | grep 'systemd-udevd.*Unknown group.*ignoring'") - - with subtest("growfs works"): - oldAvail = machine.succeed("df --output=avail / | sed 1d") - machine.shutdown() - - subprocess.check_call(["qemu-img", "resize", "vm-state-machine/machine.qcow2", "+1G"]) - - machine.start() - machine.switch_root() - newAvail = machine.succeed("df --output=avail / | sed 1d") - - assert int(oldAvail) < int(newAvail), "File system did not grow" - ''; -}) +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "systemd-initrd-simple"; + + nodes.machine = + { pkgs, ... }: + { + testing.initrdBackdoor = true; + boot.initrd.systemd.enable = true; + virtualisation.fileSystems."/".autoResize = true; + }; + + testScript = '' + import subprocess + + with subtest("testing initrd backdoor"): + machine.wait_for_unit("initrd.target") + machine.succeed("systemctl status initrd-fs.target") + machine.switch_root() + + with subtest("handover to stage-2 systemd works"): + machine.wait_for_unit("multi-user.target") + machine.succeed("systemd-analyze | grep -q '(initrd)'") # direct handover + machine.succeed("touch /testfile") # / is writable + machine.fail("touch /nix/store/testfile") # /nix/store is not writable + # Special filesystems are mounted by systemd + machine.succeed("[ -e /run/booted-system ]") # /run + machine.succeed("[ -e /sys/class ]") # /sys + machine.succeed("[ -e /dev/null ]") # /dev + machine.succeed("[ -e /proc/1 ]") # /proc + # stage-2-init mounted more special filesystems + machine.succeed("[ -e /dev/shm ]") # /dev/shm + machine.succeed("[ -e /dev/pts/ptmx ]") # /dev/pts + machine.succeed("[ -e /run/keys ]") # /run/keys + # /nixos-closure didn't leak into stage-2 + machine.succeed("[ ! -e /nixos-closure ]") + + with subtest("groups work"): + machine.fail("journalctl -b 0 | grep 'systemd-udevd.*Unknown group.*ignoring'") + + with subtest("growfs works"): + oldAvail = machine.succeed("df --output=avail / | sed 1d") + machine.shutdown() + + subprocess.check_call(["qemu-img", "resize", "vm-state-machine/machine.qcow2", "+1G"]) + + machine.start() + machine.switch_root() + newAvail = machine.succeed("df --output=avail / | sed 1d") + + assert int(oldAvail) < int(newAvail), "File system did not grow" + ''; + } +) diff --git a/nixos/tests/systemd-initrd-swraid.nix b/nixos/tests/systemd-initrd-swraid.nix index d00e67b5705ab0..106839ef4b95bc 100644 --- a/nixos/tests/systemd-initrd-swraid.nix +++ b/nixos/tests/systemd-initrd-swraid.nix @@ -1,66 +1,77 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "systemd-initrd-swraid"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "systemd-initrd-swraid"; - nodes.machine = { pkgs, ... }: { - # Use systemd-boot - virtualisation = { - emptyDiskImages = [ 512 512 ]; - useBootLoader = true; - # Booting off the RAID requires an available init script - mountHostNixStore = true; - useEFIBoot = true; - }; - boot.loader.systemd-boot.enable = true; - boot.loader.efi.canTouchEfiVariables = true; + nodes.machine = + { pkgs, ... }: + { + # Use systemd-boot + virtualisation = { + emptyDiskImages = [ + 512 + 512 + ]; + useBootLoader = true; + # Booting off the RAID requires an available init script + mountHostNixStore = true; + useEFIBoot = true; + }; + boot.loader.systemd-boot.enable = true; + boot.loader.efi.canTouchEfiVariables = true; - environment.systemPackages = with pkgs; [ mdadm e2fsprogs ]; # for mdadm and mkfs.ext4 - boot.swraid = { - enable = true; - mdadmConf = '' - ARRAY /dev/md0 devices=/dev/vdb,/dev/vdc - ''; - }; - environment.etc."mdadm.conf".text = '' - MAILADDR test@example.com - ''; - boot.initrd = { - systemd = { - enable = true; - emergencyAccess = true; - }; - kernelModules = [ "raid0" ]; - }; + environment.systemPackages = with pkgs; [ + mdadm + e2fsprogs + ]; # for mdadm and mkfs.ext4 + boot.swraid = { + enable = true; + mdadmConf = '' + ARRAY /dev/md0 devices=/dev/vdb,/dev/vdc + ''; + }; + environment.etc."mdadm.conf".text = '' + MAILADDR test@example.com + ''; + boot.initrd = { + systemd = { + enable = true; + emergencyAccess = true; + }; + kernelModules = [ "raid0" ]; + }; - specialisation.boot-swraid.configuration.virtualisation.rootDevice = "/dev/disk/by-label/testraid"; - # This protects against a regression. We do not have to switch to it. - # It's sufficient to trigger its evaluation. - specialisation.build-old-initrd.configuration.boot.initrd.systemd.enable = lib.mkForce false; - }; + specialisation.boot-swraid.configuration.virtualisation.rootDevice = "/dev/disk/by-label/testraid"; + # This protects against a regression. We do not have to switch to it. + # It's sufficient to trigger its evaluation. + specialisation.build-old-initrd.configuration.boot.initrd.systemd.enable = lib.mkForce false; + }; - testScript = '' - # Create RAID - machine.succeed("mdadm --create --force /dev/md0 -n 2 --level=raid1 /dev/vdb /dev/vdc --metadata=0.90") - machine.succeed("mkfs.ext4 -L testraid /dev/md0") - machine.succeed("mkdir -p /mnt && mount /dev/md0 /mnt && echo hello > /mnt/test && umount /mnt") + testScript = '' + # Create RAID + machine.succeed("mdadm --create --force /dev/md0 -n 2 --level=raid1 /dev/vdb /dev/vdc --metadata=0.90") + machine.succeed("mkfs.ext4 -L testraid /dev/md0") + machine.succeed("mkdir -p /mnt && mount /dev/md0 /mnt && echo hello > /mnt/test && umount /mnt") - # Boot from the RAID - machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-swraid.conf") - machine.succeed("sync") - machine.crash() - machine.wait_for_unit("multi-user.target") + # Boot from the RAID + machine.succeed("bootctl set-default nixos-generation-1-specialisation-boot-swraid.conf") + machine.succeed("sync") + machine.crash() + machine.wait_for_unit("multi-user.target") - # Ensure we have successfully booted from the RAID - assert "(initrd)" in machine.succeed("systemd-analyze") # booted with systemd in stage 1 - assert "/dev/md0 on / type ext4" in machine.succeed("mount") - assert "hello" in machine.succeed("cat /test") - assert "md0" in machine.succeed("cat /proc/mdstat") + # Ensure we have successfully booted from the RAID + assert "(initrd)" in machine.succeed("systemd-analyze") # booted with systemd in stage 1 + assert "/dev/md0 on / type ext4" in machine.succeed("mount") + assert "hello" in machine.succeed("cat /test") + assert "md0" in machine.succeed("cat /proc/mdstat") - expected_config = """MAILADDR test@example.com + expected_config = """MAILADDR test@example.com - ARRAY /dev/md0 devices=/dev/vdb,/dev/vdc - """ - got_config = machine.execute("cat /etc/mdadm.conf")[1] - assert expected_config == got_config, repr((expected_config, got_config)) - machine.wait_for_unit("mdmonitor.service") - ''; -}) + ARRAY /dev/md0 devices=/dev/vdb,/dev/vdc + """ + got_config = machine.execute("cat /etc/mdadm.conf")[1] + assert expected_config == got_config, repr((expected_config, got_config)) + machine.wait_for_unit("mdmonitor.service") + ''; + } +) diff --git a/nixos/tests/systemd-initrd-vconsole.nix b/nixos/tests/systemd-initrd-vconsole.nix index d4c2a57680c15c..4fc9b5f3738c10 100644 --- a/nixos/tests/systemd-initrd-vconsole.nix +++ b/nixos/tests/systemd-initrd-vconsole.nix @@ -1,42 +1,52 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "systemd-initrd-vconsole"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "systemd-initrd-vconsole"; - nodes.machine = { pkgs, ... }: { - boot.kernelParams = lib.mkAfter [ "rd.systemd.unit=rescue.target" "loglevel=3" "udev.log_level=3" "systemd.log_level=warning" ]; + nodes.machine = + { pkgs, ... }: + { + boot.kernelParams = lib.mkAfter [ + "rd.systemd.unit=rescue.target" + "loglevel=3" + "udev.log_level=3" + "systemd.log_level=warning" + ]; - boot.initrd.systemd = { - enable = true; - emergencyAccess = true; - }; + boot.initrd.systemd = { + enable = true; + emergencyAccess = true; + }; - console = { - earlySetup = true; - keyMap = "colemak"; - }; - }; + console = { + earlySetup = true; + keyMap = "colemak"; + }; + }; - testScript = '' - # Boot into rescue shell in initrd - machine.start() - machine.wait_for_console_text("Press Enter for maintenance") - machine.send_console("\n") + testScript = '' + # Boot into rescue shell in initrd + machine.start() + machine.wait_for_console_text("Press Enter for maintenance") + machine.send_console("\n") - # Wait for shell to become ready - for _ in range(300): - machine.send_console("printf '%s to receive commands:\\n' Ready\n") - try: - machine.wait_for_console_text("Ready to receive commands:", timeout=1) - break - except Exception: - continue - else: - raise RuntimeError("Rescue shell never became ready") + # Wait for shell to become ready + for _ in range(300): + machine.send_console("printf '%s to receive commands:\\n' Ready\n") + try: + machine.wait_for_console_text("Ready to receive commands:", timeout=1) + break + except Exception: + continue + else: + raise RuntimeError("Rescue shell never became ready") - # Check keymap - machine.send_console("(printf '%s to receive text:\\n' Ready && read text && echo \"$text\") </dev/tty1\n") - machine.wait_for_console_text("Ready to receive text:") - for key in "asdfjkl;\n": - machine.send_key(key) - machine.wait_for_console_text("arstneio") - ''; -}) + # Check keymap + machine.send_console("(printf '%s to receive text:\\n' Ready && read text && echo \"$text\") </dev/tty1\n") + machine.wait_for_console_text("Ready to receive text:") + for key in "asdfjkl;\n": + machine.send_key(key) + machine.wait_for_console_text("arstneio") + ''; + } +) diff --git a/nixos/tests/systemd-initrd-vlan.nix b/nixos/tests/systemd-initrd-vlan.nix index 5060163a047d20..36d8154cdc5ff0 100644 --- a/nixos/tests/systemd-initrd-vlan.nix +++ b/nixos/tests/systemd-initrd-vlan.nix @@ -1,59 +1,66 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "systemd-initrd-vlan"; - meta.maintainers = [ lib.maintainers.majiir ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "systemd-initrd-vlan"; + meta.maintainers = [ lib.maintainers.majiir ]; - # Tests VLAN interface configuration in systemd-initrd. - # - # Two nodes are configured for a tagged VLAN. (Note that they also still have - # their ordinary eth0 and eth1 interfaces, which are not VLAN-tagged.) - # - # The 'server' node waits forever in initrd (stage 1) with networking - # enabled. The 'client' node pings it to test network connectivity. + # Tests VLAN interface configuration in systemd-initrd. + # + # Two nodes are configured for a tagged VLAN. (Note that they also still have + # their ordinary eth0 and eth1 interfaces, which are not VLAN-tagged.) + # + # The 'server' node waits forever in initrd (stage 1) with networking + # enabled. The 'client' node pings it to test network connectivity. - nodes = let - network = id: { - networking = { - vlans."eth1.10" = { - id = 10; - interface = "eth1"; + nodes = + let + network = id: { + networking = { + vlans."eth1.10" = { + id = 10; + interface = "eth1"; + }; + interfaces."eth1.10" = { + ipv4.addresses = [ + { + address = "192.168.10.${id}"; + prefixLength = 24; + } + ]; + }; + }; }; - interfaces."eth1.10" = { - ipv4.addresses = [{ - address = "192.168.10.${id}"; - prefixLength = 24; - }]; + in + { + # Node that will use initrd networking. + server = network "1" // { + boot.initrd.systemd.enable = true; + boot.initrd.network.enable = true; + boot.initrd.systemd.services.boot-blocker = { + before = [ "initrd.target" ]; + wantedBy = [ "initrd.target" ]; + script = "sleep infinity"; + serviceConfig.Type = "oneshot"; + }; }; - }; - }; - in { - # Node that will use initrd networking. - server = network "1" // { - boot.initrd.systemd.enable = true; - boot.initrd.network.enable = true; - boot.initrd.systemd.services.boot-blocker = { - before = [ "initrd.target" ]; - wantedBy = [ "initrd.target" ]; - script = "sleep infinity"; - serviceConfig.Type = "oneshot"; - }; - }; - # Node that will ping the server. - client = network "2"; - }; + # Node that will ping the server. + client = network "2"; + }; - testScript = '' - start_all() - client.wait_for_unit("network.target") + testScript = '' + start_all() + client.wait_for_unit("network.target") - # Wait for the regular (untagged) interface to be up. - def server_is_up(_) -> bool: - status, _ = client.execute("ping -n -c 1 server >&2") - return status == 0 - with client.nested("waiting for server to come up"): - retry(server_is_up) + # Wait for the regular (untagged) interface to be up. + def server_is_up(_) -> bool: + status, _ = client.execute("ping -n -c 1 server >&2") + return status == 0 + with client.nested("waiting for server to come up"): + retry(server_is_up) - # Try to ping the (tagged) VLAN interface. - client.succeed("ping -n -w 10 -c 1 192.168.10.1 >&2") - ''; -}) + # Try to ping the (tagged) VLAN interface. + client.succeed("ping -n -w 10 -c 1 192.168.10.1 >&2") + ''; + } +) diff --git a/nixos/tests/systemd-journal-gateway.nix b/nixos/tests/systemd-journal-gateway.nix index 1d20943f238807..1b7428590a4a85 100644 --- a/nixos/tests/systemd-journal-gateway.nix +++ b/nixos/tests/systemd-journal-gateway.nix @@ -1,90 +1,95 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: -{ - name = "systemd-journal-gateway"; - meta = with pkgs.lib.maintainers; { - maintainers = [ minijackson raitobezarius ]; - }; - - # Named client for coherence with the systemd-journal-upload test, and for - # certificate validation - nodes.client = { - services.journald.gateway = { - enable = true; - cert = "/run/secrets/client/cert.pem"; - key = "/run/secrets/client/key.pem"; - trust = "/run/secrets/ca.cert.pem"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "systemd-journal-gateway"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + minijackson + raitobezarius + ]; }; - }; - - testScript = '' - import json - import subprocess - import tempfile - - tmpdir_o = tempfile.TemporaryDirectory() - tmpdir = tmpdir_o.name - - def generate_pems(domain: str): - subprocess.run( - [ - "${pkgs.minica}/bin/minica", - "--ca-key=ca.key.pem", - "--ca-cert=ca.cert.pem", - f"--domains={domain}", - ], - cwd=str(tmpdir), - ) - - with subtest("Creating keys and certificates"): - generate_pems("server") - generate_pems("client") - - client.wait_for_unit("multi-user.target") - - def copy_pem(file: str): - machine.copy_from_host(source=f"{tmpdir}/{file}", target=f"/run/secrets/{file}") - machine.succeed(f"chmod 644 /run/secrets/{file}") - - with subtest("Copying keys and certificates"): - machine.succeed("mkdir -p /run/secrets/{client,server}") - copy_pem("server/cert.pem") - copy_pem("server/key.pem") - copy_pem("client/cert.pem") - copy_pem("client/key.pem") - copy_pem("ca.cert.pem") - - client.wait_for_unit("multi-user.target") - - curl = '${pkgs.curl}/bin/curl' - accept_json = '--header "Accept: application/json"' - cacert = '--cacert /run/secrets/ca.cert.pem' - cert = '--cert /run/secrets/server/cert.pem' - key = '--key /run/secrets/server/key.pem' - base_url = 'https://client:19531' - curl_cli = f"{curl} {accept_json} {cacert} {cert} {key} --fail" - - machine_info = client.succeed(f"{curl_cli} {base_url}/machine") - assert json.loads(machine_info)["hostname"] == "client", "wrong machine name" - - # The HTTP request should have started the gateway service, triggered by - # the .socket unit - client.wait_for_unit("systemd-journal-gatewayd.service") - - identifier = "nixos-test" - message = "Hello from NixOS test infrastructure" - - client.succeed(f"systemd-cat --identifier={identifier} <<< '{message}'") + # Named client for coherence with the systemd-journal-upload test, and for + # certificate validation + nodes.client = { + services.journald.gateway = { + enable = true; + cert = "/run/secrets/client/cert.pem"; + key = "/run/secrets/client/key.pem"; + trust = "/run/secrets/ca.cert.pem"; + }; + }; - # max-time is a workaround against a bug in systemd-journal-gatewayd where - # if TLS is enabled, the connection is never closed. Since it will timeout, - # we ignore the return code. - entries = client.succeed( - f"{curl_cli} --max-time 5 {base_url}/entries?SYSLOG_IDENTIFIER={identifier} || true" - ) + testScript = '' + import json + import subprocess + import tempfile + + tmpdir_o = tempfile.TemporaryDirectory() + tmpdir = tmpdir_o.name + + def generate_pems(domain: str): + subprocess.run( + [ + "${pkgs.minica}/bin/minica", + "--ca-key=ca.key.pem", + "--ca-cert=ca.cert.pem", + f"--domains={domain}", + ], + cwd=str(tmpdir), + ) + + with subtest("Creating keys and certificates"): + generate_pems("server") + generate_pems("client") + + client.wait_for_unit("multi-user.target") + + def copy_pem(file: str): + machine.copy_from_host(source=f"{tmpdir}/{file}", target=f"/run/secrets/{file}") + machine.succeed(f"chmod 644 /run/secrets/{file}") + + with subtest("Copying keys and certificates"): + machine.succeed("mkdir -p /run/secrets/{client,server}") + copy_pem("server/cert.pem") + copy_pem("server/key.pem") + copy_pem("client/cert.pem") + copy_pem("client/key.pem") + copy_pem("ca.cert.pem") + + client.wait_for_unit("multi-user.target") + + curl = '${pkgs.curl}/bin/curl' + accept_json = '--header "Accept: application/json"' + cacert = '--cacert /run/secrets/ca.cert.pem' + cert = '--cert /run/secrets/server/cert.pem' + key = '--key /run/secrets/server/key.pem' + base_url = 'https://client:19531' + + curl_cli = f"{curl} {accept_json} {cacert} {cert} {key} --fail" + + machine_info = client.succeed(f"{curl_cli} {base_url}/machine") + assert json.loads(machine_info)["hostname"] == "client", "wrong machine name" + + # The HTTP request should have started the gateway service, triggered by + # the .socket unit + client.wait_for_unit("systemd-journal-gatewayd.service") + + identifier = "nixos-test" + message = "Hello from NixOS test infrastructure" + + client.succeed(f"systemd-cat --identifier={identifier} <<< '{message}'") + + # max-time is a workaround against a bug in systemd-journal-gatewayd where + # if TLS is enabled, the connection is never closed. Since it will timeout, + # we ignore the return code. + entries = client.succeed( + f"{curl_cli} --max-time 5 {base_url}/entries?SYSLOG_IDENTIFIER={identifier} || true" + ) - # Number of entries should be only 1 - added_entry = json.loads(entries) - assert added_entry["SYSLOG_IDENTIFIER"] == identifier and added_entry["MESSAGE"] == message, "journal entry does not correspond" - ''; -}) + # Number of entries should be only 1 + added_entry = json.loads(entries) + assert added_entry["SYSLOG_IDENTIFIER"] == identifier and added_entry["MESSAGE"] == message, "journal entry does not correspond" + ''; + } +) diff --git a/nixos/tests/systemd-journal-upload.nix b/nixos/tests/systemd-journal-upload.nix index 0cbde379aee96a..923dd48b32ac1d 100644 --- a/nixos/tests/systemd-journal-upload.nix +++ b/nixos/tests/systemd-journal-upload.nix @@ -1,101 +1,110 @@ -import ./make-test-python.nix ({ pkgs, ... }: -{ - name = "systemd-journal-upload"; - meta = with pkgs.lib.maintainers; { - maintainers = [ minijackson raitobezarius ]; - }; - - nodes.server = { nodes, ... }: { - services.journald.remote = { - enable = true; - listen = "http"; - settings.Remote = { - ServerCertificateFile = "/run/secrets/sever.cert.pem"; - ServerKeyFile = "/run/secrets/sever.key.pem"; - TrustedCertificateFile = "/run/secrets/ca.cert.pem"; - Seal = true; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "systemd-journal-upload"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + minijackson + raitobezarius + ]; }; - networking.firewall.allowedTCPPorts = [ nodes.server.services.journald.remote.port ]; - }; + nodes.server = + { nodes, ... }: + { + services.journald.remote = { + enable = true; + listen = "http"; + settings.Remote = { + ServerCertificateFile = "/run/secrets/sever.cert.pem"; + ServerKeyFile = "/run/secrets/sever.key.pem"; + TrustedCertificateFile = "/run/secrets/ca.cert.pem"; + Seal = true; + }; + }; - nodes.client = { lib, nodes, ... }: { - services.journald.upload = { - enable = true; - settings.Upload = { - URL = "http://server:${toString nodes.server.services.journald.remote.port}"; - ServerCertificateFile = "/run/secrets/client.cert.pem"; - ServerKeyFile = "/run/secrets/client.key.pem"; - TrustedCertificateFile = "/run/secrets/ca.cert.pem"; + networking.firewall.allowedTCPPorts = [ nodes.server.services.journald.remote.port ]; }; - }; - # Wait for the PEMs to arrive - systemd.services.systemd-journal-upload.wantedBy = lib.mkForce []; - systemd.paths.systemd-journal-upload = { - wantedBy = [ "default.target" ]; - # This file must be copied last - pathConfig.PathExists = [ "/run/secrets/ca.cert.pem" ]; - }; - }; + nodes.client = + { lib, nodes, ... }: + { + services.journald.upload = { + enable = true; + settings.Upload = { + URL = "http://server:${toString nodes.server.services.journald.remote.port}"; + ServerCertificateFile = "/run/secrets/client.cert.pem"; + ServerKeyFile = "/run/secrets/client.key.pem"; + TrustedCertificateFile = "/run/secrets/ca.cert.pem"; + }; + }; - testScript = '' - import subprocess - import tempfile + # Wait for the PEMs to arrive + systemd.services.systemd-journal-upload.wantedBy = lib.mkForce [ ]; + systemd.paths.systemd-journal-upload = { + wantedBy = [ "default.target" ]; + # This file must be copied last + pathConfig.PathExists = [ "/run/secrets/ca.cert.pem" ]; + }; + }; - tmpdir_o = tempfile.TemporaryDirectory() - tmpdir = tmpdir_o.name + testScript = '' + import subprocess + import tempfile - def generate_pems(domain: str): - subprocess.run( - [ - "${pkgs.minica}/bin/minica", - "--ca-key=ca.key.pem", - "--ca-cert=ca.cert.pem", - f"--domains={domain}", - ], - cwd=str(tmpdir), - ) + tmpdir_o = tempfile.TemporaryDirectory() + tmpdir = tmpdir_o.name - with subtest("Creating keys and certificates"): - generate_pems("server") - generate_pems("client") + def generate_pems(domain: str): + subprocess.run( + [ + "${pkgs.minica}/bin/minica", + "--ca-key=ca.key.pem", + "--ca-cert=ca.cert.pem", + f"--domains={domain}", + ], + cwd=str(tmpdir), + ) - server.wait_for_unit("multi-user.target") - client.wait_for_unit("multi-user.target") + with subtest("Creating keys and certificates"): + generate_pems("server") + generate_pems("client") - def copy_pems(machine: Machine, domain: str): - machine.succeed("mkdir /run/secrets") - machine.copy_from_host( - source=f"{tmpdir}/{domain}/cert.pem", - target=f"/run/secrets/{domain}.cert.pem", - ) - machine.copy_from_host( - source=f"{tmpdir}/{domain}/key.pem", - target=f"/run/secrets/{domain}.key.pem", - ) - # Should be last - machine.copy_from_host( - source=f"{tmpdir}/ca.cert.pem", - target="/run/secrets/ca.cert.pem", - ) + server.wait_for_unit("multi-user.target") + client.wait_for_unit("multi-user.target") - with subtest("Copying keys and certificates"): - copy_pems(server, "server") - copy_pems(client, "client") + def copy_pems(machine: Machine, domain: str): + machine.succeed("mkdir /run/secrets") + machine.copy_from_host( + source=f"{tmpdir}/{domain}/cert.pem", + target=f"/run/secrets/{domain}.cert.pem", + ) + machine.copy_from_host( + source=f"{tmpdir}/{domain}/key.pem", + target=f"/run/secrets/{domain}.key.pem", + ) + # Should be last + machine.copy_from_host( + source=f"{tmpdir}/ca.cert.pem", + target="/run/secrets/ca.cert.pem", + ) - client.wait_for_unit("systemd-journal-upload.service") - # The journal upload should have started the remote service, triggered by - # the .socket unit - server.wait_for_unit("systemd-journal-remote.service") + with subtest("Copying keys and certificates"): + copy_pems(server, "server") + copy_pems(client, "client") - identifier = "nixos-test" - message = "Hello from NixOS test infrastructure" + client.wait_for_unit("systemd-journal-upload.service") + # The journal upload should have started the remote service, triggered by + # the .socket unit + server.wait_for_unit("systemd-journal-remote.service") - client.succeed(f"systemd-cat --identifier={identifier} <<< '{message}'") - server.wait_until_succeeds( - f"journalctl --file /var/log/journal/remote/remote-*.journal --identifier={identifier} | grep -F '{message}'" - ) - ''; -}) + identifier = "nixos-test" + message = "Hello from NixOS test infrastructure" + + client.succeed(f"systemd-cat --identifier={identifier} <<< '{message}'") + server.wait_until_succeeds( + f"journalctl --file /var/log/journal/remote/remote-*.journal --identifier={identifier} | grep -F '{message}'" + ) + ''; + } +) diff --git a/nixos/tests/systemd-journal.nix b/nixos/tests/systemd-journal.nix index ad60c0f547a41f..a0c2f7ee19bb9e 100644 --- a/nixos/tests/systemd-journal.nix +++ b/nixos/tests/systemd-journal.nix @@ -1,16 +1,18 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -{ - name = "systemd-journal"; - meta = with pkgs.lib.maintainers; { - maintainers = [ lewo ]; - }; + { + name = "systemd-journal"; + meta = with pkgs.lib.maintainers; { + maintainers = [ lewo ]; + }; - nodes.machine = { }; + nodes.machine = { }; - testScript = '' - machine.wait_for_unit("multi-user.target") + testScript = '' + machine.wait_for_unit("multi-user.target") - machine.succeed("journalctl --grep=systemd") - ''; -}) + machine.succeed("journalctl --grep=systemd") + ''; + } +) diff --git a/nixos/tests/systemd-lock-handler.nix b/nixos/tests/systemd-lock-handler.nix index d6fb8f54590048..03905f2c81be22 100644 --- a/nixos/tests/systemd-lock-handler.nix +++ b/nixos/tests/systemd-lock-handler.nix @@ -1,11 +1,18 @@ -{ lib, ... }: { +{ lib, ... }: +{ name = "systemd-lock-handler"; meta.maintainers = with lib.maintainers; [ liff ]; enableOCR = true; - nodes.machine = { config, pkgs, lib, ... }: + nodes.machine = + { + config, + pkgs, + lib, + ... + }: let touch = "${lib.getBin pkgs.coreutils}/bin/touch"; in diff --git a/nixos/tests/systemd-machinectl.nix b/nixos/tests/systemd-machinectl.nix index 40ea4905ec67be..5866c6d7603f06 100644 --- a/nixos/tests/systemd-machinectl.nix +++ b/nixos/tests/systemd-machinectl.nix @@ -1,201 +1,211 @@ -import ./make-test-python.nix ({ pkgs, ... }: -let +import ./make-test-python.nix ( + { pkgs, ... }: + let - container = { config, ... }: { - # We re-use the NixOS container option ... - boot.isContainer = true; - # ... and revert unwanted defaults - networking.useHostResolvConf = false; - - # use networkd to obtain systemd network setup - networking.useNetworkd = true; - networking.useDHCP = false; - - # systemd-nspawn expects /sbin/init - boot.loader.initScript.enable = true; - - imports = [ ../modules/profiles/minimal.nix ]; - - system.stateVersion = config.system.nixos.release; - }; - - containerSystem = (import ../lib/eval-config.nix { - inherit (pkgs) system; - modules = [ container ]; - }).config.system.build.toplevel; + container = + { config, ... }: + { + # We re-use the NixOS container option ... + boot.isContainer = true; + # ... and revert unwanted defaults + networking.useHostResolvConf = false; - containerName = "container"; - containerRoot = "/var/lib/machines/${containerName}"; + # use networkd to obtain systemd network setup + networking.useNetworkd = true; + networking.useDHCP = false; - containerTarball = pkgs.callPackage ../lib/make-system-tarball.nix { - storeContents = [ - { - object = containerSystem; - symlink = "/nix/var/nix/profiles/system"; - } - ]; + # systemd-nspawn expects /sbin/init + boot.loader.initScript.enable = true; - contents = [ - { - source = containerSystem + "/etc/os-release"; - target = "/etc/os-release"; - } - { - source = containerSystem + "/init"; - target = "/sbin/init"; - } - ]; - }; -in -{ - name = "systemd-machinectl"; - - nodes.machine = { lib, ... }: { - # use networkd to obtain systemd network setup - networking.useNetworkd = true; - networking.useDHCP = false; - - # do not try to access cache.nixos.org - nix.settings.substituters = lib.mkForce [ ]; - - # auto-start container - systemd.targets.machines.wants = [ "systemd-nspawn@${containerName}.service" ]; - - virtualisation.additionalPaths = [ containerSystem containerTarball ]; - - systemd.tmpfiles.rules = [ - "d /var/lib/machines/shared-decl 0755 root root - -" - ]; - systemd.nspawn.shared-decl = { - execConfig = { - Boot = false; - Parameters = "${containerSystem}/init"; - }; - filesConfig = { - BindReadOnly = "/nix/store"; - }; - }; + imports = [ ../modules/profiles/minimal.nix ]; - systemd.nspawn.${containerName} = { - filesConfig = { - # workaround to fix kernel namespaces; needed for Nix sandbox - # https://github.com/systemd/systemd/issues/27994#issuecomment-1704005670 - Bind = "/proc:/run/proc"; + system.stateVersion = config.system.nixos.release; }; - }; - systemd.services."systemd-nspawn@${containerName}" = { - serviceConfig.Environment = [ - # Disable tmpfs for /tmp - "SYSTEMD_NSPAWN_TMPFS_TMP=0" + containerSystem = + (import ../lib/eval-config.nix { + inherit (pkgs) system; + modules = [ container ]; + }).config.system.build.toplevel; + + containerName = "container"; + containerRoot = "/var/lib/machines/${containerName}"; + + containerTarball = pkgs.callPackage ../lib/make-system-tarball.nix { + storeContents = [ + { + object = containerSystem; + symlink = "/nix/var/nix/profiles/system"; + } + ]; - # force unified cgroup delegation, which would be the default - # if systemd could check the capabilities of the installed systemd. - # see also: https://github.com/NixOS/nixpkgs/pull/198526 - "SYSTEMD_NSPAWN_UNIFIED_HIERARCHY=1" + contents = [ + { + source = containerSystem + "/etc/os-release"; + target = "/etc/os-release"; + } + { + source = containerSystem + "/init"; + target = "/sbin/init"; + } ]; - overrideStrategy = "asDropin"; }; + in + { + name = "systemd-machinectl"; - # open DHCP for container - networking.firewall.extraCommands = '' - ${pkgs.iptables}/bin/iptables -A nixos-fw -i ve-+ -p udp -m udp --dport 67 -j nixos-fw-accept - ''; - }; + nodes.machine = + { lib, ... }: + { + # use networkd to obtain systemd network setup + networking.useNetworkd = true; + networking.useDHCP = false; + + # do not try to access cache.nixos.org + nix.settings.substituters = lib.mkForce [ ]; + + # auto-start container + systemd.targets.machines.wants = [ "systemd-nspawn@${containerName}.service" ]; + + virtualisation.additionalPaths = [ + containerSystem + containerTarball + ]; + + systemd.tmpfiles.rules = [ + "d /var/lib/machines/shared-decl 0755 root root - -" + ]; + systemd.nspawn.shared-decl = { + execConfig = { + Boot = false; + Parameters = "${containerSystem}/init"; + }; + filesConfig = { + BindReadOnly = "/nix/store"; + }; + }; + + systemd.nspawn.${containerName} = { + filesConfig = { + # workaround to fix kernel namespaces; needed for Nix sandbox + # https://github.com/systemd/systemd/issues/27994#issuecomment-1704005670 + Bind = "/proc:/run/proc"; + }; + }; + + systemd.services."systemd-nspawn@${containerName}" = { + serviceConfig.Environment = [ + # Disable tmpfs for /tmp + "SYSTEMD_NSPAWN_TMPFS_TMP=0" + + # force unified cgroup delegation, which would be the default + # if systemd could check the capabilities of the installed systemd. + # see also: https://github.com/NixOS/nixpkgs/pull/198526 + "SYSTEMD_NSPAWN_UNIFIED_HIERARCHY=1" + ]; + overrideStrategy = "asDropin"; + }; + + # open DHCP for container + networking.firewall.extraCommands = '' + ${pkgs.iptables}/bin/iptables -A nixos-fw -i ve-+ -p udp -m udp --dport 67 -j nixos-fw-accept + ''; + }; - testScript = '' - start_all() - machine.wait_for_unit("default.target"); + testScript = '' + start_all() + machine.wait_for_unit("default.target"); - # Test machinectl start stop of shared-decl - machine.succeed("machinectl start shared-decl"); - machine.wait_until_succeeds("systemctl -M shared-decl is-active default.target"); - machine.succeed("machinectl stop shared-decl"); + # Test machinectl start stop of shared-decl + machine.succeed("machinectl start shared-decl"); + machine.wait_until_succeeds("systemctl -M shared-decl is-active default.target"); + machine.succeed("machinectl stop shared-decl"); - # create containers root - machine.succeed("mkdir -p ${containerRoot}"); + # create containers root + machine.succeed("mkdir -p ${containerRoot}"); - # start container with shared nix store by using same arguments as for systemd-nspawn@.service - machine.succeed("systemd-run systemd-nspawn --machine=${containerName} --network-veth -U --bind-ro=/nix/store ${containerSystem}/init") - machine.wait_until_succeeds("systemctl -M ${containerName} is-active default.target"); + # start container with shared nix store by using same arguments as for systemd-nspawn@.service + machine.succeed("systemd-run systemd-nspawn --machine=${containerName} --network-veth -U --bind-ro=/nix/store ${containerSystem}/init") + machine.wait_until_succeeds("systemctl -M ${containerName} is-active default.target"); - # Test machinectl stop - machine.succeed("machinectl stop ${containerName}"); + # Test machinectl stop + machine.succeed("machinectl stop ${containerName}"); - # Install container - # Workaround for nixos-install - machine.succeed("chmod o+rx /var/lib/machines"); - machine.succeed("nixos-install --root ${containerRoot} --system ${containerSystem} --no-channel-copy --no-root-passwd"); + # Install container + # Workaround for nixos-install + machine.succeed("chmod o+rx /var/lib/machines"); + machine.succeed("nixos-install --root ${containerRoot} --system ${containerSystem} --no-channel-copy --no-root-passwd"); - # Allow systemd-nspawn to apply user namespace on immutable files - machine.succeed("chattr -i ${containerRoot}/var/empty"); + # Allow systemd-nspawn to apply user namespace on immutable files + machine.succeed("chattr -i ${containerRoot}/var/empty"); - # Test machinectl start - machine.succeed("machinectl start ${containerName}"); - machine.wait_until_succeeds("systemctl -M ${containerName} is-active default.target"); + # Test machinectl start + machine.succeed("machinectl start ${containerName}"); + machine.wait_until_succeeds("systemctl -M ${containerName} is-active default.target"); - # Test systemd-nspawn configured unified cgroup delegation - # see also: - # https://github.com/systemd/systemd/blob/main/docs/CGROUP_DELEGATION.md#three-different-tree-setups- - machine.succeed('systemd-run --pty --wait -M ${containerName} /run/current-system/sw/bin/stat --format="%T" --file-system /sys/fs/cgroup > fstype') - machine.succeed('test $(tr -d "\\r" < fstype) = cgroup2fs') + # Test systemd-nspawn configured unified cgroup delegation + # see also: + # https://github.com/systemd/systemd/blob/main/docs/CGROUP_DELEGATION.md#three-different-tree-setups- + machine.succeed('systemd-run --pty --wait -M ${containerName} /run/current-system/sw/bin/stat --format="%T" --file-system /sys/fs/cgroup > fstype') + machine.succeed('test $(tr -d "\\r" < fstype) = cgroup2fs') - # Test if systemd-nspawn provides a working environment for nix to build derivations - # https://nixos.org/guides/nix-pills/07-working-derivation - machine.succeed('systemd-run --pty --wait -M ${containerName} /run/current-system/sw/bin/nix-instantiate --expr \'derivation { name = "myname"; builder = "/bin/sh"; args = [ "-c" "echo foo > $out" ]; system = "${pkgs.system}"; }\' --add-root /tmp/drv') - machine.succeed('systemd-run --pty --wait -M ${containerName} /run/current-system/sw/bin/nix-store --option substitute false --realize /tmp/drv') + # Test if systemd-nspawn provides a working environment for nix to build derivations + # https://nixos.org/guides/nix-pills/07-working-derivation + machine.succeed('systemd-run --pty --wait -M ${containerName} /run/current-system/sw/bin/nix-instantiate --expr \'derivation { name = "myname"; builder = "/bin/sh"; args = [ "-c" "echo foo > $out" ]; system = "${pkgs.system}"; }\' --add-root /tmp/drv') + machine.succeed('systemd-run --pty --wait -M ${containerName} /run/current-system/sw/bin/nix-store --option substitute false --realize /tmp/drv') - # Test nss_mymachines without nscd - machine.succeed('LD_LIBRARY_PATH="/run/current-system/sw/lib" getent -s hosts:mymachines hosts ${containerName}'); + # Test nss_mymachines without nscd + machine.succeed('LD_LIBRARY_PATH="/run/current-system/sw/lib" getent -s hosts:mymachines hosts ${containerName}'); - # Test nss_mymachines via nscd - machine.succeed("getent hosts ${containerName}"); + # Test nss_mymachines via nscd + machine.succeed("getent hosts ${containerName}"); - # Test systemd-nspawn network configuration to container - machine.succeed("networkctl --json=short status ve-${containerName} | ${pkgs.jq}/bin/jq -e '.OperationalState == \"routable\"'"); + # Test systemd-nspawn network configuration to container + machine.succeed("networkctl --json=short status ve-${containerName} | ${pkgs.jq}/bin/jq -e '.OperationalState == \"routable\"'"); - # Test systemd-nspawn network configuration to host - machine.succeed("machinectl shell ${containerName} /run/current-system/sw/bin/networkctl --json=short status host0 | ${pkgs.jq}/bin/jq -r '.OperationalState == \"routable\"'"); + # Test systemd-nspawn network configuration to host + machine.succeed("machinectl shell ${containerName} /run/current-system/sw/bin/networkctl --json=short status host0 | ${pkgs.jq}/bin/jq -r '.OperationalState == \"routable\"'"); - # Test systemd-nspawn network configuration - machine.succeed("ping -n -c 1 ${containerName}"); + # Test systemd-nspawn network configuration + machine.succeed("ping -n -c 1 ${containerName}"); - # Test systemd-nspawn uses a user namespace - machine.succeed("test $(machinectl status ${containerName} | grep 'UID Shift: ' | wc -l) = 1") + # Test systemd-nspawn uses a user namespace + machine.succeed("test $(machinectl status ${containerName} | grep 'UID Shift: ' | wc -l) = 1") - # Test systemd-nspawn reboot - machine.succeed("machinectl shell ${containerName} /run/current-system/sw/bin/reboot"); - machine.wait_until_succeeds("systemctl -M ${containerName} is-active default.target"); + # Test systemd-nspawn reboot + machine.succeed("machinectl shell ${containerName} /run/current-system/sw/bin/reboot"); + machine.wait_until_succeeds("systemctl -M ${containerName} is-active default.target"); - # Test machinectl reboot - machine.succeed("machinectl reboot ${containerName}"); - machine.wait_until_succeeds("systemctl -M ${containerName} is-active default.target"); + # Test machinectl reboot + machine.succeed("machinectl reboot ${containerName}"); + machine.wait_until_succeeds("systemctl -M ${containerName} is-active default.target"); - # Restart machine - machine.shutdown() - machine.start() - machine.wait_for_unit("default.target"); + # Restart machine + machine.shutdown() + machine.start() + machine.wait_for_unit("default.target"); - # Test auto-start - machine.succeed("machinectl show ${containerName}") + # Test auto-start + machine.succeed("machinectl show ${containerName}") - # Test machinectl stop - machine.succeed("machinectl stop ${containerName}"); - machine.wait_until_succeeds("test $(systemctl is-active systemd-nspawn@${containerName}) = inactive"); + # Test machinectl stop + machine.succeed("machinectl stop ${containerName}"); + machine.wait_until_succeeds("test $(systemctl is-active systemd-nspawn@${containerName}) = inactive"); - # Test tmpfs for /tmp - machine.fail("mountpoint /tmp"); + # Test tmpfs for /tmp + machine.fail("mountpoint /tmp"); - # Show to to delete the container - machine.succeed("chattr -i ${containerRoot}/var/empty"); - machine.succeed("rm -rf ${containerRoot}"); + # Show to to delete the container + machine.succeed("chattr -i ${containerRoot}/var/empty"); + machine.succeed("rm -rf ${containerRoot}"); - # Test import tarball, start, stop and remove - machine.succeed("machinectl import-tar ${containerTarball}/tarball/*.tar* ${containerName}"); - machine.succeed("machinectl start ${containerName}"); - machine.wait_until_succeeds("systemctl -M ${containerName} is-active default.target"); - machine.succeed("machinectl stop ${containerName}"); - machine.wait_until_succeeds("test $(systemctl is-active systemd-nspawn@${containerName}) = inactive"); - machine.succeed("machinectl remove ${containerName}"); - ''; -}) + # Test import tarball, start, stop and remove + machine.succeed("machinectl import-tar ${containerTarball}/tarball/*.tar* ${containerName}"); + machine.succeed("machinectl start ${containerName}"); + machine.wait_until_succeeds("systemctl -M ${containerName} is-active default.target"); + machine.succeed("machinectl stop ${containerName}"); + machine.wait_until_succeeds("test $(systemctl is-active systemd-nspawn@${containerName}) = inactive"); + machine.succeed("machinectl remove ${containerName}"); + ''; + } +) diff --git a/nixos/tests/systemd-misc.nix b/nixos/tests/systemd-misc.nix index 0ddd51100463ee..632f3f59d47bee 100644 --- a/nixos/tests/systemd-misc.nix +++ b/nixos/tests/systemd-misc.nix @@ -1,62 +1,66 @@ -import ./make-test-python.nix ({ pkgs, ... }: - -let - exampleScript = pkgs.writeTextFile { - name = "example.sh"; - text = '' - #! ${pkgs.runtimeShell} -e - - while true; do - echo "Example script running" >&2 - ${pkgs.coreutils}/bin/sleep 1 - done - ''; - executable = true; - }; - - unitFile = pkgs.writeTextFile { - name = "example.service"; - text = '' - [Unit] - Description=Example systemd service unit file - - [Service] - ExecStart=${exampleScript} - - [Install] - WantedBy=multi-user.target - ''; - }; -in -{ - name = "systemd-misc"; +import ./make-test-python.nix ( + { pkgs, ... }: - nodes.machine = { pkgs, lib, ... }: { - boot.extraSystemdUnitPaths = [ "/etc/systemd-rw/system" ]; + let + exampleScript = pkgs.writeTextFile { + name = "example.sh"; + text = '' + #! ${pkgs.runtimeShell} -e - users.users.limited = { - isNormalUser = true; - uid = 1000; + while true; do + echo "Example script running" >&2 + ${pkgs.coreutils}/bin/sleep 1 + done + ''; + executable = true; }; - systemd.units."user-1000.slice.d/limits.conf" = { + unitFile = pkgs.writeTextFile { + name = "example.service"; text = '' - [Slice] - TasksAccounting=yes - TasksMax=100 + [Unit] + Description=Example systemd service unit file + + [Service] + ExecStart=${exampleScript} + + [Install] + WantedBy=multi-user.target ''; }; - }; - - testScript = '' - machine.wait_for_unit("multi-user.target") - machine.succeed("mkdir -p /etc/systemd-rw/system") - machine.succeed( - "cp ${unitFile} /etc/systemd-rw/system/example.service" - ) - machine.succeed("systemctl start example.service") - machine.succeed("systemctl status example.service | grep 'Active: active'") - - machine.succeed("systemctl show --property TasksMax --value user-1000.slice | grep 100") - ''; -}) + in + { + name = "systemd-misc"; + + nodes.machine = + { pkgs, lib, ... }: + { + boot.extraSystemdUnitPaths = [ "/etc/systemd-rw/system" ]; + + users.users.limited = { + isNormalUser = true; + uid = 1000; + }; + + systemd.units."user-1000.slice.d/limits.conf" = { + text = '' + [Slice] + TasksAccounting=yes + TasksMax=100 + ''; + }; + }; + + testScript = '' + machine.wait_for_unit("multi-user.target") + machine.succeed("mkdir -p /etc/systemd-rw/system") + machine.succeed( + "cp ${unitFile} /etc/systemd-rw/system/example.service" + ) + machine.succeed("systemctl start example.service") + machine.succeed("systemctl status example.service | grep 'Active: active'") + + machine.succeed("systemctl show --property TasksMax --value user-1000.slice | grep 100") + ''; + } +) diff --git a/nixos/tests/systemd-networkd-bridge.nix b/nixos/tests/systemd-networkd-bridge.nix index f1f8823e84205a..1c21cc113167da 100644 --- a/nixos/tests/systemd-networkd-bridge.nix +++ b/nixos/tests/systemd-networkd-bridge.nix @@ -1,21 +1,22 @@ -/* This test ensures that we can configure spanning-tree protocol - across bridges using systemd-networkd. +/* + This test ensures that we can configure spanning-tree protocol + across bridges using systemd-networkd. - Test topology: + Test topology: - 1 2 3 - node1 --- sw1 --- sw2 --- node2 - \ / - 4 \ / 5 - sw3 - | - 6 | - | - node3 + 1 2 3 + node1 --- sw1 --- sw2 --- node2 + \ / + 4 \ / 5 + sw3 + | + 6 | + | + node3 - where switches 1, 2, and 3 bridge their links and use STP, - and each link is labeled with the VLAN we are assigning it in - virtualisation.vlans. + where switches 1, 2, and 3 bridge their links and use STP, + and each link is labeled with the VLAN we are assigning it in + virtualisation.vlans. */ with builtins; let @@ -26,9 +27,19 @@ let networking.firewall.enable = false; }; - generateNodeConf = { octet, vlan }: - { lib, pkgs, config, ... }: { - imports = [ common/user-account.nix commonConf ]; + generateNodeConf = + { octet, vlan }: + { + lib, + pkgs, + config, + ... + }: + { + imports = [ + common/user-account.nix + commonConf + ]; virtualisation.vlans = [ vlan ]; systemd.network = { enable = true; @@ -41,9 +52,19 @@ let }; }; - generateSwitchConf = vlans: - { lib, pkgs, config, ... }: { - imports = [ common/user-account.nix commonConf ]; + generateSwitchConf = + vlans: + { + lib, + pkgs, + config, + ... + }: + { + imports = [ + common/user-account.nix + commonConf + ]; virtualisation.vlans = vlans; systemd.network = { enable = true; @@ -61,43 +82,63 @@ let matchConfig.Name = "eth*"; networkConfig.Bridge = "br0"; }; - "40-br0" = { matchConfig.Name = "br0"; }; + "40-br0" = { + matchConfig.Name = "br0"; + }; }; }; }; -in import ./make-test-python.nix ({ pkgs, ... }: { - name = "networkd"; - meta = with pkgs.lib.maintainers; { maintainers = [ picnoir ]; }; - nodes = { - node1 = generateNodeConf { - octet = 1; - vlan = 1; +in +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "networkd"; + meta = with pkgs.lib.maintainers; { + maintainers = [ picnoir ]; }; - node2 = generateNodeConf { - octet = 2; - vlan = 3; - }; - node3 = generateNodeConf { - octet = 3; - vlan = 6; + nodes = { + node1 = generateNodeConf { + octet = 1; + vlan = 1; + }; + node2 = generateNodeConf { + octet = 2; + vlan = 3; + }; + node3 = generateNodeConf { + octet = 3; + vlan = 6; + }; + sw1 = generateSwitchConf [ + 1 + 2 + 4 + ]; + sw2 = generateSwitchConf [ + 2 + 3 + 5 + ]; + sw3 = generateSwitchConf [ + 4 + 5 + 6 + ]; }; - sw1 = generateSwitchConf [ 1 2 4 ]; - sw2 = generateSwitchConf [ 2 3 5 ]; - sw3 = generateSwitchConf [ 4 5 6 ]; - }; - testScript = '' - network_nodes = [node1, node2, node3] - network_switches = [sw1, sw2, sw3] - start_all() + testScript = '' + network_nodes = [node1, node2, node3] + network_switches = [sw1, sw2, sw3] + start_all() - for n in network_nodes + network_switches: - n.wait_for_unit("systemd-networkd-wait-online.service") + for n in network_nodes + network_switches: + n.wait_for_unit("systemd-networkd-wait-online.service") - node1.succeed("ping 10.0.0.2 -w 10 -c 1") - node1.succeed("ping 10.0.0.3 -w 10 -c 1") - node2.succeed("ping 10.0.0.1 -w 10 -c 1") - node2.succeed("ping 10.0.0.3 -w 10 -c 1") - node3.succeed("ping 10.0.0.1 -w 10 -c 1") - node3.succeed("ping 10.0.0.2 -w 10 -c 1") - ''; -}) + node1.succeed("ping 10.0.0.2 -w 10 -c 1") + node1.succeed("ping 10.0.0.3 -w 10 -c 1") + node2.succeed("ping 10.0.0.1 -w 10 -c 1") + node2.succeed("ping 10.0.0.3 -w 10 -c 1") + node3.succeed("ping 10.0.0.1 -w 10 -c 1") + node3.succeed("ping 10.0.0.2 -w 10 -c 1") + ''; + } +) diff --git a/nixos/tests/systemd-networkd-dhcpserver-static-leases.nix b/nixos/tests/systemd-networkd-dhcpserver-static-leases.nix index 8c0ebeee97c772..4604b28caf913d 100644 --- a/nixos/tests/systemd-networkd-dhcpserver-static-leases.nix +++ b/nixos/tests/systemd-networkd-dhcpserver-static-leases.nix @@ -1,89 +1,94 @@ # In contrast to systemd-networkd-dhcpserver, this test configures # the router with a static DHCP lease for the client's MAC address. -import ./make-test-python.nix ({ lib, ... }: { - name = "systemd-networkd-dhcpserver-static-leases"; - meta = with lib.maintainers; { - maintainers = [ veehaitch ]; - }; - nodes = { - router = { - virtualisation.vlans = [ 1 ]; - systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; - networking = { - useNetworkd = true; - useDHCP = false; - firewall.enable = false; - }; - systemd.network = { - networks = { - # systemd-networkd will load the first network unit file - # that matches, ordered lexiographically by filename. - # /etc/systemd/network/{40-eth1,99-main}.network already - # exists. This network unit must be loaded for the test, - # however, hence why this network is named such. - "01-eth1" = { - name = "eth1"; - networkConfig = { - DHCPServer = true; - Address = "10.0.0.1/24"; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "systemd-networkd-dhcpserver-static-leases"; + meta = with lib.maintainers; { + maintainers = [ veehaitch ]; + }; + nodes = { + router = { + virtualisation.vlans = [ 1 ]; + systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; + networking = { + useNetworkd = true; + useDHCP = false; + firewall.enable = false; + }; + systemd.network = { + networks = { + # systemd-networkd will load the first network unit file + # that matches, ordered lexiographically by filename. + # /etc/systemd/network/{40-eth1,99-main}.network already + # exists. This network unit must be loaded for the test, + # however, hence why this network is named such. + "01-eth1" = { + name = "eth1"; + networkConfig = { + DHCPServer = true; + Address = "10.0.0.1/24"; + }; + dhcpServerStaticLeases = [ + { + MACAddress = "02:de:ad:be:ef:01"; + Address = "10.0.0.10"; + } + ]; }; - dhcpServerStaticLeases = [{ - MACAddress = "02:de:ad:be:ef:01"; - Address = "10.0.0.10"; - }]; }; }; }; - }; - client = { - virtualisation.vlans = [ 1 ]; - systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; - systemd.network = { - enable = true; - links."10-eth1" = { - matchConfig.OriginalName = "eth1"; - linkConfig.MACAddress = "02:de:ad:be:ef:01"; - }; - networks."40-eth1" = { - matchConfig.Name = "eth1"; - networkConfig = { - DHCP = "ipv4"; - IPv6AcceptRA = false; + client = { + virtualisation.vlans = [ 1 ]; + systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; + systemd.network = { + enable = true; + links."10-eth1" = { + matchConfig.OriginalName = "eth1"; + linkConfig.MACAddress = "02:de:ad:be:ef:01"; + }; + networks."40-eth1" = { + matchConfig.Name = "eth1"; + networkConfig = { + DHCP = "ipv4"; + IPv6AcceptRA = false; + }; + # This setting is important to have the router assign the + # configured lease based on the client's MAC address. Also see: + # https://github.com/systemd/systemd/issues/21368#issuecomment-982193546 + dhcpV4Config.ClientIdentifier = "mac"; + linkConfig.RequiredForOnline = "routable"; }; - # This setting is important to have the router assign the - # configured lease based on the client's MAC address. Also see: - # https://github.com/systemd/systemd/issues/21368#issuecomment-982193546 - dhcpV4Config.ClientIdentifier = "mac"; - linkConfig.RequiredForOnline = "routable"; }; - }; - networking = { - useDHCP = false; - firewall.enable = false; - interfaces.eth1 = lib.mkForce {}; + networking = { + useDHCP = false; + firewall.enable = false; + interfaces.eth1 = lib.mkForce { }; + }; }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - with subtest("check router network configuration"): - router.wait_for_unit("systemd-networkd-wait-online.service") - eth1_status = router.succeed("networkctl status eth1") - assert "Network File: /etc/systemd/network/01-eth1.network" in eth1_status, \ - "The router interface eth1 is not using the expected network file" - assert "10.0.0.1" in eth1_status, "Did not find expected router IPv4" + with subtest("check router network configuration"): + router.wait_for_unit("systemd-networkd-wait-online.service") + eth1_status = router.succeed("networkctl status eth1") + assert "Network File: /etc/systemd/network/01-eth1.network" in eth1_status, \ + "The router interface eth1 is not using the expected network file" + assert "10.0.0.1" in eth1_status, "Did not find expected router IPv4" - with subtest("check client network configuration"): - client.wait_for_unit("systemd-networkd-wait-online.service") - eth1_status = client.succeed("networkctl status eth1") - assert "Network File: /etc/systemd/network/40-eth1.network" in eth1_status, \ - "The client interface eth1 is not using the expected network file" - assert "10.0.0.10" in eth1_status, "Did not find expected client IPv4" + with subtest("check client network configuration"): + client.wait_for_unit("systemd-networkd-wait-online.service") + eth1_status = client.succeed("networkctl status eth1") + assert "Network File: /etc/systemd/network/40-eth1.network" in eth1_status, \ + "The client interface eth1 is not using the expected network file" + assert "10.0.0.10" in eth1_status, "Did not find expected client IPv4" - with subtest("router and client can reach each other"): - client.wait_until_succeeds("ping -c 5 10.0.0.1") - router.wait_until_succeeds("ping -c 5 10.0.0.10") - ''; -}) + with subtest("router and client can reach each other"): + client.wait_until_succeeds("ping -c 5 10.0.0.1") + router.wait_until_succeeds("ping -c 5 10.0.0.10") + ''; + } +) diff --git a/nixos/tests/systemd-networkd-dhcpserver.nix b/nixos/tests/systemd-networkd-dhcpserver.nix index fda0c9d6419380..59cc2cfd524560 100644 --- a/nixos/tests/systemd-networkd-dhcpserver.nix +++ b/nixos/tests/systemd-networkd-dhcpserver.nix @@ -7,106 +7,121 @@ # br0 ----untagged---v # +---PVID 1+VLAN 2---[bridge]---PVID 2---eth1 # vlan2 ---VLAN 2----^ -import ./make-test-python.nix ({pkgs, ...}: { - name = "systemd-networkd-dhcpserver"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; - nodes = { - router = { config, pkgs, ... }: { - virtualisation.vlans = [ 1 ]; - systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; - networking = { - useNetworkd = true; - useDHCP = false; - firewall.enable = false; - }; - systemd.network = { - netdevs = { - br0 = { - enable = true; - netdevConfig = { - Name = "br0"; - Kind = "bridge"; - }; - extraConfig = '' - [Bridge] - VLANFiltering=yes - DefaultPVID=none - ''; - }; - vlan2 = { - enable = true; - netdevConfig = { - Name = "vlan2"; - Kind = "vlan"; - }; - vlanConfig.Id = 2; - }; - }; - networks = { - # systemd-networkd will load the first network unit file - # that matches, ordered lexiographically by filename. - # /etc/systemd/network/{40-eth1,99-main}.network already - # exists. This network unit must be loaded for the test, - # however, hence why this network is named such. - "01-eth1" = { - name = "eth1"; - networkConfig.Bridge = "br0"; - bridgeVLANs = [ - { PVID = 2; EgressUntagged = 2; } - ]; - }; - "02-br0" = { - name = "br0"; - networkConfig = { - DHCPServer = true; - Address = "10.0.0.1/24"; - VLAN = ["vlan2"]; - }; - dhcpServerConfig = { - PoolOffset = 100; - PoolSize = 1; - }; - bridgeVLANs = [ - { PVID = 1; EgressUntagged = 1; } - { VLAN = 2; } - ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "systemd-networkd-dhcpserver"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; + nodes = { + router = + { config, pkgs, ... }: + { + virtualisation.vlans = [ 1 ]; + systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; + networking = { + useNetworkd = true; + useDHCP = false; + firewall.enable = false; }; - "02-vlan2" = { - name = "vlan2"; - networkConfig = { - DHCPServer = true; - Address = "10.0.2.1/24"; + systemd.network = { + netdevs = { + br0 = { + enable = true; + netdevConfig = { + Name = "br0"; + Kind = "bridge"; + }; + extraConfig = '' + [Bridge] + VLANFiltering=yes + DefaultPVID=none + ''; + }; + vlan2 = { + enable = true; + netdevConfig = { + Name = "vlan2"; + Kind = "vlan"; + }; + vlanConfig.Id = 2; + }; }; - dhcpServerConfig = { - PoolOffset = 100; - PoolSize = 1; + networks = { + # systemd-networkd will load the first network unit file + # that matches, ordered lexiographically by filename. + # /etc/systemd/network/{40-eth1,99-main}.network already + # exists. This network unit must be loaded for the test, + # however, hence why this network is named such. + "01-eth1" = { + name = "eth1"; + networkConfig.Bridge = "br0"; + bridgeVLANs = [ + { + PVID = 2; + EgressUntagged = 2; + } + ]; + }; + "02-br0" = { + name = "br0"; + networkConfig = { + DHCPServer = true; + Address = "10.0.0.1/24"; + VLAN = [ "vlan2" ]; + }; + dhcpServerConfig = { + PoolOffset = 100; + PoolSize = 1; + }; + bridgeVLANs = [ + { + PVID = 1; + EgressUntagged = 1; + } + { VLAN = 2; } + ]; + }; + "02-vlan2" = { + name = "vlan2"; + networkConfig = { + DHCPServer = true; + Address = "10.0.2.1/24"; + }; + dhcpServerConfig = { + PoolOffset = 100; + PoolSize = 1; + }; + }; }; }; }; - }; - }; - client = { config, pkgs, ... }: { - virtualisation.vlans = [ 1 ]; - systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; - networking = { - useNetworkd = true; - useDHCP = false; - firewall.enable = false; - interfaces.eth1.useDHCP = true; - }; + client = + { config, pkgs, ... }: + { + virtualisation.vlans = [ 1 ]; + systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; + networking = { + useNetworkd = true; + useDHCP = false; + firewall.enable = false; + interfaces.eth1.useDHCP = true; + }; + }; }; - }; - testScript = { ... }: '' - start_all() + testScript = + { ... }: + '' + start_all() - router.systemctl("start network-online.target") - client.systemctl("start network-online.target") - router.wait_for_unit("systemd-networkd-wait-online.service") - client.wait_for_unit("systemd-networkd-wait-online.service") - client.wait_until_succeeds("ping -c 5 10.0.2.1") - router.wait_until_succeeds("ping -c 5 10.0.2.100") - ''; -}) + router.systemctl("start network-online.target") + client.systemctl("start network-online.target") + router.wait_for_unit("systemd-networkd-wait-online.service") + client.wait_for_unit("systemd-networkd-wait-online.service") + client.wait_until_succeeds("ping -c 5 10.0.2.1") + router.wait_until_succeeds("ping -c 5 10.0.2.100") + ''; + } +) diff --git a/nixos/tests/systemd-networkd-ipv6-prefix-delegation.nix b/nixos/tests/systemd-networkd-ipv6-prefix-delegation.nix index 2ea6d0effd536d..5ab21bee01957f 100644 --- a/nixos/tests/systemd-networkd-ipv6-prefix-delegation.nix +++ b/nixos/tests/systemd-networkd-ipv6-prefix-delegation.nix @@ -7,329 +7,356 @@ # - VLAN 1 is the connection between the ISP and the router # - VLAN 2 is the connection between the router and the client -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "systemd-networkd-ipv6-prefix-delegation"; - meta = with lib.maintainers; { - maintainers = [ andir hexa ]; - }; - nodes = { - - # The ISP's routers job is to delegate IPv6 prefixes via DHCPv6. Like with - # regular IPv6 auto-configuration it will also emit IPv6 router - # advertisements (RAs). Those RA's will not carry a prefix but in contrast - # just set the "Other" flag to indicate to the receiving nodes that they - # should attempt DHCPv6. - # - # Note: On the ISPs device we don't really care if we are using networkd in - # this example. That being said we can't use it (yet) as networkd doesn't - # implement the serving side of DHCPv6. We will use ISC Kea for that task. - isp = { lib, pkgs, ... }: { - virtualisation.vlans = [ 1 ]; - networking = { - useDHCP = false; - firewall.enable = false; - interfaces.eth1 = lib.mkForce {}; # Don't use scripted networking - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "systemd-networkd-ipv6-prefix-delegation"; + meta = with lib.maintainers; { + maintainers = [ + andir + hexa + ]; + }; + nodes = { + + # The ISP's routers job is to delegate IPv6 prefixes via DHCPv6. Like with + # regular IPv6 auto-configuration it will also emit IPv6 router + # advertisements (RAs). Those RA's will not carry a prefix but in contrast + # just set the "Other" flag to indicate to the receiving nodes that they + # should attempt DHCPv6. + # + # Note: On the ISPs device we don't really care if we are using networkd in + # this example. That being said we can't use it (yet) as networkd doesn't + # implement the serving side of DHCPv6. We will use ISC Kea for that task. + isp = + { lib, pkgs, ... }: + { + virtualisation.vlans = [ 1 ]; + networking = { + useDHCP = false; + firewall.enable = false; + interfaces.eth1 = lib.mkForce { }; # Don't use scripted networking + }; - systemd.network = { - enable = true; - - networks = { - "eth1" = { - matchConfig.Name = "eth1"; - address = [ - "2001:DB8::1/64" - ]; - networkConfig.IPv4Forwarding = true; - networkConfig.IPv6Forwarding = true; + systemd.network = { + enable = true; + + networks = { + "eth1" = { + matchConfig.Name = "eth1"; + address = [ + "2001:DB8::1/64" + ]; + networkConfig.IPv4Forwarding = true; + networkConfig.IPv6Forwarding = true; + }; + }; }; - }; - }; - # Since we want to program the routes that we delegate to the "customer" - # into our routing table we must provide kea with the required capability. - systemd.services.kea-dhcp6-server.serviceConfig = { - AmbientCapabilities = [ "CAP_NET_ADMIN" ]; - CapabilityBoundingSet = [ "CAP_NET_ADMIN" ]; - }; + # Since we want to program the routes that we delegate to the "customer" + # into our routing table we must provide kea with the required capability. + systemd.services.kea-dhcp6-server.serviceConfig = { + AmbientCapabilities = [ "CAP_NET_ADMIN" ]; + CapabilityBoundingSet = [ "CAP_NET_ADMIN" ]; + }; - services = { - # Configure the DHCPv6 server to hand out both IA_NA and IA_PD. - # - # We will hand out /48 prefixes from the subnet 2001:DB8:F000::/36. - # That gives us ~8k prefixes. That should be enough for this test. - # - # Since (usually) you will not receive a prefix with the router - # advertisements we also hand out /128 leases from the range - # 2001:DB8:0000:0000:FFFF::/112. - kea.dhcp6 = { - enable = true; - settings = { - interfaces-config.interfaces = [ "eth1" ]; - subnet6 = [ { - id = 1; - interface = "eth1"; - subnet = "2001:DB8::/32"; - pd-pools = [ { - prefix = "2001:DB8:1000::"; - prefix-len = 36; - delegated-len = 48; - } ]; - pools = [ { - pool = "2001:DB8:0000:0000::-2001:DB8:0FFF:FFFF::FFFF"; - } ]; - } ]; - - # This is the glue between Kea and the Kernel FIB. DHCPv6 - # rightfully has no concept of setting up a route in your - # FIB. This step really depends on your setup. + services = { + # Configure the DHCPv6 server to hand out both IA_NA and IA_PD. # - # In a production environment your DHCPv6 server is likely - # not the router. You might want to consider BGP, NETCONF - # calls, … in those cases. + # We will hand out /48 prefixes from the subnet 2001:DB8:F000::/36. + # That gives us ~8k prefixes. That should be enough for this test. # - # In this example we use the run script hook, that lets use - # execute anything and passes information via the environment. - # https://kea.readthedocs.io/en/kea-2.2.0/arm/hooks.html#run-script-run-script-support-for-external-hook-scripts - hooks-libraries = [ { - library = "${pkgs.kea}/lib/kea/hooks/libdhcp_run_script.so"; - parameters = { - name = pkgs.writeShellScript "kea-run-hooks" '' - export PATH="${lib.makeBinPath (with pkgs; [ coreutils iproute2 ])}" - - set -euxo pipefail - - leases6_committed() { - for i in $(seq $LEASES6_SIZE); do - idx=$((i-1)) - prefix_var="LEASES6_AT''${idx}_ADDRESS" - plen_var="LEASES6_AT''${idx}_PREFIX_LEN" - - ip -6 route replace ''${!prefix_var}/''${!plen_var} via $QUERY6_REMOTE_ADDR dev $QUERY6_IFACE_NAME - done + # Since (usually) you will not receive a prefix with the router + # advertisements we also hand out /128 leases from the range + # 2001:DB8:0000:0000:FFFF::/112. + kea.dhcp6 = { + enable = true; + settings = { + interfaces-config.interfaces = [ "eth1" ]; + subnet6 = [ + { + id = 1; + interface = "eth1"; + subnet = "2001:DB8::/32"; + pd-pools = [ + { + prefix = "2001:DB8:1000::"; + prefix-len = 36; + delegated-len = 48; + } + ]; + pools = [ + { + pool = "2001:DB8:0000:0000::-2001:DB8:0FFF:FFFF::FFFF"; + } + ]; } - - unknown_handler() { - echo "Unhandled function call ''${*}" - exit 123 + ]; + + # This is the glue between Kea and the Kernel FIB. DHCPv6 + # rightfully has no concept of setting up a route in your + # FIB. This step really depends on your setup. + # + # In a production environment your DHCPv6 server is likely + # not the router. You might want to consider BGP, NETCONF + # calls, … in those cases. + # + # In this example we use the run script hook, that lets use + # execute anything and passes information via the environment. + # https://kea.readthedocs.io/en/kea-2.2.0/arm/hooks.html#run-script-run-script-support-for-external-hook-scripts + hooks-libraries = [ + { + library = "${pkgs.kea}/lib/kea/hooks/libdhcp_run_script.so"; + parameters = { + name = pkgs.writeShellScript "kea-run-hooks" '' + export PATH="${ + lib.makeBinPath ( + with pkgs; + [ + coreutils + iproute2 + ] + ) + }" + + set -euxo pipefail + + leases6_committed() { + for i in $(seq $LEASES6_SIZE); do + idx=$((i-1)) + prefix_var="LEASES6_AT''${idx}_ADDRESS" + plen_var="LEASES6_AT''${idx}_PREFIX_LEN" + + ip -6 route replace ''${!prefix_var}/''${!plen_var} via $QUERY6_REMOTE_ADDR dev $QUERY6_IFACE_NAME + done + } + + unknown_handler() { + echo "Unhandled function call ''${*}" + exit 123 + } + + case "$1" in + "leases6_committed") + leases6_committed + ;; + *) + unknown_handler "''${@}" + ;; + esac + ''; + sync = false; + }; } - - case "$1" in - "leases6_committed") - leases6_committed - ;; - *) - unknown_handler "''${@}" - ;; - esac - ''; - sync = false; + ]; }; - } ]; - }; - }; + }; - # Finally we have to set up the router advertisements. While we could be - # using networkd or bird for this task `radvd` is probably the most - # venerable of them all. It was made explicitly for this purpose and - # the configuration is much more straightforward than what networkd - # requires. - # As outlined above we will have to set the `Managed` flag as otherwise - # the clients will not know if they should do DHCPv6. (Some do - # anyway/always) - radvd = { - enable = true; - config = '' - interface eth1 { - AdvSendAdvert on; - AdvManagedFlag on; - AdvOtherConfigFlag off; # we don't really have DNS or NTP or anything like that to distribute - prefix ::/64 { - AdvOnLink on; - AdvAutonomous on; - }; + # Finally we have to set up the router advertisements. While we could be + # using networkd or bird for this task `radvd` is probably the most + # venerable of them all. It was made explicitly for this purpose and + # the configuration is much more straightforward than what networkd + # requires. + # As outlined above we will have to set the `Managed` flag as otherwise + # the clients will not know if they should do DHCPv6. (Some do + # anyway/always) + radvd = { + enable = true; + config = '' + interface eth1 { + AdvSendAdvert on; + AdvManagedFlag on; + AdvOtherConfigFlag off; # we don't really have DNS or NTP or anything like that to distribute + prefix ::/64 { + AdvOnLink on; + AdvAutonomous on; + }; + }; + ''; }; - ''; - }; - }; - }; + }; + }; - # This will be our (residential) router that receives the IPv6 prefix (IA_PD) - # and /128 (IA_NA) allocation. - # - # Here we will actually start using networkd. - router = { - virtualisation.vlans = [ 1 2 ]; - systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; - - boot.kernel.sysctl = { - # we want to forward packets from the ISP to the client and back. - "net.ipv6.conf.all.forwarding" = 1; - }; + # This will be our (residential) router that receives the IPv6 prefix (IA_PD) + # and /128 (IA_NA) allocation. + # + # Here we will actually start using networkd. + router = { + virtualisation.vlans = [ + 1 + 2 + ]; + systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; + + boot.kernel.sysctl = { + # we want to forward packets from the ISP to the client and back. + "net.ipv6.conf.all.forwarding" = 1; + }; - networking = { - useNetworkd = true; - useDHCP = false; - # Consider enabling this in production and generating firewall rules - # for fowarding/input from the configured interfaces so you do not have - # to manage multiple places - firewall.enable = false; - interfaces.eth1.ipv6.addresses = lib.mkForce [ ]; - }; + networking = { + useNetworkd = true; + useDHCP = false; + # Consider enabling this in production and generating firewall rules + # for fowarding/input from the configured interfaces so you do not have + # to manage multiple places + firewall.enable = false; + interfaces.eth1.ipv6.addresses = lib.mkForce [ ]; + }; - systemd.network = { - networks = { - # systemd-networkd will load the first network unit file - # that matches, ordered lexiographically by filename. - # /etc/systemd/network/{40-eth1,99-main}.network already - # exists. This network unit must be loaded for the test, - # however, hence why this network is named such. - - # Configuration of the interface to the ISP. - # We must request accept RAs and request the PD prefix. - "01-eth1" = { - name = "eth1"; - networkConfig = { - Description = "ISP interface"; - IPv6AcceptRA = true; - #DHCP = false; # no need for legacy IP - }; - linkConfig = { - # We care about this interface when talking about being "online". - # If this interface is in the `routable` state we can reach - # others and they should be able to reach us. - RequiredForOnline = "routable"; - }; - # This configures the DHCPv6 client part towards the ISPs DHCPv6 server. - dhcpV6Config = { - # We have to include a request for a prefix in our DHCPv6 client - # request packets. - # Otherwise the upstream DHCPv6 server wouldn't know if we want a - # prefix or not. Note: On some installation it makes sense to - # always force that option on the DHPCv6 server since there are - # certain CPEs that are just not setting this field but happily - # accept the delegated prefix. - PrefixDelegationHint = "::/48"; - }; - ipv6SendRAConfig = { - # Let networkd know that we would very much like to use DHCPv6 - # to obtain the "managed" information. Not sure why they can't - # just take that from the upstream RAs. - Managed = true; + systemd.network = { + networks = { + # systemd-networkd will load the first network unit file + # that matches, ordered lexiographically by filename. + # /etc/systemd/network/{40-eth1,99-main}.network already + # exists. This network unit must be loaded for the test, + # however, hence why this network is named such. + + # Configuration of the interface to the ISP. + # We must request accept RAs and request the PD prefix. + "01-eth1" = { + name = "eth1"; + networkConfig = { + Description = "ISP interface"; + IPv6AcceptRA = true; + #DHCP = false; # no need for legacy IP + }; + linkConfig = { + # We care about this interface when talking about being "online". + # If this interface is in the `routable` state we can reach + # others and they should be able to reach us. + RequiredForOnline = "routable"; + }; + # This configures the DHCPv6 client part towards the ISPs DHCPv6 server. + dhcpV6Config = { + # We have to include a request for a prefix in our DHCPv6 client + # request packets. + # Otherwise the upstream DHCPv6 server wouldn't know if we want a + # prefix or not. Note: On some installation it makes sense to + # always force that option on the DHPCv6 server since there are + # certain CPEs that are just not setting this field but happily + # accept the delegated prefix. + PrefixDelegationHint = "::/48"; + }; + ipv6SendRAConfig = { + # Let networkd know that we would very much like to use DHCPv6 + # to obtain the "managed" information. Not sure why they can't + # just take that from the upstream RAs. + Managed = true; + }; }; - }; - # Interface to the client. Here we should redistribute a /64 from - # the prefix we received from the ISP. - "01-eth2" = { - name = "eth2"; - networkConfig = { - Description = "Client interface"; - # The client shouldn't be allowed to send us RAs, that would be weird. - IPv6AcceptRA = false; - - # Delegate prefixes from the DHCPv6 PD pool. - DHCPPrefixDelegation = true; - IPv6SendRA = true; - }; + # Interface to the client. Here we should redistribute a /64 from + # the prefix we received from the ISP. + "01-eth2" = { + name = "eth2"; + networkConfig = { + Description = "Client interface"; + # The client shouldn't be allowed to send us RAs, that would be weird. + IPv6AcceptRA = false; + + # Delegate prefixes from the DHCPv6 PD pool. + DHCPPrefixDelegation = true; + IPv6SendRA = true; + }; - # In a production environment you should consider setting these as well: - # ipv6SendRAConfig = { + # In a production environment you should consider setting these as well: + # ipv6SendRAConfig = { #EmitDNS = true; #EmitDomains = true; #DNS= = "fe80::1"; # or whatever "well known" IP your router will have on the inside. - # }; - - # This adds a "random" ULA prefix to the interface that is being - # advertised to the clients. - # Not used in this test. - # ipv6Prefixes = [ - # { - # ipv6PrefixConfig = { - # AddressAutoconfiguration = true; - # PreferredLifetimeSec = 1800; - # ValidLifetimeSec = 1800; - # }; - # } - # ]; - }; + # }; + + # This adds a "random" ULA prefix to the interface that is being + # advertised to the clients. + # Not used in this test. + # ipv6Prefixes = [ + # { + # ipv6PrefixConfig = { + # AddressAutoconfiguration = true; + # PreferredLifetimeSec = 1800; + # ValidLifetimeSec = 1800; + # }; + # } + # ]; + }; - # finally we are going to add a static IPv6 unique local address to - # the "lo" interface. This will serve as ICMPv6 echo target to - # verify connectivity from the client to the router. - "01-lo" = { - name = "lo"; - addresses = [ - { Address = "FD42::1/128"; } - ]; + # finally we are going to add a static IPv6 unique local address to + # the "lo" interface. This will serve as ICMPv6 echo target to + # verify connectivity from the client to the router. + "01-lo" = { + name = "lo"; + addresses = [ + { Address = "FD42::1/128"; } + ]; + }; }; }; }; - }; - # This is the client behind the router. We should be receiving router - # advertisements for both the ULA and the delegated prefix. - # All we have to do is boot with the default (networkd) configuration. - client = { - virtualisation.vlans = [ 2 ]; - systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; - networking = { - useNetworkd = true; - useDHCP = false; - interfaces.eth1.ipv6.addresses = lib.mkForce [ ]; + # This is the client behind the router. We should be receiving router + # advertisements for both the ULA and the delegated prefix. + # All we have to do is boot with the default (networkd) configuration. + client = { + virtualisation.vlans = [ 2 ]; + systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug"; + networking = { + useNetworkd = true; + useDHCP = false; + interfaces.eth1.ipv6.addresses = lib.mkForce [ ]; + }; }; }; - }; - - testScript = '' - # First start the router and wait for it it reach a state where we are - # certain networkd is up and it is able to send out RAs - router.start() - router.wait_for_unit("systemd-networkd.service") - - # After that we can boot the client and wait for the network online target. - # Since we only care about IPv6 that should not involve waiting for legacy - # IP leases. - client.start() - client.systemctl("start network-online.target") - client.wait_for_unit("network-online.target") - - # the static address on the router should not be reachable - client.wait_until_succeeds("ping -6 -c 1 FD42::1") - - # the global IP of the ISP router should still not be a reachable - router.fail("ping -6 -c 1 2001:DB8::1") - - # Once we have internal connectivity boot up the ISP - isp.start() - - # Since for the ISP "being online" should have no real meaning we just - # wait for the target where all the units have been started. - # It probably still takes a few more seconds for all the RA timers to be - # fired etc.. - isp.wait_for_unit("multi-user.target") - - # wait until the uplink interface has a good status - router.systemctl("start network-online.target") - router.wait_for_unit("network-online.target") - router.wait_until_succeeds("ping -6 -c1 2001:DB8::1") - - # shortly after that the client should have received it's global IPv6 - # address and thus be able to ping the ISP - client.wait_until_succeeds("ping -6 -c1 2001:DB8::1") - - # verify that we got a globally scoped address in eth1 from the - # documentation prefix - ip_output = client.succeed("ip --json -6 address show dev eth1") - - import json - - ip_json = json.loads(ip_output)[0] - assert any( - addr["local"].upper().startswith("2001:DB8:") - for addr in ip_json["addr_info"] - if addr["scope"] == "global" - ) - ''; -}) + + testScript = '' + # First start the router and wait for it it reach a state where we are + # certain networkd is up and it is able to send out RAs + router.start() + router.wait_for_unit("systemd-networkd.service") + + # After that we can boot the client and wait for the network online target. + # Since we only care about IPv6 that should not involve waiting for legacy + # IP leases. + client.start() + client.systemctl("start network-online.target") + client.wait_for_unit("network-online.target") + + # the static address on the router should not be reachable + client.wait_until_succeeds("ping -6 -c 1 FD42::1") + + # the global IP of the ISP router should still not be a reachable + router.fail("ping -6 -c 1 2001:DB8::1") + + # Once we have internal connectivity boot up the ISP + isp.start() + + # Since for the ISP "being online" should have no real meaning we just + # wait for the target where all the units have been started. + # It probably still takes a few more seconds for all the RA timers to be + # fired etc.. + isp.wait_for_unit("multi-user.target") + + # wait until the uplink interface has a good status + router.systemctl("start network-online.target") + router.wait_for_unit("network-online.target") + router.wait_until_succeeds("ping -6 -c1 2001:DB8::1") + + # shortly after that the client should have received it's global IPv6 + # address and thus be able to ping the ISP + client.wait_until_succeeds("ping -6 -c1 2001:DB8::1") + + # verify that we got a globally scoped address in eth1 from the + # documentation prefix + ip_output = client.succeed("ip --json -6 address show dev eth1") + + import json + + ip_json = json.loads(ip_output)[0] + assert any( + addr["local"].upper().startswith("2001:DB8:") + for addr in ip_json["addr_info"] + if addr["scope"] == "global" + ) + ''; + } +) diff --git a/nixos/tests/systemd-networkd-vrf.nix b/nixos/tests/systemd-networkd-vrf.nix index a7875bb177faf9..357431fc297ad1 100644 --- a/nixos/tests/systemd-networkd-vrf.nix +++ b/nixos/tests/systemd-networkd-vrf.nix @@ -1,187 +1,202 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: let - inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; - - mkNode = vlan: id: { - virtualisation.vlans = [ vlan ]; - networking = { - useDHCP = false; - useNetworkd = true; - }; - - systemd.network = { - enable = true; - - networks."10-eth${toString vlan}" = { - matchConfig.Name = "eth${toString vlan}"; - linkConfig.RequiredForOnline = "no"; - networkConfig = { - Address = "192.168.${toString vlan}.${toString id}/24"; - IPv4Forwarding = "yes"; - IPv6Forwarding = "yes"; - }; - }; - }; - }; -in { - name = "systemd-networkd-vrf"; - meta.maintainers = with lib.maintainers; [ ma27 ]; - - nodes = { - client = { pkgs, ... }: { - virtualisation.vlans = [ 1 2 ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; + mkNode = vlan: id: { + virtualisation.vlans = [ vlan ]; networking = { useDHCP = false; useNetworkd = true; - firewall.checkReversePath = "loose"; }; systemd.network = { enable = true; - netdevs."10-vrf1" = { - netdevConfig = { - Kind = "vrf"; - Name = "vrf1"; - MTUBytes = "1300"; - }; - vrfConfig.Table = 23; - }; - netdevs."10-vrf2" = { - netdevConfig = { - Kind = "vrf"; - Name = "vrf2"; - MTUBytes = "1300"; - }; - vrfConfig.Table = 42; - }; - - networks."10-vrf1" = { - matchConfig.Name = "vrf1"; - networkConfig.IPv4Forwarding = "yes"; - networkConfig.IPv6Forwarding = "yes"; - routes = [ - { Destination = "192.168.1.2"; Metric = 100; } - ]; - }; - networks."10-vrf2" = { - matchConfig.Name = "vrf2"; - networkConfig.IPv4Forwarding = "yes"; - networkConfig.IPv6Forwarding = "yes"; - routes = [ - { Destination = "192.168.2.3"; Metric = 100; } - ]; - }; - - networks."10-eth1" = { - matchConfig.Name = "eth1"; + networks."10-eth${toString vlan}" = { + matchConfig.Name = "eth${toString vlan}"; linkConfig.RequiredForOnline = "no"; networkConfig = { - VRF = "vrf1"; - Address = "192.168.1.1/24"; + Address = "192.168.${toString vlan}.${toString id}/24"; IPv4Forwarding = "yes"; IPv6Forwarding = "yes"; }; }; - networks."10-eth2" = { - matchConfig.Name = "eth2"; - linkConfig.RequiredForOnline = "no"; - networkConfig = { - VRF = "vrf2"; - Address = "192.168.2.1/24"; - IPv4Forwarding = "yes"; - IPv6Forwarding = "yes"; + }; + }; + in + { + name = "systemd-networkd-vrf"; + meta.maintainers = with lib.maintainers; [ ma27 ]; + + nodes = { + client = + { pkgs, ... }: + { + virtualisation.vlans = [ + 1 + 2 + ]; + + networking = { + useDHCP = false; + useNetworkd = true; + firewall.checkReversePath = "loose"; + }; + + systemd.network = { + enable = true; + + netdevs."10-vrf1" = { + netdevConfig = { + Kind = "vrf"; + Name = "vrf1"; + MTUBytes = "1300"; + }; + vrfConfig.Table = 23; + }; + netdevs."10-vrf2" = { + netdevConfig = { + Kind = "vrf"; + Name = "vrf2"; + MTUBytes = "1300"; + }; + vrfConfig.Table = 42; + }; + + networks."10-vrf1" = { + matchConfig.Name = "vrf1"; + networkConfig.IPv4Forwarding = "yes"; + networkConfig.IPv6Forwarding = "yes"; + routes = [ + { + Destination = "192.168.1.2"; + Metric = 100; + } + ]; + }; + networks."10-vrf2" = { + matchConfig.Name = "vrf2"; + networkConfig.IPv4Forwarding = "yes"; + networkConfig.IPv6Forwarding = "yes"; + routes = [ + { + Destination = "192.168.2.3"; + Metric = 100; + } + ]; + }; + + networks."10-eth1" = { + matchConfig.Name = "eth1"; + linkConfig.RequiredForOnline = "no"; + networkConfig = { + VRF = "vrf1"; + Address = "192.168.1.1/24"; + IPv4Forwarding = "yes"; + IPv6Forwarding = "yes"; + }; + }; + networks."10-eth2" = { + matchConfig.Name = "eth2"; + linkConfig.RequiredForOnline = "no"; + networkConfig = { + VRF = "vrf2"; + Address = "192.168.2.1/24"; + IPv4Forwarding = "yes"; + IPv6Forwarding = "yes"; + }; + }; }; }; - }; + + node1 = lib.mkMerge [ + (mkNode 1 2) + { + services.openssh.enable = true; + users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; + } + ]; + + node2 = mkNode 2 3; + node3 = mkNode 2 4; }; - node1 = lib.mkMerge [ - (mkNode 1 2) - { - services.openssh.enable = true; - users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; - } - ]; - - node2 = mkNode 2 3; - node3 = mkNode 2 4; - }; - - testScript = '' - import json - - def compare(raw_json, to_compare): - data = json.loads(raw_json) - assert len(raw_json) >= len(to_compare) - for i, row in enumerate(to_compare): - actual = data[i] - assert len(row.keys()) > 0 - for key, value in row.items(): - assert value == actual[key], f""" - In entry {i}, value {key}: got: {actual[key]}, expected {value} - """ - - - start_all() - - client.wait_for_unit("network.target") - node1.wait_for_unit("network.target") - node2.wait_for_unit("network.target") - node3.wait_for_unit("network.target") - - # Check that networkd properly configures the main routing table - # and the routing tables for the VRF. - with subtest("check vrf routing tables"): - compare( - client.succeed("ip --json -4 route list"), - [ - {"dst": "192.168.1.2", "dev": "vrf1", "metric": 100}, - {"dst": "192.168.2.3", "dev": "vrf2", "metric": 100} - ] - ) - compare( - client.succeed("ip --json -4 route list table 23"), - [ - {"dst": "192.168.1.0/24", "dev": "eth1", "prefsrc": "192.168.1.1"}, - {"type": "local", "dst": "192.168.1.1", "dev": "eth1", "prefsrc": "192.168.1.1"}, - {"type": "broadcast", "dev": "eth1", "prefsrc": "192.168.1.1", "dst": "192.168.1.255"} - ] - ) - compare( - client.succeed("ip --json -4 route list table 42"), - [ - {"dst": "192.168.2.0/24", "dev": "eth2", "prefsrc": "192.168.2.1"}, - {"type": "local", "dst": "192.168.2.1", "dev": "eth2", "prefsrc": "192.168.2.1"}, - {"type": "broadcast", "dev": "eth2", "prefsrc": "192.168.2.1", "dst": "192.168.2.255"} - ] - ) - - # Ensure that other nodes are reachable via ICMP through the VRF. - with subtest("icmp through vrf works"): - client.succeed("ping -c5 192.168.1.2") - client.succeed("ping -c5 192.168.2.3") - - # Test whether TCP through a VRF IP is possible. - with subtest("tcp traffic through vrf works"): - node1.wait_for_open_port(22) - client.succeed( - "cat ${snakeOilPrivateKey} > privkey.snakeoil" - ) - client.succeed("chmod 600 privkey.snakeoil") - client.succeed( - "ulimit -l 2048; ip vrf exec vrf1 ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -i privkey.snakeoil root@192.168.1.2 true" - ) - - # Only configured routes through the VRF from the main routing table should - # work. Additional IPs are only reachable when binding to the vrf interface. - with subtest("only routes from main routing table work by default"): - client.fail("ping -c5 192.168.2.4") - client.succeed("ping -I vrf2 -c5 192.168.2.4") - - client.shutdown() - node1.shutdown() - node2.shutdown() - node3.shutdown() - ''; -}) + testScript = '' + import json + + def compare(raw_json, to_compare): + data = json.loads(raw_json) + assert len(raw_json) >= len(to_compare) + for i, row in enumerate(to_compare): + actual = data[i] + assert len(row.keys()) > 0 + for key, value in row.items(): + assert value == actual[key], f""" + In entry {i}, value {key}: got: {actual[key]}, expected {value} + """ + + + start_all() + + client.wait_for_unit("network.target") + node1.wait_for_unit("network.target") + node2.wait_for_unit("network.target") + node3.wait_for_unit("network.target") + + # Check that networkd properly configures the main routing table + # and the routing tables for the VRF. + with subtest("check vrf routing tables"): + compare( + client.succeed("ip --json -4 route list"), + [ + {"dst": "192.168.1.2", "dev": "vrf1", "metric": 100}, + {"dst": "192.168.2.3", "dev": "vrf2", "metric": 100} + ] + ) + compare( + client.succeed("ip --json -4 route list table 23"), + [ + {"dst": "192.168.1.0/24", "dev": "eth1", "prefsrc": "192.168.1.1"}, + {"type": "local", "dst": "192.168.1.1", "dev": "eth1", "prefsrc": "192.168.1.1"}, + {"type": "broadcast", "dev": "eth1", "prefsrc": "192.168.1.1", "dst": "192.168.1.255"} + ] + ) + compare( + client.succeed("ip --json -4 route list table 42"), + [ + {"dst": "192.168.2.0/24", "dev": "eth2", "prefsrc": "192.168.2.1"}, + {"type": "local", "dst": "192.168.2.1", "dev": "eth2", "prefsrc": "192.168.2.1"}, + {"type": "broadcast", "dev": "eth2", "prefsrc": "192.168.2.1", "dst": "192.168.2.255"} + ] + ) + + # Ensure that other nodes are reachable via ICMP through the VRF. + with subtest("icmp through vrf works"): + client.succeed("ping -c5 192.168.1.2") + client.succeed("ping -c5 192.168.2.3") + + # Test whether TCP through a VRF IP is possible. + with subtest("tcp traffic through vrf works"): + node1.wait_for_open_port(22) + client.succeed( + "cat ${snakeOilPrivateKey} > privkey.snakeoil" + ) + client.succeed("chmod 600 privkey.snakeoil") + client.succeed( + "ulimit -l 2048; ip vrf exec vrf1 ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -i privkey.snakeoil root@192.168.1.2 true" + ) + + # Only configured routes through the VRF from the main routing table should + # work. Additional IPs are only reachable when binding to the vrf interface. + with subtest("only routes from main routing table work by default"): + client.fail("ping -c5 192.168.2.4") + client.succeed("ping -I vrf2 -c5 192.168.2.4") + + client.shutdown() + node1.shutdown() + node2.shutdown() + node3.shutdown() + ''; + } +) diff --git a/nixos/tests/systemd-no-tainted.nix b/nixos/tests/systemd-no-tainted.nix index f0504065f2a482..12b68868415c47 100644 --- a/nixos/tests/systemd-no-tainted.nix +++ b/nixos/tests/systemd-no-tainted.nix @@ -1,14 +1,17 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "systemd-no-tainted"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "systemd-no-tainted"; - nodes.machine = { }; + nodes.machine = { }; - testScript = '' - machine.wait_for_unit("multi-user.target") - with subtest("systemctl should not report tainted with unmerged-usr"): - output = machine.succeed("systemctl status") - print(output) - assert "Tainted" not in output - assert "unmerged-usr" not in output - ''; -}) + testScript = '' + machine.wait_for_unit("multi-user.target") + with subtest("systemctl should not report tainted with unmerged-usr"): + output = machine.succeed("systemctl status") + print(output) + assert "Tainted" not in output + assert "unmerged-usr" not in output + ''; + } +) diff --git a/nixos/tests/systemd-nspawn-configfile.nix b/nixos/tests/systemd-nspawn-configfile.nix index 12ab21b7f9b577..8dd0260d2aeee6 100644 --- a/nixos/tests/systemd-nspawn-configfile.nix +++ b/nixos/tests/systemd-nspawn-configfile.nix @@ -1,128 +1,133 @@ -import ./make-test-python.nix ({ lib, ... }: -let - execOptions = [ - "Boot" - "ProcessTwo" - "Parameters" - "Environment" - "User" - "WorkingDirectory" - "PivotRoot" - "Capability" - "DropCapability" - "NoNewPrivileges" - "KillSignal" - "Personality" - "MachineID" - "PrivateUsers" - "NotifyReady" - "SystemCallFilter" - "LimitCPU" - "LimitFSIZE" - "LimitDATA" - "LimitSTACK" - "LimitCORE" - "LimitRSS" - "LimitNOFILE" - "LimitAS" - "LimitNPROC" - "LimitMEMLOCK" - "LimitLOCKS" - "LimitSIGPENDING" - "LimitMSGQUEUE" - "LimitNICE" - "LimitRTPRIO" - "LimitRTTIME" - "OOMScoreAdjust" - "CPUAffinity" - "Hostname" - "ResolvConf" - "Timezone" - "LinkJournal" - "Ephemeral" - "AmbientCapability" - ]; +import ./make-test-python.nix ( + { lib, ... }: + let + execOptions = [ + "Boot" + "ProcessTwo" + "Parameters" + "Environment" + "User" + "WorkingDirectory" + "PivotRoot" + "Capability" + "DropCapability" + "NoNewPrivileges" + "KillSignal" + "Personality" + "MachineID" + "PrivateUsers" + "NotifyReady" + "SystemCallFilter" + "LimitCPU" + "LimitFSIZE" + "LimitDATA" + "LimitSTACK" + "LimitCORE" + "LimitRSS" + "LimitNOFILE" + "LimitAS" + "LimitNPROC" + "LimitMEMLOCK" + "LimitLOCKS" + "LimitSIGPENDING" + "LimitMSGQUEUE" + "LimitNICE" + "LimitRTPRIO" + "LimitRTTIME" + "OOMScoreAdjust" + "CPUAffinity" + "Hostname" + "ResolvConf" + "Timezone" + "LinkJournal" + "Ephemeral" + "AmbientCapability" + ]; - filesOptions = [ - "ReadOnly" - "Volatile" - "Bind" - "BindReadOnly" - "TemporaryFileSystem" - "Overlay" - "OverlayReadOnly" - "PrivateUsersChown" - "BindUser" - "Inaccessible" - "PrivateUsersOwnership" - ]; + filesOptions = [ + "ReadOnly" + "Volatile" + "Bind" + "BindReadOnly" + "TemporaryFileSystem" + "Overlay" + "OverlayReadOnly" + "PrivateUsersChown" + "BindUser" + "Inaccessible" + "PrivateUsersOwnership" + ]; - networkOptions = [ - "Private" - "VirtualEthernet" - "VirtualEthernetExtra" - "Interface" - "MACVLAN" - "IPVLAN" - "Bridge" - "Zone" - "Port" - ]; + networkOptions = [ + "Private" + "VirtualEthernet" + "VirtualEthernetExtra" + "Interface" + "MACVLAN" + "IPVLAN" + "Bridge" + "Zone" + "Port" + ]; - optionsToConfig = opts: builtins.listToAttrs (map (n: lib.nameValuePair n "testdata") opts); + optionsToConfig = opts: builtins.listToAttrs (map (n: lib.nameValuePair n "testdata") opts); - grepForOptions = opts: ''node.succeed( - "for o in ${builtins.concatStringsSep " " opts} ; do grep --quiet $o ${configFile} || exit 1 ; done" - )''; + grepForOptions = opts: '' + node.succeed( + "for o in ${builtins.concatStringsSep " " opts} ; do grep --quiet $o ${configFile} || exit 1 ; done" + )''; - unitName = "options-test"; - configFile = "/etc/systemd/nspawn/${unitName}.nspawn"; + unitName = "options-test"; + configFile = "/etc/systemd/nspawn/${unitName}.nspawn"; -in -{ - name = "systemd-nspawn-configfile"; + in + { + name = "systemd-nspawn-configfile"; - nodes = { - node = { pkgs, ... }: { - systemd.nspawn."${unitName}" = { - enable = true; + nodes = { + node = + { pkgs, ... }: + { + systemd.nspawn."${unitName}" = { + enable = true; - execConfig = optionsToConfig execOptions // { - Boot = true; - ProcessTwo = true; - NotifyReady = true; - }; + execConfig = optionsToConfig execOptions // { + Boot = true; + ProcessTwo = true; + NotifyReady = true; + }; - filesConfig = optionsToConfig filesOptions // { - ReadOnly = true; - Volatile = "state"; - PrivateUsersChown = true; - PrivateUsersOwnership = "auto"; - }; + filesConfig = optionsToConfig filesOptions // { + ReadOnly = true; + Volatile = "state"; + PrivateUsersChown = true; + PrivateUsersOwnership = "auto"; + }; - networkConfig = optionsToConfig networkOptions // { - Private = true; - VirtualEthernet = true; + networkConfig = optionsToConfig networkOptions // { + Private = true; + VirtualEthernet = true; + }; + }; }; - }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - node.wait_for_file("${configFile}") + node.wait_for_file("${configFile}") - with subtest("Test for presence of all specified options in config file"): - ${grepForOptions execOptions} - ${grepForOptions filesOptions} - ${grepForOptions networkOptions} + with subtest("Test for presence of all specified options in config file"): + ${grepForOptions execOptions} + ${grepForOptions filesOptions} + ${grepForOptions networkOptions} - with subtest("Test for absence of misspelled option 'MachineId' (instead of 'MachineID')"): - node.fail("grep --quiet MachineId ${configFile}") - ''; + with subtest("Test for absence of misspelled option 'MachineId' (instead of 'MachineID')"): + node.fail("grep --quiet MachineId ${configFile}") + ''; - meta.maintainers = [ - lib.maintainers.zi3m5f - ]; -}) + meta.maintainers = [ + lib.maintainers.zi3m5f + ]; + } +) diff --git a/nixos/tests/systemd-nspawn.nix b/nixos/tests/systemd-nspawn.nix index b86762233d183e..feda47bf34ef62 100644 --- a/nixos/tests/systemd-nspawn.nix +++ b/nixos/tests/systemd-nspawn.nix @@ -1,52 +1,68 @@ -import ./make-test-python.nix ({pkgs, lib, ...}: -let - gpgKeyring = import ./common/gpg-keyring.nix { inherit pkgs; }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + gpgKeyring = import ./common/gpg-keyring.nix { inherit pkgs; }; - nspawnImages = (pkgs.runCommand "localhost" { buildInputs = [ pkgs.coreutils pkgs.gnupg ]; } '' - mkdir -p $out - cd $out + nspawnImages = ( + pkgs.runCommand "localhost" + { + buildInputs = [ + pkgs.coreutils + pkgs.gnupg + ]; + } + '' + mkdir -p $out + cd $out - # produce a testimage.raw - dd if=/dev/urandom of=$out/testimage.raw bs=$((1024*1024+7)) count=5 + # produce a testimage.raw + dd if=/dev/urandom of=$out/testimage.raw bs=$((1024*1024+7)) count=5 - # produce a testimage2.tar.xz, containing the hello store path - tar cvJpf testimage2.tar.xz ${pkgs.hello} + # produce a testimage2.tar.xz, containing the hello store path + tar cvJpf testimage2.tar.xz ${pkgs.hello} - # produce signature(s) - sha256sum testimage* > SHA256SUMS - export GNUPGHOME="$(mktemp -d)" - cp -R ${gpgKeyring}/* $GNUPGHOME - gpg --batch --sign --detach-sign --output SHA256SUMS.gpg SHA256SUMS - ''); -in { - name = "systemd-nspawn"; + # produce signature(s) + sha256sum testimage* > SHA256SUMS + export GNUPGHOME="$(mktemp -d)" + cp -R ${gpgKeyring}/* $GNUPGHOME + gpg --batch --sign --detach-sign --output SHA256SUMS.gpg SHA256SUMS + '' + ); + in + { + name = "systemd-nspawn"; - nodes = { - server = { pkgs, ... }: { - networking.firewall.allowedTCPPorts = [ 80 ]; - services.nginx = { - enable = true; - virtualHosts."server".root = nspawnImages; - }; + nodes = { + server = + { pkgs, ... }: + { + networking.firewall.allowedTCPPorts = [ 80 ]; + services.nginx = { + enable = true; + virtualHosts."server".root = nspawnImages; + }; + }; + client = + { pkgs, ... }: + { + environment.etc."systemd/import-pubring.gpg".source = "${gpgKeyring}/pubkey.gpg"; + }; }; - client = { pkgs, ... }: { - environment.etc."systemd/import-pubring.gpg".source = "${gpgKeyring}/pubkey.gpg"; - }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - server.wait_for_unit("nginx.service") - client.systemctl("start network-online.target") - client.wait_for_unit("network-online.target") - client.succeed("machinectl pull-raw --verify=signature http://server/testimage.raw") - client.succeed( - "cmp /var/lib/machines/testimage.raw ${nspawnImages}/testimage.raw" - ) - client.succeed("machinectl pull-tar --verify=signature http://server/testimage2.tar.xz") - client.succeed( - "cmp /var/lib/machines/testimage2/${pkgs.hello}/bin/hello ${pkgs.hello}/bin/hello" - ) - ''; -}) + server.wait_for_unit("nginx.service") + client.systemctl("start network-online.target") + client.wait_for_unit("network-online.target") + client.succeed("machinectl pull-raw --verify=signature http://server/testimage.raw") + client.succeed( + "cmp /var/lib/machines/testimage.raw ${nspawnImages}/testimage.raw" + ) + client.succeed("machinectl pull-tar --verify=signature http://server/testimage2.tar.xz") + client.succeed( + "cmp /var/lib/machines/testimage2/${pkgs.hello}/bin/hello ${pkgs.hello}/bin/hello" + ) + ''; + } +) diff --git a/nixos/tests/systemd-oomd.nix b/nixos/tests/systemd-oomd.nix index 55c4c135000058..5c95c6705c714d 100644 --- a/nixos/tests/systemd-oomd.nix +++ b/nixos/tests/systemd-oomd.nix @@ -1,54 +1,58 @@ -import ./make-test-python.nix ({ pkgs, ... }: - -{ - name = "systemd-oomd"; - - # This test is a simplified version of systemd's testsuite-55. - # https://github.com/systemd/systemd/blob/v251/test/units/testsuite-55.sh - nodes.machine = { pkgs, ... }: { - # Limit VM resource usage. - virtualisation.memorySize = 1024; - systemd.oomd.extraConfig.DefaultMemoryPressureDurationSec = "1s"; - - systemd.slices.workload = { - description = "Test slice for memory pressure kills"; - sliceConfig = { - MemoryAccounting = true; - ManagedOOMMemoryPressure = "kill"; - ManagedOOMMemoryPressureLimit = "10%"; +import ./make-test-python.nix ( + { pkgs, ... }: + + { + name = "systemd-oomd"; + + # This test is a simplified version of systemd's testsuite-55. + # https://github.com/systemd/systemd/blob/v251/test/units/testsuite-55.sh + nodes.machine = + { pkgs, ... }: + { + # Limit VM resource usage. + virtualisation.memorySize = 1024; + systemd.oomd.extraConfig.DefaultMemoryPressureDurationSec = "1s"; + + systemd.slices.workload = { + description = "Test slice for memory pressure kills"; + sliceConfig = { + MemoryAccounting = true; + ManagedOOMMemoryPressure = "kill"; + ManagedOOMMemoryPressureLimit = "10%"; + }; + }; + + systemd.services.testbloat = { + description = "Create a lot of memory pressure"; + serviceConfig = { + Slice = "workload.slice"; + MemoryHigh = "5M"; + ExecStart = "${pkgs.coreutils}/bin/tail /dev/zero"; + }; + }; + + systemd.services.testchill = { + description = "No memory pressure"; + serviceConfig = { + Slice = "workload.slice"; + MemoryHigh = "3M"; + ExecStart = "${pkgs.coreutils}/bin/sleep infinity"; + }; + }; }; - }; - - systemd.services.testbloat = { - description = "Create a lot of memory pressure"; - serviceConfig = { - Slice = "workload.slice"; - MemoryHigh = "5M"; - ExecStart = "${pkgs.coreutils}/bin/tail /dev/zero"; - }; - }; - - systemd.services.testchill = { - description = "No memory pressure"; - serviceConfig = { - Slice = "workload.slice"; - MemoryHigh = "3M"; - ExecStart = "${pkgs.coreutils}/bin/sleep infinity"; - }; - }; - }; - - testScript = '' - # Start the system. - machine.wait_for_unit("multi-user.target") - machine.succeed("oomctl") - - machine.succeed("systemctl start testchill.service") - with subtest("OOMd should kill the bad service"): - machine.fail("systemctl start --wait testbloat.service") - assert machine.get_unit_info("testbloat.service")["Result"] == "oom-kill" - - with subtest("Service without memory pressure should be untouched"): - machine.require_unit_state("testchill.service", "active") - ''; -}) + + testScript = '' + # Start the system. + machine.wait_for_unit("multi-user.target") + machine.succeed("oomctl") + + machine.succeed("systemctl start testchill.service") + with subtest("OOMd should kill the bad service"): + machine.fail("systemctl start --wait testbloat.service") + assert machine.get_unit_info("testbloat.service")["Result"] == "oom-kill" + + with subtest("Service without memory pressure should be untouched"): + machine.require_unit_state("testchill.service", "active") + ''; + } +) diff --git a/nixos/tests/systemd-portabled.nix b/nixos/tests/systemd-portabled.nix index ef38258b0d866a..caece9089d2260 100644 --- a/nixos/tests/systemd-portabled.nix +++ b/nixos/tests/systemd-portabled.nix @@ -1,51 +1,58 @@ -import ./make-test-python.nix ({pkgs, lib, ...}: let - demo-program = pkgs.writeShellScriptBin "demo" '' +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + demo-program = pkgs.writeShellScriptBin "demo" '' while ${pkgs.coreutils}/bin/sleep 3; do echo Hello World > /dev/null done - ''; - demo-service = pkgs.writeText "demo.service" '' - [Unit] - Description=demo service - Requires=demo.socket - After=demo.socket + ''; + demo-service = pkgs.writeText "demo.service" '' + [Unit] + Description=demo service + Requires=demo.socket + After=demo.socket - [Service] - Type=simple - ExecStart=${demo-program}/bin/demo - Restart=always + [Service] + Type=simple + ExecStart=${demo-program}/bin/demo + Restart=always - [Install] - WantedBy=multi-user.target - Also=demo.socket - ''; - demo-socket = pkgs.writeText "demo.socket" '' - [Unit] - Description=demo socket + [Install] + WantedBy=multi-user.target + Also=demo.socket + ''; + demo-socket = pkgs.writeText "demo.socket" '' + [Unit] + Description=demo socket - [Socket] - ListenStream=/run/demo.sock - SocketMode=0666 + [Socket] + ListenStream=/run/demo.sock + SocketMode=0666 - [Install] - WantedBy=sockets.target - ''; - demo-portable = pkgs.portableService { - pname = "demo"; - version = "1.0"; - description = ''A demo "Portable Service" for a shell program built with nix''; - units = [ demo-service demo-socket ]; - }; -in { + [Install] + WantedBy=sockets.target + ''; + demo-portable = pkgs.portableService { + pname = "demo"; + version = "1.0"; + description = ''A demo "Portable Service" for a shell program built with nix''; + units = [ + demo-service + demo-socket + ]; + }; + in + { - name = "systemd-portabled"; - nodes.machine = {}; - testScript = '' - machine.succeed("portablectl") - machine.wait_for_unit("systemd-portabled.service") - machine.succeed("portablectl attach --now --runtime ${demo-portable}/demo_1.0.raw") - machine.wait_for_unit("demo.service") - machine.succeed("portablectl detach --now --runtime demo_1.0") - machine.fail("systemctl status demo.service") - ''; -}) + name = "systemd-portabled"; + nodes.machine = { }; + testScript = '' + machine.succeed("portablectl") + machine.wait_for_unit("systemd-portabled.service") + machine.succeed("portablectl attach --now --runtime ${demo-portable}/demo_1.0.raw") + machine.wait_for_unit("demo.service") + machine.succeed("portablectl detach --now --runtime demo_1.0") + machine.fail("systemctl status demo.service") + ''; + } +) diff --git a/nixos/tests/systemd-repart.nix b/nixos/tests/systemd-repart.nix index 3914d5b3239779..871c66d5350e7c 100644 --- a/nixos/tests/systemd-repart.nix +++ b/nixos/tests/systemd-repart.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -33,150 +34,174 @@ let os.environ['NIX_DISK_IMAGE'] = tmp_disk_image.name ''; - common = { config, pkgs, lib, ... }: { - virtualisation.useDefaultFilesystems = false; - virtualisation.fileSystems = { - "/" = { - device = "/dev/vda2"; - fsType = "ext4"; + common = + { + config, + pkgs, + lib, + ... + }: + { + virtualisation.useDefaultFilesystems = false; + virtualisation.fileSystems = { + "/" = { + device = "/dev/vda2"; + fsType = "ext4"; + }; }; - }; - # systemd-repart operates on disks with a partition table. The qemu module, - # however, creates separate filesystem images without a partition table, so - # we have to create a disk image manually. - # - # This creates two partitions, an ESP available as /dev/vda1 and the root - # partition available as /dev/vda2. - system.build.diskImage = import ../lib/make-disk-image.nix { - inherit config pkgs lib; - # Use a raw format disk so that it can be resized before starting the - # test VM. - format = "raw"; - # Keep the image as small as possible but leave some room for changes. - bootSize = "32M"; - additionalSpace = "0M"; - # GPT with an EFI System Partition is the typical use case for - # systemd-repart because it does not support MBR. - partitionTableType = "efi"; - # We do not actually care much about the content of the partitions, so we - # do not need a bootloader installed. - installBootLoader = false; - # Improve determinism by not copying a channel. - copyChannel = false; + # systemd-repart operates on disks with a partition table. The qemu module, + # however, creates separate filesystem images without a partition table, so + # we have to create a disk image manually. + # + # This creates two partitions, an ESP available as /dev/vda1 and the root + # partition available as /dev/vda2. + system.build.diskImage = import ../lib/make-disk-image.nix { + inherit config pkgs lib; + # Use a raw format disk so that it can be resized before starting the + # test VM. + format = "raw"; + # Keep the image as small as possible but leave some room for changes. + bootSize = "32M"; + additionalSpace = "0M"; + # GPT with an EFI System Partition is the typical use case for + # systemd-repart because it does not support MBR. + partitionTableType = "efi"; + # We do not actually care much about the content of the partitions, so we + # do not need a bootloader installed. + installBootLoader = false; + # Improve determinism by not copying a channel. + copyChannel = false; + }; }; - }; in { basic = makeTest { name = "systemd-repart"; meta.maintainers = with maintainers; [ nikstur ]; - nodes.machine = { config, pkgs, ... }: { - imports = [ common ]; + nodes.machine = + { config, pkgs, ... }: + { + imports = [ common ]; - boot.initrd.systemd.enable = true; + boot.initrd.systemd.enable = true; - boot.initrd.systemd.repart.enable = true; - systemd.repart.partitions = { - "10-root" = { - Type = "linux-generic"; + boot.initrd.systemd.repart.enable = true; + systemd.repart.partitions = { + "10-root" = { + Type = "linux-generic"; + }; }; }; - }; - testScript = { nodes, ... }: '' - ${useDiskImage nodes.machine} + testScript = + { nodes, ... }: + '' + ${useDiskImage nodes.machine} - machine.start() - machine.wait_for_unit("multi-user.target") + machine.start() + machine.wait_for_unit("multi-user.target") - systemd_repart_logs = machine.succeed("journalctl --boot --unit systemd-repart.service") - assert "Growing existing partition 1." in systemd_repart_logs - ''; + systemd_repart_logs = machine.succeed("journalctl --boot --unit systemd-repart.service") + assert "Growing existing partition 1." in systemd_repart_logs + ''; }; after-initrd = makeTest { name = "systemd-repart-after-initrd"; meta.maintainers = with maintainers; [ nikstur ]; - nodes.machine = { config, pkgs, ... }: { - imports = [ common ]; + nodes.machine = + { config, pkgs, ... }: + { + imports = [ common ]; - systemd.repart.enable = true; - systemd.repart.partitions = { - "10-root" = { - Type = "linux-generic"; + systemd.repart.enable = true; + systemd.repart.partitions = { + "10-root" = { + Type = "linux-generic"; + }; }; }; - }; - testScript = { nodes, ... }: '' - ${useDiskImage nodes.machine} + testScript = + { nodes, ... }: + '' + ${useDiskImage nodes.machine} - machine.start() - machine.wait_for_unit("multi-user.target") + machine.start() + machine.wait_for_unit("multi-user.target") - systemd_repart_logs = machine.succeed("journalctl --unit systemd-repart.service") - assert "Growing existing partition 1." in systemd_repart_logs - ''; + systemd_repart_logs = machine.succeed("journalctl --unit systemd-repart.service") + assert "Growing existing partition 1." in systemd_repart_logs + ''; }; create-root = makeTest { name = "systemd-repart-create-root"; meta.maintainers = with maintainers; [ nikstur ]; - nodes.machine = { config, lib, pkgs, ... }: { - virtualisation.useDefaultFilesystems = false; - virtualisation.fileSystems = { - "/" = { - device = "/dev/disk/by-partlabel/created-root"; - fsType = "ext4"; - }; - "/nix/store" = { - device = "/dev/vda2"; - fsType = "ext4"; + nodes.machine = + { + config, + lib, + pkgs, + ... + }: + { + virtualisation.useDefaultFilesystems = false; + virtualisation.fileSystems = { + "/" = { + device = "/dev/disk/by-partlabel/created-root"; + fsType = "ext4"; + }; + "/nix/store" = { + device = "/dev/vda2"; + fsType = "ext4"; + }; }; - }; - # Create an image containing only the Nix store. This enables creating - # the root partition with systemd-repart and then successfully booting - # into a working system. - # - # This creates two partitions, an ESP available as /dev/vda1 and the Nix - # store available as /dev/vda2. - system.build.diskImage = import ../lib/make-disk-image.nix { - inherit config pkgs lib; - onlyNixStore = true; - format = "raw"; - bootSize = "32M"; - additionalSpace = "0M"; - partitionTableType = "efi"; - installBootLoader = false; - copyChannel = false; - }; + # Create an image containing only the Nix store. This enables creating + # the root partition with systemd-repart and then successfully booting + # into a working system. + # + # This creates two partitions, an ESP available as /dev/vda1 and the Nix + # store available as /dev/vda2. + system.build.diskImage = import ../lib/make-disk-image.nix { + inherit config pkgs lib; + onlyNixStore = true; + format = "raw"; + bootSize = "32M"; + additionalSpace = "0M"; + partitionTableType = "efi"; + installBootLoader = false; + copyChannel = false; + }; - boot.initrd.systemd.enable = true; + boot.initrd.systemd.enable = true; - boot.initrd.systemd.repart.enable = true; - boot.initrd.systemd.repart.device = "/dev/vda"; - systemd.repart.partitions = { - "10-root" = { - Type = "root"; - Label = "created-root"; - Format = "ext4"; + boot.initrd.systemd.repart.enable = true; + boot.initrd.systemd.repart.device = "/dev/vda"; + systemd.repart.partitions = { + "10-root" = { + Type = "root"; + Label = "created-root"; + Format = "ext4"; + }; }; }; - }; - testScript = { nodes, ... }: '' - ${useDiskImage nodes.machine} + testScript = + { nodes, ... }: + '' + ${useDiskImage nodes.machine} - machine.start() - machine.wait_for_unit("multi-user.target") + machine.start() + machine.wait_for_unit("multi-user.target") - systemd_repart_logs = machine.succeed("journalctl --boot --unit systemd-repart.service") - assert "Adding new partition 2 to partition table." in systemd_repart_logs - ''; + systemd_repart_logs = machine.succeed("journalctl --boot --unit systemd-repart.service") + assert "Adding new partition 2 to partition table." in systemd_repart_logs + ''; }; } diff --git a/nixos/tests/systemd-resolved.nix b/nixos/tests/systemd-resolved.nix index 3eedc17f4b34ff..6256b7f2e67513 100644 --- a/nixos/tests/systemd-resolved.nix +++ b/nixos/tests/systemd-resolved.nix @@ -1,75 +1,93 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "systemd-resolved"; - meta.maintainers = [ lib.maintainers.elvishjerricco ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "systemd-resolved"; + meta.maintainers = [ lib.maintainers.elvishjerricco ]; - nodes.server = { lib, config, ... }: let - exampleZone = pkgs.writeTextDir "example.com.zone" '' - @ SOA ns.example.com. noc.example.com. 2019031301 86400 7200 3600000 172800 - @ A ${(lib.head config.networking.interfaces.eth1.ipv4.addresses).address} - @ AAAA ${(lib.head config.networking.interfaces.eth1.ipv6.addresses).address} - ''; - in { - networking.firewall.enable = false; - networking.useDHCP = false; + nodes.server = + { lib, config, ... }: + let + exampleZone = pkgs.writeTextDir "example.com.zone" '' + @ SOA ns.example.com. noc.example.com. 2019031301 86400 7200 3600000 172800 + @ A ${(lib.head config.networking.interfaces.eth1.ipv4.addresses).address} + @ AAAA ${(lib.head config.networking.interfaces.eth1.ipv6.addresses).address} + ''; + in + { + networking.firewall.enable = false; + networking.useDHCP = false; - networking.interfaces.eth1.ipv6.addresses = lib.mkForce [ - { address = "fd00::1"; prefixLength = 64; } - ]; - - services.knot = { - enable = true; - settings = { - server.listen = [ - "0.0.0.0@53" - "::@53" + networking.interfaces.eth1.ipv6.addresses = lib.mkForce [ + { + address = "fd00::1"; + prefixLength = 64; + } ]; - template.default.storage = exampleZone; - zone."example.com".file = "example.com.zone"; + + services.knot = { + enable = true; + settings = { + server.listen = [ + "0.0.0.0@53" + "::@53" + ]; + template.default.storage = exampleZone; + zone."example.com".file = "example.com.zone"; + }; + }; }; - }; - }; - nodes.client = { nodes, ... }: let - inherit (lib.head nodes.server.networking.interfaces.eth1.ipv4.addresses) address; - in { - networking.nameservers = [ address ]; - networking.interfaces.eth1.ipv6.addresses = lib.mkForce [ - { address = "fd00::2"; prefixLength = 64; } - ]; - services.resolved.enable = true; - services.resolved.fallbackDns = [ ]; - networking.useNetworkd = true; - networking.useDHCP = false; - systemd.network.networks."40-eth0".enable = false; + nodes.client = + { nodes, ... }: + let + inherit (lib.head nodes.server.networking.interfaces.eth1.ipv4.addresses) address; + in + { + networking.nameservers = [ address ]; + networking.interfaces.eth1.ipv6.addresses = lib.mkForce [ + { + address = "fd00::2"; + prefixLength = 64; + } + ]; + services.resolved.enable = true; + services.resolved.fallbackDns = [ ]; + networking.useNetworkd = true; + networking.useDHCP = false; + systemd.network.networks."40-eth0".enable = false; - testing.initrdBackdoor = true; - boot.initrd = { - systemd.enable = true; - systemd.initrdBin = [ pkgs.iputils ]; - network.enable = true; - services.resolved.enable = true; - }; - }; + testing.initrdBackdoor = true; + boot.initrd = { + systemd.enable = true; + systemd.initrdBin = [ pkgs.iputils ]; + network.enable = true; + services.resolved.enable = true; + }; + }; - testScript = { nodes, ... }: let - address4 = (lib.head nodes.server.networking.interfaces.eth1.ipv4.addresses).address; - address6 = (lib.head nodes.server.networking.interfaces.eth1.ipv6.addresses).address; - in '' - start_all() - server.wait_for_unit("multi-user.target") + testScript = + { nodes, ... }: + let + address4 = (lib.head nodes.server.networking.interfaces.eth1.ipv4.addresses).address; + address6 = (lib.head nodes.server.networking.interfaces.eth1.ipv6.addresses).address; + in + '' + start_all() + server.wait_for_unit("multi-user.target") - def test_client(): - query = client.succeed("resolvectl query example.com") - assert "${address4}" in query - assert "${address6}" in query - client.succeed("ping -4 -c 1 example.com") - client.succeed("ping -6 -c 1 example.com") + def test_client(): + query = client.succeed("resolvectl query example.com") + assert "${address4}" in query + assert "${address6}" in query + client.succeed("ping -4 -c 1 example.com") + client.succeed("ping -6 -c 1 example.com") - client.wait_for_unit("initrd.target") - test_client() - client.switch_root() + client.wait_for_unit("initrd.target") + test_client() + client.switch_root() - client.wait_for_unit("multi-user.target") - test_client() - ''; -}) + client.wait_for_unit("multi-user.target") + test_client() + ''; + } +) diff --git a/nixos/tests/systemd-shutdown.nix b/nixos/tests/systemd-shutdown.nix index ca6754046f57a4..1f072086bdd1f3 100644 --- a/nixos/tests/systemd-shutdown.nix +++ b/nixos/tests/systemd-shutdown.nix @@ -1,27 +1,36 @@ -import ./make-test-python.nix ({ pkgs, systemdStage1 ? false, ...} : let - msg = "Shutting down NixOS"; -in { - name = "systemd-shutdown"; - meta = with pkgs.lib.maintainers; { - maintainers = [ das_j ]; - }; +import ./make-test-python.nix ( + { + pkgs, + systemdStage1 ? false, + ... + }: + let + msg = "Shutting down NixOS"; + in + { + name = "systemd-shutdown"; + meta = with pkgs.lib.maintainers; { + maintainers = [ das_j ]; + }; - nodes.machine = { - imports = [ ../modules/profiles/minimal.nix ]; - systemd.shutdownRamfs.contents."/etc/systemd/system-shutdown/shutdown-message".source = pkgs.writeShellScript "shutdown-message" '' - echo "${msg}" - ''; - boot.initrd.systemd.enable = systemdStage1; - }; + nodes.machine = { + imports = [ ../modules/profiles/minimal.nix ]; + systemd.shutdownRamfs.contents."/etc/systemd/system-shutdown/shutdown-message".source = + pkgs.writeShellScript "shutdown-message" '' + echo "${msg}" + ''; + boot.initrd.systemd.enable = systemdStage1; + }; - testScript = '' - machine.wait_for_unit("multi-user.target") - # .shutdown() would wait for the machine to power off - machine.succeed("systemctl poweroff") - # Message printed by systemd-shutdown - machine.wait_for_console_text("Unmounting '/oldroot'") - machine.wait_for_console_text("${msg}") - # Don't try to sync filesystems - machine.wait_for_shutdown() - ''; -}) + testScript = '' + machine.wait_for_unit("multi-user.target") + # .shutdown() would wait for the machine to power off + machine.succeed("systemctl poweroff") + # Message printed by systemd-shutdown + machine.wait_for_console_text("Unmounting '/oldroot'") + machine.wait_for_console_text("${msg}") + # Don't try to sync filesystems + machine.wait_for_shutdown() + ''; + } +) diff --git a/nixos/tests/systemd-sysupdate.nix b/nixos/tests/systemd-sysupdate.nix index 6592764c9ff461..4cfd6c24438ded 100644 --- a/nixos/tests/systemd-sysupdate.nix +++ b/nixos/tests/systemd-sysupdate.nix @@ -14,26 +14,28 @@ in meta.maintainers = with lib.maintainers; [ nikstur ]; nodes = { - server = { pkgs, ... }: { - networking.firewall.enable = false; - services.nginx = { - enable = true; - virtualHosts."server" = { - root = pkgs.runCommand "sysupdate-artifacts" { buildInputs = [ pkgs.gnupg ]; } '' - mkdir -p $out - cd $out + server = + { pkgs, ... }: + { + networking.firewall.enable = false; + services.nginx = { + enable = true; + virtualHosts."server" = { + root = pkgs.runCommand "sysupdate-artifacts" { buildInputs = [ pkgs.gnupg ]; } '' + mkdir -p $out + cd $out - echo "nixos" > nixos_1.txt - sha256sum nixos_1.txt > SHA256SUMS + echo "nixos" > nixos_1.txt + sha256sum nixos_1.txt > SHA256SUMS - export GNUPGHOME="$(mktemp -d)" - cp -R ${gpgKeyring}/* $GNUPGHOME + export GNUPGHOME="$(mktemp -d)" + cp -R ${gpgKeyring}/* $GNUPGHOME - gpg --batch --sign --detach-sign --output SHA256SUMS.gpg SHA256SUMS - ''; + gpg --batch --sign --detach-sign --output SHA256SUMS.gpg SHA256SUMS + ''; + }; }; }; - }; target = { systemd.sysupdate = { diff --git a/nixos/tests/systemd-sysusers-immutable.nix b/nixos/tests/systemd-sysusers-immutable.nix index 4d65b52a0d336d..857488a6cabd26 100644 --- a/nixos/tests/systemd-sysusers-immutable.nix +++ b/nixos/tests/systemd-sysusers-immutable.nix @@ -16,7 +16,6 @@ in systemd.sysusers.enable = true; users.mutableUsers = false; - # Read this password file at runtime from outside the Nix store. environment.etc."rootpw.secret".text = rootPassword; # Override the empty root password set by the test instrumentation. diff --git a/nixos/tests/systemd-sysusers-mutable.nix b/nixos/tests/systemd-sysusers-mutable.nix index 9871a91cca9716..b0526d524584fe 100644 --- a/nixos/tests/systemd-sysusers-mutable.nix +++ b/nixos/tests/systemd-sysusers-mutable.nix @@ -12,34 +12,36 @@ in meta.maintainers = with lib.maintainers; [ nikstur ]; - nodes.machine = { pkgs, ... }: { - systemd.sysusers.enable = true; - users.mutableUsers = true; - - # Prerequisites - system.etc.overlay.enable = true; - boot.initrd.systemd.enable = true; - boot.kernelPackages = pkgs.linuxPackages_latest; - - # Override the empty root password set by the test instrumentation - users.users.root.hashedPasswordFile = lib.mkForce null; - users.users.root.initialHashedPassword = rootPassword; - users.users.sysuser = { - isSystemUser = true; - group = "wheel"; - home = "/sysuser"; - initialPassword = sysuserPassword; - }; - - specialisation.new-generation.configuration = { - users.users.new-sysuser = { + nodes.machine = + { pkgs, ... }: + { + systemd.sysusers.enable = true; + users.mutableUsers = true; + + # Prerequisites + system.etc.overlay.enable = true; + boot.initrd.systemd.enable = true; + boot.kernelPackages = pkgs.linuxPackages_latest; + + # Override the empty root password set by the test instrumentation + users.users.root.hashedPasswordFile = lib.mkForce null; + users.users.root.initialHashedPassword = rootPassword; + users.users.sysuser = { isSystemUser = true; group = "wheel"; - home = "/new-sysuser"; - initialHashedPassword = newSysuserPassword; + home = "/sysuser"; + initialPassword = sysuserPassword; + }; + + specialisation.new-generation.configuration = { + users.users.new-sysuser = { + isSystemUser = true; + group = "wheel"; + home = "/new-sysuser"; + initialHashedPassword = newSysuserPassword; + }; }; }; - }; testScript = '' machine.wait_for_unit("systemd-sysusers.service") diff --git a/nixos/tests/systemd-timesyncd-nscd-dnssec.nix b/nixos/tests/systemd-timesyncd-nscd-dnssec.nix index 697dd824e34536..fc3002dbf51ac5 100644 --- a/nixos/tests/systemd-timesyncd-nscd-dnssec.nix +++ b/nixos/tests/systemd-timesyncd-nscd-dnssec.nix @@ -13,49 +13,57 @@ # server running. For this test to succeed, we only need to ensure that systemd-timesyncd # resolves the IP address of the fake.ntp host. -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -let - ntpHostname = "fake.ntp"; - ntpIP = "192.0.2.1"; -in -{ - name = "systemd-timesyncd"; - nodes.machine = { pkgs, lib, config, ... }: - let - eth1IP = (lib.head config.networking.interfaces.eth1.ipv4.addresses).address; - in - { - # Setup a local DNS server for the NTP domain on the eth1 IP address - services.tinydns = { - enable = true; - ip = eth1IP; - data = '' - .ntp:${eth1IP} - +.${ntpHostname}:${ntpIP} - ''; - }; + let + ntpHostname = "fake.ntp"; + ntpIP = "192.0.2.1"; + in + { + name = "systemd-timesyncd"; + nodes.machine = + { + pkgs, + lib, + config, + ... + }: + let + eth1IP = (lib.head config.networking.interfaces.eth1.ipv4.addresses).address; + in + { + # Setup a local DNS server for the NTP domain on the eth1 IP address + services.tinydns = { + enable = true; + ip = eth1IP; + data = '' + .ntp:${eth1IP} + +.${ntpHostname}:${ntpIP} + ''; + }; - # Enable systemd-resolved with DNSSEC and use the local DNS as a name server - services.resolved.enable = true; - services.resolved.dnssec = "true"; - networking.nameservers = [ eth1IP ]; + # Enable systemd-resolved with DNSSEC and use the local DNS as a name server + services.resolved.enable = true; + services.resolved.dnssec = "true"; + networking.nameservers = [ eth1IP ]; - # Configure systemd-timesyncd to use our NTP hostname - services.timesyncd.enable = lib.mkForce true; - services.timesyncd.servers = [ ntpHostname ]; - services.timesyncd.extraConfig = '' - FallbackNTP=${ntpHostname} - ''; + # Configure systemd-timesyncd to use our NTP hostname + services.timesyncd.enable = lib.mkForce true; + services.timesyncd.servers = [ ntpHostname ]; + services.timesyncd.extraConfig = '' + FallbackNTP=${ntpHostname} + ''; - # The debug output is necessary to determine whether systemd-timesyncd successfully resolves our NTP hostname or not - systemd.services.systemd-timesyncd.environment.SYSTEMD_LOG_LEVEL = "debug"; - }; + # The debug output is necessary to determine whether systemd-timesyncd successfully resolves our NTP hostname or not + systemd.services.systemd-timesyncd.environment.SYSTEMD_LOG_LEVEL = "debug"; + }; - testScript = '' - machine.wait_for_unit("tinydns.service") - machine.wait_for_unit("systemd-timesyncd.service") - machine.fail("resolvectl query ${ntpHostname}") - machine.wait_until_succeeds("journalctl -u systemd-timesyncd.service --grep='Resolved address ${ntpIP}:123 for ${ntpHostname}'") - ''; -}) + testScript = '' + machine.wait_for_unit("tinydns.service") + machine.wait_for_unit("systemd-timesyncd.service") + machine.fail("resolvectl query ${ntpHostname}") + machine.wait_until_succeeds("journalctl -u systemd-timesyncd.service --grep='Resolved address ${ntpIP}:123 for ${ntpHostname}'") + ''; + } +) diff --git a/nixos/tests/systemd-timesyncd.nix b/nixos/tests/systemd-timesyncd.nix index 02f49f49b8a581..d50b6386786c5c 100644 --- a/nixos/tests/systemd-timesyncd.nix +++ b/nixos/tests/systemd-timesyncd.nix @@ -1,54 +1,67 @@ # Regression test for systemd-timesync having moved the state directory without # upstream providing a migration path. https://github.com/systemd/systemd/issues/12131 -import ./make-test-python.nix (let - common = { lib, ... }: { - # override the `false` value from the qemu-vm base profile - services.timesyncd.enable = lib.mkForce true; - }; - mkVM = conf: { imports = [ conf common ]; }; -in { - name = "systemd-timesyncd"; - nodes = { - current = mkVM {}; - pre1909 = mkVM ({lib, ... }: { - # create the path that should be migrated by our activation script when - # upgrading to a newer nixos version - system.stateVersion = "19.03"; - systemd.tmpfiles.settings.systemd-timesyncd-test = { - "/var/lib/systemd/timesync".R = { }; - "/var/lib/systemd/timesync".L.argument = "/var/lib/private/systemd/timesync"; - "/var/lib/private/systemd/timesync".d = { - user = "systemd-timesync"; - group = "systemd-timesync"; - }; +import ./make-test-python.nix ( + let + common = + { lib, ... }: + { + # override the `false` value from the qemu-vm base profile + services.timesyncd.enable = lib.mkForce true; }; - }); - }; + mkVM = conf: { + imports = [ + conf + common + ]; + }; + in + { + name = "systemd-timesyncd"; + nodes = { + current = mkVM { }; + pre1909 = mkVM ( + { lib, ... }: + { + # create the path that should be migrated by our activation script when + # upgrading to a newer nixos version + system.stateVersion = "19.03"; + systemd.tmpfiles.settings.systemd-timesyncd-test = { + "/var/lib/systemd/timesync".R = { }; + "/var/lib/systemd/timesync".L.argument = "/var/lib/private/systemd/timesync"; + "/var/lib/private/systemd/timesync".d = { + user = "systemd-timesync"; + group = "systemd-timesync"; + }; + }; + } + ); + }; - testScript = '' - start_all() - current.succeed("systemctl status systemd-timesyncd.service") - # on a new install with a recent systemd there should not be any - # leftovers from the dynamic user mess - current.succeed("test -e /var/lib/systemd/timesync") - current.succeed("test ! -L /var/lib/systemd/timesync") + testScript = '' + start_all() + current.succeed("systemctl status systemd-timesyncd.service") + # on a new install with a recent systemd there should not be any + # leftovers from the dynamic user mess + current.succeed("test -e /var/lib/systemd/timesync") + current.succeed("test ! -L /var/lib/systemd/timesync") - # timesyncd should be running on the upgrading system since we fixed the - # file bits in the activation script - pre1909.succeed("systemctl status systemd-timesyncd.service") + # timesyncd should be running on the upgrading system since we fixed the + # file bits in the activation script + pre1909.succeed("systemctl status systemd-timesyncd.service") - # the path should be gone after the migration - pre1909.succeed("test ! -e /var/lib/private/systemd/timesync") + # the path should be gone after the migration + pre1909.succeed("test ! -e /var/lib/private/systemd/timesync") - # and the new path should no longer be a symlink - pre1909.succeed("test -e /var/lib/systemd/timesync") - pre1909.succeed("test ! -L /var/lib/systemd/timesync") + # and the new path should no longer be a symlink + pre1909.succeed("test -e /var/lib/systemd/timesync") + pre1909.succeed("test ! -L /var/lib/systemd/timesync") - # after a restart things should still work and not fail in the activation - # scripts and cause the boot to fail.. - pre1909.shutdown() - pre1909.start() - pre1909.succeed("systemctl status systemd-timesyncd.service") - ''; -}) + # after a restart things should still work and not fail in the activation + # scripts and cause the boot to fail.. + pre1909.shutdown() + pre1909.start() + pre1909.succeed("systemctl status systemd-timesyncd.service") + ''; + } +) diff --git a/nixos/tests/systemd-user-tmpfiles-rules.nix b/nixos/tests/systemd-user-tmpfiles-rules.nix index bf29b4b57be3e0..6e11e9d4e5f68b 100644 --- a/nixos/tests/systemd-user-tmpfiles-rules.nix +++ b/nixos/tests/systemd-user-tmpfiles-rules.nix @@ -1,35 +1,42 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "systemd-user-tmpfiles-rules"; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "systemd-user-tmpfiles-rules"; - meta = with lib.maintainers; { - maintainers = [ schnusch ]; - }; - - nodes.machine = { ... }: { - users.users = { - alice.isNormalUser = true; - bob.isNormalUser = true; + meta = with lib.maintainers; { + maintainers = [ schnusch ]; }; - systemd.user.tmpfiles = { - rules = [ - "d %h/user_tmpfiles_created" - ]; - users.alice.rules = [ - "d %h/only_alice" - ]; - }; - }; + nodes.machine = + { ... }: + { + users.users = { + alice.isNormalUser = true; + bob.isNormalUser = true; + }; + + systemd.user.tmpfiles = { + rules = [ + "d %h/user_tmpfiles_created" + ]; + users.alice.rules = [ + "d %h/only_alice" + ]; + }; + }; - testScript = { ... }: '' - machine.succeed("loginctl enable-linger alice bob") + testScript = + { ... }: + '' + machine.succeed("loginctl enable-linger alice bob") - machine.wait_until_succeeds("systemctl --user --machine=alice@ is-active systemd-tmpfiles-setup.service") - machine.succeed("[ -d ~alice/user_tmpfiles_created ]") - machine.succeed("[ -d ~alice/only_alice ]") + machine.wait_until_succeeds("systemctl --user --machine=alice@ is-active systemd-tmpfiles-setup.service") + machine.succeed("[ -d ~alice/user_tmpfiles_created ]") + machine.succeed("[ -d ~alice/only_alice ]") - machine.wait_until_succeeds("systemctl --user --machine=bob@ is-active systemd-tmpfiles-setup.service") - machine.succeed("[ -d ~bob/user_tmpfiles_created ]") - machine.succeed("[ ! -e ~bob/only_alice ]") - ''; -}) + machine.wait_until_succeeds("systemctl --user --machine=bob@ is-active systemd-tmpfiles-setup.service") + machine.succeed("[ -d ~bob/user_tmpfiles_created ]") + machine.succeed("[ ! -e ~bob/only_alice ]") + ''; + } +) diff --git a/nixos/tests/systemd-userdbd.nix b/nixos/tests/systemd-userdbd.nix index 5d0233ffd9fb81..75fe469ed96390 100644 --- a/nixos/tests/systemd-userdbd.nix +++ b/nixos/tests/systemd-userdbd.nix @@ -1,32 +1,37 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "systemd-userdbd"; - nodes.machine = { config, pkgs, ... }: { - services.userdbd.enable = true; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "systemd-userdbd"; + nodes.machine = + { config, pkgs, ... }: + { + services.userdbd.enable = true; - users.users.test-user-nss = { - isNormalUser = true; - }; + users.users.test-user-nss = { + isNormalUser = true; + }; - environment.etc."userdb/test-user-dropin.user".text = builtins.toJSON { - userName = "test-user-dropin"; - }; + environment.etc."userdb/test-user-dropin.user".text = builtins.toJSON { + userName = "test-user-dropin"; + }; - environment.systemPackages = with pkgs; [ libvarlink ]; - }; - testScript = '' - import json - from shlex import quote + environment.systemPackages = with pkgs; [ libvarlink ]; + }; + testScript = '' + import json + from shlex import quote - def getUserRecord(name): - Interface = "unix:/run/systemd/userdb/io.systemd.Multiplexer/io.systemd.UserDatabase" - payload = json.dumps({ - "service": "io.systemd.Multiplexer", - "userName": name - }) - return json.loads(machine.succeed(f"varlink call {Interface}.GetUserRecord {quote(payload)}")) + def getUserRecord(name): + Interface = "unix:/run/systemd/userdb/io.systemd.Multiplexer/io.systemd.UserDatabase" + payload = json.dumps({ + "service": "io.systemd.Multiplexer", + "userName": name + }) + return json.loads(machine.succeed(f"varlink call {Interface}.GetUserRecord {quote(payload)}")) - machine.wait_for_unit("systemd-userdbd.socket") - getUserRecord("test-user-nss") - getUserRecord("test-user-dropin") - ''; -}) + machine.wait_for_unit("systemd-userdbd.socket") + getUserRecord("test-user-nss") + getUserRecord("test-user-dropin") + ''; + } +) diff --git a/nixos/tests/systemd.nix b/nixos/tests/systemd.nix index 63c52227e7fdc8..d8dc1998c03b97 100644 --- a/nixos/tests/systemd.nix +++ b/nixos/tests/systemd.nix @@ -1,231 +1,252 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "systemd"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "systemd"; + + nodes.machine = + { config, lib, ... }: + { + imports = [ + common/user-account.nix + common/x11.nix + ]; + + virtualisation.emptyDiskImages = [ + 512 + 512 + ]; + + environment.systemPackages = [ pkgs.cryptsetup ]; + + virtualisation.fileSystems = { + "/test-x-initrd-mount" = { + device = "/dev/vdb"; + fsType = "ext2"; + autoFormat = true; + noCheck = true; + options = [ "x-initrd.mount" ]; + }; + }; + + systemd.extraConfig = "DefaultEnvironment=\"XXX_SYSTEM=foo\""; + systemd.user.extraConfig = "DefaultEnvironment=\"XXX_USER=bar\""; + services.journald.extraConfig = "Storage=volatile"; + test-support.displayManager.auto.user = "alice"; + + systemd.shutdown.test = pkgs.writeScript "test.shutdown" '' + #!${pkgs.runtimeShell} + PATH=${ + lib.makeBinPath ( + with pkgs; + [ + util-linux + coreutils + ] + ) + } + mount -t 9p shared -o trans=virtio,version=9p2000.L /tmp/shared + touch /tmp/shared/shutdown-test + umount /tmp/shared + ''; + + systemd.services.oncalendar-test = { + description = "calendar test"; + # Japan does not have DST which makes the test a little bit simpler + startAt = "Wed 10:00 Asia/Tokyo"; + script = "true"; + }; + + systemd.services.testDependency1 = { + description = "Test Dependency 1"; + wantedBy = [ config.systemd.services."testservice1".name ]; + serviceConfig.Type = "oneshot"; + script = '' + true + ''; + }; + + systemd.services.testservice1 = { + description = "Test Service 1"; + wantedBy = [ config.systemd.targets.multi-user.name ]; + serviceConfig.Type = "oneshot"; + script = '' + if [ "$XXX_SYSTEM" = foo ]; then + touch /system_conf_read + fi + ''; + }; + + systemd.user.services.testservice2 = { + description = "Test Service 2"; + wantedBy = [ "default.target" ]; + serviceConfig.Type = "oneshot"; + script = '' + if [ "$XXX_USER" = bar ]; then + touch "$HOME/user_conf_read" + fi + ''; + }; + + systemd.watchdog = { + device = "/dev/watchdog"; + runtimeTime = "30s"; + rebootTime = "10min"; + kexecTime = "5min"; + }; + + environment.etc."systemd/system-preset/10-testservice.preset".text = '' + disable ${config.systemd.services.testservice1.name} + ''; + }; - nodes.machine = { config, lib, ... }: { - imports = [ common/user-account.nix common/x11.nix ]; + testScript = + { nodes, ... }: + '' + import re + import subprocess + + machine.start(allow_reboot=True) + + # Will not succeed unless ConditionFirstBoot=yes + machine.wait_for_unit("first-boot-complete.target") + + # Make sure, a subsequent boot isn't a ConditionFirstBoot=yes. + machine.reboot() + machine.wait_for_x() + state = machine.get_unit_info("first-boot-complete.target")['ActiveState'] + assert state == 'inactive', "Detected first boot despite first-boot-completed.target was already reached on a previous boot." + + # wait for user services + machine.wait_for_unit("default.target", "alice") + + with subtest("systemctl edit suggests --runtime"): + # --runtime is suggested when using `systemctl edit` + ret, out = machine.execute("systemctl edit testservice1.service 2>&1") + assert ret == 1 + assert out.rstrip("\n") == "The unit-directory '/etc/systemd/system' is read-only on NixOS, so it's not possible to edit system-units directly. Use 'systemctl edit --runtime' instead." + # editing w/o `--runtime` is possible for user-services, however + # it's not possible because we're not in a tty when grepping + # (i.e. hacky way to ensure that the error from above doesn't appear here). + _, out = machine.execute("systemctl --user edit testservice2.service 2>&1") + assert out.rstrip("\n") == "Cannot edit units if not on a tty." + + # Regression test for https://github.com/NixOS/nixpkgs/issues/105049 + with subtest("systemd reads timezone database in /etc/zoneinfo"): + timer = machine.succeed("TZ=UTC systemctl show --property=TimersCalendar oncalendar-test.timer") + assert re.search("next_elapse=Wed ....-..-.. 01:00:00 UTC", timer), f"got {timer.strip()}" + + # Regression test for https://github.com/NixOS/nixpkgs/issues/35415 + with subtest("configuration files are recognized by systemd"): + machine.succeed("test -e /system_conf_read") + machine.succeed("test -e /home/alice/user_conf_read") + machine.succeed("test -z $(ls -1 /var/log/journal)") + + with subtest("regression test for https://bugs.freedesktop.org/show_bug.cgi?id=77507"): + retcode, output = machine.execute("systemctl status testservice1.service") + assert retcode in [0, 3] # https://bugs.freedesktop.org/show_bug.cgi?id=77507 + + # Regression test for https://github.com/NixOS/nixpkgs/issues/35268 + with subtest("file system with x-initrd.mount is not unmounted"): + machine.succeed("mountpoint -q /test-x-initrd-mount") + machine.shutdown() + + subprocess.check_call( + [ + "qemu-img", + "convert", + "-O", + "raw", + "vm-state-machine/empty0.qcow2", + "x-initrd-mount.raw", + ] + ) + extinfo = subprocess.check_output( + [ + "${pkgs.e2fsprogs}/bin/dumpe2fs", + "x-initrd-mount.raw", + ] + ).decode("utf-8") + assert ( + re.search(r"^Filesystem state: *clean$", extinfo, re.MULTILINE) is not None + ), ("File system was not cleanly unmounted: " + extinfo) + + # Regression test for https://github.com/NixOS/nixpkgs/pull/91232 + with subtest("setting transient hostnames works"): + machine.succeed("hostnamectl set-hostname --transient machine-transient") + machine.fail("hostnamectl set-hostname machine-all") + + with subtest("systemd-shutdown works"): + machine.shutdown() + machine.wait_for_unit("multi-user.target") + machine.succeed("test -e /tmp/shared/shutdown-test") + + # Test settings from /etc/sysctl.d/50-default.conf are applied + with subtest("systemd sysctl settings are applied"): + machine.wait_for_unit("multi-user.target") + assert "fq_codel" in machine.succeed("sysctl net.core.default_qdisc") + + # Test systemd is configured to manage a watchdog + with subtest("systemd manages hardware watchdog"): + machine.wait_for_unit("multi-user.target") + + # It seems that the device's path doesn't appear in 'systemctl show' so + # check it separately. + assert "WatchdogDevice=/dev/watchdog" in machine.succeed( + "cat /etc/systemd/system.conf" + ) + + output = machine.succeed("systemctl show | grep Watchdog") + # assert "RuntimeWatchdogUSec=30s" in output + # for some reason RuntimeWatchdogUSec, doesn't seem to be updated in here. + assert "RebootWatchdogUSec=10min" in output + assert "KExecWatchdogUSec=5min" in output + + # Test systemd cryptsetup support + with subtest("systemd successfully reads /etc/crypttab and unlocks volumes"): + # create a luks volume and put a filesystem on it + machine.succeed( + "echo -n supersecret | cryptsetup luksFormat -q /dev/vdc -", + "echo -n supersecret | cryptsetup luksOpen --key-file - /dev/vdc foo", + "mkfs.ext3 /dev/mapper/foo", + ) + + # create a keyfile and /etc/crypttab + machine.succeed("echo -n supersecret > /var/lib/luks-keyfile") + machine.succeed("chmod 600 /var/lib/luks-keyfile") + machine.succeed("echo 'luks1 /dev/vdc /var/lib/luks-keyfile luks' > /etc/crypttab") + + # after a reboot, systemd should unlock the volume and we should be able to mount it + machine.shutdown() + machine.succeed("systemctl status systemd-cryptsetup@luks1.service") + machine.succeed("mkdir -p /tmp/luks1") + machine.succeed("mount /dev/mapper/luks1 /tmp/luks1") + + # Do some IP traffic + output_ping = machine.succeed( + "systemd-run --wait -- ping -c 1 127.0.0.1 2>&1" + ) - virtualisation.emptyDiskImages = [ 512 512 ]; + with subtest("systemd reports accounting data on system.slice"): + output = machine.succeed("systemctl status system.slice") + assert "CPU:" in output + assert "Memory:" in output - environment.systemPackages = [ pkgs.cryptsetup ]; + assert "IP:" in output + assert "0B in, 0B out" not in output - virtualisation.fileSystems = { - "/test-x-initrd-mount" = { - device = "/dev/vdb"; - fsType = "ext2"; - autoFormat = true; - noCheck = true; - options = [ "x-initrd.mount" ]; - }; - }; - - systemd.extraConfig = "DefaultEnvironment=\"XXX_SYSTEM=foo\""; - systemd.user.extraConfig = "DefaultEnvironment=\"XXX_USER=bar\""; - services.journald.extraConfig = "Storage=volatile"; - test-support.displayManager.auto.user = "alice"; - - systemd.shutdown.test = pkgs.writeScript "test.shutdown" '' - #!${pkgs.runtimeShell} - PATH=${lib.makeBinPath (with pkgs; [ util-linux coreutils ])} - mount -t 9p shared -o trans=virtio,version=9p2000.L /tmp/shared - touch /tmp/shared/shutdown-test - umount /tmp/shared - ''; - - systemd.services.oncalendar-test = { - description = "calendar test"; - # Japan does not have DST which makes the test a little bit simpler - startAt = "Wed 10:00 Asia/Tokyo"; - script = "true"; - }; - - systemd.services.testDependency1 = { - description = "Test Dependency 1"; - wantedBy = [ config.systemd.services."testservice1".name ]; - serviceConfig.Type = "oneshot"; - script = '' - true - ''; - }; - - systemd.services.testservice1 = { - description = "Test Service 1"; - wantedBy = [ config.systemd.targets.multi-user.name ]; - serviceConfig.Type = "oneshot"; - script = '' - if [ "$XXX_SYSTEM" = foo ]; then - touch /system_conf_read - fi - ''; - }; - - systemd.user.services.testservice2 = { - description = "Test Service 2"; - wantedBy = [ "default.target" ]; - serviceConfig.Type = "oneshot"; - script = '' - if [ "$XXX_USER" = bar ]; then - touch "$HOME/user_conf_read" - fi - ''; - }; - - systemd.watchdog = { - device = "/dev/watchdog"; - runtimeTime = "30s"; - rebootTime = "10min"; - kexecTime = "5min"; - }; - - environment.etc."systemd/system-preset/10-testservice.preset".text = '' - disable ${config.systemd.services.testservice1.name} - ''; - }; - - testScript = { nodes, ... }: '' - import re - import subprocess - - machine.start(allow_reboot=True) - - # Will not succeed unless ConditionFirstBoot=yes - machine.wait_for_unit("first-boot-complete.target") - - # Make sure, a subsequent boot isn't a ConditionFirstBoot=yes. - machine.reboot() - machine.wait_for_x() - state = machine.get_unit_info("first-boot-complete.target")['ActiveState'] - assert state == 'inactive', "Detected first boot despite first-boot-completed.target was already reached on a previous boot." - - # wait for user services - machine.wait_for_unit("default.target", "alice") - - with subtest("systemctl edit suggests --runtime"): - # --runtime is suggested when using `systemctl edit` - ret, out = machine.execute("systemctl edit testservice1.service 2>&1") - assert ret == 1 - assert out.rstrip("\n") == "The unit-directory '/etc/systemd/system' is read-only on NixOS, so it's not possible to edit system-units directly. Use 'systemctl edit --runtime' instead." - # editing w/o `--runtime` is possible for user-services, however - # it's not possible because we're not in a tty when grepping - # (i.e. hacky way to ensure that the error from above doesn't appear here). - _, out = machine.execute("systemctl --user edit testservice2.service 2>&1") - assert out.rstrip("\n") == "Cannot edit units if not on a tty." - - # Regression test for https://github.com/NixOS/nixpkgs/issues/105049 - with subtest("systemd reads timezone database in /etc/zoneinfo"): - timer = machine.succeed("TZ=UTC systemctl show --property=TimersCalendar oncalendar-test.timer") - assert re.search("next_elapse=Wed ....-..-.. 01:00:00 UTC", timer), f"got {timer.strip()}" - - # Regression test for https://github.com/NixOS/nixpkgs/issues/35415 - with subtest("configuration files are recognized by systemd"): - machine.succeed("test -e /system_conf_read") - machine.succeed("test -e /home/alice/user_conf_read") - machine.succeed("test -z $(ls -1 /var/log/journal)") - - with subtest("regression test for https://bugs.freedesktop.org/show_bug.cgi?id=77507"): - retcode, output = machine.execute("systemctl status testservice1.service") - assert retcode in [0, 3] # https://bugs.freedesktop.org/show_bug.cgi?id=77507 - - # Regression test for https://github.com/NixOS/nixpkgs/issues/35268 - with subtest("file system with x-initrd.mount is not unmounted"): - machine.succeed("mountpoint -q /test-x-initrd-mount") - machine.shutdown() - - subprocess.check_call( - [ - "qemu-img", - "convert", - "-O", - "raw", - "vm-state-machine/empty0.qcow2", - "x-initrd-mount.raw", - ] - ) - extinfo = subprocess.check_output( - [ - "${pkgs.e2fsprogs}/bin/dumpe2fs", - "x-initrd-mount.raw", - ] - ).decode("utf-8") - assert ( - re.search(r"^Filesystem state: *clean$", extinfo, re.MULTILINE) is not None - ), ("File system was not cleanly unmounted: " + extinfo) - - # Regression test for https://github.com/NixOS/nixpkgs/pull/91232 - with subtest("setting transient hostnames works"): - machine.succeed("hostnamectl set-hostname --transient machine-transient") - machine.fail("hostnamectl set-hostname machine-all") - - with subtest("systemd-shutdown works"): - machine.shutdown() - machine.wait_for_unit("multi-user.target") - machine.succeed("test -e /tmp/shared/shutdown-test") - - # Test settings from /etc/sysctl.d/50-default.conf are applied - with subtest("systemd sysctl settings are applied"): - machine.wait_for_unit("multi-user.target") - assert "fq_codel" in machine.succeed("sysctl net.core.default_qdisc") - - # Test systemd is configured to manage a watchdog - with subtest("systemd manages hardware watchdog"): - machine.wait_for_unit("multi-user.target") - - # It seems that the device's path doesn't appear in 'systemctl show' so - # check it separately. - assert "WatchdogDevice=/dev/watchdog" in machine.succeed( - "cat /etc/systemd/system.conf" - ) + assert "IO:" in output + assert "0B read, 0B written" not in output - output = machine.succeed("systemctl show | grep Watchdog") - # assert "RuntimeWatchdogUSec=30s" in output - # for some reason RuntimeWatchdogUSec, doesn't seem to be updated in here. - assert "RebootWatchdogUSec=10min" in output - assert "KExecWatchdogUSec=5min" in output - - # Test systemd cryptsetup support - with subtest("systemd successfully reads /etc/crypttab and unlocks volumes"): - # create a luks volume and put a filesystem on it - machine.succeed( - "echo -n supersecret | cryptsetup luksFormat -q /dev/vdc -", - "echo -n supersecret | cryptsetup luksOpen --key-file - /dev/vdc foo", - "mkfs.ext3 /dev/mapper/foo", - ) + with subtest("systemd per-unit accounting works"): + assert "IP traffic received: 84B sent: 84B" in output_ping - # create a keyfile and /etc/crypttab - machine.succeed("echo -n supersecret > /var/lib/luks-keyfile") - machine.succeed("chmod 600 /var/lib/luks-keyfile") - machine.succeed("echo 'luks1 /dev/vdc /var/lib/luks-keyfile luks' > /etc/crypttab") - - # after a reboot, systemd should unlock the volume and we should be able to mount it - machine.shutdown() - machine.succeed("systemctl status systemd-cryptsetup@luks1.service") - machine.succeed("mkdir -p /tmp/luks1") - machine.succeed("mount /dev/mapper/luks1 /tmp/luks1") - - # Do some IP traffic - output_ping = machine.succeed( - "systemd-run --wait -- ping -c 1 127.0.0.1 2>&1" - ) - - with subtest("systemd reports accounting data on system.slice"): - output = machine.succeed("systemctl status system.slice") - assert "CPU:" in output - assert "Memory:" in output - - assert "IP:" in output - assert "0B in, 0B out" not in output - - assert "IO:" in output - assert "0B read, 0B written" not in output - - with subtest("systemd per-unit accounting works"): - assert "IP traffic received: 84B sent: 84B" in output_ping - - with subtest("systemd environment is properly set"): - machine.systemctl("daemon-reexec") # Rewrites /proc/1/environ - machine.succeed("grep -q TZDIR=/etc/zoneinfo /proc/1/environ") - - with subtest("systemd presets are ignored"): - machine.succeed("systemctl preset ${nodes.machine.systemd.services.testservice1.name}") - machine.succeed("test -e /etc/systemd/system/${nodes.machine.systemd.services.testservice1.name}") - ''; -}) + with subtest("systemd environment is properly set"): + machine.systemctl("daemon-reexec") # Rewrites /proc/1/environ + machine.succeed("grep -q TZDIR=/etc/zoneinfo /proc/1/environ") + + with subtest("systemd presets are ignored"): + machine.succeed("systemctl preset ${nodes.machine.systemd.services.testservice1.name}") + machine.succeed("test -e /etc/systemd/system/${nodes.machine.systemd.services.testservice1.name}") + ''; + } +) diff --git a/nixos/tests/systemtap.nix b/nixos/tests/systemtap.nix index 5cd79d66e872ba..d278cf41c0dab4 100644 --- a/nixos/tests/systemtap.nix +++ b/nixos/tests/systemtap.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }@args: with pkgs.lib; @@ -14,34 +15,41 @@ let ''; ## TODO shared infra with ../kernel-generic.nix - testsForLinuxPackages = linuxPackages: (import ./make-test-python.nix ({ pkgs, ... }: { - name = "kernel-${linuxPackages.kernel.version}"; - meta = with pkgs.lib.maintainers; { - maintainers = [ bendlas ]; - }; - - nodes.machine = { ... }: + testsForLinuxPackages = + linuxPackages: + (import ./make-test-python.nix ( + { pkgs, ... }: { - boot.kernelPackages = linuxPackages; - programs.systemtap.enable = true; - }; - - testScript = - '' - with subtest("Capture stap ouput"): - output = machine.succeed("stap ${stapScript} 2>&1") - - with subtest("Ensure that expected output from stap script is there"): - assert "kernel function probe & println work\n" == output, "kernel function probe & println work\n != " + output - ''; - }) args); + name = "kernel-${linuxPackages.kernel.version}"; + meta = with pkgs.lib.maintainers; { + maintainers = [ bendlas ]; + }; + + nodes.machine = + { ... }: + { + boot.kernelPackages = linuxPackages; + programs.systemtap.enable = true; + }; + + testScript = '' + with subtest("Capture stap ouput"): + output = machine.succeed("stap ${stapScript} 2>&1") + + with subtest("Ensure that expected output from stap script is there"): + assert "kernel function probe & println work\n" == output, "kernel function probe & println work\n != " + output + ''; + } + ) args); ## TODO shared infra with ../kernel-generic.nix kernels = { inherit (pkgs.linuxKernel.packageAliases) linux_default linux_latest; }; -in mapAttrs (_: lP: testsForLinuxPackages lP) kernels // { +in +mapAttrs (_: lP: testsForLinuxPackages lP) kernels +// { passthru = { inherit testsForLinuxPackages; diff --git a/nixos/tests/tandoor-recipes.nix b/nixos/tests/tandoor-recipes.nix index bc5c3cf735755c..536746e092b99d 100644 --- a/nixos/tests/tandoor-recipes.nix +++ b/nixos/tests/tandoor-recipes.nix @@ -1,41 +1,46 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "tandoor-recipes"; - meta.maintainers = with lib.maintainers; [ ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "tandoor-recipes"; + meta.maintainers = with lib.maintainers; [ ]; - nodes.machine = { pkgs, ... }: { - services.tandoor-recipes = { - enable = true; - extraConfig = { - DB_ENGINE = "django.db.backends.postgresql"; - POSTGRES_HOST = "/run/postgresql"; - POSTGRES_USER = "tandoor_recipes"; - POSTGRES_DB = "tandoor_recipes"; - }; - }; + nodes.machine = + { pkgs, ... }: + { + services.tandoor-recipes = { + enable = true; + extraConfig = { + DB_ENGINE = "django.db.backends.postgresql"; + POSTGRES_HOST = "/run/postgresql"; + POSTGRES_USER = "tandoor_recipes"; + POSTGRES_DB = "tandoor_recipes"; + }; + }; - services.postgresql = { - enable = true; - ensureDatabases = [ "tandoor_recipes" ]; - ensureUsers = [ - { - name = "tandoor_recipes"; - ensureDBOwnership = true; - } - ]; - }; + services.postgresql = { + enable = true; + ensureDatabases = [ "tandoor_recipes" ]; + ensureUsers = [ + { + name = "tandoor_recipes"; + ensureDBOwnership = true; + } + ]; + }; - systemd.services = { - tandoor-recipes = { - after = [ "postgresql.service" ]; + systemd.services = { + tandoor-recipes = { + after = [ "postgresql.service" ]; + }; + }; }; - }; - }; - testScript = '' - machine.wait_for_unit("tandoor-recipes.service") + testScript = '' + machine.wait_for_unit("tandoor-recipes.service") - with subtest("Web interface gets ready"): - # Wait until server accepts connections - machine.wait_until_succeeds("curl -fs localhost:8080") - ''; -}) + with subtest("Web interface gets ready"): + # Wait until server accepts connections + machine.wait_until_succeeds("curl -fs localhost:8080") + ''; + } +) diff --git a/nixos/tests/tang.nix b/nixos/tests/tang.nix index 10486a9feb8cff..58d3510617917d 100644 --- a/nixos/tests/tang.nix +++ b/nixos/tests/tang.nix @@ -1,81 +1,93 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "tang"; - meta = with pkgs.lib.maintainers; { - maintainers = [ jfroche ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "tang"; + meta = with pkgs.lib.maintainers; { + maintainers = [ jfroche ]; + }; - nodes.server = - { config - , pkgs - , modulesPath - , ... - }: { - imports = [ - "${modulesPath}/../tests/common/auto-format-root-device.nix" - ]; - virtualisation = { - emptyDiskImages = [ 512 ]; - useBootLoader = true; - useEFIBoot = true; - # This requires to have access - # to a host Nix store as - # the new root device is /dev/vdb - # an empty 512MiB drive, containing no Nix store. - mountHostNixStore = true; - }; + nodes.server = + { + config, + pkgs, + modulesPath, + ... + }: + { + imports = [ + "${modulesPath}/../tests/common/auto-format-root-device.nix" + ]; + virtualisation = { + emptyDiskImages = [ 512 ]; + useBootLoader = true; + useEFIBoot = true; + # This requires to have access + # to a host Nix store as + # the new root device is /dev/vdb + # an empty 512MiB drive, containing no Nix store. + mountHostNixStore = true; + }; - boot.loader.systemd-boot.enable = true; + boot.loader.systemd-boot.enable = true; - networking.interfaces.eth1.ipv4.addresses = [ - { address = "192.168.0.1"; prefixLength = 24; } - ]; + networking.interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.0.1"; + prefixLength = 24; + } + ]; - environment.systemPackages = with pkgs; [ clevis tang cryptsetup ]; - services.tang = { - enable = true; - ipAddressAllow = [ "127.0.0.1/32" ]; + environment.systemPackages = with pkgs; [ + clevis + tang + cryptsetup + ]; + services.tang = { + enable = true; + ipAddressAllow = [ "127.0.0.1/32" ]; + }; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("sockets.target") + testScript = '' + start_all() + machine.wait_for_unit("sockets.target") - with subtest("Check keys are generated"): - machine.wait_until_succeeds("curl -v http://127.0.0.1:7654/adv") - key = machine.wait_until_succeeds("tang-show-keys 7654") + with subtest("Check keys are generated"): + machine.wait_until_succeeds("curl -v http://127.0.0.1:7654/adv") + key = machine.wait_until_succeeds("tang-show-keys 7654") - with subtest("Check systemd access list"): - machine.succeed("ping -c 3 192.168.0.1") - machine.fail("curl -v --connect-timeout 3 http://192.168.0.1:7654/adv") + with subtest("Check systemd access list"): + machine.succeed("ping -c 3 192.168.0.1") + machine.fail("curl -v --connect-timeout 3 http://192.168.0.1:7654/adv") - with subtest("Check basic encrypt and decrypt message"): - machine.wait_until_succeeds(f"""echo 'Hello World' | clevis encrypt tang '{{ "url": "http://127.0.0.1:7654", "thp":"{key}"}}' > /tmp/encrypted""") - decrypted = machine.wait_until_succeeds("clevis decrypt < /tmp/encrypted") - assert decrypted.strip() == "Hello World" - machine.wait_until_succeeds("tang-show-keys 7654") + with subtest("Check basic encrypt and decrypt message"): + machine.wait_until_succeeds(f"""echo 'Hello World' | clevis encrypt tang '{{ "url": "http://127.0.0.1:7654", "thp":"{key}"}}' > /tmp/encrypted""") + decrypted = machine.wait_until_succeeds("clevis decrypt < /tmp/encrypted") + assert decrypted.strip() == "Hello World" + machine.wait_until_succeeds("tang-show-keys 7654") - with subtest("Check encrypt and decrypt disk"): - machine.succeed("cryptsetup luksFormat --force-password --batch-mode /dev/vdb <<<'password'") - machine.succeed(f"""clevis luks bind -s1 -y -f -d /dev/vdb tang '{{ "url": "http://127.0.0.1:7654", "thp":"{key}" }}' <<< 'password' """) - clevis_luks = machine.succeed("clevis luks list -d /dev/vdb") - assert clevis_luks.strip() == """1: tang '{"url":"http://127.0.0.1:7654"}'""" - machine.succeed("clevis luks unlock -d /dev/vdb") - machine.succeed("find /dev/mapper -name 'luks*' -exec cryptsetup close {} +") - machine.succeed("clevis luks unlock -d /dev/vdb") - machine.succeed("find /dev/mapper -name 'luks*' -exec cryptsetup close {} +") - # without tang available, unlock should fail - machine.succeed("systemctl stop tangd.socket") - machine.fail("clevis luks unlock -d /dev/vdb") - machine.succeed("systemctl start tangd.socket") + with subtest("Check encrypt and decrypt disk"): + machine.succeed("cryptsetup luksFormat --force-password --batch-mode /dev/vdb <<<'password'") + machine.succeed(f"""clevis luks bind -s1 -y -f -d /dev/vdb tang '{{ "url": "http://127.0.0.1:7654", "thp":"{key}" }}' <<< 'password' """) + clevis_luks = machine.succeed("clevis luks list -d /dev/vdb") + assert clevis_luks.strip() == """1: tang '{"url":"http://127.0.0.1:7654"}'""" + machine.succeed("clevis luks unlock -d /dev/vdb") + machine.succeed("find /dev/mapper -name 'luks*' -exec cryptsetup close {} +") + machine.succeed("clevis luks unlock -d /dev/vdb") + machine.succeed("find /dev/mapper -name 'luks*' -exec cryptsetup close {} +") + # without tang available, unlock should fail + machine.succeed("systemctl stop tangd.socket") + machine.fail("clevis luks unlock -d /dev/vdb") + machine.succeed("systemctl start tangd.socket") - with subtest("Rotate server keys"): - machine.succeed("${pkgs.tang}/libexec/tangd-rotate-keys -d /var/lib/tang") - machine.succeed("clevis luks unlock -d /dev/vdb") - machine.succeed("find /dev/mapper -name 'luks*' -exec cryptsetup close {} +") + with subtest("Rotate server keys"): + machine.succeed("${pkgs.tang}/libexec/tangd-rotate-keys -d /var/lib/tang") + machine.succeed("clevis luks unlock -d /dev/vdb") + machine.succeed("find /dev/mapper -name 'luks*' -exec cryptsetup close {} +") - with subtest("Test systemd service security"): - output = machine.succeed("systemd-analyze security tangd@.service") - machine.log(output) - assert output[-9:-1] == "SAFE :-}" - ''; -}) + with subtest("Test systemd service security"): + output = machine.succeed("systemd-analyze security tangd@.service") + machine.log(output) + assert output[-9:-1] == "SAFE :-}" + ''; + } +) diff --git a/nixos/tests/taskserver.nix b/nixos/tests/taskserver.nix index caf48db77c44a9..bd4dac40da87b2 100644 --- a/nixos/tests/taskserver.nix +++ b/nixos/tests/taskserver.nix @@ -1,275 +1,299 @@ -import ./make-test-python.nix ({ pkgs, ... }: let - snakeOil = pkgs.runCommand "snakeoil-certs" { - outputs = [ "out" "cacert" "cert" "key" "crl" ]; - buildInputs = [ pkgs.gnutls.bin ]; - caTemplate = pkgs.writeText "snakeoil-ca.template" '' - cn = server - expiration_days = -1 - cert_signing_key - ca - ''; - certTemplate = pkgs.writeText "snakeoil-cert.template" '' - cn = server - expiration_days = -1 - tls_www_server - encryption_key - signing_key - ''; - crlTemplate = pkgs.writeText "snakeoil-crl.template" '' - expiration_days = -1 - ''; - userCertTemplate = pkgs.writeText "snakeoil-user-cert.template" '' - organization = snakeoil - cn = server - expiration_days = -1 - tls_www_client - encryption_key - signing_key - ''; - } '' - certtool -p --bits 4096 --outfile ca.key - certtool -s --template "$caTemplate" --load-privkey ca.key \ - --outfile "$cacert" - certtool -p --bits 4096 --outfile "$key" - certtool -c --template "$certTemplate" \ - --load-ca-privkey ca.key \ - --load-ca-certificate "$cacert" \ - --load-privkey "$key" \ - --outfile "$cert" - certtool --generate-crl --template "$crlTemplate" \ - --load-ca-privkey ca.key \ - --load-ca-certificate "$cacert" \ - --outfile "$crl" - - mkdir "$out" - - # Stripping key information before the actual PEM-encoded values is solely - # to make test output a bit less verbose when copying the client key to the - # actual client. - certtool -p --bits 4096 | sed -n \ - -e '/^----* *BEGIN/,/^----* *END/p' > "$out/alice.key" - - certtool -c --template "$userCertTemplate" \ - --load-privkey "$out/alice.key" \ - --load-ca-privkey ca.key \ - --load-ca-certificate "$cacert" \ - --outfile "$out/alice.cert" - ''; - -in { - name = "taskserver"; - - nodes = rec { - server = { - services.taskserver.enable = true; - services.taskserver.listenHost = "::"; - services.taskserver.openFirewall = true; - services.taskserver.fqdn = "server"; - services.taskserver.organisations = { - testOrganisation.users = [ "alice" "foo" ]; - anotherOrganisation.users = [ "bob" ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + let + snakeOil = + pkgs.runCommand "snakeoil-certs" + { + outputs = [ + "out" + "cacert" + "cert" + "key" + "crl" + ]; + buildInputs = [ pkgs.gnutls.bin ]; + caTemplate = pkgs.writeText "snakeoil-ca.template" '' + cn = server + expiration_days = -1 + cert_signing_key + ca + ''; + certTemplate = pkgs.writeText "snakeoil-cert.template" '' + cn = server + expiration_days = -1 + tls_www_server + encryption_key + signing_key + ''; + crlTemplate = pkgs.writeText "snakeoil-crl.template" '' + expiration_days = -1 + ''; + userCertTemplate = pkgs.writeText "snakeoil-user-cert.template" '' + organization = snakeoil + cn = server + expiration_days = -1 + tls_www_client + encryption_key + signing_key + ''; + } + '' + certtool -p --bits 4096 --outfile ca.key + certtool -s --template "$caTemplate" --load-privkey ca.key \ + --outfile "$cacert" + certtool -p --bits 4096 --outfile "$key" + certtool -c --template "$certTemplate" \ + --load-ca-privkey ca.key \ + --load-ca-certificate "$cacert" \ + --load-privkey "$key" \ + --outfile "$cert" + certtool --generate-crl --template "$crlTemplate" \ + --load-ca-privkey ca.key \ + --load-ca-certificate "$cacert" \ + --outfile "$crl" + + mkdir "$out" + + # Stripping key information before the actual PEM-encoded values is solely + # to make test output a bit less verbose when copying the client key to the + # actual client. + certtool -p --bits 4096 | sed -n \ + -e '/^----* *BEGIN/,/^----* *END/p' > "$out/alice.key" + + certtool -c --template "$userCertTemplate" \ + --load-privkey "$out/alice.key" \ + --load-ca-privkey ca.key \ + --load-ca-certificate "$cacert" \ + --outfile "$out/alice.cert" + ''; + + in + { + name = "taskserver"; + + nodes = rec { + server = { + services.taskserver.enable = true; + services.taskserver.listenHost = "::"; + services.taskserver.openFirewall = true; + services.taskserver.fqdn = "server"; + services.taskserver.organisations = { + testOrganisation.users = [ + "alice" + "foo" + ]; + anotherOrganisation.users = [ "bob" ]; + }; - specialisation.manual_config.configuration = { - services.taskserver.pki.manual = { - ca.cert = snakeOil.cacert; - server.cert = snakeOil.cert; - server.key = snakeOil.key; - server.crl = snakeOil.crl; + specialisation.manual_config.configuration = { + services.taskserver.pki.manual = { + ca.cert = snakeOil.cacert; + server.cert = snakeOil.cert; + server.key = snakeOil.key; + server.crl = snakeOil.crl; + }; }; }; - }; - client1 = { pkgs, ... }: { - environment.systemPackages = [ pkgs.taskwarrior2 pkgs.gnutls ]; - users.users.alice.isNormalUser = true; - users.users.bob.isNormalUser = true; - users.users.foo.isNormalUser = true; - users.users.bar.isNormalUser = true; - }; + client1 = + { pkgs, ... }: + { + environment.systemPackages = [ + pkgs.taskwarrior2 + pkgs.gnutls + ]; + users.users.alice.isNormalUser = true; + users.users.bob.isNormalUser = true; + users.users.foo.isNormalUser = true; + users.users.bar.isNormalUser = true; + }; - client2 = client1; - }; + client2 = client1; + }; - testScript = { nodes, ... }: let - cfg = nodes.server.config.services.taskserver; - portStr = toString cfg.listenPort; - specialisations = "${nodes.server.system.build.toplevel}/specialisation"; - newServerSystem = "${specialisations}/manual_config"; - switchToNewServer = "${newServerSystem}/bin/switch-to-configuration test"; - in '' - from shlex import quote + testScript = + { nodes, ... }: + let + cfg = nodes.server.config.services.taskserver; + portStr = toString cfg.listenPort; + specialisations = "${nodes.server.system.build.toplevel}/specialisation"; + newServerSystem = "${specialisations}/manual_config"; + switchToNewServer = "${newServerSystem}/bin/switch-to-configuration test"; + in + '' + from shlex import quote - def su(user, cmd): - return f"su - {user} -c {quote(cmd)}" + def su(user, cmd): + return f"su - {user} -c {quote(cmd)}" - def no_extra_init(client, org, user): - pass + def no_extra_init(client, org, user): + pass - def setup_clients_for(org, user, extra_init=no_extra_init): - for client in [client1, client2]: - with client.nested(f"initialize client for user {user}"): - client.succeed( - su(user, f"rm -rf /home/{user}/.task"), - su(user, "task rc.confirmation=no config confirmation no"), - ) + def setup_clients_for(org, user, extra_init=no_extra_init): + for client in [client1, client2]: + with client.nested(f"initialize client for user {user}"): + client.succeed( + su(user, f"rm -rf /home/{user}/.task"), + su(user, "task rc.confirmation=no config confirmation no"), + ) - exportinfo = server.succeed(f"nixos-taskserver user export {org} {user}") + exportinfo = server.succeed(f"nixos-taskserver user export {org} {user}") - with client.nested("importing taskwarrior configuration"): - client.succeed(su(user, f"eval {quote(exportinfo)} >&2")) + with client.nested("importing taskwarrior configuration"): + client.succeed(su(user, f"eval {quote(exportinfo)} >&2")) - extra_init(client, org, user) + extra_init(client, org, user) - client.succeed(su(user, "task config taskd.server server:${portStr} >&2")) + client.succeed(su(user, "task config taskd.server server:${portStr} >&2")) - client.succeed(su(user, "task sync init >&2")) + client.succeed(su(user, "task sync init >&2")) - def restart_server(): - server.systemctl("restart taskserver.service") - server.wait_for_open_port(${portStr}) + def restart_server(): + server.systemctl("restart taskserver.service") + server.wait_for_open_port(${portStr}) - def re_add_imperative_user(): - with server.nested("(re-)add imperative user bar"): - server.execute("nixos-taskserver org remove imperativeOrg") - server.succeed( - "nixos-taskserver org add imperativeOrg", - "nixos-taskserver user add imperativeOrg bar", + def re_add_imperative_user(): + with server.nested("(re-)add imperative user bar"): + server.execute("nixos-taskserver org remove imperativeOrg") + server.succeed( + "nixos-taskserver org add imperativeOrg", + "nixos-taskserver user add imperativeOrg bar", + ) + setup_clients_for("imperativeOrg", "bar") + + + def test_sync(user): + with subtest(f"sync for user {user}"): + client1.succeed(su(user, "task add foo >&2")) + client1.succeed(su(user, "task sync >&2")) + client2.fail(su(user, "task list >&2")) + client2.succeed(su(user, "task sync >&2")) + client2.succeed(su(user, "task list >&2")) + + + def check_client_cert(user): + # debug level 3 is a workaround for gnutls issue https://gitlab.com/gnutls/gnutls/-/issues/1040 + cmd = ( + f"gnutls-cli -d 3" + f" --x509cafile=/home/{user}/.task/keys/ca.cert" + f" --x509keyfile=/home/{user}/.task/keys/private.key" + f" --x509certfile=/home/{user}/.task/keys/public.cert" + f" --port=${portStr} server < /dev/null" ) - setup_clients_for("imperativeOrg", "bar") - - - def test_sync(user): - with subtest(f"sync for user {user}"): - client1.succeed(su(user, "task add foo >&2")) - client1.succeed(su(user, "task sync >&2")) - client2.fail(su(user, "task list >&2")) - client2.succeed(su(user, "task sync >&2")) - client2.succeed(su(user, "task list >&2")) - - - def check_client_cert(user): - # debug level 3 is a workaround for gnutls issue https://gitlab.com/gnutls/gnutls/-/issues/1040 - cmd = ( - f"gnutls-cli -d 3" - f" --x509cafile=/home/{user}/.task/keys/ca.cert" - f" --x509keyfile=/home/{user}/.task/keys/private.key" - f" --x509certfile=/home/{user}/.task/keys/public.cert" - f" --port=${portStr} server < /dev/null" - ) - return su(user, cmd) + return su(user, cmd) - # Explicitly start the VMs so that we don't accidentally start newServer - server.start() - client1.start() - client2.start() + # Explicitly start the VMs so that we don't accidentally start newServer + server.start() + client1.start() + client2.start() - server.wait_for_unit("taskserver.service") + server.wait_for_unit("taskserver.service") - server.succeed( - "nixos-taskserver user list testOrganisation | grep -qxF alice", - "nixos-taskserver user list testOrganisation | grep -qxF foo", - "nixos-taskserver user list anotherOrganisation | grep -qxF bob", - ) + server.succeed( + "nixos-taskserver user list testOrganisation | grep -qxF alice", + "nixos-taskserver user list testOrganisation | grep -qxF foo", + "nixos-taskserver user list anotherOrganisation | grep -qxF bob", + ) - server.wait_for_open_port(${portStr}) + server.wait_for_open_port(${portStr}) - client1.wait_for_unit("multi-user.target") - client2.wait_for_unit("multi-user.target") + client1.wait_for_unit("multi-user.target") + client2.wait_for_unit("multi-user.target") - setup_clients_for("testOrganisation", "alice") - setup_clients_for("testOrganisation", "foo") - setup_clients_for("anotherOrganisation", "bob") + setup_clients_for("testOrganisation", "alice") + setup_clients_for("testOrganisation", "foo") + setup_clients_for("anotherOrganisation", "bob") - for user in ["alice", "bob", "foo"]: - test_sync(user) + for user in ["alice", "bob", "foo"]: + test_sync(user) - server.fail("nixos-taskserver user add imperativeOrg bar") - re_add_imperative_user() + server.fail("nixos-taskserver user add imperativeOrg bar") + re_add_imperative_user() - test_sync("bar") + test_sync("bar") - with subtest("checking certificate revocation of user bar"): - client1.succeed(check_client_cert("bar")) + with subtest("checking certificate revocation of user bar"): + client1.succeed(check_client_cert("bar")) - server.succeed("nixos-taskserver user remove imperativeOrg bar") - restart_server() + server.succeed("nixos-taskserver user remove imperativeOrg bar") + restart_server() - client1.fail(check_client_cert("bar")) + client1.fail(check_client_cert("bar")) - client1.succeed(su("bar", "task add destroy everything >&2")) - client1.fail(su("bar", "task sync >&2")) + client1.succeed(su("bar", "task add destroy everything >&2")) + client1.fail(su("bar", "task sync >&2")) - re_add_imperative_user() + re_add_imperative_user() - with subtest("checking certificate revocation of org imperativeOrg"): - client1.succeed(check_client_cert("bar")) + with subtest("checking certificate revocation of org imperativeOrg"): + client1.succeed(check_client_cert("bar")) - server.succeed("nixos-taskserver org remove imperativeOrg") - restart_server() + server.succeed("nixos-taskserver org remove imperativeOrg") + restart_server() - client1.fail(check_client_cert("bar")) + client1.fail(check_client_cert("bar")) - client1.succeed(su("bar", "task add destroy even more >&2")) - client1.fail(su("bar", "task sync >&2")) + client1.succeed(su("bar", "task add destroy even more >&2")) + client1.fail(su("bar", "task sync >&2")) - re_add_imperative_user() + re_add_imperative_user() - with subtest("check whether declarative config overrides user bar"): - restart_server() - test_sync("bar") + with subtest("check whether declarative config overrides user bar"): + restart_server() + test_sync("bar") - def init_manual_config(client, org, user): - cfgpath = f"/home/{user}/.task" + def init_manual_config(client, org, user): + cfgpath = f"/home/{user}/.task" - client.copy_from_host( - "${snakeOil.cacert}", - f"{cfgpath}/ca.cert", - ) - for file in ["alice.key", "alice.cert"]: client.copy_from_host( - f"${snakeOil}/{file}", - f"{cfgpath}/{file}", + "${snakeOil.cacert}", + f"{cfgpath}/ca.cert", ) + for file in ["alice.key", "alice.cert"]: + client.copy_from_host( + f"${snakeOil}/{file}", + f"{cfgpath}/{file}", + ) - for file in [f"{user}.key", f"{user}.cert"]: - client.copy_from_host( - f"${snakeOil}/{file}", - f"{cfgpath}/{file}", - ) + for file in [f"{user}.key", f"{user}.cert"]: + client.copy_from_host( + f"${snakeOil}/{file}", + f"{cfgpath}/{file}", + ) - client.succeed( - su("alice", f"task config taskd.ca {cfgpath}/ca.cert"), - su("alice", f"task config taskd.key {cfgpath}/{user}.key"), - su(user, f"task config taskd.certificate {cfgpath}/{user}.cert"), - ) + client.succeed( + su("alice", f"task config taskd.ca {cfgpath}/ca.cert"), + su("alice", f"task config taskd.key {cfgpath}/{user}.key"), + su(user, f"task config taskd.certificate {cfgpath}/{user}.cert"), + ) - with subtest("check manual configuration"): - # Remove the keys from automatic CA creation, to make sure the new - # generation doesn't use keys from before. - server.succeed("rm -rf ${cfg.dataDir}/keys/* >&2") + with subtest("check manual configuration"): + # Remove the keys from automatic CA creation, to make sure the new + # generation doesn't use keys from before. + server.succeed("rm -rf ${cfg.dataDir}/keys/* >&2") - server.succeed( - "${switchToNewServer} >&2" - ) - server.wait_for_unit("taskserver.service") - server.wait_for_open_port(${portStr}) + server.succeed( + "${switchToNewServer} >&2" + ) + server.wait_for_unit("taskserver.service") + server.wait_for_open_port(${portStr}) - server.succeed( - "nixos-taskserver org add manualOrg", - "nixos-taskserver user add manualOrg alice", - ) + server.succeed( + "nixos-taskserver org add manualOrg", + "nixos-taskserver user add manualOrg alice", + ) - setup_clients_for("manualOrg", "alice", init_manual_config) + setup_clients_for("manualOrg", "alice", init_manual_config) - test_sync("alice") - ''; -}) + test_sync("alice") + ''; + } +) diff --git a/nixos/tests/tayga.nix b/nixos/tests/tayga.nix index e3c57b7d58feb5..bd60b51449b8e1 100644 --- a/nixos/tests/tayga.nix +++ b/nixos/tests/tayga.nix @@ -22,229 +22,257 @@ # | Route: 192.0.2.0/24 via 100.64.0.1 # +------ -import ./make-test-python.nix ({ pkgs, lib, ... }: - -{ - name = "tayga"; - meta = with pkgs.lib.maintainers; { - maintainers = [ hax404 ]; - }; - - nodes = { - # The server is configured with static IPv4 addresses. RFC 6052 Section 3.1 - # disallows the mapping of non-global IPv4 addresses like RFC 1918 into the - # Well-Known Prefix 64:ff9b::/96. TAYGA also does not allow the mapping of - # documentation space (RFC 5737). To circumvent this, 100.64.0.2/24 from - # RFC 6589 (Carrier Grade NAT) is used here. - # To reach the IPv4 address pool of the NAT64 gateway, there is a static - # route configured. In normal cases, where the router would also source NAT - # the pool addresses to one IPv4 addresses, this would not be needed. - server = { - virtualisation.vlans = [ - 2 # towards router - ]; - networking = { - useDHCP = false; - interfaces.eth1 = lib.mkForce {}; - }; - systemd.network = { - enable = true; - networks."vlan1" = { - matchConfig.Name = "eth1"; - address = [ - "100.64.0.2/24" - ]; - routes = [ - { Destination = "192.0.2.0/24"; Gateway = "100.64.0.1"; } - ]; - }; - }; - programs.mtr.enable = true; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + + { + name = "tayga"; + meta = with pkgs.lib.maintainers; { + maintainers = [ hax404 ]; }; - # The router is configured with static IPv4 addresses towards the server - # and IPv6 addresses towards the client. For NAT64, the Well-Known prefix - # 64:ff9b::/96 is used. NAT64 is done with TAYGA which provides the - # tun-interface nat64 and does the translation over it. The IPv6 packets - # are sent to this interfaces and received as IPv4 packets and vice versa. - # As TAYGA only translates IPv6 addresses to dedicated IPv4 addresses, it - # needs a pool of IPv4 addresses which must be at least as big as the - # expected amount of clients. In this test, the packets from the pool are - # directly routed towards the client. In normal cases, there would be a - # second source NAT44 to map all clients behind one IPv4 address. - router_systemd = { - boot.kernel.sysctl = { - "net.ipv4.ip_forward" = 1; - "net.ipv6.conf.all.forwarding" = 1; + nodes = { + # The server is configured with static IPv4 addresses. RFC 6052 Section 3.1 + # disallows the mapping of non-global IPv4 addresses like RFC 1918 into the + # Well-Known Prefix 64:ff9b::/96. TAYGA also does not allow the mapping of + # documentation space (RFC 5737). To circumvent this, 100.64.0.2/24 from + # RFC 6589 (Carrier Grade NAT) is used here. + # To reach the IPv4 address pool of the NAT64 gateway, there is a static + # route configured. In normal cases, where the router would also source NAT + # the pool addresses to one IPv4 addresses, this would not be needed. + server = { + virtualisation.vlans = [ + 2 # towards router + ]; + networking = { + useDHCP = false; + interfaces.eth1 = lib.mkForce { }; + }; + systemd.network = { + enable = true; + networks."vlan1" = { + matchConfig.Name = "eth1"; + address = [ + "100.64.0.2/24" + ]; + routes = [ + { + Destination = "192.0.2.0/24"; + Gateway = "100.64.0.1"; + } + ]; + }; + }; + programs.mtr.enable = true; }; - virtualisation.vlans = [ - 2 # towards server - 3 # towards client - ]; + # The router is configured with static IPv4 addresses towards the server + # and IPv6 addresses towards the client. For NAT64, the Well-Known prefix + # 64:ff9b::/96 is used. NAT64 is done with TAYGA which provides the + # tun-interface nat64 and does the translation over it. The IPv6 packets + # are sent to this interfaces and received as IPv4 packets and vice versa. + # As TAYGA only translates IPv6 addresses to dedicated IPv4 addresses, it + # needs a pool of IPv4 addresses which must be at least as big as the + # expected amount of clients. In this test, the packets from the pool are + # directly routed towards the client. In normal cases, there would be a + # second source NAT44 to map all clients behind one IPv4 address. + router_systemd = { + boot.kernel.sysctl = { + "net.ipv4.ip_forward" = 1; + "net.ipv6.conf.all.forwarding" = 1; + }; - networking = { - useDHCP = false; - useNetworkd = true; - firewall.enable = false; - interfaces.eth1 = lib.mkForce { - ipv4 = { - addresses = [ { address = "100.64.0.1"; prefixLength = 24; } ]; + virtualisation.vlans = [ + 2 # towards server + 3 # towards client + ]; + + networking = { + useDHCP = false; + useNetworkd = true; + firewall.enable = false; + interfaces.eth1 = lib.mkForce { + ipv4 = { + addresses = [ + { + address = "100.64.0.1"; + prefixLength = 24; + } + ]; + }; }; - }; - interfaces.eth2 = lib.mkForce { - ipv6 = { - addresses = [ { address = "2001:db8::1"; prefixLength = 64; } ]; + interfaces.eth2 = lib.mkForce { + ipv6 = { + addresses = [ + { + address = "2001:db8::1"; + prefixLength = 64; + } + ]; + }; }; }; - }; - services.tayga = { - enable = true; - ipv4 = { - address = "192.0.2.0"; - router = { - address = "192.0.2.1"; - }; - pool = { + services.tayga = { + enable = true; + ipv4 = { address = "192.0.2.0"; - prefixLength = 24; + router = { + address = "192.0.2.1"; + }; + pool = { + address = "192.0.2.0"; + prefixLength = 24; + }; }; - }; - ipv6 = { - address = "2001:db8::1"; - router = { - address = "64:ff9b::1"; + ipv6 = { + address = "2001:db8::1"; + router = { + address = "64:ff9b::1"; + }; + pool = { + address = "64:ff9b::"; + prefixLength = 96; + }; }; - pool = { - address = "64:ff9b::"; - prefixLength = 96; + mappings = { + "192.0.2.42" = "2001:db8::2"; }; }; - mappings = { - "192.0.2.42" = "2001:db8::2"; - }; }; - }; - router_nixos = { - boot.kernel.sysctl = { - "net.ipv4.ip_forward" = 1; - "net.ipv6.conf.all.forwarding" = 1; - }; + router_nixos = { + boot.kernel.sysctl = { + "net.ipv4.ip_forward" = 1; + "net.ipv6.conf.all.forwarding" = 1; + }; - virtualisation.vlans = [ - 2 # towards server - 3 # towards client - ]; + virtualisation.vlans = [ + 2 # towards server + 3 # towards client + ]; - networking = { - useDHCP = false; - firewall.enable = false; - interfaces.eth1 = lib.mkForce { - ipv4 = { - addresses = [ { address = "100.64.0.1"; prefixLength = 24; } ]; + networking = { + useDHCP = false; + firewall.enable = false; + interfaces.eth1 = lib.mkForce { + ipv4 = { + addresses = [ + { + address = "100.64.0.1"; + prefixLength = 24; + } + ]; + }; }; - }; - interfaces.eth2 = lib.mkForce { - ipv6 = { - addresses = [ { address = "2001:db8::1"; prefixLength = 64; } ]; + interfaces.eth2 = lib.mkForce { + ipv6 = { + addresses = [ + { + address = "2001:db8::1"; + prefixLength = 64; + } + ]; + }; }; }; - }; - services.tayga = { - enable = true; - ipv4 = { - address = "192.0.2.0"; - router = { - address = "192.0.2.1"; - }; - pool = { + services.tayga = { + enable = true; + ipv4 = { address = "192.0.2.0"; - prefixLength = 24; + router = { + address = "192.0.2.1"; + }; + pool = { + address = "192.0.2.0"; + prefixLength = 24; + }; }; - }; - ipv6 = { - address = "2001:db8::1"; - router = { - address = "64:ff9b::1"; + ipv6 = { + address = "2001:db8::1"; + router = { + address = "64:ff9b::1"; + }; + pool = { + address = "64:ff9b::"; + prefixLength = 96; + }; }; - pool = { - address = "64:ff9b::"; - prefixLength = 96; + mappings = { + "192.0.2.42" = "2001:db8::2"; }; }; - mappings = { - "192.0.2.42" = "2001:db8::2"; - }; }; - }; - # The client is configured with static IPv6 addresses. It has also a static - # route for the NAT64 IP space where the IPv4 addresses are mapped in. In - # normal cases, there would be only a default route. - client = { - virtualisation.vlans = [ - 3 # towards router - ]; - - networking = { - useDHCP = false; - interfaces.eth1 = lib.mkForce {}; - }; + # The client is configured with static IPv6 addresses. It has also a static + # route for the NAT64 IP space where the IPv4 addresses are mapped in. In + # normal cases, there would be only a default route. + client = { + virtualisation.vlans = [ + 3 # towards router + ]; - systemd.network = { - enable = true; - networks."vlan1" = { - matchConfig.Name = "eth1"; - address = [ - "2001:db8::2/64" - ]; - routes = [ - { Destination = "64:ff9b::/96"; Gateway = "2001:db8::1"; } - ]; + networking = { + useDHCP = false; + interfaces.eth1 = lib.mkForce { }; }; + + systemd.network = { + enable = true; + networks."vlan1" = { + matchConfig.Name = "eth1"; + address = [ + "2001:db8::2/64" + ]; + routes = [ + { + Destination = "64:ff9b::/96"; + Gateway = "2001:db8::1"; + } + ]; + }; + }; + programs.mtr.enable = true; }; - programs.mtr.enable = true; }; - }; - - testScript = '' - # start client and server - for machine in client, server: - machine.systemctl("start network-online.target") - machine.wait_for_unit("network-online.target") - machine.log(machine.execute("ip addr")[1]) - machine.log(machine.execute("ip route")[1]) - machine.log(machine.execute("ip -6 route")[1]) - - # test systemd-networkd and nixos-scripts based router - for router in router_systemd, router_nixos: - router.start() - router.systemctl("start network-online.target") - router.wait_for_unit("network-online.target") - router.wait_for_unit("tayga.service") - router.log(machine.execute("ip addr")[1]) - router.log(machine.execute("ip route")[1]) - router.log(machine.execute("ip -6 route")[1]) - - with subtest("Wait for tayga"): + + testScript = '' + # start client and server + for machine in client, server: + machine.systemctl("start network-online.target") + machine.wait_for_unit("network-online.target") + machine.log(machine.execute("ip addr")[1]) + machine.log(machine.execute("ip route")[1]) + machine.log(machine.execute("ip -6 route")[1]) + + # test systemd-networkd and nixos-scripts based router + for router in router_systemd, router_nixos: + router.start() + router.systemctl("start network-online.target") + router.wait_for_unit("network-online.target") router.wait_for_unit("tayga.service") + router.log(machine.execute("ip addr")[1]) + router.log(machine.execute("ip route")[1]) + router.log(machine.execute("ip -6 route")[1]) + + with subtest("Wait for tayga"): + router.wait_for_unit("tayga.service") - with subtest("Test ICMP server -> client"): - server.wait_until_succeeds("ping -c 3 192.0.2.42 >&2") + with subtest("Test ICMP server -> client"): + server.wait_until_succeeds("ping -c 3 192.0.2.42 >&2") - with subtest("Test ICMP and show a traceroute server -> client"): - server.wait_until_succeeds("mtr --show-ips --report-wide 192.0.2.42 >&2") + with subtest("Test ICMP and show a traceroute server -> client"): + server.wait_until_succeeds("mtr --show-ips --report-wide 192.0.2.42 >&2") - with subtest("Test ICMP client -> server"): - client.wait_until_succeeds("ping -c 3 64:ff9b::100.64.0.2 >&2") + with subtest("Test ICMP client -> server"): + client.wait_until_succeeds("ping -c 3 64:ff9b::100.64.0.2 >&2") - with subtest("Test ICMP and show a traceroute client -> server"): - client.wait_until_succeeds("mtr --show-ips --report-wide 64:ff9b::100.64.0.2 >&2") + with subtest("Test ICMP and show a traceroute client -> server"): + client.wait_until_succeeds("mtr --show-ips --report-wide 64:ff9b::100.64.0.2 >&2") - router.log(router.execute("systemd-analyze security tayga.service")[1]) - router.shutdown() - ''; -}) + router.log(router.execute("systemd-analyze security tayga.service")[1]) + router.shutdown() + ''; + } +) diff --git a/nixos/tests/technitium-dns-server.nix b/nixos/tests/technitium-dns-server.nix index 12ee57ed52d215..dbe8fac5d35421 100644 --- a/nixos/tests/technitium-dns-server.nix +++ b/nixos/tests/technitium-dns-server.nix @@ -1,27 +1,31 @@ -import ./make-test-python.nix ({pkgs, lib, ...}: -{ - name = "technitium-dns-server"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "technitium-dns-server"; - nodes = { - machine = {pkgs, ...}: { - services.technitium-dns-server = { - enable = true; - openFirewall = true; - }; + nodes = { + machine = + { pkgs, ... }: + { + services.technitium-dns-server = { + enable = true; + openFirewall = true; + }; + }; }; - }; - testScript = '' - import json + testScript = '' + import json - start_all() - machine.wait_for_unit("technitium-dns-server.service") - machine.wait_for_open_port(53) - curl_cmd = 'curl --fail-with-body -X GET "http://localhost:5380/api/user/login?user=admin&pass=admin"' - output = json.loads(machine.wait_until_succeeds(curl_cmd, timeout=10)) - print(output) - assert "ok" == output['status'], "status not ok" - ''; + start_all() + machine.wait_for_unit("technitium-dns-server.service") + machine.wait_for_open_port(53) + curl_cmd = 'curl --fail-with-body -X GET "http://localhost:5380/api/user/login?user=admin&pass=admin"' + output = json.loads(machine.wait_until_succeeds(curl_cmd, timeout=10)) + print(output) + assert "ok" == output['status'], "status not ok" + ''; - meta.maintainers = with lib.maintainers; [ fabianrig ]; -}) + meta.maintainers = with lib.maintainers; [ fabianrig ]; + } +) diff --git a/nixos/tests/teeworlds.nix b/nixos/tests/teeworlds.nix index ac2c996955c800..7c94f66a2b204f 100644 --- a/nixos/tests/teeworlds.nix +++ b/nixos/tests/teeworlds.nix @@ -1,22 +1,25 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -let - client = - { pkgs, ... }: + let + client = + { pkgs, ... }: - { imports = [ ./common/x11.nix ]; - environment.systemPackages = [ pkgs.teeworlds ]; - }; + { + imports = [ ./common/x11.nix ]; + environment.systemPackages = [ pkgs.teeworlds ]; + }; -in { - name = "teeworlds"; - meta = with pkgs.lib.maintainers; { - maintainers = [ hax404 ]; - }; + in + { + name = "teeworlds"; + meta = with pkgs.lib.maintainers; { + maintainers = [ hax404 ]; + }; - nodes = - { server = - { services.teeworlds = { + nodes = { + server = { + services.teeworlds = { enable = true; openPorts = true; }; @@ -26,8 +29,7 @@ in { client2 = client; }; - testScript = - '' + testScript = '' start_all() server.wait_for_unit("teeworlds.service") @@ -52,4 +54,5 @@ in { client2.screenshot("screen_client2") ''; -}) + } +) diff --git a/nixos/tests/telegraf.nix b/nixos/tests/telegraf.nix index 2ccad7af3f555b..93d4c85b3e8db0 100644 --- a/nixos/tests/telegraf.nix +++ b/nixos/tests/telegraf.nix @@ -1,40 +1,47 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "telegraf"; - meta = with pkgs.lib.maintainers; { - maintainers = [ mic92 ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "telegraf"; + meta = with pkgs.lib.maintainers; { + maintainers = [ mic92 ]; + }; - nodes.machine = { ... }: { - services.telegraf.enable = true; - services.telegraf.environmentFiles = [(pkgs.writeText "secrets" '' - SECRET=example - '')]; - services.telegraf.extraConfig = { - agent.interval = "1s"; - agent.flush_interval = "1s"; - inputs.exec = { - commands = [ - "${pkgs.runtimeShell} -c 'echo $SECRET,tag=a i=42i'" + nodes.machine = + { ... }: + { + services.telegraf.enable = true; + services.telegraf.environmentFiles = [ + (pkgs.writeText "secrets" '' + SECRET=example + '') ]; - timeout = "5s"; - data_format = "influx"; - }; - inputs.ping = { - urls = ["127.0.0.1"]; - count = 4; - interval = "10s"; - timeout = 1.0; + services.telegraf.extraConfig = { + agent.interval = "1s"; + agent.flush_interval = "1s"; + inputs.exec = { + commands = [ + "${pkgs.runtimeShell} -c 'echo $SECRET,tag=a i=42i'" + ]; + timeout = "5s"; + data_format = "influx"; + }; + inputs.ping = { + urls = [ "127.0.0.1" ]; + count = 4; + interval = "10s"; + timeout = 1.0; + }; + outputs.file.files = [ "/tmp/metrics.out" ]; + outputs.file.data_format = "influx"; + }; }; - outputs.file.files = ["/tmp/metrics.out"]; - outputs.file.data_format = "influx"; - }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("telegraf.service") - machine.wait_until_succeeds("grep -q example /tmp/metrics.out") - machine.wait_until_succeeds("grep -q ping /tmp/metrics.out") - ''; -}) + machine.wait_for_unit("telegraf.service") + machine.wait_until_succeeds("grep -q example /tmp/metrics.out") + machine.wait_until_succeeds("grep -q ping /tmp/metrics.out") + ''; + } +) diff --git a/nixos/tests/teleport.nix b/nixos/tests/teleport.nix index b04b45f52132ae..2fb372f6f41922 100644 --- a/nixos/tests/teleport.nix +++ b/nixos/tests/teleport.nix @@ -1,7 +1,8 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../.. { inherit system config; } -, lib ? pkgs.lib +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, + lib ? pkgs.lib, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -41,10 +42,12 @@ let auth_service.enabled = false; }; }; - networking.interfaces.eth1.ipv4.addresses = [{ - address = "192.168.1.20"; - prefixLength = 24; - }]; + networking.interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.1.20"; + prefixLength = 24; + } + ]; }; server = package: { @@ -68,48 +71,48 @@ let }; networking = { firewall.allowedTCPPorts = [ 3025 ]; - interfaces.eth1.ipv4.addresses = [{ - address = "192.168.1.10"; - prefixLength = 24; - }]; + interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.1.10"; + prefixLength = 24; + } + ]; }; }; in -lib.concatMapAttrs - (name: package: { - "minimal_${name}" = makeTest { - # minimal setup should always work - name = "teleport-minimal-setup"; - meta.maintainers = with pkgs.lib.maintainers; [ justinas ]; - nodes.minimal = minimal package; +lib.concatMapAttrs (name: package: { + "minimal_${name}" = makeTest { + # minimal setup should always work + name = "teleport-minimal-setup"; + meta.maintainers = with pkgs.lib.maintainers; [ justinas ]; + nodes.minimal = minimal package; - testScript = '' - minimal.wait_for_open_port(3025) - minimal.wait_for_open_port(3080) - minimal.wait_for_open_port(3022) - ''; - }; + testScript = '' + minimal.wait_for_open_port(3025) + minimal.wait_for_open_port(3080) + minimal.wait_for_open_port(3022) + ''; + }; - "basic_${name}" = makeTest { - # basic server and client test - name = "teleport-server-client"; - meta.maintainers = with pkgs.lib.maintainers; [ justinas ]; - nodes = { - server = server package; - client = client package; - }; + "basic_${name}" = makeTest { + # basic server and client test + name = "teleport-server-client"; + meta.maintainers = with pkgs.lib.maintainers; [ justinas ]; + nodes = { + server = server package; + client = client package; + }; - testScript = '' - with subtest("teleport ready"): - server.wait_for_open_port(3025) - client.wait_for_open_port(3022) + testScript = '' + with subtest("teleport ready"): + server.wait_for_open_port(3025) + client.wait_for_open_port(3022) - with subtest("check applied configuration"): - server.wait_until_succeeds("tctl get nodes --format=json | ${pkgs.jq}/bin/jq -e '.[] | select(.spec.hostname==\"client\") | .metadata.labels.role==\"client\"'") - server.wait_for_open_port(3000) - client.succeed("journalctl -u teleport.service --grep='DEBU'") - server.succeed("journalctl -u teleport.service --grep='Starting teleport in insecure mode.'") - ''; - }; - }) - packages + with subtest("check applied configuration"): + server.wait_until_succeeds("tctl get nodes --format=json | ${pkgs.jq}/bin/jq -e '.[] | select(.spec.hostname==\"client\") | .metadata.labels.role==\"client\"'") + server.wait_for_open_port(3000) + client.succeed("journalctl -u teleport.service --grep='DEBU'") + server.succeed("journalctl -u teleport.service --grep='Starting teleport in insecure mode.'") + ''; + }; +}) packages diff --git a/nixos/tests/terminal-emulators.nix b/nixos/tests/terminal-emulators.nix index 9195f619c8d212..1affcbf3c8f79d 100644 --- a/nixos/tests/terminal-emulators.nix +++ b/nixos/tests/terminal-emulators.nix @@ -12,211 +12,234 @@ # - Wayland support (both for testing the existing terminals, and for testing wayland-only terminals like foot and havoc) # - Test keyboard input? (skipped for now, to eliminate the possibility of race conditions and focus issues) -{ system ? builtins.currentSystem, - config ? {}, - pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; with pkgs.lib; -let tests = { - alacritty.pkg = p: p.alacritty; +let + tests = { + alacritty.pkg = p: p.alacritty; - contour.pkg = p: p.contour; - contour.cmd = "contour early-exit-threshold 0 execute $command"; + contour.pkg = p: p.contour; + contour.cmd = "contour early-exit-threshold 0 execute $command"; - cool-retro-term.pkg = p: p.cool-retro-term; - cool-retro-term.colourTest = false; # broken by gloss effect + cool-retro-term.pkg = p: p.cool-retro-term; + cool-retro-term.colourTest = false; # broken by gloss effect - ctx.pkg = p: p.ctx; - ctx.pinkValue = "#FE0065"; + ctx.pkg = p: p.ctx; + ctx.pinkValue = "#FE0065"; - darktile.pkg = p: p.darktile; + darktile.pkg = p: p.darktile; - deepin-terminal.pkg = p: p.deepin.deepin-terminal; + deepin-terminal.pkg = p: p.deepin.deepin-terminal; - eterm.pkg = p: p.eterm; - eterm.executable = "Eterm"; - eterm.pinkValue = "#D40055"; + eterm.pkg = p: p.eterm; + eterm.executable = "Eterm"; + eterm.pinkValue = "#D40055"; - germinal.pkg = p: p.germinal; + germinal.pkg = p: p.germinal; - gnome-terminal.pkg = p: p.gnome-terminal; + gnome-terminal.pkg = p: p.gnome-terminal; - guake.pkg = p: p.guake; - guake.cmd = "SHELL=$command guake --show"; - guake.kill = true; + guake.pkg = p: p.guake; + guake.cmd = "SHELL=$command guake --show"; + guake.kill = true; - hyper.pkg = p: p.hyper; + hyper.pkg = p: p.hyper; - kermit.pkg = p: p.kermit-terminal; + kermit.pkg = p: p.kermit-terminal; - kgx.pkg = p: p.kgx; - kgx.cmd = "kgx -e $command"; - kgx.kill = true; + kgx.pkg = p: p.kgx; + kgx.cmd = "kgx -e $command"; + kgx.kill = true; - kitty.pkg = p: p.kitty; - kitty.cmd = "kitty $command"; + kitty.pkg = p: p.kitty; + kitty.cmd = "kitty $command"; - konsole.pkg = p: p.plasma5Packages.konsole; + konsole.pkg = p: p.plasma5Packages.konsole; - lomiri-terminal-app.pkg = p: p.lomiri.lomiri-terminal-app; - # after recent Mesa change, borked software rendering config under x86_64 icewm? - # BGR colour display on x86_64, RGB on aarch64 - lomiri-terminal-app.colourTest = false; + lomiri-terminal-app.pkg = p: p.lomiri.lomiri-terminal-app; + # after recent Mesa change, borked software rendering config under x86_64 icewm? + # BGR colour display on x86_64, RGB on aarch64 + lomiri-terminal-app.colourTest = false; - lxterminal.pkg = p: p.lxterminal; + lxterminal.pkg = p: p.lxterminal; - mate-terminal.pkg = p: p.mate.mate-terminal; - mate-terminal.cmd = "SHELL=$command mate-terminal --disable-factory"; # factory mode uses dbus, and we don't have a proper dbus session set up + mate-terminal.pkg = p: p.mate.mate-terminal; + mate-terminal.cmd = "SHELL=$command mate-terminal --disable-factory"; # factory mode uses dbus, and we don't have a proper dbus session set up - mlterm.pkg = p: p.mlterm; + mlterm.pkg = p: p.mlterm; - mrxvt.pkg = p: p.mrxvt; + mrxvt.pkg = p: p.mrxvt; - qterminal.pkg = p: p.lxqt.qterminal; - qterminal.kill = true; + qterminal.pkg = p: p.lxqt.qterminal; + qterminal.kill = true; - rio.pkg = p: p.rio; - rio.cmd = "rio -e $command"; - rio.colourTest = false; # the rendering is changing too much so colors change every release. + rio.pkg = p: p.rio; + rio.cmd = "rio -e $command"; + rio.colourTest = false; # the rendering is changing too much so colors change every release. - roxterm.pkg = p: p.roxterm; - roxterm.cmd = "roxterm -e $command"; + roxterm.pkg = p: p.roxterm; + roxterm.cmd = "roxterm -e $command"; - sakura.pkg = p: p.sakura; + sakura.pkg = p: p.sakura; - st.pkg = p: p.st; - st.kill = true; + st.pkg = p: p.st; + st.kill = true; - stupidterm.pkg = p: p.stupidterm; - stupidterm.cmd = "stupidterm -- $command"; + stupidterm.pkg = p: p.stupidterm; + stupidterm.cmd = "stupidterm -- $command"; - terminator.pkg = p: p.terminator; - terminator.cmd = "terminator -e $command"; + terminator.pkg = p: p.terminator; + terminator.cmd = "terminator -e $command"; - terminology.pkg = p: p.enlightenment.terminology; - terminology.cmd = "SHELL=$command terminology --no-wizard=true"; - terminology.colourTest = false; # broken by gloss effect + terminology.pkg = p: p.enlightenment.terminology; + terminology.cmd = "SHELL=$command terminology --no-wizard=true"; + terminology.colourTest = false; # broken by gloss effect - termite.pkg = p: p.termite; + termite.pkg = p: p.termite; - termonad.pkg = p: p.termonad; + termonad.pkg = p: p.termonad; - tilda.pkg = p: p.tilda; + tilda.pkg = p: p.tilda; - tilix.pkg = p: p.tilix; - tilix.cmd = "tilix -e $command"; + tilix.pkg = p: p.tilix; + tilix.cmd = "tilix -e $command"; - urxvt.pkg = p: p.rxvt-unicode; + urxvt.pkg = p: p.rxvt-unicode; - wayst.pkg = p: p.wayst; - wayst.pinkValue = "#FF0066"; + wayst.pkg = p: p.wayst; + wayst.pinkValue = "#FF0066"; - # times out after spending many hours - #wezterm.pkg = p: p.wezterm; + # times out after spending many hours + #wezterm.pkg = p: p.wezterm; - xfce4-terminal.pkg = p: p.xfce.xfce4-terminal; + xfce4-terminal.pkg = p: p.xfce.xfce4-terminal; - xterm.pkg = p: p.xterm; + xterm.pkg = p: p.xterm; - zutty.pkg = p: p.zutty; - }; -in mapAttrs (name: { pkg, executable ? name, cmd ? "SHELL=$command ${executable}", colourTest ? true, pinkValue ? "#FF0087", kill ? false }: makeTest -{ - name = "terminal-emulator-${name}"; - meta = with pkgs.lib.maintainers; { - maintainers = [ jjjollyjim ]; + zutty.pkg = p: p.zutty; }; - - nodes.machine = { pkgsInner, ... }: - +in +mapAttrs ( + name: { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - - # Hyper (and any other electron-based terminals) won't run as root - test-support.displayManager.auto.user = "alice"; - - environment.systemPackages = [ - (pkg pkgs) - (pkgs.writeShellScriptBin "report-success" '' - echo 1 > /tmp/term-ran-successfully - ${optionalString kill "pkill ${executable}"} - '') - (pkgs.writeShellScriptBin "display-colour" '' - # A 256-colour background colour code for pink, then spaces. - # - # Background is used rather than foreground to minimize the effect of anti-aliasing. - # - # Keep adding more in case the window is partially offscreen to the left or requires - # a change to correctly redraw after initialising the window (as with ctx). - - while : - do - echo -ne "\e[48;5;198m " - sleep 0.5 - done - sleep infinity - '') - (pkgs.writeShellScriptBin "run-in-this-term" "sudo -u alice run-in-this-term-wrapped $1") - - (pkgs.writeShellScriptBin "run-in-this-term-wrapped" "command=\"$(which \"$1\")\"; ${cmd}") - ]; - - # Helpful reminder to add this test to passthru.tests - warnings = if !((pkg pkgs) ? "passthru" && (pkg pkgs).passthru ? "tests") then [ "The package for ${name} doesn't have a passthru.tests" ] else [ ]; - }; - - # We need imagemagick, though not tesseract - enableOCR = true; - - testScript = { nodes, ... }: let - in '' - with subtest("wait for x"): - start_all() - machine.wait_for_x() - - with subtest("have the terminal run a command"): - # We run this command synchronously, so we can be certain the exit codes are happy - machine.${if kill then "execute" else "succeed"}("run-in-this-term report-success") - machine.wait_for_file("/tmp/term-ran-successfully") - ${optionalString colourTest '' - - import tempfile - import subprocess - - - def check_for_pink(final=False) -> bool: - with tempfile.NamedTemporaryFile() as tmpin: - machine.send_monitor_command("screendump {}".format(tmpin.name)) - - cmd = 'convert {} -define histogram:unique-colors=true -format "%c" histogram:info:'.format( - tmpin.name - ) - ret = subprocess.run(cmd, shell=True, capture_output=True) - if ret.returncode != 0: - raise Exception( - "image analysis failed with exit code {}".format(ret.returncode) - ) - - text = ret.stdout.decode("utf-8") - return "${pinkValue}" in text - - - with subtest("ensuring no pink is present without the terminal"): - assert ( - check_for_pink() == False - ), "Pink was present on the screen before we even launched a terminal!" - - with subtest("have the terminal display a colour"): - # We run this command in the background - assert machine.shell is not None - machine.shell.send(b"(run-in-this-term display-colour |& systemd-cat -t terminal) &\n") - - with machine.nested("Waiting for the screen to have pink on it:"): - retry(check_for_pink) - ''}''; -} + pkg, + executable ? name, + cmd ? "SHELL=$command ${executable}", + colourTest ? true, + pinkValue ? "#FF0087", + kill ? false, + }: + makeTest { + name = "terminal-emulator-${name}"; + meta = with pkgs.lib.maintainers; { + maintainers = [ jjjollyjim ]; + }; - ) tests + nodes.machine = + { pkgsInner, ... }: + + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + + # Hyper (and any other electron-based terminals) won't run as root + test-support.displayManager.auto.user = "alice"; + + environment.systemPackages = [ + (pkg pkgs) + (pkgs.writeShellScriptBin "report-success" '' + echo 1 > /tmp/term-ran-successfully + ${optionalString kill "pkill ${executable}"} + '') + (pkgs.writeShellScriptBin "display-colour" '' + # A 256-colour background colour code for pink, then spaces. + # + # Background is used rather than foreground to minimize the effect of anti-aliasing. + # + # Keep adding more in case the window is partially offscreen to the left or requires + # a change to correctly redraw after initialising the window (as with ctx). + + while : + do + echo -ne "\e[48;5;198m " + sleep 0.5 + done + sleep infinity + '') + (pkgs.writeShellScriptBin "run-in-this-term" "sudo -u alice run-in-this-term-wrapped $1") + + (pkgs.writeShellScriptBin "run-in-this-term-wrapped" "command=\"$(which \"$1\")\"; ${cmd}") + ]; + + # Helpful reminder to add this test to passthru.tests + warnings = + if !((pkg pkgs) ? "passthru" && (pkg pkgs).passthru ? "tests") then + [ "The package for ${name} doesn't have a passthru.tests" ] + else + [ ]; + }; + + # We need imagemagick, though not tesseract + enableOCR = true; + + testScript = + { nodes, ... }: + let + in + '' + with subtest("wait for x"): + start_all() + machine.wait_for_x() + + with subtest("have the terminal run a command"): + # We run this command synchronously, so we can be certain the exit codes are happy + machine.${if kill then "execute" else "succeed"}("run-in-this-term report-success") + machine.wait_for_file("/tmp/term-ran-successfully") + ${optionalString colourTest '' + + import tempfile + import subprocess + + + def check_for_pink(final=False) -> bool: + with tempfile.NamedTemporaryFile() as tmpin: + machine.send_monitor_command("screendump {}".format(tmpin.name)) + + cmd = 'convert {} -define histogram:unique-colors=true -format "%c" histogram:info:'.format( + tmpin.name + ) + ret = subprocess.run(cmd, shell=True, capture_output=True) + if ret.returncode != 0: + raise Exception( + "image analysis failed with exit code {}".format(ret.returncode) + ) + + text = ret.stdout.decode("utf-8") + return "${pinkValue}" in text + + + with subtest("ensuring no pink is present without the terminal"): + assert ( + check_for_pink() == False + ), "Pink was present on the screen before we even launched a terminal!" + + with subtest("have the terminal display a colour"): + # We run this command in the background + assert machine.shell is not None + machine.shell.send(b"(run-in-this-term display-colour |& systemd-cat -t terminal) &\n") + + with machine.nested("Waiting for the screen to have pink on it:"): + retry(check_for_pink) + ''}''; + } + +) tests diff --git a/nixos/tests/thanos.nix b/nixos/tests/thanos.nix index 5bdfab7b3573fe..bfdee16a6f9bc6 100644 --- a/nixos/tests/thanos.nix +++ b/nixos/tests/thanos.nix @@ -1,9 +1,9 @@ let - grpcPort = 19090; - queryPort = 9090; - minioPort = 9000; - pushgwPort = 9091; - frontPort = 9092; + grpcPort = 19090; + queryPort = 9090; + minioPort = 9000; + pushgwPort = 9091; + frontPort = 9092; s3 = { accessKey = "BKIKJAA5BMMU2RHO6IBB"; @@ -15,12 +15,12 @@ let config = { bucket = "thanos-bucket"; endpoint = "s3:${toString minioPort}"; - region = "us-east-1"; + region = "us-east-1"; access_key = s3.accessKey; secret_key = s3.secretKey; insecure = true; signature_version2 = false; - put_user_metadata = {}; + put_user_metadata = { }; http_config = { idle_conn_timeout = "0s"; insecure_skip_verify = false; @@ -31,261 +31,277 @@ let }; }; -in import ./make-test-python.nix { +in +import ./make-test-python.nix { name = "prometheus"; nodes = { - prometheus = { pkgs, ... }: { - virtualisation.diskSize = 2 * 1024; - virtualisation.memorySize = 2048; - environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ grpcPort ]; - services.prometheus = { - enable = true; - enableReload = true; - scrapeConfigs = [ - { - job_name = "prometheus"; - static_configs = [ - { - targets = [ "127.0.0.1:${toString queryPort}" ]; - labels = { instance = "localhost"; }; - } - ]; - } - { - job_name = "pushgateway"; - scrape_interval = "1s"; - static_configs = [ - { - targets = [ "127.0.0.1:${toString pushgwPort}" ]; - } - ]; - } - ]; - rules = [ - '' - groups: - - name: test - rules: - - record: testrule - expr: count(up{job="prometheus"}) - '' - ]; - globalConfig = { - external_labels = { - some_label = "required by thanos"; + prometheus = + { pkgs, ... }: + { + virtualisation.diskSize = 2 * 1024; + virtualisation.memorySize = 2048; + environment.systemPackages = [ pkgs.jq ]; + networking.firewall.allowedTCPPorts = [ grpcPort ]; + services.prometheus = { + enable = true; + enableReload = true; + scrapeConfigs = [ + { + job_name = "prometheus"; + static_configs = [ + { + targets = [ "127.0.0.1:${toString queryPort}" ]; + labels = { + instance = "localhost"; + }; + } + ]; + } + { + job_name = "pushgateway"; + scrape_interval = "1s"; + static_configs = [ + { + targets = [ "127.0.0.1:${toString pushgwPort}" ]; + } + ]; + } + ]; + rules = [ + '' + groups: + - name: test + rules: + - record: testrule + expr: count(up{job="prometheus"}) + '' + ]; + globalConfig = { + external_labels = { + some_label = "required by thanos"; + }; }; + extraFlags = [ + # Required by thanos + "--storage.tsdb.min-block-duration=5s" + "--storage.tsdb.max-block-duration=5s" + ]; }; - extraFlags = [ - # Required by thanos - "--storage.tsdb.min-block-duration=5s" - "--storage.tsdb.max-block-duration=5s" - ]; - }; - services.prometheus.pushgateway = { - enable = true; - web.listen-address = ":${toString pushgwPort}"; - persistMetrics = true; - persistence.interval = "1s"; - stateDir = "prometheus-pushgateway"; - }; - services.thanos = { - sidecar = { + services.prometheus.pushgateway = { enable = true; - grpc-address = "0.0.0.0:${toString grpcPort}"; - inherit objstore; + web.listen-address = ":${toString pushgwPort}"; + persistMetrics = true; + persistence.interval = "1s"; + stateDir = "prometheus-pushgateway"; }; + services.thanos = { + sidecar = { + enable = true; + grpc-address = "0.0.0.0:${toString grpcPort}"; + inherit objstore; + }; - # TODO: Add some tests for these services: - #rule = { - # enable = true; - # http-address = "0.0.0.0:19194"; - # grpc-address = "0.0.0.0:19193"; - # query.addresses = [ - # "localhost:19191" - # ]; - # labels = { - # just = "some"; - # nice = "labels"; - # }; - #}; - # - #receive = { - # http-address = "0.0.0.0:19195"; - # enable = true; - # labels = { - # just = "some"; - # nice = "labels"; - # }; - #}; - }; - # Adds a "specialisation" of the above config which allows us to - # "switch" to it and see if the services.prometheus.enableReload - # functionality actually reloads the prometheus service instead of - # restarting it. - specialisation = { - "prometheus-config-change" = { - configuration = { - environment.systemPackages = [ pkgs.yq ]; + # TODO: Add some tests for these services: + #rule = { + # enable = true; + # http-address = "0.0.0.0:19194"; + # grpc-address = "0.0.0.0:19193"; + # query.addresses = [ + # "localhost:19191" + # ]; + # labels = { + # just = "some"; + # nice = "labels"; + # }; + #}; + # + #receive = { + # http-address = "0.0.0.0:19195"; + # enable = true; + # labels = { + # just = "some"; + # nice = "labels"; + # }; + #}; + }; + # Adds a "specialisation" of the above config which allows us to + # "switch" to it and see if the services.prometheus.enableReload + # functionality actually reloads the prometheus service instead of + # restarting it. + specialisation = { + "prometheus-config-change" = { + configuration = { + environment.systemPackages = [ pkgs.yq ]; - # This configuration just adds a new prometheus job - # to scrape the node_exporter metrics of the s3 machine. - services.prometheus = { - scrapeConfigs = [ - { - job_name = "s3-node_exporter"; - static_configs = [ - { - targets = [ "s3:9100" ]; - } - ]; - } - ]; + # This configuration just adds a new prometheus job + # to scrape the node_exporter metrics of the s3 machine. + services.prometheus = { + scrapeConfigs = [ + { + job_name = "s3-node_exporter"; + static_configs = [ + { + targets = [ "s3:9100" ]; + } + ]; + } + ]; + }; }; }; }; }; - }; - query = { pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; - services.thanos.query = { - enable = true; - http-address = "0.0.0.0:${toString queryPort}"; - endpoints = [ - "prometheus:${toString grpcPort}" - ]; - }; - services.thanos.query-frontend = { - enable = true; - http-address = "0.0.0.0:${toString frontPort}"; - query-frontend.downstream-url = "http://127.0.0.1:${toString queryPort}"; + query = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; + services.thanos.query = { + enable = true; + http-address = "0.0.0.0:${toString queryPort}"; + endpoints = [ + "prometheus:${toString grpcPort}" + ]; + }; + services.thanos.query-frontend = { + enable = true; + http-address = "0.0.0.0:${toString frontPort}"; + query-frontend.downstream-url = "http://127.0.0.1:${toString queryPort}"; + }; }; - }; - store = { pkgs, ... }: { - virtualisation.diskSize = 2 * 1024; - virtualisation.memorySize = 2048; - environment.systemPackages = with pkgs; [ jq thanos ]; - services.thanos.store = { - enable = true; - http-address = "0.0.0.0:10902"; - grpc-address = "0.0.0.0:${toString grpcPort}"; - inherit objstore; - sync-block-duration = "1s"; - }; - services.thanos.compact = { - enable = true; - http-address = "0.0.0.0:10903"; - inherit objstore; - consistency-delay = "5s"; - }; - services.thanos.query = { - enable = true; - http-address = "0.0.0.0:${toString queryPort}"; - endpoints = [ - "localhost:${toString grpcPort}" + store = + { pkgs, ... }: + { + virtualisation.diskSize = 2 * 1024; + virtualisation.memorySize = 2048; + environment.systemPackages = with pkgs; [ + jq + thanos ]; + services.thanos.store = { + enable = true; + http-address = "0.0.0.0:10902"; + grpc-address = "0.0.0.0:${toString grpcPort}"; + inherit objstore; + sync-block-duration = "1s"; + }; + services.thanos.compact = { + enable = true; + http-address = "0.0.0.0:10903"; + inherit objstore; + consistency-delay = "5s"; + }; + services.thanos.query = { + enable = true; + http-address = "0.0.0.0:${toString queryPort}"; + endpoints = [ + "localhost:${toString grpcPort}" + ]; + }; }; - }; - s3 = { pkgs, ... } : { - # Minio requires at least 1GiB of free disk space to run. - virtualisation = { - diskSize = 2 * 1024; - }; - networking.firewall.allowedTCPPorts = [ minioPort ]; + s3 = + { pkgs, ... }: + { + # Minio requires at least 1GiB of free disk space to run. + virtualisation = { + diskSize = 2 * 1024; + }; + networking.firewall.allowedTCPPorts = [ minioPort ]; - services.minio = { - enable = true; - inherit (s3) accessKey secretKey; - }; + services.minio = { + enable = true; + inherit (s3) accessKey secretKey; + }; - environment.systemPackages = [ pkgs.minio-client ]; + environment.systemPackages = [ pkgs.minio-client ]; - services.prometheus.exporters.node = { - enable = true; - openFirewall = true; + services.prometheus.exporters.node = { + enable = true; + openFirewall = true; + }; }; - }; }; - testScript = { nodes, ... } : '' - # Before starting the other machines we first make sure that our S3 service is online - # and has a bucket added for thanos: - s3.start() - s3.wait_for_unit("minio.service") - s3.wait_for_open_port(${toString minioPort}) - s3.succeed( - "mc config host add minio " - + "http://localhost:${toString minioPort} " - + "${s3.accessKey} ${s3.secretKey} --api s3v4", - "mc mb minio/thanos-bucket", - ) + testScript = + { nodes, ... }: + '' + # Before starting the other machines we first make sure that our S3 service is online + # and has a bucket added for thanos: + s3.start() + s3.wait_for_unit("minio.service") + s3.wait_for_open_port(${toString minioPort}) + s3.succeed( + "mc config host add minio " + + "http://localhost:${toString minioPort} " + + "${s3.accessKey} ${s3.secretKey} --api s3v4", + "mc mb minio/thanos-bucket", + ) - # Now that s3 has started we can start the other machines: - for machine in prometheus, query, store: - machine.start() + # Now that s3 has started we can start the other machines: + for machine in prometheus, query, store: + machine.start() - # Check if prometheus responds to requests: - prometheus.wait_for_unit("prometheus.service") + # Check if prometheus responds to requests: + prometheus.wait_for_unit("prometheus.service") - prometheus.wait_for_open_port(${toString queryPort}) - prometheus.succeed("curl -sf http://127.0.0.1:${toString queryPort}/metrics") + prometheus.wait_for_open_port(${toString queryPort}) + prometheus.succeed("curl -sf http://127.0.0.1:${toString queryPort}/metrics") - # Let's test if pushing a metric to the pushgateway succeeds: - prometheus.wait_for_unit("pushgateway.service") - prometheus.succeed( - "echo 'some_metric 3.14' | " - + "curl -f --data-binary \@- " - + "http://127.0.0.1:${toString pushgwPort}/metrics/job/some_job" - ) + # Let's test if pushing a metric to the pushgateway succeeds: + prometheus.wait_for_unit("pushgateway.service") + prometheus.succeed( + "echo 'some_metric 3.14' | " + + "curl -f --data-binary \@- " + + "http://127.0.0.1:${toString pushgwPort}/metrics/job/some_job" + ) - # Now check whether that metric gets ingested by prometheus. - # Since we'll check for the metric several times on different machines - # we abstract the test using the following function: + # Now check whether that metric gets ingested by prometheus. + # Since we'll check for the metric several times on different machines + # we abstract the test using the following function: - # Function to check if the metric "some_metric" has been received and returns the correct value. - def wait_for_metric(machine): - return machine.wait_until_succeeds( - "curl -sf 'http://127.0.0.1:${toString queryPort}/api/v1/query?query=some_metric' | " - + "jq '.data.result[0].value[1]' | grep '\"3.14\"'" - ) + # Function to check if the metric "some_metric" has been received and returns the correct value. + def wait_for_metric(machine): + return machine.wait_until_succeeds( + "curl -sf 'http://127.0.0.1:${toString queryPort}/api/v1/query?query=some_metric' | " + + "jq '.data.result[0].value[1]' | grep '\"3.14\"'" + ) - wait_for_metric(prometheus) + wait_for_metric(prometheus) - # Let's test if the pushgateway persists metrics to the configured location. - prometheus.wait_until_succeeds("test -e /var/lib/prometheus-pushgateway/metrics") + # Let's test if the pushgateway persists metrics to the configured location. + prometheus.wait_until_succeeds("test -e /var/lib/prometheus-pushgateway/metrics") - # Test thanos - prometheus.wait_for_unit("thanos-sidecar.service") + # Test thanos + prometheus.wait_for_unit("thanos-sidecar.service") - # Test if the Thanos query service can correctly retrieve the metric that was send above. - query.wait_for_unit("thanos-query.service") - wait_for_metric(query) + # Test if the Thanos query service can correctly retrieve the metric that was send above. + query.wait_for_unit("thanos-query.service") + wait_for_metric(query) - # Test Thanos query frontend service - query.wait_for_unit("thanos-query-frontend.service") - query.succeed("curl -sS http://localhost:${toString frontPort}/-/healthy") + # Test Thanos query frontend service + query.wait_for_unit("thanos-query-frontend.service") + query.succeed("curl -sS http://localhost:${toString frontPort}/-/healthy") - # Test if the Thanos sidecar has correctly uploaded its TSDB to S3, if the - # Thanos storage service has correctly downloaded it from S3 and if the Thanos - # query service running on $store can correctly retrieve the metric: - store.wait_for_unit("thanos-store.service") - wait_for_metric(store) + # Test if the Thanos sidecar has correctly uploaded its TSDB to S3, if the + # Thanos storage service has correctly downloaded it from S3 and if the Thanos + # query service running on $store can correctly retrieve the metric: + store.wait_for_unit("thanos-store.service") + wait_for_metric(store) - store.wait_for_unit("thanos-compact.service") + store.wait_for_unit("thanos-compact.service") - # Test if the Thanos bucket command is able to retrieve blocks from the S3 bucket - # and check if the blocks have the correct labels: - store.succeed( - "thanos tools bucket ls " - + "--objstore.config-file=${nodes.store.config.services.thanos.store.objstore.config-file} " - + "--output=json | " - + "jq .thanos.labels.some_label | " - + "grep 'required by thanos'" - ) - ''; + # Test if the Thanos bucket command is able to retrieve blocks from the S3 bucket + # and check if the blocks have the correct labels: + store.succeed( + "thanos tools bucket ls " + + "--objstore.config-file=${nodes.store.config.services.thanos.store.objstore.config-file} " + + "--output=json | " + + "jq .thanos.labels.some_label | " + + "grep 'required by thanos'" + ) + ''; } diff --git a/nixos/tests/thelounge.nix b/nixos/tests/thelounge.nix index 8d5a37d46c4669..5214d10739bab3 100644 --- a/nixos/tests/thelounge.nix +++ b/nixos/tests/thelounge.nix @@ -2,19 +2,23 @@ import ./make-test-python.nix { name = "thelounge"; nodes = { - private = { config, pkgs, ... }: { - services.thelounge = { - enable = true; - plugins = [ pkgs.theLoungePlugins.themes.solarized ]; + private = + { config, pkgs, ... }: + { + services.thelounge = { + enable = true; + plugins = [ pkgs.theLoungePlugins.themes.solarized ]; + }; }; - }; - public = { config, pkgs, ... }: { - services.thelounge = { - enable = true; - public = true; + public = + { config, pkgs, ... }: + { + services.thelounge = { + enable = true; + public = true; + }; }; - }; }; testScript = '' diff --git a/nixos/tests/tiddlywiki.nix b/nixos/tests/tiddlywiki.nix index 822711b8939c5e..b52bc385f7f344 100644 --- a/nixos/tests/tiddlywiki.nix +++ b/nixos/tests/tiddlywiki.nix @@ -1,27 +1,28 @@ -import ./make-test-python.nix ({ ... }: { - name = "tiddlywiki"; - nodes = { - default = { - services.tiddlywiki.enable = true; - }; - configured = { - boot.postBootCommands = '' - echo "username,password - somelogin,somesecret" > /var/lib/wikiusers.csv - ''; - services.tiddlywiki = { - enable = true; - listenOptions = { - port = 3000; - credentials="../wikiusers.csv"; - readers="(authenticated)"; +import ./make-test-python.nix ( + { ... }: + { + name = "tiddlywiki"; + nodes = { + default = { + services.tiddlywiki.enable = true; + }; + configured = { + boot.postBootCommands = '' + echo "username,password + somelogin,somesecret" > /var/lib/wikiusers.csv + ''; + services.tiddlywiki = { + enable = true; + listenOptions = { + port = 3000; + credentials = "../wikiusers.csv"; + readers = "(authenticated)"; + }; }; }; }; - }; - testScript = - '' + testScript = '' start_all() with subtest("by default works without configuration"): @@ -66,4 +67,5 @@ import ./make-test-python.nix ({ ... }: { "curl --fail -o /dev/null 127.0.0.1:8080/recipes/default/tiddlers/somepage" ) ''; -}) + } +) diff --git a/nixos/tests/tigervnc.nix b/nixos/tests/tigervnc.nix index 79c4f19178d5ec..05e4366045f28e 100644 --- a/nixos/tests/tigervnc.nix +++ b/nixos/tests/tigervnc.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem -, config ? {} -, pkgs ? import ../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../.. { inherit system config; }, }: with import ../lib/testing-python.nix { inherit system pkgs; }; @@ -11,20 +12,24 @@ makeTest { }; nodes = { - server = { pkgs, ...}: { - environment.systemPackages = with pkgs; [ - tigervnc # for Xvnc - xorg.xwininfo - imagemagickBig # for display with working label: support - ]; - networking.firewall.allowedTCPPorts = [ 5901 ]; - }; - - client = { pkgs, ... }: { - imports = [ ./common/x11.nix ]; - # for vncviewer - environment.systemPackages = [ pkgs.tigervnc ]; - }; + server = + { pkgs, ... }: + { + environment.systemPackages = with pkgs; [ + tigervnc # for Xvnc + xorg.xwininfo + imagemagickBig # for display with working label: support + ]; + networking.firewall.allowedTCPPorts = [ 5901 ]; + }; + + client = + { pkgs, ... }: + { + imports = [ ./common/x11.nix ]; + # for vncviewer + environment.systemPackages = [ pkgs.tigervnc ]; + }; }; enableOCR = true; diff --git a/nixos/tests/tika.nix b/nixos/tests/tika.nix index 61a3a6ad22aed0..39cd3ec33c4160 100644 --- a/nixos/tests/tika.nix +++ b/nixos/tests/tika.nix @@ -4,11 +4,13 @@ name = "tika-server"; nodes = { - machine = { pkgs, ... }: { - services.tika = { - enable = true; + machine = + { pkgs, ... }: + { + services.tika = { + enable = true; + }; }; - }; }; testScript = '' diff --git a/nixos/tests/timezone.nix b/nixos/tests/timezone.nix index 5d0318e33daab2..86de47204ae895 100644 --- a/nixos/tests/timezone.nix +++ b/nixos/tests/timezone.nix @@ -1,50 +1,59 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "timezone"; - meta.maintainers = with pkgs.lib.maintainers; [ ]; - - nodes = { - node_eutz = { pkgs, ... }: { - time.timeZone = "Europe/Amsterdam"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "timezone"; + meta.maintainers = with pkgs.lib.maintainers; [ ]; + + nodes = { + node_eutz = + { pkgs, ... }: + { + time.timeZone = "Europe/Amsterdam"; + }; + + node_nulltz = + { pkgs, ... }: + { + time.timeZone = null; + }; }; - node_nulltz = { pkgs, ... }: { - time.timeZone = null; - }; - }; - - testScript = { nodes, ... }: '' - node_eutz.wait_for_unit("dbus.socket") - - with subtest("static - Ensure timezone change gives the correct result"): - node_eutz.fail("timedatectl set-timezone Asia/Tokyo") - date_result = node_eutz.succeed('date -d @0 "+%Y-%m-%d %H:%M:%S"') - assert date_result == "1970-01-01 01:00:00\n", "Timezone seems to be wrong" - - node_nulltz.wait_for_unit("dbus.socket") - - with subtest("imperative - Ensure timezone defaults to UTC"): - date_result = node_nulltz.succeed('date -d @0 "+%Y-%m-%d %H:%M:%S"') - print(date_result) - assert ( - date_result == "1970-01-01 00:00:00\n" - ), "Timezone seems to be wrong (not UTC)" - - with subtest("imperative - Ensure timezone adjustment produces expected result"): - node_nulltz.succeed("timedatectl set-timezone Asia/Tokyo") - - # Adjustment should be taken into account - date_result = node_nulltz.succeed('date -d @0 "+%Y-%m-%d %H:%M:%S"') - print(date_result) - assert date_result == "1970-01-01 09:00:00\n", "Timezone was not adjusted" - - with subtest("imperative - Ensure timezone adjustment persists across reboot"): - # Adjustment should persist across a reboot - node_nulltz.shutdown() - node_nulltz.wait_for_unit("dbus.socket") - date_result = node_nulltz.succeed('date -d @0 "+%Y-%m-%d %H:%M:%S"') - print(date_result) - assert ( - date_result == "1970-01-01 09:00:00\n" - ), "Timezone adjustment was not persisted" - ''; -}) + testScript = + { nodes, ... }: + '' + node_eutz.wait_for_unit("dbus.socket") + + with subtest("static - Ensure timezone change gives the correct result"): + node_eutz.fail("timedatectl set-timezone Asia/Tokyo") + date_result = node_eutz.succeed('date -d @0 "+%Y-%m-%d %H:%M:%S"') + assert date_result == "1970-01-01 01:00:00\n", "Timezone seems to be wrong" + + node_nulltz.wait_for_unit("dbus.socket") + + with subtest("imperative - Ensure timezone defaults to UTC"): + date_result = node_nulltz.succeed('date -d @0 "+%Y-%m-%d %H:%M:%S"') + print(date_result) + assert ( + date_result == "1970-01-01 00:00:00\n" + ), "Timezone seems to be wrong (not UTC)" + + with subtest("imperative - Ensure timezone adjustment produces expected result"): + node_nulltz.succeed("timedatectl set-timezone Asia/Tokyo") + + # Adjustment should be taken into account + date_result = node_nulltz.succeed('date -d @0 "+%Y-%m-%d %H:%M:%S"') + print(date_result) + assert date_result == "1970-01-01 09:00:00\n", "Timezone was not adjusted" + + with subtest("imperative - Ensure timezone adjustment persists across reboot"): + # Adjustment should persist across a reboot + node_nulltz.shutdown() + node_nulltz.wait_for_unit("dbus.socket") + date_result = node_nulltz.succeed('date -d @0 "+%Y-%m-%d %H:%M:%S"') + print(date_result) + assert ( + date_result == "1970-01-01 09:00:00\n" + ), "Timezone adjustment was not persisted" + ''; + } +) diff --git a/nixos/tests/tinc/default.nix b/nixos/tests/tinc/default.nix index 31b675ad35c067..bec266154fe406 100644 --- a/nixos/tests/tinc/default.nix +++ b/nixos/tests/tinc/default.nix @@ -1,73 +1,89 @@ -import ../make-test-python.nix ({ lib, ... }: +import ../make-test-python.nix ( + { lib, ... }: let snakeoil-keys = import ./snakeoil-keys.nix; hosts = lib.attrNames snakeoil-keys; - subnetOf = name: config: + subnetOf = + name: config: let subnets = config.services.tinc.networks.myNetwork.hostSettings.${name}.subnets; in (builtins.head subnets).address; - makeTincHost = name: { subnet, extraConfig ? { } }: lib.mkMerge [ + makeTincHost = + name: { - subnets = [{ address = subnet; }]; - settings = { - Ed25519PublicKey = snakeoil-keys.${name}.ed25519Public; - }; - rsaPublicKey = snakeoil-keys.${name}.rsaPublic; - } - extraConfig - ]; - - makeTincNode = { config, ... }: name: extraConfig: lib.mkMerge [ - { - services.tinc.networks.myNetwork = { - inherit name; - rsaPrivateKeyFile = - builtins.toFile "rsa.priv" snakeoil-keys.${name}.rsaPrivate; - ed25519PrivateKeyFile = - builtins.toFile "ed25519.priv" snakeoil-keys.${name}.ed25519Private; - - hostSettings = lib.mapAttrs makeTincHost { - static = { - subnet = "10.0.0.11"; - # Only specify the addresses in the node's vlans, Tinc does not - # seem to try each one, unlike the documentation suggests... - extraConfig.addresses = map - (vlan: { address = "192.168.${toString vlan}.11"; port = 655; }) - config.virtualisation.vlans; + subnet, + extraConfig ? { }, + }: + lib.mkMerge [ + { + subnets = [ { address = subnet; } ]; + settings = { + Ed25519PublicKey = snakeoil-keys.${name}.ed25519Public; + }; + rsaPublicKey = snakeoil-keys.${name}.rsaPublic; + } + extraConfig + ]; + + makeTincNode = + { config, ... }: + name: extraConfig: + lib.mkMerge [ + { + services.tinc.networks.myNetwork = { + inherit name; + rsaPrivateKeyFile = builtins.toFile "rsa.priv" snakeoil-keys.${name}.rsaPrivate; + ed25519PrivateKeyFile = builtins.toFile "ed25519.priv" snakeoil-keys.${name}.ed25519Private; + + hostSettings = lib.mapAttrs makeTincHost { + static = { + subnet = "10.0.0.11"; + # Only specify the addresses in the node's vlans, Tinc does not + # seem to try each one, unlike the documentation suggests... + extraConfig.addresses = map (vlan: { + address = "192.168.${toString vlan}.11"; + port = 655; + }) config.virtualisation.vlans; + }; + dynamic1 = { + subnet = "10.0.0.21"; + }; + dynamic2 = { + subnet = "10.0.0.22"; + }; }; - dynamic1 = { subnet = "10.0.0.21"; }; - dynamic2 = { subnet = "10.0.0.22"; }; }; - }; - - networking.useDHCP = false; - networking.interfaces."tinc.myNetwork" = { - virtual = true; - virtualType = "tun"; - ipv4.addresses = [{ - address = subnetOf name config; - prefixLength = 24; - }]; - }; + networking.useDHCP = false; + + networking.interfaces."tinc.myNetwork" = { + virtual = true; + virtualType = "tun"; + ipv4.addresses = [ + { + address = subnetOf name config; + prefixLength = 24; + } + ]; + }; - # Prevents race condition between NixOS service and tinc creating the - # interface. - # See: https://github.com/NixOS/nixpkgs/issues/27070 - systemd.services."tinc.myNetwork" = { - after = [ "network-addresses-tinc.myNetwork.service" ]; - requires = [ "network-addresses-tinc.myNetwork.service" ]; - }; + # Prevents race condition between NixOS service and tinc creating the + # interface. + # See: https://github.com/NixOS/nixpkgs/issues/27070 + systemd.services."tinc.myNetwork" = { + after = [ "network-addresses-tinc.myNetwork.service" ]; + requires = [ "network-addresses-tinc.myNetwork.service" ]; + }; - networking.firewall.allowedTCPPorts = [ 655 ]; - networking.firewall.allowedUDPPorts = [ 655 ]; - } - extraConfig - ]; + networking.firewall.allowedTCPPorts = [ 655 ]; + networking.firewall.allowedUDPPorts = [ 655 ]; + } + extraConfig + ]; in { @@ -76,28 +92,37 @@ import ../make-test-python.nix ({ lib, ... }: nodes = { - static = { ... } @ args: + static = + { ... }@args: makeTincNode args "static" { - virtualisation.vlans = [ 1 2 ]; - - networking.interfaces.eth1.ipv4.addresses = [{ - address = "192.168.1.11"; - prefixLength = 24; - }]; - - networking.interfaces.eth2.ipv4.addresses = [{ - address = "192.168.2.11"; - prefixLength = 24; - }]; + virtualisation.vlans = [ + 1 + 2 + ]; + + networking.interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.1.11"; + prefixLength = 24; + } + ]; + + networking.interfaces.eth2.ipv4.addresses = [ + { + address = "192.168.2.11"; + prefixLength = 24; + } + ]; }; - - dynamic1 = { ... } @ args: + dynamic1 = + { ... }@args: makeTincNode args "dynamic1" { virtualisation.vlans = [ 1 ]; }; - dynamic2 = { ... } @ args: + dynamic2 = + { ... }@args: makeTincNode args "dynamic2" { virtualisation.vlans = [ 2 ]; }; @@ -136,4 +161,5 @@ import ../make-test-python.nix ({ lib, ... }: dynamic1.succeed("ping -c5 10.0.0.22") dynamic2.succeed("ping -c5 10.0.0.21") ''; - }) + } +) diff --git a/nixos/tests/tinydns.nix b/nixos/tests/tinydns.nix index 124508bc004ba1..74f5a9413752d1 100644 --- a/nixos/tests/tinydns.nix +++ b/nixos/tests/tinydns.nix @@ -1,40 +1,46 @@ -import ./make-test-python.nix ({ lib, ...} : { - name = "tinydns"; - meta = { - maintainers = with lib.maintainers; [ basvandijk ]; - }; - nodes = { - nameserver = { config, lib, ... } : let - ip = (lib.head config.networking.interfaces.eth1.ipv4.addresses).address; - in { - networking.nameservers = [ ip ]; - services.tinydns = { - enable = true; - inherit ip; - data = '' - .foo.bar:${ip} - +.bla.foo.bar:1.2.3.4:300 - ''; - }; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "tinydns"; + meta = { + maintainers = with lib.maintainers; [ basvandijk ]; }; - }; - testScript = '' - nameserver.start() - nameserver.wait_for_unit("tinydns.service") + nodes = { + nameserver = + { config, lib, ... }: + let + ip = (lib.head config.networking.interfaces.eth1.ipv4.addresses).address; + in + { + networking.nameservers = [ ip ]; + services.tinydns = { + enable = true; + inherit ip; + data = '' + .foo.bar:${ip} + +.bla.foo.bar:1.2.3.4:300 + ''; + }; + }; + }; + testScript = '' + nameserver.start() + nameserver.wait_for_unit("tinydns.service") - # We query tinydns a few times to trigger the bug: - # - # nameserver # [ 6.105872] mmap: tinydns (842): VmData 331776 exceed data ulimit 300000. Update limits or use boot option ignore_rlimit_data. - # - # which was reported in https://github.com/NixOS/nixpkgs/issues/119066. - # Without the patch <nixpkgs/pkgs/tools/networking/djbdns/softlimit.patch> - # it fails on the 10th iteration. - nameserver.succeed( - """ - for i in {1..100}; do - host bla.foo.bar 192.168.1.1 | grep '1\.2\.3\.4' - done - """ - ) - ''; -}) + # We query tinydns a few times to trigger the bug: + # + # nameserver # [ 6.105872] mmap: tinydns (842): VmData 331776 exceed data ulimit 300000. Update limits or use boot option ignore_rlimit_data. + # + # which was reported in https://github.com/NixOS/nixpkgs/issues/119066. + # Without the patch <nixpkgs/pkgs/tools/networking/djbdns/softlimit.patch> + # it fails on the 10th iteration. + nameserver.succeed( + """ + for i in {1..100}; do + host bla.foo.bar 192.168.1.1 | grep '1\.2\.3\.4' + done + """ + ) + ''; + } +) diff --git a/nixos/tests/tinyproxy.nix b/nixos/tests/tinyproxy.nix index b8448d4c23b660..4184f68fd181c7 100644 --- a/nixos/tests/tinyproxy.nix +++ b/nixos/tests/tinyproxy.nix @@ -1,20 +1,25 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "tinyproxy"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "tinyproxy"; - nodes.machine = { config, pkgs, ... }: { - services.tinyproxy = { - enable = true; - settings = { - Listen = "127.0.0.1"; - Port = 8080; + nodes.machine = + { config, pkgs, ... }: + { + services.tinyproxy = { + enable = true; + settings = { + Listen = "127.0.0.1"; + Port = 8080; + }; + }; }; - }; - }; - testScript = '' - machine.wait_for_unit("tinyproxy.service") - machine.wait_for_open_port(8080) + testScript = '' + machine.wait_for_unit("tinyproxy.service") + machine.wait_for_open_port(8080) - machine.succeed('curl -s http://localhost:8080 |grep -i tinyproxy') - ''; -}) + machine.succeed('curl -s http://localhost:8080 |grep -i tinyproxy') + ''; + } +) diff --git a/nixos/tests/tinywl.nix b/nixos/tests/tinywl.nix index 2dc354812a75e3..85788d74ec8919 100644 --- a/nixos/tests/tinywl.nix +++ b/nixos/tests/tinywl.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: { name = "tinywl"; @@ -6,54 +7,63 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: maintainers = with lib.maintainers; [ primeos ]; }; - nodes.machine = { config, ... }: { - # Automatically login on tty1 as a normal user: - imports = [ ./common/user-account.nix ]; - services.getty.autologinUser = "alice"; - security.polkit.enable = true; + nodes.machine = + { config, ... }: + { + # Automatically login on tty1 as a normal user: + imports = [ ./common/user-account.nix ]; + services.getty.autologinUser = "alice"; + security.polkit.enable = true; - environment = { - systemPackages = with pkgs; [ tinywl foot wayland-utils ]; + environment = { + systemPackages = with pkgs; [ + tinywl + foot + wayland-utils + ]; + }; + + hardware.graphics.enable = true; + + # Automatically start TinyWL when logging in on tty1: + programs.bash.loginShellInit = '' + if [ "$(tty)" = "/dev/tty1" ]; then + set -e + test ! -e /tmp/tinywl.log # Only start tinywl once + readonly TEST_CMD="wayland-info |& tee /tmp/test-wayland.out && touch /tmp/test-wayland-exit-ok; read" + readonly FOOT_CMD="foot sh -c '$TEST_CMD'" + tinywl -s "$FOOT_CMD" |& tee /tmp/tinywl.log + touch /tmp/tinywl-exit-ok + fi + ''; + + # Switch to a different GPU driver (default: -vga std), otherwise TinyWL segfaults: + virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ]; }; - hardware.graphics.enable = true; - - # Automatically start TinyWL when logging in on tty1: - programs.bash.loginShellInit = '' - if [ "$(tty)" = "/dev/tty1" ]; then - set -e - test ! -e /tmp/tinywl.log # Only start tinywl once - readonly TEST_CMD="wayland-info |& tee /tmp/test-wayland.out && touch /tmp/test-wayland-exit-ok; read" - readonly FOOT_CMD="foot sh -c '$TEST_CMD'" - tinywl -s "$FOOT_CMD" |& tee /tmp/tinywl.log - touch /tmp/tinywl-exit-ok - fi - ''; + testScript = + { nodes, ... }: + '' + start_all() + machine.wait_for_unit("multi-user.target") - # Switch to a different GPU driver (default: -vga std), otherwise TinyWL segfaults: - virtualisation.qemu.options = [ "-vga none -device virtio-gpu-pci" ]; - }; + # Wait for complete startup: + machine.wait_until_succeeds("pgrep tinywl") + machine.wait_for_file("/run/user/1000/wayland-0") + machine.wait_until_succeeds("pgrep foot") + machine.wait_for_file("/tmp/test-wayland-exit-ok") + + # Make a screenshot and save the result: + machine.screenshot("tinywl_foot") + print(machine.succeed("cat /tmp/test-wayland.out")) + machine.copy_from_vm("/tmp/test-wayland.out") - testScript = { nodes, ... }: '' - start_all() - machine.wait_for_unit("multi-user.target") - - # Wait for complete startup: - machine.wait_until_succeeds("pgrep tinywl") - machine.wait_for_file("/run/user/1000/wayland-0") - machine.wait_until_succeeds("pgrep foot") - machine.wait_for_file("/tmp/test-wayland-exit-ok") - - # Make a screenshot and save the result: - machine.screenshot("tinywl_foot") - print(machine.succeed("cat /tmp/test-wayland.out")) - machine.copy_from_vm("/tmp/test-wayland.out") - - # Terminate cleanly: - machine.send_key("alt-esc") - machine.wait_until_fails("pgrep foot") - machine.wait_until_fails("pgrep tinywl") - machine.wait_for_file("/tmp/tinywl-exit-ok") - machine.copy_from_vm("/tmp/tinywl.log") - ''; - }) + # Terminate cleanly: + machine.send_key("alt-esc") + machine.wait_until_fails("pgrep foot") + machine.wait_until_fails("pgrep tinywl") + machine.wait_for_file("/tmp/tinywl-exit-ok") + machine.copy_from_vm("/tmp/tinywl.log") + ''; + } +) diff --git a/nixos/tests/tmate-ssh-server.nix b/nixos/tests/tmate-ssh-server.nix index 593663a13a4e33..0d529d6e68120e 100644 --- a/nixos/tests/tmate-ssh-server.nix +++ b/nixos/tests/tmate-ssh-server.nix @@ -1,76 +1,85 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: -let - inherit (import ./ssh-keys.nix pkgs) - snakeOilPrivateKey snakeOilPublicKey; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + inherit (import ./ssh-keys.nix pkgs) + snakeOilPrivateKey + snakeOilPublicKey + ; - setUpPrivateKey = name: '' - ${name}.succeed( - "mkdir -p /root/.ssh", - "chmod 700 /root/.ssh", - "cat '${snakeOilPrivateKey}' > /root/.ssh/id_snakeoil", - "chmod 600 /root/.ssh/id_snakeoil", - ) - ${name}.wait_for_file("/root/.ssh/id_snakeoil") - ''; + setUpPrivateKey = name: '' + ${name}.succeed( + "mkdir -p /root/.ssh", + "chmod 700 /root/.ssh", + "cat '${snakeOilPrivateKey}' > /root/.ssh/id_snakeoil", + "chmod 600 /root/.ssh/id_snakeoil", + ) + ${name}.wait_for_file("/root/.ssh/id_snakeoil") + ''; - sshOpts = "-oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null -oIdentityFile=/root/.ssh/id_snakeoil"; + sshOpts = "-oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null -oIdentityFile=/root/.ssh/id_snakeoil"; -in -{ - name = "tmate-ssh-server"; - nodes = - { - server = { ... }: { - services.tmate-ssh-server = { - enable = true; - port = 2223; - openFirewall = true; + in + { + name = "tmate-ssh-server"; + nodes = { + server = + { ... }: + { + services.tmate-ssh-server = { + enable = true; + port = 2223; + openFirewall = true; + }; + }; + client = + { ... }: + { + environment.systemPackages = [ pkgs.tmate ]; + services.openssh.enable = true; + users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; + }; + client2 = + { ... }: + { + environment.systemPackages = [ pkgs.openssh ]; }; - }; - client = { ... }: { - environment.systemPackages = [ pkgs.tmate ]; - services.openssh.enable = true; - users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; - }; - client2 = { ... }: { - environment.systemPackages = [ pkgs.openssh ]; - }; }; - testScript = '' - start_all() + testScript = '' + start_all() - server.wait_for_unit("tmate-ssh-server.service") - server.wait_for_open_port(2223) - server.wait_for_file("/etc/tmate-ssh-server-keys/ssh_host_ed25519_key.pub") - server.wait_for_file("/etc/tmate-ssh-server-keys/ssh_host_rsa_key.pub") - server.succeed("tmate-client-config > /tmp/tmate.conf") - server.wait_for_file("/tmp/tmate.conf") + server.wait_for_unit("tmate-ssh-server.service") + server.wait_for_open_port(2223) + server.wait_for_file("/etc/tmate-ssh-server-keys/ssh_host_ed25519_key.pub") + server.wait_for_file("/etc/tmate-ssh-server-keys/ssh_host_rsa_key.pub") + server.succeed("tmate-client-config > /tmp/tmate.conf") + server.wait_for_file("/tmp/tmate.conf") - ${setUpPrivateKey "server"} - client.wait_for_unit("sshd.service") - client.wait_for_open_port(22) - server.succeed("scp ${sshOpts} /tmp/tmate.conf client:/tmp/tmate.conf") + ${setUpPrivateKey "server"} + client.wait_for_unit("sshd.service") + client.wait_for_open_port(22) + server.succeed("scp ${sshOpts} /tmp/tmate.conf client:/tmp/tmate.conf") - client.wait_for_file("/tmp/tmate.conf") - client.wait_until_tty_matches("1", "login:") - client.send_chars("root\n") - client.sleep(2) - client.send_chars("tmate -f /tmp/tmate.conf\n") - client.sleep(2) - client.send_chars("q") - client.sleep(2) - client.send_chars("tmate display -p '#{tmate_ssh}' > /tmp/ssh_command\n") - client.wait_for_file("/tmp/ssh_command") - ssh_cmd = client.succeed("cat /tmp/ssh_command") + client.wait_for_file("/tmp/tmate.conf") + client.wait_until_tty_matches("1", "login:") + client.send_chars("root\n") + client.sleep(2) + client.send_chars("tmate -f /tmp/tmate.conf\n") + client.sleep(2) + client.send_chars("q") + client.sleep(2) + client.send_chars("tmate display -p '#{tmate_ssh}' > /tmp/ssh_command\n") + client.wait_for_file("/tmp/ssh_command") + ssh_cmd = client.succeed("cat /tmp/ssh_command") - client2.succeed("mkdir -p ~/.ssh; ssh-keyscan -4 -p 2223 server > ~/.ssh/known_hosts") - client2.wait_until_tty_matches("1", "login:") - client2.send_chars("root\n") - client2.sleep(2) - client2.send_chars(ssh_cmd.strip() + "\n") - client2.sleep(2) - client2.send_chars("touch /tmp/client_2\n") + client2.succeed("mkdir -p ~/.ssh; ssh-keyscan -4 -p 2223 server > ~/.ssh/known_hosts") + client2.wait_until_tty_matches("1", "login:") + client2.send_chars("root\n") + client2.sleep(2) + client2.send_chars(ssh_cmd.strip() + "\n") + client2.sleep(2) + client2.send_chars("touch /tmp/client_2\n") - client.wait_for_file("/tmp/client_2") - ''; -}) + client.wait_for_file("/tmp/client_2") + ''; + } +) diff --git a/nixos/tests/tomcat.nix b/nixos/tests/tomcat.nix index c5e6e65ac600e3..6d8b9f496454e6 100644 --- a/nixos/tests/tomcat.nix +++ b/nixos/tests/tomcat.nix @@ -1,28 +1,33 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "tomcat"; - meta.maintainers = [ lib.maintainers.anthonyroussel ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "tomcat"; + meta.maintainers = [ lib.maintainers.anthonyroussel ]; - nodes.machine = { pkgs, ... }: { - services.tomcat = { - enable = true; - port = 8001; - axis2.enable = true; - }; - }; + nodes.machine = + { pkgs, ... }: + { + services.tomcat = { + enable = true; + port = 8001; + axis2.enable = true; + }; + }; - testScript = '' - machine.wait_for_unit("tomcat.service") - machine.wait_for_open_port(8001) - machine.wait_for_file("/var/tomcat/webapps/examples"); + testScript = '' + machine.wait_for_unit("tomcat.service") + machine.wait_for_open_port(8001) + machine.wait_for_file("/var/tomcat/webapps/examples"); - machine.succeed( - "curl -sS --fail http://localhost:8001/examples/servlets/servlet/HelloWorldExample | grep 'Hello World!'" - ) - machine.succeed( - "curl -sS --fail http://localhost:8001/examples/jsp/jsp2/simpletag/hello.jsp | grep 'Hello, world!'" - ) - machine.succeed( - "curl -sS --fail http://localhost:8001/axis2/axis2-web/HappyAxis.jsp | grep 'Found Axis2'" - ) - ''; -}) + machine.succeed( + "curl -sS --fail http://localhost:8001/examples/servlets/servlet/HelloWorldExample | grep 'Hello World!'" + ) + machine.succeed( + "curl -sS --fail http://localhost:8001/examples/jsp/jsp2/simpletag/hello.jsp | grep 'Hello, world!'" + ) + machine.succeed( + "curl -sS --fail http://localhost:8001/axis2/axis2-web/HappyAxis.jsp | grep 'Found Axis2'" + ) + ''; + } +) diff --git a/nixos/tests/tor.nix b/nixos/tests/tor.nix index b55fbf91232cb6..6eff3c7e260afe 100644 --- a/nixos/tests/tor.nix +++ b/nixos/tests/tor.nix @@ -1,23 +1,32 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "tor"; - meta.maintainers = with lib.maintainers; [ joachifm ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "tor"; + meta.maintainers = with lib.maintainers; [ joachifm ]; - nodes.client = { pkgs, ... }: { - boot.kernelParams = [ "audit=0" "apparmor=0" "quiet" ]; - networking.firewall.enable = false; - networking.useDHCP = false; + nodes.client = + { pkgs, ... }: + { + boot.kernelParams = [ + "audit=0" + "apparmor=0" + "quiet" + ]; + networking.firewall.enable = false; + networking.useDHCP = false; - environment.systemPackages = [ pkgs.netcat ]; - services.tor.enable = true; - services.tor.client.enable = true; - services.tor.settings.ControlPort = 9051; - }; + environment.systemPackages = [ pkgs.netcat ]; + services.tor.enable = true; + services.tor.client.enable = true; + services.tor.settings.ControlPort = 9051; + }; - testScript = '' - client.wait_for_unit("tor.service") - client.wait_for_open_port(9051) - assert "514 Authentication required." in client.succeed( - "echo GETINFO version | nc 127.0.0.1 9051" - ) - ''; -}) + testScript = '' + client.wait_for_unit("tor.service") + client.wait_for_open_port(9051) + assert "514 Authentication required." in client.succeed( + "echo GETINFO version | nc 127.0.0.1 9051" + ) + ''; + } +) diff --git a/nixos/tests/tracee.nix b/nixos/tests/tracee.nix index 1c241f3ec49839..af9e173bca9519 100644 --- a/nixos/tests/tracee.nix +++ b/nixos/tests/tracee.nix @@ -1,65 +1,72 @@ -import ./make-test-python.nix ({ pkgs, ... }: rec { - name = "tracee-integration"; - meta.maintainers = pkgs.tracee.meta.maintainers; +import ./make-test-python.nix ( + { pkgs, ... }: + rec { + name = "tracee-integration"; + meta.maintainers = pkgs.tracee.meta.maintainers; - passthru.hello-world-builder = pkgs: pkgs.dockerTools.buildImage { - name = "hello-world"; - tag = "latest"; - config.Cmd = [ "${pkgs.hello}/bin/hello" ]; - }; + passthru.hello-world-builder = + pkgs: + pkgs.dockerTools.buildImage { + name = "hello-world"; + tag = "latest"; + config.Cmd = [ "${pkgs.hello}/bin/hello" ]; + }; - nodes = { - machine = { config, pkgs, ... }: { - # EventFilters/trace_only_events_from_new_containers and - # Test_EventFilters/trace_only_events_from_"dockerd"_binary_and_contain_it's_pid - # require docker/dockerd - virtualisation.docker.enable = true; + nodes = { + machine = + { config, pkgs, ... }: + { + # EventFilters/trace_only_events_from_new_containers and + # Test_EventFilters/trace_only_events_from_"dockerd"_binary_and_contain_it's_pid + # require docker/dockerd + virtualisation.docker.enable = true; - environment.systemPackages = with pkgs; [ - # required by Test_EventFilters/trace_events_from_ls_and_which_binary_in_separate_scopes - which - # the go integration tests as a binary - tracee.passthru.tests.integration-test-cli - ]; + environment.systemPackages = with pkgs; [ + # required by Test_EventFilters/trace_events_from_ls_and_which_binary_in_separate_scopes + which + # the go integration tests as a binary + tracee.passthru.tests.integration-test-cli + ]; + }; }; - }; - testScript = - let - skippedTests = [ - # these comm tests for some reason do not resolve. - # something about the test is different as it works fine if I replicate - # the policies and run tracee myself but doesn't work in the integration - # test either with the automatic run or running the commands by hand - # while it's searching. - "Test_EventFilters/comm:_event:_args:_trace_event_set_in_a_specific_policy_with_args_from_ls_command" - "Test_EventFilters/comm:_event:_trace_events_set_in_two_specific_policies_from_ls_and_uname_commands" + testScript = + let + skippedTests = [ + # these comm tests for some reason do not resolve. + # something about the test is different as it works fine if I replicate + # the policies and run tracee myself but doesn't work in the integration + # test either with the automatic run or running the commands by hand + # while it's searching. + "Test_EventFilters/comm:_event:_args:_trace_event_set_in_a_specific_policy_with_args_from_ls_command" + "Test_EventFilters/comm:_event:_trace_events_set_in_two_specific_policies_from_ls_and_uname_commands" - # worked at some point, seems to be flakey - "Test_EventFilters/pid:_event:_args:_trace_event_sched_switch_with_args_from_pid_0" - ]; - in - '' - with subtest("prepare for integration tests"): - machine.wait_for_unit("docker.service") - machine.succeed('which bash') + # worked at some point, seems to be flakey + "Test_EventFilters/pid:_event:_args:_trace_event_sched_switch_with_args_from_pid_0" + ]; + in + '' + with subtest("prepare for integration tests"): + machine.wait_for_unit("docker.service") + machine.succeed('which bash') - # EventFilters/trace_only_events_from_new_containers also requires a container called "hello-world" - machine.succeed('docker load < ${passthru.hello-world-builder pkgs}') + # EventFilters/trace_only_events_from_new_containers also requires a container called "hello-world" + machine.succeed('docker load < ${passthru.hello-world-builder pkgs}') - # exec= needs fully resolved paths - machine.succeed( - 'mkdir /tmp/testdir', - 'cp $(which who) /tmp/testdir/who', - 'cp $(which uname) /tmp/testdir/uname', - ) + # exec= needs fully resolved paths + machine.succeed( + 'mkdir /tmp/testdir', + 'cp $(which who) /tmp/testdir/who', + 'cp $(which uname) /tmp/testdir/uname', + ) - with subtest("run integration tests"): - # Test_EventFilters/trace_event_set_in_a_specific_scope expects to be in a dir that includes "integration" - # tests must be ran with 1 process - print(machine.succeed( - 'mkdir /tmp/integration', - 'cd /tmp/integration && export PATH="/tmp/testdir:$PATH" && integration.test -test.v -test.parallel 1 -test.skip="^${builtins.concatStringsSep "$|^" skippedTests}$"' - )) - ''; -}) + with subtest("run integration tests"): + # Test_EventFilters/trace_event_set_in_a_specific_scope expects to be in a dir that includes "integration" + # tests must be ran with 1 process + print(machine.succeed( + 'mkdir /tmp/integration', + 'cd /tmp/integration && export PATH="/tmp/testdir:$PATH" && integration.test -test.v -test.parallel 1 -test.skip="^${builtins.concatStringsSep "$|^" skippedTests}$"' + )) + ''; + } +) diff --git a/nixos/tests/traefik.nix b/nixos/tests/traefik.nix index f26b79a0fa4d6f..5e0c88c8130a64 100644 --- a/nixos/tests/traefik.nix +++ b/nixos/tests/traefik.nix @@ -1,98 +1,109 @@ # Test Traefik as a reverse proxy of a local web service # and a Docker container. -import ./make-test-python.nix ({ pkgs, ... }: { - name = "traefik"; - meta = with pkgs.lib.maintainers; { - maintainers = [ joko ]; - }; - - nodes = { - client = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.curl ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "traefik"; + meta = with pkgs.lib.maintainers; { + maintainers = [ joko ]; }; - traefik = { config, pkgs, ... }: { - virtualisation.oci-containers = { - backend = "docker"; - containers.nginx = { - extraOptions = [ - "-l" - "traefik.enable=true" - "-l" - "traefik.http.routers.nginx.entrypoints=web" - "-l" - "traefik.http.routers.nginx.rule=Host(`nginx.traefik.test`)" - ]; - image = "nginx-container"; - imageStream = pkgs.dockerTools.examples.nginxStream; - }; - }; - - networking.firewall.allowedTCPPorts = [ 80 ]; - - services.traefik = { - enable = true; - dynamicConfigOptions = { - http.routers.simplehttp = { - rule = "Host(`simplehttp.traefik.test`)"; - entryPoints = [ "web" ]; - service = "simplehttp"; + nodes = { + client = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.curl ]; + }; + traefik = + { config, pkgs, ... }: + { + virtualisation.oci-containers = { + backend = "docker"; + containers.nginx = { + extraOptions = [ + "-l" + "traefik.enable=true" + "-l" + "traefik.http.routers.nginx.entrypoints=web" + "-l" + "traefik.http.routers.nginx.rule=Host(`nginx.traefik.test`)" + ]; + image = "nginx-container"; + imageStream = pkgs.dockerTools.examples.nginxStream; + }; }; - http.services.simplehttp = { - loadBalancer.servers = [{ - url = "http://127.0.0.1:8000"; - }]; + networking.firewall.allowedTCPPorts = [ 80 ]; + + services.traefik = { + enable = true; + + dynamicConfigOptions = { + http.routers.simplehttp = { + rule = "Host(`simplehttp.traefik.test`)"; + entryPoints = [ "web" ]; + service = "simplehttp"; + }; + + http.services.simplehttp = { + loadBalancer.servers = [ + { + url = "http://127.0.0.1:8000"; + } + ]; + }; + }; + + staticConfigOptions = { + global = { + checkNewVersion = false; + sendAnonymousUsage = false; + }; + + entryPoints.web.address = ":\${HTTP_PORT}"; + + providers.docker.exposedByDefault = false; + }; + environmentFiles = [ + (pkgs.writeText "traefik.env" '' + HTTP_PORT=80 + '') + ]; }; - }; - staticConfigOptions = { - global = { - checkNewVersion = false; - sendAnonymousUsage = false; + systemd.services.simplehttp = { + script = "${pkgs.python3}/bin/python -m http.server 8000"; + serviceConfig.Type = "simple"; + wantedBy = [ "multi-user.target" ]; }; - entryPoints.web.address = ":\${HTTP_PORT}"; - - providers.docker.exposedByDefault = false; + users.users.traefik.extraGroups = [ "docker" ]; }; - environmentFiles = [(pkgs.writeText "traefik.env" '' - HTTP_PORT=80 - '')]; - }; - - systemd.services.simplehttp = { - script = "${pkgs.python3}/bin/python -m http.server 8000"; - serviceConfig.Type = "simple"; - wantedBy = [ "multi-user.target" ]; - }; - - users.users.traefik.extraGroups = [ "docker" ]; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - traefik.wait_for_unit("docker-nginx.service") - traefik.wait_until_succeeds("docker ps | grep nginx-container") - traefik.wait_for_unit("simplehttp.service") - traefik.wait_for_unit("traefik.service") - traefik.wait_for_open_port(80) - traefik.wait_for_unit("multi-user.target") + traefik.wait_for_unit("docker-nginx.service") + traefik.wait_until_succeeds("docker ps | grep nginx-container") + traefik.wait_for_unit("simplehttp.service") + traefik.wait_for_unit("traefik.service") + traefik.wait_for_open_port(80) + traefik.wait_for_unit("multi-user.target") - client.wait_for_unit("multi-user.target") + client.wait_for_unit("multi-user.target") - client.wait_until_succeeds("curl -sSf -H Host:nginx.traefik.test http://traefik/") + client.wait_until_succeeds("curl -sSf -H Host:nginx.traefik.test http://traefik/") - with subtest("Check that a container can be reached via Traefik"): - assert "Hello from NGINX" in client.succeed( - "curl -sSf -H Host:nginx.traefik.test http://traefik/" - ) + with subtest("Check that a container can be reached via Traefik"): + assert "Hello from NGINX" in client.succeed( + "curl -sSf -H Host:nginx.traefik.test http://traefik/" + ) - with subtest("Check that dynamic configuration works"): - assert "Directory listing for " in client.succeed( - "curl -sSf -H Host:simplehttp.traefik.test http://traefik/" - ) - ''; -}) + with subtest("Check that dynamic configuration works"): + assert "Directory listing for " in client.succeed( + "curl -sSf -H Host:simplehttp.traefik.test http://traefik/" + ) + ''; + } +) diff --git a/nixos/tests/trafficserver.nix b/nixos/tests/trafficserver.nix index 94d0e4dd926e96..9a64534e4357f4 100644 --- a/nixos/tests/trafficserver.nix +++ b/nixos/tests/trafficserver.nix @@ -19,161 +19,188 @@ # - bin/traffic_logcat # - bin/traffic_logstats # - bin/tspush -import ./make-test-python.nix ({ pkgs, ... }: { - name = "trafficserver"; - meta = with pkgs.lib.maintainers; { - maintainers = [ midchildan ]; - }; - - nodes = { - ats = { pkgs, lib, config, ... }: let - user = config.users.users.trafficserver.name; - group = config.users.groups.trafficserver.name; - healthchecks = pkgs.writeText "healthchecks.conf" '' - /status /tmp/ats.status text/plain 200 500 - ''; - in { - services.trafficserver.enable = true; - - services.trafficserver.records = { - proxy.config.http.server_ports = "80 80:ipv6"; - proxy.config.hostdb.host_file.path = "/etc/hosts"; - proxy.config.log.max_space_mb_headroom = 0; - proxy.config.http.push_method_enabled = 1; - - # check that cache storage is usable before accepting traffic - proxy.config.http.wait_for_cache = 2; - }; - - services.trafficserver.plugins = [ - { path = "healthchecks.so"; arg = toString healthchecks; } - { path = "xdebug.so"; } - ]; - - services.trafficserver.remap = '' - map http://httpbin.test http://httpbin - map http://pristine-host-hdr.test http://httpbin \ - @plugin=conf_remap.so \ - @pparam=proxy.config.url_remap.pristine_host_hdr=1 - map http://ats/tspush http://httpbin/cache \ - @plugin=conf_remap.so \ - @pparam=proxy.config.http.cache.required_headers=0 - ''; - - services.trafficserver.storage = '' - /dev/vdb volume=1 - ''; - - networking.firewall.allowedTCPPorts = [ 80 ]; - virtualisation.emptyDiskImages = [ 256 ]; - services.udev.extraRules = '' - KERNEL=="vdb", OWNER="${user}", GROUP="${group}" - ''; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "trafficserver"; + meta = with pkgs.lib.maintainers; { + maintainers = [ midchildan ]; }; - httpbin = { pkgs, lib, ... }: let - python = pkgs.python3.withPackages - (ps: with ps; [ httpbin gunicorn gevent ]); - in { - systemd.services.httpbin = { - enable = true; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - ExecStart = "${python}/bin/gunicorn -b 0.0.0.0:80 httpbin:app -k gevent"; + nodes = { + ats = + { + pkgs, + lib, + config, + ... + }: + let + user = config.users.users.trafficserver.name; + group = config.users.groups.trafficserver.name; + healthchecks = pkgs.writeText "healthchecks.conf" '' + /status /tmp/ats.status text/plain 200 500 + ''; + in + { + services.trafficserver.enable = true; + + services.trafficserver.records = { + proxy.config.http.server_ports = "80 80:ipv6"; + proxy.config.hostdb.host_file.path = "/etc/hosts"; + proxy.config.log.max_space_mb_headroom = 0; + proxy.config.http.push_method_enabled = 1; + + # check that cache storage is usable before accepting traffic + proxy.config.http.wait_for_cache = 2; + }; + + services.trafficserver.plugins = [ + { + path = "healthchecks.so"; + arg = toString healthchecks; + } + { path = "xdebug.so"; } + ]; + + services.trafficserver.remap = '' + map http://httpbin.test http://httpbin + map http://pristine-host-hdr.test http://httpbin \ + @plugin=conf_remap.so \ + @pparam=proxy.config.url_remap.pristine_host_hdr=1 + map http://ats/tspush http://httpbin/cache \ + @plugin=conf_remap.so \ + @pparam=proxy.config.http.cache.required_headers=0 + ''; + + services.trafficserver.storage = '' + /dev/vdb volume=1 + ''; + + networking.firewall.allowedTCPPorts = [ 80 ]; + virtualisation.emptyDiskImages = [ 256 ]; + services.udev.extraRules = '' + KERNEL=="vdb", OWNER="${user}", GROUP="${group}" + ''; }; - }; - networking.firewall.allowedTCPPorts = [ 80 ]; - }; + httpbin = + { pkgs, lib, ... }: + let + python = pkgs.python3.withPackages ( + ps: with ps; [ + httpbin + gunicorn + gevent + ] + ); + in + { + systemd.services.httpbin = { + enable = true; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + ExecStart = "${python}/bin/gunicorn -b 0.0.0.0:80 httpbin:app -k gevent"; + }; + }; + + networking.firewall.allowedTCPPorts = [ 80 ]; + }; - client = { pkgs, lib, ... }: { - environment.systemPackages = with pkgs; [ curl ]; + client = + { pkgs, lib, ... }: + { + environment.systemPackages = with pkgs; [ curl ]; + }; }; - }; - - testScript = { nodes, ... }: let - sampleFile = pkgs.writeText "sample.txt" '' - It's the season of White Album. - ''; - in '' - import json - import re - - ats.wait_for_unit("trafficserver") - ats.wait_for_open_port(80) - httpbin.wait_for_unit("httpbin") - httpbin.wait_for_open_port(80) - client.systemctl("start network-online.target") - client.wait_for_unit("network-online.target") - - with subtest("Traffic Server is running"): - out = ats.succeed("traffic_ctl server status") - assert out.strip() == "Proxy -- on" - - with subtest("traffic_crashlog is running"): - ats.succeed("pgrep -f traffic_crashlog") - - with subtest("basic remapping works"): - out = client.succeed("curl -vv -H 'Host: httpbin.test' http://ats/headers") - assert json.loads(out)["headers"]["Host"] == "httpbin" - - with subtest("conf_remap plugin works"): - out = client.succeed( - "curl -vv -H 'Host: pristine-host-hdr.test' http://ats/headers" - ) - assert json.loads(out)["headers"]["Host"] == "pristine-host-hdr.test" - - with subtest("caching works"): - out = client.succeed( - "curl -vv -D - -H 'Host: httpbin.test' -H 'X-Debug: X-Cache' http://ats/cache/60 -o /dev/null" - ) - assert "X-Cache: miss" in out - - out = client.succeed( - "curl -vv -D - -H 'Host: httpbin.test' -H 'X-Debug: X-Cache' http://ats/cache/60 -o /dev/null" - ) - assert "X-Cache: hit-fresh" in out - - with subtest("pushing to cache works"): - url = "http://ats/tspush" - - ats.succeed(f"echo {url} > /tmp/urls.txt") - out = ats.succeed( - f"tspush -f '${sampleFile}' -u {url}" - ) - assert "HTTP/1.0 201 Created" in out, "cache push failed" - - out = ats.succeed( - "traffic_cache_tool --spans /etc/trafficserver/storage.config find --input /tmp/urls.txt" - ) - assert "Span: /dev/vdb" in out, "cache not stored on disk" - - out = client.succeed(f"curl {url}").strip() - expected = ( - open("${sampleFile}").read().strip() - ) - assert out == expected, "cache content mismatch" - - with subtest("healthcheck plugin works"): - out = client.succeed("curl -vv http://ats/status -o /dev/null -w '%{http_code}'") - assert out.strip() == "500" - - ats.succeed("touch /tmp/ats.status") - - out = client.succeed("curl -vv http://ats/status -o /dev/null -w '%{http_code}'") - assert out.strip() == "200" - - with subtest("logging works"): - access_log_path = "/var/log/trafficserver/squid.blog" - ats.wait_for_file(access_log_path) - - out = ats.succeed(f"traffic_logcat {access_log_path}").split("\n")[0] - expected = "^\S+ \S+ \S+ TCP_MISS/200 \S+ GET http://httpbin/headers - DIRECT/httpbin application/json$" - assert re.fullmatch(expected, out) is not None, "no matching logs" - - out = json.loads(ats.succeed(f"traffic_logstats -jf {access_log_path}")) - assert isinstance(out, dict) - assert out["total"]["error.total"]["req"] == "0", "unexpected log stat" - ''; -}) + + testScript = + { nodes, ... }: + let + sampleFile = pkgs.writeText "sample.txt" '' + It's the season of White Album. + ''; + in + '' + import json + import re + + ats.wait_for_unit("trafficserver") + ats.wait_for_open_port(80) + httpbin.wait_for_unit("httpbin") + httpbin.wait_for_open_port(80) + client.systemctl("start network-online.target") + client.wait_for_unit("network-online.target") + + with subtest("Traffic Server is running"): + out = ats.succeed("traffic_ctl server status") + assert out.strip() == "Proxy -- on" + + with subtest("traffic_crashlog is running"): + ats.succeed("pgrep -f traffic_crashlog") + + with subtest("basic remapping works"): + out = client.succeed("curl -vv -H 'Host: httpbin.test' http://ats/headers") + assert json.loads(out)["headers"]["Host"] == "httpbin" + + with subtest("conf_remap plugin works"): + out = client.succeed( + "curl -vv -H 'Host: pristine-host-hdr.test' http://ats/headers" + ) + assert json.loads(out)["headers"]["Host"] == "pristine-host-hdr.test" + + with subtest("caching works"): + out = client.succeed( + "curl -vv -D - -H 'Host: httpbin.test' -H 'X-Debug: X-Cache' http://ats/cache/60 -o /dev/null" + ) + assert "X-Cache: miss" in out + + out = client.succeed( + "curl -vv -D - -H 'Host: httpbin.test' -H 'X-Debug: X-Cache' http://ats/cache/60 -o /dev/null" + ) + assert "X-Cache: hit-fresh" in out + + with subtest("pushing to cache works"): + url = "http://ats/tspush" + + ats.succeed(f"echo {url} > /tmp/urls.txt") + out = ats.succeed( + f"tspush -f '${sampleFile}' -u {url}" + ) + assert "HTTP/1.0 201 Created" in out, "cache push failed" + + out = ats.succeed( + "traffic_cache_tool --spans /etc/trafficserver/storage.config find --input /tmp/urls.txt" + ) + assert "Span: /dev/vdb" in out, "cache not stored on disk" + + out = client.succeed(f"curl {url}").strip() + expected = ( + open("${sampleFile}").read().strip() + ) + assert out == expected, "cache content mismatch" + + with subtest("healthcheck plugin works"): + out = client.succeed("curl -vv http://ats/status -o /dev/null -w '%{http_code}'") + assert out.strip() == "500" + + ats.succeed("touch /tmp/ats.status") + + out = client.succeed("curl -vv http://ats/status -o /dev/null -w '%{http_code}'") + assert out.strip() == "200" + + with subtest("logging works"): + access_log_path = "/var/log/trafficserver/squid.blog" + ats.wait_for_file(access_log_path) + + out = ats.succeed(f"traffic_logcat {access_log_path}").split("\n")[0] + expected = "^\S+ \S+ \S+ TCP_MISS/200 \S+ GET http://httpbin/headers - DIRECT/httpbin application/json$" + assert re.fullmatch(expected, out) is not None, "no matching logs" + + out = json.loads(ats.succeed(f"traffic_logstats -jf {access_log_path}")) + assert isinstance(out, dict) + assert out["total"]["error.total"]["req"] == "0", "unexpected log stat" + ''; + } +) diff --git a/nixos/tests/transfer-sh.nix b/nixos/tests/transfer-sh.nix index f4ab7d28858e14..32750b1fdc2596 100644 --- a/nixos/tests/transfer-sh.nix +++ b/nixos/tests/transfer-sh.nix @@ -1,20 +1,25 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "transfer-sh"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "transfer-sh"; - meta = { - maintainers = with lib.maintainers; [ ocfox ]; - }; - - nodes.machine = { pkgs, ... }: { - services.transfer-sh = { - enable = true; - settings.LISTENER = ":1234"; + meta = { + maintainers = with lib.maintainers; [ ocfox ]; }; - }; - testScript = '' - machine.wait_for_unit("transfer-sh.service") - machine.wait_for_open_port(1234) - machine.succeed("curl --fail http://localhost:1234/") - ''; -}) + nodes.machine = + { pkgs, ... }: + { + services.transfer-sh = { + enable = true; + settings.LISTENER = ":1234"; + }; + }; + + testScript = '' + machine.wait_for_unit("transfer-sh.service") + machine.wait_for_open_port(1234) + machine.succeed("curl --fail http://localhost:1234/") + ''; + } +) diff --git a/nixos/tests/transmission.nix b/nixos/tests/transmission.nix index 03fc9a421510af..0ddce92e834567 100644 --- a/nixos/tests/transmission.nix +++ b/nixos/tests/transmission.nix @@ -1,24 +1,28 @@ -import ./make-test-python.nix ({ pkgs, transmission, ... }: { - name = "transmission"; - meta = with pkgs.lib.maintainers; { - maintainers = [ coconnor ]; - }; +import ./make-test-python.nix ( + { pkgs, transmission, ... }: + { + name = "transmission"; + meta = with pkgs.lib.maintainers; { + maintainers = [ coconnor ]; + }; - nodes.machine = { ... }: { - imports = [ ../modules/profiles/minimal.nix ]; + nodes.machine = + { ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; - networking.firewall.allowedTCPPorts = [ 9091 ]; + networking.firewall.allowedTCPPorts = [ 9091 ]; - security.apparmor.enable = true; + security.apparmor.enable = true; - services.transmission.enable = true; - services.transmission.package = transmission; - }; + services.transmission.enable = true; + services.transmission.package = transmission; + }; - testScript = - '' + testScript = '' start_all() machine.wait_for_unit("transmission") machine.shutdown() ''; -}) + } +) diff --git a/nixos/tests/trezord.nix b/nixos/tests/trezord.nix index fb60cb4aff1007..d8b85d99f09c46 100644 --- a/nixos/tests/trezord.nix +++ b/nixos/tests/trezord.nix @@ -1,19 +1,27 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "trezord"; - meta = with pkgs.lib; { - maintainers = with maintainers; [ mmahut _1000101 ]; - }; - nodes = { - machine = { ... }: { - services.trezord.enable = true; - services.trezord.emulator.enable = true; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "trezord"; + meta = with pkgs.lib; { + maintainers = with maintainers; [ + mmahut + _1000101 + ]; + }; + nodes = { + machine = + { ... }: + { + services.trezord.enable = true; + services.trezord.emulator.enable = true; + }; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("trezord.service") - machine.wait_for_open_port(21325) - machine.wait_until_succeeds("curl -fL http://localhost:21325/status/ | grep Version") - ''; -}) + testScript = '' + start_all() + machine.wait_for_unit("trezord.service") + machine.wait_for_open_port(21325) + machine.wait_until_succeeds("curl -fL http://localhost:21325/status/ | grep Version") + ''; + } +) diff --git a/nixos/tests/trickster.nix b/nixos/tests/trickster.nix index acb2e735c39f85..97ee1855496e4d 100644 --- a/nixos/tests/trickster.nix +++ b/nixos/tests/trickster.nix @@ -1,37 +1,44 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "trickster"; - meta = with pkgs.lib; { - maintainers = with maintainers; [ _1000101 ]; - }; - - nodes = { - prometheus = { ... }: { - services.prometheus.enable = true; - networking.firewall.allowedTCPPorts = [ 9090 ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "trickster"; + meta = with pkgs.lib; { + maintainers = with maintainers; [ _1000101 ]; }; - trickster = { ... }: { - services.trickster.enable = true; + + nodes = { + prometheus = + { ... }: + { + services.prometheus.enable = true; + networking.firewall.allowedTCPPorts = [ 9090 ]; + }; + trickster = + { ... }: + { + services.trickster.enable = true; + }; }; - }; - testScript = '' - start_all() - prometheus.wait_for_unit("prometheus.service") - prometheus.wait_for_open_port(9090) - prometheus.wait_until_succeeds( - "curl -fL http://localhost:9090/metrics | grep 'promhttp_metric_handler_requests_total{code=\"500\"} 0'" - ) - trickster.wait_for_unit("trickster.service") - trickster.wait_for_open_port(8082) - trickster.wait_for_open_port(9090) - trickster.wait_until_succeeds( - "curl -fL http://localhost:8082/metrics | grep 'promhttp_metric_handler_requests_total{code=\"500\"} 0'" - ) - trickster.wait_until_succeeds( - "curl -fL http://prometheus:9090/metrics | grep 'promhttp_metric_handler_requests_total{code=\"500\"} 0'" - ) - trickster.wait_until_succeeds( - "curl -fL http://localhost:9090/metrics | grep 'promhttp_metric_handler_requests_total{code=\"500\"} 0'" - ) - ''; -}) + testScript = '' + start_all() + prometheus.wait_for_unit("prometheus.service") + prometheus.wait_for_open_port(9090) + prometheus.wait_until_succeeds( + "curl -fL http://localhost:9090/metrics | grep 'promhttp_metric_handler_requests_total{code=\"500\"} 0'" + ) + trickster.wait_for_unit("trickster.service") + trickster.wait_for_open_port(8082) + trickster.wait_for_open_port(9090) + trickster.wait_until_succeeds( + "curl -fL http://localhost:8082/metrics | grep 'promhttp_metric_handler_requests_total{code=\"500\"} 0'" + ) + trickster.wait_until_succeeds( + "curl -fL http://prometheus:9090/metrics | grep 'promhttp_metric_handler_requests_total{code=\"500\"} 0'" + ) + trickster.wait_until_succeeds( + "curl -fL http://localhost:9090/metrics | grep 'promhttp_metric_handler_requests_total{code=\"500\"} 0'" + ) + ''; + } +) diff --git a/nixos/tests/trilium-server.nix b/nixos/tests/trilium-server.nix index 6346575b33da6b..e20e38610220af 100644 --- a/nixos/tests/trilium-server.nix +++ b/nixos/tests/trilium-server.nix @@ -1,27 +1,28 @@ -import ./make-test-python.nix ({ ... }: { - name = "trilium-server"; - nodes = { - default = { - services.trilium-server.enable = true; - }; - configured = { - services.trilium-server = { - enable = true; - dataDir = "/data/trilium"; +import ./make-test-python.nix ( + { ... }: + { + name = "trilium-server"; + nodes = { + default = { + services.trilium-server.enable = true; + }; + configured = { + services.trilium-server = { + enable = true; + dataDir = "/data/trilium"; + }; }; - }; - nginx = { - services.trilium-server = { - enable = true; - nginx.enable = true; - nginx.hostName = "trilium.example.com"; + nginx = { + services.trilium-server = { + enable = true; + nginx.enable = true; + nginx.hostName = "trilium.example.com"; + }; }; }; - }; - testScript = - '' + testScript = '' start_all() with subtest("by default works without configuration"): @@ -50,4 +51,5 @@ import ./make-test-python.nix ({ ... }: { "curl --resolve 'trilium.example.com:80:127.0.0.1' http://trilium.example.com/" ) ''; -}) + } +) diff --git a/nixos/tests/tsm-client-gui.nix b/nixos/tests/tsm-client-gui.nix index ca10cddc411fa0..edae66f6702886 100644 --- a/nixos/tests/tsm-client-gui.nix +++ b/nixos/tests/tsm-client-gui.nix @@ -5,53 +5,58 @@ # to show its main application window # and verifies some configuration information. -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "tsm-client"; - - enableOCR = true; - - nodes.machine = { pkgs, ... }: { - imports = [ ./common/x11.nix ]; - programs.tsmClient = { - enable = true; - package = pkgs.tsm-client-withGui; - defaultServername = "testserver"; - servers.testserver = { - # 192.0.0.8 is a "dummy address" according to RFC 7600 - tcpserveraddress = "192.0.0.8"; - nodename = "SOME-NODE"; - passworddir = "/tmp"; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "tsm-client"; + + enableOCR = true; + + nodes.machine = + { pkgs, ... }: + { + imports = [ ./common/x11.nix ]; + programs.tsmClient = { + enable = true; + package = pkgs.tsm-client-withGui; + defaultServername = "testserver"; + servers.testserver = { + # 192.0.0.8 is a "dummy address" according to RFC 7600 + tcpserveraddress = "192.0.0.8"; + nodename = "SOME-NODE"; + passworddir = "/tmp"; + }; + }; }; - }; - }; - - testScript = '' - machine.succeed("which dsmj") # fail early if this is missing - machine.wait_for_x() - machine.execute("DSM_LOG=/tmp dsmj -optfile=/dev/null >&2 &") - - # does it report the "TCP/IP connection failure" error code? - machine.wait_for_window("IBM Storage Protect") - machine.wait_for_text("ANS2610S") - machine.send_key("esc") - - # it asks to continue to restore a local backupset now; - # "yes" (return) leads to the main application window - machine.wait_for_text("backupset") - machine.send_key("ret") - - # main window: navigate to "Connection Information" - machine.wait_for_text("Welcome") - machine.send_key("alt-f") # "File" menu - machine.send_key("c") # "Connection Information" - - # "Connection Information" dialog box - machine.wait_for_window("Connection Information") - machine.wait_for_text("SOME-NODE") - machine.wait_for_text("${pkgs.tsm-client.passthru.unwrapped.version}") - - machine.shutdown() - ''; - - meta.maintainers = [ lib.maintainers.yarny ]; -}) + + testScript = '' + machine.succeed("which dsmj") # fail early if this is missing + machine.wait_for_x() + machine.execute("DSM_LOG=/tmp dsmj -optfile=/dev/null >&2 &") + + # does it report the "TCP/IP connection failure" error code? + machine.wait_for_window("IBM Storage Protect") + machine.wait_for_text("ANS2610S") + machine.send_key("esc") + + # it asks to continue to restore a local backupset now; + # "yes" (return) leads to the main application window + machine.wait_for_text("backupset") + machine.send_key("ret") + + # main window: navigate to "Connection Information" + machine.wait_for_text("Welcome") + machine.send_key("alt-f") # "File" menu + machine.send_key("c") # "Connection Information" + + # "Connection Information" dialog box + machine.wait_for_window("Connection Information") + machine.wait_for_text("SOME-NODE") + machine.wait_for_text("${pkgs.tsm-client.passthru.unwrapped.version}") + + machine.shutdown() + ''; + + meta.maintainers = [ lib.maintainers.yarny ]; + } +) diff --git a/nixos/tests/tuptime.nix b/nixos/tests/tuptime.nix index 93410de7bdf522..a879781c55c0e2 100644 --- a/nixos/tests/tuptime.nix +++ b/nixos/tests/tuptime.nix @@ -1,16 +1,19 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "tuptime"; - meta = with pkgs.lib.maintainers; { - maintainers = [ evils ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "tuptime"; + meta = with pkgs.lib.maintainers; { + maintainers = [ evils ]; + }; - nodes.machine = { pkgs, ... }: { - imports = [ ../modules/profiles/minimal.nix ]; - services.tuptime.enable = true; - }; + nodes.machine = + { pkgs, ... }: + { + imports = [ ../modules/profiles/minimal.nix ]; + services.tuptime.enable = true; + }; - testScript = - '' + testScript = '' # see if it starts start_all() machine.wait_for_unit("multi-user.target") @@ -25,5 +28,5 @@ import ./make-test-python.nix ({ pkgs, ...} : { machine.succeed("tuptime | grep 'System shutdowns:[[:blank:]]*1 ok'") machine.shutdown() ''; -}) - + } +) diff --git a/nixos/tests/turbovnc-headless-server.nix b/nixos/tests/turbovnc-headless-server.nix index c4384a4fc95c91..f51968e29b294e 100644 --- a/nixos/tests/turbovnc-headless-server.nix +++ b/nixos/tests/turbovnc-headless-server.nix @@ -1,175 +1,180 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "turbovnc-headless-server"; - meta = { - maintainers = with lib.maintainers; [ nh2 ]; - }; - - nodes.machine = { pkgs, ... }: { - - environment.systemPackages = with pkgs; [ - mesa-demos - procps # for `pkill`, `pidof` in the test - scrot # for screenshotting Xorg - turbovnc - ]; - - programs.turbovnc.ensureHeadlessSoftwareOpenGL = true; - - networking.firewall = { - # Reject instead of drop, for failures instead of hangs. - rejectPackets = true; - allowedTCPPorts = [ - 5900 # VNC :0, for seeing what's going on in the server - ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "turbovnc-headless-server"; + meta = { + maintainers = with lib.maintainers; [ nh2 ]; }; - # So that we can ssh into the VM, see e.g. - # https://nixos.org/manual/nixos/stable/#sec-nixos-test-port-forwarding - services.openssh.enable = true; - users.mutableUsers = false; - # `test-instrumentation.nix` already sets an empty root password. - # The following have to all be set to allow an empty SSH login password. - services.openssh.settings.PermitRootLogin = "yes"; - services.openssh.settings.PermitEmptyPasswords = "yes"; - security.pam.services.sshd.allowNullPassword = true; # the default `UsePam yes` makes this necessary - }; - - testScript = '' - def wait_until_terminated_or_succeeds( - termination_check_shell_command, - success_check_shell_command, - get_detail_message_fn, - retries=60, - retry_sleep=0.5, - ): - def check_success(): - command_exit_code, _output = machine.execute(success_check_shell_command) - return command_exit_code == 0 - - for _ in range(retries): - exit_check_exit_code, _output = machine.execute(termination_check_shell_command) - is_terminated = exit_check_exit_code != 0 - if is_terminated: - if check_success(): - return - else: - details = get_detail_message_fn() - raise Exception( - f"termination check ({termination_check_shell_command}) triggered without command succeeding ({success_check_shell_command}); details: {details}" - ) - else: - if check_success(): - return - import time - time.sleep(retry_sleep) - - if not check_success(): - details = get_detail_message_fn() - raise Exception( - f"action timed out ({success_check_shell_command}); details: {details}" - ) - - - # Below we use the pattern: - # (cmd | tee stdout.log) 3>&1 1>&2 2>&3 | tee stderr.log - # to capture both stderr and stdout while also teeing them, see: - # https://unix.stackexchange.com/questions/6430/how-to-redirect-stderr-and-stdout-to-different-files-and-also-display-in-termina/6431#6431 - - - # Starts headless VNC server, backgrounding it. - def start_xvnc(): - xvnc_command = " ".join( - [ - "Xvnc", - ":0", - "-iglx", - "-auth /root/.Xauthority", - "-geometry 1240x900", - "-depth 24", - "-rfbwait 5000", - "-deferupdate 1", - "-verbose", - "-securitytypes none", - # We don't enforce localhost listening such that we - # can connect from outside the VM using - # env QEMU_NET_OPTS=hostfwd=tcp::5900-:5900 $(nix-build nixos/tests/turbovnc-headless-server.nix -A driver)/bin/nixos-test-driver - # for testing purposes, and so that we can in the future - # add another test case that connects the TurboVNC client. - # "-localhost", - ] - ) - machine.execute( - # Note trailing & for backgrounding. - f"({xvnc_command} | tee /tmp/Xvnc.stdout) 3>&1 1>&2 2>&3 | tee /tmp/Xvnc.stderr >&2 &", - ) - - - # Waits until the server log message that tells us that GLX is ready - # (requires `-verbose` above), avoiding screenshoting racing below. - def wait_until_xvnc_glx_ready(): - machine.wait_until_succeeds("test -f /tmp/Xvnc.stderr") - wait_until_terminated_or_succeeds( - termination_check_shell_command="pidof Xvnc", - success_check_shell_command="grep 'GLX: Initialized DRISWRAST' /tmp/Xvnc.stderr", - get_detail_message_fn=lambda: "Contents of /tmp/Xvnc.stderr:\n" - + machine.succeed("cat /tmp/Xvnc.stderr"), - ) - - - # Checks that we detect glxgears failing when - # `LIBGL_DRIVERS_PATH=/nonexistent` is set - # (in which case software rendering should not work). - def test_glxgears_failing_with_bad_driver_path(): - machine.execute( - # Note trailing & for backgrounding. - "(env DISPLAY=:0 LIBGL_DRIVERS_PATH=/nonexistent glxgears -info | tee /tmp/glxgears-should-fail.stdout) 3>&1 1>&2 2>&3 | tee /tmp/glxgears-should-fail.stderr >&2 &" - ) - machine.wait_until_succeeds("test -f /tmp/glxgears-should-fail.stderr") - wait_until_terminated_or_succeeds( - termination_check_shell_command="pidof glxgears", - success_check_shell_command="grep 'MESA-LOADER: failed to open swrast' /tmp/glxgears-should-fail.stderr", - get_detail_message_fn=lambda: "Contents of /tmp/glxgears-should-fail.stderr:\n" - + machine.succeed("cat /tmp/glxgears-should-fail.stderr"), - ) - machine.wait_until_fails("pidof glxgears") - - - # Starts glxgears, backgrounding it. Waits until it prints the `GL_RENDERER`. - # Does not quit glxgears. - def test_glxgears_prints_renderer(): - machine.execute( - # Note trailing & for backgrounding. - "(env DISPLAY=:0 glxgears -info | tee /tmp/glxgears.stdout) 3>&1 1>&2 2>&3 | tee /tmp/glxgears.stderr >&2 &" - ) - machine.wait_until_succeeds("test -f /tmp/glxgears.stderr") - wait_until_terminated_or_succeeds( - termination_check_shell_command="pidof glxgears", - success_check_shell_command="grep 'GL_RENDERER' /tmp/glxgears.stdout", - get_detail_message_fn=lambda: "Contents of /tmp/glxgears.stderr:\n" - + machine.succeed("cat /tmp/glxgears.stderr"), - ) - - - with subtest("Start Xvnc"): - start_xvnc() - wait_until_xvnc_glx_ready() - - with subtest("Ensure bad driver path makes glxgears fail"): - test_glxgears_failing_with_bad_driver_path() - - with subtest("Run 3D application (glxgears)"): - test_glxgears_prints_renderer() - - # Take screenshot; should display the glxgears. - machine.succeed("scrot --display :0 /tmp/glxgears.png") - - # Copy files down. - machine.copy_from_vm("/tmp/glxgears.png") - machine.copy_from_vm("/tmp/glxgears.stdout") - machine.copy_from_vm("/tmp/glxgears-should-fail.stdout") - machine.copy_from_vm("/tmp/glxgears-should-fail.stderr") - machine.copy_from_vm("/tmp/Xvnc.stdout") - machine.copy_from_vm("/tmp/Xvnc.stderr") - ''; - -}) + nodes.machine = + { pkgs, ... }: + { + + environment.systemPackages = with pkgs; [ + mesa-demos + procps # for `pkill`, `pidof` in the test + scrot # for screenshotting Xorg + turbovnc + ]; + + programs.turbovnc.ensureHeadlessSoftwareOpenGL = true; + + networking.firewall = { + # Reject instead of drop, for failures instead of hangs. + rejectPackets = true; + allowedTCPPorts = [ + 5900 # VNC :0, for seeing what's going on in the server + ]; + }; + + # So that we can ssh into the VM, see e.g. + # https://nixos.org/manual/nixos/stable/#sec-nixos-test-port-forwarding + services.openssh.enable = true; + users.mutableUsers = false; + # `test-instrumentation.nix` already sets an empty root password. + # The following have to all be set to allow an empty SSH login password. + services.openssh.settings.PermitRootLogin = "yes"; + services.openssh.settings.PermitEmptyPasswords = "yes"; + security.pam.services.sshd.allowNullPassword = true; # the default `UsePam yes` makes this necessary + }; + + testScript = '' + def wait_until_terminated_or_succeeds( + termination_check_shell_command, + success_check_shell_command, + get_detail_message_fn, + retries=60, + retry_sleep=0.5, + ): + def check_success(): + command_exit_code, _output = machine.execute(success_check_shell_command) + return command_exit_code == 0 + + for _ in range(retries): + exit_check_exit_code, _output = machine.execute(termination_check_shell_command) + is_terminated = exit_check_exit_code != 0 + if is_terminated: + if check_success(): + return + else: + details = get_detail_message_fn() + raise Exception( + f"termination check ({termination_check_shell_command}) triggered without command succeeding ({success_check_shell_command}); details: {details}" + ) + else: + if check_success(): + return + import time + time.sleep(retry_sleep) + + if not check_success(): + details = get_detail_message_fn() + raise Exception( + f"action timed out ({success_check_shell_command}); details: {details}" + ) + + + # Below we use the pattern: + # (cmd | tee stdout.log) 3>&1 1>&2 2>&3 | tee stderr.log + # to capture both stderr and stdout while also teeing them, see: + # https://unix.stackexchange.com/questions/6430/how-to-redirect-stderr-and-stdout-to-different-files-and-also-display-in-termina/6431#6431 + + + # Starts headless VNC server, backgrounding it. + def start_xvnc(): + xvnc_command = " ".join( + [ + "Xvnc", + ":0", + "-iglx", + "-auth /root/.Xauthority", + "-geometry 1240x900", + "-depth 24", + "-rfbwait 5000", + "-deferupdate 1", + "-verbose", + "-securitytypes none", + # We don't enforce localhost listening such that we + # can connect from outside the VM using + # env QEMU_NET_OPTS=hostfwd=tcp::5900-:5900 $(nix-build nixos/tests/turbovnc-headless-server.nix -A driver)/bin/nixos-test-driver + # for testing purposes, and so that we can in the future + # add another test case that connects the TurboVNC client. + # "-localhost", + ] + ) + machine.execute( + # Note trailing & for backgrounding. + f"({xvnc_command} | tee /tmp/Xvnc.stdout) 3>&1 1>&2 2>&3 | tee /tmp/Xvnc.stderr >&2 &", + ) + + + # Waits until the server log message that tells us that GLX is ready + # (requires `-verbose` above), avoiding screenshoting racing below. + def wait_until_xvnc_glx_ready(): + machine.wait_until_succeeds("test -f /tmp/Xvnc.stderr") + wait_until_terminated_or_succeeds( + termination_check_shell_command="pidof Xvnc", + success_check_shell_command="grep 'GLX: Initialized DRISWRAST' /tmp/Xvnc.stderr", + get_detail_message_fn=lambda: "Contents of /tmp/Xvnc.stderr:\n" + + machine.succeed("cat /tmp/Xvnc.stderr"), + ) + + + # Checks that we detect glxgears failing when + # `LIBGL_DRIVERS_PATH=/nonexistent` is set + # (in which case software rendering should not work). + def test_glxgears_failing_with_bad_driver_path(): + machine.execute( + # Note trailing & for backgrounding. + "(env DISPLAY=:0 LIBGL_DRIVERS_PATH=/nonexistent glxgears -info | tee /tmp/glxgears-should-fail.stdout) 3>&1 1>&2 2>&3 | tee /tmp/glxgears-should-fail.stderr >&2 &" + ) + machine.wait_until_succeeds("test -f /tmp/glxgears-should-fail.stderr") + wait_until_terminated_or_succeeds( + termination_check_shell_command="pidof glxgears", + success_check_shell_command="grep 'MESA-LOADER: failed to open swrast' /tmp/glxgears-should-fail.stderr", + get_detail_message_fn=lambda: "Contents of /tmp/glxgears-should-fail.stderr:\n" + + machine.succeed("cat /tmp/glxgears-should-fail.stderr"), + ) + machine.wait_until_fails("pidof glxgears") + + + # Starts glxgears, backgrounding it. Waits until it prints the `GL_RENDERER`. + # Does not quit glxgears. + def test_glxgears_prints_renderer(): + machine.execute( + # Note trailing & for backgrounding. + "(env DISPLAY=:0 glxgears -info | tee /tmp/glxgears.stdout) 3>&1 1>&2 2>&3 | tee /tmp/glxgears.stderr >&2 &" + ) + machine.wait_until_succeeds("test -f /tmp/glxgears.stderr") + wait_until_terminated_or_succeeds( + termination_check_shell_command="pidof glxgears", + success_check_shell_command="grep 'GL_RENDERER' /tmp/glxgears.stdout", + get_detail_message_fn=lambda: "Contents of /tmp/glxgears.stderr:\n" + + machine.succeed("cat /tmp/glxgears.stderr"), + ) + + + with subtest("Start Xvnc"): + start_xvnc() + wait_until_xvnc_glx_ready() + + with subtest("Ensure bad driver path makes glxgears fail"): + test_glxgears_failing_with_bad_driver_path() + + with subtest("Run 3D application (glxgears)"): + test_glxgears_prints_renderer() + + # Take screenshot; should display the glxgears. + machine.succeed("scrot --display :0 /tmp/glxgears.png") + + # Copy files down. + machine.copy_from_vm("/tmp/glxgears.png") + machine.copy_from_vm("/tmp/glxgears.stdout") + machine.copy_from_vm("/tmp/glxgears-should-fail.stdout") + machine.copy_from_vm("/tmp/glxgears-should-fail.stderr") + machine.copy_from_vm("/tmp/Xvnc.stdout") + machine.copy_from_vm("/tmp/Xvnc.stderr") + ''; + + } +) diff --git a/nixos/tests/tuxguitar.nix b/nixos/tests/tuxguitar.nix index 00833024bfeacc..e491f96a89ce90 100644 --- a/nixos/tests/tuxguitar.nix +++ b/nixos/tests/tuxguitar.nix @@ -1,24 +1,29 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "tuxguitar"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "tuxguitar"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; - nodes.machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + nodes.machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; + services.xserver.enable = true; - environment.systemPackages = [ pkgs.tuxguitar ]; - }; + environment.systemPackages = [ pkgs.tuxguitar ]; + }; - testScript = '' - machine.wait_for_x() - machine.succeed("tuxguitar >&2 &") - machine.wait_for_window("TuxGuitar - Untitled.tg") - machine.sleep(1) - machine.screenshot("tuxguitar") - ''; -}) + testScript = '' + machine.wait_for_x() + machine.succeed("tuxguitar >&2 &") + machine.wait_for_window("TuxGuitar - Untitled.tg") + machine.sleep(1) + machine.screenshot("tuxguitar") + ''; + } +) diff --git a/nixos/tests/twingate.nix b/nixos/tests/twingate.nix index f8bede09d9f262..095b8e380b07d8 100644 --- a/nixos/tests/twingate.nix +++ b/nixos/tests/twingate.nix @@ -3,12 +3,14 @@ nodes.machine.services.twingate.enable = true; - testScript = { nodes, ... }: '' - machine.wait_for_unit("twingate.service") - machine.succeed("twingate --version | grep '${nodes.machine.services.twingate.package.version}' >&2") - machine.succeed("twingate config log-level 'debug'") - machine.systemctl("restart twingate.service") - machine.succeed("grep 'debug' /etc/twingate/log_level.conf >&2") - machine.succeed("twingate config log-level | grep 'debug' >&2") - ''; + testScript = + { nodes, ... }: + '' + machine.wait_for_unit("twingate.service") + machine.succeed("twingate --version | grep '${nodes.machine.services.twingate.package.version}' >&2") + machine.succeed("twingate config log-level 'debug'") + machine.systemctl("restart twingate.service") + machine.succeed("grep 'debug' /etc/twingate/log_level.conf >&2") + machine.succeed("twingate config log-level | grep 'debug' >&2") + ''; } diff --git a/nixos/tests/txredisapi.nix b/nixos/tests/txredisapi.nix index 47c2ba6d3749ad..ecfb79ea13d7aa 100644 --- a/nixos/tests/txredisapi.nix +++ b/nixos/tests/txredisapi.nix @@ -1,29 +1,40 @@ -import ./make-test-python.nix ({ pkgs, ... }: -{ - name = "txredisapi"; - meta = with pkgs.lib.maintainers; { - maintainers = [ dandellion ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "txredisapi"; + meta = with pkgs.lib.maintainers; { + maintainers = [ dandellion ]; + }; - nodes = { - machine = - { pkgs, ... }: + nodes = { + machine = + { pkgs, ... }: - { - services.redis.servers."".enable = true; + { + services.redis.servers."".enable = true; - environment.systemPackages = with pkgs; [ (python3.withPackages (ps: [ ps.twisted ps.txredisapi ps.mock ]))]; - }; - }; + environment.systemPackages = with pkgs; [ + (python3.withPackages (ps: [ + ps.twisted + ps.txredisapi + ps.mock + ])) + ]; + }; + }; - testScript = { nodes, ... }: let - inherit (nodes.machine.config.services) redis; - in '' - start_all() - machine.wait_for_unit("redis") - machine.wait_for_file("${redis.servers."".unixSocket}") - machine.succeed("ln -s ${redis.servers."".unixSocket} /tmp/redis.sock") + testScript = + { nodes, ... }: + let + inherit (nodes.machine.config.services) redis; + in + '' + start_all() + machine.wait_for_unit("redis") + machine.wait_for_file("${redis.servers."".unixSocket}") + machine.succeed("ln -s ${redis.servers."".unixSocket} /tmp/redis.sock") - tests = machine.succeed("PYTHONPATH=\"${pkgs.python3Packages.txredisapi.src}\" python -m twisted.trial ${pkgs.python3Packages.txredisapi.src}/tests") - ''; -}) + tests = machine.succeed("PYTHONPATH=\"${pkgs.python3Packages.txredisapi.src}\" python -m twisted.trial ${pkgs.python3Packages.txredisapi.src}/tests") + ''; + } +) diff --git a/nixos/tests/typesense.nix b/nixos/tests/typesense.nix index 87ed248257ea04..dbd9e4e38a9fba 100644 --- a/nixos/tests/typesense.nix +++ b/nixos/tests/typesense.nix @@ -1,24 +1,30 @@ -import ./make-test-python.nix ({ pkgs, ... }: let - testPort = 8108; -in { - name = "typesense"; - meta.maintainers = with pkgs.lib.maintainers; [ oddlama ]; +import ./make-test-python.nix ( + { pkgs, ... }: + let + testPort = 8108; + in + { + name = "typesense"; + meta.maintainers = with pkgs.lib.maintainers; [ oddlama ]; - nodes.machine = { ... }: { - services.typesense = { - enable = true; - apiKeyFile = pkgs.writeText "typesense-api-key" "dummy"; - settings.server = { - api-port = testPort; - api-address = "0.0.0.0"; + nodes.machine = + { ... }: + { + services.typesense = { + enable = true; + apiKeyFile = pkgs.writeText "typesense-api-key" "dummy"; + settings.server = { + api-port = testPort; + api-address = "0.0.0.0"; + }; + }; }; - }; - }; - testScript = '' - machine.wait_for_unit("typesense.service") - machine.wait_for_open_port(${toString testPort}) - # After waiting for the port, typesense still hasn't initialized the database, so wait until we can connect successfully - assert machine.wait_until_succeeds("curl --fail http://localhost:${toString testPort}/health") == '{"ok":true}' - ''; -}) + testScript = '' + machine.wait_for_unit("typesense.service") + machine.wait_for_open_port(${toString testPort}) + # After waiting for the port, typesense still hasn't initialized the database, so wait until we can connect successfully + assert machine.wait_until_succeeds("curl --fail http://localhost:${toString testPort}/health") == '{"ok":true}' + ''; + } +) diff --git a/nixos/tests/ucarp.nix b/nixos/tests/ucarp.nix index 1f60f770d3a8a4..ec24d49e95a9df 100644 --- a/nixos/tests/ucarp.nix +++ b/nixos/tests/ucarp.nix @@ -1,66 +1,80 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : +import ./make-test-python.nix ( + { pkgs, lib, ... }: -let - addrShared = "192.168.0.1"; - addrHostA = "192.168.0.10"; - addrHostB = "192.168.0.11"; + let + addrShared = "192.168.0.1"; + addrHostA = "192.168.0.10"; + addrHostB = "192.168.0.11"; - mkUcarpHost = addr: { config, pkgs, lib, ... }: { - networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ - { address = addr; prefixLength = 24; } - ]; + mkUcarpHost = + addr: + { + config, + pkgs, + lib, + ... + }: + { + networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ + { + address = addr; + prefixLength = 24; + } + ]; - networking.ucarp = { - enable = true; - interface = "eth1"; - srcIp = addr; - vhId = 1; - passwordFile = "${pkgs.writeText "ucarp-pass" "secure"}"; - addr = addrShared; - upscript = pkgs.writeScript "upscript" '' - #!/bin/sh - ${pkgs.iproute2}/bin/ip addr add "$2"/24 dev "$1" - ''; - downscript = pkgs.writeScript "downscript" '' - #!/bin/sh - ${pkgs.iproute2}/bin/ip addr del "$2"/24 dev "$1" - ''; - }; - }; -in { - name = "ucarp"; - meta.maintainers = with lib.maintainers; [ oxzi ]; + networking.ucarp = { + enable = true; + interface = "eth1"; + srcIp = addr; + vhId = 1; + passwordFile = "${pkgs.writeText "ucarp-pass" "secure"}"; + addr = addrShared; + upscript = pkgs.writeScript "upscript" '' + #!/bin/sh + ${pkgs.iproute2}/bin/ip addr add "$2"/24 dev "$1" + ''; + downscript = pkgs.writeScript "downscript" '' + #!/bin/sh + ${pkgs.iproute2}/bin/ip addr del "$2"/24 dev "$1" + ''; + }; + }; + in + { + name = "ucarp"; + meta.maintainers = with lib.maintainers; [ oxzi ]; - nodes = { - hostA = mkUcarpHost addrHostA; - hostB = mkUcarpHost addrHostB; - }; + nodes = { + hostA = mkUcarpHost addrHostA; + hostB = mkUcarpHost addrHostB; + }; - testScript = '' - def is_master(host): - ipOutput = host.succeed("ip addr show dev eth1") - return "inet ${addrShared}/24" in ipOutput + testScript = '' + def is_master(host): + ipOutput = host.succeed("ip addr show dev eth1") + return "inet ${addrShared}/24" in ipOutput - start_all() + start_all() - # First, let both hosts start and let a master node be selected - for host, peer in [(hostA, "${addrHostB}"), (hostB, "${addrHostA}")]: - host.wait_for_unit("ucarp.service") - host.succeed(f"ping -c 1 {peer}") + # First, let both hosts start and let a master node be selected + for host, peer in [(hostA, "${addrHostB}"), (hostB, "${addrHostA}")]: + host.wait_for_unit("ucarp.service") + host.succeed(f"ping -c 1 {peer}") - hostA.sleep(5) + hostA.sleep(5) - hostA_master, hostB_master = is_master(hostA), is_master(hostB) - assert hostA_master != hostB_master, "only one master node is allowed" + hostA_master, hostB_master = is_master(hostA), is_master(hostB) + assert hostA_master != hostB_master, "only one master node is allowed" - master_host = hostA if hostA_master else hostB - backup_host = hostB if hostA_master else hostA + master_host = hostA if hostA_master else hostB + backup_host = hostB if hostA_master else hostA - # Let's crash the master host and let the backup take over - master_host.crash() + # Let's crash the master host and let the backup take over + master_host.crash() - backup_host.sleep(5) - assert is_master(backup_host), "backup did not take over" - ''; -}) + backup_host.sleep(5) + assert is_master(backup_host), "backup did not take over" + ''; + } +) diff --git a/nixos/tests/udisks2.nix b/nixos/tests/udisks2.nix index b934f0b951562b..3800a53ef196cd 100644 --- a/nixos/tests/udisks2.nix +++ b/nixos/tests/udisks2.nix @@ -1,36 +1,36 @@ -import ./make-test-python.nix ({ pkgs, ... }: +import ./make-test-python.nix ( + { pkgs, ... }: -let + let - # FIXME: 404s - stick = pkgs.fetchurl { - url = "https://nixos.org/~eelco/nix/udisks-test.img.xz"; - sha256 = "0was1xgjkjad91nipzclaz5biv3m4b2nk029ga6nk7iklwi19l8b"; - }; + # FIXME: 404s + stick = pkgs.fetchurl { + url = "https://nixos.org/~eelco/nix/udisks-test.img.xz"; + sha256 = "0was1xgjkjad91nipzclaz5biv3m4b2nk029ga6nk7iklwi19l8b"; + }; -in + in -{ - name = "udisks2"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; + { + name = "udisks2"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; + }; - nodes.machine = - { ... }: - { services.udisks2.enable = true; - imports = [ ./common/user-account.nix ]; + nodes.machine = + { ... }: + { + services.udisks2.enable = true; + imports = [ ./common/user-account.nix ]; - security.polkit.extraConfig = - '' + security.polkit.extraConfig = '' polkit.addRule(function(action, subject) { if (subject.user == "alice") return "yes"; }); ''; - }; + }; - testScript = - '' + testScript = '' import lzma machine.systemctl("start udisks2") @@ -70,4 +70,5 @@ in machine.fail("[ -e /dev/sda ]") ''; -}) + } +) diff --git a/nixos/tests/ulogd/ulogd.nix b/nixos/tests/ulogd/ulogd.nix index 0fa92229a10054..9146ec44561df6 100644 --- a/nixos/tests/ulogd/ulogd.nix +++ b/nixos/tests/ulogd/ulogd.nix @@ -1,56 +1,61 @@ -import ../make-test-python.nix ({ pkgs, lib, ... }: { - name = "ulogd"; - - meta.maintainers = with lib.maintainers; [ p-h ]; - - nodes.machine = { ... }: { - networking.firewall.enable = false; - networking.nftables.enable = true; - networking.nftables.ruleset = '' - table inet filter { - chain input { - type filter hook input priority 0; - icmp type { echo-request, echo-reply } log group 2 accept - } - - chain output { - type filter hook output priority 0; policy accept; - icmp type { echo-request, echo-reply } log group 2 accept - } - - chain forward { - type filter hook forward priority 0; policy drop; - } - - } - ''; - services.ulogd = { - enable = true; - settings = { - global = { - logfile = "/var/log/ulogd.log"; - stack = [ - "log1:NFLOG,base1:BASE,ifi1:IFINDEX,ip2str1:IP2STR,print1:PRINTPKT,emu1:LOGEMU" - "log1:NFLOG,base1:BASE,pcap1:PCAP" - ]; +import ../make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "ulogd"; + + meta.maintainers = with lib.maintainers; [ p-h ]; + + nodes.machine = + { ... }: + { + networking.firewall.enable = false; + networking.nftables.enable = true; + networking.nftables.ruleset = '' + table inet filter { + chain input { + type filter hook input priority 0; + icmp type { echo-request, echo-reply } log group 2 accept + } + + chain output { + type filter hook output priority 0; policy accept; + icmp type { echo-request, echo-reply } log group 2 accept + } + + chain forward { + type filter hook forward priority 0; policy drop; + } + + } + ''; + services.ulogd = { + enable = true; + settings = { + global = { + logfile = "/var/log/ulogd.log"; + stack = [ + "log1:NFLOG,base1:BASE,ifi1:IFINDEX,ip2str1:IP2STR,print1:PRINTPKT,emu1:LOGEMU" + "log1:NFLOG,base1:BASE,pcap1:PCAP" + ]; + }; + + log1.group = 2; + + pcap1 = { + sync = 1; + file = "/var/log/ulogd.pcap"; + }; + + emu1 = { + sync = 1; + file = "/var/log/ulogd_pkts.log"; + }; + }; }; - log1.group = 2; - - pcap1 = { - sync = 1; - file = "/var/log/ulogd.pcap"; - }; - - emu1 = { - sync = 1; - file = "/var/log/ulogd_pkts.log"; - }; + environment.systemPackages = with pkgs; [ tcpdump ]; }; - }; - - environment.systemPackages = with pkgs; [ tcpdump ]; - }; - testScript = lib.readFile ./ulogd.py; -}) + testScript = lib.readFile ./ulogd.py; + } +) diff --git a/nixos/tests/unbound.nix b/nixos/tests/unbound.nix index 39a01259edeb5b..0aa3a6a0c16f39 100644 --- a/nixos/tests/unbound.nix +++ b/nixos/tests/unbound.nix @@ -1,37 +1,40 @@ /* - Test that our unbound module indeed works as most users would expect. - There are a few settings that we must consider when modifying the test. The - usual use-cases for unbound are - * running a recursive DNS resolver on the local machine - * running a recursive DNS resolver on the local machine, forwarding to a local DNS server via UDP/53 & TCP/53 - * running a recursive DNS resolver on the local machine, forwarding to a local DNS server via TCP/853 (DoT) - * running a recursive DNS resolver on a machine in the network awaiting input from clients over TCP/53 & UDP/53 - * running a recursive DNS resolver on a machine in the network awaiting input from clients over TCP/853 (DoT) - - In the below test setup we are trying to implement all of those use cases. - - Another aspect that we cover is access to the local control UNIX socket. It - can optionally be enabled and users can optionally be in a group to gain - access. Users that are not in the group (except for root) should not have - access to that socket. Also, when there is no socket configured, users - shouldn't be able to access the control socket at all. Not even root. + Test that our unbound module indeed works as most users would expect. + There are a few settings that we must consider when modifying the test. The + usual use-cases for unbound are + * running a recursive DNS resolver on the local machine + * running a recursive DNS resolver on the local machine, forwarding to a local DNS server via UDP/53 & TCP/53 + * running a recursive DNS resolver on the local machine, forwarding to a local DNS server via TCP/853 (DoT) + * running a recursive DNS resolver on a machine in the network awaiting input from clients over TCP/53 & UDP/53 + * running a recursive DNS resolver on a machine in the network awaiting input from clients over TCP/853 (DoT) + + In the below test setup we are trying to implement all of those use cases. + + Another aspect that we cover is access to the local control UNIX socket. It + can optionally be enabled and users can optionally be in a group to gain + access. Users that are not in the group (except for root) should not have + access to that socket. Also, when there is no socket configured, users + shouldn't be able to access the control socket at all. Not even root. */ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: let # common client configuration that we can just use for the multitude of # clients we are constructing - common = { lib, pkgs, ... }: { - config = { - environment.systemPackages = [ pkgs.knot-dns ]; - - # disable the root anchor update as we do not have internet access during - # the test execution - services.unbound.enableRootTrustAnchor = false; - - # we want to test the full-variant of the package to also get DoH support - services.unbound.package = pkgs.unbound-full; + common = + { lib, pkgs, ... }: + { + config = { + environment.systemPackages = [ pkgs.knot-dns ]; + + # disable the root anchor update as we do not have internet access during + # the test execution + services.unbound.enableRootTrustAnchor = false; + + # we want to test the full-variant of the package to also get DoH support + services.unbound.package = pkgs.unbound-full; + }; }; - }; cert = pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=dns.example.local' @@ -48,268 +51,344 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: nodes = { # The server that actually serves our zones, this tests unbounds authoriative mode - authoritative = { lib, pkgs, config, ... }: { - imports = [ common ]; - networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ - { address = "192.168.0.1"; prefixLength = 24; } - ]; - networking.interfaces.eth1.ipv6.addresses = lib.mkForce [ - { address = "fd21::1"; prefixLength = 64; } - ]; - networking.firewall.allowedTCPPorts = [ 53 ]; - networking.firewall.allowedUDPPorts = [ 53 ]; - - services.unbound = { - enable = true; - settings = { - server = { - interface = [ "192.168.0.1" "fd21::1" "::1" "127.0.0.1" ]; - access-control = [ "192.168.0.0/24 allow" "fd21::/64 allow" "::1 allow" "127.0.0.0/8 allow" ]; - local-data = [ - ''"example.local. IN A 1.2.3.4"'' - ''"example.local. IN AAAA abcd::eeff"'' - ]; + authoritative = + { + lib, + pkgs, + config, + ... + }: + { + imports = [ common ]; + networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ + { + address = "192.168.0.1"; + prefixLength = 24; + } + ]; + networking.interfaces.eth1.ipv6.addresses = lib.mkForce [ + { + address = "fd21::1"; + prefixLength = 64; + } + ]; + networking.firewall.allowedTCPPorts = [ 53 ]; + networking.firewall.allowedUDPPorts = [ 53 ]; + + services.unbound = { + enable = true; + settings = { + server = { + interface = [ + "192.168.0.1" + "fd21::1" + "::1" + "127.0.0.1" + ]; + access-control = [ + "192.168.0.0/24 allow" + "fd21::/64 allow" + "::1 allow" + "127.0.0.0/8 allow" + ]; + local-data = [ + ''"example.local. IN A 1.2.3.4"'' + ''"example.local. IN AAAA abcd::eeff"'' + ]; + }; }; }; }; - }; # The resolver that knows that forwards (only) to the authoritative server # and listens on UDP/53, TCP/53 & TCP/853. - resolver = { lib, nodes, ... }: { - imports = [ common ]; - networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ - { address = "192.168.0.2"; prefixLength = 24; } - ]; - networking.interfaces.eth1.ipv6.addresses = lib.mkForce [ - { address = "fd21::2"; prefixLength = 64; } - ]; - networking.firewall.allowedTCPPorts = [ - 53 # regular DNS - 853 # DNS over TLS - 443 # DNS over HTTPS - ]; - networking.firewall.allowedUDPPorts = [ 53 ]; - - services.unbound = { - enable = true; - settings = { - server = { - interface = [ "::1" "127.0.0.1" "192.168.0.2" "fd21::2" - "192.168.0.2@853" "fd21::2@853" "::1@853" "127.0.0.1@853" - "192.168.0.2@443" "fd21::2@443" "::1@443" "127.0.0.1@443" ]; - access-control = [ "192.168.0.0/24 allow" "fd21::/64 allow" "::1 allow" "127.0.0.0/8 allow" ]; - tls-service-pem = "${cert}/cert.pem"; - tls-service-key = "${cert}/key.pem"; - }; - forward-zone = [ - { - name = "."; - forward-addr = [ - (lib.head nodes.authoritative.networking.interfaces.eth1.ipv6.addresses).address - (lib.head nodes.authoritative.networking.interfaces.eth1.ipv4.addresses).address + resolver = + { lib, nodes, ... }: + { + imports = [ common ]; + networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ + { + address = "192.168.0.2"; + prefixLength = 24; + } + ]; + networking.interfaces.eth1.ipv6.addresses = lib.mkForce [ + { + address = "fd21::2"; + prefixLength = 64; + } + ]; + networking.firewall.allowedTCPPorts = [ + 53 # regular DNS + 853 # DNS over TLS + 443 # DNS over HTTPS + ]; + networking.firewall.allowedUDPPorts = [ 53 ]; + + services.unbound = { + enable = true; + settings = { + server = { + interface = [ + "::1" + "127.0.0.1" + "192.168.0.2" + "fd21::2" + "192.168.0.2@853" + "fd21::2@853" + "::1@853" + "127.0.0.1@853" + "192.168.0.2@443" + "fd21::2@443" + "::1@443" + "127.0.0.1@443" ]; - } - ]; + access-control = [ + "192.168.0.0/24 allow" + "fd21::/64 allow" + "::1 allow" + "127.0.0.0/8 allow" + ]; + tls-service-pem = "${cert}/cert.pem"; + tls-service-key = "${cert}/key.pem"; + }; + forward-zone = [ + { + name = "."; + forward-addr = [ + (lib.head nodes.authoritative.networking.interfaces.eth1.ipv6.addresses).address + (lib.head nodes.authoritative.networking.interfaces.eth1.ipv4.addresses).address + ]; + } + ]; + }; }; }; - }; # machine that runs a local unbound that will be reconfigured during test execution - local_resolver = { lib, nodes, config, ... }: { - imports = [ common ]; - networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ - { address = "192.168.0.3"; prefixLength = 24; } - ]; - networking.interfaces.eth1.ipv6.addresses = lib.mkForce [ - { address = "fd21::3"; prefixLength = 64; } - ]; - networking.firewall.allowedTCPPorts = [ - 53 # regular DNS - ]; - networking.firewall.allowedUDPPorts = [ 53 ]; - - services.unbound = { - enable = true; - settings = { - server = { - interface = [ "::1" "127.0.0.1" ]; - access-control = [ "::1 allow" "127.0.0.0/8 allow" ]; + local_resolver = + { + lib, + nodes, + config, + ... + }: + { + imports = [ common ]; + networking.interfaces.eth1.ipv4.addresses = lib.mkForce [ + { + address = "192.168.0.3"; + prefixLength = 24; + } + ]; + networking.interfaces.eth1.ipv6.addresses = lib.mkForce [ + { + address = "fd21::3"; + prefixLength = 64; + } + ]; + networking.firewall.allowedTCPPorts = [ + 53 # regular DNS + ]; + networking.firewall.allowedUDPPorts = [ 53 ]; + + services.unbound = { + enable = true; + settings = { + server = { + interface = [ + "::1" + "127.0.0.1" + ]; + access-control = [ + "::1 allow" + "127.0.0.0/8 allow" + ]; + }; + include = "/etc/unbound/extra*.conf"; }; - include = "/etc/unbound/extra*.conf"; + localControlSocketPath = "/run/unbound/unbound.ctl"; }; - localControlSocketPath = "/run/unbound/unbound.ctl"; - }; - users.users = { - # user that is permitted to access the unix socket - someuser = { - isSystemUser = true; - group = "someuser"; - extraGroups = [ - config.users.users.unbound.group - ]; - }; + users.users = { + # user that is permitted to access the unix socket + someuser = { + isSystemUser = true; + group = "someuser"; + extraGroups = [ + config.users.users.unbound.group + ]; + }; - # user that is not permitted to access the unix socket - unauthorizeduser = { - isSystemUser = true; - group = "unauthorizeduser"; - }; + # user that is not permitted to access the unix socket + unauthorizeduser = { + isSystemUser = true; + group = "unauthorizeduser"; + }; - }; - users.groups = { - someuser = {}; - unauthorizeduser = {}; - }; + }; + users.groups = { + someuser = { }; + unauthorizeduser = { }; + }; - # Used for testing configuration reloading - environment.etc = { - "unbound-extra1.conf".text = '' - forward-zone: - name: "example.local." - forward-addr: ${(lib.head nodes.resolver.networking.interfaces.eth1.ipv6.addresses).address} - forward-addr: ${(lib.head nodes.resolver.networking.interfaces.eth1.ipv4.addresses).address} - ''; - "unbound-extra2.conf".text = '' - auth-zone: - name: something.local. - zonefile: ${pkgs.writeText "zone" '' - something.local. IN A 3.4.5.6 - ''} - ''; + # Used for testing configuration reloading + environment.etc = { + "unbound-extra1.conf".text = '' + forward-zone: + name: "example.local." + forward-addr: ${(lib.head nodes.resolver.networking.interfaces.eth1.ipv6.addresses).address} + forward-addr: ${(lib.head nodes.resolver.networking.interfaces.eth1.ipv4.addresses).address} + ''; + "unbound-extra2.conf".text = '' + auth-zone: + name: something.local. + zonefile: ${pkgs.writeText "zone" '' + something.local. IN A 3.4.5.6 + ''} + ''; + }; }; - }; - # plain node that only has network access and doesn't run any part of the # resolver software locally - client = { lib, nodes, ... }: { - imports = [ common ]; - networking.nameservers = [ - (lib.head nodes.resolver.networking.interfaces.eth1.ipv6.addresses).address - (lib.head nodes.resolver.networking.interfaces.eth1.ipv4.addresses).address - ]; - networking.interfaces.eth1.ipv4.addresses = [ - { address = "192.168.0.10"; prefixLength = 24; } - ]; - networking.interfaces.eth1.ipv6.addresses = [ - { address = "fd21::10"; prefixLength = 64; } - ]; - }; + client = + { lib, nodes, ... }: + { + imports = [ common ]; + networking.nameservers = [ + (lib.head nodes.resolver.networking.interfaces.eth1.ipv6.addresses).address + (lib.head nodes.resolver.networking.interfaces.eth1.ipv4.addresses).address + ]; + networking.interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.0.10"; + prefixLength = 24; + } + ]; + networking.interfaces.eth1.ipv6.addresses = [ + { + address = "fd21::10"; + prefixLength = 64; + } + ]; + }; }; - testScript = { nodes, ... }: '' - import typing - - zone = "example.local." - records = [("AAAA", "abcd::eeff"), ("A", "1.2.3.4")] - - - def query( - machine, - host: str, - query_type: str, - query: str, - expected: typing.Optional[str] = None, - args: typing.Optional[typing.List[str]] = None, - ): - """ - Execute a single query and compare the result with expectation - """ - text_args = "" - if args: - text_args = " ".join(args) - - out = machine.succeed( - f"kdig {text_args} {query} {query_type} @{host} +short" - ).strip() - machine.log(f"{host} replied with {out}") - if expected: - assert expected == out, f"Expected `{expected}` but got `{out}`" - - - def test(machine, remotes, /, doh=False, zone=zone, records=records, args=[]): - """ - Run queries for the given remotes on the given machine. - """ - for query_type, expected in records: - for remote in remotes: - query(machine, remote, query_type, zone, expected, args) - query(machine, remote, query_type, zone, expected, ["+tcp"] + args) - if doh: - query( - machine, - remote, - query_type, - zone, - expected, - ["+tcp", "+tls"] + args, - ) - query( - machine, - remote, - query_type, - zone, - expected, - ["+https"] + args, - ) - - - client.start() - authoritative.wait_for_unit("unbound.service") - - # verify that we can resolve locally - with subtest("test the authoritative servers local responses"): - test(authoritative, ["::1", "127.0.0.1"]) - - resolver.wait_for_unit("unbound.service") - - with subtest("root is unable to use unbounc-control when the socket is not configured"): - resolver.succeed("which unbound-control") # the binary must exist - resolver.fail("unbound-control list_forwards") # the invocation must fail - - # verify that the resolver is able to resolve on all the local protocols - with subtest("test that the resolver resolves on all protocols and transports"): - test(resolver, ["::1", "127.0.0.1"], doh=True) - - resolver.wait_for_unit("multi-user.target") - - with subtest("client should be able to query the resolver"): - test(client, ["${(lib.head nodes.resolver.networking.interfaces.eth1.ipv6.addresses).address}", "${(lib.head nodes.resolver.networking.interfaces.eth1.ipv4.addresses).address}"], doh=True) - - # discard the client we do not need anymore - client.shutdown() - - local_resolver.wait_for_unit("multi-user.target") - - # link a new config file to /etc/unbound/extra.conf - local_resolver.succeed("ln -s /etc/unbound-extra1.conf /etc/unbound/extra1.conf") - - # reload the server & ensure the forwarding works - with subtest("test that the local resolver resolves on all protocols and transports"): - local_resolver.succeed("systemctl reload unbound") - print(local_resolver.succeed("journalctl -u unbound -n 1000")) - test(local_resolver, ["::1", "127.0.0.1"], args=["+timeout=60"]) - - with subtest("test that we can use the unbound control socket"): - out = local_resolver.succeed( - "sudo -u someuser -- unbound-control list_forwards" - ).strip() - - # Thank you black! Can't really break this line into a readable version. - expected = "example.local. IN forward ${(lib.head nodes.resolver.networking.interfaces.eth1.ipv6.addresses).address} ${(lib.head nodes.resolver.networking.interfaces.eth1.ipv4.addresses).address}" - assert out == expected, f"Expected `{expected}` but got `{out}` instead." - local_resolver.fail("sudo -u unauthorizeduser -- unbound-control list_forwards") - - - # link a new config file to /etc/unbound/extra.conf - local_resolver.succeed("ln -sf /etc/unbound-extra2.conf /etc/unbound/extra2.conf") - - # reload the server & ensure the new local zone works - with subtest("test that we can query the new local zone"): - local_resolver.succeed("unbound-control reload") - r = [("A", "3.4.5.6")] - test(local_resolver, ["::1", "127.0.0.1"], zone="something.local.", records=r) - ''; - }) + testScript = + { nodes, ... }: + '' + import typing + + zone = "example.local." + records = [("AAAA", "abcd::eeff"), ("A", "1.2.3.4")] + + + def query( + machine, + host: str, + query_type: str, + query: str, + expected: typing.Optional[str] = None, + args: typing.Optional[typing.List[str]] = None, + ): + """ + Execute a single query and compare the result with expectation + """ + text_args = "" + if args: + text_args = " ".join(args) + + out = machine.succeed( + f"kdig {text_args} {query} {query_type} @{host} +short" + ).strip() + machine.log(f"{host} replied with {out}") + if expected: + assert expected == out, f"Expected `{expected}` but got `{out}`" + + + def test(machine, remotes, /, doh=False, zone=zone, records=records, args=[]): + """ + Run queries for the given remotes on the given machine. + """ + for query_type, expected in records: + for remote in remotes: + query(machine, remote, query_type, zone, expected, args) + query(machine, remote, query_type, zone, expected, ["+tcp"] + args) + if doh: + query( + machine, + remote, + query_type, + zone, + expected, + ["+tcp", "+tls"] + args, + ) + query( + machine, + remote, + query_type, + zone, + expected, + ["+https"] + args, + ) + + + client.start() + authoritative.wait_for_unit("unbound.service") + + # verify that we can resolve locally + with subtest("test the authoritative servers local responses"): + test(authoritative, ["::1", "127.0.0.1"]) + + resolver.wait_for_unit("unbound.service") + + with subtest("root is unable to use unbounc-control when the socket is not configured"): + resolver.succeed("which unbound-control") # the binary must exist + resolver.fail("unbound-control list_forwards") # the invocation must fail + + # verify that the resolver is able to resolve on all the local protocols + with subtest("test that the resolver resolves on all protocols and transports"): + test(resolver, ["::1", "127.0.0.1"], doh=True) + + resolver.wait_for_unit("multi-user.target") + + with subtest("client should be able to query the resolver"): + test(client, ["${(lib.head nodes.resolver.networking.interfaces.eth1.ipv6.addresses).address}", "${(lib.head nodes.resolver.networking.interfaces.eth1.ipv4.addresses).address}"], doh=True) + + # discard the client we do not need anymore + client.shutdown() + + local_resolver.wait_for_unit("multi-user.target") + + # link a new config file to /etc/unbound/extra.conf + local_resolver.succeed("ln -s /etc/unbound-extra1.conf /etc/unbound/extra1.conf") + + # reload the server & ensure the forwarding works + with subtest("test that the local resolver resolves on all protocols and transports"): + local_resolver.succeed("systemctl reload unbound") + print(local_resolver.succeed("journalctl -u unbound -n 1000")) + test(local_resolver, ["::1", "127.0.0.1"], args=["+timeout=60"]) + + with subtest("test that we can use the unbound control socket"): + out = local_resolver.succeed( + "sudo -u someuser -- unbound-control list_forwards" + ).strip() + + # Thank you black! Can't really break this line into a readable version. + expected = "example.local. IN forward ${(lib.head nodes.resolver.networking.interfaces.eth1.ipv6.addresses).address} ${(lib.head nodes.resolver.networking.interfaces.eth1.ipv4.addresses).address}" + assert out == expected, f"Expected `{expected}` but got `{out}` instead." + local_resolver.fail("sudo -u unauthorizeduser -- unbound-control list_forwards") + + + # link a new config file to /etc/unbound/extra.conf + local_resolver.succeed("ln -sf /etc/unbound-extra2.conf /etc/unbound/extra2.conf") + + # reload the server & ensure the new local zone works + with subtest("test that we can query the new local zone"): + local_resolver.succeed("unbound-control reload") + r = [("A", "3.4.5.6")] + test(local_resolver, ["::1", "127.0.0.1"], zone="something.local.", records=r) + ''; + } +) diff --git a/nixos/tests/upnp.nix b/nixos/tests/upnp.nix index 93bc08f752ce33..1971943b267ce1 100644 --- a/nixos/tests/upnp.nix +++ b/nixos/tests/upnp.nix @@ -5,25 +5,29 @@ # this succeeds an external client will try to connect to the port # mapping. -import ./make-test-python.nix ({ pkgs, useNftables, ... }: +import ./make-test-python.nix ( + { pkgs, useNftables, ... }: -let - internalRouterAddress = "192.168.3.1"; - internalClient1Address = "192.168.3.2"; - externalRouterAddress = "80.100.100.1"; - externalClient2Address = "80.100.100.2"; -in -{ - name = "upnp"; - meta = with pkgs.lib.maintainers; { - maintainers = [ bobvanderlinden ]; - }; + let + internalRouterAddress = "192.168.3.1"; + internalClient1Address = "192.168.3.2"; + externalRouterAddress = "80.100.100.1"; + externalClient2Address = "80.100.100.2"; + in + { + name = "upnp"; + meta = with pkgs.lib.maintainers; { + maintainers = [ bobvanderlinden ]; + }; - nodes = - { + nodes = { router = { pkgs, nodes, ... }: - { virtualisation.vlans = [ 1 2 ]; + { + virtualisation.vlans = [ + 1 + 2 + ]; networking.nat.enable = true; networking.nat.internalInterfaces = [ "eth2" ]; networking.nat.externalInterface = "eth1"; @@ -31,10 +35,16 @@ in networking.firewall.enable = true; networking.firewall.trustedInterfaces = [ "eth2" ]; networking.interfaces.eth1.ipv4.addresses = [ - { address = externalRouterAddress; prefixLength = 24; } + { + address = externalRouterAddress; + prefixLength = 24; + } ]; networking.interfaces.eth2.ipv4.addresses = [ - { address = internalRouterAddress; prefixLength = 24; } + { + address = internalRouterAddress; + prefixLength = 24; + } ]; services.miniupnpd = { enable = true; @@ -48,17 +58,29 @@ in client1 = { pkgs, nodes, ... }: - { environment.systemPackages = [ pkgs.miniupnpc pkgs.netcat ]; + { + environment.systemPackages = [ + pkgs.miniupnpc + pkgs.netcat + ]; virtualisation.vlans = [ 2 ]; networking.defaultGateway = internalRouterAddress; networking.interfaces.eth1.ipv4.addresses = [ - { address = internalClient1Address; prefixLength = 24; } + { + address = internalClient1Address; + prefixLength = 24; + } ]; networking.firewall.enable = false; services.httpd.enable = true; services.httpd.virtualHosts.localhost = { - listen = [{ ip = "*"; port = 9000; }]; + listen = [ + { + ip = "*"; + port = 9000; + } + ]; adminAddr = "foo@example.org"; documentRoot = "/tmp"; }; @@ -66,34 +88,39 @@ in client2 = { pkgs, ... }: - { environment.systemPackages = [ pkgs.miniupnpc ]; + { + environment.systemPackages = [ pkgs.miniupnpc ]; virtualisation.vlans = [ 1 ]; networking.interfaces.eth1.ipv4.addresses = [ - { address = externalClient2Address; prefixLength = 24; } + { + address = externalClient2Address; + prefixLength = 24; + } ]; networking.firewall.enable = false; }; }; - testScript = - { nodes, ... }: - '' - start_all() + testScript = + { nodes, ... }: + '' + start_all() - # Wait for network and miniupnpd. - router.systemctl("start network-online.target") - router.wait_for_unit("network-online.target") - # $router.wait_for_unit("nat") - router.wait_for_unit("${if useNftables then "nftables" else "firewall"}.service") - router.wait_for_unit("miniupnpd") + # Wait for network and miniupnpd. + router.systemctl("start network-online.target") + router.wait_for_unit("network-online.target") + # $router.wait_for_unit("nat") + router.wait_for_unit("${if useNftables then "nftables" else "firewall"}.service") + router.wait_for_unit("miniupnpd") - client1.systemctl("start network-online.target") - client1.wait_for_unit("network-online.target") + client1.systemctl("start network-online.target") + client1.wait_for_unit("network-online.target") - client1.succeed("upnpc -a ${internalClient1Address} 9000 9000 TCP") + client1.succeed("upnpc -a ${internalClient1Address} 9000 9000 TCP") - client1.wait_for_unit("httpd") - client2.wait_until_succeeds("curl -f http://${externalRouterAddress}:9000/") - ''; + client1.wait_for_unit("httpd") + client2.wait_until_succeeds("curl -f http://${externalRouterAddress}:9000/") + ''; -}) + } +) diff --git a/nixos/tests/uptermd.nix b/nixos/tests/uptermd.nix index 469aa5047c27c8..a7f18fa3cba7cd 100644 --- a/nixos/tests/uptermd.nix +++ b/nixos/tests/uptermd.nix @@ -1,66 +1,71 @@ -import ./make-test-python.nix ({ pkgs, ...}: +import ./make-test-python.nix ( + { pkgs, ... }: -let - client = {pkgs, ...}:{ - environment.systemPackages = [ pkgs.upterm ]; - }; -in -{ - name = "uptermd"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fleaz ]; - }; - - nodes = { - server = {config, ...}: { - services.uptermd = { - enable = true; - openFirewall = true; - port = 1337; + let + client = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.upterm ]; }; + in + { + name = "uptermd"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fleaz ]; }; - client1 = client; - client2 = client; - }; + nodes = { + server = + { config, ... }: + { + services.uptermd = { + enable = true; + openFirewall = true; + port = 1337; + }; + }; + client1 = client; + client2 = client; + }; - testScript = '' - start_all() + testScript = '' + start_all() - server.wait_for_unit("uptermd.service") - server.systemctl("start network-online.target") - server.wait_for_unit("network-online.target") + server.wait_for_unit("uptermd.service") + server.systemctl("start network-online.target") + server.wait_for_unit("network-online.target") - # wait for upterm port to be reachable - client1.wait_until_succeeds("nc -z -v server 1337") + # wait for upterm port to be reachable + client1.wait_until_succeeds("nc -z -v server 1337") - # Add SSH hostkeys from the server to both clients - # uptermd needs an '@cert-authority entry so we need to modify the known_hosts file - client1.execute("mkdir -p ~/.ssh && ssh -o StrictHostKeyChecking=no -p 1337 server ls") - client1.execute("echo @cert-authority $(cat ~/.ssh/known_hosts) > ~/.ssh/known_hosts") - client2.execute("mkdir -p ~/.ssh && ssh -o StrictHostKeyChecking=no -p 1337 server ls") - client2.execute("echo @cert-authority $(cat ~/.ssh/known_hosts) > ~/.ssh/known_hosts") + # Add SSH hostkeys from the server to both clients + # uptermd needs an '@cert-authority entry so we need to modify the known_hosts file + client1.execute("mkdir -p ~/.ssh && ssh -o StrictHostKeyChecking=no -p 1337 server ls") + client1.execute("echo @cert-authority $(cat ~/.ssh/known_hosts) > ~/.ssh/known_hosts") + client2.execute("mkdir -p ~/.ssh && ssh -o StrictHostKeyChecking=no -p 1337 server ls") + client2.execute("echo @cert-authority $(cat ~/.ssh/known_hosts) > ~/.ssh/known_hosts") - client1.wait_for_unit("multi-user.target") - client1.wait_until_succeeds("pgrep -f 'agetty.*tty1'") - client1.wait_until_tty_matches("1", "login: ") - client1.send_chars("root\n") - client1.wait_until_succeeds("pgrep -u root bash") + client1.wait_for_unit("multi-user.target") + client1.wait_until_succeeds("pgrep -f 'agetty.*tty1'") + client1.wait_until_tty_matches("1", "login: ") + client1.send_chars("root\n") + client1.wait_until_succeeds("pgrep -u root bash") - client1.execute("ssh-keygen -t ed25519 -N \"\" -f /root/.ssh/id_ed25519") - client1.send_chars("TERM=xterm upterm host --server ssh://server:1337 --force-command hostname -- bash > /tmp/session-details\n") - client1.wait_for_file("/tmp/session-details") - client1.send_key("q") + client1.execute("ssh-keygen -t ed25519 -N \"\" -f /root/.ssh/id_ed25519") + client1.send_chars("TERM=xterm upterm host --server ssh://server:1337 --force-command hostname -- bash > /tmp/session-details\n") + client1.wait_for_file("/tmp/session-details") + client1.send_key("q") - # uptermd can't connect if we don't have a keypair - client2.execute("ssh-keygen -t ed25519 -N \"\" -f /root/.ssh/id_ed25519") + # uptermd can't connect if we don't have a keypair + client2.execute("ssh-keygen -t ed25519 -N \"\" -f /root/.ssh/id_ed25519") - # Grep the ssh connect command from the output of 'upterm host' - ssh_command = client1.succeed("grep 'SSH Session' /tmp/session-details | cut -d':' -f2-").strip() + # Grep the ssh connect command from the output of 'upterm host' + ssh_command = client1.succeed("grep 'SSH Session' /tmp/session-details | cut -d':' -f2-").strip() - # Connect with client2. Because we used '--force-command hostname' we should get "client1" as the output - output = client2.succeed(ssh_command) + # Connect with client2. Because we used '--force-command hostname' we should get "client1" as the output + output = client2.succeed(ssh_command) - assert output.strip() == "client1" - ''; -}) + assert output.strip() == "client1" + ''; + } +) diff --git a/nixos/tests/uptime-kuma.nix b/nixos/tests/uptime-kuma.nix index 00e2008a5257dc..e79546246f62c2 100644 --- a/nixos/tests/uptime-kuma.nix +++ b/nixos/tests/uptime-kuma.nix @@ -1,17 +1,21 @@ -import ./make-test-python.nix ({ lib, ... }: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "uptime-kuma"; - meta.maintainers = with lib.maintainers; [ julienmalka ]; + { + name = "uptime-kuma"; + meta.maintainers = with lib.maintainers; [ julienmalka ]; - nodes.machine = - { pkgs, ... }: - { services.uptime-kuma.enable = true; }; + nodes.machine = + { pkgs, ... }: + { + services.uptime-kuma.enable = true; + }; - testScript = '' - machine.start() - machine.wait_for_unit("uptime-kuma.service") - machine.wait_for_open_port(3001) - machine.succeed("curl --fail http://localhost:3001/") - ''; -}) + testScript = '' + machine.start() + machine.wait_for_unit("uptime-kuma.service") + machine.wait_for_open_port(3001) + machine.succeed("curl --fail http://localhost:3001/") + ''; + } +) diff --git a/nixos/tests/urn-timer.nix b/nixos/tests/urn-timer.nix index 10c5bef49b5b3e..157e26b30b5ecb 100644 --- a/nixos/tests/urn-timer.nix +++ b/nixos/tests/urn-timer.nix @@ -1,26 +1,30 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "urn-timer"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fgaz ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "urn-timer"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fgaz ]; + }; - nodes.machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + nodes.machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; - environment.systemPackages = [ pkgs.urn-timer ]; - }; + services.xserver.enable = true; + environment.systemPackages = [ pkgs.urn-timer ]; + }; - enableOCR = true; + enableOCR = true; - testScript = - '' + testScript = '' machine.wait_for_x() machine.execute("urn-gtk ${pkgs.urn-timer.src}/splits_examples/sotn.json >&2 &") machine.wait_for_window("urn") machine.wait_for_text(r"(Mist|Bat|Reverse|Dracula)") machine.screenshot("screen") ''; -}) + } +) diff --git a/nixos/tests/usbguard.nix b/nixos/tests/usbguard.nix index d6d3a80c5d23c7..210b8b2adac51d 100644 --- a/nixos/tests/usbguard.nix +++ b/nixos/tests/usbguard.nix @@ -1,62 +1,68 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "usbguard"; - meta = with pkgs.lib.maintainers; { - maintainers = [ tnias ]; - }; - - nodes.machine = - { ... }: - { - services.usbguard = { - enable = true; - IPCAllowedUsers = [ "alice" "root" ]; - - # As virtual USB devices get attached to the "QEMU USB Hub" we need to - # allow Hubs. Otherwise we would have to explicitly allow them too. - rules = '' - allow with-interface equals { 09:00:00 } - ''; - }; - imports = [ ./common/user-account.nix ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "usbguard"; + meta = with pkgs.lib.maintainers; { + maintainers = [ tnias ]; }; - testScript = '' - # create a blank disk image for our fake USB stick - with open(machine.state_dir / "usbstick.img", "wb") as stick: - stick.write(b"\x00" * (1024 * 1024)) + nodes.machine = + { ... }: + { + services.usbguard = { + enable = true; + IPCAllowedUsers = [ + "alice" + "root" + ]; + + # As virtual USB devices get attached to the "QEMU USB Hub" we need to + # allow Hubs. Otherwise we would have to explicitly allow them too. + rules = '' + allow with-interface equals { 09:00:00 } + ''; + }; + imports = [ ./common/user-account.nix ]; + }; + + testScript = '' + # create a blank disk image for our fake USB stick + with open(machine.state_dir / "usbstick.img", "wb") as stick: + stick.write(b"\x00" * (1024 * 1024)) - # wait for machine to have started and the usbguard service to be up - machine.wait_for_unit("usbguard.service") + # wait for machine to have started and the usbguard service to be up + machine.wait_for_unit("usbguard.service") - with subtest("IPC access control"): - # User "alice" is allowed to access the IPC interface - machine.succeed("su alice -c 'usbguard list-devices'") + with subtest("IPC access control"): + # User "alice" is allowed to access the IPC interface + machine.succeed("su alice -c 'usbguard list-devices'") - # User "bob" is not allowed to access the IPC interface - machine.fail("su bob -c 'usbguard list-devices'") + # User "bob" is not allowed to access the IPC interface + machine.fail("su bob -c 'usbguard list-devices'") - with subtest("check basic functionality"): - # at this point we expect that no USB HDD is connected - machine.fail("usbguard list-devices | grep -E 'QEMU USB HARDDRIVE'") + with subtest("check basic functionality"): + # at this point we expect that no USB HDD is connected + machine.fail("usbguard list-devices | grep -E 'QEMU USB HARDDRIVE'") - # insert usb device - machine.send_monitor_command( - f"drive_add 0 id=stick,if=none,file={stick.name},format=raw" - ) - machine.send_monitor_command("device_add usb-storage,id=stick,drive=stick") + # insert usb device + machine.send_monitor_command( + f"drive_add 0 id=stick,if=none,file={stick.name},format=raw" + ) + machine.send_monitor_command("device_add usb-storage,id=stick,drive=stick") - # the attached USB HDD should show up after a short while - machine.wait_until_succeeds("usbguard list-devices | grep -E 'QEMU USB HARDDRIVE'") + # the attached USB HDD should show up after a short while + machine.wait_until_succeeds("usbguard list-devices | grep -E 'QEMU USB HARDDRIVE'") - # at this point there should be a **blocked** USB HDD - machine.succeed("usbguard list-devices | grep -E 'block.*QEMU USB HARDDRIVE'") - machine.fail("usbguard list-devices | grep -E ' allow .*QEMU USB HARDDRIVE'") + # at this point there should be a **blocked** USB HDD + machine.succeed("usbguard list-devices | grep -E 'block.*QEMU USB HARDDRIVE'") + machine.fail("usbguard list-devices | grep -E ' allow .*QEMU USB HARDDRIVE'") - # allow storage devices - machine.succeed("usbguard allow-device 'with-interface { 08:*:* }'") + # allow storage devices + machine.succeed("usbguard allow-device 'with-interface { 08:*:* }'") - # at this point there should be an **allowed** USB HDD - machine.succeed("usbguard list-devices | grep -E ' allow .*QEMU USB HARDDRIVE'") - machine.fail("usbguard list-devices | grep -E ' block .*QEMU USB HARDDRIVE'") - ''; -}) + # at this point there should be an **allowed** USB HDD + machine.succeed("usbguard list-devices | grep -E ' allow .*QEMU USB HARDDRIVE'") + machine.fail("usbguard list-devices | grep -E ' block .*QEMU USB HARDDRIVE'") + ''; + } +) diff --git a/nixos/tests/user-activation-scripts.nix b/nixos/tests/user-activation-scripts.nix index 2e1840a8460f6e..58d1b97a09d672 100644 --- a/nixos/tests/user-activation-scripts.nix +++ b/nixos/tests/user-activation-scripts.nix @@ -1,37 +1,42 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "user-activation-scripts"; - meta = with lib.maintainers; { maintainers = [ chkno ]; }; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "user-activation-scripts"; + meta = with lib.maintainers; { + maintainers = [ chkno ]; + }; - nodes.machine = { - system.switch.enable = true; - system.userActivationScripts.foo = "mktemp ~/user-activation-ran.XXXXXX"; - users.users.alice = { - initialPassword = "pass1"; - isNormalUser = true; + nodes.machine = { + system.switch.enable = true; + system.userActivationScripts.foo = "mktemp ~/user-activation-ran.XXXXXX"; + users.users.alice = { + initialPassword = "pass1"; + isNormalUser = true; + }; + systemd.user.tmpfiles.users.alice.rules = [ "r %h/file-to-remove" ]; }; - systemd.user.tmpfiles.users.alice.rules = [ "r %h/file-to-remove" ]; - }; - testScript = '' - def verify_user_activation_run_count(n): - machine.succeed( - '[[ "$(find /home/alice/ -name user-activation-ran.\\* | wc -l)" == %s ]]' % n - ) + testScript = '' + def verify_user_activation_run_count(n): + machine.succeed( + '[[ "$(find /home/alice/ -name user-activation-ran.\\* | wc -l)" == %s ]]' % n + ) - machine.wait_for_unit("multi-user.target") - machine.wait_for_unit("getty@tty1.service") - machine.wait_until_tty_matches("1", "login: ") - machine.send_chars("alice\n") - machine.wait_until_tty_matches("1", "Password: ") - machine.send_chars("pass1\n") - machine.send_chars("touch login-ok\n") - machine.wait_for_file("/home/alice/login-ok") - verify_user_activation_run_count(1) + machine.wait_for_unit("multi-user.target") + machine.wait_for_unit("getty@tty1.service") + machine.wait_until_tty_matches("1", "login: ") + machine.send_chars("alice\n") + machine.wait_until_tty_matches("1", "Password: ") + machine.send_chars("pass1\n") + machine.send_chars("touch login-ok\n") + machine.wait_for_file("/home/alice/login-ok") + verify_user_activation_run_count(1) - machine.succeed("touch /home/alice/file-to-remove") - machine.succeed("/run/current-system/bin/switch-to-configuration test") - verify_user_activation_run_count(2) - machine.succeed("[[ ! -f /home/alice/file-to-remove ]] || false") - ''; -}) + machine.succeed("touch /home/alice/file-to-remove") + machine.succeed("/run/current-system/bin/switch-to-configuration test") + verify_user_activation_run_count(2) + machine.succeed("[[ ! -f /home/alice/file-to-remove ]] || false") + ''; + } +) diff --git a/nixos/tests/user-home-mode.nix b/nixos/tests/user-home-mode.nix index 2d6d1af3f391b1..f5bcbcbcef8a36 100644 --- a/nixos/tests/user-home-mode.nix +++ b/nixos/tests/user-home-mode.nix @@ -1,35 +1,40 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "user-home-mode"; - meta = with lib.maintainers; { maintainers = [ fbeffa ]; }; - - nodes.machine = { - users.users.alice = { - initialPassword = "pass1"; - isNormalUser = true; - }; - users.users.bob = { - initialPassword = "pass2"; - isNormalUser = true; - homeMode = "750"; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "user-home-mode"; + meta = with lib.maintainers; { + maintainers = [ fbeffa ]; }; - users.users.carol = { - initialPassword = "pass3"; - isNormalUser = true; - createHome = true; - home = "/users/carol"; + + nodes.machine = { + users.users.alice = { + initialPassword = "pass1"; + isNormalUser = true; + }; + users.users.bob = { + initialPassword = "pass2"; + isNormalUser = true; + homeMode = "750"; + }; + users.users.carol = { + initialPassword = "pass3"; + isNormalUser = true; + createHome = true; + home = "/users/carol"; + }; }; - }; - testScript = '' - machine.wait_for_unit("multi-user.target") - machine.wait_for_unit("getty@tty1.service") - machine.wait_until_tty_matches("1", "login: ") - machine.send_chars("alice\n") - machine.wait_until_tty_matches("1", "Password: ") - machine.send_chars("pass1\n") - machine.succeed('[ "$(stat -c %a /home/alice)" == "700" ]') - machine.succeed('[ "$(stat -c %a /home/bob)" == "750" ]') - machine.succeed('[ "$(stat -c %a /users)" == "755" ]') - machine.succeed('[ "$(stat -c %a /users/carol)" == "700" ]') - ''; -}) + testScript = '' + machine.wait_for_unit("multi-user.target") + machine.wait_for_unit("getty@tty1.service") + machine.wait_until_tty_matches("1", "login: ") + machine.send_chars("alice\n") + machine.wait_until_tty_matches("1", "Password: ") + machine.send_chars("pass1\n") + machine.succeed('[ "$(stat -c %a /home/alice)" == "700" ]') + machine.succeed('[ "$(stat -c %a /home/bob)" == "750" ]') + machine.succeed('[ "$(stat -c %a /users)" == "755" ]') + machine.succeed('[ "$(stat -c %a /users/carol)" == "700" ]') + ''; + } +) diff --git a/nixos/tests/ustreamer.nix b/nixos/tests/ustreamer.nix index 1354eb03a32694..12793ff8451dfb 100644 --- a/nixos/tests/ustreamer.nix +++ b/nixos/tests/ustreamer.nix @@ -1,75 +1,83 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "ustreamer-vmtest"; - nodes = { - client = {...}: { - environment.systemPackages = [ pkgs.curl ]; - }; - camera = {config, ...}: let - configFile = pkgs.writeText "akvcam-configFile" '' - [Cameras] - cameras/size = 2 +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "ustreamer-vmtest"; + nodes = { + client = + { ... }: + { + environment.systemPackages = [ pkgs.curl ]; + }; + camera = + { config, ... }: + let + configFile = pkgs.writeText "akvcam-configFile" '' + [Cameras] + cameras/size = 2 - cameras/1/type = output - cameras/1/mode = mmap, userptr, rw - cameras/1/description = Virtual Camera (output device) - cameras/1/formats = 2 - cameras/1/videonr = 7 + cameras/1/type = output + cameras/1/mode = mmap, userptr, rw + cameras/1/description = Virtual Camera (output device) + cameras/1/formats = 2 + cameras/1/videonr = 7 - cameras/2/type = capture - cameras/2/mode = mmap, rw - cameras/2/description = Virtual Camera - cameras/2/formats = 1, 2 - cameras/2/videonr = 9 + cameras/2/type = capture + cameras/2/mode = mmap, rw + cameras/2/description = Virtual Camera + cameras/2/formats = 1, 2 + cameras/2/videonr = 9 - [Connections] - connections/size = 1 - connections/1/connection = 1:2 + [Connections] + connections/size = 1 + connections/1/connection = 1:2 - [Formats] - formats/size = 2 + [Formats] + formats/size = 2 - formats/1/format = YUY2 - formats/1/width = 640 - formats/1/height = 480 - formats/1/fps = 30 + formats/1/format = YUY2 + formats/1/width = 640 + formats/1/height = 480 + formats/1/fps = 30 - formats/2/format = RGB24, YUY2 - formats/2/width = 640 - formats/2/height = 480 - formats/2/fps = 20/1, 15/2 - ''; - in { - environment.systemPackages = [ pkgs.ustreamer ]; - networking.firewall.enable = false; - systemd.services.ustreamer = { - description = "ustreamer service"; - wantedBy = ["multi-user.target"]; - serviceConfig = { - DynamicUser = true; - ExecStart = "${pkgs.ustreamer}/bin/ustreamer --host=0.0.0.0 --port 8000 --device /dev/video9 --device-timeout=8"; - PrivateTmp = true; - BindReadOnlyPaths = "/dev/video9"; - SupplementaryGroups = [ - "video" - ]; - Restart = "always"; + formats/2/format = RGB24, YUY2 + formats/2/width = 640 + formats/2/height = 480 + formats/2/fps = 20/1, 15/2 + ''; + in + { + environment.systemPackages = [ pkgs.ustreamer ]; + networking.firewall.enable = false; + systemd.services.ustreamer = { + description = "ustreamer service"; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + DynamicUser = true; + ExecStart = "${pkgs.ustreamer}/bin/ustreamer --host=0.0.0.0 --port 8000 --device /dev/video9 --device-timeout=8"; + PrivateTmp = true; + BindReadOnlyPaths = "/dev/video9"; + SupplementaryGroups = [ + "video" + ]; + Restart = "always"; + }; + }; + boot.extraModulePackages = [ config.boot.kernelPackages.akvcam ]; + boot.kernelModules = [ "akvcam" ]; + boot.extraModprobeConfig = '' + options akvcam config_file=${configFile} + ''; }; - }; - boot.extraModulePackages = [config.boot.kernelPackages.akvcam]; - boot.kernelModules = ["akvcam"]; - boot.extraModprobeConfig = '' - options akvcam config_file=${configFile} - ''; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - camera.wait_for_unit("ustreamer.service") - camera.wait_for_open_port(8000) + camera.wait_for_unit("ustreamer.service") + camera.wait_for_open_port(8000) - client.wait_for_unit("multi-user.target") - client.succeed("curl http://camera:8000") - ''; -}) + client.wait_for_unit("multi-user.target") + client.succeed("curl http://camera:8000") + ''; + } +) diff --git a/nixos/tests/uwsgi.nix b/nixos/tests/uwsgi.nix index 62da9e0a7168c0..ea8e73b0b638ee 100644 --- a/nixos/tests/uwsgi.nix +++ b/nixos/tests/uwsgi.nix @@ -1,64 +1,69 @@ -import ./make-test-python.nix ({ pkgs, ... }: -{ - name = "uwsgi"; - meta = with pkgs.lib.maintainers; { - maintainers = [ lnl7 ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "uwsgi"; + meta = with pkgs.lib.maintainers; { + maintainers = [ lnl7 ]; + }; - nodes.machine = { pkgs, ... }: { - users.users.hello = - { isSystemUser = true; - group = "hello"; - }; - users.groups.hello = { }; + nodes.machine = + { pkgs, ... }: + { + users.users.hello = { + isSystemUser = true; + group = "hello"; + }; + users.groups.hello = { }; - services.uwsgi = { - enable = true; - plugins = [ "python3" "php" ]; - capabilities = [ "CAP_NET_BIND_SERVICE" ]; - instance.type = "emperor"; + services.uwsgi = { + enable = true; + plugins = [ + "python3" + "php" + ]; + capabilities = [ "CAP_NET_BIND_SERVICE" ]; + instance.type = "emperor"; - instance.vassals.hello = { - type = "normal"; - immediate-uid = "hello"; - immediate-gid = "hello"; - module = "wsgi:application"; - http = ":80"; - cap = "net_bind_service"; - pythonPackages = self: [ self.flask ]; - chdir = pkgs.writeTextDir "wsgi.py" '' - from flask import Flask - import subprocess - application = Flask(__name__) + instance.vassals.hello = { + type = "normal"; + immediate-uid = "hello"; + immediate-gid = "hello"; + module = "wsgi:application"; + http = ":80"; + cap = "net_bind_service"; + pythonPackages = self: [ self.flask ]; + chdir = pkgs.writeTextDir "wsgi.py" '' + from flask import Flask + import subprocess + application = Flask(__name__) - @application.route("/") - def hello(): - return "Hello, World!" + @application.route("/") + def hello(): + return "Hello, World!" - @application.route("/whoami") - def whoami(): - whoami = "${pkgs.coreutils}/bin/whoami" - proc = subprocess.run(whoami, capture_output=True) - return proc.stdout.decode().strip() - ''; - }; + @application.route("/whoami") + def whoami(): + whoami = "${pkgs.coreutils}/bin/whoami" + proc = subprocess.run(whoami, capture_output=True) + return proc.stdout.decode().strip() + ''; + }; - instance.vassals.php = { - type = "normal"; - master = true; - workers = 2; - http-socket = ":8000"; - http-socket-modifier1 = 14; - php-index = "index.php"; - php-docroot = pkgs.writeTextDir "index.php" '' - <?php echo "Hello World\n"; ?> - ''; + instance.vassals.php = { + type = "normal"; + master = true; + workers = 2; + http-socket = ":8000"; + http-socket-modifier1 = 14; + php-index = "index.php"; + php-docroot = pkgs.writeTextDir "index.php" '' + <?php echo "Hello World\n"; ?> + ''; + }; + }; }; - }; - }; - testScript = - '' + testScript = '' machine.wait_for_unit("multi-user.target") machine.wait_for_unit("uwsgi.service") @@ -78,4 +83,5 @@ import ./make-test-python.nix ({ pkgs, ... }: machine.wait_for_open_port(8000) assert "Hello World" in machine.succeed("curl -fv http://machine:8000") ''; -}) + } +) diff --git a/nixos/tests/v2ray.nix b/nixos/tests/v2ray.nix index 9eee962c64e40d..c20720d057d092 100644 --- a/nixos/tests/v2ray.nix +++ b/nixos/tests/v2ray.nix @@ -1,91 +1,99 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: let +import ./make-test-python.nix ( + { lib, pkgs, ... }: + let - v2rayUser = { - # A random UUID. - id = "a6a46834-2150-45f8-8364-0f6f6ab32384"; - alterId = 0; # Non-zero support will be disabled in the future. - }; + v2rayUser = { + # A random UUID. + id = "a6a46834-2150-45f8-8364-0f6f6ab32384"; + alterId = 0; # Non-zero support will be disabled in the future. + }; - # 1080 [http proxy] -> 1081 [vmess] -> direct - v2rayConfig = { - inbounds = [ - { - tag = "http_in"; - port = 1080; - listen = "127.0.0.1"; - protocol = "http"; - } - { - tag = "vmess_in"; - port = 1081; - listen = "127.0.0.1"; - protocol = "vmess"; - settings.clients = [ v2rayUser ]; - } - ]; - outbounds = [ - { - tag = "vmess_out"; - protocol = "vmess"; - settings.vnext = [{ - address = "127.0.0.1"; + # 1080 [http proxy] -> 1081 [vmess] -> direct + v2rayConfig = { + inbounds = [ + { + tag = "http_in"; + port = 1080; + listen = "127.0.0.1"; + protocol = "http"; + } + { + tag = "vmess_in"; port = 1081; - users = [ v2rayUser ]; - }]; - } - { - tag = "direct"; - protocol = "freedom"; - } - ]; - routing.rules = [ - { - type = "field"; - inboundTag = "http_in"; - outboundTag = "vmess_out"; - } - { - type = "field"; - inboundTag = "vmess_in"; - outboundTag = "direct"; - } - - # Assert assets "geoip" and "geosite" are accessible. - { - type = "field"; - ip = [ "geoip:private" ]; - domain = [ "geosite:category-ads" ]; - outboundTag = "direct"; - } - ]; - }; + listen = "127.0.0.1"; + protocol = "vmess"; + settings.clients = [ v2rayUser ]; + } + ]; + outbounds = [ + { + tag = "vmess_out"; + protocol = "vmess"; + settings.vnext = [ + { + address = "127.0.0.1"; + port = 1081; + users = [ v2rayUser ]; + } + ]; + } + { + tag = "direct"; + protocol = "freedom"; + } + ]; + routing.rules = [ + { + type = "field"; + inboundTag = "http_in"; + outboundTag = "vmess_out"; + } + { + type = "field"; + inboundTag = "vmess_in"; + outboundTag = "direct"; + } -in { - name = "v2ray"; - meta = with lib.maintainers; { - maintainers = [ servalcatty ]; - }; - nodes.machine = { pkgs, ... }: { - environment.systemPackages = [ pkgs.curl ]; - services.v2ray = { - enable = true; - config = v2rayConfig; + # Assert assets "geoip" and "geosite" are accessible. + { + type = "field"; + ip = [ "geoip:private" ]; + domain = [ "geosite:category-ads" ]; + outboundTag = "direct"; + } + ]; }; - services.httpd = { - enable = true; - adminAddr = "foo@example.org"; + + in + { + name = "v2ray"; + meta = with lib.maintainers; { + maintainers = [ servalcatty ]; }; - }; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.curl ]; + services.v2ray = { + enable = true; + config = v2rayConfig; + }; + services.httpd = { + enable = true; + adminAddr = "foo@example.org"; + }; + }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("httpd.service") - machine.wait_for_unit("v2ray.service") - machine.wait_for_open_port(80) - machine.wait_for_open_port(1080) - machine.succeed( - "curl --fail --max-time 10 --proxy http://localhost:1080 http://localhost" - ) - ''; -}) + machine.wait_for_unit("httpd.service") + machine.wait_for_unit("v2ray.service") + machine.wait_for_open_port(80) + machine.wait_for_open_port(1080) + machine.succeed( + "curl --fail --max-time 10 --proxy http://localhost:1080 http://localhost" + ) + ''; + } +) diff --git a/nixos/tests/varnish.nix b/nixos/tests/varnish.nix index b7cb79a71cb0bc..ec9f058537374e 100644 --- a/nixos/tests/varnish.nix +++ b/nixos/tests/varnish.nix @@ -1,55 +1,63 @@ { - system ? builtins.currentSystem -, pkgs ? import ../.. { inherit system; } -, package + system ? builtins.currentSystem, + pkgs ? import ../.. { inherit system; }, + package, }: -import ./make-test-python.nix ({ pkgs, lib, ... }: let - testPath = pkgs.hello; -in { - name = "varnish"; - meta = { - maintainers = [ ]; - }; - - nodes = { - varnish = { config, pkgs, ... }: { - services.nix-serve = { - enable = true; - }; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + let + testPath = pkgs.hello; + in + { + name = "varnish"; + meta = { + maintainers = [ ]; + }; - services.varnish = { - inherit package; - enable = true; - http_address = "0.0.0.0:80"; - config = '' - vcl 4.0; - - backend nix-serve { - .host = "127.0.0.1"; - .port = "${toString config.services.nix-serve.port}"; - } - ''; + nodes = { + varnish = + { config, pkgs, ... }: + { + services.nix-serve = { + enable = true; + }; + + services.varnish = { + inherit package; + enable = true; + http_address = "0.0.0.0:80"; + config = '' + vcl 4.0; + + backend nix-serve { + .host = "127.0.0.1"; + .port = "${toString config.services.nix-serve.port}"; + } + ''; + }; + + networking.firewall.allowedTCPPorts = [ 80 ]; + system.extraDependencies = [ testPath ]; }; - networking.firewall.allowedTCPPorts = [ 80 ]; - system.extraDependencies = [ testPath ]; - }; - - client = { lib, ... }: { - nix.settings = { - require-sigs = false; - substituters = lib.mkForce [ "http://varnish" ]; - }; + client = + { lib, ... }: + { + nix.settings = { + require-sigs = false; + substituters = lib.mkForce [ "http://varnish" ]; + }; + }; }; - }; - testScript = '' - start_all() - varnish.wait_for_open_port(80) + testScript = '' + start_all() + varnish.wait_for_open_port(80) - client.wait_until_succeeds("curl -f http://varnish/nix-cache-info"); + client.wait_until_succeeds("curl -f http://varnish/nix-cache-info"); - client.wait_until_succeeds("nix-store -r ${testPath}"); - client.succeed("${testPath}/bin/hello"); - ''; -}) + client.wait_until_succeeds("nix-store -r ${testPath}"); + client.succeed("${testPath}/bin/hello"); + ''; + } +) diff --git a/nixos/tests/vault-agent.nix b/nixos/tests/vault-agent.nix index dc86c829b67af9..dfebc6b21828c4 100644 --- a/nixos/tests/vault-agent.nix +++ b/nixos/tests/vault-agent.nix @@ -1,52 +1,63 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "vault-agent"; - - nodes.machine = { config, pkgs, ... }: { - services.vault-agent.instances.example.settings = { - vault.address = config.environment.variables.VAULT_ADDR; - - auto_auth = [{ - method = [{ - type = "token_file"; - config.token_file_path = pkgs.writeText "vault-token" config.environment.variables.VAULT_TOKEN; - }]; - }]; - - template = [{ - contents = '' - {{- with secret "secret/example" }} - {{ .Data.data.key }}" - {{- end }} - ''; - perms = "0600"; - destination = "/example"; - }]; - }; - - services.vault = { - enable = true; - dev = true; - devRootTokenID = config.environment.variables.VAULT_TOKEN; - }; - - environment = { - systemPackages = [ pkgs.vault ]; - variables = { - VAULT_ADDR = "http://localhost:8200"; - VAULT_TOKEN = "root"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "vault-agent"; + + nodes.machine = + { config, pkgs, ... }: + { + services.vault-agent.instances.example.settings = { + vault.address = config.environment.variables.VAULT_ADDR; + + auto_auth = [ + { + method = [ + { + type = "token_file"; + config.token_file_path = pkgs.writeText "vault-token" config.environment.variables.VAULT_TOKEN; + } + ]; + } + ]; + + template = [ + { + contents = '' + {{- with secret "secret/example" }} + {{ .Data.data.key }}" + {{- end }} + ''; + perms = "0600"; + destination = "/example"; + } + ]; + }; + + services.vault = { + enable = true; + dev = true; + devRootTokenID = config.environment.variables.VAULT_TOKEN; + }; + + environment = { + systemPackages = [ pkgs.vault ]; + variables = { + VAULT_ADDR = "http://localhost:8200"; + VAULT_TOKEN = "root"; + }; + }; }; - }; - }; - testScript = '' - machine.wait_for_unit("vault.service") - machine.wait_for_open_port(8200) + testScript = '' + machine.wait_for_unit("vault.service") + machine.wait_for_open_port(8200) - machine.wait_until_succeeds('vault kv put secret/example key=example') + machine.wait_until_succeeds('vault kv put secret/example key=example') - machine.wait_for_unit("vault-agent-example.service") + machine.wait_for_unit("vault-agent-example.service") - machine.wait_for_file("/example") - machine.succeed('grep "example" /example') - ''; -}) + machine.wait_for_file("/example") + machine.succeed('grep "example" /example') + ''; + } +) diff --git a/nixos/tests/vault-dev.nix b/nixos/tests/vault-dev.nix index ba9a1015cc13ca..b66b72ac74a9c1 100644 --- a/nixos/tests/vault-dev.nix +++ b/nixos/tests/vault-dev.nix @@ -1,35 +1,42 @@ -import ./make-test-python.nix ({ pkgs, ... }: -{ - name = "vault-dev"; - meta = with pkgs.lib.maintainers; { - maintainers = [ lnl7 mic92 ]; - }; - nodes.machine = { pkgs, config, ... }: { - environment.systemPackages = [ pkgs.vault ]; - environment.variables.VAULT_ADDR = "http://127.0.0.1:8200"; - environment.variables.VAULT_TOKEN = "phony-secret"; - - services.vault = { - enable = true; - dev = true; - devRootTokenID = config.environment.variables.VAULT_TOKEN; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "vault-dev"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + lnl7 + mic92 + ]; }; - }; + nodes.machine = + { pkgs, config, ... }: + { + environment.systemPackages = [ pkgs.vault ]; + environment.variables.VAULT_ADDR = "http://127.0.0.1:8200"; + environment.variables.VAULT_TOKEN = "phony-secret"; + + services.vault = { + enable = true; + dev = true; + devRootTokenID = config.environment.variables.VAULT_TOKEN; + }; + }; - testScript = '' - import json - start_all() - machine.wait_for_unit("multi-user.target") - machine.wait_for_unit("vault.service") - machine.wait_for_open_port(8200) - out = machine.succeed("vault status -format=json") - print(out) - status = json.loads(out) - assert status.get("initialized") == True - machine.succeed("vault kv put secret/foo bar=baz") - out = machine.succeed("vault kv get -format=json secret/foo") - print(out) - status = json.loads(out) - assert status.get("data", {}).get("data", {}).get("bar") == "baz" - ''; -}) + testScript = '' + import json + start_all() + machine.wait_for_unit("multi-user.target") + machine.wait_for_unit("vault.service") + machine.wait_for_open_port(8200) + out = machine.succeed("vault status -format=json") + print(out) + status = json.loads(out) + assert status.get("initialized") == True + machine.succeed("vault kv put secret/foo bar=baz") + out = machine.succeed("vault kv get -format=json secret/foo") + print(out) + status = json.loads(out) + assert status.get("data", {}).get("data", {}).get("bar") == "baz" + ''; + } +) diff --git a/nixos/tests/vault-postgresql.nix b/nixos/tests/vault-postgresql.nix index e0e5881c6da790..33d45306a36ccf 100644 --- a/nixos/tests/vault-postgresql.nix +++ b/nixos/tests/vault-postgresql.nix @@ -1,53 +1,59 @@ -/* This test checks that - - multiple config files can be loaded - - the storage backend can be in a file outside the nix store - as is required for security (required because while confidentiality is - always covered, availability isn't) - - the postgres integration works - */ -import ./make-test-python.nix ({ pkgs, ... }: -{ - name = "vault-postgresql"; - meta = with pkgs.lib.maintainers; { - maintainers = [ lnl7 roberth ]; - }; - nodes.machine = { lib, pkgs, ... }: { - environment.systemPackages = [ pkgs.vault ]; - environment.variables.VAULT_ADDR = "http://127.0.0.1:8200"; - services.vault.enable = true; - services.vault.extraSettingsPaths = [ "/run/vault.hcl" ]; - - systemd.services.vault = { - after = [ - "postgresql.service" +/* + This test checks that + - multiple config files can be loaded + - the storage backend can be in a file outside the nix store + as is required for security (required because while confidentiality is + always covered, availability isn't) + - the postgres integration works +*/ +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "vault-postgresql"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + lnl7 + roberth ]; - # Try for about 10 minutes rather than the default of 5 attempts. - serviceConfig.RestartSec = 1; - serviceConfig.StartLimitBurst = 600; }; - # systemd.services.vault.unitConfig.RequiresMountsFor = "/run/keys/"; + nodes.machine = + { lib, pkgs, ... }: + { + environment.systemPackages = [ pkgs.vault ]; + environment.variables.VAULT_ADDR = "http://127.0.0.1:8200"; + services.vault.enable = true; + services.vault.extraSettingsPaths = [ "/run/vault.hcl" ]; - services.postgresql.enable = true; - services.postgresql.initialScript = pkgs.writeText "init.psql" '' - CREATE USER vaultuser WITH ENCRYPTED PASSWORD 'thisisthepass'; - GRANT CONNECT ON DATABASE postgres TO vaultuser; + systemd.services.vault = { + after = [ + "postgresql.service" + ]; + # Try for about 10 minutes rather than the default of 5 attempts. + serviceConfig.RestartSec = 1; + serviceConfig.StartLimitBurst = 600; + }; + # systemd.services.vault.unitConfig.RequiresMountsFor = "/run/keys/"; - -- https://www.vaultproject.io/docs/configuration/storage/postgresql - CREATE TABLE vault_kv_store ( - parent_path TEXT COLLATE "C" NOT NULL, - path TEXT COLLATE "C", - key TEXT COLLATE "C", - value BYTEA, - CONSTRAINT pkey PRIMARY KEY (path, key) - ); - CREATE INDEX parent_path_idx ON vault_kv_store (parent_path); + services.postgresql.enable = true; + services.postgresql.initialScript = pkgs.writeText "init.psql" '' + CREATE USER vaultuser WITH ENCRYPTED PASSWORD 'thisisthepass'; + GRANT CONNECT ON DATABASE postgres TO vaultuser; - GRANT SELECT, INSERT, UPDATE, DELETE ON ALL TABLES IN SCHEMA public TO vaultuser; - ''; - }; + -- https://www.vaultproject.io/docs/configuration/storage/postgresql + CREATE TABLE vault_kv_store ( + parent_path TEXT COLLATE "C" NOT NULL, + path TEXT COLLATE "C", + key TEXT COLLATE "C", + value BYTEA, + CONSTRAINT pkey PRIMARY KEY (path, key) + ); + CREATE INDEX parent_path_idx ON vault_kv_store (parent_path); + + GRANT SELECT, INSERT, UPDATE, DELETE ON ALL TABLES IN SCHEMA public TO vaultuser; + ''; + }; - testScript = - '' + testScript = '' secretConfig = """ storage "postgresql" { connection_url = "postgres://vaultuser:thisisthepass@localhost/postgres?sslmode=disable" @@ -66,4 +72,5 @@ import ./make-test-python.nix ({ pkgs, ... }: machine.succeed("vault operator init") machine.succeed("vault status || test $? -eq 2") ''; -}) + } +) diff --git a/nixos/tests/vault.nix b/nixos/tests/vault.nix index 1b0a26a4487f0a..a17e4fdfba0882 100644 --- a/nixos/tests/vault.nix +++ b/nixos/tests/vault.nix @@ -1,17 +1,19 @@ -import ./make-test-python.nix ({ pkgs, ... }: -{ - name = "vault"; - meta = with pkgs.lib.maintainers; { - maintainers = [ lnl7 ]; - }; - nodes.machine = { pkgs, ... }: { - environment.systemPackages = [ pkgs.vault ]; - environment.variables.VAULT_ADDR = "http://127.0.0.1:8200"; - services.vault.enable = true; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "vault"; + meta = with pkgs.lib.maintainers; { + maintainers = [ lnl7 ]; + }; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.vault ]; + environment.variables.VAULT_ADDR = "http://127.0.0.1:8200"; + services.vault.enable = true; + }; - testScript = - '' + testScript = '' start_all() machine.wait_for_unit("multi-user.target") @@ -22,4 +24,5 @@ import ./make-test-python.nix ({ pkgs, ... }: machine.fail("vault status") machine.succeed("vault status || test $? -eq 2") ''; -}) + } +) diff --git a/nixos/tests/vaultwarden.nix b/nixos/tests/vaultwarden.nix index b51a147be99d35..6ddb6161f15cb6 100644 --- a/nixos/tests/vaultwarden.nix +++ b/nixos/tests/vaultwarden.nix @@ -8,187 +8,217 @@ # The same tests should work without modification on the official bitwarden server, if we ever package that. let - makeVaultwardenTest = name: { - backend ? name, - withClient ? true, - testScript ? null, - }: import ./make-test-python.nix ({ lib, pkgs, ...}: let - dbPassword = "please_dont_hack"; - userEmail = "meow@example.com"; - userPassword = "also_super_secret_ZJWpBKZi668QGt"; # Must be complex to avoid interstitial warning on the signup page - storedPassword = "seeeecret"; - - testRunner = pkgs.writers.writePython3Bin "test-runner" { - libraries = [ pkgs.python3Packages.selenium ]; - flakeIgnore = [ "E501" ]; - } '' - - from selenium.webdriver.common.by import By - from selenium.webdriver import Firefox - from selenium.webdriver.firefox.options import Options - from selenium.webdriver.support.ui import WebDriverWait - from selenium.webdriver.support import expected_conditions as EC - - options = Options() - options.add_argument('--headless') - driver = Firefox(options=options) - - driver.implicitly_wait(20) - driver.get('http://localhost:8080/#/register') - - wait = WebDriverWait(driver, 10) - - wait.until(EC.title_contains("Vaultwarden Web")) - - driver.find_element(By.CSS_SELECTOR, 'input#register-form_input_email').send_keys( - '${userEmail}' - ) - driver.find_element(By.CSS_SELECTOR, 'input#register-form_input_name').send_keys( - 'A Cat' - ) - driver.find_element(By.CSS_SELECTOR, 'input#register-form_input_master-password').send_keys( - '${userPassword}' - ) - driver.find_element(By.CSS_SELECTOR, 'input#register-form_input_confirm-master-password').send_keys( - '${userPassword}' - ) - if driver.find_element(By.CSS_SELECTOR, 'input#checkForBreaches').is_selected(): - driver.find_element(By.CSS_SELECTOR, 'input#checkForBreaches').click() - - driver.find_element(By.XPATH, "//button[contains(., 'Create account')]").click() - - wait.until_not(EC.title_contains("Create account")) - - driver.find_element(By.XPATH, "//button[contains(., 'Continue')]").click() - - driver.find_element(By.CSS_SELECTOR, 'input#login_input_master-password').send_keys( - '${userPassword}' - ) - driver.find_element(By.XPATH, "//button[contains(., 'Log in')]").click() - - wait.until(EC.title_contains("Vaults")) - - driver.find_element(By.XPATH, "//button[contains(., 'New item')]").click() - - driver.find_element(By.CSS_SELECTOR, 'input#name').send_keys( - 'secrets' - ) - driver.find_element(By.CSS_SELECTOR, 'input#loginPassword').send_keys( - '${storedPassword}' - ) - - driver.find_element(By.XPATH, "//button[contains(., 'Save')]").click() - ''; - in { - inherit name; - - meta = { - maintainers = with pkgs.lib.maintainers; [ dotlambda SuperSandro2000 ]; - }; - - nodes = { - server = { pkgs, ... }: lib.mkMerge [ - { - mysql = { - services.mysql = { - enable = true; - initialScript = pkgs.writeText "mysql-init.sql" '' - CREATE DATABASE bitwarden; - CREATE USER 'bitwardenuser'@'localhost' IDENTIFIED BY '${dbPassword}'; - GRANT ALL ON `bitwarden`.* TO 'bitwardenuser'@'localhost'; - FLUSH PRIVILEGES; - ''; - package = pkgs.mariadb; - }; - - services.vaultwarden.config.databaseUrl = "mysql://bitwardenuser:${dbPassword}@localhost/bitwarden"; - - systemd.services.vaultwarden.after = [ "mysql.service" ]; - }; - - postgresql = { - services.postgresql = { - enable = true; - ensureDatabases = [ "vaultwarden" ]; - ensureUsers = [{ - name = "vaultwarden"; - ensureDBOwnership = true; - }]; - }; - - services.vaultwarden.config.databaseUrl = "postgresql:///vaultwarden?host=/run/postgresql"; - - systemd.services.vaultwarden.after = [ "postgresql.service" ]; + makeVaultwardenTest = + name: + { + backend ? name, + withClient ? true, + testScript ? null, + }: + import ./make-test-python.nix ( + { lib, pkgs, ... }: + let + dbPassword = "please_dont_hack"; + userEmail = "meow@example.com"; + userPassword = "also_super_secret_ZJWpBKZi668QGt"; # Must be complex to avoid interstitial warning on the signup page + storedPassword = "seeeecret"; + + testRunner = + pkgs.writers.writePython3Bin "test-runner" + { + libraries = [ pkgs.python3Packages.selenium ]; + flakeIgnore = [ "E501" ]; + } + '' + + from selenium.webdriver.common.by import By + from selenium.webdriver import Firefox + from selenium.webdriver.firefox.options import Options + from selenium.webdriver.support.ui import WebDriverWait + from selenium.webdriver.support import expected_conditions as EC + + options = Options() + options.add_argument('--headless') + driver = Firefox(options=options) + + driver.implicitly_wait(20) + driver.get('http://localhost:8080/#/register') + + wait = WebDriverWait(driver, 10) + + wait.until(EC.title_contains("Vaultwarden Web")) + + driver.find_element(By.CSS_SELECTOR, 'input#register-form_input_email').send_keys( + '${userEmail}' + ) + driver.find_element(By.CSS_SELECTOR, 'input#register-form_input_name').send_keys( + 'A Cat' + ) + driver.find_element(By.CSS_SELECTOR, 'input#register-form_input_master-password').send_keys( + '${userPassword}' + ) + driver.find_element(By.CSS_SELECTOR, 'input#register-form_input_confirm-master-password').send_keys( + '${userPassword}' + ) + if driver.find_element(By.CSS_SELECTOR, 'input#checkForBreaches').is_selected(): + driver.find_element(By.CSS_SELECTOR, 'input#checkForBreaches').click() + + driver.find_element(By.XPATH, "//button[contains(., 'Create account')]").click() + + wait.until_not(EC.title_contains("Create account")) + + driver.find_element(By.XPATH, "//button[contains(., 'Continue')]").click() + + driver.find_element(By.CSS_SELECTOR, 'input#login_input_master-password').send_keys( + '${userPassword}' + ) + driver.find_element(By.XPATH, "//button[contains(., 'Log in')]").click() + + wait.until(EC.title_contains("Vaults")) + + driver.find_element(By.XPATH, "//button[contains(., 'New item')]").click() + + driver.find_element(By.CSS_SELECTOR, 'input#name').send_keys( + 'secrets' + ) + driver.find_element(By.CSS_SELECTOR, 'input#loginPassword').send_keys( + '${storedPassword}' + ) + + driver.find_element(By.XPATH, "//button[contains(., 'Save')]").click() + ''; + in + { + inherit name; + + meta = { + maintainers = with pkgs.lib.maintainers; [ + dotlambda + SuperSandro2000 + ]; + }; + + nodes = + { + server = + { pkgs, ... }: + lib.mkMerge [ + { + mysql = { + services.mysql = { + enable = true; + initialScript = pkgs.writeText "mysql-init.sql" '' + CREATE DATABASE bitwarden; + CREATE USER 'bitwardenuser'@'localhost' IDENTIFIED BY '${dbPassword}'; + GRANT ALL ON `bitwarden`.* TO 'bitwardenuser'@'localhost'; + FLUSH PRIVILEGES; + ''; + package = pkgs.mariadb; + }; + + services.vaultwarden.config.databaseUrl = "mysql://bitwardenuser:${dbPassword}@localhost/bitwarden"; + + systemd.services.vaultwarden.after = [ "mysql.service" ]; + }; + + postgresql = { + services.postgresql = { + enable = true; + ensureDatabases = [ "vaultwarden" ]; + ensureUsers = [ + { + name = "vaultwarden"; + ensureDBOwnership = true; + } + ]; + }; + + services.vaultwarden.config.databaseUrl = "postgresql:///vaultwarden?host=/run/postgresql"; + + systemd.services.vaultwarden.after = [ "postgresql.service" ]; + }; + + sqlite = { + services.vaultwarden.backupDir = "/srv/backups/vaultwarden"; + + environment.systemPackages = [ pkgs.sqlite ]; + }; + } + .${backend} + + { + services.vaultwarden = { + enable = true; + dbBackend = backend; + config = { + rocketAddress = "::"; + rocketPort = 8080; + }; + }; + + networking.firewall.allowedTCPPorts = [ 8080 ]; + + environment.systemPackages = [ + pkgs.firefox-unwrapped + pkgs.geckodriver + testRunner + ]; + } + ]; + } + // lib.optionalAttrs withClient { + client = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.bitwarden-cli ]; + }; }; - sqlite = { - services.vaultwarden.backupDir = "/srv/backups/vaultwarden"; - - environment.systemPackages = [ pkgs.sqlite ]; - }; - }.${backend} - - { - services.vaultwarden = { - enable = true; - dbBackend = backend; - config = { - rocketAddress = "::"; - rocketPort = 8080; - }; - }; - - networking.firewall.allowedTCPPorts = [ 8080 ]; - - environment.systemPackages = [ pkgs.firefox-unwrapped pkgs.geckodriver testRunner ]; - } - ]; - } // lib.optionalAttrs withClient { - client = { pkgs, ... }: { - environment.systemPackages = [ pkgs.bitwarden-cli ]; - }; - }; - - testScript = if testScript != null then testScript else '' - start_all() - server.wait_for_unit("vaultwarden.service") - server.wait_for_open_port(8080) - - with subtest("configure the cli"): - client.succeed("bw --nointeraction config server http://server:8080") - - with subtest("can't login to nonexistent account"): - client.fail( - "bw --nointeraction --raw login ${userEmail} ${userPassword}" - ) - - with subtest("use the web interface to sign up, log in, and save a password"): - server.succeed("PYTHONUNBUFFERED=1 systemd-cat -t test-runner test-runner") - - with subtest("log in with the cli"): - key = client.succeed( - "bw --nointeraction --raw login ${userEmail} ${userPassword}" - ).strip() - - with subtest("sync with the cli"): - client.succeed(f"bw --nointeraction --raw --session {key} sync -f") - - with subtest("get the password with the cli"): - password = client.wait_until_succeeds( - f"bw --nointeraction --raw --session {key} list items | ${pkgs.jq}/bin/jq -r .[].login.password", - timeout=60 - ) - assert password.strip() == "${storedPassword}" - - with subtest("Check systemd unit hardening"): - server.log(server.succeed("systemd-analyze security vaultwarden.service | grep -v ✓")) - ''; - }); + testScript = + if testScript != null then + testScript + else + '' + start_all() + server.wait_for_unit("vaultwarden.service") + server.wait_for_open_port(8080) + + with subtest("configure the cli"): + client.succeed("bw --nointeraction config server http://server:8080") + + with subtest("can't login to nonexistent account"): + client.fail( + "bw --nointeraction --raw login ${userEmail} ${userPassword}" + ) + + with subtest("use the web interface to sign up, log in, and save a password"): + server.succeed("PYTHONUNBUFFERED=1 systemd-cat -t test-runner test-runner") + + with subtest("log in with the cli"): + key = client.succeed( + "bw --nointeraction --raw login ${userEmail} ${userPassword}" + ).strip() + + with subtest("sync with the cli"): + client.succeed(f"bw --nointeraction --raw --session {key} sync -f") + + with subtest("get the password with the cli"): + password = client.wait_until_succeeds( + f"bw --nointeraction --raw --session {key} list items | ${pkgs.jq}/bin/jq -r .[].login.password", + timeout=60 + ) + assert password.strip() == "${storedPassword}" + + with subtest("Check systemd unit hardening"): + server.log(server.succeed("systemd-analyze security vaultwarden.service | grep -v ✓")) + ''; + } + ); in builtins.mapAttrs (k: v: makeVaultwardenTest k v) { - mysql = {}; - postgresql = {}; - sqlite = {}; + mysql = { }; + postgresql = { }; + sqlite = { }; sqlite-backup = { backend = "sqlite"; withClient = false; diff --git a/nixos/tests/vector/api.nix b/nixos/tests/vector/api.nix index 8aa3a0c1b771f5..e67097ee9428e0 100644 --- a/nixos/tests/vector/api.nix +++ b/nixos/tests/vector/api.nix @@ -1,39 +1,45 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: +import ../make-test-python.nix ( + { lib, pkgs, ... }: -{ - name = "vector-api"; - meta.maintainers = [ pkgs.lib.maintainers.happysalada ]; + { + name = "vector-api"; + meta.maintainers = [ pkgs.lib.maintainers.happysalada ]; - nodes.machineapi = { config, pkgs, ... }: { - services.vector = { - enable = true; - journaldAccess = false; - settings = { - api.enabled = true; + nodes.machineapi = + { config, pkgs, ... }: + { + services.vector = { + enable = true; + journaldAccess = false; + settings = { + api.enabled = true; - sources = { - demo_logs = { - type = "demo_logs"; - format = "json"; - }; - }; + sources = { + demo_logs = { + type = "demo_logs"; + format = "json"; + }; + }; - sinks = { - file = { - type = "file"; - inputs = [ "demo_logs" ]; - path = "/var/lib/vector/logs.log"; - encoding = { codec = "json"; }; + sinks = { + file = { + type = "file"; + inputs = [ "demo_logs" ]; + path = "/var/lib/vector/logs.log"; + encoding = { + codec = "json"; + }; + }; + }; }; }; }; - }; - }; - testScript = '' - machineapi.wait_for_unit("vector") - machineapi.wait_for_open_port(8686) - machineapi.succeed("journalctl -o cat -u vector.service | grep 'API server running'") - machineapi.wait_until_succeeds("curl -sSf http://localhost:8686/health") - ''; -}) + testScript = '' + machineapi.wait_for_unit("vector") + machineapi.wait_for_open_port(8686) + machineapi.succeed("journalctl -o cat -u vector.service | grep 'API server running'") + machineapi.wait_until_succeeds("curl -sSf http://localhost:8686/health") + ''; + } +) diff --git a/nixos/tests/vector/default.nix b/nixos/tests/vector/default.nix index dc3747da742160..7ec435bd848c3b 100644 --- a/nixos/tests/vector/default.nix +++ b/nixos/tests/vector/default.nix @@ -1,6 +1,7 @@ -{ system ? builtins.currentSystem -, config ? { } -, pkgs ? import ../../.. { inherit system config; } +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../../.. { inherit system config; }, }: { diff --git a/nixos/tests/vector/dnstap.nix b/nixos/tests/vector/dnstap.nix index 5143fd938fdefa..935ea757e10732 100644 --- a/nixos/tests/vector/dnstap.nix +++ b/nixos/tests/vector/dnstap.nix @@ -1,118 +1,132 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: - -let - dnstapSocket = "/var/run/vector/dnstap.sock"; -in -{ - name = "vector-dnstap"; - meta.maintainers = [ pkgs.lib.maintainers.happysalada ]; - - nodes = { - unbound = { config, pkgs, ... }: { - networking.firewall.allowedUDPPorts = [ 53 ]; - - services.vector = { - enable = true; - - settings = { - sources = { - dnstap = { - type = "dnstap"; - multithreaded = true; - mode = "unix"; - lowercase_hostnames = true; - socket_file_mode = 504; - socket_path = "${dnstapSocket}"; +import ../make-test-python.nix ( + { lib, pkgs, ... }: + + let + dnstapSocket = "/var/run/vector/dnstap.sock"; + in + { + name = "vector-dnstap"; + meta.maintainers = [ pkgs.lib.maintainers.happysalada ]; + + nodes = { + unbound = + { config, pkgs, ... }: + { + networking.firewall.allowedUDPPorts = [ 53 ]; + + services.vector = { + enable = true; + + settings = { + sources = { + dnstap = { + type = "dnstap"; + multithreaded = true; + mode = "unix"; + lowercase_hostnames = true; + socket_file_mode = 504; + socket_path = "${dnstapSocket}"; + }; + }; + + sinks = { + file = { + type = "file"; + inputs = [ "dnstap" ]; + path = "/var/lib/vector/logs.log"; + encoding = { + codec = "json"; + }; + }; + }; }; }; - sinks = { - file = { - type = "file"; - inputs = [ "dnstap" ]; - path = "/var/lib/vector/logs.log"; - encoding = { codec = "json"; }; - }; + systemd.services.vector.serviceConfig = { + RuntimeDirectory = "vector"; + RuntimeDirectoryMode = "0770"; }; - }; - }; - - systemd.services.vector.serviceConfig = { - RuntimeDirectory = "vector"; - RuntimeDirectoryMode = "0770"; - }; - - services.unbound = { - enable = true; - enableRootTrustAnchor = false; - package = pkgs.unbound-full; - settings = { - server = { - interface = [ "0.0.0.0" "::" ]; - access-control = [ "192.168.0.0/24 allow" "::/0 allow" ]; - - domain-insecure = "local"; - private-domain = "local"; - - local-zone = "local. static"; - local-data = [ - ''"test.local. 10800 IN A 192.168.123.5"'' - ]; + + services.unbound = { + enable = true; + enableRootTrustAnchor = false; + package = pkgs.unbound-full; + settings = { + server = { + interface = [ + "0.0.0.0" + "::" + ]; + access-control = [ + "192.168.0.0/24 allow" + "::/0 allow" + ]; + + domain-insecure = "local"; + private-domain = "local"; + + local-zone = "local. static"; + local-data = [ + ''"test.local. 10800 IN A 192.168.123.5"'' + ]; + }; + + dnstap = { + dnstap-enable = "yes"; + dnstap-socket-path = "${dnstapSocket}"; + dnstap-send-identity = "yes"; + dnstap-send-version = "yes"; + dnstap-log-client-query-messages = "yes"; + dnstap-log-client-response-messages = "yes"; + }; + }; }; - dnstap = { - dnstap-enable = "yes"; - dnstap-socket-path = "${dnstapSocket}"; - dnstap-send-identity = "yes"; - dnstap-send-version = "yes"; - dnstap-log-client-query-messages = "yes"; - dnstap-log-client-response-messages = "yes"; + systemd.services.unbound = { + after = [ "vector.service" ]; + wants = [ "vector.service" ]; + serviceConfig = { + # DNSTAP access + ReadWritePaths = [ "/var/run/vector" ]; + SupplementaryGroups = [ "vector" ]; + }; }; }; - }; - - systemd.services.unbound = { - after = [ "vector.service" ]; - wants = [ "vector.service" ]; - serviceConfig = { - # DNSTAP access - ReadWritePaths = [ "/var/run/vector" ]; - SupplementaryGroups = [ "vector" ]; + + dnsclient = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.dig ]; }; - }; }; - dnsclient = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.dig ]; - }; - }; - - testScript = '' - unbound.wait_for_unit("unbound") - unbound.wait_for_unit("vector") - - unbound.wait_until_succeeds( - "journalctl -o cat -u vector.service | grep 'Socket permissions updated to 0o770'" - ) - unbound.wait_until_succeeds( - "journalctl -o cat -u vector.service | grep 'component_type=dnstap' | grep 'Listening... path=\"${dnstapSocket}\"'" - ) - - unbound.wait_for_file("${dnstapSocket}") - unbound.succeed("test 770 -eq $(stat -c '%a' ${dnstapSocket})") - - dnsclient.wait_for_unit("network-online.target") - dnsclient.succeed( - "dig @unbound test.local" - ) - - unbound.wait_for_file("/var/lib/vector/logs.log") - - unbound.wait_until_succeeds( - "grep ClientQuery /var/lib/vector/logs.log | grep '\"domainName\":\"test.local.\"' | grep '\"rcodeName\":\"NoError\"'" - ) - unbound.wait_until_succeeds( - "grep ClientResponse /var/lib/vector/logs.log | grep '\"domainName\":\"test.local.\"' | grep '\"rData\":\"192.168.123.5\"'" - ) - ''; -}) + testScript = '' + unbound.wait_for_unit("unbound") + unbound.wait_for_unit("vector") + + unbound.wait_until_succeeds( + "journalctl -o cat -u vector.service | grep 'Socket permissions updated to 0o770'" + ) + unbound.wait_until_succeeds( + "journalctl -o cat -u vector.service | grep 'component_type=dnstap' | grep 'Listening... path=\"${dnstapSocket}\"'" + ) + + unbound.wait_for_file("${dnstapSocket}") + unbound.succeed("test 770 -eq $(stat -c '%a' ${dnstapSocket})") + + dnsclient.wait_for_unit("network-online.target") + dnsclient.succeed( + "dig @unbound test.local" + ) + + unbound.wait_for_file("/var/lib/vector/logs.log") + + unbound.wait_until_succeeds( + "grep ClientQuery /var/lib/vector/logs.log | grep '\"domainName\":\"test.local.\"' | grep '\"rcodeName\":\"NoError\"'" + ) + unbound.wait_until_succeeds( + "grep ClientResponse /var/lib/vector/logs.log | grep '\"domainName\":\"test.local.\"' | grep '\"rData\":\"192.168.123.5\"'" + ) + ''; + } +) diff --git a/nixos/tests/vector/file-sink.nix b/nixos/tests/vector/file-sink.nix index 2220d20ac55c37..999e8d58443c39 100644 --- a/nixos/tests/vector/file-sink.nix +++ b/nixos/tests/vector/file-sink.nix @@ -1,49 +1,58 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: +import ../make-test-python.nix ( + { lib, pkgs, ... }: -{ - name = "vector-test1"; - meta.maintainers = [ pkgs.lib.maintainers.happysalada ]; + { + name = "vector-test1"; + meta.maintainers = [ pkgs.lib.maintainers.happysalada ]; - nodes.machine = { config, pkgs, ... }: { - services.vector = { - enable = true; - journaldAccess = true; - settings = { - sources = { - journald.type = "journald"; + nodes.machine = + { config, pkgs, ... }: + { + services.vector = { + enable = true; + journaldAccess = true; + settings = { + sources = { + journald.type = "journald"; - vector_metrics.type = "internal_metrics"; + vector_metrics.type = "internal_metrics"; - vector_logs.type = "internal_logs"; - }; + vector_logs.type = "internal_logs"; + }; - sinks = { - file = { - type = "file"; - inputs = [ "journald" "vector_logs" ]; - path = "/var/lib/vector/logs.log"; - encoding = { codec = "json"; }; - }; + sinks = { + file = { + type = "file"; + inputs = [ + "journald" + "vector_logs" + ]; + path = "/var/lib/vector/logs.log"; + encoding = { + codec = "json"; + }; + }; - prometheus_exporter = { - type = "prometheus_exporter"; - inputs = [ "vector_metrics" ]; - address = "[::]:9598"; + prometheus_exporter = { + type = "prometheus_exporter"; + inputs = [ "vector_metrics" ]; + address = "[::]:9598"; + }; + }; }; }; }; - }; - }; - # ensure vector is forwarding the messages appropriately - testScript = '' - machine.wait_for_unit("vector.service") - machine.wait_for_open_port(9598) - machine.wait_until_succeeds("journalctl -o cat -u vector.service | grep 'version=\"${pkgs.vector.version}\"'") - machine.wait_until_succeeds("journalctl -o cat -u vector.service | grep 'API is disabled'") - machine.wait_until_succeeds("curl -sSf http://localhost:9598/metrics | grep vector_build_info") - machine.wait_until_succeeds("curl -sSf http://localhost:9598/metrics | grep vector_component_received_bytes_total | grep journald") - machine.wait_until_succeeds("curl -sSf http://localhost:9598/metrics | grep vector_utilization | grep prometheus_exporter") - machine.wait_for_file("/var/lib/vector/logs.log") - ''; -}) + # ensure vector is forwarding the messages appropriately + testScript = '' + machine.wait_for_unit("vector.service") + machine.wait_for_open_port(9598) + machine.wait_until_succeeds("journalctl -o cat -u vector.service | grep 'version=\"${pkgs.vector.version}\"'") + machine.wait_until_succeeds("journalctl -o cat -u vector.service | grep 'API is disabled'") + machine.wait_until_succeeds("curl -sSf http://localhost:9598/metrics | grep vector_build_info") + machine.wait_until_succeeds("curl -sSf http://localhost:9598/metrics | grep vector_component_received_bytes_total | grep journald") + machine.wait_until_succeeds("curl -sSf http://localhost:9598/metrics | grep vector_utilization | grep prometheus_exporter") + machine.wait_for_file("/var/lib/vector/logs.log") + ''; + } +) diff --git a/nixos/tests/vector/nginx-clickhouse.nix b/nixos/tests/vector/nginx-clickhouse.nix index 3d99bac6ac1610..9470d78d968bd2 100644 --- a/nixos/tests/vector/nginx-clickhouse.nix +++ b/nixos/tests/vector/nginx-clickhouse.nix @@ -1,168 +1,174 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: - -{ - name = "vector-nginx-clickhouse"; - meta.maintainers = [ pkgs.lib.maintainers.happysalada ]; - - nodes = { - clickhouse = { config, pkgs, ... }: { - virtualisation.memorySize = 4096; - - # Clickhouse module can't listen on a non-loopback IP. - networking.firewall.allowedTCPPorts = [ 6000 ]; - services.clickhouse.enable = true; - - # Exercise Vector sink->source for now. - services.vector = { - enable = true; - - settings = { - sources = { - vector_source = { - type = "vector"; - address = "[::]:6000"; +import ../make-test-python.nix ( + { lib, pkgs, ... }: + + { + name = "vector-nginx-clickhouse"; + meta.maintainers = [ pkgs.lib.maintainers.happysalada ]; + + nodes = { + clickhouse = + { config, pkgs, ... }: + { + virtualisation.memorySize = 4096; + + # Clickhouse module can't listen on a non-loopback IP. + networking.firewall.allowedTCPPorts = [ 6000 ]; + services.clickhouse.enable = true; + + # Exercise Vector sink->source for now. + services.vector = { + enable = true; + + settings = { + sources = { + vector_source = { + type = "vector"; + address = "[::]:6000"; + }; + }; + + sinks = { + clickhouse = { + type = "clickhouse"; + inputs = [ "vector_source" ]; + endpoint = "http://localhost:8123"; + database = "nginxdb"; + table = "access_logs"; + skip_unknown_fields = true; + }; + }; }; }; + }; - sinks = { - clickhouse = { - type = "clickhouse"; - inputs = [ "vector_source" ]; - endpoint = "http://localhost:8123"; - database = "nginxdb"; - table = "access_logs"; - skip_unknown_fields = true; - }; + nginx = + { config, pkgs, ... }: + { + services.nginx = { + enable = true; + virtualHosts.localhost = { }; }; - }; - }; - }; - nginx = { config, pkgs, ... }: { - services.nginx = { - enable = true; - virtualHosts.localhost = {}; - }; - - services.vector = { - enable = true; - - settings = { - sources = { - nginx_logs = { - type = "file"; - include = [ "/var/log/nginx/access.log" ]; - read_from = "end"; + services.vector = { + enable = true; + + settings = { + sources = { + nginx_logs = { + type = "file"; + include = [ "/var/log/nginx/access.log" ]; + read_from = "end"; + }; + }; + + sinks = { + vector_sink = { + type = "vector"; + inputs = [ "nginx_logs" ]; + address = "clickhouse:6000"; + }; + }; }; }; - sinks = { - vector_sink = { - type = "vector"; - inputs = [ "nginx_logs" ]; - address = "clickhouse:6000"; - }; + systemd.services.vector.serviceConfig = { + SupplementaryGroups = [ "nginx" ]; }; }; - }; - - systemd.services.vector.serviceConfig = { - SupplementaryGroups = [ "nginx" ]; - }; }; - }; - - testScript = - let - # work around quote/substitution complexity by Nix, Perl, bash and SQL. - databaseDDL = pkgs.writeText "database.sql" "CREATE DATABASE IF NOT EXISTS nginxdb"; - - tableDDL = pkgs.writeText "table.sql" '' - CREATE TABLE IF NOT EXISTS nginxdb.access_logs ( - message String - ) - ENGINE = MergeTree() - ORDER BY tuple() - ''; - - # Graciously taken from https://clickhouse.com/docs/en/integrations/vector - tableView = pkgs.writeText "table-view.sql" '' - CREATE MATERIALIZED VIEW nginxdb.access_logs_view - ( - RemoteAddr String, - Client String, - RemoteUser String, - TimeLocal DateTime, - RequestMethod String, - Request String, - HttpVersion String, - Status Int32, - BytesSent Int64, - UserAgent String - ) - ENGINE = MergeTree() - ORDER BY RemoteAddr - POPULATE AS - WITH - splitByWhitespace(message) as split, - splitByRegexp('\S \d+ "([^"]*)"', message) as referer - SELECT - split[1] AS RemoteAddr, - split[2] AS Client, - split[3] AS RemoteUser, - parseDateTimeBestEffort(replaceOne(trim(LEADING '[' FROM split[4]), ':', ' ')) AS TimeLocal, - trim(LEADING '"' FROM split[6]) AS RequestMethod, - split[7] AS Request, - trim(TRAILING '"' FROM split[8]) AS HttpVersion, - split[9] AS Status, - split[10] AS BytesSent, - trim(BOTH '"' from referer[2]) AS UserAgent - FROM - (SELECT message FROM nginxdb.access_logs) - ''; - - selectQuery = pkgs.writeText "select.sql" "SELECT * from nginxdb.access_logs_view"; - in - '' - clickhouse.wait_for_unit("clickhouse") - clickhouse.wait_for_open_port(8123) - - clickhouse.wait_until_succeeds( - "journalctl -o cat -u clickhouse.service | grep 'Started ClickHouse server'" - ) - - clickhouse.wait_for_unit("vector") - clickhouse.wait_for_open_port(6000) - - clickhouse.succeed( - "cat ${databaseDDL} | clickhouse-client" - ) - - clickhouse.succeed( - "cat ${tableDDL} | clickhouse-client" - ) - - clickhouse.succeed( - "cat ${tableView} | clickhouse-client" - ) - - nginx.wait_for_unit("nginx") - nginx.wait_for_open_port(80) - nginx.wait_for_unit("vector") - nginx.wait_until_succeeds( - "journalctl -o cat -u vector.service | grep 'Starting file server'" - ) - - nginx.succeed("curl http://localhost/") - nginx.succeed("curl http://localhost/") - - nginx.wait_for_file("/var/log/nginx/access.log") - nginx.wait_until_succeeds( - "journalctl -o cat -u vector.service | grep 'Found new file to watch. file=/var/log/nginx/access.log'" - ) - - clickhouse.wait_until_succeeds( - "cat ${selectQuery} | clickhouse-client | grep 'curl'" - ) - ''; -}) + + testScript = + let + # work around quote/substitution complexity by Nix, Perl, bash and SQL. + databaseDDL = pkgs.writeText "database.sql" "CREATE DATABASE IF NOT EXISTS nginxdb"; + + tableDDL = pkgs.writeText "table.sql" '' + CREATE TABLE IF NOT EXISTS nginxdb.access_logs ( + message String + ) + ENGINE = MergeTree() + ORDER BY tuple() + ''; + + # Graciously taken from https://clickhouse.com/docs/en/integrations/vector + tableView = pkgs.writeText "table-view.sql" '' + CREATE MATERIALIZED VIEW nginxdb.access_logs_view + ( + RemoteAddr String, + Client String, + RemoteUser String, + TimeLocal DateTime, + RequestMethod String, + Request String, + HttpVersion String, + Status Int32, + BytesSent Int64, + UserAgent String + ) + ENGINE = MergeTree() + ORDER BY RemoteAddr + POPULATE AS + WITH + splitByWhitespace(message) as split, + splitByRegexp('\S \d+ "([^"]*)"', message) as referer + SELECT + split[1] AS RemoteAddr, + split[2] AS Client, + split[3] AS RemoteUser, + parseDateTimeBestEffort(replaceOne(trim(LEADING '[' FROM split[4]), ':', ' ')) AS TimeLocal, + trim(LEADING '"' FROM split[6]) AS RequestMethod, + split[7] AS Request, + trim(TRAILING '"' FROM split[8]) AS HttpVersion, + split[9] AS Status, + split[10] AS BytesSent, + trim(BOTH '"' from referer[2]) AS UserAgent + FROM + (SELECT message FROM nginxdb.access_logs) + ''; + + selectQuery = pkgs.writeText "select.sql" "SELECT * from nginxdb.access_logs_view"; + in + '' + clickhouse.wait_for_unit("clickhouse") + clickhouse.wait_for_open_port(8123) + + clickhouse.wait_until_succeeds( + "journalctl -o cat -u clickhouse.service | grep 'Started ClickHouse server'" + ) + + clickhouse.wait_for_unit("vector") + clickhouse.wait_for_open_port(6000) + + clickhouse.succeed( + "cat ${databaseDDL} | clickhouse-client" + ) + + clickhouse.succeed( + "cat ${tableDDL} | clickhouse-client" + ) + + clickhouse.succeed( + "cat ${tableView} | clickhouse-client" + ) + + nginx.wait_for_unit("nginx") + nginx.wait_for_open_port(80) + nginx.wait_for_unit("vector") + nginx.wait_until_succeeds( + "journalctl -o cat -u vector.service | grep 'Starting file server'" + ) + + nginx.succeed("curl http://localhost/") + nginx.succeed("curl http://localhost/") + + nginx.wait_for_file("/var/log/nginx/access.log") + nginx.wait_until_succeeds( + "journalctl -o cat -u vector.service | grep 'Found new file to watch. file=/var/log/nginx/access.log'" + ) + + clickhouse.wait_until_succeeds( + "cat ${selectQuery} | clickhouse-client | grep 'curl'" + ) + ''; + } +) diff --git a/nixos/tests/vector/syslog-quickwit.nix b/nixos/tests/vector/syslog-quickwit.nix index cb6e04e00eae49..68783a1642f1d7 100644 --- a/nixos/tests/vector/syslog-quickwit.nix +++ b/nixos/tests/vector/syslog-quickwit.nix @@ -1,156 +1,162 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: +import ../make-test-python.nix ( + { lib, pkgs, ... }: -# Based on https://quickwit.io/docs/log-management/send-logs/using-vector + # Based on https://quickwit.io/docs/log-management/send-logs/using-vector -{ - name = "vector-syslog-quickwit"; - meta.maintainers = [ pkgs.lib.maintainers.happysalada ]; + { + name = "vector-syslog-quickwit"; + meta.maintainers = [ pkgs.lib.maintainers.happysalada ]; - nodes = { - quickwit = { config, pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; + nodes = { + quickwit = + { config, pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; - networking.firewall.allowedTCPPorts = [ 7280 ]; + networking.firewall.allowedTCPPorts = [ 7280 ]; - services.quickwit = { - enable = true; - settings = { - listen_address = "::"; - }; - }; - }; - - syslog = { config, pkgs, ... }: { - services.vector = { - enable = true; - - settings = { - sources = { - generate_syslog = { - type = "demo_logs"; - format = "syslog"; - interval = 0.5; - }; - }; - - transforms = { - remap_syslog = { - inputs = ["generate_syslog"]; - type = "remap"; - source = '' - structured = parse_syslog!(.message) - .timestamp_nanos = to_unix_timestamp!(structured.timestamp, unit: "nanoseconds") - .body = structured - .service_name = structured.appname - .resource_attributes.source_type = .source_type - .resource_attributes.host.hostname = structured.hostname - .resource_attributes.service.name = structured.appname - .attributes.syslog.procid = structured.procid - .attributes.syslog.facility = structured.facility - .attributes.syslog.version = structured.version - .severity_text = if includes(["emerg", "err", "crit", "alert"], structured.severity) { - "ERROR" - } else if structured.severity == "warning" { - "WARN" - } else if structured.severity == "debug" { - "DEBUG" - } else if includes(["info", "notice"], structured.severity) { - "INFO" - } else { - structured.severity - } - .scope_name = structured.msgid - del(.message) - del(.host) - del(.timestamp) - del(.service) - del(.source_type) - ''; + services.quickwit = { + enable = true; + settings = { + listen_address = "::"; }; }; + }; - sinks = { - #emit_syslog = { - # inputs = ["remap_syslog"]; - # type = "console"; - # encoding.codec = "json"; - #}; - quickwit_logs = { - type = "http"; - method = "post"; - inputs = [ "remap_syslog" ]; - encoding.codec = "json"; - framing.method = "newline_delimited"; - uri = "http://quickwit:7280/api/v1/otel-logs-v0_7/ingest"; + syslog = + { config, pkgs, ... }: + { + services.vector = { + enable = true; + + settings = { + sources = { + generate_syslog = { + type = "demo_logs"; + format = "syslog"; + interval = 0.5; + }; + }; + + transforms = { + remap_syslog = { + inputs = [ "generate_syslog" ]; + type = "remap"; + source = '' + structured = parse_syslog!(.message) + .timestamp_nanos = to_unix_timestamp!(structured.timestamp, unit: "nanoseconds") + .body = structured + .service_name = structured.appname + .resource_attributes.source_type = .source_type + .resource_attributes.host.hostname = structured.hostname + .resource_attributes.service.name = structured.appname + .attributes.syslog.procid = structured.procid + .attributes.syslog.facility = structured.facility + .attributes.syslog.version = structured.version + .severity_text = if includes(["emerg", "err", "crit", "alert"], structured.severity) { + "ERROR" + } else if structured.severity == "warning" { + "WARN" + } else if structured.severity == "debug" { + "DEBUG" + } else if includes(["info", "notice"], structured.severity) { + "INFO" + } else { + structured.severity + } + .scope_name = structured.msgid + del(.message) + del(.host) + del(.timestamp) + del(.service) + del(.source_type) + ''; + }; + }; + + sinks = { + #emit_syslog = { + # inputs = ["remap_syslog"]; + # type = "console"; + # encoding.codec = "json"; + #}; + quickwit_logs = { + type = "http"; + method = "post"; + inputs = [ "remap_syslog" ]; + encoding.codec = "json"; + framing.method = "newline_delimited"; + uri = "http://quickwit:7280/api/v1/otel-logs-v0_7/ingest"; + }; + }; }; }; }; - }; }; - }; - - testScript = - let - aggregationQuery = pkgs.writeText "aggregation-query.json" '' - { - "query": "*", - "max_hits": 0, - "aggs": { - "count_per_minute": { - "histogram": { - "field": "timestamp_nanos", - "interval": 60000000 - }, + + testScript = + let + aggregationQuery = pkgs.writeText "aggregation-query.json" '' + { + "query": "*", + "max_hits": 0, "aggs": { - "severity_text_count": { - "terms": { - "field": "severity_text" + "count_per_minute": { + "histogram": { + "field": "timestamp_nanos", + "interval": 60000000 + }, + "aggs": { + "severity_text_count": { + "terms": { + "field": "severity_text" + } + } } } } } - } - } - ''; - in - '' - quickwit.wait_for_unit("quickwit") - quickwit.wait_for_open_port(7280) - quickwit.wait_for_open_port(7281) - - quickwit.wait_until_succeeds( - "journalctl -o cat -u quickwit.service | grep 'transitioned to ready state'" - ) - - syslog.wait_for_unit("vector") - syslog.wait_until_succeeds( - "journalctl -o cat -u vector.service | grep 'Vector has started'" - ) - - quickwit.wait_until_succeeds( - "journalctl -o cat -u quickwit.service | grep 'publish-new-splits'" - ) - - # Wait for logs to be generated - # Test below aggregates by the minute - syslog.sleep(60 * 2) - - quickwit.wait_until_succeeds( - "curl -sSf -XGET http://127.0.0.1:7280/api/v1/otel-logs-v0_7/search?query=severity_text:ERROR |" - + " jq '.num_hits' | grep -v '0'" - ) - - quickwit.wait_until_succeeds( - "journalctl -o cat -u quickwit.service | grep 'SearchRequest'" - ) - - quickwit.wait_until_succeeds( - "curl -sSf -XPOST -H 'Content-Type: application/json' http://127.0.0.1:7280/api/v1/otel-logs-v0_7/search --data @${aggregationQuery} |" - + " jq '.num_hits' | grep -v '0'" - ) - - quickwit.wait_until_succeeds( - "journalctl -o cat -u quickwit.service | grep 'count_per_minute'" - ) - ''; -}) + ''; + in + '' + quickwit.wait_for_unit("quickwit") + quickwit.wait_for_open_port(7280) + quickwit.wait_for_open_port(7281) + + quickwit.wait_until_succeeds( + "journalctl -o cat -u quickwit.service | grep 'transitioned to ready state'" + ) + + syslog.wait_for_unit("vector") + syslog.wait_until_succeeds( + "journalctl -o cat -u vector.service | grep 'Vector has started'" + ) + + quickwit.wait_until_succeeds( + "journalctl -o cat -u quickwit.service | grep 'publish-new-splits'" + ) + + # Wait for logs to be generated + # Test below aggregates by the minute + syslog.sleep(60 * 2) + + quickwit.wait_until_succeeds( + "curl -sSf -XGET http://127.0.0.1:7280/api/v1/otel-logs-v0_7/search?query=severity_text:ERROR |" + + " jq '.num_hits' | grep -v '0'" + ) + + quickwit.wait_until_succeeds( + "journalctl -o cat -u quickwit.service | grep 'SearchRequest'" + ) + + quickwit.wait_until_succeeds( + "curl -sSf -XPOST -H 'Content-Type: application/json' http://127.0.0.1:7280/api/v1/otel-logs-v0_7/search --data @${aggregationQuery} |" + + " jq '.num_hits' | grep -v '0'" + ) + + quickwit.wait_until_succeeds( + "journalctl -o cat -u quickwit.service | grep 'count_per_minute'" + ) + ''; + } +) diff --git a/nixos/tests/vengi-tools.nix b/nixos/tests/vengi-tools.nix index fd7567991487e5..fcf42c09a7a82a 100644 --- a/nixos/tests/vengi-tools.nix +++ b/nixos/tests/vengi-tools.nix @@ -1,22 +1,25 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "vengi-tools"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fgaz ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "vengi-tools"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fgaz ]; + }; - nodes.machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + nodes.machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; - environment.systemPackages = [ pkgs.vengi-tools ]; - }; + services.xserver.enable = true; + environment.systemPackages = [ pkgs.vengi-tools ]; + }; - enableOCR = true; + enableOCR = true; - testScript = - '' + testScript = '' machine.wait_for_x() machine.execute("vengi-voxedit >&2 &") machine.wait_for_window("voxedit") @@ -24,4 +27,5 @@ import ./make-test-python.nix ({ pkgs, ... }: { machine.sleep(15) machine.screenshot("screen") ''; -}) + } +) diff --git a/nixos/tests/vikunja.nix b/nixos/tests/vikunja.nix index 4e2bf166a7b6cd..f1108dc69330e2 100644 --- a/nixos/tests/vikunja.nix +++ b/nixos/tests/vikunja.nix @@ -1,58 +1,64 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "vikunja"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "vikunja"; - meta.maintainers = with lib.maintainers; [ leona ]; + meta.maintainers = with lib.maintainers; [ leona ]; - nodes = { - vikunjaSqlite = { ... }: { - services.vikunja = { - enable = true; - database = { - type = "sqlite"; + nodes = { + vikunjaSqlite = + { ... }: + { + services.vikunja = { + enable = true; + database = { + type = "sqlite"; + }; + frontendScheme = "http"; + frontendHostname = "localhost"; + }; + services.nginx = { + enable = true; + virtualHosts."http://localhost" = { + locations."/".proxyPass = "http://localhost:3456"; + }; + }; }; - frontendScheme = "http"; - frontendHostname = "localhost"; - }; - services.nginx = { - enable = true; - virtualHosts."http://localhost" = { - locations."/".proxyPass = "http://localhost:3456"; + vikunjaPostgresql = + { pkgs, ... }: + { + services.vikunja = { + enable = true; + database = { + type = "postgres"; + user = "vikunja"; + database = "vikunja"; + host = "/run/postgresql"; + }; + frontendScheme = "http"; + frontendHostname = "localhost"; + port = 9090; + }; + services.postgresql = { + enable = true; + ensureDatabases = [ "vikunja" ]; + ensureUsers = [ + { + name = "vikunja"; + ensureDBOwnership = true; + } + ]; + }; + services.nginx = { + enable = true; + virtualHosts."http://localhost" = { + locations."/".proxyPass = "http://localhost:9090"; + }; + }; }; - }; }; - vikunjaPostgresql = { pkgs, ... }: { - services.vikunja = { - enable = true; - database = { - type = "postgres"; - user = "vikunja"; - database = "vikunja"; - host = "/run/postgresql"; - }; - frontendScheme = "http"; - frontendHostname = "localhost"; - port = 9090; - }; - services.postgresql = { - enable = true; - ensureDatabases = [ "vikunja" ]; - ensureUsers = [ - { name = "vikunja"; - ensureDBOwnership = true; - } - ]; - }; - services.nginx = { - enable = true; - virtualHosts."http://localhost" = { - locations."/".proxyPass = "http://localhost:9090"; - }; - }; - }; - }; - testScript = - '' + testScript = '' vikunjaSqlite.wait_for_unit("vikunja.service") vikunjaSqlite.wait_for_open_port(3456) vikunjaSqlite.succeed("curl --fail http://localhost:3456/api/v1/info") @@ -71,4 +77,5 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: { vikunjaPostgresql.succeed("curl --fail http://localhost/api/v1/info") vikunjaPostgresql.succeed("curl --fail http://localhost") ''; -}) + } +) diff --git a/nixos/tests/vscode-remote-ssh.nix b/nixos/tests/vscode-remote-ssh.nix index 305f931d4df1b8..3ceaba967fa69a 100644 --- a/nixos/tests/vscode-remote-ssh.nix +++ b/nixos/tests/vscode-remote-ssh.nix @@ -1,132 +1,167 @@ -import ./make-test-python.nix ({ lib, ... }@args: let - pkgs = args.pkgs.extend (self: super: { - stdenv = super.stdenv.override { - config = super.config // { - allowUnfreePredicate = pkg: builtins.elem (lib.getName pkg) [ - "vscode" "vscode-with-extensions" "vscode-extension-ms-vscode-remote-remote-ssh" - ]; - }; - }; - }); - - inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; - - inherit (pkgs.vscode.passthru) rev vscodeServer; -in { - name = "vscode-remote-ssh"; - - meta = { - maintainers = [ ]; - timeout = 600; - }; - - nodes = let - serverAddress = "192.168.0.2"; - clientAddress = "192.168.0.1"; - in { - server = { ... }: { - networking.interfaces.eth1.ipv4.addresses = [ { address = serverAddress; prefixLength = 24; } ]; - services.openssh.enable = true; - users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; - virtualisation.additionalPaths = with pkgs; [ patchelf bintools (lib.getLib stdenv.cc.cc) ]; - }; - client = { ... }: { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - networking.interfaces.eth1.ipv4.addresses = [ { address = clientAddress; prefixLength = 24; } ]; - networking.hosts.${serverAddress} = [ "server" ]; - test-support.displayManager.auto.user = "alice"; - environment.systemPackages = [ - (pkgs.vscode-with-extensions.override { - vscodeExtensions = [ - pkgs.vscode-extensions.ms-vscode-remote.remote-ssh - ]; - }) - ]; - }; - }; +import ./make-test-python.nix ( + { lib, ... }@args: + let + pkgs = args.pkgs.extend ( + self: super: { + stdenv = super.stdenv.override { + config = super.config // { + allowUnfreePredicate = + pkg: + builtins.elem (lib.getName pkg) [ + "vscode" + "vscode-with-extensions" + "vscode-extension-ms-vscode-remote-remote-ssh" + ]; + }; + }; + } + ); - enableOCR = true; + inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; - testScript = let - jq = "${pkgs.jq}/bin/jq"; + inherit (pkgs.vscode.passthru) rev vscodeServer; + in + { + name = "vscode-remote-ssh"; - sshConfig = builtins.toFile "ssh.conf" '' - UserKnownHostsFile=/dev/null - StrictHostKeyChecking=no - ''; + meta = { + maintainers = [ ]; + timeout = 600; + }; - vscodeConfig = builtins.toFile "settings.json" '' + nodes = + let + serverAddress = "192.168.0.2"; + clientAddress = "192.168.0.1"; + in { - "window.zoomLevel": 1, - "security.workspace.trust.startupPrompt": "always" - } - ''; - in '' - def connect_with_remote_ssh(screenshot, should_succeed): - print(f"connect_with_remote_ssh({screenshot=}, {should_succeed=})") - - if server.execute("test -d ~/.vscode-server")[0] == 0: - server.succeed("rm -r ~/.vscode-server") - - server.succeed("mkdir -p ~/.vscode-server/bin") - server.succeed("cp -r ${vscodeServer} ~/.vscode-server/bin/${rev}") - - client.succeed("sudo -u alice code --remote=ssh-remote+root@server /root") - client.wait_for_window("Visual Studio Code") - - if should_succeed: - ocr_text = "Do you trust" - else: - ocr_text = "Could not establish connection" - client.wait_for_text(ocr_text) - client.screenshot(screenshot) - - if should_succeed: - # Press the Don't Trust button - client.send_key("tab") - client.send_key("tab") - client.send_key("tab") - client.send_key("\n") - else: - # Close the error dialog - client.send_key("esc") - - # Don't send Ctrl-q too quickly otherwise it might not get sent to VS Code - client.sleep(1) - client.send_key("ctrl-q") - client.wait_until_fails("pidof code") - - - start_all() - server.wait_for_open_port(22) - - VSCODE_COMMIT = server.execute("${jq} -r .commit ${pkgs.vscode}/lib/vscode/resources/app/product.json")[1].rstrip() - SERVER_COMMIT = server.execute("${jq} -r .commit ${vscodeServer}/product.json")[1].rstrip() - - print(f"{VSCODE_COMMIT=} {SERVER_COMMIT=}") - assert VSCODE_COMMIT == SERVER_COMMIT, "VSCODE_COMMIT and SERVER_COMMIT do not match" - - client.wait_until_succeeds("ping -c1 server") - client.succeed("sudo -u alice mkdir ~alice/.ssh") - client.succeed("sudo -u alice install -Dm 600 ${snakeOilPrivateKey} ~alice/.ssh/id_ecdsa") - client.succeed("sudo -u alice install ${sshConfig} ~alice/.ssh/config") - client.succeed("sudo -u alice install -Dm 644 ${vscodeConfig} ~alice/.config/Code/User/settings.json") - - client.wait_for_x() - client.wait_for_file("~alice/.Xauthority") - client.succeed("xauth merge ~alice/.Xauthority") - # Move the mouse out of the way - client.succeed("${pkgs.xdotool}/bin/xdotool mousemove 0 0") - - with subtest("fails to connect when nixpkgs isn't available"): - server.fail("nix-build '<nixpkgs>' -A hello") - connect_with_remote_ssh(screenshot="no_node_installed", should_succeed=False) - server.succeed("test -e ~/.vscode-server/bin/${rev}/node") - server.fail("~/.vscode-server/bin/${rev}/node -v") - - with subtest("connects when server can patch Node"): - server.succeed("mkdir -p /nix/var/nix/profiles/per-user/root/channels") - server.succeed("ln -s ${pkgs.path} /nix/var/nix/profiles/per-user/root/channels/nixos") - connect_with_remote_ssh(screenshot="build_node_with_nix", should_succeed=True) - ''; -}) + server = + { ... }: + { + networking.interfaces.eth1.ipv4.addresses = [ + { + address = serverAddress; + prefixLength = 24; + } + ]; + services.openssh.enable = true; + users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; + virtualisation.additionalPaths = with pkgs; [ + patchelf + bintools + (lib.getLib stdenv.cc.cc) + ]; + }; + client = + { ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + networking.interfaces.eth1.ipv4.addresses = [ + { + address = clientAddress; + prefixLength = 24; + } + ]; + networking.hosts.${serverAddress} = [ "server" ]; + test-support.displayManager.auto.user = "alice"; + environment.systemPackages = [ + (pkgs.vscode-with-extensions.override { + vscodeExtensions = [ + pkgs.vscode-extensions.ms-vscode-remote.remote-ssh + ]; + }) + ]; + }; + }; + + enableOCR = true; + + testScript = + let + jq = "${pkgs.jq}/bin/jq"; + + sshConfig = builtins.toFile "ssh.conf" '' + UserKnownHostsFile=/dev/null + StrictHostKeyChecking=no + ''; + + vscodeConfig = builtins.toFile "settings.json" '' + { + "window.zoomLevel": 1, + "security.workspace.trust.startupPrompt": "always" + } + ''; + in + '' + def connect_with_remote_ssh(screenshot, should_succeed): + print(f"connect_with_remote_ssh({screenshot=}, {should_succeed=})") + + if server.execute("test -d ~/.vscode-server")[0] == 0: + server.succeed("rm -r ~/.vscode-server") + + server.succeed("mkdir -p ~/.vscode-server/bin") + server.succeed("cp -r ${vscodeServer} ~/.vscode-server/bin/${rev}") + + client.succeed("sudo -u alice code --remote=ssh-remote+root@server /root") + client.wait_for_window("Visual Studio Code") + + if should_succeed: + ocr_text = "Do you trust" + else: + ocr_text = "Could not establish connection" + client.wait_for_text(ocr_text) + client.screenshot(screenshot) + + if should_succeed: + # Press the Don't Trust button + client.send_key("tab") + client.send_key("tab") + client.send_key("tab") + client.send_key("\n") + else: + # Close the error dialog + client.send_key("esc") + + # Don't send Ctrl-q too quickly otherwise it might not get sent to VS Code + client.sleep(1) + client.send_key("ctrl-q") + client.wait_until_fails("pidof code") + + + start_all() + server.wait_for_open_port(22) + + VSCODE_COMMIT = server.execute("${jq} -r .commit ${pkgs.vscode}/lib/vscode/resources/app/product.json")[1].rstrip() + SERVER_COMMIT = server.execute("${jq} -r .commit ${vscodeServer}/product.json")[1].rstrip() + + print(f"{VSCODE_COMMIT=} {SERVER_COMMIT=}") + assert VSCODE_COMMIT == SERVER_COMMIT, "VSCODE_COMMIT and SERVER_COMMIT do not match" + + client.wait_until_succeeds("ping -c1 server") + client.succeed("sudo -u alice mkdir ~alice/.ssh") + client.succeed("sudo -u alice install -Dm 600 ${snakeOilPrivateKey} ~alice/.ssh/id_ecdsa") + client.succeed("sudo -u alice install ${sshConfig} ~alice/.ssh/config") + client.succeed("sudo -u alice install -Dm 644 ${vscodeConfig} ~alice/.config/Code/User/settings.json") + + client.wait_for_x() + client.wait_for_file("~alice/.Xauthority") + client.succeed("xauth merge ~alice/.Xauthority") + # Move the mouse out of the way + client.succeed("${pkgs.xdotool}/bin/xdotool mousemove 0 0") + + with subtest("fails to connect when nixpkgs isn't available"): + server.fail("nix-build '<nixpkgs>' -A hello") + connect_with_remote_ssh(screenshot="no_node_installed", should_succeed=False) + server.succeed("test -e ~/.vscode-server/bin/${rev}/node") + server.fail("~/.vscode-server/bin/${rev}/node -v") + + with subtest("connects when server can patch Node"): + server.succeed("mkdir -p /nix/var/nix/profiles/per-user/root/channels") + server.succeed("ln -s ${pkgs.path} /nix/var/nix/profiles/per-user/root/channels/nixos") + connect_with_remote_ssh(screenshot="build_node_with_nix", should_succeed=True) + ''; + } +) diff --git a/nixos/tests/vscodium.nix b/nixos/tests/vscodium.nix index b3512ec66107c8..8600ccb814364c 100644 --- a/nixos/tests/vscodium.nix +++ b/nixos/tests/vscodium.nix @@ -1,80 +1,96 @@ let tests = { - wayland = { pkgs, ... }: { - imports = [ ./common/wayland-cage.nix ]; - - # We scale vscodium to help OCR find the small "Untitled" text. - services.cage.program = "${pkgs.vscodium}/bin/codium --force-device-scale-factor=2"; - - environment.variables.NIXOS_OZONE_WL = "1"; - environment.variables.DISPLAY = "do not use"; - - fonts.packages = with pkgs; [ dejavu_fonts ]; - }; - xorg = { pkgs, ... }: { - imports = [ ./common/user-account.nix ./common/x11.nix ]; - - virtualisation.memorySize = 2047; - services.xserver.enable = true; - services.xserver.displayManager.sessionCommands = '' - ${pkgs.vscodium}/bin/codium --force-device-scale-factor=2 - ''; - test-support.displayManager.auto.user = "alice"; - }; - }; + wayland = + { pkgs, ... }: + { + imports = [ ./common/wayland-cage.nix ]; - mkTest = name: machine: - import ./make-test-python.nix ({ pkgs, ... }: { - inherit name; + # We scale vscodium to help OCR find the small "Untitled" text. + services.cage.program = "${pkgs.vscodium}/bin/codium --force-device-scale-factor=2"; - nodes = { "${name}" = machine; }; + environment.variables.NIXOS_OZONE_WL = "1"; + environment.variables.DISPLAY = "do not use"; - meta = with pkgs.lib.maintainers; { - maintainers = [ synthetica turion ]; + fonts.packages = with pkgs; [ dejavu_fonts ]; }; - enableOCR = true; - - testScript = '' - @polling_condition - def codium_running(): - machine.succeed('pgrep -x codium') - - - start_all() - - machine.wait_for_unit('graphical.target') - - codium_running.wait() # type: ignore[union-attr] - with codium_running: # type: ignore[union-attr] - # Wait until vscodium is visible. "File" is in the menu bar. - machine.wait_for_text('Get Started with') - machine.screenshot('start_screen') - - test_string = 'testfile' - - # Create a new file - machine.send_key('ctrl-n') - machine.wait_for_text('Untitled') - machine.screenshot('empty_editor') - - # Type a string - machine.send_chars(test_string) - machine.wait_for_text(test_string) - machine.screenshot('editor') - - # Save the file - machine.send_key('ctrl-s') - machine.wait_for_text('(Save|Desktop|alice|Size)') - machine.screenshot('save_window') - machine.send_key('ret') - - # (the default filename is the first line of the file) - machine.wait_for_file(f'/home/alice/{test_string}') + xorg = + { pkgs, ... }: + { + imports = [ + ./common/user-account.nix + ./common/x11.nix + ]; + + virtualisation.memorySize = 2047; + services.xserver.enable = true; + services.xserver.displayManager.sessionCommands = '' + ${pkgs.vscodium}/bin/codium --force-device-scale-factor=2 + ''; + test-support.displayManager.auto.user = "alice"; + }; + }; - # machine.send_key('ctrl-q') - # machine.wait_until_fails('pgrep -x codium') - ''; - }); + mkTest = + name: machine: + import ./make-test-python.nix ( + { pkgs, ... }: + { + inherit name; + + nodes = { + "${name}" = machine; + }; + + meta = with pkgs.lib.maintainers; { + maintainers = [ + synthetica + turion + ]; + }; + enableOCR = true; + + testScript = '' + @polling_condition + def codium_running(): + machine.succeed('pgrep -x codium') + + + start_all() + + machine.wait_for_unit('graphical.target') + + codium_running.wait() # type: ignore[union-attr] + with codium_running: # type: ignore[union-attr] + # Wait until vscodium is visible. "File" is in the menu bar. + machine.wait_for_text('Get Started with') + machine.screenshot('start_screen') + + test_string = 'testfile' + + # Create a new file + machine.send_key('ctrl-n') + machine.wait_for_text('Untitled') + machine.screenshot('empty_editor') + + # Type a string + machine.send_chars(test_string) + machine.wait_for_text(test_string) + machine.screenshot('editor') + + # Save the file + machine.send_key('ctrl-s') + machine.wait_for_text('(Save|Desktop|alice|Size)') + machine.screenshot('save_window') + machine.send_key('ret') + + # (the default filename is the first line of the file) + machine.wait_for_file(f'/home/alice/{test_string}') + + # machine.send_key('ctrl-q') + # machine.wait_until_fails('pgrep -x codium') + ''; + } + ); in builtins.mapAttrs (k: v: mkTest k v) tests diff --git a/nixos/tests/vsftpd.nix b/nixos/tests/vsftpd.nix index 6eaf32b2258380..816014a10b54f0 100644 --- a/nixos/tests/vsftpd.nix +++ b/nixos/tests/vsftpd.nix @@ -1,42 +1,45 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "vsftpd"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "vsftpd"; - nodes = { - server = { - services.vsftpd = { - enable = true; - userlistDeny = false; - localUsers = true; - userlist = [ "ftp-test-user" ]; - writeEnable = true; - localRoot = "/tmp"; - }; - networking.firewall.enable = false; + nodes = { + server = { + services.vsftpd = { + enable = true; + userlistDeny = false; + localUsers = true; + userlist = [ "ftp-test-user" ]; + writeEnable = true; + localRoot = "/tmp"; + }; + networking.firewall.enable = false; - users = { - users.ftp-test-user = { - isSystemUser = true; - password = "ftp-test-password"; - group = "ftp-test-group"; + users = { + users.ftp-test-user = { + isSystemUser = true; + password = "ftp-test-password"; + group = "ftp-test-group"; + }; + groups.ftp-test-group = { }; }; - groups.ftp-test-group = {}; }; - }; - client = {}; - }; + client = { }; + }; - testScript = '' - client.start() - server.wait_for_unit("vsftpd") - server.wait_for_open_port(21) + testScript = '' + client.start() + server.wait_for_unit("vsftpd") + server.wait_for_open_port(21) - client.succeed("curl -u ftp-test-user:ftp-test-password ftp://server") - client.succeed('echo "this is a test" > /tmp/test.file.up') - client.succeed("curl -v -T /tmp/test.file.up -u ftp-test-user:ftp-test-password ftp://server") - client.succeed("curl -u ftp-test-user:ftp-test-password ftp://server/test.file.up > /tmp/test.file.down") - client.succeed("diff /tmp/test.file.up /tmp/test.file.down") - assert client.succeed("cat /tmp/test.file.up") == server.succeed("cat /tmp/test.file.up") - assert client.succeed("cat /tmp/test.file.down") == server.succeed("cat /tmp/test.file.up") - ''; -}) + client.succeed("curl -u ftp-test-user:ftp-test-password ftp://server") + client.succeed('echo "this is a test" > /tmp/test.file.up') + client.succeed("curl -v -T /tmp/test.file.up -u ftp-test-user:ftp-test-password ftp://server") + client.succeed("curl -u ftp-test-user:ftp-test-password ftp://server/test.file.up > /tmp/test.file.down") + client.succeed("diff /tmp/test.file.up /tmp/test.file.down") + assert client.succeed("cat /tmp/test.file.up") == server.succeed("cat /tmp/test.file.up") + assert client.succeed("cat /tmp/test.file.down") == server.succeed("cat /tmp/test.file.up") + ''; + } +) diff --git a/nixos/tests/warzone2100.nix b/nixos/tests/warzone2100.nix index 568e04a46999d6..4e9572a12c7374 100644 --- a/nixos/tests/warzone2100.nix +++ b/nixos/tests/warzone2100.nix @@ -1,26 +1,30 @@ -import ./make-test-python.nix ({ pkgs, ... }: { - name = "warzone2100"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fgaz ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "warzone2100"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fgaz ]; + }; - nodes.machine = { config, pkgs, ... }: { - imports = [ - ./common/x11.nix - ]; + nodes.machine = + { config, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ]; - services.xserver.enable = true; - environment.systemPackages = [ pkgs.warzone2100 ]; - }; + services.xserver.enable = true; + environment.systemPackages = [ pkgs.warzone2100 ]; + }; - enableOCR = true; + enableOCR = true; - testScript = - '' + testScript = '' machine.wait_for_x() machine.execute("warzone2100 >&2 &") machine.wait_for_window("Warzone 2100") machine.wait_for_text(r"(Single Player|Multi Player|Tutorial|Options|Quit Game)") machine.screenshot("screen") ''; -}) + } +) diff --git a/nixos/tests/wastebin.nix b/nixos/tests/wastebin.nix index 1cf0ff80ae99d3..dde1f658b948fe 100644 --- a/nixos/tests/wastebin.nix +++ b/nixos/tests/wastebin.nix @@ -1,19 +1,24 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "wastebin"; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "wastebin"; - meta = { - maintainers = with lib.maintainers; [ pinpox ]; - }; - - nodes.machine = { pkgs, ... }: { - services.wastebin = { - enable = true; + meta = { + maintainers = with lib.maintainers; [ pinpox ]; }; - }; - testScript = '' - machine.wait_for_unit("wastebin.service") - machine.wait_for_open_port(8088) - machine.succeed("curl --fail http://localhost:8088/") - ''; -}) + nodes.machine = + { pkgs, ... }: + { + services.wastebin = { + enable = true; + }; + }; + + testScript = '' + machine.wait_for_unit("wastebin.service") + machine.wait_for_open_port(8088) + machine.succeed("curl --fail http://localhost:8088/") + ''; + } +) diff --git a/nixos/tests/watchdogd.nix b/nixos/tests/watchdogd.nix index 663e97cbae104a..711cdee65f8e8c 100644 --- a/nixos/tests/watchdogd.nix +++ b/nixos/tests/watchdogd.nix @@ -1,22 +1,27 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "watchdogd"; - meta.maintainers = with lib.maintainers; [ vifino ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "watchdogd"; + meta.maintainers = with lib.maintainers; [ vifino ]; - nodes.machine = { pkgs, ... }: { - virtualisation.qemu.options = [ - "-device i6300esb" # virtual watchdog timer - ]; - boot.kernelModules = [ "i6300esb" ]; - services.watchdogd.enable = true; - services.watchdogd.settings = { - supervisor.enabled = true; - }; - }; + nodes.machine = + { pkgs, ... }: + { + virtualisation.qemu.options = [ + "-device i6300esb" # virtual watchdog timer + ]; + boot.kernelModules = [ "i6300esb" ]; + services.watchdogd.enable = true; + services.watchdogd.settings = { + supervisor.enabled = true; + }; + }; - testScript = '' - machine.wait_for_unit("watchdogd.service") + testScript = '' + machine.wait_for_unit("watchdogd.service") - assert "i6300ESB" in machine.succeed("watchdogctl status") - machine.succeed("watchdogctl test") - ''; -}) + assert "i6300ESB" in machine.succeed("watchdogctl status") + machine.succeed("watchdogctl test") + ''; + } +) diff --git a/nixos/tests/web-apps/gotosocial.nix b/nixos/tests/web-apps/gotosocial.nix index 49e8400533bc77..7edb04ac9df98c 100644 --- a/nixos/tests/web-apps/gotosocial.nix +++ b/nixos/tests/web-apps/gotosocial.nix @@ -3,17 +3,19 @@ name = "gotosocial"; meta.maintainers = with lib.maintainers; [ blakesmith ]; - nodes.machine = { pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; - services.gotosocial = { - enable = true; - setupPostgresqlDB = true; - settings = { - host = "localhost:8081"; - port = 8081; + nodes.machine = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; + services.gotosocial = { + enable = true; + setupPostgresqlDB = true; + settings = { + host = "localhost:8081"; + port = 8081; + }; }; }; - }; testScript = '' machine.wait_for_unit("gotosocial.service") diff --git a/nixos/tests/web-apps/healthchecks.nix b/nixos/tests/web-apps/healthchecks.nix index cb81c8b7365164..1c6755ec922cea 100644 --- a/nixos/tests/web-apps/healthchecks.nix +++ b/nixos/tests/web-apps/healthchecks.nix @@ -1,42 +1,46 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: { - name = "healthchecks"; +import ../make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "healthchecks"; - meta = with lib.maintainers; { - maintainers = [ phaer ]; - }; + meta = with lib.maintainers; { + maintainers = [ phaer ]; + }; - nodes.machine = { ... }: { - services.healthchecks = { - enable = true; - settings = { - SITE_NAME = "MyUniqueInstance"; - COMPRESS_ENABLED = "True"; - SECRET_KEY_FILE = pkgs.writeText "secret" - "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"; + nodes.machine = + { ... }: + { + services.healthchecks = { + enable = true; + settings = { + SITE_NAME = "MyUniqueInstance"; + COMPRESS_ENABLED = "True"; + SECRET_KEY_FILE = pkgs.writeText "secret" "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"; + }; + }; }; - }; - }; - testScript = '' - machine.start() - machine.wait_for_unit("healthchecks.target") - machine.wait_until_succeeds("journalctl --since -1m --unit healthchecks --grep Listening") + testScript = '' + machine.start() + machine.wait_for_unit("healthchecks.target") + machine.wait_until_succeeds("journalctl --since -1m --unit healthchecks --grep Listening") - with subtest("Home screen loads"): - machine.succeed( - "curl -sSfL http://localhost:8000 | grep '<title>Log In'" - ) + with subtest("Home screen loads"): + machine.succeed( + "curl -sSfL http://localhost:8000 | grep '<title>Log In'" + ) - with subtest("Setting SITE_NAME via freeform option works"): - machine.succeed( - "curl -sSfL http://localhost:8000 | grep 'MyUniqueInstance'" - ) + with subtest("Setting SITE_NAME via freeform option works"): + machine.succeed( + "curl -sSfL http://localhost:8000 | grep 'MyUniqueInstance'" + ) - with subtest("Manage script works"): - # "shell" sucommand should succeed, needs python in PATH. - assert "foo\n" == machine.succeed("echo 'print(\"foo\")' | sudo -u healthchecks healthchecks-manage shell") + with subtest("Manage script works"): + # "shell" sucommand should succeed, needs python in PATH. + assert "foo\n" == machine.succeed("echo 'print(\"foo\")' | sudo -u healthchecks healthchecks-manage shell") - # Shouldn't fail if not called by healthchecks user - assert "foo\n" == machine.succeed("echo 'print(\"foo\")' | healthchecks-manage shell") - ''; -}) + # Shouldn't fail if not called by healthchecks user + assert "foo\n" == machine.succeed("echo 'print(\"foo\")' | healthchecks-manage shell") + ''; + } +) diff --git a/nixos/tests/web-apps/mastodon/default.nix b/nixos/tests/web-apps/mastodon/default.nix index 7f925b9ad4ed21..b563b8cde97817 100644 --- a/nixos/tests/web-apps/mastodon/default.nix +++ b/nixos/tests/web-apps/mastodon/default.nix @@ -1,6 +1,15 @@ -{ system ? builtins.currentSystem, pkgs, handleTestOn, ... }: +{ + system ? builtins.currentSystem, + pkgs, + handleTestOn, + ... +}: let - supportedSystems = [ "x86_64-linux" "i686-linux" "aarch64-linux" ]; + supportedSystems = [ + "x86_64-linux" + "i686-linux" + "aarch64-linux" + ]; in { diff --git a/nixos/tests/web-apps/mastodon/remote-databases.nix b/nixos/tests/web-apps/mastodon/remote-databases.nix index 8dc754fe9eb09f..24709fe0df07f3 100644 --- a/nixos/tests/web-apps/mastodon/remote-databases.nix +++ b/nixos/tests/web-apps/mastodon/remote-databases.nix @@ -1,190 +1,220 @@ -import ../../make-test-python.nix ({pkgs, ...}: -let - cert = pkgs: pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' - openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=mastodon.local' -days 36500 - mkdir -p $out - cp key.pem cert.pem $out - ''; - - hosts = '' - 192.168.2.103 mastodon.local - ''; - - postgresqlPassword = "thisisnotasecret"; - redisPassword = "thisisnotasecrettoo"; - -in -{ - name = "mastodon-remote-postgresql"; - meta.maintainers = with pkgs.lib.maintainers; [ erictapen izorkin ]; - - nodes = { - databases = { config, ... }: { - environment = { - etc = { - "redis/password-redis-db".text = redisPassword; - }; - }; - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.102"; prefixLength = 24; } - ]; - }; - extraHosts = hosts; - firewall.allowedTCPPorts = [ - config.services.redis.servers.mastodon.port - config.services.postgresql.settings.port - ]; - }; - - services.redis.servers.mastodon = { - enable = true; - bind = "0.0.0.0"; - port = 31637; - requirePassFile = "/etc/redis/password-redis-db"; - }; - - services.postgresql = { - enable = true; - enableTCPIP = true; - authentication = '' - hostnossl mastodon mastodon 192.168.2.201/32 md5 - ''; - ensureDatabases = [ "mastodon" ]; - ensureUsers = [ - { - name = "mastodon"; - ensureDBOwnership = true; - } - ]; - initialScript = pkgs.writeText "postgresql_init.sql" '' - CREATE ROLE mastodon LOGIN PASSWORD '${postgresqlPassword}'; - ''; - }; - }; +import ../../make-test-python.nix ( + { pkgs, ... }: + let + cert = + pkgs: + pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' + openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=mastodon.local' -days 36500 + mkdir -p $out + cp key.pem cert.pem $out + ''; + + hosts = '' + 192.168.2.103 mastodon.local + ''; - nginx = { nodes, ... }: { - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.103"; prefixLength = 24; } - ]; - }; - extraHosts = hosts; - firewall.allowedTCPPorts = [ 80 443 ]; - }; - - security = { - pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; - }; - - services.nginx = { - enable = true; - recommendedProxySettings = true; - virtualHosts."mastodon.local" = { - root = "/var/empty"; - forceSSL = true; - enableACME = pkgs.lib.mkForce false; - sslCertificate = "${cert pkgs}/cert.pem"; - sslCertificateKey = "${cert pkgs}/key.pem"; - locations."/" = { - tryFiles = "$uri @proxy"; + postgresqlPassword = "thisisnotasecret"; + redisPassword = "thisisnotasecrettoo"; + + in + { + name = "mastodon-remote-postgresql"; + meta.maintainers = with pkgs.lib.maintainers; [ + erictapen + izorkin + ]; + + nodes = { + databases = + { config, ... }: + { + environment = { + etc = { + "redis/password-redis-db".text = redisPassword; + }; }; - locations."@proxy" = { - proxyPass = "http://192.168.2.201:${toString nodes.server.services.mastodon.webPort}"; - proxyWebsockets = true; + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.102"; + prefixLength = 24; + } + ]; + }; + extraHosts = hosts; + firewall.allowedTCPPorts = [ + config.services.redis.servers.mastodon.port + config.services.postgresql.settings.port + ]; }; - }; - }; - }; - server = { config, pkgs, ... }: { - virtualisation.memorySize = 2048; + services.redis.servers.mastodon = { + enable = true; + bind = "0.0.0.0"; + port = 31637; + requirePassFile = "/etc/redis/password-redis-db"; + }; - environment = { - etc = { - "mastodon/password-redis-db".text = redisPassword; - "mastodon/password-posgressql-db".text = postgresqlPassword; + services.postgresql = { + enable = true; + enableTCPIP = true; + authentication = '' + hostnossl mastodon mastodon 192.168.2.201/32 md5 + ''; + ensureDatabases = [ "mastodon" ]; + ensureUsers = [ + { + name = "mastodon"; + ensureDBOwnership = true; + } + ]; + initialScript = pkgs.writeText "postgresql_init.sql" '' + CREATE ROLE mastodon LOGIN PASSWORD '${postgresqlPassword}'; + ''; + }; }; - }; - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.201"; prefixLength = 24; } - ]; - }; - extraHosts = hosts; - firewall.allowedTCPPorts = [ - config.services.mastodon.webPort - config.services.mastodon.sidekiqPort - ]; - }; - - services.mastodon = { - enable = true; - configureNginx = false; - localDomain = "mastodon.local"; - enableUnixSocket = false; - streamingProcesses = 2; - redis = { - createLocally = false; - host = "192.168.2.102"; - port = 31637; - passwordFile = "/etc/mastodon/password-redis-db"; - }; - database = { - createLocally = false; - host = "192.168.2.102"; - port = 5432; - name = "mastodon"; - user = "mastodon"; - passwordFile = "/etc/mastodon/password-posgressql-db"; - }; - smtp = { - createLocally = false; - fromAddress = "mastodon@mastodon.local"; + nginx = + { nodes, ... }: + { + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.103"; + prefixLength = 24; + } + ]; + }; + extraHosts = hosts; + firewall.allowedTCPPorts = [ + 80 + 443 + ]; + }; + + security = { + pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; + }; + + services.nginx = { + enable = true; + recommendedProxySettings = true; + virtualHosts."mastodon.local" = { + root = "/var/empty"; + forceSSL = true; + enableACME = pkgs.lib.mkForce false; + sslCertificate = "${cert pkgs}/cert.pem"; + sslCertificateKey = "${cert pkgs}/key.pem"; + locations."/" = { + tryFiles = "$uri @proxy"; + }; + locations."@proxy" = { + proxyPass = "http://192.168.2.201:${toString nodes.server.services.mastodon.webPort}"; + proxyWebsockets = true; + }; + }; + }; }; - extraConfig = { - BIND = "0.0.0.0"; - EMAIL_DOMAIN_ALLOWLIST = "example.com"; - RAILS_SERVE_STATIC_FILES = "true"; - TRUSTED_PROXY_IP = "192.168.2.103"; + + server = + { config, pkgs, ... }: + { + virtualisation.memorySize = 2048; + + environment = { + etc = { + "mastodon/password-redis-db".text = redisPassword; + "mastodon/password-posgressql-db".text = postgresqlPassword; + }; + }; + + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.201"; + prefixLength = 24; + } + ]; + }; + extraHosts = hosts; + firewall.allowedTCPPorts = [ + config.services.mastodon.webPort + config.services.mastodon.sidekiqPort + ]; + }; + + services.mastodon = { + enable = true; + configureNginx = false; + localDomain = "mastodon.local"; + enableUnixSocket = false; + streamingProcesses = 2; + redis = { + createLocally = false; + host = "192.168.2.102"; + port = 31637; + passwordFile = "/etc/mastodon/password-redis-db"; + }; + database = { + createLocally = false; + host = "192.168.2.102"; + port = 5432; + name = "mastodon"; + user = "mastodon"; + passwordFile = "/etc/mastodon/password-posgressql-db"; + }; + smtp = { + createLocally = false; + fromAddress = "mastodon@mastodon.local"; + }; + extraConfig = { + BIND = "0.0.0.0"; + EMAIL_DOMAIN_ALLOWLIST = "example.com"; + RAILS_SERVE_STATIC_FILES = "true"; + TRUSTED_PROXY_IP = "192.168.2.103"; + }; + }; }; - }; - }; - client = { pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.202"; prefixLength = 24; } - ]; + client = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.202"; + prefixLength = 24; + } + ]; + }; + extraHosts = hosts; + }; + + security = { + pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; + }; }; - extraHosts = hosts; - }; + }; - security = { - pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; - }; + testScript = import ./script.nix { + inherit pkgs; + extraInit = '' + nginx.wait_for_unit("nginx.service") + nginx.wait_for_open_port(443) + databases.wait_for_unit("redis-mastodon.service") + databases.wait_for_unit("postgresql.service") + databases.wait_for_open_port(31637) + databases.wait_for_open_port(5432) + ''; + extraShutdown = '' + nginx.shutdown() + databases.shutdown() + ''; }; - }; - - testScript = import ./script.nix { - inherit pkgs; - extraInit = '' - nginx.wait_for_unit("nginx.service") - nginx.wait_for_open_port(443) - databases.wait_for_unit("redis-mastodon.service") - databases.wait_for_unit("postgresql.service") - databases.wait_for_open_port(31637) - databases.wait_for_open_port(5432) - ''; - extraShutdown = '' - nginx.shutdown() - databases.shutdown() - ''; - }; -}) + } +) diff --git a/nixos/tests/web-apps/mastodon/script.nix b/nixos/tests/web-apps/mastodon/script.nix index 9184c63c89419a..be6cbc87ae9bc8 100644 --- a/nixos/tests/web-apps/mastodon/script.nix +++ b/nixos/tests/web-apps/mastodon/script.nix @@ -1,6 +1,7 @@ -{ pkgs -, extraInit ? "" -, extraShutdown ? "" +{ + pkgs, + extraInit ? "", + extraShutdown ? "", }: '' diff --git a/nixos/tests/web-apps/mastodon/standard.nix b/nixos/tests/web-apps/mastodon/standard.nix index cd720ce9f2bfc9..3437900741a965 100644 --- a/nixos/tests/web-apps/mastodon/standard.nix +++ b/nixos/tests/web-apps/mastodon/standard.nix @@ -1,88 +1,109 @@ -import ../../make-test-python.nix ({pkgs, ...}: -let - cert = pkgs: pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' - openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=mastodon.local' -days 36500 - mkdir -p $out - cp key.pem cert.pem $out - ''; +import ../../make-test-python.nix ( + { pkgs, ... }: + let + cert = + pkgs: + pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' + openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=mastodon.local' -days 36500 + mkdir -p $out + cp key.pem cert.pem $out + ''; - hosts = '' - 192.168.2.101 mastodon.local - ''; + hosts = '' + 192.168.2.101 mastodon.local + ''; -in -{ - name = "mastodon-standard"; - meta.maintainers = with pkgs.lib.maintainers; [ erictapen izorkin turion ]; + in + { + name = "mastodon-standard"; + meta.maintainers = with pkgs.lib.maintainers; [ + erictapen + izorkin + turion + ]; - nodes = { - server = { pkgs, ... }: { + nodes = { + server = + { pkgs, ... }: + { - virtualisation.memorySize = 2048; + virtualisation.memorySize = 2048; - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.101"; prefixLength = 24; } - ]; - }; - extraHosts = hosts; - firewall.allowedTCPPorts = [ 80 443 ]; - }; + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.101"; + prefixLength = 24; + } + ]; + }; + extraHosts = hosts; + firewall.allowedTCPPorts = [ + 80 + 443 + ]; + }; - security = { - pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; - }; + security = { + pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; + }; - services.mastodon = { - enable = true; - configureNginx = true; - localDomain = "mastodon.local"; - enableUnixSocket = false; - streamingProcesses = 2; - smtp = { - createLocally = false; - fromAddress = "mastodon@mastodon.local"; - }; - extraConfig = { - EMAIL_DOMAIN_ALLOWLIST = "example.com"; - }; - }; + services.mastodon = { + enable = true; + configureNginx = true; + localDomain = "mastodon.local"; + enableUnixSocket = false; + streamingProcesses = 2; + smtp = { + createLocally = false; + fromAddress = "mastodon@mastodon.local"; + }; + extraConfig = { + EMAIL_DOMAIN_ALLOWLIST = "example.com"; + }; + }; - services.nginx = { - virtualHosts."mastodon.local" = { - enableACME = pkgs.lib.mkForce false; - sslCertificate = "${cert pkgs}/cert.pem"; - sslCertificateKey = "${cert pkgs}/key.pem"; + services.nginx = { + virtualHosts."mastodon.local" = { + enableACME = pkgs.lib.mkForce false; + sslCertificate = "${cert pkgs}/cert.pem"; + sslCertificateKey = "${cert pkgs}/key.pem"; + }; + }; }; - }; - }; - client = { pkgs, ... }: { - environment.systemPackages = [ pkgs.jq ]; - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.102"; prefixLength = 24; } - ]; - }; - extraHosts = hosts; - }; + client = + { pkgs, ... }: + { + environment.systemPackages = [ pkgs.jq ]; + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.102"; + prefixLength = 24; + } + ]; + }; + extraHosts = hosts; + }; - security = { - pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; - }; + security = { + pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; + }; + }; }; - }; - testScript = import ./script.nix { - inherit pkgs; - extraInit = '' - server.wait_for_unit("nginx.service") - server.wait_for_open_port(443) - server.wait_for_unit("redis-mastodon.service") - server.wait_for_unit("postgresql.service") - server.wait_for_open_port(5432) - ''; - }; -}) + testScript = import ./script.nix { + inherit pkgs; + extraInit = '' + server.wait_for_unit("nginx.service") + server.wait_for_open_port(443) + server.wait_for_unit("redis-mastodon.service") + server.wait_for_unit("postgresql.service") + server.wait_for_open_port(5432) + ''; + }; + } +) diff --git a/nixos/tests/web-apps/monica.nix b/nixos/tests/web-apps/monica.nix index 29f5cb85bb13a4..bb770828d5f790 100644 --- a/nixos/tests/web-apps/monica.nix +++ b/nixos/tests/web-apps/monica.nix @@ -1,33 +1,37 @@ -import ../make-test-python.nix ({pkgs, ...}: -let - cert = pkgs.runCommand "selfSignedCerts" { nativeBuildInputs = [ pkgs.openssl ]; } '' - openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=localhost' -days 36500 - mkdir -p $out - cp key.pem cert.pem $out - ''; -in -{ - name = "monica"; +import ../make-test-python.nix ( + { pkgs, ... }: + let + cert = pkgs.runCommand "selfSignedCerts" { nativeBuildInputs = [ pkgs.openssl ]; } '' + openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=localhost' -days 36500 + mkdir -p $out + cp key.pem cert.pem $out + ''; + in + { + name = "monica"; - nodes = { - machine = {pkgs, ...}: { - services.monica = { - enable = true; - hostname = "localhost"; - appKeyFile = "${pkgs.writeText "keyfile" "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"}"; - nginx = { - forceSSL = true; - sslCertificate = "${cert}/cert.pem"; - sslCertificateKey = "${cert}/key.pem"; + nodes = { + machine = + { pkgs, ... }: + { + services.monica = { + enable = true; + hostname = "localhost"; + appKeyFile = "${pkgs.writeText "keyfile" "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"}"; + nginx = { + forceSSL = true; + sslCertificate = "${cert}/cert.pem"; + sslCertificateKey = "${cert}/key.pem"; + }; + }; }; - }; }; - }; - testScript = '' - start_all() - machine.wait_for_unit("monica-setup.service") - machine.wait_for_open_port(443) - machine.succeed("curl -k --fail https://localhost", timeout=10) - ''; -}) + testScript = '' + start_all() + machine.wait_for_unit("monica-setup.service") + machine.wait_for_open_port(443) + machine.succeed("curl -k --fail https://localhost", timeout=10) + ''; + } +) diff --git a/nixos/tests/web-apps/movim/default.nix b/nixos/tests/web-apps/movim/default.nix index 5d6314e2b41be4..8274a390990ea1 100644 --- a/nixos/tests/web-apps/movim/default.nix +++ b/nixos/tests/web-apps/movim/default.nix @@ -1,7 +1,13 @@ -{ system ? builtins.currentSystem, handleTestOn }: +{ + system ? builtins.currentSystem, + handleTestOn, +}: let - supportedSystems = [ "x86_64-linux" "i686-linux" ]; + supportedSystems = [ + "x86_64-linux" + "i686-linux" + ]; in { standard = handleTestOn supportedSystems ./standard.nix { inherit system; }; diff --git a/nixos/tests/web-apps/movim/standard.nix b/nixos/tests/web-apps/movim/standard.nix index 470d81d8f7229f..1207000b922b47 100644 --- a/nixos/tests/web-apps/movim/standard.nix +++ b/nixos/tests/web-apps/movim/standard.nix @@ -1,102 +1,110 @@ -import ../../make-test-python.nix ({ lib, pkgs, ... }: +import ../../make-test-python.nix ( + { lib, pkgs, ... }: -let - movim = { - domain = "movim.local"; - info = "No ToS in tests"; - description = "NixOS testing server"; - }; - xmpp = { - domain = "xmpp.local"; - admin = rec { - JID = "${username}@${xmpp.domain}"; - username = "romeo"; - password = "juliet"; + let + movim = { + domain = "movim.local"; + info = "No ToS in tests"; + description = "NixOS testing server"; }; - }; -in -{ - name = "movim-standard"; + xmpp = { + domain = "xmpp.local"; + admin = rec { + JID = "${username}@${xmpp.domain}"; + username = "romeo"; + password = "juliet"; + }; + }; + in + { + name = "movim-standard"; - meta = { - maintainers = with pkgs.lib.maintainers; [ toastal ]; - }; + meta = { + maintainers = with pkgs.lib.maintainers; [ toastal ]; + }; - nodes = { - server = { pkgs, ... }: { - services.movim = { - inherit (movim) domain; - enable = true; - verbose = true; - podConfig = { - inherit (movim) description info; - xmppdomain = xmpp.domain; - }; - nginx = { }; - }; + nodes = { + server = + { pkgs, ... }: + { + services.movim = { + inherit (movim) domain; + enable = true; + verbose = true; + podConfig = { + inherit (movim) description info; + xmppdomain = xmpp.domain; + }; + nginx = { }; + }; - services.prosody = { - enable = true; - xmppComplianceSuite = false; - disco_items = [ - { url = "upload.${xmpp.domain}"; description = "File Uploads"; } - ]; - virtualHosts."${xmpp.domain}" = { - inherit (xmpp) domain; - enabled = true; - extraConfig = '' - Component "pubsub.${xmpp.domain}" "pubsub" - pubsub_max_items = 10000 - expose_publisher = true + services.prosody = { + enable = true; + xmppComplianceSuite = false; + disco_items = [ + { + url = "upload.${xmpp.domain}"; + description = "File Uploads"; + } + ]; + virtualHosts."${xmpp.domain}" = { + inherit (xmpp) domain; + enabled = true; + extraConfig = '' + Component "pubsub.${xmpp.domain}" "pubsub" + pubsub_max_items = 10000 + expose_publisher = true - Component "upload.${xmpp.domain}" "http_file_share" - http_external_url = "http://upload.${xmpp.domain}" - http_file_share_expires_after = 300 * 24 * 60 * 60 - http_file_share_size_limit = 1024 * 1024 * 1024 - http_file_share_daily_quota = 4 * 1024 * 1024 * 1024 - ''; - }; - extraConfig = '' - pep_max_items = 10000 + Component "upload.${xmpp.domain}" "http_file_share" + http_external_url = "http://upload.${xmpp.domain}" + http_file_share_expires_after = 300 * 24 * 60 * 60 + http_file_share_size_limit = 1024 * 1024 * 1024 + http_file_share_daily_quota = 4 * 1024 * 1024 * 1024 + ''; + }; + extraConfig = '' + pep_max_items = 10000 - http_paths = { - file_share = "/"; - } - ''; - }; + http_paths = { + file_share = "/"; + } + ''; + }; - networking.extraHosts = '' - 127.0.0.1 ${movim.domain} - 127.0.0.1 ${xmpp.domain} - ''; + networking.extraHosts = '' + 127.0.0.1 ${movim.domain} + 127.0.0.1 ${xmpp.domain} + ''; + }; }; - }; - testScript = /* python */ '' - server.wait_for_unit("phpfpm-movim.service") - server.wait_for_unit("nginx.service") - server.wait_for_open_port(80) + testScript = # python + '' + server.wait_for_unit("phpfpm-movim.service") + server.wait_for_unit("nginx.service") + server.wait_for_open_port(80) - server.wait_for_unit("prosody.service") - server.succeed('prosodyctl status | grep "Prosody is running"') - server.succeed("prosodyctl register ${xmpp.admin.username} ${xmpp.domain} ${xmpp.admin.password}") + server.wait_for_unit("prosody.service") + server.succeed('prosodyctl status | grep "Prosody is running"') + server.succeed("prosodyctl register ${xmpp.admin.username} ${xmpp.domain} ${xmpp.admin.password}") - server.wait_for_unit("movim.service") + server.wait_for_unit("movim.service") - # Test unauthenticated - server.fail("curl -L --fail-with-body --max-redirs 0 http://${movim.domain}/chat") + # Test unauthenticated + server.fail("curl -L --fail-with-body --max-redirs 0 http://${movim.domain}/chat") - # Test basic Websocket - server.succeed("echo \"\" | ${lib.getExe pkgs.websocat} 'ws://${movim.domain}/ws/?path=login&offset=0' --origin 'http://${movim.domain}'") + # Test basic Websocket + server.succeed("echo \"\" | ${lib.getExe pkgs.websocat} 'ws://${movim.domain}/ws/?path=login&offset=0' --origin 'http://${movim.domain}'") - # Test login + create cookiejar - login_html = server.succeed("curl --fail-with-body -c /tmp/cookies http://${movim.domain}/login") - assert "${movim.description}" in login_html - assert "${movim.info}" in login_html + # Test login + create cookiejar + login_html = server.succeed("curl --fail-with-body -c /tmp/cookies http://${movim.domain}/login") + assert "${movim.description}" in login_html + assert "${movim.info}" in login_html - # Test authentication POST - server.succeed("curl --fail-with-body -b /tmp/cookies -X POST --data-urlencode 'username=${xmpp.admin.JID}' --data-urlencode 'password=${xmpp.admin.password}' http://${movim.domain}/login") + # Test authentication POST + server.succeed("curl --fail-with-body -b /tmp/cookies -X POST --data-urlencode 'username=${xmpp.admin.JID}' --data-urlencode 'password=${xmpp.admin.password}' http://${movim.domain}/login") - server.succeed("curl -L --fail-with-body --max-redirs 1 -b /tmp/cookies http://${movim.domain}/chat") - ''; -}) + server.succeed("curl -L --fail-with-body --max-redirs 1 -b /tmp/cookies http://${movim.domain}/chat") + ''; + } +) diff --git a/nixos/tests/web-apps/netbox-upgrade.nix b/nixos/tests/web-apps/netbox-upgrade.nix index b43313bc8a774b..cc044b76f0b371 100644 --- a/nixos/tests/web-apps/netbox-upgrade.nix +++ b/nixos/tests/web-apps/netbox-upgrade.nix @@ -1,89 +1,101 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: let - oldNetbox = pkgs.netbox_3_7; - newNetbox = pkgs.netbox_4_1; -in { - name = "netbox-upgrade"; +import ../make-test-python.nix ( + { lib, pkgs, ... }: + let + oldNetbox = pkgs.netbox_3_7; + newNetbox = pkgs.netbox_4_1; + in + { + name = "netbox-upgrade"; - meta = with lib.maintainers; { - maintainers = [ minijackson raitobezarius ]; - }; - - nodes.machine = { config, ... }: { - virtualisation.memorySize = 2048; - services.netbox = { - enable = true; - package = oldNetbox; - secretKeyFile = pkgs.writeText "secret" '' - abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789 - ''; + meta = with lib.maintainers; { + maintainers = [ + minijackson + raitobezarius + ]; }; - services.nginx = { - enable = true; + nodes.machine = + { config, ... }: + { + virtualisation.memorySize = 2048; + services.netbox = { + enable = true; + package = oldNetbox; + secretKeyFile = pkgs.writeText "secret" '' + abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789 + ''; + }; - recommendedProxySettings = true; + services.nginx = { + enable = true; - virtualHosts.netbox = { - default = true; - locations."/".proxyPass = "http://localhost:${toString config.services.netbox.port}"; - locations."/static/".alias = "/var/lib/netbox/static/"; - }; - }; + recommendedProxySettings = true; - users.users.nginx.extraGroups = [ "netbox" ]; + virtualHosts.netbox = { + default = true; + locations."/".proxyPass = "http://localhost:${toString config.services.netbox.port}"; + locations."/static/".alias = "/var/lib/netbox/static/"; + }; + }; - networking.firewall.allowedTCPPorts = [ 80 ]; + users.users.nginx.extraGroups = [ "netbox" ]; - specialisation.upgrade.configuration.services.netbox.package = lib.mkForce newNetbox; - }; + networking.firewall.allowedTCPPorts = [ 80 ]; - testScript = { nodes, ... }: - let - apiVersion = version: lib.pipe version [ - (lib.splitString ".") - (lib.take 2) - (lib.concatStringsSep ".") - ]; - oldApiVersion = apiVersion oldNetbox.version; - newApiVersion = apiVersion newNetbox.version; - in - '' - start_all() - machine.wait_for_unit("netbox.target") - machine.wait_for_unit("nginx.service") - machine.wait_until_succeeds("journalctl --since -1m --unit netbox --grep Listening") + specialisation.upgrade.configuration.services.netbox.package = lib.mkForce newNetbox; + }; - def api_version(headers): - header = [header for header in headers.splitlines() if header.startswith("API-Version:")][0] - return header.split()[1] + testScript = + { nodes, ... }: + let + apiVersion = + version: + lib.pipe version [ + (lib.splitString ".") + (lib.take 2) + (lib.concatStringsSep ".") + ]; + oldApiVersion = apiVersion oldNetbox.version; + newApiVersion = apiVersion newNetbox.version; + in + '' + start_all() + machine.wait_for_unit("netbox.target") + machine.wait_for_unit("nginx.service") + machine.wait_until_succeeds("journalctl --since -1m --unit netbox --grep Listening") - def check_api_version(version): - # Returns 403 with NetBox >= 4.0, - # but we still get the API version in the headers - headers = machine.succeed( - "curl -sSL http://localhost/api/ --head -H 'Content-Type: application/json'" - ) - assert api_version(headers) == version + def api_version(headers): + header = [header for header in headers.splitlines() if header.startswith("API-Version:")][0] + return header.split()[1] - with subtest("NetBox version is the old one"): - check_api_version("${oldApiVersion}") + def check_api_version(version): + # Returns 403 with NetBox >= 4.0, + # but we still get the API version in the headers + headers = machine.succeed( + "curl -sSL http://localhost/api/ --head -H 'Content-Type: application/json'" + ) + assert api_version(headers) == version - # Somehow, even though netbox-housekeeping.service has After=netbox.service, - # netbox-housekeeping.service and netbox.service still get started at the - # same time, making netbox-housekeeping fail (can't really do some house - # keeping job if the database is not correctly formed). - # - # So we don't check that the upgrade went well, we just check that - # netbox.service is active, and that netbox-housekeeping can be run - # successfully afterwards. - # - # This is not good UX, but the system should be working nonetheless. - machine.execute("${nodes.machine.system.build.toplevel}/specialisation/upgrade/bin/switch-to-configuration test >&2") + with subtest("NetBox version is the old one"): + check_api_version("${oldApiVersion}") - machine.wait_for_unit("netbox.service") - machine.succeed("systemctl start netbox-housekeeping.service") + # Somehow, even though netbox-housekeeping.service has After=netbox.service, + # netbox-housekeeping.service and netbox.service still get started at the + # same time, making netbox-housekeeping fail (can't really do some house + # keeping job if the database is not correctly formed). + # + # So we don't check that the upgrade went well, we just check that + # netbox.service is active, and that netbox-housekeeping can be run + # successfully afterwards. + # + # This is not good UX, but the system should be working nonetheless. + machine.execute("${nodes.machine.system.build.toplevel}/specialisation/upgrade/bin/switch-to-configuration test >&2") - with subtest("NetBox version is the new one"): - check_api_version("${newApiVersion}") - ''; -}) + machine.wait_for_unit("netbox.service") + machine.succeed("systemctl start netbox-housekeeping.service") + + with subtest("NetBox version is the new one"): + check_api_version("${newApiVersion}") + ''; + } +) diff --git a/nixos/tests/web-apps/netbox.nix b/nixos/tests/web-apps/netbox.nix index 2fdd70cfb1bfcd..3aee8d964844b1 100644 --- a/nixos/tests/web-apps/netbox.nix +++ b/nixos/tests/web-apps/netbox.nix @@ -8,306 +8,325 @@ let testUser = "alice"; testPassword = "verySecure"; testGroup = "netbox-users"; -in import ../make-test-python.nix ({ lib, pkgs, netbox, ... }: { - name = "netbox"; - - meta = with lib.maintainers; { - maintainers = [ minijackson n0emis ]; - }; - - nodes.machine = { config, ... }: { - virtualisation.memorySize = 2048; - services.netbox = { - enable = true; - package = netbox; - secretKeyFile = pkgs.writeText "secret" '' - abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789 - ''; - - enableLdap = true; - ldapConfigPath = pkgs.writeText "ldap_config.py" '' - import ldap - from django_auth_ldap.config import LDAPSearch, PosixGroupType - - AUTH_LDAP_SERVER_URI = "ldap://localhost/" +in +import ../make-test-python.nix ( + { + lib, + pkgs, + netbox, + ... + }: + { + name = "netbox"; + + meta = with lib.maintainers; { + maintainers = [ + minijackson + n0emis + ]; + }; - AUTH_LDAP_USER_SEARCH = LDAPSearch( - "ou=accounts,ou=posix,${ldapSuffix}", - ldap.SCOPE_SUBTREE, - "(uid=%(user)s)", - ) + nodes.machine = + { config, ... }: + { + virtualisation.memorySize = 2048; + services.netbox = { + enable = true; + package = netbox; + secretKeyFile = pkgs.writeText "secret" '' + abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789 + ''; + + enableLdap = true; + ldapConfigPath = pkgs.writeText "ldap_config.py" '' + import ldap + from django_auth_ldap.config import LDAPSearch, PosixGroupType + + AUTH_LDAP_SERVER_URI = "ldap://localhost/" + + AUTH_LDAP_USER_SEARCH = LDAPSearch( + "ou=accounts,ou=posix,${ldapSuffix}", + ldap.SCOPE_SUBTREE, + "(uid=%(user)s)", + ) - AUTH_LDAP_GROUP_SEARCH = LDAPSearch( - "ou=groups,ou=posix,${ldapSuffix}", - ldap.SCOPE_SUBTREE, - "(objectClass=posixGroup)", - ) - AUTH_LDAP_GROUP_TYPE = PosixGroupType() + AUTH_LDAP_GROUP_SEARCH = LDAPSearch( + "ou=groups,ou=posix,${ldapSuffix}", + ldap.SCOPE_SUBTREE, + "(objectClass=posixGroup)", + ) + AUTH_LDAP_GROUP_TYPE = PosixGroupType() - # Mirror LDAP group assignments. - AUTH_LDAP_MIRROR_GROUPS = True + # Mirror LDAP group assignments. + AUTH_LDAP_MIRROR_GROUPS = True - # For more granular permissions, we can map LDAP groups to Django groups. - AUTH_LDAP_FIND_GROUP_PERMS = True - ''; - }; + # For more granular permissions, we can map LDAP groups to Django groups. + AUTH_LDAP_FIND_GROUP_PERMS = True + ''; + }; - services.nginx = { - enable = true; + services.nginx = { + enable = true; - recommendedProxySettings = true; + recommendedProxySettings = true; - virtualHosts.netbox = { - default = true; - locations."/".proxyPass = "http://localhost:${toString config.services.netbox.port}"; - locations."/static/".alias = "/var/lib/netbox/static/"; - }; - }; + virtualHosts.netbox = { + default = true; + locations."/".proxyPass = "http://localhost:${toString config.services.netbox.port}"; + locations."/static/".alias = "/var/lib/netbox/static/"; + }; + }; - # Adapted from the sssd-ldap NixOS test - services.openldap = { - enable = true; - settings = { - children = { - "cn=schema".includes = [ - "${pkgs.openldap}/etc/schema/core.ldif" - "${pkgs.openldap}/etc/schema/cosine.ldif" - "${pkgs.openldap}/etc/schema/inetorgperson.ldif" - "${pkgs.openldap}/etc/schema/nis.ldif" - ]; - "olcDatabase={1}mdb" = { - attrs = { - objectClass = [ "olcDatabaseConfig" "olcMdbConfig" ]; - olcDatabase = "{1}mdb"; - olcDbDirectory = "/var/lib/openldap/db"; - olcSuffix = ldapSuffix; - olcRootDN = "cn=${ldapRootUser},${ldapSuffix}"; - olcRootPW = ldapRootPassword; + # Adapted from the sssd-ldap NixOS test + services.openldap = { + enable = true; + settings = { + children = { + "cn=schema".includes = [ + "${pkgs.openldap}/etc/schema/core.ldif" + "${pkgs.openldap}/etc/schema/cosine.ldif" + "${pkgs.openldap}/etc/schema/inetorgperson.ldif" + "${pkgs.openldap}/etc/schema/nis.ldif" + ]; + "olcDatabase={1}mdb" = { + attrs = { + objectClass = [ + "olcDatabaseConfig" + "olcMdbConfig" + ]; + olcDatabase = "{1}mdb"; + olcDbDirectory = "/var/lib/openldap/db"; + olcSuffix = ldapSuffix; + olcRootDN = "cn=${ldapRootUser},${ldapSuffix}"; + olcRootPW = ldapRootPassword; + }; + }; }; }; + declarativeContents = { + ${ldapSuffix} = '' + dn: ${ldapSuffix} + objectClass: top + objectClass: dcObject + objectClass: organization + o: ${ldapDomain} + + dn: ou=posix,${ldapSuffix} + objectClass: top + objectClass: organizationalUnit + + dn: ou=accounts,ou=posix,${ldapSuffix} + objectClass: top + objectClass: organizationalUnit + + dn: uid=${testUser},ou=accounts,ou=posix,${ldapSuffix} + objectClass: person + objectClass: posixAccount + userPassword: ${testPassword} + homeDirectory: /home/${testUser} + uidNumber: 1234 + gidNumber: 1234 + cn: "" + sn: "" + + dn: ou=groups,ou=posix,${ldapSuffix} + objectClass: top + objectClass: organizationalUnit + + dn: cn=${testGroup},ou=groups,ou=posix,${ldapSuffix} + objectClass: posixGroup + gidNumber: 2345 + memberUid: ${testUser} + ''; + }; }; + + users.users.nginx.extraGroups = [ "netbox" ]; + + networking.firewall.allowedTCPPorts = [ 80 ]; }; - declarativeContents = { - ${ldapSuffix} = '' - dn: ${ldapSuffix} - objectClass: top - objectClass: dcObject - objectClass: organization - o: ${ldapDomain} - - dn: ou=posix,${ldapSuffix} - objectClass: top - objectClass: organizationalUnit - - dn: ou=accounts,ou=posix,${ldapSuffix} - objectClass: top - objectClass: organizationalUnit - - dn: uid=${testUser},ou=accounts,ou=posix,${ldapSuffix} - objectClass: person - objectClass: posixAccount - userPassword: ${testPassword} - homeDirectory: /home/${testUser} - uidNumber: 1234 - gidNumber: 1234 - cn: "" - sn: "" - - dn: ou=groups,ou=posix,${ldapSuffix} - objectClass: top - objectClass: organizationalUnit - - dn: cn=${testGroup},ou=groups,ou=posix,${ldapSuffix} - objectClass: posixGroup - gidNumber: 2345 - memberUid: ${testUser} + + testScript = + let + changePassword = pkgs.writeText "change-password.py" '' + from users.models import User + u = User.objects.get(username='netbox') + u.set_password('netbox') + u.save() ''; - }; - }; + in + '' + from typing import Any, Dict + import json + + start_all() + machine.wait_for_unit("netbox.target") + machine.wait_until_succeeds("journalctl --since -1m --unit netbox --grep Listening") - users.users.nginx.extraGroups = [ "netbox" ]; - - networking.firewall.allowedTCPPorts = [ 80 ]; - }; - - testScript = let - changePassword = pkgs.writeText "change-password.py" '' - from users.models import User - u = User.objects.get(username='netbox') - u.set_password('netbox') - u.save() - ''; - in '' - from typing import Any, Dict - import json - - start_all() - machine.wait_for_unit("netbox.target") - machine.wait_until_succeeds("journalctl --since -1m --unit netbox --grep Listening") - - with subtest("Home screen loads"): - machine.succeed( - "curl -sSfL http://[::1]:8001 | grep 'Home | NetBox'" - ) - - with subtest("Staticfiles are generated"): - machine.succeed("test -e /var/lib/netbox/static/netbox.js") - - with subtest("Superuser can be created"): - machine.succeed( - "netbox-manage createsuperuser --noinput --username netbox --email netbox@example.com" - ) - # Django doesn't have a "clean" way of inputting the password from the command line - machine.succeed("cat '${changePassword}' | netbox-manage shell") - - machine.wait_for_unit("network.target") - - with subtest("Home screen loads from nginx"): - machine.succeed( - "curl -sSfL http://localhost | grep 'Home | NetBox'" - ) - - with subtest("Staticfiles can be fetched"): - machine.succeed("curl -sSfL http://localhost/static/netbox.js") - machine.succeed("curl -sSfL http://localhost/static/docs/") - - def login(username: str, password: str): - encoded_data = json.dumps({"username": username, "password": password}) - uri = "/users/tokens/provision/" - result = json.loads( + with subtest("Home screen loads"): machine.succeed( - "curl -sSfL " - "-X POST " - "-H 'Accept: application/json' " - "-H 'Content-Type: application/json' " - f"'http://localhost/api{uri}' " - f"--data '{encoded_data}'" + "curl -sSfL http://[::1]:8001 | grep 'Home | NetBox'" + ) + + with subtest("Staticfiles are generated"): + machine.succeed("test -e /var/lib/netbox/static/netbox.js") + + with subtest("Superuser can be created"): + machine.succeed( + "netbox-manage createsuperuser --noinput --username netbox --email netbox@example.com" ) - ) - return result["key"] + # Django doesn't have a "clean" way of inputting the password from the command line + machine.succeed("cat '${changePassword}' | netbox-manage shell") - with subtest("Can login"): - auth_token = login("netbox", "netbox") + machine.wait_for_unit("network.target") - def get(uri: str): - return json.loads( + with subtest("Home screen loads from nginx"): machine.succeed( + "curl -sSfL http://localhost | grep 'Home | NetBox'" + ) + + with subtest("Staticfiles can be fetched"): + machine.succeed("curl -sSfL http://localhost/static/netbox.js") + machine.succeed("curl -sSfL http://localhost/static/docs/") + + def login(username: str, password: str): + encoded_data = json.dumps({"username": username, "password": password}) + uri = "/users/tokens/provision/" + result = json.loads( + machine.succeed( + "curl -sSfL " + "-X POST " + "-H 'Accept: application/json' " + "-H 'Content-Type: application/json' " + f"'http://localhost/api{uri}' " + f"--data '{encoded_data}'" + ) + ) + return result["key"] + + with subtest("Can login"): + auth_token = login("netbox", "netbox") + + def get(uri: str): + return json.loads( + machine.succeed( + "curl -sSfL " + "-H 'Accept: application/json' " + f"-H 'Authorization: Token {auth_token}' " + f"'http://localhost/api{uri}'" + ) + ) + + def delete(uri: str): + return machine.succeed( "curl -sSfL " + f"-X DELETE " "-H 'Accept: application/json' " f"-H 'Authorization: Token {auth_token}' " f"'http://localhost/api{uri}'" ) - ) - def delete(uri: str): - return machine.succeed( - "curl -sSfL " - f"-X DELETE " - "-H 'Accept: application/json' " - f"-H 'Authorization: Token {auth_token}' " - f"'http://localhost/api{uri}'" - ) + def data_request(uri: str, method: str, data: Dict[str, Any]): + encoded_data = json.dumps(data) + return json.loads( + machine.succeed( + "curl -sSfL " + f"-X {method} " + "-H 'Accept: application/json' " + "-H 'Content-Type: application/json' " + f"-H 'Authorization: Token {auth_token}' " + f"'http://localhost/api{uri}' " + f"--data '{encoded_data}'" + ) + ) - def data_request(uri: str, method: str, data: Dict[str, Any]): - encoded_data = json.dumps(data) - return json.loads( - machine.succeed( - "curl -sSfL " - f"-X {method} " - "-H 'Accept: application/json' " - "-H 'Content-Type: application/json' " - f"-H 'Authorization: Token {auth_token}' " - f"'http://localhost/api{uri}' " - f"--data '{encoded_data}'" + def post(uri: str, data: Dict[str, Any]): + return data_request(uri, "POST", data) + + def patch(uri: str, data: Dict[str, Any]): + return data_request(uri, "PATCH", data) + + with subtest("Can create objects"): + result = post("/dcim/sites/", {"name": "Test site", "slug": "test-site"}) + site_id = result["id"] + + # Example from: + # http://netbox.extra.cea.fr/static/docs/integrations/rest-api/#creating-a-new-object + post("/ipam/prefixes/", {"prefix": "192.0.2.0/24", "site": site_id}) + + result = post( + "/dcim/manufacturers/", + {"name": "Test manufacturer", "slug": "test-manufacturer"} ) - ) - - def post(uri: str, data: Dict[str, Any]): - return data_request(uri, "POST", data) - - def patch(uri: str, data: Dict[str, Any]): - return data_request(uri, "PATCH", data) - - with subtest("Can create objects"): - result = post("/dcim/sites/", {"name": "Test site", "slug": "test-site"}) - site_id = result["id"] - - # Example from: - # http://netbox.extra.cea.fr/static/docs/integrations/rest-api/#creating-a-new-object - post("/ipam/prefixes/", {"prefix": "192.0.2.0/24", "site": site_id}) - - result = post( - "/dcim/manufacturers/", - {"name": "Test manufacturer", "slug": "test-manufacturer"} - ) - manufacturer_id = result["id"] - - # Had an issue with device-types before NetBox 3.4.0 - result = post( - "/dcim/device-types/", - { - "model": "Test device type", - "manufacturer": manufacturer_id, - "slug": "test-device-type", - }, - ) - device_type_id = result["id"] - - with subtest("Can list objects"): - result = get("/dcim/sites/") - - assert result["count"] == 1 - assert result["results"][0]["id"] == site_id - assert result["results"][0]["name"] == "Test site" - assert result["results"][0]["description"] == "" - - result = get("/dcim/device-types/") - assert result["count"] == 1 - assert result["results"][0]["id"] == device_type_id - assert result["results"][0]["model"] == "Test device type" - - with subtest("Can update objects"): - new_description = "Test site description" - patch(f"/dcim/sites/{site_id}/", {"description": new_description}) - result = get(f"/dcim/sites/{site_id}/") - assert result["description"] == new_description - - with subtest("Can delete objects"): - # Delete a device-type since no object depends on it - delete(f"/dcim/device-types/{device_type_id}/") - - result = get("/dcim/device-types/") - assert result["count"] == 0 - - with subtest("Can use the GraphQL API"): - encoded_data = json.dumps({ - "query": "query { prefix_list { prefix, site { id, description } } }", - }) - result = json.loads( - machine.succeed( - "curl -sSfL " - "-H 'Accept: application/json' " - "-H 'Content-Type: application/json' " - f"-H 'Authorization: Token {auth_token}' " - "'http://localhost/graphql/' " - f"--data '{encoded_data}'" + manufacturer_id = result["id"] + + # Had an issue with device-types before NetBox 3.4.0 + result = post( + "/dcim/device-types/", + { + "model": "Test device type", + "manufacturer": manufacturer_id, + "slug": "test-device-type", + }, + ) + device_type_id = result["id"] + + with subtest("Can list objects"): + result = get("/dcim/sites/") + + assert result["count"] == 1 + assert result["results"][0]["id"] == site_id + assert result["results"][0]["name"] == "Test site" + assert result["results"][0]["description"] == "" + + result = get("/dcim/device-types/") + assert result["count"] == 1 + assert result["results"][0]["id"] == device_type_id + assert result["results"][0]["model"] == "Test device type" + + with subtest("Can update objects"): + new_description = "Test site description" + patch(f"/dcim/sites/{site_id}/", {"description": new_description}) + result = get(f"/dcim/sites/{site_id}/") + assert result["description"] == new_description + + with subtest("Can delete objects"): + # Delete a device-type since no object depends on it + delete(f"/dcim/device-types/{device_type_id}/") + + result = get("/dcim/device-types/") + assert result["count"] == 0 + + with subtest("Can use the GraphQL API"): + encoded_data = json.dumps({ + "query": "query { prefix_list { prefix, site { id, description } } }", + }) + result = json.loads( + machine.succeed( + "curl -sSfL " + "-H 'Accept: application/json' " + "-H 'Content-Type: application/json' " + f"-H 'Authorization: Token {auth_token}' " + "'http://localhost/graphql/' " + f"--data '{encoded_data}'" + ) ) - ) - assert len(result["data"]["prefix_list"]) == 1 - assert result["data"]["prefix_list"][0]["prefix"] == "192.0.2.0/24" - assert result["data"]["prefix_list"][0]["site"]["id"] == str(site_id) - assert result["data"]["prefix_list"][0]["site"]["description"] == new_description + assert len(result["data"]["prefix_list"]) == 1 + assert result["data"]["prefix_list"][0]["prefix"] == "192.0.2.0/24" + assert result["data"]["prefix_list"][0]["site"]["id"] == str(site_id) + assert result["data"]["prefix_list"][0]["site"]["description"] == new_description - with subtest("Can login with LDAP"): - machine.wait_for_unit("openldap.service") - login("alice", "${testPassword}") + with subtest("Can login with LDAP"): + machine.wait_for_unit("openldap.service") + login("alice", "${testPassword}") - with subtest("Can associate LDAP groups"): - result = get("/users/users/?username=${testUser}") + with subtest("Can associate LDAP groups"): + result = get("/users/users/?username=${testUser}") - assert result["count"] == 1 - assert any(group["name"] == "${testGroup}" for group in result["results"][0]["groups"]) - ''; -}) + assert result["count"] == 1 + assert any(group["name"] == "${testGroup}" for group in result["results"][0]["groups"]) + ''; + } +) diff --git a/nixos/tests/web-apps/nifi.nix b/nixos/tests/web-apps/nifi.nix index 92f7fa231df3ac..06c50151c7176e 100644 --- a/nixos/tests/web-apps/nifi.nix +++ b/nixos/tests/web-apps/nifi.nix @@ -1,30 +1,34 @@ -import ../make-test-python.nix ({pkgs, ...}: -{ - name = "nifi"; - meta.maintainers = with pkgs.lib.maintainers; [ izorkin ]; +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "nifi"; + meta.maintainers = with pkgs.lib.maintainers; [ izorkin ]; - nodes = { - nifi = { pkgs, ... }: { - virtualisation = { - memorySize = 2048; - diskSize = 4096; - }; - services.nifi = { - enable = true; - enableHTTPS = false; - }; + nodes = { + nifi = + { pkgs, ... }: + { + virtualisation = { + memorySize = 2048; + diskSize = 4096; + }; + services.nifi = { + enable = true; + enableHTTPS = false; + }; + }; }; - }; - testScript = '' - nifi.start() + testScript = '' + nifi.start() - nifi.wait_for_unit("nifi.service") - nifi.wait_for_open_port(8080) + nifi.wait_for_unit("nifi.service") + nifi.wait_for_open_port(8080) - # Check if NiFi is running - nifi.succeed("curl --fail http://127.0.0.1:8080/nifi/login 2> /dev/null | grep 'NiFi Login'") + # Check if NiFi is running + nifi.succeed("curl --fail http://127.0.0.1:8080/nifi/login 2> /dev/null | grep 'NiFi Login'") - nifi.shutdown() - ''; -}) + nifi.shutdown() + ''; + } +) diff --git a/nixos/tests/web-apps/peering-manager.nix b/nixos/tests/web-apps/peering-manager.nix index 3f0acd560d1328..6a04d5f4e5e6d5 100644 --- a/nixos/tests/web-apps/peering-manager.nix +++ b/nixos/tests/web-apps/peering-manager.nix @@ -1,40 +1,47 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: { - name = "peering-manager"; +import ../make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "peering-manager"; - meta = with lib.maintainers; { - maintainers = [ yuka ]; - }; - - nodes.machine = { ... }: { - services.peering-manager = { - enable = true; - secretKeyFile = pkgs.writeText "secret" '' - abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789 - ''; + meta = with lib.maintainers; { + maintainers = [ yuka ]; }; - }; - testScript = { nodes }: '' - machine.start() - machine.wait_for_unit("peering-manager.target") - machine.wait_until_succeeds("journalctl --since -1m --unit peering-manager --grep Listening") + nodes.machine = + { ... }: + { + services.peering-manager = { + enable = true; + secretKeyFile = pkgs.writeText "secret" '' + abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789 + ''; + }; + }; - print(machine.succeed( - "curl -sSfL http://[::1]:8001" - )) - with subtest("Home screen loads"): - machine.succeed( - "curl -sSfL http://[::1]:8001 | grep 'Home - Peering Manager'" - ) - with subtest("checks succeed"): - machine.succeed( - "systemctl stop peering-manager peering-manager-rq" - ) - machine.succeed( - "sudo -u postgres psql -c 'ALTER USER \"peering-manager\" WITH SUPERUSER;'" - ) - machine.succeed( - "cd ${nodes.machine.system.build.peeringManagerPkg}/opt/peering-manager ; peering-manager-manage test --no-input" - ) - ''; -}) + testScript = + { nodes }: + '' + machine.start() + machine.wait_for_unit("peering-manager.target") + machine.wait_until_succeeds("journalctl --since -1m --unit peering-manager --grep Listening") + + print(machine.succeed( + "curl -sSfL http://[::1]:8001" + )) + with subtest("Home screen loads"): + machine.succeed( + "curl -sSfL http://[::1]:8001 | grep 'Home - Peering Manager'" + ) + with subtest("checks succeed"): + machine.succeed( + "systemctl stop peering-manager peering-manager-rq" + ) + machine.succeed( + "sudo -u postgres psql -c 'ALTER USER \"peering-manager\" WITH SUPERUSER;'" + ) + machine.succeed( + "cd ${nodes.machine.system.build.peeringManagerPkg}/opt/peering-manager ; peering-manager-manage test --no-input" + ) + ''; + } +) diff --git a/nixos/tests/web-apps/peertube.nix b/nixos/tests/web-apps/peertube.nix index 83c7cf03701e02..e260786458e499 100644 --- a/nixos/tests/web-apps/peertube.nix +++ b/nixos/tests/web-apps/peertube.nix @@ -1,149 +1,168 @@ -import ../make-test-python.nix ({pkgs, ...}: -{ - name = "peertube"; - meta.maintainers = with pkgs.lib.maintainers; [ izorkin ]; - - nodes = { - database = { - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.10"; prefixLength = 24; } +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "peertube"; + meta.maintainers = with pkgs.lib.maintainers; [ izorkin ]; + + nodes = { + database = { + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.10"; + prefixLength = 24; + } + ]; + }; + firewall.allowedTCPPorts = [ + 5432 + 31638 ]; }; - firewall.allowedTCPPorts = [ 5432 31638 ]; - }; - - services.postgresql = { - enable = true; - enableTCPIP = true; - ensureDatabases = [ "peertube_test" ]; - ensureUsers = [ - { - name = "peertube_test"; - ensureDBOwnership = true; - } - ]; - authentication = '' - hostnossl peertube_test peertube_test 192.168.2.11/32 md5 - ''; - initialScript = pkgs.writeText "postgresql_init.sql" '' - CREATE ROLE peertube_test LOGIN PASSWORD '0gUN0C1mgST6czvjZ8T9'; - ''; - }; - - services.redis.servers.peertube = { - enable = true; - bind = "0.0.0.0"; - requirePass = "turrQfaQwnanGbcsdhxy"; - port = 31638; - }; - }; - server = { pkgs, ... }: { - environment = { - etc = { - "peertube/password-init-root".text = '' - PT_INITIAL_ROOT_PASSWORD=zw4SqYVdcsXUfRX8aaFX - ''; - "peertube/secrets-peertube".text = '' - 063d9c60d519597acef26003d5ecc32729083965d09181ef3949200cbe5f09ee - ''; - "peertube/password-posgressql-db".text = '' - 0gUN0C1mgST6czvjZ8T9 + services.postgresql = { + enable = true; + enableTCPIP = true; + ensureDatabases = [ "peertube_test" ]; + ensureUsers = [ + { + name = "peertube_test"; + ensureDBOwnership = true; + } + ]; + authentication = '' + hostnossl peertube_test peertube_test 192.168.2.11/32 md5 ''; - "peertube/password-redis-db".text = '' - turrQfaQwnanGbcsdhxy + initialScript = pkgs.writeText "postgresql_init.sql" '' + CREATE ROLE peertube_test LOGIN PASSWORD '0gUN0C1mgST6czvjZ8T9'; ''; }; - }; - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.11"; prefixLength = 24; } - ]; + services.redis.servers.peertube = { + enable = true; + bind = "0.0.0.0"; + requirePass = "turrQfaQwnanGbcsdhxy"; + port = 31638; }; - extraHosts = '' - 192.168.2.11 peertube.local - ''; - firewall.allowedTCPPorts = [ 9000 ]; }; - services.peertube = { - enable = true; - localDomain = "peertube.local"; - enableWebHttps = false; - - serviceEnvironmentFile = "/etc/peertube/password-init-root"; - - secrets = { - secretsFile = "/etc/peertube/secrets-peertube"; - }; + server = + { pkgs, ... }: + { + environment = { + etc = { + "peertube/password-init-root".text = '' + PT_INITIAL_ROOT_PASSWORD=zw4SqYVdcsXUfRX8aaFX + ''; + "peertube/secrets-peertube".text = '' + 063d9c60d519597acef26003d5ecc32729083965d09181ef3949200cbe5f09ee + ''; + "peertube/password-posgressql-db".text = '' + 0gUN0C1mgST6czvjZ8T9 + ''; + "peertube/password-redis-db".text = '' + turrQfaQwnanGbcsdhxy + ''; + }; + }; - database = { - host = "192.168.2.10"; - name = "peertube_test"; - user = "peertube_test"; - passwordFile = "/etc/peertube/password-posgressql-db"; - }; + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.11"; + prefixLength = 24; + } + ]; + }; + extraHosts = '' + 192.168.2.11 peertube.local + ''; + firewall.allowedTCPPorts = [ 9000 ]; + }; - redis = { - host = "192.168.2.10"; - port = 31638; - passwordFile = "/etc/peertube/password-redis-db"; + services.peertube = { + enable = true; + localDomain = "peertube.local"; + enableWebHttps = false; + + serviceEnvironmentFile = "/etc/peertube/password-init-root"; + + secrets = { + secretsFile = "/etc/peertube/secrets-peertube"; + }; + + database = { + host = "192.168.2.10"; + name = "peertube_test"; + user = "peertube_test"; + passwordFile = "/etc/peertube/password-posgressql-db"; + }; + + redis = { + host = "192.168.2.10"; + port = 31638; + passwordFile = "/etc/peertube/password-redis-db"; + }; + + settings = { + listen = { + hostname = "0.0.0.0"; + }; + instance = { + name = "PeerTube Test Server"; + }; + }; + }; }; - settings = { - listen = { - hostname = "0.0.0.0"; - }; - instance = { - name = "PeerTube Test Server"; + client = { + environment.systemPackages = [ + pkgs.jq + pkgs.peertube.cli + ]; + networking = { + interfaces.eth1 = { + ipv4.addresses = [ + { + address = "192.168.2.12"; + prefixLength = 24; + } + ]; }; + extraHosts = '' + 192.168.2.11 peertube.local + ''; }; }; - }; - client = { - environment.systemPackages = [ pkgs.jq pkgs.peertube.cli ]; - networking = { - interfaces.eth1 = { - ipv4.addresses = [ - { address = "192.168.2.12"; prefixLength = 24; } - ]; - }; - extraHosts = '' - 192.168.2.11 peertube.local - ''; - }; }; - }; - - testScript = '' - start_all() + testScript = '' + start_all() - database.wait_for_unit("postgresql.service") - database.wait_for_unit("redis-peertube.service") + database.wait_for_unit("postgresql.service") + database.wait_for_unit("redis-peertube.service") - database.wait_for_open_port(5432) - database.wait_for_open_port(31638) + database.wait_for_open_port(5432) + database.wait_for_open_port(31638) - server.wait_for_unit("peertube.service") - server.wait_for_open_port(9000) + server.wait_for_unit("peertube.service") + server.wait_for_open_port(9000) - # Check if PeerTube is running - client.succeed("curl --fail http://peertube.local:9000/api/v1/config/about | jq -r '.instance.name' | grep 'PeerTube\ Test\ Server'") + # Check if PeerTube is running + client.succeed("curl --fail http://peertube.local:9000/api/v1/config/about | jq -r '.instance.name' | grep 'PeerTube\ Test\ Server'") - # Check PeerTube CLI version - client.succeed('peertube-cli auth add -u "http://peertube.local:9000" -U "root" --password "zw4SqYVdcsXUfRX8aaFX"') - client.succeed('peertube-cli auth list | grep "http://peertube.local:9000"') - client.succeed('peertube-cli auth del "http://peertube.local:9000"') - client.fail('peertube-cli auth list | grep "http://peertube.local:9000"') + # Check PeerTube CLI version + client.succeed('peertube-cli auth add -u "http://peertube.local:9000" -U "root" --password "zw4SqYVdcsXUfRX8aaFX"') + client.succeed('peertube-cli auth list | grep "http://peertube.local:9000"') + client.succeed('peertube-cli auth del "http://peertube.local:9000"') + client.fail('peertube-cli auth list | grep "http://peertube.local:9000"') - client.shutdown() - server.shutdown() - database.shutdown() - ''; -}) + client.shutdown() + server.shutdown() + database.shutdown() + ''; + } +) diff --git a/nixos/tests/web-apps/phylactery.nix b/nixos/tests/web-apps/phylactery.nix index cf2689d2300d30..492d50d3d2d1f6 100644 --- a/nixos/tests/web-apps/phylactery.nix +++ b/nixos/tests/web-apps/phylactery.nix @@ -1,20 +1,25 @@ -import ../make-test-python.nix ({ pkgs, lib, ... }: { - name = "phylactery"; +import ../make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "phylactery"; - nodes.machine = { ... }: { - services.phylactery = rec { - enable = true; - port = 8080; - library = "/tmp"; - }; - }; + nodes.machine = + { ... }: + { + services.phylactery = rec { + enable = true; + port = 8080; + library = "/tmp"; + }; + }; - testScript = '' - start_all() - machine.wait_for_unit('phylactery') - machine.wait_for_open_port(8080) - machine.wait_until_succeeds('curl localhost:8080') - ''; + testScript = '' + start_all() + machine.wait_for_unit('phylactery') + machine.wait_for_open_port(8080) + machine.wait_until_succeeds('curl localhost:8080') + ''; - meta.maintainers = with lib.maintainers; [ McSinyx ]; -}) + meta.maintainers = with lib.maintainers; [ McSinyx ]; + } +) diff --git a/nixos/tests/web-apps/pixelfed/default.nix b/nixos/tests/web-apps/pixelfed/default.nix index 4464ebe4348659..0422b6cf11f4e7 100644 --- a/nixos/tests/web-apps/pixelfed/default.nix +++ b/nixos/tests/web-apps/pixelfed/default.nix @@ -1,6 +1,12 @@ -{ system ? builtins.currentSystem, handleTestOn }: +{ + system ? builtins.currentSystem, + handleTestOn, +}: let - supportedSystems = [ "x86_64-linux" "i686-linux" ]; + supportedSystems = [ + "x86_64-linux" + "i686-linux" + ]; in { diff --git a/nixos/tests/web-apps/pixelfed/standard.nix b/nixos/tests/web-apps/pixelfed/standard.nix index c575ee0b0f76c2..7b916649bf0dcb 100644 --- a/nixos/tests/web-apps/pixelfed/standard.nix +++ b/nixos/tests/web-apps/pixelfed/standard.nix @@ -3,19 +3,23 @@ import ../../make-test-python.nix { meta.maintainers = [ ]; nodes = { - server = { pkgs, ... }: { - services.pixelfed = { - enable = true; - domain = "pixelfed.local"; - # Configure NGINX. - nginx = {}; - secretFile = (pkgs.writeText "secrets.env" '' - # Snakeoil secret, can be any random 32-chars secret via CSPRNG. - APP_KEY=adKK9EcY8Hcj3PLU7rzG9rJ6KKTOtYfA - ''); - settings."FORCE_HTTPS_URLS" = false; + server = + { pkgs, ... }: + { + services.pixelfed = { + enable = true; + domain = "pixelfed.local"; + # Configure NGINX. + nginx = { }; + secretFile = ( + pkgs.writeText "secrets.env" '' + # Snakeoil secret, can be any random 32-chars secret via CSPRNG. + APP_KEY=adKK9EcY8Hcj3PLU7rzG9rJ6KKTOtYfA + '' + ); + settings."FORCE_HTTPS_URLS" = false; + }; }; - }; }; testScript = '' diff --git a/nixos/tests/web-apps/pretalx.nix b/nixos/tests/web-apps/pretalx.nix index cbb6580aa0515b..c226d607ad00ad 100644 --- a/nixos/tests/web-apps/pretalx.nix +++ b/nixos/tests/web-apps/pretalx.nix @@ -5,22 +5,24 @@ meta.maintainers = lib.teams.c3d2.members; nodes = { - pretalx = { config, ... }: { - networking.extraHosts = '' - 127.0.0.1 talks.local - ''; - - services.pretalx = { - enable = true; - plugins = with config.services.pretalx.package.plugins; [ - pages - ]; - nginx.domain = "talks.local"; - settings = { - site.url = "http://talks.local"; + pretalx = + { config, ... }: + { + networking.extraHosts = '' + 127.0.0.1 talks.local + ''; + + services.pretalx = { + enable = true; + plugins = with config.services.pretalx.package.plugins; [ + pages + ]; + nginx.domain = "talks.local"; + settings = { + site.url = "http://talks.local"; + }; }; }; - }; }; testScript = '' diff --git a/nixos/tests/web-apps/snipe-it.nix b/nixos/tests/web-apps/snipe-it.nix index b04bd516831cb9..2f5764cd33be9e 100644 --- a/nixos/tests/web-apps/snipe-it.nix +++ b/nixos/tests/web-apps/snipe-it.nix @@ -1,103 +1,118 @@ /* -Snipe-IT NixOS test + Snipe-IT NixOS test -It covers the following scenario: -- Installation -- Backup and restore + It covers the following scenario: + - Installation + - Backup and restore -Scenarios NOT covered by this test (but perhaps in the future): -- Sending and receiving emails + Scenarios NOT covered by this test (but perhaps in the future): + - Sending and receiving emails */ -{ pkgs, ... }: let +{ pkgs, ... }: +let siteName = "NixOS Snipe-IT Test Instance"; -in { +in +{ name = "snipe-it"; meta.maintainers = with pkgs.lib.maintainers; [ yayayayaka ]; nodes = { - snipeit = { ... }: { - services.snipe-it = { - enable = true; - appKeyFile = toString (pkgs.writeText "snipe-it-app-key" "uTqGUN5GUmUrh/zSAYmhyzRk62pnpXICyXv9eeITI8k="); - hostName = "localhost"; - database.createLocally = true; - mail = { - driver = "smtp"; - encryption = "tls"; - host = "localhost"; - port = 1025; - from.name = "Snipe-IT NixOS test"; - from.address = "snipe-it@localhost"; - replyTo.address = "snipe-it@localhost"; - user = "snipe-it@localhost"; - passwordFile = toString (pkgs.writeText "snipe-it-mail-pass" "a-secure-mail-password"); + snipeit = + { ... }: + { + services.snipe-it = { + enable = true; + appKeyFile = toString ( + pkgs.writeText "snipe-it-app-key" "uTqGUN5GUmUrh/zSAYmhyzRk62pnpXICyXv9eeITI8k=" + ); + hostName = "localhost"; + database.createLocally = true; + mail = { + driver = "smtp"; + encryption = "tls"; + host = "localhost"; + port = 1025; + from.name = "Snipe-IT NixOS test"; + from.address = "snipe-it@localhost"; + replyTo.address = "snipe-it@localhost"; + user = "snipe-it@localhost"; + passwordFile = toString (pkgs.writeText "snipe-it-mail-pass" "a-secure-mail-password"); + }; }; }; - }; }; - testScript = { nodes }: let - backupPath = "${nodes.snipeit.services.snipe-it.dataDir}/storage/app/backups"; - - # Snipe-IT has been installed successfully if the site name shows up on the login page - checkLoginPage = { shouldSucceed ? true }: '' - snipeit.${if shouldSucceed then "succeed" else "fail"}("""curl http://localhost/login | grep '${siteName}'""") + testScript = + { nodes }: + let + backupPath = "${nodes.snipeit.services.snipe-it.dataDir}/storage/app/backups"; + + # Snipe-IT has been installed successfully if the site name shows up on the login page + checkLoginPage = + { + shouldSucceed ? true, + }: + '' + snipeit.${ + if shouldSucceed then "succeed" else "fail" + }("""curl http://localhost/login | grep '${siteName}'""") + ''; + in + '' + start_all() + + snipeit.wait_for_unit("nginx.service") + snipeit.wait_for_unit("snipe-it-setup.service") + + # Create an admin user + snipeit.succeed( + """ + snipe-it snipeit:create-admin \ + --username="admin" \ + --email="janedoe@localhost" \ + --password="extremesecurepassword" \ + --first_name="Jane" \ + --last_name="Doe" + """ + ) + + with subtest("Circumvent the pre-flight setup by just writing some settings into the database ourself"): + snipeit.succeed( + """ + mysql -D ${nodes.snipeit.services.snipe-it.database.name} -e " + INSERT INTO settings (id, site_name, login_remote_user_custom_logout_url, login_remote_user_header_name) + VALUES ('1', '${siteName}', 'https://whatever.invalid', 'whatever');" + """ + ) + + # Usually these are generated during the pre-flight setup + snipeit.succeed("snipe-it passport:keys") + + + # Login page should now contain the configured site name + ${checkLoginPage { }} + + with subtest("Test Backup and restore"): + snipeit.succeed("snipe-it snipeit:backup") + + # One zip file should have been created + snipeit.succeed("""[ "$(ls -1 "${backupPath}" | wc -l)" -eq 1 ]""") + + # Purge the state + snipeit.succeed("snipe-it migrate:fresh --force") + + # Login page should disappear + ${checkLoginPage { shouldSucceed = false; }} + + # Restore the state + snipeit.succeed( + """ + snipe-it snipeit:restore --force $(find "${backupPath}/" -type f -name "*.zip") + """ + ) + + # Login page should be back again + ${checkLoginPage { }} ''; - in '' - start_all() - - snipeit.wait_for_unit("nginx.service") - snipeit.wait_for_unit("snipe-it-setup.service") - - # Create an admin user - snipeit.succeed( - """ - snipe-it snipeit:create-admin \ - --username="admin" \ - --email="janedoe@localhost" \ - --password="extremesecurepassword" \ - --first_name="Jane" \ - --last_name="Doe" - """ - ) - - with subtest("Circumvent the pre-flight setup by just writing some settings into the database ourself"): - snipeit.succeed( - """ - mysql -D ${nodes.snipeit.services.snipe-it.database.name} -e " - INSERT INTO settings (id, site_name, login_remote_user_custom_logout_url, login_remote_user_header_name) - VALUES ('1', '${siteName}', 'https://whatever.invalid', 'whatever');" - """ - ) - - # Usually these are generated during the pre-flight setup - snipeit.succeed("snipe-it passport:keys") - - - # Login page should now contain the configured site name - ${checkLoginPage {}} - - with subtest("Test Backup and restore"): - snipeit.succeed("snipe-it snipeit:backup") - - # One zip file should have been created - snipeit.succeed("""[ "$(ls -1 "${backupPath}" | wc -l)" -eq 1 ]""") - - # Purge the state - snipeit.succeed("snipe-it migrate:fresh --force") - - # Login page should disappear - ${checkLoginPage { shouldSucceed = false; }} - - # Restore the state - snipeit.succeed( - """ - snipe-it snipeit:restore --force $(find "${backupPath}/" -type f -name "*.zip") - """ - ) - - # Login page should be back again - ${checkLoginPage {}} - ''; } diff --git a/nixos/tests/web-apps/writefreely.nix b/nixos/tests/web-apps/writefreely.nix index ce614909706b40..3f56e1df8ead82 100644 --- a/nixos/tests/web-apps/writefreely.nix +++ b/nixos/tests/web-apps/writefreely.nix @@ -1,29 +1,35 @@ -{ system ? builtins.currentSystem, config ? { } -, pkgs ? import ../../.. { inherit system config; } }: +{ + system ? builtins.currentSystem, + config ? { }, + pkgs ? import ../../.. { inherit system config; }, +}: with import ../../lib/testing-python.nix { inherit system pkgs; }; with pkgs.lib; let - writefreelyTest = { name, type }: + writefreelyTest = + { name, type }: makeTest { name = "writefreely-${name}"; - nodes.machine = { config, pkgs, ... }: { - services.writefreely = { - enable = true; - host = "localhost:3000"; - admin.name = "nixos"; + nodes.machine = + { config, pkgs, ... }: + { + services.writefreely = { + enable = true; + host = "localhost:3000"; + admin.name = "nixos"; - database = { - inherit type; - createLocally = type == "mysql"; - passwordFile = pkgs.writeText "db-pass" "pass"; - }; + database = { + inherit type; + createLocally = type == "mysql"; + passwordFile = pkgs.writeText "db-pass" "pass"; + }; - settings.server.port = 3000; + settings.server.port = 3000; + }; }; - }; testScript = '' start_all() @@ -32,7 +38,8 @@ let machine.succeed("curl --fail http://localhost:3000") ''; }; -in { +in +{ sqlite = writefreelyTest { name = "sqlite"; type = "sqlite3"; diff --git a/nixos/tests/web-servers/agate.nix b/nixos/tests/web-servers/agate.nix index 0de27b6f7d8df6..2801ac4c9265b1 100644 --- a/nixos/tests/web-servers/agate.nix +++ b/nixos/tests/web-servers/agate.nix @@ -1,27 +1,33 @@ { pkgs, lib, ... }: { name = "agate"; - meta = with lib.maintainers; { maintainers = [ jk ]; }; + meta = with lib.maintainers; { + maintainers = [ jk ]; + }; nodes = { - geminiserver = { pkgs, ... }: { - services.agate = { - enable = true; - hostnames = [ "localhost" ]; - contentDir = pkgs.writeTextDir "index.gmi" '' - # Hello NixOS! - ''; + geminiserver = + { pkgs, ... }: + { + services.agate = { + enable = true; + hostnames = [ "localhost" ]; + contentDir = pkgs.writeTextDir "index.gmi" '' + # Hello NixOS! + ''; + }; }; - }; }; - testScript = { nodes, ... }: '' - geminiserver.wait_for_unit("agate") - geminiserver.wait_for_open_port(1965) + testScript = + { nodes, ... }: + '' + geminiserver.wait_for_unit("agate") + geminiserver.wait_for_open_port(1965) - with subtest("check is serving over gemini"): - response = geminiserver.succeed("${pkgs.gemget}/bin/gemget --header -o - gemini://localhost:1965") - print(response) - assert "Hello NixOS!" in response - ''; + with subtest("check is serving over gemini"): + response = geminiserver.succeed("${pkgs.gemget}/bin/gemget --header -o - gemini://localhost:1965") + print(response) + assert "Hello NixOS!" in response + ''; } diff --git a/nixos/tests/web-servers/stargazer.nix b/nixos/tests/web-servers/stargazer.nix index b687f2046a0446..776b9095b4aed6 100644 --- a/nixos/tests/web-servers/stargazer.nix +++ b/nixos/tests/web-servers/stargazer.nix @@ -3,7 +3,14 @@ let test_script = pkgs.stdenv.mkDerivation { pname = "stargazer-test-script"; inherit (pkgs.stargazer) version src; - buildInputs = with pkgs; [ (python3.withPackages (ps: with ps; [ cryptography urllib3 ])) ]; + buildInputs = with pkgs; [ + (python3.withPackages ( + ps: with ps; [ + cryptography + urllib3 + ] + )) + ]; dontBuild = true; doCheck = false; installPhase = '' @@ -38,120 +45,128 @@ let in { name = "stargazer"; - meta = with lib.maintainers; { maintainers = [ gaykitty ]; }; + meta = with lib.maintainers; { + maintainers = [ gaykitty ]; + }; nodes = { - geminiserver = { pkgs, ... }: { - services.stargazer = { - enable = true; - connectionLogging = false; - requestTimeout = 1; - routes = [ - { - route = "localhost"; - root = "${test_env}/test_data/test_site"; - } - { - route = "localhost=/en.gmi"; - root = "${test_env}/test_data/test_site"; - lang = "en"; - charset = "ascii"; - } - { - route = "localhost~/(.*).gemini"; - root = "${test_env}/test_data/test_site"; - rewrite = "\\1.gmi"; - lang = "en"; - charset = "ascii"; - } - { - route = "localhost=/plain.txt"; - root = "${test_env}/test_data/test_site"; - lang = "en"; - charset = "ascii"; - cert-path = "/var/lib/gemini/certs/localhost.crt"; - key-path = "/var/lib/gemini/certs/localhost.key"; - } - { - route = "localhost:/cgi-bin"; - root = "${test_env}/test_data"; - cgi = true; - cgi-timeout = 5; - } - { - route = "localhost:/scgi"; - scgi = true; - scgi-address = "127.0.0.1:1099"; - } - { - route = "localhost=/root"; - redirect = ".."; - permanent = true; - } - { - route = "localhost=/priv.gmi"; - root = "${test_env}/test_data/test_site"; - client-cert = "${test_env}/test_data/client_cert/good.crt"; - } - { - route = "example.com~(.*)"; - redirect = "gemini://localhost"; - rewrite = "\\1"; - } - { - route = "localhost:/no-exist"; - root = "${test_env}/does_not_exist"; - } - { - route = "localhost=/rss.xml"; - root = "${test_env}/test_data/test_site"; - mime-override = "application/atom+xml"; - } - ]; - }; - systemd.services.scgi_server = { - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - serviceConfig = { - ExecStart = "${scgi_server}/bin/scgi-server"; + geminiserver = + { pkgs, ... }: + { + services.stargazer = { + enable = true; + connectionLogging = false; + requestTimeout = 1; + routes = [ + { + route = "localhost"; + root = "${test_env}/test_data/test_site"; + } + { + route = "localhost=/en.gmi"; + root = "${test_env}/test_data/test_site"; + lang = "en"; + charset = "ascii"; + } + { + route = "localhost~/(.*).gemini"; + root = "${test_env}/test_data/test_site"; + rewrite = "\\1.gmi"; + lang = "en"; + charset = "ascii"; + } + { + route = "localhost=/plain.txt"; + root = "${test_env}/test_data/test_site"; + lang = "en"; + charset = "ascii"; + cert-path = "/var/lib/gemini/certs/localhost.crt"; + key-path = "/var/lib/gemini/certs/localhost.key"; + } + { + route = "localhost:/cgi-bin"; + root = "${test_env}/test_data"; + cgi = true; + cgi-timeout = 5; + } + { + route = "localhost:/scgi"; + scgi = true; + scgi-address = "127.0.0.1:1099"; + } + { + route = "localhost=/root"; + redirect = ".."; + permanent = true; + } + { + route = "localhost=/priv.gmi"; + root = "${test_env}/test_data/test_site"; + client-cert = "${test_env}/test_data/client_cert/good.crt"; + } + { + route = "example.com~(.*)"; + redirect = "gemini://localhost"; + rewrite = "\\1"; + } + { + route = "localhost:/no-exist"; + root = "${test_env}/does_not_exist"; + } + { + route = "localhost=/rss.xml"; + root = "${test_env}/test_data/test_site"; + mime-override = "application/atom+xml"; + } + ]; + }; + systemd.services.scgi_server = { + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + serviceConfig = { + ExecStart = "${scgi_server}/bin/scgi-server"; + }; }; }; - }; - cgiTestServer = { ... }: { - users.users.cgi = { - isSystemUser = true; - group = "cgi"; - }; - users.groups.cgi = { }; - services.stargazer = { - enable = true; - connectionLogging = false; - requestTimeout = 1; - allowCgiUser = true; - routes = [ - { - route = "localhost:/cgi-bin"; - root = "${test_env}/test_data"; - cgi = true; - cgi-timeout = 5; - cgi-user = "cgi"; - } - ]; + cgiTestServer = + { ... }: + { + users.users.cgi = { + isSystemUser = true; + group = "cgi"; + }; + users.groups.cgi = { }; + services.stargazer = { + enable = true; + connectionLogging = false; + requestTimeout = 1; + allowCgiUser = true; + routes = [ + { + route = "localhost:/cgi-bin"; + root = "${test_env}/test_data"; + cgi = true; + cgi-timeout = 5; + cgi-user = "cgi"; + } + ]; + }; }; - }; }; - testScript = { nodes, ... }: '' - geminiserver.wait_for_unit("scgi_server") - geminiserver.wait_for_open_port(1099) - geminiserver.wait_for_unit("stargazer") - cgiTestServer.wait_for_open_port(1965) + testScript = + { nodes, ... }: + '' + geminiserver.wait_for_unit("scgi_server") + geminiserver.wait_for_open_port(1099) + geminiserver.wait_for_unit("stargazer") + cgiTestServer.wait_for_open_port(1965) - with subtest("stargazer test suite"): - response = geminiserver.succeed("sh -c 'cd ${test_env}; ${test_script}/bin/test'") - print(response) - with subtest("stargazer cgi-user test"): - response = cgiTestServer.succeed("sh -c 'cd ${test_env}; ${test_script}/bin/test --checks CGIVars'") - print(response) - ''; + with subtest("stargazer test suite"): + response = geminiserver.succeed("sh -c 'cd ${test_env}; ${test_script}/bin/test'") + print(response) + with subtest("stargazer cgi-user test"): + response = cgiTestServer.succeed("sh -c 'cd ${test_env}; ${test_script}/bin/test --checks CGIVars'") + print(response) + ''; } diff --git a/nixos/tests/web-servers/static-web-server.nix b/nixos/tests/web-servers/static-web-server.nix index da1a9bdec5d257..1c88e70a09578f 100644 --- a/nixos/tests/web-servers/static-web-server.nix +++ b/nixos/tests/web-servers/static-web-server.nix @@ -1,32 +1,41 @@ -import ../make-test-python.nix ({ pkgs, lib, ... } : { - name = "static-web-server"; - meta = { - maintainers = with lib.maintainers; [ mac-chaffee ]; - }; +import ../make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "static-web-server"; + meta = { + maintainers = with lib.maintainers; [ mac-chaffee ]; + }; - nodes.machine = { pkgs, ... }: { - services.static-web-server = { - enable = true; - listen = "[::]:8080"; - root = toString (pkgs.writeTextDir "nixos-test.html" '' -

Hello NixOS!

- ''); - configuration = { - general = { directory-listing = true; }; + nodes.machine = + { pkgs, ... }: + { + services.static-web-server = { + enable = true; + listen = "[::]:8080"; + root = toString ( + pkgs.writeTextDir "nixos-test.html" '' +

Hello NixOS!

+ '' + ); + configuration = { + general = { + directory-listing = true; + }; + }; + }; }; - }; - }; - testScript = '' - machine.start() - machine.wait_for_unit("static-web-server.socket") - machine.wait_for_open_port(8080) - # We don't use wait_until_succeeds() because we're testing socket - # activation which better work on the first request - response = machine.succeed("curl -fsS localhost:8080") - assert "nixos-test.html" in response, "The directory listing page did not include a link to our nixos-test.html file" - response = machine.succeed("curl -fsS localhost:8080/nixos-test.html") - assert "Hello NixOS!" in response - machine.wait_for_unit("static-web-server.service") - ''; -}) + testScript = '' + machine.start() + machine.wait_for_unit("static-web-server.socket") + machine.wait_for_open_port(8080) + # We don't use wait_until_succeeds() because we're testing socket + # activation which better work on the first request + response = machine.succeed("curl -fsS localhost:8080") + assert "nixos-test.html" in response, "The directory listing page did not include a link to our nixos-test.html file" + response = machine.succeed("curl -fsS localhost:8080/nixos-test.html") + assert "Hello NixOS!" in response + machine.wait_for_unit("static-web-server.service") + ''; + } +) diff --git a/nixos/tests/web-servers/ttyd.nix b/nixos/tests/web-servers/ttyd.nix index b79a2032ec75a3..8735269afcff02 100644 --- a/nixos/tests/web-servers/ttyd.nix +++ b/nixos/tests/web-servers/ttyd.nix @@ -1,29 +1,36 @@ -import ../make-test-python.nix ({ lib, pkgs, ... }: { - name = "ttyd"; - meta.maintainers = with lib.maintainers; [ stunkymonkey ]; +import ../make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "ttyd"; + meta.maintainers = with lib.maintainers; [ stunkymonkey ]; - nodes.readonly = { pkgs, ... }: { - services.ttyd = { - enable = true; - entrypoint = [ (lib.getExe pkgs.htop) ]; - writeable = false; - }; - }; + nodes.readonly = + { pkgs, ... }: + { + services.ttyd = { + enable = true; + entrypoint = [ (lib.getExe pkgs.htop) ]; + writeable = false; + }; + }; - nodes.writeable = { pkgs, ... }: { - services.ttyd = { - enable = true; - username = "foo"; - passwordFile = pkgs.writeText "password" "bar"; - writeable = true; - }; - }; + nodes.writeable = + { pkgs, ... }: + { + services.ttyd = { + enable = true; + username = "foo"; + passwordFile = pkgs.writeText "password" "bar"; + writeable = true; + }; + }; - testScript = '' - for machine in [readonly, writeable]: - machine.wait_for_unit("ttyd.service") - machine.wait_for_open_port(7681) - response = machine.succeed("curl -vvv -u foo:bar -s -H 'Host: ttyd' http://127.0.0.1:7681/") - assert 'ttyd - Terminal' in response, "Page didn't load successfully" - ''; -}) + testScript = '' + for machine in [readonly, writeable]: + machine.wait_for_unit("ttyd.service") + machine.wait_for_open_port(7681) + response = machine.succeed("curl -vvv -u foo:bar -s -H 'Host: ttyd' http://127.0.0.1:7681/") + assert 'ttyd - Terminal' in response, "Page didn't load successfully" + ''; + } +) diff --git a/nixos/tests/web-servers/unit-php.nix b/nixos/tests/web-servers/unit-php.nix index f0df371945e5b0..fcf0224639da18 100644 --- a/nixos/tests/web-servers/unit-php.nix +++ b/nixos/tests/web-servers/unit-php.nix @@ -1,52 +1,62 @@ -import ../make-test-python.nix ({pkgs, ...}: -let - testdir = pkgs.writeTextDir "www/info.php" " >(tee wine-stderr >&2)'" - ) - assert 'Hello, world!' in greeting - '' - # only the full version contains Gecko, but the error is not printed reliably in other variants - + optionalString (variant == "full") '' - machine.fail( - "fgrep 'Could not find Wine Gecko. HTML rendering will be disabled.' wine-stderr" - ) - '') exes} + ${concatMapStrings ( + exe: + '' + greeting = machine.succeed( + "bash -c 'wine ${exe} 2> >(tee wine-stderr >&2)'" + ) + assert 'Hello, world!' in greeting + '' + # only the full version contains Gecko, but the error is not printed reliably in other variants + + optionalString (variant == "full") '' + machine.fail( + "fgrep 'Could not find Wine Gecko. HTML rendering will be disabled.' wine-stderr" + ) + '' + ) exes} ''; }; }; - variants = [ "base" "full" "minimal" "staging" "unstable" "wayland" ]; + variants = [ + "base" + "full" + "minimal" + "staging" + "unstable" + "wayland" + ]; in listToAttrs ( map (makeWineTest "winePackages" [ hello32 ]) variants - ++ optionals pkgs.stdenv.hostPlatform.is64bit - (map (makeWineTest "wineWowPackages" [ hello32 hello64 ]) - # This wayland combination times out after spending many hours. - # https://hydra.nixos.org/job/nixos/trunk-combined/nixos.tests.wine.wineWowPackages-wayland.x86_64-linux - (pkgs.lib.remove "wayland" variants)) + ++ optionals pkgs.stdenv.hostPlatform.is64bit ( + map + (makeWineTest "wineWowPackages" [ + hello32 + hello64 + ]) + # This wayland combination times out after spending many hours. + # https://hydra.nixos.org/job/nixos/trunk-combined/nixos.tests.wine.wineWowPackages-wayland.x86_64-linux + (pkgs.lib.remove "wayland" variants) + ) ) diff --git a/nixos/tests/wireguard/basic.nix b/nixos/tests/wireguard/basic.nix index 96b0a681c364da..f0ef97b55fdcef 100644 --- a/nixos/tests/wireguard/basic.nix +++ b/nixos/tests/wireguard/basic.nix @@ -1,4 +1,10 @@ -import ../make-test-python.nix ({ pkgs, lib, kernelPackages ? null, ...} : +import ../make-test-python.nix ( + { + pkgs, + lib, + kernelPackages ? null, + ... + }: let wg-snakeoil-keys = import ./snakeoil-keys.nix; peer = (import ./make-peer.nix) { inherit lib; }; @@ -17,13 +23,19 @@ import ../make-test-python.nix ({ pkgs, lib, kernelPackages ? null, ...} : boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; networking.firewall.allowedUDPPorts = [ 23542 ]; networking.wireguard.interfaces.wg0 = { - ips = [ "10.23.42.1/32" "fc00::1/128" ]; + ips = [ + "10.23.42.1/32" + "fc00::1/128" + ]; listenPort = 23542; inherit (wg-snakeoil-keys.peer0) privateKey; peers = lib.singleton { - allowedIPs = [ "10.23.42.2/32" "fc00::2/128" ]; + allowedIPs = [ + "10.23.42.2/32" + "fc00::2/128" + ]; inherit (wg-snakeoil-keys.peer1) publicKey; }; @@ -37,24 +49,34 @@ import ../make-test-python.nix ({ pkgs, lib, kernelPackages ? null, ...} : extraConfig = { boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; networking.wireguard.interfaces.wg0 = { - ips = [ "10.23.42.2/32" "fc00::2/128" ]; + ips = [ + "10.23.42.2/32" + "fc00::2/128" + ]; listenPort = 23542; allowedIPsAsRoutes = false; inherit (wg-snakeoil-keys.peer1) privateKey; peers = lib.singleton { - allowedIPs = [ "0.0.0.0/0" "::/0" ]; + allowedIPs = [ + "0.0.0.0/0" + "::/0" + ]; endpoint = "192.168.0.1:23542"; persistentKeepalive = 25; inherit (wg-snakeoil-keys.peer0) publicKey; }; - postSetup = let inherit (pkgs) iproute2; in '' - ${iproute2}/bin/ip route replace 10.23.42.1/32 dev wg0 - ${iproute2}/bin/ip route replace fc00::1/128 dev wg0 - ''; + postSetup = + let + inherit (pkgs) iproute2; + in + '' + ${iproute2}/bin/ip route replace 10.23.42.1/32 dev wg0 + ${iproute2}/bin/ip route replace fc00::1/128 dev wg0 + ''; }; }; }; diff --git a/nixos/tests/wireguard/generated.nix b/nixos/tests/wireguard/generated.nix index c58f7a75071ec8..31ecd9643ffc43 100644 --- a/nixos/tests/wireguard/generated.nix +++ b/nixos/tests/wireguard/generated.nix @@ -1,63 +1,74 @@ -import ../make-test-python.nix ({ pkgs, lib, kernelPackages ? null, ... } : { - name = "wireguard-generated"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ma27 grahamc ]; - }; - - nodes = { - peer1 = { - boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; - networking.firewall.allowedUDPPorts = [ 12345 ]; - networking.wireguard.interfaces.wg0 = { - ips = [ "10.10.10.1/24" ]; - listenPort = 12345; - privateKeyFile = "/etc/wireguard/private"; - generatePrivateKeyFile = true; +import ../make-test-python.nix ( + { + pkgs, + lib, + kernelPackages ? null, + ... + }: + { + name = "wireguard-generated"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + ma27 + grahamc + ]; + }; + + nodes = { + peer1 = { + boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; + networking.firewall.allowedUDPPorts = [ 12345 ]; + networking.wireguard.interfaces.wg0 = { + ips = [ "10.10.10.1/24" ]; + listenPort = 12345; + privateKeyFile = "/etc/wireguard/private"; + generatePrivateKeyFile = true; + }; }; - }; - peer2 = { - boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; - networking.firewall.allowedUDPPorts = [ 12345 ]; - networking.wireguard.interfaces.wg0 = { - ips = [ "10.10.10.2/24" ]; - listenPort = 12345; - privateKeyFile = "/etc/wireguard/private"; - generatePrivateKeyFile = true; + peer2 = { + boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; + networking.firewall.allowedUDPPorts = [ 12345 ]; + networking.wireguard.interfaces.wg0 = { + ips = [ "10.10.10.2/24" ]; + listenPort = 12345; + privateKeyFile = "/etc/wireguard/private"; + generatePrivateKeyFile = true; + }; }; }; - }; - - testScript = '' - start_all() - - peer1.wait_for_unit("wireguard-wg0.service") - peer2.wait_for_unit("wireguard-wg0.service") - - retcode, peer1pubkey = peer1.execute("wg pubkey < /etc/wireguard/private") - if retcode != 0: - raise Exception("Could not read public key from peer1") - - retcode, peer2pubkey = peer2.execute("wg pubkey < /etc/wireguard/private") - if retcode != 0: - raise Exception("Could not read public key from peer2") - - peer1.succeed( - "wg set wg0 peer {} allowed-ips 10.10.10.2/32 endpoint 192.168.1.2:12345 persistent-keepalive 1".format( - peer2pubkey.strip() - ) - ) - peer1.succeed("ip route replace 10.10.10.2/32 dev wg0 table main") - - peer2.succeed( - "wg set wg0 peer {} allowed-ips 10.10.10.1/32 endpoint 192.168.1.1:12345 persistent-keepalive 1".format( - peer1pubkey.strip() - ) - ) - peer2.succeed("ip route replace 10.10.10.1/32 dev wg0 table main") - - peer1.succeed("ping -c1 10.10.10.2") - peer2.succeed("ping -c1 10.10.10.1") - ''; -}) + + testScript = '' + start_all() + + peer1.wait_for_unit("wireguard-wg0.service") + peer2.wait_for_unit("wireguard-wg0.service") + + retcode, peer1pubkey = peer1.execute("wg pubkey < /etc/wireguard/private") + if retcode != 0: + raise Exception("Could not read public key from peer1") + + retcode, peer2pubkey = peer2.execute("wg pubkey < /etc/wireguard/private") + if retcode != 0: + raise Exception("Could not read public key from peer2") + + peer1.succeed( + "wg set wg0 peer {} allowed-ips 10.10.10.2/32 endpoint 192.168.1.2:12345 persistent-keepalive 1".format( + peer2pubkey.strip() + ) + ) + peer1.succeed("ip route replace 10.10.10.2/32 dev wg0 table main") + + peer2.succeed( + "wg set wg0 peer {} allowed-ips 10.10.10.1/32 endpoint 192.168.1.1:12345 persistent-keepalive 1".format( + peer1pubkey.strip() + ) + ) + peer2.succeed("ip route replace 10.10.10.1/32 dev wg0 table main") + + peer1.succeed("ping -c1 10.10.10.2") + peer2.succeed("ping -c1 10.10.10.1") + ''; + } +) diff --git a/nixos/tests/wireguard/make-peer.nix b/nixos/tests/wireguard/make-peer.nix index d2740549738b4c..aaee4b6507613a 100644 --- a/nixos/tests/wireguard/make-peer.nix +++ b/nixos/tests/wireguard/make-peer.nix @@ -1,4 +1,9 @@ -{ lib, ... }: { ip4, ip6, extraConfig }: +{ lib, ... }: +{ + ip4, + ip6, + extraConfig, +}: lib.mkMerge [ { boot.kernel.sysctl = { @@ -9,14 +14,18 @@ lib.mkMerge [ networking.useDHCP = false; networking.interfaces.eth1 = { - ipv4.addresses = [{ - address = ip4; - prefixLength = 24; - }]; - ipv6.addresses = [{ - address = ip6; - prefixLength = 64; - }]; + ipv4.addresses = [ + { + address = ip4; + prefixLength = 24; + } + ]; + ipv6.addresses = [ + { + address = ip6; + prefixLength = 64; + } + ]; }; } extraConfig diff --git a/nixos/tests/wireguard/namespaces.nix b/nixos/tests/wireguard/namespaces.nix index d0eb009e1107dd..f88ac1eb2dfa70 100644 --- a/nixos/tests/wireguard/namespaces.nix +++ b/nixos/tests/wireguard/namespaces.nix @@ -13,71 +13,79 @@ let in -import ../make-test-python.nix ({ pkgs, lib, kernelPackages ? null, ... } : { - name = "wireguard-with-namespaces"; - meta = with pkgs.lib.maintainers; { - maintainers = [ asymmetric ]; - }; +import ../make-test-python.nix ( + { + pkgs, + lib, + kernelPackages ? null, + ... + }: + { + name = "wireguard-with-namespaces"; + meta = with pkgs.lib.maintainers; { + maintainers = [ asymmetric ]; + }; - nodes = { - # interface should be created in the socketNamespace - # and not moved from there - peer0 = pkgs.lib.attrsets.recursiveUpdate node { - boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; - networking.wireguard.interfaces.wg0 = { - preSetup = '' - ip netns add ${socketNamespace} - ''; - inherit socketNamespace; + nodes = { + # interface should be created in the socketNamespace + # and not moved from there + peer0 = pkgs.lib.attrsets.recursiveUpdate node { + boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; + networking.wireguard.interfaces.wg0 = { + preSetup = '' + ip netns add ${socketNamespace} + ''; + inherit socketNamespace; + }; }; - }; - # interface should be created in the init namespace - # and moved to the interfaceNamespace - peer1 = pkgs.lib.attrsets.recursiveUpdate node { - boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; - networking.wireguard.interfaces.wg0 = { - preSetup = '' - ip netns add ${interfaceNamespace} - ''; - mtu = 1280; - inherit interfaceNamespace; + # interface should be created in the init namespace + # and moved to the interfaceNamespace + peer1 = pkgs.lib.attrsets.recursiveUpdate node { + boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; + networking.wireguard.interfaces.wg0 = { + preSetup = '' + ip netns add ${interfaceNamespace} + ''; + mtu = 1280; + inherit interfaceNamespace; + }; }; - }; - # interface should be created in the socketNamespace - # and moved to the interfaceNamespace - peer2 = pkgs.lib.attrsets.recursiveUpdate node { - boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; - networking.wireguard.interfaces.wg0 = { - preSetup = '' - ip netns add ${socketNamespace} - ip netns add ${interfaceNamespace} - ''; - inherit socketNamespace interfaceNamespace; + # interface should be created in the socketNamespace + # and moved to the interfaceNamespace + peer2 = pkgs.lib.attrsets.recursiveUpdate node { + boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; + networking.wireguard.interfaces.wg0 = { + preSetup = '' + ip netns add ${socketNamespace} + ip netns add ${interfaceNamespace} + ''; + inherit socketNamespace interfaceNamespace; + }; }; - }; - # interface should be created in the socketNamespace - # and moved to the init namespace - peer3 = pkgs.lib.attrsets.recursiveUpdate node { - boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; - networking.wireguard.interfaces.wg0 = { - preSetup = '' - ip netns add ${socketNamespace} - ''; - inherit socketNamespace; - interfaceNamespace = "init"; + # interface should be created in the socketNamespace + # and moved to the init namespace + peer3 = pkgs.lib.attrsets.recursiveUpdate node { + boot = lib.mkIf (kernelPackages != null) { inherit kernelPackages; }; + networking.wireguard.interfaces.wg0 = { + preSetup = '' + ip netns add ${socketNamespace} + ''; + inherit socketNamespace; + interfaceNamespace = "init"; + }; }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - for machine in peer0, peer1, peer2, peer3: - machine.wait_for_unit("wireguard-wg0.service") + for machine in peer0, peer1, peer2, peer3: + machine.wait_for_unit("wireguard-wg0.service") - peer0.succeed("ip -n ${socketNamespace} link show wg0") - peer1.succeed("ip -n ${interfaceNamespace} link show wg0") - peer2.succeed("ip -n ${interfaceNamespace} link show wg0") - peer3.succeed("ip link show wg0") - ''; -}) + peer0.succeed("ip -n ${socketNamespace} link show wg0") + peer1.succeed("ip -n ${interfaceNamespace} link show wg0") + peer2.succeed("ip -n ${interfaceNamespace} link show wg0") + peer3.succeed("ip link show wg0") + ''; + } +) diff --git a/nixos/tests/wireguard/wg-quick.nix b/nixos/tests/wireguard/wg-quick.nix index ec2b8d7f2d9d16..981e741d32d2a4 100644 --- a/nixos/tests/wireguard/wg-quick.nix +++ b/nixos/tests/wireguard/wg-quick.nix @@ -1,4 +1,11 @@ -import ../make-test-python.nix ({ pkgs, lib, kernelPackages ? null, nftables ? false, ... }: +import ../make-test-python.nix ( + { + pkgs, + lib, + kernelPackages ? null, + nftables ? false, + ... + }: let wg-snakeoil-keys = import ./snakeoil-keys.nix; peer = import ./make-peer.nix { inherit lib; }; @@ -24,18 +31,28 @@ import ../make-test-python.nix ({ pkgs, lib, kernelPackages ? null, nftables ? f { networking.firewall.allowedUDPPorts = [ 23542 ]; networking.wg-quick.interfaces.wg0 = { - address = [ "10.23.42.1/32" "fc00::1/128" ]; + address = [ + "10.23.42.1/32" + "fc00::1/128" + ]; listenPort = 23542; inherit (wg-snakeoil-keys.peer0) privateKey; peers = lib.singleton { - allowedIPs = [ "10.23.42.2/32" "fc00::2/128" ]; + allowedIPs = [ + "10.23.42.2/32" + "fc00::2/128" + ]; inherit (wg-snakeoil-keys.peer1) publicKey; }; - dns = [ "10.23.42.2" "fc00::2" "wg0" ]; + dns = [ + "10.23.42.2" + "fc00::2" + "wg0" + ]; }; } ]; @@ -49,18 +66,28 @@ import ../make-test-python.nix ({ pkgs, lib, kernelPackages ? null, nftables ? f { networking.useNetworkd = true; networking.wg-quick.interfaces.wg0 = { - address = [ "10.23.42.2/32" "fc00::2/128" ]; + address = [ + "10.23.42.2/32" + "fc00::2/128" + ]; inherit (wg-snakeoil-keys.peer1) privateKey; peers = lib.singleton { - allowedIPs = [ "0.0.0.0/0" "::/0" ]; + allowedIPs = [ + "0.0.0.0/0" + "::/0" + ]; endpoint = "192.168.0.1:23542"; persistentKeepalive = 25; inherit (wg-snakeoil-keys.peer0) publicKey; }; - dns = [ "10.23.42.1" "fc00::1" "wg0" ]; + dns = [ + "10.23.42.1" + "fc00::1" + "wg0" + ]; }; } ]; diff --git a/nixos/tests/without-nix.nix b/nixos/tests/without-nix.nix index b21e9f2844f50d..2469a80e99b38a 100644 --- a/nixos/tests/without-nix.nix +++ b/nixos/tests/without-nix.nix @@ -1,32 +1,37 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "without-nix"; - meta = with lib.maintainers; { - maintainers = [ ericson2314 ]; - }; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "without-nix"; + meta = with lib.maintainers; { + maintainers = [ ericson2314 ]; + }; - nodes.machine = { ... }: { - nix.enable = false; - nixpkgs.overlays = [ - (self: super: { - nix = throw "don't want to use pkgs.nix"; - nixVersions = lib.mapAttrs (k: throw "don't want to use pkgs.nixVersions.${k}") super.nixVersions; - # aliases, some deprecated - nix_2_3 = throw "don't want to use pkgs.nix_2_3"; - nix_2_4 = throw "don't want to use pkgs.nix_2_4"; - nix_2_5 = throw "don't want to use pkgs.nix_2_5"; - nix_2_6 = throw "don't want to use pkgs.nix_2_6"; - nixFlakes = throw "don't want to use pkgs.nixFlakes"; - nixStable = throw "don't want to use pkgs.nixStable"; - nixUnstable = throw "don't want to use pkgs.nixUnstable"; - nixStatic = throw "don't want to use pkgs.nixStatic"; - }) - ]; - }; + nodes.machine = + { ... }: + { + nix.enable = false; + nixpkgs.overlays = [ + (self: super: { + nix = throw "don't want to use pkgs.nix"; + nixVersions = lib.mapAttrs (k: throw "don't want to use pkgs.nixVersions.${k}") super.nixVersions; + # aliases, some deprecated + nix_2_3 = throw "don't want to use pkgs.nix_2_3"; + nix_2_4 = throw "don't want to use pkgs.nix_2_4"; + nix_2_5 = throw "don't want to use pkgs.nix_2_5"; + nix_2_6 = throw "don't want to use pkgs.nix_2_6"; + nixFlakes = throw "don't want to use pkgs.nixFlakes"; + nixStable = throw "don't want to use pkgs.nixStable"; + nixUnstable = throw "don't want to use pkgs.nixUnstable"; + nixStatic = throw "don't want to use pkgs.nixStatic"; + }) + ]; + }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.succeed("which which") - machine.fail("which nix") - ''; -}) + machine.succeed("which which") + machine.fail("which nix") + ''; + } +) diff --git a/nixos/tests/wmderland.nix b/nixos/tests/wmderland.nix index c60751c44e2cc4..44622f340ca926 100644 --- a/nixos/tests/wmderland.nix +++ b/nixos/tests/wmderland.nix @@ -1,54 +1,66 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "wmderland"; - meta = with pkgs.lib.maintainers; { - maintainers = [ takagiy ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "wmderland"; + meta = with pkgs.lib.maintainers; { + maintainers = [ takagiy ]; + }; - nodes.machine = { lib, ... }: { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - services.displayManager.defaultSession = lib.mkForce "none+wmderland"; - services.xserver.windowManager.wmderland.enable = true; + nodes.machine = + { lib, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + services.displayManager.defaultSession = lib.mkForce "none+wmderland"; + services.xserver.windowManager.wmderland.enable = true; - systemd.services.setupWmderlandConfig = { - wantedBy = [ "multi-user.target" ]; - before = [ "multi-user.target" ]; - environment = { - HOME = "/home/alice"; - }; - unitConfig = { - type = "oneshot"; - RemainAfterExit = true; - user = "alice"; + systemd.services.setupWmderlandConfig = { + wantedBy = [ "multi-user.target" ]; + before = [ "multi-user.target" ]; + environment = { + HOME = "/home/alice"; + }; + unitConfig = { + type = "oneshot"; + RemainAfterExit = true; + user = "alice"; + }; + script = + let + config = pkgs.writeText "config" '' + set $Mod = Mod1 + bindsym $Mod+Return exec ${pkgs.xterm}/bin/xterm -cm -pc + ''; + in + '' + mkdir -p $HOME/.config/wmderland + cp ${config} $HOME/.config/wmderland/config + ''; + }; }; - script = let - config = pkgs.writeText "config" '' - set $Mod = Mod1 - bindsym $Mod+Return exec ${pkgs.xterm}/bin/xterm -cm -pc - ''; - in '' - mkdir -p $HOME/.config/wmderland - cp ${config} $HOME/.config/wmderland/config - ''; - }; - }; - testScript = { ... }: '' - with subtest("ensure x starts"): - machine.wait_for_x() - machine.wait_for_file("/home/alice/.Xauthority") - machine.succeed("xauth merge ~alice/.Xauthority") + testScript = + { ... }: + '' + with subtest("ensure x starts"): + machine.wait_for_x() + machine.wait_for_file("/home/alice/.Xauthority") + machine.succeed("xauth merge ~alice/.Xauthority") - with subtest("ensure we can open a new terminal"): - machine.send_key("alt-ret") - machine.wait_until_succeeds("pgrep xterm") - machine.wait_for_window(r"alice.*?machine") - machine.screenshot("terminal") + with subtest("ensure we can open a new terminal"): + machine.send_key("alt-ret") + machine.wait_until_succeeds("pgrep xterm") + machine.wait_for_window(r"alice.*?machine") + machine.screenshot("terminal") - with subtest("ensure we can communicate through ipc with wmderlandc"): - # Kills the previously open xterm - machine.succeed("pgrep xterm") - machine.execute("DISPLAY=:0 wmderlandc kill") - machine.fail("pgrep xterm") - ''; -}) + with subtest("ensure we can communicate through ipc with wmderlandc"): + # Kills the previously open xterm + machine.succeed("pgrep xterm") + machine.execute("DISPLAY=:0 wmderlandc kill") + machine.fail("pgrep xterm") + ''; + } +) diff --git a/nixos/tests/wordpress.nix b/nixos/tests/wordpress.nix index e54f32bf0a5d8e..4961a60275653f 100644 --- a/nixos/tests/wordpress.nix +++ b/nixos/tests/wordpress.nix @@ -1,101 +1,123 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: - -rec { - name = "wordpress"; - meta = with pkgs.lib.maintainers; { - maintainers = [ - flokli - grahamc # under duress! - mmilata - ]; - }; - - nodes = lib.foldl (a: version: let - package = pkgs."wordpress_${version}"; - in a // { - "wp${version}_httpd" = _: { - services.httpd.adminAddr = "webmaster@site.local"; - services.httpd.logPerVirtualHost = true; - - services.wordpress.webserver = "httpd"; - services.wordpress.sites = { - "site1.local" = { - database.tablePrefix = "site1_"; - inherit package; - }; - "site2.local" = { - database.tablePrefix = "site2_"; - inherit package; - }; - }; - - networking.firewall.allowedTCPPorts = [ 80 ]; - networking.hosts."127.0.0.1" = [ "site1.local" "site2.local" ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + + rec { + name = "wordpress"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + flokli + grahamc # under duress! + mmilata + ]; }; - "wp${version}_nginx" = _: { - services.wordpress.webserver = "nginx"; - services.wordpress.sites = { - "site1.local" = { - database.tablePrefix = "site1_"; - inherit package; - }; - "site2.local" = { - database.tablePrefix = "site2_"; - inherit package; - }; - }; - - networking.firewall.allowedTCPPorts = [ 80 ]; - networking.hosts."127.0.0.1" = [ "site1.local" "site2.local" ]; - }; - - "wp${version}_caddy" = _: { - services.wordpress.webserver = "caddy"; - services.wordpress.sites = { - "site1.local" = { - database.tablePrefix = "site1_"; - inherit package; - }; - "site2.local" = { - database.tablePrefix = "site2_"; - inherit package; - }; - }; - - networking.firewall.allowedTCPPorts = [ 80 ]; - networking.hosts."127.0.0.1" = [ "site1.local" "site2.local" ]; - }; - }) {} [ - "6_7" - ]; - - testScript = '' - import re - - start_all() - - ${lib.concatStrings (lib.mapAttrsToList (name: value: '' - ${name}.wait_for_unit("${(value null).services.wordpress.webserver}") - '') nodes)} - - site_names = ["site1.local", "site2.local"] - - for machine in (${lib.concatStringsSep ", " (builtins.attrNames nodes)}): - for site_name in site_names: - machine.wait_for_unit(f"phpfpm-wordpress-{site_name}") - - with subtest("website returns welcome screen"): - assert "Welcome to the famous" in machine.succeed(f"curl -L {site_name}") - - with subtest("wordpress-init went through"): - info = machine.get_unit_info(f"wordpress-init-{site_name}") - assert info["Result"] == "success" - - with subtest("secret keys are set"): - pattern = re.compile(r"^define.*NONCE_SALT.{64,};$", re.MULTILINE) - assert pattern.search( - machine.succeed(f"cat /var/lib/wordpress/{site_name}/secret-keys.php") - ) - ''; -}) + nodes = + lib.foldl + ( + a: version: + let + package = pkgs."wordpress_${version}"; + in + a + // { + "wp${version}_httpd" = _: { + services.httpd.adminAddr = "webmaster@site.local"; + services.httpd.logPerVirtualHost = true; + + services.wordpress.webserver = "httpd"; + services.wordpress.sites = { + "site1.local" = { + database.tablePrefix = "site1_"; + inherit package; + }; + "site2.local" = { + database.tablePrefix = "site2_"; + inherit package; + }; + }; + + networking.firewall.allowedTCPPorts = [ 80 ]; + networking.hosts."127.0.0.1" = [ + "site1.local" + "site2.local" + ]; + }; + + "wp${version}_nginx" = _: { + services.wordpress.webserver = "nginx"; + services.wordpress.sites = { + "site1.local" = { + database.tablePrefix = "site1_"; + inherit package; + }; + "site2.local" = { + database.tablePrefix = "site2_"; + inherit package; + }; + }; + + networking.firewall.allowedTCPPorts = [ 80 ]; + networking.hosts."127.0.0.1" = [ + "site1.local" + "site2.local" + ]; + }; + + "wp${version}_caddy" = _: { + services.wordpress.webserver = "caddy"; + services.wordpress.sites = { + "site1.local" = { + database.tablePrefix = "site1_"; + inherit package; + }; + "site2.local" = { + database.tablePrefix = "site2_"; + inherit package; + }; + }; + + networking.firewall.allowedTCPPorts = [ 80 ]; + networking.hosts."127.0.0.1" = [ + "site1.local" + "site2.local" + ]; + }; + } + ) + { } + [ + "6_7" + ]; + + testScript = '' + import re + + start_all() + + ${lib.concatStrings ( + lib.mapAttrsToList (name: value: '' + ${name}.wait_for_unit("${(value null).services.wordpress.webserver}") + '') nodes + )} + + site_names = ["site1.local", "site2.local"] + + for machine in (${lib.concatStringsSep ", " (builtins.attrNames nodes)}): + for site_name in site_names: + machine.wait_for_unit(f"phpfpm-wordpress-{site_name}") + + with subtest("website returns welcome screen"): + assert "Welcome to the famous" in machine.succeed(f"curl -L {site_name}") + + with subtest("wordpress-init went through"): + info = machine.get_unit_info(f"wordpress-init-{site_name}") + assert info["Result"] == "success" + + with subtest("secret keys are set"): + pattern = re.compile(r"^define.*NONCE_SALT.{64,};$", re.MULTILINE) + assert pattern.search( + machine.succeed(f"cat /var/lib/wordpress/{site_name}/secret-keys.php") + ) + ''; + } +) diff --git a/nixos/tests/wpa_supplicant.nix b/nixos/tests/wpa_supplicant.nix index 0ec75b4606764b..180219adca7540 100644 --- a/nixos/tests/wpa_supplicant.nix +++ b/nixos/tests/wpa_supplicant.nix @@ -5,89 +5,94 @@ let inherit (pkgs) lib; meta = with lib.maintainers; { - maintainers = [ oddlama rnhmjoj ]; + maintainers = [ + oddlama + rnhmjoj + ]; }; naughtyPassphrase = ''!,./;'[]\-=<>?:"{}|_+@$%^&*()`~ # ceci n'est pas un commentaire''; - runConnectionTest = name: extraConfig: runTest { - name = "wpa_supplicant-${name}"; - inherit meta; - - nodes.machine = { - # add a virtual wlan interface - boot.kernelModules = [ "mac80211_hwsim" ]; - - # wireless access point - services.hostapd = { - enable = true; - radios.wlan0 = { - band = "2g"; - channel = 6; - countryCode = "US"; - networks = { - wlan0 = { - ssid = "nixos-test-sae"; - authentication = { - mode = "wpa3-sae"; - saePasswords = [ { password = naughtyPassphrase; } ]; + runConnectionTest = + name: extraConfig: + runTest { + name = "wpa_supplicant-${name}"; + inherit meta; + + nodes.machine = { + # add a virtual wlan interface + boot.kernelModules = [ "mac80211_hwsim" ]; + + # wireless access point + services.hostapd = { + enable = true; + radios.wlan0 = { + band = "2g"; + channel = 6; + countryCode = "US"; + networks = { + wlan0 = { + ssid = "nixos-test-sae"; + authentication = { + mode = "wpa3-sae"; + saePasswords = [ { password = naughtyPassphrase; } ]; + }; + bssid = "02:00:00:00:00:00"; }; - bssid = "02:00:00:00:00:00"; - }; - wlan0-1 = { - ssid = "nixos-test-mixed"; - authentication = { - mode = "wpa3-sae-transition"; - saeAddToMacAllow = true; - saePasswordsFile = pkgs.writeText "password" naughtyPassphrase; - wpaPasswordFile = pkgs.writeText "password" naughtyPassphrase; + wlan0-1 = { + ssid = "nixos-test-mixed"; + authentication = { + mode = "wpa3-sae-transition"; + saeAddToMacAllow = true; + saePasswordsFile = pkgs.writeText "password" naughtyPassphrase; + wpaPasswordFile = pkgs.writeText "password" naughtyPassphrase; + }; + bssid = "02:00:00:00:00:01"; }; - bssid = "02:00:00:00:00:01"; - }; - wlan0-2 = { - ssid = "nixos-test-wpa2"; - authentication = { - mode = "wpa2-sha256"; - wpaPassword = naughtyPassphrase; + wlan0-2 = { + ssid = "nixos-test-wpa2"; + authentication = { + mode = "wpa2-sha256"; + wpaPassword = naughtyPassphrase; + }; + bssid = "02:00:00:00:00:02"; }; - bssid = "02:00:00:00:00:02"; }; }; }; + + # wireless client + networking.wireless = lib.mkMerge [ + { + # the override is needed because the wifi is + # disabled with mkVMOverride in qemu-vm.nix. + enable = lib.mkOverride 0 true; + userControlled.enable = true; + interfaces = [ "wlan1" ]; + fallbackToWPA2 = lib.mkDefault true; + + # secrets + secretsFile = pkgs.writeText "wpa-secrets" '' + psk_nixos_test=${naughtyPassphrase} + ''; + } + extraConfig + ]; }; - # wireless client - networking.wireless = lib.mkMerge [ - { - # the override is needed because the wifi is - # disabled with mkVMOverride in qemu-vm.nix. - enable = lib.mkOverride 0 true; - userControlled.enable = true; - interfaces = [ "wlan1" ]; - fallbackToWPA2 = lib.mkDefault true; - - # secrets - secretsFile = pkgs.writeText "wpa-secrets" '' - psk_nixos_test=${naughtyPassphrase} - ''; - } - extraConfig - ]; + testScript = '' + # save hostapd config file for manual inspection + machine.wait_for_unit("hostapd.service") + machine.copy_from_vm("/run/hostapd/wlan0.hostapd.conf") + + with subtest("Daemon can connect to the access point"): + machine.wait_for_unit("wpa_supplicant-wlan1.service") + machine.wait_until_succeeds( + "wpa_cli -i wlan1 status | grep -q wpa_state=COMPLETED" + ) + ''; }; - testScript = '' - # save hostapd config file for manual inspection - machine.wait_for_unit("hostapd.service") - machine.copy_from_vm("/run/hostapd/wlan0.hostapd.conf") - - with subtest("Daemon can connect to the access point"): - machine.wait_for_unit("wpa_supplicant-wlan1.service") - machine.wait_until_succeeds( - "wpa_cli -i wlan1 status | grep -q wpa_state=COMPLETED" - ) - ''; - }; - in { @@ -115,7 +120,10 @@ in # test WPA2 fallback mixed-wpa = { psk = "password"; - authProtocols = [ "WPA-PSK" "SAE" ]; + authProtocols = [ + "WPA-PSK" + "SAE" + ]; }; sae-only = { psk = "password"; diff --git a/nixos/tests/wrappers.nix b/nixos/tests/wrappers.nix index 1d4fa85d739935..8feb92b3792753 100644 --- a/nixos/tests/wrappers.nix +++ b/nixos/tests/wrappers.nix @@ -1,55 +1,59 @@ -import ./make-test-python.nix ({ pkgs, ... }: -let - userUid = 1000; - usersGid = 100; - busybox = pkgs : pkgs.busybox.override { - # Without this, the busybox binary drops euid to ruid for most applets, including id. - # See https://bugs.busybox.net/show_bug.cgi?id=15101 - extraConfig = "CONFIG_FEATURE_SUID n"; - }; -in -{ - name = "wrappers"; - - nodes.machine = { config, pkgs, ... }: { - ids.gids.users = usersGid; - - users.users = { - regular = { - uid = userUid; - isNormalUser = true; +import ./make-test-python.nix ( + { pkgs, ... }: + let + userUid = 1000; + usersGid = 100; + busybox = + pkgs: + pkgs.busybox.override { + # Without this, the busybox binary drops euid to ruid for most applets, including id. + # See https://bugs.busybox.net/show_bug.cgi?id=15101 + extraConfig = "CONFIG_FEATURE_SUID n"; }; - }; - - security.apparmor.enable = true; - - security.wrappers = { - suidRoot = { - owner = "root"; - group = "root"; - setuid = true; - source = "${busybox pkgs}/bin/busybox"; - program = "suid_root_busybox"; - }; - sgidRoot = { - owner = "root"; - group = "root"; - setgid = true; - source = "${busybox pkgs}/bin/busybox"; - program = "sgid_root_busybox"; - }; - withChown = { - owner = "root"; - group = "root"; - source = "${pkgs.libcap}/bin/capsh"; - program = "capsh_with_chown"; - capabilities = "cap_chown+ep"; + in + { + name = "wrappers"; + + nodes.machine = + { config, pkgs, ... }: + { + ids.gids.users = usersGid; + + users.users = { + regular = { + uid = userUid; + isNormalUser = true; + }; + }; + + security.apparmor.enable = true; + + security.wrappers = { + suidRoot = { + owner = "root"; + group = "root"; + setuid = true; + source = "${busybox pkgs}/bin/busybox"; + program = "suid_root_busybox"; + }; + sgidRoot = { + owner = "root"; + group = "root"; + setgid = true; + source = "${busybox pkgs}/bin/busybox"; + program = "sgid_root_busybox"; + }; + withChown = { + owner = "root"; + group = "root"; + source = "${pkgs.libcap}/bin/capsh"; + program = "capsh_with_chown"; + capabilities = "cap_chown+ep"; + }; + }; }; - }; - }; - testScript = - '' + testScript = '' def cmd_as_regular(cmd): return "su -l regular -c '{0}'".format(cmd) @@ -109,4 +113,5 @@ in # test for that one. machine.succeed("ping -c 1 127.0.0.1") ''; -}) + } +) diff --git a/nixos/tests/xandikos.nix b/nixos/tests/xandikos.nix index 69d78ee21e767b..4905a5bc067d56 100644 --- a/nixos/tests/xandikos.nix +++ b/nixos/tests/xandikos.nix @@ -1,70 +1,73 @@ import ./make-test-python.nix ( { pkgs, lib, ... }: - { - name = "xandikos"; + { + name = "xandikos"; - meta.maintainers = with lib.maintainers; [ _0x4A6F ]; + meta.maintainers = with lib.maintainers; [ _0x4A6F ]; - nodes = { - xandikos_client = {}; - xandikos_default = { - networking.firewall.allowedTCPPorts = [ 8080 ]; - services.xandikos.enable = true; - }; - xandikos_proxy = { - networking.firewall.allowedTCPPorts = [ 80 8080 ]; - services.xandikos.enable = true; - services.xandikos.address = "localhost"; - services.xandikos.port = 8080; - services.xandikos.routePrefix = "/xandikos-prefix/"; - services.xandikos.extraOptions = [ - "--defaults" - ]; - services.nginx = { - enable = true; - recommendedProxySettings = true; - virtualHosts."xandikos" = { - serverName = "xandikos.local"; - basicAuth.xandikos = "snakeOilPassword"; - locations."/xandikos/" = { - proxyPass = "http://localhost:8080/xandikos-prefix/"; - }; + nodes = { + xandikos_client = { }; + xandikos_default = { + networking.firewall.allowedTCPPorts = [ 8080 ]; + services.xandikos.enable = true; + }; + xandikos_proxy = { + networking.firewall.allowedTCPPorts = [ + 80 + 8080 + ]; + services.xandikos.enable = true; + services.xandikos.address = "localhost"; + services.xandikos.port = 8080; + services.xandikos.routePrefix = "/xandikos-prefix/"; + services.xandikos.extraOptions = [ + "--defaults" + ]; + services.nginx = { + enable = true; + recommendedProxySettings = true; + virtualHosts."xandikos" = { + serverName = "xandikos.local"; + basicAuth.xandikos = "snakeOilPassword"; + locations."/xandikos/" = { + proxyPass = "http://localhost:8080/xandikos-prefix/"; }; }; }; }; + }; - testScript = '' - start_all() + testScript = '' + start_all() - with subtest("Xandikos default"): - xandikos_default.wait_for_unit("multi-user.target") - xandikos_default.wait_for_unit("xandikos.service") - xandikos_default.wait_for_open_port(8080) - xandikos_default.succeed("curl --fail http://localhost:8080/") - xandikos_default.succeed( - "curl -s --fail --location http://localhost:8080/ | grep -i Xandikos" - ) - xandikos_client.wait_for_unit("network.target") - xandikos_client.fail("curl --fail http://xandikos_default:8080/") + with subtest("Xandikos default"): + xandikos_default.wait_for_unit("multi-user.target") + xandikos_default.wait_for_unit("xandikos.service") + xandikos_default.wait_for_open_port(8080) + xandikos_default.succeed("curl --fail http://localhost:8080/") + xandikos_default.succeed( + "curl -s --fail --location http://localhost:8080/ | grep -i Xandikos" + ) + xandikos_client.wait_for_unit("network.target") + xandikos_client.fail("curl --fail http://xandikos_default:8080/") - with subtest("Xandikos proxy"): - xandikos_proxy.wait_for_unit("multi-user.target") - xandikos_proxy.wait_for_unit("xandikos.service") - xandikos_proxy.wait_for_open_port(8080) - xandikos_proxy.succeed("curl --fail http://localhost:8080/") - xandikos_proxy.succeed( - "curl -s --fail --location http://localhost:8080/ | grep -i Xandikos" - ) - xandikos_client.wait_for_unit("network.target") - xandikos_client.fail("curl --fail http://xandikos_proxy:8080/") - xandikos_client.succeed( - "curl -s --fail -u xandikos:snakeOilPassword -H 'Host: xandikos.local' http://xandikos_proxy/xandikos/ | grep -i Xandikos" - ) - xandikos_client.succeed( - "curl -s --fail -u xandikos:snakeOilPassword -H 'Host: xandikos.local' http://xandikos_proxy/xandikos/user/ | grep -i Xandikos" - ) - ''; - } + with subtest("Xandikos proxy"): + xandikos_proxy.wait_for_unit("multi-user.target") + xandikos_proxy.wait_for_unit("xandikos.service") + xandikos_proxy.wait_for_open_port(8080) + xandikos_proxy.succeed("curl --fail http://localhost:8080/") + xandikos_proxy.succeed( + "curl -s --fail --location http://localhost:8080/ | grep -i Xandikos" + ) + xandikos_client.wait_for_unit("network.target") + xandikos_client.fail("curl --fail http://xandikos_proxy:8080/") + xandikos_client.succeed( + "curl -s --fail -u xandikos:snakeOilPassword -H 'Host: xandikos.local' http://xandikos_proxy/xandikos/ | grep -i Xandikos" + ) + xandikos_client.succeed( + "curl -s --fail -u xandikos:snakeOilPassword -H 'Host: xandikos.local' http://xandikos_proxy/xandikos/user/ | grep -i Xandikos" + ) + ''; + } ) diff --git a/nixos/tests/xautolock.nix b/nixos/tests/xautolock.nix index cf81c4a1cf05db..5b35f36b754640 100644 --- a/nixos/tests/xautolock.nix +++ b/nixos/tests/xautolock.nix @@ -1,22 +1,27 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: -{ - name = "xautolock"; - meta.maintainers = [ ]; + { + name = "xautolock"; + meta.maintainers = [ ]; - nodes.machine = { - imports = [ ./common/x11.nix ./common/user-account.nix ]; + nodes.machine = { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; - test-support.displayManager.auto.user = "bob"; - services.xserver.xautolock.enable = true; - services.xserver.xautolock.time = 1; - }; + test-support.displayManager.auto.user = "bob"; + services.xserver.xautolock.enable = true; + services.xserver.xautolock.time = 1; + }; - testScript = '' - machine.start() - machine.wait_for_x() - machine.fail("pgrep xlock") - machine.sleep(120) - machine.succeed("pgrep xlock") - ''; -}) + testScript = '' + machine.start() + machine.wait_for_x() + machine.fail("pgrep xlock") + machine.sleep(120) + machine.succeed("pgrep xlock") + ''; + } +) diff --git a/nixos/tests/xfce.nix b/nixos/tests/xfce.nix index 1cef8daf3d49f0..d22681dd903bd1 100644 --- a/nixos/tests/xfce.nix +++ b/nixos/tests/xfce.nix @@ -1,70 +1,76 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "xfce"; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "xfce"; - nodes.machine = - { pkgs, ... }: + nodes.machine = + { pkgs, ... }: - { - imports = [ - ./common/user-account.nix - ]; + { + imports = [ + ./common/user-account.nix + ]; - services.xserver.enable = true; - services.xserver.displayManager.lightdm.enable = true; + services.xserver.enable = true; + services.xserver.displayManager.lightdm.enable = true; - services.displayManager.autoLogin = { - enable = true; - user = "alice"; - }; + services.displayManager.autoLogin = { + enable = true; + user = "alice"; + }; - services.xserver.desktopManager.xfce.enable = true; - environment.systemPackages = [ pkgs.xfce.xfce4-whiskermenu-plugin ]; - }; + services.xserver.desktopManager.xfce.enable = true; + environment.systemPackages = [ pkgs.xfce.xfce4-whiskermenu-plugin ]; + }; - enableOCR = true; + enableOCR = true; - testScript = { nodes, ... }: let - user = nodes.machine.users.users.alice; - bus = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${toString user.uid}/bus"; - in '' - with subtest("Wait for login"): - machine.wait_for_x() - machine.wait_for_file("${user.home}/.Xauthority") - machine.succeed("xauth merge ${user.home}/.Xauthority") + testScript = + { nodes, ... }: + let + user = nodes.machine.users.users.alice; + bus = "DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${toString user.uid}/bus"; + in + '' + with subtest("Wait for login"): + machine.wait_for_x() + machine.wait_for_file("${user.home}/.Xauthority") + machine.succeed("xauth merge ${user.home}/.Xauthority") - with subtest("Check that logging in has given the user ownership of devices"): - machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") + with subtest("Check that logging in has given the user ownership of devices"): + machine.succeed("getfacl -p /dev/snd/timer | grep -q ${user.name}") - with subtest("Check if Xfce components actually start"): - machine.wait_for_window("xfce4-panel") - machine.wait_for_window("Desktop") - for i in ["xfwm4", "xfsettingsd", "xfdesktop", "xfce4-screensaver", "xfce4-notifyd", "xfconfd"]: - machine.wait_until_succeeds(f"pgrep -f {i}") + with subtest("Check if Xfce components actually start"): + machine.wait_for_window("xfce4-panel") + machine.wait_for_window("Desktop") + for i in ["xfwm4", "xfsettingsd", "xfdesktop", "xfce4-screensaver", "xfce4-notifyd", "xfconfd"]: + machine.wait_until_succeeds(f"pgrep -f {i}") - with subtest("Open whiskermenu"): - machine.succeed("su - ${user.name} -c 'DISPLAY=:0 ${bus} xfconf-query -c xfce4-panel -p /plugins/plugin-1 -t string -s whiskermenu -n >&2 &'") - machine.succeed("su - ${user.name} -c 'DISPLAY=:0 ${bus} xfconf-query -c xfce4-panel -p /plugins/plugin-1/stay-on-focus-out -t bool -s true -n >&2 &'") - machine.succeed("su - ${user.name} -c 'DISPLAY=:0 ${bus} xfce4-panel -r >&2 &'") - machine.wait_until_succeeds("journalctl -b --grep 'xfce4-panel: Restarting' -t xsession") - machine.sleep(5) - machine.wait_until_succeeds("pgrep -f libwhiskermenu") - machine.succeed("su - ${user.name} -c 'DISPLAY=:0 ${bus} xfce4-popup-whiskermenu >&2 &'") - machine.wait_for_text('Mail Reader') - # Close the menu. - machine.succeed("su - ${user.name} -c 'DISPLAY=:0 ${bus} xfce4-popup-whiskermenu >&2 &'") + with subtest("Open whiskermenu"): + machine.succeed("su - ${user.name} -c 'DISPLAY=:0 ${bus} xfconf-query -c xfce4-panel -p /plugins/plugin-1 -t string -s whiskermenu -n >&2 &'") + machine.succeed("su - ${user.name} -c 'DISPLAY=:0 ${bus} xfconf-query -c xfce4-panel -p /plugins/plugin-1/stay-on-focus-out -t bool -s true -n >&2 &'") + machine.succeed("su - ${user.name} -c 'DISPLAY=:0 ${bus} xfce4-panel -r >&2 &'") + machine.wait_until_succeeds("journalctl -b --grep 'xfce4-panel: Restarting' -t xsession") + machine.sleep(5) + machine.wait_until_succeeds("pgrep -f libwhiskermenu") + machine.succeed("su - ${user.name} -c 'DISPLAY=:0 ${bus} xfce4-popup-whiskermenu >&2 &'") + machine.wait_for_text('Mail Reader') + # Close the menu. + machine.succeed("su - ${user.name} -c 'DISPLAY=:0 ${bus} xfce4-popup-whiskermenu >&2 &'") - with subtest("Open Xfce terminal"): - machine.succeed("su - ${user.name} -c 'DISPLAY=:0 xfce4-terminal >&2 &'") - machine.wait_for_window("Terminal") + with subtest("Open Xfce terminal"): + machine.succeed("su - ${user.name} -c 'DISPLAY=:0 xfce4-terminal >&2 &'") + machine.wait_for_window("Terminal") - with subtest("Open Thunar"): - machine.succeed("su - ${user.name} -c 'DISPLAY=:0 thunar >&2 &'") - machine.wait_for_window("Thunar") - machine.wait_for_text('(Pictures|Public|Templates|Videos)') + with subtest("Open Thunar"): + machine.succeed("su - ${user.name} -c 'DISPLAY=:0 thunar >&2 &'") + machine.wait_for_window("Thunar") + machine.wait_for_text('(Pictures|Public|Templates|Videos)') - with subtest("Check if any coredumps are found"): - machine.succeed("(coredumpctl --json=short 2>&1 || true) | grep 'No coredumps found'") - machine.sleep(10) - machine.screenshot("screen") - ''; -}) + with subtest("Check if any coredumps are found"): + machine.succeed("(coredumpctl --json=short 2>&1 || true) | grep 'No coredumps found'") + machine.sleep(10) + machine.screenshot("screen") + ''; + } +) diff --git a/nixos/tests/xmonad-xdg-autostart.nix b/nixos/tests/xmonad-xdg-autostart.nix index f1780072f9740c..419b3e413a08f4 100644 --- a/nixos/tests/xmonad-xdg-autostart.nix +++ b/nixos/tests/xmonad-xdg-autostart.nix @@ -1,35 +1,44 @@ -import ./make-test-python.nix ({ lib, ... }: { - name = "xmonad-xdg-autostart"; - meta.maintainers = with lib.maintainers; [ oxalica ]; +import ./make-test-python.nix ( + { lib, ... }: + { + name = "xmonad-xdg-autostart"; + meta.maintainers = with lib.maintainers; [ oxalica ]; - nodes.machine = { pkgs, config, ... }: { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - services.displayManager.defaultSession = "none+xmonad"; - services.xserver.windowManager.xmonad.enable = true; - services.xserver.desktopManager.runXdgAutostartIfNone = true; + nodes.machine = + { pkgs, config, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + services.displayManager.defaultSession = "none+xmonad"; + services.xserver.windowManager.xmonad.enable = true; + services.xserver.desktopManager.runXdgAutostartIfNone = true; - environment.systemPackages = [ - (pkgs.writeTextFile { - name = "test-xdg-autostart"; - destination = "/etc/xdg/autostart/test-xdg-autostart.desktop"; - text = '' - [Desktop Entry] - Name=test-xdg-autoatart - Type=Application - Terminal=false - Exec=${pkgs.coreutils}/bin/touch ${config.users.users.alice.home}/xdg-autostart-executed - ''; - }) - ]; - }; + environment.systemPackages = [ + (pkgs.writeTextFile { + name = "test-xdg-autostart"; + destination = "/etc/xdg/autostart/test-xdg-autostart.desktop"; + text = '' + [Desktop Entry] + Name=test-xdg-autoatart + Type=Application + Terminal=false + Exec=${pkgs.coreutils}/bin/touch ${config.users.users.alice.home}/xdg-autostart-executed + ''; + }) + ]; + }; - testScript = { nodes, ... }: - let - user = nodes.machine.config.users.users.alice; - in - '' - machine.wait_for_x() - machine.wait_for_file("${user.home}/xdg-autostart-executed") - ''; -}) + testScript = + { nodes, ... }: + let + user = nodes.machine.config.users.users.alice; + in + '' + machine.wait_for_x() + machine.wait_for_file("${user.home}/xdg-autostart-executed") + ''; + } +) diff --git a/nixos/tests/xmonad.nix b/nixos/tests/xmonad.nix index c61e96886e2c59..803d468bd12fa5 100644 --- a/nixos/tests/xmonad.nix +++ b/nixos/tests/xmonad.nix @@ -1,117 +1,131 @@ -import ./make-test-python.nix ({ pkgs, ...}: - -let - mkConfig = name: keys: '' - import XMonad - import XMonad.Operations (restart) - import XMonad.Util.EZConfig - import XMonad.Util.SessionStart - import Control.Monad (when) - import Text.Printf (printf) - import System.Posix.Process (executeFile) - import System.Info (arch,os) - import System.Environment (getArgs) - import System.FilePath (()) - - main = do - dirs <- getDirectories - launch (def { startupHook = startup } `additionalKeysP` myKeys) dirs - - startup = isSessionStart >>= \sessInit -> - spawn "touch /tmp/${name}" - >> if sessInit then setSessionStarted else spawn "xterm" - - myKeys = [${builtins.concatStringsSep ", " keys}] - - compiledConfig = printf "xmonad-%s-%s" arch os - - compileRestart resume = do - dirs <- asks directories - - whenX (recompile dirs True) $ - when resume writeStateToFile - *> catchIO - ( do - args <- getArgs - executeFile (cacheDir dirs compiledConfig) False args Nothing - ) - ''; - - oldKeys = - [ ''("M-C-x", spawn "xterm")'' +import ./make-test-python.nix ( + { pkgs, ... }: + + let + mkConfig = name: keys: '' + import XMonad + import XMonad.Operations (restart) + import XMonad.Util.EZConfig + import XMonad.Util.SessionStart + import Control.Monad (when) + import Text.Printf (printf) + import System.Posix.Process (executeFile) + import System.Info (arch,os) + import System.Environment (getArgs) + import System.FilePath (()) + + main = do + dirs <- getDirectories + launch (def { startupHook = startup } `additionalKeysP` myKeys) dirs + + startup = isSessionStart >>= \sessInit -> + spawn "touch /tmp/${name}" + >> if sessInit then setSessionStarted else spawn "xterm" + + myKeys = [${builtins.concatStringsSep ", " keys}] + + compiledConfig = printf "xmonad-%s-%s" arch os + + compileRestart resume = do + dirs <- asks directories + + whenX (recompile dirs True) $ + when resume writeStateToFile + *> catchIO + ( do + args <- getArgs + executeFile (cacheDir dirs compiledConfig) False args Nothing + ) + ''; + + oldKeys = [ + ''("M-C-x", spawn "xterm")'' ''("M-q", restart "xmonad" True)'' ''("M-C-q", compileRestart True)'' ''("M-C-t", spawn "touch /tmp/somefile")'' # create somefile ]; - newKeys = - [ ''("M-C-x", spawn "xterm")'' + newKeys = [ + ''("M-C-x", spawn "xterm")'' ''("M-q", restart "xmonad" True)'' ''("M-C-q", compileRestart True)'' ''("M-C-r", spawn "rm /tmp/somefile")'' # delete somefile ]; - newConfig = pkgs.writeText "xmonad.hs" (mkConfig "newXMonad" newKeys); -in { - name = "xmonad"; - meta = with pkgs.lib.maintainers; { - maintainers = [ nequissimus ivanbrennan ]; - }; - - nodes.machine = { pkgs, ... }: { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - services.displayManager.defaultSession = "none+xmonad"; - services.xserver.windowManager.xmonad = { - enable = true; - enableConfiguredRecompile = true; - enableContribAndExtras = true; - extraPackages = with pkgs.haskellPackages; haskellPackages: [ xmobar ]; - config = mkConfig "oldXMonad" oldKeys; + newConfig = pkgs.writeText "xmonad.hs" (mkConfig "newXMonad" newKeys); + in + { + name = "xmonad"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + nequissimus + ivanbrennan + ]; }; - }; - - testScript = { nodes, ... }: let - user = nodes.machine.config.users.users.alice; - in '' - machine.wait_for_x() - machine.wait_for_file("${user.home}/.Xauthority") - machine.succeed("xauth merge ${user.home}/.Xauthority") - machine.send_key("alt-ctrl-x") - machine.wait_for_window("${user.name}.*machine") - machine.sleep(1) - machine.screenshot("terminal1") - machine.succeed("rm /tmp/oldXMonad") - machine.send_key("alt-q") - machine.wait_for_file("/tmp/oldXMonad") - machine.wait_for_window("${user.name}.*machine") - machine.sleep(1) - machine.screenshot("terminal2") - - # /tmp/somefile should not exist yet - machine.fail("stat /tmp/somefile") - - # original config has a keybinding that creates somefile - machine.send_key("alt-ctrl-t") - machine.wait_for_file("/tmp/somefile") - - # set up the new config - machine.succeed("mkdir -p ${user.home}/.xmonad") - machine.copy_from_host("${newConfig}", "${user.home}/.config/xmonad/xmonad.hs") - - # recompile xmonad using the new config - machine.send_key("alt-ctrl-q") - machine.wait_for_file("/tmp/newXMonad") - - # new config has a keybinding that deletes somefile - machine.send_key("alt-ctrl-r") - machine.wait_until_fails("stat /tmp/somefile", timeout=30) - - # restart with the old config, and confirm the old keybinding is back - machine.succeed("rm /tmp/oldXMonad") - machine.send_key("alt-q") - machine.wait_for_file("/tmp/oldXMonad") - machine.send_key("alt-ctrl-t") - machine.wait_for_file("/tmp/somefile") - ''; -}) + + nodes.machine = + { pkgs, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + services.displayManager.defaultSession = "none+xmonad"; + services.xserver.windowManager.xmonad = { + enable = true; + enableConfiguredRecompile = true; + enableContribAndExtras = true; + extraPackages = with pkgs.haskellPackages; haskellPackages: [ xmobar ]; + config = mkConfig "oldXMonad" oldKeys; + }; + }; + + testScript = + { nodes, ... }: + let + user = nodes.machine.config.users.users.alice; + in + '' + machine.wait_for_x() + machine.wait_for_file("${user.home}/.Xauthority") + machine.succeed("xauth merge ${user.home}/.Xauthority") + machine.send_key("alt-ctrl-x") + machine.wait_for_window("${user.name}.*machine") + machine.sleep(1) + machine.screenshot("terminal1") + machine.succeed("rm /tmp/oldXMonad") + machine.send_key("alt-q") + machine.wait_for_file("/tmp/oldXMonad") + machine.wait_for_window("${user.name}.*machine") + machine.sleep(1) + machine.screenshot("terminal2") + + # /tmp/somefile should not exist yet + machine.fail("stat /tmp/somefile") + + # original config has a keybinding that creates somefile + machine.send_key("alt-ctrl-t") + machine.wait_for_file("/tmp/somefile") + + # set up the new config + machine.succeed("mkdir -p ${user.home}/.xmonad") + machine.copy_from_host("${newConfig}", "${user.home}/.config/xmonad/xmonad.hs") + + # recompile xmonad using the new config + machine.send_key("alt-ctrl-q") + machine.wait_for_file("/tmp/newXMonad") + + # new config has a keybinding that deletes somefile + machine.send_key("alt-ctrl-r") + machine.wait_until_fails("stat /tmp/somefile", timeout=30) + + # restart with the old config, and confirm the old keybinding is back + machine.succeed("rm /tmp/oldXMonad") + machine.send_key("alt-q") + machine.wait_for_file("/tmp/oldXMonad") + machine.send_key("alt-ctrl-t") + machine.wait_for_file("/tmp/somefile") + ''; + } +) diff --git a/nixos/tests/xmpp/ejabberd.nix b/nixos/tests/xmpp/ejabberd.nix index a31a1b8eeab851..8af378322aa93f 100644 --- a/nixos/tests/xmpp/ejabberd.nix +++ b/nixos/tests/xmpp/ejabberd.nix @@ -1,293 +1,306 @@ let - cert = pkgs: pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' - openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=example.com/CN=muc.example.com' -days 36500 - mkdir -p $out - cp key.pem cert.pem $out - ''; + cert = + pkgs: + pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' + openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=example.com/CN=muc.example.com' -days 36500 + mkdir -p $out + cp key.pem cert.pem $out + ''; in -import ../make-test-python.nix ({ pkgs, ... }: { - name = "ejabberd"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; - nodes = { - client = { nodes, pkgs, ... }: { - security.pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; - networking.extraHosts = '' - ${nodes.server.config.networking.primaryIPAddress} example.com - ''; - - environment.systemPackages = [ - (pkgs.callPackage ./xmpp-sendmessage.nix { connectTo = nodes.server.config.networking.primaryIPAddress; }) - ]; +import ../make-test-python.nix ( + { pkgs, ... }: + { + name = "ejabberd"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; }; - server = { config, pkgs, ... }: { - security.pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; - networking.extraHosts = '' - ${config.networking.primaryIPAddress} example.com - ''; + nodes = { + client = + { nodes, pkgs, ... }: + { + security.pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; + networking.extraHosts = '' + ${nodes.server.config.networking.primaryIPAddress} example.com + ''; - services.ejabberd = { - enable = true; - configFile = "/etc/ejabberd.yml"; - }; + environment.systemPackages = [ + (pkgs.callPackage ./xmpp-sendmessage.nix { + connectTo = nodes.server.config.networking.primaryIPAddress; + }) + ]; + }; + server = + { config, pkgs, ... }: + { + security.pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; + networking.extraHosts = '' + ${config.networking.primaryIPAddress} example.com + ''; - systemd.services.ejabberd.serviceConfig.TimeoutStartSec = "15min"; - environment.etc."ejabberd.yml" = { - user = "ejabberd"; - mode = "0600"; - text = '' - loglevel: 3 + services.ejabberd = { + enable = true; + configFile = "/etc/ejabberd.yml"; + }; - hosts: - - "example.com" + systemd.services.ejabberd.serviceConfig.TimeoutStartSec = "15min"; + environment.etc."ejabberd.yml" = { + user = "ejabberd"; + mode = "0600"; + text = '' + loglevel: 3 - listen: - - - port: 5222 - module: ejabberd_c2s - zlib: false - max_stanza_size: 65536 - shaper: c2s_shaper - access: c2s - starttls: true - - - port: 5269 - ip: "::" - module: ejabberd_s2s_in - - - port: 5347 - ip: "127.0.0.1" - module: ejabberd_service - access: local - shaper: fast - - - port: 5444 - module: ejabberd_http - request_handlers: - "/upload": mod_http_upload + hosts: + - "example.com" - certfiles: - - ${cert pkgs}/key.pem - - ${cert pkgs}/cert.pem + listen: + - + port: 5222 + module: ejabberd_c2s + zlib: false + max_stanza_size: 65536 + shaper: c2s_shaper + access: c2s + starttls: true + - + port: 5269 + ip: "::" + module: ejabberd_s2s_in + - + port: 5347 + ip: "127.0.0.1" + module: ejabberd_service + access: local + shaper: fast + - + port: 5444 + module: ejabberd_http + request_handlers: + "/upload": mod_http_upload - ## Disabling digest-md5 SASL authentication. digest-md5 requires plain-text - ## password storage (see auth_password_format option). - disable_sasl_mechanisms: "digest-md5" + certfiles: + - ${cert pkgs}/key.pem + - ${cert pkgs}/cert.pem - ## Outgoing S2S options - ## Preferred address families (which to try first) and connect timeout - ## in seconds. - outgoing_s2s_families: - - ipv4 - - ipv6 + ## Disabling digest-md5 SASL authentication. digest-md5 requires plain-text + ## password storage (see auth_password_format option). + disable_sasl_mechanisms: "digest-md5" - ## auth_method: Method used to authenticate the users. - ## The default method is the internal. - ## If you want to use a different method, - ## comment this line and enable the correct ones. - auth_method: internal + ## Outgoing S2S options + ## Preferred address families (which to try first) and connect timeout + ## in seconds. + outgoing_s2s_families: + - ipv4 + - ipv6 - ## Store the plain passwords or hashed for SCRAM: - ## auth_password_format: plain - auth_password_format: scram + ## auth_method: Method used to authenticate the users. + ## The default method is the internal. + ## If you want to use a different method, + ## comment this line and enable the correct ones. + auth_method: internal - ###' TRAFFIC SHAPERS - shaper: - # in B/s - normal: 1000000 - fast: 50000000 + ## Store the plain passwords or hashed for SCRAM: + ## auth_password_format: plain + auth_password_format: scram - ## This option specifies the maximum number of elements in the queue - ## of the FSM. Refer to the documentation for details. - max_fsm_queue: 1000 + ###' TRAFFIC SHAPERS + shaper: + # in B/s + normal: 1000000 + fast: 50000000 - ###' ACCESS CONTROL LISTS - acl: - ## The 'admin' ACL grants administrative privileges to XMPP accounts. - ## You can put here as many accounts as you want. - admin: - user: - - "root": "example.com" + ## This option specifies the maximum number of elements in the queue + ## of the FSM. Refer to the documentation for details. + max_fsm_queue: 1000 - ## Local users: don't modify this. - local: - user_regexp: "" + ###' ACCESS CONTROL LISTS + acl: + ## The 'admin' ACL grants administrative privileges to XMPP accounts. + ## You can put here as many accounts as you want. + admin: + user: + - "root": "example.com" - ## Loopback network - loopback: - ip: - - "127.0.0.0/8" - - "::1/128" - - "::FFFF:127.0.0.1/128" + ## Local users: don't modify this. + local: + user_regexp: "" - ###' SHAPER RULES - shaper_rules: - ## Maximum number of simultaneous sessions allowed for a single user: - max_user_sessions: 10 - ## Maximum number of offline messages that users can have: - max_user_offline_messages: - - 5000: admin - - 1024 - ## For C2S connections, all users except admins use the "normal" shaper - c2s_shaper: - - none: admin - - normal - ## All S2S connections use the "fast" shaper - s2s_shaper: fast + ## Loopback network + loopback: + ip: + - "127.0.0.0/8" + - "::1/128" + - "::FFFF:127.0.0.1/128" - ###' ACCESS RULES - access_rules: - ## This rule allows access only for local users: - local: - - allow: local - ## Only non-blocked users can use c2s connections: - c2s: - - deny: blocked - - allow - ## Only admins can send announcement messages: - announce: - - allow: admin - ## Only admins can use the configuration interface: - configure: - - allow: admin - ## Only accounts of the local ejabberd server can create rooms: - muc_create: - - allow: local - ## Only accounts on the local ejabberd server can create Pubsub nodes: - pubsub_createnode: - - allow: local - ## In-band registration allows registration of any possible username. - ## To disable in-band registration, replace 'allow' with 'deny'. - register: - - allow - ## Only allow to register from localhost - trusted_network: - - allow: loopback + ###' SHAPER RULES + shaper_rules: + ## Maximum number of simultaneous sessions allowed for a single user: + max_user_sessions: 10 + ## Maximum number of offline messages that users can have: + max_user_offline_messages: + - 5000: admin + - 1024 + ## For C2S connections, all users except admins use the "normal" shaper + c2s_shaper: + - none: admin + - normal + ## All S2S connections use the "fast" shaper + s2s_shaper: fast - ## =============== - ## API PERMISSIONS - ## =============== - ## - ## This section allows you to define who and using what method - ## can execute commands offered by ejabberd. - ## - ## By default "console commands" section allow executing all commands - ## issued using ejabberdctl command, and "admin access" section allows - ## users in admin acl that connect from 127.0.0.1 to execute all - ## commands except start and stop with any available access method - ## (ejabberdctl, http-api, xmlrpc depending what is enabled on server). - ## - ## If you remove "console commands" there will be one added by - ## default allowing executing all commands, but if you just change - ## permissions in it, version from config file will be used instead - ## of default one. - ## - api_permissions: - "console commands": - from: - - ejabberd_ctl - who: all - what: "*" + ###' ACCESS RULES + access_rules: + ## This rule allows access only for local users: + local: + - allow: local + ## Only non-blocked users can use c2s connections: + c2s: + - deny: blocked + - allow + ## Only admins can send announcement messages: + announce: + - allow: admin + ## Only admins can use the configuration interface: + configure: + - allow: admin + ## Only accounts of the local ejabberd server can create rooms: + muc_create: + - allow: local + ## Only accounts on the local ejabberd server can create Pubsub nodes: + pubsub_createnode: + - allow: local + ## In-band registration allows registration of any possible username. + ## To disable in-band registration, replace 'allow' with 'deny'. + register: + - allow + ## Only allow to register from localhost + trusted_network: + - allow: loopback - language: "en" + ## =============== + ## API PERMISSIONS + ## =============== + ## + ## This section allows you to define who and using what method + ## can execute commands offered by ejabberd. + ## + ## By default "console commands" section allow executing all commands + ## issued using ejabberdctl command, and "admin access" section allows + ## users in admin acl that connect from 127.0.0.1 to execute all + ## commands except start and stop with any available access method + ## (ejabberdctl, http-api, xmlrpc depending what is enabled on server). + ## + ## If you remove "console commands" there will be one added by + ## default allowing executing all commands, but if you just change + ## permissions in it, version from config file will be used instead + ## of default one. + ## + api_permissions: + "console commands": + from: + - ejabberd_ctl + who: all + what: "*" - ###' MODULES - ## Modules enabled in all ejabberd virtual hosts. - modules: - mod_adhoc: {} - mod_announce: # recommends mod_adhoc - access: announce - mod_blocking: {} # requires mod_privacy - mod_caps: {} - mod_carboncopy: {} - mod_client_state: {} - mod_configure: {} # requires mod_adhoc - ## mod_delegation: {} # for xep0356 - mod_disco: {} - #mod_irc: - # host: "irc.@HOST@" - # default_encoding: "utf-8" - ## mod_bosh: {} - ## mod_http_fileserver: - ## docroot: "/var/www" - ## accesslog: "/var/log/ejabberd/access.log" - mod_http_upload: - thumbnail: false # otherwise needs the identify command from ImageMagick installed - put_url: "http://@HOST@:5444/upload" - ## # docroot: "@HOME@/upload" - #mod_http_upload_quota: - # max_days: 14 - mod_last: {} - ## XEP-0313: Message Archive Management - ## You might want to setup a SQL backend for MAM because the mnesia database is - ## limited to 2GB which might be exceeded on large servers - mod_mam: {} - mod_muc: - host: "muc.@HOST@" - access: - - allow - access_admin: - - allow: admin - access_create: muc_create - access_persistent: muc_create - mod_muc_admin: {} - mod_muc_log: {} - mod_offline: - access_max_user_messages: max_user_offline_messages - mod_ping: {} - ## mod_pres_counter: - ## count: 5 - ## interval: 60 - mod_privacy: {} - mod_private: {} - mod_roster: - versioning: true - mod_shared_roster: {} - mod_stats: {} - mod_time: {} - mod_vcard: - search: false - mod_vcard_xupdate: {} - ## Convert all avatars posted by Android clients from WebP to JPEG - mod_avatar: {} - # convert: - # webp: jpeg - mod_version: {} - mod_stream_mgmt: {} - ## The module for S2S dialback (XEP-0220). Please note that you cannot - ## rely solely on dialback if you want to federate with other servers, - ## because a lot of servers have dialback disabled and instead rely on - ## PKIX authentication. Make sure you have proper certificates installed - ## and check your accessibility at https://check.messaging.one/ - mod_s2s_dialback: {} - mod_pubsub: - plugins: - - "pep" - mod_push: {} - ''; - }; + language: "en" - networking.firewall.enable = false; + ###' MODULES + ## Modules enabled in all ejabberd virtual hosts. + modules: + mod_adhoc: {} + mod_announce: # recommends mod_adhoc + access: announce + mod_blocking: {} # requires mod_privacy + mod_caps: {} + mod_carboncopy: {} + mod_client_state: {} + mod_configure: {} # requires mod_adhoc + ## mod_delegation: {} # for xep0356 + mod_disco: {} + #mod_irc: + # host: "irc.@HOST@" + # default_encoding: "utf-8" + ## mod_bosh: {} + ## mod_http_fileserver: + ## docroot: "/var/www" + ## accesslog: "/var/log/ejabberd/access.log" + mod_http_upload: + thumbnail: false # otherwise needs the identify command from ImageMagick installed + put_url: "http://@HOST@:5444/upload" + ## # docroot: "@HOME@/upload" + #mod_http_upload_quota: + # max_days: 14 + mod_last: {} + ## XEP-0313: Message Archive Management + ## You might want to setup a SQL backend for MAM because the mnesia database is + ## limited to 2GB which might be exceeded on large servers + mod_mam: {} + mod_muc: + host: "muc.@HOST@" + access: + - allow + access_admin: + - allow: admin + access_create: muc_create + access_persistent: muc_create + mod_muc_admin: {} + mod_muc_log: {} + mod_offline: + access_max_user_messages: max_user_offline_messages + mod_ping: {} + ## mod_pres_counter: + ## count: 5 + ## interval: 60 + mod_privacy: {} + mod_private: {} + mod_roster: + versioning: true + mod_shared_roster: {} + mod_stats: {} + mod_time: {} + mod_vcard: + search: false + mod_vcard_xupdate: {} + ## Convert all avatars posted by Android clients from WebP to JPEG + mod_avatar: {} + # convert: + # webp: jpeg + mod_version: {} + mod_stream_mgmt: {} + ## The module for S2S dialback (XEP-0220). Please note that you cannot + ## rely solely on dialback if you want to federate with other servers, + ## because a lot of servers have dialback disabled and instead rely on + ## PKIX authentication. Make sure you have proper certificates installed + ## and check your accessibility at https://check.messaging.one/ + mod_s2s_dialback: {} + mod_pubsub: + plugins: + - "pep" + mod_push: {} + ''; + }; + + networking.firewall.enable = false; + }; }; - }; - testScript = { nodes, ... }: '' - ejabberd_prefix = "su ejabberd -s $(which ejabberdctl) " + testScript = + { nodes, ... }: + '' + ejabberd_prefix = "su ejabberd -s $(which ejabberdctl) " - server.wait_for_unit("ejabberd.service") + server.wait_for_unit("ejabberd.service") - assert "status: started" in server.succeed(ejabberd_prefix + "status") + assert "status: started" in server.succeed(ejabberd_prefix + "status") - server.succeed( - ejabberd_prefix + "register azurediamond example.com hunter2", - ejabberd_prefix + "register cthon98 example.com nothunter2", - ) - server.fail(ejabberd_prefix + "register asdf wrong.domain") - client.succeed("send-message") - server.succeed( - ejabberd_prefix + "unregister cthon98 example.com", - ejabberd_prefix + "unregister azurediamond example.com", - ) - ''; -}) + server.succeed( + ejabberd_prefix + "register azurediamond example.com hunter2", + ejabberd_prefix + "register cthon98 example.com nothunter2", + ) + server.fail(ejabberd_prefix + "register asdf wrong.domain") + client.succeed("send-message") + server.succeed( + ejabberd_prefix + "unregister cthon98 example.com", + ejabberd_prefix + "unregister azurediamond example.com", + ) + ''; + } +) diff --git a/nixos/tests/xmpp/prosody-mysql.nix b/nixos/tests/xmpp/prosody-mysql.nix index 40f3e308a04eaa..abb6db37e76af3 100644 --- a/nixos/tests/xmpp/prosody-mysql.nix +++ b/nixos/tests/xmpp/prosody-mysql.nix @@ -1,124 +1,146 @@ let - cert = pkgs: pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' - openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=example.com/CN=uploads.example.com/CN=conference.example.com' -days 36500 - mkdir -p $out - cp key.pem cert.pem $out - ''; - createUsers = pkgs: pkgs.writeScriptBin "create-prosody-users" '' - #!${pkgs.bash}/bin/bash - set -e + cert = + pkgs: + pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' + openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=example.com/CN=uploads.example.com/CN=conference.example.com' -days 36500 + mkdir -p $out + cp key.pem cert.pem $out + ''; + createUsers = + pkgs: + pkgs.writeScriptBin "create-prosody-users" '' + #!${pkgs.bash}/bin/bash + set -e - # Creates and set password for the 2 xmpp test users. - # - # Doing that in a bash script instead of doing that in the test - # script allow us to easily provision the users when running that - # test interactively. + # Creates and set password for the 2 xmpp test users. + # + # Doing that in a bash script instead of doing that in the test + # script allow us to easily provision the users when running that + # test interactively. - prosodyctl register cthon98 example.com nothunter2 - prosodyctl register azurediamond example.com hunter2 - ''; - delUsers = pkgs: pkgs.writeScriptBin "delete-prosody-users" '' - #!${pkgs.bash}/bin/bash - set -e + prosodyctl register cthon98 example.com nothunter2 + prosodyctl register azurediamond example.com hunter2 + ''; + delUsers = + pkgs: + pkgs.writeScriptBin "delete-prosody-users" '' + #!${pkgs.bash}/bin/bash + set -e - # Deletes the test users. - # - # Doing that in a bash script instead of doing that in the test - # script allow us to easily provision the users when running that - # test interactively. + # Deletes the test users. + # + # Doing that in a bash script instead of doing that in the test + # script allow us to easily provision the users when running that + # test interactively. - prosodyctl deluser cthon98@example.com - prosodyctl deluser azurediamond@example.com - ''; -in import ../make-test-python.nix { + prosodyctl deluser cthon98@example.com + prosodyctl deluser azurediamond@example.com + ''; +in +import ../make-test-python.nix { name = "prosody-mysql"; nodes = { - client = { nodes, pkgs, config, ... }: { - security.pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; - console.keyMap = "fr-bepo"; - networking.extraHosts = '' - ${nodes.server.config.networking.primaryIPAddress} example.com - ${nodes.server.config.networking.primaryIPAddress} conference.example.com - ${nodes.server.config.networking.primaryIPAddress} uploads.example.com - ''; - environment.systemPackages = [ - (pkgs.callPackage ./xmpp-sendmessage.nix { connectTo = nodes.server.config.networking.primaryIPAddress; }) - ]; - }; - server = { config, pkgs, ... }: { - nixpkgs.overlays = [ - (self: super: { - prosody = super.prosody.override { - withExtraLuaPackages = p: [ p.luadbi-mysql ]; - }; - }) - ]; - security.pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; - console.keyMap = "fr-bepo"; - networking.extraHosts = '' - ${config.networking.primaryIPAddress} example.com - ${config.networking.primaryIPAddress} conference.example.com - ${config.networking.primaryIPAddress} uploads.example.com - ''; - networking.firewall.enable = false; - environment.systemPackages = [ - (createUsers pkgs) - (delUsers pkgs) - ]; - services.prosody = { - enable = true; - ssl.cert = "${cert pkgs}/cert.pem"; - ssl.key = "${cert pkgs}/key.pem"; - virtualHosts.example = { - domain = "example.com"; - enabled = true; + client = + { + nodes, + pkgs, + config, + ... + }: + { + security.pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; + console.keyMap = "fr-bepo"; + networking.extraHosts = '' + ${nodes.server.config.networking.primaryIPAddress} example.com + ${nodes.server.config.networking.primaryIPAddress} conference.example.com + ${nodes.server.config.networking.primaryIPAddress} uploads.example.com + ''; + environment.systemPackages = [ + (pkgs.callPackage ./xmpp-sendmessage.nix { + connectTo = nodes.server.config.networking.primaryIPAddress; + }) + ]; + }; + server = + { config, pkgs, ... }: + { + nixpkgs.overlays = [ + (self: super: { + prosody = super.prosody.override { + withExtraLuaPackages = p: [ p.luadbi-mysql ]; + }; + }) + ]; + security.pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; + console.keyMap = "fr-bepo"; + networking.extraHosts = '' + ${config.networking.primaryIPAddress} example.com + ${config.networking.primaryIPAddress} conference.example.com + ${config.networking.primaryIPAddress} uploads.example.com + ''; + networking.firewall.enable = false; + environment.systemPackages = [ + (createUsers pkgs) + (delUsers pkgs) + ]; + services.prosody = { + enable = true; ssl.cert = "${cert pkgs}/cert.pem"; ssl.key = "${cert pkgs}/key.pem"; - }; - muc = [ - { - domain = "conference.example.com"; - } - ]; - uploadHttp = { - domain = "uploads.example.com"; - }; - extraConfig = '' - storage = "sql" - sql = { - driver = "MySQL"; - database = "prosody"; - host = "mysql"; - port = 3306; - username = "prosody"; - password = "password123"; + virtualHosts.example = { + domain = "example.com"; + enabled = true; + ssl.cert = "${cert pkgs}/cert.pem"; + ssl.key = "${cert pkgs}/key.pem"; }; - ''; + muc = [ + { + domain = "conference.example.com"; + } + ]; + uploadHttp = { + domain = "uploads.example.com"; + }; + extraConfig = '' + storage = "sql" + sql = { + driver = "MySQL"; + database = "prosody"; + host = "mysql"; + port = 3306; + username = "prosody"; + password = "password123"; + }; + ''; + }; }; - }; - mysql = { config, pkgs, ... }: { - networking.firewall.enable = false; - services.mysql = { - enable = true; - initialScript = pkgs.writeText "mysql_init.sql" '' - CREATE DATABASE prosody; - CREATE USER 'prosody'@'server' IDENTIFIED BY 'password123'; - GRANT ALL PRIVILEGES ON prosody.* TO 'prosody'@'server'; - FLUSH PRIVILEGES; - ''; - package = pkgs.mariadb; + mysql = + { config, pkgs, ... }: + { + networking.firewall.enable = false; + services.mysql = { + enable = true; + initialScript = pkgs.writeText "mysql_init.sql" '' + CREATE DATABASE prosody; + CREATE USER 'prosody'@'server' IDENTIFIED BY 'password123'; + GRANT ALL PRIVILEGES ON prosody.* TO 'prosody'@'server'; + FLUSH PRIVILEGES; + ''; + package = pkgs.mariadb; + }; }; - }; }; - testScript = { nodes, ... }: '' - # Check with mysql storage - mysql.wait_for_unit("mysql.service") - server.wait_for_unit("prosody.service") - server.succeed('prosodyctl status | grep "Prosody is running"') + testScript = + { nodes, ... }: + '' + # Check with mysql storage + mysql.wait_for_unit("mysql.service") + server.wait_for_unit("prosody.service") + server.succeed('prosodyctl status | grep "Prosody is running"') - server.succeed("create-prosody-users") - client.succeed("send-message") - server.succeed("delete-prosody-users") - ''; + server.succeed("create-prosody-users") + client.succeed("send-message") + server.succeed("delete-prosody-users") + ''; } diff --git a/nixos/tests/xmpp/prosody.nix b/nixos/tests/xmpp/prosody.nix index 045ae6430fd481..0183e876803eb8 100644 --- a/nixos/tests/xmpp/prosody.nix +++ b/nixos/tests/xmpp/prosody.nix @@ -1,93 +1,111 @@ let - cert = pkgs: pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' - openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=example.com/CN=uploads.example.com/CN=conference.example.com' -days 36500 - mkdir -p $out - cp key.pem cert.pem $out - ''; - createUsers = pkgs: pkgs.writeScriptBin "create-prosody-users" '' - #!${pkgs.bash}/bin/bash - set -e + cert = + pkgs: + pkgs.runCommand "selfSignedCerts" { buildInputs = [ pkgs.openssl ]; } '' + openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -nodes -subj '/CN=example.com/CN=uploads.example.com/CN=conference.example.com' -days 36500 + mkdir -p $out + cp key.pem cert.pem $out + ''; + createUsers = + pkgs: + pkgs.writeScriptBin "create-prosody-users" '' + #!${pkgs.bash}/bin/bash + set -e - # Creates and set password for the 2 xmpp test users. - # - # Doing that in a bash script instead of doing that in the test - # script allow us to easily provision the users when running that - # test interactively. + # Creates and set password for the 2 xmpp test users. + # + # Doing that in a bash script instead of doing that in the test + # script allow us to easily provision the users when running that + # test interactively. - prosodyctl register cthon98 example.com nothunter2 - prosodyctl register azurediamond example.com hunter2 - ''; - delUsers = pkgs: pkgs.writeScriptBin "delete-prosody-users" '' - #!${pkgs.bash}/bin/bash - set -e + prosodyctl register cthon98 example.com nothunter2 + prosodyctl register azurediamond example.com hunter2 + ''; + delUsers = + pkgs: + pkgs.writeScriptBin "delete-prosody-users" '' + #!${pkgs.bash}/bin/bash + set -e - # Deletes the test users. - # - # Doing that in a bash script instead of doing that in the test - # script allow us to easily provision the users when running that - # test interactively. + # Deletes the test users. + # + # Doing that in a bash script instead of doing that in the test + # script allow us to easily provision the users when running that + # test interactively. - prosodyctl deluser cthon98@example.com - prosodyctl deluser azurediamond@example.com - ''; -in import ../make-test-python.nix { + prosodyctl deluser cthon98@example.com + prosodyctl deluser azurediamond@example.com + ''; +in +import ../make-test-python.nix { name = "prosody"; nodes = { - client = { nodes, pkgs, config, ... }: { - security.pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; - console.keyMap = "fr-bepo"; - networking.extraHosts = '' - ${nodes.server.config.networking.primaryIPAddress} example.com - ${nodes.server.config.networking.primaryIPAddress} conference.example.com - ${nodes.server.config.networking.primaryIPAddress} uploads.example.com - ''; - environment.systemPackages = [ - (pkgs.callPackage ./xmpp-sendmessage.nix { connectTo = "example.com"; }) - ]; - }; - server = { config, pkgs, ... }: { - security.pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; - console.keyMap = "fr-bepo"; - networking.extraHosts = '' - ${config.networking.primaryIPAddress} example.com - ${config.networking.primaryIPAddress} conference.example.com - ${config.networking.primaryIPAddress} uploads.example.com - ''; - networking.firewall.enable = false; - environment.systemPackages = [ - (createUsers pkgs) - (delUsers pkgs) - ]; - services.prosody = { - enable = true; - ssl.cert = "${cert pkgs}/cert.pem"; - ssl.key = "${cert pkgs}/key.pem"; - virtualHosts.example = { - domain = "example.com"; - enabled = true; + client = + { + nodes, + pkgs, + config, + ... + }: + { + security.pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; + console.keyMap = "fr-bepo"; + networking.extraHosts = '' + ${nodes.server.config.networking.primaryIPAddress} example.com + ${nodes.server.config.networking.primaryIPAddress} conference.example.com + ${nodes.server.config.networking.primaryIPAddress} uploads.example.com + ''; + environment.systemPackages = [ + (pkgs.callPackage ./xmpp-sendmessage.nix { connectTo = "example.com"; }) + ]; + }; + server = + { config, pkgs, ... }: + { + security.pki.certificateFiles = [ "${cert pkgs}/cert.pem" ]; + console.keyMap = "fr-bepo"; + networking.extraHosts = '' + ${config.networking.primaryIPAddress} example.com + ${config.networking.primaryIPAddress} conference.example.com + ${config.networking.primaryIPAddress} uploads.example.com + ''; + networking.firewall.enable = false; + environment.systemPackages = [ + (createUsers pkgs) + (delUsers pkgs) + ]; + services.prosody = { + enable = true; ssl.cert = "${cert pkgs}/cert.pem"; ssl.key = "${cert pkgs}/key.pem"; - }; - muc = [ - { - domain = "conference.example.com"; - } - ]; - uploadHttp = { - domain = "uploads.example.com"; + virtualHosts.example = { + domain = "example.com"; + enabled = true; + ssl.cert = "${cert pkgs}/cert.pem"; + ssl.key = "${cert pkgs}/key.pem"; + }; + muc = [ + { + domain = "conference.example.com"; + } + ]; + uploadHttp = { + domain = "uploads.example.com"; + }; }; }; - }; }; - testScript = { nodes, ... }: '' - # Check with sqlite storage - start_all() - server.wait_for_unit("prosody.service") - server.succeed('prosodyctl status | grep "Prosody is running"') + testScript = + { nodes, ... }: + '' + # Check with sqlite storage + start_all() + server.wait_for_unit("prosody.service") + server.succeed('prosodyctl status | grep "Prosody is running"') - server.succeed("create-prosody-users") - client.succeed("send-message") - server.succeed("delete-prosody-users") - ''; + server.succeed("create-prosody-users") + client.succeed("send-message") + server.succeed("delete-prosody-users") + ''; } diff --git a/nixos/tests/xmpp/xmpp-sendmessage.nix b/nixos/tests/xmpp/xmpp-sendmessage.nix index 8ccac06124913f..62971d86730432 100644 --- a/nixos/tests/xmpp/xmpp-sendmessage.nix +++ b/nixos/tests/xmpp/xmpp-sendmessage.nix @@ -1,4 +1,9 @@ -{ writeScriptBin, writeText, python3, connectTo ? "localhost" }: +{ + writeScriptBin, + writeText, + python3, + connectTo ? "localhost", +}: let dummyFile = writeText "dummy-file" '' Dear dog, @@ -8,83 +13,84 @@ let Yours truly, Bob ''; -in writeScriptBin "send-message" '' -#!${(python3.withPackages (ps: [ ps.slixmpp ])).interpreter} -import logging -import sys -import signal -from types import MethodType +in +writeScriptBin "send-message" '' + #!${(python3.withPackages (ps: [ ps.slixmpp ])).interpreter} + import logging + import sys + import signal + from types import MethodType -from slixmpp import ClientXMPP -from slixmpp.exceptions import IqError, IqTimeout + from slixmpp import ClientXMPP + from slixmpp.exceptions import IqError, IqTimeout -class CthonTest(ClientXMPP): + class CthonTest(ClientXMPP): - def __init__(self, jid, password): - ClientXMPP.__init__(self, jid, password) - self.add_event_handler("session_start", self.session_start) - self.test_succeeded = False + def __init__(self, jid, password): + ClientXMPP.__init__(self, jid, password) + self.add_event_handler("session_start", self.session_start) + self.test_succeeded = False - async def session_start(self, event): - try: - # Exceptions in event handlers are printed to stderr but not - # propagated, they do not make the script terminate with a non-zero - # exit code. We use the `test_succeeded` flag as a workaround and - # check it later at the end of the script to exit with a proper - # exit code. - # Additionally, this flag ensures that this event handler has been - # actually run by ClientXMPP, which may well not be the case. - await self.test_xmpp_server() - self.test_succeeded = True - finally: - # Even if an exception happens in `test_xmpp_server()`, we still - # need to disconnect explicitly, otherwise the process will hang - # forever. - self.disconnect(wait=True) + async def session_start(self, event): + try: + # Exceptions in event handlers are printed to stderr but not + # propagated, they do not make the script terminate with a non-zero + # exit code. We use the `test_succeeded` flag as a workaround and + # check it later at the end of the script to exit with a proper + # exit code. + # Additionally, this flag ensures that this event handler has been + # actually run by ClientXMPP, which may well not be the case. + await self.test_xmpp_server() + self.test_succeeded = True + finally: + # Even if an exception happens in `test_xmpp_server()`, we still + # need to disconnect explicitly, otherwise the process will hang + # forever. + self.disconnect(wait=True) - async def test_xmpp_server(self): - log = logging.getLogger(__name__) - self.send_presence() - self.get_roster() - # Sending a test message - self.send_message(mto="azurediamond@example.com", mbody="Hello, this is dog.", mtype="chat") - log.info('Message sent') + async def test_xmpp_server(self): + log = logging.getLogger(__name__) + self.send_presence() + self.get_roster() + # Sending a test message + self.send_message(mto="azurediamond@example.com", mbody="Hello, this is dog.", mtype="chat") + log.info('Message sent') - # Test http upload (XEP_0363) - try: - url = await self['xep_0363'].upload_file("${dummyFile}",timeout=10) - except: - log.error("ERROR: Cannot run upload command. XEP_0363 seems broken") - sys.exit(1) - log.info('Upload success!') + # Test http upload (XEP_0363) + try: + url = await self['xep_0363'].upload_file("${dummyFile}",timeout=10) + except: + log.error("ERROR: Cannot run upload command. XEP_0363 seems broken") + sys.exit(1) + log.info('Upload success!') - # Test MUC - # TODO: use join_muc_wait() after slixmpp 1.8.0 is released. - self.plugin['xep_0045'].join_muc('testMucRoom', 'cthon98') - log.info('MUC join success!') - log.info('XMPP SCRIPT TEST SUCCESS') + # Test MUC + # TODO: use join_muc_wait() after slixmpp 1.8.0 is released. + self.plugin['xep_0045'].join_muc('testMucRoom', 'cthon98') + log.info('MUC join success!') + log.info('XMPP SCRIPT TEST SUCCESS') -def timeout_handler(signalnum, stackframe): - print('ERROR: xmpp-sendmessage timed out') - sys.exit(1) + def timeout_handler(signalnum, stackframe): + print('ERROR: xmpp-sendmessage timed out') + sys.exit(1) -if __name__ == '__main__': - signal.signal(signal.SIGALRM, timeout_handler) - signal.alarm(120) - logging.basicConfig(level=logging.DEBUG, - format='%(levelname)-8s %(message)s') + if __name__ == '__main__': + signal.signal(signal.SIGALRM, timeout_handler) + signal.alarm(120) + logging.basicConfig(level=logging.DEBUG, + format='%(levelname)-8s %(message)s') - ct = CthonTest('cthon98@example.com', 'nothunter2') - ct.register_plugin('xep_0071') - ct.register_plugin('xep_0128') - # HTTP Upload - ct.register_plugin('xep_0363') - # MUC - ct.register_plugin('xep_0045') - ct.connect(("${connectTo}", 5222)) - ct.process(forever=False) + ct = CthonTest('cthon98@example.com', 'nothunter2') + ct.register_plugin('xep_0071') + ct.register_plugin('xep_0128') + # HTTP Upload + ct.register_plugin('xep_0363') + # MUC + ct.register_plugin('xep_0045') + ct.connect(("${connectTo}", 5222)) + ct.process(forever=False) - if not ct.test_succeeded: - sys.exit(1) + if not ct.test_succeeded: + sys.exit(1) '' diff --git a/nixos/tests/xpadneo.nix b/nixos/tests/xpadneo.nix index c7b72831fce828..20ddf4c9d048b2 100644 --- a/nixos/tests/xpadneo.nix +++ b/nixos/tests/xpadneo.nix @@ -1,18 +1,21 @@ -import ./make-test-python.nix ({ lib, pkgs, ... }: { - name = "xpadneo"; - meta.maintainers = with lib.maintainers; [ kira-bruneau ]; +import ./make-test-python.nix ( + { lib, pkgs, ... }: + { + name = "xpadneo"; + meta.maintainers = with lib.maintainers; [ kira-bruneau ]; - nodes = { - machine = { - config.hardware.xpadneo.enable = true; + nodes = { + machine = { + config.hardware.xpadneo.enable = true; + }; }; - }; - # This is just a sanity check to make sure the module was - # loaded. We'd have to find some way to mock an xbox controller if - # we wanted more in-depth testing. - testScript = '' - machine.start(); - machine.succeed("modinfo hid_xpadneo | grep 'version:\s\+${pkgs.linuxPackages.xpadneo.version}'") - ''; -}) + # This is just a sanity check to make sure the module was + # loaded. We'd have to find some way to mock an xbox controller if + # we wanted more in-depth testing. + testScript = '' + machine.start(); + machine.succeed("modinfo hid_xpadneo | grep 'version:\s\+${pkgs.linuxPackages.xpadneo.version}'") + ''; + } +) diff --git a/nixos/tests/xrdp-with-audio-pulseaudio.nix b/nixos/tests/xrdp-with-audio-pulseaudio.nix index 27da7c457c493d..839a2c07aea3b1 100644 --- a/nixos/tests/xrdp-with-audio-pulseaudio.nix +++ b/nixos/tests/xrdp-with-audio-pulseaudio.nix @@ -1,97 +1,110 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - # How to interactively test this module if the audio actually works - - # - nix run .#pulseaudio-module-xrdp.tests.xrdp-with-audio-pulseaudio.driverInteractive - # - test_script() # launches the terminal and the tests itself - # - server.send_monitor_command("hostfwd_add tcp::3389-:3389") # forward the RDP port to the host - # - Connect with the RDP client you like (ex: Remmina) - # - Don't forget to enable audio support. In remmina: Advanced -> Audio output mode to Local (default is Off) - # - Open a browser or something that plays sound. Ex: chromium - - name = "xrdp-with-audio-pulseaudio"; - meta = with pkgs.lib.maintainers; { - maintainers = [ lucasew ]; - }; - - nodes = { - server = { pkgs, ... }: { - imports = [ ./common/user-account.nix ]; - - environment.etc."xrdp/test.txt".text = "Shouldn't conflict"; - - services.xrdp.enable = true; - services.xrdp.audio.enable = true; - services.xrdp.defaultWindowManager = "${pkgs.xterm}/bin/xterm"; - - hardware.pulseaudio = { - enable = true; - }; - - systemd.user.services.pactl-list = { - script = '' - while [ ! -S /tmp/.xrdp/xrdp_chansrv_audio_in_socket_* ]; do - sleep 1 - done - sleep 1 - ${pkgs.pulseaudio}/bin/pactl list - echo Source: - ${pkgs.pulseaudio}/bin/pactl get-default-source | tee /tmp/pulseaudio-source - echo Sink: - ${pkgs.pulseaudio}/bin/pactl get-default-sink | tee /tmp/pulseaudio-sink - - ''; - wantedBy = [ "default.target" ]; - }; - - networking.firewall.allowedTCPPorts = [ 3389 ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + # How to interactively test this module if the audio actually works + + # - nix run .#pulseaudio-module-xrdp.tests.xrdp-with-audio-pulseaudio.driverInteractive + # - test_script() # launches the terminal and the tests itself + # - server.send_monitor_command("hostfwd_add tcp::3389-:3389") # forward the RDP port to the host + # - Connect with the RDP client you like (ex: Remmina) + # - Don't forget to enable audio support. In remmina: Advanced -> Audio output mode to Local (default is Off) + # - Open a browser or something that plays sound. Ex: chromium + + name = "xrdp-with-audio-pulseaudio"; + meta = with pkgs.lib.maintainers; { + maintainers = [ lucasew ]; }; - client = { pkgs, ... }: { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - - environment.systemPackages = [ pkgs.freerdp ]; - - services.xrdp.enable = true; - services.xrdp.audio.enable = true; - services.xrdp.defaultWindowManager = "${pkgs.icewm}/bin/icewm"; - - hardware.pulseaudio = { - enable = true; - }; + nodes = { + server = + { pkgs, ... }: + { + imports = [ ./common/user-account.nix ]; + + environment.etc."xrdp/test.txt".text = "Shouldn't conflict"; + + services.xrdp.enable = true; + services.xrdp.audio.enable = true; + services.xrdp.defaultWindowManager = "${pkgs.xterm}/bin/xterm"; + + hardware.pulseaudio = { + enable = true; + }; + + systemd.user.services.pactl-list = { + script = '' + while [ ! -S /tmp/.xrdp/xrdp_chansrv_audio_in_socket_* ]; do + sleep 1 + done + sleep 1 + ${pkgs.pulseaudio}/bin/pactl list + echo Source: + ${pkgs.pulseaudio}/bin/pactl get-default-source | tee /tmp/pulseaudio-source + echo Sink: + ${pkgs.pulseaudio}/bin/pactl get-default-sink | tee /tmp/pulseaudio-sink + + ''; + wantedBy = [ "default.target" ]; + }; + + networking.firewall.allowedTCPPorts = [ 3389 ]; + }; + + client = + { pkgs, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + + environment.systemPackages = [ pkgs.freerdp ]; + + services.xrdp.enable = true; + services.xrdp.audio.enable = true; + services.xrdp.defaultWindowManager = "${pkgs.icewm}/bin/icewm"; + + hardware.pulseaudio = { + enable = true; + }; + }; }; - }; - testScript = { nodes, ... }: let - user = nodes.client.config.users.users.alice; - in '' - start_all() + testScript = + { nodes, ... }: + let + user = nodes.client.config.users.users.alice; + in + '' + start_all() - client.wait_for_x() - client.wait_for_file("${user.home}/.Xauthority") - client.succeed("xauth merge ${user.home}/.Xauthority") + client.wait_for_x() + client.wait_for_file("${user.home}/.Xauthority") + client.succeed("xauth merge ${user.home}/.Xauthority") - client.sleep(5) + client.sleep(5) - client.execute("xterm >&2 &") - client.sleep(1) + client.execute("xterm >&2 &") + client.sleep(1) - client.send_chars("xfreerdp /cert-tofu /w:640 /h:480 /v:127.0.0.1 /u:${user.name} /p:${user.password} /sound\n") + client.send_chars("xfreerdp /cert-tofu /w:640 /h:480 /v:127.0.0.1 /u:${user.name} /p:${user.password} /sound\n") - client.sleep(10) + client.sleep(10) - client.succeed("[ -S /tmp/.xrdp/xrdp_chansrv_audio_in_socket_* ]") # checks if it's a socket - client.sleep(5) - client.screenshot("localrdp") + client.succeed("[ -S /tmp/.xrdp/xrdp_chansrv_audio_in_socket_* ]") # checks if it's a socket + client.sleep(5) + client.screenshot("localrdp") - client.execute("xterm >&2 &") - client.sleep(1) - client.send_chars("xfreerdp /cert-tofu /w:640 /h:480 /v:server /u:${user.name} /p:${user.password} /sound\n") - client.sleep(10) + client.execute("xterm >&2 &") + client.sleep(1) + client.send_chars("xfreerdp /cert-tofu /w:640 /h:480 /v:server /u:${user.name} /p:${user.password} /sound\n") + client.sleep(10) - server.succeed("[ -S /tmp/.xrdp/xrdp_chansrv_audio_in_socket_* ]") # checks if it's a socket - server.succeed('[ "$(cat /tmp/pulseaudio-source)" == "xrdp-source" ]') - server.succeed('[ "$(cat /tmp/pulseaudio-sink)" == "xrdp-sink" ]') - client.screenshot("remoterdp") - ''; -}) + server.succeed("[ -S /tmp/.xrdp/xrdp_chansrv_audio_in_socket_* ]") # checks if it's a socket + server.succeed('[ "$(cat /tmp/pulseaudio-source)" == "xrdp-source" ]') + server.succeed('[ "$(cat /tmp/pulseaudio-sink)" == "xrdp-sink" ]') + client.screenshot("remoterdp") + ''; + } +) diff --git a/nixos/tests/xrdp.nix b/nixos/tests/xrdp.nix index f277d4b7952561..10cc80de5056f4 100644 --- a/nixos/tests/xrdp.nix +++ b/nixos/tests/xrdp.nix @@ -1,47 +1,60 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "xrdp"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; - - nodes = { - server = { pkgs, ... }: { - imports = [ ./common/user-account.nix ]; - services.xrdp.enable = true; - services.xrdp.defaultWindowManager = "${pkgs.xterm}/bin/xterm"; - networking.firewall.allowedTCPPorts = [ 3389 ]; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "xrdp"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; }; - client = { pkgs, ... }: { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - environment.systemPackages = [ pkgs.freerdp ]; - services.xrdp.enable = true; - services.xrdp.defaultWindowManager = "${pkgs.icewm}/bin/icewm"; + nodes = { + server = + { pkgs, ... }: + { + imports = [ ./common/user-account.nix ]; + services.xrdp.enable = true; + services.xrdp.defaultWindowManager = "${pkgs.xterm}/bin/xterm"; + networking.firewall.allowedTCPPorts = [ 3389 ]; + }; + + client = + { pkgs, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + environment.systemPackages = [ pkgs.freerdp ]; + services.xrdp.enable = true; + services.xrdp.defaultWindowManager = "${pkgs.icewm}/bin/icewm"; + }; }; - }; - testScript = { nodes, ... }: let - user = nodes.client.config.users.users.alice; - in '' - start_all() + testScript = + { nodes, ... }: + let + user = nodes.client.config.users.users.alice; + in + '' + start_all() - client.wait_for_x() - client.wait_for_file("${user.home}/.Xauthority") - client.succeed("xauth merge ${user.home}/.Xauthority") + client.wait_for_x() + client.wait_for_file("${user.home}/.Xauthority") + client.succeed("xauth merge ${user.home}/.Xauthority") - client.sleep(5) + client.sleep(5) - client.execute("xterm >&2 &") - client.sleep(1) - client.send_chars("xfreerdp /cert-tofu /w:640 /h:480 /v:127.0.0.1 /u:${user.name} /p:${user.password}\n") - client.sleep(5) - client.screenshot("localrdp") + client.execute("xterm >&2 &") + client.sleep(1) + client.send_chars("xfreerdp /cert-tofu /w:640 /h:480 /v:127.0.0.1 /u:${user.name} /p:${user.password}\n") + client.sleep(5) + client.screenshot("localrdp") - client.execute("xterm >&2 &") - client.sleep(1) - client.send_chars("xfreerdp /cert-tofu /w:640 /h:480 /v:server /u:${user.name} /p:${user.password}\n") - client.sleep(5) - client.screenshot("remoterdp") - ''; -}) + client.execute("xterm >&2 &") + client.sleep(1) + client.send_chars("xfreerdp /cert-tofu /w:640 /h:480 /v:server /u:${user.name} /p:${user.password}\n") + client.sleep(5) + client.screenshot("remoterdp") + ''; + } +) diff --git a/nixos/tests/xscreensaver.nix b/nixos/tests/xscreensaver.nix index 820ddbb0e96264..70eed6034498f3 100644 --- a/nixos/tests/xscreensaver.nix +++ b/nixos/tests/xscreensaver.nix @@ -1,64 +1,82 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "pass-secret-service"; - meta.maintainers = with lib.maintainers; [ vancluever AndersonTorres ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "pass-secret-service"; + meta.maintainers = with lib.maintainers; [ + vancluever + AndersonTorres + ]; - nodes = { - ok = { nodes, pkgs, ... }: - { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - services.xscreensaver.enable = true; - }; + nodes = { + ok = + { nodes, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + services.xscreensaver.enable = true; + }; - empty_wrapperPrefix = { nodes, pkgs, ... }: - { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - services.xscreensaver.enable = true; - nixpkgs.overlays = [ - (self: super: { - xscreensaver = super.xscreensaver.override { - wrapperPrefix = ""; - }; - }) - ]; - }; + empty_wrapperPrefix = + { nodes, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + services.xscreensaver.enable = true; + nixpkgs.overlays = [ + (self: super: { + xscreensaver = super.xscreensaver.override { + wrapperPrefix = ""; + }; + }) + ]; + }; - bad_wrapperPrefix = { nodes, pkgs, ... }: - { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; - services.xscreensaver.enable = true; - nixpkgs.overlays = [ - (self: super: { - xscreensaver = super.xscreensaver.override { - wrapperPrefix = "/a/bad/path"; - }; - }) - ]; - }; - }; + bad_wrapperPrefix = + { nodes, pkgs, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; + services.xscreensaver.enable = true; + nixpkgs.overlays = [ + (self: super: { + xscreensaver = super.xscreensaver.override { + wrapperPrefix = "/a/bad/path"; + }; + }) + ]; + }; + }; - testScript = '' - ok.wait_for_x() - ok.wait_for_unit("xscreensaver", "alice") - _, output_ok = ok.systemctl("status xscreensaver", "alice") - assert 'To prevent the kernel from randomly unlocking' not in output_ok - assert 'your screen via the out-of-memory killer' not in output_ok - assert '"xscreensaver-auth" must be setuid root' not in output_ok + testScript = '' + ok.wait_for_x() + ok.wait_for_unit("xscreensaver", "alice") + _, output_ok = ok.systemctl("status xscreensaver", "alice") + assert 'To prevent the kernel from randomly unlocking' not in output_ok + assert 'your screen via the out-of-memory killer' not in output_ok + assert '"xscreensaver-auth" must be setuid root' not in output_ok - empty_wrapperPrefix.wait_for_x() - empty_wrapperPrefix.wait_for_unit("xscreensaver", "alice") - _, output_empty_wrapperPrefix = empty_wrapperPrefix.systemctl("status xscreensaver", "alice") - assert 'To prevent the kernel from randomly unlocking' in output_empty_wrapperPrefix - assert 'your screen via the out-of-memory killer' in output_empty_wrapperPrefix - assert '"xscreensaver-auth" must be setuid root' in output_empty_wrapperPrefix + empty_wrapperPrefix.wait_for_x() + empty_wrapperPrefix.wait_for_unit("xscreensaver", "alice") + _, output_empty_wrapperPrefix = empty_wrapperPrefix.systemctl("status xscreensaver", "alice") + assert 'To prevent the kernel from randomly unlocking' in output_empty_wrapperPrefix + assert 'your screen via the out-of-memory killer' in output_empty_wrapperPrefix + assert '"xscreensaver-auth" must be setuid root' in output_empty_wrapperPrefix - bad_wrapperPrefix.wait_for_x() - bad_wrapperPrefix.wait_for_unit("xscreensaver", "alice") - _, output_bad_wrapperPrefix = bad_wrapperPrefix.systemctl("status xscreensaver", "alice") - assert 'To prevent the kernel from randomly unlocking' in output_bad_wrapperPrefix - assert 'your screen via the out-of-memory killer' in output_bad_wrapperPrefix - assert '"xscreensaver-auth" must be setuid root' in output_bad_wrapperPrefix - ''; -}) + bad_wrapperPrefix.wait_for_x() + bad_wrapperPrefix.wait_for_unit("xscreensaver", "alice") + _, output_bad_wrapperPrefix = bad_wrapperPrefix.systemctl("status xscreensaver", "alice") + assert 'To prevent the kernel from randomly unlocking' in output_bad_wrapperPrefix + assert 'your screen via the out-of-memory killer' in output_bad_wrapperPrefix + assert '"xscreensaver-auth" must be setuid root' in output_bad_wrapperPrefix + ''; + } +) diff --git a/nixos/tests/xss-lock.nix b/nixos/tests/xss-lock.nix index e4e41a5aa7978c..f46db1e49c28c2 100644 --- a/nixos/tests/xss-lock.nix +++ b/nixos/tests/xss-lock.nix @@ -1,40 +1,54 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "xss-lock"; - meta.maintainers = [ ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "xss-lock"; + meta.maintainers = [ ]; - nodes = { - simple = { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - programs.xss-lock.enable = true; - test-support.displayManager.auto.user = "alice"; - }; + nodes = { + simple = { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + programs.xss-lock.enable = true; + test-support.displayManager.auto.user = "alice"; + }; - custom_lockcmd = { pkgs, ... }: { - imports = [ ./common/x11.nix ./common/user-account.nix ]; - test-support.displayManager.auto.user = "alice"; + custom_lockcmd = + { pkgs, ... }: + { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; + test-support.displayManager.auto.user = "alice"; - programs.xss-lock = { - enable = true; - extraOptions = [ "-n" "${pkgs.libnotify}/bin/notify-send 'About to sleep!'"]; - lockerCommand = "${pkgs.xlockmore}/bin/xlock -mode ant"; - }; + programs.xss-lock = { + enable = true; + extraOptions = [ + "-n" + "${pkgs.libnotify}/bin/notify-send 'About to sleep!'" + ]; + lockerCommand = "${pkgs.xlockmore}/bin/xlock -mode ant"; + }; + }; }; - }; - testScript = '' - def perform_xsslock_test(machine, lockCmd): - machine.start() - machine.wait_for_x() - machine.wait_for_unit("xss-lock.service", "alice") - machine.fail(f"pgrep {lockCmd}") - machine.succeed("su -l alice -c 'xset dpms force standby'") - machine.wait_until_succeeds(f"pgrep {lockCmd}") + testScript = '' + def perform_xsslock_test(machine, lockCmd): + machine.start() + machine.wait_for_x() + machine.wait_for_unit("xss-lock.service", "alice") + machine.fail(f"pgrep {lockCmd}") + machine.succeed("su -l alice -c 'xset dpms force standby'") + machine.wait_until_succeeds(f"pgrep {lockCmd}") - with subtest("simple"): - perform_xsslock_test(simple, "i3lock") + with subtest("simple"): + perform_xsslock_test(simple, "i3lock") - with subtest("custom_cmd"): - perform_xsslock_test(custom_lockcmd, "xlock") - ''; -}) + with subtest("custom_cmd"): + perform_xsslock_test(custom_lockcmd, "xlock") + ''; + } +) diff --git a/nixos/tests/xterm.nix b/nixos/tests/xterm.nix index 745d33e8a0d536..52a7b431a44e1b 100644 --- a/nixos/tests/xterm.nix +++ b/nixos/tests/xterm.nix @@ -1,17 +1,19 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "xterm"; - meta = with pkgs.lib.maintainers; { - maintainers = [ nequissimus ]; - }; - - nodes.machine = { pkgs, ... }: - { - imports = [ ./common/x11.nix ]; - services.xserver.desktopManager.xterm.enable = false; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "xterm"; + meta = with pkgs.lib.maintainers; { + maintainers = [ nequissimus ]; }; - testScript = - '' + nodes.machine = + { pkgs, ... }: + { + imports = [ ./common/x11.nix ]; + services.xserver.desktopManager.xterm.enable = false; + }; + + testScript = '' machine.wait_for_x() machine.succeed("DISPLAY=:0 xterm -title testterm -class testterm -fullscreen >&2 &") machine.sleep(2) @@ -20,4 +22,5 @@ import ./make-test-python.nix ({ pkgs, ...} : { assert "${pkgs.xterm.version}" in machine.succeed("cat /tmp/xterm_version") machine.screenshot("window") ''; -}) + } +) diff --git a/nixos/tests/xxh.nix b/nixos/tests/xxh.nix index 3af8e53779e342..03273ad775b567 100644 --- a/nixos/tests/xxh.nix +++ b/nixos/tests/xxh.nix @@ -1,4 +1,5 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: let inherit (import ./ssh-keys.nix pkgs) snakeOilPrivateKey snakeOilPublicKey; @@ -38,16 +39,23 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: }; nodes = { - server = { ... }: { - services.openssh.enable = true; - users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; - }; + server = + { ... }: + { + services.openssh.enable = true; + users.users.root.openssh.authorizedKeys.keys = [ snakeOilPublicKey ]; + }; - client = { ... }: { - programs.zsh.enable = true; - users.users.root.shell = pkgs.zsh; - environment.systemPackages = with pkgs; [ xxh git ]; - }; + client = + { ... }: + { + programs.zsh.enable = true; + users.users.root.shell = pkgs.zsh; + environment.systemPackages = with pkgs; [ + xxh + git + ]; + }; }; testScript = '' @@ -64,4 +72,5 @@ import ./make-test-python.nix ({ pkgs, lib, ... }: client.succeed("xxh server -i /root/.ssh/id_ecdsa +hc \'echo $0\' +i +s zsh +I xxh-shell-zsh+path+${xxh-shell-zsh} | grep -Fq '/root/.xxh/.xxh/shells/xxh-shell-zsh/build/zsh-bin/bin/zsh'") ''; - }) + } +) diff --git a/nixos/tests/yabar.nix b/nixos/tests/yabar.nix index 212a8ce4bbf5f0..1c844677abbdfc 100644 --- a/nixos/tests/yabar.nix +++ b/nixos/tests/yabar.nix @@ -1,27 +1,33 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: { - name = "yabar"; - meta.maintainers = [ ]; +import ./make-test-python.nix ( + { pkgs, lib, ... }: + { + name = "yabar"; + meta.maintainers = [ ]; - nodes.machine = { - imports = [ ./common/x11.nix ./common/user-account.nix ]; + nodes.machine = { + imports = [ + ./common/x11.nix + ./common/user-account.nix + ]; - test-support.displayManager.auto.user = "bob"; + test-support.displayManager.auto.user = "bob"; - programs.yabar.enable = true; - programs.yabar.bars = { - top.indicators.date.exec = "YABAR_DATE"; + programs.yabar.enable = true; + programs.yabar.bars = { + top.indicators.date.exec = "YABAR_DATE"; + }; }; - }; - testScript = '' - machine.start() - machine.wait_for_x() + testScript = '' + machine.start() + machine.wait_for_x() - # confirm proper startup - machine.wait_for_unit("yabar.service", "bob") - machine.sleep(10) - machine.wait_for_unit("yabar.service", "bob") + # confirm proper startup + machine.wait_for_unit("yabar.service", "bob") + machine.sleep(10) + machine.wait_for_unit("yabar.service", "bob") - machine.screenshot("top_bar") - ''; -}) + machine.screenshot("top_bar") + ''; + } +) diff --git a/nixos/tests/yggdrasil.nix b/nixos/tests/yggdrasil.nix index 70d148380bf754..0d47a599f94cd6 100644 --- a/nixos/tests/yggdrasil.nix +++ b/nixos/tests/yggdrasil.nix @@ -10,131 +10,155 @@ let InterfacePeers = { eth1 = [ "tcp://192.168.1.200:12345" ]; }; - MulticastInterfaces = [ { - Regex = ".*"; - Beacon = true; - Listen = true; - Port = 54321; - Priority = 0; - } ]; + MulticastInterfaces = [ + { + Regex = ".*"; + Beacon = true; + Listen = true; + Port = 54321; + Priority = 0; + } + ]; PublicKey = "2b6f918b6c1a4b54d6bcde86cf74e074fb32ead4ee439b7930df2aa60c825186"; PrivateKey = "0c4a24acd3402722ce9277ed179f4a04b895b49586493c25fbaed60653d857d62b6f918b6c1a4b54d6bcde86cf74e074fb32ead4ee439b7930df2aa60c825186"; }; danIp6 = bobPrefix + "::2"; -in import ./make-test-python.nix ({ pkgs, ...} : { - name = "yggdrasil"; - meta = with pkgs.lib.maintainers; { - maintainers = [ gazally ]; - }; +in +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "yggdrasil"; + meta = with pkgs.lib.maintainers; { + maintainers = [ gazally ]; + }; - nodes = rec { - # Alice is listening for peerings on a specified port, - # but has multicast peering disabled. Alice has part of her - # yggdrasil config in Nix and part of it in a file. - alice = - { ... }: - { - networking = { - interfaces.eth1.ipv4.addresses = [{ - address = "192.168.1.200"; - prefixLength = 24; - }]; - firewall.allowedTCPPorts = [ 80 12345 ]; - }; - services.httpd.enable = true; - services.httpd.adminAddr = "foo@example.org"; - - services.yggdrasil = { - enable = true; - settings = { - Listen = ["tcp://0.0.0.0:12345"]; - MulticastInterfaces = [ ]; + nodes = rec { + # Alice is listening for peerings on a specified port, + # but has multicast peering disabled. Alice has part of her + # yggdrasil config in Nix and part of it in a file. + alice = + { ... }: + { + networking = { + interfaces.eth1.ipv4.addresses = [ + { + address = "192.168.1.200"; + prefixLength = 24; + } + ]; + firewall.allowedTCPPorts = [ + 80 + 12345 + ]; + }; + services.httpd.enable = true; + services.httpd.adminAddr = "foo@example.org"; + + services.yggdrasil = { + enable = true; + settings = { + Listen = [ "tcp://0.0.0.0:12345" ]; + MulticastInterfaces = [ ]; + }; + configFile = toString ( + pkgs.writeTextFile { + name = "yggdrasil-alice-conf"; + text = builtins.toJSON aliceKeys; + } + ); }; - configFile = toString (pkgs.writeTextFile { - name = "yggdrasil-alice-conf"; - text = builtins.toJSON aliceKeys; - }); - }; - }; - - # Bob is set up to peer with Alice, and also to do local multicast - # peering. Bob's yggdrasil config is in a file. - bob = - { ... }: - { - networking.firewall.allowedTCPPorts = [ 54321 ]; - services.yggdrasil = { - enable = true; - openMulticastPort = true; - configFile = toString (pkgs.writeTextFile { - name = "yggdrasil-bob-conf"; - text = builtins.toJSON bobConfig; - }); }; - boot.kernel.sysctl."net.ipv6.conf.all.forwarding" = 1; - - networking = { - bridges.br0.interfaces = [ ]; - interfaces.br0 = { - ipv6.addresses = [{ - address = bobPrefix + "::1"; - prefixLength = 64; - }]; + # Bob is set up to peer with Alice, and also to do local multicast + # peering. Bob's yggdrasil config is in a file. + bob = + { ... }: + { + networking.firewall.allowedTCPPorts = [ 54321 ]; + services.yggdrasil = { + enable = true; + openMulticastPort = true; + configFile = toString ( + pkgs.writeTextFile { + name = "yggdrasil-bob-conf"; + text = builtins.toJSON bobConfig; + } + ); }; - }; - # dan is a node inside a container running on bob's host. - containers.dan = { - autoStart = true; - privateNetwork = true; - hostBridge = "br0"; - config = { config, pkgs, ... }: { - networking.interfaces.eth0.ipv6 = { - addresses = [{ - address = bobPrefix + "::2"; - prefixLength = 64; - }]; - routes = [{ - address = "200::"; - prefixLength = 7; - via = bobPrefix + "::1"; - }]; + boot.kernel.sysctl."net.ipv6.conf.all.forwarding" = 1; + + networking = { + bridges.br0.interfaces = [ ]; + interfaces.br0 = { + ipv6.addresses = [ + { + address = bobPrefix + "::1"; + prefixLength = 64; + } + ]; }; - services.httpd.enable = true; - services.httpd.adminAddr = "foo@example.org"; - networking.firewall.allowedTCPPorts = [ 80 ]; }; - }; - }; - # Carol only does local peering. Carol's yggdrasil config is all Nix. - carol = - { ... }: - { - networking.firewall.allowedTCPPorts = [ 43210 ]; - services.yggdrasil = { - enable = true; - extraArgs = [ "-loglevel" "error" ]; - denyDhcpcdInterfaces = [ "ygg0" ]; - settings = { - IfTAPMode = true; - IfName = "ygg0"; - MulticastInterfaces = [ + # dan is a node inside a container running on bob's host. + containers.dan = { + autoStart = true; + privateNetwork = true; + hostBridge = "br0"; + config = + { config, pkgs, ... }: { - Port = 43210; - } + networking.interfaces.eth0.ipv6 = { + addresses = [ + { + address = bobPrefix + "::2"; + prefixLength = 64; + } + ]; + routes = [ + { + address = "200::"; + prefixLength = 7; + via = bobPrefix + "::1"; + } + ]; + }; + services.httpd.enable = true; + services.httpd.adminAddr = "foo@example.org"; + networking.firewall.allowedTCPPorts = [ 80 ]; + }; + }; + }; + + # Carol only does local peering. Carol's yggdrasil config is all Nix. + carol = + { ... }: + { + networking.firewall.allowedTCPPorts = [ 43210 ]; + services.yggdrasil = { + enable = true; + extraArgs = [ + "-loglevel" + "error" ]; - openMulticastPort = true; + denyDhcpcdInterfaces = [ "ygg0" ]; + settings = { + IfTAPMode = true; + IfName = "ygg0"; + MulticastInterfaces = [ + { + Port = 43210; + } + ]; + openMulticastPort = true; + }; + persistentKeys = true; }; - persistentKeys = true; }; - }; }; - testScript = - '' + testScript = '' import re # Give Alice a head start so she is ready when Bob calls. @@ -169,4 +193,5 @@ in import ./make-test-python.nix ({ pkgs, ...} : { carol.succeed("curl --fail -g http://[${aliceIp6}]") carol.succeed("curl --fail -g http://[${danIp6}]") ''; -}) + } +) diff --git a/nixos/tests/your_spotify.nix b/nixos/tests/your_spotify.nix index a1fa0e459a8e16..9fdc2dad8eb50c 100644 --- a/nixos/tests/your_spotify.nix +++ b/nixos/tests/your_spotify.nix @@ -1,33 +1,36 @@ -import ./make-test-python.nix ({pkgs, ...}: { - name = "your_spotify"; - meta = with pkgs.lib.maintainers; { - maintainers = [patrickdag]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "your_spotify"; + meta = with pkgs.lib.maintainers; { + maintainers = [ patrickdag ]; + }; - nodes.machine = { - services.your_spotify = { - enable = true; - spotifySecretFile = pkgs.writeText "spotifySecretFile" "deadbeef"; - settings = { - CLIENT_ENDPOINT = "http://localhost"; - API_ENDPOINT = "http://localhost:3000"; - SPOTIFY_PUBLIC = "beefdead"; + nodes.machine = { + services.your_spotify = { + enable = true; + spotifySecretFile = pkgs.writeText "spotifySecretFile" "deadbeef"; + settings = { + CLIENT_ENDPOINT = "http://localhost"; + API_ENDPOINT = "http://localhost:3000"; + SPOTIFY_PUBLIC = "beefdead"; + }; + enableLocalDB = true; + nginxVirtualHost = "localhost"; }; - enableLocalDB = true; - nginxVirtualHost = "localhost"; }; - }; - testScript = '' - machine.wait_for_unit("your_spotify.service") + testScript = '' + machine.wait_for_unit("your_spotify.service") - machine.wait_for_open_port(3000) - machine.wait_for_open_port(80) + machine.wait_for_open_port(3000) + machine.wait_for_open_port(80) - out = machine.succeed("curl --fail -X GET 'http://localhost:3000/'") - assert "Hello !" in out + out = machine.succeed("curl --fail -X GET 'http://localhost:3000/'") + assert "Hello !" in out - out = machine.succeed("curl --fail -X GET 'http://localhost:80/'") - assert "Your Spotify" in out - ''; -}) + out = machine.succeed("curl --fail -X GET 'http://localhost:80/'") + assert "Your Spotify" in out + ''; + } +) diff --git a/nixos/tests/zammad.nix b/nixos/tests/zammad.nix index c799a295800391..47255500fd3ac0 100644 --- a/nixos/tests/zammad.nix +++ b/nixos/tests/zammad.nix @@ -4,18 +4,24 @@ import ./make-test-python.nix ( { name = "zammad"; - meta.maintainers = with lib.maintainers; [ taeer n0emis netali ]; + meta.maintainers = with lib.maintainers; [ + taeer + n0emis + netali + ]; - nodes.machine = { config, ... }: { - virtualisation = { - memorySize = 2048; - }; + nodes.machine = + { config, ... }: + { + virtualisation = { + memorySize = 2048; + }; - services.zammad.enable = true; - services.zammad.secretKeyBaseFile = pkgs.writeText "secret" '' - 52882ef142066e09ab99ce816ba72522e789505caba224a52d750ec7dc872c2c371b2fd19f16b25dfbdd435a4dd46cb3df9f82eb63fafad715056bdfe25740d6 - ''; - }; + services.zammad.enable = true; + services.zammad.secretKeyBaseFile = pkgs.writeText "secret" '' + 52882ef142066e09ab99ce816ba72522e789505caba224a52d750ec7dc872c2c371b2fd19f16b25dfbdd435a4dd46cb3df9f82eb63fafad715056bdfe25740d6 + ''; + }; testScript = '' start_all() diff --git a/nixos/tests/zeronet-conservancy.nix b/nixos/tests/zeronet-conservancy.nix index 8cb649cbdaabc9..1c906d80a3176a 100644 --- a/nixos/tests/zeronet-conservancy.nix +++ b/nixos/tests/zeronet-conservancy.nix @@ -1,25 +1,30 @@ let port = 43110; in -import ./make-test-python.nix ({ pkgs, ... }: { - name = "zeronet-conservancy"; - meta = with pkgs.lib.maintainers; { - maintainers = [ fgaz ]; - }; - - nodes.machine = { config, pkgs, ... }: { - services.zeronet = { - enable = true; - package = pkgs.zeronet-conservancy; - inherit port; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "zeronet-conservancy"; + meta = with pkgs.lib.maintainers; { + maintainers = [ fgaz ]; }; - }; - testScript = '' - machine.wait_for_unit("zeronet.service") + nodes.machine = + { config, pkgs, ... }: + { + services.zeronet = { + enable = true; + package = pkgs.zeronet-conservancy; + inherit port; + }; + }; + + testScript = '' + machine.wait_for_unit("zeronet.service") - machine.wait_for_open_port(${toString port}) + machine.wait_for_open_port(${toString port}) - machine.succeed("curl --fail -H 'Accept: text/html, application/xml, */*' localhost:${toString port}/Stats") - ''; -}) + machine.succeed("curl --fail -H 'Accept: text/html, application/xml, */*' localhost:${toString port}/Stats") + ''; + } +) diff --git a/nixos/tests/zigbee2mqtt.nix b/nixos/tests/zigbee2mqtt.nix index 3311bb11eb1a2c..3b7b6a8033b09e 100644 --- a/nixos/tests/zigbee2mqtt.nix +++ b/nixos/tests/zigbee2mqtt.nix @@ -1,7 +1,9 @@ -import ./make-test-python.nix ({ pkgs, lib, ... }: +import ./make-test-python.nix ( + { pkgs, lib, ... }: { name = "zigbee2mqtt"; - nodes.machine = { pkgs, ... }: + nodes.machine = + { pkgs, ... }: { systemd.services.dummy-serial = { wantedBy = [ diff --git a/nixos/tests/zoneminder.nix b/nixos/tests/zoneminder.nix index 3c97bc8282d229..7a32ff8bb8bbe9 100644 --- a/nixos/tests/zoneminder.nix +++ b/nixos/tests/zoneminder.nix @@ -1,23 +1,26 @@ -import ./make-test-python.nix ({ lib, ...}: +import ./make-test-python.nix ( + { lib, ... }: -{ - name = "zoneminder"; - meta.maintainers = with lib.maintainers; [ danielfullmer ]; - - nodes.machine = { ... }: { - services.zoneminder = { - enable = true; - database.createLocally = true; - database.username = "zoneminder"; - }; - time.timeZone = "America/New_York"; - }; + name = "zoneminder"; + meta.maintainers = with lib.maintainers; [ danielfullmer ]; + + nodes.machine = + { ... }: + { + services.zoneminder = { + enable = true; + database.createLocally = true; + database.username = "zoneminder"; + }; + time.timeZone = "America/New_York"; + }; - testScript = '' - machine.wait_for_unit("zoneminder.service") - machine.wait_for_unit("nginx.service") - machine.wait_for_open_port(8095) - machine.succeed("curl --fail http://localhost:8095/") - ''; -}) + testScript = '' + machine.wait_for_unit("zoneminder.service") + machine.wait_for_unit("nginx.service") + machine.wait_for_open_port(8095) + machine.succeed("curl --fail http://localhost:8095/") + ''; + } +) diff --git a/nixos/tests/zookeeper.nix b/nixos/tests/zookeeper.nix index 0ee2673886a74a..8442f021e051b9 100644 --- a/nixos/tests/zookeeper.nix +++ b/nixos/tests/zookeeper.nix @@ -1,46 +1,54 @@ -import ./make-test-python.nix ({ pkgs, ...} : -let - - perlEnv = pkgs.perl.withPackages (p: [p.NetZooKeeper]); - -in { - name = "zookeeper"; - meta = with pkgs.lib.maintainers; { - maintainers = [ nequissimus ztzg ]; - }; +import ./make-test-python.nix ( + { pkgs, ... }: + let + + perlEnv = pkgs.perl.withPackages (p: [ p.NetZooKeeper ]); + + in + { + name = "zookeeper"; + meta = with pkgs.lib.maintainers; { + maintainers = [ + nequissimus + ztzg + ]; + }; - nodes = { - server = { ... }: { - services.zookeeper = { - enable = true; - }; + nodes = { + server = + { ... }: + { + services.zookeeper = { + enable = true; + }; - networking.firewall.allowedTCPPorts = [ 2181 ]; + networking.firewall.allowedTCPPorts = [ 2181 ]; + }; }; - }; - - testScript = '' - start_all() - - server.wait_for_unit("zookeeper") - server.wait_for_unit("network.target") - server.wait_for_open_port(2181) - - server.wait_until_succeeds( - "${pkgs.zookeeper}/bin/zkCli.sh -server localhost:2181 create /foo bar" - ) - server.wait_until_succeeds( - "${pkgs.zookeeper}/bin/zkCli.sh -server localhost:2181 set /foo hello" - ) - server.wait_until_succeeds( - "${pkgs.zookeeper}/bin/zkCli.sh -server localhost:2181 get /foo | grep hello" - ) - - server.wait_until_succeeds( - "${perlEnv}/bin/perl -E 'use Net::ZooKeeper qw(:acls); $z=Net::ZooKeeper->new(q(localhost:2181)); $z->create(qw(/perl foo acl), ZOO_OPEN_ACL_UNSAFE) || die $z->get_error()'" - ) - server.wait_until_succeeds( - "${perlEnv}/bin/perl -E 'use Net::ZooKeeper qw(:acls); $z=Net::ZooKeeper->new(q(localhost:2181)); $z->get(qw(/perl)) eq qw(foo) || die $z->get_error()'" - ) - ''; -}) + + testScript = '' + start_all() + + server.wait_for_unit("zookeeper") + server.wait_for_unit("network.target") + server.wait_for_open_port(2181) + + server.wait_until_succeeds( + "${pkgs.zookeeper}/bin/zkCli.sh -server localhost:2181 create /foo bar" + ) + server.wait_until_succeeds( + "${pkgs.zookeeper}/bin/zkCli.sh -server localhost:2181 set /foo hello" + ) + server.wait_until_succeeds( + "${pkgs.zookeeper}/bin/zkCli.sh -server localhost:2181 get /foo | grep hello" + ) + + server.wait_until_succeeds( + "${perlEnv}/bin/perl -E 'use Net::ZooKeeper qw(:acls); $z=Net::ZooKeeper->new(q(localhost:2181)); $z->create(qw(/perl foo acl), ZOO_OPEN_ACL_UNSAFE) || die $z->get_error()'" + ) + server.wait_until_succeeds( + "${perlEnv}/bin/perl -E 'use Net::ZooKeeper qw(:acls); $z=Net::ZooKeeper->new(q(localhost:2181)); $z->get(qw(/perl)) eq qw(foo) || die $z->get_error()'" + ) + ''; + } +) diff --git a/nixos/tests/zram-generator.nix b/nixos/tests/zram-generator.nix index 2be7bd2e05b1d1..14c988f944298f 100644 --- a/nixos/tests/zram-generator.nix +++ b/nixos/tests/zram-generator.nix @@ -2,30 +2,34 @@ import ./make-test-python.nix { name = "zram-generator"; nodes = { - single = { ... }: { - virtualisation = { - emptyDiskImages = [ 512 ]; + single = + { ... }: + { + virtualisation = { + emptyDiskImages = [ 512 ]; + }; + zramSwap = { + enable = true; + priority = 10; + algorithm = "lz4"; + swapDevices = 1; + memoryPercent = 30; + memoryMax = 10 * 1024 * 1024; + writebackDevice = "/dev/vdb"; + }; }; - zramSwap = { - enable = true; - priority = 10; - algorithm = "lz4"; - swapDevices = 1; - memoryPercent = 30; - memoryMax = 10 * 1024 * 1024; - writebackDevice = "/dev/vdb"; + machine = + { ... }: + { + zramSwap = { + enable = true; + priority = 10; + algorithm = "lz4"; + swapDevices = 2; + memoryPercent = 30; + memoryMax = 10 * 1024 * 1024; + }; }; - }; - machine = { ... }: { - zramSwap = { - enable = true; - priority = 10; - algorithm = "lz4"; - swapDevices = 2; - memoryPercent = 30; - memoryMax = 10 * 1024 * 1024; - }; - }; }; testScript = '' diff --git a/nixos/tests/zrepl.nix b/nixos/tests/zrepl.nix index bdf11122c73f6c..095e03cb33446e 100644 --- a/nixos/tests/zrepl.nix +++ b/nixos/tests/zrepl.nix @@ -1,8 +1,9 @@ -import ./make-test-python.nix ( - { - name = "zrepl"; +import ./make-test-python.nix ({ + name = "zrepl"; - nodes.host = {config, pkgs, ...}: { + nodes.host = + { config, pkgs, ... }: + { config = { # Prerequisites for ZFS and tests. boot.supportedFilesystems = [ "zfs" ]; @@ -12,58 +13,64 @@ import ./make-test-python.nix ( enable = true; settings = { # Enable Prometheus output for status assertions. - global.monitoring = [{ - type = "prometheus"; - listen = ":9811"; - }]; + global.monitoring = [ + { + type = "prometheus"; + listen = ":9811"; + } + ]; # Create a periodic snapshot job for an ephemeral zpool. - jobs = [{ - name = "snap_test"; - type = "snap"; + jobs = [ + { + name = "snap_test"; + type = "snap"; - filesystems."test" = true; - snapshotting = { - type = "periodic"; - prefix = "zrepl_"; - interval = "1s"; - }; + filesystems."test" = true; + snapshotting = { + type = "periodic"; + prefix = "zrepl_"; + interval = "1s"; + }; - pruning.keep = [{ - type = "last_n"; - count = 8; - }]; - }]; + pruning.keep = [ + { + type = "last_n"; + count = 8; + } + ]; + } + ]; }; }; }; }; - testScript = '' - start_all() + testScript = '' + start_all() - with subtest("Wait for zrepl and network ready"): - host.systemctl("start network-online.target") - host.wait_for_unit("network-online.target") - host.wait_for_unit("zrepl.service") + with subtest("Wait for zrepl and network ready"): + host.systemctl("start network-online.target") + host.wait_for_unit("network-online.target") + host.wait_for_unit("zrepl.service") - with subtest("Create test zpool"): - # ZFS requires 64MiB minimum pool size. - host.succeed("fallocate -l 64MiB /root/zpool.img") - host.succeed("zpool create test /root/zpool.img") + with subtest("Create test zpool"): + # ZFS requires 64MiB minimum pool size. + host.succeed("fallocate -l 64MiB /root/zpool.img") + host.succeed("zpool create test /root/zpool.img") - with subtest("Check for completed zrepl snapshot"): - # zrepl periodic snapshot job creates a snapshot with this prefix. - host.wait_until_succeeds("zfs list -t snapshot | grep -q zrepl_") + with subtest("Check for completed zrepl snapshot"): + # zrepl periodic snapshot job creates a snapshot with this prefix. + host.wait_until_succeeds("zfs list -t snapshot | grep -q zrepl_") - with subtest("Verify HTTP monitoring server is configured"): - out = host.succeed("curl -f localhost:9811/metrics") + with subtest("Verify HTTP monitoring server is configured"): + out = host.succeed("curl -f localhost:9811/metrics") - assert ( - "zrepl_start_time" in out - ), "zrepl start time metric was not found in Prometheus output" + assert ( + "zrepl_start_time" in out + ), "zrepl start time metric was not found in Prometheus output" - assert ( - "zrepl_zfs_snapshot_duration_count{filesystem=\"test\"}" in out - ), "zrepl snapshot counter for test was not found in Prometheus output" - ''; - }) + assert ( + "zrepl_zfs_snapshot_duration_count{filesystem=\"test\"}" in out + ), "zrepl snapshot counter for test was not found in Prometheus output" + ''; +}) diff --git a/nixos/tests/zsh-history.nix b/nixos/tests/zsh-history.nix index 64f32a07e2158b..539729e32039eb 100644 --- a/nixos/tests/zsh-history.nix +++ b/nixos/tests/zsh-history.nix @@ -1,35 +1,40 @@ -import ./make-test-python.nix ({ pkgs, ...} : { - name = "zsh-history"; - meta = with pkgs.lib.maintainers; { - maintainers = [ ]; - }; - - nodes.default = { ... }: { - programs = { - zsh.enable = true; +import ./make-test-python.nix ( + { pkgs, ... }: + { + name = "zsh-history"; + meta = with pkgs.lib.maintainers; { + maintainers = [ ]; }; - environment.systemPackages = [ pkgs.zsh-history ]; - programs.zsh.interactiveShellInit = '' - source ${pkgs.zsh-history.out}/share/zsh/init.zsh - ''; - users.users.root.shell = "${pkgs.zsh}/bin/zsh"; - }; - testScript = '' - start_all() - default.wait_for_unit("multi-user.target") - default.wait_until_succeeds("pgrep -f 'agetty.*tty1'") + nodes.default = + { ... }: + { + programs = { + zsh.enable = true; + }; + environment.systemPackages = [ pkgs.zsh-history ]; + programs.zsh.interactiveShellInit = '' + source ${pkgs.zsh-history.out}/share/zsh/init.zsh + ''; + users.users.root.shell = "${pkgs.zsh}/bin/zsh"; + }; - # Login - default.wait_until_tty_matches("1", "login: ") - default.send_chars("root\n") - default.wait_until_tty_matches("1", r"\nroot@default\b") + testScript = '' + start_all() + default.wait_for_unit("multi-user.target") + default.wait_until_succeeds("pgrep -f 'agetty.*tty1'") - # Generate some history - default.send_chars("echo foobar\n") - default.wait_until_tty_matches("1", "foobar") + # Login + default.wait_until_tty_matches("1", "login: ") + default.send_chars("root\n") + default.wait_until_tty_matches("1", r"\nroot@default\b") - # Ensure that command was recorded in history - default.succeed("/run/current-system/sw/bin/history list | grep -q foobar") - ''; -}) + # Generate some history + default.send_chars("echo foobar\n") + default.wait_until_tty_matches("1", "foobar") + + # Ensure that command was recorded in history + default.succeed("/run/current-system/sw/bin/history list | grep -q foobar") + ''; + } +) diff --git a/nixos/tests/zwave-js.nix b/nixos/tests/zwave-js.nix index 9239e6964fd784..3ce12780893edb 100644 --- a/nixos/tests/zwave-js.nix +++ b/nixos/tests/zwave-js.nix @@ -1,31 +1,38 @@ -import ./make-test-python.nix ({ pkgs, lib, ...} : +import ./make-test-python.nix ( + { pkgs, lib, ... }: -let - secretsConfigFile = pkgs.writeText "secrets.json" (builtins.toJSON { - securityKeys = { - "S0_Legacy" = "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"; - }; - }); -in { - name = "zwave-js"; - meta.maintainers = with lib.maintainers; [ graham33 ]; + let + secretsConfigFile = pkgs.writeText "secrets.json" ( + builtins.toJSON { + securityKeys = { + "S0_Legacy" = "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"; + }; + } + ); + in + { + name = "zwave-js"; + meta.maintainers = with lib.maintainers; [ graham33 ]; - nodes = { - machine = { config, ... }: { - services.zwave-js = { - enable = true; - serialPort = "/dev/null"; - extraFlags = ["--mock-driver"]; - inherit secretsConfigFile; - }; + nodes = { + machine = + { config, ... }: + { + services.zwave-js = { + enable = true; + serialPort = "/dev/null"; + extraFlags = [ "--mock-driver" ]; + inherit secretsConfigFile; + }; + }; }; - }; - testScript = '' - start_all() + testScript = '' + start_all() - machine.wait_for_unit("zwave-js.service") - machine.wait_for_open_port(3000) - machine.wait_until_succeeds("journalctl --since -1m --unit zwave-js --grep 'ZwaveJS server listening'") - ''; -}) + machine.wait_for_unit("zwave-js.service") + machine.wait_for_open_port(3000) + machine.wait_until_succeeds("journalctl --since -1m --unit zwave-js --grep 'ZwaveJS server listening'") + ''; + } +) diff --git a/pkgs/applications/audio/adlplug/default.nix b/pkgs/applications/audio/adlplug/default.nix index fe83e71a598f43..bf1278e42ce8ab 100644 --- a/pkgs/applications/audio/adlplug/default.nix +++ b/pkgs/applications/audio/adlplug/default.nix @@ -1,30 +1,37 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, fmt -, liblo -, alsa-lib -, freetype -, libX11 -, libXrandr -, libXinerama -, libXext -, libXcursor +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + fmt, + liblo, + alsa-lib, + freetype, + libX11, + libXrandr, + libXinerama, + libXext, + libXcursor, # Enabling JACK requires a JACK server at runtime, no fallback mechanism -, withJack ? false, jack + withJack ? false, + jack, -, type ? "ADL" + type ? "ADL", }: -assert lib.assertOneOf "type" type [ "ADL" "OPN" ]; +assert lib.assertOneOf "type" type [ + "ADL" + "OPN" +]; let - chip = { - ADL = "OPL3"; - OPN = "OPN2"; - }.${type}; + chip = + { + ADL = "OPL3"; + OPN = "OPN2"; + } + .${type}; mainProgram = "${type}plug"; in stdenv.mkDerivation rec { @@ -45,37 +52,43 @@ stdenv.mkDerivation rec { "-DADLplug_Jack=${if withJack then "ON" else "OFF"}" ]; - NIX_LDFLAGS = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - # Framework that JUCE needs which don't get linked properly - "-framework CoreAudioKit" - "-framework QuartzCore" - "-framework AudioToolbox" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - # JUCE dlopen's these at runtime - "-lX11" - "-lXext" - "-lXcursor" - "-lXinerama" - "-lXrandr" - ]); + NIX_LDFLAGS = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + # Framework that JUCE needs which don't get linked properly + "-framework CoreAudioKit" + "-framework QuartzCore" + "-framework AudioToolbox" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + # JUCE dlopen's these at runtime + "-lX11" + "-lXext" + "-lXcursor" + "-lXinerama" + "-lXrandr" + ] + ); nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ - fmt - liblo - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - freetype - libX11 - libXrandr - libXinerama - libXext - libXcursor - ] ++ lib.optional withJack jack; + buildInputs = + [ + fmt + liblo + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + freetype + libX11 + libXrandr + libXinerama + libXext + libXcursor + ] + ++ lib.optional withJack jack; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' mkdir -p $out/{Applications,Library/Audio/Plug-Ins/{VST,Components}} diff --git a/pkgs/applications/audio/aeolus/default.nix b/pkgs/applications/audio/aeolus/default.nix index b8a2fe75570424..00dc3027180517 100644 --- a/pkgs/applications/audio/aeolus/default.nix +++ b/pkgs/applications/audio/aeolus/default.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchurl, libclthreads, zita-alsa-pcmi, alsa-lib, libjack2 -, libclxclient, libX11, libXft, readline, aeolus-stops +{ + lib, + stdenv, + fetchurl, + libclthreads, + zita-alsa-pcmi, + alsa-lib, + libjack2, + libclxclient, + libX11, + libXft, + readline, + aeolus-stops, }: stdenv.mkDerivation rec { @@ -12,8 +23,14 @@ stdenv.mkDerivation rec { }; buildInputs = [ - libclthreads zita-alsa-pcmi alsa-lib libjack2 libclxclient - libX11 libXft readline + libclthreads + zita-alsa-pcmi + alsa-lib + libjack2 + libclxclient + libX11 + libXft + readline ]; postPatch = '' @@ -23,23 +40,33 @@ stdenv.mkDerivation rec { preBuild = "cd source"; - makeFlags = [ "DESTDIR=" "PREFIX=$(out)" ]; + makeFlags = [ + "DESTDIR=" + "PREFIX=$(out)" + ]; - postInstall = let cfg = '' - # Aeolus system wide default options - # Ignored if ~/.aeolusrc with local options exists - -u -S ${aeolus-stops}/${aeolus-stops.subdir} - ''; in '' - mkdir -p $out/etc - echo -n "${cfg}" > $out/etc/aeolus.conf - ''; + postInstall = + let + cfg = '' + # Aeolus system wide default options + # Ignored if ~/.aeolusrc with local options exists + -u -S ${aeolus-stops}/${aeolus-stops.subdir} + ''; + in + '' + mkdir -p $out/etc + echo -n "${cfg}" > $out/etc/aeolus.conf + ''; meta = with lib; { description = "Synthetized (not sampled) pipe organ emulator"; homepage = "http://kokkinizita.linuxaudio.org/linuxaudio/aeolus/index.html"; license = licenses.lgpl3; platforms = platforms.linux; - maintainers = with maintainers; [ nico202 orivej ]; + maintainers = with maintainers; [ + nico202 + orivej + ]; mainProgram = "aeolus"; }; } diff --git a/pkgs/applications/audio/aeolus/stops.nix b/pkgs/applications/audio/aeolus/stops.nix index 50a2013b804800..c4ba2f34123115 100644 --- a/pkgs/applications/audio/aeolus/stops.nix +++ b/pkgs/applications/audio/aeolus/stops.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "stops"; @@ -28,6 +32,9 @@ stdenvNoCC.mkDerivation rec { homepage = "http://kokkinizita.linuxaudio.org/linuxaudio/aeolus/index.html"; license = licenses.lgpl3; platforms = platforms.linux; - maintainers = with maintainers; [ nico202 orivej ]; + maintainers = with maintainers; [ + nico202 + orivej + ]; }; } diff --git a/pkgs/applications/audio/airwave/default.nix b/pkgs/applications/audio/airwave/default.nix index a57f43eea651a0..c7422a2baac82f 100644 --- a/pkgs/applications/audio/airwave/default.nix +++ b/pkgs/applications/audio/airwave/default.nix @@ -1,4 +1,5 @@ -{ lib, +{ + lib, stdenv, multiStdenv, fetchFromGitHub, @@ -10,7 +11,7 @@ wrapQtAppsHook, file, libX11, - qt5 + qt5, }: let @@ -107,6 +108,6 @@ multiStdenv.mkDerivation { license = licenses.mit; platforms = [ "x86_64-linux" ]; maintainers = with maintainers; [ michalrus ]; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/applications/audio/amarok/default.nix b/pkgs/applications/audio/amarok/default.nix index edecadba1f1670..1160c05b6101ee 100644 --- a/pkgs/applications/audio/amarok/default.nix +++ b/pkgs/applications/audio/amarok/default.nix @@ -1,9 +1,45 @@ -{ stdenv, fetchurl, lib -, extra-cmake-modules, kdoctools -, qca-qt5, qjson, qtquickcontrols2, qtscript, qtwebengine -, karchive, kcmutils, kconfig, kdnssd, kguiaddons, kinit, kirigami2, knewstuff, knotifyconfig, ktexteditor, kwindowsystem -, fftw, phonon, plasma-framework, threadweaver, breeze-icons, wrapQtAppsHook -, curl, ffmpeg, gdk-pixbuf, libaio, liblastfm, libmtp, loudmouth, lzo, lz4, mariadb-embedded, pcre, snappy, taglib, taglib_extras +{ + stdenv, + fetchurl, + lib, + extra-cmake-modules, + kdoctools, + qca-qt5, + qjson, + qtquickcontrols2, + qtscript, + qtwebengine, + karchive, + kcmutils, + kconfig, + kdnssd, + kguiaddons, + kinit, + kirigami2, + knewstuff, + knotifyconfig, + ktexteditor, + kwindowsystem, + fftw, + phonon, + plasma-framework, + threadweaver, + breeze-icons, + wrapQtAppsHook, + curl, + ffmpeg, + gdk-pixbuf, + libaio, + liblastfm, + libmtp, + loudmouth, + lzo, + lz4, + mariadb-embedded, + pcre, + snappy, + taglib, + taglib_extras, }: stdenv.mkDerivation (finalAttrs: { @@ -15,16 +51,53 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-CrilxE8v6OcEdnWlfmQM54fxyAE0rB5VX8vvzZRyLmY="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; - nativeBuildInputs = [ extra-cmake-modules kdoctools wrapQtAppsHook ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wrapQtAppsHook + ]; propagatedBuildInputs = [ - qca-qt5 qjson qtquickcontrols2 qtscript qtwebengine - karchive kcmutils kconfig kdnssd kguiaddons kinit kirigami2 knewstuff knotifyconfig ktexteditor kwindowsystem - phonon plasma-framework threadweaver - curl fftw ffmpeg gdk-pixbuf libaio liblastfm libmtp loudmouth lz4 lzo mariadb-embedded - pcre snappy taglib taglib_extras breeze-icons + qca-qt5 + qjson + qtquickcontrols2 + qtscript + qtwebengine + karchive + kcmutils + kconfig + kdnssd + kguiaddons + kinit + kirigami2 + knewstuff + knotifyconfig + ktexteditor + kwindowsystem + phonon + plasma-framework + threadweaver + curl + fftw + ffmpeg + gdk-pixbuf + libaio + liblastfm + libmtp + loudmouth + lz4 + lzo + mariadb-embedded + pcre + snappy + taglib + taglib_extras + breeze-icons ]; enableParallelBuilding = true; diff --git a/pkgs/applications/audio/ardour/7.nix b/pkgs/applications/audio/ardour/7.nix index d0554a21af1851..fc0ba8e7a9557c 100644 --- a/pkgs/applications/audio/ardour/7.nix +++ b/pkgs/applications/audio/ardour/7.nix @@ -1,62 +1,63 @@ -{ lib -, stdenv -, fetchgit -, fetchzip -, fetchpatch -, fetchpatch2 -, alsa-lib -, aubio -, boost -, cairomm -, cppunit -, curl -, dbus -, doxygen -, ffmpeg -, fftw -, fftwSinglePrec -, flac -, glibc -, glibmm -, graphviz -, gtkmm2 -, harvid -, itstool -, libarchive -, libjack2 -, liblo -, libogg -, libpulseaudio -, librdf_raptor -, librdf_rasqal -, libsamplerate -, libsigcxx -, libsndfile -, libusb1 -, libuv -, libwebsockets -, libxml2 -, libxslt -, lilv -, lrdf -, lv2 -, makeWrapper -, pango -, perl -, pkg-config -, python3 -, readline -, rubberband -, serd -, sord -, soundtouch -, sratom -, suil -, taglib -, vamp-plugin-sdk -, wafHook -, xjadeo -, videoSupport ? true +{ + lib, + stdenv, + fetchgit, + fetchzip, + fetchpatch, + fetchpatch2, + alsa-lib, + aubio, + boost, + cairomm, + cppunit, + curl, + dbus, + doxygen, + ffmpeg, + fftw, + fftwSinglePrec, + flac, + glibc, + glibmm, + graphviz, + gtkmm2, + harvid, + itstool, + libarchive, + libjack2, + liblo, + libogg, + libpulseaudio, + librdf_raptor, + librdf_rasqal, + libsamplerate, + libsigcxx, + libsndfile, + libusb1, + libuv, + libwebsockets, + libxml2, + libxslt, + lilv, + lrdf, + lv2, + makeWrapper, + pango, + perl, + pkg-config, + python3, + readline, + rubberband, + serd, + sord, + soundtouch, + sratom, + suil, + taglib, + vamp-plugin-sdk, + wafHook, + xjadeo, + videoSupport ? true, }: stdenv.mkDerivation rec { pname = "ardour"; @@ -117,52 +118,57 @@ stdenv.mkDerivation rec { wafHook ]; - buildInputs = [ - alsa-lib - aubio - boost - cairomm - cppunit - curl - dbus - ffmpeg - fftw - fftwSinglePrec - flac - glibmm - gtkmm2 - itstool - libarchive - libjack2 - liblo - libogg - libpulseaudio - librdf_raptor - librdf_rasqal - libsamplerate - libsigcxx - libsndfile - libusb1 - libuv - libwebsockets - libxml2 - libxslt - lilv - lrdf - lv2 - pango - perl - python3 - readline - rubberband - serd - sord - soundtouch - sratom - suil - taglib - vamp-plugin-sdk - ] ++ lib.optionals videoSupport [ harvid xjadeo ]; + buildInputs = + [ + alsa-lib + aubio + boost + cairomm + cppunit + curl + dbus + ffmpeg + fftw + fftwSinglePrec + flac + glibmm + gtkmm2 + itstool + libarchive + libjack2 + liblo + libogg + libpulseaudio + librdf_raptor + librdf_rasqal + libsamplerate + libsigcxx + libsndfile + libusb1 + libuv + libwebsockets + libxml2 + libxslt + lilv + lrdf + lv2 + pango + perl + python3 + readline + rubberband + serd + sord + soundtouch + sratom + suil + taglib + vamp-plugin-sdk + ] + ++ lib.optionals videoSupport [ + harvid + xjadeo + ]; wafConfigureFlags = [ "--cxx11" @@ -177,25 +183,32 @@ stdenv.mkDerivation rec { # removed because it fixes https://tracker.ardour.org/view.php?id=8161 and https://tracker.ardour.org/view.php?id=8437 # "--use-external-libs" - postInstall = '' - # wscript does not install these for some reason - install -vDm 644 "build/gtk2_ardour/ardour.xml" \ - -t "$out/share/mime/packages" - install -vDm 644 "build/gtk2_ardour/ardour${lib.versions.major version}.desktop" \ - -t "$out/share/applications" - for size in 16 22 32 48 256 512; do - install -vDm 644 "gtk2_ardour/resources/Ardour-icon_''${size}px.png" \ - "$out/share/icons/hicolor/''${size}x''${size}/apps/ardour${lib.versions.major version}.png" - done - install -vDm 644 "ardour.1"* -t "$out/share/man/man1" + postInstall = + '' + # wscript does not install these for some reason + install -vDm 644 "build/gtk2_ardour/ardour.xml" \ + -t "$out/share/mime/packages" + install -vDm 644 "build/gtk2_ardour/ardour${lib.versions.major version}.desktop" \ + -t "$out/share/applications" + for size in 16 22 32 48 256 512; do + install -vDm 644 "gtk2_ardour/resources/Ardour-icon_''${size}px.png" \ + "$out/share/icons/hicolor/''${size}x''${size}/apps/ardour${lib.versions.major version}.png" + done + install -vDm 644 "ardour.1"* -t "$out/share/man/man1" - # install additional bundled beats, chords and progressions - cp -rp "${bundledContent}"/* "$out/share/ardour${lib.versions.major version}/media" - '' + lib.optionalString videoSupport '' - # `harvid` and `xjadeo` must be accessible in `PATH` for video to work. - wrapProgram "$out/bin/ardour${lib.versions.major version}" \ - --prefix PATH : "${lib.makeBinPath [ harvid xjadeo ]}" - ''; + # install additional bundled beats, chords and progressions + cp -rp "${bundledContent}"/* "$out/share/ardour${lib.versions.major version}/media" + '' + + lib.optionalString videoSupport '' + # `harvid` and `xjadeo` must be accessible in `PATH` for video to work. + wrapProgram "$out/bin/ardour${lib.versions.major version}" \ + --prefix PATH : "${ + lib.makeBinPath [ + harvid + xjadeo + ] + }" + ''; LINKFLAGS = "-lpthread"; @@ -214,6 +227,9 @@ stdenv.mkDerivation rec { license = licenses.gpl2Plus; mainProgram = "ardour7"; platforms = platforms.linux; - maintainers = with maintainers; [ magnetophon mitchmindtree ]; + maintainers = with maintainers; [ + magnetophon + mitchmindtree + ]; }; } diff --git a/pkgs/applications/audio/bambootracker/default.nix b/pkgs/applications/audio/bambootracker/default.nix index 419a53006ef1a8..5bf7445d268208 100644 --- a/pkgs/applications/audio/bambootracker/default.nix +++ b/pkgs/applications/audio/bambootracker/default.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, gitUpdater -, pkg-config -, qmake -, qt5compat ? null -, qtbase -, qttools -, qtwayland -, rtaudio_6 -, rtmidi -, wrapQtAppsHook +{ + stdenv, + lib, + fetchFromGitHub, + gitUpdater, + pkg-config, + qmake, + qt5compat ? null, + qtbase, + qttools, + qtwayland, + rtaudio_6, + rtmidi, + wrapQtAppsHook, }: assert lib.versionAtLeast qtbase.version "6.0" -> qt5compat != null; @@ -41,24 +42,29 @@ stdenv.mkDerivation (finalAttrs: { wrapQtAppsHook ]; - buildInputs = [ - qtbase - rtaudio_6 - rtmidi - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qtwayland - ] ++ lib.optionals (lib.versionAtLeast qtbase.version "6.0") [ - qt5compat - ]; + buildInputs = + [ + qtbase + rtaudio_6 + rtmidi + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qtwayland + ] + ++ lib.optionals (lib.versionAtLeast qtbase.version "6.0") [ + qt5compat + ]; - qmakeFlags = [ - "CONFIG+=system_rtaudio" - "CONFIG+=system_rtmidi" - ] ++ lib.optionals (stdenv.cc.isClang || (lib.versionAtLeast qtbase.version "6.0")) [ - # Clang is extra-strict about some deprecations - # Latest Qt6 deprecated QCheckBox::stateChanged(int) - "CONFIG+=no_warnings_are_errors" - ]; + qmakeFlags = + [ + "CONFIG+=system_rtaudio" + "CONFIG+=system_rtmidi" + ] + ++ lib.optionals (stdenv.cc.isClang || (lib.versionAtLeast qtbase.version "6.0")) [ + # Clang is extra-strict about some deprecations + # Latest Qt6 deprecated QCheckBox::stateChanged(int) + "CONFIG+=no_warnings_are_errors" + ]; postConfigure = "make qmake_all"; diff --git a/pkgs/applications/audio/bespokesynth/default.nix b/pkgs/applications/audio/bespokesynth/default.nix index 01b98999ce25ff..8eb63539040c4e 100644 --- a/pkgs/applications/audio/bespokesynth/default.nix +++ b/pkgs/applications/audio/bespokesynth/default.nix @@ -1,46 +1,47 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchzip -, cmake -, pkg-config -, ninja -, makeWrapper -, libjack2 -, alsa-lib -, alsa-tools -, freetype -, libusb1 -, libX11 -, libXrandr -, libXinerama -, libXext -, libXcursor -, libXScrnSaver -, libGL -, libxcb -, xcbutil -, libxkbcommon -, xcbutilkeysyms -, xcb-util-cursor -, gtk3 -, webkitgtk_4_0 -, python3 -, curl -, pcre -, mount -, zenity -, Accelerate -, Cocoa -, WebKit -, CoreServices -, CoreAudioKit -, IOBluetooth -, MetalKit +{ + lib, + stdenv, + fetchFromGitHub, + fetchzip, + cmake, + pkg-config, + ninja, + makeWrapper, + libjack2, + alsa-lib, + alsa-tools, + freetype, + libusb1, + libX11, + libXrandr, + libXinerama, + libXext, + libXcursor, + libXScrnSaver, + libGL, + libxcb, + xcbutil, + libxkbcommon, + xcbutilkeysyms, + xcb-util-cursor, + gtk3, + webkitgtk_4_0, + python3, + curl, + pcre, + mount, + zenity, + Accelerate, + Cocoa, + WebKit, + CoreServices, + CoreAudioKit, + IOBluetooth, + MetalKit, # It is not allowed to distribute binaries with the VST2 SDK plugin without a license # (the author of Bespoke has such a licence but not Nix). VST3 should work out of the box. # Read more in https://github.com/NixOS/nixpkgs/issues/145607 -, enableVST2 ? false + enableVST2 ? false, }: let @@ -73,85 +74,107 @@ stdenv.mkDerivation rec { cmakeFlags = lib.optionals enableVST2 [ "-DBESPOKE_VST2_SDK_LOCATION=${vst-sdk}/VST2_SDK" ]; - nativeBuildInputs = [ python3 makeWrapper cmake pkg-config ninja ]; - - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - # List obtained from https://github.com/BespokeSynth/BespokeSynth/blob/main/azure-pipelines.yml - libX11 - libXrandr - libXinerama - libXext - libXcursor - libXScrnSaver - curl - gtk3 - webkitgtk_4_0 - freetype - libGL - libusb1 - alsa-lib - libjack2 - zenity - alsa-tools - libxcb - xcbutil - libxkbcommon - xcbutilkeysyms - xcb-util-cursor - pcre - mount - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Accelerate - Cocoa - WebKit - CoreServices - CoreAudioKit - IOBluetooth - MetalKit + nativeBuildInputs = [ + python3 + makeWrapper + cmake + pkg-config + ninja ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + # List obtained from https://github.com/BespokeSynth/BespokeSynth/blob/main/azure-pipelines.yml + libX11 + libXrandr + libXinerama + libXext + libXcursor + libXScrnSaver + curl + gtk3 + webkitgtk_4_0 + freetype + libGL + libusb1 + alsa-lib + libjack2 + zenity + alsa-tools + libxcb + xcbutil + libxkbcommon + xcbutilkeysyms + xcb-util-cursor + pcre + mount + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Accelerate + Cocoa + WebKit + CoreServices + CoreAudioKit + IOBluetooth + MetalKit + ]; + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin (toString [ # Fails to find fp.h on its own "-isystem ${CoreServices}/Library/Frameworks/CoreServices.framework/Versions/Current/Frameworks/CarbonCore.framework/Versions/Current/Headers/" ]); postInstall = - if stdenv.hostPlatform.isDarwin then '' - mkdir -p $out/{Applications,bin} - mv Source/BespokeSynth_artefacts/${cmakeBuildType}/BespokeSynth.app $out/Applications/ - # Symlinking confuses the resource finding about the actual location of the binary - # Resources are looked up relative to the executed file's location - makeWrapper $out/{Applications/BespokeSynth.app/Contents/MacOS,bin}/BespokeSynth - '' else '' - # Ensure zenity is available, or it won't be able to open new files. - # Ensure the python used for compilation is the same as the python used at run-time. - # jedi is also required for auto-completion. - # These X11 libs get dlopen'd, they cause visual bugs when unavailable. - wrapProgram $out/bin/BespokeSynth \ - --prefix PATH : '${lib.makeBinPath [ - zenity - (python3.withPackages (ps: with ps; [ jedi ])) - ]}' - ''; + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p $out/{Applications,bin} + mv Source/BespokeSynth_artefacts/${cmakeBuildType}/BespokeSynth.app $out/Applications/ + # Symlinking confuses the resource finding about the actual location of the binary + # Resources are looked up relative to the executed file's location + makeWrapper $out/{Applications/BespokeSynth.app/Contents/MacOS,bin}/BespokeSynth + '' + else + '' + # Ensure zenity is available, or it won't be able to open new files. + # Ensure the python used for compilation is the same as the python used at run-time. + # jedi is also required for auto-completion. + # These X11 libs get dlopen'd, they cause visual bugs when unavailable. + wrapProgram $out/bin/BespokeSynth \ + --prefix PATH : '${ + lib.makeBinPath [ + zenity + (python3.withPackages (ps: with ps; [ jedi ])) + ] + }' + ''; - env.NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isLinux "-rpath ${lib.makeLibraryPath ([ - libX11 - libXrandr - libXinerama - libXext - libXcursor - libXScrnSaver - ])}"; + env.NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isLinux "-rpath ${ + lib.makeLibraryPath ([ + libX11 + libXrandr + libXinerama + libXext + libXcursor + libXScrnSaver + ]) + }"; dontPatchELF = true; # needed or nix will try to optimize the binary by removing "useless" rpath meta = with lib; { - description = - "Software modular synth with controllers support, scripting and VST"; + description = "Software modular synth with controllers support, scripting and VST"; homepage = "https://www.bespokesynth.com/"; - license = with licenses; [ - gpl3Plus - ] ++ lib.optional enableVST2 unfree; - maintainers = with maintainers; [ astro tobiasBora OPNA2608 PowerUser64 ]; + license = + with licenses; + [ + gpl3Plus + ] + ++ lib.optional enableVST2 unfree; + maintainers = with maintainers; [ + astro + tobiasBora + OPNA2608 + PowerUser64 + ]; mainProgram = "BespokeSynth"; platforms = platforms.all; }; diff --git a/pkgs/applications/audio/bitwig-studio/bitwig-studio3.nix b/pkgs/applications/audio/bitwig-studio/bitwig-studio3.nix index 4d5e5dbc265953..7c6c916154657b 100644 --- a/pkgs/applications/audio/bitwig-studio/bitwig-studio3.nix +++ b/pkgs/applications/audio/bitwig-studio/bitwig-studio3.nix @@ -1,8 +1,25 @@ -{ stdenv, fetchurl, alsa-lib, cairo, dpkg, freetype -, gdk-pixbuf, glib, gtk3, lib, xorg -, libglvnd, libjack2, ffmpeg -, libxkbcommon, xdg-utils, zlib, pulseaudio -, wrapGAppsHook3, makeWrapper }: +{ + stdenv, + fetchurl, + alsa-lib, + cairo, + dpkg, + freetype, + gdk-pixbuf, + glib, + gtk3, + lib, + xorg, + libglvnd, + libjack2, + ffmpeg, + libxkbcommon, + xdg-utils, + zlib, + pulseaudio, + wrapGAppsHook3, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "bitwig-studio"; @@ -13,13 +30,34 @@ stdenv.mkDerivation rec { sha256 = "sha256-cF8gVPjM0KUcKOW09uFccp4/lzbUmZcBkVOwr/A/8Yw="; }; - nativeBuildInputs = [ dpkg makeWrapper wrapGAppsHook3 ]; + nativeBuildInputs = [ + dpkg + makeWrapper + wrapGAppsHook3 + ]; dontBuild = true; dontWrapGApps = true; # we only want $gappsWrapperArgs here buildInputs = with xorg; [ - alsa-lib cairo freetype gdk-pixbuf glib gtk3 libxcb xcbutil xcbutilwm zlib libXtst libxkbcommon pulseaudio libjack2 libX11 libglvnd libXcursor (lib.getLib stdenv.cc.cc) + alsa-lib + cairo + freetype + gdk-pixbuf + glib + gtk3 + libxcb + xcbutil + xcbutilwm + zlib + libXtst + libxkbcommon + pulseaudio + libjack2 + libX11 + libglvnd + libXcursor + (lib.getLib stdenv.cc.cc) ]; ldLibraryPath = lib.strings.makeLibraryPath buildInputs; @@ -64,7 +102,11 @@ stdenv.mkDerivation rec { homepage = "https://www.bitwig.com/"; license = licenses.unfree; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ bfortz michalrus mrVanDalo ]; + maintainers = with maintainers; [ + bfortz + michalrus + mrVanDalo + ]; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; }; } diff --git a/pkgs/applications/audio/bitwig-studio/bitwig-studio4.nix b/pkgs/applications/audio/bitwig-studio/bitwig-studio4.nix index 47b2fbbeb968ad..fcfcd3b09b11a8 100644 --- a/pkgs/applications/audio/bitwig-studio/bitwig-studio4.nix +++ b/pkgs/applications/audio/bitwig-studio/bitwig-studio4.nix @@ -1,25 +1,26 @@ -{ stdenv -, fetchurl -, alsa-lib -, cairo -, dpkg -, ffmpeg -, freetype -, gdk-pixbuf -, glib -, gtk3 -, lib -, libglvnd -, libjack2 -, libjpeg -, libxkbcommon -, makeWrapper -, pipewire -, pulseaudio -, wrapGAppsHook3 -, xdg-utils -, xorg -, zlib +{ + stdenv, + fetchurl, + alsa-lib, + cairo, + dpkg, + ffmpeg, + freetype, + gdk-pixbuf, + glib, + gtk3, + lib, + libglvnd, + libjack2, + libjpeg, + libxkbcommon, + makeWrapper, + pipewire, + pulseaudio, + wrapGAppsHook3, + xdg-utils, + xorg, + zlib, }: stdenv.mkDerivation rec { @@ -31,7 +32,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-gtQ1mhXk0AqGidZk5TCzSR58pD1JJoELMBmELtqyb4U="; }; - nativeBuildInputs = [ dpkg makeWrapper wrapGAppsHook3 ]; + nativeBuildInputs = [ + dpkg + makeWrapper + wrapGAppsHook3 + ]; dontBuild = true; dontWrapGApps = true; # we only want $gappsWrapperArgs here @@ -110,7 +115,11 @@ stdenv.mkDerivation rec { homepage = "https://www.bitwig.com/"; license = licenses.unfree; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ bfortz michalrus mrVanDalo ]; + maintainers = with maintainers; [ + bfortz + michalrus + mrVanDalo + ]; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; }; } diff --git a/pkgs/applications/audio/bitwig-studio/bitwig-studio5.nix b/pkgs/applications/audio/bitwig-studio/bitwig-studio5.nix index 4955b43943096e..9b34f007914869 100644 --- a/pkgs/applications/audio/bitwig-studio/bitwig-studio5.nix +++ b/pkgs/applications/audio/bitwig-studio/bitwig-studio5.nix @@ -1,31 +1,32 @@ -{ stdenv -, fetchurl -, alsa-lib -, atk -, cairo -, dpkg -, ffmpeg -, freetype -, gdk-pixbuf -, glib -, gtk3 -, harfbuzz -, lib -, libglvnd -, libjack2 -, libjpeg -, libnghttp2 -, libxkbcommon -, makeWrapper -, pango -, pipewire -, pulseaudio -, vulkan-loader -, wrapGAppsHook3 -, xcb-imdkit -, xdg-utils -, xorg -, zlib +{ + stdenv, + fetchurl, + alsa-lib, + atk, + cairo, + dpkg, + ffmpeg, + freetype, + gdk-pixbuf, + glib, + gtk3, + harfbuzz, + lib, + libglvnd, + libjack2, + libjpeg, + libnghttp2, + libxkbcommon, + makeWrapper, + pango, + pipewire, + pulseaudio, + vulkan-loader, + wrapGAppsHook3, + xcb-imdkit, + xdg-utils, + xorg, + zlib, }: stdenv.mkDerivation rec { @@ -38,7 +39,11 @@ stdenv.mkDerivation rec { hash = "sha256-Tyi7qYhTQ5i6fRHhrmz4yHXSdicd4P4iuF9FRKRhkMI="; }; - nativeBuildInputs = [ dpkg makeWrapper wrapGAppsHook3 ]; + nativeBuildInputs = [ + dpkg + makeWrapper + wrapGAppsHook3 + ]; dontBuild = true; dontWrapGApps = true; # we only want $gappsWrapperArgs here @@ -128,7 +133,11 @@ stdenv.mkDerivation rec { homepage = "https://www.bitwig.com/"; license = licenses.unfree; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ bfortz michalrus mrVanDalo ]; + maintainers = with maintainers; [ + bfortz + michalrus + mrVanDalo + ]; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; }; } diff --git a/pkgs/applications/audio/bucklespring/default.nix b/pkgs/applications/audio/bucklespring/default.nix index ccc25da4f1ed0a..a126c227f3467a 100644 --- a/pkgs/applications/audio/bucklespring/default.nix +++ b/pkgs/applications/audio/bucklespring/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, -, legacy ? false -, libinput + legacy ? false, + libinput, -, pkg-config -, makeWrapper + pkg-config, + makeWrapper, -, openal -, alure -, libXtst -, libX11 + openal, + alure, + libXtst, + libX11, }: let @@ -28,10 +29,20 @@ stdenv.mkDerivation rec { sha256 = "0prhqibivxzmz90k79zpwx3c97h8wa61rk5ihi9a5651mnc46mna"; }; - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; - buildInputs = [ openal alure ] - ++ optionals (legacy) [ libXtst libX11 ] + buildInputs = + [ + openal + alure + ] + ++ optionals (legacy) [ + libXtst + libX11 + ] ++ optionals (!legacy) [ libinput ]; makeFlags = optionals (!legacy) [ "libinput=1" ]; @@ -58,7 +69,7 @@ stdenv.mkDerivation rec { ''; homepage = "https://github.com/zevv/bucklespring"; license = licenses.gpl2Only; - platforms = platforms.unix; + platforms = platforms.unix; maintainers = [ maintainers.evils ]; }; } diff --git a/pkgs/applications/audio/calf/default.nix b/pkgs/applications/audio/calf/default.nix index d4da3a2d869117..36b6bf4d3de7ae 100644 --- a/pkgs/applications/audio/calf/default.nix +++ b/pkgs/applications/audio/calf/default.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchurl, cairo, expat, fftwSinglePrec, fluidsynth, glib -, gtk2, libjack2, ladspaH , libglade, lv2, pkg-config }: +{ + lib, + stdenv, + fetchurl, + cairo, + expat, + fftwSinglePrec, + fluidsynth, + glib, + gtk2, + libjack2, + ladspaH, + libglade, + lv2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "calf"; @@ -10,14 +24,25 @@ stdenv.mkDerivation rec { sha256 = "17x4hylgq4dn9qycsdacfxy64f5cv57n2qgkvsdp524gnqzw4az3"; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; enableParallelBuilding = true; nativeBuildInputs = [ pkg-config ]; buildInputs = [ - cairo expat fftwSinglePrec fluidsynth glib gtk2 libjack2 ladspaH - libglade lv2 + cairo + expat + fftwSinglePrec + fluidsynth + glib + gtk2 + libjack2 + ladspaH + libglade + lv2 ]; meta = with lib; { diff --git a/pkgs/applications/audio/carla/default.nix b/pkgs/applications/audio/carla/default.nix index 68016e4a16bee3..7748d68206e7df 100644 --- a/pkgs/applications/audio/carla/default.nix +++ b/pkgs/applications/audio/carla/default.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchFromGitHub -, alsa-lib -, file -, fluidsynth -, jack2 -, liblo -, libpulseaudio -, libsndfile -, pkg-config -, python3Packages -, which -, gtk2 ? null -, gtk3 ? null -, qtbase ? null -, withFrontend ? true -, withGtk2 ? true -, withGtk3 ? true -, withQt ? true -, wrapQtAppsHook ? null +{ + lib, + stdenv, + fetchFromGitHub, + alsa-lib, + file, + fluidsynth, + jack2, + liblo, + libpulseaudio, + libsndfile, + pkg-config, + python3Packages, + which, + gtk2 ? null, + gtk3 ? null, + qtbase ? null, + withFrontend ? true, + withGtk2 ? true, + withGtk3 ? true, + withQt ? true, + wrapQtAppsHook ? null, }: assert withQt -> qtbase != null; @@ -36,16 +37,31 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ - python3Packages.wrapPython pkg-config which wrapQtAppsHook + python3Packages.wrapPython + pkg-config + which + wrapQtAppsHook ]; - pythonPath = with python3Packages; [ - rdflib pyliblo - ] ++ lib.optional withFrontend pyqt5; + pythonPath = + with python3Packages; + [ + rdflib + pyliblo + ] + ++ lib.optional withFrontend pyqt5; - buildInputs = [ - file liblo alsa-lib fluidsynth jack2 libpulseaudio libsndfile - ] ++ lib.optional withQt qtbase + buildInputs = + [ + file + liblo + alsa-lib + fluidsynth + jack2 + libpulseaudio + libsndfile + ] + ++ lib.optional withQt qtbase ++ lib.optional withGtk2 gtk2 ++ lib.optional withGtk3 gtk3; @@ -55,17 +71,19 @@ stdenv.mkDerivation (finalAttrs: { installFlags = [ "PREFIX=$(out)" ]; - postPatch = '' - # --with-appname="$0" is evaluated with $0=.carla-wrapped instead of carla. Fix that. - for file in $(grep -rl -- '--with-appname="$0"'); do - filename="$(basename -- "$file")" - substituteInPlace "$file" --replace '--with-appname="$0"' "--with-appname=\"$filename\"" - done - '' + lib.optionalString withGtk2 '' - # Will try to dlopen() libgtk-x11-2.0 at runtime when using the bridge. - substituteInPlace source/bridges-ui/Makefile \ - --replace '$(CXX) $(OBJS_GTK2)' '$(CXX) $(OBJS_GTK2) -lgtk-x11-2.0' - ''; + postPatch = + '' + # --with-appname="$0" is evaluated with $0=.carla-wrapped instead of carla. Fix that. + for file in $(grep -rl -- '--with-appname="$0"'); do + filename="$(basename -- "$file")" + substituteInPlace "$file" --replace '--with-appname="$0"' "--with-appname=\"$filename\"" + done + '' + + lib.optionalString withGtk2 '' + # Will try to dlopen() libgtk-x11-2.0 at runtime when using the bridge. + substituteInPlace source/bridges-ui/Makefile \ + --replace '$(CXX) $(OBJS_GTK2)' '$(CXX) $(OBJS_GTK2) -lgtk-x11-2.0' + ''; dontWrapQtApps = true; postFixup = '' diff --git a/pkgs/applications/audio/cd-discid/default.nix b/pkgs/applications/audio/cd-discid/default.nix index a30ebc8fbe394a..25898ef8bd2788 100644 --- a/pkgs/applications/audio/cd-discid/default.nix +++ b/pkgs/applications/audio/cd-discid/default.nix @@ -1,5 +1,9 @@ -{ fetchurl, lib, stdenv -, IOKit ? null }: +{ + fetchurl, + lib, + stdenv, + IOKit ? null, +}: stdenv.mkDerivation rec { pname = "cd-discid"; @@ -10,10 +14,12 @@ stdenv.mkDerivation rec { sha256 = "0qrcvn7227qaayjcd5rm7z0k5q89qfy5qkdgwr5pd7ih0va8rmpz"; }; - installFlags = [ "PREFIX=$(out)" "INSTALL=install" ]; + installFlags = [ + "PREFIX=$(out)" + "INSTALL=install" + ]; - buildInputs = [] - ++ lib.optional stdenv.hostPlatform.isDarwin IOKit; + buildInputs = [ ] ++ lib.optional stdenv.hostPlatform.isDarwin IOKit; meta = with lib; { homepage = "http://linukz.org/cd-discid.shtml"; diff --git a/pkgs/applications/audio/cdparanoia/default.nix b/pkgs/applications/audio/cdparanoia/default.nix index 3f15f90f5b78a9..e3760c9e201272 100644 --- a/pkgs/applications/audio/cdparanoia/default.nix +++ b/pkgs/applications/audio/cdparanoia/default.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchurl, fetchpatch -, updateAutotoolsGnuConfigScriptsHook, autoreconfHook +{ + lib, + stdenv, + fetchurl, + fetchpatch, + updateAutotoolsGnuConfigScriptsHook, + autoreconfHook, }: stdenv.mkDerivation rec { @@ -11,50 +16,53 @@ stdenv.mkDerivation rec { sha256 = "1pv4zrajm46za0f6lv162iqffih57a8ly4pc69f7y0gfyigb8p80"; }; - patches = lib.optionals stdenv.hostPlatform.isDarwin [ - (fetchpatch { - url = "https://github.com/macports/macports-ports/raw/c8e15973bc3c1e1ab371bc0ee2de14209e639f17/audio/cdparanoia/files/osx_interface.patch"; - hash = "sha256-9p4+9dRvqLHkpR0RWLQcNL1m7fb7L6r+c9Q2tt4jh0U="; - # Our configure patch will subsume it, but we want our configure - # patch to be used on all platforms so we cannot just start where - # this leaves off. - excludes = [ "configure.in" ]; - }) - (fetchurl { - url = "https://trac.macports.org/export/70964/trunk/dports/audio/cdparanoia/files/patch-paranoia_paranoia.c.10.4.diff"; - hash = "sha256-TW1RkJ0bKaPIrDSfUTKorNlmKDVRF++z8ZJAjSzEgp4="; - }) - # add missing include files needed for function prototypes - (fetchpatch { - url = "https://github.com/macports/macports-ports/raw/f210a6061bc53c746730a37922399c6de6d69cb7/audio/cdparanoia/files/fixing-include.patch"; - hash = "sha256-6a/u4b8/H/4XjyFup23xySgyAI9SMVMom4PLvH8KzhE="; - }) - ] ++ [ - # Has to come after darwin patches - ./fix_private_keyword.patch - # Order does not matter - ./configure.patch - # labs for long - (fetchpatch { - url = "https://github.com/macports/macports-ports/raw/f210a6061bc53c746730a37922399c6de6d69cb7/audio/cdparanoia/files/fixing-labs.patch"; - hash = "sha256-BMMQ5bbPP3eevuwWUVjQCtRBiWbkAHD+O0C0fp+BPaw="; - }) - # use "%s" for passing a buffer to fprintf - (fetchpatch { - url = "https://github.com/macports/macports-ports/raw/f210a6061bc53c746730a37922399c6de6d69cb7/audio/cdparanoia/files/fixing-fprintf.patch"; - hash = "sha256-2dJl16p+f5l3wxVOJhsuLiQ9a4prq7jsRZP8/ygEae4="; - }) - # add support for IDE4-9 - (fetchpatch { - url = "https://salsa.debian.org/optical-media-team/cdparanoia/-/raw/bbf353721834b3784ccc0fd54a36a6b25181f5a4/debian/patches/02-ide-devices.patch"; - hash = "sha256-S6OzftUIPPq9JHsoAE2K51ltsI1WkVaQrpgCjgm5AG4="; - }) - # check buffer is non-null before dereferencing - (fetchpatch { - url = "https://salsa.debian.org/optical-media-team/cdparanoia/-/raw/f7bab3024c5576da1fdb7497abbd6abc8959a98c/debian/patches/04-endian.patch"; - hash = "sha256-krfprwls0L3hsNfoj2j69J5k1RTKEQtzE0fLYG9EJKo="; - }) - ] ++ lib.optional stdenv.hostPlatform.isMusl ./utils.patch; + patches = + lib.optionals stdenv.hostPlatform.isDarwin [ + (fetchpatch { + url = "https://github.com/macports/macports-ports/raw/c8e15973bc3c1e1ab371bc0ee2de14209e639f17/audio/cdparanoia/files/osx_interface.patch"; + hash = "sha256-9p4+9dRvqLHkpR0RWLQcNL1m7fb7L6r+c9Q2tt4jh0U="; + # Our configure patch will subsume it, but we want our configure + # patch to be used on all platforms so we cannot just start where + # this leaves off. + excludes = [ "configure.in" ]; + }) + (fetchurl { + url = "https://trac.macports.org/export/70964/trunk/dports/audio/cdparanoia/files/patch-paranoia_paranoia.c.10.4.diff"; + hash = "sha256-TW1RkJ0bKaPIrDSfUTKorNlmKDVRF++z8ZJAjSzEgp4="; + }) + # add missing include files needed for function prototypes + (fetchpatch { + url = "https://github.com/macports/macports-ports/raw/f210a6061bc53c746730a37922399c6de6d69cb7/audio/cdparanoia/files/fixing-include.patch"; + hash = "sha256-6a/u4b8/H/4XjyFup23xySgyAI9SMVMom4PLvH8KzhE="; + }) + ] + ++ [ + # Has to come after darwin patches + ./fix_private_keyword.patch + # Order does not matter + ./configure.patch + # labs for long + (fetchpatch { + url = "https://github.com/macports/macports-ports/raw/f210a6061bc53c746730a37922399c6de6d69cb7/audio/cdparanoia/files/fixing-labs.patch"; + hash = "sha256-BMMQ5bbPP3eevuwWUVjQCtRBiWbkAHD+O0C0fp+BPaw="; + }) + # use "%s" for passing a buffer to fprintf + (fetchpatch { + url = "https://github.com/macports/macports-ports/raw/f210a6061bc53c746730a37922399c6de6d69cb7/audio/cdparanoia/files/fixing-fprintf.patch"; + hash = "sha256-2dJl16p+f5l3wxVOJhsuLiQ9a4prq7jsRZP8/ygEae4="; + }) + # add support for IDE4-9 + (fetchpatch { + url = "https://salsa.debian.org/optical-media-team/cdparanoia/-/raw/bbf353721834b3784ccc0fd54a36a6b25181f5a4/debian/patches/02-ide-devices.patch"; + hash = "sha256-S6OzftUIPPq9JHsoAE2K51ltsI1WkVaQrpgCjgm5AG4="; + }) + # check buffer is non-null before dereferencing + (fetchpatch { + url = "https://salsa.debian.org/optical-media-team/cdparanoia/-/raw/f7bab3024c5576da1fdb7497abbd6abc8959a98c/debian/patches/04-endian.patch"; + hash = "sha256-krfprwls0L3hsNfoj2j69J5k1RTKEQtzE0fLYG9EJKo="; + }) + ] + ++ lib.optional stdenv.hostPlatform.isMusl ./utils.patch; nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook @@ -73,7 +81,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://xiph.org/paranoia"; description = "Tool and library for reading digital audio from CDs"; - license = with licenses; [ gpl2Plus lgpl21Plus ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + ]; platforms = platforms.unix; mainProgram = "cdparanoia"; }; diff --git a/pkgs/applications/audio/chuck/default.nix b/pkgs/applications/audio/chuck/default.nix index db42e60730eabd..54fe244158407a 100644 --- a/pkgs/applications/audio/chuck/default.nix +++ b/pkgs/applications/audio/chuck/default.nix @@ -1,5 +1,21 @@ -{ stdenv, lib, fetchurl, alsa-lib, bison, flex, libsndfile, which, DarwinTools, xcbuild -, AppKit, Carbon, CoreAudio, CoreMIDI, CoreServices, Kernel, MultitouchSupport +{ + stdenv, + lib, + fetchurl, + alsa-lib, + bison, + flex, + libsndfile, + which, + DarwinTools, + xcbuild, + AppKit, + Carbon, + CoreAudio, + CoreMIDI, + CoreServices, + Kernel, + MultitouchSupport, }: stdenv.mkDerivation rec { @@ -11,16 +27,36 @@ stdenv.mkDerivation rec { sha256 = "sha256-hIwsC9rYgXWSTFqUufKGqoT0Gnsf4nR4KQ0iSVbj8xg="; }; - nativeBuildInputs = [ flex bison which ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ DarwinTools xcbuild ]; + nativeBuildInputs = + [ + flex + bison + which + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + DarwinTools + xcbuild + ]; - buildInputs = [ libsndfile ] + buildInputs = + [ libsndfile ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) alsa-lib - ++ lib.optionals stdenv.hostPlatform.isDarwin [ AppKit Carbon CoreAudio CoreMIDI CoreServices Kernel MultitouchSupport ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + Carbon + CoreAudio + CoreMIDI + CoreServices + Kernel + MultitouchSupport + ]; patches = [ ./darwin-limits.patch ]; - makeFlags = [ "-C src" "DESTDIR=$(out)/bin" ]; + makeFlags = [ + "-C src" + "DESTDIR=$(out)/bin" + ]; buildFlags = [ (if stdenv.hostPlatform.isDarwin then "mac" else "linux-alsa") ]; meta = with lib; { diff --git a/pkgs/applications/audio/cmus/default.nix b/pkgs/applications/audio/cmus/default.nix index 2ca612841cc319..d4fef58281d012 100644 --- a/pkgs/applications/audio/cmus/default.nix +++ b/pkgs/applications/audio/cmus/default.nix @@ -1,39 +1,73 @@ -{ config, lib, stdenv, fetchFromGitHub, ncurses, pkg-config -, libiconv, CoreAudio, AudioUnit, VideoToolbox - -, alsaSupport ? stdenv.hostPlatform.isLinux, alsa-lib ? null -# simple fallback for everyone else -, aoSupport ? !stdenv.hostPlatform.isLinux, libao ? null -, jackSupport ? false, libjack ? null -, samplerateSupport ? jackSupport, libsamplerate ? null -, ossSupport ? false, alsa-oss ? null -, pulseaudioSupport ? config.pulseaudio or false, libpulseaudio ? null -, sndioSupport ? false, sndio ? null -, mprisSupport ? stdenv.hostPlatform.isLinux, systemd ? null - -# TODO: add these -#, artsSupport -#, roarSupport -#, sunSupport -#, waveoutSupport - -, cddbSupport ? true, libcddb ? null -, cdioSupport ? true, libcdio ? null, libcdio-paranoia ? null -, cueSupport ? true, libcue ? null -, discidSupport ? false, libdiscid ? null -, ffmpegSupport ? true, ffmpeg ? null -, flacSupport ? true, flac ? null -, madSupport ? true, libmad ? null -, mikmodSupport ? true, libmikmod ? null -, modplugSupport ? true, libmodplug ? null -, mpcSupport ? true, libmpcdec ? null -, tremorSupport ? false, tremor ? null -, vorbisSupport ? true, libvorbis ? null -, wavpackSupport ? true, wavpack ? null -, opusSupport ? true, opusfile ? null - -, aacSupport ? false, faad2 ? null # already handled by ffmpeg -, mp4Support ? false, mp4v2 ? null # ffmpeg does support mp4 better +{ + config, + lib, + stdenv, + fetchFromGitHub, + ncurses, + pkg-config, + libiconv, + CoreAudio, + AudioUnit, + VideoToolbox, + + alsaSupport ? stdenv.hostPlatform.isLinux, + alsa-lib ? null, + # simple fallback for everyone else + aoSupport ? !stdenv.hostPlatform.isLinux, + libao ? null, + jackSupport ? false, + libjack ? null, + samplerateSupport ? jackSupport, + libsamplerate ? null, + ossSupport ? false, + alsa-oss ? null, + pulseaudioSupport ? config.pulseaudio or false, + libpulseaudio ? null, + sndioSupport ? false, + sndio ? null, + mprisSupport ? stdenv.hostPlatform.isLinux, + systemd ? null, + + # TODO: add these + #, artsSupport + #, roarSupport + #, sunSupport + #, waveoutSupport + + cddbSupport ? true, + libcddb ? null, + cdioSupport ? true, + libcdio ? null, + libcdio-paranoia ? null, + cueSupport ? true, + libcue ? null, + discidSupport ? false, + libdiscid ? null, + ffmpegSupport ? true, + ffmpeg ? null, + flacSupport ? true, + flac ? null, + madSupport ? true, + libmad ? null, + mikmodSupport ? true, + libmikmod ? null, + modplugSupport ? true, + libmodplug ? null, + mpcSupport ? true, + libmpcdec ? null, + tremorSupport ? false, + tremor ? null, + vorbisSupport ? true, + libvorbis ? null, + wavpackSupport ? true, + wavpack ? null, + opusSupport ? true, + opusfile ? null, + + aacSupport ? false, + faad2 ? null, # already handled by ffmpeg + mp4Support ? false, + mp4v2 ? null, # ffmpeg does support mp4 better # not in nixpkgs #, vtxSupport ? true, libayemu ? null @@ -47,20 +81,29 @@ assert tremorSupport -> !vorbisSupport; let - mkFlag = b: f: dep: if b - then { flags = [ f ]; deps = [ dep ]; } - else { flags = []; deps = []; }; + mkFlag = + b: f: dep: + if b then + { + flags = [ f ]; + deps = [ dep ]; + } + else + { + flags = [ ]; + deps = [ ]; + }; opts = [ # Audio output - (mkFlag alsaSupport "CONFIG_ALSA=y" alsa-lib) - (mkFlag aoSupport "CONFIG_AO=y" libao) - (mkFlag jackSupport "CONFIG_JACK=y" libjack) + (mkFlag alsaSupport "CONFIG_ALSA=y" alsa-lib) + (mkFlag aoSupport "CONFIG_AO=y" libao) + (mkFlag jackSupport "CONFIG_JACK=y" libjack) (mkFlag samplerateSupport "CONFIG_SAMPLERATE=y" libsamplerate) - (mkFlag ossSupport "CONFIG_OSS=y" alsa-oss) - (mkFlag pulseaudioSupport "CONFIG_PULSE=y" libpulseaudio) - (mkFlag sndioSupport "CONFIG_SNDIO=y" sndio) - (mkFlag mprisSupport "CONFIG_MPRIS=y" systemd) + (mkFlag ossSupport "CONFIG_OSS=y" alsa-oss) + (mkFlag pulseaudioSupport "CONFIG_PULSE=y" libpulseaudio) + (mkFlag sndioSupport "CONFIG_SNDIO=y" sndio) + (mkFlag mprisSupport "CONFIG_MPRIS=y" systemd) #(mkFlag artsSupport "CONFIG_ARTS=y") #(mkFlag roarSupport "CONFIG_ROAR=y") @@ -68,23 +111,26 @@ let #(mkFlag waveoutSupport "CONFIG_WAVEOUT=y") # Input file formats - (mkFlag cddbSupport "CONFIG_CDDB=y" libcddb) - (mkFlag cdioSupport "CONFIG_CDIO=y" [ libcdio libcdio-paranoia ]) - (mkFlag cueSupport "CONFIG_CUE=y" libcue) - (mkFlag discidSupport "CONFIG_DISCID=y" libdiscid) - (mkFlag ffmpegSupport "CONFIG_FFMPEG=y" ffmpeg) - (mkFlag flacSupport "CONFIG_FLAC=y" flac) - (mkFlag madSupport "CONFIG_MAD=y" libmad) - (mkFlag mikmodSupport "CONFIG_MIKMOD=y" libmikmod) + (mkFlag cddbSupport "CONFIG_CDDB=y" libcddb) + (mkFlag cdioSupport "CONFIG_CDIO=y" [ + libcdio + libcdio-paranoia + ]) + (mkFlag cueSupport "CONFIG_CUE=y" libcue) + (mkFlag discidSupport "CONFIG_DISCID=y" libdiscid) + (mkFlag ffmpegSupport "CONFIG_FFMPEG=y" ffmpeg) + (mkFlag flacSupport "CONFIG_FLAC=y" flac) + (mkFlag madSupport "CONFIG_MAD=y" libmad) + (mkFlag mikmodSupport "CONFIG_MIKMOD=y" libmikmod) (mkFlag modplugSupport "CONFIG_MODPLUG=y" libmodplug) - (mkFlag mpcSupport "CONFIG_MPC=y" libmpcdec) - (mkFlag tremorSupport "CONFIG_TREMOR=y" tremor) - (mkFlag vorbisSupport "CONFIG_VORBIS=y" libvorbis) + (mkFlag mpcSupport "CONFIG_MPC=y" libmpcdec) + (mkFlag tremorSupport "CONFIG_TREMOR=y" tremor) + (mkFlag vorbisSupport "CONFIG_VORBIS=y" libvorbis) (mkFlag wavpackSupport "CONFIG_WAVPACK=y" wavpack) - (mkFlag opusSupport "CONFIG_OPUS=y" opusfile) + (mkFlag opusSupport "CONFIG_OPUS=y" opusfile) - (mkFlag mp4Support "CONFIG_MP4=y" mp4v2) - (mkFlag aacSupport "CONFIG_AAC=y" faad2) + (mkFlag mp4Support "CONFIG_MP4=y" mp4v2) + (mkFlag aacSupport "CONFIG_AAC=y" faad2) #(mkFlag vtxSupport "CONFIG_VTX=y" libayemu) ]; @@ -95,15 +141,21 @@ stdenv.mkDerivation rec { version = "2.12.0"; src = fetchFromGitHub { - owner = "cmus"; - repo = "cmus"; - rev = "v${version}"; - hash = "sha256-8hgibGtkiwzenMI9YImIApRmw2EzTwE6RhglALpUkp4="; + owner = "cmus"; + repo = "cmus"; + rev = "v${version}"; + hash = "sha256-8hgibGtkiwzenMI9YImIApRmw2EzTwE6RhglALpUkp4="; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ ncurses ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv CoreAudio AudioUnit VideoToolbox ] + buildInputs = + [ ncurses ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + CoreAudio + AudioUnit + VideoToolbox + ] ++ lib.flatten (lib.concatMap (a: a.deps) opts); prefixKey = "prefix="; diff --git a/pkgs/applications/audio/codecserver/default.nix b/pkgs/applications/audio/codecserver/default.nix index 0c1bee94cc10f4..c055c72c4eafa0 100644 --- a/pkgs/applications/audio/codecserver/default.nix +++ b/pkgs/applications/audio/codecserver/default.nix @@ -1,5 +1,11 @@ -{ stdenv, lib, fetchFromGitHub -, cmake, pkg-config, udev, protobuf +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + udev, + protobuf, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/audio/csound/csound-qt/default.nix b/pkgs/applications/audio/csound/csound-qt/default.nix index 5c0c2a7f3d00e8..9ff6bb2de902c4 100644 --- a/pkgs/applications/audio/csound/csound-qt/default.nix +++ b/pkgs/applications/audio/csound/csound-qt/default.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, csound, desktop-file-utils, - fetchFromGitHub, python3, python-qt, qmake, - qtwebengine, qtxmlpatterns, rtmidi, wrapQtAppsHook }: +{ + lib, + stdenv, + csound, + desktop-file-utils, + fetchFromGitHub, + python3, + python-qt, + qmake, + qtwebengine, + qtxmlpatterns, + rtmidi, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "csound-qt"; @@ -17,23 +28,36 @@ stdenv.mkDerivation rec { ./rtmidipath.patch ]; - nativeBuildInputs = [ qmake qtwebengine qtxmlpatterns wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + qtwebengine + qtxmlpatterns + wrapQtAppsHook + ]; - buildInputs = [ csound desktop-file-utils rtmidi ]; + buildInputs = [ + csound + desktop-file-utils + rtmidi + ]; - qmakeFlags = [ "qcs.pro" "CONFIG+=rtmidi" "CONFIG+=pythonqt" - "CONFIG+=record_support" "CONFIG+=html_webengine" - "CSOUND_INCLUDE_DIR=${csound}/include/csound" - "CSOUND_LIBRARY_DIR=${csound}/lib" - "RTMIDI_DIR=${rtmidi.src}" - "PYTHONQT_SRC_DIR=${python-qt.src}" - "PYTHONQT_LIB_DIR=${python-qt}/lib" - "LIBS+=-L${python-qt}/lib" - "INSTALL_DIR=${placeholder "out"}" - "SHARE_DIR=${placeholder "out"}/share" - "PYTHON_DIR=${python3}" - "PYTHON_VERSION=3.${python3.sourceVersion.minor}" - ]; + qmakeFlags = [ + "qcs.pro" + "CONFIG+=rtmidi" + "CONFIG+=pythonqt" + "CONFIG+=record_support" + "CONFIG+=html_webengine" + "CSOUND_INCLUDE_DIR=${csound}/include/csound" + "CSOUND_LIBRARY_DIR=${csound}/lib" + "RTMIDI_DIR=${rtmidi.src}" + "PYTHONQT_SRC_DIR=${python-qt.src}" + "PYTHONQT_LIB_DIR=${python-qt}/lib" + "LIBS+=-L${python-qt}/lib" + "INSTALL_DIR=${placeholder "out"}" + "SHARE_DIR=${placeholder "out"}/share" + "PYTHON_DIR=${python3}" + "PYTHON_VERSION=3.${python3.sourceVersion.minor}" + ]; meta = with lib; { description = "CsoundQt is a frontend for Csound with editor, integrated help, widgets and other features"; diff --git a/pkgs/applications/audio/csound/default.nix b/pkgs/applications/audio/csound/default.nix index c6359103593ffd..207f1201a67101 100644 --- a/pkgs/applications/audio/csound/default.nix +++ b/pkgs/applications/audio/csound/default.nix @@ -1,20 +1,30 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libsndfile, libsamplerate, flex, bison, boost, gettext -, Accelerate -, AudioUnit -, CoreAudio -, CoreMIDI -, portaudio -, alsa-lib ? null -, libpulseaudio ? null -, libjack2 ? null -, liblo ? null -, ladspa-sdk ? null -, fluidsynth ? null -# , gmm ? null # opcodes don't build with gmm 5.1 -, eigen ? null -, curl ? null -, tcltk ? null -, fltk ? null +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libsndfile, + libsamplerate, + flex, + bison, + boost, + gettext, + Accelerate, + AudioUnit, + CoreAudio, + CoreMIDI, + portaudio, + alsa-lib ? null, + libpulseaudio ? null, + libjack2 ? null, + liblo ? null, + ladspa-sdk ? null, + fluidsynth ? null, + # , gmm ? null # opcodes don't build with gmm 5.1 + eigen ? null, + curl ? null, + tcltk ? null, + fltk ? null, }: stdenv.mkDerivation rec { @@ -30,20 +40,47 @@ stdenv.mkDerivation rec { sha256 = "sha256-O7s92N54+zIl07eIdK/puoSve/qJ3O01fTh0TP+VdZA="; }; - cmakeFlags = [ "-DBUILD_CSOUND_AC=0" ] # fails to find Score.hpp + cmakeFlags = + [ "-DBUILD_CSOUND_AC=0" ] # fails to find Score.hpp ++ lib.optional stdenv.hostPlatform.isDarwin "-DCS_FRAMEWORK_DEST=${placeholder "out"}/lib" # Ignore gettext in CMAKE_PREFIX_PATH on cross to prevent find_program picking up the wrong gettext - ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "-DCMAKE_IGNORE_PATH=${lib.getBin gettext}/bin"; + ++ lib.optional ( + stdenv.hostPlatform != stdenv.buildPlatform + ) "-DCMAKE_IGNORE_PATH=${lib.getBin gettext}/bin"; - nativeBuildInputs = [ cmake flex bison gettext ]; - buildInputs = [ libsndfile libsamplerate boost ] + nativeBuildInputs = [ + cmake + flex + bison + gettext + ]; + buildInputs = + [ + libsndfile + libsamplerate + boost + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Accelerate AudioUnit CoreAudio CoreMIDI portaudio - ] ++ lib.optionals stdenv.hostPlatform.isLinux (builtins.filter (optional: optional != null) [ - alsa-lib libpulseaudio libjack2 - liblo ladspa-sdk fluidsynth eigen - curl tcltk fltk - ]); + Accelerate + AudioUnit + CoreAudio + CoreMIDI + portaudio + ] + ++ lib.optionals stdenv.hostPlatform.isLinux ( + builtins.filter (optional: optional != null) [ + alsa-lib + libpulseaudio + libjack2 + liblo + ladspa-sdk + fluidsynth + eigen + curl + tcltk + fltk + ] + ); postInstall = lib.optional stdenv.hostPlatform.isDarwin '' mkdir -p $out/Library/Frameworks @@ -54,7 +91,7 @@ stdenv.mkDerivation rec { description = "Sound design, audio synthesis, and signal processing system, providing facilities for music composition and performance on all major operating systems and platforms"; homepage = "https://csound.com/"; license = licenses.lgpl21Plus; - maintainers = [maintainers.marcweber]; + maintainers = [ maintainers.marcweber ]; platforms = platforms.unix; }; } diff --git a/pkgs/applications/audio/deadbeef/default.nix b/pkgs/applications/audio/deadbeef/default.nix index d141a61963659d..537ed988066598 100644 --- a/pkgs/applications/audio/deadbeef/default.nix +++ b/pkgs/applications/audio/deadbeef/default.nix @@ -1,39 +1,68 @@ -{ lib, config, clangStdenv, fetchFromGitHub -, autoconf -, automake -, libtool -, intltool -, pkg-config -, jansson -, swift-corelibs-libdispatch -# deadbeef can use either gtk2 or gtk3 -, gtk2Support ? false, gtk2 -, gtk3Support ? true, gtk3, gsettings-desktop-schemas, wrapGAppsHook3 -# input plugins -, vorbisSupport ? true, libvorbis -, mp123Support ? true, libmad -, flacSupport ? true, flac -, wavSupport ? true, libsndfile -, cdaSupport ? true, libcdio, libcddb -, aacSupport ? true, faad2 -, opusSupport ? true, opusfile -, wavpackSupport ? false, wavpack -, ffmpegSupport ? false, ffmpeg -, apeSupport ? true, yasm -# misc plugins -, zipSupport ? true, libzip -, artworkSupport ? true, imlib2 -, hotkeysSupport ? true, libX11 -, osdSupport ? true, dbus -# output plugins -, alsaSupport ? true, alsa-lib -, pulseSupport ? config.pulseaudio or true, libpulseaudio -, pipewireSupport ? true, pipewire -# effect plugins -, resamplerSupport ? true, libsamplerate -, overloadSupport ? true, zlib -# transports -, remoteSupport ? true, curl +{ + lib, + config, + clangStdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + intltool, + pkg-config, + jansson, + swift-corelibs-libdispatch, + # deadbeef can use either gtk2 or gtk3 + gtk2Support ? false, + gtk2, + gtk3Support ? true, + gtk3, + gsettings-desktop-schemas, + wrapGAppsHook3, + # input plugins + vorbisSupport ? true, + libvorbis, + mp123Support ? true, + libmad, + flacSupport ? true, + flac, + wavSupport ? true, + libsndfile, + cdaSupport ? true, + libcdio, + libcddb, + aacSupport ? true, + faad2, + opusSupport ? true, + opusfile, + wavpackSupport ? false, + wavpack, + ffmpegSupport ? false, + ffmpeg, + apeSupport ? true, + yasm, + # misc plugins + zipSupport ? true, + libzip, + artworkSupport ? true, + imlib2, + hotkeysSupport ? true, + libX11, + osdSupport ? true, + dbus, + # output plugins + alsaSupport ? true, + alsa-lib, + pulseSupport ? config.pulseaudio or true, + libpulseaudio, + pipewireSupport ? true, + pipewire, + # effect plugins + resamplerSupport ? true, + libsamplerate, + overloadSupport ? true, + zlib, + # transports + remoteSupport ? true, + curl, }: assert gtk2Support || gtk3Support; @@ -42,7 +71,8 @@ let inherit (lib) optionals; version = "1.9.6"; -in clangStdenv.mkDerivation { +in +clangStdenv.mkDerivation { pname = "deadbeef"; inherit version; @@ -54,66 +84,91 @@ in clangStdenv.mkDerivation { hash = "sha256-Q6hL4fOFPHn26ZqvrebgTMTgQZrhbXCEhM4ZFzNeyJE="; }; - buildInputs = [ - jansson - swift-corelibs-libdispatch - ] ++ optionals gtk2Support [ - gtk2 - ] ++ optionals gtk3Support [ - gtk3 - gsettings-desktop-schemas - ] ++ optionals vorbisSupport [ - libvorbis - ] ++ optionals mp123Support [ - libmad - ] ++ optionals flacSupport [ - flac - ] ++ optionals wavSupport [ - libsndfile - ] ++ optionals cdaSupport [ - libcdio - libcddb - ] ++ optionals aacSupport [ - faad2 - ] ++ optionals opusSupport [ - opusfile - ] ++ optionals zipSupport [ - libzip - ] ++ optionals ffmpegSupport [ - ffmpeg - ] ++ optionals apeSupport [ - yasm - ] ++ optionals artworkSupport [ - imlib2 - ] ++ optionals hotkeysSupport [ - libX11 - ] ++ optionals osdSupport [ - dbus - ] ++ optionals alsaSupport [ - alsa-lib - ] ++ optionals pulseSupport [ - libpulseaudio - ] ++ optionals pipewireSupport [ - pipewire - ] ++ optionals resamplerSupport [ - libsamplerate - ] ++ optionals overloadSupport [ - zlib - ] ++ optionals wavpackSupport [ - wavpack - ] ++ optionals remoteSupport [ - curl - ]; + buildInputs = + [ + jansson + swift-corelibs-libdispatch + ] + ++ optionals gtk2Support [ + gtk2 + ] + ++ optionals gtk3Support [ + gtk3 + gsettings-desktop-schemas + ] + ++ optionals vorbisSupport [ + libvorbis + ] + ++ optionals mp123Support [ + libmad + ] + ++ optionals flacSupport [ + flac + ] + ++ optionals wavSupport [ + libsndfile + ] + ++ optionals cdaSupport [ + libcdio + libcddb + ] + ++ optionals aacSupport [ + faad2 + ] + ++ optionals opusSupport [ + opusfile + ] + ++ optionals zipSupport [ + libzip + ] + ++ optionals ffmpegSupport [ + ffmpeg + ] + ++ optionals apeSupport [ + yasm + ] + ++ optionals artworkSupport [ + imlib2 + ] + ++ optionals hotkeysSupport [ + libX11 + ] + ++ optionals osdSupport [ + dbus + ] + ++ optionals alsaSupport [ + alsa-lib + ] + ++ optionals pulseSupport [ + libpulseaudio + ] + ++ optionals pipewireSupport [ + pipewire + ] + ++ optionals resamplerSupport [ + libsamplerate + ] + ++ optionals overloadSupport [ + zlib + ] + ++ optionals wavpackSupport [ + wavpack + ] + ++ optionals remoteSupport [ + curl + ]; - nativeBuildInputs = [ - autoconf - automake - intltool - libtool - pkg-config - ] ++ optionals gtk3Support [ - wrapGAppsHook3 - ]; + nativeBuildInputs = + [ + autoconf + automake + intltool + libtool + pkg-config + ] + ++ optionals gtk3Support [ + wrapGAppsHook3 + ]; enableParallelBuilding = true; @@ -134,7 +189,10 @@ in clangStdenv.mkDerivation { homepage = "http://deadbeef.sourceforge.net/"; downloadPage = "https://github.com/DeaDBeeF-Player/deadbeef"; license = licenses.gpl2; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ maintainers.abbradar ]; }; } diff --git a/pkgs/applications/audio/deadbeef/plugins/headerbar-gtk3.nix b/pkgs/applications/audio/deadbeef/plugins/headerbar-gtk3.nix index 16cefc5ff85a19..784195b23d7372 100644 --- a/pkgs/applications/audio/deadbeef/plugins/headerbar-gtk3.nix +++ b/pkgs/applications/audio/deadbeef/plugins/headerbar-gtk3.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libtool, pkg-config, libxml2, deadbeef, glib, gtk3 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + pkg-config, + libxml2, + deadbeef, + glib, + gtk3, +}: stdenv.mkDerivation rec { pname = "deadbeef-headerbar-gtk3-plugin"; @@ -11,8 +23,18 @@ stdenv.mkDerivation rec { sha256 = "1v1schvnps7ypjqgcbqi74a45w8r2gbhrawz7filym22h1qr9wn0"; }; - nativeBuildInputs = [ autoconf automake libtool pkg-config libxml2 ]; - buildInputs = [ deadbeef glib gtk3 ]; + nativeBuildInputs = [ + autoconf + automake + libtool + pkg-config + libxml2 + ]; + buildInputs = [ + deadbeef + glib + gtk3 + ]; # Choose correct installation path # https://github.com/saivert/ddb_misc_headerbar_GTK3/commit/50ff75f76aa9d40761e352311670a894bfcd5cf6#r30319680 diff --git a/pkgs/applications/audio/deadbeef/plugins/lyricbar.nix b/pkgs/applications/audio/deadbeef/plugins/lyricbar.nix index bc6d206956f09b..3a6a705de5cb59 100644 --- a/pkgs/applications/audio/deadbeef/plugins/lyricbar.nix +++ b/pkgs/applications/audio/deadbeef/plugins/lyricbar.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, deadbeef, gtkmm3, libxmlxx3 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + deadbeef, + gtkmm3, + libxmlxx3, +}: stdenv.mkDerivation { pname = "deadbeef-lyricbar-plugin"; @@ -12,7 +20,11 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ deadbeef gtkmm3 libxmlxx3 ]; + buildInputs = [ + deadbeef + gtkmm3 + libxmlxx3 + ]; buildFlags = [ "gtk3" ]; diff --git a/pkgs/applications/audio/deadbeef/plugins/mpris2.nix b/pkgs/applications/audio/deadbeef/plugins/mpris2.nix index a6d6409f9f86cd..bb41a6f0f5f470 100644 --- a/pkgs/applications/audio/deadbeef/plugins/mpris2.nix +++ b/pkgs/applications/audio/deadbeef/plugins/mpris2.nix @@ -1,16 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, deadbeef -, autoreconfHook -, pkg-config -, glib +{ + lib, + stdenv, + fetchFromGitHub, + deadbeef, + autoreconfHook, + pkg-config, + glib, }: let pname = "deadbeef-mpris2-plugin"; version = "1.16"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname version; src = fetchFromGitHub { diff --git a/pkgs/applications/audio/deadbeef/plugins/musical-spectrum.nix b/pkgs/applications/audio/deadbeef/plugins/musical-spectrum.nix index de371bfb552dab..f60351ad11fac2 100644 --- a/pkgs/applications/audio/deadbeef/plugins/musical-spectrum.nix +++ b/pkgs/applications/audio/deadbeef/plugins/musical-spectrum.nix @@ -1,11 +1,12 @@ -{ deadbeef -, fetchFromGitHub -, fftw -, glib -, gtk3 -, lib -, pkg-config -, stdenv +{ + deadbeef, + fetchFromGitHub, + fftw, + glib, + gtk3, + lib, + pkg-config, + stdenv, }: stdenv.mkDerivation rec { @@ -20,7 +21,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ deadbeef fftw glib gtk3 ]; + buildInputs = [ + deadbeef + fftw + glib + gtk3 + ]; makeFlags = [ "gtk3" ]; installPhase = '' diff --git a/pkgs/applications/audio/deadbeef/plugins/playlist-manager.nix b/pkgs/applications/audio/deadbeef/plugins/playlist-manager.nix index cf82697988941c..f6113cb9e904f4 100644 --- a/pkgs/applications/audio/deadbeef/plugins/playlist-manager.nix +++ b/pkgs/applications/audio/deadbeef/plugins/playlist-manager.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, deadbeef -, gtk3 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + deadbeef, + gtk3, }: stdenv.mkDerivation { diff --git a/pkgs/applications/audio/deadbeef/plugins/statusnotifier.nix b/pkgs/applications/audio/deadbeef/plugins/statusnotifier.nix index 287f439c94d50c..c6a1a08d59542d 100644 --- a/pkgs/applications/audio/deadbeef/plugins/statusnotifier.nix +++ b/pkgs/applications/audio/deadbeef/plugins/statusnotifier.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, deadbeef, gtk3, perl -, libdbusmenu }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + deadbeef, + gtk3, + perl, + libdbusmenu, +}: stdenv.mkDerivation rec { pname = "deadbeef-statusnotifier-plugin"; @@ -13,7 +21,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ deadbeef gtk3 libdbusmenu ]; + buildInputs = [ + deadbeef + gtk3 + libdbusmenu + ]; buildFlags = [ "gtk3" ]; diff --git a/pkgs/applications/audio/deadbeef/wrapper.nix b/pkgs/applications/audio/deadbeef/wrapper.nix index 66108deab1e325..c3074e7b2e0762 100644 --- a/pkgs/applications/audio/deadbeef/wrapper.nix +++ b/pkgs/applications/audio/deadbeef/wrapper.nix @@ -1,4 +1,9 @@ -{ symlinkJoin, deadbeef, makeWrapper, plugins }: +{ + symlinkJoin, + deadbeef, + makeWrapper, + plugins, +}: symlinkJoin { name = "deadbeef-with-plugins-${deadbeef.version}"; diff --git a/pkgs/applications/audio/dfasma/default.nix b/pkgs/applications/audio/dfasma/default.nix index 78ab9c8a5f4f08..dd3827ab8a1946 100644 --- a/pkgs/applications/audio/dfasma/default.nix +++ b/pkgs/applications/audio/dfasma/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchFromGitHub, fftw, libsndfile, qtbase, qtmultimedia, qmake }: +{ + mkDerivation, + lib, + fetchFromGitHub, + fftw, + libsndfile, + qtbase, + qtmultimedia, + qmake, +}: let @@ -10,7 +19,7 @@ let owner = "gillesdegottex"; }; meta = with lib; { - license = licenses.asl20; + license = licenses.asl20; }; }; @@ -22,11 +31,12 @@ let owner = "gillesdegottex"; }; meta = with lib; { - license = licenses.gpl3Plus; + license = licenses.gpl3Plus; }; }; -in mkDerivation rec { +in +mkDerivation rec { pname = "dfasma"; version = "1.4.5"; @@ -37,7 +47,12 @@ in mkDerivation rec { owner = "gillesdegottex"; }; - buildInputs = [ fftw libsndfile qtbase qtmultimedia ]; + buildInputs = [ + fftw + libsndfile + qtbase + qtmultimedia + ]; nativeBuildInputs = [ qmake ]; @@ -59,7 +74,10 @@ in mkDerivation rec { amplitude, this software does not aim to be an audio editor. ''; homepage = "https://gillesdegottex.gitlab.io/dfasma-website/"; - license = [ licenses.gpl3Plus reaperFork.meta.license ]; + license = [ + licenses.gpl3Plus + reaperFork.meta.license + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/audio/easyabc/default.nix b/pkgs/applications/audio/easyabc/default.nix index bdc753d0f45e07..10af7b23b9d53c 100644 --- a/pkgs/applications/audio/easyabc/default.nix +++ b/pkgs/applications/audio/easyabc/default.nix @@ -1,4 +1,16 @@ -{ lib, fetchFromGitHub, fetchPypi, substituteAll, python39, fluidsynth, soundfont-fluid, wrapGAppsHook3, abcmidi, abcm2ps, ghostscript }: +{ + lib, + fetchFromGitHub, + fetchPypi, + substituteAll, + python39, + fluidsynth, + soundfont-fluid, + wrapGAppsHook3, + abcmidi, + abcm2ps, + ghostscript, +}: let # requires python39 due to https://stackoverflow.com/a/71902541 https://github.com/jwdj/EasyABC/issues/52 @@ -17,7 +29,8 @@ let }); }; }; -in python.pkgs.buildPythonApplication { +in +python.pkgs.buildPythonApplication { pname = "easyabc"; version = "1.3.8.6"; diff --git a/pkgs/applications/audio/easyaudiosync/default.nix b/pkgs/applications/audio/easyaudiosync/default.nix index b5f6a522ff5a8d..e7166cd9eb80ce 100644 --- a/pkgs/applications/audio/easyaudiosync/default.nix +++ b/pkgs/applications/audio/easyaudiosync/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, cmake -, qtbase -, qttools -, spdlog -, ffmpeg -, taglib -, wrapQtAppsHook -, makeDesktopItem -, copyDesktopItems +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + qtbase, + qttools, + spdlog, + ffmpeg, + taglib, + wrapQtAppsHook, + makeDesktopItem, + copyDesktopItems, }: stdenv.mkDerivation rec { @@ -47,11 +48,13 @@ stdenv.mkDerivation rec { installPhase = '' runHook preInstall - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' mkdir -p $out/Applications mv "easyaudiosync.app" "Easy Audio Sync.app" cp -r "Easy Audio Sync.app" $out/Applications - '' + lib.optionalString stdenv.hostPlatform.isLinux '' + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' install -Dm755 easyaudiosync $out/bin/easyaudiosync for RES in 48 64 128 256; do @@ -59,7 +62,8 @@ stdenv.mkDerivation rec { done install -Dm755 "$src/assets/icons/easyaudiosync.svg" "$out/share/icons/hicolor/scalable/apps/easyaudiosync.svg" - '' + '' + '' + + '' runHook postInstall ''; diff --git a/pkgs/applications/audio/espeak-ng/default.nix b/pkgs/applications/audio/espeak-ng/default.nix index 7eabadec04c22c..e7463c8c6613dd 100644 --- a/pkgs/applications/audio/espeak-ng/default.nix +++ b/pkgs/applications/audio/espeak-ng/default.nix @@ -1,26 +1,27 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, autoconf -, automake -, which -, libtool -, pkg-config -, ronn -, substituteAll -, buildPackages -, mbrolaSupport ? true -, mbrola -, pcaudiolibSupport ? true -, pcaudiolib -, sonicSupport ? true -, sonic -, CoreAudio -, AudioToolbox -, AudioUnit -, alsa-plugins -, makeWrapper +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + autoconf, + automake, + which, + libtool, + pkg-config, + ronn, + substituteAll, + buildPackages, + mbrolaSupport ? true, + mbrola, + pcaudiolibSupport ? true, + pcaudiolib, + sonicSupport ? true, + sonic, + CoreAudio, + AudioToolbox, + AudioUnit, + alsa-plugins, + makeWrapper, }: stdenv.mkDerivation rec { @@ -34,38 +35,51 @@ stdenv.mkDerivation rec { hash = "sha256-aAJ+k+kkOS6k835mEW7BvgAIYGhUHxf7Q4P5cKO8XTk="; }; - patches = [ - # Fix build with Clang 16. - (fetchpatch { - url = "https://github.com/espeak-ng/espeak-ng/commit/497c6217d696c1190c3e8b992ff7b9110eb3bedd.patch"; - hash = "sha256-KfzqnRyQfz6nuMKnsHoUzb9rn9h/Pg54mupW1Cr+Zx0="; - }) - ] ++ lib.optionals mbrolaSupport [ - # Hardcode correct mbrola paths. - (substituteAll { - src = ./mbrola.patch; - inherit mbrola; - }) - ]; + patches = + [ + # Fix build with Clang 16. + (fetchpatch { + url = "https://github.com/espeak-ng/espeak-ng/commit/497c6217d696c1190c3e8b992ff7b9110eb3bedd.patch"; + hash = "sha256-KfzqnRyQfz6nuMKnsHoUzb9rn9h/Pg54mupW1Cr+Zx0="; + }) + ] + ++ lib.optionals mbrolaSupport [ + # Hardcode correct mbrola paths. + (substituteAll { + src = ./mbrola.patch; + inherit mbrola; + }) + ]; - nativeBuildInputs = [ autoconf automake which libtool pkg-config ronn makeWrapper ]; + nativeBuildInputs = [ + autoconf + automake + which + libtool + pkg-config + ronn + makeWrapper + ]; - buildInputs = lib.optional mbrolaSupport mbrola + buildInputs = + lib.optional mbrolaSupport mbrola ++ lib.optional pcaudiolibSupport pcaudiolib ++ lib.optional sonicSupport sonic ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreAudio - AudioToolbox - AudioUnit - ]; + CoreAudio + AudioToolbox + AudioUnit + ]; # touch ChangeLog to avoid below error on darwin: # Makefile.am: error: required file './ChangeLog.md' not found - preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin '' - touch ChangeLog - '' + '' - ./autogen.sh - ''; + preConfigure = + lib.optionalString stdenv.hostPlatform.isDarwin '' + touch ChangeLog + '' + + '' + ./autogen.sh + ''; configureFlags = [ "--with-mbrola=${if mbrolaSupport then "yes" else "no"}" diff --git a/pkgs/applications/audio/espeak/default.nix b/pkgs/applications/audio/espeak/default.nix index 4693995883d913..d5a443095bf18f 100644 --- a/pkgs/applications/audio/espeak/default.nix +++ b/pkgs/applications/audio/espeak/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, unzip, portaudio }: +{ + lib, + stdenv, + fetchurl, + unzip, + portaudio, +}: stdenv.mkDerivation rec { pname = "espeak"; @@ -16,12 +22,14 @@ stdenv.mkDerivation rec { ./gcc6.patch ]; - prePatch = '' - sed -e s,/bin/ln,ln,g -i src/Makefile - sed -e 's,^CXXFLAGS=-O2,CXXFLAGS=-O2 -D PATH_ESPEAK_DATA=\\\"$(DATADIR)\\\",' -i src/Makefile - '' + (lib.optionalString (portaudio.api_version == 19) '' - cp src/portaudio19.h src/portaudio.h - ''); + prePatch = + '' + sed -e s,/bin/ln,ln,g -i src/Makefile + sed -e 's,^CXXFLAGS=-O2,CXXFLAGS=-O2 -D PATH_ESPEAK_DATA=\\\"$(DATADIR)\\\",' -i src/Makefile + '' + + (lib.optionalString (portaudio.api_version == 19) '' + cp src/portaudio19.h src/portaudio.h + ''); configurePhase = '' cd src diff --git a/pkgs/applications/audio/espeak/edit.nix b/pkgs/applications/audio/espeak/edit.nix index 4be2f404f60f62..a4b5536e6f997a 100644 --- a/pkgs/applications/audio/espeak/edit.nix +++ b/pkgs/applications/audio/espeak/edit.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, unzip, portaudio, wxGTK32, sox }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + unzip, + portaudio, + wxGTK32, + sox, +}: stdenv.mkDerivation rec { pname = "espeakedit"; @@ -9,8 +18,14 @@ stdenv.mkDerivation rec { sha256 = "0x8s7vpb7rw5x37yjzy1f98m4f2csdg89libb74fm36gn8ly0hli"; }; - nativeBuildInputs = [ pkg-config unzip ]; - buildInputs = [ portaudio wxGTK32 ]; + nativeBuildInputs = [ + pkg-config + unzip + ]; + buildInputs = [ + portaudio + wxGTK32 + ]; # TODO: # Uhm, seems like espeakedit still wants espeak-data/ in $HOME, even thought @@ -30,19 +45,21 @@ stdenv.mkDerivation rec { ./espeakedit-wxgtk30.patch ]; - postPatch = '' - # Disable -Wall flag because it's noisy - sed -i "s/-Wall//g" src/Makefile - - # Fixup paths (file names from above espeak-configurable* patches) - for file in src/compiledata.cpp src/readclause.cpp src/speech.h; do - sed -e "s|@sox@|${sox}/bin/sox|" \ - -e "s|@prefix@|$out|" \ - -i "$file" - done - '' + lib.optionalString (portaudio.api_version == 19) '' - cp src/portaudio19.h src/portaudio.h - ''; + postPatch = + '' + # Disable -Wall flag because it's noisy + sed -i "s/-Wall//g" src/Makefile + + # Fixup paths (file names from above espeak-configurable* patches) + for file in src/compiledata.cpp src/readclause.cpp src/speech.h; do + sed -e "s|@sox@|${sox}/bin/sox|" \ + -e "s|@prefix@|$out|" \ + -i "$file" + done + '' + + lib.optionalString (portaudio.api_version == 19) '' + cp src/portaudio19.h src/portaudio.h + ''; buildPhase = '' make -C src diff --git a/pkgs/applications/audio/faust/faust2.nix b/pkgs/applications/audio/faust/faust2.nix index 68a9708e2842e2..c1c6fb225c3ebe 100644 --- a/pkgs/applications/audio/faust/faust2.nix +++ b/pkgs/applications/audio/faust/faust2.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, coreutils -, fetchFromGitHub -, makeWrapper -, pkg-config -, cmake -, llvm -, emscripten -, openssl -, libsndfile -, libmicrohttpd -, gnutls -, libtasn1 -, p11-kit -, vim -, which -, ncurses -, fetchpatch +{ + lib, + stdenv, + coreutils, + fetchFromGitHub, + makeWrapper, + pkg-config, + cmake, + llvm, + emscripten, + openssl, + libsndfile, + libmicrohttpd, + gnutls, + libtasn1, + p11-kit, + vim, + which, + ncurses, + fetchpatch, }: with lib.strings; @@ -38,19 +39,30 @@ let downloadPage = "https://github.com/grame-cncm/faust/"; license = licenses.gpl2; platforms = platforms.unix; - maintainers = with maintainers; [ magnetophon pmahoney ]; + maintainers = with maintainers; [ + magnetophon + pmahoney + ]; }; faust = - let ncurses_static = ncurses.override { enableStatic = true; }; - in stdenv.mkDerivation { + let + ncurses_static = ncurses.override { enableStatic = true; }; + in + stdenv.mkDerivation { pname = "faust"; inherit version; inherit src; - nativeBuildInputs = [ makeWrapper pkg-config cmake vim which ]; + nativeBuildInputs = [ + makeWrapper + pkg-config + cmake + vim + which + ]; buildInputs = [ llvm emscripten @@ -74,7 +86,10 @@ let --replace 'rm -rf $(TMP)' ' ' ''; - cmakeFlags = [ "-C../backends/all.cmake" "-C../targets/all.cmake" ]; + cmakeFlags = [ + "-C../backends/all.cmake" + "-C../targets/all.cmake" + ]; postInstall = '' # syntax error when eval'd directly @@ -97,8 +112,7 @@ let ''; meta = meta // { - description = - "A functional programming language for realtime audio signal processing"; + description = "A functional programming language for realtime audio signal processing"; longDescription = '' FAUST (Functional Audio Stream) is a functional programming language specifically designed for real-time signal processing @@ -121,9 +135,15 @@ let # Default values for faust2appl. faust2ApplBase = - { baseName, dir ? "tools/faust2appls", scripts ? [ baseName ], ... }@args: - - args // { + { + baseName, + dir ? "tools/faust2appls", + scripts ? [ baseName ], + ... + }@args: + + args + // { name = "${baseName}-${version}"; inherit src; @@ -151,8 +171,7 @@ let ''; meta = meta // { - description = - "The ${baseName} script, part of faust functional programming language for realtime audio signal processing"; + description = "The ${baseName} script, part of faust functional programming language for realtime audio signal processing"; }; }; @@ -172,65 +191,83 @@ let # # The build input 'faust' is automatically added to the # propagatedBuildInputs. - wrapWithBuildEnv = { baseName, propagatedBuildInputs ? [ ], ... }@args: + wrapWithBuildEnv = + { + baseName, + propagatedBuildInputs ? [ ], + ... + }@args: - stdenv.mkDerivation ((faust2ApplBase args) // { + stdenv.mkDerivation ( + (faust2ApplBase args) + // { - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; - propagatedBuildInputs = [ faust ] ++ propagatedBuildInputs; + propagatedBuildInputs = [ faust ] ++ propagatedBuildInputs; - libPath = lib.makeLibraryPath propagatedBuildInputs; - - postFixup = '' - - # export parts of the build environment - for script in "$out"/bin/*; do - # e.g. NIX_CC_WRAPPER_TARGET_HOST_x86_64_unknown_linux_gnu - nix_cc_wrapper_target_host="$(printenv | grep ^NIX_CC_WRAPPER_TARGET_HOST | sed 's/=.*//')" + libPath = lib.makeLibraryPath propagatedBuildInputs; - # e.g. NIX_BINTOOLS_WRAPPER_TARGET_HOST_x86_64_unknown_linux_gnu - nix_bintools_wrapper_target_host="$(printenv | grep ^NIX_BINTOOLS_WRAPPER_TARGET_HOST | sed 's/=.*//')" + postFixup = '' - wrapProgram "$script" \ - --set FAUSTLDDIR "${faust}/lib" \ - --set FAUSTLIB "${faust}/share/faust" \ - --set FAUSTINC "${faust}/include/faust" \ - --set FAUSTARCH "${faust}/share/faust" \ - --prefix PATH : "$PATH" \ - --prefix PKG_CONFIG_PATH : "$PKG_CONFIG_PATH" \ - --set NIX_CFLAGS_COMPILE "$NIX_CFLAGS_COMPILE" \ - --set NIX_LDFLAGS "$NIX_LDFLAGS -lpthread" \ - --set "$nix_cc_wrapper_target_host" "''${!nix_cc_wrapper_target_host}" \ - --set "$nix_bintools_wrapper_target_host" "''${!nix_bintools_wrapper_target_host}" \ - --prefix LIBRARY_PATH "$libPath" - done - ''; - }); + # export parts of the build environment + for script in "$out"/bin/*; do + # e.g. NIX_CC_WRAPPER_TARGET_HOST_x86_64_unknown_linux_gnu + nix_cc_wrapper_target_host="$(printenv | grep ^NIX_CC_WRAPPER_TARGET_HOST | sed 's/=.*//')" + + # e.g. NIX_BINTOOLS_WRAPPER_TARGET_HOST_x86_64_unknown_linux_gnu + nix_bintools_wrapper_target_host="$(printenv | grep ^NIX_BINTOOLS_WRAPPER_TARGET_HOST | sed 's/=.*//')" + + wrapProgram "$script" \ + --set FAUSTLDDIR "${faust}/lib" \ + --set FAUSTLIB "${faust}/share/faust" \ + --set FAUSTINC "${faust}/include/faust" \ + --set FAUSTARCH "${faust}/share/faust" \ + --prefix PATH : "$PATH" \ + --prefix PKG_CONFIG_PATH : "$PKG_CONFIG_PATH" \ + --set NIX_CFLAGS_COMPILE "$NIX_CFLAGS_COMPILE" \ + --set NIX_LDFLAGS "$NIX_LDFLAGS -lpthread" \ + --set "$nix_cc_wrapper_target_host" "''${!nix_cc_wrapper_target_host}" \ + --set "$nix_bintools_wrapper_target_host" "''${!nix_bintools_wrapper_target_host}" \ + --prefix LIBRARY_PATH "$libPath" + done + ''; + } + ); # Builder for 'faust2appl' scripts, such as faust2firefox that # simply need to be wrapped with some dependencies on PATH. # # The build input 'faust' is automatically added to the PATH. - wrap = { baseName, runtimeInputs ? [ ], ... }@args: + wrap = + { + baseName, + runtimeInputs ? [ ], + ... + }@args: let - runtimePath = - concatStringsSep ":" (map (p: "${p}/bin") ([ faust ] ++ runtimeInputs)); + runtimePath = concatStringsSep ":" (map (p: "${p}/bin") ([ faust ] ++ runtimeInputs)); in - stdenv.mkDerivation ((faust2ApplBase args) // { + stdenv.mkDerivation ( + (faust2ApplBase args) + // { nativeBuildInputs = [ makeWrapper ]; postFixup = '' - for script in "$out"/bin/*; do - wrapProgram "$script" --prefix PATH : "${runtimePath}" - done - ''; + for script in "$out"/bin/*; do + wrapProgram "$script" --prefix PATH : "${runtimePath}" + done + ''; - }); + } + ); in faust diff --git a/pkgs/applications/audio/faust/faust2alqt.nix b/pkgs/applications/audio/faust/faust2alqt.nix index b12b41763ba59b..66d394e9d74034 100644 --- a/pkgs/applications/audio/faust/faust2alqt.nix +++ b/pkgs/applications/audio/faust/faust2alqt.nix @@ -1,8 +1,9 @@ -{ faust -, alsa-lib -, qtbase -, writeText -, buildPackages +{ + faust, + alsa-lib, + qtbase, + writeText, + buildPackages, }: let # Wrap the binary coming out of the the compilation script, so it knows QT_PLUGIN_PATH diff --git a/pkgs/applications/audio/faust/faust2alsa.nix b/pkgs/applications/audio/faust/faust2alsa.nix index bb6121a5d70bd6..b14d65fcd119ff 100644 --- a/pkgs/applications/audio/faust/faust2alsa.nix +++ b/pkgs/applications/audio/faust/faust2alsa.nix @@ -1,13 +1,14 @@ -{ faust -, alsa-lib -, atk -, cairo -, fontconfig -, freetype -, gdk-pixbuf -, glib -, gtk2 -, pango +{ + faust, + alsa-lib, + atk, + cairo, + fontconfig, + freetype, + gdk-pixbuf, + glib, + gtk2, + pango, }: faust.wrapWithBuildEnv { diff --git a/pkgs/applications/audio/faust/faust2csound.nix b/pkgs/applications/audio/faust/faust2csound.nix index eb5e5831cddd7f..9b921eb88af284 100644 --- a/pkgs/applications/audio/faust/faust2csound.nix +++ b/pkgs/applications/audio/faust/faust2csound.nix @@ -1,5 +1,6 @@ -{ faust -, csound +{ + faust, + csound, }: faust.wrapWithBuildEnv { diff --git a/pkgs/applications/audio/faust/faust2firefox.nix b/pkgs/applications/audio/faust/faust2firefox.nix index c718aa06806a42..cda50b929629be 100644 --- a/pkgs/applications/audio/faust/faust2firefox.nix +++ b/pkgs/applications/audio/faust/faust2firefox.nix @@ -1,5 +1,6 @@ -{ faust -, xdg-utils +{ + faust, + xdg-utils, }: # This just runs faust2svg, then attempts to open a browser using diff --git a/pkgs/applications/audio/faust/faust2jack.nix b/pkgs/applications/audio/faust/faust2jack.nix index bd213bfcadbe4f..77f9b391023412 100644 --- a/pkgs/applications/audio/faust/faust2jack.nix +++ b/pkgs/applications/audio/faust/faust2jack.nix @@ -1,10 +1,11 @@ -{ faust -, gtk2 -, jack2 -, alsa-lib -, opencv -, libsndfile -, which +{ + faust, + gtk2, + jack2, + alsa-lib, + opencv, + libsndfile, + which, }: faust.wrapWithBuildEnv { diff --git a/pkgs/applications/audio/faust/faust2jackrust.nix b/pkgs/applications/audio/faust/faust2jackrust.nix index a93251c8d2d262..a14e12e63916ff 100644 --- a/pkgs/applications/audio/faust/faust2jackrust.nix +++ b/pkgs/applications/audio/faust/faust2jackrust.nix @@ -1,11 +1,12 @@ -{ faust -, libjack2 -, cargo -, binutils -, gcc -, gnumake -, openssl -, pkg-config +{ + faust, + libjack2, + cargo, + binutils, + gcc, + gnumake, + openssl, + pkg-config, }: @@ -13,5 +14,13 @@ faust.wrapWithBuildEnv { baseName = "faust2jackrust"; - propagatedBuildInputs = [ libjack2 cargo binutils gcc gnumake openssl pkg-config ]; + propagatedBuildInputs = [ + libjack2 + cargo + binutils + gcc + gnumake + openssl + pkg-config + ]; } diff --git a/pkgs/applications/audio/faust/faust2jaqt.nix b/pkgs/applications/audio/faust/faust2jaqt.nix index 90b6ca218dd426..2fe663431aac6a 100644 --- a/pkgs/applications/audio/faust/faust2jaqt.nix +++ b/pkgs/applications/audio/faust/faust2jaqt.nix @@ -1,11 +1,12 @@ -{ faust -, jack2 -, qtbase -, libsndfile -, alsa-lib -, writeText -, buildPackages -, which +{ + faust, + jack2, + qtbase, + libsndfile, + alsa-lib, + writeText, + buildPackages, + which, }: let # Wrap the binary coming out of the the compilation script, so it knows QT_PLUGIN_PATH @@ -39,7 +40,6 @@ faust.wrapWithBuildEnv { which ]; - dontWrapQtApps = true; preFixup = '' diff --git a/pkgs/applications/audio/faust/faust2ladspa.nix b/pkgs/applications/audio/faust/faust2ladspa.nix index 67de98cab9a20a..13545980b7ca98 100644 --- a/pkgs/applications/audio/faust/faust2ladspa.nix +++ b/pkgs/applications/audio/faust/faust2ladspa.nix @@ -1,12 +1,16 @@ -{ boost -, faust -, ladspaH +{ + boost, + faust, + ladspaH, }: faust.wrapWithBuildEnv { baseName = "faust2ladspa"; - propagatedBuildInputs = [ boost ladspaH ]; + propagatedBuildInputs = [ + boost + ladspaH + ]; } diff --git a/pkgs/applications/audio/faust/faust2lv2.nix b/pkgs/applications/audio/faust/faust2lv2.nix index b863ad25ebdb54..92c2e9df942353 100644 --- a/pkgs/applications/audio/faust/faust2lv2.nix +++ b/pkgs/applications/audio/faust/faust2lv2.nix @@ -1,14 +1,19 @@ -{ boost -, faust -, lv2 -, qtbase +{ + boost, + faust, + lv2, + qtbase, }: faust.wrapWithBuildEnv { baseName = "faust2lv2"; - propagatedBuildInputs = [ boost lv2 qtbase ]; + propagatedBuildInputs = [ + boost + lv2 + qtbase + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/audio/faust/faust2sc.nix b/pkgs/applications/audio/faust/faust2sc.nix index acdc54434dc688..52690b19d5c401 100644 --- a/pkgs/applications/audio/faust/faust2sc.nix +++ b/pkgs/applications/audio/faust/faust2sc.nix @@ -1,32 +1,42 @@ -{ faust -, baseName ? "faust2sc" -, supercollider -, makeWrapper -, python3 -, stdenv +{ + faust, + baseName ? "faust2sc", + supercollider, + makeWrapper, + python3, + stdenv, }@args: let - faustDefaults = faust.faust2ApplBase - (args // { + faustDefaults = faust.faust2ApplBase ( + args + // { baseName = "${baseName}.py"; - }); + } + ); in -stdenv.mkDerivation (faustDefaults // { +stdenv.mkDerivation ( + faustDefaults + // { - nativeBuildInputs = [ makeWrapper ]; + nativeBuildInputs = [ makeWrapper ]; - propagatedBuildInputs = [ python3 faust supercollider ]; + propagatedBuildInputs = [ + python3 + faust + supercollider + ]; - postInstall = '' - mv "$out/bin/${baseName}.py" "$out"/bin/${baseName} - ''; + postInstall = '' + mv "$out/bin/${baseName}.py" "$out"/bin/${baseName} + ''; - postFixup = '' - wrapProgram "$out"/bin/${baseName} \ - --append-flags "--import-dir ${faust}/share/faust" \ - --append-flags "--architecture-dir ${faust}/share/faust" \ - --append-flags "--architecture-dir ${faust}/include" \ - --append-flags "-p ${supercollider}" \ - --prefix PATH : "$PATH" - ''; -}) + postFixup = '' + wrapProgram "$out"/bin/${baseName} \ + --append-flags "--import-dir ${faust}/share/faust" \ + --append-flags "--architecture-dir ${faust}/share/faust" \ + --append-flags "--architecture-dir ${faust}/include" \ + --append-flags "-p ${supercollider}" \ + --prefix PATH : "$PATH" + ''; + } +) diff --git a/pkgs/applications/audio/faust/faustlive.nix b/pkgs/applications/audio/faust/faustlive.nix index 9051334cb2be1b..d7830565fcc801 100644 --- a/pkgs/applications/audio/faust/faustlive.nix +++ b/pkgs/applications/audio/faust/faustlive.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, which -, alsa-lib -, curl -, faust -, flac -, gnutls -, libjack2 -, libmicrohttpd -, libmpg123 -, libogg -, libopus -, libsndfile -, libtasn1 -, libvorbis -, libxcb -, llvm -, p11-kit -, qrencode -, qt5 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + which, + alsa-lib, + curl, + faust, + flac, + gnutls, + libjack2, + libmicrohttpd, + libmpg123, + libogg, + libopus, + libsndfile, + libtasn1, + libvorbis, + libxcb, + llvm, + p11-kit, + qrencode, + qt5, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/audio/flacon/default.nix b/pkgs/applications/audio/flacon/default.nix index 811e1d806c6077..ef460e7737ddac 100644 --- a/pkgs/applications/audio/flacon/default.nix +++ b/pkgs/applications/audio/flacon/default.nix @@ -1,6 +1,26 @@ -{ stdenv, lib, fetchFromGitHub, cmake, libuchardet, pkg-config, shntool, flac -, opusTools, vorbis-tools, mp3gain, lame, taglib, wavpack, vorbisgain -, monkeysAudio, sox, gtk3, qtbase, qttools, wrapQtAppsHook }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + libuchardet, + pkg-config, + shntool, + flac, + opusTools, + vorbis-tools, + mp3gain, + lame, + taglib, + wavpack, + vorbisgain, + monkeysAudio, + sox, + gtk3, + qtbase, + qttools, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "flacon"; @@ -13,8 +33,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-guIGSKmpinDDfTDSCmcJKWysUPdG/gw5oaKmXqgf53o="; }; - nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook ]; - buildInputs = [ qtbase qttools libuchardet taglib ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapQtAppsHook + ]; + buildInputs = [ + qtbase + qttools + libuchardet + taglib + ]; bin_path = lib.makeBinPath [ shntool @@ -36,8 +65,7 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = - "Extracts audio tracks from an audio CD image to separate tracks"; + description = "Extracts audio tracks from an audio CD image to separate tracks"; mainProgram = "flacon"; homepage = "https://flacon.github.io/"; license = licenses.lgpl21; diff --git a/pkgs/applications/audio/fmit/default.nix b/pkgs/applications/audio/fmit/default.nix index c22fe3ab0977ae..81ac1609c4af47 100644 --- a/pkgs/applications/audio/fmit/default.nix +++ b/pkgs/applications/audio/fmit/default.nix @@ -1,7 +1,20 @@ -{ lib, mkDerivation, fetchFromGitHub, fftw, qtbase, qtmultimedia, qmake, itstool, wrapQtAppsHook -, alsaSupport ? true, alsa-lib ? null -, jackSupport ? false, libjack2 ? null -, portaudioSupport ? false, portaudio ? null }: +{ + lib, + mkDerivation, + fetchFromGitHub, + fftw, + qtbase, + qtmultimedia, + qmake, + itstool, + wrapQtAppsHook, + alsaSupport ? true, + alsa-lib ? null, + jackSupport ? false, + libjack2 ? null, + portaudioSupport ? false, + portaudio ? null, +}: assert alsaSupport -> alsa-lib != null; assert jackSupport -> libjack2 != null; @@ -18,8 +31,17 @@ mkDerivation rec { sha256 = "1q062pfwz2vr9hbfn29fv54ip3jqfd9r99nhpr8w7mn1csy38azx"; }; - nativeBuildInputs = [ qmake itstool wrapQtAppsHook ]; - buildInputs = [ fftw qtbase qtmultimedia ] + nativeBuildInputs = [ + qmake + itstool + wrapQtAppsHook + ]; + buildInputs = + [ + fftw + qtbase + qtmultimedia + ] ++ lib.optionals alsaSupport [ alsa-lib ] ++ lib.optionals jackSupport [ libjack2 ] ++ lib.optionals portaudioSupport [ portaudio ]; diff --git a/pkgs/applications/audio/freqtweak/default.nix b/pkgs/applications/audio/freqtweak/default.nix index c880fdb113a0e2..0f51fac4e9feda 100644 --- a/pkgs/applications/audio/freqtweak/default.nix +++ b/pkgs/applications/audio/freqtweak/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, pkg-config, fftwFloat, libjack2, libsigcxx, libxml2, wxGTK }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + pkg-config, + fftwFloat, + libjack2, + libsigcxx, + libxml2, + wxGTK, +}: stdenv.mkDerivation rec { pname = "freqtweak"; @@ -11,8 +23,18 @@ stdenv.mkDerivation rec { sha256 = "10cq27mdgrrc54a40al9ahi0wqd0p2c1wxbdg518q8pzfxaxs5fi"; }; - nativeBuildInputs = [ autoconf automake pkg-config ]; - buildInputs = [ fftwFloat libjack2 libsigcxx libxml2 wxGTK ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + ]; + buildInputs = [ + fftwFloat + libjack2 + libsigcxx + libxml2 + wxGTK + ]; preConfigure = '' sh autogen.sh diff --git a/pkgs/applications/audio/goattracker/default.nix b/pkgs/applications/audio/goattracker/default.nix index 810b4185330c32..7580bf86dfb0f7 100644 --- a/pkgs/applications/audio/goattracker/default.nix +++ b/pkgs/applications/audio/goattracker/default.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchurl -, unzip -, copyDesktopItems -, makeDesktopItem -, imagemagick -, SDL -, isStereo ? false +{ + lib, + stdenv, + fetchurl, + unzip, + copyDesktopItems, + makeDesktopItem, + imagemagick, + SDL, + isStereo ? false, }: let @@ -14,29 +16,42 @@ let name = pname; desktopName = "GoatTracker 2" + lib.optionalString isStereo " Stereo"; genericName = "Music Tracker"; - exec = if isStereo - then "gt2stereo" - else "goattrk2"; + exec = if isStereo then "gt2stereo" else "goattrk2"; icon = "goattracker"; - categories = [ "AudioVideo" "AudioVideoEditing" ]; - keywords = [ "tracker" "music" ]; + categories = [ + "AudioVideo" + "AudioVideoEditing" + ]; + keywords = [ + "tracker" + "music" + ]; }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { inherit pname; - version = if isStereo - then "2.77" # stereo - else "2.76"; # normal + version = + if isStereo then + "2.77" # stereo + else + "2.76"; # normal src = fetchurl { url = "mirror://sourceforge/goattracker2/GoatTracker_${finalAttrs.version}${lib.optionalString isStereo "_Stereo"}.zip"; - sha256 = if isStereo - then "1hiig2d152sv9kazwz33i56x1c54h5sh21ipkqnp6qlnwj8x1ksy" # stereo - else "0d7a3han4jw4bwiba3j87racswaajgl3pj4sb5lawdqdxicv3dn1"; # normal + sha256 = + if isStereo then + "1hiig2d152sv9kazwz33i56x1c54h5sh21ipkqnp6qlnwj8x1ksy" # stereo + else + "0d7a3han4jw4bwiba3j87racswaajgl3pj4sb5lawdqdxicv3dn1"; # normal }; sourceRoot = "src"; - nativeBuildInputs = [ copyDesktopItems unzip imagemagick ]; + nativeBuildInputs = [ + copyDesktopItems + unzip + imagemagick + ]; buildInputs = [ SDL ]; # PREFIX gets treated as BINDIR. @@ -58,7 +73,9 @@ in stdenv.mkDerivation (finalAttrs: { convert goattrk2.bmp goattracker.png install -Dm644 goattracker.png $out/share/icons/hicolor/32x32/apps/goattracker.png - ${lib.optionalString (!isStereo) "install -Dm644 ../linux/goattracker.1 $out/share/man/man1/goattracker.1"} + ${lib.optionalString ( + !isStereo + ) "install -Dm644 ../linux/goattracker.1 $out/share/man/man1/goattracker.1"} runHook postInstall ''; @@ -66,7 +83,8 @@ in stdenv.mkDerivation (finalAttrs: { desktopItems = [ desktopItem ]; meta = { - description = "Crossplatform music editor for creating Commodore 64 music. Uses reSID library by Dag Lem and supports alternatively HardSID & CatWeasel devices" + description = + "Crossplatform music editor for creating Commodore 64 music. Uses reSID library by Dag Lem and supports alternatively HardSID & CatWeasel devices" + lib.optionalString isStereo " - Stereo version"; homepage = "https://cadaver.github.io/tools.html"; downloadPage = "https://sourceforge.net/projects/goattracker2/"; diff --git a/pkgs/applications/audio/greg/default.nix b/pkgs/applications/audio/greg/default.nix index 77ed401f6662df..cb1e046fbe4854 100644 --- a/pkgs/applications/audio/greg/default.nix +++ b/pkgs/applications/audio/greg/default.nix @@ -1,6 +1,11 @@ -{ lib, fetchFromGitHub, pythonPackages }: +{ + lib, + fetchFromGitHub, + pythonPackages, +}: -with pythonPackages; buildPythonApplication rec { +with pythonPackages; +buildPythonApplication rec { pname = "greg"; version = "0.4.8"; @@ -13,7 +18,10 @@ with pythonPackages; buildPythonApplication rec { sha256 = "sha256-o4+tXVJTgT52JyJOC+Glr2cvZjbTaZL8TIsmz+A4vE4="; }; - propagatedBuildInputs = [ setuptools feedparser ]; + propagatedBuildInputs = [ + setuptools + feedparser + ]; meta = with lib; { homepage = "https://github.com/manolomartinez/greg"; diff --git a/pkgs/applications/audio/guitarix/default.nix b/pkgs/applications/audio/guitarix/default.nix index 5b23b0e34a219d..e565605721a834 100644 --- a/pkgs/applications/audio/guitarix/default.nix +++ b/pkgs/applications/audio/guitarix/default.nix @@ -1,40 +1,41 @@ -{ lib -, stdenv -, fetchFromGitHub -, avahi -, bluez -, boost -, curl -, eigen -, faust -, fftw -, gettext -, glib -, glib-networking -, glibmm -, adwaita-icon-theme -, gsettings-desktop-schemas -, gtk3 -, gtkmm3 -, hicolor-icon-theme -, intltool -, ladspaH -, libjack2 -, libsndfile -, lilv -, lrdf -, lv2 -, pkg-config -, python3 -, sassc -, serd -, sord -, sratom -, wafHook -, wrapGAppsHook3 -, zita-convolver -, zita-resampler -, optimizationSupport ? false # Enable support for native CPU extensions +{ + lib, + stdenv, + fetchFromGitHub, + avahi, + bluez, + boost, + curl, + eigen, + faust, + fftw, + gettext, + glib, + glib-networking, + glibmm, + adwaita-icon-theme, + gsettings-desktop-schemas, + gtk3, + gtkmm3, + hicolor-icon-theme, + intltool, + ladspaH, + libjack2, + libsndfile, + lilv, + lrdf, + lv2, + pkg-config, + python3, + sassc, + serd, + sord, + sratom, + wafHook, + wrapGAppsHook3, + zita-convolver, + zita-resampler, + optimizationSupport ? false, # Enable support for native CPU extensions }: let @@ -131,7 +132,10 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://github.com/brummer10/guitarix"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ astsmtl lord-valen ]; + maintainers = with maintainers; [ + astsmtl + lord-valen + ]; platforms = platforms.linux; }; }) diff --git a/pkgs/applications/audio/hqplayer-desktop/default.nix b/pkgs/applications/audio/hqplayer-desktop/default.nix index 8f097ff2359010..8dd61ab808f41b 100644 --- a/pkgs/applications/audio/hqplayer-desktop/default.nix +++ b/pkgs/applications/audio/hqplayer-desktop/default.nix @@ -1,23 +1,24 @@ -{ stdenv -, alsa-lib -, autoPatchelfHook -, dpkg -, evince -, fetchurl -, flac -, lib -, libmicrohttpd -, libogg -, libusb-compat-0_1 -, llvmPackages -, mpfr -, qtcharts -, qtdeclarative -, qtwayland -, qtwebengine -, qtwebview -, wavpack -, wrapQtAppsHook +{ + stdenv, + alsa-lib, + autoPatchelfHook, + dpkg, + evince, + fetchurl, + flac, + lib, + libmicrohttpd, + libogg, + libusb-compat-0_1, + llvmPackages, + mpfr, + qtcharts, + qtdeclarative, + qtwayland, + qtwebengine, + qtwebview, + wavpack, + wrapQtAppsHook, }: let @@ -37,7 +38,8 @@ stdenv.mkDerivation { pname = "hqplayer-desktop"; inherit version; - src = srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); nativeBuildInputs = [ autoPatchelfHook @@ -90,7 +92,10 @@ stdenv.mkDerivation { ''; # doc has dependencies on evince that is not required by main app - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; postInstall = '' for desktopFile in $out/share/applications/hqplayer5{client,desktop}.desktop; do diff --git a/pkgs/applications/audio/hushboard/default.nix b/pkgs/applications/audio/hushboard/default.nix index dbc0a467024cb9..e5953a922e8e08 100644 --- a/pkgs/applications/audio/hushboard/default.nix +++ b/pkgs/applications/audio/hushboard/default.nix @@ -1,16 +1,17 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, gobject-introspection -, gtk3 -, libappindicator -, libpulseaudio -, librsvg -, pycairo -, pygobject3 -, six -, wrapGAppsHook3 -, xlib +{ + lib, + buildPythonApplication, + fetchFromGitHub, + gobject-introspection, + gtk3, + libappindicator, + libpulseaudio, + librsvg, + pycairo, + pygobject3, + six, + wrapGAppsHook3, + xlib, }: buildPythonApplication { diff --git a/pkgs/applications/audio/iannix/default.nix b/pkgs/applications/audio/iannix/default.nix index f55fcdfd3601c8..753a58d0c42a0b 100644 --- a/pkgs/applications/audio/iannix/default.nix +++ b/pkgs/applications/audio/iannix/default.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, fetchFromGitHub, alsa-lib, pkg-config, qtbase, qtscript, qmake +{ + mkDerivation, + lib, + fetchFromGitHub, + alsa-lib, + pkg-config, + qtbase, + qtscript, + qmake, }: mkDerivation rec { @@ -12,8 +20,15 @@ mkDerivation rec { sha256 = "AhoP+Ok78Vk8Aee/RP572hJeM8O7v2ZTvFalOZZqRy8="; }; - nativeBuildInputs = [ pkg-config qmake ]; - buildInputs = [ alsa-lib qtbase qtscript ]; + nativeBuildInputs = [ + pkg-config + qmake + ]; + buildInputs = [ + alsa-lib + qtbase + qtscript + ]; qmakeFlags = [ "PREFIX=/" ]; diff --git a/pkgs/applications/audio/in-formant/default.nix b/pkgs/applications/audio/in-formant/default.nix index 1f33323736cefb..7266470cc9e917 100644 --- a/pkgs/applications/audio/in-formant/default.nix +++ b/pkgs/applications/audio/in-formant/default.nix @@ -1,21 +1,22 @@ -{ stdenv -, cmake -, lib -, fetchFromGitHub -, wrapQtAppsHook -, qtbase -, qtcharts -, fftw -, libtorch-bin -, portaudio -, eigen -, xorg -, pkg-config -, autoPatchelfHook -, soxr -, libsamplerate -, armadillo -, tomlplusplus +{ + stdenv, + cmake, + lib, + fetchFromGitHub, + wrapQtAppsHook, + qtbase, + qtcharts, + fftw, + libtorch-bin, + portaudio, + eigen, + xorg, + pkg-config, + autoPatchelfHook, + soxr, + libsamplerate, + armadillo, + tomlplusplus, }: stdenv.mkDerivation rec { @@ -36,7 +37,12 @@ stdenv.mkDerivation rec { ./0001-Avoid-using-vendored-dependencies-we-have-in-nixpkgs.patch ]; - nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook autoPatchelfHook ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapQtAppsHook + autoPatchelfHook + ]; buildInputs = [ qtbase diff --git a/pkgs/applications/audio/ir.lv2/default.nix b/pkgs/applications/audio/ir.lv2/default.nix index d1984170e3acc6..9414019d956cc4 100644 --- a/pkgs/applications/audio/ir.lv2/default.nix +++ b/pkgs/applications/audio/ir.lv2/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchgit, fftw, gtk2, lv2, libsamplerate, libsndfile, pkg-config, zita-convolver }: +{ + lib, + stdenv, + fetchgit, + fftw, + gtk2, + lv2, + libsamplerate, + libsndfile, + pkg-config, + zita-convolver, +}: stdenv.mkDerivation rec { pname = "ir.lv2"; @@ -10,9 +21,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-5toZYQX2oIAfQ5XPMMN+HGNE4FOE/t6mciih/OpU1dw="; }; - buildInputs = [ fftw gtk2 lv2 libsamplerate libsndfile zita-convolver ]; + buildInputs = [ + fftw + gtk2 + lv2 + libsamplerate + libsndfile + zita-convolver + ]; - nativeBuildInputs = [ pkg-config ]; + nativeBuildInputs = [ pkg-config ]; env.NIX_CFLAGS_COMPILE = "-fpermissive"; diff --git a/pkgs/applications/audio/jack-autoconnect/default.nix b/pkgs/applications/audio/jack-autoconnect/default.nix index d4fd50ca4f6d3a..51600ed031f456 100644 --- a/pkgs/applications/audio/jack-autoconnect/default.nix +++ b/pkgs/applications/audio/jack-autoconnect/default.nix @@ -1,4 +1,12 @@ -{ lib, mkDerivation, fetchFromGitHub, pkg-config, qmake, qtbase, libjack2 }: +{ + lib, + mkDerivation, + fetchFromGitHub, + pkg-config, + qmake, + qtbase, + libjack2, +}: mkDerivation rec { pname = "jack_autoconnect"; @@ -12,8 +20,14 @@ mkDerivation rec { sha256 = "sha256-imvNc498Q2W9RKmiOoNepSoJzIv2tGvFG6hx+seiifw="; }; - buildInputs = [ qtbase libjack2 ]; - nativeBuildInputs = [ pkg-config qmake ]; + buildInputs = [ + qtbase + libjack2 + ]; + nativeBuildInputs = [ + pkg-config + qmake + ]; installPhase = '' mkdir -p -- "$out/bin" @@ -22,8 +36,7 @@ mkDerivation rec { meta = with lib; { homepage = "https://github.com/kripton/jack_autoconnect"; - description = - "Tiny application that reacts on port registrations by clients and connects them"; + description = "Tiny application that reacts on port registrations by clients and connects them"; mainProgram = "jack_autoconnect"; maintainers = with maintainers; [ unclechu ]; license = licenses.gpl2Only; diff --git a/pkgs/applications/audio/jackmix/default.nix b/pkgs/applications/audio/jackmix/default.nix index 86c8a91862e77a..d4a0bf6064a44d 100644 --- a/pkgs/applications/audio/jackmix/default.nix +++ b/pkgs/applications/audio/jackmix/default.nix @@ -1,5 +1,15 @@ -{ mkDerivation, lib, fetchFromGitHub, pkg-config, scons, qtbase, lash, libjack2, jack ? libjack2, alsa-lib -, fetchpatch +{ + mkDerivation, + lib, + fetchFromGitHub, + pkg-config, + scons, + qtbase, + lash, + libjack2, + jack ? libjack2, + alsa-lib, + fetchpatch, }: mkDerivation rec { @@ -22,7 +32,10 @@ mkDerivation rec { }) ]; - nativeBuildInputs = [ scons pkg-config ]; + nativeBuildInputs = [ + scons + pkg-config + ]; buildInputs = [ qtbase lash diff --git a/pkgs/applications/audio/jamesdsp/default.nix b/pkgs/applications/audio/jamesdsp/default.nix index 20c40d5d9d9b4a..6dd5c4bba8ba7a 100644 --- a/pkgs/applications/audio/jamesdsp/default.nix +++ b/pkgs/applications/audio/jamesdsp/default.nix @@ -1,24 +1,27 @@ -{ copyDesktopItems -, fetchFromGitHub -, glibmm -, gst_all_1 -, lib -, libarchive -, makeDesktopItem -, pipewire -, pkg-config -, pulseaudio -, qmake -, qtbase -, qtsvg -, qtwayland -, stdenv -, usePipewire ? true -, usePulseaudio ? false -, wrapQtAppsHook +{ + copyDesktopItems, + fetchFromGitHub, + glibmm, + gst_all_1, + lib, + libarchive, + makeDesktopItem, + pipewire, + pkg-config, + pulseaudio, + qmake, + qtbase, + qtsvg, + qtwayland, + stdenv, + usePipewire ? true, + usePulseaudio ? false, + wrapQtAppsHook, }: -assert lib.asserts.assertMsg (usePipewire != usePulseaudio) "You need to enable one and only one of pulseaudio or pipewire support"; +assert lib.asserts.assertMsg ( + usePipewire != usePulseaudio +) "You need to enable one and only one of pulseaudio or pipewire support"; stdenv.mkDerivation (finalAttrs: { pname = "jamesdsp"; @@ -39,20 +42,23 @@ stdenv.mkDerivation (finalAttrs: { wrapQtAppsHook ]; - buildInputs = [ - glibmm - libarchive - qtbase - qtsvg - qtwayland - ] ++ lib.optionals usePipewire [ - pipewire - ] ++ lib.optionals usePulseaudio [ - pulseaudio - gst_all_1.gst-plugins-base - gst_all_1.gst-plugins-good - gst_all_1.gstreamer - ]; + buildInputs = + [ + glibmm + libarchive + qtbase + qtsvg + qtwayland + ] + ++ lib.optionals usePipewire [ + pipewire + ] + ++ lib.optionals usePulseaudio [ + pulseaudio + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-good + gst_all_1.gstreamer + ]; preFixup = lib.optionalString usePulseaudio '' qtWrapperArgs+=(--prefix GST_PLUGIN_SYSTEM_PATH_1_0 : "$GST_PLUGIN_SYSTEM_PATH_1_0") @@ -68,9 +74,16 @@ stdenv.mkDerivation (finalAttrs: { exec = "jamesdsp"; icon = "jamesdsp"; comment = "JamesDSP for Linux"; - categories = [ "AudioVideo" "Audio" ]; + categories = [ + "AudioVideo" + "Audio" + ]; startupNotify = false; - keywords = [ "equalizer" "audio" "effect" ]; + keywords = [ + "equalizer" + "audio" + "effect" + ]; }) ]; @@ -85,7 +98,10 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "jamesdsp"; homepage = "https://github.com/Audio4Linux/JDSP4Linux"; license = lib.licenses.gpl3Only; - maintainers = with lib.maintainers; [ pasqui23 rewine ]; + maintainers = with lib.maintainers; [ + pasqui23 + rewine + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/applications/audio/kmetronome/default.nix b/pkgs/applications/audio/kmetronome/default.nix index 9fd74e930a0289..a7de91b61e5ed8 100644 --- a/pkgs/applications/audio/kmetronome/default.nix +++ b/pkgs/applications/audio/kmetronome/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, cmake, pandoc, pkg-config, qttools, alsa-lib, drumstick, qtbase, qtsvg }: +{ + lib, + stdenv, + fetchurl, + cmake, + pandoc, + pkg-config, + qttools, + alsa-lib, + drumstick, + qtbase, + qtsvg, +}: stdenv.mkDerivation rec { pname = "kmetronome"; @@ -9,9 +21,19 @@ stdenv.mkDerivation rec { hash = "sha256-51uFAPR0xsY3z9rFc8SdSGu4ae/VzUmC1qC8RGdt48Y="; }; - nativeBuildInputs = [ cmake pandoc pkg-config qttools ]; + nativeBuildInputs = [ + cmake + pandoc + pkg-config + qttools + ]; - buildInputs = [ alsa-lib drumstick qtbase qtsvg ]; + buildInputs = [ + alsa-lib + drumstick + qtbase + qtsvg + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/audio/ladspa-plugins/default.nix b/pkgs/applications/audio/ladspa-plugins/default.nix index d7e7dd7b69477f..3544d18878d037 100644 --- a/pkgs/applications/audio/ladspa-plugins/default.nix +++ b/pkgs/applications/audio/ladspa-plugins/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, automake -, fftw -, ladspaH -, libxml2 -, pkg-config -, perlPackages +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + automake, + fftw, + ladspaH, + libxml2, + pkg-config, + perlPackages, }: stdenv.mkDerivation rec { @@ -21,8 +22,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-eOtIhNcuItREUShI8JRlBVKfMfovpdfIYu+m37v4KLE="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ fftw ladspaH libxml2 perlPackages.perl perlPackages.XMLParser ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + fftw + ladspaH + libxml2 + perlPackages.perl + perlPackages.XMLParser + ]; patchPhase = '' patchShebangs . diff --git a/pkgs/applications/audio/ladspa-sdk/default.nix b/pkgs/applications/audio/ladspa-sdk/default.nix index de0f07b64fddbc..0103db6a7422be 100644 --- a/pkgs/applications/audio/ladspa-sdk/default.nix +++ b/pkgs/applications/audio/ladspa-sdk/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ladspa-sdk"; diff --git a/pkgs/applications/audio/ladspa-sdk/ladspah.nix b/pkgs/applications/audio/ladspa-sdk/ladspah.nix index b497e91927b06f..fae714eb19ae3a 100644 --- a/pkgs/applications/audio/ladspa-sdk/ladspah.nix +++ b/pkgs/applications/audio/ladspa-sdk/ladspah.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ladspa.h"; version = "1.15"; diff --git a/pkgs/applications/audio/librespot/default.nix b/pkgs/applications/audio/librespot/default.nix index f598a4d21ff854..bbc55b41de22eb 100644 --- a/pkgs/applications/audio/librespot/default.nix +++ b/pkgs/applications/audio/librespot/default.nix @@ -1,18 +1,19 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, makeWrapper -, pkg-config -, stdenv -, openssl -, withALSA ? stdenv.hostPlatform.isLinux -, alsa-lib -, alsa-plugins -, withPortAudio ? false -, portaudio -, withPulseAudio ? false -, libpulseaudio -, withRodio ? true +{ + lib, + rustPlatform, + fetchFromGitHub, + makeWrapper, + pkg-config, + stdenv, + openssl, + withALSA ? stdenv.hostPlatform.isLinux, + alsa-lib, + alsa-plugins, + withPortAudio ? false, + portaudio, + withPulseAudio ? false, + libpulseaudio, + withRodio ? true, }: rustPlatform.buildRustPackage rec { @@ -28,17 +29,24 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-GScAUqALoocqvsHz4XgPytI8cl0hiuWjqaO/ItNo4v4="; - nativeBuildInputs = [ pkg-config makeWrapper ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - rustPlatform.bindgenHook - ]; + nativeBuildInputs = + [ + pkg-config + makeWrapper + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + rustPlatform.bindgenHook + ]; - buildInputs = [ openssl ] + buildInputs = + [ openssl ] ++ lib.optional withALSA alsa-lib ++ lib.optional withPortAudio portaudio ++ lib.optional withPulseAudio libpulseaudio; buildNoDefaultFeatures = true; - buildFeatures = lib.optional withRodio "rodio-backend" + buildFeatures = + lib.optional withRodio "rodio-backend" ++ lib.optional withALSA "alsa-backend" ++ lib.optional withPortAudio "portaudio-backend" ++ lib.optional withPulseAudio "pulseaudio-backend"; diff --git a/pkgs/applications/audio/linvstmanager/default.nix b/pkgs/applications/audio/linvstmanager/default.nix index 8df3fd507adc3a..1da68ebb45d1d7 100644 --- a/pkgs/applications/audio/linvstmanager/default.nix +++ b/pkgs/applications/audio/linvstmanager/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qtbase -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtbase, + wrapQtAppsHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/audio/listenbrainz-mpd/default.nix b/pkgs/applications/audio/listenbrainz-mpd/default.nix index 900839081e7179..9b3683a9f0919e 100644 --- a/pkgs/applications/audio/listenbrainz-mpd/default.nix +++ b/pkgs/applications/audio/listenbrainz-mpd/default.nix @@ -1,16 +1,18 @@ -{ lib -, rustPlatform -, fetchFromGitea -, pkg-config -, stdenv -, openssl -, libiconv -, sqlite -, Security -, SystemConfiguration -, CoreFoundation -, installShellFiles -, asciidoctor }: +{ + lib, + rustPlatform, + fetchFromGitea, + pkg-config, + stdenv, + openssl, + libiconv, + sqlite, + Security, + SystemConfiguration, + CoreFoundation, + installShellFiles, + asciidoctor, +}: rustPlatform.buildRustPackage rec { pname = "listenbrainz-mpd"; @@ -26,22 +28,35 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-jnDS9tIJ387A2P9oUSYB3tXrXjwwVmQ26erIIlHBkao="; - nativeBuildInputs = [ pkg-config installShellFiles asciidoctor ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + asciidoctor + ]; - buildInputs = [ sqlite ] ++ (if stdenv.hostPlatform.isDarwin then [ - libiconv - Security - SystemConfiguration - CoreFoundation - ] else [ - openssl - ]); + buildInputs = + [ sqlite ] + ++ ( + if stdenv.hostPlatform.isDarwin then + [ + libiconv + Security + SystemConfiguration + CoreFoundation + ] + else + [ + openssl + ] + ); - buildFeatures = [ - "shell_completion" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "systemd" - ]; + buildFeatures = + [ + "shell_completion" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "systemd" + ]; postInstall = '' installShellCompletion \ diff --git a/pkgs/applications/audio/lmms/default.nix b/pkgs/applications/audio/lmms/default.nix index e1e338698f4331..d4c45a283603cf 100644 --- a/pkgs/applications/audio/lmms/default.nix +++ b/pkgs/applications/audio/lmms/default.nix @@ -1,7 +1,29 @@ -{ lib, fetchFromGitHub, fetchpatch, cmake, pkg-config, alsa-lib ? null, carla ? null, fftwFloat, fltk13 -, fluidsynth ? null, lame ? null, libgig ? null, libjack2 ? null, libpulseaudio ? null -, libsamplerate, libsoundio ? null, libsndfile, libvorbis ? null, portaudio ? null -, qtbase, qtx11extras, qttools, SDL ? null, mkDerivation }: +{ + lib, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + alsa-lib ? null, + carla ? null, + fftwFloat, + fltk13, + fluidsynth ? null, + lame ? null, + libgig ? null, + libjack2 ? null, + libpulseaudio ? null, + libsamplerate, + libsoundio ? null, + libsndfile, + libvorbis ? null, + portaudio ? null, + qtbase, + qtx11extras, + qttools, + SDL ? null, + mkDerivation, +}: mkDerivation rec { pname = "lmms"; @@ -15,7 +37,11 @@ mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake qttools pkg-config ]; + nativeBuildInputs = [ + cmake + qttools + pkg-config + ]; buildInputs = [ carla @@ -51,7 +77,10 @@ mkDerivation rec { mainProgram = "lmms"; homepage = "https://lmms.io"; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ ]; }; } diff --git a/pkgs/applications/audio/lpd8editor/default.nix b/pkgs/applications/audio/lpd8editor/default.nix index 4c48ca18ad37f1..6592f68fa98aa7 100644 --- a/pkgs/applications/audio/lpd8editor/default.nix +++ b/pkgs/applications/audio/lpd8editor/default.nix @@ -1,11 +1,12 @@ -{ lib -, qt5 -, stdenv -, git -, fetchFromGitHub -, cmake -, alsa-lib -, qttools +{ + lib, + qt5, + stdenv, + git, + fetchFromGitHub, + cmake, + alsa-lib, + qttools, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/audio/lsp-plugins/default.nix b/pkgs/applications/audio/lsp-plugins/default.nix index ae768da7a0128c..89cbd99851d8a0 100644 --- a/pkgs/applications/audio/lsp-plugins/default.nix +++ b/pkgs/applications/audio/lsp-plugins/default.nix @@ -1,7 +1,19 @@ -{ lib, stdenv, fetchurl, pkg-config, makeWrapper -, libsndfile, jack2 -, libGLU, libGL, lv2, cairo -, ladspaH, php, libXrandr }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + makeWrapper, + libsndfile, + jack2, + libGLU, + libGL, + lv2, + cairo, + ladspaH, + php, + libXrandr, +}: stdenv.mkDerivation rec { pname = "lsp-plugins"; @@ -12,10 +24,27 @@ stdenv.mkDerivation rec { sha256 = "sha256-w2BUIF44z78syLroQk2asVXA5bt9P9POiuwxpnlkc8o="; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; - nativeBuildInputs = [ pkg-config (php.withExtensions (_: [])) makeWrapper ]; - buildInputs = [ jack2 libsndfile libGLU libGL lv2 cairo ladspaH libXrandr ]; + nativeBuildInputs = [ + pkg-config + (php.withExtensions (_: [ ])) + makeWrapper + ]; + buildInputs = [ + jack2 + libsndfile + libGLU + libGL + lv2 + cairo + ladspaH + libXrandr + ]; makeFlags = [ "PREFIX=${placeholder "out"}" @@ -33,69 +62,72 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - meta = with lib; - { description = "Collection of open-source audio plugins"; - longDescription = '' - Compatible with the following formats: + meta = with lib; { + description = "Collection of open-source audio plugins"; + longDescription = '' + Compatible with the following formats: - - CLAP - set of plugins for Clever Audio Plugins API - - LADSPA - set of plugins for Linux Audio Developer's Simple Plugin API - - LV2 - set of plugins and UIs for Linux Audio Developer's Simple Plugin API (LADSPA) version 2 - - LinuxVST - set of plugins and UIs for Steinberg's VST 2.4 format ported on GNU/Linux Platform - - JACK - Standalone versions for JACK Audio connection Kit with UI + - CLAP - set of plugins for Clever Audio Plugins API + - LADSPA - set of plugins for Linux Audio Developer's Simple Plugin API + - LV2 - set of plugins and UIs for Linux Audio Developer's Simple Plugin API (LADSPA) version 2 + - LinuxVST - set of plugins and UIs for Steinberg's VST 2.4 format ported on GNU/Linux Platform + - JACK - Standalone versions for JACK Audio connection Kit with UI - Contains the following plugins (https://lsp-plug.in/?page=plugins) + Contains the following plugins (https://lsp-plug.in/?page=plugins) - Equalizers: - - Fliter - - Graphic Equalizer - - Parametric Equalizer - Dynamic Processing: - - Compressor - - Dynamic Processor - - Expander - - Gate - - Limiter - Multiband Dynamic Processing: - - GOTT Compressor - - Multiband Compressor - - Multiband Dynamics Processor - - Multiband Expander - - Multiband Gate - - Multiband Limiter - Convolution / Reverb processing: - - Impulse Responses - - Impulse Reverb - - Room Builder - Delay Effects: - - Artistic Delay - - Compensation Delay - - Slap-back Delay - Analyzers: - - Oscilloscope - - Phase Detector - - Spectrum Analyzer - Multiband Processing: - - Crossover - Samplers: - - Multisampler - - Sampler - Generators / Oscillators: - - Noise Generator - - Oscillator - Utilitary Plugins: - - A/B Test Plugin - - Flanger - - Latency Meter - - Loudness Compensator - - Mixer - - Profiler - - Surge Filter - - Trigger - ''; - homepage = "https://lsp-plug.in"; - maintainers = with maintainers; [ magnetophon PowerUser64 ]; - license = licenses.gpl2; - platforms = platforms.linux; - }; + Equalizers: + - Fliter + - Graphic Equalizer + - Parametric Equalizer + Dynamic Processing: + - Compressor + - Dynamic Processor + - Expander + - Gate + - Limiter + Multiband Dynamic Processing: + - GOTT Compressor + - Multiband Compressor + - Multiband Dynamics Processor + - Multiband Expander + - Multiband Gate + - Multiband Limiter + Convolution / Reverb processing: + - Impulse Responses + - Impulse Reverb + - Room Builder + Delay Effects: + - Artistic Delay + - Compensation Delay + - Slap-back Delay + Analyzers: + - Oscilloscope + - Phase Detector + - Spectrum Analyzer + Multiband Processing: + - Crossover + Samplers: + - Multisampler + - Sampler + Generators / Oscillators: + - Noise Generator + - Oscillator + Utilitary Plugins: + - A/B Test Plugin + - Flanger + - Latency Meter + - Loudness Compensator + - Mixer + - Profiler + - Surge Filter + - Trigger + ''; + homepage = "https://lsp-plug.in"; + maintainers = with maintainers; [ + magnetophon + PowerUser64 + ]; + license = licenses.gpl2; + platforms = platforms.linux; + }; } diff --git a/pkgs/applications/audio/lv2lint/default.nix b/pkgs/applications/audio/lv2lint/default.nix index 85d3733905623d..c35e277675375f 100644 --- a/pkgs/applications/audio/lv2lint/default.nix +++ b/pkgs/applications/audio/lv2lint/default.nix @@ -1,4 +1,16 @@ -{ stdenv, lib, fetchFromSourcehut, pkg-config, meson, ninja, lv2, lilv, curl, elfutils, xorg }: +{ + stdenv, + lib, + fetchFromSourcehut, + pkg-config, + meson, + ninja, + lv2, + lilv, + curl, + elfutils, + xorg, +}: stdenv.mkDerivation (finalAttrs: { pname = "lv2lint"; @@ -12,9 +24,19 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-NkzbKteLZ+P+Py+CMOYYipvu6psDslWnM1MAV1XB0TM="; }; - nativeBuildInputs = [ pkg-config meson ninja ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + ]; - buildInputs = [ lv2 lilv curl elfutils xorg.libX11 ]; + buildInputs = [ + lv2 + lilv + curl + elfutils + xorg.libX11 + ]; mesonFlags = [ (lib.mesonEnable "online-tests" true) diff --git a/pkgs/applications/audio/magnetophonDSP/CharacterCompressor/default.nix b/pkgs/applications/audio/magnetophonDSP/CharacterCompressor/default.nix index 09e87abec0ea35..6de1768401157d 100644 --- a/pkgs/applications/audio/magnetophonDSP/CharacterCompressor/default.nix +++ b/pkgs/applications/audio/magnetophonDSP/CharacterCompressor/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, faust2jaqt, faust2lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + faust2jaqt, + faust2lv2, +}: stdenv.mkDerivation rec { pname = "CharacterCompressor"; version = "0.3.3"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "1h0bhjhx023476gbijq842b6f8z71zcyn4c9mddwyb18w9cdamp5"; }; - buildInputs = [ faust2jaqt faust2lv2 ]; + buildInputs = [ + faust2jaqt + faust2lv2 + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/audio/magnetophonDSP/CompBus/default.nix b/pkgs/applications/audio/magnetophonDSP/CompBus/default.nix index ce90f0f5f1641c..528c972a9829e4 100644 --- a/pkgs/applications/audio/magnetophonDSP/CompBus/default.nix +++ b/pkgs/applications/audio/magnetophonDSP/CompBus/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, faust2jaqt, faust2lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + faust2jaqt, + faust2lv2, +}: stdenv.mkDerivation rec { pname = "CompBus"; version = "1.1.1"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "0yhj680zgk4dn4fi8j3apm72f3z2mjk12amf2a7p0lwn9iyh4a2z"; }; - buildInputs = [ faust2jaqt faust2lv2 ]; + buildInputs = [ + faust2jaqt + faust2lv2 + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/audio/magnetophonDSP/ConstantDetuneChorus/default.nix b/pkgs/applications/audio/magnetophonDSP/ConstantDetuneChorus/default.nix index 98fae67d71c52b..b10cb501e12e1f 100644 --- a/pkgs/applications/audio/magnetophonDSP/ConstantDetuneChorus/default.nix +++ b/pkgs/applications/audio/magnetophonDSP/ConstantDetuneChorus/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, faust2jaqt, faust2lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + faust2jaqt, + faust2lv2, +}: stdenv.mkDerivation rec { pname = "constant-detune-chorus"; version = "0.1.3"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "1sipmc25fr7w7xqx1r0y6i2zwfkgszzwvhk1v15mnsb3cqvk8ybn"; }; - buildInputs = [ faust2jaqt faust2lv2 ]; + buildInputs = [ + faust2jaqt + faust2lv2 + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/audio/magnetophonDSP/LazyLimiter/default.nix b/pkgs/applications/audio/magnetophonDSP/LazyLimiter/default.nix index 66f66d2e24483d..cc968b5226cc7c 100644 --- a/pkgs/applications/audio/magnetophonDSP/LazyLimiter/default.nix +++ b/pkgs/applications/audio/magnetophonDSP/LazyLimiter/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, faust2jaqt, faust2lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + faust2jaqt, + faust2lv2, +}: stdenv.mkDerivation rec { pname = "LazyLimiter"; version = "0.3.2"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "10xdydwmsnkx8hzsm74pa546yahp29wifydbc48yywv3sfj5anm7"; }; - buildInputs = [ faust2jaqt faust2lv2 ]; + buildInputs = [ + faust2jaqt + faust2lv2 + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/audio/magnetophonDSP/MBdistortion/default.nix b/pkgs/applications/audio/magnetophonDSP/MBdistortion/default.nix index e8798424cc12f8..3dfea346b60a3c 100644 --- a/pkgs/applications/audio/magnetophonDSP/MBdistortion/default.nix +++ b/pkgs/applications/audio/magnetophonDSP/MBdistortion/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, faust2jaqt, faust2lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + faust2jaqt, + faust2lv2, +}: stdenv.mkDerivation rec { pname = "MBdistortion"; version = "1.1.1"; @@ -17,7 +24,10 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ faust2jaqt faust2lv2 ]; + buildInputs = [ + faust2jaqt + faust2lv2 + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/audio/magnetophonDSP/RhythmDelay/default.nix b/pkgs/applications/audio/magnetophonDSP/RhythmDelay/default.nix index fb55af1dcebd79..ab7e651fc691af 100644 --- a/pkgs/applications/audio/magnetophonDSP/RhythmDelay/default.nix +++ b/pkgs/applications/audio/magnetophonDSP/RhythmDelay/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, faust2jaqt, faust2lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + faust2jaqt, + faust2lv2, +}: stdenv.mkDerivation rec { pname = "RhythmDelay"; version = "2.1"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "1j0bjl9agz43dcrcrbiqd7fv7xsxgd65s4ahhv5pvcr729y0fxg4"; }; - buildInputs = [ faust2jaqt faust2lv2 ]; + buildInputs = [ + faust2jaqt + faust2lv2 + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/audio/magnetophonDSP/VoiceOfFaust/default.nix b/pkgs/applications/audio/magnetophonDSP/VoiceOfFaust/default.nix index f85df83401e084..983e3924f815fd 100644 --- a/pkgs/applications/audio/magnetophonDSP/VoiceOfFaust/default.nix +++ b/pkgs/applications/audio/magnetophonDSP/VoiceOfFaust/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, faust2jack, faust2lv2, helmholtz, mrpeach, puredata-with-plugins, jack-example-tools }: +{ + lib, + stdenv, + fetchFromGitHub, + faust2jack, + faust2lv2, + helmholtz, + mrpeach, + puredata-with-plugins, + jack-example-tools, +}: stdenv.mkDerivation rec { pname = "VoiceOfFaust"; version = "1.1.5"; @@ -10,11 +20,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-vB8+ymvNuuovFXwOJ3BTIj5mGzCGa1+yhYs4nWMYIxU="; }; - plugins = [ helmholtz mrpeach ]; + plugins = [ + helmholtz + mrpeach + ]; pitchTracker = puredata-with-plugins plugins; - buildInputs = [ faust2jack faust2lv2 ]; + buildInputs = [ + faust2jack + faust2lv2 + ]; enableParallelBuilding = true; diff --git a/pkgs/applications/audio/magnetophonDSP/faustCompressors/default.nix b/pkgs/applications/audio/magnetophonDSP/faustCompressors/default.nix index 0caba36177438e..beb40dcbfecec0 100644 --- a/pkgs/applications/audio/magnetophonDSP/faustCompressors/default.nix +++ b/pkgs/applications/audio/magnetophonDSP/faustCompressors/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, faust2jaqt, faust2lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + faust2jaqt, + faust2lv2, +}: stdenv.mkDerivation rec { pname = "faustCompressors"; version = "1.2"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "144f6g17q4m50kxzdncsfzdyycdfprnpwdaxcwgxj4jky1xsha1d"; }; - buildInputs = [ faust2jaqt faust2lv2 ]; + buildInputs = [ + faust2jaqt + faust2lv2 + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/audio/magnetophonDSP/pluginUtils/default.nix b/pkgs/applications/audio/magnetophonDSP/pluginUtils/default.nix index 5230ed327e23a0..7c81a87cfe9fa4 100644 --- a/pkgs/applications/audio/magnetophonDSP/pluginUtils/default.nix +++ b/pkgs/applications/audio/magnetophonDSP/pluginUtils/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, faust2jaqt, faust2lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + faust2jaqt, + faust2lv2, +}: stdenv.mkDerivation rec { pname = "pluginUtils"; version = "1.1"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "1hnr5sp7k6ypf4ks61lnyqx44dkv35yllf3a3xcbrw7yqzagwr1c"; }; - buildInputs = [ faust2jaqt faust2lv2 ]; + buildInputs = [ + faust2jaqt + faust2lv2 + ]; dontWrapQtApps = true; @@ -33,7 +42,7 @@ stdenv.mkDerivation rec { for f in $(find . -executable -type f); do cp $f $out/bin/ done - ''; + ''; meta = { description = "Some simple utility lv2 plugins"; diff --git a/pkgs/applications/audio/magnetophonDSP/shelfMultiBand/default.nix b/pkgs/applications/audio/magnetophonDSP/shelfMultiBand/default.nix index 42163d9879b8b0..70020efe098072 100644 --- a/pkgs/applications/audio/magnetophonDSP/shelfMultiBand/default.nix +++ b/pkgs/applications/audio/magnetophonDSP/shelfMultiBand/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, faust2jaqt, faust2lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + faust2jaqt, + faust2lv2, +}: stdenv.mkDerivation rec { pname = "shelfMultiBand"; version = "0.6.1"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "1b1h4z5fs2xm7wvw11p9wnd0bxs3m88124f5phh0gwvpsdrd0im5"; }; - buildInputs = [ faust2jaqt faust2lv2 ]; + buildInputs = [ + faust2jaqt + faust2lv2 + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/audio/master_me/default.nix b/pkgs/applications/audio/master_me/default.nix index 4d8a35588e7e6b..3c766b701cf9b8 100644 --- a/pkgs/applications/audio/master_me/default.nix +++ b/pkgs/applications/audio/master_me/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, libGL -, libX11 -, libXext -, libXrandr -, pkg-config -, python3 -, Cocoa +{ + lib, + stdenv, + fetchFromGitHub, + libGL, + libX11, + libXext, + libXrandr, + pkg-config, + python3, + Cocoa, }: stdenv.mkDerivation rec { pname = "master_me"; @@ -22,9 +23,17 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libGL python3 ] + buildInputs = + [ + libGL + python3 + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libX11 libXext libXrandr ]; + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libX11 + libXext + libXrandr + ]; enableParallelBuilding = true; diff --git a/pkgs/applications/audio/mbrola/default.nix b/pkgs/applications/audio/mbrola/default.nix index c67d30fc3dc60a..ade11f764c70d4 100644 --- a/pkgs/applications/audio/mbrola/default.nix +++ b/pkgs/applications/audio/mbrola/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, runCommandLocal, mbrola-voices }: +{ + stdenv, + lib, + fetchFromGitHub, + runCommandLocal, + mbrola-voices, +}: let pname = "mbrola"; @@ -43,13 +49,12 @@ let }; in - runCommandLocal - "${pname}-${version}" - { - inherit pname version meta; - } - '' - mkdir -p "$out/share/mbrola" - ln -s '${mbrola-voices}/data' "$out/share/mbrola/voices" - ln -s '${bin}/bin' "$out/" - '' +runCommandLocal "${pname}-${version}" + { + inherit pname version meta; + } + '' + mkdir -p "$out/share/mbrola" + ln -s '${mbrola-voices}/data' "$out/share/mbrola/voices" + ln -s '${bin}/bin' "$out/" + '' diff --git a/pkgs/applications/audio/mellowplayer/default.nix b/pkgs/applications/audio/mellowplayer/default.nix index 2bffd43b7b9576..0b51b83f98f79a 100644 --- a/pkgs/applications/audio/mellowplayer/default.nix +++ b/pkgs/applications/audio/mellowplayer/default.nix @@ -1,16 +1,17 @@ -{ cmake -, fetchFromGitLab -, lib -, libnotify -, mkDerivation -, pkg-config -, qtbase -, qtdeclarative -, qtgraphicaleffects -, qtquickcontrols2 -, qttools -, qtwebengine -, stdenv +{ + cmake, + fetchFromGitLab, + lib, + libnotify, + mkDerivation, + pkg-config, + qtbase, + qtdeclarative, + qtgraphicaleffects, + qtquickcontrols2, + qttools, + qtwebengine, + stdenv, }: mkDerivation rec { @@ -24,7 +25,10 @@ mkDerivation rec { hash = "sha256-rsF2xQet7U8d4oGU/HgghvE3vvmkxjlGXPBlLD9mWTk="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libnotify @@ -40,25 +44,29 @@ mkDerivation rec { cmakeFlags = [ "-DBUILD_TESTS=ON" ]; - preCheck = '' - # Running the tests requires a location at the home directory for logging. - export HOME="$NIX_BUILD_TOP/home" - mkdir -p "$HOME/.local/share/MellowPlayer.Tests/MellowPlayer.Tests/Logs" + preCheck = + '' + # Running the tests requires a location at the home directory for logging. + export HOME="$NIX_BUILD_TOP/home" + mkdir -p "$HOME/.local/share/MellowPlayer.Tests/MellowPlayer.Tests/Logs" - # Without this, the tests fail because they cannot create the QT Window - export QT_QPA_PLATFORM=offscreen - '' - # TODO: The tests are failing because it can't locate QT plugins. Is there a better way to do this? - + (builtins.concatStringsSep "\n" (lib.lists.flatten (builtins.map - (pkg: [ - (lib.optionalString (pkg ? qtPluginPrefix) '' - export QT_PLUGIN_PATH="${pkg}/${pkg.qtPluginPrefix}"''${QT_PLUGIN_PATH:+':'}$QT_PLUGIN_PATH - '') + # Without this, the tests fail because they cannot create the QT Window + export QT_QPA_PLATFORM=offscreen + '' + # TODO: The tests are failing because it can't locate QT plugins. Is there a better way to do this? + + (builtins.concatStringsSep "\n" ( + lib.lists.flatten ( + builtins.map (pkg: [ + (lib.optionalString (pkg ? qtPluginPrefix) '' + export QT_PLUGIN_PATH="${pkg}/${pkg.qtPluginPrefix}"''${QT_PLUGIN_PATH:+':'}$QT_PLUGIN_PATH + '') - (lib.optionalString (pkg ? qtQmlPrefix) '' - export QML2_IMPORT_PATH="${pkg}/${pkg.qtQmlPrefix}"''${QML2_IMPORT_PATH:+':'}$QML2_IMPORT_PATH - '') - ]) buildInputs))); + (lib.optionalString (pkg ? qtQmlPrefix) '' + export QML2_IMPORT_PATH="${pkg}/${pkg.qtQmlPrefix}"''${QML2_IMPORT_PATH:+':'}$QML2_IMPORT_PATH + '') + ]) buildInputs + ) + )); meta = with lib; { inherit (qtbase.meta) platforms; diff --git a/pkgs/applications/audio/melmatcheq.lv2/default.nix b/pkgs/applications/audio/melmatcheq.lv2/default.nix index 7469b8146f72ce..ef49dc783d2e2c 100644 --- a/pkgs/applications/audio/melmatcheq.lv2/default.nix +++ b/pkgs/applications/audio/melmatcheq.lv2/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, xorg, xorgproto, cairo, lv2, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + xorg, + xorgproto, + cairo, + lv2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "MelMatchEQ.lv2"; @@ -13,7 +22,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - xorg.libX11 xorgproto cairo lv2 + xorg.libX11 + xorgproto + cairo + lv2 ]; installFlags = [ "INSTALL_DIR=$(out)/lib/lv2" ]; diff --git a/pkgs/applications/audio/midas/generic.nix b/pkgs/applications/audio/midas/generic.nix index 6e71620ad444ad..1f0847881b6fa3 100644 --- a/pkgs/applications/audio/midas/generic.nix +++ b/pkgs/applications/audio/midas/generic.nix @@ -1,4 +1,19 @@ -{ stdenv, fetchurl, lib, libX11, libXext, alsa-lib, freetype, brand, type, version, homepage, url, sha256, ... }: +{ + stdenv, + fetchurl, + lib, + libX11, + libXext, + alsa-lib, + freetype, + brand, + type, + version, + homepage, + url, + sha256, + ... +}: stdenv.mkDerivation rec { pname = "${lib.toLower type}-edit"; inherit version; @@ -16,21 +31,23 @@ stdenv.mkDerivation rec { mkdir -p $out/bin cp ${type}-Edit $out/bin/${pname} ''; - preFixup = let - # we prepare our library path in the let clause to avoid it become part of the input of mkDerivation - libPath = lib.makeLibraryPath [ - libX11 # libX11.so.6 - libXext # libXext.so.6 - alsa-lib # libasound.so.2 - freetype # libfreetype.so.6 - (lib.getLib stdenv.cc.cc) # libstdc++.so.6 - ]; - in '' - patchelf \ - --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath "${libPath}" \ - $out/bin/${pname} - ''; + preFixup = + let + # we prepare our library path in the let clause to avoid it become part of the input of mkDerivation + libPath = lib.makeLibraryPath [ + libX11 # libX11.so.6 + libXext # libXext.so.6 + alsa-lib # libasound.so.2 + freetype # libfreetype.so.6 + (lib.getLib stdenv.cc.cc) # libstdc++.so.6 + ]; + in + '' + patchelf \ + --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ + --set-rpath "${libPath}" \ + $out/bin/${pname} + ''; meta = with lib; { inherit homepage; diff --git a/pkgs/applications/audio/midas/m32edit.nix b/pkgs/applications/audio/midas/m32edit.nix index eff7fb8f808337..41f30235f68e87 100644 --- a/pkgs/applications/audio/midas/m32edit.nix +++ b/pkgs/applications/audio/midas/m32edit.nix @@ -1,10 +1,13 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./generic.nix (args // rec { - brand = "Midas"; - type = "M32"; - version = "4.1"; - url = "https://mediadl.musictribe.com/download/software/midas_${type}/${type}-Edit_LINUX_${version}.tar.gz"; - sha256 = "0aqhdrxqa49liyvbbw5x32kwk0h1spzvmizmdxklrfs64vvr9bvh"; - homepage = "https://midasconsoles.com/midas/product?modelCode=P0B3I"; -}) +callPackage ./generic.nix ( + args + // rec { + brand = "Midas"; + type = "M32"; + version = "4.1"; + url = "https://mediadl.musictribe.com/download/software/midas_${type}/${type}-Edit_LINUX_${version}.tar.gz"; + sha256 = "0aqhdrxqa49liyvbbw5x32kwk0h1spzvmizmdxklrfs64vvr9bvh"; + homepage = "https://midasconsoles.com/midas/product?modelCode=P0B3I"; + } +) diff --git a/pkgs/applications/audio/midas/x32edit.nix b/pkgs/applications/audio/midas/x32edit.nix index d375ebf1a4680f..c425665df7a0f2 100644 --- a/pkgs/applications/audio/midas/x32edit.nix +++ b/pkgs/applications/audio/midas/x32edit.nix @@ -1,10 +1,13 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./generic.nix (args // rec { - brand = "Behringer"; - type = "X32"; - version = "4.1"; - url = "https://mediadl.musictribe.com/download/software/behringer/${type}/${type}-Edit_LINUX_${version}.tar.gz"; - sha256 = "0zsw7qfmcci87skkpq8vx5zxk35phn8y4byispvki9ascifnnb33"; - homepage = "https://www.behringer.com/behringer/product?modelCode=P0ASF"; -}) +callPackage ./generic.nix ( + args + // rec { + brand = "Behringer"; + type = "X32"; + version = "4.1"; + url = "https://mediadl.musictribe.com/download/software/behringer/${type}/${type}-Edit_LINUX_${version}.tar.gz"; + sha256 = "0zsw7qfmcci87skkpq8vx5zxk35phn8y4byispvki9ascifnnb33"; + homepage = "https://www.behringer.com/behringer/product?modelCode=P0ASF"; + } +) diff --git a/pkgs/applications/audio/midivisualizer/default.nix b/pkgs/applications/audio/midivisualizer/default.nix index 54f13d3e628a7d..eb409930a3b213 100644 --- a/pkgs/applications/audio/midivisualizer/default.nix +++ b/pkgs/applications/audio/midivisualizer/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, libX11 -, glfw -, makeWrapper -, libXrandr -, libXinerama -, libXcursor -, gtk3 -, ffmpeg-full -, AppKit -, Carbon -, Cocoa -, CoreAudio -, CoreMIDI -, CoreServices -, Kernel +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libX11, + glfw, + makeWrapper, + libXrandr, + libXinerama, + libXcursor, + gtk3, + ffmpeg-full, + AppKit, + Carbon, + Cocoa, + CoreAudio, + CoreMIDI, + CoreServices, + Kernel, }: stdenv.mkDerivation (finalAttrs: { @@ -31,38 +32,49 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-wfPSPH+E9cErVvfJZqHttFtjiUYJopM/u6w6NpRHifE="; }; - nativeBuildInputs = [ cmake pkg-config makeWrapper]; - - buildInputs = [ - glfw - ffmpeg-full - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libX11 - libXrandr - libXinerama - libXcursor - gtk3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - Carbon - Cocoa - CoreAudio - CoreMIDI - CoreServices - Kernel + nativeBuildInputs = [ + cmake + pkg-config + makeWrapper ]; - installPhase = if stdenv.hostPlatform.isDarwin then '' - mkdir -p $out/Applications $out/bin - cp -r MIDIVisualizer.app $out/Applications/ - ln -s ../Applications/MIDIVisualizer.app/Contents/MacOS/MIDIVisualizer $out/bin/ - '' else '' - mkdir -p $out/bin - cp MIDIVisualizer $out/bin + buildInputs = + [ + glfw + ffmpeg-full + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libX11 + libXrandr + libXinerama + libXcursor + gtk3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + Carbon + Cocoa + CoreAudio + CoreMIDI + CoreServices + Kernel + ]; + + installPhase = + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p $out/Applications $out/bin + cp -r MIDIVisualizer.app $out/Applications/ + ln -s ../Applications/MIDIVisualizer.app/Contents/MacOS/MIDIVisualizer $out/bin/ + '' + else + '' + mkdir -p $out/bin + cp MIDIVisualizer $out/bin - wrapProgram $out/bin/MIDIVisualizer \ - --prefix XDG_DATA_DIRS : "${gtk3}/share/gsettings-schemas/${gtk3.name}:$XDG_DATA_DIRS" - ''; + wrapProgram $out/bin/MIDIVisualizer \ + --prefix XDG_DATA_DIRS : "${gtk3}/share/gsettings-schemas/${gtk3.name}:$XDG_DATA_DIRS" + ''; meta = with lib; { description = "Small MIDI visualizer tool, using OpenGL"; diff --git a/pkgs/applications/audio/minidsp/default.nix b/pkgs/applications/audio/minidsp/default.nix index f6affaeefc3a6a..0c2e76cae389ef 100644 --- a/pkgs/applications/audio/minidsp/default.nix +++ b/pkgs/applications/audio/minidsp/default.nix @@ -21,19 +21,25 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-GUrYEFpTo83lKuDyENaVN3VhnZ2Y/igtsbEY7kNa1os="; - cargoBuildFlags = ["-p minidsp -p minidsp-daemon"]; + cargoBuildFlags = [ "-p minidsp -p minidsp-daemon" ]; buildInputs = - lib.optionals stdenv.hostPlatform.isLinux [libusb1] - ++ lib.optionals stdenv.hostPlatform.isDarwin [AppKit IOKit]; + lib.optionals stdenv.hostPlatform.isLinux [ libusb1 ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + IOKit + ]; - nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [pkg-config]; + nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ]; meta = with lib; { description = "Control interface for some MiniDSP products"; homepage = "https://github.com/mrene/minidsp-rs"; license = licenses.asl20; platforms = platforms.linux ++ platforms.darwin; - maintainers = [maintainers.adamcstephens maintainers.mrene]; + maintainers = [ + maintainers.adamcstephens + maintainers.mrene + ]; }; } diff --git a/pkgs/applications/audio/mixxx/default.nix b/pkgs/applications/audio/mixxx/default.nix index 33dddd20cfc4ee..13ddb4be64816c 100644 --- a/pkgs/applications/audio/mixxx/default.nix +++ b/pkgs/applications/audio/mixxx/default.nix @@ -1,58 +1,59 @@ -{ lib -, stdenv -, mkDerivation -, fetchFromGitHub -, chromaprint -, cmake -, faad2 -, ffmpeg -, fftw -, flac -, gbenchmark -, glibcLocales -, gtest -, hidapi -, lame -, libebur128 -, libdjinterop -, libGLU -, libid3tag -, libkeyfinder -, libmad -, libmodplug -, libopus -, libsecret -, libshout -, libsndfile -, libusb1 -, libvorbis -, libxcb -, lilv -, lv2 -, microsoft-gsl -, mp4v2 -, opusfile -, pcre -, pkg-config -, portaudio -, portmidi -, protobuf -, qtbase -, qtkeychain -, qtscript -, qtsvg -, qtx11extras -, rubberband -, serd -, sord -, soundtouch -, sratom -, sqlite -, taglib -, upower -, vamp-plugin-sdk -, wavpack -, wrapGAppsHook3 +{ + lib, + stdenv, + mkDerivation, + fetchFromGitHub, + chromaprint, + cmake, + faad2, + ffmpeg, + fftw, + flac, + gbenchmark, + glibcLocales, + gtest, + hidapi, + lame, + libebur128, + libdjinterop, + libGLU, + libid3tag, + libkeyfinder, + libmad, + libmodplug, + libopus, + libsecret, + libshout, + libsndfile, + libusb1, + libvorbis, + libxcb, + lilv, + lv2, + microsoft-gsl, + mp4v2, + opusfile, + pcre, + pkg-config, + portaudio, + portmidi, + protobuf, + qtbase, + qtkeychain, + qtscript, + qtsvg, + qtx11extras, + rubberband, + serd, + sord, + soundtouch, + sratom, + sqlite, + taglib, + upower, + vamp-plugin-sdk, + wavpack, + wrapGAppsHook3, }: mkDerivation rec { @@ -66,7 +67,11 @@ mkDerivation rec { hash = "sha256-YfpFRLosIIND+HnZN+76ZY0dQqEJaFkWZS84gZOCdfc="; }; - nativeBuildInputs = [ cmake pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapGAppsHook3 + ]; dontWrapGApps = true; @@ -121,7 +126,7 @@ mkDerivation rec { wavpack ]; - preFixup='' + preFixup = '' qtWrapperArgs+=(--set LOCALE_ARCHIVE ${glibcLocales}/lib/locale/locale-archive ''${gappsWrapperArgs[@]}) ''; @@ -147,7 +152,10 @@ mkDerivation rec { description = "Digital DJ mixing software"; mainProgram = "mixxx"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ bfortz benley ]; + maintainers = with maintainers; [ + bfortz + benley + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/audio/mmlgui/default.nix b/pkgs/applications/audio/mmlgui/default.nix index d9197abd04dc9e..d5ea07d6d3626c 100644 --- a/pkgs/applications/audio/mmlgui/default.nix +++ b/pkgs/applications/audio/mmlgui/default.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, unstableGitUpdater -, pkg-config -, glfw -, libvgm -, libX11 -, libXau -, libXdmcp -, Carbon -, Cocoa -, cppunit +{ + stdenv, + lib, + fetchFromGitHub, + unstableGitUpdater, + pkg-config, + glfw, + libvgm, + libX11, + libXau, + libXdmcp, + Carbon, + Cocoa, + cppunit, }: stdenv.mkDerivation rec { @@ -51,17 +52,20 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - glfw - libvgm - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libX11 - libXau - libXdmcp - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Carbon - Cocoa - ]; + buildInputs = + [ + glfw + libvgm + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libX11 + libXau + libXdmcp + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + Cocoa + ]; checkInputs = [ cppunit diff --git a/pkgs/applications/audio/moc/default.nix b/pkgs/applications/audio/moc/default.nix index eae8f02fe1792a..581ace1d3c3c0b 100644 --- a/pkgs/applications/audio/moc/default.nix +++ b/pkgs/applications/audio/moc/default.nix @@ -1,28 +1,57 @@ -{ lib, stdenv, fetchsvn, fetchpatch2, pkg-config -, autoreconfHook, autoconf-archive -, ncurses, db , popt, libtool -, libiconv, CoreServices -# Sound sub-systems -, alsaSupport ? (!stdenv.hostPlatform.isDarwin), alsa-lib -, pulseSupport ? true, libpulseaudio -, jackSupport ? true, libjack2 -, ossSupport ? true -# Audio formats -, aacSupport ? true, faad2, libid3tag -, flacSupport ? true, flac -, midiSupport ? true, timidity -, modplugSupport ? true, libmodplug -, mp3Support ? true, libmad -, musepackSupport ? true, libmpc, libmpcdec, taglib -, vorbisSupport ? true, libvorbis -, speexSupport ? true, speex -, ffmpegSupport ? true, ffmpeg -, sndfileSupport ? true, libsndfile -, wavpackSupport ? true, wavpack -# Misc -, curlSupport ? true, curl -, samplerateSupport ? true, libsamplerate -, withDebug ? false +{ + lib, + stdenv, + fetchsvn, + fetchpatch2, + pkg-config, + autoreconfHook, + autoconf-archive, + ncurses, + db, + popt, + libtool, + libiconv, + CoreServices, + # Sound sub-systems + alsaSupport ? (!stdenv.hostPlatform.isDarwin), + alsa-lib, + pulseSupport ? true, + libpulseaudio, + jackSupport ? true, + libjack2, + ossSupport ? true, + # Audio formats + aacSupport ? true, + faad2, + libid3tag, + flacSupport ? true, + flac, + midiSupport ? true, + timidity, + modplugSupport ? true, + libmodplug, + mp3Support ? true, + libmad, + musepackSupport ? true, + libmpc, + libmpcdec, + taglib, + vorbisSupport ? true, + libvorbis, + speexSupport ? true, + speex, + ffmpegSupport ? true, + ffmpeg, + sndfileSupport ? true, + libsndfile, + wavpackSupport ? true, + wavpack, + # Misc + curlSupport ? true, + curl, + samplerateSupport ? true, + libsamplerate, + withDebug ? false, }: stdenv.mkDerivation { @@ -57,9 +86,19 @@ stdenv.mkDerivation { rm m4/* ''; - nativeBuildInputs = [ pkg-config autoreconfHook autoconf-archive ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + autoconf-archive + ]; - buildInputs = [ ncurses db popt libtool ] + buildInputs = + [ + ncurses + db + popt + libtool + ] # Sound sub-systems ++ lib.optional alsaSupport alsa-lib ++ lib.optional pulseSupport libpulseaudio @@ -71,7 +110,11 @@ stdenv.mkDerivation { ++ lib.optional midiSupport timidity ++ lib.optional modplugSupport libmodplug ++ lib.optional mp3Support libmad - ++ lib.optionals musepackSupport [ libmpc libmpcdec taglib ] + ++ lib.optionals musepackSupport [ + libmpc + libmpcdec + taglib + ] ++ lib.optional vorbisSupport libvorbis ++ lib.optional speexSupport speex ++ lib.optional ffmpegSupport ffmpeg @@ -80,7 +123,10 @@ stdenv.mkDerivation { # Misc ++ lib.optional curlSupport curl ++ lib.optional samplerateSupport libsamplerate - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv CoreServices ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + CoreServices + ]; configureFlags = [ # Sound sub-systems @@ -112,7 +158,11 @@ stdenv.mkDerivation { description = "Terminal audio player designed to be powerful and easy to use"; homepage = "http://moc.daper.net/"; license = licenses.gpl2; - maintainers = with maintainers; [ aethelz pSub jagajaga ]; + maintainers = with maintainers; [ + aethelz + pSub + jagajaga + ]; platforms = platforms.unix; mainProgram = "mocp"; }; diff --git a/pkgs/applications/audio/mopidy/bandcamp.nix b/pkgs/applications/audio/mopidy/bandcamp.nix index 35491813f1a2ea..3d3d074aaf8263 100644 --- a/pkgs/applications/audio/mopidy/bandcamp.nix +++ b/pkgs/applications/audio/mopidy/bandcamp.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, mopidy }: +{ + lib, + python3Packages, + fetchPypi, + mopidy, +}: python3Packages.buildPythonApplication rec { pname = "Mopidy-Bandcamp"; @@ -8,7 +13,10 @@ python3Packages.buildPythonApplication rec { hash = "sha256-wg9zcOKfZQRhpyA1Cu5wvdwKpmrlcr2m9mrqBHgUXAQ="; }; - propagatedBuildInputs = with python3Packages; [ mopidy pykka ]; + propagatedBuildInputs = with python3Packages; [ + mopidy + pykka + ]; meta = with lib; { description = "Mopidy extension for playing music from bandcamp"; diff --git a/pkgs/applications/audio/mopidy/default.nix b/pkgs/applications/audio/mopidy/default.nix index 958be098d7bb75..f7c71866accba5 100644 --- a/pkgs/applications/audio/mopidy/default.nix +++ b/pkgs/applications/audio/mopidy/default.nix @@ -1,51 +1,57 @@ -{ lib, newScope, python }: +{ + lib, + newScope, + python, +}: # Create a custom scope so we are consistent in which python version is used -lib.makeScope newScope (self: with self; { - inherit python; - pythonPackages = python.pkgs; +lib.makeScope newScope ( + self: with self; { + inherit python; + pythonPackages = python.pkgs; - mopidy = callPackage ./mopidy.nix { }; + mopidy = callPackage ./mopidy.nix { }; - mopidy-bandcamp = callPackage ./bandcamp.nix { }; + mopidy-bandcamp = callPackage ./bandcamp.nix { }; - mopidy-iris = callPackage ./iris.nix { }; + mopidy-iris = callPackage ./iris.nix { }; - mopidy-jellyfin = callPackage ./jellyfin.nix { }; + mopidy-jellyfin = callPackage ./jellyfin.nix { }; - mopidy-local = callPackage ./local.nix { }; + mopidy-local = callPackage ./local.nix { }; - mopidy-moped = callPackage ./moped.nix { }; + mopidy-moped = callPackage ./moped.nix { }; - mopidy-mopify = callPackage ./mopify.nix { }; + mopidy-mopify = callPackage ./mopify.nix { }; - mopidy-mpd = callPackage ./mpd.nix { }; + mopidy-mpd = callPackage ./mpd.nix { }; - mopidy-mpris = callPackage ./mpris.nix { }; + mopidy-mpris = callPackage ./mpris.nix { }; - mopidy-muse = callPackage ./muse.nix { }; + mopidy-muse = callPackage ./muse.nix { }; - mopidy-musicbox-webclient = callPackage ./musicbox-webclient.nix { }; + mopidy-musicbox-webclient = callPackage ./musicbox-webclient.nix { }; - mopidy-notify = callPackage ./notify.nix { }; + mopidy-notify = callPackage ./notify.nix { }; - mopidy-podcast = callPackage ./podcast.nix { }; + mopidy-podcast = callPackage ./podcast.nix { }; - mopidy-scrobbler = callPackage ./scrobbler.nix { }; + mopidy-scrobbler = callPackage ./scrobbler.nix { }; - mopidy-somafm = callPackage ./somafm.nix { }; + mopidy-somafm = callPackage ./somafm.nix { }; - mopidy-soundcloud = callPackage ./soundcloud.nix { }; + mopidy-soundcloud = callPackage ./soundcloud.nix { }; - mopidy-spotify = callPackage ./spotify.nix { }; + mopidy-spotify = callPackage ./spotify.nix { }; - mopidy-tidal = callPackage ./tidal.nix { }; + mopidy-tidal = callPackage ./tidal.nix { }; - mopidy-tunein = callPackage ./tunein.nix { }; + mopidy-tunein = callPackage ./tunein.nix { }; - mopidy-youtube = callPackage ./youtube.nix { }; + mopidy-youtube = callPackage ./youtube.nix { }; - mopidy-ytmusic = callPackage ./ytmusic.nix { }; + mopidy-ytmusic = callPackage ./ytmusic.nix { }; - mopidy-subidy = callPackage ./subidy.nix { }; -}) + mopidy-subidy = callPackage ./subidy.nix { }; + } +) diff --git a/pkgs/applications/audio/mopidy/iris.nix b/pkgs/applications/audio/mopidy/iris.nix index bebb4082a40fae..d07b294528320c 100644 --- a/pkgs/applications/audio/mopidy/iris.nix +++ b/pkgs/applications/audio/mopidy/iris.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, mopidy }: +{ + lib, + python3Packages, + fetchPypi, + mopidy, +}: python3Packages.buildPythonApplication rec { pname = "Mopidy-Iris"; @@ -9,13 +14,15 @@ python3Packages.buildPythonApplication rec { hash = "sha256-PEAXnapiyxozijR053I7zQYRYLeDOV719L0QbO2r4r4="; }; - propagatedBuildInputs = [ - mopidy - ] ++ (with python3Packages; [ - configobj - requests - tornado - ]); + propagatedBuildInputs = + [ + mopidy + ] + ++ (with python3Packages; [ + configobj + requests + tornado + ]); # no tests implemented doCheck = false; diff --git a/pkgs/applications/audio/mopidy/jellyfin.nix b/pkgs/applications/audio/mopidy/jellyfin.nix index 81933616661097..9a2e7fe34c7b25 100644 --- a/pkgs/applications/audio/mopidy/jellyfin.nix +++ b/pkgs/applications/audio/mopidy/jellyfin.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, mopidy }: +{ + lib, + python3Packages, + fetchPypi, + mopidy, +}: python3Packages.buildPythonApplication rec { pname = "mopidy-jellyfin"; @@ -10,7 +15,11 @@ python3Packages.buildPythonApplication rec { hash = "sha256-cZliraTxTAJ2dXaxttWI3x4wCkmEhEo33GTNtAYwgTc="; }; - propagatedBuildInputs = [ mopidy python3Packages.unidecode python3Packages.websocket-client ]; + propagatedBuildInputs = [ + mopidy + python3Packages.unidecode + python3Packages.websocket-client + ]; # no tests implemented doCheck = false; diff --git a/pkgs/applications/audio/mopidy/local.nix b/pkgs/applications/audio/mopidy/local.nix index c907deff34f94c..b76a3abbbb1972 100644 --- a/pkgs/applications/audio/mopidy/local.nix +++ b/pkgs/applications/audio/mopidy/local.nix @@ -1,8 +1,9 @@ -{ lib -, mopidy -, python3Packages -, fetchPypi -, fetchpatch +{ + lib, + mopidy, + python3Packages, + fetchPypi, + fetchpatch, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/applications/audio/mopidy/moped.nix b/pkgs/applications/audio/mopidy/moped.nix index afefc0f0d9d51a..edb94a5a02c98b 100644 --- a/pkgs/applications/audio/mopidy/moped.nix +++ b/pkgs/applications/audio/mopidy/moped.nix @@ -1,4 +1,10 @@ -{ lib, pythonPackages, fetchPypi, mopidy, glibcLocales }: +{ + lib, + pythonPackages, + fetchPypi, + mopidy, + glibcLocales, +}: pythonPackages.buildPythonApplication rec { pname = "Mopidy-Moped"; @@ -21,6 +27,6 @@ pythonPackages.buildPythonApplication rec { description = "Web client for Mopidy"; license = licenses.mit; maintainers = [ ]; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/applications/audio/mopidy/mopify.nix b/pkgs/applications/audio/mopidy/mopify.nix index 21ebc32b9d15f7..ca27c0f7170626 100644 --- a/pkgs/applications/audio/mopidy/mopify.nix +++ b/pkgs/applications/audio/mopidy/mopify.nix @@ -1,4 +1,9 @@ -{ lib, pythonPackages, fetchPypi, mopidy }: +{ + lib, + pythonPackages, + fetchPypi, + mopidy, +}: pythonPackages.buildPythonApplication rec { pname = "Mopidy-Mopify"; @@ -9,7 +14,10 @@ pythonPackages.buildPythonApplication rec { hash = "sha256-RlCC+39zC+LeA/QDWPHYx5TrEwOgVrnvcH1Xg12qSLE="; }; - propagatedBuildInputs = with pythonPackages; [ mopidy configobj ]; + propagatedBuildInputs = with pythonPackages; [ + mopidy + configobj + ]; # no tests implemented doCheck = false; diff --git a/pkgs/applications/audio/mopidy/mpd.nix b/pkgs/applications/audio/mopidy/mpd.nix index 303a4c733e8aaa..ac4073979e79e1 100644 --- a/pkgs/applications/audio/mopidy/mpd.nix +++ b/pkgs/applications/audio/mopidy/mpd.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, mopidy }: +{ + lib, + python3Packages, + fetchPypi, + mopidy, +}: python3Packages.buildPythonApplication rec { pname = "Mopidy-MPD"; diff --git a/pkgs/applications/audio/mopidy/mpris.nix b/pkgs/applications/audio/mopidy/mpris.nix index c4f205cd359b60..5b0e09432a2e43 100644 --- a/pkgs/applications/audio/mopidy/mpris.nix +++ b/pkgs/applications/audio/mopidy/mpris.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, mopidy }: +{ + lib, + python3Packages, + fetchPypi, + mopidy, +}: python3Packages.buildPythonApplication rec { pname = "mopidy-mpris"; @@ -24,4 +29,3 @@ python3Packages.buildPythonApplication rec { maintainers = [ maintainers.nickhu ]; }; } - diff --git a/pkgs/applications/audio/mopidy/muse.nix b/pkgs/applications/audio/mopidy/muse.nix index f98d1ca458fe2f..c70a874593e0a0 100644 --- a/pkgs/applications/audio/mopidy/muse.nix +++ b/pkgs/applications/audio/mopidy/muse.nix @@ -1,4 +1,9 @@ -{ lib, pythonPackages, fetchPypi, mopidy }: +{ + lib, + pythonPackages, + fetchPypi, + mopidy, +}: pythonPackages.buildPythonApplication rec { pname = "mopidy-muse"; diff --git a/pkgs/applications/audio/mopidy/musicbox-webclient.nix b/pkgs/applications/audio/mopidy/musicbox-webclient.nix index 105fcff2accddb..caf18e26e7f1dc 100644 --- a/pkgs/applications/audio/mopidy/musicbox-webclient.nix +++ b/pkgs/applications/audio/mopidy/musicbox-webclient.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, pythonPackages -, mopidy +{ + lib, + fetchFromGitHub, + pythonPackages, + mopidy, }: pythonPackages.buildPythonApplication rec { diff --git a/pkgs/applications/audio/mopidy/notify.nix b/pkgs/applications/audio/mopidy/notify.nix index f52ed619111350..8967dcaf0ae78a 100644 --- a/pkgs/applications/audio/mopidy/notify.nix +++ b/pkgs/applications/audio/mopidy/notify.nix @@ -1,4 +1,9 @@ -{ lib, fetchPypi, pythonPackages, mopidy }: +{ + lib, + fetchPypi, + pythonPackages, + mopidy, +}: pythonPackages.buildPythonApplication rec { pname = "Mopidy-Notify"; diff --git a/pkgs/applications/audio/mopidy/podcast.nix b/pkgs/applications/audio/mopidy/podcast.nix index 8af6dff6254818..f84389dd18b49d 100644 --- a/pkgs/applications/audio/mopidy/podcast.nix +++ b/pkgs/applications/audio/mopidy/podcast.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, mopidy }: +{ + lib, + python3Packages, + fetchPypi, + mopidy, +}: python3Packages.buildPythonApplication rec { pname = "mopidy-podcast"; diff --git a/pkgs/applications/audio/mopidy/scrobbler.nix b/pkgs/applications/audio/mopidy/scrobbler.nix index f283356c808ad8..8a4d33619d1437 100644 --- a/pkgs/applications/audio/mopidy/scrobbler.nix +++ b/pkgs/applications/audio/mopidy/scrobbler.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, mopidy }: +{ + lib, + python3Packages, + fetchPypi, + mopidy, +}: python3Packages.buildPythonApplication rec { pname = "Mopidy-Scrobbler"; @@ -9,7 +14,10 @@ python3Packages.buildPythonApplication rec { sha256 = "11vxgax4xgkggnq4fr1rh2rcvzspkkimck5p3h4phdj3qpnj0680"; }; - propagatedBuildInputs = with python3Packages; [ mopidy pylast ]; + propagatedBuildInputs = with python3Packages; [ + mopidy + pylast + ]; # no tests implemented doCheck = false; diff --git a/pkgs/applications/audio/mopidy/somafm.nix b/pkgs/applications/audio/mopidy/somafm.nix index f9a9343dbf174d..ee7f63d7a24a95 100644 --- a/pkgs/applications/audio/mopidy/somafm.nix +++ b/pkgs/applications/audio/mopidy/somafm.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, mopidy }: +{ + lib, + python3Packages, + fetchPypi, + mopidy, +}: python3Packages.buildPythonApplication rec { pname = "mopidy-somafm"; @@ -21,4 +26,3 @@ python3Packages.buildPythonApplication rec { maintainers = [ maintainers.nickhu ]; }; } - diff --git a/pkgs/applications/audio/mopidy/soundcloud.nix b/pkgs/applications/audio/mopidy/soundcloud.nix index cd9ef3e691ae24..a601cc2196a629 100644 --- a/pkgs/applications/audio/mopidy/soundcloud.nix +++ b/pkgs/applications/audio/mopidy/soundcloud.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, pythonPackages, mopidy }: +{ + lib, + fetchFromGitHub, + pythonPackages, + mopidy, +}: pythonPackages.buildPythonApplication rec { pname = "mopidy-soundcloud"; diff --git a/pkgs/applications/audio/mopidy/subidy.nix b/pkgs/applications/audio/mopidy/subidy.nix index b84a14106fdca9..0891d19f8a8f4d 100644 --- a/pkgs/applications/audio/mopidy/subidy.nix +++ b/pkgs/applications/audio/mopidy/subidy.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, pythonPackages, mopidy }: +{ + lib, + fetchFromGitHub, + pythonPackages, + mopidy, +}: pythonPackages.buildPythonApplication rec { pname = "mopidy-subidy"; @@ -11,7 +16,10 @@ pythonPackages.buildPythonApplication rec { sha256 = "0c5ghhhrj5v3yp4zmll9ari6r5c6ha8c1izwqshvadn40b02q7xz"; }; - propagatedBuildInputs = [ mopidy pythonPackages.py-sonic ]; + propagatedBuildInputs = [ + mopidy + pythonPackages.py-sonic + ]; nativeCheckInputs = with pythonPackages; [ pytestCheckHook ]; diff --git a/pkgs/applications/audio/mopidy/tidal.nix b/pkgs/applications/audio/mopidy/tidal.nix index 4b485ba3886b23..5548130665cb9d 100644 --- a/pkgs/applications/audio/mopidy/tidal.nix +++ b/pkgs/applications/audio/mopidy/tidal.nix @@ -1,7 +1,8 @@ -{ lib -, python3Packages -, fetchPypi -, mopidy +{ + lib, + python3Packages, + fetchPypi, + mopidy, }: python3Packages.buildPythonApplication rec { @@ -32,5 +33,3 @@ python3Packages.buildPythonApplication rec { maintainers = [ ]; }; } - - diff --git a/pkgs/applications/audio/mopidy/tunein.nix b/pkgs/applications/audio/mopidy/tunein.nix index b306ae91f17c24..e536d81ddece89 100644 --- a/pkgs/applications/audio/mopidy/tunein.nix +++ b/pkgs/applications/audio/mopidy/tunein.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, mopidy }: +{ + lib, + python3Packages, + fetchPypi, + mopidy, +}: python3Packages.buildPythonApplication rec { pname = "mopidy-tunein"; diff --git a/pkgs/applications/audio/mopidy/ytmusic.nix b/pkgs/applications/audio/mopidy/ytmusic.nix index 6981be30b2ea59..5db613bc3ebe51 100644 --- a/pkgs/applications/audio/mopidy/ytmusic.nix +++ b/pkgs/applications/audio/mopidy/ytmusic.nix @@ -1,12 +1,14 @@ -{ lib -, python3 -, fetchFromGitHub -, mopidy +{ + lib, + python3, + fetchFromGitHub, + mopidy, }: let python = python3; -in python.pkgs.buildPythonApplication rec { +in +python.pkgs.buildPythonApplication rec { pname = "mopidy-ytmusic"; version = "0.3.9"; pyproject = true; diff --git a/pkgs/applications/audio/mpg123/default.nix b/pkgs/applications/audio/mpg123/default.nix index f18469f5658852..1d4c619fb34912 100644 --- a/pkgs/applications/audio/mpg123/default.nix +++ b/pkgs/applications/audio/mpg123/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, pkg-config -, libOnly ? false # whether to build only the library -, withAlsa ? stdenv.hostPlatform.isLinux -, alsa-lib -, withPulse ? stdenv.hostPlatform.isLinux -, libpulseaudio -, withCoreAudio ? stdenv.hostPlatform.isDarwin -, AudioUnit -, AudioToolbox -, withJack ? stdenv.hostPlatform.isUnix -, jack -, withConplay ? !stdenv.hostPlatform.isWindows -, perl -, writeScript +{ + lib, + stdenv, + fetchurl, + makeWrapper, + pkg-config, + libOnly ? false, # whether to build only the library + withAlsa ? stdenv.hostPlatform.isLinux, + alsa-lib, + withPulse ? stdenv.hostPlatform.isLinux, + libpulseaudio, + withCoreAudio ? stdenv.hostPlatform.isDarwin, + AudioUnit, + AudioToolbox, + withJack ? stdenv.hostPlatform.isUnix, + jack, + withConplay ? !stdenv.hostPlatform.isWindows, + perl, + writeScript, }: assert withConplay -> !libOnly; @@ -29,30 +30,40 @@ stdenv.mkDerivation rec { hash = "sha256-/u4TdMeVQODkBd8LxF/eIK1nARQlw2GidZ4hRolKJ6c="; }; - outputs = [ "out" "dev" "man" ] ++ lib.optional withConplay "conplay"; + outputs = [ + "out" + "dev" + "man" + ] ++ lib.optional withConplay "conplay"; nativeBuildInputs = lib.optionals (!libOnly) ( - lib.optionals withConplay [ makeWrapper ] - ++ lib.optionals (withPulse || withJack) [ pkg-config ] + lib.optionals withConplay [ makeWrapper ] ++ lib.optionals (withPulse || withJack) [ pkg-config ] ); buildInputs = lib.optionals (!libOnly) ( lib.optionals withConplay [ perl ] ++ lib.optionals withAlsa [ alsa-lib ] ++ lib.optionals withPulse [ libpulseaudio ] - ++ lib.optionals withCoreAudio [ AudioUnit AudioToolbox ] + ++ lib.optionals withCoreAudio [ + AudioUnit + AudioToolbox + ] ++ lib.optionals withJack [ jack ] ); - configureFlags = lib.optionals (!libOnly) [ - "--with-audio=${lib.strings.concatStringsSep "," ( - lib.optional withJack "jack" - ++ lib.optional withPulse "pulse" - ++ lib.optional withAlsa "alsa" - ++ lib.optional withCoreAudio "coreaudio" - ++ [ "dummy" ] - )}" - ] ++ lib.optional (stdenv.hostPlatform ? mpg123) "--with-cpu=${stdenv.hostPlatform.mpg123.cpu}"; + configureFlags = + lib.optionals (!libOnly) [ + "--with-audio=${ + lib.strings.concatStringsSep "," ( + lib.optional withJack "jack" + ++ lib.optional withPulse "pulse" + ++ lib.optional withAlsa "alsa" + ++ lib.optional withCoreAudio "coreaudio" + ++ [ "dummy" ] + ) + }" + ] + ++ lib.optional (stdenv.hostPlatform ? mpg123) "--with-cpu=${stdenv.hostPlatform.mpg123.cpu}"; enableParallelBuilding = true; diff --git a/pkgs/applications/audio/munt/libmt32emu.nix b/pkgs/applications/audio/munt/libmt32emu.nix index c8a9263b7501fe..31db8595ca103e 100644 --- a/pkgs/applications/audio/munt/libmt32emu.nix +++ b/pkgs/applications/audio/munt/libmt32emu.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { @@ -15,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-zY1AFcm8uvFkrKUZHsqtKY2CYTY4bWmkTJ7bZPqXoxk="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake diff --git a/pkgs/applications/audio/munt/mt32emu-qt.nix b/pkgs/applications/audio/munt/mt32emu-qt.nix index e84ad492c488ec..0a75f0620383c0 100644 --- a/pkgs/applications/audio/munt/mt32emu-qt.nix +++ b/pkgs/applications/audio/munt/mt32emu-qt.nix @@ -1,16 +1,18 @@ -{ lib -, stdenv -, mkDerivation -, fetchFromGitHub -, alsa-lib -, cmake -, libpulseaudio -, libmt32emu -, pkg-config -, portaudio -, qtbase -, qtmultimedia -, withJack ? stdenv.hostPlatform.isUnix, libjack2 +{ + lib, + stdenv, + mkDerivation, + fetchFromGitHub, + alsa-lib, + cmake, + libpulseaudio, + libmt32emu, + pkg-config, + portaudio, + qtbase, + qtmultimedia, + withJack ? stdenv.hostPlatform.isUnix, + libjack2, }: let @@ -36,17 +38,18 @@ mkDerivation rec { pkg-config ]; - buildInputs = [ - libmt32emu - portaudio - qtbase - qtmultimedia - ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - libpulseaudio - ] - ++ lib.optional withJack libjack2; + buildInputs = + [ + libmt32emu + portaudio + qtbase + qtmultimedia + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + libpulseaudio + ] + ++ lib.optional withJack libjack2; dontFixCmake = true; diff --git a/pkgs/applications/audio/munt/mt32emu-smf2wav.nix b/pkgs/applications/audio/munt/mt32emu-smf2wav.nix index 3ebadcca91bec8..0b1010be1893fa 100644 --- a/pkgs/applications/audio/munt/mt32emu-smf2wav.nix +++ b/pkgs/applications/audio/munt/mt32emu-smf2wav.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, glib -, libmt32emu -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + glib, + libmt32emu, + pkg-config, }: let diff --git a/pkgs/applications/audio/mup/default.nix b/pkgs/applications/audio/mup/default.nix index 8f1d5c38b341c5..b879b7c14c0cb9 100644 --- a/pkgs/applications/audio/mup/default.nix +++ b/pkgs/applications/audio/mup/default.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchurl, autoreconfHook, bison, flex, ghostscript, groff, netpbm -, fltk, libXinerama, libXpm, libjpeg +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + bison, + flex, + ghostscript, + groff, + netpbm, + fltk, + libXinerama, + libXpm, + libjpeg, }: stdenv.mkDerivation rec { @@ -7,13 +19,27 @@ stdenv.mkDerivation rec { version = "6.8"; src = fetchurl { - url = "http://www.arkkra.com/ftp/pub/unix/mup${builtins.replaceStrings ["."] [""] version}src.tar.gz"; + url = "http://www.arkkra.com/ftp/pub/unix/mup${ + builtins.replaceStrings [ "." ] [ "" ] version + }src.tar.gz"; sha256 = "06bv5nyl8rcibyb83zzrfdq6x6f93g3rgnv47i5gsjcaw5w6l31y"; }; - nativeBuildInputs = [ autoreconfHook bison flex ghostscript groff netpbm ]; + nativeBuildInputs = [ + autoreconfHook + bison + flex + ghostscript + groff + netpbm + ]; - buildInputs = [ fltk libXinerama libXpm libjpeg ]; + buildInputs = [ + fltk + libXinerama + libXpm + libjpeg + ]; patches = [ ./ghostscript-permit-file-write.patch ]; diff --git a/pkgs/applications/audio/muse/default.nix b/pkgs/applications/audio/muse/default.nix index d5f32097250b0e..5bf3612596b2b5 100644 --- a/pkgs/applications/audio/muse/default.nix +++ b/pkgs/applications/audio/muse/default.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, pkg-config -, qttools -, wrapQtAppsHook -, alsa-lib -, dssi -, fluidsynth -, ladspaH -, lash -, libinstpatch -, libjack2 -, liblo -, libsamplerate -, libsndfile -, lilv -, lrdf -, lv2 -, qtsvg -, rtaudio -, rubberband -, sord -, serd +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + pkg-config, + qttools, + wrapQtAppsHook, + alsa-lib, + dssi, + fluidsynth, + ladspaH, + lash, + libinstpatch, + libjack2, + liblo, + libsamplerate, + libsndfile, + lilv, + lrdf, + lv2, + qtsvg, + rtaudio, + rubberband, + sord, + serd, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/audio/musescore/default.nix b/pkgs/applications/audio/musescore/default.nix index 8ce689018e253f..b36d146a7d4337 100644 --- a/pkgs/applications/audio/musescore/default.nix +++ b/pkgs/applications/audio/musescore/default.nix @@ -1,37 +1,38 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, cmake -, wrapGAppsHook3 -, wrapQtAppsHook -, pkg-config -, ninja -, alsa-lib -, alsa-plugins -, freetype -, libjack2 -, lame -, libogg -, libpulseaudio -, libsndfile -, libvorbis -, portaudio -, portmidi -, qtbase -, qtdeclarative -, flac -, libopusenc -, libopus -, tinyxml-2 -, qt5compat -, qtwayland -, qtsvg -, qtscxml -, qtnetworkauth -, qttools -, nixosTests -, apple-sdk_11 +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, + wrapGAppsHook3, + wrapQtAppsHook, + pkg-config, + ninja, + alsa-lib, + alsa-plugins, + freetype, + libjack2, + lame, + libogg, + libpulseaudio, + libsndfile, + libvorbis, + portaudio, + portmidi, + qtbase, + qtdeclarative, + flac, + libopusenc, + libopus, + tinyxml-2, + qt5compat, + qtwayland, + qtsvg, + qtscxml, + qtnetworkauth, + qttools, + nixosTests, + apple-sdk_11, }: stdenv.mkDerivation (finalAttrs: { @@ -65,16 +66,21 @@ stdenv.mkDerivation (finalAttrs: { (lib.cmakeBool "MUSE_ENABLE_UNIT_TESTS" finalAttrs.finalPackage.doCheck) ]; - qtWrapperArgs = [ - # MuseScore JACK backend loads libjack at runtime. - "--prefix ${lib.optionalString stdenv.hostPlatform.isDarwin "DY"}LD_LIBRARY_PATH : ${lib.makeLibraryPath [ libjack2 ]}" - ] ++ lib.optionals (stdenv.hostPlatform.isLinux) [ - "--set ALSA_PLUGIN_DIR ${alsa-plugins}/lib/alsa-lib" - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - # There are some issues with using the wayland backend, see: - # https://musescore.org/en/node/321936 - "--set-default QT_QPA_PLATFORM xcb" - ]; + qtWrapperArgs = + [ + # MuseScore JACK backend loads libjack at runtime. + "--prefix ${lib.optionalString stdenv.hostPlatform.isDarwin "DY"}LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ libjack2 ] + }" + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux) [ + "--set ALSA_PLUGIN_DIR ${alsa-plugins}/lib/alsa-lib" + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + # There are some issues with using the wayland backend, see: + # https://musescore.org/en/node/321936 + "--set-default QT_QPA_PLATFORM xcb" + ]; preFixup = '' qtWrapperArgs+=("''${gappsWrapperArgs[@]}") @@ -82,54 +88,61 @@ stdenv.mkDerivation (finalAttrs: { dontWrapGApps = true; - nativeBuildInputs = [ - wrapQtAppsHook - cmake - qttools - pkg-config - ninja - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - # Since https://github.com/musescore/MuseScore/pull/13847/commits/685ac998 - # GTK3 is needed for file dialogs. Fixes crash with No GSettings schemas error. - wrapGAppsHook3 - ]; + nativeBuildInputs = + [ + wrapQtAppsHook + cmake + qttools + pkg-config + ninja + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + # Since https://github.com/musescore/MuseScore/pull/13847/commits/685ac998 + # GTK3 is needed for file dialogs. Fixes crash with No GSettings schemas error. + wrapGAppsHook3 + ]; - buildInputs = [ - libjack2 - freetype - lame - libogg - libpulseaudio - libsndfile - libvorbis - portaudio - portmidi - flac - libopusenc - libopus - tinyxml-2 - qtbase - qtdeclarative - qt5compat - qtsvg - qtscxml - qtnetworkauth - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - qtwayland - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - apple-sdk_11 - ]; + buildInputs = + [ + libjack2 + freetype + lame + libogg + libpulseaudio + libsndfile + libvorbis + portaudio + portmidi + flac + libopusenc + libopus + tinyxml-2 + qtbase + qtdeclarative + qt5compat + qtsvg + qtscxml + qtnetworkauth + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + qtwayland + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + apple-sdk_11 + ]; - postInstall = '' - # Remove unneeded bundled libraries and headers - rm -r $out/{include,lib} - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p "$out/Applications" - mv "$out/mscore.app" "$out/Applications/mscore.app" - mkdir -p $out/bin - ln -s $out/Applications/mscore.app/Contents/MacOS/mscore $out/bin/mscore - ''; + postInstall = + '' + # Remove unneeded bundled libraries and headers + rm -r $out/{include,lib} + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p "$out/Applications" + mv "$out/mscore.app" "$out/Applications/mscore.app" + mkdir -p $out/bin + ln -s $out/Applications/mscore.app/Contents/MacOS/mscore $out/bin/mscore + ''; # muse-sounds-manager installs Muse Sounds sampler libMuseSamplerCoreLib.so. # It requires that argv0 of the calling process ends with "/mscore" or "/MuseScore-4". @@ -163,7 +176,11 @@ stdenv.mkDerivation (finalAttrs: { description = "Music notation and composition software"; homepage = "https://musescore.org/"; license = licenses.gpl3Only; - maintainers = with maintainers; [ vandenoever doronbehar orivej ]; + maintainers = with maintainers; [ + vandenoever + doronbehar + orivej + ]; mainProgram = "mscore"; platforms = platforms.unix; }; diff --git a/pkgs/applications/audio/muso/default.nix b/pkgs/applications/audio/muso/default.nix index 97d897d5fcb397..0623754cfa184b 100644 --- a/pkgs/applications/audio/muso/default.nix +++ b/pkgs/applications/audio/muso/default.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform -, pkg-config, wrapGAppsHook3, CoreServices +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + wrapGAppsHook3, + CoreServices, }: rustPlatform.buildRustPackage rec { @@ -13,7 +19,10 @@ rustPlatform.buildRustPackage rec { hash = "sha256-09DWUER0ZWQuwfE3sjov2GjJNI7coE3D3E5iUy9mlSE="; }; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; buildInputs = lib.optional stdenv.hostPlatform.isDarwin CoreServices; preConfigure = '' diff --git a/pkgs/applications/audio/non/default.nix b/pkgs/applications/audio/non/default.nix index bd4c83742930e3..28ce729667e3d4 100644 --- a/pkgs/applications/audio/non/default.nix +++ b/pkgs/applications/audio/non/default.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, python3, cairo, libjpeg, ntk, libjack2 -, libsndfile, ladspaH, liblo, libsigcxx, lrdf, wafHook +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + python3, + cairo, + libjpeg, + ntk, + libjack2, + libsndfile, + ladspaH, + liblo, + libsigcxx, + lrdf, + wafHook, }: stdenv.mkDerivation { @@ -12,9 +26,21 @@ stdenv.mkDerivation { sha256 = "sha256-iMJNMDytNXpEkUhL0RILSd25ixkm8HL/edtOZta0Pf4="; }; - nativeBuildInputs = [ pkg-config wafHook ]; - buildInputs = [ python3 cairo libjpeg ntk libjack2 libsndfile - ladspaH liblo libsigcxx lrdf + nativeBuildInputs = [ + pkg-config + wafHook + ]; + buildInputs = [ + python3 + cairo + libjpeg + ntk + libjack2 + libsndfile + ladspaH + liblo + libsigcxx + lrdf ]; # NOTE: non provides its own waf script that is incompatible with new diff --git a/pkgs/applications/audio/nootka/default.nix b/pkgs/applications/audio/nootka/default.nix index a52c5bb98176a0..88a5ed0c43015c 100644 --- a/pkgs/applications/audio/nootka/default.nix +++ b/pkgs/applications/audio/nootka/default.nix @@ -1,6 +1,20 @@ -{ lib, stdenv, fetchurl, cmake -, alsa-lib, fftwSinglePrec, libjack2, libpulseaudio, libvorbis, soundtouch -, qtbase, qtdeclarative, qtgraphicaleffects, qtquickcontrols2, qttools, wrapQtAppsHook +{ + lib, + stdenv, + fetchurl, + cmake, + alsa-lib, + fftwSinglePrec, + libjack2, + libpulseaudio, + libvorbis, + soundtouch, + qtbase, + qtdeclarative, + qtgraphicaleffects, + qtquickcontrols2, + qttools, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -12,7 +26,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-ZHdyLZ3+TCpQ77tcNuDlN2124qLDZu9DdH5x7RI1HIs="; }; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; buildInputs = [ alsa-lib fftwSinglePrec @@ -38,7 +55,10 @@ stdenv.mkDerivation rec { mainProgram = "nootka"; homepage = "https://nootka.sourceforge.io/"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ mmlb orivej ]; + maintainers = with maintainers; [ + mmlb + orivej + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/audio/noson/default.nix b/pkgs/applications/audio/noson/default.nix index bf2c115758c48d..0ab89c1085241f 100644 --- a/pkgs/applications/audio/noson/default.nix +++ b/pkgs/applications/audio/noson/default.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, flac -, libpulseaudio -, qtbase -, qtgraphicaleffects -, qtquickcontrols2 -, wrapQtAppsHook -, makeWrapper +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + flac, + libpulseaudio, + qtbase, + qtgraphicaleffects, + qtquickcontrols2, + wrapQtAppsHook, + makeWrapper, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/audio/open-music-kontrollers/eteroj.nix b/pkgs/applications/audio/open-music-kontrollers/eteroj.nix index 60de97ca3d0de6..6076a8ff2f7922 100644 --- a/pkgs/applications/audio/open-music-kontrollers/eteroj.nix +++ b/pkgs/applications/audio/open-music-kontrollers/eteroj.nix @@ -1,10 +1,13 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./generic.nix (args // rec { - pname = "eteroj"; - version = "0.10.0"; +callPackage ./generic.nix ( + args + // rec { + pname = "eteroj"; + version = "0.10.0"; - sha256 = "18iv1sdwm0g6b53shsylj6bf3svmvvy5xadhfsgb4xg39qr07djz"; + sha256 = "18iv1sdwm0g6b53shsylj6bf3svmvvy5xadhfsgb4xg39qr07djz"; - description = "OSC injection/ejection from/to UDP/TCP/Serial for LV2"; -}) + description = "OSC injection/ejection from/to UDP/TCP/Serial for LV2"; + } +) diff --git a/pkgs/applications/audio/open-music-kontrollers/generic.nix b/pkgs/applications/audio/open-music-kontrollers/generic.nix index 4c4211e49f0aef..9d07272720aca1 100644 --- a/pkgs/applications/audio/open-music-kontrollers/generic.nix +++ b/pkgs/applications/audio/open-music-kontrollers/generic.nix @@ -1,9 +1,24 @@ -{ stdenv, lib, fetchurl, pkg-config, meson, ninja, lv2, sord, libX11, libXext, glew, lv2lint -, pname, version, sha256, description -, url ? "https://git.open-music-kontrollers.ch/lv2/${pname}.lv2/snapshot/${pname}.lv2-${version}.tar.xz" -, additionalBuildInputs ? [] -, postPatch ? "" -, ... +{ + stdenv, + lib, + fetchurl, + pkg-config, + meson, + ninja, + lv2, + sord, + libX11, + libXext, + glew, + lv2lint, + pname, + version, + sha256, + description, + url ? "https://git.open-music-kontrollers.ch/lv2/${pname}.lv2/snapshot/${pname}.lv2-${version}.tar.xz", + additionalBuildInputs ? [ ], + postPatch ? "", + ... }: stdenv.mkDerivation { @@ -17,7 +32,11 @@ stdenv.mkDerivation { url = url; sha256 = sha256; }; - nativeBuildInputs = [ pkg-config meson ninja ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + ]; buildInputs = [ lv2 sord diff --git a/pkgs/applications/audio/open-music-kontrollers/jit.nix b/pkgs/applications/audio/open-music-kontrollers/jit.nix index b82b12385ea3cc..ff6b4f46a9ddda 100644 --- a/pkgs/applications/audio/open-music-kontrollers/jit.nix +++ b/pkgs/applications/audio/open-music-kontrollers/jit.nix @@ -1,12 +1,25 @@ -{ callPackage, lv2, fontconfig, libvterm-neovim, ... } @ args: +{ + callPackage, + lv2, + fontconfig, + libvterm-neovim, + ... +}@args: -callPackage ./generic.nix (args // rec { - pname = "jit"; - version = "unstable-2021-08-15"; - url = "https://git.open-music-kontrollers.ch/lv2/${pname}.lv2/snapshot/${pname}.lv2-1f5d6935049fc0dd5a4dc257b84b36d2048f2d83.tar.xz"; - sha256 = "sha256-XGICowVb0JgLJpn2h9GtViobYTdmo1LJ7/JFEyVsIqU="; +callPackage ./generic.nix ( + args + // rec { + pname = "jit"; + version = "unstable-2021-08-15"; + url = "https://git.open-music-kontrollers.ch/lv2/${pname}.lv2/snapshot/${pname}.lv2-1f5d6935049fc0dd5a4dc257b84b36d2048f2d83.tar.xz"; + sha256 = "sha256-XGICowVb0JgLJpn2h9GtViobYTdmo1LJ7/JFEyVsIqU="; - additionalBuildInputs = [ lv2 fontconfig libvterm-neovim ]; + additionalBuildInputs = [ + lv2 + fontconfig + libvterm-neovim + ]; - description = "Just-in-Time C/Rust compiler embedded in an LV2 plugin"; -}) + description = "Just-in-Time C/Rust compiler embedded in an LV2 plugin"; + } +) diff --git a/pkgs/applications/audio/open-music-kontrollers/mephisto.nix b/pkgs/applications/audio/open-music-kontrollers/mephisto.nix index e63c2fb7325c2d..f64577d53e75c4 100644 --- a/pkgs/applications/audio/open-music-kontrollers/mephisto.nix +++ b/pkgs/applications/audio/open-music-kontrollers/mephisto.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromSourcehut -, pkg-config -, cmake -, meson -, ninja -, faust -, fontconfig -, glew -, libvterm-neovim -, lv2 -, lv2lint -, sord -, xorg +{ + stdenv, + lib, + fetchFromSourcehut, + pkg-config, + cmake, + meson, + ninja, + faust, + fontconfig, + glew, + libvterm-neovim, + lv2, + lv2lint, + sord, + xorg, }: stdenv.mkDerivation (finalAttrs: { @@ -27,7 +28,13 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-ab6OGt1XVgynKNdszzdXwJ/jVKJSzgSmAv6j1U3/va0="; }; - nativeBuildInputs = [ pkg-config meson ninja fontconfig cmake ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + fontconfig + cmake + ]; buildInputs = [ faust diff --git a/pkgs/applications/audio/open-music-kontrollers/midi_matrix.nix b/pkgs/applications/audio/open-music-kontrollers/midi_matrix.nix index 7da92eb45b18e1..7185ef17858510 100644 --- a/pkgs/applications/audio/open-music-kontrollers/midi_matrix.nix +++ b/pkgs/applications/audio/open-music-kontrollers/midi_matrix.nix @@ -1,10 +1,13 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./generic.nix (args // rec { - pname = "midi_matrix"; - version = "0.30.0"; +callPackage ./generic.nix ( + args + // rec { + pname = "midi_matrix"; + version = "0.30.0"; - sha256 = "1nwmfxdzk4pvbwcgi3d7v4flqc10bmi2fxhrhrpfa7cafqs40ib6"; + sha256 = "1nwmfxdzk4pvbwcgi3d7v4flqc10bmi2fxhrhrpfa7cafqs40ib6"; - description = "LV2 MIDI channel matrix patcher"; -}) + description = "LV2 MIDI channel matrix patcher"; + } +) diff --git a/pkgs/applications/audio/open-music-kontrollers/moony.nix b/pkgs/applications/audio/open-music-kontrollers/moony.nix index 6087e05537652c..d2eda0a202b7d2 100644 --- a/pkgs/applications/audio/open-music-kontrollers/moony.nix +++ b/pkgs/applications/audio/open-music-kontrollers/moony.nix @@ -1,13 +1,28 @@ -{ callPackage, cairo, libvterm-neovim, robodoc, cmake, ... } @ args: +{ + callPackage, + cairo, + libvterm-neovim, + robodoc, + cmake, + ... +}@args: -callPackage ./generic.nix (args // rec { - pname = "moony"; - version = "0.40.0"; +callPackage ./generic.nix ( + args + // rec { + pname = "moony"; + version = "0.40.0"; - sha256 = "sha256-9a3gR3lV8xFFTDZD+fJPCALVztgmggzyIpsPZCOw/uY="; + sha256 = "sha256-9a3gR3lV8xFFTDZD+fJPCALVztgmggzyIpsPZCOw/uY="; - additionalBuildInputs = [ cairo libvterm-neovim robodoc cmake ]; + additionalBuildInputs = [ + cairo + libvterm-neovim + robodoc + cmake + ]; - description = "Realtime Lua as programmable glue in LV2"; + description = "Realtime Lua as programmable glue in LV2"; -}) + } +) diff --git a/pkgs/applications/audio/open-music-kontrollers/orbit.nix b/pkgs/applications/audio/open-music-kontrollers/orbit.nix index 21fdf44b24c043..be7d0b5844d991 100644 --- a/pkgs/applications/audio/open-music-kontrollers/orbit.nix +++ b/pkgs/applications/audio/open-music-kontrollers/orbit.nix @@ -1,12 +1,15 @@ -{ callPackage, zlib, ... } @ args: +{ callPackage, zlib, ... }@args: -callPackage ./generic.nix (args // rec { - pname = "orbit"; - version = "unstable-2021-04-13"; - url = "https://git.open-music-kontrollers.ch/lv2/${pname}.lv2/snapshot/${pname}.lv2-f4aa620fc8d77418856581a6a955192af15b3860.tar.xz"; - sha256 = "0z8d8h2w8fb2zx84n697jvy32dc0vf60jyiyh4gm22prgr2dvgkc"; +callPackage ./generic.nix ( + args + // rec { + pname = "orbit"; + version = "unstable-2021-04-13"; + url = "https://git.open-music-kontrollers.ch/lv2/${pname}.lv2/snapshot/${pname}.lv2-f4aa620fc8d77418856581a6a955192af15b3860.tar.xz"; + sha256 = "0z8d8h2w8fb2zx84n697jvy32dc0vf60jyiyh4gm22prgr2dvgkc"; - additionalBuildInputs = [ zlib ]; + additionalBuildInputs = [ zlib ]; - description = "LV2 time event manipulation plugin bundle"; -}) + description = "LV2 time event manipulation plugin bundle"; + } +) diff --git a/pkgs/applications/audio/open-music-kontrollers/patchmatrix.nix b/pkgs/applications/audio/open-music-kontrollers/patchmatrix.nix index 39b68ba3a577cd..0e550c60b2b070 100644 --- a/pkgs/applications/audio/open-music-kontrollers/patchmatrix.nix +++ b/pkgs/applications/audio/open-music-kontrollers/patchmatrix.nix @@ -1,13 +1,16 @@ -{ callPackage, libjack2, ... } @ args: +{ callPackage, libjack2, ... }@args: -callPackage ./generic.nix (args // rec { - pname = "patchmatrix"; - version = "0.26.0"; +callPackage ./generic.nix ( + args + // rec { + pname = "patchmatrix"; + version = "0.26.0"; - url = "https://git.open-music-kontrollers.ch/lad/${pname}/snapshot/${pname}-${version}.tar.xz"; - sha256 = "sha256-cqPHCnrAhHB6a0xmPUYOAsZfLsqnGpXEuGR1W6i6W7I="; + url = "https://git.open-music-kontrollers.ch/lad/${pname}/snapshot/${pname}-${version}.tar.xz"; + sha256 = "sha256-cqPHCnrAhHB6a0xmPUYOAsZfLsqnGpXEuGR1W6i6W7I="; - additionalBuildInputs = [ libjack2 ]; + additionalBuildInputs = [ libjack2 ]; - description = "JACK patchbay in flow matrix style"; -}) + description = "JACK patchbay in flow matrix style"; + } +) diff --git a/pkgs/applications/audio/open-music-kontrollers/router.nix b/pkgs/applications/audio/open-music-kontrollers/router.nix index b7e734db2803c2..b9037d2ed78bc7 100644 --- a/pkgs/applications/audio/open-music-kontrollers/router.nix +++ b/pkgs/applications/audio/open-music-kontrollers/router.nix @@ -1,11 +1,14 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./generic.nix (args // rec { - pname = "router"; - version = "unstable-2021-04-13"; +callPackage ./generic.nix ( + args + // rec { + pname = "router"; + version = "unstable-2021-04-13"; - url = "https://git.open-music-kontrollers.ch/lv2/${pname}.lv2/snapshot/${pname}.lv2-7d754dd64c540d40b828166401617715dc235ca3.tar.xz"; - sha256 = "sha256-LjaW5Xdxfjzd6IJ2ptHzmHt7fhU1HQo7ubZ4USVqRE8="; + url = "https://git.open-music-kontrollers.ch/lv2/${pname}.lv2/snapshot/${pname}.lv2-7d754dd64c540d40b828166401617715dc235ca3.tar.xz"; + sha256 = "sha256-LjaW5Xdxfjzd6IJ2ptHzmHt7fhU1HQo7ubZ4USVqRE8="; - description = "Atom/Audio/CV router LV2 plugin bundle"; -}) + description = "Atom/Audio/CV router LV2 plugin bundle"; + } +) diff --git a/pkgs/applications/audio/open-music-kontrollers/sherlock.nix b/pkgs/applications/audio/open-music-kontrollers/sherlock.nix index c8ae0afd09a750..0a79951cd9dd53 100644 --- a/pkgs/applications/audio/open-music-kontrollers/sherlock.nix +++ b/pkgs/applications/audio/open-music-kontrollers/sherlock.nix @@ -1,12 +1,23 @@ -{ callPackage, sratom, flex, ... } @ args: +{ + callPackage, + sratom, + flex, + ... +}@args: -callPackage ./generic.nix (args // rec { - pname = "sherlock"; - version = "0.28.0"; +callPackage ./generic.nix ( + args + // rec { + pname = "sherlock"; + version = "0.28.0"; - sha256 = "07zj88s1593fpw2s0r3ix7cj2icfd9zyirsyhr2i8l6d30b6n6fb"; + sha256 = "07zj88s1593fpw2s0r3ix7cj2icfd9zyirsyhr2i8l6d30b6n6fb"; - additionalBuildInputs = [ sratom flex ]; + additionalBuildInputs = [ + sratom + flex + ]; - description = "Plugins for visualizing LV2 atom, MIDI and OSC events"; -}) + description = "Plugins for visualizing LV2 atom, MIDI and OSC events"; + } +) diff --git a/pkgs/applications/audio/open-music-kontrollers/synthpod.nix b/pkgs/applications/audio/open-music-kontrollers/synthpod.nix index 9b7964e839bf73..e513a2f61bbdec 100644 --- a/pkgs/applications/audio/open-music-kontrollers/synthpod.nix +++ b/pkgs/applications/audio/open-music-kontrollers/synthpod.nix @@ -1,13 +1,45 @@ -{ callPackage, lilv, libjack2, alsa-lib, zita-alsa-pcmi, libxcb, xcbutilxrm, sratom, gtk2, qt5, libvterm-neovim, robodoc, cmake,... } @ args: +{ + callPackage, + lilv, + libjack2, + alsa-lib, + zita-alsa-pcmi, + libxcb, + xcbutilxrm, + sratom, + gtk2, + qt5, + libvterm-neovim, + robodoc, + cmake, + ... +}@args: -callPackage ./generic.nix (args // rec { - pname = "synthpod"; - version = "unstable-2021-10-22"; +callPackage ./generic.nix ( + args + // rec { + pname = "synthpod"; + version = "unstable-2021-10-22"; - url = "https://git.open-music-kontrollers.ch/lv2/synthpod/snapshot/synthpod-6f284bdad882037a522c120af92b96d8abf2de60.tar.xz"; - sha256 = "sha256-59WBlOKum5Pcmq2CfFfRHCNEa8uPCoBk0kSjFlIcypw="; + url = "https://git.open-music-kontrollers.ch/lv2/synthpod/snapshot/synthpod-6f284bdad882037a522c120af92b96d8abf2de60.tar.xz"; + sha256 = "sha256-59WBlOKum5Pcmq2CfFfRHCNEa8uPCoBk0kSjFlIcypw="; - additionalBuildInputs = [ lilv libjack2 alsa-lib zita-alsa-pcmi libxcb xcbutilxrm sratom gtk2 qt5.qtbase qt5.wrapQtAppsHook libvterm-neovim robodoc cmake ]; + additionalBuildInputs = [ + lilv + libjack2 + alsa-lib + zita-alsa-pcmi + libxcb + xcbutilxrm + sratom + gtk2 + qt5.qtbase + qt5.wrapQtAppsHook + libvterm-neovim + robodoc + cmake + ]; - description = "Lightweight Nonlinear LV2 Plugin Container"; -}) + description = "Lightweight Nonlinear LV2 Plugin Container"; + } +) diff --git a/pkgs/applications/audio/open-music-kontrollers/vm.nix b/pkgs/applications/audio/open-music-kontrollers/vm.nix index c35da5bf363649..79f8144f54c6b8 100644 --- a/pkgs/applications/audio/open-music-kontrollers/vm.nix +++ b/pkgs/applications/audio/open-music-kontrollers/vm.nix @@ -1,10 +1,13 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./generic.nix (args // rec { - pname = "vm"; - version = "0.14.0"; +callPackage ./generic.nix ( + args + // rec { + pname = "vm"; + version = "0.14.0"; - sha256 = "013gq7jn556nkk1nq6zzh9nmp3fb36jd7ndzvyq3qryw7khzkagc"; + sha256 = "013gq7jn556nkk1nq6zzh9nmp3fb36jd7ndzvyq3qryw7khzkagc"; - description = "Programmable virtual machine LV2 plugin"; -}) + description = "Programmable virtual machine LV2 plugin"; + } +) diff --git a/pkgs/applications/audio/padthv1/default.nix b/pkgs/applications/audio/padthv1/default.nix index f51a3f69a2c5d8..4254b53bbd9192 100644 --- a/pkgs/applications/audio/padthv1/default.nix +++ b/pkgs/applications/audio/padthv1/default.nix @@ -1,4 +1,16 @@ -{ lib, fetchurl, pkg-config, libjack2, alsa-lib, libsndfile, liblo, lv2, qt5, fftwFloat, mkDerivation }: +{ + lib, + fetchurl, + pkg-config, + libjack2, + alsa-lib, + libsndfile, + liblo, + lv2, + qt5, + fftwFloat, + mkDerivation, +}: mkDerivation rec { pname = "padthv1"; @@ -9,7 +21,16 @@ mkDerivation rec { sha256 = "sha256-9yFfvlskOYnGraou2S3Qffl8RoYJqE0wnDlOP8mxQgg="; }; - buildInputs = [ libjack2 alsa-lib libsndfile liblo lv2 qt5.qtbase qt5.qttools fftwFloat ]; + buildInputs = [ + libjack2 + alsa-lib + libsndfile + liblo + lv2 + qt5.qtbase + qt5.qttools + fftwFloat + ]; nativeBuildInputs = [ pkg-config ]; diff --git a/pkgs/applications/audio/parrot/default.nix b/pkgs/applications/audio/parrot/default.nix index d7da9213bce85f..c34bd7649b13bd 100644 --- a/pkgs/applications/audio/parrot/default.nix +++ b/pkgs/applications/audio/parrot/default.nix @@ -1,16 +1,17 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, cmake -, ffmpeg -, libopus -, makeBinaryWrapper -, unstableGitUpdater -, openssl -, pkg-config -, stdenv -, yt-dlp -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + cmake, + ffmpeg, + libopus, + makeBinaryWrapper, + unstableGitUpdater, + openssl, + pkg-config, + stdenv, + yt-dlp, + Security, }: rustPlatform.buildRustPackage { pname = "parrot"; @@ -25,14 +26,25 @@ rustPlatform.buildRustPackage { cargoHash = "sha256-3G7NwSZaiocjgfdtmJVWfMZOHCNhC08NgolPa9AvPfE="; - nativeBuildInputs = [ cmake makeBinaryWrapper pkg-config ]; + nativeBuildInputs = [ + cmake + makeBinaryWrapper + pkg-config + ]; - buildInputs = [ libopus openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; + buildInputs = [ + libopus + openssl + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; postInstall = '' wrapProgram $out/bin/parrot \ - --prefix PATH : ${lib.makeBinPath [ ffmpeg yt-dlp ]} + --prefix PATH : ${ + lib.makeBinPath [ + ffmpeg + yt-dlp + ] + } ''; passthru.updateScript = unstableGitUpdater { diff --git a/pkgs/applications/audio/patchance/default.nix b/pkgs/applications/audio/patchance/default.nix index a1b39b1d78a3e8..c527bc7037c2ba 100644 --- a/pkgs/applications/audio/patchance/default.nix +++ b/pkgs/applications/audio/patchance/default.nix @@ -1,4 +1,13 @@ -{ lib, fetchurl, buildPythonApplication, libjack2, pyqt5, qt5, which, bash }: +{ + lib, + fetchurl, + buildPythonApplication, + libjack2, + pyqt5, + qt5, + which, + bash, +}: buildPythonApplication rec { pname = "patchance"; @@ -12,12 +21,15 @@ buildPythonApplication rec { format = "other"; nativeBuildInputs = [ - pyqt5 # pyuic5 and pyrcc5 to build resources. + pyqt5 # pyuic5 and pyrcc5 to build resources. qt5.qttools # lrelease to build translations. - which # which to find lrelease. + which # which to find lrelease. qt5.wrapQtAppsHook ]; - buildInputs = [ libjack2 bash ]; + buildInputs = [ + libjack2 + bash + ]; propagatedBuildInputs = [ pyqt5 ]; dontWrapQtApps = true; # The program is a python script. @@ -25,7 +37,10 @@ buildPythonApplication rec { installFlags = [ "PREFIX=$(out)" ]; makeWrapperArgs = [ - "--suffix" "LD_LIBRARY_PATH" ":" (lib.makeLibraryPath [ libjack2 ]) + "--suffix" + "LD_LIBRARY_PATH" + ":" + (lib.makeLibraryPath [ libjack2 ]) ]; preFixup = '' diff --git a/pkgs/applications/audio/pd-plugins/timbreid/default.nix b/pkgs/applications/audio/pd-plugins/timbreid/default.nix index f3da39f15b33d6..b11e6ffcdb55e2 100644 --- a/pkgs/applications/audio/pd-plugins/timbreid/default.nix +++ b/pkgs/applications/audio/pd-plugins/timbreid/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, unzip, puredata, fftw }: +{ + lib, + stdenv, + fetchurl, + unzip, + puredata, + fftw, +}: stdenv.mkDerivation rec { version = "0.7.0"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ unzip ]; - buildInputs = [ puredata fftw ]; + buildInputs = [ + puredata + fftw + ]; unpackPhase = '' mkdir source @@ -20,7 +30,7 @@ stdenv.mkDerivation rec { buildPhase = '' make tIDLib.o all - ''; + ''; installPhase = '' mkdir -p $out/ @@ -34,7 +44,7 @@ stdenv.mkDerivation rec { postFixup = '' mv $out/share/doc/ $out/ rm -rf $out/share/ - ''; + ''; meta = { description = "Collection of audio feature analysis externals for puredata"; diff --git a/pkgs/applications/audio/pd-plugins/zexy/default.nix b/pkgs/applications/audio/pd-plugins/zexy/default.nix index 3e5285fbba406d..642ccee603b80f 100644 --- a/pkgs/applications/audio/pd-plugins/zexy/default.nix +++ b/pkgs/applications/audio/pd-plugins/zexy/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, autoconf, automake, puredata }: +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + puredata, +}: stdenv.mkDerivation rec { pname = "zexy"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "1xpgl82c2lc6zfswjsa7z10yhv5jb7a4znzh3nc7ffrzm1z8vylp"; }; - nativeBuildInputs = [ autoconf automake ]; + nativeBuildInputs = [ + autoconf + automake + ]; buildInputs = [ puredata ]; preBuild = '' diff --git a/pkgs/applications/audio/petrifoo/default.nix b/pkgs/applications/audio/petrifoo/default.nix index e8298ea321c393..de8d4dc7920f24 100644 --- a/pkgs/applications/audio/petrifoo/default.nix +++ b/pkgs/applications/audio/petrifoo/default.nix @@ -1,13 +1,28 @@ -{ lib, stdenv, fetchurl, fetchpatch, alsa-lib, cmake, gtk2, libjack2, libgnomecanvas -, libpthreadstubs, libsamplerate, libsndfile, libtool, libxml2 -, pkg-config, openssl }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + alsa-lib, + cmake, + gtk2, + libjack2, + libgnomecanvas, + libpthreadstubs, + libsamplerate, + libsndfile, + libtool, + libxml2, + pkg-config, + openssl, +}: -stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "petri-foo"; version = "0.1.87"; src = fetchurl { - url = "mirror://sourceforge/petri-foo/${pname}-${version}.tar.bz2"; + url = "mirror://sourceforge/petri-foo/${pname}-${version}.tar.bz2"; sha256 = "0b25iicgn8c42487fdw32ycfrll1pm2zjgy5djvgw6mfcaa4gizh"; }; @@ -21,10 +36,23 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ alsa-lib gtk2 libjack2 libgnomecanvas libpthreadstubs - libsamplerate libsndfile libtool libxml2 openssl ]; + buildInputs = [ + alsa-lib + gtk2 + libjack2 + libgnomecanvas + libpthreadstubs + libsamplerate + libsndfile + libtool + libxml2 + openssl + ]; meta = with lib; { description = "MIDI controllable audio sampler"; diff --git a/pkgs/applications/audio/pianobooster/default.nix b/pkgs/applications/audio/pianobooster/default.nix index 216ca845f1fa10..3ec19cf487dc5e 100644 --- a/pkgs/applications/audio/pianobooster/default.nix +++ b/pkgs/applications/audio/pianobooster/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, qttools -, alsa-lib -, ftgl -, libGLU -, qtbase -, rtmidi -, libjack2 -, fluidsynth -, soundfont-fluid -, unzip -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + qttools, + alsa-lib, + ftgl, + libGLU, + qtbase, + rtmidi, + libjack2, + fluidsynth, + soundfont-fluid, + unzip, + wrapQtAppsHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/audio/pipecontrol/default.nix b/pkgs/applications/audio/pipecontrol/default.nix index 4bed5cb25037e5..63b8160868f8ac 100644 --- a/pkgs/applications/audio/pipecontrol/default.nix +++ b/pkgs/applications/audio/pipecontrol/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, pipewire -, cmake -, extra-cmake-modules -, wrapQtAppsHook -, qtbase -, qttools -, kirigami2 -, kcoreaddons -, ki18n -, qtquickcontrols2 +{ + lib, + stdenv, + fetchFromGitHub, + pipewire, + cmake, + extra-cmake-modules, + wrapQtAppsHook, + qtbase, + qttools, + kirigami2, + kcoreaddons, + ki18n, + qtquickcontrols2, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/audio/pithos/default.nix b/pkgs/applications/audio/pithos/default.nix index a9ea4096859c77..dd3473c069b4dc 100644 --- a/pkgs/applications/audio/pithos/default.nix +++ b/pkgs/applications/audio/pithos/default.nix @@ -1,6 +1,21 @@ -{ stdenv, lib, fetchFromGitHub, meson, ninja, pkg-config, appstream-glib, glib -, wrapGAppsHook3, pythonPackages, gtk3, adwaita-icon-theme, gobject-introspection -, libnotify, libsecret, gst_all_1 }: +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + appstream-glib, + glib, + wrapGAppsHook3, + pythonPackages, + gtk3, + adwaita-icon-theme, + gobject-introspection, + libnotify, + libsecret, + gst_all_1, +}: pythonPackages.buildPythonApplication rec { pname = "pithos"; @@ -8,7 +23,7 @@ pythonPackages.buildPythonApplication rec { src = fetchFromGitHub { owner = pname; - repo = pname; + repo = pname; rev = "refs/tags/${version}"; hash = "sha256-3j6IoMi30BQ8WHK4BxbsW+/3XZx7rBFd47EBENa2GiQ="; }; @@ -20,14 +35,36 @@ pythonPackages.buildPythonApplication rec { patchShebangs meson_post_install.py ''; - nativeBuildInputs = [ meson ninja pkg-config appstream-glib wrapGAppsHook3 gobject-introspection ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + appstream-glib + wrapGAppsHook3 + gobject-introspection + ]; - buildInputs = [ gtk3 libnotify libsecret glib ] - ++ (with gst_all_1; [ gstreamer gst-plugins-base gst-plugins-good gst-plugins-ugly gst-plugins-bad ]); + buildInputs = + [ + gtk3 + libnotify + libsecret + glib + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-ugly + gst-plugins-bad + ]); propagatedBuildInputs = - [ adwaita-icon-theme ] ++ - (with pythonPackages; [ pygobject3 pylast ]); + [ adwaita-icon-theme ] + ++ (with pythonPackages; [ + pygobject3 + pylast + ]); meta = with lib; { broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/applications/audio/playbar2/default.nix b/pkgs/applications/audio/playbar2/default.nix index dfbfb43e625c55..f698a39440a6fd 100644 --- a/pkgs/applications/audio/playbar2/default.nix +++ b/pkgs/applications/audio/playbar2/default.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, cmake -, extra-cmake-modules -, plasma-framework -, kwindowsystem -, fetchFromGitHub +{ + lib, + stdenv, + cmake, + extra-cmake-modules, + plasma-framework, + kwindowsystem, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/audio/plexamp/default.nix b/pkgs/applications/audio/plexamp/default.nix index b11a35c25dc560..bd949f5de67ef4 100644 --- a/pkgs/applications/audio/plexamp/default.nix +++ b/pkgs/applications/audio/plexamp/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, appimageTools, makeWrapper }: +{ + lib, + fetchurl, + appimageTools, + makeWrapper, +}: let pname = "plexamp"; @@ -35,7 +40,11 @@ appimageTools.wrapType2 { homepage = "https://plexamp.com/"; changelog = "https://forums.plex.tv/t/plexamp-release-notes/221280/76"; license = licenses.unfree; - maintainers = with maintainers; [ killercup redhawk synthetica ]; + maintainers = with maintainers; [ + killercup + redhawk + synthetica + ]; platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/applications/audio/pocket-casts/default.nix b/pkgs/applications/audio/pocket-casts/default.nix index ca5d25dd6a732a..b34c5eed3d0163 100644 --- a/pkgs/applications/audio/pocket-casts/default.nix +++ b/pkgs/applications/audio/pocket-casts/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, makeDesktopItem -, copyDesktopItems -, makeWrapper -, electron +{ + lib, + buildNpmPackage, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + makeWrapper, + electron, }: buildNpmPackage rec { diff --git a/pkgs/applications/audio/projectm/default.nix b/pkgs/applications/audio/projectm/default.nix index f7ca3d37793b6f..09db5ad83393ff 100644 --- a/pkgs/applications/audio/projectm/default.nix +++ b/pkgs/applications/audio/projectm/default.nix @@ -1,14 +1,15 @@ -{ stdenv -, mkDerivation -, lib -, fetchFromGitHub -, autoreconfHook -, pkg-config -, SDL2 -, qtdeclarative -, libpulseaudio -, glm -, which +{ + stdenv, + mkDerivation, + lib, + fetchFromGitHub, + autoreconfHook, + pkg-config, + SDL2, + qtdeclarative, + libpulseaudio, + glm, + which, }: mkDerivation rec { @@ -40,16 +41,18 @@ mkDerivation rec { "--enable-sdl" ]; - fixupPhase = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - # NOTE: 2019-10-05: Upstream inserts the src path buring build into ELF rpath, so must delete it out - # upstream report: https://github.com/projectM-visualizer/projectm/issues/245 - for entry in $out/bin/* ; do - patchelf --set-rpath "$(patchelf --print-rpath $entry | tr ':' '\n' | grep -v 'src/libprojectM' | tr '\n' ':')" "$entry" - done - '' + '' - wrapQtApp $out/bin/projectM-pulseaudio - rm $out/bin/projectM-unittest - ''; + fixupPhase = + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + # NOTE: 2019-10-05: Upstream inserts the src path buring build into ELF rpath, so must delete it out + # upstream report: https://github.com/projectM-visualizer/projectm/issues/245 + for entry in $out/bin/* ; do + patchelf --set-rpath "$(patchelf --print-rpath $entry | tr ':' '\n' | grep -v 'src/libprojectM' | tr '\n' ':')" "$entry" + done + '' + + '' + wrapQtApp $out/bin/projectM-pulseaudio + rm $out/bin/projectM-unittest + ''; meta = { homepage = "https://github.com/projectM-visualizer/projectm"; diff --git a/pkgs/applications/audio/puddletag/default.nix b/pkgs/applications/audio/puddletag/default.nix index 09ed89bb2ba210..415e1ce8425e12 100644 --- a/pkgs/applications/audio/puddletag/default.nix +++ b/pkgs/applications/audio/puddletag/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, fetchurl -, python3 -, qtbase -, qtwayland -, wrapQtAppsHook +{ + lib, + fetchFromGitHub, + fetchurl, + python3, + qtbase, + qtwayland, + wrapQtAppsHook, }: python3.pkgs.buildPythonApplication rec { @@ -77,7 +78,10 @@ python3.pkgs.buildPythonApplication rec { mainProgram = "puddletag"; homepage = "https://docs.puddletag.net"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ peterhoeg dschrempf ]; + maintainers = with maintainers; [ + peterhoeg + dschrempf + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/audio/puredata/default.nix b/pkgs/applications/audio/puredata/default.nix index f4206cb0ea7ccd..32eef50a106892 100644 --- a/pkgs/applications/audio/puredata/default.nix +++ b/pkgs/applications/audio/puredata/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, gettext -, makeWrapper -, alsa-lib -, libjack2 -, tk -, fftw -, portaudio +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + gettext, + makeWrapper, + alsa-lib, + libjack2, + tk, + fftw, + portaudio, }: stdenv.mkDerivation rec { @@ -20,29 +21,39 @@ stdenv.mkDerivation rec { hash = "sha256-hcPUvTYgtAHntdWEeHoFIIKylMTE7us1g9dwnZP9BMI="; }; - nativeBuildInputs = [ autoreconfHook gettext makeWrapper ]; - - buildInputs = [ - fftw - libjack2 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - portaudio + nativeBuildInputs = [ + autoreconfHook + gettext + makeWrapper ]; - configureFlags = [ - "--enable-universal" - "--enable-fftw" - "--enable-jack" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "--enable-alsa" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "--enable-portaudio" - "--without-local-portaudio" - "--disable-jack-framework" - "--with-wish=${tk}/bin/wish8.6" - ]; + buildInputs = + [ + fftw + libjack2 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + portaudio + ]; + + configureFlags = + [ + "--enable-universal" + "--enable-fftw" + "--enable-jack" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "--enable-alsa" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "--enable-portaudio" + "--without-local-portaudio" + "--disable-jack-framework" + "--with-wish=${tk}/bin/wish8.6" + ]; postInstall = '' wrapProgram $out/bin/pd --prefix PATH : ${lib.makeBinPath [ tk ]} diff --git a/pkgs/applications/audio/puredata/wrapper.nix b/pkgs/applications/audio/puredata/wrapper.nix index 3444ef9acbdc1d..526dd0f3da38a9 100644 --- a/pkgs/applications/audio/puredata/wrapper.nix +++ b/pkgs/applications/audio/puredata/wrapper.nix @@ -1,8 +1,14 @@ -{ symlinkJoin, puredata, makeWrapper, plugins }: +{ + symlinkJoin, + puredata, + makeWrapper, + plugins, +}: let -puredataFlags = map (x: "-path ${x}/") plugins; -in symlinkJoin { + puredataFlags = map (x: "-path ${x}/") plugins; +in +symlinkJoin { name = "puredata-with-plugins-${puredata.version}"; paths = [ puredata ] ++ plugins; diff --git a/pkgs/applications/audio/qmidinet/default.nix b/pkgs/applications/audio/qmidinet/default.nix index f6985abfbe3f85..782ddc61326087 100644 --- a/pkgs/applications/audio/qmidinet/default.nix +++ b/pkgs/applications/audio/qmidinet/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchurl, pkg-config, qtbase, qttools, alsa-lib, libjack2 }: +{ + mkDerivation, + lib, + fetchurl, + pkg-config, + qtbase, + qttools, + alsa-lib, + libjack2, +}: mkDerivation rec { version = "0.9.4"; @@ -11,7 +20,12 @@ mkDerivation rec { hardeningDisable = [ "format" ]; - buildInputs = [ qtbase qttools alsa-lib libjack2 ]; + buildInputs = [ + qtbase + qttools + alsa-lib + libjack2 + ]; nativeBuildInputs = [ pkg-config ]; diff --git a/pkgs/applications/audio/qmmp/default.nix b/pkgs/applications/audio/qmmp/default.nix index 1496efd886ca90..407d44c785da29 100644 --- a/pkgs/applications/audio/qmmp/default.nix +++ b/pkgs/applications/audio/qmmp/default.nix @@ -1,15 +1,46 @@ -{ lib, stdenv, fetchurl, cmake, pkg-config -, qtbase, qttools, qtmultimedia, wrapQtAppsHook -# transports -, curl, libmms -# input plugins -, libmad, taglib, libvorbis, libogg, flac, libmpcdec, libmodplug, libsndfile -, libcdio, cdparanoia, libcddb, faad2, ffmpeg, wildmidi, libbs2b, game-music-emu -, libarchive, opusfile, soxr, wavpack, libxmp, libsidplayfp -# output plugins -, alsa-lib, libpulseaudio, pipewire, libjack2 -# effect plugins -, libsamplerate +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + qtbase, + qttools, + qtmultimedia, + wrapQtAppsHook, + # transports + curl, + libmms, + # input plugins + libmad, + taglib, + libvorbis, + libogg, + flac, + libmpcdec, + libmodplug, + libsndfile, + libcdio, + cdparanoia, + libcddb, + faad2, + ffmpeg, + wildmidi, + libbs2b, + game-music-emu, + libarchive, + opusfile, + soxr, + wavpack, + libxmp, + libsidplayfp, + # output plugins + alsa-lib, + libpulseaudio, + pipewire, + libjack2, + # effect plugins + libsamplerate, }: # Additional plugins that can be added: @@ -33,22 +64,51 @@ stdenv.mkDerivation rec { hash = "sha256-hGphQ8epqym47C9doiSOQd3yc28XwV2UsNc7ivhaae4="; }; - nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook ]; - - buildInputs = - [ # basic requirements - qtbase qttools qtmultimedia - # transports - curl libmms - # input plugins - libmad taglib libvorbis libogg flac libmpcdec libmodplug libsndfile - libcdio cdparanoia libcddb faad2 ffmpeg wildmidi libbs2b game-music-emu - libarchive opusfile soxr wavpack libxmp libsidplayfp - # output plugins - alsa-lib libpulseaudio pipewire libjack2 - # effect plugins - libsamplerate - ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapQtAppsHook + ]; + + buildInputs = [ + # basic requirements + qtbase + qttools + qtmultimedia + # transports + curl + libmms + # input plugins + libmad + taglib + libvorbis + libogg + flac + libmpcdec + libmodplug + libsndfile + libcdio + cdparanoia + libcddb + faad2 + ffmpeg + wildmidi + libbs2b + game-music-emu + libarchive + opusfile + soxr + wavpack + libxmp + libsidplayfp + # output plugins + alsa-lib + libpulseaudio + pipewire + libjack2 + # effect plugins + libsamplerate + ]; meta = with lib; { description = "Qt-based audio player that looks like Winamp"; diff --git a/pkgs/applications/audio/qpwgraph/default.nix b/pkgs/applications/audio/qpwgraph/default.nix index 218148ca8fa5a2..32d254f6d69d75 100644 --- a/pkgs/applications/audio/qpwgraph/default.nix +++ b/pkgs/applications/audio/qpwgraph/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitLab -, cmake -, pkg-config -, wrapQtAppsHook -, qtbase -, qtsvg -, qtwayland -, alsa-lib -, pipewire +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + pkg-config, + wrapQtAppsHook, + qtbase, + qtsvg, + qtwayland, + alsa-lib, + pipewire, }: stdenv.mkDerivation (finalAttrs: { @@ -23,9 +24,19 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-jB2mMLwJ1e/fIsf1R9Wd0stwp/RQH6f9pkF1qQX72Aw="; }; - nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapQtAppsHook + ]; - buildInputs = [ qtbase qtsvg qtwayland alsa-lib pipewire ]; + buildInputs = [ + qtbase + qtsvg + qtwayland + alsa-lib + pipewire + ]; cmakeFlags = [ "-DCONFIG_WAYLAND=ON" ]; @@ -39,7 +50,11 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://gitlab.freedesktop.org/rncbc/qpwgraph"; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ kanashimia exi Scrumplex ]; + maintainers = with maintainers; [ + kanashimia + exi + Scrumplex + ]; mainProgram = "qpwgraph"; }; }) diff --git a/pkgs/applications/audio/qsampler/default.nix b/pkgs/applications/audio/qsampler/default.nix index b4c7cf5bce1d25..46e7a5c7fea312 100644 --- a/pkgs/applications/audio/qsampler/default.nix +++ b/pkgs/applications/audio/qsampler/default.nix @@ -1,5 +1,16 @@ -{ lib, fetchurl, autoconf, automake, libtool, pkg-config, qttools -, liblscp, libgig, qtbase, mkDerivation }: +{ + lib, + fetchurl, + autoconf, + automake, + libtool, + pkg-config, + qttools, + liblscp, + libgig, + qtbase, + mkDerivation, +}: mkDerivation rec { pname = "qsampler"; @@ -10,8 +21,18 @@ mkDerivation rec { sha256 = "1wr7k739zx2nz00b810f60g9k3y92w05nfci987hw7y2sks9rd8j"; }; - nativeBuildInputs = [ autoconf automake libtool pkg-config qttools ]; - buildInputs = [ liblscp libgig qtbase ]; + nativeBuildInputs = [ + autoconf + automake + libtool + pkg-config + qttools + ]; + buildInputs = [ + liblscp + libgig + qtbase + ]; preConfigure = "make -f Makefile.svn"; diff --git a/pkgs/applications/audio/qsynth/default.nix b/pkgs/applications/audio/qsynth/default.nix index d1accf5c66d2e5..5c7ae53e0bdec5 100644 --- a/pkgs/applications/audio/qsynth/default.nix +++ b/pkgs/applications/audio/qsynth/default.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchurl, alsa-lib, fluidsynth, libjack2, cmake, pkg-config -, qtbase, qttools, qtx11extras, wrapQtAppsHook +{ + lib, + stdenv, + fetchurl, + alsa-lib, + fluidsynth, + libjack2, + cmake, + pkg-config, + qtbase, + qttools, + qtx11extras, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -11,9 +22,20 @@ stdenv.mkDerivation rec { hash = "sha256-SHMPmZMAlC9L5EAecaZNB0pWnq0heeD8bcbhKeI+YOo="; }; - nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapQtAppsHook + ]; - buildInputs = [ alsa-lib fluidsynth libjack2 qtbase qttools qtx11extras ]; + buildInputs = [ + alsa-lib + fluidsynth + libjack2 + qtbase + qttools + qtx11extras + ]; meta = with lib; { description = "Fluidsynth GUI"; diff --git a/pkgs/applications/audio/radiotray-ng/default.nix b/pkgs/applications/audio/radiotray-ng/default.nix index 6577f33baba0c6..439fa8e4a0dd77 100644 --- a/pkgs/applications/audio/radiotray-ng/default.nix +++ b/pkgs/applications/audio/radiotray-ng/default.nix @@ -1,43 +1,54 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, cmake, pkg-config -# Transport -, curl -# Libraries -, boost -, jsoncpp -, libbsd -, pcre -# GUI/Desktop -, dbus -, glibmm -, gsettings-desktop-schemas -, hicolor-icon-theme -, libappindicator-gtk3 -, libnotify -, libxdg_basedir -, wxGTK -# GStreamer -, glib-networking -, gst_all_1 -# User-agent info -, lsb-release -# rt2rtng -, python3 -# Testing -, gtest -# Fixup -, wrapGAppsHook3 -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + # Transport + curl, + # Libraries + boost, + jsoncpp, + libbsd, + pcre, + # GUI/Desktop + dbus, + glibmm, + gsettings-desktop-schemas, + hicolor-icon-theme, + libappindicator-gtk3, + libnotify, + libxdg_basedir, + wxGTK, + # GStreamer + glib-networking, + gst_all_1, + # User-agent info + lsb-release, + # rt2rtng + python3, + # Testing + gtest, + # Fixup + wrapGAppsHook3, + makeWrapper, }: let gstInputs = with gst_all_1; [ - gstreamer gst-plugins-base - gst-plugins-good gst-plugins-bad gst-plugins-ugly + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + gst-plugins-ugly gst-libav ]; # For the rt2rtng utility for converting bookmark file to -ng format - pythonInputs = with python3.pkgs; [ python lxml ]; + pythonInputs = with python3.pkgs; [ + python + lxml + ]; in stdenv.mkDerivation rec { pname = "radiotray-ng"; @@ -50,18 +61,32 @@ stdenv.mkDerivation rec { sha256 = "sha256-/0GlQdSsIPKGrDT9CgxvaH8TpAbqxFduwL2A2+BSrEI="; }; - nativeBuildInputs = [ cmake pkg-config wrapGAppsHook3 makeWrapper ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapGAppsHook3 + makeWrapper + ]; - buildInputs = [ - curl - boost jsoncpp libbsd pcre - glibmm hicolor-icon-theme gsettings-desktop-schemas libappindicator-gtk3 libnotify - libxdg_basedir - lsb-release - wxGTK - # for https gstreamer / libsoup - glib-networking - ] ++ gstInputs + buildInputs = + [ + curl + boost + jsoncpp + libbsd + pcre + glibmm + hicolor-icon-theme + gsettings-desktop-schemas + libappindicator-gtk3 + libnotify + libxdg_basedir + lsb-release + wxGTK + # for https gstreamer / libsoup + glib-networking + ] + ++ gstInputs ++ pythonInputs; patches = [ diff --git a/pkgs/applications/audio/raysession/default.nix b/pkgs/applications/audio/raysession/default.nix index 375c5d3d646cfe..cc7c0e0d5a7412 100644 --- a/pkgs/applications/audio/raysession/default.nix +++ b/pkgs/applications/audio/raysession/default.nix @@ -1,4 +1,14 @@ -{ lib, fetchurl, buildPythonApplication, libjack2, pyliblo, pyqt5, which, bash, qt5 }: +{ + lib, + fetchurl, + buildPythonApplication, + libjack2, + pyliblo, + pyqt5, + which, + bash, + qt5, +}: buildPythonApplication rec { pname = "raysession"; @@ -19,20 +29,29 @@ buildPythonApplication rec { format = "other"; nativeBuildInputs = [ - pyqt5 # pyuic5 and pyrcc5 to build resources. + pyqt5 # pyuic5 and pyrcc5 to build resources. qt5.qttools # lrelease to build translations. - which # which to find lrelease. + which # which to find lrelease. qt5.wrapQtAppsHook ]; - buildInputs = [ libjack2 bash ]; - propagatedBuildInputs = [ pyliblo pyqt5 ]; + buildInputs = [ + libjack2 + bash + ]; + propagatedBuildInputs = [ + pyliblo + pyqt5 + ]; dontWrapQtApps = true; # The program is a python script. installFlags = [ "PREFIX=$(out)" ]; makeWrapperArgs = [ - "--suffix" "LD_LIBRARY_PATH" ":" (lib.makeLibraryPath [ libjack2 ]) + "--suffix" + "LD_LIBRARY_PATH" + ":" + (lib.makeLibraryPath [ libjack2 ]) ]; postFixup = '' diff --git a/pkgs/applications/audio/samplebrain/default.nix b/pkgs/applications/audio/samplebrain/default.nix index ae3549ff16d91a..253aa2b3435272 100644 --- a/pkgs/applications/audio/samplebrain/default.nix +++ b/pkgs/applications/audio/samplebrain/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitLab -, fftw -, liblo -, libsndfile -, makeDesktopItem -, portaudio -, qmake -, qtbase -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitLab, + fftw, + liblo, + libsndfile, + makeDesktopItem, + portaudio, + qmake, + qtbase, + wrapQtAppsHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/audio/samplv1/default.nix b/pkgs/applications/audio/samplv1/default.nix index c2f86609d45eb1..cc46296342e448 100644 --- a/pkgs/applications/audio/samplv1/default.nix +++ b/pkgs/applications/audio/samplv1/default.nix @@ -1,6 +1,16 @@ -{ mkDerivation, lib, fetchurl, pkg-config, libjack2 -, alsa-lib, liblo, libsndfile, lv2, qtbase, qttools -, rubberband +{ + mkDerivation, + lib, + fetchurl, + pkg-config, + libjack2, + alsa-lib, + liblo, + libsndfile, + lv2, + qtbase, + qttools, + rubberband, }: mkDerivation rec { @@ -12,9 +22,20 @@ mkDerivation rec { sha256 = "sha256-eJA6ixH20Wv+cD2CKGomncyfJ4tfpOL3UrTeCkb5/q0="; }; - nativeBuildInputs = [ qttools pkg-config ]; + nativeBuildInputs = [ + qttools + pkg-config + ]; - buildInputs = [ libjack2 alsa-lib liblo libsndfile lv2 qtbase rubberband ]; + buildInputs = [ + libjack2 + alsa-lib + liblo + libsndfile + lv2 + qtbase + rubberband + ]; meta = with lib; { description = "Old-school all-digital polyphonic sampler synthesizer with stereo fx"; diff --git a/pkgs/applications/audio/sayonara/default.nix b/pkgs/applications/audio/sayonara/default.nix index e937cd6ea77901..8426cc20e2e1b3 100644 --- a/pkgs/applications/audio/sayonara/default.nix +++ b/pkgs/applications/audio/sayonara/default.nix @@ -1,24 +1,27 @@ -{ mkDerivation -, cmake -, fetchFromGitLab -, nix-update-script -, gst_all_1 -, lib -, libpulseaudio -, ninja -, pcre -, pkg-config -, qtbase -, qttools -, taglib -, zlib -, python3 +{ + mkDerivation, + cmake, + fetchFromGitLab, + nix-update-script, + gst_all_1, + lib, + libpulseaudio, + ninja, + pcre, + pkg-config, + qtbase, + qttools, + taglib, + zlib, + python3, }: let - py = python3.withPackages (ps: with ps; [ - pydbus - ]); + py = python3.withPackages ( + ps: with ps; [ + pydbus + ] + ); in mkDerivation rec { pname = "sayonara"; @@ -37,23 +40,29 @@ mkDerivation rec { --replace-fail "std::max" "std::max" ''; - nativeBuildInputs = [ cmake ninja pkg-config qttools ]; + nativeBuildInputs = [ + cmake + ninja + pkg-config + qttools + ]; - buildInputs = [ - libpulseaudio - pcre - qtbase - taglib - zlib - py - ] - ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-good - gst-plugins-bad - gst-plugins-ugly - ]); + buildInputs = + [ + libpulseaudio + pcre + qtbase + taglib + zlib + py + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + gst-plugins-ugly + ]); # we carry the patched taglib 1.11.1 that doesn't break ogg but sayonara just # checks for the version diff --git a/pkgs/applications/audio/schismtracker/default.nix b/pkgs/applications/audio/schismtracker/default.nix index e6044f10a3411c..107a32ffd50bc0 100644 --- a/pkgs/applications/audio/schismtracker/default.nix +++ b/pkgs/applications/audio/schismtracker/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, alsa-lib -, perl -, pkg-config -, SDL2 -, libXext -, Cocoa +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + alsa-lib, + perl, + pkg-config, + SDL2, + libXext, + Cocoa, }: stdenv.mkDerivation rec { @@ -29,13 +30,22 @@ stdenv.mkDerivation rec { --replace-fail 'git log' 'echo ${version} #' ''; - configureFlags = [ "--enable-dependency-tracking" ] - ++ lib.optional stdenv.hostPlatform.isDarwin "--disable-sdltest"; + configureFlags = [ + "--enable-dependency-tracking" + ] ++ lib.optional stdenv.hostPlatform.isDarwin "--disable-sdltest"; - nativeBuildInputs = [ autoreconfHook perl pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + perl + pkg-config + ]; - buildInputs = [ SDL2 ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ alsa-lib libXext ] + buildInputs = + [ SDL2 ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + libXext + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; enableParallelBuilding = true; diff --git a/pkgs/applications/audio/sfxr-qt/default.nix b/pkgs/applications/audio/sfxr-qt/default.nix index a204ad566d4d16..e1caae7c8024f6 100644 --- a/pkgs/applications/audio/sfxr-qt/default.nix +++ b/pkgs/applications/audio/sfxr-qt/default.nix @@ -1,15 +1,16 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, cmake -, extra-cmake-modules -, qtbase -, qtquickcontrols2 -, SDL -, python3 -, catch2_3 -, callPackage -, nixosTests +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + extra-cmake-modules, + qtbase, + qtquickcontrols2, + SDL, + python3, + catch2_3, + callPackage, + nixosTests, }: mkDerivation rec { @@ -27,7 +28,13 @@ mkDerivation rec { nativeBuildInputs = [ cmake extra-cmake-modules - (python3.withPackages (pp: with pp; [ pyyaml jinja2 setuptools ])) + (python3.withPackages ( + pp: with pp; [ + pyyaml + jinja2 + setuptools + ] + )) ]; buildInputs = [ @@ -47,7 +54,7 @@ mkDerivation rec { doCheck = true; passthru.tests = { - export-square-wave = callPackage ./test-export-square-wave {}; + export-square-wave = callPackage ./test-export-square-wave { }; sfxr-qt-starts = nixosTests.sfxr-qt; }; diff --git a/pkgs/applications/audio/sisco.lv2/default.nix b/pkgs/applications/audio/sisco.lv2/default.nix index 8fd514abea5128..2163ea5db514be 100644 --- a/pkgs/applications/audio/sisco.lv2/default.nix +++ b/pkgs/applications/audio/sisco.lv2/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, lv2, pkg-config, libGLU, libGL, cairo, pango, libjack2 }: +{ + lib, + stdenv, + fetchFromGitHub, + lv2, + pkg-config, + libGLU, + libGL, + cairo, + pango, + libjack2, +}: let version = "0.7.0"; @@ -24,11 +35,21 @@ stdenv.mkDerivation rec { pname = "sisco.lv2"; inherit version; - srcs = [ src robtkSrc ]; + srcs = [ + src + robtkSrc + ]; sourceRoot = src.name; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ lv2 pango cairo libjack2 libGLU libGL ]; + buildInputs = [ + lv2 + pango + cairo + libjack2 + libGLU + libGL + ]; postUnpack = "chmod u+w -R ${robtkName}-src; mv ${robtkName}-src/* ${sourceRoot}/robtk"; sisco_VERSION = version; diff --git a/pkgs/applications/audio/snapcast/default.nix b/pkgs/applications/audio/snapcast/default.nix index 821cda32e9779a..534c951092728a 100644 --- a/pkgs/applications/audio/snapcast/default.nix +++ b/pkgs/applications/audio/snapcast/default.nix @@ -1,33 +1,65 @@ -{ stdenv, lib, fetchFromGitHub, cmake, pkg-config -, alsa-lib, asio, avahi, boost179, flac, libogg, libvorbis, libopus, soxr -, IOKit, AudioToolbox -, aixlog, popl -, pulseaudioSupport ? false, libpulseaudio -, nixosTests }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + alsa-lib, + asio, + avahi, + boost179, + flac, + libogg, + libvorbis, + libopus, + soxr, + IOKit, + AudioToolbox, + aixlog, + popl, + pulseaudioSupport ? false, + libpulseaudio, + nixosTests, +}: stdenv.mkDerivation rec { pname = "snapcast"; version = "0.29.0"; src = fetchFromGitHub { - owner = "badaix"; - repo = "snapcast"; - rev = "v${version}"; + owner = "badaix"; + repo = "snapcast"; + rev = "v${version}"; hash = "sha256-FWOGBXYWLHHZhvC5/BpkDd70ZupzALZ3ks3qTcrtwKQ="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; # snapcast also supports building against tremor but as we have libogg, that's # not needed - buildInputs = [ - boost179 - asio avahi flac libogg libvorbis libopus - aixlog popl soxr - ] ++ lib.optional pulseaudioSupport libpulseaudio - ++ lib.optional stdenv.hostPlatform.isLinux alsa-lib - ++ lib.optionals stdenv.hostPlatform.isDarwin [ IOKit AudioToolbox ]; + buildInputs = + [ + boost179 + asio + avahi + flac + libogg + libvorbis + libopus + aixlog + popl + soxr + ] + ++ lib.optional pulseaudioSupport libpulseaudio + ++ lib.optional stdenv.hostPlatform.isLinux alsa-lib + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + IOKit + AudioToolbox + ]; - TARGET=lib.optionalString stdenv.hostPlatform.isDarwin "MACOS"; + TARGET = lib.optionalString stdenv.hostPlatform.isDarwin "MACOS"; # Upstream systemd unit files are pretty awful, so we provide our own in a # NixOS module. It might make sense to get that upstreamed... diff --git a/pkgs/applications/audio/sonic-lineup/default.nix b/pkgs/applications/audio/sonic-lineup/default.nix index f58f88b3213825..e464c4a00f46d4 100644 --- a/pkgs/applications/audio/sonic-lineup/default.nix +++ b/pkgs/applications/audio/sonic-lineup/default.nix @@ -1,8 +1,31 @@ -{ lib, stdenv, fetchurl, fetchpatch2, alsa-lib, boost, bzip2, fftw, fftwFloat, libfishsound -, libid3tag, liblo, libmad, liboggz, libpulseaudio, libsamplerate -, libsndfile, lrdf, opusfile, portaudio, rubberband, serd, sord, capnproto -, wrapQtAppsHook, pkg-config -, libjack2 +{ + lib, + stdenv, + fetchurl, + fetchpatch2, + alsa-lib, + boost, + bzip2, + fftw, + fftwFloat, + libfishsound, + libid3tag, + liblo, + libmad, + liboggz, + libpulseaudio, + libsamplerate, + libsndfile, + lrdf, + opusfile, + portaudio, + rubberband, + serd, + sord, + capnproto, + wrapQtAppsHook, + pkg-config, + libjack2, }: stdenv.mkDerivation rec { @@ -24,14 +47,34 @@ stdenv.mkDerivation rec { ./match-vamp.patch ]; - buildInputs = - [ alsa-lib boost bzip2 fftw fftwFloat libfishsound libid3tag liblo - libmad liboggz libpulseaudio libsamplerate libsndfile lrdf opusfile - portaudio rubberband serd sord capnproto - libjack2 - ]; + buildInputs = [ + alsa-lib + boost + bzip2 + fftw + fftwFloat + libfishsound + libid3tag + liblo + libmad + liboggz + libpulseaudio + libsamplerate + libsndfile + lrdf + opusfile + portaudio + rubberband + serd + sord + capnproto + libjack2 + ]; - nativeBuildInputs = [ pkg-config wrapQtAppsHook ]; + nativeBuildInputs = [ + pkg-config + wrapQtAppsHook + ]; enableParallelBuilding = true; diff --git a/pkgs/applications/audio/sonic-pi/default.nix b/pkgs/applications/audio/sonic-pi/default.nix index 286e26bdaad384..2cf404acec5eeb 100644 --- a/pkgs/applications/audio/sonic-pi/default.nix +++ b/pkgs/applications/audio/sonic-pi/default.nix @@ -1,42 +1,43 @@ -{ stdenv -, lib -, fetchFromGitHub -, wrapQtAppsHook -, makeDesktopItem -, copyDesktopItems -, cmake -, pkg-config -, catch2_3 -, qtbase -, qtsvg -, qttools -, qwt -, qscintilla -, kissfftFloat -, crossguid -, reproc -, platform-folders -, ruby -, erlang -, elixir -, beamPackages -, alsa-lib -, rtmidi -, boost -, aubio -, jack2 -, jack-example-tools -, pipewire -, supercollider-with-sc3-plugins -, parallel - -, withTauWidget ? false -, qtwebengine - -, withImGui ? false -, gl3w -, SDL2 -, fmt +{ + stdenv, + lib, + fetchFromGitHub, + wrapQtAppsHook, + makeDesktopItem, + copyDesktopItems, + cmake, + pkg-config, + catch2_3, + qtbase, + qtsvg, + qttools, + qwt, + qscintilla, + kissfftFloat, + crossguid, + reproc, + platform-folders, + ruby, + erlang, + elixir, + beamPackages, + alsa-lib, + rtmidi, + boost, + aubio, + jack2, + jack-example-tools, + pipewire, + supercollider-with-sc3-plugins, + parallel, + + withTauWidget ? false, + qtwebengine, + + withImGui ? false, + gl3w, + SDL2, + fmt, }: stdenv.mkDerivation rec { @@ -71,29 +72,32 @@ stdenv.mkDerivation rec { beamPackages.hex ]; - buildInputs = [ - qtbase - qtsvg - qttools - qwt - qscintilla - kissfftFloat - catch2_3 - crossguid - reproc - platform-folders - ruby - alsa-lib - rtmidi - boost - aubio - ] ++ lib.optionals withTauWidget [ - qtwebengine - ] ++ lib.optionals withImGui [ - gl3w - SDL2 - fmt - ]; + buildInputs = + [ + qtbase + qtsvg + qttools + qwt + qscintilla + kissfftFloat + catch2_3 + crossguid + reproc + platform-folders + ruby + alsa-lib + rtmidi + boost + aubio + ] + ++ lib.optionals withTauWidget [ + qtwebengine + ] + ++ lib.optionals withImGui [ + gl3w + SDL2 + fmt + ]; nativeCheckInputs = [ parallel @@ -189,14 +193,30 @@ stdenv.mkDerivation rec { preFixup = '' # Wrap Qt GUI (distributed binary) wrapQtApp $out/bin/sonic-pi \ - --prefix PATH : ${lib.makeBinPath [ ruby supercollider-with-sc3-plugins jack2 jack-example-tools pipewire.jack ]} + --prefix PATH : ${ + lib.makeBinPath [ + ruby + supercollider-with-sc3-plugins + jack2 + jack-example-tools + pipewire.jack + ] + } # If ImGui was built if [ -e $out/app/build/gui/imgui/sonic-pi-imgui ]; then # Wrap ImGui into bin makeWrapper $out/app/build/gui/imgui/sonic-pi-imgui $out/bin/sonic-pi-imgui \ --inherit-argv0 \ - --prefix PATH : ${lib.makeBinPath [ ruby supercollider-with-sc3-plugins jack2 jack-example-tools pipewire.jack ]} + --prefix PATH : ${ + lib.makeBinPath [ + ruby + supercollider-with-sc3-plugins + jack2 + jack-example-tools + pipewire.jack + ] + } fi # Remove runtime Erlang references @@ -205,7 +225,10 @@ stdenv.mkDerivation rec { done ''; - stripDebugList = [ "app" "bin" ]; + stripDebugList = [ + "app" + "bin" + ]; desktopItems = [ (makeDesktopItem { @@ -214,7 +237,11 @@ stdenv.mkDerivation rec { icon = "sonic-pi"; desktopName = "Sonic Pi"; comment = meta.description; - categories = [ "Audio" "AudioVideo" "Education" ]; + categories = [ + "Audio" + "AudioVideo" + "Education" + ]; }) ]; @@ -224,7 +251,12 @@ stdenv.mkDerivation rec { homepage = "https://sonic-pi.net/"; description = "Free live coding synth for everyone originally designed to support computing and music lessons within schools"; license = licenses.mit; - maintainers = with maintainers; [ Phlogistique kamilchm c0deaddict sohalt ]; + maintainers = with maintainers; [ + Phlogistique + kamilchm + c0deaddict + sohalt + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/audio/sonic-visualiser/default.nix b/pkgs/applications/audio/sonic-visualiser/default.nix index ef6ed0c695a069..8f6a6e6f4cc7fd 100644 --- a/pkgs/applications/audio/sonic-visualiser/default.nix +++ b/pkgs/applications/audio/sonic-visualiser/default.nix @@ -1,11 +1,40 @@ # TODO add plugins having various licenses, see http://www.vamp-plugins.org/download.html -{ lib, stdenv, fetchurl, alsa-lib, bzip2, fftw, libjack2, libX11, liblo -, libmad, lrdf, librdf_raptor, librdf_rasqal, libsamplerate -, libsndfile, pkg-config, libpulseaudio, qtbase, qtsvg, redland -, rubberband, serd, sord, vamp-plugin-sdk, fftwFloat -, capnproto, liboggz, libfishsound, libid3tag, opusfile -, wrapQtAppsHook, meson, ninja, cmake +{ + lib, + stdenv, + fetchurl, + alsa-lib, + bzip2, + fftw, + libjack2, + libX11, + liblo, + libmad, + lrdf, + librdf_raptor, + librdf_rasqal, + libsamplerate, + libsndfile, + pkg-config, + libpulseaudio, + qtbase, + qtsvg, + redland, + rubberband, + serd, + sord, + vamp-plugin-sdk, + fftwFloat, + capnproto, + liboggz, + libfishsound, + libid3tag, + opusfile, + wrapQtAppsHook, + meson, + ninja, + cmake, }: stdenv.mkDerivation rec { @@ -17,25 +46,43 @@ stdenv.mkDerivation rec { sha256 = "1sgg4m3035a03ldipgysz7zqfa9pqaqa4j024gyvvcwh4ml8iasr"; }; - nativeBuildInputs = [ meson ninja cmake pkg-config wrapQtAppsHook ]; - buildInputs = - [ libsndfile qtbase qtsvg fftw fftwFloat bzip2 lrdf rubberband - libsamplerate vamp-plugin-sdk alsa-lib librdf_raptor librdf_rasqal redland - serd - sord - # optional - libjack2 - # portaudio - libpulseaudio - libmad - libfishsound - liblo - libX11 - capnproto - liboggz - libid3tag - opusfile - ]; + nativeBuildInputs = [ + meson + ninja + cmake + pkg-config + wrapQtAppsHook + ]; + buildInputs = [ + libsndfile + qtbase + qtsvg + fftw + fftwFloat + bzip2 + lrdf + rubberband + libsamplerate + vamp-plugin-sdk + alsa-lib + librdf_raptor + librdf_rasqal + redland + serd + sord + # optional + libjack2 + # portaudio + libpulseaudio + libmad + libfishsound + liblo + libX11 + capnproto + liboggz + libid3tag + opusfile + ]; enableParallelBuilding = true; diff --git a/pkgs/applications/audio/soundkonverter/default.nix b/pkgs/applications/audio/soundkonverter/default.nix index 87c063ce009fe0..1155ba492ddf87 100644 --- a/pkgs/applications/audio/soundkonverter/default.nix +++ b/pkgs/applications/audio/soundkonverter/default.nix @@ -1,32 +1,68 @@ # currently needs to be installed into an environment and needs a `kbuildsycoca5` run afterwards for plugin discovery { - mkDerivation, fetchFromGitHub, fetchpatch, lib, makeWrapper, - cmake, extra-cmake-modules, pkg-config, - libkcddb, kconfig, kconfigwidgets, ki18n, kdelibs4support, kio, solid, kwidgetsaddons, kxmlgui, - qtbase, phonon, + mkDerivation, + fetchFromGitHub, + fetchpatch, + lib, + makeWrapper, + cmake, + extra-cmake-modules, + pkg-config, + libkcddb, + kconfig, + kconfigwidgets, + ki18n, + kdelibs4support, + kio, + solid, + kwidgetsaddons, + kxmlgui, + qtbase, + phonon, taglib, # optional backends - withCD ? true, cdparanoia, - withFlac ? true, flac, - withMidi ? true, fluidsynth, timidity, - withSpeex ? false, speex, - withVorbis ? true, vorbis-tools, vorbisgain, - withMp3 ? true, lame, mp3gain, - withAac ? true, faad2, aacgain, - withUnfreeAac ? false, faac, - withFfmpeg ? true, ffmpeg-full, - withMplayer ? false, mplayer, - withSox ? true, sox, - withOpus ? true, opusTools, - withTwolame ? false, twolame, - withApe ? false, monkeysAudio, - withWavpack ? false, wavpack + withCD ? true, + cdparanoia, + withFlac ? true, + flac, + withMidi ? true, + fluidsynth, + timidity, + withSpeex ? false, + speex, + withVorbis ? true, + vorbis-tools, + vorbisgain, + withMp3 ? true, + lame, + mp3gain, + withAac ? true, + faad2, + aacgain, + withUnfreeAac ? false, + faac, + withFfmpeg ? true, + ffmpeg-full, + withMplayer ? false, + mplayer, + withSox ? true, + sox, + withOpus ? true, + opusTools, + withTwolame ? false, + twolame, + withApe ? false, + monkeysAudio, + withWavpack ? false, + wavpack, }: assert withAac -> withFfmpeg || withUnfreeAac; assert withUnfreeAac -> withAac; -let runtimeDeps = [] +let + runtimeDeps = + [ ] ++ lib.optional withCD cdparanoia ++ lib.optional withFlac flac ++ lib.optional withSpeex speex @@ -38,10 +74,22 @@ let runtimeDeps = [] ++ lib.optional withApe monkeysAudio ++ lib.optional withWavpack wavpack ++ lib.optional withUnfreeAac faac - ++ lib.optionals withMidi [ fluidsynth timidity ] - ++ lib.optionals withVorbis [ vorbis-tools vorbisgain ] - ++ lib.optionals withMp3 [ lame mp3gain ] - ++ lib.optionals withAac [ faad2 aacgain ]; + ++ lib.optionals withMidi [ + fluidsynth + timidity + ] + ++ lib.optionals withVorbis [ + vorbis-tools + vorbisgain + ] + ++ lib.optionals withMp3 [ + lame + mp3gain + ] + ++ lib.optionals withAac [ + faad2 + aacgain + ]; in mkDerivation rec { @@ -63,16 +111,34 @@ mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake extra-cmake-modules pkg-config kdelibs4support makeWrapper ]; - propagatedBuildInputs = [ libkcddb kconfig kconfigwidgets ki18n kdelibs4support kio solid kwidgetsaddons kxmlgui qtbase phonon]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + pkg-config + kdelibs4support + makeWrapper + ]; + propagatedBuildInputs = [ + libkcddb + kconfig + kconfigwidgets + ki18n + kdelibs4support + kio + solid + kwidgetsaddons + kxmlgui + qtbase + phonon + ]; buildInputs = [ taglib ] ++ runtimeDeps; # encoder plugins go to ${out}/lib so they're found by kbuildsycoca5 cmakeFlags = [ "-DCMAKE_INSTALL_PREFIX=$out" ]; sourceRoot = "${src.name}/src"; # add runt-time deps to PATH postInstall = '' - wrapProgram $out/bin/soundkonverter --prefix PATH : ${lib.makeBinPath runtimeDeps } - ''; + wrapProgram $out/bin/soundkonverter --prefix PATH : ${lib.makeBinPath runtimeDeps} + ''; meta = { homepage = "https://github.com/dfaust/soundkonverter"; license = lib.licenses.gpl2; @@ -103,6 +169,6 @@ mkDerivation rec { - CD ripping Backends: cdparanoia - ''; + ''; }; } diff --git a/pkgs/applications/audio/spek/default.nix b/pkgs/applications/audio/spek/default.nix index 6bc15adf6082ee..ad1c2ff5b7e2a3 100644 --- a/pkgs/applications/audio/spek/default.nix +++ b/pkgs/applications/audio/spek/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, intltool, pkg-config, ffmpeg, wxGTK32, gtk3, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + intltool, + pkg-config, + ffmpeg, + wxGTK32, + gtk3, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "spek"; @@ -11,9 +22,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-VYt2so2k3Rk3sLSV1Tf1G2pESYiXygrKr9Koop8ChCg="; }; - nativeBuildInputs = [ autoreconfHook intltool pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + autoreconfHook + intltool + pkg-config + wrapGAppsHook3 + ]; - buildInputs = [ ffmpeg wxGTK32 gtk3 ]; + buildInputs = [ + ffmpeg + wxGTK32 + gtk3 + ]; meta = with lib; { description = "Analyse your audio files by showing their spectrogram"; diff --git a/pkgs/applications/audio/spotify-qt/default.nix b/pkgs/applications/audio/spotify-qt/default.nix index cbe252bc2b9460..01600dbf5ca791 100644 --- a/pkgs/applications/audio/spotify-qt/default.nix +++ b/pkgs/applications/audio/spotify-qt/default.nix @@ -1,44 +1,49 @@ -{ stdenvNoCC -, fetchFromGitHub -, lib -, cmake -, mkDerivation -, libxcb -, qtbase -, qtsvg +{ + stdenvNoCC, + fetchFromGitHub, + lib, + cmake, + mkDerivation, + libxcb, + qtbase, + qtsvg, }: mkDerivation rec { - pname = "spotify-qt"; - version = "3.11"; + pname = "spotify-qt"; + version = "3.11"; - src = fetchFromGitHub { - owner = "kraxarn"; - repo = pname; - rev = "v${version}"; - sha256 = "sha256-Dm+ELHtYZGSzJSrERtvpuuV5cVZ9ah9WQ0iTTJqGqVg="; - }; + src = fetchFromGitHub { + owner = "kraxarn"; + repo = pname; + rev = "v${version}"; + sha256 = "sha256-Dm+ELHtYZGSzJSrERtvpuuV5cVZ9ah9WQ0iTTJqGqVg="; + }; - buildInputs = [ libxcb qtbase qtsvg ]; + buildInputs = [ + libxcb + qtbase + qtsvg + ]; - nativeBuildInputs = [ cmake ]; + nativeBuildInputs = [ cmake ]; - cmakeFlags = [ "-DCMAKE_INSTALL_PREFIX=" ]; + cmakeFlags = [ "-DCMAKE_INSTALL_PREFIX=" ]; - installFlags = [ "DESTDIR=$(out)" ]; + installFlags = [ "DESTDIR=$(out)" ]; - postInstall = lib.optionalString stdenvNoCC.hostPlatform.isDarwin '' - mkdir -p $out/Applications - mv $out/bin/spotify-qt.app $out/Applications - ln $out/Applications/spotify-qt.app/Contents/MacOS/spotify-qt $out/bin/spotify-qt - ''; + postInstall = lib.optionalString stdenvNoCC.hostPlatform.isDarwin '' + mkdir -p $out/Applications + mv $out/bin/spotify-qt.app $out/Applications + ln $out/Applications/spotify-qt.app/Contents/MacOS/spotify-qt $out/bin/spotify-qt + ''; - meta = with lib; { + meta = with lib; { description = "Lightweight unofficial Spotify client using Qt"; mainProgram = "spotify-qt"; homepage = "https://github.com/kraxarn/spotify-qt"; license = licenses.gpl3Only; maintainers = with maintainers; [ iivusly ]; platforms = platforms.unix; - }; + }; } diff --git a/pkgs/applications/audio/squishyball/default.nix b/pkgs/applications/audio/squishyball/default.nix index 170cfe63ba2551..d74b372b25f3bf 100644 --- a/pkgs/applications/audio/squishyball/default.nix +++ b/pkgs/applications/audio/squishyball/default.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, autoreconfHook, fetchFromGitLab, fetchpatch, flac, libao, libvorbis, ncurses -, opusfile, pkg-config +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitLab, + fetchpatch, + flac, + libao, + libvorbis, + ncurses, + opusfile, + pkg-config, }: stdenv.mkDerivation rec { @@ -14,9 +24,18 @@ stdenv.mkDerivation rec { sha256 = "07zs8wx1ahf3q505fk9b6cgzlkhnayfsscch46yy9s1wgxgphj7s"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ flac libao libvorbis ncurses opusfile ]; + buildInputs = [ + flac + libao + libvorbis + ncurses + opusfile + ]; patches = [ ./gnu-screen.patch @@ -39,18 +58,18 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Tool to perform sample comparison testing on the command line"; longDescription = '' - squishyball is a simple command-line utility for performing - double-blind A/B, A/B/X or X/X/Y testing on the command line. - The user specifies two input files to be compared and uses the - keyboard during playback to flip between the randomized samples - to perform on-the-fly compar‐ isons. After a predetermined - number of trials, squishyball prints the trial results to - stdout and exits. Results (stdout) may be redirected to a file - without affecting interactive use of the terminal. - - squishyball can also be used to perform casual, non-randomized - comparisons of groups of up to ten samples; this is the default - mode of operation. + squishyball is a simple command-line utility for performing + double-blind A/B, A/B/X or X/X/Y testing on the command line. + The user specifies two input files to be compared and uses the + keyboard during playback to flip between the randomized samples + to perform on-the-fly compar‐ isons. After a predetermined + number of trials, squishyball prints the trial results to + stdout and exits. Results (stdout) may be redirected to a file + without affecting interactive use of the terminal. + + squishyball can also be used to perform casual, non-randomized + comparisons of groups of up to ten samples; this is the default + mode of operation. ''; homepage = "https://gitlab.xiph.org/xiph/squishyball"; license = licenses.gpl2Plus; diff --git a/pkgs/applications/audio/surge/default.nix b/pkgs/applications/audio/surge/default.nix index f1d8600ed01bff..5f65fab87578fd 100644 --- a/pkgs/applications/audio/surge/default.nix +++ b/pkgs/applications/audio/surge/default.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchurl -, fetchpatch -, fetchFromGitHub -, cmake -, git -, pkg-config -, python3 -, cairo -, libsndfile -, libxcb -, libxkbcommon -, xcbutil -, xcbutilcursor -, xcbutilkeysyms -, zenity -, curl -, rsync +{ + stdenv, + lib, + fetchurl, + fetchpatch, + fetchFromGitHub, + cmake, + git, + pkg-config, + python3, + cairo, + libsndfile, + libxcb, + libxkbcommon, + xcbutil, + xcbutilcursor, + xcbutilkeysyms, + zenity, + curl, + rsync, }: stdenv.mkDerivation rec { @@ -78,7 +79,6 @@ stdenv.mkDerivation rec { cp -r $extraContent/Skins/ resources/data/skins ''; - installPhase = '' cd .. cmake --build build --config Release --target install-everything-global @@ -100,6 +100,9 @@ stdenv.mkDerivation rec { homepage = "https://surge-synthesizer.github.io"; license = licenses.gpl3; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ magnetophon orivej ]; + maintainers = with maintainers; [ + magnetophon + orivej + ]; }; } diff --git a/pkgs/applications/audio/synthv1/default.nix b/pkgs/applications/audio/synthv1/default.nix index a42671b3d303d3..4f6582a875cc74 100644 --- a/pkgs/applications/audio/synthv1/default.nix +++ b/pkgs/applications/audio/synthv1/default.nix @@ -1,4 +1,15 @@ -{ mkDerivation, lib, fetchurl, pkg-config, qtbase, qttools, libjack2, alsa-lib, liblo, lv2 }: +{ + mkDerivation, + lib, + fetchurl, + pkg-config, + qtbase, + qttools, + libjack2, + alsa-lib, + liblo, + lv2, +}: mkDerivation rec { pname = "synthv1"; @@ -9,7 +20,14 @@ mkDerivation rec { sha256 = "sha256-0V72T51icT/t9fJf4mwcMYZLjzTPnmiCbU+BdwnCmw4="; }; - buildInputs = [ qtbase qttools libjack2 alsa-lib liblo lv2 ]; + buildInputs = [ + qtbase + qttools + libjack2 + alsa-lib + liblo + lv2 + ]; nativeBuildInputs = [ pkg-config ]; diff --git a/pkgs/applications/audio/tageditor/default.nix b/pkgs/applications/audio/tageditor/default.nix index 173ced9ca525f8..8464918d746a2c 100644 --- a/pkgs/applications/audio/tageditor/default.nix +++ b/pkgs/applications/audio/tageditor/default.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, cmake -, cpp-utilities -, qtutilities -, mp4v2 -, libid3tag -, qtbase -, qttools -, qtwebengine -, qtx11extras -, tagparser -, wrapQtAppsHook +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + cmake, + cpp-utilities, + qtutilities, + mp4v2, + libid3tag, + qtbase, + qttools, + qtwebengine, + qtx11extras, + tagparser, + wrapQtAppsHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/audio/tamgamp.lv2/default.nix b/pkgs/applications/audio/tamgamp.lv2/default.nix index 2907a5277ee299..17b75b395ff870 100644 --- a/pkgs/applications/audio/tamgamp.lv2/default.nix +++ b/pkgs/applications/audio/tamgamp.lv2/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, lv2, zita-resampler }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + lv2, + zita-resampler, +}: stdenv.mkDerivation rec { pname = "tamgamp.lv2"; @@ -13,7 +20,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ lv2 zita-resampler ]; + buildInputs = [ + lv2 + zita-resampler + ]; makeFlags = [ "PREFIX=$(out)" ]; @@ -23,29 +33,29 @@ stdenv.mkDerivation rec { homepage = "https://github.com/sadko4u/tamgamp.lv2"; description = "Guitar amplifier simulator"; longDescription = '' - Tamgamp (Pronouncement: "Damage Amp") is an LV2 guitar amp simulator that provides two plugins: - - - Tamgamp - a plugin based on Guitarix DK Builder simulated chains. - - TamgampGX - a plugin based on tuned Guitarix internal amplifiers implementation. - - The reference to the original Guitarix project: https://guitarix.org/ - - It simulates the set of the following guitar amplifiers: - - - Fender Princeton Reverb-amp AA1164 (without reverb module) - - Fender Twin Reverb-Amp AA769 (Normal channel, bright off) - - Fender Twin Reverb-Amp AA769 (Vibrato channel, bright on) - - Marshall JCM-800 High-gain input - - Marshall JCM-800 Low-gain input - - Mesa/Boogie DC3 preamplifier (lead channel) - - Mesa/Boogie DC3 preamplifier (rhythm channel) - - Mesa Dual Rectifier preamplifier (orange channel, less gain) - - Mesa Dual Rectifier preamplifier (red channel, more gain) - - Peavey 5150II crunch channel - - Peavey 5150II lead channel - - VOX AC-30 Brilliant channel - - VOX AC-30 normal channel - ''; + Tamgamp (Pronouncement: "Damage Amp") is an LV2 guitar amp simulator that provides two plugins: + + - Tamgamp - a plugin based on Guitarix DK Builder simulated chains. + - TamgampGX - a plugin based on tuned Guitarix internal amplifiers implementation. + + The reference to the original Guitarix project: https://guitarix.org/ + + It simulates the set of the following guitar amplifiers: + + - Fender Princeton Reverb-amp AA1164 (without reverb module) + - Fender Twin Reverb-Amp AA769 (Normal channel, bright off) + - Fender Twin Reverb-Amp AA769 (Vibrato channel, bright on) + - Marshall JCM-800 High-gain input + - Marshall JCM-800 Low-gain input + - Mesa/Boogie DC3 preamplifier (lead channel) + - Mesa/Boogie DC3 preamplifier (rhythm channel) + - Mesa Dual Rectifier preamplifier (orange channel, less gain) + - Mesa Dual Rectifier preamplifier (red channel, more gain) + - Peavey 5150II crunch channel + - Peavey 5150II lead channel + - VOX AC-30 Brilliant channel + - VOX AC-30 normal channel + ''; maintainers = [ maintainers.magnetophon ]; platforms = platforms.linux; license = licenses.lgpl3Plus; diff --git a/pkgs/applications/audio/termusic/default.nix b/pkgs/applications/audio/termusic/default.nix index c4a42aa3837c73..afc767749a3d9a 100644 --- a/pkgs/applications/audio/termusic/default.nix +++ b/pkgs/applications/audio/termusic/default.nix @@ -1,25 +1,25 @@ { - alsa-lib -, AppKit -, CoreAudio -, CoreGraphics -, dbus -, Foundation -, fetchFromGitHub -, fetchpatch -, glib -, gst_all_1 -, IOKit -, lib -, MediaPlayer -, mpv-unwrapped -, openssl -, pkg-config -, protobuf -, rustPlatform -, Security -, sqlite -, stdenv + alsa-lib, + AppKit, + CoreAudio, + CoreGraphics, + dbus, + Foundation, + fetchFromGitHub, + fetchpatch, + glib, + gst_all_1, + IOKit, + lib, + MediaPlayer, + mpv-unwrapped, + openssl, + pkg-config, + protobuf, + rustPlatform, + Security, + sqlite, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -67,24 +67,27 @@ rustPlatform.buildRustPackage rec { rustPlatform.bindgenHook ]; - buildInputs = [ - dbus - glib - gst_all_1.gstreamer - mpv-unwrapped - openssl - sqlite - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - CoreAudio - CoreGraphics - Foundation - IOKit - MediaPlayer - Security - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - ]; + buildInputs = + [ + dbus + glib + gst_all_1.gstreamer + mpv-unwrapped + openssl + sqlite + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + CoreAudio + CoreGraphics + Foundation + IOKit + MediaPlayer + Security + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + ]; meta = { description = "Terminal Music Player TUI written in Rust"; diff --git a/pkgs/applications/audio/tony/default.nix b/pkgs/applications/audio/tony/default.nix index a0af1a706643b3..643228bfad913e 100644 --- a/pkgs/applications/audio/tony/default.nix +++ b/pkgs/applications/audio/tony/default.nix @@ -1,7 +1,33 @@ -{ lib, stdenv, fetchurl, fetchpatch2, pkg-config, wrapQtAppsHook -, alsa-lib, boost, bzip2, fftw, fftwFloat, libX11, libfishsound, libid3tag -, libjack2, liblo, libmad, libogg, liboggz, libpulseaudio, libsamplerate -, libsndfile, lrdf, opusfile, qtbase, qtsvg, rubberband, serd, sord +{ + lib, + stdenv, + fetchurl, + fetchpatch2, + pkg-config, + wrapQtAppsHook, + alsa-lib, + boost, + bzip2, + fftw, + fftwFloat, + libX11, + libfishsound, + libid3tag, + libjack2, + liblo, + libmad, + libogg, + liboggz, + libpulseaudio, + libsamplerate, + libsndfile, + lrdf, + opusfile, + qtbase, + qtsvg, + rubberband, + serd, + sord, }: stdenv.mkDerivation rec { @@ -29,12 +55,35 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config wrapQtAppsHook ]; + nativeBuildInputs = [ + pkg-config + wrapQtAppsHook + ]; buildInputs = [ - alsa-lib boost bzip2 fftw fftwFloat libX11 libfishsound libid3tag - libjack2 liblo libmad libogg liboggz libpulseaudio libsamplerate - libsndfile lrdf opusfile qtbase qtsvg rubberband serd sord + alsa-lib + boost + bzip2 + fftw + fftwFloat + libX11 + libfishsound + libid3tag + libjack2 + liblo + libmad + libogg + liboggz + libpulseaudio + libsamplerate + libsndfile + lrdf + opusfile + qtbase + qtsvg + rubberband + serd + sord ]; # comment out the tests diff --git a/pkgs/applications/audio/traverso/default.nix b/pkgs/applications/audio/traverso/default.nix index b8a81ec7a8e974..d58ccbf940f0a1 100644 --- a/pkgs/applications/audio/traverso/default.nix +++ b/pkgs/applications/audio/traverso/default.nix @@ -1,6 +1,22 @@ -{ mkDerivation, lib, fetchurl, cmake, pkg-config -, alsa-lib, fftw, flac, lame, libjack2, libmad, libpulseaudio -, libsamplerate, libsndfile, libvorbis, portaudio, qtbase, wavpack +{ + mkDerivation, + lib, + fetchurl, + cmake, + pkg-config, + alsa-lib, + fftw, + flac, + lame, + libjack2, + libmad, + libpulseaudio, + libsamplerate, + libsndfile, + libvorbis, + portaudio, + qtbase, + wavpack, }: mkDerivation { pname = "traverso"; @@ -11,12 +27,32 @@ mkDerivation { sha256 = "12f7x8kw4fw1j0xkwjrp54cy4cv1ql0zwz2ba5arclk4pf6bhl7q"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ alsa-lib fftw flac.dev libjack2 lame - libmad libpulseaudio libsamplerate.dev libsndfile.dev libvorbis - portaudio qtbase wavpack ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + alsa-lib + fftw + flac.dev + libjack2 + lame + libmad + libpulseaudio + libsamplerate.dev + libsndfile.dev + libvorbis + portaudio + qtbase + wavpack + ]; - cmakeFlags = [ "-DWANT_PORTAUDIO=1" "-DWANT_PULSEAUDIO=1" "-DWANT_MP3_ENCODE=1" "-DWANT_LV2=0" ]; + cmakeFlags = [ + "-DWANT_PORTAUDIO=1" + "-DWANT_PULSEAUDIO=1" + "-DWANT_MP3_ENCODE=1" + "-DWANT_LV2=0" + ]; hardeningDisable = [ "format" ]; @@ -24,7 +60,10 @@ mkDerivation { description = "Cross-platform multitrack audio recording and audio editing suite"; mainProgram = "traverso"; homepage = "https://traverso-daw.org/"; - license = with licenses; [ gpl2Plus lgpl21Plus ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + ]; platforms = platforms.all; maintainers = with maintainers; [ coconnor ]; }; diff --git a/pkgs/applications/audio/tunefish/default.nix b/pkgs/applications/audio/tunefish/default.nix index 8c2855d732828b..a953f59601228e 100644 --- a/pkgs/applications/audio/tunefish/default.nix +++ b/pkgs/applications/audio/tunefish/default.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, python3 -, alsa-lib, curl, freetype, gtk3, libGL, libX11, libXext, libXinerama, webkitgtk_4_0 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + python3, + alsa-lib, + curl, + freetype, + gtk3, + libGL, + libX11, + libXext, + libXinerama, + webkitgtk_4_0, }: stdenv.mkDerivation { @@ -14,15 +27,29 @@ stdenv.mkDerivation { sha256 = "0rjpq3s609fblzkvnc9729glcnfinmxljh0z8ldpzr245h367zxh"; }; - nativeBuildInputs = [ pkg-config python3 ]; - buildInputs = [ alsa-lib curl freetype gtk3 libGL libX11 libXext libXinerama webkitgtk_4_0 ]; + nativeBuildInputs = [ + pkg-config + python3 + ]; + buildInputs = [ + alsa-lib + curl + freetype + gtk3 + libGL + libX11 + libXext + libXinerama + webkitgtk_4_0 + ]; postPatch = '' patchShebangs src/tunefish4/generate-lv2-ttl.py ''; makeFlags = [ - "-C" "src/tunefish4/Builds/LinuxMakefile" + "-C" + "src/tunefish4/Builds/LinuxMakefile" "CONFIG=Release" ]; diff --git a/pkgs/applications/audio/viper4linux-gui/default.nix b/pkgs/applications/audio/viper4linux-gui/default.nix index ee8593c8e62029..769a0e445f790a 100644 --- a/pkgs/applications/audio/viper4linux-gui/default.nix +++ b/pkgs/applications/audio/viper4linux-gui/default.nix @@ -1,20 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, copyDesktopItems -, pkg-config -, qtbase -, qtsvg -, qtmultimedia -, qmake -, gst_all_1 -, libpulseaudio -, makeDesktopItem -, viper4linux -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + copyDesktopItems, + pkg-config, + qtbase, + qtsvg, + qtmultimedia, + qmake, + gst_all_1, + libpulseaudio, + makeDesktopItem, + viper4linux, + wrapQtAppsHook, }: let - gstPluginPath = lib.makeSearchPathOutput "lib" "lib/gstreamer-1.0" (with gst_all_1; [ gstreamer gst-plugins-viperfx gst-plugins-base gst-plugins-good ]); + gstPluginPath = lib.makeSearchPathOutput "lib" "lib/gstreamer-1.0" ( + with gst_all_1; + [ + gstreamer + gst-plugins-viperfx + gst-plugins-base + gst-plugins-good + ] + ); in stdenv.mkDerivation rec { pname = "viper4linux-gui"; @@ -35,7 +44,10 @@ stdenv.mkDerivation rec { desktopName = "viper4linux"; genericName = "Equalizer"; comment = meta.description; - categories = [ "AudioVideo" "Audio" ]; + categories = [ + "AudioVideo" + "Audio" + ]; startupNotify = false; }) ]; @@ -61,7 +73,12 @@ stdenv.mkDerivation rec { qmakeFlags = [ "V4L_Frontend.pro" ]; qtWrapperArgs = [ - "--prefix PATH : ${lib.makeBinPath [ viper4linux gst_all_1.gstreamer ]}" + "--prefix PATH : ${ + lib.makeBinPath [ + viper4linux + gst_all_1.gstreamer + ] + }" "--prefix GST_PLUGIN_SYSTEM_PATH_1_0 : ${gstPluginPath}" ]; diff --git a/pkgs/applications/audio/vmpk/default.nix b/pkgs/applications/audio/vmpk/default.nix index 7802c6cce70453..7201030bac352b 100644 --- a/pkgs/applications/audio/vmpk/default.nix +++ b/pkgs/applications/audio/vmpk/default.nix @@ -1,6 +1,13 @@ -{ mkDerivation, lib, fetchurl, cmake, pkg-config -, qttools, qtx11extras, drumstick -, docbook-xsl-nons +{ + mkDerivation, + lib, + fetchurl, + cmake, + pkg-config, + qttools, + qtx11extras, + drumstick, + docbook-xsl-nons, }: mkDerivation rec { @@ -12,9 +19,17 @@ mkDerivation rec { sha256 = "sha256-+NjTcszb1KXGynIcCf4IEDvN4f8pgXtR1TksxGR5ZHQ="; }; - nativeBuildInputs = [ cmake pkg-config qttools docbook-xsl-nons ]; + nativeBuildInputs = [ + cmake + pkg-config + qttools + docbook-xsl-nons + ]; - buildInputs = [ drumstick qtx11extras ]; + buildInputs = [ + drumstick + qtx11extras + ]; postInstall = '' # vmpk drumstickLocales looks here: diff --git a/pkgs/applications/audio/xmp/default.nix b/pkgs/applications/audio/xmp/default.nix index 8abce73aff1ffb..dace69315ac134 100644 --- a/pkgs/applications/audio/xmp/default.nix +++ b/pkgs/applications/audio/xmp/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, alsa-lib, libxmp, AudioUnit, CoreAudio }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + alsa-lib, + libxmp, + AudioUnit, + CoreAudio, +}: stdenv.mkDerivation rec { pname = "xmp"; @@ -11,16 +21,23 @@ stdenv.mkDerivation rec { hash = "sha256-037k1rFjGR6XFtr08bzs4zVz+GyUGuuutuWFlNEuATA="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libxmp ] + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = + [ libxmp ] ++ lib.optionals stdenv.hostPlatform.isLinux [ alsa-lib ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ AudioUnit CoreAudio ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AudioUnit + CoreAudio + ]; meta = with lib; { description = "Extended module player"; - homepage = "https://xmp.sourceforge.net/"; - license = licenses.gpl2Plus; - platforms = platforms.unix; + homepage = "https://xmp.sourceforge.net/"; + license = licenses.gpl2Plus; + platforms = platforms.unix; mainProgram = "xmp"; }; } diff --git a/pkgs/applications/audio/youtube-music/default.nix b/pkgs/applications/audio/youtube-music/default.nix index 8ed37540a4d702..b3cf7a032fad61 100644 --- a/pkgs/applications/audio/youtube-music/default.nix +++ b/pkgs/applications/audio/youtube-music/default.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, makeWrapper -, electron -, python3 -, stdenv -, copyDesktopItems -, nodejs -, pnpm -, makeDesktopItem +{ + lib, + fetchFromGitHub, + makeWrapper, + electron, + python3, + stdenv, + copyDesktopItems, + nodejs, + pnpm, + makeDesktopItem, }: stdenv.mkDerivation (finalAttrs: { @@ -26,43 +27,52 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-brHNp19BEYzgxhdNnn7n1GYhBdyi3S/2VqvKWXmKGX8="; }; - nativeBuildInputs = [ makeWrapper python3 nodejs pnpm.configHook ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ copyDesktopItems ]; - + nativeBuildInputs = [ + makeWrapper + python3 + nodejs + pnpm.configHook + ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ copyDesktopItems ]; ELECTRON_SKIP_BINARY_DOWNLOAD = 1; - postBuild = lib.optionalString stdenv.hostPlatform.isDarwin '' - cp -R ${electron.dist}/Electron.app Electron.app - chmod -R u+w Electron.app - '' + '' - pnpm build - ./node_modules/.bin/electron-builder \ - --dir \ - -c.electronDist=${if stdenv.hostPlatform.isDarwin then "." else electron.dist} \ - -c.electronVersion=${electron.version} - ''; + postBuild = + lib.optionalString stdenv.hostPlatform.isDarwin '' + cp -R ${electron.dist}/Electron.app Electron.app + chmod -R u+w Electron.app + '' + + '' + pnpm build + ./node_modules/.bin/electron-builder \ + --dir \ + -c.electronDist=${if stdenv.hostPlatform.isDarwin then "." else electron.dist} \ + -c.electronVersion=${electron.version} + ''; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/{Applications,bin} - mv pack/mac*/YouTube\ Music.app $out/Applications - makeWrapper $out/Applications/YouTube\ Music.app/Contents/MacOS/YouTube\ Music $out/bin/youtube-music - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - mkdir -p "$out/share/lib/youtube-music" - cp -r pack/*-unpacked/{locales,resources{,.pak}} "$out/share/lib/youtube-music" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/{Applications,bin} + mv pack/mac*/YouTube\ Music.app $out/Applications + makeWrapper $out/Applications/YouTube\ Music.app/Contents/MacOS/YouTube\ Music $out/bin/youtube-music + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + mkdir -p "$out/share/lib/youtube-music" + cp -r pack/*-unpacked/{locales,resources{,.pak}} "$out/share/lib/youtube-music" - pushd assets/generated/icons/png - for file in *.png; do - install -Dm0644 $file $out/share/icons/hicolor/''${file//.png}/apps/youtube-music.png - done - popd - '' + '' + pushd assets/generated/icons/png + for file in *.png; do + install -Dm0644 $file $out/share/icons/hicolor/''${file//.png}/apps/youtube-music.png + done + popd + '' + + '' - runHook postInstall - ''; + runHook postInstall + ''; postFixup = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' makeWrapper ${electron}/bin/electron $out/bin/youtube-music \ @@ -87,10 +97,20 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Electron wrapper around YouTube Music"; homepage = "https://th-ch.github.io/youtube-music/"; - changelog = "https://github.com/th-ch/youtube-music/blob/master/changelog.md#${lib.replaceStrings ["."] [""] finalAttrs.src.rev}"; + changelog = "https://github.com/th-ch/youtube-music/blob/master/changelog.md#${ + lib.replaceStrings [ "." ] [ "" ] finalAttrs.src.rev + }"; license = licenses.mit; - maintainers = with maintainers; [ aacebedo SuperSandro2000 ]; + maintainers = with maintainers; [ + aacebedo + SuperSandro2000 + ]; mainProgram = "youtube-music"; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; }; }) diff --git a/pkgs/applications/audio/zynaddsubfx/default.nix b/pkgs/applications/audio/zynaddsubfx/default.nix index b419ec217a8088..77045ea36dfb6e 100644 --- a/pkgs/applications/audio/zynaddsubfx/default.nix +++ b/pkgs/applications/audio/zynaddsubfx/default.nix @@ -1,62 +1,71 @@ -{ lib -, stdenv -, fetchFromGitHub -, callPackage -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + callPackage, + fetchpatch, # Required build tools -, cmake -, makeWrapper -, pkg-config + cmake, + makeWrapper, + pkg-config, # Required dependencies -, fftw -, liblo -, minixml -, zlib + fftw, + liblo, + minixml, + zlib, # Optional dependencies -, alsaSupport ? stdenv.hostPlatform.isLinux -, alsa-lib -, dssiSupport ? false -, dssi -, ladspaH -, jackSupport ? true -, libjack2 -, lashSupport ? false -, lash -, ossSupport ? true -, portaudioSupport ? true -, portaudio -, sndioSupport ? stdenv.hostPlatform.isOpenBSD -, sndio + alsaSupport ? stdenv.hostPlatform.isLinux, + alsa-lib, + dssiSupport ? false, + dssi, + ladspaH, + jackSupport ? true, + libjack2, + lashSupport ? false, + lash, + ossSupport ? true, + portaudioSupport ? true, + portaudio, + sndioSupport ? stdenv.hostPlatform.isOpenBSD, + sndio, # Optional GUI dependencies -, guiModule ? "off" -, cairo -, fltk -, libGL -, libjpeg -, libX11 -, libXpm -, ntk + guiModule ? "off", + cairo, + fltk, + libGL, + libjpeg, + libX11, + libXpm, + ntk, # Test dependencies -, cxxtest -, ruby + cxxtest, + ruby, }: -assert builtins.any (g: guiModule == g) [ "fltk" "ntk" "zest" "off" ]; +assert builtins.any (g: guiModule == g) [ + "fltk" + "ntk" + "zest" + "off" +]; let - guiName = { - "fltk" = "FLTK"; - "ntk" = "NTK"; - "zest" = "Zyn-Fusion"; - }.${guiModule}; + guiName = + { + "fltk" = "FLTK"; + "ntk" = "NTK"; + "zest" = "Zyn-Fusion"; + } + .${guiModule}; mruby-zest = callPackage ./mruby-zest { }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "zynaddsubfx"; version = "3.0.6"; @@ -68,7 +77,10 @@ in stdenv.mkDerivation rec { hash = "sha256-0siAx141DZx39facXWmKbsi0rHBNpobApTdey07EcXg="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; patches = [ # Lazily expand ZYN_DATADIR to fix builtin banks across updates @@ -82,18 +94,42 @@ in stdenv.mkDerivation rec { patchShebangs rtosc/test/test-port-checker.rb src/Tests/check-ports.rb ''; - nativeBuildInputs = [ cmake makeWrapper pkg-config ]; + nativeBuildInputs = [ + cmake + makeWrapper + pkg-config + ]; - buildInputs = [ fftw liblo minixml zlib ] + buildInputs = + [ + fftw + liblo + minixml + zlib + ] ++ lib.optionals alsaSupport [ alsa-lib ] - ++ lib.optionals dssiSupport [ dssi ladspaH ] + ++ lib.optionals dssiSupport [ + dssi + ladspaH + ] ++ lib.optionals jackSupport [ libjack2 ] ++ lib.optionals lashSupport [ lash ] ++ lib.optionals portaudioSupport [ portaudio ] ++ lib.optionals sndioSupport [ sndio ] - ++ lib.optionals (guiModule == "fltk") [ fltk libjpeg libXpm ] - ++ lib.optionals (guiModule == "ntk") [ ntk cairo libXpm ] - ++ lib.optionals (guiModule == "zest") [ libGL libX11 ]; + ++ lib.optionals (guiModule == "fltk") [ + fltk + libjpeg + libXpm + ] + ++ lib.optionals (guiModule == "ntk") [ + ntk + cairo + libXpm + ] + ++ lib.optionals (guiModule == "zest") [ + libGL + libX11 + ]; cmakeFlags = [ @@ -112,23 +148,31 @@ in stdenv.mkDerivation rec { ]; doCheck = true; - nativeCheckInputs = [ cxxtest ruby ]; + nativeCheckInputs = [ + cxxtest + ruby + ]; # TODO: Update cmake hook to make it simpler to selectively disable cmake tests: #113829 - checkPhase = let - disabledTests = - # PortChecker is non-deterministic. It's fixed in the master - # branch, but backporting would require an update to rtosc, so - # we'll just disable it until the next release. - [ "PortChecker" ] - - # Tests fail on aarch64 - ++ lib.optionals stdenv.hostPlatform.isAarch64 [ "MessageTest" "UnisonTest" ]; - in '' - runHook preCheck - ctest --output-on-failure -E '^${lib.concatStringsSep "|" disabledTests}$' - runHook postCheck - ''; + checkPhase = + let + disabledTests = + # PortChecker is non-deterministic. It's fixed in the master + # branch, but backporting would require an update to rtosc, so + # we'll just disable it until the next release. + [ "PortChecker" ] + + # Tests fail on aarch64 + ++ lib.optionals stdenv.hostPlatform.isAarch64 [ + "MessageTest" + "UnisonTest" + ]; + in + '' + runHook preCheck + ctest --output-on-failure -E '^${lib.concatStringsSep "|" disabledTests}$' + runHook postCheck + ''; # Use Zyn-Fusion logo for zest build # An SVG version of the logo isn't hosted anywhere we can fetch, I @@ -156,9 +200,10 @@ in stdenv.mkDerivation rec { description = "High quality software synthesizer (${guiName} GUI)"; mainProgram = "zynaddsubfx"; homepage = - if guiModule == "zest" - then "https://zynaddsubfx.sourceforge.io/zyn-fusion.html" - else "https://zynaddsubfx.sourceforge.io"; + if guiModule == "zest" then + "https://zynaddsubfx.sourceforge.io/zyn-fusion.html" + else + "https://zynaddsubfx.sourceforge.io"; license = licenses.gpl2Plus; maintainers = with maintainers; [ kira-bruneau ]; diff --git a/pkgs/applications/audio/zynaddsubfx/mruby-zest/default.nix b/pkgs/applications/audio/zynaddsubfx/mruby-zest/default.nix index 7f33e10f742080..d7b9ad31335371 100644 --- a/pkgs/applications/audio/zynaddsubfx/mruby-zest/default.nix +++ b/pkgs/applications/audio/zynaddsubfx/mruby-zest/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, bison -, pkg-config -, rake -, ruby -, libGL -, libuv -, libX11 +{ + lib, + stdenv, + fetchFromGitHub, + bison, + pkg-config, + rake, + ruby, + libGL, + libuv, + libX11, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/backup/restique/default.nix b/pkgs/applications/backup/restique/default.nix index b7038d5a3d6ed1..d2e1a78361ee5d 100644 --- a/pkgs/applications/backup/restique/default.nix +++ b/pkgs/applications/backup/restique/default.nix @@ -1,11 +1,12 @@ -{ lib -, mkDerivation -, fetchFromGitea -, cmake -, libsecret -, qtkeychain -, qttools -, restic +{ + lib, + mkDerivation, + fetchFromGitea, + cmake, + libsecret, + qtkeychain, + qttools, + restic, }: mkDerivation rec { @@ -31,13 +32,20 @@ mkDerivation rec { ]; qtWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath [ restic ]) + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ restic ]) ]; meta = with lib; { description = "Restic GUI for Desktop/Laptop Backups"; homepage = "https://git.srcbox.net/stefan/restique"; - license = with licenses; [ gpl3Plus cc-by-sa-40 cc0 ]; + license = with licenses; [ + gpl3Plus + cc-by-sa-40 + cc0 + ]; maintainers = with maintainers; [ dotlambda ]; mainProgram = "restique"; }; diff --git a/pkgs/applications/backup/vorta/default.nix b/pkgs/applications/backup/vorta/default.nix index 8bc6e719718ad4..0eb847724fea62 100644 --- a/pkgs/applications/backup/vorta/default.nix +++ b/pkgs/applications/backup/vorta/default.nix @@ -1,12 +1,13 @@ -{ lib -, python3Packages -, fetchFromGitHub -, wrapQtAppsHook -, borgbackup -, qtbase -, qtwayland -, stdenv -, makeFontsConf +{ + lib, + python3Packages, + fetchFromGitHub, + wrapQtAppsHook, + borgbackup, + qtbase, + qtwayland, + stdenv, + makeFontsConf, }: python3Packages.buildPythonApplication rec { @@ -62,18 +63,20 @@ python3Packages.buildPythonApplication rec { pytestCheckHook ]; - preCheck = let - fontsConf = makeFontsConf { - fontDirectories = [ ]; - }; - in '' - export HOME=$(mktemp -d) - export FONTCONFIG_FILE=${fontsConf}; - # For tests/test_misc.py::test_autostart - mkdir -p $HOME/.config/autostart - export QT_PLUGIN_PATH="${qtbase}/${qtbase.qtPluginPrefix}" - export QT_QPA_PLATFORM=offscreen - ''; + preCheck = + let + fontsConf = makeFontsConf { + fontDirectories = [ ]; + }; + in + '' + export HOME=$(mktemp -d) + export FONTCONFIG_FILE=${fontsConf}; + # For tests/test_misc.py::test_autostart + mkdir -p $HOME/.config/autostart + export QT_PLUGIN_PATH="${qtbase}/${qtbase.qtPluginPrefix}" + export QT_QPA_PLATFORM=offscreen + ''; disabledTestPaths = [ # QObject::connect: No such signal QPlatformNativeInterface::systemTrayWindowChanged(QScreen*) diff --git a/pkgs/applications/blockchains/bitcoin-abc/default.nix b/pkgs/applications/blockchains/bitcoin-abc/default.nix index 8ae8a998b76c41..d4c96b31232d65 100644 --- a/pkgs/applications/blockchains/bitcoin-abc/default.nix +++ b/pkgs/applications/blockchains/bitcoin-abc/default.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, mkDerivation -, fetchFromGitHub -, fetchpatch2 -, pkg-config -, cmake -, openssl -, db53 -, boost -, zlib -, miniupnpc -, qtbase ? null -, qttools ? null -, util-linux -, protobuf -, qrencode -, libevent -, libnatpmp -, sqlite -, withGui -, python3 -, jemalloc -, zeromq4 +{ + lib, + stdenv, + mkDerivation, + fetchFromGitHub, + fetchpatch2, + pkg-config, + cmake, + openssl, + db53, + boost, + zlib, + miniupnpc, + qtbase ? null, + qttools ? null, + util-linux, + protobuf, + qrencode, + libevent, + libnatpmp, + sqlite, + withGui, + python3, + jemalloc, + zeromq4, }: mkDerivation rec { @@ -43,22 +44,31 @@ mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config cmake ]; - buildInputs = [ - openssl - db53 - boost - zlib - python3 - jemalloc - libnatpmp - zeromq4 - miniupnpc - util-linux - protobuf - libevent - sqlite - ] ++ lib.optionals withGui [ qtbase qttools qrencode ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; + buildInputs = + [ + openssl + db53 + boost + zlib + python3 + jemalloc + libnatpmp + zeromq4 + miniupnpc + util-linux + protobuf + libevent + sqlite + ] + ++ lib.optionals withGui [ + qtbase + qttools + qrencode + ]; cmakeFlags = lib.optionals (!withGui) [ "-DBUILD_BITCOIN_QT=OFF" diff --git a/pkgs/applications/blockchains/bitcoin-knots/default.nix b/pkgs/applications/blockchains/bitcoin-knots/default.nix index e0db12dc167c1e..984ba370893bce 100644 --- a/pkgs/applications/blockchains/bitcoin-knots/default.nix +++ b/pkgs/applications/blockchains/bitcoin-knots/default.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch2 -, autoreconfHook -, pkg-config -, util-linux -, hexdump -, autoSignDarwinBinariesHook -, wrapQtAppsHook ? null -, boost -, libevent -, miniupnpc -, zeromq -, zlib -, db48 -, sqlite -, qrencode -, qtbase ? null -, qttools ? null -, python3 -, withGui -, withWallet ? true +{ + lib, + stdenv, + fetchurl, + fetchpatch2, + autoreconfHook, + pkg-config, + util-linux, + hexdump, + autoSignDarwinBinariesHook, + wrapQtAppsHook ? null, + boost, + libevent, + miniupnpc, + zeromq, + zlib, + db48, + sqlite, + qrencode, + qtbase ? null, + qttools ? null, + python3, + withGui, + withWallet ? true, }: stdenv.mkDerivation rec { @@ -41,29 +42,49 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = - [ autoreconfHook pkg-config ] + [ + autoreconfHook + pkg-config + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ util-linux ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ hexdump ] - ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ autoSignDarwinBinariesHook ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + autoSignDarwinBinariesHook + ] ++ lib.optionals withGui [ wrapQtAppsHook ]; - buildInputs = [ boost libevent miniupnpc zeromq zlib ] + buildInputs = + [ + boost + libevent + miniupnpc + zeromq + zlib + ] ++ lib.optionals withWallet [ sqlite ] ++ lib.optionals (withWallet && !stdenv.hostPlatform.isDarwin) [ db48 ] - ++ lib.optionals withGui [ qrencode qtbase qttools ]; + ++ lib.optionals withGui [ + qrencode + qtbase + qttools + ]; - configureFlags = [ - "--with-boost-libdir=${boost.out}/lib" - "--disable-bench" - ] ++ lib.optionals (!doCheck) [ - "--disable-tests" - "--disable-gui-tests" - ] ++ lib.optionals (!withWallet) [ - "--disable-wallet" - ] ++ lib.optionals withGui [ - "--with-gui=qt5" - "--with-qt-bindir=${qtbase.dev}/bin:${qttools.dev}/bin" - ]; + configureFlags = + [ + "--with-boost-libdir=${boost.out}/lib" + "--disable-bench" + ] + ++ lib.optionals (!doCheck) [ + "--disable-tests" + "--disable-gui-tests" + ] + ++ lib.optionals (!withWallet) [ + "--disable-wallet" + ] + ++ lib.optionals withGui [ + "--with-gui=qt5" + "--with-qt-bindir=${qtbase.dev}/bin:${qttools.dev}/bin" + ]; nativeCheckInputs = [ python3 ]; @@ -81,7 +102,10 @@ stdenv.mkDerivation rec { description = "Derivative of Bitcoin Core with a collection of improvements"; homepage = "https://bitcoinknots.org/"; changelog = "https://github.com/bitcoinknots/bitcoin/blob/v${version}/doc/release-notes.md"; - maintainers = with maintainers; [ prusnak mmahut ]; + maintainers = with maintainers; [ + prusnak + mmahut + ]; license = licenses.mit; platforms = platforms.unix; }; diff --git a/pkgs/applications/blockchains/bitcoin/default.nix b/pkgs/applications/blockchains/bitcoin/default.nix index e56d332cf57594..03f518cbab9282 100644 --- a/pkgs/applications/blockchains/bitcoin/default.nix +++ b/pkgs/applications/blockchains/bitcoin/default.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch2 -, autoreconfHook -, pkg-config -, installShellFiles -, util-linux -, hexdump -, autoSignDarwinBinariesHook -, wrapQtAppsHook ? null -, boost -, libevent -, miniupnpc -, zeromq -, zlib -, db48 -, sqlite -, qrencode -, qtbase ? null -, qttools ? null -, python3 -, nixosTests -, withGui -, withWallet ? true +{ + lib, + stdenv, + fetchurl, + fetchpatch2, + autoreconfHook, + pkg-config, + installShellFiles, + util-linux, + hexdump, + autoSignDarwinBinariesHook, + wrapQtAppsHook ? null, + boost, + libevent, + miniupnpc, + zeromq, + zlib, + db48, + sqlite, + qrencode, + qtbase ? null, + qttools ? null, + python3, + nixosTests, + withGui, + withWallet ? true, }: let @@ -45,52 +46,75 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = - [ autoreconfHook pkg-config installShellFiles ] + [ + autoreconfHook + pkg-config + installShellFiles + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ util-linux ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ hexdump ] - ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ autoSignDarwinBinariesHook ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + autoSignDarwinBinariesHook + ] ++ lib.optionals withGui [ wrapQtAppsHook ]; - buildInputs = [ boost libevent miniupnpc zeromq zlib ] + buildInputs = + [ + boost + libevent + miniupnpc + zeromq + zlib + ] ++ lib.optionals withWallet [ sqlite ] # building with db48 (for legacy descriptor wallet support) is broken on Darwin ++ lib.optionals (withWallet && !stdenv.hostPlatform.isDarwin) [ db48 ] - ++ lib.optionals withGui [ qrencode qtbase qttools ]; + ++ lib.optionals withGui [ + qrencode + qtbase + qttools + ]; - postInstall = '' - installShellCompletion --bash contrib/completions/bash/bitcoin-cli.bash - installShellCompletion --bash contrib/completions/bash/bitcoind.bash - installShellCompletion --bash contrib/completions/bash/bitcoin-tx.bash + postInstall = + '' + installShellCompletion --bash contrib/completions/bash/bitcoin-cli.bash + installShellCompletion --bash contrib/completions/bash/bitcoind.bash + installShellCompletion --bash contrib/completions/bash/bitcoin-tx.bash - installShellCompletion --fish contrib/completions/fish/bitcoin-cli.fish - installShellCompletion --fish contrib/completions/fish/bitcoind.fish - installShellCompletion --fish contrib/completions/fish/bitcoin-tx.fish - installShellCompletion --fish contrib/completions/fish/bitcoin-util.fish - installShellCompletion --fish contrib/completions/fish/bitcoin-wallet.fish - '' + lib.optionalString withGui '' - installShellCompletion --fish contrib/completions/fish/bitcoin-qt.fish + installShellCompletion --fish contrib/completions/fish/bitcoin-cli.fish + installShellCompletion --fish contrib/completions/fish/bitcoind.fish + installShellCompletion --fish contrib/completions/fish/bitcoin-tx.fish + installShellCompletion --fish contrib/completions/fish/bitcoin-util.fish + installShellCompletion --fish contrib/completions/fish/bitcoin-wallet.fish + '' + + lib.optionalString withGui '' + installShellCompletion --fish contrib/completions/fish/bitcoin-qt.fish - install -Dm644 ${desktop} $out/share/applications/bitcoin-qt.desktop - substituteInPlace $out/share/applications/bitcoin-qt.desktop --replace "Icon=bitcoin128" "Icon=bitcoin" - install -Dm644 share/pixmaps/bitcoin256.png $out/share/pixmaps/bitcoin.png - ''; + install -Dm644 ${desktop} $out/share/applications/bitcoin-qt.desktop + substituteInPlace $out/share/applications/bitcoin-qt.desktop --replace "Icon=bitcoin128" "Icon=bitcoin" + install -Dm644 share/pixmaps/bitcoin256.png $out/share/pixmaps/bitcoin.png + ''; preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin '' export MACOSX_DEPLOYMENT_TARGET=10.13 ''; - configureFlags = [ - "--with-boost-libdir=${boost.out}/lib" - "--disable-bench" - ] ++ lib.optionals (!doCheck) [ - "--disable-tests" - "--disable-gui-tests" - ] ++ lib.optionals (!withWallet) [ - "--disable-wallet" - ] ++ lib.optionals withGui [ - "--with-gui=qt5" - "--with-qt-bindir=${qtbase.dev}/bin:${qttools.dev}/bin" - ]; + configureFlags = + [ + "--with-boost-libdir=${boost.out}/lib" + "--disable-bench" + ] + ++ lib.optionals (!doCheck) [ + "--disable-tests" + "--disable-gui-tests" + ] + ++ lib.optionals (!withWallet) [ + "--disable-wallet" + ] + ++ lib.optionals withGui [ + "--with-gui=qt5" + "--with-qt-bindir=${qtbase.dev}/bin:${qttools.dev}/bin" + ]; nativeCheckInputs = [ python3 ]; @@ -119,7 +143,10 @@ stdenv.mkDerivation rec { homepage = "https://bitcoin.org/en/"; downloadPage = "https://bitcoincore.org/bin/bitcoin-core-${version}/"; changelog = "https://bitcoincore.org/en/releases/${version}/"; - maintainers = with maintainers; [ prusnak roconnor ]; + maintainers = with maintainers; [ + prusnak + roconnor + ]; license = licenses.mit; platforms = platforms.unix; }; diff --git a/pkgs/applications/blockchains/cryptop/default.nix b/pkgs/applications/blockchains/cryptop/default.nix index 588fb03a36569b..61ab913b2e1562 100644 --- a/pkgs/applications/blockchains/cryptop/default.nix +++ b/pkgs/applications/blockchains/cryptop/default.nix @@ -1,4 +1,11 @@ -{ lib, buildPythonApplication, fetchPypi, requests, requests-cache, setuptools }: +{ + lib, + buildPythonApplication, + fetchPypi, + requests, + requests-cache, + setuptools, +}: buildPythonApplication rec { pname = "cryptop"; @@ -9,7 +16,11 @@ buildPythonApplication rec { sha256 = "0akrrz735vjfrm78plwyg84vabj0x3qficq9xxmy9kr40fhdkzpb"; }; - propagatedBuildInputs = [ setuptools requests requests-cache ]; + propagatedBuildInputs = [ + setuptools + requests + requests-cache + ]; # No tests in archive doCheck = false; diff --git a/pkgs/applications/blockchains/digibyte/default.nix b/pkgs/applications/blockchains/digibyte/default.nix index 4e563d21fa22db..bb254dc0c32f6a 100644 --- a/pkgs/applications/blockchains/digibyte/default.nix +++ b/pkgs/applications/blockchains/digibyte/default.nix @@ -1,18 +1,20 @@ -{ lib, stdenv -, fetchFromGitHub -, openssl -, boost -, libevent -, autoreconfHook -, db4 -, pkg-config -, protobuf -, hexdump -, zeromq -, withGui -, qtbase ? null -, qttools ? null -, wrapQtAppsHook ? null +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + boost, + libevent, + autoreconfHook, + db4, + pkg-config, + protobuf, + hexdump, + zeromq, + withGui, + qtbase ? null, + qttools ? null, + wrapQtAppsHook ? null, }: stdenv.mkDerivation rec { @@ -28,34 +30,40 @@ stdenv.mkDerivation rec { sha256 = "zPwnC2qd28fA1saG4nysPlKU1nnXhfuSG3DpCY6T+kM="; }; - nativeBuildInputs = [ - autoreconfHook - pkg-config - hexdump - ] ++ lib.optionals withGui [ - wrapQtAppsHook - ]; + nativeBuildInputs = + [ + autoreconfHook + pkg-config + hexdump + ] + ++ lib.optionals withGui [ + wrapQtAppsHook + ]; - buildInputs = [ - openssl - boost - libevent - db4 - zeromq - ] ++ lib.optionals withGui [ - qtbase - qttools - protobuf - ]; + buildInputs = + [ + openssl + boost + libevent + db4 + zeromq + ] + ++ lib.optionals withGui [ + qtbase + qttools + protobuf + ]; enableParallelBuilding = true; - configureFlags = [ + configureFlags = + [ "--with-boost-libdir=${boost.out}/lib" - ] ++ lib.optionals withGui [ + ] + ++ lib.optionals withGui [ "--with-gui=qt5" "--with-qt-bindir=${qtbase.dev}/bin:${qttools.dev}/bin" - ]; + ]; meta = with lib; { description = "DigiByte (DGB) is a rapidly growing decentralized, global blockchain"; diff --git a/pkgs/applications/blockchains/electrs/default.nix b/pkgs/applications/blockchains/electrs/default.nix index 3c669592c0dd5a..c24cca9fcf0be9 100644 --- a/pkgs/applications/blockchains/electrs/default.nix +++ b/pkgs/applications/blockchains/electrs/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, rocksdb_7_10 -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + rocksdb_7_10, + Security, }: let diff --git a/pkgs/applications/blockchains/fulcrum/default.nix b/pkgs/applications/blockchains/fulcrum/default.nix index 8c45ab48570280..b52c720267e5af 100644 --- a/pkgs/applications/blockchains/fulcrum/default.nix +++ b/pkgs/applications/blockchains/fulcrum/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, qmake -, python3 -, qtbase -, rocksdb_7_10 -, zeromq +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + qmake, + python3, + qtbase, + rocksdb_7_10, + zeromq, }: stdenv.mkDerivation rec { @@ -20,11 +21,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-+hBc7jW1MVLVjYXNOV7QvFJJpZ5RzW5/c9NdqOXrsj0="; }; - nativeBuildInputs = [ pkg-config qmake ]; + nativeBuildInputs = [ + pkg-config + qmake + ]; dontWrapQtApps = true; # no GUI - buildInputs = [ python3 qtbase rocksdb_7_10 zeromq ]; + buildInputs = [ + python3 + qtbase + rocksdb_7_10 + zeromq + ]; meta = with lib; { description = "Fast & nimble SPV server for Bitcoin Cash & Bitcoin BTC"; diff --git a/pkgs/applications/blockchains/gridcoin-research/default.nix b/pkgs/applications/blockchains/gridcoin-research/default.nix index d5e06622ae0d25..136800a4eb11d2 100644 --- a/pkgs/applications/blockchains/gridcoin-research/default.nix +++ b/pkgs/applications/blockchains/gridcoin-research/default.nix @@ -1,20 +1,21 @@ -{ fetchFromGitHub -, stdenv -, lib -, openssl -, boost -, curl -, libevent -, libzip -, qrencode -, qtbase -, qttools -, wrapQtAppsHook -, autoreconfHook -, pkg-config -, libtool -, miniupnpc -, hexdump +{ + fetchFromGitHub, + stdenv, + lib, + openssl, + boost, + curl, + libevent, + libzip, + qrencode, + qtbase, + qttools, + wrapQtAppsHook, + autoreconfHook, + pkg-config, + libtool, + miniupnpc, + hexdump, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/blockchains/groestlcoin/default.nix b/pkgs/applications/blockchains/groestlcoin/default.nix index b107cd23726311..2922a04723120d 100644 --- a/pkgs/applications/blockchains/groestlcoin/default.nix +++ b/pkgs/applications/blockchains/groestlcoin/default.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitHub -, autoreconfHook -, pkg-config -, installShellFiles -, util-linux -, hexdump -, autoSignDarwinBinariesHook -, wrapQtAppsHook ? null -, boost -, libevent -, miniupnpc -, zeromq -, zlib -, db53 -, sqlite -, qrencode -, qtbase ? null -, qttools ? null -, python3 -, withGui ? false -, withWallet ? true +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + autoreconfHook, + pkg-config, + installShellFiles, + util-linux, + hexdump, + autoSignDarwinBinariesHook, + wrapQtAppsHook ? null, + boost, + libevent, + miniupnpc, + zeromq, + zlib, + db53, + sqlite, + qrencode, + qtbase ? null, + qttools ? null, + python3, + withGui ? false, + withWallet ? true, }: let @@ -42,49 +43,76 @@ stdenv.mkDerivation rec { sha256 = "0kl7nq62362clgzxwwd5c256xnaar4ilxcvbralazxg47zv95r11"; }; - nativeBuildInputs = [ autoreconfHook pkg-config installShellFiles ] + nativeBuildInputs = + [ + autoreconfHook + pkg-config + installShellFiles + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ util-linux ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ hexdump ] - ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ autoSignDarwinBinariesHook ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + autoSignDarwinBinariesHook + ] ++ lib.optionals withGui [ wrapQtAppsHook ]; - buildInputs = [ boost libevent miniupnpc zeromq zlib ] - ++ lib.optionals withWallet [ db53 sqlite ] - ++ lib.optionals withGui [ qrencode qtbase qttools ]; + buildInputs = + [ + boost + libevent + miniupnpc + zeromq + zlib + ] + ++ lib.optionals withWallet [ + db53 + sqlite + ] + ++ lib.optionals withGui [ + qrencode + qtbase + qttools + ]; - postInstall = '' - installShellCompletion --bash contrib/completions/bash/groestlcoin-cli.bash - installShellCompletion --bash contrib/completions/bash/groestlcoind.bash - installShellCompletion --bash contrib/completions/bash/groestlcoin-tx.bash + postInstall = + '' + installShellCompletion --bash contrib/completions/bash/groestlcoin-cli.bash + installShellCompletion --bash contrib/completions/bash/groestlcoind.bash + installShellCompletion --bash contrib/completions/bash/groestlcoin-tx.bash - for file in contrib/completions/fish/groestlcoin-*.fish; do - installShellCompletion --fish $file - done - '' + lib.optionalString withGui '' - installShellCompletion --fish contrib/completions/fish/groestlcoin-qt.fish + for file in contrib/completions/fish/groestlcoin-*.fish; do + installShellCompletion --fish $file + done + '' + + lib.optionalString withGui '' + installShellCompletion --fish contrib/completions/fish/groestlcoin-qt.fish - install -Dm644 ${desktop} $out/share/applications/groestlcoin-qt.desktop - substituteInPlace $out/share/applications/groestlcoin-qt.desktop --replace "Icon=groestlcoin128" "Icon=groestlcoin" - install -Dm644 share/pixmaps/groestlcoin256.png $out/share/pixmaps/groestlcoin.png - ''; + install -Dm644 ${desktop} $out/share/applications/groestlcoin-qt.desktop + substituteInPlace $out/share/applications/groestlcoin-qt.desktop --replace "Icon=groestlcoin128" "Icon=groestlcoin" + install -Dm644 share/pixmaps/groestlcoin256.png $out/share/pixmaps/groestlcoin.png + ''; preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin '' export MACOSX_DEPLOYMENT_TARGET=10.13 ''; - configureFlags = [ - "--with-boost-libdir=${boost.out}/lib" - "--disable-bench" - ] ++ lib.optionals (!withWallet) [ - "--disable-wallet" - ] ++ lib.optionals withGui [ - "--with-gui=qt5" - "--with-qt-bindir=${qtbase.dev}/bin:${qttools.dev}/bin" - ]; + configureFlags = + [ + "--with-boost-libdir=${boost.out}/lib" + "--disable-bench" + ] + ++ lib.optionals (!withWallet) [ + "--disable-wallet" + ] + ++ lib.optionals withGui [ + "--with-gui=qt5" + "--with-qt-bindir=${qtbase.dev}/bin:${qttools.dev}/bin" + ]; nativeCheckInputs = [ python3 ]; - checkFlags = [ "LC_ALL=en_US.UTF-8" ] + checkFlags = + [ "LC_ALL=en_US.UTF-8" ] # QT_PLUGIN_PATH needs to be set when executing QT, which is needed when testing Groestlcoin's GUI. # See also https://github.com/NixOS/nixpkgs/issues/24256 ++ lib.optional withGui "QT_PLUGIN_PATH=${qtbase}/${qtbase.qtPluginPrefix}"; diff --git a/pkgs/applications/blockchains/haven-cli/default.nix b/pkgs/applications/blockchains/haven-cli/default.nix index 31ceee6ff1025c..55024aa83e440b 100644 --- a/pkgs/applications/blockchains/haven-cli/default.nix +++ b/pkgs/applications/blockchains/haven-cli/default.nix @@ -1,10 +1,30 @@ -{ lib, stdenv, fetchFromGitHub, cmake, ninja, pkg-config -, boost, miniupnpc, openssl, unbound -, zeromq, pcsclite, readline, libsodium, hidapi -, randomx, rapidjson, easyloggingpp -, CoreData, IOKit, PCSC -, trezorSupport ? true, libusb1, protobuf, python3 -, monero-cli +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + pkg-config, + boost, + miniupnpc, + openssl, + unbound, + zeromq, + pcsclite, + readline, + libsodium, + hidapi, + randomx, + rapidjson, + easyloggingpp, + CoreData, + IOKit, + PCSC, + trezorSupport ? true, + libusb1, + protobuf, + python3, + monero-cli, }: stdenv.mkDerivation rec { @@ -28,33 +48,62 @@ stdenv.mkDerivation rec { cp -r . $source ''; - nativeBuildInputs = [ cmake ninja pkg-config ]; - - buildInputs = [ - boost miniupnpc openssl unbound - zeromq pcsclite readline - libsodium hidapi randomx rapidjson - protobuf readline easyloggingpp - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ IOKit CoreData PCSC ] - ++ lib.optionals trezorSupport [ libusb1 protobuf python3 ]; - - cmakeFlags = [ - "-DBUILD_GUI_DEPS=ON" - "-DReadline_ROOT_DIR=${readline.dev}" - "-DReadline_INCLUDE_DIR=${readline.dev}/include/readline" - "-DRandomX_ROOT_DIR=${randomx}" - ] ++ lib.optional stdenv.hostPlatform.isDarwin "-DBoost_USE_MULTITHREADED=OFF" + nativeBuildInputs = [ + cmake + ninja + pkg-config + ]; + + buildInputs = + [ + boost + miniupnpc + openssl + unbound + zeromq + pcsclite + readline + libsodium + hidapi + randomx + rapidjson + protobuf + readline + easyloggingpp + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + IOKit + CoreData + PCSC + ] + ++ lib.optionals trezorSupport [ + libusb1 + protobuf + python3 + ]; + + cmakeFlags = + [ + "-DBUILD_GUI_DEPS=ON" + "-DReadline_ROOT_DIR=${readline.dev}" + "-DReadline_INCLUDE_DIR=${readline.dev}/include/readline" + "-DRandomX_ROOT_DIR=${randomx}" + ] + ++ lib.optional stdenv.hostPlatform.isDarwin "-DBoost_USE_MULTITHREADED=OFF" ++ lib.optional (!trezorSupport) "-DUSE_DEVICE_TREZOR=OFF"; - outputs = [ "out" "source" ]; + outputs = [ + "out" + "source" + ]; meta = with lib; { - description = "Haven Protocol is the world's only network of private stable asset"; - homepage = "https://havenprotocol.org/"; - license = licenses.bsd3; - platforms = platforms.all; + description = "Haven Protocol is the world's only network of private stable asset"; + homepage = "https://havenprotocol.org/"; + license = licenses.bsd3; + platforms = platforms.all; badPlatforms = [ "x86_64-darwin" ]; - maintainers = with maintainers; [ kim0 ]; - mainProgram = "haven-wallet-cli"; + maintainers = with maintainers; [ kim0 ]; + mainProgram = "haven-wallet-cli"; }; } diff --git a/pkgs/applications/blockchains/monero-gui/default.nix b/pkgs/applications/blockchains/monero-gui/default.nix index 7e8a5fe73dcd23..f1173d97f8d9a5 100644 --- a/pkgs/applications/blockchains/monero-gui/default.nix +++ b/pkgs/applications/blockchains/monero-gui/default.nix @@ -126,7 +126,10 @@ stdenv.mkDerivation rec { icon = "monero"; desktopName = "Monero"; genericName = "Wallet"; - categories = [ "Network" "Utility" ]; + categories = [ + "Network" + "Utility" + ]; }; postInstall = '' diff --git a/pkgs/applications/blockchains/nano-wallet/default.nix b/pkgs/applications/blockchains/nano-wallet/default.nix index 0dc6db9e5d7f76..f0080a1150da3b 100644 --- a/pkgs/applications/blockchains/nano-wallet/default.nix +++ b/pkgs/applications/blockchains/nano-wallet/default.nix @@ -1,7 +1,16 @@ -{ lib, stdenv, fetchFromGitHub -, fetchpatch -, cmake, pkg-config, wrapQtAppsHook, boost, libGL -, qtbase, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + wrapQtAppsHook, + boost, + libGL, + qtbase, + python3, +}: stdenv.mkDerivation rec { @@ -27,23 +36,33 @@ stdenv.mkDerivation rec { }) ]; - cmakeFlags = let - options = { - PYTHON_EXECUTABLE = "${python3.interpreter}"; - NANO_SHARED_BOOST = "ON"; - BOOST_ROOT = boost; - RAIBLOCKS_GUI = "ON"; - RAIBLOCKS_TEST = "ON"; - Qt5_DIR = "${qtbase.dev}/lib/cmake/Qt5"; - Qt5Core_DIR = "${qtbase.dev}/lib/cmake/Qt5Core"; - Qt5Gui_INCLUDE_DIRS = "${qtbase.dev}/include/QtGui"; - Qt5Widgets_INCLUDE_DIRS = "${qtbase.dev}/include/QtWidgets"; - }; - optionToFlag = name: value: "-D${name}=${value}"; - in lib.mapAttrsToList optionToFlag options; + cmakeFlags = + let + options = { + PYTHON_EXECUTABLE = "${python3.interpreter}"; + NANO_SHARED_BOOST = "ON"; + BOOST_ROOT = boost; + RAIBLOCKS_GUI = "ON"; + RAIBLOCKS_TEST = "ON"; + Qt5_DIR = "${qtbase.dev}/lib/cmake/Qt5"; + Qt5Core_DIR = "${qtbase.dev}/lib/cmake/Qt5Core"; + Qt5Gui_INCLUDE_DIRS = "${qtbase.dev}/include/QtGui"; + Qt5Widgets_INCLUDE_DIRS = "${qtbase.dev}/include/QtWidgets"; + }; + optionToFlag = name: value: "-D${name}=${value}"; + in + lib.mapAttrsToList optionToFlag options; - nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook ]; - buildInputs = [ boost libGL qtbase ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapQtAppsHook + ]; + buildInputs = [ + boost + libGL + qtbase + ]; strictDeps = true; diff --git a/pkgs/applications/blockchains/optimism/default.nix b/pkgs/applications/blockchains/optimism/default.nix index 73f26ee494b906..d4b915d8cd82b4 100644 --- a/pkgs/applications/blockchains/optimism/default.nix +++ b/pkgs/applications/blockchains/optimism/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, libpcap +{ + lib, + buildGoModule, + fetchFromGitHub, + libpcap, }: buildGoModule rec { @@ -16,7 +17,11 @@ buildGoModule rec { fetchSubmodules = true; }; - subPackages = [ "op-node/cmd" "op-proposer/cmd" "op-batcher/cmd" ]; + subPackages = [ + "op-node/cmd" + "op-proposer/cmd" + "op-batcher/cmd" + ]; vendorHash = "sha256-Sr9OECXbRa4SPe3owMto2EbnAIygeIEmZv73hvA6iww="; @@ -24,7 +29,10 @@ buildGoModule rec { libpcap ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Optimism is Ethereum, scaled"; diff --git a/pkgs/applications/blockchains/optimism/geth.nix b/pkgs/applications/blockchains/optimism/geth.nix index 473ee254d08feb..e88ce594cd8d53 100644 --- a/pkgs/applications/blockchains/optimism/geth.nix +++ b/pkgs/applications/blockchains/optimism/geth.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, buildGoModule -, fetchFromGitHub -, libobjc -, IOKit +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, + libobjc, + IOKit, }: buildGoModule rec { @@ -36,10 +37,15 @@ buildGoModule rec { vendorHash = "sha256-pcIydpKWZt3vwShwzGlPKGq+disdxYFOB8gxHou3mVU="; # Fix for usb-related segmentation faults on darwin - propagatedBuildInputs = - lib.optionals stdenv.hostPlatform.isDarwin [ libobjc IOKit ]; + propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + IOKit + ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = ""; diff --git a/pkgs/applications/blockchains/snarkos/default.nix b/pkgs/applications/blockchains/snarkos/default.nix index 0cebbecc03095d..e54e24c5a7b6d8 100644 --- a/pkgs/applications/blockchains/snarkos/default.nix +++ b/pkgs/applications/blockchains/snarkos/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, fetchFromGitHub -, lib -, rustPlatform -, Security -, curl -, pkg-config -, openssl +{ + stdenv, + fetchFromGitHub, + lib, + rustPlatform, + Security, + curl, + pkg-config, + openssl, }: rustPlatform.buildRustPackage rec { pname = "snarkos"; @@ -22,12 +23,15 @@ rustPlatform.buildRustPackage rec { # buildAndTestSubdir = "cli"; - nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ pkg-config rustPlatform.bindgenHook ]; + nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ + pkg-config + rustPlatform.bindgenHook + ]; # Needed to get openssl-sys to use pkg-config. OPENSSL_NO_VENDOR = 1; OPENSSL_LIB_DIR = "${lib.getLib openssl}/lib"; - OPENSSL_DIR="${lib.getDev openssl}"; + OPENSSL_DIR = "${lib.getDev openssl}"; # TODO check why rust compilation fails by including the rocksdb from nixpkgs # Used by build.rs in the rocksdb-sys crate. If we don't set these, it would @@ -35,7 +39,10 @@ rustPlatform.buildRustPackage rec { # ROCKSDB_INCLUDE_DIR="${rocksdb}/include"; # ROCKSDB_LIB_DIR="${rocksdb}/lib"; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Security curl ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + Security + curl + ]; # some tests are flaky and some need network access # TODO finish filtering the tests to enable them @@ -47,7 +54,6 @@ rustPlatform.buildRustPackage rec { # "--skip=helpers::block_requests::tests::test_block_requests_case_2ca" # ]; - meta = with lib; { description = "Decentralized Operating System for Zero-Knowledge Applications"; homepage = "https://snarkos.org"; diff --git a/pkgs/applications/blockchains/solana-validator/default.nix b/pkgs/applications/blockchains/solana-validator/default.nix index de66bc1c6d57c3..ffd6ec7243703a 100644 --- a/pkgs/applications/blockchains/solana-validator/default.nix +++ b/pkgs/applications/blockchains/solana-validator/default.nix @@ -1,44 +1,47 @@ # largely inspired from https://github.com/saber-hq/saber-overlay/blob/master/packages/solana/solana.nix -{ stdenv -, fetchFromGitHub -, lib -, rustPlatform -, pkg-config -, darwin -, udev -, zlib -, protobuf -, openssl -, libcxx -, rocksdb_8_3 -, rustfmt -, perl -, hidapi -, solanaPkgs ? [ - "solana" - "solana-bench-tps" - "solana-faucet" - "solana-gossip" - "solana-install" - "solana-keygen" - "solana-ledger-tool" - "solana-log-analyzer" - "solana-net-shaper" - "solana-validator" - "cargo-build-bpf" - "cargo-test-bpf" - "solana-dos" - "solana-install-init" - "solana-stake-accounts" - "solana-test-validator" - "solana-tokens" - "solana-watchtower" - ] ++ [ - # XXX: Ensure `solana-genesis` is built LAST! - # See https://github.com/solana-labs/solana/issues/5826 - "solana-genesis" - ] +{ + stdenv, + fetchFromGitHub, + lib, + rustPlatform, + pkg-config, + darwin, + udev, + zlib, + protobuf, + openssl, + libcxx, + rocksdb_8_3, + rustfmt, + perl, + hidapi, + solanaPkgs ? + [ + "solana" + "solana-bench-tps" + "solana-faucet" + "solana-gossip" + "solana-install" + "solana-keygen" + "solana-ledger-tool" + "solana-log-analyzer" + "solana-net-shaper" + "solana-validator" + "cargo-build-bpf" + "cargo-test-bpf" + "solana-dos" + "solana-install-init" + "solana-stake-accounts" + "solana-test-validator" + "solana-tokens" + "solana-watchtower" + ] + ++ [ + # XXX: Ensure `solana-genesis` is built LAST! + # See https://github.com/solana-labs/solana/issues/5826 + "solana-genesis" + ], }: let pinData = lib.importJSON ./pin.json; @@ -46,7 +49,12 @@ let hash = pinData.hash; rocksdb = rocksdb_8_3; inherit (darwin.apple_sdk_11_0) Libsystem; - inherit (darwin.apple_sdk_11_0.frameworks) System IOKit AppKit Security; + inherit (darwin.apple_sdk_11_0.frameworks) + System + IOKit + AppKit + Security + ; in rustPlatform.buildRustPackage rec { pname = "solana-validator"; @@ -72,27 +80,45 @@ rustPlatform.buildRustPackage rec { # weird errors. see https://github.com/NixOS/nixpkgs/issues/52447#issuecomment-852079285 # LLVM_CONFIG_PATH = "${llvm}/bin/llvm-config"; - nativeBuildInputs = [ pkg-config protobuf rustfmt perl rustPlatform.bindgenHook ]; + nativeBuildInputs = [ + pkg-config + protobuf + rustfmt + perl + rustPlatform.bindgenHook + ]; buildInputs = - [ openssl zlib hidapi ] ++ (lib.optionals stdenv.hostPlatform.isLinux [ udev ]) - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security System Libsystem libcxx ]; + [ + openssl + zlib + hidapi + ] + ++ (lib.optionals stdenv.hostPlatform.isLinux [ udev ]) + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + System + Libsystem + libcxx + ]; strictDeps = true; doCheck = false; - env = { - # Used by build.rs in the rocksdb-sys crate. If we don't set these, it would - # try to build RocksDB from source. - ROCKSDB_LIB_DIR = "${lib.getLib rocksdb}/lib"; + env = + { + # Used by build.rs in the rocksdb-sys crate. If we don't set these, it would + # try to build RocksDB from source. + ROCKSDB_LIB_DIR = "${lib.getLib rocksdb}/lib"; - # If set, always finds OpenSSL in the system, even if the vendored feature is enabled. - OPENSSL_NO_VENDOR = "1"; - } // lib.optionalAttrs stdenv.hostPlatform.isDarwin { - # Require this on darwin otherwise the compiler starts rambling about missing - # cmath functions - CPPFLAGS = "-isystem ${lib.getDev libcxx}/include/c++/v1"; - LDFLAGS = "-L${lib.getLib libcxx}/lib"; - }; + # If set, always finds OpenSSL in the system, even if the vendored feature is enabled. + OPENSSL_NO_VENDOR = "1"; + } + // lib.optionalAttrs stdenv.hostPlatform.isDarwin { + # Require this on darwin otherwise the compiler starts rambling about missing + # cmath functions + CPPFLAGS = "-isystem ${lib.getDev libcxx}/include/c++/v1"; + LDFLAGS = "-L${lib.getLib libcxx}/lib"; + }; meta = with lib; { description = "Web-Scale Blockchain for fast, secure, scalable, decentralized apps and marketplaces."; diff --git a/pkgs/applications/blockchains/sparrow/default.nix b/pkgs/applications/blockchains/sparrow/default.nix index ec5bea4535022d..e0df2dc7bc6bbf 100644 --- a/pkgs/applications/blockchains/sparrow/default.nix +++ b/pkgs/applications/blockchains/sparrow/default.nix @@ -1,24 +1,25 @@ -{ stdenv -, stdenvNoCC -, lib -, makeWrapper -, fetchurl -, makeDesktopItem -, copyDesktopItems -, autoPatchelfHook -, openjdk -, gtk3 -, gsettings-desktop-schemas -, writeScript -, bash -, gnugrep -, tor -, zlib -, openimajgrabber -, hwi -, imagemagick -, gzip -, gnupg +{ + stdenv, + stdenvNoCC, + lib, + makeWrapper, + fetchurl, + makeDesktopItem, + copyDesktopItems, + autoPatchelfHook, + openjdk, + gtk3, + gsettings-desktop-schemas, + writeScript, + bash, + gnugrep, + tor, + zlib, + openimajgrabber, + hwi, + imagemagick, + gzip, + gnupg, }: let @@ -136,7 +137,15 @@ let sparrow-modules = stdenvNoCC.mkDerivation { pname = "sparrow-modules"; inherit version src; - nativeBuildInputs = [ makeWrapper gzip gnugrep openjdk autoPatchelfHook (lib.getLib stdenv.cc.cc) zlib ]; + nativeBuildInputs = [ + makeWrapper + gzip + gnugrep + openjdk + autoPatchelfHook + (lib.getLib stdenv.cc.cc) + zlib + ]; buildPhase = '' # Extract Sparrow's JIMAGE and generate a list of them. @@ -202,7 +211,10 @@ in stdenvNoCC.mkDerivation rec { inherit version src; pname = "sparrow-unwrapped"; - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; desktopItems = [ (makeDesktopItem { @@ -211,8 +223,17 @@ stdenvNoCC.mkDerivation rec { icon = "sparrow-desktop"; desktopName = "Sparrow Bitcoin Wallet"; genericName = "Bitcoin Wallet"; - categories = [ "Finance" "Network" ]; - mimeTypes = [ "application/psbt" "application/bitcoin-transaction" "x-scheme-handler/bitcoin" "x-scheme-handler/auth47" "x-scheme-handler/lightning" ]; + categories = [ + "Finance" + "Network" + ]; + mimeTypes = [ + "application/psbt" + "application/bitcoin-transaction" + "x-scheme-handler/bitcoin" + "x-scheme-handler/auth47" + "x-scheme-handler/lightning" + ]; startupWMClass = "Sparrow"; }) ]; @@ -257,7 +278,10 @@ stdenvNoCC.mkDerivation rec { binaryNativeCode ]; license = licenses.asl20; - maintainers = with maintainers; [ emmanuelrosa _1000101 ]; + maintainers = with maintainers; [ + emmanuelrosa + _1000101 + ]; platforms = [ "x86_64-linux" ]; mainProgram = "sparrow-desktop"; }; diff --git a/pkgs/applications/blockchains/sparrow/fhsenv.nix b/pkgs/applications/blockchains/sparrow/fhsenv.nix index 8a8abfe8103283..4d17e8adb1a474 100644 --- a/pkgs/applications/blockchains/sparrow/fhsenv.nix +++ b/pkgs/applications/blockchains/sparrow/fhsenv.nix @@ -1,5 +1,6 @@ -{ buildFHSEnv -, sparrow-unwrapped +{ + buildFHSEnv, + sparrow-unwrapped, }: buildFHSEnv { @@ -8,14 +9,16 @@ buildFHSEnv { runScript = "${sparrow-unwrapped}/bin/sparrow-desktop"; - targetPkgs = pkgs: with pkgs; [ - sparrow-unwrapped - pcsclite - ]; + targetPkgs = + pkgs: with pkgs; [ + sparrow-unwrapped + pcsclite + ]; - multiPkgs = pkgs: with pkgs; [ - pcsclite - ]; + multiPkgs = + pkgs: with pkgs; [ + pcsclite + ]; extraInstallCommands = '' mkdir -p $out/share diff --git a/pkgs/applications/blockchains/sparrow/openimajgrabber.nix b/pkgs/applications/blockchains/sparrow/openimajgrabber.nix index 8fac6f1a27ae67..7282aa8c305c1d 100644 --- a/pkgs/applications/blockchains/sparrow/openimajgrabber.nix +++ b/pkgs/applications/blockchains/sparrow/openimajgrabber.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, libv4l +{ + stdenv, + lib, + fetchFromGitHub, + libv4l, }: stdenv.mkDerivation rec { pname = "openimajgrabber"; @@ -34,7 +35,10 @@ stdenv.mkDerivation rec { description = "Collection of libraries and tools for multimedia (images, text, video, audio, etc.) content analysis and content generation. This package only builds the OpenIMAJGrabber for Linux"; homepage = "http://www.openimaj.org"; license = licenses.bsd0; - maintainers = with maintainers; [ emmanuelrosa _1000101 ]; + maintainers = with maintainers; [ + emmanuelrosa + _1000101 + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/blockchains/teos/default.nix b/pkgs/applications/blockchains/teos/default.nix index 61299621e0fb55..45cb42514ac345 100644 --- a/pkgs/applications/blockchains/teos/default.nix +++ b/pkgs/applications/blockchains/teos/default.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, protobuf -, rustfmt -, stdenv -, darwin -, pkg-config -, openssl +{ + lib, + rustPlatform, + fetchFromGitHub, + protobuf, + rustfmt, + stdenv, + darwin, + pkg-config, + openssl, }: let @@ -67,11 +68,13 @@ in rustfmt ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; passthru.updateScript = updateScript; diff --git a/pkgs/applications/blockchains/vertcoin/default.nix b/pkgs/applications/blockchains/vertcoin/default.nix index 835c89768de91d..056bad01dfc641 100644 --- a/pkgs/applications/blockchains/vertcoin/default.nix +++ b/pkgs/applications/blockchains/vertcoin/default.nix @@ -1,20 +1,22 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, openssl -, boost -, libevent -, autoreconfHook -, db4 -, pkg-config -, protobuf -, hexdump -, zeromq -, gmp -, withGui -, qtbase ? null -, qttools ? null -, wrapQtAppsHook ? null +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + openssl, + boost, + libevent, + autoreconfHook, + db4, + pkg-config, + protobuf, + hexdump, + zeromq, + gmp, + withGui, + qtbase ? null, + qttools ? null, + wrapQtAppsHook ? null, }: stdenv.mkDerivation rec { @@ -44,35 +46,41 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ - autoreconfHook - pkg-config - hexdump - ] ++ lib.optionals withGui [ - wrapQtAppsHook - ]; + nativeBuildInputs = + [ + autoreconfHook + pkg-config + hexdump + ] + ++ lib.optionals withGui [ + wrapQtAppsHook + ]; - buildInputs = [ - openssl - boost - libevent - db4 - zeromq - gmp - ] ++ lib.optionals withGui [ - qtbase - qttools - protobuf - ]; + buildInputs = + [ + openssl + boost + libevent + db4 + zeromq + gmp + ] + ++ lib.optionals withGui [ + qtbase + qttools + protobuf + ]; enableParallelBuilding = true; - configureFlags = [ + configureFlags = + [ "--with-boost-libdir=${boost.out}/lib" - ] ++ lib.optionals withGui [ + ] + ++ lib.optionals withGui [ "--with-gui=qt5" "--with-qt-bindir=${qtbase.dev}/bin:${qttools.dev}/bin" - ]; + ]; meta = with lib; { description = "Digital currency with mining decentralisation and ASIC resistance as a key focus"; diff --git a/pkgs/applications/blockchains/zcash/default.nix b/pkgs/applications/blockchains/zcash/default.nix index f2c3cc7a065f26..a11388ef4764fe 100644 --- a/pkgs/applications/blockchains/zcash/default.nix +++ b/pkgs/applications/blockchains/zcash/default.nix @@ -1,6 +1,28 @@ -{ autoreconfHook, boost180, cargo, coreutils, curl, cxx-rs, db62, fetchFromGitHub -, git, hexdump, lib, libevent, libsodium, makeWrapper, rustPlatform -, pkg-config, Security, stdenv, testers, tl-expected, utf8cpp, util-linux, zcash, zeromq +{ + autoreconfHook, + boost180, + cargo, + coreutils, + curl, + cxx-rs, + db62, + fetchFromGitHub, + git, + hexdump, + lib, + libevent, + libsodium, + makeWrapper, + rustPlatform, + pkg-config, + Security, + stdenv, + testers, + tl-expected, + utf8cpp, + util-linux, + zcash, + zeromq, }: rustPlatform.buildRustPackage.override { inherit stdenv; } rec { @@ -9,7 +31,7 @@ rustPlatform.buildRustPackage.override { inherit stdenv; } rec { src = fetchFromGitHub { owner = "zcash"; - repo = "zcash"; + repo = "zcash"; rev = "v${version}"; hash = "sha256-XGq/cYUo43FcpmRDO2YiNLCuEQLsTFLBFC4M1wM29l8="; }; @@ -22,20 +44,30 @@ rustPlatform.buildRustPackage.override { inherit stdenv; } rec { cargoHash = "sha256-Mz8mr/RDcOfwJvXhY19rZmWHP8mUeEf9GYD+3JAPNOw="; - nativeBuildInputs = [ autoreconfHook cargo cxx-rs git hexdump makeWrapper pkg-config ]; - - buildInputs = [ - boost180 - db62 - libevent - libsodium - tl-expected - utf8cpp - zeromq - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security + nativeBuildInputs = [ + autoreconfHook + cargo + cxx-rs + git + hexdump + makeWrapper + pkg-config ]; + buildInputs = + [ + boost180 + db62 + libevent + libsodium + tl-expected + utf8cpp + zeromq + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + ]; + # Use the stdenv default phases (./configure; make) instead of the # ones from buildRustPackage. configurePhase = "configurePhase"; @@ -73,13 +105,23 @@ rustPlatform.buildRustPackage.override { inherit stdenv; } rec { postInstall = '' wrapProgram $out/bin/zcash-fetch-params \ - --set PATH ${lib.makeBinPath [ coreutils curl util-linux ]} + --set PATH ${ + lib.makeBinPath [ + coreutils + curl + util-linux + ] + } ''; meta = with lib; { description = "Peer-to-peer, anonymous electronic cash system"; homepage = "https://z.cash/"; - maintainers = with maintainers; [ rht tkerber centromere ]; + maintainers = with maintainers; [ + rht + tkerber + centromere + ]; license = licenses.mit; # https://github.com/zcash/zcash/issues/4405 diff --git a/pkgs/applications/display-managers/greetd/default.nix b/pkgs/applications/display-managers/greetd/default.nix index 08661deb7a3c79..37db111efe0adc 100644 --- a/pkgs/applications/display-managers/greetd/default.nix +++ b/pkgs/applications/display-managers/greetd/default.nix @@ -1,9 +1,10 @@ -{ rustPlatform -, lib -, fetchFromSourcehut -, pam -, scdoc -, installShellFiles +{ + rustPlatform, + lib, + fetchFromSourcehut, + pam, + scdoc, + installShellFiles, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/applications/display-managers/greetd/gtkgreet.nix b/pkgs/applications/display-managers/greetd/gtkgreet.nix index b40d4051083c22..425e4c1790b3dc 100644 --- a/pkgs/applications/display-managers/greetd/gtkgreet.nix +++ b/pkgs/applications/display-managers/greetd/gtkgreet.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromSourcehut -, wrapGAppsHook3 -, pkg-config -, cmake -, meson -, ninja -, gtk3 -, gtk-layer-shell -, json_c -, librsvg -, scdoc +{ + stdenv, + lib, + fetchFromSourcehut, + wrapGAppsHook3, + pkg-config, + cmake, + meson, + ninja, + gtk3, + gtk-layer-shell, + json_c, + librsvg, + scdoc, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/display-managers/greetd/regreet.nix b/pkgs/applications/display-managers/greetd/regreet.nix index ff0511a15c1c3b..99b5dce2455d69 100644 --- a/pkgs/applications/display-managers/greetd/regreet.nix +++ b/pkgs/applications/display-managers/greetd/regreet.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, wrapGAppsHook4 -, glib -, gtk4 -, pango -, librsvg +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + wrapGAppsHook4, + glib, + gtk4, + pango, + librsvg, }: rustPlatform.buildRustPackage rec { @@ -24,8 +25,16 @@ rustPlatform.buildRustPackage rec { buildFeatures = [ "gtk4_8" ]; - nativeBuildInputs = [ pkg-config wrapGAppsHook4 ]; - buildInputs = [ glib gtk4 pango librsvg ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook4 + ]; + buildInputs = [ + glib + gtk4 + pango + librsvg + ]; meta = with lib; { description = "Clean and customizable greeter for greetd"; diff --git a/pkgs/applications/display-managers/greetd/wlgreet.nix b/pkgs/applications/display-managers/greetd/wlgreet.nix index 3e1ee18e7b462d..aa4cd8e2f94bbd 100644 --- a/pkgs/applications/display-managers/greetd/wlgreet.nix +++ b/pkgs/applications/display-managers/greetd/wlgreet.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromSourcehut -, autoPatchelfHook -, gcc-unwrapped -, wayland -, libxkbcommon +{ + lib, + rustPlatform, + fetchFromSourcehut, + autoPatchelfHook, + gcc-unwrapped, + wayland, + libxkbcommon, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/applications/display-managers/lightdm/default.nix b/pkgs/applications/display-managers/lightdm/default.nix index 820477861bb594..c3988cdd4e681a 100644 --- a/pkgs/applications/display-managers/lightdm/default.nix +++ b/pkgs/applications/display-managers/lightdm/default.nix @@ -1,41 +1,46 @@ -{ lib, stdenv -, buildPackages -, fetchFromGitHub -, nix-update-script -, substituteAll -, plymouth -, pam -, pkg-config -, autoconf -, automake -, libtool -, libxcb -, glib -, libXdmcp -, itstool -, intltool -, libxklavier -, libgcrypt -, audit -, busybox -, polkit -, accountsservice -, gtk-doc -, gobject-introspection -, vala -, fetchpatch -, withQt5 ? false -, qtbase -, yelp-tools -, yelp-xsl -, nixosTests +{ + lib, + stdenv, + buildPackages, + fetchFromGitHub, + nix-update-script, + substituteAll, + plymouth, + pam, + pkg-config, + autoconf, + automake, + libtool, + libxcb, + glib, + libXdmcp, + itstool, + intltool, + libxklavier, + libgcrypt, + audit, + busybox, + polkit, + accountsservice, + gtk-doc, + gobject-introspection, + vala, + fetchpatch, + withQt5 ? false, + qtbase, + yelp-tools, + yelp-xsl, + nixosTests, }: stdenv.mkDerivation rec { pname = "lightdm"; version = "1.32.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "canonical"; @@ -119,7 +124,6 @@ stdenv.mkDerivation rec { tests = { inherit (nixosTests) lightdm; }; }; - meta = with lib; { homepage = "https://github.com/canonical/lightdm"; description = "Cross-desktop display manager"; diff --git a/pkgs/applications/display-managers/ly/default.nix b/pkgs/applications/display-managers/ly/default.nix index 24332a10c080fc..35221c4637c719 100644 --- a/pkgs/applications/display-managers/ly/default.nix +++ b/pkgs/applications/display-managers/ly/default.nix @@ -1,5 +1,14 @@ -{ stdenv, lib, fetchFromGitHub, linux-pam, libxcb, makeBinaryWrapper, zig_0_12 -, callPackage, nixosTests }: +{ + stdenv, + lib, + fetchFromGitHub, + linux-pam, + libxcb, + makeBinaryWrapper, + zig_0_12, + callPackage, + nixosTests, +}: stdenv.mkDerivation { pname = "ly"; @@ -12,8 +21,14 @@ stdenv.mkDerivation { hash = "sha256-VUtNEL7Te/ba+wvL0SsUHlyv2NPmkYKs76TnW8r3ysw="; }; - nativeBuildInputs = [ makeBinaryWrapper zig_0_12.hook ]; - buildInputs = [ libxcb linux-pam ]; + nativeBuildInputs = [ + makeBinaryWrapper + zig_0_12.hook + ]; + buildInputs = [ + libxcb + linux-pam + ]; postPatch = '' ln -s ${callPackage ./deps.nix { }} $ZIG_GLOBAL_CACHE_DIR/p diff --git a/pkgs/applications/display-managers/sddm/default.nix b/pkgs/applications/display-managers/sddm/default.nix index 451317fae2681c..bbddc99731fcd9 100644 --- a/pkgs/applications/display-managers/sddm/default.nix +++ b/pkgs/applications/display-managers/sddm/default.nix @@ -5,38 +5,42 @@ layer-shell-qt, qtwayland, wrapQtAppsHook, - unwrapped ? callPackage ./unwrapped.nix {}, + unwrapped ? callPackage ./unwrapped.nix { }, withWayland ? false, withLayerShellQt ? false, - extraPackages ? [], + extraPackages ? [ ], }: -runCommand "sddm-wrapped" { - inherit (unwrapped) version; +runCommand "sddm-wrapped" + { + inherit (unwrapped) version; - buildInputs = unwrapped.buildInputs ++ extraPackages - ++ lib.optional withWayland qtwayland - ++ lib.optional (withWayland && withLayerShellQt) layer-shell-qt; - nativeBuildInputs = [ wrapQtAppsHook ]; + buildInputs = + unwrapped.buildInputs + ++ extraPackages + ++ lib.optional withWayland qtwayland + ++ lib.optional (withWayland && withLayerShellQt) layer-shell-qt; + nativeBuildInputs = [ wrapQtAppsHook ]; - passthru = { - inherit unwrapped; - inherit (unwrapped.passthru) tests; - }; + passthru = { + inherit unwrapped; + inherit (unwrapped.passthru) tests; + }; - meta = unwrapped.meta; -} '' - mkdir -p $out/bin + meta = unwrapped.meta; + } + '' + mkdir -p $out/bin - cd ${unwrapped} + cd ${unwrapped} - for i in *; do - if [ "$i" == "bin" ]; then - continue - fi - ln -s ${unwrapped}/$i $out/$i - done + for i in *; do + if [ "$i" == "bin" ]; then + continue + fi + ln -s ${unwrapped}/$i $out/$i + done - for i in bin/*; do - makeQtWrapper ${unwrapped}/$i $out/$i --set SDDM_GREETER_DIR $out/bin - done -'' + for i in bin/*; do + makeQtWrapper ${unwrapped}/$i $out/$i --set SDDM_GREETER_DIR $out/bin + done + '' diff --git a/pkgs/applications/display-managers/sddm/unwrapped.nix b/pkgs/applications/display-managers/sddm/unwrapped.nix index 3a7a73dd9610fa..517cfddd881dea 100644 --- a/pkgs/applications/display-managers/sddm/unwrapped.nix +++ b/pkgs/applications/display-managers/sddm/unwrapped.nix @@ -1,12 +1,24 @@ -{ stdenv, lib, fetchFromGitHub -, cmake, pkg-config, qttools -, libxcb, libXau, pam, qtbase, qtdeclarative -, qtquickcontrols2 ? null, systemd, xkeyboardconfig -, nixosTests +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + qttools, + libxcb, + libXau, + pam, + qtbase, + qtdeclarative, + qtquickcontrols2 ? null, + systemd, + xkeyboardconfig, + nixosTests, }: let isQt6 = lib.versions.major qtbase.version == "6"; -in stdenv.mkDerivation(finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "sddm-unwrapped"; version = "0.21.0"; @@ -28,7 +40,11 @@ in stdenv.mkDerivation(finalAttrs: { --replace "/usr/share/X11/xkb/rules/evdev.xml" "${xkeyboardconfig}/share/X11/xkb/rules/evdev.xml" ''; - nativeBuildInputs = [ cmake pkg-config qttools ]; + nativeBuildInputs = [ + cmake + pkg-config + qttools + ]; buildInputs = [ libxcb @@ -81,9 +97,13 @@ in stdenv.mkDerivation(finalAttrs: { meta = with lib; { description = "QML based X11 display manager"; - homepage = "https://github.com/sddm/sddm"; - maintainers = with maintainers; [ abbradar ttuegel k900 ]; - platforms = platforms.linux; - license = licenses.gpl2Plus; + homepage = "https://github.com/sddm/sddm"; + maintainers = with maintainers; [ + abbradar + ttuegel + k900 + ]; + platforms = platforms.linux; + license = licenses.gpl2Plus; }; }) diff --git a/pkgs/applications/editors/android-studio-for-platform/common.nix b/pkgs/applications/editors/android-studio-for-platform/common.nix index 049a5600d6848d..299bc5c627c022 100644 --- a/pkgs/applications/editors/android-studio-for-platform/common.nix +++ b/pkgs/applications/editors/android-studio-for-platform/common.nix @@ -1,45 +1,52 @@ -{ channel, pname, version, sha256Hash }: - -{ android-tools -, bash -, buildFHSEnv -, coreutils -, dpkg -, e2fsprogs -, fetchurl -, findutils -, git -, gnugrep -, gnused -, gnutar -, gtk2, glib -, gzip -, fontsConf -, fontconfig -, freetype -, libX11 -, libXext -, libXi -, libXrandr -, libXrender -, libXtst -, makeFontsConf -, makeWrapper -, ncurses5 -, openssl -, ps -, python3 -, lib -, stdenv -, unzip -, usbutils -, which -, runCommand -, xkeyboard_config -, zip -, zlib -, makeDesktopItem -, tiling_wm ? false # if we are using a tiling wm, need to set _JAVA_AWT_WM_NONREPARENTING in wrapper +{ + channel, + pname, + version, + sha256Hash, +}: + +{ + android-tools, + bash, + buildFHSEnv, + coreutils, + dpkg, + e2fsprogs, + fetchurl, + findutils, + git, + gnugrep, + gnused, + gnutar, + gtk2, + glib, + gzip, + fontsConf, + fontconfig, + freetype, + libX11, + libXext, + libXi, + libXrandr, + libXrender, + libXtst, + makeFontsConf, + makeWrapper, + ncurses5, + openssl, + ps, + python3, + lib, + stdenv, + unzip, + usbutils, + which, + runCommand, + xkeyboard_config, + zip, + zlib, + makeDesktopItem, + tiling_wm ? false, # if we are using a tiling wm, need to set _JAVA_AWT_WM_NONREPARENTING in wrapper }: let @@ -66,52 +73,56 @@ let --set QT_XKB_CONFIG_ROOT "${xkeyboard_config}/share/X11/xkb" \ ${lib.optionalString tiling_wm "--set _JAVA_AWT_WM_NONREPARENTING 1"} \ --set FONTCONFIG_FILE ${fontsConf} \ - --prefix PATH : "${lib.makeBinPath [ - - # Checked in studio.sh - coreutils - findutils - gnugrep - which - gnused - - # Used during setup wizard - gnutar - gzip - - # Runtime stuff - git - ps - usbutils - android-tools - - # For Soong sync - openssl - python3 - unzip - zip - e2fsprogs - ]}" \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ - # Crash at startup without these - fontconfig - freetype - libXext - libXi - libXrender - libXtst - libX11 - - # Support multiple monitors - libXrandr - - # For GTKLookAndFeel - gtk2 - glib - - # For Soong sync - e2fsprogs - ]}" + --prefix PATH : "${ + lib.makeBinPath [ + + # Checked in studio.sh + coreutils + findutils + gnugrep + which + gnused + + # Used during setup wizard + gnutar + gzip + + # Runtime stuff + git + ps + usbutils + android-tools + + # For Soong sync + openssl + python3 + unzip + zip + e2fsprogs + ] + }" \ + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + # Crash at startup without these + fontconfig + freetype + libXext + libXi + libXrender + libXtst + libX11 + + # Support multiple monitors + libXrandr + + # For GTKLookAndFeel + gtk2 + glib + + # For Soong sync + e2fsprogs + ] + }" ''; }; @@ -121,7 +132,10 @@ let icon = pname; desktopName = "Android Studio for Platform (${channel} channel)"; comment = "The official Android IDE for Android platform development"; - categories = [ "Development" "IDE" ]; + categories = [ + "Development" + "IDE" + ]; startupNotify = true; startupWMClass = "jetbrains-studio"; }; @@ -142,8 +156,8 @@ let export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/lib:/usr/lib32 ''; }; -in runCommand - drvName +in +runCommand drvName { startScript = '' #!${bash}/bin/bash @@ -161,7 +175,10 @@ in runCommand for Android Open Source Project (AOSP) platform developers who build with the Soong build system. ''; homepage = "https://developer.android.com/studio/platform.html"; - license = with licenses; [ asl20 unfree ]; # The code is under Apache-2.0, but: + license = with licenses; [ + asl20 + unfree + ]; # The code is under Apache-2.0, but: # If one selects Help -> Licenses in Android Studio, the dialog shows the following: # "Android Studio includes proprietary code subject to separate license, # including JetBrains CLion(R) (www.jetbrains.com/clion) and IntelliJ(R) diff --git a/pkgs/applications/editors/android-studio-for-platform/default.nix b/pkgs/applications/editors/android-studio-for-platform/default.nix index 1f11bd55ac3a7c..444368bb9f9ea9 100644 --- a/pkgs/applications/editors/android-studio-for-platform/default.nix +++ b/pkgs/applications/editors/android-studio-for-platform/default.nix @@ -1,13 +1,20 @@ -{ callPackage, makeFontsConf, buildFHSEnv, tiling_wm ? false }: +{ + callPackage, + makeFontsConf, + buildFHSEnv, + tiling_wm ? false, +}: let - mkStudio = opts: callPackage (import ./common.nix opts) { - fontsConf = makeFontsConf { - fontDirectories = []; + mkStudio = + opts: + callPackage (import ./common.nix opts) { + fontsConf = makeFontsConf { + fontDirectories = [ ]; + }; + inherit buildFHSEnv; + inherit tiling_wm; }; - inherit buildFHSEnv; - inherit tiling_wm; - }; stableVersion = { version = "2023.2.1.20"; # Android Studio Iguana | 2023.2.1 Beta 2 sha256Hash = "sha256-cM/pkSghqLUUvJVF/OVLDOxVBJlJLH8ge1bfZtDUegY="; @@ -16,16 +23,23 @@ let version = "2023.3.2.1"; # Android Studio Jellyfish | 2023.3.2 Canary 1 sha256Hash = "sha256-XOsbMyNentklfEp1k49H3uFeiRNMCV/Seisw9K1ganM="; }; -in { +in +{ # Attributes are named by their corresponding release channels - stable = mkStudio (stableVersion // { - channel = "stable"; - pname = "android-studio-for-platform"; - }); + stable = mkStudio ( + stableVersion + // { + channel = "stable"; + pname = "android-studio-for-platform"; + } + ); - canary = mkStudio (canaryVersion // { - channel = "canary"; - pname = "android-studio-for-platform-canary"; - }); + canary = mkStudio ( + canaryVersion + // { + channel = "canary"; + pname = "android-studio-for-platform-canary"; + } + ); } diff --git a/pkgs/applications/editors/android-studio/common.nix b/pkgs/applications/editors/android-studio/common.nix index a3e5f4cc3e5252..768e572b11c9ee 100644 --- a/pkgs/applications/editors/android-studio/common.nix +++ b/pkgs/applications/editors/android-studio/common.nix @@ -1,74 +1,81 @@ -{ channel, pname, version, sha256Hash }: +{ + channel, + pname, + version, + sha256Hash, +}: -{ alsa-lib -, runtimeShell -, buildFHSEnv -, cacert -, coreutils -, dbus -, e2fsprogs -, expat -, fetchurl -, findutils -, file -, fontsConf -, git -, gnugrep -, gnused -, gnutar -, gtk2, glib -, gzip -, fontconfig -, freetype -, libbsd -, libpulseaudio -, libGL -, libdrm -, libpng -, libuuid -, libX11 -, libxcb -, libxkbcommon -, mesa-demos -, xcbutilwm -, xcbutilrenderutil -, xcbutilkeysyms -, xcbutilimage -, xcbutilcursor -, libxkbfile -, libXcomposite -, libXcursor -, libXdamage -, libXext -, libXfixes -, libXi -, libXrandr -, libXrender -, libXtst -, makeWrapper -, ncurses5 -, nspr -, nss_latest -, pciutils -, pkgsi686Linux -, ps -, setxkbmap -, lib -, stdenv -, systemd -, unzip -, usbutils -, which -, runCommand -, wayland -, xkeyboard_config -, xorg -, zlib -, makeDesktopItem -, tiling_wm # if we are using a tiling wm, need to set _JAVA_AWT_WM_NONREPARENTING in wrapper -, androidenv +{ + alsa-lib, + runtimeShell, + buildFHSEnv, + cacert, + coreutils, + dbus, + e2fsprogs, + expat, + fetchurl, + findutils, + file, + fontsConf, + git, + gnugrep, + gnused, + gnutar, + gtk2, + glib, + gzip, + fontconfig, + freetype, + libbsd, + libpulseaudio, + libGL, + libdrm, + libpng, + libuuid, + libX11, + libxcb, + libxkbcommon, + mesa-demos, + xcbutilwm, + xcbutilrenderutil, + xcbutilkeysyms, + xcbutilimage, + xcbutilcursor, + libxkbfile, + libXcomposite, + libXcursor, + libXdamage, + libXext, + libXfixes, + libXi, + libXrandr, + libXrender, + libXtst, + makeWrapper, + ncurses5, + nspr, + nss_latest, + pciutils, + pkgsi686Linux, + ps, + setxkbmap, + lib, + stdenv, + systemd, + unzip, + usbutils, + which, + runCommand, + wayland, + xkeyboard_config, + xorg, + zlib, + makeDesktopItem, + tiling_wm, # if we are using a tiling wm, need to set _JAVA_AWT_WM_NONREPARENTING in wrapper + androidenv, -, forceWayland ? false + forceWayland ? false, }: let @@ -99,97 +106,103 @@ let --set QT_XKB_CONFIG_ROOT "${xkeyboard_config}/share/X11/xkb" \ ${lib.optionalString tiling_wm "--set _JAVA_AWT_WM_NONREPARENTING 1"} \ --set FONTCONFIG_FILE ${fontsConf} \ - --prefix PATH : "${lib.makeBinPath [ + --prefix PATH : "${ + lib.makeBinPath [ - # Checked in studio.sh - coreutils - findutils - gnugrep - which - gnused + # Checked in studio.sh + coreutils + findutils + gnugrep + which + gnused - # For Android emulator - file - mesa-demos - pciutils - setxkbmap + # For Android emulator + file + mesa-demos + pciutils + setxkbmap - # Used during setup wizard - gnutar - gzip + # Used during setup wizard + gnutar + gzip - # Runtime stuff - git - ps - usbutils - ]}" \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ + # Runtime stuff + git + ps + usbutils + ] + }" \ + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ - # Crash at startup without these - fontconfig - freetype - libXext - libXi - libXrender - libXtst + # Crash at startup without these + fontconfig + freetype + libXext + libXi + libXrender + libXtst - # No crash, but attempted to load at startup - e2fsprogs + # No crash, but attempted to load at startup + e2fsprogs - # Gradle wants libstdc++.so.6 - (lib.getLib stdenv.cc.cc) - # mksdcard wants 32 bit libstdc++.so.6 - pkgsi686Linux.stdenv.cc.cc.lib + # Gradle wants libstdc++.so.6 + (lib.getLib stdenv.cc.cc) + # mksdcard wants 32 bit libstdc++.so.6 + pkgsi686Linux.stdenv.cc.cc.lib - # aapt wants libz.so.1 - zlib - pkgsi686Linux.zlib - # Support multiple monitors - libXrandr + # aapt wants libz.so.1 + zlib + pkgsi686Linux.zlib + # Support multiple monitors + libXrandr - # For Android emulator - alsa-lib - dbus - expat - libbsd - libpulseaudio - libuuid - libX11 - libxcb - libxkbcommon - xcbutilwm - xcbutilrenderutil - xcbutilkeysyms - xcbutilimage - xcbutilcursor - xorg.libICE - xorg.libSM - libxkbfile - libXcomposite - libXcursor - libXdamage - libXfixes - libGL - libdrm - libpng - nspr - nss_latest - systemd + # For Android emulator + alsa-lib + dbus + expat + libbsd + libpulseaudio + libuuid + libX11 + libxcb + libxkbcommon + xcbutilwm + xcbutilrenderutil + xcbutilkeysyms + xcbutilimage + xcbutilcursor + xorg.libICE + xorg.libSM + libxkbfile + libXcomposite + libXcursor + libXdamage + libXfixes + libGL + libdrm + libpng + nspr + nss_latest + systemd - # For GTKLookAndFeel - gtk2 - glib + # For GTKLookAndFeel + gtk2 + glib - # For wayland support - wayland - ]}" \ + # For wayland support + wayland + ] + }" \ ${lib.optionalString forceWayland "--add-flags -Dawt.toolkit.name=WLToolkit"} # AS launches LLDBFrontend with a custom LD_LIBRARY_PATH - wrapProgram $(find $out -name LLDBFrontend) --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ - ncurses5 - zlib - ]}" + wrapProgram $(find $out -name LLDBFrontend) --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + ncurses5 + zlib + ] + }" ''; }; @@ -199,7 +212,10 @@ let icon = pname; desktopName = "Android Studio (${channel} channel)"; comment = "The official Android IDE"; - categories = [ "Development" "IDE" ]; + categories = [ + "Development" + "IDE" + ]; startupNotify = true; startupWMClass = "jetbrains-studio"; }; @@ -214,97 +230,122 @@ let ncurses5 # Flutter can only search for certs Fedora-way. - (runCommand "fedoracert" {} - '' + (runCommand "fedoracert" { } '' mkdir -p $out/etc/pki/tls/ ln -s ${cacert}/etc/ssl/certs $out/etc/pki/tls/certs - '') + '') ]; }; - mkAndroidStudioWrapper = {androidStudio, androidSdk ? null}: runCommand drvName { - startScript = let - hasAndroidSdk = androidSdk != null; - androidSdkRoot = lib.optionalString hasAndroidSdk "${androidSdk}/libexec/android-sdk"; - in '' - #!${runtimeShell} - ${lib.optionalString hasAndroidSdk '' - echo "=== nixpkgs Android Studio wrapper" >&2 + mkAndroidStudioWrapper = + { + androidStudio, + androidSdk ? null, + }: + runCommand drvName + { + startScript = + let + hasAndroidSdk = androidSdk != null; + androidSdkRoot = lib.optionalString hasAndroidSdk "${androidSdk}/libexec/android-sdk"; + in + '' + #!${runtimeShell} + ${lib.optionalString hasAndroidSdk '' + echo "=== nixpkgs Android Studio wrapper" >&2 - # Default ANDROID_SDK_ROOT to the packaged one, if not provided. - ANDROID_SDK_ROOT="''${ANDROID_SDK_ROOT-${androidSdkRoot}}" + # Default ANDROID_SDK_ROOT to the packaged one, if not provided. + ANDROID_SDK_ROOT="''${ANDROID_SDK_ROOT-${androidSdkRoot}}" - if [ -d "$ANDROID_SDK_ROOT" ]; then - export ANDROID_SDK_ROOT - # Legacy compatibility. - export ANDROID_HOME="$ANDROID_SDK_ROOT" - echo " - ANDROID_SDK_ROOT=$ANDROID_SDK_ROOT" >&2 + if [ -d "$ANDROID_SDK_ROOT" ]; then + export ANDROID_SDK_ROOT + # Legacy compatibility. + export ANDROID_HOME="$ANDROID_SDK_ROOT" + echo " - ANDROID_SDK_ROOT=$ANDROID_SDK_ROOT" >&2 - # See if we can export ANDROID_NDK_ROOT too. - ANDROID_NDK_ROOT="$ANDROID_SDK_ROOT/ndk-bundle" - if [ ! -d "$ANDROID_NDK_ROOT" ]; then - ANDROID_NDK_ROOT="$(ls "$ANDROID_SDK_ROOT/ndk/"* 2>/dev/null | head -n1)" - fi + # See if we can export ANDROID_NDK_ROOT too. + ANDROID_NDK_ROOT="$ANDROID_SDK_ROOT/ndk-bundle" + if [ ! -d "$ANDROID_NDK_ROOT" ]; then + ANDROID_NDK_ROOT="$(ls "$ANDROID_SDK_ROOT/ndk/"* 2>/dev/null | head -n1)" + fi - if [ -d "$ANDROID_NDK_ROOT" ]; then - export ANDROID_NDK_ROOT - echo " - ANDROID_NDK_ROOT=$ANDROID_NDK_ROOT" >&2 - else - unset ANDROID_NDK_ROOT - fi - else - unset ANDROID_SDK_ROOT - unset ANDROID_HOME - fi - ''} - exec ${fhsEnv}/bin/${drvName}-fhs-env ${androidStudio}/bin/studio.sh "$@" - ''; - preferLocalBuild = true; - allowSubstitutes = false; - passthru = let - withSdk = androidSdk: mkAndroidStudioWrapper { inherit androidStudio androidSdk; }; - in { - inherit version; - unwrapped = androidStudio; - full = withSdk androidenv.androidPkgs.androidsdk; - inherit withSdk; - sdk = androidSdk; - updateScript = [ ./update.sh "${channel}" ]; - }; - meta = { - description = "Official IDE for Android (${channel} channel)"; - longDescription = '' - Android Studio is the official IDE for Android app development, based on - IntelliJ IDEA. - ''; - homepage = if channel == "stable" - then "https://developer.android.com/studio/index.html" - else "https://developer.android.com/studio/preview/index.html"; - license = with lib.licenses; [ asl20 unfree ]; # The code is under Apache-2.0, but: - # If one selects Help -> Licenses in Android Studio, the dialog shows the following: - # "Android Studio includes proprietary code subject to separate license, - # including JetBrains CLion(R) (www.jetbrains.com/clion) and IntelliJ(R) - # IDEA Community Edition (www.jetbrains.com/idea)." - # Also: For actual development the Android SDK is required and the Google - # binaries are also distributed as proprietary software (unlike the - # source-code itself). - platforms = [ "x86_64-linux" ]; - maintainers = with lib.maintainers; rec { - stable = [ alapshin johnrtitor numinit ]; - beta = stable; - canary = stable; - dev = stable; - }."${channel}"; - mainProgram = pname; - sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; - }; - } - '' - mkdir -p $out/{bin,share/pixmaps} + if [ -d "$ANDROID_NDK_ROOT" ]; then + export ANDROID_NDK_ROOT + echo " - ANDROID_NDK_ROOT=$ANDROID_NDK_ROOT" >&2 + else + unset ANDROID_NDK_ROOT + fi + else + unset ANDROID_SDK_ROOT + unset ANDROID_HOME + fi + ''} + exec ${fhsEnv}/bin/${drvName}-fhs-env ${androidStudio}/bin/studio.sh "$@" + ''; + preferLocalBuild = true; + allowSubstitutes = false; + passthru = + let + withSdk = androidSdk: mkAndroidStudioWrapper { inherit androidStudio androidSdk; }; + in + { + inherit version; + unwrapped = androidStudio; + full = withSdk androidenv.androidPkgs.androidsdk; + inherit withSdk; + sdk = androidSdk; + updateScript = [ + ./update.sh + "${channel}" + ]; + }; + meta = { + description = "Official IDE for Android (${channel} channel)"; + longDescription = '' + Android Studio is the official IDE for Android app development, based on + IntelliJ IDEA. + ''; + homepage = + if channel == "stable" then + "https://developer.android.com/studio/index.html" + else + "https://developer.android.com/studio/preview/index.html"; + license = with lib.licenses; [ + asl20 + unfree + ]; # The code is under Apache-2.0, but: + # If one selects Help -> Licenses in Android Studio, the dialog shows the following: + # "Android Studio includes proprietary code subject to separate license, + # including JetBrains CLion(R) (www.jetbrains.com/clion) and IntelliJ(R) + # IDEA Community Edition (www.jetbrains.com/idea)." + # Also: For actual development the Android SDK is required and the Google + # binaries are also distributed as proprietary software (unlike the + # source-code itself). + platforms = [ "x86_64-linux" ]; + maintainers = + with lib.maintainers; + rec { + stable = [ + alapshin + johnrtitor + numinit + ]; + beta = stable; + canary = stable; + dev = stable; + } + ."${channel}"; + mainProgram = pname; + sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; + }; + } + '' + mkdir -p $out/{bin,share/pixmaps} - echo -n "$startScript" > $out/bin/${pname} - chmod +x $out/bin/${pname} + echo -n "$startScript" > $out/bin/${pname} + chmod +x $out/bin/${pname} - ln -s ${androidStudio}/bin/studio.png $out/share/pixmaps/${pname}.png - ln -s ${desktopItem}/share/applications $out/share/applications - ''; -in mkAndroidStudioWrapper { inherit androidStudio; } + ln -s ${androidStudio}/bin/studio.png $out/share/pixmaps/${pname}.png + ln -s ${desktopItem}/share/applications $out/share/applications + ''; +in +mkAndroidStudioWrapper { inherit androidStudio; } diff --git a/pkgs/applications/editors/bluefish/default.nix b/pkgs/applications/editors/bluefish/default.nix index 09795194bf0af6..04f5a97a51ae42 100644 --- a/pkgs/applications/editors/bluefish/default.nix +++ b/pkgs/applications/editors/bluefish/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, wrapGAppsHook3 -, pkg-config -, gtk -, libxml2 -, enchant -, gucharmap -, python3 -, adwaita-icon-theme +{ + lib, + stdenv, + fetchurl, + wrapGAppsHook3, + pkg-config, + gtk, + libxml2, + enchant, + gucharmap, + python3, + adwaita-icon-theme, }: stdenv.mkDerivation rec { @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-FOZHb87o+jJvf2Px9pPSUhlfncsWrw/jyRXEmbr13XQ="; }; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; buildInputs = [ adwaita-icon-theme gtk diff --git a/pkgs/applications/editors/code-browser/default.nix b/pkgs/applications/editors/code-browser/default.nix index 0efdae2ea65d30..093b5fe3309e48 100644 --- a/pkgs/applications/editors/code-browser/default.nix +++ b/pkgs/applications/editors/code-browser/default.nix @@ -1,15 +1,27 @@ -{ lib, stdenv -, fetchurl -, copper -, python3 -, pkg-config -, withQt ? false, qtbase ? null, wrapQtAppsHook ? null -, withGtk2 ? false, gtk2 -, withGtk3 ? false, gtk3 -, mkDerivation ? stdenv.mkDerivation +{ + lib, + stdenv, + fetchurl, + copper, + python3, + pkg-config, + withQt ? false, + qtbase ? null, + wrapQtAppsHook ? null, + withGtk2 ? false, + gtk2, + withGtk3 ? false, + gtk3, + mkDerivation ? stdenv.mkDerivation, }: -let onlyOneEnabled = xs: 1 == builtins.length (builtins.filter lib.id xs); -in assert onlyOneEnabled [ withQt withGtk2 withGtk3 ]; +let + onlyOneEnabled = xs: 1 == builtins.length (builtins.filter lib.id xs); +in +assert onlyOneEnabled [ + withQt + withGtk2 + withGtk3 +]; mkDerivation rec { pname = "code-browser"; version = "8.0"; @@ -17,41 +29,49 @@ mkDerivation rec { url = "https://tibleiz.net/download/code-browser-${version}-src.tar.gz"; sha256 = "sha256-beCp4lx4MI1+hVgWp2h3piE/zu51zfwQdB5g7ImgmwY="; }; - postPatch = '' - substituteInPlace Makefile --replace "LFLAGS=-no-pie" "LFLAGS=-no-pie -L." - patchShebangs . - '' - + lib.optionalString withQt '' - substituteInPlace libs/copper-ui/Makefile --replace "moc -o" "${qtbase.dev}/bin/moc -o" - substituteInPlace libs/copper-ui/Makefile --replace "all: qt gtk gtk2" "all: qt" - '' - + lib.optionalString withGtk2 '' - substituteInPlace libs/copper-ui/Makefile --replace "all: qt gtk gtk2" "all: gtk2" - '' - + lib.optionalString withGtk3 '' - substituteInPlace libs/copper-ui/Makefile --replace "all: qt gtk gtk2" "all: gtk" - '' - ; - nativeBuildInputs = [ copper - python3 - pkg-config - ] - ++ lib.optionals withGtk2 [ gtk2 ] - ++ lib.optionals withGtk3 [ gtk3 ] - ++ lib.optionals withQt [ qtbase wrapQtAppsHook ]; - buildInputs = lib.optionals withQt [ qtbase ] - ++ lib.optionals withGtk2 [ gtk2 ] - ++ lib.optionals withGtk3 [ gtk3 ]; - makeFlags = [ - "prefix=$(out)" - "COPPER=${copper}/bin/copper-elf64" - "with-local-libs" - ] - ++ lib.optionals withQt [ "QINC=${qtbase.dev}/include" - "UI=qt" - ] - ++ lib.optionals withGtk2 [ "UI=gtk2" ] - ++ lib.optionals withGtk3 [ "UI=gtk" ]; + postPatch = + '' + substituteInPlace Makefile --replace "LFLAGS=-no-pie" "LFLAGS=-no-pie -L." + patchShebangs . + '' + + lib.optionalString withQt '' + substituteInPlace libs/copper-ui/Makefile --replace "moc -o" "${qtbase.dev}/bin/moc -o" + substituteInPlace libs/copper-ui/Makefile --replace "all: qt gtk gtk2" "all: qt" + '' + + lib.optionalString withGtk2 '' + substituteInPlace libs/copper-ui/Makefile --replace "all: qt gtk gtk2" "all: gtk2" + '' + + lib.optionalString withGtk3 '' + substituteInPlace libs/copper-ui/Makefile --replace "all: qt gtk gtk2" "all: gtk" + ''; + nativeBuildInputs = + [ + copper + python3 + pkg-config + ] + ++ lib.optionals withGtk2 [ gtk2 ] + ++ lib.optionals withGtk3 [ gtk3 ] + ++ lib.optionals withQt [ + qtbase + wrapQtAppsHook + ]; + buildInputs = + lib.optionals withQt [ qtbase ] + ++ lib.optionals withGtk2 [ gtk2 ] + ++ lib.optionals withGtk3 [ gtk3 ]; + makeFlags = + [ + "prefix=$(out)" + "COPPER=${copper}/bin/copper-elf64" + "with-local-libs" + ] + ++ lib.optionals withQt [ + "QINC=${qtbase.dev}/include" + "UI=qt" + ] + ++ lib.optionals withGtk2 [ "UI=gtk2" ] + ++ lib.optionals withGtk3 [ "UI=gtk" ]; meta = with lib; { description = "Folding text editor, designed to hierarchically structure any kind of text file and especially source code"; diff --git a/pkgs/applications/editors/cpeditor/default.nix b/pkgs/applications/editors/cpeditor/default.nix index d90ab08614077b..b869ec3b6d155f 100644 --- a/pkgs/applications/editors/cpeditor/default.nix +++ b/pkgs/applications/editors/cpeditor/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, qtbase -, qttools -, wrapQtAppsHook -, syntax-highlighting -, cmake -, ninja -, python3 -, runtimeShell +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + qtbase, + qttools, + wrapQtAppsHook, + syntax-highlighting, + cmake, + ninja, + python3, + runtimeShell, }: stdenv.mkDerivation rec { @@ -24,8 +25,18 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake ninja pkg-config wrapQtAppsHook python3 ]; - buildInputs = [ qtbase qttools syntax-highlighting ]; + nativeBuildInputs = [ + cmake + ninja + pkg-config + wrapQtAppsHook + python3 + ]; + buildInputs = [ + qtbase + qttools + syntax-highlighting + ]; postPatch = '' substituteInPlace src/Core/Runner.cpp --replace-fail "/bin/bash" "${runtimeShell}" diff --git a/pkgs/applications/editors/eclipse/build-eclipse.nix b/pkgs/applications/editors/eclipse/build-eclipse.nix index dfb2fd38b99782..2852d7649ad602 100644 --- a/pkgs/applications/editors/eclipse/build-eclipse.nix +++ b/pkgs/applications/editors/eclipse/build-eclipse.nix @@ -1,8 +1,32 @@ -{ lib, stdenv, makeDesktopItem, freetype, fontconfig, libX11, libXrender -, zlib, jdk, glib, glib-networking, gtk, libXtst, libsecret, gsettings-desktop-schemas, webkitgtk_4_0 -, makeWrapper, perl, ... }: +{ + lib, + stdenv, + makeDesktopItem, + freetype, + fontconfig, + libX11, + libXrender, + zlib, + jdk, + glib, + glib-networking, + gtk, + libXtst, + libsecret, + gsettings-desktop-schemas, + webkitgtk_4_0, + makeWrapper, + perl, + ... +}: -{ name, src ? builtins.getAttr stdenv.hostPlatform.system sources, sources ? null, description, productVersion }: +{ + name, + src ? builtins.getAttr stdenv.hostPlatform.system sources, + sources ? null, + description, + productVersion, +}: stdenv.mkDerivation rec { inherit name src; @@ -17,10 +41,22 @@ stdenv.mkDerivation rec { categories = [ "Development" ]; }; - nativeBuildInputs = [ makeWrapper perl ]; + nativeBuildInputs = [ + makeWrapper + perl + ]; buildInputs = [ - fontconfig freetype glib gsettings-desktop-schemas gtk jdk libX11 - libXrender libXtst libsecret zlib + fontconfig + freetype + glib + gsettings-desktop-schemas + gtk + jdk + libX11 + libXrender + libXtst + libsecret + zlib ] ++ lib.optional (webkitgtk_4_0 != null) webkitgtk_4_0; buildCommand = '' @@ -32,7 +68,15 @@ stdenv.mkDerivation rec { interpreter="$(cat $NIX_BINTOOLS/nix-support/dynamic-linker)" libCairo=$out/eclipse/libcairo-swt.so patchelf --set-interpreter $interpreter $out/eclipse/eclipse - [ -f $libCairo ] && patchelf --set-rpath ${lib.makeLibraryPath [ freetype fontconfig libX11 libXrender zlib ]} $libCairo + [ -f $libCairo ] && patchelf --set-rpath ${ + lib.makeLibraryPath [ + freetype + fontconfig + libX11 + libXrender + zlib + ] + } $libCairo # Create wrapper script. Pass -configuration to store # settings in ~/.eclipse/org.eclipse.platform_ rather @@ -41,7 +85,17 @@ stdenv.mkDerivation rec { makeWrapper $out/eclipse/eclipse $out/bin/eclipse \ --prefix PATH : ${jdk}/bin \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath ([ glib gtk libXtst libsecret ] ++ lib.optional (webkitgtk_4_0 != null) webkitgtk_4_0)} \ + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath ( + [ + glib + gtk + libXtst + libsecret + ] + ++ lib.optional (webkitgtk_4_0 != null) webkitgtk_4_0 + ) + } \ --prefix GIO_EXTRA_MODULES : "${glib-networking}/lib/gio/modules" \ --prefix XDG_DATA_DIRS : "$GSETTINGS_SCHEMAS_PATH" \ --add-flags "-configuration \$HOME/.eclipse/''${productId}_${productVersion}/configuration" @@ -60,7 +114,10 @@ stdenv.mkDerivation rec { homepage = "https://www.eclipse.org/"; inherit description; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; }; } diff --git a/pkgs/applications/editors/eclipse/default.nix b/pkgs/applications/editors/eclipse/default.nix index bb2a4d3bfd296b..74e8257c77bdaf 100644 --- a/pkgs/applications/editors/eclipse/default.nix +++ b/pkgs/applications/editors/eclipse/default.nix @@ -1,9 +1,25 @@ -{ lib, stdenv, fetchurl, makeDesktopItem, makeWrapper -, freetype, fontconfig, libX11, libXrender, zlib -, glib, gtk3, gtk2, libXtst, jdk, jdk8, gsettings-desktop-schemas -, webkitgtk_4_0 ? null # for internal web browser -, buildEnv, runCommand -, callPackage +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + makeWrapper, + freetype, + fontconfig, + libX11, + libXrender, + zlib, + glib, + gtk3, + gtk2, + libXtst, + jdk, + jdk8, + gsettings-desktop-schemas, + webkitgtk_4_0 ? null, # for internal web browser + buildEnv, + runCommand, + callPackage, }: # use ./update.sh to help with updating for each quarterly release @@ -15,38 +31,59 @@ let platform_major = "4"; platform_minor = "33"; year = "2024"; - month = "09"; #release month - buildmonth = "09"; #sometimes differs from release month + month = "09"; # release month + buildmonth = "09"; # sometimes differs from release month timestamp = "${year}${buildmonth}030240"; gtk = gtk3; - arch = if stdenv.hostPlatform.isx86_64 then - "x86_64" - else if stdenv.hostPlatform.isAarch64 then - "aarch64" - else throw "don't know what platform suffix for ${stdenv.hostPlatform.system} will be"; -in rec { + arch = + if stdenv.hostPlatform.isx86_64 then + "x86_64" + else if stdenv.hostPlatform.isAarch64 then + "aarch64" + else + throw "don't know what platform suffix for ${stdenv.hostPlatform.system} will be"; +in +rec { # work around https://bugs.eclipse.org/bugs/show_bug.cgi?id=476075#c3 buildEclipseUnversioned = callPackage ./build-eclipse.nix { - inherit stdenv makeDesktopItem freetype fontconfig libX11 libXrender zlib - jdk glib gtk libXtst gsettings-desktop-schemas webkitgtk_4_0 - makeWrapper; + inherit + stdenv + makeDesktopItem + freetype + fontconfig + libX11 + libXrender + zlib + jdk + glib + gtk + libXtst + gsettings-desktop-schemas + webkitgtk_4_0 + makeWrapper + ; }; - buildEclipse = eclipseData: buildEclipseUnversioned (eclipseData // { productVersion = "${platform_major}.${platform_minor}"; }); + buildEclipse = + eclipseData: + buildEclipseUnversioned ( + eclipseData // { productVersion = "${platform_major}.${platform_minor}"; } + ); ### Eclipse CPP eclipse-cpp = buildEclipse { name = "eclipse-cpp-${platform_major}.${platform_minor}"; description = "Eclipse IDE for C/C++ Developers"; - src = - fetchurl { - url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-cpp-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; - hash = { + src = fetchurl { + url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-cpp-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; + hash = + { x86_64 = "sha256-zCIVlrr8CPRBiv1FOVHjoW7WcKC74V+JC2ciyiBuYOw="; aarch64 = "sha256-Lnwz8up/WoOdth0bxxePxagwkOaTljFYkCHHu5NoCPk="; - }.${arch}; - }; + } + .${arch}; + }; }; ### Eclipse DSL @@ -54,14 +91,15 @@ in rec { eclipse-dsl = buildEclipse { name = "eclipse-dsl-${platform_major}.${platform_minor}"; description = "Eclipse IDE for Java and DSL Developers"; - src = - fetchurl { - url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-dsl-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; - hash = { + src = fetchurl { + url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-dsl-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; + hash = + { x86_64 = "sha256-a/Vnbm1zzay5GSsJbU3yFGs7fSBx77wvOHJdlEs8BjE="; aarch64 = "sha256-ghf0Q31cudxGDmYvLXyeqTYCpqIkZNp9y1Bd/izOSl4="; - }.${arch}; - }; + } + .${arch}; + }; }; ### Eclipse IDE for Embedded C/C++ Developers @@ -69,14 +107,15 @@ in rec { eclipse-embedcpp = buildEclipse { name = "eclipse-embedcpp-${platform_major}.${platform_minor}"; description = "Eclipse IDE for Embedded C/C++ Developers"; - src = - fetchurl { - url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-embedcpp-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; - hash = { + src = fetchurl { + url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-embedcpp-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; + hash = + { x86_64 = "sha256-6krmMvja30Jal1w4gi1NQSZpPxAMtjvs+tPtts+YuLA="; aarch64 = "sha256-qYzcR+4m8QAdV6JTvMuVU2h2oxVJGmyg9UJMibdkPxM="; - }.${arch}; - }; + } + .${arch}; + }; }; ### Eclipse Modeling @@ -84,14 +123,15 @@ in rec { eclipse-modeling = buildEclipse { name = "eclipse-modeling-${platform_major}.${platform_minor}"; description = "Eclipse Modeling Tools"; - src = - fetchurl { - url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-modeling-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; - hash = { + src = fetchurl { + url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-modeling-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; + hash = + { x86_64 = "sha256-AFwJNQJdULmiID3JPjQG3L631ujaNYsaDJ3QT60WwSY="; aarch64 = "sha256-MbvWrgHhTS1odtFCdZYdTOYZNjhb3gqvjGO1dVfdokA="; - }.${arch}; - }; + } + .${arch}; + }; }; ### Eclipse Platform @@ -99,46 +139,54 @@ in rec { eclipse-platform = buildEclipse { name = "eclipse-platform-${platform_major}.${platform_minor}"; description = "Eclipse Platform ${year}-${month}"; - src = - fetchurl { - url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/eclipse/downloads/drops${platform_major}/R-${platform_major}.${platform_minor}-${timestamp}/eclipse-platform-${platform_major}.${platform_minor}-linux-gtk-${arch}.tar.gz"; - hash = { + src = fetchurl { + url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/eclipse/downloads/drops${platform_major}/R-${platform_major}.${platform_minor}-${timestamp}/eclipse-platform-${platform_major}.${platform_minor}-linux-gtk-${arch}.tar.gz"; + hash = + { x86_64 = "sha256-6vNwys0HTaJdSl+1mK7hlGU0tQVyakvzrL0GZEObniQ="; aarch64 = "sha256-fERBf9bkGowZkRLQEMxLUB8qUVKZgRZOZjJEz+kc+WU="; - }.${arch}; - }; + } + .${arch}; + }; }; ### Eclipse Scala SDK eclipse-scala-sdk = - (buildEclipseUnversioned.override { jdk = jdk8; gtk = gtk2; } { - name = "eclipse-scala-sdk-4.7.0"; - description = "Eclipse IDE for Scala Developers"; - productVersion = "4.7"; - src = - fetchurl { + (buildEclipseUnversioned.override + { + jdk = jdk8; + gtk = gtk2; + } + { + name = "eclipse-scala-sdk-4.7.0"; + description = "Eclipse IDE for Scala Developers"; + productVersion = "4.7"; + src = fetchurl { url = "https://downloads.typesafe.com/scalaide-pack/4.7.0-vfinal-oxygen-212-20170929/scala-SDK-4.7.0-vfinal-2.12-linux.gtk.x86_64.tar.gz"; - sha256 = "1n5w2a7mh9ajv6fxcas1gpgwb04pdxbr9v5dzr67gsz5bhahq4ya"; + sha256 = "1n5w2a7mh9ajv6fxcas1gpgwb04pdxbr9v5dzr67gsz5bhahq4ya"; }; - }).overrideAttrs(oa: { - # Only download for x86_64 - meta.platforms = [ "x86_64-linux" ]; - }); + } + ).overrideAttrs + (oa: { + # Only download for x86_64 + meta.platforms = [ "x86_64-linux" ]; + }); ### Eclipse SDK eclipse-sdk = buildEclipse { name = "eclipse-sdk-${platform_major}.${platform_minor}"; description = "Eclipse ${year}-${month} Classic"; - src = - fetchurl { - url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/eclipse/downloads/drops${platform_major}/R-${platform_major}.${platform_minor}-${timestamp}/eclipse-SDK-${platform_major}.${platform_minor}-linux-gtk-${arch}.tar.gz"; - hash = { + src = fetchurl { + url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/eclipse/downloads/drops${platform_major}/R-${platform_major}.${platform_minor}-${timestamp}/eclipse-SDK-${platform_major}.${platform_minor}-linux-gtk-${arch}.tar.gz"; + hash = + { x86_64 = "sha256-4eYdixsPswwsBWfRng5VPp+/39mDuAO7cHc6NS3VI7o="; aarch64 = "sha256-UUdm7YqLOTappGwEnM3frvGZcESuh3LVl1L/HoN88Ug="; - }.${arch}; - }; + } + .${arch}; + }; }; ### Eclipse Java @@ -146,14 +194,15 @@ in rec { eclipse-java = buildEclipse { name = "eclipse-java-${platform_major}.${platform_minor}"; description = "Eclipse IDE for Java Developers"; - src = - fetchurl { - url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-java-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; - hash = { + src = fetchurl { + url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-java-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; + hash = + { x86_64 = "sha256-gAbc049iHCPwGohQwNG1pCejCpOh0qUsnjSZosedqUU="; aarch64 = "sha256-VpKs4O1Rxb/qhULUK+EPIPsGSH+qQJpNsDRGNX09Bj0="; - }.${arch}; - }; + } + .${arch}; + }; }; ### Eclipse Java EE @@ -161,14 +210,15 @@ in rec { eclipse-jee = buildEclipse { name = "eclipse-jee-${platform_major}.${platform_minor}"; description = "Eclipse IDE for Enterprise Java and Web Developers"; - src = - fetchurl { - url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-jee-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; - hash = { + src = fetchurl { + url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-jee-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; + hash = + { x86_64 = "sha256-BLvjy4vBuvMt3mZccp+UWw9p58taWiyZkbwaeMOOBpU="; aarch64 = "sha256-5tGJoOPk56/0WVZAxB8VWryJmnHMr4gHQyjET9sB1Qk="; - }.${arch}; - }; + } + .${arch}; + }; }; ### Eclipse Committers @@ -176,14 +226,15 @@ in rec { eclipse-committers = buildEclipse { name = "eclipse-committers-${platform_major}.${platform_minor}"; description = "Eclipse IDE for Eclipse Committers and Eclipse Platform Plugin Developers"; - src = - fetchurl { - url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-committers-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; - hash = { + src = fetchurl { + url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-committers-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; + hash = + { x86_64 = "sha256-IQL6dWNHg5DMVkR2XYge2jHmIwx8KS968k8EoS/II+A="; aarch64 = "sha256-ATni52tdHyaVvacSAiiOB6eN1zwS17VZazcsd6HOemA="; - }.${arch}; - }; + } + .${arch}; + }; }; ### Eclipse IDE for RCP and RAP Developers @@ -191,21 +242,27 @@ in rec { eclipse-rcp = buildEclipse { name = "eclipse-rcp-${platform_major}.${platform_minor}"; description = "Eclipse IDE for RCP and RAP Developers"; - src = - fetchurl { - url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-rcp-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; - hash = { + src = fetchurl { + url = "https://www.eclipse.org/downloads/download.php?r=1&nf=1&file=/technology/epp/downloads/release/${year}-${month}/R/eclipse-rcp-${year}-${month}-R-linux-gtk-${arch}.tar.gz"; + hash = + { x86_64 = "sha256-BqRcUU6GivuPFzr3e2FX+ga5OVO8o7NzuXuqUu52pN4="; aarch64 = "sha256-lAsur73Z/EaKVLY9URoyvcvtD9LoOO7FG6l/lUtT8H8="; - }.${arch}; - }; + } + .${arch}; + }; }; ### Environments # Function that assembles a complete Eclipse environment from an # Eclipse package and list of Eclipse plugins. - eclipseWithPlugins = { eclipse, plugins ? [], jvmArgs ? [] }: + eclipseWithPlugins = + { + eclipse, + plugins ? [ ], + jvmArgs ? [ ], + }: let # Gather up the desired plugins. pluginEnv = buildEnv { @@ -217,25 +274,25 @@ in rec { # add the property indicating the plugin directory. dropinPropName = "org.eclipse.equinox.p2.reconciler.dropins.directory"; dropinProp = "-D${dropinPropName}=${pluginEnv}/eclipse/dropins"; - jvmArgsText = lib.concatStringsSep "\n" (jvmArgs ++ [dropinProp]); + jvmArgsText = lib.concatStringsSep "\n" (jvmArgs ++ [ dropinProp ]); # Base the derivation name on the name of the underlying # Eclipse. name = (lib.meta.appendToName "with-plugins" eclipse).name; in - runCommand name { nativeBuildInputs = [ makeWrapper ]; } '' - mkdir -p $out/bin $out/etc + runCommand name { nativeBuildInputs = [ makeWrapper ]; } '' + mkdir -p $out/bin $out/etc - # Prepare an eclipse.ini with the plugin directory. - cat ${eclipse}/eclipse/eclipse.ini - > $out/etc/eclipse.ini < $out/etc/eclipse.ini < srcPlugins != []; - assert srcPlugin != null -> srcPlugins == []; + { + name, + srcFeature, + srcPlugin ? null, + srcPlugins ? [ ], + ... + }@attrs: + assert srcPlugin == null -> srcPlugins != [ ]; + assert srcPlugin != null -> srcPlugins == [ ]; - let + let - pSrcs = if (srcPlugin != null) then [ srcPlugin ] else srcPlugins; + pSrcs = if (srcPlugin != null) then [ srcPlugin ] else srcPlugins; - in + in - buildEclipsePluginBase (attrs // { - srcs = [ srcFeature ] ++ pSrcs; + buildEclipsePluginBase ( + attrs + // { + srcs = [ srcFeature ] ++ pSrcs; - buildCommand = '' - dropinDir="$out/eclipse/dropins/${name}" + buildCommand = '' + dropinDir="$out/eclipse/dropins/${name}" - mkdir -p $dropinDir/features - unzip ${srcFeature} -d $dropinDir/features/ + mkdir -p $dropinDir/features + unzip ${srcFeature} -d $dropinDir/features/ - mkdir -p $dropinDir/plugins - for plugin in ${toString pSrcs}; do - cp -v $plugin $dropinDir/plugins/$(stripHash $plugin) - done - ''; - }); + mkdir -p $dropinDir/plugins + for plugin in ${toString pSrcs}; do + cp -v $plugin $dropinDir/plugins/$(stripHash $plugin) + done + ''; + } + ); # Helper for the case where the build directory has the layout of an # Eclipse update site, that is, it contains the directories # `features` and `plugins`. All features and plugins inside these # directories will be installed. - buildEclipseUpdateSite = { name, ... } @ attrs: - buildEclipsePluginBase (attrs // { - dontBuild = true; - doCheck = false; - - installPhase = '' - dropinDir="$out/eclipse/dropins/${name}" - - # Install features. - cd features - for feature in *.jar; do - featureName=''${feature%.jar} - mkdir -p $dropinDir/features/$featureName - unzip $feature -d $dropinDir/features/$featureName - done - cd .. - - # Install plugins. - mkdir -p $dropinDir/plugins - - # A bundle should be unpacked if the manifest matches this - # pattern. - unpackPat="Eclipse-BundleShape:\\s*dir" - - cd plugins - for plugin in *.jar ; do - pluginName=''${plugin%.jar} - manifest=$(unzip -p $plugin META-INF/MANIFEST.MF) - - if [[ $manifest =~ $unpackPat ]] ; then - mkdir $dropinDir/plugins/$pluginName - unzip $plugin -d $dropinDir/plugins/$pluginName - else - cp -v $plugin $dropinDir/plugins/ - fi - done - cd .. - ''; - }); + buildEclipseUpdateSite = + { name, ... }@attrs: + buildEclipsePluginBase ( + attrs + // { + dontBuild = true; + doCheck = false; + + installPhase = '' + dropinDir="$out/eclipse/dropins/${name}" + + # Install features. + cd features + for feature in *.jar; do + featureName=''${feature%.jar} + mkdir -p $dropinDir/features/$featureName + unzip $feature -d $dropinDir/features/$featureName + done + cd .. + + # Install plugins. + mkdir -p $dropinDir/plugins + + # A bundle should be unpacked if the manifest matches this + # pattern. + unpackPat="Eclipse-BundleShape:\\s*dir" + + cd plugins + for plugin in *.jar ; do + pluginName=''${plugin%.jar} + manifest=$(unzip -p $plugin META-INF/MANIFEST.MF) + + if [[ $manifest =~ $unpackPat ]] ; then + mkdir $dropinDir/plugins/$pluginName + unzip $plugin -d $dropinDir/plugins/$pluginName + else + cp -v $plugin $dropinDir/plugins/ + fi + done + cd .. + ''; + } + ); acejump = buildEclipsePlugin rec { name = "acejump-${version}"; @@ -465,21 +490,43 @@ rec { srcPlugins = let - fetch = { n, h }: + fetch = + { n, h }: fetchurl { url = "https://boothen.github.io/Json-Eclipse-Plugin/plugins/jsonedit-${n}_${version}.jar"; sha256 = h; }; in - map fetch [ - { n = "core"; h = "0svs0aswnhl26cqw6bmw30cisx4cr50kc5njg272sy5c1dqjm1zq"; } - { n = "editor"; h = "1q62dinrbb18aywbvii4mlr7rxa20rdsxxd6grix9y8h9776q4l5"; } - { n = "folding"; h = "1qh4ijfb1gl9xza5ydi87v1kyima3a9sh7lncwdy1way3pdhln1y"; } - { n = "model"; h = "1pr6k2pdfdwx8jqs7gx7wzn3gxsql3sk6lnjha8m15lv4al6d4kj"; } - { n = "outline"; h = "1jgr2g16j3id8v367jbgd6kx6g2w636fbzmd8jvkvkh7y1jgjqxm"; } - { n = "preferences"; h = "027fhaqa5xbil6dmhvkbpha3pgw6dpmc2im3nlliyds57mdmdb1h"; } - { n = "text"; h = "0clywylyidrxlqs0n816nhgjmk1c3xl7sn904ki4q050amfy0wb2"; } - ]; + map fetch [ + { + n = "core"; + h = "0svs0aswnhl26cqw6bmw30cisx4cr50kc5njg272sy5c1dqjm1zq"; + } + { + n = "editor"; + h = "1q62dinrbb18aywbvii4mlr7rxa20rdsxxd6grix9y8h9776q4l5"; + } + { + n = "folding"; + h = "1qh4ijfb1gl9xza5ydi87v1kyima3a9sh7lncwdy1way3pdhln1y"; + } + { + n = "model"; + h = "1pr6k2pdfdwx8jqs7gx7wzn3gxsql3sk6lnjha8m15lv4al6d4kj"; + } + { + n = "outline"; + h = "1jgr2g16j3id8v367jbgd6kx6g2w636fbzmd8jvkvkh7y1jgjqxm"; + } + { + n = "preferences"; + h = "027fhaqa5xbil6dmhvkbpha3pgw6dpmc2im3nlliyds57mdmdb1h"; + } + { + n = "text"; + h = "0clywylyidrxlqs0n816nhgjmk1c3xl7sn904ki4q050amfy0wb2"; + } + ]; propagatedBuildInputs = [ antlr-runtime_4_7 ]; @@ -526,10 +573,9 @@ rec { stripRoot = false; url = "https://github.com/${owner}/${repo}/archive/${rev}.zip"; sha256 = "1xfj4j27d1h4bdf2v7f78zi8lz4zkkj7s9kskmsqx5jcs2d459yp"; - postFetch = - '' - mv "$out/${repo}-${rev}/releases/local-repo/"* "$out/" - ''; + postFetch = '' + mv "$out/${repo}-${rev}/releases/local-repo/"* "$out/" + ''; }; meta = with lib; { diff --git a/pkgs/applications/editors/emacs/build-support/buffer.nix b/pkgs/applications/editors/emacs/build-support/buffer.nix index 48a7996916e8d6..c91fd033e0b652 100644 --- a/pkgs/applications/editors/emacs/build-support/buffer.nix +++ b/pkgs/applications/editors/emacs/build-support/buffer.nix @@ -1,13 +1,22 @@ # Functions to build elisp files to locally configure emcas buffers. # See https://github.com/shlevy/nix-buffer -{ lib, writeText, inherit-local }: +{ + lib, + writeText, + inherit-local, +}: rec { - withPackages = pkgs': let + withPackages = + pkgs': + let pkgs = builtins.filter (x: x != null) pkgs'; - extras = map (x: x.emacsBufferSetup pkgs) (builtins.filter (builtins.hasAttr "emacsBufferSetup") pkgs); - in writeText "dir-locals.el" '' + extras = map (x: x.emacsBufferSetup pkgs) ( + builtins.filter (builtins.hasAttr "emacsBufferSetup") pkgs + ); + in + writeText "dir-locals.el" '' (require 'inherit-local "${inherit-local}/share/emacs/site-lisp/elpa/inherit-local-${inherit-local.version}/inherit-local.elc") ; Only set up nixpkgs buffer handling when we have some buffers active @@ -43,7 +52,9 @@ rec { ; setenv modifies in place, so copy the environment first (setq process-environment (copy-tree process-environment)) (setenv "PATH" (concat "${lib.makeSearchPath "bin" pkgs}:" (getenv "PATH"))) - (inherit-local-permanent exec-path (append '(${builtins.concatStringsSep " " (map (p: "\"${p}/bin\"") pkgs)}) exec-path)) + (inherit-local-permanent exec-path (append '(${ + builtins.concatStringsSep " " (map (p: "\"${p}/bin\"") pkgs) + }) exec-path)) (inherit-local-permanent eshell-path-env (concat "${lib.makeSearchPath "bin" pkgs}:" (if (boundp 'eshell-path-env) eshell-path-env (getenv "PATH")))) @@ -54,24 +65,28 @@ rec { ''; # nix-buffer function for a project with a bunch of haskell packages # in one directory - haskellMonoRepo = { project-root # The monorepo root - , haskellPackages # The composed haskell packages set that contains all of the packages - }: { root }: - let # The haskell paths. - haskell-paths = lib.filesystem.haskellPathsInDir project-root; - # Find the haskell package that the 'root' is in, if any. - haskell-path-parent = - let filtered = builtins.filter (name: - lib.hasPrefix (toString (project-root + "/${name}")) (toString root) + haskellMonoRepo = + { + project-root, # The monorepo root + haskellPackages, # The composed haskell packages set that contains all of the packages + }: + { root }: + let + # The haskell paths. + haskell-paths = lib.filesystem.haskellPathsInDir project-root; + # Find the haskell package that the 'root' is in, if any. + haskell-path-parent = + let + filtered = builtins.filter ( + name: lib.hasPrefix (toString (project-root + "/${name}")) (toString root) ) (builtins.attrNames haskell-paths); - in - if filtered == [] then null else builtins.head filtered; - # We're in the directory of a haskell package - is-haskell-package = haskell-path-parent != null; - haskell-package = haskellPackages.${haskell-path-parent}; - # GHC environment with all needed deps for the haskell package - haskell-package-env = - builtins.head haskell-package.env.nativeBuildInputs; + in + if filtered == [ ] then null else builtins.head filtered; + # We're in the directory of a haskell package + is-haskell-package = haskell-path-parent != null; + haskell-package = haskellPackages.${haskell-path-parent}; + # GHC environment with all needed deps for the haskell package + haskell-package-env = builtins.head haskell-package.env.nativeBuildInputs; in - lib.optionalAttrs is-haskell-package (withPackages [ haskell-package-env ]); + lib.optionalAttrs is-haskell-package (withPackages [ haskell-package-env ]); } diff --git a/pkgs/applications/editors/emacs/build-support/elpa.nix b/pkgs/applications/editors/emacs/build-support/elpa.nix index 5a8f0ab9e52c80..1b30a5ac898d84 100644 --- a/pkgs/applications/editors/emacs/build-support/elpa.nix +++ b/pkgs/applications/editors/emacs/build-support/elpa.nix @@ -1,40 +1,57 @@ # builder for Emacs packages built for packages.el -{ lib, stdenv, emacs, texinfo, writeText }: +{ + lib, + stdenv, + emacs, + texinfo, + writeText, +}: let - genericBuild = import ./generic.nix { inherit lib stdenv emacs texinfo writeText; }; + genericBuild = import ./generic.nix { + inherit + lib + stdenv + emacs + texinfo + writeText + ; + }; libBuildHelper = import ./lib-build-helper.nix; in -libBuildHelper.extendMkDerivation' genericBuild (finalAttrs: +libBuildHelper.extendMkDerivation' genericBuild ( + finalAttrs: -{ pname -, dontUnpack ? true -, meta ? {} -, ... -}@args: + { + pname, + dontUnpack ? true, + meta ? { }, + ... + }@args: -{ + { - elpa2nix = args.elpa2nix or ./elpa2nix.el; + elpa2nix = args.elpa2nix or ./elpa2nix.el; - inherit dontUnpack; + inherit dontUnpack; - installPhase = args.installPhase or '' - runHook preInstall + installPhase = + args.installPhase or '' + runHook preInstall - emacs --batch -Q -l "$elpa2nix" \ - -f elpa2nix-install-package \ - "$src" "$out/share/emacs/site-lisp/elpa" + emacs --batch -Q -l "$elpa2nix" \ + -f elpa2nix-install-package \ + "$src" "$out/share/emacs/site-lisp/elpa" - runHook postInstall - ''; + runHook postInstall + ''; - meta = { - homepage = args.src.meta.homepage or "https://elpa.gnu.org/packages/${pname}.html"; - } // meta; -} + meta = { + homepage = args.src.meta.homepage or "https://elpa.gnu.org/packages/${pname}.html"; + } // meta; + } ) diff --git a/pkgs/applications/editors/emacs/build-support/generic.nix b/pkgs/applications/editors/emacs/build-support/generic.nix index f5b60305fc6b94..282d42d76284b6 100644 --- a/pkgs/applications/editors/emacs/build-support/generic.nix +++ b/pkgs/applications/editors/emacs/build-support/generic.nix @@ -1,6 +1,13 @@ # generic builder for Emacs packages -{ lib, stdenv, emacs, texinfo, writeText, ... }: +{ + lib, + stdenv, + emacs, + texinfo, + writeText, + ... +}: let inherit (lib) optionalAttrs; @@ -23,84 +30,97 @@ let in -libBuildHelper.extendMkDerivation' stdenv.mkDerivation (finalAttrs: - -{ buildInputs ? [] -, nativeBuildInputs ? [] -, packageRequires ? [] -, propagatedBuildInputs ? [] -, propagatedUserEnvPkgs ? [] -, postInstall ? "" -, meta ? {} -, turnCompilationWarningToError ? false -, ignoreCompilationError ? false -, ... -}@args: - -{ - name = args.name or "emacs-${finalAttrs.pname}-${finalAttrs.version}"; - - unpackCmd = args.unpackCmd or '' - case "$curSrc" in - *.el) - # keep original source filename without the hash - local filename=$(basename "$curSrc") - filename="''${filename:33}" - cp $curSrc $filename - chmod +w $filename - sourceRoot="." - ;; - *) - _defaultUnpack "$curSrc" - ;; - esac - ''; - - inherit packageRequires; - buildInputs = finalAttrs.packageRequires ++ buildInputs; - nativeBuildInputs = [ emacs texinfo ] ++ nativeBuildInputs; - propagatedBuildInputs = finalAttrs.packageRequires ++ propagatedBuildInputs; - propagatedUserEnvPkgs = finalAttrs.packageRequires ++ propagatedUserEnvPkgs; - - setupHook = args.setupHook or setupHook; - - inherit turnCompilationWarningToError ignoreCompilationError; - - meta = { - broken = false; - platforms = emacs.meta.platforms; - } // optionalAttrs ((args.src.meta.homepage or "") != "") { - homepage = args.src.meta.homepage; - } // meta; -} - -// optionalAttrs (emacs.withNativeCompilation or false) { - - addEmacsNativeLoadPath = args.addEmacsNativeLoadPath or true; - - postInstall = '' - # Besides adding the output directory to the native load path, make sure - # the current package's elisp files are in the load path, otherwise - # (require 'file-b) from file-a.el in the same package will fail. - mkdir -p $out/share/emacs/native-lisp - source ${./emacs-funcs.sh} - addEmacsVars "$out" - - # package-activate-all is used to activate packages. In other builder - # helpers, package-initialize is used for this purpose because - # package-activate-all is not available before Emacs 27. - find $out/share/emacs -type f -name '*.el' -not -name ".dir-locals.el" -print0 \ - | xargs --verbose -0 -I {} -n 1 -P $NIX_BUILD_CORES sh -c \ - "emacs \ - --batch \ - -f package-activate-all \ - --eval '(setq native-comp-eln-load-path (cdr native-comp-eln-load-path))' \ - --eval '(let ((default-directory \"$out/share/emacs/site-lisp\")) (normal-top-level-add-subdirs-to-load-path))' \ - --eval '(setq large-file-warning-threshold nil)' \ - --eval '(setq byte-compile-error-on-warn ${if finalAttrs.turnCompilationWarningToError then "t" else "nil"})' \ - -f batch-native-compile {} \ - || exit ${if finalAttrs.ignoreCompilationError then "0" else "\\$?"}" - '' + postInstall; -} +libBuildHelper.extendMkDerivation' stdenv.mkDerivation ( + finalAttrs: + + { + buildInputs ? [ ], + nativeBuildInputs ? [ ], + packageRequires ? [ ], + propagatedBuildInputs ? [ ], + propagatedUserEnvPkgs ? [ ], + postInstall ? "", + meta ? { }, + turnCompilationWarningToError ? false, + ignoreCompilationError ? false, + ... + }@args: + + { + name = args.name or "emacs-${finalAttrs.pname}-${finalAttrs.version}"; + + unpackCmd = + args.unpackCmd or '' + case "$curSrc" in + *.el) + # keep original source filename without the hash + local filename=$(basename "$curSrc") + filename="''${filename:33}" + cp $curSrc $filename + chmod +w $filename + sourceRoot="." + ;; + *) + _defaultUnpack "$curSrc" + ;; + esac + ''; + + inherit packageRequires; + buildInputs = finalAttrs.packageRequires ++ buildInputs; + nativeBuildInputs = [ + emacs + texinfo + ] ++ nativeBuildInputs; + propagatedBuildInputs = finalAttrs.packageRequires ++ propagatedBuildInputs; + propagatedUserEnvPkgs = finalAttrs.packageRequires ++ propagatedUserEnvPkgs; + + setupHook = args.setupHook or setupHook; + + inherit turnCompilationWarningToError ignoreCompilationError; + + meta = + { + broken = false; + platforms = emacs.meta.platforms; + } + // optionalAttrs ((args.src.meta.homepage or "") != "") { + homepage = args.src.meta.homepage; + } + // meta; + } + + // optionalAttrs (emacs.withNativeCompilation or false) { + + addEmacsNativeLoadPath = args.addEmacsNativeLoadPath or true; + + postInstall = + '' + # Besides adding the output directory to the native load path, make sure + # the current package's elisp files are in the load path, otherwise + # (require 'file-b) from file-a.el in the same package will fail. + mkdir -p $out/share/emacs/native-lisp + source ${./emacs-funcs.sh} + addEmacsVars "$out" + + # package-activate-all is used to activate packages. In other builder + # helpers, package-initialize is used for this purpose because + # package-activate-all is not available before Emacs 27. + find $out/share/emacs -type f -name '*.el' -not -name ".dir-locals.el" -print0 \ + | xargs --verbose -0 -I {} -n 1 -P $NIX_BUILD_CORES sh -c \ + "emacs \ + --batch \ + -f package-activate-all \ + --eval '(setq native-comp-eln-load-path (cdr native-comp-eln-load-path))' \ + --eval '(let ((default-directory \"$out/share/emacs/site-lisp\")) (normal-top-level-add-subdirs-to-load-path))' \ + --eval '(setq large-file-warning-threshold nil)' \ + --eval '(setq byte-compile-error-on-warn ${ + if finalAttrs.turnCompilationWarningToError then "t" else "nil" + })' \ + -f batch-native-compile {} \ + || exit ${if finalAttrs.ignoreCompilationError then "0" else "\\$?"}" + '' + + postInstall; + } ) diff --git a/pkgs/applications/editors/emacs/build-support/melpa.nix b/pkgs/applications/editors/emacs/build-support/melpa.nix index a6e6e7c5d4b1b2..6aa9d2502d76ff 100644 --- a/pkgs/applications/editors/emacs/build-support/melpa.nix +++ b/pkgs/applications/editors/emacs/build-support/melpa.nix @@ -1,10 +1,25 @@ # builder for Emacs packages built for packages.el # using MELPA package-build.el -{ lib, stdenv, fetchFromGitHub, emacs, texinfo, writeText }: +{ + lib, + stdenv, + fetchFromGitHub, + emacs, + texinfo, + writeText, +}: let - genericBuild = import ./generic.nix { inherit lib stdenv emacs texinfo writeText; }; + genericBuild = import ./generic.nix { + inherit + lib + stdenv + emacs + texinfo + writeText + ; + }; libBuildHelper = import ./lib-build-helper.nix; packageBuild = stdenv.mkDerivation { @@ -29,140 +44,156 @@ let in -libBuildHelper.extendMkDerivation' genericBuild (finalAttrs: - -{ /* - pname: Nix package name without special symbols and without version or - "emacs-" prefix. - */ - pname - /* - ename: Original Emacs package name, possibly containing special symbols. - Default: pname - */ -, ename ? pname - /* - version: Either a stable version such as "1.2" or an unstable version. - An unstable version can use either Nix format (preferred) such as - "1.2-unstable-2024-06-01" or MELPA format such as "20240601.1230". - */ -, version - /* - commit: Optional package history commit. - Default: src.rev or "unknown" - This will be written into the generated package but it is not needed during - the build process. - */ -, commit ? (finalAttrs.src.rev or "unknown") - /* - files: Optional recipe property specifying the files used to build the package. - If null, do not set it in recipe, keeping the default upstream behaviour. - Default: null - */ -, files ? null - /* - recipe: Optional MELPA recipe. - Default: a minimally functional recipe - This can be a path of a recipe file, a string of the recipe content or an empty string. - The default value is used if it is an empty string. - */ -, recipe ? "" -, preUnpack ? "" -, postUnpack ? "" -, meta ? {} -, ... -}@args: - -{ - - elpa2nix = args.elpa2nix or ./elpa2nix.el; - melpa2nix = args.melpa2nix or ./melpa2nix.el; - - inherit commit ename files recipe; - - packageBuild = args.packageBuild or packageBuild; - - melpaVersion = args.melpaVersion or ( - let - parsed = lib.flip builtins.match version - # match -unstable-YYYY-MM-DD format - "^.*-unstable-([[:digit:]]{4})-([[:digit:]]{2})-([[:digit:]]{2})$"; - unstableVersionInNixFormat = parsed != null; # heuristics - date = builtins.concatStringsSep "" parsed; - time = "0"; # unstable version in nix format lacks this info - in - if unstableVersionInNixFormat - then date + "." + time - else finalAttrs.version); - - preUnpack = '' - mkdir -p "$NIX_BUILD_TOP/recipes" - recipeFile="$NIX_BUILD_TOP/recipes/$ename" - if [ -r "$recipe" ]; then - ln -s "$recipe" "$recipeFile" - nixInfoLog "link recipe" - elif [ -n "$recipe" ]; then - printf "%s" "$recipe" > "$recipeFile" - nixInfoLog "write recipe" - else - cat > "$recipeFile" <<'EOF' -(${finalAttrs.ename} :fetcher git :url "" ${lib.optionalString (finalAttrs.files != null) ":files ${finalAttrs.files}"}) -EOF - nixInfoLog "use default recipe" - fi - nixInfoLog "recipe content:" "$(< $recipeFile)" - unset -v recipeFile - - ln -s "$packageBuild" "$NIX_BUILD_TOP/package-build" - - mkdir -p "$NIX_BUILD_TOP/packages" - '' + preUnpack; - - postUnpack = '' - mkdir -p "$NIX_BUILD_TOP/working" - ln -s "$NIX_BUILD_TOP/$sourceRoot" "$NIX_BUILD_TOP/working/$ename" - '' + postUnpack; - - buildPhase = args.buildPhase or '' - runHook preBuild - - # This is modified from stdenv buildPhase. foundMakefile is used in stdenv checkPhase. - if [[ ! ( -z "''${makeFlags-}" && -z "''${makefile:-}" && ! ( -e Makefile || -e makefile || -e GNUmakefile ) ) ]]; then - foundMakefile=1 - fi - - pushd "$NIX_BUILD_TOP" - - emacs --batch -Q \ - -L "$NIX_BUILD_TOP/package-build" \ - -l "$melpa2nix" \ - -f melpa2nix-build-package \ - $ename $melpaVersion $commit - - popd - - runHook postBuild - ''; - - installPhase = args.installPhase or '' - runHook preInstall - - archive="$NIX_BUILD_TOP/packages/$ename-$melpaVersion.el" - if [ ! -f "$archive" ]; then - archive="$NIX_BUILD_TOP/packages/$ename-$melpaVersion.tar" - fi - - emacs --batch -Q \ - -l "$elpa2nix" \ - -f elpa2nix-install-package \ - "$archive" "$out/share/emacs/site-lisp/elpa" - - runHook postInstall - ''; - - meta = { - homepage = args.src.meta.homepage or "https://melpa.org/#/${pname}"; - } // meta; -} +libBuildHelper.extendMkDerivation' genericBuild ( + finalAttrs: + + { + /* + pname: Nix package name without special symbols and without version or + "emacs-" prefix. + */ + pname, + /* + ename: Original Emacs package name, possibly containing special symbols. + Default: pname + */ + ename ? pname, + /* + version: Either a stable version such as "1.2" or an unstable version. + An unstable version can use either Nix format (preferred) such as + "1.2-unstable-2024-06-01" or MELPA format such as "20240601.1230". + */ + version, + /* + commit: Optional package history commit. + Default: src.rev or "unknown" + This will be written into the generated package but it is not needed during + the build process. + */ + commit ? (finalAttrs.src.rev or "unknown"), + /* + files: Optional recipe property specifying the files used to build the package. + If null, do not set it in recipe, keeping the default upstream behaviour. + Default: null + */ + files ? null, + /* + recipe: Optional MELPA recipe. + Default: a minimally functional recipe + This can be a path of a recipe file, a string of the recipe content or an empty string. + The default value is used if it is an empty string. + */ + recipe ? "", + preUnpack ? "", + postUnpack ? "", + meta ? { }, + ... + }@args: + + { + + elpa2nix = args.elpa2nix or ./elpa2nix.el; + melpa2nix = args.melpa2nix or ./melpa2nix.el; + + inherit + commit + ename + files + recipe + ; + + packageBuild = args.packageBuild or packageBuild; + + melpaVersion = + args.melpaVersion or ( + let + parsed = + lib.flip builtins.match version + # match -unstable-YYYY-MM-DD format + "^.*-unstable-([[:digit:]]{4})-([[:digit:]]{2})-([[:digit:]]{2})$"; + unstableVersionInNixFormat = parsed != null; # heuristics + date = builtins.concatStringsSep "" parsed; + time = "0"; # unstable version in nix format lacks this info + in + if unstableVersionInNixFormat then date + "." + time else finalAttrs.version + ); + + preUnpack = + '' + mkdir -p "$NIX_BUILD_TOP/recipes" + recipeFile="$NIX_BUILD_TOP/recipes/$ename" + if [ -r "$recipe" ]; then + ln -s "$recipe" "$recipeFile" + nixInfoLog "link recipe" + elif [ -n "$recipe" ]; then + printf "%s" "$recipe" > "$recipeFile" + nixInfoLog "write recipe" + else + cat > "$recipeFile" <<'EOF' + (${finalAttrs.ename} :fetcher git :url "" ${ + lib.optionalString (finalAttrs.files != null) ":files ${finalAttrs.files}" + }) + EOF + nixInfoLog "use default recipe" + fi + nixInfoLog "recipe content:" "$(< $recipeFile)" + unset -v recipeFile + + ln -s "$packageBuild" "$NIX_BUILD_TOP/package-build" + + mkdir -p "$NIX_BUILD_TOP/packages" + '' + + preUnpack; + + postUnpack = + '' + mkdir -p "$NIX_BUILD_TOP/working" + ln -s "$NIX_BUILD_TOP/$sourceRoot" "$NIX_BUILD_TOP/working/$ename" + '' + + postUnpack; + + buildPhase = + args.buildPhase or '' + runHook preBuild + + # This is modified from stdenv buildPhase. foundMakefile is used in stdenv checkPhase. + if [[ ! ( -z "''${makeFlags-}" && -z "''${makefile:-}" && ! ( -e Makefile || -e makefile || -e GNUmakefile ) ) ]]; then + foundMakefile=1 + fi + + pushd "$NIX_BUILD_TOP" + + emacs --batch -Q \ + -L "$NIX_BUILD_TOP/package-build" \ + -l "$melpa2nix" \ + -f melpa2nix-build-package \ + $ename $melpaVersion $commit + + popd + + runHook postBuild + ''; + + installPhase = + args.installPhase or '' + runHook preInstall + + archive="$NIX_BUILD_TOP/packages/$ename-$melpaVersion.el" + if [ ! -f "$archive" ]; then + archive="$NIX_BUILD_TOP/packages/$ename-$melpaVersion.tar" + fi + + emacs --batch -Q \ + -l "$elpa2nix" \ + -f elpa2nix-install-package \ + "$archive" "$out/share/emacs/site-lisp/elpa" + + runHook postInstall + ''; + + meta = { + homepage = args.src.meta.homepage or "https://melpa.org/#/${pname}"; + } // meta; + } ) diff --git a/pkgs/applications/editors/emacs/build-support/trivial.nix b/pkgs/applications/editors/emacs/build-support/trivial.nix index 2e4da1ca8ea02e..9a3b59246497bc 100644 --- a/pkgs/applications/editors/emacs/build-support/trivial.nix +++ b/pkgs/applications/editors/emacs/build-support/trivial.nix @@ -6,33 +6,36 @@ let libBuildHelper = import ./lib-build-helper.nix; in -libBuildHelper.extendMkDerivation' (callPackage ./generic.nix envargs) (finalAttrs: +libBuildHelper.extendMkDerivation' (callPackage ./generic.nix envargs) ( + finalAttrs: -args: + args: -{ - buildPhase = args.buildPhase or '' - runHook preBuild + { + buildPhase = + args.buildPhase or '' + runHook preBuild - # This is modified from stdenv buildPhase. foundMakefile is used in stdenv checkPhase. - if [[ ! ( -z "''${makeFlags-}" && -z "''${makefile:-}" && ! ( -e Makefile || -e makefile || -e GNUmakefile ) ) ]]; then - foundMakefile=1 - fi + # This is modified from stdenv buildPhase. foundMakefile is used in stdenv checkPhase. + if [[ ! ( -z "''${makeFlags-}" && -z "''${makefile:-}" && ! ( -e Makefile || -e makefile || -e GNUmakefile ) ) ]]; then + foundMakefile=1 + fi - emacs -l package -f package-initialize -L . --batch -f batch-byte-compile *.el + emacs -l package -f package-initialize -L . --batch -f batch-byte-compile *.el - runHook postBuild - ''; + runHook postBuild + ''; - installPhase = args.installPhase or '' - runHook preInstall + installPhase = + args.installPhase or '' + runHook preInstall - LISPDIR=$out/share/emacs/site-lisp - install -d $LISPDIR - install *.el *.elc $LISPDIR + LISPDIR=$out/share/emacs/site-lisp + install -d $LISPDIR + install *.el *.elc $LISPDIR - runHook postInstall - ''; -} + runHook postInstall + ''; + } ) diff --git a/pkgs/applications/editors/emacs/build-support/wrapper.nix b/pkgs/applications/editors/emacs/build-support/wrapper.nix index 5b325f5e0a9e69..606a7a500e33a1 100644 --- a/pkgs/applications/editors/emacs/build-support/wrapper.nix +++ b/pkgs/applications/editors/emacs/build-support/wrapper.nix @@ -1,38 +1,41 @@ /* - -# Usage - -`emacs.pkgs.withPackages` takes a single argument: a function from a package -set to a list of packages (the packages that will be available in -Emacs). For example, -``` -emacs.pkgs.withPackages (epkgs: [ epkgs.evil epkgs.magit ]) -``` -All the packages in the list should come from the provided package -set. It is possible to add any package to the list, but the provided -set is guaranteed to have consistent dependencies and be built with -the correct version of Emacs. - -# Overriding - -`emacs.pkgs.withPackages` inherits the package set which contains it, so the -correct way to override the provided package set is to override the -set which contains `emacs.pkgs.withPackages`. For example, to override -`emacs.pkgs.emacs.pkgs.withPackages`, -``` -let customEmacsPackages = - emacs.pkgs.overrideScope (self: super: { - # use a custom version of emacs - emacs = ...; - # use the unstable MELPA version of magit - magit = self.melpaPackages.magit; - }); -in customEmacsPackages.withPackages (epkgs: [ epkgs.evil epkgs.magit ]) -``` - + # Usage + + `emacs.pkgs.withPackages` takes a single argument: a function from a package + set to a list of packages (the packages that will be available in + Emacs). For example, + ``` + emacs.pkgs.withPackages (epkgs: [ epkgs.evil epkgs.magit ]) + ``` + All the packages in the list should come from the provided package + set. It is possible to add any package to the list, but the provided + set is guaranteed to have consistent dependencies and be built with + the correct version of Emacs. + + # Overriding + + `emacs.pkgs.withPackages` inherits the package set which contains it, so the + correct way to override the provided package set is to override the + set which contains `emacs.pkgs.withPackages`. For example, to override + `emacs.pkgs.emacs.pkgs.withPackages`, + ``` + let customEmacsPackages = + emacs.pkgs.overrideScope (self: super: { + # use a custom version of emacs + emacs = ...; + # use the unstable MELPA version of magit + magit = self.melpaPackages.magit; + }); + in customEmacsPackages.withPackages (epkgs: [ epkgs.evil epkgs.magit ]) + ``` */ -{ lib, lndir, makeBinaryWrapper, runCommand }: +{ + lib, + lndir, + makeBinaryWrapper, + runCommand, +}: self: let inherit (self) emacs; @@ -41,148 +44,152 @@ let in packagesFun: # packages explicitly requested by the user let - explicitRequires = - if lib.isFunction packagesFun - then packagesFun self - else packagesFun; + explicitRequires = if lib.isFunction packagesFun then packagesFun self else packagesFun; in -runCommand - (lib.appendToName "with-packages" emacs).name +runCommand (lib.appendToName "with-packages" emacs).name { inherit emacs explicitRequires; - nativeBuildInputs = [ emacs lndir makeBinaryWrapper ]; + nativeBuildInputs = [ + emacs + lndir + makeBinaryWrapper + ]; preferLocalBuild = true; allowSubstitutes = false; # Store all paths we want to add to emacs here, so that we only need to add # one path to the load lists - deps = runCommand "emacs-packages-deps" - ({ - inherit explicitRequires lndir emacs; - } // lib.optionalAttrs withNativeCompilation { - inherit (emacs) LIBRARY_PATH; - }) - '' - findInputsOld() { - local pkg="$1"; shift - local var="$1"; shift - local propagatedBuildInputsFiles=("$@") - - # TODO(@Ericson2314): Restore using associative array once Darwin - # nix-shell doesn't use impure bash. This should replace the O(n) - # case with an O(1) hash map lookup, assuming bash is implemented - # well :D. - local varSlice="$var[*]" - # ''${..-} to hack around old bash empty array problem - case "''${!varSlice-}" in - *" $pkg "*) return 0 ;; - esac - unset -v varSlice - - eval "$var"'+=("$pkg")' - - if ! [ -e "$pkg" ]; then - echo "build input $pkg does not exist" >&2 - exit 1 - fi - - local file - for file in "''${propagatedBuildInputsFiles[@]}"; do - file="$pkg/nix-support/$file" - [[ -f "$file" ]] || continue - - local pkgNext - for pkgNext in $(< "$file"); do - findInputsOld "$pkgNext" "$var" "''${propagatedBuildInputsFiles[@]}" - done - done - } - mkdir -p $out/bin - mkdir -p $out/share/emacs/site-lisp - ${lib.optionalString withNativeCompilation '' - mkdir -p $out/share/emacs/native-lisp - ''} - ${lib.optionalString withTreeSitter '' - mkdir -p $out/lib - ''} - - local requires - for pkg in $explicitRequires; do - findInputsOld $pkg requires propagated-user-env-packages - done - # requires now holds all requested packages and their transitive dependencies - - linkPath() { - local pkg=$1 - local origin_path=$2 - local dest_path=$3 - - # Add the path to the search path list, but only if it exists - if [[ -d "$pkg/$origin_path" ]]; then - $lndir/bin/lndir -silent "$pkg/$origin_path" "$out/$dest_path" - fi - } - - linkEmacsPackage() { - linkPath "$1" "bin" "bin" - linkPath "$1" "share/emacs/site-lisp" "share/emacs/site-lisp" + deps = + runCommand "emacs-packages-deps" + ( + { + inherit explicitRequires lndir emacs; + } + // lib.optionalAttrs withNativeCompilation { + inherit (emacs) LIBRARY_PATH; + } + ) + '' + findInputsOld() { + local pkg="$1"; shift + local var="$1"; shift + local propagatedBuildInputsFiles=("$@") + + # TODO(@Ericson2314): Restore using associative array once Darwin + # nix-shell doesn't use impure bash. This should replace the O(n) + # case with an O(1) hash map lookup, assuming bash is implemented + # well :D. + local varSlice="$var[*]" + # ''${..-} to hack around old bash empty array problem + case "''${!varSlice-}" in + *" $pkg "*) return 0 ;; + esac + unset -v varSlice + + eval "$var"'+=("$pkg")' + + if ! [ -e "$pkg" ]; then + echo "build input $pkg does not exist" >&2 + exit 1 + fi + + local file + for file in "''${propagatedBuildInputsFiles[@]}"; do + file="$pkg/nix-support/$file" + [[ -f "$file" ]] || continue + + local pkgNext + for pkgNext in $(< "$file"); do + findInputsOld "$pkgNext" "$var" "''${propagatedBuildInputsFiles[@]}" + done + done + } + mkdir -p $out/bin + mkdir -p $out/share/emacs/site-lisp ${lib.optionalString withNativeCompilation '' - linkPath "$1" "share/emacs/native-lisp" "share/emacs/native-lisp" + mkdir -p $out/share/emacs/native-lisp ''} ${lib.optionalString withTreeSitter '' - linkPath "$1" "lib" "lib" + mkdir -p $out/lib + ''} + + local requires + for pkg in $explicitRequires; do + findInputsOld $pkg requires propagated-user-env-packages + done + # requires now holds all requested packages and their transitive dependencies + + linkPath() { + local pkg=$1 + local origin_path=$2 + local dest_path=$3 + + # Add the path to the search path list, but only if it exists + if [[ -d "$pkg/$origin_path" ]]; then + $lndir/bin/lndir -silent "$pkg/$origin_path" "$out/$dest_path" + fi + } + + linkEmacsPackage() { + linkPath "$1" "bin" "bin" + linkPath "$1" "share/emacs/site-lisp" "share/emacs/site-lisp" + ${lib.optionalString withNativeCompilation '' + linkPath "$1" "share/emacs/native-lisp" "share/emacs/native-lisp" + ''} + ${lib.optionalString withTreeSitter '' + linkPath "$1" "lib" "lib" + ''} + } + + # Iterate over the array of inputs (avoiding nix's own interpolation) + for pkg in "''${requires[@]}"; do + linkEmacsPackage $pkg + done + + siteStart="$out/share/emacs/site-lisp/site-start.el" + siteStartByteCompiled="$siteStart"c + subdirs="$out/share/emacs/site-lisp/subdirs.el" + subdirsByteCompiled="$subdirs"c + + # A dependency may have brought the original siteStart or subdirs, delete + # it and create our own + # Begin the new site-start.el by loading the original, which sets some + # NixOS-specific paths. Paths are searched in the reverse of the order + # they are specified in, so user and system profile paths are searched last. + # + # NOTE: Avoid displaying messages early at startup by binding + # inhibit-message to t. This would prevent the Emacs GUI from showing up + # prematurely. The messages would still be logged to the *Messages* + # buffer. + rm -f $siteStart $siteStartByteCompiled $subdirs $subdirsByteCompiled + cat >"$siteStart" < "$subdirs" + + # Byte-compiling improves start-up time only slightly, but costs nothing. + $emacs/bin/emacs --batch -f batch-byte-compile "$siteStart" "$subdirs" + + ${lib.optionalString withNativeCompilation '' + $emacs/bin/emacs --batch \ + --eval "(add-to-list 'native-comp-eln-load-path \"$out/share/emacs/native-lisp/\")" \ + -f batch-native-compile "$siteStart" "$subdirs" ''} - } - - # Iterate over the array of inputs (avoiding nix's own interpolation) - for pkg in "''${requires[@]}"; do - linkEmacsPackage $pkg - done - - siteStart="$out/share/emacs/site-lisp/site-start.el" - siteStartByteCompiled="$siteStart"c - subdirs="$out/share/emacs/site-lisp/subdirs.el" - subdirsByteCompiled="$subdirs"c - - # A dependency may have brought the original siteStart or subdirs, delete - # it and create our own - # Begin the new site-start.el by loading the original, which sets some - # NixOS-specific paths. Paths are searched in the reverse of the order - # they are specified in, so user and system profile paths are searched last. - # - # NOTE: Avoid displaying messages early at startup by binding - # inhibit-message to t. This would prevent the Emacs GUI from showing up - # prematurely. The messages would still be logged to the *Messages* - # buffer. - rm -f $siteStart $siteStartByteCompiled $subdirs $subdirsByteCompiled - cat >"$siteStart" < "$subdirs" - - # Byte-compiling improves start-up time only slightly, but costs nothing. - $emacs/bin/emacs --batch -f batch-byte-compile "$siteStart" "$subdirs" - - ${lib.optionalString withNativeCompilation '' - $emacs/bin/emacs --batch \ - --eval "(add-to-list 'native-comp-eln-load-path \"$out/share/emacs/native-lisp/\")" \ - -f batch-native-compile "$siteStart" "$subdirs" - ''} - ''; + ''; inherit (emacs) meta; } diff --git a/pkgs/applications/editors/emacs/default.nix b/pkgs/applications/editors/emacs/default.nix index faf06ca843c7f0..2801a660f3125c 100644 --- a/pkgs/applications/editors/emacs/default.nix +++ b/pkgs/applications/editors/emacs/default.nix @@ -1,21 +1,35 @@ { lib, pkgs }: -lib.makeScope pkgs.newScope (self: +lib.makeScope pkgs.newScope ( + self: let inherit (self) callPackage; inheritedArgs = { inherit (pkgs.darwin) sigtool; inherit (pkgs.darwin.apple_sdk.frameworks) - Accelerate AppKit Carbon Cocoa GSS ImageCaptureCore ImageIO IOKit OSAKit - Quartz QuartzCore WebKit; + Accelerate + AppKit + Carbon + Cocoa + GSS + ImageCaptureCore + ImageIO + IOKit + OSAKit + Quartz + QuartzCore + WebKit + ; inherit (pkgs.darwin.apple_sdk_11_0.frameworks) UniformTypeIdentifiers; }; - in { + in + { sources = import ./sources.nix { inherit lib; inherit (pkgs) fetchFromBitbucket - fetchFromSavannah; + fetchFromSavannah + ; }; emacs28 = callPackage (self.sources.emacs28) inheritedArgs; @@ -24,9 +38,11 @@ lib.makeScope pkgs.newScope (self: withGTK3 = true; }; - emacs28-nox = pkgs.lowPrio (self.emacs28.override { - noGui = true; - }); + emacs28-nox = pkgs.lowPrio ( + self.emacs28.override { + noGui = true; + } + ); emacs29 = callPackage (self.sources.emacs29) inheritedArgs; @@ -59,4 +75,5 @@ lib.makeScope pkgs.newScope (self: emacs28-macport = callPackage (self.sources.emacs28-macport) inheritedArgs; emacs29-macport = callPackage (self.sources.emacs29-macport) inheritedArgs; - }) + } +) diff --git a/pkgs/applications/editors/emacs/elisp-packages/fetchelpa.nix b/pkgs/applications/editors/emacs/elisp-packages/fetchelpa.nix index f4524f3b7a95bb..1f76abd232e57f 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/fetchelpa.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/fetchelpa.nix @@ -7,15 +7,19 @@ { fetchurl, lzip }: -{ url, ... }@args: fetchurl ((removeAttrs args [ "url" ]) // { - urls = [ - url - (url + ".lz") - ]; - postFetch = '' - if [[ $url == *.lz ]]; then - ${lzip}/bin/lzip -c -d $out > uncompressed - mv uncompressed $out - fi - ''; -}) +{ url, ... }@args: +fetchurl ( + (removeAttrs args [ "url" ]) + // { + urls = [ + url + (url + ".lz") + ]; + postFetch = '' + if [[ $url == *.lz ]]; then + ${lzip}/bin/lzip -c -d $out > uncompressed + mv uncompressed $out + fi + ''; + } +) diff --git a/pkgs/applications/editors/emacs/elisp-packages/libgenerated.nix b/pkgs/applications/editors/emacs/elisp-packages/libgenerated.nix index 1a2a138b206af2..bccc26776c32e3 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/libgenerated.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/libgenerated.nix @@ -52,9 +52,10 @@ let (fetchgit { rev = commit; inherit sha256 url; - }).overrideAttrs(_: { - GIT_SSL_NO_VERIFY = true; - }) + }).overrideAttrs + (_: { + GIT_SSL_NO_VERIFY = true; + }) ); bitbucket = @@ -107,50 +108,61 @@ let }; }; -in { +in +{ - melpaDerivation = variant: - { ename, fetcher - , commit ? null - , sha256 ? null - , ... }@args: - let - sourceArgs = args.${variant}; - version = sourceArgs.version or null; - deps = sourceArgs.deps or null; - error = sourceArgs.error or args.error or null; - hasSource = lib.hasAttr variant args; - pname = builtins.replaceStrings [ "@" ] [ "at" ] ename; - broken = error != null; - in - if hasSource then - lib.nameValuePair ename ( - self.callPackage ({ melpaBuild, fetchurl, ... }@pkgargs: + melpaDerivation = + variant: + { + ename, + fetcher, + commit ? null, + sha256 ? null, + ... + }@args: + let + sourceArgs = args.${variant}; + version = sourceArgs.version or null; + deps = sourceArgs.deps or null; + error = sourceArgs.error or args.error or null; + hasSource = lib.hasAttr variant args; + pname = builtins.replaceStrings [ "@" ] [ "at" ] ename; + broken = error != null; + in + if hasSource then + lib.nameValuePair ename ( + self.callPackage ( + { melpaBuild, fetchurl, ... }@pkgargs: melpaBuild { inherit pname ename; inherit (sourceArgs) commit; - version = lib.optionalString (version != null) - (lib.concatStringsSep "." (map toString - # Hack: Melpa archives contains versions with parse errors such as [ 4 4 -4 413 ] which should be 4.4-413 - # This filter method is still technically wrong, but it's computationally cheap enough and tapers over the issue - (builtins.filter (n: n >= 0) version))); + version = lib.optionalString (version != null) ( + lib.concatStringsSep "." ( + map toString + # Hack: Melpa archives contains versions with parse errors such as [ 4 4 -4 413 ] which should be 4.4-413 + # This filter method is still technically wrong, but it's computationally cheap enough and tapers over the issue + (builtins.filter (n: n >= 0) version) + ) + ); # TODO: Broken should not result in src being null (hack to avoid eval errors) - src = if (sha256 == null || broken) then null else - fetchers.${fetcher} args sourceArgs; - recipe = if commit == null then null else - fetchurl { - name = pname + "-recipe"; - url = "https://raw.githubusercontent.com/melpa/melpa/${commit}/recipes/${ename}"; - inherit sha256; - }; - packageRequires = lib.optionals (deps != null) - (map (dep: pkgargs.${dep} or self.${dep} or null) - deps); - meta = (sourceArgs.meta or {}) // { + src = if (sha256 == null || broken) then null else fetchers.${fetcher} args sourceArgs; + recipe = + if commit == null then + null + else + fetchurl { + name = pname + "-recipe"; + url = "https://raw.githubusercontent.com/melpa/melpa/${commit}/recipes/${ename}"; + inherit sha256; + }; + packageRequires = lib.optionals (deps != null) ( + map (dep: pkgargs.${dep} or self.${dep} or null) deps + ); + meta = (sourceArgs.meta or { }) // { inherit broken; }; } - ) {} + ) { } ) else null; diff --git a/pkgs/applications/editors/emacs/elisp-packages/manual-packages.nix b/pkgs/applications/editors/emacs/elisp-packages/manual-packages.nix index 2186fede2562c0..ecb597cfc97330 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/manual-packages.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/manual-packages.nix @@ -16,7 +16,13 @@ lib.packagesFromDirectoryRecursive { }; lsp-bridge = callPackage ./manual-packages/lsp-bridge { - inherit (pkgs) basedpyright git go gopls python3; + inherit (pkgs) + basedpyright + git + go + gopls + python3 + ; }; structured-haskell-mode = self.shm; diff --git a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/cedille/default.nix b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/cedille/default.nix index e9a5e9128810b1..cb514eef5347df 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/cedille/default.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/cedille/default.nix @@ -1,6 +1,7 @@ -{ stdenv -, cedille -, emacs +{ + stdenv, + cedille, + emacs, }: stdenv.mkDerivation { @@ -27,7 +28,11 @@ stdenv.mkDerivation { meta = { inherit (cedille.meta) - homepage license maintainers platforms; + homepage + license + maintainers + platforms + ; description = "Emacs major mode for Cedille"; }; } diff --git a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/idris2-mode/package.nix b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/idris2-mode/package.nix index 2a7b7b571d12e2..52f82935717dd9 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/idris2-mode/package.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/idris2-mode/package.nix @@ -30,6 +30,9 @@ melpaBuild { homepage = "https://github.com/idris-community/idris2-mode"; description = "Emacs mode for editing Idris 2 code"; license = lib.licenses.gpl3Only; - maintainers = with lib.maintainers; [ wuyoli AndersonTorres ]; + maintainers = with lib.maintainers; [ + wuyoli + AndersonTorres + ]; }; } diff --git a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/isearch-prop/package.nix b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/isearch-prop/package.nix index f8c2a6c6aafe2b..4b893e5b98fd4b 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/isearch-prop/package.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/isearch-prop/package.nix @@ -22,6 +22,9 @@ melpaBuild { homepage = "https://www.emacswiki.org/emacs/IsearchPlus"; description = "Search text- or overlay-property contexts"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ leungbk AndersonTorres ]; + maintainers = with lib.maintainers; [ + leungbk + AndersonTorres + ]; }; } diff --git a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/pod-mode/package.nix b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/pod-mode/package.nix index f6ec8048715cee..bf6d2aef72ce97 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/pod-mode/package.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/pod-mode/package.nix @@ -1,7 +1,7 @@ { lib, melpaBuild, - fetchurl + fetchurl, }: let diff --git a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/tree-sitter-langs/default.nix b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/tree-sitter-langs/default.nix index 5f04332db117f1..902e8f1721bfe4 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/tree-sitter-langs/default.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/tree-sitter-langs/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, melpaStablePackages -, runCommand -, tree-sitter-grammars -, plugins ? map (g: tree-sitter-grammars.${g}) (lib.importJSON ./default-grammars.json) -, final +{ + lib, + stdenv, + melpaStablePackages, + runCommand, + tree-sitter-grammars, + plugins ? map (g: tree-sitter-grammars.${g}) (lib.importJSON ./default-grammars.json), + final, }: let @@ -13,38 +14,44 @@ let langName = g: lib.removeSuffix "-grammar" (lib.removePrefix "tree-sitter-" g.pname); soName = g: langName g + stdenv.hostPlatform.extensions.sharedLibrary; - grammarDir = runCommand "emacs-tree-sitter-grammars" { - # Fake same version number as upstream language bundle to prevent triggering runtime downloads - inherit (tree-sitter-langs) version; - } ('' - install -d $out/langs/bin - echo -n $version > $out/langs/bin/BUNDLE-VERSION - '' + lib.concatStringsSep "\n" (map ( - g: "ln -s ${g}/parser $out/langs/bin/${soName g}") plugins - )); + grammarDir = + runCommand "emacs-tree-sitter-grammars" + { + # Fake same version number as upstream language bundle to prevent triggering runtime downloads + inherit (tree-sitter-langs) version; + } + ( + '' + install -d $out/langs/bin + echo -n $version > $out/langs/bin/BUNDLE-VERSION + '' + + lib.concatStringsSep "\n" (map (g: "ln -s ${g}/parser $out/langs/bin/${soName g}") plugins) + ); siteDir = "$out/share/emacs/site-lisp/elpa/${tree-sitter-langs.pname}-${tree-sitter-langs.version}"; in -melpaStablePackages.tree-sitter-langs.overrideAttrs(old: { - postPatch = old.postPatch or "" + '' - substituteInPlace ./tree-sitter-langs-build.el \ - --replace "tree-sitter-langs-grammar-dir tree-sitter-langs--dir" "tree-sitter-langs-grammar-dir \"${grammarDir}/langs\"" - ''; +melpaStablePackages.tree-sitter-langs.overrideAttrs (old: { + postPatch = + old.postPatch or "" + + '' + substituteInPlace ./tree-sitter-langs-build.el \ + --replace "tree-sitter-langs-grammar-dir tree-sitter-langs--dir" "tree-sitter-langs-grammar-dir \"${grammarDir}/langs\"" + ''; postInstall = old.postInstall or "" - + lib.concatStringsSep "\n" - (map - (g: '' - if [[ -d "${g}/queries" ]]; then - mkdir -p ${siteDir}/queries/${langName g}/ - for f in ${g}/queries/*; do - ln -sfn "$f" ${siteDir}/queries/${langName g}/ - done - fi - '') plugins); + + lib.concatStringsSep "\n" ( + map (g: '' + if [[ -d "${g}/queries" ]]; then + mkdir -p ${siteDir}/queries/${langName g}/ + for f in ${g}/queries/*; do + ln -sfn "$f" ${siteDir}/queries/${langName g}/ + done + fi + '') plugins + ); - passthru = old.passthru or {} // { + passthru = old.passthru or { } // { inherit plugins; withPlugins = fn: final.tree-sitter-langs.override { plugins = fn tree-sitter-grammars; }; }; diff --git a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/treesit-grammars/package.nix b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/treesit-grammars/package.nix index af720337ff05e7..30a536e3d4e5e8 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/treesit-grammars/package.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/treesit-grammars/package.nix @@ -2,16 +2,16 @@ let libExt = pkgs.stdenv.hostPlatform.extensions.sharedLibrary; - grammarToAttrSet = drv: - { - name = "lib/lib${lib.strings.removeSuffix "-grammar" (lib.strings.getName drv)}${libExt}"; - path = "${drv}/parser"; - }; + grammarToAttrSet = drv: { + name = "lib/lib${lib.strings.removeSuffix "-grammar" (lib.strings.getName drv)}${libExt}"; + path = "${drv}/parser"; + }; # Usage: # treesit-grammars.with-grammars (p: [ p.tree-sitter-bash p.tree-sitter-c ... ]) - with-grammars = fn: pkgs.linkFarm "emacs-treesit-grammars" - (map grammarToAttrSet (fn pkgs.tree-sitter.builtGrammars)); + with-grammars = + fn: + pkgs.linkFarm "emacs-treesit-grammars" (map grammarToAttrSet (fn pkgs.tree-sitter.builtGrammars)); in { inherit with-grammars; diff --git a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/tsc/package.nix b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/tsc/package.nix index bf23d0caf9df0a..c3fafdf27a1333 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/tsc/package.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/tsc/package.nix @@ -1,9 +1,10 @@ -{ lib -, melpaBuild -, fetchFromGitHub -, rustPlatform -, stdenv -, nix-update-script +{ + lib, + melpaBuild, + fetchFromGitHub, + rustPlatform, + stdenv, + nix-update-script, }: let @@ -36,7 +37,8 @@ let popd ''; }; -in melpaBuild { +in +melpaBuild { pname = "tsc"; inherit (tsc-dyn) version src; diff --git a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/xapian-lite/package.nix b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/xapian-lite/package.nix index afd1ddb0fbebd5..754eb9fa926c16 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/manual-packages/xapian-lite/package.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/manual-packages/xapian-lite/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, emacs, fetchFromSourcehut, xapian }: +{ + lib, + stdenv, + emacs, + fetchFromSourcehut, + xapian, +}: stdenv.mkDerivation (finalAttrs: { pname = "xapian-lite"; @@ -16,7 +22,10 @@ stdenv.mkDerivation (finalAttrs: { rm emacs-module.h ''; - buildInputs = [ xapian emacs ]; + buildInputs = [ + xapian + emacs + ]; installPhase = '' runHook preInstall diff --git a/pkgs/applications/editors/emacs/elisp-packages/update-manual.nix b/pkgs/applications/editors/emacs/elisp-packages/update-manual.nix index 788d096e6ec694..ff14c7a29de76e 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/update-manual.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/update-manual.nix @@ -3,9 +3,18 @@ let config.allowBroken = true; }; inherit (pkgs) lib emacs; - inherit (lib) isDerivation hasAttr filterAttrs mapAttrs attrValues; + inherit (lib) + isDerivation + hasAttr + filterAttrs + mapAttrs + attrValues + ; # Extract updateScript's from manually package emacs packages - hasScript = filterAttrs (_: v: isDerivation v && hasAttr "updateScript" v) emacs.pkgs.manualPackages; + hasScript = filterAttrs ( + _: v: isDerivation v && hasAttr "updateScript" v + ) emacs.pkgs.manualPackages; -in attrValues (mapAttrs (_: v: v.updateScript) hasScript) +in +attrValues (mapAttrs (_: v: v.updateScript) hasScript) diff --git a/pkgs/applications/editors/emacs/elisp-packages/updater-emacs.nix b/pkgs/applications/editors/emacs/elisp-packages/updater-emacs.nix index 824567318f2235..9356a9e3d0c1ae 100644 --- a/pkgs/applications/editors/emacs/elisp-packages/updater-emacs.nix +++ b/pkgs/applications/editors/emacs/elisp-packages/updater-emacs.nix @@ -1,39 +1,47 @@ let - pkgs = import ../../../../.. {}; + pkgs = import ../../../../.. { }; - emacsEnv = pkgs.emacs.pkgs.withPackages (epkgs: let + emacsEnv = pkgs.emacs.pkgs.withPackages ( + epkgs: + let - promise = epkgs.melpaBuild { - pname = "promise"; - version = "0-unstable-2019-06-07"; + promise = epkgs.melpaBuild { + pname = "promise"; + version = "0-unstable-2019-06-07"; - src = pkgs.fetchFromGitHub { - owner = "bendlas"; - repo = "emacs-promise"; - rev = "4da97087c5babbd8429b5ce62a8323b9b03c6022"; - hash = "sha256-XsvPsA/lUzPWyJAdJg9XtD/vLDtk7guG7p+8ZOQ8Nno="; + src = pkgs.fetchFromGitHub { + owner = "bendlas"; + repo = "emacs-promise"; + rev = "4da97087c5babbd8429b5ce62a8323b9b03c6022"; + hash = "sha256-XsvPsA/lUzPWyJAdJg9XtD/vLDtk7guG7p+8ZOQ8Nno="; + }; + + packageRequires = [ epkgs.async ]; }; - packageRequires = [ epkgs.async ]; - }; + semaphore = epkgs.melpaBuild { + pname = "semaphore"; + version = "0-unstable-2019-06-07"; - semaphore = epkgs.melpaBuild { - pname = "semaphore"; - version = "0-unstable-2019-06-07"; + src = pkgs.fetchFromGitHub { + owner = "webnf"; + repo = "semaphore.el"; + rev = "93802cb093073bc6a6ccd797328dafffcef248e0"; + hash = "sha256-o6B5oaGGxwQOCoTIXrQre4veT6Mwqw7I2LqMesT17iY="; + }; - src = pkgs.fetchFromGitHub { - owner = "webnf"; - repo = "semaphore.el"; - rev = "93802cb093073bc6a6ccd797328dafffcef248e0"; - hash = "sha256-o6B5oaGGxwQOCoTIXrQre4veT6Mwqw7I2LqMesT17iY="; + packageRequires = [ promise ]; }; - packageRequires = [ promise ]; - }; - - in [ promise semaphore ]); + in + [ + promise + semaphore + ] + ); -in pkgs.mkShell { +in +pkgs.mkShell { packages = [ pkgs.git pkgs.bash diff --git a/pkgs/applications/editors/emacs/make-emacs.nix b/pkgs/applications/editors/emacs/make-emacs.nix index 7bae78f35e70ef..63f4d1e59cb51a 100644 --- a/pkgs/applications/editors/emacs/make-emacs.nix +++ b/pkgs/applications/editors/emacs/make-emacs.nix @@ -1,117 +1,128 @@ -{ pname -, version -, variant -, src -, patches ? _: [ ] -, meta +{ + pname, + version, + variant, + src, + patches ? _: [ ], + meta, }: -{ lib -, stdenv -, Xaw3d -, acl -, alsa-lib -, autoreconfHook -, cairo -, dbus -, emacsPackagesFor -, fetchpatch -, gettext -, giflib -, glib-networking -, gnutls -, gpm -, gsettings-desktop-schemas -, gtk3 -, gtk3-x11 -, harfbuzz -, imagemagick -, jansson -, libXaw -, libXcursor -, libXi -, libXpm -, libgccjit -, libjpeg -, libotf -, libpng -, librsvg -, libselinux -, libtiff -, libwebp -, libxml2 -, llvmPackages_14 -, m17n_lib -, mailutils -, makeWrapper -, motif -, ncurses -, nixosTests -, pkg-config -, recurseIntoAttrs -, sigtool -, sqlite -, substituteAll -, systemd -, tree-sitter -, texinfo -, webkitgtk_4_0 -, wrapGAppsHook3 -, zlib +{ + lib, + stdenv, + Xaw3d, + acl, + alsa-lib, + autoreconfHook, + cairo, + dbus, + emacsPackagesFor, + fetchpatch, + gettext, + giflib, + glib-networking, + gnutls, + gpm, + gsettings-desktop-schemas, + gtk3, + gtk3-x11, + harfbuzz, + imagemagick, + jansson, + libXaw, + libXcursor, + libXi, + libXpm, + libgccjit, + libjpeg, + libotf, + libpng, + librsvg, + libselinux, + libtiff, + libwebp, + libxml2, + llvmPackages_14, + m17n_lib, + mailutils, + makeWrapper, + motif, + ncurses, + nixosTests, + pkg-config, + recurseIntoAttrs, + sigtool, + sqlite, + substituteAll, + systemd, + tree-sitter, + texinfo, + webkitgtk_4_0, + wrapGAppsHook3, + zlib, -# Boolean flags -, withNativeCompilation ? stdenv.buildPlatform.canExecute stdenv.hostPlatform -, noGui ? false -, srcRepo ? true -, withAcl ? false -, withAlsaLib ? false -, withAthena ? false -, withCsrc ? true -, withDbus ? stdenv.hostPlatform.isLinux -, withGTK3 ? withPgtk && !noGui -, withGlibNetworking ? withPgtk || withGTK3 || (withX && withXwidgets) -, withGpm ? stdenv.hostPlatform.isLinux -, withImageMagick ? lib.versionOlder version "27" && (withX || withNS) -# Emacs 30+ has native JSON support -, withJansson ? lib.versionOlder version "30" -, withMailutils ? true -, withMotif ? false -, withNS ? stdenv.hostPlatform.isDarwin && !(variant == "macport" || noGui) -, withPgtk ? false -, withSelinux ? stdenv.hostPlatform.isLinux -, withSQLite3 ? lib.versionAtLeast version "29" -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, withToolkitScrollBars ? true -, withTreeSitter ? lib.versionAtLeast version "29" -, withWebP ? lib.versionAtLeast version "29" -, withX ? !(stdenv.hostPlatform.isDarwin || noGui || withPgtk) -, withXinput2 ? withX && lib.versionAtLeast version "29" -, withXwidgets ? !stdenv.hostPlatform.isDarwin && !noGui && (withGTK3 || withPgtk) && (lib.versionOlder version "30") # XXX: upstream bug 66068 precludes newer versions of webkit2gtk (https://lists.gnu.org/archive/html/bug-gnu-emacs/2024-09/msg00695.html) -, withSmallJaDic ? false -, withCompressInstall ? true + # Boolean flags + withNativeCompilation ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, + noGui ? false, + srcRepo ? true, + withAcl ? false, + withAlsaLib ? false, + withAthena ? false, + withCsrc ? true, + withDbus ? stdenv.hostPlatform.isLinux, + withGTK3 ? withPgtk && !noGui, + withGlibNetworking ? withPgtk || withGTK3 || (withX && withXwidgets), + withGpm ? stdenv.hostPlatform.isLinux, + withImageMagick ? lib.versionOlder version "27" && (withX || withNS), + # Emacs 30+ has native JSON support + withJansson ? lib.versionOlder version "30", + withMailutils ? true, + withMotif ? false, + withNS ? stdenv.hostPlatform.isDarwin && !(variant == "macport" || noGui), + withPgtk ? false, + withSelinux ? stdenv.hostPlatform.isLinux, + withSQLite3 ? lib.versionAtLeast version "29", + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + withToolkitScrollBars ? true, + withTreeSitter ? lib.versionAtLeast version "29", + withWebP ? lib.versionAtLeast version "29", + withX ? !(stdenv.hostPlatform.isDarwin || noGui || withPgtk), + withXinput2 ? withX && lib.versionAtLeast version "29", + withXwidgets ? + !stdenv.hostPlatform.isDarwin + && !noGui + && (withGTK3 || withPgtk) + && (lib.versionOlder version "30"), # XXX: upstream bug 66068 precludes newer versions of webkit2gtk (https://lists.gnu.org/archive/html/bug-gnu-emacs/2024-09/msg00695.html) + withSmallJaDic ? false, + withCompressInstall ? true, -# Options -, siteStart ? ./site-start.el -, toolkit ? ( - if withGTK3 then "gtk3" - else if withMotif then "motif" - else if withAthena then "athena" - else "lucid") + # Options + siteStart ? ./site-start.el, + toolkit ? ( + if withGTK3 then + "gtk3" + else if withMotif then + "motif" + else if withAthena then + "athena" + else + "lucid" + ), -# macOS dependencies for NS and macPort -, Accelerate -, AppKit -, Carbon -, Cocoa -, GSS -, IOKit -, ImageCaptureCore -, ImageIO -, OSAKit -, Quartz -, QuartzCore -, UniformTypeIdentifiers -, WebKit + # macOS dependencies for NS and macPort + Accelerate, + AppKit, + Carbon, + Cocoa, + GSS, + IOKit, + ImageCaptureCore, + ImageIO, + OSAKit, + Quartz, + QuartzCore, + UniformTypeIdentifiers, + WebKit, }: assert (withGTK3 && !withNS && variant != "macport") -> withX || withPgtk; @@ -125,47 +136,68 @@ assert withPgtk -> withGTK3 && !withX; assert withXwidgets -> !noGui && (withGTK3 || withPgtk); let - libGccJitLibraryPaths = [ - "${lib.getLib libgccjit}/lib/gcc" - "${lib.getLib stdenv.cc.libc}/lib" - ] ++ lib.optionals (stdenv.cc?cc.lib.libgcc) [ - "${lib.getLib stdenv.cc.cc.lib.libgcc}/lib" - ]; + libGccJitLibraryPaths = + [ + "${lib.getLib libgccjit}/lib/gcc" + "${lib.getLib stdenv.cc.libc}/lib" + ] + ++ lib.optionals (stdenv.cc ? cc.lib.libgcc) [ + "${lib.getLib stdenv.cc.cc.lib.libgcc}/lib" + ]; - inherit (if variant == "macport" - then llvmPackages_14.stdenv - else stdenv) mkDerivation; + inherit (if variant == "macport" then llvmPackages_14.stdenv else stdenv) + mkDerivation + ; in mkDerivation (finalAttrs: { - pname = pname - + (if noGui then "-nox" - else if variant == "macport" then "-macport" - else if withPgtk then "-pgtk" - else if withGTK3 then "-gtk3" - else ""); + pname = + pname + + ( + if noGui then + "-nox" + else if variant == "macport" then + "-macport" + else if withPgtk then + "-pgtk" + else if withGTK3 then + "-gtk3" + else + "" + ); inherit version; inherit src; - patches = patches fetchpatch ++ lib.optionals withNativeCompilation [ - (substituteAll { - src = if lib.versionOlder finalAttrs.version "29" - then ./native-comp-driver-options-28.patch - else if lib.versionOlder finalAttrs.version "30" - then ./native-comp-driver-options.patch - else ./native-comp-driver-options-30.patch; - backendPath = (lib.concatStringsSep " " - (builtins.map (x: ''"-B${x}"'') ([ - # Paths necessary so the JIT compiler finds its libraries: - "${lib.getLib libgccjit}/lib" - ] ++ libGccJitLibraryPaths ++ [ - # Executable paths necessary for compilation (ld, as): - "${lib.getBin stdenv.cc.cc}/bin" - "${lib.getBin stdenv.cc.bintools}/bin" - "${lib.getBin stdenv.cc.bintools.bintools}/bin" - ]))); - }) - ]; + patches = + patches fetchpatch + ++ lib.optionals withNativeCompilation [ + (substituteAll { + src = + if lib.versionOlder finalAttrs.version "29" then + ./native-comp-driver-options-28.patch + else if lib.versionOlder finalAttrs.version "30" then + ./native-comp-driver-options.patch + else + ./native-comp-driver-options-30.patch; + backendPath = ( + lib.concatStringsSep " " ( + builtins.map (x: ''"-B${x}"'') ( + [ + # Paths necessary so the JIT compiler finds its libraries: + "${lib.getLib libgccjit}/lib" + ] + ++ libGccJitLibraryPaths + ++ [ + # Executable paths necessary for compilation (ld, as): + "${lib.getBin stdenv.cc.cc}/bin" + "${lib.getBin stdenv.cc.bintools}/bin" + "${lib.getBin stdenv.cc.bintools.bintools}/bin" + ] + ) + ) + ); + }) + ]; postPatch = lib.concatStringsSep "\n" [ (lib.optionalString srcRepo '' @@ -175,12 +207,16 @@ mkDerivation (finalAttrs: { # Add the name of the wrapped gvfsd # This used to be carried as a patch but it often got out of sync with # upstream and was hard to maintain for emacs-overlay. - (lib.concatStrings (map (fn: '' - sed -i 's#(${fn} "gvfs-fuse-daemon")#(${fn} "gvfs-fuse-daemon") (${fn} ".gvfsd-fuse-wrapped")#' lisp/net/tramp-gvfs.el - '') [ - "tramp-compat-process-running-p" - "tramp-process-running-p" - ])) + (lib.concatStrings ( + map + (fn: '' + sed -i 's#(${fn} "gvfs-fuse-daemon")#(${fn} "gvfs-fuse-daemon") (${fn} ".gvfsd-fuse-wrapped")#' lisp/net/tramp-gvfs.el + '') + [ + "tramp-compat-process-running-p" + "tramp-process-running-p" + ] + )) # Reduce closure size by cleaning the environment of the emacs dumper '' @@ -200,105 +236,136 @@ mkDerivation (finalAttrs: { "" ]; - nativeBuildInputs = [ - makeWrapper - pkg-config - ] ++ lib.optionals (variant == "macport") [ - texinfo - ] ++ lib.optionals srcRepo [ - autoreconfHook - texinfo - ] ++ lib.optionals (withPgtk || withX && (withGTK3 || withXwidgets)) [ wrapGAppsHook3 ]; + nativeBuildInputs = + [ + makeWrapper + pkg-config + ] + ++ lib.optionals (variant == "macport") [ + texinfo + ] + ++ lib.optionals srcRepo [ + autoreconfHook + texinfo + ] + ++ lib.optionals (withPgtk || withX && (withGTK3 || withXwidgets)) [ wrapGAppsHook3 ]; - buildInputs = [ - gettext - gnutls - (lib.getDev harfbuzz) - ] ++ lib.optionals withJansson [ - jansson - ] ++ [ - libxml2 - ncurses - ] ++ lib.optionals withAcl [ - acl - ] ++ lib.optionals withAlsaLib [ - alsa-lib - ] ++ lib.optionals withGpm [ - gpm - ] ++ lib.optionals withDbus [ - dbus - ] ++ lib.optionals withSelinux [ - libselinux - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin && withGTK3) [ - gsettings-desktop-schemas - ] ++ lib.optionals (stdenv.hostPlatform.isLinux && withX) [ - libotf - m17n_lib - ] ++ lib.optionals (withX && withGTK3) [ - gtk3-x11 - ] ++ lib.optionals (withX && withMotif) [ - motif - ] ++ lib.optionals withGlibNetworking [ - glib-networking - ] ++ lib.optionals withNativeCompilation [ - libgccjit - zlib - ] ++ lib.optionals withImageMagick [ - imagemagick - ] ++ lib.optionals withPgtk [ - giflib - gtk3 - libXpm - libjpeg - libpng - librsvg - libtiff - ] ++ lib.optionals withSQLite3 [ - sqlite - ] ++ lib.optionals withSystemd [ - systemd - ] ++ lib.optionals withTreeSitter [ - tree-sitter - ] ++ lib.optionals withWebP [ - libwebp - ] ++ lib.optionals withX [ - Xaw3d - cairo - giflib - libXaw - libXpm - libjpeg - libpng - librsvg - libtiff - ] ++ lib.optionals withXinput2 [ - libXi - ] ++ lib.optionals withXwidgets [ - webkitgtk_4_0 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - sigtool - ] ++ lib.optionals withNS [ - librsvg - AppKit - GSS - ImageIO - ] ++ lib.optionals (variant == "macport") [ - Accelerate - AppKit - Carbon - Cocoa - IOKit - OSAKit - Quartz - QuartzCore - WebKit - # TODO are these optional? - GSS - ImageCaptureCore - ImageIO - ] ++ lib.optionals (variant == "macport" && stdenv.hostPlatform.isAarch64) [ - UniformTypeIdentifiers - ]; + buildInputs = + [ + gettext + gnutls + (lib.getDev harfbuzz) + ] + ++ lib.optionals withJansson [ + jansson + ] + ++ [ + libxml2 + ncurses + ] + ++ lib.optionals withAcl [ + acl + ] + ++ lib.optionals withAlsaLib [ + alsa-lib + ] + ++ lib.optionals withGpm [ + gpm + ] + ++ lib.optionals withDbus [ + dbus + ] + ++ lib.optionals withSelinux [ + libselinux + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin && withGTK3) [ + gsettings-desktop-schemas + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && withX) [ + libotf + m17n_lib + ] + ++ lib.optionals (withX && withGTK3) [ + gtk3-x11 + ] + ++ lib.optionals (withX && withMotif) [ + motif + ] + ++ lib.optionals withGlibNetworking [ + glib-networking + ] + ++ lib.optionals withNativeCompilation [ + libgccjit + zlib + ] + ++ lib.optionals withImageMagick [ + imagemagick + ] + ++ lib.optionals withPgtk [ + giflib + gtk3 + libXpm + libjpeg + libpng + librsvg + libtiff + ] + ++ lib.optionals withSQLite3 [ + sqlite + ] + ++ lib.optionals withSystemd [ + systemd + ] + ++ lib.optionals withTreeSitter [ + tree-sitter + ] + ++ lib.optionals withWebP [ + libwebp + ] + ++ lib.optionals withX [ + Xaw3d + cairo + giflib + libXaw + libXpm + libjpeg + libpng + librsvg + libtiff + ] + ++ lib.optionals withXinput2 [ + libXi + ] + ++ lib.optionals withXwidgets [ + webkitgtk_4_0 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + sigtool + ] + ++ lib.optionals withNS [ + librsvg + AppKit + GSS + ImageIO + ] + ++ lib.optionals (variant == "macport") [ + Accelerate + AppKit + Carbon + Cocoa + IOKit + OSAKit + Quartz + QuartzCore + WebKit + # TODO are these optional? + GSS + ImageCaptureCore + ImageIO + ] + ++ lib.optionals (variant == "macport" && stdenv.hostPlatform.isAarch64) [ + UniformTypeIdentifiers + ]; # Emacs needs to find movemail at run time, see info (emacs) Movemail propagatedUserEnvPkgs = lib.optionals withMailutils [ @@ -307,101 +374,122 @@ mkDerivation (finalAttrs: { hardeningDisable = [ "format" ]; - configureFlags = [ - (lib.enableFeature false "build-details") # for a (more) reproducible build - (lib.withFeature true "modules") - ] ++ (if withNS then [ - (lib.enableFeature false "ns-self-contained") - ] else if withX then [ - (lib.withFeatureAs true "x-toolkit" toolkit) - (lib.withFeature true "cairo") - (lib.withFeature true "xft") - ] else if withPgtk then [ - (lib.withFeature true "pgtk") - ] else [ - (lib.withFeature false "gif") - (lib.withFeature false "jpeg") - (lib.withFeature false "png") - (lib.withFeature false "tiff") - (lib.withFeature false "x") - (lib.withFeature false "xpm") - ]) - ++ lib.optionals (variant == "macport") [ - (lib.enableFeatureAs true "mac-app" "$$out/Applications") - (lib.withFeature true "gnutls") - (lib.withFeature true "mac") - (lib.withFeature true "xml2") - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - (lib.withFeature withNS "ns") - ] - ++ [ - (lib.withFeature withCompressInstall "compress-install") - (lib.withFeature withToolkitScrollBars "toolkit-scroll-bars") - (lib.withFeature withNativeCompilation "native-compilation") - (lib.withFeature withImageMagick "imagemagick") - (lib.withFeature withMailutils "mailutils") - (lib.withFeature withSmallJaDic "small-ja-dic") - (lib.withFeature withTreeSitter "tree-sitter") - (lib.withFeature withXinput2 "xinput2") - (lib.withFeature withXwidgets "xwidgets") - (lib.withFeature withDbus "dbus") - (lib.withFeature withSelinux "selinux") - ]; + configureFlags = + [ + (lib.enableFeature false "build-details") # for a (more) reproducible build + (lib.withFeature true "modules") + ] + ++ ( + if withNS then + [ + (lib.enableFeature false "ns-self-contained") + ] + else if withX then + [ + (lib.withFeatureAs true "x-toolkit" toolkit) + (lib.withFeature true "cairo") + (lib.withFeature true "xft") + ] + else if withPgtk then + [ + (lib.withFeature true "pgtk") + ] + else + [ + (lib.withFeature false "gif") + (lib.withFeature false "jpeg") + (lib.withFeature false "png") + (lib.withFeature false "tiff") + (lib.withFeature false "x") + (lib.withFeature false "xpm") + ] + ) + ++ lib.optionals (variant == "macport") [ + (lib.enableFeatureAs true "mac-app" "$$out/Applications") + (lib.withFeature true "gnutls") + (lib.withFeature true "mac") + (lib.withFeature true "xml2") + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + (lib.withFeature withNS "ns") + ] + ++ [ + (lib.withFeature withCompressInstall "compress-install") + (lib.withFeature withToolkitScrollBars "toolkit-scroll-bars") + (lib.withFeature withNativeCompilation "native-compilation") + (lib.withFeature withImageMagick "imagemagick") + (lib.withFeature withMailutils "mailutils") + (lib.withFeature withSmallJaDic "small-ja-dic") + (lib.withFeature withTreeSitter "tree-sitter") + (lib.withFeature withXinput2 "xinput2") + (lib.withFeature withXwidgets "xwidgets") + (lib.withFeature withDbus "dbus") + (lib.withFeature withSelinux "selinux") + ]; - env = lib.optionalAttrs withNativeCompilation { - NATIVE_FULL_AOT = "1"; - LIBRARY_PATH = lib.concatStringsSep ":" libGccJitLibraryPaths; - } // lib.optionalAttrs (variant == "macport") { - # Fixes intermittent segfaults when compiled with LLVM >= 7.0. - # See https://github.com/NixOS/nixpkgs/issues/127902 - NIX_CFLAGS_COMPILE = "-include ${./macport_noescape_noop.h}"; - }; + env = + lib.optionalAttrs withNativeCompilation { + NATIVE_FULL_AOT = "1"; + LIBRARY_PATH = lib.concatStringsSep ":" libGccJitLibraryPaths; + } + // lib.optionalAttrs (variant == "macport") { + # Fixes intermittent segfaults when compiled with LLVM >= 7.0. + # See https://github.com/NixOS/nixpkgs/issues/127902 + NIX_CFLAGS_COMPILE = "-include ${./macport_noescape_noop.h}"; + }; enableParallelBuilding = true; - installTargets = [ "tags" "install" ]; + installTargets = [ + "tags" + "install" + ]; - postInstall = '' - mkdir -p $out/share/emacs/site-lisp - cp ${siteStart} $out/share/emacs/site-lisp/site-start.el + postInstall = + '' + mkdir -p $out/share/emacs/site-lisp + cp ${siteStart} $out/share/emacs/site-lisp/site-start.el - $out/bin/emacs --batch -f batch-byte-compile $out/share/emacs/site-lisp/site-start.el + $out/bin/emacs --batch -f batch-byte-compile $out/share/emacs/site-lisp/site-start.el - siteVersionDir=`ls $out/share/emacs | grep -v site-lisp | head -n 1` + siteVersionDir=`ls $out/share/emacs | grep -v site-lisp | head -n 1` - rm -r $out/share/emacs/$siteVersionDir/site-lisp - '' + lib.optionalString withCsrc '' - for srcdir in src lisp lwlib ; do - dstdir=$out/share/emacs/$siteVersionDir/$srcdir - mkdir -p $dstdir - find $srcdir -name "*.[chm]" -exec cp {} $dstdir \; - cp $srcdir/TAGS $dstdir - echo '((nil . ((tags-file-name . "TAGS"))))' > $dstdir/.dir-locals.el - done - '' + lib.optionalString withNS '' - mkdir -p $out/Applications - mv nextstep/Emacs.app $out/Applications - '' + lib.optionalString (withNativeCompilation && (withNS || variant == "macport")) '' - ln -snf $out/lib/emacs/*/native-lisp $out/Applications/Emacs.app/Contents/native-lisp - '' + lib.optionalString withNativeCompilation '' - echo "Generating native-compiled trampolines..." - # precompile trampolines in parallel, but avoid spawning one process per trampoline. - # 1000 is a rough lower bound on the number of trampolines compiled. - $out/bin/emacs --batch --eval "(mapatoms (lambda (s) \ - (when (subr-primitive-p (symbol-function s)) (print s))))" \ - | xargs -n $((1000/NIX_BUILD_CORES + 1)) -P $NIX_BUILD_CORES \ - $out/bin/emacs --batch -l comp --eval "(while argv \ - (comp-trampoline-compile (intern (pop argv))))" - mkdir -p $out/share/emacs/native-lisp - $out/bin/emacs --batch \ - --eval "(add-to-list 'native-comp-eln-load-path \"$out/share/emacs/native-lisp\")" \ - -f batch-native-compile $out/share/emacs/site-lisp/site-start.el - ''; + rm -r $out/share/emacs/$siteVersionDir/site-lisp + '' + + lib.optionalString withCsrc '' + for srcdir in src lisp lwlib ; do + dstdir=$out/share/emacs/$siteVersionDir/$srcdir + mkdir -p $dstdir + find $srcdir -name "*.[chm]" -exec cp {} $dstdir \; + cp $srcdir/TAGS $dstdir + echo '((nil . ((tags-file-name . "TAGS"))))' > $dstdir/.dir-locals.el + done + '' + + lib.optionalString withNS '' + mkdir -p $out/Applications + mv nextstep/Emacs.app $out/Applications + '' + + lib.optionalString (withNativeCompilation && (withNS || variant == "macport")) '' + ln -snf $out/lib/emacs/*/native-lisp $out/Applications/Emacs.app/Contents/native-lisp + '' + + lib.optionalString withNativeCompilation '' + echo "Generating native-compiled trampolines..." + # precompile trampolines in parallel, but avoid spawning one process per trampoline. + # 1000 is a rough lower bound on the number of trampolines compiled. + $out/bin/emacs --batch --eval "(mapatoms (lambda (s) \ + (when (subr-primitive-p (symbol-function s)) (print s))))" \ + | xargs -n $((1000/NIX_BUILD_CORES + 1)) -P $NIX_BUILD_CORES \ + $out/bin/emacs --batch -l comp --eval "(while argv \ + (comp-trampoline-compile (intern (pop argv))))" + mkdir -p $out/share/emacs/native-lisp + $out/bin/emacs --batch \ + --eval "(add-to-list 'native-comp-eln-load-path \"$out/share/emacs/native-lisp\")" \ + -f batch-native-compile $out/share/emacs/site-lisp/site-start.el + ''; postFixup = lib.optionalString (stdenv.hostPlatform.isLinux && withX && toolkit == "lucid") '' - patchelf --add-rpath ${lib.makeLibraryPath [ libXcursor ]} $out/bin/emacs - patchelf --add-needed "libXcursor.so.1" "$out/bin/emacs" + patchelf --add-rpath ${lib.makeLibraryPath [ libXcursor ]} $out/bin/emacs + patchelf --add-needed "libXcursor.so.1" "$out/bin/emacs" ''; passthru = { diff --git a/pkgs/applications/editors/emacs/sources.nix b/pkgs/applications/editors/emacs/sources.nix index 521a3d83a0976a..f197a0d1d09cfc 100644 --- a/pkgs/applications/editors/emacs/sources.nix +++ b/pkgs/applications/editors/emacs/sources.nix @@ -1,72 +1,104 @@ -{ lib -, fetchFromBitbucket -, fetchFromSavannah +{ + lib, + fetchFromBitbucket, + fetchFromSavannah, }: let - mkArgs = { pname, version, variant, patches ? _: [ ], rev, hash }: { - inherit pname version variant patches; + mkArgs = + { + pname, + version, + variant, + patches ? _: [ ], + rev, + hash, + }: + { + inherit + pname + version + variant + patches + ; - src = { - "mainline" = (fetchFromSavannah { - repo = "emacs"; - inherit rev hash; - }); - "macport" = (fetchFromBitbucket { - owner = "mituharu"; - repo = "emacs-mac"; - inherit rev hash; - }); - }.${variant}; + src = + { + "mainline" = ( + fetchFromSavannah { + repo = "emacs"; + inherit rev hash; + } + ); + "macport" = ( + fetchFromBitbucket { + owner = "mituharu"; + repo = "emacs-mac"; + inherit rev hash; + } + ); + } + .${variant}; - meta = { - homepage = { - "mainline" = "https://www.gnu.org/software/emacs/"; - "macport" = "https://bitbucket.org/mituharu/emacs-mac/"; - }.${variant}; - description = "Extensible, customizable GNU text editor" - + lib.optionalString (variant == "macport") " - macport variant"; - longDescription = '' - GNU Emacs is an extensible, customizable text editor—and more. At its core - is an interpreter for Emacs Lisp, a dialect of the Lisp programming - language with extensions to support text editing. + meta = { + homepage = + { + "mainline" = "https://www.gnu.org/software/emacs/"; + "macport" = "https://bitbucket.org/mituharu/emacs-mac/"; + } + .${variant}; + description = + "Extensible, customizable GNU text editor" + + lib.optionalString (variant == "macport") " - macport variant"; + longDescription = + '' + GNU Emacs is an extensible, customizable text editor—and more. At its core + is an interpreter for Emacs Lisp, a dialect of the Lisp programming + language with extensions to support text editing. - The features of GNU Emacs include: content-sensitive editing modes, - including syntax coloring, for a wide variety of file types including - plain text, source code, and HTML; complete built-in documentation, - including a tutorial for new users; full Unicode support for nearly all - human languages and their scripts; highly customizable, using Emacs Lisp - code or a graphical interface; a large number of extensions that add other - functionality, including a project planner, mail and news reader, debugger - interface, calendar, and more. Many of these extensions are distributed - with GNU Emacs; others are available separately. - '' + lib.optionalString (variant == "macport") '' + The features of GNU Emacs include: content-sensitive editing modes, + including syntax coloring, for a wide variety of file types including + plain text, source code, and HTML; complete built-in documentation, + including a tutorial for new users; full Unicode support for nearly all + human languages and their scripts; highly customizable, using Emacs Lisp + code or a graphical interface; a large number of extensions that add other + functionality, including a project planner, mail and news reader, debugger + interface, calendar, and more. Many of these extensions are distributed + with GNU Emacs; others are available separately. + '' + + lib.optionalString (variant == "macport") '' - This release is built from Mitsuharu Yamamoto's patched source code - tailored for macOS. - ''; - changelog = { - "mainline" = "https://www.gnu.org/savannah-checkouts/gnu/emacs/news/NEWS.${version}"; - "macport" = "https://bitbucket.org/mituharu/emacs-mac/raw/${rev}/NEWS-mac"; - }.${variant}; - license = lib.licenses.gpl3Plus; - maintainers = { - "mainline" = with lib.maintainers; [ - AndersonTorres - adisbladis - jwiegley - lovek323 - matthewbauer - ]; - "macport" = with lib.maintainers; [ ]; - }.${variant}; - platforms = { - "mainline" = lib.platforms.all; - "macport" = lib.platforms.darwin; - }.${variant}; - mainProgram = "emacs"; + This release is built from Mitsuharu Yamamoto's patched source code + tailored for macOS. + ''; + changelog = + { + "mainline" = "https://www.gnu.org/savannah-checkouts/gnu/emacs/news/NEWS.${version}"; + "macport" = "https://bitbucket.org/mituharu/emacs-mac/raw/${rev}/NEWS-mac"; + } + .${variant}; + license = lib.licenses.gpl3Plus; + maintainers = + { + "mainline" = with lib.maintainers; [ + AndersonTorres + adisbladis + jwiegley + lovek323 + matthewbauer + ]; + "macport" = with lib.maintainers; [ ]; + } + .${variant}; + platforms = + { + "mainline" = lib.platforms.all; + "macport" = lib.platforms.darwin; + } + .${variant}; + mainProgram = "emacs"; + }; }; - }; in { emacs28 = import ./make-emacs.nix (mkArgs { diff --git a/pkgs/applications/editors/featherpad/default.nix b/pkgs/applications/editors/featherpad/default.nix index 4334a7ba1191a3..72fd7d1dac8750 100644 --- a/pkgs/applications/editors/featherpad/default.nix +++ b/pkgs/applications/editors/featherpad/default.nix @@ -1,5 +1,15 @@ -{ lib, mkDerivation, cmake, hunspell, pkg-config, qttools, qtbase, qtsvg, qtx11extras -, fetchFromGitHub }: +{ + lib, + mkDerivation, + cmake, + hunspell, + pkg-config, + qttools, + qtbase, + qtsvg, + qtx11extras, + fetchFromGitHub, +}: mkDerivation rec { pname = "featherpad"; @@ -12,8 +22,17 @@ mkDerivation rec { sha256 = "sha256-8IT/PxLz6BsLHzY5pM0bTlAO0xvfC7/aI7+Gbw2LyME="; }; - nativeBuildInputs = [ cmake pkg-config qttools ]; - buildInputs = [ hunspell qtbase qtsvg qtx11extras ]; + nativeBuildInputs = [ + cmake + pkg-config + qttools + ]; + buildInputs = [ + hunspell + qtbase + qtsvg + qtx11extras + ]; meta = with lib; { description = "Lightweight Qt5 Plain-Text Editor for Linux"; diff --git a/pkgs/applications/editors/focuswriter/default.nix b/pkgs/applications/editors/focuswriter/default.nix index 5126c7c6725e51..1319120a1991d4 100644 --- a/pkgs/applications/editors/focuswriter/default.nix +++ b/pkgs/applications/editors/focuswriter/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, cmake -, hunspell -, qtbase -, qtmultimedia -, qttools -, qt5compat -, qtwayland -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + hunspell, + qtbase, + qtmultimedia, + qttools, + qt5compat, + qtwayland, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -23,15 +24,29 @@ stdenv.mkDerivation rec { hash = "sha256-FFfNjjVwi0bE6oc8LYhXrCKd+nwRQrjWzK5P4DSIIgs="; }; - nativeBuildInputs = [ pkg-config cmake qttools wrapQtAppsHook ]; - buildInputs = [ hunspell qtbase qtmultimedia qt5compat qtwayland ]; + nativeBuildInputs = [ + pkg-config + cmake + qttools + wrapQtAppsHook + ]; + buildInputs = [ + hunspell + qtbase + qtmultimedia + qt5compat + qtwayland + ]; installFlags = [ "INSTALL_ROOT=$(out)" ]; meta = with lib; { description = "Simple, distraction-free writing environment"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ madjar kashw2 ]; + maintainers = with maintainers; [ + madjar + kashw2 + ]; platforms = platforms.linux; homepage = "https://gottcode.org/focuswriter/"; mainProgram = "focuswriter"; diff --git a/pkgs/applications/editors/geany/default.nix b/pkgs/applications/editors/geany/default.nix index 8268c7c8678977..4c98f18c4346d4 100644 --- a/pkgs/applications/editors/geany/default.nix +++ b/pkgs/applications/editors/geany/default.nix @@ -1,21 +1,28 @@ -{ lib, stdenv -, fetchurl -, gtk3 -, which -, pkg-config -, intltool -, file -, libintl -, hicolor-icon-theme -, python3 -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + gtk3, + which, + pkg-config, + intltool, + file, + libintl, + hicolor-icon-theme, + python3, + wrapGAppsHook3, }: stdenv.mkDerivation (finalAttrs: { pname = "geany"; version = "2.0"; - outputs = [ "out" "dev" "doc" "man" ]; + outputs = [ + "out" + "dev" + "doc" + "man" + ]; src = fetchurl { url = "https://download.geany.org/geany-${finalAttrs.version}.tar.bz2"; diff --git a/pkgs/applications/editors/geany/with-vte.nix b/pkgs/applications/editors/geany/with-vte.nix index ba9e941f38968d..c896cb8df25efe 100644 --- a/pkgs/applications/editors/geany/with-vte.nix +++ b/pkgs/applications/editors/geany/with-vte.nix @@ -1,14 +1,19 @@ -{ symlinkJoin -, makeWrapper -, geany -, vte +{ + symlinkJoin, + makeWrapper, + geany, + vte, }: symlinkJoin { name = "geany-with-vte-${geany.version}"; # TODO: add geany-plugins - paths = with geany; [ out doc man ]; + paths = with geany; [ + out + doc + man + ]; nativeBuildInputs = [ makeWrapper ]; @@ -19,5 +24,5 @@ symlinkJoin { --prefix LD_LIBRARY_PATH : ${vte}/lib ''; - inherit (geany.meta); + inherit (geany.meta) ; } diff --git a/pkgs/applications/editors/greenfoot/default.nix b/pkgs/applications/editors/greenfoot/default.nix index 50a912fd0f01cf..1a1b8dcffd17b7 100644 --- a/pkgs/applications/editors/greenfoot/default.nix +++ b/pkgs/applications/editors/greenfoot/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, openjdk, glib, dpkg, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchurl, + openjdk, + glib, + dpkg, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "greenfoot"; @@ -8,11 +16,16 @@ stdenv.mkDerivation rec { # We use the deb here. First instinct might be to go for the "generic" JAR # download, but that is actually a graphical installer that is much harder # to unpack than the deb. - url = "https://www.greenfoot.org/download/files/Greenfoot-linux-${builtins.replaceStrings ["."] [""] version}.deb"; + url = "https://www.greenfoot.org/download/files/Greenfoot-linux-${ + builtins.replaceStrings [ "." ] [ "" ] version + }.deb"; hash = "sha256-wpmgWtx2jTDjt+7p6HcjU/uy1PRmnAHpJ1rOYb+hV+U="; }; - nativeBuildInputs = [ dpkg wrapGAppsHook3 ]; + nativeBuildInputs = [ + dpkg + wrapGAppsHook3 + ]; buildInputs = [ glib ]; dontWrapGApps = true; diff --git a/pkgs/applications/editors/jetbrains/bin/darwin.nix b/pkgs/applications/editors/jetbrains/bin/darwin.nix index f5edf904726b03..14673f41debb92 100644 --- a/pkgs/applications/editors/jetbrains/bin/darwin.nix +++ b/pkgs/applications/editors/jetbrains/bin/darwin.nix @@ -1,28 +1,37 @@ -{ lib -, stdenvNoCC -, undmg -, ... +{ + lib, + stdenvNoCC, + undmg, + ... }: -{ meta -, pname -, product -, productShort ? product -, src -, version -, plugins ? [ ] -, buildNumber -, ... +{ + meta, + pname, + product, + productShort ? product, + src, + version, + plugins ? [ ], + buildNumber, + ... }: let loname = lib.toLower productShort; in stdenvNoCC.mkDerivation { - inherit pname src version plugins; + inherit + pname + src + version + plugins + ; passthru.buildNumber = buildNumber; passthru.product = product; - meta = meta // { mainProgram = loname; }; + meta = meta // { + mainProgram = loname; + }; desktopName = product; dontFixup = true; installPhase = '' diff --git a/pkgs/applications/editors/jetbrains/bin/linux.nix b/pkgs/applications/editors/jetbrains/bin/linux.nix index b1ddb8f5cb62bb..123bf81d2dde77 100644 --- a/pkgs/applications/editors/jetbrains/bin/linux.nix +++ b/pkgs/applications/editors/jetbrains/bin/linux.nix @@ -1,138 +1,161 @@ -{ stdenv -, lib -, makeDesktopItem -, makeWrapper -, patchelf -, writeText -, coreutils -, gnugrep -, which -, git -, unzip -, libsecret -, libnotify -, udev -, e2fsprogs -, python3 -, autoPatchelfHook -, vmopts ? null -, glibcLocales +{ + stdenv, + lib, + makeDesktopItem, + makeWrapper, + patchelf, + writeText, + coreutils, + gnugrep, + which, + git, + unzip, + libsecret, + libnotify, + udev, + e2fsprogs, + python3, + autoPatchelfHook, + vmopts ? null, + glibcLocales, }: -{ pname -, product -, productShort ? product -, version -, src -, wmClass -, buildNumber -, jdk -, meta -, libdbm -, fsnotifier -, extraLdPath ? [ ] -, extraWrapperArgs ? [ ] -, extraBuildInputs ? [ ] +{ + pname, + product, + productShort ? product, + version, + src, + wmClass, + buildNumber, + jdk, + meta, + libdbm, + fsnotifier, + extraLdPath ? [ ], + extraWrapperArgs ? [ ], + extraBuildInputs ? [ ], }@args: let loName = lib.toLower productShort; hiName = lib.toUpper productShort; - vmoptsName = loName - + lib.optionalString stdenv.hostPlatform.is64bit "64" - + ".vmoptions"; + vmoptsName = loName + lib.optionalString stdenv.hostPlatform.is64bit "64" + ".vmoptions"; in -with stdenv; lib.makeOverridable mkDerivation (rec { - inherit pname version src; - passthru.buildNumber = buildNumber; - meta = args.meta // { mainProgram = pname; }; - - desktopItem = makeDesktopItem { - name = pname; - exec = pname; - comment = lib.replaceStrings [ "\n" ] [ " " ] meta.longDescription; - desktopName = product; - genericName = meta.description; - categories = [ "Development" ]; - icon = pname; - startupWMClass = wmClass; - }; - - vmoptsIDE = if hiName == "WEBSTORM" then "WEBIDE" else hiName; - vmoptsFile = lib.optionalString (vmopts != null) (writeText vmoptsName vmopts); - - nativeBuildInputs = [ makeWrapper patchelf unzip autoPatchelfHook ]; - buildInputs = extraBuildInputs; - - postPatch = '' - rm -rf jbr - # When using the IDE as a remote backend using gateway, it expects the jbr directory to contain the jdk - ln -s ${jdk.home} jbr - - if [ -d "plugins/remote-dev-server" ]; then - patch -F3 -p1 < ${../patches/jetbrains-remote-dev.patch} - fi - - vmopts_file=bin/linux/${vmoptsName} - if [[ ! -f $vmopts_file ]]; then - vmopts_file=bin/${vmoptsName} +with stdenv; +lib.makeOverridable mkDerivation ( + rec { + inherit pname version src; + passthru.buildNumber = buildNumber; + meta = args.meta // { + mainProgram = pname; + }; + + desktopItem = makeDesktopItem { + name = pname; + exec = pname; + comment = lib.replaceStrings [ "\n" ] [ " " ] meta.longDescription; + desktopName = product; + genericName = meta.description; + categories = [ "Development" ]; + icon = pname; + startupWMClass = wmClass; + }; + + vmoptsIDE = if hiName == "WEBSTORM" then "WEBIDE" else hiName; + vmoptsFile = lib.optionalString (vmopts != null) (writeText vmoptsName vmopts); + + nativeBuildInputs = [ + makeWrapper + patchelf + unzip + autoPatchelfHook + ]; + buildInputs = extraBuildInputs; + + postPatch = '' + rm -rf jbr + # When using the IDE as a remote backend using gateway, it expects the jbr directory to contain the jdk + ln -s ${jdk.home} jbr + + if [ -d "plugins/remote-dev-server" ]; then + patch -F3 -p1 < ${../patches/jetbrains-remote-dev.patch} + fi + + vmopts_file=bin/linux/${vmoptsName} if [[ ! -f $vmopts_file ]]; then - echo "ERROR: $vmopts_file not found" - exit 1 + vmopts_file=bin/${vmoptsName} + if [[ ! -f $vmopts_file ]]; then + echo "ERROR: $vmopts_file not found" + exit 1 + fi fi - fi - echo -Djna.library.path=${lib.makeLibraryPath ([ - libsecret e2fsprogs libnotify - # Required for Help -> Collect Logs - # in at least rider and goland - udev - ])} >> $vmopts_file - ''; - - installPhase = '' - runHook preInstall - - mkdir -p $out/{bin,$pname,share/pixmaps,share/icons/hicolor/scalable/apps} - cp -a . $out/$pname - [[ -f $out/$pname/bin/${loName}.png ]] && ln -s $out/$pname/bin/${loName}.png $out/share/pixmaps/${pname}.png - [[ -f $out/$pname/bin/${loName}.svg ]] && ln -s $out/$pname/bin/${loName}.svg $out/share/pixmaps/${pname}.svg \ - && ln -s $out/$pname/bin/${loName}.svg $out/share/icons/hicolor/scalable/apps/${pname}.svg - cp ${libdbm}/lib/libdbm.so $out/$pname/bin/libdbm.so - cp ${fsnotifier}/bin/fsnotifier $out/$pname/bin/fsnotifier - - jdk=${jdk.home} - item=${desktopItem} - - launcher="$out/$pname/bin/${loName}" - if [ -e "$launcher" ]; then - rm "$launcher".sh # We do not wrap the old script-style launcher anymore. - else - launcher+=.sh - fi - - wrapProgram "$launcher" \ - --prefix PATH : "${lib.makeBinPath [ jdk coreutils gnugrep which git ]}" \ - --suffix PATH : "${lib.makeBinPath [ python3 ]}" \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath extraLdPath}" \ - ${lib.concatStringsSep " " extraWrapperArgs} \ - --set-default JDK_HOME "$jdk" \ - --set-default ANDROID_JAVA_HOME "$jdk" \ - --set-default JAVA_HOME "$jdk" \ - --set-default JETBRAINS_CLIENT_JDK "$jdk" \ - --set-default ${hiName}_JDK "$jdk" \ - --set-default LOCALE_ARCHIVE "${glibcLocales}/lib/locale/locale-archive" \ - --set-default ${vmoptsIDE}_VM_OPTIONS ${vmoptsFile} - - ln -s "$launcher" $out/bin/$pname - rm -rf $out/$pname/plugins/remote-dev-server/selfcontained/ - echo -e '#!/usr/bin/env bash\n'"$out/$pname/bin/remote-dev-server.sh"' "$@"' > $out/$pname/bin/remote-dev-server-wrapped.sh - chmod +x $out/$pname/bin/remote-dev-server-wrapped.sh - ln -s "$out/$pname/bin/remote-dev-server-wrapped.sh" $out/bin/$pname-remote-dev-server - ln -s "$item/share/applications" $out/share - - runHook postInstall - ''; -} // lib.optionalAttrs (!(meta.license.free or true)) { - preferLocalBuild = true; -}) + echo -Djna.library.path=${ + lib.makeLibraryPath ([ + libsecret + e2fsprogs + libnotify + # Required for Help -> Collect Logs + # in at least rider and goland + udev + ]) + } >> $vmopts_file + ''; + + installPhase = '' + runHook preInstall + + mkdir -p $out/{bin,$pname,share/pixmaps,share/icons/hicolor/scalable/apps} + cp -a . $out/$pname + [[ -f $out/$pname/bin/${loName}.png ]] && ln -s $out/$pname/bin/${loName}.png $out/share/pixmaps/${pname}.png + [[ -f $out/$pname/bin/${loName}.svg ]] && ln -s $out/$pname/bin/${loName}.svg $out/share/pixmaps/${pname}.svg \ + && ln -s $out/$pname/bin/${loName}.svg $out/share/icons/hicolor/scalable/apps/${pname}.svg + cp ${libdbm}/lib/libdbm.so $out/$pname/bin/libdbm.so + cp ${fsnotifier}/bin/fsnotifier $out/$pname/bin/fsnotifier + + jdk=${jdk.home} + item=${desktopItem} + + launcher="$out/$pname/bin/${loName}" + if [ -e "$launcher" ]; then + rm "$launcher".sh # We do not wrap the old script-style launcher anymore. + else + launcher+=.sh + fi + + wrapProgram "$launcher" \ + --prefix PATH : "${ + lib.makeBinPath [ + jdk + coreutils + gnugrep + which + git + ] + }" \ + --suffix PATH : "${lib.makeBinPath [ python3 ]}" \ + --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath extraLdPath}" \ + ${lib.concatStringsSep " " extraWrapperArgs} \ + --set-default JDK_HOME "$jdk" \ + --set-default ANDROID_JAVA_HOME "$jdk" \ + --set-default JAVA_HOME "$jdk" \ + --set-default JETBRAINS_CLIENT_JDK "$jdk" \ + --set-default ${hiName}_JDK "$jdk" \ + --set-default LOCALE_ARCHIVE "${glibcLocales}/lib/locale/locale-archive" \ + --set-default ${vmoptsIDE}_VM_OPTIONS ${vmoptsFile} + + ln -s "$launcher" $out/bin/$pname + rm -rf $out/$pname/plugins/remote-dev-server/selfcontained/ + echo -e '#!/usr/bin/env bash\n'"$out/$pname/bin/remote-dev-server.sh"' "$@"' > $out/$pname/bin/remote-dev-server-wrapped.sh + chmod +x $out/$pname/bin/remote-dev-server-wrapped.sh + ln -s "$out/$pname/bin/remote-dev-server-wrapped.sh" $out/bin/$pname-remote-dev-server + ln -s "$item/share/applications" $out/share + + runHook postInstall + ''; + } + // lib.optionalAttrs (!(meta.license.free or true)) { + preferLocalBuild = true; + } +) diff --git a/pkgs/applications/editors/jetbrains/default.nix b/pkgs/applications/editors/jetbrains/default.nix index e2552a631becc2..5f212cc1b679cc 100644 --- a/pkgs/applications/editors/jetbrains/default.nix +++ b/pkgs/applications/editors/jetbrains/default.nix @@ -5,37 +5,38 @@ let versions = builtins.fromJSON (builtins.readFile ./bin/versions.json); in -{ lib -, stdenv -, callPackage -, fetchurl - -, jdk -, zlib -, python3 -, lldb -, dotnet-sdk_8 -, maven -, openssl -, expat -, libxcrypt -, libxcrypt-legacy -, fontconfig -, libxml2 -, runCommand -, musl -, R -, libgcc -, lttng-ust_2_12 -, xz -, xorg -, libGL - -, libICE -, libSM -, libX11 - -, vmopts ? null +{ + lib, + stdenv, + callPackage, + fetchurl, + + jdk, + zlib, + python3, + lldb, + dotnet-sdk_8, + maven, + openssl, + expat, + libxcrypt, + libxcrypt-legacy, + fontconfig, + libxml2, + runCommand, + musl, + R, + libgcc, + lttng-ust_2_12, + xz, + xorg, + libGL, + + libICE, + libSM, + libX11, + + vmopts ? null, }: let @@ -47,179 +48,286 @@ let mkJetBrainsProductCore = callPackage package { inherit vmopts; }; mkMeta = meta: fromSource: { inherit (meta) homepage longDescription; - description = meta.description + lib.optionalString meta.isOpenSource (if fromSource then " (built from source)" else " (patched binaries from jetbrains)"); + description = + meta.description + + lib.optionalString meta.isOpenSource ( + if fromSource then " (built from source)" else " (patched binaries from jetbrains)" + ); maintainers = map (x: lib.maintainers."${x}") meta.maintainers; license = if meta.isOpenSource then lib.licenses.asl20 else lib.licenses.unfree; - sourceProvenance = if fromSource then [ lib.sourceTypes.fromSource ] else - (if stdenv.hostPlatform.isDarwin then [ lib.sourceTypes.binaryNativeCode ] else [ lib.sourceTypes.binaryBytecode ]); + sourceProvenance = + if fromSource then + [ lib.sourceTypes.fromSource ] + else + ( + if stdenv.hostPlatform.isDarwin then + [ lib.sourceTypes.binaryNativeCode ] + else + [ lib.sourceTypes.binaryBytecode ] + ); }; mkJetBrainsProduct = - { pname - , fromSource ? false - , extraWrapperArgs ? [ ] - , extraLdPath ? [ ] - , extraBuildInputs ? [ ] + { + pname, + fromSource ? false, + extraWrapperArgs ? [ ], + extraLdPath ? [ ], + extraBuildInputs ? [ ], }: mkJetBrainsProductCore { - inherit pname jdk extraWrapperArgs extraLdPath extraBuildInputs; - src = if fromSource then communitySources."${pname}" else - fetchurl { - url = products."${pname}".url; - sha256 = products."${pname}".sha256; - }; + inherit + pname + jdk + extraWrapperArgs + extraLdPath + extraBuildInputs + ; + src = + if fromSource then + communitySources."${pname}" + else + fetchurl { + url = products."${pname}".url; + sha256 = products."${pname}".sha256; + }; inherit (products."${pname}") version; buildNumber = products."${pname}".build_number; inherit (ideInfo."${pname}") wmClass product; productShort = ideInfo."${pname}".productShort or ideInfo."${pname}".product; meta = mkMeta ideInfo."${pname}".meta fromSource; - libdbm = if ideInfo."${pname}".meta.isOpenSource then communitySources."${pname}".libdbm else communitySources.idea-community.libdbm; - fsnotifier = if ideInfo."${pname}".meta.isOpenSource then communitySources."${pname}".fsnotifier else communitySources.idea-community.fsnotifier; + libdbm = + if ideInfo."${pname}".meta.isOpenSource then + communitySources."${pname}".libdbm + else + communitySources.idea-community.libdbm; + fsnotifier = + if ideInfo."${pname}".meta.isOpenSource then + communitySources."${pname}".fsnotifier + else + communitySources.idea-community.fsnotifier; }; communitySources = callPackage ./source { }; - buildIdea = args: - mkJetBrainsProduct (args // { - extraLdPath = [ zlib ]; - extraWrapperArgs = [ - ''--set M2_HOME "${maven}/maven"'' - ''--set M2 "${maven}/maven/bin"'' - ]; - }); - - buildPycharm = args: - (mkJetBrainsProduct args).overrideAttrs (finalAttrs: previousAttrs: lib.optionalAttrs stdenv.hostPlatform.isLinux { - buildInputs = with python3.pkgs; (previousAttrs.buildInputs or []) ++ [ python3 setuptools ]; - preInstall = '' - echo "compiling cython debug speedups" - if [[ -d plugins/python-ce ]]; then - ${python3.interpreter} plugins/python-ce/helpers/pydev/setup_cython.py build_ext --inplace - else - ${python3.interpreter} plugins/python/helpers/pydev/setup_cython.py build_ext --inplace - fi - ''; - # See https://www.jetbrains.com/help/pycharm/2022.1/cython-speedups.html - }); + buildIdea = + args: + mkJetBrainsProduct ( + args + // { + extraLdPath = [ zlib ]; + extraWrapperArgs = [ + ''--set M2_HOME "${maven}/maven"'' + ''--set M2 "${maven}/maven/bin"'' + ]; + } + ); + + buildPycharm = + args: + (mkJetBrainsProduct args).overrideAttrs ( + finalAttrs: previousAttrs: + lib.optionalAttrs stdenv.hostPlatform.isLinux { + buildInputs = + with python3.pkgs; + (previousAttrs.buildInputs or [ ]) + ++ [ + python3 + setuptools + ]; + preInstall = '' + echo "compiling cython debug speedups" + if [[ -d plugins/python-ce ]]; then + ${python3.interpreter} plugins/python-ce/helpers/pydev/setup_cython.py build_ext --inplace + else + ${python3.interpreter} plugins/python/helpers/pydev/setup_cython.py build_ext --inplace + fi + ''; + # See https://www.jetbrains.com/help/pycharm/2022.1/cython-speedups.html + } + ); in rec { # Sorted alphabetically - aqua = mkJetBrainsProduct { pname = "aqua"; extraBuildInputs = [ stdenv.cc.cc lldb ]; }; - - clion = (mkJetBrainsProduct { - pname = "clion"; - extraBuildInputs = lib.optionals (stdenv.hostPlatform.isLinux) [ - fontconfig - python3 + aqua = mkJetBrainsProduct { + pname = "aqua"; + extraBuildInputs = [ stdenv.cc.cc - openssl - libxcrypt-legacy - lttng-ust_2_12 - musl - ] ++ lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) [ - expat - libxml2 - xz + lldb ]; - }).overrideAttrs (attrs: { - postInstall = (attrs.postInstall or "") + lib.optionalString (stdenv.hostPlatform.isLinux) '' - ( - cd $out/clion - - for dir in plugins/clion-radler/DotFiles/linux-*; do - rm -rf $dir/dotnet - ln -s ${dotnet-sdk_8.unwrapped}/share/dotnet $dir/dotnet - done - ) - ''; - - postFixup = (attrs.postFixup or "") + lib.optionalString (stdenv.hostPlatform.isLinux) '' - ( - cd $out/clion - - # I think the included gdb has a couple of patches, so we patch it instead of replacing - ls -d $PWD/bin/gdb/linux/*/lib/python3.8/lib-dynload/* | - xargs patchelf \ - --replace-needed libssl.so.10 libssl.so \ - --replace-needed libcrypto.so.10 libcrypto.so - - ls -d $PWD/bin/lldb/linux/*/lib/python3.8/lib-dynload/* | - xargs patchelf \ - --replace-needed libssl.so.10 libssl.so \ - --replace-needed libcrypto.so.10 libcrypto.so - ) - ''; - }); - - datagrip = mkJetBrainsProduct { pname = "datagrip"; extraBuildInputs = [ stdenv.cc.cc ]; }; - - dataspell = let - libr = runCommand "libR" {} '' - mkdir -p $out/lib - ln -s ${R}/lib/R/lib/libR.so $out/lib/libR.so - ''; - in mkJetBrainsProduct { - pname = "dataspell"; - extraBuildInputs = [ libgcc libr stdenv.cc.cc ]; }; + clion = + (mkJetBrainsProduct { + pname = "clion"; + extraBuildInputs = + lib.optionals (stdenv.hostPlatform.isLinux) [ + fontconfig + python3 + stdenv.cc.cc + openssl + libxcrypt-legacy + lttng-ust_2_12 + musl + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) [ + expat + libxml2 + xz + ]; + }).overrideAttrs + (attrs: { + postInstall = + (attrs.postInstall or "") + + lib.optionalString (stdenv.hostPlatform.isLinux) '' + ( + cd $out/clion + + for dir in plugins/clion-radler/DotFiles/linux-*; do + rm -rf $dir/dotnet + ln -s ${dotnet-sdk_8.unwrapped}/share/dotnet $dir/dotnet + done + ) + ''; + + postFixup = + (attrs.postFixup or "") + + lib.optionalString (stdenv.hostPlatform.isLinux) '' + ( + cd $out/clion + + # I think the included gdb has a couple of patches, so we patch it instead of replacing + ls -d $PWD/bin/gdb/linux/*/lib/python3.8/lib-dynload/* | + xargs patchelf \ + --replace-needed libssl.so.10 libssl.so \ + --replace-needed libcrypto.so.10 libcrypto.so + + ls -d $PWD/bin/lldb/linux/*/lib/python3.8/lib-dynload/* | + xargs patchelf \ + --replace-needed libssl.so.10 libssl.so \ + --replace-needed libcrypto.so.10 libcrypto.so + ) + ''; + }); + + datagrip = mkJetBrainsProduct { + pname = "datagrip"; + extraBuildInputs = [ stdenv.cc.cc ]; + }; + + dataspell = + let + libr = runCommand "libR" { } '' + mkdir -p $out/lib + ln -s ${R}/lib/R/lib/libR.so $out/lib/libR.so + ''; + in + mkJetBrainsProduct { + pname = "dataspell"; + extraBuildInputs = [ + libgcc + libr + stdenv.cc.cc + ]; + }; + gateway = mkJetBrainsProduct { pname = "gateway"; extraBuildInputs = [ libgcc ]; }; - goland = (mkJetBrainsProduct { - pname = "goland"; - extraWrapperArgs = [ - # fortify source breaks build since delve compiles with -O0 - ''--prefix CGO_CPPFLAGS " " "-U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=0"'' - ]; - extraBuildInputs = [ libgcc stdenv.cc.cc ]; - }).overrideAttrs - (attrs: { - postFixup = (attrs.postFixup or "") + lib.optionalString stdenv.hostPlatform.isLinux '' - interp="$(cat $NIX_CC/nix-support/dynamic-linker)" - patchelf --set-interpreter $interp $out/goland/plugins/go-plugin/lib/dlv/linux/dlv - chmod +x $out/goland/plugins/go-plugin/lib/dlv/linux/dlv - ''; - }); - - idea-community-bin = buildIdea { pname = "idea-community"; extraBuildInputs = [ stdenv.cc.cc ]; }; + goland = + (mkJetBrainsProduct { + pname = "goland"; + extraWrapperArgs = [ + # fortify source breaks build since delve compiles with -O0 + ''--prefix CGO_CPPFLAGS " " "-U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=0"'' + ]; + extraBuildInputs = [ + libgcc + stdenv.cc.cc + ]; + }).overrideAttrs + (attrs: { + postFixup = + (attrs.postFixup or "") + + lib.optionalString stdenv.hostPlatform.isLinux '' + interp="$(cat $NIX_CC/nix-support/dynamic-linker)" + patchelf --set-interpreter $interp $out/goland/plugins/go-plugin/lib/dlv/linux/dlv + chmod +x $out/goland/plugins/go-plugin/lib/dlv/linux/dlv + ''; + }); + + idea-community-bin = buildIdea { + pname = "idea-community"; + extraBuildInputs = [ stdenv.cc.cc ]; + }; - idea-community-src = buildIdea { pname = "idea-community"; extraBuildInputs = [ stdenv.cc.cc ]; fromSource = true; }; + idea-community-src = buildIdea { + pname = "idea-community"; + extraBuildInputs = [ stdenv.cc.cc ]; + fromSource = true; + }; - idea-community = if stdenv.hostPlatform.isDarwin || stdenv.hostPlatform.isAarch64 then idea-community-bin else idea-community-src; + idea-community = + if stdenv.hostPlatform.isDarwin || stdenv.hostPlatform.isAarch64 then + idea-community-bin + else + idea-community-src; - idea-ultimate = buildIdea { pname = "idea-ultimate"; extraBuildInputs = [ stdenv.cc.cc lldb musl ]; }; + idea-ultimate = buildIdea { + pname = "idea-ultimate"; + extraBuildInputs = [ + stdenv.cc.cc + lldb + musl + ]; + }; mps = mkJetBrainsProduct { pname = "mps"; }; - phpstorm = mkJetBrainsProduct { pname = "phpstorm"; extraBuildInputs = [ stdenv.cc.cc musl ]; }; + phpstorm = mkJetBrainsProduct { + pname = "phpstorm"; + extraBuildInputs = [ + stdenv.cc.cc + musl + ]; + }; pycharm-community-bin = buildPycharm { pname = "pycharm-community"; }; - pycharm-community-src = buildPycharm { pname = "pycharm-community"; fromSource = true; }; + pycharm-community-src = buildPycharm { + pname = "pycharm-community"; + fromSource = true; + }; - pycharm-community = if stdenv.hostPlatform.isDarwin then pycharm-community-bin else pycharm-community-src; + pycharm-community = + if stdenv.hostPlatform.isDarwin then pycharm-community-bin else pycharm-community-src; - pycharm-professional = buildPycharm { pname = "pycharm-professional"; extraBuildInputs = [ musl ]; }; + pycharm-professional = buildPycharm { + pname = "pycharm-professional"; + extraBuildInputs = [ musl ]; + }; - rider = (mkJetBrainsProduct { + rider = + (mkJetBrainsProduct { pname = "rider"; - extraBuildInputs = [ - fontconfig - stdenv.cc.cc - openssl - libxcrypt - lttng-ust_2_12 - musl - ]++ lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) [ - expat - libxml2 - xz - ]; + extraBuildInputs = + [ + fontconfig + stdenv.cc.cc + openssl + libxcrypt + lttng-ust_2_12 + musl + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) [ + expat + libxml2 + xz + ]; extraLdPath = lib.optionals (stdenv.hostPlatform.isLinux) [ # Avalonia dependencies needed for dotMemory libICE @@ -227,66 +335,95 @@ rec { libX11 libGL ]; - }).overrideAttrs (attrs: { - postInstall = (attrs.postInstall or "") + lib.optionalString (stdenv.hostPlatform.isLinux) '' - ( - cd $out/rider - - ls -d $PWD/plugins/cidr-debugger-plugin/bin/lldb/linux/*/lib/python3.8/lib-dynload/* | - xargs patchelf \ - --replace-needed libssl.so.10 libssl.so \ - --replace-needed libcrypto.so.10 libcrypto.so \ - --replace-needed libcrypt.so.1 libcrypt.so - - for dir in lib/ReSharperHost/linux-*; do - rm -rf $dir/dotnet - ln -s ${dotnet-sdk_8.unwrapped}/share/dotnet $dir/dotnet - done - ) - ''; - }); - - ruby-mine = mkJetBrainsProduct { pname = "ruby-mine"; extraBuildInputs = [ stdenv.cc.cc musl ]; }; - - rust-rover = (mkJetBrainsProduct { - pname = "rust-rover"; - extraBuildInputs = lib.optionals (stdenv.hostPlatform.isLinux) [ - python3 - openssl - libxcrypt-legacy - fontconfig - xorg.libX11 - libGL - ] ++ lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) [ - expat - libxml2 - xz + }).overrideAttrs + (attrs: { + postInstall = + (attrs.postInstall or "") + + lib.optionalString (stdenv.hostPlatform.isLinux) '' + ( + cd $out/rider + + ls -d $PWD/plugins/cidr-debugger-plugin/bin/lldb/linux/*/lib/python3.8/lib-dynload/* | + xargs patchelf \ + --replace-needed libssl.so.10 libssl.so \ + --replace-needed libcrypto.so.10 libcrypto.so \ + --replace-needed libcrypt.so.1 libcrypt.so + + for dir in lib/ReSharperHost/linux-*; do + rm -rf $dir/dotnet + ln -s ${dotnet-sdk_8.unwrapped}/share/dotnet $dir/dotnet + done + ) + ''; + }); + + ruby-mine = mkJetBrainsProduct { + pname = "ruby-mine"; + extraBuildInputs = [ + stdenv.cc.cc + musl ]; - }).overrideAttrs (attrs: { - postFixup = (attrs.postFixup or "") + lib.optionalString (stdenv.hostPlatform.isLinux) '' - ( - cd $out/rust-rover - - # Copied over from clion (gdb seems to have a couple of patches) - ls -d $PWD/bin/gdb/linux/*/lib/python3.8/lib-dynload/* | - xargs patchelf \ - --replace-needed libssl.so.10 libssl.so \ - --replace-needed libcrypto.so.10 libcrypto.so - - ls -d $PWD/bin/lldb/linux/*/lib/python3.8/lib-dynload/* | - xargs patchelf \ - --replace-needed libssl.so.10 libssl.so \ - --replace-needed libcrypto.so.10 libcrypto.so - - chmod +x $PWD/plugins/intellij-rust/bin/linux/*/intellij-rust-native-helper - ) - ''; - }); + }; - webstorm = mkJetBrainsProduct { pname = "webstorm"; extraBuildInputs = [ stdenv.cc.cc musl ]; }; + rust-rover = + (mkJetBrainsProduct { + pname = "rust-rover"; + extraBuildInputs = + lib.optionals (stdenv.hostPlatform.isLinux) [ + python3 + openssl + libxcrypt-legacy + fontconfig + xorg.libX11 + libGL + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) [ + expat + libxml2 + xz + ]; + }).overrideAttrs + (attrs: { + postFixup = + (attrs.postFixup or "") + + lib.optionalString (stdenv.hostPlatform.isLinux) '' + ( + cd $out/rust-rover + + # Copied over from clion (gdb seems to have a couple of patches) + ls -d $PWD/bin/gdb/linux/*/lib/python3.8/lib-dynload/* | + xargs patchelf \ + --replace-needed libssl.so.10 libssl.so \ + --replace-needed libcrypto.so.10 libcrypto.so + + ls -d $PWD/bin/lldb/linux/*/lib/python3.8/lib-dynload/* | + xargs patchelf \ + --replace-needed libssl.so.10 libssl.so \ + --replace-needed libcrypto.so.10 libcrypto.so + + chmod +x $PWD/plugins/intellij-rust/bin/linux/*/intellij-rust-native-helper + ) + ''; + }); + + webstorm = mkJetBrainsProduct { + pname = "webstorm"; + extraBuildInputs = [ + stdenv.cc.cc + musl + ]; + }; - writerside = mkJetBrainsProduct { pname = "writerside"; extraBuildInputs = [ stdenv.cc.cc musl ]; }; + writerside = mkJetBrainsProduct { + pname = "writerside"; + extraBuildInputs = [ + stdenv.cc.cc + musl + ]; + }; - plugins = callPackage ./plugins { } // { __attrsFailEvaluation = true; }; + plugins = callPackage ./plugins { } // { + __attrsFailEvaluation = true; + }; } diff --git a/pkgs/applications/editors/jetbrains/plugins/specialPlugins.nix b/pkgs/applications/editors/jetbrains/plugins/specialPlugins.nix index 1ba1e0f38c1f83..ccfd90b68b8cb5 100644 --- a/pkgs/applications/editors/jetbrains/plugins/specialPlugins.nix +++ b/pkgs/applications/editors/jetbrains/plugins/specialPlugins.nix @@ -1,4 +1,11 @@ -{ delve, autoPatchelfHook, stdenv, lib, glibc, gcc-unwrapped }: +{ + delve, + autoPatchelfHook, + stdenv, + lib, + glibc, + gcc-unwrapped, +}: # This is a list of plugins that need special treatment. For example, the go plugin (id is 9568) comes with delve, a # debugger, but that needs various linking fixes. The changes here replace it with the system one. { @@ -27,8 +34,11 @@ buildInputs = [ delve ]; buildPhase = let - arch = (if stdenv.hostPlatform.isLinux then "linux" else "mac") + (if stdenv.hostPlatform.isAarch64 then "arm" else ""); - in '' + arch = + (if stdenv.hostPlatform.isLinux then "linux" else "mac") + + (if stdenv.hostPlatform.isAarch64 then "arm" else ""); + in + '' runHook preBuild ln -sf ${delve}/bin/dlv lib/dlv/${arch}/dlv runHook postBuild @@ -38,13 +48,21 @@ # Github Copilot # Modified version of https://github.com/ktor/nixos/commit/35f4071faab696b2a4d86643726c9dd3e4293964 buildPhase = '' - agent='copilot-agent/native/${lib.toLower stdenv.hostPlatform.uname.system}${{ - x86_64 = "-x64"; - aarch64 = "-arm64"; - }.${stdenv.hostPlatform.uname.processor} or ""}/copilot-language-server' + agent='copilot-agent/native/${lib.toLower stdenv.hostPlatform.uname.system}${ + { + x86_64 = "-x64"; + aarch64 = "-arm64"; + } + .${stdenv.hostPlatform.uname.processor} or "" + }/copilot-language-server' orig_size=$(stat --printf=%s $agent) patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" $agent - patchelf --set-rpath ${lib.makeLibraryPath [glibc gcc-unwrapped]} $agent + patchelf --set-rpath ${ + lib.makeLibraryPath [ + glibc + gcc-unwrapped + ] + } $agent chmod +x $agent new_size=$(stat --printf=%s $agent) var_skip=20 diff --git a/pkgs/applications/editors/jetbrains/plugins/tests.nix b/pkgs/applications/editors/jetbrains/plugins/tests.nix index 4b07cc5f8818ca..2c9be7479368a1 100644 --- a/pkgs/applications/editors/jetbrains/plugins/tests.nix +++ b/pkgs/applications/editors/jetbrains/plugins/tests.nix @@ -5,25 +5,27 @@ default = let modify-ide = ide: jetbrains.plugins.addPlugins ide [ ]; - ides = with jetbrains; map modify-ide [ - clion - datagrip - dataspell - goland - idea-community - idea-ultimate - mps - phpstorm - pycharm-community - pycharm-professional - rider - ruby-mine - rust-rover - webstorm - ]; + ides = + with jetbrains; + map modify-ide [ + clion + datagrip + dataspell + goland + idea-community + idea-ultimate + mps + phpstorm + pycharm-community + pycharm-professional + rider + ruby-mine + rust-rover + webstorm + ]; paths = builtins.concatStringsSep " " ides; in writeText "jb-ides" paths; - clion-with-vim = jetbrains.plugins.addPlugins jetbrains.clion [ "ideavim" ]; + clion-with-vim = jetbrains.plugins.addPlugins jetbrains.clion [ "ideavim" ]; } diff --git a/pkgs/applications/editors/jupyter-kernels/clojupyter/default.nix b/pkgs/applications/editors/jupyter-kernels/clojupyter/default.nix index 2f06cf3757c9e7..0a1de3a871a2c1 100644 --- a/pkgs/applications/editors/jupyter-kernels/clojupyter/default.nix +++ b/pkgs/applications/editors/jupyter-kernels/clojupyter/default.nix @@ -1,11 +1,12 @@ -{ pkgs -, stdenv -, lib -, jre -, fetchFromGitHub -, writeShellScript -, runCommand -, imagemagick +{ + pkgs, + stdenv, + lib, + jre, + fetchFromGitHub, + writeShellScript, + runCommand, + imagemagick, }: # Jupyter console: @@ -16,7 +17,7 @@ let cljdeps = import ./deps.nix { inherit pkgs; }; - classp = cljdeps.makeClasspaths {}; + classp = cljdeps.makeClasspaths { }; shellScript = writeShellScript "clojupyter" '' ${jre}/bin/java -cp ${classp} clojupyter.kernel.core "$@" @@ -28,41 +29,53 @@ let meta = with lib; { description = "Jupyter kernel for Clojure"; homepage = "https://github.com/clojupyter/clojupyter"; - sourceProvenance = with sourceTypes; [ binaryBytecode ]; # deps from maven + sourceProvenance = with sourceTypes; [ binaryBytecode ]; # deps from maven license = licenses.mit; maintainers = with maintainers; [ thomasjm ]; platforms = jre.meta.platforms; }; - sizedLogo = size: stdenv.mkDerivation { - name = "clojupyter-logo-${size}x${size}.png"; + sizedLogo = + size: + stdenv.mkDerivation { + name = "clojupyter-logo-${size}x${size}.png"; - src = fetchFromGitHub { - owner = "clojupyter"; - repo = "clojupyter"; - rev = version; - sha256 = "sha256-BCzcPnLSonm+ELFU4JIIzLPlVnP0VzlrRSGxOd/LFow="; - }; + src = fetchFromGitHub { + owner = "clojupyter"; + repo = "clojupyter"; + rev = version; + sha256 = "sha256-BCzcPnLSonm+ELFU4JIIzLPlVnP0VzlrRSGxOd/LFow="; + }; - buildInputs = [ imagemagick ]; + buildInputs = [ imagemagick ]; - dontConfigure = true; - dontInstall = true; + dontConfigure = true; + dontInstall = true; - buildPhase = '' - convert ./resources/clojupyter/assets/logo-64x64.png -resize ${size}x${size} $out - ''; + buildPhase = '' + convert ./resources/clojupyter/assets/logo-64x64.png -resize ${size}x${size} $out + ''; - inherit meta; - }; + inherit meta; + }; in rec { - launcher = runCommand "clojupyter" { inherit pname version meta shellScript; } '' - mkdir -p $out/bin - ln -s $shellScript $out/bin/clojupyter - ''; + launcher = + runCommand "clojupyter" + { + inherit + pname + version + meta + shellScript + ; + } + '' + mkdir -p $out/bin + ln -s $shellScript $out/bin/clojupyter + ''; definition = { displayName = "Clojure"; diff --git a/pkgs/applications/editors/jupyter-kernels/clojupyter/deps.nix b/pkgs/applications/editors/jupyter-kernels/clojupyter/deps.nix index 99299e2715094d..00d19b29152316 100644 --- a/pkgs/applications/editors/jupyter-kernels/clojupyter/deps.nix +++ b/pkgs/applications/editors/jupyter-kernels/clojupyter/deps.nix @@ -1,1085 +1,1100 @@ # generated by clj2nix-1.0.5 -{ pkgs ? import {} }: - - let repos = [ - "https://repo1.maven.org/maven2/" - "https://repo.clojars.org/" - "http://oss.sonatype.org/content/repositories/releases/" - "http://oss.sonatype.org/content/repositories/public/" - "http://repo.typesafe.com/typesafe/releases/" - ]; - - in rec { - makePaths = {extraClasspaths ? []}: (builtins.map (dep: if builtins.hasAttr "jar" dep.path then dep.path.jar else dep.path) packages) ++ extraClasspaths; - makeClasspaths = {extraClasspaths ? []}: builtins.concatStringsSep ":" (makePaths {inherit extraClasspaths;}); - - packages = [ - { - name = "javax.inject/javax.inject"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "javax.inject"; - groupId = "javax.inject"; - sha512 = "e126b7ccf3e42fd1984a0beef1004a7269a337c202e59e04e8e2af714280d2f2d8d2ba5e6f59481b8dcd34aaf35c966a688d0b48ec7e96f102c274dc0d3b381e"; - version = "1"; - }; - } - - { - name = "org.clojure/data.json"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "data.json"; - groupId = "org.clojure"; - sha512 = "04b7c0c90cb26d643a0b3e7e1ffa2d2d423e977c1454ee5ea7c2e75547ecbc113838df17b797902a975f5ea2184a81a45b605a4d82970805e2bbb02feebc578d"; - version = "2.4.0"; - }; - } - - { - name = "org.clojure/clojure"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "clojure"; - groupId = "org.clojure"; - sha512 = "1925300a0fe4cc9fc3985910bb04ae65a19ce274dacc5ec76e708cfa87a7952a0a77282b083d0aebb2206afff619af73a57f0d661a3423601586f0829cc7956b"; - version = "1.11.1"; - }; - } - - { - name = "net.cgrand/sjacket"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "sjacket"; - groupId = "net.cgrand"; - sha512 = "34a359a0a633f116147e5bd52d4f4a9cd755636ce0e8abf155da9c3f04b07f93bbbf7c1f8e370db922e14da0efd36a5b127ff9e564141ca7a843f0498a8b860a"; - version = "0.1.1"; - }; - } - - { - name = "clojupyter/clojupyter"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "clojupyter"; - groupId = "clojupyter"; - sha512 = "9a4f001cbde7a4de2d27859b25e508ba649225acf9dabad4c1c274e86674e0dcde250a49cacd0767bb99f5b15a61e2f1c829fb2fe7b7dfc4b87681b7ae0b04ae"; - version = "0.3.6"; - }; - } - - { - name = "commons-codec/commons-codec"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "commons-codec"; - groupId = "commons-codec"; - sha512 = "b65531ead8500493e3dd14a860224851b80f438fc53bf8868b443a0557d839a2b0c868e4fedcf99579ae04b6b2bbd8cdb37f9921ad785983c37569aa9d2e8102"; - version = "1.9"; - }; - } - - { - name = "org.clojure/tools.analyzer"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "tools.analyzer"; - groupId = "org.clojure"; - sha512 = "c51752a714848247b05c6f98b54276b4fe8fd44b3d970070b0f30cd755ac6656030fd8943a1ffd08279af8eeff160365be47791e48f05ac9cc2488b6e2dfe504"; - version = "1.1.0"; - }; - } - - { - name = "org.codehaus.plexus/plexus-component-annotations"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "plexus-component-annotations"; - groupId = "org.codehaus.plexus"; - sha512 = "e20aa9fdb3fda4126f55ef45c36362138c6554ede40fa266ff6b63fe1c3b4d699f9eb95793f26527e096ec7567874aa7af5fe84124815729fdb2d4abaa9ddea8"; - version = "1.7.1"; - }; - } - - { - name = "org.apache.commons/commons-compress"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "commons-compress"; - groupId = "org.apache.commons"; - sha512 = "f3e077ff7f69992961d744dc513eca93606e472e3733657636808a7f50c17f39e3de8367a1af7972cb158f05725808627b6232585a81f197c0da3eff0336913e"; - version = "1.8"; - }; - } - - { - name = "org.apache.commons/commons-lang3"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "commons-lang3"; - groupId = "org.apache.commons"; - sha512 = "9e6ff20e891b6835d5926c90f237d55931e75723c8b88d6417926393e077e71013dab006372d34a6b5801e6ca3ce080a00f202cba700cab5aabfc17bbbdcab36"; - version = "3.5"; - }; - } - - { - name = "org.clojure/core.specs.alpha"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "core.specs.alpha"; - groupId = "org.clojure"; - sha512 = "f521f95b362a47bb35f7c85528c34537f905fb3dd24f2284201e445635a0df701b35d8419d53c6507cc78d3717c1f83cda35ea4c82abd8943cd2ab3de3fcad70"; - version = "0.2.62"; - }; - } - - { - name = "org.tukaani/xz"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "xz"; - groupId = "org.tukaani"; - sha512 = "c5c130bf22f24f61b57fc0c6243e7f961ca2a8928416e8bb288aec6650c1c1c06ace4383913cd1277fc6785beb9a74458807ea7e3d6b2e09189cfaf2fb9ab7e1"; - version = "1.5"; - }; - } - - { - name = "org.zeromq/jeromq"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "jeromq"; - groupId = "org.zeromq"; - sha512 = "bd502d345926160b1a09e45f60eb81254dc67d6d9d7b79e025c08018dd16a18d32ff85b2440c352d530e61c96cd3b2d88fee2a8a912b436015ed31039e308ff4"; - version = "0.5.2"; - }; - } - - { - name = "org.clojure/spec.alpha"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "spec.alpha"; - groupId = "org.clojure"; - sha512 = "ddfe4fa84622abd8ac56e2aa565a56e6bdc0bf330f377ff3e269ddc241bb9dbcac332c13502dfd4c09c2c08fe24d8d2e8cf3d04a1bc819ca5657b4e41feaa7c2"; - version = "0.3.218"; - }; - } - - { - name = "pandect/pandect"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "pandect"; - groupId = "pandect"; - sha512 = "6179967af34e1abbe0dda2bd0961f101d016df6b1ce5bf4bb823794b07ee551d245d09e957a9c47bc3a15d306cca80ad1b9b11be99e1b3feb245c26e1b9154a3"; - version = "1.0.2"; - }; - } - - { - name = "org.clojure/tools.cli"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "tools.cli"; - groupId = "org.clojure"; - sha512 = "1d88aa03eb6a664bf2c0ce22c45e7296d54d716e29b11904115be80ea1661623cf3e81fc222d164047058239010eb678af92ffedc7c3006475cceb59f3b21265"; - version = "1.0.206"; - }; - } - - { - name = "com.taoensso/encore"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "encore"; - groupId = "com.taoensso"; - sha512 = "43dbec081c4ad7b21526371bc78844877d50dd08580c4c039c4dac7e854247a6b145bda835460863fa91d270e81783ddcdad3aaa1a902575be5b21ac0a95c7d0"; - version = "3.21.0"; - }; - } - - { - name = "org.apache.maven.resolver/maven-resolver-transport-wagon"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-resolver-transport-wagon"; - groupId = "org.apache.maven.resolver"; - sha512 = "b7a4dcd2f9bb39bfd561e9b2a8fc087bd9e7e59136ea7787341c173fa22c6b8e9370117ed6c30b0c930dd5b188fab2f2b060042861df19e79772a74c703fcf64"; - version = "1.0.3"; - }; - } - - { - name = "org.slf4j/jcl-over-slf4j"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "jcl-over-slf4j"; - groupId = "org.slf4j"; - sha512 = "17aca766b01f136d39bda982a6046d01d296ee076d9628e9776256bd931bbd88437377d5f1cc196d75bd7fa1672dd131311dbf567b4c3a618dd538a6905fbb64"; - version = "2.0.3"; - }; - } - - { - name = "org.clojure/tools.analyzer.jvm"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "tools.analyzer.jvm"; - groupId = "org.clojure"; - sha512 = "36ad50a7a79c47dea16032fc4b927bd7b56b8bedcbd20cc9c1b9c85edede3a455369b8806509b56a48457dcd32e1f708f74228bce2b4492bd6ff6fc4f1219d56"; - version = "1.2.2"; - }; - } - - { - name = "org.apache.maven.wagon/wagon-provider-api"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "wagon-provider-api"; - groupId = "org.apache.maven.wagon"; - sha512 = "4571002ad5bfc0442bb2eaf32ec42675dc0a179413230615475842bba12fb561159ffc0213127cf241088641a218627e84049b715b9e71ed83d960f4f09da985"; - version = "3.0.0"; - }; - } - - { - name = "io.pedestal/pedestal.log"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "pedestal.log"; - groupId = "io.pedestal"; - sha512 = "229c6c73dc7ec39aee15f54ce81cf2b33301e444241f2dff2066b4c10ff47968f3caa95a8a918601e8f3e7563b34da6925e533615e7ce8b1f39bdb97ca082757"; - version = "0.5.10"; - }; - } - - { - name = "com.fasterxml.jackson.dataformat/jackson-dataformat-cbor"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "jackson-dataformat-cbor"; - groupId = "com.fasterxml.jackson.dataformat"; - sha512 = "b6e16c43fb3e71f82f8e7dc558f53cbcc8fea31efa59f40d22220f6e40167cf32c150efa18a81f839008d6a042e201bf17d8fd52a4fecbe8f356454f2d6a6170"; - version = "2.13.3"; - }; - } - - { - name = "org.apache.maven.resolver/maven-resolver-transport-http"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-resolver-transport-http"; - groupId = "org.apache.maven.resolver"; - sha512 = "97c23620a57406a8d87a08ab2897355afcce4b53b397ef7d13b4254cb07e965b51f05e21ce2d77ea93c4dbc63f32b3f07ff2171bccfe2b4f21116569968a003e"; - version = "1.0.3"; - }; - } - - { - name = "net.cgrand/parsley"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "parsley"; - groupId = "net.cgrand"; - sha512 = "e114f9e5709b9a38214aabc2b7bb33984693a4302fd8570bb91956bce2755d69b6ee2eaa7224137e306ab1f830672eee928e030677f50739edc62314429fa1f7"; - version = "0.9.3"; - }; - } - - { - name = "funcool/cats"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "cats"; - groupId = "funcool"; - sha512 = "83ccb058078c3c380435512e6f92cfc117244fab4819db776eb963d3b488ac92ca70a783b5d3b776d9d4cf06d9de5d3730c07ce6e7013e6717ba28335601ece8"; - version = "2.3.2"; - }; - } - - { - name = "org.apache.maven/maven-model-builder"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-model-builder"; - groupId = "org.apache.maven"; - sha512 = "6684b58d14e7d037f240ae15ee0456d27354c9dd93a1dc2bdbb66f399b012ffe8ff67a1dd83ee1e45c07fd91af77909a9c19d6b29791002d5b5acf23ca75dcb2"; - version = "3.5.3"; - }; - } - - { - name = "io.aviso/pretty"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "pretty"; - groupId = "io.aviso"; - sha512 = "416433ae5c5773a3a12e7cff3f75a43f1a2d3f4454aad04d065c1e4e13627130f289dbb41355a5665236082b6535939fc4c40a2fddcc22a40d0d4ba290544bfb"; - version = "1.1.1"; - }; - } - - { - name = "rewrite-clj/rewrite-clj"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "rewrite-clj"; - groupId = "rewrite-clj"; - sha512 = "04850f7b29be722be6c01760705be43e1b5b93315baa096925ceac94835b58702913c45c8166dadf193fb8f5150ff2c5539ae3ec85c37331727e5d0accfefcca"; - version = "1.1.45"; - }; - } - - { - name = "org.codehaus.plexus/plexus-utils"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "plexus-utils"; - groupId = "org.codehaus.plexus"; - sha512 = "3805c57b7297459c5e2754d0fd56abd454eee08691974fb930ebb9b79a529fd874f16d40cec66e7fd90d4146c9d1fef45cdb59f9e359fce0c48ac77526fc320d"; - version = "3.1.0"; - }; - } - - { - name = "org.apache.maven.resolver/maven-resolver-transport-file"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-resolver-transport-file"; - groupId = "org.apache.maven.resolver"; - sha512 = "a83cc067c0857f091787120dcbde00f2df5cd6379a02cca95a091aa243ca22dfbae634406c58373b391caf911dd6db3b4ff4a3d51768f4a61b1081e7c78bb252"; - version = "1.0.3"; - }; - } - - { - name = "slingshot/slingshot"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "slingshot"; - groupId = "slingshot"; - sha512 = "ff2b2a27b441d230261c7f3ec8c38aa551865e05ab6438a74bd12bfcbc5f6bdc88199d42aaf5932b47df84f3d2700c8f514b9f4e9b5da28d29da7ff6b09a7fb5"; - version = "0.12.2"; - }; - } - - { - name = "org.flatland/ordered"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "ordered"; - groupId = "org.flatland"; - sha512 = "849f115d8dc22122577bb6c2af383663488a84125303ba90559f4f5d8538693a5797d95aca608e6844413b925ea6e12112f0cf2d3dcacfcc603b50d749f7a25e"; - version = "1.15.10"; - }; - } - - { - name = "commons-io/commons-io"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "commons-io"; - groupId = "commons-io"; - sha512 = "1f6bfc215da9ae661dbabba80a0f29101a2d5e49c7d0c6ed760d1cafea005b7f0ff177b3b741e75b8e59804b0280fa453a76940b97e52b800ec03042f1692b07"; - version = "2.5"; - }; - } - - { - name = "org.apache.maven.wagon/wagon-http-shared"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "wagon-http-shared"; - groupId = "org.apache.maven.wagon"; - sha512 = "d4ef092c8ca8efd4295323d7bdb98315fcf574c2e5e227840847b936ab36095217583c5a807a27e21b831ade4cfbaa570278aa0d1a0144e92b90a42099b541f1"; - version = "3.0.0"; - }; - } - - { - name = "com.fasterxml.jackson.core/jackson-core"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "jackson-core"; - groupId = "com.fasterxml.jackson.core"; - sha512 = "d5337db908b2c56dcb911e3d1a5f671456c13f254fe8d2a620823bc15b2db6aaa8325a86b436b5d181f2584b533158fd14d140b98305ac252f8dfd9a627da859"; - version = "2.13.3"; - }; - } - - { - name = "org.yaml/snakeyaml"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "snakeyaml"; - groupId = "org.yaml"; - sha512 = "4322e41c6fc5114521da21787ab313fa74bf8449ab0c23ec830627b8121504f70d4522e880aec64df227164729d40b2fbd9670e3a046dd5a5aabc1f71e91c16c"; - version = "1.25"; - }; - } - - { - name = "org.ow2.asm/asm"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "asm"; - groupId = "org.ow2.asm"; - sha512 = "876eac7406e60ab8b9bd6cd3c221960eaa53febea176a88ae02f4fa92dbcfe80a3c764ba390d96b909c87269a30a69b1ee037a4c642c2f535df4ea2e0dd499f2"; - version = "9.2"; - }; - } - - { - name = "org.slf4j/jul-to-slf4j"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "jul-to-slf4j"; - groupId = "org.slf4j"; - sha512 = "152f153c42e5f69c95e3caeed5ab519e975d7ad79ac0199f31699646299b7ddab58068d5964fbd2170eed29966c3d8d1b00b0a1a4a6f698f9a9eb9c9b9d30dcb"; - version = "2.0.3"; - }; - } - - { - name = "org.apache.httpcomponents/httpcore"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "httpcore"; - groupId = "org.apache.httpcomponents"; - sha512 = "10814bfb8dcce31034f8fd6822f9da29299529b900616b78d8caf846748cf2b1e093f7b99db26a8580266e3346b822b5edb347004b0d13580e6df85cb327c93c"; - version = "4.4.6"; - }; - } - - { - name = "io.pedestal/pedestal.interceptor"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "pedestal.interceptor"; - groupId = "io.pedestal"; - sha512 = "b6d99300e2c656fc63841449067d74893c63f884d282ff1af40510e5e53baac0f17ac869212e0023dc01d3766248ce28e93e32a57239926254e3af0240c82178"; - version = "0.5.10"; - }; - } - - { - name = "io.dropwizard.metrics/metrics-core"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "metrics-core"; - groupId = "io.dropwizard.metrics"; - sha512 = "4b500efcc88e717dbbfff9629e12db0f23380bc7dbae820039ed730cdaf26fb6d5be6e58434bd6f688ea3d675576e2057ec183472aac99189817fc28b3c3489e"; - version = "4.1.0"; - }; - } - - { - name = "com.grammarly/omniconf"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "omniconf"; - groupId = "com.grammarly"; - sha512 = "2b13138090c9706af014b7d22b316af5300f41bfc70ee1f604ee6d817f70ca6227951f673231830c81888db2c50533f9c53de3e314d725a60b8eee99718655af"; - version = "0.4.3"; - }; - } - - { - name = "eu.neilalexander/jnacl"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "jnacl"; - groupId = "eu.neilalexander"; - sha512 = "addba1eae1975a71a204557dafb111c5c2aab39d9a7bb6428a26107935d95290139381c0a283b77e67b44e1d8110d3fa3919d7e7fc73e0023771beece4eab994"; - version = "1.0.0"; - }; - } - - { - name = "zprint/zprint"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "zprint"; - groupId = "zprint"; - sha512 = "2f29288a1d9dd7e76689b32616049af8ebc0e98f0994f1eae1c8e6e725084df23de11a4d6231d2712167ef4adfdfffe494cea2c11b6e752f81acd641381516eb"; - version = "1.2.4"; - }; - } - - { - name = "com.taoensso/truss"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "truss"; - groupId = "com.taoensso"; - sha512 = "79a515306228e8e8f1c1cf5bb65ac8c979954f3a6e8461c059a7b9402967163a1eb7a70de3ad41e8195d9dbfac2d17af8cc03e09bf72f8e9f6704b842656c0b9"; - version = "1.6.0"; - }; - } - - { - name = "org.apache.maven.resolver/maven-resolver-api"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-resolver-api"; - groupId = "org.apache.maven.resolver"; - sha512 = "d00cd4ec92bfafe88d9c4f4ce91e6c2d581d416a096743d396c1712a5788239cf2d55f910e1c0024034f7e0d8028ff602339b87c8fd3ad54f665a8b63d142e67"; - version = "1.1.1"; - }; - } - - { - name = "hiccup/hiccup"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "hiccup"; - groupId = "hiccup"; - sha512 = "419dd67281135feb31f74528907b785679066e22cf397f14a6d9439cb9c463d0db66436c214b2b1b5944be6b9d28e3fc7d9e4042de52f9633bf0825548c0f524"; - version = "2.0.0-alpha2"; - }; - } - - { - name = "io.opentracing/opentracing-api"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "opentracing-api"; - groupId = "io.opentracing"; - sha512 = "931197ca33e509570e389cd163af96e277bb3635f019e34e2fc97d3fa9c34bb9042f25b2ba8aa59f8516cc044ec3e9584462601b8aa5f954bbc6ad88e5fbe5cd"; - version = "0.33.0"; - }; - } - - { - name = "org.apache.maven/maven-resolver-provider"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-resolver-provider"; - groupId = "org.apache.maven"; - sha512 = "ec9e402084886554d247232b3dc5a971f6cbc93206759104ee7f94c7ba3ea2d69a715c68e479d2c64f6fe5045b6d7bd75cc3bb239462464ac608b0db1a5f0db5"; - version = "3.5.3"; - }; - } - - { - name = "commons-logging/commons-logging"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "commons-logging"; - groupId = "commons-logging"; - sha512 = "ed00dbfabd9ae00efa26dd400983601d076fe36408b7d6520084b447e5d1fa527ce65bd6afdcb58506c3a808323d28e88f26cb99c6f5db9ff64f6525ecdfa557"; - version = "1.2"; - }; - } - - { - name = "com.google.guava/guava"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "guava"; - groupId = "com.google.guava"; - sha512 = "d8736b5151df2dd052c09548a118af15a8b8b40999954cd093cfd301445accb8b7e9532b36bac8b2fab9234a24e2e05009a33d0a8e149e841ebddbcc733a8e4c"; - version = "20.0"; - }; - } - - { - name = "com.fzakaria/slf4j-timbre"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "slf4j-timbre"; - groupId = "com.fzakaria"; - sha512 = "9a25ed545a7dac8fb74096ed531fa4362989a1ed68350e63f403a871fdf19ab582c6f2c1c8e08978a431d8da31d8226bf34f1d0263ac5f6a14955ff56fdf9e17"; - version = "0.3.21"; - }; - } - - { - name = "clojure.java-time/clojure.java-time"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "clojure.java-time"; - groupId = "clojure.java-time"; - sha512 = "cd27eddad69554fcc443603bb69ab7dbe5d4cc937080f4b4d1ef3590e855faef2366dda77724da6c9b8941c340f8b5c5cb1345855f946718bd3ceb9c124a226a"; - version = "1.1.0"; - }; - } - - { - name = "org.apache.maven.resolver/maven-resolver-spi"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-resolver-spi"; - groupId = "org.apache.maven.resolver"; - sha512 = "bb58083c5ef2b6d3915acb368c80bd55ca6318925c606ad74e3e4ab2fc0066c7fa2480cefa34487c5349f1edff02131bbaa4c3a426f9a52d5a6a66a4a023d452"; - version = "1.1.1"; - }; - } - - { - name = "org.clojure/algo.generic"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "algo.generic"; - groupId = "org.clojure"; - sha512 = "2ded22096f7bf051fcc649d56fdb0ef2dddcb5490e22ce4d7e6f714d910db0cc7d453862b2180169641c21f0754b799036e4b0e7944c79f29d22dcb4152e384d"; - version = "0.1.3"; - }; - } - - { - name = "borkdude/edamame"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "edamame"; - groupId = "borkdude"; - sha512 = "5f5f36a85521464e97c0ada94581b37d7ffc7d1b9adaf7b3b509447bc0d6cedf339f12ae75d6bf679b69f9e1b582d0ee1a995bfd039657b17ec9a85516700fbe"; - version = "0.0.19"; - }; - } - - { - name = "com.taoensso/timbre"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "timbre"; - groupId = "com.taoensso"; - sha512 = "8c88eea8f0a94a3fc14f450a03e76ce0573d31f6c301252d3f9afc177f87a03326966197e8508e766f3caab61ef356142c6dc002e07ed09771f341dd6b290edf"; - version = "5.2.1"; - }; - } - - { - name = "org.clojure/java.jdbc"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "java.jdbc"; - groupId = "org.clojure"; - sha512 = "19e37ee3a16ccfdeb299e72ee0ae64a557b20296dd9461bf2288d0507e1d915ad6fcc56e4aadd712340f5c21e2c764ed7d4ad074eb8e4c82dc6ba5fe96111930"; - version = "0.7.12"; - }; - } - - { - name = "org.apache.maven.wagon/wagon-http"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "wagon-http"; - groupId = "org.apache.maven.wagon"; - sha512 = "e565e6541d53a5c2823a211586163707a5dbf5d9b3dd9f4a8d1d9dd2ffc0c8cf3ef2adb78d455235d22ede99d2e4619eb7f94d2a52eb0ffd119b52b33f9d89ba"; - version = "3.0.0"; - }; - } - - { - name = "io.opentracing/opentracing-noop"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "opentracing-noop"; - groupId = "io.opentracing"; - sha512 = "c727bcf20504fa72bfc07456bdde3b0b50988632d85c7af78df742efd90a431c125f5d644273203fa211a62fc4a282455cf281c7c82b82df4695afbc5488577f"; - version = "0.33.0"; - }; - } - - { - name = "net.cgrand/regex"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "regex"; - groupId = "net.cgrand"; - sha512 = "f0dfa4727818765364ce1793337597b06a2f95364245ab6c860e2373a98da55771e77a7eb772dcf415a336d8caad35673d5054e18b9494c3e1b9f882fecfb4d9"; - version = "1.1.0"; - }; - } - - { - name = "cider/cider-nrepl"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "cider-nrepl"; - groupId = "cider"; - sha512 = "e201944e32ce9b8fa328327c84f31d11cf5507a97b4fd3189a0304f4ebfd3bd557a1886335f295831941ac30d2b2394ad79a2897cb9bce506c0cbd8e04bbc40f"; - version = "0.26.0"; - }; - } - - { - name = "com.cemerick/pomegranate"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "pomegranate"; - groupId = "com.cemerick"; - sha512 = "a08137b575305aeff9858b93fc1febba92aaff27d9994e884c0e614f43704403cfb7e3e8d819a8151966c6439c178f4fb371003c392591dbc87b9e0fa64788fd"; - version = "1.1.0"; - }; - } - - { - name = "org.codehaus.plexus/plexus-interpolation"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "plexus-interpolation"; - groupId = "org.codehaus.plexus"; - sha512 = "d9183dc0920fb996901644903194883d1e1d1e8c4863f3c55bd6a9b14de996ee30651849435a92c8c55fc82be0e4524f1b2741957f9464434da292188ffcee70"; - version = "1.24"; - }; - } - - { - name = "org.apache.httpcomponents/httpclient"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "httpclient"; - groupId = "org.apache.httpcomponents"; - sha512 = "f8d4a960ed235770570afaf793c4596404adfa777e08bdb87ae2db92575db5e11755025fe43969f852ef505a390833e79bdd1fccd5f3fb7dee87625607b504a2"; - version = "4.5.3"; - }; - } - - { - name = "cheshire/cheshire"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "cheshire"; - groupId = "cheshire"; - sha512 = "2262573047d194bba28b3d2ca4b00b12f8171d6f8f7f5449df35f10ab1ef5902a9ba2f9937399d6e4b54a78bda919fa205a22a44cde998019bc0cfc508e90f29"; - version = "5.11.0"; - }; - } - - { - name = "tigris/tigris"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "tigris"; - groupId = "tigris"; - sha512 = "fdff4ef5e7175a973aaef98de4f37dee8e125fc711c495382e280aaf3e11341fe8925d52567ca60f3f1795511ade11bc23461c88959632dfae3cf50374d02bf6"; - version = "0.1.2"; - }; - } - - { - name = "org.clojure/core.match"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "core.match"; - groupId = "org.clojure"; - sha512 = "d69ed23bad115ed665b402886e1946fcecacbbfd05150f3eb66dce9ffc0381d0e02ed6f41cb390a6dfb74f4f26e3b0f6793dec38f6a4622dc53c0739d79f5f5e"; - version = "0.3.0"; - }; - } - - { - name = "org.clojure/tools.reader"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "tools.reader"; - groupId = "org.clojure"; - sha512 = "3481259c7a1eac719db2921e60173686726a0c2b65879d51a64d516a37f6120db8ffbb74b8bd273404285d7b25143ab5c7ced37e7c0eaf4ab1e44586ccd3c651"; - version = "1.3.6"; - }; - } - - { - name = "org.tcrawley/dynapath"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "dynapath"; - groupId = "org.tcrawley"; - sha512 = "1b0caf390515212e6b151d6c227b1a62e430e682b6c811736edba3cc918344053e35c092e12afd523198ed6244018450931776f8388e61a593f266476b6db19e"; - version = "1.0.0"; - }; - } - - { - name = "org.babashka/sci"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "sci"; - groupId = "org.babashka"; - sha512 = "2897029dba4917facf93935229f1288d9e90973e8dbc8ff84448335452815274c23371ab643c35df0b1854ff6de1574c37880267fd0edd900039f5a1678d73c5"; - version = "0.3.4"; - }; - } - - { - name = "io.opentracing/opentracing-util"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "opentracing-util"; - groupId = "io.opentracing"; - sha512 = "fbba29ff3d6018561077e9539ad9b72876424600eca3addb6a26981a4a3e52cb3dfd30f27945aff2b6c222c42454ce3ba67597171fd809a74c65b920f3a47c7a"; - version = "0.33.0"; - }; - } - - { - name = "org.jsoup/jsoup"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "jsoup"; - groupId = "org.jsoup"; - sha512 = "8119ec44ee622c75f47a80dedeadf557744208dc49d3d9f579660929a0be3f71d3b8cb4aed64ee31f6bf7488bfc3516fb3980137d2fc63063caf46c9921f19f0"; - version = "1.7.2"; - }; - } - - { - name = "nrepl/nrepl"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "nrepl"; - groupId = "nrepl"; - sha512 = "92534555cc5fa45e8990b8566996fe784df368849e0938fbc7a89909ccbb62dd7d4fca9b7aa3c615702ec30f9962a460c500f6b60abc72661c5f4c66414fc395"; - version = "1.0.0"; - }; - } - - { - name = "org.apache.maven.resolver/maven-resolver-connector-basic"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-resolver-connector-basic"; - groupId = "org.apache.maven.resolver"; - sha512 = "c8c14480ed89cf5d4cfec5dee7dae366b0b5d003cd835d4b1358add81253b205a53f6a62e5ecc145f09406fc8c57adb5fbf8f4521a044ac3d37b5fa8e67d4e21"; - version = "1.0.3"; - }; - } - - { - name = "org.xerial/sqlite-jdbc"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "sqlite-jdbc"; - groupId = "org.xerial"; - sha512 = "f4c27027fe3cb7914aaf155a1afaa0c8b455e5d142b4e5f31d87bfe619c9949e1981ba7eed1f7a8a3cd27edba1321cc4cd74cf4321ae800e8a911b4d94e03930"; - version = "3.39.3.0"; - }; - } - - { - name = "org.apache.maven.resolver/maven-resolver-impl"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-resolver-impl"; - groupId = "org.apache.maven.resolver"; - sha512 = "3ffcac7ed4a05b2b58669ce05cc348acad627be3e0941ee28a9a665fea43a571d554005dd72ec51130083f792e31894880525df3cd6962d7c95885340abfb7da"; - version = "1.1.1"; - }; - } - - { - name = "org.slf4j/slf4j-api"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "slf4j-api"; - groupId = "org.slf4j"; - sha512 = "cf50d5cc86404fefa49730da36147db5f6d65c8b06163bbf62311e6874c20ca46db02ab6bda27c9c1485a5c57fe63b89fd3000b8d838c429240ee95734f5901e"; - version = "2.0.3"; - }; - } - - { - name = "org.apache.maven/maven-model"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-model"; - groupId = "org.apache.maven"; - sha512 = "888a778101774265e0d8dbc96305274053d275c0b261e81c6aae8765f92b13d1e06c5aa8f51c7d53d5267e46041adc9218686e53fc47cc15563a1b178291bc16"; - version = "3.5.3"; - }; - } - - { - name = "org.clojure/test.check"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "test.check"; - groupId = "org.clojure"; - sha512 = "b8d7a330b0b5514cd6a00c4382052fab51c3c9d3bc53133f8506791fa670e7c5ecd65094977ea5ced91f59623b0abd1ab8feeec96d63c5c6e459b265a655c577"; - version = "1.1.1"; - }; - } - - { - name = "org.apache.maven.resolver/maven-resolver-util"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-resolver-util"; - groupId = "org.apache.maven.resolver"; - sha512 = "91dcbb8184f06e64da35d40c7b96e854f7311b6232d74b4b6d3489a51e0c05ebbee44f59367ab118974cdb6c5b3747981a41869cc7372691b2c2e1d0daa2ffa3"; - version = "1.1.1"; - }; - } - - { - name = "io.dropwizard.metrics/metrics-jmx"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "metrics-jmx"; - groupId = "io.dropwizard.metrics"; - sha512 = "706f7428b967923d2792b0587684e972b1404d663a6ac3d661772a57edf096f0de0efac8bbfcead4576c008b096c33f77499e8f193ccbb8b072d7aa6e6d7a40d"; - version = "4.1.0"; - }; - } - - { - name = "io.forward/yaml"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "yaml"; - groupId = "io.forward"; - sha512 = "e2d3b7aea260346a1db44bcc3c363877d0ff2b327c4fd287759782949b1a498bc8019f06ddabee84443b96b07ea4765443f8190e04f5f903de049e2cc0fd63e9"; - version = "1.0.11"; - }; - } - - { - name = "me.raynes/fs"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "fs"; - groupId = "me.raynes"; - sha512 = "b72af0093c1feccf78ea0632ba523eca89436b0575abc0af484e03570011aa89f429f9820a9fc27f60da113d728d2bbc09ba26d3a0cdd63d9d9c7775643f6852"; - version = "1.4.6"; - }; - } - - { - name = "org.clojure/core.memoize"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "core.memoize"; - groupId = "org.clojure"; - sha512 = "67196537084b7cc34a01454d2a3b72de3fddce081b72d7a6dc1592d269a6c2728b79630bd2d52c1bf2d2f903c12add6f23df954c02ef8237f240d7394ccc3dde"; - version = "1.0.253"; - }; - } - - { - name = "org.apache.maven/maven-repository-metadata"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-repository-metadata"; - groupId = "org.apache.maven"; - sha512 = "6d898373d483ac7f24ab0256406f4be45035f95a247bb19ac7102ea7f5e336976381c5125b30a7148bc9a8e1df6d27b456d1f8e9b55b99d9688e37dfd03733a3"; - version = "3.5.3"; - }; - } - - { - name = "io.simplect/compose"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "compose"; - groupId = "io.simplect"; - sha512 = "0aceab86d4a97285ddd6d40abdeb5b9bea16a16b6509ef2fcd80e547d772185041e26abcc12ae11938d7b78fed175850f811d5cb2a2f0590524c2c11975bacd1"; - version = "0.7.27"; - }; - } - - { - name = "org.clojure/data.priority-map"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "data.priority-map"; - groupId = "org.clojure"; - sha512 = "bb8bc5dbfd3738c36b99a51880ac3f1381d6564e67601549ef5e7ae2b900e53cdcdfb8d0fa4bf32fb8ebc4de89d954bfa3ab7e8a1122bc34ee5073c7c707ac13"; - version = "1.1.0"; - }; - } - - { - name = "borkdude/sci.impl.reflector"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "sci.impl.reflector"; - groupId = "borkdude"; - sha512 = "c747fd347e6aba9578d105298b7c7402f53e8639d5c8e6dc83b127f3c413feeb1b9dead7405ac2c4345f02290902e8a2affbec749474481e9c9f19b3d049f18f"; - version = "0.0.1"; - }; - } - - { - name = "org.apache.maven/maven-builder-support"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-builder-support"; - groupId = "org.apache.maven"; - sha512 = "1b2ca4427772532cfb93b4d643b17eca5843f1e1a9c4b26089eed8c10028344fb85d593d133fdffaff07b552c3027a9f24e1a92d68ed4696682be04069e84583"; - version = "3.5.3"; - }; - } - - { - name = "org.slf4j/log4j-over-slf4j"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "log4j-over-slf4j"; - groupId = "org.slf4j"; - sha512 = "a1f90d8ea338660cc0e38073752cf32e46a042bc408477d841ba7ad69ad0d066bbbf9d4c399a34352d620ba9d2402c7a51574a88f314ddcc796c35adc99c37f4"; - version = "2.0.3"; - }; - } - - { - name = "org.clojure/core.cache"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "core.cache"; - groupId = "org.clojure"; - sha512 = "0a07ceffc2fa3a536b23773eefc7ef5e1108913b93c3a5416116a6566de76dd5c218f3fb0cc19415cbaa8843838de310b76282f20bf1fc3467006c9ec373667e"; - version = "1.0.225"; - }; - } - - { - name = "org.clojure/core.async"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "core.async"; - groupId = "org.clojure"; - sha512 = "160a77da25382d7c257eee56cfe83538620576a331e025a2d672fc26d9f04e606666032395f3c2e26247c782544816a5862348f3a921b1ffffcd309c62ac64f5"; - version = "1.5.648"; - }; - } - - { - name = "com.fasterxml.jackson.dataformat/jackson-dataformat-smile"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "jackson-dataformat-smile"; - groupId = "com.fasterxml.jackson.dataformat"; - sha512 = "4c1566aa4fac309de8fba08ea355165cf2a888b7bcec98e7035ac8acd7315e340415a10b8deec6497fc4eea5ba9319fc989676170d8c4c0d0bbc3d4f3cc4d681"; - version = "2.13.3"; - }; - } - - { - name = "org.apache.maven/maven-artifact"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "maven-artifact"; - groupId = "org.apache.maven"; - sha512 = "a4cafc89d66c8f074c5c3f9454e5077abc0de6242c29904d8ee5816348af21b1006da67f3118478bc9eb067725c39be9b88e4a019eb8368c936f971f0499c2ca"; - version = "3.5.3"; - }; - } - - { - name = "org.clojure/data.codec"; - path = pkgs.fetchMavenArtifact { - inherit repos; - artifactId = "data.codec"; - groupId = "org.clojure"; - sha512 = "cb6910fc0ee47ce6959a442ba3ef456dd91fe8589a576526d20fd661c8d305962f64a8e8ebde69f0bd00082027dbd0ac52b642fcd4950b4f0e5b7a1205f95138"; - version = "0.1.1"; - }; - } +{ + pkgs ? import { }, +}: + +let + repos = [ + "https://repo1.maven.org/maven2/" + "https://repo.clojars.org/" + "http://oss.sonatype.org/content/repositories/releases/" + "http://oss.sonatype.org/content/repositories/public/" + "http://repo.typesafe.com/typesafe/releases/" + ]; + +in +rec { + makePaths = + { + extraClasspaths ? [ ], + }: + (builtins.map (dep: if builtins.hasAttr "jar" dep.path then dep.path.jar else dep.path) packages) + ++ extraClasspaths; + makeClasspaths = + { + extraClasspaths ? [ ], + }: + builtins.concatStringsSep ":" (makePaths { + inherit extraClasspaths; + }); + + packages = [ + { + name = "javax.inject/javax.inject"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "javax.inject"; + groupId = "javax.inject"; + sha512 = "e126b7ccf3e42fd1984a0beef1004a7269a337c202e59e04e8e2af714280d2f2d8d2ba5e6f59481b8dcd34aaf35c966a688d0b48ec7e96f102c274dc0d3b381e"; + version = "1"; + }; + } + + { + name = "org.clojure/data.json"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "data.json"; + groupId = "org.clojure"; + sha512 = "04b7c0c90cb26d643a0b3e7e1ffa2d2d423e977c1454ee5ea7c2e75547ecbc113838df17b797902a975f5ea2184a81a45b605a4d82970805e2bbb02feebc578d"; + version = "2.4.0"; + }; + } + + { + name = "org.clojure/clojure"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "clojure"; + groupId = "org.clojure"; + sha512 = "1925300a0fe4cc9fc3985910bb04ae65a19ce274dacc5ec76e708cfa87a7952a0a77282b083d0aebb2206afff619af73a57f0d661a3423601586f0829cc7956b"; + version = "1.11.1"; + }; + } + + { + name = "net.cgrand/sjacket"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "sjacket"; + groupId = "net.cgrand"; + sha512 = "34a359a0a633f116147e5bd52d4f4a9cd755636ce0e8abf155da9c3f04b07f93bbbf7c1f8e370db922e14da0efd36a5b127ff9e564141ca7a843f0498a8b860a"; + version = "0.1.1"; + }; + } + + { + name = "clojupyter/clojupyter"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "clojupyter"; + groupId = "clojupyter"; + sha512 = "9a4f001cbde7a4de2d27859b25e508ba649225acf9dabad4c1c274e86674e0dcde250a49cacd0767bb99f5b15a61e2f1c829fb2fe7b7dfc4b87681b7ae0b04ae"; + version = "0.3.6"; + }; + } + + { + name = "commons-codec/commons-codec"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "commons-codec"; + groupId = "commons-codec"; + sha512 = "b65531ead8500493e3dd14a860224851b80f438fc53bf8868b443a0557d839a2b0c868e4fedcf99579ae04b6b2bbd8cdb37f9921ad785983c37569aa9d2e8102"; + version = "1.9"; + }; + } + + { + name = "org.clojure/tools.analyzer"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "tools.analyzer"; + groupId = "org.clojure"; + sha512 = "c51752a714848247b05c6f98b54276b4fe8fd44b3d970070b0f30cd755ac6656030fd8943a1ffd08279af8eeff160365be47791e48f05ac9cc2488b6e2dfe504"; + version = "1.1.0"; + }; + } + + { + name = "org.codehaus.plexus/plexus-component-annotations"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "plexus-component-annotations"; + groupId = "org.codehaus.plexus"; + sha512 = "e20aa9fdb3fda4126f55ef45c36362138c6554ede40fa266ff6b63fe1c3b4d699f9eb95793f26527e096ec7567874aa7af5fe84124815729fdb2d4abaa9ddea8"; + version = "1.7.1"; + }; + } + + { + name = "org.apache.commons/commons-compress"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "commons-compress"; + groupId = "org.apache.commons"; + sha512 = "f3e077ff7f69992961d744dc513eca93606e472e3733657636808a7f50c17f39e3de8367a1af7972cb158f05725808627b6232585a81f197c0da3eff0336913e"; + version = "1.8"; + }; + } + + { + name = "org.apache.commons/commons-lang3"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "commons-lang3"; + groupId = "org.apache.commons"; + sha512 = "9e6ff20e891b6835d5926c90f237d55931e75723c8b88d6417926393e077e71013dab006372d34a6b5801e6ca3ce080a00f202cba700cab5aabfc17bbbdcab36"; + version = "3.5"; + }; + } + + { + name = "org.clojure/core.specs.alpha"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "core.specs.alpha"; + groupId = "org.clojure"; + sha512 = "f521f95b362a47bb35f7c85528c34537f905fb3dd24f2284201e445635a0df701b35d8419d53c6507cc78d3717c1f83cda35ea4c82abd8943cd2ab3de3fcad70"; + version = "0.2.62"; + }; + } + + { + name = "org.tukaani/xz"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "xz"; + groupId = "org.tukaani"; + sha512 = "c5c130bf22f24f61b57fc0c6243e7f961ca2a8928416e8bb288aec6650c1c1c06ace4383913cd1277fc6785beb9a74458807ea7e3d6b2e09189cfaf2fb9ab7e1"; + version = "1.5"; + }; + } + + { + name = "org.zeromq/jeromq"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "jeromq"; + groupId = "org.zeromq"; + sha512 = "bd502d345926160b1a09e45f60eb81254dc67d6d9d7b79e025c08018dd16a18d32ff85b2440c352d530e61c96cd3b2d88fee2a8a912b436015ed31039e308ff4"; + version = "0.5.2"; + }; + } + + { + name = "org.clojure/spec.alpha"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "spec.alpha"; + groupId = "org.clojure"; + sha512 = "ddfe4fa84622abd8ac56e2aa565a56e6bdc0bf330f377ff3e269ddc241bb9dbcac332c13502dfd4c09c2c08fe24d8d2e8cf3d04a1bc819ca5657b4e41feaa7c2"; + version = "0.3.218"; + }; + } + + { + name = "pandect/pandect"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "pandect"; + groupId = "pandect"; + sha512 = "6179967af34e1abbe0dda2bd0961f101d016df6b1ce5bf4bb823794b07ee551d245d09e957a9c47bc3a15d306cca80ad1b9b11be99e1b3feb245c26e1b9154a3"; + version = "1.0.2"; + }; + } + + { + name = "org.clojure/tools.cli"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "tools.cli"; + groupId = "org.clojure"; + sha512 = "1d88aa03eb6a664bf2c0ce22c45e7296d54d716e29b11904115be80ea1661623cf3e81fc222d164047058239010eb678af92ffedc7c3006475cceb59f3b21265"; + version = "1.0.206"; + }; + } + + { + name = "com.taoensso/encore"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "encore"; + groupId = "com.taoensso"; + sha512 = "43dbec081c4ad7b21526371bc78844877d50dd08580c4c039c4dac7e854247a6b145bda835460863fa91d270e81783ddcdad3aaa1a902575be5b21ac0a95c7d0"; + version = "3.21.0"; + }; + } + + { + name = "org.apache.maven.resolver/maven-resolver-transport-wagon"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-resolver-transport-wagon"; + groupId = "org.apache.maven.resolver"; + sha512 = "b7a4dcd2f9bb39bfd561e9b2a8fc087bd9e7e59136ea7787341c173fa22c6b8e9370117ed6c30b0c930dd5b188fab2f2b060042861df19e79772a74c703fcf64"; + version = "1.0.3"; + }; + } + + { + name = "org.slf4j/jcl-over-slf4j"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "jcl-over-slf4j"; + groupId = "org.slf4j"; + sha512 = "17aca766b01f136d39bda982a6046d01d296ee076d9628e9776256bd931bbd88437377d5f1cc196d75bd7fa1672dd131311dbf567b4c3a618dd538a6905fbb64"; + version = "2.0.3"; + }; + } + + { + name = "org.clojure/tools.analyzer.jvm"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "tools.analyzer.jvm"; + groupId = "org.clojure"; + sha512 = "36ad50a7a79c47dea16032fc4b927bd7b56b8bedcbd20cc9c1b9c85edede3a455369b8806509b56a48457dcd32e1f708f74228bce2b4492bd6ff6fc4f1219d56"; + version = "1.2.2"; + }; + } + + { + name = "org.apache.maven.wagon/wagon-provider-api"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "wagon-provider-api"; + groupId = "org.apache.maven.wagon"; + sha512 = "4571002ad5bfc0442bb2eaf32ec42675dc0a179413230615475842bba12fb561159ffc0213127cf241088641a218627e84049b715b9e71ed83d960f4f09da985"; + version = "3.0.0"; + }; + } + + { + name = "io.pedestal/pedestal.log"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "pedestal.log"; + groupId = "io.pedestal"; + sha512 = "229c6c73dc7ec39aee15f54ce81cf2b33301e444241f2dff2066b4c10ff47968f3caa95a8a918601e8f3e7563b34da6925e533615e7ce8b1f39bdb97ca082757"; + version = "0.5.10"; + }; + } + + { + name = "com.fasterxml.jackson.dataformat/jackson-dataformat-cbor"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "jackson-dataformat-cbor"; + groupId = "com.fasterxml.jackson.dataformat"; + sha512 = "b6e16c43fb3e71f82f8e7dc558f53cbcc8fea31efa59f40d22220f6e40167cf32c150efa18a81f839008d6a042e201bf17d8fd52a4fecbe8f356454f2d6a6170"; + version = "2.13.3"; + }; + } + + { + name = "org.apache.maven.resolver/maven-resolver-transport-http"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-resolver-transport-http"; + groupId = "org.apache.maven.resolver"; + sha512 = "97c23620a57406a8d87a08ab2897355afcce4b53b397ef7d13b4254cb07e965b51f05e21ce2d77ea93c4dbc63f32b3f07ff2171bccfe2b4f21116569968a003e"; + version = "1.0.3"; + }; + } + + { + name = "net.cgrand/parsley"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "parsley"; + groupId = "net.cgrand"; + sha512 = "e114f9e5709b9a38214aabc2b7bb33984693a4302fd8570bb91956bce2755d69b6ee2eaa7224137e306ab1f830672eee928e030677f50739edc62314429fa1f7"; + version = "0.9.3"; + }; + } + + { + name = "funcool/cats"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "cats"; + groupId = "funcool"; + sha512 = "83ccb058078c3c380435512e6f92cfc117244fab4819db776eb963d3b488ac92ca70a783b5d3b776d9d4cf06d9de5d3730c07ce6e7013e6717ba28335601ece8"; + version = "2.3.2"; + }; + } + + { + name = "org.apache.maven/maven-model-builder"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-model-builder"; + groupId = "org.apache.maven"; + sha512 = "6684b58d14e7d037f240ae15ee0456d27354c9dd93a1dc2bdbb66f399b012ffe8ff67a1dd83ee1e45c07fd91af77909a9c19d6b29791002d5b5acf23ca75dcb2"; + version = "3.5.3"; + }; + } + + { + name = "io.aviso/pretty"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "pretty"; + groupId = "io.aviso"; + sha512 = "416433ae5c5773a3a12e7cff3f75a43f1a2d3f4454aad04d065c1e4e13627130f289dbb41355a5665236082b6535939fc4c40a2fddcc22a40d0d4ba290544bfb"; + version = "1.1.1"; + }; + } + + { + name = "rewrite-clj/rewrite-clj"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "rewrite-clj"; + groupId = "rewrite-clj"; + sha512 = "04850f7b29be722be6c01760705be43e1b5b93315baa096925ceac94835b58702913c45c8166dadf193fb8f5150ff2c5539ae3ec85c37331727e5d0accfefcca"; + version = "1.1.45"; + }; + } + + { + name = "org.codehaus.plexus/plexus-utils"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "plexus-utils"; + groupId = "org.codehaus.plexus"; + sha512 = "3805c57b7297459c5e2754d0fd56abd454eee08691974fb930ebb9b79a529fd874f16d40cec66e7fd90d4146c9d1fef45cdb59f9e359fce0c48ac77526fc320d"; + version = "3.1.0"; + }; + } + + { + name = "org.apache.maven.resolver/maven-resolver-transport-file"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-resolver-transport-file"; + groupId = "org.apache.maven.resolver"; + sha512 = "a83cc067c0857f091787120dcbde00f2df5cd6379a02cca95a091aa243ca22dfbae634406c58373b391caf911dd6db3b4ff4a3d51768f4a61b1081e7c78bb252"; + version = "1.0.3"; + }; + } + + { + name = "slingshot/slingshot"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "slingshot"; + groupId = "slingshot"; + sha512 = "ff2b2a27b441d230261c7f3ec8c38aa551865e05ab6438a74bd12bfcbc5f6bdc88199d42aaf5932b47df84f3d2700c8f514b9f4e9b5da28d29da7ff6b09a7fb5"; + version = "0.12.2"; + }; + } + + { + name = "org.flatland/ordered"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "ordered"; + groupId = "org.flatland"; + sha512 = "849f115d8dc22122577bb6c2af383663488a84125303ba90559f4f5d8538693a5797d95aca608e6844413b925ea6e12112f0cf2d3dcacfcc603b50d749f7a25e"; + version = "1.15.10"; + }; + } + + { + name = "commons-io/commons-io"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "commons-io"; + groupId = "commons-io"; + sha512 = "1f6bfc215da9ae661dbabba80a0f29101a2d5e49c7d0c6ed760d1cafea005b7f0ff177b3b741e75b8e59804b0280fa453a76940b97e52b800ec03042f1692b07"; + version = "2.5"; + }; + } + + { + name = "org.apache.maven.wagon/wagon-http-shared"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "wagon-http-shared"; + groupId = "org.apache.maven.wagon"; + sha512 = "d4ef092c8ca8efd4295323d7bdb98315fcf574c2e5e227840847b936ab36095217583c5a807a27e21b831ade4cfbaa570278aa0d1a0144e92b90a42099b541f1"; + version = "3.0.0"; + }; + } + + { + name = "com.fasterxml.jackson.core/jackson-core"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "jackson-core"; + groupId = "com.fasterxml.jackson.core"; + sha512 = "d5337db908b2c56dcb911e3d1a5f671456c13f254fe8d2a620823bc15b2db6aaa8325a86b436b5d181f2584b533158fd14d140b98305ac252f8dfd9a627da859"; + version = "2.13.3"; + }; + } + + { + name = "org.yaml/snakeyaml"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "snakeyaml"; + groupId = "org.yaml"; + sha512 = "4322e41c6fc5114521da21787ab313fa74bf8449ab0c23ec830627b8121504f70d4522e880aec64df227164729d40b2fbd9670e3a046dd5a5aabc1f71e91c16c"; + version = "1.25"; + }; + } + + { + name = "org.ow2.asm/asm"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "asm"; + groupId = "org.ow2.asm"; + sha512 = "876eac7406e60ab8b9bd6cd3c221960eaa53febea176a88ae02f4fa92dbcfe80a3c764ba390d96b909c87269a30a69b1ee037a4c642c2f535df4ea2e0dd499f2"; + version = "9.2"; + }; + } + + { + name = "org.slf4j/jul-to-slf4j"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "jul-to-slf4j"; + groupId = "org.slf4j"; + sha512 = "152f153c42e5f69c95e3caeed5ab519e975d7ad79ac0199f31699646299b7ddab58068d5964fbd2170eed29966c3d8d1b00b0a1a4a6f698f9a9eb9c9b9d30dcb"; + version = "2.0.3"; + }; + } + + { + name = "org.apache.httpcomponents/httpcore"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "httpcore"; + groupId = "org.apache.httpcomponents"; + sha512 = "10814bfb8dcce31034f8fd6822f9da29299529b900616b78d8caf846748cf2b1e093f7b99db26a8580266e3346b822b5edb347004b0d13580e6df85cb327c93c"; + version = "4.4.6"; + }; + } + + { + name = "io.pedestal/pedestal.interceptor"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "pedestal.interceptor"; + groupId = "io.pedestal"; + sha512 = "b6d99300e2c656fc63841449067d74893c63f884d282ff1af40510e5e53baac0f17ac869212e0023dc01d3766248ce28e93e32a57239926254e3af0240c82178"; + version = "0.5.10"; + }; + } + + { + name = "io.dropwizard.metrics/metrics-core"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "metrics-core"; + groupId = "io.dropwizard.metrics"; + sha512 = "4b500efcc88e717dbbfff9629e12db0f23380bc7dbae820039ed730cdaf26fb6d5be6e58434bd6f688ea3d675576e2057ec183472aac99189817fc28b3c3489e"; + version = "4.1.0"; + }; + } + + { + name = "com.grammarly/omniconf"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "omniconf"; + groupId = "com.grammarly"; + sha512 = "2b13138090c9706af014b7d22b316af5300f41bfc70ee1f604ee6d817f70ca6227951f673231830c81888db2c50533f9c53de3e314d725a60b8eee99718655af"; + version = "0.4.3"; + }; + } + + { + name = "eu.neilalexander/jnacl"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "jnacl"; + groupId = "eu.neilalexander"; + sha512 = "addba1eae1975a71a204557dafb111c5c2aab39d9a7bb6428a26107935d95290139381c0a283b77e67b44e1d8110d3fa3919d7e7fc73e0023771beece4eab994"; + version = "1.0.0"; + }; + } + + { + name = "zprint/zprint"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "zprint"; + groupId = "zprint"; + sha512 = "2f29288a1d9dd7e76689b32616049af8ebc0e98f0994f1eae1c8e6e725084df23de11a4d6231d2712167ef4adfdfffe494cea2c11b6e752f81acd641381516eb"; + version = "1.2.4"; + }; + } + + { + name = "com.taoensso/truss"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "truss"; + groupId = "com.taoensso"; + sha512 = "79a515306228e8e8f1c1cf5bb65ac8c979954f3a6e8461c059a7b9402967163a1eb7a70de3ad41e8195d9dbfac2d17af8cc03e09bf72f8e9f6704b842656c0b9"; + version = "1.6.0"; + }; + } + + { + name = "org.apache.maven.resolver/maven-resolver-api"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-resolver-api"; + groupId = "org.apache.maven.resolver"; + sha512 = "d00cd4ec92bfafe88d9c4f4ce91e6c2d581d416a096743d396c1712a5788239cf2d55f910e1c0024034f7e0d8028ff602339b87c8fd3ad54f665a8b63d142e67"; + version = "1.1.1"; + }; + } + + { + name = "hiccup/hiccup"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "hiccup"; + groupId = "hiccup"; + sha512 = "419dd67281135feb31f74528907b785679066e22cf397f14a6d9439cb9c463d0db66436c214b2b1b5944be6b9d28e3fc7d9e4042de52f9633bf0825548c0f524"; + version = "2.0.0-alpha2"; + }; + } + + { + name = "io.opentracing/opentracing-api"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "opentracing-api"; + groupId = "io.opentracing"; + sha512 = "931197ca33e509570e389cd163af96e277bb3635f019e34e2fc97d3fa9c34bb9042f25b2ba8aa59f8516cc044ec3e9584462601b8aa5f954bbc6ad88e5fbe5cd"; + version = "0.33.0"; + }; + } + + { + name = "org.apache.maven/maven-resolver-provider"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-resolver-provider"; + groupId = "org.apache.maven"; + sha512 = "ec9e402084886554d247232b3dc5a971f6cbc93206759104ee7f94c7ba3ea2d69a715c68e479d2c64f6fe5045b6d7bd75cc3bb239462464ac608b0db1a5f0db5"; + version = "3.5.3"; + }; + } + + { + name = "commons-logging/commons-logging"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "commons-logging"; + groupId = "commons-logging"; + sha512 = "ed00dbfabd9ae00efa26dd400983601d076fe36408b7d6520084b447e5d1fa527ce65bd6afdcb58506c3a808323d28e88f26cb99c6f5db9ff64f6525ecdfa557"; + version = "1.2"; + }; + } + + { + name = "com.google.guava/guava"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "guava"; + groupId = "com.google.guava"; + sha512 = "d8736b5151df2dd052c09548a118af15a8b8b40999954cd093cfd301445accb8b7e9532b36bac8b2fab9234a24e2e05009a33d0a8e149e841ebddbcc733a8e4c"; + version = "20.0"; + }; + } + + { + name = "com.fzakaria/slf4j-timbre"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "slf4j-timbre"; + groupId = "com.fzakaria"; + sha512 = "9a25ed545a7dac8fb74096ed531fa4362989a1ed68350e63f403a871fdf19ab582c6f2c1c8e08978a431d8da31d8226bf34f1d0263ac5f6a14955ff56fdf9e17"; + version = "0.3.21"; + }; + } + + { + name = "clojure.java-time/clojure.java-time"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "clojure.java-time"; + groupId = "clojure.java-time"; + sha512 = "cd27eddad69554fcc443603bb69ab7dbe5d4cc937080f4b4d1ef3590e855faef2366dda77724da6c9b8941c340f8b5c5cb1345855f946718bd3ceb9c124a226a"; + version = "1.1.0"; + }; + } + + { + name = "org.apache.maven.resolver/maven-resolver-spi"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-resolver-spi"; + groupId = "org.apache.maven.resolver"; + sha512 = "bb58083c5ef2b6d3915acb368c80bd55ca6318925c606ad74e3e4ab2fc0066c7fa2480cefa34487c5349f1edff02131bbaa4c3a426f9a52d5a6a66a4a023d452"; + version = "1.1.1"; + }; + } + + { + name = "org.clojure/algo.generic"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "algo.generic"; + groupId = "org.clojure"; + sha512 = "2ded22096f7bf051fcc649d56fdb0ef2dddcb5490e22ce4d7e6f714d910db0cc7d453862b2180169641c21f0754b799036e4b0e7944c79f29d22dcb4152e384d"; + version = "0.1.3"; + }; + } + + { + name = "borkdude/edamame"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "edamame"; + groupId = "borkdude"; + sha512 = "5f5f36a85521464e97c0ada94581b37d7ffc7d1b9adaf7b3b509447bc0d6cedf339f12ae75d6bf679b69f9e1b582d0ee1a995bfd039657b17ec9a85516700fbe"; + version = "0.0.19"; + }; + } + + { + name = "com.taoensso/timbre"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "timbre"; + groupId = "com.taoensso"; + sha512 = "8c88eea8f0a94a3fc14f450a03e76ce0573d31f6c301252d3f9afc177f87a03326966197e8508e766f3caab61ef356142c6dc002e07ed09771f341dd6b290edf"; + version = "5.2.1"; + }; + } + + { + name = "org.clojure/java.jdbc"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "java.jdbc"; + groupId = "org.clojure"; + sha512 = "19e37ee3a16ccfdeb299e72ee0ae64a557b20296dd9461bf2288d0507e1d915ad6fcc56e4aadd712340f5c21e2c764ed7d4ad074eb8e4c82dc6ba5fe96111930"; + version = "0.7.12"; + }; + } + + { + name = "org.apache.maven.wagon/wagon-http"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "wagon-http"; + groupId = "org.apache.maven.wagon"; + sha512 = "e565e6541d53a5c2823a211586163707a5dbf5d9b3dd9f4a8d1d9dd2ffc0c8cf3ef2adb78d455235d22ede99d2e4619eb7f94d2a52eb0ffd119b52b33f9d89ba"; + version = "3.0.0"; + }; + } + + { + name = "io.opentracing/opentracing-noop"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "opentracing-noop"; + groupId = "io.opentracing"; + sha512 = "c727bcf20504fa72bfc07456bdde3b0b50988632d85c7af78df742efd90a431c125f5d644273203fa211a62fc4a282455cf281c7c82b82df4695afbc5488577f"; + version = "0.33.0"; + }; + } + + { + name = "net.cgrand/regex"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "regex"; + groupId = "net.cgrand"; + sha512 = "f0dfa4727818765364ce1793337597b06a2f95364245ab6c860e2373a98da55771e77a7eb772dcf415a336d8caad35673d5054e18b9494c3e1b9f882fecfb4d9"; + version = "1.1.0"; + }; + } + + { + name = "cider/cider-nrepl"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "cider-nrepl"; + groupId = "cider"; + sha512 = "e201944e32ce9b8fa328327c84f31d11cf5507a97b4fd3189a0304f4ebfd3bd557a1886335f295831941ac30d2b2394ad79a2897cb9bce506c0cbd8e04bbc40f"; + version = "0.26.0"; + }; + } + + { + name = "com.cemerick/pomegranate"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "pomegranate"; + groupId = "com.cemerick"; + sha512 = "a08137b575305aeff9858b93fc1febba92aaff27d9994e884c0e614f43704403cfb7e3e8d819a8151966c6439c178f4fb371003c392591dbc87b9e0fa64788fd"; + version = "1.1.0"; + }; + } + + { + name = "org.codehaus.plexus/plexus-interpolation"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "plexus-interpolation"; + groupId = "org.codehaus.plexus"; + sha512 = "d9183dc0920fb996901644903194883d1e1d1e8c4863f3c55bd6a9b14de996ee30651849435a92c8c55fc82be0e4524f1b2741957f9464434da292188ffcee70"; + version = "1.24"; + }; + } + + { + name = "org.apache.httpcomponents/httpclient"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "httpclient"; + groupId = "org.apache.httpcomponents"; + sha512 = "f8d4a960ed235770570afaf793c4596404adfa777e08bdb87ae2db92575db5e11755025fe43969f852ef505a390833e79bdd1fccd5f3fb7dee87625607b504a2"; + version = "4.5.3"; + }; + } + + { + name = "cheshire/cheshire"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "cheshire"; + groupId = "cheshire"; + sha512 = "2262573047d194bba28b3d2ca4b00b12f8171d6f8f7f5449df35f10ab1ef5902a9ba2f9937399d6e4b54a78bda919fa205a22a44cde998019bc0cfc508e90f29"; + version = "5.11.0"; + }; + } + + { + name = "tigris/tigris"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "tigris"; + groupId = "tigris"; + sha512 = "fdff4ef5e7175a973aaef98de4f37dee8e125fc711c495382e280aaf3e11341fe8925d52567ca60f3f1795511ade11bc23461c88959632dfae3cf50374d02bf6"; + version = "0.1.2"; + }; + } + + { + name = "org.clojure/core.match"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "core.match"; + groupId = "org.clojure"; + sha512 = "d69ed23bad115ed665b402886e1946fcecacbbfd05150f3eb66dce9ffc0381d0e02ed6f41cb390a6dfb74f4f26e3b0f6793dec38f6a4622dc53c0739d79f5f5e"; + version = "0.3.0"; + }; + } + + { + name = "org.clojure/tools.reader"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "tools.reader"; + groupId = "org.clojure"; + sha512 = "3481259c7a1eac719db2921e60173686726a0c2b65879d51a64d516a37f6120db8ffbb74b8bd273404285d7b25143ab5c7ced37e7c0eaf4ab1e44586ccd3c651"; + version = "1.3.6"; + }; + } + + { + name = "org.tcrawley/dynapath"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "dynapath"; + groupId = "org.tcrawley"; + sha512 = "1b0caf390515212e6b151d6c227b1a62e430e682b6c811736edba3cc918344053e35c092e12afd523198ed6244018450931776f8388e61a593f266476b6db19e"; + version = "1.0.0"; + }; + } + + { + name = "org.babashka/sci"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "sci"; + groupId = "org.babashka"; + sha512 = "2897029dba4917facf93935229f1288d9e90973e8dbc8ff84448335452815274c23371ab643c35df0b1854ff6de1574c37880267fd0edd900039f5a1678d73c5"; + version = "0.3.4"; + }; + } + + { + name = "io.opentracing/opentracing-util"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "opentracing-util"; + groupId = "io.opentracing"; + sha512 = "fbba29ff3d6018561077e9539ad9b72876424600eca3addb6a26981a4a3e52cb3dfd30f27945aff2b6c222c42454ce3ba67597171fd809a74c65b920f3a47c7a"; + version = "0.33.0"; + }; + } + + { + name = "org.jsoup/jsoup"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "jsoup"; + groupId = "org.jsoup"; + sha512 = "8119ec44ee622c75f47a80dedeadf557744208dc49d3d9f579660929a0be3f71d3b8cb4aed64ee31f6bf7488bfc3516fb3980137d2fc63063caf46c9921f19f0"; + version = "1.7.2"; + }; + } + + { + name = "nrepl/nrepl"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "nrepl"; + groupId = "nrepl"; + sha512 = "92534555cc5fa45e8990b8566996fe784df368849e0938fbc7a89909ccbb62dd7d4fca9b7aa3c615702ec30f9962a460c500f6b60abc72661c5f4c66414fc395"; + version = "1.0.0"; + }; + } + + { + name = "org.apache.maven.resolver/maven-resolver-connector-basic"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-resolver-connector-basic"; + groupId = "org.apache.maven.resolver"; + sha512 = "c8c14480ed89cf5d4cfec5dee7dae366b0b5d003cd835d4b1358add81253b205a53f6a62e5ecc145f09406fc8c57adb5fbf8f4521a044ac3d37b5fa8e67d4e21"; + version = "1.0.3"; + }; + } + + { + name = "org.xerial/sqlite-jdbc"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "sqlite-jdbc"; + groupId = "org.xerial"; + sha512 = "f4c27027fe3cb7914aaf155a1afaa0c8b455e5d142b4e5f31d87bfe619c9949e1981ba7eed1f7a8a3cd27edba1321cc4cd74cf4321ae800e8a911b4d94e03930"; + version = "3.39.3.0"; + }; + } + + { + name = "org.apache.maven.resolver/maven-resolver-impl"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-resolver-impl"; + groupId = "org.apache.maven.resolver"; + sha512 = "3ffcac7ed4a05b2b58669ce05cc348acad627be3e0941ee28a9a665fea43a571d554005dd72ec51130083f792e31894880525df3cd6962d7c95885340abfb7da"; + version = "1.1.1"; + }; + } + + { + name = "org.slf4j/slf4j-api"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "slf4j-api"; + groupId = "org.slf4j"; + sha512 = "cf50d5cc86404fefa49730da36147db5f6d65c8b06163bbf62311e6874c20ca46db02ab6bda27c9c1485a5c57fe63b89fd3000b8d838c429240ee95734f5901e"; + version = "2.0.3"; + }; + } + + { + name = "org.apache.maven/maven-model"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-model"; + groupId = "org.apache.maven"; + sha512 = "888a778101774265e0d8dbc96305274053d275c0b261e81c6aae8765f92b13d1e06c5aa8f51c7d53d5267e46041adc9218686e53fc47cc15563a1b178291bc16"; + version = "3.5.3"; + }; + } + + { + name = "org.clojure/test.check"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "test.check"; + groupId = "org.clojure"; + sha512 = "b8d7a330b0b5514cd6a00c4382052fab51c3c9d3bc53133f8506791fa670e7c5ecd65094977ea5ced91f59623b0abd1ab8feeec96d63c5c6e459b265a655c577"; + version = "1.1.1"; + }; + } + + { + name = "org.apache.maven.resolver/maven-resolver-util"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-resolver-util"; + groupId = "org.apache.maven.resolver"; + sha512 = "91dcbb8184f06e64da35d40c7b96e854f7311b6232d74b4b6d3489a51e0c05ebbee44f59367ab118974cdb6c5b3747981a41869cc7372691b2c2e1d0daa2ffa3"; + version = "1.1.1"; + }; + } + + { + name = "io.dropwizard.metrics/metrics-jmx"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "metrics-jmx"; + groupId = "io.dropwizard.metrics"; + sha512 = "706f7428b967923d2792b0587684e972b1404d663a6ac3d661772a57edf096f0de0efac8bbfcead4576c008b096c33f77499e8f193ccbb8b072d7aa6e6d7a40d"; + version = "4.1.0"; + }; + } + + { + name = "io.forward/yaml"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "yaml"; + groupId = "io.forward"; + sha512 = "e2d3b7aea260346a1db44bcc3c363877d0ff2b327c4fd287759782949b1a498bc8019f06ddabee84443b96b07ea4765443f8190e04f5f903de049e2cc0fd63e9"; + version = "1.0.11"; + }; + } + + { + name = "me.raynes/fs"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "fs"; + groupId = "me.raynes"; + sha512 = "b72af0093c1feccf78ea0632ba523eca89436b0575abc0af484e03570011aa89f429f9820a9fc27f60da113d728d2bbc09ba26d3a0cdd63d9d9c7775643f6852"; + version = "1.4.6"; + }; + } + + { + name = "org.clojure/core.memoize"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "core.memoize"; + groupId = "org.clojure"; + sha512 = "67196537084b7cc34a01454d2a3b72de3fddce081b72d7a6dc1592d269a6c2728b79630bd2d52c1bf2d2f903c12add6f23df954c02ef8237f240d7394ccc3dde"; + version = "1.0.253"; + }; + } + + { + name = "org.apache.maven/maven-repository-metadata"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-repository-metadata"; + groupId = "org.apache.maven"; + sha512 = "6d898373d483ac7f24ab0256406f4be45035f95a247bb19ac7102ea7f5e336976381c5125b30a7148bc9a8e1df6d27b456d1f8e9b55b99d9688e37dfd03733a3"; + version = "3.5.3"; + }; + } + + { + name = "io.simplect/compose"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "compose"; + groupId = "io.simplect"; + sha512 = "0aceab86d4a97285ddd6d40abdeb5b9bea16a16b6509ef2fcd80e547d772185041e26abcc12ae11938d7b78fed175850f811d5cb2a2f0590524c2c11975bacd1"; + version = "0.7.27"; + }; + } + + { + name = "org.clojure/data.priority-map"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "data.priority-map"; + groupId = "org.clojure"; + sha512 = "bb8bc5dbfd3738c36b99a51880ac3f1381d6564e67601549ef5e7ae2b900e53cdcdfb8d0fa4bf32fb8ebc4de89d954bfa3ab7e8a1122bc34ee5073c7c707ac13"; + version = "1.1.0"; + }; + } + + { + name = "borkdude/sci.impl.reflector"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "sci.impl.reflector"; + groupId = "borkdude"; + sha512 = "c747fd347e6aba9578d105298b7c7402f53e8639d5c8e6dc83b127f3c413feeb1b9dead7405ac2c4345f02290902e8a2affbec749474481e9c9f19b3d049f18f"; + version = "0.0.1"; + }; + } + + { + name = "org.apache.maven/maven-builder-support"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-builder-support"; + groupId = "org.apache.maven"; + sha512 = "1b2ca4427772532cfb93b4d643b17eca5843f1e1a9c4b26089eed8c10028344fb85d593d133fdffaff07b552c3027a9f24e1a92d68ed4696682be04069e84583"; + version = "3.5.3"; + }; + } + + { + name = "org.slf4j/log4j-over-slf4j"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "log4j-over-slf4j"; + groupId = "org.slf4j"; + sha512 = "a1f90d8ea338660cc0e38073752cf32e46a042bc408477d841ba7ad69ad0d066bbbf9d4c399a34352d620ba9d2402c7a51574a88f314ddcc796c35adc99c37f4"; + version = "2.0.3"; + }; + } + + { + name = "org.clojure/core.cache"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "core.cache"; + groupId = "org.clojure"; + sha512 = "0a07ceffc2fa3a536b23773eefc7ef5e1108913b93c3a5416116a6566de76dd5c218f3fb0cc19415cbaa8843838de310b76282f20bf1fc3467006c9ec373667e"; + version = "1.0.225"; + }; + } + + { + name = "org.clojure/core.async"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "core.async"; + groupId = "org.clojure"; + sha512 = "160a77da25382d7c257eee56cfe83538620576a331e025a2d672fc26d9f04e606666032395f3c2e26247c782544816a5862348f3a921b1ffffcd309c62ac64f5"; + version = "1.5.648"; + }; + } + + { + name = "com.fasterxml.jackson.dataformat/jackson-dataformat-smile"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "jackson-dataformat-smile"; + groupId = "com.fasterxml.jackson.dataformat"; + sha512 = "4c1566aa4fac309de8fba08ea355165cf2a888b7bcec98e7035ac8acd7315e340415a10b8deec6497fc4eea5ba9319fc989676170d8c4c0d0bbc3d4f3cc4d681"; + version = "2.13.3"; + }; + } + + { + name = "org.apache.maven/maven-artifact"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "maven-artifact"; + groupId = "org.apache.maven"; + sha512 = "a4cafc89d66c8f074c5c3f9454e5077abc0de6242c29904d8ee5816348af21b1006da67f3118478bc9eb067725c39be9b88e4a019eb8368c936f971f0499c2ca"; + version = "3.5.3"; + }; + } + + { + name = "org.clojure/data.codec"; + path = pkgs.fetchMavenArtifact { + inherit repos; + artifactId = "data.codec"; + groupId = "org.clojure"; + sha512 = "cb6910fc0ee47ce6959a442ba3ef456dd91fe8589a576526d20fd661c8d305962f64a8e8ebde69f0bd00082027dbd0ac52b642fcd4950b4f0e5b7a1205f95138"; + version = "0.1.1"; + }; + } ]; - } +} diff --git a/pkgs/applications/editors/jupyter-kernels/coq/default.nix b/pkgs/applications/editors/jupyter-kernels/coq/default.nix index 9a2c12152d976f..134a6b2a6b63ea 100644 --- a/pkgs/applications/editors/jupyter-kernels/coq/default.nix +++ b/pkgs/applications/editors/jupyter-kernels/coq/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, callPackage -, runCommand -, makeWrapper -, coq -, imagemagick -, python3 +{ + lib, + stdenv, + callPackage, + runCommand, + makeWrapper, + coq, + imagemagick, + python3, }: # Jupyter console: @@ -18,7 +19,12 @@ # nix run --impure --expr 'with import {}; jupyter.override { definitions.coq = coq-kernel.definition; }' let - python = python3.withPackages (ps: [ ps.traitlets ps.jupyter-core ps.ipykernel (callPackage ./kernel.nix {}) ]); + python = python3.withPackages (ps: [ + ps.traitlets + ps.jupyter-core + ps.ipykernel + (callPackage ./kernel.nix { }) + ]); logos = runCommand "coq-logos" { buildInputs = [ imagemagick ]; } '' mkdir -p $out @@ -29,17 +35,20 @@ let in rec { - launcher = runCommand "coq-kernel-launcher" { - nativeBuildInputs = [ makeWrapper ]; - } '' - mkdir -p $out/bin - - makeWrapper ${python.interpreter} $out/bin/coq-kernel \ - --add-flags "-m coq_jupyter" \ - --suffix PATH : ${coq}/bin - ''; + launcher = + runCommand "coq-kernel-launcher" + { + nativeBuildInputs = [ makeWrapper ]; + } + '' + mkdir -p $out/bin + + makeWrapper ${python.interpreter} $out/bin/coq-kernel \ + --add-flags "-m coq_jupyter" \ + --suffix PATH : ${coq}/bin + ''; - definition = definitionWithPackages []; + definition = definitionWithPackages [ ]; definitionWithPackages = packages: { displayName = "Coq " + coq.version; @@ -52,7 +61,9 @@ rec { logo32 = "${logos}/logo-32x32.png"; logo64 = "${logos}/logo-64x64.png"; env = { - COQPATH = lib.concatStringsSep ":" (map (x: "${x}/lib/coq/${coq.coq-version}/user-contrib/") packages); + COQPATH = lib.concatStringsSep ":" ( + map (x: "${x}/lib/coq/${coq.coq-version}/user-contrib/") packages + ); }; }; } diff --git a/pkgs/applications/editors/jupyter-kernels/coq/kernel.nix b/pkgs/applications/editors/jupyter-kernels/coq/kernel.nix index 78bf84716fef5f..1fd032e465f078 100644 --- a/pkgs/applications/editors/jupyter-kernels/coq/kernel.nix +++ b/pkgs/applications/editors/jupyter-kernels/coq/kernel.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3 -, coq +{ + lib, + fetchFromGitHub, + python3, + coq, }: python3.pkgs.buildPythonPackage rec { @@ -15,7 +16,12 @@ python3.pkgs.buildPythonPackage rec { sha256 = "sha256-+Pp51cxeqjg5MW4CEccNWVjNcY9iyFNATIEage9RWJ0="; }; - propagatedBuildInputs = (with python3.pkgs; [ ipykernel future ]) ++ [ coq ]; + propagatedBuildInputs = + (with python3.pkgs; [ + ipykernel + future + ]) + ++ [ coq ]; nativeBuildInputs = [ coq ]; diff --git a/pkgs/applications/editors/jupyter-kernels/iruby/default.nix b/pkgs/applications/editors/jupyter-kernels/iruby/default.nix index f456d469ca36e7..26da29208d3a7e 100644 --- a/pkgs/applications/editors/jupyter-kernels/iruby/default.nix +++ b/pkgs/applications/editors/jupyter-kernels/iruby/default.nix @@ -1,5 +1,6 @@ -{ lib -, bundlerApp +{ + lib, + bundlerApp, }: # Jupyter console: @@ -30,10 +31,13 @@ let meta = { description = "Ruby kernel for Jupyter"; - homepage = "https://github.com/SciRuby/iruby"; - license = lib.licenses.mit; - maintainers = with lib.maintainers; [ costrouc thomasjm ]; - platforms = lib.platforms.unix; + homepage = "https://github.com/SciRuby/iruby"; + license = lib.licenses.mit; + maintainers = with lib.maintainers; [ + costrouc + thomasjm + ]; + platforms = lib.platforms.unix; }; }; diff --git a/pkgs/applications/editors/jupyter-kernels/iruby/gemset.nix b/pkgs/applications/editors/jupyter-kernels/iruby/gemset.nix index 314b78be4bd14a..932a0b79221e24 100644 --- a/pkgs/applications/editors/jupyter-kernels/iruby/gemset.nix +++ b/pkgs/applications/editors/jupyter-kernels/iruby/gemset.nix @@ -1,125 +1,132 @@ { data_uri = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fzkxgdxrlbfl4537y3n9mjxbm28kir639gcw3x47ffchwsgdcky"; type = "gem"; }; version = "0.1.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1862ydmclzy1a0cjbvm8dz7847d9rch495ib0zb64y84d3xd4bkg"; type = "gem"; }; version = "1.15.5"; }; ffi-rzmq = { - dependencies = ["ffi-rzmq-core"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi-rzmq-core" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14a5kxfnf8l3ngyk8hgmk30z07aj1324ll8i48z67ps6pz2kpsrg"; type = "gem"; }; version = "2.0.7"; }; ffi-rzmq-core = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0amkbvljpjfnv0jpdmz71p1i3mqbhyrnhamjn566w0c01xd64hb5"; type = "gem"; }; version = "1.0.7"; }; io-console = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dikardh14c72gd9ypwh8dim41wvqmzfzf35mincaj5yals9m7ff"; type = "gem"; }; version = "0.6.0"; }; irb = { - dependencies = ["reline"]; - groups = ["default"]; - platforms = []; + dependencies = [ "reline" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "158ca10kj3qqnql5g8f1g2arsnhgdl79mg74manpf8ldkwjjn3n8"; type = "gem"; }; version = "1.7.4"; }; iruby = { - dependencies = ["data_uri" "ffi-rzmq" "irb" "mime-types" "multi_json" "native-package-installer"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "data_uri" + "ffi-rzmq" + "irb" + "mime-types" + "multi_json" + "native-package-installer" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0856ncjk7akm55gxcnhfmv426xsl4ryywdxrqbwgphwpqwm9w8fc"; type = "gem"; }; version = "0.7.4"; }; mime-types = { - dependencies = ["mime-types-data"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mime-types-data" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0q8d881k1b3rbsfcdi3fx0b5vpdr5wcrhn88r2d9j7zjdkxp5mw5"; type = "gem"; }; version = "3.5.1"; }; mime-types-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17zdim7kzrh5j8c97vjqp4xp78wbyz7smdp4hi5iyzk0s9imdn5a"; type = "gem"; }; version = "3.2023.0808"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; native-package-installer = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "004wx9xhcam92g1d4ybvrl1yqablm2svalyck9sq4igy9nwkz9nb"; type = "gem"; }; version = "1.1.8"; }; reline = { - dependencies = ["io-console"]; - groups = ["default"]; - platforms = []; + dependencies = [ "io-console" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lv1nv7z63n4qmsm3h5h273m7daxngkcq8ynkk9j8lmn7jji98lb"; type = "gem"; }; diff --git a/pkgs/applications/editors/jupyter-kernels/octave/default.nix b/pkgs/applications/editors/jupyter-kernels/octave/default.nix index 88bc1b2803bbd3..158fc967056b71 100644 --- a/pkgs/applications/editors/jupyter-kernels/octave/default.nix +++ b/pkgs/applications/editors/jupyter-kernels/octave/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, callPackage -, runCommand -, makeWrapper -, octave -, imagemagick -, python3 +{ + stdenv, + callPackage, + runCommand, + makeWrapper, + octave, + imagemagick, + python3, }: # Jupyter console: @@ -21,33 +22,44 @@ let in rec { - launcher = runCommand "octave-kernel-launcher" { - inherit octave; - python = python3.withPackages (ps: [ ps.traitlets ps.jupyter-core ps.ipykernel ps.metakernel kernel ]); - nativeBuildInputs = [ makeWrapper ]; - } '' - mkdir -p $out/bin + launcher = + runCommand "octave-kernel-launcher" + { + inherit octave; + python = python3.withPackages (ps: [ + ps.traitlets + ps.jupyter-core + ps.ipykernel + ps.metakernel + kernel + ]); + nativeBuildInputs = [ makeWrapper ]; + } + '' + mkdir -p $out/bin - makeWrapper $python/bin/python $out/bin/octave-kernel \ - --add-flags "-m octave_kernel" \ - --suffix PATH : $octave/bin - ''; + makeWrapper $python/bin/python $out/bin/octave-kernel \ + --add-flags "-m octave_kernel" \ + --suffix PATH : $octave/bin + ''; - sizedLogo = size: stdenv.mkDerivation { - pname = "octave-logo-${size}x${size}.png"; - inherit (octave) version; + sizedLogo = + size: + stdenv.mkDerivation { + pname = "octave-logo-${size}x${size}.png"; + inherit (octave) version; - src = octave.src; + src = octave.src; - buildInputs = [ imagemagick ]; + buildInputs = [ imagemagick ]; - dontConfigure = true; - dontInstall = true; + dontConfigure = true; + dontInstall = true; - buildPhase = '' - convert ./libgui/src/icons/octave/128x128/logo.png -resize ${size}x${size} $out - ''; - }; + buildPhase = '' + convert ./libgui/src/icons/octave/128x128/logo.png -resize ${size}x${size} $out + ''; + }; definition = { displayName = "Octave"; diff --git a/pkgs/applications/editors/jupyter-kernels/octave/kernel.nix b/pkgs/applications/editors/jupyter-kernels/octave/kernel.nix index f1a83bc274c27b..e21608970e6d0b 100644 --- a/pkgs/applications/editors/jupyter-kernels/octave/kernel.nix +++ b/pkgs/applications/editors/jupyter-kernels/octave/kernel.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: with python3Packages; @@ -12,7 +16,10 @@ buildPythonPackage rec { sha256 = "sha256-5ki2lekfK7frPsmPBIzYQOfANCUY9x+F2ZRAQSdPTxo="; }; - propagatedBuildInputs = [ metakernel ipykernel ]; + propagatedBuildInputs = [ + metakernel + ipykernel + ]; # Tests fail because the kernel appears to be halting or failing to launch # There appears to be a similar problem with metakernel's tests diff --git a/pkgs/applications/editors/jupyter-kernels/wolfram/default.nix b/pkgs/applications/editors/jupyter-kernels/wolfram/default.nix index efa78f74bc960e..92ffdcb38e8a35 100644 --- a/pkgs/applications/editors/jupyter-kernels/wolfram/default.nix +++ b/pkgs/applications/editors/jupyter-kernels/wolfram/default.nix @@ -1,5 +1,6 @@ -{ callPackage -, wolfram-engine +{ + callPackage, + wolfram-engine, }: # Jupyter console: @@ -8,8 +9,10 @@ # Jupyter notebook: # nix run --impure --expr 'with import {}; jupyter.override { definitions.wolfram = wolfram-for-jupyter-kernel.definition; }' -let kernel = callPackage ./kernel.nix {}; -in { +let + kernel = callPackage ./kernel.nix { }; +in +{ definition = { displayName = "Wolfram Language ${wolfram-engine.version}"; argv = [ diff --git a/pkgs/applications/editors/jupyter-kernels/wolfram/kernel.nix b/pkgs/applications/editors/jupyter-kernels/wolfram/kernel.nix index e1beb4048b14d5..eab4626a663c51 100644 --- a/pkgs/applications/editors/jupyter-kernels/wolfram/kernel.nix +++ b/pkgs/applications/editors/jupyter-kernels/wolfram/kernel.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "wolfram-for-jupyter-kernel"; diff --git a/pkgs/applications/editors/jupyter-kernels/xeus-cling/default.nix b/pkgs/applications/editors/jupyter-kernels/xeus-cling/default.nix index 751c3db697ee8e..bffd4c89403920 100644 --- a/pkgs/applications/editors/jupyter-kernels/xeus-cling/default.nix +++ b/pkgs/applications/editors/jupyter-kernels/xeus-cling/default.nix @@ -1,10 +1,11 @@ -{ callPackage -, cling -, fetchurl -, jq -, makeWrapper -, python3 -, stdenv +{ + callPackage, + cling, + fetchurl, + jq, + makeWrapper, + python3, + stdenv, }: # Jupyter console: @@ -14,17 +15,20 @@ # nix run --impure --expr 'with import {}; jupyter.override { definitions = { cpp17 = cpp17-kernel; }; }' let - xeus-cling-unwrapped = callPackage ./xeus-cling.nix {}; + xeus-cling-unwrapped = callPackage ./xeus-cling.nix { }; xeus-cling = xeus-cling-unwrapped.overrideAttrs (oldAttrs: { - nativeBuildInputs = oldAttrs.nativeBuildInputs ++ [makeWrapper]; + nativeBuildInputs = oldAttrs.nativeBuildInputs ++ [ makeWrapper ]; # xcpp needs a collection of flags to start up properly, so wrap it by default. # We'll provide the unwrapped version as a passthru flags = cling.flags ++ [ - "-resource-dir" "${cling.unwrapped}" - "-L" "${cling.unwrapped}/lib" - "-l" "${cling.unwrapped}/lib/cling.so" + "-resource-dir" + "${cling.unwrapped}" + "-L" + "${cling.unwrapped}/lib" + "-l" + "${cling.unwrapped}/lib/cling.so" ]; fixupPhase = '' @@ -59,17 +63,18 @@ let runHook postCheck ''; - passthru = (oldAttrs.passthru or {}) // { + passthru = (oldAttrs.passthru or { }) // { unwrapped = xeus-cling-unwrapped; }; }); mkKernelSpec = std: { - displayName = builtins.replaceStrings ["c++"] ["C++ "] std; + displayName = builtins.replaceStrings [ "c++" ] [ "C++ " ] std; argv = [ "${xeus-cling}/bin/xcpp" "-std=${std}" - "-f" "{connection_file}" + "-f" + "{connection_file}" ]; language = "cpp"; logo32 = "${xeus-cling-unwrapped}/share/jupyter/kernels/xcpp17/logo-32x32.png"; diff --git a/pkgs/applications/editors/jupyter-kernels/xeus-cling/xeus-cling.nix b/pkgs/applications/editors/jupyter-kernels/xeus-cling/xeus-cling.nix index b944569ff4a7bd..fd88db33bcc4a7 100644 --- a/pkgs/applications/editors/jupyter-kernels/xeus-cling/xeus-cling.nix +++ b/pkgs/applications/editors/jupyter-kernels/xeus-cling/xeus-cling.nix @@ -1,23 +1,24 @@ -{ lib -, clangStdenv -, cmake -, fetchFromGitHub -, llvmPackages_13 -# Libraries -, argparse -, cling -, cppzmq -, libuuid -, ncurses -, openssl -, pugixml -, xeus -, xeus-zmq -, xtl -, zeromq -, zlib -# Settings -, debug ? false +{ + lib, + clangStdenv, + cmake, + fetchFromGitHub, + llvmPackages_13, + # Libraries + argparse, + cling, + cppzmq, + libuuid, + ncurses, + openssl, + pugixml, + xeus, + xeus-zmq, + xtl, + zeromq, + zlib, + # Settings + debug ? false, }: let diff --git a/pkgs/applications/editors/jupyter/console.nix b/pkgs/applications/editors/jupyter/console.nix index 06bc82a1780b4c..255e76e85132a4 100644 --- a/pkgs/applications/editors/jupyter/console.nix +++ b/pkgs/applications/editors/jupyter/console.nix @@ -1,25 +1,32 @@ -{ python3 -, jupyter-kernel -, lib +{ + python3, + jupyter-kernel, + lib, }: let - mkConsole = { - definitions ? jupyter-kernel.default - , kernel ? null - }: + mkConsole = + { + definitions ? jupyter-kernel.default, + kernel ? null, + }: (python3.buildEnv.override { extraLibs = [ python3.pkgs.jupyter-console ]; - makeWrapperArgs = [ - "--set JUPYTER_PATH ${jupyter-kernel.create { inherit definitions; }}" - ] ++ lib.optionals (kernel != null) [ - "--add-flags --kernel" - "--add-flags ${kernel}" - ]; - }).overrideAttrs (oldAttrs: { - # To facilitate running nix run .#jupyter-console - meta = oldAttrs.meta // { mainProgram = "jupyter-console"; }; - }); + makeWrapperArgs = + [ + "--set JUPYTER_PATH ${jupyter-kernel.create { inherit definitions; }}" + ] + ++ lib.optionals (kernel != null) [ + "--add-flags --kernel" + "--add-flags ${kernel}" + ]; + }).overrideAttrs + (oldAttrs: { + # To facilitate running nix run .#jupyter-console + meta = oldAttrs.meta // { + mainProgram = "jupyter-console"; + }; + }); in @@ -30,8 +37,10 @@ in inherit mkConsole; # An ergonomic way to start a console with a single kernel. - withSingleKernel = definition: mkConsole { - definitions = lib.listToAttrs [(lib.nameValuePair definition.language definition)]; - kernel = definition.language; - }; + withSingleKernel = + definition: + mkConsole { + definitions = lib.listToAttrs [ (lib.nameValuePair definition.language definition) ]; + kernel = definition.language; + }; } diff --git a/pkgs/applications/editors/jupyter/default.nix b/pkgs/applications/editors/jupyter/default.nix index 08c33982364da4..9b078be78a70fd 100644 --- a/pkgs/applications/editors/jupyter/default.nix +++ b/pkgs/applications/editors/jupyter/default.nix @@ -1,18 +1,23 @@ # Jupyter notebook with the given kernel definitions -{ python3 -, jupyter-kernel -, definitions ? jupyter-kernel.default +{ + python3, + jupyter-kernel, + definitions ? jupyter-kernel.default, }: let jupyterPath = (jupyter-kernel.create { inherit definitions; }); - jupyter-notebook = (python3.buildEnv.override { - extraLibs = [ python3.pkgs.notebook ]; - makeWrapperArgs = ["--prefix JUPYTER_PATH : ${jupyterPath}"]; - }).overrideAttrs(oldAttrs: { - meta = oldAttrs.meta // { mainProgram = "jupyter-notebook"; }; - }); + jupyter-notebook = + (python3.buildEnv.override { + extraLibs = [ python3.pkgs.notebook ]; + makeWrapperArgs = [ "--prefix JUPYTER_PATH : ${jupyterPath}" ]; + }).overrideAttrs + (oldAttrs: { + meta = oldAttrs.meta // { + mainProgram = "jupyter-notebook"; + }; + }); in jupyter-notebook diff --git a/pkgs/applications/editors/jupyter/kernel.nix b/pkgs/applications/editors/jupyter/kernel.nix index b036c7274d51de..4496b943997bfa 100644 --- a/pkgs/applications/editors/jupyter/kernel.nix +++ b/pkgs/applications/editors/jupyter/kernel.nix @@ -1,23 +1,29 @@ -{ lib, stdenv, python3}: +{ + lib, + stdenv, + python3, +}: let default = { - python3 = let - env = (python3.withPackages (ps: with ps; [ ipykernel ])); - in { - displayName = "Python 3"; - argv = [ - env.interpreter - "-m" - "ipykernel_launcher" - "-f" - "{connection_file}" - ]; - language = "python"; - logo32 = "${env}/${env.sitePackages}/ipykernel/resources/logo-32x32.png"; - logo64 = "${env}/${env.sitePackages}/ipykernel/resources/logo-64x64.png"; - }; + python3 = + let + env = (python3.withPackages (ps: with ps; [ ipykernel ])); + in + { + displayName = "Python 3"; + argv = [ + env.interpreter + "-m" + "ipykernel_launcher" + "-f" + "{connection_file}" + ]; + language = "python"; + logo32 = "${env}/${env.sitePackages}/ipykernel/resources/logo-32x32.png"; + logo64 = "${env}/${env.sitePackages}/ipykernel/resources/logo-64x64.png"; + }; }; in @@ -26,45 +32,68 @@ in # Definitions is an attribute set. - create = { definitions ? default }: stdenv.mkDerivation { + create = + { + definitions ? default, + }: + stdenv.mkDerivation { - name = "jupyter-kernels"; + name = "jupyter-kernels"; - src = "/dev/null"; + src = "/dev/null"; - unpackCmd = "mkdir jupyter_kernels"; + unpackCmd = "mkdir jupyter_kernels"; - installPhase = '' - mkdir kernels + installPhase = '' + mkdir kernels - ${lib.concatStringsSep "\n" (lib.mapAttrsToList (kernelName: unfilteredKernel: - let - allowedKernelKeys = ["argv" "displayName" "language" "interruptMode" "env" "metadata" "logo32" "logo64" "extraPaths"]; - kernel = lib.filterAttrs (n: v: (lib.any (x: x == n) allowedKernelKeys)) unfilteredKernel; - config = builtins.toJSON ( - kernel - // {display_name = if (kernel.displayName != "") then kernel.displayName else kernelName;} - // (lib.optionalAttrs (kernel ? interruptMode) { interrupt_mode = kernel.interruptMode; }) - ); - extraPaths = kernel.extraPaths or {} - // lib.optionalAttrs (kernel.logo32 != null) { "logo-32x32.png" = kernel.logo32; } - // lib.optionalAttrs (kernel.logo64 != null) { "logo-64x64.png" = kernel.logo64; } - ; - linkExtraPaths = lib.mapAttrsToList (name: value: "ln -s ${value} 'kernels/${kernelName}/${name}';") extraPaths; - in '' - mkdir 'kernels/${kernelName}'; - echo '${config}' > 'kernels/${kernelName}/kernel.json'; - ${lib.concatStringsSep "\n" linkExtraPaths} - '') definitions)} + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList ( + kernelName: unfilteredKernel: + let + allowedKernelKeys = [ + "argv" + "displayName" + "language" + "interruptMode" + "env" + "metadata" + "logo32" + "logo64" + "extraPaths" + ]; + kernel = lib.filterAttrs (n: v: (lib.any (x: x == n) allowedKernelKeys)) unfilteredKernel; + config = builtins.toJSON ( + kernel + // { + display_name = if (kernel.displayName != "") then kernel.displayName else kernelName; + } + // (lib.optionalAttrs (kernel ? interruptMode) { interrupt_mode = kernel.interruptMode; }) + ); + extraPaths = + kernel.extraPaths or { } + // lib.optionalAttrs (kernel.logo32 != null) { "logo-32x32.png" = kernel.logo32; } + // lib.optionalAttrs (kernel.logo64 != null) { "logo-64x64.png" = kernel.logo64; }; + linkExtraPaths = lib.mapAttrsToList ( + name: value: "ln -s ${value} 'kernels/${kernelName}/${name}';" + ) extraPaths; + in + '' + mkdir 'kernels/${kernelName}'; + echo '${config}' > 'kernels/${kernelName}/kernel.json'; + ${lib.concatStringsSep "\n" linkExtraPaths} + '' + ) definitions + )} - mkdir $out - cp -r kernels $out - ''; + mkdir $out + cp -r kernels $out + ''; - meta = { - description = "Wrapper to create jupyter notebook kernel definitions"; - homepage = "https://jupyter.org/"; - maintainers = with lib.maintainers; [ aborsu ]; + meta = { + description = "Wrapper to create jupyter notebook kernel definitions"; + homepage = "https://jupyter.org/"; + maintainers = with lib.maintainers; [ aborsu ]; + }; }; - }; } diff --git a/pkgs/applications/editors/kakoune/default.nix b/pkgs/applications/editors/kakoune/default.nix index c45ad92674a684..7b20a0d668d3d1 100644 --- a/pkgs/applications/editors/kakoune/default.nix +++ b/pkgs/applications/editors/kakoune/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation (finalAttrs: { pname = "kakoune-unwrapped"; @@ -9,7 +13,10 @@ stdenv.mkDerivation (finalAttrs: { rev = "v${finalAttrs.version}"; hash = "sha256-1nYSVbvQ4tz1r8p7zCD6w/79haqpelb15qva9r3Fwew="; }; - makeFlags = [ "debug=no" "PREFIX=${placeholder "out"}" ]; + makeFlags = [ + "debug=no" + "PREFIX=${placeholder "out"}" + ]; postPatch = '' echo "v${finalAttrs.version}" >.version diff --git a/pkgs/applications/editors/kakoune/plugins/aliases.nix b/pkgs/applications/editors/kakoune/plugins/aliases.nix index 392ee835d3392f..0b43189e617c15 100644 --- a/pkgs/applications/editors/kakoune/plugins/aliases.nix +++ b/pkgs/applications/editors/kakoune/plugins/aliases.nix @@ -5,41 +5,43 @@ lib: overridden: let # Removing recurseForDerivation prevents derivations of aliased attribute # set to appear while listing all the packages available. - removeRecurseForDerivations = alias: + removeRecurseForDerivations = + alias: if alias.recurseForDerivations or false then - lib.removeAttrs alias ["recurseForDerivations"] - else alias; + lib.removeAttrs alias [ "recurseForDerivations" ] + else + alias; # Disabling distribution prevents top-level aliases for non-recursed package # sets from building on Hydra. - removeDistribute = alias: - if lib.isDerivation alias then - lib.dontDistribute alias - else alias; + removeDistribute = alias: if lib.isDerivation alias then lib.dontDistribute alias else alias; # Make sure that we are not shadowing something from # all-packages.nix. - checkInPkgs = n: alias: if builtins.hasAttr n overridden - then throw "Alias ${n} is still in kakounePlugins" - else alias; + checkInPkgs = + n: alias: + if builtins.hasAttr n overridden then throw "Alias ${n} is still in kakounePlugins" else alias; - mapAliases = aliases: - lib.mapAttrs (n: alias: removeDistribute - (removeRecurseForDerivations - (checkInPkgs n alias))) - aliases; + mapAliases = + aliases: + lib.mapAttrs ( + n: alias: removeDistribute (removeRecurseForDerivations (checkInPkgs n alias)) + ) aliases; - deprecations = lib.mapAttrs (old: info: - throw "${old} was renamed to ${info.new} on ${info.date}. Please update to ${info.new}." + deprecations = lib.mapAttrs ( + old: info: throw "${old} was renamed to ${info.new} on ${info.date}. Please update to ${info.new}." ) (lib.importJSON ./deprecated.json); in -mapAliases ({ - kak-auto-pairs = overridden.auto-pairs-kak; # backwards compat, added 2021-01-04 - kak-buffers = overridden.kakoune-buffers; # backwards compat, added 2021-01-04 - kak-byline = overridden.byline-kak; # backwards compat, added 2023-10-22 - kak-fzf = overridden.fzf-kak; # backwards compat, added 2021-01-04 - kak-powerline = overridden.powerline-kak; # backwards compat, added 2021-01-04 - kak-prelude = overridden.prelude-kak; # backwards compat, added 2021-01-04 - kak-vertical-selection = overridden.kakoune-vertical-selection; # backwards compat, added 2021-01-04 -} // deprecations) +mapAliases ( + { + kak-auto-pairs = overridden.auto-pairs-kak; # backwards compat, added 2021-01-04 + kak-buffers = overridden.kakoune-buffers; # backwards compat, added 2021-01-04 + kak-byline = overridden.byline-kak; # backwards compat, added 2023-10-22 + kak-fzf = overridden.fzf-kak; # backwards compat, added 2021-01-04 + kak-powerline = overridden.powerline-kak; # backwards compat, added 2021-01-04 + kak-prelude = overridden.prelude-kak; # backwards compat, added 2021-01-04 + kak-vertical-selection = overridden.kakoune-vertical-selection; # backwards compat, added 2021-01-04 + } + // deprecations +) diff --git a/pkgs/applications/editors/kakoune/plugins/build-kakoune-plugin.nix b/pkgs/applications/editors/kakoune/plugins/build-kakoune-plugin.nix index 196a1d122d65a9..11a615cfba82d2 100644 --- a/pkgs/applications/editors/kakoune/plugins/build-kakoune-plugin.nix +++ b/pkgs/applications/editors/kakoune/plugins/build-kakoune-plugin.nix @@ -1,33 +1,49 @@ -{ lib, stdenv, rtpPath ? "share/kak/autoload/plugins" }: +{ + lib, + stdenv, + rtpPath ? "share/kak/autoload/plugins", +}: rec { - buildKakounePlugin = attrs@{ - name ? "${attrs.pname}-${attrs.version}", - namePrefix ? "kakplugin-", - src, - unpackPhase ? "", - configurePhase ? "", - buildPhase ? "", - preInstall ? "", - postInstall ? "", - path ? lib.getName name, - ... - }: - stdenv.mkDerivation ((builtins.removeAttrs attrs [ "namePrefix" "path" ]) // { - name = namePrefix + name; + buildKakounePlugin = + attrs@{ + name ? "${attrs.pname}-${attrs.version}", + namePrefix ? "kakplugin-", + src, + unpackPhase ? "", + configurePhase ? "", + buildPhase ? "", + preInstall ? "", + postInstall ? "", + path ? lib.getName name, + ... + }: + stdenv.mkDerivation ( + (builtins.removeAttrs attrs [ + "namePrefix" + "path" + ]) + // { + name = namePrefix + name; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - target=$out/${rtpPath}/${path} - mkdir -p $out/${rtpPath} - cp -r . $target + target=$out/${rtpPath}/${path} + mkdir -p $out/${rtpPath} + cp -r . $target - runHook postInstall - ''; - }); + runHook postInstall + ''; + } + ); - buildKakounePluginFrom2Nix = attrs: buildKakounePlugin ({ - dontBuild = true; - dontConfigure = true; - } // attrs); + buildKakounePluginFrom2Nix = + attrs: + buildKakounePlugin ( + { + dontBuild = true; + dontConfigure = true; + } + // attrs + ); } diff --git a/pkgs/applications/editors/kakoune/plugins/default.nix b/pkgs/applications/editors/kakoune/plugins/default.nix index dc4381446b97af..21f4018d2e2b91 100644 --- a/pkgs/applications/editors/kakoune/plugins/default.nix +++ b/pkgs/applications/editors/kakoune/plugins/default.nix @@ -1,8 +1,13 @@ -{ callPackage, config, kakouneUtils, lib }: +{ + callPackage, + config, + kakouneUtils, + lib, +}: let - inherit (kakouneUtils.override {}) buildKakounePluginFrom2Nix; + inherit (kakouneUtils.override { }) buildKakounePluginFrom2Nix; plugins = callPackage ./generated.nix { inherit buildKakounePluginFrom2Nix overrides; diff --git a/pkgs/applications/editors/kakoune/plugins/generated.nix b/pkgs/applications/editors/kakoune/plugins/generated.nix index 9bc508d618d69e..403e0f80391270 100644 --- a/pkgs/applications/editors/kakoune/plugins/generated.nix +++ b/pkgs/applications/editors/kakoune/plugins/generated.nix @@ -1,248 +1,255 @@ # This file has been generated by ./pkgs/applications/editors/kakoune/plugins/update.py. Do not edit! -{ lib, buildKakounePluginFrom2Nix, fetchFromGitHub, overrides ? (self: super: {}) }: -let -packages = ( self: { - active-window-kak = buildKakounePluginFrom2Nix { - pname = "active-window-kak"; - version = "2022-11-14"; - src = fetchFromGitHub { - owner = "greenfork"; - repo = "active-window.kak"; - rev = "36bf0364eed856a52cddf274072e9f255902c0ee"; - sha256 = "1fv1cp9q212gamf9z2papl5xcl2w31fpcmbgdzbxcxdl1pvfsqp8"; - }; - meta.homepage = "https://github.com/greenfork/active-window.kak/"; - }; - - auto-pairs-kak = buildKakounePluginFrom2Nix { - pname = "auto-pairs-kak"; - version = "2023-07-30"; - src = fetchFromGitHub { - owner = "alexherbo2"; - repo = "auto-pairs.kak"; - rev = "d4b33b783ea42a536c848296b5b6d434b4d1470f"; - sha256 = "017x9g89q0w60y561xhigc0f14ryp4phh1hdna847ca5lvmbxksp"; - }; - meta.homepage = "https://github.com/alexherbo2/auto-pairs.kak/"; - }; - - byline-kak = buildKakounePluginFrom2Nix { - pname = "byline-kak"; - version = "2023-02-27"; - src = fetchFromGitHub { - owner = "evanrelf"; - repo = "byline.kak"; - rev = "a27d109b776c60e11752eeb3207c989a5e157fc0"; - sha256 = "121dxd65ml65ablkvdxj0rib3kvfwss0pv943bgl3nq35ag19b81"; - }; - meta.homepage = "https://github.com/evanrelf/byline.kak/"; - }; - - connect-kak = buildKakounePluginFrom2Nix { - pname = "connect-kak"; - version = "2021-02-24"; - src = fetchFromGitHub { - owner = "kakounedotcom"; - repo = "connect.kak"; - rev = "a536605a208149eed58986bda54f3dda215dfe61"; - sha256 = "1svw64zk28sn271vjyzvq21zaln13vnx59rxnxah6adq8n5nkr4a"; - }; - meta.homepage = "https://github.com/kakounedotcom/connect.kak/"; - }; - - fzf-kak = buildKakounePluginFrom2Nix { - pname = "fzf-kak"; - version = "2022-10-11"; - src = fetchFromGitHub { - owner = "andreyorst"; - repo = "fzf.kak"; - rev = "6910bfb4c23cac59c17f5b7850f7bd49aba3e5cb"; - sha256 = "1hlals4d9x5i4mwigxjlx4f9xgc9rw15yzvbvc64cminxic2i3i8"; - }; - meta.homepage = "https://github.com/andreyorst/fzf.kak/"; - }; - - kakboard = buildKakounePluginFrom2Nix { - pname = "kakboard"; - version = "2022-04-02"; - src = fetchFromGitHub { - owner = "lePerdu"; - repo = "kakboard"; - rev = "5759dcc5af593ff88a7faecc41a8f549ec440771"; - sha256 = "0g8q0rkdnzsfvlibjd1zfcapngfli5aa3qrgmkgdi24n9ad8wzvh"; - }; - meta.homepage = "https://github.com/lePerdu/kakboard/"; - }; - - kakoune-buffer-switcher = buildKakounePluginFrom2Nix { - pname = "kakoune-buffer-switcher"; - version = "2022-09-18"; - src = fetchFromGitHub { - owner = "occivink"; - repo = "kakoune-buffer-switcher"; - rev = "21319aa08e7c9072dcf1a4f2f5583887d701fc37"; - sha256 = "0lnvcb4khw1ywxd369phd2xibsh5f6qc11x5vrla331wr1q7y8j8"; - }; - meta.homepage = "https://github.com/occivink/kakoune-buffer-switcher/"; - }; - - kakoune-buffers = buildKakounePluginFrom2Nix { - pname = "kakoune-buffers"; - version = "2021-11-10"; - src = fetchFromGitHub { - owner = "Delapouite"; - repo = "kakoune-buffers"; - rev = "6b2081f5b7d58c72de319a5cba7bf628b6802881"; - sha256 = "0pbrgydifw2a8yf3ringyqq91fccfv4lm4v8sk5349hbcz6apr4c"; - }; - meta.homepage = "https://github.com/Delapouite/kakoune-buffers/"; - }; - - kakoune-easymotion = buildKakounePluginFrom2Nix { - pname = "kakoune-easymotion"; - version = "2020-03-09"; - src = fetchFromGitHub { - owner = "danr"; - repo = "kakoune-easymotion"; - rev = "0ca75450023a149efc70e8e383e459b571355c70"; - sha256 = "15czvl0qj2k767pysr6xk2v31mkhvcbmv76xs2a8yrslchms70b5"; - }; - meta.homepage = "https://github.com/danr/kakoune-easymotion/"; - }; - - kakoune-extra-filetypes = buildKakounePluginFrom2Nix { - pname = "kakoune-extra-filetypes"; - version = "2021-05-16"; - src = fetchFromGitHub { - owner = "kakoune-editor"; - repo = "kakoune-extra-filetypes"; - rev = "8ffeec08068edfee42e076c5f6d56a54a498bad2"; - sha256 = "1v87aqfk2jcysbdls3mh2v1yafk1albbinfxsxp11m4nxd2b9agl"; - }; - meta.homepage = "https://github.com/kakoune-editor/kakoune-extra-filetypes/"; - }; - - kakoune-rainbow = buildKakounePluginFrom2Nix { - pname = "kakoune-rainbow"; - version = "2020-09-01"; - src = fetchFromGitHub { - owner = "listentolist"; - repo = "kakoune-rainbow"; - rev = "d09103e8d268cf4621215bf162a0244c9482be3c"; - sha256 = "1i3id7xw0j4z1a14mscr68ckpgvcwsjpl86lr864wy7w7qcmblx6"; - }; - meta.homepage = "https://github.com/listentolist/kakoune-rainbow/"; - meta.mainProgram = "kak-rainbow.scm"; - }; - - kakoune-registers = buildKakounePluginFrom2Nix { - pname = "kakoune-registers"; - version = "2022-03-01"; - src = fetchFromGitHub { - owner = "Delapouite"; - repo = "kakoune-registers"; - rev = "b8ca8e04ebe50671a937bceccba69c62b68ae8b0"; - sha256 = "0vy5dc6jly5xqcck0vhnmbjxjdy3615b6d329v0b04amzy0hdlck"; - }; - meta.homepage = "https://github.com/Delapouite/kakoune-registers/"; - }; - - kakoune-vertical-selection = buildKakounePluginFrom2Nix { - pname = "kakoune-vertical-selection"; - version = "2023-04-20"; - src = fetchFromGitHub { - owner = "occivink"; - repo = "kakoune-vertical-selection"; - rev = "dbb39712e3824ca6142b510f26f35a769934a1e1"; - sha256 = "1wncx16a8mi2b81cvkiji3ccv8is5g3sa4hwf1669va5a432vdwn"; - }; - meta.homepage = "https://github.com/occivink/kakoune-vertical-selection/"; - }; - - openscad-kak = buildKakounePluginFrom2Nix { - pname = "openscad-kak"; - version = "2020-12-10"; - src = fetchFromGitHub { - owner = "mayjs"; - repo = "openscad.kak"; - rev = "ba51bbdcd96ccf94bb9239bef1481b6f37125849"; - sha256 = "15dybd6dnnwla6mj8sw83nwd62para1syxzifznl6rz6kp8vqjjj"; - }; - meta.homepage = "https://github.com/mayjs/openscad.kak/"; - }; - - pandoc-kak = buildKakounePluginFrom2Nix { - pname = "pandoc-kak"; - version = "2021-06-29"; - src = fetchFromGitHub { - owner = "basbebe"; - repo = "pandoc.kak"; - rev = "e9597e8df58427884161ce27392a9558930832a7"; - sha256 = "1baslidszbybx2ngdkm7wns2m5l27gc0mb3blhhydiav8fcfvc6m"; - }; - meta.homepage = "https://github.com/basbebe/pandoc.kak/"; - }; - - powerline-kak = buildKakounePluginFrom2Nix { - pname = "powerline-kak"; - version = "2022-04-05"; - src = fetchFromGitHub { - owner = "andreyorst"; - repo = "powerline.kak"; - rev = "c5ef9a845bbd886c73ef00c0efff986e02d5f5d8"; - sha256 = "1lshlnz5xrxzafxmb6w05g2i6nvi49aqyd8852k9l0lmzqryp7l2"; - }; - meta.homepage = "https://github.com/andreyorst/powerline.kak/"; - }; - - prelude-kak = buildKakounePluginFrom2Nix { - pname = "prelude-kak"; - version = "2021-02-24"; - src = fetchFromGitHub { - owner = "kakounedotcom"; - repo = "prelude.kak"; - rev = "5dbdc020c546032885c1fdb463e366cc89fc15ad"; - sha256 = "1pncr8azqvl2z9yvzhc68p1s9fld8cvak8yz88zgrp5ypx2cxl8c"; - }; - meta.homepage = "https://github.com/kakounedotcom/prelude.kak/"; - }; - - smarttab-kak = buildKakounePluginFrom2Nix { - pname = "smarttab-kak"; - version = "2022-04-10"; - src = fetchFromGitHub { - owner = "andreyorst"; - repo = "smarttab.kak"; - rev = "86ac6599b13617ff938905ba4cdd8225d7eb6a2e"; - sha256 = "1992xwf2aygzfd26lhg3yiy253g0hl1iagj0kq9yhcqg0i5xjcj9"; - }; - meta.homepage = "https://github.com/andreyorst/smarttab.kak/"; - }; - - tabs-kak = buildKakounePluginFrom2Nix { - pname = "tabs-kak"; - version = "2023-05-15"; - src = fetchFromGitHub { - owner = "enricozb"; - repo = "tabs.kak"; - rev = "f0b3a399db1dfa12b89fbff3eed09aec74725bab"; - sha256 = "1sg26bv4vr08pqyxp68wsmzj8vhi2qg1bmkqb2jnngi5sjp4r7xy"; - }; - meta.homepage = "https://github.com/enricozb/tabs.kak/"; - }; - - zig-kak = buildKakounePluginFrom2Nix { - pname = "zig-kak"; - version = "2019-05-06"; - src = fetchFromGitHub { - owner = "adrusi"; - repo = "zig.kak"; - rev = "5a7e84e138324e6b8d140fe384dfe5cc941e26b7"; - sha256 = "1w0nmhsgchjga4by9ch9md3pdc1bwn0p157g6zwnfpj7lnaahsmq"; - }; - meta.homepage = "https://github.com/adrusi/zig.kak/"; - }; - -}); -in lib.fix' (lib.extends overrides packages) + lib, + buildKakounePluginFrom2Nix, + fetchFromGitHub, + overrides ? (self: super: { }), +}: +let + packages = ( + self: { + active-window-kak = buildKakounePluginFrom2Nix { + pname = "active-window-kak"; + version = "2022-11-14"; + src = fetchFromGitHub { + owner = "greenfork"; + repo = "active-window.kak"; + rev = "36bf0364eed856a52cddf274072e9f255902c0ee"; + sha256 = "1fv1cp9q212gamf9z2papl5xcl2w31fpcmbgdzbxcxdl1pvfsqp8"; + }; + meta.homepage = "https://github.com/greenfork/active-window.kak/"; + }; + + auto-pairs-kak = buildKakounePluginFrom2Nix { + pname = "auto-pairs-kak"; + version = "2023-07-30"; + src = fetchFromGitHub { + owner = "alexherbo2"; + repo = "auto-pairs.kak"; + rev = "d4b33b783ea42a536c848296b5b6d434b4d1470f"; + sha256 = "017x9g89q0w60y561xhigc0f14ryp4phh1hdna847ca5lvmbxksp"; + }; + meta.homepage = "https://github.com/alexherbo2/auto-pairs.kak/"; + }; + + byline-kak = buildKakounePluginFrom2Nix { + pname = "byline-kak"; + version = "2023-02-27"; + src = fetchFromGitHub { + owner = "evanrelf"; + repo = "byline.kak"; + rev = "a27d109b776c60e11752eeb3207c989a5e157fc0"; + sha256 = "121dxd65ml65ablkvdxj0rib3kvfwss0pv943bgl3nq35ag19b81"; + }; + meta.homepage = "https://github.com/evanrelf/byline.kak/"; + }; + + connect-kak = buildKakounePluginFrom2Nix { + pname = "connect-kak"; + version = "2021-02-24"; + src = fetchFromGitHub { + owner = "kakounedotcom"; + repo = "connect.kak"; + rev = "a536605a208149eed58986bda54f3dda215dfe61"; + sha256 = "1svw64zk28sn271vjyzvq21zaln13vnx59rxnxah6adq8n5nkr4a"; + }; + meta.homepage = "https://github.com/kakounedotcom/connect.kak/"; + }; + + fzf-kak = buildKakounePluginFrom2Nix { + pname = "fzf-kak"; + version = "2022-10-11"; + src = fetchFromGitHub { + owner = "andreyorst"; + repo = "fzf.kak"; + rev = "6910bfb4c23cac59c17f5b7850f7bd49aba3e5cb"; + sha256 = "1hlals4d9x5i4mwigxjlx4f9xgc9rw15yzvbvc64cminxic2i3i8"; + }; + meta.homepage = "https://github.com/andreyorst/fzf.kak/"; + }; + + kakboard = buildKakounePluginFrom2Nix { + pname = "kakboard"; + version = "2022-04-02"; + src = fetchFromGitHub { + owner = "lePerdu"; + repo = "kakboard"; + rev = "5759dcc5af593ff88a7faecc41a8f549ec440771"; + sha256 = "0g8q0rkdnzsfvlibjd1zfcapngfli5aa3qrgmkgdi24n9ad8wzvh"; + }; + meta.homepage = "https://github.com/lePerdu/kakboard/"; + }; + + kakoune-buffer-switcher = buildKakounePluginFrom2Nix { + pname = "kakoune-buffer-switcher"; + version = "2022-09-18"; + src = fetchFromGitHub { + owner = "occivink"; + repo = "kakoune-buffer-switcher"; + rev = "21319aa08e7c9072dcf1a4f2f5583887d701fc37"; + sha256 = "0lnvcb4khw1ywxd369phd2xibsh5f6qc11x5vrla331wr1q7y8j8"; + }; + meta.homepage = "https://github.com/occivink/kakoune-buffer-switcher/"; + }; + + kakoune-buffers = buildKakounePluginFrom2Nix { + pname = "kakoune-buffers"; + version = "2021-11-10"; + src = fetchFromGitHub { + owner = "Delapouite"; + repo = "kakoune-buffers"; + rev = "6b2081f5b7d58c72de319a5cba7bf628b6802881"; + sha256 = "0pbrgydifw2a8yf3ringyqq91fccfv4lm4v8sk5349hbcz6apr4c"; + }; + meta.homepage = "https://github.com/Delapouite/kakoune-buffers/"; + }; + + kakoune-easymotion = buildKakounePluginFrom2Nix { + pname = "kakoune-easymotion"; + version = "2020-03-09"; + src = fetchFromGitHub { + owner = "danr"; + repo = "kakoune-easymotion"; + rev = "0ca75450023a149efc70e8e383e459b571355c70"; + sha256 = "15czvl0qj2k767pysr6xk2v31mkhvcbmv76xs2a8yrslchms70b5"; + }; + meta.homepage = "https://github.com/danr/kakoune-easymotion/"; + }; + + kakoune-extra-filetypes = buildKakounePluginFrom2Nix { + pname = "kakoune-extra-filetypes"; + version = "2021-05-16"; + src = fetchFromGitHub { + owner = "kakoune-editor"; + repo = "kakoune-extra-filetypes"; + rev = "8ffeec08068edfee42e076c5f6d56a54a498bad2"; + sha256 = "1v87aqfk2jcysbdls3mh2v1yafk1albbinfxsxp11m4nxd2b9agl"; + }; + meta.homepage = "https://github.com/kakoune-editor/kakoune-extra-filetypes/"; + }; + + kakoune-rainbow = buildKakounePluginFrom2Nix { + pname = "kakoune-rainbow"; + version = "2020-09-01"; + src = fetchFromGitHub { + owner = "listentolist"; + repo = "kakoune-rainbow"; + rev = "d09103e8d268cf4621215bf162a0244c9482be3c"; + sha256 = "1i3id7xw0j4z1a14mscr68ckpgvcwsjpl86lr864wy7w7qcmblx6"; + }; + meta.homepage = "https://github.com/listentolist/kakoune-rainbow/"; + meta.mainProgram = "kak-rainbow.scm"; + }; + + kakoune-registers = buildKakounePluginFrom2Nix { + pname = "kakoune-registers"; + version = "2022-03-01"; + src = fetchFromGitHub { + owner = "Delapouite"; + repo = "kakoune-registers"; + rev = "b8ca8e04ebe50671a937bceccba69c62b68ae8b0"; + sha256 = "0vy5dc6jly5xqcck0vhnmbjxjdy3615b6d329v0b04amzy0hdlck"; + }; + meta.homepage = "https://github.com/Delapouite/kakoune-registers/"; + }; + + kakoune-vertical-selection = buildKakounePluginFrom2Nix { + pname = "kakoune-vertical-selection"; + version = "2023-04-20"; + src = fetchFromGitHub { + owner = "occivink"; + repo = "kakoune-vertical-selection"; + rev = "dbb39712e3824ca6142b510f26f35a769934a1e1"; + sha256 = "1wncx16a8mi2b81cvkiji3ccv8is5g3sa4hwf1669va5a432vdwn"; + }; + meta.homepage = "https://github.com/occivink/kakoune-vertical-selection/"; + }; + + openscad-kak = buildKakounePluginFrom2Nix { + pname = "openscad-kak"; + version = "2020-12-10"; + src = fetchFromGitHub { + owner = "mayjs"; + repo = "openscad.kak"; + rev = "ba51bbdcd96ccf94bb9239bef1481b6f37125849"; + sha256 = "15dybd6dnnwla6mj8sw83nwd62para1syxzifznl6rz6kp8vqjjj"; + }; + meta.homepage = "https://github.com/mayjs/openscad.kak/"; + }; + + pandoc-kak = buildKakounePluginFrom2Nix { + pname = "pandoc-kak"; + version = "2021-06-29"; + src = fetchFromGitHub { + owner = "basbebe"; + repo = "pandoc.kak"; + rev = "e9597e8df58427884161ce27392a9558930832a7"; + sha256 = "1baslidszbybx2ngdkm7wns2m5l27gc0mb3blhhydiav8fcfvc6m"; + }; + meta.homepage = "https://github.com/basbebe/pandoc.kak/"; + }; + + powerline-kak = buildKakounePluginFrom2Nix { + pname = "powerline-kak"; + version = "2022-04-05"; + src = fetchFromGitHub { + owner = "andreyorst"; + repo = "powerline.kak"; + rev = "c5ef9a845bbd886c73ef00c0efff986e02d5f5d8"; + sha256 = "1lshlnz5xrxzafxmb6w05g2i6nvi49aqyd8852k9l0lmzqryp7l2"; + }; + meta.homepage = "https://github.com/andreyorst/powerline.kak/"; + }; + + prelude-kak = buildKakounePluginFrom2Nix { + pname = "prelude-kak"; + version = "2021-02-24"; + src = fetchFromGitHub { + owner = "kakounedotcom"; + repo = "prelude.kak"; + rev = "5dbdc020c546032885c1fdb463e366cc89fc15ad"; + sha256 = "1pncr8azqvl2z9yvzhc68p1s9fld8cvak8yz88zgrp5ypx2cxl8c"; + }; + meta.homepage = "https://github.com/kakounedotcom/prelude.kak/"; + }; + + smarttab-kak = buildKakounePluginFrom2Nix { + pname = "smarttab-kak"; + version = "2022-04-10"; + src = fetchFromGitHub { + owner = "andreyorst"; + repo = "smarttab.kak"; + rev = "86ac6599b13617ff938905ba4cdd8225d7eb6a2e"; + sha256 = "1992xwf2aygzfd26lhg3yiy253g0hl1iagj0kq9yhcqg0i5xjcj9"; + }; + meta.homepage = "https://github.com/andreyorst/smarttab.kak/"; + }; + + tabs-kak = buildKakounePluginFrom2Nix { + pname = "tabs-kak"; + version = "2023-05-15"; + src = fetchFromGitHub { + owner = "enricozb"; + repo = "tabs.kak"; + rev = "f0b3a399db1dfa12b89fbff3eed09aec74725bab"; + sha256 = "1sg26bv4vr08pqyxp68wsmzj8vhi2qg1bmkqb2jnngi5sjp4r7xy"; + }; + meta.homepage = "https://github.com/enricozb/tabs.kak/"; + }; + + zig-kak = buildKakounePluginFrom2Nix { + pname = "zig-kak"; + version = "2019-05-06"; + src = fetchFromGitHub { + owner = "adrusi"; + repo = "zig.kak"; + rev = "5a7e84e138324e6b8d140fe384dfe5cc941e26b7"; + sha256 = "1w0nmhsgchjga4by9ch9md3pdc1bwn0p157g6zwnfpj7lnaahsmq"; + }; + meta.homepage = "https://github.com/adrusi/zig.kak/"; + }; + + } + ); +in +lib.fix' (lib.extends overrides packages) diff --git a/pkgs/applications/editors/kakoune/plugins/kakoune-utils.nix b/pkgs/applications/editors/kakoune/plugins/kakoune-utils.nix index 11a1cc130d6c9e..9bceed0841b3d1 100644 --- a/pkgs/applications/editors/kakoune/plugins/kakoune-utils.nix +++ b/pkgs/applications/editors/kakoune/plugins/kakoune-utils.nix @@ -1,4 +1,7 @@ { lib, stdenv }: { - inherit (import ./build-kakoune-plugin.nix { inherit lib stdenv; }) buildKakounePlugin buildKakounePluginFrom2Nix; + inherit (import ./build-kakoune-plugin.nix { inherit lib stdenv; }) + buildKakounePlugin + buildKakounePluginFrom2Nix + ; } diff --git a/pkgs/applications/editors/kakoune/plugins/overrides.nix b/pkgs/applications/editors/kakoune/plugins/overrides.nix index 6f60573f48b29e..1f5aaeb092793e 100644 --- a/pkgs/applications/editors/kakoune/plugins/overrides.nix +++ b/pkgs/applications/editors/kakoune/plugins/overrides.nix @@ -1,8 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, fetchFromGitLab, fetchgit -, buildKakounePluginFrom2Nix -, kakoune-lsp, parinfer-rust, rep -, fzf, git, guile, kakoune-unwrapped, lua5_3, plan9port -, rustPlatform +{ + lib, + stdenv, + fetchFromGitHub, + fetchFromGitLab, + fetchgit, + buildKakounePluginFrom2Nix, + kakoune-lsp, + parinfer-rust, + rep, + fzf, + git, + guile, + kakoune-unwrapped, + lua5_3, + plan9port, + rustPlatform, }: self: super: { @@ -20,7 +32,7 @@ self: super: { meta.homepage = "https://gitlab.com/FlyingWombat/case.kak"; }; - fzf-kak = super.fzf-kak.overrideAttrs(oldAttrs: rec { + fzf-kak = super.fzf-kak.overrideAttrs (oldAttrs: rec { preFixup = '' if [[ -x "${fzf}/bin/fzf" ]]; then fzfImpl='${fzf}/bin/fzf' @@ -45,21 +57,24 @@ self: super: { }; installPhase = '' - mkdir -p $out/bin $out/share/kak/autoload/plugins/ - cp kak-ansi-filter $out/bin/ - # Hard-code path of filter and don't try to build when Kakoune boots - sed ' - /^declare-option.* ansi_filter /i\ -declare-option -hidden str ansi_filter %{'"$out"'/bin/kak-ansi-filter} - /^declare-option.* ansi_filter /,/^}/d - ' rc/ansi.kak >$out/share/kak/autoload/plugins/ansi.kak + mkdir -p $out/bin $out/share/kak/autoload/plugins/ + cp kak-ansi-filter $out/bin/ + # Hard-code path of filter and don't try to build when Kakoune boots + sed ' + /^declare-option.* ansi_filter /i\ + declare-option -hidden str ansi_filter %{'"$out"'/bin/kak-ansi-filter} + /^declare-option.* ansi_filter /,/^}/d + ' rc/ansi.kak >$out/share/kak/autoload/plugins/ansi.kak ''; meta = with lib; { description = "Kakoune support for rendering ANSI code"; homepage = "https://github.com/eraserhd/kak-ansi"; license = licenses.unlicense; - maintainers = with maintainers; [ eraserhd philiptaron ]; + maintainers = with maintainers; [ + eraserhd + philiptaron + ]; platforms = platforms.all; }; }; @@ -89,12 +104,15 @@ declare-option -hidden str ansi_filter %{'"$out"'/bin/kak-ansi-filter} description = "Kakoune integration with the Plan 9 plumber"; homepage = "https://github.com/eraserhd/kak-plumb"; license = licenses.unlicense; - maintainers = with maintainers; [ eraserhd philiptaron ]; + maintainers = with maintainers; [ + eraserhd + philiptaron + ]; platforms = platforms.all; }; }; - kakoune-rainbow = super.kakoune-rainbow.overrideAttrs(oldAttrs: rec { + kakoune-rainbow = super.kakoune-rainbow.overrideAttrs (oldAttrs: rec { preFixup = '' mkdir -p $out/bin mv $out/share/kak/autoload/plugins/kakoune-rainbow/bin/kak-rainbow.scm $out/bin @@ -120,12 +138,15 @@ declare-option -hidden str ansi_filter %{'"$out"'/bin/kak-ansi-filter} description = "Help Kakoune save and restore state between sessions"; homepage = "https://gitlab.com/Screwtapello/kakoune-state-save"; license = licenses.mit; - maintainers = with maintainers; [ Flakebi philiptaron ]; + maintainers = with maintainers; [ + Flakebi + philiptaron + ]; platforms = platforms.all; }; }; - powerline-kak = super.powerline-kak.overrideAttrs(oldAttrs: rec { + powerline-kak = super.powerline-kak.overrideAttrs (oldAttrs: rec { preFixup = '' substituteInPlace $out/share/kak/autoload/plugins/powerline-kak/rc/modules/git.kak \ --replace ' git ' ' ${git}/bin/git ' diff --git a/pkgs/applications/editors/kakoune/plugins/update-shell.nix b/pkgs/applications/editors/kakoune/plugins/update-shell.nix index b323574169aa3b..787891309237b2 100644 --- a/pkgs/applications/editors/kakoune/plugins/update-shell.nix +++ b/pkgs/applications/editors/kakoune/plugins/update-shell.nix @@ -1,4 +1,6 @@ -{ pkgs ? import ../../../../.. { } }: +{ + pkgs ? import ../../../../.. { }, +}: with pkgs; let diff --git a/pkgs/applications/editors/kakoune/wrapper.nix b/pkgs/applications/editors/kakoune/wrapper.nix index 60ae58aa72c362..b1db86c7e58856 100644 --- a/pkgs/applications/editors/kakoune/wrapper.nix +++ b/pkgs/applications/editors/kakoune/wrapper.nix @@ -1,38 +1,47 @@ -{ lib, symlinkJoin, makeWrapper, kakoune, plugins ? [], configure ? {} }: +{ + lib, + symlinkJoin, + makeWrapper, + kakoune, + plugins ? [ ], + configure ? { }, +}: let # "plugins" is the preferred way, but some configurations may be # using "configure.plugins", so accept both - requestedPlugins = plugins ++ (configure.plugins or []); + requestedPlugins = plugins ++ (configure.plugins or [ ]); in - symlinkJoin { - name = "kakoune-${kakoune.version}"; - - nativeBuildInputs = [ makeWrapper ]; - - paths = [ kakoune ] ++ requestedPlugins; - - postBuild = '' - # create a directory for bins that kakoune needs - # access to, without polluting the users path by adding - # that binary nested with this symlinkJoin. - mkdir -p $out/share/kak/bin - - # location of kak binary is used to find ../share/kak/autoload, - # unless explicitly overriden with KAKOUNE_RUNTIME - rm "$out/bin/kak" - makeWrapper "${kakoune}/bin/kak" "$out/bin/kak" \ - --set KAKOUNE_RUNTIME "$out/share/kak" \ - --suffix PATH : "$out/share/kak/bin" - - # currently kakoune ignores doc files if they are symlinks, so workaround by - # copying doc files over, so they become regular files... - mkdir "$out/DELETE_ME" - mv "$out/share/kak/doc" "$out/DELETE_ME" - cp -r --dereference "$out/DELETE_ME/doc" "$out/share/kak" - rm -Rf "$out/DELETE_ME" - ''; - - meta = kakoune.meta // { priority = (kakoune.meta.priority or lib.meta.defaultPriority) - 1; }; - } +symlinkJoin { + name = "kakoune-${kakoune.version}"; + + nativeBuildInputs = [ makeWrapper ]; + + paths = [ kakoune ] ++ requestedPlugins; + + postBuild = '' + # create a directory for bins that kakoune needs + # access to, without polluting the users path by adding + # that binary nested with this symlinkJoin. + mkdir -p $out/share/kak/bin + + # location of kak binary is used to find ../share/kak/autoload, + # unless explicitly overriden with KAKOUNE_RUNTIME + rm "$out/bin/kak" + makeWrapper "${kakoune}/bin/kak" "$out/bin/kak" \ + --set KAKOUNE_RUNTIME "$out/share/kak" \ + --suffix PATH : "$out/share/kak/bin" + + # currently kakoune ignores doc files if they are symlinks, so workaround by + # copying doc files over, so they become regular files... + mkdir "$out/DELETE_ME" + mv "$out/share/kak/doc" "$out/DELETE_ME" + cp -r --dereference "$out/DELETE_ME/doc" "$out/share/kak" + rm -Rf "$out/DELETE_ME" + ''; + + meta = kakoune.meta // { + priority = (kakoune.meta.priority or lib.meta.defaultPriority) - 1; + }; +} diff --git a/pkgs/applications/editors/libresprite/default.nix b/pkgs/applications/editors/libresprite/default.nix index e4e6a1dd3c8111..d65389d917e27d 100644 --- a/pkgs/applications/editors/libresprite/default.nix +++ b/pkgs/applications/editors/libresprite/default.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, -, cmake -, pkg-config -, ninja -, gtest + cmake, + pkg-config, + ninja, + gtest, -, curl -, freetype -, giflib -, libjpeg -, libpng -, libwebp -, libarchive -, pixman -, tinyxml-2 -, zlib -, SDL2 -, SDL2_image -, lua -, AppKit -, Cocoa -, Foundation + curl, + freetype, + giflib, + libjpeg, + libpng, + libwebp, + libarchive, + pixman, + tinyxml-2, + zlib, + SDL2, + SDL2_image, + lua, + AppKit, + Cocoa, + Foundation, -, nixosTests + nixosTests, }: stdenv.mkDerivation (finalAttrs: { @@ -46,26 +47,28 @@ stdenv.mkDerivation (finalAttrs: { gtest ]; - buildInputs = [ - curl - freetype - giflib - libjpeg - libpng - libwebp - libarchive - pixman - tinyxml-2 - zlib - SDL2 - SDL2_image - lua - # no v8 due to missing libplatform and libbase - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - Cocoa - Foundation - ]; + buildInputs = + [ + curl + freetype + giflib + libjpeg + libpng + libwebp + libarchive + pixman + tinyxml-2 + zlib + SDL2 + SDL2_image + lua + # no v8 due to missing libplatform and libbase + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + Cocoa + Foundation + ]; cmakeFlags = [ "-DWITH_DESKTOP_INTEGRATION=ON" @@ -92,19 +95,19 @@ stdenv.mkDerivation (finalAttrs: { description = "Animated sprite editor & pixel art tool, fork of Aseprite"; license = lib.licenses.gpl2Only; longDescription = '' - LibreSprite is a program to create animated sprites. Its main features are: + LibreSprite is a program to create animated sprites. Its main features are: - - Sprites are composed by layers & frames (as separated concepts). - - Supported color modes: RGBA, Indexed (palettes up to 256 colors), and Grayscale. - - Load/save sequence of PNG files and GIF animations (and FLC, FLI, JPG, BMP, PCX, TGA). - - Export/import animations to/from Sprite Sheets. - - Tiled drawing mode, useful to draw patterns and textures. - - Undo/Redo for every operation. - - Real-time animation preview. - - Multiple editors support. - - Pixel-art specific tools like filled Contour, Polygon, Shading mode, etc. - - Onion skinning. - ''; + - Sprites are composed by layers & frames (as separated concepts). + - Supported color modes: RGBA, Indexed (palettes up to 256 colors), and Grayscale. + - Load/save sequence of PNG files and GIF animations (and FLC, FLI, JPG, BMP, PCX, TGA). + - Export/import animations to/from Sprite Sheets. + - Tiled drawing mode, useful to draw patterns and textures. + - Undo/Redo for every operation. + - Real-time animation preview. + - Multiple editors support. + - Pixel-art specific tools like filled Contour, Polygon, Shading mode, etc. + - Onion skinning. + ''; maintainers = with lib.maintainers; [ fgaz ]; platforms = lib.platforms.all; # https://github.com/LibreSprite/LibreSprite/issues/308 diff --git a/pkgs/applications/editors/manuskript/default.nix b/pkgs/applications/editors/manuskript/default.nix index 8fa589c13b5d47..56802dde7cd547 100644 --- a/pkgs/applications/editors/manuskript/default.nix +++ b/pkgs/applications/editors/manuskript/default.nix @@ -1,4 +1,10 @@ -{ lib, zlib, fetchFromGitHub, python3Packages, wrapQtAppsHook }: +{ + lib, + zlib, + fetchFromGitHub, + python3Packages, + wrapQtAppsHook, +}: python3Packages.buildPythonApplication rec { pname = "manuskript"; diff --git a/pkgs/applications/editors/molsketch/default.nix b/pkgs/applications/editors/molsketch/default.nix index dd3ee9bcdbb1cf..ca8c048fa18226 100644 --- a/pkgs/applications/editors/molsketch/default.nix +++ b/pkgs/applications/editors/molsketch/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, cmake -, pkg-config -, qttools -, wrapQtAppsHook -, hicolor-icon-theme -, openbabel -, desktop-file-utils +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + qttools, + wrapQtAppsHook, + hicolor-icon-theme, + openbabel, + desktop-file-utils, }: stdenv.mkDerivation rec { @@ -41,7 +42,12 @@ stdenv.mkDerivation rec { ln -s $out/lib/molsketch/* $out/lib/. ''; - nativeBuildInputs = [ cmake pkg-config qttools wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + pkg-config + qttools + wrapQtAppsHook + ]; buildInputs = [ hicolor-icon-theme openbabel diff --git a/pkgs/applications/editors/nano/default.nix b/pkgs/applications/editors/nano/default.nix index 76fd7cea623804..f353e39d2d1751 100644 --- a/pkgs/applications/editors/nano/default.nix +++ b/pkgs/applications/editors/nano/default.nix @@ -1,6 +1,22 @@ -{ lib, stdenv, fetchurl, fetchFromGitHub, ncurses, texinfo, writeScript -, common-updater-scripts, git, nix, nixfmt-classic, coreutils, gnused -, callPackage, file ? null, gettext ? null, enableNls ? true, enableTiny ? false +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + ncurses, + texinfo, + writeScript, + common-updater-scripts, + git, + nix, + nixfmt-classic, + coreutils, + gnused, + callPackage, + file ? null, + gettext ? null, + enableNls ? true, + enableTiny ? false, }: assert enableNls -> (gettext != null); @@ -13,7 +29,8 @@ let hash = "sha256-1tJV7F+iwMPRV6FgnbTw+5m7vMhgaeXftYkr9GPR4xw="; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "nano"; version = "8.2"; @@ -25,7 +42,10 @@ in stdenv.mkDerivation rec { nativeBuildInputs = [ texinfo ] ++ lib.optional enableNls gettext; buildInputs = [ ncurses ] ++ lib.optional (!enableTiny) file; - outputs = [ "out" "info" ]; + outputs = [ + "out" + "info" + ]; configureFlags = [ "--sysconfdir=/etc" @@ -33,16 +53,20 @@ in stdenv.mkDerivation rec { (lib.enableFeature enableTiny "tiny") ]; - postInstall = if enableTiny then - null - else '' - cp ${nixSyntaxHighlight}/nix.nanorc $out/share/nano/ - ''; + postInstall = + if enableTiny then + null + else + '' + cp ${nixSyntaxHighlight}/nix.nanorc $out/share/nano/ + ''; enableParallelBuilding = true; passthru = { - tests = { expect = callPackage ./test-with-expect.nix { }; }; + tests = { + expect = callPackage ./test-with-expect.nix { }; + }; updateScript = writeScript "update.sh" '' #!${stdenv.shell} @@ -76,7 +100,11 @@ in stdenv.mkDerivation rec { homepage = "https://www.nano-editor.org/"; description = "Small, user-friendly console text editor"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ joachifm nequissimus sigmasquadron ]; + maintainers = with maintainers; [ + joachifm + nequissimus + sigmasquadron + ]; platforms = platforms.all; mainProgram = "nano"; }; diff --git a/pkgs/applications/editors/nano/test-with-expect.nix b/pkgs/applications/editors/nano/test-with-expect.nix index 60cd3020454290..9e97e3843df856 100644 --- a/pkgs/applications/editors/nano/test-with-expect.nix +++ b/pkgs/applications/editors/nano/test-with-expect.nix @@ -1,35 +1,46 @@ -{ nano, expect, runCommand, writeScriptBin }: +{ + nano, + expect, + runCommand, + writeScriptBin, +}: -let expect-script = writeScriptBin "expect-script" '' - #!${expect}/bin/expect -f +let + expect-script = writeScriptBin "expect-script" '' + #!${expect}/bin/expect -f - # Load nano - spawn nano file.txt - expect "GNU nano ${nano.version}" + # Load nano + spawn nano file.txt + expect "GNU nano ${nano.version}" - # Add some text to the buffer - send "Hello world!" - expect "Hello world!" + # Add some text to the buffer + send "Hello world!" + expect "Hello world!" - # Send ctrl-x (exit) - send "\030" - expect "Save modified buffer?" + # Send ctrl-x (exit) + send "\030" + expect "Save modified buffer?" - # Answer "yes" - send "y" - expect "File Name to Write" + # Answer "yes" + send "y" + expect "File Name to Write" - # Send "return" to accept the file path. - send "\r" - sleep 1 - exit -''; in + # Send "return" to accept the file path. + send "\r" + sleep 1 + exit + ''; +in runCommand "nano-test-expect" -{ - nativeBuildInputs = [ nano expect ]; - passthru = { inherit expect-script; }; -} '' - expect -f ${expect-script}/bin/expect-script - grep "Hello world!" file.txt - touch $out -'' + { + nativeBuildInputs = [ + nano + expect + ]; + passthru = { inherit expect-script; }; + } + '' + expect -f ${expect-script}/bin/expect-script + grep "Hello world!" file.txt + touch $out + '' diff --git a/pkgs/applications/editors/neovim/gnvim/default.nix b/pkgs/applications/editors/neovim/gnvim/default.nix index e39a43a85863d0..ea2f543b5ef10d 100644 --- a/pkgs/applications/editors/neovim/gnvim/default.nix +++ b/pkgs/applications/editors/neovim/gnvim/default.nix @@ -1,4 +1,11 @@ -{ lib, rustPlatform, fetchFromGitHub, pkg-config, glib, gtk4 }: +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + glib, + gtk4, +}: rustPlatform.buildRustPackage rec { pname = "gnvim-unwrapped"; @@ -18,7 +25,10 @@ rustPlatform.buildRustPackage rec { # for the `glib-compile-resources` command glib ]; - buildInputs = [ glib gtk4 ]; + buildInputs = [ + glib + gtk4 + ]; # The default build script tries to get the version through Git, so we # replace it diff --git a/pkgs/applications/editors/neovim/gnvim/wrapper.nix b/pkgs/applications/editors/neovim/gnvim/wrapper.nix index 7869885d1b749c..dd651f56ff15ec 100644 --- a/pkgs/applications/editors/neovim/gnvim/wrapper.nix +++ b/pkgs/applications/editors/neovim/gnvim/wrapper.nix @@ -1,22 +1,30 @@ -{ lib, stdenv, gnvim-unwrapped, neovim, makeWrapper }: +{ + lib, + stdenv, + gnvim-unwrapped, + neovim, + makeWrapper, +}: stdenv.mkDerivation { pname = "gnvim"; version = gnvim-unwrapped.version; - buildCommand = '' - makeWrapper '${gnvim-unwrapped}/bin/gnvim' "$out/bin/gnvim" \ - --prefix PATH : "${neovim}/bin" \ - --set GNVIM_RUNTIME_PATH "${gnvim-unwrapped}/share/gnvim/runtime" - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - mkdir -p "$out/share" - ln -s '${gnvim-unwrapped}/share/icons' "$out/share/icons" + buildCommand = + '' + makeWrapper '${gnvim-unwrapped}/bin/gnvim' "$out/bin/gnvim" \ + --prefix PATH : "${neovim}/bin" \ + --set GNVIM_RUNTIME_PATH "${gnvim-unwrapped}/share/gnvim/runtime" + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + mkdir -p "$out/share" + ln -s '${gnvim-unwrapped}/share/icons' "$out/share/icons" - # copy and fix .desktop file - cp -r '${gnvim-unwrapped}/share/applications' "$out/share/applications" - # Sed needs a writable directory to do inplace modifications - chmod u+rw "$out/share/applications" - sed -e "s|Exec=.\\+gnvim\\>|Exec=gnvim|" -i $out/share/applications/*.desktop - ''; + # copy and fix .desktop file + cp -r '${gnvim-unwrapped}/share/applications' "$out/share/applications" + # Sed needs a writable directory to do inplace modifications + chmod u+rw "$out/share/applications" + sed -e "s|Exec=.\\+gnvim\\>|Exec=gnvim|" -i $out/share/applications/*.desktop + ''; preferLocalBuild = true; @@ -28,4 +36,3 @@ stdenv.mkDerivation { inherit (gnvim-unwrapped) meta; } - diff --git a/pkgs/applications/editors/neovim/ruby_provider/gemset.nix b/pkgs/applications/editors/neovim/ruby_provider/gemset.nix index 75b461a908a3c1..f19ac51e9d5515 100644 --- a/pkgs/applications/editors/neovim/ruby_provider/gemset.nix +++ b/pkgs/applications/editors/neovim/ruby_provider/gemset.nix @@ -1,40 +1,43 @@ { logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; msgpack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a5fsgchkpcca4wf3pipbb2jbj523l7fbaq37j10cr0yymwlkc7z"; type = "gem"; }; version = "1.7.5"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "sha256-H9BBOLbkqQAX6NG4BMA5AxOZhm/z+6u3girqNnx4YV0="; type = "gem"; }; version = "1.15.0"; }; neovim = { - dependencies = ["msgpack" "multi_json"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "msgpack" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gl34rriwwmj6p1s6ms0b311wmqaqiyc510svq31283jk0kp0qcd"; type = "gem"; }; diff --git a/pkgs/applications/editors/neovim/utils.nix b/pkgs/applications/editors/neovim/utils.nix index 946619698dbc4a..926e0a5cf5c4ec 100644 --- a/pkgs/applications/editors/neovim/utils.nix +++ b/pkgs/applications/editors/neovim/utils.nix @@ -1,34 +1,36 @@ -{ lib -, stdenv -, makeSetupHook -, callPackage -, config -, vimUtils -, vimPlugins -, nodejs -, neovim-unwrapped -, bundlerEnv -, ruby -, lua -, python3Packages -, wrapNeovimUnstable +{ + lib, + stdenv, + makeSetupHook, + callPackage, + config, + vimUtils, + vimPlugins, + nodejs, + neovim-unwrapped, + bundlerEnv, + ruby, + lua, + python3Packages, + wrapNeovimUnstable, }: let inherit (vimUtils) toVimPlugin; - /* transform all plugins into an attrset - { optional = bool; plugin = package; } + /* + transform all plugins into an attrset + { optional = bool; plugin = package; } */ - normalizePlugins = plugins: - let - defaultPlugin = { - plugin = null; - config = null; - optional = false; - }; - in - map (x: defaultPlugin // (if (x ? plugin) then x else { plugin = x; })) plugins; - + normalizePlugins = + plugins: + let + defaultPlugin = { + plugin = null; + config = null; + optional = false; + }; + in + map (x: defaultPlugin // (if (x ? plugin) then x else { plugin = x; })) plugins; /** accepts a list of normalized plugins and convert them into a vim package @@ -47,97 +49,135 @@ let => { start = [ vim-fugitive ]; opt = []; } ::: */ - normalizedPluginsToVimPackage = normalizedPlugins: + normalizedPluginsToVimPackage = + normalizedPlugins: let pluginsPartitioned = lib.partition (x: x.optional == true) normalizedPlugins; - in { - start = map (x: x.plugin) pluginsPartitioned.wrong; - opt = map (x: x.plugin) pluginsPartitioned.right; - }; + in + { + start = map (x: x.plugin) pluginsPartitioned.wrong; + opt = map (x: x.plugin) pluginsPartitioned.right; + }; - /* returns everything needed for the caller to wrap its own neovim: - - the generated content of the future init.vim - - the arguments to wrap neovim with - The caller is responsible for writing the init.vim and adding it to the wrapped - arguments (["-u" writeText "init.vim" GENERATEDRC)]). - This makes it possible to write the config anywhere: on a per-project basis - .nvimrc or in $XDG_CONFIG_HOME/nvim/init.vim to avoid sideeffects. - Indeed, note that wrapping with `-u init.vim` has sideeffects like .nvimrc wont be loaded - anymore, $MYVIMRC wont be set etc - */ - makeNeovimConfig = { - customRC ? "" - /* the function you would have passed to lua.withPackages */ - , extraLuaPackages ? (_: [ ]) - , ...}@attrs: let - luaEnv = neovim-unwrapped.lua.withPackages extraLuaPackages; - in attrs // { - neovimRcContent = customRC; - wrapperArgs = lib.optionals (luaEnv != null) [ - "--prefix" "LUA_PATH" ";" (neovim-unwrapped.lua.pkgs.luaLib.genLuaPathAbsStr luaEnv) - "--prefix" "LUA_CPATH" ";" (neovim-unwrapped.lua.pkgs.luaLib.genLuaCPathAbsStr luaEnv) + /* + returns everything needed for the caller to wrap its own neovim: + - the generated content of the future init.vim + - the arguments to wrap neovim with + The caller is responsible for writing the init.vim and adding it to the wrapped + arguments (["-u" writeText "init.vim" GENERATEDRC)]). + This makes it possible to write the config anywhere: on a per-project basis + .nvimrc or in $XDG_CONFIG_HOME/nvim/init.vim to avoid sideeffects. + Indeed, note that wrapping with `-u init.vim` has sideeffects like .nvimrc wont be loaded + anymore, $MYVIMRC wont be set etc + */ + makeNeovimConfig = + { + customRC ? "", + # the function you would have passed to lua.withPackages + extraLuaPackages ? (_: [ ]), + ... + }@attrs: + let + luaEnv = neovim-unwrapped.lua.withPackages extraLuaPackages; + in + attrs + // { + neovimRcContent = customRC; + wrapperArgs = lib.optionals (luaEnv != null) [ + "--prefix" + "LUA_PATH" + ";" + (neovim-unwrapped.lua.pkgs.luaLib.genLuaPathAbsStr luaEnv) + "--prefix" + "LUA_CPATH" + ";" + (neovim-unwrapped.lua.pkgs.luaLib.genLuaCPathAbsStr luaEnv) ]; - }; - + }; # to keep backwards compatibility for people using neovim.override - legacyWrapper = neovim: { - extraMakeWrapperArgs ? "" - /* the function you would have passed to python.withPackages */ - , extraPythonPackages ? (_: []) - /* the function you would have passed to python.withPackages */ - , withPython3 ? true, extraPython3Packages ? (_: []) - /* the function you would have passed to lua.withPackages */ - , extraLuaPackages ? (_: []) - , withNodeJs ? false - , withRuby ? true - , vimAlias ? false - , viAlias ? false - , configure ? {} - , extraName ? "" - }: + legacyWrapper = + neovim: + { + extraMakeWrapperArgs ? "", + # the function you would have passed to python.withPackages + extraPythonPackages ? (_: [ ]), + # the function you would have passed to python.withPackages + withPython3 ? true, + extraPython3Packages ? (_: [ ]), + # the function you would have passed to lua.withPackages + extraLuaPackages ? (_: [ ]), + withNodeJs ? false, + withRuby ? true, + vimAlias ? false, + viAlias ? false, + configure ? { }, + extraName ? "", + }: let # we convert from the old configure.format to - plugins = if builtins.hasAttr "plug" configure then + plugins = + if builtins.hasAttr "plug" configure then throw "The neovim legacy wrapper doesn't support configure.plug anymore, please setup your plugins via 'configure.packages' instead" else - lib.flatten (lib.mapAttrsToList genPlugin (configure.packages or {})); - genPlugin = packageName: {start ? [], opt ? []}: - start ++ (map (p: { plugin = p; optional = true; }) opt); + lib.flatten (lib.mapAttrsToList genPlugin (configure.packages or { })); + genPlugin = + packageName: + { + start ? [ ], + opt ? [ ], + }: + start + ++ (map (p: { + plugin = p; + optional = true; + }) opt); res = makeNeovimConfig { inherit withPython3; inherit extraPython3Packages; inherit extraLuaPackages; - inherit withNodeJs withRuby viAlias vimAlias; + inherit + withNodeJs + withRuby + viAlias + vimAlias + ; customRC = configure.customRC or ""; inherit plugins; inherit extraName; }; in - wrapNeovimUnstable neovim (res // { - wrapperArgs = lib.escapeShellArgs res.wrapperArgs + " " + extraMakeWrapperArgs; - wrapRc = (configure != {}); - }); - - /* Generate vim.g._host_prog lua rc to setup host providers - - Mapping a boolean argument to a key that tells us whether to add - vim.g._host_prog=$out/bin/nvim- - Or this: - let g:loaded_${prog}_provider=0 - While the latter tells nvim that this provider is not available */ - generateProviderRc = { - withPython3 ? true - , withNodeJs ? false - , withRuby ? true - # perl is problematic https://github.com/NixOS/nixpkgs/issues/132368 - , withPerl ? false - - # so that we can pass the full neovim config while ignoring it - , ... - }: let + wrapNeovimUnstable neovim ( + res + // { + wrapperArgs = lib.escapeShellArgs res.wrapperArgs + " " + extraMakeWrapperArgs; + wrapRc = (configure != { }); + } + ); + + /* + Generate vim.g._host_prog lua rc to setup host providers + + Mapping a boolean argument to a key that tells us whether to add + vim.g._host_prog=$out/bin/nvim- + Or this: + let g:loaded_${prog}_provider=0 + While the latter tells nvim that this provider is not available + */ + generateProviderRc = + { + withPython3 ? true, + withNodeJs ? false, + withRuby ? true, + # perl is problematic https://github.com/NixOS/nixpkgs/issues/132368 + withPerl ? false, + + # so that we can pass the full neovim config while ignoring it + ... + }: + let hostprog_check_table = { node = withNodeJs; python = false; @@ -146,7 +186,8 @@ let perl = withPerl; }; - genProviderCommand = prog: withProg: + genProviderCommand = + prog: withProg: if withProg then "vim.g.${prog}_host_prog='${placeholder "out"}/bin/nvim-${prog}'" else @@ -154,9 +195,10 @@ let hostProviderLua = lib.mapAttrsToList genProviderCommand hostprog_check_table; in - lib.concatStringsSep ";" hostProviderLua; + lib.concatStringsSep ";" hostProviderLua; - /* Converts a lua package into a neovim plugin. + /* + Converts a lua package into a neovim plugin. Does so by installing the lua package with a flat hierarchy of folders */ buildNeovimPlugin = callPackage ./build-neovim-plugin.nix { @@ -164,7 +206,8 @@ let inherit lua; }; - grammarToPlugin = grammar: + grammarToPlugin = + grammar: let name = lib.pipe grammar [ lib.getName @@ -184,45 +227,49 @@ let ) vimPlugins.nvim-treesitter.grammarPlugins; isNvimGrammar = x: builtins.elem x nvimGrammars; - toNvimTreesitterGrammar = callPackage ({ }: + toNvimTreesitterGrammar = callPackage ( + { }: makeSetupHook { name = "to-nvim-treesitter-grammar"; - } ./to-nvim-treesitter-grammar.sh) {}; + } ./to-nvim-treesitter-grammar.sh + ) { }; in - (toVimPlugin (stdenv.mkDerivation { - name = "treesitter-grammar-${name}"; - - origGrammar = grammar; - grammarName = name; - - # Queries for nvim-treesitter's (not just tree-sitter's) officially - # supported languages are bundled with nvim-treesitter - # Queries from repositories for such languages are incompatible - # with nvim's implementation of treesitter. - # - # We try our best effort to only include queries for niche languages - # (there are grammars for them in nixpkgs, but they're in - # `tree-sitter-grammars.tree-sitter-*`; `vimPlugins.nvim-treesitter-parsers.*` - # only includes officially supported languages) - # - # To use grammar for a niche language, users usually do: - # packages.all.start = with final.vimPlugins; [ - # (pkgs.neovimUtils.grammarToPlugin pkgs.tree-sitter-grammars.tree-sitter-LANG) - # ] - # - # See also https://github.com/NixOS/nixpkgs/pull/344849#issuecomment-2381447839 - installQueries = !isNvimGrammar grammar; - - dontUnpack = true; - __structuredAttrs = true; - - nativeBuildInputs = [ toNvimTreesitterGrammar ]; - - meta = { - platforms = lib.platforms.all; - } // grammar.meta; - })); + (toVimPlugin ( + stdenv.mkDerivation { + name = "treesitter-grammar-${name}"; + + origGrammar = grammar; + grammarName = name; + + # Queries for nvim-treesitter's (not just tree-sitter's) officially + # supported languages are bundled with nvim-treesitter + # Queries from repositories for such languages are incompatible + # with nvim's implementation of treesitter. + # + # We try our best effort to only include queries for niche languages + # (there are grammars for them in nixpkgs, but they're in + # `tree-sitter-grammars.tree-sitter-*`; `vimPlugins.nvim-treesitter-parsers.*` + # only includes officially supported languages) + # + # To use grammar for a niche language, users usually do: + # packages.all.start = with final.vimPlugins; [ + # (pkgs.neovimUtils.grammarToPlugin pkgs.tree-sitter-grammars.tree-sitter-LANG) + # ] + # + # See also https://github.com/NixOS/nixpkgs/pull/344849#issuecomment-2381447839 + installQueries = !isNvimGrammar grammar; + + dontUnpack = true; + __structuredAttrs = true; + + nativeBuildInputs = [ toNvimTreesitterGrammar ]; + + meta = { + platforms = lib.platforms.all; + } // grammar.meta; + } + )); /* Fork of vimUtils.packDir that additionnally generates a propagated-build-inputs-file that @@ -233,19 +280,20 @@ let packDir ( {myVimPackage = { start = [ vimPlugins.vim-fugitive ]; opt = []; }; }) => "/nix/store/xxxxx-pack-dir" */ - packDir = packages: - let - rawPackDir = vimUtils.packDir packages; + packDir = + packages: + let + rawPackDir = vimUtils.packDir packages; - in + in rawPackDir.override ({ - postBuild = '' - mkdir $out/nix-support - for i in $(find -L $out -name propagated-build-inputs ); do - cat "$i" >> $out/nix-support/propagated-build-inputs - done - '';}); - + postBuild = '' + mkdir $out/nix-support + for i in $(find -L $out -name propagated-build-inputs ); do + cat "$i" >> $out/nix-support/propagated-build-inputs + done + ''; + }); in { @@ -257,6 +305,7 @@ in inherit normalizePlugins normalizedPluginsToVimPackage; inherit buildNeovimPlugin; -} // lib.optionalAttrs config.allowAliases { +} +// lib.optionalAttrs config.allowAliases { buildNeovimPluginFrom2Nix = lib.warn "buildNeovimPluginFrom2Nix was renamed to buildNeovimPlugin" buildNeovimPlugin; } diff --git a/pkgs/applications/editors/notepad-next/default.nix b/pkgs/applications/editors/notepad-next/default.nix index aecdc76d9c6883..e7a41ddc482b0c 100644 --- a/pkgs/applications/editors/notepad-next/default.nix +++ b/pkgs/applications/editors/notepad-next/default.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, fetchFromGitHub, qmake, qttools, qtx11extras, stdenv }: +{ + mkDerivation, + lib, + fetchFromGitHub, + qmake, + qttools, + qtx11extras, + stdenv, +}: mkDerivation rec { pname = "notepad-next"; @@ -13,7 +21,10 @@ mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ qmake qttools ]; + nativeBuildInputs = [ + qmake + qttools + ]; buildInputs = [ qtx11extras ]; qmakeFlags = [ diff --git a/pkgs/applications/editors/notepadqq/default.nix b/pkgs/applications/editors/notepadqq/default.nix index 0fbf6685a79d94..019887ee324bbc 100644 --- a/pkgs/applications/editors/notepadqq/default.nix +++ b/pkgs/applications/editors/notepadqq/default.nix @@ -1,14 +1,15 @@ -{ mkDerivation -, lib -, fetchFromGitHub -, pkg-config -, which -, libuchardet -, qtbase -, qtsvg -, qttools -, qtwebengine -, qtwebsockets +{ + mkDerivation, + lib, + fetchFromGitHub, + pkg-config, + which, + libuchardet, + qtbase, + qtsvg, + qttools, + qtwebengine, + qtwebsockets, }: mkDerivation rec { diff --git a/pkgs/applications/editors/okteta/default.nix b/pkgs/applications/editors/okteta/default.nix index e210787327b906..d0f9dfc4b6fd9b 100644 --- a/pkgs/applications/editors/okteta/default.nix +++ b/pkgs/applications/editors/okteta/default.nix @@ -1,6 +1,21 @@ -{ mkDerivation, lib, fetchurl, extra-cmake-modules, kdoctools, qtscript, kconfig -, kinit, karchive, kcrash, kcmutils, kconfigwidgets, knewstuff, kparts -, qca-qt5, shared-mime-info }: +{ + mkDerivation, + lib, + fetchurl, + extra-cmake-modules, + kdoctools, + qtscript, + kconfig, + kinit, + karchive, + kcrash, + kcmutils, + kconfigwidgets, + knewstuff, + kparts, + qca-qt5, + shared-mime-info, +}: mkDerivation rec { pname = "okteta"; @@ -11,7 +26,11 @@ mkDerivation rec { sha256 = "sha256-xAlhZtQuIRtvMaHflCr89lHH6ocqIRAECwHdRa+/imM="; }; - nativeBuildInputs = [ qtscript extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + qtscript + extra-cmake-modules + kdoctools + ]; buildInputs = [ shared-mime-info ]; propagatedBuildInputs = [ @@ -26,13 +45,19 @@ mkDerivation rec { kcrash ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = with lib; { license = licenses.gpl2; description = "Hex editor"; homepage = "https://apps.kde.org/okteta/"; - maintainers = with maintainers; [ peterhoeg bkchr ]; + maintainers = with maintainers; [ + peterhoeg + bkchr + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/editors/pinegrow/default.nix b/pkgs/applications/editors/pinegrow/default.nix index 2e3de9ae8aa362..25d3f0a100bb51 100644 --- a/pkgs/applications/editors/pinegrow/default.nix +++ b/pkgs/applications/editors/pinegrow/default.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchurl -, unzip -, udev -, nwjs -, gcc-unwrapped -, autoPatchelfHook -, gsettings-desktop-schemas -, gtk3 -, wrapGAppsHook3 -, makeWrapper -, pinegrowVersion ? "7" +{ + stdenv, + lib, + fetchurl, + unzip, + udev, + nwjs, + gcc-unwrapped, + autoPatchelfHook, + gsettings-desktop-schemas, + gtk3, + wrapGAppsHook3, + makeWrapper, + pinegrowVersion ? "7", }: let @@ -26,7 +27,9 @@ let "7" = { version = "7.8"; src = fetchurl { - url = "https://github.com/Pinegrow/PinegrowReleases/releases/download/pg${builtins.substring 0 4 (versions."7".version)}/PinegrowLinux64.${versions."7".version}.zip"; + url = "https://github.com/Pinegrow/PinegrowReleases/releases/download/pg${ + builtins.substring 0 4 (versions."7".version) + }/PinegrowLinux64.${versions."7".version}.zip"; hash = "sha256-tYQfPfzKRwClNwgSoJfMwG3LHhi3O/iFuuwIVHS8OXk="; }; }; @@ -58,7 +61,13 @@ stdenv.mkDerivation rec { dontWrapGApps = true; makeWrapperArgs = [ - "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ gcc-unwrapped.lib gtk3 udev ]}" + "--prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + gcc-unwrapped.lib + gtk3 + udev + ] + }" "--prefix PATH : ${lib.makeBinPath [ stdenv.cc ]}" ]; diff --git a/pkgs/applications/editors/qxmledit/default.nix b/pkgs/applications/editors/qxmledit/default.nix index 946a56917d6302..9d64e6549c8e92 100644 --- a/pkgs/applications/editors/qxmledit/default.nix +++ b/pkgs/applications/editors/qxmledit/default.nix @@ -1,11 +1,23 @@ -{ lib, stdenv, fetchFromGitHub, qmake, qtbase, qtxmlpatterns, qtsvg, qtscxml -, libGLU }: +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + qtbase, + qtxmlpatterns, + qtsvg, + qtscxml, + libGLU, +}: stdenv.mkDerivation rec { pname = "qxmledit"; version = "0.9.17"; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; src = fetchFromGitHub { owner = "lbellonda"; @@ -16,7 +28,13 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ qmake ]; - buildInputs = [ qtbase qtxmlpatterns qtsvg qtscxml libGLU ]; + buildInputs = [ + qtbase + qtxmlpatterns + qtsvg + qtscxml + libGLU + ]; qmakeFlags = [ "CONFIG+=release" ]; diff --git a/pkgs/applications/editors/rednotebook/default.nix b/pkgs/applications/editors/rednotebook/default.nix index 4709d880056bcf..7600b3376d17da 100644 --- a/pkgs/applications/editors/rednotebook/default.nix +++ b/pkgs/applications/editors/rednotebook/default.nix @@ -1,6 +1,17 @@ -{ lib, buildPythonApplication, fetchFromGitHub -, gdk-pixbuf, glib, gobject-introspection, gtk3, gtksourceview, pango, webkitgtk_4_0 -, pygobject3, pyyaml, setuptools +{ + lib, + buildPythonApplication, + fetchFromGitHub, + gdk-pixbuf, + glib, + gobject-introspection, + gtk3, + gtksourceview, + pango, + webkitgtk_4_0, + pygobject3, + pyyaml, + setuptools, }: buildPythonApplication rec { @@ -23,8 +34,14 @@ buildPythonApplication rec { build-system = [ setuptools ]; propagatedBuildInputs = [ - gdk-pixbuf glib gtk3 gtksourceview pango webkitgtk_4_0 - pygobject3 pyyaml + gdk-pixbuf + glib + gtk3 + gtksourceview + pango + webkitgtk_4_0 + pygobject3 + pyyaml ]; makeWrapperArgs = [ diff --git a/pkgs/applications/editors/retext/default.nix b/pkgs/applications/editors/retext/default.nix index 10e6a04498ab5e..095447a17a4040 100644 --- a/pkgs/applications/editors/retext/default.nix +++ b/pkgs/applications/editors/retext/default.nix @@ -1,16 +1,20 @@ -{ lib -, python3 -, fetchzip -, fetchFromGitHub -, wrapQtAppsHook -, qtbase -, qttools -, qtsvg -, buildEnv -, aspellDicts +{ + lib, + python3, + fetchzip, + fetchFromGitHub, + wrapQtAppsHook, + qtbase, + qttools, + qtsvg, + buildEnv, + aspellDicts, # Use `lib.collect lib.isDerivation aspellDicts;` to make all dictionaries # available. -, enchantAspellDicts ? with aspellDicts; [ en en-computers ] + enchantAspellDicts ? with aspellDicts; [ + en + en-computers + ], }: python3.pkgs.buildPythonApplication rec { @@ -63,10 +67,12 @@ python3.pkgs.buildPythonApplication rec { postInstall = '' makeWrapperArgs+=("''${qtWrapperArgs[@]}") makeWrapperArgs+=( - "--set" "ASPELL_CONF" "dict-dir ${buildEnv { - name = "aspell-all-dicts"; - paths = map (path: "${path}/lib/aspell") enchantAspellDicts; - }}" + "--set" "ASPELL_CONF" "dict-dir ${ + buildEnv { + name = "aspell-all-dicts"; + paths = map (path: "${path}/lib/aspell") enchantAspellDicts; + } + }" ) cp ${toolbarIcons}/* $out/${python3.pkgs.python.sitePackages}/ReText/icons diff --git a/pkgs/applications/editors/sigil/default.nix b/pkgs/applications/editors/sigil/default.nix index 022e9ec6972028..4bba56f46e3295 100644 --- a/pkgs/applications/editors/sigil/default.nix +++ b/pkgs/applications/editors/sigil/default.nix @@ -1,6 +1,17 @@ -{ lib, mkDerivation, fetchFromGitHub, cmake, pkg-config, makeWrapper -, boost, xercesc, qtbase, qttools, qtwebengine, qtxmlpatterns -, python3Packages +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + pkg-config, + makeWrapper, + boost, + xercesc, + qtbase, + qttools, + qtwebengine, + qtxmlpatterns, + python3Packages, }: mkDerivation rec { @@ -16,10 +27,19 @@ mkDerivation rec { pythonPath = with python3Packages; [ lxml ]; - nativeBuildInputs = [ cmake pkg-config makeWrapper ]; + nativeBuildInputs = [ + cmake + pkg-config + makeWrapper + ]; buildInputs = [ - boost xercesc qtbase qttools qtwebengine qtxmlpatterns + boost + xercesc + qtbase + qttools + qtwebengine + qtxmlpatterns python3Packages.lxml ]; diff --git a/pkgs/applications/editors/standardnotes/default.nix b/pkgs/applications/editors/standardnotes/default.nix index f7cd2872a227be..61eb5f88585218 100644 --- a/pkgs/applications/editors/standardnotes/default.nix +++ b/pkgs/applications/editors/standardnotes/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, dpkg -, makeWrapper -, electron -, libsecret -, asar -, glib -, desktop-file-utils -, callPackage +{ + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + electron, + libsecret, + asar, + glib, + desktop-file-utils, + callPackage, }: let @@ -31,37 +32,43 @@ stdenv.mkDerivation rec { dontBuild = true; - nativeBuildInputs = [ makeWrapper dpkg desktop-file-utils asar ]; - - installPhase = let - libPath = lib.makeLibraryPath [ - libsecret - glib - (lib.getLib stdenv.cc.cc) - ]; - in + nativeBuildInputs = [ + makeWrapper + dpkg + desktop-file-utils + asar + ]; + + installPhase = + let + libPath = lib.makeLibraryPath [ + libsecret + glib + (lib.getLib stdenv.cc.cc) + ]; + in '' - runHook preInstall + runHook preInstall - mkdir -p $out/bin $out/share/standardnotes - cp -R usr/share/{applications,icons} $out/share - cp -R opt/Standard\ Notes/resources/app.asar $out/share/standardnotes/ - asar e $out/share/standardnotes/app.asar asar-unpacked - find asar-unpacked -name '*.node' -exec patchelf \ - --add-rpath "${libPath}" \ - {} \; - asar p asar-unpacked $out/share/standardnotes/app.asar + mkdir -p $out/bin $out/share/standardnotes + cp -R usr/share/{applications,icons} $out/share + cp -R opt/Standard\ Notes/resources/app.asar $out/share/standardnotes/ + asar e $out/share/standardnotes/app.asar asar-unpacked + find asar-unpacked -name '*.node' -exec patchelf \ + --add-rpath "${libPath}" \ + {} \; + asar p asar-unpacked $out/share/standardnotes/app.asar - makeWrapper ${electron}/bin/electron $out/bin/standardnotes \ - --add-flags $out/share/standardnotes/app.asar + makeWrapper ${electron}/bin/electron $out/bin/standardnotes \ + --add-flags $out/share/standardnotes/app.asar - ${desktop-file-utils}/bin/desktop-file-install --dir $out/share/applications \ - --set-key Exec --set-value standardnotes usr/share/applications/standard-notes.desktop + ${desktop-file-utils}/bin/desktop-file-install --dir $out/share/applications \ + --set-key Exec --set-value standardnotes usr/share/applications/standard-notes.desktop - runHook postInstall - ''; + runHook postInstall + ''; - passthru.updateScript = callPackage ./update.nix {}; + passthru.updateScript = callPackage ./update.nix { }; meta = with lib; { description = "Simple and private notes app"; @@ -71,7 +78,11 @@ stdenv.mkDerivation rec { ''; homepage = "https://standardnotes.org"; license = licenses.agpl3Only; - maintainers = with maintainers; [ mgregoire chuangzhu squalus ]; + maintainers = with maintainers; [ + mgregoire + chuangzhu + squalus + ]; sourceProvenance = [ sourceTypes.binaryNativeCode ]; platforms = builtins.attrNames srcjson.deb; mainProgram = "standardnotes"; diff --git a/pkgs/applications/editors/standardnotes/update.nix b/pkgs/applications/editors/standardnotes/update.nix index ab8e472a324f8c..a6110e0684de28 100644 --- a/pkgs/applications/editors/standardnotes/update.nix +++ b/pkgs/applications/editors/standardnotes/update.nix @@ -1,9 +1,27 @@ -{ writeScript -, lib, curl, runtimeShell, jq, coreutils, moreutils, nix, gnused }: +{ + writeScript, + lib, + curl, + runtimeShell, + jq, + coreutils, + moreutils, + nix, + gnused, +}: writeScript "update-standardnotes" '' #!${runtimeShell} - PATH=${lib.makeBinPath [ jq curl nix coreutils moreutils gnused ]} + PATH=${ + lib.makeBinPath [ + jq + curl + nix + coreutils + moreutils + gnused + ] + } set -euo pipefail set -x diff --git a/pkgs/applications/editors/sublime/3/common.nix b/pkgs/applications/editors/sublime/3/common.nix index 7c5e9aef1ea1ff..65d01a6eedb163 100644 --- a/pkgs/applications/editors/sublime/3/common.nix +++ b/pkgs/applications/editors/sublime/3/common.nix @@ -1,31 +1,58 @@ -{ buildVersion, x32sha256, x64sha256, dev ? false }: +{ + buildVersion, + x32sha256, + x64sha256, + dev ? false, +}: -{ fetchurl, lib, stdenv, xorg, glib, glibcLocales, gtk3, cairo, pango, libredirect, makeWrapper, wrapGAppsHook3 -, pkexecPath ? "/run/wrappers/bin/pkexec" -, openssl, bzip2, bash, unzip, zip +{ + fetchurl, + lib, + stdenv, + xorg, + glib, + glibcLocales, + gtk3, + cairo, + pango, + libredirect, + makeWrapper, + wrapGAppsHook3, + pkexecPath ? "/run/wrappers/bin/pkexec", + openssl, + bzip2, + bash, + unzip, + zip, }: let pname = "sublimetext3"; packageAttribute = "sublime3${lib.optionalString dev "-dev"}"; - binaries = [ "sublime_text" "plugin_host" "crash_reporter" ]; + binaries = [ + "sublime_text" + "plugin_host" + "crash_reporter" + ]; primaryBinary = "sublime_text"; - primaryBinaryAliases = [ "subl" "sublime" "sublime3" ]; + primaryBinaryAliases = [ + "subl" + "sublime" + "sublime3" + ]; downloadUrl = "https://download.sublimetext.com/sublime_text_3_build_${buildVersion}_${arch}.tar.bz2"; versionUrl = "https://download.sublimetext.com/latest/${if dev then "dev" else "stable"}"; versionFile = builtins.toString ./packages.nix; - archSha256 = - if stdenv.hostPlatform.system == "i686-linux" then - x32sha256 - else - x64sha256; - arch = - if stdenv.hostPlatform.system == "i686-linux" then - "x32" - else - "x64"; - - libPath = lib.makeLibraryPath [ xorg.libX11 glib gtk3 cairo pango ]; + archSha256 = if stdenv.hostPlatform.system == "i686-linux" then x32sha256 else x64sha256; + arch = if stdenv.hostPlatform.system == "i686-linux" then "x32" else "x64"; + + libPath = lib.makeLibraryPath [ + xorg.libX11 + glib + gtk3 + cairo + pango + ]; redirects = [ "/usr/bin/pkexec=${pkexecPath}" ]; binaryPackage = stdenv.mkDerivation { @@ -39,8 +66,16 @@ let dontStrip = true; dontPatchELF = true; - buildInputs = [ glib gtk3 ]; # for GSETTINGS_SCHEMAS_PATH - nativeBuildInputs = [ zip unzip makeWrapper wrapGAppsHook3 ]; + buildInputs = [ + glib + gtk3 + ]; # for GSETTINGS_SCHEMAS_PATH + nativeBuildInputs = [ + zip + unzip + makeWrapper + wrapGAppsHook3 + ]; # make exec.py in Default.sublime-package use own bash with an LD_PRELOAD instead of "/bin/bash" patchPhase = '' @@ -62,7 +97,7 @@ let buildPhase = '' runHook preBuild - for binary in ${ builtins.concatStringsSep " " binaries }; do + for binary in ${builtins.concatStringsSep " " binaries}; do patchelf \ --interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ --set-rpath ${libPath}:${lib.getLib stdenv.cc.cc}/lib${lib.optionalString stdenv.hostPlatform.is64bit "64"} \ @@ -104,7 +139,8 @@ let wrapProgram $out/plugin_host --prefix LD_PRELOAD : ${lib.getLib stdenv.cc.cc}/lib${lib.optionalString stdenv.hostPlatform.is64bit "64"}/libgcc_s.so.1:${lib.getLib openssl}/lib/libssl.so:${bzip2.out}/lib/libbz2.so ''; }; -in stdenv.mkDerivation (rec { +in +stdenv.mkDerivation (rec { inherit pname; version = buildVersion; @@ -114,25 +150,37 @@ in stdenv.mkDerivation (rec { nativeBuildInputs = [ makeWrapper ]; - installPhase = '' - mkdir -p "$out/bin" - makeWrapper "''$${primaryBinary}/${primaryBinary}" "$out/bin/${primaryBinary}" - '' + builtins.concatStringsSep "" (map (binaryAlias: "ln -s $out/bin/${primaryBinary} $out/bin/${binaryAlias}\n") primaryBinaryAliases) + '' - mkdir -p "$out/share/applications" - substitute "''$${primaryBinary}/${primaryBinary}.desktop" "$out/share/applications/${primaryBinary}.desktop" --replace "/opt/${primaryBinary}/${primaryBinary}" "$out/bin/${primaryBinary}" - for directory in ''$${primaryBinary}/Icon/*; do - size=$(basename $directory) - mkdir -p "$out/share/icons/hicolor/$size/apps" - ln -s ''$${primaryBinary}/Icon/$size/* $out/share/icons/hicolor/$size/apps - done - ''; + installPhase = + '' + mkdir -p "$out/bin" + makeWrapper "''$${primaryBinary}/${primaryBinary}" "$out/bin/${primaryBinary}" + '' + + builtins.concatStringsSep "" ( + map (binaryAlias: "ln -s $out/bin/${primaryBinary} $out/bin/${binaryAlias}\n") primaryBinaryAliases + ) + + '' + mkdir -p "$out/share/applications" + substitute "''$${primaryBinary}/${primaryBinary}.desktop" "$out/share/applications/${primaryBinary}.desktop" --replace "/opt/${primaryBinary}/${primaryBinary}" "$out/bin/${primaryBinary}" + for directory in ''$${primaryBinary}/Icon/*; do + size=$(basename $directory) + mkdir -p "$out/share/icons/hicolor/$size/apps" + ln -s ''$${primaryBinary}/Icon/$size/* $out/share/icons/hicolor/$size/apps + done + ''; meta = with lib; { description = "Sophisticated text editor for code, markup and prose"; homepage = "https://www.sublimetext.com/"; - maintainers = with maintainers; [ wmertens demin-dmitriy zimbatm ]; + maintainers = with maintainers; [ + wmertens + demin-dmitriy + zimbatm + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; }) diff --git a/pkgs/applications/editors/sublime/3/packages.nix b/pkgs/applications/editors/sublime/3/packages.nix index d72966e04401de..e511ba54103fc1 100644 --- a/pkgs/applications/editors/sublime/3/packages.nix +++ b/pkgs/applications/editors/sublime/3/packages.nix @@ -3,17 +3,17 @@ let common = opts: callPackage (import ./common.nix opts); in - { - sublime3-dev = common { - buildVersion = "3210"; - dev = true; - x32sha256 = "1ngr4c8h2mafy96mi8dd3g8mg5r9ha1cpcd8p3gz7jwpbypvkkbv"; - x64sha256 = "0j65a4ylgga1qzc74wf3k5craghahma8hwqg3zs1rgzz601nl693"; - } {}; +{ + sublime3-dev = common { + buildVersion = "3210"; + dev = true; + x32sha256 = "1ngr4c8h2mafy96mi8dd3g8mg5r9ha1cpcd8p3gz7jwpbypvkkbv"; + x64sha256 = "0j65a4ylgga1qzc74wf3k5craghahma8hwqg3zs1rgzz601nl693"; + } { }; - sublime3 = common { - buildVersion = "3211"; - x32sha256 = "0w9hba1nl2hv1mri418n7v0m321b6wqphb1knll23ldv5fb0j1j8"; - x64sha256 = "1vkldmimyjhbgplcd6r27gvk64rr7cparfd44hy6qdyzwsjqqg0b"; - } {}; - } + sublime3 = common { + buildVersion = "3211"; + x32sha256 = "0w9hba1nl2hv1mri418n7v0m321b6wqphb1knll23ldv5fb0j1j8"; + x64sha256 = "1vkldmimyjhbgplcd6r27gvk64rr7cparfd44hy6qdyzwsjqqg0b"; + } { }; +} diff --git a/pkgs/applications/editors/sublime/4/common.nix b/pkgs/applications/editors/sublime/4/common.nix index 8390a004b1f4a2..5eb44da324944d 100644 --- a/pkgs/applications/editors/sublime/4/common.nix +++ b/pkgs/applications/editors/sublime/4/common.nix @@ -48,19 +48,21 @@ let versionUrl = "https://download.sublimetext.com/latest/${if dev then "dev" else "stable"}"; versionFile = builtins.toString ./packages.nix; - neededLibraries = [ - xorg.libX11 - xorg.libXtst - glib - libglvnd - openssl_1_1 - gtk3 - cairo - pango - curl - ] ++ lib.optionals (lib.versionAtLeast buildVersion "4145") [ - sqlite - ]; + neededLibraries = + [ + xorg.libX11 + xorg.libXtst + glib + libglvnd + openssl_1_1 + gtk3 + cairo + pango + curl + ] + ++ lib.optionals (lib.versionAtLeast buildVersion "4145") [ + sqlite + ]; binaryPackage = stdenv.mkDerivation rec { pname = "${pnameBase}-bin"; diff --git a/pkgs/applications/editors/texmacs/common.nix b/pkgs/applications/editors/texmacs/common.nix index 06b7290c4baff6..bbf7e645494981 100644 --- a/pkgs/applications/editors/texmacs/common.nix +++ b/pkgs/applications/editors/texmacs/common.nix @@ -1,4 +1,12 @@ -{ lib, fetchurl, tex, extraFonts, chineseFonts, japaneseFonts, koreanFonts }: +{ + lib, + fetchurl, + tex, + extraFonts, + chineseFonts, + japaneseFonts, + koreanFonts, +}: rec { extraFontsSrc = fetchurl { url = "ftp://ftp.texmacs.org/pub/TeXmacs/fonts/TeXmacs-extra-fonts-1.0-noarch.tar.gz"; @@ -25,21 +33,26 @@ rec { sha256 = "07axg57mqm3jbnm4lawx0h3r2h56xv9acwzjppryfklw4c27f5hh"; }; - postPatch = (if tex == null then '' - gunzip < ${fullFontsSrc} | (cd TeXmacs && tar xvf -) - '' else lib.optionalString extraFonts '' - gunzip < ${extraFontsSrc} | (cd TeXmacs && tar xvf -) - '') + - (lib.optionalString chineseFonts '' - gunzip < ${chineseFontsSrc} | (cd TeXmacs && tar xvf -) - '') + - (lib.optionalString japaneseFonts '' - gunzip < ${japaneseFontsSrc} | (cd TeXmacs && tar xvf -) - '') + - (lib.optionalString koreanFonts '' - gunzip < ${koreanFontsSrc} | (cd TeXmacs && tar xvf -) - ''); - + postPatch = + ( + if tex == null then + '' + gunzip < ${fullFontsSrc} | (cd TeXmacs && tar xvf -) + '' + else + lib.optionalString extraFonts '' + gunzip < ${extraFontsSrc} | (cd TeXmacs && tar xvf -) + '' + ) + + (lib.optionalString chineseFonts '' + gunzip < ${chineseFontsSrc} | (cd TeXmacs && tar xvf -) + '') + + (lib.optionalString japaneseFonts '' + gunzip < ${japaneseFontsSrc} | (cd TeXmacs && tar xvf -) + '') + + (lib.optionalString koreanFonts '' + gunzip < ${koreanFontsSrc} | (cd TeXmacs && tar xvf -) + ''); meta = { description = "WYSIWYW editing platform with special features for scientists"; diff --git a/pkgs/applications/editors/texmacs/default.nix b/pkgs/applications/editors/texmacs/default.nix index 92d162cdc30030..329c0f5a889379 100644 --- a/pkgs/applications/editors/texmacs/default.nix +++ b/pkgs/applications/editors/texmacs/default.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, callPackage, fetchurl, - guile_1_8, xmodmap, which, freetype, +{ + lib, + stdenv, + callPackage, + fetchurl, + guile_1_8, + xmodmap, + which, + freetype, libjpeg, sqlite, texliveSmall ? null, @@ -17,13 +24,19 @@ extraFonts ? false, chineseFonts ? false, japaneseFonts ? false, - koreanFonts ? false }: + koreanFonts ? false, +}: let pname = "texmacs"; version = "2.1.4"; common = callPackage ./common.nix { - inherit extraFonts chineseFonts japaneseFonts koreanFonts; + inherit + extraFonts + chineseFonts + japaneseFonts + koreanFonts + ; tex = texliveSmall; }; in @@ -35,10 +48,12 @@ stdenv.mkDerivation { hash = "sha256-h6aSLuDdrAtVzOnNVPqMEWX9WLDHtkCjPy9JXWnBgYY="; }; - postPatch = common.postPatch + '' - substituteInPlace configure \ - --replace "-mfpmath=sse -msse2" "" - ''; + postPatch = + common.postPatch + + '' + substituteInPlace configure \ + --replace "-mfpmath=sse -msse2" "" + ''; nativeBuildInputs = [ guile_1_8 @@ -48,19 +63,21 @@ stdenv.mkDerivation { cmake ]; - buildInputs = [ - guile_1_8 - qtbase - qtsvg - ghostscriptX - freetype - libjpeg - sqlite - git - python3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - qtmacextras - ]; + buildInputs = + [ + guile_1_8 + qtbase + qtsvg + ghostscriptX + freetype + libjpeg + sqlite + git + python3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + qtmacextras + ]; cmakeFlags = lib.optionals stdenv.hostPlatform.isDarwin [ (lib.cmakeFeature "TEXMACS_GUI" "Qt") @@ -76,7 +93,10 @@ stdenv.mkDerivation { ''; qtWrapperArgs = [ - "--suffix" "PATH" ":" (lib.makeBinPath [ + "--suffix" + "PATH" + ":" + (lib.makeBinPath [ xmodmap which ghostscriptX diff --git a/pkgs/applications/editors/texmaker/default.nix b/pkgs/applications/editors/texmaker/default.nix index 57757746cba329..fada79bc0f8d94 100644 --- a/pkgs/applications/editors/texmaker/default.nix +++ b/pkgs/applications/editors/texmaker/default.nix @@ -10,7 +10,7 @@ qttools, qtwebengine, qt5compat, - zlib + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/editors/texstudio/default.nix b/pkgs/applications/editors/texstudio/default.nix index bdd8fab7a9a6fc..71569838c0c8a8 100644 --- a/pkgs/applications/editors/texstudio/default.nix +++ b/pkgs/applications/editors/texstudio/default.nix @@ -1,7 +1,20 @@ -{ stdenv, lib, fetchFromGitHub, cmake, qtbase, qttools, qtsvg, qt5compat, quazip -, qtwayland -, hunspell -, wrapQtAppsHook, poppler, zlib, pkg-config }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + qtbase, + qttools, + qtsvg, + qt5compat, + quazip, + qtwayland, + hunspell, + wrapQtAppsHook, + poppler, + zlib, + pkg-config, +}: stdenv.mkDerivation (finalAttrs: { pname = "texstudio"; @@ -19,18 +32,20 @@ stdenv.mkDerivation (finalAttrs: { wrapQtAppsHook pkg-config ]; - buildInputs = [ - hunspell - poppler - qt5compat - qtbase - qtsvg - qttools - quazip - zlib - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qtwayland - ]; + buildInputs = + [ + hunspell + poppler + qt5compat + qtbase + qtsvg + qttools + quazip + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qtwayland + ]; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' mkdir -p "$out/Applications" @@ -40,7 +55,7 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "TeX and LaTeX editor"; - longDescription='' + longDescription = '' Fork of TeXMaker, this editor is a full fledged IDE for LaTeX editing with completion, structure viewer, preview, spell checking and support of any compilation chain. @@ -49,7 +64,10 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://github.com/texstudio-org/texstudio/blob/${finalAttrs.version}/utilities/manual/source/CHANGELOG.md"; license = licenses.gpl2Plus; platforms = platforms.unix; - maintainers = with maintainers; [ ajs124 cfouche ]; + maintainers = with maintainers; [ + ajs124 + cfouche + ]; mainProgram = "texstudio"; }; }) diff --git a/pkgs/applications/editors/textadept/default.nix b/pkgs/applications/editors/textadept/default.nix index 936361c8440661..da5ffb192a3fc9 100644 --- a/pkgs/applications/editors/textadept/default.nix +++ b/pkgs/applications/editors/textadept/default.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl, cmake -, withQt ? true, qtbase, wrapQtAppsHook -, withCurses ? false, ncurses +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + cmake, + withQt ? true, + qtbase, + wrapQtAppsHook, + withCurses ? false, + ncurses, }: stdenv.mkDerivation rec { version = "12.4"; @@ -14,30 +22,37 @@ stdenv.mkDerivation rec { sha256 = "sha256-nPgpQeBq5Stv2o0Ke4W2Ltnx6qLe5TIC5a8HSYVkmfI="; }; - nativeBuildInputs = [ cmake ] - ++ lib.optionals withQt [ wrapQtAppsHook ]; + nativeBuildInputs = [ cmake ] ++ lib.optionals withQt [ wrapQtAppsHook ]; - buildInputs = - lib.optionals withQt [ qtbase ] - ++ lib.optionals withCurses ncurses; + buildInputs = lib.optionals withQt [ qtbase ] ++ lib.optionals withCurses ncurses; cmakeFlags = - lib.optional withQt [ "-DQT=ON" ] - ++ lib.optional withCurses [ "-DCURSES=ON" "-DQT=OFF"]; + lib.optional withQt [ "-DQT=ON" ] + ++ lib.optional withCurses [ + "-DCURSES=ON" + "-DQT=OFF" + ]; - preConfigure = '' - mkdir -p $PWD/build/_deps + preConfigure = + '' + mkdir -p $PWD/build/_deps - '' + - lib.concatStringsSep "\n" (lib.mapAttrsToList (name: params: - "ln -s ${fetchurl params} $PWD/build/_deps/${name}" - ) (import ./deps.nix)); + '' + + lib.concatStringsSep "\n" ( + lib.mapAttrsToList ( + name: params: "ln -s ${fetchurl params} $PWD/build/_deps/${name}" + ) (import ./deps.nix) + ); meta = with lib; { description = "Extensible text editor based on Scintilla with Lua scripting"; homepage = "http://foicica.com/textadept"; license = licenses.mit; - maintainers = with maintainers; [ raskin mirrexagon arcuru ]; + maintainers = with maintainers; [ + raskin + mirrexagon + arcuru + ]; platforms = platforms.linux; mainProgram = "textadept"; }; diff --git a/pkgs/applications/editors/textadept/deps.nix b/pkgs/applications/editors/textadept/deps.nix index f2322fd8a01312..0018eb15849a92 100644 --- a/pkgs/applications/editors/textadept/deps.nix +++ b/pkgs/applications/editors/textadept/deps.nix @@ -55,5 +55,3 @@ sha256 = "sha256-FwyzM+R9ALpGH9u2RXab4Sqi4Q+p3Qs+8EdfhjPGcXY="; }; } - - diff --git a/pkgs/applications/editors/texworks/default.nix b/pkgs/applications/editors/texworks/default.nix index a20bc426b3ca2e..31c719ba3f2f44 100644 --- a/pkgs/applications/editors/texworks/default.nix +++ b/pkgs/applications/editors/texworks/default.nix @@ -1,16 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, wrapQtAppsHook -, hunspell -, poppler -, qt5compat -, qttools -, qtwayland -, withLua ? true, lua -, withPython ? true, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + wrapQtAppsHook, + hunspell, + poppler, + qt5compat, + qttools, + qtwayland, + withLua ? true, + lua, + withPython ? true, + python3, +}: stdenv.mkDerivation rec { pname = "texworks"; @@ -29,18 +33,22 @@ stdenv.mkDerivation rec { wrapQtAppsHook ]; - buildInputs = [ - hunspell - poppler - qt5compat - qttools - ] ++ lib.optional withLua lua + buildInputs = + [ + hunspell + poppler + qt5compat + qttools + ] + ++ lib.optional withLua lua ++ lib.optional withPython python3 ++ lib.optional stdenv.hostPlatform.isLinux qtwayland; - cmakeFlags = [ - "-DQT_DEFAULT_MAJOR_VERSION=6" - ] ++ lib.optional withLua "-DWITH_LUA=ON" + cmakeFlags = + [ + "-DQT_DEFAULT_MAJOR_VERSION=6" + ] + ++ lib.optional withLua "-DWITH_LUA=ON" ++ lib.optional withPython "-DWITH_PYTHON=ON"; meta = with lib; { diff --git a/pkgs/applications/editors/tiled/default.nix b/pkgs/applications/editors/tiled/default.nix index dac1dbe0d0f71a..a8c7a18a4aae33 100644 --- a/pkgs/applications/editors/tiled/default.nix +++ b/pkgs/applications/editors/tiled/default.nix @@ -1,22 +1,29 @@ -{ lib -, stdenv -, env -, fetchFromGitHub -, pkg-config -, qbs -, wrapQtAppsHook -, qtbase -, qtdeclarative -, qttools -, qtwayland -, qtsvg -, zlib -, zstd -, libGL +{ + lib, + stdenv, + env, + fetchFromGitHub, + pkg-config, + qbs, + wrapQtAppsHook, + qtbase, + qtdeclarative, + qttools, + qtwayland, + qtsvg, + zlib, + zstd, + libGL, }: let - qtEnv = env "tiled-qt-env" [ qtbase qtdeclarative qtsvg qttools qtwayland ]; + qtEnv = env "tiled-qt-env" [ + qtbase + qtdeclarative + qtsvg + qttools + qtwayland + ]; in stdenv.mkDerivation rec { @@ -30,10 +37,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-cFS1OSYfGMsnw+VkZD/HO4+D+pxNKuifWjNhy0FoxN0="; }; - nativeBuildInputs = [ pkg-config qbs wrapQtAppsHook ]; - buildInputs = [ qtEnv zlib zstd libGL ]; - - outputs = [ "out" "dev" ]; + nativeBuildInputs = [ + pkg-config + qbs + wrapQtAppsHook + ]; + buildInputs = [ + qtEnv + zlib + zstd + libGL + ]; + + outputs = [ + "out" + "dev" + ]; strictDeps = true; @@ -67,10 +86,13 @@ stdenv.mkDerivation rec { description = "Free, easy to use and flexible tile map editor"; homepage = "https://www.mapeditor.org/"; license = with licenses; [ - bsd2 # libtiled and tmxviewer - gpl2Plus # all the rest + bsd2 # libtiled and tmxviewer + gpl2Plus # all the rest + ]; + maintainers = with maintainers; [ + dywedir + ryan4yin ]; - maintainers = with maintainers; [ dywedir ryan4yin ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/editors/vim/common.nix b/pkgs/applications/editors/vim/common.nix index afe60212baf77b..4dbf706a0a67e5 100644 --- a/pkgs/applications/editors/vim/common.nix +++ b/pkgs/applications/editors/vim/common.nix @@ -2,7 +2,10 @@ rec { version = "9.1.0787"; - outputs = [ "out" "xxd" ]; + outputs = [ + "out" + "xxd" + ]; src = fetchFromGitHub { owner = "vim"; @@ -34,11 +37,18 @@ rec { meta = with lib; { description = "Most popular clone of the VI editor"; - homepage = "http://www.vim.org"; - license = licenses.vim; - maintainers = with maintainers; [ das_j equirosa philiptaron ]; - platforms = platforms.unix; + homepage = "http://www.vim.org"; + license = licenses.vim; + maintainers = with maintainers; [ + das_j + equirosa + philiptaron + ]; + platforms = platforms.unix; mainProgram = "vim"; - outputsToInstall = [ "out" "xxd" ]; + outputsToInstall = [ + "out" + "xxd" + ]; }; } diff --git a/pkgs/applications/editors/vim/default.nix b/pkgs/applications/editors/vim/default.nix index b9c5f4ff7bbcc1..837e0b9085a07e 100644 --- a/pkgs/applications/editors/vim/default.nix +++ b/pkgs/applications/editors/vim/default.nix @@ -1,47 +1,84 @@ -{ lib, stdenv, fetchurl, callPackage, ncurses, bash, gawk, gettext, pkg-config -# default vimrc -, vimrc ? fetchurl { +{ + lib, + stdenv, + fetchurl, + callPackage, + ncurses, + bash, + gawk, + gettext, + pkg-config, + # default vimrc + vimrc ? fetchurl { name = "default-vimrc"; url = "https://raw.githubusercontent.com/archlinux/svntogit-packages/68f6d131750aa778807119e03eed70286a17b1cb/trunk/archlinux.vim"; sha256 = "18ifhv5q9prd175q3vxbqf6qyvkk6bc7d2lhqdk0q78i68kv9y0c"; - } -# apple frameworks -, Carbon, Cocoa + }, + # apple frameworks + Carbon, + Cocoa, }: let - common = callPackage ./common.nix {}; + common = callPackage ./common.nix { }; in stdenv.mkDerivation { pname = "vim"; - inherit (common) version outputs src postPatch hardeningDisable enableParallelBuilding enableParallelInstalling postFixup meta; + inherit (common) + version + outputs + src + postPatch + hardeningDisable + enableParallelBuilding + enableParallelInstalling + postFixup + meta + ; - nativeBuildInputs = [ gettext pkg-config ]; - buildInputs = [ ncurses bash gawk ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Carbon Cocoa ]; + nativeBuildInputs = [ + gettext + pkg-config + ]; + buildInputs = + [ + ncurses + bash + gawk + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + Cocoa + ]; strictDeps = true; - configureFlags = [ - "--enable-multibyte" - "--enable-nls" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) ([ - "vim_cv_toupper_broken=no" - "--with-tlib=ncurses" - "vim_cv_terminfo=yes" - "vim_cv_tgetent=zero" # it does on native anyway - "vim_cv_tty_group=tty" - "vim_cv_tty_mode=0660" - "vim_cv_getcwd_broken=no" - "vim_cv_stat_ignores_slash=yes" - "vim_cv_memmove_handles_overlap=yes" - ] ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ - "vim_cv_timer_create=no" - "vim_cv_timer_create_with_lrt=yes" - ] ++ lib.optionals (!stdenv.hostPlatform.isFreeBSD) [ - "vim_cv_timer_create=yes" - ]); + configureFlags = + [ + "--enable-multibyte" + "--enable-nls" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) ( + [ + "vim_cv_toupper_broken=no" + "--with-tlib=ncurses" + "vim_cv_terminfo=yes" + "vim_cv_tgetent=zero" # it does on native anyway + "vim_cv_tty_group=tty" + "vim_cv_tty_mode=0660" + "vim_cv_getcwd_broken=no" + "vim_cv_stat_ignores_slash=yes" + "vim_cv_memmove_handles_overlap=yes" + ] + ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ + "vim_cv_timer_create=no" + "vim_cv_timer_create_with_lrt=yes" + ] + ++ lib.optionals (!stdenv.hostPlatform.isFreeBSD) [ + "vim_cv_timer_create=yes" + ] + ); # which.sh is used to for vim's own shebang patching, so make it find # binaries for the host platform. diff --git a/pkgs/applications/editors/vim/full.nix b/pkgs/applications/editors/vim/full.nix index 5183ee5d39f20d..34aa8e84721a45 100644 --- a/pkgs/applications/editors/vim/full.nix +++ b/pkgs/applications/editors/vim/full.nix @@ -1,33 +1,60 @@ -{ source ? "default", callPackage, lib, stdenv, ncurses, pkg-config, gettext -, writeText, config, glib, gtk2-x11, gtk3-x11, lua, python3, perl, tcl, ruby -, libX11, libXext, libSM, libXpm, libXt, libXaw, libXau, libXmu, libsodium -, libICE -, vimPlugins -, makeWrapper -, wrapGAppsHook3 - -# apple frameworks -, CoreServices, CoreData, Cocoa, Foundation, libobjc - -, features ? "huge" # One of tiny, small, normal, big or huge -, wrapPythonDrv ? false -, guiSupport ? config.vim.gui or (if stdenv.hostPlatform.isDarwin then "gtk2" else "gtk3") -, luaSupport ? config.vim.lua or true -, perlSupport ? config.vim.perl or false # Perl interpreter -, pythonSupport ? config.vim.python or true # Python interpreter -, rubySupport ? config.vim.ruby or true # Ruby interpreter -, nlsSupport ? config.vim.nls or false # Enable NLS (gettext()) -, tclSupport ? config.vim.tcl or false # Include Tcl interpreter -, multibyteSupport ? config.vim.multibyte or false # Enable multibyte editing support -, cscopeSupport ? config.vim.cscope or true # Enable cscope interface -, netbeansSupport ? config.netbeans or true # Enable NetBeans integration support. -, ximSupport ? config.vim.xim or true # less than 15KB, needed for deadkeys -, darwinSupport ? config.vim.darwin or false # Enable Darwin support -, ftNixSupport ? config.vim.ftNix or true # Add nix indentation support from vim-nix (not needed for basic syntax highlighting) -, sodiumSupport ? config.vim.sodium or true # Enable sodium based encryption +{ + source ? "default", + callPackage, + lib, + stdenv, + ncurses, + pkg-config, + gettext, + writeText, + config, + glib, + gtk2-x11, + gtk3-x11, + lua, + python3, + perl, + tcl, + ruby, + libX11, + libXext, + libSM, + libXpm, + libXt, + libXaw, + libXau, + libXmu, + libsodium, + libICE, + vimPlugins, + makeWrapper, + wrapGAppsHook3, + + # apple frameworks + CoreServices, + CoreData, + Cocoa, + Foundation, + libobjc, + + features ? "huge", # One of tiny, small, normal, big or huge + wrapPythonDrv ? false, + guiSupport ? config.vim.gui or (if stdenv.hostPlatform.isDarwin then "gtk2" else "gtk3"), + luaSupport ? config.vim.lua or true, + perlSupport ? config.vim.perl or false, # Perl interpreter + pythonSupport ? config.vim.python or true, # Python interpreter + rubySupport ? config.vim.ruby or true, # Ruby interpreter + nlsSupport ? config.vim.nls or false, # Enable NLS (gettext()) + tclSupport ? config.vim.tcl or false, # Include Tcl interpreter + multibyteSupport ? config.vim.multibyte or false, # Enable multibyte editing support + cscopeSupport ? config.vim.cscope or true, # Enable cscope interface + netbeansSupport ? config.netbeans or true, # Enable NetBeans integration support. + ximSupport ? config.vim.xim or true, # less than 15KB, needed for deadkeys + darwinSupport ? config.vim.darwin or false, # Enable Darwin support + ftNixSupport ? config.vim.ftNix or true, # Add nix indentation support from vim-nix (not needed for basic syntax highlighting) + sodiumSupport ? config.vim.sodium or true, # Enable sodium based encryption }: - let nixosRuntimepath = writeText "nixos-vimrc" '' set nocompatible @@ -59,13 +86,21 @@ let endif ''; - common = callPackage ./common.nix {}; + common = callPackage ./common.nix { }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "vim-full"; - inherit (common) version outputs postPatch hardeningDisable enableParallelBuilding meta; + inherit (common) + version + outputs + postPatch + hardeningDisable + enableParallelBuilding + meta + ; src = builtins.getAttr source { default = common.src; # latest release @@ -73,74 +108,79 @@ in stdenv.mkDerivation { patches = [ ./cflags-prune.diff ]; - configureFlags = [ - "--with-features=${features}" - "--disable-xsmp" # XSMP session management - "--disable-xsmp_interact" # XSMP interaction - "--disable-workshop" # Sun Visual Workshop support - "--disable-sniff" # Sniff interface - "--disable-hangulinput" # Hangul input support - "--disable-fontset" # X fontset output support - "--disable-acl" # ACL support - "--disable-gpm" # GPM (Linux mouse daemon) - "--disable-mzschemeinterp" - "--disable-gtk_check" - "--disable-gtk2_check" - "--disable-gnome_check" - "--disable-motif_check" - "--disable-athena_check" - "--disable-nextaf_check" - "--disable-carbon_check" - "--disable-gtktest" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "vim_cv_toupper_broken=no" - "--with-tlib=ncurses" - "vim_cv_terminfo=yes" - "vim_cv_tgetent=zero" # it does on native anyway - "vim_cv_tty_group=tty" - "vim_cv_tty_mode=0660" - "vim_cv_getcwd_broken=no" - "vim_cv_stat_ignores_slash=yes" - "vim_cv_memmove_handles_overlap=yes" - ] + configureFlags = + [ + "--with-features=${features}" + "--disable-xsmp" # XSMP session management + "--disable-xsmp_interact" # XSMP interaction + "--disable-workshop" # Sun Visual Workshop support + "--disable-sniff" # Sniff interface + "--disable-hangulinput" # Hangul input support + "--disable-fontset" # X fontset output support + "--disable-acl" # ACL support + "--disable-gpm" # GPM (Linux mouse daemon) + "--disable-mzschemeinterp" + "--disable-gtk_check" + "--disable-gtk2_check" + "--disable-gnome_check" + "--disable-motif_check" + "--disable-athena_check" + "--disable-nextaf_check" + "--disable-carbon_check" + "--disable-gtktest" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "vim_cv_toupper_broken=no" + "--with-tlib=ncurses" + "vim_cv_terminfo=yes" + "vim_cv_tgetent=zero" # it does on native anyway + "vim_cv_tty_group=tty" + "vim_cv_tty_mode=0660" + "vim_cv_getcwd_broken=no" + "vim_cv_stat_ignores_slash=yes" + "vim_cv_memmove_handles_overlap=yes" + ] ++ lib.optional (guiSupport == "gtk2" || guiSupport == "gtk3") "--enable-gui=${guiSupport}" - ++ lib.optional stdenv.hostPlatform.isDarwin - (if darwinSupport then "--enable-darwin" else "--disable-darwin") - ++ lib.optionals luaSupport [ - "--with-lua-prefix=${lua}" - "--enable-luainterp" - ] ++ lib.optionals lua.pkgs.isLuaJIT [ - "--with-luajit" - ] - ++ lib.optionals pythonSupport [ - "--enable-python3interp=yes" - "--with-python3-config-dir=${python3}/lib" - # Disables Python 2 - "--disable-pythoninterp" - ] - ++ lib.optional nlsSupport "--enable-nls" - ++ lib.optional perlSupport "--enable-perlinterp" - ++ lib.optional rubySupport "--enable-rubyinterp" - ++ lib.optional tclSupport "--enable-tclinterp" - ++ lib.optional multibyteSupport "--enable-multibyte" - ++ lib.optional cscopeSupport "--enable-cscope" - ++ lib.optional netbeansSupport "--enable-netbeans" - ++ lib.optional ximSupport "--enable-xim" - ++ lib.optional sodiumSupport "--enable-sodium"; - - nativeBuildInputs = [ - pkg-config - ] - ++ lib.optional wrapPythonDrv makeWrapper - ++ lib.optional nlsSupport gettext - ++ lib.optional perlSupport perl - ++ lib.optional (guiSupport == "gtk3") wrapGAppsHook3 - ; - - buildInputs = [ - ncurses - glib - ] + ++ lib.optional stdenv.hostPlatform.isDarwin ( + if darwinSupport then "--enable-darwin" else "--disable-darwin" + ) + ++ lib.optionals luaSupport [ + "--with-lua-prefix=${lua}" + "--enable-luainterp" + ] + ++ lib.optionals lua.pkgs.isLuaJIT [ + "--with-luajit" + ] + ++ lib.optionals pythonSupport [ + "--enable-python3interp=yes" + "--with-python3-config-dir=${python3}/lib" + # Disables Python 2 + "--disable-pythoninterp" + ] + ++ lib.optional nlsSupport "--enable-nls" + ++ lib.optional perlSupport "--enable-perlinterp" + ++ lib.optional rubySupport "--enable-rubyinterp" + ++ lib.optional tclSupport "--enable-tclinterp" + ++ lib.optional multibyteSupport "--enable-multibyte" + ++ lib.optional cscopeSupport "--enable-cscope" + ++ lib.optional netbeansSupport "--enable-netbeans" + ++ lib.optional ximSupport "--enable-xim" + ++ lib.optional sodiumSupport "--enable-sodium"; + + nativeBuildInputs = + [ + pkg-config + ] + ++ lib.optional wrapPythonDrv makeWrapper + ++ lib.optional nlsSupport gettext + ++ lib.optional perlSupport perl + ++ lib.optional (guiSupport == "gtk3") wrapGAppsHook3; + + buildInputs = + [ + ncurses + glib + ] # All X related dependencies ++ lib.optionals (guiSupport == "gtk2" || guiSupport == "gtk3") [ libSM @@ -155,7 +195,13 @@ in stdenv.mkDerivation { ] ++ lib.optional (guiSupport == "gtk2") gtk2-x11 ++ lib.optional (guiSupport == "gtk3") gtk3-x11 - ++ lib.optionals darwinSupport [ CoreServices CoreData Cocoa Foundation libobjc ] + ++ lib.optionals darwinSupport [ + CoreServices + CoreData + Cocoa + Foundation + libobjc + ] ++ lib.optional luaSupport lua ++ lib.optional pythonSupport python3 ++ lib.optional tclSupport tcl @@ -166,24 +212,28 @@ in stdenv.mkDerivation { env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-fdeclspec"; preConfigure = lib.optionalString ftNixSupport '' - cp ${vimPlugins.vim-nix.src}/ftplugin/nix.vim runtime/ftplugin/nix.vim - cp ${vimPlugins.vim-nix.src}/indent/nix.vim runtime/indent/nix.vim - ''; + cp ${vimPlugins.vim-nix.src}/ftplugin/nix.vim runtime/ftplugin/nix.vim + cp ${vimPlugins.vim-nix.src}/indent/nix.vim runtime/indent/nix.vim + ''; preInstall = '' mkdir -p $out/share/applications $out/share/icons/{hicolor,locolor}/{16x16,32x32,48x48}/apps ''; - postInstall = '' - ln -s $out/bin/vim $out/bin/vi - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - ln -sfn '${nixosRuntimepath}' "$out"/share/vim/vimrc - ''; + postInstall = + '' + ln -s $out/bin/vim $out/bin/vi + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + ln -sfn '${nixosRuntimepath}' "$out"/share/vim/vimrc + ''; - postFixup = common.postFixup + lib.optionalString wrapPythonDrv '' - wrapProgram "$out/bin/vim" --prefix PATH : "${python3}/bin" \ - --set NIX_PYTHONPATH "${python3}/${python3.sitePackages}" - ''; + postFixup = + common.postFixup + + lib.optionalString wrapPythonDrv '' + wrapProgram "$out/bin/vim" --prefix PATH : "${python3}/bin" \ + --set NIX_PYTHONPATH "${python3}/${python3.sitePackages}" + ''; dontStrip = true; } diff --git a/pkgs/applications/editors/vim/macvim-configurable.nix b/pkgs/applications/editors/vim/macvim-configurable.nix index cca5d06ba90ad6..36253f918a5c23 100644 --- a/pkgs/applications/editors/vim/macvim-configurable.nix +++ b/pkgs/applications/editors/vim/macvim-configurable.nix @@ -1,63 +1,81 @@ -{ lib, stdenv, callPackage, vimUtils, buildEnv, makeWrapper }: +{ + lib, + stdenv, + callPackage, + vimUtils, + buildEnv, + makeWrapper, +}: let - makeCustomizable = macvim: macvim // { - # configure expects the same args as vimUtils.vimrcFile. - # This is the same as the value given to neovim.override { configure = … } - # or the value of vim-full.customize { vimrcConfig = … } - # - # Note: Like neovim and vim-full, configuring macvim disables the - # sourcing of the user's vimrc. Use `customRC = "source $HOME/.vim/vimrc"` - # if you want to preserve that behavior. - configure = let - doConfig = config: let - vimrcConfig = config // { - # always source the bundled system vimrc - beforePlugins = '' - source $VIM/vimrc - ${config.beforePlugins or ""} - ''; - }; - in buildEnv { - name = macvim.name; - paths = [ macvim ]; - pathsToLink = [ - "/" - "/bin" - "/Applications/MacVim.app/Contents/MacOS" - "/Applications/MacVim.app/Contents/bin" - ]; - nativeBuildInputs = [ makeWrapper ]; - # We need to do surgery on the resulting app. We can't just make a wrapper for vim because this - # is a GUI app. We need to copy the actual GUI executable image as AppKit uses the loaded image's - # path to locate the bundle. We can use symlinks for other executables and resources though. - postBuild = '' - # Replace the Contents/MacOS/MacVim symlink with the original file - target=$(readlink $out/Applications/MacVim.app/Contents/MacOS/MacVim) - rm $out/Applications/MacVim.app/Contents/MacOS/MacVim - cp -a -t $out/Applications/MacVim.app/Contents/MacOS "$target" + makeCustomizable = + macvim: + macvim + // { + # configure expects the same args as vimUtils.vimrcFile. + # This is the same as the value given to neovim.override { configure = … } + # or the value of vim-full.customize { vimrcConfig = … } + # + # Note: Like neovim and vim-full, configuring macvim disables the + # sourcing of the user's vimrc. Use `customRC = "source $HOME/.vim/vimrc"` + # if you want to preserve that behavior. + configure = + let + doConfig = + config: + let + vimrcConfig = config // { + # always source the bundled system vimrc + beforePlugins = '' + source $VIM/vimrc + ${config.beforePlugins or ""} + ''; + }; + in + buildEnv { + name = macvim.name; + paths = [ macvim ]; + pathsToLink = [ + "/" + "/bin" + "/Applications/MacVim.app/Contents/MacOS" + "/Applications/MacVim.app/Contents/bin" + ]; + nativeBuildInputs = [ makeWrapper ]; + # We need to do surgery on the resulting app. We can't just make a wrapper for vim because this + # is a GUI app. We need to copy the actual GUI executable image as AppKit uses the loaded image's + # path to locate the bundle. We can use symlinks for other executables and resources though. + postBuild = '' + # Replace the Contents/MacOS/MacVim symlink with the original file + target=$(readlink $out/Applications/MacVim.app/Contents/MacOS/MacVim) + rm $out/Applications/MacVim.app/Contents/MacOS/MacVim + cp -a -t $out/Applications/MacVim.app/Contents/MacOS "$target" - # Wrap the Vim binary for our vimrc - wrapProgram $out/Applications/MacVim.app/Contents/MacOS/Vim \ - --add-flags "-u ${vimUtils.vimrcFile vimrcConfig}" + # Wrap the Vim binary for our vimrc + wrapProgram $out/Applications/MacVim.app/Contents/MacOS/Vim \ + --add-flags "-u ${vimUtils.vimrcFile vimrcConfig}" - # Replace each symlink in bin/ with the original. Most of them point at other symlinks - # and we need those original symlinks to point into our new app bundle. - for prefix in bin Applications/MacVim.app/Contents/bin; do - for link in $out/$prefix/*; do - target=$(readlink "$link") - # don't copy binaries like vimtutor, but we do need mvim - [ -L "$target" ] || [ "$(basename "$target")" = mvim ] || continue; - rm "$link" - cp -a -t $out/$prefix "$target" - done - done - ''; - meta = macvim.meta; - }; - in lib.makeOverridable (lib.setFunctionArgs doConfig (lib.functionArgs vimUtils.vimrcFile)); + # Replace each symlink in bin/ with the original. Most of them point at other symlinks + # and we need those original symlinks to point into our new app bundle. + for prefix in bin Applications/MacVim.app/Contents/bin; do + for link in $out/$prefix/*; do + target=$(readlink "$link") + # don't copy binaries like vimtutor, but we do need mvim + [ -L "$target" ] || [ "$(basename "$target")" = mvim ] || continue; + rm "$link" + cp -a -t $out/$prefix "$target" + done + done + ''; + meta = macvim.meta; + }; + in + lib.makeOverridable (lib.setFunctionArgs doConfig (lib.functionArgs vimUtils.vimrcFile)); - override = f: makeCustomizable (macvim.override f); - overrideAttrs = f: makeCustomizable (macvim.overrideAttrs f); - }; -in { inherit makeCustomizable; } + override = f: makeCustomizable (macvim.override f); + overrideAttrs = f: makeCustomizable (macvim.overrideAttrs f); + }; +in +{ + inherit makeCustomizable; +} diff --git a/pkgs/applications/editors/vim/macvim.nix b/pkgs/applications/editors/vim/macvim.nix index 23aa24ff9b6d78..3d401f553f35d0 100644 --- a/pkgs/applications/editors/vim/macvim.nix +++ b/pkgs/applications/editors/vim/macvim.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, runCommand -, ncurses -, gettext -, pkg-config -, cscope -, ruby_3_2 -, tcl -, perl540 -, luajit -, darwin -, libiconv -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + runCommand, + ncurses, + gettext, + pkg-config, + cscope, + ruby_3_2, + tcl, + perl540, + luajit, + darwin, + libiconv, + python3, }: # Try to match MacVim's documented script interface compatibility @@ -25,7 +26,7 @@ let # Some of these we could patch into the relevant source files (such as xcodebuild and # qlmanage) but some are used by Xcode itself and we have no choice but to put them in PATH. # Symlinking them in this way is better than just putting all of /usr/bin in there. - buildSymlinks = runCommand "macvim-build-symlinks" {} '' + buildSymlinks = runCommand "macvim-build-symlinks" { } '' mkdir -p $out/bin ln -s /usr/bin/xcrun /usr/bin/xcodebuild /usr/bin/tiffutil /usr/bin/qlmanage $out/bin ''; @@ -45,9 +46,19 @@ stdenv.mkDerivation (finalAttrs: { enableParallelBuilding = true; - nativeBuildInputs = [ pkg-config buildSymlinks ]; + nativeBuildInputs = [ + pkg-config + buildSymlinks + ]; buildInputs = [ - gettext ncurses cscope luajit ruby tcl perl python3 + gettext + ncurses + cscope + luajit + ruby + tcl + perl + python3 ]; patches = [ ./macvim.patch ]; @@ -123,8 +134,7 @@ stdenv.mkDerivation (finalAttrs: { XCODEFLAGS="-scheme MacVim -derivedDataPath $NIX_BUILD_TOP/derivedData" --with-xcodecfg="Release" ) - '' - ; + ''; # Because we're building with system clang, this means we're building against Xcode's SDK and # linking against system libraries. The configure script is picking up Nix Libsystem (via ruby) @@ -205,6 +215,6 @@ stdenv.mkDerivation (finalAttrs: { license = licenses.vim; maintainers = [ ]; platforms = platforms.darwin; - hydraPlatforms = []; # hydra can't build this as long as we rely on Xcode and sandboxProfile + hydraPlatforms = [ ]; # hydra can't build this as long as we rely on Xcode and sandboxProfile }; }) diff --git a/pkgs/applications/editors/vim/plugins/aliases.nix b/pkgs/applications/editors/vim/plugins/aliases.nix index 299faf7222c733..a69af50ef77e47 100644 --- a/pkgs/applications/editors/vim/plugins/aliases.nix +++ b/pkgs/applications/editors/vim/plugins/aliases.nix @@ -6,148 +6,150 @@ final: prev: let # Removing recurseForDerivation prevents derivations of aliased attribute # set to appear while listing all the packages available. - removeRecurseForDerivations = alias: + removeRecurseForDerivations = + alias: if alias.recurseForDerivations or false then - lib.removeAttrs alias ["recurseForDerivations"] - else alias; + lib.removeAttrs alias [ "recurseForDerivations" ] + else + alias; # Disabling distribution prevents top-level aliases for non-recursed package # sets from building on Hydra. - removeDistribute = alias: - if lib.isDerivation alias then - lib.dontDistribute alias - else alias; + removeDistribute = alias: if lib.isDerivation alias then lib.dontDistribute alias else alias; # Make sure that we are not shadowing something from # all-packages.nix. - checkInPkgs = n: alias: if builtins.hasAttr n prev - then throw "Alias ${n} is still in vim-plugins" - else alias; + checkInPkgs = + n: alias: if builtins.hasAttr n prev then throw "Alias ${n} is still in vim-plugins" else alias; - mapAliases = aliases: - lib.mapAttrs (n: alias: removeDistribute - (removeRecurseForDerivations - (checkInPkgs n alias))) - aliases; + mapAliases = + aliases: + lib.mapAttrs ( + n: alias: removeDistribute (removeRecurseForDerivations (checkInPkgs n alias)) + ) aliases; - deprecations = lib.mapAttrs (old: info: - throw "${old} was renamed to ${info.new} on ${info.date}. Please update to ${info.new}." + deprecations = lib.mapAttrs ( + old: info: throw "${old} was renamed to ${info.new} on ${info.date}. Please update to ${info.new}." ) (lib.importJSON ./deprecated.json); in -mapAliases (with prev; { - airline = vim-airline; - alternative = a-vim; # backwards compat, added 2014-10-21 - bats = bats-vim; - BufOnly = BufOnly-vim; - calendar = calendar-vim; - coffee-script = vim-coffee-script; - coffeeScript = vim-coffee-script; # backwards compat, added 2014-10-18 - Solarized = vim-colors-solarized; - solarized = vim-colors-solarized; - spacevim = throw "this distribution was unmaintained for the last 6 years, please use top-level 'spacevim'"; # added 2024-11-27 - SpaceVim = throw "this distribution didn't work properly in vimPlugins, please use top-level 'spacevim' instead"; # added 2024-11-27 - colors-solarized = vim-colors-solarized; - caw = caw-vim; - chad = chadtree; - colorsamplerpack = Colour-Sampler-Pack; - Colour_Sampler_Pack = Colour-Sampler-Pack; - command_T = command-t; # backwards compat, added 2014-10-18 - commentary = vim-commentary; - committia = committia-vim; - concealedyank = concealedyank-vim; - context-filetype = context_filetype-vim; - Cosco = cosco-vim; - css_color_5056 = vim-css-color; - CSApprox = csapprox; - csv = csv-vim; - ctrlp = ctrlp-vim; - cute-python = vim-cute-python; - denite = denite-nvim; - easy-align = vim-easy-align; - easygit = vim-easygit; - easymotion = vim-easymotion; - echodoc = echodoc-vim; - eighties = vim-eighties; - extradite = vim-extradite; - fugitive = vim-fugitive; - floating-nvim = throw "floating.nvim has been removed: abandoned by upstream. Use popup-nvim or nui-nvim"; # Added 2024-11-26 - ghc-mod-vim = ghcmod-vim; - ghcmod = ghcmod-vim; - goyo = goyo-vim; - Gist = vim-gist; - gitgutter = vim-gitgutter; - gundo = gundo-vim; - Gundo = gundo-vim; # backwards compat, added 2015-10-03 - haskellConceal = vim-haskellconceal; # backwards compat, added 2014-10-18 - haskellConcealPlus = vim-haskellConcealPlus; - haskellconceal = vim-haskellconceal; - hier = vim-hier; - hlint-refactor = hlint-refactor-vim; - hoogle = vim-hoogle; - Hoogle = vim-hoogle; - indent-blankline-nvim-lua = indent-blankline-nvim; # backwards compat, added 2021-07-05 - ipython = vim-ipython; - latex-live-preview = vim-latex-live-preview; - maktaba = vim-maktaba; - multiple-cursors = vim-multiple-cursors; - necoGhc = neco-ghc; # backwards compat, added 2014-10-18 - neocomplete = neocomplete-vim; - neoinclude = neoinclude-vim; - neomru = neomru-vim; - neosnippet = neosnippet-vim; - nvim-ts-rainbow = throw "nvim-ts-rainbow has been deprecated: Use rainbow-delimiters-nvim"; # Added 2023-11-30 - nvim-ts-rainbow2 = throw "nvim-ts-rainbow2 has been deprecated: Use rainbow-delimiters-nvim"; # Added 2023-11-30 - The_NERD_Commenter = nerdcommenter; - The_NERD_tree = nerdtree; - open-browser = open-browser-vim; - pathogen = vim-pathogen; - peskcolor-vim = throw "peskcolor-vim has been removed: abandoned by upstream"; # Added 2024-08-23 - polyglot = vim-polyglot; - prettyprint = vim-prettyprint; - quickrun = vim-quickrun; - rainbow_parentheses = rainbow_parentheses-vim; - repeat = vim-repeat; - riv = riv-vim; - rhubarb = vim-rhubarb; - sensible = vim-sensible; - signature = vim-signature; - snipmate = vim-snipmate; - sourcemap = sourcemap-vim; - "sourcemap.vim" = sourcemap-vim; - surround = vim-surround; - sleuth = vim-sleuth; - solidity = vim-solidity; - stylish-haskell = vim-stylish-haskell; - stylishHaskell = vim-stylish-haskell; # backwards compat, added 2014-10-18 - suda-vim = vim-suda; # backwards compat, added 2024-05-16 - Supertab = supertab; - Syntastic = syntastic; - SyntaxRange = vim-SyntaxRange; - table-mode = vim-table-mode; - taglist = taglist-vim; - tabpagebuffer = tabpagebuffer-vim; - tabpagecd = vim-tabpagecd; - Tabular = tabular; - Tagbar = tagbar; - thumbnail = thumbnail-vim; - tlib = tlib_vim; - tmux-navigator = vim-tmux-navigator; - tmuxNavigator = vim-tmux-navigator; # backwards compat, added 2014-10-18 - todo-nvim = throw "todo-nvim has been removed: abandoned by upstream"; # Added 2023-08-23 - tslime = tslime-vim; - unite = unite-vim; - UltiSnips = ultisnips; - vim-addon-vim2nix = vim2nix; - vim-sourcetrail = throw "vim-sourcetrail has been removed: abandoned by upstream"; # Added 2022-08-14 - vimproc = vimproc-vim; - vimshell = vimshell-vim; - vinegar = vim-vinegar; - watchdogs = vim-watchdogs; - WebAPI = webapi-vim; - wombat256 = wombat256-vim; # backwards compat, added 2015-7-8 - yankring = YankRing-vim; - Yankring = YankRing-vim; - xterm-color-table = xterm-color-table-vim; - zeavim = zeavim-vim; -} // deprecations) +mapAliases ( + with prev; + { + airline = vim-airline; + alternative = a-vim; # backwards compat, added 2014-10-21 + bats = bats-vim; + BufOnly = BufOnly-vim; + calendar = calendar-vim; + coffee-script = vim-coffee-script; + coffeeScript = vim-coffee-script; # backwards compat, added 2014-10-18 + Solarized = vim-colors-solarized; + solarized = vim-colors-solarized; + spacevim = throw "this distribution was unmaintained for the last 6 years, please use top-level 'spacevim'"; # added 2024-11-27 + SpaceVim = throw "this distribution didn't work properly in vimPlugins, please use top-level 'spacevim' instead"; # added 2024-11-27 + colors-solarized = vim-colors-solarized; + caw = caw-vim; + chad = chadtree; + colorsamplerpack = Colour-Sampler-Pack; + Colour_Sampler_Pack = Colour-Sampler-Pack; + command_T = command-t; # backwards compat, added 2014-10-18 + commentary = vim-commentary; + committia = committia-vim; + concealedyank = concealedyank-vim; + context-filetype = context_filetype-vim; + Cosco = cosco-vim; + css_color_5056 = vim-css-color; + CSApprox = csapprox; + csv = csv-vim; + ctrlp = ctrlp-vim; + cute-python = vim-cute-python; + denite = denite-nvim; + easy-align = vim-easy-align; + easygit = vim-easygit; + easymotion = vim-easymotion; + echodoc = echodoc-vim; + eighties = vim-eighties; + extradite = vim-extradite; + fugitive = vim-fugitive; + floating-nvim = throw "floating.nvim has been removed: abandoned by upstream. Use popup-nvim or nui-nvim"; # Added 2024-11-26 + ghc-mod-vim = ghcmod-vim; + ghcmod = ghcmod-vim; + goyo = goyo-vim; + Gist = vim-gist; + gitgutter = vim-gitgutter; + gundo = gundo-vim; + Gundo = gundo-vim; # backwards compat, added 2015-10-03 + haskellConceal = vim-haskellconceal; # backwards compat, added 2014-10-18 + haskellConcealPlus = vim-haskellConcealPlus; + haskellconceal = vim-haskellconceal; + hier = vim-hier; + hlint-refactor = hlint-refactor-vim; + hoogle = vim-hoogle; + Hoogle = vim-hoogle; + indent-blankline-nvim-lua = indent-blankline-nvim; # backwards compat, added 2021-07-05 + ipython = vim-ipython; + latex-live-preview = vim-latex-live-preview; + maktaba = vim-maktaba; + multiple-cursors = vim-multiple-cursors; + necoGhc = neco-ghc; # backwards compat, added 2014-10-18 + neocomplete = neocomplete-vim; + neoinclude = neoinclude-vim; + neomru = neomru-vim; + neosnippet = neosnippet-vim; + nvim-ts-rainbow = throw "nvim-ts-rainbow has been deprecated: Use rainbow-delimiters-nvim"; # Added 2023-11-30 + nvim-ts-rainbow2 = throw "nvim-ts-rainbow2 has been deprecated: Use rainbow-delimiters-nvim"; # Added 2023-11-30 + The_NERD_Commenter = nerdcommenter; + The_NERD_tree = nerdtree; + open-browser = open-browser-vim; + pathogen = vim-pathogen; + peskcolor-vim = throw "peskcolor-vim has been removed: abandoned by upstream"; # Added 2024-08-23 + polyglot = vim-polyglot; + prettyprint = vim-prettyprint; + quickrun = vim-quickrun; + rainbow_parentheses = rainbow_parentheses-vim; + repeat = vim-repeat; + riv = riv-vim; + rhubarb = vim-rhubarb; + sensible = vim-sensible; + signature = vim-signature; + snipmate = vim-snipmate; + sourcemap = sourcemap-vim; + "sourcemap.vim" = sourcemap-vim; + surround = vim-surround; + sleuth = vim-sleuth; + solidity = vim-solidity; + stylish-haskell = vim-stylish-haskell; + stylishHaskell = vim-stylish-haskell; # backwards compat, added 2014-10-18 + suda-vim = vim-suda; # backwards compat, added 2024-05-16 + Supertab = supertab; + Syntastic = syntastic; + SyntaxRange = vim-SyntaxRange; + table-mode = vim-table-mode; + taglist = taglist-vim; + tabpagebuffer = tabpagebuffer-vim; + tabpagecd = vim-tabpagecd; + Tabular = tabular; + Tagbar = tagbar; + thumbnail = thumbnail-vim; + tlib = tlib_vim; + tmux-navigator = vim-tmux-navigator; + tmuxNavigator = vim-tmux-navigator; # backwards compat, added 2014-10-18 + todo-nvim = throw "todo-nvim has been removed: abandoned by upstream"; # Added 2023-08-23 + tslime = tslime-vim; + unite = unite-vim; + UltiSnips = ultisnips; + vim-addon-vim2nix = vim2nix; + vim-sourcetrail = throw "vim-sourcetrail has been removed: abandoned by upstream"; # Added 2022-08-14 + vimproc = vimproc-vim; + vimshell = vimshell-vim; + vinegar = vim-vinegar; + watchdogs = vim-watchdogs; + WebAPI = webapi-vim; + wombat256 = wombat256-vim; # backwards compat, added 2015-7-8 + yankring = YankRing-vim; + Yankring = YankRing-vim; + xterm-color-table = xterm-color-table-vim; + zeavim = zeavim-vim; + } + // deprecations +) diff --git a/pkgs/applications/editors/vim/plugins/build-vim-plugin.nix b/pkgs/applications/editors/vim/plugins/build-vim-plugin.nix index b746e186644e00..ac5fb20e183b53 100644 --- a/pkgs/applications/editors/vim/plugins/build-vim-plugin.nix +++ b/pkgs/applications/editors/vim/plugins/build-vim-plugin.nix @@ -1,47 +1,59 @@ -{ lib -, stdenv -, rtpPath -, toVimPlugin +{ + lib, + stdenv, + rtpPath, + toVimPlugin, }: { addRtp = drv: lib.warn "`addRtp` is deprecated, does nothing." drv; buildVimPlugin = - { name ? "${attrs.pname}-${attrs.version}" - , src - , unpackPhase ? "" - , configurePhase ? ":" - , buildPhase ? ":" - , preInstall ? "" - , postInstall ? "" - , path ? "." - , addonInfo ? null - , meta ? { } - , ... + { + name ? "${attrs.pname}-${attrs.version}", + src, + unpackPhase ? "", + configurePhase ? ":", + buildPhase ? ":", + preInstall ? "", + postInstall ? "", + path ? ".", + addonInfo ? null, + meta ? { }, + ... }@attrs: let - drv = stdenv.mkDerivation (attrs // { - name = lib.warnIf (attrs ? vimprefix) "The 'vimprefix' is now hardcoded in toVimPlugin" name; - - __structuredAttrs = true; - inherit unpackPhase configurePhase buildPhase addonInfo preInstall postInstall; - - installPhase = '' - runHook preInstall - - target=$out/${rtpPath}/${path} - mkdir -p $out/${rtpPath} - cp -r . $target - - runHook postInstall - ''; - - meta = { - platforms = lib.platforms.all; - } // meta; - }); + drv = stdenv.mkDerivation ( + attrs + // { + name = lib.warnIf (attrs ? vimprefix) "The 'vimprefix' is now hardcoded in toVimPlugin" name; + + __structuredAttrs = true; + inherit + unpackPhase + configurePhase + buildPhase + addonInfo + preInstall + postInstall + ; + + installPhase = '' + runHook preInstall + + target=$out/${rtpPath}/${path} + mkdir -p $out/${rtpPath} + cp -r . $target + + runHook postInstall + ''; + + meta = { + platforms = lib.platforms.all; + } // meta; + } + ); in - toVimPlugin drv; + toVimPlugin drv; } diff --git a/pkgs/applications/editors/vim/plugins/default.nix b/pkgs/applications/editors/vim/plugins/default.nix index fd821bbec97015..4ee82593a198a3 100644 --- a/pkgs/applications/editors/vim/plugins/default.nix +++ b/pkgs/applications/editors/vim/plugins/default.nix @@ -1,13 +1,21 @@ # TODO check that no license information gets lost -{ callPackage, config, lib, vimUtils, vim, darwin, llvmPackages -, neovim-unwrapped -, neovimUtils +{ + callPackage, + config, + lib, + vimUtils, + vim, + darwin, + llvmPackages, + neovim-unwrapped, + neovimUtils, }: let - inherit (vimUtils.override {inherit vim;}) - buildVimPlugin; + inherit (vimUtils.override { inherit vim; }) + buildVimPlugin + ; inherit (lib) extends; @@ -30,13 +38,10 @@ let inherit llvmPackages; }; - aliases = if config.allowAliases then (import ./aliases.nix lib) else final: prev: {}; + aliases = if config.allowAliases then (import ./aliases.nix lib) else final: prev: { }; - extensible-self = lib.makeExtensible - (extends aliases - (extends overrides - (extends plugins initialPackages) - ) - ); + extensible-self = lib.makeExtensible ( + extends aliases (extends overrides (extends plugins initialPackages)) + ); in - extensible-self +extensible-self diff --git a/pkgs/applications/editors/vim/plugins/nvim-treesitter/overrides.nix b/pkgs/applications/editors/vim/plugins/nvim-treesitter/overrides.nix index c1e80f20d198b0..ef1fd6363c71cd 100644 --- a/pkgs/applications/editors/vim/plugins/nvim-treesitter/overrides.nix +++ b/pkgs/applications/editors/vim/plugins/nvim-treesitter/overrides.nix @@ -1,4 +1,13 @@ -{ lib, callPackage, tree-sitter, neovim, neovimUtils, runCommand, vimPlugins, tree-sitter-grammars }: +{ + lib, + callPackage, + tree-sitter, + neovim, + neovimUtils, + runCommand, + vimPlugins, + tree-sitter-grammars, +}: self: super: @@ -15,18 +24,21 @@ let # ocaml-interface # tree-sitter-ocaml-interface # tree-sitter-ocaml_interface - builtGrammars = generatedGrammars // lib.concatMapAttrs - (k: v: + builtGrammars = + generatedGrammars + // lib.concatMapAttrs ( + k: v: let replaced = lib.replaceStrings [ "_" ] [ "-" ] k; in { "tree-sitter-${k}" = v; - } // lib.optionalAttrs (k != replaced) { + } + // lib.optionalAttrs (k != replaced) { ${replaced} = v; "tree-sitter-${replaced}" = v; - }) - generatedDerivations; + } + ) generatedDerivations; allGrammars = lib.attrValues generatedDerivations; @@ -35,9 +47,9 @@ let # or for all grammars: # pkgs.vimPlugins.nvim-treesitter.withAllGrammars withPlugins = - f: self.nvim-treesitter.overrideAttrs { - passthru.dependencies = map grammarToPlugin - (f (tree-sitter.builtGrammars // builtGrammars)); + f: + self.nvim-treesitter.overrideAttrs { + passthru.dependencies = map grammarToPlugin (f (tree-sitter.builtGrammars // builtGrammars)); }; withAllGrammars = withPlugins (_: allGrammars); @@ -49,7 +61,13 @@ in ''; passthru = (super.nvim-treesitter.passthru or { }) // { - inherit builtGrammars allGrammars grammarToPlugin withPlugins withAllGrammars; + inherit + builtGrammars + allGrammars + grammarToPlugin + withPlugins + withAllGrammars + ; grammarPlugins = lib.mapAttrs (_: grammarToPlugin) generatedDerivations; @@ -81,16 +99,11 @@ in tree-sitter-queries-are-present-for-custom-grammars = let pluginsToCheck = - builtins.map - (grammar: grammarToPlugin grammar) - # true is here because there is `recurseForDerivations = true` - (lib.remove true - (lib.attrValues tree-sitter-grammars) - ); + builtins.map (grammar: grammarToPlugin grammar) + # true is here because there is `recurseForDerivations = true` + (lib.remove true (lib.attrValues tree-sitter-grammars)); in - runCommand "nvim-treesitter-test-queries-are-present-for-custom-grammars" - { CI = true; } - '' + runCommand "nvim-treesitter-test-queries-are-present-for-custom-grammars" { CI = true; } '' function check_grammar { EXPECTED_FILES="$2/parser/$1.so `ls $2/queries/$1/*.scm`" @@ -110,12 +123,7 @@ in done } - ${lib.concatLines - (lib.forEach - pluginsToCheck - (g: "check_grammar \"${g.grammarName}\" \"${g}\"") - ) - } + ${lib.concatLines (lib.forEach pluginsToCheck (g: "check_grammar \"${g.grammarName}\" \"${g}\""))} touch $out ''; @@ -123,13 +131,9 @@ in let pluginsToCheck = # true is here because there is `recurseForDerivations = true` - (lib.remove true - (lib.attrValues vimPlugins.nvim-treesitter-parsers) - ); + (lib.remove true (lib.attrValues vimPlugins.nvim-treesitter-parsers)); in - runCommand "nvim-treesitter-test-no-queries-for-official-grammars" - { CI = true; } - '' + runCommand "nvim-treesitter-test-no-queries-for-official-grammars" { CI = true; } '' touch $out function check_grammar { @@ -141,19 +145,17 @@ in fi } - ${lib.concatLines - (lib.forEach - pluginsToCheck - (g: "check_grammar \"${g.grammarName}\" \"${g}\"") - ) - } + ${lib.concatLines (lib.forEach pluginsToCheck (g: "check_grammar \"${g.grammarName}\" \"${g}\""))} ''; }; }; - meta = with lib; (super.nvim-treesitter.meta or { }) // { - license = licenses.asl20; - maintainers = with maintainers; [ figsoda ]; - }; + meta = + with lib; + (super.nvim-treesitter.meta or { }) + // { + license = licenses.asl20; + maintainers = with maintainers; [ figsoda ]; + }; nvimRequireCheck = "nvim-treesitter"; } diff --git a/pkgs/applications/editors/vim/plugins/nvim-treesitter/update-shell.nix b/pkgs/applications/editors/vim/plugins/nvim-treesitter/update-shell.nix index 04d83d42c8733c..a81c4daa32f8d1 100644 --- a/pkgs/applications/editors/vim/plugins/nvim-treesitter/update-shell.nix +++ b/pkgs/applications/editors/vim/plugins/nvim-treesitter/update-shell.nix @@ -1,4 +1,6 @@ -{ pkgs ? import ../../../../../.. { } }: +{ + pkgs ? import ../../../../../.. { }, +}: with pkgs; @@ -11,7 +13,11 @@ let in mkShell { - packages = [ neovim nurl python3 ]; + packages = [ + neovim + nurl + python3 + ]; NVIM_TREESITTER = nvim-treesitter; } diff --git a/pkgs/applications/editors/vim/plugins/updater.nix b/pkgs/applications/editors/vim/plugins/updater.nix index 1a62f13a04086c..41413a5b4c6618 100644 --- a/pkgs/applications/editors/vim/plugins/updater.nix +++ b/pkgs/applications/editors/vim/plugins/updater.nix @@ -1,13 +1,14 @@ -{ buildPythonApplication -, nix -, makeWrapper -, python3Packages -, lib -, nix-prefetch-git -, nurl - -# optional -, neovim-unwrapped +{ + buildPythonApplication, + nix, + makeWrapper, + python3Packages, + lib, + nix-prefetch-git, + nurl, + + # optional + neovim-unwrapped, }: buildPythonApplication { pname = "vim-plugins-updater"; @@ -32,15 +33,20 @@ buildPythonApplication { cp ${./get-plugins.nix} $out/bin/get-plugins.nix # wrap python scripts - makeWrapperArgs+=( --prefix PATH : "${lib.makeBinPath [ - nix nix-prefetch-git neovim-unwrapped nurl ]}" --prefix PYTHONPATH : "${./.}:${../../../../../maintainers/scripts/pluginupdate-py}" ) + makeWrapperArgs+=( --prefix PATH : "${ + lib.makeBinPath [ + nix + nix-prefetch-git + neovim-unwrapped + nurl + ] + }" --prefix PYTHONPATH : "${./.}:${../../../../../maintainers/scripts/pluginupdate-py}" ) wrapPythonPrograms ''; shellHook = '' export PYTHONPATH=pkgs/applications/editors/vim/plugins:maintainers/scripts/pluginupdate-py:$PYTHONPATH - ''; + ''; meta.mainProgram = "vim-plugins-updater"; } - diff --git a/pkgs/applications/editors/vim/vimacs.nix b/pkgs/applications/editors/vim/vimacs.nix index e54ac39b2ae49d..09f092be322ddc 100644 --- a/pkgs/applications/editors/vim/vimacs.nix +++ b/pkgs/applications/editors/vim/vimacs.nix @@ -1,13 +1,23 @@ -{ lib, stdenv, config, vim-full, macvim, vimPlugins -, useMacvim ? stdenv.hostPlatform.isDarwin && (config.vimacs.macvim or true) -, vimacsExtraArgs ? "" }: +{ + lib, + stdenv, + config, + vim-full, + macvim, + vimPlugins, + useMacvim ? stdenv.hostPlatform.isDarwin && (config.vimacs.macvim or true), + vimacsExtraArgs ? "", +}: stdenv.mkDerivation rec { pname = "vimacs"; version = lib.getVersion vimPackage; vimPackage = if useMacvim then macvim else vim-full; - buildInputs = [ vimPackage vimPlugins.vimacs ]; + buildInputs = [ + vimPackage + vimPlugins.vimacs + ]; buildCommand = '' mkdir -p "$out"/bin diff --git a/pkgs/applications/editors/vscode/extensions/vscodeExts2nix.nix b/pkgs/applications/editors/vscode/extensions/vscodeExts2nix.nix index 96b892911b06dc..ed2e32bd0c0837 100644 --- a/pkgs/applications/editors/vscode/extensions/vscodeExts2nix.nix +++ b/pkgs/applications/editors/vscode/extensions/vscodeExts2nix.nix @@ -19,13 +19,11 @@ writeShellScriptBin "vscodeExts2nix" '' echo '[' for line in $(${vscode}/bin/code --list-extensions --show-versions \ - ${ - lib.optionalString (extensionsToIgnore != [ ]) '' - | grep -v -i '^\(${ - lib.concatMapStringsSep "\\|" (e: "${e.publisher}.${e.name}") extensionsToIgnore - }\)' - '' - } + ${lib.optionalString (extensionsToIgnore != [ ]) '' + | grep -v -i '^\(${ + lib.concatMapStringsSep "\\|" (e: "${e.publisher}.${e.name}") extensionsToIgnore + }\)' + ''} ) ; do [[ $line =~ ([^.]*)\.([^@]*)@(.*) ]] name=''${BASH_REMATCH[2]} diff --git a/pkgs/applications/editors/vscode/generic.nix b/pkgs/applications/editors/vscode/generic.nix index fbe7658d8e4d5b..c32f80bd89da20 100644 --- a/pkgs/applications/editors/vscode/generic.nix +++ b/pkgs/applications/editors/vscode/generic.nix @@ -1,265 +1,334 @@ -{ stdenv -, lib -, copyDesktopItems -, makeDesktopItem -, unzip -, libsecret -, libXScrnSaver -, libxshmfence -, buildPackages -, at-spi2-atk -, autoPatchelfHook -, alsa-lib -, mesa -, nss -, nspr -, xorg -, systemd -, fontconfig -, libdbusmenu -, glib -, buildFHSEnv -, wayland -, libglvnd -, libkrb5 +{ + stdenv, + lib, + copyDesktopItems, + makeDesktopItem, + unzip, + libsecret, + libXScrnSaver, + libxshmfence, + buildPackages, + at-spi2-atk, + autoPatchelfHook, + alsa-lib, + mesa, + nss, + nspr, + xorg, + systemd, + fontconfig, + libdbusmenu, + glib, + buildFHSEnv, + wayland, + libglvnd, + libkrb5, # Populate passthru.tests -, tests + tests, # needed to fix "Save as Root" -, asar -, bash + asar, + bash, # Attributes inherit from specific versions -, version -, src -, meta -, sourceRoot -, commandLineArgs -, executableName -, longName -, shortName -, pname -, updateScript -, dontFixup ? false -, rev ? null -, vscodeServer ? null -, sourceExecutableName ? executableName -, useVSCodeRipgrep ? false -, ripgrep + version, + src, + meta, + sourceRoot, + commandLineArgs, + executableName, + longName, + shortName, + pname, + updateScript, + dontFixup ? false, + rev ? null, + vscodeServer ? null, + sourceExecutableName ? executableName, + useVSCodeRipgrep ? false, + ripgrep, }: -stdenv.mkDerivation (finalAttrs: -let +stdenv.mkDerivation ( + finalAttrs: + let - # Vscode and variants allow for users to download and use extensions - # which often include the usage of pre-built binaries. - # This has been an on-going painpoint for many users, as - # a full extension update cycle has to be done through nixpkgs - # in order to create or update extensions. - # See: #83288 #91179 #73810 #41189 - # - # buildFHSEnv allows for users to use the existing vscode - # extension tooling without significant pain. - fhs = { additionalPkgs ? pkgs: [ ] }: buildFHSEnv { - # also determines the name of the wrapped command - pname = executableName; - inherit version; + # Vscode and variants allow for users to download and use extensions + # which often include the usage of pre-built binaries. + # This has been an on-going painpoint for many users, as + # a full extension update cycle has to be done through nixpkgs + # in order to create or update extensions. + # See: #83288 #91179 #73810 #41189 + # + # buildFHSEnv allows for users to use the existing vscode + # extension tooling without significant pain. + fhs = + { + additionalPkgs ? pkgs: [ ], + }: + buildFHSEnv { + # also determines the name of the wrapped command + pname = executableName; + inherit version; - # additional libraries which are commonly needed for extensions - targetPkgs = pkgs: (with pkgs; [ - # ld-linux-x86-64-linux.so.2 and others - glibc + # additional libraries which are commonly needed for extensions + targetPkgs = + pkgs: + (with pkgs; [ + # ld-linux-x86-64-linux.so.2 and others + glibc - # dotnet - curl - icu - libunwind - libuuid - lttng-ust - openssl - zlib + # dotnet + curl + icu + libunwind + libuuid + lttng-ust + openssl + zlib - # mono - krb5 - ]) ++ additionalPkgs pkgs; + # mono + krb5 + ]) + ++ additionalPkgs pkgs; - extraBwrapArgs = [ - "--bind-try /etc/nixos/ /etc/nixos/" - ]; + extraBwrapArgs = [ + "--bind-try /etc/nixos/ /etc/nixos/" + ]; - # symlink shared assets, including icons and desktop entries - extraInstallCommands = '' - ln -s "${finalAttrs.finalPackage}/share" "$out/" - ''; + # symlink shared assets, including icons and desktop entries + extraInstallCommands = '' + ln -s "${finalAttrs.finalPackage}/share" "$out/" + ''; - runScript = "${finalAttrs.finalPackage}/bin/${executableName}"; + runScript = "${finalAttrs.finalPackage}/bin/${executableName}"; - # vscode likes to kill the parent so that the - # gui application isn't attached to the terminal session - dieWithParent = false; + # vscode likes to kill the parent so that the + # gui application isn't attached to the terminal session + dieWithParent = false; - passthru = { - inherit executableName; - inherit (finalAttrs.finalPackage) pname version; # for home-manager module - }; + passthru = { + inherit executableName; + inherit (finalAttrs.finalPackage) pname version; # for home-manager module + }; - meta = meta // { - description = '' - Wrapped variant of ${pname} which launches in a FHS compatible environment. - Should allow for easy usage of extensions without nix-specific modifications. - ''; - }; - }; -in -{ + meta = meta // { + description = '' + Wrapped variant of ${pname} which launches in a FHS compatible environment. + Should allow for easy usage of extensions without nix-specific modifications. + ''; + }; + }; + in + { - inherit pname version src sourceRoot dontFixup; + inherit + pname + version + src + sourceRoot + dontFixup + ; - passthru = { - inherit executableName longName tests updateScript; - fhs = fhs { }; - fhsWithPackages = f: fhs { additionalPkgs = f; }; - } // lib.optionalAttrs (vscodeServer != null) { - inherit rev vscodeServer; - }; + passthru = + { + inherit + executableName + longName + tests + updateScript + ; + fhs = fhs { }; + fhsWithPackages = f: fhs { additionalPkgs = f; }; + } + // lib.optionalAttrs (vscodeServer != null) { + inherit rev vscodeServer; + }; - desktopItems = [ - (makeDesktopItem { - name = executableName; - desktopName = longName; - comment = "Code Editing. Redefined."; - genericName = "Text Editor"; - exec = "${executableName} %F"; - icon = "vs${executableName}"; - startupNotify = true; - startupWMClass = shortName; - categories = [ "Utility" "TextEditor" "Development" "IDE" ]; - keywords = [ "vscode" ]; - actions.new-empty-window = { - name = "New Empty Window"; - exec = "${executableName} --new-window %F"; + desktopItems = [ + (makeDesktopItem { + name = executableName; + desktopName = longName; + comment = "Code Editing. Redefined."; + genericName = "Text Editor"; + exec = "${executableName} %F"; icon = "vs${executableName}"; - }; - }) - (makeDesktopItem { - name = executableName + "-url-handler"; - desktopName = longName + " - URL Handler"; - comment = "Code Editing. Redefined."; - genericName = "Text Editor"; - exec = executableName + " --open-url %U"; - icon = "vs${executableName}"; - startupNotify = true; - startupWMClass = shortName; - categories = [ "Utility" "TextEditor" "Development" "IDE" ]; - mimeTypes = [ "x-scheme-handler/vs${executableName}" ]; - keywords = [ "vscode" ]; - noDisplay = true; - }) - ]; + startupNotify = true; + startupWMClass = shortName; + categories = [ + "Utility" + "TextEditor" + "Development" + "IDE" + ]; + keywords = [ "vscode" ]; + actions.new-empty-window = { + name = "New Empty Window"; + exec = "${executableName} --new-window %F"; + icon = "vs${executableName}"; + }; + }) + (makeDesktopItem { + name = executableName + "-url-handler"; + desktopName = longName + " - URL Handler"; + comment = "Code Editing. Redefined."; + genericName = "Text Editor"; + exec = executableName + " --open-url %U"; + icon = "vs${executableName}"; + startupNotify = true; + startupWMClass = shortName; + categories = [ + "Utility" + "TextEditor" + "Development" + "IDE" + ]; + mimeTypes = [ "x-scheme-handler/vs${executableName}" ]; + keywords = [ "vscode" ]; + noDisplay = true; + }) + ]; - buildInputs = [ libsecret libXScrnSaver libxshmfence ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ alsa-lib at-spi2-atk libkrb5 mesa nss nspr systemd xorg.libxkbfile ]; + buildInputs = + [ + libsecret + libXScrnSaver + libxshmfence + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + alsa-lib + at-spi2-atk + libkrb5 + mesa + nss + nspr + systemd + xorg.libxkbfile + ]; - runtimeDependencies = lib.optionals stdenv.hostPlatform.isLinux [ (lib.getLib systemd) fontconfig.lib libdbusmenu wayland libsecret ]; + runtimeDependencies = lib.optionals stdenv.hostPlatform.isLinux [ + (lib.getLib systemd) + fontconfig.lib + libdbusmenu + wayland + libsecret + ]; - nativeBuildInputs = [ unzip ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ - autoPatchelfHook - asar - copyDesktopItems - # override doesn't preserve splicing https://github.com/NixOS/nixpkgs/issues/132651 - # Has to use `makeShellWrapper` from `buildPackages` even though `makeShellWrapper` from the inputs is spliced because `propagatedBuildInputs` would pick the wrong one because of a different offset. - (buildPackages.wrapGAppsHook3.override { makeWrapper = buildPackages.makeShellWrapper; }) - ]; + nativeBuildInputs = + [ unzip ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + autoPatchelfHook + asar + copyDesktopItems + # override doesn't preserve splicing https://github.com/NixOS/nixpkgs/issues/132651 + # Has to use `makeShellWrapper` from `buildPackages` even though `makeShellWrapper` from the inputs is spliced because `propagatedBuildInputs` would pick the wrong one because of a different offset. + (buildPackages.wrapGAppsHook3.override { makeWrapper = buildPackages.makeShellWrapper; }) + ]; - dontBuild = true; - dontConfigure = true; - noDumpEnvVars = true; + dontBuild = true; + dontConfigure = true; + noDumpEnvVars = true; - installPhase = '' - runHook preInstall - '' + (if stdenv.hostPlatform.isDarwin then '' - mkdir -p "$out/Applications/${longName}.app" "$out/bin" - cp -r ./* "$out/Applications/${longName}.app" - ln -s "$out/Applications/${longName}.app/Contents/Resources/app/bin/${sourceExecutableName}" "$out/bin/${executableName}" - '' else '' - mkdir -p "$out/lib/vscode" "$out/bin" - cp -r ./* "$out/lib/vscode" + installPhase = + '' + runHook preInstall + '' + + ( + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p "$out/Applications/${longName}.app" "$out/bin" + cp -r ./* "$out/Applications/${longName}.app" + ln -s "$out/Applications/${longName}.app/Contents/Resources/app/bin/${sourceExecutableName}" "$out/bin/${executableName}" + '' + else + '' + mkdir -p "$out/lib/vscode" "$out/bin" + cp -r ./* "$out/lib/vscode" - ln -s "$out/lib/vscode/bin/${sourceExecutableName}" "$out/bin/${executableName}" + ln -s "$out/lib/vscode/bin/${sourceExecutableName}" "$out/bin/${executableName}" - # These are named vscode.png, vscode-insiders.png, etc to match the name in upstream *.deb packages. - mkdir -p "$out/share/pixmaps" - cp "$out/lib/vscode/resources/app/resources/linux/code.png" "$out/share/pixmaps/vs${executableName}.png" + # These are named vscode.png, vscode-insiders.png, etc to match the name in upstream *.deb packages. + mkdir -p "$out/share/pixmaps" + cp "$out/lib/vscode/resources/app/resources/linux/code.png" "$out/share/pixmaps/vs${executableName}.png" - # Override the previously determined VSCODE_PATH with the one we know to be correct - sed -i "/ELECTRON=/iVSCODE_PATH='$out/lib/vscode'" "$out/bin/${executableName}" - grep -q "VSCODE_PATH='$out/lib/vscode'" "$out/bin/${executableName}" # check if sed succeeded + # Override the previously determined VSCODE_PATH with the one we know to be correct + sed -i "/ELECTRON=/iVSCODE_PATH='$out/lib/vscode'" "$out/bin/${executableName}" + grep -q "VSCODE_PATH='$out/lib/vscode'" "$out/bin/${executableName}" # check if sed succeeded - # Remove native encryption code, as it derives the key from the executable path which does not work for us. - # The credentials should be stored in a secure keychain already, so the benefit of this is questionable - # in the first place. - rm -rf $out/lib/vscode/resources/app/node_modules/vscode-encrypt - '') + '' - runHook postInstall - ''; + # Remove native encryption code, as it derives the key from the executable path which does not work for us. + # The credentials should be stored in a secure keychain already, so the benefit of this is questionable + # in the first place. + rm -rf $out/lib/vscode/resources/app/node_modules/vscode-encrypt + '' + ) + + '' + runHook postInstall + ''; - preFixup = '' - gappsWrapperArgs+=( - ${ # we cannot use runtimeDependencies otherwise libdbusmenu do not work on kde - lib.optionalString stdenv.hostPlatform.isLinux - "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ libdbusmenu ]}"} - # Add gio to PATH so that moving files to the trash works when not using a desktop environment - --prefix PATH : ${glib.bin}/bin - --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" - --add-flags ${lib.escapeShellArg commandLineArgs} - ) - ''; + preFixup = '' + gappsWrapperArgs+=( + ${ + # we cannot use runtimeDependencies otherwise libdbusmenu do not work on kde + lib.optionalString stdenv.hostPlatform.isLinux + "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ libdbusmenu ]}" + } + # Add gio to PATH so that moving files to the trash works when not using a desktop environment + --prefix PATH : ${glib.bin}/bin + --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" + --add-flags ${lib.escapeShellArg commandLineArgs} + ) + ''; - # See https://github.com/NixOS/nixpkgs/issues/49643#issuecomment-873853897 - # linux only because of https://github.com/NixOS/nixpkgs/issues/138729 - postPatch = lib.optionalString stdenv.hostPlatform.isLinux '' - # this is a fix for "save as root" functionality - packed="resources/app/node_modules.asar" - unpacked="resources/app/node_modules" - asar extract "$packed" "$unpacked" - substituteInPlace $unpacked/@vscode/sudo-prompt/index.js \ - --replace "/usr/bin/pkexec" "/run/wrappers/bin/pkexec" \ - --replace "/bin/bash" "${bash}/bin/bash" - rm -rf "$packed" + # See https://github.com/NixOS/nixpkgs/issues/49643#issuecomment-873853897 + # linux only because of https://github.com/NixOS/nixpkgs/issues/138729 + postPatch = + lib.optionalString stdenv.hostPlatform.isLinux '' + # this is a fix for "save as root" functionality + packed="resources/app/node_modules.asar" + unpacked="resources/app/node_modules" + asar extract "$packed" "$unpacked" + substituteInPlace $unpacked/@vscode/sudo-prompt/index.js \ + --replace "/usr/bin/pkexec" "/run/wrappers/bin/pkexec" \ + --replace "/bin/bash" "${bash}/bin/bash" + rm -rf "$packed" - # without this symlink loading JsChardet, the library that is used for auto encoding detection when files.autoGuessEncoding is true, - # fails to load with: electron/js2c/renderer_init: Error: Cannot find module 'jschardet' - # and the window immediately closes which renders VSCode unusable - # see https://github.com/NixOS/nixpkgs/issues/152939 for full log - ln -rs "$unpacked" "$packed" - '' + ( - let - vscodeRipgrep = - if stdenv.hostPlatform.isDarwin then - if lib.versionAtLeast version "1.94.0" then - "Contents/Resources/app/node_modules/@vscode/ripgrep/bin/rg" - else - "Contents/Resources/app/node_modules.asar.unpacked/@vscode/ripgrep/bin/rg" + # without this symlink loading JsChardet, the library that is used for auto encoding detection when files.autoGuessEncoding is true, + # fails to load with: electron/js2c/renderer_init: Error: Cannot find module 'jschardet' + # and the window immediately closes which renders VSCode unusable + # see https://github.com/NixOS/nixpkgs/issues/152939 for full log + ln -rs "$unpacked" "$packed" + '' + + ( + let + vscodeRipgrep = + if stdenv.hostPlatform.isDarwin then + if lib.versionAtLeast version "1.94.0" then + "Contents/Resources/app/node_modules/@vscode/ripgrep/bin/rg" + else + "Contents/Resources/app/node_modules.asar.unpacked/@vscode/ripgrep/bin/rg" + else + "resources/app/node_modules/@vscode/ripgrep/bin/rg"; + in + if !useVSCodeRipgrep then + '' + rm ${vscodeRipgrep} + ln -s ${ripgrep}/bin/rg ${vscodeRipgrep} + '' else - "resources/app/node_modules/@vscode/ripgrep/bin/rg"; - in - if !useVSCodeRipgrep then '' - rm ${vscodeRipgrep} - ln -s ${ripgrep}/bin/rg ${vscodeRipgrep} - '' else '' - chmod +x ${vscodeRipgrep} - '' - ); + '' + chmod +x ${vscodeRipgrep} + '' + ); - postFixup = lib.optionalString stdenv.hostPlatform.isLinux '' - patchelf \ - --add-needed ${libglvnd}/lib/libGLESv2.so.2 \ - --add-needed ${libglvnd}/lib/libGL.so.1 \ - --add-needed ${libglvnd}/lib/libEGL.so.1 \ - $out/lib/vscode/${executableName} - ''; + postFixup = lib.optionalString stdenv.hostPlatform.isLinux '' + patchelf \ + --add-needed ${libglvnd}/lib/libGLESv2.so.2 \ + --add-needed ${libglvnd}/lib/libGL.so.1 \ + --add-needed ${libglvnd}/lib/libEGL.so.1 \ + $out/lib/vscode/${executableName} + ''; - inherit meta; -}) + inherit meta; + } +) diff --git a/pkgs/applications/editors/vscode/update-shell.nix b/pkgs/applications/editors/vscode/update-shell.nix index aa9488c217f4b9..03ad7780722268 100644 --- a/pkgs/applications/editors/vscode/update-shell.nix +++ b/pkgs/applications/editors/vscode/update-shell.nix @@ -1,4 +1,6 @@ -{ pkgs ? import ../../../.. { } }: +{ + pkgs ? import ../../../.. { }, +}: # Ideally, pkgs points to default.nix file of Nixpkgs official tree with pkgs; diff --git a/pkgs/applications/editors/vscode/vscode.nix b/pkgs/applications/editors/vscode/vscode.nix index 90c543f352b131..1da3040f558e82 100644 --- a/pkgs/applications/editors/vscode/vscode.nix +++ b/pkgs/applications/editors/vscode/vscode.nix @@ -1,105 +1,122 @@ -{ stdenv -, stdenvNoCC -, lib -, callPackage -, fetchurl -, nixosTests -, srcOnly -, isInsiders ? false -# sourceExecutableName is the name of the binary in the source archive over -# which we have no control and it is needed to run the insider version as -# documented in https://wiki.nixos.org/wiki/Visual_Studio_Code#Insiders_Build -# On MacOS the insider binary is still called code instead of code-insiders as -# of 2023-08-06. -, sourceExecutableName ? "code" + lib.optionalString (isInsiders && stdenv.hostPlatform.isLinux) "-insiders" -, commandLineArgs ? "" -, useVSCodeRipgrep ? stdenv.hostPlatform.isDarwin +{ + stdenv, + stdenvNoCC, + lib, + callPackage, + fetchurl, + nixosTests, + srcOnly, + isInsiders ? false, + # sourceExecutableName is the name of the binary in the source archive over + # which we have no control and it is needed to run the insider version as + # documented in https://wiki.nixos.org/wiki/Visual_Studio_Code#Insiders_Build + # On MacOS the insider binary is still called code instead of code-insiders as + # of 2023-08-06. + sourceExecutableName ? + "code" + lib.optionalString (isInsiders && stdenv.hostPlatform.isLinux) "-insiders", + commandLineArgs ? "", + useVSCodeRipgrep ? stdenv.hostPlatform.isDarwin, }: let inherit (stdenv.hostPlatform) system; throwSystem = throw "Unsupported system: ${system}"; - plat = { - x86_64-linux = "linux-x64"; - x86_64-darwin = "darwin"; - aarch64-linux = "linux-arm64"; - aarch64-darwin = "darwin-arm64"; - armv7l-linux = "linux-armhf"; - }.${system} or throwSystem; + plat = + { + x86_64-linux = "linux-x64"; + x86_64-darwin = "darwin"; + aarch64-linux = "linux-arm64"; + aarch64-darwin = "darwin-arm64"; + armv7l-linux = "linux-armhf"; + } + .${system} or throwSystem; archive_fmt = if stdenv.hostPlatform.isDarwin then "zip" else "tar.gz"; - sha256 = { - x86_64-linux = "0ijv2y2brc05m45slsy24dp8r0733d89f082l3mbs64vkz76s748"; - x86_64-darwin = "012lkaxq5cqcby6lzmgwxbhgr36mk5szqvnxkw9xf5bjcpmxllfz"; - aarch64-linux = "1975pvzg9hvbwqri80sbzbrgr96h85fi22x1walgqw4px74lsa1d"; - aarch64-darwin = "023an5g5lgjizdppv52lpsah8kr0y40dm2kl7rq7byvsfxjga0gy"; - armv7l-linux = "1f871lafkfyjw57iwz5gzl3bjjhqdac32akj0n26lkl3zq86p417"; - }.${system} or throwSystem; + sha256 = + { + x86_64-linux = "0ijv2y2brc05m45slsy24dp8r0733d89f082l3mbs64vkz76s748"; + x86_64-darwin = "012lkaxq5cqcby6lzmgwxbhgr36mk5szqvnxkw9xf5bjcpmxllfz"; + aarch64-linux = "1975pvzg9hvbwqri80sbzbrgr96h85fi22x1walgqw4px74lsa1d"; + aarch64-darwin = "023an5g5lgjizdppv52lpsah8kr0y40dm2kl7rq7byvsfxjga0gy"; + armv7l-linux = "1f871lafkfyjw57iwz5gzl3bjjhqdac32akj0n26lkl3zq86p417"; + } + .${system} or throwSystem; in - callPackage ./generic.nix rec { - # Please backport all compatible updates to the stable release. - # This is important for the extension ecosystem. - version = "1.95.3"; - pname = "vscode" + lib.optionalString isInsiders "-insiders"; +callPackage ./generic.nix rec { + # Please backport all compatible updates to the stable release. + # This is important for the extension ecosystem. + version = "1.95.3"; + pname = "vscode" + lib.optionalString isInsiders "-insiders"; - # This is used for VS Code - Remote SSH test - rev = "f1a4fb101478ce6ec82fe9627c43efbf9e98c813"; + # This is used for VS Code - Remote SSH test + rev = "f1a4fb101478ce6ec82fe9627c43efbf9e98c813"; - executableName = "code" + lib.optionalString isInsiders "-insiders"; - longName = "Visual Studio Code" + lib.optionalString isInsiders " - Insiders"; - shortName = "Code" + lib.optionalString isInsiders " - Insiders"; - inherit commandLineArgs useVSCodeRipgrep sourceExecutableName; + executableName = "code" + lib.optionalString isInsiders "-insiders"; + longName = "Visual Studio Code" + lib.optionalString isInsiders " - Insiders"; + shortName = "Code" + lib.optionalString isInsiders " - Insiders"; + inherit commandLineArgs useVSCodeRipgrep sourceExecutableName; - src = fetchurl { - name = "VSCode_${version}_${plat}.${archive_fmt}"; - url = "https://update.code.visualstudio.com/${version}/${plat}/stable"; - inherit sha256; - }; + src = fetchurl { + name = "VSCode_${version}_${plat}.${archive_fmt}"; + url = "https://update.code.visualstudio.com/${version}/${plat}/stable"; + inherit sha256; + }; - # We don't test vscode on CI, instead we test vscodium - tests = {}; + # We don't test vscode on CI, instead we test vscodium + tests = { }; - sourceRoot = ""; + sourceRoot = ""; - # As tests run without networking, we need to download this for the Remote SSH server - vscodeServer = srcOnly { + # As tests run without networking, we need to download this for the Remote SSH server + vscodeServer = srcOnly { + name = "vscode-server-${rev}.tar.gz"; + src = fetchurl { name = "vscode-server-${rev}.tar.gz"; - src = fetchurl { - name = "vscode-server-${rev}.tar.gz"; - url = "https://update.code.visualstudio.com/commit:${rev}/server-linux-x64/stable"; - sha256 = "1ij7qfp5z801ny3n397801fv3hw5yvss1wxl9cyjgmjxmi6id7c1"; - }; - stdenv = stdenvNoCC; + url = "https://update.code.visualstudio.com/commit:${rev}/server-linux-x64/stable"; + sha256 = "1ij7qfp5z801ny3n397801fv3hw5yvss1wxl9cyjgmjxmi6id7c1"; }; + stdenv = stdenvNoCC; + }; - tests = { inherit (nixosTests) vscode-remote-ssh; }; + tests = { inherit (nixosTests) vscode-remote-ssh; }; - updateScript = ./update-vscode.sh; + updateScript = ./update-vscode.sh; - # Editing the `code` binary within the app bundle causes the bundle's signature - # to be invalidated, which prevents launching starting with macOS Ventura, because VS Code is notarized. - # See https://eclecticlight.co/2022/06/17/app-security-changes-coming-in-ventura/ for more information. - dontFixup = stdenv.hostPlatform.isDarwin; + # Editing the `code` binary within the app bundle causes the bundle's signature + # to be invalidated, which prevents launching starting with macOS Ventura, because VS Code is notarized. + # See https://eclecticlight.co/2022/06/17/app-security-changes-coming-in-ventura/ for more information. + dontFixup = stdenv.hostPlatform.isDarwin; - meta = with lib; { - description = '' - Open source source code editor developed by Microsoft for Windows, - Linux and macOS - ''; - mainProgram = "code"; - longDescription = '' - Open source source code editor developed by Microsoft for Windows, - Linux and macOS. It includes support for debugging, embedded Git - control, syntax highlighting, intelligent code completion, snippets, - and code refactoring. It is also customizable, so users can change the - editor's theme, keyboard shortcuts, and preferences - ''; - homepage = "https://code.visualstudio.com/"; - downloadPage = "https://code.visualstudio.com/Updates"; - license = licenses.unfree; - maintainers = with maintainers; [ eadwu synthetica bobby285271 johnrtitor ]; - platforms = [ "x86_64-linux" "x86_64-darwin" "aarch64-darwin" "aarch64-linux" "armv7l-linux" ]; - }; - } + meta = with lib; { + description = '' + Open source source code editor developed by Microsoft for Windows, + Linux and macOS + ''; + mainProgram = "code"; + longDescription = '' + Open source source code editor developed by Microsoft for Windows, + Linux and macOS. It includes support for debugging, embedded Git + control, syntax highlighting, intelligent code completion, snippets, + and code refactoring. It is also customizable, so users can change the + editor's theme, keyboard shortcuts, and preferences + ''; + homepage = "https://code.visualstudio.com/"; + downloadPage = "https://code.visualstudio.com/Updates"; + license = licenses.unfree; + maintainers = with maintainers; [ + eadwu + synthetica + bobby285271 + johnrtitor + ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + "aarch64-darwin" + "aarch64-linux" + "armv7l-linux" + ]; + }; +} diff --git a/pkgs/applications/editors/vscode/vscodium.nix b/pkgs/applications/editors/vscode/vscodium.nix index 167df0c8548228..de083f67a7d996 100644 --- a/pkgs/applications/editors/vscode/vscodium.nix +++ b/pkgs/applications/editors/vscode/vscodium.nix @@ -1,68 +1,90 @@ -{ lib, stdenv, callPackage, fetchurl, nixosTests, commandLineArgs ? "", useVSCodeRipgrep ? stdenv.hostPlatform.isDarwin }: +{ + lib, + stdenv, + callPackage, + fetchurl, + nixosTests, + commandLineArgs ? "", + useVSCodeRipgrep ? stdenv.hostPlatform.isDarwin, +}: let inherit (stdenv.hostPlatform) system; throwSystem = throw "Unsupported system: ${system}"; - plat = { - x86_64-linux = "linux-x64"; - x86_64-darwin = "darwin-x64"; - aarch64-linux = "linux-arm64"; - aarch64-darwin = "darwin-arm64"; - armv7l-linux = "linux-armhf"; - }.${system} or throwSystem; + plat = + { + x86_64-linux = "linux-x64"; + x86_64-darwin = "darwin-x64"; + aarch64-linux = "linux-arm64"; + aarch64-darwin = "darwin-arm64"; + armv7l-linux = "linux-armhf"; + } + .${system} or throwSystem; archive_fmt = if stdenv.hostPlatform.isDarwin then "zip" else "tar.gz"; - sha256 = { - x86_64-linux = "0948jbnhjra09bvf9acrl6b2dp1xar5ajahmzy0cwf6dbidfms5y"; - x86_64-darwin = "1a8ga66526lfy2xrgshhizmidp8aaiwvpr38rvhsx0hqb4vmm0hy"; - aarch64-linux = "08la7kbb6myf9iz23p60vd00mrmhnizw8dgh54gb0msh8wbasidq"; - aarch64-darwin = "01z1dx77briqzhfx45c2f2np78r11b5xm92smi9idivbsia800i3"; - armv7l-linux = "0h3f9sy7d4ylk0ay63adhnz9s7jlpwlf3x831v8pygzm2r7k9zgc"; - }.${system} or throwSystem; + sha256 = + { + x86_64-linux = "0948jbnhjra09bvf9acrl6b2dp1xar5ajahmzy0cwf6dbidfms5y"; + x86_64-darwin = "1a8ga66526lfy2xrgshhizmidp8aaiwvpr38rvhsx0hqb4vmm0hy"; + aarch64-linux = "08la7kbb6myf9iz23p60vd00mrmhnizw8dgh54gb0msh8wbasidq"; + aarch64-darwin = "01z1dx77briqzhfx45c2f2np78r11b5xm92smi9idivbsia800i3"; + armv7l-linux = "0h3f9sy7d4ylk0ay63adhnz9s7jlpwlf3x831v8pygzm2r7k9zgc"; + } + .${system} or throwSystem; sourceRoot = lib.optionalString (!stdenv.hostPlatform.isDarwin) "."; in - callPackage ./generic.nix rec { - inherit sourceRoot commandLineArgs useVSCodeRipgrep; +callPackage ./generic.nix rec { + inherit sourceRoot commandLineArgs useVSCodeRipgrep; - # Please backport all compatible updates to the stable release. - # This is important for the extension ecosystem. - version = "1.95.3.24321"; - pname = "vscodium"; + # Please backport all compatible updates to the stable release. + # This is important for the extension ecosystem. + version = "1.95.3.24321"; + pname = "vscodium"; - executableName = "codium"; - longName = "VSCodium"; - shortName = "vscodium"; + executableName = "codium"; + longName = "VSCodium"; + shortName = "vscodium"; - src = fetchurl { - url = "https://github.com/VSCodium/vscodium/releases/download/${version}/VSCodium-${plat}-${version}.${archive_fmt}"; - inherit sha256; - }; + src = fetchurl { + url = "https://github.com/VSCodium/vscodium/releases/download/${version}/VSCodium-${plat}-${version}.${archive_fmt}"; + inherit sha256; + }; - tests = nixosTests.vscodium; + tests = nixosTests.vscodium; - updateScript = ./update-vscodium.sh; + updateScript = ./update-vscodium.sh; - meta = with lib; { - description = '' - Open source source code editor developed by Microsoft for Windows, - Linux and macOS (VS Code without MS branding/telemetry/licensing) - ''; - longDescription = '' - Open source source code editor developed by Microsoft for Windows, - Linux and macOS. It includes support for debugging, embedded Git - control, syntax highlighting, intelligent code completion, snippets, - and code refactoring. It is also customizable, so users can change the - editor's theme, keyboard shortcuts, and preferences - ''; - homepage = "https://github.com/VSCodium/vscodium"; - downloadPage = "https://github.com/VSCodium/vscodium/releases"; - license = licenses.mit; - sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - maintainers = with maintainers; [ synthetica bobby285271 ludovicopiero ]; - mainProgram = "codium"; - platforms = [ "x86_64-linux" "x86_64-darwin" "aarch64-linux" "aarch64-darwin" "armv7l-linux" ]; - }; - } + meta = with lib; { + description = '' + Open source source code editor developed by Microsoft for Windows, + Linux and macOS (VS Code without MS branding/telemetry/licensing) + ''; + longDescription = '' + Open source source code editor developed by Microsoft for Windows, + Linux and macOS. It includes support for debugging, embedded Git + control, syntax highlighting, intelligent code completion, snippets, + and code refactoring. It is also customizable, so users can change the + editor's theme, keyboard shortcuts, and preferences + ''; + homepage = "https://github.com/VSCodium/vscodium"; + downloadPage = "https://github.com/VSCodium/vscodium/releases"; + license = licenses.mit; + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; + maintainers = with maintainers; [ + synthetica + bobby285271 + ludovicopiero + ]; + mainProgram = "codium"; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + "aarch64-linux" + "aarch64-darwin" + "armv7l-linux" + ]; + }; +} diff --git a/pkgs/applications/editors/vscode/with-extensions.nix b/pkgs/applications/editors/vscode/with-extensions.nix index 25c97f52d765e5..5097d177d62427 100644 --- a/pkgs/applications/editors/vscode/with-extensions.nix +++ b/pkgs/applications/editors/vscode/with-extensions.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, runCommand, buildEnv, vscode, vscode-utils, makeWrapper, writeTextFile -, vscodeExtensions ? [] }: +{ + lib, + stdenv, + runCommand, + buildEnv, + vscode, + vscode-utils, + makeWrapper, + writeTextFile, + vscodeExtensions ? [ ], +}: /* `vscodeExtensions` @@ -62,29 +71,36 @@ let ''; in -runCommand "${wrappedPkgName}-with-extensions-${wrappedPkgVersion}" { - nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ vscode ]; - dontPatchELF = true; - dontStrip = true; - meta = vscode.meta; -} (if stdenv.hostPlatform.isDarwin then '' - mkdir -p $out/bin/ - mkdir -p "$out/Applications/${longName}.app/Contents/MacOS" - - for path in PkgInfo Frameworks Resources _CodeSignature Info.plist; do - ln -s "${vscode}/Applications/${longName}.app/Contents/$path" "$out/Applications/${longName}.app/Contents/" - done - - makeWrapper "${vscode}/bin/${executableName}" "$out/bin/${executableName}" ${extensionsFlag} - makeWrapper "${vscode}/Applications/${longName}.app/Contents/MacOS/Electron" "$out/Applications/${longName}.app/Contents/MacOS/Electron" ${extensionsFlag} -'' else '' - mkdir -p "$out/bin" - mkdir -p "$out/share/applications" - mkdir -p "$out/share/pixmaps" - - ln -sT "${vscode}/share/pixmaps/vs${executableName}.png" "$out/share/pixmaps/vs${executableName}.png" - ln -sT "${vscode}/share/applications/${executableName}.desktop" "$out/share/applications/${executableName}.desktop" - ln -sT "${vscode}/share/applications/${executableName}-url-handler.desktop" "$out/share/applications/${executableName}-url-handler.desktop" - makeWrapper "${vscode}/bin/${executableName}" "$out/bin/${executableName}" ${extensionsFlag} -'') +runCommand "${wrappedPkgName}-with-extensions-${wrappedPkgVersion}" + { + nativeBuildInputs = [ makeWrapper ]; + buildInputs = [ vscode ]; + dontPatchELF = true; + dontStrip = true; + meta = vscode.meta; + } + ( + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p $out/bin/ + mkdir -p "$out/Applications/${longName}.app/Contents/MacOS" + + for path in PkgInfo Frameworks Resources _CodeSignature Info.plist; do + ln -s "${vscode}/Applications/${longName}.app/Contents/$path" "$out/Applications/${longName}.app/Contents/" + done + + makeWrapper "${vscode}/bin/${executableName}" "$out/bin/${executableName}" ${extensionsFlag} + makeWrapper "${vscode}/Applications/${longName}.app/Contents/MacOS/Electron" "$out/Applications/${longName}.app/Contents/MacOS/Electron" ${extensionsFlag} + '' + else + '' + mkdir -p "$out/bin" + mkdir -p "$out/share/applications" + mkdir -p "$out/share/pixmaps" + + ln -sT "${vscode}/share/pixmaps/vs${executableName}.png" "$out/share/pixmaps/vs${executableName}.png" + ln -sT "${vscode}/share/applications/${executableName}.desktop" "$out/share/applications/${executableName}.desktop" + ln -sT "${vscode}/share/applications/${executableName}-url-handler.desktop" "$out/share/applications/${executableName}-url-handler.desktop" + makeWrapper "${vscode}/bin/${executableName}" "$out/bin/${executableName}" ${extensionsFlag} + '' + ) diff --git a/pkgs/applications/editors/wxhexeditor/default.nix b/pkgs/applications/editors/wxhexeditor/default.nix index eee370d174e022..9dda57287fc442 100644 --- a/pkgs/applications/editors/wxhexeditor/default.nix +++ b/pkgs/applications/editors/wxhexeditor/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoconf -, automake -, gettext -, libtool -, python3 -, wxGTK -, openmp -, Cocoa +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoconf, + automake, + gettext, + libtool, + python3, + wxGTK, + openmp, + Cocoa, }: stdenv.mkDerivation rec { @@ -34,20 +35,24 @@ stdenv.mkDerivation rec { wxGTK ]; - buildInputs = lib.optionals stdenv.cc.isClang [ - openmp - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Cocoa - ]; + buildInputs = + lib.optionals stdenv.cc.isClang [ + openmp + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + ]; preConfigure = "patchShebangs ."; - prePatch = '' - substituteInPlace Makefile --replace "/usr" "$out" - substituteInPlace Makefile --replace "mhash; ./configure" "mhash; ./configure --prefix=$out" - '' + lib.optionalString stdenv.cc.isClang '' - substituteInPlace Makefile --replace "-lgomp" "-lomp" - ''; + prePatch = + '' + substituteInPlace Makefile --replace "/usr" "$out" + substituteInPlace Makefile --replace "mhash; ./configure" "mhash; ./configure --prefix=$out" + '' + + lib.optionalString stdenv.cc.isClang '' + substituteInPlace Makefile --replace "-lgomp" "-lomp" + ''; patches = [ # https://github.com/EUA/wxHexEditor/issues/90 diff --git a/pkgs/applications/editors/your-editor/default.nix b/pkgs/applications/editors/your-editor/default.nix index 7ca6cd4b4fc5aa..272729bcb47fed 100644 --- a/pkgs/applications/editors/your-editor/default.nix +++ b/pkgs/applications/editors/your-editor/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "your-editor"; diff --git a/pkgs/applications/editors/zee/default.nix b/pkgs/applications/editors/zee/default.nix index cea97686072c5d..4aec2af12cda91 100644 --- a/pkgs/applications/editors/zee/default.nix +++ b/pkgs/applications/editors/zee/default.nix @@ -1,4 +1,12 @@ -{ lib, rustPlatform, fetchFromGitHub, pkg-config, openssl, stdenv, Security }: +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + Security, +}: rustPlatform.buildRustPackage rec { pname = "zee"; @@ -23,7 +31,7 @@ rustPlatform.buildRustPackage rec { # disable downloading and building the tree-sitter grammars at build time # grammars can be configured in a config file and installed with `zee --build` # see https://github.com/zee-editor/zee#syntax-highlighting - ZEE_DISABLE_GRAMMAR_BUILD=1; + ZEE_DISABLE_GRAMMAR_BUILD = 1; cargoHash = "sha256-fBBjtjM7AnyAL6EOFstL4h6yS+UoLgxck6Mc0tJcXaI="; diff --git a/pkgs/applications/emulators/blink/default.nix b/pkgs/applications/emulators/blink/default.nix index 129bde2792c3c2..a65ebf5886b380 100644 --- a/pkgs/applications/emulators/blink/default.nix +++ b/pkgs/applications/emulators/blink/default.nix @@ -1,4 +1,8 @@ -{ stdenv, fetchFromGitHub, lib }: +{ + stdenv, + fetchFromGitHub, + lib, +}: stdenv.mkDerivation (finalAttrs: { pname = "blink"; diff --git a/pkgs/applications/emulators/cdemu/analyzer.nix b/pkgs/applications/emulators/cdemu/analyzer.nix index 09e5f4959bac28..e9065676e1476a 100644 --- a/pkgs/applications/emulators/cdemu/analyzer.nix +++ b/pkgs/applications/emulators/cdemu/analyzer.nix @@ -1,16 +1,49 @@ -{ cmake, pkg-config, callPackage, gobject-introspection, wrapGAppsHook3 -, python3Packages, libxml2, gnuplot, adwaita-icon-theme, gdk-pixbuf, intltool, libmirage }: +{ + cmake, + pkg-config, + callPackage, + gobject-introspection, + wrapGAppsHook3, + python3Packages, + libxml2, + gnuplot, + adwaita-icon-theme, + gdk-pixbuf, + intltool, + libmirage, +}: python3Packages.buildPythonApplication { - inherit (callPackage ./common-drv-attrs.nix { - version = "3.2.6"; - pname = "image-analyzer"; - hash = "sha256-7I8RUgd+k3cEzskJGbziv1f0/eo5QQXn62wGh/Y5ozc="; - }) pname version src meta; + inherit + (callPackage ./common-drv-attrs.nix { + version = "3.2.6"; + pname = "image-analyzer"; + hash = "sha256-7I8RUgd+k3cEzskJGbziv1f0/eo5QQXn62wGh/Y5ozc="; + }) + pname + version + src + meta + ; - buildInputs = [ libxml2 gnuplot libmirage adwaita-icon-theme gdk-pixbuf ]; - propagatedBuildInputs = with python3Packages; [ pygobject3 matplotlib ]; - nativeBuildInputs = [ cmake pkg-config wrapGAppsHook3 intltool gobject-introspection ]; + buildInputs = [ + libxml2 + gnuplot + libmirage + adwaita-icon-theme + gdk-pixbuf + ]; + propagatedBuildInputs = with python3Packages; [ + pygobject3 + matplotlib + ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapGAppsHook3 + intltool + gobject-introspection + ]; pyproject = false; dontWrapGApps = true; diff --git a/pkgs/applications/emulators/cdemu/client.nix b/pkgs/applications/emulators/cdemu/client.nix index 0a9c71cf6e14c9..afb68755775c89 100644 --- a/pkgs/applications/emulators/cdemu/client.nix +++ b/pkgs/applications/emulators/cdemu/client.nix @@ -1,14 +1,37 @@ -{ callPackage, python3Packages, cmake, pkg-config, intltool, wrapGAppsNoGuiHook, gobject-introspection }: +{ + callPackage, + python3Packages, + cmake, + pkg-config, + intltool, + wrapGAppsNoGuiHook, + gobject-introspection, +}: python3Packages.buildPythonApplication { - inherit (callPackage ./common-drv-attrs.nix { - version = "3.2.5"; - pname = "cdemu-client"; - hash = "sha256-py2F61v8vO0BCM18GCflAiD48deZjbMM6wqoCDZsOd8="; - }) pname version src meta; + inherit + (callPackage ./common-drv-attrs.nix { + version = "3.2.5"; + pname = "cdemu-client"; + hash = "sha256-py2F61v8vO0BCM18GCflAiD48deZjbMM6wqoCDZsOd8="; + }) + pname + version + src + meta + ; - nativeBuildInputs = [ cmake pkg-config intltool wrapGAppsNoGuiHook gobject-introspection ]; - propagatedBuildInputs = with python3Packages; [ dbus-python pygobject3 ]; + nativeBuildInputs = [ + cmake + pkg-config + intltool + wrapGAppsNoGuiHook + gobject-introspection + ]; + propagatedBuildInputs = with python3Packages; [ + dbus-python + pygobject3 + ]; pyproject = false; dontWrapGApps = true; diff --git a/pkgs/applications/emulators/cdemu/common-drv-attrs.nix b/pkgs/applications/emulators/cdemu/common-drv-attrs.nix index 2a99841eeed81e..f6dc006ad05611 100644 --- a/pkgs/applications/emulators/cdemu/common-drv-attrs.nix +++ b/pkgs/applications/emulators/cdemu/common-drv-attrs.nix @@ -1,5 +1,9 @@ -{ lib, fetchurl -, pname, version, hash +{ + lib, + fetchurl, + pname, + version, + hash, }: { diff --git a/pkgs/applications/emulators/cdemu/daemon.nix b/pkgs/applications/emulators/cdemu/daemon.nix index 0100ea5321d639..874b0522aa07f8 100644 --- a/pkgs/applications/emulators/cdemu/daemon.nix +++ b/pkgs/applications/emulators/cdemu/daemon.nix @@ -1,17 +1,41 @@ -{ stdenv, callPackage, cmake, pkg-config, glib, libao, intltool, libmirage, coreutils }: +{ + stdenv, + callPackage, + cmake, + pkg-config, + glib, + libao, + intltool, + libmirage, + coreutils, +}: let - inherit (callPackage ./common-drv-attrs.nix { - version = "3.2.7"; - pname = "cdemu-daemon"; - hash = "sha256-EKh2G6RA9Yq46BpTAqN2s6TpLJb8gwDuEpGiwdGcelc="; - }) pname version src meta; + inherit + (callPackage ./common-drv-attrs.nix { + version = "3.2.7"; + pname = "cdemu-daemon"; + hash = "sha256-EKh2G6RA9Yq46BpTAqN2s6TpLJb8gwDuEpGiwdGcelc="; + }) + pname + version + src + meta + ; in stdenv.mkDerivation { inherit pname version src; - nativeBuildInputs = [ cmake pkg-config intltool ]; - buildInputs = [ glib libao libmirage ]; + nativeBuildInputs = [ + cmake + pkg-config + intltool + ]; + buildInputs = [ + glib + libao + libmirage + ]; postInstall = '' mkdir -p $out/share/dbus-1/services cp -R ../service-example $out/share/cdemu diff --git a/pkgs/applications/emulators/cdemu/gui.nix b/pkgs/applications/emulators/cdemu/gui.nix index eb1d533c40f4ab..779f21ac2f20cb 100644 --- a/pkgs/applications/emulators/cdemu/gui.nix +++ b/pkgs/applications/emulators/cdemu/gui.nix @@ -1,15 +1,41 @@ -{ callPackage, cmake, pkg-config, wrapGAppsHook3, gobject-introspection -, python3Packages, libnotify, intltool, adwaita-icon-theme, gdk-pixbuf }: +{ + callPackage, + cmake, + pkg-config, + wrapGAppsHook3, + gobject-introspection, + python3Packages, + libnotify, + intltool, + adwaita-icon-theme, + gdk-pixbuf, +}: python3Packages.buildPythonApplication { - inherit (callPackage ./common-drv-attrs.nix { - version = "3.2.6"; - pname = "gcdemu"; - hash = "sha256-w4vzKoSotL5Cjfr4Cu4YhNSWXJqS+n/vySrwvbhR1zA="; - }) pname version src meta; + inherit + (callPackage ./common-drv-attrs.nix { + version = "3.2.6"; + pname = "gcdemu"; + hash = "sha256-w4vzKoSotL5Cjfr4Cu4YhNSWXJqS+n/vySrwvbhR1zA="; + }) + pname + version + src + meta + ; - nativeBuildInputs = [ cmake pkg-config wrapGAppsHook3 intltool gobject-introspection ]; - buildInputs = [ libnotify adwaita-icon-theme gdk-pixbuf ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapGAppsHook3 + intltool + gobject-introspection + ]; + buildInputs = [ + libnotify + adwaita-icon-theme + gdk-pixbuf + ]; propagatedBuildInputs = with python3Packages; [ pygobject3 ]; pyproject = false; diff --git a/pkgs/applications/emulators/cdemu/libmirage.nix b/pkgs/applications/emulators/cdemu/libmirage.nix index 2cad3672599788..8015093207c16a 100644 --- a/pkgs/applications/emulators/cdemu/libmirage.nix +++ b/pkgs/applications/emulators/cdemu/libmirage.nix @@ -1,22 +1,60 @@ -{ stdenv, callPackage, cmake, pkg-config, gobject-introspection -, glib, libsndfile, zlib, bzip2, xz, libsamplerate, intltool -, pcre, util-linux, libselinux, libsepol }: +{ + stdenv, + callPackage, + cmake, + pkg-config, + gobject-introspection, + glib, + libsndfile, + zlib, + bzip2, + xz, + libsamplerate, + intltool, + pcre, + util-linux, + libselinux, + libsepol, +}: let - inherit (callPackage ./common-drv-attrs.nix { - version = "3.2.9"; - pname = "libmirage"; - hash = "sha256-JBd+wHSZRyRW1SZsaAaRO2dNUFkpwRCr3s1f39KyWIs="; - }) pname version src meta; + inherit + (callPackage ./common-drv-attrs.nix { + version = "3.2.9"; + pname = "libmirage"; + hash = "sha256-JBd+wHSZRyRW1SZsaAaRO2dNUFkpwRCr3s1f39KyWIs="; + }) + pname + version + src + meta + ; in stdenv.mkDerivation { inherit pname version src; PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_GIRDIR = "${placeholder "out"}/share/gir-1.0"; PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_TYPELIBDIR = "${placeholder "out"}/lib/girepository-1.0"; - buildInputs = [ glib libsndfile zlib bzip2 xz libsamplerate ]; - nativeBuildInputs = [ cmake pkg-config intltool gobject-introspection ]; - propagatedBuildInputs = [ pcre util-linux libselinux libsepol ]; + buildInputs = [ + glib + libsndfile + zlib + bzip2 + xz + libsamplerate + ]; + nativeBuildInputs = [ + cmake + pkg-config + intltool + gobject-introspection + ]; + propagatedBuildInputs = [ + pcre + util-linux + libselinux + libsepol + ]; meta = { inherit (meta) diff --git a/pkgs/applications/emulators/cdemu/vhba.nix b/pkgs/applications/emulators/cdemu/vhba.nix index e1d251a763923c..4ab79810dc2ac3 100644 --- a/pkgs/applications/emulators/cdemu/vhba.nix +++ b/pkgs/applications/emulators/cdemu/vhba.nix @@ -1,15 +1,23 @@ -{ lib, stdenv, fetchurl, kernel }: +{ + lib, + stdenv, + fetchurl, + kernel, +}: stdenv.mkDerivation rec { pname = "vhba"; version = "20240917"; - src = fetchurl { + src = fetchurl { url = "mirror://sourceforge/cdemu/vhba-module-${version}.tar.xz"; hash = "sha256-zjTLriw2zvjX0Jxfa9QtaHG5tTC7cLTKEA+WSCP+Dpg="; }; - makeFlags = kernel.makeFlags ++ [ "KDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" "INSTALL_MOD_PATH=$(out)" ]; + makeFlags = kernel.makeFlags ++ [ + "KDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" + "INSTALL_MOD_PATH=$(out)" + ]; nativeBuildInputs = kernel.moduleBuildDependencies; meta = with lib; { diff --git a/pkgs/applications/emulators/dolphin-emu/primehack.nix b/pkgs/applications/emulators/dolphin-emu/primehack.nix index 9872a1bffdc72f..66200efda7202b 100644 --- a/pkgs/applications/emulators/dolphin-emu/primehack.nix +++ b/pkgs/applications/emulators/dolphin-emu/primehack.nix @@ -1,50 +1,51 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, cmake -, wrapQtAppsHook -, qtbase -, qtsvg -, bluez -, ffmpeg -, libao -, libGLU -, libGL -, pcre -, gettext -, libXrandr -, libusb1 -, libpthreadstubs -, libXext -, libXxf86vm -, libXinerama -, libSM -, libXdmcp -, readline -, openal -, udev -, libevdev -, portaudio -, curl -, alsa-lib -, miniupnpc -, enet -, mbedtls_2 -, soundtouch -, sfml -, fmt -, xz -, vulkan-loader -, libpulseaudio +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + wrapQtAppsHook, + qtbase, + qtsvg, + bluez, + ffmpeg, + libao, + libGLU, + libGL, + pcre, + gettext, + libXrandr, + libusb1, + libpthreadstubs, + libXext, + libXxf86vm, + libXinerama, + libSM, + libXdmcp, + readline, + openal, + udev, + libevdev, + portaudio, + curl, + alsa-lib, + miniupnpc, + enet, + mbedtls_2, + soundtouch, + sfml, + fmt, + xz, + vulkan-loader, + libpulseaudio, -# - Inputs used for Darwin -, CoreBluetooth -, ForceFeedback -, IOKit -, OpenGL -, libpng -, hidapi + # - Inputs used for Darwin + CoreBluetooth, + ForceFeedback, + IOKit, + OpenGL, + libpng, + hidapi, }: stdenv.mkDerivation rec { @@ -64,56 +65,61 @@ stdenv.mkDerivation rec { cmake ] ++ lib.optional stdenv.hostPlatform.isLinux wrapQtAppsHook; - buildInputs = [ - curl - ffmpeg - libao - libGLU - libGL - pcre - gettext - libpthreadstubs - libpulseaudio - libXrandr - libXext - libXxf86vm - libXinerama - libSM - readline - openal - libXdmcp - portaudio - libusb1 - libpng - hidapi - miniupnpc - enet - mbedtls_2 - soundtouch - sfml - fmt - xz - qtbase - qtsvg - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - bluez - udev - libevdev - alsa-lib - vulkan-loader - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreBluetooth - OpenGL - ForceFeedback - IOKit - ]; + buildInputs = + [ + curl + ffmpeg + libao + libGLU + libGL + pcre + gettext + libpthreadstubs + libpulseaudio + libXrandr + libXext + libXxf86vm + libXinerama + libSM + readline + openal + libXdmcp + portaudio + libusb1 + libpng + hidapi + miniupnpc + enet + mbedtls_2 + soundtouch + sfml + fmt + xz + qtbase + qtsvg + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + bluez + udev + libevdev + alsa-lib + vulkan-loader + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreBluetooth + OpenGL + ForceFeedback + IOKit + ]; - cmakeFlags = [ - "-DUSE_SHARED_ENET=ON" - "-DENABLE_LTO=ON" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DOSX_USE_DEFAULT_SEARCH_PATH=True" - ]; + cmakeFlags = + [ + "-DUSE_SHARED_ENET=ON" + "-DENABLE_LTO=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DOSX_USE_DEFAULT_SEARCH_PATH=True" + ]; qtWrapperArgs = lib.optionals stdenv.hostPlatform.isLinux [ "--prefix LD_LIBRARY_PATH : ${vulkan-loader}/lib" @@ -123,23 +129,27 @@ stdenv.mkDerivation rec { ]; # - Allow Dolphin to use nix-provided libraries instead of building them - postPatch = '' - substituteInPlace CMakeLists.txt --replace 'DISTRIBUTOR "None"' 'DISTRIBUTOR "NixOS"' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace CMakeLists.txt --replace 'if(NOT APPLE)' 'if(true)' - substituteInPlace CMakeLists.txt --replace 'if(LIBUSB_FOUND AND NOT APPLE)' 'if(LIBUSB_FOUND)' - ''; + postPatch = + '' + substituteInPlace CMakeLists.txt --replace 'DISTRIBUTOR "None"' 'DISTRIBUTOR "NixOS"' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace CMakeLists.txt --replace 'if(NOT APPLE)' 'if(true)' + substituteInPlace CMakeLists.txt --replace 'if(LIBUSB_FOUND AND NOT APPLE)' 'if(LIBUSB_FOUND)' + ''; - postInstall = '' - mv $out/bin/dolphin-emu $out/bin/dolphin-emu-primehack - mv $out/bin/dolphin-emu-nogui $out/bin/dolphin-emu-primehack-nogui - mv $out/share/applications/dolphin-emu.desktop $out/share/applications/dolphin-emu-primehack.desktop - mv $out/share/icons/hicolor/256x256/apps/dolphin-emu.png $out/share/icons/hicolor/256x256/apps/dolphin-emu-primehack.png - substituteInPlace $out/share/applications/dolphin-emu-primehack.desktop --replace 'dolphin-emu' 'dolphin-emu-primehack' - substituteInPlace $out/share/applications/dolphin-emu-primehack.desktop --replace 'Dolphin Emulator' 'PrimeHack' - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - install -D $src/Data/51-usb-device.rules $out/etc/udev/rules.d/51-usb-device.rules - ''; + postInstall = + '' + mv $out/bin/dolphin-emu $out/bin/dolphin-emu-primehack + mv $out/bin/dolphin-emu-nogui $out/bin/dolphin-emu-primehack-nogui + mv $out/share/applications/dolphin-emu.desktop $out/share/applications/dolphin-emu-primehack.desktop + mv $out/share/icons/hicolor/256x256/apps/dolphin-emu.png $out/share/icons/hicolor/256x256/apps/dolphin-emu-primehack.png + substituteInPlace $out/share/applications/dolphin-emu-primehack.desktop --replace 'dolphin-emu' 'dolphin-emu-primehack' + substituteInPlace $out/share/applications/dolphin-emu-primehack.desktop --replace 'Dolphin Emulator' 'PrimeHack' + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + install -D $src/Data/51-usb-device.rules $out/etc/udev/rules.d/51-usb-device.rules + ''; meta = with lib; { homepage = "https://github.com/shiiion/dolphin"; diff --git a/pkgs/applications/emulators/dosbox/default.nix b/pkgs/applications/emulators/dosbox/default.nix index cda07d42423cc0..f27d3e06adb591 100644 --- a/pkgs/applications/emulators/dosbox/default.nix +++ b/pkgs/applications/emulators/dosbox/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, autoreconfHook -, SDL -, SDL_net -, SDL_sound -, copyDesktopItems -, graphicsmagick -, libGL -, libGLU -, OpenGL -, libpng -, makeDesktopItem +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + SDL, + SDL_net, + SDL_sound, + copyDesktopItems, + graphicsmagick, + libGL, + libGLU, + OpenGL, + libpng, + makeDesktopItem, }: stdenv.mkDerivation rec { @@ -38,17 +39,24 @@ stdenv.mkDerivation rec { graphicsmagick ]; - buildInputs = [ - SDL - SDL_net - SDL_sound - libpng - ] ++ (if stdenv.hostPlatform.isDarwin then [ - OpenGL - ] else [ - libGL - libGLU - ]); + buildInputs = + [ + SDL + SDL_net + SDL_sound + libpng + ] + ++ ( + if stdenv.hostPlatform.isDarwin then + [ + OpenGL + ] + else + [ + libGL + libGLU + ] + ); # Tests for SDL_net.h for modem & IPX support, not automatically picked up due to being in SDL subdirectory env.NIX_CFLAGS_COMPILE = "-I${lib.getDev SDL_net}/include/SDL"; @@ -65,13 +73,16 @@ stdenv.mkDerivation rec { comment = "x86 dos emulator"; desktopName = "DOSBox"; genericName = "DOS emulator"; - categories = [ "Emulator" "Game" ]; + categories = [ + "Emulator" + "Game" + ]; }) ]; postInstall = '' - mkdir -p $out/share/icons/hicolor/256x256/apps - gm convert src/dosbox.ico $out/share/icons/hicolor/256x256/apps/dosbox.png + mkdir -p $out/share/icons/hicolor/256x256/apps + gm convert src/dosbox.ico $out/share/icons/hicolor/256x256/apps/dosbox.png ''; enableParallelBuilding = true; diff --git a/pkgs/applications/emulators/firebird-emu/default.nix b/pkgs/applications/emulators/firebird-emu/default.nix index 28d6c182c7606b..e0ff2b7c20a6d6 100644 --- a/pkgs/applications/emulators/firebird-emu/default.nix +++ b/pkgs/applications/emulators/firebird-emu/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, qmake -, qtbase -, qtdeclarative -, qtquickcontrols -, wrapQtAppsHook +{ + stdenv, + lib, + fetchFromGitHub, + qmake, + qtbase, + qtdeclarative, + qtquickcontrols, + wrapQtAppsHook, }: stdenv.mkDerivation rec { pname = "firebird-emu"; @@ -19,9 +20,16 @@ stdenv.mkDerivation rec { hash = "sha256-ZptjlnOiF+hKuKYvBFJL95H5YQuR99d4biOco/MVEmE="; }; - nativeBuildInputs = [ wrapQtAppsHook qmake ]; + nativeBuildInputs = [ + wrapQtAppsHook + qmake + ]; - buildInputs = [ qtbase qtdeclarative qtquickcontrols ]; + buildInputs = [ + qtbase + qtdeclarative + qtquickcontrols + ]; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' mkdir $out/Applications diff --git a/pkgs/applications/emulators/gens-gs/default.nix b/pkgs/applications/emulators/gens-gs/default.nix index 7665d324971a0e..c2b4751b5adb9a 100644 --- a/pkgs/applications/emulators/gens-gs/default.nix +++ b/pkgs/applications/emulators/gens-gs/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, pkg-config, gtk2, SDL, nasm, zlib, libpng, libGLU, libGL }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + SDL, + nasm, + zlib, + libpng, + libGLU, + libGL, +}: stdenv.mkDerivation rec { pname = "gens-gs"; @@ -10,7 +22,15 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk2 SDL nasm zlib libpng libGLU libGL ]; + buildInputs = [ + gtk2 + SDL + nasm + zlib + libpng + libGLU + libGL + ]; # Work around build failures on recent GTK. # See http://ubuntuforums.org/showthread.php?p=10535837 diff --git a/pkgs/applications/emulators/goldberg-emu/default.nix b/pkgs/applications/emulators/goldberg-emu/default.nix index e165a36b317b9e..e3100d497681c7 100644 --- a/pkgs/applications/emulators/goldberg-emu/default.nix +++ b/pkgs/applications/emulators/goldberg-emu/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitLab -, cmake -, protobuf - }: +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + protobuf, +}: stdenv.mkDerivation rec { pname = "goldberg-emu"; diff --git a/pkgs/applications/emulators/kega-fusion/default.nix b/pkgs/applications/emulators/kega-fusion/default.nix index 9bf359b88ccd02..e74e02d9e50683 100644 --- a/pkgs/applications/emulators/kega-fusion/default.nix +++ b/pkgs/applications/emulators/kega-fusion/default.nix @@ -1,9 +1,40 @@ -{ stdenv, lib, writeText, fetchurl, upx, libGL, libGLU, glib, gtk2, alsa-lib, libSM, libX11, gdk-pixbuf, pango, libXinerama, mpg123, runtimeShell }: +{ + stdenv, + lib, + writeText, + fetchurl, + upx, + libGL, + libGLU, + glib, + gtk2, + alsa-lib, + libSM, + libX11, + gdk-pixbuf, + pango, + libXinerama, + mpg123, + runtimeShell, +}: let - libPath = lib.makeLibraryPath [ stdenv.cc.cc libGL libGLU glib gtk2 alsa-lib libSM libX11 gdk-pixbuf pango libXinerama ]; - -in stdenv.mkDerivation { + libPath = lib.makeLibraryPath [ + stdenv.cc.cc + libGL + libGLU + glib + gtk2 + alsa-lib + libSM + libX11 + gdk-pixbuf + pango + libXinerama + ]; + +in +stdenv.mkDerivation { pname = "kega-fusion"; version = "3.63x"; diff --git a/pkgs/applications/emulators/mame/default.nix b/pkgs/applications/emulators/mame/default.nix index cb0f765c776d18..d4fe0df3679129 100644 --- a/pkgs/applications/emulators/mame/default.nix +++ b/pkgs/applications/emulators/mame/default.nix @@ -1,36 +1,37 @@ -{ lib -, stdenv -, fetchFromGitHub -, alsa-lib -, SDL2 -, SDL2_ttf -, copyDesktopItems -, expat -, flac -, fontconfig -, glm -, installShellFiles -, libXi -, libXinerama -, libjpeg -, libpcap -, libpulseaudio -, makeDesktopItem -, makeWrapper -, papirus-icon-theme -, pkg-config -, portaudio -, portmidi -, pugixml -, python3 -, qtbase -, rapidjson -, sqlite -, utf8proc -, which -, writeScript -, zlib -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + alsa-lib, + SDL2, + SDL2_ttf, + copyDesktopItems, + expat, + flac, + fontconfig, + glm, + installShellFiles, + libXi, + libXinerama, + libjpeg, + libpcap, + libpulseaudio, + makeDesktopItem, + makeWrapper, + papirus-icon-theme, + pkg-config, + portaudio, + portmidi, + pugixml, + python3, + qtbase, + rapidjson, + sqlite, + utf8proc, + which, + writeScript, + zlib, + darwin, }: let @@ -48,7 +49,10 @@ stdenv.mkDerivation rec { hash = "sha256-qD9xWP4KtPJWqje9QVb5wozgLTc+hE84kkEFM6Re+Sk="; }; - outputs = [ "out" "tools" ]; + outputs = [ + "out" + "tools" + ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" @@ -74,24 +78,35 @@ stdenv.mkDerivation rec { dontWrapQtApps = true; # https://docs.mamedev.org/initialsetup/compilingmame.html - buildInputs = [ - expat - zlib - flac - portmidi - portaudio - utf8proc - libjpeg - rapidjson - pugixml - glm - SDL2 - SDL2_ttf - sqlite - qtbase - ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ alsa-lib libpulseaudio libXinerama libXi fontconfig ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libpcap CoreAudioKit ForceFeedback ]; + buildInputs = + [ + expat + zlib + flac + portmidi + portaudio + utf8proc + libjpeg + rapidjson + pugixml + glm + SDL2 + SDL2_ttf + sqlite + qtbase + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + libpulseaudio + libXinerama + libXi + fontconfig + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libpcap + CoreAudioKit + ForceFeedback + ]; nativeBuildInputs = [ copyDesktopItems @@ -125,36 +140,45 @@ stdenv.mkDerivation rec { type = "Application"; genericName = "MAME is a multi-purpose emulation framework"; comment = "Play vintage games using the MAME emulator"; - categories = [ "Game" "Emulator" ]; - keywords = [ "Game" "Emulator" "Arcade" ]; + categories = [ + "Game" + "Emulator" + ]; + keywords = [ + "Game" + "Emulator" + "Arcade" + ]; }) ]; # TODO: copy shaders from src/osd/modules/opengl/shader/glsl*.*h # to the final package after we figure out how they work - installPhase = let - icon = "${papirus-icon-theme}/share/icons/Papirus/32x32/apps/mame.svg"; - in '' - runHook preInstall - - # mame - mkdir -p $out/opt/mame - - install -Dm755 mame -t $out/bin - install -Dm644 ${icon} $out/share/icons/hicolor/scalable/apps/mame.svg - installManPage docs/man/*.1 docs/man/*.6 - cp -ar {artwork,bgfx,plugins,language,ctrlr,keymaps,hash} $out/opt/mame - - # mame-tools - for _tool in castool chdman floptool imgtool jedutil ldresample ldverify \ - nltool nlwav pngcmp regrep romcmp split srcclean testkeys \ - unidasm; do - install -Dm755 $_tool -t $tools/bin - done - mv $tools/bin/{,mame-}split - - runHook postInstall - ''; + installPhase = + let + icon = "${papirus-icon-theme}/share/icons/Papirus/32x32/apps/mame.svg"; + in + '' + runHook preInstall + + # mame + mkdir -p $out/opt/mame + + install -Dm755 mame -t $out/bin + install -Dm644 ${icon} $out/share/icons/hicolor/scalable/apps/mame.svg + installManPage docs/man/*.1 docs/man/*.6 + cp -ar {artwork,bgfx,plugins,language,ctrlr,keymaps,hash} $out/opt/mame + + # mame-tools + for _tool in castool chdman floptool imgtool jedutil ldresample ldverify \ + nltool nlwav pngcmp regrep romcmp split srcclean testkeys \ + unidasm; do + install -Dm755 $_tool -t $tools/bin + done + mv $tools/bin/{,mame-}split + + runHook postInstall + ''; # man1 is the tools documentation, man6 is the emulator documentation # Need to be done in postFixup otherwise multi-output hook will move it back to $out @@ -192,7 +216,10 @@ stdenv.mkDerivation rec { focus. ''; changelog = "https://github.com/mamedev/mame/releases/download/mame${srcVersion}/whatsnew_${srcVersion}.txt"; - license = with licenses; [ bsd3 gpl2Plus ]; + license = with licenses; [ + bsd3 + gpl2Plus + ]; maintainers = with maintainers; [ thiagokokada ]; platforms = platforms.unix; broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/applications/emulators/punes/default.nix b/pkgs/applications/emulators/punes/default.nix index a7b435c3a0ae8c..f1d713e9f00870 100644 --- a/pkgs/applications/emulators/punes/default.nix +++ b/pkgs/applications/emulators/punes/default.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, gitUpdater -, cmake -, pkg-config -, ffmpeg -, libGLU -, alsa-lib -, libX11 -, libXrandr -, sndio -, qtbase -, qtsvg -, qttools -, wrapQtAppsHook +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + gitUpdater, + cmake, + pkg-config, + ffmpeg, + libGLU, + alsa-lib, + libX11, + libXrandr, + sndio, + qtbase, + qtsvg, + qttools, + wrapQtAppsHook, }: stdenv.mkDerivation (finalAttrs: { @@ -45,18 +46,21 @@ stdenv.mkDerivation (finalAttrs: { wrapQtAppsHook ]; - buildInputs = [ - ffmpeg - libGLU - qtbase - qtsvg - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - libX11 - libXrandr - ] ++ lib.optionals stdenv.hostPlatform.isBSD [ - sndio - ]; + buildInputs = + [ + ffmpeg + libGLU + qtbase + qtsvg + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + libX11 + libXrandr + ] + ++ lib.optionals stdenv.hostPlatform.isBSD [ + sndio + ]; cmakeFlags = [ "-DENABLE_GIT_INFO=OFF" diff --git a/pkgs/applications/emulators/ripes/default.nix b/pkgs/applications/emulators/ripes/default.nix index 312c25a020076b..61cc99cbc46c48 100644 --- a/pkgs/applications/emulators/ripes/default.nix +++ b/pkgs/applications/emulators/ripes/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, qtbase -, qtsvg -, qtcharts -, wrapQtAppsHook -, cmake -, python3 -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + qtbase, + qtsvg, + qtcharts, + wrapQtAppsHook, + cmake, + python3, + unstableGitUpdater, }: stdenv.mkDerivation rec { @@ -37,18 +38,22 @@ stdenv.mkDerivation rec { qtcharts ]; - installPhase = '' - runHook preInstall - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/Applications - cp -r Ripes.app $out/Applications/ - makeBinaryWrapper $out/Applications/Ripes.app/Contents/MacOS/Ripes $out/bin/Ripes - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - install -D Ripes $out/bin/Ripes - '' + '' - cp -r ${src}/appdir/usr/share $out/share - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/Applications + cp -r Ripes.app $out/Applications/ + makeBinaryWrapper $out/Applications/Ripes.app/Contents/MacOS/Ripes $out/bin/Ripes + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + install -D Ripes $out/bin/Ripes + '' + + '' + cp -r ${src}/appdir/usr/share $out/share + runHook postInstall + ''; passthru.updateScript = unstableGitUpdater { }; diff --git a/pkgs/applications/emulators/wibo/default.nix b/pkgs/applications/emulators/wibo/default.nix index 71ed31ff4bcb60..1909e6b0fb8dde 100644 --- a/pkgs/applications/emulators/wibo/default.nix +++ b/pkgs/applications/emulators/wibo/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchzip -, srcOnly -, cmake -, unzip +{ + lib, + stdenv, + fetchFromGitHub, + fetchzip, + srcOnly, + cmake, + unzip, }: stdenv.mkDerivation rec { @@ -25,20 +26,22 @@ stdenv.mkDerivation rec { doCheck = false; # Test step from https://github.com/decompals/wibo/blob/main/.github/workflows/ci.yml - checkPhase = let - gc = srcOnly { - name = "GC_WII_COMPILERS"; - src = fetchzip { - url = "https://files.decomp.dev/compilers_20230715.zip"; - hash = "sha256-IX3byvEUVJB6Rmc+NqO9ZNt1jl95nQpEIqxbHI+uUio="; - stripRoot = false; + checkPhase = + let + gc = srcOnly { + name = "GC_WII_COMPILERS"; + src = fetchzip { + url = "https://files.decomp.dev/compilers_20230715.zip"; + hash = "sha256-IX3byvEUVJB6Rmc+NqO9ZNt1jl95nQpEIqxbHI+uUio="; + stripRoot = false; + }; + meta.license = lib.licenses.unfree; }; - meta.license = lib.licenses.unfree; - }; - in lib.optionalString doCheck '' - MWCIncludes=../test ./wibo ${gc}/GC/2.7/mwcceppc.exe -c ../test/test.c - file test.o | grep "ELF 32-bit" - ''; + in + lib.optionalString doCheck '' + MWCIncludes=../test ./wibo ${gc}/GC/2.7/mwcceppc.exe -c ../test/test.c + file test.o | grep "ELF 32-bit" + ''; meta = with lib; { description = "Quick-and-dirty wrapper to run 32-bit windows EXEs on linux"; diff --git a/pkgs/applications/emulators/wine/default.nix b/pkgs/applications/emulators/wine/default.nix index 8f579c35184f7a..c39e373587ca72 100644 --- a/pkgs/applications/emulators/wine/default.nix +++ b/pkgs/applications/emulators/wine/default.nix @@ -6,7 +6,11 @@ # }; # Make additional configurations on demand: # wine.override { wineBuild = "wine32"; wineRelease = "staging"; }; -{ lib, stdenv, callPackage, darwin, +{ + lib, + stdenv, + callPackage, + darwin, wineRelease ? "stable", wineBuild ? if stdenv.hostPlatform.system == "x86_64-linux" then "wineWow" else "wine32", gettextSupport ? false, @@ -39,27 +43,55 @@ waylandSupport ? false, x11Support ? false, embedInstallers ? false, # The Mono and Gecko MSI installers - moltenvk # Allow users to override MoltenVK easily + moltenvk, # Allow users to override MoltenVK easily }: -let wine-build = build: release: - lib.getAttr build (callPackage ./packages.nix { +let + wine-build = + build: release: + lib.getAttr build ( + callPackage ./packages.nix { wineRelease = release; supportFlags = { inherit - alsaSupport cairoSupport cupsSupport cursesSupport dbusSupport - embedInstallers fontconfigSupport gettextSupport gphoto2Support - gstreamerSupport gtkSupport krb5Support mingwSupport netapiSupport - odbcSupport openclSupport openglSupport pcapSupport - pulseaudioSupport saneSupport sdlSupport tlsSupport udevSupport - usbSupport v4lSupport vaSupport vulkanSupport waylandSupport - x11Support xineramaSupport - ; + alsaSupport + cairoSupport + cupsSupport + cursesSupport + dbusSupport + embedInstallers + fontconfigSupport + gettextSupport + gphoto2Support + gstreamerSupport + gtkSupport + krb5Support + mingwSupport + netapiSupport + odbcSupport + openclSupport + openglSupport + pcapSupport + pulseaudioSupport + saneSupport + sdlSupport + tlsSupport + udevSupport + usbSupport + v4lSupport + vaSupport + vulkanSupport + waylandSupport + x11Support + xineramaSupport + ; }; inherit moltenvk; - }); + } + ); -in if wineRelease == "staging" then +in +if wineRelease == "staging" then callPackage ./staging.nix { wineUnstable = wine-build wineBuild "unstable"; } diff --git a/pkgs/applications/emulators/wine/fonts.nix b/pkgs/applications/emulators/wine/fonts.nix index 0ee1b3973d86c3..9620d51cb74e9b 100644 --- a/pkgs/applications/emulators/wine/fonts.nix +++ b/pkgs/applications/emulators/wine/fonts.nix @@ -1,5 +1,10 @@ -{ stdenv, lib, callPackage }: -let src = (callPackage ./sources.nix {}).stable; +{ + stdenv, + lib, + callPackage, +}: +let + src = (callPackage ./sources.nix { }).stable; in stdenv.mkDerivation { pname = "wine-fonts"; @@ -17,6 +22,11 @@ stdenv.mkDerivation { homepage = "https://wiki.winehq.org/Create_Fonts"; license = with lib.licenses; [ lgpl21Plus ]; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ avnik raskin bendlas johnazoidberg ]; + maintainers = with lib.maintainers; [ + avnik + raskin + bendlas + johnazoidberg + ]; }; } diff --git a/pkgs/applications/emulators/wine/packages.nix b/pkgs/applications/emulators/wine/packages.nix index b40f92dae81c76..3d87723f440419 100644 --- a/pkgs/applications/emulators/wine/packages.nix +++ b/pkgs/applications/emulators/wine/packages.nix @@ -1,57 +1,120 @@ -{ stdenv_32bit, lib, pkgs, pkgsi686Linux, pkgsCross, callPackage, substituteAll, moltenvk, +{ + stdenv_32bit, + lib, + pkgs, + pkgsi686Linux, + pkgsCross, + callPackage, + substituteAll, + moltenvk, wineRelease ? "stable", - supportFlags + supportFlags, }: let - src = lib.getAttr wineRelease (callPackage ./sources.nix {}); -in with src; { + src = lib.getAttr wineRelease (callPackage ./sources.nix { }); +in +with src; +{ wine32 = pkgsi686Linux.callPackage ./base.nix { pname = "wine"; - inherit src version supportFlags patches moltenvk wineRelease; + inherit + src + version + supportFlags + patches + moltenvk + wineRelease + ; pkgArches = [ pkgsi686Linux ]; geckos = [ gecko32 ]; mingwGccs = with pkgsCross; [ mingw32.buildPackages.gcc ]; - monos = [ mono ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + monos = [ mono ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; wine64 = callPackage ./base.nix { pname = "wine64"; - inherit src version supportFlags patches moltenvk wineRelease; + inherit + src + version + supportFlags + patches + moltenvk + wineRelease + ; pkgArches = [ pkgs ]; mingwGccs = with pkgsCross; [ mingwW64.buildPackages.gcc ]; geckos = [ gecko64 ]; - monos = [ mono ]; + monos = [ mono ]; configureFlags = [ "--enable-win64" ]; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; mainProgram = "wine64"; }; wineWow = callPackage ./base.nix { pname = "wine-wow"; - inherit src version supportFlags patches moltenvk wineRelease; + inherit + src + version + supportFlags + patches + moltenvk + wineRelease + ; stdenv = stdenv_32bit; - pkgArches = [ pkgs pkgsi686Linux ]; - geckos = [ gecko32 gecko64 ]; - mingwGccs = with pkgsCross; [ mingw32.buildPackages.gcc mingwW64.buildPackages.gcc ]; - monos = [ mono ]; + pkgArches = [ + pkgs + pkgsi686Linux + ]; + geckos = [ + gecko32 + gecko64 + ]; + mingwGccs = with pkgsCross; [ + mingw32.buildPackages.gcc + mingwW64.buildPackages.gcc + ]; + monos = [ mono ]; buildScript = substituteAll { - src = ./builder-wow.sh; - # pkgconfig has trouble picking the right architecture - pkgconfig64remove = lib.makeSearchPathOutput "dev" "lib/pkgconfig" [ pkgs.glib pkgs.gst_all_1.gstreamer ]; - }; + src = ./builder-wow.sh; + # pkgconfig has trouble picking the right architecture + pkgconfig64remove = lib.makeSearchPathOutput "dev" "lib/pkgconfig" [ + pkgs.glib + pkgs.gst_all_1.gstreamer + ]; + }; platforms = [ "x86_64-linux" ]; mainProgram = "wine64"; }; wineWow64 = callPackage ./base.nix { pname = "wine-wow64"; - inherit src version patches moltenvk wineRelease; - supportFlags = supportFlags // { mingwSupport = true; }; # Required because we request "--enable-archs=x86_64" + inherit + src + version + patches + moltenvk + wineRelease + ; + supportFlags = supportFlags // { + mingwSupport = true; + }; # Required because we request "--enable-archs=x86_64" pkgArches = [ pkgs ]; - mingwGccs = with pkgsCross; [ mingw32.buildPackages.gcc mingwW64.buildPackages.gcc ]; + mingwGccs = with pkgsCross; [ + mingw32.buildPackages.gcc + mingwW64.buildPackages.gcc + ]; geckos = [ gecko64 ]; - monos = [ mono ]; + monos = [ mono ]; configureFlags = [ "--enable-archs=x86_64,i386" ]; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; mainProgram = "wine"; }; } diff --git a/pkgs/applications/emulators/wine/staging.nix b/pkgs/applications/emulators/wine/staging.nix index 634964fb75330f..ed3fe3125067d1 100644 --- a/pkgs/applications/emulators/wine/staging.nix +++ b/pkgs/applications/emulators/wine/staging.nix @@ -1,24 +1,53 @@ -{ lib, stdenv, callPackage, autoconf, hexdump, perl, python3, wineUnstable, gitMinimal }: +{ + lib, + stdenv, + callPackage, + autoconf, + hexdump, + perl, + python3, + wineUnstable, + gitMinimal, +}: -with callPackage ./util.nix {}; +with callPackage ./util.nix { }; -let patch = (callPackage ./sources.nix {}).staging; - build-inputs = pkgNames: extra: - (mkBuildInputs wineUnstable.pkgArches pkgNames) ++ extra; -in assert lib.versions.majorMinor wineUnstable.version == lib.versions.majorMinor patch.version; +let + patch = (callPackage ./sources.nix { }).staging; + build-inputs = pkgNames: extra: (mkBuildInputs wineUnstable.pkgArches pkgNames) ++ extra; +in +assert lib.versions.majorMinor wineUnstable.version == lib.versions.majorMinor patch.version; (wineUnstable.override { wineRelease = "staging"; }).overrideAttrs (self: { - buildInputs = build-inputs ([ "perl" "autoconf" "gitMinimal" ] ++ lib.optional stdenv.hostPlatform.isLinux "util-linux") self.buildInputs; - nativeBuildInputs = [ autoconf hexdump perl python3 gitMinimal ] ++ self.nativeBuildInputs; + buildInputs = build-inputs ( + [ + "perl" + "autoconf" + "gitMinimal" + ] + ++ lib.optional stdenv.hostPlatform.isLinux "util-linux" + ) self.buildInputs; + nativeBuildInputs = [ + autoconf + hexdump + perl + python3 + gitMinimal + ] ++ self.nativeBuildInputs; - prePatch = self.prePatch or "" + '' - patchShebangs tools - cp -r ${patch}/patches ${patch}/staging . - chmod +w patches - patchShebangs ./patches/gitapply.sh - python3 ./staging/patchinstall.py DESTDIR="$PWD" --all ${lib.concatMapStringsSep " " (ps: "-W ${ps}") patch.disabledPatchsets} - ''; -}) // { + prePatch = + self.prePatch or "" + + '' + patchShebangs tools + cp -r ${patch}/patches ${patch}/staging . + chmod +w patches + patchShebangs ./patches/gitapply.sh + python3 ./staging/patchinstall.py DESTDIR="$PWD" --all ${ + lib.concatMapStringsSep " " (ps: "-W ${ps}") patch.disabledPatchsets + } + ''; +}) +// { meta = wineUnstable.meta // { description = wineUnstable.meta.description + " (with staging patches)"; }; diff --git a/pkgs/applications/emulators/wine/util.nix b/pkgs/applications/emulators/wine/util.nix index cd5bd03130b605..5eb27588f653aa 100644 --- a/pkgs/applications/emulators/wine/util.nix +++ b/pkgs/applications/emulators/wine/util.nix @@ -1,9 +1,6 @@ { lib }: rec { - toPackages = pkgNames: pkgs: - map (pn: lib.getAttr pn pkgs) pkgNames; - toBuildInputs = pkgArches: archPkgs: - lib.concatLists (map archPkgs pkgArches); - mkBuildInputs = pkgArches: pkgNames: - toBuildInputs pkgArches (toPackages pkgNames); + toPackages = pkgNames: pkgs: map (pn: lib.getAttr pn pkgs) pkgNames; + toBuildInputs = pkgArches: archPkgs: lib.concatLists (map archPkgs pkgArches); + mkBuildInputs = pkgArches: pkgNames: toBuildInputs pkgArches (toPackages pkgNames); } diff --git a/pkgs/applications/emulators/wine/winetricks.nix b/pkgs/applications/emulators/wine/winetricks.nix index b809a85a079b6c..dee2a107e9d2a5 100644 --- a/pkgs/applications/emulators/wine/winetricks.nix +++ b/pkgs/applications/emulators/wine/winetricks.nix @@ -1,17 +1,44 @@ -{ lib, stdenv, callPackage, perl, which, coreutils, zenity, curl -, cabextract, unzip, p7zip, gnused, gnugrep, bash } : +{ + lib, + stdenv, + callPackage, + perl, + which, + coreutils, + zenity, + curl, + cabextract, + unzip, + p7zip, + gnused, + gnugrep, + bash, +}: stdenv.mkDerivation rec { pname = "winetricks"; version = src.version; - src = (callPackage ./sources.nix {}).winetricks; + src = (callPackage ./sources.nix { }).winetricks; - buildInputs = [ perl which ]; + buildInputs = [ + perl + which + ]; # coreutils is for sha1sum pathAdd = lib.makeBinPath [ - perl which coreutils zenity curl cabextract unzip p7zip gnused gnugrep bash + perl + which + coreutils + zenity + curl + cabextract + unzip + p7zip + gnused + gnugrep + bash ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/applications/emulators/yabause/default.nix b/pkgs/applications/emulators/yabause/default.nix index 7623cc49efb9ae..1016d00fbaae55 100644 --- a/pkgs/applications/emulators/yabause/default.nix +++ b/pkgs/applications/emulators/yabause/default.nix @@ -1,5 +1,17 @@ -{ mkDerivation, lib, fetchurl, cmake, pkg-config, qtbase, qt5, libGLU, libGL -, libglut ? null, openal ? null, SDL2 ? null }: +{ + mkDerivation, + lib, + fetchurl, + cmake, + pkg-config, + qtbase, + qt5, + libGLU, + libGL, + libglut ? null, + openal ? null, + SDL2 ? null, +}: mkDerivation rec { pname = "yabause"; @@ -10,8 +22,19 @@ mkDerivation rec { sha256 = "1cn2rjjb7d9pkr4g5bqz55vd4pzyb7hg94cfmixjkzzkw0zw8d23"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ qtbase qt5.qtmultimedia libGLU libGL libglut openal SDL2 ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + qtbase + qt5.qtmultimedia + libGLU + libGL + libglut + openal + SDL2 + ]; patches = [ ./linkage-rwx-linux-elf.patch @@ -24,7 +47,7 @@ mkDerivation rec { "-DYAB_NETWORK=ON" "-DYAB_OPTIMIZED_DMA=ON" "-DYAB_PORTS=qt" - ] ; + ]; meta = with lib; { description = "Open-source Sega Saturn emulator"; diff --git a/pkgs/applications/emulators/zsnes/2.x.nix b/pkgs/applications/emulators/zsnes/2.x.nix index 4a446174a34d24..58e537c064ee4b 100644 --- a/pkgs/applications/emulators/zsnes/2.x.nix +++ b/pkgs/applications/emulators/zsnes/2.x.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL -, libGL -, libGLU -, libpng -, nasm -, pkg-config -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + SDL, + libGL, + libGLU, + libpng, + nasm, + pkg-config, + zlib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/emulators/zsnes/default.nix b/pkgs/applications/emulators/zsnes/default.nix index 98fed7058611c5..718ce9e371280c 100644 --- a/pkgs/applications/emulators/zsnes/default.nix +++ b/pkgs/applications/emulators/zsnes/default.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, nasm, SDL, zlib, libpng, ncurses, libGLU, libGL -, makeDesktopItem }: +{ + lib, + stdenv, + fetchFromGitHub, + nasm, + SDL, + zlib, + libpng, + ncurses, + libGLU, + libGL, + makeDesktopItem, +}: let desktopItem = makeDesktopItem { @@ -12,7 +23,8 @@ let categories = [ "Game" ]; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "zsnes"; version = "1.51"; @@ -28,7 +40,15 @@ in stdenv.mkDerivation { ./fortify3.patch ]; - buildInputs = [ nasm SDL zlib libpng ncurses libGLU libGL ]; + buildInputs = [ + nasm + SDL + zlib + libpng + ncurses + libGLU + libGL + ]; prePatch = '' for i in $(cat debian/patches/series); do @@ -69,7 +89,10 @@ in stdenv.mkDerivation { license = lib.licenses.gpl2Plus; maintainers = [ lib.maintainers.sander ]; homepage = "https://www.zsnes.com"; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; mainProgram = "zsnes"; }; } diff --git a/pkgs/applications/file-managers/dfilemanager/default.nix b/pkgs/applications/file-managers/dfilemanager/default.nix index 8a30535f646ee6..44f2675f18d691 100644 --- a/pkgs/applications/file-managers/dfilemanager/default.nix +++ b/pkgs/applications/file-managers/dfilemanager/default.nix @@ -1,4 +1,13 @@ -{ lib, mkDerivation, fetchFromGitHub, cmake, file, qtbase, qttools, solid }: +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + file, + qtbase, + qttools, + solid, +}: mkDerivation { pname = "dfilemanager"; @@ -12,7 +21,12 @@ mkDerivation { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ qtbase qttools file solid ]; + buildInputs = [ + qtbase + qttools + file + solid + ]; cmakeFlags = [ "-DQT5BUILD=true" ]; diff --git a/pkgs/applications/file-managers/krusader/default.nix b/pkgs/applications/file-managers/krusader/default.nix index 0df5ed386c43e4..e11d3f71af8930 100644 --- a/pkgs/applications/file-managers/krusader/default.nix +++ b/pkgs/applications/file-managers/krusader/default.nix @@ -1,16 +1,17 @@ -{ mkDerivation -, lib -, fetchurl -, extra-cmake-modules -, kdoctools -, wrapGAppsHook3 -, karchive -, kconfig -, kcrash -, kguiaddons -, kinit -, kparts -, kwindowsystem +{ + mkDerivation, + lib, + fetchurl, + extra-cmake-modules, + kdoctools, + wrapGAppsHook3, + karchive, + kconfig, + kcrash, + kguiaddons, + kinit, + kparts, + kwindowsystem, }: mkDerivation rec { diff --git a/pkgs/applications/file-managers/lf/ctpv.nix b/pkgs/applications/file-managers/lf/ctpv.nix index d1e4a6633730b7..257fd9cc666e80 100644 --- a/pkgs/applications/file-managers/lf/ctpv.nix +++ b/pkgs/applications/file-managers/lf/ctpv.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, file -, openssl -, atool -, bat -, chafa -, delta -, ffmpeg -, ffmpegthumbnailer -, fontforge -, glow -, imagemagick -, jq -, ueberzug +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + file, + openssl, + atool, + bat, + chafa, + delta, + ffmpeg, + ffmpegthumbnailer, + fontforge, + glow, + imagemagick, + jq, + ueberzug, }: stdenv.mkDerivation rec { @@ -39,19 +40,21 @@ stdenv.mkDerivation rec { preFixup = '' wrapProgram $out/bin/ctpv \ - --prefix PATH ":" "${lib.makeBinPath [ - atool # for archive files - bat - chafa # for image files on Wayland - delta # for diff files - ffmpeg - ffmpegthumbnailer - fontforge - glow # for markdown files - imagemagick - jq # for json files - ueberzug # for image files on X11 - ]}"; + --prefix PATH ":" "${ + lib.makeBinPath [ + atool # for archive files + bat + chafa # for image files on Wayland + delta # for diff files + ffmpeg + ffmpegthumbnailer + fontforge + glow # for markdown files + imagemagick + jq # for json files + ueberzug # for image files on X11 + ] + }"; ''; meta = with lib; { diff --git a/pkgs/applications/file-managers/lf/default.nix b/pkgs/applications/file-managers/lf/default.nix index 79975b988926b2..0426d0725ac002 100644 --- a/pkgs/applications/file-managers/lf/default.nix +++ b/pkgs/applications/file-managers/lf/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -20,7 +21,11 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - ldflags = [ "-s" "-w" "-X main.gVersion=r${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.gVersion=r${version}" + ]; # Force the use of the pure-go implementation of the os/user library. # Relevant issue: https://github.com/gokcehan/lf/issues/191 diff --git a/pkgs/applications/file-managers/mc/default.nix b/pkgs/applications/file-managers/mc/default.nix index 1644da02ed2fd2..80e929eb71600a 100644 --- a/pkgs/applications/file-managers/mc/default.nix +++ b/pkgs/applications/file-managers/mc/default.nix @@ -1,25 +1,28 @@ -{ lib, stdenv -, fetchurl -, buildPackages -, pkg-config -, glib -, gpm -, file -, e2fsprogs -, libICE -, perl -, zip -, unzip -, gettext -, slang -, libssh2 -, openssl -, coreutils -, autoSignDarwinBinariesHook -, x11Support ? true, libX11 +{ + lib, + stdenv, + fetchurl, + buildPackages, + pkg-config, + glib, + gpm, + file, + e2fsprogs, + libICE, + perl, + zip, + unzip, + gettext, + slang, + libssh2, + openssl, + coreutils, + autoSignDarwinBinariesHook, + x11Support ? true, + libX11, -# updater only -, writeScript + # updater only + writeScript, }: stdenv.mkDerivation rec { @@ -31,24 +34,33 @@ stdenv.mkDerivation rec { hash = "sha256-TdyD0e3pryNjs+q5h/VLh89mGTJBEM4tOg5wlE0TWf4="; }; - nativeBuildInputs = [ pkg-config unzip ] + nativeBuildInputs = + [ + pkg-config + unzip + ] # The preFixup hook rewrites the binary, which invaliates the code # signature. Add the fixup hook to sign the output. ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ autoSignDarwinBinariesHook ]; - buildInputs = [ - file - gettext - glib - libICE - libssh2 - openssl - slang - zip - ] ++ lib.optionals x11Support [ libX11 ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ e2fsprogs gpm ]; + buildInputs = + [ + file + gettext + glib + libICE + libssh2 + openssl + slang + zip + ] + ++ lib.optionals x11Support [ libX11 ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + e2fsprogs + gpm + ]; enableParallelBuilding = true; @@ -76,15 +88,15 @@ stdenv.mkDerivation rec { ''; passthru.updateScript = writeScript "update-mc" '' - #!/usr/bin/env nix-shell - #!nix-shell -i bash -p curl pcre common-updater-scripts + #!/usr/bin/env nix-shell + #!nix-shell -i bash -p curl pcre common-updater-scripts - set -eu -o pipefail + set -eu -o pipefail - # Expect the text in format of "Current version is: 4.8.27; ...". - new_version="$(curl -s https://midnight-commander.org/ | pcregrep -o1 'Current version is: (([0-9]+\.?)+);')" - update-source-version mc "$new_version" - ''; + # Expect the text in format of "Current version is: 4.8.27; ...". + new_version="$(curl -s https://midnight-commander.org/ | pcregrep -o1 'Current version is: (([0-9]+\.?)+);')" + update-source-version mc "$new_version" + ''; meta = with lib; { description = "File Manager and User Shell for the GNU Project, known as Midnight Commander"; diff --git a/pkgs/applications/file-managers/xfe/default.nix b/pkgs/applications/file-managers/xfe/default.nix index 0b09d6ea9ed58c..383ed13c9498cd 100644 --- a/pkgs/applications/file-managers/xfe/default.nix +++ b/pkgs/applications/file-managers/xfe/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, fox -, fontconfig -, freetype -, pkg-config -, gettext -, xcbutil -, gcc -, intltool -, file -, libpng -, xorg +{ + lib, + stdenv, + fetchurl, + fox, + fontconfig, + freetype, + pkg-config, + gettext, + xcbutil, + gcc, + intltool, + file, + libpng, + xorg, }: stdenv.mkDerivation rec { @@ -23,7 +24,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-6hNNda4BKCY9E02uFYJnt0JySNp/is1ZqjFlOwQcRWs="; }; - nativeBuildInputs = [ pkg-config intltool ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; buildInputs = [ fox gettext diff --git a/pkgs/applications/gis/grass/tests.nix b/pkgs/applications/gis/grass/tests.nix index 1a38d07de7891c..0a54bfaef83559 100644 --- a/pkgs/applications/gis/grass/tests.nix +++ b/pkgs/applications/gis/grass/tests.nix @@ -4,15 +4,14 @@ let inherit (grass) pname version; in -runCommand "${pname}-tests" { meta.timeout = 60; } - '' - HOME=$(mktemp -d) +runCommand "${pname}-tests" { meta.timeout = 60; } '' + HOME=$(mktemp -d) - ${grass}/bin/grass --tmp-location EPSG:3857 --exec g.version \ - | grep 'GRASS ${version}' + ${grass}/bin/grass --tmp-location EPSG:3857 --exec g.version \ + | grep 'GRASS ${version}' - ${grass}/bin/grass --tmp-location EPSG:3857 --exec g.mapset -l \ - | grep 'PERMANENT' + ${grass}/bin/grass --tmp-location EPSG:3857 --exec g.mapset -l \ + | grep 'PERMANENT' - touch $out - '' + touch $out +'' diff --git a/pkgs/applications/gis/qgis/default.nix b/pkgs/applications/gis/qgis/default.nix index d7a65bb7b7a424..29294726714ce1 100644 --- a/pkgs/applications/gis/qgis/default.nix +++ b/pkgs/applications/gis/qgis/default.nix @@ -1,15 +1,16 @@ -{ makeWrapper -, nixosTests -, symlinkJoin +{ + makeWrapper, + nixosTests, + symlinkJoin, -, extraPythonPackages ? (ps: [ ]) + extraPythonPackages ? (ps: [ ]), -, libsForQt5 + libsForQt5, -# unwrapped package parameters -, withGrass ? false -, withServer ? false -, withWebKit ? false + # unwrapped package parameters + withGrass ? false, + withServer ? false, + withWebKit ? false, }: let qgis-unwrapped = libsForQt5.callPackage ./unwrapped.nix { @@ -17,7 +18,8 @@ let withServer = withServer; withWebKit = withWebKit; }; -in symlinkJoin rec { +in +symlinkJoin rec { inherit (qgis-unwrapped) version; name = "qgis-${version}"; diff --git a/pkgs/applications/gis/qgis/ltr.nix b/pkgs/applications/gis/qgis/ltr.nix index 596347a97e3f2a..9d53d47af96c00 100644 --- a/pkgs/applications/gis/qgis/ltr.nix +++ b/pkgs/applications/gis/qgis/ltr.nix @@ -1,15 +1,16 @@ -{ makeWrapper -, nixosTests -, symlinkJoin +{ + makeWrapper, + nixosTests, + symlinkJoin, -, extraPythonPackages ? (ps: [ ]) + extraPythonPackages ? (ps: [ ]), -, libsForQt5 + libsForQt5, -# unwrapped package parameters -, withGrass ? false -, withServer ? false -, withWebKit ? false + # unwrapped package parameters + withGrass ? false, + withServer ? false, + withWebKit ? false, }: let qgis-ltr-unwrapped = libsForQt5.callPackage ./unwrapped-ltr.nix { @@ -17,7 +18,8 @@ let withServer = withServer; withWebKit = withWebKit; }; -in symlinkJoin rec { +in +symlinkJoin rec { inherit (qgis-ltr-unwrapped) version; name = "qgis-${version}"; @@ -30,7 +32,8 @@ in symlinkJoin rec { ]; # extend to add to the python environment of QGIS without rebuilding QGIS application. - pythonInputs = qgis-ltr-unwrapped.pythonBuildInputs ++ (extraPythonPackages qgis-ltr-unwrapped.py.pkgs); + pythonInputs = + qgis-ltr-unwrapped.pythonBuildInputs ++ (extraPythonPackages qgis-ltr-unwrapped.py.pkgs); postBuild = '' buildPythonPath "$pythonInputs" diff --git a/pkgs/applications/gis/qgis/unwrapped-ltr.nix b/pkgs/applications/gis/qgis/unwrapped-ltr.nix index 7ebf46bb840aba..6806ba5d41e4d4 100644 --- a/pkgs/applications/gis/qgis/unwrapped-ltr.nix +++ b/pkgs/applications/gis/qgis/unwrapped-ltr.nix @@ -1,51 +1,52 @@ -{ lib -, fetchFromGitHub -, makeWrapper -, mkDerivation -, substituteAll -, wrapGAppsHook3 -, wrapQtAppsHook - -, withGrass -, withServer -, withWebKit - -, bison -, cmake -, draco -, exiv2 -, fcgi -, flex -, geos -, grass -, gsl -, hdf5 -, libspatialindex -, libspatialite -, libzip -, netcdf -, ninja -, openssl -, pdal -, postgresql -, proj -, protobuf -, python3 -, qca-qt5 -, qscintilla -, qt3d -, qtbase -, qtkeychain -, qtlocation -, qtmultimedia -, qtsensors -, qtserialport -, qtwebkit -, qtxmlpatterns -, qwt -, sqlite -, txt2tags -, zstd +{ + lib, + fetchFromGitHub, + makeWrapper, + mkDerivation, + substituteAll, + wrapGAppsHook3, + wrapQtAppsHook, + + withGrass, + withServer, + withWebKit, + + bison, + cmake, + draco, + exiv2, + fcgi, + flex, + geos, + grass, + gsl, + hdf5, + libspatialindex, + libspatialite, + libzip, + netcdf, + ninja, + openssl, + pdal, + postgresql, + proj, + protobuf, + python3, + qca-qt5, + qscintilla, + qt3d, + qtbase, + qtkeychain, + qtlocation, + qtmultimedia, + qtsensors, + qtserialport, + qtwebkit, + qtxmlpatterns, + qwt, + sqlite, + txt2tags, + zstd, }: let @@ -79,7 +80,8 @@ let six urllib3 ]; -in mkDerivation rec { +in +mkDerivation rec { version = "3.34.13"; pname = "qgis-ltr-unwrapped"; @@ -106,37 +108,39 @@ in mkDerivation rec { ninja ]; - buildInputs = [ - draco - exiv2 - fcgi - geos - gsl - hdf5 - libspatialindex - libspatialite - libzip - netcdf - openssl - pdal - postgresql - proj - protobuf - qca-qt5 - qscintilla - qt3d - qtbase - qtkeychain - qtlocation - qtmultimedia - qtsensors - qtserialport - qtxmlpatterns - qwt - sqlite - txt2tags - zstd - ] ++ lib.optional withGrass grass + buildInputs = + [ + draco + exiv2 + fcgi + geos + gsl + hdf5 + libspatialindex + libspatialite + libzip + netcdf + openssl + pdal + postgresql + proj + protobuf + qca-qt5 + qscintilla + qt3d + qtbase + qtkeychain + qtlocation + qtmultimedia + qtsensors + qtserialport + qtxmlpatterns + qwt + sqlite + txt2tags + zstd + ] + ++ lib.optional withGrass grass ++ lib.optional withWebKit qtwebkit ++ pythonBuildInputs; @@ -150,20 +154,25 @@ in mkDerivation rec { # Add path to Qt platform plugins # (offscreen is needed by "${APIS_SRC_DIR}/generate_console_pap.py") - env.QT_QPA_PLATFORM_PLUGIN_PATH="${qtbase}/${qtbase.qtPluginPrefix}/platforms"; - - cmakeFlags = [ - "-DWITH_3D=True" - "-DWITH_PDAL=True" - "-DENABLE_TESTS=False" - ] ++ lib.optional (!withWebKit) "-DWITH_QTWEBKIT=OFF" + env.QT_QPA_PLATFORM_PLUGIN_PATH = "${qtbase}/${qtbase.qtPluginPrefix}/platforms"; + + cmakeFlags = + [ + "-DWITH_3D=True" + "-DWITH_PDAL=True" + "-DENABLE_TESTS=False" + ] + ++ lib.optional (!withWebKit) "-DWITH_QTWEBKIT=OFF" ++ lib.optional withServer [ - "-DWITH_SERVER=True" - "-DQGIS_CGIBIN_SUBDIR=${placeholder "out"}/lib/cgi-bin" - ] ++ lib.optional withGrass (let + "-DWITH_SERVER=True" + "-DQGIS_CGIBIN_SUBDIR=${placeholder "out"}/lib/cgi-bin" + ] + ++ lib.optional withGrass ( + let gmajor = lib.versions.major grass.version; gminor = lib.versions.minor grass.version; - in "-DGRASS_PREFIX${gmajor}=${grass}/grass${gmajor}${gminor}" + in + "-DGRASS_PREFIX${gmajor}=${grass}/grass${gmajor}${gminor}" ); qtWrapperArgs = [ diff --git a/pkgs/applications/gis/qmapshack/default.nix b/pkgs/applications/gis/qmapshack/default.nix index 4fca64f0dde5d2..de60afff3ffe17 100644 --- a/pkgs/applications/gis/qmapshack/default.nix +++ b/pkgs/applications/gis/qmapshack/default.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, cmake, wrapQtAppsHook -, qtscript, qtwebengine, gdal, proj, routino, quazip }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + wrapQtAppsHook, + qtscript, + qtwebengine, + gdal, + proj, + routino, + quazip, +}: stdenv.mkDerivation rec { pname = "qmapshack"; @@ -12,16 +23,31 @@ stdenv.mkDerivation rec { hash = "sha256-wqztKmaUxY3qd7IgPM7kV7x0BsrTMTX3DbcdM+lsarI="; }; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; - buildInputs = [ qtscript qtwebengine gdal proj routino quazip ]; + buildInputs = [ + qtscript + qtwebengine + gdal + proj + routino + quazip + ]; cmakeFlags = [ "-DROUTINO_XML_PATH=${routino}/share/routino" ]; qtWrapperArgs = [ - "--suffix PATH : ${lib.makeBinPath [ gdal routino ]}" + "--suffix PATH : ${ + lib.makeBinPath [ + gdal + routino + ] + }" ]; meta = with lib; { @@ -29,7 +55,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/Maproom/qmapshack"; changelog = "https://github.com/Maproom/qmapshack/blob/V_${version}/changelog.txt"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ dotlambda sikmir ]; + maintainers = with maintainers; [ + dotlambda + sikmir + ]; platforms = with platforms; linux; }; } diff --git a/pkgs/applications/gis/spatialite-gui/default.nix b/pkgs/applications/gis/spatialite-gui/default.nix index a8bdedabaa374e..c5257c9669a13f 100644 --- a/pkgs/applications/gis/spatialite-gui/default.nix +++ b/pkgs/applications/gis/spatialite-gui/default.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, desktopToDarwinBundle -, curl -, freexl -, geos -, librasterlite2 -, librttopo -, libspatialite -, libwebp -, libxlsxwriter -, libxml2 -, lz4 -, minizip -, openjpeg -, postgresql -, proj -, sqlite -, virtualpg -, wxGTK -, xz -, zstd -, Carbon -, Cocoa -, IOKit +{ + lib, + stdenv, + fetchurl, + pkg-config, + desktopToDarwinBundle, + curl, + freexl, + geos, + librasterlite2, + librttopo, + libspatialite, + libwebp, + libxlsxwriter, + libxml2, + lz4, + minizip, + openjpeg, + postgresql, + proj, + sqlite, + virtualpg, + wxGTK, + xz, + zstd, + Carbon, + Cocoa, + IOKit, }: stdenv.mkDerivation rec { @@ -36,30 +37,37 @@ stdenv.mkDerivation rec { hash = "sha256-ukjZbfGM68P/I/aXlyB64VgszmL0WWtpuuMAyjwj2zM="; }; - nativeBuildInputs = [ pkg-config ] - ++ lib.optional stdenv.hostPlatform.isDarwin desktopToDarwinBundle; + nativeBuildInputs = [ + pkg-config + ] ++ lib.optional stdenv.hostPlatform.isDarwin desktopToDarwinBundle; - buildInputs = [ - curl - freexl - geos - librasterlite2 - librttopo - libspatialite - libwebp - libxlsxwriter - libxml2 - lz4 - minizip - openjpeg - postgresql - proj - sqlite - virtualpg - wxGTK - xz - zstd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Carbon Cocoa IOKit ]; + buildInputs = + [ + curl + freexl + geos + librasterlite2 + librttopo + libspatialite + libwebp + libxlsxwriter + libxml2 + lz4 + minizip + openjpeg + postgresql + proj + sqlite + virtualpg + wxGTK + xz + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + Cocoa + IOKit + ]; enableParallelBuilding = true; diff --git a/pkgs/applications/gis/zombietrackergps/default.nix b/pkgs/applications/gis/zombietrackergps/default.nix index 762777bf8acf55..2cd1c823521fc3 100644 --- a/pkgs/applications/gis/zombietrackergps/default.nix +++ b/pkgs/applications/gis/zombietrackergps/default.nix @@ -55,7 +55,7 @@ mkDerivation rec { homepage = "https://www.zombietrackergps.net/ztgps/"; changelog = "https://www.zombietrackergps.net/ztgps/history.html"; license = licenses.gpl3Plus; - maintainers = with maintainers; [sohalt]; + maintainers = with maintainers; [ sohalt ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/graphics/ImageMagick/6.x.nix b/pkgs/applications/graphics/ImageMagick/6.x.nix index e0834055e71638..3dd69d56b19d10 100644 --- a/pkgs/applications/graphics/ImageMagick/6.x.nix +++ b/pkgs/applications/graphics/ImageMagick/6.x.nix @@ -1,37 +1,73 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, libtool -, bzip2Support ? true, bzip2 -, zlibSupport ? true, zlib -, libX11Support ? !stdenv.hostPlatform.isMinGW, libX11 -, libXtSupport ? !stdenv.hostPlatform.isMinGW, libXt -, fontconfigSupport ? true, fontconfig -, freetypeSupport ? true, freetype -, ghostscriptSupport ? false, ghostscript -, libjpegSupport ? true, libjpeg -, djvulibreSupport ? true, djvulibre -, lcms2Support ? true, lcms2 -, openexrSupport ? !stdenv.hostPlatform.isMinGW, openexr -, libpngSupport ? true, libpng -, liblqr1Support ? true, liblqr1 -, librsvgSupport ? !stdenv.hostPlatform.isMinGW, librsvg -, libtiffSupport ? true, libtiff -, libxml2Support ? true, libxml2 -, openjpegSupport ? !stdenv.hostPlatform.isMinGW, openjpeg -, libwebpSupport ? !stdenv.hostPlatform.isMinGW, libwebp -, libheifSupport ? true, libheif -, libde265Support ? true, libde265 -, fftw -, ApplicationServices, Foundation -, testers +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libtool, + bzip2Support ? true, + bzip2, + zlibSupport ? true, + zlib, + libX11Support ? !stdenv.hostPlatform.isMinGW, + libX11, + libXtSupport ? !stdenv.hostPlatform.isMinGW, + libXt, + fontconfigSupport ? true, + fontconfig, + freetypeSupport ? true, + freetype, + ghostscriptSupport ? false, + ghostscript, + libjpegSupport ? true, + libjpeg, + djvulibreSupport ? true, + djvulibre, + lcms2Support ? true, + lcms2, + openexrSupport ? !stdenv.hostPlatform.isMinGW, + openexr, + libpngSupport ? true, + libpng, + liblqr1Support ? true, + liblqr1, + librsvgSupport ? !stdenv.hostPlatform.isMinGW, + librsvg, + libtiffSupport ? true, + libtiff, + libxml2Support ? true, + libxml2, + openjpegSupport ? !stdenv.hostPlatform.isMinGW, + openjpeg, + libwebpSupport ? !stdenv.hostPlatform.isMinGW, + libwebp, + libheifSupport ? true, + libheif, + libde265Support ? true, + libde265, + fftw, + ApplicationServices, + Foundation, + testers, }: let arch = - if stdenv.hostPlatform.system == "i686-linux" then "i686" - else if stdenv.hostPlatform.system == "x86_64-linux" || stdenv.hostPlatform.system == "x86_64-darwin" then "x86-64" - else if stdenv.hostPlatform.system == "armv7l-linux" then "armv7l" - else if stdenv.hostPlatform.system == "aarch64-linux" || stdenv.hostPlatform.system == "aarch64-darwin" then "aarch64" - else if stdenv.hostPlatform.system == "powerpc64le-linux" then "ppc64le" - else null; + if stdenv.hostPlatform.system == "i686-linux" then + "i686" + else if + stdenv.hostPlatform.system == "x86_64-linux" || stdenv.hostPlatform.system == "x86_64-darwin" + then + "x86-64" + else if stdenv.hostPlatform.system == "armv7l-linux" then + "armv7l" + else if + stdenv.hostPlatform.system == "aarch64-linux" || stdenv.hostPlatform.system == "aarch64-darwin" + then + "aarch64" + else if stdenv.hostPlatform.system == "powerpc64le-linux" then + "ppc64le" + else + null; in stdenv.mkDerivation (finalAttrs: { @@ -45,26 +81,37 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-AdlJaCJOrN+NkkzzzgELtgAr5iZ9dvlVYVc7tYiM+R8="; }; - outputs = [ "out" "dev" "doc" ]; # bin/ isn't really big + outputs = [ + "out" + "dev" + "doc" + ]; # bin/ isn't really big outputMan = "out"; # it's tiny enableParallelBuilding = true; - configureFlags = [ - "--with-frozenpaths" - (lib.withFeatureAs (arch != null) "gcc-arch" arch) - (lib.withFeature librsvgSupport "rsvg") - (lib.withFeature liblqr1Support "lqr") - (lib.withFeatureAs ghostscriptSupport "gs-font-dir" "${ghostscript.fonts}/share/fonts") - (lib.withFeature ghostscriptSupport "gslib") - ] ++ lib.optionals stdenv.hostPlatform.isMinGW [ - # due to libxml2 being without DLLs ATM - "--enable-static" "--disable-shared" - ]; + configureFlags = + [ + "--with-frozenpaths" + (lib.withFeatureAs (arch != null) "gcc-arch" arch) + (lib.withFeature librsvgSupport "rsvg") + (lib.withFeature liblqr1Support "lqr") + (lib.withFeatureAs ghostscriptSupport "gs-font-dir" "${ghostscript.fonts}/share/fonts") + (lib.withFeature ghostscriptSupport "gslib") + ] + ++ lib.optionals stdenv.hostPlatform.isMinGW [ + # due to libxml2 being without DLLs ATM + "--enable-static" + "--disable-shared" + ]; - nativeBuildInputs = [ pkg-config libtool ]; + nativeBuildInputs = [ + pkg-config + libtool + ]; - buildInputs = [ ] + buildInputs = + [ ] ++ lib.optional zlibSupport zlib ++ lib.optional fontconfigSupport fontconfig ++ lib.optional ghostscriptSupport ghostscript @@ -83,7 +130,8 @@ stdenv.mkDerivation (finalAttrs: { Foundation ]; - propagatedBuildInputs = [ fftw ] + propagatedBuildInputs = + [ fftw ] ++ lib.optional bzip2Support bzip2 ++ lib.optional freetypeSupport freetype ++ lib.optional libjpegSupport libjpeg @@ -94,21 +142,23 @@ stdenv.mkDerivation (finalAttrs: { doCheck = false; # fails 2 out of 76 tests - postInstall = '' - (cd "$dev/include" && ln -s ImageMagick* ImageMagick) - moveToOutput "bin/*-config" "$dev" - moveToOutput "lib/ImageMagick-*/config-Q16" "$dev" # includes configure params - for file in "$dev"/bin/*-config; do - substituteInPlace "$file" --replace "${pkg-config}/bin/pkg-config -config" \ - ${pkg-config}/bin/${pkg-config.targetPrefix}pkg-config - substituteInPlace "$file" --replace ${pkg-config}/bin/pkg-config \ - "PKG_CONFIG_PATH='$dev/lib/pkgconfig' '${pkg-config}/bin/${pkg-config.targetPrefix}pkg-config'" - done - '' + lib.optionalString ghostscriptSupport '' - for la in $out/lib/*.la; do - sed 's|-lgs|-L${lib.getLib ghostscript}/lib -lgs|' -i $la - done - ''; + postInstall = + '' + (cd "$dev/include" && ln -s ImageMagick* ImageMagick) + moveToOutput "bin/*-config" "$dev" + moveToOutput "lib/ImageMagick-*/config-Q16" "$dev" # includes configure params + for file in "$dev"/bin/*-config; do + substituteInPlace "$file" --replace "${pkg-config}/bin/pkg-config -config" \ + ${pkg-config}/bin/${pkg-config.targetPrefix}pkg-config + substituteInPlace "$file" --replace ${pkg-config}/bin/pkg-config \ + "PKG_CONFIG_PATH='$dev/lib/pkgconfig' '${pkg-config}/bin/${pkg-config.targetPrefix}pkg-config'" + done + '' + + lib.optionalString ghostscriptSupport '' + for la in $out/lib/*.la; do + sed 's|-lgs|-L${lib.getLib ghostscript}/lib -lgs|' -i $la + done + ''; passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; @@ -116,7 +166,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://legacy.imagemagick.org/"; changelog = "https://legacy.imagemagick.org/script/changelog.php"; description = "Software suite to create, edit, compose, or convert bitmap images"; - pkgConfigModules = [ "ImageMagick" "MagickWand" ]; + pkgConfigModules = [ + "ImageMagick" + "MagickWand" + ]; platforms = platforms.linux ++ platforms.darwin; maintainers = [ ]; license = licenses.asl20; diff --git a/pkgs/applications/graphics/antimony/default.nix b/pkgs/applications/graphics/antimony/default.nix index b55e6a8a5bb006..4078f09d24eeca 100644 --- a/pkgs/applications/graphics/antimony/default.nix +++ b/pkgs/applications/graphics/antimony/default.nix @@ -1,71 +1,101 @@ -{ lib, stdenv, fetchFromGitHub, libpng, python3 -, libGLU, libGL, qtbase, wrapQtAppsHook, ncurses -, cmake, flex, lemon -, makeDesktopItem, copyDesktopItems +{ + lib, + stdenv, + fetchFromGitHub, + libpng, + python3, + libGLU, + libGL, + qtbase, + wrapQtAppsHook, + ncurses, + cmake, + flex, + lemon, + makeDesktopItem, + copyDesktopItems, }: let - gitRev = "8b805c674adad536f9dd552b4be75fadcb3c7db6"; + gitRev = "8b805c674adad536f9dd552b4be75fadcb3c7db6"; gitBranch = "develop"; - gitTag = "0.9.3"; + gitTag = "0.9.3"; in - stdenv.mkDerivation { - pname = "antimony"; - version = "2022-11-23"; +stdenv.mkDerivation { + pname = "antimony"; + version = "2022-11-23"; - src = fetchFromGitHub { - owner = "mkeeter"; - repo = "antimony"; - rev = gitRev; - sha256 = "NmOuBewfHqtAim2cNP62LXgRjVWuVUGweV46sY1qjGk="; - }; + src = fetchFromGitHub { + owner = "mkeeter"; + repo = "antimony"; + rev = gitRev; + sha256 = "NmOuBewfHqtAim2cNP62LXgRjVWuVUGweV46sY1qjGk="; + }; - patches = [ ./paths-fix.patch ]; + patches = [ ./paths-fix.patch ]; - postPatch = '' - sed -i "s,/usr/local,$out,g" \ - app/CMakeLists.txt app/app/app.cpp app/app/main.cpp - sed -i "s,python3,${python3.executable}," CMakeLists.txt - ''; + postPatch = '' + sed -i "s,/usr/local,$out,g" \ + app/CMakeLists.txt app/app/app.cpp app/app/main.cpp + sed -i "s,python3,${python3.executable}," CMakeLists.txt + ''; - postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' - install -Dm644 $src/deploy/icon.svg $out/share/icons/hicolor/scalable/apps/antimony.svg - install -Dm644 ${./mimetype.xml} $out/share/mime/packages/antimony.xml - ''; + postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' + install -Dm644 $src/deploy/icon.svg $out/share/icons/hicolor/scalable/apps/antimony.svg + install -Dm644 ${./mimetype.xml} $out/share/mime/packages/antimony.xml + ''; - buildInputs = [ - libpng python3 python3.pkgs.boost - libGLU libGL qtbase ncurses - ]; + buildInputs = [ + libpng + python3 + python3.pkgs.boost + libGLU + libGL + qtbase + ncurses + ]; - nativeBuildInputs = [ cmake flex lemon wrapQtAppsHook copyDesktopItems ]; + nativeBuildInputs = [ + cmake + flex + lemon + wrapQtAppsHook + copyDesktopItems + ]; - desktopItems = [ - (makeDesktopItem { - name = "antimony"; - desktopName = "Antimony"; - comment="Tree-based Modeler"; - genericName = "CAD Application"; - exec = "antimony %f"; - icon = "antimony"; - categories = [ "Graphics" "Science" "Engineering" ]; - mimeTypes = [ "application/x-extension-sb" "application/x-antimony" ]; - startupWMClass = "antimony"; - }) - ]; + desktopItems = [ + (makeDesktopItem { + name = "antimony"; + desktopName = "Antimony"; + comment = "Tree-based Modeler"; + genericName = "CAD Application"; + exec = "antimony %f"; + icon = "antimony"; + categories = [ + "Graphics" + "Science" + "Engineering" + ]; + mimeTypes = [ + "application/x-extension-sb" + "application/x-antimony" + ]; + startupWMClass = "antimony"; + }) + ]; - cmakeFlags= [ - "-DGITREV=${gitRev}" - "-DGITTAG=${gitTag}" - "-DGITBRANCH=${gitBranch}" - ]; + cmakeFlags = [ + "-DGITREV=${gitRev}" + "-DGITTAG=${gitTag}" + "-DGITBRANCH=${gitBranch}" + ]; - meta = with lib; { - description = "Computer-aided design (CAD) tool from a parallel universe"; - mainProgram = "antimony"; - homepage = "https://github.com/mkeeter/antimony"; - license = licenses.mit; - maintainers = with maintainers; [ rnhmjoj ]; - platforms = platforms.linux; - }; - } + meta = with lib; { + description = "Computer-aided design (CAD) tool from a parallel universe"; + mainProgram = "antimony"; + homepage = "https://github.com/mkeeter/antimony"; + license = licenses.mit; + maintainers = with maintainers; [ rnhmjoj ]; + platforms = platforms.linux; + }; +} diff --git a/pkgs/applications/graphics/apitrace/default.nix b/pkgs/applications/graphics/apitrace/default.nix index c6057ccc285b2a..0aa3f79b001dda 100644 --- a/pkgs/applications/graphics/apitrace/default.nix +++ b/pkgs/applications/graphics/apitrace/default.nix @@ -29,9 +29,21 @@ stdenv.mkDerivation rec { # LD_PRELOAD wrappers need to be statically linked to work against all kinds # of games -- so it's fine to use e.g. bundled snappy. - buildInputs = [ libX11 procps python3 libdwarf qtbase gtest brotli ]; + buildInputs = [ + libX11 + procps + python3 + libdwarf + qtbase + gtest + brotli + ]; - nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapQtAppsHook + ]; # Don't automatically wrap all binaries, I prefer to explicitly only wrap # `qapitrace`. @@ -68,7 +80,7 @@ stdenv.mkDerivation rec { for i in $out/bin/eglretrace $out/bin/glretrace do echo "Patching RPath for $i" - patchelf --set-rpath "${lib.makeLibraryPath [libglvnd]}:$(patchelf --print-rpath $i)" $i + patchelf --set-rpath "${lib.makeLibraryPath [ libglvnd ]}:$(patchelf --print-rpath $i)" $i done wrapQtApp $out/bin/qapitrace diff --git a/pkgs/applications/graphics/apngasm/2.nix b/pkgs/applications/graphics/apngasm/2.nix index f581f9dd12456a..7a7084cc17ce80 100644 --- a/pkgs/applications/graphics/apngasm/2.nix +++ b/pkgs/applications/graphics/apngasm/2.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchzip, libpng, zlib, zopfli }: +{ + lib, + stdenv, + fetchzip, + libpng, + zlib, + zopfli, +}: stdenv.mkDerivation rec { pname = "apngasm"; @@ -10,7 +17,11 @@ stdenv.mkDerivation rec { sha256 = "0qhljqql159xkn1l83vz0q8wvzr7rjz4jnhiy0zn36pgvacg0zn1"; }; - buildInputs = [ libpng zlib zopfli ]; + buildInputs = [ + libpng + zlib + zopfli + ]; postPatch = '' rm -rf libpng zlib zopfli diff --git a/pkgs/applications/graphics/apngasm/default.nix b/pkgs/applications/graphics/apngasm/default.nix index d75188b36dd614..f915d88d3f2a1f 100644 --- a/pkgs/applications/graphics/apngasm/default.nix +++ b/pkgs/applications/graphics/apngasm/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, boost, libpng, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + boost, + libpng, + zlib, +}: stdenv.mkDerivation rec { pname = "apngasm"; @@ -21,7 +30,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ boost libpng zlib ]; + buildInputs = [ + boost + libpng + zlib + ]; meta = with lib; { description = "Create an APNG from multiple PNG files"; diff --git a/pkgs/applications/graphics/awesomebump/default.nix b/pkgs/applications/graphics/awesomebump/default.nix index a096a14ec4f7d1..78028135186df2 100644 --- a/pkgs/applications/graphics/awesomebump/default.nix +++ b/pkgs/applications/graphics/awesomebump/default.nix @@ -1,5 +1,14 @@ -{ mkDerivation, lib, fetchgit, qtbase, qmake, qtscript, flex, bison, qtdeclarative }: - +{ + mkDerivation, + lib, + fetchgit, + qtbase, + qmake, + qtscript, + flex, + bison, + qtdeclarative, +}: let version = "5.1"; @@ -16,19 +25,32 @@ let inherit src; sourceRoot = "${src.name}/Sources/utils/QtnProperty"; patches = [ ./qtnproperty-parallel-building.patch ]; - buildInputs = [ qtscript qtbase qtdeclarative ]; - nativeBuildInputs = [ qmake flex bison ]; + buildInputs = [ + qtscript + qtbase + qtdeclarative + ]; + nativeBuildInputs = [ + qmake + flex + bison + ]; postInstall = '' install -D bin-linux/QtnPEG $out/bin/QtnPEG ''; }; -in mkDerivation { +in +mkDerivation { pname = "awesomebump"; inherit version; inherit src; - buildInputs = [ qtbase qtscript qtdeclarative ]; + buildInputs = [ + qtbase + qtscript + qtdeclarative + ]; nativeBuildInputs = [ qmake ]; diff --git a/pkgs/applications/graphics/cloudcompare/default.nix b/pkgs/applications/graphics/cloudcompare/default.nix index 738ce255a4cf77..39ca9122d13ada 100644 --- a/pkgs/applications/graphics/cloudcompare/default.nix +++ b/pkgs/applications/graphics/cloudcompare/default.nix @@ -1,24 +1,25 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, makeDesktopItem -, copyDesktopItems -, cmake -, boost -, cgal -, eigen -, flann -, gdal -, gmp -, laszip -, mpfr -, pcl -, qtbase -, qtsvg -, qttools -, tbb -, xercesc -, wrapGAppsHook3 +{ + lib, + mkDerivation, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + cmake, + boost, + cgal, + eigen, + flann, + gdal, + gmp, + laszip, + mpfr, + pcl, + qtbase, + qtsvg, + qttools, + tbb, + xercesc, + wrapGAppsHook3, }: mkDerivation rec { @@ -119,8 +120,15 @@ mkDerivation rec { comment = "3D point cloud and mesh processing software"; exec = "CloudCompare"; terminal = false; - categories = [ "Graphics" "3DGraphics" "Viewer" ]; - keywords = [ "3d" "processing" ]; + categories = [ + "Graphics" + "3DGraphics" + "Viewer" + ]; + keywords = [ + "3d" + "processing" + ]; icon = "CloudCompare"; }) (makeDesktopItem { @@ -129,8 +137,15 @@ mkDerivation rec { comment = "3D point cloud and mesh processing software"; exec = "ccViewer"; terminal = false; - categories = [ "Graphics" "3DGraphics" "Viewer" ]; - keywords = [ "3d" "viewer" ]; + categories = [ + "Graphics" + "3DGraphics" + "Viewer" + ]; + keywords = [ + "3d" + "viewer" + ]; icon = "ccViewer"; }) ]; diff --git a/pkgs/applications/graphics/comical/default.nix b/pkgs/applications/graphics/comical/default.nix index f25259e5ebf406..4fcbd1e98eeb62 100644 --- a/pkgs/applications/graphics/comical/default.nix +++ b/pkgs/applications/graphics/comical/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, hexdump -, wxGTK32 -, zlib -, Cocoa +{ + lib, + stdenv, + fetchurl, + hexdump, + wxGTK32, + zlib, + Cocoa, }: stdenv.mkDerivation rec { @@ -24,12 +25,14 @@ stdenv.mkDerivation rec { hexdump ]; - buildInputs = [ - wxGTK32 - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Cocoa - ]; + buildInputs = + [ + wxGTK32 + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + ]; makeFlags = [ "prefix=${placeholder "out"}" diff --git a/pkgs/applications/graphics/djview/default.nix b/pkgs/applications/graphics/djview/default.nix index 99af85a12b8d6f..e207d3c68373af 100644 --- a/pkgs/applications/graphics/djview/default.nix +++ b/pkgs/applications/graphics/djview/default.nix @@ -1,23 +1,28 @@ -{ lib, stdenv -, mkDerivation -, fetchurl -, autoconf -, automake -, libtool -, pkg-config -, djvulibre -, qtbase -, qttools -, xorg -, libtiff -, darwin +{ + lib, + stdenv, + mkDerivation, + fetchurl, + autoconf, + automake, + libtool, + pkg-config, + djvulibre, + qtbase, + qttools, + xorg, + libtiff, + darwin, }: mkDerivation rec { pname = "djview"; version = "4.12"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchurl { url = "mirror://sourceforge/djvu/${pname}-${version}.tar.gz"; diff --git a/pkgs/applications/graphics/drawio/default.nix b/pkgs/applications/graphics/drawio/default.nix index 2963624aaae17c..432ec2db9f7f31 100644 --- a/pkgs/applications/graphics/drawio/default.nix +++ b/pkgs/applications/graphics/drawio/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, makeDesktopItem -, copyDesktopItems -, fixup-yarn-lock -, makeWrapper -, autoSignDarwinBinariesHook -, nodejs -, yarn -, electron +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + makeDesktopItem, + copyDesktopItems, + fixup-yarn-lock, + makeWrapper, + autoSignDarwinBinariesHook, + nodejs, + yarn, + electron, }: stdenv.mkDerivation rec { @@ -34,16 +35,19 @@ stdenv.mkDerivation rec { hash = "sha256-bAvS7AXmmS+yYsEkXxvszlErpZ3J5hVVXxxzYcsVP5Y="; }; - nativeBuildInputs = [ - fixup-yarn-lock - makeWrapper - nodejs - yarn - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - copyDesktopItems - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - autoSignDarwinBinariesHook - ]; + nativeBuildInputs = + [ + fixup-yarn-lock + makeWrapper + nodejs + yarn + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + copyDesktopItems + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + autoSignDarwinBinariesHook + ]; ELECTRON_SKIP_BINARY_DOWNLOAD = true; @@ -59,46 +63,53 @@ stdenv.mkDerivation rec { runHook postConfigure ''; - buildPhase = '' - runHook preBuild - - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - cp -R ${electron.dist}/Electron.app Electron.app - chmod -R u+w Electron.app - export CSC_IDENTITY_AUTO_DISCOVERY=false - sed -i "/afterSign/d" electron-builder-linux-mac.json - '' + '' - yarn --offline run electron-builder --dir \ - ${lib.optionalString stdenv.hostPlatform.isDarwin "--config electron-builder-linux-mac.json"} \ - -c.electronDist=${if stdenv.hostPlatform.isDarwin then "." else electron.dist} \ - -c.electronVersion=${electron.version} - - runHook postBuild - ''; - - installPhase = '' - runHook preInstall - - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/{Applications,bin} - mv dist/mac*/draw.io.app $out/Applications - - # Symlinking `draw.io` doesn't work; seems to look for files in the wrong place. - makeWrapper $out/Applications/draw.io.app/Contents/MacOS/draw.io $out/bin/drawio - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - mkdir -p "$out/share/lib/drawio" - cp -r dist/*-unpacked/{locales,resources{,.pak}} "$out/share/lib/drawio" - - install -Dm644 build/icon.svg "$out/share/icons/hicolor/scalable/apps/drawio.svg" - - makeWrapper '${electron}/bin/electron' "$out/bin/drawio" \ - --add-flags "$out/share/lib/drawio/resources/app.asar" \ - --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" \ - --inherit-argv0 - '' + '' - - runHook postInstall - ''; + buildPhase = + '' + runHook preBuild + + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + cp -R ${electron.dist}/Electron.app Electron.app + chmod -R u+w Electron.app + export CSC_IDENTITY_AUTO_DISCOVERY=false + sed -i "/afterSign/d" electron-builder-linux-mac.json + '' + + '' + yarn --offline run electron-builder --dir \ + ${lib.optionalString stdenv.hostPlatform.isDarwin "--config electron-builder-linux-mac.json"} \ + -c.electronDist=${if stdenv.hostPlatform.isDarwin then "." else electron.dist} \ + -c.electronVersion=${electron.version} + + runHook postBuild + ''; + + installPhase = + '' + runHook preInstall + + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/{Applications,bin} + mv dist/mac*/draw.io.app $out/Applications + + # Symlinking `draw.io` doesn't work; seems to look for files in the wrong place. + makeWrapper $out/Applications/draw.io.app/Contents/MacOS/draw.io $out/bin/drawio + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + mkdir -p "$out/share/lib/drawio" + cp -r dist/*-unpacked/{locales,resources{,.pak}} "$out/share/lib/drawio" + + install -Dm644 build/icon.svg "$out/share/icons/hicolor/scalable/apps/drawio.svg" + + makeWrapper '${electron}/bin/electron' "$out/bin/drawio" \ + --add-flags "$out/share/lib/drawio/resources/app.asar" \ + --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" \ + --inherit-argv0 + '' + + '' + + runHook postInstall + ''; desktopItems = [ (makeDesktopItem { @@ -107,7 +118,10 @@ stdenv.mkDerivation rec { icon = "drawio"; desktopName = "drawio"; comment = "draw.io desktop"; - mimeTypes = [ "application/vnd.jgraph.mxfile" "application/vnd.visio" ]; + mimeTypes = [ + "application/vnd.jgraph.mxfile" + "application/vnd.visio" + ]; categories = [ "Graphics" ]; startupWMClass = "draw.io"; }) diff --git a/pkgs/applications/graphics/drawio/headless.nix b/pkgs/applications/graphics/drawio/headless.nix index a287c40c6801d0..b7880e791fa619 100644 --- a/pkgs/applications/graphics/drawio/headless.nix +++ b/pkgs/applications/graphics/drawio/headless.nix @@ -1,4 +1,10 @@ -{ lib, writeTextFile, runtimeShell, drawio, xvfb-run }: +{ + lib, + writeTextFile, + runtimeShell, + drawio, + xvfb-run, +}: writeTextFile { name = "${drawio.pname}-headless-${drawio.version}"; @@ -31,7 +37,10 @@ writeTextFile { Runs drawio under xvfb-run, with configuration going to a temporary directory. ''; - maintainers = with maintainers; [ qyliss tfc ]; + maintainers = with maintainers; [ + qyliss + tfc + ]; mainProgram = "drawio"; }; } diff --git a/pkgs/applications/graphics/drawpile/default.nix b/pkgs/applications/graphics/drawpile/default.nix index ad76e0e92b7ccd..b8a9339f5ecf0f 100644 --- a/pkgs/applications/graphics/drawpile/default.nix +++ b/pkgs/applications/graphics/drawpile/default.nix @@ -1,45 +1,47 @@ -{ stdenv -, lib -, mkDerivation -, fetchFromGitHub -, cargo -, extra-cmake-modules -, rustc -, rustPlatform +{ + stdenv, + lib, + mkDerivation, + fetchFromGitHub, + cargo, + extra-cmake-modules, + rustc, + rustPlatform, -# common deps -, karchive -, qtwebsockets + # common deps + karchive, + qtwebsockets, -# client deps -, qtbase -, qtkeychain -, qtmultimedia -, qtsvg -, qttools -, libsecret + # client deps + qtbase, + qtkeychain, + qtmultimedia, + qtsvg, + qttools, + libsecret, -# optional client deps -, giflib -, kdnssd -, libvpx -, miniupnpc + # optional client deps + giflib, + kdnssd, + libvpx, + miniupnpc, -# optional server deps -, libmicrohttpd -, libsodium -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, systemd ? null + # optional server deps + libmicrohttpd, + libsodium, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd ? null, -# options -, buildClient ? true -, buildServer ? true -, buildServerGui ? true # if false builds a headless server -, buildExtraTools ? false + # options + buildClient ? true, + buildServer ? true, + buildServerGui ? true, # if false builds a headless server + buildExtraTools ? false, }: -assert lib.assertMsg (buildClient || buildServer || buildExtraTools) - "You must specify at least one of buildClient, buildServer, or buildExtraTools."; +assert lib.assertMsg ( + buildClient || buildServer || buildExtraTools +) "You must specify at least one of buildClient, buildServer, or buildExtraTools."; let clientDeps = [ @@ -62,7 +64,8 @@ let libsodium # ext-auth support ] ++ lib.optional withSystemd systemd; -in mkDerivation rec { +in +mkDerivation rec { pname = "drawpile"; version = "2.2.1"; @@ -85,12 +88,13 @@ in mkDerivation rec { rustPlatform.cargoSetupHook ]; - buildInputs = [ - karchive - qtwebsockets - ] - ++ lib.optionals buildClient clientDeps - ++ lib.optionals buildServer serverDeps; + buildInputs = + [ + karchive + qtwebsockets + ] + ++ lib.optionals buildClient clientDeps + ++ lib.optionals buildServer serverDeps; cmakeFlags = [ (lib.cmakeFeature "INITSYS" (lib.optionalString withSystemd "systemd")) @@ -100,17 +104,20 @@ in mkDerivation rec { (lib.cmakeBool "TOOLS" buildExtraTools) ]; - meta = { - description = "Collaborative drawing program that allows multiple users to sketch on the same canvas simultaneously"; - homepage = "https://drawpile.net/"; - downloadPage = "https://drawpile.net/download/"; - license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ fgaz ]; - platforms = lib.platforms.unix; - broken = stdenv.hostPlatform.isDarwin; - } // lib.optionalAttrs buildServer { - mainProgram = "drawpile-srv"; - } // lib.optionalAttrs buildClient { - mainProgram = "drawpile"; - }; + meta = + { + description = "Collaborative drawing program that allows multiple users to sketch on the same canvas simultaneously"; + homepage = "https://drawpile.net/"; + downloadPage = "https://drawpile.net/download/"; + license = lib.licenses.gpl3Plus; + maintainers = with lib.maintainers; [ fgaz ]; + platforms = lib.platforms.unix; + broken = stdenv.hostPlatform.isDarwin; + } + // lib.optionalAttrs buildServer { + mainProgram = "drawpile-srv"; + } + // lib.optionalAttrs buildClient { + mainProgram = "drawpile"; + }; } diff --git a/pkgs/applications/graphics/emulsion/default.nix b/pkgs/applications/graphics/emulsion/default.nix index 0db2a75721ec0e..03032dd6074bf9 100644 --- a/pkgs/applications/graphics/emulsion/default.nix +++ b/pkgs/applications/graphics/emulsion/default.nix @@ -1,39 +1,42 @@ -{ stdenv -, lib -, fetchFromGitHub -, rustPlatform -, installShellFiles -, makeWrapper -, pkg-config -, python3 -, libGL -, libX11 -, libXcursor -, libXi -, libXrandr -, libXxf86vm -, libxcb -, libxkbcommon -, wayland -, AppKit -, CoreGraphics -, CoreServices -, Foundation -, OpenGL +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + installShellFiles, + makeWrapper, + pkg-config, + python3, + libGL, + libX11, + libXcursor, + libXi, + libXrandr, + libXxf86vm, + libxcb, + libxkbcommon, + wayland, + AppKit, + CoreGraphics, + CoreServices, + Foundation, + OpenGL, }: let - rpathLibs = [ - libGL - libX11 - libXcursor - libXi - libXrandr - libXxf86vm - libxcb - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libxkbcommon - wayland - ]; + rpathLibs = + [ + libGL + libX11 + libXcursor + libXi + libXrandr + libXxf86vm + libxcb + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libxkbcommon + wayland + ]; in rustPlatform.buildRustPackage rec { pname = "emulsion"; @@ -55,13 +58,15 @@ rustPlatform.buildRustPackage rec { python3 ]; - buildInputs = rpathLibs ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - CoreGraphics - CoreServices - Foundation - OpenGL - ]; + buildInputs = + rpathLibs + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + CoreGraphics + CoreServices + Foundation + OpenGL + ]; postFixup = lib.optionalString stdenv.hostPlatform.isLinux '' patchelf --set-rpath "${lib.makeLibraryPath rpathLibs}" $out/bin/emulsion diff --git a/pkgs/applications/graphics/epick/default.nix b/pkgs/applications/graphics/epick/default.nix index 939232197eeb35..a74e1c00181302 100644 --- a/pkgs/applications/graphics/epick/default.nix +++ b/pkgs/applications/graphics/epick/default.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, pkg-config -, expat -, fontconfig -, freetype -, libGL -, xorg -, AppKit +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + pkg-config, + expat, + fontconfig, + freetype, + libGL, + xorg, + AppKit, }: rustPlatform.buildRustPackage rec { @@ -28,17 +29,19 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - expat - fontconfig - freetype - xorg.libX11 - xorg.libXcursor - xorg.libXi - xorg.libXrandr - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + expat + fontconfig + freetype + xorg.libX11 + xorg.libXcursor + xorg.libXi + xorg.libXrandr + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + ]; postInstall = '' install -Dm444 assets/epick.desktop -t $out/share/applications diff --git a/pkgs/applications/graphics/evilpixie/default.nix b/pkgs/applications/graphics/evilpixie/default.nix index 9c5c7e81c3a766..0c7bb0023cbf19 100644 --- a/pkgs/applications/graphics/evilpixie/default.nix +++ b/pkgs/applications/graphics/evilpixie/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, wrapQtAppsHook -, qtbase -, libpng -, giflib -, libjpeg -, impy +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + wrapQtAppsHook, + qtbase, + libpng, + giflib, + libjpeg, + impy, }: stdenv.mkDerivation (finalAttrs: { @@ -48,8 +49,10 @@ stdenv.mkDerivation (finalAttrs: { platforms = platforms.all; # Undefined symbols for architecture x86_64: # "_bundle_path", referenced from: App::SetupPaths() in src_app.cpp.o - broken = stdenv.hostPlatform.isDarwin || - # https://github.com/bcampbell/evilpixie/issues/28 - stdenv.hostPlatform.isAarch64; + broken = + stdenv.hostPlatform.isDarwin + || + # https://github.com/bcampbell/evilpixie/issues/28 + stdenv.hostPlatform.isAarch64; }; }) diff --git a/pkgs/applications/graphics/feh/default.nix b/pkgs/applications/graphics/feh/default.nix index e7d144579afdfb..fcc62660dc0f45 100644 --- a/pkgs/applications/graphics/feh/default.nix +++ b/pkgs/applications/graphics/feh/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, xorg -, imlib2 -, libjpeg -, libpng -, curl -, libexif -, jpegexiforient -, perl -, enableAutoreload ? !stdenv.hostPlatform.isDarwin +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + xorg, + imlib2, + libjpeg, + libpng, + curl, + libexif, + jpegexiforient, + perl, + enableAutoreload ? !stdenv.hostPlatform.isDarwin, }: stdenv.mkDerivation (finalAttrs: { @@ -24,21 +25,41 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-FtaFoLjI3HTLAxRTucp5VDYS73UuWqw9r9UWKK6T+og="; }; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ xorg.libXt xorg.libX11 xorg.libXinerama imlib2 libjpeg libpng curl libexif ]; + buildInputs = [ + xorg.libXt + xorg.libX11 + xorg.libXinerama + imlib2 + libjpeg + libpng + curl + libexif + ]; - makeFlags = [ - "PREFIX=${placeholder "out"}" - "exif=1" - ] ++ lib.optional stdenv.hostPlatform.isDarwin "verscmp=0" - ++ lib.optional enableAutoreload "inotify=1"; + makeFlags = + [ + "PREFIX=${placeholder "out"}" + "exif=1" + ] + ++ lib.optional stdenv.hostPlatform.isDarwin "verscmp=0" + ++ lib.optional enableAutoreload "inotify=1"; installTargets = [ "install" ]; postInstall = '' - wrapProgram "$out/bin/feh" --prefix PATH : "${lib.makeBinPath [ libjpeg jpegexiforient ]}" \ + wrapProgram "$out/bin/feh" --prefix PATH : "${ + lib.makeBinPath [ + libjpeg + jpegexiforient + ] + }" \ --add-flags '--theme=feh' ''; @@ -51,7 +72,11 @@ stdenv.mkDerivation (finalAttrs: { # released under a variant of the MIT license # https://spdx.org/licenses/MIT-feh.html license = licenses.mit-feh; - maintainers = with maintainers; [ gepbird globin willibutz ]; + maintainers = with maintainers; [ + gepbird + globin + willibutz + ]; platforms = platforms.unix; mainProgram = "feh"; }; diff --git a/pkgs/applications/graphics/fontmatrix/default.nix b/pkgs/applications/graphics/fontmatrix/default.nix index 6945c3ac3ae42b..04f0ff9bf35883 100644 --- a/pkgs/applications/graphics/fontmatrix/default.nix +++ b/pkgs/applications/graphics/fontmatrix/default.nix @@ -1,9 +1,10 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, cmake -, qttools -, qtwebkit +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + qttools, + qtwebkit, }: mkDerivation rec { @@ -17,7 +18,10 @@ mkDerivation rec { sha256 = "sha256-DtajGhx79DiecglXHja9q/TKVq8Jl2faQdA5Ib/yT88="; }; - buildInputs = [ qttools qtwebkit ]; + buildInputs = [ + qttools + qtwebkit + ]; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/applications/graphics/foxotron/default.nix b/pkgs/applications/graphics/foxotron/default.nix index 1ccbc136c7c9c3..f25c1064a7acc0 100644 --- a/pkgs/applications/graphics/foxotron/default.nix +++ b/pkgs/applications/graphics/foxotron/default.nix @@ -1,27 +1,28 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, nix-update-script -, cmake -, pkg-config -, makeWrapper -, zlib -, libX11 -, libXrandr -, libXinerama -, libXcursor -, libXi -, libXext -, libGLU -, alsa-lib -, fontconfig -, AVFoundation -, Carbon -, Cocoa -, CoreAudio -, Kernel -, OpenGL +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + nix-update-script, + cmake, + pkg-config, + makeWrapper, + zlib, + libX11, + libXrandr, + libXinerama, + libXcursor, + libXi, + libXext, + libGLU, + alsa-lib, + fontconfig, + AVFoundation, + Carbon, + Cocoa, + CoreAudio, + Kernel, + OpenGL, }: stdenv.mkDerivation rec { @@ -56,11 +57,33 @@ stdenv.mkDerivation rec { --replace 'TARGET_COMPILE_OPTIONS(assimp PRIVATE -Werror)' "" ''; - nativeBuildInputs = [ cmake pkg-config makeWrapper ]; + nativeBuildInputs = [ + cmake + pkg-config + makeWrapper + ]; - buildInputs = [ zlib ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libX11 libXrandr libXinerama libXcursor libXi libXext alsa-lib fontconfig libGLU ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ AVFoundation Carbon Cocoa CoreAudio Kernel OpenGL ]; + buildInputs = + [ zlib ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libX11 + libXrandr + libXinerama + libXcursor + libXi + libXext + alsa-lib + fontconfig + libGLU + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AVFoundation + Carbon + Cocoa + CoreAudio + Kernel + OpenGL + ]; env.NIX_CFLAGS_COMPILE = toString [ # Needed with GCC 12 diff --git a/pkgs/applications/graphics/fstl/default.nix b/pkgs/applications/graphics/fstl/default.nix index f902776fb58b3c..68f55c84c57124 100644 --- a/pkgs/applications/graphics/fstl/default.nix +++ b/pkgs/applications/graphics/fstl/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, mkDerivation, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + mkDerivation, + cmake, +}: mkDerivation rec { pname = "fstl"; diff --git a/pkgs/applications/graphics/gimp/default.nix b/pkgs/applications/graphics/gimp/default.nix index e71cefc6ce06ca..9258defc289d55 100644 --- a/pkgs/applications/graphics/gimp/default.nix +++ b/pkgs/applications/graphics/gimp/default.nix @@ -1,65 +1,70 @@ -{ stdenv -, lib -, fetchurl -, substituteAll -, autoreconfHook -, pkg-config -, intltool -, babl -, gegl -, gtk2 -, glib -, gdk-pixbuf -, isocodes -, pango -, cairo -, freetype -, fontconfig -, lcms -, libpng -, libjpeg -, libjxl -, poppler -, poppler_data -, libtiff -, libmng -, librsvg -, libwmf -, zlib -, libzip -, ghostscript -, aalib -, shared-mime-info -, libexif -, gettext -, makeWrapper -, gtk-doc -, xorg -, glib-networking -, libmypaint -, gexiv2 -, harfbuzz -, mypaint-brushes1 -, libwebp -, libheif -, libxslt -, libgudev -, openexr -, desktopToDarwinBundle -, AppKit -, Cocoa -, gtk-mac-integration-gtk2 -, withPython ? false -, python2 +{ + stdenv, + lib, + fetchurl, + substituteAll, + autoreconfHook, + pkg-config, + intltool, + babl, + gegl, + gtk2, + glib, + gdk-pixbuf, + isocodes, + pango, + cairo, + freetype, + fontconfig, + lcms, + libpng, + libjpeg, + libjxl, + poppler, + poppler_data, + libtiff, + libmng, + librsvg, + libwmf, + zlib, + libzip, + ghostscript, + aalib, + shared-mime-info, + libexif, + gettext, + makeWrapper, + gtk-doc, + xorg, + glib-networking, + libmypaint, + gexiv2, + harfbuzz, + mypaint-brushes1, + libwebp, + libheif, + libxslt, + libgudev, + openexr, + desktopToDarwinBundle, + AppKit, + Cocoa, + gtk-mac-integration-gtk2, + withPython ? false, + python2, }: let python = python2.withPackages (pp: [ pp.pygtk ]); -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "gimp"; version = "2.10.38"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "http://download.gimp.org/pub/gimp/v${lib.versions.majorMinor finalAttrs.version}/gimp-${finalAttrs.version}.tar.bz2"; @@ -87,81 +92,89 @@ in stdenv.mkDerivation (finalAttrs: { ./force-enable-libheif.patch ]; - nativeBuildInputs = [ - autoreconfHook # hardcode-plugin-interpreters.patch changes Makefile.am - pkg-config - intltool - gettext - makeWrapper - gtk-doc - libxslt - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - desktopToDarwinBundle - ]; - - buildInputs = [ - babl - gegl - gtk2 - glib - gdk-pixbuf - pango - cairo - gexiv2 - harfbuzz - isocodes - freetype - fontconfig - lcms - libpng - libjpeg - libjxl - poppler - poppler_data - libtiff - openexr - libmng - librsvg - libwmf - zlib - libzip - ghostscript - aalib - shared-mime-info - libwebp - libheif - libexif - xorg.libXpm - glib-networking - libmypaint - mypaint-brushes1 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - Cocoa - gtk-mac-integration-gtk2 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libgudev - ] ++ lib.optionals withPython [ - python - # Duplicated here because python.withPackages does not expose the dev output with pkg-config files - python2.pkgs.pygtk - ]; + nativeBuildInputs = + [ + autoreconfHook # hardcode-plugin-interpreters.patch changes Makefile.am + pkg-config + intltool + gettext + makeWrapper + gtk-doc + libxslt + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + desktopToDarwinBundle + ]; + + buildInputs = + [ + babl + gegl + gtk2 + glib + gdk-pixbuf + pango + cairo + gexiv2 + harfbuzz + isocodes + freetype + fontconfig + lcms + libpng + libjpeg + libjxl + poppler + poppler_data + libtiff + openexr + libmng + librsvg + libwmf + zlib + libzip + ghostscript + aalib + shared-mime-info + libwebp + libheif + libexif + xorg.libXpm + glib-networking + libmypaint + mypaint-brushes1 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + Cocoa + gtk-mac-integration-gtk2 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libgudev + ] + ++ lib.optionals withPython [ + python + # Duplicated here because python.withPackages does not expose the dev output with pkg-config files + python2.pkgs.pygtk + ]; # needed by gimp-2.0.pc propagatedBuildInputs = [ gegl ]; - configureFlags = [ - "--without-webkit" # old version is required - "--disable-check-update" - "--with-bug-report-url=https://github.com/NixOS/nixpkgs/issues/new" - "--with-icc-directory=/run/current-system/sw/share/color/icc" - # fix libdir in pc files (${exec_prefix} needs to be passed verbatim) - "--libdir=\${exec_prefix}/lib" - ] ++ lib.optionals (!withPython) [ - "--disable-python" # depends on Python2 which was EOLed on 2020-01-01 - ]; + configureFlags = + [ + "--without-webkit" # old version is required + "--disable-check-update" + "--with-bug-report-url=https://github.com/NixOS/nixpkgs/issues/new" + "--with-icc-directory=/run/current-system/sw/share/color/icc" + # fix libdir in pc files (${exec_prefix} needs to be passed verbatim) + "--libdir=\${exec_prefix}/lib" + ] + ++ lib.optionals (!withPython) [ + "--disable-python" # depends on Python2 which was EOLed on 2020-01-01 + ]; enableParallelBuilding = true; diff --git a/pkgs/applications/graphics/gimp/plugins/default.nix b/pkgs/applications/graphics/gimp/plugins/default.nix index 04721df9197f9e..bf30838cc12b0f 100644 --- a/pkgs/applications/graphics/gimp/plugins/default.nix +++ b/pkgs/applications/graphics/gimp/plugins/default.nix @@ -5,370 +5,410 @@ { lib, pkgs }: let - inherit (pkgs) stdenv fetchurl fetchpatch fetchpatch2 pkg-config intltool glib fetchFromGitHub fetchFromGitLab; + inherit (pkgs) + stdenv + fetchurl + fetchpatch + fetchpatch2 + pkg-config + intltool + glib + fetchFromGitHub + fetchFromGitLab + ; in -lib.makeScope pkgs.newScope (self: - -let - # Use GIMP from the scope. - inherit (self) gimp; - - pluginDerivation = attrs: let - name = attrs.name or "${attrs.pname}-${attrs.version}"; - in stdenv.mkDerivation ({ - prePhases = [ "extraLib" ]; - extraLib = '' - installScripts(){ - mkdir -p $out/${gimp.targetScriptDir}/${name}; - for p in "$@"; do cp "$p" -r $out/${gimp.targetScriptDir}/${name}; done - } - installPlugin() { - # The base name of the first argument is the plug-in name and the main executable. - # GIMP only allows a single plug-in per directory: - # https://gitlab.gnome.org/GNOME/gimp/-/commit/efae55a73e98389e38fa0e59ebebcda0abe3ee96 - pluginDir=$out/${gimp.targetPluginDir}/$(basename "$1") - install -Dt "$pluginDir" "$@" - } - ''; - } - // attrs - // { - name = "${gimp.pname}-plugin-${name}"; - buildInputs = [ - gimp - gimp.gtk - glib - ] ++ (attrs.buildInputs or []); - - nativeBuildInputs = [ - pkg-config - intltool - ] ++ (attrs.nativeBuildInputs or []); - - # Override installation paths. - env = { - PKG_CONFIG_GIMP_2_0_GIMPLIBDIR = "${placeholder "out"}/${gimp.targetLibDir}"; - PKG_CONFIG_GIMP_2_0_GIMPDATADIR = "${placeholder "out"}/${gimp.targetDataDir}"; - } // attrs.env or { }; - }); - - scriptDerivation = {src, ...}@attrs : pluginDerivation ({ - prePhases = [ "extraLib" ]; - dontUnpack = true; - installPhase = '' - runHook preInstall - installScripts ${src} - runHook postInstall - ''; - } // attrs); -in -{ - # Allow overriding GIMP package in the scope. - inherit (pkgs) gimp; - - bimp = pluginDerivation rec { - /* menu: - File/Batch Image Manipulation... - */ - pname = "bimp"; - version = "2.6"; - - src = fetchFromGitHub { - owner = "alessandrofrancesconi"; - repo = "gimp-plugin-bimp"; - rev = "v${version}"; - hash = "sha256-IJ3+/9UwxJTRo0hUdzlOndOHwso1wGv7Q4UuhbsFkco="; - }; +lib.makeScope pkgs.newScope ( + self: + + let + # Use GIMP from the scope. + inherit (self) gimp; + + pluginDerivation = + attrs: + let + name = attrs.name or "${attrs.pname}-${attrs.version}"; + in + stdenv.mkDerivation ( + { + prePhases = [ "extraLib" ]; + extraLib = '' + installScripts(){ + mkdir -p $out/${gimp.targetScriptDir}/${name}; + for p in "$@"; do cp "$p" -r $out/${gimp.targetScriptDir}/${name}; done + } + installPlugin() { + # The base name of the first argument is the plug-in name and the main executable. + # GIMP only allows a single plug-in per directory: + # https://gitlab.gnome.org/GNOME/gimp/-/commit/efae55a73e98389e38fa0e59ebebcda0abe3ee96 + pluginDir=$out/${gimp.targetPluginDir}/$(basename "$1") + install -Dt "$pluginDir" "$@" + } + ''; + } + // attrs + // { + name = "${gimp.pname}-plugin-${name}"; + buildInputs = [ + gimp + gimp.gtk + glib + ] ++ (attrs.buildInputs or [ ]); + + nativeBuildInputs = [ + pkg-config + intltool + ] ++ (attrs.nativeBuildInputs or [ ]); + + # Override installation paths. + env = { + PKG_CONFIG_GIMP_2_0_GIMPLIBDIR = "${placeholder "out"}/${gimp.targetLibDir}"; + PKG_CONFIG_GIMP_2_0_GIMPDATADIR = "${placeholder "out"}/${gimp.targetDataDir}"; + } // attrs.env or { }; + } + ); + + scriptDerivation = + { src, ... }@attrs: + pluginDerivation ( + { + prePhases = [ "extraLib" ]; + dontUnpack = true; + installPhase = '' + runHook preInstall + installScripts ${src} + runHook postInstall + ''; + } + // attrs + ); + in + { + # Allow overriding GIMP package in the scope. + inherit (pkgs) gimp; + + bimp = pluginDerivation rec { + /* + menu: + File/Batch Image Manipulation... + */ + pname = "bimp"; + version = "2.6"; + + src = fetchFromGitHub { + owner = "alessandrofrancesconi"; + repo = "gimp-plugin-bimp"; + rev = "v${version}"; + hash = "sha256-IJ3+/9UwxJTRo0hUdzlOndOHwso1wGv7Q4UuhbsFkco="; + }; - patches = [ - # Allow overriding installation path - # https://github.com/alessandrofrancesconi/gimp-plugin-bimp/pull/311 - (fetchpatch { - url = "https://github.com/alessandrofrancesconi/gimp-plugin-bimp/commit/098edb5f70a151a3f377478fd6e0d08ed56b8ef7.patch"; - sha256 = "2Afx9fmdn6ztbsll2f2j7mfffMWYWyr4BuBy9ySV6vM="; - }) - ]; - - postPatch = '' - substituteInPlace Makefile \ - --replace-fail "gcc" "${stdenv.cc.targetPrefix}cc" - ''; - - nativeBuildInputs = with pkgs; [ which ]; - - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-error=incompatible-function-pointer-types" - ]); - - installFlags = [ - "SYSTEM_INSTALL_DIR=${placeholder "out"}/${gimp.targetPluginDir}/bimp" - ]; - - installTargets = [ "install-admin" ]; - - meta = with lib; { - description = "Batch Image Manipulation Plugin for GIMP"; - homepage = "https://github.com/alessandrofrancesconi/gimp-plugin-bimp"; - license = licenses.gpl2Plus; - maintainers = [ ]; - }; - }; - - gap = pluginDerivation { - /* menu: - Video - */ - pname = "gap"; - version = "2.6.0-unstable-2023-05-20"; - - src = fetchFromGitLab { - domain = "gitlab.gnome.org"; - owner = "Archive"; - repo = "gimp-gap"; - rev = "b2aa06cc7ee4ae1938f14640fe46b75ef5b15982"; - hash = "sha256-q5TgCy0+iIfxyqJRXsKxiFrWMFSzBqC0SA9MBGTHXcA="; + patches = [ + # Allow overriding installation path + # https://github.com/alessandrofrancesconi/gimp-plugin-bimp/pull/311 + (fetchpatch { + url = "https://github.com/alessandrofrancesconi/gimp-plugin-bimp/commit/098edb5f70a151a3f377478fd6e0d08ed56b8ef7.patch"; + sha256 = "2Afx9fmdn6ztbsll2f2j7mfffMWYWyr4BuBy9ySV6vM="; + }) + ]; + + postPatch = '' + substituteInPlace Makefile \ + --replace-fail "gcc" "${stdenv.cc.targetPrefix}cc" + ''; + + nativeBuildInputs = with pkgs; [ which ]; + + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-error=incompatible-function-pointer-types" + ] + ); + + installFlags = [ + "SYSTEM_INSTALL_DIR=${placeholder "out"}/${gimp.targetPluginDir}/bimp" + ]; + + installTargets = [ "install-admin" ]; + + meta = with lib; { + description = "Batch Image Manipulation Plugin for GIMP"; + homepage = "https://github.com/alessandrofrancesconi/gimp-plugin-bimp"; + license = licenses.gpl2Plus; + maintainers = [ ]; + }; }; - nativeBuildInputs = with pkgs; [autoreconfHook]; + gap = pluginDerivation { + /* + menu: + Video + */ + pname = "gap"; + version = "2.6.0-unstable-2023-05-20"; + + src = fetchFromGitLab { + domain = "gitlab.gnome.org"; + owner = "Archive"; + repo = "gimp-gap"; + rev = "b2aa06cc7ee4ae1938f14640fe46b75ef5b15982"; + hash = "sha256-q5TgCy0+iIfxyqJRXsKxiFrWMFSzBqC0SA9MBGTHXcA="; + }; - postUnpack = '' - tar -xf $sourceRoot/extern_libs/ffmpeg.tar.gz -C $sourceRoot/extern_libs - ''; + nativeBuildInputs = with pkgs; [ autoreconfHook ]; + + postUnpack = '' + tar -xf $sourceRoot/extern_libs/ffmpeg.tar.gz -C $sourceRoot/extern_libs + ''; + + postPatch = + let + ffmpegPatch = fetchpatch2 { + name = "fix-ffmpeg-binutil-2.41.patch"; + url = "https://git.ffmpeg.org/gitweb/ffmpeg.git/patch/effadce6c756247ea8bae32dc13bb3e6f464f0eb"; + hash = "sha256-vLSltvZVMcQ0CnkU0A29x6fJSywE8/aU+Mp9os8DZYY="; + }; + in + '' + patch -Np1 -i ${ffmpegPatch} -d extern_libs/ffmpeg + ffmpegSrc=$(realpath extern_libs/ffmpeg) + ''; + + configureFlags = + [ + "--with-ffmpegsrcdir=${placeholder "ffmpegSrc"}" + ] + ++ lib.optionals (!stdenv.hostPlatform.isx86) [ + "--disable-libavformat" + ]; + + hardeningDisable = [ "format" ]; + + env = { + NIX_LDFLAGS = "-lm"; + }; - postPatch = let - ffmpegPatch = fetchpatch2 { - name = "fix-ffmpeg-binutil-2.41.patch"; - url = "https://git.ffmpeg.org/gitweb/ffmpeg.git/patch/effadce6c756247ea8bae32dc13bb3e6f464f0eb"; - hash = "sha256-vLSltvZVMcQ0CnkU0A29x6fJSywE8/aU+Mp9os8DZYY="; + meta = with lib; { + description = "GIMP Animation Package"; + homepage = "https://www.gimp.org"; + # The main code is given in GPLv3, but it has ffmpeg in it, and I think ffmpeg license + # falls inside "free". + license = with licenses; [ + gpl3 + free + ]; + # Depends on linux/soundcard.h + platforms = platforms.linux; }; - in '' - patch -Np1 -i ${ffmpegPatch} -d extern_libs/ffmpeg - ffmpegSrc=$(realpath extern_libs/ffmpeg) - ''; + }; - configureFlags = [ - "--with-ffmpegsrcdir=${placeholder "ffmpegSrc"}" - ] ++ lib.optionals (!stdenv.hostPlatform.isx86) [ - "--disable-libavformat" - ]; + farbfeld = pluginDerivation { + pname = "farbfeld"; + version = "unstable-2019-08-12"; - hardeningDisable = [ "format" ]; + src = fetchFromGitHub { + owner = "ids1024"; + repo = "gimp-farbfeld"; + rev = "5feacebf61448bd3c550dda03cd08130fddc5af4"; + sha256 = "1vmw7k773vrndmfffj0m503digdjmkpcqy2r3p3i5x0qw9vkkkc6"; + }; - env = { - NIX_LDFLAGS = "-lm"; - }; + installPhase = '' + installPlugin farbfeld + ''; - meta = with lib; { - description = "GIMP Animation Package"; - homepage = "https://www.gimp.org"; - # The main code is given in GPLv3, but it has ffmpeg in it, and I think ffmpeg license - # falls inside "free". - license = with licenses; [ gpl3 free ]; - # Depends on linux/soundcard.h - platforms = platforms.linux; + meta = { + description = "Gimp plug-in for the farbfeld image format"; + homepage = "https://github.com/ids1024/gimp-farbfeld"; + license = lib.licenses.mit; + maintainers = with lib.maintainers; [ sikmir ]; + }; }; - }; - farbfeld = pluginDerivation { - pname = "farbfeld"; - version = "unstable-2019-08-12"; - - src = fetchFromGitHub { - owner = "ids1024"; - repo = "gimp-farbfeld"; - rev = "5feacebf61448bd3c550dda03cd08130fddc5af4"; - sha256 = "1vmw7k773vrndmfffj0m503digdjmkpcqy2r3p3i5x0qw9vkkkc6"; - }; + fourier = pluginDerivation rec { + /* + menu: + Filters/Generic/FFT Forward + Filters/Generic/FFT Inverse + */ + pname = "fourier"; + version = "0.4.3"; + + src = fetchurl { + url = "https://www.lprp.fr/files/old-web/soft/gimp/${pname}-${version}.tar.gz"; + sha256 = "0mf7f8vaqs2madx832x3kcxw3hv3w3wampvzvaps1mkf2kvrjbsn"; + }; - installPhase = '' - installPlugin farbfeld - ''; + buildInputs = with pkgs; [ fftw ]; - meta = { - description = "Gimp plug-in for the farbfeld image format"; - homepage = "https://github.com/ids1024/gimp-farbfeld"; - license = lib.licenses.mit; - maintainers = with lib.maintainers; [ sikmir ]; - }; - }; - - fourier = pluginDerivation rec { - /* menu: - Filters/Generic/FFT Forward - Filters/Generic/FFT Inverse - */ - pname = "fourier"; - version = "0.4.3"; - - src = fetchurl { - url = "https://www.lprp.fr/files/old-web/soft/gimp/${pname}-${version}.tar.gz"; - sha256 = "0mf7f8vaqs2madx832x3kcxw3hv3w3wampvzvaps1mkf2kvrjbsn"; - }; + postPatch = '' + substituteInPlace Makefile --replace '$(GCC)' '$(CC)' - buildInputs = with pkgs; [ fftw ]; + # The tarball contains a prebuilt binary. + make clean + ''; - postPatch = '' - substituteInPlace Makefile --replace '$(GCC)' '$(CC)' + installPhase = '' + runHook preInstall - # The tarball contains a prebuilt binary. - make clean - ''; + installPlugin fourier - installPhase = '' - runHook preInstall + runHook postInstall + ''; - installPlugin fourier + meta = with lib; { + description = "GIMP plug-in to do the fourier transform"; + homepage = "https://people.via.ecp.fr/~remi/soft/gimp/gimp_plugin_en.php3#fourier"; + license = with licenses; [ gpl3Plus ]; + }; + }; - runHook postInstall - ''; + resynthesizer = pluginDerivation rec { + /* + menu: + Edit/Fill with pattern seamless... + Filters/Enhance/Heal selection... + Filters/Enhance/Heal transparency... + Filters/Enhance/Sharpen by synthesis... + Filters/Enhance/Uncrop... + Filters/Map/Style... + Filters/Render/Texture... + */ + pname = "resynthesizer"; + version = "2.0.3"; + buildInputs = with pkgs; [ fftw ]; + nativeBuildInputs = with pkgs; [ autoreconfHook ]; + makeFlags = [ "GIMP_LIBDIR=${placeholder "out"}/${gimp.targetLibDir}" ]; + src = fetchFromGitHub { + owner = "bootchk"; + repo = "resynthesizer"; + rev = "v${version}"; + sha256 = "1jwc8bhhm21xhrgw56nzbma6fwg59gc8anlmyns7jdiw83y0zx3j"; + }; - meta = with lib; { - description = "GIMP plug-in to do the fourier transform"; - homepage = "https://people.via.ecp.fr/~remi/soft/gimp/gimp_plugin_en.php3#fourier"; - license = with licenses; [ gpl3Plus ]; - }; - }; - - resynthesizer = pluginDerivation rec { - /* menu: - Edit/Fill with pattern seamless... - Filters/Enhance/Heal selection... - Filters/Enhance/Heal transparency... - Filters/Enhance/Sharpen by synthesis... - Filters/Enhance/Uncrop... - Filters/Map/Style... - Filters/Render/Texture... - */ - pname = "resynthesizer"; - version = "2.0.3"; - buildInputs = with pkgs; [ fftw ]; - nativeBuildInputs = with pkgs; [ autoreconfHook ]; - makeFlags = [ "GIMP_LIBDIR=${placeholder "out"}/${gimp.targetLibDir}" ]; - src = fetchFromGitHub { - owner = "bootchk"; - repo = "resynthesizer"; - rev = "v${version}"; - sha256 = "1jwc8bhhm21xhrgw56nzbma6fwg59gc8anlmyns7jdiw83y0zx3j"; + meta = { + broken = !gimp.python2Support; + }; }; - meta = { - broken = !gimp.python2Support; - }; - }; - - texturize = pluginDerivation { - pname = "texturize"; - version = "2.2+unstable=2021-12-03"; - src = fetchFromGitHub { - owner = "lmanul"; - repo = "gimp-texturize"; - rev = "9ceff0d411cda018108e5477320669b8d00d811e"; - sha256 = "haYS0K3oAPlHtHB8phOCX5/gtWq9uiVQhG5ZhAFX0t0="; - }; - nativeBuildInputs = with pkgs; [ - meson - ninja - gettext - ]; - }; - - waveletSharpen = pluginDerivation { - /* menu: - Filters/Enhance/Wavelet sharpen - */ - pname = "wavelet-sharpen"; - version = "0.1.2"; - - src = fetchurl { - url = "https://github.com/pixlsus/registry.gimp.org_static/raw/master/registry.gimp.org/files/wavelet-sharpen-0.1.2.tar.gz"; - sha256 = "0vql1k67i21g5ivaa1jh56rg427m0icrkpryrhg75nscpirfxxqw"; + texturize = pluginDerivation { + pname = "texturize"; + version = "2.2+unstable=2021-12-03"; + src = fetchFromGitHub { + owner = "lmanul"; + repo = "gimp-texturize"; + rev = "9ceff0d411cda018108e5477320669b8d00d811e"; + sha256 = "haYS0K3oAPlHtHB8phOCX5/gtWq9uiVQhG5ZhAFX0t0="; + }; + nativeBuildInputs = with pkgs; [ + meson + ninja + gettext + ]; }; - env = { - # Workaround build failure on -fno-common toolchains like upstream - # gcc-10. Otherwise build fails as: - # ld: interface.o:(.bss+0xe0): multiple definition of `fimg'; plugin.o:(.bss+0x40): first defined here - NIX_CFLAGS_COMPILE = "-fcommon"; - NIX_LDFLAGS = "-lm"; + waveletSharpen = pluginDerivation { + /* + menu: + Filters/Enhance/Wavelet sharpen + */ + pname = "wavelet-sharpen"; + version = "0.1.2"; + + src = fetchurl { + url = "https://github.com/pixlsus/registry.gimp.org_static/raw/master/registry.gimp.org/files/wavelet-sharpen-0.1.2.tar.gz"; + sha256 = "0vql1k67i21g5ivaa1jh56rg427m0icrkpryrhg75nscpirfxxqw"; + }; + + env = { + # Workaround build failure on -fno-common toolchains like upstream + # gcc-10. Otherwise build fails as: + # ld: interface.o:(.bss+0xe0): multiple definition of `fimg'; plugin.o:(.bss+0x40): first defined here + NIX_CFLAGS_COMPILE = "-fcommon"; + NIX_LDFLAGS = "-lm"; + }; + + installPhase = "installPlugin src/wavelet-sharpen"; # TODO translations are not copied .. How to do this on nix? }; - installPhase = "installPlugin src/wavelet-sharpen"; # TODO translations are not copied .. How to do this on nix? - }; - - lqrPlugin = pluginDerivation rec { - /* menu: - Layer/Liquid Rescale - */ - pname = "lqr-plugin"; - version = "0.7.2"; - buildInputs = with pkgs; [ liblqr1 ]; - src = fetchFromGitHub { - owner = "carlobaldassi"; - repo = "gimp-lqr-plugin"; - rev = "v${version}"; - sha256 = "81ajdZ2zQi/THxnBlSeT36tVTEzrS1YqLGpHMhFTKAo="; + lqrPlugin = pluginDerivation rec { + /* + menu: + Layer/Liquid Rescale + */ + pname = "lqr-plugin"; + version = "0.7.2"; + buildInputs = with pkgs; [ liblqr1 ]; + src = fetchFromGitHub { + owner = "carlobaldassi"; + repo = "gimp-lqr-plugin"; + rev = "v${version}"; + sha256 = "81ajdZ2zQi/THxnBlSeT36tVTEzrS1YqLGpHMhFTKAo="; + }; + patches = [ + # Pull upstream fix for -fno-common toolchain support: + # https://github.com/carlobaldassi/gimp-lqr-plugin/pull/6 + (fetchpatch { + name = "fno-common.patch"; + url = "https://github.com/carlobaldassi/gimp-lqr-plugin/commit/ae3464a82e1395fc577cc94999bdc7c4a7bb35f1.patch"; + sha256 = "EdjZWM6U1bhUmsOnLA8iJ4SFKuAXHIfNPzxZqel+JrY="; + }) + ]; }; - patches = [ - # Pull upstream fix for -fno-common toolchain support: - # https://github.com/carlobaldassi/gimp-lqr-plugin/pull/6 - (fetchpatch { - name = "fno-common.patch"; - url = "https://github.com/carlobaldassi/gimp-lqr-plugin/commit/ae3464a82e1395fc577cc94999bdc7c4a7bb35f1.patch"; - sha256 = "EdjZWM6U1bhUmsOnLA8iJ4SFKuAXHIfNPzxZqel+JrY="; - }) - ]; - }; - - gmic = pkgs.gmic-qt.override { - variant = "gimp"; - }; - - gimplensfun = pluginDerivation { - version = "unstable-2018-10-21"; - pname = "gimplensfun"; - - src = fetchFromGitHub { - owner = "seebk"; - repo = "GIMP-Lensfun"; - rev = "1c5a5c1534b5faf098b7441f8840d22835592f17"; - sha256 = "1jj3n7spkjc63aipwdqsvq9gi07w13bb1v8iqzvxwzld2kxa3c8w"; + + gmic = pkgs.gmic-qt.override { + variant = "gimp"; }; - buildInputs = with pkgs; [ lensfun gexiv2 ]; + gimplensfun = pluginDerivation { + version = "unstable-2018-10-21"; + pname = "gimplensfun"; + + src = fetchFromGitHub { + owner = "seebk"; + repo = "GIMP-Lensfun"; + rev = "1c5a5c1534b5faf098b7441f8840d22835592f17"; + sha256 = "1jj3n7spkjc63aipwdqsvq9gi07w13bb1v8iqzvxwzld2kxa3c8w"; + }; + + buildInputs = with pkgs; [ + lensfun + gexiv2 + ]; - installPhase = " + installPhase = " installPlugin gimp-lensfun "; - meta = { - description = "GIMP plugin to correct lens distortion using the lensfun library and database"; + meta = { + description = "GIMP plugin to correct lens distortion using the lensfun library and database"; - homepage = "http://lensfun.sebastiankraft.net/"; + homepage = "http://lensfun.sebastiankraft.net/"; - license = lib.licenses.gpl3Plus; - maintainers = [ ]; - platforms = lib.platforms.gnu ++ lib.platforms.linux; + license = lib.licenses.gpl3Plus; + maintainers = [ ]; + platforms = lib.platforms.gnu ++ lib.platforms.linux; + }; }; - }; - /* =============== simple script files ==================== */ + # =============== simple script files ==================== - # also have a look at enblend-enfuse in all-packages.nix - exposureBlend = scriptDerivation { - name = "exposure-blend"; - src = fetchurl { - url = "http://tir.astro.utoledo.edu/jdsmith/code/eb/exposure-blend.scm"; - sha256 = "1b6c9wzpklqras4wwsyw3y3jp6fjmhnnskqiwm5sabs8djknfxla"; + # also have a look at enblend-enfuse in all-packages.nix + exposureBlend = scriptDerivation { + name = "exposure-blend"; + src = fetchurl { + url = "http://tir.astro.utoledo.edu/jdsmith/code/eb/exposure-blend.scm"; + sha256 = "1b6c9wzpklqras4wwsyw3y3jp6fjmhnnskqiwm5sabs8djknfxla"; + }; + meta.broken = true; }; - meta.broken = true; - }; - - lightning = scriptDerivation { - name = "Lightning"; - src = fetchurl { - url = "https://github.com/pixlsus/registry.gimp.org_static/raw/master/registry.gimp.org/files/Lightning.scm"; - sha256 = "c14a8f4f709695ede3f77348728a25b3f3ded420da60f3f8de3944b7eae98a49"; + + lightning = scriptDerivation { + name = "Lightning"; + src = fetchurl { + url = "https://github.com/pixlsus/registry.gimp.org_static/raw/master/registry.gimp.org/files/Lightning.scm"; + sha256 = "c14a8f4f709695ede3f77348728a25b3f3ded420da60f3f8de3944b7eae98a49"; + }; }; - }; -}) + } +) diff --git a/pkgs/applications/graphics/gimp/wrapper.nix b/pkgs/applications/graphics/gimp/wrapper.nix index f2400aca0fd1ff..82ff058ba7dc0b 100644 --- a/pkgs/applications/graphics/gimp/wrapper.nix +++ b/pkgs/applications/graphics/gimp/wrapper.nix @@ -1,13 +1,23 @@ -{ lib, symlinkJoin, makeWrapper, gimpPlugins, gnome-themes-extra, plugins ? null}: +{ + lib, + symlinkJoin, + makeWrapper, + gimpPlugins, + gnome-themes-extra, + plugins ? null, +}: let -inherit (gimpPlugins) gimp; -allPlugins = lib.filter (pkg: lib.isDerivation pkg && !pkg.meta.broken or false) (lib.attrValues gimpPlugins); -selectedPlugins = lib.filter (pkg: pkg != gimp) (if plugins == null then allPlugins else plugins); -extraArgs = map (x: x.wrapArgs or "") selectedPlugins; -versionBranch = lib.versions.majorMinor gimp.version; + inherit (gimpPlugins) gimp; + allPlugins = lib.filter (pkg: lib.isDerivation pkg && !pkg.meta.broken or false) ( + lib.attrValues gimpPlugins + ); + selectedPlugins = lib.filter (pkg: pkg != gimp) (if plugins == null then allPlugins else plugins); + extraArgs = map (x: x.wrapArgs or "") selectedPlugins; + versionBranch = lib.versions.majorMinor gimp.version; -in symlinkJoin { +in +symlinkJoin { name = "gimp-with-plugins-${gimp.version}"; paths = [ gimp ] ++ selectedPlugins; diff --git a/pkgs/applications/graphics/glabels-qt/default.nix b/pkgs/applications/graphics/glabels-qt/default.nix index 5715241fb75787..6865060f2fc244 100644 --- a/pkgs/applications/graphics/glabels-qt/default.nix +++ b/pkgs/applications/graphics/glabels-qt/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, cmake -, mkDerivation -, qttools +{ + lib, + fetchFromGitHub, + cmake, + mkDerivation, + qttools, }: mkDerivation { diff --git a/pkgs/applications/graphics/gnome-obfuscate/default.nix b/pkgs/applications/graphics/gnome-obfuscate/default.nix index db173f58b54e66..8d8f5e37fb2dfd 100644 --- a/pkgs/applications/graphics/gnome-obfuscate/default.nix +++ b/pkgs/applications/graphics/gnome-obfuscate/default.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchFromGitLab -, buildPackages -, cargo -, gettext -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, wrapGAppsHook4 -, appstream-glib -, desktop-file-utils -, glib -, gtk4 -, gdk-pixbuf -, libadwaita -, Foundation +{ + stdenv, + lib, + fetchFromGitLab, + buildPackages, + cargo, + gettext, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + wrapGAppsHook4, + appstream-glib, + desktop-file-utils, + glib, + gtk4, + gdk-pixbuf, + libadwaita, + Foundation, }: stdenv.mkDerivation (finalAttrs: { @@ -58,14 +59,16 @@ stdenv.mkDerivation (finalAttrs: { desktop-file-utils ]; - buildInputs = [ - glib - gtk4 - gdk-pixbuf - libadwaita - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Foundation - ]; + buildInputs = + [ + glib + gtk4 + gdk-pixbuf + libadwaita + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Foundation + ]; meta = with lib; { description = "Censor private information"; diff --git a/pkgs/applications/graphics/hdrmerge/default.nix b/pkgs/applications/graphics/hdrmerge/default.nix index ba0d25ac112d48..1c8eb725626855 100644 --- a/pkgs/applications/graphics/hdrmerge/default.nix +++ b/pkgs/applications/graphics/hdrmerge/default.nix @@ -1,17 +1,18 @@ -{ lib -, mkDerivation -, fetchpatch -, fetchFromGitHub -, cmake -, qtbase -, wrapQtAppsHook -, libraw -, exiv2 -, zlib -, alglib -, pkg-config -, makeDesktopItem -, copyDesktopItems +{ + lib, + mkDerivation, + fetchpatch, + fetchFromGitHub, + cmake, + qtbase, + wrapQtAppsHook, + libraw, + exiv2, + zlib, + alglib, + pkg-config, + makeDesktopItem, + copyDesktopItems, }: mkDerivation rec { @@ -31,7 +32,13 @@ mkDerivation rec { copyDesktopItems ]; - buildInputs = [ qtbase libraw exiv2 zlib alglib ]; + buildInputs = [ + qtbase + libraw + exiv2 + zlib + alglib + ]; cmakeFlags = [ "-DALGLIB_DIR:PATH=${alglib}" @@ -51,7 +58,10 @@ mkDerivation rec { icon = "hdrmerge"; exec = "hdrmerge %F"; categories = [ "Graphics" ]; - mimeTypes = [ "image/x-dcraw" "image/x-adobe-dng" ]; + mimeTypes = [ + "image/x-dcraw" + "image/x-adobe-dng" + ]; terminal = false; }) ]; diff --git a/pkgs/applications/graphics/image_optim/default.nix b/pkgs/applications/graphics/image_optim/default.nix index feceb00c31e84d..cf3f813906c612 100644 --- a/pkgs/applications/graphics/image_optim/default.nix +++ b/pkgs/applications/graphics/image_optim/default.nix @@ -1,20 +1,37 @@ -{ lib, bundlerApp, bundlerUpdateScript, makeWrapper, - withPngcrush ? true, pngcrush, - withPngout ? false, pngout, # disabled by default because it's unfree - withAdvpng ? true, advancecomp, - withOptipng ? true, optipng, - withPngquant ? true, pngquant, - withOxipng ? true, oxipng, - withJhead ? true, jhead, - withJpegoptim ? true, jpegoptim, - withJpegrecompress ? true, jpeg-archive, - withJpegtran ? true, libjpeg, - withGifsicle ? true, gifsicle, - withSvgo ? true, svgo +{ + lib, + bundlerApp, + bundlerUpdateScript, + makeWrapper, + withPngcrush ? true, + pngcrush, + withPngout ? false, + pngout, # disabled by default because it's unfree + withAdvpng ? true, + advancecomp, + withOptipng ? true, + optipng, + withPngquant ? true, + pngquant, + withOxipng ? true, + oxipng, + withJhead ? true, + jhead, + withJpegoptim ? true, + jpegoptim, + withJpegrecompress ? true, + jpeg-archive, + withJpegtran ? true, + libjpeg, + withGifsicle ? true, + gifsicle, + withSvgo ? true, + svgo, }: let - optionalDepsPath = lib.optional withPngcrush pngcrush + optionalDepsPath = + lib.optional withPngcrush pngcrush ++ lib.optional withPngout pngout ++ lib.optional withAdvpng advancecomp ++ lib.optional withOptipng optipng @@ -27,7 +44,8 @@ let ++ lib.optional withGifsicle gifsicle ++ lib.optional withSvgo svgo; - disabledWorkersFlags = lib.optional (!withPngcrush) "--no-pngcrush" + disabledWorkersFlags = + lib.optional (!withPngcrush) "--no-pngcrush" ++ lib.optional (!withPngout) "--no-pngout" ++ lib.optional (!withAdvpng) "--no-advpng" ++ lib.optional (!withOptipng) "--no-optipng" @@ -67,7 +85,10 @@ bundlerApp { ''; homepage = "https://github.com/toy/image_optim"; license = licenses.mit; - maintainers = with maintainers; [ srghma nicknovitski ]; + maintainers = with maintainers; [ + srghma + nicknovitski + ]; platforms = platforms.all; mainProgram = "image_optim"; }; diff --git a/pkgs/applications/graphics/image_optim/gemset.nix b/pkgs/applications/graphics/image_optim/gemset.nix index b9de8acc28d167..10c909a92080f0 100644 --- a/pkgs/applications/graphics/image_optim/gemset.nix +++ b/pkgs/applications/graphics/image_optim/gemset.nix @@ -1,60 +1,66 @@ { exifr = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08fmmswa9fwymwsa2gzlm856ak3y9kjxdzm4zdrcrfyxs2p8yqwc"; type = "gem"; }; version = "1.3.10"; }; fspath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xcxikkrjv8ws328nn5ax5pyfjs8pn7djg1hks7qyb3yp6prpb5m"; type = "gem"; }; version = "3.1.2"; }; image_optim = { - dependencies = ["exifr" "fspath" "image_size" "in_threads" "progress"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "exifr" + "fspath" + "image_size" + "in_threads" + "progress" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02iw1plldayr1l8bdw2gshq0h083h0fxwji1m1nfhzikz917c07p"; type = "gem"; }; version = "0.31.3"; }; image_size = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10slvvyam8gkdjzlhb3wb21hp46ay18miyh1advwvyny660rmdsb"; type = "gem"; }; version = "3.2.0"; }; in_threads = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j9132d4g8prjafgdh4pw948j527kr09m2lvylrcd797il9yd9wi"; type = "gem"; }; version = "1.6.0"; }; progress = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wymdk40cwrqn32gwg1kw94s5p1n0z3n7ma7x1s62gd4vw3d63in"; type = "gem"; }; diff --git a/pkgs/applications/graphics/imgp/default.nix b/pkgs/applications/graphics/imgp/default.nix index bb2334222fb7c6..3855d3e16ba5fc 100644 --- a/pkgs/applications/graphics/imgp/default.nix +++ b/pkgs/applications/graphics/imgp/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildPythonApplication, pythonOlder, pillow }: +{ + lib, + fetchFromGitHub, + buildPythonApplication, + pythonOlder, + pillow, +}: buildPythonApplication rec { pname = "imgp"; diff --git a/pkgs/applications/graphics/imlibsetroot/default.nix b/pkgs/applications/graphics/imlibsetroot/default.nix index 7fac0a0d386c96..81976a3160c946 100644 --- a/pkgs/applications/graphics/imlibsetroot/default.nix +++ b/pkgs/applications/graphics/imlibsetroot/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, libX11, libXinerama, imlib2 }: +{ + lib, + stdenv, + fetchurl, + libX11, + libXinerama, + imlib2, +}: stdenv.mkDerivation { pname = "imlibsetroot"; @@ -8,7 +15,11 @@ stdenv.mkDerivation { sha256 = "8c1b3b7c861e4d865883ec13a96b8e4ab22464a87d4e6c67255b17a88e3cfd1c"; }; - buildInputs = [ libX11 imlib2 libXinerama ]; + buildInputs = [ + libX11 + imlib2 + libXinerama + ]; buildPhase = '' runHook preBuild diff --git a/pkgs/applications/graphics/inkscape/extensions/applytransforms/default.nix b/pkgs/applications/graphics/inkscape/extensions/applytransforms/default.nix index ceab3eaea3d9a6..0405b961605ce1 100644 --- a/pkgs/applications/graphics/inkscape/extensions/applytransforms/default.nix +++ b/pkgs/applications/graphics/inkscape/extensions/applytransforms/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + python3, }: stdenv.mkDerivation { diff --git a/pkgs/applications/graphics/inkscape/extensions/silhouette/default.nix b/pkgs/applications/graphics/inkscape/extensions/silhouette/default.nix index 3a121a9bfde09a..d511395889b088 100644 --- a/pkgs/applications/graphics/inkscape/extensions/silhouette/default.nix +++ b/pkgs/applications/graphics/inkscape/extensions/silhouette/default.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, lib -, gettext -, pkgs -, python3 -, umockdev -, writeScript +{ + fetchFromGitHub, + lib, + gettext, + pkgs, + python3, + umockdev, + writeScript, }: let diff --git a/pkgs/applications/graphics/inkscape/extensions/textext/default.nix b/pkgs/applications/graphics/inkscape/extensions/textext/default.nix index cb4be37759bcb9..312d018c13b47f 100644 --- a/pkgs/applications/graphics/inkscape/extensions/textext/default.nix +++ b/pkgs/applications/graphics/inkscape/extensions/textext/default.nix @@ -1,15 +1,16 @@ -{ lib -, writeScript -, fetchFromGitHub -, substituteAll -, inkscape -, pdflatex -, lualatex -, python3 -, wrapGAppsHook3 -, gobject-introspection -, gtk3 -, gtksourceview3 +{ + lib, + writeScript, + fetchFromGitHub, + substituteAll, + inkscape, + pdflatex, + lualatex, + python3, + wrapGAppsHook3, + gobject-introspection, + gtk3, + gtksourceview3, }: let diff --git a/pkgs/applications/graphics/inkscape/test-ps2pdf-plugin.nix b/pkgs/applications/graphics/inkscape/test-ps2pdf-plugin.nix index 3e55557c860e1a..8f500e9ab2cbdb 100644 --- a/pkgs/applications/graphics/inkscape/test-ps2pdf-plugin.nix +++ b/pkgs/applications/graphics/inkscape/test-ps2pdf-plugin.nix @@ -1,27 +1,32 @@ -{ inkscape, runCommand, writeTextFile }: +{ + inkscape, + runCommand, + writeTextFile, +}: let svg_file = writeTextFile { name = "test.svg"; text = '' - - - -''; + + + + ''; }; in runCommand "inkscape-test-eps" -{ - nativeBuildInputs = [ inkscape ]; -} '' - echo ps test - inkscape ${svg_file} --export-type=ps -o test.ps - inkscape test.ps -o test.ps.svg + { + nativeBuildInputs = [ inkscape ]; + } + '' + echo ps test + inkscape ${svg_file} --export-type=ps -o test.ps + inkscape test.ps -o test.ps.svg - echo eps test - inkscape ${svg_file} --export-type=eps -o test.eps - inkscape test.eps -o test.eps.svg + echo eps test + inkscape ${svg_file} --export-type=eps -o test.eps + inkscape test.eps -o test.eps.svg - # inkscape does not return an error code, only does not create files - [[ -f test.ps.svg && -f test.eps.svg ]] && touch $out -'' + # inkscape does not return an error code, only does not create files + [[ -f test.ps.svg && -f test.eps.svg ]] && touch $out + '' diff --git a/pkgs/applications/graphics/inkscape/with-extensions.nix b/pkgs/applications/graphics/inkscape/with-extensions.nix index 14fffadd036060..7970cdfb89a4cb 100644 --- a/pkgs/applications/graphics/inkscape/with-extensions.nix +++ b/pkgs/applications/graphics/inkscape/with-extensions.nix @@ -1,13 +1,16 @@ -{ lib -, inkscape -, symlinkJoin -, makeWrapper -, inkscapeExtensions ? [ ] -, inkscape-extensions +{ + lib, + inkscape, + symlinkJoin, + makeWrapper, + inkscapeExtensions ? [ ], + inkscape-extensions, }: let - allExtensions = lib.filter (pkg: lib.isDerivation pkg && !pkg.meta.broken or false) (lib.attrValues inkscape-extensions); + allExtensions = lib.filter (pkg: lib.isDerivation pkg && !pkg.meta.broken or false) ( + lib.attrValues inkscape-extensions + ); selectedExtensions = if inkscapeExtensions == null then allExtensions else inkscapeExtensions; in diff --git a/pkgs/applications/graphics/kgraphviewer/default.nix b/pkgs/applications/graphics/kgraphviewer/default.nix index c7cbf22e013eb7..b387a1a8d918ce 100644 --- a/pkgs/applications/graphics/kgraphviewer/default.nix +++ b/pkgs/applications/graphics/kgraphviewer/default.nix @@ -1,7 +1,21 @@ -{ lib, mkDerivation, fetchurl, cmake, extra-cmake-modules, pkg-config, wrapGAppsHook3 -, kconfig, kinit, kdoctools, kio, kparts, kwidgetsaddons -, qtbase, qtsvg -, boost, graphviz +{ + lib, + mkDerivation, + fetchurl, + cmake, + extra-cmake-modules, + pkg-config, + wrapGAppsHook3, + kconfig, + kinit, + kdoctools, + kio, + kparts, + kwidgetsaddons, + qtbase, + qtsvg, + boost, + graphviz, }: mkDerivation rec { @@ -14,24 +28,33 @@ mkDerivation rec { }; buildInputs = [ - qtbase qtsvg - boost graphviz + qtbase + qtsvg + boost + graphviz ]; nativeBuildInputs = [ - cmake extra-cmake-modules pkg-config wrapGAppsHook3 + cmake + extra-cmake-modules + pkg-config + wrapGAppsHook3 kdoctools ]; propagatedBuildInputs = [ - kconfig kinit kio kparts kwidgetsaddons + kconfig + kinit + kio + kparts + kwidgetsaddons ]; meta = with lib; { description = "Graphviz dot graph viewer for KDE"; mainProgram = "kgraphviewer"; - license = licenses.gpl2; + license = licenses.gpl2; maintainers = [ ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/applications/graphics/kodelife/default.nix b/pkgs/applications/graphics/kodelife/default.nix index 564be8f1059382..10acce631f6df5 100644 --- a/pkgs/applications/graphics/kodelife/default.nix +++ b/pkgs/applications/graphics/kodelife/default.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, autoPatchelfHook -, dpkg -, alsa-lib -, curl -, avahi -, gstreamer -, gst-plugins-base -, libxcb -, libX11 -, libXcursor -, libXext -, libXi -, libXinerama -, libXrandr -, libXrender -, libXxf86vm -, libglvnd -, zenity +{ + lib, + stdenv, + fetchurl, + makeWrapper, + autoPatchelfHook, + dpkg, + alsa-lib, + curl, + avahi, + gstreamer, + gst-plugins-base, + libxcb, + libX11, + libXcursor, + libXext, + libXi, + libXinerama, + libXrandr, + libXrender, + libXxf86vm, + libglvnd, + zenity, }: let @@ -47,19 +48,23 @@ stdenv.mkDerivation rec { pname = "kodelife"; version = "1.1.0.173"; - suffix = { - aarch64-linux = "linux-arm64"; - armv7l-linux = "linux-armhf"; - x86_64-linux = "linux-x64"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + suffix = + { + aarch64-linux = "linux-arm64"; + armv7l-linux = "linux-armhf"; + x86_64-linux = "linux-x64"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); src = fetchurl { url = "https://hexler.net/pub/${pname}/${pname}-${version}-${suffix}.deb"; - hash = { - aarch64-linux = "sha256-WPUWvgVZR+2Dg4zpk+iUemMBGlGBDtaGkUGrWuF5LBs="; - armv7l-linux = "sha256-tOPqP40e0JrXg92OluMZrurWHXZavGwTkJiNN1IFVEE="; - x86_64-linux = "sha256-ZA8BlUtKaiSnXGncYwb2BbhBlULuGz7SWuXL0RAgQLI="; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + hash = + { + aarch64-linux = "sha256-WPUWvgVZR+2Dg4zpk+iUemMBGlGBDtaGkUGrWuF5LBs="; + armv7l-linux = "sha256-tOPqP40e0JrXg92OluMZrurWHXZavGwTkJiNN1IFVEE="; + x86_64-linux = "sha256-ZA8BlUtKaiSnXGncYwb2BbhBlULuGz7SWuXL0RAgQLI="; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); }; strictDeps = true; @@ -101,7 +106,11 @@ stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; maintainers = with maintainers; [ prusnak ]; - platforms = [ "aarch64-linux" "armv7l-linux" "x86_64-linux" ]; + platforms = [ + "aarch64-linux" + "armv7l-linux" + "x86_64-linux" + ]; mainProgram = "KodeLife"; }; } diff --git a/pkgs/applications/graphics/kphotoalbum/default.nix b/pkgs/applications/graphics/kphotoalbum/default.nix index aa4bd7fd7e7e68..6af9d69f5574ea 100644 --- a/pkgs/applications/graphics/kphotoalbum/default.nix +++ b/pkgs/applications/graphics/kphotoalbum/default.nix @@ -1,20 +1,21 @@ -{ mkDerivation -, fetchpatch -, fetchurl -, lib -, extra-cmake-modules -, kdoctools -, wrapGAppsHook3 -, exiv2 -, ffmpeg -, libkdcraw -, phonon -, libvlc -, kconfig -, kiconthemes -, kio -, kinit -, kpurpose +{ + mkDerivation, + fetchpatch, + fetchurl, + lib, + extra-cmake-modules, + kdoctools, + wrapGAppsHook3, + exiv2, + ffmpeg, + libkdcraw, + phonon, + libvlc, + kconfig, + kiconthemes, + kio, + kinit, + kpurpose, }: mkDerivation rec { @@ -36,11 +37,26 @@ mkDerivation rec { # not sure if we really need phonon when we have vlc, but on KDE it's bound to # be on the system anyway, so there is no real harm including it - buildInputs = [ exiv2 phonon libvlc ]; + buildInputs = [ + exiv2 + phonon + libvlc + ]; - nativeBuildInputs = [ extra-cmake-modules kdoctools wrapGAppsHook3 ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wrapGAppsHook3 + ]; - propagatedBuildInputs = [ kconfig kiconthemes kio kinit kpurpose libkdcraw ]; + propagatedBuildInputs = [ + kconfig + kiconthemes + kio + kinit + kpurpose + libkdcraw + ]; qtWrapperArgs = [ "--prefix PATH : ${lib.makeBinPath [ ffmpeg ]}" diff --git a/pkgs/applications/graphics/krita/generic.nix b/pkgs/applications/graphics/krita/generic.nix index b781bedd084fea..1a1ba8e115fd59 100644 --- a/pkgs/applications/graphics/krita/generic.nix +++ b/pkgs/applications/graphics/krita/generic.nix @@ -1,15 +1,61 @@ -{ mkDerivation, lib, stdenv, fetchpatch, fetchurl, cmake, extra-cmake-modules -, karchive, kconfig, kwidgetsaddons, kcompletion, kcoreaddons -, kguiaddons, ki18n, kitemmodels, kitemviews, kwindowsystem -, kio, kcrash, breeze-icons -, boost, libraw, fftw, eigen, exiv2, fribidi, libaom, libheif, libkdcraw, lcms2, gsl, openexr, giflib -, libjxl, mlt , openjpeg, opencolorio, xsimd, poppler, curl, ilmbase, immer, kseexpr, lager -, libmypaint , libunibreak, libwebp -, qtmultimedia, qtx11extras, quazip, SDL2, zug, pkg-config -, python3Packages -, version -, kde-channel -, hash +{ + mkDerivation, + lib, + stdenv, + fetchpatch, + fetchurl, + cmake, + extra-cmake-modules, + karchive, + kconfig, + kwidgetsaddons, + kcompletion, + kcoreaddons, + kguiaddons, + ki18n, + kitemmodels, + kitemviews, + kwindowsystem, + kio, + kcrash, + breeze-icons, + boost, + libraw, + fftw, + eigen, + exiv2, + fribidi, + libaom, + libheif, + libkdcraw, + lcms2, + gsl, + openexr, + giflib, + libjxl, + mlt, + openjpeg, + opencolorio, + xsimd, + poppler, + curl, + ilmbase, + immer, + kseexpr, + lager, + libmypaint, + libunibreak, + libwebp, + qtmultimedia, + qtx11extras, + quazip, + SDL2, + zug, + pkg-config, + python3Packages, + version, + kde-channel, + hash, }: mkDerivation rec { @@ -30,33 +76,87 @@ mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake extra-cmake-modules pkg-config python3Packages.sip ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + pkg-config + python3Packages.sip + ]; buildInputs = [ - karchive kconfig kwidgetsaddons kcompletion kcoreaddons kguiaddons - ki18n kitemmodels kitemviews kwindowsystem kio kcrash breeze-icons - boost libraw fftw eigen exiv2 fribidi lcms2 gsl openexr lager libaom libheif libkdcraw giflib - libjxl mlt openjpeg opencolorio xsimd poppler curl ilmbase immer kseexpr libmypaint - libunibreak libwebp qtmultimedia qtx11extras quazip SDL2 zug + karchive + kconfig + kwidgetsaddons + kcompletion + kcoreaddons + kguiaddons + ki18n + kitemmodels + kitemviews + kwindowsystem + kio + kcrash + breeze-icons + boost + libraw + fftw + eigen + exiv2 + fribidi + lcms2 + gsl + openexr + lager + libaom + libheif + libkdcraw + giflib + libjxl + mlt + openjpeg + opencolorio + xsimd + poppler + curl + ilmbase + immer + kseexpr + libmypaint + libunibreak + libwebp + qtmultimedia + qtx11extras + quazip + SDL2 + zug python3Packages.pyqt5 ]; - env.NIX_CFLAGS_COMPILE = toString ([ "-I${ilmbase.dev}/include/OpenEXR" ] - ++ lib.optional stdenv.cc.isGNU "-Wno-deprecated-copy"); + env.NIX_CFLAGS_COMPILE = toString ( + [ "-I${ilmbase.dev}/include/OpenEXR" ] ++ lib.optional stdenv.cc.isGNU "-Wno-deprecated-copy" + ); # Krita runs custom python scripts in CMake with custom PYTHONPATH which krita determined in their CMake script. # Patch the PYTHONPATH so python scripts can import sip successfully. - postPatch = let - pythonPath = python3Packages.makePythonPath (with python3Packages; [ sip setuptools ]); - in '' - substituteInPlace cmake/modules/FindSIP.cmake \ - --replace 'PYTHONPATH=''${_sip_python_path}' 'PYTHONPATH=${pythonPath}' - substituteInPlace cmake/modules/SIPMacros.cmake \ - --replace 'PYTHONPATH=''${_krita_python_path}' 'PYTHONPATH=${pythonPath}' + postPatch = + let + pythonPath = python3Packages.makePythonPath ( + with python3Packages; + [ + sip + setuptools + ] + ); + in + '' + substituteInPlace cmake/modules/FindSIP.cmake \ + --replace 'PYTHONPATH=''${_sip_python_path}' 'PYTHONPATH=${pythonPath}' + substituteInPlace cmake/modules/SIPMacros.cmake \ + --replace 'PYTHONPATH=''${_krita_python_path}' 'PYTHONPATH=${pythonPath}' - substituteInPlace plugins/impex/jp2/jp2_converter.cc \ - --replace '' '<${openjpeg.incDir}/openjpeg.h>' - ''; + substituteInPlace plugins/impex/jp2/jp2_converter.cc \ + --replace '' '<${openjpeg.incDir}/openjpeg.h>' + ''; cmakeBuildType = "RelWithDebInfo"; @@ -69,7 +169,11 @@ mkDerivation rec { meta = with lib; { description = "Free and open source painting application"; homepage = "https://krita.org/"; - maintainers = with maintainers; [ abbradar sifmelcara nek0 ]; + maintainers = with maintainers; [ + abbradar + sifmelcara + nek0 + ]; mainProgram = "krita"; platforms = platforms.linux; license = licenses.gpl3Only; diff --git a/pkgs/applications/graphics/krita/wrapper.nix b/pkgs/applications/graphics/krita/wrapper.nix index 6d62412e5662c1..75160d027a83d2 100644 --- a/pkgs/applications/graphics/krita/wrapper.nix +++ b/pkgs/applications/graphics/krita/wrapper.nix @@ -1,17 +1,23 @@ -{ lib -, libsForQt5 -, symlinkJoin -, unwrapped ? libsForQt5.callPackage ./. { } -, krita-plugin-gmic -, binaryPlugins ? [ +{ + lib, + libsForQt5, + symlinkJoin, + unwrapped ? libsForQt5.callPackage ./. { }, + krita-plugin-gmic, + binaryPlugins ? [ # Default plugins provided by upstream appimage krita-plugin-gmic - ] + ], }: symlinkJoin { name = lib.replaceStrings [ "-unwrapped" ] [ "" ] unwrapped.name; - inherit (unwrapped) version buildInputs nativeBuildInputs meta; + inherit (unwrapped) + version + buildInputs + nativeBuildInputs + meta + ; paths = [ unwrapped ] ++ binaryPlugins; diff --git a/pkgs/applications/graphics/ktikz/default.nix b/pkgs/applications/graphics/ktikz/default.nix index b7fe2e205fa8be..c267b563d974a1 100644 --- a/pkgs/applications/graphics/ktikz/default.nix +++ b/pkgs/applications/graphics/ktikz/default.nix @@ -1,7 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, pkg-config, wrapQtAppsHook -, poppler, gnuplot -, qmake, qtbase, qttools +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + wrapQtAppsHook, + poppler, + gnuplot, + qmake, + qtbase, + qttools, }: # This package only builds ktikz without KDE integration because KDE4 is @@ -44,10 +52,18 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config qttools qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + pkg-config + qttools + qmake + wrapQtAppsHook + ]; QT_PLUGIN_PATH = "${qtbase}/${qtbase.qtPluginPrefix}"; - buildInputs = [ qtbase poppler ]; + buildInputs = [ + qtbase + poppler + ]; qmakeFlags = [ "DESKTOP_INSTALL_DIR=${placeholder "out"}/share/applications" diff --git a/pkgs/applications/graphics/leocad/default.nix b/pkgs/applications/graphics/leocad/default.nix index 9a0bbaefe50566..1d9b06f4144bb3 100644 --- a/pkgs/applications/graphics/leocad/default.nix +++ b/pkgs/applications/graphics/leocad/default.nix @@ -1,17 +1,18 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, fetchurl -, povray -, qmake -, qttools -, substituteAll -, zlib +{ + lib, + mkDerivation, + fetchFromGitHub, + fetchurl, + povray, + qmake, + qttools, + substituteAll, + zlib, }: /* -To use aditional parts libraries -set the variable LEOCAD_LIB=/path/to/libs/ or use option -l /path/to/libs/ + To use aditional parts libraries + set the variable LEOCAD_LIB=/path/to/libs/ or use option -l /path/to/libs/ */ let @@ -32,7 +33,10 @@ mkDerivation rec { sha256 = "1ifbxngkbmg6d8vv08amxbnfvlyjdwzykrjp98lbwvgb0b843ygq"; }; - nativeBuildInputs = [ qmake qttools ]; + nativeBuildInputs = [ + qmake + qttools + ]; buildInputs = [ zlib ]; diff --git a/pkgs/applications/graphics/lightburn/default.nix b/pkgs/applications/graphics/lightburn/default.nix index 5877d6a013d5af..11a6b17cd3160e 100644 --- a/pkgs/applications/graphics/lightburn/default.nix +++ b/pkgs/applications/graphics/lightburn/default.nix @@ -1,7 +1,16 @@ -{ lib, stdenv, fetchurl, p7zip -, nss, nspr, libusb1 -, qtbase, qtmultimedia, qtserialport, cups -, autoPatchelfHook +{ + lib, + stdenv, + fetchurl, + p7zip, + nss, + nspr, + libusb1, + qtbase, + qtmultimedia, + qtserialport, + cups, + autoPatchelfHook, }: stdenv.mkDerivation rec { @@ -19,8 +28,13 @@ stdenv.mkDerivation rec { }; buildInputs = [ - nss nspr libusb1 - qtbase qtmultimedia qtserialport cups + nss + nspr + libusb1 + qtbase + qtmultimedia + qtserialport + cups ]; unpackPhase = '' diff --git a/pkgs/applications/graphics/luminance-hdr/default.nix b/pkgs/applications/graphics/luminance-hdr/default.nix index ef0f687d334b65..e12bca03746151 100644 --- a/pkgs/applications/graphics/luminance-hdr/default.nix +++ b/pkgs/applications/graphics/luminance-hdr/default.nix @@ -1,7 +1,24 @@ -{ lib, mkDerivation, cmake, fetchFromGitHub, fetchpatch, pkg-config -, boost, exiv2, fftwFloat, gsl -, ilmbase, lcms2, libraw, libtiff, openexr -, qtbase, qtdeclarative, qttools, qtwebengine, eigen +{ + lib, + mkDerivation, + cmake, + fetchFromGitHub, + fetchpatch, + pkg-config, + boost, + exiv2, + fftwFloat, + gsl, + ilmbase, + lcms2, + libraw, + libtiff, + openexr, + qtbase, + qtdeclarative, + qttools, + qtwebengine, + eigen, }: mkDerivation rec { @@ -26,11 +43,26 @@ mkDerivation rec { env.NIX_CFLAGS_COMPILE = "-I${ilmbase.dev}/include/OpenEXR"; buildInputs = [ - qtbase qtdeclarative qttools qtwebengine eigen - boost exiv2 fftwFloat gsl ilmbase lcms2 libraw libtiff openexr + qtbase + qtdeclarative + qttools + qtwebengine + eigen + boost + exiv2 + fftwFloat + gsl + ilmbase + lcms2 + libraw + libtiff + openexr ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; meta = with lib; { homepage = "https://qtpfsgui.sourceforge.net/"; diff --git a/pkgs/applications/graphics/menyoki/default.nix b/pkgs/applications/graphics/menyoki/default.nix index e8ae4e7f255581..c2b66fb45755c9 100644 --- a/pkgs/applications/graphics/menyoki/default.nix +++ b/pkgs/applications/graphics/menyoki/default.nix @@ -1,14 +1,15 @@ -{ fetchFromGitHub -, installShellFiles -, lib -, pkg-config -, rustPlatform -, stdenv -, withSixel ? false -, libsixel -, xorg -, AppKit -, withSki ? true +{ + fetchFromGitHub, + installShellFiles, + lib, + pkg-config, + rustPlatform, + stdenv, + withSixel ? false, + libsixel, + xorg, + AppKit, + withSki ? true, }: rustPlatform.buildRustPackage rec { @@ -24,11 +25,17 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-NtXjlGkX8AzSw98xHPymzdnTipMIunyDbpSr4eVowa0="; - nativeBuildInputs = [ installShellFiles ] - ++ lib.optional stdenv.hostPlatform.isLinux pkg-config; - - buildInputs = lib.optional withSixel libsixel - ++ lib.optionals stdenv.hostPlatform.isLinux (with xorg; [ libX11 libXrandr ]) + nativeBuildInputs = [ installShellFiles ] ++ lib.optional stdenv.hostPlatform.isLinux pkg-config; + + buildInputs = + lib.optional withSixel libsixel + ++ lib.optionals stdenv.hostPlatform.isLinux ( + with xorg; + [ + libX11 + libXrandr + ] + ) ++ lib.optional stdenv.hostPlatform.isDarwin AppKit; buildNoDefaultFeatures = !withSki; diff --git a/pkgs/applications/graphics/meshlab/default.nix b/pkgs/applications/graphics/meshlab/default.nix index 658e4b4e9c7045..7e5f40682ff0fb 100644 --- a/pkgs/applications/graphics/meshlab/default.nix +++ b/pkgs/applications/graphics/meshlab/default.nix @@ -1,30 +1,31 @@ -{ mkDerivation -, lib -, fetchFromGitHub -, libGLU -, qtbase -, qtscript -, qtxmlpatterns -, lib3ds -, bzip2 -, muparser -, eigen -, glew -, gmp -, levmar -, qhull -, cmake -, cgal -, boost -, mpfr -, xercesc -, tbb -, embree -, vcg -, libigl -, corto -, openctm -, structuresynth +{ + mkDerivation, + lib, + fetchFromGitHub, + libGLU, + qtbase, + qtscript, + qtxmlpatterns, + lib3ds, + bzip2, + muparser, + eigen, + glew, + gmp, + levmar, + qhull, + cmake, + cgal, + boost, + mpfr, + xercesc, + tbb, + embree, + vcg, + libigl, + corto, + openctm, + structuresynth, }: mkDerivation rec { diff --git a/pkgs/applications/graphics/nufraw/default.nix b/pkgs/applications/graphics/nufraw/default.nix index 8b5966bbaf0a59..58624aa5199d67 100644 --- a/pkgs/applications/graphics/nufraw/default.nix +++ b/pkgs/applications/graphics/nufraw/default.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch +{ + lib, + stdenv, + fetchurl, + fetchpatch, -, autoreconfHook -, bzip2 -, cfitsio -, exiv2 -, gettext -, gtk2 -, gtkimageview -, lcms2 -, lensfun -, libjpeg -, libtiff -, perl -, pkg-config -, zlib + autoreconfHook, + bzip2, + cfitsio, + exiv2, + gettext, + gtk2, + gtkimageview, + lcms2, + lensfun, + libjpeg, + libtiff, + perl, + pkg-config, + zlib, -, addThumbnailer ? false + addThumbnailer ? false, }: stdenv.mkDerivation rec { @@ -30,7 +31,12 @@ stdenv.mkDerivation rec { sha256 = "0b63qvw9r8kaqw36bk3a9zwxc41h8fr6498indkw4glrj0awqz9c"; }; - nativeBuildInputs = [ autoreconfHook gettext perl pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + gettext + perl + pkg-config + ]; buildInputs = [ bzip2 @@ -57,32 +63,33 @@ stdenv.mkDerivation rec { substituteAll ${./nufraw.thumbnailer} $out/share/thumbnailers/${pname}.thumbnailer ''; - patches = [ - # Fixes an upstream issue where headers with templates were included in an extern-C scope - # which caused the build to fail - (fetchpatch { - name = "0001-nufraw-glib-2.70.patch"; - url = "https://gitlab.archlinux.org/archlinux/packaging/packages/gimp-nufraw/-/raw/3405bc864752dbd04f2d182a21b4108d6cc3aa95/0001-nufraw-glib-2.70.patch"; - hash = "sha256-XgzgjikWTcqymHa7bKmruNZaeb2/lpN19HXoRUt5rTk="; - }) - ] ++ lib.optionals (lib.versionAtLeast exiv2.version "0.28") [ - (fetchpatch { - name = "0002-exiv2-error.patch"; - url = "https://gitlab.archlinux.org/archlinux/packaging/packages/gimp-nufraw/-/raw/3405bc864752dbd04f2d182a21b4108d6cc3aa95/0002-exiv2-error.patch"; - hash = "sha256-40/Wwk1sWiaIWp077EYgP8jFO4k1cvf30heRDMYJw3M="; - }) - ]; + patches = + [ + # Fixes an upstream issue where headers with templates were included in an extern-C scope + # which caused the build to fail + (fetchpatch { + name = "0001-nufraw-glib-2.70.patch"; + url = "https://gitlab.archlinux.org/archlinux/packaging/packages/gimp-nufraw/-/raw/3405bc864752dbd04f2d182a21b4108d6cc3aa95/0001-nufraw-glib-2.70.patch"; + hash = "sha256-XgzgjikWTcqymHa7bKmruNZaeb2/lpN19HXoRUt5rTk="; + }) + ] + ++ lib.optionals (lib.versionAtLeast exiv2.version "0.28") [ + (fetchpatch { + name = "0002-exiv2-error.patch"; + url = "https://gitlab.archlinux.org/archlinux/packaging/packages/gimp-nufraw/-/raw/3405bc864752dbd04f2d182a21b4108d6cc3aa95/0002-exiv2-error.patch"; + hash = "sha256-40/Wwk1sWiaIWp077EYgP8jFO4k1cvf30heRDMYJw3M="; + }) + ]; meta = with lib; { homepage = "https://nufraw.sourceforge.io/"; description = "Utility to read and manipulate raw images from digital cameras"; - longDescription = - '' - A new version of the popular raw digital images manipulator ufraw. - Forks from the version 0.23 of ufraw (that's why the first nufraw version is the 0.24). - Nufraw offers the same features (gimp plugin, batch, ecc) and the same quality of - ufraw in a brand new improved user interface. - ''; + longDescription = '' + A new version of the popular raw digital images manipulator ufraw. + Forks from the version 0.23 of ufraw (that's why the first nufraw version is the 0.24). + Nufraw offers the same features (gimp plugin, batch, ecc) and the same quality of + ufraw in a brand new improved user interface. + ''; license = licenses.gpl2Plus; maintainers = with maintainers; [ asbachb ]; platforms = platforms.linux; diff --git a/pkgs/applications/graphics/odafileconverter/default.nix b/pkgs/applications/graphics/odafileconverter/default.nix index acc00b4fa0bd41..047c2e9dd56a55 100644 --- a/pkgs/applications/graphics/odafileconverter/default.nix +++ b/pkgs/applications/graphics/odafileconverter/default.nix @@ -1,13 +1,26 @@ -{ lib, stdenv, mkDerivation, dpkg, fetchurl, qtbase }: +{ + lib, + stdenv, + mkDerivation, + dpkg, + fetchurl, + qtbase, +}: let # To obtain the version you will need to run the following command: # # dpkg-deb -I ${odafileconverter.src} | grep Version version = "21.11.0.0"; - rpath = "$ORIGIN:${lib.makeLibraryPath [ stdenv.cc.cc qtbase ]}"; + rpath = "$ORIGIN:${ + lib.makeLibraryPath [ + stdenv.cc.cc + qtbase + ] + }"; -in mkDerivation { +in +mkDerivation { pname = "oda-file-converter"; inherit version; nativeBuildInputs = [ dpkg ]; diff --git a/pkgs/applications/graphics/openboard/default.nix b/pkgs/applications/graphics/openboard/default.nix index cd5331d00672f4..f8ffdc12ec6719 100644 --- a/pkgs/applications/graphics/openboard/default.nix +++ b/pkgs/applications/graphics/openboard/default.nix @@ -1,7 +1,37 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch2, copyDesktopItems, makeDesktopItem, qmake -, qtbase, qtxmlpatterns, qttools, qtwebengine, libGL, fontconfig, openssl, poppler, wrapQtAppsHook -, ffmpeg, libva, alsa-lib, SDL, x264, libvpx, libvorbis, libtheora, libogg -, libopus, lame, fdk_aac, libass, quazip, libXext, libXfixes }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch2, + copyDesktopItems, + makeDesktopItem, + qmake, + qtbase, + qtxmlpatterns, + qttools, + qtwebengine, + libGL, + fontconfig, + openssl, + poppler, + wrapQtAppsHook, + ffmpeg, + libva, + alsa-lib, + SDL, + x264, + libvpx, + libvorbis, + libtheora, + libogg, + libopus, + lame, + fdk_aac, + libass, + quazip, + libXext, + libXfixes, +}: let importer = stdenv.mkDerivation { @@ -23,7 +53,8 @@ let install -Dm755 OpenBoardImporter $out/bin/OpenBoardImporter ''; }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "openboard"; version = "1.7.1"; @@ -62,7 +93,11 @@ in stdenv.mkDerivation (finalAttrs: { --replace-fail 'HideCheckForSoftwareUpdate=false' 'HideCheckForSoftwareUpdate=true' ''; - nativeBuildInputs = [ qmake copyDesktopItems wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + copyDesktopItems + wrapQtAppsHook + ]; buildInputs = [ qtbase diff --git a/pkgs/applications/graphics/openscad/default.nix b/pkgs/applications/graphics/openscad/default.nix index 26e19eec33f8d2..9299811de9ceac 100644 --- a/pkgs/applications/graphics/openscad/default.nix +++ b/pkgs/applications/graphics/openscad/default.nix @@ -1,39 +1,43 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, qtbase -, qtmultimedia -, qscintilla -, bison -, flex -, eigen -, boost -, libGLU, libGL -, glew -, opencsg -, cgal_4 -, mpfr -, gmp -, glib -, pkg-config -, harfbuzz -, gettext -, freetype -, fontconfig -, double-conversion -, lib3mf -, libzip -, mkDerivation -, qtmacextras -, qmake -, spacenavSupport ? stdenv.hostPlatform.isLinux, libspnav -, wayland -, wayland-protocols -, wrapGAppsHook3 -, qtwayland -, cairo -, openscad -, runCommand +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + qtbase, + qtmultimedia, + qscintilla, + bison, + flex, + eigen, + boost, + libGLU, + libGL, + glew, + opencsg, + cgal_4, + mpfr, + gmp, + glib, + pkg-config, + harfbuzz, + gettext, + freetype, + fontconfig, + double-conversion, + lib3mf, + libzip, + mkDerivation, + qtmacextras, + qmake, + spacenavSupport ? stdenv.hostPlatform.isLinux, + libspnav, + wayland, + wayland-protocols, + wrapGAppsHook3, + qtwayland, + cairo, + openscad, + runCommand, }: mkDerivation rec { @@ -60,23 +64,53 @@ mkDerivation rec { }) ]; - nativeBuildInputs = [ bison flex pkg-config gettext qmake wrapGAppsHook3]; + nativeBuildInputs = [ + bison + flex + pkg-config + gettext + qmake + wrapGAppsHook3 + ]; - buildInputs = [ - eigen boost glew opencsg cgal_4 mpfr gmp glib - harfbuzz lib3mf libzip double-conversion freetype fontconfig - qtbase qtmultimedia qscintilla cairo - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libGLU libGL wayland wayland-protocols qtwayland ] + buildInputs = + [ + eigen + boost + glew + opencsg + cgal_4 + mpfr + gmp + glib + harfbuzz + lib3mf + libzip + double-conversion + freetype + fontconfig + qtbase + qtmultimedia + qscintilla + cairo + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libGLU + libGL + wayland + wayland-protocols + qtwayland + ] ++ lib.optional stdenv.hostPlatform.isDarwin qtmacextras - ++ lib.optional spacenavSupport libspnav - ; + ++ lib.optional spacenavSupport libspnav; - qmakeFlags = [ - "VERSION=${version}" - "LIB3MF_INCLUDEPATH=${lib3mf.dev}/include/lib3mf/Bindings/Cpp" - "LIB3MF_LIBPATH=${lib3mf}/lib" - ] ++ - lib.optionals spacenavSupport [ + qmakeFlags = + [ + "VERSION=${version}" + "LIB3MF_INCLUDEPATH=${lib3mf.dev}/include/lib3mf/Bindings/Cpp" + "LIB3MF_LIBPATH=${lib3mf}/lib" + ] + ++ lib.optionals spacenavSupport [ "ENABLE_SPNAV=1" "SPNAV_INCLUDEPATH=${libspnav}/include" "SPNAV_LIBPATH=${libspnav}/lib" @@ -115,17 +149,24 @@ mkDerivation rec { homepage = "https://openscad.org/"; license = lib.licenses.gpl2; platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ bjornfor raskin gebner ]; + maintainers = with lib.maintainers; [ + bjornfor + raskin + gebner + ]; mainProgram = "openscad"; }; passthru.tests = { - lib3mf_support = runCommand "${pname}-lib3mf-support-test" { - nativeBuildInputs = [ openscad ]; - } '' - echo "cube([1, 1, 1]);" | openscad -o cube.3mf - - echo "import(\"cube.3mf\");" | openscad -o cube-import.3mf - - mv cube-import.3mf $out - ''; + lib3mf_support = + runCommand "${pname}-lib3mf-support-test" + { + nativeBuildInputs = [ openscad ]; + } + '' + echo "cube([1, 1, 1]);" | openscad -o cube.3mf - + echo "import(\"cube.3mf\");" | openscad -o cube-import.3mf - + mv cube-import.3mf $out + ''; }; } diff --git a/pkgs/applications/graphics/opentoonz/default.nix b/pkgs/applications/graphics/opentoonz/default.nix index a474550820ba30..c53122f52434ec 100644 --- a/pkgs/applications/graphics/opentoonz/default.nix +++ b/pkgs/applications/graphics/opentoonz/default.nix @@ -1,29 +1,30 @@ -{ boost -, cmake -, fetchFromGitHub -, libglut -, freetype -, glew -, libjpeg -, libmypaint -, libpng -, libusb1 -, lz4 -, xz -, lzo -, openblas -, opencv -, pkg-config -, qtbase -, qtmultimedia -, qtscript -, qtserialport -, lib -, stdenv -, superlu -, wrapQtAppsHook -, libtiff -, zlib +{ + boost, + cmake, + fetchFromGitHub, + libglut, + freetype, + glew, + libjpeg, + libmypaint, + libpng, + libusb1, + lz4, + xz, + lzo, + openblas, + opencv, + pkg-config, + qtbase, + qtmultimedia, + qtscript, + qtserialport, + lib, + stdenv, + superlu, + wrapQtAppsHook, + libtiff, + zlib, }: let libtiff-ver = "4.0.3"; # The version in thirdparty/tiff-* @@ -45,10 +46,20 @@ let version = "${libtiff-ver}-opentoonz"; inherit src; - outputs = [ "bin" "dev" "out" "man" "doc" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + "doc" + ]; nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ zlib libjpeg xz ]; + propagatedBuildInputs = [ + zlib + libjpeg + xz + ]; postUnpack = '' sourceRoot="$sourceRoot/thirdparty/tiff-${libtiff-ver}" @@ -89,7 +100,11 @@ stdenv.mkDerivation { pname = "opentoonz"; version = opentoonz-ver; - nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapQtAppsHook + ]; buildInputs = [ boost diff --git a/pkgs/applications/graphics/pencil/default.nix b/pkgs/applications/graphics/pencil/default.nix index 96d9ddd0ab2174..35cbfbf83c1703 100644 --- a/pkgs/applications/graphics/pencil/default.nix +++ b/pkgs/applications/graphics/pencil/default.nix @@ -1,8 +1,30 @@ -{ stdenv, fetchurl, lib, makeWrapper, wrapGAppsHook3, +{ + stdenv, + fetchurl, + lib, + makeWrapper, + wrapGAppsHook3, # build dependencies - alsa-lib, atk, at-spi2-atk, at-spi2-core, cairo, cups, dbus, expat, fontconfig, - freetype, gdk-pixbuf, glib, glibc, gtk3, libuuid, nspr, nss, pango, - xorg, systemd + alsa-lib, + atk, + at-spi2-atk, + at-spi2-core, + cairo, + cups, + dbus, + expat, + fontconfig, + freetype, + gdk-pixbuf, + glib, + glibc, + gtk3, + libuuid, + nspr, + nss, + pango, + xorg, + systemd, }: let @@ -41,12 +63,13 @@ let stdenv.cc.cc ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { version = "3.1.0"; pname = "pencil"; src = fetchurl { - url = "http://pencil.evolus.vn/dl/V${version}.ga/pencil_${version}.ga_amd64.deb"; + url = "http://pencil.evolus.vn/dl/V${version}.ga/pencil_${version}.ga_amd64.deb"; sha256 = "01ae54b1a1351b909eb2366c6ec00816e1deba370e58f35601cf7368f10aaba3"; }; @@ -58,7 +81,10 @@ in stdenv.mkDerivation rec { dontBuild = true; - nativeBuildInputs = [ makeWrapper wrapGAppsHook3 ]; + nativeBuildInputs = [ + makeWrapper + wrapGAppsHook3 + ]; buildInputs = deps; @@ -77,32 +103,37 @@ in stdenv.mkDerivation rec { ln -s $out/opt/pencil/pencil $out/bin/pencil ''; + preFixup = + let + packages = deps; + libPathNative = lib.makeLibraryPath packages; + libPath64 = lib.makeSearchPathOutput "lib" "lib64" packages; + libPath = "${libPathNative}:${libPath64}"; + in + '' + # patch executable + patchelf \ + --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ + --set-rpath "${libPath}:$out/opt/pencil" \ + $out/opt/pencil/pencil - preFixup = let - packages = deps; - libPathNative = lib.makeLibraryPath packages; - libPath64 = lib.makeSearchPathOutput "lib" "lib64" packages; - libPath = "${libPathNative}:${libPath64}"; - in '' - # patch executable - patchelf \ - --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath "${libPath}:$out/opt/pencil" \ - $out/opt/pencil/pencil - - # fix missing libudev - ln -s ${lib.getLib systemd}/lib/libudev.so.1 $out/opt/pencil/libudev.so.1 - wrapProgram $out/opt/pencil/pencil \ - --prefix LD_LIBRARY_PATH : $out/opt/pencil - ''; + # fix missing libudev + ln -s ${lib.getLib systemd}/lib/libudev.so.1 $out/opt/pencil/libudev.so.1 + wrapProgram $out/opt/pencil/pencil \ + --prefix LD_LIBRARY_PATH : $out/opt/pencil + ''; meta = with lib; { description = "GUI prototyping/mockup tool"; mainProgram = "pencil"; - homepage = "https://pencil.evolus.vn/"; + homepage = "https://pencil.evolus.vn/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.gpl2; # Commercial license is also available - maintainers = with maintainers; [ bjornfor prikhi mrVanDalo ]; - platforms = platforms.linux; + license = licenses.gpl2; # Commercial license is also available + maintainers = with maintainers; [ + bjornfor + prikhi + mrVanDalo + ]; + platforms = platforms.linux; }; } diff --git a/pkgs/applications/graphics/photoflare/default.nix b/pkgs/applications/graphics/photoflare/default.nix index bb79b8c8ddc0f3..75645349377b37 100644 --- a/pkgs/applications/graphics/photoflare/default.nix +++ b/pkgs/applications/graphics/photoflare/default.nix @@ -1,4 +1,11 @@ -{ mkDerivation, lib, graphicsmagick, fetchFromGitHub, qmake, qtbase, qttools +{ + mkDerivation, + lib, + graphicsmagick, + fetchFromGitHub, + qmake, + qtbase, + qttools, }: mkDerivation rec { @@ -12,8 +19,14 @@ mkDerivation rec { sha256 = "sha256-0eAuof/FBro2IKxkJ6JHauW6C96VTPxy7QtfPVzPFi4="; }; - nativeBuildInputs = [ qmake qttools ]; - buildInputs = [ qtbase graphicsmagick ]; + nativeBuildInputs = [ + qmake + qttools + ]; + buildInputs = [ + qtbase + graphicsmagick + ]; qmakeFlags = [ "PREFIX=${placeholder "out"}" ]; diff --git a/pkgs/applications/graphics/phototonic/default.nix b/pkgs/applications/graphics/phototonic/default.nix index e3fea1ee9c4782..fca4490d34489c 100644 --- a/pkgs/applications/graphics/phototonic/default.nix +++ b/pkgs/applications/graphics/phototonic/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, qmake, wrapQtAppsHook, qtbase, exiv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + qmake, + wrapQtAppsHook, + qtbase, + exiv2, +}: stdenv.mkDerivation rec { pname = "phototonic"; @@ -19,8 +28,14 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; - buildInputs = [ qtbase exiv2 ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; + buildInputs = [ + qtbase + exiv2 + ]; preConfigure = '' sed -i 's;/usr;$$PREFIX/;g' phototonic.pro diff --git a/pkgs/applications/graphics/pick-colour-picker/default.nix b/pkgs/applications/graphics/pick-colour-picker/default.nix index b255db33625646..4e72738134d525 100644 --- a/pkgs/applications/graphics/pick-colour-picker/default.nix +++ b/pkgs/applications/graphics/pick-colour-picker/default.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, buildPythonPackage -, pygobject3 -, pycairo -, glib -, gtk3 -, gobject-introspection -, wrapGAppsHook3 +{ + lib, + fetchFromGitHub, + buildPythonPackage, + pygobject3, + pycairo, + glib, + gtk3, + gobject-introspection, + wrapGAppsHook3, }: buildPythonPackage rec { @@ -53,6 +54,6 @@ buildPythonPackage rec { Pick lets you pick colours from anywhere on your screen. Choose the colour you want and Pick remembers it, names it, and shows you a screenshot so you can remember where you got it from. Zoom all the way in to pixels to pick just the right one. Show your colours in your choice of format: rgba() or hex, CSS or Gdk or Qt, whichever you prefer. Copy to the clipboard ready for pasting into code or graphics apps. - ''; + ''; }; } diff --git a/pkgs/applications/graphics/pixinsight/default.nix b/pkgs/applications/graphics/pixinsight/default.nix index a6692b350f3c2c..3cce7faf76d0f6 100644 --- a/pkgs/applications/graphics/pixinsight/default.nix +++ b/pkgs/applications/graphics/pixinsight/default.nix @@ -1,49 +1,50 @@ -{ stdenv -, lib -, requireFile -, wrapQtAppsHook -, autoPatchelfHook -, unixtools -, fakeroot -, mailcap -, libGL -, libpulseaudio -, alsa-lib -, nss -, gd -, gst_all_1 -, nspr -, expat -, fontconfig -, dbus -, glib -, zlib -, openssl -, libdrm -, cups -, avahi-compat -, xorg -, wayland -, libudev0-shim -, bubblewrap -, libjpeg8 -, gdk-pixbuf -, gtk3 -, pango +{ + stdenv, + lib, + requireFile, + wrapQtAppsHook, + autoPatchelfHook, + unixtools, + fakeroot, + mailcap, + libGL, + libpulseaudio, + alsa-lib, + nss, + gd, + gst_all_1, + nspr, + expat, + fontconfig, + dbus, + glib, + zlib, + openssl, + libdrm, + cups, + avahi-compat, + xorg, + wayland, + libudev0-shim, + bubblewrap, + libjpeg8, + gdk-pixbuf, + gtk3, + pango, # Qt 6 subpackages -, qtbase -, qtserialport -, qtserialbus -, qtvirtualkeyboard -, qtmultimedia -, qt3d -, mlt -, qtlocation -, qtwebengine -, qtquick3d -, qtwayland -, qtwebview -, qtscxml + qtbase, + qtserialport, + qtserialbus, + qtvirtualkeyboard, + qtmultimedia, + qt3d, + mlt, + qtlocation, + qtwebengine, + qtquick3d, + qtwayland, + qtwebview, + qtscxml, }: stdenv.mkDerivation (finalAttrs: { @@ -74,57 +75,59 @@ stdenv.mkDerivation (finalAttrs: { bubblewrap ]; - buildInputs = [ - (lib.getLib stdenv.cc.cc) - stdenv.cc - libGL - libpulseaudio - alsa-lib - nss - gd - gst_all_1.gstreamer - gst_all_1.gst-plugins-base - nspr - expat - fontconfig - dbus - glib - zlib - openssl - libdrm - wayland - cups - avahi-compat - libjpeg8 - gdk-pixbuf - gtk3 - pango - # Qt stuff - qt3d - mlt - qtbase - #qtgamepad - qtserialport - qtserialbus - qtvirtualkeyboard - qtmultimedia - qtlocation - qtwebengine - qtquick3d - qtwayland - qtwebview - qtscxml - ] ++ (with xorg; [ - libX11 - libXdamage - xrandr - libXtst - libXcomposite - libXext - libXfixes - libXrandr - libxkbfile - ]); + buildInputs = + [ + (lib.getLib stdenv.cc.cc) + stdenv.cc + libGL + libpulseaudio + alsa-lib + nss + gd + gst_all_1.gstreamer + gst_all_1.gst-plugins-base + nspr + expat + fontconfig + dbus + glib + zlib + openssl + libdrm + wayland + cups + avahi-compat + libjpeg8 + gdk-pixbuf + gtk3 + pango + # Qt stuff + qt3d + mlt + qtbase + #qtgamepad + qtserialport + qtserialbus + qtvirtualkeyboard + qtmultimedia + qtlocation + qtwebengine + qtquick3d + qtwayland + qtwebview + qtscxml + ] + ++ (with xorg; [ + libX11 + libXdamage + xrandr + libXtst + libXcomposite + libXext + libXfixes + libXrandr + libxkbfile + ]); postPatch = '' patchelf ./installer \ diff --git a/pkgs/applications/graphics/pymeshlab/default.nix b/pkgs/applications/graphics/pymeshlab/default.nix index 4a4653b4522720..a44d4c4f5bee69 100644 --- a/pkgs/applications/graphics/pymeshlab/default.nix +++ b/pkgs/applications/graphics/pymeshlab/default.nix @@ -1,32 +1,33 @@ -{ stdenv -, lib -, fetchFromGitHub -, libGLU -, qtbase -, qtscript -, qtxmlpatterns -, lib3ds -, bzip2 -, muparser -, eigen -, glew -, gmp -, levmar -, qhull -, cmake -, cgal -, boost -, mpfr -, xercesc -, tbb -, embree -, vcg -, libigl -, corto -, openctm -, structuresynth -, wrapQtAppsHook -, python3Packages +{ + stdenv, + lib, + fetchFromGitHub, + libGLU, + qtbase, + qtscript, + qtxmlpatterns, + lib3ds, + bzip2, + muparser, + eigen, + glew, + gmp, + levmar, + qhull, + cmake, + cgal, + boost, + mpfr, + xercesc, + tbb, + embree, + vcg, + libigl, + corto, + openctm, + structuresynth, + wrapQtAppsHook, + python3Packages, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/graphics/qcomicbook/default.nix b/pkgs/applications/graphics/qcomicbook/default.nix index ee2296b391bb24..734a49f026227e 100644 --- a/pkgs/applications/graphics/qcomicbook/default.nix +++ b/pkgs/applications/graphics/qcomicbook/default.nix @@ -1,4 +1,14 @@ -{ mkDerivation, lib, fetchFromGitHub, pkg-config, cmake, qtbase, qttools, qtx11extras, poppler }: +{ + mkDerivation, + lib, + fetchFromGitHub, + pkg-config, + cmake, + qtbase, + qttools, + qtx11extras, + poppler, +}: mkDerivation rec { pname = "qcomicbook"; @@ -12,11 +22,15 @@ mkDerivation rec { }; nativeBuildInputs = [ - cmake pkg-config + cmake + pkg-config ]; buildInputs = [ - qtbase qttools qtx11extras poppler + qtbase + qttools + qtx11extras + poppler ]; postInstall = '' diff --git a/pkgs/applications/graphics/qimgv/default.nix b/pkgs/applications/graphics/qimgv/default.nix index f4eedb6c3fb0ee..6bd3fabee5e135 100644 --- a/pkgs/applications/graphics/qimgv/default.nix +++ b/pkgs/applications/graphics/qimgv/default.nix @@ -1,16 +1,17 @@ -{ mkDerivation -, lib -, fetchFromGitHub +{ + mkDerivation, + lib, + fetchFromGitHub, -, cmake -, pkg-config + cmake, + pkg-config, -, exiv2 -, mpv -, opencv4 -, qtbase -, qtimageformats -, qtsvg + exiv2, + mpv, + opencv4, + qtbase, + qtimageformats, + qtsvg, }: mkDerivation rec { diff --git a/pkgs/applications/graphics/qiv/default.nix b/pkgs/applications/graphics/qiv/default.nix index 2758148dc1ae3a..311ed40220f372 100644 --- a/pkgs/applications/graphics/qiv/default.nix +++ b/pkgs/applications/graphics/qiv/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, pkg-config, gtk2, imlib2, file, lcms2, libexif } : +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + imlib2, + file, + lcms2, + libexif, +}: stdenv.mkDerivation (rec { version = "2.3.3"; @@ -10,9 +20,15 @@ stdenv.mkDerivation (rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk2 imlib2 file lcms2 libexif ]; + buildInputs = [ + gtk2 + imlib2 + file + lcms2 + libexif + ]; - preBuild='' + preBuild = '' substituteInPlace Makefile --replace /usr/local "$out" substituteInPlace Makefile --replace /man/ /share/man/ substituteInPlace Makefile --replace /share/share/ /share/ diff --git a/pkgs/applications/graphics/qosmic/default.nix b/pkgs/applications/graphics/qosmic/default.nix index eab80b018ccc8a..3643a9e7af4f07 100644 --- a/pkgs/applications/graphics/qosmic/default.nix +++ b/pkgs/applications/graphics/qosmic/default.nix @@ -1,16 +1,17 @@ -{ stdenv -, fetchFromGitHub -, fetchpatch -, qmake -, wrapQtAppsHook -, qtbase -, pkg-config -, lua -, flam3 -, libxml2 -, libpng -, libjpeg -, lib +{ + stdenv, + fetchFromGitHub, + fetchpatch, + qmake, + wrapQtAppsHook, + qtbase, + pkg-config, + lua, + flam3, + libxml2, + libpng, + libjpeg, + lib, }: stdenv.mkDerivation rec { @@ -49,7 +50,11 @@ stdenv.mkDerivation rec { --replace "install_icons install_desktop" "" ''; - nativeBuildInputs = [ qmake wrapQtAppsHook pkg-config ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + pkg-config + ]; buildInputs = [ qtbase diff --git a/pkgs/applications/graphics/qscreenshot/default.nix b/pkgs/applications/graphics/qscreenshot/default.nix index d8ed2a14e925af..3120503b07391b 100644 --- a/pkgs/applications/graphics/qscreenshot/default.nix +++ b/pkgs/applications/graphics/qscreenshot/default.nix @@ -1,11 +1,13 @@ -{ stdenv -, lib -, fetchgit -, qtbase -, qttools -, qtx11extras -, wrapQtAppsHook -, cmake }: +{ + stdenv, + lib, + fetchgit, + qtbase, + qttools, + qtx11extras, + wrapQtAppsHook, + cmake, +}: stdenv.mkDerivation rec { pname = "qscreenshot"; diff --git a/pkgs/applications/graphics/qvge/default.nix b/pkgs/applications/graphics/qvge/default.nix index ef4e17fcce812d..1ded1a805ca7e9 100644 --- a/pkgs/applications/graphics/qvge/default.nix +++ b/pkgs/applications/graphics/qvge/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, substituteAll -, wrapQtAppsHook -, qmake -, qtsvg -, qtx11extras -, graphviz +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + wrapQtAppsHook, + qmake, + qtsvg, + qtx11extras, + graphviz, }: stdenv.mkDerivation rec { @@ -22,12 +23,17 @@ stdenv.mkDerivation rec { sourceRoot = "${src.name}/src"; - patches = (substituteAll { - src = ./set-graphviz-path.patch; - inherit graphviz; - }); + patches = ( + substituteAll { + src = ./set-graphviz-path.patch; + inherit graphviz; + } + ); - nativeBuildInputs = [ wrapQtAppsHook qmake ]; + nativeBuildInputs = [ + wrapQtAppsHook + qmake + ]; buildInputs = if stdenv.hostPlatform.isDarwin then [ qtsvg ] else [ qtx11extras ]; diff --git a/pkgs/applications/graphics/qview/default.nix b/pkgs/applications/graphics/qview/default.nix index 38ff606487c0a2..eb2f81c939845a 100644 --- a/pkgs/applications/graphics/qview/default.nix +++ b/pkgs/applications/graphics/qview/default.nix @@ -1,13 +1,14 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, qmake -, qtbase -, qttools -, qtimageformats -, qtsvg -, qtx11extras -, x11Support ? true +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qtbase, + qttools, + qtimageformats, + qtsvg, + qtx11extras, + x11Support ? true, }: mkDerivation rec { diff --git a/pkgs/applications/graphics/rapid-photo-downloader/default.nix b/pkgs/applications/graphics/rapid-photo-downloader/default.nix index 8b952ab79d8404..f7a2685169ca88 100644 --- a/pkgs/applications/graphics/rapid-photo-downloader/default.nix +++ b/pkgs/applications/graphics/rapid-photo-downloader/default.nix @@ -1,7 +1,22 @@ -{ lib, mkDerivationWith, fetchFromGitHub, python3Packages -, file, intltool, gobject-introspection, libgudev -, udisks, gexiv2, gst_all_1, libnotify, ifuse, libimobiledevice -, exiftool, gdk-pixbuf, libmediainfo, vmtouch +{ + lib, + mkDerivationWith, + fetchFromGitHub, + python3Packages, + file, + intltool, + gobject-introspection, + libgudev, + udisks, + gexiv2, + gst_all_1, + libnotify, + ifuse, + libimobiledevice, + exiftool, + gdk-pixbuf, + libmediainfo, + vmtouch, }: mkDerivationWith python3Packages.buildPythonApplication rec { @@ -57,38 +72,46 @@ mkDerivationWith python3Packages.buildPythonApplication rec { # "Namespace [Notify / GExiv2 / GUdev] not available" strictDeps = false; - propagatedBuildInputs = with python3Packages; [ - ifuse - libimobiledevice - pyqt5 - pygobject3 - gphoto2 - pyzmq - tornado - psutil - pyxdg - arrow - python-dateutil - easygui - babel - colour - pillow - pyheif - pymediainfo - sortedcontainers - requests - colorlog - pyprind - setuptools - show-in-file-manager - tenacity - ] ++ lib.optional (pythonOlder "3.8") importlib-metadata; + propagatedBuildInputs = + with python3Packages; + [ + ifuse + libimobiledevice + pyqt5 + pygobject3 + gphoto2 + pyzmq + tornado + psutil + pyxdg + arrow + python-dateutil + easygui + babel + colour + pillow + pyheif + pymediainfo + sortedcontainers + requests + colorlog + pyprind + setuptools + show-in-file-manager + tenacity + ] + ++ lib.optional (pythonOlder "3.8") importlib-metadata; preFixup = '' makeWrapperArgs+=( --set GI_TYPELIB_PATH "$GI_TYPELIB_PATH" --set PYTHONPATH "$PYTHONPATH" - --prefix PATH : "${lib.makeBinPath [ exiftool vmtouch ]}" + --prefix PATH : "${ + lib.makeBinPath [ + exiftool + vmtouch + ] + }" --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ libmediainfo ]}" --prefix GST_PLUGIN_SYSTEM_PATH_1_0 : "$GST_PLUGIN_SYSTEM_PATH_1_0" "''${qtWrapperArgs[@]}" diff --git a/pkgs/applications/graphics/rawtherapee/default.nix b/pkgs/applications/graphics/rawtherapee/default.nix index deb45b06d19f17..b4493bdbc41cd1 100644 --- a/pkgs/applications/graphics/rawtherapee/default.nix +++ b/pkgs/applications/graphics/rawtherapee/default.nix @@ -1,37 +1,38 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, util-linux -, libselinux -, libsepol -, lerc -, libthai -, libdatrie -, libxkbcommon -, libepoxy -, libXtst -, wrapGAppsHook3 -, makeWrapper -, pixman -, libpthreadstubs -, gtkmm3 -, libXau -, libXdmcp -, lcms2 -, libiptcdata -, fftw -, expat -, pcre2 -, libsigcxx -, lensfun -, librsvg -, libcanberra-gtk3 -, gtk-mac-integration -, exiv2 -, libraw - , libjxl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + util-linux, + libselinux, + libsepol, + lerc, + libthai, + libdatrie, + libxkbcommon, + libepoxy, + libXtst, + wrapGAppsHook3, + makeWrapper, + pixman, + libpthreadstubs, + gtkmm3, + libXau, + libXdmcp, + lcms2, + libiptcdata, + fftw, + expat, + pcre2, + libsigcxx, + lensfun, + librsvg, + libcanberra-gtk3, + gtk-mac-integration, + exiv2, + libraw, + libjxl, }: stdenv.mkDerivation rec { @@ -54,54 +55,61 @@ stdenv.mkDerivation rec { --replace "/Applications" "${placeholder "out"}/Applications" ''; - nativeBuildInputs = [ - cmake - pkg-config - wrapGAppsHook3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - makeWrapper - ]; + nativeBuildInputs = + [ + cmake + pkg-config + wrapGAppsHook3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + makeWrapper + ]; - buildInputs = [ - util-linux - libselinux - libsepol - lerc - libthai - libdatrie - libxkbcommon - libepoxy - libXtst - pixman - libpthreadstubs - gtkmm3 - libXau - libXdmcp - lcms2 - libiptcdata - fftw - expat - pcre2 - libsigcxx - lensfun - librsvg - exiv2 - libraw - libjxl - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libcanberra-gtk3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - gtk-mac-integration - ]; + buildInputs = + [ + util-linux + libselinux + libsepol + lerc + libthai + libdatrie + libxkbcommon + libepoxy + libXtst + pixman + libpthreadstubs + gtkmm3 + libXau + libXdmcp + lcms2 + libiptcdata + fftw + expat + pcre2 + libsigcxx + lensfun + librsvg + exiv2 + libraw + libjxl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libcanberra-gtk3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + gtk-mac-integration + ]; - cmakeFlags = [ - "-DPROC_TARGET_NUMBER=2" - "-DCACHE_NAME_SUFFIX=\"\"" - "-DWITH_SYSTEM_LIBRAW=\"ON\"" - "-DWITH_JXL=\"ON\"" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DCMAKE_OSX_DEPLOYMENT_TARGET=${stdenv.hostPlatform.darwinMinVersion}" - ]; + cmakeFlags = + [ + "-DPROC_TARGET_NUMBER=2" + "-DCACHE_NAME_SUFFIX=\"\"" + "-DWITH_SYSTEM_LIBRAW=\"ON\"" + "-DWITH_JXL=\"ON\"" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DCMAKE_OSX_DEPLOYMENT_TARGET=${stdenv.hostPlatform.darwinMinVersion}" + ]; CMAKE_CXX_FLAGS = toString [ "-std=c++11" @@ -122,7 +130,10 @@ stdenv.mkDerivation rec { description = "RAW converter and digital photo processing software"; homepage = "http://www.rawtherapee.com/"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ jcumming mahe ]; + maintainers = with lib.maintainers; [ + jcumming + mahe + ]; platforms = with lib.platforms; unix; }; } diff --git a/pkgs/applications/graphics/sane/backends/default.nix b/pkgs/applications/graphics/sane/backends/default.nix index 55fbc9a3616a7a..4532d7317c571a 100644 --- a/pkgs/applications/graphics/sane/backends/default.nix +++ b/pkgs/applications/graphics/sane/backends/default.nix @@ -28,14 +28,16 @@ libtool, autoconf-archive, -# List of { src name backend } attibute sets - see installFirmware below: - extraFirmware ? [], + # List of { src name backend } attibute sets - see installFirmware below: + extraFirmware ? [ ], -# For backwards compatibility with older setups; use extraFirmware instead: - gt68xxFirmware ? null, snapscanFirmware ? null, + # For backwards compatibility with older setups; use extraFirmware instead: + gt68xxFirmware ? null, + snapscanFirmware ? null, -# Not included by default, scan snap drivers require fetching of unfree binaries. - scanSnapDriversUnfree ? false, scanSnapDriversPackage ? sane-drivers.epjitsu, + # Not included by default, scan snap drivers require fetching of unfree binaries. + scanSnapDriversUnfree ? false, + scanSnapDriversPackage ? sane-drivers.epjitsu, }: stdenv.mkDerivation rec { @@ -74,7 +76,11 @@ stdenv.mkDerivation rec { patch -p1 -i ${./sane-desc-cross.patch} ''; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; depsBuildBuild = [ buildPackages.stdenv.cc ]; @@ -88,28 +94,31 @@ stdenv.mkDerivation rec { python3 ]; - buildInputs = [ - avahi - libgphoto2 - libjpeg - libpng - libtiff - libusb1 - curl - libxml2 - poppler - gawk - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libieee1284 - libv4l - net-snmp - systemd - ]; + buildInputs = + [ + avahi + libgphoto2 + libjpeg + libpng + libtiff + libusb1 + curl + libxml2 + poppler + gawk + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libieee1284 + libv4l + net-snmp + systemd + ]; enableParallelBuilding = true; - configureFlags = [ "--with-lockdir=/var/lock/sane" ] - ++ lib.optional (avahi != null) "--with-avahi" + configureFlags = + [ "--with-lockdir=/var/lock/sane" ] + ++ lib.optional (avahi != null) "--with-avahi" ++ lib.optional (libusb1 != null) "--with-usb"; # autoconf check for HAVE_MMAP is never set on cross compilation. @@ -118,46 +127,49 @@ stdenv.mkDerivation rec { "CFLAGS=-DHAVE_MMAP=${if stdenv.hostPlatform.isLinux then "1" else "0"}" ]; - postInstall = let - - compatFirmware = extraFirmware - ++ lib.optional (gt68xxFirmware != null) { - src = gt68xxFirmware.fw; - inherit (gt68xxFirmware) name; - backend = "gt68xx"; - } - ++ lib.optional (snapscanFirmware != null) { - src = snapscanFirmware; - name = "your-firmwarefile.bin"; - backend = "snapscan"; - }; - - installFirmware = f: '' - mkdir -p $out/share/sane/${f.backend} - ln -sv ${f.src} $out/share/sane/${f.backend}/${f.name} - ''; - - in '' - mkdir -p $out/etc/udev/rules.d/ $out/etc/udev/hwdb.d - ./tools/sane-desc -m udev+hwdb -s doc/descriptions:doc/descriptions-external > $out/etc/udev/rules.d/49-libsane.rules - ./tools/sane-desc -m udev+hwdb -s doc/descriptions:doc/descriptions-external -m hwdb > $out/etc/udev/hwdb.d/20-sane.hwdb - # the created 49-libsane references /bin/sh - substituteInPlace $out/etc/udev/rules.d/49-libsane.rules \ - --replace "RUN+=\"/bin/sh" "RUN+=\"${runtimeShell}" - - substituteInPlace $out/lib/libsane.la \ - --replace "-ljpeg" "-L${lib.getLib libjpeg}/lib -ljpeg" - - # net.conf conflicts with the file generated by the nixos module - rm $out/etc/sane.d/net.conf - - '' - + lib.optionalString scanSnapDriversUnfree '' - # the ScanSnap drivers live under the epjitsu subdirectory, which was already created by the build but is empty. - rmdir $out/share/sane/epjitsu - ln -svT ${scanSnapDriversPackage} $out/share/sane/epjitsu - '' - + lib.concatStrings (builtins.map installFirmware compatFirmware); + postInstall = + let + + compatFirmware = + extraFirmware + ++ lib.optional (gt68xxFirmware != null) { + src = gt68xxFirmware.fw; + inherit (gt68xxFirmware) name; + backend = "gt68xx"; + } + ++ lib.optional (snapscanFirmware != null) { + src = snapscanFirmware; + name = "your-firmwarefile.bin"; + backend = "snapscan"; + }; + + installFirmware = f: '' + mkdir -p $out/share/sane/${f.backend} + ln -sv ${f.src} $out/share/sane/${f.backend}/${f.name} + ''; + + in + '' + mkdir -p $out/etc/udev/rules.d/ $out/etc/udev/hwdb.d + ./tools/sane-desc -m udev+hwdb -s doc/descriptions:doc/descriptions-external > $out/etc/udev/rules.d/49-libsane.rules + ./tools/sane-desc -m udev+hwdb -s doc/descriptions:doc/descriptions-external -m hwdb > $out/etc/udev/hwdb.d/20-sane.hwdb + # the created 49-libsane references /bin/sh + substituteInPlace $out/etc/udev/rules.d/49-libsane.rules \ + --replace "RUN+=\"/bin/sh" "RUN+=\"${runtimeShell}" + + substituteInPlace $out/lib/libsane.la \ + --replace "-ljpeg" "-L${lib.getLib libjpeg}/lib -ljpeg" + + # net.conf conflicts with the file generated by the nixos module + rm $out/etc/sane.d/net.conf + + '' + + lib.optionalString scanSnapDriversUnfree '' + # the ScanSnap drivers live under the epjitsu subdirectory, which was already created by the build but is empty. + rmdir $out/share/sane/epjitsu + ln -svT ${scanSnapDriversPackage} $out/share/sane/epjitsu + '' + + lib.concatStrings (builtins.map installFirmware compatFirmware); # parallel install creates a bad symlink at $out/lib/sane/libsane.so.1 which prevents finding plugins # https://github.com/NixOS/nixpkgs/issues/224569 diff --git a/pkgs/applications/graphics/sane/config.nix b/pkgs/applications/graphics/sane/config.nix index c637ff3cfcd320..07cb0736690b3d 100644 --- a/pkgs/applications/graphics/sane/config.nix +++ b/pkgs/applications/graphics/sane/config.nix @@ -1,53 +1,56 @@ { lib, stdenv }: -{ paths, disabledDefaultBackends ? [] }: - +{ + paths, + disabledDefaultBackends ? [ ], +}: let -installSanePath = path: '' - if [ -e "${path}/lib/sane" ]; then - find "${path}/lib/sane" -maxdepth 1 -not -type d | while read backend; do - symlink "$backend" "$out/lib/sane/$(basename "$backend")" - done - fi + installSanePath = path: '' + if [ -e "${path}/lib/sane" ]; then + find "${path}/lib/sane" -maxdepth 1 -not -type d | while read backend; do + symlink "$backend" "$out/lib/sane/$(basename "$backend")" + done + fi - if [ -e "${path}/etc/sane.d" ]; then - find "${path}/etc/sane.d" -maxdepth 1 -not -type d | while read conf; do - name="$(basename $conf)" - if [ "$name" = "dll.conf" ] || [ "$name" = "saned.conf" ] || [ "$name" = "net.conf" ]; then - cat "$conf" >> "$out/etc/sane.d/$name" - else - symlink "$conf" "$out/etc/sane.d/$name" - fi - done - fi + if [ -e "${path}/etc/sane.d" ]; then + find "${path}/etc/sane.d" -maxdepth 1 -not -type d | while read conf; do + name="$(basename $conf)" + if [ "$name" = "dll.conf" ] || [ "$name" = "saned.conf" ] || [ "$name" = "net.conf" ]; then + cat "$conf" >> "$out/etc/sane.d/$name" + else + symlink "$conf" "$out/etc/sane.d/$name" + fi + done + fi - if [ -e "${path}/etc/sane.d/dll.d" ]; then - find "${path}/etc/sane.d/dll.d" -maxdepth 1 -not -type d | while read conf; do - symlink "$conf" "$out/etc/sane.d/dll.d/$(basename $conf)" - done - fi - ''; - disableBackend = backend: '' - grep -w -q '${backend}' $out/etc/sane.d/dll.conf || { echo '${backend} is not a default plugin in $SANE_CONFIG_DIR/dll.conf'; exit 1; } - sed -i 's/\b${backend}\b/# ${backend} disabled by nixos config/' $out/etc/sane.d/dll.conf - ''; + if [ -e "${path}/etc/sane.d/dll.d" ]; then + find "${path}/etc/sane.d/dll.d" -maxdepth 1 -not -type d | while read conf; do + symlink "$conf" "$out/etc/sane.d/dll.d/$(basename $conf)" + done + fi + ''; + disableBackend = backend: '' + grep -w -q '${backend}' $out/etc/sane.d/dll.conf || { echo '${backend} is not a default plugin in $SANE_CONFIG_DIR/dll.conf'; exit 1; } + sed -i 's/\b${backend}\b/# ${backend} disabled by nixos config/' $out/etc/sane.d/dll.conf + ''; in stdenv.mkDerivation { name = "sane-config"; dontUnpack = true; - installPhase = '' - function symlink () { - local target=$1 linkname=$2 - if [ -e "$linkname" ]; then - echo "warning: conflict for $linkname. Overriding $(readlink $linkname) with $target." - fi - ln -sfn "$target" "$linkname" - } + installPhase = + '' + function symlink () { + local target=$1 linkname=$2 + if [ -e "$linkname" ]; then + echo "warning: conflict for $linkname. Overriding $(readlink $linkname) with $target." + fi + ln -sfn "$target" "$linkname" + } - mkdir -p $out/etc/sane.d $out/etc/sane.d/dll.d $out/lib/sane - '' - + (lib.concatMapStrings installSanePath paths) - + (lib.concatMapStrings disableBackend disabledDefaultBackends); + mkdir -p $out/etc/sane.d $out/etc/sane.d/dll.d $out/lib/sane + '' + + (lib.concatMapStrings installSanePath paths) + + (lib.concatMapStrings disableBackend disabledDefaultBackends); } diff --git a/pkgs/applications/graphics/sane/frontends.nix b/pkgs/applications/graphics/sane/frontends.nix index d34ab9856fca5f..5cbc2dd2988221 100644 --- a/pkgs/applications/graphics/sane/frontends.nix +++ b/pkgs/applications/graphics/sane/frontends.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, sane-backends, libX11, gtk2, pkg-config, libusb-compat-0_1 ? null }: +{ + lib, + stdenv, + fetchurl, + sane-backends, + libX11, + gtk2, + pkg-config, + libusb-compat-0_1 ? null, +}: stdenv.mkDerivation rec { pname = "sane-frontends"; @@ -13,16 +22,19 @@ stdenv.mkDerivation rec { sed -e '/SANE_CAP_ALWAYS_SETTABLE/d' -i src/gtkglue.c ''; - buildInputs = [ sane-backends libX11 gtk2 ] - ++ lib.optional (libusb-compat-0_1 != null) libusb-compat-0_1; + buildInputs = [ + sane-backends + libX11 + gtk2 + ] ++ lib.optional (libusb-compat-0_1 != null) libusb-compat-0_1; nativeBuildInputs = [ pkg-config ]; enableParallelBuilding = true; meta = with lib; { description = "Scanner Access Now Easy"; - homepage = "http://www.sane-project.org/"; - license = licenses.gpl2Plus; - platforms = platforms.linux; + homepage = "http://www.sane-project.org/"; + license = licenses.gpl2Plus; + platforms = platforms.linux; }; } diff --git a/pkgs/applications/graphics/sane/xsane.nix b/pkgs/applications/graphics/sane/xsane.nix index e9a1ca2c40de01..773474edd8914a 100644 --- a/pkgs/applications/graphics/sane/xsane.nix +++ b/pkgs/applications/graphics/sane/xsane.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitLab -, sane-backends -, sane-frontends -, libX11 -, gtk2 -, pkg-config -, libpng -, libusb-compat-0_1 -, gimpSupport ? false -, gimp -, nix-update-script -, fetchpatch +{ + lib, + stdenv, + fetchFromGitLab, + sane-backends, + sane-frontends, + libX11, + gtk2, + pkg-config, + libpng, + libusb-compat-0_1, + gimpSupport ? false, + gimp, + nix-update-script, + fetchpatch, }: stdenv.mkDerivation rec { @@ -40,8 +41,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libpng libusb-compat-0_1 sane-backends sane-frontends libX11 gtk2 ] - ++ lib.optional gimpSupport gimp; + buildInputs = [ + libpng + libusb-compat-0_1 + sane-backends + sane-frontends + libX11 + gtk2 + ] ++ lib.optional gimpSupport gimp; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/applications/graphics/scantailor/advanced.nix b/pkgs/applications/graphics/scantailor/advanced.nix index b85e0bdc6042d3..954ddb4f407c20 100644 --- a/pkgs/applications/graphics/scantailor/advanced.nix +++ b/pkgs/applications/graphics/scantailor/advanced.nix @@ -1,6 +1,15 @@ -{ lib, fetchFromGitHub, mkDerivation -, cmake, libjpeg, libpng, libtiff, boost -, qtbase, qttools }: +{ + lib, + fetchFromGitHub, + mkDerivation, + cmake, + libjpeg, + libpng, + libtiff, + boost, + qtbase, + qttools, +}: mkDerivation rec { pname = "scantailor-advanced"; @@ -13,8 +22,17 @@ mkDerivation rec { sha256 = "sha256-mvoCoYdRTgXW5t8yd9Y9TOl7D3RDVwcjUv2YDUWrtRI="; }; - nativeBuildInputs = [ cmake qttools ]; - buildInputs = [ libjpeg libpng libtiff boost qtbase ]; + nativeBuildInputs = [ + cmake + qttools + ]; + buildInputs = [ + libjpeg + libpng + libtiff + boost + qtbase + ]; meta = with lib; { homepage = "https://github.com/vigri/scantailor-advanced"; diff --git a/pkgs/applications/graphics/scantailor/universal.nix b/pkgs/applications/graphics/scantailor/universal.nix index 31d5c6ca65707f..b7bdc609f61c8a 100644 --- a/pkgs/applications/graphics/scantailor/universal.nix +++ b/pkgs/applications/graphics/scantailor/universal.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, mkDerivation -, fetchFromGitHub -, cmake -, qtbase -, qttools -, wrapQtAppsHook -, zlib -, openjpeg -, libjpeg_turbo -, libpng -, libtiff -, boost -, libcanberra +{ + lib, + stdenv, + mkDerivation, + fetchFromGitHub, + cmake, + qtbase, + qttools, + wrapQtAppsHook, + zlib, + openjpeg, + libjpeg_turbo, + libpng, + libtiff, + boost, + libcanberra, }: stdenv.mkDerivation rec { @@ -27,8 +28,21 @@ stdenv.mkDerivation rec { hash = "sha256-n8NbokK+U0FAuYXtjRJcxlI1XAmI4hk5zV3sF86hB/s="; }; - buildInputs = [ qtbase zlib libjpeg_turbo libpng libtiff boost libcanberra openjpeg ]; - nativeBuildInputs = [ cmake wrapQtAppsHook qttools ]; + buildInputs = [ + qtbase + zlib + libjpeg_turbo + libpng + libtiff + boost + libcanberra + openjpeg + ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + qttools + ]; meta = with lib; { description = "Interactive post-processing tool for scanned pages"; diff --git a/pkgs/applications/graphics/seamly2d/default.nix b/pkgs/applications/graphics/seamly2d/default.nix index b25c9b6dacfe87..295f6887488797 100644 --- a/pkgs/applications/graphics/seamly2d/default.nix +++ b/pkgs/applications/graphics/seamly2d/default.nix @@ -1,6 +1,22 @@ -{ stdenv, lib, qtbase, wrapQtAppsHook, fetchFromGitHub, - addDriverRunpath, poppler_utils, qtxmlpatterns, qtsvg, mesa, xvfb-run, - fontconfig, freetype, xorg, qmake, python3, qttools, git +{ + stdenv, + lib, + qtbase, + wrapQtAppsHook, + fetchFromGitHub, + addDriverRunpath, + poppler_utils, + qtxmlpatterns, + qtsvg, + mesa, + xvfb-run, + fontconfig, + freetype, + xorg, + qmake, + python3, + qttools, + git, }: let qtPython = python3.withPackages (pkgs: with pkgs; [ pyqt5 ]); diff --git a/pkgs/applications/graphics/smartdeblur/default.nix b/pkgs/applications/graphics/smartdeblur/default.nix index db2dd60214a2a3..a1c7dee5f84280 100644 --- a/pkgs/applications/graphics/smartdeblur/default.nix +++ b/pkgs/applications/graphics/smartdeblur/default.nix @@ -1,5 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, fftw -, qtbase, qmake, wrapQtAppsHook }: +{ + stdenv, + lib, + fetchFromGitHub, + fftw, + qtbase, + qmake, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "smartdeblur"; @@ -14,8 +21,14 @@ stdenv.mkDerivation rec { sourceRoot = "${src.name}/src"; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; - buildInputs = [ qtbase fftw ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; + buildInputs = [ + qtbase + fftw + ]; installPhase = '' runHook preInstall diff --git a/pkgs/applications/graphics/sxiv/default.nix b/pkgs/applications/graphics/sxiv/default.nix index 09855af551fe72..e40a1e0b5805c1 100644 --- a/pkgs/applications/graphics/sxiv/default.nix +++ b/pkgs/applications/graphics/sxiv/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, libXft, imlib2, giflib, libexif, conf ? null }: +{ + lib, + stdenv, + fetchFromGitHub, + libXft, + imlib2, + giflib, + libexif, + conf ? null, +}: stdenv.mkDerivation rec { pname = "sxiv"; @@ -11,10 +20,15 @@ stdenv.mkDerivation rec { sha256 = "0xaawlfdy7b277m38mgg4423kd7p1ffn0dq4hciqs6ivbb3q9c4f"; }; - configFile = lib.optionalString (conf!=null) (builtins.toFile "config.def.h" conf); - preBuild = lib.optionalString (conf!=null) "cp ${configFile} config.def.h"; + configFile = lib.optionalString (conf != null) (builtins.toFile "config.def.h" conf); + preBuild = lib.optionalString (conf != null) "cp ${configFile} config.def.h"; - buildInputs = [ libXft imlib2 giflib libexif ]; + buildInputs = [ + libXft + imlib2 + giflib + libexif + ]; makeFlags = [ "PREFIX=${placeholder "out"}" ]; diff --git a/pkgs/applications/graphics/tesseract/default.nix b/pkgs/applications/graphics/tesseract/default.nix index 70649d633b8529..16b15a555172b5 100644 --- a/pkgs/applications/graphics/tesseract/default.nix +++ b/pkgs/applications/graphics/tesseract/default.nix @@ -1,12 +1,18 @@ -{ callPackage, lowPrio, Accelerate, CoreGraphics, CoreVideo}: +{ + callPackage, + lowPrio, + Accelerate, + CoreGraphics, + CoreVideo, +}: let - base3 = callPackage ./tesseract3.nix {}; - base4 = callPackage ./tesseract4.nix {}; + base3 = callPackage ./tesseract3.nix { }; + base4 = callPackage ./tesseract4.nix { }; base5 = callPackage ./tesseract5.nix { inherit Accelerate CoreGraphics CoreVideo; }; - languages = callPackage ./languages.nix {}; + languages = callPackage ./languages.nix { }; in { tesseract3 = callPackage ./wrapper.nix { @@ -14,13 +20,17 @@ in languages = languages.v3; }; - tesseract4 = lowPrio (callPackage ./wrapper.nix { - tesseractBase = base4; - languages = languages.v4; - }); + tesseract4 = lowPrio ( + callPackage ./wrapper.nix { + tesseractBase = base4; + languages = languages.v4; + } + ); - tesseract5 = lowPrio (callPackage ./wrapper.nix { - tesseractBase = base5; - languages = languages.v4; - }); + tesseract5 = lowPrio ( + callPackage ./wrapper.nix { + tesseractBase = base5; + languages = languages.v4; + } + ); } diff --git a/pkgs/applications/graphics/tesseract/languages.nix b/pkgs/applications/graphics/tesseract/languages.nix index 11270f70b5da08..c705a8e90355e4 100644 --- a/pkgs/applications/graphics/tesseract/languages.nix +++ b/pkgs/applications/graphics/tesseract/languages.nix @@ -1,7 +1,18 @@ -{ stdenv, lib, fetchurl, fetchFromGitHub }: +{ + stdenv, + lib, + fetchurl, + fetchFromGitHub, +}: rec { - makeLanguages = { tessdataRev, tessdata ? null, all ? null, languages ? {} }: + makeLanguages = + { + tessdataRev, + tessdata ? null, + all ? null, + languages ? { }, + }: let tessdataSrc = fetchFromGitHub { owner = "tesseract-ocr"; @@ -10,25 +21,28 @@ rec { hash = tessdata; }; - languageFile = lang: hash: fetchurl { - url = "https://github.com/tesseract-ocr/tessdata/raw/${tessdataRev}/${lang}.traineddata"; - inherit hash; - }; - in - { - # Use a simple fixed-output derivation for all languages to increase nix eval performance - all = stdenv.mkDerivation { - name = "all"; - buildCommand = '' - mkdir $out - cd ${tessdataSrc} - cp *.traineddata $out - ''; - outputHashMode = "recursive"; - outputHashAlgo = "sha256"; - outputHash = all; + languageFile = + lang: hash: + fetchurl { + url = "https://github.com/tesseract-ocr/tessdata/raw/${tessdataRev}/${lang}.traineddata"; + inherit hash; }; - } // (lib.mapAttrs languageFile languages); + in + { + # Use a simple fixed-output derivation for all languages to increase nix eval performance + all = stdenv.mkDerivation { + name = "all"; + buildCommand = '' + mkdir $out + cd ${tessdataSrc} + cp *.traineddata $out + ''; + outputHashMode = "recursive"; + outputHashAlgo = "sha256"; + outputHash = all; + }; + } + // (lib.mapAttrs languageFile languages); v3 = makeLanguages { tessdataRev = "3cf1e2df1fe1d1da29295c9ef0983796c7958b7d"; diff --git a/pkgs/applications/graphics/tesseract/tesseract3.nix b/pkgs/applications/graphics/tesseract/tesseract3.nix index 5ee965a25e09f3..4d3a97ade7dd19 100644 --- a/pkgs/applications/graphics/tesseract/tesseract3.nix +++ b/pkgs/applications/graphics/tesseract/tesseract3.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config -, leptonica, libpng, libtiff, icu, pango, opencl-headers }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + leptonica, + libpng, + libtiff, + icu, + pango, + opencl-headers, +}: stdenv.mkDerivation rec { pname = "tesseract"; diff --git a/pkgs/applications/graphics/tesseract/tesseract4.nix b/pkgs/applications/graphics/tesseract/tesseract4.nix index e73e237cfea53f..96ce6dda1ead8c 100644 --- a/pkgs/applications/graphics/tesseract/tesseract4.nix +++ b/pkgs/applications/graphics/tesseract/tesseract4.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, autoconf-archive, pkg-config -, leptonica, libpng, libtiff, icu, pango, opencl-headers }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + autoconf-archive, + pkg-config, + leptonica, + libpng, + libtiff, + icu, + pango, + opencl-headers, +}: stdenv.mkDerivation rec { pname = "tesseract"; diff --git a/pkgs/applications/graphics/unigine-superposition/default.nix b/pkgs/applications/graphics/unigine-superposition/default.nix index 6d62edab7a4a53..37b7418c843f00 100644 --- a/pkgs/applications/graphics/unigine-superposition/default.nix +++ b/pkgs/applications/graphics/unigine-superposition/default.nix @@ -1,37 +1,38 @@ -{ lib -, glib -, stdenv -, dbus -, freetype -, fontconfig -, zlib -, qtquickcontrols2 -, libXinerama -, libxcb -, libSM -, libXi -, libglvnd -, libXext -, libXrandr -, mailspring -, libX11 -, libICE -, libXrender -, autoPatchelfHook -, makeWrapper -, mkDerivation -, xkeyboard_config -, fetchurl -, buildFHSEnv -, openal -, makeDesktopItem +{ + lib, + glib, + stdenv, + dbus, + freetype, + fontconfig, + zlib, + qtquickcontrols2, + libXinerama, + libxcb, + libSM, + libXi, + libglvnd, + libXext, + libXrandr, + mailspring, + libX11, + libICE, + libXrender, + autoPatchelfHook, + makeWrapper, + mkDerivation, + xkeyboard_config, + fetchurl, + buildFHSEnv, + openal, + makeDesktopItem, }: let pname = "unigine-superposition"; version = "1.1"; - superposition = stdenv.mkDerivation rec{ + superposition = stdenv.mkDerivation rec { inherit pname version; src = fetchurl { diff --git a/pkgs/applications/graphics/vengi-tools/default.nix b/pkgs/applications/graphics/vengi-tools/default.nix index 1487e2d65324b4..b4a99396fb977d 100644 --- a/pkgs/applications/graphics/vengi-tools/default.nix +++ b/pkgs/applications/graphics/vengi-tools/default.nix @@ -1,36 +1,37 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, -, cmake -, pkg-config -, ninja -, python3 -, makeWrapper + cmake, + pkg-config, + ninja, + python3, + makeWrapper, -, backward-cpp -, curl -, enet -, freetype -, glm -, gtest -, libbfd -, libdwarf -, libjpeg -, libuuid -, libuv -, lua5_4 -, lzfse -, opencl-headers -, SDL2 -, SDL2_mixer -, wayland-protocols -, Carbon -, CoreServices -, OpenCL + backward-cpp, + curl, + enet, + freetype, + glm, + gtest, + libbfd, + libdwarf, + libjpeg, + libuuid, + libuv, + lua5_4, + lzfse, + opencl-headers, + SDL2, + SDL2_mixer, + wayland-protocols, + Carbon, + CoreServices, + OpenCL, -, callPackage -, nixosTests + callPackage, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { @@ -52,27 +53,32 @@ stdenv.mkDerivation (finalAttrs: { makeWrapper ]; - buildInputs = [ - libbfd - libdwarf - backward-cpp - curl - enet - freetype - glm - libjpeg - libuuid - libuv - lua5_4 - lzfse - SDL2 - SDL2_mixer - ] ++ lib.optional stdenv.hostPlatform.isLinux wayland-protocols - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Carbon CoreServices OpenCL ] + buildInputs = + [ + libbfd + libdwarf + backward-cpp + curl + enet + freetype + glm + libjpeg + libuuid + libuv + lua5_4 + lzfse + SDL2 + SDL2_mixer + ] + ++ lib.optional stdenv.hostPlatform.isLinux wayland-protocols + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + CoreServices + OpenCL + ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) opencl-headers; - cmakeFlags = - lib.optional stdenv.hostPlatform.isDarwin "-DCORESERVICES_LIB=${CoreServices}"; + cmakeFlags = lib.optional stdenv.hostPlatform.isDarwin "-DCORESERVICES_LIB=${CoreServices}"; # error: "The plain signature for target_link_libraries has already been used" doCheck = false; @@ -94,8 +100,8 @@ stdenv.mkDerivation (finalAttrs: { ''; passthru.tests = { - voxconvert-roundtrip = callPackage ./test-voxconvert-roundtrip.nix {}; - voxconvert-all-formats = callPackage ./test-voxconvert-all-formats.nix {}; + voxconvert-roundtrip = callPackage ./test-voxconvert-roundtrip.nix { }; + voxconvert-all-formats = callPackage ./test-voxconvert-all-formats.nix { }; run-voxedit = nixosTests.vengi-tools; }; @@ -110,7 +116,10 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://mgerhardy.github.io/vengi/"; downloadPage = "https://github.com/mgerhardy/vengi/releases"; - license = [ licenses.mit licenses.cc-by-sa-30 ]; + license = [ + licenses.mit + licenses.cc-by-sa-30 + ]; maintainers = with maintainers; [ fgaz ]; platforms = platforms.all; broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/applications/graphics/vengi-tools/test-voxconvert-all-formats.nix b/pkgs/applications/graphics/vengi-tools/test-voxconvert-all-formats.nix index c3e6e47adfbafe..767983cc847436 100644 --- a/pkgs/applications/graphics/vengi-tools/test-voxconvert-all-formats.nix +++ b/pkgs/applications/graphics/vengi-tools/test-voxconvert-all-formats.nix @@ -1,5 +1,6 @@ -{ stdenv -, vengi-tools +{ + stdenv, + vengi-tools, }: stdenv.mkDerivation { diff --git a/pkgs/applications/graphics/vengi-tools/test-voxconvert-roundtrip.nix b/pkgs/applications/graphics/vengi-tools/test-voxconvert-roundtrip.nix index a683bff7a10b66..91737ed5836699 100644 --- a/pkgs/applications/graphics/vengi-tools/test-voxconvert-roundtrip.nix +++ b/pkgs/applications/graphics/vengi-tools/test-voxconvert-roundtrip.nix @@ -1,5 +1,6 @@ -{ stdenv -, vengi-tools +{ + stdenv, + vengi-tools, }: stdenv.mkDerivation { diff --git a/pkgs/applications/graphics/veusz/default.nix b/pkgs/applications/graphics/veusz/default.nix index d5ccbf71661973..4622f87d9312c3 100644 --- a/pkgs/applications/graphics/veusz/default.nix +++ b/pkgs/applications/graphics/veusz/default.nix @@ -1,8 +1,9 @@ -{ lib -, python3Packages -, fetchPypi -, wrapQtAppsHook -, qtbase +{ + lib, + python3Packages, + fetchPypi, + wrapQtAppsHook, + qtbase, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/applications/graphics/weylus/default.nix b/pkgs/applications/graphics/weylus/default.nix index 61b40006b3865a..264f34a8fe420f 100644 --- a/pkgs/applications/graphics/weylus/default.nix +++ b/pkgs/applications/graphics/weylus/default.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, makeWrapper -, dbus -, ffmpeg -, x264 -, libva -, gst_all_1 -, xorg -, libdrm -, pkg-config -, pango -, pipewire -, cmake -, git -, autoconf -, libtool -, typescript -, ApplicationServices -, Carbon -, Cocoa -, VideoToolbox +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + makeWrapper, + dbus, + ffmpeg, + x264, + libva, + gst_all_1, + xorg, + libdrm, + pkg-config, + pango, + pipewire, + cmake, + git, + autoconf, + libtool, + typescript, + ApplicationServices, + Carbon, + Cocoa, + VideoToolbox, }: rustPlatform.buildRustPackage rec { @@ -35,43 +36,48 @@ rustPlatform.buildRustPackage rec { sha256 = "sha256-J9eVFIfmyBviVuT1MYKb5yoacbPqOAT3A8jahWv5qw8="; }; - buildInputs = [ - ffmpeg - x264 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ApplicationServices - Carbon - Cocoa - VideoToolbox - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - dbus - libva - gst_all_1.gst-plugins-base - xorg.libXext - xorg.libXft - xorg.libXinerama - xorg.libXcursor - xorg.libXrender - xorg.libXfixes - xorg.libXtst - xorg.libXrandr - xorg.libXcomposite - xorg.libXi - xorg.libXv - pango - libdrm - ]; + buildInputs = + [ + ffmpeg + x264 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ApplicationServices + Carbon + Cocoa + VideoToolbox + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + dbus + libva + gst_all_1.gst-plugins-base + xorg.libXext + xorg.libXft + xorg.libXinerama + xorg.libXcursor + xorg.libXrender + xorg.libXfixes + xorg.libXtst + xorg.libXrandr + xorg.libXcomposite + xorg.libXi + xorg.libXv + pango + libdrm + ]; - nativeBuildInputs = [ - cmake - git - typescript - makeWrapper - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - pkg-config - autoconf - libtool - ]; + nativeBuildInputs = + [ + cmake + git + typescript + makeWrapper + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + pkg-config + autoconf + libtool + ]; cargoLock = { lockFile = ./Cargo.lock; @@ -83,14 +89,16 @@ rustPlatform.buildRustPackage rec { cargoBuildFlags = [ "--features=ffmpeg-system" ]; cargoTestFlags = [ "--features=ffmpeg-system" ]; - postFixup = let - GST_PLUGIN_PATH = lib.makeSearchPathOutput "lib" "lib/gstreamer-1.0" [ - gst_all_1.gst-plugins-base - pipewire - ]; - in lib.optionalString stdenv.hostPlatform.isLinux '' - wrapProgram $out/bin/weylus --prefix GST_PLUGIN_PATH : ${GST_PLUGIN_PATH} - ''; + postFixup = + let + GST_PLUGIN_PATH = lib.makeSearchPathOutput "lib" "lib/gstreamer-1.0" [ + gst_all_1.gst-plugins-base + pipewire + ]; + in + lib.optionalString stdenv.hostPlatform.isLinux '' + wrapProgram $out/bin/weylus --prefix GST_PLUGIN_PATH : ${GST_PLUGIN_PATH} + ''; postInstall = '' install -vDm755 weylus.desktop $out/share/applications/weylus.desktop diff --git a/pkgs/applications/graphics/xaos/default.nix b/pkgs/applications/graphics/xaos/default.nix index dd717223fdbb31..a337447eaeb593 100644 --- a/pkgs/applications/graphics/xaos/default.nix +++ b/pkgs/applications/graphics/xaos/default.nix @@ -1,10 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, qmake, qtbase, qttools, wrapQtAppsHook, copyDesktopItems }: +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + qtbase, + qttools, + wrapQtAppsHook, + copyDesktopItems, +}: -let datapath = "$out/share/XaoS"; -in stdenv.mkDerivation rec { +let + datapath = "$out/share/XaoS"; +in +stdenv.mkDerivation rec { pname = "xaos"; version = "4.2.1"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchFromGitHub { owner = "xaos-project"; @@ -13,11 +27,19 @@ in stdenv.mkDerivation rec { hash = "sha256-JLF8Mz/OHZEEJG/aryKQuJ6B5R8hPJdvln7mbKoqXFU="; }; - nativeBuildInputs = [ qmake qttools wrapQtAppsHook copyDesktopItems ]; + nativeBuildInputs = [ + qmake + qttools + wrapQtAppsHook + copyDesktopItems + ]; buildInputs = [ qtbase ]; QMAKE_LRELEASE = "lrelease"; - DEFINES = [ "USE_OPENGL" "USE_FLOAT128" ]; + DEFINES = [ + "USE_OPENGL" + "USE_FLOAT128" + ]; postPatch = '' substituteInPlace src/include/config.h \ diff --git a/pkgs/applications/graphics/yacreader/default.nix b/pkgs/applications/graphics/yacreader/default.nix index e0fa8cc64da490..af1d7579bbcac4 100644 --- a/pkgs/applications/graphics/yacreader/default.nix +++ b/pkgs/applications/graphics/yacreader/default.nix @@ -1,6 +1,17 @@ -{ mkDerivation, lib, fetchFromGitHub, qmake, poppler, pkg-config, libunarr -, libGLU, qtdeclarative, qtgraphicaleffects, qtmultimedia, qtquickcontrols2 -, qtscript +{ + mkDerivation, + lib, + fetchFromGitHub, + qmake, + poppler, + pkg-config, + libunarr, + libGLU, + qtdeclarative, + qtgraphicaleffects, + qtmultimedia, + qtquickcontrols2, + qtscript, }: mkDerivation rec { @@ -14,9 +25,22 @@ mkDerivation rec { sha256 = "sha256-gQ4Aaapini6j3lCtowFbrfwbe91aFl50hp1EfxTO8uY="; }; - nativeBuildInputs = [ qmake pkg-config ]; - buildInputs = [ poppler libunarr libGLU qtmultimedia qtscript ]; - propagatedBuildInputs = [ qtquickcontrols2 qtgraphicaleffects qtdeclarative ]; + nativeBuildInputs = [ + qmake + pkg-config + ]; + buildInputs = [ + poppler + libunarr + libGLU + qtmultimedia + qtscript + ]; + propagatedBuildInputs = [ + qtquickcontrols2 + qtgraphicaleffects + qtdeclarative + ]; meta = { description = "Comic reader for cross-platform reading and managing your digital comic collection"; diff --git a/pkgs/applications/graphics/zgv/default.nix b/pkgs/applications/graphics/zgv/default.nix index 8df5e82622494c..457d233176b9f4 100644 --- a/pkgs/applications/graphics/zgv/default.nix +++ b/pkgs/applications/graphics/zgv/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, SDL, SDL_image, libjpeg, libpng, libtiff }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + SDL, + SDL_image, + libjpeg, + libpng, + libtiff, +}: stdenv.mkDerivation rec { pname = "zgv"; @@ -9,7 +20,13 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ SDL SDL_image libjpeg libpng libtiff ]; + buildInputs = [ + SDL + SDL_image + libjpeg + libpng + libtiff + ]; hardeningDisable = [ "format" ]; @@ -19,8 +36,8 @@ stdenv.mkDerivation rec { patches = [ (fetchpatch { - url = "https://foss.aueb.gr/mirrors/linux/gentoo/media-gfx/zgv/files/zgv-5.9-libpng15.patch"; - sha256 = "1blw9n04c28bnwcmcn64si4f5zpg42s8yn345js88fyzi9zm19xw"; + url = "https://foss.aueb.gr/mirrors/linux/gentoo/media-gfx/zgv/files/zgv-5.9-libpng15.patch"; + sha256 = "1blw9n04c28bnwcmcn64si4f5zpg42s8yn345js88fyzi9zm19xw"; }) ./switch.patch ]; diff --git a/pkgs/applications/kde/akonadi-calendar-tools.nix b/pkgs/applications/kde/akonadi-calendar-tools.nix index 64fe3e1f4388e2..204fe6f46a0a78 100644 --- a/pkgs/applications/kde/akonadi-calendar-tools.nix +++ b/pkgs/applications/kde/akonadi-calendar-tools.nix @@ -1,9 +1,10 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, akonadi -, calendarsupport +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + akonadi, + calendarsupport, }: mkDerivation { @@ -11,14 +12,23 @@ mkDerivation { meta = { homepage = "https://github.com/KDE/akonadi-calendar-tools"; description = "Console applications and utilities for managing calendars in Akonadi"; - license = with lib.licenses; [ gpl2Plus cc0 ]; + license = with lib.licenses; [ + gpl2Plus + cc0 + ]; maintainers = with lib.maintainers; [ kennyballou ]; platforms = lib.platforms.linux; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; propagatedBuildInputs = [ akonadi calendarsupport ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/applications/kde/akonadi-calendar.nix b/pkgs/applications/kde/akonadi-calendar.nix index c149ac905dd8d0..6b4a248d88ddc0 100644 --- a/pkgs/applications/kde/akonadi-calendar.nix +++ b/pkgs/applications/kde/akonadi-calendar.nix @@ -1,22 +1,48 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-contacts, kcalendarcore, kcalutils, kcontacts, - kidentitymanagement, kio, kmailtransport, messagelib + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-contacts, + kcalendarcore, + kcalutils, + kcontacts, + kidentitymanagement, + kio, + kmailtransport, + messagelib, }: mkDerivation { pname = "akonadi-calendar"; meta = { - license = with lib.licenses; [ gpl2 lgpl21 ]; + license = with lib.licenses; [ + gpl2 + lgpl21 + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; propagatedBuildInputs = [ - akonadi akonadi-contacts kcalendarcore kcalutils kcontacts kidentitymanagement - kio kmailtransport messagelib + akonadi + akonadi-contacts + kcalendarcore + kcalutils + kcontacts + kidentitymanagement + kio + kmailtransport + messagelib + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/akonadi-contacts.nix b/pkgs/applications/kde/akonadi-contacts.nix index 2486019ac69ad1..d00fe2e8f56ba0 100644 --- a/pkgs/applications/kde/akonadi-contacts.nix +++ b/pkgs/applications/kde/akonadi-contacts.nix @@ -1,27 +1,60 @@ { - mkDerivation, lib, kdepimTeam, + mkDerivation, + lib, + kdepimTeam, extra-cmake-modules, qtwebengine, - grantlee, grantleetheme, - kcmutils, kdbusaddons, ki18n, kiconthemes, kio, kitemmodels, ktextwidgets, - prison, akonadi, akonadi-mime, kcontacts, kmime, libkleo, + grantlee, + grantleetheme, + kcmutils, + kdbusaddons, + ki18n, + kiconthemes, + kio, + kitemmodels, + ktextwidgets, + prison, + akonadi, + akonadi-mime, + kcontacts, + kmime, + libkleo, }: mkDerivation { pname = "akonadi-contacts"; meta = { - license = with lib.licenses; [ gpl2 lgpl21 ]; + license = with lib.licenses; [ + gpl2 + lgpl21 + ]; maintainers = kdepimTeam; }; nativeBuildInputs = [ extra-cmake-modules ]; buildInputs = [ qtwebengine grantlee - kcmutils kdbusaddons ki18n kiconthemes kio kitemmodels ktextwidgets prison - akonadi-mime kcontacts kmime libkleo + kcmutils + kdbusaddons + ki18n + kiconthemes + kio + kitemmodels + ktextwidgets + prison + akonadi-mime + kcontacts + kmime + libkleo + ]; + propagatedBuildInputs = [ + akonadi + grantleetheme + ]; + outputs = [ + "out" + "dev" ]; - propagatedBuildInputs = [ akonadi grantleetheme ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/akonadi-import-wizard.nix b/pkgs/applications/kde/akonadi-import-wizard.nix index 370f77c3831813..fcdab9b52858ed 100644 --- a/pkgs/applications/kde/akonadi-import-wizard.nix +++ b/pkgs/applications/kde/akonadi-import-wizard.nix @@ -1,22 +1,55 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, karchive, kcontacts, kcrash, kidentitymanagement, kio, - kmailtransport, kwallet, mailcommon, mailimporter, messagelib, - qtkeychain, libsecret + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + karchive, + kcontacts, + kcrash, + kidentitymanagement, + kio, + kmailtransport, + kwallet, + mailcommon, + mailimporter, + messagelib, + qtkeychain, + libsecret, }: mkDerivation { pname = "akonadi-import-wizard"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi karchive kcontacts kcrash kidentitymanagement kio - kmailtransport kwallet mailcommon mailimporter messagelib - qtkeychain libsecret + akonadi + karchive + kcontacts + kcrash + kidentitymanagement + kio + kmailtransport + kwallet + mailcommon + mailimporter + messagelib + qtkeychain + libsecret + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; } diff --git a/pkgs/applications/kde/akonadi-mime.nix b/pkgs/applications/kde/akonadi-mime.nix index b498fde26dfa47..fb538574349331 100644 --- a/pkgs/applications/kde/akonadi-mime.nix +++ b/pkgs/applications/kde/akonadi-mime.nix @@ -1,18 +1,42 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, shared-mime-info, - akonadi, kdbusaddons, ki18n, kio, kitemmodels, kmime + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + shared-mime-info, + akonadi, + kdbusaddons, + ki18n, + kio, + kitemmodels, + kmime, }: mkDerivation { pname = "akonadi-mime"; meta = { - license = with lib.licenses; [ gpl2 lgpl21 ]; + license = with lib.licenses; [ + gpl2 + lgpl21 + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules shared-mime-info ]; - buildInputs = [ akonadi kdbusaddons ki18n kio kitemmodels kmime ]; - outputs = [ "out" "dev" ]; + nativeBuildInputs = [ + extra-cmake-modules + shared-mime-info + ]; + buildInputs = [ + akonadi + kdbusaddons + ki18n + kio + kitemmodels + kmime + ]; + outputs = [ + "out" + "dev" + ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/akonadi-notes.nix b/pkgs/applications/kde/akonadi-notes.nix index 411f71440a0dc4..f40d588ff68748 100644 --- a/pkgs/applications/kde/akonadi-notes.nix +++ b/pkgs/applications/kde/akonadi-notes.nix @@ -1,20 +1,43 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, kcompletion, ki18n, kitemmodels, kmime, kxmlgui + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + kcompletion, + ki18n, + kitemmodels, + kmime, + kxmlgui, }: mkDerivation { pname = "akonadi-notes"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi kcompletion ki18n kitemmodels kmime kxmlgui + akonadi + kcompletion + ki18n + kitemmodels + kmime + kxmlgui + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/akonadi-search.nix b/pkgs/applications/kde/akonadi-search.nix index 2908748e474dd9..5050d2ae3ddc44 100644 --- a/pkgs/applications/kde/akonadi-search.nix +++ b/pkgs/applications/kde/akonadi-search.nix @@ -1,22 +1,53 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-mime, kcalendarcore, kcmutils, kcontacts, kcoreaddons, kmime, - krunner, qtbase, xapian + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-mime, + kcalendarcore, + kcmutils, + kcontacts, + kcoreaddons, + kmime, + krunner, + qtbase, + xapian, }: mkDerivation { pname = "akonadi-search"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ kcmutils krunner xapian ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + kcmutils + krunner + xapian + ]; propagatedBuildInputs = [ - akonadi akonadi-mime kcalendarcore kcontacts kcoreaddons kmime qtbase + akonadi + akonadi-mime + kcalendarcore + kcontacts + kcoreaddons + kmime + qtbase + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/akonadi/default.nix b/pkgs/applications/kde/akonadi/default.nix index ade8ebbcf4213b..fc3fd063720d3d 100644 --- a/pkgs/applications/kde/akonadi/default.nix +++ b/pkgs/applications/kde/akonadi/default.nix @@ -1,9 +1,27 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, shared-mime-info, accounts-qt, - boost, kaccounts-integration, kcompletion, kconfigwidgets, kcrash, kdbusaddons, - kdesignerplugin, ki18n, kiconthemes, kio, kitemmodels, kwindowsystem, mariadb, - postgresql, qttools, signond, xz, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + shared-mime-info, + accounts-qt, + boost, + kaccounts-integration, + kcompletion, + kconfigwidgets, + kcrash, + kdbusaddons, + kdesignerplugin, + ki18n, + kiconthemes, + kio, + kitemmodels, + kwindowsystem, + mariadb, + postgresql, + qttools, + signond, + xz, mysqlSupport ? true, postgresSupport ? false, @@ -23,13 +41,34 @@ mkDerivation { ./0002-akonadi-timestamps.patch ./0003-akonadi-revert-make-relocatable.patch ]; - nativeBuildInputs = [ extra-cmake-modules shared-mime-info ]; + nativeBuildInputs = [ + extra-cmake-modules + shared-mime-info + ]; buildInputs = [ - kaccounts-integration kcompletion kconfigwidgets kcrash kdbusaddons kdesignerplugin - ki18n kiconthemes kio kwindowsystem xz accounts-qt qttools signond + kaccounts-integration + kcompletion + kconfigwidgets + kcrash + kdbusaddons + kdesignerplugin + ki18n + kiconthemes + kio + kwindowsystem + xz + accounts-qt + qttools + signond + ]; + propagatedBuildInputs = [ + boost + kitemmodels + ]; + outputs = [ + "out" + "dev" ]; - propagatedBuildInputs = [ boost kitemmodels ]; - outputs = [ "out" "dev" ]; CXXFLAGS = [ ''-DNIXPKGS_MYSQL_MYSQLD=\"${lib.optionalString mysqlSupport "${lib.getBin mariadb}/bin/mysqld"}\"'' ''-DNIXPKGS_MYSQL_MYSQLADMIN=\"${lib.optionalString mysqlSupport "${lib.getBin mariadb}/bin/mysqladmin"}\"'' @@ -39,7 +78,7 @@ mkDerivation { ''-DNIXPKGS_POSTGRES_PG_UPGRADE=\"${lib.optionalString postgresSupport "${lib.getBin postgresql}/bin/pg_upgrade"}\"'' ''-DNIXPKGS_POSTGRES_INITDB=\"${lib.optionalString postgresSupport "${lib.getBin postgresql}/bin/initdb"}\"'' ''-DNIX_OUT=\"${placeholder "out"}\"'' - ''-I${lib.getDev kio}/include/KF5'' # Fixes: kio_version.h: No such file or directory + ''-I${lib.getDev kio}/include/KF5'' # Fixes: kio_version.h: No such file or directory ]; cmakeFlags = lib.optional (defaultDriver != "MYSQL") "-DDATABASE_BACKEND=${defaultDriver}"; diff --git a/pkgs/applications/kde/akonadiconsole.nix b/pkgs/applications/kde/akonadiconsole.nix index bb0b8424b4e478..da5f1ec023cda7 100644 --- a/pkgs/applications/kde/akonadiconsole.nix +++ b/pkgs/applications/kde/akonadiconsole.nix @@ -1,21 +1,59 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-contacts, calendarsupport, kcalendarcore, kcompletion, - kconfigwidgets, kcontacts, kdbusaddons, kitemmodels, kpimtextedit, libkdepim, - ktextwidgets, kxmlgui, messagelib, qtbase, akonadi-search, xapian + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-contacts, + calendarsupport, + kcalendarcore, + kcompletion, + kconfigwidgets, + kcontacts, + kdbusaddons, + kitemmodels, + kpimtextedit, + libkdepim, + ktextwidgets, + kxmlgui, + messagelib, + qtbase, + akonadi-search, + xapian, }: mkDerivation { pname = "akonadiconsole"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi akonadi-contacts calendarsupport kcalendarcore kcompletion kconfigwidgets - kcontacts kdbusaddons kitemmodels kpimtextedit ktextwidgets kxmlgui - messagelib qtbase libkdepim akonadi-search xapian + akonadi + akonadi-contacts + calendarsupport + kcalendarcore + kcompletion + kconfigwidgets + kcontacts + kdbusaddons + kitemmodels + kpimtextedit + ktextwidgets + kxmlgui + messagelib + qtbase + libkdepim + akonadi-search + xapian ]; } diff --git a/pkgs/applications/kde/akregator.nix b/pkgs/applications/kde/akregator.nix index 684049d5f0b287..1d86d93a73b154 100644 --- a/pkgs/applications/kde/akregator.nix +++ b/pkgs/applications/kde/akregator.nix @@ -1,13 +1,27 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, qtwebengine, grantlee, - kcmutils, kcrash, kiconthemes, knotifyconfig, kparts, ktexteditor, + kcmutils, + kcrash, + kiconthemes, + knotifyconfig, + kparts, + ktexteditor, kuserfeedback, kwindowsystem, - akonadi, akonadi-mime, grantleetheme, kontactinterface, libkdepim, libkleo, - messagelib, syndication + akonadi, + akonadi-mime, + grantleetheme, + kontactinterface, + libkdepim, + libkleo, + messagelib, + syndication, }: mkDerivation { @@ -15,21 +29,42 @@ mkDerivation { meta = { homepage = "https://apps.kde.org/akregator/"; description = "KDE feed reader"; - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ qtwebengine grantlee - kcmutils kcrash kiconthemes knotifyconfig kparts ktexteditor + kcmutils + kcrash + kiconthemes + knotifyconfig + kparts + ktexteditor kuserfeedback kwindowsystem - akonadi akonadi-mime grantleetheme kontactinterface libkdepim libkleo - messagelib syndication + akonadi + akonadi-mime + grantleetheme + kontactinterface + libkdepim + libkleo + messagelib + syndication + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; } diff --git a/pkgs/applications/kde/alligator.nix b/pkgs/applications/kde/alligator.nix index cf178e3fe4a7bf..305f39bd712f77 100644 --- a/pkgs/applications/kde/alligator.nix +++ b/pkgs/applications/kde/alligator.nix @@ -1,16 +1,17 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules + cmake, + extra-cmake-modules, -, kconfig -, kcoreaddons -, ki18n -, kirigami-addons -, kirigami2 -, qtquickcontrols2 -, syndication + kconfig, + kcoreaddons, + ki18n, + kirigami-addons, + kirigami2, + qtquickcontrols2, + syndication, }: mkDerivation rec { @@ -37,7 +38,10 @@ mkDerivation rec { homepage = "https://invent.kde.org/plasma-mobile/alligator"; # https://invent.kde.org/plasma-mobile/alligator/-/commit/db30f159c4700244532b17a260deb95551045b7a # * SPDX-License-Identifier: GPL-2.0-only OR GPL-3.0-only OR LicenseRef-KDE-Accepted-GPL - license = with licenses; [ gpl2Only gpl3Only ]; + license = with licenses; [ + gpl2Only + gpl3Only + ]; maintainers = [ ]; }; } diff --git a/pkgs/applications/kde/analitza.nix b/pkgs/applications/kde/analitza.nix index 2ddd8cfbb821ff..74d1b4f816f01d 100644 --- a/pkgs/applications/kde/analitza.nix +++ b/pkgs/applications/kde/analitza.nix @@ -1,12 +1,13 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, qtbase -, qtsvg -, eigen -, kdoctools -, qttools +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + qtbase, + qtsvg, + eigen, + kdoctools, + qttools, }: mkDerivation { @@ -28,7 +29,11 @@ mkDerivation { meta = with lib; { description = "Front end to powerful mathematics and statistics packages"; homepage = "https://cantor.kde.org/"; - license = with licenses; [ gpl2Only lgpl2Only fdl12Only ]; + license = with licenses; [ + gpl2Only + lgpl2Only + fdl12Only + ]; maintainers = with maintainers; [ hqurve ]; }; } diff --git a/pkgs/applications/kde/angelfish.nix b/pkgs/applications/kde/angelfish.nix index 326a9fc309ac22..22b24f112ce981 100644 --- a/pkgs/applications/kde/angelfish.nix +++ b/pkgs/applications/kde/angelfish.nix @@ -1,31 +1,32 @@ -{ lib -, mkDerivation -, cargo -, cmake -, corrosion -, extra-cmake-modules -, fetchpatch2 -, futuresql -, kconfig -, kcoreaddons -, kdbusaddons -, ki18n -, kirigami-addons -, kirigami2 -, knotifications -, kpurpose -, kwindowsystem -, qcoro -, qtfeedback -, qtquickcontrols2 -, qqc2-desktop-style -, qtwebengine -, rustPlatform -, rustc -, srcs +{ + lib, + mkDerivation, + cargo, + cmake, + corrosion, + extra-cmake-modules, + fetchpatch2, + futuresql, + kconfig, + kcoreaddons, + kdbusaddons, + ki18n, + kirigami-addons, + kirigami2, + knotifications, + kpurpose, + kwindowsystem, + qcoro, + qtfeedback, + qtquickcontrols2, + qqc2-desktop-style, + qtwebengine, + rustPlatform, + rustc, + srcs, -# provided as callPackage input to enable easier overrides through overlays -, cargoSha256 ? "sha256-PSrTo7nGgH0KxA82RlBEwtOu80WMCBeaCxHj3n7SgEE=" + # provided as callPackage input to enable easier overrides through overlays + cargoSha256 ? "sha256-PSrTo7nGgH0KxA82RlBEwtOu80WMCBeaCxHj3n7SgEE=", }: mkDerivation rec { diff --git a/pkgs/applications/kde/arianna.nix b/pkgs/applications/kde/arianna.nix index 95427d74e29559..79cb3670895fb8 100644 --- a/pkgs/applications/kde/arianna.nix +++ b/pkgs/applications/kde/arianna.nix @@ -1,25 +1,26 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, qtbase -, qtdeclarative -, qtquickcontrols2 -, qtwebchannel -, qtwebengine -, qtwebsockets -, baloo -, karchive -, kconfig -, kcoreaddons -, kdbusaddons -, kfilemetadata -, ki18n -, kirigami-addons -, kitemmodels -, kquickcharts -, kwindowsystem -, qqc2-desktop-style +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + qtbase, + qtdeclarative, + qtquickcontrols2, + qtwebchannel, + qtwebengine, + qtwebsockets, + baloo, + karchive, + kconfig, + kcoreaddons, + kdbusaddons, + kfilemetadata, + ki18n, + kirigami-addons, + kitemmodels, + kquickcharts, + kwindowsystem, + qqc2-desktop-style, }: mkDerivation { diff --git a/pkgs/applications/kde/ark/default.nix b/pkgs/applications/kde/ark/default.nix index 815bee892d6de6..931282c7f282f6 100644 --- a/pkgs/applications/kde/ark/default.nix +++ b/pkgs/applications/kde/ark/default.nix @@ -1,38 +1,94 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools -, breeze-icons, karchive, kconfig, kcrash, kdbusaddons, ki18n -, kiconthemes, kitemmodels, khtml, kio, kparts, kpty, kservice, kwidgetsaddons -, libarchive, libzip -# Archive tools -, p7zip, lrzip, unar -# Unfree tools -, unfreeEnableUnrar ? false, unrar +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + breeze-icons, + karchive, + kconfig, + kcrash, + kdbusaddons, + ki18n, + kiconthemes, + kitemmodels, + khtml, + kio, + kparts, + kpty, + kservice, + kwidgetsaddons, + libarchive, + libzip, + # Archive tools + p7zip, + lrzip, + unar, + # Unfree tools + unfreeEnableUnrar ? false, + unrar, }: let - extraTools = [ p7zip lrzip unar ] ++ lib.optional unfreeEnableUnrar unrar; + extraTools = [ + p7zip + lrzip + unar + ] ++ lib.optional unfreeEnableUnrar unrar; in mkDerivation { pname = "ark"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; - buildInputs = [ libarchive libzip ] ++ extraTools; + buildInputs = [ + libarchive + libzip + ] ++ extraTools; propagatedBuildInputs = [ - breeze-icons karchive kconfig kcrash kdbusaddons khtml ki18n kiconthemes kio - kitemmodels kparts kpty kservice kwidgetsaddons + breeze-icons + karchive + kconfig + kcrash + kdbusaddons + khtml + ki18n + kiconthemes + kio + kitemmodels + kparts + kpty + kservice + kwidgetsaddons ]; - qtWrapperArgs = [ "--prefix" "PATH" ":" (lib.makeBinPath extraTools) ]; + qtWrapperArgs = [ + "--prefix" + "PATH" + ":" + (lib.makeBinPath extraTools) + ]; meta = with lib; { homepage = "https://apps.kde.org/ark/"; description = "Graphical file compression/decompression utility"; mainProgram = "ark"; - license = with licenses; [ gpl2 lgpl3 ] ++ optional unfreeEnableUnrar unfree; + license = + with licenses; + [ + gpl2 + lgpl3 + ] + ++ optional unfreeEnableUnrar unfree; maintainers = [ maintainers.ttuegel ]; }; } diff --git a/pkgs/applications/kde/audiotube.nix b/pkgs/applications/kde/audiotube.nix index 2f9937f106b61f..9bd199d99296b2 100644 --- a/pkgs/applications/kde/audiotube.nix +++ b/pkgs/applications/kde/audiotube.nix @@ -1,22 +1,23 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, extra-cmake-modules -, wrapGAppsHook3 + extra-cmake-modules, + wrapGAppsHook3, -, futuresql -, gst_all_1 -, kcoreaddons -, kcrash -, ki18n -, kirigami2 -, kirigami-addons -, kpurpose -, qcoro -, qtimageformats -, qtmultimedia -, qtquickcontrols2 -, python3Packages + futuresql, + gst_all_1, + kcoreaddons, + kcrash, + ki18n, + kirigami2, + kirigami-addons, + kpurpose, + qcoro, + qtimageformats, + qtmultimedia, + qtquickcontrols2, + python3Packages, }: mkDerivation rec { @@ -29,24 +30,27 @@ mkDerivation rec { python3Packages.pybind11 ]; - buildInputs = [ - futuresql - kcoreaddons - kcrash - ki18n - kirigami2 - kirigami-addons - kpurpose - qcoro - qtimageformats - qtmultimedia - qtquickcontrols2 - ] ++ (with gst_all_1; [ - gst-plugins-bad - gst-plugins-base - gst-plugins-good - gstreamer - ]) ++ pythonPath; + buildInputs = + [ + futuresql + kcoreaddons + kcrash + ki18n + kirigami2 + kirigami-addons + kpurpose + qcoro + qtimageformats + qtmultimedia + qtquickcontrols2 + ] + ++ (with gst_all_1; [ + gst-plugins-bad + gst-plugins-base + gst-plugins-good + gstreamer + ]) + ++ pythonPath; pythonPath = with python3Packages; [ yt-dlp @@ -65,7 +69,12 @@ mkDerivation rec { mainProgram = "audiotube"; homepage = "https://invent.kde.org/plasma-mobile/audiotube"; # https://invent.kde.org/plasma-mobile/audiotube/-/tree/c503d0607a3386112beaa9cf990ab85fe33ef115/LICENSES - license = with licenses; [ bsd2 cc0 gpl2Only gpl3Only ]; + license = with licenses; [ + bsd2 + cc0 + gpl2Only + gpl3Only + ]; maintainers = [ ]; }; } diff --git a/pkgs/applications/kde/baloo-widgets.nix b/pkgs/applications/kde/baloo-widgets.nix index 940c47a2ac83f4..646a4582a5e201 100644 --- a/pkgs/applications/kde/baloo-widgets.nix +++ b/pkgs/applications/kde/baloo-widgets.nix @@ -1,7 +1,14 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - baloo, kconfig, kfilemetadata, ki18n, kio, kservice + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + baloo, + kconfig, + kfilemetadata, + ki18n, + kio, + kservice, }: mkDerivation { @@ -10,9 +17,20 @@ mkDerivation { license = [ lib.licenses.lgpl21 ]; maintainers = [ lib.maintainers.ttuegel ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; propagatedBuildInputs = [ - baloo kconfig kfilemetadata ki18n kio kservice + baloo + kconfig + kfilemetadata + ki18n + kio + kservice + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; } diff --git a/pkgs/applications/kde/bomber.nix b/pkgs/applications/kde/bomber.nix index 59c6ab779cf35c..9e84dc1edfa38b 100644 --- a/pkgs/applications/kde/bomber.nix +++ b/pkgs/applications/kde/bomber.nix @@ -1,6 +1,10 @@ -{ mkDerivation, lib -, libkdegames, extra-cmake-modules -, kdeclarative, knewstuff +{ + mkDerivation, + lib, + libkdegames, + extra-cmake-modules, + kdeclarative, + knewstuff, }: mkDerivation { @@ -15,7 +19,7 @@ mkDerivation { The goal of the game is to destroy all the buildings and advance to the next level. Each level gets a bit harder by increasing the speed of the plane and the height of the buildings. - ''; + ''; maintainers = with maintainers; [ freezeboy ]; license = licenses.gpl2Plus; platforms = platforms.linux; diff --git a/pkgs/applications/kde/bovo.nix b/pkgs/applications/kde/bovo.nix index d1788bd5e234c9..b441234d65fe92 100644 --- a/pkgs/applications/kde/bovo.nix +++ b/pkgs/applications/kde/bovo.nix @@ -1,6 +1,10 @@ -{ mkDerivation, lib -, libkdegames, extra-cmake-modules -, kdeclarative, knewstuff +{ + mkDerivation, + lib, + libkdegames, + extra-cmake-modules, + kdeclarative, + knewstuff, }: mkDerivation { diff --git a/pkgs/applications/kde/calendarsupport.nix b/pkgs/applications/kde/calendarsupport.nix index 4cc1bb1f1c6ca1..f28eb200ce6863 100644 --- a/pkgs/applications/kde/calendarsupport.nix +++ b/pkgs/applications/kde/calendarsupport.nix @@ -1,22 +1,53 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-calendar, akonadi-mime, akonadi-notes, kcalutils, - kholidays, kidentitymanagement, kmime, pimcommon, qttools, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-calendar, + akonadi-mime, + akonadi-notes, + kcalutils, + kholidays, + kidentitymanagement, + kmime, + pimcommon, + qttools, }: mkDerivation { pname = "calendarsupport"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi akonadi-mime akonadi-notes kcalutils kholidays pimcommon qttools + akonadi + akonadi-mime + akonadi-notes + kcalutils + kholidays + pimcommon + qttools + ]; + propagatedBuildInputs = [ + akonadi-calendar + kidentitymanagement + kmime + ]; + outputs = [ + "out" + "dev" ]; - propagatedBuildInputs = [ akonadi-calendar kidentitymanagement kmime ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/calindori.nix b/pkgs/applications/kde/calindori.nix index d7d508f55bcd06..76bf9a806f19a0 100644 --- a/pkgs/applications/kde/calindori.nix +++ b/pkgs/applications/kde/calindori.nix @@ -1,19 +1,20 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules + cmake, + extra-cmake-modules, -, kcalendarcore -, kconfig -, kcoreaddons -, kdbusaddons -, ki18n -, kirigami2 -, knotifications -, kpeople -, kservice -, qtquickcontrols2 + kcalendarcore, + kconfig, + kcoreaddons, + kdbusaddons, + ki18n, + kirigami2, + knotifications, + kpeople, + kservice, + qtquickcontrols2, }: mkDerivation rec { diff --git a/pkgs/applications/kde/colord-kde.nix b/pkgs/applications/kde/colord-kde.nix index 7b3c783995c6c6..02fe456061d773 100644 --- a/pkgs/applications/kde/colord-kde.nix +++ b/pkgs/applications/kde/colord-kde.nix @@ -1,8 +1,25 @@ -{ mkDerivation, lib -, extra-cmake-modules, ki18n -, kconfig, kconfigwidgets, kcoreaddons, kdbusaddons, kiconthemes, kirigami-addons -, kcmutils, kio, knotifications, plasma-framework, kwidgetsaddons -, kwindowsystem, kitemmodels, kitemviews, lcms2, libXrandr, qtx11extras +{ + mkDerivation, + lib, + extra-cmake-modules, + ki18n, + kconfig, + kconfigwidgets, + kcoreaddons, + kdbusaddons, + kiconthemes, + kirigami-addons, + kcmutils, + kio, + knotifications, + plasma-framework, + kwidgetsaddons, + kwindowsystem, + kitemmodels, + kitemviews, + lcms2, + libXrandr, + qtx11extras, }: mkDerivation { @@ -11,9 +28,24 @@ mkDerivation { nativeBuildInputs = [ extra-cmake-modules ]; buildInputs = [ - kconfig kconfigwidgets kcoreaddons kdbusaddons kiconthemes kirigami-addons - kcmutils ki18n kio knotifications plasma-framework kwidgetsaddons - kwindowsystem kitemmodels kitemviews lcms2 libXrandr qtx11extras + kconfig + kconfigwidgets + kcoreaddons + kdbusaddons + kiconthemes + kirigami-addons + kcmutils + ki18n + kio + knotifications + plasma-framework + kwidgetsaddons + kwindowsystem + kitemmodels + kitemviews + lcms2 + libXrandr + qtx11extras ]; meta = with lib; { diff --git a/pkgs/applications/kde/dolphin-plugins.nix b/pkgs/applications/kde/dolphin-plugins.nix index 123b6f0fc268c9..946fcd4143dd14 100644 --- a/pkgs/applications/kde/dolphin-plugins.nix +++ b/pkgs/applications/kde/dolphin-plugins.nix @@ -1,7 +1,12 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - dolphin, ki18n, kio, kxmlgui + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + dolphin, + ki18n, + kio, + kxmlgui, }: mkDerivation { @@ -10,9 +15,18 @@ mkDerivation { license = [ lib.licenses.gpl2 ]; maintainers = [ lib.maintainers.ttuegel ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; propagatedBuildInputs = [ - dolphin ki18n kio kxmlgui + dolphin + ki18n + kio + kxmlgui + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; } diff --git a/pkgs/applications/kde/dolphin.nix b/pkgs/applications/kde/dolphin.nix index ad14f62d7c0f5b..69ce5b03e455b9 100644 --- a/pkgs/applications/kde/dolphin.nix +++ b/pkgs/applications/kde/dolphin.nix @@ -1,11 +1,34 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - baloo, baloo-widgets, kactivities, kbookmarks, kcmutils, - kcompletion, kconfig, kcoreaddons, kdbusaddons, - kfilemetadata, ki18n, kiconthemes, kinit, kio, knewstuff, knotifications, - kparts, ktexteditor, kwindowsystem, phonon, solid, - kuserfeedback, wayland, qtwayland, qtx11extras, qtimageformats + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + baloo, + baloo-widgets, + kactivities, + kbookmarks, + kcmutils, + kcompletion, + kconfig, + kcoreaddons, + kdbusaddons, + kfilemetadata, + ki18n, + kiconthemes, + kinit, + kio, + knewstuff, + knotifications, + kparts, + ktexteditor, + kwindowsystem, + phonon, + solid, + kuserfeedback, + wayland, + qtwayland, + qtx11extras, + qtimageformats, }: mkDerivation { @@ -13,20 +36,47 @@ mkDerivation { meta = { homepage = "https://apps.kde.org/dolphin/"; description = "KDE file manager"; - license = with lib.licenses; [ gpl2Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + fdl12Plus + ]; maintainers = [ lib.maintainers.ttuegel ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; propagatedUserEnvPkgs = [ baloo ]; propagatedBuildInputs = [ - baloo baloo-widgets kactivities kbookmarks kcmutils kcompletion kconfig - kcoreaddons kdbusaddons kfilemetadata ki18n kiconthemes - kinit kio knewstuff knotifications kparts ktexteditor kwindowsystem - phonon solid + baloo + baloo-widgets + kactivities + kbookmarks + kcmutils + kcompletion + kconfig + kcoreaddons + kdbusaddons + kfilemetadata + ki18n + kiconthemes + kinit + kio + knewstuff + knotifications + kparts + ktexteditor + kwindowsystem + phonon + solid kuserfeedback - wayland qtwayland + wayland + qtwayland qtx11extras qtimageformats ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/applications/kde/dragon.nix b/pkgs/applications/kde/dragon.nix index 38d81647edadfd..d1bc7233a5f8ec 100644 --- a/pkgs/applications/kde/dragon.nix +++ b/pkgs/applications/kde/dragon.nix @@ -1,27 +1,74 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - baloo, baloo-widgets, kactivities, kbookmarks, kcmutils, - kcompletion, kconfig, kcoreaddons, kdbusaddons, - kfilemetadata, ki18n, kiconthemes, kinit, kio, knewstuff, knotifications, - kparts, ktexteditor, kwindowsystem, phonon, solid, phonon-backend-gstreamer + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + baloo, + baloo-widgets, + kactivities, + kbookmarks, + kcmutils, + kcompletion, + kconfig, + kcoreaddons, + kdbusaddons, + kfilemetadata, + ki18n, + kiconthemes, + kinit, + kio, + knewstuff, + knotifications, + kparts, + ktexteditor, + kwindowsystem, + phonon, + solid, + phonon-backend-gstreamer, }: mkDerivation { pname = "dragon"; meta = { homepage = "https://apps.kde.org/dragonplayer/"; - license = with lib.licenses; [ gpl2Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + fdl12Plus + ]; description = "Simple media player for KDE"; mainProgram = "dragon"; maintainers = [ lib.maintainers.jonathanreeve ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; propagatedBuildInputs = [ - baloo baloo-widgets kactivities kbookmarks kcmutils kcompletion kconfig - kcoreaddons kdbusaddons kfilemetadata ki18n kiconthemes - kinit kio knewstuff knotifications kparts ktexteditor kwindowsystem - phonon solid phonon-backend-gstreamer + baloo + baloo-widgets + kactivities + kbookmarks + kcmutils + kcompletion + kconfig + kcoreaddons + kdbusaddons + kfilemetadata + ki18n + kiconthemes + kinit + kio + knewstuff + knotifications + kparts + ktexteditor + kwindowsystem + phonon + solid + phonon-backend-gstreamer + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; } diff --git a/pkgs/applications/kde/elisa.nix b/pkgs/applications/kde/elisa.nix index 82facd60e72a3b..f920f4811ae416 100644 --- a/pkgs/applications/kde/elisa.nix +++ b/pkgs/applications/kde/elisa.nix @@ -1,29 +1,36 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, qtmultimedia -, qtquickcontrols2 -, qtwebsockets -, kconfig -, kcmutils -, kcrash -, kdeclarative -, kfilemetadata -, kinit -, kirigami2 -, baloo -, libvlc +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + qtmultimedia, + qtquickcontrols2, + qtwebsockets, + kconfig, + kcmutils, + kcrash, + kdeclarative, + kfilemetadata, + kinit, + kirigami2, + baloo, + libvlc, }: mkDerivation { pname = "elisa"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; buildInputs = [ libvlc ]; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; propagatedBuildInputs = [ baloo diff --git a/pkgs/applications/kde/eventviews.nix b/pkgs/applications/kde/eventviews.nix index 382f0ee48b1db6..12fbe28e6148a6 100644 --- a/pkgs/applications/kde/eventviews.nix +++ b/pkgs/applications/kde/eventviews.nix @@ -1,22 +1,47 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, calendarsupport, kcalutils, - kdiagram, libkdepim, qtbase, qttools, kholidays + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + calendarsupport, + kcalutils, + kdiagram, + libkdepim, + qtbase, + qttools, + kholidays, }: mkDerivation { pname = "eventviews"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi calendarsupport kcalutils kdiagram - libkdepim qtbase qttools kholidays + akonadi + calendarsupport + kcalutils + kdiagram + libkdepim + qtbase + qttools + kholidays + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/falkon.nix b/pkgs/applications/kde/falkon.nix index 85c4d113fb1395..0a630f0cfe64c4 100644 --- a/pkgs/applications/kde/falkon.nix +++ b/pkgs/applications/kde/falkon.nix @@ -1,9 +1,23 @@ -{ stdenv, mkDerivation, lib -, cmake, extra-cmake-modules, pkg-config -, libpthreadstubs, libxcb, libXdmcp -, qtsvg, qttools, qtwebengine, qtx11extras -, qtwayland, wrapQtAppsHook -, kwallet, kpurpose, karchive, kio +{ + stdenv, + mkDerivation, + lib, + cmake, + extra-cmake-modules, + pkg-config, + libpthreadstubs, + libxcb, + libXdmcp, + qtsvg, + qttools, + qtwebengine, + qtx11extras, + qtwayland, + wrapQtAppsHook, + kwallet, + kpurpose, + karchive, + kio, }: mkDerivation rec { @@ -17,9 +31,17 @@ mkDerivation rec { ''; buildInputs = [ - libpthreadstubs libxcb libXdmcp - qtsvg qttools qtwebengine qtx11extras - kwallet kpurpose karchive kio + libpthreadstubs + libxcb + libXdmcp + qtsvg + qttools + qtwebengine + qtx11extras + kwallet + kpurpose + karchive + kio ] ++ lib.optionals stdenv.hostPlatform.isLinux [ qtwayland ]; nativeBuildInputs = [ @@ -33,9 +55,9 @@ mkDerivation rec { meta = with lib; { description = "QtWebEngine based cross-platform web browser"; mainProgram = "falkon"; - homepage = "https://www.falkon.org"; - license = licenses.gpl3; + homepage = "https://www.falkon.org"; + license = licenses.gpl3; maintainers = with maintainers; [ peterhoeg ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/applications/kde/ffmpegthumbs.nix b/pkgs/applications/kde/ffmpegthumbs.nix index 360da8ede775ad..76d04046d741b6 100644 --- a/pkgs/applications/kde/ffmpegthumbs.nix +++ b/pkgs/applications/kde/ffmpegthumbs.nix @@ -1,15 +1,25 @@ { - mkDerivation, lib, + mkDerivation, + lib, extra-cmake-modules, - ffmpeg, kio, taglib + ffmpeg, + kio, + taglib, }: mkDerivation { pname = "ffmpegthumbs"; meta = { - license = with lib.licenses; [ gpl2 bsd3 ]; + license = with lib.licenses; [ + gpl2 + bsd3 + ]; maintainers = [ lib.maintainers.ttuegel ]; }; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ ffmpeg kio taglib ]; + buildInputs = [ + ffmpeg + kio + taglib + ]; } diff --git a/pkgs/applications/kde/filelight.nix b/pkgs/applications/kde/filelight.nix index 4793da1562a7ec..b64add65981d43 100644 --- a/pkgs/applications/kde/filelight.nix +++ b/pkgs/applications/kde/filelight.nix @@ -1,16 +1,17 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, kio -, kparts -, kxmlgui -, qtscript -, solid -, qtquickcontrols2 -, kdeclarative -, kirigami2 -, kquickcharts +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kio, + kparts, + kxmlgui, + qtscript, + solid, + qtquickcontrols2, + kdeclarative, + kirigami2, + kquickcharts, }: mkDerivation { @@ -22,7 +23,10 @@ mkDerivation { license = with lib.licenses; [ gpl2 ]; maintainers = with lib.maintainers; [ vcunat ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; propagatedBuildInputs = [ kio kparts @@ -34,5 +38,8 @@ mkDerivation { kirigami2 kquickcharts ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/applications/kde/ghostwriter.nix b/pkgs/applications/kde/ghostwriter.nix index b29d1a9519b669..3541de3df6c41f 100644 --- a/pkgs/applications/kde/ghostwriter.nix +++ b/pkgs/applications/kde/ghostwriter.nix @@ -1,22 +1,26 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, qttools -, qtwebengine -, kcoreaddons -, kconfigwidgets -, sonnet -, kxmlgui -, hunspell -, cmark -, multimarkdown -, pandoc +{ + lib, + mkDerivation, + extra-cmake-modules, + qttools, + qtwebengine, + kcoreaddons, + kconfigwidgets, + sonnet, + kxmlgui, + hunspell, + cmark, + multimarkdown, + pandoc, }: mkDerivation { pname = "ghostwriter"; - nativeBuildInputs = [ extra-cmake-modules qttools ]; + nativeBuildInputs = [ + extra-cmake-modules + qttools + ]; buildInputs = [ qtwebengine @@ -28,7 +32,14 @@ mkDerivation { ]; qtWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath [ cmark multimarkdown pandoc ]) + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ + cmark + multimarkdown + pandoc + ]) ]; meta = with lib; { @@ -37,6 +48,9 @@ mkDerivation { homepage = "https://ghostwriter.kde.org/"; changelog = "https://invent.kde.org/office/ghostwriter/-/blob/master/CHANGELOG.md"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ dotlambda erictapen ]; + maintainers = with maintainers; [ + dotlambda + erictapen + ]; }; } diff --git a/pkgs/applications/kde/granatier.nix b/pkgs/applications/kde/granatier.nix index ac050e01479442..35683214a721b6 100644 --- a/pkgs/applications/kde/granatier.nix +++ b/pkgs/applications/kde/granatier.nix @@ -1,6 +1,10 @@ -{ mkDerivation, lib -, libkdegames, extra-cmake-modules -, kdeclarative, knewstuff +{ + mkDerivation, + lib, + libkdegames, + extra-cmake-modules, + kdeclarative, + knewstuff, }: mkDerivation { diff --git a/pkgs/applications/kde/grantleetheme/default.nix b/pkgs/applications/kde/grantleetheme/default.nix index 14f4b26290c878..7e5aa89f128eb2 100644 --- a/pkgs/applications/kde/grantleetheme/default.nix +++ b/pkgs/applications/kde/grantleetheme/default.nix @@ -1,21 +1,50 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - grantlee, ki18n, kiconthemes, knewstuff, kservice, kxmlgui, qtbase, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + grantlee, + ki18n, + kiconthemes, + knewstuff, + kservice, + kxmlgui, + qtbase, }: mkDerivation { pname = "grantleetheme"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - outputs = [ "out" "dev" ]; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + outputs = [ + "out" + "dev" + ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - grantlee ki18n kiconthemes knewstuff kservice kxmlgui qtbase + grantlee + ki18n + kiconthemes + knewstuff + kservice + kxmlgui + qtbase + ]; + propagatedBuildInputs = [ + grantlee + kiconthemes + knewstuff ]; - propagatedBuildInputs = [ grantlee kiconthemes knewstuff ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/gwenview/default.nix b/pkgs/applications/kde/gwenview/default.nix index 883620904ee473..13dc1b52a60b74 100644 --- a/pkgs/applications/kde/gwenview/default.nix +++ b/pkgs/applications/kde/gwenview/default.nix @@ -1,10 +1,30 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - exiv2, lcms2, cfitsio, - baloo, kactivities, kio, kipi-plugins, kitemmodels, kparts, libkdcraw, libkipi, - phonon, qtimageformats, qtsvg, qtx11extras, kinit, kpurpose, kcolorpicker, kimageannotator, - wayland, wayland-protocols, wayland-scanner + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + exiv2, + lcms2, + cfitsio, + baloo, + kactivities, + kio, + kipi-plugins, + kitemmodels, + kparts, + libkdcraw, + libkipi, + phonon, + qtimageformats, + qtsvg, + qtx11extras, + kinit, + kpurpose, + kcolorpicker, + kimageannotator, + wayland, + wayland-protocols, + wayland-scanner, }: mkDerivation { @@ -12,20 +32,46 @@ mkDerivation { meta = { homepage = "https://apps.kde.org/gwenview/"; description = "KDE image viewer"; - license = with lib.licenses; [ gpl2Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + fdl12Plus + ]; maintainers = [ lib.maintainers.ttuegel ]; mainProgram = "gwenview"; }; # Fix build with versioned kImageAnnotator - patches = [./kimageannotator.patch]; + patches = [ ./kimageannotator.patch ]; - nativeBuildInputs = [ extra-cmake-modules kdoctools wayland-scanner ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wayland-scanner + ]; buildInputs = [ - baloo kactivities kio kitemmodels kparts libkdcraw libkipi phonon - exiv2 lcms2 cfitsio - qtimageformats qtsvg qtx11extras kpurpose kcolorpicker kimageannotator - wayland wayland-protocols + baloo + kactivities + kio + kitemmodels + kparts + libkdcraw + libkipi + phonon + exiv2 + lcms2 + cfitsio + qtimageformats + qtsvg + qtx11extras + kpurpose + kcolorpicker + kimageannotator + wayland + wayland-protocols + ]; + propagatedUserEnvPkgs = [ + kipi-plugins + libkipi + (lib.getBin kinit) ]; - propagatedUserEnvPkgs = [ kipi-plugins libkipi (lib.getBin kinit) ]; } diff --git a/pkgs/applications/kde/incidenceeditor.nix b/pkgs/applications/kde/incidenceeditor.nix index 2e10c129eefd65..36b056280992c8 100644 --- a/pkgs/applications/kde/incidenceeditor.nix +++ b/pkgs/applications/kde/incidenceeditor.nix @@ -1,22 +1,49 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-mime, calendarsupport, eventviews, - kdiagram, kldap, kmime, pimcommon, qtbase + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-mime, + calendarsupport, + eventviews, + kdiagram, + kldap, + kmime, + pimcommon, + qtbase, }: mkDerivation { pname = "incidenceeditor"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi akonadi-mime calendarsupport eventviews kdiagram - kldap kmime pimcommon qtbase + akonadi + akonadi-mime + calendarsupport + eventviews + kdiagram + kldap + kmime + pimcommon + qtbase + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/itinerary.nix b/pkgs/applications/kde/itinerary.nix index 7ac03f0800ff6f..1fb82cdac64e81 100644 --- a/pkgs/applications/kde/itinerary.nix +++ b/pkgs/applications/kde/itinerary.nix @@ -1,34 +1,38 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, karchive -, kcalendarcore -, kcontacts -, kdbusaddons -, kfilemetadata -, kholidays -, kio -, kirigami-addons -, kitemmodels -, kitinerary -, kmime -, knotifications -, kosmindoormap -, kpkpass -, kpublictransport -, kunitconversion -, libquotient -, networkmanager-qt -, prison -, qqc2-desktop-style -, qtpositioning -, qtquickcontrols2 -, shared-mime-info +{ + mkDerivation, + lib, + extra-cmake-modules, + karchive, + kcalendarcore, + kcontacts, + kdbusaddons, + kfilemetadata, + kholidays, + kio, + kirigami-addons, + kitemmodels, + kitinerary, + kmime, + knotifications, + kosmindoormap, + kpkpass, + kpublictransport, + kunitconversion, + libquotient, + networkmanager-qt, + prison, + qqc2-desktop-style, + qtpositioning, + qtquickcontrols2, + shared-mime-info, }: mkDerivation { pname = "itinerary"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ extra-cmake-modules @@ -60,5 +64,10 @@ mkDerivation { qtquickcontrols2 ]; - meta.license = with lib.licenses; [ asl20 bsd3 cc0 lgpl2Plus ]; + meta.license = with lib.licenses; [ + asl20 + bsd3 + cc0 + lgpl2Plus + ]; } diff --git a/pkgs/applications/kde/juk.nix b/pkgs/applications/kde/juk.nix index dd428a0144874a..4e887562b07031 100644 --- a/pkgs/applications/kde/juk.nix +++ b/pkgs/applications/kde/juk.nix @@ -1,13 +1,14 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, wrapQtAppsHook -, kdoctools -, kcoreaddons -, kxmlgui -, kio -, phonon -, taglib +{ + lib, + mkDerivation, + extra-cmake-modules, + wrapQtAppsHook, + kdoctools, + kcoreaddons, + kxmlgui, + kio, + phonon, + taglib, }: mkDerivation { diff --git a/pkgs/applications/kde/kaccounts-integration.nix b/pkgs/applications/kde/kaccounts-integration.nix index 069bedcb53b25e..ef9b3deb2d1938 100644 --- a/pkgs/applications/kde/kaccounts-integration.nix +++ b/pkgs/applications/kde/kaccounts-integration.nix @@ -1,4 +1,15 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, kcmutils, kcoreaddons, kwallet, accounts-qt, signond, qcoro }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kcmutils, + kcoreaddons, + kwallet, + accounts-qt, + signond, + qcoro, +}: mkDerivation { pname = "kaccounts-integration"; diff --git a/pkgs/applications/kde/kaccounts-providers.nix b/pkgs/applications/kde/kaccounts-providers.nix index e0e5ee3cd3261a..3e265c37677839 100644 --- a/pkgs/applications/kde/kaccounts-providers.nix +++ b/pkgs/applications/kde/kaccounts-providers.nix @@ -1,18 +1,19 @@ -{ mkDerivation -, lib -, accounts-qt -, extra-cmake-modules -, intltool -, kaccounts-integration -, kcmutils -, kcoreaddons -, kdeclarative -, kdoctools -, kio -, kpackage -, kwallet -, qtwebengine -, signond +{ + mkDerivation, + lib, + accounts-qt, + extra-cmake-modules, + intltool, + kaccounts-integration, + kcmutils, + kcoreaddons, + kdeclarative, + kdoctools, + kio, + kpackage, + kwallet, + qtwebengine, + signond, }: mkDerivation { diff --git a/pkgs/applications/kde/kaddressbook.nix b/pkgs/applications/kde/kaddressbook.nix index 0d5df31781c310..9e01da6d5a192b 100644 --- a/pkgs/applications/kde/kaddressbook.nix +++ b/pkgs/applications/kde/kaddressbook.nix @@ -1,12 +1,30 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-search, grantlee, grantleetheme, kcmutils, kcompletion, - kcrash, kdbusaddons, ki18n, kontactinterface, kparts, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-search, + grantlee, + grantleetheme, + kcmutils, + kcompletion, + kcrash, + kdbusaddons, + ki18n, + kontactinterface, + kparts, kpimtextedit, kuserfeedback, - kxmlgui, libkdepim, libkleo, mailcommon, pimcommon, prison, - qgpgme, qtbase, + kxmlgui, + libkdepim, + libkleo, + mailcommon, + pimcommon, + prison, + qgpgme, + qtbase, }: mkDerivation { @@ -15,15 +33,39 @@ mkDerivation { homepage = "https://apps.kde.org/kaddressbook/"; description = "KDE contact manager"; mainProgram = "kaddressbook"; - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi akonadi-search grantlee grantleetheme kcmutils kcompletion kcrash - kdbusaddons ki18n kontactinterface kparts kpimtextedit + akonadi + akonadi-search + grantlee + grantleetheme + kcmutils + kcompletion + kcrash + kdbusaddons + ki18n + kontactinterface + kparts + kpimtextedit kuserfeedback - kxmlgui libkdepim libkleo mailcommon pimcommon prison qgpgme qtbase + kxmlgui + libkdepim + libkleo + mailcommon + pimcommon + prison + qgpgme + qtbase ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing diff --git a/pkgs/applications/kde/kalarm.nix b/pkgs/applications/kde/kalarm.nix index b99098c56f936f..6a546c8f235500 100644 --- a/pkgs/applications/kde/kalarm.nix +++ b/pkgs/applications/kde/kalarm.nix @@ -1,19 +1,49 @@ { - mkDerivation, lib, + mkDerivation, + lib, extra-cmake-modules, - kauth, kcodecs, kcompletion, kconfig, kconfigwidgets, kdbusaddons, kdoctools, - kguiaddons, ki18n, kiconthemes, kidletime, kjobwidgets, kcmutils, - kio, knotifications, knotifyconfig, kservice, kwidgetsaddons, - kwindowsystem, kxmlgui, phonon, + kauth, + kcodecs, + kcompletion, + kconfig, + kconfigwidgets, + kdbusaddons, + kdoctools, + kguiaddons, + ki18n, + kiconthemes, + kidletime, + kjobwidgets, + kcmutils, + kio, + knotifications, + knotifyconfig, + kservice, + kwidgetsaddons, + kwindowsystem, + kxmlgui, + phonon, - kimap, akonadi, akonadi-contacts, akonadi-mime, kcalendarcore, kcalutils, - kholidays, kidentitymanagement, libkdepim, mailcommon, kmailtransport, kmime, - pimcommon, kpimtextedit, messagelib, + kimap, + akonadi, + akonadi-contacts, + akonadi-mime, + kcalendarcore, + kcalutils, + kholidays, + kidentitymanagement, + libkdepim, + mailcommon, + kmailtransport, + kmime, + pimcommon, + kpimtextedit, + messagelib, qtx11extras, - kdepim-runtime + kdepim-runtime, }: mkDerivation { @@ -24,16 +54,48 @@ mkDerivation { license = with lib.licenses; [ gpl2 ]; maintainers = [ ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kauth kcodecs kcompletion kconfig kconfigwidgets kdbusaddons kdoctools - kguiaddons ki18n kiconthemes kidletime kjobwidgets kcmutils - kio knotifications knotifyconfig kservice kwidgetsaddons kwindowsystem - kxmlgui phonon + kauth + kcodecs + kcompletion + kconfig + kconfigwidgets + kdbusaddons + kdoctools + kguiaddons + ki18n + kiconthemes + kidletime + kjobwidgets + kcmutils + kio + knotifications + knotifyconfig + kservice + kwidgetsaddons + kwindowsystem + kxmlgui + phonon - kimap akonadi akonadi-contacts akonadi-mime kcalendarcore - kcalutils kholidays kidentitymanagement libkdepim mailcommon kmailtransport - kmime pimcommon kpimtextedit messagelib + kimap + akonadi + akonadi-contacts + akonadi-mime + kcalendarcore + kcalutils + kholidays + kidentitymanagement + libkdepim + mailcommon + kmailtransport + kmime + pimcommon + kpimtextedit + messagelib qtx11extras ]; diff --git a/pkgs/applications/kde/kalgebra.nix b/pkgs/applications/kde/kalgebra.nix index 539ee30a668021..b3d6e7b76df477 100644 --- a/pkgs/applications/kde/kalgebra.nix +++ b/pkgs/applications/kde/kalgebra.nix @@ -1,23 +1,27 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, analitza -, ki18n -, kinit -, kirigami2 -, kconfigwidgets -, kwidgetsaddons -, kio -, kxmlgui -, qtwebengine -, plasma-framework +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + analitza, + ki18n, + kinit, + kirigami2, + kconfigwidgets, + kwidgetsaddons, + kio, + kxmlgui, + qtwebengine, + plasma-framework, }: mkDerivation { pname = "kalgebra"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ extra-cmake-modules diff --git a/pkgs/applications/kde/kalk.nix b/pkgs/applications/kde/kalk.nix index dd4be365d7be31..688c3de2711286 100644 --- a/pkgs/applications/kde/kalk.nix +++ b/pkgs/applications/kde/kalk.nix @@ -1,21 +1,22 @@ -{ lib -, mkDerivation - -, cmake -, extra-cmake-modules -, bison -, flex - -, gmp -, mpfr - -, kconfig -, kcoreaddons -, ki18n -, kirigami2 -, kunitconversion -, qtfeedback -, qtquickcontrols2 +{ + lib, + mkDerivation, + + cmake, + extra-cmake-modules, + bison, + flex, + + gmp, + mpfr, + + kconfig, + kcoreaddons, + ki18n, + kirigami2, + kunitconversion, + qtfeedback, + qtquickcontrols2, }: mkDerivation rec { diff --git a/pkgs/applications/kde/kalzium.nix b/pkgs/applications/kde/kalzium.nix index c365f6e7e7d449..8565fc6d8d722d 100644 --- a/pkgs/applications/kde/kalzium.nix +++ b/pkgs/applications/kde/kalzium.nix @@ -1,4 +1,16 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, openbabel, qtscript, kparts, kplotting, kunitconversion }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + openbabel, + qtscript, + kparts, + kplotting, + kunitconversion, +}: mkDerivation { pname = "kalzium"; diff --git a/pkgs/applications/kde/kamoso.nix b/pkgs/applications/kde/kamoso.nix index bb83ccb8f20b10..42de6ca81e9f57 100644 --- a/pkgs/applications/kde/kamoso.nix +++ b/pkgs/applications/kde/kamoso.nix @@ -1,24 +1,35 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, wrapQtAppsHook -, qtdeclarative -, qtgraphicaleffects -, qtquickcontrols2 -, kirigami2 -, kpurpose -, gst_all_1 -, pcre +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + wrapQtAppsHook, + qtdeclarative, + qtgraphicaleffects, + qtquickcontrols2, + kirigami2, + kpurpose, + gst_all_1, + pcre, }: let - gst = with gst_all_1; [ gstreamer gst-libav gst-plugins-base gst-plugins-good gst-plugins-bad ]; + gst = with gst_all_1; [ + gstreamer + gst-libav + gst-plugins-base + gst-plugins-good + gst-plugins-bad + ]; in mkDerivation { pname = "kamoso"; - nativeBuildInputs = [ extra-cmake-modules kdoctools wrapQtAppsHook ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wrapQtAppsHook + ]; buildInputs = [ pcre ] ++ gst; propagatedBuildInputs = [ qtdeclarative @@ -41,6 +52,9 @@ mkDerivation { homepage = "https://apps.kde.org/kamoso/"; description = "Simple and friendly program to use your camera"; mainProgram = "kamoso"; - license = with lib.licenses; [ lgpl21Only gpl3Only ]; + license = with lib.licenses; [ + lgpl21Only + gpl3Only + ]; }; } diff --git a/pkgs/applications/kde/kapman.nix b/pkgs/applications/kde/kapman.nix index cb0187e9763979..2d736f974cdc08 100644 --- a/pkgs/applications/kde/kapman.nix +++ b/pkgs/applications/kde/kapman.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, libkdegames }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + libkdegames, +}: mkDerivation { pname = "kapman"; diff --git a/pkgs/applications/kde/kapptemplate.nix b/pkgs/applications/kde/kapptemplate.nix index 38b671bc382d27..278e14a2442791 100644 --- a/pkgs/applications/kde/kapptemplate.nix +++ b/pkgs/applications/kde/kapptemplate.nix @@ -1,17 +1,24 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, qtbase -, kactivities +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + qtbase, + kactivities, }: mkDerivation { pname = "kapptemplate"; - nativeBuildInputs = [ extra-cmake-modules cmake ]; + nativeBuildInputs = [ + extra-cmake-modules + cmake + ]; - buildInputs = [ kactivities qtbase ]; + buildInputs = [ + kactivities + qtbase + ]; meta = with lib; { description = "KDE App Code Template Generator"; diff --git a/pkgs/applications/kde/kasts.nix b/pkgs/applications/kde/kasts.nix index 00e87c05a48668..7ac724c761c011 100644 --- a/pkgs/applications/kde/kasts.nix +++ b/pkgs/applications/kde/kasts.nix @@ -1,27 +1,33 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules -, wrapGAppsHook3 + cmake, + extra-cmake-modules, + wrapGAppsHook3, -, gst_all_1 -, kconfig -, kcoreaddons -, ki18n -, kirigami-addons -, kirigami2 -, networkmanager-qt -, qtkeychain -, qtmultimedia -, qtquickcontrols2 -, syndication -, taglib -, threadweaver + gst_all_1, + kconfig, + kcoreaddons, + ki18n, + kirigami-addons, + kirigami2, + networkmanager-qt, + qtkeychain, + qtmultimedia, + qtquickcontrols2, + syndication, + taglib, + threadweaver, }: let - inherit (gst_all_1) gstreamer gst-plugins-base gst-plugins-good gst-plugins-bad; + inherit (gst_all_1) + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + ; in mkDerivation rec { pname = "kasts"; @@ -62,7 +68,16 @@ mkDerivation rec { mainProgram = "kasts"; homepage = "https://apps.kde.org/kasts/"; # https://invent.kde.org/plasma-mobile/kasts/-/tree/master/LICENSES - license = with licenses; [ bsd2 cc-by-sa-40 cc0 gpl2Only gpl2Plus gpl3Only gpl3Plus lgpl3Plus ]; + license = with licenses; [ + bsd2 + cc-by-sa-40 + cc0 + gpl2Only + gpl2Plus + gpl3Only + gpl3Plus + lgpl3Plus + ]; maintainers = [ ]; }; } diff --git a/pkgs/applications/kde/kate.nix b/pkgs/applications/kde/kate.nix index 646fedba158f00..6ac890208f57ab 100644 --- a/pkgs/applications/kde/kate.nix +++ b/pkgs/applications/kde/kate.nix @@ -1,10 +1,33 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - kactivities, kconfig, kcrash, kdbusaddons, kguiaddons, kiconthemes, ki18n, - kinit, kio, kitemmodels, kjobwidgets, knewstuff, knotifications, konsole, - kparts, ktexteditor, kwindowsystem, kwallet, kxmlgui, libgit2, - kuserfeedback, plasma-framework, qtscript, threadweaver, qtx11extras + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kactivities, + kconfig, + kcrash, + kdbusaddons, + kguiaddons, + kiconthemes, + ki18n, + kinit, + kio, + kitemmodels, + kjobwidgets, + knewstuff, + knotifications, + konsole, + kparts, + ktexteditor, + kwindowsystem, + kwallet, + kxmlgui, + libgit2, + kuserfeedback, + plasma-framework, + qtscript, + threadweaver, + qtx11extras, }: mkDerivation { @@ -12,7 +35,11 @@ mkDerivation { meta = { homepage = "https://apps.kde.org/kate/"; description = "Advanced text editor"; - license = with lib.licenses; [ gpl3 lgpl3 lgpl2 ]; + license = with lib.licenses; [ + gpl3 + lgpl3 + lgpl2 + ]; maintainers = [ lib.maintainers.ttuegel ]; }; @@ -26,13 +53,35 @@ mkDerivation { --replace InitialPreference=8 InitialPreference=1 ''; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ libgit2 - kactivities ki18n kio ktexteditor kwindowsystem plasma-framework - qtscript kconfig kcrash kguiaddons kiconthemes kinit kjobwidgets kparts - kxmlgui kdbusaddons kwallet kitemmodels knotifications threadweaver - knewstuff kuserfeedback qtx11extras + kactivities + ki18n + kio + ktexteditor + kwindowsystem + plasma-framework + qtscript + kconfig + kcrash + kguiaddons + kiconthemes + kinit + kjobwidgets + kparts + kxmlgui + kdbusaddons + kwallet + kitemmodels + knotifications + threadweaver + knewstuff + kuserfeedback + qtx11extras ]; propagatedUserEnvPkgs = [ konsole ]; } diff --git a/pkgs/applications/kde/katomic.nix b/pkgs/applications/kde/katomic.nix index 29e67635fb3e09..b6b39e04365c50 100644 --- a/pkgs/applications/kde/katomic.nix +++ b/pkgs/applications/kde/katomic.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, libkdegames, knewstuff }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + libkdegames, + knewstuff, +}: mkDerivation { pname = "katomic"; diff --git a/pkgs/applications/kde/kblackbox.nix b/pkgs/applications/kde/kblackbox.nix index c85184dcc10926..167a2d833011f5 100644 --- a/pkgs/applications/kde/kblackbox.nix +++ b/pkgs/applications/kde/kblackbox.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, libkdegames }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + libkdegames, +}: mkDerivation { pname = "kblackbox"; diff --git a/pkgs/applications/kde/kblocks.nix b/pkgs/applications/kde/kblocks.nix index 61e49a69999c20..80107c310a3952 100644 --- a/pkgs/applications/kde/kblocks.nix +++ b/pkgs/applications/kde/kblocks.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, libkdegames }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + libkdegames, +}: mkDerivation { pname = "kblocks"; diff --git a/pkgs/applications/kde/kbounce.nix b/pkgs/applications/kde/kbounce.nix index f6f6ad43829b55..531f703489f90a 100644 --- a/pkgs/applications/kde/kbounce.nix +++ b/pkgs/applications/kde/kbounce.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, extra-cmake-modules, libkdegames, kconfig, kcrash, kio, ki18n }: +{ + mkDerivation, + lib, + extra-cmake-modules, + libkdegames, + kconfig, + kcrash, + kio, + ki18n, +}: mkDerivation { pname = "kbounce"; diff --git a/pkgs/applications/kde/kbreakout.nix b/pkgs/applications/kde/kbreakout.nix index eb448d1a7400b7..71ce5517667a2a 100644 --- a/pkgs/applications/kde/kbreakout.nix +++ b/pkgs/applications/kde/kbreakout.nix @@ -1,12 +1,14 @@ -{ mkDerivation, lib -, extra-cmake-modules -, cmake -, kdbusaddons -, ki18n -, kconfigwidgets -, kcrash -, kxmlgui -, libkdegames +{ + mkDerivation, + lib, + extra-cmake-modules, + cmake, + kdbusaddons, + ki18n, + kconfigwidgets, + kcrash, + kxmlgui, + libkdegames, }: mkDerivation { @@ -15,13 +17,25 @@ mkDerivation { homepage = "https://apps.kde.org/kbreakout/"; description = "Breakout-like game"; mainProgram = "kbreakout"; - license = with lib.licenses; [ lgpl21 gpl3 ]; + license = with lib.licenses; [ + lgpl21 + gpl3 + ]; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ - cmake extra-cmake-modules + cmake + extra-cmake-modules ]; propagatedBuildInputs = [ - kdbusaddons ki18n kconfigwidgets kcrash kxmlgui libkdegames + kdbusaddons + ki18n + kconfigwidgets + kcrash + kxmlgui + libkdegames ]; } diff --git a/pkgs/applications/kde/kcachegrind.nix b/pkgs/applications/kde/kcachegrind.nix index 3648c18934492e..db65a3ef4c29c9 100644 --- a/pkgs/applications/kde/kcachegrind.nix +++ b/pkgs/applications/kde/kcachegrind.nix @@ -1,8 +1,18 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - karchive, ki18n, kio, perl, python3, php, qttools, - kdbusaddons, makeBinaryWrapper, graphviz + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + karchive, + ki18n, + kio, + perl, + python3, + php, + qttools, + kdbusaddons, + makeBinaryWrapper, + graphviz, }: mkDerivation { @@ -13,8 +23,21 @@ mkDerivation { license = with lib.licenses; [ gpl2 ]; maintainers = with lib.maintainers; [ orivej ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools makeBinaryWrapper ]; - buildInputs = [ karchive ki18n kio perl python3 php qttools kdbusaddons ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + makeBinaryWrapper + ]; + buildInputs = [ + karchive + ki18n + kio + perl + python3 + php + qttools + kdbusaddons + ]; postInstall = '' wrapProgram $out/bin/kcachegrind \ --suffix PATH : "${lib.makeBinPath [ graphviz ]}" diff --git a/pkgs/applications/kde/kcalc.nix b/pkgs/applications/kde/kcalc.nix index b17bda85fb7243..bbfc5661ebac1d 100644 --- a/pkgs/applications/kde/kcalc.nix +++ b/pkgs/applications/kde/kcalc.nix @@ -1,8 +1,18 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - gmp, kconfig, kconfigwidgets, kcrash, kguiaddons, ki18n, kinit, - knotifications, kxmlgui, mpfr, + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + gmp, + kconfig, + kconfigwidgets, + kcrash, + kguiaddons, + ki18n, + kinit, + knotifications, + kxmlgui, + mpfr, }: mkDerivation { @@ -13,9 +23,20 @@ mkDerivation { mainProgram = "kcalc"; license = with lib.licenses; [ gpl2 ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - gmp kconfig kconfigwidgets kcrash kguiaddons ki18n kinit knotifications - kxmlgui mpfr + gmp + kconfig + kconfigwidgets + kcrash + kguiaddons + ki18n + kinit + knotifications + kxmlgui + mpfr ]; } diff --git a/pkgs/applications/kde/kcalutils.nix b/pkgs/applications/kde/kcalutils.nix index 591e28cd737f1f..3cfbc789a50850 100644 --- a/pkgs/applications/kde/kcalutils.nix +++ b/pkgs/applications/kde/kcalutils.nix @@ -1,22 +1,45 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - grantlee, kcalendarcore, kconfig, kontactinterface, kcoreaddons, - kidentitymanagement, kpimtextedit, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + grantlee, + kcalendarcore, + kconfig, + kontactinterface, + kcoreaddons, + kidentitymanagement, + kpimtextedit, }: mkDerivation { pname = "kcalutils"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - grantlee kcalendarcore kconfig kontactinterface kcoreaddons - kidentitymanagement kpimtextedit + grantlee + kcalendarcore + kconfig + kontactinterface + kcoreaddons + kidentitymanagement + kpimtextedit + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/kcharselect.nix b/pkgs/applications/kde/kcharselect.nix index ae607c5fe49e4d..5f92632cda85e9 100644 --- a/pkgs/applications/kde/kcharselect.nix +++ b/pkgs/applications/kde/kcharselect.nix @@ -1,7 +1,16 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - kbookmarks, kconfig, kconfigwidgets, kcrash, kcoreaddons, ki18n, kwidgetsaddons, kxmlgui + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kbookmarks, + kconfig, + kconfigwidgets, + kcrash, + kcoreaddons, + ki18n, + kwidgetsaddons, + kxmlgui, }: mkDerivation { @@ -13,9 +22,19 @@ mkDerivation { description = "Tool to select special characters from all installed fonts and copy them into the clipboard"; mainProgram = "kcharselect"; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kbookmarks kconfig kconfigwidgets kcoreaddons kcrash ki18n kwidgetsaddons kxmlgui + kbookmarks + kconfig + kconfigwidgets + kcoreaddons + kcrash + ki18n + kwidgetsaddons + kxmlgui ]; enableParallelBuilding = true; } diff --git a/pkgs/applications/kde/kclock.nix b/pkgs/applications/kde/kclock.nix index 678c5ad6285e55..2f135727ba6460 100644 --- a/pkgs/applications/kde/kclock.nix +++ b/pkgs/applications/kde/kclock.nix @@ -1,19 +1,20 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules + cmake, + extra-cmake-modules, -, kconfig -, kcoreaddons -, kdbusaddons -, ki18n -, kirigami-addons -, kirigami2 -, knotifications -, plasma-framework -, qtmultimedia -, qtquickcontrols2 + kconfig, + kcoreaddons, + kdbusaddons, + ki18n, + kirigami-addons, + kirigami2, + knotifications, + plasma-framework, + qtmultimedia, + qtquickcontrols2, }: mkDerivation rec { diff --git a/pkgs/applications/kde/kcolorchooser.nix b/pkgs/applications/kde/kcolorchooser.nix index 601fe705d47ad8..2a9777388b1c2a 100644 --- a/pkgs/applications/kde/kcolorchooser.nix +++ b/pkgs/applications/kde/kcolorchooser.nix @@ -1,7 +1,10 @@ { - mkDerivation, lib, + mkDerivation, + lib, extra-cmake-modules, - ki18n, kwidgetsaddons, kxmlgui + ki18n, + kwidgetsaddons, + kxmlgui, }: mkDerivation { @@ -14,5 +17,9 @@ mkDerivation { maintainers = [ lib.maintainers.ttuegel ]; }; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ ki18n kwidgetsaddons kxmlgui ]; + buildInputs = [ + ki18n + kwidgetsaddons + kxmlgui + ]; } diff --git a/pkgs/applications/kde/kde-inotify-survey.nix b/pkgs/applications/kde/kde-inotify-survey.nix index 9adbbe3a08c1e3..9fa9c91758e836 100644 --- a/pkgs/applications/kde/kde-inotify-survey.nix +++ b/pkgs/applications/kde/kde-inotify-survey.nix @@ -1,11 +1,12 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kauth -, kcoreaddons -, kdbusaddons -, ki18n -, knotifications +{ + mkDerivation, + lib, + extra-cmake-modules, + kauth, + kcoreaddons, + kdbusaddons, + ki18n, + knotifications, }: mkDerivation { diff --git a/pkgs/applications/kde/kdebugsettings.nix b/pkgs/applications/kde/kdebugsettings.nix index 792d2dc0489667..968096d668711e 100644 --- a/pkgs/applications/kde/kdebugsettings.nix +++ b/pkgs/applications/kde/kdebugsettings.nix @@ -1,9 +1,17 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, gettext, - kcoreaddons, kconfig, kdbusaddons, kwidgetsaddons, kitemviews, kcompletion, kxmlgui, - python3 + kcoreaddons, + kconfig, + kdbusaddons, + kwidgetsaddons, + kitemviews, + kcompletion, + kxmlgui, + python3, }: mkDerivation { @@ -15,9 +23,20 @@ mkDerivation { license = with lib.licenses; [ gpl2 ]; maintainers = [ ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - gettext kcoreaddons kconfig kdbusaddons kwidgetsaddons kitemviews kcompletion kxmlgui python3 + gettext + kcoreaddons + kconfig + kdbusaddons + kwidgetsaddons + kitemviews + kcompletion + kxmlgui + python3 ]; propagatedUserEnvPkgs = [ ]; } diff --git a/pkgs/applications/kde/kdeconnect-kde.nix b/pkgs/applications/kde/kdeconnect-kde.nix index 56ccd7f103c879..736a25ec58fd51 100644 --- a/pkgs/applications/kde/kdeconnect-kde.nix +++ b/pkgs/applications/kde/kdeconnect-kde.nix @@ -1,36 +1,37 @@ -{ mkDerivation -, extra-cmake-modules -, kcmutils -, kconfigwidgets -, kdbusaddons -, kdoctools -, ki18n -, kiconthemes -, kio -, kirigami2 -, kirigami-addons -, knotifications -, kpeople -, kpeoplevcard -, kwayland -, lib -, libXtst -, libfakekey -, makeWrapper -, modemmanager-qt -, pulseaudio-qt -, qca-qt5 -, qqc2-desktop-style -, qtgraphicaleffects -, qtmultimedia -, qtquickcontrols2 -, qtx11extras -, breeze-icons -, sshfs -, wayland -, wayland-protocols -, wayland-scanner -, plasma-wayland-protocols +{ + mkDerivation, + extra-cmake-modules, + kcmutils, + kconfigwidgets, + kdbusaddons, + kdoctools, + ki18n, + kiconthemes, + kio, + kirigami2, + kirigami-addons, + knotifications, + kpeople, + kpeoplevcard, + kwayland, + lib, + libXtst, + libfakekey, + makeWrapper, + modemmanager-qt, + pulseaudio-qt, + qca-qt5, + qqc2-desktop-style, + qtgraphicaleffects, + qtmultimedia, + qtquickcontrols2, + qtx11extras, + breeze-icons, + sshfs, + wayland, + wayland-protocols, + wayland-scanner, + plasma-wayland-protocols, }: mkDerivation { @@ -67,7 +68,11 @@ mkDerivation { breeze-icons ]; - nativeBuildInputs = [ extra-cmake-modules kdoctools makeWrapper ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + makeWrapper + ]; qtWrapperArgs = [ "--prefix PATH : ${lib.makeBinPath [ sshfs ]}" diff --git a/pkgs/applications/kde/kdegraphics-mobipocket.nix b/pkgs/applications/kde/kdegraphics-mobipocket.nix index bdfe5102c01a16..221e8bbabcf195 100644 --- a/pkgs/applications/kde/kdegraphics-mobipocket.nix +++ b/pkgs/applications/kde/kdegraphics-mobipocket.nix @@ -1,7 +1,8 @@ { - mkDerivation, lib, + mkDerivation, + lib, extra-cmake-modules, - kio + kio, }: mkDerivation { @@ -12,5 +13,8 @@ mkDerivation { }; nativeBuildInputs = [ extra-cmake-modules ]; buildInputs = [ kio ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/applications/kde/kdegraphics-thumbnailers/default.nix b/pkgs/applications/kde/kdegraphics-thumbnailers/default.nix index 6686f582d6d2b7..94ff4fb6b5cf87 100644 --- a/pkgs/applications/kde/kdegraphics-thumbnailers/default.nix +++ b/pkgs/applications/kde/kdegraphics-thumbnailers/default.nix @@ -1,6 +1,14 @@ { - mkDerivation, lib, ghostscript, substituteAll, - extra-cmake-modules, karchive, kio, libkexiv2, libkdcraw, kdegraphics-mobipocket + mkDerivation, + lib, + ghostscript, + substituteAll, + extra-cmake-modules, + karchive, + kio, + libkexiv2, + libkdcraw, + kdegraphics-mobipocket, }: mkDerivation { @@ -10,7 +18,13 @@ mkDerivation { maintainers = [ lib.maintainers.ttuegel ]; }; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ karchive kio libkexiv2 libkdcraw kdegraphics-mobipocket ]; + buildInputs = [ + karchive + kio + libkexiv2 + libkdcraw + kdegraphics-mobipocket + ]; patches = [ # Hardcode patches to Ghostscript so PDF thumbnails work OOTB. diff --git a/pkgs/applications/kde/kdenetwork-filesharing.nix b/pkgs/applications/kde/kdenetwork-filesharing.nix index 4cff4a84fc407b..8300986b634eed 100644 --- a/pkgs/applications/kde/kdenetwork-filesharing.nix +++ b/pkgs/applications/kde/kdenetwork-filesharing.nix @@ -1,15 +1,37 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - kcoreaddons, kdeclarative, ki18n, kio, kwidgetsaddons, samba, qcoro + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kcoreaddons, + kdeclarative, + ki18n, + kio, + kwidgetsaddons, + samba, + qcoro, }: mkDerivation { pname = "kdenetwork-filesharing"; meta = { - license = [ lib.licenses.gpl2 lib.licenses.lgpl21 ]; + license = [ + lib.licenses.gpl2 + lib.licenses.lgpl21 + ]; maintainers = [ lib.maintainers.ttuegel ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ kcoreaddons kdeclarative ki18n kio kwidgetsaddons samba qcoro ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + kcoreaddons + kdeclarative + ki18n + kio + kwidgetsaddons + samba + qcoro + ]; } diff --git a/pkgs/applications/kde/kdenlive/default.nix b/pkgs/applications/kde/kdenlive/default.nix index 13a208fd997180..95fed3cd35ba91 100644 --- a/pkgs/applications/kde/kdenlive/default.nix +++ b/pkgs/applications/kde/kdenlive/default.nix @@ -1,41 +1,42 @@ -{ mkDerivation -, substituteAll -, lib -, extra-cmake-modules -, breeze-icons -, breeze-qt5 -, kdoctools -, kconfig -, kcrash -, kguiaddons -, kiconthemes -, ki18n -, kinit -, kdbusaddons -, knotifications -, knewstuff -, karchive -, knotifyconfig -, kplotting -, ktextwidgets -, mediainfo -, mlt -, shared-mime-info -, libv4l -, kfilemetadata -, ffmpeg-full -, frei0r -, phonon-backend-gstreamer -, qtdeclarative -, qtmultimedia -, qtnetworkauth -, qtquickcontrols2 -, qtscript -, rttr -, kpurpose -, kdeclarative -, wrapGAppsHook3 -, glaxnimate +{ + mkDerivation, + substituteAll, + lib, + extra-cmake-modules, + breeze-icons, + breeze-qt5, + kdoctools, + kconfig, + kcrash, + kguiaddons, + kiconthemes, + ki18n, + kinit, + kdbusaddons, + knotifications, + knewstuff, + karchive, + knotifyconfig, + kplotting, + ktextwidgets, + mediainfo, + mlt, + shared-mime-info, + libv4l, + kfilemetadata, + ffmpeg-full, + frei0r, + phonon-backend-gstreamer, + qtdeclarative, + qtmultimedia, + qtnetworkauth, + qtquickcontrols2, + qtscript, + rttr, + kpurpose, + kdeclarative, + wrapGAppsHook3, + glaxnimate, }: let @@ -88,14 +89,12 @@ mkDerivation { # doesn't find them. See: # https://github.com/NixOS/nixpkgs/issues/83885 patches = [ - ( - substituteAll { - src = ./dependency-paths.patch; - inherit mediainfo glaxnimate; - ffmpeg = ffmpeg-full; - mlt = mlt-full; - } - ) + (substituteAll { + src = ./dependency-paths.patch; + inherit mediainfo glaxnimate; + ffmpeg = ffmpeg-full; + mlt = mlt-full; + }) ]; postPatch = diff --git a/pkgs/applications/kde/kdepim-addons.nix b/pkgs/applications/kde/kdepim-addons.nix index 2baf991f2fb600..e86e774416eb20 100644 --- a/pkgs/applications/kde/kdepim-addons.nix +++ b/pkgs/applications/kde/kdepim-addons.nix @@ -1,25 +1,78 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, shared-mime-info, - akonadi-import-wizard, akonadi-notes, calendarsupport, eventviews, - incidenceeditor, kcalendarcore, kcalutils, kconfig, kdbusaddons, kdeclarative, - kholidays, ki18n, kmime, ktexteditor, ktnef, libgravatar, - libksieve, mailcommon, mailimporter, messagelib, poppler, prison, kpkpass, - kitinerary, kontactinterface, kaddressbook, discount + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + shared-mime-info, + akonadi-import-wizard, + akonadi-notes, + calendarsupport, + eventviews, + incidenceeditor, + kcalendarcore, + kcalutils, + kconfig, + kdbusaddons, + kdeclarative, + kholidays, + ki18n, + kmime, + ktexteditor, + ktnef, + libgravatar, + libksieve, + mailcommon, + mailimporter, + messagelib, + poppler, + prison, + kpkpass, + kitinerary, + kontactinterface, + kaddressbook, + discount, }: mkDerivation { pname = "kdepim-addons"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules shared-mime-info ]; + nativeBuildInputs = [ + extra-cmake-modules + shared-mime-info + ]; buildInputs = [ - akonadi-import-wizard akonadi-notes calendarsupport eventviews - incidenceeditor kcalendarcore kcalutils kconfig kdbusaddons kdeclarative - kholidays ki18n kmime ktexteditor ktnef libgravatar - libksieve mailcommon mailimporter messagelib poppler prison kpkpass - kitinerary kontactinterface kaddressbook discount + akonadi-import-wizard + akonadi-notes + calendarsupport + eventviews + incidenceeditor + kcalendarcore + kcalutils + kconfig + kdbusaddons + kdeclarative + kholidays + ki18n + kmime + ktexteditor + ktnef + libgravatar + libksieve + mailcommon + mailimporter + messagelib + poppler + prison + kpkpass + kitinerary + kontactinterface + kaddressbook + discount ]; } diff --git a/pkgs/applications/kde/kdepim-runtime/default.nix b/pkgs/applications/kde/kdepim-runtime/default.nix index b5158bfd15491c..5287737fb4b101 100644 --- a/pkgs/applications/kde/kdepim-runtime/default.nix +++ b/pkgs/applications/kde/kdepim-runtime/default.nix @@ -1,29 +1,88 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, shared-mime-info, - akonadi, akonadi-calendar, akonadi-contacts, akonadi-mime, akonadi-notes, - cyrus_sasl, kholidays, kcalutils, kcontacts, kdav, kidentitymanagement, - kimap, kldap, kmailtransport, kmbox, kmime, knotifications, knotifyconfig, - pimcommon, libkgapi, libsecret, - qca-qt5, qtkeychain, qtnetworkauth, qtspeech, qtwebengine, qtxmlpatterns, + akonadi, + akonadi-calendar, + akonadi-contacts, + akonadi-mime, + akonadi-notes, + cyrus_sasl, + kholidays, + kcalutils, + kcontacts, + kdav, + kidentitymanagement, + kimap, + kldap, + kmailtransport, + kmbox, + kmime, + knotifications, + knotifyconfig, + pimcommon, + libkgapi, + libsecret, + qca-qt5, + qtkeychain, + qtnetworkauth, + qtspeech, + qtwebengine, + qtxmlpatterns, }: mkDerivation { pname = "kdepim-runtime"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools shared-mime-info ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + shared-mime-info + ]; buildInputs = [ - akonadi akonadi-calendar akonadi-contacts akonadi-mime akonadi-notes - kholidays kcalutils kcontacts kdav kidentitymanagement kimap - kldap kmailtransport kmbox kmime knotifications knotifyconfig qtwebengine - pimcommon libkgapi libsecret - qca-qt5 qtkeychain qtnetworkauth qtspeech qtxmlpatterns + akonadi + akonadi-calendar + akonadi-contacts + akonadi-mime + akonadi-notes + kholidays + kcalutils + kcontacts + kdav + kidentitymanagement + kimap + kldap + kmailtransport + kmbox + kmime + knotifications + knotifyconfig + qtwebengine + pimcommon + libkgapi + libsecret + qca-qt5 + qtkeychain + qtnetworkauth + qtspeech + qtxmlpatterns ]; qtWrapperArgs = [ - "--prefix SASL_PATH : ${lib.makeSearchPath "lib/sasl2" [ cyrus_sasl.out libkgapi ]}" + "--prefix SASL_PATH : ${ + lib.makeSearchPath "lib/sasl2" [ + cyrus_sasl.out + libkgapi + ] + }" ]; } diff --git a/pkgs/applications/kde/kdevelop/kdev-php.nix b/pkgs/applications/kde/kdevelop/kdev-php.nix index 46c4af8c1c078a..5edb607cb40ee7 100644 --- a/pkgs/applications/kde/kdevelop/kdev-php.nix +++ b/pkgs/applications/kde/kdevelop/kdev-php.nix @@ -1,10 +1,27 @@ -{ mkDerivation, lib, cmake, extra-cmake-modules, threadweaver, ktexteditor, kdevelop-unwrapped, kdevelop-pg-qt }: +{ + mkDerivation, + lib, + cmake, + extra-cmake-modules, + threadweaver, + ktexteditor, + kdevelop-unwrapped, + kdevelop-pg-qt, +}: mkDerivation rec { pname = "kdev-php"; - nativeBuildInputs = [ cmake extra-cmake-modules ]; - buildInputs = [ kdevelop-pg-qt threadweaver ktexteditor kdevelop-unwrapped ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; + buildInputs = [ + kdevelop-pg-qt + threadweaver + ktexteditor + kdevelop-unwrapped + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/kde/kdevelop/kdev-python.nix b/pkgs/applications/kde/kdevelop/kdev-python.nix index 66335429bdd130..9c033837b0a81b 100644 --- a/pkgs/applications/kde/kdevelop/kdev-python.nix +++ b/pkgs/applications/kde/kdevelop/kdev-python.nix @@ -1,5 +1,12 @@ -{ mkDerivation, lib, cmake, extra-cmake-modules -, threadweaver, ktexteditor, kdevelop-unwrapped, python39 +{ + mkDerivation, + lib, + cmake, + extra-cmake-modules, + threadweaver, + ktexteditor, + kdevelop-unwrapped, + python39, }: let # FIXME: stick with python 3.9 until MR supporting 3.10 is ready: @@ -13,8 +20,15 @@ mkDerivation rec { "-DPYTHON_EXECUTABLE=${python}/bin/python" ]; - nativeBuildInputs = [ cmake extra-cmake-modules ]; - buildInputs = [ threadweaver ktexteditor kdevelop-unwrapped ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; + buildInputs = [ + threadweaver + ktexteditor + kdevelop-unwrapped + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/kde/kdevelop/kdevelop-pg-qt.nix b/pkgs/applications/kde/kdevelop/kdevelop-pg-qt.nix index 908c21bba8a655..f164e3f2e96f15 100644 --- a/pkgs/applications/kde/kdevelop/kdevelop-pg-qt.nix +++ b/pkgs/applications/kde/kdevelop/kdevelop-pg-qt.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, cmake, pkg-config, extra-cmake-modules, qtbase }: +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + extra-cmake-modules, + qtbase, +}: stdenv.mkDerivation rec { pname = "kdevelop-pg-qt"; @@ -9,7 +17,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-PVZgTEefjwSuMqUj7pHzB4xxcRfQ3rOelz4iSUy7ZfE="; }; - nativeBuildInputs = [ cmake pkg-config extra-cmake-modules ]; + nativeBuildInputs = [ + cmake + pkg-config + extra-cmake-modules + ]; buildInputs = [ qtbase ]; diff --git a/pkgs/applications/kde/kdevelop/kdevelop.nix b/pkgs/applications/kde/kdevelop/kdevelop.nix index f62d71726b22d1..7c99e4e23c300e 100644 --- a/pkgs/applications/kde/kdevelop/kdevelop.nix +++ b/pkgs/applications/kde/kdevelop/kdevelop.nix @@ -1,11 +1,47 @@ -{ mkDerivation, lib, cmake, gettext, pkg-config, extra-cmake-modules -, qtquickcontrols, qttools, kde-cli-tools -, kconfig, kdeclarative, kdoctools, kiconthemes, ki18n, kitemmodels, kitemviews -, kjobwidgets, kcmutils, kio, knewstuff, knotifyconfig, kparts, ktexteditor -, threadweaver, kxmlgui, kwindowsystem, grantlee, kcrash, karchive, kguiaddons -, plasma-framework, krunner, kdevelop-pg-qt, shared-mime-info, libkomparediff2 -, libksysguard, konsole, llvmPackages_13, makeWrapper, kpurpose, boost -, qtwebengine, cppcheck +{ + mkDerivation, + lib, + cmake, + gettext, + pkg-config, + extra-cmake-modules, + qtquickcontrols, + qttools, + kde-cli-tools, + kconfig, + kdeclarative, + kdoctools, + kiconthemes, + ki18n, + kitemmodels, + kitemviews, + kjobwidgets, + kcmutils, + kio, + knewstuff, + knotifyconfig, + kparts, + ktexteditor, + threadweaver, + kxmlgui, + kwindowsystem, + grantlee, + kcrash, + karchive, + kguiaddons, + plasma-framework, + krunner, + kdevelop-pg-qt, + shared-mime-info, + libkomparediff2, + libksysguard, + konsole, + llvmPackages_13, + makeWrapper, + kpurpose, + boost, + qtwebengine, + cppcheck, }: let @@ -15,21 +51,52 @@ mkDerivation rec { pname = "kdevelop"; nativeBuildInputs = [ - cmake gettext pkg-config extra-cmake-modules makeWrapper + cmake + gettext + pkg-config + extra-cmake-modules + makeWrapper ]; buildInputs = [ kdevelop-pg-qt - llvmPackages.llvm llvmPackages.libclang + llvmPackages.llvm + llvmPackages.libclang ]; propagatedBuildInputs = [ - qtquickcontrols boost libkomparediff2 - kconfig kdeclarative kdoctools kiconthemes ki18n kitemmodels kitemviews - kjobwidgets kcmutils kio knewstuff knotifyconfig kparts ktexteditor - threadweaver kxmlgui kwindowsystem grantlee plasma-framework krunner - shared-mime-info libksysguard konsole kcrash karchive kguiaddons kpurpose - cppcheck qtwebengine + qtquickcontrols + boost + libkomparediff2 + kconfig + kdeclarative + kdoctools + kiconthemes + ki18n + kitemmodels + kitemviews + kjobwidgets + kcmutils + kio + knewstuff + knotifyconfig + kparts + ktexteditor + threadweaver + kxmlgui + kwindowsystem + grantlee + plasma-framework + krunner + shared-mime-info + libksysguard + konsole + kcrash + karchive + kguiaddons + kpurpose + cppcheck + qtwebengine ]; # https://cgit.kde.org/kdevelop.git/commit/?id=716372ae2e8dff9c51e94d33443536786e4bd85b @@ -43,7 +110,12 @@ mkDerivation rec { postInstall = '' # The kdevelop! script (shell environment) needs qdbus and kioclient5 in PATH. wrapProgram "$out/bin/kdevelop!" \ - --prefix PATH ":" "${lib.makeBinPath [ qttools kde-cli-tools ]}" + --prefix PATH ":" "${ + lib.makeBinPath [ + qttools + kde-cli-tools + ] + }" wrapQtApp "$out/bin/kdevelop" @@ -57,15 +129,17 @@ mkDerivation rec { maintainers = [ maintainers.ambrop72 ]; platforms = platforms.linux; description = "KDE official IDE"; - longDescription = - '' - A free, opensource IDE (Integrated Development Environment) - for MS Windows, Mac OsX, Linux, Solaris and FreeBSD. It is a - feature-full, plugin extendable IDE for C/C++ and other - programming languages. It is based on KDevPlatform, KDE and Qt - libraries and is under development since 1998. - ''; + longDescription = '' + A free, opensource IDE (Integrated Development Environment) + for MS Windows, Mac OsX, Linux, Solaris and FreeBSD. It is a + feature-full, plugin extendable IDE for C/C++ and other + programming languages. It is based on KDevPlatform, KDE and Qt + libraries and is under development since 1998. + ''; homepage = "https://www.kdevelop.org"; - license = with licenses; [ gpl2Plus lgpl2Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + ]; }; } diff --git a/pkgs/applications/kde/kdevelop/wrapper.nix b/pkgs/applications/kde/kdevelop/wrapper.nix index c73f2bba7b5083..757e4d5db8d38e 100644 --- a/pkgs/applications/kde/kdevelop/wrapper.nix +++ b/pkgs/applications/kde/kdevelop/wrapper.nix @@ -1,4 +1,9 @@ -{ lib, symlinkJoin, kdevelop-unwrapped, plugins ? null }: +{ + lib, + symlinkJoin, + kdevelop-unwrapped, + plugins ? null, +}: symlinkJoin { name = "kdevelop-with-plugins"; diff --git a/pkgs/applications/kde/kdf.nix b/pkgs/applications/kde/kdf.nix index 5c196d6a3b129c..931d0ce88febc6 100644 --- a/pkgs/applications/kde/kdf.nix +++ b/pkgs/applications/kde/kdf.nix @@ -1,7 +1,14 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - kcmutils, ki18n, kiconthemes, kio, knotifications, kxmlgui, + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kcmutils, + ki18n, + kiconthemes, + kio, + knotifications, + kxmlgui, }: mkDerivation { @@ -10,6 +17,16 @@ mkDerivation { license = with lib.licenses; [ gpl2 ]; maintainers = [ lib.maintainers.peterhoeg ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ kcmutils ki18n kiconthemes kio knotifications kxmlgui ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + kcmutils + ki18n + kiconthemes + kio + knotifications + kxmlgui + ]; } diff --git a/pkgs/applications/kde/kdialog.nix b/pkgs/applications/kde/kdialog.nix index ea7393e72261b8..857ce19890f574 100644 --- a/pkgs/applications/kde/kdialog.nix +++ b/pkgs/applications/kde/kdialog.nix @@ -1,7 +1,11 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - kinit, kguiaddons, kwindowsystem + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kinit, + kguiaddons, + kwindowsystem, }: mkDerivation { @@ -10,11 +14,21 @@ mkDerivation { meta = { homepage = "https://apps.kde.org/kdialog/"; description = "Display dialog boxes from shell scripts"; - license = with lib.licenses; [ gpl2Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + fdl12Plus + ]; maintainers = with lib.maintainers; [ peterhoeg ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; - propagatedBuildInputs = [ kinit kguiaddons kwindowsystem ]; + propagatedBuildInputs = [ + kinit + kguiaddons + kwindowsystem + ]; } diff --git a/pkgs/applications/kde/kdiamond.nix b/pkgs/applications/kde/kdiamond.nix index 7da4e4605289c8..8415deb26180f0 100644 --- a/pkgs/applications/kde/kdiamond.nix +++ b/pkgs/applications/kde/kdiamond.nix @@ -1,4 +1,14 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, libkdegames, kconfig, knotifyconfig }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + libkdegames, + kconfig, + knotifyconfig, +}: mkDerivation { pname = "kdiamond"; diff --git a/pkgs/applications/kde/keditbookmarks.nix b/pkgs/applications/kde/keditbookmarks.nix index 8bc0ec87361301..f5fa35591c80b4 100644 --- a/pkgs/applications/kde/keditbookmarks.nix +++ b/pkgs/applications/kde/keditbookmarks.nix @@ -1,16 +1,32 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - kio, kparts, kwindowsystem + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kio, + kparts, + kwindowsystem, }: mkDerivation { pname = "keditbookmarks"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ kio kparts kwindowsystem ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + kio + kparts + kwindowsystem + ]; meta = with lib; { homepage = "http://www.kde.org"; - license = with licenses; [ gpl2Plus lgpl21Plus fdl12Plus bsd3 ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + bsd3 + ]; maintainers = with maintainers; [ peterhoeg ]; platforms = platforms.linux; }; diff --git a/pkgs/applications/kde/keysmith.nix b/pkgs/applications/kde/keysmith.nix index 08327151b580a9..427d708f992249 100644 --- a/pkgs/applications/kde/keysmith.nix +++ b/pkgs/applications/kde/keysmith.nix @@ -1,16 +1,17 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules + cmake, + extra-cmake-modules, -, kdbusaddons -, ki18n -, kirigami2 -, kirigami-addons -, kwindowsystem -, libsodium -, qtquickcontrols2 + kdbusaddons, + ki18n, + kirigami2, + kirigami-addons, + kwindowsystem, + libsodium, + qtquickcontrols2, }: mkDerivation rec { diff --git a/pkgs/applications/kde/kfind.nix b/pkgs/applications/kde/kfind.nix index e7449660fcd53f..70b79716dc3d28 100644 --- a/pkgs/applications/kde/kfind.nix +++ b/pkgs/applications/kde/kfind.nix @@ -1,7 +1,14 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - karchive, kcoreaddons, kfilemetadata, ktextwidgets, kwidgetsaddons, kio + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + karchive, + kcoreaddons, + kfilemetadata, + ktextwidgets, + kwidgetsaddons, + kio, }: mkDerivation { @@ -13,8 +20,16 @@ mkDerivation { license = with lib.licenses; [ gpl2 ]; maintainers = [ lib.maintainers.iblech ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - karchive kcoreaddons kfilemetadata ktextwidgets kwidgetsaddons kio + karchive + kcoreaddons + kfilemetadata + ktextwidgets + kwidgetsaddons + kio ]; } diff --git a/pkgs/applications/kde/kgeography.nix b/pkgs/applications/kde/kgeography.nix index 9e55ed5879d8c4..e38c3a12bf929c 100644 --- a/pkgs/applications/kde/kgeography.nix +++ b/pkgs/applications/kde/kgeography.nix @@ -1,7 +1,14 @@ -{ mkDerivation, lib -, cmake, extra-cmake-modules, qtbase -, kconfigwidgets, kxmlgui, kcrash, kdoctools -, kitemviews +{ + mkDerivation, + lib, + cmake, + extra-cmake-modules, + qtbase, + kconfigwidgets, + kxmlgui, + kcrash, + kdoctools, + kitemviews, }: mkDerivation { @@ -13,6 +20,16 @@ mkDerivation { license = with lib.licenses; [ gpl2 ]; maintainers = [ lib.maintainers.globin ]; }; - nativeBuildInputs = [ cmake extra-cmake-modules ]; - buildInputs = [ qtbase kconfigwidgets kxmlgui kcrash kdoctools kitemviews ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; + buildInputs = [ + qtbase + kconfigwidgets + kxmlgui + kcrash + kdoctools + kitemviews + ]; } diff --git a/pkgs/applications/kde/kget.nix b/pkgs/applications/kde/kget.nix index 1c537e97071140..d086b193cf80e6 100644 --- a/pkgs/applications/kde/kget.nix +++ b/pkgs/applications/kde/kget.nix @@ -1,18 +1,47 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - kdelibs4support, libgcrypt, libktorrent, qca-qt5, qgpgme, - kcmutils, kcompletion, kcoreaddons, knotifyconfig, kparts, kwallet, kwidgetsaddons, kwindowsystem, kxmlgui + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kdelibs4support, + libgcrypt, + libktorrent, + qca-qt5, + qgpgme, + kcmutils, + kcompletion, + kcoreaddons, + knotifyconfig, + kparts, + kwallet, + kwidgetsaddons, + kwindowsystem, + kxmlgui, }: mkDerivation { pname = "kget"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kdelibs4support libgcrypt libktorrent qca-qt5 qgpgme - kcmutils kcompletion kcoreaddons knotifyconfig kparts kwallet kwidgetsaddons kwindowsystem kxmlgui + kdelibs4support + libgcrypt + libktorrent + qca-qt5 + qgpgme + kcmutils + kcompletion + kcoreaddons + knotifyconfig + kparts + kwallet + kwidgetsaddons + kwindowsystem + kxmlgui ]; meta = with lib; { diff --git a/pkgs/applications/kde/kgpg.nix b/pkgs/applications/kde/kgpg.nix index 0aa84dd5eaffc2..8c4faa87f7278e 100644 --- a/pkgs/applications/kde/kgpg.nix +++ b/pkgs/applications/kde/kgpg.nix @@ -1,18 +1,57 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, ki18n, makeWrapper, - akonadi-contacts, gnupg, karchive, kcodecs, kcontacts, kcoreaddons, - kcrash, kdbusaddons, kiconthemes, kjobwidgets, kio, knotifications, kservice, - ktextwidgets, kxmlgui, kwidgetsaddons, kwindowsystem, qgpgme, + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + makeWrapper, + akonadi-contacts, + gnupg, + karchive, + kcodecs, + kcontacts, + kcoreaddons, + kcrash, + kdbusaddons, + kiconthemes, + kjobwidgets, + kio, + knotifications, + kservice, + ktextwidgets, + kxmlgui, + kwidgetsaddons, + kwindowsystem, + qgpgme, }: mkDerivation { pname = "kgpg"; - nativeBuildInputs = [ extra-cmake-modules kdoctools makeWrapper ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + makeWrapper + ]; buildInputs = [ - akonadi-contacts gnupg karchive kcodecs kcontacts kcoreaddons kcrash - kdbusaddons ki18n kiconthemes kjobwidgets kio knotifications kservice - ktextwidgets kxmlgui kwidgetsaddons kwindowsystem qgpgme + akonadi-contacts + gnupg + karchive + kcodecs + kcontacts + kcoreaddons + kcrash + kdbusaddons + ki18n + kiconthemes + kjobwidgets + kio + knotifications + kservice + ktextwidgets + kxmlgui + kwidgetsaddons + kwindowsystem + qgpgme ]; postFixup = '' wrapProgram "$out/bin/kgpg" --prefix PATH : "${lib.makeBinPath [ gnupg ]}" diff --git a/pkgs/applications/kde/khelpcenter.nix b/pkgs/applications/kde/khelpcenter.nix index 1638c3223de563..838705a3812ee6 100644 --- a/pkgs/applications/kde/khelpcenter.nix +++ b/pkgs/applications/kde/khelpcenter.nix @@ -1,15 +1,37 @@ -{ lib, mkDerivation -, extra-cmake-modules, kdoctools -, grantlee, kcmutils, kconfig, kcoreaddons, kdbusaddons, ki18n -, kinit, khtml, kservice, xapian +{ + lib, + mkDerivation, + extra-cmake-modules, + kdoctools, + grantlee, + kcmutils, + kconfig, + kcoreaddons, + kdbusaddons, + ki18n, + kinit, + khtml, + kservice, + xapian, }: mkDerivation { pname = "khelpcenter"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - grantlee kcmutils kconfig kcoreaddons kdbusaddons khtml - ki18n kinit kservice xapian + grantlee + kcmutils + kconfig + kcoreaddons + kdbusaddons + khtml + ki18n + kinit + kservice + xapian ]; preFixup = '' diff --git a/pkgs/applications/kde/kidentitymanagement.nix b/pkgs/applications/kde/kidentitymanagement.nix index 6316a86024b2e6..024bed81044b44 100644 --- a/pkgs/applications/kde/kidentitymanagement.nix +++ b/pkgs/applications/kde/kidentitymanagement.nix @@ -1,22 +1,49 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - kcompletion, kcoreaddons, kemoticons, kiconthemes, kio, kpimtextedit, - ktextwidgets, kxmlgui + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + kcompletion, + kcoreaddons, + kemoticons, + kiconthemes, + kio, + kpimtextedit, + ktextwidgets, + kxmlgui, }: mkDerivation { pname = "kidentitymanagement"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kcompletion kemoticons kiconthemes kio ktextwidgets kxmlgui + kcompletion + kemoticons + kiconthemes + kio + ktextwidgets + kxmlgui + ]; + propagatedBuildInputs = [ + kcoreaddons + kpimtextedit + ]; + outputs = [ + "out" + "dev" ]; - propagatedBuildInputs = [ kcoreaddons kpimtextedit ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/kig.nix b/pkgs/applications/kde/kig.nix index d04cc76fc22a48..9eb9c3e7a85343 100644 --- a/pkgs/applications/kde/kig.nix +++ b/pkgs/applications/kde/kig.nix @@ -1,7 +1,15 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - boost, karchive, kcrash, kiconthemes, kparts, ktexteditor, qtsvg, + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + boost, + karchive, + kcrash, + kiconthemes, + kparts, + ktexteditor, + qtsvg, qtxmlpatterns, }: @@ -13,8 +21,18 @@ mkDerivation { license = with lib.licenses; [ gpl2 ]; maintainers = with lib.maintainers; [ raskin ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - boost karchive kcrash kiconthemes kparts ktexteditor qtsvg qtxmlpatterns + boost + karchive + kcrash + kiconthemes + kparts + ktexteditor + qtsvg + qtxmlpatterns ]; } diff --git a/pkgs/applications/kde/kigo.nix b/pkgs/applications/kde/kigo.nix index 7d6b99fd136aed..d6780752c54628 100644 --- a/pkgs/applications/kde/kigo.nix +++ b/pkgs/applications/kde/kigo.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, libkdegames, knewstuff }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + libkdegames, + knewstuff, +}: mkDerivation { pname = "kigo"; diff --git a/pkgs/applications/kde/killbots.nix b/pkgs/applications/kde/killbots.nix index 39a774b8212ede..dd3500be7ffaa2 100644 --- a/pkgs/applications/kde/killbots.nix +++ b/pkgs/applications/kde/killbots.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, libkdegames }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + libkdegames, +}: mkDerivation { pname = "killbots"; diff --git a/pkgs/applications/kde/kimap.nix b/pkgs/applications/kde/kimap.nix index b910328c2cadac..fd0a21d4312e98 100644 --- a/pkgs/applications/kde/kimap.nix +++ b/pkgs/applications/kde/kimap.nix @@ -1,19 +1,45 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - cyrus_sasl, kcoreaddons, ki18n, kio, kmime, kitemmodels + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + cyrus_sasl, + kcoreaddons, + ki18n, + kio, + kmime, + kitemmodels, }: mkDerivation { pname = "kimap"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ ki18n kio ]; - propagatedBuildInputs = [ cyrus_sasl kcoreaddons kmime kitemmodels ]; - outputs = [ "out" "dev" ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + ki18n + kio + ]; + propagatedBuildInputs = [ + cyrus_sasl + kcoreaddons + kmime + kitemmodels + ]; + outputs = [ + "out" + "dev" + ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/kio-admin.nix b/pkgs/applications/kde/kio-admin.nix index 70215ee863ed28..824ef5edb66eae 100644 --- a/pkgs/applications/kde/kio-admin.nix +++ b/pkgs/applications/kde/kio-admin.nix @@ -1,10 +1,23 @@ -{ mkDerivation, lib, extra-cmake-modules, qtbase, kio, ki18n, polkit-qt }: +{ + mkDerivation, + lib, + extra-cmake-modules, + qtbase, + kio, + ki18n, + polkit-qt, +}: mkDerivation { pname = "kio-admin"; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ qtbase kio ki18n polkit-qt ]; + buildInputs = [ + qtbase + kio + ki18n + polkit-qt + ]; meta = with lib; { description = "Manage files as administrator using the admin:// KIO protocol"; diff --git a/pkgs/applications/kde/kio-extras.nix b/pkgs/applications/kde/kio-extras.nix index 880fba59b1cbef..21738a1ac14284 100644 --- a/pkgs/applications/kde/kio-extras.nix +++ b/pkgs/applications/kde/kio-extras.nix @@ -1,23 +1,87 @@ { - mkDerivation, lib, extra-cmake-modules, kdoctools, shared-mime-info, - exiv2, kactivities, kactivities-stats, karchive, kbookmarks, kconfig, kconfigwidgets, - kcoreaddons, kdbusaddons, kdsoap, kguiaddons, kdnssd, kiconthemes, ki18n, kio, - khtml, kpty, syntax-highlighting, libmtp, libssh, openexr, libtirpc, - ilmbase, phonon, qtsvg, samba, solid, gperf, taglib, libX11, libXcursor + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + shared-mime-info, + exiv2, + kactivities, + kactivities-stats, + karchive, + kbookmarks, + kconfig, + kconfigwidgets, + kcoreaddons, + kdbusaddons, + kdsoap, + kguiaddons, + kdnssd, + kiconthemes, + ki18n, + kio, + khtml, + kpty, + syntax-highlighting, + libmtp, + libssh, + openexr, + libtirpc, + ilmbase, + phonon, + qtsvg, + samba, + solid, + gperf, + taglib, + libX11, + libXcursor, }: mkDerivation { pname = "kio-extras"; meta = { - license = with lib.licenses; [ gpl2 lgpl21 ]; + license = with lib.licenses; [ + gpl2 + lgpl21 + ]; maintainers = [ lib.maintainers.ttuegel ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools shared-mime-info ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + shared-mime-info + ]; buildInputs = [ - exiv2 kactivities kactivities-stats karchive kbookmarks kconfig kconfigwidgets kcoreaddons - kdbusaddons kdsoap kguiaddons kdnssd kiconthemes ki18n kio khtml - kpty syntax-highlighting libmtp libssh openexr libtirpc - phonon qtsvg samba solid gperf taglib libX11 libXcursor + exiv2 + kactivities + kactivities-stats + karchive + kbookmarks + kconfig + kconfigwidgets + kcoreaddons + kdbusaddons + kdsoap + kguiaddons + kdnssd + kiconthemes + ki18n + kio + khtml + kpty + syntax-highlighting + libmtp + libssh + openexr + libtirpc + phonon + qtsvg + samba + solid + gperf + taglib + libX11 + libXcursor ]; # org.kde.kmtpd5 DBUS service launches kiod5 binary from kio derivation, not from kio-extras diff --git a/pkgs/applications/kde/kio-gdrive.nix b/pkgs/applications/kde/kio-gdrive.nix index 0be35469d4068b..13076e58987cd3 100644 --- a/pkgs/applications/kde/kio-gdrive.nix +++ b/pkgs/applications/kde/kio-gdrive.nix @@ -1,14 +1,15 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, kio -, libkgapi -, kcalendarcore -, kcontacts -, qtkeychain -, libsecret -, kaccounts-integration +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kio, + libkgapi, + kcalendarcore, + kcontacts, + qtkeychain, + libsecret, + kaccounts-integration, }: mkDerivation { diff --git a/pkgs/applications/kde/kipi-plugins.nix b/pkgs/applications/kde/kipi-plugins.nix index 8dde231b7cecba..a9de8cf2dabb08 100644 --- a/pkgs/applications/kde/kipi-plugins.nix +++ b/pkgs/applications/kde/kipi-plugins.nix @@ -1,17 +1,38 @@ { - mkDerivation, lib, + mkDerivation, + lib, extra-cmake-modules, - karchive, kconfig, ki18n, kiconthemes, kio, kservice, kwindowsystem, kxmlgui, - libkipi, qtbase, qtsvg, qtxmlpatterns + karchive, + kconfig, + ki18n, + kiconthemes, + kio, + kservice, + kwindowsystem, + kxmlgui, + libkipi, + qtbase, + qtsvg, + qtxmlpatterns, }: mkDerivation { - pname = "kipi-plugins"; + pname = "kipi-plugins"; nativeBuildInputs = [ extra-cmake-modules ]; buildInputs = [ - karchive kconfig ki18n kiconthemes kio kservice kwindowsystem kxmlgui libkipi - qtbase qtsvg qtxmlpatterns + karchive + kconfig + ki18n + kiconthemes + kio + kservice + kwindowsystem + kxmlgui + libkipi + qtbase + qtsvg + qtxmlpatterns ]; meta = { diff --git a/pkgs/applications/kde/kirigami-gallery.nix b/pkgs/applications/kde/kirigami-gallery.nix index 492d687e01d729..34ce15ffc6d126 100644 --- a/pkgs/applications/kde/kirigami-gallery.nix +++ b/pkgs/applications/kde/kirigami-gallery.nix @@ -1,17 +1,21 @@ -{ mkDerivation -, lib -, kirigami2 -, extra-cmake-modules -, kitemmodels -, qtgraphicaleffects -, qtquickcontrols2 -, qttools +{ + mkDerivation, + lib, + kirigami2, + extra-cmake-modules, + kitemmodels, + qtgraphicaleffects, + qtquickcontrols2, + qttools, }: mkDerivation { pname = "kirigami-gallery"; - nativeBuildInputs = [ extra-cmake-modules qttools ]; + nativeBuildInputs = [ + extra-cmake-modules + qttools + ]; buildInputs = [ qtgraphicaleffects diff --git a/pkgs/applications/kde/kitinerary.nix b/pkgs/applications/kde/kitinerary.nix index d795e4fac4c89e..0ccc338badb1b8 100644 --- a/pkgs/applications/kde/kitinerary.nix +++ b/pkgs/applications/kde/kitinerary.nix @@ -1,7 +1,16 @@ -{ mkDerivation, lib, extra-cmake-modules -, qtdeclarative, ki18n, kmime, kpkpass -, poppler, kcontacts, kcalendarcore -, shared-mime-info, zxing-cpp +{ + mkDerivation, + lib, + extra-cmake-modules, + qtdeclarative, + ki18n, + kmime, + kpkpass, + poppler, + kcontacts, + kcalendarcore, + shared-mime-info, + zxing-cpp, }: mkDerivation { @@ -15,9 +24,18 @@ mkDerivation { shared-mime-info # for update-mime-database ]; buildInputs = [ - qtdeclarative kmime kpkpass poppler - kcontacts kcalendarcore ki18n zxing-cpp + qtdeclarative + kmime + kpkpass + poppler + kcontacts + kcalendarcore + ki18n + zxing-cpp ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/applications/kde/kldap.nix b/pkgs/applications/kde/kldap.nix index b7c7777a9a5ef2..2cd16f9235f776 100644 --- a/pkgs/applications/kde/kldap.nix +++ b/pkgs/applications/kde/kldap.nix @@ -1,19 +1,47 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - cyrus_sasl, ki18n, kio, kmbox, libsecret, openldap, qtkeychain + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + cyrus_sasl, + ki18n, + kio, + kmbox, + libsecret, + openldap, + qtkeychain, }: mkDerivation { pname = "kldap"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ ki18n kio kmbox libsecret qtkeychain ]; - propagatedBuildInputs = [ cyrus_sasl openldap ]; - outputs = [ "out" "dev" ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + ki18n + kio + kmbox + libsecret + qtkeychain + ]; + propagatedBuildInputs = [ + cyrus_sasl + openldap + ]; + outputs = [ + "out" + "dev" + ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/kleopatra.nix b/pkgs/applications/kde/kleopatra.nix index fc844796acd027..1b07daee7a3386 100644 --- a/pkgs/applications/kde/kleopatra.nix +++ b/pkgs/applications/kde/kleopatra.nix @@ -1,24 +1,56 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - boost, gpgme, kcmutils, kdbusaddons, kiconthemes, kitemmodels, kmime, - knotifications, kwindowsystem, kxmlgui, libkleo, kcrash, kpipewire + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + boost, + gpgme, + kcmutils, + kdbusaddons, + kiconthemes, + kitemmodels, + kmime, + knotifications, + kwindowsystem, + kxmlgui, + libkleo, + kcrash, + kpipewire, }: mkDerivation { pname = "kleopatra"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - boost gpgme kcmutils kdbusaddons kiconthemes kitemmodels kmime - knotifications kwindowsystem kxmlgui libkleo kcrash kpipewire + boost + gpgme + kcmutils + kdbusaddons + kiconthemes + kitemmodels + kmime + knotifications + kwindowsystem + kxmlgui + libkleo + kcrash + kpipewire ]; meta = { homepage = "https://apps.kde.org/kleopatra/"; description = "Certificate manager and unified crypto GUI"; - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; } diff --git a/pkgs/applications/kde/klettres.nix b/pkgs/applications/kde/klettres.nix index 806aa6583d5c39..6e87d565198509 100644 --- a/pkgs/applications/kde/klettres.nix +++ b/pkgs/applications/kde/klettres.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, phonon, knewstuff }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + phonon, + knewstuff, +}: mkDerivation { pname = "klettres"; diff --git a/pkgs/applications/kde/klines.nix b/pkgs/applications/kde/klines.nix index de628516c826c0..36d76211c81d28 100644 --- a/pkgs/applications/kde/klines.nix +++ b/pkgs/applications/kde/klines.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, libkdegames }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + libkdegames, +}: mkDerivation { pname = "klines"; diff --git a/pkgs/applications/kde/kmag.nix b/pkgs/applications/kde/kmag.nix index adf63b145f89cb..b12e36917623e6 100644 --- a/pkgs/applications/kde/kmag.nix +++ b/pkgs/applications/kde/kmag.nix @@ -1,4 +1,11 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, +}: mkDerivation { pname = "kmag"; diff --git a/pkgs/applications/kde/kmahjongg.nix b/pkgs/applications/kde/kmahjongg.nix index 6b089aa156acd9..9d3bef13e588d5 100644 --- a/pkgs/applications/kde/kmahjongg.nix +++ b/pkgs/applications/kde/kmahjongg.nix @@ -1,17 +1,26 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, kdoctools -, kdeclarative -, knewstuff -, libkdegames -, libkmahjongg +{ + lib, + mkDerivation, + extra-cmake-modules, + kdoctools, + kdeclarative, + knewstuff, + libkdegames, + libkmahjongg, }: mkDerivation { pname = "kmahjongg"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ kdeclarative libkmahjongg knewstuff libkdegames ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + kdeclarative + libkmahjongg + knewstuff + libkdegames + ]; meta = { description = "Mahjongg solitaire"; mainProgram = "kmahjongg"; diff --git a/pkgs/applications/kde/kmail-account-wizard.nix b/pkgs/applications/kde/kmail-account-wizard.nix index 216586076aecaa..6a2e867fa34685 100644 --- a/pkgs/applications/kde/kmail-account-wizard.nix +++ b/pkgs/applications/kde/kmail-account-wizard.nix @@ -1,21 +1,63 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, shared-mime-info, - akonadi, kcmutils, kcrash, kdbusaddons, kidentitymanagement, kldap, - kmailtransport, knewstuff, knotifications, knotifyconfig, kparts, kross, ktexteditor, - kwallet, libkdepim, libkleo, pimcommon, qttools, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + shared-mime-info, + akonadi, + kcmutils, + kcrash, + kdbusaddons, + kidentitymanagement, + kldap, + kmailtransport, + knewstuff, + knotifications, + knotifyconfig, + kparts, + kross, + ktexteditor, + kwallet, + libkdepim, + libkleo, + pimcommon, + qttools, }: mkDerivation { pname = "kmail-account-wizard"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools shared-mime-info ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + shared-mime-info + ]; buildInputs = [ - akonadi kcmutils kcrash kdbusaddons kidentitymanagement kldap kmailtransport - knewstuff knotifications knotifyconfig kparts kross ktexteditor kwallet libkdepim - libkleo pimcommon qttools + akonadi + kcmutils + kcrash + kdbusaddons + kidentitymanagement + kldap + kmailtransport + knewstuff + knotifications + knotifyconfig + kparts + kross + ktexteditor + kwallet + libkdepim + libkleo + pimcommon + qttools ]; } diff --git a/pkgs/applications/kde/kmail.nix b/pkgs/applications/kde/kmail.nix index 29a60880f1274d..d8876da285a524 100644 --- a/pkgs/applications/kde/kmail.nix +++ b/pkgs/applications/kde/kmail.nix @@ -1,54 +1,55 @@ -{ mkDerivation -, lib -, akonadi -, akonadi-import-wizard -, akonadi-search -, extra-cmake-modules -, kaddressbook -, kbookmarks -, kcalutils -, kcmutils -, kcompletion -, kconfig -, kconfigwidgets -, kcoreaddons -, kdepim-addons -, kdepim-runtime -, kdepimTeam -, kdoctools -, kguiaddons -, ki18n -, kiconthemes -, kinit -, kio -, kldap -, kleopatra -, kmail-account-wizard -, kmailtransport -, knotifications -, knotifyconfig -, kontactinterface -, kparts -, kpty -, kservice -, ktextwidgets -, ktnef -, kuserfeedback -, kwallet -, kwidgetsaddons -, kwindowsystem -, kxmlgui -, libgravatar -, libkdepim -, libksieve -, libsecret -, mailcommon -, messagelib -, pim-data-exporter -, pim-sieve-editor -, qtkeychain -, qtscript -, qtwebengine +{ + mkDerivation, + lib, + akonadi, + akonadi-import-wizard, + akonadi-search, + extra-cmake-modules, + kaddressbook, + kbookmarks, + kcalutils, + kcmutils, + kcompletion, + kconfig, + kconfigwidgets, + kcoreaddons, + kdepim-addons, + kdepim-runtime, + kdepimTeam, + kdoctools, + kguiaddons, + ki18n, + kiconthemes, + kinit, + kio, + kldap, + kleopatra, + kmail-account-wizard, + kmailtransport, + knotifications, + knotifyconfig, + kontactinterface, + kparts, + kpty, + kservice, + ktextwidgets, + ktnef, + kuserfeedback, + kwallet, + kwidgetsaddons, + kwindowsystem, + kxmlgui, + libgravatar, + libkdepim, + libksieve, + libsecret, + mailcommon, + messagelib, + pim-data-exporter, + pim-sieve-editor, + qtkeychain, + qtscript, + qtwebengine, }: mkDerivation { @@ -56,10 +57,17 @@ mkDerivation { meta = { homepage = "https://apps.kde.org/kmail2/"; description = "Mail client"; - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ akonadi-search kbookmarks @@ -105,10 +113,26 @@ mkDerivation { kleopatra pim-data-exporter ]; - outputs = [ "out" "doc" ]; - propagatedUserEnvPkgs = [ kdepim-runtime kwallet akonadi ]; + outputs = [ + "out" + "doc" + ]; + propagatedUserEnvPkgs = [ + kdepim-runtime + kwallet + akonadi + ]; postFixup = '' wrapProgram "$out/bin/kmail" \ - --prefix PATH : "${lib.makeBinPath [ akonadi akonadi-import-wizard kaddressbook kleopatra kmail-account-wizard pim-data-exporter ]}" + --prefix PATH : "${ + lib.makeBinPath [ + akonadi + akonadi-import-wizard + kaddressbook + kleopatra + kmail-account-wizard + pim-data-exporter + ] + }" ''; } diff --git a/pkgs/applications/kde/kmailtransport.nix b/pkgs/applications/kde/kmailtransport.nix index ab6700144a815e..335e4a42b663f9 100644 --- a/pkgs/applications/kde/kmailtransport.nix +++ b/pkgs/applications/kde/kmailtransport.nix @@ -1,24 +1,61 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-mime, cyrus_sasl, kcmutils, - ki18n, kio, kmime, kwallet, ksmtp, libkgapi, - kcalendarcore, kcontacts, qtkeychain, libsecret + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-mime, + cyrus_sasl, + kcmutils, + ki18n, + kio, + kmime, + kwallet, + ksmtp, + libkgapi, + kcalendarcore, + kcontacts, + qtkeychain, + libsecret, }: mkDerivation { pname = "kmailtransport"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi kcmutils ki18n kio ksmtp libkgapi kcalendarcore kcontacts - qtkeychain libsecret + akonadi + kcmutils + ki18n + kio + ksmtp + libkgapi + kcalendarcore + kcontacts + qtkeychain + libsecret + ]; + propagatedBuildInputs = [ + akonadi-mime + cyrus_sasl + kmime + kwallet + ]; + outputs = [ + "out" + "dev" ]; - propagatedBuildInputs = [ akonadi-mime cyrus_sasl kmime kwallet ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/kmbox.nix b/pkgs/applications/kde/kmbox.nix index 9a835116c42f98..d14d3dba08b5bf 100644 --- a/pkgs/applications/kde/kmbox.nix +++ b/pkgs/applications/kde/kmbox.nix @@ -1,18 +1,37 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - kmime, qtbase, kcodecs + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + kmime, + qtbase, + kcodecs, }: mkDerivation { pname = "kmbox"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ kmime qtbase kcodecs ]; - outputs = [ "out" "dev" ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + kmime + qtbase + kcodecs + ]; + outputs = [ + "out" + "dev" + ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/kmime.nix b/pkgs/applications/kde/kmime.nix index fe8442e9d19dd3..6e2ad294db1c66 100644 --- a/pkgs/applications/kde/kmime.nix +++ b/pkgs/applications/kde/kmime.nix @@ -1,7 +1,11 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, ki18n, - kcodecs, qtbase, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + ki18n, + kcodecs, + qtbase, }: mkDerivation { @@ -11,8 +15,15 @@ mkDerivation { maintainers = kdepimTeam; }; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ kcodecs ki18n qtbase ]; - outputs = [ "out" "dev" ]; + buildInputs = [ + kcodecs + ki18n + qtbase + ]; + outputs = [ + "out" + "dev" + ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/kmines.nix b/pkgs/applications/kde/kmines.nix index 99413733b13bb1..d527f9f0aff2b0 100644 --- a/pkgs/applications/kde/kmines.nix +++ b/pkgs/applications/kde/kmines.nix @@ -1,4 +1,14 @@ -{ mkDerivation, lib, extra-cmake-modules, libkdegames, kconfig, kcrash, kdoctools, ki18n, kio }: +{ + mkDerivation, + lib, + extra-cmake-modules, + libkdegames, + kconfig, + kcrash, + kdoctools, + ki18n, + kio, +}: mkDerivation { pname = "kmines"; diff --git a/pkgs/applications/kde/kmix.nix b/pkgs/applications/kde/kmix.nix index 352fd129ce9457..1c433395dc24fe 100644 --- a/pkgs/applications/kde/kmix.nix +++ b/pkgs/applications/kde/kmix.nix @@ -1,8 +1,15 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - kglobalaccel, kxmlgui, kcoreaddons, - plasma-framework, libpulseaudio, alsa-lib, libcanberra_kde + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kglobalaccel, + kxmlgui, + kcoreaddons, + plasma-framework, + libpulseaudio, + alsa-lib, + libcanberra_kde, }: mkDerivation { @@ -10,13 +17,25 @@ mkDerivation { meta = { homepage = "https://apps.kde.org/kmix/"; description = "Sound mixer"; - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = [ lib.maintainers.rongcuid ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - alsa-lib kglobalaccel kxmlgui kcoreaddons - libcanberra_kde libpulseaudio plasma-framework + alsa-lib + kglobalaccel + kxmlgui + kcoreaddons + libcanberra_kde + libpulseaudio + plasma-framework ]; cmakeFlags = [ "-DKMIX_KF5_BUILD=1" ]; } diff --git a/pkgs/applications/kde/kmousetool.nix b/pkgs/applications/kde/kmousetool.nix index bedcbb6bc4dc08..b750a34d1899b2 100644 --- a/pkgs/applications/kde/kmousetool.nix +++ b/pkgs/applications/kde/kmousetool.nix @@ -1,20 +1,24 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, ki18n -, kiconthemes -, knotifications -, kxmlgui -, kwindowsystem -, phonon -, libXtst -, libXt +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kiconthemes, + knotifications, + kxmlgui, + kwindowsystem, + phonon, + libXtst, + libXt, }: mkDerivation { pname = "kmousetool"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ ki18n kiconthemes @@ -29,8 +33,10 @@ mkDerivation { homepage = "https://github.com/KDE/kmousetool"; description = "Program that clicks the mouse for you"; mainProgram = "kmousetool"; - license = with lib.licenses; [ gpl2Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + fdl12Plus + ]; maintainers = [ lib.maintainers.jayesh-bhoot ]; }; } - diff --git a/pkgs/applications/kde/kmplot.nix b/pkgs/applications/kde/kmplot.nix index 4781982153962d..b4a35a8bbc09fa 100644 --- a/pkgs/applications/kde/kmplot.nix +++ b/pkgs/applications/kde/kmplot.nix @@ -1,5 +1,14 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools -, kcrash, kguiaddons, ki18n, kparts, kwidgetsaddons, kdbusaddons +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kcrash, + kguiaddons, + ki18n, + kparts, + kwidgetsaddons, + kdbusaddons, }: mkDerivation { @@ -8,11 +17,22 @@ mkDerivation { homepage = "https://apps.kde.org/kmplot/"; description = "Mathematical function plotter"; mainProgram = "kmplot"; - license = with lib.licenses; [ gpl2Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + fdl12Plus + ]; maintainers = [ lib.maintainers.orivej ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kcrash kguiaddons ki18n kparts kwidgetsaddons kdbusaddons + kcrash + kguiaddons + ki18n + kparts + kwidgetsaddons + kdbusaddons ]; } diff --git a/pkgs/applications/kde/knavalbattle.nix b/pkgs/applications/kde/knavalbattle.nix index b405bfe1834d70..dce8ac5f0515dc 100644 --- a/pkgs/applications/kde/knavalbattle.nix +++ b/pkgs/applications/kde/knavalbattle.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, libkdegames, kdnssd }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + libkdegames, + kdnssd, +}: mkDerivation { pname = "knavalbattle"; diff --git a/pkgs/applications/kde/knetwalk.nix b/pkgs/applications/kde/knetwalk.nix index a74b18d184d7ce..14c301c0652187 100644 --- a/pkgs/applications/kde/knetwalk.nix +++ b/pkgs/applications/kde/knetwalk.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, libkdegames }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + libkdegames, +}: mkDerivation { pname = "knetwalk"; diff --git a/pkgs/applications/kde/knights.nix b/pkgs/applications/kde/knights.nix index ae0d1d62fe573a..a96486d62dbfc5 100644 --- a/pkgs/applications/kde/knights.nix +++ b/pkgs/applications/kde/knights.nix @@ -1,4 +1,14 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, kplotting, plasma-framework, libkdegames }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + kplotting, + plasma-framework, + libkdegames, +}: mkDerivation { pname = "knights"; diff --git a/pkgs/applications/kde/knotes.nix b/pkgs/applications/kde/knotes.nix index a465b82041a0f6..cf8bf1658bb7dc 100644 --- a/pkgs/applications/kde/knotes.nix +++ b/pkgs/applications/kde/knotes.nix @@ -1,26 +1,79 @@ -{ lib, mkDerivation -, extra-cmake-modules, kdoctools -, kcompletion, kconfig, kconfigwidgets, kcoreaddons, kcrash -, kdbusaddons, kdnssd, kglobalaccel, kiconthemes, kitemmodels -, kitemviews, kcmutils, knewstuff, knotifications, knotifyconfig -, kparts, ktextwidgets, kwidgetsaddons, kwindowsystem -, grantlee, grantleetheme, qtx11extras -, akonadi, akonadi-notes, akonadi-search, kcalutils -, kontactinterface, libkdepim, kmime, pimcommon, kpimtextedit -, kcalendarcore +{ + lib, + mkDerivation, + extra-cmake-modules, + kdoctools, + kcompletion, + kconfig, + kconfigwidgets, + kcoreaddons, + kcrash, + kdbusaddons, + kdnssd, + kglobalaccel, + kiconthemes, + kitemmodels, + kitemviews, + kcmutils, + knewstuff, + knotifications, + knotifyconfig, + kparts, + ktextwidgets, + kwidgetsaddons, + kwindowsystem, + grantlee, + grantleetheme, + qtx11extras, + akonadi, + akonadi-notes, + akonadi-search, + kcalutils, + kontactinterface, + libkdepim, + kmime, + pimcommon, + kpimtextedit, + kcalendarcore, }: mkDerivation { pname = "knotes"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kcompletion kconfig kconfigwidgets kcoreaddons kcrash - kdbusaddons kdnssd kglobalaccel kiconthemes kitemmodels kitemviews - kcmutils knewstuff knotifications knotifyconfig kparts ktextwidgets - kwidgetsaddons kwindowsystem - grantlee grantleetheme qtx11extras - akonadi akonadi-notes kcalutils kontactinterface - libkdepim kmime pimcommon kpimtextedit + kcompletion + kconfig + kconfigwidgets + kcoreaddons + kcrash + kdbusaddons + kdnssd + kglobalaccel + kiconthemes + kitemmodels + kitemviews + kcmutils + knewstuff + knotifications + knotifyconfig + kparts + ktextwidgets + kwidgetsaddons + kwindowsystem + grantlee + grantleetheme + qtx11extras + akonadi + akonadi-notes + kcalutils + kontactinterface + libkdepim + kmime + pimcommon + kpimtextedit akonadi-search kcalendarcore ]; diff --git a/pkgs/applications/kde/koko.nix b/pkgs/applications/kde/koko.nix index 4ea96c995bd209..38b0a3f69887ff 100644 --- a/pkgs/applications/kde/koko.nix +++ b/pkgs/applications/kde/koko.nix @@ -1,25 +1,26 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, fetchurl -, cmake -, extra-cmake-modules + fetchurl, + cmake, + extra-cmake-modules, -, exiv2 -, kconfig -, kcoreaddons -, kdeclarative -, kfilemetadata -, kguiaddons -, ki18n -, kio -, kirigami2 -, knotifications -, kpurpose -, kquickimageedit -, qtgraphicaleffects -, qtlocation -, qtquickcontrols2 + exiv2, + kconfig, + kcoreaddons, + kdeclarative, + kfilemetadata, + kguiaddons, + ki18n, + kio, + kirigami2, + knotifications, + kpurpose, + kquickimageedit, + qtgraphicaleffects, + qtlocation, + qtquickcontrols2, }: let @@ -76,7 +77,10 @@ mkDerivation rec { mainProgram = "koko"; homepage = "https://apps.kde.org/koko/"; # LGPL-2.1-only OR LGPL-3.0-only OR LicenseRef-KDE-Accepted-LGPL - license = [ licenses.lgpl3Only licenses.lgpl21Only ]; + license = [ + licenses.lgpl3Only + licenses.lgpl21Only + ]; maintainers = [ ]; }; } diff --git a/pkgs/applications/kde/kolf.nix b/pkgs/applications/kde/kolf.nix index 7d966e60c67938..eeddcf100710fe 100644 --- a/pkgs/applications/kde/kolf.nix +++ b/pkgs/applications/kde/kolf.nix @@ -1,14 +1,24 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, kdoctools -, libkdegames, kio, ktextwidgets +{ + lib, + mkDerivation, + extra-cmake-modules, + kdoctools, + libkdegames, + kio, + ktextwidgets, }: mkDerivation { pname = "kolf"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ libkdegames kio ktextwidgets ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + libkdegames + kio + ktextwidgets + ]; meta = { homepage = "https://apps.kde.org/kolf/"; description = "Miniature golf"; diff --git a/pkgs/applications/kde/kollision.nix b/pkgs/applications/kde/kollision.nix index 96e34f69c93b35..eced7728016e08 100644 --- a/pkgs/applications/kde/kollision.nix +++ b/pkgs/applications/kde/kollision.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, libkdegames }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + libkdegames, +}: mkDerivation { pname = "kollision"; diff --git a/pkgs/applications/kde/kolourpaint.nix b/pkgs/applications/kde/kolourpaint.nix index 0844cbe0a23ea4..1182cdf8d6be97 100644 --- a/pkgs/applications/kde/kolourpaint.nix +++ b/pkgs/applications/kde/kolourpaint.nix @@ -1,20 +1,29 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, kdoctools -, kguiaddons -, kio -, ktextwidgets -, kwidgetsaddons -, kxmlgui -, libkexiv2 +{ + lib, + mkDerivation, + extra-cmake-modules, + kdoctools, + kguiaddons, + kio, + ktextwidgets, + kwidgetsaddons, + kxmlgui, + libkexiv2, }: mkDerivation { pname = "kolourpaint"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kguiaddons kio ktextwidgets kwidgetsaddons kxmlgui libkexiv2 + kguiaddons + kio + ktextwidgets + kwidgetsaddons + kxmlgui + libkexiv2 ]; meta = { homepage = "https://apps.kde.org/kolourpaint/"; diff --git a/pkgs/applications/kde/kompare.nix b/pkgs/applications/kde/kompare.nix index 27c2d646413bab..efcc37a3390388 100644 --- a/pkgs/applications/kde/kompare.nix +++ b/pkgs/applications/kde/kompare.nix @@ -1,7 +1,13 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - kiconthemes, kparts, ktexteditor, kwidgetsaddons, libkomparediff2, + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kiconthemes, + kparts, + ktexteditor, + kwidgetsaddons, + libkomparediff2, }: mkDerivation { @@ -12,9 +18,19 @@ mkDerivation { mainProgram = "kompare"; license = with lib.licenses; [ gpl2 ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kiconthemes kparts ktexteditor kwidgetsaddons libkomparediff2 + kiconthemes + kparts + ktexteditor + kwidgetsaddons + libkomparediff2 + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; } diff --git a/pkgs/applications/kde/kongress.nix b/pkgs/applications/kde/kongress.nix index f5bfa9f919d112..75c650c2c85f74 100644 --- a/pkgs/applications/kde/kongress.nix +++ b/pkgs/applications/kde/kongress.nix @@ -1,14 +1,15 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, qtquickcontrols2 -, kcalendarcore -, kconfig -, kcoreaddons -, kdbusaddons -, kirigami2 -, ki18n -, knotifications +{ + mkDerivation, + lib, + extra-cmake-modules, + qtquickcontrols2, + kcalendarcore, + kconfig, + kcoreaddons, + kdbusaddons, + kirigami2, + ki18n, + knotifications, }: mkDerivation { diff --git a/pkgs/applications/kde/konqueror.nix b/pkgs/applications/kde/konqueror.nix index f048879ea545da..ce734cb3024a31 100644 --- a/pkgs/applications/kde/konqueror.nix +++ b/pkgs/applications/kde/konqueror.nix @@ -1,16 +1,33 @@ -{ lib -, mkDerivation -, extra-cmake-modules, kdoctools -, kinit, kcmutils, khtml, kdesu -, qtwebengine, qtx11extras, qtscript, qtwayland +{ + lib, + mkDerivation, + extra-cmake-modules, + kdoctools, + kinit, + kcmutils, + khtml, + kdesu, + qtwebengine, + qtx11extras, + qtscript, + qtwayland, }: mkDerivation { pname = "konqueror"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kcmutils khtml kinit kdesu - qtwebengine qtx11extras qtscript qtwayland + kcmutils + khtml + kinit + kdesu + qtwebengine + qtx11extras + qtscript + qtwayland ]; # InitialPreference values are too high and any text/html ends up diff --git a/pkgs/applications/kde/konquest.nix b/pkgs/applications/kde/konquest.nix index ca5be592af1418..5de5fc7eb5df39 100644 --- a/pkgs/applications/kde/konquest.nix +++ b/pkgs/applications/kde/konquest.nix @@ -1,23 +1,33 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, kdoctools -, kconfig -, kcoreaddons -, kcrash -, kdbusaddons -, kguiaddons -, kxmlgui -, kwidgetsaddons -, libkdegames -, qtquickcontrols +{ + lib, + mkDerivation, + extra-cmake-modules, + kdoctools, + kconfig, + kcoreaddons, + kcrash, + kdbusaddons, + kguiaddons, + kxmlgui, + kwidgetsaddons, + libkdegames, + qtquickcontrols, }: mkDerivation { pname = "konquest"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kconfig kcoreaddons kcrash kdbusaddons kguiaddons kxmlgui kwidgetsaddons + kconfig + kcoreaddons + kcrash + kdbusaddons + kguiaddons + kxmlgui + kwidgetsaddons libkdegames qtquickcontrols ]; diff --git a/pkgs/applications/kde/konsole.nix b/pkgs/applications/kde/konsole.nix index e063743186dc3b..3a5ba815b95654 100644 --- a/pkgs/applications/kde/konsole.nix +++ b/pkgs/applications/kde/konsole.nix @@ -1,10 +1,31 @@ { - mkDerivation, lib, nixosTests, - extra-cmake-modules, kdoctools, - kbookmarks, kcompletion, kconfig, kconfigwidgets, kcoreaddons, kguiaddons, - ki18n, kiconthemes, kinit, kio, knotifications, - knotifyconfig, kparts, kpty, kservice, ktextwidgets, kwidgetsaddons, - kwindowsystem, kxmlgui, qtscript, knewstuff, qtmultimedia + mkDerivation, + lib, + nixosTests, + extra-cmake-modules, + kdoctools, + kbookmarks, + kcompletion, + kconfig, + kconfigwidgets, + kcoreaddons, + kguiaddons, + ki18n, + kiconthemes, + kinit, + kio, + knotifications, + knotifyconfig, + kparts, + kpty, + kservice, + ktextwidgets, + kwidgetsaddons, + kwindowsystem, + kxmlgui, + qtscript, + knewstuff, + qtmultimedia, }: mkDerivation { @@ -12,15 +33,41 @@ mkDerivation { meta = { homepage = "https://apps.kde.org/konsole/"; description = "KDE terminal emulator"; - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = with lib.maintainers; [ ttuegel ]; mainProgram = "konsole"; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kbookmarks kcompletion kconfig kconfigwidgets kcoreaddons - kguiaddons ki18n kiconthemes kinit kio knotifications knotifyconfig kparts kpty - kservice ktextwidgets kwidgetsaddons kwindowsystem kxmlgui qtscript knewstuff qtmultimedia + kbookmarks + kcompletion + kconfig + kconfigwidgets + kcoreaddons + kguiaddons + ki18n + kiconthemes + kinit + kio + knotifications + knotifyconfig + kparts + kpty + kservice + ktextwidgets + kwidgetsaddons + kwindowsystem + kxmlgui + qtscript + knewstuff + qtmultimedia ]; passthru.tests.test = nixosTests.terminal-emulators.konsole; diff --git a/pkgs/applications/kde/kontact.nix b/pkgs/applications/kde/kontact.nix index f405b9af20abeb..7923157c96f4f6 100644 --- a/pkgs/applications/kde/kontact.nix +++ b/pkgs/applications/kde/kontact.nix @@ -1,11 +1,28 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, qtwebengine, - kcmutils, kcrash, kdbusaddons, kparts, kwindowsystem, - akonadi, grantleetheme, kontactinterface, kpimtextedit, - mailcommon, libkdepim, pimcommon, - akregator, kaddressbook, kmail, knotes, korganizer, zanshin + kcmutils, + kcrash, + kdbusaddons, + kparts, + kwindowsystem, + akonadi, + grantleetheme, + kontactinterface, + kpimtextedit, + mailcommon, + libkdepim, + pimcommon, + akregator, + kaddressbook, + kmail, + knotes, + korganizer, + zanshin, }: mkDerivation { @@ -14,15 +31,36 @@ mkDerivation { homepage = "https://apps.kde.org/kontact/"; description = "Personal information manager"; mainProgram = "kontact"; - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ qtwebengine - kcmutils kcrash kdbusaddons kparts kwindowsystem - akonadi grantleetheme kontactinterface kpimtextedit - mailcommon libkdepim pimcommon - akregator kaddressbook kmail knotes korganizer zanshin + kcmutils + kcrash + kdbusaddons + kparts + kwindowsystem + akonadi + grantleetheme + kontactinterface + kpimtextedit + mailcommon + libkdepim + pimcommon + akregator + kaddressbook + kmail + knotes + korganizer + zanshin ]; } diff --git a/pkgs/applications/kde/kontactinterface.nix b/pkgs/applications/kde/kontactinterface.nix index 43e09777bddd1d..c1b7957dee4eec 100644 --- a/pkgs/applications/kde/kontactinterface.nix +++ b/pkgs/applications/kde/kontactinterface.nix @@ -1,19 +1,35 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - kiconthemes, kparts, kwindowsystem, kxmlgui, - qtx11extras + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + kiconthemes, + kparts, + kwindowsystem, + kxmlgui, + qtx11extras, }: mkDerivation { pname = "kontactinterface"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kiconthemes kwindowsystem kxmlgui qtx11extras + kiconthemes + kwindowsystem + kxmlgui + qtx11extras ]; propagatedBuildInputs = [ kparts ]; postInstall = '' diff --git a/pkgs/applications/kde/konversation.nix b/pkgs/applications/kde/konversation.nix index 9b995629460fa8..0752c253f7f46e 100644 --- a/pkgs/applications/kde/konversation.nix +++ b/pkgs/applications/kde/konversation.nix @@ -1,31 +1,32 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, kbookmarks -, karchive -, kconfig -, kconfigwidgets -, kcoreaddons -, kcrash -, kdbusaddons -, kemoticons -, kglobalaccel -, ki18n -, kiconthemes -, kidletime -, kitemviews -, knewstuff -, knotifications -, knotifyconfig -, kwindowsystem -, kio -, kparts -, kwallet -, solid -, sonnet -, phonon -, qtmultimedia +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kbookmarks, + karchive, + kconfig, + kconfigwidgets, + kcoreaddons, + kcrash, + kdbusaddons, + kemoticons, + kglobalaccel, + ki18n, + kiconthemes, + kidletime, + kitemviews, + knewstuff, + knotifications, + knotifyconfig, + kwindowsystem, + kio, + kparts, + kwallet, + solid, + sonnet, + phonon, + qtmultimedia, }: mkDerivation { diff --git a/pkgs/applications/kde/kopeninghours.nix b/pkgs/applications/kde/kopeninghours.nix index 6a49aeea5874c5..a35fa19dc56cac 100644 --- a/pkgs/applications/kde/kopeninghours.nix +++ b/pkgs/applications/kde/kopeninghours.nix @@ -1,15 +1,19 @@ -{ mkDerivation -, lib -, bison -, extra-cmake-modules -, flex -, kholidays -, ki18n +{ + mkDerivation, + lib, + bison, + extra-cmake-modules, + flex, + kholidays, + ki18n, }: mkDerivation { pname = "kopeninghours"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ bison @@ -23,6 +27,10 @@ mkDerivation { ]; meta = { - license = with lib.licenses; [ bsd3 cc0 lgpl2Plus ]; + license = with lib.licenses; [ + bsd3 + cc0 + lgpl2Plus + ]; }; } diff --git a/pkgs/applications/kde/korganizer.nix b/pkgs/applications/kde/korganizer.nix index c1febe58f45ad5..811b67345eeb8f 100644 --- a/pkgs/applications/kde/korganizer.nix +++ b/pkgs/applications/kde/korganizer.nix @@ -1,13 +1,28 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - qtbase, qttools, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + qtbase, + qttools, phonon, knewstuff, - akonadi-calendar, akonadi-contacts, akonadi-notes, akonadi-search, - calendarsupport, eventviews, incidenceeditor, kcalutils, - kholidays, kidentitymanagement, kldap, kmailtransport, kontactinterface, - kparts, kpimtextedit, + akonadi-calendar, + akonadi-contacts, + akonadi-notes, + akonadi-search, + calendarsupport, + eventviews, + incidenceeditor, + kcalutils, + kholidays, + kidentitymanagement, + kldap, + kmailtransport, + kontactinterface, + kparts, + kpimtextedit, kuserfeedback, pimcommon, }: @@ -18,18 +33,37 @@ mkDerivation { homepage = "https://apps.kde.org/korganizer/"; description = "Personal organizer"; mainProgram = "korganizer"; - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; propagatedBuildInputs = [ - qtbase qttools + qtbase + qttools phonon knewstuff - akonadi-calendar akonadi-contacts akonadi-notes akonadi-search - calendarsupport eventviews incidenceeditor kcalutils - kholidays kidentitymanagement kldap kmailtransport kontactinterface - kparts kpimtextedit + akonadi-calendar + akonadi-contacts + akonadi-notes + akonadi-search + calendarsupport + eventviews + incidenceeditor + kcalutils + kholidays + kidentitymanagement + kldap + kmailtransport + kontactinterface + kparts + kpimtextedit kuserfeedback pimcommon ]; diff --git a/pkgs/applications/kde/kosmindoormap.nix b/pkgs/applications/kde/kosmindoormap.nix index 529aac48da7a7b..6569615eb6b0fa 100644 --- a/pkgs/applications/kde/kosmindoormap.nix +++ b/pkgs/applications/kde/kosmindoormap.nix @@ -1,16 +1,20 @@ -{ mkDerivation -, lib -, bison -, extra-cmake-modules -, flex -, ki18n -, kopeninghours -, kpublictransport +{ + mkDerivation, + lib, + bison, + extra-cmake-modules, + flex, + ki18n, + kopeninghours, + kpublictransport, }: mkDerivation { pname = "kosmindoormap"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ bison @@ -25,6 +29,14 @@ mkDerivation { ]; meta = { - license = with lib.licenses; [ bsd2 bsd3 cc0 lgpl2Plus lgpl3Plus mit odbl ]; + license = with lib.licenses; [ + bsd2 + bsd3 + cc0 + lgpl2Plus + lgpl3Plus + mit + odbl + ]; }; } diff --git a/pkgs/applications/kde/kpat.nix b/pkgs/applications/kde/kpat.nix index 3d480db6bc13f9..077a6ea5b4e36c 100644 --- a/pkgs/applications/kde/kpat.nix +++ b/pkgs/applications/kde/kpat.nix @@ -1,11 +1,12 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, knewstuff -, shared-mime-info -, libkdegames -, freecell-solver -, black-hole-solver +{ + lib, + mkDerivation, + extra-cmake-modules, + knewstuff, + shared-mime-info, + libkdegames, + freecell-solver, + black-hole-solver, }: mkDerivation { @@ -21,7 +22,11 @@ mkDerivation { freecell-solver ]; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = with lib.maintainers; [ rnhmjoj ]; }; } diff --git a/pkgs/applications/kde/kpimtextedit.nix b/pkgs/applications/kde/kpimtextedit.nix index de5afb72d1fabf..634cc2ab26fe3f 100644 --- a/pkgs/applications/kde/kpimtextedit.nix +++ b/pkgs/applications/kde/kpimtextedit.nix @@ -1,24 +1,57 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - grantlee, kcodecs, kconfigwidgets, kemoticons, ki18n, kiconthemes, kio, - kdesignerplugin, ktextwidgets, sonnet, syntax-highlighting, qttools, - qtspeech + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + grantlee, + kcodecs, + kconfigwidgets, + kemoticons, + ki18n, + kiconthemes, + kio, + kdesignerplugin, + ktextwidgets, + sonnet, + syntax-highlighting, + qttools, + qtspeech, }: mkDerivation { pname = "kpimtextedit"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - grantlee kcodecs kconfigwidgets kemoticons ki18n kiconthemes kio kdesignerplugin - sonnet syntax-highlighting qttools qtspeech + grantlee + kcodecs + kconfigwidgets + kemoticons + ki18n + kiconthemes + kio + kdesignerplugin + sonnet + syntax-highlighting + qttools + qtspeech ]; propagatedBuildInputs = [ ktextwidgets ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/kpkpass.nix b/pkgs/applications/kde/kpkpass.nix index 1d5454ac045656..94dd6381a0d588 100644 --- a/pkgs/applications/kde/kpkpass.nix +++ b/pkgs/applications/kde/kpkpass.nix @@ -1,6 +1,10 @@ { - mkDerivation, lib, extra-cmake-modules -, qtbase, karchive, shared-mime-info + mkDerivation, + lib, + extra-cmake-modules, + qtbase, + karchive, + shared-mime-info, }: mkDerivation { @@ -9,7 +13,16 @@ mkDerivation { license = with lib.licenses; [ lgpl21 ]; maintainers = [ lib.maintainers.bkchr ]; }; - nativeBuildInputs = [ extra-cmake-modules shared-mime-info ]; - buildInputs = [ qtbase karchive ]; - outputs = [ "out" "dev" ]; + nativeBuildInputs = [ + extra-cmake-modules + shared-mime-info + ]; + buildInputs = [ + qtbase + karchive + ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/applications/kde/kpmcore/default.nix b/pkgs/applications/kde/kpmcore/default.nix index 4bfc4db0f4a536..c76603b1747327 100644 --- a/pkgs/applications/kde/kpmcore/default.nix +++ b/pkgs/applications/kde/kpmcore/default.nix @@ -1,11 +1,12 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, qca-qt5 -, kauth -, kio -, polkit-qt -, util-linux +{ + mkDerivation, + lib, + extra-cmake-modules, + qca-qt5, + kauth, + kio, + polkit-qt, + util-linux, }: mkDerivation rec { @@ -38,7 +39,15 @@ mkDerivation rec { meta = with lib; { description = "KDE Partition Manager core library"; homepage = "https://invent.kde.org/system/kpmcore"; - license = with licenses; [ cc-by-40 cc0 gpl3Plus mit ]; - maintainers = with maintainers; [ peterhoeg oxalica ]; + license = with licenses; [ + cc-by-40 + cc0 + gpl3Plus + mit + ]; + maintainers = with maintainers; [ + peterhoeg + oxalica + ]; }; } diff --git a/pkgs/applications/kde/kpublictransport.nix b/pkgs/applications/kde/kpublictransport.nix index 84d97a42ac3fe4..87cc7e65bc8892 100644 --- a/pkgs/applications/kde/kpublictransport.nix +++ b/pkgs/applications/kde/kpublictransport.nix @@ -1,9 +1,10 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, qtquickcontrols2 -, networkmanager-qt -, ki18n +{ + mkDerivation, + lib, + extra-cmake-modules, + qtquickcontrols2, + networkmanager-qt, + ki18n, }: mkDerivation { diff --git a/pkgs/applications/kde/kqtquickcharts.nix b/pkgs/applications/kde/kqtquickcharts.nix index 0560fc9da01dfe..16b4432cb9342f 100644 --- a/pkgs/applications/kde/kqtquickcharts.nix +++ b/pkgs/applications/kde/kqtquickcharts.nix @@ -1,15 +1,24 @@ { - mkDerivation, lib, + mkDerivation, + lib, extra-cmake-modules, - qtbase, qtdeclarative, + qtbase, + qtdeclarative, }: mkDerivation { pname = "kqtquickcharts"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = [ lib.maintainers.ttuegel ]; }; nativeBuildInputs = [ extra-cmake-modules ]; - propagatedBuildInputs = [ qtbase qtdeclarative ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ]; } diff --git a/pkgs/applications/kde/krdc.nix b/pkgs/applications/kde/krdc.nix index 5d3fd18706dbda..2c6f4106ec53fd 100644 --- a/pkgs/applications/kde/krdc.nix +++ b/pkgs/applications/kde/krdc.nix @@ -1,16 +1,39 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, makeWrapper, - kcmutils, kcompletion, kconfig, kdnssd, knotifyconfig, kwallet, kwidgetsaddons, - kwindowsystem, libvncserver, freerdp, + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + makeWrapper, + kcmutils, + kcompletion, + kconfig, + kdnssd, + knotifyconfig, + kwallet, + kwidgetsaddons, + kwindowsystem, + libvncserver, + freerdp, }: mkDerivation { pname = "krdc"; - nativeBuildInputs = [ extra-cmake-modules kdoctools makeWrapper ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + makeWrapper + ]; buildInputs = [ - kcmutils kcompletion kconfig kdnssd knotifyconfig kwallet kwidgetsaddons - kwindowsystem freerdp libvncserver + kcmutils + kcompletion + kconfig + kdnssd + knotifyconfig + kwallet + kwidgetsaddons + kwindowsystem + freerdp + libvncserver ]; postFixup = '' wrapProgram $out/bin/krdc \ @@ -20,7 +43,12 @@ mkDerivation { homepage = "http://www.kde.org"; description = "Remote desktop client"; mainProgram = "krdc"; - license = with licenses; [ gpl2Plus lgpl21Plus fdl12Plus bsd3 ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + bsd3 + ]; maintainers = with maintainers; [ peterhoeg ]; platforms = platforms.linux; }; diff --git a/pkgs/applications/kde/krecorder.nix b/pkgs/applications/kde/krecorder.nix index 78c8e9ebb7fdbd..baae8e36eefd18 100644 --- a/pkgs/applications/kde/krecorder.nix +++ b/pkgs/applications/kde/krecorder.nix @@ -1,17 +1,18 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules + cmake, + extra-cmake-modules, -, kconfig -, kcoreaddons -, ki18n -, kirigami2 -, kirigami-addons -, kwindowsystem -, qtmultimedia -, qtquickcontrols2 + kconfig, + kcoreaddons, + ki18n, + kirigami2, + kirigami-addons, + kwindowsystem, + qtmultimedia, + qtquickcontrols2, }: mkDerivation rec { diff --git a/pkgs/applications/kde/kreversi.nix b/pkgs/applications/kde/kreversi.nix index 11cce1799c1b6b..0afc0a8eef870f 100644 --- a/pkgs/applications/kde/kreversi.nix +++ b/pkgs/applications/kde/kreversi.nix @@ -1,4 +1,10 @@ -{ mkDerivation, lib, extra-cmake-modules, libkdegames, kdeclarative }: +{ + mkDerivation, + lib, + extra-cmake-modules, + libkdegames, + kdeclarative, +}: mkDerivation { pname = "kreversi"; diff --git a/pkgs/applications/kde/krfb.nix b/pkgs/applications/kde/krfb.nix index c1294e1f1e3bb0..efd564de083f55 100644 --- a/pkgs/applications/kde/krfb.nix +++ b/pkgs/applications/kde/krfb.nix @@ -1,9 +1,28 @@ -{ mkDerivation, lib -, extra-cmake-modules, kdoctools, wayland-scanner -, kconfig, kcoreaddons, kcrash, kdbusaddons, kdnssd, knotifications, kwallet -, kwidgetsaddons, kwindowsystem, kxmlgui, kwayland, kpipewire -, libvncserver, libXtst, libXdamage -, qtx11extras, pipewire, plasma-wayland-protocols, wayland +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + wayland-scanner, + kconfig, + kcoreaddons, + kcrash, + kdbusaddons, + kdnssd, + knotifications, + kwallet, + kwidgetsaddons, + kwindowsystem, + kxmlgui, + kwayland, + kpipewire, + libvncserver, + libXtst, + libXdamage, + qtx11extras, + pipewire, + plasma-wayland-protocols, + wayland, }: mkDerivation { @@ -11,14 +30,32 @@ mkDerivation { meta = { homepage = "https://apps.kde.org/krfb/"; description = "Desktop sharing (VNC)"; - license = with lib.licenses; [ gpl2Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + fdl12Plus + ]; maintainers = with lib.maintainers; [ jerith666 ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools wayland-scanner ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wayland-scanner + ]; buildInputs = [ - libvncserver libXtst libXdamage - kconfig kcoreaddons kcrash kdbusaddons knotifications kwallet kwidgetsaddons - kwindowsystem kxmlgui kwayland kpipewire + libvncserver + libXtst + libXdamage + kconfig + kcoreaddons + kcrash + kdbusaddons + knotifications + kwallet + kwidgetsaddons + kwindowsystem + kxmlgui + kwayland + kpipewire qtx11extras pipewire plasma-wayland-protocols diff --git a/pkgs/applications/kde/kruler.nix b/pkgs/applications/kde/kruler.nix index 965ef278542b4f..fe905d37cd0a29 100644 --- a/pkgs/applications/kde/kruler.nix +++ b/pkgs/applications/kde/kruler.nix @@ -1,7 +1,12 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - knotifications, kwindowsystem, kxmlgui, qtx11extras + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + knotifications, + kwindowsystem, + kxmlgui, + qtx11extras, }: mkDerivation { @@ -13,8 +18,14 @@ mkDerivation { license = with lib.licenses; [ gpl2 ]; maintainers = [ lib.maintainers.vandenoever ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kwindowsystem knotifications kxmlgui qtx11extras + kwindowsystem + knotifications + kxmlgui + qtx11extras ]; } diff --git a/pkgs/applications/kde/ksanecore.nix b/pkgs/applications/kde/ksanecore.nix index 4ba18ffca1dff2..ae9ec9dfebcdd7 100644 --- a/pkgs/applications/kde/ksanecore.nix +++ b/pkgs/applications/kde/ksanecore.nix @@ -1,13 +1,20 @@ { - mkDerivation, lib, - extra-cmake-modules, qtbase, - ki18n, sane-backends + mkDerivation, + lib, + extra-cmake-modules, + qtbase, + ki18n, + sane-backends, }: mkDerivation { pname = "ksanecore"; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ qtbase ki18n sane-backends ]; + buildInputs = [ + qtbase + ki18n + sane-backends + ]; meta = with lib; { license = licenses.gpl2; maintainers = with maintainers; [ andrevmatos ]; diff --git a/pkgs/applications/kde/kshisen.nix b/pkgs/applications/kde/kshisen.nix index 4982456bdd01e1..3ec0dc535025b5 100644 --- a/pkgs/applications/kde/kshisen.nix +++ b/pkgs/applications/kde/kshisen.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, libkdegames, libkmahjongg }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + libkdegames, + libkmahjongg, +}: mkDerivation { pname = "kshisen"; diff --git a/pkgs/applications/kde/ksmtp/default.nix b/pkgs/applications/kde/ksmtp/default.nix index 591426e141e083..f25110706d65bb 100644 --- a/pkgs/applications/kde/ksmtp/default.nix +++ b/pkgs/applications/kde/ksmtp/default.nix @@ -1,17 +1,34 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - kcoreaddons, kio, kmime, cyrus_sasl + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + kcoreaddons, + kio, + kmime, + cyrus_sasl, }: mkDerivation { pname = "ksmtp"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ kcoreaddons kio kmime ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + kcoreaddons + kio + kmime + ]; propagatedBuildInputs = [ cyrus_sasl ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing diff --git a/pkgs/applications/kde/kspaceduel.nix b/pkgs/applications/kde/kspaceduel.nix index 500f2813b8f441..15adbd15a87b64 100644 --- a/pkgs/applications/kde/kspaceduel.nix +++ b/pkgs/applications/kde/kspaceduel.nix @@ -1,12 +1,14 @@ -{ mkDerivation, lib -, extra-cmake-modules -, cmake -, kdbusaddons -, ki18n -, kconfigwidgets -, kcrash -, kxmlgui -, libkdegames +{ + mkDerivation, + lib, + extra-cmake-modules, + cmake, + kdbusaddons, + ki18n, + kconfigwidgets, + kcrash, + kxmlgui, + libkdegames, }: mkDerivation { @@ -15,13 +17,25 @@ mkDerivation { homepage = "https://apps.kde.org/kspaceduel/"; description = "Space arcade game"; mainProgram = "kspaceduel"; - license = with lib.licenses; [ lgpl21 gpl3 ]; + license = with lib.licenses; [ + lgpl21 + gpl3 + ]; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ - cmake extra-cmake-modules + cmake + extra-cmake-modules ]; propagatedBuildInputs = [ - kdbusaddons ki18n kconfigwidgets kcrash kxmlgui libkdegames + kdbusaddons + ki18n + kconfigwidgets + kcrash + kxmlgui + libkdegames ]; } diff --git a/pkgs/applications/kde/ksquares.nix b/pkgs/applications/kde/ksquares.nix index 34a3cdeb8702fe..cdd2ce84afad81 100644 --- a/pkgs/applications/kde/ksquares.nix +++ b/pkgs/applications/kde/ksquares.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, libkdegames, kconfig, kcrash, kxmlgui }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + libkdegames, + kconfig, + kcrash, + kxmlgui, +}: mkDerivation { pname = "ksquares"; diff --git a/pkgs/applications/kde/ksudoku.nix b/pkgs/applications/kde/ksudoku.nix index 8771c878323f77..dd5744c7aa9a94 100644 --- a/pkgs/applications/kde/ksudoku.nix +++ b/pkgs/applications/kde/ksudoku.nix @@ -1,16 +1,24 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, libGLU -, kdoctools -, kdeclarative -, libkdegames +{ + lib, + mkDerivation, + extra-cmake-modules, + libGLU, + kdoctools, + kdeclarative, + libkdegames, }: mkDerivation { pname = "ksudoku"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ libGLU kdeclarative libkdegames ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + libGLU + kdeclarative + libkdegames + ]; meta = { homepage = "https://apps.kde.org/ksudoku/"; description = "Suduko game"; diff --git a/pkgs/applications/kde/ksystemlog.nix b/pkgs/applications/kde/ksystemlog.nix index c886acc65f5a70..f3e88e6e035233 100644 --- a/pkgs/applications/kde/ksystemlog.nix +++ b/pkgs/applications/kde/ksystemlog.nix @@ -1,14 +1,27 @@ { - mkDerivation, lib, - extra-cmake-modules, gettext, kdoctools, - karchive, kconfig, kio + mkDerivation, + lib, + extra-cmake-modules, + gettext, + kdoctools, + karchive, + kconfig, + kio, }: mkDerivation { pname = "ksystemlog"; - nativeBuildInputs = [ extra-cmake-modules gettext kdoctools ]; - propagatedBuildInputs = [ karchive kconfig kio ]; + nativeBuildInputs = [ + extra-cmake-modules + gettext + kdoctools + ]; + propagatedBuildInputs = [ + karchive + kconfig + kio + ]; meta = with lib; { homepage = "https://apps.kde.org/ksystemlog/"; diff --git a/pkgs/applications/kde/kteatime.nix b/pkgs/applications/kde/kteatime.nix index bda8f6b7f1f7a5..0f48b6c8b45a02 100644 --- a/pkgs/applications/kde/kteatime.nix +++ b/pkgs/applications/kde/kteatime.nix @@ -1,4 +1,14 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kconfig, kcrash, kiconthemes, knotifyconfig }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kconfig, + kcrash, + kiconthemes, + knotifyconfig, +}: mkDerivation { pname = "kteatime"; diff --git a/pkgs/applications/kde/ktimer.nix b/pkgs/applications/kde/ktimer.nix index bc2d6494c13466..a4034b83f47484 100644 --- a/pkgs/applications/kde/ktimer.nix +++ b/pkgs/applications/kde/ktimer.nix @@ -1,4 +1,11 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, +}: mkDerivation { pname = "ktimer"; diff --git a/pkgs/applications/kde/ktnef.nix b/pkgs/applications/kde/ktnef.nix index 4b0e751734e155..0bde31a482e034 100644 --- a/pkgs/applications/kde/ktnef.nix +++ b/pkgs/applications/kde/ktnef.nix @@ -1,20 +1,37 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - kcalendarcore, kcalutils, kcontacts + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + kcalendarcore, + kcalutils, + kcontacts, }: mkDerivation { pname = "ktnef"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; propagatedBuildInputs = [ - kcalendarcore kcalutils kcontacts + kcalendarcore + kcalutils + kcontacts + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/ktorrent.nix b/pkgs/applications/kde/ktorrent.nix index b33cc3bc541b41..b2e5118bee8e22 100644 --- a/pkgs/applications/kde/ktorrent.nix +++ b/pkgs/applications/kde/ktorrent.nix @@ -1,22 +1,47 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - karchive, kcmutils, kcrash, kdnssd, ki18n, knotifications, knotifyconfig, - kplotting, kross, libgcrypt, libktorrent, taglib + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + karchive, + kcmutils, + kcrash, + kdnssd, + ki18n, + knotifications, + knotifyconfig, + kplotting, + kross, + libgcrypt, + libktorrent, + taglib, }: mkDerivation { pname = "ktorrent"; meta = with lib; { description = "KDE integrated BtTorrent client"; - homepage = "https://apps.kde.org/ktorrent/"; - license = licenses.gpl2Plus; + homepage = "https://apps.kde.org/ktorrent/"; + license = licenses.gpl2Plus; maintainers = [ ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - karchive kcmutils kcrash kdnssd ki18n knotifications knotifyconfig kplotting - kross libgcrypt libktorrent taglib + karchive + kcmutils + kcrash + kdnssd + ki18n + knotifications + knotifyconfig + kplotting + kross + libgcrypt + libktorrent + taglib ]; } diff --git a/pkgs/applications/kde/ktouch.nix b/pkgs/applications/kde/ktouch.nix index 18cc2ec0e32f21..6256fd174bf539 100644 --- a/pkgs/applications/kde/ktouch.nix +++ b/pkgs/applications/kde/ktouch.nix @@ -1,10 +1,29 @@ -{ mkDerivation, lib -, extra-cmake-modules, kdoctools -, kconfig, kconfigwidgets, kcoreaddons, kdeclarative, ki18n -, kitemviews, kcmutils, kio, knewstuff, ktexteditor, kwidgetsaddons -, kwindowsystem, kxmlgui, qtscript, qtdeclarative, kqtquickcharts -, qtx11extras, qtgraphicaleffects, qtxmlpatterns, qtquickcontrols2 -, xorg +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kconfig, + kconfigwidgets, + kcoreaddons, + kdeclarative, + ki18n, + kitemviews, + kcmutils, + kio, + knewstuff, + ktexteditor, + kwidgetsaddons, + kwindowsystem, + kxmlgui, + qtscript, + qtdeclarative, + kqtquickcharts, + qtx11extras, + qtgraphicaleffects, + qtxmlpatterns, + qtquickcontrols2, + xorg, }: mkDerivation { @@ -16,13 +35,34 @@ mkDerivation { description = "Touch typing tutor from the KDE software collection"; mainProgram = "ktouch"; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools qtdeclarative ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + qtdeclarative + ]; buildInputs = [ - kconfig kconfigwidgets kcoreaddons kdeclarative ki18n - kitemviews kcmutils kio knewstuff ktexteditor kwidgetsaddons - kwindowsystem kxmlgui qtscript qtdeclarative kqtquickcharts - qtx11extras qtgraphicaleffects qtxmlpatterns qtquickcontrols2 - xorg.libxkbfile xorg.libxcb + kconfig + kconfigwidgets + kcoreaddons + kdeclarative + ki18n + kitemviews + kcmutils + kio + knewstuff + ktexteditor + kwidgetsaddons + kwindowsystem + kxmlgui + qtscript + qtdeclarative + kqtquickcharts + qtx11extras + qtgraphicaleffects + qtxmlpatterns + qtquickcontrols2 + xorg.libxkbfile + xorg.libxcb ]; enableParallelBuilding = true; diff --git a/pkgs/applications/kde/ktrip.nix b/pkgs/applications/kde/ktrip.nix index fd30379465d53a..9d14b319a1b97a 100644 --- a/pkgs/applications/kde/ktrip.nix +++ b/pkgs/applications/kde/ktrip.nix @@ -1,19 +1,20 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules + cmake, + extra-cmake-modules, -, kconfig -, kcontacts -, kcoreaddons -, ki18n -, kirigami-addons -, kirigami2 -, kitemmodels -, kpublictransport -, qqc2-desktop-style -, qtquickcontrols2 + kconfig, + kcontacts, + kcoreaddons, + ki18n, + kirigami-addons, + kirigami2, + kitemmodels, + kpublictransport, + qqc2-desktop-style, + qtquickcontrols2, }: mkDerivation rec { diff --git a/pkgs/applications/kde/kturtle.nix b/pkgs/applications/kde/kturtle.nix index 299b6bd83faccb..af0b867ae9881e 100644 --- a/pkgs/applications/kde/kturtle.nix +++ b/pkgs/applications/kde/kturtle.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, ki18n, kio, knewstuff }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + kio, + knewstuff, +}: mkDerivation { pname = "kturtle"; diff --git a/pkgs/applications/kde/kwalletmanager.nix b/pkgs/applications/kde/kwalletmanager.nix index 64d4d36806f2e6..8edc210f2e0687 100644 --- a/pkgs/applications/kde/kwalletmanager.nix +++ b/pkgs/applications/kde/kwalletmanager.nix @@ -1,14 +1,15 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, kdoctools -, kauth -, kcmutils -, kconfigwidgets -, kcoreaddons -, kdbusaddons -, kwallet -, kxmlgui +{ + lib, + mkDerivation, + extra-cmake-modules, + kdoctools, + kauth, + kcmutils, + kconfigwidgets, + kcoreaddons, + kdbusaddons, + kwallet, + kxmlgui, }: mkDerivation { @@ -20,9 +21,17 @@ mkDerivation { mainProgram = "kwalletmanager5"; license = with lib.licenses; [ gpl2 ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kauth kcmutils kconfigwidgets kcoreaddons kdbusaddons - kwallet kxmlgui + kauth + kcmutils + kconfigwidgets + kcoreaddons + kdbusaddons + kwallet + kxmlgui ]; } diff --git a/pkgs/applications/kde/kwave.nix b/pkgs/applications/kde/kwave.nix index 46e6c1a5cf3c4d..899b0177da98c3 100644 --- a/pkgs/applications/kde/kwave.nix +++ b/pkgs/applications/kde/kwave.nix @@ -1,6 +1,27 @@ -{ mkDerivation, lib, extra-cmake-modules, kdoctools, qtmultimedia, kcompletion, kconfig -, kcrash, kiconthemes, kio, audiofile, libsamplerate, alsa-lib, libpulseaudio, flac, id3lib -, libogg, libmad, libopus, libvorbis, fftw, librsvg }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + qtmultimedia, + kcompletion, + kconfig, + kcrash, + kiconthemes, + kio, + audiofile, + libsamplerate, + alsa-lib, + libpulseaudio, + flac, + id3lib, + libogg, + libmad, + libopus, + libvorbis, + fftw, + librsvg, +}: mkDerivation { pname = "kwave"; diff --git a/pkgs/applications/kde/kweather.nix b/pkgs/applications/kde/kweather.nix index 6e2d3047d02517..7bf505d27ca4e8 100644 --- a/pkgs/applications/kde/kweather.nix +++ b/pkgs/applications/kde/kweather.nix @@ -1,20 +1,21 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules + cmake, + extra-cmake-modules, -, kconfig -, kholidays -, ki18n -, kirigami-addons -, kirigami2 -, knotifications -, kquickcharts -, kweathercore -, plasma-framework -, qtcharts -, qtquickcontrols2 + kconfig, + kholidays, + ki18n, + kirigami-addons, + kirigami2, + knotifications, + kquickcharts, + kweathercore, + plasma-framework, + qtcharts, + qtquickcontrols2, }: mkDerivation rec { @@ -43,7 +44,10 @@ mkDerivation rec { description = "Weather application for Plasma Mobile"; mainProgram = "kweather"; homepage = "https://invent.kde.org/plasma-mobile/kweather"; - license = with licenses; [ gpl2Plus cc-by-40 ]; + license = with licenses; [ + gpl2Plus + cc-by-40 + ]; maintainers = [ ]; }; } diff --git a/pkgs/applications/kde/libgravatar.nix b/pkgs/applications/kde/libgravatar.nix index 0335ded006521f..b444d0488e3343 100644 --- a/pkgs/applications/kde/libgravatar.nix +++ b/pkgs/applications/kde/libgravatar.nix @@ -1,20 +1,41 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - kconfig, kio, ktextwidgets, kwidgetsaddons, pimcommon + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + kconfig, + kio, + ktextwidgets, + kwidgetsaddons, + pimcommon, }: mkDerivation { pname = "libgravatar"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; propagatedBuildInputs = [ - kconfig kio ktextwidgets kwidgetsaddons pimcommon + kconfig + kio + ktextwidgets + kwidgetsaddons + pimcommon + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/libkcddb.nix b/pkgs/applications/kde/libkcddb.nix index d7523de0db8a51..1a634fd44532fd 100644 --- a/pkgs/applications/kde/libkcddb.nix +++ b/pkgs/applications/kde/libkcddb.nix @@ -1,17 +1,40 @@ -{ mkDerivation, lib, extra-cmake-modules, qtbase, kdoctools -, kcodecs, ki18n, kio, kwidgetsaddons, kcmutils -, libmusicbrainz5 }: +{ + mkDerivation, + lib, + extra-cmake-modules, + qtbase, + kdoctools, + kcodecs, + ki18n, + kio, + kwidgetsaddons, + kcmutils, + libmusicbrainz5, +}: mkDerivation { pname = "libkcddb"; meta = with lib; { - license = with licenses; [ gpl2 lgpl21 bsd3 ]; + license = with licenses; [ + gpl2 + lgpl21 + bsd3 + ]; maintainers = with maintainers; [ peterhoeg ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ qtbase kcmutils ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + qtbase + kcmutils + ]; propagatedBuildInputs = [ - kcodecs ki18n kio kwidgetsaddons + kcodecs + ki18n + kio + kwidgetsaddons libmusicbrainz5 ]; } diff --git a/pkgs/applications/kde/libkdcraw.nix b/pkgs/applications/kde/libkdcraw.nix index 1419fb0e980b22..545233d970f9a2 100644 --- a/pkgs/applications/kde/libkdcraw.nix +++ b/pkgs/applications/kde/libkdcraw.nix @@ -1,13 +1,26 @@ -{ mkDerivation, lib, extra-cmake-modules, libraw, qtbase }: +{ + mkDerivation, + lib, + extra-cmake-modules, + libraw, + qtbase, +}: mkDerivation { pname = "libkdcraw"; meta = { - license = with lib.licenses; [ gpl2 lgpl21 bsd3 ]; + license = with lib.licenses; [ + gpl2 + lgpl21 + bsd3 + ]; maintainers = [ lib.maintainers.ttuegel ]; }; nativeBuildInputs = [ extra-cmake-modules ]; buildInputs = [ qtbase ]; propagatedBuildInputs = [ libraw ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/applications/kde/libkdegames.nix b/pkgs/applications/kde/libkdegames.nix index 89d9626363ea43..dc667eb75a97b6 100644 --- a/pkgs/applications/kde/libkdegames.nix +++ b/pkgs/applications/kde/libkdegames.nix @@ -1,21 +1,30 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, kdoctools -, qtdeclarative -, kdeclarative -, kdnssd -, knewstuff -, openal -, libsndfile -, qtquickcontrols +{ + lib, + mkDerivation, + extra-cmake-modules, + kdoctools, + qtdeclarative, + kdeclarative, + kdnssd, + knewstuff, + openal, + libsndfile, + qtquickcontrols, }: mkDerivation { pname = "libkdegames"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - qtdeclarative kdeclarative kdnssd knewstuff openal libsndfile + qtdeclarative + kdeclarative + kdnssd + knewstuff + openal + libsndfile qtquickcontrols ]; meta = { diff --git a/pkgs/applications/kde/libkdepim.nix b/pkgs/applications/kde/libkdepim.nix index 7e66a17e5dc43d..63eb0265850119 100644 --- a/pkgs/applications/kde/libkdepim.nix +++ b/pkgs/applications/kde/libkdepim.nix @@ -1,21 +1,55 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-contacts, akonadi-search, kcmutils, kcodecs, kcompletion, - kconfigwidgets, kcontacts, ki18n, kiconthemes, kio, kitemviews, kjobwidgets, - kldap, kwallet, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-contacts, + akonadi-search, + kcmutils, + kcodecs, + kcompletion, + kconfigwidgets, + kcontacts, + ki18n, + kiconthemes, + kio, + kitemviews, + kjobwidgets, + kldap, + kwallet, }: mkDerivation { pname = "libkdepim"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi akonadi-contacts akonadi-search kcmutils kcodecs kcompletion - kconfigwidgets kcontacts ki18n kiconthemes kio kitemviews kjobwidgets kldap + akonadi + akonadi-contacts + akonadi-search + kcmutils + kcodecs + kcompletion + kconfigwidgets + kcontacts + ki18n + kiconthemes + kio + kitemviews + kjobwidgets + kldap kwallet ]; postInstall = '' diff --git a/pkgs/applications/kde/libkexiv2.nix b/pkgs/applications/kde/libkexiv2.nix index 8d9b3a82032996..3017618fcaa554 100644 --- a/pkgs/applications/kde/libkexiv2.nix +++ b/pkgs/applications/kde/libkexiv2.nix @@ -1,13 +1,26 @@ -{ mkDerivation, lib, exiv2, extra-cmake-modules, qtbase }: +{ + mkDerivation, + lib, + exiv2, + extra-cmake-modules, + qtbase, +}: mkDerivation { pname = "libkexiv2"; meta = { - license = with lib.licenses; [ gpl2 lgpl21 bsd3 ]; + license = with lib.licenses; [ + gpl2 + lgpl21 + bsd3 + ]; maintainers = [ lib.maintainers.ttuegel ]; }; nativeBuildInputs = [ extra-cmake-modules ]; buildInputs = [ qtbase ]; propagatedBuildInputs = [ exiv2 ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/applications/kde/libkgapi.nix b/pkgs/applications/kde/libkgapi.nix index d5e34aa5024faf..3e3678d58812f6 100644 --- a/pkgs/applications/kde/libkgapi.nix +++ b/pkgs/applications/kde/libkgapi.nix @@ -1,16 +1,35 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - qtwebengine, kio, kcalendarcore, kcontacts, - cyrus_sasl + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + qtwebengine, + kio, + kcalendarcore, + kcontacts, + cyrus_sasl, }: mkDerivation { pname = "libkgapi"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ qtwebengine kio kcalendarcore kcontacts cyrus_sasl ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + qtwebengine + kio + kcalendarcore + kcontacts + cyrus_sasl + ]; } diff --git a/pkgs/applications/kde/libkipi.nix b/pkgs/applications/kde/libkipi.nix index e94f0e6c4a824f..79fd1eed63b9d9 100644 --- a/pkgs/applications/kde/libkipi.nix +++ b/pkgs/applications/kde/libkipi.nix @@ -1,12 +1,32 @@ -{ mkDerivation, lib, extra-cmake-modules, kconfig, ki18n, kservice, kxmlgui }: +{ + mkDerivation, + lib, + extra-cmake-modules, + kconfig, + ki18n, + kservice, + kxmlgui, +}: mkDerivation { pname = "libkipi"; meta = { - license = with lib.licenses; [ gpl2 lgpl21 bsd3 ]; + license = with lib.licenses; [ + gpl2 + lgpl21 + bsd3 + ]; maintainers = [ lib.maintainers.ttuegel ]; }; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ kconfig ki18n kservice kxmlgui ]; - outputs = [ "out" "dev" ]; + buildInputs = [ + kconfig + ki18n + kservice + kxmlgui + ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/applications/kde/libkleo.nix b/pkgs/applications/kde/libkleo.nix index 32369495aefa35..ac13ea5ae853b5 100644 --- a/pkgs/applications/kde/libkleo.nix +++ b/pkgs/applications/kde/libkleo.nix @@ -1,23 +1,53 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - boost, qgpgme, kcodecs, kcompletion, kconfig, kcoreaddons, ki18n, kitemmodels, - kpimtextedit, kwidgetsaddons, kwindowsystem + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + boost, + qgpgme, + kcodecs, + kcompletion, + kconfig, + kcoreaddons, + ki18n, + kitemmodels, + kpimtextedit, + kwidgetsaddons, + kwindowsystem, }: mkDerivation { pname = "libkleo"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - boost kcodecs kcompletion kconfig kcoreaddons ki18n kitemmodels - kpimtextedit kwidgetsaddons kwindowsystem + boost + kcodecs + kcompletion + kconfig + kcoreaddons + ki18n + kitemmodels + kpimtextedit + kwidgetsaddons + kwindowsystem ]; propagatedBuildInputs = [ qgpgme ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/libkmahjongg.nix b/pkgs/applications/kde/libkmahjongg.nix index 1b202b614880ef..97ff358b9b5496 100644 --- a/pkgs/applications/kde/libkmahjongg.nix +++ b/pkgs/applications/kde/libkmahjongg.nix @@ -1,8 +1,14 @@ { - mkDerivation, lib, - extra-cmake-modules, kdoctools, - kcompletion, kconfig, kconfigwidgets, kcoreaddons, ki18n, - kwidgetsaddons + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + kcompletion, + kconfig, + kconfigwidgets, + kcoreaddons, + ki18n, + kwidgetsaddons, }: mkDerivation { @@ -11,8 +17,20 @@ mkDerivation { license = with lib.licenses; [ gpl2 ]; maintainers = [ ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ kcompletion kconfig kconfigwidgets kcoreaddons ki18n - kwidgetsaddons ]; - outputs = [ "out" "dev" ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + kcompletion + kconfig + kconfigwidgets + kcoreaddons + ki18n + kwidgetsaddons + ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/applications/kde/libkomparediff2.nix b/pkgs/applications/kde/libkomparediff2.nix index 93ac12d97d6203..8f18cd0b3b2e85 100644 --- a/pkgs/applications/kde/libkomparediff2.nix +++ b/pkgs/applications/kde/libkomparediff2.nix @@ -1,7 +1,19 @@ -{ mkDerivation, extra-cmake-modules, ki18n, kxmlgui, kcodecs, kio }: +{ + mkDerivation, + extra-cmake-modules, + ki18n, + kxmlgui, + kcodecs, + kio, +}: mkDerivation { pname = "libkomparediff2"; nativeBuildInputs = [ extra-cmake-modules ]; - propagatedBuildInputs = [ kcodecs ki18n kxmlgui kio ]; + propagatedBuildInputs = [ + kcodecs + ki18n + kxmlgui + kio + ]; } diff --git a/pkgs/applications/kde/libksane.nix b/pkgs/applications/kde/libksane.nix index 8dee898412b889..241a9e284b86e3 100644 --- a/pkgs/applications/kde/libksane.nix +++ b/pkgs/applications/kde/libksane.nix @@ -1,8 +1,14 @@ { - mkDerivation, lib, - extra-cmake-modules, qtbase, - ki18n, ktextwidgets, kwallet, kwidgetsaddons, - ksanecore, sane-backends + mkDerivation, + lib, + extra-cmake-modules, + qtbase, + ki18n, + ktextwidgets, + kwallet, + kwidgetsaddons, + ksanecore, + sane-backends, }: mkDerivation { @@ -12,6 +18,15 @@ mkDerivation { maintainers = with maintainers; [ polendri ]; }; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ qtbase ki18n ktextwidgets kwallet kwidgetsaddons ]; - propagatedBuildInputs = [ ksanecore sane-backends ]; + buildInputs = [ + qtbase + ki18n + ktextwidgets + kwallet + kwidgetsaddons + ]; + propagatedBuildInputs = [ + ksanecore + sane-backends + ]; } diff --git a/pkgs/applications/kde/libksieve.nix b/pkgs/applications/kde/libksieve.nix index adc232f091d68c..f6e3d3252b3bfd 100644 --- a/pkgs/applications/kde/libksieve.nix +++ b/pkgs/applications/kde/libksieve.nix @@ -1,22 +1,56 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, karchive, kcompletion, kiconthemes, kidentitymanagement, kio, - kmailtransport, knewstuff, kwindowsystem, kxmlgui, libkdepim, pimcommon, - qtwebengine, syntax-highlighting, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + karchive, + kcompletion, + kiconthemes, + kidentitymanagement, + kio, + kmailtransport, + knewstuff, + kwindowsystem, + kxmlgui, + libkdepim, + pimcommon, + qtwebengine, + syntax-highlighting, }: mkDerivation { pname = "libksieve"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - outputs = [ "out" "dev" ]; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + outputs = [ + "out" + "dev" + ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi karchive kcompletion kiconthemes kidentitymanagement kio - kmailtransport knewstuff kwindowsystem kxmlgui libkdepim pimcommon + akonadi + karchive + kcompletion + kiconthemes + kidentitymanagement + kio + kmailtransport + knewstuff + kwindowsystem + kxmlgui + libkdepim + pimcommon qtwebengine ]; propagatedBuildInputs = [ syntax-highlighting ]; diff --git a/pkgs/applications/kde/libktorrent.nix b/pkgs/applications/kde/libktorrent.nix index 63732bb8dcdf3b..c7432bb0f1d3fc 100644 --- a/pkgs/applications/kde/libktorrent.nix +++ b/pkgs/applications/kde/libktorrent.nix @@ -1,22 +1,43 @@ { mkDerivation, extra-cmake-modules, - karchive, kcrash, ki18n, kio, libgcrypt, qca-qt5, solid, - boost, gmp + karchive, + kcrash, + ki18n, + kio, + libgcrypt, + qca-qt5, + solid, + boost, + gmp, }: mkDerivation { pname = "libktorrent"; meta = { description = "BitTorrent library used by KTorrent"; - homepage = "https://apps.kde.org/ktorrent/"; + homepage = "https://apps.kde.org/ktorrent/"; maintainers = [ ]; }; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ karchive kcrash ki18n kio libgcrypt qca-qt5 solid ]; - propagatedBuildInputs = [ boost gmp ]; - outputs = [ "out" "dev" ]; + buildInputs = [ + karchive + kcrash + ki18n + kio + libgcrypt + qca-qt5 + solid + ]; + propagatedBuildInputs = [ + boost + gmp + ]; + outputs = [ + "out" + "dev" + ]; dontWrapQtApps = true; } diff --git a/pkgs/applications/kde/mailcommon.nix b/pkgs/applications/kde/mailcommon.nix index d9885058ef8950..b703f056488bc3 100644 --- a/pkgs/applications/kde/mailcommon.nix +++ b/pkgs/applications/kde/mailcommon.nix @@ -1,24 +1,67 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-mime, karchive, kcodecs, kcompletion, kconfigwidgets, - kdbusaddons, kdesignerplugin, kiconthemes, kio, kitemmodels, kldap, - kmailtransport, kwindowsystem, mailimporter, messagelib, phonon, libkdepim + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-mime, + karchive, + kcodecs, + kcompletion, + kconfigwidgets, + kdbusaddons, + kdesignerplugin, + kiconthemes, + kio, + kitemmodels, + kldap, + kmailtransport, + kwindowsystem, + mailimporter, + messagelib, + phonon, + libkdepim, }: mkDerivation { pname = "mailcommon"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi akonadi-mime karchive kcodecs kcompletion kconfigwidgets kdbusaddons - kdesignerplugin kiconthemes kio kitemmodels kldap kmailtransport - kwindowsystem mailimporter messagelib phonon libkdepim + akonadi + akonadi-mime + karchive + kcodecs + kcompletion + kconfigwidgets + kdbusaddons + kdesignerplugin + kiconthemes + kio + kitemmodels + kldap + kmailtransport + kwindowsystem + mailimporter + messagelib + phonon + libkdepim + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/mailimporter.nix b/pkgs/applications/kde/mailimporter.nix index 08503ba9e83123..270c515f5fe8cd 100644 --- a/pkgs/applications/kde/mailimporter.nix +++ b/pkgs/applications/kde/mailimporter.nix @@ -1,20 +1,48 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-mime, karchive, kcompletion, kconfig, kcoreaddons, ki18n, - kmime, kxmlgui, libkdepim, pimcommon + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-mime, + karchive, + kcompletion, + kconfig, + kcoreaddons, + ki18n, + kmime, + kxmlgui, + libkdepim, + pimcommon, }: mkDerivation { pname = "mailimporter"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi akonadi-mime karchive kcompletion kconfig kcoreaddons ki18n kmime - kxmlgui libkdepim pimcommon + akonadi + akonadi-mime + karchive + kcompletion + kconfig + kcoreaddons + ki18n + kmime + kxmlgui + libkdepim + pimcommon ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing diff --git a/pkgs/applications/kde/marble.nix b/pkgs/applications/kde/marble.nix index 78fc52996dc519..00a3d834ee3ca8 100644 --- a/pkgs/applications/kde/marble.nix +++ b/pkgs/applications/kde/marble.nix @@ -1,8 +1,19 @@ -{ mkDerivation, lib -, extra-cmake-modules, kdoctools -, qtscript, qtsvg, qtquickcontrols, qtwebengine -, krunner, shared-mime-info, kparts, knewstuff -, gpsd, perl, protobuf_21 +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + qtscript, + qtsvg, + qtquickcontrols, + qtwebengine, + krunner, + shared-mime-info, + kparts, + knewstuff, + gpsd, + perl, + protobuf_21, }: mkDerivation { @@ -10,13 +21,31 @@ mkDerivation { meta = { homepage = "https://apps.kde.org/marble/"; description = "Virtual globe"; - license = with lib.licenses; [ lgpl21 gpl3 ]; + license = with lib.licenses; [ + lgpl21 + gpl3 + ]; }; - outputs = [ "out" "dev" ]; - nativeBuildInputs = [ extra-cmake-modules kdoctools perl ]; + outputs = [ + "out" + "dev" + ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + perl + ]; propagatedBuildInputs = [ - protobuf_21 qtscript qtsvg qtquickcontrols qtwebengine shared-mime-info krunner kparts - knewstuff gpsd + protobuf_21 + qtscript + qtsvg + qtquickcontrols + qtwebengine + shared-mime-info + krunner + kparts + knewstuff + gpsd ]; preConfigure = '' cmakeFlags+=" -DINCLUDE_INSTALL_DIR=''${!outputDev}/include" diff --git a/pkgs/applications/kde/mbox-importer.nix b/pkgs/applications/kde/mbox-importer.nix index d51b7e99ce60b7..fe1864b11e8445 100644 --- a/pkgs/applications/kde/mbox-importer.nix +++ b/pkgs/applications/kde/mbox-importer.nix @@ -1,17 +1,41 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-search, kconfig, kservice, kio, mailcommon, mailimporter, messagelib + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-search, + kconfig, + kservice, + kio, + mailcommon, + mailimporter, + messagelib, }: mkDerivation { pname = "mbox-importer"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi akonadi-search kconfig kservice kio mailcommon mailimporter messagelib + akonadi + akonadi-search + kconfig + kservice + kio + mailcommon + mailimporter + messagelib ]; } diff --git a/pkgs/applications/kde/merkuro.nix b/pkgs/applications/kde/merkuro.nix index 7c2064e2969b23..89220319be138a 100644 --- a/pkgs/applications/kde/merkuro.nix +++ b/pkgs/applications/kde/merkuro.nix @@ -1,44 +1,45 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, makeWrapper +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + makeWrapper, -, qtbase -, qtquickcontrols2 -, qtsvg -, qtlocation -, qtdeclarative -, qqc2-desktop-style + qtbase, + qtquickcontrols2, + qtsvg, + qtlocation, + qtdeclarative, + qqc2-desktop-style, -, kirigami2 -, kirigami-addons -, kdbusaddons -, ki18n -, kcalendarcore -, kconfigwidgets -, kwindowsystem -, kcoreaddons -, kcontacts -, kitemmodels -, kxmlgui -, knotifications -, kiconthemes -, kservice -, kmime -, kpackage -, eventviews -, calendarsupport + kirigami2, + kirigami-addons, + kdbusaddons, + ki18n, + kcalendarcore, + kconfigwidgets, + kwindowsystem, + kcoreaddons, + kcontacts, + kitemmodels, + kxmlgui, + knotifications, + kiconthemes, + kservice, + kmime, + kpackage, + eventviews, + calendarsupport, -, akonadi -, akonadi-search -, akonadi-contacts -, akonadi-calendar-tools -, kdepim-runtime -, gpgme -, pimcommon -, mailcommon -, messagelib + akonadi, + akonadi-search, + akonadi-contacts, + akonadi-calendar-tools, + kdepim-runtime, + gpgme, + pimcommon, + mailcommon, + messagelib, }: mkDerivation { @@ -88,8 +89,20 @@ mkDerivation { messagelib ]; - propagatedUserEnvPkgs = [ akonadi kdepim-runtime akonadi-search ]; - qtWrapperArgs = [''--prefix PATH : "${lib.makeBinPath [ akonadi kdepim-runtime akonadi-search ]}"'']; + propagatedUserEnvPkgs = [ + akonadi + kdepim-runtime + akonadi-search + ]; + qtWrapperArgs = [ + ''--prefix PATH : "${ + lib.makeBinPath [ + akonadi + kdepim-runtime + akonadi-search + ] + }"'' + ]; meta = with lib; { description = "Calendar application using Akonadi to sync with external services (Nextcloud, GMail, ...)"; diff --git a/pkgs/applications/kde/messagelib.nix b/pkgs/applications/kde/messagelib.nix index abd9382a1f0ff9..8c1e91e9f6f2cf 100644 --- a/pkgs/applications/kde/messagelib.nix +++ b/pkgs/applications/kde/messagelib.nix @@ -1,31 +1,90 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-mime, akonadi-notes, akonadi-search, gpgme, grantlee, - grantleetheme, karchive, kcodecs, kconfig, kconfigwidgets, kcontacts, - kiconthemes, kidentitymanagement, kio, kjobwidgets, kldap, - kmailtransport, kmbox, kmime, kwindowsystem, libgravatar, libkdepim, libkleo, - pimcommon, qca-qt5, qtwebengine, syntax-highlighting + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-mime, + akonadi-notes, + akonadi-search, + gpgme, + grantlee, + grantleetheme, + karchive, + kcodecs, + kconfig, + kconfigwidgets, + kcontacts, + kiconthemes, + kidentitymanagement, + kio, + kjobwidgets, + kldap, + kmailtransport, + kmbox, + kmime, + kwindowsystem, + libgravatar, + libkdepim, + libkleo, + pimcommon, + qca-qt5, + qtwebengine, + syntax-highlighting, }: mkDerivation { pname = "messagelib"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi-notes akonadi-search gpgme grantlee grantleetheme karchive kcodecs - kconfig kconfigwidgets kiconthemes kio kjobwidgets kldap - kmailtransport kmbox kmime kwindowsystem libgravatar libkdepim qca-qt5 + akonadi-notes + akonadi-search + gpgme + grantlee + grantleetheme + karchive + kcodecs + kconfig + kconfigwidgets + kiconthemes + kio + kjobwidgets + kldap + kmailtransport + kmbox + kmime + kwindowsystem + libgravatar + libkdepim + qca-qt5 syntax-highlighting ]; propagatedBuildInputs = [ - akonadi akonadi-mime kcontacts kidentitymanagement kmime libkleo pimcommon + akonadi + akonadi-mime + kcontacts + kidentitymanagement + kmime + libkleo + pimcommon qtwebengine ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postInstall = '' # added as an include directory by cmake files and fails to compile if it's missing mkdir -p "$dev/include/KF5" diff --git a/pkgs/applications/kde/minuet.nix b/pkgs/applications/kde/minuet.nix index 8e5285ac57d8e4..c3000bdec25dd0 100644 --- a/pkgs/applications/kde/minuet.nix +++ b/pkgs/applications/kde/minuet.nix @@ -1,8 +1,18 @@ -{ mkDerivation -, lib, extra-cmake-modules, gettext, python3 -, drumstick, fluidsynth -, kcoreaddons, kcrash, kdoctools -, qtquickcontrols2, qtsvg, qttools, qtdeclarative +{ + mkDerivation, + lib, + extra-cmake-modules, + gettext, + python3, + drumstick, + fluidsynth, + kcoreaddons, + kcrash, + kdoctools, + qtquickcontrols2, + qtsvg, + qttools, + qtdeclarative, }: mkDerivation { @@ -11,16 +21,32 @@ mkDerivation { homepage = "https://apps.kde.org/minuet/"; description = "Music Education Software"; mainProgram = "minuet"; - license = with licenses; [ lgpl21 gpl3 ]; - maintainers = with maintainers; [ peterhoeg HaoZeke ]; + license = with licenses; [ + lgpl21 + gpl3 + ]; + maintainers = with maintainers; [ + peterhoeg + HaoZeke + ]; }; - nativeBuildInputs = [ extra-cmake-modules gettext kdoctools python3 qtdeclarative ]; + nativeBuildInputs = [ + extra-cmake-modules + gettext + kdoctools + python3 + qtdeclarative + ]; propagatedBuildInputs = [ - drumstick fluidsynth - kcoreaddons kcrash - qtquickcontrols2 qtsvg qttools + drumstick + fluidsynth + kcoreaddons + kcrash + qtquickcontrols2 + qtsvg + qttools ]; enableParallelBuilding = true; diff --git a/pkgs/applications/kde/neochat.nix b/pkgs/applications/kde/neochat.nix index f8dc1f6c35b7e1..8f2601930d7f4a 100644 --- a/pkgs/applications/kde/neochat.nix +++ b/pkgs/applications/kde/neochat.nix @@ -1,33 +1,34 @@ -{ mkDerivation -, lib +{ + mkDerivation, + lib, -, cmake -, extra-cmake-modules -, pkg-config -, wrapQtAppsHook + cmake, + extra-cmake-modules, + pkg-config, + wrapQtAppsHook, -, cmark -, kconfig -, kdbusaddons -, ki18n -, kio -, kirigami-addons -, kirigami2 -, kitemmodels -, knotifications -, kquickcharts -, kquickimageedit -, libpulseaudio -, libquotient -, libsecret -, olm -, qcoro -, qqc2-desktop-style -, qtgraphicaleffects -, qtlocation -, qtmultimedia -, qtquickcontrols2 -, sonnet + cmark, + kconfig, + kdbusaddons, + ki18n, + kio, + kirigami-addons, + kirigami2, + kitemmodels, + knotifications, + kquickcharts, + kquickimageedit, + libpulseaudio, + libquotient, + libsecret, + olm, + qcoro, + qqc2-desktop-style, + qtgraphicaleffects, + qtlocation, + qtmultimedia, + qtquickcontrols2, + sonnet, }: mkDerivation { diff --git a/pkgs/applications/kde/okular.nix b/pkgs/applications/kde/okular.nix index bd2794af242128..d604b800d7ba10 100644 --- a/pkgs/applications/kde/okular.nix +++ b/pkgs/applications/kde/okular.nix @@ -1,24 +1,89 @@ -{ mkDerivation, lib -, extra-cmake-modules, kdoctools -, breeze-icons, chmlib, discount, djvulibre, ebook_tools, kactivities -, karchive, kbookmarks, kcompletion, kconfig, kconfigwidgets, kcoreaddons -, kdbusaddons, kdegraphics-mobipocket, kiconthemes, kjs, khtml, kio, kparts -, kpty, kpurpose, kwallet, kwindowsystem, libkexiv2, libspectre, libzip, phonon, poppler -, qca-qt5, qtdeclarative, qtsvg, threadweaver, kcrash -, withSpeech ? true, qtspeech, qtx11extras +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + breeze-icons, + chmlib, + discount, + djvulibre, + ebook_tools, + kactivities, + karchive, + kbookmarks, + kcompletion, + kconfig, + kconfigwidgets, + kcoreaddons, + kdbusaddons, + kdegraphics-mobipocket, + kiconthemes, + kjs, + khtml, + kio, + kparts, + kpty, + kpurpose, + kwallet, + kwindowsystem, + libkexiv2, + libspectre, + libzip, + phonon, + poppler, + qca-qt5, + qtdeclarative, + qtsvg, + threadweaver, + kcrash, + withSpeech ? true, + qtspeech, + qtx11extras, }: mkDerivation { pname = "okular"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - breeze-icons discount djvulibre ebook_tools kactivities karchive kbookmarks - kcompletion kconfig kconfigwidgets kcoreaddons kdbusaddons - kdegraphics-mobipocket kiconthemes kjs khtml kio kparts kpty kpurpose kwallet - kwindowsystem libkexiv2 libspectre libzip phonon poppler qca-qt5 - qtdeclarative qtsvg threadweaver kcrash chmlib qtx11extras + breeze-icons + discount + djvulibre + ebook_tools + kactivities + karchive + kbookmarks + kcompletion + kconfig + kconfigwidgets + kcoreaddons + kdbusaddons + kdegraphics-mobipocket + kiconthemes + kjs + khtml + kio + kparts + kpty + kpurpose + kwallet + kwindowsystem + libkexiv2 + libspectre + libzip + phonon + poppler + qca-qt5 + qtdeclarative + qtsvg + threadweaver + kcrash + chmlib + qtx11extras ] ++ lib.optional withSpeech qtspeech; # InitialPreference values are too high and end up making okular @@ -35,7 +100,12 @@ mkDerivation { homepage = "http://www.kde.org"; description = "KDE document viewer"; mainProgram = "okular"; - license = with licenses; [ gpl2Plus lgpl21Plus fdl12Plus bsd3 ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + bsd3 + ]; maintainers = with maintainers; [ ttuegel ]; platforms = lib.platforms.linux; }; diff --git a/pkgs/applications/kde/palapeli.nix b/pkgs/applications/kde/palapeli.nix index 1db865942fd254..43c5134343a80c 100644 --- a/pkgs/applications/kde/palapeli.nix +++ b/pkgs/applications/kde/palapeli.nix @@ -1,17 +1,26 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, shared-mime-info -, kdoctools -, kio -, ktextwidgets -, libkdegames +{ + lib, + mkDerivation, + extra-cmake-modules, + shared-mime-info, + kdoctools, + kio, + ktextwidgets, + libkdegames, }: mkDerivation { pname = "palapeli"; - nativeBuildInputs = [ extra-cmake-modules kdoctools shared-mime-info ]; - buildInputs = [ libkdegames kio ktextwidgets ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + shared-mime-info + ]; + buildInputs = [ + libkdegames + kio + ktextwidgets + ]; meta = { homepage = "https://apps.kde.org/palapeli/"; description = "Single-player jigsaw puzzle game"; diff --git a/pkgs/applications/kde/partitionmanager/default.nix b/pkgs/applications/kde/partitionmanager/default.nix index b5a5053419ecd2..35ede9df1eebf3 100644 --- a/pkgs/applications/kde/partitionmanager/default.nix +++ b/pkgs/applications/kde/partitionmanager/default.nix @@ -1,33 +1,34 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, wrapGAppsHook3 -, kconfig -, kcrash -, kinit -, kpmcore -, polkit-qt -, cryptsetup -, lvm2 -, mdadm -, smartmontools -, systemdMinimal -, util-linux -, btrfs-progs -, dosfstools -, e2fsprogs -, exfat -, f2fs-tools -, fatresize -, jfsutils -, nilfs-utils -, ntfs3g -, reiser4progs -, reiserfsprogs -, udftools -, xfsprogs -, zfs +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + wrapGAppsHook3, + kconfig, + kcrash, + kinit, + kpmcore, + polkit-qt, + cryptsetup, + lvm2, + mdadm, + smartmontools, + systemdMinimal, + util-linux, + btrfs-progs, + dosfstools, + e2fsprogs, + exfat, + f2fs-tools, + fatresize, + jfsutils, + nilfs-utils, + ntfs3g, + reiser4progs, + reiserfsprogs, + udftools, + xfsprogs, + zfs, }: let @@ -66,9 +67,19 @@ in mkDerivation { pname = "partitionmanager"; - nativeBuildInputs = [ extra-cmake-modules kdoctools wrapGAppsHook3 ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wrapGAppsHook3 + ]; - propagatedBuildInputs = [ kconfig kcrash kinit kpmcore polkit-qt ]; + propagatedBuildInputs = [ + kconfig + kcrash + kinit + kpmcore + polkit-qt + ]; dontWrapGApps = true; preFixup = '' @@ -91,9 +102,18 @@ mkDerivation { To install on NixOS, use the option `programs.partition-manager.enable = true`. ''; - license = with licenses; [ cc-by-40 cc0 gpl3Plus lgpl3Plus mit ]; + license = with licenses; [ + cc-by-40 + cc0 + gpl3Plus + lgpl3Plus + mit + ]; homepage = "https://www.kde.org/applications/system/kdepartitionmanager/"; - maintainers = with maintainers; [ peterhoeg oxalica ]; + maintainers = with maintainers; [ + peterhoeg + oxalica + ]; mainProgram = "partitionmanager"; }; } diff --git a/pkgs/applications/kde/picmi.nix b/pkgs/applications/kde/picmi.nix index 52a1245610b8ba..7261f1f3925671 100644 --- a/pkgs/applications/kde/picmi.nix +++ b/pkgs/applications/kde/picmi.nix @@ -1,6 +1,10 @@ -{ mkDerivation, lib -, libkdegames, extra-cmake-modules -, kdeclarative, knewstuff +{ + mkDerivation, + lib, + libkdegames, + extra-cmake-modules, + kdeclarative, + knewstuff, }: mkDerivation { diff --git a/pkgs/applications/kde/pim-data-exporter.nix b/pkgs/applications/kde/pim-data-exporter.nix index 1bc54cac3e1438..f40365eb36da18 100644 --- a/pkgs/applications/kde/pim-data-exporter.nix +++ b/pkgs/applications/kde/pim-data-exporter.nix @@ -1,12 +1,33 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-notes, kcalendarcore, kcmutils, kcrash, kdbusaddons, - kidentitymanagement, kldap, kmailtransport, knewstuff, knotifications, - knotifyconfig, kparts, kross, ktexteditor, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-notes, + kcalendarcore, + kcmutils, + kcrash, + kdbusaddons, + kidentitymanagement, + kldap, + kmailtransport, + knewstuff, + knotifications, + knotifyconfig, + kparts, + kross, + ktexteditor, kuserfeedback, - kwallet, libkdepim, libkleo, - pimcommon, qttools, karchive, mailcommon, messagelib + kwallet, + libkdepim, + libkleo, + pimcommon, + qttools, + karchive, + mailcommon, + messagelib, }: mkDerivation { @@ -14,16 +35,41 @@ mkDerivation { meta = { homepage = "https://apps.kde.org/pimdataexporter/"; description = "Saves and restores all data from PIM apps"; - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi akonadi-notes kcalendarcore kcmutils kcrash kdbusaddons - kidentitymanagement kldap kmailtransport knewstuff knotifications - knotifyconfig kparts kross ktexteditor + akonadi + akonadi-notes + kcalendarcore + kcmutils + kcrash + kdbusaddons + kidentitymanagement + kldap + kmailtransport + knewstuff + knotifications + knotifyconfig + kparts + kross + ktexteditor kuserfeedback - kwallet libkdepim libkleo pimcommon - qttools karchive mailcommon messagelib + kwallet + libkdepim + libkleo + pimcommon + qttools + karchive + mailcommon + messagelib ]; } diff --git a/pkgs/applications/kde/pim-sieve-editor.nix b/pkgs/applications/kde/pim-sieve-editor.nix index 28c15282c5feba..def5908a205dd7 100644 --- a/pkgs/applications/kde/pim-sieve-editor.nix +++ b/pkgs/applications/kde/pim-sieve-editor.nix @@ -1,22 +1,49 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - kdbusaddons, kcrash, kbookmarks, kiconthemes, kio, kpimtextedit, + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + kdbusaddons, + kcrash, + kbookmarks, + kiconthemes, + kio, + kpimtextedit, kmailtransport, kuserfeedback, - libksieve, pimcommon, qtkeychain, libsecret + libksieve, + pimcommon, + qtkeychain, + libsecret, }: mkDerivation { pname = "pim-sieve-editor"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - kdbusaddons kcrash kbookmarks kiconthemes kio kpimtextedit kmailtransport + kdbusaddons + kcrash + kbookmarks + kiconthemes + kio + kpimtextedit + kmailtransport kuserfeedback - libksieve pimcommon qtkeychain libsecret + libksieve + pimcommon + qtkeychain + libsecret ]; } diff --git a/pkgs/applications/kde/pimcommon.nix b/pkgs/applications/kde/pimcommon.nix index d82bc3f506b50a..1fa03b02b5c6c6 100644 --- a/pkgs/applications/kde/pimcommon.nix +++ b/pkgs/applications/kde/pimcommon.nix @@ -1,26 +1,85 @@ { - mkDerivation, lib, kdepimTeam, - extra-cmake-modules, kdoctools, - akonadi, akonadi-contacts, akonadi-mime, akonadi-search, grantlee, karchive, kcmutils, kcodecs, - kcompletion, kconfig, kconfigwidgets, kcontacts, kdbusaddons, - kiconthemes, kimap, kio, kitemmodels, kjobwidgets, kldap, knewstuff, kpimtextedit, - kpurpose, kwallet, kwindowsystem, libkdepim, qtwebengine, ktextaddons + mkDerivation, + lib, + kdepimTeam, + extra-cmake-modules, + kdoctools, + akonadi, + akonadi-contacts, + akonadi-mime, + akonadi-search, + grantlee, + karchive, + kcmutils, + kcodecs, + kcompletion, + kconfig, + kconfigwidgets, + kcontacts, + kdbusaddons, + kiconthemes, + kimap, + kio, + kitemmodels, + kjobwidgets, + kldap, + knewstuff, + kpimtextedit, + kpurpose, + kwallet, + kwindowsystem, + libkdepim, + qtwebengine, + ktextaddons, }: mkDerivation { pname = "pimcommon"; meta = { - license = with lib.licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; maintainers = kdepimTeam; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - akonadi-mime grantlee karchive kcmutils kcodecs kcompletion kconfigwidgets - kdbusaddons kiconthemes kio kitemmodels kjobwidgets knewstuff kldap - kpurpose kwallet kwindowsystem libkdepim qtwebengine ktextaddons + akonadi-mime + grantlee + karchive + kcmutils + kcodecs + kcompletion + kconfigwidgets + kdbusaddons + kiconthemes + kio + kitemmodels + kjobwidgets + knewstuff + kldap + kpurpose + kwallet + kwindowsystem + libkdepim + qtwebengine + ktextaddons ]; propagatedBuildInputs = [ - akonadi akonadi-contacts akonadi-search kconfig kcontacts kimap kpimtextedit + akonadi + akonadi-contacts + akonadi-search + kconfig + kcontacts + kimap + kpimtextedit + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; } diff --git a/pkgs/applications/kde/plasmatube/default.nix b/pkgs/applications/kde/plasmatube/default.nix index fbb577e6c80b78..c36554b5705d07 100644 --- a/pkgs/applications/kde/plasmatube/default.nix +++ b/pkgs/applications/kde/plasmatube/default.nix @@ -1,16 +1,17 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, wrapGAppsHook3 -, gst_all_1 -, kcoreaddons -, kdeclarative -, ki18n -, kirigami2 -, mpv -, qtmultimedia -, qtquickcontrols2 -, yt-dlp +{ + lib, + mkDerivation, + extra-cmake-modules, + wrapGAppsHook3, + gst_all_1, + kcoreaddons, + kdeclarative, + ki18n, + kirigami2, + mpv, + qtmultimedia, + qtquickcontrols2, + yt-dlp, }: mkDerivation { @@ -21,20 +22,22 @@ mkDerivation { wrapGAppsHook3 ]; - buildInputs = [ - kcoreaddons - kdeclarative - ki18n - kirigami2 - mpv - qtmultimedia - qtquickcontrols2 - ] ++ (with gst_all_1; [ - gst-plugins-bad - gst-plugins-base - gst-plugins-good - gstreamer - ]); + buildInputs = + [ + kcoreaddons + kdeclarative + ki18n + kirigami2 + mpv + qtmultimedia + qtquickcontrols2 + ] + ++ (with gst_all_1; [ + gst-plugins-bad + gst-plugins-base + gst-plugins-good + gstreamer + ]); qtWrapperArgs = [ "--prefix" diff --git a/pkgs/applications/kde/print-manager.nix b/pkgs/applications/kde/print-manager.nix index 5fa200978353c0..5b213cc914eee3 100644 --- a/pkgs/applications/kde/print-manager.nix +++ b/pkgs/applications/kde/print-manager.nix @@ -1,10 +1,21 @@ { - mkDerivation, lib, + mkDerivation, + lib, extra-cmake-modules, - cups, ki18n, - kconfig, kconfigwidgets, kdbusaddons, kiconthemes, kcmutils, kio, - knotifications, kwidgetsaddons, kwindowsystem, kitemviews, plasma-framework, - qtdeclarative + cups, + ki18n, + kconfig, + kconfigwidgets, + kdbusaddons, + kiconthemes, + kcmutils, + kio, + knotifications, + kwidgetsaddons, + kwindowsystem, + kitemviews, + plasma-framework, + qtdeclarative, }: mkDerivation { @@ -14,12 +25,28 @@ mkDerivation { maintainers = [ lib.maintainers.ttuegel ]; }; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ cups ki18n ]; + buildInputs = [ + cups + ki18n + ]; propagatedBuildInputs = [ - kconfig kconfigwidgets kdbusaddons kiconthemes kcmutils knotifications - kwidgetsaddons kitemviews kio kwindowsystem plasma-framework qtdeclarative + kconfig + kconfigwidgets + kdbusaddons + kiconthemes + kcmutils + knotifications + kwidgetsaddons + kitemviews + kio + kwindowsystem + plasma-framework + qtdeclarative + ]; + outputs = [ + "out" + "dev" ]; - outputs = [ "out" "dev" ]; # Fix build with cups deprecations etc. # See: https://github.com/NixOS/nixpkgs/issues/73334 env.NIX_CFLAGS_COMPILE = "-Wno-error=deprecated-declarations -Wno-error=format-security"; diff --git a/pkgs/applications/kde/qmlkonsole.nix b/pkgs/applications/kde/qmlkonsole.nix index 1071fce7e752f4..5cf001eb1ed196 100644 --- a/pkgs/applications/kde/qmlkonsole.nix +++ b/pkgs/applications/kde/qmlkonsole.nix @@ -1,17 +1,18 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules + cmake, + extra-cmake-modules, -, kconfig -, ki18n -, kirigami-addons -, kirigami2 -, kcoreaddons -, qtquickcontrols2 -, kwindowsystem -, qmltermwidget + kconfig, + ki18n, + kirigami-addons, + kirigami2, + kcoreaddons, + qtquickcontrols2, + kwindowsystem, + qmltermwidget, }: mkDerivation { @@ -37,7 +38,11 @@ mkDerivation { description = "Terminal app for Plasma Mobile"; mainProgram = "qmlkonsole"; homepage = "https://invent.kde.org/plasma-mobile/qmlkonsole"; - license = with licenses; [ gpl2Plus gpl3Plus cc0 ]; + license = with licenses; [ + gpl2Plus + gpl3Plus + cc0 + ]; maintainers = with maintainers; [ balsoft ]; }; } diff --git a/pkgs/applications/kde/rocs.nix b/pkgs/applications/kde/rocs.nix index 263cce39f176f8..6742ad2182c791 100644 --- a/pkgs/applications/kde/rocs.nix +++ b/pkgs/applications/kde/rocs.nix @@ -1,8 +1,20 @@ { - mkDerivation, lib, - extra-cmake-modules, boost, - qtbase, qtscript, qtquickcontrols, qtxmlpatterns, grantlee, - kdoctools, karchive, kxmlgui, kcrash, kdeclarative, ktexteditor, kguiaddons + mkDerivation, + lib, + extra-cmake-modules, + boost, + qtbase, + qtscript, + qtquickcontrols, + qtxmlpatterns, + grantlee, + kdoctools, + karchive, + kxmlgui, + kcrash, + kdeclarative, + ktexteditor, + kguiaddons, }: mkDerivation { @@ -12,15 +24,31 @@ mkDerivation { homepage = "https://edu.kde.org/rocs/"; description = "Graph theory IDE"; mainProgram = "rocs"; - license = with licenses; [ gpl2Plus lgpl21Plus fdl12Plus ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + fdl12Plus + ]; platforms = lib.platforms.linux; maintainers = with maintainers; [ knairda ]; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ boost - qtbase qtscript qtquickcontrols qtxmlpatterns grantlee - kxmlgui kcrash kdeclarative karchive ktexteditor kguiaddons + qtbase + qtscript + qtquickcontrols + qtxmlpatterns + grantlee + kxmlgui + kcrash + kdeclarative + karchive + ktexteditor + kguiaddons ]; } diff --git a/pkgs/applications/kde/skanlite.nix b/pkgs/applications/kde/skanlite.nix index 0c518cc8ca22b2..6dcba10e0897f2 100644 --- a/pkgs/applications/kde/skanlite.nix +++ b/pkgs/applications/kde/skanlite.nix @@ -1,8 +1,11 @@ { - mkDerivation, lib, + mkDerivation, + lib, wrapGAppsHook3, - extra-cmake-modules, kdoctools, - kio, libksane + extra-cmake-modules, + kdoctools, + kio, + libksane, }: mkDerivation { @@ -10,11 +13,18 @@ mkDerivation { meta = with lib; { description = "KDE simple image scanning application"; mainProgram = "skanlite"; - homepage = "https://apps.kde.org/skanlite"; - license = licenses.gpl2Plus; + homepage = "https://apps.kde.org/skanlite"; + license = licenses.gpl2Plus; maintainers = with maintainers; [ polendri ]; }; - nativeBuildInputs = [ wrapGAppsHook3 extra-cmake-modules kdoctools ]; - buildInputs = [ kio libksane ]; + nativeBuildInputs = [ + wrapGAppsHook3 + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + kio + libksane + ]; } diff --git a/pkgs/applications/kde/skanpage.nix b/pkgs/applications/kde/skanpage.nix index 89094a10a87b32..8f4a636f5cb127 100644 --- a/pkgs/applications/kde/skanpage.nix +++ b/pkgs/applications/kde/skanpage.nix @@ -1,12 +1,13 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, kirigami2 -, ktextwidgets -, libksane -, qtquickcontrols2 -, kpurpose -, kquickimageedit +{ + lib, + mkDerivation, + extra-cmake-modules, + kirigami2, + ktextwidgets, + libksane, + qtquickcontrols2, + kpurpose, + kquickimageedit, }: mkDerivation { diff --git a/pkgs/applications/kde/spectacle.nix b/pkgs/applications/kde/spectacle.nix index 528c15eb8b734b..657af4cbc26ba8 100644 --- a/pkgs/applications/kde/spectacle.nix +++ b/pkgs/applications/kde/spectacle.nix @@ -1,22 +1,72 @@ -{ mkDerivation, lib -, extra-cmake-modules, kdoctools -, ki18n, xcb-util-cursor -, kconfig, kcoreaddons, kdbusaddons, kdeclarative, kio, kipi-plugins -, knotifications, kscreen, kwidgetsaddons, kwindowsystem, kxmlgui, libkipi -, qtx11extras, knewstuff, kwayland, qttools, kcolorpicker, kimageannotator -, qcoro, qtquickcontrols2, wayland, plasma-wayland-protocols, kpurpose, kpipewire -, wrapGAppsHook3, wayland-scanner +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + ki18n, + xcb-util-cursor, + kconfig, + kcoreaddons, + kdbusaddons, + kdeclarative, + kio, + kipi-plugins, + knotifications, + kscreen, + kwidgetsaddons, + kwindowsystem, + kxmlgui, + libkipi, + qtx11extras, + knewstuff, + kwayland, + qttools, + kcolorpicker, + kimageannotator, + qcoro, + qtquickcontrols2, + wayland, + plasma-wayland-protocols, + kpurpose, + kpipewire, + wrapGAppsHook3, + wayland-scanner, }: mkDerivation { pname = "spectacle"; - nativeBuildInputs = [ extra-cmake-modules kdoctools wrapGAppsHook3 wayland-scanner ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wrapGAppsHook3 + wayland-scanner + ]; buildInputs = [ - kconfig kcoreaddons kdbusaddons kdeclarative ki18n kio knotifications - kscreen kwidgetsaddons kwindowsystem kxmlgui libkipi qtx11extras xcb-util-cursor - knewstuff kwayland kcolorpicker kimageannotator qcoro qtquickcontrols2 - wayland plasma-wayland-protocols kpurpose kpipewire + kconfig + kcoreaddons + kdbusaddons + kdeclarative + ki18n + kio + knotifications + kscreen + kwidgetsaddons + kwindowsystem + kxmlgui + libkipi + qtx11extras + xcb-util-cursor + knewstuff + kwayland + kcolorpicker + kimageannotator + qcoro + qtquickcontrols2 + wayland + plasma-wayland-protocols + kpurpose + kpipewire ]; postPatch = '' substituteInPlace desktop/org.kde.spectacle.desktop.cmake \ @@ -29,7 +79,10 @@ mkDerivation { qtWrapperArgs+=("''${gappsWrapperArgs[@]}") ''; - propagatedUserEnvPkgs = [ kipi-plugins libkipi ]; + propagatedUserEnvPkgs = [ + kipi-plugins + libkipi + ]; meta = with lib; { homepage = "https://apps.kde.org/spectacle/"; description = "Screenshot capture utility"; diff --git a/pkgs/applications/kde/telly-skout.nix b/pkgs/applications/kde/telly-skout.nix index 00df33583f5c1c..12496afe9dbf99 100644 --- a/pkgs/applications/kde/telly-skout.nix +++ b/pkgs/applications/kde/telly-skout.nix @@ -1,11 +1,12 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, qtquickcontrols2 -, kcoreaddons -, kconfig -, ki18n -, kirigami2 +{ + mkDerivation, + lib, + extra-cmake-modules, + qtquickcontrols2, + kcoreaddons, + kconfig, + ki18n, + kirigami2, }: mkDerivation { @@ -13,7 +14,13 @@ mkDerivation { nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ qtquickcontrols2 kcoreaddons kconfig ki18n kirigami2 ]; + buildInputs = [ + qtquickcontrols2 + kcoreaddons + kconfig + ki18n + kirigami2 + ]; meta = { description = "Convergent Kirigami TV guide"; diff --git a/pkgs/applications/kde/tokodon.nix b/pkgs/applications/kde/tokodon.nix index fdf2d63d2bf5f0..5771ce5c60e514 100644 --- a/pkgs/applications/kde/tokodon.nix +++ b/pkgs/applications/kde/tokodon.nix @@ -1,26 +1,27 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules -, pkg-config + cmake, + extra-cmake-modules, + pkg-config, -, kconfig -, kdbusaddons -, ki18n -, kirigami2 -, kirigami-addons -, knotifications -, qqc2-desktop-style -, qtbase -, qtkeychain -, qtmultimedia -, qtquickcontrols2 -, qttools -, qtwebsockets -, kitemmodels -, pimcommon -, mpv + kconfig, + kdbusaddons, + ki18n, + kirigami2, + kirigami-addons, + knotifications, + qqc2-desktop-style, + qtbase, + qtkeychain, + qtmultimedia, + qtquickcontrols2, + qttools, + qtwebsockets, + kitemmodels, + pimcommon, + mpv, }: mkDerivation { diff --git a/pkgs/applications/kde/umbrello.nix b/pkgs/applications/kde/umbrello.nix index 7a3356fd2103a0..e6ee77742877a1 100644 --- a/pkgs/applications/kde/umbrello.nix +++ b/pkgs/applications/kde/umbrello.nix @@ -1,12 +1,13 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, cmake -, karchive -, ki18n -, kiconthemes -, kdelibs4support -, ktexteditor +{ + mkDerivation, + lib, + extra-cmake-modules, + cmake, + karchive, + ki18n, + kiconthemes, + kdelibs4support, + ktexteditor, }: mkDerivation { @@ -17,9 +18,14 @@ mkDerivation { license = [ lib.licenses.gpl2 ]; }; nativeBuildInputs = [ - cmake extra-cmake-modules + cmake + extra-cmake-modules ]; propagatedBuildInputs = [ - karchive ki18n kiconthemes kdelibs4support ktexteditor + karchive + ki18n + kiconthemes + kdelibs4support + ktexteditor ]; } diff --git a/pkgs/applications/kde/yakuake.nix b/pkgs/applications/kde/yakuake.nix index cf88cd280c2ebb..b64a7aac696424 100644 --- a/pkgs/applications/kde/yakuake.nix +++ b/pkgs/applications/kde/yakuake.nix @@ -1,29 +1,65 @@ { - mkDerivation, lib, kdoctools, extra-cmake-modules, - karchive, kcrash, kdbusaddons, ki18n, kiconthemes, knewstuff, knotifications, - knotifyconfig, konsole, kparts, kwayland, kwindowsystem, qtx11extras + mkDerivation, + lib, + kdoctools, + extra-cmake-modules, + karchive, + kcrash, + kdbusaddons, + ki18n, + kiconthemes, + knewstuff, + knotifications, + knotifyconfig, + konsole, + kparts, + kwayland, + kwindowsystem, + qtx11extras, }: mkDerivation { pname = "yakuake"; buildInputs = [ - karchive kcrash kdbusaddons ki18n kiconthemes knewstuff knotifications - knotifyconfig kparts kwayland kwindowsystem qtx11extras + karchive + kcrash + kdbusaddons + ki18n + kiconthemes + knewstuff + knotifications + knotifyconfig + kparts + kwayland + kwindowsystem + qtx11extras ]; propagatedBuildInputs = [ - karchive kcrash kdbusaddons ki18n kiconthemes knewstuff knotifications - knotifyconfig kparts kwindowsystem + karchive + kcrash + kdbusaddons + ki18n + kiconthemes + knewstuff + knotifications + knotifyconfig + kparts + kwindowsystem ]; propagatedUserEnvPkgs = [ konsole ]; nativeBuildInputs = [ - extra-cmake-modules kdoctools + extra-cmake-modules + kdoctools ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = { homepage = "https://yakuake.kde.org"; diff --git a/pkgs/applications/kde/zanshin.nix b/pkgs/applications/kde/zanshin.nix index 4b98ea8e0cf7c4..137f7fc02c557c 100644 --- a/pkgs/applications/kde/zanshin.nix +++ b/pkgs/applications/kde/zanshin.nix @@ -1,7 +1,11 @@ { - mkDerivation, lib, + mkDerivation, + lib, extra-cmake-modules, - akonadi-calendar, boost, kontactinterface, krunner + akonadi-calendar, + boost, + kontactinterface, + krunner, }: mkDerivation { @@ -14,5 +18,10 @@ mkDerivation { }; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ akonadi-calendar boost kontactinterface krunner ]; + buildInputs = [ + akonadi-calendar + boost + kontactinterface + krunner + ]; } diff --git a/pkgs/applications/logging/sosreport/default.nix b/pkgs/applications/logging/sosreport/default.nix index c92bab6d523749..faa59c21fa8755 100644 --- a/pkgs/applications/logging/sosreport/default.nix +++ b/pkgs/applications/logging/sosreport/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, gettext -, magic -, pexpect -, pyyaml -, setuptools +{ + lib, + buildPythonPackage, + fetchFromGitHub, + gettext, + magic, + pexpect, + pyyaml, + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/applications/maui/booth.nix b/pkgs/applications/maui/booth.nix index bca0c23a854364..1d9a8e9568df7c 100644 --- a/pkgs/applications/maui/booth.nix +++ b/pkgs/applications/maui/booth.nix @@ -1,17 +1,18 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, kcoreaddons -, ki18n -, kirigami2 -, mauikit -, mauikit-filebrowsing -, prison -, qtgraphicaleffects -, qtmultimedia -, qtquickcontrols2 -, gst_all_1 +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + kcoreaddons, + ki18n, + kirigami2, + mauikit, + mauikit-filebrowsing, + prison, + qtgraphicaleffects, + qtmultimedia, + qtquickcontrols2, + gst_all_1, }: mkDerivation { @@ -22,22 +23,24 @@ mkDerivation { extra-cmake-modules ]; - buildInputs = [ - kcoreaddons - ki18n - kirigami2 - mauikit - mauikit-filebrowsing - prison - qtgraphicaleffects - qtmultimedia - qtquickcontrols2 - ] ++ (with gst_all_1; [ - gst-plugins-bad - gst-plugins-base - gst-plugins-good - gstreamer - ]); + buildInputs = + [ + kcoreaddons + ki18n + kirigami2 + mauikit + mauikit-filebrowsing + prison + qtgraphicaleffects + qtmultimedia + qtquickcontrols2 + ] + ++ (with gst_all_1; [ + gst-plugins-bad + gst-plugins-base + gst-plugins-good + gstreamer + ]); preFixup = '' qtWrapperArgs+=( diff --git a/pkgs/applications/maui/buho.nix b/pkgs/applications/maui/buho.nix index b9f9fb446fb5d1..d207955ad4b918 100644 --- a/pkgs/applications/maui/buho.nix +++ b/pkgs/applications/maui/buho.nix @@ -1,19 +1,20 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, applet-window-buttons -, karchive -, kcoreaddons -, ki18n -, kio -, kirigami2 -, mauikit -, mauikit-filebrowsing -, mauikit-accounts -, mauikit-texteditor -, qtmultimedia -, qtquickcontrols2 +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + applet-window-buttons, + karchive, + kcoreaddons, + ki18n, + kio, + kirigami2, + mauikit, + mauikit-filebrowsing, + mauikit-accounts, + mauikit-texteditor, + qtmultimedia, + qtquickcontrols2, }: mkDerivation { diff --git a/pkgs/applications/maui/clip.nix b/pkgs/applications/maui/clip.nix index 88d874c04e120b..901a798252b7fe 100644 --- a/pkgs/applications/maui/clip.nix +++ b/pkgs/applications/maui/clip.nix @@ -1,19 +1,20 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, applet-window-buttons -, karchive -, kcoreaddons -, ki18n -, kio -, kirigami2 -, mauikit -, mauikit-filebrowsing -, qtmultimedia -, qtquickcontrols2 -, taglib -, ffmpeg +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + applet-window-buttons, + karchive, + kcoreaddons, + ki18n, + kio, + kirigami2, + mauikit, + mauikit-filebrowsing, + qtmultimedia, + qtquickcontrols2, + taglib, + ffmpeg, }: mkDerivation { diff --git a/pkgs/applications/maui/communicator.nix b/pkgs/applications/maui/communicator.nix index 4ee5f59dc3cd9b..c239a1c84296d0 100644 --- a/pkgs/applications/maui/communicator.nix +++ b/pkgs/applications/maui/communicator.nix @@ -1,21 +1,22 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, applet-window-buttons -, karchive -, kcoreaddons -, ki18n -, kio -, kirigami2 -, mauikit -, mauikit-accounts -, mauikit-filebrowsing -, mauikit-texteditor -, qtmultimedia -, qtquickcontrols2 -, kpeople -, kcontacts +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + applet-window-buttons, + karchive, + kcoreaddons, + ki18n, + kio, + kirigami2, + mauikit, + mauikit-accounts, + mauikit-filebrowsing, + mauikit-texteditor, + qtmultimedia, + qtquickcontrols2, + kpeople, + kcontacts, }: mkDerivation { diff --git a/pkgs/applications/maui/index.nix b/pkgs/applications/maui/index.nix index 4e12123074fdd0..c16603490d18da 100644 --- a/pkgs/applications/maui/index.nix +++ b/pkgs/applications/maui/index.nix @@ -1,16 +1,17 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, karchive -, kcoreaddons -, ki18n -, kio -, kirigami2 -, mauikit -, mauikit-filebrowsing -, qtmultimedia -, qtquickcontrols2 +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + karchive, + kcoreaddons, + ki18n, + kio, + kirigami2, + mauikit, + mauikit-filebrowsing, + qtmultimedia, + qtquickcontrols2, }: mkDerivation { diff --git a/pkgs/applications/maui/mauikit-accounts.nix b/pkgs/applications/maui/mauikit-accounts.nix index 24308b76248311..e04ab551f0870b 100644 --- a/pkgs/applications/maui/mauikit-accounts.nix +++ b/pkgs/applications/maui/mauikit-accounts.nix @@ -1,10 +1,11 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, kconfig -, kio -, mauikit +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + kconfig, + kio, + mauikit, }: mkDerivation { diff --git a/pkgs/applications/maui/mauikit-calendar/default.nix b/pkgs/applications/maui/mauikit-calendar/default.nix index 161e2046b72836..42aaff0f386c70 100644 --- a/pkgs/applications/maui/mauikit-calendar/default.nix +++ b/pkgs/applications/maui/mauikit-calendar/default.nix @@ -1,14 +1,15 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, mauikit -, qtquickcontrols2 -, akonadi -, akonadi-contacts -, akonadi-calendar -, calendarsupport -, eventviews +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + mauikit, + qtquickcontrols2, + akonadi, + akonadi-contacts, + akonadi-calendar, + calendarsupport, + eventviews, }: mkDerivation { diff --git a/pkgs/applications/maui/mauikit-documents.nix b/pkgs/applications/maui/mauikit-documents.nix index 19d8e9faa2072e..4ec7e6892bfb07 100644 --- a/pkgs/applications/maui/mauikit-documents.nix +++ b/pkgs/applications/maui/mauikit-documents.nix @@ -1,17 +1,18 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, karchive -, kconfig -, kcoreaddons -, kfilemetadata -, kguiaddons -, ki18n -, kiconthemes -, kio -, mauikit -, poppler +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + karchive, + kconfig, + kcoreaddons, + kfilemetadata, + kguiaddons, + ki18n, + kiconthemes, + kio, + mauikit, + poppler, }: mkDerivation { @@ -38,7 +39,10 @@ mkDerivation { meta = { homepage = "https://invent.kde.org/maui/mauikit-documents"; description = "MauiKit QtQuick plugins for text editing"; - license = with lib.licenses; [ bsd2 lgpl21Plus ]; + license = with lib.licenses; [ + bsd2 + lgpl21Plus + ]; maintainers = with lib.maintainers; [ dotlambda ]; }; } diff --git a/pkgs/applications/maui/mauikit-filebrowsing.nix b/pkgs/applications/maui/mauikit-filebrowsing.nix index d8be881f764968..13a98b37e03b93 100644 --- a/pkgs/applications/maui/mauikit-filebrowsing.nix +++ b/pkgs/applications/maui/mauikit-filebrowsing.nix @@ -1,10 +1,11 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, kconfig -, kio -, mauikit +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + kconfig, + kio, + mauikit, }: mkDerivation { diff --git a/pkgs/applications/maui/mauikit-imagetools.nix b/pkgs/applications/maui/mauikit-imagetools.nix index 141d1953528a07..8b96c55002fc02 100644 --- a/pkgs/applications/maui/mauikit-imagetools.nix +++ b/pkgs/applications/maui/mauikit-imagetools.nix @@ -1,16 +1,17 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, kconfig -, kio -, leptonica -, mauikit -, opencv -, qtlocation -, exiv2 -, kquickimageedit -, tesseract +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + kconfig, + kio, + leptonica, + mauikit, + opencv, + qtlocation, + exiv2, + kquickimageedit, + tesseract, }: mkDerivation { diff --git a/pkgs/applications/maui/mauikit-terminal.nix b/pkgs/applications/maui/mauikit-terminal.nix index 2f292ba2d0a1af..905132a9d7a58a 100644 --- a/pkgs/applications/maui/mauikit-terminal.nix +++ b/pkgs/applications/maui/mauikit-terminal.nix @@ -1,11 +1,12 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, kconfig -, kcoreaddons -, ki18n -, mauikit +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + kconfig, + kcoreaddons, + ki18n, + mauikit, }: mkDerivation { diff --git a/pkgs/applications/maui/mauikit-texteditor.nix b/pkgs/applications/maui/mauikit-texteditor.nix index 75826c2079ac0d..c38ba401d060f0 100644 --- a/pkgs/applications/maui/mauikit-texteditor.nix +++ b/pkgs/applications/maui/mauikit-texteditor.nix @@ -1,11 +1,12 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, kconfig -, kio -, mauikit -, syntax-highlighting +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + kconfig, + kio, + mauikit, + syntax-highlighting, }: mkDerivation { diff --git a/pkgs/applications/maui/mauikit.nix b/pkgs/applications/maui/mauikit.nix index 71d148685e7eec..60b795604c8309 100644 --- a/pkgs/applications/maui/mauikit.nix +++ b/pkgs/applications/maui/mauikit.nix @@ -1,14 +1,15 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, kconfig -, kcoreaddons -, ki18n -, knotifications -, mauiman -, qtquickcontrols2 -, qtx11extras +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + kconfig, + kcoreaddons, + ki18n, + knotifications, + mauiman, + qtquickcontrols2, + qtx11extras, }: mkDerivation { diff --git a/pkgs/applications/maui/mauiman.nix b/pkgs/applications/maui/mauiman.nix index 7566c7d6ed7d01..c90a02055450e2 100644 --- a/pkgs/applications/maui/mauiman.nix +++ b/pkgs/applications/maui/mauiman.nix @@ -1,8 +1,9 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, qtsystems +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + qtsystems, }: mkDerivation { diff --git a/pkgs/applications/maui/nota.nix b/pkgs/applications/maui/nota.nix index 5e579c8cbdcb4b..0c72106795fea0 100644 --- a/pkgs/applications/maui/nota.nix +++ b/pkgs/applications/maui/nota.nix @@ -1,18 +1,19 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, applet-window-buttons -, karchive -, kcoreaddons -, ki18n -, kio -, kirigami2 -, mauikit -, mauikit-filebrowsing -, mauikit-texteditor -, qtmultimedia -, qtquickcontrols2 +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + applet-window-buttons, + karchive, + kcoreaddons, + ki18n, + kio, + kirigami2, + mauikit, + mauikit-filebrowsing, + mauikit-texteditor, + qtmultimedia, + qtquickcontrols2, }: mkDerivation { diff --git a/pkgs/applications/maui/shelf.nix b/pkgs/applications/maui/shelf.nix index 1c1b53a8e1e931..e82c8afb6fe018 100644 --- a/pkgs/applications/maui/shelf.nix +++ b/pkgs/applications/maui/shelf.nix @@ -1,20 +1,21 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, applet-window-buttons -, karchive -, kcoreaddons -, ki18n -, kio -, kirigami2 -, mauikit -, mauikit-documents -, mauikit-filebrowsing -, mauikit-texteditor -, qtmultimedia -, qtquickcontrols2 -, poppler +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + applet-window-buttons, + karchive, + kcoreaddons, + ki18n, + kio, + kirigami2, + mauikit, + mauikit-documents, + mauikit-filebrowsing, + mauikit-texteditor, + qtmultimedia, + qtquickcontrols2, + poppler, }: mkDerivation { diff --git a/pkgs/applications/maui/station.nix b/pkgs/applications/maui/station.nix index 2ca994397ccd22..6389576a125cfc 100644 --- a/pkgs/applications/maui/station.nix +++ b/pkgs/applications/maui/station.nix @@ -1,16 +1,17 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, kconfig -, kcoreaddons -, ki18n -, kirigami2 -, mauikit -, mauikit-filebrowsing -, mauikit-terminal -, qmltermwidget -, qtmultimedia +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + kconfig, + kcoreaddons, + ki18n, + kirigami2, + mauikit, + mauikit-filebrowsing, + mauikit-terminal, + qmltermwidget, + qtmultimedia, }: mkDerivation { diff --git a/pkgs/applications/maui/vvave.nix b/pkgs/applications/maui/vvave.nix index e10d33df0eb5f7..d30a747a87e5b6 100644 --- a/pkgs/applications/maui/vvave.nix +++ b/pkgs/applications/maui/vvave.nix @@ -1,19 +1,20 @@ -{ lib -, mkDerivation -, cmake -, extra-cmake-modules -, applet-window-buttons -, karchive -, kcoreaddons -, ki18n -, kio -, kirigami2 -, mauikit -, mauikit-accounts -, mauikit-filebrowsing -, qtmultimedia -, qtquickcontrols2 -, taglib +{ + lib, + mkDerivation, + cmake, + extra-cmake-modules, + applet-window-buttons, + karchive, + kcoreaddons, + ki18n, + kio, + kirigami2, + mauikit, + mauikit-accounts, + mauikit-filebrowsing, + qtmultimedia, + qtquickcontrols2, + taglib, }: mkDerivation { @@ -47,4 +48,3 @@ mkDerivation { maintainers = with maintainers; [ onny ]; }; } - diff --git a/pkgs/applications/misc/ArchiSteamFarm/web-ui/default.nix b/pkgs/applications/misc/ArchiSteamFarm/web-ui/default.nix index c9b3ee26d3bae0..28e4be38989c4a 100644 --- a/pkgs/applications/misc/ArchiSteamFarm/web-ui/default.nix +++ b/pkgs/applications/misc/ArchiSteamFarm/web-ui/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildNpmPackage, ArchiSteamFarm }: +{ + lib, + fetchFromGitHub, + buildNpmPackage, + ArchiSteamFarm, +}: buildNpmPackage rec { pname = "asf-ui"; diff --git a/pkgs/applications/misc/adobe-reader/default.nix b/pkgs/applications/misc/adobe-reader/default.nix index 1a164f578a0166..3510d9393e43db 100644 --- a/pkgs/applications/misc/adobe-reader/default.nix +++ b/pkgs/applications/misc/adobe-reader/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, libX11 -, cups -, zlib -, libxml2 -, pango -, atk -, gtk2 -, glib -, gdk-pixbuf -, gdk-pixbuf-xlib +{ + lib, + stdenv, + fetchurl, + libX11, + cups, + zlib, + libxml2, + pango, + atk, + gtk2, + glib, + gdk-pixbuf, + gdk-pixbuf-xlib, }: stdenv.mkDerivation rec { @@ -27,7 +28,19 @@ stdenv.mkDerivation rec { # !!! Adobe Reader contains copies of OpenSSL, libcurl, and libicu. # We should probably remove those and use the regular Nixpkgs versions. - libPath = lib.makeLibraryPath [ stdenv.cc.cc libX11 zlib libxml2 cups pango atk gtk2 glib gdk-pixbuf gdk-pixbuf-xlib ]; + libPath = lib.makeLibraryPath [ + stdenv.cc.cc + libX11 + zlib + libxml2 + cups + pango + atk + gtk2 + glib + gdk-pixbuf + gdk-pixbuf-xlib + ]; passthru.mozillaPlugin = "/libexec/adobe-reader/Browser/intellinux"; diff --git a/pkgs/applications/misc/aitrack/default.nix b/pkgs/applications/misc/aitrack/default.nix index b9bb6962348778..7fa8e8e9d61071 100644 --- a/pkgs/applications/misc/aitrack/default.nix +++ b/pkgs/applications/misc/aitrack/default.nix @@ -1,14 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, qmake -, wrapQtAppsHook -, opencv -, spdlog -, onnxruntime -, qtx11extras -}: stdenv.mkDerivation { +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + qmake, + wrapQtAppsHook, + opencv, + spdlog, + onnxruntime, + qtx11extras, +}: +stdenv.mkDerivation { pname = "aitrack"; version = "0.6.5"; diff --git a/pkgs/applications/misc/anup/default.nix b/pkgs/applications/misc/anup/default.nix index a72ba17eb6b4ab..ef343f34614641 100644 --- a/pkgs/applications/misc/anup/default.nix +++ b/pkgs/applications/misc/anup/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, Security, sqlite, xdg-utils}: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + Security, + sqlite, + xdg-utils, +}: rustPlatform.buildRustPackage rec { pname = "anup"; @@ -11,12 +19,14 @@ rustPlatform.buildRustPackage rec { sha256 = "sha256-4pXF4p4K8+YihVB9NdgT6bOidmQEgWXUbcbvgXJ0IDA="; }; - buildInputs = [ - sqlite - xdg-utils - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - ]; + buildInputs = + [ + sqlite + xdg-utils + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + ]; cargoLock = { lockFile = ./Cargo.lock; diff --git a/pkgs/applications/misc/ape/apeclex.nix b/pkgs/applications/misc/ape/apeclex.nix index 7f0523270f283a..1f59e8dcf0afef 100644 --- a/pkgs/applications/misc/ape/apeclex.nix +++ b/pkgs/applications/misc/ape/apeclex.nix @@ -1,8 +1,15 @@ -{ lib, attemptoClex, callPackage }: +{ + lib, + attemptoClex, + callPackage, +}: callPackage ./. { pname = "ape-clex"; lexiconPath = "${attemptoClex}/clex_lexicon.pl"; description = "Parser for Attempto Controlled English (ACE) with a large lexicon (~100,000 entries)"; - license = with lib.licenses; [ lgpl3 gpl3 ]; + license = with lib.licenses; [ + lgpl3 + gpl3 + ]; } diff --git a/pkgs/applications/misc/ape/clex.nix b/pkgs/applications/misc/ape/clex.nix index a98695dab68258..5403e4d5e95bdf 100644 --- a/pkgs/applications/misc/ape/clex.nix +++ b/pkgs/applications/misc/ape/clex.nix @@ -1,14 +1,18 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "attempto-clex"; version = "5133afe"; src = fetchFromGitHub { - owner = "Attempto"; - repo = "Clex"; - rev = version; - sha256 = "0p9s64g1jic213bwm6347jqckszgnni9szrrz31qjgaf32kf7nkp"; + owner = "Attempto"; + repo = "Clex"; + rev = version; + sha256 = "0p9s64g1jic213bwm6347jqckszgnni9szrrz31qjgaf32kf7nkp"; }; installPhase = '' diff --git a/pkgs/applications/misc/ape/default.nix b/pkgs/applications/misc/ape/default.nix index 598ad82c1e35f3..b3c281c6b820ad 100644 --- a/pkgs/applications/misc/ape/default.nix +++ b/pkgs/applications/misc/ape/default.nix @@ -1,9 +1,13 @@ -{ lib, stdenv, swi-prolog, makeWrapper, +{ + lib, + stdenv, + swi-prolog, + makeWrapper, fetchFromGitHub, lexiconPath ? "prolog/lexicon/clex_lexicon.pl", pname ? "ape", description ? "Parser for Attempto Controlled English (ACE)", - license ? lib.licenses.lgpl3 + license ? lib.licenses.lgpl3, }: stdenv.mkDerivation rec { @@ -14,10 +18,10 @@ stdenv.mkDerivation rec { buildInputs = [ swi-prolog ]; src = fetchFromGitHub { - owner = "Attempto"; - repo = "APE"; - rev = "113b81621262d7a395779465cb09397183e6f74c"; - sha256 = "0xyvna2fbr18hi5yvm0zwh77q02dfna1g4g53z9mn2rmlfn2mhjh"; + owner = "Attempto"; + repo = "APE"; + rev = "113b81621262d7a395779465cb09397183e6f74c"; + sha256 = "0xyvna2fbr18hi5yvm0zwh77q02dfna1g4g53z9mn2rmlfn2mhjh"; }; patchPhase = '' diff --git a/pkgs/applications/misc/audio/sox/default.nix b/pkgs/applications/misc/audio/sox/default.nix index 621fca6feb2d7a..26a93f8b00357c 100644 --- a/pkgs/applications/misc/audio/sox/default.nix +++ b/pkgs/applications/misc/audio/sox/default.nix @@ -1,38 +1,40 @@ -{ config -, lib -, stdenv -, fetchgit -, autoreconfHook -, autoconf-archive -, pkg-config -, CoreAudio -, enableAlsa ? true -, alsa-lib -, enableLibao ? true -, libao -, enableLame ? config.sox.enableLame or false -, lame -, enableLibmad ? true -, libmad -, enableLibogg ? true -, libogg -, libvorbis -, enableOpusfile ? true -, opusfile -, enableFLAC ? true -, flac -, enablePNG ? true -, libpng -, enableLibsndfile ? true -, libsndfile -, enableWavpack ? true -, wavpack +{ + config, + lib, + stdenv, + fetchgit, + autoreconfHook, + autoconf-archive, + pkg-config, + CoreAudio, + enableAlsa ? true, + alsa-lib, + enableLibao ? true, + libao, + enableLame ? config.sox.enableLame or false, + lame, + enableLibmad ? true, + libmad, + enableLibogg ? true, + libogg, + libvorbis, + enableOpusfile ? true, + opusfile, + enableFLAC ? true, + flac, + enablePNG ? true, + libpng, + enableLibsndfile ? true, + libsndfile, + enableWavpack ? true, + wavpack, # amrnb and amrwb are unfree, disabled by default -, enableAMR ? false -, amrnb -, amrwb -, enableLibpulseaudio ? stdenv.hostPlatform.isLinux && lib.meta.availableOn stdenv.hostPlatform libpulseaudio -, libpulseaudio + enableAMR ? false, + amrnb, + amrwb, + enableLibpulseaudio ? + stdenv.hostPlatform.isLinux && lib.meta.availableOn stdenv.hostPlatform libpulseaudio, + libpulseaudio, }: stdenv.mkDerivation rec { @@ -69,13 +71,19 @@ stdenv.mkDerivation rec { ++ lib.optional enableLibao libao ++ lib.optional enableLame lame ++ lib.optional enableLibmad libmad - ++ lib.optionals enableLibogg [ libogg libvorbis ] + ++ lib.optionals enableLibogg [ + libogg + libvorbis + ] ++ lib.optional enableOpusfile opusfile ++ lib.optional enableFLAC flac ++ lib.optional enablePNG libpng ++ lib.optional enableLibsndfile libsndfile ++ lib.optional enableWavpack wavpack - ++ lib.optionals enableAMR [ amrnb amrwb ] + ++ lib.optionals enableAMR [ + amrnb + amrwb + ] ++ lib.optional enableLibpulseaudio libpulseaudio ++ lib.optional stdenv.hostPlatform.isDarwin CoreAudio; diff --git a/pkgs/applications/misc/ausweisapp/default.nix b/pkgs/applications/misc/ausweisapp/default.nix index 7b4f813e8084ab..c20def2cadc981 100644 --- a/pkgs/applications/misc/ausweisapp/default.nix +++ b/pkgs/applications/misc/ausweisapp/default.nix @@ -12,7 +12,7 @@ qttools, qtwayland, qtwebsockets, - gitUpdater + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { pname = "ausweisapp"; @@ -60,7 +60,7 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.ausweisapp.bund.de/open-source-software"; license = lib.licenses.eupl12; mainProgram = "AusweisApp"; - maintainers = with lib.maintainers; [b4dm4n]; + maintainers = with lib.maintainers; [ b4dm4n ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/applications/misc/avell-unofficial-control-center/default.nix b/pkgs/applications/misc/avell-unofficial-control-center/default.nix index c37d2c42b64f20..94b091a2b2ca53 100644 --- a/pkgs/applications/misc/avell-unofficial-control-center/default.nix +++ b/pkgs/applications/misc/avell-unofficial-control-center/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "avell-unofficial-control-center"; @@ -15,7 +19,10 @@ python3Packages.buildPythonApplication rec { # No tests included doCheck = false; - propagatedBuildInputs = with python3Packages; [ pyusb elevate ]; + propagatedBuildInputs = with python3Packages; [ + pyusb + elevate + ]; meta = with lib; { homepage = "https://github.com/rodgomesc/avell-unofficial-control-center"; diff --git a/pkgs/applications/misc/barrier/default.nix b/pkgs/applications/misc/barrier/default.nix index 6c483c02f3c78c..d43ed3921c0d1b 100644 --- a/pkgs/applications/misc/barrier/default.nix +++ b/pkgs/applications/misc/barrier/default.nix @@ -1,7 +1,16 @@ -{ lib, fetchFromGitHub, cmake, curl, xorg, avahi, qtbase, mkDerivation, - openssl, wrapGAppsHook3, +{ + lib, + fetchFromGitHub, + cmake, + curl, + xorg, + avahi, + qtbase, + mkDerivation, + openssl, + wrapGAppsHook3, avahiWithLibdnssdCompat ? avahi.override { withLibdnssdCompat = true; }, - fetchpatch + fetchpatch, }: mkDerivation rec { @@ -31,8 +40,18 @@ mkDerivation rec { "-include cstdint" ]; - buildInputs = [ curl xorg.libX11 xorg.libXext xorg.libXtst avahiWithLibdnssdCompat qtbase ]; - nativeBuildInputs = [ cmake wrapGAppsHook3 ]; + buildInputs = [ + curl + xorg.libX11 + xorg.libXext + xorg.libXtst + avahiWithLibdnssdCompat + qtbase + ]; + nativeBuildInputs = [ + cmake + wrapGAppsHook3 + ]; postFixup = '' substituteInPlace "$out/share/applications/barrier.desktop" --replace "Exec=barrier" "Exec=$out/bin/barrier" diff --git a/pkgs/applications/misc/bfcal/default.nix b/pkgs/applications/misc/bfcal/default.nix index 0f801aa2e13046..c309652c6d48fa 100644 --- a/pkgs/applications/misc/bfcal/default.nix +++ b/pkgs/applications/misc/bfcal/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromSourcehut -, meson -, ninja -, pkg-config -, wrapQtAppsHook -, qtbase +{ + stdenv, + lib, + fetchFromSourcehut, + meson, + ninja, + pkg-config, + wrapQtAppsHook, + qtbase, }: stdenv.mkDerivation rec { @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - meson ninja pkg-config wrapQtAppsHook + meson + ninja + pkg-config + wrapQtAppsHook ]; buildInputs = [ diff --git a/pkgs/applications/misc/binocle/default.nix b/pkgs/applications/misc/binocle/default.nix index da77d6c693df7b..d80678848b9424 100644 --- a/pkgs/applications/misc/binocle/default.nix +++ b/pkgs/applications/misc/binocle/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, makeWrapper -, AppKit -, CoreFoundation -, CoreGraphics -, CoreVideo -, Foundation -, Metal -, QuartzCore -, xorg -, vulkan-loader +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + makeWrapper, + AppKit, + CoreFoundation, + CoreGraphics, + CoreVideo, + Foundation, + Metal, + QuartzCore, + xorg, + vulkan-loader, }: rustPlatform.buildRustPackage rec { @@ -32,19 +33,39 @@ rustPlatform.buildRustPackage rec { ]; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit CoreFoundation CoreGraphics CoreVideo Foundation Metal QuartzCore + AppKit + CoreFoundation + CoreGraphics + CoreVideo + Foundation + Metal + QuartzCore ]; postInstall = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' wrapProgram $out/bin/binocle \ - --suffix LD_LIBRARY_PATH : ${lib.makeLibraryPath (with xorg; [ libX11 libXcursor libXi libXrandr ] ++ [ vulkan-loader ])} + --suffix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath ( + with xorg; + [ + libX11 + libXcursor + libXi + libXrandr + ] + ++ [ vulkan-loader ] + ) + } ''; meta = with lib; { description = "Graphical tool to visualize binary data"; mainProgram = "binocle"; homepage = "https://github.com/sharkdp/binocle"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/applications/misc/birdtray/default.nix b/pkgs/applications/misc/birdtray/default.nix index cbdb165a648472..42824954950985 100644 --- a/pkgs/applications/misc/birdtray/default.nix +++ b/pkgs/applications/misc/birdtray/default.nix @@ -1,12 +1,13 @@ -{ mkDerivation - , lib - , fetchFromGitHub +{ + mkDerivation, + lib, + fetchFromGitHub, - , cmake - , pkg-config - , qtbase - , qttools - , qtx11extras + cmake, + pkg-config, + qtbase, + qttools, + qtx11extras, }: mkDerivation rec { @@ -20,9 +21,14 @@ mkDerivation rec { sha256 = "sha256-rj8tPzZzgW0hXmq8c1LiunIX1tO/tGAaqDGJgCQda5M="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ - qtbase qttools qtx11extras + qtbase + qttools + qtx11extras ]; # Wayland support is broken. diff --git a/pkgs/applications/misc/blender/wrapper.nix b/pkgs/applications/misc/blender/wrapper.nix index 8b5e8916a13884..5606de21aeb825 100644 --- a/pkgs/applications/misc/blender/wrapper.nix +++ b/pkgs/applications/misc/blender/wrapper.nix @@ -1,7 +1,8 @@ -{ stdenv -, blender -, makeWrapper -, extraModules ? [] +{ + stdenv, + blender, + makeWrapper, + extraModules ? [ ], }: stdenv.mkDerivation (finalAttrs: { pname = blender.pname + "-wrapped"; @@ -9,7 +10,10 @@ stdenv.mkDerivation (finalAttrs: { inherit (blender) version meta; - nativeBuildInputs = [ blender.pythonPackages.wrapPython makeWrapper ]; + nativeBuildInputs = [ + blender.pythonPackages.wrapPython + makeWrapper + ]; installPhase = '' mkdir $out/{share/applications,bin} -p sed 's/Exec=blender/Exec=${finalAttrs.finalPackage.pname}/g' $src/share/applications/blender.desktop > $out/share/applications/${finalAttrs.finalPackage.pname}.desktop diff --git a/pkgs/applications/misc/blucontrol/wrapper.nix b/pkgs/applications/misc/blucontrol/wrapper.nix index 3ace71b7644a64..20b19c45bb8b9b 100644 --- a/pkgs/applications/misc/blucontrol/wrapper.nix +++ b/pkgs/applications/misc/blucontrol/wrapper.nix @@ -1,33 +1,39 @@ -{ stdenv, lib, makeWrapper, ghcWithPackages, packages ? (_:[]) }: +{ + stdenv, + lib, + makeWrapper, + ghcWithPackages, + packages ? (_: [ ]), +}: let blucontrolEnv = ghcWithPackages (self: [ self.blucontrol ] ++ packages self); in - stdenv.mkDerivation { - pname = "blucontrol-with-packages"; - version = blucontrolEnv.version; +stdenv.mkDerivation { + pname = "blucontrol-with-packages"; + version = blucontrolEnv.version; - nativeBuildInputs = [ makeWrapper ]; + nativeBuildInputs = [ makeWrapper ]; - buildCommand = '' - makeWrapper ${blucontrolEnv}/bin/blucontrol $out/bin/blucontrol \ - --prefix PATH : ${lib.makeBinPath [ blucontrolEnv ]} - ''; + buildCommand = '' + makeWrapper ${blucontrolEnv}/bin/blucontrol $out/bin/blucontrol \ + --prefix PATH : ${lib.makeBinPath [ blucontrolEnv ]} + ''; - # trivial derivation - preferLocalBuild = true; - allowSubstitues = false; + # trivial derivation + preferLocalBuild = true; + allowSubstitues = false; - meta = with lib; { - description = "Configurable blue light filter"; - mainProgram = "blucontrol"; - longDescription = '' - This application is a blue light filter, with the main focus on configurability. - Configuration is done in Haskell in the style of xmonad. - Blucontrol makes use of monad transformers and allows monadic calculation of gamma values and recoloring. The user chooses, what will be captured in the monadic state. - ''; - license = licenses.bsd3; - homepage = "https://github.com/jumper149/blucontrol"; - platforms = platforms.unix; - maintainers = with maintainers; [ jumper149 ]; - }; - } + meta = with lib; { + description = "Configurable blue light filter"; + mainProgram = "blucontrol"; + longDescription = '' + This application is a blue light filter, with the main focus on configurability. + Configuration is done in Haskell in the style of xmonad. + Blucontrol makes use of monad transformers and allows monadic calculation of gamma values and recoloring. The user chooses, what will be captured in the monadic state. + ''; + license = licenses.bsd3; + homepage = "https://github.com/jumper149/blucontrol"; + platforms = platforms.unix; + maintainers = with maintainers; [ jumper149 ]; + }; +} diff --git a/pkgs/applications/misc/bluetooth_battery/default.nix b/pkgs/applications/misc/bluetooth_battery/default.nix index 4158cdf8cc5595..0eff5be2206fd9 100644 --- a/pkgs/applications/misc/bluetooth_battery/default.nix +++ b/pkgs/applications/misc/bluetooth_battery/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildPythonApplication, pybluez }: +{ + lib, + fetchFromGitHub, + buildPythonApplication, + pybluez, +}: buildPythonApplication rec { pname = "bluetooth_battery"; diff --git a/pkgs/applications/misc/brewtarget/default.nix b/pkgs/applications/misc/brewtarget/default.nix index d46cf7e0d5dd3a..72e7df62486a0b 100644 --- a/pkgs/applications/misc/brewtarget/default.nix +++ b/pkgs/applications/misc/brewtarget/default.nix @@ -1,15 +1,16 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, bash -, cmake -, boost -, xercesc -, xalanc -, qtbase -, qttools -, qtmultimedia -, qtsvg +{ + lib, + mkDerivation, + fetchFromGitHub, + bash, + cmake, + boost, + xercesc, + xalanc, + qtbase, + qttools, + qtmultimedia, + qtsvg, }: mkDerivation rec { @@ -23,8 +24,18 @@ mkDerivation rec { sha256 = "sha256-PqaiZ2eLH8+qRRkIolnQClTL9O9EgHMqFH/nUffosV8="; }; - nativeBuildInputs = [ cmake boost xercesc xalanc ]; - buildInputs = [ qtbase qttools qtmultimedia qtsvg ]; + nativeBuildInputs = [ + cmake + boost + xercesc + xalanc + ]; + buildInputs = [ + qtbase + qttools + qtmultimedia + qtsvg + ]; preConfigure = '' chmod +x configure diff --git a/pkgs/applications/misc/cambrinary/default.nix b/pkgs/applications/misc/cambrinary/default.nix index 15bb60d4c3f764..c55007b6205ff1 100644 --- a/pkgs/applications/misc/cambrinary/default.nix +++ b/pkgs/applications/misc/cambrinary/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, flit -, aiohttp -, beautifulsoup4 +{ + lib, + buildPythonApplication, + fetchFromGitHub, + flit, + aiohttp, + beautifulsoup4, }: buildPythonApplication rec { diff --git a/pkgs/applications/misc/candle/default.nix b/pkgs/applications/misc/candle/default.nix index 7b62e50e900632..32c0b872d1ae18 100644 --- a/pkgs/applications/misc/candle/default.nix +++ b/pkgs/applications/misc/candle/default.nix @@ -1,13 +1,20 @@ -{ mkDerivation, lib, fetchFromGitHub, qtbase, qtserialport, qmake }: +{ + mkDerivation, + lib, + fetchFromGitHub, + qtbase, + qtserialport, + qmake, +}: mkDerivation rec { pname = "candle"; version = "1.1"; src = fetchFromGitHub { - owner = "Denvi"; - repo = "Candle"; - rev = "v${version}"; + owner = "Denvi"; + repo = "Candle"; + rev = "v${version}"; sha256 = "1gpx08gdz8awbsj6lsczwgffp19z3q0r2fvm72a73qd9az29pmm0"; }; @@ -21,7 +28,10 @@ mkDerivation rec { runHook postInstall ''; - buildInputs = [ qtbase qtserialport ]; + buildInputs = [ + qtbase + qtserialport + ]; meta = with lib; { description = "GRBL controller application with G-Code visualizer written in Qt"; diff --git a/pkgs/applications/misc/cardpeek/default.nix b/pkgs/applications/misc/cardpeek/default.nix index 6122607bc4dc21..cc953ba23ec833 100644 --- a/pkgs/applications/misc/cardpeek/default.nix +++ b/pkgs/applications/misc/cardpeek/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, autoreconfHook -, glib -, gtk3 -, pcsclite -, lua5_2 -, curl -, readline -, PCSC +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + glib, + gtk3, + pcsclite, + lua5_2, + curl, + readline, + PCSC, }: let version = "0.8.4"; @@ -32,8 +33,18 @@ stdenv.mkDerivation { --replace 'PCSC_HEADERS=`ls -d /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/*.sdk/System/Library/Frameworks/PCSC.framework/Versions/Current/Headers/ | sort | head -1`' 'PCSC_HEADERS=${PCSC}/Library/Frameworks/PCSC.framework/Headers' ''; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ glib gtk3 lua5_2 curl readline ] + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = + [ + glib + gtk3 + lua5_2 + curl + readline + ] ++ lib.optional stdenv.hostPlatform.isDarwin PCSC ++ lib.optional stdenv.hostPlatform.isLinux pcsclite; diff --git a/pkgs/applications/misc/cask-server/default.nix b/pkgs/applications/misc/cask-server/default.nix index 2cb52a2b2cc8c0..f2d6b680be34a7 100644 --- a/pkgs/applications/misc/cask-server/default.nix +++ b/pkgs/applications/misc/cask-server/default.nix @@ -1,8 +1,9 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, cmake -, extra-cmake-modules +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + extra-cmake-modules, }: mkDerivation rec { diff --git a/pkgs/applications/misc/cataract/build.nix b/pkgs/applications/misc/cataract/build.nix index 860a49b5ce03ec..a6ee2a4a36c992 100644 --- a/pkgs/applications/misc/cataract/build.nix +++ b/pkgs/applications/misc/cataract/build.nix @@ -1,14 +1,17 @@ -{ lib, stdenv -, fetchgit -, autoreconfHook -, glib -, pkg-config -, libxml2 -, exiv2 -, imagemagick6 -, version -, sha256 -, rev }: +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + glib, + pkg-config, + libxml2, + exiv2, + imagemagick6, + version, + sha256, + rev, +}: stdenv.mkDerivation { inherit version; @@ -19,8 +22,16 @@ stdenv.mkDerivation { inherit sha256 rev; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ glib libxml2 exiv2 imagemagick6 ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + glib + libxml2 + exiv2 + imagemagick6 + ]; prePatch = '' sed -i 's|#include |#include |' src/jpeg-utils.cpp @@ -45,5 +56,3 @@ stdenv.mkDerivation { platforms = with platforms; linux ++ darwin; }; } - - diff --git a/pkgs/applications/misc/cataract/default.nix b/pkgs/applications/misc/cataract/default.nix index 3a9f20289227bf..0c450be4029261 100644 --- a/pkgs/applications/misc/cataract/default.nix +++ b/pkgs/applications/misc/cataract/default.nix @@ -5,4 +5,3 @@ callPackage ./build.nix { rev = "675e647dc8ae918d29f520a29be9201ae85a94dd"; sha256 = "13b9rvcy9k2ay8w36j28kc7f4lnxp4jc0494ck3xsmwgqsawmzdj"; } - diff --git a/pkgs/applications/misc/cataract/unstable.nix b/pkgs/applications/misc/cataract/unstable.nix index 397aed355a9524..deabaf7417211e 100644 --- a/pkgs/applications/misc/cataract/unstable.nix +++ b/pkgs/applications/misc/cataract/unstable.nix @@ -5,4 +5,3 @@ callPackage ./build.nix { rev = "db3d992febbe703931840e9bdad95c43081694a5"; sha256 = "04f85piy675lq36w1mw6mw66n8911mmn4ifj8h9x47z8z806h3rf"; } - diff --git a/pkgs/applications/misc/chewing-editor/default.nix b/pkgs/applications/misc/chewing-editor/default.nix index 9cf163055a4bc2..9f2e10fce87437 100644 --- a/pkgs/applications/misc/chewing-editor/default.nix +++ b/pkgs/applications/misc/chewing-editor/default.nix @@ -1,5 +1,13 @@ -{ lib, mkDerivation, fetchFromGitHub, cmake, pkg-config, libchewing, qtbase -, qttools }: +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + pkg-config, + libchewing, + qtbase, + qttools, +}: mkDerivation rec { pname = "chewing-editor"; @@ -14,8 +22,15 @@ mkDerivation rec { doCheck = true; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libchewing qtbase qttools ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + libchewing + qtbase + qttools + ]; meta = with lib; { description = "Cross platform chewing user phrase editor"; diff --git a/pkgs/applications/misc/clight/clight-gui.nix b/pkgs/applications/misc/clight/clight-gui.nix index da7dd77deeaa23..495ebc5024cd12 100644 --- a/pkgs/applications/misc/clight/clight-gui.nix +++ b/pkgs/applications/misc/clight/clight-gui.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qtbase -, qtcharts -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtbase, + qtcharts, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -18,8 +19,14 @@ stdenv.mkDerivation rec { hash = "sha256-U4vaMwnVDZnYLc+K3/yD81Q1vyBL8uSrrhOHbjbox5U="; }; - buildInputs = [ qtbase qtcharts ]; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + buildInputs = [ + qtbase + qtcharts + ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; sourceRoot = "${src.name}/src"; diff --git a/pkgs/applications/misc/clight/clightd.nix b/pkgs/applications/misc/clight/clightd.nix index 14fba10232bbf1..cb9bdea22067ac 100644 --- a/pkgs/applications/misc/clight/clightd.nix +++ b/pkgs/applications/misc/clight/clightd.nix @@ -1,12 +1,32 @@ -{ lib, stdenv, fetchFromGitHub -, dbus, cmake, pkg-config, wayland-scanner -, glib, udev, polkit, libusb1, libjpeg, libmodule -, pcre, libXdmcp, util-linux, libpthreadstubs -, enableDdc ? true, ddcutil -, enableDpms ? true, libXext -, enableGamma ? true, libdrm, libXrandr, wayland -, enableScreen ? true -, enableYoctolight ? true }: +{ + lib, + stdenv, + fetchFromGitHub, + dbus, + cmake, + pkg-config, + wayland-scanner, + glib, + udev, + polkit, + libusb1, + libjpeg, + libmodule, + pcre, + libXdmcp, + util-linux, + libpthreadstubs, + enableDdc ? true, + ddcutil, + enableDpms ? true, + libXext, + enableGamma ? true, + libdrm, + libXrandr, + wayland, + enableScreen ? true, + enableYoctolight ? true, +}: stdenv.mkDerivation rec { pname = "clightd"; @@ -30,15 +50,17 @@ stdenv.mkDerivation rec { ''; cmakeFlags = - [ "-DSYSTEMD_SERVICE_DIR=${placeholder "out"}/lib/systemd/system" + [ + "-DSYSTEMD_SERVICE_DIR=${placeholder "out"}/lib/systemd/system" "-DDBUS_CONFIG_DIR=${placeholder "out"}/etc/dbus-1/system.d" # systemd.pc has prefix=${systemd.out} "-DMODULE_LOAD_DIR=${placeholder "out"}/lib/modules-load.d" - ] ++ lib.optional enableDdc "-DENABLE_DDC=1" - ++ lib.optional enableDpms "-DENABLE_DPMS=1" - ++ lib.optional enableGamma "-DENABLE_GAMMA=1" - ++ lib.optional enableScreen "-DENABLE_SCREEN=1" - ++ lib.optional enableYoctolight "-DENABLE_YOCTOLIGHT=1"; + ] + ++ lib.optional enableDdc "-DENABLE_DDC=1" + ++ lib.optional enableDpms "-DENABLE_DPMS=1" + ++ lib.optional enableGamma "-DENABLE_GAMMA=1" + ++ lib.optional enableScreen "-DENABLE_SCREEN=1" + ++ lib.optional enableYoctolight "-DENABLE_YOCTOLIGHT=1"; depsBuildBuild = [ pkg-config @@ -50,23 +72,28 @@ stdenv.mkDerivation rec { wayland-scanner ]; - buildInputs = [ - dbus - glib - udev - polkit - libusb1 - libjpeg - libmodule + buildInputs = + [ + dbus + glib + udev + polkit + libusb1 + libjpeg + libmodule - pcre - libXdmcp - util-linux - libpthreadstubs - ] ++ lib.optionals enableDdc [ ddcutil ] + pcre + libXdmcp + util-linux + libpthreadstubs + ] + ++ lib.optionals enableDdc [ ddcutil ] ++ lib.optionals enableDpms [ libXext ] ++ lib.optionals enableGamma [ libXrandr ] - ++ lib.optionals (enableDpms || enableGamma || enableScreen) [ libdrm wayland ]; + ++ lib.optionals (enableDpms || enableGamma || enableScreen) [ + libdrm + wayland + ]; postInstall = '' mkdir -p $out/bin diff --git a/pkgs/applications/misc/clight/default.nix b/pkgs/applications/misc/clight/default.nix index 3f3ea2416d8936..820e1f3d62fd62 100644 --- a/pkgs/applications/misc/clight/default.nix +++ b/pkgs/applications/misc/clight/default.nix @@ -1,8 +1,22 @@ -{ lib, stdenv, fetchFromGitHub -, dbus, cmake, pkg-config, bash-completion -, gsl, popt, clightd, systemd, libconfig, libmodule -, withGeoclue ? true, geoclue2 -, withUpower ? true, upower }: +{ + lib, + stdenv, + fetchFromGitHub, + dbus, + cmake, + pkg-config, + bash-completion, + gsl, + popt, + clightd, + systemd, + libconfig, + libmodule, + withGeoclue ? true, + geoclue2, + withUpower ? true, + upower, +}: stdenv.mkDerivation rec { pname = "clight"; @@ -22,16 +36,18 @@ stdenv.mkDerivation rec { bash-completion ]; - buildInputs = [ - gsl - popt - upower - clightd - systemd - geoclue2 - libconfig - libmodule - ] ++ lib.optional withGeoclue geoclue2 + buildInputs = + [ + gsl + popt + upower + clightd + systemd + geoclue2 + libconfig + libmodule + ] + ++ lib.optional withGeoclue geoclue2 ++ lib.optional withUpower upower; cmakeFlags = [ diff --git a/pkgs/applications/misc/cobalt/default.nix b/pkgs/applications/misc/cobalt/default.nix index a5dd6a8d9ef406..53cff166991e43 100644 --- a/pkgs/applications/misc/cobalt/default.nix +++ b/pkgs/applications/misc/cobalt/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, CoreServices }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + CoreServices, +}: rustPlatform.buildRustPackage rec { pname = "cobalt"; diff --git a/pkgs/applications/misc/collision/default.nix b/pkgs/applications/misc/collision/default.nix index 1f05eb614f0dab..a0ff53ec331441 100644 --- a/pkgs/applications/misc/collision/default.nix +++ b/pkgs/applications/misc/collision/default.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitHub -, crystal -, wrapGAppsHook4 -, desktopToDarwinBundle -, gobject-introspection -, nautilus-python -, python3 -, libadwaita -, openssl -, libxml2 -, pkg-config -, gitUpdater -, _experimental-update-script-combinators -, runCommand -, crystal2nix -, writeShellScript +{ + stdenv, + lib, + fetchFromGitHub, + crystal, + wrapGAppsHook4, + desktopToDarwinBundle, + gobject-introspection, + nautilus-python, + python3, + libadwaita, + openssl, + libxml2, + pkg-config, + gitUpdater, + _experimental-update-script-combinators, + runCommand, + crystal2nix, + writeShellScript, }: crystal.buildCrystalPackage rec { @@ -47,8 +48,11 @@ crystal.buildCrystalPackage rec { # There is an explanation for this https://danilafe.com/blog/crystal_nix_revisited/ # Shortly, adding pkg-config to buildInputs along with openssl fixes the issue. - nativeBuildInputs = [ wrapGAppsHook4 pkg-config gobject-introspection ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; + nativeBuildInputs = [ + wrapGAppsHook4 + pkg-config + gobject-introspection + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; buildInputs = [ libadwaita @@ -58,23 +62,41 @@ crystal.buildCrystalPackage rec { python3.pkgs.pygobject3 ]; - buildTargets = ["bindings" "build"]; + buildTargets = [ + "bindings" + "build" + ]; doCheck = false; doInstallCheck = false; - installTargets = ["desktop" "install"]; + installTargets = [ + "desktop" + "install" + ]; postInstall = '' - install -Dm555 ./nautilus-extension/collision-extension.py -t $out/share/nautilus-python/extensions + install -Dm555 ./nautilus-extension/collision-extension.py -t $out/share/nautilus-python/extensions ''; passthru = { updateScript = _experimental-update-script-combinators.sequence [ (gitUpdater { rev-prefix = "v"; }) (_experimental-update-script-combinators.copyAttrOutputToFile "collision.shardLock" ./shard.lock) - { command = [ (writeShellScript "update-lock" "cd $1; ${lib.getExe crystal2nix}") ./. ]; supportedFeatures = [ "silent" ]; } - { command = [ "rm" ./shard.lock ]; supportedFeatures = [ "silent" ]; } + { + command = [ + (writeShellScript "update-lock" "cd $1; ${lib.getExe crystal2nix}") + ./. + ]; + supportedFeatures = [ "silent" ]; + } + { + command = [ + "rm" + ./shard.lock + ]; + supportedFeatures = [ "silent" ]; + } ]; shardLock = runCommand "shard.lock" { inherit src; } '' cp $src/shard.lock $out diff --git a/pkgs/applications/misc/confclerk/default.nix b/pkgs/applications/misc/confclerk/default.nix index 0ace0e1e493b01..0d7a4131e6fe60 100644 --- a/pkgs/applications/misc/confclerk/default.nix +++ b/pkgs/applications/misc/confclerk/default.nix @@ -1,4 +1,10 @@ -{ lib, mkDerivation, fetchurl, qtbase, qmake }: +{ + lib, + mkDerivation, + fetchurl, + qtbase, + qmake, +}: mkDerivation rec { pname = "confclerk"; diff --git a/pkgs/applications/misc/coolreader/default.nix b/pkgs/applications/misc/coolreader/default.nix index 22e9906db561df..6433e007992376 100644 --- a/pkgs/applications/misc/coolreader/default.nix +++ b/pkgs/applications/misc/coolreader/default.nix @@ -1,5 +1,14 @@ -{ stdenv, mkDerivation, fetchFromGitHub, cmake, pkg-config, lib, - qttools, fribidi, libunibreak }: +{ + stdenv, + mkDerivation, + fetchFromGitHub, + cmake, + pkg-config, + lib, + qttools, + fribidi, + libunibreak, +}: mkDerivation rec { pname = "coolreader"; @@ -12,9 +21,16 @@ mkDerivation rec { sha256 = "sha256-ZfgaLCLvBU6xP7nx7YJTsJSpvpdQgLpSMWH+BsG8E1g="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ qttools fribidi libunibreak ]; + buildInputs = [ + qttools + fribidi + libunibreak + ]; meta = with lib; { broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/applications/misc/copyq/default.nix b/pkgs/applications/misc/copyq/default.nix index e6788abeca528f..bb395236a66c38 100644 --- a/pkgs/applications/misc/copyq/default.nix +++ b/pkgs/applications/misc/copyq/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -, qtbase -, qtsvg -, qttools -, qtdeclarative -, libXfixes -, libXtst -, qtwayland -, wayland -, wrapQtAppsHook -, kdePackages +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + qtbase, + qtsvg, + qttools, + qtdeclarative, + libXfixes, + libXtst, + qtwayland, + wayland, + wrapQtAppsHook, + kdePackages, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/misc/cubocore-packages/coreaction/default.nix b/pkgs/applications/misc/cubocore-packages/coreaction/default.nix index cd6363f5a10064..944dc109c0e9f8 100644 --- a/pkgs/applications/misc/cubocore-packages/coreaction/default.nix +++ b/pkgs/applications/misc/cubocore-packages/coreaction/default.nix @@ -1,4 +1,14 @@ -{ mkDerivation, lib, fetchFromGitLab, qtsvg, qtbase, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtsvg, + qtbase, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "coreaction"; diff --git a/pkgs/applications/misc/cubocore-packages/corearchiver/default.nix b/pkgs/applications/misc/cubocore-packages/corearchiver/default.nix index 691917e28da9f0..d06bea646dc7e1 100644 --- a/pkgs/applications/misc/cubocore-packages/corearchiver/default.nix +++ b/pkgs/applications/misc/cubocore-packages/corearchiver/default.nix @@ -1,4 +1,15 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, libarchive, libarchive-qt, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + libarchive, + libarchive-qt, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "corearchiver"; diff --git a/pkgs/applications/misc/cubocore-packages/corefm/default.nix b/pkgs/applications/misc/cubocore-packages/corefm/default.nix index 79e1e206ea02d0..1bdf0f104dee60 100644 --- a/pkgs/applications/misc/cubocore-packages/corefm/default.nix +++ b/pkgs/applications/misc/cubocore-packages/corefm/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "corefm"; diff --git a/pkgs/applications/misc/cubocore-packages/coregarage/default.nix b/pkgs/applications/misc/cubocore-packages/coregarage/default.nix index 6c181da0b112d5..32ab1063a04b6d 100644 --- a/pkgs/applications/misc/cubocore-packages/coregarage/default.nix +++ b/pkgs/applications/misc/cubocore-packages/coregarage/default.nix @@ -1,4 +1,15 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, libarchive, libarchive-qt, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + libarchive, + libarchive-qt, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "coregarage"; diff --git a/pkgs/applications/misc/cubocore-packages/corehunt/default.nix b/pkgs/applications/misc/cubocore-packages/corehunt/default.nix index 1c4d643488eb59..61d585e347fe9e 100644 --- a/pkgs/applications/misc/cubocore-packages/corehunt/default.nix +++ b/pkgs/applications/misc/cubocore-packages/corehunt/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "corehunt"; diff --git a/pkgs/applications/misc/cubocore-packages/coreimage/default.nix b/pkgs/applications/misc/cubocore-packages/coreimage/default.nix index 61e20afa5eeb00..d0c01f95c0d260 100644 --- a/pkgs/applications/misc/cubocore-packages/coreimage/default.nix +++ b/pkgs/applications/misc/cubocore-packages/coreimage/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "coreimage"; diff --git a/pkgs/applications/misc/cubocore-packages/coreinfo/default.nix b/pkgs/applications/misc/cubocore-packages/coreinfo/default.nix index 32ccccf4b2a41c..7d788eea2286ac 100644 --- a/pkgs/applications/misc/cubocore-packages/coreinfo/default.nix +++ b/pkgs/applications/misc/cubocore-packages/coreinfo/default.nix @@ -1,4 +1,16 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, libzen, libmediainfo, zlib, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + libzen, + libmediainfo, + zlib, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "coreinfo"; diff --git a/pkgs/applications/misc/cubocore-packages/corekeyboard/default.nix b/pkgs/applications/misc/cubocore-packages/corekeyboard/default.nix index 0a6b7b15e14247..d5df2a0bf8300b 100644 --- a/pkgs/applications/misc/cubocore-packages/corekeyboard/default.nix +++ b/pkgs/applications/misc/cubocore-packages/corekeyboard/default.nix @@ -1,4 +1,15 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, qtx11extras, xorg, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + qtx11extras, + xorg, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "corekeyboard"; diff --git a/pkgs/applications/misc/cubocore-packages/corepad/default.nix b/pkgs/applications/misc/cubocore-packages/corepad/default.nix index 3a1cd9f87c1c88..e3ff6fdf2b3677 100644 --- a/pkgs/applications/misc/cubocore-packages/corepad/default.nix +++ b/pkgs/applications/misc/cubocore-packages/corepad/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "corepad"; diff --git a/pkgs/applications/misc/cubocore-packages/corepaint/default.nix b/pkgs/applications/misc/cubocore-packages/corepaint/default.nix index 01a495bfcbaf80..2f4e15543a2f3c 100644 --- a/pkgs/applications/misc/cubocore-packages/corepaint/default.nix +++ b/pkgs/applications/misc/cubocore-packages/corepaint/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "corepaint"; diff --git a/pkgs/applications/misc/cubocore-packages/corepdf/default.nix b/pkgs/applications/misc/cubocore-packages/corepdf/default.nix index a343f84baf8c7d..b45330fef2cead 100644 --- a/pkgs/applications/misc/cubocore-packages/corepdf/default.nix +++ b/pkgs/applications/misc/cubocore-packages/corepdf/default.nix @@ -1,4 +1,15 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, poppler, qtwebengine, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + poppler, + qtwebengine, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "corepdf"; diff --git a/pkgs/applications/misc/cubocore-packages/corepins/default.nix b/pkgs/applications/misc/cubocore-packages/corepins/default.nix index e7306691b02c0f..19e34bfbfea1d3 100644 --- a/pkgs/applications/misc/cubocore-packages/corepins/default.nix +++ b/pkgs/applications/misc/cubocore-packages/corepins/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "corepins"; diff --git a/pkgs/applications/misc/cubocore-packages/corerenamer/default.nix b/pkgs/applications/misc/cubocore-packages/corerenamer/default.nix index 92d8cd04c95b40..c500ab6fa6a81f 100644 --- a/pkgs/applications/misc/cubocore-packages/corerenamer/default.nix +++ b/pkgs/applications/misc/cubocore-packages/corerenamer/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "corerenamer"; diff --git a/pkgs/applications/misc/cubocore-packages/coreshot/default.nix b/pkgs/applications/misc/cubocore-packages/coreshot/default.nix index ed9339251756ae..b283e49237aae3 100644 --- a/pkgs/applications/misc/cubocore-packages/coreshot/default.nix +++ b/pkgs/applications/misc/cubocore-packages/coreshot/default.nix @@ -1,4 +1,14 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, qtx11extras, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + qtx11extras, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "coreshot"; diff --git a/pkgs/applications/misc/cubocore-packages/corestats/default.nix b/pkgs/applications/misc/cubocore-packages/corestats/default.nix index a6d12a0d2c28a8..f557f48740f8ba 100644 --- a/pkgs/applications/misc/cubocore-packages/corestats/default.nix +++ b/pkgs/applications/misc/cubocore-packages/corestats/default.nix @@ -1,4 +1,14 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, lm_sensors, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + lm_sensors, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "corestats"; diff --git a/pkgs/applications/misc/cubocore-packages/corestuff/default.nix b/pkgs/applications/misc/cubocore-packages/corestuff/default.nix index 08b8629da6525a..8ec6080a4c32ae 100644 --- a/pkgs/applications/misc/cubocore-packages/corestuff/default.nix +++ b/pkgs/applications/misc/cubocore-packages/corestuff/default.nix @@ -1,4 +1,16 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, qtx11extras, kglobalaccel, xorg, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + qtx11extras, + kglobalaccel, + xorg, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "corestuff"; diff --git a/pkgs/applications/misc/cubocore-packages/coreterminal/default.nix b/pkgs/applications/misc/cubocore-packages/coreterminal/default.nix index d2dc3599bd34a4..f2671ab3eff250 100644 --- a/pkgs/applications/misc/cubocore-packages/coreterminal/default.nix +++ b/pkgs/applications/misc/cubocore-packages/coreterminal/default.nix @@ -1,13 +1,14 @@ -{ mkDerivation -, lib -, fetchFromGitLab -, qtbase -, qtserialport -, qtermwidget -, cmake -, ninja -, libcprime -, libcsys +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + qtserialport, + qtermwidget, + cmake, + ninja, + libcprime, + libcsys, }: mkDerivation rec { diff --git a/pkgs/applications/misc/cubocore-packages/coretime/default.nix b/pkgs/applications/misc/cubocore-packages/coretime/default.nix index 626b7cf8eda41c..b210b0ca766c21 100644 --- a/pkgs/applications/misc/cubocore-packages/coretime/default.nix +++ b/pkgs/applications/misc/cubocore-packages/coretime/default.nix @@ -1,4 +1,14 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, qtmultimedia, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + qtmultimedia, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "coretime"; diff --git a/pkgs/applications/misc/cubocore-packages/coretoppings/default.nix b/pkgs/applications/misc/cubocore-packages/coretoppings/default.nix index 1296c8f57564f7..ed5d5fc49fa94e 100644 --- a/pkgs/applications/misc/cubocore-packages/coretoppings/default.nix +++ b/pkgs/applications/misc/cubocore-packages/coretoppings/default.nix @@ -1,31 +1,32 @@ -{ mkDerivation -, lib -, fetchFromGitLab -, ffmpeg -, cmake -, ninja -, qtbase -, qtx11extras -, qtconnectivity -, v4l-utils -, grim -, wf-recorder -, libdbusmenu -, playerctl -, xorg -, iio-sensor-proxy -, inotify-tools -, bluez -, networkmanager -, connman -, redshift -, gawk -, polkit -, libnotify -, systemd -, xdg-utils -, libcprime -, libcsys +{ + mkDerivation, + lib, + fetchFromGitLab, + ffmpeg, + cmake, + ninja, + qtbase, + qtx11extras, + qtconnectivity, + v4l-utils, + grim, + wf-recorder, + libdbusmenu, + playerctl, + xorg, + iio-sensor-proxy, + inotify-tools, + bluez, + networkmanager, + connman, + redshift, + gawk, + polkit, + libnotify, + systemd, + xdg-utils, + libcprime, + libcsys, }: mkDerivation rec { diff --git a/pkgs/applications/misc/cubocore-packages/coreuniverse/default.nix b/pkgs/applications/misc/cubocore-packages/coreuniverse/default.nix index df84578090f85e..dfe9e4f1ea893e 100644 --- a/pkgs/applications/misc/cubocore-packages/coreuniverse/default.nix +++ b/pkgs/applications/misc/cubocore-packages/coreuniverse/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchFromGitLab, qtbase, cmake, ninja, libcprime, libcsys }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qtbase, + cmake, + ninja, + libcprime, + libcsys, +}: mkDerivation rec { pname = "coreuniverse"; diff --git a/pkgs/applications/misc/cubocore-packages/libcprime/default.nix b/pkgs/applications/misc/cubocore-packages/libcprime/default.nix index d4b15ead4ec009..353128b091af69 100644 --- a/pkgs/applications/misc/cubocore-packages/libcprime/default.nix +++ b/pkgs/applications/misc/cubocore-packages/libcprime/default.nix @@ -1,11 +1,12 @@ -{ mkDerivation -, lib -, fetchFromGitLab -, libnotify -, cmake -, ninja -, qtbase -, qtconnectivity +{ + mkDerivation, + lib, + fetchFromGitLab, + libnotify, + cmake, + ninja, + qtbase, + qtconnectivity, }: mkDerivation rec { diff --git a/pkgs/applications/misc/cubocore-packages/libcsys/default.nix b/pkgs/applications/misc/cubocore-packages/libcsys/default.nix index 3a36c40fd28133..ba9162ed33c8c9 100644 --- a/pkgs/applications/misc/cubocore-packages/libcsys/default.nix +++ b/pkgs/applications/misc/cubocore-packages/libcsys/default.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, fetchFromGitLab, udisks2, qtbase, cmake, ninja }: +{ + mkDerivation, + lib, + fetchFromGitLab, + udisks2, + qtbase, + cmake, + ninja, +}: mkDerivation rec { pname = "libcsys"; diff --git a/pkgs/applications/misc/cura/default.nix b/pkgs/applications/misc/cura/default.nix index a385d31ec74b61..1c512fec699f85 100644 --- a/pkgs/applications/misc/cura/default.nix +++ b/pkgs/applications/misc/cura/default.nix @@ -1,5 +1,15 @@ -{ mkDerivation, lib, fetchFromGitHub, cmake, python3, qtbase, - qtquickcontrols2, qtgraphicaleffects, curaengine, plugins ? [] }: +{ + mkDerivation, + lib, + fetchFromGitHub, + cmake, + python3, + qtbase, + qtquickcontrols2, + qtgraphicaleffects, + curaengine, + plugins ? [ ], +}: mkDerivation rec { pname = "cura"; @@ -19,12 +29,30 @@ mkDerivation rec { sha256 = "sha256-7y4OcbeQHv+loJ4cMgPU0e818Zsv90EwARdztNWS8zM="; }; - buildInputs = [ qtbase qtquickcontrols2 qtgraphicaleffects ]; - propagatedBuildInputs = with python3.pkgs; [ - libsavitar numpy-stl pyserial requests uranium zeroconf pynest2d - sentry-sdk trimesh keyring - ] ++ plugins; - nativeBuildInputs = [ cmake python3.pkgs.wrapPython ]; + buildInputs = [ + qtbase + qtquickcontrols2 + qtgraphicaleffects + ]; + propagatedBuildInputs = + with python3.pkgs; + [ + libsavitar + numpy-stl + pyserial + requests + uranium + zeroconf + pynest2d + sentry-sdk + trimesh + keyring + ] + ++ plugins; + nativeBuildInputs = [ + cmake + python3.pkgs.wrapPython + ]; cmakeFlags = [ "-DURANIUM_DIR=${python3.pkgs.uranium.src}" @@ -61,6 +89,9 @@ mkDerivation rec { homepage = "https://github.com/Ultimaker/Cura"; license = licenses.lgpl3Plus; platforms = platforms.linux; - maintainers = with maintainers; [ abbradar gebner ]; + maintainers = with maintainers; [ + abbradar + gebner + ]; }; } diff --git a/pkgs/applications/misc/cura/plugins.nix b/pkgs/applications/misc/cura/plugins.nix index 12f7920d3bf725..b80111e216dba9 100644 --- a/pkgs/applications/misc/cura/plugins.nix +++ b/pkgs/applications/misc/cura/plugins.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, python3Packages, libspnav, jq }: +{ + lib, + stdenv, + fetchFromGitHub, + python3Packages, + libspnav, + jq, +}: let @@ -73,4 +80,5 @@ let }; -in self +in +self diff --git a/pkgs/applications/misc/curaengine/default.nix b/pkgs/applications/misc/curaengine/default.nix index 70283d49fea937..428865935e2daf 100644 --- a/pkgs/applications/misc/curaengine/default.nix +++ b/pkgs/applications/misc/curaengine/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libarcus, stb, protobuf, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libarcus, + stb, + protobuf, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "curaengine"; @@ -12,7 +21,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libarcus stb protobuf ]; + buildInputs = [ + libarcus + stb + protobuf + ]; cmakeFlags = [ "-DCURA_ENGINE_VERSION=${version}" ]; @@ -30,7 +43,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/Ultimaker/CuraEngine"; license = licenses.agpl3Only; platforms = platforms.linux; - maintainers = with maintainers; [ abbradar gebner ]; + maintainers = with maintainers; [ + abbradar + gebner + ]; mainProgram = "CuraEngine"; }; } diff --git a/pkgs/applications/misc/curaengine/stable.nix b/pkgs/applications/misc/curaengine/stable.nix index 0de7e18f172d79..103f081fe15014 100644 --- a/pkgs/applications/misc/curaengine/stable.nix +++ b/pkgs/applications/misc/curaengine/stable.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "curaengine"; diff --git a/pkgs/applications/misc/databricks-sql-cli/default.nix b/pkgs/applications/misc/databricks-sql-cli/default.nix index 75b5529187296f..385910f680103d 100644 --- a/pkgs/applications/misc/databricks-sql-cli/default.nix +++ b/pkgs/applications/misc/databricks-sql-cli/default.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/applications/misc/ddcui/default.nix b/pkgs/applications/misc/ddcui/default.nix index 045e37cef160ee..f4095b1782c081 100644 --- a/pkgs/applications/misc/ddcui/default.nix +++ b/pkgs/applications/misc/ddcui/default.nix @@ -1,11 +1,12 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, cmake -, pkg-config -, qtbase -, qttools -, ddcutil +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + pkg-config, + qtbase, + qttools, + ddcutil, }: mkDerivation rec { diff --git a/pkgs/applications/misc/deadd-notification-center/default.nix b/pkgs/applications/misc/deadd-notification-center/default.nix index e6fed669c72d62..dda967a113e179 100644 --- a/pkgs/applications/misc/deadd-notification-center/default.nix +++ b/pkgs/applications/misc/deadd-notification-center/default.nix @@ -1,4 +1,9 @@ -{ mkDerivation, haskellPackages, fetchFromGitHub, lib }: +{ + mkDerivation, + haskellPackages, + fetchFromGitHub, + lib, +}: let # deadd-notification-center.service @@ -15,7 +20,8 @@ let [Install] WantedBy=graphical-session.target ''; -in mkDerivation rec { +in +mkDerivation rec { pname = "deadd-notification-center"; version = "2.1.1"; @@ -31,11 +37,42 @@ in mkDerivation rec { isExecutable = true; libraryHaskellDepends = with haskellPackages; [ - aeson base bytestring ConfigFile containers dbus directory env-locale - filepath gi-cairo gi-gdk gi-gdkpixbuf gi-gio gi-glib gi-gobject - gi-gtk gi-pango haskell-gettext haskell-gi haskell-gi-base - hdaemonize here lens mtl process regex-tdfa setlocale split stm - tagsoup text time transformers tuple unix yaml + aeson + base + bytestring + ConfigFile + containers + dbus + directory + env-locale + filepath + gi-cairo + gi-gdk + gi-gdkpixbuf + gi-gio + gi-glib + gi-gobject + gi-gtk + gi-pango + haskell-gettext + haskell-gi + haskell-gi-base + hdaemonize + here + lens + mtl + process + regex-tdfa + setlocale + split + stm + tagsoup + text + time + transformers + tuple + unix + yaml ]; executableHaskellDepends = with haskellPackages; [ base ]; @@ -58,7 +95,10 @@ in mkDerivation rec { description = "Haskell-written notification center for users that like a desktop with style"; homepage = "https://github.com/phuhl/linux_notification_center"; license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [ melkor333 sna ]; + maintainers = with lib.maintainers; [ + melkor333 + sna + ]; platforms = lib.platforms.linux; mainProgram = "deadd-notification-center"; } diff --git a/pkgs/applications/misc/devilspie2/default.nix b/pkgs/applications/misc/devilspie2/default.nix index 830bfd19471a22..89af855c78625a 100644 --- a/pkgs/applications/misc/devilspie2/default.nix +++ b/pkgs/applications/misc/devilspie2/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, intltool, pkg-config, glib, gtk, lua, libwnck }: +{ + lib, + stdenv, + fetchurl, + intltool, + pkg-config, + glib, + gtk, + lua, + libwnck, +}: stdenv.mkDerivation rec { pname = "devilspie2"; @@ -9,8 +19,16 @@ stdenv.mkDerivation rec { sha256 = "Cp8erdKyKjGBY+QYAGXUlSIboaQ60gIepoZs0RgEJkA="; }; - nativeBuildInputs = [ intltool pkg-config ]; - buildInputs = [ glib gtk lua libwnck ]; + nativeBuildInputs = [ + intltool + pkg-config + ]; + buildInputs = [ + glib + gtk + lua + libwnck + ]; installPhase = '' mkdir -p $out/bin $out/share/man/man1 diff --git a/pkgs/applications/misc/diff-pdf/default.nix b/pkgs/applications/misc/diff-pdf/default.nix index d64d8f6ab9be19..4302d6cde399f7 100644 --- a/pkgs/applications/misc/diff-pdf/default.nix +++ b/pkgs/applications/misc/diff-pdf/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, pkg-config, cairo, poppler, wxGTK, Cocoa }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + pkg-config, + cairo, + poppler, + wxGTK, + Cocoa, +}: stdenv.mkDerivation rec { pname = "diff-pdf"; @@ -11,9 +22,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-6aKF3Xqp/1BoHEiZVZJSemTjn5Qwwr3QyhsXOIjTr08="; }; - nativeBuildInputs = [ autoconf automake pkg-config ]; - buildInputs = [ cairo poppler wxGTK ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + ]; + buildInputs = [ + cairo + poppler + wxGTK + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; preConfigure = "./bootstrap"; diff --git a/pkgs/applications/misc/diffpdf/default.nix b/pkgs/applications/misc/diffpdf/default.nix index 41265e61cfc363..e0e82119269429 100644 --- a/pkgs/applications/misc/diffpdf/default.nix +++ b/pkgs/applications/misc/diffpdf/default.nix @@ -1,4 +1,13 @@ -{ lib, mkDerivation, fetchurl, fetchpatch, qmake, qttools, qtbase, poppler }: +{ + lib, + mkDerivation, + fetchurl, + fetchpatch, + qmake, + qttools, + qtbase, + poppler, +}: mkDerivation rec { version = "2.1.3"; @@ -17,8 +26,14 @@ mkDerivation rec { ./fix_path_poppler_qt5.patch ]; - nativeBuildInputs = [ qmake qttools ]; - buildInputs = [ qtbase poppler ]; + nativeBuildInputs = [ + qmake + qttools + ]; + buildInputs = [ + qtbase + poppler + ]; preConfigure = '' substituteInPlace diffpdf.pro --replace @@NIX_POPPLER_QT5@@ ${poppler.dev} @@ -46,7 +61,7 @@ mkDerivation rec { Exec=$out/bin/diffpdf Terminal=false EOF - ''; + ''; meta = { homepage = "http://www.qtrac.eu/diffpdf.html"; diff --git a/pkgs/applications/misc/digitalbitbox/default.nix b/pkgs/applications/misc/digitalbitbox/default.nix index 93802ee8682c42..1aa3ca72eb6191 100644 --- a/pkgs/applications/misc/digitalbitbox/default.nix +++ b/pkgs/applications/misc/digitalbitbox/default.nix @@ -1,27 +1,28 @@ -{ mkDerivation -, lib -, autoreconfHook -, curl -, fetchFromGitHub -, git -, libevent -, libtool -, qrencode -, udev -, libusb1 -, makeWrapper -, pkg-config -, qtbase -, qttools -, qtwebsockets -, qtmultimedia -, udevRule51 ? '' -, SUBSYSTEM=="usb", TAG+="uaccess", TAG+="udev-acl", SYMLINK+="dbb%n", ATTRS{idVendor}=="03eb", ATTRS{idProduct}=="2402" -, '' -, udevRule52 ? '' -, KERNEL=="hidraw*", SUBSYSTEM=="hidraw", ATTRS{idVendor}=="03eb", ATTRS{idProduct}=="2402", TAG+="uaccess", TAG+="udev-acl", SYMLINK+="dbbf%n" -, '' -, writeText +{ + mkDerivation, + lib, + autoreconfHook, + curl, + fetchFromGitHub, + git, + libevent, + libtool, + qrencode, + udev, + libusb1, + makeWrapper, + pkg-config, + qtbase, + qttools, + qtwebsockets, + qtmultimedia, + udevRule51 ? '' + , SUBSYSTEM=="usb", TAG+="uaccess", TAG+="udev-acl", SYMLINK+="dbb%n", ATTRS{idVendor}=="03eb", ATTRS{idProduct}=="2402" + , '', + udevRule52 ? '' + , KERNEL=="hidraw*", SUBSYSTEM=="hidraw", ATTRS{idVendor}=="03eb", ATTRS{idProduct}=="2402", TAG+="uaccess", TAG+="udev-acl", SYMLINK+="dbbf%n" + , '', + writeText, }: # Enabling the digitalbitbox program @@ -45,9 +46,9 @@ # See https://digitalbitbox.com/start_linux for more information. let - copyUdevRuleToOutput = name: rule: - "cp ${writeText name rule} $out/etc/udev/rules.d/${name}"; -in mkDerivation rec { + copyUdevRuleToOutput = name: rule: "cp ${writeText name rule} $out/etc/udev/rules.d/${name}"; +in +mkDerivation rec { pname = "digitalbitbox"; version = "3.0.0"; @@ -79,12 +80,12 @@ in mkDerivation rec { qtmultimedia ]; - LUPDATE="${qttools.dev}/bin/lupdate"; - LRELEASE="${qttools.dev}/bin/lrelease"; - MOC="${qtbase.dev}/bin/moc"; - QTDIR=qtbase.dev; - RCC="${qtbase.dev}/bin/rcc"; - UIC="${qtbase.dev}/bin/uic"; + LUPDATE = "${qttools.dev}/bin/lupdate"; + LRELEASE = "${qttools.dev}/bin/lrelease"; + MOC = "${qtbase.dev}/bin/moc"; + QTDIR = qtbase.dev; + RCC = "${qtbase.dev}/bin/rcc"; + UIC = "${qtbase.dev}/bin/uic"; configureFlags = [ "--enable-libusb" diff --git a/pkgs/applications/misc/ding/default.nix b/pkgs/applications/misc/ding/default.nix index d0791b492f09f9..a80f3061241c43 100644 --- a/pkgs/applications/misc/ding/default.nix +++ b/pkgs/applications/misc/ding/default.nix @@ -1,4 +1,17 @@ -{ aspell, aspellDicts_de, aspellDicts_en, buildEnv, fetchurl, fortune, gnugrep, makeWrapper, lib, stdenv, tk, tre }: +{ + aspell, + aspellDicts_de, + aspellDicts_en, + buildEnv, + fetchurl, + fortune, + gnugrep, + makeWrapper, + lib, + stdenv, + tk, + tre, +}: let aspellEnv = buildEnv { name = "env-ding-aspell"; @@ -19,7 +32,13 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ aspellEnv fortune gnugrep tk tre ]; + buildInputs = [ + aspellEnv + fortune + gnugrep + tk + tre + ]; patches = [ ./dict.patch ]; @@ -44,7 +63,14 @@ stdenv.mkDerivation rec { cp -v ding.png $out/share/pixmaps/ cp -v ding.desktop $out/share/applications/ - wrapProgram $out/bin/ding --prefix PATH : ${lib.makeBinPath [ gnugrep aspellEnv tk fortune ]} --prefix ASPELL_CONF : "\"prefix ${aspellEnv};\"" + wrapProgram $out/bin/ding --prefix PATH : ${ + lib.makeBinPath [ + gnugrep + aspellEnv + tk + fortune + ] + } --prefix ASPELL_CONF : "\"prefix ${aspellEnv};\"" ''; meta = with lib; { diff --git a/pkgs/applications/misc/dmensamenu/default.nix b/pkgs/applications/misc/dmensamenu/default.nix index 75c9302e079168..7e20001b44a380 100644 --- a/pkgs/applications/misc/dmensamenu/default.nix +++ b/pkgs/applications/misc/dmensamenu/default.nix @@ -1,4 +1,11 @@ -{ lib, buildPythonApplication, fetchFromGitHub, substituteAll, requests, dmenu }: +{ + lib, + buildPythonApplication, + fetchFromGitHub, + substituteAll, + requests, + dmenu, +}: buildPythonApplication rec { pname = "dmensamenu"; diff --git a/pkgs/applications/misc/dmenu/default.nix b/pkgs/applications/misc/dmenu/default.nix index 75ae73179cf372..8479bf15d382ba 100644 --- a/pkgs/applications/misc/dmenu/default.nix +++ b/pkgs/applications/misc/dmenu/default.nix @@ -1,7 +1,19 @@ -{ lib, stdenv, fetchurl, fontconfig, libX11, libXinerama, libXft, pkg-config, zlib, writeText -, conf ? null, patches ? null +{ + lib, + stdenv, + fetchurl, + fontconfig, + libX11, + libXinerama, + libXft, + pkg-config, + zlib, + writeText, + conf ? null, + patches ? null, # update script dependencies -, gitUpdater }: + gitUpdater, +}: stdenv.mkDerivation rec { pname = "dmenu"; @@ -13,20 +25,26 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ fontconfig libX11 libXinerama zlib libXft ]; + buildInputs = [ + fontconfig + libX11 + libXinerama + zlib + libXft + ]; inherit patches; - postPatch = let - configFile = if lib.isDerivation conf || builtins.isPath conf then - conf - else - writeText "config.def.h" conf; - in '' - sed -ri -e 's!\<(dmenu|dmenu_path|stest)\>!'"$out/bin"'/&!g' dmenu_run - sed -ri -e 's!\!'"$out/bin"'/&!g' dmenu_path - ${lib.optionalString (conf != null) "cp ${configFile} config.def.h"} - ''; + postPatch = + let + configFile = + if lib.isDerivation conf || builtins.isPath conf then conf else writeText "config.def.h" conf; + in + '' + sed -ri -e 's!\<(dmenu|dmenu_path|stest)\>!'"$out/bin"'/&!g' dmenu_run + sed -ri -e 's!\!'"$out/bin"'/&!g' dmenu_path + ${lib.optionalString (conf != null) "cp ${configFile} config.def.h"} + ''; preConfigure = '' makeFlagsArray+=( @@ -41,11 +59,15 @@ stdenv.mkDerivation rec { passthru.updateScript = gitUpdater { url = "git://git.suckless.org/dmenu"; }; meta = with lib; { - description = - "Generic, highly customizable, and efficient menu for the X Window System"; + description = "Generic, highly customizable, and efficient menu for the X Window System"; homepage = "https://tools.suckless.org/dmenu"; license = licenses.mit; - maintainers = with maintainers; [ pSub globin qusic _0david0mp ]; + maintainers = with maintainers; [ + pSub + globin + qusic + _0david0mp + ]; platforms = platforms.all; mainProgram = "dmenu"; }; diff --git a/pkgs/applications/misc/dmenu/wayland.nix b/pkgs/applications/misc/dmenu/wayland.nix index 2e4e62acae6341..996aef30464dcc 100644 --- a/pkgs/applications/misc/dmenu/wayland.nix +++ b/pkgs/applications/misc/dmenu/wayland.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, cairo, pango, pkg-config, wayland-protocols -, glib, wayland, libxkbcommon, makeWrapper, wayland-scanner -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + cairo, + pango, + pkg-config, + wayland-protocols, + glib, + wayland, + libxkbcommon, + makeWrapper, + wayland-scanner, + fetchpatch, }: stdenv.mkDerivation rec { @@ -14,11 +27,27 @@ stdenv.mkDerivation rec { hash = "sha256-dqFvU2mRYEw7n8Fmbudwi5XMLQ7mQXFkug9D9j4FIrU="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson ninja pkg-config makeWrapper wayland-scanner ]; - buildInputs = [ cairo pango wayland-protocols glib wayland libxkbcommon ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + makeWrapper + wayland-scanner + ]; + buildInputs = [ + cairo + pango + wayland-protocols + glib + wayland + libxkbcommon + ]; patches = [ # can be removed when https://github.com/nyyManni/dmenu-wayland/pull/23 is included diff --git a/pkgs/applications/misc/dupeguru/default.nix b/pkgs/applications/misc/dupeguru/default.nix index 8ec9dfc35033bf..bab21335b1e8ee 100644 --- a/pkgs/applications/misc/dupeguru/default.nix +++ b/pkgs/applications/misc/dupeguru/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, python3Packages, gettext, qt5, fetchFromGitHub }: +{ + stdenv, + lib, + python3Packages, + gettext, + qt5, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "dupeguru"; diff --git a/pkgs/applications/misc/edgetx/default.nix b/pkgs/applications/misc/edgetx/default.nix index 36626903b4c8bc..e4b4e3f3b385c7 100644 --- a/pkgs/applications/misc/edgetx/default.nix +++ b/pkgs/applications/misc/edgetx/default.nix @@ -1,7 +1,16 @@ -{ lib, mkDerivation, fetchFromGitHub -, cmake, gcc-arm-embedded, python3Packages -, qtbase, qtmultimedia, qttools, SDL, gtest -, dfu-util +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + gcc-arm-embedded, + python3Packages, + qtbase, + qtmultimedia, + qttools, + SDL, + gtest, + dfu-util, }: mkDerivation rec { @@ -16,9 +25,18 @@ mkDerivation rec { hash = "sha256-bKMAyONy1Udd+2nDVEMrtIsnfqrNuBVMWU7nCqvZ+3E="; }; - nativeBuildInputs = [ cmake gcc-arm-embedded python3Packages.pillow qttools ]; + nativeBuildInputs = [ + cmake + gcc-arm-embedded + python3Packages.pillow + qttools + ]; - buildInputs = [ qtbase qtmultimedia SDL ]; + buildInputs = [ + qtbase + qtmultimedia + SDL + ]; postPatch = '' sed -i companion/src/burnconfigdialog.cpp \ @@ -42,8 +60,16 @@ mkDerivation rec { mainProgram = "companion" + lib.concatStrings (lib.take 2 (lib.splitVersion version)); homepage = "https://edgetx.org/"; license = licenses.gpl2Only; - platforms = [ "i686-linux" "x86_64-linux" "aarch64-linux" ]; - maintainers = with maintainers; [ elitak lopsided98 wucke13 ]; + platforms = [ + "i686-linux" + "x86_64-linux" + "aarch64-linux" + ]; + maintainers = with maintainers; [ + elitak + lopsided98 + wucke13 + ]; }; } diff --git a/pkgs/applications/misc/electrum/default.nix b/pkgs/applications/misc/electrum/default.nix index 6078c17f4cbb70..219046157cf8f9 100644 --- a/pkgs/applications/misc/electrum/default.nix +++ b/pkgs/applications/misc/electrum/default.nix @@ -1,26 +1,33 @@ -{ lib -, stdenv -, fetchurl -, protobuf -, wrapQtAppsHook -, python3 -, zbar -, secp256k1 -, enableQt ? true -, callPackage -, qtwayland +{ + lib, + stdenv, + fetchurl, + protobuf, + wrapQtAppsHook, + python3, + zbar, + secp256k1, + enableQt ? true, + callPackage, + qtwayland, }: let libsecp256k1_name = - if stdenv.hostPlatform.isLinux then "libsecp256k1.so.{v}" - else if stdenv.hostPlatform.isDarwin then "libsecp256k1.{v}.dylib" - else "libsecp256k1${stdenv.hostPlatform.extensions.sharedLibrary}"; + if stdenv.hostPlatform.isLinux then + "libsecp256k1.so.{v}" + else if stdenv.hostPlatform.isDarwin then + "libsecp256k1.{v}.dylib" + else + "libsecp256k1${stdenv.hostPlatform.extensions.sharedLibrary}"; libzbar_name = - if stdenv.hostPlatform.isLinux then "libzbar.so.0" - else if stdenv.hostPlatform.isDarwin then "libzbar.0.dylib" - else "libzbar${stdenv.hostPlatform.extensions.sharedLibrary}"; + if stdenv.hostPlatform.isLinux then + "libzbar.so.0" + else if stdenv.hostPlatform.isDarwin then + "libzbar.0.dylib" + else + "libzbar${stdenv.hostPlatform.extensions.sharedLibrary}"; in @@ -36,56 +43,68 @@ python3.pkgs.buildPythonApplication rec { build-system = [ protobuf ] ++ lib.optionals enableQt [ wrapQtAppsHook ]; buildInputs = lib.optional (stdenv.hostPlatform.isLinux && enableQt) qtwayland; - dependencies = with python3.pkgs; [ - aiohttp - aiohttp-socks - aiorpcx - attrs - bitstring - cryptography - dnspython - jsonrpclib-pelix - matplotlib - pbkdf2 - protobuf - pysocks - qrcode - requests - certifi - jsonpatch - # plugins - btchip-python - ledger-bitcoin - ckcc-protocol - keepkey - trezor - bitbox02 - cbor2 - pyserial - ] ++ lib.optionals enableQt [ - pyqt5 - qdarkstyle - ]; - - checkInputs = with python3.pkgs; lib.optionals enableQt [ - pyqt6 - ]; - - postPatch = '' - # make compatible with protobuf4 by easing dependencies ... - substituteInPlace ./contrib/requirements/requirements.txt \ - --replace "protobuf>=3.20,<4" "protobuf>=3.20" - # ... and regenerating the paymentrequest_pb2.py file - protoc --python_out=. electrum/paymentrequest.proto - - substituteInPlace ./electrum/ecc_fast.py \ - --replace ${libsecp256k1_name} ${secp256k1}/lib/libsecp256k1${stdenv.hostPlatform.extensions.sharedLibrary} - '' + (if enableQt then '' - substituteInPlace ./electrum/qrscanner.py \ - --replace ${libzbar_name} ${zbar.lib}/lib/libzbar${stdenv.hostPlatform.extensions.sharedLibrary} - '' else '' - sed -i '/qdarkstyle/d' contrib/requirements/requirements.txt - ''); + dependencies = + with python3.pkgs; + [ + aiohttp + aiohttp-socks + aiorpcx + attrs + bitstring + cryptography + dnspython + jsonrpclib-pelix + matplotlib + pbkdf2 + protobuf + pysocks + qrcode + requests + certifi + jsonpatch + # plugins + btchip-python + ledger-bitcoin + ckcc-protocol + keepkey + trezor + bitbox02 + cbor2 + pyserial + ] + ++ lib.optionals enableQt [ + pyqt5 + qdarkstyle + ]; + + checkInputs = + with python3.pkgs; + lib.optionals enableQt [ + pyqt6 + ]; + + postPatch = + '' + # make compatible with protobuf4 by easing dependencies ... + substituteInPlace ./contrib/requirements/requirements.txt \ + --replace "protobuf>=3.20,<4" "protobuf>=3.20" + # ... and regenerating the paymentrequest_pb2.py file + protoc --python_out=. electrum/paymentrequest.proto + + substituteInPlace ./electrum/ecc_fast.py \ + --replace ${libsecp256k1_name} ${secp256k1}/lib/libsecp256k1${stdenv.hostPlatform.extensions.sharedLibrary} + '' + + ( + if enableQt then + '' + substituteInPlace ./electrum/qrscanner.py \ + --replace ${libzbar_name} ${zbar.lib}/lib/libzbar${stdenv.hostPlatform.extensions.sharedLibrary} + '' + else + '' + sed -i '/qdarkstyle/d' contrib/requirements/requirements.txt + '' + ); postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' substituteInPlace $out/share/applications/electrum.desktop \ @@ -99,7 +118,11 @@ python3.pkgs.buildPythonApplication rec { wrapQtApp $out/bin/electrum ''; - nativeCheckInputs = with python3.pkgs; [ pytestCheckHook pyaes pycryptodomex ]; + nativeCheckInputs = with python3.pkgs; [ + pytestCheckHook + pyaes + pycryptodomex + ]; pytestFlagsArray = [ "tests" ]; @@ -122,7 +145,12 @@ python3.pkgs.buildPythonApplication rec { changelog = "https://github.com/spesmilo/electrum/blob/master/RELEASE-NOTES"; license = licenses.mit; platforms = platforms.all; - maintainers = with maintainers; [ joachifm np prusnak chewblacka ]; + maintainers = with maintainers; [ + joachifm + np + prusnak + chewblacka + ]; mainProgram = "electrum"; }; } diff --git a/pkgs/applications/misc/electrum/ltc.nix b/pkgs/applications/misc/electrum/ltc.nix index e0aaf139cd65e1..e2d1f54c63a9b7 100644 --- a/pkgs/applications/misc/electrum/ltc.nix +++ b/pkgs/applications/misc/electrum/ltc.nix @@ -1,27 +1,34 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitHub -, wrapQtAppsHook -, python3 -, zbar -, secp256k1 -, enableQt ? true -, qtwayland +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + wrapQtAppsHook, + python3, + zbar, + secp256k1, + enableQt ? true, + qtwayland, }: let version = "4.2.2.1"; libsecp256k1_name = - if stdenv.hostPlatform.isLinux then "libsecp256k1.so.0" - else if stdenv.hostPlatform.isDarwin then "libsecp256k1.0.dylib" - else "libsecp256k1${stdenv.hostPlatform.extensions.sharedLibrary}"; + if stdenv.hostPlatform.isLinux then + "libsecp256k1.so.0" + else if stdenv.hostPlatform.isDarwin then + "libsecp256k1.0.dylib" + else + "libsecp256k1${stdenv.hostPlatform.extensions.sharedLibrary}"; libzbar_name = - if stdenv.hostPlatform.isLinux then "libzbar.so.0" - else if stdenv.hostPlatform.isDarwin then "libzbar.0.dylib" - else "libzbar${stdenv.hostPlatform.extensions.sharedLibrary}"; + if stdenv.hostPlatform.isLinux then + "libzbar.so.0" + else if stdenv.hostPlatform.isDarwin then + "libzbar.0.dylib" + else + "libzbar${stdenv.hostPlatform.extensions.sharedLibrary}"; # Not provided in official source releases, which are what upstream signs. tests = fetchFromGitHub { @@ -54,32 +61,35 @@ python3.pkgs.buildPythonApplication { nativeBuildInputs = lib.optionals enableQt [ wrapQtAppsHook ]; - propagatedBuildInputs = with python3.pkgs; [ - aiohttp - aiohttp-socks - aiorpcx - attrs - bitstring - cryptography - dnspython - jsonrpclib-pelix - matplotlib - pbkdf2 - protobuf - py-scrypt - pysocks - qrcode - requests - certifi - # plugins - btchip-python - ckcc-protocol - keepkey - trezor - ] ++ lib.optionals enableQt [ - pyqt5 - qdarkstyle - ]; + propagatedBuildInputs = + with python3.pkgs; + [ + aiohttp + aiohttp-socks + aiorpcx + attrs + bitstring + cryptography + dnspython + jsonrpclib-pelix + matplotlib + pbkdf2 + protobuf + py-scrypt + pysocks + qrcode + requests + certifi + # plugins + btchip-python + ckcc-protocol + keepkey + trezor + ] + ++ lib.optionals enableQt [ + pyqt5 + qdarkstyle + ]; patches = [ # electrum-ltc attempts to pin to aiorpcX < 0.23, but nixpkgs @@ -101,16 +111,23 @@ python3.pkgs.buildPythonApplication { cp run_electrum electrum_ltc/electrum-ltc ''; - preBuild = '' - sed -i 's,usr_share = .*,usr_share = "'$out'/share",g' setup.py - substituteInPlace ./electrum_ltc/ecc_fast.py \ - --replace ${libsecp256k1_name} ${secp256k1}/lib/libsecp256k1${stdenv.hostPlatform.extensions.sharedLibrary} - '' + (if enableQt then '' - substituteInPlace ./electrum_ltc/qrscanner.py \ - --replace ${libzbar_name} ${zbar.lib}/lib/libzbar${stdenv.hostPlatform.extensions.sharedLibrary} - '' else '' - sed -i '/qdarkstyle/d' contrib/requirements/requirements.txt - ''); + preBuild = + '' + sed -i 's,usr_share = .*,usr_share = "'$out'/share",g' setup.py + substituteInPlace ./electrum_ltc/ecc_fast.py \ + --replace ${libsecp256k1_name} ${secp256k1}/lib/libsecp256k1${stdenv.hostPlatform.extensions.sharedLibrary} + '' + + ( + if enableQt then + '' + substituteInPlace ./electrum_ltc/qrscanner.py \ + --replace ${libzbar_name} ${zbar.lib}/lib/libzbar${stdenv.hostPlatform.extensions.sharedLibrary} + '' + else + '' + sed -i '/qdarkstyle/d' contrib/requirements/requirements.txt + '' + ); postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' # Despite setting usr_share above, these files are installed under @@ -130,14 +147,18 @@ python3.pkgs.buildPythonApplication { wrapQtApp $out/bin/electrum-ltc ''; - nativeCheckInputs = with python3.pkgs; [ pytestCheckHook pyaes pycryptodomex ]; + nativeCheckInputs = with python3.pkgs; [ + pytestCheckHook + pyaes + pycryptodomex + ]; buildInputs = lib.optional stdenv.hostPlatform.isLinux qtwayland; pytestFlagsArray = [ "electrum_ltc/tests" ]; disabledTests = [ - "test_loop" # test tries to bind 127.0.0.1 causing permission error - "test_is_ip_address" # fails spuriously https://github.com/spesmilo/electrum/issues/7307 + "test_loop" # test tries to bind 127.0.0.1 causing permission error + "test_is_ip_address" # fails spuriously https://github.com/spesmilo/electrum/issues/7307 # electrum_ltc.lnutil.RemoteMisbehaving: received commitment_signed without pending changes "test_reestablish_replay_messages_rev_then_sig" "test_reestablish_replay_messages_sig_then_rev" diff --git a/pkgs/applications/misc/electrum/update.nix b/pkgs/applications/misc/electrum/update.nix index 509a643780885a..e231757da9993b 100644 --- a/pkgs/applications/misc/electrum/update.nix +++ b/pkgs/applications/misc/electrum/update.nix @@ -1,14 +1,15 @@ -{ lib -, writeScript -, common-updater-scripts -, bash -, coreutils -, curl -, fetchurl -, gnugrep -, gnupg -, gnused -, nix +{ + lib, + writeScript, + common-updater-scripts, + bash, + coreutils, + curl, + fetchurl, + gnugrep, + gnupg, + gnused, + nix, }: let @@ -33,41 +34,43 @@ let in writeScript "update-electrum" '' -#! ${bash}/bin/bash + #! ${bash}/bin/bash -set -eu -o pipefail + set -eu -o pipefail -export PATH=${lib.makeBinPath [ - common-updater-scripts - coreutils - curl - gnugrep - gnupg - gnused - nix -]} + export PATH=${ + lib.makeBinPath [ + common-updater-scripts + coreutils + curl + gnugrep + gnupg + gnused + nix + ] + } -version=$(curl -L --list-only -- '${downloadPageUrl}' \ - | grep -Po '
src/huggle_core/version.txt @@ -42,7 +51,8 @@ stdenv.mkDerivation rec { cmakeBuildType = "None"; cmakeFlags = [ - "-S" "/build/source/src" + "-S" + "/build/source/src" "-DINSTALL_DATA_DIR=bin" "-DQT5_BUILD=ON" "-DWEB_ENGINE=ON" diff --git a/pkgs/applications/misc/ikiwiki/default.nix b/pkgs/applications/misc/ikiwiki/default.nix index 49798c843231c5..ef866eb7b54142 100644 --- a/pkgs/applications/misc/ikiwiki/default.nix +++ b/pkgs/applications/misc/ikiwiki/default.nix @@ -1,12 +1,31 @@ -{ lib, stdenv, fetchurl, fetchpatch, perlPackages, gettext, makeWrapper, ImageMagick, which, highlight -, gitSupport ? false, git -, docutilsSupport ? false, python, docutils -, monotoneSupport ? false, monotone -, bazaarSupport ? false, breezy -, cvsSupport ? false, cvs, cvsps -, subversionSupport ? false, subversion -, mercurialSupport ? false, mercurial -, extraUtils ? [] +{ + lib, + stdenv, + fetchurl, + fetchpatch, + perlPackages, + gettext, + makeWrapper, + ImageMagick, + which, + highlight, + gitSupport ? false, + git, + docutilsSupport ? false, + python, + docutils, + monotoneSupport ? false, + monotone, + bazaarSupport ? false, + breezy, + cvsSupport ? false, + cvs, + cvsps, + subversionSupport ? false, + subversion, + mercurialSupport ? false, + mercurial, + extraUtils ? [ ], }: stdenv.mkDerivation rec { @@ -19,21 +38,49 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ which highlight ] - ++ (with perlPackages; [ perl TextMarkdown URI HTMLParser HTMLScrubber HTMLTemplate - TimeDate gettext DBFile CGISession CGIFormBuilder LocaleGettext - RpcXML XMLSimple ImageMagick YAML YAMLLibYAML HTMLTree AuthenPassphrase - NetOpenIDConsumer LWPxParanoidAgent CryptSSLeay ]) + buildInputs = + [ + which + highlight + ] + ++ (with perlPackages; [ + perl + TextMarkdown + URI + HTMLParser + HTMLScrubber + HTMLTemplate + TimeDate + gettext + DBFile + CGISession + CGIFormBuilder + LocaleGettext + RpcXML + XMLSimple + ImageMagick + YAML + YAMLLibYAML + HTMLTree + AuthenPassphrase + NetOpenIDConsumer + LWPxParanoidAgent + CryptSSLeay + ]) ++ lib.optionals docutilsSupport [ - (python.withPackages (pp: with pp; [ pygments ])) - docutils - ] - ++ lib.optionals gitSupport [git] - ++ lib.optionals monotoneSupport [monotone] - ++ lib.optionals bazaarSupport [breezy] - ++ lib.optionals cvsSupport [cvs cvsps perlPackages.Filechdir] - ++ lib.optionals subversionSupport [subversion] - ++ lib.optionals mercurialSupport [mercurial]; + (python.withPackages (pp: with pp; [ pygments ])) + docutils + ] + ++ lib.optionals gitSupport [ git ] + ++ lib.optionals monotoneSupport [ monotone ] + ++ lib.optionals bazaarSupport [ breezy ] + ++ lib.optionals cvsSupport [ + cvs + cvsps + perlPackages.Filechdir + ] + ++ lib.optionals subversionSupport [ subversion ] + ++ lib.optionals mercurialSupport [ mercurial ]; patches = [ # A few markdown tests fail, but this is expected when using Text::Markdown diff --git a/pkgs/applications/misc/inherd-quake/default.nix b/pkgs/applications/misc/inherd-quake/default.nix index c71dae3b27e1b6..5cd38ca8cc08f7 100644 --- a/pkgs/applications/misc/inherd-quake/default.nix +++ b/pkgs/applications/misc/inherd-quake/default.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, openssl -, stdenv -, CoreServices -, Security +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + stdenv, + CoreServices, + Security, }: rustPlatform.buildRustPackage rec { @@ -23,12 +24,14 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreServices - Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + Security + ]; meta = with lib; { description = "Knowledge management meta-framework for geeks"; diff --git a/pkgs/applications/misc/inkcut/default.nix b/pkgs/applications/misc/inkcut/default.nix index b711fd9330dc51..b23d544071acc2 100644 --- a/pkgs/applications/misc/inkcut/default.nix +++ b/pkgs/applications/misc/inkcut/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchpatch -, python3 -, fetchFromGitHub -, wrapQtAppsHook -, cups +{ + lib, + fetchpatch, + python3, + fetchFromGitHub, + wrapQtAppsHook, + cups, }: python3.pkgs.buildPythonApplication rec { @@ -75,7 +76,11 @@ python3.pkgs.buildPythonApplication rec { ]; dontWrapQtApps = true; - makeWrapperArgs = [ "--unset" "PYTHONPATH" "\${qtWrapperArgs[@]}" ]; + makeWrapperArgs = [ + "--unset" + "PYTHONPATH" + "\${qtWrapperArgs[@]}" + ]; postInstall = '' mkdir -p $out/share/inkscape/extensions diff --git a/pkgs/applications/misc/inlyne/default.nix b/pkgs/applications/misc/inlyne/default.nix index 9f10136042293d..904f4df67646df 100644 --- a/pkgs/applications/misc/inlyne/default.nix +++ b/pkgs/applications/misc/inlyne/default.nix @@ -1,16 +1,17 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv -, pkg-config -, fontconfig -, xorg -, libxkbcommon -, wayland -, libGL -, openssl -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + pkg-config, + fontconfig, + xorg, + libxkbcommon, + wayland, + libGL, + openssl, + darwin, }: rustPlatform.buildRustPackage rec { @@ -26,24 +27,28 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-fMovzaP+R0CUwJy1HKATH2tPrIPwzGtubF1WHUoQDRY="; - nativeBuildInputs = [ - installShellFiles - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - pkg-config - ]; + nativeBuildInputs = + [ + installShellFiles + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + pkg-config + ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - fontconfig - xorg.libXcursor - xorg.libXi - xorg.libXrandr - xorg.libxcb - wayland - libxkbcommon - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk_11_0.frameworks.AppKit - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + fontconfig + xorg.libXcursor + xorg.libXi + xorg.libXrandr + xorg.libxcb + wayland + libxkbcommon + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk_11_0.frameworks.AppKit + ]; checkFlags = lib.optionals stdenv.hostPlatform.isDarwin [ # time out on darwin @@ -60,7 +65,12 @@ rustPlatform.buildRustPackage rec { postFixup = lib.optionalString stdenv.hostPlatform.isLinux '' patchelf $out/bin/inlyne \ - --add-rpath ${lib.makeLibraryPath [ libGL xorg.libX11 ]} + --add-rpath ${ + lib.makeLibraryPath [ + libGL + xorg.libX11 + ] + } ''; meta = with lib; { diff --git a/pkgs/applications/misc/input-leap/default.nix b/pkgs/applications/misc/input-leap/default.nix index a826afefc63a73..fc43fe749fea6d 100644 --- a/pkgs/applications/misc/input-leap/default.nix +++ b/pkgs/applications/misc/input-leap/default.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, -, withLibei ? true + withLibei ? true, -, avahi -, curl -, libICE -, libSM -, libX11 -, libXdmcp -, libXext -, libXinerama -, libXrandr -, libXtst -, libei -, libportal -, openssl -, pkg-config -, qtbase -, qttools -, wrapGAppsHook3 -, wrapQtAppsHook + avahi, + curl, + libICE, + libSM, + libX11, + libXdmcp, + libXext, + libXinerama, + libXrandr, + libXtst, + libei, + libportal, + openssl, + pkg-config, + qtbase, + qttools, + wrapGAppsHook3, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -37,11 +38,31 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ pkg-config cmake wrapGAppsHook3 wrapQtAppsHook qttools ]; - buildInputs = [ - curl qtbase avahi - libX11 libXext libXtst libXinerama libXrandr libXdmcp libICE libSM - ] ++ lib.optionals withLibei [ libei libportal ]; + nativeBuildInputs = [ + pkg-config + cmake + wrapGAppsHook3 + wrapQtAppsHook + qttools + ]; + buildInputs = + [ + curl + qtbase + avahi + libX11 + libXext + libXtst + libXinerama + libXrandr + libXdmcp + libICE + libSM + ] + ++ lib.optionals withLibei [ + libei + libportal + ]; cmakeFlags = [ "-DINPUTLEAP_REVISION=${builtins.substring 0 8 src.rev}" @@ -72,7 +93,12 @@ stdenv.mkDerivation rec { ''; homepage = "https://github.com/input-leap/input-leap"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ kovirobi phryneas twey shymega ]; + maintainers = with lib.maintainers; [ + kovirobi + phryneas + twey + shymega + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/applications/misc/johnny-reborn/default.nix b/pkgs/applications/misc/johnny-reborn/default.nix index 4ad2328feda85b..7b3630654933c3 100644 --- a/pkgs/applications/misc/johnny-reborn/default.nix +++ b/pkgs/applications/misc/johnny-reborn/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL2 +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/misc/johnny-reborn/with-data.nix b/pkgs/applications/misc/johnny-reborn/with-data.nix index 1e669658186f1c..a316dae27f860d 100644 --- a/pkgs/applications/misc/johnny-reborn/with-data.nix +++ b/pkgs/applications/misc/johnny-reborn/with-data.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, fetchzip -, johnny-reborn-engine -, makeWrapper +{ + lib, + stdenvNoCC, + fetchFromGitHub, + fetchzip, + johnny-reborn-engine, + makeWrapper, }: let @@ -26,7 +27,10 @@ stdenvNoCC.mkDerivation { pname = "johnny-reborn"; inherit (johnny-reborn-engine) version; - srcs = [ sounds resources ]; + srcs = [ + sounds + resources + ]; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/applications/misc/k4dirstat/default.nix b/pkgs/applications/misc/k4dirstat/default.nix index 55e0de4d552460..0894b4b08b692a 100644 --- a/pkgs/applications/misc/k4dirstat/default.nix +++ b/pkgs/applications/misc/k4dirstat/default.nix @@ -1,13 +1,14 @@ -{ mkDerivation -, extra-cmake-modules -, fetchFromGitHub -, kiconthemes -, kio -, kjobwidgets -, kxmlgui -, lib -, testers -, k4dirstat +{ + mkDerivation, + extra-cmake-modules, + fetchFromGitHub, + kiconthemes, + kio, + kjobwidgets, + kxmlgui, + lib, + testers, + k4dirstat, }: mkDerivation rec { @@ -22,13 +23,17 @@ mkDerivation rec { }; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ kiconthemes kio kjobwidgets kxmlgui ]; + buildInputs = [ + kiconthemes + kio + kjobwidgets + kxmlgui + ]; - passthru.tests.version = - testers.testVersion { - package = k4dirstat; - command = "k4dirstat -platform offscreen --version &>/dev/stdout"; - }; + passthru.tests.version = testers.testVersion { + package = k4dirstat; + command = "k4dirstat -platform offscreen --version &>/dev/stdout"; + }; meta = with lib; { homepage = "https://github.com/jeromerobert/k4dirstat"; diff --git a/pkgs/applications/misc/kapow/default.nix b/pkgs/applications/misc/kapow/default.nix index db352199408cfe..d2eef8279c3aa9 100644 --- a/pkgs/applications/misc/kapow/default.nix +++ b/pkgs/applications/misc/kapow/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, qmake, fetchFromGitHub, qtbase, qttools, wrapQtAppsHook }: +{ + lib, + stdenv, + qmake, + fetchFromGitHub, + qtbase, + qttools, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "kapow"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { sha256 = "1fz9fb4w21ax8hjs6dwfn2410ig4lqvzdlijq0jcj3jbgxd4i1gw"; }; - nativeBuildInputs = [ qmake qttools wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + qttools + wrapQtAppsHook + ]; buildInputs = [ qtbase ]; diff --git a/pkgs/applications/misc/kchmviewer/default.nix b/pkgs/applications/misc/kchmviewer/default.nix index 83d077f8279551..f3ecbdf87e3760 100644 --- a/pkgs/applications/misc/kchmviewer/default.nix +++ b/pkgs/applications/misc/kchmviewer/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, qmake, wrapQtAppsHook, chmlib, libzip, qtwebengine }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + qmake, + wrapQtAppsHook, + chmlib, + libzip, + qtwebengine, +}: stdenv.mkDerivation rec { pname = "kchmviewer"; @@ -28,9 +38,16 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ chmlib libzip qtwebengine ]; + buildInputs = [ + chmlib + libzip + qtwebengine + ]; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; postInstall = '' install -Dm755 bin/kchmviewer -t $out/bin diff --git a/pkgs/applications/misc/keepassxc/default.nix b/pkgs/applications/misc/keepassxc/default.nix index 941c658fea71ba..e563e84a345df8 100644 --- a/pkgs/applications/misc/keepassxc/default.nix +++ b/pkgs/applications/misc/keepassxc/default.nix @@ -1,44 +1,45 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, qttools - -, asciidoctor -, botan3 -, curl -, kio -, libXi -, libXtst -, libargon2 -, libusb1 -, minizip -, pcsclite -, pkg-config -, qrencode -, qtbase -, qtmacextras -, qtsvg -, qtx11extras -, readline -, wrapGAppsHook3 -, wrapQtAppsHook -, zlib - -, LocalAuthentication - -, withKeePassBrowser ? true -, withKeePassBrowserPasskeys ? true -, withKeePassFDOSecrets ? true -, withKeePassKeeShare ? true -, withKeePassNetworking ? true -, withKeePassSSHAgent ? true -, withKeePassTouchID ? true -, withKeePassX11 ? true -, withKeePassYubiKey ? true - -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + qttools, + + asciidoctor, + botan3, + curl, + kio, + libXi, + libXtst, + libargon2, + libusb1, + minizip, + pcsclite, + pkg-config, + qrencode, + qtbase, + qtmacextras, + qtsvg, + qtx11extras, + readline, + wrapGAppsHook3, + wrapQtAppsHook, + zlib, + + LocalAuthentication, + + withKeePassBrowser ? true, + withKeePassBrowserPasskeys ? true, + withKeePassFDOSecrets ? true, + withKeePassKeeShare ? true, + withKeePassNetworking ? true, + withKeePassSSHAgent ? true, + withKeePassTouchID ? true, + withKeePassX11 ? true, + withKeePassYubiKey ? true, + + nixosTests, }: stdenv.mkDerivation rec { @@ -70,19 +71,20 @@ stdenv.mkDerivation rec { }) ]; - cmakeFlags = [ - "-DKEEPASSXC_BUILD_TYPE=Release" - "-DWITH_GUI_TESTS=ON" - "-DWITH_XC_UPDATECHECK=OFF" - ] - ++ (lib.optional (!withKeePassX11) "-DWITH_XC_X11=OFF") - ++ (lib.optional (withKeePassFDOSecrets && stdenv.hostPlatform.isLinux) "-DWITH_XC_FDOSECRETS=ON") - ++ (lib.optional (withKeePassYubiKey && stdenv.hostPlatform.isLinux) "-DWITH_XC_YUBIKEY=ON") - ++ (lib.optional withKeePassBrowser "-DWITH_XC_BROWSER=ON") - ++ (lib.optional withKeePassBrowserPasskeys "-DWITH_XC_BROWSER_PASSKEYS=ON") - ++ (lib.optional withKeePassKeeShare "-DWITH_XC_KEESHARE=ON") - ++ (lib.optional withKeePassNetworking "-DWITH_XC_NETWORKING=ON") - ++ (lib.optional withKeePassSSHAgent "-DWITH_XC_SSHAGENT=ON"); + cmakeFlags = + [ + "-DKEEPASSXC_BUILD_TYPE=Release" + "-DWITH_GUI_TESTS=ON" + "-DWITH_XC_UPDATECHECK=OFF" + ] + ++ (lib.optional (!withKeePassX11) "-DWITH_XC_X11=OFF") + ++ (lib.optional (withKeePassFDOSecrets && stdenv.hostPlatform.isLinux) "-DWITH_XC_FDOSECRETS=ON") + ++ (lib.optional (withKeePassYubiKey && stdenv.hostPlatform.isLinux) "-DWITH_XC_YUBIKEY=ON") + ++ (lib.optional withKeePassBrowser "-DWITH_XC_BROWSER=ON") + ++ (lib.optional withKeePassBrowserPasskeys "-DWITH_XC_BROWSER_PASSKEYS=ON") + ++ (lib.optional withKeePassKeeShare "-DWITH_XC_KEESHARE=ON") + ++ (lib.optional withKeePassNetworking "-DWITH_XC_NETWORKING=ON") + ++ (lib.optional withKeePassSSHAgent "-DWITH_XC_SSHAGENT=ON"); doCheck = true; checkPhase = '' @@ -104,15 +106,16 @@ stdenv.mkDerivation rec { wrapQtAppsHook qttools pkg-config - ] - ++ lib.optional (!stdenv.hostPlatform.isDarwin) wrapGAppsHook3; + ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) wrapGAppsHook3; dontWrapGApps = true; - preFixup = '' - qtWrapperArgs+=("''${gappsWrapperArgs[@]}") - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - wrapQtApp "$out/Applications/KeePassXC.app/Contents/MacOS/KeePassXC" - ''; + preFixup = + '' + qtWrapperArgs+=("''${gappsWrapperArgs[@]}") + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + wrapQtApp "$out/Applications/KeePassXC.app/Contents/MacOS/KeePassXC" + ''; # See https://github.com/keepassxreboot/keepassxc/blob/cd7a53abbbb81e468efb33eb56eefc12739969b8/src/browser/NativeMessageInstaller.cpp#L317 postInstall = lib.optionalString withKeePassBrowser '' @@ -120,25 +123,26 @@ stdenv.mkDerivation rec { substituteAll "${./firefox-native-messaging-host.json}" "$out/lib/mozilla/native-messaging-hosts/org.keepassxc.keepassxc_browser.json" ''; - buildInputs = [ - curl - botan3 - kio - libXi - libXtst - libargon2 - minizip - pcsclite - qrencode - qtbase - qtsvg - readline - zlib - ] - ++ lib.optional (stdenv.hostPlatform.isDarwin && withKeePassTouchID) LocalAuthentication - ++ lib.optional stdenv.hostPlatform.isDarwin qtmacextras - ++ lib.optional stdenv.hostPlatform.isLinux libusb1 - ++ lib.optional withKeePassX11 qtx11extras; + buildInputs = + [ + curl + botan3 + kio + libXi + libXtst + libargon2 + minizip + pcsclite + qrencode + qtbase + qtsvg + readline + zlib + ] + ++ lib.optional (stdenv.hostPlatform.isDarwin && withKeePassTouchID) LocalAuthentication + ++ lib.optional stdenv.hostPlatform.isDarwin qtmacextras + ++ lib.optional stdenv.hostPlatform.isLinux libusb1 + ++ lib.optional withKeePassX11 qtx11extras; passthru.tests = nixosTests.keepassxc; @@ -154,7 +158,10 @@ stdenv.mkDerivation rec { homepage = "https://keepassxc.org/"; license = licenses.gpl2Plus; mainProgram = "keepassxc"; - maintainers = with maintainers; [ blankparticle sigmasquadron ]; + maintainers = with maintainers; [ + blankparticle + sigmasquadron + ]; platforms = platforms.linux ++ platforms.darwin; }; } diff --git a/pkgs/applications/misc/keystore-explorer/default.nix b/pkgs/applications/misc/keystore-explorer/default.nix index d5576ccb725e70..aa37f5cfe689c5 100644 --- a/pkgs/applications/misc/keystore-explorer/default.nix +++ b/pkgs/applications/misc/keystore-explorer/default.nix @@ -1,10 +1,20 @@ -{ fetchzip, lib, stdenv, jdk, runtimeShell, glib, wrapGAppsHook3 }: +{ + fetchzip, + lib, + stdenv, + jdk, + runtimeShell, + glib, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { version = "5.5.3"; pname = "keystore-explorer"; src = fetchzip { - url = "https://github.com/kaikramer/keystore-explorer/releases/download/v${version}/kse-${lib.replaceStrings ["."] [""] version}.zip"; + url = "https://github.com/kaikramer/keystore-explorer/releases/download/v${version}/kse-${ + lib.replaceStrings [ "." ] [ "" ] version + }.zip"; sha256 = "sha256-oShVfmien4HMpAfSa9rPr18wLu7RN8ZWEZEUtiBHyBs="; }; diff --git a/pkgs/applications/misc/kiwix/default.nix b/pkgs/applications/misc/kiwix/default.nix index 3b9d4f83f5743c..2c9eafb16c11fc 100644 --- a/pkgs/applications/misc/kiwix/default.nix +++ b/pkgs/applications/misc/kiwix/default.nix @@ -1,12 +1,15 @@ -{ lib, mkDerivation, fetchFromGitHub -, libkiwix -, pkg-config -, qmake -, qtbase -, qtwebengine -, qtsvg -, qtimageformats -, aria2 +{ + lib, + mkDerivation, + fetchFromGitHub, + libkiwix, + pkg-config, + qmake, + qtbase, + qtwebengine, + qtsvg, + qtimageformats, + aria2, }: mkDerivation { diff --git a/pkgs/applications/misc/kiwix/lib.nix b/pkgs/applications/misc/kiwix/lib.nix index 0fb33b6b0a9b10..dfaddd3212afdd 100644 --- a/pkgs/applications/misc/kiwix/lib.nix +++ b/pkgs/applications/misc/kiwix/lib.nix @@ -1,14 +1,19 @@ -{ lib, stdenv, fetchFromGitHub -, meson, ninja, pkg-config -, python3 -, curl -, icu -, libzim -, pugixml -, zlib -, libmicrohttpd -, mustache-hpp -, gtest +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + python3, + curl, + icu, + libzim, + pugixml, + zlib, + libmicrohttpd, + mustache-hpp, + gtest, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/misc/kiwix/tools.nix b/pkgs/applications/misc/kiwix/tools.nix index bc2ea83d1480e4..e8564a7ff77b19 100644 --- a/pkgs/applications/misc/kiwix/tools.nix +++ b/pkgs/applications/misc/kiwix/tools.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, gitUpdater -, icu -, libkiwix -, meson -, ninja -, pkg-config -, stdenv +{ + lib, + fetchFromGitHub, + gitUpdater, + icu, + libkiwix, + meson, + ninja, + pkg-config, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/misc/kjv/default.nix b/pkgs/applications/misc/kjv/default.nix index 6408168d67838e..0bd8f52d0a3b0f 100644 --- a/pkgs/applications/misc/kjv/default.nix +++ b/pkgs/applications/misc/kjv/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, readline }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + readline, +}: let patchPrefix = "https://web.archive.org/web/20220422205751/https://github.com/samuelgrf/kjv/commit/"; @@ -25,7 +31,10 @@ stdenv.mkDerivation { hash = "sha256-Z6myd9Xn23pYizG+IZVDrP988pYU06QIcpqXtWTcPiw="; }; - patches = [ add-apocrypha add-install-target ]; + patches = [ + add-apocrypha + add-install-target + ]; buildInputs = [ readline ]; @@ -35,7 +44,10 @@ stdenv.mkDerivation { description = "Bible, King James Version"; homepage = "https://github.com/bontibon/kjv"; license = licenses.unlicense; - maintainers = with maintainers; [ jtobin cafkafk ]; + maintainers = with maintainers; [ + jtobin + cafkafk + ]; mainProgram = "kjv"; }; } diff --git a/pkgs/applications/misc/kjv/lukesmithxyz-kjv.nix b/pkgs/applications/misc/kjv/lukesmithxyz-kjv.nix index 27a1a90502845c..8e08295a58e372 100644 --- a/pkgs/applications/misc/kjv/lukesmithxyz-kjv.nix +++ b/pkgs/applications/misc/kjv/lukesmithxyz-kjv.nix @@ -1,7 +1,8 @@ -{ lib -, gawk -, stdenv -, fetchFromGitHub +{ + lib, + gawk, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/misc/klipper-estimator/default.nix b/pkgs/applications/misc/klipper-estimator/default.nix index e7a511769a8eb9..a577bb30f64624 100644 --- a/pkgs/applications/misc/klipper-estimator/default.nix +++ b/pkgs/applications/misc/klipper-estimator/default.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, stdenv -, rustPlatform -, pkg-config -, openssl -, libgit2 -, Security -, SystemConfiguration +{ + lib, + fetchFromGitHub, + stdenv, + rustPlatform, + pkg-config, + openssl, + libgit2, + Security, + SystemConfiguration, }: rustPlatform.buildRustPackage rec { @@ -24,7 +25,11 @@ rustPlatform.buildRustPackage rec { buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libgit2 Security SystemConfiguration ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libgit2 + Security + SystemConfiguration + ]; nativeBuildInputs = [ pkg-config ]; diff --git a/pkgs/applications/misc/krename/default.nix b/pkgs/applications/misc/krename/default.nix index a5f09789fc404c..58e81790e68317 100644 --- a/pkgs/applications/misc/krename/default.nix +++ b/pkgs/applications/misc/krename/default.nix @@ -1,15 +1,26 @@ { - mkDerivation, fetchurl, fetchpatch, lib, - extra-cmake-modules, kdoctools, wrapGAppsHook3, - kconfig, kinit, kjsembed, taglib, exiv2, podofo, - kcrash + mkDerivation, + fetchurl, + fetchpatch, + lib, + extra-cmake-modules, + kdoctools, + wrapGAppsHook3, + kconfig, + kinit, + kjsembed, + taglib, + exiv2, + podofo, + kcrash, }: let pname = "krename"; version = "5.0.2"; -in mkDerivation rec { +in +mkDerivation rec { name = "${pname}-${version}"; src = fetchurl { @@ -25,11 +36,24 @@ in mkDerivation rec { }) ]; - buildInputs = [ taglib exiv2 podofo ]; + buildInputs = [ + taglib + exiv2 + podofo + ]; - nativeBuildInputs = [ extra-cmake-modules kdoctools wrapGAppsHook3 ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wrapGAppsHook3 + ]; - propagatedBuildInputs = [ kconfig kcrash kinit kjsembed ]; + propagatedBuildInputs = [ + kconfig + kcrash + kinit + kjsembed + ]; NIX_LDFLAGS = "-ltag"; diff --git a/pkgs/applications/misc/ksmoothdock/default.nix b/pkgs/applications/misc/ksmoothdock/default.nix index 41a7c438750195..526ee7eafd96ec 100644 --- a/pkgs/applications/misc/ksmoothdock/default.nix +++ b/pkgs/applications/misc/ksmoothdock/default.nix @@ -1,10 +1,11 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, cmake -, extra-cmake-modules -, kactivities -, qtbase +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + extra-cmake-modules, + kactivities, + qtbase, }: mkDerivation rec { @@ -24,9 +25,15 @@ mkDerivation rec { substituteInPlace src/CMakeLists.txt --replace "-Werror" "" ''; - nativeBuildInputs = [ cmake extra-cmake-modules ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; - buildInputs = [ kactivities qtbase ]; + buildInputs = [ + kactivities + qtbase + ]; cmakeDir = "../src"; diff --git a/pkgs/applications/misc/kup/default.nix b/pkgs/applications/misc/kup/default.nix index 3ac622b11ff505..2ee5e5e7aaa652 100644 --- a/pkgs/applications/misc/kup/default.nix +++ b/pkgs/applications/misc/kup/default.nix @@ -1,4 +1,5 @@ -{ lib, +{ + lib, stdenv, fetchFromGitLab, extra-cmake-modules, @@ -15,7 +16,7 @@ kinit, kjobwidgets, plasma-framework, - libgit2 + libgit2, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/misc/latte-dock/default.nix b/pkgs/applications/misc/latte-dock/default.nix index a870a7fec3b014..4337fb4c85bb08 100644 --- a/pkgs/applications/misc/latte-dock/default.nix +++ b/pkgs/applications/misc/latte-dock/default.nix @@ -1,8 +1,22 @@ -{ lib, mkDerivation, fetchFromGitLab -, cmake, extra-cmake-modules, karchive, kwindowsystem, qtx11extras, kcrash -, knewstuff, wayland-scanner -, plasma-framework, plasma-wayland-protocols, plasma-workspace, plasma-desktop, qtwayland -, wayland, xorg +{ + lib, + mkDerivation, + fetchFromGitLab, + cmake, + extra-cmake-modules, + karchive, + kwindowsystem, + qtx11extras, + kcrash, + knewstuff, + wayland-scanner, + plasma-framework, + plasma-wayland-protocols, + plasma-workspace, + plasma-desktop, + qtwayland, + wayland, + xorg, }: mkDerivation rec { @@ -17,10 +31,28 @@ mkDerivation rec { sha256 = "sha256-C1FvgkdxCzny+F6igS2YjsHOpkK34wl6je2tHlGQwU0="; }; - buildInputs = [ plasma-framework plasma-wayland-protocols qtwayland xorg.libpthreadstubs xorg.libXdmcp xorg.libSM wayland plasma-workspace plasma-desktop ]; + buildInputs = [ + plasma-framework + plasma-wayland-protocols + qtwayland + xorg.libpthreadstubs + xorg.libXdmcp + xorg.libSM + wayland + plasma-workspace + plasma-desktop + ]; - nativeBuildInputs = [ extra-cmake-modules cmake karchive kwindowsystem - qtx11extras kcrash knewstuff wayland-scanner ]; + nativeBuildInputs = [ + extra-cmake-modules + cmake + karchive + kwindowsystem + qtx11extras + kcrash + knewstuff + wayland-scanner + ]; patches = [ ./0001-Disable-autostart.patch @@ -40,5 +72,4 @@ mkDerivation rec { maintainers = [ maintainers.ysndr ]; }; - } diff --git a/pkgs/applications/misc/librecad/default.nix b/pkgs/applications/misc/librecad/default.nix index ae1f5c9813ac65..7d41c040db8e2b 100644 --- a/pkgs/applications/misc/librecad/default.nix +++ b/pkgs/applications/misc/librecad/default.nix @@ -1,15 +1,16 @@ -{ lib -, boost -, fetchFromGitHub -, installShellFiles -, mkDerivation -, muparser -, pkg-config -, qmake -, qtbase -, qtsvg -, qttools -, runtimeShell +{ + lib, + boost, + fetchFromGitHub, + installShellFiles, + mkDerivation, + muparser, + pkg-config, + qmake, + qtbase, + qtsvg, + qttools, + runtimeShell, }: mkDerivation rec { @@ -50,7 +51,6 @@ mkDerivation rec { --replace __DATE__ 0 ''; - installPhase = '' runHook preInstall diff --git a/pkgs/applications/misc/lutris/default.nix b/pkgs/applications/misc/lutris/default.nix index 5b44dde5dac86b..27b05e427b138f 100644 --- a/pkgs/applications/misc/lutris/default.nix +++ b/pkgs/applications/misc/lutris/default.nix @@ -1,55 +1,56 @@ -{ buildPythonApplication -, lib -, fetchFromGitHub +{ + buildPythonApplication, + lib, + fetchFromGitHub, # build inputs -, atk -, file -, gdk-pixbuf -, glib-networking -, gnome-desktop -, gobject-introspection -, gst_all_1 -, gtk3 -, libnotify -, pango -, webkitgtk_4_0 -, wrapGAppsHook3 + atk, + file, + gdk-pixbuf, + glib-networking, + gnome-desktop, + gobject-introspection, + gst_all_1, + gtk3, + libnotify, + pango, + webkitgtk_4_0, + wrapGAppsHook3, # check inputs -, xvfb-run -, nose2 -, flake8 + xvfb-run, + nose2, + flake8, # python dependencies -, certifi -, dbus-python -, distro -, evdev -, lxml -, pillow -, pygobject3 -, pypresence -, pyyaml -, requests -, protobuf -, moddb + certifi, + dbus-python, + distro, + evdev, + lxml, + pillow, + pygobject3, + pypresence, + pyyaml, + requests, + protobuf, + moddb, # commands that lutris needs -, xrandr -, pciutils -, psmisc -, mesa-demos -, vulkan-tools -, xboxdrv -, pulseaudio -, p7zip -, xgamma -, libstrangle -, fluidsynth -, xorgserver -, xorg -, util-linux + xrandr, + pciutils, + psmisc, + mesa-demos, + vulkan-tools, + xboxdrv, + pulseaudio, + p7zip, + xgamma, + libstrangle, + fluidsynth, + xorgserver, + xorg, + util-linux, }: let @@ -84,24 +85,29 @@ buildPythonApplication rec { hash = "sha256-dI5hqWBWrOGYUEM9Mfm7bTh7BEc4e+T9gJeiZ3BiqmE="; }; - nativeBuildInputs = [ wrapGAppsHook3 gobject-introspection ]; - buildInputs = [ - atk - gdk-pixbuf - glib-networking - gnome-desktop - gtk3 - libnotify - pango - webkitgtk_4_0 - ] ++ (with gst_all_1; [ - gst-libav - gst-plugins-bad - gst-plugins-base - gst-plugins-good - gst-plugins-ugly - gstreamer - ]); + nativeBuildInputs = [ + wrapGAppsHook3 + gobject-introspection + ]; + buildInputs = + [ + atk + gdk-pixbuf + glib-networking + gnome-desktop + gtk3 + libnotify + pango + webkitgtk_4_0 + ] + ++ (with gst_all_1; [ + gst-libav + gst-plugins-bad + gst-plugins-base + gst-plugins-good + gst-plugins-ugly + gstreamer + ]); # See `install_requires` in https://github.com/lutris/lutris/blob/master/setup.py propagatedBuildInputs = [ @@ -124,7 +130,11 @@ buildPythonApplication rec { --replace '"libmagic.so.1"' "'${lib.getLib file}/lib/libmagic.so.1'" ''; - nativeCheckInputs = [ xvfb-run nose2 flake8 ] ++ requiredTools; + nativeCheckInputs = [ + xvfb-run + nose2 + flake8 + ] ++ requiredTools; checkPhase = '' runHook preCheck @@ -146,7 +156,10 @@ buildPythonApplication rec { homepage = "https://lutris.net"; description = "Open Source gaming platform for GNU/Linux"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ Madouura rapiteanu ]; + maintainers = with maintainers; [ + Madouura + rapiteanu + ]; platforms = platforms.linux; mainProgram = "lutris"; }; diff --git a/pkgs/applications/misc/lutris/fhsenv.nix b/pkgs/applications/misc/lutris/fhsenv.nix index 56a23a42ae63d0..770ae39bd0d511 100644 --- a/pkgs/applications/misc/lutris/fhsenv.nix +++ b/pkgs/applications/misc/lutris/fhsenv.nix @@ -1,29 +1,64 @@ -{ lib, buildFHSEnv, lutris-unwrapped -, extraPkgs ? pkgs: [ ] -, extraLibraries ? pkgs: [ ] -, steamSupport ? true +{ + lib, + buildFHSEnv, + lutris-unwrapped, + extraPkgs ? pkgs: [ ], + extraLibraries ? pkgs: [ ], + steamSupport ? true, }: let - qt5Deps = pkgs: with pkgs.qt5; [ qtbase qtmultimedia ]; + qt5Deps = + pkgs: with pkgs.qt5; [ + qtbase + qtmultimedia + ]; qt6Deps = pkgs: with pkgs.qt6; [ qtbase ]; - gnomeDeps = pkgs: with pkgs; [ zenity gtksourceview gnome-desktop libgnome-keyring webkitgtk_4_0 ]; - xorgDeps = pkgs: with pkgs.xorg; [ - libX11 libXrender libXrandr libxcb libXmu libpthreadstubs libXext libXdmcp - libXxf86vm libXinerama libSM libXv libXaw libXi libXcursor libXcomposite - libXfixes libXtst libXScrnSaver libICE libXt - ]; - gstreamerDeps = pkgs: with pkgs.gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-good - gst-plugins-ugly - gst-plugins-bad - gst-libav - ]; - -in buildFHSEnv { + gnomeDeps = + pkgs: with pkgs; [ + zenity + gtksourceview + gnome-desktop + libgnome-keyring + webkitgtk_4_0 + ]; + xorgDeps = + pkgs: with pkgs.xorg; [ + libX11 + libXrender + libXrandr + libxcb + libXmu + libpthreadstubs + libXext + libXdmcp + libXxf86vm + libXinerama + libSM + libXv + libXaw + libXi + libXcursor + libXcomposite + libXfixes + libXtst + libXScrnSaver + libICE + libXt + ]; + gstreamerDeps = + pkgs: with pkgs.gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-ugly + gst-plugins-bad + gst-libav + ]; + +in +buildFHSEnv { pname = "lutris"; inherit (lutris-unwrapped) version; @@ -32,112 +67,229 @@ in buildFHSEnv { # Many native and WINE games need 32bit multiArch = true; - targetPkgs = pkgs: with pkgs; [ - lutris-unwrapped - - # Appimages - fuse - - # Adventure Game Studio - allegro dumb - - # Battle.net - jansson - - # Curl - libnghttp2 - - # Desmume - lua agg soundtouch openal desktop-file-utils atk - - # DGen // TODO: libarchive is broken - - # Dolphin - bluez ffmpeg_6 gettext portaudio miniupnpc mbedtls_2 lzo sfml gsm - wavpack orc nettle gmp pcre vulkan-loader zstd - - # DOSBox - SDL_net SDL_sound - - # GOG - glib-networking - - # Higan // TODO: "higan is not available for the x86_64 architecture" - - # Libretro - fluidsynth hidapi mesa libdrm - - # MAME - fontconfig SDL2_ttf - - # Mednafen - libglut mesa_glu - - # MESS - expat - - # Minecraft - nss - - # Mupen64Plus - boost dash - - # Overwatch 2 - libunwind - - # PPSSPP - glew snappy - - # Redream // "redream is not available for the x86_64 architecture" - - # RPCS3 - llvm e2fsprogs libgpg-error - - # ScummVM - nasm sndio - - # ResidualVM is now merged with ScummVM and therefore does not exist anymore - flac - - # Snes9x - libepoxy minizip - - # Vice - bison flex - - # WINE - xorg.xrandr perl which p7zip gnused gnugrep psmisc opencl-headers - - # ZDOOM - soundfont-fluid bzip2 game-music-emu - ] ++ qt5Deps pkgs + targetPkgs = + pkgs: + with pkgs; + [ + lutris-unwrapped + + # Appimages + fuse + + # Adventure Game Studio + allegro + dumb + + # Battle.net + jansson + + # Curl + libnghttp2 + + # Desmume + lua + agg + soundtouch + openal + desktop-file-utils + atk + + # DGen // TODO: libarchive is broken + + # Dolphin + bluez + ffmpeg_6 + gettext + portaudio + miniupnpc + mbedtls_2 + lzo + sfml + gsm + wavpack + orc + nettle + gmp + pcre + vulkan-loader + zstd + + # DOSBox + SDL_net + SDL_sound + + # GOG + glib-networking + + # Higan // TODO: "higan is not available for the x86_64 architecture" + + # Libretro + fluidsynth + hidapi + mesa + libdrm + + # MAME + fontconfig + SDL2_ttf + + # Mednafen + libglut + mesa_glu + + # MESS + expat + + # Minecraft + nss + + # Mupen64Plus + boost + dash + + # Overwatch 2 + libunwind + + # PPSSPP + glew + snappy + + # Redream // "redream is not available for the x86_64 architecture" + + # RPCS3 + llvm + e2fsprogs + libgpg-error + + # ScummVM + nasm + sndio + + # ResidualVM is now merged with ScummVM and therefore does not exist anymore + flac + + # Snes9x + libepoxy + minizip + + # Vice + bison + flex + + # WINE + xorg.xrandr + perl + which + p7zip + gnused + gnugrep + psmisc + opencl-headers + + # ZDOOM + soundfont-fluid + bzip2 + game-music-emu + ] + ++ qt5Deps pkgs ++ qt6Deps pkgs ++ gnomeDeps pkgs ++ lib.optional steamSupport pkgs.steam ++ extraPkgs pkgs; - multiPkgs = pkgs: with pkgs; [ - # Common - libsndfile libtheora libogg libvorbis libopus libGLU libpcap libpulseaudio - libao libevdev udev libgcrypt libxml2 libusb1 libpng libmpeg2 libv4l - libjpeg libxkbcommon libass libcdio libjack2 libsamplerate libzip libmad libaio - libcap libtiff libva libgphoto2 libxslt libsndfile giflib zlib glib - alsa-lib zziplib bash dbus keyutils zip cabextract freetype unzip coreutils - readline gcc SDL SDL2 curl graphite2 gtk2 gtk3 udev ncurses wayland libglvnd - vulkan-loader xdg-utils sqlite gnutls p11-kit libbsd harfbuzz - - # PCSX2 // TODO: "libgobject-2.0.so.0: wrong ELF class: ELFCLASS64" - - # WINE - cups lcms2 mpg123 cairo unixODBC samba4 sane-backends openldap - ocl-icd util-linux libkrb5 - - # Proton - libselinux - - # Winetricks - fribidi pango - ] ++ xorgDeps pkgs + multiPkgs = + pkgs: + with pkgs; + [ + # Common + libsndfile + libtheora + libogg + libvorbis + libopus + libGLU + libpcap + libpulseaudio + libao + libevdev + udev + libgcrypt + libxml2 + libusb1 + libpng + libmpeg2 + libv4l + libjpeg + libxkbcommon + libass + libcdio + libjack2 + libsamplerate + libzip + libmad + libaio + libcap + libtiff + libva + libgphoto2 + libxslt + libsndfile + giflib + zlib + glib + alsa-lib + zziplib + bash + dbus + keyutils + zip + cabextract + freetype + unzip + coreutils + readline + gcc + SDL + SDL2 + curl + graphite2 + gtk2 + gtk3 + udev + ncurses + wayland + libglvnd + vulkan-loader + xdg-utils + sqlite + gnutls + p11-kit + libbsd + harfbuzz + + # PCSX2 // TODO: "libgobject-2.0.so.0: wrong ELF class: ELFCLASS64" + + # WINE + cups + lcms2 + mpg123 + cairo + unixODBC + samba4 + sane-backends + openldap + ocl-icd + util-linux + libkrb5 + + # Proton + libselinux + + # Winetricks + fribidi + pango + ] + ++ xorgDeps pkgs ++ gstreamerDeps pkgs ++ extraLibraries pkgs; @@ -163,7 +315,8 @@ in buildFHSEnv { platforms license maintainers - broken; + broken + ; mainProgram = "lutris"; }; diff --git a/pkgs/applications/misc/makehuman/default.nix b/pkgs/applications/misc/makehuman/default.nix index b9394aacb6f5c0..04cc4e5c0d5c01 100644 --- a/pkgs/applications/misc/makehuman/default.nix +++ b/pkgs/applications/misc/makehuman/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchpatch -, fetchFromGitHub -, python3 -, qtbase -, git-lfs -, wrapQtAppsHook +{ + stdenv, + lib, + fetchpatch, + fetchFromGitHub, + python3, + qtbase, + git-lfs, + wrapQtAppsHook, }: let @@ -99,7 +100,10 @@ stdenv.mkDerivation rec { meta = { description = "Software to create realistic humans"; homepage = "http://www.makehumancommunity.org/"; - license = with lib.licenses; [ agpl3Plus cc0 ]; + license = with lib.licenses; [ + agpl3Plus + cc0 + ]; longDescription = '' MakeHuman is a GUI program for procedurally generating realistic-looking humans. diff --git a/pkgs/applications/misc/maliit-framework/default.nix b/pkgs/applications/misc/maliit-framework/default.nix index 7093524fc04dfb..99b3e75922d0c2 100644 --- a/pkgs/applications/misc/maliit-framework/default.nix +++ b/pkgs/applications/misc/maliit-framework/default.nix @@ -1,26 +1,27 @@ -{ mkDerivation -, lib -, fetchFromGitHub -, fetchpatch +{ + mkDerivation, + lib, + fetchFromGitHub, + fetchpatch, -, at-spi2-atk -, at-spi2-core -, libepoxy -, gtk3 -, libdatrie -, libselinux -, libsepol -, libthai -, pcre -, util-linux -, wayland -, xorg + at-spi2-atk, + at-spi2-core, + libepoxy, + gtk3, + libdatrie, + libselinux, + libsepol, + libthai, + pcre, + util-linux, + wayland, + xorg, -, cmake -, doxygen -, pkg-config -, wayland-protocols -, wayland-scanner + cmake, + doxygen, + pkg-config, + wayland-protocols, + wayland-scanner, }: mkDerivation rec { diff --git a/pkgs/applications/misc/maliit-keyboard/default.nix b/pkgs/applications/misc/maliit-keyboard/default.nix index 108137188b226c..dd7d60049c466d 100644 --- a/pkgs/applications/misc/maliit-keyboard/default.nix +++ b/pkgs/applications/misc/maliit-keyboard/default.nix @@ -1,22 +1,23 @@ -{ mkDerivation -, lib -, fetchFromGitHub +{ + mkDerivation, + lib, + fetchFromGitHub, -, anthy -, hunspell -, libchewing -, libpinyin -, maliit-framework -, pcre -, presage -, qtfeedback -, qtmultimedia -, qtquickcontrols2 -, qtgraphicaleffects + anthy, + hunspell, + libchewing, + libpinyin, + maliit-framework, + pcre, + presage, + qtfeedback, + qtmultimedia, + qtquickcontrols2, + qtgraphicaleffects, -, cmake -, pkg-config -, wrapGAppsHook3 + cmake, + pkg-config, + wrapGAppsHook3, }: mkDerivation rec { @@ -68,7 +69,11 @@ mkDerivation rec { description = "Virtual keyboard"; mainProgram = "maliit-keyboard"; homepage = "http://maliit.github.io/"; - license = with licenses; [ lgpl3Only bsd3 cc-by-30 ]; + license = with licenses; [ + lgpl3Only + bsd3 + cc-by-30 + ]; maintainers = [ ]; }; } diff --git a/pkgs/applications/misc/masterpdfeditor4/default.nix b/pkgs/applications/misc/masterpdfeditor4/default.nix index 355c23d3d18722..9eeac8660a2aa8 100644 --- a/pkgs/applications/misc/masterpdfeditor4/default.nix +++ b/pkgs/applications/misc/masterpdfeditor4/default.nix @@ -1,4 +1,13 @@ -{ stdenv, fetchurl, sane-backends, qtbase, qtsvg, autoPatchelfHook, lib, wrapQtAppsHook }: +{ + stdenv, + fetchurl, + sane-backends, + qtbase, + qtsvg, + autoPatchelfHook, + lib, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "masterpdfeditor4"; @@ -9,9 +18,17 @@ stdenv.mkDerivation rec { sha256 = "0k5bzlhqglskiiq86nmy18mnh5bf2w3mr9cq3pibrwn5pisxnxxc"; }; - nativeBuildInputs = [ autoPatchelfHook wrapQtAppsHook ]; - - buildInputs = [ qtbase qtsvg sane-backends stdenv.cc.cc ]; + nativeBuildInputs = [ + autoPatchelfHook + wrapQtAppsHook + ]; + + buildInputs = [ + qtbase + qtsvg + sane-backends + stdenv.cc.cc + ]; installPhase = '' runHook preInstall diff --git a/pkgs/applications/misc/mdzk/default.nix b/pkgs/applications/misc/mdzk/default.nix index 92498cc92612dd..a613fe5492a142 100644 --- a/pkgs/applications/misc/mdzk/default.nix +++ b/pkgs/applications/misc/mdzk/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, CoreServices }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + CoreServices, +}: rustPlatform.buildRustPackage rec { pname = "mdzk"; @@ -25,7 +31,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/mdzk-rs/mdzk/"; changelog = "https://github.com/mdzk-rs/mdzk/blob/main/CHANGELOG.md"; license = licenses.mpl20; - maintainers = with maintainers; [ bryanasdev000 ratsclub ]; + maintainers = with maintainers; [ + bryanasdev000 + ratsclub + ]; mainProgram = "mdzk"; }; } diff --git a/pkgs/applications/misc/mediaelch/default.nix b/pkgs/applications/misc/mediaelch/default.nix index 58aae6450ed08b..d815c354f8e6d6 100644 --- a/pkgs/applications/misc/mediaelch/default.nix +++ b/pkgs/applications/misc/mediaelch/default.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, -, cmake -, qttools -, wrapQtAppsHook + cmake, + qttools, + wrapQtAppsHook, -, curl -, ffmpeg -, libmediainfo -, libzen -, qt5compat ? null # qt6 only -, qtbase -, qtdeclarative -, qtmultimedia -, qtsvg -, qtwayland -, quazip + curl, + ffmpeg, + libmediainfo, + libzen, + qt5compat ? null, # qt6 only + qtbase, + qtdeclarative, + qtmultimedia, + qtsvg, + qtwayland, + quazip, }: let qtVersion = lib.versions.major qtbase.version; @@ -39,21 +40,22 @@ stdenv.mkDerivation rec { wrapQtAppsHook ]; - buildInputs = [ - curl - ffmpeg - libmediainfo - libzen - qtbase - qtdeclarative - qtmultimedia - qtsvg - qtwayland - quazip - ] ++ lib.optionals (qtVersion == "6") [ - qt5compat - ]; - + buildInputs = + [ + curl + ffmpeg + libmediainfo + libzen + qtbase + qtdeclarative + qtmultimedia + qtsvg + qtwayland + quazip + ] + ++ lib.optionals (qtVersion == "6") [ + qt5compat + ]; cmakeFlags = [ "-DDISABLE_UPDATER=ON" diff --git a/pkgs/applications/misc/meerk40t/camera.nix b/pkgs/applications/misc/meerk40t/camera.nix index ab2a70ad8eb27d..6e33c8077c6686 100644 --- a/pkgs/applications/misc/meerk40t/camera.nix +++ b/pkgs/applications/misc/meerk40t/camera.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: let diff --git a/pkgs/applications/misc/meerk40t/default.nix b/pkgs/applications/misc/meerk40t/default.nix index e9a2a9d4838e76..6406abad27bb3d 100644 --- a/pkgs/applications/misc/meerk40t/default.nix +++ b/pkgs/applications/misc/meerk40t/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, meerk40t-camera -, python3Packages -, gtk3 -, wrapGAppsHook3 +{ + lib, + fetchFromGitHub, + meerk40t-camera, + python3Packages, + gtk3, + wrapGAppsHook3, }: python3Packages.buildPythonApplication rec { @@ -18,25 +19,29 @@ python3Packages.buildPythonApplication rec { hash = "sha256-dybmbmEvvTka0wMBIUDYemqDaCvG9odgCbIWYhROJLI="; }; - nativeBuildInputs = [ - wrapGAppsHook3 - ] ++ (with python3Packages; [ - setuptools - ]); + nativeBuildInputs = + [ + wrapGAppsHook3 + ] + ++ (with python3Packages; [ + setuptools + ]); # prevent double wrapping dontWrapGApps = true; # https://github.com/meerk40t/meerk40t/blob/main/setup.py - propagatedBuildInputs = with python3Packages; [ - meerk40t-camera - numpy - pyserial - pyusb - setuptools - wxpython - ] - ++ lib.flatten (lib.attrValues optional-dependencies); + propagatedBuildInputs = + with python3Packages; + [ + meerk40t-camera + numpy + pyserial + pyusb + setuptools + wxpython + ] + ++ lib.flatten (lib.attrValues optional-dependencies); optional-dependencies = with python3Packages; { cam = [ diff --git a/pkgs/applications/misc/michabo/default.nix b/pkgs/applications/misc/michabo/default.nix index 7f077d20fc85c1..b44b5300749b03 100644 --- a/pkgs/applications/misc/michabo/default.nix +++ b/pkgs/applications/misc/michabo/default.nix @@ -1,11 +1,12 @@ -{ lib -, mkDerivation -, makeDesktopItem -, fetchFromGitLab -, qmake -# qt -, qtbase -, qtwebsockets +{ + lib, + mkDerivation, + makeDesktopItem, + fetchFromGitLab, + qmake, + # qt + qtbase, + qtwebsockets, }: let @@ -15,7 +16,8 @@ let exec = "Michabo"; }; -in mkDerivation rec { +in +mkDerivation rec { pname = "michabo"; version = "0.1"; @@ -35,7 +37,10 @@ in mkDerivation rec { qtwebsockets ]; - qmakeFlags = [ "michabo.pro" "DESTDIR=${placeholder "out"}/bin" ]; + qmakeFlags = [ + "michabo.pro" + "DESTDIR=${placeholder "out"}/bin" + ]; postInstall = '' ln -s ${desktopItem}/share $out/share @@ -50,4 +55,3 @@ in mkDerivation rec { platforms = platforms.all; }; } - diff --git a/pkgs/applications/misc/mkgmap/default.nix b/pkgs/applications/misc/mkgmap/default.nix index f475359a86cb3f..19e16d2d854bad 100644 --- a/pkgs/applications/misc/mkgmap/default.nix +++ b/pkgs/applications/misc/mkgmap/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, fetchsvn -, jdk -, jre -, ant -, makeWrapper -, stripJavaArchivesHook -, doCheck ? true -, withExamples ? false +{ + lib, + stdenv, + fetchurl, + fetchsvn, + jdk, + jre, + ant, + makeWrapper, + stripJavaArchivesHook, + doCheck ? true, + withExamples ? false, }: let deps = import ./deps.nix { inherit fetchurl; }; @@ -30,35 +31,43 @@ stdenv.mkDerivation rec { ./ignore-impure-test.patch ]; - postPatch = with deps; '' - # Manually create version properties file for reproducibility - mkdir -p build/classes - cat > build/classes/mkgmap-version.properties << EOF - svn.version=${version} - build.timestamp=unknown - EOF - - # Put pre-fetched dependencies into the right place - mkdir -p lib/compile - cp ${fastutil} lib/compile/${fastutil.name} - cp ${osmpbf} lib/compile/${osmpbf.name} - cp ${protobuf} lib/compile/${protobuf.name} - '' + lib.optionalString doCheck '' - mkdir -p lib/test - cp ${fastutil} lib/test/${fastutil.name} - cp ${osmpbf} lib/test/${osmpbf.name} - cp ${protobuf} lib/test/${protobuf.name} - cp ${jaxb-api} lib/test/${jaxb-api.name} - cp ${junit} lib/test/${junit.name} - cp ${hamcrest-core} lib/test/${hamcrest-core.name} - - mkdir -p test/resources/in/img - ${lib.concatMapStringsSep "\n" (res: '' - cp ${res} test/resources/in/${builtins.replaceStrings [ "__" ] [ "/" ] res.name} - '') testInputs} - ''; - - nativeBuildInputs = [ jdk ant makeWrapper stripJavaArchivesHook ]; + postPatch = + with deps; + '' + # Manually create version properties file for reproducibility + mkdir -p build/classes + cat > build/classes/mkgmap-version.properties << EOF + svn.version=${version} + build.timestamp=unknown + EOF + + # Put pre-fetched dependencies into the right place + mkdir -p lib/compile + cp ${fastutil} lib/compile/${fastutil.name} + cp ${osmpbf} lib/compile/${osmpbf.name} + cp ${protobuf} lib/compile/${protobuf.name} + '' + + lib.optionalString doCheck '' + mkdir -p lib/test + cp ${fastutil} lib/test/${fastutil.name} + cp ${osmpbf} lib/test/${osmpbf.name} + cp ${protobuf} lib/test/${protobuf.name} + cp ${jaxb-api} lib/test/${jaxb-api.name} + cp ${junit} lib/test/${junit.name} + cp ${hamcrest-core} lib/test/${hamcrest-core.name} + + mkdir -p test/resources/in/img + ${lib.concatMapStringsSep "\n" (res: '' + cp ${res} test/resources/in/${builtins.replaceStrings [ "__" ] [ "/" ] res.name} + '') testInputs} + ''; + + nativeBuildInputs = [ + jdk + ant + makeWrapper + stripJavaArchivesHook + ]; buildPhase = '' runHook preBuild @@ -91,7 +100,11 @@ stdenv.mkDerivation rec { runHook postInstall ''; - passthru.updateScript = [ ./update.sh "mkgmap" meta.downloadPage ]; + passthru.updateScript = [ + ./update.sh + "mkgmap" + meta.downloadPage + ]; meta = with lib; { description = "Create maps for Garmin GPS devices from OpenStreetMap (OSM) data"; diff --git a/pkgs/applications/misc/mkgmap/splitter/testinputs.nix b/pkgs/applications/misc/mkgmap/splitter/testinputs.nix index 0d73f971029102..462e8bfa0bebf9 100644 --- a/pkgs/applications/misc/mkgmap/splitter/testinputs.nix +++ b/pkgs/applications/misc/mkgmap/splitter/testinputs.nix @@ -1,10 +1,12 @@ { fetchurl }: let - fetchTestInput = { res, sha256 }: fetchurl { - inherit sha256; - url = "https://www.mkgmap.org.uk/testinput/${res}"; - name = builtins.replaceStrings [ "/" ] [ "__" ] res; - }; + fetchTestInput = + { res, sha256 }: + fetchurl { + inherit sha256; + url = "https://www.mkgmap.org.uk/testinput/${res}"; + name = builtins.replaceStrings [ "/" ] [ "__" ] res; + }; in [ (fetchTestInput { diff --git a/pkgs/applications/misc/mkgmap/testinputs.nix b/pkgs/applications/misc/mkgmap/testinputs.nix index 93c858a3889524..c92499aea5c7e5 100644 --- a/pkgs/applications/misc/mkgmap/testinputs.nix +++ b/pkgs/applications/misc/mkgmap/testinputs.nix @@ -1,10 +1,12 @@ { fetchurl }: let - fetchTestInput = { res, sha256 }: fetchurl { - inherit sha256; - url = "https://www.mkgmap.org.uk/testinput/${res}"; - name = builtins.replaceStrings [ "/" ] [ "__" ] res; - }; + fetchTestInput = + { res, sha256 }: + fetchurl { + inherit sha256; + url = "https://www.mkgmap.org.uk/testinput/${res}"; + name = builtins.replaceStrings [ "/" ] [ "__" ] res; + }; in [ (fetchTestInput { diff --git a/pkgs/applications/misc/moolticute/default.nix b/pkgs/applications/misc/moolticute/default.nix index fbdbe92ff6341e..b8023272f60f1f 100644 --- a/pkgs/applications/misc/moolticute/default.nix +++ b/pkgs/applications/misc/moolticute/default.nix @@ -1,10 +1,13 @@ -{ lib, mkDerivation, fetchFromGitHub -, libusb1 -, pkg-config -, qmake -, qtbase -, qttools -, qtwebsockets +{ + lib, + mkDerivation, + fetchFromGitHub, + libusb1, + pkg-config, + qmake, + qtbase, + qttools, + qtwebsockets, }: mkDerivation rec { @@ -18,10 +21,21 @@ mkDerivation rec { sha256 = "sha256-S2Pnueo3opP1k6XBBHGAyRJpkNuI1Hotz7ypXa/96eQ="; }; - outputs = [ "out" "udev" ]; + outputs = [ + "out" + "udev" + ]; - nativeBuildInputs = [ pkg-config qmake qttools ]; - buildInputs = [ libusb1 qtbase qtwebsockets ]; + nativeBuildInputs = [ + pkg-config + qmake + qttools + ]; + buildInputs = [ + libusb1 + qtbase + qtwebsockets + ]; preConfigure = "mkdir -p build && cd build"; qmakeFlags = [ "../Moolticute.pro" ]; @@ -30,7 +44,7 @@ mkDerivation rec { mkdir -p $udev/lib/udev/rules.d sed -n '/^UDEV_RULE=="\$(cat <<-EOF$/,/^EOF$/p' ../data/moolticute.sh | sed '1d;$d' > $udev/lib/udev/rules.d/50-mooltipass.rules - ''; + ''; meta = with lib; { description = "GUI app and daemon to work with Mooltipass device via USB"; @@ -40,7 +54,10 @@ mkDerivation rec { ''; homepage = "https://github.com/mooltipass/moolticute"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ kirikaza hughobrien ]; + maintainers = with maintainers; [ + kirikaza + hughobrien + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/misc/mu-repo/default.nix b/pkgs/applications/misc/mu-repo/default.nix index ff07856e0e8d8d..c2acd018b78ef1 100644 --- a/pkgs/applications/misc/mu-repo/default.nix +++ b/pkgs/applications/misc/mu-repo/default.nix @@ -1,4 +1,12 @@ -{ lib, fetchFromGitHub, buildPythonApplication, pytestCheckHook, git, testers, mu-repo }: +{ + lib, + fetchFromGitHub, + buildPythonApplication, + pytestCheckHook, + git, + testers, + mu-repo, +}: buildPythonApplication rec { pname = "mu-repo"; @@ -13,7 +21,10 @@ buildPythonApplication rec { propagatedBuildInputs = [ git ]; - nativeCheckInputs = [ pytestCheckHook git ]; + nativeCheckInputs = [ + pytestCheckHook + git + ]; passthru.tests.version = testers.testVersion { package = mu-repo; diff --git a/pkgs/applications/misc/mwic/default.nix b/pkgs/applications/misc/mwic/default.nix index 6b647aab24734a..045c8cdfeab305 100644 --- a/pkgs/applications/misc/mwic/default.nix +++ b/pkgs/applications/misc/mwic/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, pythonPackages }: +{ + lib, + stdenv, + fetchurl, + pythonPackages, +}: stdenv.mkDerivation rec { version = "0.7.10"; @@ -9,13 +14,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-dmIHPehkxpSb78ymVpcPCu4L41coskrHQOg067dprOo="; }; - makeFlags=["PREFIX=\${out}"]; + makeFlags = [ "PREFIX=\${out}" ]; nativeBuildInputs = [ pythonPackages.wrapPython ]; - propagatedBuildInputs = with pythonPackages; [ pyenchant regex ]; + propagatedBuildInputs = with pythonPackages; [ + pyenchant + regex + ]; postFixup = '' wrapPythonPrograms @@ -29,4 +37,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ matthiasbeyer ]; }; } - diff --git a/pkgs/applications/misc/mysql-workbench/default.nix b/pkgs/applications/misc/mysql-workbench/default.nix index 01df4df5d1c75a..a6705904f78f9e 100644 --- a/pkgs/applications/misc/mysql-workbench/default.nix +++ b/pkgs/applications/misc/mysql-workbench/default.nix @@ -1,46 +1,47 @@ -{ lib -, stdenv -, fetchurl -, substituteAll -, cmake -, ninja -, pkg-config -, glibc -, gtk3 -, gtkmm3 -, pcre -, swig -, antlr4_12 -, sudo -, mysql -, libxml2 -, libmysqlconnectorcpp -, vsqlite -, gdal -, libiodbc -, libpthreadstubs -, libXdmcp -, libuuid -, libzip -, libsecret -, libssh -, python3 -, jre -, boost -, libsigcxx -, libX11 -, openssl -, rapidjson -, proj -, cairo -, libxkbcommon -, libepoxy -, wrapGAppsHook3 -, at-spi2-core -, dbus -, bash -, coreutils -, zstd +{ + lib, + stdenv, + fetchurl, + substituteAll, + cmake, + ninja, + pkg-config, + glibc, + gtk3, + gtkmm3, + pcre, + swig, + antlr4_12, + sudo, + mysql, + libxml2, + libmysqlconnectorcpp, + vsqlite, + gdal, + libiodbc, + libpthreadstubs, + libXdmcp, + libuuid, + libzip, + libsecret, + libssh, + python3, + jre, + boost, + libsigcxx, + libX11, + openssl, + rapidjson, + proj, + cairo, + libxkbcommon, + libepoxy, + wrapGAppsHook3, + at-spi2-core, + dbus, + bash, + coreutils, + zstd, }: let @@ -138,16 +139,20 @@ stdenv.mkDerivation (finalAttrs: { zstd ]; - env.NIX_CFLAGS_COMPILE = toString ([ - # error: 'OGRErr OGRSpatialReference::importFromWkt(char**)' is deprecated - "-Wno-error=deprecated-declarations" - ] ++ lib.optionals stdenv.hostPlatform.isAarch64 [ - # error: narrowing conversion of '-1' from 'int' to 'char' - "-Wno-error=narrowing" - ] ++ lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ - # Needed with GCC 12 but problematic with some old GCCs - "-Wno-error=maybe-uninitialized" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + [ + # error: 'OGRErr OGRSpatialReference::importFromWkt(char**)' is deprecated + "-Wno-error=deprecated-declarations" + ] + ++ lib.optionals stdenv.hostPlatform.isAarch64 [ + # error: narrowing conversion of '-1' from 'int' to 'char' + "-Wno-error=narrowing" + ] + ++ lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ + # Needed with GCC 12 but problematic with some old GCCs + "-Wno-error=maybe-uninitialized" + ] + ); cmakeFlags = [ "-DMySQL_CONFIG_PATH=${mysql}/bin/mysql_config" diff --git a/pkgs/applications/misc/nimbo/default.nix b/pkgs/applications/misc/nimbo/default.nix index d028f205f3d531..151393c804b402 100644 --- a/pkgs/applications/misc/nimbo/default.nix +++ b/pkgs/applications/misc/nimbo/default.nix @@ -1,8 +1,9 @@ -{ lib -, python3 -, fetchFromGitHub -, installShellFiles -, awscli +{ + lib, + python3, + fetchFromGitHub, + installShellFiles, + awscli, }: python3.pkgs.buildPythonApplication rec { @@ -43,7 +44,10 @@ python3.pkgs.buildPythonApplication rec { pythonImportsCheck = [ "nimbo" ]; makeWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath [ awscli ]) + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ awscli ]) ]; postInstall = '' diff --git a/pkgs/applications/misc/nixnote2/default.nix b/pkgs/applications/misc/nixnote2/default.nix index d6d0775f78d21a..9014f2f32344c1 100644 --- a/pkgs/applications/misc/nixnote2/default.nix +++ b/pkgs/applications/misc/nixnote2/default.nix @@ -1,5 +1,15 @@ -{ lib, mkDerivation, fetchFromGitHub, boost -, qtbase, qtwebkit, poppler, qmake, hunspell, html-tidy}: +{ + lib, + mkDerivation, + fetchFromGitHub, + boost, + qtbase, + qtwebkit, + poppler, + qmake, + hunspell, + html-tidy, +}: mkDerivation rec { pname = "nixnote2"; @@ -12,7 +22,13 @@ mkDerivation rec { sha256 = "0cfq95mxvcgby66r61gclm1a2c6zck5aln04xmg2q8kg6p9d31fr"; }; - buildInputs = [ boost qtbase qtwebkit poppler hunspell ]; + buildInputs = [ + boost + qtbase + qtwebkit + poppler + hunspell + ]; nativeBuildInputs = [ qmake ]; diff --git a/pkgs/applications/misc/ola/default.nix b/pkgs/applications/misc/ola/default.nix index 26f9845dcfd1d7..3a8f03259f2169 100644 --- a/pkgs/applications/misc/ola/default.nix +++ b/pkgs/applications/misc/ola/default.nix @@ -1,18 +1,20 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, bison -, flex -, pkg-config -, libftdi1 -, libuuid -, cppunit -, protobuf -, zlib -, avahi -, libmicrohttpd -, perl -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + bison, + flex, + pkg-config, + libftdi1, + libuuid, + cppunit, + protobuf, + zlib, + avahi, + libmicrohttpd, + perl, + python3, }: stdenv.mkDerivation rec { @@ -26,7 +28,13 @@ stdenv.mkDerivation rec { hash = "sha256-8w8ZT3D/+8Pxl9z2KTXeydVxE5xiPjxZevgmMFgrblU="; }; - nativeBuildInputs = [ autoreconfHook bison flex pkg-config perl ]; + nativeBuildInputs = [ + autoreconfHook + bison + flex + pkg-config + perl + ]; buildInputs = [ # required for ola-ftdidmx plugin (support for 'dumb' FTDI devices) libftdi1 @@ -52,7 +60,10 @@ stdenv.mkDerivation rec { description = "Framework for controlling entertainment lighting equipment"; homepage = "https://www.openlighting.org/ola/"; maintainers = [ ]; - license = with licenses; [ lgpl21 gpl2Plus ]; + license = with licenses; [ + lgpl21 + gpl2Plus + ]; platforms = platforms.all; }; } diff --git a/pkgs/applications/misc/omegat.nix b/pkgs/applications/misc/omegat.nix index f5d9a9eb920714..b88bccd32de48d 100644 --- a/pkgs/applications/misc/omegat.nix +++ b/pkgs/applications/misc/omegat.nix @@ -1,17 +1,28 @@ -{ lib, stdenv, fetchurl, unzip, jdk, makeWrapper}: +{ + lib, + stdenv, + fetchurl, + unzip, + jdk, + makeWrapper, +}: stdenv.mkDerivation { version = "6.0.1"; pname = "omegat"; - src = fetchurl { # their zip has repeated files or something, so no fetchzip + src = fetchurl { + # their zip has repeated files or something, so no fetchzip url = "mirror://sourceforge/project/omegat/OmegaT%20-%20Standard/OmegaT%206.0.1/OmegaT_6.0.1_Without_JRE.zip"; sha256 = "sha256-Rj50bzT8k7+GWb0p/ma+zy+PzkF7tB6iV4F4UVAImJg="; }; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; - unpackCmd = "unzip -o $curSrc"; # tries to go interactive without -o + unpackCmd = "unzip -o $curSrc"; # tries to go interactive without -o installPhase = '' mkdir -p $out/bin @@ -37,6 +48,9 @@ stdenv.mkDerivation { sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.gpl3Plus; maintainers = with maintainers; [ t184256 ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/applications/misc/openambit/default.nix b/pkgs/applications/misc/openambit/default.nix index f3429a05ee6e3d..9f80b8ee316821 100644 --- a/pkgs/applications/misc/openambit/default.nix +++ b/pkgs/applications/misc/openambit/default.nix @@ -1,14 +1,15 @@ -{ cmake -, fetchFromGitHub -, fetchpatch -, lib -, libusb1 -, mkDerivation -, python3 -, qtbase -, qttools -, udev -, zlib +{ + cmake, + fetchFromGitHub, + fetchpatch, + lib, + libusb1, + mkDerivation, + python3, + qtbase, + qttools, + udev, + zlib, }: mkDerivation rec { @@ -32,8 +33,17 @@ mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake qttools ]; - buildInputs = [ libusb1 python3 qtbase udev zlib ]; + nativeBuildInputs = [ + cmake + qttools + ]; + buildInputs = [ + libusb1 + python3 + qtbase + udev + zlib + ]; cmakeFlags = [ "-DCMAKE_INSTALL_UDEVRULESDIR=${placeholder "out"}/lib/udev/rules.d" ]; diff --git a/pkgs/applications/misc/openbangla-keyboard/default.nix b/pkgs/applications/misc/openbangla-keyboard/default.nix index 04a9fffcb083bc..f257eff50a3260 100644 --- a/pkgs/applications/misc/openbangla-keyboard/default.nix +++ b/pkgs/applications/misc/openbangla-keyboard/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, cargo -, cmake -, pkg-config -, rustPlatform -, rustc -, wrapQtAppsHook -, fcitx5 -, ibus -, qtbase -, zstd -, fetchpatch -, withFcitx5Support ? false -, withIbusSupport ? false +{ + lib, + stdenv, + fetchFromGitHub, + cargo, + cmake, + pkg-config, + rustPlatform, + rustc, + wrapQtAppsHook, + fcitx5, + ibus, + qtbase, + zstd, + fetchpatch, + withFcitx5Support ? false, + withIbusSupport ? false, }: stdenv.mkDerivation rec { @@ -48,14 +49,17 @@ stdenv.mkDerivation rec { wrapQtAppsHook ]; - buildInputs = lib.optionals withFcitx5Support [ - fcitx5 - ] ++ lib.optionals withIbusSupport [ - ibus - ] ++ [ - qtbase - zstd - ]; + buildInputs = + lib.optionals withFcitx5Support [ + fcitx5 + ] + ++ lib.optionals withIbusSupport [ + ibus + ] + ++ [ + qtbase + zstd + ]; cargoDeps = rustPlatform.fetchCargoTarball { inherit src; @@ -66,16 +70,18 @@ stdenv.mkDerivation rec { hash = "sha256-XMleyP2h1aBhtjXhuGHyU0BN+tuL12CGoj+kLY5uye0="; }; - cmakeFlags = lib.optionals withFcitx5Support [ - "-DENABLE_FCITX=YES" - ] ++ lib.optionals withIbusSupport [ - "-DENABLE_IBUS=YES" - ]; + cmakeFlags = + lib.optionals withFcitx5Support [ + "-DENABLE_FCITX=YES" + ] + ++ lib.optionals withIbusSupport [ + "-DENABLE_IBUS=YES" + ]; cargoRoot = "src/engine/riti"; postPatch = '' cp ${./Cargo.lock} ${cargoRoot}/Cargo.lock - ''; + ''; meta = { isIbusEngine = withIbusSupport; diff --git a/pkgs/applications/misc/openbox-menu/default.nix b/pkgs/applications/misc/openbox-menu/default.nix index 7a9fd06cc295c2..465a3749df6d64 100644 --- a/pkgs/applications/misc/openbox-menu/default.nix +++ b/pkgs/applications/misc/openbox-menu/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, glib -, gtk2 -, menu-cache +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + gtk2, + menu-cache, }: stdenv.mkDerivation rec { @@ -17,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib gtk2 menu-cache ]; + buildInputs = [ + glib + gtk2 + menu-cache + ]; # Enables SVG support by uncommenting the Makefile patches = [ ./000-enable-svg.patch ]; @@ -41,7 +46,7 @@ stdenv.mkDerivation rec { ''; license = licenses.gpl3Plus; maintainers = [ maintainers.romildo ]; - platforms = platforms.unix; + platforms = platforms.unix; mainProgram = "openbox-menu"; }; } diff --git a/pkgs/applications/misc/openbrf/default.nix b/pkgs/applications/misc/openbrf/default.nix index d2419ae25b9ec4..bfac320abe8a43 100644 --- a/pkgs/applications/misc/openbrf/default.nix +++ b/pkgs/applications/misc/openbrf/default.nix @@ -1,5 +1,17 @@ -{ mkDerivation, lib, stdenv, fetchFromGitHub, fetchpatch, qtbase, vcg, glew, qmake, libGLU, eigen, libGL }: - +{ + mkDerivation, + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + qtbase, + vcg, + glew, + qmake, + libGLU, + eigen, + libGL, +}: mkDerivation { pname = "openbrf"; @@ -21,7 +33,12 @@ mkDerivation { }) ]; - buildInputs = [ qtbase vcg glew eigen ]; + buildInputs = [ + qtbase + vcg + glew + eigen + ]; nativeBuildInputs = [ qmake ]; @@ -39,7 +56,15 @@ mkDerivation { install -Dm644 reference.brf $out/share/openBrf/reference.brf patchelf \ - --set-rpath "${lib.makeLibraryPath [ qtbase glew stdenv.cc.cc libGLU libGL ]}" \ + --set-rpath "${ + lib.makeLibraryPath [ + qtbase + glew + stdenv.cc.cc + libGLU + libGL + ] + }" \ $out/share/openBrf/openBrf mkdir -p "$out/bin" diff --git a/pkgs/applications/misc/opencpn/default.nix b/pkgs/applications/misc/opencpn/default.nix index 8e5009d440c47e..cf253fa3bc52ce 100644 --- a/pkgs/applications/misc/opencpn/default.nix +++ b/pkgs/applications/misc/opencpn/default.nix @@ -1,50 +1,51 @@ -{ stdenv -, lib -, AppKit -, DarwinTools -, alsa-utils -, at-spi2-core -, cmake -, curl -, dbus -, elfutils -, fetchFromGitHub -, flac -, gitMinimal -, gtk3 -, glew -, gtest -, jasper -, lame -, libGLU -, libarchive -, libdatrie -, libepoxy -, libexif -, libogg -, libopus -, libselinux -, libsepol -, libsndfile -, libthai -, libunarr -, libusb1 -, libvorbis -, libxkbcommon -, lsb-release -, lz4 -, libmpg123 -, makeWrapper -, pcre -, pcre2 -, pkg-config -, portaudio -, rapidjson -, sqlite -, tinyxml -, util-linux -, wxGTK32 -, xorg +{ + stdenv, + lib, + AppKit, + DarwinTools, + alsa-utils, + at-spi2-core, + cmake, + curl, + dbus, + elfutils, + fetchFromGitHub, + flac, + gitMinimal, + gtk3, + glew, + gtest, + jasper, + lame, + libGLU, + libarchive, + libdatrie, + libepoxy, + libexif, + libogg, + libopus, + libselinux, + libsepol, + libsndfile, + libthai, + libunarr, + libusb1, + libvorbis, + libxkbcommon, + lsb-release, + lz4, + libmpg123, + makeWrapper, + pcre, + pcre2, + pkg-config, + portaudio, + rapidjson, + sqlite, + tinyxml, + util-linux, + wxGTK32, + xorg, }: stdenv.mkDerivation (finalAttrs: { @@ -62,74 +63,87 @@ stdenv.mkDerivation (finalAttrs: { sed -i '/fixup_bundle/d; /NO_DEFAULT_PATH/d' CMakeLists.txt ''; - nativeBuildInputs = [ - cmake - pkg-config - gtest - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - lsb-release - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - DarwinTools - makeWrapper - ]; + nativeBuildInputs = + [ + cmake + pkg-config + gtest + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + lsb-release + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + DarwinTools + makeWrapper + ]; - buildInputs = [ - at-spi2-core - curl - dbus - flac - gitMinimal - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ - AppKit - ] ++ [ - gtk3 - glew - jasper - libGLU - libarchive - libdatrie - libepoxy - libexif - libogg - libopus - libsndfile - libthai - libunarr - libusb1 - libvorbis - libxkbcommon - lz4 - libmpg123 - pcre - pcre2 - portaudio - rapidjson - sqlite - tinyxml - wxGTK32 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-utils - libselinux - libsepol - util-linux - xorg.libXdmcp - xorg.libXtst - ] ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform elfutils) [ - elfutils - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - lame - ]; + buildInputs = + [ + at-spi2-core + curl + dbus + flac + gitMinimal + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + AppKit + ] + ++ [ + gtk3 + glew + jasper + libGLU + libarchive + libdatrie + libepoxy + libexif + libogg + libopus + libsndfile + libthai + libunarr + libusb1 + libvorbis + libxkbcommon + lz4 + libmpg123 + pcre + pcre2 + portaudio + rapidjson + sqlite + tinyxml + wxGTK32 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-utils + libselinux + libsepol + util-linux + xorg.libXdmcp + xorg.libXtst + ] + ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform elfutils) [ + elfutils + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + lame + ]; - cmakeFlags = [ - "-DOCPN_BUNDLE_DOCS=true" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - # Override OpenCPN platform detection. - "-DOCPN_TARGET_TUPLE=unknown;unknown;${stdenv.hostPlatform.linuxArch}" - ]; + cmakeFlags = + [ + "-DOCPN_BUNDLE_DOCS=true" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + # Override OpenCPN platform detection. + "-DOCPN_TARGET_TUPLE=unknown;unknown;${stdenv.hostPlatform.linuxArch}" + ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals (!stdenv.hostPlatform.isx86) [ - "-DSQUISH_USE_SSE=0" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals (!stdenv.hostPlatform.isx86) [ + "-DSQUISH_USE_SSE=0" + ] + ); postInstall = lib.optionals stdenv.hostPlatform.isDarwin '' mkdir -p $out/Applications @@ -141,7 +155,10 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Concise ChartPlotter/Navigator"; - maintainers = with maintainers; [ kragniz lovesegfault ]; + maintainers = with maintainers; [ + kragniz + lovesegfault + ]; platforms = platforms.unix; license = licenses.gpl2Plus; homepage = "https://opencpn.org/"; diff --git a/pkgs/applications/misc/openrgb-plugins/effects/default.nix b/pkgs/applications/misc/openrgb-plugins/effects/default.nix index 9cdda76f8a138f..5723bab1d1c80f 100644 --- a/pkgs/applications/misc/openrgb-plugins/effects/default.nix +++ b/pkgs/applications/misc/openrgb-plugins/effects/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitLab -, qtbase -, openrgb -, glib -, openal -, qmake -, pkg-config -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitLab, + qtbase, + openrgb, + glib, + openal, + qmake, + pkg-config, + wrapQtAppsHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/misc/openrgb-plugins/hardwaresync/default.nix b/pkgs/applications/misc/openrgb-plugins/hardwaresync/default.nix index 9080f53481fbc4..497da16c10a605 100644 --- a/pkgs/applications/misc/openrgb-plugins/hardwaresync/default.nix +++ b/pkgs/applications/misc/openrgb-plugins/hardwaresync/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitLab -, qtbase -, openrgb -, glib -, libgtop -, lm_sensors -, qmake -, pkg-config -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitLab, + qtbase, + openrgb, + glib, + libgtop, + lm_sensors, + qmake, + pkg-config, + wrapQtAppsHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/misc/openrgb/default.nix b/pkgs/applications/misc/openrgb/default.nix index 5c158d7ab7679f..ac8651b36e3797 100644 --- a/pkgs/applications/misc/openrgb/default.nix +++ b/pkgs/applications/misc/openrgb/default.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchFromGitLab, qmake, wrapQtAppsHook, libusb1, hidapi, pkg-config, coreutils, mbedtls_2, qtbase, qttools, symlinkJoin, openrgb }: +{ + lib, + stdenv, + fetchFromGitLab, + qmake, + wrapQtAppsHook, + libusb1, + hidapi, + pkg-config, + coreutils, + mbedtls_2, + qtbase, + qttools, + symlinkJoin, + openrgb, +}: stdenv.mkDerivation rec { pname = "openrgb"; @@ -11,8 +26,18 @@ stdenv.mkDerivation rec { hash = "sha256-XBLj4EfupyeVHRc0pVI7hrXFoCNJ7ak2yO0QSfhBsGU="; }; - nativeBuildInputs = [ qmake pkg-config wrapQtAppsHook ]; - buildInputs = [ libusb1 hidapi mbedtls_2 qtbase qttools ]; + nativeBuildInputs = [ + qmake + pkg-config + wrapQtAppsHook + ]; + buildInputs = [ + libusb1 + hidapi + mbedtls_2 + qtbase + qttools + ]; postPatch = '' patchShebangs scripts/build-udev-rules.sh @@ -25,26 +50,31 @@ stdenv.mkDerivation rec { HOME=$TMPDIR $out/bin/openrgb --help > /dev/null ''; - passthru.withPlugins = plugins: - let pluginsDir = symlinkJoin { - name = "openrgb-plugins"; - paths = plugins; - # Remove all library version symlinks except one, - # or they will result in duplicates in the UI. - # We leave the one pointing to the actual library, usually the most - # qualified one (eg. libOpenRGBHardwareSyncPlugin.so.1.0.0). - postBuild = '' - for f in $out/lib/*; do - if [ "$(dirname $(readlink "$f"))" == "." ]; then - rm "$f" - fi - done - ''; - }; - in openrgb.overrideAttrs (old: { - qmakeFlags = old.qmakeFlags or [] ++ [ + passthru.withPlugins = + plugins: + let + pluginsDir = symlinkJoin { + name = "openrgb-plugins"; + paths = plugins; + # Remove all library version symlinks except one, + # or they will result in duplicates in the UI. + # We leave the one pointing to the actual library, usually the most + # qualified one (eg. libOpenRGBHardwareSyncPlugin.so.1.0.0). + postBuild = '' + for f in $out/lib/*; do + if [ "$(dirname $(readlink "$f"))" == "." ]; then + rm "$f" + fi + done + ''; + }; + in + openrgb.overrideAttrs (old: { + qmakeFlags = old.qmakeFlags or [ ] ++ [ # Welcome to Escape Hell, we have backslashes - ''DEFINES+=OPENRGB_EXTRA_PLUGIN_DIRECTORY=\\\""${lib.escape ["\\" "\"" " "] (toString pluginsDir)}/lib\\\""'' + ''DEFINES+=OPENRGB_EXTRA_PLUGIN_DIRECTORY=\\\""${ + lib.escape [ "\\" "\"" " " ] (toString pluginsDir) + }/lib\\\""'' ]; }); diff --git a/pkgs/applications/misc/opentrack/aruco.nix b/pkgs/applications/misc/opentrack/aruco.nix index dddbfe78beabe1..291ff7ad24f942 100644 --- a/pkgs/applications/misc/opentrack/aruco.nix +++ b/pkgs/applications/misc/opentrack/aruco.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, cmake, fetchFromGitHub, opencv4 }: +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + opencv4, +}: stdenv.mkDerivation { pname = "opentrack-aruco"; diff --git a/pkgs/applications/misc/opentrack/default.nix b/pkgs/applications/misc/opentrack/default.nix index 13466240ffe0ed..8297117956c9ce 100644 --- a/pkgs/applications/misc/opentrack/default.nix +++ b/pkgs/applications/misc/opentrack/default.nix @@ -20,10 +20,11 @@ fetchurl, fetchpatch, wineWowPackages, -}: let +}: +let version = "2023.3.0"; - aruco = callPackage ./aruco.nix {}; + aruco = callPackage ./aruco.nix { }; # license.txt inside the zip file is MIT xplaneSdk = fetchzip { @@ -31,63 +32,76 @@ hash = "sha256-tUT9yV1949QVr5VebU/7esg7wwWkyak2TSA/kQSrbeo="; }; in - mkDerivation { - pname = "opentrack"; - inherit version; +mkDerivation { + pname = "opentrack"; + inherit version; - src = fetchFromGitHub { - owner = "opentrack"; - repo = "opentrack"; - rev = "opentrack-${version}"; - hash = "sha256-C0jLS55DcLJh/e5yM8kLG7fhhKvBNllv5HkfCWRIfc4="; - }; + src = fetchFromGitHub { + owner = "opentrack"; + repo = "opentrack"; + rev = "opentrack-${version}"; + hash = "sha256-C0jLS55DcLJh/e5yM8kLG7fhhKvBNllv5HkfCWRIfc4="; + }; - patches = [ - # https://github.com/opentrack/opentrack/pull/1754 - (fetchpatch { - url = "https://github.com/opentrack/opentrack/commit/d501d7e0b237ed0c305525788b423d842ffa356d.patch"; - hash = "sha256-XMGHV78vt/Xn3hS+4V//pqtsdBQCfJPjIXxfwtdXX+Q="; - }) - ]; + patches = [ + # https://github.com/opentrack/opentrack/pull/1754 + (fetchpatch { + url = "https://github.com/opentrack/opentrack/commit/d501d7e0b237ed0c305525788b423d842ffa356d.patch"; + hash = "sha256-XMGHV78vt/Xn3hS+4V//pqtsdBQCfJPjIXxfwtdXX+Q="; + }) + ]; - nativeBuildInputs = [cmake pkg-config ninja copyDesktopItems]; - buildInputs = [qtbase qttools opencv4 procps eigen libXdmcp libevdev aruco] - ++ lib.optionals pkgs.stdenv.targetPlatform.isx86_64 [ wineWowPackages.stable ]; + nativeBuildInputs = [ + cmake + pkg-config + ninja + copyDesktopItems + ]; + buildInputs = [ + qtbase + qttools + opencv4 + procps + eigen + libXdmcp + libevdev + aruco + ] ++ lib.optionals pkgs.stdenv.targetPlatform.isx86_64 [ wineWowPackages.stable ]; - env.NIX_CFLAGS_COMPILE = "-Wall -Wextra -Wpedantic -ffast-math -O3"; - dontWrapQtApps = true; + env.NIX_CFLAGS_COMPILE = "-Wall -Wextra -Wpedantic -ffast-math -O3"; + dontWrapQtApps = true; - cmakeFlags = [ - "-GNinja" - "-DCMAKE_BUILD_TYPE=Release" - "-DSDK_ARUCO_LIBPATH=${aruco}/lib/libaruco.a" - "-DSDK_XPLANE=${xplaneSdk}" - ] ++ lib.optionals pkgs.stdenv.targetPlatform.isx86_64 [ "-DSDK_WINE=ON" ]; + cmakeFlags = [ + "-GNinja" + "-DCMAKE_BUILD_TYPE=Release" + "-DSDK_ARUCO_LIBPATH=${aruco}/lib/libaruco.a" + "-DSDK_XPLANE=${xplaneSdk}" + ] ++ lib.optionals pkgs.stdenv.targetPlatform.isx86_64 [ "-DSDK_WINE=ON" ]; - postInstall = '' - wrapQtApp $out/bin/opentrack - ''; + postInstall = '' + wrapQtApp $out/bin/opentrack + ''; - desktopItems = [ - (makeDesktopItem rec { - name = "opentrack"; - exec = "opentrack"; - icon = fetchurl { - url = "https://github.com/opentrack/opentrack/raw/opentrack-${version}/gui/images/opentrack.png"; - hash = "sha256-9k3jToEpdW14ErbNGHM4c0x/LH7k14RmtvY4dOYnITQ="; - }; - desktopName = name; - genericName = "Head tracking software"; - categories = ["Utility"]; - }) - ]; + desktopItems = [ + (makeDesktopItem rec { + name = "opentrack"; + exec = "opentrack"; + icon = fetchurl { + url = "https://github.com/opentrack/opentrack/raw/opentrack-${version}/gui/images/opentrack.png"; + hash = "sha256-9k3jToEpdW14ErbNGHM4c0x/LH7k14RmtvY4dOYnITQ="; + }; + desktopName = name; + genericName = "Head tracking software"; + categories = [ "Utility" ]; + }) + ]; - meta = with lib; { - homepage = "https://github.com/opentrack/opentrack"; - description = "Head tracking software for MS Windows, Linux, and Apple OSX"; - mainProgram = "opentrack"; - changelog = "https://github.com/opentrack/opentrack/releases/tag/${version}"; - license = licenses.isc; - maintainers = with maintainers; [zaninime]; - }; - } + meta = with lib; { + homepage = "https://github.com/opentrack/opentrack"; + description = "Head tracking software for MS Windows, Linux, and Apple OSX"; + mainProgram = "opentrack"; + changelog = "https://github.com/opentrack/opentrack/releases/tag/${version}"; + license = licenses.isc; + maintainers = with maintainers; [ zaninime ]; + }; +} diff --git a/pkgs/applications/misc/opentx/default.nix b/pkgs/applications/misc/opentx/default.nix index 52d53c44cf3a8c..fba0292455a787 100644 --- a/pkgs/applications/misc/opentx/default.nix +++ b/pkgs/applications/misc/opentx/default.nix @@ -1,7 +1,17 @@ -{ lib, mkDerivation, fetchFromGitHub -, cmake, gcc-arm-embedded, python3Packages -, qtbase, qtmultimedia, qttools, SDL, gtest -, dfu-util, avrdude +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + gcc-arm-embedded, + python3Packages, + qtbase, + qtmultimedia, + qttools, + SDL, + gtest, + dfu-util, + avrdude, }: mkDerivation rec { @@ -15,9 +25,18 @@ mkDerivation rec { sha256 = "sha256-F3zykJhKuIpLQSTjn7mcdjEmgRAlwCZpkTaKQR9ve3g="; }; - nativeBuildInputs = [ cmake gcc-arm-embedded python3Packages.pillow qttools ]; + nativeBuildInputs = [ + cmake + gcc-arm-embedded + python3Packages.pillow + qttools + ]; - buildInputs = [ qtbase qtmultimedia SDL ]; + buildInputs = [ + qtbase + qtmultimedia + SDL + ]; postPatch = '' sed -i companion/src/burnconfigdialog.cpp \ @@ -45,8 +64,15 @@ mkDerivation rec { mainProgram = "companion" + lib.concatStrings (lib.take 2 (lib.splitVersion version)); homepage = "https://www.open-tx.org/"; license = licenses.gpl2Only; - platforms = [ "i686-linux" "x86_64-linux" "aarch64-linux" ]; - maintainers = with maintainers; [ elitak lopsided98 ]; + platforms = [ + "i686-linux" + "x86_64-linux" + "aarch64-linux" + ]; + maintainers = with maintainers; [ + elitak + lopsided98 + ]; }; } diff --git a/pkgs/applications/misc/orpie/default.nix b/pkgs/applications/misc/orpie/default.nix index b817c253830b65..0783d9cf16bfea 100644 --- a/pkgs/applications/misc/orpie/default.nix +++ b/pkgs/applications/misc/orpie/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, ocamlPackages }: +{ + lib, + fetchFromGitHub, + ocamlPackages, +}: ocamlPackages.buildDunePackage rec { pname = "orpie"; @@ -18,7 +22,11 @@ ocamlPackages.buildDunePackage rec { ''; nativeBuildInputs = [ ocamlPackages.camlp5 ]; - buildInputs = with ocamlPackages; [ curses num gsl ]; + buildInputs = with ocamlPackages; [ + curses + num + gsl + ]; meta = { inherit (src.meta) homepage; diff --git a/pkgs/applications/misc/osmscout-server/default.nix b/pkgs/applications/misc/osmscout-server/default.nix index 4772ac454fc682..a06269390b4e77 100644 --- a/pkgs/applications/misc/osmscout-server/default.nix +++ b/pkgs/applications/misc/osmscout-server/default.nix @@ -1,23 +1,24 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, fetchpatch -, pkg-config -, qmake -, qttools -, boost -, kirigami2 -, kyotocabinet -, libmicrohttpd -, libosmscout -, libpostal -, marisa -, osrm-backend -, protobuf -, qtquickcontrols2 -, qtlocation -, sqlite -, valhalla +{ + lib, + mkDerivation, + fetchFromGitHub, + fetchpatch, + pkg-config, + qmake, + qttools, + boost, + kirigami2, + kyotocabinet, + libmicrohttpd, + libosmscout, + libpostal, + marisa, + osrm-backend, + protobuf, + qtquickcontrols2, + qtlocation, + sqlite, + valhalla, }: let @@ -40,11 +41,26 @@ mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ qmake pkg-config qttools ]; + nativeBuildInputs = [ + qmake + pkg-config + qttools + ]; buildInputs = [ - kirigami2 qtquickcontrols2 qtlocation - valhalla libosmscout osrm-backend libmicrohttpd - libpostal sqlite marisa kyotocabinet boost protobuf date + kirigami2 + qtquickcontrols2 + qtlocation + valhalla + libosmscout + osrm-backend + libmicrohttpd + libpostal + sqlite + marisa + kyotocabinet + boost + protobuf + date ]; qmakeFlags = [ diff --git a/pkgs/applications/misc/parsec/bin.nix b/pkgs/applications/misc/parsec/bin.nix index b94c65c081254b..a1aa2bf422ed07 100644 --- a/pkgs/applications/misc/parsec/bin.nix +++ b/pkgs/applications/misc/parsec/bin.nix @@ -1,27 +1,28 @@ -{ stdenvNoCC -, stdenv -, lib -, dpkg -, autoPatchelfHook -, makeWrapper -, fetchurl -, alsa-lib -, openssl -, udev -, libglvnd -, libX11 -, libXcursor -, libXi -, libXrandr -, libXfixes -, libpulseaudio -, libva -, ffmpeg_6 -, libpng -, libjpeg8 -, curl -, vulkan-loader -, zenity +{ + stdenvNoCC, + stdenv, + lib, + dpkg, + autoPatchelfHook, + makeWrapper, + fetchurl, + alsa-lib, + openssl, + udev, + libglvnd, + libX11, + libXcursor, + libXi, + libXrandr, + libXfixes, + libpulseaudio, + libva, + ffmpeg_6, + libpng, + libjpeg8, + curl, + vulkan-loader, + zenity, }: stdenvNoCC.mkDerivation { @@ -33,7 +34,11 @@ stdenvNoCC.mkDerivation { sha256 = "sha256-9F56u+jYj2CClhbnGlLi65FxS1Vq00coxwu7mjVTY1w="; }; - nativeBuildInputs = [ dpkg autoPatchelfHook makeWrapper ]; + nativeBuildInputs = [ + dpkg + autoPatchelfHook + makeWrapper + ]; buildInputs = [ stdenv.cc.cc # libstdc++ @@ -108,7 +113,10 @@ stdenvNoCC.mkDerivation { changelog = "https://parsec.app/changelog"; description = "Remote streaming service client"; license = licenses.unfree; - maintainers = with maintainers; [ arcnmx pabloaul ]; + maintainers = with maintainers; [ + arcnmx + pabloaul + ]; platforms = platforms.linux; mainProgram = "parsecd"; }; diff --git a/pkgs/applications/misc/pastel/default.nix b/pkgs/applications/misc/pastel/default.nix index 5164e294a89bcc..e8b81cfeb59de5 100644 --- a/pkgs/applications/misc/pastel/default.nix +++ b/pkgs/applications/misc/pastel/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, +}: rustPlatform.buildRustPackage rec { pname = "pastel"; @@ -19,7 +25,10 @@ rustPlatform.buildRustPackage rec { description = "Command-line tool to generate, analyze, convert and manipulate colors"; homepage = "https://github.com/sharkdp/pastel"; changelog = "https://github.com/sharkdp/pastel/releases/tag/v${version}"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ davidtwco ]; mainProgram = "pastel"; }; diff --git a/pkgs/applications/misc/pattypan/default.nix b/pkgs/applications/misc/pattypan/default.nix index b5f48c51de8033..a02c8ae92f531f 100644 --- a/pkgs/applications/misc/pattypan/default.nix +++ b/pkgs/applications/misc/pattypan/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, ant -, jdk -, makeWrapper -, wrapGAppsHook3 -, makeDesktopItem -, copyDesktopItems -, stripJavaArchivesHook +{ + lib, + stdenv, + fetchFromGitHub, + ant, + jdk, + makeWrapper, + wrapGAppsHook3, + makeDesktopItem, + copyDesktopItems, + stripJavaArchivesHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/misc/pdfpc/default.nix b/pkgs/applications/misc/pdfpc/default.nix index f7fa1223a34c6b..661117bcaaceeb 100644 --- a/pkgs/applications/misc/pdfpc/default.nix +++ b/pkgs/applications/misc/pdfpc/default.nix @@ -1,6 +1,26 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, vala, gtk3, libgee -, poppler, libpthreadstubs, gstreamer, gst-plugins-base, gst-plugins-good, gst-libav, gobject-introspection, wrapGAppsHook3 -, qrencode, webkitgtk_4_0, discount, json-glib, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + vala, + gtk3, + libgee, + poppler, + libpthreadstubs, + gstreamer, + gst-plugins-base, + gst-plugins-good, + gst-libav, + gobject-introspection, + wrapGAppsHook3, + qrencode, + webkitgtk_4_0, + discount, + json-glib, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "pdfpc"; @@ -14,14 +34,18 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - cmake pkg-config vala + cmake + pkg-config + vala # For setup hook gobject-introspection wrapGAppsHook3 ]; buildInputs = [ - gtk3 libgee poppler + gtk3 + libgee + poppler libpthreadstubs gstreamer gst-plugins-base diff --git a/pkgs/applications/misc/pdfsam-basic/default.nix b/pkgs/applications/misc/pdfsam-basic/default.nix index 79d053fa20839d..a67a1821d554d8 100644 --- a/pkgs/applications/misc/pdfsam-basic/default.nix +++ b/pkgs/applications/misc/pdfsam-basic/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, makeDesktopItem, fetchurl, jdk21, wrapGAppsHook3, glib }: +{ + lib, + stdenv, + makeDesktopItem, + fetchurl, + jdk21, + wrapGAppsHook3, + glib, +}: stdenv.mkDerivation rec { pname = "pdfsam-basic"; diff --git a/pkgs/applications/misc/pe-bear/default.nix b/pkgs/applications/misc/pe-bear/default.nix index 7ee5f3167434f3..c85fc3f9403bea 100644 --- a/pkgs/applications/misc/pe-bear/default.nix +++ b/pkgs/applications/misc/pe-bear/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qtbase -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtbase, + wrapQtAppsHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/misc/peaclock/default.nix b/pkgs/applications/misc/peaclock/default.nix index 57f1a17685d8fb..7b495ed4dc30f6 100644 --- a/pkgs/applications/misc/peaclock/default.nix +++ b/pkgs/applications/misc/peaclock/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libpthreadstubs, icu }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libpthreadstubs, + icu, +}: stdenv.mkDerivation rec { pname = "peaclock"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libpthreadstubs icu ]; + buildInputs = [ + libpthreadstubs + icu + ]; meta = with lib; { description = "Clock, timer, and stopwatch for the terminal"; diff --git a/pkgs/applications/misc/pgmodeler/default.nix b/pkgs/applications/misc/pgmodeler/default.nix index 59c732ec81d06b..b1dcadb75b34c4 100644 --- a/pkgs/applications/misc/pgmodeler/default.nix +++ b/pkgs/applications/misc/pgmodeler/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, copyDesktopItems -, fetchFromGitHub -, makeDesktopItem -, wrapQtAppsHook -, pkg-config -, qmake -, qtwayland -, qtsvg -, postgresql -, cups -, libxml2 +{ + lib, + stdenv, + copyDesktopItems, + fetchFromGitHub, + makeDesktopItem, + wrapQtAppsHook, + pkg-config, + qmake, + qtwayland, + qtsvg, + postgresql, + cups, + libxml2, }: stdenv.mkDerivation rec { @@ -24,19 +25,36 @@ stdenv.mkDerivation rec { sha256 = "sha256-VbAGdMeuIQLzcHwYoPbkC0UjzxXgW4BGlYfz32oHmms="; }; - nativeBuildInputs = [ pkg-config qmake wrapQtAppsHook copyDesktopItems ]; - qmakeFlags = [ "pgmodeler.pro" "CONFIG+=release" ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "PGSQL_INC=${lib.getDev postgresql}/include" - "PGSQL_LIB=${lib.getLib postgresql}/lib/libpq.dylib" - "XML_INC=${libxml2.dev}/include/libxml2" - "XML_LIB=${libxml2.out}/lib/libxml2.dylib" - "PREFIX=${placeholder "out"}/Applications/pgModeler.app/Contents" + nativeBuildInputs = [ + pkg-config + qmake + wrapQtAppsHook + copyDesktopItems ]; + qmakeFlags = + [ + "pgmodeler.pro" + "CONFIG+=release" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "PGSQL_INC=${lib.getDev postgresql}/include" + "PGSQL_LIB=${lib.getLib postgresql}/lib/libpq.dylib" + "XML_INC=${libxml2.dev}/include/libxml2" + "XML_LIB=${libxml2.out}/lib/libxml2.dylib" + "PREFIX=${placeholder "out"}/Applications/pgModeler.app/Contents" + ]; # todo: libpq would suffice here. Unfortunately this won't work, if one uses only postgresql.lib here. - buildInputs = [ postgresql qtsvg ] + buildInputs = + [ + postgresql + qtsvg + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ qtwayland ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ cups libxml2 ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + cups + libxml2 + ]; desktopItems = [ (makeDesktopItem { @@ -51,15 +69,17 @@ stdenv.mkDerivation rec { }) ]; - postInstall = '' - install -Dm444 apps/pgmodeler/res/windows_ico.ico $out/share/icons/hicolor/256x256/apps/pgmodeler.ico - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/bin - for item in pgmodeler pgmodeler-{cli,se,ch} - do - ln -s $out/Applications/pgModeler.app/Contents/MacOS/$item $out/bin - done - ''; + postInstall = + '' + install -Dm444 apps/pgmodeler/res/windows_ico.ico $out/share/icons/hicolor/256x256/apps/pgmodeler.ico + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/bin + for item in pgmodeler pgmodeler-{cli,se,ch} + do + ln -s $out/Applications/pgModeler.app/Contents/MacOS/$item $out/bin + done + ''; dontWrapQtApps = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/applications/misc/plasma-applet-volumewin7mixer/default.nix b/pkgs/applications/misc/plasma-applet-volumewin7mixer/default.nix index 124b43f1bfae59..cba463516a6883 100644 --- a/pkgs/applications/misc/plasma-applet-volumewin7mixer/default.nix +++ b/pkgs/applications/misc/plasma-applet-volumewin7mixer/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, cmake, extra-cmake-modules, plasma-framework, kwindowsystem, plasma-pa, fetchFromGitHub }: +{ + lib, + stdenv, + cmake, + extra-cmake-modules, + plasma-framework, + kwindowsystem, + plasma-pa, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "plasma-applet-volumewin7mixer"; @@ -14,8 +23,15 @@ stdenv.mkDerivation rec { # Adds the CMakeLists.txt not provided by upstream patches = [ ./cmake.patch ]; postPatch = "rm build"; - nativeBuildInputs = [ cmake extra-cmake-modules ]; - buildInputs = [ plasma-framework kwindowsystem plasma-pa ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; + buildInputs = [ + plasma-framework + kwindowsystem + plasma-pa + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/misc/plasma-theme-switcher/default.nix b/pkgs/applications/misc/plasma-theme-switcher/default.nix index ecdece47c0b2e2..324cca93099f18 100644 --- a/pkgs/applications/misc/plasma-theme-switcher/default.nix +++ b/pkgs/applications/misc/plasma-theme-switcher/default.nix @@ -1,5 +1,11 @@ { - stdenv, lib, cmake, extra-cmake-modules, fetchFromGitHub, qtbase, kdeFrameworks + stdenv, + lib, + cmake, + extra-cmake-modules, + fetchFromGitHub, + qtbase, + kdeFrameworks, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/misc/plater/default.nix b/pkgs/applications/misc/plater/default.nix index e2e1906926a724..80cd745f8b9afe 100644 --- a/pkgs/applications/misc/plater/default.nix +++ b/pkgs/applications/misc/plater/default.nix @@ -1,11 +1,12 @@ -{ mkDerivation -, cmake -, fetchFromGitHub -, lib -, libGLU -, makeDesktopItem -, qtbase -, wrapQtAppsHook +{ + mkDerivation, + cmake, + fetchFromGitHub, + lib, + libGLU, + makeDesktopItem, + qtbase, + wrapQtAppsHook, }: mkDerivation rec { @@ -19,8 +20,14 @@ mkDerivation rec { sha256 = "0r20mbzd16zv1aiadjqdy7z6sp09rr6lgfxhvir4ll3cpakkynr4"; }; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; - buildInputs = [ libGLU qtbase ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; + buildInputs = [ + libGLU + qtbase + ]; desktopItem = makeDesktopItem { name = pname; @@ -28,7 +35,10 @@ mkDerivation rec { icon = pname; desktopName = "Ideamaker"; genericName = meta.description; - categories = ["Utility" "Engineering"]; + categories = [ + "Utility" + "Engineering" + ]; }; postInstall = '' diff --git a/pkgs/applications/misc/pomodoro/default.nix b/pkgs/applications/misc/pomodoro/default.nix index d9f76a75451b8f..b0afdcf23538d6 100644 --- a/pkgs/applications/misc/pomodoro/default.nix +++ b/pkgs/applications/misc/pomodoro/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Foundation }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Foundation, +}: rustPlatform.buildRustPackage rec { pname = "pomodoro"; diff --git a/pkgs/applications/misc/protonup-qt/default.nix b/pkgs/applications/misc/protonup-qt/default.nix index f5c47507893a28..20e51b4897cc15 100644 --- a/pkgs/applications/misc/protonup-qt/default.nix +++ b/pkgs/applications/misc/protonup-qt/default.nix @@ -1,4 +1,8 @@ -{ appimageTools, fetchurl, lib }: +{ + appimageTools, + fetchurl, + lib, +}: let pname = "protonup-qt"; version = "2.10.2"; diff --git a/pkgs/applications/misc/prusa-slicer/super-slicer.nix b/pkgs/applications/misc/prusa-slicer/super-slicer.nix index 358dc6781a4501..5d137f557fef5e 100644 --- a/pkgs/applications/misc/prusa-slicer/super-slicer.nix +++ b/pkgs/applications/misc/prusa-slicer/super-slicer.nix @@ -1,4 +1,12 @@ -{ lib, fetchFromGitHub, fetchpatch, makeDesktopItem, wxGTK31, prusa-slicer, libspnav }: +{ + lib, + fetchFromGitHub, + fetchpatch, + makeDesktopItem, + wxGTK31, + prusa-slicer, + libspnav, +}: let appname = "SuperSlicer"; pname = "super-slicer"; @@ -41,65 +49,76 @@ let }; }; - override = { version, hash, patches }: super: { - inherit version pname patches; + override = + { + version, + hash, + patches, + }: + super: { + inherit version pname patches; - src = fetchFromGitHub { - owner = "supermerill"; - repo = "SuperSlicer"; - inherit hash; - rev = version; - fetchSubmodules = true; - }; + src = fetchFromGitHub { + owner = "supermerill"; + repo = "SuperSlicer"; + inherit hash; + rev = version; + fetchSubmodules = true; + }; - # - wxScintilla is not used on macOS - # - Partially applied upstream changes cause a bug when trying to link against a nonexistent libexpat - postPatch = super.postPatch + '' - substituteInPlace src/CMakeLists.txt \ - --replace "scintilla" "" \ - --replace "list(APPEND wxWidgets_LIBRARIES libexpat)" "list(APPEND wxWidgets_LIBRARIES EXPAT::EXPAT)" + # - wxScintilla is not used on macOS + # - Partially applied upstream changes cause a bug when trying to link against a nonexistent libexpat + postPatch = + super.postPatch + + '' + substituteInPlace src/CMakeLists.txt \ + --replace "scintilla" "" \ + --replace "list(APPEND wxWidgets_LIBRARIES libexpat)" "list(APPEND wxWidgets_LIBRARIES EXPAT::EXPAT)" - substituteInPlace src/libslic3r/CMakeLists.txt \ - --replace "libexpat" "EXPAT::EXPAT" + substituteInPlace src/libslic3r/CMakeLists.txt \ + --replace "libexpat" "EXPAT::EXPAT" - # fixes GCC 14 error - substituteInPlace src/libslic3r/MeshBoolean.cpp \ - --replace-fail 'auto &face' 'auto face' \ - --replace-fail 'auto &vi' 'auto vi' - ''; + # fixes GCC 14 error + substituteInPlace src/libslic3r/MeshBoolean.cpp \ + --replace-fail 'auto &face' 'auto face' \ + --replace-fail 'auto &vi' 'auto vi' + ''; - # We don't need PS overrides anymore, and gcode-viewer is embedded in the binary. - postInstall = null; - separateDebugInfo = true; + # We don't need PS overrides anymore, and gcode-viewer is embedded in the binary. + postInstall = null; + separateDebugInfo = true; - buildInputs = super.buildInputs ++ [ - libspnav - ]; + buildInputs = super.buildInputs ++ [ + libspnav + ]; - desktopItems = [ - (makeDesktopItem { - name = "superslicer"; - exec = "superslicer"; - icon = appname; - comment = description; - desktopName = appname; - genericName = "3D printer tool"; - categories = [ "Development" ]; - }) - ]; + desktopItems = [ + (makeDesktopItem { + name = "superslicer"; + exec = "superslicer"; + icon = appname; + comment = description; + desktopName = appname; + genericName = "3D printer tool"; + categories = [ "Development" ]; + }) + ]; - meta = with lib; { - inherit description; - homepage = "https://github.com/supermerill/SuperSlicer"; - license = licenses.agpl3Plus; - maintainers = with maintainers; [ cab404 tmarkus ]; - mainProgram = "superslicer"; - }; + meta = with lib; { + inherit description; + homepage = "https://github.com/supermerill/SuperSlicer"; + license = licenses.agpl3Plus; + maintainers = with maintainers; [ + cab404 + tmarkus + ]; + mainProgram = "superslicer"; + }; - passthru = allVersions; + passthru = allVersions; - }; - wxGTK31-prusa = wxGTK31.overrideAttrs (old: rec { + }; + wxGTK31-prusa = wxGTK31.overrideAttrs (old: rec { pname = "wxwidgets-prusa3d-patched"; version = "3.1.4"; src = fetchFromGitHub { @@ -111,6 +130,8 @@ let }; }); prusa-slicer-wxGTK-override = prusa-slicer.override { wxGTK-override = wxGTK31-prusa; }; - allVersions = builtins.mapAttrs (_name: version: (prusa-slicer-wxGTK-override.overrideAttrs (override version))) versions; + allVersions = builtins.mapAttrs ( + _name: version: (prusa-slicer-wxGTK-override.overrideAttrs (override version)) + ) versions; in allVersions.stable diff --git a/pkgs/applications/misc/pueue/default.nix b/pkgs/applications/misc/pueue/default.nix index 1eff0355412c5a..31f19f4fbbe040 100644 --- a/pkgs/applications/misc/pueue/default.nix +++ b/pkgs/applications/misc/pueue/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, Libsystem -, SystemConfiguration -, installShellFiles -, libiconv -, rustPlatform +{ + lib, + stdenv, + fetchFromGitHub, + Libsystem, + SystemConfiguration, + installShellFiles, + libiconv, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -21,11 +22,13 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-sTpxcJs5I7LzVw56ka5PlFixJSiJeCae9serS0FhmuA="; - nativeBuildInputs = [ - installShellFiles - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - rustPlatform.bindgenHook - ]; + nativeBuildInputs = + [ + installShellFiles + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + rustPlatform.bindgenHook + ]; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Libsystem diff --git a/pkgs/applications/misc/pure-maps/default.nix b/pkgs/applications/misc/pure-maps/default.nix index c3fdc5b7ed66cf..f93c1e6cd8535b 100644 --- a/pkgs/applications/misc/pure-maps/default.nix +++ b/pkgs/applications/misc/pure-maps/default.nix @@ -1,7 +1,18 @@ -{ lib, mkDerivation, fetchFromGitHub -, cmake, qttools, kirigami2, qtquickcontrols2, qtlocation, qtsensors -, nemo-qml-plugin-dbus, mapbox-gl-qml, s2geometry -, python3, pyotherside +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + qttools, + kirigami2, + qtquickcontrols2, + qtlocation, + qtsensors, + nemo-qml-plugin-dbus, + mapbox-gl-qml, + s2geometry, + python3, + pyotherside, }: mkDerivation rec { @@ -17,12 +28,21 @@ mkDerivation rec { }; nativeBuildInputs = [ - cmake python3 qttools python3.pkgs.wrapPython + cmake + python3 + qttools + python3.pkgs.wrapPython ]; buildInputs = [ - kirigami2 qtquickcontrols2 qtlocation qtsensors - nemo-qml-plugin-dbus pyotherside mapbox-gl-qml s2geometry + kirigami2 + qtquickcontrols2 + qtlocation + qtsensors + nemo-qml-plugin-dbus + pyotherside + mapbox-gl-qml + s2geometry ]; cmakeFlags = [ "-DFLAVOR=kirigami" ]; diff --git a/pkgs/applications/misc/q4wine/default.nix b/pkgs/applications/misc/q4wine/default.nix index a06dbc8f47fc5b..b3cbb95729234d 100644 --- a/pkgs/applications/misc/q4wine/default.nix +++ b/pkgs/applications/misc/q4wine/default.nix @@ -1,7 +1,18 @@ -{ lib, fetchFromGitHub, mkDerivation, cmake, sqlite -, qtbase, qtsvg, qttools, wrapQtAppsHook -, icoutils # build and runtime deps. -, wget, fuseiso, wine, which # runtime deps. +{ + lib, + fetchFromGitHub, + mkDerivation, + cmake, + sqlite, + qtbase, + qtsvg, + qttools, + wrapQtAppsHook, + icoutils, # build and runtime deps. + wget, + fuseiso, + wine, + which, # runtime deps. }: mkDerivation rec { @@ -16,15 +27,30 @@ mkDerivation rec { }; buildInputs = [ - sqlite icoutils qtbase qtsvg qttools + sqlite + icoutils + qtbase + qtsvg + qttools ]; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; # Add runtime deps. postInstall = '' wrapProgram $out/bin/q4wine \ - --prefix PATH : ${lib.makeBinPath [ icoutils wget fuseiso wine which ]} + --prefix PATH : ${ + lib.makeBinPath [ + icoutils + wget + fuseiso + wine + which + ] + } ''; meta = with lib; { diff --git a/pkgs/applications/misc/qMasterPassword/default.nix b/pkgs/applications/misc/qMasterPassword/default.nix index 806d1df05fc44e..069e5ae7b48a66 100644 --- a/pkgs/applications/misc/qMasterPassword/default.nix +++ b/pkgs/applications/misc/qMasterPassword/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, libX11 -, libXtst -, cmake -, qtbase -, qttools -, qtwayland -, openssl -, libscrypt -, wrapQtAppsHook -, testers -, qMasterPassword -, x11Support ? true -, waylandSupport ? false +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + libXtst, + cmake, + qtbase, + qttools, + qtwayland, + openssl, + libscrypt, + wrapQtAppsHook, + testers, + qMasterPassword, + x11Support ? true, + waylandSupport ? false, }: stdenv.mkDerivation rec { @@ -27,29 +28,47 @@ stdenv.mkDerivation rec { hash = "sha256-4qxPjrf6r2S0l/hcs6bqfJm56jdDz+0a0xEkqGBYGBs="; }; - buildInputs = [ qtbase qtwayland openssl libscrypt ] ++ lib.optionals x11Support [ libX11 libXtst ]; - nativeBuildInputs = [ cmake qttools wrapQtAppsHook ]; + buildInputs = + [ + qtbase + qtwayland + openssl + libscrypt + ] + ++ lib.optionals x11Support [ + libX11 + libXtst + ]; + nativeBuildInputs = [ + cmake + qttools + wrapQtAppsHook + ]; cmakeFlags = lib.optionals waylandSupport [ "-DDISABLE_FILL_FORM_SHORTCUTS=1" ]; # Upstream install is mostly defunct. It hardcodes target.path and doesn't # install anything but the binary. - installPhase = if stdenv.hostPlatform.isDarwin then '' - mkdir -p "$out"/{Applications,bin} - mv qMasterPassword.app "$out"/Applications/ - ln -s ../Applications/qMasterPassword.app/Contents/MacOS/qMasterPassword "$out"/bin/qMasterPassword - '' else '' - mkdir -p $out/bin - mkdir -p $out/share/{applications,doc/qMasterPassword,icons/qmasterpassword,icons/hicolor/512x512/apps,qMasterPassword/translations} - cp qMasterPassword $out/bin - cp $src/data/qMasterPassword.desktop $out/share/applications - cp $src/LICENSE $src/README.md $out/share/doc/qMasterPassword - cp $src/data/icons/app_icon.png $out/share/icons/hicolor/512x512/apps/qmasterpassword.png - cp $src/data/icons/* $out/share/icons/qmasterpassword - cp ./translations/translation_de.qm $out/share/qMasterPassword/translations/translation_de.qm - cp ./translations/translation_pl.qm $out/share/qMasterPassword/translations/translation_pl.qm - ''; + installPhase = + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p "$out"/{Applications,bin} + mv qMasterPassword.app "$out"/Applications/ + ln -s ../Applications/qMasterPassword.app/Contents/MacOS/qMasterPassword "$out"/bin/qMasterPassword + '' + else + '' + mkdir -p $out/bin + mkdir -p $out/share/{applications,doc/qMasterPassword,icons/qmasterpassword,icons/hicolor/512x512/apps,qMasterPassword/translations} + cp qMasterPassword $out/bin + cp $src/data/qMasterPassword.desktop $out/share/applications + cp $src/LICENSE $src/README.md $out/share/doc/qMasterPassword + cp $src/data/icons/app_icon.png $out/share/icons/hicolor/512x512/apps/qmasterpassword.png + cp $src/data/icons/* $out/share/icons/qmasterpassword + cp ./translations/translation_de.qm $out/share/qMasterPassword/translations/translation_de.qm + cp ./translations/translation_pl.qm $out/share/qMasterPassword/translations/translation_pl.qm + ''; passthru = { tests.version = testers.testVersion { diff --git a/pkgs/applications/misc/qelectrotech/default.nix b/pkgs/applications/misc/qelectrotech/default.nix index 705618bd2f01c5..a7dc6d32d83e51 100644 --- a/pkgs/applications/misc/qelectrotech/default.nix +++ b/pkgs/applications/misc/qelectrotech/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, mkDerivation -, fetchzip -, installShellFiles -, pkg-config -, qmake -, qtbase -, kcoreaddons -, kwidgetsaddons +{ + lib, + stdenv, + mkDerivation, + fetchzip, + installShellFiles, + pkg-config, + qmake, + qtbase, + kcoreaddons, + kwidgetsaddons, }: mkDerivation rec { diff --git a/pkgs/applications/misc/qlcplus/default.nix b/pkgs/applications/misc/qlcplus/default.nix index 806a2fed8943ab..e61fbe2864e501 100644 --- a/pkgs/applications/misc/qlcplus/default.nix +++ b/pkgs/applications/misc/qlcplus/default.nix @@ -1,6 +1,19 @@ -{ lib, mkDerivation, fetchFromGitHub, qmake, pkg-config, udev -, qtmultimedia, qtscript, qtserialport, alsa-lib, ola, libftdi1, libusb-compat-0_1 -, libsndfile, libmad +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + pkg-config, + udev, + qtmultimedia, + qtscript, + qtserialport, + alsa-lib, + ola, + libftdi1, + libusb-compat-0_1, + libsndfile, + libmad, }: mkDerivation rec { @@ -14,9 +27,21 @@ mkDerivation rec { sha256 = "sha256-AKmPxHOlMtea3q0NDULp3XfJ0JnYeF/iFUJw0dDOiio="; }; - nativeBuildInputs = [ qmake pkg-config ]; + nativeBuildInputs = [ + qmake + pkg-config + ]; buildInputs = [ - udev qtmultimedia qtscript qtserialport alsa-lib ola libftdi1 libusb-compat-0_1 libsndfile libmad + udev + qtmultimedia + qtscript + qtserialport + alsa-lib + ola + libftdi1 + libusb-compat-0_1 + libsndfile + libmad ]; qmakeFlags = [ "INSTALLROOT=$(out)" ]; diff --git a/pkgs/applications/misc/qolibri/default.nix b/pkgs/applications/misc/qolibri/default.nix index 4b8213d46d607c..bd4dfaf58a85c8 100644 --- a/pkgs/applications/misc/qolibri/default.nix +++ b/pkgs/applications/misc/qolibri/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, ninja -, qttools -, qtwebengine -, wrapQtAppsHook +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + ninja, + qttools, + qtwebengine, + wrapQtAppsHook, }: let diff --git a/pkgs/applications/misc/qsudo/default.nix b/pkgs/applications/misc/qsudo/default.nix index a573ba814a427e..d379b95eb2bb82 100644 --- a/pkgs/applications/misc/qsudo/default.nix +++ b/pkgs/applications/misc/qsudo/default.nix @@ -1,9 +1,10 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, qmake -, qtbase -, sudo +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qtbase, + sudo, }: mkDerivation rec { diff --git a/pkgs/applications/misc/qsyncthingtray/default.nix b/pkgs/applications/misc/qsyncthingtray/default.nix index 68baf5e08ebb3c..523a91b92f4f7d 100644 --- a/pkgs/applications/misc/qsyncthingtray/default.nix +++ b/pkgs/applications/misc/qsyncthingtray/default.nix @@ -1,34 +1,49 @@ -{ mkDerivation, stdenv, lib, fetchFromGitHub, fetchpatch, procps -, qtbase, qtwebengine, qtwebkit -, cmake -, syncthing -, preferQWebView ? false -, preferNative ? true }: +{ + mkDerivation, + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + procps, + qtbase, + qtwebengine, + qtwebkit, + cmake, + syncthing, + preferQWebView ? false, + preferNative ? true, +}: mkDerivation rec { version = "0.5.8"; pname = "qsyncthingtray"; src = fetchFromGitHub { - owner = "sieren"; - repo = "QSyncthingTray"; - rev = version; + owner = "sieren"; + repo = "QSyncthingTray"; + rev = version; sha256 = "1n9g4j7qznvg9zl6x163pi9f7wsc3x6q76i33psnm7x2v1i22x5w"; }; - buildInputs = [ qtbase qtwebengine ] ++ lib.optional preferQWebView qtwebkit; + buildInputs = [ + qtbase + qtwebengine + ] ++ lib.optional preferQWebView qtwebkit; nativeBuildInputs = [ cmake ]; - cmakeFlags = [ ] + cmakeFlags = + [ ] ++ lib.optional preferQWebView "-DQST_BUILD_WEBKIT=1" - ++ lib.optional preferNative "-DQST_BUILD_NATIVEBROWSER=1"; + ++ lib.optional preferNative "-DQST_BUILD_NATIVEBROWSER=1"; - patches = [ (fetchpatch { - name = "support_native_browser.patch"; - url = "https://patch-diff.githubusercontent.com/raw/sieren/QSyncthingTray/pull/225.patch"; - sha256 = "0w665xdlsbjxs977pdpzaclxpswf7xys1q3rxriz181lhk2y66yy"; - }) ] ++ lib.optional (!preferQWebView && !preferNative) ./qsyncthingtray-0.5.8-qt-5.6.3.patch; + patches = [ + (fetchpatch { + name = "support_native_browser.patch"; + url = "https://patch-diff.githubusercontent.com/raw/sieren/QSyncthingTray/pull/225.patch"; + sha256 = "0w665xdlsbjxs977pdpzaclxpswf7xys1q3rxriz181lhk2y66yy"; + }) + ] ++ lib.optional (!preferQWebView && !preferNative) ./qsyncthingtray-0.5.8-qt-5.6.3.patch; postPatch = '' ${lib.optionalString stdenv.hostPlatform.isLinux '' @@ -43,26 +58,33 @@ mkDerivation rec { ''} ''; - installPhase = let qst = "qsyncthingtray"; in '' - runHook preInstall + installPhase = + let + qst = "qsyncthingtray"; + in + '' + runHook preInstall - mkdir -p $out/bin - install -m755 QSyncthingTray $out/bin/${qst} - ln -s $out/bin/${qst} $out/bin/QSyncthingTray + mkdir -p $out/bin + install -m755 QSyncthingTray $out/bin/${qst} + ln -s $out/bin/${qst} $out/bin/QSyncthingTray - runHook postInstall - ''; + runHook postInstall + ''; meta = with lib; { homepage = "https://github.com/sieren/QSyncthingTray/"; description = "Traybar Application for Syncthing written in C++"; longDescription = '' - A cross-platform status bar for Syncthing. - Currently supports macOS, Windows and Linux. - Written in C++ with Qt. + A cross-platform status bar for Syncthing. + Currently supports macOS, Windows and Linux. + Written in C++ with Qt. ''; license = licenses.lgpl3; - maintainers = with maintainers; [ zraexy peterhoeg ]; + maintainers = with maintainers; [ + zraexy + peterhoeg + ]; platforms = platforms.all; broken = !preferNative || stdenv.hostPlatform.isDarwin; }; diff --git a/pkgs/applications/misc/qt-box-editor/default.nix b/pkgs/applications/misc/qt-box-editor/default.nix index 937641021a5c29..7d584f78645dda 100644 --- a/pkgs/applications/misc/qt-box-editor/default.nix +++ b/pkgs/applications/misc/qt-box-editor/default.nix @@ -1,11 +1,12 @@ -{ mkDerivation -, lib -, fetchFromGitHub -, qtbase -, qtsvg -, qmake -, leptonica -, tesseract4 +{ + mkDerivation, + lib, + fetchFromGitHub, + qtbase, + qtsvg, + qmake, + leptonica, + tesseract4, }: mkDerivation { @@ -19,7 +20,12 @@ mkDerivation { hash = "sha256-3dWnAu0CLO3atjbC1zJEnL3vzsIEecDDDhW3INMfCv4="; }; - buildInputs = [ qtbase qtsvg leptonica tesseract4 ]; + buildInputs = [ + qtbase + qtsvg + leptonica + tesseract4 + ]; nativeBuildInputs = [ qmake ]; diff --git a/pkgs/applications/misc/qt-video-wlr/default.nix b/pkgs/applications/misc/qt-video-wlr/default.nix index dc634a8f2ad8b0..7b3fe39b6d1ae7 100644 --- a/pkgs/applications/misc/qt-video-wlr/default.nix +++ b/pkgs/applications/misc/qt-video-wlr/default.nix @@ -1,13 +1,30 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config, meson, cmake, ninja, gst_all_1, wrapQtAppsHook, qtbase, qtmultimedia, layer-shell-qt, wayland-scanner }: +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + meson, + cmake, + ninja, + gst_all_1, + wrapQtAppsHook, + qtbase, + qtmultimedia, + layer-shell-qt, + wayland-scanner, +}: let - gstreamerPath = with gst_all_1; lib.makeSearchPathOutput "lib" "lib/gstreamer-1.0" [ - gstreamer - gst-plugins-base - gst-plugins-good - gst-plugins-bad - gst-plugins-ugly - ]; -in stdenv.mkDerivation rec { + gstreamerPath = + with gst_all_1; + lib.makeSearchPathOutput "lib" "lib/gstreamer-1.0" [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + gst-plugins-ugly + ]; +in +stdenv.mkDerivation rec { pname = "qt-video-wlr"; version = "2023-07-22"; @@ -43,7 +60,10 @@ in stdenv.mkDerivation rec { mainProgram = "qt-video-wlr"; homepage = "https://github.com/xdavidwu/qt-video-wlr"; license = licenses.mit; - maintainers = with maintainers; [ fionera rewine ]; + maintainers = with maintainers; [ + fionera + rewine + ]; platforms = with platforms; linux; }; } diff --git a/pkgs/applications/misc/qtbitcointrader/default.nix b/pkgs/applications/misc/qtbitcointrader/default.nix index ce265d5f67fd4b..89ed268ff5ced2 100644 --- a/pkgs/applications/misc/qtbitcointrader/default.nix +++ b/pkgs/applications/misc/qtbitcointrader/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, qt5, mkDerivation }: +{ + lib, + fetchFromGitHub, + qt5, + mkDerivation, +}: mkDerivation rec { pname = "qtbitcointrader"; @@ -11,7 +16,11 @@ mkDerivation rec { sha256 = "sha256-u3+Kwn8KunYUpWCd55TQuVVfoSp8hdti93d6hk7Uqx8="; }; - buildInputs = [ qt5.qtbase qt5.qtmultimedia qt5.qtscript ]; + buildInputs = [ + qt5.qtbase + qt5.qtmultimedia + qt5.qtscript + ]; postUnpack = "sourceRoot=\${sourceRoot}/src"; diff --git a/pkgs/applications/misc/qtpass/default.nix b/pkgs/applications/misc/qtpass/default.nix index e37056e86a56a7..56a43e10e360a3 100644 --- a/pkgs/applications/misc/qtpass/default.nix +++ b/pkgs/applications/misc/qtpass/default.nix @@ -1,6 +1,17 @@ -{ fetchFromGitHub, lib, stdenv -, git, gnupg, pass, pwgen, qrencode -, qtbase, qtsvg, qttools, qmake, wrapQtAppsHook +{ + fetchFromGitHub, + lib, + stdenv, + git, + gnupg, + pass, + pwgen, + qrencode, + qtbase, + qtsvg, + qttools, + qmake, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -19,9 +30,19 @@ stdenv.mkDerivation rec { --replace "/usr/bin/qrencode" "${qrencode}/bin/qrencode" ''; - buildInputs = [ git gnupg pass qtbase qtsvg ]; + buildInputs = [ + git + gnupg + pass + qtbase + qtsvg + ]; - nativeBuildInputs = [ qmake qttools wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + qttools + wrapQtAppsHook + ]; qmakeFlags = [ # setup hook only sets QMAKE_LRELEASE, set QMAKE_LUPDATE too: @@ -29,7 +50,14 @@ stdenv.mkDerivation rec { ]; qtWrapperArgs = [ - "--suffix PATH : ${lib.makeBinPath [ git gnupg pass pwgen ]}" + "--suffix PATH : ${ + lib.makeBinPath [ + git + gnupg + pass + pwgen + ] + }" ]; postInstall = '' diff --git a/pkgs/applications/misc/razergenie/default.nix b/pkgs/applications/misc/razergenie/default.nix index 9b18c60447e39e..ca5ac7f4a42ea6 100644 --- a/pkgs/applications/misc/razergenie/default.nix +++ b/pkgs/applications/misc/razergenie/default.nix @@ -1,14 +1,23 @@ -{ stdenv, fetchFromGitHub, lib, meson, ninja, pkg-config, qtbase, qttools -, wrapQtAppsHook -, enableExperimental ? false -, includeMatrixDiscovery ? false +{ + stdenv, + fetchFromGitHub, + lib, + meson, + ninja, + pkg-config, + qtbase, + qttools, + wrapQtAppsHook, + enableExperimental ? false, + includeMatrixDiscovery ? false, }: let version = "0.9.0"; pname = "razergenie"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname version; src = fetchFromGitHub { @@ -19,11 +28,15 @@ in stdenv.mkDerivation { }; nativeBuildInputs = [ - pkg-config meson ninja wrapQtAppsHook + pkg-config + meson + ninja + wrapQtAppsHook ]; buildInputs = [ - qtbase qttools + qtbase + qttools ]; mesonFlags = [ @@ -36,7 +49,10 @@ in stdenv.mkDerivation { description = "Qt application for configuring your Razer devices under GNU/Linux"; mainProgram = "razergenie"; license = licenses.gpl3; - maintainers = with maintainers; [ f4814n Mogria ]; + maintainers = with maintainers; [ + f4814n + Mogria + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/misc/reddsaver/default.nix b/pkgs/applications/misc/reddsaver/default.nix index c544dc44888f02..46e684d0d36e41 100644 --- a/pkgs/applications/misc/reddsaver/default.nix +++ b/pkgs/applications/misc/reddsaver/default.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitHub -, rustPlatform -, openssl -, pkg-config -, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + openssl, + pkg-config, + Security, }: rustPlatform.buildRustPackage rec { @@ -20,8 +22,7 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-l+fxk9gkM+pStBVJcsN4P2tNCuFIiBaAxpq9SLlvJHk="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optional stdenv.hostPlatform.isDarwin Security; + buildInputs = [ openssl ] ++ lib.optional stdenv.hostPlatform.isDarwin Security; # package does not contain tests as of v0.3.3 docCheck = false; @@ -29,7 +30,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "CLI tool to download saved media from Reddit"; homepage = "https://github.com/manojkarthick/reddsaver"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = [ maintainers.manojkarthick ]; mainProgram = "reddsaver"; }; diff --git a/pkgs/applications/misc/redshift-plasma-applet/default.nix b/pkgs/applications/misc/redshift-plasma-applet/default.nix index 9bc39aaac4ff65..8a198a702eaabd 100644 --- a/pkgs/applications/misc/redshift-plasma-applet/default.nix +++ b/pkgs/applications/misc/redshift-plasma-applet/default.nix @@ -1,6 +1,18 @@ -{ lib, stdenv, cmake, extra-cmake-modules, plasma-framework, kwindowsystem, redshift, fetchFromGitHub, fetchpatch, }: +{ + lib, + stdenv, + cmake, + extra-cmake-modules, + plasma-framework, + kwindowsystem, + redshift, + fetchFromGitHub, + fetchpatch, +}: -let version = "1.0.18"; in +let + version = "1.0.18"; +in stdenv.mkDerivation { pname = "redshift-plasma-applet"; @@ -20,7 +32,7 @@ stdenv.mkDerivation { # Without it scrolling makes the screen gets darker and darker until it is impossible to see anything. (fetchpatch { url = "https://invent.kde.org/plasma/plasma-redshift-control/-/commit/898c3a4cfc6c317915f1e664078d8606497c4049.patch"; - sha256 = "0b6pa3fcj698mgqnc85jbbmcl3qpf418mh06qgsd3c4v237my0nv"; + sha256 = "0b6pa3fcj698mgqnc85jbbmcl3qpf418mh06qgsd3c4v237my0nv"; }) ]; @@ -53,6 +65,9 @@ stdenv.mkDerivation { homepage = "https://github.com/kotelnik/plasma-applet-redshift-control"; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ benley zraexy ]; + maintainers = with maintainers; [ + benley + zraexy + ]; }; } diff --git a/pkgs/applications/misc/redshift/default.nix b/pkgs/applications/misc/redshift/default.nix index 6451fa2c7acf9a..31e866d0e7c5c3 100644 --- a/pkgs/applications/misc/redshift/default.nix +++ b/pkgs/applications/misc/redshift/default.nix @@ -1,24 +1,59 @@ -{ lib, stdenv, fetchFromGitHub, fetchFromGitLab -, autoconf, automake, gettext, intltool -, libtool, pkg-config, wrapGAppsHook3, wrapPython, gobject-introspection, wayland-scanner -, gtk3, python, pygobject3, pyxdg - -, withQuartz ? stdenv.hostPlatform.isDarwin, ApplicationServices -, withRandr ? stdenv.hostPlatform.isLinux, libxcb -, withDrm ? stdenv.hostPlatform.isLinux, libdrm -, withVidmode ? stdenv.hostPlatform.isLinux, libXxf86vm - -, withGeolocation ? true -, withCoreLocation ? withGeolocation && stdenv.hostPlatform.isDarwin, CoreLocation, Foundation, Cocoa -, withGeoclue ? withGeolocation && stdenv.hostPlatform.isLinux, geoclue -, withAppIndicator ? stdenv.hostPlatform.isLinux, libappindicator, libayatana-appindicator +{ + lib, + stdenv, + fetchFromGitHub, + fetchFromGitLab, + autoconf, + automake, + gettext, + intltool, + libtool, + pkg-config, + wrapGAppsHook3, + wrapPython, + gobject-introspection, + wayland-scanner, + gtk3, + python, + pygobject3, + pyxdg, + + withQuartz ? stdenv.hostPlatform.isDarwin, + ApplicationServices, + withRandr ? stdenv.hostPlatform.isLinux, + libxcb, + withDrm ? stdenv.hostPlatform.isLinux, + libdrm, + withVidmode ? stdenv.hostPlatform.isLinux, + libXxf86vm, + + withGeolocation ? true, + withCoreLocation ? withGeolocation && stdenv.hostPlatform.isDarwin, + CoreLocation, + Foundation, + Cocoa, + withGeoclue ? withGeolocation && stdenv.hostPlatform.isLinux, + geoclue, + withAppIndicator ? stdenv.hostPlatform.isLinux, + libappindicator, + libayatana-appindicator, }: let mkRedshift = - { pname, version, src, meta }: + { + pname, + version, + src, + meta, + }: stdenv.mkDerivation rec { - inherit pname version src meta; + inherit + pname + version + src + meta + ; patches = lib.optionals (pname != "gammastep") [ # https://github.com/jonls/redshift/pull/575 @@ -42,33 +77,43 @@ let python ] ++ lib.optionals (pname == "gammastep") [ wayland-scanner ]; - configureFlags = [ - "--enable-randr=${if withRandr then "yes" else "no"}" - "--enable-geoclue2=${if withGeoclue then "yes" else "no"}" - "--enable-drm=${if withDrm then "yes" else "no"}" - "--enable-vidmode=${if withVidmode then "yes" else "no"}" - "--enable-quartz=${if withQuartz then "yes" else "no"}" - "--enable-corelocation=${if withCoreLocation then "yes" else "no"}" - ] ++ lib.optionals (pname == "gammastep") [ - "--with-systemduserunitdir=${placeholder "out"}/lib/systemd/user/" - "--enable-apparmor" + configureFlags = + [ + "--enable-randr=${if withRandr then "yes" else "no"}" + "--enable-geoclue2=${if withGeoclue then "yes" else "no"}" + "--enable-drm=${if withDrm then "yes" else "no"}" + "--enable-vidmode=${if withVidmode then "yes" else "no"}" + "--enable-quartz=${if withQuartz then "yes" else "no"}" + "--enable-corelocation=${if withCoreLocation then "yes" else "no"}" + ] + ++ lib.optionals (pname == "gammastep") [ + "--with-systemduserunitdir=${placeholder "out"}/lib/systemd/user/" + "--enable-apparmor" + ]; + + buildInputs = + [ + gtk3 + ] + ++ lib.optional withRandr libxcb + ++ lib.optional withGeoclue geoclue + ++ lib.optional withDrm libdrm + ++ lib.optional withVidmode libXxf86vm + ++ lib.optional withQuartz ApplicationServices + ++ lib.optionals withCoreLocation [ + CoreLocation + Foundation + Cocoa + ] + ++ lib.optional withAppIndicator ( + if (pname != "gammastep") then libappindicator else libayatana-appindicator + ); + + pythonPath = [ + pygobject3 + pyxdg ]; - buildInputs = [ - gtk3 - ] ++ lib.optional withRandr libxcb - ++ lib.optional withGeoclue geoclue - ++ lib.optional withDrm libdrm - ++ lib.optional withVidmode libXxf86vm - ++ lib.optional withQuartz ApplicationServices - ++ lib.optionals withCoreLocation [ CoreLocation Foundation Cocoa ] - ++ lib.optional withAppIndicator (if (pname != "gammastep") - then libappindicator - else libayatana-appindicator) - ; - - pythonPath = [ pygobject3 pyxdg ]; - preConfigure = "./bootstrap"; dontWrapGApps = true; @@ -84,17 +129,21 @@ let # the geoclue agent may inspect these paths and expect them to be # valid without having the correct $PATH set - postInstall = if (pname == "gammastep") then '' - substituteInPlace $out/share/applications/gammastep.desktop \ - --replace 'Exec=gammastep' "Exec=$out/bin/gammastep" - substituteInPlace $out/share/applications/gammastep-indicator.desktop \ - --replace 'Exec=gammastep-indicator' "Exec=$out/bin/gammastep-indicator" - '' else '' - substituteInPlace $out/share/applications/redshift.desktop \ - --replace 'Exec=redshift' "Exec=$out/bin/redshift" - substituteInPlace $out/share/applications/redshift-gtk.desktop \ - --replace 'Exec=redshift-gtk' "Exec=$out/bin/redshift-gtk" - ''; + postInstall = + if (pname == "gammastep") then + '' + substituteInPlace $out/share/applications/gammastep.desktop \ + --replace 'Exec=gammastep' "Exec=$out/bin/gammastep" + substituteInPlace $out/share/applications/gammastep-indicator.desktop \ + --replace 'Exec=gammastep-indicator' "Exec=$out/bin/gammastep-indicator" + '' + else + '' + substituteInPlace $out/share/applications/redshift.desktop \ + --replace 'Exec=redshift' "Exec=$out/bin/redshift" + substituteInPlace $out/share/applications/redshift-gtk.desktop \ + --replace 'Exec=redshift-gtk' "Exec=$out/bin/redshift-gtk" + ''; enableParallelBuilding = true; }; @@ -142,8 +191,7 @@ rec { meta = redshift.meta // { name = "${pname}-${version}"; - longDescription = "Gammastep" - + lib.removePrefix "Redshift" redshift.meta.longDescription; + longDescription = "Gammastep" + lib.removePrefix "Redshift" redshift.meta.longDescription; homepage = "https://gitlab.com/chinstrap/gammastep"; mainProgram = "gammastep"; maintainers = (with lib.maintainers; [ primeos ]) ++ redshift.meta.maintainers; diff --git a/pkgs/applications/misc/remarkable/remarkable-mouse/default.nix b/pkgs/applications/misc/remarkable/remarkable-mouse/default.nix index 8d59f0ae99f66c..5a85f5ab4867d9 100644 --- a/pkgs/applications/misc/remarkable/remarkable-mouse/default.nix +++ b/pkgs/applications/misc/remarkable/remarkable-mouse/default.nix @@ -1,4 +1,9 @@ -{ lib, buildPythonApplication, fetchPypi, python3Packages }: +{ + lib, + buildPythonApplication, + fetchPypi, + python3Packages, +}: buildPythonApplication rec { pname = "remarkable-mouse"; @@ -9,7 +14,12 @@ buildPythonApplication rec { hash = "sha256-82P9tE3jiUlKBGZCiWDoL+9VJ06Bc+If+aMfcEEU90U="; }; - propagatedBuildInputs = with python3Packages; [ screeninfo paramiko pynput libevdev ]; + propagatedBuildInputs = with python3Packages; [ + screeninfo + paramiko + pynput + libevdev + ]; # no tests doCheck = false; diff --git a/pkgs/applications/misc/remarkable/rmview/default.nix b/pkgs/applications/misc/remarkable/rmview/default.nix index 40ffc4df8b9126..5831773cfd8cec 100644 --- a/pkgs/applications/misc/remarkable/rmview/default.nix +++ b/pkgs/applications/misc/remarkable/rmview/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, python3Packages, wrapQtAppsHook }: +{ + lib, + fetchFromGitHub, + python3Packages, + wrapQtAppsHook, +}: python3Packages.buildPythonApplication rec { pname = "rmview"; @@ -12,8 +17,20 @@ python3Packages.buildPythonApplication rec { sha256 = "sha256-V26zmu8cQkLs0IMR7eFO8x34McnT3xYyzlZfntApYkk="; }; - nativeBuildInputs = with python3Packages; [ pyqt5 setuptools wrapQtAppsHook ]; - propagatedBuildInputs = with python3Packages; [ pyqt5 paramiko twisted pyjwt pyopenssl service-identity sshtunnel ]; + nativeBuildInputs = with python3Packages; [ + pyqt5 + setuptools + wrapQtAppsHook + ]; + propagatedBuildInputs = with python3Packages; [ + pyqt5 + paramiko + twisted + pyjwt + pyopenssl + service-identity + sshtunnel + ]; preBuild = '' pyrcc5 -o src/rmview/resources.py resources.qrc diff --git a/pkgs/applications/misc/rescuetime/default.nix b/pkgs/applications/misc/rescuetime/default.nix index fa1cfe4afb623e..7788357f97604f 100644 --- a/pkgs/applications/misc/rescuetime/default.nix +++ b/pkgs/applications/misc/rescuetime/default.nix @@ -1,18 +1,38 @@ -{ stdenv, lib, fetchurl, dpkg, patchelf, qt5, libXtst, libXext, libX11, mkDerivation, libXScrnSaver, writeScript, common-updater-scripts, curl, pup }: +{ + stdenv, + lib, + fetchurl, + dpkg, + patchelf, + qt5, + libXtst, + libXext, + libX11, + mkDerivation, + libXScrnSaver, + writeScript, + common-updater-scripts, + curl, + pup, +}: let version = "2.16.5.1"; src = - if stdenv.hostPlatform.system == "i686-linux" then fetchurl { - name = "rescuetime-installer.deb"; - url = "https://www.rescuetime.com/installers/rescuetime_${version}_i386.deb"; - sha256 = "1xrvyy0higc1fbc8ascpaszvg2bl6x0a35bzmdq6dkay48hnrd8b"; - } else fetchurl { - name = "rescuetime-installer.deb"; - url = "https://www.rescuetime.com/installers/rescuetime_${version}_amd64.deb"; - sha256 = "09ng0yal66d533vzfv27k9l2va03rqbqmsni43qi3hgx7w9wx5ii"; - }; -in mkDerivation rec { + if stdenv.hostPlatform.system == "i686-linux" then + fetchurl { + name = "rescuetime-installer.deb"; + url = "https://www.rescuetime.com/installers/rescuetime_${version}_i386.deb"; + sha256 = "1xrvyy0higc1fbc8ascpaszvg2bl6x0a35bzmdq6dkay48hnrd8b"; + } + else + fetchurl { + name = "rescuetime-installer.deb"; + url = "https://www.rescuetime.com/installers/rescuetime_${version}_amd64.deb"; + sha256 = "09ng0yal66d533vzfv27k9l2va03rqbqmsni43qi3hgx7w9wx5ii"; + }; +in +mkDerivation rec { # https://www.rescuetime.com/updates/linux_release_notes.html inherit version; pname = "rescuetime"; @@ -27,14 +47,28 @@ in mkDerivation rec { ${patchelf}/bin/patchelf \ --interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath "${lib.makeLibraryPath [ qt5.qtbase libXtst libXext libX11 libXScrnSaver ]}" \ + --set-rpath "${ + lib.makeLibraryPath [ + qt5.qtbase + libXtst + libXext + libX11 + libXScrnSaver + ] + }" \ $out/bin/rescuetime ''; passthru.updateScript = writeScript "${pname}-updater" '' #!${stdenv.shell} set -eu -o pipefail - PATH=${lib.makeBinPath [curl pup common-updater-scripts]}:$PATH + PATH=${ + lib.makeBinPath [ + curl + pup + common-updater-scripts + ] + }:$PATH latestVersion="$(curl -sS https://www.rescuetime.com/release-notes/linux | pup '.release:first-of-type h2 strong text{}' | tr -d '\n')" for platform in ${lib.concatStringsSep " " meta.platforms}; do @@ -44,10 +78,13 @@ in mkDerivation rec { meta = with lib; { description = "Helps you understand your daily habits so you can focus and be more productive"; - homepage = "https://www.rescuetime.com"; + homepage = "https://www.rescuetime.com"; maintainers = [ ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.unfree; - platforms = [ "i686-linux" "x86_64-linux" ]; + license = licenses.unfree; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/applications/misc/resp-app/default.nix b/pkgs/applications/misc/resp-app/default.nix index 18e7a1c7224178..25f80e3e2a83c6 100644 --- a/pkgs/applications/misc/resp-app/default.nix +++ b/pkgs/applications/misc/resp-app/default.nix @@ -1,20 +1,21 @@ -{ mkDerivation -, lib -, fetchFromGitHub -, fetchpatch -, brotli -, lz4 -, pyotherside -, python3 -, python3Packages -, qtbase -, qtcharts -, qmake -, qttools -, rdbtools -, snappy -, wrapQtAppsHook -, zstd +{ + mkDerivation, + lib, + fetchFromGitHub, + fetchpatch, + brotli, + lz4, + pyotherside, + python3, + python3Packages, + qtbase, + qtcharts, + qmake, + qttools, + rdbtools, + snappy, + wrapQtAppsHook, + zstd, }: let @@ -59,7 +60,6 @@ mkDerivation rec { zstd ] ++ pythonPath; - pythonPath = with python3Packages; [ bitstring cbor diff --git a/pkgs/applications/misc/rofi-emoji/default.nix b/pkgs/applications/misc/rofi-emoji/default.nix index 39004f04945ec7..a8a83fcfe8631c 100644 --- a/pkgs/applications/misc/rofi-emoji/default.nix +++ b/pkgs/applications/misc/rofi-emoji/default.nix @@ -1,25 +1,31 @@ -{ stdenv -, lib -, fetchFromGitHub -, makeWrapper +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, -, autoreconfHook -, pkg-config + autoreconfHook, + pkg-config, -, waylandSupport ? true -, x11Support ? true + waylandSupport ? true, + x11Support ? true, -, cairo -, glib -, libnotify -, rofi-unwrapped -, wl-clipboard -, xclip -, xdotool -, wtype + cairo, + glib, + libnotify, + rofi-unwrapped, + wl-clipboard, + xclip, + xdotool, + wtype, }: -import ./versions.nix ({ version, hash, patches}: +import ./versions.nix ( + { + version, + hash, + patches, + }: stdenv.mkDerivation rec { pname = "rofi-emoji"; inherit version; @@ -40,32 +46,48 @@ import ./versions.nix ({ version, hash, patches}: postFixup = '' chmod +x $out/share/rofi-emoji/clipboard-adapter.sh wrapProgram $out/share/rofi-emoji/clipboard-adapter.sh \ - --prefix PATH ":" ${lib.makeBinPath ([ libnotify ] - ++ lib.optionals waylandSupport [ wl-clipboard wtype ] - ++ lib.optionals x11Support [ xclip xdotool ])} + --prefix PATH ":" ${ + lib.makeBinPath ( + [ libnotify ] + ++ lib.optionals waylandSupport [ + wl-clipboard + wtype + ] + ++ lib.optionals x11Support [ + xclip + xdotool + ] + ) + } ''; - nativeBuildInputs = [ autoreconfHook pkg-config makeWrapper ]; - buildInputs = [ - cairo - glib - libnotify - rofi-unwrapped - ] - ++ lib.optionals waylandSupport [ wl-clipboard wtype ] + buildInputs = + [ + cairo + glib + libnotify + rofi-unwrapped + ] + ++ lib.optionals waylandSupport [ + wl-clipboard + wtype + ] ++ lib.optionals x11Support [ xclip ]; meta = with lib; { description = "Emoji selector plugin for Rofi (built against ${rofi-unwrapped.pname})"; homepage = "https://github.com/Mange/rofi-emoji"; license = licenses.mit; - maintainers = with maintainers; [ cole-h Mange ]; + maintainers = with maintainers; [ + cole-h + Mange + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/misc/rofi-rbw/default.nix b/pkgs/applications/misc/rofi-rbw/default.nix index f4cbf40e3d07cb..e1cb6a1e61bfce 100644 --- a/pkgs/applications/misc/rofi-rbw/default.nix +++ b/pkgs/applications/misc/rofi-rbw/default.nix @@ -1,18 +1,19 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, configargparse -, setuptools -, poetry-core -, rbw +{ + lib, + buildPythonApplication, + fetchFromGitHub, + configargparse, + setuptools, + poetry-core, + rbw, -, waylandSupport ? false -, wl-clipboard -, wtype + waylandSupport ? false, + wl-clipboard, + wtype, -, x11Support ? false -, xclip -, xdotool + x11Support ? false, + xclip, + xdotool, }: buildPythonApplication rec { @@ -32,29 +33,35 @@ buildPythonApplication rec { poetry-core ]; - buildInputs = [ - rbw - ] ++ lib.optionals waylandSupport [ - wl-clipboard - wtype - ] ++ lib.optionals x11Support [ - xclip - xdotool - ]; + buildInputs = + [ + rbw + ] + ++ lib.optionals waylandSupport [ + wl-clipboard + wtype + ] + ++ lib.optionals x11Support [ + xclip + xdotool + ]; propagatedBuildInputs = [ configargparse ]; pythonImportsCheck = [ "rofi_rbw" ]; - wrapper_paths = [ - rbw - ] ++ lib.optionals waylandSupport [ - wl-clipboard - wtype - ] ++ lib.optionals x11Support [ - xclip - xdotool - ]; + wrapper_paths = + [ + rbw + ] + ++ lib.optionals waylandSupport [ + wl-clipboard + wtype + ] + ++ lib.optionals x11Support [ + xclip + xdotool + ]; wrapper_flags = lib.optionalString waylandSupport "--typer wtype --clipboarder wl-copy" @@ -68,7 +75,10 @@ buildPythonApplication rec { description = "Rofi frontend for Bitwarden"; homepage = "https://github.com/fdw/rofi-rbw"; license = licenses.mit; - maintainers = with maintainers; [ equirosa dit7ya ]; + maintainers = with maintainers; [ + equirosa + dit7ya + ]; platforms = platforms.linux; mainProgram = "rofi-rbw"; }; diff --git a/pkgs/applications/misc/rofi/default.nix b/pkgs/applications/misc/rofi/default.nix index cad73779a85e67..3aedaeb2eece12 100644 --- a/pkgs/applications/misc/rofi/default.nix +++ b/pkgs/applications/misc/rofi/default.nix @@ -1,26 +1,27 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, libxkbcommon -, pango -, which -, git -, cairo -, libxcb -, xcbutil -, xcbutilwm -, xcbutilxrm -, xcb-util-cursor -, libstartup_notification -, bison -, flex -, librsvg -, check -, glib -, buildPackages +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + libxkbcommon, + pango, + which, + git, + cairo, + libxcb, + xcbutil, + xcbutilwm, + xcbutilxrm, + xcb-util-cursor, + libstartup_notification, + bison, + flex, + librsvg, + check, + glib, + buildPackages, }: stdenv.mkDerivation rec { @@ -41,8 +42,18 @@ stdenv.mkDerivation rec { sed -i 's/~root/~nobody/g' test/helper-expand.c ''; - depsBuildBuild = [ buildPackages.stdenv.cc pkg-config glib ]; - nativeBuildInputs = [ meson ninja pkg-config flex bison ]; + depsBuildBuild = [ + buildPackages.stdenv.cc + pkg-config + glib + ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + flex + bison + ]; buildInputs = [ libxkbcommon pango diff --git a/pkgs/applications/misc/rofi/wayland.nix b/pkgs/applications/misc/rofi/wayland.nix index f866f8fb7f72f8..56e23ffb7c52e8 100644 --- a/pkgs/applications/misc/rofi/wayland.nix +++ b/pkgs/applications/misc/rofi/wayland.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, rofi-unwrapped -, wayland-scanner -, pkg-config -, wayland-protocols -, wayland +{ + lib, + fetchFromGitHub, + fetchpatch, + rofi-unwrapped, + wayland-scanner, + pkg-config, + wayland-protocols, + wayland, }: rofi-unwrapped.overrideAttrs (oldAttrs: rec { @@ -31,8 +32,14 @@ rofi-unwrapped.overrideAttrs (oldAttrs: rec { ]; depsBuildBuild = oldAttrs.depsBuildBuild ++ [ pkg-config ]; - nativeBuildInputs = oldAttrs.nativeBuildInputs ++ [ wayland-protocols wayland-scanner ]; - buildInputs = oldAttrs.buildInputs ++ [ wayland wayland-protocols ]; + nativeBuildInputs = oldAttrs.nativeBuildInputs ++ [ + wayland-protocols + wayland-scanner + ]; + buildInputs = oldAttrs.buildInputs ++ [ + wayland + wayland-protocols + ]; meta = with lib; { description = "Window switcher, run dialog and dmenu replacement for Wayland"; diff --git a/pkgs/applications/misc/rofi/wrapper.nix b/pkgs/applications/misc/rofi/wrapper.nix index 3f08a504759045..89bf267998a896 100644 --- a/pkgs/applications/misc/rofi/wrapper.nix +++ b/pkgs/applications/misc/rofi/wrapper.nix @@ -1,4 +1,15 @@ -{ symlinkJoin, lib, rofi-unwrapped, makeWrapper, wrapGAppsHook3, gdk-pixbuf, hicolor-icon-theme, theme ? null, plugins ? [], symlink-dmenu ? false }: +{ + symlinkJoin, + lib, + rofi-unwrapped, + makeWrapper, + wrapGAppsHook3, + gdk-pixbuf, + hicolor-icon-theme, + theme ? null, + plugins ? [ ], + symlink-dmenu ? false, +}: symlinkJoin { name = "rofi-${rofi-unwrapped.version}"; @@ -7,7 +18,10 @@ symlinkJoin { rofi-unwrapped.out ] ++ (lib.forEach plugins (p: p.out)); - nativeBuildInputs = [ makeWrapper wrapGAppsHook3 ]; + nativeBuildInputs = [ + makeWrapper + wrapGAppsHook3 + ]; buildInputs = [ gdk-pixbuf ]; preferLocalBuild = true; @@ -25,9 +39,12 @@ symlinkJoin { makeWrapper ${rofi-unwrapped}/bin/rofi $out/bin/rofi \ ''${gappsWrapperArgs[@]} \ --prefix XDG_DATA_DIRS : ${hicolor-icon-theme}/share \ - ${lib.optionalString (plugins != []) ''--prefix XDG_DATA_DIRS : ${lib.concatStringsSep ":" (lib.forEach plugins (p: "${p.out}/share"))}''} \ + ${ + lib.optionalString (plugins != [ ]) + ''--prefix XDG_DATA_DIRS : ${lib.concatStringsSep ":" (lib.forEach plugins (p: "${p.out}/share"))}'' + } \ ${lib.optionalString (theme != null) ''--add-flags "-theme ${theme}"''} \ - ${lib.optionalString (plugins != []) ''--add-flags "-plugin-path $out/lib/rofi"''} + ${lib.optionalString (plugins != [ ]) ''--add-flags "-plugin-path $out/lib/rofi"''} ${lib.optionalString symlink-dmenu "ln -s ${rofi-unwrapped}/bin/rofi $out/bin/dmenu"} diff --git a/pkgs/applications/misc/rsibreak/default.nix b/pkgs/applications/misc/rsibreak/default.nix index 24d0a0eaa6ab95..e680ee956ef525 100644 --- a/pkgs/applications/misc/rsibreak/default.nix +++ b/pkgs/applications/misc/rsibreak/default.nix @@ -1,7 +1,14 @@ { - mkDerivation, fetchurl, lib, - extra-cmake-modules, kdoctools, - knotifyconfig, kidletime, kwindowsystem, ktextwidgets, kcrash + mkDerivation, + fetchurl, + lib, + extra-cmake-modules, + kdoctools, + knotifyconfig, + kidletime, + kwindowsystem, + ktextwidgets, + kcrash, }: mkDerivation rec { @@ -13,8 +20,17 @@ mkDerivation rec { sha256 = "N0C+f788fq5yotSC54H2K4WDc6PnGi8Nh/vXL4v0fxo="; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - propagatedBuildInputs = [ knotifyconfig kidletime kwindowsystem ktextwidgets kcrash ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + propagatedBuildInputs = [ + knotifyconfig + kidletime + kwindowsystem + ktextwidgets + kcrash + ]; meta = with lib; { description = "Takes care of your health and regularly breaks your work to avoid repetitive strain injury (RSI)"; diff --git a/pkgs/applications/misc/selectdefaultapplication/default.nix b/pkgs/applications/misc/selectdefaultapplication/default.nix index cfc142cb96e8d7..46868edc6fe63b 100644 --- a/pkgs/applications/misc/selectdefaultapplication/default.nix +++ b/pkgs/applications/misc/selectdefaultapplication/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, qmake, qtbase, wrapQtAppsHook }: +{ + stdenv, + lib, + fetchFromGitHub, + qmake, + qtbase, + wrapQtAppsHook, +}: stdenv.mkDerivation { pname = "selectdefaultapplication"; @@ -11,7 +18,10 @@ stdenv.mkDerivation { sha256 = "C/70xpt6RoQNIlAjSJhOCyheolK4Xp6RiSZmeqMP4fw="; }; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; buildInputs = [ qtbase ]; installPhase = '' diff --git a/pkgs/applications/misc/serial-studio/default.nix b/pkgs/applications/misc/serial-studio/default.nix index 129f3d49eb75ef..081cff81337b80 100644 --- a/pkgs/applications/misc/serial-studio/default.nix +++ b/pkgs/applications/misc/serial-studio/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, qmake, qtquickcontrols2, qtserialport, qtsvg, wrapQtAppsHook }: +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + qtquickcontrols2, + qtserialport, + qtsvg, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "serial-studio"; @@ -12,9 +21,16 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; - buildInputs = [ qtquickcontrols2 qtserialport qtsvg ]; + buildInputs = [ + qtquickcontrols2 + qtserialport + qtsvg + ]; meta = with lib; { description = "Multi-purpose serial data visualization & processing program"; diff --git a/pkgs/applications/misc/sl1-to-photon/default.nix b/pkgs/applications/misc/sl1-to-photon/default.nix index 901265016f8efd..f9bd5c9d0c1fbb 100644 --- a/pkgs/applications/misc/sl1-to-photon/default.nix +++ b/pkgs/applications/misc/sl1-to-photon/default.nix @@ -1,16 +1,17 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, pillow -, pyside2 -, numpy -, pyphotonfile -, shiboken2 +{ + lib, + buildPythonApplication, + fetchFromGitHub, + pillow, + pyside2, + numpy, + pyphotonfile, + shiboken2, }: let version = "0.1.3+"; in - buildPythonApplication rec { +buildPythonApplication rec { pname = "sl1-to-photon"; inherit version; @@ -21,7 +22,13 @@ in sha256 = "ssFfjlBMi3FHosDBUA2gs71VUIBkEdPVcV3STNxmOIM="; }; - pythonPath = [ pyphotonfile pillow numpy pyside2 shiboken2 ]; + pythonPath = [ + pyphotonfile + pillow + numpy + pyside2 + shiboken2 + ]; format = "setuptools"; dontUseSetuptoolsCheck = true; diff --git a/pkgs/applications/misc/slstatus/default.nix b/pkgs/applications/misc/slstatus/default.nix index 94aad50bc1d375..090c0454def11b 100644 --- a/pkgs/applications/misc/slstatus/default.nix +++ b/pkgs/applications/misc/slstatus/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchgit -, pkg-config -, writeText -, libX11 -, libXau -, libXdmcp -, conf ? null -, patches ? [ ] -# update script dependencies -, gitUpdater +{ + lib, + stdenv, + fetchgit, + pkg-config, + writeText, + libX11, + libXau, + libXdmcp, + conf ? null, + patches ? [ ], + # update script dependencies + gitUpdater, }: stdenv.mkDerivation rec { @@ -24,27 +25,35 @@ stdenv.mkDerivation rec { preBuild = let - configFile = if lib.isDerivation conf || builtins.isPath conf then conf else writeText "config.def.h" conf; + configFile = + if lib.isDerivation conf || builtins.isPath conf then conf else writeText "config.def.h" conf; in '' - ${lib.optionalString (conf!=null) "cp ${configFile} config.def.h"} + ${lib.optionalString (conf != null) "cp ${configFile} config.def.h"} makeFlagsArray+=(LDLIBS="-lX11 -lxcb -lXau -lXdmcp" CC=$CC) ''; inherit patches; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libX11 libXau libXdmcp ]; + buildInputs = [ + libX11 + libXau + libXdmcp + ]; installFlags = [ "PREFIX=$(out)" ]; - passthru.updateScript = gitUpdater {}; + passthru.updateScript = gitUpdater { }; meta = with lib; { homepage = "https://tools.suckless.org/slstatus/"; description = "status monitor for window managers that use WM_NAME like dwm"; license = licenses.isc; - maintainers = with maintainers; [ oxzi qusic ]; + maintainers = with maintainers; [ + oxzi + qusic + ]; platforms = platforms.linux; mainProgram = "slstatus"; }; diff --git a/pkgs/applications/misc/snagboot/default.nix b/pkgs/applications/misc/snagboot/default.nix index 3a663443513c86..ccfe1fc9ab0baf 100644 --- a/pkgs/applications/misc/snagboot/default.nix +++ b/pkgs/applications/misc/snagboot/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 -, snagboot -, testers -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + python3, + snagboot, + testers, + gitUpdater, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/applications/misc/stag/default.nix b/pkgs/applications/misc/stag/default.nix index 711d549d1ac35d..2efe5eaa4dbf7f 100644 --- a/pkgs/applications/misc/stag/default.nix +++ b/pkgs/applications/misc/stag/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, curses, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + curses, + fetchpatch, +}: stdenv.mkDerivation (finalAttrs: { pname = "stag"; diff --git a/pkgs/applications/misc/stog/asy.nix b/pkgs/applications/misc/stog/asy.nix index 58f1cf35f4d474..f39ece3ec9f8a5 100644 --- a/pkgs/applications/misc/stog/asy.nix +++ b/pkgs/applications/misc/stog/asy.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, stog, ocf_ppx }: +{ + buildDunePackage, + stog, + ocf_ppx, +}: buildDunePackage { pname = "stog_asy"; diff --git a/pkgs/applications/misc/stog/default.nix b/pkgs/applications/misc/stog/default.nix index b91624525483ba..e002893538423a 100644 --- a/pkgs/applications/misc/stog/default.nix +++ b/pkgs/applications/misc/stog/default.nix @@ -1,6 +1,23 @@ -{ lib, buildDunePackage, fetchFromGitLab -, fmt, lwt_ppx, menhir, ocf_ppx, ppx_blob, xtmpl_ppx -, dune-build-info, dune-site, higlo, logs, lwt, ocf, ptime, uri, uutf, xtmpl +{ + lib, + buildDunePackage, + fetchFromGitLab, + fmt, + lwt_ppx, + menhir, + ocf_ppx, + ppx_blob, + xtmpl_ppx, + dune-build-info, + dune-site, + higlo, + logs, + lwt, + ocf, + ptime, + uri, + uutf, + xtmpl, }: buildDunePackage rec { @@ -16,7 +33,13 @@ buildDunePackage rec { }; nativeBuildInputs = [ menhir ]; - buildInputs = [ fmt lwt_ppx ocf_ppx ppx_blob xtmpl_ppx ]; + buildInputs = [ + fmt + lwt_ppx + ocf_ppx + ppx_blob + xtmpl_ppx + ]; propagatedBuildInputs = [ dune-build-info dune-site diff --git a/pkgs/applications/misc/stog/markdown.nix b/pkgs/applications/misc/stog/markdown.nix index 48fd4a0b009673..f5a3142b2a035c 100644 --- a/pkgs/applications/misc/stog/markdown.nix +++ b/pkgs/applications/misc/stog/markdown.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, stog, ocf_ppx, omd }: +{ + buildDunePackage, + stog, + ocf_ppx, + omd, +}: buildDunePackage { pname = "stog_markdown"; @@ -6,10 +11,12 @@ buildDunePackage { inherit (stog) version src; buildInputs = [ ocf_ppx ]; - propagatedBuildInputs = [ omd stog ]; + propagatedBuildInputs = [ + omd + stog + ]; meta = stog.meta // { description = "Stog plugin to use markdown syntax"; }; } - diff --git a/pkgs/applications/misc/stork/default.nix b/pkgs/applications/misc/stork/default.nix index 4441508e0be885..5c020e923765f8 100644 --- a/pkgs/applications/misc/stork/default.nix +++ b/pkgs/applications/misc/stork/default.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, openssl -, pkg-config -, stdenv -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + openssl, + pkg-config, + stdenv, + Security, }: rustPlatform.buildRustPackage rec { @@ -27,8 +28,7 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; + buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; meta = with lib; { description = "Impossibly fast web search, made for static sites"; diff --git a/pkgs/applications/misc/subsurface/default.nix b/pkgs/applications/misc/subsurface/default.nix index f1ebdb98c1c86e..6387913ac37322 100644 --- a/pkgs/applications/misc/subsurface/default.nix +++ b/pkgs/applications/misc/subsurface/default.nix @@ -1,43 +1,46 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, writeShellScriptBin -, cmake -, wrapQtAppsHook -, pkg-config -, qmake -, curl -, grantlee -, hidapi -, libgit2 -, libssh2 -, libusb1 -, libxml2 -, libxslt -, libzip -, zlib -, qtbase -, qtconnectivity -, qtlocation -, qtsvg -, qttools -, qtwebengine -, libXcomposite -, bluez -, writeScript +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + writeShellScriptBin, + cmake, + wrapQtAppsHook, + pkg-config, + qmake, + curl, + grantlee, + hidapi, + libgit2, + libssh2, + libusb1, + libxml2, + libxslt, + libzip, + zlib, + qtbase, + qtconnectivity, + qtlocation, + qtsvg, + qttools, + qtwebengine, + libXcomposite, + bluez, + writeScript, }: let version = "6.0.5231"; - subsurfaceSrc = (fetchFromGitHub { - owner = "Subsurface"; - repo = "subsurface"; - rev = "38a0050ac33566dfd34bf94cf1d7ac66034e4118"; - hash = "sha256-6fNcBF/Ep2xs2z83ZQ09XNb/ZkhK1nUNLChV1x8qh0Y="; - fetchSubmodules = true; - }); + subsurfaceSrc = ( + fetchFromGitHub { + owner = "Subsurface"; + repo = "subsurface"; + rev = "38a0050ac33566dfd34bf94cf1d7ac66034e4118"; + hash = "sha256-6fNcBF/Ep2xs2z83ZQ09XNb/ZkhK1nUNLChV1x8qh0Y="; + fetchSubmodules = true; + } + ); libdc = stdenv.mkDerivation { pname = "libdivecomputer-ssrf"; @@ -47,9 +50,17 @@ let sourceRoot = "${subsurfaceSrc.name}/libdivecomputer"; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ zlib libusb1 bluez hidapi ]; + buildInputs = [ + zlib + libusb1 + bluez + hidapi + ]; enableParallelBuilding = true; @@ -75,7 +86,11 @@ let nativeBuildInputs = [ qmake ]; - buildInputs = [ qtbase qtlocation libXcomposite ]; + buildInputs = [ + qtbase + qtlocation + libXcomposite + ]; dontWrapQtApps = true; @@ -130,7 +145,11 @@ stdenv.mkDerivation { qtwebengine ]; - nativeBuildInputs = [ cmake wrapQtAppsHook pkg-config ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + pkg-config + ]; cmakeFlags = [ "-DLIBDC_FROM_PKGCONFIG=ON" diff --git a/pkgs/applications/misc/survex/default.nix b/pkgs/applications/misc/survex/default.nix index f5ce17ea21f78c..fe33a366780f88 100644 --- a/pkgs/applications/misc/survex/default.nix +++ b/pkgs/applications/misc/survex/default.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, Carbon -, Cocoa -, ffmpeg -, glib -, libGLU -, libICE -, libX11 -, mesa -, perl -, pkg-config -, proj -, gdal -, python3 -, wrapGAppsHook3 -, wxGTK32 +{ + lib, + stdenv, + fetchurl, + fetchpatch, + Carbon, + Cocoa, + ffmpeg, + glib, + libGLU, + libICE, + libX11, + mesa, + perl, + pkg-config, + proj, + gdal, + python3, + wrapGAppsHook3, + wxGTK32, }: stdenv.mkDerivation rec { @@ -35,23 +36,26 @@ stdenv.mkDerivation rec { wrapGAppsHook3 ]; - buildInputs = [ - ffmpeg - glib - proj - gdal - wxGTK32 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Carbon - Cocoa - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - # TODO: libGLU doesn't build for macOS because of Mesa issues - # (#233265); is it required for anything? - libGLU - mesa - libICE - libX11 - ]; + buildInputs = + [ + ffmpeg + glib + proj + gdal + wxGTK32 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + Cocoa + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + # TODO: libGLU doesn't build for macOS because of Mesa issues + # (#233265); is it required for anything? + libGLU + mesa + libICE + libX11 + ]; postPatch = '' patchShebangs . diff --git a/pkgs/applications/misc/swappy/default.nix b/pkgs/applications/misc/swappy/default.nix index d13578b3c82ae7..848e73ff2df3a2 100644 --- a/pkgs/applications/misc/swappy/default.nix +++ b/pkgs/applications/misc/swappy/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, wayland -, cairo -, pango -, gtk -, pkg-config -, scdoc -, libnotify -, glib -, wrapGAppsHook3 -, hicolor-icon-theme +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + wayland, + cairo, + pango, + gtk, + pkg-config, + scdoc, + libnotify, + glib, + wrapGAppsHook3, + hicolor-icon-theme, }: stdenv.mkDerivation rec { @@ -26,10 +27,23 @@ stdenv.mkDerivation rec { hash = "sha256-/XPvy98Il4i8cDl9vH6f0/AZmiSqseSXnen7HfMqCDo="; }; - nativeBuildInputs = [ glib meson ninja pkg-config scdoc wrapGAppsHook3 ]; + nativeBuildInputs = [ + glib + meson + ninja + pkg-config + scdoc + wrapGAppsHook3 + ]; buildInputs = [ - cairo pango gtk libnotify wayland glib hicolor-icon-theme + cairo + pango + gtk + libnotify + wayland + glib + hicolor-icon-theme ]; strictDeps = true; diff --git a/pkgs/applications/misc/sway-contrib/default.nix b/pkgs/applications/misc/sway-contrib/default.nix index b0c8154f2c513d..04854aec5b0998 100644 --- a/pkgs/applications/misc/sway-contrib/default.nix +++ b/pkgs/applications/misc/sway-contrib/default.nix @@ -1,18 +1,20 @@ -{ lib, stdenvNoCC -, fetchFromGitHub -, coreutils -, makeWrapper -, sway-unwrapped -, installShellFiles -, wl-clipboard -, libnotify -, slurp -, grim -, jq -, gnugrep -, bash - -, python3Packages +{ + lib, + stdenvNoCC, + fetchFromGitHub, + coreutils, + makeWrapper, + sway-unwrapped, + installShellFiles, + wl-clipboard, + libnotify, + slurp, + grim, + jq, + gnugrep, + bash, + + python3Packages, }: let @@ -32,80 +34,95 @@ let in { -grimshot = stdenvNoCC.mkDerivation { - inherit version src; - - pname = "grimshot"; - - dontBuild = true; - dontConfigure = true; - - outputs = [ "out" "man" ]; - - strictDeps = true; - nativeBuildInputs = [ makeWrapper installShellFiles ]; - buildInputs = [ bash ]; - installPhase = '' - installManPage grimshot.1 - installShellCompletion --cmd grimshot grimshot-completion.bash - - install -Dm 0755 grimshot $out/bin/grimshot - wrapProgram $out/bin/grimshot --set PATH \ - "${lib.makeBinPath [ - sway-unwrapped - wl-clipboard - coreutils - libnotify - slurp - grim - jq - gnugrep - ] }" - ''; - - doInstallCheck = true; - - installCheckPhase = '' - # check always returns 0 - if [[ $($out/bin/grimshot check | grep "NOT FOUND") ]]; then false - else - echo "grimshot check passed" - fi - ''; - - meta = with lib; meta // { - description = "Helper for screenshots within sway"; - maintainers = with maintainers; [ evils ]; - mainProgram = "grimshot"; - }; -}; - - -inactive-windows-transparency = let - # long name is long - lname = "inactive-windows-transparency"; -in python3Packages.buildPythonApplication { - inherit version src; + grimshot = stdenvNoCC.mkDerivation { + inherit version src; - pname = "sway-${lname}"; + pname = "grimshot"; - format = "other"; - dontBuild = true; - dontConfigure = true; + dontBuild = true; + dontConfigure = true; - propagatedBuildInputs = [ python3Packages.i3ipc ]; - - installPhase = '' - install -Dm 0755 $src/${lname}.py $out/bin/${lname}.py - ''; + outputs = [ + "out" + "man" + ]; - meta = with lib; meta // { - description = "It makes inactive sway windows transparent"; - mainProgram = "${lname}.py"; - maintainers = with maintainers; [ - evils # packaged this as a side-effect of grimshot but doesn't use it + strictDeps = true; + nativeBuildInputs = [ + makeWrapper + installShellFiles ]; + buildInputs = [ bash ]; + installPhase = '' + installManPage grimshot.1 + installShellCompletion --cmd grimshot grimshot-completion.bash + + install -Dm 0755 grimshot $out/bin/grimshot + wrapProgram $out/bin/grimshot --set PATH \ + "${ + lib.makeBinPath [ + sway-unwrapped + wl-clipboard + coreutils + libnotify + slurp + grim + jq + gnugrep + ] + }" + ''; + + doInstallCheck = true; + + installCheckPhase = '' + # check always returns 0 + if [[ $($out/bin/grimshot check | grep "NOT FOUND") ]]; then false + else + echo "grimshot check passed" + fi + ''; + + meta = + with lib; + meta + // { + description = "Helper for screenshots within sway"; + maintainers = with maintainers; [ evils ]; + mainProgram = "grimshot"; + }; }; -}; + + inactive-windows-transparency = + let + # long name is long + lname = "inactive-windows-transparency"; + in + python3Packages.buildPythonApplication { + inherit version src; + + pname = "sway-${lname}"; + + format = "other"; + dontBuild = true; + dontConfigure = true; + + propagatedBuildInputs = [ python3Packages.i3ipc ]; + + installPhase = '' + install -Dm 0755 $src/${lname}.py $out/bin/${lname}.py + ''; + + meta = + with lib; + meta + // { + description = "It makes inactive sway windows transparent"; + mainProgram = "${lname}.py"; + maintainers = with maintainers; [ + evils # packaged this as a side-effect of grimshot but doesn't use it + ]; + }; + }; } diff --git a/pkgs/applications/misc/sweethome3d/editors.nix b/pkgs/applications/misc/sweethome3d/editors.nix index 9d37423f568db2..8a9959832da752 100644 --- a/pkgs/applications/misc/sweethome3d/editors.nix +++ b/pkgs/applications/misc/sweethome3d/editors.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchzip -, makeWrapper -, makeDesktopItem -, jdk -, ant -, stripJavaArchivesHook -, gtk3 -, gsettings-desktop-schemas -, sweethome3dApp -, unzip +{ + lib, + stdenv, + fetchzip, + makeWrapper, + makeDesktopItem, + jdk, + ant, + stripJavaArchivesHook, + gtk3, + gsettings-desktop-schemas, + sweethome3dApp, + unzip, }: let @@ -17,65 +18,92 @@ let sweetExec = m: "sweethome3d-" + lib.removeSuffix "libraryeditor" (lib.toLower m) + "-editor"; mkEditorProject = - { pname, module, version, src, license, description, desktopName }: - - stdenv.mkDerivation rec { - application = sweethome3dApp; - inherit pname module version src description; - exec = sweetExec module; - editorItem = makeDesktopItem { - inherit exec desktopName; - name = pname; - comment = description; - genericName = "Computer Aided (Interior) Design"; - categories = [ "Graphics" "2DGraphics" "3DGraphics" ]; - }; - - nativeBuildInputs = [ makeWrapper stripJavaArchivesHook ]; - buildInputs = [ ant jdk gtk3 gsettings-desktop-schemas ]; - - # upstream targets Java 7 by default - env.ANT_ARGS = "-DappletClassSource=8 -DappletClassTarget=8 -DclassSource=8 -DclassTarget=8"; - - postPatch = '' - sed -i -e 's,../SweetHome3D,${sweethome3dApp.src},g' build.xml - sed -i -e 's,lib/macosx/java3d-1.6/jogl-all.jar,lib/java3d-1.6/jogl-all.jar,g' build.xml - ''; - - buildPhase = '' - runHook preBuild - - ant -lib ${sweethome3dApp.src}/libtest -lib ${sweethome3dApp.src}/lib -lib ${jdk}/lib + { + pname, + module, + version, + src, + license, + description, + desktopName, + }: + + stdenv.mkDerivation rec { + application = sweethome3dApp; + inherit + pname + module + version + src + description + ; + exec = sweetExec module; + editorItem = makeDesktopItem { + inherit exec desktopName; + name = pname; + comment = description; + genericName = "Computer Aided (Interior) Design"; + categories = [ + "Graphics" + "2DGraphics" + "3DGraphics" + ]; + }; + + nativeBuildInputs = [ + makeWrapper + stripJavaArchivesHook + ]; + buildInputs = [ + ant + jdk + gtk3 + gsettings-desktop-schemas + ]; + + # upstream targets Java 7 by default + env.ANT_ARGS = "-DappletClassSource=8 -DappletClassTarget=8 -DclassSource=8 -DclassTarget=8"; + + postPatch = '' + sed -i -e 's,../SweetHome3D,${sweethome3dApp.src},g' build.xml + sed -i -e 's,lib/macosx/java3d-1.6/jogl-all.jar,lib/java3d-1.6/jogl-all.jar,g' build.xml + ''; + + buildPhase = '' + runHook preBuild + + ant -lib ${sweethome3dApp.src}/libtest -lib ${sweethome3dApp.src}/lib -lib ${jdk}/lib + + runHook postBuild + ''; + + installPhase = '' + mkdir -p $out/bin + mkdir -p $out/share/{java,applications} + cp ${module}-${version}.jar $out/share/java/. + cp "${editorItem}/share/applications/"* $out/share/applications + makeWrapper ${jdk}/bin/java $out/bin/$exec \ + --prefix XDG_DATA_DIRS : "$XDG_ICON_DIRS:${gtk3.out}/share:${gsettings-desktop-schemas}/share:$out/share:$GSETTINGS_SCHEMAS_PATH" \ + --add-flags "-jar $out/share/java/${module}-${version}.jar -d${toString stdenv.hostPlatform.parsed.cpu.bits}" + ''; + + dontStrip = true; + + meta = { + homepage = "http://www.sweethome3d.com/index.jsp"; + inherit description; + inherit license; + maintainers = [ lib.maintainers.edwtjo ]; + platforms = lib.platforms.linux; + mainProgram = exec; + }; - runHook postBuild - ''; - - installPhase = '' - mkdir -p $out/bin - mkdir -p $out/share/{java,applications} - cp ${module}-${version}.jar $out/share/java/. - cp "${editorItem}/share/applications/"* $out/share/applications - makeWrapper ${jdk}/bin/java $out/bin/$exec \ - --prefix XDG_DATA_DIRS : "$XDG_ICON_DIRS:${gtk3.out}/share:${gsettings-desktop-schemas}/share:$out/share:$GSETTINGS_SCHEMAS_PATH" \ - --add-flags "-jar $out/share/java/${module}-${version}.jar -d${toString stdenv.hostPlatform.parsed.cpu.bits}" - ''; - - dontStrip = true; - - meta = { - homepage = "http://www.sweethome3d.com/index.jsp"; - inherit description; - inherit license; - maintainers = [ lib.maintainers.edwtjo ]; - platforms = lib.platforms.linux; - mainProgram = exec; }; - }; - - d2u = lib.replaceStrings ["."] ["_"]; + d2u = lib.replaceStrings [ "." ] [ "_" ]; -in { +in +{ textures-editor = mkEditorProject rec { version = "1.7"; diff --git a/pkgs/applications/misc/syncthingtray/default.nix b/pkgs/applications/misc/syncthingtray/default.nix index e996a39d9d4b44..fdfff2f567ac4b 100644 --- a/pkgs/applications/misc/syncthingtray/default.nix +++ b/pkgs/applications/misc/syncthingtray/default.nix @@ -1,37 +1,40 @@ -{ lib -, stdenv -, fetchFromGitHub -, qtbase -, qtsvg -, qtwayland -, qtwebengine -, qtdeclarative -, extra-cmake-modules -, cpp-utilities -, qtutilities -, qtforkawesome -, boost -, wrapQtAppsHook -, cmake -, kio -, plasma-framework -, qttools -, iconv -, cppunit -, syncthing -, xdg-utils -, webviewSupport ? true -, jsSupport ? true -, kioPluginSupport ? stdenv.hostPlatform.isLinux -, plasmoidSupport ? stdenv.hostPlatform.isLinux -, systemdSupport ? stdenv.hostPlatform.isLinux -/* It is possible to set via this option an absolute exec path that will be -written to the `~/.config/autostart/syncthingtray.desktop` file generated -during runtime. Alternatively, one can edit the desktop file themselves after -it is generated See: -https://github.com/NixOS/nixpkgs/issues/199596#issuecomment-1310136382 */ -, autostartExecPath ? "syncthingtray" -, versionCheckHook +{ + lib, + stdenv, + fetchFromGitHub, + qtbase, + qtsvg, + qtwayland, + qtwebengine, + qtdeclarative, + extra-cmake-modules, + cpp-utilities, + qtutilities, + qtforkawesome, + boost, + wrapQtAppsHook, + cmake, + kio, + plasma-framework, + qttools, + iconv, + cppunit, + syncthing, + xdg-utils, + webviewSupport ? true, + jsSupport ? true, + kioPluginSupport ? stdenv.hostPlatform.isLinux, + plasmoidSupport ? stdenv.hostPlatform.isLinux, + systemdSupport ? stdenv.hostPlatform.isLinux, + /* + It is possible to set via this option an absolute exec path that will be + written to the `~/.config/autostart/syncthingtray.desktop` file generated + during runtime. Alternatively, one can edit the desktop file themselves after + it is generated See: + https://github.com/NixOS/nixpkgs/issues/199596#issuecomment-1310136382 + */ + autostartExecPath ? "syncthingtray", + versionCheckHook, }: stdenv.mkDerivation (finalAttrs: { @@ -45,20 +48,21 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-nWG9r0/qs9Jrj0Bo3RKtNSP1pnUd7CRiEkkRWf0UMNs="; }; - buildInputs = [ - qtbase - qtsvg - cpp-utilities - qtutilities - boost - qtforkawesome - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ iconv ] + buildInputs = + [ + qtbase + qtsvg + cpp-utilities + qtutilities + boost + qtforkawesome + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ iconv ] ++ lib.optionals stdenv.hostPlatform.isLinux [ qtwayland ] ++ lib.optionals webviewSupport [ qtwebengine ] ++ lib.optionals jsSupport [ qtdeclarative ] ++ lib.optionals kioPluginSupport [ kio ] - ++ lib.optionals plasmoidSupport [ plasma-framework ] - ; + ++ lib.optionals plasmoidSupport [ plasma-framework ]; nativeBuildInputs = [ wrapQtAppsHook @@ -69,9 +73,7 @@ stdenv.mkDerivation (finalAttrs: { # still build them. cppunit syncthing - ] - ++ lib.optionals plasmoidSupport [ extra-cmake-modules ] - ; + ] ++ lib.optionals plasmoidSupport [ extra-cmake-modules ]; # syncthing server seems to hang on darwin, causing tests to fail. doCheck = !stdenv.hostPlatform.isDarwin; @@ -91,21 +93,22 @@ stdenv.mkDerivation (finalAttrs: { ]; doInstallCheck = true; - cmakeFlags = [ - "-DQT_PACKAGE_PREFIX=Qt${lib.versions.major qtbase.version}" - "-DKF_PACKAGE_PREFIX=KF${lib.versions.major qtbase.version}" - "-DBUILD_TESTING=ON" - # See https://github.com/Martchus/syncthingtray/issues/208 - "-DEXCLUDE_TESTS_FROM_ALL=OFF" - "-DAUTOSTART_EXEC_PATH=${autostartExecPath}" - # See https://github.com/Martchus/syncthingtray/issues/42 - "-DQT_PLUGIN_DIR:STRING=${placeholder "out"}/${qtbase.qtPluginPrefix}" - "-DBUILD_SHARED_LIBS=ON" - ] ++ lib.optionals (!plasmoidSupport) ["-DNO_PLASMOID=ON"] - ++ lib.optionals (!kioPluginSupport) ["-DNO_FILE_ITEM_ACTION_PLUGIN=ON"] - ++ lib.optionals systemdSupport ["-DSYSTEMD_SUPPORT=ON"] - ++ lib.optionals (!webviewSupport) ["-DWEBVIEW_PROVIDER:STRING=none"] - ; + cmakeFlags = + [ + "-DQT_PACKAGE_PREFIX=Qt${lib.versions.major qtbase.version}" + "-DKF_PACKAGE_PREFIX=KF${lib.versions.major qtbase.version}" + "-DBUILD_TESTING=ON" + # See https://github.com/Martchus/syncthingtray/issues/208 + "-DEXCLUDE_TESTS_FROM_ALL=OFF" + "-DAUTOSTART_EXEC_PATH=${autostartExecPath}" + # See https://github.com/Martchus/syncthingtray/issues/42 + "-DQT_PLUGIN_DIR:STRING=${placeholder "out"}/${qtbase.qtPluginPrefix}" + "-DBUILD_SHARED_LIBS=ON" + ] + ++ lib.optionals (!plasmoidSupport) [ "-DNO_PLASMOID=ON" ] + ++ lib.optionals (!kioPluginSupport) [ "-DNO_FILE_ITEM_ACTION_PLUGIN=ON" ] + ++ lib.optionals systemdSupport [ "-DSYSTEMD_SUPPORT=ON" ] + ++ lib.optionals (!webviewSupport) [ "-DWEBVIEW_PROVIDER:STRING=none" ]; qtWrapperArgs = [ "--prefix PATH : ${lib.makeBinPath [ xdg-utils ]}" diff --git a/pkgs/applications/misc/synergy/default.nix b/pkgs/applications/misc/synergy/default.nix index 7db338b16897f2..df841710a11ca4 100644 --- a/pkgs/applications/misc/synergy/default.nix +++ b/pkgs/applications/misc/synergy/default.nix @@ -1,38 +1,39 @@ -{ withGUI ? true -, stdenv -, lib -, fetchFromGitHub -, wrapQtAppsHook - -, cmake -, openssl -, pcre -, util-linux -, libselinux -, libsepol -, pkg-config -, gdk-pixbuf -, libnotify -, qttools -, libICE -, libSM -, libX11 -, libxkbfile -, libXi -, libXtst -, libXrandr -, libXinerama -, xkeyboardconfig -, xinput -, avahi-compat +{ + withGUI ? true, + stdenv, + lib, + fetchFromGitHub, + wrapQtAppsHook, + + cmake, + openssl, + pcre, + util-linux, + libselinux, + libsepol, + pkg-config, + gdk-pixbuf, + libnotify, + qttools, + libICE, + libSM, + libX11, + libxkbfile, + libXi, + libXtst, + libXrandr, + libXinerama, + xkeyboardconfig, + xinput, + avahi-compat, # MacOS / darwin -, ApplicationServices -, Carbon -, Cocoa -, CoreServices -, ScreenSaver -, UserNotifications + ApplicationServices, + Carbon, + Cocoa, + CoreServices, + ScreenSaver, + UserNotifications, }: stdenv.mkDerivation rec { @@ -52,86 +53,102 @@ stdenv.mkDerivation rec { ./darwin-non-static-openssl.patch ]; - postPatch = '' - substituteInPlace src/gui/src/SslCertificate.cpp \ - --replace 'kUnixOpenSslCommand[] = "openssl";' 'kUnixOpenSslCommand[] = "${openssl}/bin/openssl";' - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace src/lib/synergy/unix/AppUtilUnix.cpp \ - --replace "/usr/share/X11/xkb/rules/evdev.xml" "${xkeyboardconfig}/share/X11/xkb/rules/evdev.xml" - ''; + postPatch = + '' + substituteInPlace src/gui/src/SslCertificate.cpp \ + --replace 'kUnixOpenSslCommand[] = "openssl";' 'kUnixOpenSslCommand[] = "${openssl}/bin/openssl";' + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace src/lib/synergy/unix/AppUtilUnix.cpp \ + --replace "/usr/share/X11/xkb/rules/evdev.xml" "${xkeyboardconfig}/share/X11/xkb/rules/evdev.xml" + ''; nativeBuildInputs = [ cmake pkg-config ] ++ lib.optional withGUI wrapQtAppsHook; - buildInputs = [ - qttools # Used for translations even when not building the GUI - openssl - pcre - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ApplicationServices - Carbon - Cocoa - CoreServices - ScreenSaver - UserNotifications - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - util-linux - libselinux - libsepol - libICE - libSM - libX11 - libXi - libXtst - libXrandr - libXinerama - libxkbfile - xinput - avahi-compat - gdk-pixbuf - libnotify - ]; + buildInputs = + [ + qttools # Used for translations even when not building the GUI + openssl + pcre + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ApplicationServices + Carbon + Cocoa + CoreServices + ScreenSaver + UserNotifications + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + util-linux + libselinux + libsepol + libICE + libSM + libX11 + libXi + libXtst + libXrandr + libXinerama + libxkbfile + xinput + avahi-compat + gdk-pixbuf + libnotify + ]; # Silences many warnings env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-Wno-inconsistent-missing-override"; - cmakeFlags = lib.optional (!withGUI) "-DSYNERGY_BUILD_LEGACY_GUI=OFF" + cmakeFlags = + lib.optional (!withGUI) "-DSYNERGY_BUILD_LEGACY_GUI=OFF" # NSFilenamesPboardType is deprecated in 10.14+ - ++ lib.optional stdenv.hostPlatform.isDarwin "-DCMAKE_OSX_DEPLOYMENT_TARGET=${if stdenv.hostPlatform.isAarch64 then "10.13" else stdenv.hostPlatform.darwinSdkVersion}"; + ++ lib.optional stdenv.hostPlatform.isDarwin "-DCMAKE_OSX_DEPLOYMENT_TARGET=${ + if stdenv.hostPlatform.isAarch64 then "10.13" else stdenv.hostPlatform.darwinSdkVersion + }"; doCheck = true; - checkPhase = '' - runHook preCheck - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # filter out tests failing with sandboxing on darwin - export GTEST_FILTER=-ServerConfigTests.serverconfig_will_deem_equal_configs_with_same_cell_names:NetworkAddress.hostname_valid_parsing - '' + '' - bin/unittests - runHook postCheck - ''; - - installPhase = '' - runHook preInstall - - mkdir -p $out/bin - cp bin/{synergyc,synergys,synergyd,syntool} $out/bin/ - '' + lib.optionalString withGUI '' - cp bin/synergy $out/bin/ - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - mkdir -p $out/share/{applications,icons/hicolor/scalable/apps} - cp ../res/synergy.svg $out/share/icons/hicolor/scalable/apps/ - substitute ../res/synergy.desktop $out/share/applications/synergy.desktop \ - --replace "/usr/bin" "$out/bin" - '' + lib.optionalString (stdenv.hostPlatform.isDarwin && withGUI) '' - mkdir -p $out/Applications - cp -r bundle/Synergy.app $out/Applications - ln -s $out/bin $out/Applications/Synergy.app/Contents/MacOS - '' + '' - runHook postInstall - ''; + checkPhase = + '' + runHook preCheck + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # filter out tests failing with sandboxing on darwin + export GTEST_FILTER=-ServerConfigTests.serverconfig_will_deem_equal_configs_with_same_cell_names:NetworkAddress.hostname_valid_parsing + '' + + '' + bin/unittests + runHook postCheck + ''; + + installPhase = + '' + runHook preInstall + + mkdir -p $out/bin + cp bin/{synergyc,synergys,synergyd,syntool} $out/bin/ + '' + + lib.optionalString withGUI '' + cp bin/synergy $out/bin/ + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + mkdir -p $out/share/{applications,icons/hicolor/scalable/apps} + cp ../res/synergy.svg $out/share/icons/hicolor/scalable/apps/ + substitute ../res/synergy.desktop $out/share/applications/synergy.desktop \ + --replace "/usr/bin" "$out/bin" + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin && withGUI) '' + mkdir -p $out/Applications + cp -r bundle/Synergy.app $out/Applications + ln -s $out/bin $out/Applications/Synergy.app/Contents/MacOS + '' + + '' + runHook postInstall + ''; dontWrapQtApps = lib.optional (!withGUI) true; diff --git a/pkgs/applications/misc/tandoor-recipes/frontend.nix b/pkgs/applications/misc/tandoor-recipes/frontend.nix index 76867f67a2cc1a..0248e5ffbae0d2 100644 --- a/pkgs/applications/misc/tandoor-recipes/frontend.nix +++ b/pkgs/applications/misc/tandoor-recipes/frontend.nix @@ -1,4 +1,11 @@ -{ stdenv, fetchYarnDeps, fixup-yarn-lock, callPackage, nodejs, yarn }: +{ + stdenv, + fetchYarnDeps, + fixup-yarn-lock, + callPackage, + nodejs, + yarn, +}: let common = callPackage ./common.nix { }; in diff --git a/pkgs/applications/misc/tellico/default.nix b/pkgs/applications/misc/tellico/default.nix index 4fd35bee7e93c1..baf3f2faa4958a 100644 --- a/pkgs/applications/misc/tellico/default.nix +++ b/pkgs/applications/misc/tellico/default.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, fetchFromGitLab -, mkDerivation -, cmake -, exempi -, extra-cmake-modules -, karchive -, kdoctools -, kfilemetadata -, khtml -, kitemmodels -, knewstuff -, kxmlgui -, libcdio -, libkcddb -, libksane -, makeWrapper -, poppler -, qtcharts -, qtwebengine -, solid -, taglib -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitLab, + mkDerivation, + cmake, + exempi, + extra-cmake-modules, + karchive, + kdoctools, + kfilemetadata, + khtml, + kitemmodels, + knewstuff, + kxmlgui, + libcdio, + libkcddb, + libksane, + makeWrapper, + poppler, + qtcharts, + qtwebengine, + solid, + taglib, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -66,7 +67,11 @@ stdenv.mkDerivation rec { description = "Collection management software, free and simple"; mainProgram = "tellico"; homepage = "https://tellico-project.org/"; - license = with licenses; [ gpl2Only gpl3Only lgpl2Only ]; + license = with licenses; [ + gpl2Only + gpl3Only + lgpl2Only + ]; maintainers = with maintainers; [ numkem ]; platforms = platforms.linux; }; diff --git a/pkgs/applications/misc/termdown/default.nix b/pkgs/applications/misc/termdown/default.nix index d2d592dce7e9d3..aa20f51e3ae0aa 100644 --- a/pkgs/applications/misc/termdown/default.nix +++ b/pkgs/applications/misc/termdown/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, buildPythonApplication -, click -, pyfiglet -, python-dateutil -, setuptools +{ + lib, + fetchFromGitHub, + buildPythonApplication, + click, + pyfiglet, + python-dateutil, + setuptools, }: buildPythonApplication rec { @@ -18,7 +19,12 @@ buildPythonApplication rec { owner = "trehn"; }; - propagatedBuildInputs = [ python-dateutil click pyfiglet setuptools ]; + propagatedBuildInputs = [ + python-dateutil + click + pyfiglet + setuptools + ]; meta = with lib; { description = "Starts a countdown to or from TIMESPEC"; diff --git a/pkgs/applications/misc/termpdf.py/default.nix b/pkgs/applications/misc/termpdf.py/default.nix index 244bfee240329b..9997f53ca3fb34 100644 --- a/pkgs/applications/misc/termpdf.py/default.nix +++ b/pkgs/applications/misc/termpdf.py/default.nix @@ -1,5 +1,17 @@ -{ lib, buildPythonApplication, fetchFromGitHub, bibtool, pybtex, pymupdf, pynvim -, pyperclip, roman, pdfrw, pagelabels, setuptools }: +{ + lib, + buildPythonApplication, + fetchFromGitHub, + bibtool, + pybtex, + pymupdf, + pynvim, + pyperclip, + roman, + pdfrw, + pagelabels, + setuptools, +}: buildPythonApplication { pname = "termpdf.py"; diff --git a/pkgs/applications/misc/tipp10/default.nix b/pkgs/applications/misc/tipp10/default.nix index 2986d7981b35f4..29f1591b9fc851 100644 --- a/pkgs/applications/misc/tipp10/default.nix +++ b/pkgs/applications/misc/tipp10/default.nix @@ -1,5 +1,14 @@ -{ stdenv, cmake, lib, fetchFromGitLab, - qtmultimedia, qttools, qtwayland, wrapQtAppsHook, ... }: +{ + stdenv, + cmake, + lib, + fetchFromGitLab, + qtmultimedia, + qttools, + qtwayland, + wrapQtAppsHook, + ... +}: stdenv.mkDerivation rec { pname = "tipp10"; @@ -12,8 +21,15 @@ stdenv.mkDerivation rec { hash = "sha256-e0sWH4pT7ej9XGK/Sg9XMX2bMqcXqtSaYI7KBZTXvp4="; }; - nativeBuildInputs = [ cmake qttools wrapQtAppsHook ]; - buildInputs = [ qtmultimedia qtwayland ]; + nativeBuildInputs = [ + cmake + qttools + wrapQtAppsHook + ]; + buildInputs = [ + qtmultimedia + qtwayland + ]; meta = { description = "Learn and train typing with the ten-finger system"; diff --git a/pkgs/applications/misc/tpmmanager/default.nix b/pkgs/applications/misc/tpmmanager/default.nix index 763cd75ffdbfa6..0e25349d2f338b 100644 --- a/pkgs/applications/misc/tpmmanager/default.nix +++ b/pkgs/applications/misc/tpmmanager/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, qtbase, qmake, wrapQtAppsHook, trousers }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + qtbase, + qmake, + wrapQtAppsHook, + trousers, +}: stdenv.mkDerivation rec { version = "0.8.1"; @@ -23,9 +32,15 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; - buildInputs = [ qtbase trousers ]; + buildInputs = [ + qtbase + trousers + ]; installPhase = '' mkdir -p $out/bin @@ -41,7 +56,7 @@ stdenv.mkDerivation rec { Exec=$out/bin/tpmmanager Terminal=false EOF - ''; + ''; meta = { homepage = "https://projects.sirrix.com/trac/tpmmanager"; diff --git a/pkgs/applications/misc/trenchbroom/default.nix b/pkgs/applications/misc/trenchbroom/default.nix index df7cb0a0839230..646cac86cb8b9f 100644 --- a/pkgs/applications/misc/trenchbroom/default.nix +++ b/pkgs/applications/misc/trenchbroom/default.nix @@ -1,9 +1,32 @@ -{ lib, stdenv, fetchFromGitHub, writeText -, cmake, ninja, curl, git, pandoc, pkg-config, unzip, zip -, libGL, libGLU, freeimage, freetype, assimp -, catch2, fmt, glew, miniz, tinyxml-2, xorg -, qtbase, qtwayland, wrapQtAppsHook -, copyDesktopItems, makeDesktopItem +{ + lib, + stdenv, + fetchFromGitHub, + writeText, + cmake, + ninja, + curl, + git, + pandoc, + pkg-config, + unzip, + zip, + libGL, + libGLU, + freeimage, + freetype, + assimp, + catch2, + fmt, + glew, + miniz, + tinyxml-2, + xorg, + qtbase, + qtwayland, + wrapQtAppsHook, + copyDesktopItems, + makeDesktopItem, }: stdenv.mkDerivation rec { @@ -40,8 +63,10 @@ stdenv.mkDerivation rec { Architecture : ${vcpkg_target} Version : 1.0 Status : is installed - '') vcpkg_pkgs); - in '' + '') vcpkg_pkgs + ); + in + '' export VCPKG_ROOT="$TMP/vcpkg" mkdir -p $VCPKG_ROOT/.vcpkg-root @@ -71,11 +96,33 @@ stdenv.mkDerivation rec { --replace 'set(CPACK_PACKAGING_INSTALL_PREFIX "/usr")' 'set(CPACK_PACKAGING_INSTALL_PREFIX "'$out'")' ''; - nativeBuildInputs = [ cmake ninja curl git pandoc wrapQtAppsHook copyDesktopItems pkg-config unzip zip ]; + nativeBuildInputs = [ + cmake + ninja + curl + git + pandoc + wrapQtAppsHook + copyDesktopItems + pkg-config + unzip + zip + ]; buildInputs = [ - libGL libGLU xorg.libXxf86vm xorg.libSM - freeimage freetype qtbase qtwayland catch2 fmt - glew miniz tinyxml-2 assimp + libGL + libGLU + xorg.libXxf86vm + xorg.libSM + freeimage + freetype + qtbase + qtwayland + catch2 + fmt + glew + miniz + tinyxml-2 + assimp ]; QT_PLUGIN_PATH = "${qtbase}/${qtbase.qtPluginPrefix}"; QT_QPA_PLATFORM = "offscreen"; diff --git a/pkgs/applications/misc/tuxclocker/default.nix b/pkgs/applications/misc/tuxclocker/default.nix index 8f1cdde3d703f9..42f02f2ab223a0 100644 --- a/pkgs/applications/misc/tuxclocker/default.nix +++ b/pkgs/applications/misc/tuxclocker/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, boost -, fetchFromGitHub -, git -, makeWrapper -, meson -, ninja -, pkg-config -, python3 -, qtbase -, qtcharts -, tuxclocker-plugins -, tuxclocker-without-unfree -, wrapQtAppsHook +{ + lib, + stdenv, + boost, + fetchFromGitHub, + git, + makeWrapper, + meson, + ninja, + pkg-config, + python3, + qtbase, + qtcharts, + tuxclocker-plugins, + tuxclocker-without-unfree, + wrapQtAppsHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/misc/twitch-chat-downloader/default.nix b/pkgs/applications/misc/twitch-chat-downloader/default.nix index ffe1ddc9c220a5..e3b42c54a1988f 100644 --- a/pkgs/applications/misc/twitch-chat-downloader/default.nix +++ b/pkgs/applications/misc/twitch-chat-downloader/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, iso8601 -, progressbar2 -, requests +{ + lib, + buildPythonApplication, + fetchFromGitHub, + iso8601, + progressbar2, + requests, }: buildPythonApplication rec { diff --git a/pkgs/applications/misc/twmn/default.nix b/pkgs/applications/misc/twmn/default.nix index 7700c62a50642c..6a55e9ecdcbf1a 100644 --- a/pkgs/applications/misc/twmn/default.nix +++ b/pkgs/applications/misc/twmn/default.nix @@ -1,4 +1,13 @@ -{ lib, mkDerivation, fetchFromGitHub, qtbase, qtx11extras, qmake, pkg-config, boost }: +{ + lib, + mkDerivation, + fetchFromGitHub, + qtbase, + qtx11extras, + qmake, + pkg-config, + boost, +}: mkDerivation { pname = "twmn"; @@ -11,8 +20,15 @@ mkDerivation { sha256 = "0mpjvp800x07lp9i3hfcc5f4bqj1fj4w3dyr0zwaxc6wqmm0fdqz"; }; - nativeBuildInputs = [ pkg-config qmake ]; - buildInputs = [ qtbase qtx11extras boost ]; + nativeBuildInputs = [ + pkg-config + qmake + ]; + buildInputs = [ + qtbase + qtx11extras + boost + ]; postPatch = '' sed -i s/-Werror// twmnd/twmnd.pro diff --git a/pkgs/applications/misc/ubpm/default.nix b/pkgs/applications/misc/ubpm/default.nix index 883850f10b133d..013d31b9d57fdd 100644 --- a/pkgs/applications/misc/ubpm/default.nix +++ b/pkgs/applications/misc/ubpm/default.nix @@ -1,5 +1,16 @@ -{ stdenv, lib, fetchFromGitea, qmake, qttools, qtbase, qtserialport -, qtconnectivity, qtcharts, wrapQtAppsHook, fetchpatch }: +{ + stdenv, + lib, + fetchFromGitea, + qmake, + qttools, + qtbase, + qtserialport, + qtconnectivity, + qtcharts, + wrapQtAppsHook, + fetchpatch, +}: stdenv.mkDerivation (finalAttrs: { pname = "ubpm"; @@ -16,8 +27,7 @@ stdenv.mkDerivation (finalAttrs: { patches = [ # fixes qmake for nix (fetchpatch { - url = - "https://codeberg.org/LazyT/ubpm/commit/f18841d6473cab9aa2a9d4c02392b8e103245ef6.diff"; + url = "https://codeberg.org/LazyT/ubpm/commit/f18841d6473cab9aa2a9d4c02392b8e103245ef6.diff"; hash = "sha256-lgXWu8PUUCt66btj6hVgOFXz3U1BJM3ataSo1MpHkfU="; }) ]; @@ -30,12 +40,21 @@ stdenv.mkDerivation (finalAttrs: { wrapQtApp $out/bin/ubpm ''; - nativeBuildInputs = [ qmake qttools wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + qttools + wrapQtAppsHook + ]; # *.so plugins are being wrapped automatically which breaks them dontWrapQtApps = true; - buildInputs = [ qtbase qtserialport qtconnectivity qtcharts ]; + buildInputs = [ + qtbase + qtserialport + qtconnectivity + qtcharts + ]; meta = with lib; { homepage = "https://codeberg.org/LazyT/ubpm"; diff --git a/pkgs/applications/misc/visidata/default.nix b/pkgs/applications/misc/visidata/default.nix index 7cb59e2c8c2bfc..51530cec1a28cb 100644 --- a/pkgs/applications/misc/visidata/default.nix +++ b/pkgs/applications/misc/visidata/default.nix @@ -1,49 +1,53 @@ -{ stdenv -, lib -, buildPythonApplication -, fetchFromGitHub +{ + stdenv, + lib, + buildPythonApplication, + fetchFromGitHub, # python requirements -, beautifulsoup4 -, boto3 -, faker -, fonttools -, h5py -, importlib-metadata -, lxml -, matplotlib -, numpy -, odfpy -, openpyxl -, pandas -, pdfminer-six -, praw -, psutil -, psycopg2 -, pyarrow -, pyshp -, pypng -, msgpack -, brotli -, python-dateutil -, pyyaml -, requests -, seaborn -, setuptools -, sh -, tabulate -, urllib3 -, vobject -, wcwidth -, xlrd -, xlwt -, zstandard -, zulip -# other -, git -, withPcap ? true, dpkt, dnslib -, withXclip ? stdenv.hostPlatform.isLinux, xclip -, testers -, visidata + beautifulsoup4, + boto3, + faker, + fonttools, + h5py, + importlib-metadata, + lxml, + matplotlib, + numpy, + odfpy, + openpyxl, + pandas, + pdfminer-six, + praw, + psutil, + psycopg2, + pyarrow, + pyshp, + pypng, + msgpack, + brotli, + python-dateutil, + pyyaml, + requests, + seaborn, + setuptools, + sh, + tabulate, + urllib3, + vobject, + wcwidth, + xlrd, + xlwt, + zstandard, + zulip, + # other + git, + withPcap ? true, + dpkt, + dnslib, + withXclip ? stdenv.hostPlatform.isLinux, + xclip, + testers, + visidata, }: buildPythonApplication rec { pname = "visidata"; @@ -56,60 +60,65 @@ buildPythonApplication rec { hash = "sha256-ICEYC9QjYrB+oTzakfjgyg4DigzDOtYnqHRTaqF7Gw0="; }; - propagatedBuildInputs = [ - # from visidata/requirements.txt - # packages not (yet) present in nixpkgs are commented - python-dateutil - pandas - requests - lxml - openpyxl - xlrd - xlwt - h5py - psycopg2 - boto3 - pyshp - #mapbox-vector-tile - pypng - #pyconll - msgpack - brotli - #fecfile - fonttools - #sas7bdat - #xport - #savReaderWriter - pyyaml - #namestand - #datapackage - pdfminer-six - #tabula - vobject - tabulate - wcwidth - zstandard - odfpy - urllib3 - pyarrow - seaborn - matplotlib - sh - psutil - numpy + propagatedBuildInputs = + [ + # from visidata/requirements.txt + # packages not (yet) present in nixpkgs are commented + python-dateutil + pandas + requests + lxml + openpyxl + xlrd + xlwt + h5py + psycopg2 + boto3 + pyshp + #mapbox-vector-tile + pypng + #pyconll + msgpack + brotli + #fecfile + fonttools + #sas7bdat + #xport + #savReaderWriter + pyyaml + #namestand + #datapackage + pdfminer-six + #tabula + vobject + tabulate + wcwidth + zstandard + odfpy + urllib3 + pyarrow + seaborn + matplotlib + sh + psutil + numpy - #requests_cache - beautifulsoup4 + #requests_cache + beautifulsoup4 - faker - praw - zulip - #pyairtable + faker + praw + zulip + #pyairtable - setuptools - importlib-metadata - ] ++ lib.optionals withPcap [ dpkt dnslib ] - ++ lib.optional withXclip xclip; + setuptools + importlib-metadata + ] + ++ lib.optionals withPcap [ + dpkt + dnslib + ] + ++ lib.optional withXclip xclip; nativeCheckInputs = [ git @@ -147,7 +156,7 @@ buildPythonApplication rec { install -Dm644 _visidata -t $out/share/zsh/site-functions ''; - pythonImportsCheck = ["visidata"]; + pythonImportsCheck = [ "visidata" ]; passthru.tests.version = testers.testVersion { package = visidata; @@ -157,7 +166,10 @@ buildPythonApplication rec { meta = { description = "Interactive terminal multitool for tabular data"; license = lib.licenses.gpl3; - maintainers = with lib.maintainers; [ raskin markus1189 ]; + maintainers = with lib.maintainers; [ + raskin + markus1189 + ]; homepage = "https://visidata.org/"; changelog = "https://github.com/saulpw/visidata/blob/v${version}/CHANGELOG.md"; }; diff --git a/pkgs/applications/misc/whalebird/default.nix b/pkgs/applications/misc/whalebird/default.nix index 794ae86e0cfcc1..938904dfc7999f 100644 --- a/pkgs/applications/misc/whalebird/default.nix +++ b/pkgs/applications/misc/whalebird/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeDesktopItem -, copyDesktopItems -, makeWrapper -, electron -, cacert -, gitMinimal -, yarn +{ + lib, + stdenv, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + makeWrapper, + electron, + cacert, + gitMinimal, + yarn, }: stdenv.mkDerivation rec { pname = "whalebird"; @@ -108,6 +109,9 @@ stdenv.mkDerivation rec { changelog = "https://github.com/h3poteto/whalebird-desktop/releases/tag/v${version}"; license = licenses.gpl3Only; maintainers = with maintainers; [ weathercold ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; }; } diff --git a/pkgs/applications/misc/wikicurses/default.nix b/pkgs/applications/misc/wikicurses/default.nix index d339e8646e75f7..64f8f2cbac36c2 100644 --- a/pkgs/applications/misc/wikicurses/default.nix +++ b/pkgs/applications/misc/wikicurses/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, pythonPackages }: +{ + lib, + fetchFromGitHub, + pythonPackages, +}: pythonPackages.buildPythonApplication rec { version = "1.4"; @@ -11,9 +15,16 @@ pythonPackages.buildPythonApplication rec { sha256 = "0f14s4qx3q5pr5vn460c34b5mbz2xs62d8ljs3kic8gmdn8x2knm"; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - propagatedBuildInputs = with pythonPackages; [ urwid beautifulsoup4 lxml ]; + propagatedBuildInputs = with pythonPackages; [ + urwid + beautifulsoup4 + lxml + ]; postInstall = '' mkdir -p $man/share/man/man{1,5} @@ -33,4 +44,3 @@ pythonPackages.buildPythonApplication rec { }; } - diff --git a/pkgs/applications/misc/wordnet/default.nix b/pkgs/applications/misc/wordnet/default.nix index 6789c33ce29df3..0772cd2d01a225 100644 --- a/pkgs/applications/misc/wordnet/default.nix +++ b/pkgs/applications/misc/wordnet/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, tcl, tk, Cocoa, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + tcl, + tk, + Cocoa, + makeWrapper, +}: stdenv.mkDerivation rec { version = "3.0"; @@ -9,8 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ tcl tk ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; + buildInputs = [ + tcl + tk + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/applications/misc/workrave/default.nix b/pkgs/applications/misc/workrave/default.nix index 869f7c63712c77..5a0f4cd51acf6d 100644 --- a/pkgs/applications/misc/workrave/default.nix +++ b/pkgs/applications/misc/workrave/default.nix @@ -1,36 +1,37 @@ -{ lib -, stdenv -, fetchFromGitHub -, wrapGAppsHook3 -, autoconf -, autoconf-archive -, automake -, gettext -, intltool -, libtool -, pkg-config -, libICE -, libSM -, libXScrnSaver -, libXtst -, gobject-introspection -, glib -, glibmm -, gtkmm3 -, atk -, pango -, pangomm -, cairo -, cairomm -, dbus -, dbus-glib -, gdome2 -, gstreamer -, gst-plugins-base -, gst-plugins-good -, libsigcxx -, boost -, jinja2 +{ + lib, + stdenv, + fetchFromGitHub, + wrapGAppsHook3, + autoconf, + autoconf-archive, + automake, + gettext, + intltool, + libtool, + pkg-config, + libICE, + libSM, + libXScrnSaver, + libXtst, + gobject-introspection, + glib, + glibmm, + gtkmm3, + atk, + pango, + pangomm, + cairo, + cairomm, + dbus, + dbus-glib, + gdome2, + gstreamer, + gst-plugins-base, + gst-plugins-good, + libsigcxx, + boost, + jinja2, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/misc/xca/default.nix b/pkgs/applications/misc/xca/default.nix index 0863756777e232..bd8227b4c83519 100644 --- a/pkgs/applications/misc/xca/default.nix +++ b/pkgs/applications/misc/xca/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, wrapQtAppsHook -, cmake -, pkg-config -, openssl -, qtbase -, qttools -, sphinx +{ + stdenv, + lib, + fetchFromGitHub, + wrapQtAppsHook, + cmake, + pkg-config, + openssl, + qtbase, + qttools, + sphinx, }: stdenv.mkDerivation (finalAttrs: { @@ -21,7 +22,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-2TqqHTutG+5YU2mJNTS3pvtEqV7qKVB+j/dipdmEkIk="; }; - buildInputs = [ openssl qtbase ]; + buildInputs = [ + openssl + qtbase + ]; nativeBuildInputs = [ cmake @@ -48,7 +52,10 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "xca"; homepage = "https://hohnstaedt.de/xca/"; license = licenses.bsd3; - maintainers = with maintainers; [ offline peterhoeg ]; + maintainers = with maintainers; [ + offline + peterhoeg + ]; inherit (qtbase.meta) platforms; }; }) diff --git a/pkgs/applications/misc/xmrig/proxy.nix b/pkgs/applications/misc/xmrig/proxy.nix index 9efdbc700a6467..7090f85483b4c9 100644 --- a/pkgs/applications/misc/xmrig/proxy.nix +++ b/pkgs/applications/misc/xmrig/proxy.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, libuv -, libmicrohttpd -, openssl -, darwin +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + libuv, + libmicrohttpd, + openssl, + darwin, }: let @@ -34,14 +35,16 @@ stdenv.mkDerivation rec { cmake ]; - buildInputs = [ - libuv - libmicrohttpd - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreServices - IOKit - ]; + buildInputs = + [ + libuv + libmicrohttpd + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + IOKit + ]; installPhase = '' runHook preInstall diff --git a/pkgs/applications/misc/xpdf/default.nix b/pkgs/applications/misc/xpdf/default.nix index 13b4097f8cdf22..172da584bd0eb3 100644 --- a/pkgs/applications/misc/xpdf/default.nix +++ b/pkgs/applications/misc/xpdf/default.nix @@ -1,9 +1,19 @@ -{ enableGUI ? true -, enablePDFtoPPM ? true -, enablePrinting ? true -, lib, stdenv, fetchzip, cmake, makeDesktopItem -, zlib, libpng, cups ? null, freetype ? null -, qtbase ? null, qtsvg ? null, wrapQtAppsHook +{ + enableGUI ? true, + enablePDFtoPPM ? true, + enablePrinting ? true, + lib, + stdenv, + fetchzip, + cmake, + makeDesktopItem, + zlib, + libpng, + cups ? null, + freetype ? null, + qtbase ? null, + qtsvg ? null, + wrapQtAppsHook, }: assert enableGUI -> qtbase != null && qtsvg != null && freetype != null; @@ -28,19 +38,24 @@ stdenv.mkDerivation rec { postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' substituteInPlace CMakeLists.txt --replace \ 'cmake_minimum_required(VERSION 2.8.12)' 'cmake_minimum_required(VERSION 3.1.0)' - ''; + ''; - nativeBuildInputs = - [ cmake ] - ++ lib.optional enableGUI wrapQtAppsHook; + nativeBuildInputs = [ cmake ] ++ lib.optional enableGUI wrapQtAppsHook; - cmakeFlags = ["-DSYSTEM_XPDFRC=/etc/xpdfrc" "-DA4_PAPER=ON" "-DOPI_SUPPORT=ON"] - ++ lib.optional (!enablePrinting) "-DXPDFWIDGET_PRINTING=OFF"; + cmakeFlags = [ + "-DSYSTEM_XPDFRC=/etc/xpdfrc" + "-DA4_PAPER=ON" + "-DOPI_SUPPORT=ON" + ] ++ lib.optional (!enablePrinting) "-DXPDFWIDGET_PRINTING=OFF"; - buildInputs = [ zlib libpng ] ++ - lib.optional enableGUI qtbase ++ - lib.optional enablePrinting cups ++ - lib.optional enablePDFtoPPM freetype; + buildInputs = + [ + zlib + libpng + ] + ++ lib.optional enableGUI qtbase + ++ lib.optional enablePrinting cups + ++ lib.optional enablePDFtoPPM freetype; desktopItem = makeDesktopItem { name = "xpdf"; @@ -72,7 +87,10 @@ stdenv.mkDerivation rec { pdffonts: lists fonts used in PDF files pdfdetach: extracts attached files from PDF files ''; - license = with licenses; [ gpl2Only gpl3Only ]; + license = with licenses; [ + gpl2Only + gpl3Only + ]; platforms = platforms.unix; maintainers = with maintainers; [ sikmir ]; knownVulnerabilities = [ diff --git a/pkgs/applications/misc/xpdf/libxpdf.nix b/pkgs/applications/misc/xpdf/libxpdf.nix index 61c696f1309e56..6f7ccfb8974082 100644 --- a/pkgs/applications/misc/xpdf/libxpdf.nix +++ b/pkgs/applications/misc/xpdf/libxpdf.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation { diff --git a/pkgs/applications/misc/xsw/default.nix b/pkgs/applications/misc/xsw/default.nix index 0baf0dc47a4e04..fddaaa1652d74d 100644 --- a/pkgs/applications/misc/xsw/default.nix +++ b/pkgs/applications/misc/xsw/default.nix @@ -1,9 +1,21 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config, SDL, SDL_image, SDL_ttf, SDL_gfx, flex, bison }: +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + SDL, + SDL_image, + SDL_ttf, + SDL_gfx, + flex, + bison, +}: let makeSDLFlags = map (p: "-I${lib.getDev p}/include/SDL"); -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "xsw"; version = "0.1.2"; @@ -14,11 +26,25 @@ in stdenv.mkDerivation rec { sha256 = "092vp61ngd2vscsvyisi7dv6qrk5m1i81gg19hyfl5qvjq5p0p8g"; }; - nativeBuildInputs = [ pkg-config flex bison ]; + nativeBuildInputs = [ + pkg-config + flex + bison + ]; - buildInputs = [ SDL SDL_image SDL_ttf SDL_gfx ]; + buildInputs = [ + SDL + SDL_image + SDL_ttf + SDL_gfx + ]; - env.NIX_CFLAGS_COMPILE = toString (makeSDLFlags [ SDL SDL_image SDL_ttf SDL_gfx ]); + env.NIX_CFLAGS_COMPILE = toString (makeSDLFlags [ + SDL + SDL_image + SDL_ttf + SDL_gfx + ]); patches = [ ./parse.patch # Fixes compilation error by avoiding redundant definitions. @@ -29,7 +55,7 @@ in stdenv.mkDerivation rec { description = "Slide show presentation tool"; platforms = platforms.unix; - license = licenses.gpl3; + license = licenses.gpl3; maintainers = [ ]; mainProgram = "xsw"; }; diff --git a/pkgs/applications/misc/xygrib/default.nix b/pkgs/applications/misc/xygrib/default.nix index 32605747399a34..72a5f47d9053b0 100644 --- a/pkgs/applications/misc/xygrib/default.nix +++ b/pkgs/applications/misc/xygrib/default.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, wrapQtAppsHook, cmake, bzip2, qtbase, qttools, libnova, proj_7, libpng, openjpeg }: +{ + lib, + stdenv, + fetchFromGitHub, + wrapQtAppsHook, + cmake, + bzip2, + qtbase, + qttools, + libnova, + proj_7, + libpng, + openjpeg, +}: stdenv.mkDerivation rec { version = "unstable-2022-05-16"; @@ -11,26 +24,43 @@ stdenv.mkDerivation rec { sha256 = "sha256-qMMeRYIQqJpVRE3YjbXIiXHwS/CHs9l2QihszwQIr/A="; }; - nativeBuildInputs = [ cmake qttools wrapQtAppsHook ]; - buildInputs = [ bzip2 qtbase libnova proj_7 openjpeg libpng ]; - cmakeFlags = [ "-DOPENJPEG_INCLUDE_DIR=${openjpeg.dev}/include/openjpeg-${lib.versions.majorMinor openjpeg.version}" ] + nativeBuildInputs = [ + cmake + qttools + wrapQtAppsHook + ]; + buildInputs = [ + bzip2 + qtbase + libnova + proj_7 + openjpeg + libpng + ]; + cmakeFlags = + [ + "-DOPENJPEG_INCLUDE_DIR=${openjpeg.dev}/include/openjpeg-${lib.versions.majorMinor openjpeg.version}" + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ "-DLIBNOVA_LIBRARY=${libnova}/lib/libnova.dylib" ]; postInstall = - if stdenv.hostPlatform.isDarwin then '' - mkdir -p "$out/Applications" "$out/XyGrib/XyGrib.app/Contents/Resources" - cp "../data/img/xyGrib.icns" "$out/XyGrib/XyGrib.app/Contents/Resources/xyGrib.icns" - mv $out/XyGrib/XyGrib.app $out/Applications - wrapQtApp "$out/Applications/XyGrib.app/Contents/MacOS/XyGrib" - '' else '' - wrapQtApp $out/XyGrib/XyGrib - mkdir -p $out/bin - ln -s $out/XyGrib/XyGrib $out/bin/xygrib - install -Dm444 $src/debian/xygrib.png -t $out/share/icons/hicolor/32x32/apps - install -Dm444 $src/debian/xygrib.desktop -t $out/share/applications - substituteInPlace $out/share/applications/xygrib.desktop \ - --replace 'Exec=XyGrib' 'Exec=xygrib' - ''; + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p "$out/Applications" "$out/XyGrib/XyGrib.app/Contents/Resources" + cp "../data/img/xyGrib.icns" "$out/XyGrib/XyGrib.app/Contents/Resources/xyGrib.icns" + mv $out/XyGrib/XyGrib.app $out/Applications + wrapQtApp "$out/Applications/XyGrib.app/Contents/MacOS/XyGrib" + '' + else + '' + wrapQtApp $out/XyGrib/XyGrib + mkdir -p $out/bin + ln -s $out/XyGrib/XyGrib $out/bin/xygrib + install -Dm444 $src/debian/xygrib.png -t $out/share/icons/hicolor/32x32/apps + install -Dm444 $src/debian/xygrib.desktop -t $out/share/applications + substituteInPlace $out/share/applications/xygrib.desktop \ + --replace 'Exec=XyGrib' 'Exec=xygrib' + ''; meta = with lib; { homepage = "https://opengribs.org"; diff --git a/pkgs/applications/misc/yokadi/default.nix b/pkgs/applications/misc/yokadi/default.nix index 55acd53fd1e0fd..84030033ffe0ac 100644 --- a/pkgs/applications/misc/yokadi/default.nix +++ b/pkgs/applications/misc/yokadi/default.nix @@ -1,5 +1,12 @@ -{ lib, fetchurl, buildPythonApplication, python-dateutil, - sqlalchemy, setproctitle, icalendar }: +{ + lib, + fetchurl, + buildPythonApplication, + python-dateutil, + sqlalchemy, + setproctitle, + icalendar, +}: buildPythonApplication rec { pname = "yokadi"; diff --git a/pkgs/applications/networking/breitbandmessung/default.nix b/pkgs/applications/networking/breitbandmessung/default.nix index 6bcd3c662e86c3..56315779dd1112 100644 --- a/pkgs/applications/networking/breitbandmessung/default.nix +++ b/pkgs/applications/networking/breitbandmessung/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, asar -, dpkg -, electron -, makeWrapper -, nixosTests -, undmg +{ + lib, + stdenv, + fetchurl, + asar, + dpkg, + electron, + makeWrapper, + nixosTests, + undmg, }: let @@ -14,74 +15,85 @@ let sources = import ./sources.nix; - systemArgs = rec { - x86_64-linux = { - src = fetchurl sources.x86_64-linux; + systemArgs = + rec { + x86_64-linux = { + src = fetchurl sources.x86_64-linux; - nativeBuildInputs = [ - asar - dpkg - makeWrapper - ]; + nativeBuildInputs = [ + asar + dpkg + makeWrapper + ]; - installPhase = '' - mkdir -p $out/bin - mv usr/share $out/share - mkdir -p $out/share/breitbandmessung/resources + installPhase = '' + mkdir -p $out/bin + mv usr/share $out/share + mkdir -p $out/share/breitbandmessung/resources - asar e opt/Breitbandmessung/resources/app.asar $out/share/breitbandmessung/resources + asar e opt/Breitbandmessung/resources/app.asar $out/share/breitbandmessung/resources - # At first start, the program checks for supported operating systems by using the `bizzby-lsb-release` - # module and only runs when it finds Debian/Ubuntu. So we present us as Debian and make it happy. - cat < $out/share/breitbandmessung/resources/node_modules/bizzby-lsb-release/lib/lsb-release.js - module.exports = function release() { - return { - distributorID: "Debian", - description: "Debian GNU/Linux 10 (buster)", - release: "10", - codename: "buster" + # At first start, the program checks for supported operating systems by using the `bizzby-lsb-release` + # module and only runs when it finds Debian/Ubuntu. So we present us as Debian and make it happy. + cat < $out/share/breitbandmessung/resources/node_modules/bizzby-lsb-release/lib/lsb-release.js + module.exports = function release() { + return { + distributorID: "Debian", + description: "Debian GNU/Linux 10 (buster)", + release: "10", + codename: "buster" + } } - } - EOF + EOF - makeWrapper ${electron}/bin/electron $out/bin/breitbandmessung \ - --add-flags $out/share/breitbandmessung/resources/build/electron.js + makeWrapper ${electron}/bin/electron $out/bin/breitbandmessung \ + --add-flags $out/share/breitbandmessung/resources/build/electron.js - # Fix the desktop link - substituteInPlace $out/share/applications/breitbandmessung.desktop \ - --replace /opt/Breitbandmessung $out/bin - ''; - }; + # Fix the desktop link + substituteInPlace $out/share/applications/breitbandmessung.desktop \ + --replace /opt/Breitbandmessung $out/bin + ''; + }; - x86_64-darwin = { - src = fetchurl sources.x86_64-darwin; + x86_64-darwin = { + src = fetchurl sources.x86_64-darwin; - nativeBuildInputs = [ undmg ]; + nativeBuildInputs = [ undmg ]; - installPhase = '' - runHook preInstall - mkdir -p $out/Applications/Breitbandmessung.app - cp -R . $out/Applications/Breitbandmessung.app - runHook postInstall - ''; - }; + installPhase = '' + runHook preInstall + mkdir -p $out/Applications/Breitbandmessung.app + cp -R . $out/Applications/Breitbandmessung.app + runHook postInstall + ''; + }; - aarch64-darwin = x86_64-darwin; - }.${system} or { src = throw "Unsupported system: ${system}"; }; + aarch64-darwin = x86_64-darwin; + } + .${system} or { + src = throw "Unsupported system: ${system}"; + }; in -stdenv.mkDerivation ({ - pname = "breitbandmessung"; - inherit (sources) version; +stdenv.mkDerivation ( + { + pname = "breitbandmessung"; + inherit (sources) version; - passthru.tests = { inherit (nixosTests) breitbandmessung; }; - passthru.updateScript = ./update.sh; + passthru.tests = { inherit (nixosTests) breitbandmessung; }; + passthru.updateScript = ./update.sh; - meta = with lib; { - description = "Broadband internet speed test app from the german Bundesnetzagentur"; - homepage = "https://www.breitbandmessung.de"; - license = licenses.unfree; - sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - maintainers = with maintainers; [ b4dm4n ]; - platforms = [ "x86_64-linux" "x86_64-darwin" "aarch64-darwin" ]; - }; -} // systemArgs) + meta = with lib; { + description = "Broadband internet speed test app from the german Bundesnetzagentur"; + homepage = "https://www.breitbandmessung.de"; + license = licenses.unfree; + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; + maintainers = with maintainers; [ b4dm4n ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; + }; + } + // systemArgs +) diff --git a/pkgs/applications/networking/browsers/asuka/default.nix b/pkgs/applications/networking/browsers/asuka/default.nix index 786f11d2d743c6..c2f6a0936771fd 100644 --- a/pkgs/applications/networking/browsers/asuka/default.nix +++ b/pkgs/applications/networking/browsers/asuka/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, rustPlatform, fetchFromSourcehut, pkg-config, ncurses, openssl, Security }: +{ + lib, + stdenv, + rustPlatform, + fetchFromSourcehut, + pkg-config, + ncurses, + openssl, + Security, +}: rustPlatform.buildRustPackage rec { pname = "asuka"; @@ -15,8 +24,10 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ ncurses openssl ] - ++ lib.optional stdenv.hostPlatform.isDarwin Security; + buildInputs = [ + ncurses + openssl + ] ++ lib.optional stdenv.hostPlatform.isDarwin Security; meta = with lib; { description = "Gemini Project client written in Rust with NCurses"; diff --git a/pkgs/applications/networking/browsers/chromium/browser.nix b/pkgs/applications/networking/browsers/chromium/browser.nix index bdedac20c5ebd3..9006e143ed6ea8 100644 --- a/pkgs/applications/networking/browsers/chromium/browser.nix +++ b/pkgs/applications/networking/browsers/chromium/browser.nix @@ -1,14 +1,24 @@ -{ lib, mkChromiumDerivation -, chromiumVersionAtLeast -, enableWideVine, ungoogled +{ + lib, + mkChromiumDerivation, + chromiumVersionAtLeast, + enableWideVine, + ungoogled, }: mkChromiumDerivation (base: rec { name = "chromium-browser"; packageName = "chromium"; - buildTargets = [ "run_mksnapshot_default" "chrome_sandbox" "chrome" ]; + buildTargets = [ + "run_mksnapshot_default" + "chrome_sandbox" + "chrome" + ]; - outputs = ["out" "sandbox"]; + outputs = [ + "out" + "sandbox" + ]; sandboxExecutableName = "__chromium-suid-sandbox"; @@ -73,7 +83,8 @@ mkChromiumDerivation (base: rec { requiredSystemFeatures = [ "big-parallel" ]; meta = { - description = "Open source web browser from Google" + description = + "Open source web browser from Google" + lib.optionalString ungoogled ", with dependencies on Google web services removed"; longDescription = '' Chromium is an open source web browser from Google that aims to build a @@ -81,18 +92,32 @@ mkChromiumDerivation (base: rec { the web. It has a minimalist user interface and provides the vast majority of source code for Google Chrome (which has some additional features). ''; - homepage = if ungoogled - then "https://github.com/ungoogled-software/ungoogled-chromium" - else "https://www.chromium.org/"; + homepage = + if ungoogled then + "https://github.com/ungoogled-software/ungoogled-chromium" + else + "https://www.chromium.org/"; # Maintainer pings for this derivation are highly unreliable. # If you add yourself as maintainer here, please also add yourself as CODEOWNER. - maintainers = with lib.maintainers; if ungoogled - then [ networkexception emilylange ] - else [ networkexception emilylange ]; + maintainers = + with lib.maintainers; + if ungoogled then + [ + networkexception + emilylange + ] + else + [ + networkexception + emilylange + ]; license = if enableWideVine then lib.licenses.unfree else lib.licenses.bsd3; platforms = lib.platforms.linux; mainProgram = "chromium"; - hydraPlatforms = ["aarch64-linux" "x86_64-linux"]; + hydraPlatforms = [ + "aarch64-linux" + "x86_64-linux" + ]; timeout = 172800; # 48 hours (increased from the Hydra default of 10h) }; }) diff --git a/pkgs/applications/networking/browsers/chromium/common.nix b/pkgs/applications/networking/browsers/chromium/common.nix index c0a661a8603890..0c990c1b9d2a16 100644 --- a/pkgs/applications/networking/browsers/chromium/common.nix +++ b/pkgs/applications/networking/browsers/chromium/common.nix @@ -1,97 +1,152 @@ -{ stdenv, lib, fetchpatch -, zstd -, fetchFromGitiles -, fetchNpmDeps -, buildPackages -, pkgsBuildBuild -# Channel data: -, upstream-info -# Helper functions: -, chromiumVersionAtLeast, versionRange - -# Native build inputs: -, ninja, pkg-config -, python3, perl -, nodejs -, npmHooks -, which -, libuuid -, overrideCC -# postPatch: -, pkgsBuildHost -# configurePhase: -, gnChromium -, symlinkJoin - -# Build inputs: -, libpng -, bzip2, flac, speex, libopus -, libevent, expat, libjpeg, snappy -, libcap -, minizip, libwebp -, libusb1, re2 -, ffmpeg, libxslt, libxml2 -, nasm -, nspr, nss -, util-linux, alsa-lib -, bison, gperf, libkrb5 -, glib, gtk3, dbus-glib -, libXScrnSaver, libXcursor, libXtst, libxshmfence, libGLU, libGL -, mesa -, pciutils, protobuf, speechd-minimal, libXdamage, at-spi2-core -, pipewire -, libva -, libdrm, wayland, libxkbcommon # Ozone -, curl -, libffi -, libepoxy -, libevdev -# postPatch: -, glibc # gconv + locale -# postFixup: -, vulkan-loader - -# Package customization: -, cupsSupport ? true, cups ? null -, proprietaryCodecs ? true -, pulseSupport ? false, libpulseaudio ? null -, ungoogled ? false, ungoogled-chromium -# Optional dependencies: -, libgcrypt ? null # cupsSupport -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd -, systemd +{ + stdenv, + lib, + fetchpatch, + zstd, + fetchFromGitiles, + fetchNpmDeps, + buildPackages, + pkgsBuildBuild, + # Channel data: + upstream-info, + # Helper functions: + chromiumVersionAtLeast, + versionRange, + + # Native build inputs: + ninja, + pkg-config, + python3, + perl, + nodejs, + npmHooks, + which, + libuuid, + overrideCC, + # postPatch: + pkgsBuildHost, + # configurePhase: + gnChromium, + symlinkJoin, + + # Build inputs: + libpng, + bzip2, + flac, + speex, + libopus, + libevent, + expat, + libjpeg, + snappy, + libcap, + minizip, + libwebp, + libusb1, + re2, + ffmpeg, + libxslt, + libxml2, + nasm, + nspr, + nss, + util-linux, + alsa-lib, + bison, + gperf, + libkrb5, + glib, + gtk3, + dbus-glib, + libXScrnSaver, + libXcursor, + libXtst, + libxshmfence, + libGLU, + libGL, + mesa, + pciutils, + protobuf, + speechd-minimal, + libXdamage, + at-spi2-core, + pipewire, + libva, + libdrm, + wayland, + libxkbcommon, # Ozone + curl, + libffi, + libepoxy, + libevdev, + # postPatch: + glibc, # gconv + locale + # postFixup: + vulkan-loader, + + # Package customization: + cupsSupport ? true, + cups ? null, + proprietaryCodecs ? true, + pulseSupport ? false, + libpulseaudio ? null, + ungoogled ? false, + ungoogled-chromium, + # Optional dependencies: + libgcrypt ? null, # cupsSupport + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, }: buildFun: let - python3WithPackages = python3.pythonOnBuildForHost.withPackages(ps: with ps; [ - ply jinja2 setuptools - ]); + python3WithPackages = python3.pythonOnBuildForHost.withPackages ( + ps: with ps; [ + ply + jinja2 + setuptools + ] + ); # The additional attributes for creating derivations based on the chromium # source tree. extraAttrs = buildFun base; - githubPatch = { commit, hash, revert ? false, excludes ? [] }: fetchpatch { - url = "https://github.com/chromium/chromium/commit/${commit}.patch"; - inherit hash revert excludes; - }; + githubPatch = + { + commit, + hash, + revert ? false, + excludes ? [ ], + }: + fetchpatch { + url = "https://github.com/chromium/chromium/commit/${commit}.patch"; + inherit hash revert excludes; + }; mkGnFlags = let # Serialize Nix types into GN types according to this document: # https://source.chromium.org/gn/gn/+/master:docs/language.md - mkGnString = value: "\"${lib.escape ["\"" "$" "\\"] value}\""; - sanitize = value: - if value == true then "true" - else if value == false then "false" - else if lib.isList value then "[${lib.concatMapStringsSep ", " sanitize value}]" - else if lib.isInt value then toString value - else if lib.isString value then mkGnString value - else throw "Unsupported type for GN value `${value}'."; + mkGnString = value: "\"${lib.escape [ "\"" "$" "\\" ] value}\""; + sanitize = + value: + if value == true then + "true" + else if value == false then + "false" + else if lib.isList value then + "[${lib.concatMapStringsSep ", " sanitize value}]" + else if lib.isInt value then + toString value + else if lib.isString value then + mkGnString value + else + throw "Unsupported type for GN value `${value}'."; toFlag = key: value: "${key}=${sanitize value}"; - in attrs: lib.concatStringsSep " " (lib.attrValues (lib.mapAttrs toFlag attrs)); + in + attrs: lib.concatStringsSep " " (lib.attrValues (lib.mapAttrs toFlag attrs)); # https://source.chromium.org/chromium/chromium/src/+/master:build/linux/unbundle/replace_gn_files.py gnSystemLibraries = [ @@ -111,7 +166,6 @@ let # "opus" ]; - # build paths and release info packageName = extraAttrs.packageName or extraAttrs.name; buildType = "Release"; @@ -129,61 +183,83 @@ let let llvmPackages = pkgsBuildBuild.rustc.llvmPackages; in - overrideCC llvmPackages.stdenv - (llvmPackages.stdenv.cc.override { - inherit (llvmPackages) bintools; - }); + overrideCC llvmPackages.stdenv ( + llvmPackages.stdenv.cc.override { + inherit (llvmPackages) bintools; + } + ); chromiumRosettaStone = { - cpu = platform: - let name = platform.parsed.cpu.name; - in ({ "x86_64" = "x64"; - "i686" = "x86"; - "arm" = "arm"; - "aarch64" = "arm64"; - }.${platform.parsed.cpu.name} - or (throw "no chromium Rosetta Stone entry for cpu: ${name}")); - os = platform: - if platform.isLinux - then "linux" - else throw "no chromium Rosetta Stone entry for os: ${platform.config}"; + cpu = + platform: + let + name = platform.parsed.cpu.name; + in + ( + { + "x86_64" = "x64"; + "i686" = "x86"; + "arm" = "arm"; + "aarch64" = "arm64"; + } + .${platform.parsed.cpu.name} or (throw "no chromium Rosetta Stone entry for cpu: ${name}") + ); + os = + platform: + if platform.isLinux then + "linux" + else + throw "no chromium Rosetta Stone entry for os: ${platform.config}"; }; isElectron = packageName == "electron"; - chromiumDeps = lib.mapAttrs (path: args: fetchFromGitiles (removeAttrs args [ "recompress" ] // lib.optionalAttrs args.recompress or false { - name = "source.tar.zstd"; - downloadToTemp = false; - passthru.unpack = true; - postFetch = '' - tar \ - --use-compress-program="${lib.getExe zstd} -T$NIX_BUILD_CORES" \ - --sort=name \ - --mtime="1970-01-01" \ - --owner=root --group=root \ - --numeric-owner --mode=go=rX,u+rw,a-s \ - --remove-files \ - --directory="$out" \ - -cf "$TMPDIR/source.zstd" . - mv "$TMPDIR/source.zstd" "$out" - ''; - })) upstream-info.DEPS; - - unpackPhaseSnippet = lib.concatStrings (lib.mapAttrsToList (path: dep: - (if dep.unpack or false - then '' - mkdir -p ${path} - pushd ${path} - unpackFile ${dep} - popd - '' - else '' - mkdir -p ${builtins.dirOf path} - cp -r ${dep}/. ${path} + chromiumDeps = lib.mapAttrs ( + path: args: + fetchFromGitiles ( + removeAttrs args [ "recompress" ] + // lib.optionalAttrs args.recompress or false { + name = "source.tar.zstd"; + downloadToTemp = false; + passthru.unpack = true; + postFetch = '' + tar \ + --use-compress-program="${lib.getExe zstd} -T$NIX_BUILD_CORES" \ + --sort=name \ + --mtime="1970-01-01" \ + --owner=root --group=root \ + --numeric-owner --mode=go=rX,u+rw,a-s \ + --remove-files \ + --directory="$out" \ + -cf "$TMPDIR/source.zstd" . + mv "$TMPDIR/source.zstd" "$out" + ''; + } + ) + ) upstream-info.DEPS; + + unpackPhaseSnippet = lib.concatStrings ( + lib.mapAttrsToList ( + path: dep: + ( + if dep.unpack or false then + '' + mkdir -p ${path} + pushd ${path} + unpackFile ${dep} + popd + '' + else + '' + mkdir -p ${builtins.dirOf path} + cp -r ${dep}/. ${path} + '' + ) + + '' + chmod u+w -R ${path} '' - ) + '' - chmod u+w -R ${path} - '') chromiumDeps); + ) chromiumDeps + ); base = rec { pname = "${lib.optionalString ungoogled "ungoogled-"}${packageName}-unwrapped"; @@ -200,292 +276,374 @@ let ''; npmRoot = "third_party/node"; - npmDeps = (fetchNpmDeps { - src = chromiumDeps."src"; - sourceRoot = npmRoot; - hash = upstream-info.deps.npmHash; - }).overrideAttrs (p: { - nativeBuildInputs = p.nativeBuildInputs or [ ] ++ [ zstd ]; - }); - - nativeBuildInputs = [ - ninja pkg-config - python3WithPackages perl - which - buildPackages.rustc.llvmPackages.bintools - bison gperf - ] ++ lib.optionals (!isElectron) [ - nodejs - npmHooks.npmConfigHook - ]; - - depsBuildBuild = [ - buildPlatformLlvmStdenv - buildPlatformLlvmStdenv.cc - pkg-config - libuuid - ] - # When cross-compiling, chromium builds a huge proportion of its - # components for both the `buildPlatform` (which it calls - # `host`) as well as for the `hostPlatform` -- easily more than - # half of the dependencies are needed here. To avoid having to - # maintain a separate list of buildPlatform-dependencies, we - # simply throw in the kitchen sink. - # ** Because of overrides, we have to copy the list as it otherwise mess with splicing ** - ++ [ - (buildPackages.libpng.override { apngSupport = false; }) # https://bugs.chromium.org/p/chromium/issues/detail?id=752403 - (buildPackages.libopus.override { withCustomModes = true; }) - bzip2 flac speex - libevent expat libjpeg snappy - libcap - minizip libwebp - libusb1 re2 - ffmpeg libxslt libxml2 - nasm - nspr nss - util-linux alsa-lib - libkrb5 - glib gtk3 dbus-glib - libXScrnSaver libXcursor libXtst libxshmfence libGLU libGL - mesa # required for libgbm - pciutils protobuf speechd-minimal libXdamage at-spi2-core - pipewire - libva - libdrm wayland libxkbcommon - curl - libepoxy - libffi - libevdev - ] ++ lib.optional systemdSupport systemd - ++ lib.optionals cupsSupport [ libgcrypt cups ] + npmDeps = + (fetchNpmDeps { + src = chromiumDeps."src"; + sourceRoot = npmRoot; + hash = upstream-info.deps.npmHash; + }).overrideAttrs + (p: { + nativeBuildInputs = p.nativeBuildInputs or [ ] ++ [ zstd ]; + }); + + nativeBuildInputs = + [ + ninja + pkg-config + python3WithPackages + perl + which + buildPackages.rustc.llvmPackages.bintools + bison + gperf + ] + ++ lib.optionals (!isElectron) [ + nodejs + npmHooks.npmConfigHook + ]; + + depsBuildBuild = + [ + buildPlatformLlvmStdenv + buildPlatformLlvmStdenv.cc + pkg-config + libuuid + ] + # When cross-compiling, chromium builds a huge proportion of its + # components for both the `buildPlatform` (which it calls + # `host`) as well as for the `hostPlatform` -- easily more than + # half of the dependencies are needed here. To avoid having to + # maintain a separate list of buildPlatform-dependencies, we + # simply throw in the kitchen sink. + # ** Because of overrides, we have to copy the list as it otherwise mess with splicing ** + ++ [ + (buildPackages.libpng.override { apngSupport = false; }) # https://bugs.chromium.org/p/chromium/issues/detail?id=752403 + (buildPackages.libopus.override { withCustomModes = true; }) + bzip2 + flac + speex + libevent + expat + libjpeg + snappy + libcap + minizip + libwebp + libusb1 + re2 + ffmpeg + libxslt + libxml2 + nasm + nspr + nss + util-linux + alsa-lib + libkrb5 + glib + gtk3 + dbus-glib + libXScrnSaver + libXcursor + libXtst + libxshmfence + libGLU + libGL + mesa # required for libgbm + pciutils + protobuf + speechd-minimal + libXdamage + at-spi2-core + pipewire + libva + libdrm + wayland + libxkbcommon + curl + libepoxy + libffi + libevdev + ] + ++ lib.optional systemdSupport systemd + ++ lib.optionals cupsSupport [ + libgcrypt + cups + ] ++ lib.optional pulseSupport libpulseaudio; - buildInputs = [ - (libpng.override { apngSupport = false; }) # https://bugs.chromium.org/p/chromium/issues/detail?id=752403 - (libopus.override { withCustomModes = true; }) - bzip2 flac speex - libevent expat libjpeg snappy - libcap - minizip libwebp - libusb1 re2 - ffmpeg libxslt libxml2 - nasm - nspr nss - util-linux alsa-lib - libkrb5 - glib gtk3 dbus-glib - libXScrnSaver libXcursor libXtst libxshmfence libGLU libGL - mesa # required for libgbm - pciutils protobuf speechd-minimal libXdamage at-spi2-core - pipewire - libva - libdrm wayland libxkbcommon - curl - libepoxy - libffi - libevdev - ] ++ lib.optional systemdSupport systemd - ++ lib.optionals cupsSupport [ libgcrypt cups ] + buildInputs = + [ + (libpng.override { apngSupport = false; }) # https://bugs.chromium.org/p/chromium/issues/detail?id=752403 + (libopus.override { withCustomModes = true; }) + bzip2 + flac + speex + libevent + expat + libjpeg + snappy + libcap + minizip + libwebp + libusb1 + re2 + ffmpeg + libxslt + libxml2 + nasm + nspr + nss + util-linux + alsa-lib + libkrb5 + glib + gtk3 + dbus-glib + libXScrnSaver + libXcursor + libXtst + libxshmfence + libGLU + libGL + mesa # required for libgbm + pciutils + protobuf + speechd-minimal + libXdamage + at-spi2-core + pipewire + libva + libdrm + wayland + libxkbcommon + curl + libepoxy + libffi + libevdev + ] + ++ lib.optional systemdSupport systemd + ++ lib.optionals cupsSupport [ + libgcrypt + cups + ] ++ lib.optional pulseSupport libpulseaudio; - patches = [ - ./patches/cross-compile.patch - # Optional patch to use SOURCE_DATE_EPOCH in compute_build_timestamp.py (should be upstreamed): - ./patches/no-build-timestamps.patch - ] ++ lib.optionals (packageName == "chromium") [ - # This patch is limited to chromium and ungoogled-chromium because electron-source sets - # enable_widevine to false. - # - # The patch disables the automatic Widevine download (component) that happens at runtime - # completely (~/.config/chromium/WidevineCdm/). This would happen if chromium encounters DRM - # protected content or when manually opening chrome://components. - # - # It also prevents previously downloaded Widevine blobs in that location from being loaded and - # used at all, while still allowing the use of our -wv wrapper. This is because those old - # versions are out of out our control and may be vulnerable, given we literally disable their - # auto updater. - # - # bundle_widevine_cdm is available as gn flag, but we cannot use it, as it expects a bunch of - # files Widevine files at configure/compile phase that we don't have. Changing the value of the - # BUNDLE_WIDEVINE_CDM build flag does work in the way we want though. - # We also need enable_widevine_cdm_component to be false. Unfortunately it isn't exposed as gn - # flag (declare_args) so we simply hardcode it to false. - ./patches/widevine-disable-auto-download-allow-bundle.patch - ] ++ lib.optionals (versionRange "127" "128") [ - # Fix missing chrome/browser/ui/webui_name_variants.h dependency - # and ninja 1.12 compat in M127. - # https://issues.chromium.org/issues/345645751 - # https://issues.chromium.org/issues/40253918 - # https://chromium-review.googlesource.com/c/chromium/src/+/5641516 - (githubPatch { - commit = "2c101186b60ed50f2ba4feaa2e963bd841bcca47"; - hash = "sha256-luu3ggo6XoeeECld1cKZ6Eh8x/qQYmmKI/ThEhuutuY="; - }) - # https://chromium-review.googlesource.com/c/chromium/src/+/5644627 - (githubPatch { - commit = "f2b43c18b8ecfc3ddc49c42c062d796c8b563984"; - hash = "sha256-uxXxSsiS8R0827Oi3xsG2gtT0X+jJXziwZ1y8+7K+Qg="; - }) - # https://chromium-review.googlesource.com/c/chromium/src/+/5646245 - (githubPatch { - commit = "4ca70656fde83d2db6ed5a8ac9ec9e7443846924"; - hash = "sha256-iQuRRZjDDtJfr+B7MV+TvUDDX3bvpCnv8OpSLJ1WqCE="; - }) - # https://chromium-review.googlesource.com/c/chromium/src/+/5647662 - (githubPatch { - commit = "50d63ffee3f7f1b1b9303363742ad8ebbfec31fa"; - hash = "sha256-H+dv+lgXSdry3NkygpbCdTAWWdTVdKdVD3Aa62w091E="; - }) - ] ++ [ - # Required to fix the build with a more recent wayland-protocols version - # (we currently package 1.26 in Nixpkgs while Chromium bundles 1.21): - # Source: https://bugs.chromium.org/p/angleproject/issues/detail?id=7582#c1 - ./patches/angle-wayland-include-protocol.patch - # Chromium reads initial_preferences from its own executable directory - # This patch modifies it to read /etc/chromium/initial_preferences - ./patches/chromium-initial-prefs.patch - # https://github.com/chromium/chromium/commit/02b6456643700771597c00741937e22068b0f956 - # https://github.com/chromium/chromium/commit/69736ffe943ff996d4a88d15eb30103a8c854e29 - # Rebased variant of patch to build M126+ with LLVM 17. - # staging-next will bump LLVM to 18, so we will be able to drop this soon. - ./patches/chromium-126-llvm-17.patch - ] ++ lib.optionals (versionRange "126" "129") [ - # Partial revert of https://github.com/chromium/chromium/commit/3687976b0c6d36cf4157419a24a39f6770098d61 - # allowing us to use our rustc and our clang. - # Rebased variant of patch right above to build M126+ with our rust and our clang. - ./patches/chromium-126-rust.patch - ] ++ lib.optionals (chromiumVersionAtLeast "129") [ - # Rebased variant of patch right above to build M129+ with our rust and our clang. - ./patches/chromium-129-rust.patch - ] ++ lib.optionals (chromiumVersionAtLeast "130" && !ungoogled) [ - # Our rustc.llvmPackages is too old for std::hardware_destructive_interference_size - # and std::hardware_constructive_interference_size. - # So let's revert the change for now and hope that our rustc.llvmPackages and - # nixpkgs-stable catch up sooner than later. - # https://groups.google.com/a/chromium.org/g/cxx/c/cwktrFxxUY4 - # https://chromium-review.googlesource.com/c/chromium/src/+/5767325 - # Note: We exclude the changes made to the partition_allocator (PA), as the revert - # would otherwise not apply because upstream reverted those changes to PA already - # in https://chromium-review.googlesource.com/c/chromium/src/+/5841144 - # Note: ungoogled-chromium already reverts this as part of its patchset. - (githubPatch { - commit = "fc838e8cc887adbe95110045d146b9d5885bf2a9"; - hash = "sha256-NNKzIp6NYdeZaqBLWDW/qNxiDB1VFRz7msjMXuMOrZ8="; - excludes = [ "base/allocator/partition_allocator/src/partition_alloc/*" ]; - revert = true; - }) - ]; - - postPatch = lib.optionalString (!isElectron) '' - ln -s ${./files/gclient_args.gni} build/config/gclient_args.gni - - echo 'LASTCHANGE=${upstream-info.DEPS."src".rev}-refs/tags/${version}@{#0}' > build/util/LASTCHANGE - echo "$SOURCE_DATE_EPOCH" > build/util/LASTCHANGE.committime - - cat << EOF > gpu/config/gpu_lists_version.h - /* Generated by lastchange.py, do not edit.*/ - #ifndef GPU_CONFIG_GPU_LISTS_VERSION_H_ - #define GPU_CONFIG_GPU_LISTS_VERSION_H_ - #define GPU_LISTS_VERSION "${upstream-info.DEPS."src".rev}" - #endif // GPU_CONFIG_GPU_LISTS_VERSION_H_ - EOF - - cat << EOF > skia/ext/skia_commit_hash.h - /* Generated by lastchange.py, do not edit.*/ - #ifndef SKIA_EXT_SKIA_COMMIT_HASH_H_ - #define SKIA_EXT_SKIA_COMMIT_HASH_H_ - #define SKIA_COMMIT_HASH "${upstream-info.DEPS."src/third_party/skia".rev}-" - #endif // SKIA_EXT_SKIA_COMMIT_HASH_H_ - EOF - - echo -n '${upstream-info.DEPS."src/third_party/dawn".rev}' > gpu/webgpu/DAWN_VERSION - - mkdir -p third_party/jdk/current/bin - '' + '' - # Workaround/fix for https://bugs.chromium.org/p/chromium/issues/detail?id=1313361: - substituteInPlace BUILD.gn \ - --replace '"//infra/orchestrator:orchestrator_all",' "" - # Disable build flags that require LLVM 15: - substituteInPlace build/config/compiler/BUILD.gn \ - --replace '"-Xclang",' "" \ - --replace '"-no-opaque-pointers",' "" - # remove unused third-party - for lib in ${toString gnSystemLibraries}; do - if [ -d "third_party/$lib" ]; then - find "third_party/$lib" -type f \ - \! -path "third_party/$lib/chromium/*" \ - \! -path "third_party/$lib/google/*" \ - \! -path "third_party/harfbuzz-ng/utils/hb_scoped.h" \ - \! -regex '.*\.\(gn\|gni\|isolate\)' \ - -delete + patches = + [ + ./patches/cross-compile.patch + # Optional patch to use SOURCE_DATE_EPOCH in compute_build_timestamp.py (should be upstreamed): + ./patches/no-build-timestamps.patch + ] + ++ lib.optionals (packageName == "chromium") [ + # This patch is limited to chromium and ungoogled-chromium because electron-source sets + # enable_widevine to false. + # + # The patch disables the automatic Widevine download (component) that happens at runtime + # completely (~/.config/chromium/WidevineCdm/). This would happen if chromium encounters DRM + # protected content or when manually opening chrome://components. + # + # It also prevents previously downloaded Widevine blobs in that location from being loaded and + # used at all, while still allowing the use of our -wv wrapper. This is because those old + # versions are out of out our control and may be vulnerable, given we literally disable their + # auto updater. + # + # bundle_widevine_cdm is available as gn flag, but we cannot use it, as it expects a bunch of + # files Widevine files at configure/compile phase that we don't have. Changing the value of the + # BUNDLE_WIDEVINE_CDM build flag does work in the way we want though. + # We also need enable_widevine_cdm_component to be false. Unfortunately it isn't exposed as gn + # flag (declare_args) so we simply hardcode it to false. + ./patches/widevine-disable-auto-download-allow-bundle.patch + ] + ++ lib.optionals (versionRange "127" "128") [ + # Fix missing chrome/browser/ui/webui_name_variants.h dependency + # and ninja 1.12 compat in M127. + # https://issues.chromium.org/issues/345645751 + # https://issues.chromium.org/issues/40253918 + # https://chromium-review.googlesource.com/c/chromium/src/+/5641516 + (githubPatch { + commit = "2c101186b60ed50f2ba4feaa2e963bd841bcca47"; + hash = "sha256-luu3ggo6XoeeECld1cKZ6Eh8x/qQYmmKI/ThEhuutuY="; + }) + # https://chromium-review.googlesource.com/c/chromium/src/+/5644627 + (githubPatch { + commit = "f2b43c18b8ecfc3ddc49c42c062d796c8b563984"; + hash = "sha256-uxXxSsiS8R0827Oi3xsG2gtT0X+jJXziwZ1y8+7K+Qg="; + }) + # https://chromium-review.googlesource.com/c/chromium/src/+/5646245 + (githubPatch { + commit = "4ca70656fde83d2db6ed5a8ac9ec9e7443846924"; + hash = "sha256-iQuRRZjDDtJfr+B7MV+TvUDDX3bvpCnv8OpSLJ1WqCE="; + }) + # https://chromium-review.googlesource.com/c/chromium/src/+/5647662 + (githubPatch { + commit = "50d63ffee3f7f1b1b9303363742ad8ebbfec31fa"; + hash = "sha256-H+dv+lgXSdry3NkygpbCdTAWWdTVdKdVD3Aa62w091E="; + }) + ] + ++ [ + # Required to fix the build with a more recent wayland-protocols version + # (we currently package 1.26 in Nixpkgs while Chromium bundles 1.21): + # Source: https://bugs.chromium.org/p/angleproject/issues/detail?id=7582#c1 + ./patches/angle-wayland-include-protocol.patch + # Chromium reads initial_preferences from its own executable directory + # This patch modifies it to read /etc/chromium/initial_preferences + ./patches/chromium-initial-prefs.patch + # https://github.com/chromium/chromium/commit/02b6456643700771597c00741937e22068b0f956 + # https://github.com/chromium/chromium/commit/69736ffe943ff996d4a88d15eb30103a8c854e29 + # Rebased variant of patch to build M126+ with LLVM 17. + # staging-next will bump LLVM to 18, so we will be able to drop this soon. + ./patches/chromium-126-llvm-17.patch + ] + ++ lib.optionals (versionRange "126" "129") [ + # Partial revert of https://github.com/chromium/chromium/commit/3687976b0c6d36cf4157419a24a39f6770098d61 + # allowing us to use our rustc and our clang. + # Rebased variant of patch right above to build M126+ with our rust and our clang. + ./patches/chromium-126-rust.patch + ] + ++ lib.optionals (chromiumVersionAtLeast "129") [ + # Rebased variant of patch right above to build M129+ with our rust and our clang. + ./patches/chromium-129-rust.patch + ] + ++ lib.optionals (chromiumVersionAtLeast "130" && !ungoogled) [ + # Our rustc.llvmPackages is too old for std::hardware_destructive_interference_size + # and std::hardware_constructive_interference_size. + # So let's revert the change for now and hope that our rustc.llvmPackages and + # nixpkgs-stable catch up sooner than later. + # https://groups.google.com/a/chromium.org/g/cxx/c/cwktrFxxUY4 + # https://chromium-review.googlesource.com/c/chromium/src/+/5767325 + # Note: We exclude the changes made to the partition_allocator (PA), as the revert + # would otherwise not apply because upstream reverted those changes to PA already + # in https://chromium-review.googlesource.com/c/chromium/src/+/5841144 + # Note: ungoogled-chromium already reverts this as part of its patchset. + (githubPatch { + commit = "fc838e8cc887adbe95110045d146b9d5885bf2a9"; + hash = "sha256-NNKzIp6NYdeZaqBLWDW/qNxiDB1VFRz7msjMXuMOrZ8="; + excludes = [ "base/allocator/partition_allocator/src/partition_alloc/*" ]; + revert = true; + }) + ]; + + postPatch = + lib.optionalString (!isElectron) '' + ln -s ${./files/gclient_args.gni} build/config/gclient_args.gni + + echo 'LASTCHANGE=${upstream-info.DEPS."src".rev}-refs/tags/${version}@{#0}' > build/util/LASTCHANGE + echo "$SOURCE_DATE_EPOCH" > build/util/LASTCHANGE.committime + + cat << EOF > gpu/config/gpu_lists_version.h + /* Generated by lastchange.py, do not edit.*/ + #ifndef GPU_CONFIG_GPU_LISTS_VERSION_H_ + #define GPU_CONFIG_GPU_LISTS_VERSION_H_ + #define GPU_LISTS_VERSION "${upstream-info.DEPS."src".rev}" + #endif // GPU_CONFIG_GPU_LISTS_VERSION_H_ + EOF + + cat << EOF > skia/ext/skia_commit_hash.h + /* Generated by lastchange.py, do not edit.*/ + #ifndef SKIA_EXT_SKIA_COMMIT_HASH_H_ + #define SKIA_EXT_SKIA_COMMIT_HASH_H_ + #define SKIA_COMMIT_HASH "${upstream-info.DEPS."src/third_party/skia".rev}-" + #endif // SKIA_EXT_SKIA_COMMIT_HASH_H_ + EOF + + echo -n '${upstream-info.DEPS."src/third_party/dawn".rev}' > gpu/webgpu/DAWN_VERSION + + mkdir -p third_party/jdk/current/bin + '' + + '' + # Workaround/fix for https://bugs.chromium.org/p/chromium/issues/detail?id=1313361: + substituteInPlace BUILD.gn \ + --replace '"//infra/orchestrator:orchestrator_all",' "" + # Disable build flags that require LLVM 15: + substituteInPlace build/config/compiler/BUILD.gn \ + --replace '"-Xclang",' "" \ + --replace '"-no-opaque-pointers",' "" + # remove unused third-party + for lib in ${toString gnSystemLibraries}; do + if [ -d "third_party/$lib" ]; then + find "third_party/$lib" -type f \ + \! -path "third_party/$lib/chromium/*" \ + \! -path "third_party/$lib/google/*" \ + \! -path "third_party/harfbuzz-ng/utils/hb_scoped.h" \ + \! -regex '.*\.\(gn\|gni\|isolate\)' \ + -delete + fi + done + + if [[ -e native_client/SConstruct ]]; then + # Required for patchShebangs (unsupported interpreter directive, basename: invalid option -- '*', etc.): + substituteInPlace native_client/SConstruct --replace "#! -*- python -*-" "" + fi + if [ -e third_party/harfbuzz-ng/src/src/update-unicode-tables.make ]; then + substituteInPlace third_party/harfbuzz-ng/src/src/update-unicode-tables.make \ + --replace "/usr/bin/env -S make -f" "/usr/bin/make -f" + fi + if [ -e third_party/webgpu-cts/src/tools/run_deno ]; then + chmod -x third_party/webgpu-cts/src/tools/run_deno + fi + if [ -e third_party/dawn/third_party/webgpu-cts/tools/run_deno ]; then + chmod -x third_party/dawn/third_party/webgpu-cts/tools/run_deno fi - done - if [[ -e native_client/SConstruct ]]; then - # Required for patchShebangs (unsupported interpreter directive, basename: invalid option -- '*', etc.): - substituteInPlace native_client/SConstruct --replace "#! -*- python -*-" "" - fi - if [ -e third_party/harfbuzz-ng/src/src/update-unicode-tables.make ]; then - substituteInPlace third_party/harfbuzz-ng/src/src/update-unicode-tables.make \ - --replace "/usr/bin/env -S make -f" "/usr/bin/make -f" - fi - if [ -e third_party/webgpu-cts/src/tools/run_deno ]; then - chmod -x third_party/webgpu-cts/src/tools/run_deno - fi - if [ -e third_party/dawn/third_party/webgpu-cts/tools/run_deno ]; then - chmod -x third_party/dawn/third_party/webgpu-cts/tools/run_deno - fi - - # We want to be able to specify where the sandbox is via CHROME_DEVEL_SANDBOX - substituteInPlace sandbox/linux/suid/client/setuid_sandbox_host.cc \ - --replace \ - 'return sandbox_binary;' \ - 'return base::FilePath(GetDevelSandboxPath());' - - substituteInPlace services/audio/audio_sandbox_hook_linux.cc \ - --replace \ - '/usr/share/alsa/' \ - '${alsa-lib}/share/alsa/' \ - --replace \ - '/usr/lib/x86_64-linux-gnu/gconv/' \ - '${glibc}/lib/gconv/' \ - --replace \ - '/usr/share/locale/' \ - '${glibc}/share/locale/' - - '' + lib.optionalString systemdSupport '' - sed -i -e '/lib_loader.*Load/s!"\(libudev\.so\)!"${lib.getLib systemd}/lib/\1!' \ - device/udev_linux/udev?_loader.cc - '' + '' - # Allow to put extensions into the system-path. - sed -i -e 's,/usr,/run/current-system/sw,' chrome/common/chrome_paths.cc - - # Add final newlines to scripts that do not end with one. - # This is a temporary workaround until https://github.com/NixOS/nixpkgs/pull/255463 (or similar) has been merged, - # as patchShebangs hard-crashes when it encounters files that contain only a shebang and do not end with a final - # newline. - find . -type f -perm -0100 -exec sed -i -e '$a\' {} + - - patchShebangs . - '' + lib.optionalString (ungoogled) '' - # Prune binaries (ungoogled only) *before* linking our own binaries: - ${ungoogler}/utils/prune_binaries.py . ${ungoogler}/pruning.list || echo "some errors" - '' + '' - # Link to our own Node.js and Java (required during the build): - mkdir -p third_party/node/linux/node-linux-x64/bin - ln -s${lib.optionalString (chromiumVersionAtLeast "127") "f"} "${pkgsBuildHost.nodejs}/bin/node" third_party/node/linux/node-linux-x64/bin/node - ln -s "${pkgsBuildHost.jdk17_headless}/bin/java" third_party/jdk/current/bin/ - - # Allow building against system libraries in official builds - sed -i 's/OFFICIAL_BUILD/GOOGLE_CHROME_BUILD/' tools/generate_shim_headers/generate_shim_headers.py - - '' + lib.optionalString (stdenv.hostPlatform == stdenv.buildPlatform && stdenv.hostPlatform.isAarch64) '' - substituteInPlace build/toolchain/linux/BUILD.gn \ - --replace 'toolprefix = "aarch64-linux-gnu-"' 'toolprefix = ""' - '' + lib.optionalString ungoogled '' - ${ungoogler}/utils/patches.py . ${ungoogler}/patches - ${ungoogler}/utils/domain_substitution.py apply -r ${ungoogler}/domain_regex.list -f ${ungoogler}/domain_substitution.list -c ./ungoogled-domsubcache.tar.gz . - ''; + # We want to be able to specify where the sandbox is via CHROME_DEVEL_SANDBOX + substituteInPlace sandbox/linux/suid/client/setuid_sandbox_host.cc \ + --replace \ + 'return sandbox_binary;' \ + 'return base::FilePath(GetDevelSandboxPath());' + + substituteInPlace services/audio/audio_sandbox_hook_linux.cc \ + --replace \ + '/usr/share/alsa/' \ + '${alsa-lib}/share/alsa/' \ + --replace \ + '/usr/lib/x86_64-linux-gnu/gconv/' \ + '${glibc}/lib/gconv/' \ + --replace \ + '/usr/share/locale/' \ + '${glibc}/share/locale/' + + '' + + lib.optionalString systemdSupport '' + sed -i -e '/lib_loader.*Load/s!"\(libudev\.so\)!"${lib.getLib systemd}/lib/\1!' \ + device/udev_linux/udev?_loader.cc + '' + + '' + # Allow to put extensions into the system-path. + sed -i -e 's,/usr,/run/current-system/sw,' chrome/common/chrome_paths.cc + + # Add final newlines to scripts that do not end with one. + # This is a temporary workaround until https://github.com/NixOS/nixpkgs/pull/255463 (or similar) has been merged, + # as patchShebangs hard-crashes when it encounters files that contain only a shebang and do not end with a final + # newline. + find . -type f -perm -0100 -exec sed -i -e '$a\' {} + + + patchShebangs . + '' + + lib.optionalString (ungoogled) '' + # Prune binaries (ungoogled only) *before* linking our own binaries: + ${ungoogler}/utils/prune_binaries.py . ${ungoogler}/pruning.list || echo "some errors" + '' + + '' + # Link to our own Node.js and Java (required during the build): + mkdir -p third_party/node/linux/node-linux-x64/bin + ln -s${lib.optionalString (chromiumVersionAtLeast "127") "f"} "${pkgsBuildHost.nodejs}/bin/node" third_party/node/linux/node-linux-x64/bin/node + ln -s "${pkgsBuildHost.jdk17_headless}/bin/java" third_party/jdk/current/bin/ + + # Allow building against system libraries in official builds + sed -i 's/OFFICIAL_BUILD/GOOGLE_CHROME_BUILD/' tools/generate_shim_headers/generate_shim_headers.py + + '' + + + lib.optionalString (stdenv.hostPlatform == stdenv.buildPlatform && stdenv.hostPlatform.isAarch64) + '' + substituteInPlace build/toolchain/linux/BUILD.gn \ + --replace 'toolprefix = "aarch64-linux-gnu-"' 'toolprefix = ""' + '' + + lib.optionalString ungoogled '' + ${ungoogler}/utils/patches.py . ${ungoogler}/patches + ${ungoogler}/utils/domain_substitution.py apply -r ${ungoogler}/domain_regex.list -f ${ungoogler}/domain_substitution.list -c ./ungoogled-domsubcache.tar.gz . + ''; llvmCcAndBintools = symlinkJoin { name = "llvmCcAndBintools"; @@ -495,114 +653,128 @@ let ]; }; - gnFlags = mkGnFlags ({ - # Main build and toolchain settings: - # Create an official and optimized release build (only official builds - # should be distributed to users, as non-official builds are intended for - # development and may not be configured appropriately for production, - # e.g. unsafe developer builds have developer-friendly features that may - # weaken or disable security measures like sandboxing or ASLR): - is_official_build = true; - disable_fieldtrial_testing_config = true; - - # note: chromium calls buildPlatform "host" and calls hostPlatform "target" - host_cpu = chromiumRosettaStone.cpu stdenv.buildPlatform; - host_os = chromiumRosettaStone.os stdenv.buildPlatform; - target_cpu = chromiumRosettaStone.cpu stdenv.hostPlatform; - v8_target_cpu = chromiumRosettaStone.cpu stdenv.hostPlatform; - target_os = chromiumRosettaStone.os stdenv.hostPlatform; - - # Build Chromium using the system toolchain (for Linux distributions): - # - # What you would expect to be caled "target_toolchain" is - # actually called either "default_toolchain" or "custom_toolchain", - # depending on which part of the codebase you are in; see: - # https://github.com/chromium/chromium/blob/d36462cc9279464395aea5e65d0893d76444a296/build/config/BUILDCONFIG.gn#L17-L44 - custom_toolchain = "//build/toolchain/linux/unbundle:default"; - host_toolchain = "//build/toolchain/linux/unbundle:default"; - # We only build those specific toolchains when we cross-compile, as native non-cross-compilations would otherwise - # end up building much more things than they need to (roughtly double the build steps and time/compute): - } // lib.optionalAttrs (stdenv.buildPlatform != stdenv.hostPlatform) { - host_toolchain = "//build/toolchain/linux/unbundle:host"; - v8_snapshot_toolchain = "//build/toolchain/linux/unbundle:host"; - } // { - host_pkg_config = "${pkgsBuildBuild.pkg-config}/bin/pkg-config"; - pkg_config = "${pkgsBuildHost.pkg-config}/bin/${stdenv.cc.targetPrefix}pkg-config"; - - # Don't build against a sysroot image downloaded from Cloud Storage: - use_sysroot = false; - # Because we use a different toolchain / compiler version: - treat_warnings_as_errors = false; - # We aren't compiling with Chrome's Clang (would enable Chrome-specific - # plugins for enforcing coding guidelines, etc.): - clang_use_chrome_plugins = false; - # Disable symbols (they would negatively affect the performance of the - # build since the symbols are large and dealing with them is slow): - symbol_level = 0; - blink_symbol_level = 0; - - # Google API key, see: https://www.chromium.org/developers/how-tos/api-keys - # Note: The API key is for NixOS/nixpkgs use ONLY. - # For your own distribution, please get your own set of keys. - google_api_key = "AIzaSyDGi15Zwl11UNe6Y-5XW_upsfyw31qwZPI"; - - # Optional features: - use_gio = true; - use_cups = cupsSupport; - - # Feature overrides: - # Native Client support was deprecated in 2020 and support will end in June 2021: - enable_nacl = false; - } // lib.optionalAttrs (packageName == "chromium") { - # Enabling the Widevine here doesn't affect whether we can redistribute the chromium package. - # Widevine in this drv is a bit more complex than just that. See Widevine patch somewhere above. - enable_widevine = true; - } // { - # Provides the enable-webrtc-pipewire-capturer flag to support Wayland screen capture: - rtc_use_pipewire = true; - # Disable PGO because the profile data requires a newer compiler version (LLVM 14 isn't sufficient): - chrome_pgo_phase = 0; - clang_base_path = "${llvmCcAndBintools}"; - use_qt = false; - # To fix the build as we don't provide libffi_pic.a - # (ld.lld: error: unable to find library -l:libffi_pic.a): - use_system_libffi = true; - # Use nixpkgs Rust compiler instead of the one shipped by Chromium. - rust_sysroot_absolute = "${buildPackages.rustc}"; - } // lib.optionalAttrs (chromiumVersionAtLeast "127") { - rust_bindgen_root = "${buildPackages.rust-bindgen}"; - } // { - enable_rust = true; - # While we technically don't need the cache-invalidation rustc_version provides, rustc_version - # is still used in some scripts (e.g. build/rust/std/find_std_rlibs.py). - rustc_version = buildPackages.rustc.version; - } // lib.optionalAttrs (!(stdenv.buildPlatform.canExecute stdenv.hostPlatform)) { - # https://www.mail-archive.com/v8-users@googlegroups.com/msg14528.html - arm_control_flow_integrity = "none"; - } // lib.optionalAttrs proprietaryCodecs { - # enable support for the H.264 codec - proprietary_codecs = true; - enable_hangout_services_extension = true; - ffmpeg_branding = "Chrome"; - } // lib.optionalAttrs pulseSupport { - use_pulseaudio = true; - link_pulseaudio = true; - } // lib.optionalAttrs ungoogled (lib.importTOML ./ungoogled-flags.toml) - // (extraAttrs.gnFlags or {})); + gnFlags = mkGnFlags ( + { + # Main build and toolchain settings: + # Create an official and optimized release build (only official builds + # should be distributed to users, as non-official builds are intended for + # development and may not be configured appropriately for production, + # e.g. unsafe developer builds have developer-friendly features that may + # weaken or disable security measures like sandboxing or ASLR): + is_official_build = true; + disable_fieldtrial_testing_config = true; + + # note: chromium calls buildPlatform "host" and calls hostPlatform "target" + host_cpu = chromiumRosettaStone.cpu stdenv.buildPlatform; + host_os = chromiumRosettaStone.os stdenv.buildPlatform; + target_cpu = chromiumRosettaStone.cpu stdenv.hostPlatform; + v8_target_cpu = chromiumRosettaStone.cpu stdenv.hostPlatform; + target_os = chromiumRosettaStone.os stdenv.hostPlatform; + + # Build Chromium using the system toolchain (for Linux distributions): + # + # What you would expect to be caled "target_toolchain" is + # actually called either "default_toolchain" or "custom_toolchain", + # depending on which part of the codebase you are in; see: + # https://github.com/chromium/chromium/blob/d36462cc9279464395aea5e65d0893d76444a296/build/config/BUILDCONFIG.gn#L17-L44 + custom_toolchain = "//build/toolchain/linux/unbundle:default"; + host_toolchain = "//build/toolchain/linux/unbundle:default"; + # We only build those specific toolchains when we cross-compile, as native non-cross-compilations would otherwise + # end up building much more things than they need to (roughtly double the build steps and time/compute): + } + // lib.optionalAttrs (stdenv.buildPlatform != stdenv.hostPlatform) { + host_toolchain = "//build/toolchain/linux/unbundle:host"; + v8_snapshot_toolchain = "//build/toolchain/linux/unbundle:host"; + } + // { + host_pkg_config = "${pkgsBuildBuild.pkg-config}/bin/pkg-config"; + pkg_config = "${pkgsBuildHost.pkg-config}/bin/${stdenv.cc.targetPrefix}pkg-config"; + + # Don't build against a sysroot image downloaded from Cloud Storage: + use_sysroot = false; + # Because we use a different toolchain / compiler version: + treat_warnings_as_errors = false; + # We aren't compiling with Chrome's Clang (would enable Chrome-specific + # plugins for enforcing coding guidelines, etc.): + clang_use_chrome_plugins = false; + # Disable symbols (they would negatively affect the performance of the + # build since the symbols are large and dealing with them is slow): + symbol_level = 0; + blink_symbol_level = 0; + + # Google API key, see: https://www.chromium.org/developers/how-tos/api-keys + # Note: The API key is for NixOS/nixpkgs use ONLY. + # For your own distribution, please get your own set of keys. + google_api_key = "AIzaSyDGi15Zwl11UNe6Y-5XW_upsfyw31qwZPI"; + + # Optional features: + use_gio = true; + use_cups = cupsSupport; + + # Feature overrides: + # Native Client support was deprecated in 2020 and support will end in June 2021: + enable_nacl = false; + } + // lib.optionalAttrs (packageName == "chromium") { + # Enabling the Widevine here doesn't affect whether we can redistribute the chromium package. + # Widevine in this drv is a bit more complex than just that. See Widevine patch somewhere above. + enable_widevine = true; + } + // { + # Provides the enable-webrtc-pipewire-capturer flag to support Wayland screen capture: + rtc_use_pipewire = true; + # Disable PGO because the profile data requires a newer compiler version (LLVM 14 isn't sufficient): + chrome_pgo_phase = 0; + clang_base_path = "${llvmCcAndBintools}"; + use_qt = false; + # To fix the build as we don't provide libffi_pic.a + # (ld.lld: error: unable to find library -l:libffi_pic.a): + use_system_libffi = true; + # Use nixpkgs Rust compiler instead of the one shipped by Chromium. + rust_sysroot_absolute = "${buildPackages.rustc}"; + } + // lib.optionalAttrs (chromiumVersionAtLeast "127") { + rust_bindgen_root = "${buildPackages.rust-bindgen}"; + } + // { + enable_rust = true; + # While we technically don't need the cache-invalidation rustc_version provides, rustc_version + # is still used in some scripts (e.g. build/rust/std/find_std_rlibs.py). + rustc_version = buildPackages.rustc.version; + } + // lib.optionalAttrs (!(stdenv.buildPlatform.canExecute stdenv.hostPlatform)) { + # https://www.mail-archive.com/v8-users@googlegroups.com/msg14528.html + arm_control_flow_integrity = "none"; + } + // lib.optionalAttrs proprietaryCodecs { + # enable support for the H.264 codec + proprietary_codecs = true; + enable_hangout_services_extension = true; + ffmpeg_branding = "Chrome"; + } + // lib.optionalAttrs pulseSupport { + use_pulseaudio = true; + link_pulseaudio = true; + } + // lib.optionalAttrs ungoogled (lib.importTOML ./ungoogled-flags.toml) + // (extraAttrs.gnFlags or { }) + ); # TODO: Migrate this to env.RUSTC_BOOTSTRAP next mass-rebuild. # Chromium expects nightly/bleeding edge rustc features to be available. # Our rustc in nixpkgs follows stable, but since bootstrapping rustc requires # nightly features too, we can (ab-)use RUSTC_BOOTSTRAP here as well to # enable those features in our stable builds. - preConfigure = '' - export RUSTC_BOOTSTRAP=1 - '' + lib.optionalString (!isElectron) '' - ( - cd third_party/node - grep patch update_npm_deps | sh - ) - ''; + preConfigure = + '' + export RUSTC_BOOTSTRAP=1 + '' + + lib.optionalString (!isElectron) '' + ( + cd third_party/node + grep patch update_npm_deps | sh + ) + ''; configurePhase = '' runHook preConfigure @@ -628,29 +800,37 @@ let env.BUILD_NM = "$NM_FOR_BUILD"; env.BUILD_READELF = "$READELF_FOR_BUILD"; - buildPhase = let - buildCommand = target: '' - TERM=dumb ninja -C "${buildPath}" -j$NIX_BUILD_CORES "${target}" - ( - source chrome/installer/linux/common/installer.include - PACKAGE=$packageName - MENUNAME="Chromium" - process_template chrome/app/resources/manpage.1.in "${buildPath}/chrome.1" - ) + buildPhase = + let + buildCommand = target: '' + TERM=dumb ninja -C "${buildPath}" -j$NIX_BUILD_CORES "${target}" + ( + source chrome/installer/linux/common/installer.include + PACKAGE=$packageName + MENUNAME="Chromium" + process_template chrome/app/resources/manpage.1.in "${buildPath}/chrome.1" + ) + ''; + targets = extraAttrs.buildTargets or [ ]; + commands = map buildCommand targets; + in + '' + runHook preBuild + ${lib.concatStringsSep "\n" commands} + runHook postBuild ''; - targets = extraAttrs.buildTargets or []; - commands = map buildCommand targets; - in '' - runHook preBuild - ${lib.concatStringsSep "\n" commands} - runHook postBuild - ''; postFixup = '' # Make sure that libGLESv2 and libvulkan are found by dlopen in both chromium binary and ANGLE libGLESv2.so. # libpci (from pciutils) is needed by dlopen in angle/src/gpu_info_util/SystemInfo_libpci.cpp for chromiumBinary in "$libExecPath/$packageName" "$libExecPath/libGLESv2.so"; do - patchelf --set-rpath "${lib.makeLibraryPath [ libGL vulkan-loader pciutils ]}:$(patchelf --print-rpath "$chromiumBinary")" "$chromiumBinary" + patchelf --set-rpath "${ + lib.makeLibraryPath [ + libGL + vulkan-loader + pciutils + ] + }:$(patchelf --print-rpath "$chromiumBinary")" "$chromiumBinary" done # replace bundled vulkan-loader @@ -658,14 +838,25 @@ let ln -s -t "$libExecPath" "${lib.getLib vulkan-loader}/lib/libvulkan.so.1" ''; - passthru = { - updateScript = ./update.mjs; - } // lib.optionalAttrs (!isElectron) { - inherit chromiumDeps npmDeps; - }; + passthru = + { + updateScript = ./update.mjs; + } + // lib.optionalAttrs (!isElectron) { + inherit chromiumDeps npmDeps; + }; }; +in # Remove some extraAttrs we supplied to the base attributes already. -in stdenv.mkDerivation (base // removeAttrs extraAttrs [ - "name" "gnFlags" "buildTargets" -] // { passthru = base.passthru // (extraAttrs.passthru or {}); }) +stdenv.mkDerivation ( + base + // removeAttrs extraAttrs [ + "name" + "gnFlags" + "buildTargets" + ] + // { + passthru = base.passthru // (extraAttrs.passthru or { }); + } +) diff --git a/pkgs/applications/networking/browsers/chromium/default.nix b/pkgs/applications/networking/browsers/chromium/default.nix index 296c3502128064..884399fd6b7483 100644 --- a/pkgs/applications/networking/browsers/chromium/default.nix +++ b/pkgs/applications/networking/browsers/chromium/default.nix @@ -1,43 +1,68 @@ -{ newScope, config, stdenv, makeWrapper -, buildPackages -, ed, gnugrep, coreutils, xdg-utils -, glib, gtk3, gtk4, adwaita-icon-theme, gsettings-desktop-schemas, gn, fetchgit -, libva, pipewire, wayland -, runCommand -, lib, libkrb5 -, widevine-cdm -, electron-source # for warnObsoleteVersionConditional - -# package customization -# Note: enable* flags should not require full rebuilds (i.e. only affect the wrapper) -, upstream-info ? (lib.importJSON ./info.json).${if !ungoogled then "chromium" else "ungoogled-chromium"} -, proprietaryCodecs ? true -, enableWideVine ? false -, ungoogled ? false # Whether to build chromium or ungoogled-chromium -, cupsSupport ? true -, pulseSupport ? config.pulseaudio or stdenv.hostPlatform.isLinux -, commandLineArgs ? "" -, pkgsBuildBuild -, pkgs +{ + newScope, + config, + stdenv, + makeWrapper, + buildPackages, + ed, + gnugrep, + coreutils, + xdg-utils, + glib, + gtk3, + gtk4, + adwaita-icon-theme, + gsettings-desktop-schemas, + gn, + fetchgit, + libva, + pipewire, + wayland, + runCommand, + lib, + libkrb5, + widevine-cdm, + electron-source, # for warnObsoleteVersionConditional + + # package customization + # Note: enable* flags should not require full rebuilds (i.e. only affect the wrapper) + upstream-info ? + (lib.importJSON ./info.json).${if !ungoogled then "chromium" else "ungoogled-chromium"}, + proprietaryCodecs ? true, + enableWideVine ? false, + ungoogled ? false, # Whether to build chromium or ungoogled-chromium + cupsSupport ? true, + pulseSupport ? config.pulseaudio or stdenv.hostPlatform.isLinux, + commandLineArgs ? "", + pkgsBuildBuild, + pkgs, }: let stdenv = pkgs.rustc.llvmPackages.stdenv; # Helper functions for changes that depend on specific versions: - warnObsoleteVersionConditional = min-version: result: - let min-supported-version = (lib.head (lib.attrValues electron-source)).unwrapped.info.chromium.version; - in lib.warnIf - (lib.versionAtLeast min-supported-version min-version) - "chromium: min-supported-version ${min-supported-version} is newer than a conditional bounded at ${min-version}. You can safely delete it." - result; - chromiumVersionAtLeast = min-version: - let result = lib.versionAtLeast upstream-info.version min-version; - in warnObsoleteVersionConditional min-version result; - versionRange = min-version: upto-version: - let inherit (upstream-info) version; - result = lib.versionAtLeast version min-version && lib.versionOlder version upto-version; - in warnObsoleteVersionConditional upto-version result; + warnObsoleteVersionConditional = + min-version: result: + let + min-supported-version = (lib.head (lib.attrValues electron-source)).unwrapped.info.chromium.version; + in + lib.warnIf (lib.versionAtLeast min-supported-version min-version) + "chromium: min-supported-version ${min-supported-version} is newer than a conditional bounded at ${min-version}. You can safely delete it." + result; + chromiumVersionAtLeast = + min-version: + let + result = lib.versionAtLeast upstream-info.version min-version; + in + warnObsoleteVersionConditional min-version result; + versionRange = + min-version: upto-version: + let + inherit (upstream-info) version; + result = lib.versionAtLeast version min-version && lib.versionOlder version upto-version; + in + warnObsoleteVersionConditional upto-version result; callPackage = newScope chromium; @@ -46,25 +71,34 @@ let mkChromiumDerivation = callPackage ./common.nix ({ inherit chromiumVersionAtLeast versionRange; - inherit proprietaryCodecs - cupsSupport pulseSupport ungoogled; - gnChromium = buildPackages.gn.overrideAttrs (oldAttrs: { - version = if (upstream-info.deps.gn ? "version") then upstream-info.deps.gn.version else "0"; - src = fetchgit { - url = "https://gn.googlesource.com/gn"; - inherit (upstream-info.deps.gn) rev hash; - }; - } // lib.optionalAttrs (chromiumVersionAtLeast "127") { - # Relax hardening as otherwise gn unstable 2024-06-06 and later fail with: - # cc1plus: error: '-Wformat-security' ignored without '-Wformat' [-Werror=format-security] - hardeningDisable = [ "format" ]; - } // lib.optionalAttrs (chromiumVersionAtLeast "130") { - # At the time of writing, gn is at v2024-05-13 and has a backported patch. - # This patch appears to be already present in v2024-09-09 (from M130), which - # results in the patch not applying and thus failing the build. - # As a work around until gn is updated again, we filter specifically that patch out. - patches = lib.filter (e: lib.getName e != "LFS64.patch") oldAttrs.patches; - }); + inherit + proprietaryCodecs + cupsSupport + pulseSupport + ungoogled + ; + gnChromium = buildPackages.gn.overrideAttrs ( + oldAttrs: + { + version = if (upstream-info.deps.gn ? "version") then upstream-info.deps.gn.version else "0"; + src = fetchgit { + url = "https://gn.googlesource.com/gn"; + inherit (upstream-info.deps.gn) rev hash; + }; + } + // lib.optionalAttrs (chromiumVersionAtLeast "127") { + # Relax hardening as otherwise gn unstable 2024-06-06 and later fail with: + # cc1plus: error: '-Wformat-security' ignored without '-Wformat' [-Werror=format-security] + hardeningDisable = [ "format" ]; + } + // lib.optionalAttrs (chromiumVersionAtLeast "130") { + # At the time of writing, gn is at v2024-05-13 and has a backported patch. + # This patch appears to be already present in v2024-09-09 (from M130), which + # results in the patch not applying and thus failing the build. + # As a work around until gn is updated again, we filter specifically that patch out. + patches = lib.filter (e: lib.getName e != "LFS64.patch") oldAttrs.patches; + } + ); }); browser = callPackage ./browser.nix { @@ -76,7 +110,7 @@ let # Therefore, it needs to come from buildPackages, because it # contains python scripts which get /nix/store/.../bin/python3 # patched into their shebangs. - ungoogled-chromium = pkgsBuildBuild.callPackage ./ungoogled.nix {}; + ungoogled-chromium = pkgsBuildBuild.callPackage ./ungoogled.nix { }; }; sandboxExecutableName = chromium.browser.passthru.sandboxExecutableName; @@ -84,28 +118,36 @@ let # We want users to be able to enableWideVine without rebuilding all of # chromium, so we have a separate derivation here that copies chromium # and adds the unfree WidevineCdm. - chromiumWV = let browser = chromium.browser; in if enableWideVine then - runCommand (browser.name + "-wv") { version = browser.version; } - '' + chromiumWV = + let + browser = chromium.browser; + in + if enableWideVine then + runCommand (browser.name + "-wv") { version = browser.version; } '' mkdir -p $out cp -a ${browser}/* $out/ chmod u+w $out/libexec/chromium cp -a ${widevine-cdm}/share/google/chrome/WidevineCdm $out/libexec/chromium/ '' - else browser; + else + browser; -in stdenv.mkDerivation { - pname = lib.optionalString ungoogled "ungoogled-" - + "chromium"; +in +stdenv.mkDerivation { + pname = lib.optionalString ungoogled "ungoogled-" + "chromium"; inherit (chromium.browser) version; nativeBuildInputs = [ - makeWrapper ed + makeWrapper + ed ]; buildInputs = [ # needed for GSETTINGS_SCHEMAS_PATH - gsettings-desktop-schemas glib gtk3 gtk4 + gsettings-desktop-schemas + glib + gtk3 + gtk4 # needed for XDG_ICON_DIRS adwaita-icon-theme @@ -114,61 +156,77 @@ in stdenv.mkDerivation { libkrb5 ]; - outputs = ["out" "sandbox"]; - - buildCommand = let - browserBinary = "${chromiumWV}/libexec/chromium/chromium"; - libPath = lib.makeLibraryPath [ libva pipewire wayland gtk3 gtk4 libkrb5 ]; - - in '' - mkdir -p "$out/bin" - - makeWrapper "${browserBinary}" "$out/bin/chromium" \ - --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" \ - --add-flags ${lib.escapeShellArg commandLineArgs} - - ed -v -s "$out/bin/chromium" << EOF - 2i - - if [ -x "/run/wrappers/bin/${sandboxExecutableName}" ] - then - export CHROME_DEVEL_SANDBOX="/run/wrappers/bin/${sandboxExecutableName}" - else - export CHROME_DEVEL_SANDBOX="$sandbox/bin/${sandboxExecutableName}" - fi - - # Make generated desktop shortcuts have a valid executable name. - export CHROME_WRAPPER='chromium' - - '' + lib.optionalString (libPath != "") '' - # To avoid loading .so files from cwd, LD_LIBRARY_PATH here must not - # contain an empty section before or after a colon. - export LD_LIBRARY_PATH="\$LD_LIBRARY_PATH\''${LD_LIBRARY_PATH:+:}${libPath}" - '' + '' - - # libredirect causes chromium to deadlock on startup - export LD_PRELOAD="\$(echo -n "\$LD_PRELOAD" | ${coreutils}/bin/tr ':' '\n' | ${gnugrep}/bin/grep -v /lib/libredirect\\\\.so$ | ${coreutils}/bin/tr '\n' ':')" - - export XDG_DATA_DIRS=$XDG_ICON_DIRS:$GSETTINGS_SCHEMAS_PATH\''${XDG_DATA_DIRS:+:}\$XDG_DATA_DIRS - - '' + lib.optionalString (!xdg-utils.meta.broken) '' - # Mainly for xdg-open but also other xdg-* tools (this is only a fallback; \$PATH is suffixed so that other implementations can be used): - export PATH="\$PATH\''${PATH:+:}${xdg-utils}/bin" - '' + '' - - . - w - EOF - - ln -sv "${chromium.browser.sandbox}" "$sandbox" - - ln -s "$out/bin/chromium" "$out/bin/chromium-browser" + outputs = [ + "out" + "sandbox" + ]; - mkdir -p "$out/share" - for f in '${chromium.browser}'/share/*; do # hello emacs */ - ln -s -t "$out/share/" "$f" - done - ''; + buildCommand = + let + browserBinary = "${chromiumWV}/libexec/chromium/chromium"; + libPath = lib.makeLibraryPath [ + libva + pipewire + wayland + gtk3 + gtk4 + libkrb5 + ]; + + in + '' + mkdir -p "$out/bin" + + makeWrapper "${browserBinary}" "$out/bin/chromium" \ + --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" \ + --add-flags ${lib.escapeShellArg commandLineArgs} + + ed -v -s "$out/bin/chromium" << EOF + 2i + + if [ -x "/run/wrappers/bin/${sandboxExecutableName}" ] + then + export CHROME_DEVEL_SANDBOX="/run/wrappers/bin/${sandboxExecutableName}" + else + export CHROME_DEVEL_SANDBOX="$sandbox/bin/${sandboxExecutableName}" + fi + + # Make generated desktop shortcuts have a valid executable name. + export CHROME_WRAPPER='chromium' + + '' + + lib.optionalString (libPath != "") '' + # To avoid loading .so files from cwd, LD_LIBRARY_PATH here must not + # contain an empty section before or after a colon. + export LD_LIBRARY_PATH="\$LD_LIBRARY_PATH\''${LD_LIBRARY_PATH:+:}${libPath}" + '' + + '' + + # libredirect causes chromium to deadlock on startup + export LD_PRELOAD="\$(echo -n "\$LD_PRELOAD" | ${coreutils}/bin/tr ':' '\n' | ${gnugrep}/bin/grep -v /lib/libredirect\\\\.so$ | ${coreutils}/bin/tr '\n' ':')" + + export XDG_DATA_DIRS=$XDG_ICON_DIRS:$GSETTINGS_SCHEMAS_PATH\''${XDG_DATA_DIRS:+:}\$XDG_DATA_DIRS + + '' + + lib.optionalString (!xdg-utils.meta.broken) '' + # Mainly for xdg-open but also other xdg-* tools (this is only a fallback; \$PATH is suffixed so that other implementations can be used): + export PATH="\$PATH\''${PATH:+:}${xdg-utils}/bin" + '' + + '' + + . + w + EOF + + ln -sv "${chromium.browser.sandbox}" "$sandbox" + + ln -s "$out/bin/chromium" "$out/bin/chromium-browser" + + mkdir -p "$out/share" + for f in '${chromium.browser}'/share/*; do # hello emacs */ + ln -s -t "$out/share/" "$f" + done + ''; inherit (chromium.browser) packageName; meta = chromium.browser.meta; diff --git a/pkgs/applications/networking/browsers/chromium/ungoogled.nix b/pkgs/applications/networking/browsers/chromium/ungoogled.nix index cf3d0a7d73ad2a..d4895b848544c9 100644 --- a/pkgs/applications/networking/browsers/chromium/ungoogled.nix +++ b/pkgs/applications/networking/browsers/chromium/ungoogled.nix @@ -1,12 +1,14 @@ -{ stdenv -, fetchFromGitHub -, python3Packages -, makeWrapper -, patch +{ + stdenv, + fetchFromGitHub, + python3Packages, + makeWrapper, + patch, }: -{ rev -, hash +{ + rev, + hash, }: stdenv.mkDerivation { diff --git a/pkgs/applications/networking/browsers/elinks/default.nix b/pkgs/applications/networking/browsers/elinks/default.nix index 25a4368e822125..5dbc82b991bb64 100644 --- a/pkgs/applications/networking/browsers/elinks/default.nix +++ b/pkgs/applications/networking/browsers/elinks/default.nix @@ -1,10 +1,30 @@ -{ lib, stdenv, fetchFromGitHub, ncurses, libX11, bzip2, zlib -, brotli, zstd, xz, openssl, autoreconfHook, gettext, pkg-config, libev -, gpm, libidn, tre, expat -, # Incompatible licenses, LGPLv3 - GPLv2 - enableGuile ? false, guile ? null -, enablePython ? false, python ? null -, enablePerl ? (!stdenv.hostPlatform.isDarwin) && (stdenv.hostPlatform == stdenv.buildPlatform), perl ? null +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + libX11, + bzip2, + zlib, + brotli, + zstd, + xz, + openssl, + autoreconfHook, + gettext, + pkg-config, + libev, + gpm, + libidn, + tre, + expat, + # Incompatible licenses, LGPLv3 - GPLv2 + enableGuile ? false, + guile ? null, + enablePython ? false, + python ? null, + enablePerl ? (!stdenv.hostPlatform.isDarwin) && (stdenv.hostPlatform == stdenv.buildPlatform), + perl ? null, # re-add javascript support when upstream supports modern spidermonkey }: @@ -22,36 +42,51 @@ stdenv.mkDerivation rec { hash = "sha256-d5bc6SZ8UQuvVJZjWziy4pi/iIiDAnpU9YTlrlfkdoo="; }; - buildInputs = [ - ncurses libX11 bzip2 zlib brotli zstd xz - openssl libidn tre expat libev - ] + buildInputs = + [ + ncurses + libX11 + bzip2 + zlib + brotli + zstd + xz + openssl + libidn + tre + expat + libev + ] ++ lib.optional stdenv.hostPlatform.isLinux gpm ++ lib.optional enableGuile guile ++ lib.optional enablePython python - ++ lib.optional enablePerl perl - ; + ++ lib.optional enablePerl perl; - nativeBuildInputs = [ autoreconfHook gettext pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + gettext + pkg-config + ]; - configureFlags = [ - "--enable-finger" - "--enable-html-highlight" - "--enable-gopher" - "--enable-gemini" - "--enable-cgi" - "--enable-bittorrent" - "--enable-nntp" - "--enable-256-colors" - "--enable-true-color" - "--with-brotli" - "--with-lzma" - "--with-libev" - "--with-terminfo" - ] ++ lib.optional enableGuile "--with-guile" - ++ lib.optional enablePython "--with-python" - ++ lib.optional enablePerl "--with-perl" - ; + configureFlags = + [ + "--enable-finger" + "--enable-html-highlight" + "--enable-gopher" + "--enable-gemini" + "--enable-cgi" + "--enable-bittorrent" + "--enable-nntp" + "--enable-256-colors" + "--enable-true-color" + "--with-brotli" + "--with-lzma" + "--with-libev" + "--with-terminfo" + ] + ++ lib.optional enableGuile "--with-guile" + ++ lib.optional enablePython "--with-python" + ++ lib.optional enablePerl "--with-perl"; meta = with lib; { description = "Full-featured text-mode web browser"; @@ -59,6 +94,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/rkd77/elinks"; license = licenses.gpl2; platforms = with platforms; linux ++ darwin; - maintainers = with maintainers; [ iblech gebner ]; + maintainers = with maintainers; [ + iblech + gebner + ]; }; } diff --git a/pkgs/applications/networking/browsers/firefox-bin/developer-edition_sources.nix b/pkgs/applications/networking/browsers/firefox-bin/developer-edition_sources.nix index 156ab2725eaa8e..6e214e3e215903 100644 --- a/pkgs/applications/networking/browsers/firefox-bin/developer-edition_sources.nix +++ b/pkgs/applications/networking/browsers/firefox-bin/developer-edition_sources.nix @@ -1,1035 +1,1241 @@ { version = "133.0b1"; sources = [ - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ach/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ach/firefox-133.0b1.tar.bz2"; locale = "ach"; arch = "linux-x86_64"; sha256 = "5c42ebef65493ca583a7f00d22bc1b7f62cc9bd91ae96c08dbd74d7126df38ad"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/af/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/af/firefox-133.0b1.tar.bz2"; locale = "af"; arch = "linux-x86_64"; sha256 = "6d1ff31eaf8fe786b9de349314175a1b542b7fbed9510d30795cd7898260580d"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/an/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/an/firefox-133.0b1.tar.bz2"; locale = "an"; arch = "linux-x86_64"; sha256 = "9e4aee3ae27ce32ef25865d23dd00e62c627e4e1cea5cc71a456aa514b41f8fe"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ar/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ar/firefox-133.0b1.tar.bz2"; locale = "ar"; arch = "linux-x86_64"; sha256 = "173b9c75fa988e17f85ebaedc81d7f01a47e1cebe9b5705c21b6ebd9b68f870c"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ast/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ast/firefox-133.0b1.tar.bz2"; locale = "ast"; arch = "linux-x86_64"; sha256 = "82322cc9db2fb89267b28b869cc1d3abd9a99f53967bd588e1debd8c7c3d2a44"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/az/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/az/firefox-133.0b1.tar.bz2"; locale = "az"; arch = "linux-x86_64"; sha256 = "8eded83bc34d39495ae67333f96efc00e71d3152d842ea8b70ad09303b479af9"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/be/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/be/firefox-133.0b1.tar.bz2"; locale = "be"; arch = "linux-x86_64"; sha256 = "240be57831e1981cbb6fb803e7c269d3e4f880aafefc4a94eb848d8296e511a2"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/bg/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/bg/firefox-133.0b1.tar.bz2"; locale = "bg"; arch = "linux-x86_64"; sha256 = "75181bb251f3a0ed3ee54a59d8336cc5ae1b9275b513c6a251e8f7b61acca0bc"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/bn/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/bn/firefox-133.0b1.tar.bz2"; locale = "bn"; arch = "linux-x86_64"; sha256 = "b98e1240f7a254de8d11a20081b9b78977ca5fb457a554a59a9898f6a02aa2fd"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/br/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/br/firefox-133.0b1.tar.bz2"; locale = "br"; arch = "linux-x86_64"; sha256 = "f9ba2badd98674e657d6cc11a8bb0a9dc40a987fdd9feb6c5c09cc724b15a1c8"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/bs/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/bs/firefox-133.0b1.tar.bz2"; locale = "bs"; arch = "linux-x86_64"; sha256 = "7b2bc6c540c69db95777ca8237408bb0c7d9722edbce25a1b0ff768ce401e759"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ca-valencia/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ca-valencia/firefox-133.0b1.tar.bz2"; locale = "ca-valencia"; arch = "linux-x86_64"; sha256 = "48f589c0ae08b84600897683d8cc88fa8e0b6b7feb9803a9ac7d0f6eff57e39d"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ca/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ca/firefox-133.0b1.tar.bz2"; locale = "ca"; arch = "linux-x86_64"; sha256 = "dc9b36d6d4fffd577d793edb4a15e115ca623e7160c3ba122ed5b7b91e6213b9"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/cak/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/cak/firefox-133.0b1.tar.bz2"; locale = "cak"; arch = "linux-x86_64"; sha256 = "d23edc8e857bd65bddd142c9f8d324951e1d8c47ec5457aa5c17db1c1f8abad0"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/cs/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/cs/firefox-133.0b1.tar.bz2"; locale = "cs"; arch = "linux-x86_64"; sha256 = "aff33a070bde117bc895a9341db21a66e22b81834c4035a7d8d490f276778027"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/cy/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/cy/firefox-133.0b1.tar.bz2"; locale = "cy"; arch = "linux-x86_64"; sha256 = "75bcfe33c4d161a64e259112032ade36fb8d02284b3882c948c62e04082caa0b"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/da/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/da/firefox-133.0b1.tar.bz2"; locale = "da"; arch = "linux-x86_64"; sha256 = "797573e69ac32c81011e8f627ec2cbf621a5bf189ced7514e3fc125ecc889f7d"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/de/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/de/firefox-133.0b1.tar.bz2"; locale = "de"; arch = "linux-x86_64"; sha256 = "414afe0dc658893cce23a21ddd4f879e8402a1eea60d62ce591e483da657b48b"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/dsb/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/dsb/firefox-133.0b1.tar.bz2"; locale = "dsb"; arch = "linux-x86_64"; sha256 = "4ca0de6888fdf03640b2d25eb46a88ed8b43eef26a71e2aceadd8c22341ce1fb"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/el/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/el/firefox-133.0b1.tar.bz2"; locale = "el"; arch = "linux-x86_64"; sha256 = "9eb42c8323ac9f05f157a36265b3cffc3b8c20f9730018912db76e9bb511a023"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/en-CA/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/en-CA/firefox-133.0b1.tar.bz2"; locale = "en-CA"; arch = "linux-x86_64"; sha256 = "54a05bcd08463251bd62b5e1b43e2a063d6a757f66855cac981c19482c171205"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/en-GB/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/en-GB/firefox-133.0b1.tar.bz2"; locale = "en-GB"; arch = "linux-x86_64"; sha256 = "8d6070c9e4d20aa11aec0b1b89963c103c665035f6a315adf5c1321a8f84c03d"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/en-US/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/en-US/firefox-133.0b1.tar.bz2"; locale = "en-US"; arch = "linux-x86_64"; sha256 = "bd60365443d1063aaabf555df4fb11411fd29ea31ac2aa1c80c9ada0e363e087"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/eo/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/eo/firefox-133.0b1.tar.bz2"; locale = "eo"; arch = "linux-x86_64"; sha256 = "c145076111c58985e25d4ca937ca51a92e1359b8b87d117c1ccdd8aeda58bb83"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/es-AR/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/es-AR/firefox-133.0b1.tar.bz2"; locale = "es-AR"; arch = "linux-x86_64"; sha256 = "aadd10fa5e2c58b77caef30e59d4ba6f6d0c7502387bc6e96921b3308383f065"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/es-CL/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/es-CL/firefox-133.0b1.tar.bz2"; locale = "es-CL"; arch = "linux-x86_64"; sha256 = "5635b30ca049a62e7ae2bd2ddb5a5d0bd3a89ddc4fbaebb9aa8069d55c28b6ea"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/es-ES/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/es-ES/firefox-133.0b1.tar.bz2"; locale = "es-ES"; arch = "linux-x86_64"; sha256 = "cb65652cc54501185be04b33c2f89d29ae118f84d30149f747270551fb1a1b9b"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/es-MX/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/es-MX/firefox-133.0b1.tar.bz2"; locale = "es-MX"; arch = "linux-x86_64"; sha256 = "2a9ed3f17448c7c2158bb13c757fa42a473bab4208e17879f7be7f45d2b3e532"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/et/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/et/firefox-133.0b1.tar.bz2"; locale = "et"; arch = "linux-x86_64"; sha256 = "edaef66989d1641d2854dc2766d99ed46764b2d769093094b3dfe15a31f52d4c"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/eu/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/eu/firefox-133.0b1.tar.bz2"; locale = "eu"; arch = "linux-x86_64"; sha256 = "92f713be50d333f4a09eacf4ae63d3031fef13893ec96d4e5fc1f6a8085cfc7f"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/fa/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/fa/firefox-133.0b1.tar.bz2"; locale = "fa"; arch = "linux-x86_64"; sha256 = "d67cb179bb6ab763867a0c3e37f4a60c0374343a5c3832ebd515bc22e10db74b"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ff/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ff/firefox-133.0b1.tar.bz2"; locale = "ff"; arch = "linux-x86_64"; sha256 = "a3a2453735601d5ff84214061bd0a13c34d0c77c186fb224565573bddf27fff6"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/fi/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/fi/firefox-133.0b1.tar.bz2"; locale = "fi"; arch = "linux-x86_64"; sha256 = "0be6d6b66280b352783a276eda0bd4895f05d27b0012528c1d1c73ab15326585"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/fr/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/fr/firefox-133.0b1.tar.bz2"; locale = "fr"; arch = "linux-x86_64"; sha256 = "2ebeaab8ca0e53240e8ba2858b7a161a7725336be452c8deb643f36b4398e619"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/fur/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/fur/firefox-133.0b1.tar.bz2"; locale = "fur"; arch = "linux-x86_64"; sha256 = "a5bf8c850244ac685fcdc21e988398bfe740b4b7cf8bb871e9966b12f73cd1f9"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/fy-NL/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/fy-NL/firefox-133.0b1.tar.bz2"; locale = "fy-NL"; arch = "linux-x86_64"; sha256 = "09db11c5eda2a8b3b0f456fb5dcd35dc794d0793d5b48c33cb3c045ff6ac7ab3"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ga-IE/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ga-IE/firefox-133.0b1.tar.bz2"; locale = "ga-IE"; arch = "linux-x86_64"; sha256 = "9f3b087ad1193a637173b912139750acc0c06a52e11326fcebdc8371b74602e5"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/gd/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/gd/firefox-133.0b1.tar.bz2"; locale = "gd"; arch = "linux-x86_64"; sha256 = "8989162bb822f5a9a9f51eda496022066e232e93f97fc0a4c3a533c37f688090"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/gl/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/gl/firefox-133.0b1.tar.bz2"; locale = "gl"; arch = "linux-x86_64"; sha256 = "84a82790c373b0b70410fa06df2e63d776ac709345eb11a6464143371c9e7dd8"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/gn/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/gn/firefox-133.0b1.tar.bz2"; locale = "gn"; arch = "linux-x86_64"; sha256 = "409c4d33cd7120e9e6b81c245f6b704052644c262b7417316d02c965e3127ab2"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/gu-IN/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/gu-IN/firefox-133.0b1.tar.bz2"; locale = "gu-IN"; arch = "linux-x86_64"; sha256 = "dda2b37db9e0913d4bff59671eca21479e6e64b41f41ea9879c98d42864eb4fa"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/he/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/he/firefox-133.0b1.tar.bz2"; locale = "he"; arch = "linux-x86_64"; sha256 = "1b7b0eda7e646daff52964f619fe9c463127aba76a4dcc472c75af25ce412927"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/hi-IN/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/hi-IN/firefox-133.0b1.tar.bz2"; locale = "hi-IN"; arch = "linux-x86_64"; sha256 = "8a0858bdfb74aeb3fb5dc7f6f58de97ba72b1a7280f23a7261c838cdc3f3b4c3"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/hr/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/hr/firefox-133.0b1.tar.bz2"; locale = "hr"; arch = "linux-x86_64"; sha256 = "666c22ef6c63393fcfadc106e5d9e45f9045871d7320084bb27bea2bc940a4dd"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/hsb/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/hsb/firefox-133.0b1.tar.bz2"; locale = "hsb"; arch = "linux-x86_64"; sha256 = "3687f58291699a0998156e17384da66cafab51834d7c5dbe8a4b6a106173b32c"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/hu/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/hu/firefox-133.0b1.tar.bz2"; locale = "hu"; arch = "linux-x86_64"; sha256 = "96809520bad15744ac0882acadcce7b5bcf5fa0bc4b352a0d4ed2577ff625750"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/hy-AM/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/hy-AM/firefox-133.0b1.tar.bz2"; locale = "hy-AM"; arch = "linux-x86_64"; sha256 = "c8ceac8c1d97cb6526b4d5010762afe6a4259f02e7e0bb7e237f811ebdf73eab"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ia/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ia/firefox-133.0b1.tar.bz2"; locale = "ia"; arch = "linux-x86_64"; sha256 = "114b0c25121b47a83b6614e7e1c7d4f267b38033b4d9ba1da0299cc2e64c9388"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/id/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/id/firefox-133.0b1.tar.bz2"; locale = "id"; arch = "linux-x86_64"; sha256 = "67aac95105b980657b01eddd19fe36febb3bbd085be505695a1addb7681d0e4c"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/is/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/is/firefox-133.0b1.tar.bz2"; locale = "is"; arch = "linux-x86_64"; sha256 = "6e712498fdab6993e70245a81a3dd34ef28743d08222637963028efff80ce076"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/it/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/it/firefox-133.0b1.tar.bz2"; locale = "it"; arch = "linux-x86_64"; sha256 = "b17a924b15c6fa4f2b894557d596d7e9e44829fbd1aee36ad8923bbb183dd2f4"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ja/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ja/firefox-133.0b1.tar.bz2"; locale = "ja"; arch = "linux-x86_64"; sha256 = "fba05f5aed261d17be91fd8b244decbd376d9a99d845c14d9a233a6e480cf7ec"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ka/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ka/firefox-133.0b1.tar.bz2"; locale = "ka"; arch = "linux-x86_64"; sha256 = "7d6ec78930a4d530f4dbdb471e870c0b9ec4b908d83100edaf1eec5a4c1a69fb"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/kab/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/kab/firefox-133.0b1.tar.bz2"; locale = "kab"; arch = "linux-x86_64"; sha256 = "f819c92656b1d7a11e73ed35d5bfc443ef5af0468935dbd783788e48cb07ae40"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/kk/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/kk/firefox-133.0b1.tar.bz2"; locale = "kk"; arch = "linux-x86_64"; sha256 = "616dab450ca82656646018e5718a83b4689e3e51f82a10211c543e39fcbba3a4"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/km/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/km/firefox-133.0b1.tar.bz2"; locale = "km"; arch = "linux-x86_64"; sha256 = "946d66dac62726147ffae686410a761b7187c1230a740bee61937fc5acfd3b68"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/kn/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/kn/firefox-133.0b1.tar.bz2"; locale = "kn"; arch = "linux-x86_64"; sha256 = "57aa68e667431152b26dce17f52d381daea3bbbd51d20d2d41c282b71506b4d0"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ko/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ko/firefox-133.0b1.tar.bz2"; locale = "ko"; arch = "linux-x86_64"; sha256 = "8a8b38085990d15443e819ea087b1b241af99ed843351308d7cd49962e434fb5"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/lij/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/lij/firefox-133.0b1.tar.bz2"; locale = "lij"; arch = "linux-x86_64"; sha256 = "5d88633bc0cc1badd60c32ae3ca597ecbd6f82c8ba17c363ba35504451aa0966"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/lt/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/lt/firefox-133.0b1.tar.bz2"; locale = "lt"; arch = "linux-x86_64"; sha256 = "c70d3e92bd3f9027c69589fb17996a8085bb4c74f447f0cd32610988851817ed"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/lv/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/lv/firefox-133.0b1.tar.bz2"; locale = "lv"; arch = "linux-x86_64"; sha256 = "066ac178e2e6076f9d15f731e71b0346e30b54be2d896cf00cd78eb6601083db"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/mk/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/mk/firefox-133.0b1.tar.bz2"; locale = "mk"; arch = "linux-x86_64"; sha256 = "31c8eff29a9ebe3b29c683533cad12aa48b3afd5ee7845f3033f70b6c0bc6241"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/mr/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/mr/firefox-133.0b1.tar.bz2"; locale = "mr"; arch = "linux-x86_64"; sha256 = "078da76e4f7b8764593f1701cef1f06d9e77fd607c68be7481948ee2fb4a791a"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ms/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ms/firefox-133.0b1.tar.bz2"; locale = "ms"; arch = "linux-x86_64"; sha256 = "94229a433c2487ac653c82b2daad6503cdf80602b4ded2fb7072c7d0a64afb3d"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/my/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/my/firefox-133.0b1.tar.bz2"; locale = "my"; arch = "linux-x86_64"; sha256 = "317294bf218a0d19f205b908a48a90fbe06cf5c0fa114e8e831d033ddb3e32b4"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/nb-NO/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/nb-NO/firefox-133.0b1.tar.bz2"; locale = "nb-NO"; arch = "linux-x86_64"; sha256 = "64014f27b7cd516da9f76bea26a2e37729a535740b5c52e1556932fa8e357c82"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ne-NP/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ne-NP/firefox-133.0b1.tar.bz2"; locale = "ne-NP"; arch = "linux-x86_64"; sha256 = "d5c3cd9524e069953305c1a52b8e6a9967f0eb947baedeeff8736ef6a6ac83ca"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/nl/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/nl/firefox-133.0b1.tar.bz2"; locale = "nl"; arch = "linux-x86_64"; sha256 = "a575e4899c81ac773d0a40a1a9f89af0c3ad77b8776634abed33fc9fe7511fca"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/nn-NO/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/nn-NO/firefox-133.0b1.tar.bz2"; locale = "nn-NO"; arch = "linux-x86_64"; sha256 = "36ad31e105bf6edb37fac55bfd58e50afe32b4a705c74e5c2b6e9db27a869d54"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/oc/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/oc/firefox-133.0b1.tar.bz2"; locale = "oc"; arch = "linux-x86_64"; sha256 = "e3fb3a792cb7afc025ce3b4d19f089c80a542a9b91ea0cf8945e69a229ccfe6f"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/pa-IN/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/pa-IN/firefox-133.0b1.tar.bz2"; locale = "pa-IN"; arch = "linux-x86_64"; sha256 = "0c5a828f6c7d42026cf896fba8423d04e094de396bf26dde94621fcff363e975"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/pl/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/pl/firefox-133.0b1.tar.bz2"; locale = "pl"; arch = "linux-x86_64"; sha256 = "4b122397e9ccdabccdf7f0f5ddbfc734c5675170d8e32a1059ff42da08fe11e5"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/pt-BR/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/pt-BR/firefox-133.0b1.tar.bz2"; locale = "pt-BR"; arch = "linux-x86_64"; sha256 = "076a75a158bea4023bd38e4f5a534187ba329b0ddfcf3ab0b97657bf21dccc66"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/pt-PT/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/pt-PT/firefox-133.0b1.tar.bz2"; locale = "pt-PT"; arch = "linux-x86_64"; sha256 = "6c254118ee767d71a0203487512ab2411dacea0903074def934581c92d5b5fb3"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/rm/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/rm/firefox-133.0b1.tar.bz2"; locale = "rm"; arch = "linux-x86_64"; sha256 = "313917e95e615d934308b127f56a35a69bb516a5e4d6ef5f63fe4a2f7a5fcf2a"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ro/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ro/firefox-133.0b1.tar.bz2"; locale = "ro"; arch = "linux-x86_64"; sha256 = "8ad52f9cd80a2bb1df257f7a3b5c09ebc6abff52eaa5d504a9a45819e2329a85"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ru/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ru/firefox-133.0b1.tar.bz2"; locale = "ru"; arch = "linux-x86_64"; sha256 = "ad91ca54f0b7cde1de770bb57078ba8d891300ea5554aac6e7b1e8fbd750e097"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sat/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sat/firefox-133.0b1.tar.bz2"; locale = "sat"; arch = "linux-x86_64"; sha256 = "f8e310b7fde9ba123fdf478038dd9597979dc710491a1fe4316a0759b756e5e6"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sc/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sc/firefox-133.0b1.tar.bz2"; locale = "sc"; arch = "linux-x86_64"; sha256 = "15b761a6fbb95c47ba6fe2d7bb1d2cedfd522ce43645f070e1403ba6fef74e08"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sco/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sco/firefox-133.0b1.tar.bz2"; locale = "sco"; arch = "linux-x86_64"; sha256 = "bb56b3741ddcfd7d1d3751a364985cd94a59b4b26f18c4502a57687cc269ae1a"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/si/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/si/firefox-133.0b1.tar.bz2"; locale = "si"; arch = "linux-x86_64"; sha256 = "4f6011912dd99fbc23e3d764874c1e6e532957c561e79b30252f6dfcccd400f3"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sk/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sk/firefox-133.0b1.tar.bz2"; locale = "sk"; arch = "linux-x86_64"; sha256 = "82af3e4d39dfa2f5c8f399af21c0f167941a46bd7ad4ca512c652909b45d034a"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/skr/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/skr/firefox-133.0b1.tar.bz2"; locale = "skr"; arch = "linux-x86_64"; sha256 = "3fd67475eb317ea3f83c0787cac862d8b8725aedfd3f6dc8d0274f368dd1a36a"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sl/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sl/firefox-133.0b1.tar.bz2"; locale = "sl"; arch = "linux-x86_64"; sha256 = "5c8991a89e795de0d8c5c6b2a08e1029d7ddbfd25045951b33a0b04223a41bad"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/son/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/son/firefox-133.0b1.tar.bz2"; locale = "son"; arch = "linux-x86_64"; sha256 = "d9a96931cfeb04cc23bc03954c69934d21bf4c5a5810c94ac961a6088e39054e"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sq/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sq/firefox-133.0b1.tar.bz2"; locale = "sq"; arch = "linux-x86_64"; sha256 = "8d27d21903f512004900cdc7198de4991f22218ce948d5242cda649cc30ccf68"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sr/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sr/firefox-133.0b1.tar.bz2"; locale = "sr"; arch = "linux-x86_64"; sha256 = "b78db319c021661d41824f2267ae462695745e19345364495c40827e0a5247ca"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sv-SE/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/sv-SE/firefox-133.0b1.tar.bz2"; locale = "sv-SE"; arch = "linux-x86_64"; sha256 = "1215e48cacd11570a2f3a8914328a472c6167d7810f94953699e5c6f44d2bac3"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/szl/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/szl/firefox-133.0b1.tar.bz2"; locale = "szl"; arch = "linux-x86_64"; sha256 = "2828965807f5b8ec7718cc58eb9ef38452acd6018a89987fb1e07faca47c1c9a"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ta/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ta/firefox-133.0b1.tar.bz2"; locale = "ta"; arch = "linux-x86_64"; sha256 = "ea30035871e66630a9057c54ca67fa49b94f0c75772a4fc2f1aad486481ed385"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/te/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/te/firefox-133.0b1.tar.bz2"; locale = "te"; arch = "linux-x86_64"; sha256 = "e878689ad558db568f50baf0803978f2c6fde36fa8020cdcd7706b2f223d4e05"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/tg/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/tg/firefox-133.0b1.tar.bz2"; locale = "tg"; arch = "linux-x86_64"; sha256 = "4611925af4e593b82f4fbd7517bcb48ba3757093c819af3c5c5b69e0b45672bc"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/th/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/th/firefox-133.0b1.tar.bz2"; locale = "th"; arch = "linux-x86_64"; sha256 = "fb6240f394ff58a04557117ed281d28c28abcbb7a37223281e42cba3aba58a8e"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/tl/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/tl/firefox-133.0b1.tar.bz2"; locale = "tl"; arch = "linux-x86_64"; sha256 = "e6233f5f26b5b22aec20cab3c0fa434ca8cdbd301c671650e8a4385f2785517d"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/tr/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/tr/firefox-133.0b1.tar.bz2"; locale = "tr"; arch = "linux-x86_64"; sha256 = "de2e4b9ebbec7428044df32206338318a77625c70bef63b86a87df7880f899e9"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/trs/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/trs/firefox-133.0b1.tar.bz2"; locale = "trs"; arch = "linux-x86_64"; sha256 = "e23e749741ae2afdf3cbe580221753c90a5dc115327f1dc1b17a840cd05b93d2"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/uk/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/uk/firefox-133.0b1.tar.bz2"; locale = "uk"; arch = "linux-x86_64"; sha256 = "7641ff9a44fed05133ec2a7876f7a70b7fc701efb98a99c9099f0263cf100701"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ur/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/ur/firefox-133.0b1.tar.bz2"; locale = "ur"; arch = "linux-x86_64"; sha256 = "76b84dea317b8d096626636e4317df7a0de33f045824494dc1076fbf9a11c3ce"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/uz/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/uz/firefox-133.0b1.tar.bz2"; locale = "uz"; arch = "linux-x86_64"; sha256 = "ea3bbd715f93ac09524258ef039f97b67ae04163f9ba490217e3448a50ea69db"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/vi/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/vi/firefox-133.0b1.tar.bz2"; locale = "vi"; arch = "linux-x86_64"; sha256 = "d26f876dc7458fec133133cb4bc25350f96a0a7b4b6ffcfe26483fa62c03985f"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/xh/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/xh/firefox-133.0b1.tar.bz2"; locale = "xh"; arch = "linux-x86_64"; sha256 = "69e8a971f8925945c0323320f45a843d98d7ab73b80f9428f47e83626651b6ef"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/zh-CN/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/zh-CN/firefox-133.0b1.tar.bz2"; locale = "zh-CN"; arch = "linux-x86_64"; sha256 = "1eaa3adc05330db6849d01314a7bb8afea8dd69b7ad1dde5c0b373d84341eeb3"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/zh-TW/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-x86_64/zh-TW/firefox-133.0b1.tar.bz2"; locale = "zh-TW"; arch = "linux-x86_64"; sha256 = "22d501328e4728fdd2e8e22c44b164ea3435b5905f57adfcaa97843abf3d1d2b"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ach/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ach/firefox-133.0b1.tar.bz2"; locale = "ach"; arch = "linux-i686"; sha256 = "5235e26e6100a1216b7e814f4885cb70f18544926cd5717bd10ce0f921a5dfa7"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/af/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/af/firefox-133.0b1.tar.bz2"; locale = "af"; arch = "linux-i686"; sha256 = "ecd5f7edcf44f0bc6c8f9cb2e959d64652477c0a91138186a47d049090333967"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/an/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/an/firefox-133.0b1.tar.bz2"; locale = "an"; arch = "linux-i686"; sha256 = "62080977a6f277a02982a1ca4f95226539d896cbcab49be5ada9419fbb35c2a7"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ar/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ar/firefox-133.0b1.tar.bz2"; locale = "ar"; arch = "linux-i686"; sha256 = "d159f1146a116f128fd93468f9a52b264bb97c8f98cd615b4c22fd0f4bb54369"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ast/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ast/firefox-133.0b1.tar.bz2"; locale = "ast"; arch = "linux-i686"; sha256 = "c7786d6134922c00a7add9d55b36aa277f791c57e7ae1370a57ad2293c279a58"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/az/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/az/firefox-133.0b1.tar.bz2"; locale = "az"; arch = "linux-i686"; sha256 = "37a7f70e459ce17ba506dcf57a2d0a918b1d34f6d65d71a65cacdded1d36cbec"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/be/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/be/firefox-133.0b1.tar.bz2"; locale = "be"; arch = "linux-i686"; sha256 = "f35bfd4c67e2e16241bf5d18058d01da003b6db98ef20a5c5ff80866dee2a3a5"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/bg/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/bg/firefox-133.0b1.tar.bz2"; locale = "bg"; arch = "linux-i686"; sha256 = "6e591047810cdeb9fb455146a6d7fc40e2bc07be8ba80b9000956c958bc4590a"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/bn/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/bn/firefox-133.0b1.tar.bz2"; locale = "bn"; arch = "linux-i686"; sha256 = "94018749fd939955bda8911d44ebfa1336e1ed6b0deb78cfcf51c978ca21c586"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/br/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/br/firefox-133.0b1.tar.bz2"; locale = "br"; arch = "linux-i686"; sha256 = "dc9a5b38938dc4ee51a1774b57ea9b8ed178908d5c792b5c8d6072f964a8ce2b"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/bs/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/bs/firefox-133.0b1.tar.bz2"; locale = "bs"; arch = "linux-i686"; sha256 = "4dfecd9c6b843636df4a952769d30779ca167968c204556ca21be822f2c6488b"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ca-valencia/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ca-valencia/firefox-133.0b1.tar.bz2"; locale = "ca-valencia"; arch = "linux-i686"; sha256 = "d95465f69ff0a31c5c5fab725a0c8bfc9564a896993f5eaef9f1a46badef9d16"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ca/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ca/firefox-133.0b1.tar.bz2"; locale = "ca"; arch = "linux-i686"; sha256 = "f60d2f04ef97c94604a38c9065fbc4d7762a0e97cb7a951963d977f599574fb4"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/cak/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/cak/firefox-133.0b1.tar.bz2"; locale = "cak"; arch = "linux-i686"; sha256 = "8fc8cee299c1eb3a7bff416cb749eca7a26840d7b4934f31bc36cf6b9ac0a40e"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/cs/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/cs/firefox-133.0b1.tar.bz2"; locale = "cs"; arch = "linux-i686"; sha256 = "6a1adadeb5516c35fe30874c3805f31276aae3638213a3b14a491e2b091aacef"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/cy/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/cy/firefox-133.0b1.tar.bz2"; locale = "cy"; arch = "linux-i686"; sha256 = "9eb63eded5bdb7199b26bc621fca862df9aa7aab1886b79e1c1d3e230742976e"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/da/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/da/firefox-133.0b1.tar.bz2"; locale = "da"; arch = "linux-i686"; sha256 = "e4e33e4319a9072892ef395aaf6c1175223e802bfc1f7dc474ad1ef9f91c5883"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/de/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/de/firefox-133.0b1.tar.bz2"; locale = "de"; arch = "linux-i686"; sha256 = "ec69257df5cfe9a37c3a69726f2281a3d0e6a9a85a501f19e46535eae80a5e2d"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/dsb/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/dsb/firefox-133.0b1.tar.bz2"; locale = "dsb"; arch = "linux-i686"; sha256 = "e7244987df4e971dedd31de64586863f5d2888382d3da68d1386b406f2405200"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/el/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/el/firefox-133.0b1.tar.bz2"; locale = "el"; arch = "linux-i686"; sha256 = "5b3c989407a6ed42f095cf8b5656aa2a49dca17adb117458828424812881183d"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/en-CA/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/en-CA/firefox-133.0b1.tar.bz2"; locale = "en-CA"; arch = "linux-i686"; sha256 = "2377969cb6f7e2f169932c7f20581bcd1bf740db9f1e2f464896666a3fc38987"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/en-GB/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/en-GB/firefox-133.0b1.tar.bz2"; locale = "en-GB"; arch = "linux-i686"; sha256 = "039ceea2c9ebc264d01bfefed9bf8fbc16434698d5c4d4cfe457794d92a92a1f"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/en-US/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/en-US/firefox-133.0b1.tar.bz2"; locale = "en-US"; arch = "linux-i686"; sha256 = "32ce9d0bbb2080ce8afa73ae5d1bf166105b6dfe8bf26ccce3721d42815f0581"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/eo/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/eo/firefox-133.0b1.tar.bz2"; locale = "eo"; arch = "linux-i686"; sha256 = "90a50460c92718c62a0c0f0c3e58348ef5cb4757db8fd05aca4c251bf23ab3d7"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/es-AR/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/es-AR/firefox-133.0b1.tar.bz2"; locale = "es-AR"; arch = "linux-i686"; sha256 = "4ae7d1644197612b266b8844e27c6ea7b5e3df079e0ef1b44f8b885b93e1f18f"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/es-CL/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/es-CL/firefox-133.0b1.tar.bz2"; locale = "es-CL"; arch = "linux-i686"; sha256 = "e547ecb14f8bd32c91f4025022029bb79af4b065e71c234940306949b5c5e462"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/es-ES/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/es-ES/firefox-133.0b1.tar.bz2"; locale = "es-ES"; arch = "linux-i686"; sha256 = "e5a6d7dc34190992814995a0b57b4d9188c3ed6c8746a045750a56bd079713e2"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/es-MX/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/es-MX/firefox-133.0b1.tar.bz2"; locale = "es-MX"; arch = "linux-i686"; sha256 = "53ad3eaa0f7b969350ae43c023586d42fb18044926bde5c1f5d8337c8d83f7f6"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/et/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/et/firefox-133.0b1.tar.bz2"; locale = "et"; arch = "linux-i686"; sha256 = "c647317e95f41ea684e38d3aace7055d920f3b119a82759b335012446f1b5724"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/eu/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/eu/firefox-133.0b1.tar.bz2"; locale = "eu"; arch = "linux-i686"; sha256 = "873e4d999c8a96c8aafcbffea4c18cfce5166c395309ccbeec638ea26a80dfa2"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/fa/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/fa/firefox-133.0b1.tar.bz2"; locale = "fa"; arch = "linux-i686"; sha256 = "fa443519be951c02b12dd2cf8a5c163deb8408ce3142d499484078d8f7040f9d"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ff/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ff/firefox-133.0b1.tar.bz2"; locale = "ff"; arch = "linux-i686"; sha256 = "dd025f7616a71ff7fc71162acbfef86ae1a6905c039ec2749c7742982dc89a4a"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/fi/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/fi/firefox-133.0b1.tar.bz2"; locale = "fi"; arch = "linux-i686"; sha256 = "bed429db1a03783615ddcd1ecd1383f3f4c52e1295bc7cff0af450718d079db7"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/fr/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/fr/firefox-133.0b1.tar.bz2"; locale = "fr"; arch = "linux-i686"; sha256 = "7d577bd3cad1e960424aceffcea266d1e0f26757e5942dcb473a1657c3290ba0"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/fur/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/fur/firefox-133.0b1.tar.bz2"; locale = "fur"; arch = "linux-i686"; sha256 = "5fa36efcefbb0626419b9a8beae643ef1e6f0c386a2f507e72247c565e1e8998"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/fy-NL/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/fy-NL/firefox-133.0b1.tar.bz2"; locale = "fy-NL"; arch = "linux-i686"; sha256 = "02997236f0488ce1b9fa1ec40648154bda3c445c0130d7a08982abc25ea2ebf1"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ga-IE/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ga-IE/firefox-133.0b1.tar.bz2"; locale = "ga-IE"; arch = "linux-i686"; sha256 = "41bbc0b9583e97acb6c52751974e602345e1ed593673574a9c6d6ae4fc185990"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/gd/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/gd/firefox-133.0b1.tar.bz2"; locale = "gd"; arch = "linux-i686"; sha256 = "a6831f8632128c1b2d02935f63000b1bf7d0e88b6bea0b2d814a8e8774aa24fe"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/gl/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/gl/firefox-133.0b1.tar.bz2"; locale = "gl"; arch = "linux-i686"; sha256 = "54b7785440073d33262667bfa6c2867a8f623741274dc55ac70b3053ff17032b"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/gn/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/gn/firefox-133.0b1.tar.bz2"; locale = "gn"; arch = "linux-i686"; sha256 = "e2542e3c1d1fa72bfaa601bc6db5c327cf3d992efeb0d40dda79c8c2a91e57e0"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/gu-IN/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/gu-IN/firefox-133.0b1.tar.bz2"; locale = "gu-IN"; arch = "linux-i686"; sha256 = "e67053a7ab1a8549de586a38271239188aa77572514945781d34d3c56b61259d"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/he/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/he/firefox-133.0b1.tar.bz2"; locale = "he"; arch = "linux-i686"; sha256 = "a0d06ad4015f912dbf8f12b97a7193ffbba48afe63b53bf24242f4eec44b21ad"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/hi-IN/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/hi-IN/firefox-133.0b1.tar.bz2"; locale = "hi-IN"; arch = "linux-i686"; sha256 = "74d9298bf2219c3fd8e9ee0783b90d2fdeec7dc11ef48d7dd388a20b9e99079b"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/hr/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/hr/firefox-133.0b1.tar.bz2"; locale = "hr"; arch = "linux-i686"; sha256 = "067f27467dced6d01362b396802cd33dd9c80d45c849a579b49f3c5c07ebd182"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/hsb/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/hsb/firefox-133.0b1.tar.bz2"; locale = "hsb"; arch = "linux-i686"; sha256 = "46581a547587e8469d171192d7f45c029c6868addc0df73ae52ce86eec5b555d"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/hu/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/hu/firefox-133.0b1.tar.bz2"; locale = "hu"; arch = "linux-i686"; sha256 = "7401a0dd3ea993a1b35252e383258b03ea3b66bb5f8760b06556b1141598f740"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/hy-AM/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/hy-AM/firefox-133.0b1.tar.bz2"; locale = "hy-AM"; arch = "linux-i686"; sha256 = "2aa425086ff2ceefca72afb084992225b33383492379e91b85441c33140f34d0"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ia/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ia/firefox-133.0b1.tar.bz2"; locale = "ia"; arch = "linux-i686"; sha256 = "0aa4009346092ad02ec4242f5748c087ca3a1f0f49c753101b70a03ec8e07a42"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/id/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/id/firefox-133.0b1.tar.bz2"; locale = "id"; arch = "linux-i686"; sha256 = "be998daeebbf20dbd12976f33c75edd7dd1db838c439ae16120ad96e887f5e7c"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/is/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/is/firefox-133.0b1.tar.bz2"; locale = "is"; arch = "linux-i686"; sha256 = "89c5a3329217c033b12a706b1dfd239a31b9b6c25bcc44fc250cde6cae9a7a5e"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/it/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/it/firefox-133.0b1.tar.bz2"; locale = "it"; arch = "linux-i686"; sha256 = "b2eb6281f75c734ff2d8190bbefe360e239a384161fbd61eb61dca837be6df3c"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ja/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ja/firefox-133.0b1.tar.bz2"; locale = "ja"; arch = "linux-i686"; sha256 = "cfb7a0c45fc51a75c888f27c119e841e4afbf59a68af79ed81fd054a8fab3292"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ka/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ka/firefox-133.0b1.tar.bz2"; locale = "ka"; arch = "linux-i686"; sha256 = "134cc6680cd261624677b68c41330e7283cbf940e3c5cadc89cce10fcbcff4f8"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/kab/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/kab/firefox-133.0b1.tar.bz2"; locale = "kab"; arch = "linux-i686"; sha256 = "e9eef562d65a06f595cf620b96fd796c76cde9c9ebafe017bac7ee01abb09d85"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/kk/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/kk/firefox-133.0b1.tar.bz2"; locale = "kk"; arch = "linux-i686"; sha256 = "844b7b7c2737bf8ab1beface6fb3ab66bb9447d90c7e284c0db5977f193ca608"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/km/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/km/firefox-133.0b1.tar.bz2"; locale = "km"; arch = "linux-i686"; sha256 = "3153a0d951761133902853591b8dc324f51b7937afef7f876d42cef9819de7e5"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/kn/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/kn/firefox-133.0b1.tar.bz2"; locale = "kn"; arch = "linux-i686"; sha256 = "3b15251296773062dd58666feb4e4d1d069069035f7f29d0c30d89a8aa8ede52"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ko/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ko/firefox-133.0b1.tar.bz2"; locale = "ko"; arch = "linux-i686"; sha256 = "26d3ec847cb4f4a63dc65e5f85b71a83c0000b3a2245242aeb0c85717f638c05"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/lij/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/lij/firefox-133.0b1.tar.bz2"; locale = "lij"; arch = "linux-i686"; sha256 = "821cebf1615b8d6ccc886f1ba6f71b7c96d1f905f25656c06202aa9823b9fd7c"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/lt/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/lt/firefox-133.0b1.tar.bz2"; locale = "lt"; arch = "linux-i686"; sha256 = "67f446c2dc13ab0f5e807c359f58b6629237b84b270119e1a07b4783c0f32f8a"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/lv/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/lv/firefox-133.0b1.tar.bz2"; locale = "lv"; arch = "linux-i686"; sha256 = "3610f2928483acf76391b76d6daa7163dd2f67fafc9f52fd24741cb9fceb6c27"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/mk/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/mk/firefox-133.0b1.tar.bz2"; locale = "mk"; arch = "linux-i686"; sha256 = "59952564993c98da66d5b88672fd9c40911601cb7845d64587f88636ac724310"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/mr/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/mr/firefox-133.0b1.tar.bz2"; locale = "mr"; arch = "linux-i686"; sha256 = "a28a7e3bc05f3053d35a2f7ec1e6f6e9a23b09039d129986fdda4f8e827b85ec"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ms/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ms/firefox-133.0b1.tar.bz2"; locale = "ms"; arch = "linux-i686"; sha256 = "7ffaa99af8244ab466607bccefded8b0e6e714fd40243160a9c4bc8778faa1bc"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/my/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/my/firefox-133.0b1.tar.bz2"; locale = "my"; arch = "linux-i686"; sha256 = "c709c5f9dc3626a3bc9bc68d833ee1c4f1d31fe316f5b764d40f73540e0a38f6"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/nb-NO/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/nb-NO/firefox-133.0b1.tar.bz2"; locale = "nb-NO"; arch = "linux-i686"; sha256 = "a97b29ebe0a76915cc4faedea6c448300ab8c7e8767c9f3244f1b339c8ebed5b"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ne-NP/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ne-NP/firefox-133.0b1.tar.bz2"; locale = "ne-NP"; arch = "linux-i686"; sha256 = "3214b27b65fbd84ebb8f409a6d05e2afe76f838432e4c35865ff3bd3fbc5b5b7"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/nl/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/nl/firefox-133.0b1.tar.bz2"; locale = "nl"; arch = "linux-i686"; sha256 = "fe1de7ebf13cf5fd0d9460a331d66d490b00fca1c1f5f36877297f65b34acb9a"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/nn-NO/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/nn-NO/firefox-133.0b1.tar.bz2"; locale = "nn-NO"; arch = "linux-i686"; sha256 = "131754185d4b0bdbdd8e5456ae54051a7e974fe65c92e5e68cebbc09ad77c3cf"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/oc/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/oc/firefox-133.0b1.tar.bz2"; locale = "oc"; arch = "linux-i686"; sha256 = "a83510b6064cada58cb3e69faa54081f63e118cc6a3ee82fae6b85041f4e9d7c"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/pa-IN/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/pa-IN/firefox-133.0b1.tar.bz2"; locale = "pa-IN"; arch = "linux-i686"; sha256 = "7ff6673e6851a9c7885803d4410534fbef1e383b24f5675dc0cd4536278bd6a8"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/pl/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/pl/firefox-133.0b1.tar.bz2"; locale = "pl"; arch = "linux-i686"; sha256 = "21958228263df676dd210810523848a25875f45897b2c777a23c0b41e57aceb9"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/pt-BR/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/pt-BR/firefox-133.0b1.tar.bz2"; locale = "pt-BR"; arch = "linux-i686"; sha256 = "e5b6e65b2e94fd4c083405ff9402d8b8121578e429403413969e973217d8edec"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/pt-PT/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/pt-PT/firefox-133.0b1.tar.bz2"; locale = "pt-PT"; arch = "linux-i686"; sha256 = "bce05639655230d8fddae84489f89505517dcdf7d2270635de952f02a1dfb0f8"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/rm/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/rm/firefox-133.0b1.tar.bz2"; locale = "rm"; arch = "linux-i686"; sha256 = "fad7e57b866dd5484a3c2987cfa7092d3b1505b9ff1bbe8b4abae01cb2862893"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ro/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ro/firefox-133.0b1.tar.bz2"; locale = "ro"; arch = "linux-i686"; sha256 = "91680a58a8178c48f22ca36a7d86bb09bed0ae26b223b8d3ee4b1401aae56f29"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ru/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ru/firefox-133.0b1.tar.bz2"; locale = "ru"; arch = "linux-i686"; sha256 = "9071420c5ad59bbf55c86c6b399d664547cc3f0e061985ddafc084c7ecb20996"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sat/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sat/firefox-133.0b1.tar.bz2"; locale = "sat"; arch = "linux-i686"; sha256 = "ebdb74ac24cd8844efcdb33eaecf2e3e6638708e87c720c81b7f2c5e968c068a"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sc/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sc/firefox-133.0b1.tar.bz2"; locale = "sc"; arch = "linux-i686"; sha256 = "caa20cc0c17491356bb4e1a5bbaa00278145773ede483f8aafdc42be39afd438"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sco/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sco/firefox-133.0b1.tar.bz2"; locale = "sco"; arch = "linux-i686"; sha256 = "09c69b7988f004b8a8ead03ecc784d11a3360d73dad12360692252660472f3b5"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/si/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/si/firefox-133.0b1.tar.bz2"; locale = "si"; arch = "linux-i686"; sha256 = "c087b6c581e769ae4d66761ff8826fb329d7f0bf6420b73368d2ceb538bf3d9f"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sk/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sk/firefox-133.0b1.tar.bz2"; locale = "sk"; arch = "linux-i686"; sha256 = "1b1226826371a1ebe2fcff4b8c874f0e0bbc854f8a3d6ea38aff82ff859b5eb9"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/skr/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/skr/firefox-133.0b1.tar.bz2"; locale = "skr"; arch = "linux-i686"; sha256 = "3a40bee963b81c94eac34b0da4163751f04dd97f9e18e22a408ea2e055c34a46"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sl/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sl/firefox-133.0b1.tar.bz2"; locale = "sl"; arch = "linux-i686"; sha256 = "7b34537382118ab1fd811d81a7ffb2a7292d447d3e5c922412676ddcca2c94dc"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/son/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/son/firefox-133.0b1.tar.bz2"; locale = "son"; arch = "linux-i686"; sha256 = "fa1660e07117c736a2d7c4249b3b34da98c70061dafcb7971ebaddf88c8fff18"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sq/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sq/firefox-133.0b1.tar.bz2"; locale = "sq"; arch = "linux-i686"; sha256 = "e4fb5bfb39bac51113b585daca8d60734a551252d7ae1196fb96023b2ba57c72"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sr/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sr/firefox-133.0b1.tar.bz2"; locale = "sr"; arch = "linux-i686"; sha256 = "62594ac892147e1a21bd7bb7b0d8609e779f18fab6c45cf9910b79bc6a7eae03"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sv-SE/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/sv-SE/firefox-133.0b1.tar.bz2"; locale = "sv-SE"; arch = "linux-i686"; sha256 = "dd1e6823bfbd0063912258e0da87df33d770fef2847643fda0a9b806d196e049"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/szl/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/szl/firefox-133.0b1.tar.bz2"; locale = "szl"; arch = "linux-i686"; sha256 = "28329d3165c3a0f629b71450df71ef264d0b962e0a19969c7fb1dce35c88b290"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ta/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ta/firefox-133.0b1.tar.bz2"; locale = "ta"; arch = "linux-i686"; sha256 = "8ab0bd1542f5484edeb1c8d4290a33ccbac6702bf732e9a57e34e28218605f7f"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/te/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/te/firefox-133.0b1.tar.bz2"; locale = "te"; arch = "linux-i686"; sha256 = "6e73c1550ea59e9177b13daefc84f9cd024c285865aba024af84ccea87e7ed30"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/tg/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/tg/firefox-133.0b1.tar.bz2"; locale = "tg"; arch = "linux-i686"; sha256 = "956a5816c8d32a9d513fb36889f1910c2d2e61b2e19ef4244572d993bd768611"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/th/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/th/firefox-133.0b1.tar.bz2"; locale = "th"; arch = "linux-i686"; sha256 = "685abae351da387a88ab5810c63fc7aba98f2c6329ef278e14666c1528be2554"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/tl/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/tl/firefox-133.0b1.tar.bz2"; locale = "tl"; arch = "linux-i686"; sha256 = "596044bebf8631c25f0025ed4b48a3ace63e854a6c35f7e5703780c5df2d814b"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/tr/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/tr/firefox-133.0b1.tar.bz2"; locale = "tr"; arch = "linux-i686"; sha256 = "a8de705710efc4bba5cd91dccb82d609cb05c218225cd93149c945a1c514d4ef"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/trs/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/trs/firefox-133.0b1.tar.bz2"; locale = "trs"; arch = "linux-i686"; sha256 = "2c147a19c1c09ae9ff74f885ba2e37808303d9ad78bc5f20354fcad59d345f42"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/uk/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/uk/firefox-133.0b1.tar.bz2"; locale = "uk"; arch = "linux-i686"; sha256 = "a408f1aff785082a163590575999837aa6ccaf681893266c2a3d497a32a50e8c"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ur/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/ur/firefox-133.0b1.tar.bz2"; locale = "ur"; arch = "linux-i686"; sha256 = "91ccc6797e9db30917880159356d4a79edf966ad55b000bddfaa73d46afab7ba"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/uz/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/uz/firefox-133.0b1.tar.bz2"; locale = "uz"; arch = "linux-i686"; sha256 = "58c625b07d58c5d10ac4d445d0f2c7f04ddddbd52089ad276ee831d8af1982df"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/vi/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/vi/firefox-133.0b1.tar.bz2"; locale = "vi"; arch = "linux-i686"; sha256 = "eddc3be87d3e8f496dbdc1cc722f60d61daf32bdefa13ae3988309e672e9f2ff"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/xh/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/xh/firefox-133.0b1.tar.bz2"; locale = "xh"; arch = "linux-i686"; sha256 = "2e78558a4e9861230f145896f3f1d5ea36aa5dcfca8f95dc671f992510f8a062"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/zh-CN/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/zh-CN/firefox-133.0b1.tar.bz2"; locale = "zh-CN"; arch = "linux-i686"; sha256 = "c4746b06cf2ebdba66d84c4a2e0cd62ff41cb5320f91542c98a315a1c0800492"; } - { url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/zh-TW/firefox-133.0b1.tar.bz2"; + { + url = "https://archive.mozilla.org/pub/devedition/releases/133.0b1/linux-i686/zh-TW/firefox-133.0b1.tar.bz2"; locale = "zh-TW"; arch = "linux-i686"; sha256 = "ce7e0872a09c86c1da689d68bc7eb4adcbdbfdc7d0a9e76ca48dafdb8ba6124f"; } - ]; + ]; } diff --git a/pkgs/applications/networking/browsers/firefox-bin/update.nix b/pkgs/applications/networking/browsers/firefox-bin/update.nix index 0e1c6241aae419..8d3ea28e46b389 100644 --- a/pkgs/applications/networking/browsers/firefox-bin/update.nix +++ b/pkgs/applications/networking/browsers/firefox-bin/update.nix @@ -1,25 +1,26 @@ -{ pname -, channel -, lib -, writeScript -, xidel -, coreutils -, gnused -, gnugrep -, curl -, gnupg -, runtimeShell -, baseName ? "firefox" -, basePath ? "pkgs/applications/networking/browsers/firefox-bin" -, baseUrl -, versionSuffix ? "" +{ + pname, + channel, + lib, + writeScript, + xidel, + coreutils, + gnused, + gnugrep, + curl, + gnupg, + runtimeShell, + baseName ? "firefox", + basePath ? "pkgs/applications/networking/browsers/firefox-bin", + baseUrl, + versionSuffix ? "", }: let - isBeta = - channel != "release"; + isBeta = channel != "release"; -in writeScript "update-${pname}" '' +in +writeScript "update-${pname}" '' #!${runtimeShell} PATH=${coreutils}/bin:${gnused}/bin:${gnugrep}/bin:${xidel}/bin:${curl}/bin:${gnupg}/bin set -eux @@ -48,7 +49,9 @@ in writeScript "update-${pname}" '' grep "^[0-9]" | \ sort --version-sort | \ grep -v "funnelcake" | \ - grep -e "${lib.optionalString isBeta "b"}\([[:digit:]]\|[[:digit:]][[:digit:]]\)${versionSuffix}$" | ${lib.optionalString (!isBeta) "grep -v \"b\" |"} \ + grep -e "${lib.optionalString isBeta "b"}\([[:digit:]]\|[[:digit:]][[:digit:]]\)${versionSuffix}$" | ${ + lib.optionalString (!isBeta) "grep -v \"b\" |" + } \ tail -1` curl --silent -o $HOME/shasums "$url$version/SHA256SUMS" diff --git a/pkgs/applications/networking/browsers/firefox/mobile-config.nix b/pkgs/applications/networking/browsers/firefox/mobile-config.nix index 7d97a2e97d684c..db88c093120145 100644 --- a/pkgs/applications/networking/browsers/firefox/mobile-config.nix +++ b/pkgs/applications/networking/browsers/firefox/mobile-config.nix @@ -1,4 +1,9 @@ -{ runCommand, fetchFromGitLab, wrapFirefox, firefox-unwrapped }: +{ + runCommand, + fetchFromGitLab, + wrapFirefox, + firefox-unwrapped, +}: let pkg = fetchFromGitLab { @@ -7,13 +12,14 @@ let rev = "ff2f07873f4ebc6e220da0e9b9f04c69f451edda"; sha256 = "sha256-8wRz8corz00+0qROMiOmZAddM4tjfmE91bx0+P8JNx4="; }; - userChrome = runCommand "userChrome.css" {} '' + userChrome = runCommand "userChrome.css" { } '' cat ${pkg}/src/userChrome/*.css > $out ''; - userContent = runCommand "userContent.css" {} '' + userContent = runCommand "userContent.css" { } '' cat ${pkg}/src/userContent/*.css > $out ''; -in wrapFirefox firefox-unwrapped { +in +wrapFirefox firefox-unwrapped { # extraPolicies = (lib.importJSON "${pkg}/src/policies.json").policies; extraPoliciesFiles = [ "${pkg}/src/policies.json" ]; extraPrefs = '' diff --git a/pkgs/applications/networking/browsers/firefox/update.nix b/pkgs/applications/networking/browsers/firefox/update.nix index 95820bc406c40b..14ccac13680771 100644 --- a/pkgs/applications/networking/browsers/firefox/update.nix +++ b/pkgs/applications/networking/browsers/firefox/update.nix @@ -1,23 +1,34 @@ -{ writeScript -, lib -, xidel -, common-updater-scripts -, coreutils -, gnused -, gnugrep -, curl -, gnupg -, attrPath -, runtimeShell -, baseUrl ? "https://archive.mozilla.org/pub/firefox/releases/" -, versionPrefix ? "" -, versionSuffix ? "" -, versionKey ? "version" +{ + writeScript, + lib, + xidel, + common-updater-scripts, + coreutils, + gnused, + gnugrep, + curl, + gnupg, + attrPath, + runtimeShell, + baseUrl ? "https://archive.mozilla.org/pub/firefox/releases/", + versionPrefix ? "", + versionSuffix ? "", + versionKey ? "version", }: writeScript "update-${attrPath}" '' #!${runtimeShell} - PATH=${lib.makeBinPath [ common-updater-scripts coreutils curl gnugrep gnupg gnused xidel ]} + PATH=${ + lib.makeBinPath [ + common-updater-scripts + coreutils + curl + gnugrep + gnupg + gnused + xidel + ] + } set -eux HOME=`mktemp -d` diff --git a/pkgs/applications/networking/browsers/kristall/default.nix b/pkgs/applications/networking/browsers/kristall/default.nix index f228c97306840b..ac6ac96c3faea0 100644 --- a/pkgs/applications/networking/browsers/kristall/default.nix +++ b/pkgs/applications/networking/browsers/kristall/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, wrapQtAppsHook, qmake, qtmultimedia }: +{ + lib, + stdenv, + fetchFromGitHub, + wrapQtAppsHook, + qmake, + qtmultimedia, +}: stdenv.mkDerivation rec { pname = "kristall"; @@ -15,27 +22,33 @@ stdenv.mkDerivation rec { sed -i '1i #include ' src/browsertab.cpp ''; - nativeBuildInputs = [ wrapQtAppsHook qmake ]; + nativeBuildInputs = [ + wrapQtAppsHook + qmake + ]; buildInputs = [ qtmultimedia ]; qmakeFlags = [ "src/kristall.pro" ]; - installPhase = if stdenv.hostPlatform.isDarwin then '' - mkdir -p $out/Applications - mv kristall.app $out/Applications - '' else '' - install -Dt $out/bin kristall - install -D Kristall.desktop $out/share/applications/net.random-projects.kristall.desktop - install -D src/icons/kristall.svg $out/share/icons/hicolor/scalable/apps/net.random-projects.kristall.svg - for size in 16 32 64 128; do - install -D src/icons/kristall-''${size}.png $out/share/icons/hicolor/''${size}x''${size}/apps/net.random-projects.kristall.png - done - ''; + installPhase = + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p $out/Applications + mv kristall.app $out/Applications + '' + else + '' + install -Dt $out/bin kristall + install -D Kristall.desktop $out/share/applications/net.random-projects.kristall.desktop + install -D src/icons/kristall.svg $out/share/icons/hicolor/scalable/apps/net.random-projects.kristall.svg + for size in 16 32 64 128; do + install -D src/icons/kristall-''${size}.png $out/share/icons/hicolor/''${size}x''${size}/apps/net.random-projects.kristall.png + done + ''; meta = with lib; { - description = - "Graphical small-internet client, supports gemini, http, https, gopher, finger"; + description = "Graphical small-internet client, supports gemini, http, https, gopher, finger"; mainProgram = "kristall"; homepage = "https://random-projects.net/projects/kristall.gemini"; maintainers = with maintainers; [ ehmry ]; diff --git a/pkgs/applications/networking/browsers/librewolf/default.nix b/pkgs/applications/networking/browsers/librewolf/default.nix index bcaa02cfa94897..df1ac6fa676f2f 100644 --- a/pkgs/applications/networking/browsers/librewolf/default.nix +++ b/pkgs/applications/networking/browsers/librewolf/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, callPackage, buildMozillaMach, nixosTests }: +{ + stdenv, + lib, + callPackage, + buildMozillaMach, + nixosTests, +}: let librewolf-src = callPackage ./librewolf.nix { }; @@ -12,15 +18,24 @@ in requireSigning = false; allowAddonSideload = true; branding = "browser/branding/librewolf"; - inherit (librewolf-src) extraConfigureFlags extraPatches extraPostPatch extraPassthru; + inherit (librewolf-src) + extraConfigureFlags + extraPatches + extraPostPatch + extraPassthru + ; meta = { description = "Fork of Firefox, focused on privacy, security and freedom"; homepage = "https://librewolf.net/"; - maintainers = with lib.maintainers; [ squalus dwrege ]; + maintainers = with lib.maintainers; [ + squalus + dwrege + ]; platforms = lib.platforms.unix; - broken = stdenv.buildPlatform.is32bit; # since Firefox 60, build on 32-bit platforms fails with "out of memory". - # not in `badPlatforms` because cross-compilation on 64-bit machine might work. + broken = stdenv.buildPlatform.is32bit; + # since Firefox 60, build on 32-bit platforms fails with "out of memory". + # not in `badPlatforms` because cross-compilation on 64-bit machine might work. maxSilent = 14400; # 4h, double the default of 7200s (c.f. #129212, #129115) license = lib.licenses.mpl20; mainProgram = "librewolf"; @@ -29,7 +44,8 @@ in updateScript = callPackage ./update.nix { attrPath = "librewolf-unwrapped"; }; -}).override { - crashreporterSupport = false; - enableOfficialBranding = false; -} +}).override + { + crashreporterSupport = false; + enableOfficialBranding = false; + } diff --git a/pkgs/applications/networking/browsers/librewolf/src.nix b/pkgs/applications/networking/browsers/librewolf/src.nix index fd5b1aaa1f2105..ead541fa36d61e 100644 --- a/pkgs/applications/networking/browsers/librewolf/src.nix +++ b/pkgs/applications/networking/browsers/librewolf/src.nix @@ -1,5 +1,10 @@ -{ lib, fetchurl, fetchFromGitea }: -let src = lib.importJSON ./src.json; +{ + lib, + fetchurl, + fetchFromGitea, +}: +let + src = lib.importJSON ./src.json; in { inherit (src) packageVersion; @@ -11,9 +16,7 @@ in inherit (src.source) rev sha256; }; firefox = fetchurl { - url = - "mirror://mozilla/firefox/releases/${src.firefox.version}/source/firefox-${src.firefox.version}.source.tar.xz"; + url = "mirror://mozilla/firefox/releases/${src.firefox.version}/source/firefox-${src.firefox.version}.source.tar.xz"; inherit (src.firefox) sha512; }; } - diff --git a/pkgs/applications/networking/browsers/librewolf/update.nix b/pkgs/applications/networking/browsers/librewolf/update.nix index f614509fba2866..33807902ea84a4 100644 --- a/pkgs/applications/networking/browsers/librewolf/update.nix +++ b/pkgs/applications/networking/browsers/librewolf/update.nix @@ -1,20 +1,32 @@ -{ writeScript -, lib -, coreutils -, gnused -, gnugrep -, curl -, gnupg -, jq -, nix-prefetch-git -, moreutils -, runtimeShell -, ... +{ + writeScript, + lib, + coreutils, + gnused, + gnugrep, + curl, + gnupg, + jq, + nix-prefetch-git, + moreutils, + runtimeShell, + ... }: writeScript "update-librewolf" '' #!${runtimeShell} - PATH=${lib.makeBinPath [ coreutils curl gnugrep gnupg gnused jq moreutils nix-prefetch-git ]} + PATH=${ + lib.makeBinPath [ + coreutils + curl + gnugrep + gnupg + gnused + jq + moreutils + nix-prefetch-git + ] + } set -euo pipefail latestTag=$(curl "https://codeberg.org/api/v1/repos/librewolf/source/tags?page=1&limit=1" | jq -r .[0].name) diff --git a/pkgs/applications/networking/browsers/misc/widevine-cdm.nix b/pkgs/applications/networking/browsers/misc/widevine-cdm.nix index ce68502c57c9ac..a5e7bc2f1b4024 100644 --- a/pkgs/applications/networking/browsers/misc/widevine-cdm.nix +++ b/pkgs/applications/networking/browsers/misc/widevine-cdm.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchzip +{ + lib, + stdenv, + fetchzip, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/networking/browsers/netsurf/browser.nix b/pkgs/applications/networking/browsers/netsurf/browser.nix index 760bd691dfb81e..6396009fd47a6e 100644 --- a/pkgs/applications/networking/browsers/netsurf/browser.nix +++ b/pkgs/applications/networking/browsers/netsurf/browser.nix @@ -1,47 +1,48 @@ -{ lib -, stdenv -, fetchurl -, SDL -, check -, curl -, expat -, gperf -, gtk2 -, gtk3 -, libXcursor -, libXrandr -, libidn -, libjpeg -, libjxl -, libpng -, libwebp -, libxml2 -, makeWrapper -, openssl -, perlPackages -, pkg-config -, wrapGAppsHook3 -, xxd - -# Netsurf-specific dependencies -, buildsystem -, libcss -, libdom -, libhubbub -, libnsbmp -, libnsfb -, libnsgif -, libnslog -, libnspsl -, libnsutils -, libparserutils -, libsvgtiny -, libutf8proc -, libwapcaplet -, nsgenbind - -# Configuration -, uilib +{ + lib, + stdenv, + fetchurl, + SDL, + check, + curl, + expat, + gperf, + gtk2, + gtk3, + libXcursor, + libXrandr, + libidn, + libjpeg, + libjxl, + libpng, + libwebp, + libxml2, + makeWrapper, + openssl, + perlPackages, + pkg-config, + wrapGAppsHook3, + xxd, + + # Netsurf-specific dependencies + buildsystem, + libcss, + libdom, + libhubbub, + libnsbmp, + libnsfb, + libnsgif, + libnslog, + libnspsl, + libnsutils, + libparserutils, + libsvgtiny, + libutf8proc, + libwapcaplet, + nsgenbind, + + # Configuration + uilib, }: stdenv.mkDerivation (finalAttrs: { @@ -59,42 +60,44 @@ stdenv.mkDerivation (finalAttrs: { perlPackages.perl pkg-config xxd - ] - ++ lib.optional (uilib == "gtk2" || uilib == "gtk3") wrapGAppsHook3; - - buildInputs = [ - check - curl - gperf - libXcursor - libXrandr - libidn - libjpeg - libjxl - libpng - libwebp - libxml2 - openssl - - libcss - libdom - libhubbub - libnsbmp - libnsfb - libnsgif - libnslog - libnspsl - libnsutils - libparserutils - libsvgtiny - libutf8proc - libwapcaplet - nsgenbind - ] - ++ lib.optionals (uilib == "framebuffer") [ expat SDL ] - ++ lib.optional (uilib == "gtk2") gtk2 - ++ lib.optional (uilib == "gtk3") gtk3 - ; + ] ++ lib.optional (uilib == "gtk2" || uilib == "gtk3") wrapGAppsHook3; + + buildInputs = + [ + check + curl + gperf + libXcursor + libXrandr + libidn + libjpeg + libjxl + libpng + libwebp + libxml2 + openssl + + libcss + libdom + libhubbub + libnsbmp + libnsfb + libnsgif + libnslog + libnspsl + libnsutils + libparserutils + libsvgtiny + libutf8proc + libwapcaplet + nsgenbind + ] + ++ lib.optionals (uilib == "framebuffer") [ + expat + SDL + ] + ++ lib.optional (uilib == "gtk2") gtk2 + ++ lib.optional (uilib == "gtk3") gtk3; # Since at least 2018 AD, GCC and other compilers run in `-fno-common` mode as # default, in order to comply with C standards and also get rid of some bad diff --git a/pkgs/applications/networking/browsers/netsurf/buildsystem.nix b/pkgs/applications/networking/browsers/netsurf/buildsystem.nix index 489bf7cd7e0290..12ce586c4de754 100644 --- a/pkgs/applications/networking/browsers/netsurf/buildsystem.nix +++ b/pkgs/applications/networking/browsers/netsurf/buildsystem.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/netsurf/default.nix b/pkgs/applications/networking/browsers/netsurf/default.nix index 36bfe10d5d2404..11f9742975a60a 100644 --- a/pkgs/applications/networking/browsers/netsurf/default.nix +++ b/pkgs/applications/networking/browsers/netsurf/default.nix @@ -1,39 +1,46 @@ { lib, pkgs }: -lib.makeScope pkgs.newScope (self: +lib.makeScope pkgs.newScope ( + self: let inherit (self) callPackage; - in { - # ui can be: gtk2, gtk3, sixel, framebuffer. Note that console display (sixel) - # requires a terminal that supports `sixel` capabilities, such as mlterm - # or xterm -ti 340 - ui = "gtk3"; - uilib = { - "framebuffer" = "framebuffer"; - "gtk2" = "gtk2"; - "gtk3" = "gtk3"; - "sixel" = "framebuffer"; - }.${self.ui} or null; # Null will never happen - SDL = { - "sixel" = pkgs.SDL_sixel; - "framebuffer" = pkgs.SDL; - }.${self.ui} or null; + in + { + # ui can be: gtk2, gtk3, sixel, framebuffer. Note that console display (sixel) + # requires a terminal that supports `sixel` capabilities, such as mlterm + # or xterm -ti 340 + ui = "gtk3"; + uilib = + { + "framebuffer" = "framebuffer"; + "gtk2" = "gtk2"; + "gtk3" = "gtk3"; + "sixel" = "framebuffer"; + } + .${self.ui} or null; # Null will never happen + SDL = + { + "sixel" = pkgs.SDL_sixel; + "framebuffer" = pkgs.SDL; + } + .${self.ui} or null; - browser = callPackage ./browser.nix { }; + browser = callPackage ./browser.nix { }; - buildsystem = callPackage ./buildsystem.nix { }; - libcss = callPackage ./libcss.nix { }; - libdom = callPackage ./libdom.nix { }; - libhubbub = callPackage ./libhubbub.nix { }; - libnsbmp = callPackage ./libnsbmp.nix { }; - libnsfb = callPackage ./libnsfb.nix { }; - libnsgif = callPackage ./libnsgif.nix { }; - libnslog = callPackage ./libnslog.nix { }; - libnspsl = callPackage ./libnspsl.nix { }; - libnsutils = callPackage ./libnsutils.nix { }; - libparserutils = callPackage ./libparserutils.nix { }; - libsvgtiny = callPackage ./libsvgtiny.nix { }; - libutf8proc = callPackage ./libutf8proc.nix { }; - libwapcaplet = callPackage ./libwapcaplet.nix { }; - nsgenbind = callPackage ./nsgenbind.nix { }; -}) + buildsystem = callPackage ./buildsystem.nix { }; + libcss = callPackage ./libcss.nix { }; + libdom = callPackage ./libdom.nix { }; + libhubbub = callPackage ./libhubbub.nix { }; + libnsbmp = callPackage ./libnsbmp.nix { }; + libnsfb = callPackage ./libnsfb.nix { }; + libnsgif = callPackage ./libnsgif.nix { }; + libnslog = callPackage ./libnslog.nix { }; + libnspsl = callPackage ./libnspsl.nix { }; + libnsutils = callPackage ./libnsutils.nix { }; + libparserutils = callPackage ./libparserutils.nix { }; + libsvgtiny = callPackage ./libsvgtiny.nix { }; + libutf8proc = callPackage ./libutf8proc.nix { }; + libwapcaplet = callPackage ./libwapcaplet.nix { }; + nsgenbind = callPackage ./nsgenbind.nix { }; + } +) diff --git a/pkgs/applications/networking/browsers/netsurf/libcss.nix b/pkgs/applications/networking/browsers/netsurf/libcss.nix index 4b54f013449b7a..c6c1de45fe7593 100644 --- a/pkgs/applications/networking/browsers/netsurf/libcss.nix +++ b/pkgs/applications/networking/browsers/netsurf/libcss.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, perl -, pkg-config -, buildsystem -, libparserutils -, libwapcaplet +{ + lib, + stdenv, + fetchurl, + perl, + pkg-config, + buildsystem, + libparserutils, + libwapcaplet, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/netsurf/libdom.nix b/pkgs/applications/networking/browsers/netsurf/libdom.nix index 2f198021fafbb2..015b5cec032138 100644 --- a/pkgs/applications/networking/browsers/netsurf/libdom.nix +++ b/pkgs/applications/networking/browsers/netsurf/libdom.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, expat -, pkg-config -, buildsystem -, libparserutils -, libwapcaplet -, libhubbub +{ + lib, + stdenv, + fetchurl, + expat, + pkg-config, + buildsystem, + libparserutils, + libwapcaplet, + libhubbub, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/netsurf/libhubbub.nix b/pkgs/applications/networking/browsers/netsurf/libhubbub.nix index 5847fd21d2ae87..85a086702a4de0 100644 --- a/pkgs/applications/networking/browsers/netsurf/libhubbub.nix +++ b/pkgs/applications/networking/browsers/netsurf/libhubbub.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, gperf -, perl -, pkg-config -, buildsystem -, libparserutils +{ + lib, + stdenv, + fetchurl, + gperf, + perl, + pkg-config, + buildsystem, + libparserutils, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/netsurf/libnsbmp.nix b/pkgs/applications/networking/browsers/netsurf/libnsbmp.nix index a0c1cf1062883e..59c37ef3869ec7 100644 --- a/pkgs/applications/networking/browsers/netsurf/libnsbmp.nix +++ b/pkgs/applications/networking/browsers/netsurf/libnsbmp.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, buildsystem +{ + lib, + stdenv, + fetchurl, + pkg-config, + buildsystem, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/netsurf/libnsfb.nix b/pkgs/applications/networking/browsers/netsurf/libnsfb.nix index 079e351ab18a86..7faf219e855bf3 100644 --- a/pkgs/applications/networking/browsers/netsurf/libnsfb.nix +++ b/pkgs/applications/networking/browsers/netsurf/libnsfb.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, SDL -, pkg-config -, buildsystem -, uilib +{ + lib, + stdenv, + fetchurl, + SDL, + pkg-config, + buildsystem, + uilib, }: stdenv.mkDerivation (finalAttrs: { @@ -18,7 +19,10 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ SDL buildsystem ]; + buildInputs = [ + SDL + buildsystem + ]; makeFlags = [ "PREFIX=$(out)" diff --git a/pkgs/applications/networking/browsers/netsurf/libnsgif.nix b/pkgs/applications/networking/browsers/netsurf/libnsgif.nix index 0f57939e17007d..1a4b2dcaebb7de 100644 --- a/pkgs/applications/networking/browsers/netsurf/libnsgif.nix +++ b/pkgs/applications/networking/browsers/netsurf/libnsgif.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, buildPackages -, buildsystem +{ + lib, + stdenv, + fetchurl, + pkg-config, + buildPackages, + buildsystem, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/netsurf/libnslog.nix b/pkgs/applications/networking/browsers/netsurf/libnslog.nix index f9243ec5688883..c7cff75ecd06b7 100644 --- a/pkgs/applications/networking/browsers/netsurf/libnslog.nix +++ b/pkgs/applications/networking/browsers/netsurf/libnslog.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, bison -, flex -, pkg-config -, buildsystem +{ + lib, + stdenv, + fetchurl, + bison, + flex, + pkg-config, + buildsystem, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/netsurf/libnspsl.nix b/pkgs/applications/networking/browsers/netsurf/libnspsl.nix index 30c91908d9f37d..3b07876961fa3b 100644 --- a/pkgs/applications/networking/browsers/netsurf/libnspsl.nix +++ b/pkgs/applications/networking/browsers/netsurf/libnspsl.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, buildsystem +{ + lib, + stdenv, + fetchurl, + pkg-config, + buildsystem, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/netsurf/libnsutils.nix b/pkgs/applications/networking/browsers/netsurf/libnsutils.nix index 141117a94f7099..d72cbc6eec27f6 100644 --- a/pkgs/applications/networking/browsers/netsurf/libnsutils.nix +++ b/pkgs/applications/networking/browsers/netsurf/libnsutils.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, buildsystem +{ + lib, + stdenv, + fetchurl, + pkg-config, + buildsystem, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/netsurf/libparserutils.nix b/pkgs/applications/networking/browsers/netsurf/libparserutils.nix index 73c8448f2604dd..55bc05cbbf1176 100644 --- a/pkgs/applications/networking/browsers/netsurf/libparserutils.nix +++ b/pkgs/applications/networking/browsers/netsurf/libparserutils.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, perl -, buildsystem -, libiconv +{ + lib, + stdenv, + fetchurl, + perl, + buildsystem, + libiconv, }: stdenv.mkDerivation (finalAttrs: { @@ -15,12 +16,14 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-MX7VxxjxeSe1chl0uuXeMsP9bQVdsTGtMbQxKgMu0Tk="; }; - buildInputs = [ - perl - buildsystem - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - ]; + buildInputs = + [ + perl + buildsystem + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + ]; makeFlags = [ "PREFIX=$(out)" diff --git a/pkgs/applications/networking/browsers/netsurf/libsvgtiny.nix b/pkgs/applications/networking/browsers/netsurf/libsvgtiny.nix index a672a7b7cde9da..bcdc561da2d196 100644 --- a/pkgs/applications/networking/browsers/netsurf/libsvgtiny.nix +++ b/pkgs/applications/networking/browsers/netsurf/libsvgtiny.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, gperf -, pkg-config -, buildsystem -, libdom -, libhubbub -, libparserutils -, libwapcaplet +{ + lib, + stdenv, + fetchurl, + gperf, + pkg-config, + buildsystem, + libdom, + libhubbub, + libparserutils, + libwapcaplet, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/netsurf/libutf8proc.nix b/pkgs/applications/networking/browsers/netsurf/libutf8proc.nix index adbd138b2260fb..9740911160f35f 100644 --- a/pkgs/applications/networking/browsers/netsurf/libutf8proc.nix +++ b/pkgs/applications/networking/browsers/netsurf/libutf8proc.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, buildsystem +{ + lib, + stdenv, + fetchurl, + pkg-config, + buildsystem, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/netsurf/libwapcaplet.nix b/pkgs/applications/networking/browsers/netsurf/libwapcaplet.nix index 01c1b6c67f3a9f..6f783a35f7eeca 100644 --- a/pkgs/applications/networking/browsers/netsurf/libwapcaplet.nix +++ b/pkgs/applications/networking/browsers/netsurf/libwapcaplet.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, buildsystem +{ + lib, + stdenv, + fetchurl, + buildsystem, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/netsurf/nsgenbind.nix b/pkgs/applications/networking/browsers/netsurf/nsgenbind.nix index 0ad77b07ca4066..efd68a30571fab 100644 --- a/pkgs/applications/networking/browsers/netsurf/nsgenbind.nix +++ b/pkgs/applications/networking/browsers/netsurf/nsgenbind.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, bison -, flex -, buildsystem +{ + lib, + stdenv, + fetchurl, + bison, + flex, + buildsystem, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/browsers/nyxt/default.nix b/pkgs/applications/networking/browsers/nyxt/default.nix index 6ff4976f00c8b7..5c1d3a610e8db5 100644 --- a/pkgs/applications/networking/browsers/nyxt/default.nix +++ b/pkgs/applications/networking/browsers/nyxt/default.nix @@ -1,32 +1,33 @@ -{ stdenv -, lib -, testers -, wrapGAppsHook3 -, fetchzip -, sbcl -, pkg-config -, libfixposix -, gobject-introspection -, gsettings-desktop-schemas -, glib-networking -, notify-osd -, gtk3 -, glib -, gdk-pixbuf -, cairo -, pango -, webkitgtk_4_0 -, openssl -, gstreamer -, gst-libav -, gst-plugins-base -, gst-plugins-good -, gst-plugins-bad -, gst-plugins-ugly -, xdg-utils -, xclip -, wl-clipboard -, nix-update-script +{ + stdenv, + lib, + testers, + wrapGAppsHook3, + fetchzip, + sbcl, + pkg-config, + libfixposix, + gobject-introspection, + gsettings-desktop-schemas, + glib-networking, + notify-osd, + gtk3, + glib, + gdk-pixbuf, + cairo, + pango, + webkitgtk_4_0, + openssl, + gstreamer, + gst-libav, + gst-plugins-base, + gst-plugins-good, + gst-plugins-bad, + gst-plugins-ugly, + xdg-utils, + xclip, + wl-clipboard, + nix-update-script, }: stdenv.mkDerivation (finalAttrs: { @@ -44,7 +45,8 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ sbcl # for groveller - pkg-config libfixposix + pkg-config + libfixposix # for gappsWrapper gobject-introspection gsettings-desktop-schemas @@ -80,11 +82,20 @@ stdenv.mkDerivation (finalAttrs: { ''; # don't refresh from git - makeFlags = [ "all" "NYXT_SUBMODULES=false" ]; + makeFlags = [ + "all" + "NYXT_SUBMODULES=false" + ]; preFixup = '' gappsWrapperArgs+=(--prefix LD_LIBRARY_PATH : "$LD_LIBRARY_PATH") - gappsWrapperArgs+=(--prefix PATH : "${lib.makeBinPath [ xdg-utils xclip wl-clipboard ]}") + gappsWrapperArgs+=(--prefix PATH : "${ + lib.makeBinPath [ + xdg-utils + xclip + wl-clipboard + ] + }") ''; # prevent corrupting core in exe @@ -100,7 +111,10 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "nyxt"; homepage = "https://nyxt.atlas.engineer"; license = licenses.bsd3; - maintainers = with maintainers; [ lewo dariof4 ]; + maintainers = with maintainers; [ + lewo + dariof4 + ]; platforms = platforms.all; }; }) diff --git a/pkgs/applications/networking/browsers/palemoon/bin.nix b/pkgs/applications/networking/browsers/palemoon/bin.nix index 07b2b804943195..637672bef5955d 100644 --- a/pkgs/applications/networking/browsers/palemoon/bin.nix +++ b/pkgs/applications/networking/browsers/palemoon/bin.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchzip -, alsa-lib -, autoPatchelfHook -, copyDesktopItems -, dbus-glib -, ffmpeg -, gtk2-x11 -, withGTK3 ? true -, gtk3 -, libglvnd -, libXt -, libpulseaudio -, makeDesktopItem -, wrapGAppsHook3 -, writeScript -, testers +{ + stdenv, + lib, + fetchzip, + alsa-lib, + autoPatchelfHook, + copyDesktopItems, + dbus-glib, + ffmpeg, + gtk2-x11, + withGTK3 ? true, + gtk3, + libglvnd, + libXt, + libpulseaudio, + makeDesktopItem, + wrapGAppsHook3, + writeScript, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -34,76 +35,80 @@ stdenv.mkDerivation (finalAttrs: { wrapGAppsHook3 ]; - buildInputs = [ - alsa-lib - dbus-glib - gtk2-x11 - libXt - (lib.getLib stdenv.cc.cc) - ] ++ lib.optionals withGTK3 [ - gtk3 - ]; - - desktopItems = [(makeDesktopItem rec { - name = "palemoon-bin"; - desktopName = "Pale Moon Web Browser"; - comment = "Browse the World Wide Web"; - keywords = [ - "Internet" - "WWW" - "Browser" - "Web" - "Explorer" - ]; - exec = "palemoon %u"; - terminal = false; - type = "Application"; - icon = "palemoon"; - categories = [ - "Network" - "WebBrowser" - ]; - mimeTypes = [ - "text/html" - "text/xml" - "application/xhtml+xml" - "application/xml" - "application/rss+xml" - "application/rdf+xml" - "image/gif" - "image/jpeg" - "image/png" - "x-scheme-handler/http" - "x-scheme-handler/https" - "x-scheme-handler/ftp" - "x-scheme-handler/chrome" - "video/webm" - "application/x-xpinstall" + buildInputs = + [ + alsa-lib + dbus-glib + gtk2-x11 + libXt + (lib.getLib stdenv.cc.cc) + ] + ++ lib.optionals withGTK3 [ + gtk3 ]; - startupNotify = true; - startupWMClass = "Pale moon"; - extraConfig = { - X-MultipleArgs = "false"; - }; - actions = { - "NewTab" = { - name = "Open new tab"; - exec = "palemoon -new-tab https://start.palemoon.org"; - }; - "NewWindow" = { - name = "Open new window"; - exec = "palemoon -new-window"; - }; - "NewPrivateWindow" = { - name = "Open new private window"; - exec = "palemoon -private-window"; + + desktopItems = [ + (makeDesktopItem rec { + name = "palemoon-bin"; + desktopName = "Pale Moon Web Browser"; + comment = "Browse the World Wide Web"; + keywords = [ + "Internet" + "WWW" + "Browser" + "Web" + "Explorer" + ]; + exec = "palemoon %u"; + terminal = false; + type = "Application"; + icon = "palemoon"; + categories = [ + "Network" + "WebBrowser" + ]; + mimeTypes = [ + "text/html" + "text/xml" + "application/xhtml+xml" + "application/xml" + "application/rss+xml" + "application/rdf+xml" + "image/gif" + "image/jpeg" + "image/png" + "x-scheme-handler/http" + "x-scheme-handler/https" + "x-scheme-handler/ftp" + "x-scheme-handler/chrome" + "video/webm" + "application/x-xpinstall" + ]; + startupNotify = true; + startupWMClass = "Pale moon"; + extraConfig = { + X-MultipleArgs = "false"; }; - "ProfileManager" = { - name = "Open the Profile Manager"; - exec = "palemoon --ProfileManager"; + actions = { + "NewTab" = { + name = "Open new tab"; + exec = "palemoon -new-tab https://start.palemoon.org"; + }; + "NewWindow" = { + name = "Open new window"; + exec = "palemoon -new-window"; + }; + "NewPrivateWindow" = { + name = "Open new private window"; + exec = "palemoon -private-window"; + }; + "ProfileManager" = { + name = "Open the Profile Manager"; + exec = "palemoon --ProfileManager"; + }; }; - }; - })]; + }) + ]; dontConfigure = true; dontBuild = true; @@ -138,33 +143,42 @@ stdenv.mkDerivation (finalAttrs: { preFixup = '' # Make optional dependencies available gappsWrapperArgs+=( - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ - ffmpeg - libglvnd - libpulseaudio - ]}" + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + ffmpeg + libglvnd + libpulseaudio + ] + }" ) wrapGApp $out/lib/palemoon/palemoon ''; passthru = { - sources = let - urlRegionVariants = buildVariant: map - (region: "https://rm-${region}.palemoon.org/release/palemoon-${finalAttrs.version}.linux-x86_64-${buildVariant}.tar.xz") - [ - "eu" - "us" - ]; - in { - gtk3 = fetchzip { - urls = urlRegionVariants "gtk3"; - hash = "sha256-TlmDsZKHolTS+y+1BymyY49+AvqUv8zmUXCGNHCRPL0="; - }; - gtk2 = fetchzip { - urls = urlRegionVariants "gtk2"; - hash = "sha256-f6vLHbpmvVfkjZr7x0DiCFoGGvfxHfFZ3KTagq2Mwp4="; + sources = + let + urlRegionVariants = + buildVariant: + map + ( + region: + "https://rm-${region}.palemoon.org/release/palemoon-${finalAttrs.version}.linux-x86_64-${buildVariant}.tar.xz" + ) + [ + "eu" + "us" + ]; + in + { + gtk3 = fetchzip { + urls = urlRegionVariants "gtk3"; + hash = "sha256-TlmDsZKHolTS+y+1BymyY49+AvqUv8zmUXCGNHCRPL0="; + }; + gtk2 = fetchzip { + urls = urlRegionVariants "gtk2"; + hash = "sha256-f6vLHbpmvVfkjZr7x0DiCFoGGvfxHfFZ3KTagq2Mwp4="; + }; }; - }; tests.version = testers.testVersion { package = finalAttrs.finalPackage; @@ -216,6 +230,6 @@ stdenv.mkDerivation (finalAttrs: { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; mainProgram = "palemoon"; platforms = [ "x86_64-linux" ]; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; }) diff --git a/pkgs/applications/networking/browsers/qtchan/default.nix b/pkgs/applications/networking/browsers/qtchan/default.nix index eb2e9789caa561..3e266f5f8712f0 100644 --- a/pkgs/applications/networking/browsers/qtchan/default.nix +++ b/pkgs/applications/networking/browsers/qtchan/default.nix @@ -1,13 +1,19 @@ -{ mkDerivation, lib, fetchFromGitHub, qmake, qtbase }: +{ + mkDerivation, + lib, + fetchFromGitHub, + qmake, + qtbase, +}: mkDerivation rec { pname = "qtchan"; version = "1.0.1"; src = fetchFromGitHub { - owner = "siavash119"; - repo = "qtchan"; - rev = "v${version}"; + owner = "siavash119"; + repo = "qtchan"; + rev = "v${version}"; sha256 = "1x11m1kwqindzc0dkpfifcglsb362impaxs85kgzx50p898sz9ll"; }; @@ -23,9 +29,9 @@ mkDerivation rec { meta = with lib; { description = "4chan browser in qt5"; mainProgram = "qtchan"; - homepage = "https://github.com/siavash119/qtchan"; - license = licenses.mit; + homepage = "https://github.com/siavash119/qtchan"; + license = licenses.mit; maintainers = with maintainers; [ Madouura ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/applications/networking/browsers/qutebrowser/default.nix b/pkgs/applications/networking/browsers/qutebrowser/default.nix index 0586d6cc5fc9d1..f0f0800b2ae4ea 100644 --- a/pkgs/applications/networking/browsers/qutebrowser/default.nix +++ b/pkgs/applications/networking/browsers/qutebrowser/default.nix @@ -1,30 +1,40 @@ -{ stdenv, lib, fetchurl, fetchzip, python3 -, wrapQtAppsHook, glib-networking -, asciidoc, docbook_xml_dtd_45, docbook_xsl, libxml2 -, libxslt -, withPdfReader ? true -, pipewireSupport ? stdenv.hostPlatform.isLinux -, pipewire -, qtwayland -, qtbase -, qtwebengine -, enableWideVine ? false -, widevine-cdm -# can cause issues on some graphics chips -, enableVulkan ? false -, vulkan-loader +{ + stdenv, + lib, + fetchurl, + fetchzip, + python3, + wrapQtAppsHook, + glib-networking, + asciidoc, + docbook_xml_dtd_45, + docbook_xsl, + libxml2, + libxslt, + withPdfReader ? true, + pipewireSupport ? stdenv.hostPlatform.isLinux, + pipewire, + qtwayland, + qtbase, + qtwebengine, + enableWideVine ? false, + widevine-cdm, + # can cause issues on some graphics chips + enableVulkan ? false, + vulkan-loader, }: let isQt6 = lib.versions.major qtbase.version == "6"; - pdfjs = let - version = "4.2.67"; - in - fetchzip { - url = "https://github.com/mozilla/pdf.js/releases/download/v${version}/pdfjs-${version}-dist.zip"; - hash = "sha256-7kfT3+ZwoGqZ5OwkO9h3DIuBFd0v8fRlcufxoBdcy8c="; - stripRoot = false; - }; + pdfjs = + let + version = "4.2.67"; + in + fetchzip { + url = "https://github.com/mozilla/pdf.js/releases/download/v${version}/pdfjs-${version}-dist.zip"; + hash = "sha256-7kfT3+ZwoGqZ5OwkO9h3DIuBFd0v8fRlcufxoBdcy8c="; + stripRoot = false; + }; version = "3.3.1"; in @@ -42,28 +52,39 @@ python3.pkgs.buildPythonApplication { # Needs tox doCheck = false; - buildInputs = [ - qtbase - glib-networking - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qtwayland - ]; + buildInputs = + [ + qtbase + glib-networking + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qtwayland + ]; build-system = with python3.pkgs; [ setuptools ]; nativeBuildInputs = [ - wrapQtAppsHook asciidoc - docbook_xml_dtd_45 docbook_xsl libxml2 libxslt + wrapQtAppsHook + asciidoc + docbook_xml_dtd_45 + docbook_xsl + libxml2 + libxslt ]; dependencies = with python3.pkgs; [ colorama - pyyaml (if isQt6 then pyqt6-webengine else pyqtwebengine) jinja2 pygments + pyyaml + (if isQt6 then pyqt6-webengine else pyqtwebengine) + jinja2 + pygments # scripts and userscripts libs - tldextract beautifulsoup4 - readability-lxml pykeepass + tldextract + beautifulsoup4 + readability-lxml + pykeepass stem pynacl # extensive ad blocking @@ -72,20 +93,21 @@ python3.pkgs.buildPythonApplication { pyperclip ]; - patches = [ ./fix-restart.patch ]; dontWrapQtApps = true; - postPatch = '' - substituteInPlace qutebrowser/misc/quitter.py --subst-var-by qutebrowser "$out/bin/qutebrowser" + postPatch = + '' + substituteInPlace qutebrowser/misc/quitter.py --subst-var-by qutebrowser "$out/bin/qutebrowser" - sed -i "s,/usr,$out,g" qutebrowser/utils/standarddir.py - '' + lib.optionalString withPdfReader '' - sed -i "s,/usr/share/pdf.js,${pdfjs},g" qutebrowser/browser/pdfjs.py - ''; + sed -i "s,/usr,$out,g" qutebrowser/utils/standarddir.py + '' + + lib.optionalString withPdfReader '' + sed -i "s,/usr/share/pdf.js,${pdfjs},g" qutebrowser/browser/pdfjs.py + ''; installPhase = '' runHook preInstall @@ -109,33 +131,40 @@ python3.pkgs.buildPythonApplication { done ''; - preFixup = let - libPath = lib.makeLibraryPath [ pipewire ]; - in + preFixup = + let + libPath = lib.makeLibraryPath [ pipewire ]; + in '' - makeWrapperArgs+=( - # Force the app to use QT_PLUGIN_PATH values from wrapper - --unset QT_PLUGIN_PATH - "''${qtWrapperArgs[@]}" - # avoid persistant warning on starup - --set QT_STYLE_OVERRIDE Fusion - ${lib.optionalString pipewireSupport ''--prefix LD_LIBRARY_PATH : ${libPath}''} - ${lib.optionalString (enableVulkan) '' - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [vulkan-loader]} - --set-default QSG_RHI_BACKEND vulkan - ''} - ${lib.optionalString enableWideVine ''--add-flags "--qt-flag widevine-path=${widevine-cdm}/share/google/chrome/WidevineCdm/_platform_specific/linux_x64/libwidevinecdm.so"''} - --set QTWEBENGINE_RESOURCES_PATH "${qtwebengine}/resources" - ) - ''; + makeWrapperArgs+=( + # Force the app to use QT_PLUGIN_PATH values from wrapper + --unset QT_PLUGIN_PATH + "''${qtWrapperArgs[@]}" + # avoid persistant warning on starup + --set QT_STYLE_OVERRIDE Fusion + ${lib.optionalString pipewireSupport ''--prefix LD_LIBRARY_PATH : ${libPath}''} + ${lib.optionalString (enableVulkan) '' + --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ vulkan-loader ]} + --set-default QSG_RHI_BACKEND vulkan + ''} + ${lib.optionalString enableWideVine ''--add-flags "--qt-flag widevine-path=${widevine-cdm}/share/google/chrome/WidevineCdm/_platform_specific/linux_x64/libwidevinecdm.so"''} + --set QTWEBENGINE_RESOURCES_PATH "${qtwebengine}/resources" + ) + ''; meta = with lib; { - homepage = "https://github.com/qutebrowser/qutebrowser"; - changelog = "https://github.com/qutebrowser/qutebrowser/blob/v${version}/doc/changelog.asciidoc"; + homepage = "https://github.com/qutebrowser/qutebrowser"; + changelog = "https://github.com/qutebrowser/qutebrowser/blob/v${version}/doc/changelog.asciidoc"; description = "Keyboard-focused browser with a minimal GUI"; - license = licenses.gpl3Plus; + license = licenses.gpl3Plus; mainProgram = "qutebrowser"; - platforms = if enableWideVine then [ "x86_64-linux" ] else qtwebengine.meta.platforms; - maintainers = with maintainers; [ jagajaga rnhmjoj ebzzry dotlambda nrdxp ]; + platforms = if enableWideVine then [ "x86_64-linux" ] else qtwebengine.meta.platforms; + maintainers = with maintainers; [ + jagajaga + rnhmjoj + ebzzry + dotlambda + nrdxp + ]; }; } diff --git a/pkgs/applications/networking/browsers/vivaldi/ffmpeg-codecs.nix b/pkgs/applications/networking/browsers/vivaldi/ffmpeg-codecs.nix index dafc914c1ac277..0872fd859b201f 100644 --- a/pkgs/applications/networking/browsers/vivaldi/ffmpeg-codecs.nix +++ b/pkgs/applications/networking/browsers/vivaldi/ffmpeg-codecs.nix @@ -1,4 +1,9 @@ -{ squashfsTools, fetchurl, lib, stdenv }: +{ + squashfsTools, + fetchurl, + lib, + stdenv, +}: # This derivation roughly follows the update-ffmpeg script that ships with the official Vivaldi # downloads at https://vivaldi.com/download/ @@ -23,10 +28,14 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Additional support for proprietary codecs for Vivaldi"; - homepage = "https://ffmpeg.org/"; + homepage = "https://ffmpeg.org/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.lgpl21; - maintainers = with maintainers; [ betaboon cawilliamson fptje ]; - platforms = [ "x86_64-linux" ]; + license = licenses.lgpl21; + maintainers = with maintainers; [ + betaboon + cawilliamson + fptje + ]; + platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/applications/networking/browsers/webmacs/default.nix b/pkgs/applications/networking/browsers/webmacs/default.nix index dc8b89ac1df78c..fbec74002d1f8d 100644 --- a/pkgs/applications/networking/browsers/webmacs/default.nix +++ b/pkgs/applications/networking/browsers/webmacs/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, mkDerivationWith -, fetchFromGitHub -, python3Packages -, herbstluftwm +{ + lib, + stdenv, + mkDerivationWith, + fetchFromGitHub, + python3Packages, + herbstluftwm, }: mkDerivationWith python3Packages.buildPythonApplication rec { @@ -47,7 +48,7 @@ mkDerivationWith python3Packages.buildPythonApplication rec { # See https://github.com/parkouss/webmacs/blob/1a04fb7bd3f33d39cb4d71621b48c2458712ed39/setup.py#L32 # Don't know why they're using CC for g++. preConfigure = '' - export CC=$CXX + export CC=$CXX ''; doCheck = false; # test dependencies not packaged up yet diff --git a/pkgs/applications/networking/charles/default.nix b/pkgs/applications/networking/charles/default.nix index 27c5ebf9e9c0f4..a76be42cf11216 100644 --- a/pkgs/applications/networking/charles/default.nix +++ b/pkgs/applications/networking/charles/default.nix @@ -1,40 +1,57 @@ -{ lib -, stdenv -, makeWrapper -, makeDesktopItem -, fetchurl -, jdk11 -, jdk8 +{ + lib, + stdenv, + makeWrapper, + makeDesktopItem, + fetchurl, + jdk11, + jdk8, }: let - generic = { version, sha256, platform ? "", jdk, ... }@attrs: - let - desktopItem = makeDesktopItem { - categories = [ "Network" "Development" "WebDevelopment" "Java" ]; - desktopName = "Charles"; - exec = "charles %F"; - genericName = "Web Debugging Proxy"; - icon = "charles-proxy"; - mimeTypes = [ - "application/x-charles-savedsession" - "application/x-charles-savedsession+xml" - "application/x-charles-savedsession+json" - "application/har+json" - "application/vnd.tcpdump.pcap" - "application/x-charles-trace" - ]; - name = "Charles"; - startupNotify = true; - }; + generic = + { + version, + sha256, + platform ? "", + jdk, + ... + }@attrs: + let + desktopItem = makeDesktopItem { + categories = [ + "Network" + "Development" + "WebDevelopment" + "Java" + ]; + desktopName = "Charles"; + exec = "charles %F"; + genericName = "Web Debugging Proxy"; + icon = "charles-proxy"; + mimeTypes = [ + "application/x-charles-savedsession" + "application/x-charles-savedsession+xml" + "application/x-charles-savedsession+json" + "application/har+json" + "application/vnd.tcpdump.pcap" + "application/x-charles-trace" + ]; + name = "Charles"; + startupNotify = true; + }; - in stdenv.mkDerivation { + in + stdenv.mkDerivation { pname = "charles"; inherit version; src = fetchurl { url = "https://www.charlesproxy.com/assets/release/${version}/charles-proxy-${version}${platform}.tar.gz"; - curlOptsList = [ "--user-agent" "Mozilla/5.0" ]; # HTTP 104 otherwise + curlOptsList = [ + "--user-agent" + "Mozilla/5.0" + ]; # HTTP 104 otherwise inherit sha256; }; nativeBuildInputs = [ makeWrapper ]; @@ -57,24 +74,32 @@ let meta = with lib; { description = "Web Debugging Proxy"; homepage = "https://www.charlesproxy.com/"; - maintainers = with maintainers; [ kalbasit kashw2 ]; + maintainers = with maintainers; [ + kalbasit + kashw2 + ]; sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.unfree; platforms = platforms.unix; }; }; -in { - charles4 = (generic { - version = "4.6.4"; - sha256 = "KEQYb90kt41dS3TJLZqdaV9P3mQA9UPsEyiFb/knm3w="; - platform = "_amd64"; - jdk = jdk11; - }); - charles3 = (generic { - version = "3.12.3"; - sha256 = "13zk82ny1w5zd9qcs9qkq0kdb22ni5byzajyshpxdfm4zv6p32ss"; - jdk = jdk8.jre; - mainProgram = "charles"; - }); +in +{ + charles4 = ( + generic { + version = "4.6.4"; + sha256 = "KEQYb90kt41dS3TJLZqdaV9P3mQA9UPsEyiFb/knm3w="; + platform = "_amd64"; + jdk = jdk11; + } + ); + charles3 = ( + generic { + version = "3.12.3"; + sha256 = "13zk82ny1w5zd9qcs9qkq0kdb22ni5byzajyshpxdfm4zv6p32ss"; + jdk = jdk8.jre; + mainProgram = "charles"; + } + ); } diff --git a/pkgs/applications/networking/cloudflared/tests.nix b/pkgs/applications/networking/cloudflared/tests.nix index 8314e84075fd28..c1c081c0a503bc 100644 --- a/pkgs/applications/networking/cloudflared/tests.nix +++ b/pkgs/applications/networking/cloudflared/tests.nix @@ -1,4 +1,14 @@ -{ version, lib, stdenv, pkgsCross, testers, cloudflared, runCommand, wine, wine64 }: +{ + version, + lib, + stdenv, + pkgsCross, + testers, + cloudflared, + runCommand, + wine, + wine64, +}: let inherit (stdenv) buildPlatform; @@ -8,37 +18,45 @@ in package = cloudflared; command = "cloudflared help"; }; - refuses-to-autoupdate = runCommand "cloudflared-${version}-refuses-to-autoupdate" - { - nativeBuildInputs = [ cloudflared ]; - } '' - set -e - cloudflared update 2>&1 | tee output.txt - if ! grep "cloudflared was installed by nixpkgs" output.txt - then - echo "cloudflared's output didn't contain the package manager name" - exit 1 - fi - mkdir $out - ''; -} // lib.optionalAttrs (buildPlatform.isLinux && (buildPlatform.isi686 || buildPlatform.isx86_64)) { - runs-through-wine = runCommand "cloudflared-${version}-runs-through-wine" - { - nativeBuildInputs = [ wine ]; - exe = "${pkgsCross.mingw32.cloudflared}/bin/cloudflared.exe"; - } '' - export HOME="$(mktemp -d)" - wine $exe help - mkdir $out - ''; -} // lib.optionalAttrs (buildPlatform.isLinux && buildPlatform.isx86_64) { - runs-through-wine64 = runCommand "cloudflared-${version}-runs-through-wine64" - { - nativeBuildInputs = [ wine64 ]; - exe = "${pkgsCross.mingwW64.cloudflared}/bin/cloudflared.exe"; - } '' - export HOME="$(mktemp -d)" - wine64 $exe help - mkdir $out - ''; + refuses-to-autoupdate = + runCommand "cloudflared-${version}-refuses-to-autoupdate" + { + nativeBuildInputs = [ cloudflared ]; + } + '' + set -e + cloudflared update 2>&1 | tee output.txt + if ! grep "cloudflared was installed by nixpkgs" output.txt + then + echo "cloudflared's output didn't contain the package manager name" + exit 1 + fi + mkdir $out + ''; +} +// lib.optionalAttrs (buildPlatform.isLinux && (buildPlatform.isi686 || buildPlatform.isx86_64)) { + runs-through-wine = + runCommand "cloudflared-${version}-runs-through-wine" + { + nativeBuildInputs = [ wine ]; + exe = "${pkgsCross.mingw32.cloudflared}/bin/cloudflared.exe"; + } + '' + export HOME="$(mktemp -d)" + wine $exe help + mkdir $out + ''; +} +// lib.optionalAttrs (buildPlatform.isLinux && buildPlatform.isx86_64) { + runs-through-wine64 = + runCommand "cloudflared-${version}-runs-through-wine64" + { + nativeBuildInputs = [ wine64 ]; + exe = "${pkgsCross.mingwW64.cloudflared}/bin/cloudflared.exe"; + } + '' + export HOME="$(mktemp -d)" + wine64 $exe help + mkdir $out + ''; } diff --git a/pkgs/applications/networking/cluster/cni/default.nix b/pkgs/applications/networking/cluster/cni/default.nix index 7710490816e7e0..be96dfdbe56281 100644 --- a/pkgs/applications/networking/cluster/cni/default.nix +++ b/pkgs/applications/networking/cluster/cni/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "cni"; @@ -17,14 +21,23 @@ buildGoModule rec { "./cnitool" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Container Network Interface - networking for Linux containers"; mainProgram = "cnitool"; license = licenses.asl20; homepage = "https://github.com/containernetworking/cni"; - maintainers = with maintainers; [ offline vdemeester ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + maintainers = with maintainers; [ + offline + vdemeester + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; }; } diff --git a/pkgs/applications/networking/cluster/cni/plugins.nix b/pkgs/applications/networking/cluster/cni/plugins.nix index 417bf7fb690156..085d688e51bda4 100644 --- a/pkgs/applications/networking/cluster/cni/plugins.nix +++ b/pkgs/applications/networking/cluster/cni/plugins.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, nixosTests }: +{ + lib, + fetchFromGitHub, + buildGoModule, + nixosTests, +}: buildGoModule rec { pname = "cni-plugins"; diff --git a/pkgs/applications/networking/cluster/docker-machine/hyperkit.nix b/pkgs/applications/networking/cluster/docker-machine/hyperkit.nix index d9af5c360d4c19..a0ebcefe31ed87 100644 --- a/pkgs/applications/networking/cluster/docker-machine/hyperkit.nix +++ b/pkgs/applications/networking/cluster/docker-machine/hyperkit.nix @@ -1,7 +1,18 @@ -{ lib, buildGoModule, minikube }: +{ + lib, + buildGoModule, + minikube, +}: buildGoModule rec { - inherit (minikube) version src nativeBuildInputs buildInputs vendorHash doCheck; + inherit (minikube) + version + src + nativeBuildInputs + buildInputs + vendorHash + doCheck + ; pname = "docker-machine-hyperkit"; diff --git a/pkgs/applications/networking/cluster/docker-machine/kvm2.nix b/pkgs/applications/networking/cluster/docker-machine/kvm2.nix index c21cf5b4970e88..803f7033bc23e2 100644 --- a/pkgs/applications/networking/cluster/docker-machine/kvm2.nix +++ b/pkgs/applications/networking/cluster/docker-machine/kvm2.nix @@ -1,7 +1,18 @@ -{ lib, buildGoModule, minikube }: +{ + lib, + buildGoModule, + minikube, +}: buildGoModule rec { - inherit (minikube) version src nativeBuildInputs buildInputs vendorHash doCheck; + inherit (minikube) + version + src + nativeBuildInputs + buildInputs + vendorHash + doCheck + ; pname = "docker-machine-kvm2"; @@ -22,7 +33,10 @@ buildGoModule rec { description = "KVM2 driver for docker-machine"; mainProgram = "docker-machine-driver-kvm2"; license = licenses.asl20; - maintainers = with maintainers; [ tadfisher atkinschang ]; + maintainers = with maintainers; [ + tadfisher + atkinschang + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/networking/cluster/hadoop/containerExecutor.nix b/pkgs/applications/networking/cluster/hadoop/containerExecutor.nix index 7d5d2918e9b9fc..778ed6261df02a 100644 --- a/pkgs/applications/networking/cluster/hadoop/containerExecutor.nix +++ b/pkgs/applications/networking/cluster/hadoop/containerExecutor.nix @@ -1,4 +1,13 @@ -{ version, stdenv, fetchurl, lib, cmake, openssl, platformAttrs, ... }: +{ + version, + stdenv, + fetchurl, + lib, + cmake, + openssl, + platformAttrs, + ... +}: stdenv.mkDerivation (finalAttrs: { pname = "hadoop-yarn-containerexecutor"; @@ -8,8 +17,9 @@ stdenv.mkDerivation (finalAttrs: { url = "mirror://apache/hadoop/common/hadoop-${finalAttrs.version}/hadoop-${finalAttrs.version}-src.tar.gz"; hash = platformAttrs.${stdenv.system}.srcHash; }; - sourceRoot = "hadoop-${finalAttrs.version}-src/hadoop-yarn-project/hadoop-yarn/" - +"hadoop-yarn-server/hadoop-yarn-server-nodemanager/src"; + sourceRoot = + "hadoop-${finalAttrs.version}-src/hadoop-yarn-project/hadoop-yarn/" + + "hadoop-yarn-server/hadoop-yarn-server-nodemanager/src"; nativeBuildInputs = [ cmake ]; buildInputs = [ openssl ]; @@ -26,9 +36,9 @@ stdenv.mkDerivation (finalAttrs: { license = licenses.asl20; longDescription = '' - The Hadoop YARN Container Executor is a native component responsible for managing the lifecycle of containers - on individual nodes in a Hadoop YARN cluster. It launches, monitors, and terminates containers, ensuring that - resources like CPU and memory are allocated according to the policies defined in the ResourceManager. + The Hadoop YARN Container Executor is a native component responsible for managing the lifecycle of containers + on individual nodes in a Hadoop YARN cluster. It launches, monitors, and terminates containers, ensuring that + resources like CPU and memory are allocated according to the policies defined in the ResourceManager. ''; maintainers = with maintainers; [ illustris ]; diff --git a/pkgs/applications/networking/cluster/hadoop/default.nix b/pkgs/applications/networking/cluster/hadoop/default.nix index 1fdcbd5e564982..1a9aa3667e4502 100644 --- a/pkgs/applications/networking/cluster/hadoop/default.nix +++ b/pkgs/applications/networking/cluster/hadoop/default.nix @@ -1,122 +1,159 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, autoPatchelfHook -, jdk8_headless -, jdk11_headless -, bash -, coreutils -, which -, bzip2 -, cyrus_sasl -, protobuf -, snappy -, zlib -, zstd -, openssl -, nixosTests -, sparkSupport ? true -, spark -, libtirpc -, callPackage +{ + lib, + stdenv, + fetchurl, + makeWrapper, + autoPatchelfHook, + jdk8_headless, + jdk11_headless, + bash, + coreutils, + which, + bzip2, + cyrus_sasl, + protobuf, + snappy, + zlib, + zstd, + openssl, + nixosTests, + sparkSupport ? true, + spark, + libtirpc, + callPackage, }: -assert lib.elem stdenv.system [ "x86_64-linux" "x86_64-darwin" "aarch64-linux" "aarch64-darwin" ]; +assert lib.elem stdenv.system [ + "x86_64-linux" + "x86_64-darwin" + "aarch64-linux" + "aarch64-darwin" +]; let - common = { pname, platformAttrs, jdk, tests }: + common = + { + pname, + platformAttrs, + jdk, + tests, + }: stdenv.mkDerivation (finalAttrs: { inherit pname jdk; version = platformAttrs.${stdenv.system}.version or (throw "Unsupported system: ${stdenv.system}"); src = fetchurl { - url = "mirror://apache/hadoop/common/hadoop-${finalAttrs.version}/hadoop-${finalAttrs.version}" - + lib.optionalString stdenv.hostPlatform.isAarch64 "-aarch64" + ".tar.gz"; + url = + "mirror://apache/hadoop/common/hadoop-${finalAttrs.version}/hadoop-${finalAttrs.version}" + + lib.optionalString stdenv.hostPlatform.isAarch64 "-aarch64" + + ".tar.gz"; inherit (platformAttrs.${stdenv.system} or (throw "Unsupported system: ${stdenv.system}")) hash; }; doCheck = true; # Build the container executor binary from source # InstallPhase is not lazily evaluating containerExecutor for some reason - containerExecutor = if stdenv.hostPlatform.isLinux then (callPackage ./containerExecutor.nix { - inherit (finalAttrs) version; - inherit platformAttrs; - }) else ""; + containerExecutor = + if stdenv.hostPlatform.isLinux then + (callPackage ./containerExecutor.nix { + inherit (finalAttrs) version; + inherit platformAttrs; + }) + else + ""; - nativeBuildInputs = [ makeWrapper ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ autoPatchelfHook ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ (lib.getLib stdenv.cc.cc) openssl protobuf zlib snappy libtirpc ]; + nativeBuildInputs = [ + makeWrapper + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ autoPatchelfHook ]; + buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ + (lib.getLib stdenv.cc.cc) + openssl + protobuf + zlib + snappy + libtirpc + ]; - installPhase = '' - mkdir $out - mv * $out/ - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - for n in $(find ${finalAttrs.containerExecutor}/bin -type f); do - ln -sf "$n" $out/bin - done + installPhase = + '' + mkdir $out + mv * $out/ + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + for n in $(find ${finalAttrs.containerExecutor}/bin -type f); do + ln -sf "$n" $out/bin + done - # these libraries are loaded at runtime by the JVM - ln -s ${lib.getLib cyrus_sasl}/lib/libsasl2.so $out/lib/native/libsasl2.so.2 - ln -s ${lib.getLib openssl}/lib/libcrypto.so $out/lib/native/ - ln -s ${lib.getLib zlib}/lib/libz.so.1 $out/lib/native/ - ln -s ${lib.getLib zstd}/lib/libzstd.so.1 $out/lib/native/ - ln -s ${lib.getLib bzip2}/lib/libbz2.so.1 $out/lib/native/ - ln -s ${lib.getLib snappy}/lib/libsnappy.so.1 $out/lib/native/ + # these libraries are loaded at runtime by the JVM + ln -s ${lib.getLib cyrus_sasl}/lib/libsasl2.so $out/lib/native/libsasl2.so.2 + ln -s ${lib.getLib openssl}/lib/libcrypto.so $out/lib/native/ + ln -s ${lib.getLib zlib}/lib/libz.so.1 $out/lib/native/ + ln -s ${lib.getLib zstd}/lib/libzstd.so.1 $out/lib/native/ + ln -s ${lib.getLib bzip2}/lib/libbz2.so.1 $out/lib/native/ + ln -s ${lib.getLib snappy}/lib/libsnappy.so.1 $out/lib/native/ - # libjvm.so is in different paths for java 8 and 11 - # libnativetask.so in hadooop 3 and libhdfs.so in hadoop 2 depend on it - find $out/lib/native/ -name 'libnativetask.so*' -o -name 'libhdfs.so*' | \ - xargs -n1 patchelf --add-rpath $(dirname $(find ${finalAttrs.jdk.home} -name libjvm.so | head -n1)) + # libjvm.so is in different paths for java 8 and 11 + # libnativetask.so in hadooop 3 and libhdfs.so in hadoop 2 depend on it + find $out/lib/native/ -name 'libnativetask.so*' -o -name 'libhdfs.so*' | \ + xargs -n1 patchelf --add-rpath $(dirname $(find ${finalAttrs.jdk.home} -name libjvm.so | head -n1)) - # NixOS/nixpkgs#193370 - # This workaround is needed to use protobuf 3.19 - # hadoop 3.3+ depends on protobuf 3.18, 3.2 depends on 3.8 - find $out/lib/native -name 'libhdfspp.so*' | \ - xargs -r -n1 patchelf --replace-needed libprotobuf.so.${ - if (lib.versionAtLeast finalAttrs.version "3.3") then "18" - else "8" - } libprotobuf.so + # NixOS/nixpkgs#193370 + # This workaround is needed to use protobuf 3.19 + # hadoop 3.3+ depends on protobuf 3.18, 3.2 depends on 3.8 + find $out/lib/native -name 'libhdfspp.so*' | \ + xargs -r -n1 patchelf --replace-needed libprotobuf.so.${ + if (lib.versionAtLeast finalAttrs.version "3.3") then "18" else "8" + } libprotobuf.so - patchelf --replace-needed libcrypto.so.1.1 libcrypto.so \ - $out/lib/native/{libhdfs{pp,}.so*,examples/{pipes-sort,wordcount-nopipe,wordcount-part,wordcount-simple}} + patchelf --replace-needed libcrypto.so.1.1 libcrypto.so \ + $out/lib/native/{libhdfs{pp,}.so*,examples/{pipes-sort,wordcount-nopipe,wordcount-part,wordcount-simple}} - '' + '' - for n in $(find $out/bin -type f ! -name "*.*"); do - wrapProgram "$n"\ - --set-default JAVA_HOME ${finalAttrs.jdk.home}\ - --set-default HADOOP_HOME $out/\ - --run "test -d /etc/hadoop-conf && export HADOOP_CONF_DIR=\''${HADOOP_CONF_DIR-'/etc/hadoop-conf/'}"\ - --set-default HADOOP_CONF_DIR $out/etc/hadoop/\ - --prefix PATH : "${lib.makeBinPath [ bash coreutils which]}"\ - --prefix JAVA_LIBRARY_PATH : "${lib.makeLibraryPath finalAttrs.buildInputs}" - done - '' + (lib.optionalString sparkSupport '' - # Add the spark shuffle service jar to YARN - cp ${spark.src}/yarn/spark-${spark.version}-yarn-shuffle.jar $out/share/hadoop/yarn/ - ''); + '' + + '' + for n in $(find $out/bin -type f ! -name "*.*"); do + wrapProgram "$n"\ + --set-default JAVA_HOME ${finalAttrs.jdk.home}\ + --set-default HADOOP_HOME $out/\ + --run "test -d /etc/hadoop-conf && export HADOOP_CONF_DIR=\''${HADOOP_CONF_DIR-'/etc/hadoop-conf/'}"\ + --set-default HADOOP_CONF_DIR $out/etc/hadoop/\ + --prefix PATH : "${ + lib.makeBinPath [ + bash + coreutils + which + ] + }"\ + --prefix JAVA_LIBRARY_PATH : "${lib.makeLibraryPath finalAttrs.buildInputs}" + done + '' + + (lib.optionalString sparkSupport '' + # Add the spark shuffle service jar to YARN + cp ${spark.src}/yarn/spark-${spark.version}-yarn-shuffle.jar $out/share/hadoop/yarn/ + ''); passthru = { inherit tests; }; - meta = with lib; recursiveUpdate { - homepage = "https://hadoop.apache.org/"; - description = "Framework for distributed processing of large data sets across clusters of computers"; - license = licenses.asl20; - sourceProvenance = with sourceTypes; [ binaryBytecode ]; + meta = + with lib; + recursiveUpdate { + homepage = "https://hadoop.apache.org/"; + description = "Framework for distributed processing of large data sets across clusters of computers"; + license = licenses.asl20; + sourceProvenance = with sourceTypes; [ binaryBytecode ]; - longDescription = '' - The Apache Hadoop software library is a framework that allows for - the distributed processing of large data sets across clusters of - computers using a simple programming model. It is designed to - scale up from single servers to thousands of machines, each - offering local computation and storage. Rather than rely on - hardware to deliver high-avaiability, the library itself is - designed to detect and handle failures at the application layer, - so delivering a highly-availabile service on top of a cluster of - computers, each of which may be prone to failures. - ''; - maintainers = with maintainers; [ illustris ]; - platforms = attrNames platformAttrs; - } (attrByPath [ stdenv.system "meta" ] {} platformAttrs); + longDescription = '' + The Apache Hadoop software library is a framework that allows for + the distributed processing of large data sets across clusters of + computers using a simple programming model. It is designed to + scale up from single servers to thousands of machines, each + offering local computation and storage. Rather than rely on + hardware to deliver high-avaiability, the library itself is + designed to detect and handle failures at the application layer, + so delivering a highly-availabile service on top of a cluster of + computers, each of which may be prone to failures. + ''; + maintainers = with maintainers; [ illustris ]; + platforms = attrNames platformAttrs; + } (attrByPath [ stdenv.system "meta" ] { } platformAttrs); }); in { diff --git a/pkgs/applications/networking/cluster/helm/plugins/helm-diff.nix b/pkgs/applications/networking/cluster/helm/plugins/helm-diff.nix index 4dd748b4989bac..63561d489dfc80 100644 --- a/pkgs/applications/networking/cluster/helm/plugins/helm-diff.nix +++ b/pkgs/applications/networking/cluster/helm/plugins/helm-diff.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "helm-diff"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-7amqt5FIgnDtaybyur3t01BuuQXPdFptDBfqhX6jPIE="; - ldflags = [ "-s" "-w" "-X github.com/databus23/helm-diff/v3/cmd.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/databus23/helm-diff/v3/cmd.Version=${version}" + ]; # NOTE: Remove the install and upgrade hooks. postPatch = '' diff --git a/pkgs/applications/networking/cluster/helm/plugins/helm-git.nix b/pkgs/applications/networking/cluster/helm/plugins/helm-git.nix index ab4a912aab2993..12724709f993f2 100644 --- a/pkgs/applications/networking/cluster/helm/plugins/helm-git.nix +++ b/pkgs/applications/networking/cluster/helm/plugins/helm-git.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, coreutils -, findutils -, gitMinimal -, gnugrep -, gnused -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + coreutils, + findutils, + gitMinimal, + gnugrep, + gnused, + makeWrapper, }: stdenv.mkDerivation rec { @@ -32,7 +33,15 @@ stdenv.mkDerivation rec { patchShebangs $out/helm-git/helm-git{,-plugin.sh} wrapProgram $out/helm-git/helm-git \ - --prefix PATH : ${lib.makeBinPath [ coreutils findutils gitMinimal gnugrep gnused ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + findutils + gitMinimal + gnugrep + gnused + ] + } runHook postInstall ''; diff --git a/pkgs/applications/networking/cluster/helm/plugins/helm-mapkubeapis.nix b/pkgs/applications/networking/cluster/helm/plugins/helm-mapkubeapis.nix index 4dc5619079444b..47aa83ee965398 100644 --- a/pkgs/applications/networking/cluster/helm/plugins/helm-mapkubeapis.nix +++ b/pkgs/applications/networking/cluster/helm/plugins/helm-mapkubeapis.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "helm-mapkubeapis"; diff --git a/pkgs/applications/networking/cluster/helm/plugins/helm-s3.nix b/pkgs/applications/networking/cluster/helm/plugins/helm-s3.nix index d56d850d3bb7cf..78d58b0c0b47d9 100644 --- a/pkgs/applications/networking/cluster/helm/plugins/helm-s3.nix +++ b/pkgs/applications/networking/cluster/helm/plugins/helm-s3.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "helm-s3"; @@ -23,7 +27,11 @@ buildGoModule rec { go test $(go list ./... | grep -vE '(awsutil|e2e)') ''; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; subPackages = [ "cmd/helm-s3" ]; diff --git a/pkgs/applications/networking/cluster/helm/plugins/helm-secrets.nix b/pkgs/applications/networking/cluster/helm/plugins/helm-secrets.nix index c432ec035cd745..cd063d17d6b727 100644 --- a/pkgs/applications/networking/cluster/helm/plugins/helm-secrets.nix +++ b/pkgs/applications/networking/cluster/helm/plugins/helm-secrets.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, coreutils, findutils, getopt, gnugrep, gnused, sops }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + coreutils, + findutils, + getopt, + gnugrep, + gnused, + sops, +}: stdenv.mkDerivation rec { pname = "helm-secrets"; @@ -12,7 +23,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ getopt sops ]; + buildInputs = [ + getopt + sops + ]; # NOTE: helm-secrets is comprised of shell scripts. dontBuild = true; @@ -29,7 +43,16 @@ stdenv.mkDerivation rec { install -m644 -Dt $out/${pname} plugin.yaml cp -r scripts/* $out/${pname}/scripts wrapProgram $out/${pname}/scripts/run.sh \ - --prefix PATH : ${lib.makeBinPath [ coreutils findutils getopt gnugrep gnused sops ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + findutils + getopt + gnugrep + gnused + sops + ] + } runHook postInstall ''; diff --git a/pkgs/applications/networking/cluster/helm/wrapper.nix b/pkgs/applications/networking/cluster/helm/wrapper.nix index d933d84db3368b..ab44afb750d51c 100644 --- a/pkgs/applications/networking/cluster/helm/wrapper.nix +++ b/pkgs/applications/networking/cluster/helm/wrapper.nix @@ -1,47 +1,56 @@ -{ symlinkJoin, lib, makeWrapper, writeText }: +{ + symlinkJoin, + lib, + makeWrapper, + writeText, +}: helm: let - wrapper = { - plugins ? [], - extraMakeWrapperArgs ? "" - }: - let - - initialMakeWrapperArgs = [ - ]; - - pluginsDir = symlinkJoin { - name = "helm-plugins"; - paths = plugins; - }; -in - symlinkJoin { - name = "helm-${lib.getVersion helm}"; - - # Remove the symlinks created by symlinkJoin which we need to perform - # extra actions upon - postBuild = '' - wrapProgram "$out/bin/helm" \ - "--set" "HELM_PLUGINS" "${pluginsDir}" ${extraMakeWrapperArgs} - ''; - paths = [ helm pluginsDir ]; - - preferLocalBuild = true; - - nativeBuildInputs = [ makeWrapper ]; - passthru = { - inherit pluginsDir; - unwrapped = helm; - }; - - meta = helm.meta // { - # To prevent builds on hydra - hydraPlatforms = []; - # prefer wrapper over the package - priority = (helm.meta.priority or lib.meta.defaultPriority) - 1; + wrapper = + { + plugins ? [ ], + extraMakeWrapperArgs ? "", + }: + let + + initialMakeWrapperArgs = [ + ]; + + pluginsDir = symlinkJoin { + name = "helm-plugins"; + paths = plugins; + }; + in + symlinkJoin { + name = "helm-${lib.getVersion helm}"; + + # Remove the symlinks created by symlinkJoin which we need to perform + # extra actions upon + postBuild = '' + wrapProgram "$out/bin/helm" \ + "--set" "HELM_PLUGINS" "${pluginsDir}" ${extraMakeWrapperArgs} + ''; + paths = [ + helm + pluginsDir + ]; + + preferLocalBuild = true; + + nativeBuildInputs = [ makeWrapper ]; + passthru = { + inherit pluginsDir; + unwrapped = helm; + }; + + meta = helm.meta // { + # To prevent builds on hydra + hydraPlatforms = [ ]; + # prefer wrapper over the package + priority = (helm.meta.priority or lib.meta.defaultPriority) - 1; + }; }; - }; in - lib.makeOverridable wrapper +lib.makeOverridable wrapper diff --git a/pkgs/applications/networking/cluster/helmfile/default.nix b/pkgs/applications/networking/cluster/helmfile/default.nix index b57ce2570e4e21..21caf1ea4c3d05 100644 --- a/pkgs/applications/networking/cluster/helmfile/default.nix +++ b/pkgs/applications/networking/cluster/helmfile/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, makeWrapper -, pluginsDir ? null +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + makeWrapper, + pluginsDir ? null, }: buildGoModule rec { @@ -25,21 +26,25 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" "-X go.szostok.io/version.version=v${version}" ]; - - nativeBuildInputs = - [ installShellFiles ] ++ - lib.optional (pluginsDir != null) makeWrapper; - - postInstall = lib.optionalString (pluginsDir != null) '' - wrapProgram $out/bin/helmfile \ - --set HELM_PLUGINS "${pluginsDir}" - '' + '' - installShellCompletion --cmd helmfile \ - --bash <($out/bin/helmfile completion bash) \ - --fish <($out/bin/helmfile completion fish) \ - --zsh <($out/bin/helmfile completion zsh) - ''; + ldflags = [ + "-s" + "-w" + "-X go.szostok.io/version.version=v${version}" + ]; + + nativeBuildInputs = [ installShellFiles ] ++ lib.optional (pluginsDir != null) makeWrapper; + + postInstall = + lib.optionalString (pluginsDir != null) '' + wrapProgram $out/bin/helmfile \ + --set HELM_PLUGINS "${pluginsDir}" + '' + + '' + installShellCompletion --cmd helmfile \ + --bash <($out/bin/helmfile completion bash) \ + --fish <($out/bin/helmfile completion fish) \ + --zsh <($out/bin/helmfile completion zsh) + ''; meta = { description = "Declarative spec for deploying Helm charts"; @@ -50,6 +55,9 @@ buildGoModule rec { ''; homepage = "https://helmfile.readthedocs.io/"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ pneumaticat yurrriq ]; + maintainers = with lib.maintainers; [ + pneumaticat + yurrriq + ]; }; } diff --git a/pkgs/applications/networking/cluster/krane/default.nix b/pkgs/applications/networking/cluster/krane/default.nix index 9be10f5d2f0fab..93d3836492fd18 100644 --- a/pkgs/applications/networking/cluster/krane/default.nix +++ b/pkgs/applications/networking/cluster/krane/default.nix @@ -1,6 +1,7 @@ -{ lib -, bundlerApp -, bundlerUpdateScript +{ + lib, + bundlerApp, + bundlerUpdateScript, }: bundlerApp { diff --git a/pkgs/applications/networking/cluster/krane/gemset.nix b/pkgs/applications/networking/cluster/krane/gemset.nix index 39b8783c3a539e..11f28420210144 100644 --- a/pkgs/applications/networking/cluster/krane/gemset.nix +++ b/pkgs/applications/networking/cluster/krane/gemset.nix @@ -1,459 +1,518 @@ { activesupport = { - dependencies = ["base64" "bigdecimal" "concurrent-ruby" "connection_pool" "drb" "i18n" "logger" "minitest" "securerandom" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "bigdecimal" + "concurrent-ruby" + "connection_pool" + "drb" + "i18n" + "logger" + "minitest" + "securerandom" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "094cv9kxa8hwlsw3c0njkvvayd0wszcz9b6xywv4yajrg83zlmvm"; type = "gem"; }; version = "7.2.1"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; colorize = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "133rqj85n400qk6g3dhf2bmfws34mak1wqihvh3bgy9jhajw580b"; type = "gem"; }; version = "0.8.1"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; connection_pool = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; domain_name = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cyr2xm576gqhqicsyqnhanni47408w2pgvrfi8pd13h2li3nsaz"; type = "gem"; }; version = "0.6.20240107"; }; drb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h5kbj9hvg5hb3c7l425zpds0vb42phvln2knab8nmazg2zp5m79"; type = "gem"; }; version = "2.2.1"; }; ejson = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bpry4i9ajh2h8fyljp0cb17iy03ar36yc9mpfxflmdznl7dwsjf"; type = "gem"; }; version = "1.4.1"; }; faraday = { - dependencies = ["faraday-net_http" "logger"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-net_http" + "logger" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00pd34pnfmij5iw1xv73f6d68zng63wyjhmk7dyi010kmb4x5sp6"; type = "gem"; }; version = "2.11.0"; }; faraday-net_http = { - dependencies = ["net-http"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-http" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rg54k4skaz8z7j358p6pdzc9pr84fjq7sdlpicf7s5ig7vb1rlk"; type = "gem"; }; version = "3.3.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; ffi-compiler = { - dependencies = ["ffi" "rake"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ffi" + "rake" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1844j58cdg2q6g0rqfwg4rrambnhf059h4yg9rfmrbrcs60kskx9"; type = "gem"; }; version = "1.3.2"; }; google-cloud-env = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vlwifnhih8nq5441pfbnzc7w4z8rmy7j54pfixpm9yvlq11428j"; type = "gem"; }; version = "2.2.0"; }; googleauth = { - dependencies = ["faraday" "google-cloud-env" "jwt" "multi_json" "os" "signet"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "google-cloud-env" + "jwt" + "multi_json" + "os" + "signet" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15knmk2fcyqxdpppc3wb5lc6xapbx5hax4lma0iclc2p55aa2kkl"; type = "gem"; }; version = "1.11.0"; }; http = { - dependencies = ["addressable" "base64" "http-cookie" "http-form_data" "llhttp-ffi"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "base64" + "http-cookie" + "http-form_data" + "llhttp-ffi" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05b1khh7wxga9jviy9yi8z1nckxbm3svlzv40y0zvq3nag3d77mr"; type = "gem"; }; version = "5.2.0"; }; http-accept = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09m1facypsdjynfwrcv19xcb1mqg8z6kk31g8r33pfxzh838c9n6"; type = "gem"; }; version = "1.7.0"; }; http-cookie = { - dependencies = ["domain_name"]; - groups = ["default"]; - platforms = []; + dependencies = [ "domain_name" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lr2yk5g5vvf9nzlmkn3p7mhh9mn55gpdc7kl2w21xs46fgkjynb"; type = "gem"; }; version = "1.0.7"; }; http-form_data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wx591jdhy84901pklh1n9sgh74gnvq1qyqxwchni1yrc49ynknc"; type = "gem"; }; version = "2.3.0"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ffix518y7976qih9k1lgnc17i3v6yrlh0a3mckpxdb4wc2vrp16"; type = "gem"; }; version = "1.14.5"; }; jsonpath = { - dependencies = ["multi_json"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multi_json" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ghxjcs9rss0fd43yqnc3ab6fhnm4qrkvv34p0xcjb9s35kh9xr9"; type = "gem"; }; version = "1.1.5"; }; jwt = { - dependencies = ["base64"]; - groups = ["default"]; - platforms = []; + dependencies = [ "base64" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04mw326i9vsdcqwm4bf0zvnqw237f8l7022nhlbmak92bqqpg62s"; type = "gem"; }; version = "2.8.2"; }; krane = { - dependencies = ["activesupport" "colorize" "concurrent-ruby" "ejson" "googleauth" "jsonpath" "kubeclient" "multi_json" "statsd-instrument" "thor"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "colorize" + "concurrent-ruby" + "ejson" + "googleauth" + "jsonpath" + "kubeclient" + "multi_json" + "statsd-instrument" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07f87rzlr0yamji5ns2isf5f554jal5b9v62lijhsafmq9545f42"; type = "gem"; }; version = "3.6.2"; }; kubeclient = { - dependencies = ["http" "jsonpath" "recursive-open-struct" "rest-client"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "http" + "jsonpath" + "recursive-open-struct" + "rest-client" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1g89qd1hhf111zy9djlzblzz06pnv59zmamh6fk06wvnih7vj446"; type = "gem"; }; version = "4.12.0"; }; llhttp-ffi = { - dependencies = ["ffi-compiler" "rake"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ffi-compiler" + "rake" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yph78m8w8l6i9833fc7shy5krk4mnqjc7ys0bg9kgxw8jnl0vs9"; type = "gem"; }; version = "0.5.0"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; mime-types = { - dependencies = ["mime-types-data"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mime-types-data" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1r64z0m5zrn4k37wabfnv43wa6yivgdfk6cf2rpmmirlz889yaf1"; type = "gem"; }; version = "3.5.2"; }; mime-types-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0d5bmxcq87nj6h5rx6b1fkdzq8256yba97s2vlkszpwhc47m9rfs"; type = "gem"; }; version = "3.2024.0903"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n1akmc6bibkbxkzm1p1wmfb4n9vv397knkgz0ffykb3h1d7kdix"; type = "gem"; }; version = "5.25.1"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; net-http = { - dependencies = ["uri"]; - groups = ["default"]; - platforms = []; + dependencies = [ "uri" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10n2n9aq00ih8v881af88l1zyrqgs5cl3njdw8argjwbl5ggqvm9"; type = "gem"; }; version = "0.4.1"; }; netrc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gzfmcywp1da8nzfqsql2zqi648mfnx6qwkig3cv36n9m0yy676y"; type = "gem"; }; version = "0.11.0"; }; os = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gwd20smyhxbm687vdikfh1gpi96h8qb1x28s2pdcysf6dm6v0ap"; type = "gem"; }; version = "1.1.4"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vqcw3iwby3yc6avs1vb3gfd0vcp2v7q310665dvxfswmcf4xm31"; type = "gem"; }; version = "6.0.1"; }; rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17850wcwkgi30p7yqh60960ypn7yibacjjha0av78zaxwvd3ijs6"; type = "gem"; }; version = "13.2.1"; }; recursive-open-struct = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rjs8804zn5v39mklmqy65xwdji7iq598lkw876zspclziy4h2c3"; type = "gem"; }; version = "1.2.2"; }; rest-client = { - dependencies = ["http-accept" "http-cookie" "mime-types" "netrc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "http-accept" + "http-cookie" + "mime-types" + "netrc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1qs74yzl58agzx9dgjhcpgmzfn61fqkk33k1js2y5yhlvc5l19im"; type = "gem"; }; version = "2.1.0"; }; securerandom = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1phv6kh417vkanhssbjr960c0gfqvf8z7d3d9fd2yvd41q64bw4q"; type = "gem"; }; version = "0.3.1"; }; signet = { - dependencies = ["addressable" "faraday" "jwt" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "faraday" + "jwt" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cfxa11wy1nv9slmnzjczkdgld0gqizajsb03rliy53zylwkjzsk"; type = "gem"; }; version = "0.19.0"; }; statsd-instrument = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kd75axvmyq866nan18n9ys5bd140h0mka2kz9s5m86r8m42jbhj"; type = "gem"; }; version = "3.8.0"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nmymd86a0vb39pzj2cwv57avdrl6pl3lf5bsz58q594kqxjkw7f"; type = "gem"; }; version = "1.3.2"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; uri = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07ndgxyhzd02cg94s6rnfhkb9rwx9z72lzk368sa9j78wc9qnbfz"; type = "gem"; }; diff --git a/pkgs/applications/networking/cluster/kubectl-evict-pod/default.nix b/pkgs/applications/networking/cluster/kubectl-evict-pod/default.nix index ac1f1cbf0b6817..83f3e752a02179 100644 --- a/pkgs/applications/networking/cluster/kubectl-evict-pod/default.nix +++ b/pkgs/applications/networking/cluster/kubectl-evict-pod/default.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "kubectl-evict-pod"; @@ -16,8 +20,8 @@ buildGoModule rec { meta = with lib; { description = "This plugin evicts the given pod and is useful for testing pod disruption budget rules"; mainProgram = "kubectl-evict-pod"; - homepage = "https://github.com/rajatjindal/kubectl-evict-pod"; - license = licenses.asl20; + homepage = "https://github.com/rajatjindal/kubectl-evict-pod"; + license = licenses.asl20; maintainers = [ maintainers.j4m3s ]; }; } diff --git a/pkgs/applications/networking/cluster/kubectl-view-allocations/default.nix b/pkgs/applications/networking/cluster/kubectl-view-allocations/default.nix index 8f912c26701948..71b0f9d9ed6567 100644 --- a/pkgs/applications/networking/cluster/kubectl-view-allocations/default.nix +++ b/pkgs/applications/networking/cluster/kubectl-view-allocations/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, Security ? null +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + Security ? null, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/applications/networking/cluster/kubernetes/default.nix b/pkgs/applications/networking/cluster/kubernetes/default.nix index f7bd5695202ebf..187457cb55cc7f 100644 --- a/pkgs/applications/networking/cluster/kubernetes/default.nix +++ b/pkgs/applications/networking/cluster/kubernetes/default.nix @@ -1,21 +1,22 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, which -, makeWrapper -, rsync -, installShellFiles -, runtimeShell -, kubectl -, nixosTests - -, components ? [ +{ + lib, + buildGoModule, + fetchFromGitHub, + which, + makeWrapper, + rsync, + installShellFiles, + runtimeShell, + kubectl, + nixosTests, + + components ? [ "cmd/kubelet" "cmd/kube-apiserver" "cmd/kube-controller-manager" "cmd/kube-proxy" "cmd/kube-scheduler" - ] + ], }: buildGoModule rec { @@ -33,15 +34,27 @@ buildGoModule rec { doCheck = false; - nativeBuildInputs = [ makeWrapper which rsync installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + which + rsync + installShellFiles + ]; - outputs = [ "out" "man" "pause" ]; + outputs = [ + "out" + "man" + "pause" + ]; patches = [ ./fixup-addonmanager-lib-path.patch ]; - WHAT = lib.concatStringsSep " " ([ - "cmd/kubeadm" - ] ++ components); + WHAT = lib.concatStringsSep " " ( + [ + "cmd/kubeadm" + ] + ++ components + ); buildPhase = '' runHook preBuild @@ -90,5 +103,7 @@ buildGoModule rec { platforms = platforms.linux; }; - passthru.tests = nixosTests.kubernetes // { inherit kubectl; }; + passthru.tests = nixosTests.kubernetes // { + inherit kubectl; + }; } diff --git a/pkgs/applications/networking/cluster/kubernetes/kubectl.nix b/pkgs/applications/networking/cluster/kubernetes/kubectl.nix index b7036251b77ab3..48c6805aef5935 100644 --- a/pkgs/applications/networking/cluster/kubernetes/kubectl.nix +++ b/pkgs/applications/networking/cluster/kubernetes/kubectl.nix @@ -3,7 +3,11 @@ kubernetes.overrideAttrs (_: rec { pname = "kubectl"; - outputs = [ "out" "man" "convert" ]; + outputs = [ + "out" + "man" + "convert" + ]; WHAT = lib.concatStringsSep " " [ "cmd/kubectl" diff --git a/pkgs/applications/networking/cluster/kubeval/default.nix b/pkgs/applications/networking/cluster/kubeval/default.nix index 8fb1e68b020692..f9209c858ebc9a 100644 --- a/pkgs/applications/networking/cluster/kubeval/default.nix +++ b/pkgs/applications/networking/cluster/kubeval/default.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, fetchpatch +{ + lib, + fetchFromGitHub, + buildGoModule, + fetchpatch, }: buildGoModule rec { @@ -33,6 +34,9 @@ buildGoModule rec { mainProgram = "kubeval"; homepage = "https://github.com/instrumenta/kubeval"; license = licenses.asl20; - maintainers = with maintainers; [ johanot nicknovitski ]; + maintainers = with maintainers; [ + johanot + nicknovitski + ]; }; } diff --git a/pkgs/applications/networking/cluster/kubeval/schema.nix b/pkgs/applications/networking/cluster/kubeval/schema.nix index 370fe9a1cd8231..85e255a423f958 100644 --- a/pkgs/applications/networking/cluster/kubeval/schema.nix +++ b/pkgs/applications/networking/cluster/kubeval/schema.nix @@ -9,7 +9,8 @@ repo = "kubernetes-json-schema"; rev = "6a498a60dc68c5f6a1cc248f94b5cd1e7241d699"; sha256 = "1y9m2ma3n4h7sf2lg788vjw6pkfyi0fa7gzc870faqv326n6x2jr"; -}) // { +}) +// { # the schema is huge (> 7GB), we don't get any benefit from building int on hydra - meta.hydraPlatforms = []; + meta.hydraPlatforms = [ ]; } diff --git a/pkgs/applications/networking/cluster/linkerd/generic.nix b/pkgs/applications/networking/cluster/linkerd/generic.nix index 5ccdb9320bf584..bb604d74aed93a 100644 --- a/pkgs/applications/networking/cluster/linkerd/generic.nix +++ b/pkgs/applications/networking/cluster/linkerd/generic.nix @@ -1,6 +1,16 @@ -{ lib, fetchFromGitHub, buildGoModule, installShellFiles }: +{ + lib, + fetchFromGitHub, + buildGoModule, + installShellFiles, +}: -{ channel, version, sha256, vendorHash }: +{ + channel, + version, + sha256, + vendorHash, +}: buildGoModule rec { pname = "linkerd-${channel}"; @@ -32,7 +42,8 @@ buildGoModule rec { ]; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/linkerd/linkerd2/pkg/version.Version=${src.rev}" ]; @@ -59,6 +70,9 @@ buildGoModule rec { downloadPage = "https://github.com/linkerd/linkerd2/"; homepage = "https://linkerd.io/"; license = licenses.asl20; - maintainers = with maintainers; [ bryanasdev000 Gonzih ]; + maintainers = with maintainers; [ + bryanasdev000 + Gonzih + ]; }; } diff --git a/pkgs/applications/networking/cluster/minikube/default.nix b/pkgs/applications/networking/cluster/minikube/default.nix index a367c8bc3aab36..438fb2cfde4909 100644 --- a/pkgs/applications/networking/cluster/minikube/default.nix +++ b/pkgs/applications/networking/cluster/minikube/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles -, pkg-config -, which -, libvirt -, vmnet -, withQemu ? false -, qemu -, makeWrapper -, OVMF +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, + pkg-config, + which, + libvirt, + vmnet, + withQemu ? false, + qemu, + makeWrapper, + OVMF, }: buildGoModule rec { @@ -28,25 +29,33 @@ buildGoModule rec { sha256 = "sha256-Z7x3MOQUF3a19X4SSiIUfSJ3xl3482eKH700m/9pqcU="; }; postPatch = - ( - lib.optionalString (withQemu && stdenv.hostPlatform.isDarwin) '' - substituteInPlace \ - pkg/minikube/registry/drvs/qemu2/qemu2.go \ - --replace "/usr/local/opt/qemu/share/qemu" "${qemu}/share/qemu" \ - --replace "/opt/homebrew/opt/qemu/share/qemu" "${qemu}/share/qemu" - '' - ) + ( - lib.optionalString (withQemu && stdenv.hostPlatform.isLinux) '' - substituteInPlace \ - pkg/minikube/registry/drvs/qemu2/qemu2.go \ - --replace "/usr/share/OVMF/OVMF_CODE.fd" "${OVMF.firmware}" \ - --replace "/usr/share/AAVMF/AAVMF_CODE.fd" "${OVMF.firmware}" - '' - ); + (lib.optionalString (withQemu && stdenv.hostPlatform.isDarwin) '' + substituteInPlace \ + pkg/minikube/registry/drvs/qemu2/qemu2.go \ + --replace "/usr/local/opt/qemu/share/qemu" "${qemu}/share/qemu" \ + --replace "/opt/homebrew/opt/qemu/share/qemu" "${qemu}/share/qemu" + '') + + (lib.optionalString (withQemu && stdenv.hostPlatform.isLinux) '' + substituteInPlace \ + pkg/minikube/registry/drvs/qemu2/qemu2.go \ + --replace "/usr/share/OVMF/OVMF_CODE.fd" "${OVMF.firmware}" \ + --replace "/usr/share/AAVMF/AAVMF_CODE.fd" "${OVMF.firmware}" + ''); - nativeBuildInputs = [ installShellFiles pkg-config which makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + which + makeWrapper + ]; - buildInputs = if stdenv.hostPlatform.isDarwin then [ vmnet ] else if stdenv.hostPlatform.isLinux then [ libvirt ] else null; + buildInputs = + if stdenv.hostPlatform.isDarwin then + [ vmnet ] + else if stdenv.hostPlatform.isLinux then + [ libvirt ] + else + null; buildPhase = '' make COMMIT=${src.rev} @@ -69,6 +78,12 @@ buildGoModule rec { description = "Tool that makes it easy to run Kubernetes locally"; mainProgram = "minikube"; license = licenses.asl20; - maintainers = with maintainers; [ ebzzry copumpkin vdemeester atkinschang Chili-Man ]; + maintainers = with maintainers; [ + ebzzry + copumpkin + vdemeester + atkinschang + Chili-Man + ]; }; } diff --git a/pkgs/applications/networking/cluster/nixops/default.nix b/pkgs/applications/networking/cluster/nixops/default.nix index 88c426565fc4e7..80b8f6ce03f2da 100644 --- a/pkgs/applications/networking/cluster/nixops/default.nix +++ b/pkgs/applications/networking/cluster/nixops/default.nix @@ -1,102 +1,143 @@ -{ lib, python3, emptyFile }: +{ + lib, + python3, + emptyFile, +}: let inherit (lib) extends; # doc: https://github.com/NixOS/nixpkgs/pull/158781/files#diff-854251fa1fe071654921224671c8ba63c95feb2f96b2b3a9969c81676780053a - encapsulate = layerZero: + encapsulate = + layerZero: let fixed = layerZero ({ extend = f: encapsulate (extends f layerZero); } // fixed); - in fixed.public; + in + fixed.public; nixopsContextBase = this: { python = python3.override { self = this.python; - packageOverrides = self: super: { - nixops = self.callPackage ./unwrapped.nix { }; - } // (this.plugins self super); + packageOverrides = + self: super: + { + nixops = self.callPackage ./unwrapped.nix { }; + } + // (this.plugins self super); }; - plugins = ps: _super: with ps; rec { - nixops-digitalocean = callPackage ./plugins/nixops-digitalocean.nix { }; - nixops-encrypted-links = callPackage ./plugins/nixops-encrypted-links.nix { }; - nixops-hercules-ci = callPackage ./plugins/nixops-hercules-ci.nix { }; - nixops-vbox = callPackage ./plugins/nixops-vbox.nix { }; - nixos-modules-contrib = callPackage ./plugins/nixos-modules-contrib.nix { }; - - nixops-aws = throw "nixops-aws was broken and was removed from nixpkgs"; - nixops-gce = throw "nixops-gce was broken and was removed from nixpkgs"; - nixops-libvirtd = throw "nixops-libvirtd was broken and was removed from nixpkgs"; - nixops-hetzner = throw "nixops-hetzner was broken and was removed from nixpkgs"; - nixops-hetznercloud = throw "nixops-hetznercloud was broken and was removed from nixpkgs"; - - # aliases for backwards compatibility - nixops-virtd = nixops-libvirtd; - nixopsvbox = nixops-vbox; - }; + plugins = + ps: _super: with ps; rec { + nixops-digitalocean = callPackage ./plugins/nixops-digitalocean.nix { }; + nixops-encrypted-links = callPackage ./plugins/nixops-encrypted-links.nix { }; + nixops-hercules-ci = callPackage ./plugins/nixops-hercules-ci.nix { }; + nixops-vbox = callPackage ./plugins/nixops-vbox.nix { }; + nixos-modules-contrib = callPackage ./plugins/nixos-modules-contrib.nix { }; + + nixops-aws = throw "nixops-aws was broken and was removed from nixpkgs"; + nixops-gce = throw "nixops-gce was broken and was removed from nixpkgs"; + nixops-libvirtd = throw "nixops-libvirtd was broken and was removed from nixpkgs"; + nixops-hetzner = throw "nixops-hetzner was broken and was removed from nixpkgs"; + nixops-hetznercloud = throw "nixops-hetznercloud was broken and was removed from nixpkgs"; + + # aliases for backwards compatibility + nixops-virtd = nixops-libvirtd; + nixopsvbox = nixops-vbox; + }; # We should not reapply the overlay, but it tends to work out. (It's been this way since poetry2nix was dropped.) availablePlugins = this.plugins this.python.pkgs this.python.pkgs; - selectedPlugins = []; + selectedPlugins = [ ]; # selector is a function mapping pythonPackages to a list of plugins # e.g. nixops_unstable.withPlugins (ps: with ps; [ nixops-digitalocean ]) - withPlugins = selector: - this.extend (this: _old: { - selectedPlugins = selector this.availablePlugins; - }); - - rawPackage = this.python.pkgs.toPythonApplication (this.python.pkgs.nixops.overridePythonAttrs (old: { - propagatedBuildInputs = old.propagatedBuildInputs ++ this.selectedPlugins; - - # Propagating dependencies leaks them through $PYTHONPATH which causes issues - # when used in nix-shell. - postFixup = '' - rm $out/nix-support/propagated-build-inputs - ''; - })); + withPlugins = + selector: + this.extend ( + this: _old: { + selectedPlugins = selector this.availablePlugins; + } + ); + + rawPackage = this.python.pkgs.toPythonApplication ( + this.python.pkgs.nixops.overridePythonAttrs (old: { + propagatedBuildInputs = old.propagatedBuildInputs ++ this.selectedPlugins; + + # Propagating dependencies leaks them through $PYTHONPATH which causes issues + # when used in nix-shell. + postFixup = '' + rm $out/nix-support/propagated-build-inputs + ''; + }) + ); # Extra package attributes that aren't derivation attributes, just like `mkDerivation`'s `passthru`. extraPackageAttrs = { - inherit (this) selectedPlugins availablePlugins withPlugins python; - tests = this.rawPackage.tests // { - nixos = this.rawPackage.tests.nixos.passthru.override { - nixopsPkg = this.rawPackage; - }; - commutative_addAvailablePlugins_withPlugins = - assert - (this.public.addAvailablePlugins (self: super: { inherit emptyFile; })).withPlugins (ps: [ emptyFile ]) - == - # Note that this value proves that the package is not instantiated until the end, where it's valid again. - (this.public.withPlugins (ps: [ emptyFile ])).addAvailablePlugins (self: super: { inherit emptyFile; }); - emptyFile; - } + inherit (this) + selectedPlugins + availablePlugins + withPlugins + python + ; + tests = + this.rawPackage.tests + // { + nixos = this.rawPackage.tests.nixos.passthru.override { + nixopsPkg = this.rawPackage; + }; + commutative_addAvailablePlugins_withPlugins = + assert + (this.public.addAvailablePlugins (self: super: { inherit emptyFile; })).withPlugins (ps: [ + emptyFile + ]) == + # Note that this value proves that the package is not instantiated until the end, where it's valid again. + (this.public.withPlugins (ps: [ emptyFile ])).addAvailablePlugins ( + self: super: { inherit emptyFile; } + ); + emptyFile; + } # Make sure we also test with a configuration that's been extended with a plugin. // lib.optionalAttrs (this.selectedPlugins == [ ]) { - withAPlugin = - lib.recurseIntoAttrs - (this.withPlugins (ps: with ps; [ nixops-encrypted-links ])).tests; - }; - overrideAttrs = f: this.extend (this: oldThis: { - rawPackage = oldThis.rawPackage.overrideAttrs f; - }); + withAPlugin = + lib.recurseIntoAttrs + (this.withPlugins (ps: with ps; [ nixops-encrypted-links ])).tests; + }; + overrideAttrs = + f: + this.extend ( + this: oldThis: { + rawPackage = oldThis.rawPackage.overrideAttrs f; + } + ); /** - * nixops.addAvailablePlugins: Overlay -> Package - * - * Add available plugins to the package. You probably also want to enable - * them with the `withPlugins` method. - */ - addAvailablePlugins = newPlugins: this.extend (finalThis: oldThis: { - plugins = lib.composeExtensions oldThis.plugins newPlugins; - }); + nixops.addAvailablePlugins: Overlay -> Package + + Add available plugins to the package. You probably also want to enable + them with the `withPlugins` method. + */ + addAvailablePlugins = + newPlugins: + this.extend ( + finalThis: oldThis: { + plugins = lib.composeExtensions oldThis.plugins newPlugins; + } + ); # For those who need or dare. internals = this; }; - package = lib.lazyDerivation { outputs = [ "out" "dist" ]; derivation = this.rawPackage; } // this.extraPackageAttrs; + package = + lib.lazyDerivation { + outputs = [ + "out" + "dist" + ]; + derivation = this.rawPackage; + } + // this.extraPackageAttrs; public = this.package; }; diff --git a/pkgs/applications/networking/cluster/nixops/plugins/nixops-digitalocean.nix b/pkgs/applications/networking/cluster/nixops/plugins/nixops-digitalocean.nix index a78d4d2cfd997c..55aec60b9e3095 100644 --- a/pkgs/applications/networking/cluster/nixops/plugins/nixops-digitalocean.nix +++ b/pkgs/applications/networking/cluster/nixops/plugins/nixops-digitalocean.nix @@ -1,11 +1,12 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, unstableGitUpdater -, poetry-core -, nixops -, python-digitalocean -, pythonOlder +{ + lib, + buildPythonPackage, + fetchFromGitHub, + unstableGitUpdater, + poetry-core, + nixops, + python-digitalocean, + pythonOlder, }: buildPythonPackage { @@ -42,7 +43,7 @@ buildPythonPackage { pythonImportsCheck = [ "nixops_digitalocean" ]; - passthru.updateScript = unstableGitUpdater {}; + passthru.updateScript = unstableGitUpdater { }; meta = with lib; { description = "NixOps Digitalocean plugin"; diff --git a/pkgs/applications/networking/cluster/nixops/plugins/nixops-encrypted-links.nix b/pkgs/applications/networking/cluster/nixops/plugins/nixops-encrypted-links.nix index 8b890157a22218..5a7e261e8661e4 100644 --- a/pkgs/applications/networking/cluster/nixops/plugins/nixops-encrypted-links.nix +++ b/pkgs/applications/networking/cluster/nixops/plugins/nixops-encrypted-links.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, unstableGitUpdater -, poetry-core -, nixops +{ + lib, + buildPythonPackage, + fetchFromGitHub, + unstableGitUpdater, + poetry-core, + nixops, }: buildPythonPackage { @@ -34,7 +35,7 @@ buildPythonPackage { pythonImportsCheck = [ "nixops_encrypted_links" ]; - passthru.updateScript = unstableGitUpdater {}; + passthru.updateScript = unstableGitUpdater { }; meta = with lib; { description = "EncryptedLinksTo from Nixops 1 module port"; diff --git a/pkgs/applications/networking/cluster/nixops/plugins/nixops-hercules-ci.nix b/pkgs/applications/networking/cluster/nixops/plugins/nixops-hercules-ci.nix index 04044b94da0fdd..5ac5cb6a53f062 100644 --- a/pkgs/applications/networking/cluster/nixops/plugins/nixops-hercules-ci.nix +++ b/pkgs/applications/networking/cluster/nixops/plugins/nixops-hercules-ci.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, unstableGitUpdater -, poetry-core -, nixops +{ + lib, + buildPythonPackage, + fetchFromGitHub, + unstableGitUpdater, + poetry-core, + nixops, }: buildPythonPackage { @@ -28,7 +29,7 @@ buildPythonPackage { pythonImportsCheck = [ "nixops_hercules_ci" ]; - passthru.updateScript = unstableGitUpdater {}; + passthru.updateScript = unstableGitUpdater { }; meta = with lib; { description = "Use Hercules CI as a NixOps backend"; diff --git a/pkgs/applications/networking/cluster/nixops/plugins/nixops-vbox.nix b/pkgs/applications/networking/cluster/nixops/plugins/nixops-vbox.nix index 3d712e5c23978a..ee071316d28d10 100644 --- a/pkgs/applications/networking/cluster/nixops/plugins/nixops-vbox.nix +++ b/pkgs/applications/networking/cluster/nixops/plugins/nixops-vbox.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, unstableGitUpdater -, poetry-core -, nixops +{ + lib, + buildPythonPackage, + fetchFromGitHub, + unstableGitUpdater, + poetry-core, + nixops, }: buildPythonPackage { diff --git a/pkgs/applications/networking/cluster/nixops/plugins/nixos-modules-contrib.nix b/pkgs/applications/networking/cluster/nixops/plugins/nixos-modules-contrib.nix index a3039482c8f1ad..fc6f06460decd6 100644 --- a/pkgs/applications/networking/cluster/nixops/plugins/nixos-modules-contrib.nix +++ b/pkgs/applications/networking/cluster/nixops/plugins/nixos-modules-contrib.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, unstableGitUpdater -, poetry-core -, nixops +{ + lib, + buildPythonPackage, + fetchFromGitHub, + unstableGitUpdater, + poetry-core, + nixops, }: buildPythonPackage { @@ -34,7 +35,7 @@ buildPythonPackage { pythonImportsCheck = [ "nixos_modules_contrib" ]; - passthru.updateScript = unstableGitUpdater {}; + passthru.updateScript = unstableGitUpdater { }; meta = with lib; { description = "Useful NixOS modules which may not belong in the Nixpkgs repository itself"; diff --git a/pkgs/applications/networking/cluster/nixops/unwrapped.nix b/pkgs/applications/networking/cluster/nixops/unwrapped.nix index 7f00babc15e4fd..4527ed9121e01a 100644 --- a/pkgs/applications/networking/cluster/nixops/unwrapped.nix +++ b/pkgs/applications/networking/cluster/nixops/unwrapped.nix @@ -1,14 +1,15 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, unstableGitUpdater -, poetry-core -, sphinx -, pluggy -, prettytable -, typeguard -, typing-extensions -, nixosTests +{ + lib, + buildPythonApplication, + fetchFromGitHub, + unstableGitUpdater, + poetry-core, + sphinx, + pluggy, + prettytable, + typeguard, + typing-extensions, + nixosTests, }: buildPythonApplication rec { @@ -24,7 +25,9 @@ buildPythonApplication rec { }; postPatch = '' - substituteInPlace nixops/args.py --replace "@version@" "${version}-pre-${lib.substring 0 7 src.rev or "dirty"}" + substituteInPlace nixops/args.py --replace "@version@" "${version}-pre-${ + lib.substring 0 7 src.rev or "dirty" + }" ''; nativeBuildInputs = [ @@ -60,7 +63,10 @@ buildPythonApplication rec { description = "Tool for deploying to NixOS machines in a network or cloud"; homepage = "https://github.com/NixOS/nixops"; license = licenses.lgpl3Only; - maintainers = with lib.maintainers; [ aminechikhaoui roberth ]; + maintainers = with lib.maintainers; [ + aminechikhaoui + roberth + ]; platforms = lib.platforms.unix; mainProgram = "nixops"; }; diff --git a/pkgs/applications/networking/cluster/nomad/default.nix b/pkgs/applications/networking/cluster/nomad/default.nix index f20eedd3ea4469..6544baff55bed2 100644 --- a/pkgs/applications/networking/cluster/nomad/default.nix +++ b/pkgs/applications/networking/cluster/nomad/default.nix @@ -1,58 +1,83 @@ -{ lib -, buildGoModule -, buildGo122Module -, buildGo123Module -, fetchFromGitHub -, nixosTests -, installShellFiles +{ + lib, + buildGoModule, + buildGo122Module, + buildGo123Module, + fetchFromGitHub, + nixosTests, + installShellFiles, }: let generic = - { buildGoModule, version, sha256, vendorHash, license, ... }@attrs: - let attrs' = builtins.removeAttrs attrs [ "buildGoModule" "version" "sha256" "vendorHash" "license" ]; - in - buildGoModule (rec { - pname = "nomad"; - inherit version vendorHash; - - subPackages = [ "." ]; - - src = fetchFromGitHub { - owner = "hashicorp"; - repo = pname; - rev = "v${version}"; - inherit sha256; - }; - - nativeBuildInputs = [ installShellFiles ]; - - ldflags = [ - "-X github.com/hashicorp/nomad/version.Version=${version}" - "-X github.com/hashicorp/nomad/version.VersionPrerelease=" - "-X github.com/hashicorp/nomad/version.BuildDate=1970-01-01T00:00:00Z" + { + buildGoModule, + version, + sha256, + vendorHash, + license, + ... + }@attrs: + let + attrs' = builtins.removeAttrs attrs [ + "buildGoModule" + "version" + "sha256" + "vendorHash" + "license" ]; - - # ui: - # Nomad release commits include the compiled version of the UI, but the file - # is only included if we build with the ui tag. - tags = [ "ui" ]; - - postInstall = '' - echo "complete -C $out/bin/nomad nomad" > nomad.bash - installShellCompletion nomad.bash - ''; - - meta = with lib; { - homepage = "https://www.nomadproject.io/"; - description = "Distributed, Highly Available, Datacenter-Aware Scheduler"; - mainProgram = "nomad"; - inherit license; - maintainers = with maintainers; [ rushmorem pradeepchhetri techknowlogick cottand ]; - }; - } // attrs'); - - throwUnsupportaed = version: "${version} is no longer supported upstream. You can switch to using a newer version of the nomad package, or revert to older nixpkgs if you cannot upgrade"; + in + buildGoModule ( + rec { + pname = "nomad"; + inherit version vendorHash; + + subPackages = [ "." ]; + + src = fetchFromGitHub { + owner = "hashicorp"; + repo = pname; + rev = "v${version}"; + inherit sha256; + }; + + nativeBuildInputs = [ installShellFiles ]; + + ldflags = [ + "-X github.com/hashicorp/nomad/version.Version=${version}" + "-X github.com/hashicorp/nomad/version.VersionPrerelease=" + "-X github.com/hashicorp/nomad/version.BuildDate=1970-01-01T00:00:00Z" + ]; + + # ui: + # Nomad release commits include the compiled version of the UI, but the file + # is only included if we build with the ui tag. + tags = [ "ui" ]; + + postInstall = '' + echo "complete -C $out/bin/nomad nomad" > nomad.bash + installShellCompletion nomad.bash + ''; + + meta = with lib; { + homepage = "https://www.nomadproject.io/"; + description = "Distributed, Highly Available, Datacenter-Aware Scheduler"; + mainProgram = "nomad"; + inherit license; + maintainers = with maintainers; [ + rushmorem + pradeepchhetri + techknowlogick + cottand + ]; + }; + } + // attrs' + ); + + throwUnsupportaed = + version: + "${version} is no longer supported upstream. You can switch to using a newer version of the nomad package, or revert to older nixpkgs if you cannot upgrade"; in rec { # Nomad never updates major go versions within a release series and is unsupported diff --git a/pkgs/applications/networking/cluster/rke2/builder.nix b/pkgs/applications/networking/cluster/rke2/builder.nix index 9274d127f889bc..31d4d9d3cb3665 100644 --- a/pkgs/applications/networking/cluster/rke2/builder.nix +++ b/pkgs/applications/networking/cluster/rke2/builder.nix @@ -1,17 +1,48 @@ -lib: { rke2Version, rke2Commit, rke2TarballHash, rke2VendorHash, updateScript -, k8sImageTag, etcdVersion, pauseVersion, ccmVersion, dockerizedVersion, ... }: +lib: +{ + rke2Version, + rke2Commit, + rke2TarballHash, + rke2VendorHash, + updateScript, + k8sImageTag, + etcdVersion, + pauseVersion, + ccmVersion, + dockerizedVersion, + ... +}: # Build dependencies -{ lib, stdenv, buildGoModule, go, makeWrapper, fetchzip - -# Runtime dependencies -, procps, coreutils, util-linux, ethtool, socat, iptables, bridge-utils, iproute2, kmod, lvm2 - -# Killall Script dependencies -, systemd, gnugrep, gnused - -# Testing dependencies -, nixosTests, testers, rke2 +{ + lib, + stdenv, + buildGoModule, + go, + makeWrapper, + fetchzip, + + # Runtime dependencies + procps, + coreutils, + util-linux, + ethtool, + socat, + iptables, + bridge-utils, + iproute2, + kmod, + lvm2, + + # Killall Script dependencies + systemd, + gnugrep, + gnused, + + # Testing dependencies + nixosTests, + testers, + rke2, }: buildGoModule rec { @@ -77,7 +108,13 @@ buildGoModule rec { install -D ./bundle/bin/rke2-killall.sh $out/bin/rke2-killall.sh wrapProgram $out/bin/rke2-killall.sh \ - --prefix PATH : ${lib.makeBinPath [ systemd gnugrep gnused ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + systemd + gnugrep + gnused + ] + } \ --prefix PATH : ${lib.makeBinPath buildInputs} ''; @@ -85,21 +122,26 @@ buildGoModule rec { passthru.updateScript = updateScript; - passthru.tests = { - version = testers.testVersion { - package = rke2; - version = "v${version}"; + passthru.tests = + { + version = testers.testVersion { + package = rke2; + version = "v${version}"; + }; + } + // lib.optionalAttrs stdenv.hostPlatform.isLinux { + inherit (nixosTests) rke2; }; - } // lib.optionalAttrs stdenv.hostPlatform.isLinux { - inherit (nixosTests) rke2; - }; meta = with lib; { homepage = "https://github.com/rancher/rke2"; description = "RKE2, also known as RKE Government, is Rancher's next-generation Kubernetes distribution"; changelog = "https://github.com/rancher/rke2/releases/tag/v${version}"; license = licenses.asl20; - maintainers = with maintainers; [ zimbatm zygot ]; + maintainers = with maintainers; [ + zimbatm + zygot + ]; mainProgram = "rke2"; platforms = platforms.linux; }; diff --git a/pkgs/applications/networking/cluster/rke2/default.nix b/pkgs/applications/networking/cluster/rke2/default.nix index fc65ac86947317..c31ce510a2d044 100644 --- a/pkgs/applications/networking/cluster/rke2/default.nix +++ b/pkgs/applications/networking/cluster/rke2/default.nix @@ -5,15 +5,33 @@ let extraArgs = builtins.removeAttrs args [ "callPackage" ]; in { - rke2_stable = common ((import ./stable/versions.nix) // { - updateScript = [ ./update-script.sh "stable" ]; - }) extraArgs; + rke2_stable = common ( + (import ./stable/versions.nix) + // { + updateScript = [ + ./update-script.sh + "stable" + ]; + } + ) extraArgs; - rke2_latest = common ((import ./latest/versions.nix) // { - updateScript = [ ./update-script.sh "latest" ]; - }) extraArgs; + rke2_latest = common ( + (import ./latest/versions.nix) + // { + updateScript = [ + ./update-script.sh + "latest" + ]; + } + ) extraArgs; - rke2_testing = common ((import ./testing/versions.nix) // { - updateScript = [ ./update-script.sh "testing" ]; - }) extraArgs; + rke2_testing = common ( + (import ./testing/versions.nix) + // { + updateScript = [ + ./update-script.sh + "testing" + ]; + } + ) extraArgs; } diff --git a/pkgs/applications/networking/cluster/sonobuoy/default.nix b/pkgs/applications/networking/cluster/sonobuoy/default.nix index e86d9c920c3a62..449e315851f00e 100644 --- a/pkgs/applications/networking/cluster/sonobuoy/default.nix +++ b/pkgs/applications/networking/cluster/sonobuoy/default.nix @@ -1,16 +1,25 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, sonobuoy }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + sonobuoy, +}: # SHA of ${version} for the tool's help output. Unfortunately this is needed in build flags. # The update script can update this automatically, the comment is used to find the line. -let rev = "cc22d58f4c8b5a155bd1778cd3702eca5ad43e05"; # update-commit-sha +let + rev = "cc22d58f4c8b5a155bd1778cd3702eca5ad43e05"; # update-commit-sha in buildGoModule rec { pname = "sonobuoy"; version = "0.57.2"; # Do not forget to update `rev` above ldflags = - let t = "github.com/vmware-tanzu/sonobuoy"; - in [ + let + t = "github.com/vmware-tanzu/sonobuoy"; + in + [ "-s" "-X ${t}/pkg/buildinfo.Version=v${version}" "-X ${t}/pkg/buildinfo.GitSHA=${rev}" @@ -49,6 +58,10 @@ buildGoModule rec { changelog = "https://github.com/vmware-tanzu/sonobuoy/releases/tag/v${version}"; license = licenses.asl20; mainProgram = "sonobuoy"; - maintainers = with maintainers; [ carlosdagos saschagrunert wilsonehusin ]; + maintainers = with maintainers; [ + carlosdagos + saschagrunert + wilsonehusin + ]; }; } diff --git a/pkgs/applications/networking/cluster/spark/default.nix b/pkgs/applications/networking/cluster/spark/default.nix index 86e98c3a419d0a..f6dab13a787f0f 100644 --- a/pkgs/applications/networking/cluster/spark/default.nix +++ b/pkgs/applications/networking/cluster/spark/default.nix @@ -1,25 +1,47 @@ -{ lib -, stdenv -, fetchzip -, makeWrapper -, python3 -, hadoop -, RSupport ? true -, R -, nixosTests +{ + lib, + stdenv, + fetchzip, + makeWrapper, + python3, + hadoop, + RSupport ? true, + R, + nixosTests, }: let - spark = { pname, version, hash, extraMeta ? {}, pysparkPython ? python3 }: + spark = + { + pname, + version, + hash, + extraMeta ? { }, + pysparkPython ? python3, + }: stdenv.mkDerivation (finalAttrs: { - inherit pname version hash hadoop R pysparkPython; + inherit + pname + version + hash + hadoop + R + pysparkPython + ; inherit (finalAttrs.hadoop) jdk; src = fetchzip { - url = with finalAttrs; "mirror://apache/spark/${pname}-${version}/${pname}-${version}-bin-without-hadoop.tgz"; + url = + with finalAttrs; + "mirror://apache/spark/${pname}-${version}/${pname}-${version}-bin-without-hadoop.tgz"; inherit (finalAttrs) hash; }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = with finalAttrs; [ jdk pysparkPython ] + buildInputs = + with finalAttrs; + [ + jdk + pysparkPython + ] ++ lib.optional RSupport finalAttrs.R; installPhase = '' @@ -30,10 +52,8 @@ let --run "[ -z $SPARK_DIST_CLASSPATH ] && export SPARK_DIST_CLASSPATH=$(${finalAttrs.hadoop}/bin/hadoop classpath)" \ ${lib.optionalString RSupport ''--set SPARKR_R_SHELL "${finalAttrs.R}/bin/R"''} \ --prefix PATH : "${ - lib.makeBinPath ( - [ finalAttrs.pysparkPython ] ++ - (lib.optionals RSupport [ finalAttrs.R ]) - )}" + lib.makeBinPath ([ finalAttrs.pysparkPython ] ++ (lib.optionals RSupport [ finalAttrs.R ])) + }" done ln -s ${finalAttrs.hadoop} "$out/opt/hadoop" ${lib.optionalString RSupport ''ln -s ${finalAttrs.R} "$out/opt/R"''} @@ -44,9 +64,11 @@ let sparkPackage = finalAttrs.finalPackage; }; # Add python packages to PYSPARK_PYTHON - withPythonPackages = f: finalAttrs.finalPackage.overrideAttrs (old: { - pysparkPython = old.pysparkPython.withPackages f; - }); + withPythonPackages = + f: + finalAttrs.finalPackage.overrideAttrs (old: { + pysparkPython = old.pysparkPython.withPackages f; + }); }; meta = { @@ -55,7 +77,12 @@ let sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; license = lib.licenses.asl20; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ thoughtpolice offline kamilchm illustris ]; + maintainers = with lib.maintainers; [ + thoughtpolice + offline + kamilchm + illustris + ]; } // extraMeta; }); in diff --git a/pkgs/applications/networking/cluster/terraform-landscape/default.nix b/pkgs/applications/networking/cluster/terraform-landscape/default.nix index 903aa9abb6e2bf..637a5d5262305a 100644 --- a/pkgs/applications/networking/cluster/terraform-landscape/default.nix +++ b/pkgs/applications/networking/cluster/terraform-landscape/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "terraform_landscape"; @@ -10,9 +14,13 @@ bundlerApp { meta = with lib; { description = "Improve Terraform's plan output to be easier to read and understand"; - homepage = "https://github.com/coinbase/terraform-landscape"; - license = with licenses; asl20; - maintainers = with maintainers; [ mbode manveru nicknovitski ]; - platforms = platforms.unix; + homepage = "https://github.com/coinbase/terraform-landscape"; + license = with licenses; asl20; + maintainers = with maintainers; [ + mbode + manveru + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/applications/networking/cluster/terraform-landscape/gemset.nix b/pkgs/applications/networking/cluster/terraform-landscape/gemset.nix index bf3767486eaf17..9b3dafac634014 100644 --- a/pkgs/applications/networking/cluster/terraform-landscape/gemset.nix +++ b/pkgs/applications/networking/cluster/terraform-landscape/gemset.nix @@ -1,16 +1,16 @@ { colorize = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "133rqj85n400qk6g3dhf2bmfws34mak1wqihvh3bgy9jhajw580b"; type = "gem"; }; version = "0.8.1"; }; commander = { - dependencies = ["highline"]; + dependencies = [ "highline" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11sd2sb0id2dbxkv4pvymdiia1xxhms45kh4nr8mryqybad0fwwf"; type = "gem"; }; @@ -18,7 +18,7 @@ }; diffy = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "119imrkn01agwhx5raxhknsi331y5i4yda7r0ws0an6905ximzjg"; type = "gem"; }; @@ -26,7 +26,7 @@ }; highline = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01ib7jp85xjc4gh4jg0wyzllm46hwv8p0w1m4c75pbgi41fps50y"; type = "gem"; }; @@ -34,25 +34,30 @@ }; polyglot = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bqnxwyip623d8pr29rg6m8r0hdg08fpr2yb74f46rn1wgsnxmjr"; type = "gem"; }; version = "0.3.5"; }; terraform_landscape = { - dependencies = ["colorize" "commander" "diffy" "treetop"]; + dependencies = [ + "colorize" + "commander" + "diffy" + "treetop" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1i93pih7r6zcqpjhsmvkpfkgbh0l66c60i6fkiymq7vy2xd6wnns"; type = "gem"; }; version = "0.2.1"; }; treetop = { - dependencies = ["polyglot"]; + dependencies = [ "polyglot" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0g31pijhnv7z960sd09lckmw9h8rs3wmc8g4ihmppszxqm99zpv7"; type = "gem"; }; diff --git a/pkgs/applications/networking/cluster/terraform/default.nix b/pkgs/applications/networking/cluster/terraform/default.nix index 49a4042c2215d6..f3980a456b9cf8 100644 --- a/pkgs/applications/networking/cluster/terraform/default.nix +++ b/pkgs/applications/networking/cluster/terraform/default.nix @@ -1,86 +1,105 @@ -{ stdenv -, lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, coreutils -, runCommand -, runtimeShell -, writeText -, terraform-providers -, installShellFiles +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + coreutils, + runCommand, + runtimeShell, + writeText, + terraform-providers, + installShellFiles, }: let - generic = { version, hash, vendorHash ? null, ... }@attrs: - let attrs' = builtins.removeAttrs attrs [ "version" "hash" "vendorHash" ]; + generic = + { + version, + hash, + vendorHash ? null, + ... + }@attrs: + let + attrs' = builtins.removeAttrs attrs [ + "version" + "hash" + "vendorHash" + ]; in - buildGoModule ({ - pname = "terraform"; - inherit version vendorHash; - - src = fetchFromGitHub { - owner = "hashicorp"; - repo = "terraform"; - rev = "v${version}"; - inherit hash; - }; - - ldflags = [ "-s" "-w" "-X 'github.com/hashicorp/terraform/version.dev=no'" ]; - - postConfigure = '' - # speakeasy hardcodes /bin/stty https://github.com/bgentry/speakeasy/issues/22 - substituteInPlace vendor/github.com/bgentry/speakeasy/speakeasy_unix.go \ - --replace-fail "/bin/stty" "${coreutils}/bin/stty" - ''; + buildGoModule ( + { + pname = "terraform"; + inherit version vendorHash; + + src = fetchFromGitHub { + owner = "hashicorp"; + repo = "terraform"; + rev = "v${version}"; + inherit hash; + }; + + ldflags = [ + "-s" + "-w" + "-X 'github.com/hashicorp/terraform/version.dev=no'" + ]; - nativeBuildInputs = [ installShellFiles ]; + postConfigure = '' + # speakeasy hardcodes /bin/stty https://github.com/bgentry/speakeasy/issues/22 + substituteInPlace vendor/github.com/bgentry/speakeasy/speakeasy_unix.go \ + --replace-fail "/bin/stty" "${coreutils}/bin/stty" + ''; - postInstall = '' - # https://github.com/posener/complete/blob/9a4745ac49b29530e07dc2581745a218b646b7a3/cmd/install/bash.go#L8 - installShellCompletion --bash --name terraform <(echo complete -C terraform terraform) - ''; + nativeBuildInputs = [ installShellFiles ]; - preCheck = '' - export HOME=$TMPDIR - export TF_SKIP_REMOTE_TESTS=1 - ''; + postInstall = '' + # https://github.com/posener/complete/blob/9a4745ac49b29530e07dc2581745a218b646b7a3/cmd/install/bash.go#L8 + installShellCompletion --bash --name terraform <(echo complete -C terraform terraform) + ''; - subPackages = [ "." ]; - - meta = with lib; { - description = - "Tool for building, changing, and versioning infrastructure"; - homepage = "https://www.terraform.io/"; - changelog = "https://github.com/hashicorp/terraform/blob/v${version}/CHANGELOG.md"; - license = licenses.bsl11; - maintainers = with maintainers; [ - Chili-Man - kalbasit - timstott - zimbatm - zowoq - techknowlogick - qjoly - ]; - mainProgram = "terraform"; - }; - } // attrs'); + preCheck = '' + export HOME=$TMPDIR + export TF_SKIP_REMOTE_TESTS=1 + ''; - pluggable = terraform: + subPackages = [ "." ]; + + meta = with lib; { + description = "Tool for building, changing, and versioning infrastructure"; + homepage = "https://www.terraform.io/"; + changelog = "https://github.com/hashicorp/terraform/blob/v${version}/CHANGELOG.md"; + license = licenses.bsl11; + maintainers = with maintainers; [ + Chili-Man + kalbasit + timstott + zimbatm + zowoq + techknowlogick + qjoly + ]; + mainProgram = "terraform"; + }; + } + // attrs' + ); + + pluggable = + terraform: let - withPlugins = plugins: + withPlugins = + plugins: let actualPlugins = plugins terraform.plugins; # Wrap PATH of plugins propagatedBuildInputs, plugins may have runtime dependencies on external binaries - wrapperInputs = lib.unique (lib.flatten - (lib.catAttrs "propagatedBuildInputs" - (builtins.filter (x: x != null) actualPlugins))); + wrapperInputs = lib.unique ( + lib.flatten (lib.catAttrs "propagatedBuildInputs" (builtins.filter (x: x != null) actualPlugins)) + ); passthru = { - withPlugins = newplugins: - withPlugins (x: newplugins x ++ actualPlugins); + withPlugins = newplugins: withPlugins (x: newplugins x ++ actualPlugins); full = withPlugins (p: lib.filter lib.isDerivation (lib.attrValues p.actualProviders)); # Expose wrappers around the override* functions of the terraform @@ -103,54 +122,54 @@ let # 3. Specifying overrides on the wrapper is unsupported. # # See nixpkgs#158620 for details. - overrideDerivation = f: - (pluggable (terraform.overrideDerivation f)).withPlugins plugins; - overrideAttrs = f: - (pluggable (terraform.overrideAttrs f)).withPlugins plugins; - override = x: - (pluggable (terraform.override x)).withPlugins plugins; + overrideDerivation = f: (pluggable (terraform.overrideDerivation f)).withPlugins plugins; + overrideAttrs = f: (pluggable (terraform.overrideAttrs f)).withPlugins plugins; + override = x: (pluggable (terraform.override x)).withPlugins plugins; }; - # Don't bother wrapping unless we actually have plugins, since the wrapper will stop automatic downloading - # of plugins, which might be counterintuitive if someone just wants a vanilla Terraform. in + # Don't bother wrapping unless we actually have plugins, since the wrapper will stop automatic downloading + # of plugins, which might be counterintuitive if someone just wants a vanilla Terraform. if actualPlugins == [ ] then - terraform.overrideAttrs - (orig: { passthru = orig.passthru // passthru; }) + terraform.overrideAttrs (orig: { + passthru = orig.passthru // passthru; + }) else - lib.appendToName "with-plugins" (stdenv.mkDerivation { - inherit (terraform) meta pname version; - nativeBuildInputs = [ makeWrapper ]; - - # Expose the passthru set with the override functions - # defined above, as well as any passthru values already - # set on `terraform` at this point (relevant in case a - # user overrides attributes). - passthru = terraform.passthru // passthru; - - buildCommand = '' - # Create wrappers for terraform plugins because Terraform only - # walks inside of a tree of files. - for providerDir in ${toString actualPlugins} - do - for file in $(find $providerDir/libexec/terraform-providers -type f) + lib.appendToName "with-plugins" ( + stdenv.mkDerivation { + inherit (terraform) meta pname version; + nativeBuildInputs = [ makeWrapper ]; + + # Expose the passthru set with the override functions + # defined above, as well as any passthru values already + # set on `terraform` at this point (relevant in case a + # user overrides attributes). + passthru = terraform.passthru // passthru; + + buildCommand = '' + # Create wrappers for terraform plugins because Terraform only + # walks inside of a tree of files. + for providerDir in ${toString actualPlugins} do - relFile=''${file#$providerDir/} - mkdir -p $out/$(dirname $relFile) - cat < $out/$relFile - #!${runtimeShell} - exec "$file" "$@" - WRAPPER - chmod +x $out/$relFile + for file in $(find $providerDir/libexec/terraform-providers -type f) + do + relFile=''${file#$providerDir/} + mkdir -p $out/$(dirname $relFile) + cat < $out/$relFile + #!${runtimeShell} + exec "$file" "$@" + WRAPPER + chmod +x $out/$relFile + done done - done - - # Create a wrapper for terraform to point it to the plugins dir. - mkdir -p $out/bin/ - makeWrapper "${terraform}/bin/terraform" "$out/bin/terraform" \ - --set NIX_TERRAFORM_PLUGIN_DIR $out/libexec/terraform-providers \ - --prefix PATH : "${lib.makeBinPath wrapperInputs}" - ''; - }); + + # Create a wrapper for terraform to point it to the plugins dir. + mkdir -p $out/bin/ + makeWrapper "${terraform}/bin/terraform" "$out/bin/terraform" \ + --set NIX_TERRAFORM_PLUGIN_DIR $out/libexec/terraform-providers \ + --prefix PATH : "${lib.makeBinPath wrapperInputs}" + ''; + } + ); in withPlugins (_: [ ]); @@ -185,15 +204,14 @@ rec { resource "random_id" "test" {} ''; terraform = terraform_1.withPlugins (p: [ p.random ]); - test = - runCommand "terraform-plugin-test" { buildInputs = [ terraform ]; } '' - set -e - # make it fail outside of sandbox - export HTTP_PROXY=http://127.0.0.1:0 HTTPS_PROXY=https://127.0.0.1:0 - cp ${mainTf} main.tf - terraform init - touch $out - ''; + test = runCommand "terraform-plugin-test" { buildInputs = [ terraform ]; } '' + set -e + # make it fail outside of sandbox + export HTTP_PROXY=http://127.0.0.1:0 HTTPS_PROXY=https://127.0.0.1:0 + cp ${mainTf} main.tf + terraform init + touch $out + ''; in test; diff --git a/pkgs/applications/networking/cluster/terraforming/default.nix b/pkgs/applications/networking/cluster/terraforming/default.nix index 85d522257cde39..68fa21239f5371 100644 --- a/pkgs/applications/networking/cluster/terraforming/default.nix +++ b/pkgs/applications/networking/cluster/terraforming/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerApp, bundlerUpdateScript, ruby }: +{ + lib, + bundlerApp, + bundlerUpdateScript, + ruby, +}: bundlerApp rec { inherit ruby; @@ -13,8 +18,8 @@ bundlerApp rec { inherit (ruby.meta) platforms; description = "Export existing AWS resources to Terraform style (tf, tfstate)"; - homepage = "https://github.com/dtan4/terraforming"; - license = with licenses; mit; + homepage = "https://github.com/dtan4/terraforming"; + license = with licenses; mit; maintainers = with maintainers; [ kalbasit ]; }; } diff --git a/pkgs/applications/networking/cluster/terraforming/gemset.nix b/pkgs/applications/networking/cluster/terraforming/gemset.nix index 9882efc29e806d..9f58d2977cf967 100644 --- a/pkgs/applications/networking/cluster/terraforming/gemset.nix +++ b/pkgs/applications/networking/cluster/terraforming/gemset.nix @@ -1,258 +1,331 @@ { aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jfki5ikfr8ln5cdgv4iv1643kax0bjpp29jh78chzy713274jh3"; type = "gem"; }; version = "1.1.1"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gn09cafg2n6gdc3ja80r3xjllly05r0m7x3w3b3rywir6k6ai4f"; type = "gem"; }; version = "1.436.0"; }; aws-sdk-autoscaling = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0br6hfi2i5rri8ivamkmnx00p640s24pqmp8s67sm5asvdfzx4vr"; type = "gem"; }; version = "1.59.0"; }; aws-sdk-cloudwatch = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xga00dn925rfgz4p2zf734aaik00dqb9psll27lg5626jd6xr0c"; type = "gem"; }; version = "1.50.0"; }; aws-sdk-core = { - dependencies = ["aws-eventstream" "aws-partitions" "aws-sigv4" "jmespath"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-eventstream" + "aws-partitions" + "aws-sigv4" + "jmespath" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1774xyfqf307qvh5npvf01948ayrviaadq576r4jxin6xvlg8j9z"; type = "gem"; }; version = "3.113.0"; }; aws-sdk-dynamodb = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dfsmkzv9cziykzc56g9pwxmbdqjpykxka3fq07b6iarzh38j1i3"; type = "gem"; }; version = "1.60.0"; }; aws-sdk-ec2 = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c7qqly2f94db3643xwjj9mcb34vilx11awbv40v2f8z7xisvvz3"; type = "gem"; }; version = "1.230.0"; }; aws-sdk-efs = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kmpz86sxkm6nzcf80nd65902fy29hz8lvx1kjwl5idx07ls8pnd"; type = "gem"; }; version = "1.39.0"; }; aws-sdk-elasticache = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05kn2k437rnsf9nkwc1x5i2klrasjgyk1pj89f2gb0za86swjcza"; type = "gem"; }; version = "1.54.0"; }; aws-sdk-elasticloadbalancing = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j3px8dn2yxsnmy010kfkwa1a2flbdxachmly20f436ysi3ql3v3"; type = "gem"; }; version = "1.31.0"; }; aws-sdk-elasticloadbalancingv2 = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16hknbqv5s1im04dch9kdbc79x072613imdih62w48mvsf12c1mm"; type = "gem"; }; version = "1.61.0"; }; aws-sdk-iam = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0x2768blsy8lpib9pi2f2d67flabar3bq6chmbj07iqzpwvpz569"; type = "gem"; }; version = "1.51.0"; }; aws-sdk-kms = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01pd0f4srsa65zl4zq4014p9j5yrr2yy9h9ab17g3w9d0qqm2vsh"; type = "gem"; }; version = "1.43.0"; }; aws-sdk-rds = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hwxgcka6bmzdn5pazss0fv8xgbbgas4h2cwpzwhkjkwhh23dx6a"; type = "gem"; }; version = "1.117.0"; }; aws-sdk-redshift = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sp186v00lj517hia6rsn28ph8rqknz9r79vbkbyh5fgrbh2j6bd"; type = "gem"; }; version = "1.58.0"; }; aws-sdk-route53 = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p9g0scw9c6qancdwvaw3kkj3pywchy2vl3qz2rqpjncqvj04pn5"; type = "gem"; }; version = "1.48.0"; }; aws-sdk-s3 = { - dependencies = ["aws-sdk-core" "aws-sdk-kms" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sdk-kms" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0iy2f9z43pc6fgwmga2cz8nf9gy2pwcw4jib141vp8z8dhylqj94"; type = "gem"; }; version = "1.93.0"; }; aws-sdk-sns = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pmxi871r2nkl6by89vsy05ahk8dr6hmkny56fycrby6r9kri9q4"; type = "gem"; }; version = "1.39.0"; }; aws-sdk-sqs = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01m2l8y4q4fixjvl70w5bi1ihmmx2y4krms9kkjwd3ch21y14hif"; type = "gem"; }; version = "1.38.0"; }; aws-sigv4 = { - dependencies = ["aws-eventstream"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-eventstream" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d9zhmi3mpfzkkpg7yw7s9r1dwk157kh9875j3c7gh6cy95lmmaw"; type = "gem"; }; version = "1.2.3"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d4wac0dcd1jf6kc57891glih9w57552zgqswgy74d1xhgnk0ngf"; type = "gem"; }; version = "1.4.0"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1raim9ddjh672m32psaa9niw67ywzjbxbdb8iijx3wv9k5b0pk2x"; type = "gem"; }; version = "1.12.2"; }; terraforming = { - dependencies = ["aws-sdk-autoscaling" "aws-sdk-cloudwatch" "aws-sdk-dynamodb" "aws-sdk-ec2" "aws-sdk-efs" "aws-sdk-elasticache" "aws-sdk-elasticloadbalancing" "aws-sdk-elasticloadbalancingv2" "aws-sdk-iam" "aws-sdk-kms" "aws-sdk-rds" "aws-sdk-redshift" "aws-sdk-route53" "aws-sdk-s3" "aws-sdk-sns" "aws-sdk-sqs" "multi_json" "thor"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "aws-sdk-autoscaling" + "aws-sdk-cloudwatch" + "aws-sdk-dynamodb" + "aws-sdk-ec2" + "aws-sdk-efs" + "aws-sdk-elasticache" + "aws-sdk-elasticloadbalancing" + "aws-sdk-elasticloadbalancingv2" + "aws-sdk-iam" + "aws-sdk-kms" + "aws-sdk-rds" + "aws-sdk-redshift" + "aws-sdk-route53" + "aws-sdk-s3" + "aws-sdk-sns" + "aws-sdk-sqs" + "multi_json" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03fyhqx6bxpbn26pbcz748gz7rh7q3r9r0jimq7vj07fl454fmwh"; type = "gem"; }; version = "0.18.0"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18yhlvmfya23cs3pvhr1qy38y41b6mhr5q9vwv5lrgk16wmf3jna"; type = "gem"; }; diff --git a/pkgs/applications/networking/cluster/terraspace/default.nix b/pkgs/applications/networking/cluster/terraspace/default.nix index da45541108f693..b849f4b106654f 100644 --- a/pkgs/applications/networking/cluster/terraspace/default.nix +++ b/pkgs/applications/networking/cluster/terraspace/default.nix @@ -1,11 +1,19 @@ -{ stdenv, lib, bundlerEnv, bundlerUpdateScript, makeWrapper, ruby }: +{ + stdenv, + lib, + bundlerEnv, + bundlerUpdateScript, + makeWrapper, + ruby, +}: let rubyEnv = bundlerEnv { inherit ruby; name = "terraspace"; - gemdir = ./.; + gemdir = ./.; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "terraspace"; version = (import ./gemset.nix).terraspace.version; @@ -25,9 +33,9 @@ in stdenv.mkDerivation { meta = with lib; { description = "Terraform framework that provides an organized structure, and keeps your code DRY"; mainProgram = "terraspace"; - homepage = "https://github.com/boltops-tools/terraspace"; - license = licenses.asl20; - platforms = ruby.meta.platforms; + homepage = "https://github.com/boltops-tools/terraspace"; + license = licenses.asl20; + platforms = ruby.meta.platforms; maintainers = with maintainers; [ mislavzanic ]; }; } diff --git a/pkgs/applications/networking/cluster/terraspace/gemset.nix b/pkgs/applications/networking/cluster/terraspace/gemset.nix index 606e450c427084..1a78094d37a585 100644 --- a/pkgs/applications/networking/cluster/terraspace/gemset.nix +++ b/pkgs/applications/networking/cluster/terraspace/gemset.nix @@ -1,522 +1,605 @@ { activesupport = { - dependencies = ["base64" "bigdecimal" "concurrent-ruby" "connection_pool" "drb" "i18n" "minitest" "mutex_m" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "bigdecimal" + "concurrent-ruby" + "connection_pool" + "drb" + "i18n" + "minitest" + "mutex_m" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0283wk1zxb76lg79dk501kcf5xy9h25qiw15m86s4nrfv11vqns5"; type = "gem"; }; version = "7.1.3.4"; }; aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gvdg4yx4p9av2glmp7vsxhs0n8fj1ga9kq2xdb8f95j7b04qhzi"; type = "gem"; }; version = "1.3.0"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03zb6x4x68y91gywsyi4a6hxy4pdyng8mnxwd858bhjfymml8kkf"; type = "gem"; }; version = "1.956.0"; }; aws-sdk-core = { - dependencies = ["aws-eventstream" "aws-partitions" "aws-sigv4" "jmespath"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-eventstream" + "aws-partitions" + "aws-sigv4" + "jmespath" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ihl7iwndl3jjy89sh427wf8mdb7ii76bsjf6fkxq9ha30nz4f3g"; type = "gem"; }; version = "3.201.1"; }; aws-sdk-kms = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "02g3l3lcyddqncrwjxgawxl33p2p715k1gbrdlgyiv0yvy88sn0k"; type = "gem"; }; version = "1.88.0"; }; aws-sdk-s3 = { - dependencies = ["aws-sdk-core" "aws-sdk-kms" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sdk-kms" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ika0xmmrkc7jiwdi5gqia5wywkcbw1nal2dhl436dkh38fxl0lk"; type = "gem"; }; version = "1.156.0"; }; aws-sigv4 = { - dependencies = ["aws-eventstream"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-eventstream" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g3w27wzjy4si6kp49w10as6ml6g6zl3xrfqs5ikpfciidv9kpc4"; type = "gem"; }; version = "1.8.0"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; cli-format = { - dependencies = ["activesupport" "text-table" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "text-table" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0rrjck5r25dlcg1gwz6pb5f4rllx77lg6a514a5l3lajfd95shm3"; type = "gem"; }; version = "0.6.1"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0skwdasxq7mnlcccn6aqabl7n9r3jd7k19ryzlzzip64cn4x572g"; type = "gem"; }; version = "1.3.3"; }; connection_pool = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; deep_merge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fjn4civid68a3zxnbgyjj6krs3l30dy8b4djpg6fpzrsyix7kl3"; type = "gem"; }; version = "1.2.2"; }; diff-lcs = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znxccz83m4xgpd239nyqxlifdb7m8rlfayk6s259186nkgj6ci7"; type = "gem"; }; version = "1.5.1"; }; dotenv = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0y24jabiz4cf9ni9vi4j8sab8b5phpf2mpw3981r0r94l4m6q0q8"; type = "gem"; }; version = "3.1.2"; }; drb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h5kbj9hvg5hb3c7l425zpds0vb42phvln2knab8nmazg2zp5m79"; type = "gem"; }; version = "2.2.1"; }; dsl_evaluator = { - dependencies = ["activesupport" "memoist" "rainbow" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "memoist" + "rainbow" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0hd079baa5pfyyc2wc9p5h82qjp7fnx0s0shn2i19ig186cizh2x"; type = "gem"; }; version = "0.3.2"; }; eventmachine = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wh9aqb0skz80fhfn66lbpr4f86ya2z5rx6gm5xlfhd05bj1ch4r"; type = "gem"; }; version = "1.2.7"; }; eventmachine-tail = { - dependencies = ["eventmachine"]; - groups = ["default"]; - platforms = []; + dependencies = [ "eventmachine" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0x5ly7mnfr6gibjyxz6lrxb4jbf05p0r8257qcgkf8rkwg9ynw0c"; type = "gem"; }; version = "0.6.5"; }; graph = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bwssjgl9nfq9jhn9bfc7pqfl2c2xi0wnpng66l029m03kmdq8k4"; type = "gem"; }; version = "2.11.1"; }; hcl_parser = { - dependencies = ["rhcl"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rhcl" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09d55i9y187xkw0fi0b5aq8wyzvq8w73ryi939dvzdzgss25m7jj"; type = "gem"; }; version = "0.2.2"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ffix518y7976qih9k1lgnc17i3v6yrlh0a3mckpxdb4wc2vrp16"; type = "gem"; }; version = "1.14.5"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cdw9vw2qly7q7r41s7phnac264rbsdqgj4l0h4nqgbjb157g393"; type = "gem"; }; version = "1.6.2"; }; memoist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0i9wpzix3sjhf6d9zw60dm4371iq8kyz7ckh2qapan2vyaim6b55"; type = "gem"; }; version = "0.16.2"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q1f2sdw3y3y9mnym9dhjgsjr72sq975cfg5c4yx7gwv8nmzbvhk"; type = "gem"; }; version = "2.8.7"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jj629q3vw5yn90q4di4dyb87pil4a8qfm2srhgy5nc8j2n33v1i"; type = "gem"; }; version = "5.24.1"; }; mutex_m = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ma093ayps1m92q845hmpk0dmadicvifkbf05rpq9pifhin0rvxn"; type = "gem"; }; version = "0.2.0"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vz1ychq2fhfqjgqdrx8bqkaxg5dzcgwnah00m57ydylczfy8pwk"; type = "gem"; }; version = "1.16.6"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "021s7maw0c4d9a6s07vbmllrzqsj2sgmrwimlh8ffkvwqdjrld09"; type = "gem"; }; version = "1.8.0"; }; rainbow = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0smwg4mii0fm38pyb5fddbmrdpifwv22zv3d3px2xx497am93503"; type = "gem"; }; version = "3.1.1"; }; render_me_pretty = { - dependencies = ["activesupport" "rainbow" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "rainbow" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0qx9pv0irkcqjx9f0mh5s6d9m0fck329bp845ryic34nsvnbsp4k"; type = "gem"; }; version = "0.9.0"; }; rexml = { - dependencies = ["strscan"]; - groups = ["default"]; - platforms = []; + dependencies = [ "strscan" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zr5qpa8lampaqzhdcjcvyqnrqcjl7439mqjlkjz43wdhmpnh4s5"; type = "gem"; }; version = "3.3.2"; }; rhcl = { - dependencies = ["deep_merge"]; - groups = ["default"]; - platforms = []; + dependencies = [ "deep_merge" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c7xp9y9438mnqrfrvjp1fwy2lk0b1ixz45qi2g2kbl91ilhn834"; type = "gem"; }; version = "0.1.0"; }; rspec = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14xrp8vq6i9zx37vh0yp4h9m0anx9paw200l1r5ad9fmq559346l"; type = "gem"; }; version = "3.13.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rspec-support" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k252n7s80bvjvpskgfm285a3djjjqyjcarlh3aq7a4dx2s94xsm"; type = "gem"; }; version = "3.13.0"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0022nxs9gqfhx35n4klibig770n0j31pnkd8anz00yvrvkdghk41"; type = "gem"; }; version = "3.13.1"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0f3vgp43hajw716vmgjv6f4ar6f97zf50snny6y3fy9kkj4qjw88"; type = "gem"; }; version = "3.13.1"; }; rspec-support = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03z7gpqz5xkw9rf53835pa8a9vgj4lic54rnix9vfwmp2m7pv1s8"; type = "gem"; }; version = "3.13.1"; }; rspec-terraspace = { - dependencies = ["activesupport" "memoist" "rainbow" "rspec" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "memoist" + "rainbow" + "rspec" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1q8dlamvd11d5q2p6yvq0gkm3smz42mzsva4qimim7jn2yjbh58y"; type = "gem"; }; version = "0.3.3"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; strscan = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mamrl7pxacbc79ny5hzmakc9grbjysm3yy6119ppgsg44fsif01"; type = "gem"; }; version = "3.1.0"; }; terraspace = { - dependencies = ["activesupport" "cli-format" "deep_merge" "dotenv" "dsl_evaluator" "eventmachine-tail" "graph" "hcl_parser" "memoist" "rainbow" "render_me_pretty" "rexml" "rspec-terraspace" "terraspace-bundler" "thor" "tty-tree" "zeitwerk" "zip_folder"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "cli-format" + "deep_merge" + "dotenv" + "dsl_evaluator" + "eventmachine-tail" + "graph" + "hcl_parser" + "memoist" + "rainbow" + "render_me_pretty" + "rexml" + "rspec-terraspace" + "terraspace-bundler" + "thor" + "tty-tree" + "zeitwerk" + "zip_folder" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zmnp71fwcj453cafmb8iicbk93flk98wh0wdk0q9xd3mgm3qh6x"; type = "gem"; }; version = "2.2.17"; }; terraspace-bundler = { - dependencies = ["activesupport" "aws-sdk-s3" "dsl_evaluator" "memoist" "nokogiri" "rainbow" "rubyzip" "thor" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "aws-sdk-s3" + "dsl_evaluator" + "memoist" + "nokogiri" + "rainbow" + "rubyzip" + "thor" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0kn6is7zqlw8l4njj4pjwbdi95w651nz3qvqgc3vw07rchs08nnx"; type = "gem"; }; version = "0.5.0"; }; text-table = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06yhlnb49fn0fhkmi6lrziyv2hd42gcm2zi3sggm2qab48qxn94j"; type = "gem"; }; version = "1.2.4"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vq1fjp45az9hfp6fxljhdrkv75cvbab1jfrwcw738pnsiqk8zps"; type = "gem"; }; version = "1.3.1"; }; tilt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kds7wkxmb038cwp6ravnwn8k65ixc68wpm8j5jx5bhx8ndg4x6z"; type = "gem"; }; version = "2.4.0"; }; tty-tree = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0w3nh9yppb7zaswa7d9hnhf6k64z5d3jd8xvpyg2mjfrzcw9rbgs"; type = "gem"; }; version = "0.4.0"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; zeitwerk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08cfb35232p9s1r4jqv8wacv38vxh699mgbr9y03ga89gx9lipqp"; type = "gem"; }; version = "2.6.16"; }; zip_folder = { - dependencies = ["rubyzip"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rubyzip" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1884a1ixy7bzm9yp8cjikhdfcn8205p4fsjq894ilby8i1whl58k"; type = "gem"; }; diff --git a/pkgs/applications/networking/cluster/tftui/default.nix b/pkgs/applications/networking/cluster/tftui/default.nix index 097476446676cf..41a8fc4cbe745f 100644 --- a/pkgs/applications/networking/cluster/tftui/default.nix +++ b/pkgs/applications/networking/cluster/tftui/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, makeWrapper -, python3 -, enableUsageTracking ? false +{ + lib, + fetchFromGitHub, + makeWrapper, + python3, + enableUsageTracking ? false, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/applications/networking/cluster/timoni/default.nix b/pkgs/applications/networking/cluster/timoni/default.nix index 26be204a06f340..74b54c7b84a53f 100644 --- a/pkgs/applications/networking/cluster/timoni/default.nix +++ b/pkgs/applications/networking/cluster/timoni/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/applications/networking/cluster/tubekit/default.nix b/pkgs/applications/networking/cluster/tubekit/default.nix index 1e4895118be15a..7dcbf5c6c97509 100644 --- a/pkgs/applications/networking/cluster/tubekit/default.nix +++ b/pkgs/applications/networking/cluster/tubekit/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/applications/networking/cluster/tubekit/wrapper.nix b/pkgs/applications/networking/cluster/tubekit/wrapper.nix index d12f69adbfb9c8..2475697e207815 100644 --- a/pkgs/applications/networking/cluster/tubekit/wrapper.nix +++ b/pkgs/applications/networking/cluster/tubekit/wrapper.nix @@ -1,16 +1,18 @@ -{ runCommand -, makeWrapper -, tubekit-unwrapped -, pname ? "tubekit" -, version ? tubekit-unwrapped.version -, kubectl +{ + runCommand, + makeWrapper, + tubekit-unwrapped, + pname ? "tubekit", + version ? tubekit-unwrapped.version, + kubectl, }: runCommand "${pname}-${version}" -{ - inherit pname version; - inherit (tubekit-unwrapped) src meta; - nativeBuildInputs = [ makeWrapper ]; -} '' - mkdir -p $out/bin - makeWrapper ${tubekit-unwrapped}/bin/tubectl $out/bin/tubectl --set-default TUBEKIT_KUBECTL ${kubectl}/bin/kubectl -'' + { + inherit pname version; + inherit (tubekit-unwrapped) src meta; + nativeBuildInputs = [ makeWrapper ]; + } + '' + mkdir -p $out/bin + makeWrapper ${tubekit-unwrapped}/bin/tubectl $out/bin/tubectl --set-default TUBEKIT_KUBECTL ${kubectl}/bin/kubectl + '' diff --git a/pkgs/applications/networking/compactor/default.nix b/pkgs/applications/networking/compactor/default.nix index 88f0b34fd27cfa..041c45f782f405 100644 --- a/pkgs/applications/networking/compactor/default.nix +++ b/pkgs/applications/networking/compactor/default.nix @@ -1,7 +1,28 @@ -{ lib, stdenv, fetchFromGitHub -, asciidoctor, autoreconfHook, pkg-config -, boost, libctemplate, libmaxminddb, libpcap, libtins, openssl, protobuf, xz, zlib, catch2 -, cbor-diag, cddl, diffutils, file, mktemp, netcat, tcpdump, wireshark-cli +{ + lib, + stdenv, + fetchFromGitHub, + asciidoctor, + autoreconfHook, + pkg-config, + boost, + libctemplate, + libmaxminddb, + libpcap, + libtins, + openssl, + protobuf, + xz, + zlib, + catch2, + cbor-diag, + cddl, + diffutils, + file, + mktemp, + netcat, + tcpdump, + wireshark-cli, }: stdenv.mkDerivation rec { @@ -67,10 +88,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Tools to capture DNS traffic and record it in C-DNS files"; - homepage = "https://dns-stats.org/"; - changelog = "https://github.com/dns-stats/compactor/raw/${version}/ChangeLog.txt"; - license = licenses.mpl20; + homepage = "https://dns-stats.org/"; + changelog = "https://github.com/dns-stats/compactor/raw/${version}/ChangeLog.txt"; + license = licenses.mpl20; maintainers = with maintainers; [ fdns ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/applications/networking/davmail/default.nix b/pkgs/applications/networking/davmail/default.nix index 5b262e405a8735..6f971f0c849f38 100644 --- a/pkgs/applications/networking/davmail/default.nix +++ b/pkgs/applications/networking/davmail/default.nix @@ -1,18 +1,19 @@ -{ stdenv -, fetchurl -, lib -, makeWrapper -, unzip -, glib -, gtk2 -, gtk3 -, jre -, libXtst -, coreutils -, gnugrep -, zulu -, preferGtk3 ? true -, preferZulu ? true +{ + stdenv, + fetchurl, + lib, + makeWrapper, + unzip, + glib, + gtk2, + gtk3, + jre, + libXtst, + coreutils, + gnugrep, + zulu, + preferGtk3 ? true, + preferZulu ? true, }: let @@ -35,7 +36,10 @@ stdenv.mkDerivation rec { sourceRoot = "."; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; installPhase = '' runHook preInstall @@ -44,8 +48,20 @@ stdenv.mkDerivation rec { cp -vR ./* $out/share/davmail makeWrapper $out/share/davmail/davmail $out/bin/davmail \ --set-default JAVA_OPTS "-Xmx512M -Dsun.net.inetaddr.ttl=60 -Djdk.gtk.version=${lib.versions.major gtk'.version}" \ - --prefix PATH : ${lib.makeBinPath [ jre' coreutils gnugrep ]} \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ glib gtk' libXtst ]} + --prefix PATH : ${ + lib.makeBinPath [ + jre' + coreutils + gnugrep + ] + } \ + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + glib + gtk' + libXtst + ] + } runHook postInstall ''; diff --git a/pkgs/applications/networking/droopy/default.nix b/pkgs/applications/networking/droopy/default.nix index 35176db8b24156..0cbcdbe568d49a 100644 --- a/pkgs/applications/networking/droopy/default.nix +++ b/pkgs/applications/networking/droopy/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, wrapPython, fetchpatch }: +{ + stdenv, + lib, + fetchFromGitHub, + wrapPython, + fetchpatch, +}: stdenv.mkDerivation { pname = "droopy"; diff --git a/pkgs/applications/networking/dropbox/cli.nix b/pkgs/applications/networking/dropbox/cli.nix index 10e133ac4cab57..31eda100eb9735 100644 --- a/pkgs/applications/networking/dropbox/cli.nix +++ b/pkgs/applications/networking/dropbox/cli.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, substituteAll -, autoreconfHook -, pkg-config -, fetchurl -, python3 -, dropbox -, gtk4 -, nautilus -, gdk-pixbuf -, gobject-introspection +{ + lib, + stdenv, + substituteAll, + autoreconfHook, + pkg-config, + fetchurl, + python3, + dropbox, + gtk4, + nautilus, + gdk-pixbuf, + gobject-introspection, }: let @@ -19,7 +21,10 @@ stdenv.mkDerivation { pname = "dropbox-cli"; inherit version; - outputs = [ "out" "nautilusExtension" ]; + outputs = [ + "out" + "nautilusExtension" + ]; src = fetchurl { url = "https://linux.dropbox.com/packages/nautilus-dropbox-${version}.tar.bz2"; @@ -42,10 +47,12 @@ stdenv.mkDerivation { gdk-pixbuf # only for build, the install command also wants to use GTK through introspection # but we are using Nix for installation so we will not need that. - (python3.withPackages (ps: with ps; [ - docutils - pygobject3 - ])) + (python3.withPackages ( + ps: with ps; [ + docutils + pygobject3 + ] + )) ]; buildInputs = [ diff --git a/pkgs/applications/networking/feedreaders/rss2email/default.nix b/pkgs/applications/networking/feedreaders/rss2email/default.nix index a24325454af57d..7dba7e9684b9f4 100644 --- a/pkgs/applications/networking/feedreaders/rss2email/default.nix +++ b/pkgs/applications/networking/feedreaders/rss2email/default.nix @@ -1,8 +1,9 @@ -{ lib -, pythonPackages -, fetchPypi -, fetchpatch2 -, nixosTests +{ + lib, + pythonPackages, + fetchPypi, + fetchpatch2, + nixosTests, }: with pythonPackages; @@ -11,7 +12,10 @@ buildPythonApplication rec { pname = "rss2email"; version = "3.14"; - propagatedBuildInputs = [ feedparser html2text ]; + propagatedBuildInputs = [ + feedparser + html2text + ]; nativeCheckInputs = [ beautifulsoup4 ]; src = fetchPypi { @@ -27,7 +31,11 @@ buildPythonApplication rec { }) ]; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; postPatch = '' # sendmail executable is called from PATH instead of sbin by default diff --git a/pkgs/applications/networking/feedreaders/rssguard/default.nix b/pkgs/applications/networking/feedreaders/rssguard/default.nix index 1a3124f64ad5ae..795a252ef0434a 100644 --- a/pkgs/applications/networking/feedreaders/rssguard/default.nix +++ b/pkgs/applications/networking/feedreaders/rssguard/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qtwebengine -, qttools -, wrapGAppsHook3 -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtwebengine, + qttools, + wrapGAppsHook3, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -19,8 +20,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-eF0jPT0gQnnBWu9IKfY0DwMwotL3IEjovqnQqx9v2NA="; }; - buildInputs = [ qtwebengine qttools ]; - nativeBuildInputs = [ cmake wrapGAppsHook3 wrapQtAppsHook ]; + buildInputs = [ + qtwebengine + qttools + ]; + nativeBuildInputs = [ + cmake + wrapGAppsHook3 + wrapQtAppsHook + ]; qmakeFlags = [ "CONFIG+=release" ]; meta = with lib; { diff --git a/pkgs/applications/networking/feedreaders/tuifeed/default.nix b/pkgs/applications/networking/feedreaders/tuifeed/default.nix index 16bb0324d07a6d..b4262c7aa4249e 100644 --- a/pkgs/applications/networking/feedreaders/tuifeed/default.nix +++ b/pkgs/applications/networking/feedreaders/tuifeed/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchCrate -, rustPlatform -, Security +{ + lib, + stdenv, + fetchCrate, + rustPlatform, + Security, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/applications/networking/firehol/default.nix b/pkgs/applications/networking/firehol/default.nix index cdff695aa8df5f..d5af0443de1235 100644 --- a/pkgs/applications/networking/firehol/default.nix +++ b/pkgs/applications/networking/firehol/default.nix @@ -1,8 +1,24 @@ -{ stdenv, lib, fetchFromGitHub, autoconf, automake, curl, iprange, iproute2, iptables, iputils -, kmod, nettools, procps, tcpdump, traceroute, util-linux, whois +{ + stdenv, + lib, + fetchFromGitHub, + autoconf, + automake, + curl, + iprange, + iproute2, + iptables, + iputils, + kmod, + nettools, + procps, + tcpdump, + traceroute, + util-linux, + whois, -# If true, just install FireQOS without FireHOL -, onlyQOS ? false + # If true, just install FireQOS without FireHOL + onlyQOS ? false, }: stdenv.mkDerivation rec { @@ -32,17 +48,32 @@ stdenv.mkDerivation rec { ./firehol-uname-command.patch ]; - nativeBuildInputs = [ autoconf automake ]; + nativeBuildInputs = [ + autoconf + automake + ]; buildInputs = [ - curl iprange iproute2 iptables iputils kmod - nettools procps tcpdump traceroute util-linux whois + curl + iprange + iproute2 + iptables + iputils + kmod + nettools + procps + tcpdump + traceroute + util-linux + whois ]; preConfigure = "./autogen.sh"; - configureFlags = [ "--localstatedir=/var" - "--disable-doc" "--disable-man" - "--disable-update-ipsets" ] ++ - lib.optionals onlyQOS [ "--disable-firehol" ]; + configureFlags = [ + "--localstatedir=/var" + "--disable-doc" + "--disable-man" + "--disable-update-ipsets" + ] ++ lib.optionals onlyQOS [ "--disable-firehol" ]; meta = with lib; { description = "Firewall for humans"; diff --git a/pkgs/applications/networking/firehol/iprange.nix b/pkgs/applications/networking/firehol/iprange.nix index d2504b73cc3019..63157c65aa3338 100644 --- a/pkgs/applications/networking/firehol/iprange.nix +++ b/pkgs/applications/networking/firehol/iprange.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "iprange"; diff --git a/pkgs/applications/networking/ftp/gftp/default.nix b/pkgs/applications/networking/ftp/gftp/default.nix index 3007fdd67183e6..94299b5fc0a138 100644 --- a/pkgs/applications/networking/ftp/gftp/default.nix +++ b/pkgs/applications/networking/ftp/gftp/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, gettext -, gtk -, intltool -, libtool -, ncurses -, openssl -, pkg-config -, readline +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + gettext, + gtk, + intltool, + libtool, + ncurses, + openssl, + pkg-config, + readline, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/networking/gns3/gui.nix b/pkgs/applications/networking/gns3/gui.nix index e01380bc286ab1..f1f14ad917d03a 100644 --- a/pkgs/applications/networking/gns3/gui.nix +++ b/pkgs/applications/networking/gns3/gui.nix @@ -31,18 +31,21 @@ python3Packages.buildPythonApplication rec { propagatedBuildInputs = [ qt5.qtwayland ]; - dependencies = with python3Packages; [ - distro - jsonschema - psutil - sentry-sdk - setuptools - sip - (pyqt5.override { withWebSockets = true; }) - truststore - ] ++ lib.optionals (pythonOlder "3.9") [ - importlib-resources - ]; + dependencies = + with python3Packages; + [ + distro + jsonschema + psutil + sentry-sdk + setuptools + sip + (pyqt5.override { withWebSockets = true; }) + truststore + ] + ++ lib.optionals (pythonOlder "3.9") [ + importlib-resources + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/networking/gns3/server.nix b/pkgs/applications/networking/gns3/server.nix index dec90b620f704b..ba36823fb93865 100644 --- a/pkgs/applications/networking/gns3/server.nix +++ b/pkgs/applications/networking/gns3/server.nix @@ -34,25 +34,28 @@ python3Packages.buildPythonApplication { build-system = with python3Packages; [ setuptools ]; - dependencies = with python3Packages; [ - aiofiles - aiohttp - aiohttp-cors - async-generator - distro - jinja2 - jsonschema - multidict - platformdirs - prompt-toolkit - psutil - py-cpuinfo - sentry-sdk - truststore - yarl - ] ++ lib.optionals (pythonOlder "3.9") [ - importlib-resources - ]; + dependencies = + with python3Packages; + [ + aiofiles + aiohttp + aiohttp-cors + async-generator + distro + jinja2 + jsonschema + multidict + platformdirs + prompt-toolkit + psutil + py-cpuinfo + sentry-sdk + truststore + yarl + ] + ++ lib.optionals (pythonOlder "3.9") [ + importlib-resources + ]; postInstall = lib.optionalString (!stdenv.hostPlatform.isWindows) '' rm $out/bin/gns3loopback diff --git a/pkgs/applications/networking/google-drive-ocamlfuse/default.nix b/pkgs/applications/networking/google-drive-ocamlfuse/default.nix index 5455ce856d5229..48af19cc590f55 100644 --- a/pkgs/applications/networking/google-drive-ocamlfuse/default.nix +++ b/pkgs/applications/networking/google-drive-ocamlfuse/default.nix @@ -1,7 +1,14 @@ -{ lib, ocaml, buildDunePackage, fetchFromGitHub -, extlib, ocamlfuse, gapi-ocaml, ocaml_sqlite3 -, tiny_httpd -, ounit2 +{ + lib, + ocaml, + buildDunePackage, + fetchFromGitHub, + extlib, + ocamlfuse, + gapi-ocaml, + ocaml_sqlite3, + tiny_httpd, + ounit2, }: buildDunePackage rec { @@ -18,7 +25,13 @@ buildDunePackage rec { doCheck = lib.versionOlder ocaml.version "5.0"; checkInputs = [ ounit2 ]; - buildInputs = [ extlib ocamlfuse gapi-ocaml ocaml_sqlite3 tiny_httpd ]; + buildInputs = [ + extlib + ocamlfuse + gapi-ocaml + ocaml_sqlite3 + tiny_httpd + ]; meta = { inherit (src.meta) homepage; diff --git a/pkgs/applications/networking/gopher/phetch/default.nix b/pkgs/applications/networking/gopher/phetch/default.nix index a74f94eceb60ed..90ad50006bae7c 100644 --- a/pkgs/applications/networking/gopher/phetch/default.nix +++ b/pkgs/applications/networking/gopher/phetch/default.nix @@ -1,20 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles -, rustPlatform -, pkg-config -, openssl -, scdoc -, Security -, which +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + rustPlatform, + pkg-config, + openssl, + scdoc, + Security, + which, }: rustPlatform.buildRustPackage rec { pname = "phetch"; version = "1.2.0"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchFromGitHub { owner = "xvxx"; @@ -25,7 +29,12 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-y3Y5PnZ51Zc3LmVTijUGnb0KaGm28sWOSYxjuM3A1Zk="; - nativeBuildInputs = [ installShellFiles pkg-config scdoc which ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + scdoc + which + ]; buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; postInstall = '' diff --git a/pkgs/applications/networking/hpmyroom/default.nix b/pkgs/applications/networking/hpmyroom/default.nix index 78fdb5077818e1..fd68b718d40b4a 100644 --- a/pkgs/applications/networking/hpmyroom/default.nix +++ b/pkgs/applications/networking/hpmyroom/default.nix @@ -1,6 +1,26 @@ -{ mkDerivation, stdenv, lib, fetchurl, rpmextract, autoPatchelfHook , libuuid -, libXtst, libXfixes, glib, gst_all_1, alsa-lib, freetype, fontconfig , libXext -, libGL, libpng, libXScrnSaver, libxcb, xorg, libpulseaudio, libdrm +{ + mkDerivation, + stdenv, + lib, + fetchurl, + rpmextract, + autoPatchelfHook, + libuuid, + libXtst, + libXfixes, + glib, + gst_all_1, + alsa-lib, + freetype, + fontconfig, + libXext, + libGL, + libpng, + libXScrnSaver, + libxcb, + xorg, + libpulseaudio, + libdrm, }: mkDerivation rec { pname = "hpmyroom"; @@ -12,16 +32,33 @@ mkDerivation rec { }; nativeBuildInputs = [ - rpmextract autoPatchelfHook + rpmextract + autoPatchelfHook ]; - buildInputs = [ - libuuid libXtst libXScrnSaver libXfixes alsa-lib freetype fontconfig libXext - libGL libpng libxcb libpulseaudio libdrm - glib # For libgobject - stdenv.cc.cc # For libstdc++ - xorg.libX11 - ] ++ (with gst_all_1; [ gstreamer gst-plugins-base ]); + buildInputs = + [ + libuuid + libXtst + libXScrnSaver + libXfixes + alsa-lib + freetype + fontconfig + libXext + libGL + libpng + libxcb + libpulseaudio + libdrm + glib # For libgobject + stdenv.cc.cc # For libstdc++ + xorg.libX11 + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + ]); unpackPhase = '' rpmextract $src diff --git a/pkgs/applications/networking/icemon/default.nix b/pkgs/applications/networking/icemon/default.nix index 7fa4c37b557a25..43e9c2b8ebbadb 100644 --- a/pkgs/applications/networking/icemon/default.nix +++ b/pkgs/applications/networking/icemon/default.nix @@ -1,4 +1,17 @@ -{ lib, fetchFromGitHub, mkDerivation, qtbase, cmake, extra-cmake-modules, icecream, libcap_ng, lzo, zstd, libarchive, wrapQtAppsHook }: +{ + lib, + fetchFromGitHub, + mkDerivation, + qtbase, + cmake, + extra-cmake-modules, + icecream, + libcap_ng, + lzo, + zstd, + libarchive, + wrapQtAppsHook, +}: mkDerivation rec { pname = "icemon"; @@ -11,8 +24,19 @@ mkDerivation rec { sha256 = "09jnipr67dhawbxfn69yh7mmjrkylgiqmd0gmc2limd3z15d7pgc"; }; - nativeBuildInputs = [ cmake extra-cmake-modules wrapQtAppsHook ]; - buildInputs = [ icecream qtbase libcap_ng lzo zstd libarchive ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + wrapQtAppsHook + ]; + buildInputs = [ + icecream + qtbase + libcap_ng + lzo + zstd + libarchive + ]; meta = with lib; { description = "Icecream GUI Monitor"; diff --git a/pkgs/applications/networking/ids/zeek/broker/default.nix b/pkgs/applications/networking/ids/zeek/broker/default.nix index 0fcdd5048c0e6a..f187f8ef682ca4 100644 --- a/pkgs/applications/networking/ids/zeek/broker/default.nix +++ b/pkgs/applications/networking/ids/zeek/broker/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, python3 -, caf -, openssl +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + python3, + caf, + openssl, }: let inherit (stdenv.hostPlatform) isStatic; @@ -38,7 +39,10 @@ in stdenv.mkDerivation rec { pname = "zeek-broker"; version = "6.2.0"; - outputs = [ "out" "py" ]; + outputs = [ + "out" + "py" + ]; strictDeps = true; @@ -66,8 +70,14 @@ stdenv.mkDerivation rec { substituteInPlace bindings/python/CMakeLists.txt --replace " -u -r" "" ''; - nativeBuildInputs = [ cmake python3 ]; - buildInputs = [ openssl python3.pkgs.pybind11 ]; + nativeBuildInputs = [ + cmake + python3 + ]; + buildInputs = [ + openssl + python3.pkgs.pybind11 + ]; propagatedBuildInputs = [ caf' ]; cmakeFlags = [ diff --git a/pkgs/applications/networking/ids/zeek/default.nix b/pkgs/applications/networking/ids/zeek/default.nix index 8286c46bcb484a..54e8e7022493d1 100644 --- a/pkgs/applications/networking/ids/zeek/default.nix +++ b/pkgs/applications/networking/ids/zeek/default.nix @@ -1,28 +1,32 @@ -{ lib -, stdenv -, callPackage -, fetchurl -, cmake -, flex -, bison -, openssl -, libkqueue -, libpcap -, zlib -, file -, curl -, libmaxminddb -, gperftools -, python3 -, swig -, gettext -, coreutils -, ncurses +{ + lib, + stdenv, + callPackage, + fetchurl, + cmake, + flex, + bison, + openssl, + libkqueue, + libpcap, + zlib, + file, + curl, + libmaxminddb, + gperftools, + python3, + swig, + gettext, + coreutils, + ncurses, }: let broker = callPackage ./broker { }; - python = python3.withPackages (p: [ p.gitpython p.semantic-version ]); + python = python3.withPackages (p: [ + p.gitpython + p.semantic-version + ]); in stdenv.mkDerivation rec { pname = "zeek"; @@ -48,39 +52,44 @@ stdenv.mkDerivation rec { swig ]; - buildInputs = [ - broker - curl - gperftools - libmaxminddb - libpcap - ncurses - openssl - zlib - python - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libkqueue - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - gettext - ]; + buildInputs = + [ + broker + curl + gperftools + libmaxminddb + libpcap + ncurses + openssl + zlib + python + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libkqueue + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + gettext + ]; postPatch = '' patchShebangs ./ci/collect-repo-info.py patchShebangs ./auxil/spicy/scripts ''; - cmakeFlags = [ - "-DBroker_ROOT=${broker}" - "-DENABLE_PERFTOOLS=true" - "-DINSTALL_AUX_TOOLS=true" - "-DZEEK_ETC_INSTALL_DIR=/etc/zeek" - "-DZEEK_LOG_DIR=/var/log/zeek" - "-DZEEK_STATE_DIR=/var/lib/zeek" - "-DZEEK_SPOOL_DIR=/var/spool/zeek" - "-DDISABLE_JAVASCRIPT=ON" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "-DLIBKQUEUE_ROOT_DIR=${libkqueue}" - ]; + cmakeFlags = + [ + "-DBroker_ROOT=${broker}" + "-DENABLE_PERFTOOLS=true" + "-DINSTALL_AUX_TOOLS=true" + "-DZEEK_ETC_INSTALL_DIR=/etc/zeek" + "-DZEEK_LOG_DIR=/var/log/zeek" + "-DZEEK_STATE_DIR=/var/lib/zeek" + "-DZEEK_SPOOL_DIR=/var/spool/zeek" + "-DDISABLE_JAVASCRIPT=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "-DLIBKQUEUE_ROOT_DIR=${libkqueue}" + ]; env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-faligned-allocation"; @@ -105,7 +114,10 @@ stdenv.mkDerivation rec { homepage = "https://www.zeek.org"; changelog = "https://github.com/zeek/zeek/blob/v${version}/CHANGES"; license = licenses.bsd3; - maintainers = with maintainers; [ pSub tobim ]; + maintainers = with maintainers; [ + pSub + tobim + ]; platforms = platforms.unix; }; } diff --git a/pkgs/applications/networking/instant-messengers/bitlbee/default.nix b/pkgs/applications/networking/instant-messengers/bitlbee/default.nix index 32b3096c3c6693..b1cac93af625c8 100644 --- a/pkgs/applications/networking/instant-messengers/bitlbee/default.nix +++ b/pkgs/applications/networking/instant-messengers/bitlbee/default.nix @@ -1,6 +1,18 @@ -{ lib, fetchurl, fetchpatch, stdenv, gnutls, glib, pkg-config, check, libotr, python3 -, enableLibPurple ? false, pidgin ? null -, enablePam ? false, pam ? null +{ + lib, + fetchurl, + fetchpatch, + stdenv, + gnutls, + glib, + pkg-config, + check, + libotr, + python3, + enableLibPurple ? false, + pidgin ? null, + enablePam ? false, + pam ? null, }: stdenv.mkDerivation rec { @@ -14,17 +26,24 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ] ++ lib.optional doCheck check; - buildInputs = [ gnutls libotr python3 ] + buildInputs = + [ + gnutls + libotr + python3 + ] ++ lib.optional enableLibPurple pidgin ++ lib.optional enablePam pam; propagatedBuildInputs = [ glib ]; - configureFlags = [ - "--otr=1" - "--ssl=gnutls" - "--pidfile=/var/lib/bitlbee/bitlbee.pid" - ] ++ lib.optional enableLibPurple "--purple=1" + configureFlags = + [ + "--otr=1" + "--ssl=gnutls" + "--pidfile=/var/lib/bitlbee/bitlbee.pid" + ] + ++ lib.optional enableLibPurple "--purple=1" ++ lib.optional enablePam "--pam=1"; patches = [ @@ -35,7 +54,10 @@ stdenv.mkDerivation rec { }) ]; - installTargets = [ "install" "install-dev" ]; + installTargets = [ + "install" + "install-dev" + ]; doCheck = !enableLibPurple; # Checks fail with libpurple for some reason checkPhase = '' @@ -63,7 +85,10 @@ stdenv.mkDerivation rec { homepage = "https://www.bitlbee.org/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ lassulus pSub ]; - platforms = platforms.gnu ++ platforms.linux; # arbitrary choice + maintainers = with maintainers; [ + lassulus + pSub + ]; + platforms = platforms.gnu ++ platforms.linux; # arbitrary choice }; } diff --git a/pkgs/applications/networking/instant-messengers/bitlbee/plugins.nix b/pkgs/applications/networking/instant-messengers/bitlbee/plugins.nix index f750f7f9d602bd..81289e43c5667e 100644 --- a/pkgs/applications/networking/instant-messengers/bitlbee/plugins.nix +++ b/pkgs/applications/networking/instant-messengers/bitlbee/plugins.nix @@ -1,13 +1,23 @@ -{ lib, runCommandLocal, bitlbee }: +{ + lib, + runCommandLocal, + bitlbee, +}: -plugins: runCommandLocal "bitlbee-plugins" { - inherit plugins; - buildInputs = [ bitlbee plugins ]; -} '' - mkdir -p $out/lib/bitlbee - for plugin in $plugins; do - for thing in $(ls $plugin/lib/bitlbee); do - ln -s $plugin/lib/bitlbee/$thing $out/lib/bitlbee/ +plugins: +runCommandLocal "bitlbee-plugins" + { + inherit plugins; + buildInputs = [ + bitlbee + plugins + ]; + } + '' + mkdir -p $out/lib/bitlbee + for plugin in $plugins; do + for thing in $(ls $plugin/lib/bitlbee); do + ln -s $plugin/lib/bitlbee/$thing $out/lib/bitlbee/ + done done - done -'' + '' diff --git a/pkgs/applications/networking/instant-messengers/discord-screenaudio/default.nix b/pkgs/applications/networking/instant-messengers/discord-screenaudio/default.nix index 9b4778cfd6a4e9..cf8eab529474f4 100644 --- a/pkgs/applications/networking/instant-messengers/discord-screenaudio/default.nix +++ b/pkgs/applications/networking/instant-messengers/discord-screenaudio/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, wrapQtAppsHook -, cmake -, pkg-config -, qtbase -, qtwebengine -, qtwayland -, pipewire -, kdePackages -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + wrapQtAppsHook, + cmake, + pkg-config, + qtbase, + qtwebengine, + qtwayland, + pipewire, + kdePackages, + nix-update-script, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/networking/instant-messengers/element/element-desktop.nix b/pkgs/applications/networking/instant-messengers/element/element-desktop.nix index 2a7d91790909f3..3bccfdec1d6874 100644 --- a/pkgs/applications/networking/instant-messengers/element/element-desktop.nix +++ b/pkgs/applications/networking/instant-messengers/element/element-desktop.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, makeDesktopItem -, fixup-yarn-lock -, yarn -, nodejs -, fetchYarnDeps -, jq -, electron_33 -, element-web -, sqlcipher -, callPackage -, Security -, AppKit -, CoreServices -, desktopToDarwinBundle -, useKeytar ? true -# command line arguments which are always set -, commandLineArgs ? "" +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + makeDesktopItem, + fixup-yarn-lock, + yarn, + nodejs, + fetchYarnDeps, + jq, + electron_33, + element-web, + sqlcipher, + callPackage, + Security, + AppKit, + CoreServices, + desktopToDarwinBundle, + useKeytar ? true, + # command line arguments which are always set + commandLineArgs ? "", }: let @@ -29,132 +30,144 @@ let seshat = callPackage ./seshat { inherit CoreServices; }; electron = electron_33; in -stdenv.mkDerivation (finalAttrs: builtins.removeAttrs pinData [ "hashes" ] // { - pname = "element-desktop"; - name = "${finalAttrs.pname}-${finalAttrs.version}"; - src = fetchFromGitHub { - owner = "element-hq"; - repo = "element-desktop"; - rev = "v${finalAttrs.version}"; - hash = desktopSrcHash; - }; - - offlineCache = fetchYarnDeps { - yarnLock = finalAttrs.src + "/yarn.lock"; - sha256 = desktopYarnHash; - }; - - nativeBuildInputs = [ yarn fixup-yarn-lock nodejs makeWrapper jq ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; - - inherit seshat; - - configurePhase = '' - runHook preConfigure - - export HOME=$(mktemp -d) - yarn config --offline set yarn-offline-mirror $offlineCache - fixup-yarn-lock yarn.lock - yarn install --offline --frozen-lockfile --ignore-platform --ignore-scripts --no-progress --non-interactive - patchShebangs node_modules/ - - runHook postConfigure - ''; - - # Only affects unused scripts in $out/share/element/electron/scripts. Also - # breaks because there are some `node`-scripts with a `npx`-shebang and - # this shouldn't be in the closure just for unused scripts. - dontPatchShebangs = true; - - buildPhase = '' - runHook preBuild - - yarn --offline run build:ts - yarn --offline run i18n - yarn --offline run build:res - - rm -rf node_modules/matrix-seshat node_modules/keytar - ${lib.optionalString useKeytar "ln -s ${keytar} node_modules/keytar"} - ln -s $seshat node_modules/matrix-seshat - - runHook postBuild - ''; - - installPhase = - '' - runHook preInstall - - # resources - mkdir -p "$out/share/element" - ln -s '${element-web}' "$out/share/element/webapp" - cp -r '.' "$out/share/element/electron" - cp -r './res/img' "$out/share/element" - rm -rf "$out/share/element/electron/node_modules" - cp -r './node_modules' "$out/share/element/electron" - cp $out/share/element/electron/lib/i18n/strings/en_EN.json $out/share/element/electron/lib/i18n/strings/en-us.json - ln -s $out/share/element/electron/lib/i18n/strings/en{-us,}.json - - # icons - for icon in $out/share/element/electron/build/icons/*.png; do - mkdir -p "$out/share/icons/hicolor/$(basename $icon .png)/apps" - ln -s "$icon" "$out/share/icons/hicolor/$(basename $icon .png)/apps/element.png" - done - - # desktop item - mkdir -p "$out/share" - ln -s "${finalAttrs.desktopItem}/share/applications" "$out/share/applications" - - # executable wrapper - # LD_PRELOAD workaround for sqlcipher not found: https://github.com/matrix-org/seshat/issues/102 - makeWrapper '${electron}/bin/electron' "$out/bin/${executableName}" \ - --set LD_PRELOAD ${sqlcipher}/lib/libsqlcipher.so \ - --add-flags "$out/share/element/electron" \ - --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" \ - --add-flags ${lib.escapeShellArg commandLineArgs} - - runHook postInstall - ''; - - # The desktop item properties should be kept in sync with data from upstream: - # https://github.com/element-hq/element-desktop/blob/develop/package.json - desktopItem = makeDesktopItem { - name = "element-desktop"; - exec = "${executableName} %u"; - icon = "element"; - desktopName = "Element"; - genericName = "Matrix Client"; - comment = finalAttrs.meta.description; - categories = [ "Network" "InstantMessaging" "Chat" ]; - startupWMClass = "Element"; - mimeTypes = [ "x-scheme-handler/element" ]; - }; - - postFixup = lib.optionalString stdenv.hostPlatform.isDarwin '' - cp build/icon.icns $out/Applications/Element.app/Contents/Resources/element.icns - ''; - - passthru = { - updateScript = ./update.sh; - - # TL;DR: keytar is optional while seshat isn't. - # - # This prevents building keytar when `useKeytar` is set to `false`, because - # if libsecret is unavailable (e.g. set to `null` or fails to build), then - # this package wouldn't even considered for building because - # "one of the dependencies failed to build", - # although the dependency wouldn't even be used. - # - # It needs to be `passthru` anyways because other packages do depend on it. - inherit keytar; - }; - - meta = with lib; { - description = "A feature-rich client for Matrix.org"; - homepage = "https://element.io/"; - changelog = "https://github.com/element-hq/element-desktop/blob/v${finalAttrs.version}/CHANGELOG.md"; - license = licenses.asl20; - maintainers = teams.matrix.members; - inherit (electron.meta) platforms; - mainProgram = "element-desktop"; - }; -}) +stdenv.mkDerivation ( + finalAttrs: + builtins.removeAttrs pinData [ "hashes" ] + // { + pname = "element-desktop"; + name = "${finalAttrs.pname}-${finalAttrs.version}"; + src = fetchFromGitHub { + owner = "element-hq"; + repo = "element-desktop"; + rev = "v${finalAttrs.version}"; + hash = desktopSrcHash; + }; + + offlineCache = fetchYarnDeps { + yarnLock = finalAttrs.src + "/yarn.lock"; + sha256 = desktopYarnHash; + }; + + nativeBuildInputs = [ + yarn + fixup-yarn-lock + nodejs + makeWrapper + jq + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; + + inherit seshat; + + configurePhase = '' + runHook preConfigure + + export HOME=$(mktemp -d) + yarn config --offline set yarn-offline-mirror $offlineCache + fixup-yarn-lock yarn.lock + yarn install --offline --frozen-lockfile --ignore-platform --ignore-scripts --no-progress --non-interactive + patchShebangs node_modules/ + + runHook postConfigure + ''; + + # Only affects unused scripts in $out/share/element/electron/scripts. Also + # breaks because there are some `node`-scripts with a `npx`-shebang and + # this shouldn't be in the closure just for unused scripts. + dontPatchShebangs = true; + + buildPhase = '' + runHook preBuild + + yarn --offline run build:ts + yarn --offline run i18n + yarn --offline run build:res + + rm -rf node_modules/matrix-seshat node_modules/keytar + ${lib.optionalString useKeytar "ln -s ${keytar} node_modules/keytar"} + ln -s $seshat node_modules/matrix-seshat + + runHook postBuild + ''; + + installPhase = '' + runHook preInstall + + # resources + mkdir -p "$out/share/element" + ln -s '${element-web}' "$out/share/element/webapp" + cp -r '.' "$out/share/element/electron" + cp -r './res/img' "$out/share/element" + rm -rf "$out/share/element/electron/node_modules" + cp -r './node_modules' "$out/share/element/electron" + cp $out/share/element/electron/lib/i18n/strings/en_EN.json $out/share/element/electron/lib/i18n/strings/en-us.json + ln -s $out/share/element/electron/lib/i18n/strings/en{-us,}.json + + # icons + for icon in $out/share/element/electron/build/icons/*.png; do + mkdir -p "$out/share/icons/hicolor/$(basename $icon .png)/apps" + ln -s "$icon" "$out/share/icons/hicolor/$(basename $icon .png)/apps/element.png" + done + + # desktop item + mkdir -p "$out/share" + ln -s "${finalAttrs.desktopItem}/share/applications" "$out/share/applications" + + # executable wrapper + # LD_PRELOAD workaround for sqlcipher not found: https://github.com/matrix-org/seshat/issues/102 + makeWrapper '${electron}/bin/electron' "$out/bin/${executableName}" \ + --set LD_PRELOAD ${sqlcipher}/lib/libsqlcipher.so \ + --add-flags "$out/share/element/electron" \ + --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" \ + --add-flags ${lib.escapeShellArg commandLineArgs} + + runHook postInstall + ''; + + # The desktop item properties should be kept in sync with data from upstream: + # https://github.com/element-hq/element-desktop/blob/develop/package.json + desktopItem = makeDesktopItem { + name = "element-desktop"; + exec = "${executableName} %u"; + icon = "element"; + desktopName = "Element"; + genericName = "Matrix Client"; + comment = finalAttrs.meta.description; + categories = [ + "Network" + "InstantMessaging" + "Chat" + ]; + startupWMClass = "Element"; + mimeTypes = [ "x-scheme-handler/element" ]; + }; + + postFixup = lib.optionalString stdenv.hostPlatform.isDarwin '' + cp build/icon.icns $out/Applications/Element.app/Contents/Resources/element.icns + ''; + + passthru = { + updateScript = ./update.sh; + + # TL;DR: keytar is optional while seshat isn't. + # + # This prevents building keytar when `useKeytar` is set to `false`, because + # if libsecret is unavailable (e.g. set to `null` or fails to build), then + # this package wouldn't even considered for building because + # "one of the dependencies failed to build", + # although the dependency wouldn't even be used. + # + # It needs to be `passthru` anyways because other packages do depend on it. + inherit keytar; + }; + + meta = with lib; { + description = "A feature-rich client for Matrix.org"; + homepage = "https://element.io/"; + changelog = "https://github.com/element-hq/element-desktop/blob/v${finalAttrs.version}/CHANGELOG.md"; + license = licenses.asl20; + maintainers = teams.matrix.members; + inherit (electron.meta) platforms; + mainProgram = "element-desktop"; + }; + } +) diff --git a/pkgs/applications/networking/instant-messengers/element/element-web-wrapper.nix b/pkgs/applications/networking/instant-messengers/element/element-web-wrapper.nix index e6dc8fb84c7d20..165761f2a25c98 100644 --- a/pkgs/applications/networking/instant-messengers/element/element-web-wrapper.nix +++ b/pkgs/applications/networking/instant-messengers/element/element-web-wrapper.nix @@ -1,30 +1,33 @@ -{ stdenv -, jq -, element-web-unwrapped -, conf ? { } +{ + stdenv, + jq, + element-web-unwrapped, + conf ? { }, }: -if (conf == { }) then element-web-unwrapped else -stdenv.mkDerivation rec { - pname = "${element-web-unwrapped.pname}-wrapped"; - inherit (element-web-unwrapped) version meta; +if (conf == { }) then + element-web-unwrapped +else + stdenv.mkDerivation rec { + pname = "${element-web-unwrapped.pname}-wrapped"; + inherit (element-web-unwrapped) version meta; - dontUnpack = true; + dontUnpack = true; - nativeBuildInputs = [ jq ]; + nativeBuildInputs = [ jq ]; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $out - ln -s ${element-web-unwrapped}/* $out - rm $out/config.json - jq -s '.[0] * $conf' "${element-web-unwrapped}/config.json" --argjson "conf" '${builtins.toJSON conf}' > "$out/config.json" + mkdir -p $out + ln -s ${element-web-unwrapped}/* $out + rm $out/config.json + jq -s '.[0] * $conf' "${element-web-unwrapped}/config.json" --argjson "conf" '${builtins.toJSON conf}' > "$out/config.json" - runHook postInstall - ''; + runHook postInstall + ''; - passthru = { - inherit conf; - }; -} + passthru = { + inherit conf; + }; + } diff --git a/pkgs/applications/networking/instant-messengers/element/keytar/default.nix b/pkgs/applications/networking/instant-messengers/element/keytar/default.nix index 958a80fb47430d..993bbcd2068f60 100644 --- a/pkgs/applications/networking/instant-messengers/element/keytar/default.nix +++ b/pkgs/applications/networking/instant-messengers/element/keytar/default.nix @@ -1,10 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, nodejs, python3, removeReferencesTo -, pkg-config, libsecret, xcbuild, Security, AppKit, fetchNpmDeps, npmHooks }: +{ + lib, + stdenv, + fetchFromGitHub, + nodejs, + python3, + removeReferencesTo, + pkg-config, + libsecret, + xcbuild, + Security, + AppKit, + fetchNpmDeps, + npmHooks, +}: let pinData = lib.importJSON ./pin.json; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "keytar"; inherit (pinData) version; @@ -16,13 +30,18 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ - nodejs python3 pkg-config + nodejs + python3 + pkg-config npmHooks.npmConfigHook - ] - ++ lib.optional stdenv.hostPlatform.isDarwin xcbuild; + ] ++ lib.optional stdenv.hostPlatform.isDarwin xcbuild; - buildInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ libsecret ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security AppKit ]; + buildInputs = + lib.optionals (!stdenv.hostPlatform.isDarwin) [ libsecret ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + AppKit + ]; npmDeps = fetchNpmDeps { inherit src; @@ -37,10 +56,18 @@ in stdenv.mkDerivation rec { ''; # https://nodejs.org/api/os.html#osarch - npmFlags = [ "--arch=${if stdenv.hostPlatform.parsed.cpu.name == "i686" then "ia32" - else if stdenv.hostPlatform.parsed.cpu.name == "x86_64" then "x64" - else if stdenv.hostPlatform.parsed.cpu.name == "aarch64" then "arm64" - else stdenv.hostPlatform.parsed.cpu.name}" ]; + npmFlags = [ + "--arch=${ + if stdenv.hostPlatform.parsed.cpu.name == "i686" then + "ia32" + else if stdenv.hostPlatform.parsed.cpu.name == "x86_64" then + "x64" + else if stdenv.hostPlatform.parsed.cpu.name == "aarch64" then + "arm64" + else + stdenv.hostPlatform.parsed.cpu.name + }" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/applications/networking/instant-messengers/element/seshat/default.nix b/pkgs/applications/networking/instant-messengers/element/seshat/default.nix index e8e88491c2cc0c..800650ce5b66b4 100644 --- a/pkgs/applications/networking/instant-messengers/element/seshat/default.nix +++ b/pkgs/applications/networking/instant-messengers/element/seshat/default.nix @@ -1,9 +1,24 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, rust, sqlcipher, nodejs, python3, yarn, fixup-yarn-lock, CoreServices, fetchYarnDeps, removeReferencesTo }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + rust, + sqlcipher, + nodejs, + python3, + yarn, + fixup-yarn-lock, + CoreServices, + fetchYarnDeps, + removeReferencesTo, +}: let pinData = lib.importJSON ./pin.json; -in rustPlatform.buildRustPackage rec { +in +rustPlatform.buildRustPackage rec { pname = "seshat-node"; inherit (pinData) version cargoHash; @@ -16,7 +31,12 @@ in rustPlatform.buildRustPackage rec { sourceRoot = "${src.name}/seshat-node/native"; - nativeBuildInputs = [ nodejs python3 yarn fixup-yarn-lock ]; + nativeBuildInputs = [ + nodejs + python3 + yarn + fixup-yarn-lock + ]; buildInputs = [ sqlcipher ] ++ lib.optional stdenv.hostPlatform.isDarwin CoreServices; npm_config_nodedir = nodejs; diff --git a/pkgs/applications/networking/instant-messengers/ferdium/default.nix b/pkgs/applications/networking/instant-messengers/ferdium/default.nix index e67a46cdf50283..606732baf58086 100644 --- a/pkgs/applications/networking/instant-messengers/ferdium/default.nix +++ b/pkgs/applications/networking/instant-messengers/ferdium/default.nix @@ -1,14 +1,24 @@ -{ lib, mkFranzDerivation, fetchurl, xorg, stdenv }: +{ + lib, + mkFranzDerivation, + fetchurl, + xorg, + stdenv, +}: let - arch = { - x86_64-linux = "amd64"; - aarch64-linux = "arm64"; - }."${stdenv.hostPlatform.system}" or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); - hash = { - amd64-linux_hash = "sha256-Ey2FhekQVSYB0ki4U3HyuKs/URgtZMCl41jkPsZMNrQ="; - arm64-linux_hash = "sha256-oiimMFwwkBOwqlCSFoGQSYHsDpcjTQingyuBkYz8fvA="; - }."${arch}-linux_hash"; + arch = + { + x86_64-linux = "amd64"; + aarch64-linux = "arm64"; + } + ."${stdenv.hostPlatform.system}" or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + hash = + { + amd64-linux_hash = "sha256-Ey2FhekQVSYB0ki4U3HyuKs/URgtZMCl41jkPsZMNrQ="; + arm64-linux_hash = "sha256-oiimMFwwkBOwqlCSFoGQSYHsDpcjTQingyuBkYz8fvA="; + } + ."${arch}-linux_hash"; in mkFranzDerivation rec { pname = "ferdium"; @@ -30,7 +40,10 @@ mkFranzDerivation rec { homepage = "https://ferdium.org/"; license = licenses.asl20; maintainers = with maintainers; [ magnouvean ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; hydraPlatforms = [ ]; }; } diff --git a/pkgs/applications/networking/instant-messengers/franz/default.nix b/pkgs/applications/networking/instant-messengers/franz/default.nix index e986ff75a34af0..58265e71823fd4 100644 --- a/pkgs/applications/networking/instant-messengers/franz/default.nix +++ b/pkgs/applications/networking/instant-messengers/franz/default.nix @@ -1,4 +1,8 @@ -{ lib, mkFranzDerivation, fetchurl }: +{ + lib, + mkFranzDerivation, + fetchurl, +}: mkFranzDerivation rec { pname = "franz"; diff --git a/pkgs/applications/networking/instant-messengers/franz/generic.nix b/pkgs/applications/networking/instant-messengers/franz/generic.nix index 807e96332de094..ab586f06335994 100644 --- a/pkgs/applications/networking/instant-messengers/franz/generic.nix +++ b/pkgs/applications/networking/instant-messengers/franz/generic.nix @@ -1,95 +1,134 @@ -{ stdenv -, lib -, makeWrapper -, wrapGAppsHook3 -, autoPatchelfHook -, dpkg -, xorg -, atk -, glib -, pango -, gdk-pixbuf -, cairo -, freetype -, fontconfig -, gtk3 -, dbus -, nss -, nspr -, alsa-lib -, cups -, expat -, udev -, libnotify -, xdg-utils -, mesa -, libglvnd -, libappindicator-gtk3 +{ + stdenv, + lib, + makeWrapper, + wrapGAppsHook3, + autoPatchelfHook, + dpkg, + xorg, + atk, + glib, + pango, + gdk-pixbuf, + cairo, + freetype, + fontconfig, + gtk3, + dbus, + nss, + nspr, + alsa-lib, + cups, + expat, + udev, + libnotify, + xdg-utils, + mesa, + libglvnd, + libappindicator-gtk3, }: # Helper function for building a derivation for Franz and forks. -{ pname, name, version, src, meta, extraBuildInputs ? [], ... } @ args: +{ + pname, + name, + version, + src, + meta, + extraBuildInputs ? [ ], + ... +}@args: let - cleanedArgs = builtins.removeAttrs args [ "pname" "name" "version" "src" "meta" "extraBuildInputs" ]; -in stdenv.mkDerivation (rec { - inherit pname version src meta; + cleanedArgs = builtins.removeAttrs args [ + "pname" + "name" + "version" + "src" + "meta" + "extraBuildInputs" + ]; +in +stdenv.mkDerivation ( + rec { + inherit + pname + version + src + meta + ; - # Don't remove runtime deps. - dontPatchELF = true; + # Don't remove runtime deps. + dontPatchELF = true; - nativeBuildInputs = [ autoPatchelfHook makeWrapper wrapGAppsHook3 dpkg ]; - buildInputs = extraBuildInputs ++ (with xorg; [ - libXi - libXcursor - libXdamage - libXrandr - libXcomposite - libXext - libXfixes - libXrender - libX11 - libXtst - libXScrnSaver - ]) ++ [ - mesa #libgbm - gtk3 - atk - glib - pango - gdk-pixbuf - cairo - freetype - fontconfig - dbus - nss - nspr - alsa-lib - cups - expat - stdenv.cc.cc - ]; - runtimeDependencies = [ libglvnd (lib.getLib stdenv.cc.cc) (lib.getLib udev) libnotify libappindicator-gtk3 ]; + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + wrapGAppsHook3 + dpkg + ]; + buildInputs = + extraBuildInputs + ++ (with xorg; [ + libXi + libXcursor + libXdamage + libXrandr + libXcomposite + libXext + libXfixes + libXrender + libX11 + libXtst + libXScrnSaver + ]) + ++ [ + mesa # libgbm + gtk3 + atk + glib + pango + gdk-pixbuf + cairo + freetype + fontconfig + dbus + nss + nspr + alsa-lib + cups + expat + stdenv.cc.cc + ]; + runtimeDependencies = [ + libglvnd + (lib.getLib stdenv.cc.cc) + (lib.getLib udev) + libnotify + libappindicator-gtk3 + ]; - installPhase = '' - mkdir -p $out/bin - cp -r opt $out - ln -s $out/opt/${name}/${pname} $out/bin + installPhase = '' + mkdir -p $out/bin + cp -r opt $out + ln -s $out/opt/${name}/${pname} $out/bin - # Provide desktop item and icon. - cp -r usr/share $out - substituteInPlace $out/share/applications/${pname}.desktop \ - --replace /opt/${name}/${pname} ${pname} - ''; + # Provide desktop item and icon. + cp -r usr/share $out + substituteInPlace $out/share/applications/${pname}.desktop \ + --replace /opt/${name}/${pname} ${pname} + ''; - dontWrapGApps = true; + dontWrapGApps = true; - postFixup = '' - # make xdg-open overridable at runtime - wrapProgramShell $out/opt/${name}/${pname} \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath runtimeDependencies}" \ - --suffix PATH : ${xdg-utils}/bin \ - --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" \ - "''${gappsWrapperArgs[@]}" - ''; -} // cleanedArgs) + postFixup = '' + # make xdg-open overridable at runtime + wrapProgramShell $out/opt/${name}/${pname} \ + --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath runtimeDependencies}" \ + --suffix PATH : ${xdg-utils}/bin \ + --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" \ + "''${gappsWrapperArgs[@]}" + ''; + } + // cleanedArgs +) diff --git a/pkgs/applications/networking/instant-messengers/gajim/default.nix b/pkgs/applications/networking/instant-messengers/gajim/default.nix index 29d22aa5049b50..1b4f2536d20b00 100644 --- a/pkgs/applications/networking/instant-messengers/gajim/default.nix +++ b/pkgs/applications/networking/instant-messengers/gajim/default.nix @@ -1,22 +1,41 @@ -{ lib, fetchurl, gettext, wrapGAppsHook3 - -# Native dependencies -, python3, gtk3, gobject-introspection, adwaita-icon-theme -, gtksourceview4 -, glib-networking - -# Test dependencies -, xvfb-run, dbus - -# Optional dependencies -, enableJingle ? true, farstream, gstreamer, gst-plugins-base, gst-libav, gst-plugins-good, libnice -, enableE2E ? true -, enableSecrets ? true, libsecret -, enableRST ? true, docutils -, enableSpelling ? true, gspell -, enableUPnP ? true, gupnp-igd -, enableAppIndicator ? true, libappindicator-gtk3 -, extraPythonPackages ? ps: [] +{ + lib, + fetchurl, + gettext, + wrapGAppsHook3, + + # Native dependencies + python3, + gtk3, + gobject-introspection, + adwaita-icon-theme, + gtksourceview4, + glib-networking, + + # Test dependencies + xvfb-run, + dbus, + + # Optional dependencies + enableJingle ? true, + farstream, + gstreamer, + gst-plugins-base, + gst-libav, + gst-plugins-good, + libnice, + enableE2E ? true, + enableSecrets ? true, + libsecret, + enableRST ? true, + docutils, + enableSpelling ? true, + gspell, + enableUPnP ? true, + gupnp-igd, + enableAppIndicator ? true, + libappindicator-gtk3, + extraPythonPackages ? ps: [ ], }: python3.pkgs.buildPythonApplication rec { @@ -30,19 +49,30 @@ python3.pkgs.buildPythonApplication rec { format = "pyproject"; - buildInputs = [ - gtk3 - adwaita-icon-theme - gtksourceview4 - glib-networking - ] ++ lib.optionals enableJingle [ farstream gstreamer gst-plugins-base gst-libav gst-plugins-good libnice ] + buildInputs = + [ + gtk3 + adwaita-icon-theme + gtksourceview4 + glib-networking + ] + ++ lib.optionals enableJingle [ + farstream + gstreamer + gst-plugins-base + gst-libav + gst-plugins-good + libnice + ] ++ lib.optional enableSecrets libsecret ++ lib.optional enableSpelling gspell ++ lib.optional enableUPnP gupnp-igd ++ lib.optional enableAppIndicator libappindicator-gtk3; nativeBuildInputs = [ - gettext wrapGAppsHook3 gobject-introspection + gettext + wrapGAppsHook3 + gobject-introspection ]; dontWrapGApps = true; @@ -59,14 +89,35 @@ python3.pkgs.buildPythonApplication rec { makeWrapperArgs+=("''${gappsWrapperArgs[@]}") ''; - propagatedBuildInputs = with python3.pkgs; [ - nbxmpp pygobject3 dbus-python pillow css-parser precis-i18n keyring setuptools packaging gssapi - omemo-dr qrcode sqlalchemy emoji - ] ++ lib.optionals enableE2E [ pycrypto python-gnupg ] + propagatedBuildInputs = + with python3.pkgs; + [ + nbxmpp + pygobject3 + dbus-python + pillow + css-parser + precis-i18n + keyring + setuptools + packaging + gssapi + omemo-dr + qrcode + sqlalchemy + emoji + ] + ++ lib.optionals enableE2E [ + pycrypto + python-gnupg + ] ++ lib.optional enableRST docutils ++ extraPythonPackages python3.pkgs; - nativeCheckInputs = [ xvfb-run dbus ]; + nativeCheckInputs = [ + xvfb-run + dbus + ]; checkPhase = '' xvfb-run dbus-run-session \ @@ -85,7 +136,10 @@ python3.pkgs.buildPythonApplication rec { homepage = "http://gajim.org/"; description = "Jabber client written in PyGTK"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ raskin abbradar ]; + maintainers = with lib.maintainers; [ + raskin + abbradar + ]; downloadPage = "http://gajim.org/download/"; platforms = lib.platforms.linux; mainProgram = "gajim"; diff --git a/pkgs/applications/networking/instant-messengers/gurk-rs/default.nix b/pkgs/applications/networking/instant-messengers/gurk-rs/default.nix index 862677d691fd69..2959feb587b24e 100644 --- a/pkgs/applications/networking/instant-messengers/gurk-rs/default.nix +++ b/pkgs/applications/networking/instant-messengers/gurk-rs/default.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, protobuf -, rustPlatform -, fetchFromGitHub -, Cocoa -, pkgsBuildHost -, openssl -, pkg-config -, testers -, gurk-rs +{ + stdenv, + lib, + protobuf, + rustPlatform, + fetchFromGitHub, + Cocoa, + pkgsBuildHost, + openssl, + pkg-config, + testers, + gurk-rs, }: rustPlatform.buildRustPackage rec { @@ -30,12 +31,17 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-jTZ2wJPXj3nU7GVTfne64eSra+JuKhNryCtRZMKOE44="; - nativeBuildInputs = [ protobuf pkg-config ]; + nativeBuildInputs = [ + protobuf + pkg-config + ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; + buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; - NIX_LDFLAGS = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ "-framework" "AppKit" ]; + NIX_LDFLAGS = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + "-framework" + "AppKit" + ]; PROTOC = "${pkgsBuildHost.protobuf}/bin/protoc"; diff --git a/pkgs/applications/networking/instant-messengers/hydrogen-web/wrapper.nix b/pkgs/applications/networking/instant-messengers/hydrogen-web/wrapper.nix index 9ea22e864f4305..af89a8d9f82a44 100644 --- a/pkgs/applications/networking/instant-messengers/hydrogen-web/wrapper.nix +++ b/pkgs/applications/networking/instant-messengers/hydrogen-web/wrapper.nix @@ -1,26 +1,29 @@ -{ stdenv -, jq -, hydrogen-web-unwrapped -, conf ? { } +{ + stdenv, + jq, + hydrogen-web-unwrapped, + conf ? { }, }: -if (conf == { }) then hydrogen-web-unwrapped else -stdenv.mkDerivation { - pname = "${hydrogen-web-unwrapped.pname}-wrapped"; - inherit (hydrogen-web-unwrapped) version meta; +if (conf == { }) then + hydrogen-web-unwrapped +else + stdenv.mkDerivation { + pname = "${hydrogen-web-unwrapped.pname}-wrapped"; + inherit (hydrogen-web-unwrapped) version meta; - dontUnpack = true; + dontUnpack = true; - nativeBuildInputs = [ jq ]; + nativeBuildInputs = [ jq ]; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $out - ln -s ${hydrogen-web-unwrapped}/* $out - rm $out/config.json - jq -s '.[0] * $conf' "${hydrogen-web-unwrapped}/config.json" --argjson "conf" '${builtins.toJSON conf}' > "$out/config.json" + mkdir -p $out + ln -s ${hydrogen-web-unwrapped}/* $out + rm $out/config.json + jq -s '.[0] * $conf' "${hydrogen-web-unwrapped}/config.json" --argjson "conf" '${builtins.toJSON conf}' > "$out/config.json" - runHook postInstall - ''; -} + runHook postInstall + ''; + } diff --git a/pkgs/applications/networking/instant-messengers/jackline/default.nix b/pkgs/applications/networking/instant-messengers/jackline/default.nix index fd830858ea7bc4..c81355666be4de 100644 --- a/pkgs/applications/networking/instant-messengers/jackline/default.nix +++ b/pkgs/applications/networking/instant-messengers/jackline/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, ocamlPackages }: +{ + lib, + fetchFromGitHub, + ocamlPackages, +}: with ocamlPackages; @@ -9,9 +13,9 @@ buildDunePackage rec { minimalOCamlVersion = "4.13"; src = fetchFromGitHub { - owner = "hannesm"; - repo = "jackline"; - rev = "cf6b26e37e37b0b48be9fd2e74fc563375f757f0"; + owner = "hannesm"; + repo = "jackline"; + rev = "cf6b26e37e37b0b48be9fd2e74fc563375f757f0"; hash = "sha256-6QZZ77C1G3x/GOJsUEQMrCatVsyyxNjq36ez/TgeHSY="; }; diff --git a/pkgs/applications/networking/instant-messengers/kaidan/default.nix b/pkgs/applications/networking/instant-messengers/kaidan/default.nix index 497f9eef64ba97..63eb3776a97f3a 100644 --- a/pkgs/applications/networking/instant-messengers/kaidan/default.nix +++ b/pkgs/applications/networking/instant-messengers/kaidan/default.nix @@ -1,22 +1,23 @@ -{ mkDerivation -, lib -, fetchFromGitLab -, cmake -, extra-cmake-modules -, pkg-config -, qtquickcontrols2 -, qtmultimedia -, qtlocation -, qqc2-desktop-style -, kirigami-addons -, kirigami2 -, kio -, knotifications -, kquickimageedit -, zxing-cpp -, qxmpp -, sonnet -, gst_all_1 +{ + mkDerivation, + lib, + fetchFromGitLab, + cmake, + extra-cmake-modules, + pkg-config, + qtquickcontrols2, + qtmultimedia, + qtlocation, + qqc2-desktop-style, + kirigami-addons, + kirigami2, + kio, + knotifications, + kquickimageedit, + zxing-cpp, + qxmpp, + sonnet, + gst_all_1, }: mkDerivation rec { @@ -31,7 +32,11 @@ mkDerivation rec { hash = "sha256-2UzXWd/fR5UwGywebYGWhh817x+VC76zmVaVZSBOg7M="; }; - nativeBuildInputs = [ cmake extra-cmake-modules pkg-config ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + pkg-config + ]; buildInputs = with gst_all_1; [ qtquickcontrols2 @@ -59,13 +64,13 @@ mkDerivation rec { description = "User-friendly and modern chat app, using XMPP"; mainProgram = "kaidan"; longDescription = '' - Kaidan is a user-friendly and modern chat app for every device. It uses - the open communication protocol XMPP (Jabber). Unlike other chat apps, - you are not dependent on one specific service provider. + Kaidan is a user-friendly and modern chat app for every device. It uses + the open communication protocol XMPP (Jabber). Unlike other chat apps, + you are not dependent on one specific service provider. - Kaidan does not have all basic features yet and has still some - stability issues. Current features include audio messages, video - messages, and file sharing. + Kaidan does not have all basic features yet and has still some + stability issues. Current features include audio messages, video + messages, and file sharing. ''; homepage = "https://www.kaidan.im"; license = with licenses; [ diff --git a/pkgs/applications/networking/instant-messengers/kdeltachat/default.nix b/pkgs/applications/networking/instant-messengers/kdeltachat/default.nix index 955c20c2c6f65e..a0150fd6778059 100644 --- a/pkgs/applications/networking/instant-messengers/kdeltachat/default.nix +++ b/pkgs/applications/networking/instant-messengers/kdeltachat/default.nix @@ -1,15 +1,16 @@ -{ lib -, mkDerivation -, fetchFromSourcehut -, cmake -, extra-cmake-modules -, pkg-config -, kirigami2 -, libdeltachat -, qtbase -, qtimageformats -, qtmultimedia -, qtwebengine +{ + lib, + mkDerivation, + fetchFromSourcehut, + cmake, + extra-cmake-modules, + pkg-config, + kirigami2, + libdeltachat, + qtbase, + qtimageformats, + qtmultimedia, + qtwebengine, }: mkDerivation rec { @@ -39,9 +40,10 @@ mkDerivation rec { # needed for qmlplugindump to work QT_PLUGIN_PATH = "${qtbase.bin}/${qtbase.qtPluginPrefix}"; - QML2_IMPORT_PATH = lib.concatMapStringsSep ":" - (lib: "${lib}/${qtbase.qtQmlPrefix}") - [ kirigami2 qtmultimedia ]; + QML2_IMPORT_PATH = lib.concatMapStringsSep ":" (lib: "${lib}/${qtbase.qtQmlPrefix}") [ + kirigami2 + qtmultimedia + ]; meta = with lib; { description = "Delta Chat client using Kirigami framework"; diff --git a/pkgs/applications/networking/instant-messengers/linphone/default.nix b/pkgs/applications/networking/instant-messengers/linphone/default.nix index 778e1dc9cf50c5..b762d87a4866f9 100644 --- a/pkgs/applications/networking/instant-messengers/linphone/default.nix +++ b/pkgs/applications/networking/instant-messengers/linphone/default.nix @@ -1,19 +1,20 @@ -{ bctoolbox -, belcard -, belle-sip -, belr -, cmake -, fetchFromGitLab -, lib -, liblinphone -, mediastreamer -, mediastreamer-openh264 -, minizip-ng -, mkDerivation -, qtgraphicaleffects -, qtmultimedia -, qtquickcontrols2 -, qttools +{ + bctoolbox, + belcard, + belle-sip, + belr, + cmake, + fetchFromGitLab, + lib, + liblinphone, + mediastreamer, + mediastreamer-openh264, + minizip-ng, + mkDerivation, + qtgraphicaleffects, + qtmultimedia, + qtquickcontrols2, + qttools, }: # How to update Linphone? (The Qt desktop app) diff --git a/pkgs/applications/networking/instant-messengers/matrix-commander/default.nix b/pkgs/applications/networking/instant-messengers/matrix-commander/default.nix index 856aa55f132da0..23df7627e6fa8a 100644 --- a/pkgs/applications/networking/instant-messengers/matrix-commander/default.nix +++ b/pkgs/applications/networking/instant-messengers/matrix-commander/default.nix @@ -1,18 +1,19 @@ -{ lib -, fetchFromGitHub -, buildPythonApplication -, cacert -, setuptools -, matrix-nio -, python-magic -, markdown -, pillow -, aiofiles -, notify2 -, dbus-python -, pyxdg -, python-olm -, emoji +{ + lib, + fetchFromGitHub, + buildPythonApplication, + cacert, + setuptools, + matrix-nio, + python-magic, + markdown, + pillow, + aiofiles, + notify2, + dbus-python, + pyxdg, + python-olm, + emoji, }: buildPythonApplication rec { diff --git a/pkgs/applications/networking/instant-messengers/pantalaimon/default.nix b/pkgs/applications/networking/instant-messengers/pantalaimon/default.nix index 8a6391892ae400..35e438c6a61f75 100644 --- a/pkgs/applications/networking/instant-messengers/pantalaimon/default.nix +++ b/pkgs/applications/networking/instant-messengers/pantalaimon/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, python3Packages -, fetchFromGitHub -, installShellFiles -, nixosTests -, enableDbusUi ? true -, wrapGAppsHook3 +{ + lib, + stdenv, + python3Packages, + fetchFromGitHub, + installShellFiles, + nixosTests, + enableDbusUi ? true, + wrapGAppsHook3, }: python3Packages.buildPythonApplication rec { @@ -21,30 +22,34 @@ python3Packages.buildPythonApplication rec { hash = "sha256-yMhE3wKRbFHoL0vdFR8gMkNU7Su4FHbAwKQYADaaWpk="; }; - build-system = [ - installShellFiles - ] ++ (with python3Packages; [ - setuptools - ]); + build-system = + [ + installShellFiles + ] + ++ (with python3Packages; [ + setuptools + ]); pythonRelaxDeps = [ "matrix-nio" ]; - dependencies = with python3Packages; [ - aiohttp - appdirs - attrs - cachetools - click - janus - keyring - logbook - (matrix-nio.override { withOlm = true; }) - peewee - prompt-toolkit - ] - ++ lib.optionals enableDbusUi optional-dependencies.ui; + dependencies = + with python3Packages; + [ + aiohttp + appdirs + attrs + cachetools + click + janus + keyring + logbook + (matrix-nio.override { withOlm = true; }) + peewee + prompt-toolkit + ] + ++ lib.optionals enableDbusUi optional-dependencies.ui; optional-dependencies.ui = with python3Packages; [ dbus-python @@ -53,13 +58,15 @@ python3Packages.buildPythonApplication rec { pydbus ]; - nativeCheckInputs = with python3Packages; [ - aioresponses - faker - pytest-aiohttp - pytestCheckHook - ] - ++ lib.flatten (lib.attrValues optional-dependencies); + nativeCheckInputs = + with python3Packages; + [ + aioresponses + faker + pytest-aiohttp + pytestCheckHook + ] + ++ lib.flatten (lib.attrValues optional-dependencies); nativeBuildInputs = lib.optionals enableDbusUi [ wrapGAppsHook3 diff --git a/pkgs/applications/networking/instant-messengers/pidgin/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/default.nix index e999c27cfb0962..98fd9783704d67 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/default.nix @@ -1,41 +1,45 @@ -{ stdenv -, callPackage -, fetchurl -, makeWrapper -, aspell -, avahi -, cacert -, dbus -, dbus-glib -, farstream -, gettext -, gst_all_1 -, gtk2 -, gtk2-x11 -, gtkspell2 -, intltool -, lib -, libICE -, libSM -, libXScrnSaver -, libXext -, libgcrypt -, libgnt -, libidn -, libstartup_notification -, libxml2 -, ncurses -, nspr -, nss -, perlPackages -, pkg-config -, python3 -, pidgin -, plugins ? [] -, withOpenssl ? false, openssl -, withGnutls ? false , gnutls -, withCyrus_sasl ? true, cyrus_sasl -, pidginPackages +{ + stdenv, + callPackage, + fetchurl, + makeWrapper, + aspell, + avahi, + cacert, + dbus, + dbus-glib, + farstream, + gettext, + gst_all_1, + gtk2, + gtk2-x11, + gtkspell2, + intltool, + lib, + libICE, + libSM, + libXScrnSaver, + libXext, + libgcrypt, + libgnt, + libidn, + libstartup_notification, + libxml2, + ncurses, + nspr, + nss, + perlPackages, + pkg-config, + python3, + pidgin, + plugins ? [ ], + withOpenssl ? false, + openssl, + withGnutls ? false, + gnutls, + withCyrus_sasl ? true, + cyrus_sasl, + pidginPackages, }: # FIXME: clean the mess around choosing the SSL library (nss by default) @@ -50,41 +54,60 @@ let sha256 = "sha256-EgBJ3I4X4JoqfSVq/yGR/4SRq7hAyMfrMZoWHi3xa6g="; }; - nativeBuildInputs = [ makeWrapper intltool ]; + nativeBuildInputs = [ + makeWrapper + intltool + ]; env.NIX_CFLAGS_COMPILE = "-I${gst_all_1.gst-plugins-base.dev}/include/gstreamer-1.0"; - buildInputs = let - python-with-dbus = python3.withPackages (pp: with pp; [ dbus-python ]); - in [ - aspell - avahi - cyrus_sasl - dbus - dbus-glib - gst_all_1.gst-plugins-base gst_all_1.gst-plugins-good - gst_all_1.gstreamer - libICE - libSM - libXScrnSaver - libXext - libgnt - libidn - libstartup_notification - libxml2 - ncurses # optional: build finch - the console UI - nspr - nss - python-with-dbus - ] - ++ lib.optional withOpenssl openssl - ++ lib.optionals withGnutls [ gnutls libgcrypt ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ gtk2 gtkspell2 farstream ] - ++ lib.optional stdenv.hostPlatform.isDarwin gtk2-x11; - + buildInputs = + let + python-with-dbus = python3.withPackages (pp: with pp; [ dbus-python ]); + in + [ + aspell + avahi + cyrus_sasl + dbus + dbus-glib + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-good + gst_all_1.gstreamer + libICE + libSM + libXScrnSaver + libXext + libgnt + libidn + libstartup_notification + libxml2 + ncurses # optional: build finch - the console UI + nspr + nss + python-with-dbus + ] + ++ lib.optional withOpenssl openssl + ++ lib.optionals withGnutls [ + gnutls + libgcrypt + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + gtk2 + gtkspell2 + farstream + ] + ++ lib.optional stdenv.hostPlatform.isDarwin gtk2-x11; - propagatedBuildInputs = [ pkg-config gettext ] - ++ (with perlPackages; [ perl XMLParser ]) + propagatedBuildInputs = + [ + pkg-config + gettext + ] + ++ (with perlPackages; [ + perl + XMLParser + ]) ++ lib.optional stdenv.hostPlatform.isLinux gtk2 ++ lib.optional stdenv.hostPlatform.isDarwin gtk2-x11; @@ -93,22 +116,29 @@ let ./pidgin-makefile.patch ]; - configureFlags = [ - "--with-nspr-includes=${nspr.dev}/include/nspr" - "--with-nspr-libs=${nspr.out}/lib" - "--with-nss-includes=${nss.dev}/include/nss" - "--with-nss-libs=${nss.out}/lib" - "--with-ncurses-headers=${ncurses.dev}/include" - "--with-system-ssl-certs=${cacert}/etc/ssl/certs" - "--disable-meanwhile" - "--disable-nm" - "--disable-tcl" - "--disable-gevolution" - ] - ++ lib.optionals withCyrus_sasl [ "--enable-cyrus-sasl=yes" ] - ++ lib.optionals withGnutls [ "--enable-gnutls=yes" "--enable-nss=no" ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ "--disable-gtkspell" "--disable-vv" ] - ++ lib.optionals stdenv.cc.isClang [ "CFLAGS=-Wno-error=int-conversion" ]; + configureFlags = + [ + "--with-nspr-includes=${nspr.dev}/include/nspr" + "--with-nspr-libs=${nspr.out}/lib" + "--with-nss-includes=${nss.dev}/include/nss" + "--with-nss-libs=${nss.out}/lib" + "--with-ncurses-headers=${ncurses.dev}/include" + "--with-system-ssl-certs=${cacert}/etc/ssl/certs" + "--disable-meanwhile" + "--disable-nm" + "--disable-tcl" + "--disable-gevolution" + ] + ++ lib.optionals withCyrus_sasl [ "--enable-cyrus-sasl=yes" ] + ++ lib.optionals withGnutls [ + "--enable-gnutls=yes" + "--enable-nss=no" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "--disable-gtkspell" + "--disable-vv" + ] + ++ lib.optionals stdenv.cc.isClang [ "CFLAGS=-Wno-error=int-conversion" ]; enableParallelBuilding = true; @@ -119,22 +149,26 @@ let doInstallCheck = stdenv.buildPlatform.canExecute stdenv.hostPlatform; # In particular, this detects missing python imports in some of the tools. - postFixup = let - # TODO: python is a script, so it doesn't work as interpreter on darwin - binsToTest = lib.optionalString stdenv.hostPlatform.isLinux "purple-remote," + "pidgin,finch"; - in lib.optionalString doInstallCheck '' - for f in "''${!outputBin}"/bin/{${binsToTest}}; do - echo "Testing: $f --help" - "$f" --help - done - ''; + postFixup = + let + # TODO: python is a script, so it doesn't work as interpreter on darwin + binsToTest = lib.optionalString stdenv.hostPlatform.isLinux "purple-remote," + "pidgin,finch"; + in + lib.optionalString doInstallCheck '' + for f in "''${!outputBin}"/bin/{${binsToTest}}; do + echo "Testing: $f --help" + "$f" --help + done + ''; passthru = { makePluginPath = lib.makeSearchPathOutput "lib" "lib/purple-${lib.versions.major version}"; - withPlugins = pluginfn: callPackage ./wrapper.nix { - plugins = pluginfn pidginPackages; - pidgin = unwrapped; - }; + withPlugins = + pluginfn: + callPackage ./wrapper.nix { + plugins = pluginfn pidginPackages; + pidgin = unwrapped; + }; }; meta = { @@ -147,5 +181,5 @@ let }; }; -in if plugins == [] then unwrapped - else unwrapped.withPlugins (_: plugins) +in +if plugins == [ ] then unwrapped else unwrapped.withPlugins (_: plugins) diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/carbons/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/carbons/default.nix index d24504f8260ca2..6333693e946d38 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/carbons/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/carbons/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, libxml2, pidgin, pkg-config, fetchFromGitHub } : +{ + lib, + stdenv, + libxml2, + pidgin, + pkg-config, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "pidgin-carbons"; @@ -6,15 +13,18 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "gkdr"; - repo = "carbons"; - rev = "v${version}"; + repo = "carbons"; + rev = "v${version}"; sha256 = "sha256-qiyIvmJbRmCrAi/93UxDVtO76nSdtzUVfT/sZGxxAh8="; }; makeFlags = [ "PURPLE_PLUGIN_DIR=$(out)/lib/pidgin" ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libxml2 pidgin ]; + buildInputs = [ + libxml2 + pidgin + ]; meta = with lib; { homepage = "https://github.com/gkdr/carbons"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/default.nix index 09d7bed922ee7c..6652781c75fcc7 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/default.nix @@ -1,21 +1,29 @@ -{ lib -, newScope -, pidgin -, texliveBasic -, config +{ + lib, + newScope, + pidgin, + texliveBasic, + config, }: -lib.makeScope newScope (self: - let callPackage = self.callPackage; - in { +lib.makeScope newScope ( + self: + let + callPackage = self.callPackage; + in + { pidgin = callPackage ../. { withOpenssl = config.pidgin.openssl or true; withGnutls = config.pidgin.gnutls or false; - plugins = []; + plugins = [ ]; }; # Prevent `pkgs/top-level/release-attrpaths-superset.nix` from recursing here. - pidginPackages = self // { pidginPackages = self.pidginPackages // { __attrsFailEvaluation = true; }; }; + pidginPackages = self // { + pidginPackages = self.pidginPackages // { + __attrsFailEvaluation = true; + }; + }; pidgin-indicator = callPackage ./pidgin-indicator { }; @@ -68,4 +76,5 @@ lib.makeScope newScope (self: pidgin-opensteamworks = callPackage ./pidgin-opensteamworks { }; purple-facebook = callPackage ./purple-facebook { }; -}) + } +) diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/msn-pecan/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/msn-pecan/default.nix index 7a761c1e91c864..1d50370c4be725 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/msn-pecan/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/msn-pecan/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, pidgin} : +{ + lib, + stdenv, + fetchFromGitHub, + pidgin, +}: stdenv.mkDerivation rec { pname = "pidgin-msn-pecan"; @@ -21,5 +26,5 @@ stdenv.mkDerivation rec { "PURPLE_DATADIR=${placeholder "out"}/share/data" ]; - buildInputs = [pidgin]; + buildInputs = [ pidgin ]; } diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/otr/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/otr/default.nix index aa871df5e8af21..912afcc18e1589 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/otr/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/otr/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, libotr, pidgin, intltool } : +{ + lib, + stdenv, + fetchurl, + libotr, + pidgin, + intltool, +}: stdenv.mkDerivation rec { pname = "pidgin-otr"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { postInstall = "ln -s \$out/lib/pidgin \$out/share/pidgin-otr"; nativeBuildInputs = [ intltool ]; - buildInputs = [ libotr pidgin ]; + buildInputs = [ + libotr + pidgin + ]; meta = with lib; { homepage = "https://otr.cypherpunks.ca/"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-indicator/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-indicator/default.nix index ddc52274174d0c..35002f0b577333 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-indicator/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-indicator/default.nix @@ -1,12 +1,13 @@ -{ autoreconfHook -, fetchFromGitHub -, glib -, intltool -, lib -, libappindicator-gtk2 -, libtool -, pidgin -, stdenv +{ + autoreconfHook, + fetchFromGitHub, + glib, + intltool, + lib, + libappindicator-gtk2, + libtool, + pidgin, + stdenv, }: stdenv.mkDerivation rec { @@ -20,8 +21,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-CdA/aUu+CmCRbVBKpJGydicqFQa/rEsLWS3MBKlH2/M="; }; - nativeBuildInputs = [ autoreconfHook intltool ]; - buildInputs = [ glib libappindicator-gtk2 libtool pidgin ]; + nativeBuildInputs = [ + autoreconfHook + intltool + ]; + buildInputs = [ + glib + libappindicator-gtk2 + libtool + pidgin + ]; meta = with lib; { description = "AppIndicator and KStatusNotifierItem Plugin for Pidgin"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-latex/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-latex/default.nix index 1250e3877b96b7..bdf455ea9ee9b8 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-latex/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-latex/default.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, fetchurl, pkg-config, pidgin, texLive, imagemagick, glib, gtk2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + pidgin, + texLive, + imagemagick, + glib, + gtk2, +}: -let version = "1.5.0"; +let + version = "1.5.0"; in stdenv.mkDerivation { pname = "pidgin-latex"; @@ -11,8 +22,12 @@ stdenv.mkDerivation { sha256 = "9c850aee90d7e59de834f83e09fa6e3e51b123f06e265ead70957608ada95441"; }; - nativeBuildInputs = [pkg-config]; - buildInputs = [gtk2 glib pidgin]; + nativeBuildInputs = [ pkg-config ]; + buildInputs = [ + gtk2 + glib + pidgin + ]; makeFlags = [ "PREFIX=$(out)" ]; postPatch = '' @@ -20,7 +35,12 @@ stdenv.mkDerivation { ''; passthru = { - wrapArgs = "--prefix PATH ':' ${lib.makeBinPath [ texLive imagemagick ]}"; + wrapArgs = "--prefix PATH ':' ${ + lib.makeBinPath [ + texLive + imagemagick + ] + }"; }; meta = with lib; { diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-mra/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-mra/default.nix index 2c6a0c5e7e64a9..9a53cd25f732ed 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-mra/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-mra/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, pidgin } : +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + pidgin, +}: stdenv.mkDerivation rec { pname = "pidgin-mra"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-opensteamworks/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-opensteamworks/default.nix index ceeac0acd0c3c5..3e2231c887d3dd 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-opensteamworks/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-opensteamworks/default.nix @@ -1,6 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, pidgin, glib, json-glib, nss, nspr -, libsecret -} : +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + pidgin, + glib, + json-glib, + nss, + nspr, + libsecret, +}: stdenv.mkDerivation rec { pname = "pidgin-opensteamworks"; @@ -24,7 +33,12 @@ stdenv.mkDerivation rec { pkg-config ]; buildInputs = [ - pidgin glib json-glib nss nspr libsecret + pidgin + glib + json-glib + nss + nspr + libsecret ]; meta = with lib; { diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-osd/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-osd/default.nix index d50a3ed5c30f28..bc3d98542a7229 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-osd/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-osd/default.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pidgin, xosd -, autoreconfHook } : +{ + lib, + stdenv, + fetchFromGitHub, + pidgin, + xosd, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "pidgin-osd"; @@ -21,7 +27,10 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ xosd pidgin ]; + buildInputs = [ + xosd + pidgin + ]; meta = with lib; { homepage = "https://github.com/mbroemme/pidgin-osd"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-skypeweb/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-skypeweb/default.nix index fc877115ad15b1..6c14b86281a11d 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-skypeweb/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-skypeweb/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, pidgin, json-glib }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + pidgin, + json-glib, +}: stdenv.mkDerivation rec { pname = "pidgin-skypeweb"; @@ -16,7 +23,10 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ pidgin json-glib ]; + buildInputs = [ + pidgin + json-glib + ]; PKG_CONFIG_PURPLE_PLUGINDIR = "${placeholder "out"}/lib/purple-2"; PKG_CONFIG_PURPLE_DATADIR = "${placeholder "out"}/share"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-xmpp-receipts/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-xmpp-receipts/default.nix index f545b65cd8ea9b..bae5df8c633395 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-xmpp-receipts/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/pidgin-xmpp-receipts/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, pidgin } : +{ + lib, + stdenv, + fetchFromGitHub, + pidgin, +}: let version = "0.8"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-discord/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-discord/default.nix index 8af6811d6a58c6..bda6c8455ad82a 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-discord/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-discord/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, imagemagick, gettext, pidgin, json-glib }: +{ + lib, + stdenv, + fetchFromGitHub, + imagemagick, + gettext, + pidgin, + json-glib, +}: stdenv.mkDerivation { pname = "purple-discord"; @@ -11,8 +19,14 @@ stdenv.mkDerivation { sha256 = "0xvj9rdvgsvcr55sk9m40y07rchg699l1yr98xqwx7sc2sba3814"; }; - nativeBuildInputs = [ imagemagick gettext ]; - buildInputs = [ pidgin json-glib ]; + nativeBuildInputs = [ + imagemagick + gettext + ]; + buildInputs = [ + pidgin + json-glib + ]; PKG_CONFIG_PURPLE_PLUGINDIR = "${placeholder "out"}/lib/purple-2"; PKG_CONFIG_PURPLE_DATADIR = "${placeholder "out"}/share"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-facebook/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-facebook/default.nix index b1078c864de67c..2a7a5238ec41c8 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-facebook/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-facebook/default.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchhg, pidgin, glib, json-glib, autoreconfHook }: - +{ + lib, + stdenv, + fetchFromGitHub, + fetchhg, + pidgin, + glib, + json-glib, + autoreconfHook, +}: let pidginHg = fetchhg { @@ -9,7 +17,8 @@ let sha256 = "06imlhsps4wrjgjb92zpaxprxfxl2pjb2x9pl859c8cryssrz2jv"; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "purple-facebook"; version = "0.9.5"; @@ -54,7 +63,11 @@ in stdenv.mkDerivation rec { ''; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ pidgin glib json-glib ]; + buildInputs = [ + pidgin + glib + json-glib + ]; meta = with lib; { inherit (src.meta) homepage; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-googlechat/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-googlechat/default.nix index 4fb4a1c1c26dcd..66d5d1605e24ba 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-googlechat/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-googlechat/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, pidgin, glib, json-glib, protobuf, protobufc }: +{ + lib, + stdenv, + fetchFromGitHub, + pidgin, + glib, + json-glib, + protobuf, + protobufc, +}: stdenv.mkDerivation { pname = "purple-googlechat"; @@ -12,7 +21,12 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ protobufc ]; - buildInputs = [ pidgin glib json-glib protobuf ]; + buildInputs = [ + pidgin + glib + json-glib + protobuf + ]; PKG_CONFIG_PURPLE_PLUGINDIR = "${placeholder "out"}/lib/purple-2"; PKG_CONFIG_PURPLE_DATADIR = "${placeholder "out"}/share"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-hangouts/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-hangouts/default.nix index e3713afbec0ebc..03efdd49513fd6 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-hangouts/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-hangouts/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchhg, pidgin, glib, json-glib, protobuf, protobufc }: +{ + lib, + stdenv, + fetchhg, + pidgin, + glib, + json-glib, + protobuf, + protobufc, +}: stdenv.mkDerivation { pname = "purple-hangouts-hg"; @@ -10,7 +19,13 @@ stdenv.mkDerivation { sha256 = "1zd1rlzqvw1zkb0ydyz039n3xa1kv1f20a4l6rkm9a8sp6rpf3pi"; }; - buildInputs = [ pidgin glib json-glib protobuf protobufc ]; + buildInputs = [ + pidgin + glib + json-glib + protobuf + protobufc + ]; PKG_CONFIG_PURPLE_PLUGINDIR = "${placeholder "out"}/lib/purple-2"; PKG_CONFIG_PURPLE_DATADIR = "${placeholder "out"}/share"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-lurch/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-lurch/default.nix index 2348e1a877ec68..4f29ebdf3bb690 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-lurch/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-lurch/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pidgin, minixml, libxml2, sqlite, libgcrypt }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pidgin, + minixml, + libxml2, + sqlite, + libgcrypt, +}: stdenv.mkDerivation rec { pname = "purple-lurch"; @@ -13,7 +23,13 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ pidgin minixml libxml2 sqlite libgcrypt ]; + buildInputs = [ + pidgin + minixml + libxml2 + sqlite + libgcrypt + ]; dontUseCmakeConfigure = true; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-matrix/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-matrix/default.nix index 0b51d172b7462c..1c34b3381708e0 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-matrix/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-matrix/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, pidgin, json-glib, glib, http-parser, sqlite, olm, libgcrypt } : +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + pidgin, + json-glib, + glib, + http-parser, + sqlite, + olm, + libgcrypt, +}: stdenv.mkDerivation rec { pname = "purple-matrix-unstable"; @@ -15,11 +27,20 @@ stdenv.mkDerivation rec { # glib-2.62 deprecations "-DGLIB_DISABLE_DEPRECATION_WARNINGS" # override "-O0 -Werror" set by build system - "-O3" "-Wno-error" + "-O3" + "-Wno-error" ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ pidgin json-glib glib http-parser sqlite olm libgcrypt ]; + buildInputs = [ + pidgin + json-glib + glib + http-parser + sqlite + olm + libgcrypt + ]; makeFlags = [ "PLUGIN_DIR_PURPLE=${placeholder "out"}/lib/purple-2" diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-mm-sms/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-mm-sms/default.nix index 1b84b1a93ab22a..b002d1f08eeca5 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-mm-sms/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-mm-sms/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, glibmm, pidgin, pkg-config, modemmanager, fetchFromGitLab } : +{ + lib, + stdenv, + glibmm, + pidgin, + pkg-config, + modemmanager, + fetchFromGitLab, +}: stdenv.mkDerivation rec { pname = "purple-mm-sms"; @@ -18,7 +26,11 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glibmm pidgin modemmanager ]; + buildInputs = [ + glibmm + pidgin + modemmanager + ]; meta = with lib; { homepage = "https://source.puri.sm/Librem5/purple-mm-sms"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-plugin-pack/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-plugin-pack/default.nix index 388f633f3dabf0..47c01b85383442 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-plugin-pack/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-plugin-pack/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pidgin +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pidgin, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-signald/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-signald/default.nix index c3ff29cb09fbec..ed295055c2bec5 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-signald/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-signald/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pidgin, json-glib, signald }: +{ + lib, + stdenv, + fetchFromGitHub, + pidgin, + json-glib, + signald, +}: stdenv.mkDerivation rec { pname = "purple-signald"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-slack/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-slack/default.nix index 9f5f9a2bda1e3c..567b957c8aaaba 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-slack/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-slack/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pidgin, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + pidgin, + pkg-config, +}: stdenv.mkDerivation { pname = "purple-slack-unstable"; @@ -25,4 +31,3 @@ stdenv.mkDerivation { maintainers = with maintainers; [ eyjhb ]; }; } - diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-vk-plugin/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-vk-plugin/default.nix index 07b38ff3c5a27c..ad3ad0d088a544 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-vk-plugin/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-vk-plugin/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchhg, pidgin, cmake, libxml2 } : +{ + lib, + stdenv, + fetchhg, + pidgin, + cmake, + libxml2, +}: let version = "40ddb6d"; @@ -14,7 +21,10 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ pidgin libxml2 ]; + buildInputs = [ + pidgin + libxml2 + ]; preConfigure = '' sed -i -e 's|DESTINATION.*PURPLE_PLUGIN_DIR}|DESTINATION lib/purple-2|' CMakeLists.txt diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-xmpp-http-upload/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-xmpp-http-upload/default.nix index c52082e06c908e..8e70c8f6d2c4a9 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-xmpp-http-upload/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/purple-xmpp-http-upload/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pidgin, glib, libxml2 }: +{ + lib, + stdenv, + fetchFromGitHub, + pidgin, + glib, + libxml2, +}: stdenv.mkDerivation { pname = "purple-xmpp-upload"; @@ -11,7 +18,11 @@ stdenv.mkDerivation { sha256 = "0n05jybmibn44xb660p08vrrbanfsyjn17w1xm9gwl75fxxq8cdc"; }; - buildInputs = [ pidgin glib libxml2 ]; + buildInputs = [ + pidgin + glib + libxml2 + ]; installPhase = '' install -Dm644 -t $out/lib/purple-2 jabber_http_file_upload.so diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/sipe/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/sipe/default.nix index 1cf7fed874e9db..37e69759286f80 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/sipe/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/sipe/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, fetchpatch, pidgin, intltool, libxml2, gmime, nss }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pidgin, + intltool, + libxml2, + gmime, + nss, +}: stdenv.mkDerivation rec { pname = "pidgin-sipe"; @@ -24,7 +34,12 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ intltool ]; - buildInputs = [ pidgin gmime libxml2 nss ]; + buildInputs = [ + pidgin + gmime + libxml2 + nss + ]; configureFlags = [ "--without-dbus" "--enable-quality-check=no" diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/tdlib-purple/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/tdlib-purple/default.nix index 26c67b070e5e83..1e8bf780dcebfd 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/tdlib-purple/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/tdlib-purple/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, libwebp, pidgin, tdlib } : +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + libwebp, + pidgin, + tdlib, +}: stdenv.mkDerivation rec { pname = "tdlib-purple"; @@ -25,11 +34,17 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ cmake ]; - buildInputs = [ libwebp pidgin tdlib ]; + buildInputs = [ + libwebp + pidgin + tdlib + ]; cmakeFlags = [ "-DNoVoip=True" ]; # libtgvoip required - env.NIX_CFLAGS_COMPILE = toString (lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ "-U__ARM_NEON__" ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ "-U__ARM_NEON__" ] + ); meta = with lib; { homepage = "https://github.com/ars3niy/tdlib-purple"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/window-merge/default.nix b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/window-merge/default.nix index bcc09b1f6481ec..387ebbd9f3ce68 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/window-merge/default.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/pidgin-plugins/window-merge/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, pidgin } : +{ + lib, + stdenv, + fetchurl, + pidgin, +}: stdenv.mkDerivation rec { pname = "pidgin-window-merge"; diff --git a/pkgs/applications/networking/instant-messengers/pidgin/wrapper.nix b/pkgs/applications/networking/instant-messengers/pidgin/wrapper.nix index a2885d7194f4b1..8f24b2124503ef 100644 --- a/pkgs/applications/networking/instant-messengers/pidgin/wrapper.nix +++ b/pkgs/applications/networking/instant-messengers/pidgin/wrapper.nix @@ -1,8 +1,15 @@ -{ lib, symlinkJoin, pidgin, makeWrapper, plugins }: +{ + lib, + symlinkJoin, + pidgin, + makeWrapper, + plugins, +}: let -extraArgs = map (x: x.wrapArgs or "") plugins; -in symlinkJoin { + extraArgs = map (x: x.wrapArgs or "") plugins; +in +symlinkJoin { name = "pidgin-with-plugins-${pidgin.version}"; paths = [ pidgin ] ++ plugins; diff --git a/pkgs/applications/networking/instant-messengers/profanity/default.nix b/pkgs/applications/networking/instant-messengers/profanity/default.nix index 4687fd5f4ac3ed..5ea2ed6bc1b3ae 100644 --- a/pkgs/applications/networking/instant-messengers/profanity/default.nix +++ b/pkgs/applications/networking/instant-messengers/profanity/default.nix @@ -1,29 +1,40 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf-archive -, autoreconfHook -, cmocka -, curl -, expat -, expect -, glib -, glibcLocales -, libstrophe -, libmicrohttpd -, libotr -, libuuid -, ncurses -, openssl -, pkg-config -, readline -, sqlite -, autoAwaySupport ? true, libXScrnSaver, libX11 -, notifySupport ? true, libnotify, gdk-pixbuf -, omemoSupport ? true, libsignal-protocol-c, libgcrypt, qrencode -, pgpSupport ? true, gpgme -, pythonPluginSupport ? true, python3 -, traySupport ? true, gtk3 +{ + lib, + stdenv, + fetchFromGitHub, + autoconf-archive, + autoreconfHook, + cmocka, + curl, + expat, + expect, + glib, + glibcLocales, + libstrophe, + libmicrohttpd, + libotr, + libuuid, + ncurses, + openssl, + pkg-config, + readline, + sqlite, + autoAwaySupport ? true, + libXScrnSaver, + libX11, + notifySupport ? true, + libnotify, + gdk-pixbuf, + omemoSupport ? true, + libsignal-protocol-c, + libgcrypt, + qrencode, + pgpSupport ? true, + gpgme, + pythonPluginSupport ? true, + python3, + traySupport ? true, + gtk3, }: stdenv.mkDerivation rec { @@ -50,36 +61,50 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - cmocka - curl - expat - expect - glib - libstrophe - libmicrohttpd - libotr - libuuid - ncurses - openssl - readline - sqlite - ] ++ lib.optionals autoAwaySupport [ libXScrnSaver libX11 ] - ++ lib.optionals notifySupport [ libnotify gdk-pixbuf ] - ++ lib.optionals omemoSupport [ libsignal-protocol-c libgcrypt qrencode ] - ++ lib.optionals pgpSupport [ gpgme ] + buildInputs = + [ + cmocka + curl + expat + expect + glib + libstrophe + libmicrohttpd + libotr + libuuid + ncurses + openssl + readline + sqlite + ] + ++ lib.optionals autoAwaySupport [ + libXScrnSaver + libX11 + ] + ++ lib.optionals notifySupport [ + libnotify + gdk-pixbuf + ] + ++ lib.optionals omemoSupport [ + libsignal-protocol-c + libgcrypt + qrencode + ] + ++ lib.optionals pgpSupport [ gpgme ] ++ lib.optionals pythonPluginSupport [ python3 ] - ++ lib.optionals traySupport [ gtk3 ]; + ++ lib.optionals traySupport [ gtk3 ]; # Enable feature flags, so that build fail if libs are missing - configureFlags = [ - "--enable-c-plugins" - "--enable-otr" - ] ++ lib.optionals notifySupport [ "--enable-notifications" ] - ++ lib.optionals traySupport [ "--enable-icons-and-clipboard" ] - ++ lib.optionals pgpSupport [ "--enable-pgp" ] + configureFlags = + [ + "--enable-c-plugins" + "--enable-otr" + ] + ++ lib.optionals notifySupport [ "--enable-notifications" ] + ++ lib.optionals traySupport [ "--enable-icons-and-clipboard" ] + ++ lib.optionals pgpSupport [ "--enable-pgp" ] ++ lib.optionals pythonPluginSupport [ "--enable-python-plugins" ] - ++ lib.optionals omemoSupport [ "--enable-omemo" ]; + ++ lib.optionals omemoSupport [ "--enable-omemo" ]; preAutoreconf = '' mkdir m4 @@ -89,7 +114,7 @@ stdenv.mkDerivation rec { LC_ALL = "en_US.utf8"; - meta = with lib; { + meta = with lib; { homepage = "http://www.profanity.im/"; description = "Console based XMPP client"; mainProgram = "profanity"; diff --git a/pkgs/applications/networking/instant-messengers/psi-plus/default.nix b/pkgs/applications/networking/instant-messengers/psi-plus/default.nix index 519c2a0b66eca6..8baa7849901758 100644 --- a/pkgs/applications/networking/instant-messengers/psi-plus/default.nix +++ b/pkgs/applications/networking/instant-messengers/psi-plus/default.nix @@ -1,36 +1,37 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, cmake -, qtbase -, qtmultimedia -, qtimageformats -, qtx11extras -, qttools -, libidn -, qca-qt5 -, libXScrnSaver -, hunspell -, libsecret -, libgcrypt -, libotr -, html-tidy -, libgpg-error -, libsignal-protocol-c -, usrsctp +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + qtbase, + qtmultimedia, + qtimageformats, + qtx11extras, + qttools, + libidn, + qca-qt5, + libXScrnSaver, + hunspell, + libsecret, + libgcrypt, + libotr, + html-tidy, + libgpg-error, + libsignal-protocol-c, + usrsctp, -, chatType ? "basic" # See the assertion below for available options -, qtwebkit -, qtwebengine + chatType ? "basic", # See the assertion below for available options + qtwebkit, + qtwebengine, -, enablePlugins ? true + enablePlugins ? true, # Voice messages -, voiceMessagesSupport ? true -, gst_all_1 + voiceMessagesSupport ? true, + gst_all_1, -, enablePsiMedia ? false -, pkg-config + enablePsiMedia ? false, + pkg-config, }: assert builtins.elem (lib.toLower chatType) [ @@ -58,37 +59,43 @@ mkDerivation rec { "-DBUILD_PSIMEDIA=${if enablePsiMedia then "ON" else "OFF"}" ]; - nativeBuildInputs = [ - cmake - qttools - ] ++ lib.optionals enablePsiMedia [ - pkg-config - ]; + nativeBuildInputs = + [ + cmake + qttools + ] + ++ lib.optionals enablePsiMedia [ + pkg-config + ]; - buildInputs = [ - qtbase - qtmultimedia - qtimageformats - qtx11extras - libidn - qca-qt5 - libXScrnSaver - hunspell - libsecret - libgcrypt - libotr - html-tidy - libgpg-error - libsignal-protocol-c - usrsctp - ] ++ lib.optionals voiceMessagesSupport [ - gst_all_1.gst-plugins-base - gst_all_1.gst-plugins-good - ] ++ lib.optionals (chatType == "webkit") [ - qtwebkit - ] ++ lib.optionals (chatType == "webengine") [ - qtwebengine - ]; + buildInputs = + [ + qtbase + qtmultimedia + qtimageformats + qtx11extras + libidn + qca-qt5 + libXScrnSaver + hunspell + libsecret + libgcrypt + libotr + html-tidy + libgpg-error + libsignal-protocol-c + usrsctp + ] + ++ lib.optionals voiceMessagesSupport [ + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-good + ] + ++ lib.optionals (chatType == "webkit") [ + qtwebkit + ] + ++ lib.optionals (chatType == "webengine") [ + qtwebengine + ]; preFixup = lib.optionalString voiceMessagesSupport '' qtWrapperArgs+=( @@ -100,7 +107,10 @@ mkDerivation rec { homepage = "https://psi-plus.com"; description = "XMPP (Jabber) client based on Qt5"; mainProgram = "psi-plus"; - maintainers = with maintainers; [ orivej unclechu ]; + maintainers = with maintainers; [ + orivej + unclechu + ]; license = licenses.gpl2Only; platforms = platforms.linux; }; diff --git a/pkgs/applications/networking/instant-messengers/psi/default.nix b/pkgs/applications/networking/instant-messengers/psi/default.nix index d1f0ce3b228594..0f386c884cc84e 100644 --- a/pkgs/applications/networking/instant-messengers/psi/default.nix +++ b/pkgs/applications/networking/instant-messengers/psi/default.nix @@ -1,6 +1,17 @@ -{ lib, mkDerivation, fetchFromGitHub, cmake -, qtbase, qtmultimedia, qtx11extras, qttools, qtwebengine -, libidn, qca-qt5, libXScrnSaver, hunspell +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + qtbase, + qtmultimedia, + qtx11extras, + qttools, + qtwebengine, + libidn, + qca-qt5, + libXScrnSaver, + hunspell, }: mkDerivation rec { @@ -16,10 +27,19 @@ mkDerivation rec { patches = [ ./fix-cmake-hunspell-1.7.patch ]; - nativeBuildInputs = [ cmake qttools ]; + nativeBuildInputs = [ + cmake + qttools + ]; buildInputs = [ - qtbase qtmultimedia qtx11extras qtwebengine - libidn qca-qt5 libXScrnSaver hunspell + qtbase + qtmultimedia + qtx11extras + qtwebengine + libidn + qca-qt5 + libXScrnSaver + hunspell ]; meta = with lib; { diff --git a/pkgs/applications/networking/instant-messengers/quaternion/default.nix b/pkgs/applications/networking/instant-messengers/quaternion/default.nix index ef6bc08616c541..af2c5434bd684a 100644 --- a/pkgs/applications/networking/instant-messengers/quaternion/default.nix +++ b/pkgs/applications/networking/instant-messengers/quaternion/default.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, wrapQtAppsHook -, qtbase -, qtquickcontrols2 ? null # only a separate package on qt5 -, qtkeychain -, qtmultimedia -, qttools -, libquotient -, libsecret -, olm +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + wrapQtAppsHook, + qtbase, + qtquickcontrols2 ? null, # only a separate package on qt5 + qtkeychain, + qtmultimedia, + qttools, + libquotient, + libsecret, + olm, }: let @@ -38,7 +39,11 @@ stdenv.mkDerivation (finalAttrs: { qtquickcontrols2 ]; - nativeBuildInputs = [ cmake qttools wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + qttools + wrapQtAppsHook + ]; # qt6 needs UTF env.LANG = "C.UTF-8"; @@ -49,14 +54,17 @@ stdenv.mkDerivation (finalAttrs: { ]; postInstall = - if stdenv.hostPlatform.isDarwin then '' - mkdir -p $out/Applications - mv $out/bin/quaternion.app $out/Applications - rmdir $out/bin || : - '' else '' - substituteInPlace $out/share/applications/com.github.quaternion.desktop \ - --replace 'Exec=quaternion' "Exec=$out/bin/quaternion" - ''; + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p $out/Applications + mv $out/bin/quaternion.app $out/Applications + rmdir $out/bin || : + '' + else + '' + substituteInPlace $out/share/applications/com.github.quaternion.desktop \ + --replace 'Exec=quaternion' "Exec=$out/bin/quaternion" + ''; meta = with lib; { description = "Cross-platform desktop IM client for the Matrix protocol"; diff --git a/pkgs/applications/networking/instant-messengers/ripcord/darwin.nix b/pkgs/applications/networking/instant-messengers/ripcord/darwin.nix index 39403ba774fa33..9fccad174317a6 100644 --- a/pkgs/applications/networking/instant-messengers/ripcord/darwin.nix +++ b/pkgs/applications/networking/instant-messengers/ripcord/darwin.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchzip }: +{ + stdenvNoCC, + lib, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "ripcord"; diff --git a/pkgs/applications/networking/instant-messengers/ripcord/default.nix b/pkgs/applications/networking/instant-messengers/ripcord/default.nix index 7e40f880d27617..fdfa1fd0184e74 100644 --- a/pkgs/applications/networking/instant-messengers/ripcord/default.nix +++ b/pkgs/applications/networking/instant-messengers/ripcord/default.nix @@ -1,27 +1,67 @@ -{ lib, mkDerivation, fetchurl, makeFontsConf, appimageTools -, qtbase, qtsvg, qtmultimedia, qtwebsockets, qtimageformats -, autoPatchelfHook, desktop-file-utils, imagemagick -, twemoji-color-font, xorg, libsodium, libopus, libGL, alsa-lib }: +{ + lib, + mkDerivation, + fetchurl, + makeFontsConf, + appimageTools, + qtbase, + qtsvg, + qtmultimedia, + qtwebsockets, + qtimageformats, + autoPatchelfHook, + desktop-file-utils, + imagemagick, + twemoji-color-font, + xorg, + libsodium, + libopus, + libGL, + alsa-lib, +}: mkDerivation rec { pname = "ripcord"; version = "0.4.29"; - src = let - appimage = fetchurl { - url = "https://cancel.fm/dl/Ripcord-${version}-x86_64.AppImage"; - sha256 = "sha256-4yDLPEBDsPKWtLwdpmSyl3b5XCwLAr2/EVtNRrFmmJk="; - name = "${pname}-${version}.AppImage"; + src = + let + appimage = fetchurl { + url = "https://cancel.fm/dl/Ripcord-${version}-x86_64.AppImage"; + sha256 = "sha256-4yDLPEBDsPKWtLwdpmSyl3b5XCwLAr2/EVtNRrFmmJk="; + name = "${pname}-${version}.AppImage"; + }; + in + appimageTools.extract { + inherit pname version; + src = appimage; }; - in appimageTools.extract { - inherit pname version; - src = appimage; - }; - nativeBuildInputs = [ autoPatchelfHook desktop-file-utils imagemagick ]; - buildInputs = [ libsodium libopus libGL alsa-lib ] - ++ [ qtbase qtsvg qtmultimedia qtwebsockets qtimageformats ] - ++ (with xorg; [ libX11 libXScrnSaver libXcursor xkeyboardconfig ]); + nativeBuildInputs = [ + autoPatchelfHook + desktop-file-utils + imagemagick + ]; + buildInputs = + [ + libsodium + libopus + libGL + alsa-lib + ] + ++ [ + qtbase + qtsvg + qtmultimedia + qtwebsockets + qtimageformats + ] + ++ (with xorg; [ + libX11 + libXScrnSaver + libXcursor + xkeyboardconfig + ]); fontsConf = makeFontsConf { fontDirectories = [ twemoji-color-font ]; diff --git a/pkgs/applications/networking/instant-messengers/teamspeak/client5.nix b/pkgs/applications/networking/instant-messengers/teamspeak/client5.nix index c66c765a5038e5..88884c6ba9d51b 100644 --- a/pkgs/applications/networking/instant-messengers/teamspeak/client5.nix +++ b/pkgs/applications/networking/instant-messengers/teamspeak/client5.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, copyDesktopItems -, makeDesktopItem -, makeWrapper -, alsa-lib -, at-spi2-atk -, atk -, cairo -, cups -, dbus -, gcc-unwrapped -, gdk-pixbuf -, glib -, gtk3 -, libdrm -, libnotify -, libpulseaudio -, libxkbcommon -, mesa -, nss -, udev -, xorg +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + copyDesktopItems, + makeDesktopItem, + makeWrapper, + alsa-lib, + at-spi2-atk, + atk, + cairo, + cups, + dbus, + gcc-unwrapped, + gdk-pixbuf, + glib, + gtk3, + libdrm, + libnotify, + libpulseaudio, + libxkbcommon, + mesa, + nss, + udev, + xorg, }: stdenv.mkDerivation rec { @@ -74,7 +75,12 @@ stdenv.mkDerivation rec { icon = pname; desktopName = pname; comment = "TeamSpeak Voice Communication Client"; - categories = ["Audio" "AudioVideo" "Chat" "Network"]; + categories = [ + "Audio" + "AudioVideo" + "Chat" + "Network" + ]; }) ]; diff --git a/pkgs/applications/networking/instant-messengers/teamspeak/server.nix b/pkgs/applications/networking/instant-messengers/teamspeak/server.nix index d1be4c251fc704..ba8a5c5fa61052 100644 --- a/pkgs/applications/networking/instant-messengers/teamspeak/server.nix +++ b/pkgs/applications/networking/instant-messengers/teamspeak/server.nix @@ -1,19 +1,32 @@ -{ lib, stdenv, fetchurl, postgresql, autoPatchelfHook, writeScript }: +{ + lib, + stdenv, + fetchurl, + postgresql, + autoPatchelfHook, + writeScript, +}: let arch = if stdenv.hostPlatform.is64bit then "amd64" else "x86"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "teamspeak-server"; version = "3.13.7"; src = fetchurl { url = "https://files.teamspeak-services.com/releases/server/${version}/teamspeak3-server_linux_${arch}-${version}.tar.bz2"; - sha256 = if stdenv.hostPlatform.is64bit - then "sha256-d1pXMamAmAHkyPkGbNm8ViobNoVTE5wSSfKgdA1QBB4=" - else "sha256-aMEDOnvBeKfzG8lDFhU8I5DYgG53IsCDBMV2MUyJi2g="; + sha256 = + if stdenv.hostPlatform.is64bit then + "sha256-d1pXMamAmAHkyPkGbNm8ViobNoVTE5wSSfKgdA1QBB4=" + else + "sha256-aMEDOnvBeKfzG8lDFhU8I5DYgG53IsCDBMV2MUyJi2g="; }; - buildInputs = [ stdenv.cc.cc postgresql.lib ]; + buildInputs = [ + stdenv.cc.cc + postgresql.lib + ]; nativeBuildInputs = [ autoPatchelfHook ]; @@ -62,6 +75,9 @@ in stdenv.mkDerivation rec { # See distribution-permit.txt for a confirmation that nixpkgs is allowed to distribute TeamSpeak. license = licenses.unfreeRedistributable; platforms = platforms.linux; - maintainers = with maintainers; [ arobyn gerschtli ]; + maintainers = with maintainers; [ + arobyn + gerschtli + ]; }; } diff --git a/pkgs/applications/networking/instant-messengers/telegram/tg/default.nix b/pkgs/applications/networking/instant-messengers/telegram/tg/default.nix index d23ee405efc2f6..efa7dffdae7117 100644 --- a/pkgs/applications/networking/instant-messengers/telegram/tg/default.nix +++ b/pkgs/applications/networking/instant-messengers/telegram/tg/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, pythonOlder -, fetchpatch -, stdenv -, libnotify -, python-telegram +{ + lib, + buildPythonApplication, + fetchFromGitHub, + pythonOlder, + fetchpatch, + stdenv, + libnotify, + python-telegram, }: buildPythonApplication rec { diff --git a/pkgs/applications/networking/instant-messengers/tensor/default.nix b/pkgs/applications/networking/instant-messengers/tensor/default.nix index 2a42692e412c2a..1ee4fec5e564bc 100644 --- a/pkgs/applications/networking/instant-messengers/tensor/default.nix +++ b/pkgs/applications/networking/instant-messengers/tensor/default.nix @@ -1,11 +1,12 @@ -{ mkDerivation -, lib -, stdenv -, fetchFromGitHub -, qtbase -, qtquickcontrols -, qmake -, makeDesktopItem +{ + mkDerivation, + lib, + stdenv, + fetchFromGitHub, + qtbase, + qtquickcontrols, + qmake, + makeDesktopItem, }: # we now have libqmatrixclient so a future version of tensor that supports it @@ -23,7 +24,10 @@ mkDerivation rec { fetchSubmodules = true; }; - buildInputs = [ qtbase qtquickcontrols ]; + buildInputs = [ + qtbase + qtquickcontrols + ]; nativeBuildInputs = [ qmake ]; desktopItem = makeDesktopItem { @@ -33,31 +37,38 @@ mkDerivation rec { comment = meta.description; desktopName = "Tensor Matrix Client"; genericName = meta.description; - categories = [ "Chat" "Utility" ]; + categories = [ + "Chat" + "Utility" + ]; mimeTypes = [ "application/x-chat" ]; }; - installPhase = if stdenv.hostPlatform.isDarwin then '' - runHook preInstall + installPhase = + if stdenv.hostPlatform.isDarwin then + '' + runHook preInstall - mkdir -p $out/Applications - cp -r tensor.app $out/Applications/tensor.app + mkdir -p $out/Applications + cp -r tensor.app $out/Applications/tensor.app - runHook postInstall - '' else '' - runHook preInstall + runHook postInstall + '' + else + '' + runHook preInstall - install -Dm755 tensor $out/bin/tensor - install -Dm644 client/logo.png \ - $out/share/icons/hicolor/512x512/apps/tensor.png - install -Dm644 ${desktopItem}/share/applications/tensor.desktop \ - $out/share/applications/tensor.desktop + install -Dm755 tensor $out/bin/tensor + install -Dm644 client/logo.png \ + $out/share/icons/hicolor/512x512/apps/tensor.png + install -Dm644 ${desktopItem}/share/applications/tensor.desktop \ + $out/share/applications/tensor.desktop - substituteInPlace $out/share/applications/tensor.desktop \ - --subst-var-by bin $out/bin/tensor + substituteInPlace $out/share/applications/tensor.desktop \ + --subst-var-by bin $out/bin/tensor - runHook postInstall - ''; + runHook postInstall + ''; meta = with lib; { homepage = "https://github.com/davidar/tensor"; diff --git a/pkgs/applications/networking/instant-messengers/twinkle/default.nix b/pkgs/applications/networking/instant-messengers/twinkle/default.nix index af00b360bf9b18..d86fad39c334b9 100644 --- a/pkgs/applications/networking/instant-messengers/twinkle/default.nix +++ b/pkgs/applications/networking/instant-messengers/twinkle/default.nix @@ -1,22 +1,23 @@ -{ lib -, fetchFromGitHub -, cmake -, libxml2 -, libsndfile -, file -, readline -, bison -, flex -, ucommon -, ccrtp -, qtbase -, qttools -, qtquickcontrols2 -, alsa-lib -, speex -, ilbc -, mkDerivation -, bcg729 +{ + lib, + fetchFromGitHub, + cmake, + libxml2, + libsndfile, + file, + readline, + bison, + flex, + ucommon, + ccrtp, + qtbase, + qttools, + qtquickcontrols2, + alsa-lib, + speex, + ilbc, + mkDerivation, + bcg729, }: mkDerivation rec { @@ -57,7 +58,7 @@ mkDerivation rec { "-DWITH_SPEEX=On" "-DWITH_ILBC=On" "-DHAVE_LIBATOMIC=atomic" - /* "-DWITH_DIAMONDCARD=On" seems ancient and broken */ + # "-DWITH_DIAMONDCARD=On" seems ancient and broken ]; meta = with lib; { diff --git a/pkgs/applications/networking/instant-messengers/twitch-tui/default.nix b/pkgs/applications/networking/instant-messengers/twitch-tui/default.nix index 6c703855039ded..807d8f9fbbb668 100644 --- a/pkgs/applications/networking/instant-messengers/twitch-tui/default.nix +++ b/pkgs/applications/networking/instant-messengers/twitch-tui/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, pkg-config -, openssl -, CoreServices -, Security -, SystemConfiguration +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + CoreServices, + Security, + SystemConfiguration, }: rustPlatform.buildRustPackage rec { @@ -26,13 +27,15 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreServices - Security - SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + Security + SystemConfiguration + ]; meta = with lib; { description = "Twitch chat in the terminal"; diff --git a/pkgs/applications/networking/instant-messengers/vacuum/default.nix b/pkgs/applications/networking/instant-messengers/vacuum/default.nix index fffda2fedfa84e..b390d62ea97568 100644 --- a/pkgs/applications/networking/instant-messengers/vacuum/default.nix +++ b/pkgs/applications/networking/instant-messengers/vacuum/default.nix @@ -1,14 +1,20 @@ -{ stdenv, lib, fetchFromGitHub -, qtbase -, qttools -, qtx11extras -, qtmultimedia -, qtwebkit -, wrapQtAppsHook -, cmake -, openssl -, xorgproto, libX11, libXScrnSaver -, xz, zlib +{ + stdenv, + lib, + fetchFromGitHub, + qtbase, + qttools, + qtx11extras, + qtmultimedia, + qtwebkit, + wrapQtAppsHook, + cmake, + openssl, + xorgproto, + libX11, + libXScrnSaver, + xz, + zlib, }: stdenv.mkDerivation { pname = "vacuum-im"; diff --git a/pkgs/applications/networking/irc/communi/default.nix b/pkgs/applications/networking/irc/communi/default.nix index 9c25ece8556b34..2d631994512bcc 100644 --- a/pkgs/applications/networking/irc/communi/default.nix +++ b/pkgs/applications/networking/irc/communi/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, libcommuni -, qmake -, qtbase -, wrapQtAppsHook +{ + stdenv, + lib, + fetchFromGitHub, + libcommuni, + qmake, + qtbase, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -47,22 +48,27 @@ stdenv.mkDerivation rec { "COMMUNI_INSTALL_ICONS=${placeholder "out"}/share/icons/hicolor" "COMMUNI_INSTALL_DESKTOP=${placeholder "out"}/share/applications" "COMMUNI_INSTALL_THEMES=${placeholder "out"}/share/communi/themes" - "COMMUNI_INSTALL_BINS=${placeholder "out"}/${if stdenv.hostPlatform.isDarwin then "Applications" else "bin"}" + "COMMUNI_INSTALL_BINS=${placeholder "out"}/${ + if stdenv.hostPlatform.isDarwin then "Applications" else "bin" + }" ]; postInstall = - if stdenv.hostPlatform.isDarwin then '' - # Nix qmake does not add the bundle rpath by default. - install_name_tool \ - -add_rpath @executable_path/../Frameworks \ - $out/Applications/Communi.app/Contents/MacOS/Communi + if stdenv.hostPlatform.isDarwin then + '' + # Nix qmake does not add the bundle rpath by default. + install_name_tool \ + -add_rpath @executable_path/../Frameworks \ + $out/Applications/Communi.app/Contents/MacOS/Communi - # Do not remove until wrapQtAppsHook doesn't wrap dylibs in app bundles anymore - wrapQtApp $out/Applications/Communi.app/Contents/MacOS/Communi - '' else '' - substituteInPlace "$out/share/applications/communi.desktop" \ - --replace "/usr/bin" "$out/bin" - ''; + # Do not remove until wrapQtAppsHook doesn't wrap dylibs in app bundles anymore + wrapQtApp $out/Applications/Communi.app/Contents/MacOS/Communi + '' + else + '' + substituteInPlace "$out/share/applications/communi.desktop" \ + --replace "/usr/bin" "$out/bin" + ''; preFixup = '' rm -rf lib diff --git a/pkgs/applications/networking/irc/ii/default.nix b/pkgs/applications/networking/irc/ii/default.nix index 8fca009922527c..fbab300a60bb38 100644 --- a/pkgs/applications/networking/irc/ii/default.nix +++ b/pkgs/applications/networking/irc/ii/default.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ii"; diff --git a/pkgs/applications/networking/irc/irssi/default.nix b/pkgs/applications/networking/irc/irssi/default.nix index 6e035b2bdbc2fc..1495b2daca7089 100644 --- a/pkgs/applications/networking/irc/irssi/default.nix +++ b/pkgs/applications/networking/irc/irssi/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, glib -, libgcrypt -, libintl -, libotr -, meson -, ncurses -, ninja -, openssl -, perl -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + glib, + libgcrypt, + libintl, + libotr, + meson, + ncurses, + ninja, + openssl, + perl, + pkg-config, }: stdenv.mkDerivation rec { @@ -51,7 +52,10 @@ stdenv.mkDerivation rec { mainProgram = "irssi"; homepage = "https://irssi.org"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ fab lovek323 ]; + maintainers = with maintainers; [ + fab + lovek323 + ]; platforms = platforms.unix; }; } diff --git a/pkgs/applications/networking/irc/kvirc/default.nix b/pkgs/applications/networking/irc/kvirc/default.nix index eb443666764fd7..c68b84fac1cb0e 100644 --- a/pkgs/applications/networking/irc/kvirc/default.nix +++ b/pkgs/applications/networking/irc/kvirc/default.nix @@ -1,6 +1,14 @@ -{ lib, mkDerivation, fetchFromGitHub -, qtbase, qtmultimedia, qtsvg, qtx11extras -, pkg-config, cmake, gettext +{ + lib, + mkDerivation, + fetchFromGitHub, + qtbase, + qtmultimedia, + qtsvg, + qtx11extras, + pkg-config, + cmake, + gettext, }: mkDerivation rec { @@ -15,11 +23,16 @@ mkDerivation rec { }; buildInputs = [ - qtbase qtmultimedia qtsvg qtx11extras + qtbase + qtmultimedia + qtsvg + qtx11extras ]; nativeBuildInputs = [ - pkg-config cmake gettext + pkg-config + cmake + gettext ]; meta = with lib; { diff --git a/pkgs/applications/networking/irc/quassel/default.nix b/pkgs/applications/networking/irc/quassel/default.nix index 1324ec21a0ae64..0807b51f6fca99 100644 --- a/pkgs/applications/networking/irc/quassel/default.nix +++ b/pkgs/applications/networking/irc/quassel/default.nix @@ -1,27 +1,40 @@ -{ monolithic ? true # build monolithic Quassel -, enableDaemon ? false # build Quassel daemon -, client ? false # build Quassel client -, tag ? "-kf5" # tag added to the package name -, static ? false # link statically +{ + monolithic ? true, # build monolithic Quassel + enableDaemon ? false, # build Quassel daemon + client ? false, # build Quassel client + tag ? "-kf5", # tag added to the package name + static ? false, # link statically -, lib, stdenv, fetchFromGitHub, cmake, makeWrapper, dconf -, mkDerivation, qtbase, boost, zlib, qtscript -, phonon, libdbusmenu, qca-qt5, openldap + lib, + stdenv, + fetchFromGitHub, + cmake, + makeWrapper, + dconf, + mkDerivation, + qtbase, + boost, + zlib, + qtscript, + phonon, + libdbusmenu, + qca-qt5, + openldap, -, withKDE ? true # enable KDE integration -, extra-cmake-modules -, kconfigwidgets -, kcoreaddons -, knotifications -, knotifyconfig -, ktextwidgets -, kwidgetsaddons -, kxmlgui + withKDE ? true, # enable KDE integration + extra-cmake-modules, + kconfigwidgets, + kcoreaddons, + knotifications, + knotifyconfig, + ktextwidgets, + kwidgetsaddons, + kxmlgui, }: let - buildClient = monolithic || client; - buildCore = monolithic || enableDaemon; + buildClient = monolithic || client; + buildCore = monolithic || enableDaemon; in assert monolithic -> !client && !enableDaemon; @@ -29,9 +42,10 @@ assert client || enableDaemon -> !monolithic; assert !buildClient -> !withKDE; # KDE is used by the client only let - edf = flag: feature: [("-D" + feature + (if flag then "=ON" else "=OFF"))]; + edf = flag: feature: [ ("-D" + feature + (if flag then "=ON" else "=OFF")) ]; -in (if !buildClient then stdenv.mkDerivation else mkDerivation) rec { +in +(if !buildClient then stdenv.mkDerivation else mkDerivation) rec { pname = "quassel${tag}"; version = "0.14.0"; @@ -45,20 +59,41 @@ in (if !buildClient then stdenv.mkDerivation else mkDerivation) rec { # Prevent ``undefined reference to `qt_version_tag''' in SSL check env.NIX_CFLAGS_COMPILE = "-DQT_NO_VERSION_TAGGING=1"; - nativeBuildInputs = [ cmake makeWrapper ]; - buildInputs = [ qtbase boost zlib ] - ++ lib.optionals buildCore [qtscript qca-qt5 openldap] - ++ lib.optionals buildClient [libdbusmenu phonon] + nativeBuildInputs = [ + cmake + makeWrapper + ]; + buildInputs = + [ + qtbase + boost + zlib + ] + ++ lib.optionals buildCore [ + qtscript + qca-qt5 + openldap + ] + ++ lib.optionals buildClient [ + libdbusmenu + phonon + ] ++ lib.optionals (buildClient && withKDE) [ - extra-cmake-modules kconfigwidgets kcoreaddons - knotifications knotifyconfig ktextwidgets kwidgetsaddons + extra-cmake-modules + kconfigwidgets + kcoreaddons + knotifications + knotifyconfig + ktextwidgets + kwidgetsaddons kxmlgui ]; - cmakeFlags = [ - "-DEMBED_DATA=OFF" - "-DUSE_QT5=ON" - ] + cmakeFlags = + [ + "-DEMBED_DATA=OFF" + "-DUSE_QT5=ON" + ] ++ edf static "STATIC" ++ edf monolithic "WANT_MONO" ++ edf enableDaemon "WANT_CORE" @@ -71,8 +106,8 @@ in (if !buildClient then stdenv.mkDerivation else mkDerivation) rec { postFixup = lib.optionalString enableDaemon '' wrapProgram "$out/bin/quasselcore" --suffix PATH : "${qtbase.bin}/bin" - '' + - lib.optionalString buildClient '' + '' + + lib.optionalString buildClient '' wrapQtApp "$out/bin/quassel${lib.optionalString client "client"}" \ --prefix GIO_EXTRA_MODULES : "${dconf}/lib/gio/modules" ''; diff --git a/pkgs/applications/networking/irc/tiny/default.nix b/pkgs/applications/networking/irc/tiny/default.nix index fa8f3edf5ad6e1..6a875fcceedd5f 100644 --- a/pkgs/applications/networking/irc/tiny/default.nix +++ b/pkgs/applications/networking/irc/tiny/default.nix @@ -1,13 +1,16 @@ -{ stdenv -, lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, Foundation -, dbusSupport ? stdenv.hostPlatform.isLinux, dbus -# rustls will be used for TLS if useOpenSSL=false -, useOpenSSL ? stdenv.hostPlatform.isLinux, openssl -, notificationSupport ? stdenv.hostPlatform.isLinux +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + Foundation, + dbusSupport ? stdenv.hostPlatform.isLinux, + dbus, + # rustls will be used for TLS if useOpenSSL=false + useOpenSSL ? stdenv.hostPlatform.isLinux, + openssl, + notificationSupport ? stdenv.hostPlatform.isLinux, }: rustPlatform.buildRustPackage rec { @@ -24,9 +27,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-AhQCfLCoJU7o8s+XL3hDOPmZi9QjOxXSA9uglA1KSuY="; nativeBuildInputs = lib.optional stdenv.hostPlatform.isLinux pkg-config; - buildInputs = lib.optionals dbusSupport [ dbus ] - ++ lib.optionals useOpenSSL [ openssl ] - ++ lib.optional stdenv.hostPlatform.isDarwin Foundation; + buildInputs = + lib.optionals dbusSupport [ dbus ] + ++ lib.optionals useOpenSSL [ openssl ] + ++ lib.optional stdenv.hostPlatform.isDarwin Foundation; buildFeatures = lib.optional notificationSupport "desktop-notifications"; @@ -35,7 +39,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/osa1/tiny"; changelog = "https://github.com/osa1/tiny/blob/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ Br1ght0ne vyp ]; + maintainers = with maintainers; [ + Br1ght0ne + vyp + ]; mainProgram = "tiny"; }; } diff --git a/pkgs/applications/networking/irc/weechat/default.nix b/pkgs/applications/networking/irc/weechat/default.nix index 800d5e41bb3f8f..d647126750dccf 100644 --- a/pkgs/applications/networking/irc/weechat/default.nix +++ b/pkgs/applications/networking/irc/weechat/default.nix @@ -1,17 +1,43 @@ -{ stdenv, fetchurl, lib -, ncurses, openssl, aspell, cjson, gnutls, gettext -, zlib, curl, pkg-config, libgcrypt -, cmake, libobjc, libresolv, libiconv -, asciidoctor # manpages -, enableTests ? !stdenv.hostPlatform.isDarwin, cpputest -, guileSupport ? true, guile -, luaSupport ? true, lua5 -, perlSupport ? true, perl -, pythonSupport ? true, python3Packages -, rubySupport ? true, ruby -, tclSupport ? true, tcl -, phpSupport ? !stdenv.hostPlatform.isDarwin, php, systemd, libxml2, pcre2, libargon2 -, extraBuildInputs ? [] +{ + stdenv, + fetchurl, + lib, + ncurses, + openssl, + aspell, + cjson, + gnutls, + gettext, + zlib, + curl, + pkg-config, + libgcrypt, + cmake, + libobjc, + libresolv, + libiconv, + asciidoctor, # manpages + enableTests ? !stdenv.hostPlatform.isDarwin, + cpputest, + guileSupport ? true, + guile, + luaSupport ? true, + lua5, + perlSupport ? true, + perl, + pythonSupport ? true, + python3Packages, + rubySupport ? true, + ruby, + tclSupport ? true, + tcl, + phpSupport ? !stdenv.hostPlatform.isDarwin, + php, + systemd, + libxml2, + pcre2, + libargon2, + extraBuildInputs ? [ ], }: let @@ -21,82 +47,142 @@ let apxs2Support = false; }; plugins = [ - { name = "perl"; enabled = perlSupport; cmakeFlag = "ENABLE_PERL"; buildInputs = [ perl ]; } - { name = "tcl"; enabled = tclSupport; cmakeFlag = "ENABLE_TCL"; buildInputs = [ tcl ]; } - { name = "ruby"; enabled = rubySupport; cmakeFlag = "ENABLE_RUBY"; buildInputs = [ ruby ]; } - { name = "guile"; enabled = guileSupport; cmakeFlag = "ENABLE_GUILE"; buildInputs = [ guile ]; } - { name = "lua"; enabled = luaSupport; cmakeFlag = "ENABLE_LUA"; buildInputs = [ lua5 ]; } - { name = "python"; enabled = pythonSupport; cmakeFlag = "ENABLE_PYTHON3"; buildInputs = [ python ]; } - { name = "php"; enabled = phpSupport; cmakeFlag = "ENABLE_PHP"; buildInputs = [ - php-embed.unwrapped.dev libxml2 pcre2 libargon2 - ] ++ lib.optional stdenv.hostPlatform.isLinux systemd; } + { + name = "perl"; + enabled = perlSupport; + cmakeFlag = "ENABLE_PERL"; + buildInputs = [ perl ]; + } + { + name = "tcl"; + enabled = tclSupport; + cmakeFlag = "ENABLE_TCL"; + buildInputs = [ tcl ]; + } + { + name = "ruby"; + enabled = rubySupport; + cmakeFlag = "ENABLE_RUBY"; + buildInputs = [ ruby ]; + } + { + name = "guile"; + enabled = guileSupport; + cmakeFlag = "ENABLE_GUILE"; + buildInputs = [ guile ]; + } + { + name = "lua"; + enabled = luaSupport; + cmakeFlag = "ENABLE_LUA"; + buildInputs = [ lua5 ]; + } + { + name = "python"; + enabled = pythonSupport; + cmakeFlag = "ENABLE_PYTHON3"; + buildInputs = [ python ]; + } + { + name = "php"; + enabled = phpSupport; + cmakeFlag = "ENABLE_PHP"; + buildInputs = [ + php-embed.unwrapped.dev + libxml2 + pcre2 + libargon2 + ] ++ lib.optional stdenv.hostPlatform.isLinux systemd; + } ]; enabledPlugins = builtins.filter (p: p.enabled) plugins; - in - assert lib.all (p: p.enabled -> ! (builtins.elem null p.buildInputs)) plugins; - stdenv.mkDerivation rec { - version = "4.4.4"; - pname = "weechat"; +in +assert lib.all (p: p.enabled -> !(builtins.elem null p.buildInputs)) plugins; +stdenv.mkDerivation rec { + version = "4.4.4"; + pname = "weechat"; - hardeningEnable = [ "pie" ]; + hardeningEnable = [ "pie" ]; - src = fetchurl { - url = "https://weechat.org/files/src/weechat-${version}.tar.xz"; - hash = "sha256-qPS7dow9asPqHrTm3Hp7su4ZtzSnLMWOBjR22ujz0Hc="; - }; + src = fetchurl { + url = "https://weechat.org/files/src/weechat-${version}.tar.xz"; + hash = "sha256-qPS7dow9asPqHrTm3Hp7su4ZtzSnLMWOBjR22ujz0Hc="; + }; - # Why is this needed? https://github.com/weechat/weechat/issues/2031 - patches = lib.optional gettext.gettextNeedsLdflags ./gettext-intl.patch; + # Why is this needed? https://github.com/weechat/weechat/issues/2031 + patches = lib.optional gettext.gettextNeedsLdflags ./gettext-intl.patch; - outputs = [ "out" "man" ] ++ map (p: p.name) enabledPlugins; + outputs = [ + "out" + "man" + ] ++ map (p: p.name) enabledPlugins; - cmakeFlags = [ - "-DENABLE_MAN=ON" - "-DENABLE_DOC=ON" - "-DENABLE_DOC_INCOMPLETE=ON" - "-DENABLE_TESTS=${if enableTests then "ON" else "OFF"}" - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin ["-DICONV_LIBRARY=${libiconv}/lib/libiconv.dylib"] - ++ map (p: "-D${p.cmakeFlag}=" + (if p.enabled then "ON" else "OFF")) plugins - ; + cmakeFlags = + [ + "-DENABLE_MAN=ON" + "-DENABLE_DOC=ON" + "-DENABLE_DOC_INCOMPLETE=ON" + "-DENABLE_TESTS=${if enableTests then "ON" else "OFF"}" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ "-DICONV_LIBRARY=${libiconv}/lib/libiconv.dylib" ] + ++ map (p: "-D${p.cmakeFlag}=" + (if p.enabled then "ON" else "OFF")) plugins; - nativeBuildInputs = [ cmake pkg-config asciidoctor ] ++ lib.optional enableTests cpputest; - buildInputs = [ ncurses openssl aspell cjson gnutls gettext zlib curl libgcrypt ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libobjc libresolv ] - ++ lib.concatMap (p: p.buildInputs) enabledPlugins - ++ extraBuildInputs; + nativeBuildInputs = [ + cmake + pkg-config + asciidoctor + ] ++ lib.optional enableTests cpputest; + buildInputs = + [ + ncurses + openssl + aspell + cjson + gnutls + gettext + zlib + curl + libgcrypt + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + libresolv + ] + ++ lib.concatMap (p: p.buildInputs) enabledPlugins + ++ extraBuildInputs; - env.NIX_CFLAGS_COMPILE = "-I${python}/include/${python.libPrefix}" - # Fix '_res_9_init: undefined symbol' error - + (lib.optionalString stdenv.hostPlatform.isDarwin "-DBIND_8_COMPAT=1 -lresolv"); + env.NIX_CFLAGS_COMPILE = + "-I${python}/include/${python.libPrefix}" + # Fix '_res_9_init: undefined symbol' error + + (lib.optionalString stdenv.hostPlatform.isDarwin "-DBIND_8_COMPAT=1 -lresolv"); - postInstall = '' - for p in ${lib.concatMapStringsSep " " (p: p.name) enabledPlugins}; do - from=$out/lib/weechat/plugins/$p.so - to=''${!p}/lib/weechat/plugins/$p.so - mkdir -p $(dirname $to) - mv $from $to - done - ''; + postInstall = '' + for p in ${lib.concatMapStringsSep " " (p: p.name) enabledPlugins}; do + from=$out/lib/weechat/plugins/$p.so + to=''${!p}/lib/weechat/plugins/$p.so + mkdir -p $(dirname $to) + mv $from $to + done + ''; - doInstallCheck = true; - installCheckPhase = '' - $out/bin/weechat --version - ''; + doInstallCheck = true; + installCheckPhase = '' + $out/bin/weechat --version + ''; - meta = { - homepage = "https://weechat.org/"; - changelog = "https://weechat.org/files/doc/weechat/ChangeLog-${version}.html"; - description = "Fast, light and extensible chat client"; - longDescription = '' - You can find more documentation as to how to customize this package - (e.g. adding python modules for scripts that would require them, etc.) - on https://nixos.org/nixpkgs/manual/#sec-weechat . - ''; - license = lib.licenses.gpl3; - maintainers = with lib.maintainers; [ ncfavier ]; - mainProgram = "weechat"; - platforms = lib.platforms.unix; - }; - } + meta = { + homepage = "https://weechat.org/"; + changelog = "https://weechat.org/files/doc/weechat/ChangeLog-${version}.html"; + description = "Fast, light and extensible chat client"; + longDescription = '' + You can find more documentation as to how to customize this package + (e.g. adding python modules for scripts that would require them, etc.) + on https://nixos.org/nixpkgs/manual/#sec-weechat . + ''; + license = lib.licenses.gpl3; + maintainers = with lib.maintainers; [ ncfavier ]; + mainProgram = "weechat"; + platforms = lib.platforms.unix; + }; +} diff --git a/pkgs/applications/networking/irc/weechat/scripts/autosort/default.nix b/pkgs/applications/networking/irc/weechat/scripts/autosort/default.nix index 6cbcc117af040c..5758822dbdae5c 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/autosort/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/autosort/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, weechat }: +{ + lib, + stdenv, + fetchurl, + weechat, +}: stdenv.mkDerivation { pname = "weechat-autosort"; diff --git a/pkgs/applications/networking/irc/weechat/scripts/buffer_autoset/default.nix b/pkgs/applications/networking/irc/weechat/scripts/buffer_autoset/default.nix index 9ef49296299247..7def5ecf90af73 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/buffer_autoset/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/buffer_autoset/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, weechat }: +{ + lib, + stdenv, + fetchurl, + weechat, +}: stdenv.mkDerivation { pname = "buffer_autoset"; diff --git a/pkgs/applications/networking/irc/weechat/scripts/colorize_nicks/default.nix b/pkgs/applications/networking/irc/weechat/scripts/colorize_nicks/default.nix index 0b6d355797f307..7cdb408c2f6747 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/colorize_nicks/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/colorize_nicks/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchurl, weechat }: +{ + stdenv, + lib, + fetchurl, + weechat, +}: stdenv.mkDerivation { pname = "weechat-colorize_nicks"; diff --git a/pkgs/applications/networking/irc/weechat/scripts/default.nix b/pkgs/applications/networking/irc/weechat/scripts/default.nix index 1825ee3f5d7aaf..0d3805b366dc19 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/default.nix @@ -1,4 +1,9 @@ -{ callPackage, luaPackages, perlPackages, python3Packages }: +{ + callPackage, + luaPackages, + perlPackages, + python3Packages, +}: { autosort = callPackage ./autosort { }; diff --git a/pkgs/applications/networking/irc/weechat/scripts/edit/default.nix b/pkgs/applications/networking/irc/weechat/scripts/edit/default.nix index b510c17ac1e9cd..b89971bc06865c 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/edit/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/edit/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, weechat }: +{ + lib, + stdenv, + fetchFromGitHub, + weechat, +}: stdenv.mkDerivation rec { pname = "edit-weechat"; diff --git a/pkgs/applications/networking/irc/weechat/scripts/highmon/default.nix b/pkgs/applications/networking/irc/weechat/scripts/highmon/default.nix index d221a0cf972c4f..5238eb27b17a95 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/highmon/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/highmon/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, weechat }: +{ + lib, + stdenv, + fetchurl, + weechat, +}: stdenv.mkDerivation { pname = "highmon"; diff --git a/pkgs/applications/networking/irc/weechat/scripts/multiline/default.nix b/pkgs/applications/networking/irc/weechat/scripts/multiline/default.nix index f61b4391e18dd9..a54078a15299cb 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/multiline/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/multiline/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, substituteAll, PodParser }: +{ + stdenv, + lib, + fetchurl, + substituteAll, + PodParser, +}: stdenv.mkDerivation { pname = "multiline"; diff --git a/pkgs/applications/networking/irc/weechat/scripts/url_hint/default.nix b/pkgs/applications/networking/irc/weechat/scripts/url_hint/default.nix index 38df127d14cf00..b72c4c09633139 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/url_hint/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/url_hint/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, weechat }: +{ + lib, + stdenv, + fetchurl, + weechat, +}: stdenv.mkDerivation { pname = "url_hint"; diff --git a/pkgs/applications/networking/irc/weechat/scripts/wee-slack/default.nix b/pkgs/applications/networking/irc/weechat/scripts/wee-slack/default.nix index 88a36560114600..a21001ab84f2e0 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/wee-slack/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/wee-slack/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchpatch, substituteAll, buildEnv, fetchFromGitHub, python3Packages }: +{ + lib, + stdenv, + fetchpatch, + substituteAll, + buildEnv, + fetchFromGitHub, + python3Packages, +}: stdenv.mkDerivation rec { pname = "wee-slack"; @@ -14,13 +22,15 @@ stdenv.mkDerivation rec { patches = [ (substituteAll { src = ./libpath.patch; - env = "${buildEnv { - name = "wee-slack-env"; - paths = with python3Packages; [ - websocket-client - six - ]; - }}/${python3Packages.python.sitePackages}"; + env = "${ + buildEnv { + name = "wee-slack-env"; + paths = with python3Packages; [ + websocket-client + six + ]; + } + }/${python3Packages.python.sitePackages}"; }) ./load_weemoji_path.patch ]; diff --git a/pkgs/applications/networking/irc/weechat/scripts/weechat-autosort/default.nix b/pkgs/applications/networking/irc/weechat/scripts/weechat-autosort/default.nix index 010470c6fbaab6..c26792dbc0a2fd 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/weechat-autosort/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/weechat-autosort/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "weechat-autosort"; diff --git a/pkgs/applications/networking/irc/weechat/scripts/weechat-go/default.nix b/pkgs/applications/networking/irc/weechat/scripts/weechat-go/default.nix index 623b2570b475a3..e4bbde39155856 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/weechat-go/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/weechat-go/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, weechat }: +{ + lib, + stdenv, + fetchurl, + weechat, +}: stdenv.mkDerivation { pname = "weechat-go"; diff --git a/pkgs/applications/networking/irc/weechat/scripts/weechat-grep/default.nix b/pkgs/applications/networking/irc/weechat/scripts/weechat-grep/default.nix index efc575bd3e29ce..de1b34576a0b1d 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/weechat-grep/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/weechat-grep/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "weechat-grep"; diff --git a/pkgs/applications/networking/irc/weechat/scripts/weechat-matrix-bridge/default.nix b/pkgs/applications/networking/irc/weechat/scripts/weechat-matrix-bridge/default.nix index 22eb0849cc4a0f..3434f8d4047a55 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/weechat-matrix-bridge/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/weechat-matrix-bridge/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, curl, fetchFromGitHub, cjson, olm, luaffi }: +{ + lib, + stdenv, + curl, + fetchFromGitHub, + cjson, + olm, + luaffi, +}: stdenv.mkDerivation { pname = "weechat-matrix-bridge"; @@ -14,7 +22,12 @@ stdenv.mkDerivation { ./library-path.patch ]; - buildInputs = [ curl cjson olm luaffi ]; + buildInputs = [ + curl + cjson + olm + luaffi + ]; postPatch = '' substituteInPlace matrix.lua \ diff --git a/pkgs/applications/networking/irc/weechat/scripts/weechat-matrix/default.nix b/pkgs/applications/networking/irc/weechat/scripts/weechat-matrix/default.nix index 265065a445e3c2..0a9765549b6332 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/weechat-matrix/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/weechat-matrix/default.nix @@ -1,29 +1,33 @@ -{ buildPythonPackage -, lib -, python -, fetchFromGitHub -, fetchpatch -, pyopenssl -, webcolors -, future -, atomicwrites -, attrs -, logbook -, pygments -, matrix-nio -, aiohttp -, requests +{ + buildPythonPackage, + lib, + python, + fetchFromGitHub, + fetchpatch, + pyopenssl, + webcolors, + future, + atomicwrites, + attrs, + logbook, + pygments, + matrix-nio, + aiohttp, + requests, }: let - scriptPython = python.withPackages (ps: with ps; [ - aiohttp - requests - python-magic - ]); + scriptPython = python.withPackages ( + ps: with ps; [ + aiohttp + requests + python-magic + ] + ); version = "0.3.0"; -in buildPythonPackage { +in +buildPythonPackage { pname = "weechat-matrix"; inherit version; @@ -44,7 +48,7 @@ in buildPythonPackage { (fetchpatch { url = "https://github.com/poljar/weechat-matrix/commit/feae9fda26ea9de98da9cd6733980a203115537e.patch"; hash = "sha256-MAfxJ85dqz5PNwp/GJdHA2VvXVdWh+Ayx5g0oHiw9rs="; - includes = ["matrix/config.py"]; + includes = [ "matrix/config.py" ]; }) ]; diff --git a/pkgs/applications/networking/irc/weechat/scripts/weechat-notify-send/default.nix b/pkgs/applications/networking/irc/weechat/scripts/weechat-notify-send/default.nix index abd289d9903754..5aebaf7c82cf82 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/weechat-notify-send/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/weechat-notify-send/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libnotify }: +{ + lib, + stdenv, + fetchFromGitHub, + libnotify, +}: stdenv.mkDerivation rec { pname = "weechat-notify-send"; diff --git a/pkgs/applications/networking/irc/weechat/scripts/weechat-otr/default.nix b/pkgs/applications/networking/irc/weechat/scripts/weechat-otr/default.nix index fd5f376ad2636e..717cec1dc34135 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/weechat-otr/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/weechat-otr/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, substituteAll, buildEnv, fetchgit, fetchFromGitHub, python3Packages, gmp }: +{ + lib, + stdenv, + substituteAll, + buildEnv, + fetchgit, + fetchFromGitHub, + python3Packages, + gmp, +}: let # pure-python-otr (potr) requires an older version of pycrypto, which is @@ -36,7 +45,8 @@ let potr = python3Packages.potr.overridePythonAttrs (oldAttrs: { propagatedBuildInputs = [ pycrypto ]; }); -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "weechat-otr"; version = "1.9.2"; @@ -50,10 +60,15 @@ in stdenv.mkDerivation rec { patches = [ (substituteAll { src = ./libpath.patch; - env = "${buildEnv { - name = "weechat-otr-env"; - paths = [ potr pycrypto ]; - }}/${python3Packages.python.sitePackages}"; + env = "${ + buildEnv { + name = "weechat-otr-env"; + paths = [ + potr + pycrypto + ]; + } + }/${python3Packages.python.sitePackages}"; }) ]; diff --git a/pkgs/applications/networking/irc/weechat/scripts/zncplayback/default.nix b/pkgs/applications/networking/irc/weechat/scripts/zncplayback/default.nix index d15b130cae2804..71bd89d3ec152e 100644 --- a/pkgs/applications/networking/irc/weechat/scripts/zncplayback/default.nix +++ b/pkgs/applications/networking/irc/weechat/scripts/zncplayback/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "weechat-zncplayback"; diff --git a/pkgs/applications/networking/irc/weechat/wrapper.nix b/pkgs/applications/networking/irc/weechat/wrapper.nix index 353b7ffd6fda40..019b730608a527 100644 --- a/pkgs/applications/networking/irc/weechat/wrapper.nix +++ b/pkgs/applications/networking/irc/weechat/wrapper.nix @@ -1,97 +1,129 @@ -{ lib, runCommand, writeScriptBin, buildEnv -, python3Packages, perlPackages, runtimeShell +{ + lib, + runCommand, + writeScriptBin, + buildEnv, + python3Packages, + perlPackages, + runtimeShell, }: weechat: let - wrapper = { - installManPages ? true - , configure ? { availablePlugins, ... }: { - # Do not include PHP by default, because it bloats the closure, doesn't - # build on Darwin, and there are no official PHP scripts. - plugins = builtins.attrValues (builtins.removeAttrs availablePlugins [ "php" ]); - } - }: + wrapper = + { + installManPages ? true, + configure ? + { availablePlugins, ... }: + { + # Do not include PHP by default, because it bloats the closure, doesn't + # build on Darwin, and there are no official PHP scripts. + plugins = builtins.attrValues (builtins.removeAttrs availablePlugins [ "php" ]); + }, + }: - let - perlInterpreter = perlPackages.perl; - availablePlugins = let - simplePlugin = name: {pluginFile = "${weechat.${name}}/lib/weechat/plugins/${name}.so";}; - in rec { - python = (simplePlugin "python") // { - extraEnv = '' - export PATH="${python3Packages.python}/bin:$PATH" - ''; - withPackages = pkgsFun: (python // { + let + perlInterpreter = perlPackages.perl; + availablePlugins = + let + simplePlugin = name: { pluginFile = "${weechat.${name}}/lib/weechat/plugins/${name}.so"; }; + in + rec { + python = (simplePlugin "python") // { extraEnv = '' - ${python.extraEnv} - export PYTHONHOME="${python3Packages.python.withPackages pkgsFun}" + export PATH="${python3Packages.python}/bin:$PATH" ''; - }); - }; - perl = (simplePlugin "perl") // { - extraEnv = '' - export PATH="${perlInterpreter}/bin:$PATH" - ''; - withPackages = pkgsFun: (perl // { + withPackages = + pkgsFun: + ( + python + // { + extraEnv = '' + ${python.extraEnv} + export PYTHONHOME="${python3Packages.python.withPackages pkgsFun}" + ''; + } + ); + }; + perl = (simplePlugin "perl") // { extraEnv = '' - ${perl.extraEnv} - export PERL5LIB=${perlPackages.makeFullPerlPath (pkgsFun perlPackages)} + export PATH="${perlInterpreter}/bin:$PATH" ''; - }); + withPackages = + pkgsFun: + ( + perl + // { + extraEnv = '' + ${perl.extraEnv} + export PERL5LIB=${perlPackages.makeFullPerlPath (pkgsFun perlPackages)} + ''; + } + ); + }; + tcl = simplePlugin "tcl"; + ruby = simplePlugin "ruby"; + guile = simplePlugin "guile"; + lua = simplePlugin "lua"; + php = simplePlugin "php"; }; - tcl = simplePlugin "tcl"; - ruby = simplePlugin "ruby"; - guile = simplePlugin "guile"; - lua = simplePlugin "lua"; - php = simplePlugin "php"; - }; - config = configure { inherit availablePlugins; }; + config = configure { inherit availablePlugins; }; - plugins = config.plugins or (builtins.attrValues availablePlugins); + plugins = config.plugins or (builtins.attrValues availablePlugins); - pluginsDir = runCommand "weechat-plugins" {} '' - mkdir -p $out/plugins - for plugin in ${lib.concatMapStringsSep " " (p: p.pluginFile) plugins} ; do - ln -s $plugin $out/plugins - done - ''; + pluginsDir = runCommand "weechat-plugins" { } '' + mkdir -p $out/plugins + for plugin in ${lib.concatMapStringsSep " " (p: p.pluginFile) plugins} ; do + ln -s $plugin $out/plugins + done + ''; - init = let - init = builtins.replaceStrings [ "\n" ] [ ";" ] (config.init or ""); + init = + let + init = builtins.replaceStrings [ "\n" ] [ ";" ] (config.init or ""); - mkScript = drv: lib.forEach drv.scripts (script: "/script load ${drv}/share/${script}"); + mkScript = drv: lib.forEach drv.scripts (script: "/script load ${drv}/share/${script}"); - scripts = builtins.concatStringsSep ";" (lib.foldl (scripts: drv: scripts ++ mkScript drv) - [ ] (config.scripts or [])); - in "${scripts};${init}"; + scripts = builtins.concatStringsSep ";" ( + lib.foldl (scripts: drv: scripts ++ mkScript drv) [ ] (config.scripts or [ ]) + ); + in + "${scripts};${init}"; - mkWeechat = bin: (writeScriptBin bin '' - #!${runtimeShell} - export WEECHAT_EXTRA_LIBDIR=${pluginsDir} - ${lib.concatMapStringsSep "\n" (p: lib.optionalString (p ? extraEnv) p.extraEnv) plugins} - exec ${weechat}/bin/${bin} "$@" --run-command ${lib.escapeShellArg init} - '') // { - inherit (weechat) name man; - unwrapped = weechat; - outputs = [ "out" "man" ]; + mkWeechat = + bin: + (writeScriptBin bin '' + #!${runtimeShell} + export WEECHAT_EXTRA_LIBDIR=${pluginsDir} + ${lib.concatMapStringsSep "\n" (p: lib.optionalString (p ? extraEnv) p.extraEnv) plugins} + exec ${weechat}/bin/${bin} "$@" --run-command ${lib.escapeShellArg init} + '') + // { + inherit (weechat) name man; + unwrapped = weechat; + outputs = [ + "out" + "man" + ]; + }; + in + buildEnv { + name = "weechat-bin-env-${weechat.version}"; + extraOutputsToInstall = lib.optionals installManPages [ "man" ]; + paths = [ + (mkWeechat "weechat") + (mkWeechat "weechat-headless") + (runCommand "weechat-out-except-bin" { } '' + mkdir $out + ln -sf ${weechat}/include $out/include + ln -sf ${weechat}/lib $out/lib + ln -sf ${weechat}/share $out/share + '') + ]; + meta = builtins.removeAttrs weechat.meta [ "outputsToInstall" ]; }; - in buildEnv { - name = "weechat-bin-env-${weechat.version}"; - extraOutputsToInstall = lib.optionals installManPages [ "man" ]; - paths = [ - (mkWeechat "weechat") - (mkWeechat "weechat-headless") - (runCommand "weechat-out-except-bin" { } '' - mkdir $out - ln -sf ${weechat}/include $out/include - ln -sf ${weechat}/lib $out/lib - ln -sf ${weechat}/share $out/share - '') - ]; - meta = builtins.removeAttrs weechat.meta [ "outputsToInstall" ]; - }; -in lib.makeOverridable wrapper +in +lib.makeOverridable wrapper diff --git a/pkgs/applications/networking/irc/wraith/default.nix b/pkgs/applications/networking/irc/wraith/default.nix index c046a0c2d7f997..1a6f26aa2699d0 100644 --- a/pkgs/applications/networking/irc/wraith/default.nix +++ b/pkgs/applications/networking/irc/wraith/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, openssl }: +{ + lib, + stdenv, + fetchurl, + openssl, +}: stdenv.mkDerivation rec { pname = "wraith"; @@ -9,7 +14,10 @@ stdenv.mkDerivation rec { }; hardeningDisable = [ "format" ]; buildInputs = [ openssl ]; - patches = [ ./configure.patch ./dlopen.patch ]; + patches = [ + ./configure.patch + ./dlopen.patch + ]; postPatch = '' substituteInPlace configure --subst-var-by openssl.dev ${openssl.dev} \ --subst-var-by openssl-lib ${lib.getLib openssl} diff --git a/pkgs/applications/networking/ktailctl/default.nix b/pkgs/applications/networking/ktailctl/default.nix index 2c028fda4285e7..e40525734b9a75 100644 --- a/pkgs/applications/networking/ktailctl/default.nix +++ b/pkgs/applications/networking/ktailctl/default.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildGo123Module -, cmake -, extra-cmake-modules -, git -, go_1_23 -, wrapQtAppsHook -, qtbase -, qtdeclarative -, qtsvg -, qtwayland -, kconfig -, kcoreaddons -, kguiaddons -, ki18n -, kirigami -, kirigami-addons -, knotifications -, nlohmann_json -, qqc2-desktop-style +{ + lib, + stdenv, + fetchFromGitHub, + buildGo123Module, + cmake, + extra-cmake-modules, + git, + go_1_23, + wrapQtAppsHook, + qtbase, + qtdeclarative, + qtsvg, + qtwayland, + kconfig, + kcoreaddons, + kguiaddons, + ki18n, + kirigami, + kirigami-addons, + knotifications, + nlohmann_json, + qqc2-desktop-style, }: let @@ -32,12 +33,13 @@ let hash = "sha256-nxYgpIUNgWhWnrd5rqSH2r1QKhWPJwxlIQl6F9PmjpU="; }; - goDeps = (buildGo123Module { - pname = "ktailctl-go-wrapper"; - inherit src version; - modRoot = "src/wrapper"; - vendorHash = "sha256-UjgHfR+MJ8ROqOPIM0ZkqgFGVEkw8gKYlVQ6oxoIcgE="; - }).goModules; + goDeps = + (buildGo123Module { + pname = "ktailctl-go-wrapper"; + inherit src version; + modRoot = "src/wrapper"; + vendorHash = "sha256-UjgHfR+MJ8ROqOPIM0ZkqgFGVEkw8gKYlVQ6oxoIcgE="; + }).goModules; in stdenv.mkDerivation { pname = "ktailctl"; diff --git a/pkgs/applications/networking/libcoap/default.nix b/pkgs/applications/networking/libcoap/default.nix index d705536ea7dfe9..bef56def692c26 100644 --- a/pkgs/applications/networking/libcoap/default.nix +++ b/pkgs/applications/networking/libcoap/default.nix @@ -1,6 +1,17 @@ -{ fetchFromGitHub, automake, autoconf, which, pkg-config, libtool, lib, stdenv, gnutls, asciidoc, doxygen -, withTLS ? true -, withDocs ? true +{ + fetchFromGitHub, + automake, + autoconf, + which, + pkg-config, + libtool, + lib, + stdenv, + gnutls, + asciidoc, + doxygen, + withTLS ? true, + withDocs ? true, }: stdenv.mkDerivation rec { pname = "libcoap"; @@ -12,15 +23,22 @@ stdenv.mkDerivation rec { fetchSubmodules = true; hash = "sha256-QNrsR6VarZ2favvTZ9pMhVafwF2fOjYLKcyNqZyUl6s="; }; - nativeBuildInputs = [ - automake - autoconf - which - libtool - pkg-config - ] ++ lib.optional withTLS gnutls ++ lib.optionals withDocs [ doxygen asciidoc ] ; + nativeBuildInputs = + [ + automake + autoconf + which + libtool + pkg-config + ] + ++ lib.optional withTLS gnutls + ++ lib.optionals withDocs [ + doxygen + asciidoc + ]; preConfigure = "./autogen.sh"; - configureFlags = [ "--disable-shared" ] + configureFlags = + [ "--disable-shared" ] ++ lib.optional (!withDocs) "--disable-documentation" ++ lib.optional withTLS "--enable-dtls"; meta = with lib; { diff --git a/pkgs/applications/networking/linssid/default.nix b/pkgs/applications/networking/linssid/default.nix index 000354d1e5c9a2..132b68764952ee 100644 --- a/pkgs/applications/networking/linssid/default.nix +++ b/pkgs/applications/networking/linssid/default.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, qtbase, qtsvg, qmake, pkg-config, boost, wirelesstools, iw, qwt6_1, wrapQtAppsHook }: +{ + lib, + stdenv, + fetchurl, + qtbase, + qtsvg, + qmake, + pkg-config, + boost, + wirelesstools, + iw, + qwt6_1, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "linssid"; @@ -9,8 +22,17 @@ stdenv.mkDerivation rec { sha256 = "13d35rlcjncd8lx3khkgn9x8is2xjd5fp6ns5xsn3w6l4xj9b4gl"; }; - nativeBuildInputs = [ pkg-config qmake wrapQtAppsHook ]; - buildInputs = [ qtbase qtsvg boost qwt6_1 ]; + nativeBuildInputs = [ + pkg-config + qmake + wrapQtAppsHook + ]; + buildInputs = [ + qtbase + qtsvg + boost + qwt6_1 + ]; patches = [ ./0001-unbundled-qwt.patch ]; @@ -26,8 +48,14 @@ stdenv.mkDerivation rec { rm -fr qwt-lib ''; - qtWrapperArgs = - [ ''--prefix PATH : ${lib.makeBinPath [ wirelesstools iw ]}'' ]; + qtWrapperArgs = [ + ''--prefix PATH : ${ + lib.makeBinPath [ + wirelesstools + iw + ] + }'' + ]; meta = with lib; { description = "Graphical wireless scanning for Linux"; diff --git a/pkgs/applications/networking/mailreaders/astroid/default.nix b/pkgs/applications/networking/mailreaders/astroid/default.nix index 559c17bd7467b6..e0a09434a9d91c 100644 --- a/pkgs/applications/networking/mailreaders/astroid/default.nix +++ b/pkgs/applications/networking/mailreaders/astroid/default.nix @@ -1,12 +1,31 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, pkg-config, adwaita-icon-theme, gmime3, webkitgtk_4_0, ronn -, libsass, notmuch, boost, wrapGAppsHook3, glib-networking, protobuf -, gtkmm3, libpeas, gsettings-desktop-schemas, gobject-introspection, python3 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + adwaita-icon-theme, + gmime3, + webkitgtk_4_0, + ronn, + libsass, + notmuch, + boost, + wrapGAppsHook3, + glib-networking, + protobuf, + gtkmm3, + libpeas, + gsettings-desktop-schemas, + gobject-introspection, + python3, -# vim to be used, should support the GUI mode. -, vim + # vim to be used, should support the GUI mode. + vim, -# additional python3 packages to be available within plugins -, extraPythonPackages ? [] + # additional python3 packages to be available within plugins + extraPythonPackages ? [ ], }: stdenv.mkDerivation rec { @@ -23,22 +42,34 @@ stdenv.mkDerivation rec { patches = [ (fetchpatch { name = "symbolic-icons.patch"; - url = - "https://github.com/astroidmail/astroid/commit/7c2022f06a4146ad62e858bcaacdb4ee817851b9.patch"; + url = "https://github.com/astroidmail/astroid/commit/7c2022f06a4146ad62e858bcaacdb4ee817851b9.patch"; hash = "sha256-hZHOg1wUR8Kpd6017fWzhMmG+/WQxSOCnsiyIvUcpbU="; }) ]; nativeBuildInputs = [ - cmake ronn pkg-config wrapGAppsHook3 gobject-introspection - python3 python3.pkgs.wrapPython + cmake + ronn + pkg-config + wrapGAppsHook3 + gobject-introspection + python3 + python3.pkgs.wrapPython ]; buildInputs = [ - gtkmm3 gmime3 webkitgtk_4_0 libsass libpeas + gtkmm3 + gmime3 + webkitgtk_4_0 + libsass + libpeas python3 - notmuch boost gsettings-desktop-schemas adwaita-icon-theme - glib-networking protobuf + notmuch + boost + gsettings-desktop-schemas + adwaita-icon-theme + glib-networking + protobuf vim ]; @@ -59,7 +90,10 @@ stdenv.mkDerivation rec { homepage = "https://astroidmail.github.io/"; description = "GTK frontend to the notmuch mail system"; mainProgram = "astroid"; - maintainers = with maintainers; [ bdimcheff SuprDewd ]; + maintainers = with maintainers; [ + bdimcheff + SuprDewd + ]; license = licenses.gpl3Plus; platforms = platforms.linux; }; diff --git a/pkgs/applications/networking/mailreaders/evolution/evolution-ews/default.nix b/pkgs/applications/networking/mailreaders/evolution/evolution-ews/default.nix index 74d2d776643c2c..93a0eb591f9db6 100644 --- a/pkgs/applications/networking/mailreaders/evolution/evolution-ews/default.nix +++ b/pkgs/applications/networking/mailreaders/evolution/evolution-ews/default.nix @@ -1,23 +1,24 @@ -{ stdenv -, lib -, fetchurl -, gnome -, cmake -, gettext -, intltool -, pkg-config -, evolution-data-server -, evolution -, gtk3 -, libsoup_3 -, libical -, json-glib -, libmspack -, webkitgtk_4_1 -, substituteAll -, _experimental-update-script-combinators -, glib -, makeHardcodeGsettingsPatch +{ + stdenv, + lib, + fetchurl, + gnome, + cmake, + gettext, + intltool, + pkg-config, + evolution-data-server, + evolution, + gtk3, + libsoup_3, + libical, + json-glib, + libmspack, + webkitgtk_4_1, + substituteAll, + _experimental-update-script-combinators, + glib, + makeHardcodeGsettingsPatch, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/networking/mailreaders/evolution/evolution/default.nix b/pkgs/applications/networking/mailreaders/evolution/evolution/default.nix index b8d1c3740e443d..2d429f4c1c8b10 100644 --- a/pkgs/applications/networking/mailreaders/evolution/evolution/default.nix +++ b/pkgs/applications/networking/mailreaders/evolution/evolution/default.nix @@ -1,46 +1,47 @@ -{ lib -, stdenv -, cmake -, ninja -, intltool -, fetchurl -, libxml2 -, webkitgtk_4_1 -, highlight -, pkg-config -, gtk3 -, glib -, libnotify -, libpst -, gspell -, evolution-data-server -, libgweather -, glib-networking -, gsettings-desktop-schemas -, wrapGAppsHook3 -, itstool -, shared-mime-info -, libical -, db -, sqlite -, adwaita-icon-theme -, gnome -, gnome-desktop -, librsvg -, gdk-pixbuf -, libsecret -, nss -, nspr -, icu -, libcanberra-gtk3 -, geocode-glib_2 -, cmark -, bogofilter -, gst_all_1 -, procps -, p11-kit -, openldap -, spamassassin +{ + lib, + stdenv, + cmake, + ninja, + intltool, + fetchurl, + libxml2, + webkitgtk_4_1, + highlight, + pkg-config, + gtk3, + glib, + libnotify, + libpst, + gspell, + evolution-data-server, + libgweather, + glib-networking, + gsettings-desktop-schemas, + wrapGAppsHook3, + itstool, + shared-mime-info, + libical, + db, + sqlite, + adwaita-icon-theme, + gnome, + gnome-desktop, + librsvg, + gdk-pixbuf, + libsecret, + nss, + nspr, + icu, + libcanberra-gtk3, + geocode-glib_2, + cmark, + bogofilter, + gst_all_1, + procps, + p11-kit, + openldap, + spamassassin, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/networking/mailreaders/evolution/evolution/wrapper.nix b/pkgs/applications/networking/mailreaders/evolution/evolution/wrapper.nix index bae0bdb2fd4547..a1e3e525b4ceed 100644 --- a/pkgs/applications/networking/mailreaders/evolution/evolution/wrapper.nix +++ b/pkgs/applications/networking/mailreaders/evolution/evolution/wrapper.nix @@ -1,4 +1,10 @@ -{ lib, makeWrapper, symlinkJoin, evolution-data-server, plugins }: +{ + lib, + makeWrapper, + symlinkJoin, + evolution-data-server, + plugins, +}: symlinkJoin { name = "evolution-with-plugins"; diff --git a/pkgs/applications/networking/mailreaders/imapfilter.nix b/pkgs/applications/networking/mailreaders/imapfilter.nix index 3277dee46a9d51..93eede6853d6f8 100644 --- a/pkgs/applications/networking/mailreaders/imapfilter.nix +++ b/pkgs/applications/networking/mailreaders/imapfilter.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, openssl, lua, pcre2 }: +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + lua, + pcre2, +}: stdenv.mkDerivation (finalAttrs: { pname = "imapfilter"; @@ -15,7 +22,11 @@ stdenv.mkDerivation (finalAttrs: { "PREFIX=$(out)" ]; - buildInputs = [ openssl pcre2 lua ]; + buildInputs = [ + openssl + pcre2 + lua + ]; meta = { homepage = "https://github.com/lefcha/imapfilter"; diff --git a/pkgs/applications/networking/mailreaders/lumail/default.nix b/pkgs/applications/networking/mailreaders/lumail/default.nix index e35d37dfe2240b..6bdd5430251721 100644 --- a/pkgs/applications/networking/mailreaders/lumail/default.nix +++ b/pkgs/applications/networking/mailreaders/lumail/default.nix @@ -1,27 +1,43 @@ -{ lib, stdenv, fetchurl, pkg-config, lua, file, ncurses, gmime, pcre-cpp -, perl, perlPackages, makeWrapper -, debugBuild ? false -, alternativeGlobalConfigFilePath ? null +{ + lib, + stdenv, + fetchurl, + pkg-config, + lua, + file, + ncurses, + gmime, + pcre-cpp, + perl, + perlPackages, + makeWrapper, + debugBuild ? false, + alternativeGlobalConfigFilePath ? null, }: let - version = "3.1"; + version = "3.1"; binaryName = if debugBuild then "lumail2-debug" else "lumail2"; - alternativeConfig = builtins.toFile "lumail2.lua" - (builtins.readFile alternativeGlobalConfigFilePath); + alternativeConfig = builtins.toFile "lumail2.lua" ( + builtins.readFile alternativeGlobalConfigFilePath + ); - globalConfig = if alternativeGlobalConfigFilePath == null then '' - mkdir -p $out/etc/lumail2 - cp global.config.lua $out/etc/lumail2.lua - for n in ./lib/*.lua; do - cp "$n" $out/etc/lumail2/ - done - '' else '' - ln -s ${alternativeConfig} $out/etc/lumail2.lua - ''; + globalConfig = + if alternativeGlobalConfigFilePath == null then + '' + mkdir -p $out/etc/lumail2 + cp global.config.lua $out/etc/lumail2.lua + for n in ./lib/*.lua; do + cp "$n" $out/etc/lumail2/ + done + '' + else + '' + ln -s ${alternativeConfig} $out/etc/lumail2.lua + ''; - getPath = type : "${lua}/lib/?.${type};"; - luaPath = getPath "lua"; + getPath = type: "${lua}/lib/?.${type};"; + luaPath = getPath "lua"; luaCPath = getPath "so"; in stdenv.mkDerivation { @@ -35,10 +51,19 @@ stdenv.mkDerivation { enableParallelBuilding = true; - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; buildInputs = [ - lua file ncurses gmime pcre-cpp - perl perlPackages.JSON perlPackages.NetIMAPClient + lua + file + ncurses + gmime + pcre-cpp + perl + perlPackages.JSON + perlPackages.NetIMAPClient ]; preConfigure = '' @@ -54,16 +79,17 @@ stdenv.mkDerivation { buildFlags = lib.optional debugBuild "lumail2-debug"; - installPhase = '' - mkdir -p $out/bin || true - install -m755 ${binaryName} $out/bin/ - '' - + globalConfig - + '' - wrapProgram $out/bin/${binaryName} \ - --prefix LUA_PATH : "${luaPath}" \ - --prefix LUA_CPATH : "${luaCPath}" - ''; + installPhase = + '' + mkdir -p $out/bin || true + install -m755 ${binaryName} $out/bin/ + '' + + globalConfig + + '' + wrapProgram $out/bin/${binaryName} \ + --prefix LUA_PATH : "${luaPath}" \ + --prefix LUA_CPATH : "${luaCPath}" + ''; makeFlags = [ "LVER=lua" @@ -78,6 +104,6 @@ stdenv.mkDerivation { homepage = "https://lumail.org/"; license = licenses.gpl2; platforms = platforms.linux; - maintainers = with maintainers; [orivej]; + maintainers = with maintainers; [ orivej ]; }; } diff --git a/pkgs/applications/networking/mailreaders/mailnag/default.nix b/pkgs/applications/networking/mailreaders/mailnag/default.nix index 1976521b2f2202..25904e5b44b0fc 100644 --- a/pkgs/applications/networking/mailreaders/mailnag/default.nix +++ b/pkgs/applications/networking/mailreaders/mailnag/default.nix @@ -1,24 +1,25 @@ -{ lib -, fetchFromGitHub -, gettext -, xorg # for lndir -, gtk3 -, python3Packages -, gdk-pixbuf -, libnotify -, gst_all_1 -, libsecret -, wrapGAppsHook3 -, gsettings-desktop-schemas -, glib -, gobject-introspection -# Available plugins (can be overridden) -, availablePlugins -# Used in the withPlugins interface at passthru, can be overrided directly, or -# prefarably via e.g: `mailnag.withPlugins([mailnag.availablePlugins.goa])` -, mailnag -, userPlugins ? [ ] -, pluginsDeps ? [ ] +{ + lib, + fetchFromGitHub, + gettext, + xorg, # for lndir + gtk3, + python3Packages, + gdk-pixbuf, + libnotify, + gst_all_1, + libsecret, + wrapGAppsHook3, + gsettings-desktop-schemas, + glib, + gobject-introspection, + # Available plugins (can be overridden) + availablePlugins, + # Used in the withPlugins interface at passthru, can be overrided directly, or + # prefarably via e.g: `mailnag.withPlugins([mailnag.availablePlugins.goa])` + mailnag, + userPlugins ? [ ], + pluginsDeps ? [ ], }: python3Packages.buildPythonApplication rec { @@ -71,10 +72,10 @@ python3Packages.buildPythonApplication rec { pluginsDeps = lib.flatten (lib.catAttrs "buildInputs" plugs); self = mailnag; in - self.override { - userPlugins = plugs; - inherit pluginsDeps; - }; + self.override { + userPlugins = plugs; + inherit pluginsDeps; + }; }; # See https://nixos.org/nixpkgs/manual/#ssec-gnome-common-issues-double-wrapped diff --git a/pkgs/applications/networking/mailreaders/mailnag/goa-plugin.nix b/pkgs/applications/networking/mailreaders/mailnag/goa-plugin.nix index 8a5d4c74a40294..3b32debe0f14e8 100644 --- a/pkgs/applications/networking/mailreaders/mailnag/goa-plugin.nix +++ b/pkgs/applications/networking/mailreaders/mailnag/goa-plugin.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, python3Packages -, gobject-introspection -, gnome-online-accounts +{ + lib, + fetchFromGitHub, + python3Packages, + gobject-introspection, + gnome-online-accounts, }: python3Packages.buildPythonPackage rec { diff --git a/pkgs/applications/networking/mailreaders/neomutt/default.nix b/pkgs/applications/networking/mailreaders/neomutt/default.nix index a34b8f8f6ca71a..d4f160ff788a36 100644 --- a/pkgs/applications/networking/mailreaders/neomutt/default.nix +++ b/pkgs/applications/networking/mailreaders/neomutt/default.nix @@ -50,20 +50,23 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-c8G0CGg4jrwq+HVR4O0AtaJNzr7pDYsie1410tisLEY="; }; - buildInputs = [ - cyrus_sasl - gss - gpgme - libkrb5 - libidn2 - ncurses - notmuch - openssl - perl - lmdb - mailcap - sqlite - ] ++ lib.optional enableZstd zstd ++ lib.optional enableLua lua; + buildInputs = + [ + cyrus_sasl + gss + gpgme + libkrb5 + libidn2 + ncurses + notmuch + openssl + perl + lmdb + mailcap + sqlite + ] + ++ lib.optional enableZstd zstd + ++ lib.optional enableLua lua; nativeBuildInputs = [ docbook_xsl @@ -99,21 +102,24 @@ stdenv.mkDerivation (finalAttrs: { --replace /etc/mime.types ${mailcap}/etc/mime.types ''; - configureFlags = [ - "--enable-autocrypt" - "--gpgme" - "--gss" - "--lmdb" - "--notmuch" - "--ssl" - "--sasl" - "--with-homespool=mailbox" - "--with-mailpath=" - # To make it not reference .dev outputs. See: - # https://github.com/neomutt/neomutt/pull/2367 - "--disable-include-path-in-cflags" - "--zlib" - ] ++ lib.optional enableZstd "--zstd" ++ lib.optional enableLua "--lua"; + configureFlags = + [ + "--enable-autocrypt" + "--gpgme" + "--gss" + "--lmdb" + "--notmuch" + "--ssl" + "--sasl" + "--with-homespool=mailbox" + "--with-mailpath=" + # To make it not reference .dev outputs. See: + # https://github.com/neomutt/neomutt/pull/2367 + "--disable-include-path-in-cflags" + "--zlib" + ] + ++ lib.optional enableZstd "--zstd" + ++ lib.optional enableLua "--lua"; postInstall = '' diff --git a/pkgs/applications/networking/mailreaders/notmuch/default.nix b/pkgs/applications/networking/mailreaders/notmuch/default.nix index e3b6d3a2bdef50..90c0c98b400a72 100644 --- a/pkgs/applications/networking/mailreaders/notmuch/default.nix +++ b/pkgs/applications/networking/mailreaders/notmuch/default.nix @@ -1,18 +1,36 @@ -{ fetchurl, lib, stdenv, makeWrapper, buildEnv -, pkg-config, gnupg -, xapian, gmime3, sfsexp, talloc, zlib -, doxygen, perl, texinfo -, pythonPackages -, emacs -, ruby -, testers -, gitUpdater -, which, dtach, openssl, bash, gdb, man, git -, withEmacs ? true -, withRuby ? true -, withSfsexp ? true # also installs notmuch-git, which requires sexp-support -# TODO upstream: it takes too long ! 800 ms here -, withVim ? true +{ + fetchurl, + lib, + stdenv, + makeWrapper, + buildEnv, + pkg-config, + gnupg, + xapian, + gmime3, + sfsexp, + talloc, + zlib, + doxygen, + perl, + texinfo, + pythonPackages, + emacs, + ruby, + testers, + gitUpdater, + which, + dtach, + openssl, + bash, + gdb, + man, + git, + withEmacs ? true, + withRuby ? true, + withSfsexp ? true, # also installs notmuch-git, which requires sexp-support + # TODO upstream: it takes too long ! 800 ms here + withVim ? true, }: stdenv.mkDerivation (finalAttrs: { @@ -24,44 +42,55 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-mvRsyA2li0MByiuu/MJaQNES0DFVB+YywPPw8IMo0FQ="; }; - nativeBuildInputs = [ - pkg-config - doxygen # (optional) api docs - pythonPackages.sphinx # (optional) documentation -> doc/INSTALL - texinfo # (optional) documentation -> doc/INSTALL - pythonPackages.cffi - ] ++ lib.optional withEmacs emacs + nativeBuildInputs = + [ + pkg-config + doxygen # (optional) api docs + pythonPackages.sphinx # (optional) documentation -> doc/INSTALL + texinfo # (optional) documentation -> doc/INSTALL + pythonPackages.cffi + ] + ++ lib.optional withEmacs emacs ++ lib.optional withRuby ruby ++ lib.optional withSfsexp makeWrapper; - buildInputs = [ - gnupg # undefined dependencies - xapian gmime3 talloc zlib # dependencies described in INSTALL - perl - pythonPackages.python - ] ++ lib.optional withRuby ruby + buildInputs = + [ + gnupg # undefined dependencies + xapian + gmime3 + talloc + zlib # dependencies described in INSTALL + perl + pythonPackages.python + ] + ++ lib.optional withRuby ruby ++ lib.optional withSfsexp sfsexp; - postPatch = '' - patchShebangs configure test/ + postPatch = + '' + patchShebangs configure test/ - substituteInPlace lib/Makefile.local \ - --replace '-install_name $(libdir)' "-install_name $out/lib" + substituteInPlace lib/Makefile.local \ + --replace '-install_name $(libdir)' "-install_name $out/lib" - # do not override CFLAGS of the Makefile created by mkmf - substituteInPlace bindings/Makefile.local \ - --replace 'CFLAGS="$(CFLAGS) -pipe -fno-plt -fPIC"' "" - '' + lib.optionalString withEmacs '' - substituteInPlace emacs/notmuch-emacs-mua \ - --replace 'EMACS:-emacs' 'EMACS:-${emacs}/bin/emacs' \ - --replace 'EMACSCLIENT:-emacsclient' 'EMACSCLIENT:-${emacs}/bin/emacsclient' - ''; + # do not override CFLAGS of the Makefile created by mkmf + substituteInPlace bindings/Makefile.local \ + --replace 'CFLAGS="$(CFLAGS) -pipe -fno-plt -fPIC"' "" + '' + + lib.optionalString withEmacs '' + substituteInPlace emacs/notmuch-emacs-mua \ + --replace 'EMACS:-emacs' 'EMACS:-${emacs}/bin/emacs' \ + --replace 'EMACSCLIENT:-emacsclient' 'EMACSCLIENT:-${emacs}/bin/emacsclient' + ''; - configureFlags = [ - "--zshcompletiondir=${placeholder "out"}/share/zsh/site-functions" - "--bashcompletiondir=${placeholder "out"}/share/bash-completion/completions" - "--infodir=${placeholder "info"}/share/info" - ] ++ lib.optional (!withEmacs) "--without-emacs" + configureFlags = + [ + "--zshcompletiondir=${placeholder "out"}/share/zsh/site-functions" + "--bashcompletiondir=${placeholder "out"}/share/bash-completion/completions" + "--infodir=${placeholder "info"}/share/info" + ] + ++ lib.optional (!withEmacs) "--without-emacs" ++ lib.optional withEmacs "--emacslispdir=${placeholder "emacs"}/share/emacs/site-lisp" ++ lib.optional (!withRuby) "--without-ruby"; @@ -76,7 +105,13 @@ stdenv.mkDerivation (finalAttrs: { cp bindings/python-cffi/_notmuch_config.py ${placeholder "bindingconfig"}/ ''; - outputs = [ "out" "man" "info" "bindingconfig" ] + outputs = + [ + "out" + "man" + "info" + "bindingconfig" + ] ++ lib.optional withEmacs "emacs" ++ lib.optional withVim "vim"; @@ -109,54 +144,70 @@ stdenv.mkDerivation (finalAttrs: { doCheck = !stdenv.hostPlatform.isDarwin && (lib.versionAtLeast gmime3.version "3.0.3"); checkTarget = "test"; - nativeCheckInputs = [ - which dtach openssl bash - gdb man - ] - # for the test T-850.sh for notmuch-git, which is skipped when notmuch is - # built without sexp-support - ++ lib.optional withEmacs emacs - ++ lib.optional withSfsexp git; - - installTargets = [ "install" "install-man" "install-info" ]; - - postInstall = lib.optionalString withEmacs '' - moveToOutput bin/notmuch-emacs-mua $emacs - '' + lib.optionalString withRuby '' - make -C bindings/ruby install \ - vendordir=$out/lib/ruby \ - SHELL=$SHELL \ - $makeFlags "''${makeFlagsArray[@]}" \ - $installFlags "''${installFlagsArray[@]}" - '' - # notmuch-git (https://notmuchmail.org/doc/latest/man1/notmuch-git.html) does not work without - # sexp-support, so there is no point in installing if we're building without it. - + lib.optionalString withSfsexp '' - cp notmuch-git $out/bin/notmuch-git - wrapProgram $out/bin/notmuch-git --prefix PATH : $out/bin:${lib.getBin git}/bin - '' + lib.optionalString withVim '' - make -C vim DESTDIR="$vim/share/vim-plugins/notmuch" prefix="" install - mkdir -p $vim/share/nvim - ln -s $vim/share/vim-plugins/notmuch $vim/share/nvim/site - '' + lib.optionalString (withVim && withRuby) '' - PLUG=$vim/share/vim-plugins/notmuch/plugin/notmuch.vim - cat >> $PLUG << EOF - let \$GEM_PATH=\$GEM_PATH . ":${finalAttrs.passthru.gemEnv}/${ruby.gemPath}" - let \$RUBYLIB=\$RUBYLIB . ":$vim/${ruby.libPath}/${ruby.system}" - if has('nvim') - EOF - for gem in ${finalAttrs.passthru.gemEnv}/${ruby.gemPath}/gems/*/lib; do - echo "ruby \$LOAD_PATH.unshift('$gem')" >> $PLUG - done - echo 'endif' >> $PLUG - ''; + nativeCheckInputs = + [ + which + dtach + openssl + bash + gdb + man + ] + # for the test T-850.sh for notmuch-git, which is skipped when notmuch is + # built without sexp-support + ++ lib.optional withEmacs emacs + ++ lib.optional withSfsexp git; + + installTargets = [ + "install" + "install-man" + "install-info" + ]; + + postInstall = + lib.optionalString withEmacs '' + moveToOutput bin/notmuch-emacs-mua $emacs + '' + + lib.optionalString withRuby '' + make -C bindings/ruby install \ + vendordir=$out/lib/ruby \ + SHELL=$SHELL \ + $makeFlags "''${makeFlagsArray[@]}" \ + $installFlags "''${installFlagsArray[@]}" + '' + # notmuch-git (https://notmuchmail.org/doc/latest/man1/notmuch-git.html) does not work without + # sexp-support, so there is no point in installing if we're building without it. + + lib.optionalString withSfsexp '' + cp notmuch-git $out/bin/notmuch-git + wrapProgram $out/bin/notmuch-git --prefix PATH : $out/bin:${lib.getBin git}/bin + '' + + lib.optionalString withVim '' + make -C vim DESTDIR="$vim/share/vim-plugins/notmuch" prefix="" install + mkdir -p $vim/share/nvim + ln -s $vim/share/vim-plugins/notmuch $vim/share/nvim/site + '' + + lib.optionalString (withVim && withRuby) '' + PLUG=$vim/share/vim-plugins/notmuch/plugin/notmuch.vim + cat >> $PLUG << EOF + let \$GEM_PATH=\$GEM_PATH . ":${finalAttrs.passthru.gemEnv}/${ruby.gemPath}" + let \$RUBYLIB=\$RUBYLIB . ":$vim/${ruby.libPath}/${ruby.system}" + if has('nvim') + EOF + for gem in ${finalAttrs.passthru.gemEnv}/${ruby.gemPath}/gems/*/lib; do + echo "ruby \$LOAD_PATH.unshift('$gem')" >> $PLUG + done + echo 'endif' >> $PLUG + ''; passthru = { pythonSourceRoot = "notmuch-${finalAttrs.version}/bindings/python"; gemEnv = buildEnv { name = "notmuch-vim-gems"; paths = with ruby.gems; [ mail ]; - pathsToLink = [ "/lib" "/nix-support" ]; + pathsToLink = [ + "/lib" + "/nix-support" + ]; }; tests.version = testers.testVersion { package = finalAttrs.finalPackage; }; @@ -168,11 +219,14 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Mail indexer"; - homepage = "https://notmuchmail.org/"; - changelog = "https://git.notmuchmail.org/git?p=notmuch;a=blob_plain;f=NEWS;hb=${version}"; - license = licenses.gpl3Plus; - maintainers = with maintainers; [ flokli puckipedia ]; - platforms = platforms.unix; + homepage = "https://notmuchmail.org/"; + changelog = "https://git.notmuchmail.org/git?p=notmuch;a=blob_plain;f=NEWS;hb=${version}"; + license = licenses.gpl3Plus; + maintainers = with maintainers; [ + flokli + puckipedia + ]; + platforms = platforms.unix; mainProgram = "notmuch"; }; }) diff --git a/pkgs/applications/networking/mailreaders/notmuch/muchsync.nix b/pkgs/applications/networking/mailreaders/notmuch/muchsync.nix index 6de6838eeeda1b..5ac38f7db782e8 100644 --- a/pkgs/applications/networking/mailreaders/notmuch/muchsync.nix +++ b/pkgs/applications/networking/mailreaders/notmuch/muchsync.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchurl -, notmuch, openssl, pkg-config, sqlite, xapian, zlib +{ + lib, + stdenv, + fetchurl, + notmuch, + openssl, + pkg-config, + sqlite, + xapian, + zlib, }: stdenv.mkDerivation rec { version = "7"; @@ -12,7 +20,13 @@ stdenv.mkDerivation rec { hash = "sha256-+D4vb80O9IE0df3cjTkoVoZlTaX0FWWh6ams14Gjvqw="; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ notmuch openssl sqlite xapian zlib ]; + buildInputs = [ + notmuch + openssl + sqlite + xapian + zlib + ]; XAPIAN_CONFIG = "${xapian}/bin/xapian-config"; meta = { description = "Synchronize maildirs and notmuch databases"; diff --git a/pkgs/applications/networking/mailreaders/notmuch/mutt.nix b/pkgs/applications/networking/mailreaders/notmuch/mutt.nix index 92d82f057fbdd5..370dc7ebf8fe27 100644 --- a/pkgs/applications/networking/mailreaders/notmuch/mutt.nix +++ b/pkgs/applications/networking/mailreaders/notmuch/mutt.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, perl, perlPackages, makeWrapper, coreutils, notmuch }: +{ + stdenv, + lib, + perl, + perlPackages, + makeWrapper, + coreutils, + notmuch, +}: stdenv.mkDerivation rec { pname = "notmuch-mutt"; @@ -9,18 +17,20 @@ stdenv.mkDerivation rec { dontStrip = true; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ - perl - ] ++ (with perlPackages; [ - FileRemove - DigestSHA1 - Later - MailBox - MailMaildir - MailTools - StringShellQuote - TermReadLineGnu - ]); + buildInputs = + [ + perl + ] + ++ (with perlPackages; [ + FileRemove + DigestSHA1 + Later + MailBox + MailMaildir + MailTools + StringShellQuote + TermReadLineGnu + ]); src = notmuch.src; @@ -39,9 +49,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Mutt support for notmuch"; mainProgram = "notmuch-mutt"; - homepage = "https://notmuchmail.org/"; - license = with licenses; gpl3; + homepage = "https://notmuchmail.org/"; + license = with licenses; gpl3; maintainers = with maintainers; [ peterhoeg ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/applications/networking/mailreaders/sylpheed/default.nix b/pkgs/applications/networking/mailreaders/sylpheed/default.nix index 9e765743dd636f..42f6c8597701d1 100644 --- a/pkgs/applications/networking/mailreaders/sylpheed/default.nix +++ b/pkgs/applications/networking/mailreaders/sylpheed/default.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchurl, pkg-config, gtk2, openssl ? null, gpgme ? null -, gpgSupport ? true, sslSupport ? true, fetchpatch, Foundation }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + openssl ? null, + gpgme ? null, + gpgSupport ? true, + sslSupport ? true, + fetchpatch, + Foundation, +}: assert gpgSupport -> gpgme != null; assert sslSupport -> openssl != null; @@ -30,13 +41,13 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk2 ] + buildInputs = + [ gtk2 ] ++ lib.optionals gpgSupport [ gpgme ] ++ lib.optionals sslSupport [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Foundation ]; - configureFlags = lib.optional gpgSupport "--enable-gpgme" - ++ lib.optional sslSupport "--enable-ssl"; + configureFlags = lib.optional gpgSupport "--enable-gpgme" ++ lib.optional sslSupport "--enable-ssl"; # Undefined symbols for architecture arm64: "_OBJC_CLASS_$_NSAutoreleasePool" NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin "-framework Foundation"; diff --git a/pkgs/applications/networking/mailreaders/thunderbird-bin/default.nix b/pkgs/applications/networking/mailreaders/thunderbird-bin/default.nix index cd3954ba590a34..e7c901d5cbd62c 100644 --- a/pkgs/applications/networking/mailreaders/thunderbird-bin/default.nix +++ b/pkgs/applications/networking/mailreaders/thunderbird-bin/default.nix @@ -3,21 +3,27 @@ # To update `thunderbird-bin`'s `release_sources.nix`, run from the nixpkgs root: # # nix-shell maintainers/scripts/update.nix --argstr package pkgs.thunderbird-bin-unwrapped -{ lib, stdenv, fetchurl, config, wrapGAppsHook3, autoPatchelfHook -, alsa-lib -, curl -, gtk3 -, writeScript -, writeText -, xidel -, coreutils -, gnused -, gnugrep -, gnupg -, runtimeShell -, systemLocale ? config.i18n.defaultLocale or "en_US" -, patchelfUnstable # have to use patchelfUnstable to support --no-clobber-old-sections -, generated +{ + lib, + stdenv, + fetchurl, + config, + wrapGAppsHook3, + autoPatchelfHook, + alsa-lib, + curl, + gtk3, + writeScript, + writeText, + xidel, + coreutils, + gnused, + gnugrep, + gnupg, + runtimeShell, + systemLocale ? config.i18n.defaultLocale or "en_US", + patchelfUnstable, # have to use patchelfUnstable to support --no-clobber-old-sections + generated, }: let @@ -30,21 +36,22 @@ let arch = mozillaPlatforms.${stdenv.hostPlatform.system}; - isPrefixOf = prefix: string: - builtins.substring 0 (builtins.stringLength prefix) string == prefix; + isPrefixOf = prefix: string: builtins.substring 0 (builtins.stringLength prefix) string == prefix; - sourceMatches = locale: source: - (isPrefixOf source.locale locale) && source.arch == arch; + sourceMatches = locale: source: (isPrefixOf source.locale locale) && source.arch == arch; - policies = { DisableAppUpdate = true; } // config.thunderbird.policies or { }; + policies = { + DisableAppUpdate = true; + } // config.thunderbird.policies or { }; policiesJson = writeText "thunderbird-policies.json" (builtins.toJSON { inherit policies; }); - defaultSource = lib.findFirst (sourceMatches "en-US") {} sources; + defaultSource = lib.findFirst (sourceMatches "en-US") { } sources; mozLocale = - if systemLocale == "ca_ES@valencia" - then "ca-valencia" - else lib.replaceStrings ["_"] ["-"] systemLocale; + if systemLocale == "ca_ES@valencia" then + "ca-valencia" + else + lib.replaceStrings [ "_" ] [ "-" ] systemLocale; source = lib.findFirst (sourceMatches mozLocale) defaultSource sources; @@ -59,7 +66,11 @@ stdenv.mkDerivation { inherit (source) sha256; }; - nativeBuildInputs = [ wrapGAppsHook3 autoPatchelfHook patchelfUnstable ]; + nativeBuildInputs = [ + wrapGAppsHook3 + autoPatchelfHook + patchelfUnstable + ]; buildInputs = [ alsa-lib ]; @@ -71,26 +82,36 @@ stdenv.mkDerivation { echo 'pref("app.update.auto", "false");' >> defaults/pref/channel-prefs.js ''; - installPhase = - '' - mkdir -p "$prefix/usr/lib/thunderbird-bin-${version}" - cp -r * "$prefix/usr/lib/thunderbird-bin-${version}" + installPhase = '' + mkdir -p "$prefix/usr/lib/thunderbird-bin-${version}" + cp -r * "$prefix/usr/lib/thunderbird-bin-${version}" - mkdir -p "$out/bin" - ln -s "$prefix/usr/lib/thunderbird-bin-${version}/thunderbird" "$out/bin/" + mkdir -p "$out/bin" + ln -s "$prefix/usr/lib/thunderbird-bin-${version}/thunderbird" "$out/bin/" - # wrapThunderbird expects "$out/lib" instead of "$out/usr/lib" - ln -s "$out/usr/lib" "$out/lib" + # wrapThunderbird expects "$out/lib" instead of "$out/usr/lib" + ln -s "$out/usr/lib" "$out/lib" - gappsWrapperArgs+=(--argv0 "$out/bin/.thunderbird-wrapped") + gappsWrapperArgs+=(--argv0 "$out/bin/.thunderbird-wrapped") - # See: https://github.com/mozilla/policy-templates/blob/master/README.md - mkdir -p "$out/lib/thunderbird-bin-${version}/distribution"; - ln -s ${policiesJson} "$out/lib/thunderbird-bin-${version}/distribution/policies.json"; - ''; + # See: https://github.com/mozilla/policy-templates/blob/master/README.md + mkdir -p "$out/lib/thunderbird-bin-${version}/distribution"; + ln -s ${policiesJson} "$out/lib/thunderbird-bin-${version}/distribution/policies.json"; + ''; passthru.updateScript = import ./../../browsers/firefox-bin/update.nix { - inherit pname lib writeScript xidel coreutils gnused gnugrep curl gnupg runtimeShell; + inherit + pname + lib + writeScript + xidel + coreutils + gnused + gnugrep + curl + gnupg + runtimeShell + ; baseName = "thunderbird"; channel = "release"; basePath = "pkgs/applications/networking/mailreaders/thunderbird-bin"; diff --git a/pkgs/applications/networking/mailreaders/thunderbird-bin/release_sources.nix b/pkgs/applications/networking/mailreaders/thunderbird-bin/release_sources.nix index 75d5df9ecfa90c..11fda1d9d8143f 100644 --- a/pkgs/applications/networking/mailreaders/thunderbird-bin/release_sources.nix +++ b/pkgs/applications/networking/mailreaders/thunderbird-bin/release_sources.nix @@ -1,665 +1,797 @@ { version = "128.5.0esr"; sources = [ - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/af/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/af/thunderbird-128.5.0esr.tar.bz2"; locale = "af"; arch = "linux-x86_64"; sha256 = "bf141809be942000802ccc5c7e7f9c9de64345e2ee323f57c29e30fb8301613f"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ar/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ar/thunderbird-128.5.0esr.tar.bz2"; locale = "ar"; arch = "linux-x86_64"; sha256 = "ac71adbd3510e52f5280c2674c9ce3104f41d7ff0800c244093a331d04b4971d"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ast/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ast/thunderbird-128.5.0esr.tar.bz2"; locale = "ast"; arch = "linux-x86_64"; sha256 = "51838e12a6a1f304a0a5c1c85417bc81b5e2f3870a58912e08e088bfbca636d3"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/be/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/be/thunderbird-128.5.0esr.tar.bz2"; locale = "be"; arch = "linux-x86_64"; sha256 = "b9a95f985de60041985ba11611af933d9cfdc15a5345bb1f71019e1caae5fad8"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/bg/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/bg/thunderbird-128.5.0esr.tar.bz2"; locale = "bg"; arch = "linux-x86_64"; sha256 = "ab8493efca260eee3ade25251be5cf00549c80940c22560fb3927a2c4b1e700f"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/br/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/br/thunderbird-128.5.0esr.tar.bz2"; locale = "br"; arch = "linux-x86_64"; sha256 = "a3134f3df5baab7c99acb53f9ad27e367b641ea42216f8753cb0c55513d863d9"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ca/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ca/thunderbird-128.5.0esr.tar.bz2"; locale = "ca"; arch = "linux-x86_64"; sha256 = "57e922d86a1fad2d220372eb1086236853b56a04619eb3ce5b72cca24532d46c"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/cak/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/cak/thunderbird-128.5.0esr.tar.bz2"; locale = "cak"; arch = "linux-x86_64"; sha256 = "0ac666a4f2066bfc7b77ed3400340c3e7510b695d979dee19b2dbe08cad64df9"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/cs/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/cs/thunderbird-128.5.0esr.tar.bz2"; locale = "cs"; arch = "linux-x86_64"; sha256 = "39eed8ef4c0d6035cd250acc46852c590c95f2985f04f32619013cfade06f893"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/cy/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/cy/thunderbird-128.5.0esr.tar.bz2"; locale = "cy"; arch = "linux-x86_64"; sha256 = "cd11988b3bc4b228470e36f1af45571e8a85b96361da46410a0ee38a366af2b1"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/da/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/da/thunderbird-128.5.0esr.tar.bz2"; locale = "da"; arch = "linux-x86_64"; sha256 = "0c05b4aad2e76343a1923f89593ae51bf3a2db326d44e089834e9d54bf31c263"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/de/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/de/thunderbird-128.5.0esr.tar.bz2"; locale = "de"; arch = "linux-x86_64"; sha256 = "8b281370178e06a6a35133c7cdb791e22cef34da9dbf9b84b5847b8b4201746b"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/dsb/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/dsb/thunderbird-128.5.0esr.tar.bz2"; locale = "dsb"; arch = "linux-x86_64"; sha256 = "324a99f3ba46d9ccef0f7ac0dab35db5330cddfa3c09b328770c7812fe3d364c"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/el/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/el/thunderbird-128.5.0esr.tar.bz2"; locale = "el"; arch = "linux-x86_64"; sha256 = "08f49bf601feb248f98bbb5d558440f04c7df9e320466c0282c0588fda275a03"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/en-CA/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/en-CA/thunderbird-128.5.0esr.tar.bz2"; locale = "en-CA"; arch = "linux-x86_64"; sha256 = "329fa38d6e881706bfbbaa8b9625b9e681e41606b42cfd9f25c866a45ab58fee"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/en-GB/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/en-GB/thunderbird-128.5.0esr.tar.bz2"; locale = "en-GB"; arch = "linux-x86_64"; sha256 = "276387261629de231ad41570c0821d39c4e343f6b34bb31867e7c4ff5bc7c9b3"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/en-US/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/en-US/thunderbird-128.5.0esr.tar.bz2"; locale = "en-US"; arch = "linux-x86_64"; sha256 = "d612084b5e5f4005577171bc8c8bf8ee7e38fd7e16cbb2b7c32fb4148faf0e50"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/es-AR/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/es-AR/thunderbird-128.5.0esr.tar.bz2"; locale = "es-AR"; arch = "linux-x86_64"; sha256 = "81a62da51a8b732721783059359f98033778831db689cb602bf1add2c53256b5"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/es-ES/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/es-ES/thunderbird-128.5.0esr.tar.bz2"; locale = "es-ES"; arch = "linux-x86_64"; sha256 = "b7374e7069ef698c83c55a32247543b0229bf1f1dc2a1656532b95dde2d6e3a3"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/es-MX/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/es-MX/thunderbird-128.5.0esr.tar.bz2"; locale = "es-MX"; arch = "linux-x86_64"; sha256 = "63b228f1de074f1f7e59d2e26f5531c49643e9e83ed2c87dd52c39b059c8985a"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/et/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/et/thunderbird-128.5.0esr.tar.bz2"; locale = "et"; arch = "linux-x86_64"; sha256 = "6d6f597f49a0c0606257534d44075ebacb25f503a0380858b6f46841d78e20de"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/eu/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/eu/thunderbird-128.5.0esr.tar.bz2"; locale = "eu"; arch = "linux-x86_64"; sha256 = "441c835d3990fd72ceb87fa1a8474ba0988c9423f4fad6558eade93ad840d730"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/fi/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/fi/thunderbird-128.5.0esr.tar.bz2"; locale = "fi"; arch = "linux-x86_64"; sha256 = "2b6d9faf698fbf46fde988b1f9bcfa35a5ecad69327f1fc50f4a0f9f99ef2e62"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/fr/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/fr/thunderbird-128.5.0esr.tar.bz2"; locale = "fr"; arch = "linux-x86_64"; sha256 = "7b96d4d29d4185cf3f4539e79466d71e110c516f1ea5b71e909bd4f6d6c197e3"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/fy-NL/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/fy-NL/thunderbird-128.5.0esr.tar.bz2"; locale = "fy-NL"; arch = "linux-x86_64"; sha256 = "3793b5f8ea3900980608d8771597645caa1c3173b3ca50e52d39002d5ff45fe3"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ga-IE/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ga-IE/thunderbird-128.5.0esr.tar.bz2"; locale = "ga-IE"; arch = "linux-x86_64"; sha256 = "e71dda89ed9d87a1a4685efc2d30962db948c5cf01eb70a22adcdff93c96f371"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/gd/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/gd/thunderbird-128.5.0esr.tar.bz2"; locale = "gd"; arch = "linux-x86_64"; sha256 = "70262e69f9b02d86358d9c9303becba44ffec53ef982bdc3eebac026c83702bd"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/gl/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/gl/thunderbird-128.5.0esr.tar.bz2"; locale = "gl"; arch = "linux-x86_64"; sha256 = "c4cb4c3e0d882dd460f476da3d22553a2402cf54865411005754777f8c370644"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/he/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/he/thunderbird-128.5.0esr.tar.bz2"; locale = "he"; arch = "linux-x86_64"; sha256 = "b455c97a5a1e0ecaef5374b11ab08ad709330c14bcc29abaa4767e151ab2f1ba"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/hr/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/hr/thunderbird-128.5.0esr.tar.bz2"; locale = "hr"; arch = "linux-x86_64"; sha256 = "1ac9c1583ce60d5f6878038c60cfc0bcee90a5fb34cc1d4f0a239f710586668b"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/hsb/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/hsb/thunderbird-128.5.0esr.tar.bz2"; locale = "hsb"; arch = "linux-x86_64"; sha256 = "f40a7d7eec65fe20e3ddd26d7dbb49c80131ade60ccb1872b51c6cf09b5cdaac"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/hu/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/hu/thunderbird-128.5.0esr.tar.bz2"; locale = "hu"; arch = "linux-x86_64"; sha256 = "876cd1f1840edaf44602d42012bcc31b2f928f83915869e7a1a85b74ec1b8cc1"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/hy-AM/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/hy-AM/thunderbird-128.5.0esr.tar.bz2"; locale = "hy-AM"; arch = "linux-x86_64"; sha256 = "974f0eb2b1452d787036db75dc8ef06ccf1d15521ddcdf7fefe89e25ea0451c1"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/id/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/id/thunderbird-128.5.0esr.tar.bz2"; locale = "id"; arch = "linux-x86_64"; sha256 = "2e7ba78aed383c152fbf443e74a25ff41c22b28a34fcdcf8d347ff1c0e46ce77"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/is/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/is/thunderbird-128.5.0esr.tar.bz2"; locale = "is"; arch = "linux-x86_64"; sha256 = "55c295af6a1339b7c432834381d587ea921d558ecb78f29e29564d1f394c155a"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/it/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/it/thunderbird-128.5.0esr.tar.bz2"; locale = "it"; arch = "linux-x86_64"; sha256 = "2479f33f19d0d2724202a133e2590931ceab894660c3dc775151f6c850c9e42c"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ja/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ja/thunderbird-128.5.0esr.tar.bz2"; locale = "ja"; arch = "linux-x86_64"; sha256 = "1f3b76a1193330f7a4538400805a0cdafad56b96a4cc4bc2ada5cf1d62361648"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ka/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ka/thunderbird-128.5.0esr.tar.bz2"; locale = "ka"; arch = "linux-x86_64"; sha256 = "b63d8939320c1dd3d6e9a7d965f82b0fc388640e304fce7995f7a13710339e99"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/kab/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/kab/thunderbird-128.5.0esr.tar.bz2"; locale = "kab"; arch = "linux-x86_64"; sha256 = "d221cd9396a1b2b8945e0e75b8ad118f2ee34d45976bdb9b717dae0a96db9286"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/kk/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/kk/thunderbird-128.5.0esr.tar.bz2"; locale = "kk"; arch = "linux-x86_64"; sha256 = "56a63af61c24148d5fe12601580157381669ab670f07507107d9ea46d03d4392"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ko/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ko/thunderbird-128.5.0esr.tar.bz2"; locale = "ko"; arch = "linux-x86_64"; sha256 = "b5d2af0451f659e7abb6d548ceff053e3cbf13cf3eb6c42374a9a193e331fda7"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/lt/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/lt/thunderbird-128.5.0esr.tar.bz2"; locale = "lt"; arch = "linux-x86_64"; sha256 = "5ee2a8440be5e344564a5d4b4f4629df691e6245f2b0f2024020752430ba488e"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/lv/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/lv/thunderbird-128.5.0esr.tar.bz2"; locale = "lv"; arch = "linux-x86_64"; sha256 = "3e2fe77604f976102a274e77a506b025b4c0443077082da6cfaa648b3018f322"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ms/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ms/thunderbird-128.5.0esr.tar.bz2"; locale = "ms"; arch = "linux-x86_64"; sha256 = "e180dc2c02fad1473272b7dfb447208a1b8abdb335d362696d649fe6f2fa9da6"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/nb-NO/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/nb-NO/thunderbird-128.5.0esr.tar.bz2"; locale = "nb-NO"; arch = "linux-x86_64"; sha256 = "472ae10df128c9d16a5c1bf688edc4bf43da36b4f254c55b37e5af8768339581"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/nl/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/nl/thunderbird-128.5.0esr.tar.bz2"; locale = "nl"; arch = "linux-x86_64"; sha256 = "18235f21aae857efcff66427a4d1e3a513c71d89aad3142e4161f61c7775224e"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/nn-NO/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/nn-NO/thunderbird-128.5.0esr.tar.bz2"; locale = "nn-NO"; arch = "linux-x86_64"; sha256 = "99fe98fc5c5a015a053a2918625be003a67ffb0369f8b373cda1684391a9a281"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/pa-IN/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/pa-IN/thunderbird-128.5.0esr.tar.bz2"; locale = "pa-IN"; arch = "linux-x86_64"; sha256 = "f7f27918958d21c681c10b413907b3517e5090134fd29a659b0c31dfba6f9e69"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/pl/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/pl/thunderbird-128.5.0esr.tar.bz2"; locale = "pl"; arch = "linux-x86_64"; sha256 = "2dbfacbedb8dcfaa57553240ea7b52320a5ee0ea2351aeba731532674fd8903e"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/pt-BR/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/pt-BR/thunderbird-128.5.0esr.tar.bz2"; locale = "pt-BR"; arch = "linux-x86_64"; sha256 = "91e59ecd438834f178d283f305500030c5d7f37ecd527c4c052a1b77b0f789d9"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/pt-PT/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/pt-PT/thunderbird-128.5.0esr.tar.bz2"; locale = "pt-PT"; arch = "linux-x86_64"; sha256 = "3677a355554546e8dfd0654829662fb5d0ec50eeb95516ce50a96e656f055bd4"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/rm/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/rm/thunderbird-128.5.0esr.tar.bz2"; locale = "rm"; arch = "linux-x86_64"; sha256 = "4ff5642d2e03153feb8c692959879391bb2506fe7727009ad50ca8163c06f293"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ro/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ro/thunderbird-128.5.0esr.tar.bz2"; locale = "ro"; arch = "linux-x86_64"; sha256 = "db9d6d7e5b786d20f3fa9dc270a0ea1cc6e2ca3c1c87079f2b490300b402bc02"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ru/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/ru/thunderbird-128.5.0esr.tar.bz2"; locale = "ru"; arch = "linux-x86_64"; sha256 = "0153f7690b1996b0e0f13bec1cbb19eaedd84dd3a10d0e3f4343ecc623407140"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/sk/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/sk/thunderbird-128.5.0esr.tar.bz2"; locale = "sk"; arch = "linux-x86_64"; sha256 = "0ed388ce9ff2bfc214b612b0a2e8982ec6162e4950769b0deb89a362f5440900"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/sl/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/sl/thunderbird-128.5.0esr.tar.bz2"; locale = "sl"; arch = "linux-x86_64"; sha256 = "2cbd30d96f27d5d292d88c0a73e2e13589b254527d109fab2d2aae7bda7d7ff1"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/sq/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/sq/thunderbird-128.5.0esr.tar.bz2"; locale = "sq"; arch = "linux-x86_64"; sha256 = "cdbf3a92fa32a750575b6c1258ddae971ce62a1e6d57ac24b137742830306977"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/sr/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/sr/thunderbird-128.5.0esr.tar.bz2"; locale = "sr"; arch = "linux-x86_64"; sha256 = "f67aa8002c54ff88405ee37a2d875826fd46e8481750138531c713d15a97d79c"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/sv-SE/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/sv-SE/thunderbird-128.5.0esr.tar.bz2"; locale = "sv-SE"; arch = "linux-x86_64"; sha256 = "82c2b8a75d8bb8c3261366b049ea6524317d254d2dc61a5ee813d7220e927f6c"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/th/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/th/thunderbird-128.5.0esr.tar.bz2"; locale = "th"; arch = "linux-x86_64"; sha256 = "5e55930bda79b5cefd10f5d7418f67cc355eb5b3548e424984a8ee18c5aba5ef"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/tr/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/tr/thunderbird-128.5.0esr.tar.bz2"; locale = "tr"; arch = "linux-x86_64"; sha256 = "4285425d9cebd097360212de6d9534f05373478946b6ad1a0233421246fa7c0d"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/uk/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/uk/thunderbird-128.5.0esr.tar.bz2"; locale = "uk"; arch = "linux-x86_64"; sha256 = "417c6482d30b61839b3545cbcccb7664f91e9993a94a7475a513a6842646240d"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/uz/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/uz/thunderbird-128.5.0esr.tar.bz2"; locale = "uz"; arch = "linux-x86_64"; sha256 = "6a051d014f8bdca6195e3f21dd481be9a232501e0280843cc07b0fde09149801"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/vi/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/vi/thunderbird-128.5.0esr.tar.bz2"; locale = "vi"; arch = "linux-x86_64"; sha256 = "d5ebe571e630ef8a963f5a27e6e0096eccfc12f35fd5437bae82bacdf0e5538e"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/zh-CN/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/zh-CN/thunderbird-128.5.0esr.tar.bz2"; locale = "zh-CN"; arch = "linux-x86_64"; sha256 = "97563908550924bc43d99da7d096e7260b3c23e59df58a51bfe1b6c76de54f33"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/zh-TW/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-x86_64/zh-TW/thunderbird-128.5.0esr.tar.bz2"; locale = "zh-TW"; arch = "linux-x86_64"; sha256 = "bce0c4667d7444d63802badffdaad9f7bf3d916233f836b98b7565fc68171804"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/af/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/af/thunderbird-128.5.0esr.tar.bz2"; locale = "af"; arch = "linux-i686"; sha256 = "ba311de618f1d21f816de08fe19410f5e7623c177ca1a60054b62457662b4721"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ar/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ar/thunderbird-128.5.0esr.tar.bz2"; locale = "ar"; arch = "linux-i686"; sha256 = "7b9a0a04a18ee7a051254fd72d0cefbbf82b86cf3b6fcefaec8481ca969c70bc"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ast/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ast/thunderbird-128.5.0esr.tar.bz2"; locale = "ast"; arch = "linux-i686"; sha256 = "3cf834ba074f2a38e0686d820ee9abe6714b3f0e4d1c385b22bf81e4681eb42a"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/be/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/be/thunderbird-128.5.0esr.tar.bz2"; locale = "be"; arch = "linux-i686"; sha256 = "9c7e2f2e1285b4a728948226d8b3494c79053b5ec210b2b42c261b18a79c8f68"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/bg/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/bg/thunderbird-128.5.0esr.tar.bz2"; locale = "bg"; arch = "linux-i686"; sha256 = "fa4786856bf6966c5e6f3bb0066950cd3da1f6fed2179e7071ca76d96ea09880"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/br/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/br/thunderbird-128.5.0esr.tar.bz2"; locale = "br"; arch = "linux-i686"; sha256 = "9baa235bfdf221d9494c028ec29f968be68a23595ef4bb6817f71bccaa5cae8b"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ca/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ca/thunderbird-128.5.0esr.tar.bz2"; locale = "ca"; arch = "linux-i686"; sha256 = "d3ca0c86f8ce9313272c540cf7ab87e01b7a6f183adceff9f31a571eacbcc0bc"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/cak/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/cak/thunderbird-128.5.0esr.tar.bz2"; locale = "cak"; arch = "linux-i686"; sha256 = "97cb59dfaaf9f7f7c68f3d6030aa4e65314f80ed2be7671a188d10aeb2b1166a"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/cs/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/cs/thunderbird-128.5.0esr.tar.bz2"; locale = "cs"; arch = "linux-i686"; sha256 = "acb99acc481fdaa9135e07e10c962df82d66f7296fec84bbddba324248a3b115"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/cy/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/cy/thunderbird-128.5.0esr.tar.bz2"; locale = "cy"; arch = "linux-i686"; sha256 = "b3945247f968f32b59fbea6454d05bc32973d6caee3a1b89a3551555321ee18c"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/da/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/da/thunderbird-128.5.0esr.tar.bz2"; locale = "da"; arch = "linux-i686"; sha256 = "c786d70438ece2b4b20d4ddfb79ba150981e4a46d5095525da9cfe5ec8d3b5ee"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/de/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/de/thunderbird-128.5.0esr.tar.bz2"; locale = "de"; arch = "linux-i686"; sha256 = "98e47e0264d620ec111ebc29fd56f07b113adf4dabe29c8982e6ae8f325dc0df"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/dsb/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/dsb/thunderbird-128.5.0esr.tar.bz2"; locale = "dsb"; arch = "linux-i686"; sha256 = "61c38ccd7c956da45aae15ed5d83387efdf6d1a2efd5a23bd2cd689885d99732"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/el/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/el/thunderbird-128.5.0esr.tar.bz2"; locale = "el"; arch = "linux-i686"; sha256 = "ee48d2bc6b808b38ef15381c35f152fd8c6b6c6ea2847a8bf1664299787ced22"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/en-CA/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/en-CA/thunderbird-128.5.0esr.tar.bz2"; locale = "en-CA"; arch = "linux-i686"; sha256 = "4e2ddaea30c6e96305816e325799480976bd4a592a12aeec3847f432e60f66b1"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/en-GB/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/en-GB/thunderbird-128.5.0esr.tar.bz2"; locale = "en-GB"; arch = "linux-i686"; sha256 = "d5e799d093ba2aa4559e4be92791e2be385db915fbfc2965d87d3c19b2a67a46"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/en-US/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/en-US/thunderbird-128.5.0esr.tar.bz2"; locale = "en-US"; arch = "linux-i686"; sha256 = "225928a3496a12af6b7b324255702e0057e3e80dd4bafb1166394a2bc3933d2c"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/es-AR/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/es-AR/thunderbird-128.5.0esr.tar.bz2"; locale = "es-AR"; arch = "linux-i686"; sha256 = "269ec58e0278505c778353e454e91756720b8c0c65b8a976e7ab443380c6c1bc"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/es-ES/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/es-ES/thunderbird-128.5.0esr.tar.bz2"; locale = "es-ES"; arch = "linux-i686"; sha256 = "38ae3bb15128c5c3aa7f8e9a3361c5cff75f16fc27bccc55589f6e93b65567d9"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/es-MX/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/es-MX/thunderbird-128.5.0esr.tar.bz2"; locale = "es-MX"; arch = "linux-i686"; sha256 = "44d11638c8cb8a7aa2072b37b384d17e125ab5ba62459bc2fd849e3965a66f2c"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/et/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/et/thunderbird-128.5.0esr.tar.bz2"; locale = "et"; arch = "linux-i686"; sha256 = "fdd71790464e206363c079d118fa318b2b5ae530851d381b832ccf29a172dce9"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/eu/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/eu/thunderbird-128.5.0esr.tar.bz2"; locale = "eu"; arch = "linux-i686"; sha256 = "4b88c2d28eea088bdcbfb6abfc3a0591a0ee2792d009027b5f420785ec8f6313"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/fi/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/fi/thunderbird-128.5.0esr.tar.bz2"; locale = "fi"; arch = "linux-i686"; sha256 = "55e655f7dd3ce2143cdf9069f87fab107a604c61503c8212f77db95d4f3d98cf"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/fr/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/fr/thunderbird-128.5.0esr.tar.bz2"; locale = "fr"; arch = "linux-i686"; sha256 = "cc8f46937ef91d7eb2a5e8eadf3f8a493c2575d028ea8c9644e33913f7475d08"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/fy-NL/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/fy-NL/thunderbird-128.5.0esr.tar.bz2"; locale = "fy-NL"; arch = "linux-i686"; sha256 = "b77292a17c79f90d986e5b29dd7a5953fe4bd25cf50c8b857c7577d4fcbccf1f"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ga-IE/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ga-IE/thunderbird-128.5.0esr.tar.bz2"; locale = "ga-IE"; arch = "linux-i686"; sha256 = "d094e795f50e27de04f6955043cbdef837d6ef62dc46dc76a4d0ae563a02f80e"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/gd/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/gd/thunderbird-128.5.0esr.tar.bz2"; locale = "gd"; arch = "linux-i686"; sha256 = "ded59f8212ffbe5b232cc966a41868ec7693f4512e4601d248090842632756da"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/gl/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/gl/thunderbird-128.5.0esr.tar.bz2"; locale = "gl"; arch = "linux-i686"; sha256 = "38772837b18fc6c1b76776e346b5fe55c247846eaef66c438d0041b88e68179b"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/he/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/he/thunderbird-128.5.0esr.tar.bz2"; locale = "he"; arch = "linux-i686"; sha256 = "d3b5d4f548520e72c5c73aeafaf322246c1211027903b7364cab2b343ac382c0"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/hr/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/hr/thunderbird-128.5.0esr.tar.bz2"; locale = "hr"; arch = "linux-i686"; sha256 = "02f9f830b1337d657d14e185426b1e1f7c0843960539391312b496285ca575b9"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/hsb/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/hsb/thunderbird-128.5.0esr.tar.bz2"; locale = "hsb"; arch = "linux-i686"; sha256 = "7e9d8c754dc440413f69ce6c9c08c312e02c7492317541b61fa408ba234c7ea0"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/hu/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/hu/thunderbird-128.5.0esr.tar.bz2"; locale = "hu"; arch = "linux-i686"; sha256 = "c346a07a93298fa66ff79013c1551e544920da1eacf5afcb8f556dc1bdbfd38f"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/hy-AM/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/hy-AM/thunderbird-128.5.0esr.tar.bz2"; locale = "hy-AM"; arch = "linux-i686"; sha256 = "b3d19416bfe0101db8c03a4de0c686da8fcf187943c4d187a5eaf1953d11d9f9"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/id/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/id/thunderbird-128.5.0esr.tar.bz2"; locale = "id"; arch = "linux-i686"; sha256 = "e7bbb5da9c98343fe39ed2e4a816825b9ac4e45c89e31a0f0b3ed685c3447bf3"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/is/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/is/thunderbird-128.5.0esr.tar.bz2"; locale = "is"; arch = "linux-i686"; sha256 = "1528dacdd88638660567ce992705f63675530389161c5af6e3c8e9388d624faf"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/it/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/it/thunderbird-128.5.0esr.tar.bz2"; locale = "it"; arch = "linux-i686"; sha256 = "2ab9b4b12aa7ffbedf2e74719ece9cb9cbe45005e751f3b4b416ad0c31ea995e"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ja/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ja/thunderbird-128.5.0esr.tar.bz2"; locale = "ja"; arch = "linux-i686"; sha256 = "48556fcff723564962d5efc2d9b81f44f284fc402ed637b2a399c4ee39820365"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ka/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ka/thunderbird-128.5.0esr.tar.bz2"; locale = "ka"; arch = "linux-i686"; sha256 = "32cae5dc83bc8af9e8dc78a9d4840ae65dc7cb9398eb8941b1eb447a3673d5a3"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/kab/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/kab/thunderbird-128.5.0esr.tar.bz2"; locale = "kab"; arch = "linux-i686"; sha256 = "9777ffd9750589355d6813a55bc0467f956020e8f406b121e9f309e1e7b479da"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/kk/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/kk/thunderbird-128.5.0esr.tar.bz2"; locale = "kk"; arch = "linux-i686"; sha256 = "668aeab0a0805d16ee124b5b01b70558d1b719a3f1192c13a180d119ec5dc44c"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ko/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ko/thunderbird-128.5.0esr.tar.bz2"; locale = "ko"; arch = "linux-i686"; sha256 = "bc3cb3148ff679839bdfded84fa7cd304293a6aad2309af6660436e5bba9b8ec"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/lt/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/lt/thunderbird-128.5.0esr.tar.bz2"; locale = "lt"; arch = "linux-i686"; sha256 = "0892035b80226a7b2ec419d50784abe51f71554fe18d93c2ec19d2712e94992d"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/lv/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/lv/thunderbird-128.5.0esr.tar.bz2"; locale = "lv"; arch = "linux-i686"; sha256 = "48d8939c0ef1a9873ed899c9c48136b9588834d92cf30e3c596c852ba52151cc"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ms/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ms/thunderbird-128.5.0esr.tar.bz2"; locale = "ms"; arch = "linux-i686"; sha256 = "3232bbabf77527e425cd11482ce3958f123ef15d678091d5db8557bb6e44bb7e"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/nb-NO/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/nb-NO/thunderbird-128.5.0esr.tar.bz2"; locale = "nb-NO"; arch = "linux-i686"; sha256 = "278250280ca434aa4609d6f40f736c9eb2e591f860732acccc14caea9d4fce91"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/nl/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/nl/thunderbird-128.5.0esr.tar.bz2"; locale = "nl"; arch = "linux-i686"; sha256 = "06d5b30f31d8cb020df0b29d8bf116664623b58dba6fccb4da49620d55e11097"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/nn-NO/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/nn-NO/thunderbird-128.5.0esr.tar.bz2"; locale = "nn-NO"; arch = "linux-i686"; sha256 = "6a06b0eb2885a9673bd46f4f2fa2298e3ae97ea460e2b86b7a4974d37ab056b3"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/pa-IN/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/pa-IN/thunderbird-128.5.0esr.tar.bz2"; locale = "pa-IN"; arch = "linux-i686"; sha256 = "540fea06d1665754e8aa440f2f09267b4907245d3f4a5f5a01ffd375c8b1f9b9"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/pl/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/pl/thunderbird-128.5.0esr.tar.bz2"; locale = "pl"; arch = "linux-i686"; sha256 = "50601e0dcc19aede6d8f731690a98accd3f190525eb3f9239ac002943736772e"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/pt-BR/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/pt-BR/thunderbird-128.5.0esr.tar.bz2"; locale = "pt-BR"; arch = "linux-i686"; sha256 = "5f0f63a764a1078219fd74890260cdd88409c635c1ec5159170dd55f53e77269"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/pt-PT/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/pt-PT/thunderbird-128.5.0esr.tar.bz2"; locale = "pt-PT"; arch = "linux-i686"; sha256 = "14aa259fb2791e21d597267972d73fd7653bccd9ae5d46568a2356f8d6b99ff3"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/rm/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/rm/thunderbird-128.5.0esr.tar.bz2"; locale = "rm"; arch = "linux-i686"; sha256 = "dc76ed46119a8674bcf1d635736fed833f5059c1bbfcb5ec438cbb14ce3cfc60"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ro/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ro/thunderbird-128.5.0esr.tar.bz2"; locale = "ro"; arch = "linux-i686"; sha256 = "6cd8772297a9ad2081a2b09a98f7d927907734cce5be4353c323f1a47d7c5c53"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ru/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/ru/thunderbird-128.5.0esr.tar.bz2"; locale = "ru"; arch = "linux-i686"; sha256 = "09e176ce5b1fdc83011ee13656a16f05ac001b37b312c60499ed125a7d0045d8"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/sk/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/sk/thunderbird-128.5.0esr.tar.bz2"; locale = "sk"; arch = "linux-i686"; sha256 = "d92580dc8af74dc6f8e42f83816d5f673023bf3c99d111e4db209169120844e7"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/sl/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/sl/thunderbird-128.5.0esr.tar.bz2"; locale = "sl"; arch = "linux-i686"; sha256 = "9a7a336d20a67550a29820d0971c35b9ea094a725bc31322570ed87c3d0c6df6"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/sq/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/sq/thunderbird-128.5.0esr.tar.bz2"; locale = "sq"; arch = "linux-i686"; sha256 = "4b30e60ddd89e203f43c229e8a068f9168d4950f28872b3718526bf1cec96fee"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/sr/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/sr/thunderbird-128.5.0esr.tar.bz2"; locale = "sr"; arch = "linux-i686"; sha256 = "cf81a4717f8711b3271c3885d30307ed21096d5c75cd350d7c147df14758e49c"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/sv-SE/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/sv-SE/thunderbird-128.5.0esr.tar.bz2"; locale = "sv-SE"; arch = "linux-i686"; sha256 = "5fd223489a2547f1bd90c86ffd92ba3fab9ffca84830927d70b2d2d875d370f3"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/th/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/th/thunderbird-128.5.0esr.tar.bz2"; locale = "th"; arch = "linux-i686"; sha256 = "278b2051256b8d2185701ddce3ddded8db683295e1d8b28ae26c5f0aeb4c4dde"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/tr/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/tr/thunderbird-128.5.0esr.tar.bz2"; locale = "tr"; arch = "linux-i686"; sha256 = "36a716a4e38eedde49ab9632d32782fa244eed8091caa7a7acd4065c523994b5"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/uk/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/uk/thunderbird-128.5.0esr.tar.bz2"; locale = "uk"; arch = "linux-i686"; sha256 = "f3e32dcbde43f6f6cbf85da393d777b781022264897958b5bc31e5cb9b4dfa74"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/uz/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/uz/thunderbird-128.5.0esr.tar.bz2"; locale = "uz"; arch = "linux-i686"; sha256 = "4bf7147f7b81a06bf8768cc765dd8a18689ae275d802cfe21da31a80edff0dbc"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/vi/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/vi/thunderbird-128.5.0esr.tar.bz2"; locale = "vi"; arch = "linux-i686"; sha256 = "50446ba6696a84faaedda2d2f8e733c37410ac6d94f74f6634a9f3bacee326cd"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/zh-CN/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/zh-CN/thunderbird-128.5.0esr.tar.bz2"; locale = "zh-CN"; arch = "linux-i686"; sha256 = "f1bf08a735a7d6aab3a732be36ad5d37c880673a268feb4272d82b3beef48b04"; } - { url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/zh-TW/thunderbird-128.5.0esr.tar.bz2"; + { + url = "http://archive.mozilla.org/pub/thunderbird/releases/128.5.0esr/linux-i686/zh-TW/thunderbird-128.5.0esr.tar.bz2"; locale = "zh-TW"; arch = "linux-i686"; sha256 = "523cab1dac4989ea47a3432d3d99bb467f9e1e71e90a9c0069c81eb9c8ff946e"; } - ]; + ]; } diff --git a/pkgs/applications/networking/mailreaders/thunderbird/packages.nix b/pkgs/applications/networking/mailreaders/thunderbird/packages.nix index f57484428cd056..afc227e45991a7 100644 --- a/pkgs/applications/networking/mailreaders/thunderbird/packages.nix +++ b/pkgs/applications/networking/mailreaders/thunderbird/packages.nix @@ -1,57 +1,81 @@ -{ stdenv, lib, buildMozillaMach, callPackage, fetchurl, icu73, fetchpatch2, config }: +{ + stdenv, + lib, + buildMozillaMach, + callPackage, + fetchurl, + icu73, + fetchpatch2, + config, +}: let icu73' = icu73.overrideAttrs (attrs: { # standardize vtzone output # Work around ICU-22132 https://unicode-org.atlassian.net/browse/ICU-22132 # https://bugzilla.mozilla.org/show_bug.cgi?id=1790071 - patches = attrs.patches ++ [(fetchpatch2 { - url = "https://hg.mozilla.org/mozilla-central/raw-file/fb8582f80c558000436922fb37572adcd4efeafc/intl/icu-patches/bug-1790071-ICU-22132-standardize-vtzone-output.diff"; - stripLen = 3; - hash = "sha256-MGNnWix+kDNtLuACrrONDNcFxzjlUcLhesxwVZFzPAM="; - })]; + patches = attrs.patches ++ [ + (fetchpatch2 { + url = "https://hg.mozilla.org/mozilla-central/raw-file/fb8582f80c558000436922fb37572adcd4efeafc/intl/icu-patches/bug-1790071-ICU-22132-standardize-vtzone-output.diff"; + stripLen = 3; + hash = "sha256-MGNnWix+kDNtLuACrrONDNcFxzjlUcLhesxwVZFzPAM="; + }) + ]; }); - common = { version, sha512, updateScript }: (buildMozillaMach rec { - pname = "thunderbird"; - inherit version updateScript; - application = "comm/mail"; - applicationName = "Mozilla Thunderbird"; - binaryName = pname; - src = fetchurl { - url = "mirror://mozilla/thunderbird/releases/${version}/source/thunderbird-${version}.source.tar.xz"; - inherit sha512; - }; - extraPatches = [ - # The file to be patched is different from firefox's `no-buildconfig-ffx90.patch`. - ./no-buildconfig.patch - ]; + common = + { + version, + sha512, + updateScript, + }: + (buildMozillaMach rec { + pname = "thunderbird"; + inherit version updateScript; + application = "comm/mail"; + applicationName = "Mozilla Thunderbird"; + binaryName = pname; + src = fetchurl { + url = "mirror://mozilla/thunderbird/releases/${version}/source/thunderbird-${version}.source.tar.xz"; + inherit sha512; + }; + extraPatches = [ + # The file to be patched is different from firefox's `no-buildconfig-ffx90.patch`. + ./no-buildconfig.patch + ]; - extraPassthru = { - icu73 = icu73'; - }; + extraPassthru = { + icu73 = icu73'; + }; - meta = with lib; { - changelog = "https://www.thunderbird.net/en-US/thunderbird/${version}/releasenotes/"; - description = "Full-featured e-mail client"; - homepage = "https://thunderbird.net/"; - mainProgram = "thunderbird"; - maintainers = with maintainers; [ lovesegfault pierron vcunat ]; - platforms = platforms.unix; - broken = stdenv.buildPlatform.is32bit; # since Firefox 60, build on 32-bit platforms fails with "out of memory". - # not in `badPlatforms` because cross-compilation on 64-bit machine might work. - license = licenses.mpl20; - }; - }).override { - geolocationSupport = false; - webrtcSupport = false; + meta = with lib; { + changelog = "https://www.thunderbird.net/en-US/thunderbird/${version}/releasenotes/"; + description = "Full-featured e-mail client"; + homepage = "https://thunderbird.net/"; + mainProgram = "thunderbird"; + maintainers = with maintainers; [ + lovesegfault + pierron + vcunat + ]; + platforms = platforms.unix; + broken = stdenv.buildPlatform.is32bit; + # since Firefox 60, build on 32-bit platforms fails with "out of memory". + # not in `badPlatforms` because cross-compilation on 64-bit machine might work. + license = licenses.mpl20; + }; + }).override + { + geolocationSupport = false; + webrtcSupport = false; - pgoSupport = false; # console.warn: feeds: "downloadFeed: network connection unavailable" + pgoSupport = false; # console.warn: feeds: "downloadFeed: network connection unavailable" - icu73 = icu73'; - }; + icu73 = icu73'; + }; -in rec { +in +rec { # Upstream claims -latest is "for testing purposes only". Stick to -esr until this changes. thunderbird = thunderbird-esr; @@ -78,8 +102,7 @@ in rec { }; }; } - // lib.optionalAttrs config.allowAliases { +// lib.optionalAttrs config.allowAliases { thunderbird-102 = throw "Thunderbird 102 support ended in September 2023"; thunderbird-115 = throw "Thunderbird 115 support ended in October 2024"; } - diff --git a/pkgs/applications/networking/mailreaders/thunderbird/update.nix b/pkgs/applications/networking/mailreaders/thunderbird/update.nix index c7f2e0511d2416..e584a88b703097 100644 --- a/pkgs/applications/networking/mailreaders/thunderbird/update.nix +++ b/pkgs/applications/networking/mailreaders/thunderbird/update.nix @@ -1,7 +1,11 @@ -{ callPackage -, ... +{ + callPackage, + ... }@args: -callPackage ../../browsers/firefox/update.nix ({ - baseUrl = "https://archive.mozilla.org/pub/thunderbird/releases/"; -} // (builtins.removeAttrs args ["callPackage"])) +callPackage ../../browsers/firefox/update.nix ( + { + baseUrl = "https://archive.mozilla.org/pub/thunderbird/releases/"; + } + // (builtins.removeAttrs args [ "callPackage" ]) +) diff --git a/pkgs/applications/networking/mailreaders/thunderbird/wrapper.nix b/pkgs/applications/networking/mailreaders/thunderbird/wrapper.nix index bb135568fdb5a2..e623d3ac6141fc 100644 --- a/pkgs/applications/networking/mailreaders/thunderbird/wrapper.nix +++ b/pkgs/applications/networking/mailreaders/thunderbird/wrapper.nix @@ -1,23 +1,33 @@ -{ lib, wrapFirefox, gpgme, gnupg }: +{ + lib, + wrapFirefox, + gpgme, + gnupg, +}: -browser: -args: +browser: args: -(wrapFirefox browser ({ - libName = "thunderbird"; -} // args)) +(wrapFirefox browser ( + { + libName = "thunderbird"; + } + // args +)) -.overrideAttrs (old: { - # Thunderbird's native GPG support does not yet support smartcards. - # The official upstream recommendation is to configure fall back to gnupg - # using the Thunderbird config `mail.openpgp.allow_external_gnupg` - # and GPG keys set up; instructions with pictures at: - # https://anweshadas.in/how-to-use-yubikey-or-any-gpg-smartcard-in-thunderbird-78/ - # For that to work out of the box, it requires `gnupg` on PATH and - # `gpgme` in `LD_LIBRARY_PATH`; we do this below. - buildCommand = old.buildCommand + '' - wrapProgram $out/bin/${browser.binaryName} \ - --prefix LD_LIBRARY_PATH ':' "${lib.makeLibraryPath [ gpgme ]}" \ - --prefix PATH ':' "${lib.makeBinPath [ gnupg ]}" - ''; -}) +.overrideAttrs + (old: { + # Thunderbird's native GPG support does not yet support smartcards. + # The official upstream recommendation is to configure fall back to gnupg + # using the Thunderbird config `mail.openpgp.allow_external_gnupg` + # and GPG keys set up; instructions with pictures at: + # https://anweshadas.in/how-to-use-yubikey-or-any-gpg-smartcard-in-thunderbird-78/ + # For that to work out of the box, it requires `gnupg` on PATH and + # `gpgme` in `LD_LIBRARY_PATH`; we do this below. + buildCommand = + old.buildCommand + + '' + wrapProgram $out/bin/${browser.binaryName} \ + --prefix LD_LIBRARY_PATH ':' "${lib.makeLibraryPath [ gpgme ]}" \ + --prefix PATH ':' "${lib.makeBinPath [ gnupg ]}" + ''; + }) diff --git a/pkgs/applications/networking/mailreaders/trojita/default.nix b/pkgs/applications/networking/mailreaders/trojita/default.nix index 8015484d704357..685d78b0f50b80 100644 --- a/pkgs/applications/networking/mailreaders/trojita/default.nix +++ b/pkgs/applications/networking/mailreaders/trojita/default.nix @@ -1,22 +1,23 @@ -{ akonadi-contacts -, cmake -, fetchFromGitLab -, fetchsvn -, gnupg -, gpgme -, kcontacts -, kf5gpgmepp -, lib -, libsecret -, mimetic -, mkDerivation -, pkg-config -, qgpgme -, qtbase -, qtkeychain -, qttools -, qtwebkit -, withI18n ? false +{ + akonadi-contacts, + cmake, + fetchFromGitLab, + fetchsvn, + gnupg, + gpgme, + kcontacts, + kf5gpgmepp, + lib, + libsecret, + mimetic, + mkDerivation, + pkg-config, + qgpgme, + qtbase, + qtkeychain, + qttools, + qtwebkit, + withI18n ? false, }: let @@ -25,7 +26,8 @@ let rev = "1566642"; sha256 = "0y45fjib153za085la3hqpryycx33dkj3cz8kwzn2w31kvldfl1q"; }; -in mkDerivation rec { +in +mkDerivation rec { pname = "trojita"; version = "unstable-2022-08-22"; @@ -58,18 +60,22 @@ in mkDerivation rec { gnupg ]; - postPatch = "echo ${version} > src/trojita-version" + postPatch = + "echo ${version} > src/trojita-version" + lib.optionalString withI18n '' - mkdir -p po - for f in `find ${l10n} -name "trojita_common.po"`; do - cp $f po/trojita_common_$(echo $f | cut -d/ -f5).po - done - ''; + mkdir -p po + for f in `find ${l10n} -name "trojita_common.po"`; do + cp $f po/trojita_common_$(echo $f | cut -d/ -f5).po + done + ''; meta = with lib; { description = "Qt IMAP e-mail client"; homepage = "http://trojita.flaska.net/"; - license = with licenses; [ gpl2 gpl3 ]; + license = with licenses; [ + gpl2 + gpl3 + ]; maintainers = with maintainers; [ ehmry ]; platforms = platforms.linux; }; diff --git a/pkgs/applications/networking/mhost/default.nix b/pkgs/applications/networking/mhost/default.nix index 777ea44dc7bdbf..145a68bbfc7673 100644 --- a/pkgs/applications/networking/mhost/default.nix +++ b/pkgs/applications/networking/mhost/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Security, SystemConfiguration }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, + SystemConfiguration, +}: rustPlatform.buildRustPackage rec { pname = "mhost"; @@ -25,7 +32,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Modern take on the classic host DNS lookup utility including an easy to use and very fast Rust lookup library"; homepage = "https://github.com/lukaspustina/mhost"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = [ maintainers.mgttlinger ]; mainProgram = "mhost"; }; diff --git a/pkgs/applications/networking/mkchromecast/default.nix b/pkgs/applications/networking/mkchromecast/default.nix index b0df1210b318bf..e431ad81b6af42 100644 --- a/pkgs/applications/networking/mkchromecast/default.nix +++ b/pkgs/applications/networking/mkchromecast/default.nix @@ -1,31 +1,34 @@ -{ lib, stdenv -, fetchFromGitHub -, python3Packages -, sox -, flac -, lame -, wrapQtAppsHook -, ffmpeg -, vorbis-tools -, pulseaudio -, nodejs -, youtube-dl -, opusTools -, gst_all_1 -, enableSonos ? true -, qtwayland +{ + lib, + stdenv, + fetchFromGitHub, + python3Packages, + sox, + flac, + lame, + wrapQtAppsHook, + ffmpeg, + vorbis-tools, + pulseaudio, + nodejs, + youtube-dl, + opusTools, + gst_all_1, + enableSonos ? true, + qtwayland, }: -let packages = [ - vorbis-tools - sox - flac - lame - opusTools - gst_all_1.gstreamer - nodejs - ffmpeg - youtube-dl -] ++ lib.optionals stdenv.hostPlatform.isLinux [ pulseaudio ]; +let + packages = [ + vorbis-tools + sox + flac + lame + opusTools + gst_all_1.gstreamer + nodejs + ffmpeg + youtube-dl + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ pulseaudio ]; in python3Packages.buildPythonApplication { @@ -40,15 +43,20 @@ python3Packages.buildPythonApplication { }; buildInputs = lib.optional stdenv.hostPlatform.isLinux qtwayland; - propagatedBuildInputs = with python3Packages; ([ - pychromecast - psutil - mutagen - flask - netifaces - requests - pyqt5 - ] ++ lib.optionals enableSonos [ soco ]); + propagatedBuildInputs = + with python3Packages; + ( + [ + pychromecast + psutil + mutagen + flask + netifaces + requests + pyqt5 + ] + ++ lib.optionals enableSonos [ soco ] + ); postPatch = '' substituteInPlace setup.py \ @@ -69,14 +77,16 @@ python3Packages.buildPythonApplication { "--prefix PATH : ${lib.makeBinPath packages}" ]; - postInstall = '' - substituteInPlace $out/${python3Packages.python.sitePackages}/mkchromecast/video.py \ - --replace '/usr/share/mkchromecast/nodejs/' '${placeholder "out"}/share/mkchromecast/nodejs/' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install -Dm 755 -t $out/bin bin/audiodevice - substituteInPlace $out/${python3Packages.python.sitePackages}/mkchromecast/audio_devices.py \ - --replace './bin/audiodevice' '${placeholder "out"}/bin/audiodevice' - ''; + postInstall = + '' + substituteInPlace $out/${python3Packages.python.sitePackages}/mkchromecast/video.py \ + --replace '/usr/share/mkchromecast/nodejs/' '${placeholder "out"}/share/mkchromecast/nodejs/' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install -Dm 755 -t $out/bin bin/audiodevice + substituteInPlace $out/${python3Packages.python.sitePackages}/mkchromecast/audio_devices.py \ + --replace './bin/audiodevice' '${placeholder "out"}/bin/audiodevice' + ''; meta = with lib; { homepage = "https://mkchromecast.com/"; diff --git a/pkgs/applications/networking/mpop/default.nix b/pkgs/applications/networking/mpop/default.nix index 5e41ef5d2a91ae..c0fab98d6102ed 100644 --- a/pkgs/applications/networking/mpop/default.nix +++ b/pkgs/applications/networking/mpop/default.nix @@ -1,18 +1,23 @@ -{ lib -, stdenv -, fetchurl -, gnutls -, openssl -, gsasl -, libidn -, pkg-config -, Security -, nlsSupport ? true -, idnSupport ? true -, gsaslSupport ? true -, sslLibrary ? "gnutls" +{ + lib, + stdenv, + fetchurl, + gnutls, + openssl, + gsasl, + libidn, + pkg-config, + Security, + nlsSupport ? true, + idnSupport ? true, + gsaslSupport ? true, + sslLibrary ? "gnutls", }: -assert lib.assertOneOf "sslLibrary" sslLibrary ["gnutls" "openssl" "no"]; +assert lib.assertOneOf "sslLibrary" sslLibrary [ + "gnutls" + "openssl" + "no" +]; stdenv.mkDerivation rec { pname = "mpop"; @@ -41,7 +46,7 @@ stdenv.mkDerivation rec { "--with-tls=${sslLibrary}" ] ++ lib.optional stdenv.hostPlatform.isDarwin "--with-macosx-keyring"; - meta = with lib;{ + meta = with lib; { description = "POP3 mail retrieval agent"; homepage = "https://marlam.de/mpop"; license = licenses.gpl3Plus; diff --git a/pkgs/applications/networking/mujmap/default.nix b/pkgs/applications/networking/mujmap/default.nix index 8ee04ef19607a1..b522e29370e5f4 100644 --- a/pkgs/applications/networking/mujmap/default.nix +++ b/pkgs/applications/networking/mujmap/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, notmuch -, stdenv -, Security +{ + lib, + fetchFromGitHub, + rustPlatform, + notmuch, + stdenv, + Security, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/applications/networking/mullvad/default.nix b/pkgs/applications/networking/mullvad/default.nix index 7b4bcf9d61b25d..7c987f4b025a78 100644 --- a/pkgs/applications/networking/mullvad/default.nix +++ b/pkgs/applications/networking/mullvad/default.nix @@ -1,5 +1,6 @@ -{ lib -, newScope +{ + lib, + newScope, }: lib.makeScope newScope (self: { libwg = self.callPackage ./libwg.nix { }; diff --git a/pkgs/applications/networking/mullvad/libwg.nix b/pkgs/applications/networking/mullvad/libwg.nix index 12e6c1deccc3aa..a5bcc68b544d56 100644 --- a/pkgs/applications/networking/mullvad/libwg.nix +++ b/pkgs/applications/networking/mullvad/libwg.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, mullvad +{ + lib, + buildGoModule, + mullvad, }: buildGoModule { pname = "libwg"; @@ -21,7 +22,11 @@ buildGoModule { GOBIN = "${placeholder "out"}/lib"; subPackages = [ "." ]; - ldflags = [ "-s" "-w" "-buildmode=c-archive" ]; + ldflags = [ + "-s" + "-w" + "-buildmode=c-archive" + ]; tags = [ "daita" ]; postInstall = '' diff --git a/pkgs/applications/networking/mullvad/openvpn.nix b/pkgs/applications/networking/mullvad/openvpn.nix index af2a2d2e494e9f..b62ce2d5edeeda 100644 --- a/pkgs/applications/networking/mullvad/openvpn.nix +++ b/pkgs/applications/networking/mullvad/openvpn.nix @@ -1,20 +1,24 @@ -{ lib -, stdenv -, openvpn -, fetchpatch -, fetchurl -, libnl -, autoreconfHook -, pkg-config +{ + lib, + stdenv, + openvpn, + fetchpatch, + fetchurl, + libnl, + autoreconfHook, + pkg-config, }: -openvpn.overrideAttrs (oldAttrs: +openvpn.overrideAttrs ( + oldAttrs: let inherit (lib) optional; - fetchMullvadPatch = { commit, sha256 }: fetchpatch { - url = "https://github.com/mullvad/openvpn/commit/${commit}.patch"; - inherit sha256; - }; + fetchMullvadPatch = + { commit, sha256 }: + fetchpatch { + url = "https://github.com/mullvad/openvpn/commit/${commit}.patch"; + inherit sha256; + }; in rec { pname = "openvpn-mullvad"; @@ -30,33 +34,33 @@ openvpn.overrideAttrs (oldAttrs: pkg-config ]; - buildInputs = oldAttrs.buildInputs or [ ] - ++ optional stdenv.hostPlatform.isLinux [ libnl.dev ]; + buildInputs = oldAttrs.buildInputs or [ ] ++ optional stdenv.hostPlatform.isLinux [ libnl.dev ]; - configureFlags = [ - # Assignement instead of appending to make sure to use exactly the flags required by mullvad + configureFlags = + [ + # Assignement instead of appending to make sure to use exactly the flags required by mullvad - # Flags are based on https://github.com/mullvad/mullvadvpn-app-binaries/blob/main/Makefile#L17 - "--enable-static" - "--disable-shared" - "--disable-debug" - "--disable-plugin-down-root" - "--disable-management" - "--disable-port-share" - "--disable-systemd" - "--disable-dependency-tracking" - "--disable-pkcs11" - "--disable-plugin-auth-pam" - "--enable-plugins" - "--disable-lzo" - "--disable-lz4" - "--enable-comp-stub" - ] - ++ optional stdenv.hostPlatform.isLinux [ - # Flags are based on https://github.com/mullvad/mullvadvpn-app-binaries/blob/main/Makefile#L35 - "--enable-dco" # requires libnl - "--disable-iproute2" - ]; + # Flags are based on https://github.com/mullvad/mullvadvpn-app-binaries/blob/main/Makefile#L17 + "--enable-static" + "--disable-shared" + "--disable-debug" + "--disable-plugin-down-root" + "--disable-management" + "--disable-port-share" + "--disable-systemd" + "--disable-dependency-tracking" + "--disable-pkcs11" + "--disable-plugin-auth-pam" + "--enable-plugins" + "--disable-lzo" + "--disable-lz4" + "--enable-comp-stub" + ] + ++ optional stdenv.hostPlatform.isLinux [ + # Flags are based on https://github.com/mullvad/mullvadvpn-app-binaries/blob/main/Makefile#L35 + "--enable-dco" # requires libnl + "--disable-iproute2" + ]; patches = oldAttrs.patches or [ ] ++ [ # look at compare to find the relevant commits @@ -99,13 +103,16 @@ openvpn.overrideAttrs (oldAttrs: sha256 = "sha256-Via62wKVfMWHTmO7xIXXO7b5k0KYHs1D0JVg3qnXkeM="; }) ]; - postPatch = oldAttrs.postPatch or "" + '' - rm ./configure - ''; + postPatch = + oldAttrs.postPatch or "" + + '' + rm ./configure + ''; meta = oldAttrs.meta or { } // { description = "OpenVPN with Mullvad-specific patches applied"; homepage = "https://github.com/mullvad/openvpn"; maintainers = with lib; [ maintainers.cole-h ]; }; - }) + } +) diff --git a/pkgs/applications/networking/netmaker/default.nix b/pkgs/applications/networking/netmaker/default.nix index 1a4edc965a7f5d..2cd84673364076 100644 --- a/pkgs/applications/networking/netmaker/default.nix +++ b/pkgs/applications/networking/netmaker/default.nix @@ -1,10 +1,14 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, libglvnd -, pkg-config -, subPackages ? ["." "netclient"] -, xorg +{ + buildGoModule, + fetchFromGitHub, + lib, + libglvnd, + pkg-config, + subPackages ? [ + "." + "netclient" + ], + xorg, }: buildGoModule rec { @@ -38,7 +42,10 @@ buildGoModule rec { homepage = "https://netmaker.io"; changelog = "https://github.com/gravitl/netmaker/-/releases/v${version}"; license = licenses.asl20; - maintainers = with maintainers; [ urandom qjoly ]; + maintainers = with maintainers; [ + urandom + qjoly + ]; mainProgram = "netmaker"; }; } diff --git a/pkgs/applications/networking/newsreaders/quiterss/default.nix b/pkgs/applications/networking/newsreaders/quiterss/default.nix index f9266db68917b4..1adc5d981b871b 100644 --- a/pkgs/applications/networking/newsreaders/quiterss/default.nix +++ b/pkgs/applications/networking/newsreaders/quiterss/default.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, qmake, pkg-config, wrapQtAppsHook -, qtbase, qttools, qtwebkit, sqlite +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + pkg-config, + wrapQtAppsHook, + qtbase, + qttools, + qtwebkit, + sqlite, }: stdenv.mkDerivation rec { @@ -13,8 +22,17 @@ stdenv.mkDerivation rec { sha256 = "1cgvl67vhn5y7bj5gbjbgk26bhb0196bgrgsp3r5fmrislarj8s6"; }; - nativeBuildInputs = [ qmake pkg-config wrapQtAppsHook ]; - buildInputs = [ qtbase qttools qtwebkit sqlite.dev ]; + nativeBuildInputs = [ + qmake + pkg-config + wrapQtAppsHook + ]; + buildInputs = [ + qtbase + qttools + qtwebkit + sqlite.dev + ]; meta = with lib; { description = "Qt-based RSS/Atom news feed reader"; diff --git a/pkgs/applications/networking/ostinato/default.nix b/pkgs/applications/networking/ostinato/default.nix index ef67028087812e..5ae05c37776e42 100644 --- a/pkgs/applications/networking/ostinato/default.nix +++ b/pkgs/applications/networking/ostinato/default.nix @@ -1,17 +1,30 @@ -{ lib, mkDerivation, fetchFromGitHub, fetchurl, qmake, makeDesktopItem -, qtbase, qtscript, protobuf, libpcap, wireshark, gzip, diffutils, gawk -, libnl -, copyDesktopItems +{ + lib, + mkDerivation, + fetchFromGitHub, + fetchurl, + qmake, + makeDesktopItem, + qtbase, + qtscript, + protobuf, + libpcap, + wireshark, + gzip, + diffutils, + gawk, + libnl, + copyDesktopItems, }: mkDerivation rec { pname = "ostinato"; version = "1.3.0"; - src = fetchFromGitHub { - owner = "pstavirs"; - repo = "ostinato"; - rev = "v${version}"; + src = fetchFromGitHub { + owner = "pstavirs"; + repo = "ostinato"; + rev = "v${version}"; sha256 = "sha256-/fPUxGeh5Cc3rb+1mR0chkiFPw5m+O6KtWDvzLn0iYo="; }; @@ -20,7 +33,13 @@ mkDerivation rec { sha256 = "f5c067823f2934e4d358d76f65a343efd69ad783a7aeabd7ab4ce3cd03490d70"; }; - buildInputs = [ qtbase protobuf libpcap qtscript libnl ]; + buildInputs = [ + qtbase + protobuf + libpcap + qtscript + libnl + ]; nativeBuildInputs = [ copyDesktopItems @@ -33,17 +52,17 @@ mkDerivation rec { ''; desktopItems = lib.singleton (makeDesktopItem { - name = "ostinato"; - desktopName = "Ostinato"; - genericName = "Packet/Traffic Generator and Analyzer"; - comment = "Network packet and traffic generator and analyzer with a friendly GUI"; - categories = [ "Network" ]; + name = "ostinato"; + desktopName = "Ostinato"; + genericName = "Packet/Traffic Generator and Analyzer"; + comment = "Network packet and traffic generator and analyzer with a friendly GUI"; + categories = [ "Network" ]; startupNotify = true; - exec = "@out@/bin/ostinato"; - icon = ostinatoIcon; - extraConfig = { + exec = "@out@/bin/ostinato"; + icon = ostinatoIcon; + extraConfig = { "GenericName[it]" = "Generatore ed Analizzatore di pacchetti di rete"; - "Comment[it]" = "Generatore ed Analizzatore di pacchetti di rete con interfaccia amichevole"; + "Comment[it]" = "Generatore ed Analizzatore di pacchetti di rete con interfaccia amichevole"; }; }); @@ -66,9 +85,9 @@ mkDerivation rec { meta = with lib; { description = "Packet traffic generator and analyzer"; - homepage = "https://ostinato.org/"; - license = licenses.gpl3Plus; + homepage = "https://ostinato.org/"; + license = licenses.gpl3Plus; maintainers = with maintainers; [ rick68 ]; - platforms = with platforms; linux ++ darwin ++ cygwin; + platforms = with platforms; linux ++ darwin ++ cygwin; }; } diff --git a/pkgs/applications/networking/p2p/deluge/default.nix b/pkgs/applications/networking/p2p/deluge/default.nix index 241f2a02e80335..99309c0a0989ad 100644 --- a/pkgs/applications/networking/p2p/deluge/default.nix +++ b/pkgs/applications/networking/p2p/deluge/default.nix @@ -1,14 +1,15 @@ -{ lib -, fetchurl -, intltool -, libtorrent-rasterbar -, python3Packages -, gtk3 -, glib -, gobject-introspection -, librsvg -, wrapGAppsHook3 -, nixosTests +{ + lib, + fetchurl, + intltool, + libtorrent-rasterbar, + python3Packages, + gtk3, + glib, + gobject-introspection, + librsvg, + wrapGAppsHook3, + nixosTests, }: let @@ -16,7 +17,8 @@ let pypkgs = python3Packages; - generic = { pname, withGUI }: + generic = + { pname, withGUI }: pypkgs.buildPythonPackage rec { inherit pname; version = "2.1.1"; @@ -26,37 +28,42 @@ let hash = "sha256-do3TGYAuQkN6s3lOvnW0lxQuCO1bD7JQO61izvRC3/c="; }; - propagatedBuildInputs = with pypkgs; [ - twisted - mako - chardet - pyxdg - pyopenssl - service-identity - libtorrent-rasterbar.dev - libtorrent-rasterbar.python - setuptools - setproctitle - pillow - rencode - six - zope-interface - dbus-python - pycairo - librsvg - ] ++ optionals withGUI [ - gtk3 - gobject-introspection - pygobject3 - ]; + propagatedBuildInputs = + with pypkgs; + [ + twisted + mako + chardet + pyxdg + pyopenssl + service-identity + libtorrent-rasterbar.dev + libtorrent-rasterbar.python + setuptools + setproctitle + pillow + rencode + six + zope-interface + dbus-python + pycairo + librsvg + ] + ++ optionals withGUI [ + gtk3 + gobject-introspection + pygobject3 + ]; - nativeBuildInputs = [ - intltool - glib - ] ++ optionals withGUI [ - gobject-introspection - wrapGAppsHook3 - ]; + nativeBuildInputs = + [ + intltool + glib + ] + ++ optionals withGUI [ + gobject-introspection + wrapGAppsHook3 + ]; nativeCheckInputs = with pypkgs; [ pytestCheckHook @@ -69,18 +76,24 @@ let doCheck = false; # tests are not working at all - postInstall = '' - install -Dm444 -t $out/lib/systemd/system packaging/systemd/*.service - '' + (if withGUI - then '' - mkdir -p $out/share - cp -R deluge/ui/data/{icons,pixmaps} $out/share/ - install -Dm444 -t $out/share/applications deluge/ui/data/share/applications/deluge.desktop - '' else '' - rm -r $out/bin/deluge-gtk - rm -r $out/${python3Packages.python.sitePackages}/deluge/ui/gtk3 - rm -r $out/share/{icons,man/man1/deluge-gtk*,pixmaps} - ''); + postInstall = + '' + install -Dm444 -t $out/lib/systemd/system packaging/systemd/*.service + '' + + ( + if withGUI then + '' + mkdir -p $out/share + cp -R deluge/ui/data/{icons,pixmaps} $out/share/ + install -Dm444 -t $out/share/applications deluge/ui/data/share/applications/deluge.desktop + '' + else + '' + rm -r $out/bin/deluge-gtk + rm -r $out/${python3Packages.python.sitePackages}/deluge/ui/gtk3 + rm -r $out/share/{icons,man/man1/deluge-gtk*,pixmaps} + '' + ); postFixup = '' for f in $out/lib/systemd/system/*; do @@ -94,14 +107,23 @@ let description = "Torrent client"; homepage = "https://deluge-torrent.org"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ domenkozar ebzzry ]; + maintainers = with maintainers; [ + domenkozar + ebzzry + ]; platforms = platforms.all; }; }; in rec { - deluge-gtk = generic { pname = "deluge-gtk"; withGUI = true; }; - deluged = generic { pname = "deluged"; withGUI = false; }; + deluge-gtk = generic { + pname = "deluge-gtk"; + withGUI = true; + }; + deluged = generic { + pname = "deluged"; + withGUI = false; + }; deluge = deluge-gtk; } diff --git a/pkgs/applications/networking/p2p/eiskaltdcpp/default.nix b/pkgs/applications/networking/p2p/eiskaltdcpp/default.nix index 61501dbeb20e9f..5b122cc3fe5580 100644 --- a/pkgs/applications/networking/p2p/eiskaltdcpp/default.nix +++ b/pkgs/applications/networking/p2p/eiskaltdcpp/default.nix @@ -1,6 +1,26 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch2, cmake, pkg-config, bzip2, libX11 -, mkDerivation, qtbase, qttools, qtmultimedia, qtscript -, libiconv, pcre-cpp, libidn, lua5, miniupnpc, aspell, gettext, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch2, + cmake, + pkg-config, + bzip2, + libX11, + mkDerivation, + qtbase, + qttools, + qtmultimedia, + qtscript, + libiconv, + pcre-cpp, + libidn, + lua5, + miniupnpc, + aspell, + gettext, + perl, +}: mkDerivation rec { pname = "eiskaltdcpp"; @@ -20,13 +40,30 @@ mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ qtbase qttools qtmultimedia qtscript bzip2 libX11 pcre-cpp libidn lua5 miniupnpc aspell gettext - (perl.withPackages (p: with p; [ - GetoptLong - TermShellUI - ])) ] - ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + qtbase + qttools + qtmultimedia + qtscript + bzip2 + libX11 + pcre-cpp + libidn + lua5 + miniupnpc + aspell + gettext + (perl.withPackages ( + p: with p; [ + GetoptLong + TermShellUI + ] + )) + ] ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; cmakeFlags = [ "-DDBUS_NOTIFY=ON" diff --git a/pkgs/applications/networking/p2p/frostwire/frostwire-bin.nix b/pkgs/applications/networking/p2p/frostwire/frostwire-bin.nix index d61ee7bb15ce84..ccc8aeceb8a350 100644 --- a/pkgs/applications/networking/p2p/frostwire/frostwire-bin.nix +++ b/pkgs/applications/networking/p2p/frostwire/frostwire-bin.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { version = "6.13.3"; @@ -42,6 +48,6 @@ stdenv.mkDerivation rec { ]; license = licenses.gpl3Plus; maintainers = with maintainers; [ gavin ]; - platforms = [ "x86_64-linux"]; + platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/applications/networking/p2p/gnunet/gtk.nix b/pkgs/applications/networking/p2p/gnunet/gtk.nix index 633a8da08778a8..95c1780256d7b8 100644 --- a/pkgs/applications/networking/p2p/gnunet/gtk.nix +++ b/pkgs/applications/networking/p2p/gnunet/gtk.nix @@ -1,14 +1,16 @@ -{ stdenv, fetchurl -, glade -, gnunet -, gnutls -, gtk3 -, libextractor -, libgcrypt -, libsodium -, libxml2 -, pkg-config -, wrapGAppsHook3 +{ + stdenv, + fetchurl, + glade, + gnunet, + gnutls, + gtk3, + libextractor, + libgcrypt, + libsodium, + libxml2, + pkg-config, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -20,7 +22,7 @@ stdenv.mkDerivation rec { hash = "sha256-vQFtKFI57YG64WpKVngx1kq687hI+f1kpP9ooK53/aw="; }; - nativeBuildInputs= [ + nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; diff --git a/pkgs/applications/networking/p2p/jesec-rtorrent/default.nix b/pkgs/applications/networking/p2p/jesec-rtorrent/default.nix index 883d995a0e02c7..78f804fc6bce4c 100644 --- a/pkgs/applications/networking/p2p/jesec-rtorrent/default.nix +++ b/pkgs/applications/networking/p2p/jesec-rtorrent/default.nix @@ -1,13 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, curl -, gtest -, libtorrent -, ncurses -, jsonRpcSupport ? true, nlohmann_json -, xmlRpcSupport ? true, xmlrpc_c +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + curl, + gtest, + libtorrent, + ncurses, + jsonRpcSupport ? true, + nlohmann_json, + xmlRpcSupport ? true, + xmlrpc_c, }: stdenv.mkDerivation rec { @@ -33,19 +36,21 @@ stdenv.mkDerivation rec { cmake ]; - buildInputs = [ - curl - libtorrent - ncurses - ] - ++ lib.optional jsonRpcSupport nlohmann_json - ++ lib.optional xmlRpcSupport xmlrpc_c; + buildInputs = + [ + curl + libtorrent + ncurses + ] + ++ lib.optional jsonRpcSupport nlohmann_json + ++ lib.optional xmlRpcSupport xmlrpc_c; - cmakeFlags = [ - "-DUSE_RUNTIME_CA_DETECTION=NO" - ] - ++ lib.optional (!jsonRpcSupport) "-DUSE_JSONRPC=NO" - ++ lib.optional (!xmlRpcSupport) "-DUSE_XMLRPC=NO"; + cmakeFlags = + [ + "-DUSE_RUNTIME_CA_DETECTION=NO" + ] + ++ lib.optional (!jsonRpcSupport) "-DUSE_JSONRPC=NO" + ++ lib.optional (!xmlRpcSupport) "-DUSE_XMLRPC=NO"; doCheck = true; diff --git a/pkgs/applications/networking/p2p/jesec-rtorrent/libtorrent.nix b/pkgs/applications/networking/p2p/jesec-rtorrent/libtorrent.nix index e267a059a289a1..50d250e7efe309 100644 --- a/pkgs/applications/networking/p2p/jesec-rtorrent/libtorrent.nix +++ b/pkgs/applications/networking/p2p/jesec-rtorrent/libtorrent.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gtest -, openssl -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gtest, + openssl, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/networking/p2p/libutp/3.4.nix b/pkgs/applications/networking/p2p/libutp/3.4.nix index fb853354308ca1..ae575bc8c396f1 100644 --- a/pkgs/applications/networking/p2p/libutp/3.4.nix +++ b/pkgs/applications/networking/p2p/libutp/3.4.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, cmake, unstableGitUpdater }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + unstableGitUpdater, +}: stdenv.mkDerivation rec { pname = "libutp"; diff --git a/pkgs/applications/networking/p2p/libutp/default.nix b/pkgs/applications/networking/p2p/libutp/default.nix index a07ffdea6b69dc..a9ba52e1b497d8 100644 --- a/pkgs/applications/networking/p2p/libutp/default.nix +++ b/pkgs/applications/networking/p2p/libutp/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, cmake }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "libutp"; diff --git a/pkgs/applications/networking/p2p/mldonkey/default.nix b/pkgs/applications/networking/p2p/mldonkey/default.nix index d83a33833b0bcd..1f144f9577e268 100644 --- a/pkgs/applications/networking/p2p/mldonkey/default.nix +++ b/pkgs/applications/networking/p2p/mldonkey/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, fetchpatch, ocamlPackages, zlib }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + ocamlPackages, + zlib, +}: stdenv.mkDerivation rec { pname = "mldonkey"; @@ -33,7 +40,10 @@ stdenv.mkDerivation rec { ''; strictDeps = true; - nativeBuildInputs = with ocamlPackages; [ ocaml camlp4 ]; + nativeBuildInputs = with ocamlPackages; [ + ocaml + camlp4 + ]; buildInputs = (with ocamlPackages; [ num ]) ++ [ zlib ]; meta = { diff --git a/pkgs/applications/networking/p2p/retroshare/default.nix b/pkgs/applications/networking/p2p/retroshare/default.nix index bbfc978eef5b02..1bc2b7db19c707 100644 --- a/pkgs/applications/networking/p2p/retroshare/default.nix +++ b/pkgs/applications/networking/p2p/retroshare/default.nix @@ -1,7 +1,24 @@ -{ lib, mkDerivation, fetchFromGitHub, fetchpatch2 -, qmake, cmake, pkg-config, miniupnpc, bzip2 -, speex, libmicrohttpd, libxml2, libxslt, sqlcipher, rapidjson, libXScrnSaver -, qtbase, qtx11extras, qtmultimedia, libgnome-keyring +{ + lib, + mkDerivation, + fetchFromGitHub, + fetchpatch2, + qmake, + cmake, + pkg-config, + miniupnpc, + bzip2, + speex, + libmicrohttpd, + libxml2, + libxslt, + sqlcipher, + rapidjson, + libXScrnSaver, + qtbase, + qtx11extras, + qtmultimedia, + libgnome-keyring, }: mkDerivation rec { @@ -30,10 +47,25 @@ mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config qmake cmake ]; + nativeBuildInputs = [ + pkg-config + qmake + cmake + ]; buildInputs = [ - speex miniupnpc qtmultimedia qtx11extras qtbase libgnome-keyring - bzip2 libXScrnSaver libxml2 libxslt sqlcipher libmicrohttpd rapidjson + speex + miniupnpc + qtmultimedia + qtx11extras + qtbase + libgnome-keyring + bzip2 + libXScrnSaver + libxml2 + libxslt + sqlcipher + libmicrohttpd + rapidjson ]; qmakeFlags = [ diff --git a/pkgs/applications/networking/p2p/soulseekqt/default.nix b/pkgs/applications/networking/p2p/soulseekqt/default.nix index 917012279eb6e9..2a7a3bb37e6a99 100644 --- a/pkgs/applications/networking/p2p/soulseekqt/default.nix +++ b/pkgs/applications/networking/p2p/soulseekqt/default.nix @@ -1,9 +1,13 @@ -{ stdenv, lib, fetchzip, mkDerivation -, appimageTools -, autoPatchelfHook -, desktop-file-utils -, imagemagick -, qtmultimedia +{ + stdenv, + lib, + fetchzip, + mkDerivation, + appimageTools, + autoPatchelfHook, + desktop-file-utils, + imagemagick, + qtmultimedia, }: mkDerivation rec { @@ -11,39 +15,46 @@ mkDerivation rec { version = "2018-1-30"; src = fetchzip { - url = "https://www.slsknet.org/SoulseekQt/Linux/SoulseekQt-${version}-64bit-appimage.tgz"; - sha256 = "16ncnvv8h33f161mgy7qc0wjvvqahsbwvby65qhgfh9pbbgb4xgg"; + url = "https://www.slsknet.org/SoulseekQt/Linux/SoulseekQt-${version}-64bit-appimage.tgz"; + sha256 = "16ncnvv8h33f161mgy7qc0wjvvqahsbwvby65qhgfh9pbbgb4xgg"; }; appextracted = appimageTools.extractType2 { inherit pname version; - src="${src}/SoulseekQt-2018-1-30-64bit.AppImage"; + src = "${src}/SoulseekQt-2018-1-30-64bit.AppImage"; }; dontBuild = true; dontConfigure = true; - nativeBuildInputs = [ imagemagick autoPatchelfHook desktop-file-utils ]; - buildInputs = [ qtmultimedia stdenv.cc.cc ]; + nativeBuildInputs = [ + imagemagick + autoPatchelfHook + desktop-file-utils + ]; + buildInputs = [ + qtmultimedia + stdenv.cc.cc + ]; installPhase = '' - binary="$(realpath ${appextracted}/AppRun)" - install -Dm755 $binary -t $out/bin - - # fixup and install desktop file - desktop-file-install --dir $out/share/applications \ - --set-key Exec --set-value SoulseekQt \ - --set-key Terminal --set-value false \ - --set-key Comment --set-value "${meta.description}" \ - --set-key Categories --set-value Network ${appextracted}/default.desktop - mv $out/share/applications/default.desktop $out/share/applications/SoulseekQt.desktop - #TODO: write generic code to read icon path from $binary.desktop - icon="$(realpath ${appextracted}/.DirIcon)" - for size in 16 32 48 64 72 96 128 192 256 512 1024; do - mkdir -p $out/share/icons/hicolor/"$size"x"$size"/apps - convert -resize "$size"x"$size" $icon $out/share/icons/hicolor/"$size"x"$size"/apps/$(basename $icon) - done - ''; + binary="$(realpath ${appextracted}/AppRun)" + install -Dm755 $binary -t $out/bin + + # fixup and install desktop file + desktop-file-install --dir $out/share/applications \ + --set-key Exec --set-value SoulseekQt \ + --set-key Terminal --set-value false \ + --set-key Comment --set-value "${meta.description}" \ + --set-key Categories --set-value Network ${appextracted}/default.desktop + mv $out/share/applications/default.desktop $out/share/applications/SoulseekQt.desktop + #TODO: write generic code to read icon path from $binary.desktop + icon="$(realpath ${appextracted}/.DirIcon)" + for size in 16 32 48 64 72 96 128 192 256 512 1024; do + mkdir -p $out/share/icons/hicolor/"$size"x"$size"/apps + convert -resize "$size"x"$size" $icon $out/share/icons/hicolor/"$size"x"$size"/apps/$(basename $icon) + done + ''; meta = with lib; { description = "Official Qt SoulSeek client"; diff --git a/pkgs/applications/networking/p2p/synapse-bt/default.nix b/pkgs/applications/networking/p2p/synapse-bt/default.nix index 120afed45de6a6..ba0200066918d4 100644 --- a/pkgs/applications/networking/p2p/synapse-bt/default.nix +++ b/pkgs/applications/networking/p2p/synapse-bt/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, pkg-config, openssl, CoreServices, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + CoreServices, + Security, +}: rustPlatform.buildRustPackage rec { pname = "synapse-bt"; @@ -14,8 +23,12 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-TwXouPYM7Hg1HEr2KnEPScYFkC52PcQ5kb5aGP1gj9U="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices Security ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + Security + ]; cargoBuildFlags = [ "--all" ]; diff --git a/pkgs/applications/networking/p2p/transmission/4.nix b/pkgs/applications/networking/p2p/transmission/4.nix index 900fd4a3974b1f..45dcb717f2b8ce 100644 --- a/pkgs/applications/networking/p2p/transmission/4.nix +++ b/pkgs/applications/networking/p2p/transmission/4.nix @@ -1,61 +1,64 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch2 -, cmake -, pkg-config -, python3 -, openssl -, curl -, libevent -, inotify-tools -, systemd -, zlib -, pcre -, libb64 -, libutp -, libdeflate -, utf8cpp -, fmt -, libpsl -, miniupnpc -, dht -, libnatpmp -, libiconv -, Foundation +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch2, + cmake, + pkg-config, + python3, + openssl, + curl, + libevent, + inotify-tools, + systemd, + zlib, + pcre, + libb64, + libutp, + libdeflate, + utf8cpp, + fmt, + libpsl, + miniupnpc, + dht, + libnatpmp, + libiconv, + Foundation, # Build options -, enableGTK3 ? false -, gtkmm3 -, xorg -, wrapGAppsHook3 -, enableQt5 ? false -, enableQt6 ? false -, qt5 -, qt6Packages -, nixosTests -, enableSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, enableDaemon ? true -, enableCli ? true -, installLib ? false -, apparmorRulesFromClosure + enableGTK3 ? false, + gtkmm3, + xorg, + wrapGAppsHook3, + enableQt5 ? false, + enableQt6 ? false, + qt5, + qt6Packages, + nixosTests, + enableSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + enableDaemon ? true, + enableCli ? true, + installLib ? false, + apparmorRulesFromClosure, }: let inherit (lib) cmakeBool optionals; - apparmorRules = apparmorRulesFromClosure { name = "transmission-daemon"; } ([ - curl - libdeflate - libevent - libnatpmp - libpsl - miniupnpc - openssl - pcre - zlib - ] - ++ optionals enableSystemd [ systemd ] - ++ optionals stdenv.hostPlatform.isLinux [ inotify-tools ]); + apparmorRules = apparmorRulesFromClosure { name = "transmission-daemon"; } ( + [ + curl + libdeflate + libevent + libnatpmp + libpsl + miniupnpc + openssl + pcre + zlib + ] + ++ optionals enableSystemd [ systemd ] + ++ optionals stdenv.hostPlatform.isLinux [ inotify-tools ] + ); in stdenv.mkDerivation (finalAttrs: { @@ -84,20 +87,25 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - outputs = [ "out" "apparmor" ]; - - cmakeFlags = [ - (cmakeBool "ENABLE_CLI" enableCli) - (cmakeBool "ENABLE_DAEMON" enableDaemon) - (cmakeBool "ENABLE_GTK" enableGTK3) - (cmakeBool "ENABLE_MAC" false) # requires xcodebuild - (cmakeBool "ENABLE_QT" (enableQt5 || enableQt6)) - (cmakeBool "INSTALL_LIB" installLib) - ] ++ optionals stdenv.hostPlatform.isDarwin [ - # Transmission sets this to 10.13 if not explicitly specified, see https://github.com/transmission/transmission/blob/0be7091eb12f4eb55f6690f313ef70a66795ee72/CMakeLists.txt#L7-L16. - "-DCMAKE_OSX_DEPLOYMENT_TARGET=${stdenv.hostPlatform.darwinMinVersion}" + outputs = [ + "out" + "apparmor" ]; + cmakeFlags = + [ + (cmakeBool "ENABLE_CLI" enableCli) + (cmakeBool "ENABLE_DAEMON" enableDaemon) + (cmakeBool "ENABLE_GTK" enableGTK3) + (cmakeBool "ENABLE_MAC" false) # requires xcodebuild + (cmakeBool "ENABLE_QT" (enableQt5 || enableQt6)) + (cmakeBool "INSTALL_LIB" installLib) + ] + ++ optionals stdenv.hostPlatform.isDarwin [ + # Transmission sets this to 10.13 if not explicitly specified, see https://github.com/transmission/transmission/blob/0be7091eb12f4eb55f6690f313ef70a66795ee72/CMakeLists.txt#L7-L16. + "-DCMAKE_OSX_DEPLOYMENT_TARGET=${stdenv.hostPlatform.darwinMinVersion}" + ]; + postPatch = '' # Clean third-party libraries to ensure system ones are used. # Excluding gtest since it is hardcoded to vendored version. The rest of the listed libraries are not packaged. @@ -119,37 +127,54 @@ stdenv.mkDerivation (finalAttrs: { --replace-fail '#if defined(HAVE_GETTEXT) && !defined(__APPLE__)' '#if defined(HAVE_GETTEXT)' ''; - nativeBuildInputs = [ - pkg-config - cmake - python3 - ] - ++ optionals enableGTK3 [ wrapGAppsHook3 ] - ++ optionals enableQt5 [ qt5.wrapQtAppsHook ] - ++ optionals enableQt6 [ qt6Packages.wrapQtAppsHook ] - ; - - buildInputs = [ - curl - dht - fmt - libb64 - libdeflate - libevent - libnatpmp - libpsl - libutp - miniupnpc - openssl - pcre - utf8cpp - zlib - ] - ++ optionals enableQt5 (with qt5; [ qttools qtbase ]) - ++ optionals enableQt6 (with qt6Packages; [ qttools qtbase qtsvg ]) - ++ optionals enableGTK3 [ gtkmm3 xorg.libpthreadstubs ] - ++ optionals enableSystemd [ systemd ] - ++ optionals stdenv.hostPlatform.isLinux [ inotify-tools ]; + nativeBuildInputs = + [ + pkg-config + cmake + python3 + ] + ++ optionals enableGTK3 [ wrapGAppsHook3 ] + ++ optionals enableQt5 [ qt5.wrapQtAppsHook ] + ++ optionals enableQt6 [ qt6Packages.wrapQtAppsHook ]; + + buildInputs = + [ + curl + dht + fmt + libb64 + libdeflate + libevent + libnatpmp + libpsl + libutp + miniupnpc + openssl + pcre + utf8cpp + zlib + ] + ++ optionals enableQt5 ( + with qt5; + [ + qttools + qtbase + ] + ) + ++ optionals enableQt6 ( + with qt6Packages; + [ + qttools + qtbase + qtsvg + ] + ) + ++ optionals enableGTK3 [ + gtkmm3 + xorg.libpthreadstubs + ] + ++ optionals enableSystemd [ systemd ] + ++ optionals stdenv.hostPlatform.isLinux [ inotify-tools ]; postInstall = '' mkdir $apparmor @@ -181,7 +206,13 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Fast, easy and free BitTorrent client"; - mainProgram = if (enableQt5 || enableQt6) then "transmission-qt" else if enableGTK3 then "transmission-gtk" else "transmission-cli"; + mainProgram = + if (enableQt5 || enableQt6) then + "transmission-qt" + else if enableGTK3 then + "transmission-gtk" + else + "transmission-cli"; longDescription = '' Transmission is a BitTorrent client which features a simple interface on top of a cross-platform back-end. @@ -194,7 +225,10 @@ stdenv.mkDerivation (finalAttrs: { * Full encryption, DHT, and PEX support ''; homepage = "https://www.transmissionbt.com/"; - license = with licenses; [ gpl2Plus mit ]; + license = with licenses; [ + gpl2Plus + mit + ]; maintainers = with maintainers; [ astsmtl ]; platforms = platforms.unix; }; diff --git a/pkgs/applications/networking/p2p/tremotesf/default.nix b/pkgs/applications/networking/p2p/tremotesf/default.nix index 6cf8c73bfb6930..2f2eab6ada89e2 100644 --- a/pkgs/applications/networking/p2p/tremotesf/default.nix +++ b/pkgs/applications/networking/p2p/tremotesf/default.nix @@ -1,16 +1,17 @@ -{stdenv -,lib -, cmake -, pkg-config -, fetchFromGitHub -, qtbase -, qttools -, kwidgetsaddons -, kwindowsystem -, fmt -, libpsl -, cxxopts -, wrapQtAppsHook +{ + stdenv, + lib, + cmake, + pkg-config, + fetchFromGitHub, + qtbase, + qttools, + kwidgetsaddons, + kwindowsystem, + fmt, + libpsl, + cxxopts, + wrapQtAppsHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/networking/protonvpn-cli/2.nix b/pkgs/applications/networking/protonvpn-cli/2.nix index c8f21cfc0df96f..a707832771a694 100644 --- a/pkgs/applications/networking/protonvpn-cli/2.nix +++ b/pkgs/applications/networking/protonvpn-cli/2.nix @@ -1,15 +1,17 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, pythonOlder -, requests -, docopt -, pythondialog -, jinja2 -, distro -, dialog -, iptables -, openvpn }: +{ + lib, + buildPythonApplication, + fetchFromGitHub, + pythonOlder, + requests, + docopt, + pythondialog, + jinja2, + distro, + dialog, + iptables, + openvpn, +}: buildPythonApplication rec { pname = "protonvpn-cli_2"; @@ -43,7 +45,11 @@ buildPythonApplication rec { meta = with lib; { description = "Linux command-line client for ProtonVPN using Openvpn"; homepage = "https://github.com/Rafficer/linux-cli-community"; - maintainers = with maintainers; [ jtcoolen jefflabonte shamilton ]; + maintainers = with maintainers; [ + jtcoolen + jefflabonte + shamilton + ]; license = licenses.gpl3Plus; platforms = platforms.linux; mainProgram = "protonvpn"; diff --git a/pkgs/applications/networking/protonvpn-cli/default.nix b/pkgs/applications/networking/protonvpn-cli/default.nix index 7a79c986ca3008..3c896200c98d77 100644 --- a/pkgs/applications/networking/protonvpn-cli/default.nix +++ b/pkgs/applications/networking/protonvpn-cli/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildPythonApplication -, pythonOlder -, fetchFromGitHub -, protonvpn-nm-lib -, pythondialog -, dialog +{ + lib, + buildPythonApplication, + pythonOlder, + fetchFromGitHub, + protonvpn-nm-lib, + pythondialog, + dialog, }: buildPythonApplication rec { diff --git a/pkgs/applications/networking/qv2ray/default.nix b/pkgs/applications/networking/qv2ray/default.nix index bf3dd2bd23e359..2e570937f2d7ea 100644 --- a/pkgs/applications/networking/qv2ray/default.nix +++ b/pkgs/applications/networking/qv2ray/default.nix @@ -1,21 +1,26 @@ -{ lib -, stdenv -, mkDerivation -, fetchFromGitHub -, symlinkJoin -, qttools -, cmake -, grpc -, protobuf_21 -, openssl -, pkg-config -, c-ares -, libGL -, zlib -, curl -, v2ray -, v2ray-geoip, v2ray-domain-list-community -, assets ? [ v2ray-geoip v2ray-domain-list-community ] +{ + lib, + stdenv, + mkDerivation, + fetchFromGitHub, + symlinkJoin, + qttools, + cmake, + grpc, + protobuf_21, + openssl, + pkg-config, + c-ares, + libGL, + zlib, + curl, + v2ray, + v2ray-geoip, + v2ray-domain-list-community, + assets ? [ + v2ray-geoip + v2ray-domain-list-community + ], }: mkDerivation rec { @@ -73,7 +78,10 @@ mkDerivation rec { description = "GUI frontend to v2ray"; homepage = "https://github.com/Qv2ray/Qv2ray"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ poscat rewine ]; + maintainers = with maintainers; [ + poscat + rewine + ]; platforms = platforms.all; # never built on aarch64-darwin, x86_64-darwin since update to unstable-2022-09-25 broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/applications/networking/remote/citrix-workspace/default.nix b/pkgs/applications/networking/remote/citrix-workspace/default.nix index 891dfe5d8e9e4f..c6bd8596920b5c 100644 --- a/pkgs/applications/networking/remote/citrix-workspace/default.nix +++ b/pkgs/applications/networking/remote/citrix-workspace/default.nix @@ -9,16 +9,19 @@ let toAttrName = x: "citrix_workspace_${builtins.replaceStrings [ "." ] [ "_" ] x}"; unsupported = lib.listToAttrs ( - map (x: lib.nameValuePair (toAttrName x) (throw '' - Citrix Workspace at version ${x} is not supported anymore! + map ( + x: + lib.nameValuePair (toAttrName x) (throw '' + Citrix Workspace at version ${x} is not supported anymore! - Actively supported releases are listed here: - https://www.citrix.com/support/product-lifecycle/workspace-app.html - '')) unsupportedVersions + Actively supported releases are listed here: + https://www.citrix.com/support/product-lifecycle/workspace-app.html + '') + ) unsupportedVersions ); supported = lib.mapAttrs' ( attr: versionInfo: lib.nameValuePair (toAttrName attr) (callPackage ./generic.nix versionInfo) ) supportedVersions; in - supported // unsupported +supported // unsupported diff --git a/pkgs/applications/networking/remote/citrix-workspace/sources.nix b/pkgs/applications/networking/remote/citrix-workspace/sources.nix index 42d393c20b328c..328d330475fd5b 100644 --- a/pkgs/applications/networking/remote/citrix-workspace/sources.nix +++ b/pkgs/applications/networking/remote/citrix-workspace/sources.nix @@ -1,9 +1,23 @@ { stdenv, lib }: let - mkVersionInfo = _: { major, minor, patch, x64hash, x86hash, x64suffix, x86suffix, homepage }: - { inherit homepage; - version = "${major}.${minor}.${patch}.${if stdenv.hostPlatform.is64bit then x64suffix else x86suffix}"; + mkVersionInfo = + _: + { + major, + minor, + patch, + x64hash, + x86hash, + x64suffix, + x86suffix, + homepage, + }: + { + inherit homepage; + version = "${major}.${minor}.${patch}.${ + if stdenv.hostPlatform.is64bit then x64suffix else x86suffix + }"; prefix = "linuxx${if stdenv.hostPlatform.is64bit then "64" else "86"}"; hash = if stdenv.hostPlatform.is64bit then x64hash else x86hash; }; @@ -15,58 +29,58 @@ let # x86 is unsupported past 23.11, see https://docs.citrix.com/en-us/citrix-workspace-app-for-linux/deprecation supportedVersions = lib.mapAttrs mkVersionInfo { "23.09.0" = { - major = "23"; - minor = "9"; - patch = "0"; - x64hash = "7b06339654aa27258d6dfa922828b43256e780b282d07109f452246c7aa27514"; - x86hash = "95436fb289602cf31c65b7df89da145fc170233cb2e758a2f11116f15b57d382"; + major = "23"; + minor = "9"; + patch = "0"; + x64hash = "7b06339654aa27258d6dfa922828b43256e780b282d07109f452246c7aa27514"; + x86hash = "95436fb289602cf31c65b7df89da145fc170233cb2e758a2f11116f15b57d382"; x64suffix = "24"; x86suffix = "24"; - homepage = "https://www.citrix.com/downloads/workspace-app/legacy-workspace-app-for-linux/workspace-app-for-linux-latest9.html"; + homepage = "https://www.citrix.com/downloads/workspace-app/legacy-workspace-app-for-linux/workspace-app-for-linux-latest9.html"; }; "23.11.0" = { - major = "23"; - minor = "11"; - patch = "0"; - x64hash = "d3dde64baa6db7675a025eff546d552544d3523f4f3047621884f7830a9e2822"; - x86hash = "65b8c144e51b5bd78b98ae69e0fa76d6c020a857d74fd5254be49492527072b6"; + major = "23"; + minor = "11"; + patch = "0"; + x64hash = "d3dde64baa6db7675a025eff546d552544d3523f4f3047621884f7830a9e2822"; + x86hash = "65b8c144e51b5bd78b98ae69e0fa76d6c020a857d74fd5254be49492527072b6"; x64suffix = "82"; x86suffix = "82"; - homepage = "https://www.citrix.com/downloads/workspace-app/legacy-workspace-app-for-linux/workspace-app-for-linux-latest10.html"; + homepage = "https://www.citrix.com/downloads/workspace-app/legacy-workspace-app-for-linux/workspace-app-for-linux-latest10.html"; }; "24.02.0" = { - major = "24"; - minor = "2"; - patch = "0"; - x64hash = "eaeb5d3bd079d4e5c9707da67f5f7a25cb765e19c36d01861290655dbf2aaee4"; - x86hash = ""; + major = "24"; + minor = "2"; + patch = "0"; + x64hash = "eaeb5d3bd079d4e5c9707da67f5f7a25cb765e19c36d01861290655dbf2aaee4"; + x86hash = ""; x64suffix = "65"; x86suffix = ""; - homepage = "https://www.citrix.com/downloads/workspace-app/legacy-workspace-app-for-linux/workspace-app-for-linux-latest12.html"; + homepage = "https://www.citrix.com/downloads/workspace-app/legacy-workspace-app-for-linux/workspace-app-for-linux-latest12.html"; }; "24.05.0" = { - major = "24"; - minor = "5"; - patch = "0"; - x64hash = "sha256-pye2JOilSbp8PFCpVXFkrRW98E8klCqoisVSWjR38nE="; - x86hash = ""; + major = "24"; + minor = "5"; + patch = "0"; + x64hash = "sha256-pye2JOilSbp8PFCpVXFkrRW98E8klCqoisVSWjR38nE="; + x86hash = ""; x64suffix = "76"; x86suffix = ""; - homepage = "https://www.citrix.com/downloads/workspace-app/linux/workspace-app-for-linux-latest.html"; + homepage = "https://www.citrix.com/downloads/workspace-app/linux/workspace-app-for-linux-latest.html"; }; "24.08.0" = { - major = "24"; - minor = "8"; - patch = "0"; - x64hash = "1jb22n6gcv4pv8khg98sv663yfpi47dpkvqgifbhps98iw5zrkbp"; - x86hash = ""; + major = "24"; + minor = "8"; + patch = "0"; + x64hash = "1jb22n6gcv4pv8khg98sv663yfpi47dpkvqgifbhps98iw5zrkbp"; + x86hash = ""; x64suffix = "98"; x86suffix = ""; - homepage = "https://www.citrix.com/downloads/workspace-app/linux/workspace-app-for-linux-latest.html"; + homepage = "https://www.citrix.com/downloads/workspace-app/linux/workspace-app-for-linux-latest.html"; }; }; @@ -75,7 +89,11 @@ let # # The lifespans of Citrix products can be found here: # https://www.citrix.com/support/product-lifecycle/workspace-app.html - unsupportedVersions = [ "23.02.0" "23.07.0" ]; -in { + unsupportedVersions = [ + "23.02.0" + "23.07.0" + ]; +in +{ inherit supportedVersions unsupportedVersions; } diff --git a/pkgs/applications/networking/remote/freerdp/3.nix b/pkgs/applications/networking/remote/freerdp/3.nix index 3071928503b827..26c0567c666ebf 100644 --- a/pkgs/applications/networking/remote/freerdp/3.nix +++ b/pkgs/applications/networking/remote/freerdp/3.nix @@ -1,69 +1,70 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, cmake -, docbook-xsl-nons -, libxslt -, pkg-config -, alsa-lib -, faac -, faad2 -, ffmpeg -, fuse3 -, glib -, openh264 -, openssl -, pcre2 -, pkcs11helper -, uriparser -, zlib -, libX11 -, libXcursor -, libXdamage -, libXdmcp -, libXext -, libXi -, libXinerama -, libXrandr -, libXrender -, libXtst -, libXv -, libxkbcommon -, libxkbfile -, wayland -, wayland-scanner -, icu -, libunwind -, orc -, cairo -, cjson -, libusb1 -, libpulseaudio -, cups -, pcsclite -, SDL2 -, SDL2_ttf -, SDL2_image -, systemd -, libjpeg_turbo -, libkrb5 -, libopus -, buildServer ? true -, nocaps ? false -, AudioToolbox -, AVFoundation -, Carbon -, Cocoa -, CoreMedia -, withUnfree ? false +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, + docbook-xsl-nons, + libxslt, + pkg-config, + alsa-lib, + faac, + faad2, + ffmpeg, + fuse3, + glib, + openh264, + openssl, + pcre2, + pkcs11helper, + uriparser, + zlib, + libX11, + libXcursor, + libXdamage, + libXdmcp, + libXext, + libXi, + libXinerama, + libXrandr, + libXrender, + libXtst, + libXv, + libxkbcommon, + libxkbfile, + wayland, + wayland-scanner, + icu, + libunwind, + orc, + cairo, + cjson, + libusb1, + libpulseaudio, + cups, + pcsclite, + SDL2, + SDL2_ttf, + SDL2_image, + systemd, + libjpeg_turbo, + libkrb5, + libopus, + buildServer ? true, + nocaps ? false, + AudioToolbox, + AVFoundation, + Carbon, + Cocoa, + CoreMedia, + withUnfree ? false, # tries to compile and run generate_argument_docbook.c -, withManPages ? stdenv.buildPlatform.canExecute stdenv.hostPlatform + withManPages ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, -, buildPackages -, gnome -, remmina + buildPackages, + gnome, + remmina, }: stdenv.mkDerivation (finalAttrs: { @@ -77,22 +78,25 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-oThlqUpEmhcLpMMYExMA3GbtB2+lq6oc5TRZt0eKRLA="; }; - postPatch = '' - export HOME=$TMP + postPatch = + '' + export HOME=$TMP - # skip NIB file generation on darwin - substituteInPlace "client/Mac/CMakeLists.txt" "client/Mac/cli/CMakeLists.txt" \ - --replace-fail "if (NOT IS_XCODE)" "if (FALSE)" + # skip NIB file generation on darwin + substituteInPlace "client/Mac/CMakeLists.txt" "client/Mac/cli/CMakeLists.txt" \ + --replace-fail "if (NOT IS_XCODE)" "if (FALSE)" - substituteInPlace "libfreerdp/freerdp.pc.in" \ - --replace-fail "Requires:" "Requires: @WINPR_PKG_CONFIG_FILENAME@" - '' + lib.optionalString (pcsclite != null) '' - substituteInPlace "winpr/libwinpr/smartcard/smartcard_pcsc.c" \ - --replace-fail "libpcsclite.so" "${lib.getLib pcsclite}/lib/libpcsclite.so" - '' + lib.optionalString nocaps '' - substituteInPlace "libfreerdp/locale/keyboard_xkbfile.c" \ - --replace-fail "RDP_SCANCODE_CAPSLOCK" "RDP_SCANCODE_LCONTROL" - ''; + substituteInPlace "libfreerdp/freerdp.pc.in" \ + --replace-fail "Requires:" "Requires: @WINPR_PKG_CONFIG_FILENAME@" + '' + + lib.optionalString (pcsclite != null) '' + substituteInPlace "winpr/libwinpr/smartcard/smartcard_pcsc.c" \ + --replace-fail "libpcsclite.so" "${lib.getLib pcsclite}/lib/libpcsclite.so" + '' + + lib.optionalString nocaps '' + substituteInPlace "libfreerdp/locale/keyboard_xkbfile.c" \ + --replace-fail "RDP_SCANCODE_CAPSLOCK" "RDP_SCANCODE_LCONTROL" + ''; nativeBuildInputs = [ cmake @@ -102,99 +106,111 @@ stdenv.mkDerivation (finalAttrs: { wayland-scanner ]; - buildInputs = [ - cairo - cjson - cups - faad2 - ffmpeg - glib - icu - libX11 - libXcursor - libXdamage - libXdmcp - libXext - libXi - libXinerama - libXrandr - libXrender - libXtst - libXv - libjpeg_turbo - libkrb5 - libopus - libpulseaudio - libunwind - libusb1 - libxkbcommon - libxkbfile - openh264 - openssl - orc - pcre2 - pcsclite - pkcs11helper - SDL2 - SDL2_ttf - SDL2_image - uriparser - zlib - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - fuse3 - systemd - wayland - wayland-scanner - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AudioToolbox - AVFoundation - Carbon - Cocoa - CoreMedia - ] ++ lib.optionals withUnfree [ - faac - ]; + buildInputs = + [ + cairo + cjson + cups + faad2 + ffmpeg + glib + icu + libX11 + libXcursor + libXdamage + libXdmcp + libXext + libXi + libXinerama + libXrandr + libXrender + libXtst + libXv + libjpeg_turbo + libkrb5 + libopus + libpulseaudio + libunwind + libusb1 + libxkbcommon + libxkbfile + openh264 + openssl + orc + pcre2 + pcsclite + pkcs11helper + SDL2 + SDL2_ttf + SDL2_image + uriparser + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + fuse3 + systemd + wayland + wayland-scanner + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AudioToolbox + AVFoundation + Carbon + Cocoa + CoreMedia + ] + ++ lib.optionals withUnfree [ + faac + ]; # https://github.com/FreeRDP/FreeRDP/issues/8526#issuecomment-1357134746 - cmakeFlags = [ - "-Wno-dev" - (lib.cmakeFeature "CMAKE_INSTALL_LIBDIR" "lib") - (lib.cmakeFeature "DOCBOOKXSL_DIR" "${docbook-xsl-nons}/xml/xsl/docbook") - ] ++ lib.mapAttrsToList lib.cmakeBool { - BUILD_TESTING = false; # false is recommended by upstream - WITH_CAIRO = cairo != null; - WITH_CUPS = cups != null; - WITH_FAAC = withUnfree && faac != null; - WITH_FAAD2 = faad2 != null; - WITH_FUSE = stdenv.hostPlatform.isLinux && fuse3 != null; - WITH_JPEG = libjpeg_turbo != null; - WITH_KRB5 = libkrb5 != null; - WITH_OPENH264 = openh264 != null; - WITH_OPUS = libopus != null; - WITH_OSS = false; - WITH_MANPAGES = withManPages; - WITH_PCSC = pcsclite != null; - WITH_PULSE = libpulseaudio != null; - WITH_SERVER = buildServer; - WITH_WEBVIEW = false; # avoid introducing webkit2gtk-4.0 - WITH_VAAPI = false; # false is recommended by upstream - WITH_X11 = true; - } ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - (lib.cmakeBool "SDL_USE_COMPILED_RESOURCES" false) - ]; + cmakeFlags = + [ + "-Wno-dev" + (lib.cmakeFeature "CMAKE_INSTALL_LIBDIR" "lib") + (lib.cmakeFeature "DOCBOOKXSL_DIR" "${docbook-xsl-nons}/xml/xsl/docbook") + ] + ++ lib.mapAttrsToList lib.cmakeBool { + BUILD_TESTING = false; # false is recommended by upstream + WITH_CAIRO = cairo != null; + WITH_CUPS = cups != null; + WITH_FAAC = withUnfree && faac != null; + WITH_FAAD2 = faad2 != null; + WITH_FUSE = stdenv.hostPlatform.isLinux && fuse3 != null; + WITH_JPEG = libjpeg_turbo != null; + WITH_KRB5 = libkrb5 != null; + WITH_OPENH264 = openh264 != null; + WITH_OPUS = libopus != null; + WITH_OSS = false; + WITH_MANPAGES = withManPages; + WITH_PCSC = pcsclite != null; + WITH_PULSE = libpulseaudio != null; + WITH_SERVER = buildServer; + WITH_WEBVIEW = false; # avoid introducing webkit2gtk-4.0 + WITH_VAAPI = false; # false is recommended by upstream + WITH_X11 = true; + } + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + (lib.cmakeBool "SDL_USE_COMPILED_RESOURCES" false) + ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-DTARGET_OS_IPHONE=0" - "-DTARGET_OS_WATCH=0" - "-include AudioToolbox/AudioToolbox.h" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-error=incompatible-function-pointer-types" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-DTARGET_OS_IPHONE=0" + "-DTARGET_OS_WATCH=0" + "-include AudioToolbox/AudioToolbox.h" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-error=incompatible-function-pointer-types" + ] + ); - env.NIX_LDFLAGS = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-framework AudioToolbox" - ]); + env.NIX_LDFLAGS = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-framework AudioToolbox" + ] + ); passthru.tests = { inherit remmina; diff --git a/pkgs/applications/networking/remote/freerdp/default.nix b/pkgs/applications/networking/remote/freerdp/default.nix index 7490066c732719..0d4de207b00adb 100644 --- a/pkgs/applications/networking/remote/freerdp/default.nix +++ b/pkgs/applications/networking/remote/freerdp/default.nix @@ -1,75 +1,78 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, docbook-xsl-nons -, libxslt -, pkg-config -, alsa-lib -, faac -, faad2 -, ffmpeg -, glib -, openh264 -, openssl -, pcre2 -, zlib -, libX11 -, libXcursor -, libXdamage -, libXdmcp -, libXext -, libXi -, libXinerama -, libXrandr -, libXrender -, libXtst -, libXv -, libxkbcommon -, libxkbfile -, wayland -, wayland-scanner -, gstreamer -, gst-plugins-base -, gst-plugins-good -, libunwind -, orc -, cairo -, libusb1 -, libpulseaudio -, cups -, pcsclite -, systemd -, libjpeg_turbo -, buildServer ? true -, nocaps ? false -, AudioToolbox -, AVFoundation -, Carbon -, Cocoa -, CoreMedia -, withUnfree ? false - -# tries to compile and run generate_argument_docbook.c -, withManPages ? stdenv.buildPlatform.canExecute stdenv.hostPlatform - -, buildPackages +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + docbook-xsl-nons, + libxslt, + pkg-config, + alsa-lib, + faac, + faad2, + ffmpeg, + glib, + openh264, + openssl, + pcre2, + zlib, + libX11, + libXcursor, + libXdamage, + libXdmcp, + libXext, + libXi, + libXinerama, + libXrandr, + libXrender, + libXtst, + libXv, + libxkbcommon, + libxkbfile, + wayland, + wayland-scanner, + gstreamer, + gst-plugins-base, + gst-plugins-good, + libunwind, + orc, + cairo, + libusb1, + libpulseaudio, + cups, + pcsclite, + systemd, + libjpeg_turbo, + buildServer ? true, + nocaps ? false, + AudioToolbox, + AVFoundation, + Carbon, + Cocoa, + CoreMedia, + withUnfree ? false, + + # tries to compile and run generate_argument_docbook.c + withManPages ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, + + buildPackages, }: let cmFlag = flag: if flag then "ON" else "OFF"; - disabledTests = [ - # this one is probably due to our sandbox - { - dir = "libfreerdp/crypto/test"; - file = "Test_x509_cert_info.c"; - } - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - { - dir = "winpr/libwinpr/sysinfo/test"; - file = "TestGetComputerName.c"; - } - ]; + disabledTests = + [ + # this one is probably due to our sandbox + { + dir = "libfreerdp/crypto/test"; + file = "Test_x509_cert_info.c"; + } + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + { + dir = "winpr/libwinpr/sysinfo/test"; + file = "TestGetComputerName.c"; + } + ]; inherit (lib) optionals; @@ -85,113 +88,126 @@ stdenv.mkDerivation rec { hash = "sha256-w+xyMNFmKylSheK0yAGl8J6MXly/HUjjAfR9Qq3s/kA="; }; - postPatch = '' - export HOME=$TMP - - # skip NIB file generation on darwin - sed -z 's/NIB file generation.*//' -i client/Mac{,/cli}/CMakeLists.txt - - # failing test(s) - ${lib.concatMapStringsSep "\n" (e: '' - substituteInPlace ${e.dir}/CMakeLists.txt \ - --replace ${e.file} "" - rm ${e.dir}/${e.file} - '') disabledTests} - - substituteInPlace "libfreerdp/freerdp.pc.in" \ - --replace "Requires:" "Requires: @WINPR_PKG_CONFIG_FILENAME@" - '' + lib.optionalString (pcsclite != null) '' - substituteInPlace "winpr/libwinpr/smartcard/smartcard_pcsc.c" \ - --replace "libpcsclite.so" "${lib.getLib pcsclite}/lib/libpcsclite.so" - '' + lib.optionalString nocaps '' - substituteInPlace "libfreerdp/locale/keyboard_xkbfile.c" \ - --replace "RDP_SCANCODE_CAPSLOCK" "RDP_SCANCODE_LCONTROL" - ''; - - buildInputs = [ - cairo - cups - faad2 - ffmpeg - glib - gst-plugins-base - gst-plugins-good - gstreamer - libX11 - libXcursor - libXdamage - libXdmcp - libXext - libXi - libXinerama - libXrandr - libXrender - libXtst - libXv - libjpeg_turbo - libpulseaudio - libunwind - libusb1 - libxkbcommon - libxkbfile - openh264 - openssl - orc - pcre2 - pcsclite - zlib - ] ++ optionals stdenv.hostPlatform.isLinux [ - alsa-lib - systemd - wayland - ] ++ optionals stdenv.hostPlatform.isDarwin [ - AudioToolbox - AVFoundation - Carbon - Cocoa - CoreMedia - ] - ++ optionals withUnfree [ - faac - ]; + postPatch = + '' + export HOME=$TMP + + # skip NIB file generation on darwin + sed -z 's/NIB file generation.*//' -i client/Mac{,/cli}/CMakeLists.txt + + # failing test(s) + ${lib.concatMapStringsSep "\n" (e: '' + substituteInPlace ${e.dir}/CMakeLists.txt \ + --replace ${e.file} "" + rm ${e.dir}/${e.file} + '') disabledTests} + + substituteInPlace "libfreerdp/freerdp.pc.in" \ + --replace "Requires:" "Requires: @WINPR_PKG_CONFIG_FILENAME@" + '' + + lib.optionalString (pcsclite != null) '' + substituteInPlace "winpr/libwinpr/smartcard/smartcard_pcsc.c" \ + --replace "libpcsclite.so" "${lib.getLib pcsclite}/lib/libpcsclite.so" + '' + + lib.optionalString nocaps '' + substituteInPlace "libfreerdp/locale/keyboard_xkbfile.c" \ + --replace "RDP_SCANCODE_CAPSLOCK" "RDP_SCANCODE_LCONTROL" + ''; + + buildInputs = + [ + cairo + cups + faad2 + ffmpeg + glib + gst-plugins-base + gst-plugins-good + gstreamer + libX11 + libXcursor + libXdamage + libXdmcp + libXext + libXi + libXinerama + libXrandr + libXrender + libXtst + libXv + libjpeg_turbo + libpulseaudio + libunwind + libusb1 + libxkbcommon + libxkbfile + openh264 + openssl + orc + pcre2 + pcsclite + zlib + ] + ++ optionals stdenv.hostPlatform.isLinux [ + alsa-lib + systemd + wayland + ] + ++ optionals stdenv.hostPlatform.isDarwin [ + AudioToolbox + AVFoundation + Carbon + Cocoa + CoreMedia + ] + ++ optionals withUnfree [ + faac + ]; nativeBuildInputs = [ - cmake libxslt docbook-xsl-nons pkg-config + cmake + libxslt + docbook-xsl-nons + pkg-config wayland-scanner ]; doCheck = true; # https://github.com/FreeRDP/FreeRDP/issues/8526#issuecomment-1357134746 - cmakeFlags = [ - "-Wno-dev" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DDOCBOOKXSL_DIR=${docbook-xsl-nons}/xml/xsl/docbook" - ] - ++ lib.mapAttrsToList (k: v: "-D${k}=${cmFlag v}") { - BUILD_TESTING = false; # false is recommended by upstream - WITH_CAIRO = (cairo != null); - WITH_CUPS = (cups != null); - WITH_FAAC = (withUnfree && faac != null); - WITH_FAAD2 = (faad2 != null); - WITH_JPEG = (libjpeg_turbo != null); - WITH_OPENH264 = (openh264 != null); - WITH_OSS = false; - WITH_MANPAGES = withManPages; - WITH_PCSC = (pcsclite != null); - WITH_PULSE = (libpulseaudio != null); - WITH_SERVER = buildServer; - WITH_VAAPI = false; # false is recommended by upstream - WITH_X11 = true; - }; - - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-DTARGET_OS_IPHONE=0" - "-DTARGET_OS_WATCH=0" - "-include AudioToolbox/AudioToolbox.h" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-error=incompatible-function-pointer-types" - ]); + cmakeFlags = + [ + "-Wno-dev" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DDOCBOOKXSL_DIR=${docbook-xsl-nons}/xml/xsl/docbook" + ] + ++ lib.mapAttrsToList (k: v: "-D${k}=${cmFlag v}") { + BUILD_TESTING = false; # false is recommended by upstream + WITH_CAIRO = (cairo != null); + WITH_CUPS = (cups != null); + WITH_FAAC = (withUnfree && faac != null); + WITH_FAAD2 = (faad2 != null); + WITH_JPEG = (libjpeg_turbo != null); + WITH_OPENH264 = (openh264 != null); + WITH_OSS = false; + WITH_MANPAGES = withManPages; + WITH_PCSC = (pcsclite != null); + WITH_PULSE = (libpulseaudio != null); + WITH_SERVER = buildServer; + WITH_VAAPI = false; # false is recommended by upstream + WITH_X11 = true; + }; + + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-DTARGET_OS_IPHONE=0" + "-DTARGET_OS_WATCH=0" + "-include AudioToolbox/AudioToolbox.h" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-error=incompatible-function-pointer-types" + ] + ); NIX_LDFLAGS = lib.optionals stdenv.hostPlatform.isDarwin [ "-framework AudioToolbox" diff --git a/pkgs/applications/networking/remote/remmina/default.nix b/pkgs/applications/networking/remote/remmina/default.nix index a05afc9a652afb..69f773163d0a16 100644 --- a/pkgs/applications/networking/remote/remmina/default.nix +++ b/pkgs/applications/networking/remote/remmina/default.nix @@ -1,19 +1,53 @@ -{ lib, stdenv, fetchFromGitLab, cmake, ninja, pkg-config, wrapGAppsHook3 -, curl, fuse3, fetchpatch2 -, desktopToDarwinBundle -, glib, gtk3, gettext, libxkbfile, libX11, python3 -, freerdp3, libssh, libgcrypt, gnutls -, pcre2, libdbusmenu-gtk3, libappindicator-gtk3 -, libvncserver, libpthreadstubs, libXdmcp, libxkbcommon -, libsecret, libsoup_3, spice-protocol, spice-gtk, libepoxy, at-spi2-core -, openssl, gsettings-desktop-schemas, json-glib, libsodium, harfbuzz -, wayland -# The themes here are soft dependencies; only icons are missing without them. -, adwaita-icon-theme -, withKf5Wallet ? stdenv.hostPlatform.isLinux, libsForQt5 -, withLibsecret ? stdenv.hostPlatform.isLinux -, withWebkitGtk ? false, webkitgtk_4_1 -, withVte ? true, vte +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + ninja, + pkg-config, + wrapGAppsHook3, + curl, + fuse3, + fetchpatch2, + desktopToDarwinBundle, + glib, + gtk3, + gettext, + libxkbfile, + libX11, + python3, + freerdp3, + libssh, + libgcrypt, + gnutls, + pcre2, + libdbusmenu-gtk3, + libappindicator-gtk3, + libvncserver, + libpthreadstubs, + libXdmcp, + libxkbcommon, + libsecret, + libsoup_3, + spice-protocol, + spice-gtk, + libepoxy, + at-spi2-core, + openssl, + gsettings-desktop-schemas, + json-glib, + libsodium, + harfbuzz, + wayland, + # The themes here are soft dependencies; only icons are missing without them. + adwaita-icon-theme, + withKf5Wallet ? stdenv.hostPlatform.isLinux, + libsForQt5, + withLibsecret ? stdenv.hostPlatform.isLinux, + withWebkitGtk ? false, + webkitgtk_4_1, + withVte ? true, + vte, }: stdenv.mkDerivation (finalAttrs: { @@ -27,41 +61,69 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-u+ysAFi7I7nXIiAw7VCmHbqgtRoZgkPnRfy/Mnl1b2g="; }; - nativeBuildInputs = [ cmake ninja pkg-config wrapGAppsHook3 ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; + nativeBuildInputs = [ + cmake + ninja + pkg-config + wrapGAppsHook3 + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; - buildInputs = [ - curl - gsettings-desktop-schemas - glib gtk3 gettext libxkbfile libX11 - freerdp3 libssh libgcrypt gnutls - pcre2 - libvncserver libpthreadstubs libXdmcp libxkbcommon - libsoup_3 spice-protocol - spice-gtk - libepoxy at-spi2-core - openssl adwaita-icon-theme json-glib libsodium - harfbuzz python3 - wayland - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ fuse3 libappindicator-gtk3 libdbusmenu-gtk3 ] + buildInputs = + [ + curl + gsettings-desktop-schemas + glib + gtk3 + gettext + libxkbfile + libX11 + freerdp3 + libssh + libgcrypt + gnutls + pcre2 + libvncserver + libpthreadstubs + libXdmcp + libxkbcommon + libsoup_3 + spice-protocol + spice-gtk + libepoxy + at-spi2-core + openssl + adwaita-icon-theme + json-glib + libsodium + harfbuzz + python3 + wayland + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + fuse3 + libappindicator-gtk3 + libdbusmenu-gtk3 + ] ++ lib.optionals withLibsecret [ libsecret ] ++ lib.optionals withKf5Wallet [ libsForQt5.kwallet ] ++ lib.optionals withWebkitGtk [ webkitgtk_4_1 ] ++ lib.optionals withVte [ vte ]; - cmakeFlags = [ - "-DWITH_FREERDP3=ON" - "-DWITH_VTE=${if withVte then "ON" else "OFF"}" - "-DWITH_TELEPATHY=OFF" - "-DWITH_AVAHI=OFF" - "-DWITH_KF5WALLET=${if withKf5Wallet then "ON" else "OFF"}" - "-DWITH_LIBSECRET=${if withLibsecret then "ON" else "OFF"}" - "-DWITH_WEBKIT2GTK=${if withWebkitGtk then "ON" else "OFF"}" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DHAVE_LIBAPPINDICATOR=OFF" - "-DWITH_CUPS=OFF" - "-DWITH_ICON_CACHE=OFF" - ]; + cmakeFlags = + [ + "-DWITH_FREERDP3=ON" + "-DWITH_VTE=${if withVte then "ON" else "OFF"}" + "-DWITH_TELEPATHY=OFF" + "-DWITH_AVAHI=OFF" + "-DWITH_KF5WALLET=${if withKf5Wallet then "ON" else "OFF"}" + "-DWITH_LIBSECRET=${if withLibsecret then "ON" else "OFF"}" + "-DWITH_WEBKIT2GTK=${if withWebkitGtk then "ON" else "OFF"}" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DHAVE_LIBAPPINDICATOR=OFF" + "-DWITH_CUPS=OFF" + "-DWITH_ICON_CACHE=OFF" + ]; env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin (toString [ "-DTARGET_OS_IPHONE=0" @@ -83,10 +145,16 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { license = licenses.gpl2Plus; homepage = "https://gitlab.com/Remmina/Remmina"; - changelog = "https://gitlab.com/Remmina/Remmina/-/blob/master/CHANGELOG.md#${lib.replaceStrings ["."] [""] finalAttrs.src.rev}"; + changelog = "https://gitlab.com/Remmina/Remmina/-/blob/master/CHANGELOG.md#${ + lib.replaceStrings [ "." ] [ "" ] finalAttrs.src.rev + }"; description = "Remote desktop client written in GTK"; mainProgram = "remmina"; - maintainers = with maintainers; [ bbigras melsigl ryantm ]; + maintainers = with maintainers; [ + bbigras + melsigl + ryantm + ]; platforms = platforms.linux ++ platforms.darwin; }; }) diff --git a/pkgs/applications/networking/remote/teamviewer/default.nix b/pkgs/applications/networking/remote/teamviewer/default.nix index c88f380961dea2..45c972d4f87e62 100644 --- a/pkgs/applications/networking/remote/teamviewer/default.nix +++ b/pkgs/applications/networking/remote/teamviewer/default.nix @@ -1,55 +1,68 @@ -{ mkDerivation -, lib -, stdenv -, fetchurl -, autoPatchelfHook -, makeWrapper -, xdg-utils -, dbus -, getconf -, glibc -, libXrandr -, libX11 -, libXext -, libXdamage -, libXtst -, libSM -, libXfixes -, coreutils -, wrapQtAppsHook -, icu63 -, nss -, minizip +{ + mkDerivation, + lib, + stdenv, + fetchurl, + autoPatchelfHook, + makeWrapper, + xdg-utils, + dbus, + getconf, + glibc, + libXrandr, + libX11, + libXext, + libXdamage, + libXtst, + libSM, + libXfixes, + coreutils, + wrapQtAppsHook, + icu63, + nss, + minizip, }: mkDerivation rec { pname = "teamviewer"; # teamviewer itself has not development files but the dev output removes propagated other dev outputs from runtime - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; version = "15.54.3"; src = let - base_url = "https://dl.teamviewer.com/download/linux/version_${lib.versions.major version}x"; + base_url = "https://dl.teamviewer.com/download/linux/version_${lib.versions.major version}x"; in - { - x86_64-linux = fetchurl { - url = "${base_url}/teamviewer_${version}_amd64.deb"; - hash = "sha256-41zVX2svomcRKu2ow1A/EeKojBIpABO4o2EZxappzgo="; - }; - aarch64-linux = fetchurl { - url = "${base_url}/teamviewer_${version}_arm64.deb"; - hash = "sha256-wuQYWeYgXW54/5dpiGzJxZ9JZDlUgFgCKq8Z4xV2HlI="; - }; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + { + x86_64-linux = fetchurl { + url = "${base_url}/teamviewer_${version}_amd64.deb"; + hash = "sha256-41zVX2svomcRKu2ow1A/EeKojBIpABO4o2EZxappzgo="; + }; + aarch64-linux = fetchurl { + url = "${base_url}/teamviewer_${version}_arm64.deb"; + hash = "sha256-wuQYWeYgXW54/5dpiGzJxZ9JZDlUgFgCKq8Z4xV2HlI="; + }; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); unpackPhase = '' ar x $src tar xf data.tar.* ''; - nativeBuildInputs = [ autoPatchelfHook makeWrapper wrapQtAppsHook ]; - buildInputs = [ minizip icu63 nss ]; + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + wrapQtAppsHook + ]; + buildInputs = [ + minizip + icu63 + nss + ]; installPhase = '' mkdir -p $out/share/teamviewer $out/bin $out/share/applications @@ -106,8 +119,25 @@ mkDerivation rec { ''; makeWrapperArgs = [ - "--prefix PATH : ${lib.makeBinPath [ getconf coreutils ]}" - "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ libXrandr libX11 libXext libXdamage libXtst libSM libXfixes dbus icu63 ]}" + "--prefix PATH : ${ + lib.makeBinPath [ + getconf + coreutils + ] + }" + "--prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + libXrandr + libX11 + libXext + libXdamage + libXtst + libSM + libXfixes + dbus + icu63 + ] + }" ]; postFixup = '' @@ -128,6 +158,10 @@ mkDerivation rec { license = licenses.unfree; description = "Desktop sharing application, providing remote support and online meetings"; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ jagajaga jraygauthier gador ]; + maintainers = with maintainers; [ + jagajaga + jraygauthier + gador + ]; }; } diff --git a/pkgs/applications/networking/remote/x2goclient/default.nix b/pkgs/applications/networking/remote/x2goclient/default.nix index a9182b739fbfe6..6500d65151c9e9 100644 --- a/pkgs/applications/networking/remote/x2goclient/default.nix +++ b/pkgs/applications/networking/remote/x2goclient/default.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchurl -, cups -, libssh -, libXpm -, nx-libs -, openldap -, openssh -, qt5 -, qtbase -, qtsvg -, qtx11extras -, qttools -, phonon -, pkg-config +{ + stdenv, + lib, + fetchurl, + cups, + libssh, + libXpm, + nx-libs, + openldap, + openssh, + qt5, + qtbase, + qtsvg, + qtx11extras, + qttools, + phonon, + pkg-config, }: stdenv.mkDerivation rec { @@ -45,19 +46,30 @@ stdenv.mkDerivation rec { ]; postPatch = '' - substituteInPlace src/onmainwindow.cpp --replace "/usr/sbin/sshd" "${openssh}/bin/sshd" - substituteInPlace Makefile \ - --replace "SHELL=/bin/bash" "SHELL=$SHELL" \ - --replace "lrelease-qt4" "${qttools.dev}/bin/lrelease" \ - --replace "qmake-qt4" "${qtbase.dev}/bin/qmake" \ - --replace "-o root -g root" "" + substituteInPlace src/onmainwindow.cpp --replace "/usr/sbin/sshd" "${openssh}/bin/sshd" + substituteInPlace Makefile \ + --replace "SHELL=/bin/bash" "SHELL=$SHELL" \ + --replace "lrelease-qt4" "${qttools.dev}/bin/lrelease" \ + --replace "qmake-qt4" "${qtbase.dev}/bin/qmake" \ + --replace "-o root -g root" "" ''; - makeFlags = [ "PREFIX=$(out)" "ETCDIR=$(out)/etc" "build_client" "build_man" ]; + makeFlags = [ + "PREFIX=$(out)" + "ETCDIR=$(out)/etc" + "build_client" + "build_man" + ]; - installTargets = [ "install_client" "install_man" ]; + installTargets = [ + "install_client" + "install_man" + ]; - qtWrapperArgs = [ "--suffix PATH : ${nx-libs}/bin:${openssh}/libexec" "--set QT_QPA_PLATFORM xcb" ]; + qtWrapperArgs = [ + "--suffix PATH : ${nx-libs}/bin:${openssh}/libexec" + "--set QT_QPA_PLATFORM xcb" + ]; meta = with lib; { description = "Graphical NoMachine NX3 remote desktop client"; diff --git a/pkgs/applications/networking/remote/xrdp/default.nix b/pkgs/applications/networking/remote/xrdp/default.nix index 191a09c422cfd9..69e8592aa7dd8e 100644 --- a/pkgs/applications/networking/remote/xrdp/default.nix +++ b/pkgs/applications/networking/remote/xrdp/default.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, applyPatches -, fetchFromGitHub -, pkg-config -, which -, perl -, autoconf -, automake -, libtool -, openssl -, systemd -, pam -, fuse -, libdrm -, libjpeg -, libopus -, nasm -, xorg -, lame -, pixman -, libjpeg_turbo -, _experimental-update-script-combinators -, gitUpdater -, nixosTests +{ + lib, + stdenv, + applyPatches, + fetchFromGitHub, + pkg-config, + which, + perl, + autoconf, + automake, + libtool, + openssl, + systemd, + pam, + fuse, + libdrm, + libjpeg, + libopus, + nasm, + xorg, + lame, + pixman, + libjpeg_turbo, + _experimental-update-script-combinators, + gitUpdater, + nixosTests, }: let @@ -37,9 +38,19 @@ let hash = "sha256-xwkGY9dD747kyTvoXrYAIoiFBzQe5ngskUYQhDawnbU="; }; - nativeBuildInputs = [ pkg-config autoconf automake which libtool nasm ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + which + libtool + nasm + ]; - buildInputs = [ xorg.xorgserver libdrm ]; + buildInputs = [ + xorg.xorgserver + libdrm + ]; postPatch = '' # patch from Debian, allows to run xrdp daemon under unprivileged user @@ -78,7 +89,15 @@ let }; }; - nativeBuildInputs = [ pkg-config autoconf automake which libtool nasm perl ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + which + libtool + nasm + perl + ]; buildInputs = [ fuse @@ -121,7 +140,10 @@ let "--enable-vsock" ]; - installFlags = [ "DESTDIR=$(out)" "prefix=" ]; + installFlags = [ + "DESTDIR=$(out)" + "prefix=" + ]; postInstall = '' # remove generated keys (as non-deterministic) @@ -158,11 +180,25 @@ let passthru = { inherit xorgxrdp; - updateScript = _experimental-update-script-combinators.sequence (map (item: item.command) [ - (gitUpdater { rev-prefix = "v"; attrPath = "xrdp.src"; ignoredVersions = [ "beta" ]; }) - { command = ["rm" "update-git-commits.txt"]; } - (gitUpdater { rev-prefix = "v"; attrPath = "xrdp.xorgxrdp"; }) - ]); + updateScript = _experimental-update-script-combinators.sequence ( + map (item: item.command) [ + (gitUpdater { + rev-prefix = "v"; + attrPath = "xrdp.src"; + ignoredVersions = [ "beta" ]; + }) + { + command = [ + "rm" + "update-git-commits.txt" + ]; + } + (gitUpdater { + rev-prefix = "v"; + attrPath = "xrdp.xorgxrdp"; + }) + ] + ); tests = { inherit (nixosTests) xrdp; }; @@ -172,8 +208,12 @@ let description = "Open source RDP server"; homepage = "https://github.com/neutrinolabs/xrdp"; license = licenses.asl20; - maintainers = with maintainers; [ chvp lucasew ]; + maintainers = with maintainers; [ + chvp + lucasew + ]; platforms = platforms.linux; }; }; -in xrdp +in +xrdp diff --git a/pkgs/applications/networking/rymdport/default.nix b/pkgs/applications/networking/rymdport/default.nix index 70b446db8a5a28..dd1548158f2dc8 100644 --- a/pkgs/applications/networking/rymdport/default.nix +++ b/pkgs/applications/networking/rymdport/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, pkg-config -, libGL -, xorg -, Carbon -, Cocoa +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + pkg-config, + libGL, + xorg, + Carbon, + Cocoa, }: buildGoModule rec { @@ -26,20 +27,23 @@ buildGoModule rec { pkg-config ]; - buildInputs = with xorg; [ - libGL - libX11 - libXcursor - libXext - libXi - libXinerama - libXrandr - libXxf86vm - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Carbon - Cocoa - IOKit - ]; + buildInputs = + with xorg; + [ + libGL + libX11 + libXcursor + libXext + libXi + libXinerama + libXrandr + libXxf86vm + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + Cocoa + IOKit + ]; postInstall = '' for res in $(ls internal/assets/icons | sed -e 's/icon-//g' -e 's/.png//g'); do diff --git a/pkgs/applications/networking/sniffers/qtwirediff/default.nix b/pkgs/applications/networking/sniffers/qtwirediff/default.nix index ad71c217dbb92a..e1ab359298f076 100644 --- a/pkgs/applications/networking/sniffers/qtwirediff/default.nix +++ b/pkgs/applications/networking/sniffers/qtwirediff/default.nix @@ -1,14 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, qtbase -, qmake -, qtwayland -, wrapQtAppsHook -, wireshark-cli +{ + lib, + stdenv, + fetchFromGitHub, + qtbase, + qmake, + qtwayland, + wrapQtAppsHook, + wireshark-cli, }: - stdenv.mkDerivation { pname = "qtwirediff"; version = "unstable-2023-03-07"; @@ -25,25 +25,31 @@ stdenv.mkDerivation { wrapQtAppsHook ]; - buildInputs = [ - qtbase - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qtwayland - ]; + buildInputs = + [ + qtbase + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qtwayland + ]; - installPhase = '' - runHook preInstall - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/Applications - cp -r qtwirediff.app $out/Applications - makeWrapper $out/{Applications/qtwirediff.app/Contents/MacOS,bin}/qtwirediff - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - install -Dm755 -T qtwirediff $out/bin/qtwirediff - wrapProgram $out/bin/qtwirediff \ - --prefix PATH : "${lib.makeBinPath [ wireshark-cli ]}" - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/Applications + cp -r qtwirediff.app $out/Applications + makeWrapper $out/{Applications/qtwirediff.app/Contents/MacOS,bin}/qtwirediff + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + install -Dm755 -T qtwirediff $out/bin/qtwirediff + wrapProgram $out/bin/qtwirediff \ + --prefix PATH : "${lib.makeBinPath [ wireshark-cli ]}" + '' + + '' + runHook postInstall + ''; meta = { description = "Debugging tool to diff network traffic leveraging Wireshark"; diff --git a/pkgs/applications/networking/sniffers/savvycan/default.nix b/pkgs/applications/networking/sniffers/savvycan/default.nix index aea109549221c0..195412111d0ec2 100644 --- a/pkgs/applications/networking/sniffers/savvycan/default.nix +++ b/pkgs/applications/networking/sniffers/savvycan/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, qtbase -, qttools -, qmake -, qtserialbus -, qtserialport -, qtdeclarative -, wrapQtAppsHook +{ + stdenv, + lib, + fetchFromGitHub, + qtbase, + qttools, + qmake, + qtserialbus, + qtserialport, + qtdeclarative, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -22,9 +23,18 @@ stdenv.mkDerivation rec { hash = "sha256-duITY6s/uadeBCFuG42JbLCaq7yaYv1qB8Q3GA8UJ0A="; }; - buildInputs = [ qtbase qttools qtserialbus qtserialport qtdeclarative ]; + buildInputs = [ + qtbase + qttools + qtserialbus + qtserialport + qtdeclarative + ]; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; meta = with lib; { description = "QT based cross platform canbus tool"; diff --git a/pkgs/applications/networking/sniffers/wireshark/default.nix b/pkgs/applications/networking/sniffers/wireshark/default.nix index 5c00d64bf678bc..bedcb6c1d8e3d5 100644 --- a/pkgs/applications/networking/sniffers/wireshark/default.nix +++ b/pkgs/applications/networking/sniffers/wireshark/default.nix @@ -1,54 +1,55 @@ -{ lib -, stdenv -, fetchFromGitLab - -, ApplicationServices -, asciidoctor -, bcg729 -, bison -, buildPackages -, c-ares -, cmake -, fixDarwinDylibNames -, flex -, gettext -, glib -, gmp -, gnutls -, libcap -, libgcrypt -, libgpg-error -, libkrb5 -, libmaxminddb -, libnl -, libopus -, libpcap -, libsmi -, libssh -, lua5_4 -, lz4 -, makeWrapper -, minizip -, nghttp2 -, nghttp3 -, ninja -, opencore-amr -, openssl -, pcre2 -, perl -, pkg-config -, python3 -, sbc -, snappy -, spandsp3 -, speexdsp -, SystemConfiguration -, wrapGAppsHook3 -, zlib-ng -, zstd - -, withQt ? true -, qt6 ? null +{ + lib, + stdenv, + fetchFromGitLab, + + ApplicationServices, + asciidoctor, + bcg729, + bison, + buildPackages, + c-ares, + cmake, + fixDarwinDylibNames, + flex, + gettext, + glib, + gmp, + gnutls, + libcap, + libgcrypt, + libgpg-error, + libkrb5, + libmaxminddb, + libnl, + libopus, + libpcap, + libsmi, + libssh, + lua5_4, + lz4, + makeWrapper, + minizip, + nghttp2, + nghttp3, + ninja, + opencore-amr, + openssl, + pcre2, + perl, + pkg-config, + python3, + sbc, + snappy, + spandsp3, + speexdsp, + SystemConfiguration, + wrapGAppsHook3, + zlib-ng, + zstd, + + withQt ? true, + qt6 ? null, }: let isAppBundle = withQt && stdenv.hostPlatform.isDarwin; @@ -59,7 +60,10 @@ stdenv.mkDerivation rec { pname = "wireshark-${if withQt then "qt" else "cli"}"; version = "4.4.2"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitLab { repo = "wireshark"; @@ -76,80 +80,93 @@ stdenv.mkDerivation rec { buildPackages.stdenv.cc ]; - nativeBuildInputs = [ - asciidoctor - bison - cmake - flex - makeWrapper - ninja - perl - pkg-config - python3 - ] ++ lib.optionals withQt [ - qt6.wrapQtAppsHook - wrapGAppsHook3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ]; - - buildInputs = [ - bcg729 - c-ares - gettext - glib - gnutls - libgcrypt - libgpg-error - libkrb5 - libmaxminddb - libopus - libpcap - libsmi - libssh - lua5_4 - lz4 - minizip - nghttp2 - nghttp3 - opencore-amr - openssl - pcre2 - snappy - spandsp3 - speexdsp - zlib-ng - zstd - ] ++ lib.optionals withQt (with qt6; [ - qt5compat - qtbase - qtmultimedia - qtsvg - qttools - ]) ++ lib.optionals (withQt && stdenv.hostPlatform.isLinux) [ - qt6.qtwayland - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libcap - libnl - sbc - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ApplicationServices - gmp - SystemConfiguration - ]; + nativeBuildInputs = + [ + asciidoctor + bison + cmake + flex + makeWrapper + ninja + perl + pkg-config + python3 + ] + ++ lib.optionals withQt [ + qt6.wrapQtAppsHook + wrapGAppsHook3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ]; + + buildInputs = + [ + bcg729 + c-ares + gettext + glib + gnutls + libgcrypt + libgpg-error + libkrb5 + libmaxminddb + libopus + libpcap + libsmi + libssh + lua5_4 + lz4 + minizip + nghttp2 + nghttp3 + opencore-amr + openssl + pcre2 + snappy + spandsp3 + speexdsp + zlib-ng + zstd + ] + ++ lib.optionals withQt ( + with qt6; + [ + qt5compat + qtbase + qtmultimedia + qtsvg + qttools + ] + ) + ++ lib.optionals (withQt && stdenv.hostPlatform.isLinux) [ + qt6.qtwayland + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libcap + libnl + sbc + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ApplicationServices + gmp + SystemConfiguration + ]; strictDeps = true; - cmakeFlags = [ - "-DBUILD_wireshark=${if withQt then "ON" else "OFF"}" - # Fix `extcap` and `plugins` paths. See https://bugs.wireshark.org/bugzilla/show_bug.cgi?id=16444 - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DENABLE_APPLICATION_BUNDLE=${if isAppBundle then "ON" else "OFF"}" - "-DLEMON_C_COMPILER=cc" - ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ - "-DHAVE_C99_VSNPRINTF_EXITCODE__TRYRUN_OUTPUT=" - "-DHAVE_C99_VSNPRINTF_EXITCODE=0" - ]; + cmakeFlags = + [ + "-DBUILD_wireshark=${if withQt then "ON" else "OFF"}" + # Fix `extcap` and `plugins` paths. See https://bugs.wireshark.org/bugzilla/show_bug.cgi?id=16444 + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DENABLE_APPLICATION_BUNDLE=${if isAppBundle then "ON" else "OFF"}" + "-DLEMON_C_COMPILER=cc" + ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "-DHAVE_C99_VSNPRINTF_EXITCODE__TRYRUN_OUTPUT=" + "-DHAVE_C99_VSNPRINTF_EXITCODE=0" + ]; # Avoid referencing -dev paths because of debug assertions. env.NIX_CFLAGS_COMPILE = toString [ "-DQT_NO_DEBUG" ]; @@ -166,24 +183,27 @@ stdenv.mkDerivation rec { sed -i -e '1i cmake_policy(SET CMP0025 NEW)' CMakeLists.txt ''; - postInstall = '' - cmake --install . --prefix "''${!outputDev}" --component Development - '' + lib.optionalString isAppBundle '' - mkdir -p $out/Applications - mv $out/bin/Wireshark.app $out/Applications/Wireshark.app - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - local flags=() - for file in $out/lib/*.dylib; do - flags+=(-change @rpath/"$(basename "$file")" "$file") - done - - for file in $out/lib/wireshark/extcap/*; do - if [ -L "$file" ]; then continue; fi - echo "$file: fixing dylib references" - # note that -id does nothing on binaries - install_name_tool -id "$file" "''${flags[@]}" "$file" - done - ''; + postInstall = + '' + cmake --install . --prefix "''${!outputDev}" --component Development + '' + + lib.optionalString isAppBundle '' + mkdir -p $out/Applications + mv $out/bin/Wireshark.app $out/Applications/Wireshark.app + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + local flags=() + for file in $out/lib/*.dylib; do + flags+=(-change @rpath/"$(basename "$file")" "$file") + done + + for file in $out/lib/wireshark/extcap/*; do + if [ -L "$file" ]; then continue; fi + echo "$file: fixing dylib references" + # note that -id does nothing on binaries + install_name_tool -id "$file" "''${flags[@]}" "$file" + done + ''; preFixup = '' qtWrapperArgs+=("''${gappsWrapperArgs[@]}") @@ -209,7 +229,10 @@ stdenv.mkDerivation rec { changelog = "https://www.wireshark.org/docs/relnotes/wireshark-${version}.html"; license = licenses.gpl2Plus; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ bjornfor fpletz ]; + maintainers = with maintainers; [ + bjornfor + fpletz + ]; mainProgram = if withQt then "wireshark" else "tshark"; }; } diff --git a/pkgs/applications/networking/soapui/default.nix b/pkgs/applications/networking/soapui/default.nix index 8b7aca35246836..bde8a72416ffd8 100644 --- a/pkgs/applications/networking/soapui/default.nix +++ b/pkgs/applications/networking/soapui/default.nix @@ -16,8 +16,8 @@ stdenv.mkDerivation rec { sha256 = "sha256-pT0ZANVC7Sv7zxMDPY86aclIUGZeazOZadiVVsmEjtw="; }; - nativeBuildInputs = [makeWrapper]; - buildInputs = [jdk]; + nativeBuildInputs = [ makeWrapper ]; + buildInputs = [ jdk ]; installPhase = '' runHook preInstall @@ -53,14 +53,14 @@ stdenv.mkDerivation rec { '') ]; - passthru.tests = {inherit (nixosTests) soapui;}; + passthru.tests = { inherit (nixosTests) soapui; }; meta = with lib; { description = "Most Advanced REST & SOAP Testing Tool in the World"; homepage = "https://www.soapui.org/"; - sourceProvenance = with sourceTypes; [binaryBytecode]; + sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = "SoapUI End User License Agreement"; - maintainers = with maintainers; [gerschtli]; + maintainers = with maintainers; [ gerschtli ]; platforms = platforms.linux; # we don't fetch the dmg yet mainProgram = "soapui"; }; diff --git a/pkgs/applications/networking/sync/acd_cli/default.nix b/pkgs/applications/networking/sync/acd_cli/default.nix index 78453da19d16c5..f782cc9937b4f4 100644 --- a/pkgs/applications/networking/sync/acd_cli/default.nix +++ b/pkgs/applications/networking/sync/acd_cli/default.nix @@ -1,6 +1,17 @@ -{ lib, fetchFromGitHub, buildPythonApplication, fuse -, appdirs, colorama, python-dateutil, requests, requests-toolbelt -, fusepy, sqlalchemy, setuptools }: +{ + lib, + fetchFromGitHub, + buildPythonApplication, + fuse, + appdirs, + colorama, + python-dateutil, + requests, + requests-toolbelt, + fusepy, + sqlalchemy, + setuptools, +}: buildPythonApplication rec { pname = "acd_cli"; @@ -15,8 +26,16 @@ buildPythonApplication rec { sha256 = "0a0fr632l24a3jmgla3b1vcm50ayfa9hdbp677ch1chwj5dq4zfp"; }; - propagatedBuildInputs = [ appdirs colorama python-dateutil fusepy requests - requests-toolbelt setuptools sqlalchemy ]; + propagatedBuildInputs = [ + appdirs + colorama + python-dateutil + fusepy + requests + requests-toolbelt + setuptools + sqlalchemy + ]; makeWrapperArgs = [ "--prefix LIBFUSE_PATH : ${lib.getLib fuse}/lib/libfuse.so" ]; diff --git a/pkgs/applications/networking/sync/backintime/common.nix b/pkgs/applications/networking/sync/backintime/common.nix index 602f2a3126752f..ee79119edb2554 100644 --- a/pkgs/applications/networking/sync/backintime/common.nix +++ b/pkgs/applications/networking/sync/backintime/common.nix @@ -1,11 +1,36 @@ -{stdenv, lib, fetchFromGitHub, makeWrapper, gettext, -python3, rsync, cron, openssh, sshfs-fuse, encfs }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + gettext, + python3, + rsync, + cron, + openssh, + sshfs-fuse, + encfs, +}: let - python' = python3.withPackages (ps: with ps; [ dbus-python keyring packaging ]); + python' = python3.withPackages ( + ps: with ps; [ + dbus-python + keyring + packaging + ] + ); - apps = lib.makeBinPath [ openssh python' cron rsync sshfs-fuse encfs ]; -in stdenv.mkDerivation rec { + apps = lib.makeBinPath [ + openssh + python' + cron + rsync + sshfs-fuse + encfs + ]; +in +stdenv.mkDerivation rec { pname = "backintime-common"; version = "1.5.3"; @@ -16,7 +41,10 @@ in stdenv.mkDerivation rec { sha256 = "sha256-byJyRsjZND0CQAfx45jQa3PNHhqzF2O0cFGSfN4o/QA="; }; - nativeBuildInputs = [ makeWrapper gettext ]; + nativeBuildInputs = [ + makeWrapper + gettext + ]; buildInputs = [ python' ]; installFlags = [ "DEST=$(out)" ]; @@ -38,7 +66,7 @@ in stdenv.mkDerivation rec { preFixup = '' wrapProgram "$out/bin/backintime" \ --prefix PATH : ${apps} - ''; + ''; meta = { homepage = "https://github.com/bit-team/backintime"; diff --git a/pkgs/applications/networking/sync/backintime/qt.nix b/pkgs/applications/networking/sync/backintime/qt.nix index 136b91a0623cf0..2708997a45b67c 100644 --- a/pkgs/applications/networking/sync/backintime/qt.nix +++ b/pkgs/applications/networking/sync/backintime/qt.nix @@ -1,16 +1,44 @@ -{ lib, stdenv, backintime-common, python3, polkit, which, su, coreutils, util-linux, -wrapQtAppsHook, qtbase, qtwayland }: +{ + lib, + stdenv, + backintime-common, + python3, + polkit, + which, + su, + coreutils, + util-linux, + wrapQtAppsHook, + qtbase, + qtwayland, +}: let - python' = python3.withPackages (ps: with ps; [ pyqt6 backintime-common packaging ]); + python' = python3.withPackages ( + ps: with ps; [ + pyqt6 + backintime-common + packaging + ] + ); in stdenv.mkDerivation { inherit (backintime-common) - version src installFlags meta dontAddPrefix; + version + src + installFlags + meta + dontAddPrefix + ; pname = "backintime-qt"; - buildInputs = [ python' backintime-common qtbase qtwayland ]; + buildInputs = [ + python' + backintime-common + qtbase + qtwayland + ]; nativeBuildInputs = backintime-common.nativeBuildInputs or [ ] ++ [ wrapQtAppsHook diff --git a/pkgs/applications/networking/sync/casync/default.nix b/pkgs/applications/networking/sync/casync/default.nix index 79064f6bc107e2..3e8fa37f5d4b3c 100644 --- a/pkgs/applications/networking/sync/casync/default.nix +++ b/pkgs/applications/networking/sync/casync/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, python3 -, sphinx -, acl -, curl -, fuse -, libselinux -, udev -, xz -, zstd -, fuseSupport ? true -, selinuxSupport ? true -, udevSupport ? true -, glibcLocales -, rsync +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + python3, + sphinx, + acl, + curl, + fuse, + libselinux, + udev, + xz, + zstd, + fuseSupport ? true, + selinuxSupport ? true, + udevSupport ? true, + glibcLocales, + rsync, }: stdenv.mkDerivation { @@ -31,12 +32,27 @@ stdenv.mkDerivation { sha256 = "04ibglizjzyd7ih13q6m7ic78n0mzw9nfmb3zd1fcm9j62qlq11i"; }; - buildInputs = [ acl curl xz zstd ] + buildInputs = + [ + acl + curl + xz + zstd + ] ++ lib.optionals (fuseSupport) [ fuse ] ++ lib.optionals (selinuxSupport) [ libselinux ] ++ lib.optionals (udevSupport) [ udev ]; - nativeBuildInputs = [ meson ninja pkg-config python3 sphinx ]; - nativeCheckInputs = [ glibcLocales rsync ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + python3 + sphinx + ]; + nativeCheckInputs = [ + glibcLocales + rsync + ]; postPatch = '' for f in test/test-*.sh.in; do @@ -46,7 +62,8 @@ stdenv.mkDerivation { ''; PKG_CONFIG_UDEV_UDEVDIR = "lib/udev"; - mesonFlags = lib.optionals (!fuseSupport) [ "-Dfuse=false" ] + mesonFlags = + lib.optionals (!fuseSupport) [ "-Dfuse=false" ] ++ lib.optionals (!udevSupport) [ "-Dudev=false" ] ++ lib.optionals (!selinuxSupport) [ "-Dselinux=false" ]; diff --git a/pkgs/applications/networking/sync/lsyncd/default.nix b/pkgs/applications/networking/sync/lsyncd/default.nix index 8468749b7eaa58..7a985b7ad94023 100644 --- a/pkgs/applications/networking/sync/lsyncd/default.nix +++ b/pkgs/applications/networking/sync/lsyncd/default.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, cmake, lua, pkg-config, rsync, -asciidoc, libxml2, docbook_xml_dtd_45, docbook_xsl, libxslt, apple-sdk_11 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + lua, + pkg-config, + rsync, + asciidoc, + libxml2, + docbook_xml_dtd_45, + docbook_xsl, + libxslt, + apple-sdk_11, +}: let xnu = apple-sdk_11.sourceRelease "xnu"; @@ -30,11 +43,18 @@ stdenv.mkDerivation rec { dontUseCmakeBuildDir = true; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ rsync lua - asciidoc libxml2 docbook_xml_dtd_45 docbook_xsl libxslt + asciidoc + libxml2 + docbook_xml_dtd_45 + docbook_xsl + libxslt ] ++ lib.optional stdenv.hostPlatform.isDarwin apple-sdk_11; meta = with lib; { diff --git a/pkgs/applications/networking/sync/openrsync/default.nix b/pkgs/applications/networking/sync/openrsync/default.nix index 8b91bf24407cec..639ffeec28abdd 100644 --- a/pkgs/applications/networking/sync/openrsync/default.nix +++ b/pkgs/applications/networking/sync/openrsync/default.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation { diff --git a/pkgs/applications/networking/sync/rclone/browser.nix b/pkgs/applications/networking/sync/rclone/browser.nix index 99945267fa9941..272445a047530d 100644 --- a/pkgs/applications/networking/sync/rclone/browser.nix +++ b/pkgs/applications/networking/sync/rclone/browser.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, wrapQtAppsHook, qtbase }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + wrapQtAppsHook, + qtbase, +}: stdenv.mkDerivation rec { pname = "rclone-browser"; @@ -19,7 +27,10 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; buildInputs = [ qtbase ]; diff --git a/pkgs/applications/networking/sync/rclone/default.nix b/pkgs/applications/networking/sync/rclone/default.nix index fbb614f65ef6cf..5bf4ac7eac68a1 100644 --- a/pkgs/applications/networking/sync/rclone/default.nix +++ b/pkgs/applications/networking/sync/rclone/default.nix @@ -1,14 +1,26 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, buildPackages, installShellFiles -, makeWrapper -, enableCmount ? true, fuse, fuse3, macfuse-stubs -, librclone +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + buildPackages, + installShellFiles, + makeWrapper, + enableCmount ? true, + fuse, + fuse3, + macfuse-stubs, + librclone, }: buildGoModule rec { pname = "rclone"; version = "1.68.2"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchFromGitHub { owner = "rclone"; @@ -21,13 +33,22 @@ buildGoModule rec { subPackages = [ "." ]; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; - buildInputs = lib.optional enableCmount (if stdenv.hostPlatform.isDarwin then macfuse-stubs else fuse); + buildInputs = lib.optional enableCmount ( + if stdenv.hostPlatform.isDarwin then macfuse-stubs else fuse + ); tags = lib.optionals enableCmount [ "cmount" ]; - ldflags = [ "-s" "-w" "-X github.com/rclone/rclone/fs.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/rclone/rclone/fs.Version=${version}" + ]; postConfigure = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' substituteInPlace vendor/github.com/winfsp/cgofuse/fuse/host_cgo.go \ @@ -37,9 +58,10 @@ buildGoModule rec { postInstall = let rcloneBin = - if stdenv.buildPlatform.canExecute stdenv.hostPlatform - then "$out" - else lib.getBin buildPackages.rclone; + if stdenv.buildPlatform.canExecute stdenv.hostPlatform then + "$out" + else + lib.getBin buildPackages.rclone; in '' installManPage rclone.1 @@ -51,13 +73,15 @@ buildGoModule rec { # filesystem helpers ln -s $out/bin/rclone $out/bin/rclonefs ln -s $out/bin/rclone $out/bin/mount.rclone - '' + lib.optionalString (enableCmount && !stdenv.hostPlatform.isDarwin) - # use --suffix here to ensure we don't shadow /run/wrappers/bin/fusermount3, - # as the setuid wrapper is required as non-root on NixOS. - '' - wrapProgram $out/bin/rclone \ - --suffix PATH : "${lib.makeBinPath [ fuse3 ] }" - ''; + '' + + + lib.optionalString (enableCmount && !stdenv.hostPlatform.isDarwin) + # use --suffix here to ensure we don't shadow /run/wrappers/bin/fusermount3, + # as the setuid wrapper is required as non-root on NixOS. + '' + wrapProgram $out/bin/rclone \ + --suffix PATH : "${lib.makeBinPath [ fuse3 ]}" + ''; passthru.tests = { inherit librclone; @@ -69,6 +93,9 @@ buildGoModule rec { changelog = "https://github.com/rclone/rclone/blob/v${version}/docs/content/changelog.md"; license = licenses.mit; mainProgram = "rclone"; - maintainers = with maintainers; [ SuperSandro2000 tomfitzhenry ]; + maintainers = with maintainers; [ + SuperSandro2000 + tomfitzhenry + ]; }; } diff --git a/pkgs/applications/networking/sync/rsync/default.nix b/pkgs/applications/networking/sync/rsync/default.nix index 32236f36a9b907..d1e6501b5dcbf9 100644 --- a/pkgs/applications/networking/sync/rsync/default.nix +++ b/pkgs/applications/networking/sync/rsync/default.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchurl -, updateAutotoolsGnuConfigScriptsHook -, perl -, libiconv -, zlib -, popt -, enableACLs ? lib.meta.availableOn stdenv.hostPlatform acl -, acl -, enableLZ4 ? true -, lz4 -, enableOpenSSL ? true -, openssl -, enableXXHash ? true -, xxHash -, enableZstd ? true -, zstd -, nixosTests +{ + lib, + stdenv, + fetchurl, + updateAutotoolsGnuConfigScriptsHook, + perl, + libiconv, + zlib, + popt, + enableACLs ? lib.meta.availableOn stdenv.hostPlatform acl, + acl, + enableLZ4 ? true, + lz4, + enableOpenSSL ? true, + openssl, + enableXXHash ? true, + xxHash, + enableZstd ? true, + zstd, + nixosTests, }: stdenv.mkDerivation rec { @@ -29,34 +30,44 @@ stdenv.mkDerivation rec { hash = "sha256-c5nppnCMMtZ4pypjIZ6W8jvgviM25Q/RNISY0HBB35A="; }; - nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook perl ]; + nativeBuildInputs = [ + updateAutotoolsGnuConfigScriptsHook + perl + ]; patches = [ # https://github.com/WayneD/rsync/pull/558 ./configure.ac-fix-failing-IPv6-check.patch ]; - buildInputs = [ libiconv zlib popt ] + buildInputs = + [ + libiconv + zlib + popt + ] ++ lib.optional enableACLs acl ++ lib.optional enableZstd zstd ++ lib.optional enableLZ4 lz4 ++ lib.optional enableOpenSSL openssl ++ lib.optional enableXXHash xxHash; - configureFlags = [ - (lib.enableFeature enableLZ4 "lz4") - (lib.enableFeature enableOpenSSL "openssl") - (lib.enableFeature enableXXHash "xxhash") - (lib.enableFeature enableZstd "zstd") - "--with-nobody-group=nogroup" + configureFlags = + [ + (lib.enableFeature enableLZ4 "lz4") + (lib.enableFeature enableOpenSSL "openssl") + (lib.enableFeature enableXXHash "xxhash") + (lib.enableFeature enableZstd "zstd") + "--with-nobody-group=nogroup" - # disable the included zlib explicitly as it otherwise still compiles and - # links them even. - "--with-included-zlib=no" - ] ++ lib.optionals (stdenv.hostPlatform.isMusl && stdenv.hostPlatform.isx86_64) [ - # fix `multiversioning needs 'ifunc' which is not supported on this target` error - "--disable-roll-simd" - ]; + # disable the included zlib explicitly as it otherwise still compiles and + # links them even. + "--with-included-zlib=no" + ] + ++ lib.optionals (stdenv.hostPlatform.isMusl && stdenv.hostPlatform.isx86_64) [ + # fix `multiversioning needs 'ifunc' which is not supported on this target` error + "--disable-roll-simd" + ]; enableParallelBuilding = true; @@ -67,7 +78,11 @@ stdenv.mkDerivation rec { homepage = "https://rsync.samba.org/"; license = licenses.gpl3Plus; mainProgram = "rsync"; - maintainers = with lib.maintainers; [ ehmry kampfschlaefer ivan ]; + maintainers = with lib.maintainers; [ + ehmry + kampfschlaefer + ivan + ]; platforms = platforms.unix; }; } diff --git a/pkgs/applications/networking/sync/rsync/rrsync.nix b/pkgs/applications/networking/sync/rsync/rrsync.nix index 7bbdbf3adc1ec6..2f5db91370e18c 100644 --- a/pkgs/applications/networking/sync/rsync/rrsync.nix +++ b/pkgs/applications/networking/sync/rsync/rrsync.nix @@ -1,4 +1,8 @@ -{ stdenv, python3, rsync }: +{ + stdenv, + python3, + rsync, +}: stdenv.mkDerivation { pname = "rrsync"; diff --git a/pkgs/applications/networking/syncplay/default.nix b/pkgs/applications/networking/syncplay/default.nix index f7d0fdeb5c36ff..1d21cc6c252858 100644 --- a/pkgs/applications/networking/syncplay/default.nix +++ b/pkgs/applications/networking/syncplay/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildPythonApplication -, pem -, pyside6 -, twisted -, certifi -, qt6 -, appnope -, enableGUI ? true +{ + lib, + stdenv, + fetchFromGitHub, + buildPythonApplication, + pem, + pyside6, + twisted, + certifi, + qt6, + appnope, + enableGUI ? true, }: buildPythonApplication rec { @@ -28,14 +29,24 @@ buildPythonApplication rec { ./trusted_certificates.patch ]; - buildInputs = lib.optionals enableGUI [ (if stdenv.hostPlatform.isLinux then qt6.qtwayland else qt6.qtbase) ]; - propagatedBuildInputs = [ certifi pem twisted ] + buildInputs = lib.optionals enableGUI [ + (if stdenv.hostPlatform.isLinux then qt6.qtwayland else qt6.qtbase) + ]; + propagatedBuildInputs = + [ + certifi + pem + twisted + ] ++ twisted.optional-dependencies.tls ++ lib.optional enableGUI pyside6 ++ lib.optional (stdenv.hostPlatform.isDarwin && enableGUI) appnope; nativeBuildInputs = lib.optionals enableGUI [ qt6.wrapQtAppsHook ]; - makeFlags = [ "DESTDIR=" "PREFIX=$(out)" ]; + makeFlags = [ + "DESTDIR=" + "PREFIX=$(out)" + ]; postFixup = lib.optionalString enableGUI '' wrapQtApp $out/bin/syncplay diff --git a/pkgs/applications/networking/wayback_machine_downloader/default.nix b/pkgs/applications/networking/wayback_machine_downloader/default.nix index 4b8c5096cc5d34..d2f0e3a5e30e87 100644 --- a/pkgs/applications/networking/wayback_machine_downloader/default.nix +++ b/pkgs/applications/networking/wayback_machine_downloader/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "wayback_machine_downloader"; exes = [ "wayback_machine_downloader" ]; diff --git a/pkgs/applications/networking/wayback_machine_downloader/gemset.nix b/pkgs/applications/networking/wayback_machine_downloader/gemset.nix index 87cb3019d0a528..2fab9ad3a71f4c 100644 --- a/pkgs/applications/networking/wayback_machine_downloader/gemset.nix +++ b/pkgs/applications/networking/wayback_machine_downloader/gemset.nix @@ -1,9 +1,9 @@ { wayback_machine_downloader = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "170426sashqc2k2angg8d0bhs7spi1x1isv6cyk2hif0l6xxm3cm"; type = "gem"; }; diff --git a/pkgs/applications/networking/znc/default.nix b/pkgs/applications/networking/znc/default.nix index 60fdf00a2b3e74..18a4b9f3ac84e1 100644 --- a/pkgs/applications/networking/znc/default.nix +++ b/pkgs/applications/networking/znc/default.nix @@ -1,12 +1,24 @@ -{ lib, stdenv, fetchurl, fetchpatch2, openssl, pkg-config -, withPerl ? false, perl -, withPython ? false, python3 -, withTcl ? false, tcl -, withCyrus ? true, cyrus_sasl -, withUnicode ? true, icu -, withZlib ? true, zlib -, withIPv6 ? true -, withDebug ? false +{ + lib, + stdenv, + fetchurl, + fetchpatch2, + openssl, + pkg-config, + withPerl ? false, + perl, + withPython ? false, + python3, + withTcl ? false, + tcl, + withCyrus ? true, + cyrus_sasl, + withUnicode ? true, + icu, + withZlib ? true, + zlib, + withIPv6 ? true, + withDebug ? false, }: stdenv.mkDerivation rec { @@ -28,7 +40,8 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] + buildInputs = + [ openssl ] ++ lib.optional withPerl perl ++ lib.optional withPython python3 ++ lib.optional withTcl tcl @@ -36,13 +49,15 @@ stdenv.mkDerivation rec { ++ lib.optional withUnicode icu ++ lib.optional withZlib zlib; - configureFlags = [ - (lib.enableFeature withPerl "perl") - (lib.enableFeature withPython "python") - (lib.enableFeature withTcl "tcl") - (lib.withFeatureAs withTcl "tcl" "${tcl}/lib") - (lib.enableFeature withCyrus "cyrus") - ] ++ lib.optionals (!withIPv6) [ "--disable-ipv6" ] + configureFlags = + [ + (lib.enableFeature withPerl "perl") + (lib.enableFeature withPython "python") + (lib.enableFeature withTcl "tcl") + (lib.withFeatureAs withTcl "tcl" "${tcl}/lib") + (lib.enableFeature withCyrus "cyrus") + ] + ++ lib.optionals (!withIPv6) [ "--disable-ipv6" ] ++ lib.optionals withDebug [ "--enable-debug" ]; enableParallelBuilding = true; @@ -50,7 +65,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Advanced IRC bouncer"; homepage = "https://wiki.znc.in/ZNC"; - maintainers = with maintainers; [ schneefux lnl7 ]; + maintainers = with maintainers; [ + schneefux + lnl7 + ]; license = licenses.asl20; platforms = platforms.unix; }; diff --git a/pkgs/applications/networking/znc/modules.nix b/pkgs/applications/networking/znc/modules.nix index f19573bace9856..30e1973b180c68 100644 --- a/pkgs/applications/networking/znc/modules.nix +++ b/pkgs/applications/networking/znc/modules.nix @@ -1,22 +1,34 @@ -{ lib, stdenv, fetchFromGitHub, znc }: +{ + lib, + stdenv, + fetchFromGitHub, + znc, +}: let zncDerivation = - a@{ pname - , src - , module_name - , buildPhase ? "${znc}/bin/znc-buildmod ${module_name}.cpp" - , installPhase ? "install -D ${module_name}.so $out/lib/znc/${module_name}.so" - , ... - }: stdenv.mkDerivation (a // { - inherit buildPhase; - inherit installPhase; - - buildInputs = znc.buildInputs; - - meta = a.meta // { platforms = lib.platforms.unix; }; - passthru.module_name = module_name; - }); + a@{ + pname, + src, + module_name, + buildPhase ? "${znc}/bin/znc-buildmod ${module_name}.cpp", + installPhase ? "install -D ${module_name}.so $out/lib/znc/${module_name}.so", + ... + }: + stdenv.mkDerivation ( + a + // { + inherit buildPhase; + inherit installPhase; + + buildInputs = znc.buildInputs; + + meta = a.meta // { + platforms = lib.platforms.unix; + }; + passthru.module_name = module_name; + } + ); in { @@ -57,7 +69,11 @@ in description = "ZNC module for client specific buffers"; homepage = "https://github.com/CyberShadow/znc-clientbuffer"; license = licenses.asl20; - maintainers = with maintainers; [ hrdinka szlend cybershadow ]; + maintainers = with maintainers; [ + hrdinka + szlend + cybershadow + ]; }; }; @@ -195,7 +211,10 @@ in description = "Push notification service module for ZNC"; homepage = "https://github.com/jreese/znc-push"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ offline schneefux ]; + maintainers = with lib.maintainers; [ + offline + schneefux + ]; }; }; diff --git a/pkgs/applications/office/PageEdit/default.nix b/pkgs/applications/office/PageEdit/default.nix index fa7acd9310ba5a..fc2d43bb2fb2e6 100644 --- a/pkgs/applications/office/PageEdit/default.nix +++ b/pkgs/applications/office/PageEdit/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, qtsvg, qtwebengine, wrapQtAppsHook, qttools }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtsvg, + qtwebengine, + wrapQtAppsHook, + qttools, +}: stdenv.mkDerivation rec { pname = "pageedit"; @@ -11,20 +20,30 @@ stdenv.mkDerivation rec { hash = "sha256-zwOSt1eyvuuqfQ1G2bCB4yj6GgixFRc2FLOgcCrdg3Q="; }; - nativeBuildInputs = [ cmake wrapQtAppsHook qttools ]; - propagatedBuildInputs = [ qtsvg qtwebengine ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + qttools + ]; + propagatedBuildInputs = [ + qtsvg + qtwebengine + ]; cmakeFlags = [ "-DINSTALL_BUNDLED_DICTS=0" ]; installPhase = - if stdenv.hostPlatform.isDarwin then '' - runHook preInstall + if stdenv.hostPlatform.isDarwin then + '' + runHook preInstall - mkdir -p $out/Applications - cp -r bin/PageEdit.app $out/Applications - makeWrapper $out/Applications/PageEdit.app/Contents/MacOS/PageEdit $out/bin/pageedit + mkdir -p $out/Applications + cp -r bin/PageEdit.app $out/Applications + makeWrapper $out/Applications/PageEdit.app/Contents/MacOS/PageEdit $out/bin/pageedit - runHook postInstall - '' else null; + runHook postInstall + '' + else + null; meta = with lib; { description = "ePub XHTML Visual Editor"; diff --git a/pkgs/applications/office/beamerpresenter/default.nix b/pkgs/applications/office/beamerpresenter/default.nix index 0d122cfbf3cd93..7be305ba0249c0 100644 --- a/pkgs/applications/office/beamerpresenter/default.nix +++ b/pkgs/applications/office/beamerpresenter/default.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, wrapGAppsHook3 -, wrapQtAppsHook -, gst_all_1 -, qtbase -, qtsvg -, qtmultimedia -, qttools -, qtwayland -, zlib -# only required when using poppler -, poppler -# only required when using mupdf -, freetype -, gumbo -, jbig2dec -, mupdf -, openjpeg -# choose renderer: mupdf or poppler or both (not recommended) -, usePoppler ? false -, useMupdf ? true -, useExternalRenderer ? false +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + wrapGAppsHook3, + wrapQtAppsHook, + gst_all_1, + qtbase, + qtsvg, + qtmultimedia, + qttools, + qtwayland, + zlib, + # only required when using poppler + poppler, + # only required when using mupdf + freetype, + gumbo, + jbig2dec, + mupdf, + openjpeg, + # choose renderer: mupdf or poppler or both (not recommended) + usePoppler ? false, + useMupdf ? true, + useExternalRenderer ? false, }: stdenv.mkDerivation rec { @@ -46,26 +47,30 @@ stdenv.mkDerivation rec { dontWrapGApps = true; - buildInputs = [ - gst_all_1.gst-libav - gst_all_1.gst-plugins-base - gst_all_1.gst-plugins-good - zlib - qtbase - qtsvg - qtmultimedia - qttools - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qtwayland - ] ++ lib.optionals useMupdf [ - freetype - gumbo - jbig2dec - mupdf - openjpeg - ] ++ lib.optionals usePoppler [ - poppler - ]; + buildInputs = + [ + gst_all_1.gst-libav + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-good + zlib + qtbase + qtsvg + qtmultimedia + qttools + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qtwayland + ] + ++ lib.optionals useMupdf [ + freetype + gumbo + jbig2dec + mupdf + openjpeg + ] + ++ lib.optionals usePoppler [ + poppler + ]; cmakeFlags = [ "-DGIT_VERSION=OFF" @@ -87,9 +92,15 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Modular multi screen pdf presentation viewer"; homepage = "https://github.com/stiglers-eponym/BeamerPresenter"; - license = with licenses; [ agpl3Only gpl3Plus ]; + license = with licenses; [ + agpl3Only + gpl3Plus + ]; platforms = platforms.all; - maintainers = with maintainers; [ pacien dotlambda ]; + maintainers = with maintainers; [ + pacien + dotlambda + ]; mainProgram = "beamerpresenter"; }; } diff --git a/pkgs/applications/office/beancount/bean-add.nix b/pkgs/applications/office/beancount/bean-add.nix index 9d451668eff69f..1f2fb4cec1cd32 100644 --- a/pkgs/applications/office/beancount/bean-add.nix +++ b/pkgs/applications/office/beancount/bean-add.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3Packages }: +{ + lib, + stdenv, + fetchFromGitHub, + python3Packages, +}: stdenv.mkDerivation { pname = "bean-add"; @@ -30,4 +35,3 @@ stdenv.mkDerivation { maintainers = with lib.maintainers; [ matthiasbeyer ]; }; } - diff --git a/pkgs/applications/office/beancount/beancount-ing-diba.nix b/pkgs/applications/office/beancount/beancount-ing-diba.nix index e1f3cb55fd8a8b..84e9053537401b 100644 --- a/pkgs/applications/office/beancount/beancount-ing-diba.nix +++ b/pkgs/applications/office/beancount/beancount-ing-diba.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, fetchpatch +{ + lib, + python3, + fetchFromGitHub, + fetchpatch, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/applications/office/beancount/beancount_share.nix b/pkgs/applications/office/beancount/beancount_share.nix index 2d702ad8d7ce75..f9732bfc5f50e7 100644 --- a/pkgs/applications/office/beancount/beancount_share.nix +++ b/pkgs/applications/office/beancount/beancount_share.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { @@ -25,7 +26,8 @@ python3.pkgs.buildPythonApplication rec { description = "Beancount plugin to share expenses with external partners within one ledger"; license = licenses.agpl3Plus; maintainers = with maintainers; [ matthiasbeyer ]; - broken = true; # At 2024-06-29, missing unpacked dependency - # https://hydra.nixos.org/build/262800507/nixlog/1 + broken = true; + # At 2024-06-29, missing unpacked dependency + # https://hydra.nixos.org/build/262800507/nixlog/1 }; } diff --git a/pkgs/applications/office/beebeep/default.nix b/pkgs/applications/office/beebeep/default.nix index 63843433b3c541..970680b8251a47 100644 --- a/pkgs/applications/office/beebeep/default.nix +++ b/pkgs/applications/office/beebeep/default.nix @@ -1,11 +1,12 @@ -{ lib -, mkDerivation -, fetchzip -, wrapQtAppsHook -, autoPatchelfHook -, qtbase -, qtmultimedia -, qtx11extras +{ + lib, + mkDerivation, + fetchzip, + wrapQtAppsHook, + autoPatchelfHook, + qtbase, + qtmultimedia, + qtx11extras, }: mkDerivation rec { diff --git a/pkgs/applications/office/cb2bib/default.nix b/pkgs/applications/office/cb2bib/default.nix index 331e6a7c3a2645..96e2ae202815af 100644 --- a/pkgs/applications/office/cb2bib/default.nix +++ b/pkgs/applications/office/cb2bib/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, qmake, qtbase, qtwebkit, qtx11extras, lzo, libX11, wrapQtAppsHook }: +{ + lib, + stdenv, + fetchurl, + qmake, + qtbase, + qtwebkit, + qtx11extras, + lzo, + libX11, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "cb2bib"; @@ -7,8 +18,17 @@ stdenv.mkDerivation rec { url = "https://www.molspaces.com/dl/progs/${pname}-${version}.tar.gz"; sha256 = "0gv7cnxi84lr6d5y71pd67h0ilmf5c88j1jxgyn9dvj19smrv99h"; }; - buildInputs = [ qtbase qtwebkit qtx11extras lzo libX11 ]; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + buildInputs = [ + qtbase + qtwebkit + qtx11extras + lzo + libX11 + ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; configurePhase = '' runHook preConfigure diff --git a/pkgs/applications/office/cutemarked-ng/default.nix b/pkgs/applications/office/cutemarked-ng/default.nix index 2c55edb037aafa..021259dd40041a 100644 --- a/pkgs/applications/office/cutemarked-ng/default.nix +++ b/pkgs/applications/office/cutemarked-ng/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, qmake -, pkg-config -, qttools -, qtwebengine -, wrapQtAppsHook -, qmarkdowntextedit -, md4c -, hunspell +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + pkg-config, + qttools, + qtwebengine, + wrapQtAppsHook, + qmarkdowntextedit, + md4c, + hunspell, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/office/jabref/default.nix b/pkgs/applications/office/jabref/default.nix index 5c7fd7b7de9aa9..da3d47bb7597f3 100644 --- a/pkgs/applications/office/jabref/default.nix +++ b/pkgs/applications/office/jabref/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, wrapGAppsHook3 -, makeDesktopItem -, copyDesktopItems -, unzip -, xdg-utils -, gtk3 -, jdk -, gradle_8 -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + wrapGAppsHook3, + makeDesktopItem, + copyDesktopItems, + unzip, + xdg-utils, + gtk3, + jdk, + gradle_8, + python3, }: let # "Deprecated Gradle features were used in this build, making it incompatible with Gradle 9.0." @@ -134,7 +135,13 @@ stdenv.mkDerivation rec { binaryNativeCode # source bundles dependencies as jars ]; license = licenses.mit; - platforms = [ "x86_64-linux" "aarch64-linux" ]; - maintainers = with maintainers; [ gebner linsui ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; + maintainers = with maintainers; [ + gebner + linsui + ]; }; } diff --git a/pkgs/applications/office/jameica/default.nix b/pkgs/applications/office/jameica/default.nix index 3f9e20d7a042c2..c724658db2aadf 100644 --- a/pkgs/applications/office/jameica/default.nix +++ b/pkgs/applications/office/jameica/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeDesktopItem -, makeWrapper -, wrapGAppsHook3 -, stripJavaArchivesHook -, ant -, jdk -, jre -, gtk2 -, glib -, libXtst -, Cocoa +{ + lib, + stdenv, + fetchFromGitHub, + makeDesktopItem, + makeWrapper, + wrapGAppsHook3, + stripJavaArchivesHook, + ant, + jdk, + jre, + gtk2, + glib, + libXtst, + Cocoa, }: let @@ -20,12 +21,18 @@ let version = "${_version}-${_build}"; swtSystem = - if stdenv.hostPlatform.system == "i686-linux" then "linux" - else if stdenv.hostPlatform.system == "x86_64-linux" then "linux64" - else if stdenv.hostPlatform.system == "aarch64-linux" then "linux-arm64" - else if stdenv.hostPlatform.system == "x86_64-darwin" then "macos64" - else if stdenv.hostPlatform.system == "aarch64-darwin" then "macos-aarch64" - else throw "Unsupported system: ${stdenv.hostPlatform.system}"; + if stdenv.hostPlatform.system == "i686-linux" then + "linux" + else if stdenv.hostPlatform.system == "x86_64-linux" then + "linux64" + else if stdenv.hostPlatform.system == "aarch64-linux" then + "linux-arm64" + else if stdenv.hostPlatform.system == "x86_64-darwin" then + "macos64" + else if stdenv.hostPlatform.system == "aarch64-darwin" then + "macos-aarch64" + else + throw "Unsupported system: ${stdenv.hostPlatform.system}"; desktopItem = makeDesktopItem { name = "jameica"; @@ -44,12 +51,23 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "willuhn"; repo = "jameica"; - rev = "V_${builtins.replaceStrings ["."] ["_"] _version}_BUILD_${_build}"; + rev = "V_${builtins.replaceStrings [ "." ] [ "_" ] _version}_BUILD_${_build}"; hash = "sha256-MSVSd5DyVL+dcfTDv1M99hxickPwT2Pt6QGNsu6DGZI="; }; - nativeBuildInputs = [ ant jdk wrapGAppsHook3 makeWrapper stripJavaArchivesHook ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ gtk2 glib libXtst ] + nativeBuildInputs = [ + ant + jdk + wrapGAppsHook3 + makeWrapper + stripJavaArchivesHook + ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + gtk2 + glib + libXtst + ] ++ lib.optional stdenv.hostPlatform.isDarwin Cocoa; dontWrapGApps = true; @@ -62,36 +80,37 @@ stdenv.mkDerivation rec { runHook postBuild ''; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - mkdir -p $out/libexec $out/lib $out/bin $out/share/{applications,jameica-${version},java}/ + mkdir -p $out/libexec $out/lib $out/bin $out/share/{applications,jameica-${version},java}/ - # copy libraries except SWT - cp $(find lib -type f -iname '*.jar' | grep -ve 'swt/.*/swt.jar') $out/share/jameica-${version}/ - # copy platform-specific SWT - cp lib/swt/${swtSystem}/swt.jar $out/share/jameica-${version}/ + # copy libraries except SWT + cp $(find lib -type f -iname '*.jar' | grep -ve 'swt/.*/swt.jar') $out/share/jameica-${version}/ + # copy platform-specific SWT + cp lib/swt/${swtSystem}/swt.jar $out/share/jameica-${version}/ - install -Dm644 releases/${_version}-*/jameica/jameica.jar $out/share/java/ - install -Dm644 plugin.xml $out/share/java/ - install -Dm644 build/jameica-icon.png $out/share/pixmaps/jameica.png - cp ${desktopItem}/share/applications/* $out/share/applications/ - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + install -Dm644 releases/${_version}-*/jameica/jameica.jar $out/share/java/ + install -Dm644 plugin.xml $out/share/java/ + install -Dm644 build/jameica-icon.png $out/share/pixmaps/jameica.png + cp ${desktopItem}/share/applications/* $out/share/applications/ + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Create .app bundle for macOS - mkdir -p $out/Applications - chmod +x releases/${_version}-${_build}-${_build}/tmp/jameica.app/jameica*.sh - cp -r releases/${_version}-${_build}-${_build}/tmp/jameica.app $out/Applications/Jameica.app - '' + '' + # Create .app bundle for macOS + mkdir -p $out/Applications + chmod +x releases/${_version}-${_build}-${_build}/tmp/jameica.app/jameica*.sh + cp -r releases/${_version}-${_build}-${_build}/tmp/jameica.app $out/Applications/Jameica.app + '' + + '' - runHook postInstall - ''; + runHook postInstall + ''; postFixup = '' makeWrapper ${jre}/bin/java $out/bin/jameica \ - --add-flags "-cp $out/share/java/jameica.jar:$out/share/jameica-${version}/* ${ - lib.optionalString stdenv.hostPlatform.isDarwin ''-Xdock:name="Jameica" -XstartOnFirstThread'' - } de.willuhn.jameica.Main" \ + --add-flags "-cp $out/share/java/jameica.jar:$out/share/jameica-${version}/* ${lib.optionalString stdenv.hostPlatform.isDarwin ''-Xdock:name="Jameica" -XstartOnFirstThread''} de.willuhn.jameica.Main" \ --prefix LD_LIBRARY_PATH : ${lib.escapeShellArg (lib.makeLibraryPath buildInputs)} \ --chdir "$out/share/java/" \ "''${gappsWrapperArgs[@]}" @@ -110,7 +129,10 @@ stdenv.mkDerivation rec { ]; license = licenses.gpl2Plus; platforms = platforms.unix; - maintainers = with maintainers; [ flokli r3dl3g ]; + maintainers = with maintainers; [ + flokli + r3dl3g + ]; mainProgram = "jameica"; }; } diff --git a/pkgs/applications/office/kbibtex/default.nix b/pkgs/applications/office/kbibtex/default.nix index e7b04848ca4047..3cfa32da90e698 100644 --- a/pkgs/applications/office/kbibtex/default.nix +++ b/pkgs/applications/office/kbibtex/default.nix @@ -1,42 +1,45 @@ -{ lib -, mkDerivation -, fetchurl -# build-time -, extra-cmake-modules -, shared-mime-info -# Qt -, qtxmlpatterns -, qtwebengine -, qca-qt5 -, qtnetworkauth -# KDE -, ki18n -, kxmlgui -, kio -, kiconthemes -, kitemviews -, kparts -, kcoreaddons -, kservice -, ktexteditor -, kdoctools -, kwallet -, kcrash -# other -, poppler -, bibutils +{ + lib, + mkDerivation, + fetchurl, + # build-time + extra-cmake-modules, + shared-mime-info, + # Qt + qtxmlpatterns, + qtwebengine, + qca-qt5, + qtnetworkauth, + # KDE + ki18n, + kxmlgui, + kio, + kiconthemes, + kitemviews, + kparts, + kcoreaddons, + kservice, + ktexteditor, + kdoctools, + kwallet, + kcrash, + # other + poppler, + bibutils, }: mkDerivation rec { pname = "kbibtex"; version = "0.10.0"; - src = let - majorMinorPatch = lib.concatStringsSep "." (lib.take 3 (lib.splitVersion version)); - in fetchurl { - url = "mirror://kde/stable/KBibTeX/${majorMinorPatch}/kbibtex-${version}.tar.xz"; - hash = "sha256-sSeyQKfNd8U4YZ3IgqOZs8bM13oEQopJevkG8U0JuMQ="; - }; + src = + let + majorMinorPatch = lib.concatStringsSep "." (lib.take 3 (lib.splitVersion version)); + in + fetchurl { + url = "mirror://kde/stable/KBibTeX/${majorMinorPatch}/kbibtex-${version}.tar.xz"; + hash = "sha256-sSeyQKfNd8U4YZ3IgqOZs8bM13oEQopJevkG8U0JuMQ="; + }; nativeBuildInputs = [ extra-cmake-modules @@ -65,7 +68,10 @@ mkDerivation rec { ]; qtWrapperArgs = [ - "--prefix" "PATH" ":" "${lib.makeBinPath [ bibutils ]}" + "--prefix" + "PATH" + ":" + "${lib.makeBinPath [ bibutils ]}" ]; meta = with lib; { diff --git a/pkgs/applications/office/kexi/default.nix b/pkgs/applications/office/kexi/default.nix index 132194d0c78245..d081796bddb6b3 100644 --- a/pkgs/applications/office/kexi/default.nix +++ b/pkgs/applications/office/kexi/default.nix @@ -1,10 +1,37 @@ { - mkDerivation, lib, fetchurl, fetchpatch, extra-cmake-modules, kdoctools, - boost, qttools, qtwebkit, - breeze-icons, karchive, kcodecs, kcompletion, kconfig, kconfigwidgets, kcoreaddons, - kcrash, kguiaddons, ki18n, kiconthemes, kitemviews, kio, ktexteditor, ktextwidgets, - kwidgetsaddons, kxmlgui, - kdb, kproperty, kreport, lcms2, libmysqlclient, marble, postgresql + mkDerivation, + lib, + fetchurl, + fetchpatch, + extra-cmake-modules, + kdoctools, + boost, + qttools, + qtwebkit, + breeze-icons, + karchive, + kcodecs, + kcompletion, + kconfig, + kconfigwidgets, + kcoreaddons, + kcrash, + kguiaddons, + ki18n, + kiconthemes, + kitemviews, + kio, + ktexteditor, + ktextwidgets, + kwidgetsaddons, + kxmlgui, + kdb, + kproperty, + kreport, + lcms2, + libmysqlclient, + marble, + postgresql, }: mkDerivation rec { @@ -16,14 +43,39 @@ mkDerivation rec { sha256 = "1zy1q7q9rfdaws3rwf3my22ywkn6g747s3ixfcg9r80mm2g3z0bs"; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ - boost qttools qtwebkit - breeze-icons karchive kcodecs kcompletion kconfig kconfigwidgets kcoreaddons - kcrash kguiaddons ki18n kiconthemes kitemviews kio ktexteditor ktextwidgets - kwidgetsaddons kxmlgui - kdb kproperty kreport lcms2 libmysqlclient marble postgresql + boost + qttools + qtwebkit + breeze-icons + karchive + kcodecs + kcompletion + kconfig + kconfigwidgets + kcoreaddons + kcrash + kguiaddons + ki18n + kiconthemes + kitemviews + kio + ktexteditor + ktextwidgets + kwidgetsaddons + kxmlgui + kdb + kproperty + kreport + lcms2 + libmysqlclient + marble + postgresql ]; propagatedUserEnvPkgs = [ kproperty ]; @@ -52,6 +104,9 @@ mkDerivation rec { homepage = "https://kexi-project.org/"; maintainers = with maintainers; [ zraexy ]; platforms = platforms.linux; - license = with licenses; [ gpl2 lgpl2 ]; + license = with licenses; [ + gpl2 + lgpl2 + ]; }; } diff --git a/pkgs/applications/office/kmymoney/default.nix b/pkgs/applications/office/kmymoney/default.nix index 86547c638dfaa7..f21c568c210c67 100644 --- a/pkgs/applications/office/kmymoney/default.nix +++ b/pkgs/applications/office/kmymoney/default.nix @@ -1,17 +1,38 @@ -{ stdenv, lib, fetchurl, doxygen, extra-cmake-modules, graphviz, kdoctools -, wrapQtAppsHook -, autoPatchelfHook - -, akonadi, alkimia, aqbanking, gmp, gwenhywfar, kactivities, karchive -, kcmutils, kcontacts, qtwebengine, kdiagram, kholidays, kidentitymanagement -, kitemmodels, libical, libofx, qgpgme - -, sqlcipher - -# Needed for running tests: -, xvfb-run - -, python3 +{ + stdenv, + lib, + fetchurl, + doxygen, + extra-cmake-modules, + graphviz, + kdoctools, + wrapQtAppsHook, + autoPatchelfHook, + + akonadi, + alkimia, + aqbanking, + gmp, + gwenhywfar, + kactivities, + karchive, + kcmutils, + kcontacts, + qtwebengine, + kdiagram, + kholidays, + kidentitymanagement, + kitemmodels, + libical, + libofx, + qgpgme, + + sqlcipher, + + # Needed for running tests: + xvfb-run, + + python3, }: stdenv.mkDerivation rec { @@ -33,14 +54,33 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = "-I${kitemmodels.dev}/include/KF5"; nativeBuildInputs = [ - doxygen extra-cmake-modules graphviz kdoctools - python3.pkgs.wrapPython wrapQtAppsHook autoPatchelfHook + doxygen + extra-cmake-modules + graphviz + kdoctools + python3.pkgs.wrapPython + wrapQtAppsHook + autoPatchelfHook ]; buildInputs = [ - akonadi alkimia aqbanking gmp gwenhywfar kactivities karchive kcmutils - kcontacts qtwebengine kdiagram kholidays kidentitymanagement kitemmodels - libical libofx qgpgme + akonadi + alkimia + aqbanking + gmp + gwenhywfar + kactivities + karchive + kcmutils + kcontacts + qtwebengine + kdiagram + kholidays + kidentitymanagement + kitemmodels + libical + libofx + qgpgme sqlcipher # Put it into buildInputs so that CMake can find it, even though we patch @@ -61,11 +101,10 @@ stdenv.mkDerivation rec { doInstallCheck = stdenv.buildPlatform.canExecute stdenv.hostPlatform; nativeInstallCheckInputs = [ xvfb-run ]; - installCheckPhase = - lib.optionalString doInstallCheck '' - xvfb-run -s '-screen 0 1024x768x24' make test \ - ARGS="-E '(reports-chart-test)'" # Test fails, so exclude it for now. - ''; + installCheckPhase = lib.optionalString doInstallCheck '' + xvfb-run -s '-screen 0 1024x768x24' make test \ + ARGS="-E '(reports-chart-test)'" # Test fails, so exclude it for now. + ''; # libpython is required by the python interpreter embedded in kmymoney, so we # need to explicitly tell autoPatchelf about it. @@ -80,6 +119,9 @@ stdenv.mkDerivation rec { homepage = "https://kmymoney.org/"; platforms = lib.platforms.linux; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ aidalgol das-g ]; + maintainers = with lib.maintainers; [ + aidalgol + das-g + ]; }; } diff --git a/pkgs/applications/office/ktimetracker/default.nix b/pkgs/applications/office/ktimetracker/default.nix index b31eb4588c3f8c..50cd0de5142eb7 100644 --- a/pkgs/applications/office/ktimetracker/default.nix +++ b/pkgs/applications/office/ktimetracker/default.nix @@ -1,7 +1,23 @@ -{ mkDerivation, lib, fetchurl, cmake, pkg-config, extra-cmake-modules, -kconfig, kconfigwidgets, kdbusaddons, kdoctools, ki18n, kidletime, -kjobwidgets, kio, knotifications, kwindowsystem, kxmlgui, ktextwidgets, -kcalendarcore +{ + mkDerivation, + lib, + fetchurl, + cmake, + pkg-config, + extra-cmake-modules, + kconfig, + kconfigwidgets, + kdbusaddons, + kdoctools, + ki18n, + kidletime, + kjobwidgets, + kio, + knotifications, + kwindowsystem, + kxmlgui, + ktextwidgets, + kcalendarcore, }: mkDerivation rec { @@ -14,12 +30,24 @@ mkDerivation rec { }; nativeBuildInputs = [ - cmake pkg-config extra-cmake-modules + cmake + pkg-config + extra-cmake-modules ]; buildInputs = [ - kconfig kconfigwidgets kdbusaddons kdoctools ki18n kidletime kjobwidgets -kio knotifications kwindowsystem kxmlgui ktextwidgets + kconfig + kconfigwidgets + kdbusaddons + kdoctools + ki18n + kidletime + kjobwidgets + kio + knotifications + kwindowsystem + kxmlgui + ktextwidgets kcalendarcore ]; diff --git a/pkgs/applications/office/ledger-web/default.nix b/pkgs/applications/office/ledger-web/default.nix index 00e3636fc3971c..5662713bc6a0b3 100644 --- a/pkgs/applications/office/ledger-web/default.nix +++ b/pkgs/applications/office/ledger-web/default.nix @@ -1,6 +1,11 @@ -{ lib, bundlerApp, bundlerUpdateScript -, withPostgresql ? true, postgresql -, withSqlite ? false, sqlite +{ + lib, + bundlerApp, + bundlerUpdateScript, + withPostgresql ? true, + postgresql, + withSqlite ? false, + sqlite, }: bundlerApp { @@ -8,8 +13,7 @@ bundlerApp { gemdir = ./.; exes = [ "ledger_web" ]; - buildInputs = lib.optional withPostgresql postgresql - ++ lib.optional withSqlite sqlite; + buildInputs = lib.optional withPostgresql postgresql ++ lib.optional withSqlite sqlite; passthru.updateScript = bundlerUpdateScript "ledger-web"; @@ -17,7 +21,11 @@ bundlerApp { description = "Web frontend to the Ledger CLI tool"; homepage = "https://github.com/peterkeen/ledger-web"; license = licenses.mit; - maintainers = with maintainers; [ peterhoeg manveru nicknovitski ]; + maintainers = with maintainers; [ + peterhoeg + manveru + nicknovitski + ]; platforms = platforms.linux; mainProgram = "ledger_web"; }; diff --git a/pkgs/applications/office/ledger-web/gemset.nix b/pkgs/applications/office/ledger-web/gemset.nix index 3bdcc86595fe79..02f049066d804c 100644 --- a/pkgs/applications/office/ledger-web/gemset.nix +++ b/pkgs/applications/office/ledger-web/gemset.nix @@ -1,208 +1,240 @@ { backports = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17j5pf0b69bkn043wi4xd530ky53jbbnljr4bsjzlm4k8bzlknfn"; type = "gem"; }; version = "3.14.0"; }; database_cleaner = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05i0nf2aj70m61y3fspypdkc6d1qgibf5kav05a71b5gjz0k7y5x"; type = "gem"; }; version = "1.7.0"; }; diff-lcs = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18w22bjz424gzafv6nzv98h0aqkwz3d9xhm7cbr1wfbyas8zayza"; type = "gem"; }; version = "1.3"; }; directory_watcher = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fwc2shba7vks262ind74y3g76qp7znjq5q8b2dvza0yidgywhcq"; type = "gem"; }; version = "1.5.1"; }; ledger_web = { - dependencies = ["database_cleaner" "directory_watcher" "pg" "rack" "rspec" "sequel" "sinatra" "sinatra-contrib" "sinatra-session"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "database_cleaner" + "directory_watcher" + "pg" + "rack" + "rspec" + "sequel" + "sinatra" + "sinatra-contrib" + "sinatra-session" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0i4vagaiyayymlr41rsy4lg2cl1r011ib0ql9dgjadfy6imb4kqh"; type = "gem"; }; version = "1.5.2"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rl0qy4inf1mp8mybfk56dfga0mvx97zwpmq5xmiwl5r770171nv"; type = "gem"; }; version = "1.13.1"; }; mustermann = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lycgkmnyy0bf29nnd2zql5a6pcf8sp69g9v4xw0gcfcxgpwp7i1"; type = "gem"; }; version = "1.0.3"; }; pg = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fmnyxcyrvgdbgq7m09whgn9i8rwfybk0w8aii1nc4g5kqw0k2jy"; type = "gem"; }; version = "1.1.4"; }; rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0z90vflxbgjy2n84r7mbyax3i2vyvvrxxrf86ljzn5rw65jgnn2i"; type = "gem"; }; version = "2.0.7"; }; rack-protection = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15167q25rmxipqwi6hjqj3i1byi9iwl3xq9b7mdar7qiz39pmjsk"; type = "gem"; }; version = "2.0.5"; }; rspec = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15ppasvb9qrscwlyjz67ppw1lnxiqnkzx5vkx1bd8x5n3dhikxc3"; type = "gem"; }; version = "3.8.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rspec-support" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1p1s5bnbqp3sxk67y0fh0x884jjym527r0vgmhbm81w7aq6b7l4p"; type = "gem"; }; version = "3.8.0"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1c4gs5ybf7km0qshdm92p38zvg32n1j2kr5fgs2icacz7xf2y6fy"; type = "gem"; }; version = "3.8.3"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "06y508cjqycb4yfhxmb3nxn0v9xqf17qbd46l1dh4xhncinr4fyp"; type = "gem"; }; version = "3.8.0"; }; rspec-support = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p3m7drixrlhvj2zpc38b11x145bvm311x6f33jjcxmvcm0wq609"; type = "gem"; }; version = "3.8.0"; }; sequel = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwkc9kf4jn1x1ph4mgy4saiw2dirq6fhnkpyd0zq8rj1d0nay9a"; type = "gem"; }; version = "5.19.0"; }; sinatra = { - dependencies = ["mustermann" "rack" "rack-protection" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mustermann" + "rack" + "rack-protection" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1gasgn5f15myv08k10i16p326pchxjsy37pgqfw0xm66kcc5d7ry"; type = "gem"; }; version = "2.0.5"; }; sinatra-contrib = { - dependencies = ["backports" "multi_json" "mustermann" "rack-protection" "sinatra" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "backports" + "multi_json" + "mustermann" + "rack-protection" + "sinatra" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "093blvpfy5n7s8knaav9a4pm4j7kck9zidwz942qqd4g99fnk443"; type = "gem"; }; version = "2.0.5"; }; sinatra-session = { - dependencies = ["sinatra"]; - groups = ["default"]; - platforms = []; + dependencies = [ "sinatra" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "183xl8i4d2hc03afd1i52gwn2xi3vzrv02g22llhfy5wkmm44gmq"; type = "gem"; }; version = "1.0.0"; }; tilt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ca4k0clwf0rkvy7726x4nxpjxkpv67w043i39saxgldxd97zmwz"; type = "gem"; }; diff --git a/pkgs/applications/office/libreoffice/darwin/default.nix b/pkgs/applications/office/libreoffice/darwin/default.nix index f415b9164959d7..4b55faab1f5b6b 100644 --- a/pkgs/applications/office/libreoffice/darwin/default.nix +++ b/pkgs/applications/office/libreoffice/darwin/default.nix @@ -1,8 +1,9 @@ -{ stdenvNoCC -, lib -, fetchurl -, undmg -, writeScript +{ + stdenvNoCC, + lib, + fetchurl, + undmg, + writeScript, }: let @@ -30,8 +31,13 @@ stdenvNoCC.mkDerivation { inherit version; pname = "libreoffice"; src = fetchurl { - inherit (dist.${stdenvNoCC.hostPlatform.system} or - (throw "Unsupported system: ${stdenvNoCC.hostPlatform.system}")) url sha256; + inherit + (dist.${stdenvNoCC.hostPlatform.system} + or (throw "Unsupported system: ${stdenvNoCC.hostPlatform.system}") + ) + url + sha256 + ; }; nativeBuildInputs = [ undmg ]; @@ -56,15 +62,14 @@ stdenvNoCC.mkDerivation { aarch64Url = dist."aarch64-darwin".url; x86_64Url = dist."x86_64-darwin".url; in - writeScript "update-libreoffice.sh" - '' - #!/usr/bin/env nix-shell - #!nix-shell -i bash --argstr aarch64Url ${aarch64Url} --argstr x86_64Url ${x86_64Url} --argstr version ${version} ${updateNix} - set -eou pipefail + writeScript "update-libreoffice.sh" '' + #!/usr/bin/env nix-shell + #!nix-shell -i bash --argstr aarch64Url ${aarch64Url} --argstr x86_64Url ${x86_64Url} --argstr version ${version} ${updateNix} + set -eou pipefail - update-source-version libreoffice-bin $newVersion $newAarch64Sha256 --file=${defaultNixFile} --system=aarch64-darwin --ignore-same-version - update-source-version libreoffice-bin $newVersion $newX86_64Sha256 --file=${defaultNixFile} --system=x86_64-darwin --ignore-same-version - ''; + update-source-version libreoffice-bin $newVersion $newAarch64Sha256 --file=${defaultNixFile} --system=aarch64-darwin --ignore-same-version + update-source-version libreoffice-bin $newVersion $newX86_64Sha256 --file=${defaultNixFile} --system=x86_64-darwin --ignore-same-version + ''; meta = with lib; { description = "Comprehensive, professional-quality productivity suite, a variant of openoffice.org"; @@ -72,6 +77,9 @@ stdenvNoCC.mkDerivation { license = licenses.lgpl3; maintainers = with maintainers; [ tricktron ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - platforms = [ "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-darwin" + "aarch64-darwin" + ]; }; } diff --git a/pkgs/applications/office/libreoffice/darwin/update-test.nix b/pkgs/applications/office/libreoffice/darwin/update-test.nix index 994a923c556dca..0d9119eaeae748 100644 --- a/pkgs/applications/office/libreoffice/darwin/update-test.nix +++ b/pkgs/applications/office/libreoffice/darwin/update-test.nix @@ -1,45 +1,48 @@ # run the tests with nixt -v -{ pkgs ? import { }, nixt }: +{ + pkgs ? import { }, + nixt, +}: let inherit (import ./update-utils.nix { inherit (pkgs) lib; }) extractLatestVersionFromHtml extractSha256FromHtml - getLatestStableVersion; + getLatestStableVersion + ; in -nixt.mkSuite "LibreOffice Updater" -{ +nixt.mkSuite "LibreOffice Updater" { "should extract latest stable version from html" = let - latestVersionHtmlMock = - '' - - - - Index of /libreoffice/stable - - - -

Index of /libreoffice/stable

- - - - - - -
 NameLast modifiedSizeMetadata

 Parent Directory  -  
 7.2.7/10-Mar-2022 11:12 -  
 7.3.3/12-May-2022 10:06 -  
 7.2.6/05-May-2022 07:57 -  

-
Apache Server at download.documentfoundation.org Port 80
-
MirrorBrain powered by Apache
- - ''; + latestVersionHtmlMock = '' + + + + Index of /libreoffice/stable + + + +

Index of /libreoffice/stable

+ + + + + + +
 NameLast modifiedSizeMetadata

 Parent Directory  -  
 7.2.7/10-Mar-2022 11:12 -  
 7.3.3/12-May-2022 10:06 -  
 7.2.6/05-May-2022 07:57 -  

+
Apache Server at download.documentfoundation.org Port 80
+
MirrorBrain powered by Apache
+ + ''; actual = extractLatestVersionFromHtml latestVersionHtmlMock; in "7.3.3" == actual; - "should extract latest stable version from website" = (builtins.compareVersions getLatestStableVersion "7.3.3") >= 0; + "should extract latest stable version from website" = + (builtins.compareVersions getLatestStableVersion "7.3.3") >= 0; "should extract sha256 from html" = let diff --git a/pkgs/applications/office/libreoffice/darwin/update-utils.nix b/pkgs/applications/office/libreoffice/darwin/update-utils.nix index 766e858e33e2c7..d96d6027398729 100644 --- a/pkgs/applications/office/libreoffice/darwin/update-utils.nix +++ b/pkgs/applications/office/libreoffice/darwin/update-utils.nix @@ -1,42 +1,42 @@ { lib }: let # extractLatestVersionFromHtml :: String -> String - extractLatestVersionFromHtml = htmlString: + extractLatestVersionFromHtml = + htmlString: let majorMinorPatchGroup = "([0-9]+\\.[0-9]+\\.[0-9]+)"; splittedVersions = builtins.split "href=\"${majorMinorPatchGroup}" htmlString; - stableVersions = builtins.concatLists - (builtins.filter (e: builtins.isList e) - splittedVersions); + stableVersions = builtins.concatLists (builtins.filter (e: builtins.isList e) splittedVersions); in - if stableVersions == [ ] - then abort "Failed to extract versions from html." - else lib.last (builtins.sort builtins.lessThan stableVersions); + if stableVersions == [ ] then + abort "Failed to extract versions from html." + else + lib.last (builtins.sort builtins.lessThan stableVersions); # getHtml :: String -> String - getHtml = url: - builtins.readFile (builtins.fetchurl url); + getHtml = url: builtins.readFile (builtins.fetchurl url); # getLatestStableVersion :: String - getLatestStableVersion = - extractLatestVersionFromHtml - (getHtml "https://download.documentfoundation.org/libreoffice/stable/"); + getLatestStableVersion = extractLatestVersionFromHtml ( + getHtml "https://download.documentfoundation.org/libreoffice/stable/" + ); # extractSha256FromHtml :: String -> String - extractSha256FromHtml = htmlString: + extractSha256FromHtml = + htmlString: let sha256 = (builtins.match ".*([0-9a-fA-F]{64}).*" htmlString); in - if sha256 == [ ] - then abort "Failed to extract sha256 from html." - else builtins.head sha256; + if sha256 == [ ] then abort "Failed to extract sha256 from html." else builtins.head sha256; # getSha256 :: String -> String - getSha256 = dmgUrl: oldVersion: newVersion: + getSha256 = + dmgUrl: oldVersion: newVersion: extractSha256FromHtml (getHtml (getSha256Url dmgUrl oldVersion newVersion)); # getSha256Url :: String -> String -> String -> String - getSha256Url = dmgUrl: oldVersion: newVersion: + getSha256Url = + dmgUrl: oldVersion: newVersion: (builtins.replaceStrings [ oldVersion ] [ newVersion ] dmgUrl) + ".sha256"; in @@ -47,5 +47,6 @@ in getLatestStableVersion extractSha256FromHtml getSha256 - getSha256Url; + getSha256Url + ; } diff --git a/pkgs/applications/office/libreoffice/darwin/update.nix b/pkgs/applications/office/libreoffice/darwin/update.nix index b74cca802fcb1e..f3c5c758b428c4 100644 --- a/pkgs/applications/office/libreoffice/darwin/update.nix +++ b/pkgs/applications/office/libreoffice/darwin/update.nix @@ -1,14 +1,15 @@ # Impure functions, for passthru.updateScript runtime only -{ aarch64Url -, x86_64Url -, version -, pkgs ? import ../../../../../default.nix { } -, +{ + aarch64Url, + x86_64Url, + version, + pkgs ? import ../../../../../default.nix { }, }: let inherit (import ./update-utils.nix { inherit (pkgs) lib; }) getLatestStableVersion - getSha256; + getSha256 + ; in pkgs.mkShell rec { buildInputs = [ pkgs.common-updater-scripts ]; diff --git a/pkgs/applications/office/libreoffice/wrapper.nix b/pkgs/applications/office/libreoffice/wrapper.nix index aeab3da08dd7a4..1bb8a60c35841f 100644 --- a/pkgs/applications/office/libreoffice/wrapper.nix +++ b/pkgs/applications/office/libreoffice/wrapper.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -# The unwrapped libreoffice derivation -, unwrapped -, makeWrapper -, xorg # for lndir -, runCommand -# For Emulating wrapGAppsHook3 -, gsettings-desktop-schemas -, hicolor-icon-theme -, dconf -, librsvg -, gdk-pixbuf -# some scripts need these when used in conjuction with firejail -, coreutils -, gnugrep -# Configuration options for the wrapper -, extraMakeWrapperArgs ? [] -, dbusVerify ? stdenv.hostPlatform.isLinux -, dbus +{ + lib, + stdenv, + # The unwrapped libreoffice derivation + unwrapped, + makeWrapper, + xorg, # for lndir + runCommand, + # For Emulating wrapGAppsHook3 + gsettings-desktop-schemas, + hicolor-icon-theme, + dconf, + librsvg, + gdk-pixbuf, + # some scripts need these when used in conjuction with firejail + coreutils, + gnugrep, + # Configuration options for the wrapper + extraMakeWrapperArgs ? [ ], + dbusVerify ? stdenv.hostPlatform.isLinux, + dbus, }: let @@ -25,110 +26,154 @@ let major = lib.versions.major version; minor = lib.versions.minor version; - makeWrapperArgs = builtins.concatStringsSep " " ([ - "--set" "GDK_PIXBUF_MODULE_FILE" "${librsvg}/${gdk-pixbuf.moduleDir}.cache" - "--prefix" "GIO_EXTRA_MODULES" ":" "${lib.getLib dconf}/lib/gio/modules" - "--prefix" "XDG_DATA_DIRS" ":" "${unwrapped.gtk3}/share/gsettings-schemas/${unwrapped.gtk3.name}" - "--prefix" "XDG_DATA_DIRS" ":" "$out/share" - "--prefix" "XDG_DATA_DIRS" ":" "${gsettings-desktop-schemas}/share/gsettings-schemas/${gsettings-desktop-schemas.name}" - "--prefix" "XDG_DATA_DIRS" ":" "${hicolor-icon-theme}/share" - "--prefix" "GST_PLUGIN_SYSTEM_PATH_1_0" ":" + makeWrapperArgs = builtins.concatStringsSep " " ( + [ + "--set" + "GDK_PIXBUF_MODULE_FILE" + "${librsvg}/${gdk-pixbuf.moduleDir}.cache" + "--prefix" + "GIO_EXTRA_MODULES" + ":" + "${lib.getLib dconf}/lib/gio/modules" + "--prefix" + "XDG_DATA_DIRS" + ":" + "${unwrapped.gtk3}/share/gsettings-schemas/${unwrapped.gtk3.name}" + "--prefix" + "XDG_DATA_DIRS" + ":" + "$out/share" + "--prefix" + "XDG_DATA_DIRS" + ":" + "${gsettings-desktop-schemas}/share/gsettings-schemas/${gsettings-desktop-schemas.name}" + "--prefix" + "XDG_DATA_DIRS" + ":" + "${hicolor-icon-theme}/share" + "--prefix" + "GST_PLUGIN_SYSTEM_PATH_1_0" + ":" "${lib.makeSearchPath "lib/girepository-1.0" unwrapped.gst_packages}" - "--suffix" "PATH" ":" "${lib.makeBinPath [ coreutils gnugrep ]}" - ] ++ lib.optionals unwrapped.kdeIntegration [ - "--prefix" "QT_PLUGIN_PATH" ":" "${ - lib.makeSearchPath - unwrapped.qtbase.qtPluginPrefix - (builtins.map lib.getBin unwrapped.qtPackages) - }" - "--prefix" "QML2_IMPORT_PATH" ":" "${ - lib.makeSearchPath unwrapped.qtbase.qtQmlPrefix - (builtins.map lib.getBin unwrapped.qmlPackages) - }" - ] ++ [ - # Add dictionaries from all NIX_PROFILES - "--run" (lib.escapeShellArg '' - for PROFILE in $NIX_PROFILES; do - HU_DIR="$PROFILE/share/hunspell" - HY_DIR="$PROFILE/share/hyphen" - if [ -d "$HU_DIR" ]; then - export DICPATH=$DICPATH''${DICPATH:+:}$HU_DIR - fi - if [ -d "$HY_DIR" ]; then - export DICPATH=$DICPATH''${DICPATH:+:}$HY_DIR - fi - done - '') - ] ++ lib.optionals dbusVerify [ - # If no dbus is running, start a dedicated dbus daemon - "--run" (lib.escapeShellArg '' - if ! ( test -n "$DBUS_SESSION_BUS_ADDRESS" ); then - dbus_tmp_dir="/run/user/$(id -u)/libreoffice-dbus" - if ! test -d "$dbus_tmp_dir" && test -d "/run"; then - mkdir -p "$dbus_tmp_dir" - fi - if ! test -d "$dbus_tmp_dir"; then - dbus_tmp_dir="/tmp/libreoffice-$(id -u)/libreoffice-dbus" - mkdir -p "$dbus_tmp_dir" - fi - dbus_socket_dir="$(mktemp -d -p "$dbus_tmp_dir")" - "${dbus}"/bin/dbus-daemon \ - --nopidfile \ - --nofork \ - --config-file "${dbus}"/share/dbus-1/session.conf \ - --address "unix:path=$dbus_socket_dir/session" &> /dev/null & - dbus_pid=$! - export DBUS_SESSION_BUS_ADDRESS="unix:path=$dbus_socket_dir/session" - fi - '') - ] ++ [ - "--inherit-argv0" - ] ++ extraMakeWrapperArgs + "--suffix" + "PATH" + ":" + "${lib.makeBinPath [ + coreutils + gnugrep + ]}" + ] + ++ lib.optionals unwrapped.kdeIntegration [ + "--prefix" + "QT_PLUGIN_PATH" + ":" + "${lib.makeSearchPath unwrapped.qtbase.qtPluginPrefix ( + builtins.map lib.getBin unwrapped.qtPackages + )}" + "--prefix" + "QML2_IMPORT_PATH" + ":" + "${lib.makeSearchPath unwrapped.qtbase.qtQmlPrefix (builtins.map lib.getBin unwrapped.qmlPackages)}" + ] + ++ [ + # Add dictionaries from all NIX_PROFILES + "--run" + (lib.escapeShellArg '' + for PROFILE in $NIX_PROFILES; do + HU_DIR="$PROFILE/share/hunspell" + HY_DIR="$PROFILE/share/hyphen" + if [ -d "$HU_DIR" ]; then + export DICPATH=$DICPATH''${DICPATH:+:}$HU_DIR + fi + if [ -d "$HY_DIR" ]; then + export DICPATH=$DICPATH''${DICPATH:+:}$HY_DIR + fi + done + '') + ] + ++ lib.optionals dbusVerify [ + # If no dbus is running, start a dedicated dbus daemon + "--run" + (lib.escapeShellArg '' + if ! ( test -n "$DBUS_SESSION_BUS_ADDRESS" ); then + dbus_tmp_dir="/run/user/$(id -u)/libreoffice-dbus" + if ! test -d "$dbus_tmp_dir" && test -d "/run"; then + mkdir -p "$dbus_tmp_dir" + fi + if ! test -d "$dbus_tmp_dir"; then + dbus_tmp_dir="/tmp/libreoffice-$(id -u)/libreoffice-dbus" + mkdir -p "$dbus_tmp_dir" + fi + dbus_socket_dir="$(mktemp -d -p "$dbus_tmp_dir")" + "${dbus}"/bin/dbus-daemon \ + --nopidfile \ + --nofork \ + --config-file "${dbus}"/share/dbus-1/session.conf \ + --address "unix:path=$dbus_socket_dir/session" &> /dev/null & + dbus_pid=$! + export DBUS_SESSION_BUS_ADDRESS="unix:path=$dbus_socket_dir/session" + fi + '') + ] + ++ [ + "--inherit-argv0" + ] + ++ extraMakeWrapperArgs ); -in runCommand "${unwrapped.name}-wrapped" { - inherit (unwrapped) meta; - paths = [ unwrapped ]; - nativeBuildInputs = [ makeWrapper xorg.lndir ]; - passthru = { - inherit unwrapped; - # For backwards compatibility: - libreoffice = lib.warn "libreoffice: Use the unwrapped attributed, using libreoffice.libreoffice is deprecated." unwrapped; - inherit (unwrapped) kdeIntegration; - }; -} ('' - mkdir -p $out/share - for dir in ${unwrapped}/share/*; do - dirname="''${dir##*/}" - if [[ $dirname == "applications" ]]; then - cp -r $dir/ $out/share/ - else - ln -s $dir $out/share/ - fi - done - for f in $out/share/applications/*.desktop; do - substituteInPlace "$f" \ - --replace "Exec=libreoffice${major}.${minor}" "Exec=soffice" - done +in +runCommand "${unwrapped.name}-wrapped" + { + inherit (unwrapped) meta; + paths = [ unwrapped ]; + nativeBuildInputs = [ + makeWrapper + xorg.lndir + ]; + passthru = { + inherit unwrapped; + # For backwards compatibility: + libreoffice = lib.warn "libreoffice: Use the unwrapped attributed, using libreoffice.libreoffice is deprecated." unwrapped; + inherit (unwrapped) kdeIntegration; + }; + } + ( + '' + mkdir -p $out/share + for dir in ${unwrapped}/share/*; do + dirname="''${dir##*/}" + if [[ $dirname == "applications" ]]; then + cp -r $dir/ $out/share/ + else + ln -s $dir $out/share/ + fi + done + for f in $out/share/applications/*.desktop; do + substituteInPlace "$f" \ + --replace "Exec=libreoffice${major}.${minor}" "Exec=soffice" + done - mkdir -p $out/bin - mkdir -p $out/lib/libreoffice/program - lndir -silent ${unwrapped}/lib/libreoffice/program $out/lib/libreoffice/program - for i in sbase scalc sdraw smath swriter simpress soffice unopkg; do - # Delete the symlink created by lndir, and replace it by our wrapper - rm $out/lib/libreoffice/program/$i - makeWrapper \ - ${unwrapped}/lib/libreoffice/program/$i \ - $out/lib/libreoffice/program/$i \ - ${makeWrapperArgs} -'' + lib.optionalString dbusVerify '' - # Delete the dbus socket directory after libreoffice quits - sed -i 's/^exec -a "$0" //g' $out/lib/libreoffice/program/$i - echo 'code="$?"' >> $out/lib/libreoffice/program/$i - echo 'test -n "$dbus_socket_dir" && { rm -rf "$dbus_socket_dir"; kill $dbus_pid; }' >> $out/lib/libreoffice/program/$i - echo 'exit "$code"' >> $out/lib/libreoffice/program/$i -'' + '' - ln -s $out/lib/libreoffice/program/$i $out/bin/$i - done - # A symlink many users rely upon - ln -s $out/bin/soffice $out/bin/libreoffice -'') + mkdir -p $out/bin + mkdir -p $out/lib/libreoffice/program + lndir -silent ${unwrapped}/lib/libreoffice/program $out/lib/libreoffice/program + for i in sbase scalc sdraw smath swriter simpress soffice unopkg; do + # Delete the symlink created by lndir, and replace it by our wrapper + rm $out/lib/libreoffice/program/$i + makeWrapper \ + ${unwrapped}/lib/libreoffice/program/$i \ + $out/lib/libreoffice/program/$i \ + ${makeWrapperArgs} + '' + + lib.optionalString dbusVerify '' + # Delete the dbus socket directory after libreoffice quits + sed -i 's/^exec -a "$0" //g' $out/lib/libreoffice/program/$i + echo 'code="$?"' >> $out/lib/libreoffice/program/$i + echo 'test -n "$dbus_socket_dir" && { rm -rf "$dbus_socket_dir"; kill $dbus_pid; }' >> $out/lib/libreoffice/program/$i + echo 'exit "$code"' >> $out/lib/libreoffice/program/$i + '' + + '' + ln -s $out/lib/libreoffice/program/$i $out/bin/$i + done + # A symlink many users rely upon + ln -s $out/bin/soffice $out/bin/libreoffice + '' + ) diff --git a/pkgs/applications/office/mendeley/default.nix b/pkgs/applications/office/mendeley/default.nix index 25ee02de209fdf..d00ea783405e1f 100644 --- a/pkgs/applications/office/mendeley/default.nix +++ b/pkgs/applications/office/mendeley/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchurl -, appimageTools -, gconf -, imagemagick +{ + lib, + fetchurl, + appimageTools, + gconf, + imagemagick, }: let @@ -19,7 +20,8 @@ let appimageContents = appimageTools.extractType2 { inherit pname version src; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; extraInstallCommands = '' @@ -38,7 +40,7 @@ in appimageTools.wrapType2 { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ atila ]; + maintainers = with maintainers; [ atila ]; mainProgram = "mendeley-reference-manager"; }; diff --git a/pkgs/applications/office/micropad/default.nix b/pkgs/applications/office/micropad/default.nix index 0d06ca5e8afe35..1dd3394e63276b 100644 --- a/pkgs/applications/office/micropad/default.nix +++ b/pkgs/applications/office/micropad/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, yarnBuildHook -, fetchzip -, makeWrapper -, makeDesktopItem -, electron -, desktopToDarwinBundle -, copyDesktopItems +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + yarnBuildHook, + fetchzip, + makeWrapper, + makeDesktopItem, + electron, + desktopToDarwinBundle, + copyDesktopItems, }: stdenv.mkDerivation (finalAttrs: { @@ -34,8 +35,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-ESYSHuHLNsn3EYKIe2p0kg142jyC0USB+Ef//oGeF08="; }; - nativeBuildInputs = [ yarnBuildHook copyDesktopItems makeWrapper ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; + nativeBuildInputs = [ + yarnBuildHook + copyDesktopItems + makeWrapper + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; installPhase = '' runHook preInstall @@ -74,7 +78,7 @@ stdenv.mkDerivation (finalAttrs: { desktopName = "µPad"; startupWMClass = "µPad"; comment = finalAttrs.meta.description; - categories = ["Office"]; + categories = [ "Office" ]; }) ]; @@ -82,7 +86,7 @@ stdenv.mkDerivation (finalAttrs: { description = "A powerful note-taking app that helps you organise + take notes without restrictions"; homepage = "https://getmicropad.com/"; license = lib.licenses.mpl20; - maintainers = with lib.maintainers; [rhysmdnz]; + maintainers = with lib.maintainers; [ rhysmdnz ]; inherit (electron.meta) platforms; mainProgram = "micropad"; }; diff --git a/pkgs/applications/office/mmex/default.nix b/pkgs/applications/office/mmex/default.nix index 53cc19e5f1d382..af29fa9e9b0574 100644 --- a/pkgs/applications/office/mmex/default.nix +++ b/pkgs/applications/office/mmex/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, appstream -, cmake -, fetchpatch -, gettext -, git -, makeWrapper -, lsb-release -, pkg-config -, wrapGAppsHook3 -, curl -, sqlite -, wxGTK32 -, gtk3 -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + appstream, + cmake, + fetchpatch, + gettext, + git, + makeWrapper, + lsb-release, + pkg-config, + wrapGAppsHook3, + curl, + sqlite, + wxGTK32, + gtk3, + darwin, }: stdenv.mkDerivation rec { @@ -30,50 +31,59 @@ stdenv.mkDerivation rec { }; patches = [ - (fetchpatch { # https://github.com/moneymanagerex/moneymanagerex/pull/6716 + (fetchpatch { + # https://github.com/moneymanagerex/moneymanagerex/pull/6716 name = "workaround-appstream-1.0.3.patch"; url = "https://github.com/moneymanagerex/moneymanagerex/commit/bb98eab92d95b7315d27f4e59ae59b50587106d8.patch"; hash = "sha256-98OyFO2nnGBRTIirxZ3jX1NPvsw5kVT8nsCSSmyfabo="; }) ]; - postPatch = lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) '' - substituteInPlace src/platfdep_mac.mm \ - --replace "appearance.name == NSAppearanceNameDarkAqua" "NO" - '' + lib.optionalString (stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isx86_64) '' - substituteInPlace 3rd/CMakeLists.txt \ - --replace "-msse4.2 -maes" "" - ''; + postPatch = + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) '' + substituteInPlace src/platfdep_mac.mm \ + --replace "appearance.name == NSAppearanceNameDarkAqua" "NO" + '' + + lib.optionalString (stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isx86_64) '' + substituteInPlace 3rd/CMakeLists.txt \ + --replace "-msse4.2 -maes" "" + ''; - nativeBuildInputs = [ - appstream # for appstreamcli - cmake - gettext - git - makeWrapper - pkg-config - wrapGAppsHook3 - wxGTK32 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - lsb-release - ]; + nativeBuildInputs = + [ + appstream # for appstreamcli + cmake + gettext + git + makeWrapper + pkg-config + wrapGAppsHook3 + wxGTK32 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + lsb-release + ]; - buildInputs = [ - curl - sqlite - wxGTK32 - gtk3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.libobjc - ]; + buildInputs = + [ + curl + sqlite + wxGTK32 + gtk3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.libobjc + ]; strictDeps = true; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-deprecated-copy" - "-Wno-old-style-cast" - "-Wno-unused-parameter" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-deprecated-copy" + "-Wno-old-style-cast" + "-Wno-unused-parameter" + ] + ); postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' mkdir -p $out/{Applications,bin} diff --git a/pkgs/applications/office/mytetra/default.nix b/pkgs/applications/office/mytetra/default.nix index 8195a73bb2075b..53e3fcad15c8c3 100644 --- a/pkgs/applications/office/mytetra/default.nix +++ b/pkgs/applications/office/mytetra/default.nix @@ -1,4 +1,12 @@ -{ lib, mkDerivation, fetchFromGitHub, qmake, qtsvg, makeWrapper, xdg-utils }: +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qtsvg, + makeWrapper, + xdg-utils, +}: mkDerivation rec { pname = "mytetra"; @@ -11,7 +19,10 @@ mkDerivation rec { sha256 = "sha256-jQXnDoLkqbDZxfsYKPDsTOE7p/BFeA8wEznpbkRVGdw="; }; - nativeBuildInputs = [ qmake makeWrapper ]; + nativeBuildInputs = [ + qmake + makeWrapper + ]; buildInputs = [ qtsvg ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/applications/office/paperwork/openpaperwork-core.nix b/pkgs/applications/office/paperwork/openpaperwork-core.nix index ed9a7d6ed5ad04..01317f647589d9 100644 --- a/pkgs/applications/office/paperwork/openpaperwork-core.nix +++ b/pkgs/applications/office/paperwork/openpaperwork-core.nix @@ -1,17 +1,18 @@ -{ buildPythonPackage -, lib -, fetchFromGitLab +{ + buildPythonPackage, + lib, + fetchFromGitLab, -, isPy3k -, isPyPy + isPy3k, + isPyPy, -, distro -, setuptools -, psutil -, certifi -, setuptools-scm + distro, + setuptools, + psutil, + certifi, + setuptools-scm, -, pkgs + pkgs, }: buildPythonPackage rec { @@ -54,7 +55,10 @@ buildPythonPackage rec { description = "Backend part of Paperwork (Python API, no UI)"; homepage = "https://openpaper.work/"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ aszlig symphorien ]; + maintainers = with lib.maintainers; [ + aszlig + symphorien + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/applications/office/paperwork/openpaperwork-gtk.nix b/pkgs/applications/office/paperwork/openpaperwork-gtk.nix index 95d5effa151ffb..2e88ee23bfe59a 100644 --- a/pkgs/applications/office/paperwork/openpaperwork-gtk.nix +++ b/pkgs/applications/office/paperwork/openpaperwork-gtk.nix @@ -1,17 +1,18 @@ -{ buildPythonPackage -, lib -, fetchFromGitLab +{ + buildPythonPackage, + lib, + fetchFromGitLab, -, isPy3k -, isPyPy + isPy3k, + isPyPy, -, openpaperwork-core -, pillow -, pygobject3 -, distro -, setuptools-scm + openpaperwork-core, + pillow, + pygobject3, + distro, + setuptools-scm, -, pkgs + pkgs, }: buildPythonPackage rec { @@ -54,7 +55,10 @@ buildPythonPackage rec { description = "Reusable GTK components of Paperwork"; homepage = "https://openpaper.work/"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ aszlig symphorien ]; + maintainers = with lib.maintainers; [ + aszlig + symphorien + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/applications/office/paperwork/paperwork-backend.nix b/pkgs/applications/office/paperwork/paperwork-backend.nix index 4460e50ab6246c..0d0cee9f69fc9a 100644 --- a/pkgs/applications/office/paperwork/paperwork-backend.nix +++ b/pkgs/applications/office/paperwork/paperwork-backend.nix @@ -1,28 +1,29 @@ -{ buildPythonPackage -, lib -, fetchFromGitLab -, pyenchant -, scikit-learn -, pypillowfight -, pycountry -, whoosh -, termcolor -, pygobject3 -, pyocr -, natsort -, libinsane -, distro -, openpaperwork-core -, openpaperwork-gtk -, psutil -, gtk3 -, poppler_gi -, gettext -, which -, shared-mime-info -, libreoffice -, unittestCheckHook -, setuptools-scm +{ + buildPythonPackage, + lib, + fetchFromGitLab, + pyenchant, + scikit-learn, + pypillowfight, + pycountry, + whoosh, + termcolor, + pygobject3, + pyocr, + natsort, + libinsane, + distro, + openpaperwork-core, + openpaperwork-gtk, + psutil, + gtk3, + poppler_gi, + gettext, + which, + shared-mime-info, + libreoffice, + unittestCheckHook, + setuptools-scm, }: buildPythonPackage rec { @@ -87,6 +88,9 @@ buildPythonPackage rec { description = "Backend part of Paperwork (Python API, no UI)"; homepage = "https://openpaper.work"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ aszlig symphorien ]; + maintainers = with maintainers; [ + aszlig + symphorien + ]; }; } diff --git a/pkgs/applications/office/paperwork/paperwork-gtk.nix b/pkgs/applications/office/paperwork/paperwork-gtk.nix index c9b9efeba89064..3f8876779d830b 100644 --- a/pkgs/applications/office/paperwork/paperwork-gtk.nix +++ b/pkgs/applications/office/paperwork/paperwork-gtk.nix @@ -1,27 +1,33 @@ -{ lib -, python3Packages -, gtk3 -, cairo -, adwaita-icon-theme -, librsvg -, xvfb-run -, dbus -, libnotify -, wrapGAppsHook3 -, fetchFromGitLab -, which -, gettext -, gobject-introspection -, gdk-pixbuf -, texliveSmall -, imagemagick -, perlPackages -, writeScript +{ + lib, + python3Packages, + gtk3, + cairo, + adwaita-icon-theme, + librsvg, + xvfb-run, + dbus, + libnotify, + wrapGAppsHook3, + fetchFromGitLab, + which, + gettext, + gobject-introspection, + gdk-pixbuf, + texliveSmall, + imagemagick, + perlPackages, + writeScript, }: let documentation_deps = [ - (texliveSmall.withPackages (ps: with ps; [ wrapfig gensymb ])) + (texliveSmall.withPackages ( + ps: with ps; [ + wrapfig + gensymb + ] + )) xvfb-run imagemagick perlPackages.Po4a @@ -146,7 +152,10 @@ python3Packages.buildPythonApplication rec { description = "Personal document manager for scanned documents"; homepage = "https://openpaper.work/"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ aszlig symphorien ]; + maintainers = with lib.maintainers; [ + aszlig + symphorien + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/applications/office/paperwork/paperwork-shell.nix b/pkgs/applications/office/paperwork/paperwork-shell.nix index cbda78976b5b1a..21e3976a9adaa3 100644 --- a/pkgs/applications/office/paperwork/paperwork-shell.nix +++ b/pkgs/applications/office/paperwork/paperwork-shell.nix @@ -1,21 +1,22 @@ -{ buildPythonPackage -, lib -, fetchFromGitLab +{ + buildPythonPackage, + lib, + fetchFromGitLab, -, isPy3k -, isPyPy + isPy3k, + isPyPy, -, openpaperwork-core -, openpaperwork-gtk -, paperwork-backend -, fabulous -, rich -, getkey -, psutil -, shared-mime-info -, setuptools-scm + openpaperwork-core, + openpaperwork-gtk, + paperwork-backend, + fabulous, + rich, + getkey, + psutil, + shared-mime-info, + setuptools-scm, -, pkgs + pkgs, }: buildPythonPackage rec { @@ -65,6 +66,9 @@ buildPythonPackage rec { description = "CLI for Paperwork"; homepage = "https://openpaper.work/"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ aszlig symphorien ]; + maintainers = with lib.maintainers; [ + aszlig + symphorien + ]; }; } diff --git a/pkgs/applications/office/paperwork/src.nix b/pkgs/applications/office/paperwork/src.nix index 8b8735d9ac354f..5f83eddd3fb795 100644 --- a/pkgs/applications/office/paperwork/src.nix +++ b/pkgs/applications/office/paperwork/src.nix @@ -1,4 +1,4 @@ -{fetchFromGitLab}: +{ fetchFromGitLab }: rec { version = "2.2.5"; src = fetchFromGitLab { diff --git a/pkgs/applications/office/pdfmixtool/default.nix b/pkgs/applications/office/pdfmixtool/default.nix index 73a5b54cb4424e..61443dddcde053 100644 --- a/pkgs/applications/office/pdfmixtool/default.nix +++ b/pkgs/applications/office/pdfmixtool/default.nix @@ -1,15 +1,16 @@ -{ lib -, mkDerivation -, fetchFromGitLab -, fetchpatch -, fetchpatch2 -, cmake -, pkg-config -, qtbase -, qttools -, qpdf -, podofo -, imagemagick +{ + lib, + mkDerivation, + fetchFromGitLab, + fetchpatch, + fetchpatch2, + cmake, + pkg-config, + qtbase, + qttools, + qpdf, + podofo, + imagemagick, }: mkDerivation rec { @@ -57,4 +58,3 @@ mkDerivation rec { maintainers = with maintainers; [ onny ]; }; } - diff --git a/pkgs/applications/office/qnotero/default.nix b/pkgs/applications/office/qnotero/default.nix index 4fd2e741adb00e..028c5bad8aea9b 100644 --- a/pkgs/applications/office/qnotero/default.nix +++ b/pkgs/applications/office/qnotero/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, python3Packages, wrapQtAppsHook }: +{ + lib, + stdenv, + fetchFromGitHub, + python3Packages, + wrapQtAppsHook, +}: python3Packages.buildPythonPackage rec { pname = "qnotero"; @@ -12,14 +18,17 @@ python3Packages.buildPythonPackage rec { sha256 = "sha256-Rym7neluRbYCpuezRQyLc6gSl3xbVR9fvhOxxW5+Nzo="; }; - propagatedBuildInputs = [ python3Packages.pyqt5 wrapQtAppsHook ]; + propagatedBuildInputs = [ + python3Packages.pyqt5 + wrapQtAppsHook + ]; patchPhase = '' - substituteInPlace ./setup.py \ - --replace "/usr/share" "usr/share" + substituteInPlace ./setup.py \ + --replace "/usr/share" "usr/share" - substituteInPlace ./libqnotero/_themes/light.py \ - --replace "/usr/share" "$out/usr/share" + substituteInPlace ./libqnotero/_themes/light.py \ + --replace "/usr/share" "$out/usr/share" ''; preFixup = '' diff --git a/pkgs/applications/office/qpdfview/default.nix b/pkgs/applications/office/qpdfview/default.nix index 7d44c684fd99e6..ccac3a6e385a87 100644 --- a/pkgs/applications/office/qpdfview/default.nix +++ b/pkgs/applications/office/qpdfview/default.nix @@ -1,17 +1,18 @@ -{ lib -, mkDerivation -, fetchurl -, qmake -, qtbase -, qttools -, qtsvg -, pkg-config -, poppler -, djvulibre -, libspectre -, cups -, file -, ghostscript +{ + lib, + mkDerivation, + fetchurl, + qmake, + qtbase, + qttools, + qtsvg, + pkg-config, + poppler, + djvulibre, + libspectre, + cups, + file, + ghostscript, }: mkDerivation rec { diff --git a/pkgs/applications/office/scribus/default.nix b/pkgs/applications/office/scribus/default.nix index f95ac14c67ab56..2d67bd99c12b89 100644 --- a/pkgs/applications/office/scribus/default.nix +++ b/pkgs/applications/office/scribus/default.nix @@ -1,34 +1,33 @@ -{ boost -, cairo -, cmake -, cups -, fetchurl -, fontconfig -, freetype -, harfbuzzFull -, hunspell -, lcms2 -, libjpeg -, libtiff -, libxml2 -, pixman -, pkg-config -, podofo -, poppler -, poppler_data -, python3 -, lib -, stdenv -, qt5 +{ + boost, + cairo, + cmake, + cups, + fetchurl, + fontconfig, + freetype, + harfbuzzFull, + hunspell, + lcms2, + libjpeg, + libtiff, + libxml2, + pixman, + pkg-config, + podofo, + poppler, + poppler_data, + python3, + lib, + stdenv, + qt5, }: let - pythonEnv = python3.withPackages ( - ps: [ - ps.pillow - ps.tkinter - ] - ); + pythonEnv = python3.withPackages (ps: [ + ps.pillow + ps.tkinter + ]); in stdenv.mkDerivation (finalAttrs: { pname = "scribus"; diff --git a/pkgs/applications/office/semantik/default.nix b/pkgs/applications/office/semantik/default.nix index b7007719a694d5..568a5e0ad1424c 100644 --- a/pkgs/applications/office/semantik/default.nix +++ b/pkgs/applications/office/semantik/default.nix @@ -1,25 +1,26 @@ -{ lib -, mkDerivation -, fetchFromGitLab -, wafHook -, pkg-config -, cmake -, qtbase -, python3 -, qtwebengine -, qtsvg -, ncurses6 -, kio -, kauth -, kiconthemes -, kconfigwidgets -, kxmlgui -, kcoreaddons -, kconfig -, kwidgetsaddons -, ki18n -, sonnet -, kdelibs4support +{ + lib, + mkDerivation, + fetchFromGitLab, + wafHook, + pkg-config, + cmake, + qtbase, + python3, + qtwebengine, + qtsvg, + ncurses6, + kio, + kauth, + kiconthemes, + kconfigwidgets, + kxmlgui, + kcoreaddons, + kconfig, + kwidgetsaddons, + ki18n, + sonnet, + kdelibs4support, }: mkDerivation rec { @@ -58,7 +59,14 @@ mkDerivation rec { --replace /usr/include/KF5/KDELibs4Support "${lib.getDev kdelibs4support}/include/KF5/KDELibs4Support" ''; - nativeBuildInputs = [ (lib.getDev qtsvg) (lib.getLib qtsvg) python3 pkg-config wafHook cmake ]; + nativeBuildInputs = [ + (lib.getDev qtsvg) + (lib.getLib qtsvg) + python3 + pkg-config + wafHook + cmake + ]; buildInputs = [ qtbase diff --git a/pkgs/applications/office/skrooge/default.nix b/pkgs/applications/office/skrooge/default.nix index 851f53039dd4d7..abd9c2a909b71b 100644 --- a/pkgs/applications/office/skrooge/default.nix +++ b/pkgs/applications/office/skrooge/default.nix @@ -1,8 +1,31 @@ -{ mkDerivation, lib, fetchurl, - cmake, extra-cmake-modules, qtwebengine, qtscript, grantlee, qtxmlpatterns, - kxmlgui, kwallet, kparts, kdoctools, kjobwidgets, kdesignerplugin, - kiconthemes, knewstuff, sqlcipher, qca-qt5, kactivities, karchive, - kguiaddons, knotifyconfig, krunner, kwindowsystem, libofx, shared-mime-info +{ + mkDerivation, + lib, + fetchurl, + cmake, + extra-cmake-modules, + qtwebengine, + qtscript, + grantlee, + qtxmlpatterns, + kxmlgui, + kwallet, + kparts, + kdoctools, + kjobwidgets, + kdesignerplugin, + kiconthemes, + knewstuff, + sqlcipher, + qca-qt5, + kactivities, + karchive, + kguiaddons, + knotifyconfig, + krunner, + kwindowsystem, + libofx, + shared-mime-info, }: mkDerivation rec { @@ -15,13 +38,33 @@ mkDerivation rec { }; nativeBuildInputs = [ - cmake extra-cmake-modules kdoctools shared-mime-info + cmake + extra-cmake-modules + kdoctools + shared-mime-info ]; buildInputs = [ - qtwebengine qtscript grantlee kxmlgui kwallet kparts qtxmlpatterns - kjobwidgets kdesignerplugin kiconthemes knewstuff sqlcipher qca-qt5 - kactivities karchive kguiaddons knotifyconfig krunner kwindowsystem libofx + qtwebengine + qtscript + grantlee + kxmlgui + kwallet + kparts + qtxmlpatterns + kjobwidgets + kdesignerplugin + kiconthemes + knewstuff + sqlcipher + qca-qt5 + kactivities + karchive + kguiaddons + knotifyconfig + krunner + kwindowsystem + libofx ]; # SKG_DESIGNER must be used to generate the needed library for QtDesigner. diff --git a/pkgs/applications/office/tagainijisho/default.nix b/pkgs/applications/office/tagainijisho/default.nix index cc2522ffa72824..6915ded792e584 100644 --- a/pkgs/applications/office/tagainijisho/default.nix +++ b/pkgs/applications/office/tagainijisho/default.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchzip, qtbase, qttools, cmake, sqlite, wrapQtAppsHook }: +{ + stdenv, + lib, + fetchzip, + qtbase, + qttools, + cmake, + sqlite, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "tagainijisho"; @@ -9,8 +18,15 @@ stdenv.mkDerivation rec { hash = "sha256-CTDMoYGbVE4W0SDerW//aAdUVsySWFQycSy0I3a9+94="; }; - nativeBuildInputs = [ qttools cmake wrapQtAppsHook ]; - buildInputs = [ qtbase sqlite ]; + nativeBuildInputs = [ + qttools + cmake + wrapQtAppsHook + ]; + buildInputs = [ + qtbase + sqlite + ]; cmakeFlags = [ "-DEMBED_SQLITE=OFF" @@ -21,9 +37,9 @@ stdenv.mkDerivation rec { mainProgram = "tagainijisho"; homepage = "https://www.tagaini.net/"; license = with licenses; [ - /* program */ + # program gpl3Plus - /* data */ + # data cc-by-sa-30 ]; platforms = platforms.linux; diff --git a/pkgs/applications/office/timetrap/default.nix b/pkgs/applications/office/timetrap/default.nix index 1bdc8466383543..cfb1c0a62fc93a 100644 --- a/pkgs/applications/office/timetrap/default.nix +++ b/pkgs/applications/office/timetrap/default.nix @@ -1,16 +1,20 @@ -{ stdenv -, lib -, bundlerEnv -, bundlerApp -, bundlerUpdateScript -, installShellFiles +{ + stdenv, + lib, + bundlerEnv, + bundlerApp, + bundlerUpdateScript, + installShellFiles, }: let ttBundlerApp = bundlerApp { pname = "timetrap"; gemdir = ./.; - exes = [ "t" "timetrap" ]; + exes = [ + "t" + "timetrap" + ]; passthru.updateScript = bundlerUpdateScript "timetrap"; }; @@ -46,9 +50,13 @@ stdenv.mkDerivation { meta = with lib; { description = "Simple command line time tracker written in ruby"; - homepage = "https://github.com/samg/timetrap"; - license = licenses.mit; - maintainers = with maintainers; [ jerith666 manveru nicknovitski ]; - platforms = platforms.unix; + homepage = "https://github.com/samg/timetrap"; + license = licenses.mit; + maintainers = with maintainers; [ + jerith666 + manveru + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/applications/office/treesheets/default.nix b/pkgs/applications/office/treesheets/default.nix index 90df4c1342f5cf..ff77f41ec49166 100644 --- a/pkgs/applications/office/treesheets/default.nix +++ b/pkgs/applications/office/treesheets/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -, wrapGAppsHook3 -, makeWrapper -, wxGTK32 -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + wrapGAppsHook3, + makeWrapper, + wxGTK32, + unstableGitUpdater, }: stdenv.mkDerivation rec { @@ -31,7 +32,9 @@ stdenv.mkDerivation rec { wxGTK32 ]; - env.NIX_CFLAGS_COMPILE = "-DPACKAGE_VERSION=\"${builtins.replaceStrings [ "unstable-" ] [ "" ] version}\""; + env.NIX_CFLAGS_COMPILE = "-DPACKAGE_VERSION=\"${ + builtins.replaceStrings [ "unstable-" ] [ "" ] version + }\""; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' mkdir -p $out/{Applications,bin} diff --git a/pkgs/applications/office/trilium/default.nix b/pkgs/applications/office/trilium/default.nix index 35b9b694c09180..b910e548ba6f6e 100644 --- a/pkgs/applications/office/trilium/default.nix +++ b/pkgs/applications/office/trilium/default.nix @@ -7,9 +7,13 @@ let license = licenses.agpl3Plus; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ fliegendewurst eliandoran ]; + maintainers = with maintainers; [ + fliegendewurst + eliandoran + ]; }; -in { +in +{ trilium-desktop = callPackage ./desktop.nix { metaCommon = metaCommon; }; trilium-server = callPackage ./server.nix { metaCommon = metaCommon; }; diff --git a/pkgs/applications/office/trilium/desktop.nix b/pkgs/applications/office/trilium/desktop.nix index 13a291f458042d..f832951be37421 100644 --- a/pkgs/applications/office/trilium/desktop.nix +++ b/pkgs/applications/office/trilium/desktop.nix @@ -1,8 +1,19 @@ -{ stdenv, lib, unzip, autoPatchelfHook -, fetchurl, makeWrapper -, alsa-lib, mesa, nss, nspr, systemd -, makeDesktopItem, copyDesktopItems, wrapGAppsHook3 -, metaCommon +{ + stdenv, + lib, + unzip, + autoPatchelfHook, + fetchurl, + makeWrapper, + alsa-lib, + mesa, + nss, + nspr, + systemd, + makeDesktopItem, + copyDesktopItems, + wrapGAppsHook3, + metaCommon, }: let @@ -17,7 +28,10 @@ let meta = metaCommon // { mainProgram = "trilium"; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; }; linux = stdenv.mkDerivation rec { @@ -96,4 +110,4 @@ let }; in - if stdenv.hostPlatform.isDarwin then darwin else linux +if stdenv.hostPlatform.isDarwin then darwin else linux diff --git a/pkgs/applications/office/trilium/server.nix b/pkgs/applications/office/trilium/server.nix index 125c23050d7418..e96025aabc9c20 100644 --- a/pkgs/applications/office/trilium/server.nix +++ b/pkgs/applications/office/trilium/server.nix @@ -1,11 +1,18 @@ -{ lib, stdenv, autoPatchelfHook, fetchurl, nixosTests -, metaCommon }: +{ + lib, + stdenv, + autoPatchelfHook, + fetchurl, + nixosTests, + metaCommon, +}: let serverSource.url = "https://github.com/zadam/trilium/releases/download/v${version}/trilium-linux-x64-server-${version}.tar.xz"; serverSource.sha256 = "0gwp6h6nvfzq7k1g3233h838nans45jkd5c3pzl6qdhhm19vcs27"; version = "0.63.6"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "trilium-server"; inherit version; meta = metaCommon // { diff --git a/pkgs/applications/plasma-mobile/default.nix b/pkgs/applications/plasma-mobile/default.nix index 97076070ae6004..7742b0a13f4b6b 100644 --- a/pkgs/applications/plasma-mobile/default.nix +++ b/pkgs/applications/plasma-mobile/default.nix @@ -1,66 +1,74 @@ /* + # New packages -# New packages + READ THIS FIRST -READ THIS FIRST + This module is for official packages in the Plasma Mobile Gear. All + available packages are listed in `./srcs.nix`, although some are not yet + packaged in Nixpkgs. -This module is for official packages in the Plasma Mobile Gear. All -available packages are listed in `./srcs.nix`, although some are not yet -packaged in Nixpkgs. + IF YOUR PACKAGE IS NOT LISTED IN `./srcs.nix`, IT DOES NOT GO HERE. -IF YOUR PACKAGE IS NOT LISTED IN `./srcs.nix`, IT DOES NOT GO HERE. + See also `pkgs/applications/kde` as this is what this is based on. -See also `pkgs/applications/kde` as this is what this is based on. - -# Updates - -1. Update the URL in `./fetch.sh`. -2. Run `./maintainers/scripts/fetch-kde-qt.sh pkgs/applications/plasma-mobile` - from the top of the Nixpkgs tree. -3. Use `nox-review wip` to check that everything builds. -4. Commit the changes and open a pull request. + # Updates + 1. Update the URL in `./fetch.sh`. + 2. Run `./maintainers/scripts/fetch-kde-qt.sh pkgs/applications/plasma-mobile` + from the top of the Nixpkgs tree. + 3. Use `nox-review wip` to check that everything builds. + 4. Commit the changes and open a pull request. */ -{ lib -, libsForQt5 -, fetchurl +{ + lib, + libsForQt5, + fetchurl, }: let mirror = "mirror://kde"; srcs = import ./srcs.nix { inherit fetchurl mirror; }; - mkDerivation = args: + mkDerivation = + args: let inherit (args) pname; inherit (srcs.${pname}) src version; - mkDerivation = - libsForQt5.callPackage ({ mkDerivation }: mkDerivation) {}; + mkDerivation = libsForQt5.callPackage ({ mkDerivation }: mkDerivation) { }; in - mkDerivation (args // { + mkDerivation ( + args + // { inherit pname version src; outputs = args.outputs or [ "out" ]; meta = - let meta = args.meta or {}; in - meta // { + let + meta = args.meta or { }; + in + meta + // { homepage = meta.homepage or "https://www.plasma-mobile.org/"; platforms = meta.platforms or lib.platforms.linux; }; - }); + } + ); - packages = self: + packages = + self: let callPackage = self.newScope { inherit mkDerivation; }; - in { - plasma-dialer = callPackage ./plasma-dialer.nix {}; - plasma-phonebook = callPackage ./plasma-phonebook.nix {}; - plasma-settings = callPackage ./plasma-settings.nix {}; - spacebar = callPackage ./spacebar.nix {}; + in + { + plasma-dialer = callPackage ./plasma-dialer.nix { }; + plasma-phonebook = callPackage ./plasma-phonebook.nix { }; + plasma-settings = callPackage ./plasma-settings.nix { }; + spacebar = callPackage ./spacebar.nix { }; }; -in lib.makeScope libsForQt5.newScope packages +in +lib.makeScope libsForQt5.newScope packages diff --git a/pkgs/applications/plasma-mobile/plasma-dialer.nix b/pkgs/applications/plasma-mobile/plasma-dialer.nix index 5fa2638042e725..e741de2974f605 100644 --- a/pkgs/applications/plasma-mobile/plasma-dialer.nix +++ b/pkgs/applications/plasma-mobile/plasma-dialer.nix @@ -1,33 +1,34 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules + cmake, + extra-cmake-modules, -, callaudiod -, kcontacts -, kcoreaddons -, kdbusaddons -, ki18n -, kio -, kirigami-addons -, kirigami2 -, knotifications -, kpeople -, libphonenumber -, libselinux -, libsepol -, modemmanager-qt -, pcre -, plasma-wayland-protocols -, protobuf -, pulseaudio-qt -, qtfeedback -, qtmpris -, qtquickcontrols2 -, util-linux -, wayland -, wayland-protocols + callaudiod, + kcontacts, + kcoreaddons, + kdbusaddons, + ki18n, + kio, + kirigami-addons, + kirigami2, + knotifications, + kpeople, + libphonenumber, + libselinux, + libsepol, + modemmanager-qt, + pcre, + plasma-wayland-protocols, + protobuf, + pulseaudio-qt, + qtfeedback, + qtmpris, + qtquickcontrols2, + util-linux, + wayland, + wayland-protocols, }: mkDerivation rec { diff --git a/pkgs/applications/plasma-mobile/plasma-phonebook.nix b/pkgs/applications/plasma-mobile/plasma-phonebook.nix index a3d62cc4a7889b..00bf96db6ec164 100644 --- a/pkgs/applications/plasma-mobile/plasma-phonebook.nix +++ b/pkgs/applications/plasma-mobile/plasma-phonebook.nix @@ -1,16 +1,17 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules + cmake, + extra-cmake-modules, -, kcontacts -, kcoreaddons -, kirigami2 -, kirigami-addons -, kpeople -, kpeoplevcard -, qtquickcontrols2 + kcontacts, + kcoreaddons, + kirigami2, + kirigami-addons, + kpeople, + kpeoplevcard, + qtquickcontrols2, }: mkDerivation rec { diff --git a/pkgs/applications/plasma-mobile/plasma-settings.nix b/pkgs/applications/plasma-mobile/plasma-settings.nix index c0e58b6653c77a..39465ab00ec685 100644 --- a/pkgs/applications/plasma-mobile/plasma-settings.nix +++ b/pkgs/applications/plasma-mobile/plasma-settings.nix @@ -1,24 +1,25 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules + cmake, + extra-cmake-modules, -, kauth -, kconfig -, kcoreaddons -, kdbusaddons -, ki18n -, kirigami-addons -, kirigami2 -, kitemmodels -, libselinux -, libsepol -, modemmanager-qt -, networkmanager-qt -, pcre -, plasma-framework -, util-linux + kauth, + kconfig, + kcoreaddons, + kdbusaddons, + ki18n, + kirigami-addons, + kirigami2, + kitemmodels, + libselinux, + libsepol, + modemmanager-qt, + networkmanager-qt, + pcre, + plasma-framework, + util-linux, }: mkDerivation rec { diff --git a/pkgs/applications/plasma-mobile/spacebar.nix b/pkgs/applications/plasma-mobile/spacebar.nix index 4e38649d47e71a..2b8b065d63b334 100644 --- a/pkgs/applications/plasma-mobile/spacebar.nix +++ b/pkgs/applications/plasma-mobile/spacebar.nix @@ -1,24 +1,25 @@ -{ lib -, mkDerivation +{ + lib, + mkDerivation, -, cmake -, extra-cmake-modules -, wrapQtAppsHook + cmake, + extra-cmake-modules, + wrapQtAppsHook, -, c-ares -, curl -, kcontacts -, ki18n -, kio -, kirigami-addons -, kirigami2 -, knotifications -, kpeople -, libphonenumber -, modemmanager-qt -, protobuf -, qcoro -, qtquickcontrols2 + c-ares, + curl, + kcontacts, + ki18n, + kio, + kirigami-addons, + kirigami2, + knotifications, + kpeople, + libphonenumber, + modemmanager-qt, + protobuf, + qcoro, + qtquickcontrols2, }: mkDerivation { diff --git a/pkgs/applications/radio/btlejack/default.nix b/pkgs/applications/radio/btlejack/default.nix index 5be832d6d9a68f..86a9c52dbb2900 100644 --- a/pkgs/applications/radio/btlejack/default.nix +++ b/pkgs/applications/radio/btlejack/default.nix @@ -1,4 +1,10 @@ -{ lib, buildPythonApplication, fetchFromGitHub, pyserial, halo }: +{ + lib, + buildPythonApplication, + fetchFromGitHub, + pyserial, + halo, +}: buildPythonApplication rec { pname = "btlejack"; @@ -15,7 +21,10 @@ buildPythonApplication rec { sed -i "s|^.*'argparse',$||" setup.py ''; - propagatedBuildInputs = [ pyserial halo ]; + propagatedBuildInputs = [ + pyserial + halo + ]; meta = with lib; { homepage = "https://github.com/virtualabs/btlejack"; diff --git a/pkgs/applications/radio/cqrlog/default.nix b/pkgs/applications/radio/cqrlog/default.nix index 7c973e097d5336..935585761d701d 100644 --- a/pkgs/applications/radio/cqrlog/default.nix +++ b/pkgs/applications/radio/cqrlog/default.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, fpc -, lazarus -, atk -, cairo -, gdk-pixbuf -, glib -, gtk2-x11 -, libX11 -, pango -, hamlib -, mariadb -, tqsl -, xdg-utils -, xplanet -, autoPatchelfHook -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + fpc, + lazarus, + atk, + cairo, + gdk-pixbuf, + glib, + gtk2-x11, + libX11, + pango, + hamlib, + mariadb, + tqsl, + xdg-utils, + xplanet, + autoPatchelfHook, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -62,7 +63,12 @@ stdenv.mkDerivation rec { ! grep -C src -RC0 "/usr" ''; - nativeBuildInputs = [ lazarus fpc autoPatchelfHook wrapGAppsHook3 ]; + nativeBuildInputs = [ + lazarus + fpc + autoPatchelfHook + wrapGAppsHook3 + ]; buildInputs = [ atk cairo diff --git a/pkgs/applications/radio/cubicsdr/default.nix b/pkgs/applications/radio/cubicsdr/default.nix index 2677795dc0edfe..2fe9dffa6f8b12 100644 --- a/pkgs/applications/radio/cubicsdr/default.nix +++ b/pkgs/applications/radio/cubicsdr/default.nix @@ -1,6 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, fftw, hamlib, libpulseaudio, libGL, libX11, - liquid-dsp, pkg-config, soapysdr-with-plugins, wxGTK32, enableDigitalLab ? false, - Cocoa, WebKit }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + fftw, + hamlib, + libpulseaudio, + libGL, + libX11, + liquid-dsp, + pkg-config, + soapysdr-with-plugins, + wxGTK32, + enableDigitalLab ? false, + Cocoa, + WebKit, +}: stdenv.mkDerivation rec { pname = "cubicsdr"; @@ -21,14 +37,30 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ fftw hamlib liquid-dsp soapysdr-with-plugins wxGTK32 ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libpulseaudio libGL libX11 ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa WebKit ]; + buildInputs = + [ + fftw + hamlib + liquid-dsp + soapysdr-with-plugins + wxGTK32 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libpulseaudio + libGL + libX11 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + WebKit + ]; - cmakeFlags = [ "-DUSE_HAMLIB=ON" ] - ++ lib.optional enableDigitalLab "-DENABLE_DIGITAL_LAB=ON"; + cmakeFlags = [ "-DUSE_HAMLIB=ON" ] ++ lib.optional enableDigitalLab "-DENABLE_DIGITAL_LAB=ON"; meta = with lib; { homepage = "https://cubicsdr.com"; diff --git a/pkgs/applications/radio/direwolf/default.nix b/pkgs/applications/radio/direwolf/default.nix index 6cd591fcbda64d..f35f66ecc2a4a9 100644 --- a/pkgs/applications/radio/direwolf/default.nix +++ b/pkgs/applications/radio/direwolf/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, alsa-lib -, gpsd -, gpsdSupport ? false -, hamlib -, hamlibSupport ? true -, perl -, portaudio -, python3 -, espeak -, udev -, extraScripts ? false +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + alsa-lib, + gpsd, + gpsdSupport ? false, + hamlib, + hamlibSupport ? true, + perl, + portaudio, + python3, + espeak, + udev, + extraScripts ? false, }: stdenv.mkDerivation rec { @@ -30,42 +31,54 @@ stdenv.mkDerivation rec { strictDeps = true; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ alsa-lib udev ] + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + udev + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ portaudio ] ++ lib.optionals gpsdSupport [ gpsd ] ++ lib.optionals hamlibSupport [ hamlib ] - ++ lib.optionals extraScripts [ python3 perl espeak ]; + ++ lib.optionals extraScripts [ + python3 + perl + espeak + ]; preConfigure = lib.optionals (!extraScripts) '' echo "" > scripts/CMakeLists.txt ''; - postPatch = '' - substituteInPlace conf/CMakeLists.txt \ - --replace /etc/udev/rules.d/ $out/lib/udev/rules.d/ - substituteInPlace src/symbols.c \ - --replace /usr/share/direwolf/symbols-new.txt $out/share/direwolf/symbols-new.txt \ - --replace /opt/local/share/direwolf/symbols-new.txt $out/share/direwolf/symbols-new.txt - substituteInPlace src/decode_aprs.c \ - --replace /usr/share/direwolf/tocalls.txt $out/share/direwolf/tocalls.txt \ - --replace /opt/local/share/direwolf/tocalls.txt $out/share/direwolf/tocalls.txt - substituteInPlace cmake/cpack/direwolf.desktop.in \ - --replace 'Terminal=false' 'Terminal=true' \ - --replace 'Exec=@APPLICATION_DESKTOP_EXEC@' 'Exec=direwolf' - substituteInPlace src/dwgpsd.c \ - --replace 'GPSD_API_MAJOR_VERSION > 11' 'GPSD_API_MAJOR_VERSION > 14' - '' - + lib.optionalString extraScripts '' - patchShebangs scripts/dwespeak.sh - substituteInPlace scripts/dwespeak.sh \ - --replace espeak ${espeak}/bin/espeak - ''; + postPatch = + '' + substituteInPlace conf/CMakeLists.txt \ + --replace /etc/udev/rules.d/ $out/lib/udev/rules.d/ + substituteInPlace src/symbols.c \ + --replace /usr/share/direwolf/symbols-new.txt $out/share/direwolf/symbols-new.txt \ + --replace /opt/local/share/direwolf/symbols-new.txt $out/share/direwolf/symbols-new.txt + substituteInPlace src/decode_aprs.c \ + --replace /usr/share/direwolf/tocalls.txt $out/share/direwolf/tocalls.txt \ + --replace /opt/local/share/direwolf/tocalls.txt $out/share/direwolf/tocalls.txt + substituteInPlace cmake/cpack/direwolf.desktop.in \ + --replace 'Terminal=false' 'Terminal=true' \ + --replace 'Exec=@APPLICATION_DESKTOP_EXEC@' 'Exec=direwolf' + substituteInPlace src/dwgpsd.c \ + --replace 'GPSD_API_MAJOR_VERSION > 11' 'GPSD_API_MAJOR_VERSION > 14' + '' + + lib.optionalString extraScripts '' + patchShebangs scripts/dwespeak.sh + substituteInPlace scripts/dwespeak.sh \ + --replace espeak ${espeak}/bin/espeak + ''; meta = with lib; { description = "Soundcard Packet TNC, APRS Digipeater, IGate, APRStt gateway"; homepage = "https://github.com/wb2osz/direwolf/"; license = licenses.gpl2; platforms = platforms.unix; - maintainers = with maintainers; [ lasandell sarcasticadmin ]; + maintainers = with maintainers; [ + lasandell + sarcasticadmin + ]; }; } diff --git a/pkgs/applications/radio/fldigi/default.nix b/pkgs/applications/radio/fldigi/default.nix index 28662cdc7b1578..c759b83b546bd4 100644 --- a/pkgs/applications/radio/fldigi/default.nix +++ b/pkgs/applications/radio/fldigi/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, hamlib -, fltk13 -, libjpeg -, libpng -, portaudio -, libsndfile -, libsamplerate -, libpulseaudio -, libXinerama -, gettext -, pkg-config -, alsa-lib -, udev +{ + lib, + stdenv, + fetchurl, + hamlib, + fltk13, + libjpeg, + libpng, + portaudio, + libsndfile, + libsamplerate, + libpulseaudio, + libXinerama, + gettext, + pkg-config, + alsa-lib, + udev, }: stdenv.mkDerivation rec { @@ -27,17 +28,23 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - libXinerama - gettext - hamlib - fltk13 - libjpeg - libpng - portaudio - libsndfile - libsamplerate - ] ++ lib.optionals (stdenv.hostPlatform.isLinux) [ libpulseaudio alsa-lib udev ]; + buildInputs = + [ + libXinerama + gettext + hamlib + fltk13 + libjpeg + libpng + portaudio + libsndfile + libsamplerate + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux) [ + libpulseaudio + alsa-lib + udev + ]; env.CXXFLAGS = lib.optionalString stdenv.cc.isClang "-std=c++14"; @@ -47,7 +54,10 @@ stdenv.mkDerivation rec { description = "Digital modem program"; homepage = "https://sourceforge.net/projects/fldigi/"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ relrod ftrvxmtrx ]; + maintainers = with maintainers; [ + relrod + ftrvxmtrx + ]; platforms = platforms.unix; }; } diff --git a/pkgs/applications/radio/gnuradio/shared.nix b/pkgs/applications/radio/gnuradio/shared.nix index 75a2a97e0d22f5..ef1b5feb6a8d91 100644 --- a/pkgs/applications/radio/gnuradio/shared.nix +++ b/pkgs/applications/radio/gnuradio/shared.nix @@ -1,88 +1,94 @@ -{ lib, stdenv -, python -, qt -, gtk -, removeReferencesTo -, featuresInfo -, features -, version -, sourceSha256 -# If overridden. No need to set default values, as they are given defaults in -# the main expressions -, overrideSrc -, fetchFromGitHub +{ + lib, + stdenv, + python, + qt, + gtk, + removeReferencesTo, + featuresInfo, + features, + version, + sourceSha256, + # If overridden. No need to set default values, as they are given defaults in + # the main expressions + overrideSrc, + fetchFromGitHub, }: let # Check if a feature is enabled, while defaulting to true if feat is not # specified. - hasFeature = feat: ( - if builtins.hasAttr feat features then - features.${feat} - else - true - ); + hasFeature = feat: (if builtins.hasAttr feat features then features.${feat} else true); versionAttr = { major = builtins.concatStringsSep "." (lib.take 2 (lib.splitVersion version)); minor = builtins.elemAt (lib.splitVersion version) 2; patch = builtins.elemAt (lib.splitVersion version) 3; }; -in { - src = if overrideSrc != {} then - overrideSrc - else - fetchFromGitHub { - repo = "gnuradio"; - owner = "gnuradio"; - rev = "v${version}"; - sha256 = sourceSha256; - } - ; - nativeBuildInputs = [ removeReferencesTo ] ++ lib.flatten (lib.mapAttrsToList ( - feat: info: ( - lib.optionals (hasFeature feat) ( - (lib.optionals (builtins.hasAttr "native" info) info.native) ++ - (lib.optionals (builtins.hasAttr "pythonNative" info) info.pythonNative) - ) - ) - ) featuresInfo); - buildInputs = lib.flatten (lib.mapAttrsToList ( - feat: info: ( - lib.optionals (hasFeature feat) ( - (lib.optionals (builtins.hasAttr "runtime" info) info.runtime) ++ - (lib.optionals (builtins.hasAttr "pythonRuntime" info) info.pythonRuntime) - ) - ) - ) featuresInfo); +in +{ + src = + if overrideSrc != { } then + overrideSrc + else + fetchFromGitHub { + repo = "gnuradio"; + owner = "gnuradio"; + rev = "v${version}"; + sha256 = sourceSha256; + }; + nativeBuildInputs = + [ removeReferencesTo ] + ++ lib.flatten ( + lib.mapAttrsToList ( + feat: info: + (lib.optionals (hasFeature feat) ( + (lib.optionals (builtins.hasAttr "native" info) info.native) + ++ (lib.optionals (builtins.hasAttr "pythonNative" info) info.pythonNative) + )) + ) featuresInfo + ); + buildInputs = lib.flatten ( + lib.mapAttrsToList ( + feat: info: + (lib.optionals (hasFeature feat) ( + (lib.optionals (builtins.hasAttr "runtime" info) info.runtime) + ++ (lib.optionals (builtins.hasAttr "pythonRuntime" info) info.pythonRuntime) + )) + ) featuresInfo + ); cmakeFlags = lib.mapAttrsToList ( - feat: info: ( + feat: info: + ( if feat == "basic" then # Abuse this unavoidable "iteration" to set this flag which we want as # well - it means: Don't turn on features just because their deps are # satisfied, let only our cmakeFlags decide. "-DENABLE_DEFAULT=OFF" + else if hasFeature feat then + "-DENABLE_${info.cmakeEnableFlag}=ON" else - if hasFeature feat then - "-DENABLE_${info.cmakeEnableFlag}=ON" - else - "-DENABLE_${info.cmakeEnableFlag}=OFF" - )) featuresInfo - ; - disallowedReferences = [ - # TODO: Should this be conditional? - stdenv.cc - stdenv.cc.cc - ] + "-DENABLE_${info.cmakeEnableFlag}=OFF" + ) + ) featuresInfo; + disallowedReferences = + [ + # TODO: Should this be conditional? + stdenv.cc + stdenv.cc.cc + ] # If python-support is disabled, we probably don't want it referenced - ++ lib.optionals (!hasFeature "python-support") [ python ] - ; + ++ lib.optionals (!hasFeature "python-support") [ python ]; # Gcc references from examples - stripDebugList = [ "lib" "bin" ] + stripDebugList = + [ + "lib" + "bin" + ] ++ lib.optionals (hasFeature "gr-audio") [ "share/gnuradio/examples/audio" ] ++ lib.optionals (hasFeature "gr-uhd") [ "share/gnuradio/examples/uhd" ] - ++ lib.optionals (hasFeature "gr-qtgui") [ "share/gnuradio/examples/qt-gui" ] - ; - postInstall = "" + ++ lib.optionals (hasFeature "gr-qtgui") [ "share/gnuradio/examples/qt-gui" ]; + postInstall = + "" # Gcc references + lib.optionalString (hasFeature "gnuradio-runtime") '' remove-references-to -t ${stdenv.cc} $(readlink -f $out/lib/libgnuradio-runtime${stdenv.hostPlatform.extensions.sharedLibrary}) @@ -90,27 +96,29 @@ in { # Clang references in InstalledDir + lib.optionalString (hasFeature "gnuradio-runtime" && stdenv.hostPlatform.isDarwin) '' remove-references-to -t ${stdenv.cc.cc} $(readlink -f $out/lib/libgnuradio-runtime${stdenv.hostPlatform.extensions.sharedLibrary}) - '' - ; + ''; # NOTE: Outputs are disabled due to upstream not using GNU InstallDIrs cmake # module. It's not that bad since it's a development package for most # purposes. If closure size needs to be reduced, features should be disabled # via an override. - passthru = { - inherit - hasFeature - versionAttr - features - featuresInfo - python - ; - gnuradioOlder = lib.versionOlder versionAttr.major; - gnuradioAtLeast = lib.versionAtLeast versionAttr.major; - } // lib.optionalAttrs (hasFeature "gr-qtgui") { - inherit qt; - } // lib.optionalAttrs (hasFeature "gnuradio-companion") { - inherit gtk; - }; + passthru = + { + inherit + hasFeature + versionAttr + features + featuresInfo + python + ; + gnuradioOlder = lib.versionOlder versionAttr.major; + gnuradioAtLeast = lib.versionAtLeast versionAttr.major; + } + // lib.optionalAttrs (hasFeature "gr-qtgui") { + inherit qt; + } + // lib.optionalAttrs (hasFeature "gnuradio-companion") { + inherit gtk; + }; # Wrapping is done with an external wrapper dontWrapPythonPrograms = true; dontWrapQtApps = true; @@ -138,6 +146,11 @@ in { homepage = "https://www.gnuradio.org"; license = lib.licenses.gpl3; platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ doronbehar bjornfor fpletz jiegec ]; + maintainers = with lib.maintainers; [ + doronbehar + bjornfor + fpletz + jiegec + ]; }; } diff --git a/pkgs/applications/radio/gnuradio/wrapper.nix b/pkgs/applications/radio/gnuradio/wrapper.nix index 4ffe42593ec5d7..7146c32d20fbb1 100644 --- a/pkgs/applications/radio/gnuradio/wrapper.nix +++ b/pkgs/applications/radio/gnuradio/wrapper.nix @@ -1,100 +1,133 @@ -{ lib -, stdenv -# The unwrapped gnuradio derivation -, unwrapped -# If it's a minimal build, we don't want to wrap it with lndir and -# wrapProgram.. -, doWrap ? true -# For the wrapper -, makeWrapper -# For lndir -, xorg -# To define a the gnuradio.pkgs scope -, newScope -# For Emulating wrapGAppsHook3 -, gsettings-desktop-schemas -, glib -, hicolor-icon-theme -, pango -, json-glib -, dconf -, gobject-introspection -, librsvg -, gdk-pixbuf -, harfbuzz -, at-spi2-core -, atk -# For Adding additional GRC blocks -, extraPackages ? [] -# For Adding additional python packaages -, extraPythonPackages ? [] -, soapysdr # For it's passthru.searchPath -# soapysdr plugins we add by default. Ideally, we should have a -# soapysdrPackages = soapysdr.pkgs attribute set, but until now this wasn't -# crucial. -, soapyairspy -, soapyaudio -, soapybladerf -, soapyhackrf -, soapyremote -, soapyrtlsdr -, soapyuhd -# For adding / changing soapysdr packages, like soapsdr-with-plugins does -, extraSoapySdrPackages ? [ - soapyairspy - soapyaudio - soapybladerf - soapyhackrf - soapyremote - soapyrtlsdr - soapyuhd -] -# Allow to add whatever you want to the wrapper -, extraMakeWrapperArgs ? [] +{ + lib, + stdenv, + # The unwrapped gnuradio derivation + unwrapped, + # If it's a minimal build, we don't want to wrap it with lndir and + # wrapProgram.. + doWrap ? true, + # For the wrapper + makeWrapper, + # For lndir + xorg, + # To define a the gnuradio.pkgs scope + newScope, + # For Emulating wrapGAppsHook3 + gsettings-desktop-schemas, + glib, + hicolor-icon-theme, + pango, + json-glib, + dconf, + gobject-introspection, + librsvg, + gdk-pixbuf, + harfbuzz, + at-spi2-core, + atk, + # For Adding additional GRC blocks + extraPackages ? [ ], + # For Adding additional python packaages + extraPythonPackages ? [ ], + soapysdr, # For it's passthru.searchPath + # soapysdr plugins we add by default. Ideally, we should have a + # soapysdrPackages = soapysdr.pkgs attribute set, but until now this wasn't + # crucial. + soapyairspy, + soapyaudio, + soapybladerf, + soapyhackrf, + soapyremote, + soapyrtlsdr, + soapyuhd, + # For adding / changing soapysdr packages, like soapsdr-with-plugins does + extraSoapySdrPackages ? [ + soapyairspy + soapyaudio + soapybladerf + soapyhackrf + soapyremote + soapyrtlsdr + soapyuhd + ], + # Allow to add whatever you want to the wrapper + extraMakeWrapperArgs ? [ ], }: let # We don't check if `python-support` feature is on, as it's unlikely someone # may wish to wrap GR without python support. - pythonPkgs = extraPythonPackages + pythonPkgs = + extraPythonPackages ++ [ (unwrapped.python.pkgs.toPythonModule unwrapped) ] ++ unwrapped.passthru.uhd.pythonPath - ++ lib.optionals (unwrapped.passthru.uhd.pythonPath != []) [ + ++ lib.optionals (unwrapped.passthru.uhd.pythonPath != [ ]) [ (unwrapped.python.pkgs.toPythonModule unwrapped.passthru.uhd) ] # Add the extraPackages as python modules as well ++ (builtins.map unwrapped.python.pkgs.toPythonModule extraPackages) - ++ lib.flatten (lib.mapAttrsToList ( - feat: info: ( - lib.optionals ((unwrapped.hasFeature feat) && (builtins.hasAttr "pythonRuntime" info)) info.pythonRuntime - ) - ) unwrapped.featuresInfo) - ; - pythonEnv = unwrapped.python.withPackages(ps: pythonPkgs); + ++ lib.flatten ( + lib.mapAttrsToList ( + feat: info: + (lib.optionals ( + (unwrapped.hasFeature feat) && (builtins.hasAttr "pythonRuntime" info) + ) info.pythonRuntime) + ) unwrapped.featuresInfo + ); + pythonEnv = unwrapped.python.withPackages (ps: pythonPkgs); pname = unwrapped.pname + "-wrapped"; inherit (unwrapped) version; - makeWrapperArgs = builtins.concatStringsSep " " ([ - ] - # Emulating wrapGAppsHook3 & wrapQtAppsHook working together - ++ lib.optionals ( - (unwrapped.hasFeature "gnuradio-companion") - || (unwrapped.hasFeature "gr-qtgui") - ) [ - "--prefix" "XDG_DATA_DIRS" ":" "$out/share" - "--prefix" "XDG_DATA_DIRS" ":" "$out/share/gsettings-schemas/${pname}" - "--prefix" "XDG_DATA_DIRS" ":" "${gsettings-desktop-schemas}/share/gsettings-schemas/${gsettings-desktop-schemas.name}" - "--prefix" "XDG_DATA_DIRS" ":" "${hicolor-icon-theme}/share" - # Needs to run `gsettings` on startup, see: - # https://www.mail-archive.com/debian-bugs-dist@lists.debian.org/msg1764890.html - "--prefix" "PATH" ":" "${lib.getBin glib}/bin" + makeWrapperArgs = builtins.concatStringsSep " " ( + [ ] + # Emulating wrapGAppsHook3 & wrapQtAppsHook working together + ++ + lib.optionals ((unwrapped.hasFeature "gnuradio-companion") || (unwrapped.hasFeature "gr-qtgui")) + [ + "--prefix" + "XDG_DATA_DIRS" + ":" + "$out/share" + "--prefix" + "XDG_DATA_DIRS" + ":" + "$out/share/gsettings-schemas/${pname}" + "--prefix" + "XDG_DATA_DIRS" + ":" + "${gsettings-desktop-schemas}/share/gsettings-schemas/${gsettings-desktop-schemas.name}" + "--prefix" + "XDG_DATA_DIRS" + ":" + "${hicolor-icon-theme}/share" + # Needs to run `gsettings` on startup, see: + # https://www.mail-archive.com/debian-bugs-dist@lists.debian.org/msg1764890.html + "--prefix" + "PATH" + ":" + "${lib.getBin glib}/bin" + ] ++ lib.optionals (unwrapped.hasFeature "gnuradio-companion") [ - "--set" "GDK_PIXBUF_MODULE_FILE" "${librsvg}/${gdk-pixbuf.moduleDir}.cache" - "--prefix" "GIO_EXTRA_MODULES" ":" "${lib.getLib dconf}/lib/gio/modules" - "--prefix" "XDG_DATA_DIRS" ":" "${unwrapped.gtk}/share" - "--prefix" "XDG_DATA_DIRS" ":" "${unwrapped.gtk}/share/gsettings-schemas/${unwrapped.gtk.name}" - "--prefix" "GI_TYPELIB_PATH" ":" "${lib.makeSearchPath "lib/girepository-1.0" [ + "--set" + "GDK_PIXBUF_MODULE_FILE" + "${librsvg}/${gdk-pixbuf.moduleDir}.cache" + "--prefix" + "GIO_EXTRA_MODULES" + ":" + "${lib.getLib dconf}/lib/gio/modules" + "--prefix" + "XDG_DATA_DIRS" + ":" + "${unwrapped.gtk}/share" + "--prefix" + "XDG_DATA_DIRS" + ":" + "${unwrapped.gtk}/share/gsettings-schemas/${unwrapped.gtk.name}" + "--prefix" + "GI_TYPELIB_PATH" + ":" + "${lib.makeSearchPath "lib/girepository-1.0" [ (lib.getLib glib) unwrapped.gtk gsettings-desktop-schemas @@ -110,44 +143,57 @@ let at-spi2-core ]}" ] - ++ lib.optionals (extraPackages != []) [ - "--prefix" "GRC_BLOCKS_PATH" ":" "${lib.makeSearchPath "share/gnuradio/grc/blocks" extraPackages}" + ++ lib.optionals (extraPackages != [ ]) [ + "--prefix" + "GRC_BLOCKS_PATH" + ":" + "${lib.makeSearchPath "share/gnuradio/grc/blocks" extraPackages}" ] - ++ lib.optionals (extraSoapySdrPackages != []) [ - "--prefix" "SOAPY_SDR_PLUGIN_PATH" ":" "${lib.makeSearchPath - soapysdr.passthru.searchPath extraSoapySdrPackages}" + ++ lib.optionals (extraSoapySdrPackages != [ ]) [ + "--prefix" + "SOAPY_SDR_PLUGIN_PATH" + ":" + "${lib.makeSearchPath soapysdr.passthru.searchPath extraSoapySdrPackages}" ] - ++ lib.optionals (unwrapped.hasFeature "gr-qtgui") - # 3.7 builds with qt4 - (if lib.versionAtLeast unwrapped.versionAttr.major "3.8" then - [ - "--prefix" "QT_PLUGIN_PATH" ":" - "${ - lib.makeSearchPath - unwrapped.qt.qtbase.qtPluginPrefix - (builtins.map lib.getBin ([ - unwrapped.qt.qtbase - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - unwrapped.qt.qtwayland - ])) - }" - "--prefix" "QML2_IMPORT_PATH" ":" - "${ - lib.makeSearchPath - unwrapped.qt.qtbase.qtQmlPrefix - (builtins.map lib.getBin ([ - unwrapped.qt.qtbase - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - unwrapped.qt.qtwayland - ])) - }" - ] - else - # Add here qt4 related environment for 3.7? - [ + ++ + lib.optionals (unwrapped.hasFeature "gr-qtgui") + # 3.7 builds with qt4 + ( + if lib.versionAtLeast unwrapped.versionAttr.major "3.8" then + [ + "--prefix" + "QT_PLUGIN_PATH" + ":" + "${lib.makeSearchPath unwrapped.qt.qtbase.qtPluginPrefix ( + builtins.map lib.getBin ( + [ + unwrapped.qt.qtbase + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + unwrapped.qt.qtwayland + ] + ) + )}" + "--prefix" + "QML2_IMPORT_PATH" + ":" + "${lib.makeSearchPath unwrapped.qt.qtbase.qtQmlPrefix ( + builtins.map lib.getBin ( + [ + unwrapped.qt.qtbase + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + unwrapped.qt.qtwayland + ] + ) + )}" + ] + else + # Add here qt4 related environment for 3.7? + [ - ] - ) + ] + ) ++ extraMakeWrapperArgs ); @@ -160,48 +206,48 @@ let pythonEnv pythonPkgs unwrapped - ; + ; pkgs = packages; }; - self = if doWrap then - stdenv.mkDerivation { - inherit pname version passthru; - nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ - xorg.lndir - ]; - buildCommand = '' - mkdir $out - cd $out - lndir -silent ${unwrapped} - ${lib.optionalString - (extraPackages != []) - (builtins.concatStringsSep "\n" - (builtins.map (pkg: '' - if [[ -d ${lib.getBin pkg}/bin/ ]]; then - lndir -silent ${pkg}/bin ./bin - fi - '') extraPackages) - ) - } - for i in $out/bin/*; do - if [[ ! -x "$i" ]]; then - continue - fi - cp -L "$i" "$i".tmp - mv -f "$i".tmp "$i" - if head -1 "$i" | grep -q ${unwrapped.python}; then - substituteInPlace "$i" \ - --replace ${unwrapped.python} ${pythonEnv} - fi - wrapProgram "$i" ${makeWrapperArgs} - done - ''; - inherit (unwrapped) meta; - } - else - unwrapped.overrideAttrs(_: { - inherit passthru; - }) - ; -in self + self = + if doWrap then + stdenv.mkDerivation { + inherit pname version passthru; + nativeBuildInputs = [ makeWrapper ]; + buildInputs = [ + xorg.lndir + ]; + buildCommand = '' + mkdir $out + cd $out + lndir -silent ${unwrapped} + ${lib.optionalString (extraPackages != [ ]) ( + builtins.concatStringsSep "\n" ( + builtins.map (pkg: '' + if [[ -d ${lib.getBin pkg}/bin/ ]]; then + lndir -silent ${pkg}/bin ./bin + fi + '') extraPackages + ) + )} + for i in $out/bin/*; do + if [[ ! -x "$i" ]]; then + continue + fi + cp -L "$i" "$i".tmp + mv -f "$i".tmp "$i" + if head -1 "$i" | grep -q ${unwrapped.python}; then + substituteInPlace "$i" \ + --replace ${unwrapped.python} ${pythonEnv} + fi + wrapProgram "$i" ${makeWrapperArgs} + done + ''; + inherit (unwrapped) meta; + } + else + unwrapped.overrideAttrs (_: { + inherit passthru; + }); +in +self diff --git a/pkgs/applications/radio/gqrx/default.nix b/pkgs/applications/radio/gqrx/default.nix index 5e11d6119bea25..a74aead0f80f88 100644 --- a/pkgs/applications/radio/gqrx/default.nix +++ b/pkgs/applications/radio/gqrx/default.nix @@ -1,23 +1,26 @@ -{ lib -, fetchFromGitHub -, cmake -, pkg-config -, qtbase -, qtsvg -, qtwayland -, gnuradioMinimal -, thrift -, mpir -, fftwFloat -, alsa-lib -, libjack2 -, wrapGAppsHook3 -, wrapQtAppsHook -# drivers (optional): -, rtl-sdr -, hackrf -, pulseaudioSupport ? true, libpulseaudio -, portaudioSupport ? false, portaudio +{ + lib, + fetchFromGitHub, + cmake, + pkg-config, + qtbase, + qtsvg, + qtwayland, + gnuradioMinimal, + thrift, + mpir, + fftwFloat, + alsa-lib, + libjack2, + wrapGAppsHook3, + wrapQtAppsHook, + # drivers (optional): + rtl-sdr, + hackrf, + pulseaudioSupport ? true, + libpulseaudio, + portaudioSupport ? false, + portaudio, }: assert pulseaudioSupport -> libpulseaudio != null; @@ -42,38 +45,43 @@ gnuradioMinimal.pkgs.mkDerivation rec { wrapQtAppsHook wrapGAppsHook3 ]; - buildInputs = [ - gnuradioMinimal.unwrapped.logLib - mpir - fftwFloat - alsa-lib - libjack2 - gnuradioMinimal.unwrapped.boost - qtbase - qtsvg - qtwayland - gnuradioMinimal.pkgs.osmosdr - rtl-sdr - hackrf - ] ++ lib.optionals (gnuradioMinimal.hasFeature "gr-ctrlport") [ - thrift - gnuradioMinimal.unwrapped.python.pkgs.thrift - ] ++ lib.optionals pulseaudioSupport [ libpulseaudio ] + buildInputs = + [ + gnuradioMinimal.unwrapped.logLib + mpir + fftwFloat + alsa-lib + libjack2 + gnuradioMinimal.unwrapped.boost + qtbase + qtsvg + qtwayland + gnuradioMinimal.pkgs.osmosdr + rtl-sdr + hackrf + ] + ++ lib.optionals (gnuradioMinimal.hasFeature "gr-ctrlport") [ + thrift + gnuradioMinimal.unwrapped.python.pkgs.thrift + ] + ++ lib.optionals pulseaudioSupport [ libpulseaudio ] ++ lib.optionals portaudioSupport [ portaudio ]; cmakeFlags = let audioBackend = - if pulseaudioSupport - then "Pulseaudio" - else if portaudioSupport - then "Portaudio" - else "Gr-audio"; - in [ + if pulseaudioSupport then + "Pulseaudio" + else if portaudioSupport then + "Portaudio" + else + "Gr-audio"; + in + [ "-DLINUX_AUDIO_BACKEND=${audioBackend}" ]; - # Prevent double-wrapping, inject wrapper args manually instead. + # Prevent double-wrapping, inject wrapper args manually instead. dontWrapGApps = true; preFixup = '' qtWrapperArgs+=("''${gappsWrapperArgs[@]}") @@ -92,7 +100,10 @@ gnuradioMinimal.pkgs.mkDerivation rec { # Some of the code comes from the Cutesdr project, with a BSD license, but # it's currently unknown which version of the BSD license that is. license = licenses.gpl3Plus; - platforms = platforms.linux; # should work on Darwin / macOS too - maintainers = with maintainers; [ bjornfor fpletz ]; + platforms = platforms.linux; # should work on Darwin / macOS too + maintainers = with maintainers; [ + bjornfor + fpletz + ]; }; } diff --git a/pkgs/applications/radio/guglielmo/default.nix b/pkgs/applications/radio/guglielmo/default.nix index 98cde58e8cfff2..9836d03ee8511c 100644 --- a/pkgs/applications/radio/guglielmo/default.nix +++ b/pkgs/applications/radio/guglielmo/default.nix @@ -1,15 +1,20 @@ -{ lib, mkDerivation, fetchFromGitHub, cmake, pkg-config -, airspy -, rtl-sdr -, fdk_aac -, faad2 -, fftwFloat -, libsndfile -, libsamplerate -, portaudio -, qtmultimedia -, qwt -} : +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + pkg-config, + airspy, + rtl-sdr, + fdk_aac, + faad2, + fftwFloat, + libsndfile, + libsamplerate, + portaudio, + qtmultimedia, + qwt, +}: mkDerivation rec { pname = "guglielmo"; @@ -26,7 +31,10 @@ mkDerivation rec { mv $out/linux-bin $out/bin ''; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ airspy rtl-sdr @@ -51,6 +59,6 @@ mkDerivation rec { homepage = "https://github.com/marcogrecopriolo/guglielmo"; license = licenses.gpl2Only; maintainers = [ maintainers.markuskowa ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/applications/radio/js8call/default.nix b/pkgs/applications/radio/js8call/default.nix index e89d3445697f46..3b4e247e360980 100644 --- a/pkgs/applications/radio/js8call/default.nix +++ b/pkgs/applications/radio/js8call/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromBitbucket -, wrapQtAppsHook -, pkg-config -, hamlib -, libusb1 -, cmake -, gfortran -, fftw -, fftwFloat -, qtbase -, qtmultimedia -, qtserialport +{ + lib, + stdenv, + fetchFromBitbucket, + wrapQtAppsHook, + pkg-config, + hamlib, + libusb1, + cmake, + gfortran, + fftw, + fftwFloat, + qtbase, + qtmultimedia, + qtserialport, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/radio/klog/default.nix b/pkgs/applications/radio/klog/default.nix index 0215e6cdcdabdc..9ac067a4189702 100644 --- a/pkgs/applications/radio/klog/default.nix +++ b/pkgs/applications/radio/klog/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, hamlib, pkg-config, qtbase, qttools, qtserialport, qtcharts, qmake, wrapQtAppsHook }: +{ + lib, + stdenv, + fetchurl, + hamlib, + pkg-config, + qtbase, + qttools, + qtserialport, + qtcharts, + qmake, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "klog"; @@ -9,8 +21,18 @@ stdenv.mkDerivation rec { sha256 = "1d5x7rq0mgfrqws3q1y4z8wh2qa3gvsmd0ssf2yqgkyq3fhdrb5c"; }; - nativeBuildInputs = [ pkg-config wrapQtAppsHook qmake qttools ]; - buildInputs = [ hamlib qtbase qtserialport qtcharts ]; + nativeBuildInputs = [ + pkg-config + wrapQtAppsHook + qmake + qttools + ]; + buildInputs = [ + hamlib + qtbase + qtserialport + qtcharts + ]; qmakeFlags = [ "KLog.pro" ]; @@ -20,7 +42,7 @@ stdenv.mkDerivation rec { longDescription = '' KLog provides QSO management, useful QSL management DX-Cluster client, DXCC management, ClubLog integration, WSJT-X, DX-Marathon support and much more. - ''; + ''; homepage = "https://www.klog.xyz/"; license = licenses.gpl2Plus; platforms = platforms.linux; diff --git a/pkgs/applications/radio/limesuite/default.nix b/pkgs/applications/radio/limesuite/default.nix index 9190896d8e11a1..2679132bdb8fb6 100644 --- a/pkgs/applications/radio/limesuite/default.nix +++ b/pkgs/applications/radio/limesuite/default.nix @@ -1,8 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, sqlite, wxGTK32, libusb1, soapysdr -, mesa_glu, libX11, gnuplot, fltk -, GLUT -, withGui ? false +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + sqlite, + wxGTK32, + libusb1, + soapysdr, + mesa_glu, + libX11, + gnuplot, + fltk, + GLUT, + withGui ? false, }: stdenv.mkDerivation rec { @@ -22,20 +32,23 @@ stdenv.mkDerivation rec { "-DOpenGL_GL_PREFERENCE=GLVND" ] ++ lib.optional (!withGui) "-DENABLE_GUI=OFF"; - buildInputs = [ - libusb1 - sqlite - gnuplot - libusb1 - soapysdr - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - GLUT - ] ++ lib.optionals withGui [ - fltk - libX11 - mesa_glu - wxGTK32 - ]; + buildInputs = + [ + libusb1 + sqlite + gnuplot + libusb1 + soapysdr + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + GLUT + ] + ++ lib.optionals withGui [ + fltk + libX11 + mesa_glu + wxGTK32 + ]; postInstall = '' install -Dm444 -t $out/lib/udev/rules.d ../udev-rules/64-limesuite.rules @@ -51,4 +64,3 @@ stdenv.mkDerivation rec { badPlatforms = lib.optionals withGui platforms.darwin; # withGui transitively depends on mesa, which is broken on darwin }; } - diff --git a/pkgs/applications/radio/pothos/default.nix b/pkgs/applications/radio/pothos/default.nix index ac28698a46097c..641df521c7fd82 100644 --- a/pkgs/applications/radio/pothos/default.nix +++ b/pkgs/applications/radio/pothos/default.nix @@ -1,22 +1,23 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, doxygen -, wrapQtAppsHook -, pcre -, poco -, qtbase -, qtsvg -, qwt6_1 -, nlohmann_json -, soapysdr-with-plugins -, portaudio -, alsa-lib -, muparserx -, python3 +{ + lib, + mkDerivation, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + doxygen, + wrapQtAppsHook, + pcre, + poco, + qtbase, + qtsvg, + qwt6_1, + nlohmann_json, + soapysdr-with-plugins, + portaudio, + alsa-lib, + muparserx, + python3, }: mkDerivation rec { @@ -42,11 +43,25 @@ mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config doxygen wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + pkg-config + doxygen + wrapQtAppsHook + ]; buildInputs = [ - pcre poco qtbase qtsvg qwt6_1 nlohmann_json - soapysdr-with-plugins portaudio alsa-lib muparserx python3 + pcre + poco + qtbase + qtsvg + qwt6_1 + nlohmann_json + soapysdr-with-plugins + portaudio + alsa-lib + muparserx + python3 ]; postInstall = '' diff --git a/pkgs/applications/radio/qlog/default.nix b/pkgs/applications/radio/qlog/default.nix index 9732d836b7e5bf..3afa1d038311e0 100644 --- a/pkgs/applications/radio/qlog/default.nix +++ b/pkgs/applications/radio/qlog/default.nix @@ -1,17 +1,18 @@ -{ fetchFromGitHub -, qtbase -, stdenv -, lib -, wrapQtAppsHook -, qmake -, qtcharts -, qtwebengine -, qtserialport -, qtwebchannel -, hamlib -, qtkeychain -, pkg-config -, cups +{ + fetchFromGitHub, + qtbase, + stdenv, + lib, + wrapQtAppsHook, + qmake, + qtcharts, + qtwebengine, + qtserialport, + qtwebchannel, + hamlib, + qtkeychain, + pkg-config, + cups, }: stdenv.mkDerivation rec { @@ -28,17 +29,19 @@ stdenv.mkDerivation rec { env.NIX_LDFLAGS = "-lhamlib"; - buildInputs = [ - qtbase - qtcharts - qtwebengine - qtserialport - qtwebchannel - hamlib - qtkeychain - ] ++ (lib.optionals stdenv.hostPlatform.isDarwin [ - cups - ]); + buildInputs = + [ + qtbase + qtcharts + qtwebengine + qtserialport + qtwebchannel + hamlib + qtkeychain + ] + ++ (lib.optionals stdenv.hostPlatform.isDarwin [ + cups + ]); nativeBuildInputs = [ wrapQtAppsHook @@ -51,7 +54,10 @@ stdenv.mkDerivation rec { mainProgram = "qlog"; license = with licenses; [ gpl3Only ]; homepage = "https://github.com/foldynl/QLog"; - maintainers = with maintainers; [ oliver-koss mkg20001 ]; + maintainers = with maintainers; [ + oliver-koss + mkg20001 + ]; platforms = with platforms; unix; }; } diff --git a/pkgs/applications/radio/qsstv/default.nix b/pkgs/applications/radio/qsstv/default.nix index 43d9ad13e4b930..ba49faf73e39ad 100644 --- a/pkgs/applications/radio/qsstv/default.nix +++ b/pkgs/applications/radio/qsstv/default.nix @@ -1,5 +1,18 @@ -{ mkDerivation, lib, fetchurl, qtbase, qmake, openjpeg, pkg-config, fftw, - libpulseaudio, alsa-lib, hamlib, libv4l, fftwFloat }: +{ + mkDerivation, + lib, + fetchurl, + qtbase, + qmake, + openjpeg, + pkg-config, + fftw, + libpulseaudio, + alsa-lib, + hamlib, + libv4l, + fftwFloat, +}: mkDerivation rec { version = "9.5.8"; @@ -15,8 +28,16 @@ mkDerivation rec { pkg-config ]; - buildInputs = [ qtbase openjpeg fftw libpulseaudio alsa-lib hamlib libv4l - fftwFloat ]; + buildInputs = [ + qtbase + openjpeg + fftw + libpulseaudio + alsa-lib + hamlib + libv4l + fftwFloat + ]; postInstall = '' # Install desktop icon diff --git a/pkgs/applications/radio/rtl-sdr/default.nix b/pkgs/applications/radio/rtl-sdr/default.nix index 6cb25feb980b80..9697488a7b7d93 100644 --- a/pkgs/applications/radio/rtl-sdr/default.nix +++ b/pkgs/applications/radio/rtl-sdr/default.nix @@ -1,16 +1,26 @@ -{ lib -, stdenv -, fetchFromGitea -, fetchFromGitHub -, cmake -, pkg-config -, libusb1 +{ + lib, + stdenv, + fetchFromGitea, + fetchFromGitHub, + cmake, + pkg-config, + libusb1, }: let - generic = { version, pname, src, meta }: + generic = + { + version, + pname, + src, + meta, + }: stdenv.mkDerivation { inherit version pname src; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; propagatedBuildInputs = [ libusb1 ]; cmakeFlags = lib.optionals stdenv.hostPlatform.isLinux [ @@ -31,7 +41,11 @@ let inherit (meta) longDescription homepage; description = "Software to turn the RTL2832U into a SDR receiver"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ bjornfor skovati Tungsten842 ]; + maintainers = with maintainers; [ + bjornfor + skovati + Tungsten842 + ]; platforms = platforms.unix; mainProgram = "rtl_sdr"; }; diff --git a/pkgs/applications/radio/sdr-j-fm/default.nix b/pkgs/applications/radio/sdr-j-fm/default.nix index e77ce2d88eaaca..23be0ff1ac701a 100644 --- a/pkgs/applications/radio/sdr-j-fm/default.nix +++ b/pkgs/applications/radio/sdr-j-fm/default.nix @@ -50,11 +50,11 @@ stdenv.mkDerivation (finalAttrs: { features = { # All of these features don't require an external depencies, althought it # may be implied - upstraem bundles everything they need in their repo. - AIRSPY = true; - SDRPLAY = true; + AIRSPY = true; + SDRPLAY = true; SDRPLAY_V3 = true; - HACKRF = true; - PLUTO = true; + HACKRF = true; + PLUTO = true; # Some more cmake flags are mentioned in upstream's CMakeLists.txt file # but they don't actually make a difference. } // featuresOverride; diff --git a/pkgs/applications/radio/sdrpp/default.nix b/pkgs/applications/radio/sdrpp/default.nix index 151a967d943ffa..6e140c25bffd1b 100644 --- a/pkgs/applications/radio/sdrpp/default.nix +++ b/pkgs/applications/radio/sdrpp/default.nix @@ -1,40 +1,67 @@ -{ stdenv, lib, fetchFromGitHub, cmake, pkg-config -, libX11, glfw, glew, fftwFloat, volk, zstd, AppKit -# Sources -, airspy_source ? true, airspy -, airspyhf_source ? true, airspyhf -, bladerf_source ? true, libbladeRF -, file_source ? true -, hackrf_source ? true, hackrf -, limesdr_source ? true, limesuite -, perseus_source ? false # needs libperseus-sdr, not yet available in nixpks -, plutosdr_source ? stdenv.hostPlatform.isLinux, libiio, libad9361 -, rfspace_source ? true -, rtl_sdr_source ? true, rtl-sdr-osmocom, libusb1 # osmocom better w/ rtlsdr v4 -, rtl_tcp_source ? true -, sdrplay_source ? false, sdrplay -, soapy_source ? true, soapysdr-with-plugins -, spyserver_source ? true -, usrp_source ? false, uhd, boost - -# Sinks -, audio_sink ? true, rtaudio -, network_sink ? true -, portaudio_sink ? false, portaudio - -# Decoders -, falcon9_decoder ? false -, m17_decoder ? false, codec2 -, meteor_demodulator ? true -, radio ? true -, weather_sat_decoder ? false # is missing some dsp/pll.h - -# Misc -, discord_presence ? true -, frequency_manager ? true -, recorder ? true -, rigctl_server ? true -, scanner ? true +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + libX11, + glfw, + glew, + fftwFloat, + volk, + zstd, + AppKit, + # Sources + airspy_source ? true, + airspy, + airspyhf_source ? true, + airspyhf, + bladerf_source ? true, + libbladeRF, + file_source ? true, + hackrf_source ? true, + hackrf, + limesdr_source ? true, + limesuite, + perseus_source ? false, # needs libperseus-sdr, not yet available in nixpks + plutosdr_source ? stdenv.hostPlatform.isLinux, + libiio, + libad9361, + rfspace_source ? true, + rtl_sdr_source ? true, + rtl-sdr-osmocom, + libusb1, # osmocom better w/ rtlsdr v4 + rtl_tcp_source ? true, + sdrplay_source ? false, + sdrplay, + soapy_source ? true, + soapysdr-with-plugins, + spyserver_source ? true, + usrp_source ? false, + uhd, + boost, + + # Sinks + audio_sink ? true, + rtaudio, + network_sink ? true, + portaudio_sink ? false, + portaudio, + + # Decoders + falcon9_decoder ? false, + m17_decoder ? false, + codec2, + meteor_demodulator ? true, + radio ? true, + weather_sat_decoder ? false, # is missing some dsp/pll.h + + # Misc + discord_presence ? true, + frequency_manager ? true, + recorder ? true, + rigctl_server ? true, + scanner ? true, }: stdenv.mkDerivation rec { @@ -67,9 +94,19 @@ stdenv.mkDerivation rec { substituteInPlace core/src/version.h --replace "1.1.0" "$version" ''; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ glfw glew fftwFloat volk zstd ] + buildInputs = + [ + glfw + glew + fftwFloat + volk + zstd + ] ++ lib.optional stdenv.hostPlatform.isDarwin AppKit ++ lib.optional stdenv.hostPlatform.isLinux libX11 ++ lib.optional airspy_source airspy @@ -77,11 +114,20 @@ stdenv.mkDerivation rec { ++ lib.optional bladerf_source libbladeRF ++ lib.optional hackrf_source hackrf ++ lib.optional limesdr_source limesuite - ++ lib.optionals rtl_sdr_source [ rtl-sdr-osmocom libusb1 ] + ++ lib.optionals rtl_sdr_source [ + rtl-sdr-osmocom + libusb1 + ] ++ lib.optional sdrplay_source sdrplay ++ lib.optional soapy_source soapysdr-with-plugins - ++ lib.optionals plutosdr_source [ libiio libad9361 ] - ++ lib.optionals usrp_source [ uhd boost ] + ++ lib.optionals plutosdr_source [ + libiio + libad9361 + ] + ++ lib.optionals usrp_source [ + uhd + boost + ] ++ lib.optional audio_sink rtaudio ++ lib.optional portaudio_sink portaudio ++ lib.optional m17_decoder codec2; diff --git a/pkgs/applications/radio/sigdigger/default.nix b/pkgs/applications/radio/sigdigger/default.nix index 03f783f970dac2..6e344c84d625f9 100644 --- a/pkgs/applications/radio/sigdigger/default.nix +++ b/pkgs/applications/radio/sigdigger/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, qmake -, qtbase -, pkg-config -, sigutils -, fftwSinglePrec -, suwidgets -, wrapQtAppsHook -, suscan -, libsndfile -, soapysdr-with-plugins -, libxml2 -, volk +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + qtbase, + pkg-config, + sigutils, + fftwSinglePrec, + suwidgets, + wrapQtAppsHook, + suscan, + libsndfile, + soapysdr-with-plugins, + libxml2, + volk, }: stdenv.mkDerivation rec { @@ -55,6 +56,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/BatchDrake/SigDigger"; license = licenses.gpl3; platforms = platforms.all; - maintainers = with maintainers; [ polygon oxapentane ]; + maintainers = with maintainers; [ + polygon + oxapentane + ]; }; } diff --git a/pkgs/applications/radio/soapyairspy/default.nix b/pkgs/applications/radio/soapyairspy/default.nix index 9d198ad15eb35f..975a7dc1c261ad 100644 --- a/pkgs/applications/radio/soapyairspy/default.nix +++ b/pkgs/applications/radio/soapyairspy/default.nix @@ -1,7 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, airspy, soapysdr -, libobjc, IOKit, Security -} : +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + airspy, + soapysdr, + libobjc, + IOKit, + Security, +}: stdenv.mkDerivation rec { pname = "soapyairspy"; @@ -15,8 +22,16 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ airspy soapysdr ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libobjc IOKit Security ]; + buildInputs = + [ + airspy + soapysdr + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + IOKit + Security + ]; cmakeFlags = [ "-DSoapySDR_DIR=${soapysdr}/share/cmake/SoapySDR/" ]; diff --git a/pkgs/applications/radio/soapyaudio/default.nix b/pkgs/applications/radio/soapyaudio/default.nix index 86921754d6b64e..003561495c1b16 100644 --- a/pkgs/applications/radio/soapyaudio/default.nix +++ b/pkgs/applications/radio/soapyaudio/default.nix @@ -1,7 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config -, hamlib, rtaudio, alsa-lib, libpulseaudio, libjack2, libusb1, soapysdr -, Accelerate, CoreAudio -} : +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + hamlib, + rtaudio, + alsa-lib, + libpulseaudio, + libjack2, + libusb1, + soapysdr, + Accelerate, + CoreAudio, +}: stdenv.mkDerivation rec { pname = "soapyaudio"; @@ -14,10 +26,26 @@ stdenv.mkDerivation rec { sha256 = "0minlsc1lvmqm20vn5hb4im7pz8qwklfy7sbr2xr73xkrbqdahc0"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ hamlib rtaudio libjack2 libusb1 soapysdr ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ alsa-lib libpulseaudio ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Accelerate CoreAudio ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = + [ + hamlib + rtaudio + libjack2 + libusb1 + soapysdr + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + libpulseaudio + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Accelerate + CoreAudio + ]; cmakeFlags = [ "-DSoapySDR_DIR=${soapysdr}/share/cmake/SoapySDR/" diff --git a/pkgs/applications/radio/soapybladerf/default.nix b/pkgs/applications/radio/soapybladerf/default.nix index 15c46507350c2e..1def3e822fe107 100644 --- a/pkgs/applications/radio/soapybladerf/default.nix +++ b/pkgs/applications/radio/soapybladerf/default.nix @@ -1,12 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config -, libbladeRF, soapysdr -, libobjc, IOKit, Security -} : +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libbladeRF, + soapysdr, + libobjc, + IOKit, + Security, +}: let version = "0.4.1"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "soapybladerf"; inherit version; @@ -17,13 +26,23 @@ in stdenv.mkDerivation { sha256 = "02wh09850vinqg248fw4lxmx7y857cqmnnb8jm9zhyrsggal0hki"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libbladeRF soapysdr ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libobjc IOKit Security ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = + [ + libbladeRF + soapysdr + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + IOKit + Security + ]; cmakeFlags = [ "-DSoapySDR_DIR=${soapysdr}/share/cmake/SoapySDR/" ]; - meta = with lib; { homepage = "https://github.com/pothosware/SoapyBladeRF"; description = "SoapySDR plugin for BladeRF devices"; diff --git a/pkgs/applications/radio/soapyhackrf/default.nix b/pkgs/applications/radio/soapyhackrf/default.nix index 3f385a4b7255e6..949e5b5bff9da5 100644 --- a/pkgs/applications/radio/soapyhackrf/default.nix +++ b/pkgs/applications/radio/soapyhackrf/default.nix @@ -1,12 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config -, hackrf, soapysdr -, libobjc, IOKit, Security -} : +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + hackrf, + soapysdr, + libobjc, + IOKit, + Security, +}: let version = "0.3.4"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "soapyhackrf"; inherit version; @@ -17,9 +26,20 @@ in stdenv.mkDerivation { sha256 = "sha256-fzPYHJAPX8FkFxPXpLlUagTd/NoamRX0YnxHwkbV1nI="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ hackrf soapysdr ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libobjc IOKit Security ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = + [ + hackrf + soapysdr + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + IOKit + Security + ]; cmakeFlags = [ "-DSoapySDR_DIR=${soapysdr}/share/cmake/SoapySDR/" ]; diff --git a/pkgs/applications/radio/soapyrtlsdr/default.nix b/pkgs/applications/radio/soapyrtlsdr/default.nix index f0a5194a4a9e88..16dd80a12cbc0c 100644 --- a/pkgs/applications/radio/soapyrtlsdr/default.nix +++ b/pkgs/applications/radio/soapyrtlsdr/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, rtl-sdr -, soapysdr -, libobjc -, IOKit -, Security +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + rtl-sdr, + soapysdr, + libobjc, + IOKit, + Security, }: stdenv.mkDerivation (finalAttrs: { @@ -21,9 +22,20 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-IapdrBE8HhibY52Anm76/mVAoA0GghwnRCxxfGkyLTw="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ rtl-sdr soapysdr ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libobjc IOKit Security ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = + [ + rtl-sdr + soapysdr + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + IOKit + Security + ]; cmakeFlags = [ "-DSoapySDR_DIR=${soapysdr}/share/cmake/SoapySDR/" ]; @@ -31,7 +43,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/pothosware/SoapyRTLSDR"; description = "SoapySDR plugin for RTL-SDR devices"; license = licenses.mit; - maintainers = with maintainers; [ ragge luizribeiro ]; + maintainers = with maintainers; [ + ragge + luizribeiro + ]; platforms = platforms.unix; }; }) diff --git a/pkgs/applications/radio/soapyuhd/default.nix b/pkgs/applications/radio/soapyuhd/default.nix index de7b7be855ec69..062a5c17bf0315 100644 --- a/pkgs/applications/radio/soapyuhd/default.nix +++ b/pkgs/applications/radio/soapyuhd/default.nix @@ -1,7 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config -, uhd, boost, soapysdr -, libobjc, IOKit, Security -} : +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + uhd, + boost, + soapysdr, + libobjc, + IOKit, + Security, +}: stdenv.mkDerivation rec { pname = "soapyuhd"; @@ -14,9 +23,21 @@ stdenv.mkDerivation rec { sha256 = "14rk9ap9ayks2ma6mygca08yfds9bgfmip8cvwl87l06hwhnlwhj"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ uhd boost soapysdr ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libobjc IOKit Security ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = + [ + uhd + boost + soapysdr + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + IOKit + Security + ]; cmakeFlags = [ "-DSoapySDR_DIR=${soapysdr}/share/cmake/SoapySDR/" ]; diff --git a/pkgs/applications/radio/suwidgets/default.nix b/pkgs/applications/radio/suwidgets/default.nix index 05f6cf12d6cdce..84fa92ef53527d 100644 --- a/pkgs/applications/radio/suwidgets/default.nix +++ b/pkgs/applications/radio/suwidgets/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, qmake -, qtbase -, pkg-config -, sigutils -, fftwSinglePrec +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + qtbase, + pkg-config, + sigutils, + fftwSinglePrec, }: stdenv.mkDerivation rec { @@ -46,6 +47,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/BatchDrake/SuWidgets"; license = licenses.gpl3; platforms = platforms.all; - maintainers = with maintainers; [ polygon oxapentane ]; + maintainers = with maintainers; [ + polygon + oxapentane + ]; }; } diff --git a/pkgs/applications/radio/svxlink/default.nix b/pkgs/applications/radio/svxlink/default.nix index 8c1d5f2129ea3c..156ba47147629e 100644 --- a/pkgs/applications/radio/svxlink/default.nix +++ b/pkgs/applications/radio/svxlink/default.nix @@ -1,6 +1,26 @@ -{ lib, stdenv, cmake, pkg-config, fetchFromGitHub, makeDesktopItem, alsa-lib, speex -, libopus, curl, gsm, libgcrypt, libsigcxx, popt, qtbase, qttools -, wrapQtAppsHook, rtl-sdr, tcl, doxygen, groff }: +{ + lib, + stdenv, + cmake, + pkg-config, + fetchFromGitHub, + makeDesktopItem, + alsa-lib, + speex, + libopus, + curl, + gsm, + libgcrypt, + libsigcxx, + popt, + qtbase, + qttools, + wrapQtAppsHook, + rtl-sdr, + tcl, + doxygen, + groff, +}: let desktopItem = makeDesktopItem rec { @@ -9,10 +29,15 @@ let icon = "qtel"; desktopName = name; genericName = "EchoLink Client"; - categories = [ "HamRadio" "Qt" "Network" ]; + categories = [ + "HamRadio" + "Qt" + "Network" + ]; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "svxlink"; version = "19.09.2"; @@ -31,7 +56,13 @@ in stdenv.mkDerivation rec { ]; dontWrapQtApps = true; - nativeBuildInputs = [ cmake pkg-config doxygen groff wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + pkg-config + doxygen + groff + wrapQtAppsHook + ]; buildInputs = [ alsa-lib diff --git a/pkgs/applications/radio/uhd/default.nix b/pkgs/applications/radio/uhd/default.nix index 22e734e0dac864..c69de023e25fa1 100644 --- a/pkgs/applications/radio/uhd/default.nix +++ b/pkgs/applications/radio/uhd/default.nix @@ -1,33 +1,34 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitHub -, cmake -, pkg-config -# See https://files.ettus.com/manual_archive/v3.15.0.0/html/page_build_guide.html for dependencies explanations -, boost -, ncurses -, enableCApi ? true -, enablePythonApi ? true -, python3 -, enableExamples ? false -, enableUtils ? true -, libusb1 -# Disable dpdk for now due to compilation issues. -, enableDpdk ? false -, dpdk -# Devices -, enableOctoClock ? true -, enableMpmd ? true -, enableB100 ? true -, enableB200 ? true -, enableUsrp1 ? true -, enableUsrp2 ? true -, enableX300 ? true -, enableN300 ? true -, enableN320 ? true -, enableE300 ? true -, enableE320 ? true +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + cmake, + pkg-config, + # See https://files.ettus.com/manual_archive/v3.15.0.0/html/page_build_guide.html for dependencies explanations + boost, + ncurses, + enableCApi ? true, + enablePythonApi ? true, + python3, + enableExamples ? false, + enableUtils ? true, + libusb1, + # Disable dpdk for now due to compilation issues. + enableDpdk ? false, + dpdk, + # Devices + enableOctoClock ? true, + enableMpmd ? true, + enableB100 ? true, + enableB200 ? true, + enableUsrp1 ? true, + enableUsrp2 ? true, + enableX300 ? true, + enableN300 ? true, + enableN320 ? true, + enableE300 ? true, + enableE320 ? true, }: let @@ -42,7 +43,10 @@ stdenv.mkDerivation (finalAttrs: { # version = "4.7.0.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "EttusResearch"; @@ -62,25 +66,27 @@ stdenv.mkDerivation (finalAttrs: { # This are the minimum required Python dependencies, this attribute might # be useful if you want to build a development environment with a python # interpreter able to import the uhd module. - pythonPath = optionals (enablePythonApi || enableUtils) [ - python3.pkgs.numpy - python3.pkgs.setuptools - ] ++ optionals (enableUtils) [ - python3.pkgs.requests - python3.pkgs.six - - /* These deps are needed for the usrp_hwd.py utility, however even if they - would have been added here, the utility wouldn't have worked because it - depends on an old python library mprpc that is not supported for Python > - 3.8. See also report upstream: - https://github.com/EttusResearch/uhd/issues/744 - - python3.pkgs.gevent - python3.pkgs.pyudev - python3.pkgs.pyroute2 - - */ - ]; + pythonPath = + optionals (enablePythonApi || enableUtils) [ + python3.pkgs.numpy + python3.pkgs.setuptools + ] + ++ optionals (enableUtils) [ + python3.pkgs.requests + python3.pkgs.six + + /* + These deps are needed for the usrp_hwd.py utility, however even if they + would have been added here, the utility wouldn't have worked because it + depends on an old python library mprpc that is not supported for Python > + 3.8. See also report upstream: + https://github.com/EttusResearch/uhd/issues/744 + + python3.pkgs.gevent + python3.pkgs.pyudev + python3.pkgs.pyroute2 + */ + ]; passthru = { runtimePython = python3.withPackages (ps: finalAttrs.pythonPath); updateScript = [ @@ -90,58 +96,58 @@ stdenv.mkDerivation (finalAttrs: { ]; }; - cmakeFlags = [ - "-DENABLE_LIBUHD=ON" - "-DENABLE_USB=ON" - # Regardless of doCheck, we want to build the tests to help us gain - # confident that the package is OK. - "-DENABLE_TESTS=ON" - (cmakeBool "ENABLE_EXAMPLES" enableExamples) - (cmakeBool "ENABLE_UTILS" enableUtils) - (cmakeBool "ENABLE_C_API" enableCApi) - (cmakeBool "ENABLE_PYTHON_API" enablePythonApi) - /* - - Otherwise python tests fail. Using a dedicated pythonEnv for either or both - nativeBuildInputs and buildInputs makes upstream's cmake scripts fail to - install the Python API as reported on our end at [1] (we don't want - upstream to think we are in a virtual environment because we use - python3.withPackages...). - - Putting simply the python dependencies in the nativeBuildInputs and - buildInputs as they are now from some reason makes the `python` in the - checkPhase fail to find the python dependencies, as reported at [2]. Even - using nativeCheckInputs with the python dependencies, or using a - `python3.withPackages` wrapper in nativeCheckInputs, doesn't help, as the - `python` found in $PATH first is the one from nativeBuildInputs. - - [1]: https://github.com/NixOS/nixpkgs/pull/307435 - [2]: https://discourse.nixos.org/t/missing-python-package-in-checkphase/9168/ - - Hence we use upstream's provided cmake flag to control which python - interpreter they will use to run the the python tests. - - */ - "-DRUNTIME_PYTHON_EXECUTABLE=${lib.getExe finalAttrs.passthru.runtimePython}" - (cmakeBool "ENABLE_DPDK" enableDpdk) - # Devices - (cmakeBool "ENABLE_OCTOCLOCK" enableOctoClock) - (cmakeBool "ENABLE_MPMD" enableMpmd) - (cmakeBool "ENABLE_B100" enableB100) - (cmakeBool "ENABLE_B200" enableB200) - (cmakeBool "ENABLE_USRP1" enableUsrp1) - (cmakeBool "ENABLE_USRP2" enableUsrp2) - (cmakeBool "ENABLE_X300" enableX300) - (cmakeBool "ENABLE_N300" enableN300) - (cmakeBool "ENABLE_N320" enableN320) - (cmakeBool "ENABLE_E300" enableE300) - (cmakeBool "ENABLE_E320" enableE320) - # TODO: Check if this still needed - # ABI differences GCC 7.1 - # /nix/store/wd6r25miqbk9ia53pp669gn4wrg9n9cj-gcc-7.3.0/include/c++/7.3.0/bits/vector.tcc:394:7: note: parameter passing for argument of type 'std::vector::iterator {aka __gnu_cxx::__normal_iterator >}' changed in GCC 7.1 - ] ++ optionals stdenv.hostPlatform.isAarch32 [ - "-DCMAKE_CXX_FLAGS=-Wno-psabi" - ]; + cmakeFlags = + [ + "-DENABLE_LIBUHD=ON" + "-DENABLE_USB=ON" + # Regardless of doCheck, we want to build the tests to help us gain + # confident that the package is OK. + "-DENABLE_TESTS=ON" + (cmakeBool "ENABLE_EXAMPLES" enableExamples) + (cmakeBool "ENABLE_UTILS" enableUtils) + (cmakeBool "ENABLE_C_API" enableCApi) + (cmakeBool "ENABLE_PYTHON_API" enablePythonApi) + /* + Otherwise python tests fail. Using a dedicated pythonEnv for either or both + nativeBuildInputs and buildInputs makes upstream's cmake scripts fail to + install the Python API as reported on our end at [1] (we don't want + upstream to think we are in a virtual environment because we use + python3.withPackages...). + + Putting simply the python dependencies in the nativeBuildInputs and + buildInputs as they are now from some reason makes the `python` in the + checkPhase fail to find the python dependencies, as reported at [2]. Even + using nativeCheckInputs with the python dependencies, or using a + `python3.withPackages` wrapper in nativeCheckInputs, doesn't help, as the + `python` found in $PATH first is the one from nativeBuildInputs. + + [1]: https://github.com/NixOS/nixpkgs/pull/307435 + [2]: https://discourse.nixos.org/t/missing-python-package-in-checkphase/9168/ + + Hence we use upstream's provided cmake flag to control which python + interpreter they will use to run the the python tests. + */ + "-DRUNTIME_PYTHON_EXECUTABLE=${lib.getExe finalAttrs.passthru.runtimePython}" + (cmakeBool "ENABLE_DPDK" enableDpdk) + # Devices + (cmakeBool "ENABLE_OCTOCLOCK" enableOctoClock) + (cmakeBool "ENABLE_MPMD" enableMpmd) + (cmakeBool "ENABLE_B100" enableB100) + (cmakeBool "ENABLE_B200" enableB200) + (cmakeBool "ENABLE_USRP1" enableUsrp1) + (cmakeBool "ENABLE_USRP2" enableUsrp2) + (cmakeBool "ENABLE_X300" enableX300) + (cmakeBool "ENABLE_N300" enableN300) + (cmakeBool "ENABLE_N320" enableN320) + (cmakeBool "ENABLE_E300" enableE300) + (cmakeBool "ENABLE_E320" enableE320) + # TODO: Check if this still needed + # ABI differences GCC 7.1 + # /nix/store/wd6r25miqbk9ia53pp669gn4wrg9n9cj-gcc-7.3.0/include/c++/7.3.0/bits/vector.tcc:394:7: note: parameter passing for argument of type 'std::vector::iterator {aka __gnu_cxx::__normal_iterator >}' changed in GCC 7.1 + ] + ++ optionals stdenv.hostPlatform.isAarch32 [ + "-DCMAKE_CXX_FLAGS=-Wno-psabi" + ]; nativeBuildInputs = [ cmake @@ -153,14 +159,19 @@ stdenv.mkDerivation (finalAttrs: { # python utilities are enabled python3.pkgs.wrapPython ]; - buildInputs = finalAttrs.pythonPath ++ [ - boost - libusb1 - ] ++ optionals (enableExamples) [ - ncurses ncurses.dev - ] ++ optionals (enableDpdk) [ - dpdk - ]; + buildInputs = + finalAttrs.pythonPath + ++ [ + boost + libusb1 + ] + ++ optionals (enableExamples) [ + ncurses + ncurses.dev + ] + ++ optionals (enableDpdk) [ + dpdk + ]; # many tests fails on darwin, according to ofborg doCheck = !stdenv.hostPlatform.isDarwin; @@ -172,12 +183,14 @@ stdenv.mkDerivation (finalAttrs: { ./no-adapter-tests.patch ]; - postPhases = [ - "installFirmware" - "removeInstalledTests" - ] ++ optionals (enableUtils && stdenv.hostPlatform.isLinux) [ - "moveUdevRules" - ]; + postPhases = + [ + "installFirmware" + "removeInstalledTests" + ] + ++ optionals (enableUtils && stdenv.hostPlatform.isLinux) [ + "moveUdevRules" + ]; # UHD expects images in `$CMAKE_INSTALL_PREFIX/share/uhd/images` installFirmware = '' @@ -217,6 +230,11 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://uhd.ettus.com/"; license = licenses.gpl3Plus; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ bjornfor fpletz tomberek doronbehar ]; + maintainers = with maintainers; [ + bjornfor + fpletz + tomberek + doronbehar + ]; }; }) diff --git a/pkgs/applications/radio/unixcw/default.nix b/pkgs/applications/radio/unixcw/default.nix index 80121db69c010d..8565b691802d55 100644 --- a/pkgs/applications/radio/unixcw/default.nix +++ b/pkgs/applications/radio/unixcw/default.nix @@ -1,39 +1,51 @@ -{ lib, mkDerivation, fetchurl, libpulseaudio, alsa-lib , pkg-config, qtbase }: +{ + lib, + mkDerivation, + fetchurl, + libpulseaudio, + alsa-lib, + pkg-config, + qtbase, +}: mkDerivation rec { pname = "unixcw"; version = "3.5.1"; src = fetchurl { url = "mirror://sourceforge/unixcw/unixcw_${version}.orig.tar.gz"; - sha256 ="5f3aacd8a26e16e6eff437c7ae1e9b389956fb137eeb3de24670ce05de479e7a"; + sha256 = "5f3aacd8a26e16e6eff437c7ae1e9b389956fb137eeb3de24670ce05de479e7a"; }; patches = [ ./remove-use-of-dlopen.patch ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libpulseaudio alsa-lib qtbase ]; - CFLAGS ="-lasound -lpulse-simple"; + buildInputs = [ + libpulseaudio + alsa-lib + qtbase + ]; + CFLAGS = "-lasound -lpulse-simple"; meta = with lib; { description = "sound characters as Morse code on the soundcard or console speaker"; longDescription = '' - unixcw is a project providing libcw library and a set of programs - using the library: cw, cwgen, cwcp and xcwcp. - The programs are intended for people who want to learn receiving - and sending Morse code. - unixcw is developed and tested primarily on GNU/Linux system. + unixcw is a project providing libcw library and a set of programs + using the library: cw, cwgen, cwcp and xcwcp. + The programs are intended for people who want to learn receiving + and sending Morse code. + unixcw is developed and tested primarily on GNU/Linux system. - cw reads characters from an input file, or from standard input, - and sounds each valid character as Morse code on either the system sound card, - or the system console speaker. - After it sounds a character, cw echoes it to standard output. - The input stream can contain embedded command strings. - These change the parameters used when sounding the Morse code. - cw reports any errors in embedded commands - ''; + cw reads characters from an input file, or from standard input, + and sounds each valid character as Morse code on either the system sound card, + or the system console speaker. + After it sounds a character, cw echoes it to standard output. + The input stream can contain embedded command strings. + These change the parameters used when sounding the Morse code. + cw reports any errors in embedded commands + ''; homepage = "https://unixcw.sourceforge.net"; maintainers = [ maintainers.mafo ]; license = licenses.gpl2; - platforms=platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/applications/radio/wsjtx/default.nix b/pkgs/applications/radio/wsjtx/default.nix index b624898664c8e4..09a5fd5f80d6c4 100644 --- a/pkgs/applications/radio/wsjtx/default.nix +++ b/pkgs/applications/radio/wsjtx/default.nix @@ -1,6 +1,25 @@ -{ lib, stdenv, fetchgit, asciidoc, asciidoctor, cmake, pkg-config, - fftw, fftwFloat, gfortran, hamlib_4, libtool, libusb1, qtbase, - qtmultimedia, qtserialport, qttools, boost, texinfo, wrapQtAppsHook }: +{ + lib, + stdenv, + fetchgit, + asciidoc, + asciidoctor, + cmake, + pkg-config, + fftw, + fftwFloat, + gfortran, + hamlib_4, + libtool, + libusb1, + qtbase, + qtmultimedia, + qtserialport, + qttools, + boost, + texinfo, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "wsjtx"; @@ -13,10 +32,26 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - asciidoc asciidoctor cmake gfortran libtool - pkg-config qttools texinfo wrapQtAppsHook + asciidoc + asciidoctor + cmake + gfortran + libtool + pkg-config + qttools + texinfo + wrapQtAppsHook + ]; + buildInputs = [ + fftw + fftwFloat + hamlib_4 + libusb1 + qtbase + qtmultimedia + qtserialport + boost ]; - buildInputs = [ fftw fftwFloat hamlib_4 libusb1 qtbase qtmultimedia qtserialport boost ]; meta = with lib; { description = "Weak-signal digital communication modes for amateur radio"; @@ -30,6 +65,10 @@ stdenv.mkDerivation rec { homepage = "https://wsjt.sourceforge.io"; license = with licenses; [ gpl3Plus ]; platforms = platforms.linux; - maintainers = with maintainers; [ lasandell numinit melling ]; + maintainers = with maintainers; [ + lasandell + numinit + melling + ]; }; } diff --git a/pkgs/applications/science/astronomy/calcmysky/default.nix b/pkgs/applications/science/astronomy/calcmysky/default.nix index 2fe51ba98d925e..b3bd3ed4ae9f12 100644 --- a/pkgs/applications/science/astronomy/calcmysky/default.nix +++ b/pkgs/applications/science/astronomy/calcmysky/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, wrapQtAppsHook -, glm -, eigen -, qtbase -, stellarium +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + wrapQtAppsHook, + glm, + eigen, + qtbase, + stellarium, }: stdenv.mkDerivation rec { @@ -20,8 +21,15 @@ stdenv.mkDerivation rec { hash = "sha256-18ZNnLK2zMT7P0MDXS6Z38LffE8EqXKBH89TPPxVWlo="; }; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; - buildInputs = [ glm eigen qtbase ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; + buildInputs = [ + glm + eigen + qtbase + ]; cmakeFlags = [ "-DQT_VERSION=6" ]; @@ -31,7 +39,7 @@ stdenv.mkDerivation rec { inherit stellarium; }; - meta = with lib;{ + meta = with lib; { description = "Simulator of light scattering by planetary atmospheres"; homepage = "https://github.com/10110111/CalcMySky"; license = licenses.gpl3Only; diff --git a/pkgs/applications/science/astronomy/celestia/default.nix b/pkgs/applications/science/astronomy/celestia/default.nix index 2d227389d4298e..43b7b27ce71e97 100644 --- a/pkgs/applications/science/astronomy/celestia/default.nix +++ b/pkgs/applications/science/astronomy/celestia/default.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, libglut, gtk2, gtkglext -, libjpeg_turbo, libtheora, libXmu, lua, libGLU, libGL, perl, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libglut, + gtk2, + gtkglext, + libjpeg_turbo, + libtheora, + libXmu, + lua, + libGLU, + libGL, + perl, + autoreconfHook, }: stdenv.mkDerivation rec { @@ -13,10 +27,21 @@ stdenv.mkDerivation rec { sha256 = "sha256-MkElGo1ZR0ImW/526QlDE1ePd+VOQxwkX7l+0WyZ6Vs="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; buildInputs = [ - libglut gtk2 gtkglext lua perl - libjpeg_turbo libtheora libXmu libGLU libGL + libglut + gtk2 + gtkglext + lua + perl + libjpeg_turbo + libtheora + libXmu + libGLU + libGL ]; configureFlags = [ diff --git a/pkgs/applications/science/astronomy/kstars/default.nix b/pkgs/applications/science/astronomy/kstars/default.nix index 5f9fe55b9b5f3c..d2d83bce0e0553 100644 --- a/pkgs/applications/science/astronomy/kstars/default.nix +++ b/pkgs/applications/science/astronomy/kstars/default.nix @@ -1,38 +1,39 @@ -{ lib -, stdenv -, mkDerivation -, extra-cmake-modules -, fetchurl -, kconfig -, kdoctools -, kguiaddons -, ki18n -, kinit -, kiconthemes -, kio -, knewstuff -, kplotting -, kwidgetsaddons -, kxmlgui -, knotifyconfig -, qtx11extras -, qtwebsockets -, qtkeychain -, qtdatavis3d -, wrapQtAppsHook -, breeze-icons -, libsecret -, eigen -, zlib -, cfitsio -, indi-full -, xplanet -, libnova -, libraw -, gsl -, wcslib -, stellarsolver -, libxisf +{ + lib, + stdenv, + mkDerivation, + extra-cmake-modules, + fetchurl, + kconfig, + kdoctools, + kguiaddons, + ki18n, + kinit, + kiconthemes, + kio, + knewstuff, + kplotting, + kwidgetsaddons, + kxmlgui, + knotifyconfig, + qtx11extras, + qtwebsockets, + qtkeychain, + qtdatavis3d, + wrapQtAppsHook, + breeze-icons, + libsecret, + eigen, + zlib, + cfitsio, + indi-full, + xplanet, + libnova, + libraw, + gsl, + wcslib, + stellarsolver, + libxisf, }: stdenv.mkDerivation (finalAttrs: { @@ -97,6 +98,9 @@ stdenv.mkDerivation (finalAttrs: { ''; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ timput hjones2199 ]; + maintainers = with maintainers; [ + timput + hjones2199 + ]; }; }) diff --git a/pkgs/applications/science/astronomy/stellarium/default.nix b/pkgs/applications/science/astronomy/stellarium/default.nix index 5a1787ee867258..e970cfc16b3470 100644 --- a/pkgs/applications/science/astronomy/stellarium/default.nix +++ b/pkgs/applications/science/astronomy/stellarium/default.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, perl -, wrapGAppsHook3 -, wrapQtAppsHook -, qtbase -, qtcharts -, qtpositioning -, qtmultimedia -, qtserialport -, qtwayland -, qtwebengine -, calcmysky -, qxlsx -, indilib -, libnova -, qttools -, exiv2 -, nlopt -, testers -, xvfb-run -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + perl, + wrapGAppsHook3, + wrapQtAppsHook, + qtbase, + qtcharts, + qtpositioning, + qtmultimedia, + qtserialport, + qtwayland, + qtwebengine, + calcmysky, + qxlsx, + indilib, + libnova, + qttools, + exiv2, + nlopt, + testers, + xvfb-run, + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { @@ -60,28 +61,32 @@ stdenv.mkDerivation (finalAttrs: { qttools ]; - buildInputs = [ - qtbase - qtcharts - qtpositioning - qtmultimedia - qtserialport - qtwebengine - calcmysky - qxlsx - indilib - libnova - exiv2 - nlopt - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qtwayland - ]; + buildInputs = + [ + qtbase + qtcharts + qtpositioning + qtmultimedia + qtserialport + qtwebengine + calcmysky + qxlsx + indilib + libnova + exiv2 + nlopt + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qtwayland + ]; - preConfigure = '' - export SOURCE_DATE_EPOCH=$(date -d 20${lib.versions.major finalAttrs.version}0101 +%s) - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - export LC_ALL=en_US.UTF-8 - ''; + preConfigure = + '' + export SOURCE_DATE_EPOCH=$(date -d 20${lib.versions.major finalAttrs.version}0101 +%s) + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + export LC_ALL=en_US.UTF-8 + ''; # fatal error: 'QtSerialPort/QSerialPortInfo' file not found env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-F${qtserialport}/lib"; @@ -111,7 +116,7 @@ stdenv.mkDerivation (finalAttrs: { updateScript = gitUpdater { rev-prefix = "v"; }; }; - meta = { + meta = { description = "Free open-source planetarium"; mainProgram = "stellarium"; homepage = "https://stellarium.org/"; diff --git a/pkgs/applications/science/biology/ants/default.nix b/pkgs/applications/science/biology/ants/default.nix index 3e8435a9ff02eb..6316458e1c289e 100644 --- a/pkgs/applications/science/biology/ants/default.nix +++ b/pkgs/applications/science/biology/ants/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, makeBinaryWrapper -, itk -, vtk -, Cocoa +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + makeBinaryWrapper, + itk, + vtk, + Cocoa, }: stdenv.mkDerivation (finalAttrs: { @@ -24,12 +25,14 @@ stdenv.mkDerivation (finalAttrs: { makeBinaryWrapper ]; - buildInputs = [ - itk - vtk - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Cocoa - ]; + buildInputs = + [ + itk + vtk + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + ]; cmakeFlags = [ "-DANTS_SUPERBUILD=FALSE" diff --git a/pkgs/applications/science/biology/blast/bin.nix b/pkgs/applications/science/biology/blast/bin.nix index 1e3975f9f5ffa1..54d3cd783891a9 100644 --- a/pkgs/applications/science/biology/blast/bin.nix +++ b/pkgs/applications/science/biology/blast/bin.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, python3 -, perl -, blast -, autoPatchelfHook -, zlib -, bzip2 -, glib -, libxml2 -, coreutils +{ + lib, + stdenv, + fetchurl, + python3, + perl, + blast, + autoPatchelfHook, + zlib, + bzip2, + glib, + libxml2, + coreutils, }: let pname = "blast-bin"; @@ -37,7 +38,17 @@ stdenv.mkDerivation { nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ autoPatchelfHook ]; - buildInputs = [ python3 perl ] ++ lib.optionals stdenv.hostPlatform.isLinux [ zlib bzip2 glib libxml2 ]; + buildInputs = + [ + python3 + perl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + zlib + bzip2 + glib + libxml2 + ]; installPhase = '' runHook preInstall @@ -54,7 +65,12 @@ stdenv.mkDerivation { meta = with lib; { inherit (blast.meta) description homepage license; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; maintainers = with maintainers; [ natsukium ]; }; diff --git a/pkgs/applications/science/biology/blast/default.nix b/pkgs/applications/science/biology/blast/default.nix index 9dc5fcb1feb7a9..760137ac382a16 100644 --- a/pkgs/applications/science/biology/blast/default.nix +++ b/pkgs/applications/science/biology/blast/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, buildPackages, fetchurl, zlib, bzip2, perl, cpio, gawk, coreutils, ApplicationServices }: +{ + lib, + stdenv, + buildPackages, + fetchurl, + zlib, + bzip2, + perl, + cpio, + gawk, + coreutils, + ApplicationServices, +}: stdenv.mkDerivation rec { pname = "blast"; @@ -16,8 +28,8 @@ stdenv.mkDerivation rec { # These extra cause clang to hang on Darwin. "--with-flat-makefile" "--without-makefile-auto-update" - "--with-dll" # build dynamic libraries (static are default) - ]; + "--with-dll" # build dynamic libraries (static are default) + ]; makeFlags = [ "all_projects=app/" ]; @@ -80,8 +92,14 @@ stdenv.mkDerivation rec { # perl is necessary in buildInputs so that installed perl scripts get patched # correctly - buildInputs = [ coreutils perl gawk zlib bzip2 cpio ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ ApplicationServices ]; + buildInputs = [ + coreutils + perl + gawk + zlib + bzip2 + cpio + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ ApplicationServices ]; hardeningDisable = [ "format" ]; postInstall = '' diff --git a/pkgs/applications/science/biology/cd-hit/default.nix b/pkgs/applications/science/biology/cd-hit/default.nix index 474c0f292af44a..8a0faae9e63ed2 100644 --- a/pkgs/applications/science/biology/cd-hit/default.nix +++ b/pkgs/applications/science/biology/cd-hit/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, zlib, perl, perlPackages, openmp }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + zlib, + perl, + perlPackages, + openmp, +}: stdenv.mkDerivation rec { version = "4.8.1"; @@ -11,9 +20,16 @@ stdenv.mkDerivation rec { sha256 = "032nva6iiwmw59gjipm1mv0xlcckhxsf45mc2qbnv19lbis0q22i"; }; - propagatedBuildInputs = [ perl perlPackages.TextNSP perlPackages.ImageMagick ]; + propagatedBuildInputs = [ + perl + perlPackages.TextNSP + perlPackages.ImageMagick + ]; - nativeBuildInputs = [ zlib makeWrapper ]; + nativeBuildInputs = [ + zlib + makeWrapper + ]; buildInputs = lib.optional stdenv.cc.isClang openmp; makeFlags = [ diff --git a/pkgs/applications/science/biology/hh-suite/default.nix b/pkgs/applications/science/biology/hh-suite/default.nix index 76c6544b343048..51f12d9ae6eac7 100644 --- a/pkgs/applications/science/biology/hh-suite/default.nix +++ b/pkgs/applications/science/biology/hh-suite/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, xxd -, enableMpi ? false -, mpi -, openmp +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + xxd, + enableMpi ? false, + mpi, + openmp, }: stdenv.mkDerivation rec { pname = "hh-suite"; @@ -28,14 +29,17 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake xxd ]; - cmakeFlags = lib.optional stdenv.hostPlatform.isx86 "-DHAVE_SSE2=1" + nativeBuildInputs = [ + cmake + xxd + ]; + cmakeFlags = + lib.optional stdenv.hostPlatform.isx86 "-DHAVE_SSE2=1" ++ lib.optional stdenv.hostPlatform.isAarch "-DHAVE_ARM8=1" ++ lib.optional stdenv.hostPlatform.avx2Support "-DHAVE_AVX2=1" ++ lib.optional stdenv.hostPlatform.sse4_1Support "-DHAVE_SSE4_1=1"; - buildInputs = lib.optional stdenv.cc.isClang openmp - ++ lib.optional enableMpi mpi; + buildInputs = lib.optional stdenv.cc.isClang openmp ++ lib.optional enableMpi mpi; meta = with lib; { description = "Remote protein homology detection suite"; diff --git a/pkgs/applications/science/biology/iv/default.nix b/pkgs/applications/science/biology/iv/default.nix index a4b408b14a012a..32a32488c7345f 100644 --- a/pkgs/applications/science/biology/iv/default.nix +++ b/pkgs/applications/science/biology/iv/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, neuron-version -, libX11 -, libXext -, patchelf +{ + lib, + stdenv, + fetchurl, + neuron-version, + libX11, + libXext, + patchelf, }: stdenv.mkDerivation rec { @@ -22,17 +23,19 @@ stdenv.mkDerivation rec { hardeningDisable = [ "format" ]; - postInstall = '' - for dir in $out/*; do # */ - if [ -d $dir/lib ]; then - mv $dir/* $out # */ - rmdir $dir - break - fi - done - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - patchelf --add-needed ${libX11}/lib/libX11.so $out/lib/libIVhines.so - ''; + postInstall = + '' + for dir in $out/*; do # */ + if [ -d $dir/lib ]; then + mv $dir/* $out # */ + rmdir $dir + break + fi + done + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + patchelf --add-needed ${libX11}/lib/libX11.so $out/lib/libIVhines.so + ''; meta = with lib; { description = "InterViews graphical library for Neuron"; diff --git a/pkgs/applications/science/biology/kallisto/default.nix b/pkgs/applications/science/biology/kallisto/default.nix index 686a9de554e9ce..9ba81327710dfa 100644 --- a/pkgs/applications/science/biology/kallisto/default.nix +++ b/pkgs/applications/science/biology/kallisto/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, cmake, hdf5, zlib, nix-update-script }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + cmake, + hdf5, + zlib, + nix-update-script, +}: stdenv.mkDerivation rec { pname = "kallisto"; @@ -11,9 +20,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-hfdeztEyHvuOnLS71oSv8sPqFe2UCX5KlANqrT/Gfx8="; }; - nativeBuildInputs = [ autoconf cmake ]; + nativeBuildInputs = [ + autoconf + cmake + ]; - buildInputs = [ hdf5 zlib ]; + buildInputs = [ + hdf5 + zlib + ]; cmakeFlags = [ "-DUSE_HDF5=ON" ]; diff --git a/pkgs/applications/science/biology/mrtrix/default.nix b/pkgs/applications/science/biology/mrtrix/default.nix index e17aa3ca038c71..7b107029dd20d5 100644 --- a/pkgs/applications/science/biology/mrtrix/default.nix +++ b/pkgs/applications/science/biology/mrtrix/default.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchFromGitHub -, python -, makeWrapper -, eigen -, fftw -, libtiff -, libpng -, zlib -, ants -, bc -, qt5 -, libGL -, libGLU -, libX11 -, libXext -, less -, withGui ? true +{ + stdenv, + lib, + fetchFromGitHub, + python, + makeWrapper, + eigen, + fftw, + libtiff, + libpng, + zlib, + ants, + bc, + qt5, + libGL, + libGLU, + libX11, + libXext, + less, + withGui ? true, }: stdenv.mkDerivation rec { @@ -31,23 +32,28 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ eigen makeWrapper ] ++ lib.optional withGui qt5.wrapQtAppsHook; - - buildInputs = [ - ants - python - fftw - libtiff - libpng - zlib - ] ++ lib.optionals withGui [ - libGL - libGLU - libX11 - libXext - qt5.qtbase - qt5.qtsvg - ]; + nativeBuildInputs = [ + eigen + makeWrapper + ] ++ lib.optional withGui qt5.wrapQtAppsHook; + + buildInputs = + [ + ants + python + fftw + libtiff + libpng + zlib + ] + ++ lib.optionals withGui [ + libGL + libGLU + libX11 + libXext + qt5.qtbase + qt5.qtsvg + ]; nativeInstallCheckInputs = [ bc ]; @@ -107,6 +113,6 @@ stdenv.mkDerivation rec { description = "Suite of tools for diffusion imaging"; maintainers = with maintainers; [ bcdarwin ]; platforms = platforms.linux; - license = licenses.mpl20; + license = licenses.mpl20; }; } diff --git a/pkgs/applications/science/biology/nest/default.nix b/pkgs/applications/science/biology/nest/default.nix index 9714f015f71a41..3026ac9ce8859a 100644 --- a/pkgs/applications/science/biology/nest/default.nix +++ b/pkgs/applications/science/biology/nest/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, testers -, cmake -, gsl -, libtool -, findutils -, llvmPackages -, mpi -, nest -, pkg-config -, boost -, python3 -, readline -, withPython ? false -, withMpi ? false +{ + lib, + stdenv, + fetchFromGitHub, + testers, + cmake, + gsl, + libtool, + findutils, + llvmPackages, + mpi, + nest, + pkg-config, + boost, + python3, + readline, + withPython ? false, + withMpi ? false, }: stdenv.mkDerivation rec { @@ -42,15 +43,18 @@ stdenv.mkDerivation rec { findutils ]; - buildInputs = [ - gsl - readline - libtool # libltdl - boost - ] ++ lib.optionals withPython [ - python3 - python3.pkgs.cython - ] ++ lib.optional withMpi mpi + buildInputs = + [ + gsl + readline + libtool # libltdl + boost + ] + ++ lib.optionals withPython [ + python3 + python3.pkgs.cython + ] + ++ lib.optional withMpi mpi ++ lib.optional stdenv.hostPlatform.isDarwin llvmPackages.openmp; propagatedBuildInputs = with python3.pkgs; [ @@ -79,7 +83,10 @@ stdenv.mkDerivation rec { homepage = "https://www.nest-simulator.org/"; changelog = "https://github.com/nest/nest-simulator/releases/tag/v${version}"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ jiegec davidcromp ]; + maintainers = with maintainers; [ + jiegec + davidcromp + ]; platforms = platforms.unix; }; } diff --git a/pkgs/applications/science/biology/obitools/obitools3.nix b/pkgs/applications/science/biology/obitools/obitools3.nix index 53aa177307dfa9..8470b37699de09 100644 --- a/pkgs/applications/science/biology/obitools/obitools3.nix +++ b/pkgs/applications/science/biology/obitools/obitools3.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchurl, python3Packages, cmake, python3 }: +{ + stdenv, + lib, + fetchurl, + python3Packages, + cmake, + python3, +}: python3Packages.buildPythonApplication rec { pname = "obitools3"; @@ -9,11 +16,14 @@ python3Packages.buildPythonApplication rec { sha256 = "1x7a0nrr9agg1pfgq8i1j8r1p6c0jpyxsv196ylix1dd2iivmas1"; }; - nativeBuildInputs = [ python3Packages.cython cmake ]; + nativeBuildInputs = [ + python3Packages.cython + cmake + ]; postPatch = lib.optionalString stdenv.hostPlatform.isAarch64 '' - substituteInPlace setup.py \ - --replace "'-msse2'," "" + substituteInPlace setup.py \ + --replace "'-msse2'," "" ''; preBuild = '' @@ -25,7 +35,7 @@ python3Packages.buildPythonApplication rec { doCheck = true; - meta = with lib ; { + meta = with lib; { description = "Management of analyses and data in DNA metabarcoding"; mainProgram = "obi"; homepage = "https://git.metabarcoding.org/obitools/obitools3"; diff --git a/pkgs/applications/science/biology/samtools/default.nix b/pkgs/applications/science/biology/samtools/default.nix index 7e12047e095bcd..f7426dd112709e 100644 --- a/pkgs/applications/science/biology/samtools/default.nix +++ b/pkgs/applications/science/biology/samtools/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, zlib, htslib, perl, ncurses ? null }: +{ + lib, + stdenv, + fetchurl, + zlib, + htslib, + perl, + ncurses ? null, +}: stdenv.mkDerivation rec { pname = "samtools"; @@ -14,17 +22,21 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ perl ]; - buildInputs = [ zlib ncurses htslib ]; + buildInputs = [ + zlib + ncurses + htslib + ]; preConfigure = lib.optional stdenv.hostPlatform.isStatic '' export LIBS="-lz -lbz2 -llzma" ''; makeFlags = lib.optional stdenv.hostPlatform.isStatic "AR=${stdenv.cc.targetPrefix}ar"; - configureFlags = [ "--with-htslib=${htslib}" ] + configureFlags = + [ "--with-htslib=${htslib}" ] ++ lib.optional (ncurses == null) "--without-curses" - ++ lib.optionals stdenv.hostPlatform.isStatic ["--without-curses" ] - ; + ++ lib.optionals stdenv.hostPlatform.isStatic [ "--without-curses" ]; preCheck = '' patchShebangs test/ @@ -39,6 +51,9 @@ stdenv.mkDerivation rec { license = licenses.mit; homepage = "http://www.htslib.org/"; platforms = platforms.unix; - maintainers = with maintainers; [ mimame unode ]; + maintainers = with maintainers; [ + mimame + unode + ]; }; } diff --git a/pkgs/applications/science/biology/samtools/samtools_0_1_19.nix b/pkgs/applications/science/biology/samtools/samtools_0_1_19.nix index edb3a9a9da5bb1..dddf33a536b3f4 100644 --- a/pkgs/applications/science/biology/samtools/samtools_0_1_19.nix +++ b/pkgs/applications/science/biology/samtools/samtools_0_1_19.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, zlib }: +{ + lib, + stdenv, + fetchurl, + zlib, +}: stdenv.mkDerivation rec { pname = "samtools"; diff --git a/pkgs/applications/science/biology/sumatools/default.nix b/pkgs/applications/science/biology/sumatools/default.nix index 2a30f33172b959..fc07cd661c5641 100644 --- a/pkgs/applications/science/biology/sumatools/default.nix +++ b/pkgs/applications/science/biology/sumatools/default.nix @@ -1,4 +1,9 @@ -{ lib, gccStdenv, fetchFromGitLab, zlib }: +{ + lib, + gccStdenv, + fetchFromGitLab, + zlib, +}: let stdenv = gccStdenv; @@ -9,7 +14,8 @@ let platforms = platforms.unix; }; -in rec { +in +rec { # Suma library sumalibs = stdenv.mkDerivation rec { @@ -37,7 +43,10 @@ in rec { rev = "${pname}_v${version}"; sha256 = "1bbpbdkshdc3xffqnr1qfy8qk64ldsmdc3s8mrcrlx132rgbi5f6"; }; - buildInputs = [ sumalibs zlib ]; + buildInputs = [ + sumalibs + zlib + ]; makeFlags = [ "LIBSUMA=${sumalibs}/lib/libsuma.a" "LIBSUMAPATH=-L${sumalibs}" diff --git a/pkgs/applications/science/biology/trimmomatic/default.nix b/pkgs/applications/science/biology/trimmomatic/default.nix index 111a4dda9e9df5..1c22b3ec7fb3ab 100644 --- a/pkgs/applications/science/biology/trimmomatic/default.nix +++ b/pkgs/applications/science/biology/trimmomatic/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, ant -, jdk -, jre -, makeWrapper -, stripJavaArchivesHook +{ + lib, + stdenv, + fetchFromGitHub, + ant, + jdk, + jre, + makeWrapper, + stripJavaArchivesHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/science/biology/truvari/default.nix b/pkgs/applications/science/biology/truvari/default.nix index 3c523b21fc641a..51fd73ea2493f0 100644 --- a/pkgs/applications/science/biology/truvari/default.nix +++ b/pkgs/applications/science/biology/truvari/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, python3Packages -, runtimeShell -, bcftools -, htslib +{ + lib, + fetchFromGitHub, + python3Packages, + runtimeShell, + bcftools, + htslib, }: let @@ -13,7 +14,8 @@ let rev = "d21f7f928a167fca6e2eb31616673444d15e6fd0"; hash = "sha256-zecZHEnfhDtT44VMbHLHOhRtNsIMWeaBASupVXtmrks="; }; -in python3Packages.buildPythonApplication rec { +in +python3Packages.buildPythonApplication rec { pname = "truvari"; version = "4.2.2"; pyproject = true; @@ -50,17 +52,25 @@ in python3Packages.buildPythonApplication rec { ]; makeWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath [ bcftools htslib ]) + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ + bcftools + htslib + ]) ]; pythonImportsCheck = [ "truvari" ]; - nativeCheckInputs = [ - bcftools - htslib - ] ++ (with python3Packages; [ - coverage - ]); + nativeCheckInputs = + [ + bcftools + htslib + ] + ++ (with python3Packages; [ + coverage + ]); checkPhase = '' runHook preCheck @@ -76,7 +86,10 @@ in python3Packages.buildPythonApplication rec { homepage = "https://github.com/ACEnglish/truvari"; changelog = "https://github.com/ACEnglish/truvari/releases/tag/${src.rev}"; license = licenses.mit; - maintainers = with maintainers; [ natsukium scalavision ]; + maintainers = with maintainers; [ + natsukium + scalavision + ]; longDescription = '' Truvari is a benchmarking tool for comparison sets of SVs. It can calculate the recall, precision, and f-measure of a diff --git a/pkgs/applications/science/chemistry/autodock-vina/default.nix b/pkgs/applications/science/chemistry/autodock-vina/default.nix index 844fe5fea7ed53..1a0549ea68a3d6 100644 --- a/pkgs/applications/science/chemistry/autodock-vina/default.nix +++ b/pkgs/applications/science/chemistry/autodock-vina/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, boost -, glibc +{ + lib, + stdenv, + fetchFromGitHub, + boost, + glibc, }: let boost' = boost.override { @@ -21,15 +22,16 @@ stdenv.mkDerivation (finalAttrs: { }; sourceRoot = "${finalAttrs.src.name}/build/${ - if stdenv.hostPlatform.isDarwin then "mac" - else "linux" + if stdenv.hostPlatform.isDarwin then "mac" else "linux" }/release"; - buildInputs = [ - boost' - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - glibc.static - ]; + buildInputs = + [ + boost' + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + glibc.static + ]; makeFlags = [ "GPP=${stdenv.cc.targetPrefix}c++" diff --git a/pkgs/applications/science/chemistry/autodock-vina/python-bindings.nix b/pkgs/applications/science/chemistry/autodock-vina/python-bindings.nix index fb7fd1ece0e652..fac32fed596a6f 100644 --- a/pkgs/applications/science/chemistry/autodock-vina/python-bindings.nix +++ b/pkgs/applications/science/chemistry/autodock-vina/python-bindings.nix @@ -1,14 +1,20 @@ -{ lib -, buildPythonPackage -, autodock-vina -, boost -, swig -, setuptools -, numpy +{ + lib, + buildPythonPackage, + autodock-vina, + boost, + swig, + setuptools, + numpy, }: buildPythonPackage { - inherit (autodock-vina) pname version src meta; + inherit (autodock-vina) + pname + version + src + meta + ; format = "pyproject"; diff --git a/pkgs/applications/science/chemistry/avogadro2/default.nix b/pkgs/applications/science/chemistry/avogadro2/default.nix index f69f10164cc1c3..a7b3e656b77cde 100644 --- a/pkgs/applications/science/chemistry/avogadro2/default.nix +++ b/pkgs/applications/science/chemistry/avogadro2/default.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, cmake, eigen, avogadrolibs, molequeue, hdf5 -, openbabel, qttools, wrapQtAppsHook, mesa +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + eigen, + avogadrolibs, + molequeue, + hdf5, + openbabel, + qttools, + wrapQtAppsHook, + mesa, }: let @@ -10,7 +21,8 @@ let hash = "sha256-AR/y70zeYR9xBzWDB5JXjJdDM+NLOX6yxCQte2lYN/U="; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "avogadro2"; version = "1.99.0"; @@ -25,7 +37,10 @@ in stdenv.mkDerivation rec { cp -r ${avogadroI18N} avogadro-i18n ''; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; buildInputs = [ avogadrolibs diff --git a/pkgs/applications/science/chemistry/marvin/default.nix b/pkgs/applications/science/chemistry/marvin/default.nix index e1e911e2d4dfbc..dc1822bfa59da3 100644 --- a/pkgs/applications/science/chemistry/marvin/default.nix +++ b/pkgs/applications/science/chemistry/marvin/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, dpkg, makeWrapper, coreutils, gawk, gnugrep, gnused, openjdk17 }: +{ + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + coreutils, + gawk, + gnugrep, + gnused, + openjdk17, +}: stdenv.mkDerivation rec { pname = "marvin"; @@ -10,7 +21,10 @@ stdenv.mkDerivation rec { hash = "sha256-zE/9EaOsNJwzE4Doasm9N8QG4t7wDOxqpV/Nhc4p7Ws="; }; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; unpackPhase = '' dpkg-deb -x $src opt @@ -20,7 +34,14 @@ stdenv.mkDerivation rec { wrapBin() { makeWrapper $1 $out/bin/$(basename $1) \ --set INSTALL4J_JAVA_HOME "${openjdk17}" \ - --prefix PATH : ${lib.makeBinPath [ coreutils gawk gnugrep gnused ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + gawk + gnugrep + gnused + ] + } } cp -r opt $out mkdir -p $out/bin $out/share/pixmaps $out/share/applications @@ -31,9 +52,17 @@ stdenv.mkDerivation rec { for name in cxcalc cxtrain evaluate molconvert mview msketch; do wrapBin $out/opt/chemaxon/marvinsuite/bin/$name done - ${lib.concatStrings (map (name: '' - substitute ${./. + "/${name}.desktop"} $out/share/applications/${name}.desktop --subst-var out - '') [ "LicenseManager" "MarvinSketch" "MarvinView" ])} + ${lib.concatStrings ( + map + (name: '' + substitute ${./. + "/${name}.desktop"} $out/share/applications/${name}.desktop --subst-var out + '') + [ + "LicenseManager" + "MarvinSketch" + "MarvinView" + ] + )} ''; meta = with lib; { diff --git a/pkgs/applications/science/chemistry/nwchem/default.nix b/pkgs/applications/science/chemistry/nwchem/default.nix index d3d349969bb2fc..cc80ad3c67ec07 100644 --- a/pkgs/applications/science/chemistry/nwchem/default.nix +++ b/pkgs/applications/science/chemistry/nwchem/default.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchurl -, mpiCheckPhaseHook -, which -, openssh -, gcc -, gfortran -, perl -, mpi -, blas -, lapack -, python3 -, tcsh -, automake -, autoconf -, libtool -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + mpiCheckPhaseHook, + which, + openssh, + gcc, + gfortran, + perl, + mpi, + blas, + lapack, + python3, + tcsh, + automake, + autoconf, + libtool, + makeWrapper, }: assert blas.isILP64 == lapack.isILP64; @@ -211,8 +212,14 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Open Source High-Performance Computational Chemistry"; mainProgram = "nwchem"; - platforms = [ "x86_64-linux" "aarch64-linux" ]; - maintainers = with maintainers; [ sheepforce markuskowa ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; + maintainers = with maintainers; [ + sheepforce + markuskowa + ]; homepage = "https://nwchemgit.github.io"; license = licenses.ecl20; }; diff --git a/pkgs/applications/science/chemistry/pymol/default.nix b/pkgs/applications/science/chemistry/pymol/default.nix index 295ac7e14cb232..2a02d4aed2f73f 100644 --- a/pkgs/applications/science/chemistry/pymol/default.nix +++ b/pkgs/applications/science/chemistry/pymol/default.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, makeDesktopItem -, python3Packages -, netcdf -, glew -, glm -, libpng -, libxml2 -, freetype -, msgpack -, qt5 +{ + stdenv, + lib, + fetchFromGitHub, + makeDesktopItem, + python3Packages, + netcdf, + glew, + glm, + libpng, + libxml2, + freetype, + msgpack, + qt5, }: let pname = "pymol"; @@ -32,7 +33,12 @@ let "chemical/x-xyz" "chemical/x-mdl-sdf" ]; - categories = [ "Graphics" "Education" "Science" "Chemistry" ]; + categories = [ + "Graphics" + "Education" + "Science" + "Chemistry" + ]; }; in python3Packages.buildPythonApplication rec { @@ -57,18 +63,36 @@ python3Packages.buildPythonApplication rec { ]; nativeBuildInputs = [ qt5.wrapQtAppsHook ]; - buildInputs = [ python3Packages.numpy python3Packages.pyqt5 glew glm libpng libxml2 freetype msgpack netcdf ]; + buildInputs = [ + python3Packages.numpy + python3Packages.pyqt5 + glew + glm + libpng + libxml2 + freetype + msgpack + netcdf + ]; env.NIX_CFLAGS_COMPILE = "-I ${libxml2.dev}/include/libxml2"; - postInstall = with python3Packages; '' - wrapProgram $out/bin/pymol \ - --prefix PYTHONPATH : ${lib.makeSearchPathOutput "lib" python3Packages.python.sitePackages [ pyqt5 pyqt5.pyqt5-sip ]} - - mkdir -p "$out/share/icons/" - ln -s $out/${python3Packages.python.sitePackages}/pymol/pymol_path/data/pymol/icons/icon2.svg "$out/share/icons/pymol.svg" - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - cp -r "${desktopItem}/share/applications/" "$out/share/" - ''; + postInstall = + with python3Packages; + '' + wrapProgram $out/bin/pymol \ + --prefix PYTHONPATH : ${ + lib.makeSearchPathOutput "lib" python3Packages.python.sitePackages [ + pyqt5 + pyqt5.pyqt5-sip + ] + } + + mkdir -p "$out/share/icons/" + ln -s $out/${python3Packages.python.sitePackages}/pymol/pymol_path/data/pymol/icons/icon2.svg "$out/share/icons/pymol.svg" + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + cp -r "${desktopItem}/share/applications/" "$out/share/" + ''; pythonImportsCheck = [ "pymol" @@ -115,6 +139,9 @@ python3Packages.buildPythonApplication rec { mainProgram = "pymol"; homepage = "https://www.pymol.org/"; license = licenses.mit; - maintainers = with maintainers; [ natsukium samlich ]; + maintainers = with maintainers; [ + natsukium + samlich + ]; }; } diff --git a/pkgs/applications/science/chemistry/quantum-espresso/default.nix b/pkgs/applications/science/chemistry/quantum-espresso/default.nix index 2156c1d2696915..8220cc842fb67c 100644 --- a/pkgs/applications/science/chemistry/quantum-espresso/default.nix +++ b/pkgs/applications/science/chemistry/quantum-espresso/default.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchFromGitHub -, git -, cmake -, gfortran -, pkg-config -, fftw -, blas -, lapack -, scalapack -, wannier90 -, hdf5 -, libmbd -, libxc -, enableMpi ? true -, mpi +{ + lib, + stdenv, + fetchFromGitLab, + fetchFromGitHub, + git, + cmake, + gfortran, + pkg-config, + fftw, + blas, + lapack, + scalapack, + wannier90, + hdf5, + libmbd, + libxc, + enableMpi ? true, + mpi, }: -assert ! blas.isILP64; -assert ! lapack.isILP64; +assert !blas.isILP64; +assert !lapack.isILP64; let # "rev"s must exactly match the git submodule commits in the QE repo @@ -63,13 +64,12 @@ stdenv.mkDerivation rec { --replace "qe_git_submodule_update(external/d3q)" "" \ --replace "qe_git_submodule_update(external/qe-gipaw)" "" - ${builtins.toString (builtins.attrValues - (builtins.mapAttrs - (name: val: '' + ${builtins.toString ( + builtins.attrValues ( + builtins.mapAttrs (name: val: '' cp -r ${val}/* external/${name}/. chmod -R +rwx external/${name} - '') - gitSubmodules + '') gitSubmodules ) )} @@ -99,19 +99,21 @@ stdenv.mkDerivation rec { propagatedBuildInputs = lib.optional enableMpi mpi; propagatedUserEnvPkgs = lib.optional enableMpi mpi; - cmakeFlags = [ - "-DBUILD_SHARED_LIBS=ON" - "-DWANNIER90_ROOT=${wannier90}" - "-DMBD_ROOT=${libmbd}" - "-DQE_ENABLE_OPENMP=ON" - "-DQE_ENABLE_LIBXC=ON" - "-DQE_ENABLE_HDF5=ON" - "-DQE_ENABLE_PLUGINS=pw2qmcpack" - ] ++ lib.optionals enableMpi [ - "-DQE_ENABLE_MPI=ON" - "-DQE_ENABLE_MPI_MODULE=ON" - "-DQE_ENABLE_SCALAPACK=ON" - ]; + cmakeFlags = + [ + "-DBUILD_SHARED_LIBS=ON" + "-DWANNIER90_ROOT=${wannier90}" + "-DMBD_ROOT=${libmbd}" + "-DQE_ENABLE_OPENMP=ON" + "-DQE_ENABLE_LIBXC=ON" + "-DQE_ENABLE_HDF5=ON" + "-DQE_ENABLE_PLUGINS=pw2qmcpack" + ] + ++ lib.optionals enableMpi [ + "-DQE_ENABLE_MPI=ON" + "-DQE_ENABLE_MPI_MODULE=ON" + "-DQE_ENABLE_SCALAPACK=ON" + ]; meta = with lib; { description = "Electronic-structure calculations and materials modeling at the nanoscale"; @@ -123,7 +125,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://www.quantum-espresso.org/"; license = licenses.gpl2; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; maintainers = [ maintainers.costrouc ]; }; } diff --git a/pkgs/applications/science/chemistry/siesta/default.nix b/pkgs/applications/science/chemistry/siesta/default.nix index 2ec4d37f73ed2d..2d662a407dc89b 100644 --- a/pkgs/applications/science/chemistry/siesta/default.nix +++ b/pkgs/applications/science/chemistry/siesta/default.nix @@ -1,8 +1,13 @@ -{ lib, stdenv -, gfortran, blas, lapack, scalapack -, useMpi ? false -, mpi -, fetchFromGitLab +{ + lib, + stdenv, + gfortran, + blas, + lapack, + scalapack, + useMpi ? false, + mpi, + fetchFromGitLab, }: stdenv.mkDerivation rec { @@ -26,10 +31,17 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ gfortran ]; - buildInputs = [ blas lapack ] - ++ lib.optionals useMpi [ mpi scalapack ]; + buildInputs = + [ + blas + lapack + ] + ++ lib.optionals useMpi [ + mpi + scalapack + ]; - enableParallelBuilding = false; # Started making trouble with gcc-11 + enableParallelBuilding = false; # Started making trouble with gcc-11 # Must do manually because siesta does not do the regular # ./configure; make; make install @@ -39,23 +51,30 @@ stdenv.mkDerivation rec { cp gfortran.make arch.make ''; - preBuild = '' - # See https://gitlab.com/siesta-project/siesta/-/commit/a10bf1628e7141ba263841889c3503c263de1582 - # This may be fixed in the next release. - makeFlagsArray=( - FFLAGS="-fallow-argument-mismatch" - ) - '' + (if useMpi then '' - makeFlagsArray+=( - CC="mpicc" FC="mpifort" - FPPFLAGS="-DMPI" MPI_INTERFACE="libmpi_f90.a" MPI_INCLUDE="." - COMP_LIBS="" LIBS="-lblas -llapack -lscalapack" + preBuild = + '' + # See https://gitlab.com/siesta-project/siesta/-/commit/a10bf1628e7141ba263841889c3503c263de1582 + # This may be fixed in the next release. + makeFlagsArray=( + FFLAGS="-fallow-argument-mismatch" + ) + '' + + ( + if useMpi then + '' + makeFlagsArray+=( + CC="mpicc" FC="mpifort" + FPPFLAGS="-DMPI" MPI_INTERFACE="libmpi_f90.a" MPI_INCLUDE="." + COMP_LIBS="" LIBS="-lblas -llapack -lscalapack" + ); + '' + else + '' + makeFlagsArray+=( + COMP_LIBS="" LIBS="-lblas -llapack" + ); + '' ); - '' else '' - makeFlagsArray+=( - COMP_LIBS="" LIBS="-lblas -llapack" - ); - ''); installPhase = '' mkdir -p $out/bin @@ -66,18 +85,18 @@ stdenv.mkDerivation rec { description = "First-principles materials simulation code using DFT"; mainProgram = "siesta"; longDescription = '' - SIESTA is both a method and its computer program - implementation, to perform efficient electronic structure - calculations and ab initio molecular dynamics simulations of - molecules and solids. SIESTA's efficiency stems from the use - of strictly localized basis sets and from the implementation - of linear-scaling algorithms which can be applied to suitable - systems. A very important feature of the code is that its - accuracy and cost can be tuned in a wide range, from quick - exploratory calculations to highly accurate simulations - matching the quality of other approaches, such as plane-wave - and all-electron methods. - ''; + SIESTA is both a method and its computer program + implementation, to perform efficient electronic structure + calculations and ab initio molecular dynamics simulations of + molecules and solids. SIESTA's efficiency stems from the use + of strictly localized basis sets and from the implementation + of linear-scaling algorithms which can be applied to suitable + systems. A very important feature of the code is that its + accuracy and cost can be tuned in a wide range, from quick + exploratory calculations to highly accurate simulations + matching the quality of other approaches, such as plane-wave + and all-electron methods. + ''; homepage = "https://siesta-project.org/siesta/"; license = licenses.gpl2; platforms = [ "x86_64-linux" ]; diff --git a/pkgs/applications/science/computer-architecture/qtrvsim/default.nix b/pkgs/applications/science/computer-architecture/qtrvsim/default.nix index 41597cb02945fa..cfe7606cbbb0ea 100644 --- a/pkgs/applications/science/computer-architecture/qtrvsim/default.nix +++ b/pkgs/applications/science/computer-architecture/qtrvsim/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, wrapQtAppsHook, qtbase }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + wrapQtAppsHook, + qtbase, +}: stdenv.mkDerivation rec { pname = "QtRVSim"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-+EpPDA2+mBTdQjq6i9TN11yeXqvJA28JtmdNihM1a/U="; }; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; buildInputs = [ qtbase ]; diff --git a/pkgs/applications/science/computer-architecture/timeloop/default.nix b/pkgs/applications/science/computer-architecture/timeloop/default.nix index 3a70478262d554..627773ef7b9a8f 100644 --- a/pkgs/applications/science/computer-architecture/timeloop/default.nix +++ b/pkgs/applications/science/computer-architecture/timeloop/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, scons -, libconfig -, boost -, libyaml -, yaml-cpp -, ncurses -, gpm -, enableAccelergy ? true -, enableISL ? false -, accelergy +{ + lib, + stdenv, + fetchFromGitHub, + scons, + libconfig, + boost, + libyaml, + yaml-cpp, + ncurses, + gpm, + enableAccelergy ? true, + enableISL ? false, + accelergy, }: stdenv.mkDerivation rec { @@ -33,7 +34,7 @@ stdenv.mkDerivation rec { yaml-cpp ncurses accelergy - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ gpm ]; + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ gpm ]; preConfigure = '' cp -r ./pat-public/src/pat ./src/pat @@ -41,37 +42,39 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - postPatch = '' - # Fix gcc-13 build failure due to missing includes: - sed -e '1i #include ' -i \ - include/compound-config/compound-config.hpp - - # use nix ar/ranlib - substituteInPlace ./SConstruct \ - --replace-fail "env.Replace(AR = \"gcc-ar\")" "pass" \ - --replace-fail "env.Replace(RANLIB = \"gcc-ranlib\")" "pass" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # prevent clang from dying on errors that gcc is fine with - substituteInPlace ./src/SConscript --replace "-Werror" "-Wno-inconsistent-missing-override" - - # disable LTO on macos - substituteInPlace ./src/SConscript --replace ", '-flto'" "" - - # static builds on mac fail as no static libcrt is provided by apple - # see https://stackoverflow.com/questions/3801011/ld-library-not-found-for-lcrt0-o-on-osx-10-6-with-gcc-clang-static-flag - substituteInPlace ./src/SConscript \ - --replace "'-static-libgcc', " "" \ - --replace "'-static-libstdc++', " "" \ - --replace "'-Wl,--whole-archive', '-static', " "" \ - --replace ", '-Wl,--no-whole-archive'" "" - - #remove hardcoding of gcc - sed -i '40i env.Replace(CC = "${stdenv.cc.targetPrefix}cc")' ./SConstruct - sed -i '40i env.Replace(CXX = "${stdenv.cc.targetPrefix}c++")' ./SConstruct - - #gpm doesn't exist on darwin - substituteInPlace ./src/SConscript --replace ", 'gpm'" "" - ''; + postPatch = + '' + # Fix gcc-13 build failure due to missing includes: + sed -e '1i #include ' -i \ + include/compound-config/compound-config.hpp + + # use nix ar/ranlib + substituteInPlace ./SConstruct \ + --replace-fail "env.Replace(AR = \"gcc-ar\")" "pass" \ + --replace-fail "env.Replace(RANLIB = \"gcc-ranlib\")" "pass" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # prevent clang from dying on errors that gcc is fine with + substituteInPlace ./src/SConscript --replace "-Werror" "-Wno-inconsistent-missing-override" + + # disable LTO on macos + substituteInPlace ./src/SConscript --replace ", '-flto'" "" + + # static builds on mac fail as no static libcrt is provided by apple + # see https://stackoverflow.com/questions/3801011/ld-library-not-found-for-lcrt0-o-on-osx-10-6-with-gcc-clang-static-flag + substituteInPlace ./src/SConscript \ + --replace "'-static-libgcc', " "" \ + --replace "'-static-libstdc++', " "" \ + --replace "'-Wl,--whole-archive', '-static', " "" \ + --replace ", '-Wl,--no-whole-archive'" "" + + #remove hardcoding of gcc + sed -i '40i env.Replace(CC = "${stdenv.cc.targetPrefix}cc")' ./SConstruct + sed -i '40i env.Replace(CXX = "${stdenv.cc.targetPrefix}c++")' ./SConstruct + + #gpm doesn't exist on darwin + substituteInPlace ./src/SConscript --replace ", 'gpm'" "" + ''; sconsFlags = # will fail on clang/darwin on link without --static due to undefined extern @@ -80,14 +83,13 @@ stdenv.mkDerivation rec { ++ lib.optional enableAccelergy "--accelergy" ++ lib.optional enableISL "--with-isl"; - installPhase = '' cp -r ./bin ./lib $out mkdir -p $out/share cp -r ./doc $out/share mkdir -p $out/data cp -r ./problem-shapes ./configs $out/data - ''; + ''; meta = with lib; { description = "Chip modeling/mapping benchmarking framework"; diff --git a/pkgs/applications/science/electronics/appcsxcad/default.nix b/pkgs/applications/science/electronics/appcsxcad/default.nix index c401e150f35e08..36b029b5f0dc9e 100644 --- a/pkgs/applications/science/electronics/appcsxcad/default.nix +++ b/pkgs/applications/science/electronics/appcsxcad/default.nix @@ -1,16 +1,17 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, cmake -, csxcad -, qcsxcad -, hdf5 -, vtkWithQt5 -, qtbase -, fparser -, tinyxml -, cgal -, boost +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + csxcad, + qcsxcad, + hdf5, + vtkWithQt5, + qtbase, + fparser, + tinyxml, + cgal, + boost, }: mkDerivation { diff --git a/pkgs/applications/science/electronics/bitscope/common.nix b/pkgs/applications/science/electronics/bitscope/common.nix index 7ea5e4b57a0d27..30e7c72a145c01 100644 --- a/pkgs/applications/science/electronics/bitscope/common.nix +++ b/pkgs/applications/science/electronics/bitscope/common.nix @@ -1,17 +1,24 @@ -{ atk -, buildFHSEnv -, cairo -, dpkg -, gdk-pixbuf -, glib -, gtk2-x11 -, makeWrapper -, pango -, lib, stdenv -, xorg +{ + atk, + buildFHSEnv, + cairo, + dpkg, + gdk-pixbuf, + glib, + gtk2-x11, + makeWrapper, + pango, + lib, + stdenv, + xorg, }: -{ src, toolName, version, ... } @ attrs: +{ + src, + toolName, + version, + ... +}@attrs: let wrapBinary = libPaths: binaryName: '' wrapProgram "$out/bin/${binaryName}" \ @@ -22,42 +29,55 @@ let name = "${toolName}-${version}"; - meta = with lib; { - homepage = "http://bitscope.com/software/"; - sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.unfree; - platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ - vidbina - ]; - } // (attrs.meta or {}); - - nativeBuildInputs = [ makeWrapper dpkg ]; - - libs = attrs.libs or [ - atk - cairo - gdk-pixbuf - glib - gtk2-x11 - pango - xorg.libX11 + meta = + with lib; + { + homepage = "http://bitscope.com/software/"; + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; + license = licenses.unfree; + platforms = [ "x86_64-linux" ]; + maintainers = with maintainers; [ + vidbina + ]; + } + // (attrs.meta or { }); + + nativeBuildInputs = [ + makeWrapper + dpkg ]; + libs = + attrs.libs or [ + atk + cairo + gdk-pixbuf + glib + gtk2-x11 + pango + xorg.libX11 + ]; + dontBuild = true; - unpackPhase = attrs.unpackPhase or '' - dpkg-deb -x ${attrs.src} ./ - ''; + unpackPhase = + attrs.unpackPhase or '' + dpkg-deb -x ${attrs.src} ./ + ''; - installPhase = attrs.installPhase or '' - mkdir -p "$out/bin" - cp -a usr/* "$out/" - ${(wrapBinary libs) attrs.toolName} - ''; + installPhase = + attrs.installPhase or '' + mkdir -p "$out/bin" + cp -a usr/* "$out/" + ${(wrapBinary libs) attrs.toolName} + ''; }); -in buildFHSEnv { +in +buildFHSEnv { pname = attrs.toolName; inherit (attrs) version; runScript = "${pkg.outPath}/bin/${attrs.toolName}"; -} // { inherit (pkg) meta name; } +} +// { + inherit (pkg) meta name; +} diff --git a/pkgs/applications/science/electronics/bitscope/packages.nix b/pkgs/applications/science/electronics/bitscope/packages.nix index 11e1ed524ed281..94ab661ee8b9b6 100644 --- a/pkgs/applications/science/electronics/bitscope/packages.nix +++ b/pkgs/applications/science/electronics/bitscope/packages.nix @@ -1,146 +1,164 @@ -{ callPackage -, fetchurl +{ + callPackage, + fetchurl, }: let mkBitscope = callPackage (import ./common.nix) { }; -in { - chart = let - toolName = "bitscope-chart"; - version = "2.0.FK22M"; - in mkBitscope { - inherit toolName version; - - meta = { - description = "Multi-channel waveform data acquisition and chart recording application"; - homepage = "http://bitscope.com/software/chart/"; +in +{ + chart = + let + toolName = "bitscope-chart"; + version = "2.0.FK22M"; + in + mkBitscope { + inherit toolName version; + + meta = { + description = "Multi-channel waveform data acquisition and chart recording application"; + homepage = "http://bitscope.com/software/chart/"; + }; + + src = fetchurl { + url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; + sha256 = "08mc82pjamyyyhh15sagsv0sc7yx5v5n54bg60fpj7v41wdwrzxw"; + }; + }; + + console = + let + toolName = "bitscope-console"; + version = "1.0.FK29A"; + in + mkBitscope { + # NOTE: this is meant as a demo by BitScope + inherit toolName version; + + meta = { + description = "Demonstrative communications program designed to make it easy to talk to any model BitScope"; + }; + + src = fetchurl { + url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; + sha256 = "00b4gxwz7w6pmfrcz14326b24kl44hp0gzzqcqxwi5vws3f0y49d"; + }; + }; + + display = + let + toolName = "bitscope-display"; + version = "1.0.EC17A"; + in + mkBitscope { + inherit toolName version; + + meta = { + description = "Display diagnostic application for BitScope"; + homepage = "http://bitscope.com/software/display/"; + }; + + src = fetchurl { + url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; + sha256 = "05xr5mnka1v3ibcasg74kmj6nlv1nmn3lca1wv77whkq85cmz0s1"; + }; + }; + + dso = + let + toolName = "bitscope-dso"; + version = "2.8.FE22H"; + in + mkBitscope { + inherit toolName version; + + meta = { + description = "Test and measurement software for BitScope"; + homepage = "http://bitscope.com/software/dso/"; + }; + + src = fetchurl { + url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; + sha256 = "0fc6crfkprj78dxxhvhbn1dx1db5chm0cpwlqpqv8sz6whp12mcj"; + }; + }; + + logic = + let + toolName = "bitscope-logic"; + version = "1.2.FC20C"; + in + mkBitscope { + inherit toolName version; + + meta = { + description = "Mixed signal logic timing and serial protocol analysis software for BitScope"; + homepage = "http://bitscope.com/software/logic/"; + }; + + src = fetchurl { + url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; + sha256 = "0lkb7z9gfkiyxdwh4dq1zxfls8gzdw0na1vrrbgnxfg3klv4xns3"; + }; + }; + + meter = + let + toolName = "bitscope-meter"; + version = "2.0.FK22G"; + in + mkBitscope { + inherit toolName version; + + meta = { + description = "Automated oscilloscope, voltmeter and frequency meter for BitScope"; + homepage = "http://bitscope.com/software/logic/"; + }; + + src = fetchurl { + url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; + sha256 = "0nirbci6ymhk4h4bck2s4wbsl5r9yndk2jvvv72zwkg21248mnbp"; + }; + }; + + proto = + let + toolName = "bitscope-proto"; + version = "0.9.FG13B"; + in + mkBitscope { + inherit toolName version; + # NOTE: this is meant as a demo by BitScope + # NOTE: clicking on logo produces error + # TApplication.HandleException Executable not found: "http://bitscope.com/blog/DK/?p=DK15A" + + meta = { + description = "Demonstrative prototype oscilloscope built using the BitScope Library"; + homepage = "http://bitscope.com/blog/DK/?p=DK15A"; + }; + + src = fetchurl { + url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; + sha256 = "1ybjfbh3narn29ll4nci4b7rnxy0hj3wdfm4v8c6pjr8pfvv9spy"; + }; + }; + + server = + let + toolName = "bitscope-server"; + version = "1.0.FK26A"; + in + mkBitscope { + inherit toolName version; + + meta = { + description = "Remote access server solution for any BitScope"; + homepage = "http://bitscope.com/software/server/"; + }; + + src = fetchurl { + url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; + sha256 = "1079n7msq6ks0n4aasx40rd4q99w8j9hcsaci71nd2im2jvjpw9a"; + }; }; - - src = fetchurl { - url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; - sha256 = "08mc82pjamyyyhh15sagsv0sc7yx5v5n54bg60fpj7v41wdwrzxw"; - }; - }; - - console = let - toolName = "bitscope-console"; - version = "1.0.FK29A"; - in mkBitscope { - # NOTE: this is meant as a demo by BitScope - inherit toolName version; - - meta = { - description = "Demonstrative communications program designed to make it easy to talk to any model BitScope"; - }; - - src = fetchurl { - url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; - sha256 = "00b4gxwz7w6pmfrcz14326b24kl44hp0gzzqcqxwi5vws3f0y49d"; - }; - }; - - display = let - toolName = "bitscope-display"; - version = "1.0.EC17A"; - in mkBitscope { - inherit toolName version; - - meta = { - description = "Display diagnostic application for BitScope"; - homepage = "http://bitscope.com/software/display/"; - }; - - src = fetchurl { - url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; - sha256 = "05xr5mnka1v3ibcasg74kmj6nlv1nmn3lca1wv77whkq85cmz0s1"; - }; - }; - - dso = let - toolName = "bitscope-dso"; - version = "2.8.FE22H"; - in mkBitscope { - inherit toolName version; - - meta = { - description = "Test and measurement software for BitScope"; - homepage = "http://bitscope.com/software/dso/"; - }; - - src = fetchurl { - url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; - sha256 = "0fc6crfkprj78dxxhvhbn1dx1db5chm0cpwlqpqv8sz6whp12mcj"; - }; - }; - - logic = let - toolName = "bitscope-logic"; - version = "1.2.FC20C"; - in mkBitscope { - inherit toolName version; - - meta = { - description = "Mixed signal logic timing and serial protocol analysis software for BitScope"; - homepage = "http://bitscope.com/software/logic/"; - }; - - src = fetchurl { - url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; - sha256 = "0lkb7z9gfkiyxdwh4dq1zxfls8gzdw0na1vrrbgnxfg3klv4xns3"; - }; - }; - - meter = let - toolName = "bitscope-meter"; - version = "2.0.FK22G"; - in mkBitscope { - inherit toolName version; - - meta = { - description = "Automated oscilloscope, voltmeter and frequency meter for BitScope"; - homepage = "http://bitscope.com/software/logic/"; - }; - - src = fetchurl { - url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; - sha256 = "0nirbci6ymhk4h4bck2s4wbsl5r9yndk2jvvv72zwkg21248mnbp"; - }; - }; - - proto = let - toolName = "bitscope-proto"; - version = "0.9.FG13B"; - in mkBitscope { - inherit toolName version; - # NOTE: this is meant as a demo by BitScope - # NOTE: clicking on logo produces error - # TApplication.HandleException Executable not found: "http://bitscope.com/blog/DK/?p=DK15A" - - meta = { - description = "Demonstrative prototype oscilloscope built using the BitScope Library"; - homepage = "http://bitscope.com/blog/DK/?p=DK15A"; - }; - - src = fetchurl { - url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; - sha256 = "1ybjfbh3narn29ll4nci4b7rnxy0hj3wdfm4v8c6pjr8pfvv9spy"; - }; - }; - - server = let - toolName = "bitscope-server"; - version = "1.0.FK26A"; - in mkBitscope { - inherit toolName version; - - meta = { - description = "Remote access server solution for any BitScope"; - homepage = "http://bitscope.com/software/server/"; - }; - - src = fetchurl { - url = "http://bitscope.com/download/files/${toolName}_${version}_amd64.deb"; - sha256 = "1079n7msq6ks0n4aasx40rd4q99w8j9hcsaci71nd2im2jvjpw9a"; - }; - }; } diff --git a/pkgs/applications/science/electronics/caneda/default.nix b/pkgs/applications/science/electronics/caneda/default.nix index db664965adb884..b99c2201ec0972 100644 --- a/pkgs/applications/science/electronics/caneda/default.nix +++ b/pkgs/applications/science/electronics/caneda/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchFromGitHub, cmake, qtbase, qttools, qtsvg, qwt6_1}: +{ + mkDerivation, + lib, + fetchFromGitHub, + cmake, + qtbase, + qttools, + qtsvg, + qwt6_1, +}: mkDerivation rec { pname = "caneda"; @@ -12,7 +21,12 @@ mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ qtbase qttools qtsvg qwt6_1 ]; + buildInputs = [ + qtbase + qttools + qtsvg + qwt6_1 + ]; meta = { description = "Open source EDA software focused on easy of use and portability"; diff --git a/pkgs/applications/science/electronics/degate/default.nix b/pkgs/applications/science/electronics/degate/default.nix index 580d452f333dfc..478e1b78ab2591 100644 --- a/pkgs/applications/science/electronics/degate/default.nix +++ b/pkgs/applications/science/electronics/degate/default.nix @@ -1,19 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, boost -, qtbase -, qtimageformats -, qttools -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + boost, + qtbase, + qtimageformats, + qttools, + wrapQtAppsHook, }: let boost_static = boost.override { enableStatic = true; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "degate"; version = "2.0.0"; diff --git a/pkgs/applications/science/electronics/dsview/default.nix b/pkgs/applications/science/electronics/dsview/default.nix index 48a94468ef0b2f..0141bd2ebadc4f 100644 --- a/pkgs/applications/science/electronics/dsview/default.nix +++ b/pkgs/applications/science/electronics/dsview/default.nix @@ -1,6 +1,19 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config, cmake, wrapQtAppsHook -, libzip, boost, fftw, libusb1, qtbase, qtsvg, qtwayland -, python3, desktopToDarwinBundle +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + cmake, + wrapQtAppsHook, + libzip, + boost, + fftw, + libusb1, + qtbase, + qtsvg, + qtwayland, + python3, + desktopToDarwinBundle, }: stdenv.mkDerivation rec { @@ -9,10 +22,10 @@ stdenv.mkDerivation rec { version = "1.3.2"; src = fetchFromGitHub { - owner = "DreamSourceLab"; - repo = "DSView"; - rev = "v${version}"; - sha256 = "sha256-d/TfCuJzAM0WObOiBhgfsTirlvdROrlCm+oL1cqUrIs="; + owner = "DreamSourceLab"; + repo = "DSView"; + rev = "v${version}"; + sha256 = "sha256-d/TfCuJzAM0WObOiBhgfsTirlvdROrlCm+oL1cqUrIs="; }; patches = [ @@ -20,11 +33,19 @@ stdenv.mkDerivation rec { ./install.patch ]; - nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook ] - ++ lib.optional stdenv.hostPlatform.isDarwin desktopToDarwinBundle; + nativeBuildInputs = [ + cmake + pkg-config + wrapQtAppsHook + ] ++ lib.optional stdenv.hostPlatform.isDarwin desktopToDarwinBundle; buildInputs = [ - boost fftw qtbase qtsvg libusb1 libzip + boost + fftw + qtbase + qtsvg + libusb1 + libzip python3 ] ++ lib.optional stdenv.hostPlatform.isLinux qtwayland; @@ -34,6 +55,9 @@ stdenv.mkDerivation rec { homepage = "https://www.dreamsourcelab.com/"; license = licenses.gpl3Plus; platforms = platforms.unix; - maintainers = with maintainers; [ bachp carlossless ]; + maintainers = with maintainers; [ + bachp + carlossless + ]; }; } diff --git a/pkgs/applications/science/electronics/eagle/eagle.nix b/pkgs/applications/science/electronics/eagle/eagle.nix index a8da40bd070b21..3277bda1326c76 100644 --- a/pkgs/applications/science/electronics/eagle/eagle.nix +++ b/pkgs/applications/science/electronics/eagle/eagle.nix @@ -1,81 +1,136 @@ -{ lib, stdenv, mkDerivation, fetchurl, makeDesktopItem -, libXrender, libXrandr, libXcursor, libX11, libXext, libXi, libxcb - , libGL, glib, nss, nspr, expat, alsa-lib -, qtbase, qtdeclarative, qtsvg, qtlocation, qtwebchannel, qtwebengine +{ + lib, + stdenv, + mkDerivation, + fetchurl, + makeDesktopItem, + libXrender, + libXrandr, + libXcursor, + libX11, + libXext, + libXi, + libxcb, + libGL, + glib, + nss, + nspr, + expat, + alsa-lib, + qtbase, + qtdeclarative, + qtsvg, + qtlocation, + qtwebchannel, + qtwebengine, }: let - libPath = lib.makeLibraryPath - [ libXrender libXrandr libXcursor libX11 libXext libXi libxcb - libGL glib nss nspr expat alsa-lib - qtbase qtdeclarative qtsvg qtlocation qtwebchannel qtwebengine - ]; - in - mkDerivation rec { - pname = "eagle"; - version = "9.6.2"; + libPath = lib.makeLibraryPath [ + libXrender + libXrandr + libXcursor + libX11 + libXext + libXi + libxcb + libGL + glib + nss + nspr + expat + alsa-lib + qtbase + qtdeclarative + qtsvg + qtlocation + qtwebchannel + qtwebengine + ]; +in +mkDerivation rec { + pname = "eagle"; + version = "9.6.2"; - src = fetchurl { - url = "https://eagle-updates.circuits.io/downloads/${builtins.replaceStrings ["."] ["_"] version}/Autodesk_EAGLE_${version}_English_Linux_64bit.tar.gz"; - sha256 = "18syygnskl286kn8aqfzzdsyzq59d2w19y1h1ynyxsnrvkyv71h0"; - }; + src = fetchurl { + url = "https://eagle-updates.circuits.io/downloads/${ + builtins.replaceStrings [ "." ] [ "_" ] version + }/Autodesk_EAGLE_${version}_English_Linux_64bit.tar.gz"; + sha256 = "18syygnskl286kn8aqfzzdsyzq59d2w19y1h1ynyxsnrvkyv71h0"; + }; - desktopItem = makeDesktopItem { - name = "eagle"; - exec = "eagle"; - icon = "eagle"; - comment = "Schematic capture and PCB layout"; - desktopName = "Eagle"; - genericName = "Schematic editor"; - categories = [ "Development" ]; - }; + desktopItem = makeDesktopItem { + name = "eagle"; + exec = "eagle"; + icon = "eagle"; + comment = "Schematic capture and PCB layout"; + desktopName = "Eagle"; + genericName = "Schematic editor"; + categories = [ "Development" ]; + }; - buildInputs = - [ libXrender libXrandr libXcursor libX11 libXext libXi libxcb - libGL glib nss nspr expat alsa-lib - qtbase qtdeclarative qtsvg qtlocation qtwebchannel qtwebengine - ]; + buildInputs = [ + libXrender + libXrandr + libXcursor + libX11 + libXext + libXi + libxcb + libGL + glib + nss + nspr + expat + alsa-lib + qtbase + qtdeclarative + qtsvg + qtlocation + qtwebchannel + qtwebengine + ]; - installPhase = '' - # Extract eagle tarball - mkdir "$out" - tar -xzf "$src" -C "$out" + installPhase = '' + # Extract eagle tarball + mkdir "$out" + tar -xzf "$src" -C "$out" - # Install manpage - mkdir -p "$out"/share/man/man1 - ln -s "$out"/eagle-${version}/doc/eagle.1 "$out"/share/man/man1/eagle.1 + # Install manpage + mkdir -p "$out"/share/man/man1 + ln -s "$out"/eagle-${version}/doc/eagle.1 "$out"/share/man/man1/eagle.1 - patchelf \ - --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath "${libPath}:$out/eagle-${version}/lib:${lib.getLib stdenv.cc.cc}/lib" \ - "$out"/eagle-${version}/eagle + patchelf \ + --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ + --set-rpath "${libPath}:$out/eagle-${version}/lib:${lib.getLib stdenv.cc.cc}/lib" \ + "$out"/eagle-${version}/eagle - mkdir -p "$out"/bin - ln -s "$out"/eagle-${version}/eagle "$out"/bin/eagle + mkdir -p "$out"/bin + ln -s "$out"/eagle-${version}/eagle "$out"/bin/eagle - # Remove bundled libraries that are available in nixpkgs - # TODO: There still may be unused bundled libraries - rm "$out"/eagle-${version}/lib/libQt5*.so.5 - rm "$out"/eagle-${version}/lib/{libxcb-*.so.*,libX*.so.*,libxshmfence.so.1} - rm "$out"/eagle-${version}/lib/{libEGL.so.1,libglapi.so.0,libgbm.so.1} + # Remove bundled libraries that are available in nixpkgs + # TODO: There still may be unused bundled libraries + rm "$out"/eagle-${version}/lib/libQt5*.so.5 + rm "$out"/eagle-${version}/lib/{libxcb-*.so.*,libX*.so.*,libxshmfence.so.1} + rm "$out"/eagle-${version}/lib/{libEGL.so.1,libglapi.so.0,libgbm.so.1} - # No longer needed (we don't use the bundled Qt libraries) - rm -r "$out"/eagle-${version}/libexec - rm -r "$out"/eagle-${version}/plugins + # No longer needed (we don't use the bundled Qt libraries) + rm -r "$out"/eagle-${version}/libexec + rm -r "$out"/eagle-${version}/plugins - # Make desktop item - mkdir -p "$out"/share/applications - cp "$desktopItem"/share/applications/* "$out"/share/applications/ - mkdir -p "$out"/share/pixmaps - ln -s "$out/eagle-${version}/bin/eagle-logo.png" "$out"/share/pixmaps/eagle.png - ''; + # Make desktop item + mkdir -p "$out"/share/applications + cp "$desktopItem"/share/applications/* "$out"/share/applications/ + mkdir -p "$out"/share/pixmaps + ln -s "$out/eagle-${version}/bin/eagle-logo.png" "$out"/share/pixmaps/eagle.png + ''; - meta = with lib; { - description = "Schematic editor and PCB layout tool from Autodesk (formerly CadSoft)"; - homepage = "https://www.autodesk.com/products/eagle/overview"; - sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.unfree; - platforms = [ "x86_64-linux" ]; - maintainers = [ ]; - }; - } + meta = with lib; { + description = "Schematic editor and PCB layout tool from Autodesk (formerly CadSoft)"; + homepage = "https://www.autodesk.com/products/eagle/overview"; + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; + license = licenses.unfree; + platforms = [ "x86_64-linux" ]; + maintainers = [ ]; + }; +} diff --git a/pkgs/applications/science/electronics/flatcam/default.nix b/pkgs/applications/science/electronics/flatcam/default.nix index 2235cf0b4a3377..0cefff6dc47e65 100644 --- a/pkgs/applications/science/electronics/flatcam/default.nix +++ b/pkgs/applications/science/electronics/flatcam/default.nix @@ -1,33 +1,34 @@ -{ lib -, fetchFromBitbucket -, buildPythonApplication -, pyqt5 -, matplotlib -, numpy -, cycler -, python-dateutil -, kiwisolver -, six -, setuptools -, dill -, rtree -, pyopengl -, vispy -, ortools -, svg-path -, simplejson -, shapely -, freetype-py -, fonttools -, rasterio -, lxml -, ezdxf -, qrcode -, reportlab -, svglib -, gdal -, pyserial -, python3 +{ + lib, + fetchFromBitbucket, + buildPythonApplication, + pyqt5, + matplotlib, + numpy, + cycler, + python-dateutil, + kiwisolver, + six, + setuptools, + dill, + rtree, + pyopengl, + vispy, + ortools, + svg-path, + simplejson, + shapely, + freetype-py, + fonttools, + rasterio, + lxml, + ezdxf, + qrcode, + reportlab, + svglib, + gdal, + pyserial, + python3, }: buildPythonApplication rec { @@ -91,7 +92,9 @@ buildPythonApplication rec { ]; postInstall = '' - sed -i "s|python3|${python3.withPackages (_: propagatedBuildInputs)}/bin/python3|" $out/bin/flatcam-beta + sed -i "s|python3|${ + python3.withPackages (_: propagatedBuildInputs) + }/bin/python3|" $out/bin/flatcam-beta mv $out/bin/flatcam{-beta,} ''; diff --git a/pkgs/applications/science/electronics/fritzing/default.nix b/pkgs/applications/science/electronics/fritzing/default.nix index 04ca24861c0d82..1821ac63a4ebbf 100644 --- a/pkgs/applications/science/electronics/fritzing/default.nix +++ b/pkgs/applications/science/electronics/fritzing/default.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, fetchFromGitHub -, wrapQtAppsHook -, qmake -, pkg-config -, qtbase -, qtsvg -, qttools -, qtserialport -, qtwayland -, qt5compat -, boost -, libngspice -, libgit2 -, quazip -, clipper +{ + stdenv, + lib, + fetchFromGitHub, + wrapQtAppsHook, + qmake, + pkg-config, + qtbase, + qtsvg, + qttools, + qtserialport, + qtwayland, + qt5compat, + boost, + libngspice, + libgit2, + quazip, + clipper, }: let @@ -49,20 +50,27 @@ stdenv.mkDerivation { hash = "sha256-Xi5sPU2RGkqh7T+EOvwxJJKKYDhJfccyEZ8LBBTb2s4="; }; - nativeBuildInputs = [ qmake pkg-config qttools wrapQtAppsHook ]; - buildInputs = [ - qtbase - qtsvg - qtserialport - qt5compat - boost - libgit2 - quazip - libngspice - clipper - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qtwayland + nativeBuildInputs = [ + qmake + pkg-config + qttools + wrapQtAppsHook ]; + buildInputs = + [ + qtbase + qtsvg + qtserialport + qt5compat + boost + libgit2 + quazip + libngspice + clipper + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qtwayland + ]; postPatch = '' # Use packaged quazip, libgit and ngspice @@ -111,8 +119,14 @@ stdenv.mkDerivation { meta = with lib; { description = "Open source prototyping tool for Arduino-based projects"; homepage = "https://fritzing.org/"; - license = with licenses; [ gpl3 cc-by-sa-30 ]; - maintainers = with maintainers; [ robberer muscaln ]; + license = with licenses; [ + gpl3 + cc-by-sa-30 + ]; + maintainers = with maintainers; [ + robberer + muscaln + ]; platforms = platforms.unix; mainProgram = "Fritzing"; }; diff --git a/pkgs/applications/science/electronics/geda/default.nix b/pkgs/applications/science/electronics/geda/default.nix index 160928633a3cca..8ed37c9b4b3cb8 100644 --- a/pkgs/applications/science/electronics/geda/default.nix +++ b/pkgs/applications/science/electronics/geda/default.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, fetchpatch, autoreconfHook, groff, pkg-config, guile, gtk2, flex, gawk, perl }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + groff, + pkg-config, + guile, + gtk2, + flex, + gawk, + perl, +}: stdenv.mkDerivation rec { pname = "geda"; @@ -22,8 +35,18 @@ stdenv.mkDerivation rec { "--without-libfam" ]; - nativeBuildInputs = [ autoreconfHook groff pkg-config ]; - buildInputs = [ guile gtk2 flex gawk perl ]; + nativeBuildInputs = [ + autoreconfHook + groff + pkg-config + ]; + buildInputs = [ + guile + gtk2 + flex + gawk + perl + ]; meta = with lib; { description = "Full GPL'd suite of Electronic Design Automation tools"; diff --git a/pkgs/applications/science/electronics/gerbv/default.nix b/pkgs/applications/science/electronics/gerbv/default.nix index c4c46b55079944..cf0dfe7e43f9f2 100644 --- a/pkgs/applications/science/electronics/gerbv/default.nix +++ b/pkgs/applications/science/electronics/gerbv/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, autoconf -, automake -, autoreconfHook -, cairo -, fetchFromGitHub -, gettext -, gtk2-x11 -, libtool -, pkg-config +{ + lib, + stdenv, + autoconf, + automake, + autoreconfHook, + cairo, + fetchFromGitHub, + gettext, + gtk2-x11, + libtool, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/science/electronics/hal-hardware-analyzer/default.nix b/pkgs/applications/science/electronics/hal-hardware-analyzer/default.nix index e8c15c35f2f918..9d1c447c9c84a5 100644 --- a/pkgs/applications/science/electronics/hal-hardware-analyzer/default.nix +++ b/pkgs/applications/science/electronics/hal-hardware-analyzer/default.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, boost -, cmake -, fetchFromGitHub -, fetchpatch -, graphviz -, igraph -, llvmPackages -, ninja -, nlohmann_json -, pkg-config -, python3Packages -, qtbase -, qtsvg -, quazip -, rapidjson -, spdlog -, verilator -, wrapQtAppsHook -, z3 +{ + lib, + stdenv, + boost, + cmake, + fetchFromGitHub, + fetchpatch, + graphviz, + igraph, + llvmPackages, + ninja, + nlohmann_json, + pkg-config, + python3Packages, + qtbase, + qtsvg, + quazip, + rapidjson, + spdlog, + verilator, + wrapQtAppsHook, + z3, }: stdenv.mkDerivation rec { @@ -62,22 +63,25 @@ stdenv.mkDerivation rec { pkg-config wrapQtAppsHook ]; - buildInputs = [ - qtbase - qtsvg - boost - rapidjson - igraph - nlohmann_json - spdlog - graphviz - verilator - z3 - quazip - ] - ++ (with python3Packages; [ python pybind11 ]) - ++ lib.optional stdenv.cc.isClang llvmPackages.openmp - ; + buildInputs = + [ + qtbase + qtsvg + boost + rapidjson + igraph + nlohmann_json + spdlog + graphviz + verilator + z3 + quazip + ] + ++ (with python3Packages; [ + python + pybind11 + ]) + ++ lib.optional stdenv.cc.isClang llvmPackages.openmp; cmakeFlags = with lib.versions; [ "-DHAL_VERSION_RETURN=${version}" @@ -116,6 +120,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/emsec/hal"; license = licenses.mit; platforms = platforms.unix; - maintainers = with maintainers; [ ris shamilton ]; + maintainers = with maintainers; [ + ris + shamilton + ]; }; } diff --git a/pkgs/applications/science/electronics/kicad/default.nix b/pkgs/applications/science/electronics/kicad/default.nix index a5cceb492522e2..edfcf61c1a2542 100644 --- a/pkgs/applications/science/electronics/kicad/default.nix +++ b/pkgs/applications/science/electronics/kicad/default.nix @@ -1,38 +1,40 @@ -{ lib, stdenv -, runCommand -, newScope -, fetchFromGitLab -, makeWrapper -, symlinkJoin -, callPackage -, callPackages - -, adwaita-icon-theme -, dconf -, gtk3 -, wxGTK32 -, librsvg -, cups -, gsettings-desktop-schemas -, hicolor-icon-theme - -, unzip -, jq - -, pname ? "kicad" -, stable ? true -, testing ? false -, withNgspice ? !stdenv.hostPlatform.isDarwin -, libngspice -, withScripting ? true -, python3 -, addons ? [ ] -, debug ? false -, sanitizeAddress ? false -, sanitizeThreads ? false -, with3d ? true -, withI18n ? true -, srcs ? { } +{ + lib, + stdenv, + runCommand, + newScope, + fetchFromGitLab, + makeWrapper, + symlinkJoin, + callPackage, + callPackages, + + adwaita-icon-theme, + dconf, + gtk3, + wxGTK32, + librsvg, + cups, + gsettings-desktop-schemas, + hicolor-icon-theme, + + unzip, + jq, + + pname ? "kicad", + stable ? true, + testing ? false, + withNgspice ? !stdenv.hostPlatform.isDarwin, + libngspice, + withScripting ? true, + python3, + addons ? [ ], + debug ? false, + sanitizeAddress ? false, + sanitizeThreads ? false, + with3d ? true, + withI18n ? true, + srcs ? { }, }: # `addons`: https://dev-docs.kicad.org/en/addons/ @@ -78,9 +80,13 @@ # } let - baseName = if (testing) then "kicad-testing" - else if (stable) then "kicad" - else "kicad-unstable"; + baseName = + if (testing) then + "kicad-testing" + else if (stable) then + "kicad" + else + "kicad-unstable"; versionsImport = import ./versions.nix; # versions.nix does not provide us with version, src and rev. We @@ -93,13 +99,15 @@ let sha256 = versionsImport.${baseName}.kicadVersion.src.sha256; }; - libSrcFetch = name: fetchFromGitLab { - group = "kicad"; - owner = "libraries"; - repo = "kicad-${name}"; - rev = versionsImport.${baseName}.libVersion.libSources.${name}.rev; - sha256 = versionsImport.${baseName}.libVersion.libSources.${name}.sha256; - }; + libSrcFetch = + name: + fetchFromGitLab { + group = "kicad"; + owner = "libraries"; + repo = "kicad-${name}"; + rev = versionsImport.${baseName}.libVersion.libSources.${name}.rev; + sha256 = versionsImport.${baseName}.libVersion.libSources.${name}.sha256; + }; # only override `src` or `version` if building `kicad-unstable` with # the appropriate attribute defined in `srcs`. @@ -108,18 +116,20 @@ let # use default source and version (as defined in versions.nix) by # default, or use the appropriate attribute from `srcs` if building # unstable with `srcs` properly defined. - kicadSrc = - if srcOverridep "kicad" then srcs.kicad - else kicadSrcFetch; + kicadSrc = if srcOverridep "kicad" then srcs.kicad else kicadSrcFetch; kicadVersion = - if srcOverridep "kicadVersion" then srcs.kicadVersion - else versionsImport.${baseName}.kicadVersion.version; + if srcOverridep "kicadVersion" then + srcs.kicadVersion + else + versionsImport.${baseName}.kicadVersion.version; libSrc = name: if srcOverridep name then srcs.${name} else libSrcFetch name; # TODO does it make sense to only have one version for all libs? libVersion = - if srcOverridep "libVersion" then srcs.libVersion - else versionsImport.${baseName}.libVersion.version; + if srcOverridep "libVersion" then + srcs.libVersion + else + versionsImport.${baseName}.libVersion.version; wxGTK = wxGTK32; python = python3; @@ -131,27 +141,36 @@ let runCommand "addonsJoined" { inherit addonsDrvs; - nativeBuildInputs = [ unzip jq ]; - } '' - mkdir $out - - for pkg in $addonsDrvs; do - unzip $pkg/addon.zip -d unpacked - - folder_name=$(jq .identifier unpacked/metadata.json --raw-output | tr . _) - for d in unpacked/*; do - if [ -d "$d" ]; then - dest=$out/share/kicad/scripting/$(basename $d)/$folder_name - mkdir -p $(dirname $dest) - - mv $d $dest - fi + nativeBuildInputs = [ + unzip + jq + ]; + } + '' + mkdir $out + + for pkg in $addonsDrvs; do + unzip $pkg/addon.zip -d unpacked + + folder_name=$(jq .identifier unpacked/metadata.json --raw-output | tr . _) + for d in unpacked/*; do + if [ -d "$d" ]; then + dest=$out/share/kicad/scripting/$(basename $d)/$folder_name + mkdir -p $(dirname $dest) + + mv $d $dest + fi + done + rm -r unpacked done - rm -r unpacked - done - ''; - - inherit (lib) concatStringsSep flatten optionalString optionals; + ''; + + inherit (lib) + concatStringsSep + flatten + optionalString + optionals + ; in stdenv.mkDerivation rec { @@ -175,12 +194,15 @@ stdenv.mkDerivation rec { dontBuild = true; dontFixup = true; - pythonPath = optionals (withScripting) - [ wxPython python.pkgs.six python.pkgs.requests ] ++ addonsDrvs; + pythonPath = + optionals (withScripting) [ + wxPython + python.pkgs.six + python.pkgs.requests + ] + ++ addonsDrvs; - nativeBuildInputs = [ makeWrapper ] - ++ optionals (withScripting) - [ python.pkgs.wrapPython ]; + nativeBuildInputs = [ makeWrapper ] ++ optionals (withScripting) [ python.pkgs.wrapPython ]; # KICAD7_TEMPLATE_DIR only works with a single path (it does not handle : separated paths) # but it's used to find both the templates and the symbol/footprint library tables @@ -194,70 +216,82 @@ stdenv.mkDerivation rec { ]; }; # We are emulating wrapGAppsHook3, along with other variables to the wrapper - makeWrapperArgs = with passthru.libraries; [ - "--prefix XDG_DATA_DIRS : ${base}/share" - "--prefix XDG_DATA_DIRS : ${hicolor-icon-theme}/share" - "--prefix XDG_DATA_DIRS : ${adwaita-icon-theme}/share" - "--prefix XDG_DATA_DIRS : ${gtk3}/share/gsettings-schemas/${gtk3.name}" - "--prefix XDG_DATA_DIRS : ${gsettings-desktop-schemas}/share/gsettings-schemas/${gsettings-desktop-schemas.name}" - # wrapGAppsHook3 did these two as well, no idea if it matters... - "--prefix XDG_DATA_DIRS : ${cups}/share" - "--prefix GIO_EXTRA_MODULES : ${dconf}/lib/gio/modules" - # required to open a bug report link in firefox-wayland - "--set-default MOZ_DBUS_REMOTE 1" - "--set-default KICAD8_FOOTPRINT_DIR ${footprints}/share/kicad/footprints" - "--set-default KICAD8_SYMBOL_DIR ${symbols}/share/kicad/symbols" - "--set-default KICAD8_TEMPLATE_DIR ${template_dir}" - ] - ++ optionals (addons != [ ]) ( - let stockDataPath = symlinkJoin { - name = "kicad_stock_data_path"; - paths = [ - "${base}/share/kicad" - "${addonsJoined}/share/kicad" - ]; - }; - in - [ "--set-default NIX_KICAD8_STOCK_DATA_PATH ${stockDataPath}" ] - ) - ++ optionals (with3d) - [ - "--set-default KICAD8_3DMODEL_DIR ${packages3d}/share/kicad/3dmodels" - ] - ++ optionals (withNgspice) [ "--prefix LD_LIBRARY_PATH : ${libngspice}/lib" ] - - # infinisil's workaround for #39493 - ++ [ "--set GDK_PIXBUF_MODULE_FILE ${librsvg}/lib/gdk-pixbuf-2.0/2.10.0/loaders.cache" ] - ; + makeWrapperArgs = + with passthru.libraries; + [ + "--prefix XDG_DATA_DIRS : ${base}/share" + "--prefix XDG_DATA_DIRS : ${hicolor-icon-theme}/share" + "--prefix XDG_DATA_DIRS : ${adwaita-icon-theme}/share" + "--prefix XDG_DATA_DIRS : ${gtk3}/share/gsettings-schemas/${gtk3.name}" + "--prefix XDG_DATA_DIRS : ${gsettings-desktop-schemas}/share/gsettings-schemas/${gsettings-desktop-schemas.name}" + # wrapGAppsHook3 did these two as well, no idea if it matters... + "--prefix XDG_DATA_DIRS : ${cups}/share" + "--prefix GIO_EXTRA_MODULES : ${dconf}/lib/gio/modules" + # required to open a bug report link in firefox-wayland + "--set-default MOZ_DBUS_REMOTE 1" + "--set-default KICAD8_FOOTPRINT_DIR ${footprints}/share/kicad/footprints" + "--set-default KICAD8_SYMBOL_DIR ${symbols}/share/kicad/symbols" + "--set-default KICAD8_TEMPLATE_DIR ${template_dir}" + ] + ++ optionals (addons != [ ]) ( + let + stockDataPath = symlinkJoin { + name = "kicad_stock_data_path"; + paths = [ + "${base}/share/kicad" + "${addonsJoined}/share/kicad" + ]; + }; + in + [ "--set-default NIX_KICAD8_STOCK_DATA_PATH ${stockDataPath}" ] + ) + ++ optionals (with3d) [ + "--set-default KICAD8_3DMODEL_DIR ${packages3d}/share/kicad/3dmodels" + ] + ++ optionals (withNgspice) [ "--prefix LD_LIBRARY_PATH : ${libngspice}/lib" ] + + # infinisil's workaround for #39493 + ++ [ "--set GDK_PIXBUF_MODULE_FILE ${librsvg}/lib/gdk-pixbuf-2.0/2.10.0/loaders.cache" ]; # why does $makeWrapperArgs have to be added explicitly? # $out and $program_PYTHONPATH don't exist when makeWrapperArgs gets set? installPhase = let bin = if stdenv.hostPlatform.isDarwin then "*.app/Contents/MacOS" else "bin"; - tools = [ "kicad" "pcbnew" "eeschema" "gerbview" "pcb_calculator" "pl_editor" "bitmap2component" ]; - utils = [ "dxf2idf" "idf2vrml" "idfcyl" "idfrect" "kicad-cli" ]; + tools = [ + "kicad" + "pcbnew" + "eeschema" + "gerbview" + "pcb_calculator" + "pl_editor" + "bitmap2component" + ]; + utils = [ + "dxf2idf" + "idf2vrml" + "idfcyl" + "idfrect" + "kicad-cli" + ]; in - (concatStringsSep "\n" - (flatten [ - "runHook preInstall" + (concatStringsSep "\n" (flatten [ + "runHook preInstall" - (optionalString (withScripting) "buildPythonPath \"${base} $pythonPath\" \n") + (optionalString (withScripting) "buildPythonPath \"${base} $pythonPath\" \n") - # wrap each of the directly usable tools - (map - (tool: "makeWrapper ${base}/${bin}/${tool} $out/bin/${tool} $makeWrapperArgs" - + optionalString (withScripting) " --set PYTHONPATH \"$program_PYTHONPATH\"" - ) - tools) + # wrap each of the directly usable tools + (map ( + tool: + "makeWrapper ${base}/${bin}/${tool} $out/bin/${tool} $makeWrapperArgs" + + optionalString (withScripting) " --set PYTHONPATH \"$program_PYTHONPATH\"" + ) tools) - # link in the CLI utils - (map (util: "ln -s ${base}/${bin}/${util} $out/bin/${util}") utils) + # link in the CLI utils + (map (util: "ln -s ${base}/${bin}/${util} $out/bin/${util}") utils) - "runHook postInstall" - ]) - ) - ; + "runHook postInstall" + ])); postInstall = '' mkdir -p $out/share @@ -268,16 +302,24 @@ stdenv.mkDerivation rec { ''; passthru.updateScript = { - command = [ ./update.sh "${pname}" ]; + command = [ + ./update.sh + "${pname}" + ]; supportedFeatures = [ "commit" ]; }; meta = rec { - description = (if (stable) - then "Open Source Electronics Design Automation suite" - else if (testing) then "Open Source EDA suite, latest on stable branch" - else "Open Source EDA suite, latest on master branch") - + (lib.optionalString (!with3d) ", without 3D models"); + description = + ( + if (stable) then + "Open Source Electronics Design Automation suite" + else if (testing) then + "Open Source EDA suite, latest on stable branch" + else + "Open Source EDA suite, latest on master branch" + ) + + (lib.optionalString (!with3d) ", without 3D models"); homepage = "https://www.kicad.org/"; longDescription = '' KiCad is an open source software suite for Electronic Design Automation. diff --git a/pkgs/applications/science/electronics/kicad/libraries.nix b/pkgs/applications/science/electronics/kicad/libraries.nix index 4a3e40a3166d23..15c937671434a2 100644 --- a/pkgs/applications/science/electronics/kicad/libraries.nix +++ b/pkgs/applications/science/electronics/kicad/libraries.nix @@ -1,19 +1,23 @@ -{ lib, stdenv -, cmake -, libSrc -, stepreduce -, parallel -, zip +{ + lib, + stdenv, + cmake, + libSrc, + stepreduce, + parallel, + zip, }: let - mkLib = name: + mkLib = + name: stdenv.mkDerivation { pname = "kicad-${name}"; version = builtins.substring 0 10 (libSrc name).rev; src = libSrc name; - nativeBuildInputs = [ cmake ] + nativeBuildInputs = + [ cmake ] ++ lib.optionals (name == "packages3d") [ stepreduce parallel diff --git a/pkgs/applications/science/electronics/librepcb/default.nix b/pkgs/applications/science/electronics/librepcb/default.nix index 05d5e497541d62..ef645d36b079d6 100644 --- a/pkgs/applications/science/electronics/librepcb/default.nix +++ b/pkgs/applications/science/electronics/librepcb/default.nix @@ -1,5 +1,15 @@ -{ stdenv, lib, fetchFromGitHub -, qtbase, qttools, qtsvg, qt5compat, opencascade-occt, libGLU, cmake, wrapQtAppsHook +{ + stdenv, + lib, + fetchFromGitHub, + qtbase, + qttools, + qtsvg, + qt5compat, + opencascade-occt, + libGLU, + cmake, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -7,21 +17,32 @@ stdenv.mkDerivation rec { version = "1.2.0"; src = fetchFromGitHub { - owner = pname; - repo = pname; - rev = version; + owner = pname; + repo = pname; + rev = version; hash = "sha256-/Hw7ZTv2CbDcKuyI27wC46IxCcTnrXDS/Mf7csUTc7w="; fetchSubmodules = true; }; - nativeBuildInputs = [ cmake qttools qtsvg qt5compat wrapQtAppsHook opencascade-occt libGLU ]; + nativeBuildInputs = [ + cmake + qttools + qtsvg + qt5compat + wrapQtAppsHook + opencascade-occt + libGLU + ]; buildInputs = [ qtbase ]; meta = with lib; { description = "Free EDA software to develop printed circuit boards"; - homepage = "https://librepcb.org/"; - maintainers = with maintainers; [ luz thoughtpolice ]; - license = licenses.gpl3Plus; - platforms = platforms.linux; + homepage = "https://librepcb.org/"; + maintainers = with maintainers; [ + luz + thoughtpolice + ]; + license = licenses.gpl3Plus; + platforms = platforms.linux; }; } diff --git a/pkgs/applications/science/electronics/linux-gpib/common.nix b/pkgs/applications/science/electronics/linux-gpib/common.nix index e87751a1886053..e121c6c005f090 100644 --- a/pkgs/applications/science/electronics/linux-gpib/common.nix +++ b/pkgs/applications/science/electronics/linux-gpib/common.nix @@ -1,4 +1,9 @@ -{ pname, fetchurl, lib }: rec { +{ + pname, + fetchurl, + lib, +}: +rec { version = "4.3.6"; inherit pname; diff --git a/pkgs/applications/science/electronics/linux-gpib/kernel.nix b/pkgs/applications/science/electronics/linux-gpib/kernel.nix index d64e2fc81fbdf5..49d280757d142f 100644 --- a/pkgs/applications/science/electronics/linux-gpib/kernel.nix +++ b/pkgs/applications/science/electronics/linux-gpib/kernel.nix @@ -1,23 +1,30 @@ -{ lib -, stdenv -, fetchurl -, kernel -, pahole +{ + lib, + stdenv, + fetchurl, + kernel, + pahole, }: -stdenv.mkDerivation (import ./common.nix { inherit fetchurl lib; pname = "linux-gpib-kernel"; } // { +stdenv.mkDerivation ( + import ./common.nix { + inherit fetchurl lib; + pname = "linux-gpib-kernel"; + } + // { - postPatch = '' - sed -i 's@/sbin/depmod -A@@g' Makefile - ''; + postPatch = '' + sed -i 's@/sbin/depmod -A@@g' Makefile + ''; - buildInputs = [ pahole ] ++ kernel.moduleBuildDependencies; + buildInputs = [ pahole ] ++ kernel.moduleBuildDependencies; - makeFlags = [ - "LINUX_SRCDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" - ]; + makeFlags = [ + "LINUX_SRCDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" + ]; - installFlags = [ - "INSTALL_MOD_PATH=$(out)" - ]; -}) + installFlags = [ + "INSTALL_MOD_PATH=$(out)" + ]; + } +) diff --git a/pkgs/applications/science/electronics/linux-gpib/user.nix b/pkgs/applications/science/electronics/linux-gpib/user.nix index f9c9a2e1e6cbcf..f7cb2d7daea4ef 100644 --- a/pkgs/applications/science/electronics/linux-gpib/user.nix +++ b/pkgs/applications/science/electronics/linux-gpib/user.nix @@ -1,25 +1,32 @@ -{ lib -, stdenv -, fetchurl -, autoconf -, libtool -, bison -, flex -, automake +{ + lib, + stdenv, + fetchurl, + autoconf, + libtool, + bison, + flex, + automake, }: -stdenv.mkDerivation (import ./common.nix { inherit fetchurl lib; pname = "linux-gpib-user"; } // { +stdenv.mkDerivation ( + import ./common.nix { + inherit fetchurl lib; + pname = "linux-gpib-user"; + } + // { - nativeBuildInputs = [ - autoconf - libtool - bison - flex - automake - ]; + nativeBuildInputs = [ + autoconf + libtool + bison + flex + automake + ]; - configureFlags = [ - "--sysconfdir=$(out)/etc" - "--prefix=$(out)" - ]; -}) + configureFlags = [ + "--sysconfdir=$(out)/etc" + "--prefix=$(out)" + ]; + } +) diff --git a/pkgs/applications/science/electronics/openhantek6022/default.nix b/pkgs/applications/science/electronics/openhantek6022/default.nix index ca0c651fad2780..5f3ce59053cee8 100644 --- a/pkgs/applications/science/electronics/openhantek6022/default.nix +++ b/pkgs/applications/science/electronics/openhantek6022/default.nix @@ -1,4 +1,15 @@ -{ mkDerivation, lib, fetchFromGitHub, makeWrapper, cmake, qtbase, qttools, fftw, libusb1, libglvnd }: +{ + mkDerivation, + lib, + fetchFromGitHub, + makeWrapper, + cmake, + qtbase, + qttools, + fftw, + libusb1, + libglvnd, +}: mkDerivation rec { pname = "openhantek6022"; @@ -11,8 +22,17 @@ mkDerivation rec { sha256 = "sha256-y2pNLAa0P/r0YEdKjQ3iP66cqtTWERG8lTOZDR64WTk="; }; - nativeBuildInputs = [ cmake makeWrapper ]; - buildInputs = [ fftw libusb1 libglvnd qtbase qttools ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; + buildInputs = [ + fftw + libusb1 + libglvnd + qtbase + qttools + ]; postPatch = '' # Fix up install paths & checks diff --git a/pkgs/applications/science/electronics/openroad/default.nix b/pkgs/applications/science/electronics/openroad/default.nix index 05e9e6eb64f1ab..79890192ef1def 100644 --- a/pkgs/applications/science/electronics/openroad/default.nix +++ b/pkgs/applications/science/electronics/openroad/default.nix @@ -1,35 +1,36 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, fetchpatch -, bison -, cmake -, doxygen -, flex -, git -, python3 -, swig -, boost179 -, cbc # for clp -, cimg -, clp # for or-tools -, eigen -, glpk -, lcov -, lemon-graph -, libjpeg -, or-tools -, pcre -, pkg-config -, qtbase -, re2 # for or-tools -, readline -, spdlog -, tcl -, tclPackages -, xorg -, yosys -, zlib +{ + lib, + mkDerivation, + fetchFromGitHub, + fetchpatch, + bison, + cmake, + doxygen, + flex, + git, + python3, + swig, + boost179, + cbc, # for clp + cimg, + clp, # for or-tools + eigen, + glpk, + lcov, + lemon-graph, + libjpeg, + or-tools, + pcre, + pkg-config, + qtbase, + re2, # for or-tools + readline, + spdlog, + tcl, + tclPackages, + xorg, + yosys, + zlib, }: mkDerivation rec { diff --git a/pkgs/applications/science/electronics/pulseview/default.nix b/pkgs/applications/science/electronics/pulseview/default.nix index 3a40b107817db1..2e59358072c713 100644 --- a/pkgs/applications/science/electronics/pulseview/default.nix +++ b/pkgs/applications/science/electronics/pulseview/default.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchgit -, pkg-config -, cmake -, glib -, boost -, libsigrok -, libsigrokdecode -, libserialport -, libzip -, libftdi1 -, hidapi -, glibmm -, pcre -, python3 -, qtsvg -, qttools -, bluez -, wrapQtAppsHook -, desktopToDarwinBundle +{ + lib, + stdenv, + fetchgit, + pkg-config, + cmake, + glib, + boost, + libsigrok, + libsigrokdecode, + libserialport, + libzip, + libftdi1, + hidapi, + glibmm, + pcre, + python3, + qtsvg, + qttools, + bluez, + wrapQtAppsHook, + desktopToDarwinBundle, }: stdenv.mkDerivation rec { @@ -58,7 +59,10 @@ stdenv.mkDerivation rec { mainProgram = "pulseview"; homepage = "https://sigrok.org/"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ bjornfor vifino ]; + maintainers = with maintainers; [ + bjornfor + vifino + ]; platforms = platforms.unix; }; } diff --git a/pkgs/applications/science/electronics/tkgate/1.x.nix b/pkgs/applications/science/electronics/tkgate/1.x.nix index 03883652e63785..c0119ebcd13cb8 100644 --- a/pkgs/applications/science/electronics/tkgate/1.x.nix +++ b/pkgs/applications/science/electronics/tkgate/1.x.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchurl, tcl, tk, libX11, glibc, which, bison, flex, imake, xorgproto, gccmakedep }: +{ + lib, + stdenv, + fetchurl, + tcl, + tk, + libX11, + glibc, + which, + bison, + flex, + imake, + xorgproto, + gccmakedep, +}: let libiconvInc = lib.optionalString stdenv.hostPlatform.isLinux "${glibc.dev}/include"; @@ -13,8 +27,19 @@ stdenv.mkDerivation rec { sha256 = "1pqywkidfpdbj18i03h97f4cimld4fb3mqfy8jjsxs12kihm18fs"; }; - nativeBuildInputs = [ which bison flex imake gccmakedep ]; - buildInputs = [ tcl tk libX11 xorgproto ]; + nativeBuildInputs = [ + which + bison + flex + imake + gccmakedep + ]; + buildInputs = [ + tcl + tk + libX11 + xorgproto + ]; dontUseImakeConfigure = true; patchPhase = '' diff --git a/pkgs/applications/science/electronics/xyce/default.nix b/pkgs/applications/science/electronics/xyce/default.nix index 56fc59c0809941..6ad07b3f35cb67 100644 --- a/pkgs/applications/science/electronics/xyce/default.nix +++ b/pkgs/applications/science/electronics/xyce/default.nix @@ -1,30 +1,31 @@ -{ stdenv -, fetchFromGitHub -, fetchgit -, lib -, autoconf -, automake -, bison -, blas -, flex -, fftw -, gfortran -, lapack -, libtool_2 -, mpi -, suitesparse -, trilinos -, withMPI ? false +{ + stdenv, + fetchFromGitHub, + fetchgit, + lib, + autoconf, + automake, + bison, + blas, + flex, + fftw, + gfortran, + lapack, + libtool_2, + mpi, + suitesparse, + trilinos, + withMPI ? false, # for doc -, texliveMedium -, enableDocs ? true + texliveMedium, + enableDocs ? true, # for tests -, bash -, bc -, openssh # required by MPI -, perl -, python3 -, enableTests ? true + bash, + bc, + openssh, # required by MPI + perl, + python3, + enableTests ? true, }: assert withMPI -> trilinos.withMPI; @@ -52,44 +53,53 @@ stdenv.mkDerivation rec { pname = "xyce"; inherit version; - srcs = [ xyce_src regression_src ]; + srcs = [ + xyce_src + regression_src + ]; sourceRoot = xyce_src.name; preConfigure = "./bootstrap"; - configureFlags = [ - "CXXFLAGS=-O3" - "--enable-xyce-shareable" - "--enable-shared" - "--enable-stokhos" - "--enable-amesos2" - ] ++ lib.optionals withMPI [ - "--enable-mpi" - "CXX=mpicxx" - "CC=mpicc" - "F77=mpif77" - ]; + configureFlags = + [ + "CXXFLAGS=-O3" + "--enable-xyce-shareable" + "--enable-shared" + "--enable-stokhos" + "--enable-amesos2" + ] + ++ lib.optionals withMPI [ + "--enable-mpi" + "CXX=mpicxx" + "CC=mpicc" + "F77=mpif77" + ]; enableParallelBuilding = true; - nativeBuildInputs = [ - autoconf - automake - gfortran - libtool_2 - ] ++ lib.optionals enableDocs [ - (texliveMedium.withPackages (ps: with ps; [ - enumitem - koma-script - optional - framed - enumitem - multirow - newtx - preprint - ])) - ]; + nativeBuildInputs = + [ + autoconf + automake + gfortran + libtool_2 + ] + ++ lib.optionals enableDocs [ + (texliveMedium.withPackages ( + ps: with ps; [ + enumitem + koma-script + optional + framed + enumitem + multirow + newtx + preprint + ] + )) + ]; buildInputs = [ bison @@ -118,11 +128,21 @@ stdenv.mkDerivation rec { popd ''; - nativeCheckInputs = [ - bc - perl - (python3.withPackages (ps: with ps; [ numpy scipy ])) - ] ++ lib.optionals withMPI [ mpi openssh ]; + nativeCheckInputs = + [ + bc + perl + (python3.withPackages ( + ps: with ps; [ + numpy + scipy + ] + )) + ] + ++ lib.optionals withMPI [ + mpi + openssh + ]; checkPhase = '' XYCE_BINARY="$(pwd)/src/Xyce" @@ -147,7 +167,10 @@ stdenv.mkDerivation rec { "''${EXECSTRING}" ''; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; postInstall = lib.optionalString enableDocs '' local docFiles=("doc/Users_Guide/Xyce_UG" @@ -173,7 +196,8 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - broken = (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) || stdenv.hostPlatform.isDarwin; + broken = + (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) || stdenv.hostPlatform.isDarwin; description = "High-performance analog circuit simulator"; longDescription = '' Xyce is a SPICE-compatible, high-performance analog circuit simulator, diff --git a/pkgs/applications/science/geometry/tetgen/1.4.nix b/pkgs/applications/science/geometry/tetgen/1.4.nix index f67bf198443abd..ab70e9b77e90c8 100644 --- a/pkgs/applications/science/geometry/tetgen/1.4.nix +++ b/pkgs/applications/science/geometry/tetgen/1.4.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "tetgen"; diff --git a/pkgs/applications/science/geometry/tetgen/default.nix b/pkgs/applications/science/geometry/tetgen/default.nix index e64941f4243add..56b6bcbe92972b 100644 --- a/pkgs/applications/science/geometry/tetgen/default.nix +++ b/pkgs/applications/science/geometry/tetgen/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, cmake }: +{ + lib, + stdenv, + fetchurl, + cmake, +}: stdenv.mkDerivation rec { pname = "tetgen"; diff --git a/pkgs/applications/science/logic/abella/default.nix b/pkgs/applications/science/logic/abella/default.nix index 7878626d6e9a39..62da3a42e0672f 100644 --- a/pkgs/applications/science/logic/abella/default.nix +++ b/pkgs/applications/science/logic/abella/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, rsync, ocamlPackages }: +{ + lib, + stdenv, + fetchurl, + rsync, + ocamlPackages, +}: stdenv.mkDerivation (finalAttrs: { pname = "abella"; @@ -11,8 +17,18 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - nativeBuildInputs = [ rsync ] ++ (with ocamlPackages; [ ocaml dune_3 menhir findlib ]); - buildInputs = with ocamlPackages; [ cmdliner yojson ]; + nativeBuildInputs = + [ rsync ] + ++ (with ocamlPackages; [ + ocaml + dune_3 + menhir + findlib + ]); + buildInputs = with ocamlPackages; [ + cmdliner + yojson + ]; installPhase = '' mkdir -p $out/bin @@ -36,7 +52,10 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://abella-prover.org"; license = lib.licenses.gpl3; - maintainers = with lib.maintainers; [ bcdarwin ciil ]; + maintainers = with lib.maintainers; [ + bcdarwin + ciil + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/applications/science/logic/avy/default.nix b/pkgs/applications/science/logic/avy/default.nix index 38fef51c56e6d1..9edd9f27e5ac56 100644 --- a/pkgs/applications/science/logic/avy/default.nix +++ b/pkgs/applications/science/logic/avy/default.nix @@ -1,26 +1,39 @@ -{ lib, stdenv, fetchgit, cmake, zlib, boost }: +{ + lib, + stdenv, + fetchgit, + cmake, + zlib, + boost, +}: stdenv.mkDerivation rec { pname = "avy"; version = "2019.05.01"; # date of cav19 tag src = fetchgit { - url = "https://bitbucket.org/arieg/extavy"; - rev = "cav19"; + url = "https://bitbucket.org/arieg/extavy"; + rev = "cav19"; sha256 = "0qdzy9srxp5f38x4dbb3prnr9il6cy0kz80avrvd7fxqzy7wdlwy"; fetchSubmodules = true; }; nativeBuildInputs = [ cmake ]; - buildInputs = [ zlib boost.out boost.dev ]; - env.NIX_CFLAGS_COMPILE = toString ([ "-Wno-narrowing" ] + buildInputs = [ + zlib + boost.out + boost.dev + ]; + env.NIX_CFLAGS_COMPILE = toString ( + [ "-Wno-narrowing" ] # Squelch endless stream of warnings on same few things ++ lib.optionals stdenv.cc.isClang [ "-Wno-empty-body" "-Wno-tautological-compare" "-Wc++11-compat-deprecated-writable-strings" "-Wno-deprecated" - ]); + ] + ); prePatch = '' sed -i -e '1i#include ' abc/src/bdd/dsd/dsd.h @@ -39,9 +52,9 @@ stdenv.mkDerivation rec { meta = { description = "AIGER model checking for Property Directed Reachability"; - homepage = "https://arieg.bitbucket.io/avy/"; - license = lib.licenses.mit; + homepage = "https://arieg.bitbucket.io/avy/"; + license = lib.licenses.mit; maintainers = with lib.maintainers; [ thoughtpolice ]; - platforms = lib.platforms.linux; + platforms = lib.platforms.linux; }; } diff --git a/pkgs/applications/science/logic/cedille/default.nix b/pkgs/applications/science/logic/cedille/default.nix index 1ac3ff3fe310af..2e15890aa30cc0 100644 --- a/pkgs/applications/science/logic/cedille/default.nix +++ b/pkgs/applications/science/logic/cedille/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, alex -, happy -, Agda -, buildPackages -, ghcWithPackages +{ + stdenv, + lib, + fetchFromGitHub, + alex, + happy, + Agda, + buildPackages, + ghcWithPackages, }: stdenv.mkDerivation rec { @@ -24,13 +25,19 @@ stdenv.mkDerivation rec { ./Fix-to-string.agda-to-compile-with-Agda-2.6.1.patch ]; - nativeBuildInputs = [ alex happy ]; - buildInputs = [ Agda (ghcWithPackages (ps: [ps.ieee])) ]; + nativeBuildInputs = [ + alex + happy + ]; + buildInputs = [ + Agda + (ghcWithPackages (ps: [ ps.ieee ])) + ]; LANG = "en_US.UTF-8"; - LOCALE_ARCHIVE = - lib.optionalString (stdenv.buildPlatform.libc == "glibc") - "${buildPackages.glibcLocales}/lib/locale/locale-archive"; + LOCALE_ARCHIVE = lib.optionalString ( + stdenv.buildPlatform.libc == "glibc" + ) "${buildPackages.glibcLocales}/lib/locale/locale-archive"; postPatch = '' patchShebangs create-libraries.sh diff --git a/pkgs/applications/science/logic/cubicle/default.nix b/pkgs/applications/science/logic/cubicle/default.nix index 2af9e6e9264923..1aef01858dbc58 100644 --- a/pkgs/applications/science/logic/cubicle/default.nix +++ b/pkgs/applications/science/logic/cubicle/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, which -, ocamlPackages +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + which, + ocamlPackages, }: stdenv.mkDerivation rec { @@ -16,13 +17,15 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ - autoreconfHook - which - ] ++ (with ocamlPackages; [ - findlib - ocaml - ]); + nativeBuildInputs = + [ + autoreconfHook + which + ] + ++ (with ocamlPackages; [ + findlib + ocaml + ]); buildInputs = with ocamlPackages; [ functory diff --git a/pkgs/applications/science/logic/cvc3/default.nix b/pkgs/applications/science/logic/cvc3/default.nix index 8b78b86cbb073d..6c0f500816cda1 100644 --- a/pkgs/applications/science/logic/cvc3/default.nix +++ b/pkgs/applications/science/logic/cvc3/default.nix @@ -1,20 +1,36 @@ -{ lib, stdenv, fetchurl, flex, bison, gmp, perl }: +{ + lib, + stdenv, + fetchurl, + flex, + bison, + gmp, + perl, +}: stdenv.mkDerivation rec { - pname = "cvc3"; - version = "2.4.1"; + pname = "cvc3"; + version = "2.4.1"; - src = fetchurl { - url = "https://cs.nyu.edu/acsys/cvc3/releases/${version}/${pname}-${version}.tar.gz"; - sha256 = "1xxcwhz3y6djrycw8sm6xz83wb4hb12rd1n0skvc7fng0rh1snym"; - }; + src = fetchurl { + url = "https://cs.nyu.edu/acsys/cvc3/releases/${version}/${pname}-${version}.tar.gz"; + sha256 = "1xxcwhz3y6djrycw8sm6xz83wb4hb12rd1n0skvc7fng0rh1snym"; + }; - buildInputs = [ gmp flex bison perl ]; + buildInputs = [ + gmp + flex + bison + perl + ]; patches = [ ./cvc3-2.4.1-gccv6-fix.patch ]; # fails to configure on darwin due to gmp not found - configureFlags = [ "LIBS=-L${gmp}/lib" "CXXFLAGS=-I${gmp.dev}/include" ]; + configureFlags = [ + "LIBS=-L${gmp}/lib" + "CXXFLAGS=-I${gmp.dev}/include" + ]; postPatch = '' sed -e "s@ /bin/bash@bash@g" -i Makefile.std @@ -29,8 +45,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Prover for satisfiability modulo theory (SMT)"; mainProgram = "cvc3"; - maintainers = with maintainers; - [ raskin ]; + maintainers = with maintainers; [ raskin ]; platforms = platforms.unix; license = licenses.free; homepage = "https://cs.nyu.edu/acsys/cvc3/index.html"; diff --git a/pkgs/applications/science/logic/easycrypt/default.nix b/pkgs/applications/science/logic/easycrypt/default.nix index faf3dc75167f1b..3e7afa28ba3355 100644 --- a/pkgs/applications/science/logic/easycrypt/default.nix +++ b/pkgs/applications/science/logic/easycrypt/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, darwin, fetchFromGitHub, ocamlPackages, why3, python3 }: +{ + lib, + stdenv, + darwin, + fetchFromGitHub, + ocamlPackages, + why3, + python3, +}: stdenv.mkDerivation rec { pname = "easycrypt"; @@ -11,13 +19,16 @@ stdenv.mkDerivation rec { hash = "sha256-ZGYklG1eXfytRKzFvRSB6jFrOCm1gjyG8W78eMve5Ng="; }; - nativeBuildInputs = with ocamlPackages; [ - dune_3 - findlib - menhir - ocaml - python3.pkgs.wrapPython - ] ++ lib.optional stdenv.hostPlatform.isDarwin darwin.sigtool; + nativeBuildInputs = + with ocamlPackages; + [ + dune_3 + findlib + menhir + ocaml + python3.pkgs.wrapPython + ] + ++ lib.optional stdenv.hostPlatform.isDarwin darwin.sigtool; buildInputs = with ocamlPackages; [ batteries diff --git a/pkgs/applications/science/logic/ekrhyper/default.nix b/pkgs/applications/science/logic/ekrhyper/default.nix index 4a5124b235823d..d4daf57961f45e 100644 --- a/pkgs/applications/science/logic/ekrhyper/default.nix +++ b/pkgs/applications/science/logic/ekrhyper/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, ocaml, perl }: +{ + lib, + stdenv, + fetchurl, + ocaml, + perl, +}: stdenv.mkDerivation rec { pname = "ekrhyper"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ ocaml perl ]; + nativeBuildInputs = [ + ocaml + perl + ]; setSourceRoot = "export sourceRoot=$(echo */ekrh/src)"; preInstall = "export INSTALLDIR=$out"; postInstall = ''for i in "$out/casc"/*; do ln -s "$i" "$out/bin/ekrh-casc-$(basename $i)"; done ''; diff --git a/pkgs/applications/science/logic/eprover/default.nix b/pkgs/applications/science/logic/eprover/default.nix index 85833940157f47..ffae8cc79e0f34 100644 --- a/pkgs/applications/science/logic/eprover/default.nix +++ b/pkgs/applications/science/logic/eprover/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, which, enableHO ? false }: +{ + lib, + stdenv, + fetchurl, + which, + enableHO ? false, +}: stdenv.mkDerivation rec { pname = "eprover"; @@ -14,18 +20,23 @@ stdenv.mkDerivation rec { preConfigure = '' sed -e 's/ *CC *= *gcc$//' -i Makefile.vars ''; - configureFlags = [ - "--exec-prefix=$(out)" - "--man-prefix=$(out)/share/man" - ] ++ lib.optionals enableHO [ - "--enable-ho" - ]; + configureFlags = + [ + "--exec-prefix=$(out)" + "--man-prefix=$(out)/share/man" + ] + ++ lib.optionals enableHO [ + "--enable-ho" + ]; meta = with lib; { description = "Automated theorem prover for full first-order logic with equality"; homepage = "http://www.eprover.org/"; license = licenses.gpl2; - maintainers = with maintainers; [ raskin gebner ]; + maintainers = with maintainers; [ + raskin + gebner + ]; platforms = platforms.all; }; } diff --git a/pkgs/applications/science/logic/glucose/default.nix b/pkgs/applications/science/logic/glucose/default.nix index a2392ef3986109..69f5f24f229eeb 100644 --- a/pkgs/applications/science/logic/glucose/default.nix +++ b/pkgs/applications/science/logic/glucose/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, unzip -, zlib -, enableUnfree ? false +{ + lib, + stdenv, + fetchurl, + unzip, + zlib, + enableUnfree ? false, }: stdenv.mkDerivation rec { @@ -39,7 +40,9 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = "Modern, parallel SAT solver (${if enableUnfree then "parallel" else "sequential"} version)"; + description = "Modern, parallel SAT solver (${ + if enableUnfree then "parallel" else "sequential" + } version)"; mainProgram = "glucose"; homepage = "https://www.labri.fr/perso/lsimon/research/glucose/"; license = if enableUnfree then licenses.unfreeRedistributable else licenses.mit; diff --git a/pkgs/applications/science/logic/hol_light/default.nix b/pkgs/applications/science/logic/hol_light/default.nix index 59389f11a28287..92c6456b391851 100644 --- a/pkgs/applications/science/logic/hol_light/default.nix +++ b/pkgs/applications/science/logic/hol_light/default.nix @@ -1,29 +1,42 @@ -{ lib, stdenv, runtimeShell, fetchFromGitHub, ocaml, findlib, num, zarith, camlp5, camlp-streams }: +{ + lib, + stdenv, + runtimeShell, + fetchFromGitHub, + ocaml, + findlib, + num, + zarith, + camlp5, + camlp-streams, +}: let use_zarith = lib.versionAtLeast ocaml.version "4.14"; load_num = - if use_zarith then '' - -I ${zarith}/lib/ocaml/${ocaml.version}/site-lib/zarith \ - -I ${zarith}/lib/ocaml/${ocaml.version}/site-lib/stublibs \ - '' else lib.optionalString (num != null) '' - -I ${num}/lib/ocaml/${ocaml.version}/site-lib/num \ - -I ${num}/lib/ocaml/${ocaml.version}/site-lib/top-num \ - -I ${num}/lib/ocaml/${ocaml.version}/site-lib/stublibs \ - ''; + if use_zarith then + '' + -I ${zarith}/lib/ocaml/${ocaml.version}/site-lib/zarith \ + -I ${zarith}/lib/ocaml/${ocaml.version}/site-lib/stublibs \ + '' + else + lib.optionalString (num != null) '' + -I ${num}/lib/ocaml/${ocaml.version}/site-lib/num \ + -I ${num}/lib/ocaml/${ocaml.version}/site-lib/top-num \ + -I ${num}/lib/ocaml/${ocaml.version}/site-lib/stublibs \ + ''; - start_script = - '' - #!${runtimeShell} - cd $out/lib/hol_light - export OCAMLPATH="''${OCAMLPATH-}''${OCAMLPATH:+:}${camlp5}/lib/ocaml/${ocaml.version}/site-lib/" - exec ${ocaml}/bin/ocaml \ - -I \`${camlp5}/bin/camlp5 -where\` \ - ${load_num} \ - -I ${findlib}/lib/ocaml/${ocaml.version}/site-lib/ \ - -I ${camlp-streams}/lib/ocaml/${ocaml.version}/site-lib/camlp-streams camlp_streams.cma \ - -init make.ml - ''; + start_script = '' + #!${runtimeShell} + cd $out/lib/hol_light + export OCAMLPATH="''${OCAMLPATH-}''${OCAMLPATH:+:}${camlp5}/lib/ocaml/${ocaml.version}/site-lib/" + exec ${ocaml}/bin/ocaml \ + -I \`${camlp5}/bin/camlp5 -where\` \ + ${load_num} \ + -I ${findlib}/lib/ocaml/${ocaml.version}/site-lib/ \ + -I ${camlp-streams}/lib/ocaml/${ocaml.version}/site-lib/camlp-streams camlp_streams.cma \ + -init make.ml + ''; in stdenv.mkDerivation { @@ -41,7 +54,11 @@ stdenv.mkDerivation { strictDeps = true; - nativeBuildInputs = [ ocaml findlib camlp5 ]; + nativeBuildInputs = [ + ocaml + findlib + camlp5 + ]; propagatedBuildInputs = [ camlp-streams (if use_zarith then zarith else num) @@ -59,6 +76,10 @@ stdenv.mkDerivation { homepage = "http://www.cl.cam.ac.uk/~jrh13/hol-light/"; license = licenses.bsd2; platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice maggesi vbgl ]; + maintainers = with maintainers; [ + thoughtpolice + maggesi + vbgl + ]; }; } diff --git a/pkgs/applications/science/logic/klee/default.nix b/pkgs/applications/science/logic/klee/default.nix index fb02c6d40b9dc9..54c9cdc30c8066 100644 --- a/pkgs/applications/science/logic/klee/default.nix +++ b/pkgs/applications/science/logic/klee/default.nix @@ -1,39 +1,40 @@ -{ lib -, llvmPackages -, callPackage -, fetchFromGitHub -, cmake -, python3 -, z3 -, stp -, cryptominisat -, gperftools -, sqlite -, gtest -, lit -, nix-update-script - -# Build KLEE in debug mode. Defaults to false. -, debug ? false - -# Include debug info in the build. Defaults to true. -, includeDebugInfo ? true - -# Enable KLEE asserts. Defaults to true, since LLVM is built with them. -, asserts ? true - -# Build the KLEE runtime in debug mode. Defaults to true, as this improves -# stack traces of the software under test. -, debugRuntime ? true - -# Enable runtime asserts. Default false. -, runtimeAsserts ? false - -# Klee uclibc. Defaults to the bundled version. -, kleeuClibc ? null - -# Extra klee-uclibc config for the default klee-uclibc. -, extraKleeuClibcConfig ? {} +{ + lib, + llvmPackages, + callPackage, + fetchFromGitHub, + cmake, + python3, + z3, + stp, + cryptominisat, + gperftools, + sqlite, + gtest, + lit, + nix-update-script, + + # Build KLEE in debug mode. Defaults to false. + debug ? false, + + # Include debug info in the build. Defaults to true. + includeDebugInfo ? true, + + # Enable KLEE asserts. Defaults to true, since LLVM is built with them. + asserts ? true, + + # Build the KLEE runtime in debug mode. Defaults to true, as this improves + # stack traces of the software under test. + debugRuntime ? true, + + # Enable runtime asserts. Default false. + runtimeAsserts ? false, + + # Klee uclibc. Defaults to the bundled version. + kleeuClibc ? null, + + # Extra klee-uclibc config for the default klee-uclibc. + extraKleeuClibcConfig ? { }, }: # Klee supports these LLVM versions. @@ -88,27 +89,35 @@ llvmPackages.stdenv.mkDerivation rec { (lit.override { python = kleePython; }) ]; - cmakeBuildType = if debug then "Debug" else if !debug && includeDebugInfo then "RelWithDebInfo" else "MinSizeRel"; - - cmakeFlags = let - onOff = val: if val then "ON" else "OFF"; - in [ - "-DKLEE_RUNTIME_BUILD_TYPE=${if debugRuntime then "Debug" else "Release"}" - "-DLLVMCC=${llvmPackages.clang}/bin/clang" - "-DLLVMCXX=${llvmPackages.clang}/bin/clang++" - "-DKLEE_ENABLE_TIMESTAMP=${onOff false}" - "-DKLEE_UCLIBC_PATH=${chosenKleeuClibc}" - "-DENABLE_KLEE_ASSERTS=${onOff asserts}" - "-DENABLE_POSIX_RUNTIME=${onOff true}" - "-DENABLE_UNIT_TESTS=${onOff true}" - "-DENABLE_SYSTEM_TESTS=${onOff true}" - "-DGTEST_SRC_DIR=${gtest.src}" - "-DGTEST_INCLUDE_DIR=${gtest.src}/googletest/include" - "-Wno-dev" - ]; + cmakeBuildType = + if debug then + "Debug" + else if !debug && includeDebugInfo then + "RelWithDebInfo" + else + "MinSizeRel"; + + cmakeFlags = + let + onOff = val: if val then "ON" else "OFF"; + in + [ + "-DKLEE_RUNTIME_BUILD_TYPE=${if debugRuntime then "Debug" else "Release"}" + "-DLLVMCC=${llvmPackages.clang}/bin/clang" + "-DLLVMCXX=${llvmPackages.clang}/bin/clang++" + "-DKLEE_ENABLE_TIMESTAMP=${onOff false}" + "-DKLEE_UCLIBC_PATH=${chosenKleeuClibc}" + "-DENABLE_KLEE_ASSERTS=${onOff asserts}" + "-DENABLE_POSIX_RUNTIME=${onOff true}" + "-DENABLE_UNIT_TESTS=${onOff true}" + "-DENABLE_SYSTEM_TESTS=${onOff true}" + "-DGTEST_SRC_DIR=${gtest.src}" + "-DGTEST_INCLUDE_DIR=${gtest.src}/googletest/include" + "-Wno-dev" + ]; # Silence various warnings during the compilation of fortified bitcode. - env.NIX_CFLAGS_COMPILE = toString ["-Wno-macro-redefined"]; + env.NIX_CFLAGS_COMPILE = toString [ "-Wno-macro-redefined" ]; prePatch = '' patchShebangs --build . @@ -122,7 +131,10 @@ llvmPackages.stdenv.mkDerivation rec { passthru = { updateScript = nix-update-script { - extraArgs = [ "--version-regex" "v(\d\.\d)" ]; + extraArgs = [ + "--version-regex" + "v(\d\.\d)" + ]; }; # Let the user access the chosen uClibc outside the derivation. uclibc = chosenKleeuClibc; diff --git a/pkgs/applications/science/logic/klee/klee-uclibc.nix b/pkgs/applications/science/logic/klee/klee-uclibc.nix index c87a881e75336c..61cb5892edd5f3 100644 --- a/pkgs/applications/science/logic/klee/klee-uclibc.nix +++ b/pkgs/applications/science/logic/klee/klee-uclibc.nix @@ -1,15 +1,16 @@ -{ lib -, llvmPackages -, fetchurl -, fetchFromGitHub -, linuxHeaders -, python3 -, curl -, which -, nix-update-script -, debugRuntime ? true -, runtimeAsserts ? false -, extraKleeuClibcConfig ? {} +{ + lib, + llvmPackages, + fetchurl, + fetchFromGitHub, + linuxHeaders, + python3, + curl, + which, + nix-update-script, + debugRuntime ? true, + runtimeAsserts ? false, + extraKleeuClibcConfig ? { }, }: let @@ -18,11 +19,14 @@ let url = "http://www.uclibc.org/downloads/${localeSrcBase}"; sha256 = "xDYr4xijjxjZjcz0YtItlbq5LwVUi7k/ZSmP6a+uvVc="; }; - resolvedExtraKleeuClibcConfig = lib.mapAttrsToList (name: value: "${name}=${value}") (extraKleeuClibcConfig // { - "UCLIBC_DOWNLOAD_PREGENERATED_LOCALE_DATA" = "n"; - "RUNTIME_PREFIX" = "/"; - "DEVEL_PREFIX" = "/"; - }); + resolvedExtraKleeuClibcConfig = lib.mapAttrsToList (name: value: "${name}=${value}") ( + extraKleeuClibcConfig + // { + "UCLIBC_DOWNLOAD_PREGENERATED_LOCALE_DATA" = "n"; + "RUNTIME_PREFIX" = "/"; + "DEVEL_PREFIX" = "/"; + } + ); in llvmPackages.stdenv.mkDerivation rec { pname = "klee-uclibc"; @@ -56,11 +60,13 @@ llvmPackages.stdenv.mkDerivation rec { # klee-uclibc configure does not support --prefix, so we override configurePhase entirely configurePhase = '' - ./configure ${lib.escapeShellArgs ( - ["--make-llvm-lib"] - ++ lib.optional (!debugRuntime) "--enable-release" - ++ lib.optional runtimeAsserts "--enable-assertions" - )} + ./configure ${ + lib.escapeShellArgs ( + [ "--make-llvm-lib" ] + ++ lib.optional (!debugRuntime) "--enable-release" + ++ lib.optional runtimeAsserts "--enable-assertions" + ) + } # Set all the configs we care about. configs=( @@ -86,12 +92,15 @@ llvmPackages.stdenv.mkDerivation rec { ln -sf ${localeSrc} extra/locale/${localeSrcBase} ''; - makeFlags = ["HAVE_DOT_CONFIG=y"]; + makeFlags = [ "HAVE_DOT_CONFIG=y" ]; enableParallelBuilding = true; passthru.updateScript = nix-update-script { - extraArgs = [ "--version-regex" "v(\d\.\d)" ]; + extraArgs = [ + "--version-regex" + "v(\d\.\d)" + ]; }; meta = with lib; { diff --git a/pkgs/applications/science/logic/leo2/default.nix b/pkgs/applications/science/logic/leo2/default.nix index 7fdc37c4db4e35..d26b2f06a97b81 100644 --- a/pkgs/applications/science/logic/leo2/default.nix +++ b/pkgs/applications/science/logic/leo2/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, fetchpatch, makeWrapper, eprover, ocaml, camlp4, perl, zlib }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + makeWrapper, + eprover, + ocaml, + camlp4, + perl, + zlib, +}: stdenv.mkDerivation rec { pname = "leo2"; @@ -11,10 +22,17 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ makeWrapper eprover ocaml camlp4 perl ]; + nativeBuildInputs = [ + makeWrapper + eprover + ocaml + camlp4 + perl + ]; buildInputs = [ zlib ]; - patches = [ (fetchpatch { + patches = [ + (fetchpatch { url = "https://github.com/niklasso/minisat/commit/7eb6015313561a2586032574788fcb133eeaa19f.patch"; stripLen = 1; extraPrefix = "lib/"; diff --git a/pkgs/applications/science/logic/leo3/binary.nix b/pkgs/applications/science/logic/leo3/binary.nix index e8af3fdaab1a30..cf0c9ba0806e33 100644 --- a/pkgs/applications/science/logic/leo3/binary.nix +++ b/pkgs/applications/science/logic/leo3/binary.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, openjdk, runtimeShell}: +{ + lib, + stdenv, + fetchurl, + openjdk, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "leo3"; version = "1.2"; @@ -23,7 +29,7 @@ stdenv.mkDerivation rec { mainProgram = "leo3"; sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.bsd3; - maintainers = [maintainers.raskin]; + maintainers = [ maintainers.raskin ]; platforms = platforms.linux; homepage = "https://page.mi.fu-berlin.de/lex/leo3/"; }; diff --git a/pkgs/applications/science/logic/potassco/clingcon.nix b/pkgs/applications/science/logic/potassco/clingcon.nix index 957ebfd3ec43fc..33521fc0248dd7 100644 --- a/pkgs/applications/science/logic/potassco/clingcon.nix +++ b/pkgs/applications/science/logic/potassco/clingcon.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, clingo -, catch2 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + clingo, + catch2, }: stdenv.mkDerivation rec { @@ -14,13 +16,16 @@ stdenv.mkDerivation rec { repo = pname; rev = "v${version}"; sha256 = "sha256-R2kgcw8VUwhOdvPXnsahT5gnoUd5DXLqfdH++8rFoAA="; - }; + }; postPatch = '' cp ${catch2}/include/catch2/catch.hpp libclingcon/tests/catch.hpp ''; - nativeBuildInputs = [ cmake clingo ]; + nativeBuildInputs = [ + cmake + clingo + ]; cmakeFlags = [ "-DCLINGCON_MANAGE_RPATH=ON" diff --git a/pkgs/applications/science/logic/potassco/clingo.nix b/pkgs/applications/science/logic/potassco/clingo.nix index ad3af12429a29b..a37d64e943b163 100644 --- a/pkgs/applications/science/logic/potassco/clingo.nix +++ b/pkgs/applications/science/logic/potassco/clingo.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "clingo"; @@ -18,7 +23,7 @@ stdenv.mkDerivation rec { meta = { description = "ASP system to ground and solve logic programs"; license = lib.licenses.mit; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.unix; homepage = "https://potassco.org/"; downloadPage = "https://github.com/potassco/clingo/releases/"; diff --git a/pkgs/applications/science/logic/prooftree/default.nix b/pkgs/applications/science/logic/prooftree/default.nix index bb20477fd1788e..5f09e6d23d2079 100644 --- a/pkgs/applications/science/logic/prooftree/default.nix +++ b/pkgs/applications/science/logic/prooftree/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, ncurses, ocamlPackages }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + ncurses, + ocamlPackages, +}: stdenv.mkDerivation rec { pname = "prooftree"; @@ -11,7 +18,13 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ pkg-config ] ++ (with ocamlPackages; [ ocaml findlib camlp5 ]); + nativeBuildInputs = + [ pkg-config ] + ++ (with ocamlPackages; [ + ocaml + findlib + camlp5 + ]); buildInputs = [ ncurses ] ++ (with ocamlPackages; [ lablgtk ]); prefixKey = "--prefix "; diff --git a/pkgs/applications/science/logic/satallax/default.nix b/pkgs/applications/science/logic/satallax/default.nix index 0f7d05a8823ee2..ff1bb99dac34bb 100644 --- a/pkgs/applications/science/logic/satallax/default.nix +++ b/pkgs/applications/science/logic/satallax/default.nix @@ -1,11 +1,27 @@ -{ lib, stdenv, fetchurl, ocaml, zlib, which, eprover, makeWrapper, coq }: +{ + lib, + stdenv, + fetchurl, + ocaml, + zlib, + which, + eprover, + makeWrapper, + coq, +}: stdenv.mkDerivation rec { pname = "satallax"; version = "2.7"; strictDeps = true; - nativeBuildInputs = [ makeWrapper ocaml which eprover coq ]; + nativeBuildInputs = [ + makeWrapper + ocaml + which + eprover + coq + ]; buildInputs = [ zlib ]; src = fetchurl { @@ -55,7 +71,12 @@ stdenv.mkDerivation rec { mkdir -p "$out/share/doc/satallax" "$out/bin" "$out/lib" "$out/lib/satallax" cp bin/satallax.opt "$out/bin/satallax" wrapProgram "$out/bin/satallax" \ - --suffix PATH : "${lib.makeBinPath [ coq eprover ]}:$out/libexec/satallax" \ + --suffix PATH : "${ + lib.makeBinPath [ + coq + eprover + ] + }:$out/libexec/satallax" \ --add-flags "-M" --add-flags "$out/lib/satallax/modes" cp LICENSE README "$out/share/doc/satallax" diff --git a/pkgs/applications/science/logic/spass/default.nix b/pkgs/applications/science/logic/spass/default.nix index 77b297b4fbbbda..fff6a6b0858be0 100644 --- a/pkgs/applications/science/logic/spass/default.nix +++ b/pkgs/applications/science/logic/spass/default.nix @@ -1,10 +1,17 @@ -{ lib, stdenv, fetchurl, bison, flex }: +{ + lib, + stdenv, + fetchurl, + bison, + flex, +}: let - baseVersion="3"; - minorVersion="9"; + baseVersion = "3"; + minorVersion = "9"; - extraTools = "FLOTTER prolog2dfg dfg2otter dfg2dimacs dfg2tptp" + extraTools = + "FLOTTER prolog2dfg dfg2otter dfg2dimacs dfg2tptp" + " dfg2ascii dfg2dfg tptp2dfg dimacs2dfg pgen rescmp"; in @@ -19,7 +26,10 @@ stdenv.mkDerivation { sourceRoot = "."; - nativeBuildInputs = [ bison flex ]; + nativeBuildInputs = [ + bison + flex + ]; buildPhase = '' make RM="rm -f" proparser.c ${extraTools} opt @@ -31,8 +41,7 @@ stdenv.mkDerivation { meta = with lib; { description = "Automated theorem prover for first-order logic"; - maintainers = with maintainers; - [ + maintainers = with maintainers; [ raskin ]; platforms = platforms.unix; diff --git a/pkgs/applications/science/logic/statverif/default.nix b/pkgs/applications/science/logic/statverif/default.nix index 1f623897755175..6e6090ffaa1451 100644 --- a/pkgs/applications/science/logic/statverif/default.nix +++ b/pkgs/applications/science/logic/statverif/default.nix @@ -1,16 +1,21 @@ -{ lib, stdenv, fetchurl, ocaml }: +{ + lib, + stdenv, + fetchurl, + ocaml, +}: stdenv.mkDerivation rec { pname = "statverif"; version = "1.86pl4"; src = fetchurl { - url = "http://prosecco.gforge.inria.fr/personal/bblanche/proverif/proverif${version}.tar.gz"; + url = "http://prosecco.gforge.inria.fr/personal/bblanche/proverif/proverif${version}.tar.gz"; sha256 = "163vdcixs764jj8xa08w80qm4kcijf7xj911yp8jvz6pi1q5g13i"; }; pf-patch = fetchurl { - url = "http://markryan.eu/research/statverif/files/proverif-${version}-statverif-2657ab4.patch"; + url = "http://markryan.eu/research/statverif/files/proverif-${version}-statverif-2657ab4.patch"; sha256 = "113jjhi1qkcggbsmbw8fa9ln8vs7vy2r288szks7rn0jjn0wxmbw"; }; @@ -28,9 +33,9 @@ stdenv.mkDerivation rec { meta = { description = "Verification of stateful processes (via Proverif)"; - homepage = "https://markryan.eu/research/statverif/"; - license = lib.licenses.gpl2; - platforms = lib.platforms.unix; + homepage = "https://markryan.eu/research/statverif/"; + license = lib.licenses.gpl2; + platforms = lib.platforms.unix; maintainers = [ lib.maintainers.thoughtpolice ]; }; } diff --git a/pkgs/applications/science/logic/tamarin-prover/default.nix b/pkgs/applications/science/logic/tamarin-prover/default.nix index 698b4ddc47da55..2dac1f012c9e68 100644 --- a/pkgs/applications/science/logic/tamarin-prover/default.nix +++ b/pkgs/applications/science/logic/tamarin-prover/default.nix @@ -1,25 +1,33 @@ -{ haskellPackages, mkDerivation, fetchFromGitHub, lib, stdenv -# the following are non-haskell dependencies -, makeWrapper, which, maude, graphviz, glibcLocales +{ + haskellPackages, + mkDerivation, + fetchFromGitHub, + lib, + stdenv, + # the following are non-haskell dependencies + makeWrapper, + which, + maude, + graphviz, + glibcLocales, }: let version = "1.10.0"; src = fetchFromGitHub { owner = "tamarin-prover"; - repo = "tamarin-prover"; - rev = version; - hash = "sha256-v1BruU2p/Sg/g7b9a+QRza46bD7PkMtsGq82qFaNhpI="; + repo = "tamarin-prover"; + rev = version; + hash = "sha256-v1BruU2p/Sg/g7b9a+QRza46bD7PkMtsGq82qFaNhpI="; }; - # tamarin has its own dependencies, but they're kept inside the repo, # no submodules. this factors out the common metadata among all derivations common = pname: src: { inherit pname version src; - license = lib.licenses.gpl3; - homepage = "https://tamarin-prover.github.io"; + license = lib.licenses.gpl3; + homepage = "https://tamarin-prover.github.io"; description = "Security protocol verification in the symbolic model"; maintainers = [ lib.maintainers.thoughtpolice ]; hydraPlatforms = lib.platforms.linux; # maude is broken on darwin @@ -32,99 +40,174 @@ let cp --remove-destination ${src}/Setup.hs .; ''; - tamarin-prover-utils = mkDerivation (common "tamarin-prover-utils" (src + "/lib/utils") // { - postPatch = replaceSymlinks; - libraryHaskellDepends = with haskellPackages; [ - base64-bytestring blaze-builder list-t - dlist exceptions fclabels haskellPackages.graphviz safe SHA split syb - ]; - }); - - tamarin-prover-term = mkDerivation (common "tamarin-prover-term" (src + "/lib/term") // { - postPatch = replaceSymlinks; - libraryHaskellDepends = (with haskellPackages; [ - attoparsec HUnit - ]) ++ [ tamarin-prover-utils ]; - }); - - tamarin-prover-theory = mkDerivation (common "tamarin-prover-theory" (src + "/lib/theory") // { - postPatch = replaceSymlinks; - doHaddock = false; # broken - libraryHaskellDepends = (with haskellPackages; [ - aeson aeson-pretty parallel uniplate - regex-pcre-builtin regex-posix split - ]) ++ [ tamarin-prover-utils tamarin-prover-term ]; - }); - - tamarin-prover-sapic = mkDerivation (common "tamarin-prover-sapic" (src + "/lib/sapic") // { - postPatch = "cp --remove-destination ${src}/LICENSE ."; - doHaddock = false; # broken - libraryHaskellDepends = (with haskellPackages; [ - raw-strings-qq - ]) ++ [ tamarin-prover-theory ]; - }); - - tamarin-prover-accountability = mkDerivation (common "tamarin-prover-accountability" (src + "/lib/accountability") // { - postPatch = "cp --remove-destination ${src}/LICENSE ."; - doHaddock = false; # broken - libraryHaskellDepends = (with haskellPackages; [ - raw-strings-qq - ]) ++ [ - tamarin-prover-utils - tamarin-prover-term - tamarin-prover-theory - ]; - }); - - tamarin-prover-export = mkDerivation (common "tamarin-prover-export" (src + "/lib/export") // { - postPatch = "cp --remove-destination ${src}/LICENSE ."; - doHaddock = false; # broken - libraryHaskellDepends = [ - tamarin-prover-utils - tamarin-prover-term - tamarin-prover-theory - tamarin-prover-sapic - ]; - }); - -in -mkDerivation (common "tamarin-prover" src // { - isLibrary = false; - isExecutable = true; - - # strip out unneeded deps manually - doHaddock = false; - enableSharedExecutables = false; - postFixup = "rm -rf $out/lib $out/nix-support $out/share/doc"; - - # wrap the prover to be sure it can find maude, sapic, etc - executableToolDepends = [ makeWrapper which maude graphviz ]; - postInstall = '' - wrapProgram $out/bin/tamarin-prover \ - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - --set LOCALE_ARCHIVE "${glibcLocales}/lib/locale/locale-archive" \ - '' + '' - --prefix PATH : ${lib.makeBinPath [ which maude graphviz ]} - # so that the package can be used as a vim plugin to install syntax coloration - install -Dt $out/share/vim-plugins/tamarin-prover/syntax/ etc/syntax/spthy.vim - install etc/filetype.vim -D $out/share/vim-plugins/tamarin-prover/ftdetect/tamarin.vim - mkdir -p $out/share/nvim - ln -s $out/share/vim-plugins/tamarin-prover $out/share/nvim/site - # Emacs SPTHY major mode - install -Dt $out/share/emacs/site-lisp etc/spthy-mode.el - ''; - - checkPhase = "./dist/build/tamarin-prover/tamarin-prover test"; - - executableHaskellDepends = (with haskellPackages; [ - binary-instances binary-orphans blaze-html conduit file-embed - gitrev http-types - resourcet shakespeare threads wai warp yesod-core yesod-static - ]) ++ [ tamarin-prover-utils - tamarin-prover-sapic - tamarin-prover-accountability - tamarin-prover-export + tamarin-prover-utils = mkDerivation ( + common "tamarin-prover-utils" (src + "/lib/utils") + // { + postPatch = replaceSymlinks; + libraryHaskellDepends = with haskellPackages; [ + base64-bytestring + blaze-builder + list-t + dlist + exceptions + fclabels + haskellPackages.graphviz + safe + SHA + split + syb + ]; + } + ); + + tamarin-prover-term = mkDerivation ( + common "tamarin-prover-term" (src + "/lib/term") + // { + postPatch = replaceSymlinks; + libraryHaskellDepends = + (with haskellPackages; [ + attoparsec + HUnit + ]) + ++ [ tamarin-prover-utils ]; + } + ); + + tamarin-prover-theory = mkDerivation ( + common "tamarin-prover-theory" (src + "/lib/theory") + // { + postPatch = replaceSymlinks; + doHaddock = false; # broken + libraryHaskellDepends = + (with haskellPackages; [ + aeson + aeson-pretty + parallel + uniplate + regex-pcre-builtin + regex-posix + split + ]) + ++ [ + tamarin-prover-utils + tamarin-prover-term + ]; + } + ); + + tamarin-prover-sapic = mkDerivation ( + common "tamarin-prover-sapic" (src + "/lib/sapic") + // { + postPatch = "cp --remove-destination ${src}/LICENSE ."; + doHaddock = false; # broken + libraryHaskellDepends = + (with haskellPackages; [ + raw-strings-qq + ]) + ++ [ tamarin-prover-theory ]; + } + ); + + tamarin-prover-accountability = mkDerivation ( + common "tamarin-prover-accountability" (src + "/lib/accountability") + // { + postPatch = "cp --remove-destination ${src}/LICENSE ."; + doHaddock = false; # broken + libraryHaskellDepends = + (with haskellPackages; [ + raw-strings-qq + ]) + ++ [ + tamarin-prover-utils tamarin-prover-term tamarin-prover-theory ]; -}) + } + ); + + tamarin-prover-export = mkDerivation ( + common "tamarin-prover-export" (src + "/lib/export") + // { + postPatch = "cp --remove-destination ${src}/LICENSE ."; + doHaddock = false; # broken + libraryHaskellDepends = [ + tamarin-prover-utils + tamarin-prover-term + tamarin-prover-theory + tamarin-prover-sapic + ]; + } + ); + +in +mkDerivation ( + common "tamarin-prover" src + // { + isLibrary = false; + isExecutable = true; + + # strip out unneeded deps manually + doHaddock = false; + enableSharedExecutables = false; + postFixup = "rm -rf $out/lib $out/nix-support $out/share/doc"; + + # wrap the prover to be sure it can find maude, sapic, etc + executableToolDepends = [ + makeWrapper + which + maude + graphviz + ]; + postInstall = + '' + wrapProgram $out/bin/tamarin-prover \ + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + --set LOCALE_ARCHIVE "${glibcLocales}/lib/locale/locale-archive" \ + '' + + '' + --prefix PATH : ${ + lib.makeBinPath [ + which + maude + graphviz + ] + } + # so that the package can be used as a vim plugin to install syntax coloration + install -Dt $out/share/vim-plugins/tamarin-prover/syntax/ etc/syntax/spthy.vim + install etc/filetype.vim -D $out/share/vim-plugins/tamarin-prover/ftdetect/tamarin.vim + mkdir -p $out/share/nvim + ln -s $out/share/vim-plugins/tamarin-prover $out/share/nvim/site + # Emacs SPTHY major mode + install -Dt $out/share/emacs/site-lisp etc/spthy-mode.el + ''; + + checkPhase = "./dist/build/tamarin-prover/tamarin-prover test"; + + executableHaskellDepends = + (with haskellPackages; [ + binary-instances + binary-orphans + blaze-html + conduit + file-embed + gitrev + http-types + resourcet + shakespeare + threads + wai + warp + yesod-core + yesod-static + ]) + ++ [ + tamarin-prover-utils + tamarin-prover-sapic + tamarin-prover-accountability + tamarin-prover-export + tamarin-prover-term + tamarin-prover-theory + ]; + } +) diff --git a/pkgs/applications/science/logic/tlaplus/default.nix b/pkgs/applications/science/logic/tlaplus/default.nix index f53da73e1e6329..183bb80ece9d21 100644 --- a/pkgs/applications/science/logic/tlaplus/default.nix +++ b/pkgs/applications/science/logic/tlaplus/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "tlaplus"; @@ -28,10 +34,14 @@ stdenv.mkDerivation rec { meta = { description = "Algorithm specification language with model checking tools"; - homepage = "http://lamport.azurewebsites.net/tla/tla.html"; + homepage = "http://lamport.azurewebsites.net/tla/tla.html"; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; - license = lib.licenses.mit; - platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ florentc thoughtpolice mgregson ]; + license = lib.licenses.mit; + platforms = lib.platforms.unix; + maintainers = with lib.maintainers; [ + florentc + thoughtpolice + mgregson + ]; }; } diff --git a/pkgs/applications/science/logic/tlaplus/tlaplus18.nix b/pkgs/applications/science/logic/tlaplus/tlaplus18.nix index 2bd0f4b835647f..639a0513f1d584 100644 --- a/pkgs/applications/science/logic/tlaplus/tlaplus18.nix +++ b/pkgs/applications/science/logic/tlaplus/tlaplus18.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "tlaplus"; @@ -30,10 +36,14 @@ stdenv.mkDerivation rec { meta = { description = "Algorithm specification language with model checking tools"; - homepage = "http://lamport.azurewebsites.net/tla/tla.html"; + homepage = "http://lamport.azurewebsites.net/tla/tla.html"; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; - license = lib.licenses.mit; - platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ florentc thoughtpolice mgregson ]; + license = lib.licenses.mit; + platforms = lib.platforms.unix; + maintainers = with lib.maintainers; [ + florentc + thoughtpolice + mgregson + ]; }; } diff --git a/pkgs/applications/science/logic/tlaplus/tlaps.nix b/pkgs/applications/science/logic/tlaplus/tlaps.nix index 59afbc094e40db..fd5f62b5177acb 100644 --- a/pkgs/applications/science/logic/tlaplus/tlaps.nix +++ b/pkgs/applications/science/logic/tlaplus/tlaps.nix @@ -1,12 +1,13 @@ -{ fetchurl -, lib -, stdenv -, ocaml -, isabelle -, cvc3 -, perl -, wget -, which +{ + fetchurl, + lib, + stdenv, + ocaml, + isabelle, + cvc3, + perl, + wget, + which, }: stdenv.mkDerivation rec { @@ -19,7 +20,14 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ ocaml isabelle cvc3 perl wget which ]; + nativeBuildInputs = [ + ocaml + isabelle + cvc3 + perl + wget + which + ]; installPhase = '' mkdir -pv "$out" diff --git a/pkgs/applications/science/logic/tlaplus/toolbox.nix b/pkgs/applications/science/logic/tlaplus/toolbox.nix index 1d5cfa5c5d93ca..15e9e1857a1476 100644 --- a/pkgs/applications/science/logic/tlaplus/toolbox.nix +++ b/pkgs/applications/science/logic/tlaplus/toolbox.nix @@ -1,13 +1,14 @@ -{ lib -, fetchzip -, makeShellWrapper -, makeDesktopItem -, stdenv -, gtk3 -, libXtst -, glib -, zlib -, wrapGAppsHook3 +{ + lib, + fetchzip, + makeShellWrapper, + makeDesktopItem, + stdenv, + gtk3, + libXtst, + glib, + zlib, + wrapGAppsHook3, }: let @@ -22,7 +23,6 @@ let startupWMClass = "TLA+ Toolbox"; }; - in stdenv.mkDerivation rec { pname = "tla-toolbox"; @@ -67,7 +67,14 @@ stdenv.mkDerivation rec { makeShellWrapper $out/toolbox/toolbox $out/bin/tla-toolbox \ --chdir "$out/toolbox" \ --add-flags "-data ~/.tla-toolbox" \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ gtk3 libXtst glib zlib ]}" \ + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + gtk3 + libXtst + glib + zlib + ] + }" \ "''${gappsWrapperArgs[@]}" echo -e "\nCreating TLA Toolbox icons..." diff --git a/pkgs/applications/science/logic/vampire/default.nix b/pkgs/applications/science/logic/vampire/default.nix index e86f22613ad473..65ec0b8d972118 100644 --- a/pkgs/applications/science/logic/vampire/default.nix +++ b/pkgs/applications/science/logic/vampire/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, z3, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + z3, + zlib, +}: stdenv.mkDerivation rec { pname = "vampire"; @@ -11,9 +18,16 @@ stdenv.mkDerivation rec { sha256 = "0z71nxjak3ibp842r8iv37w1x3cbkrmjs88lpvxqb4sgrbyk38zd"; }; - buildInputs = [ z3 zlib ]; + buildInputs = [ + z3 + zlib + ]; - makeFlags = [ "vampire_z3_rel" "CC:=$(CC)" "CXX:=$(CXX)" ]; + makeFlags = [ + "vampire_z3_rel" + "CC:=$(CC)" + "CXX:=$(CXX)" + ]; patches = [ # https://github.com/vprover/vampire/pull/54 diff --git a/pkgs/applications/science/logic/verit/default.nix b/pkgs/applications/science/logic/verit/default.nix index 65878ba43df93e..fa4cfef4e53e50 100644 --- a/pkgs/applications/science/logic/verit/default.nix +++ b/pkgs/applications/science/logic/verit/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, autoreconfHook, gmp, flex, bison }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + gmp, + flex, + bison, +}: stdenv.mkDerivation { pname = "veriT"; @@ -9,7 +17,11 @@ stdenv.mkDerivation { sha256 = "1yjvvxnsix0rhilc81ycx1s85dymq366c6zh1hwwd8qxp7k1zca2"; }; - nativeBuildInputs = [ autoreconfHook flex bison ]; + nativeBuildInputs = [ + autoreconfHook + flex + bison + ]; buildInputs = [ gmp ]; # --disable-static actually enables static linking here... diff --git a/pkgs/applications/science/logic/why3/default.nix b/pkgs/applications/science/logic/why3/default.nix index ac9475417dbdda..8c1cedc9ef7d1e 100644 --- a/pkgs/applications/science/logic/why3/default.nix +++ b/pkgs/applications/science/logic/why3/default.nix @@ -1,8 +1,16 @@ -{ callPackage, fetchurl, lib, stdenv -, ocamlPackages, coqPackages, rubber, hevea, emacs -, version ? "1.7.2" -, ideSupport ? true -, wrapGAppsHook3 +{ + callPackage, + fetchurl, + lib, + stdenv, + ocamlPackages, + coqPackages, + rubber, + hevea, + emacs, + version ? "1.7.2", + ideSupport ? true, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -11,66 +19,98 @@ stdenv.mkDerivation rec { src = fetchurl { url = "https://why3.gitlabpages.inria.fr/releases/${pname}-${version}.tar.gz"; - hash = { - "1.7.2" = "sha256-VaSG/FiO2MDdSSFXGJJrIylQx0LPwtT8AF7TpPVZhCQ="; - "1.6.0" = "sha256-hFvM6kHScaCtcHCc6Vezl9CR7BFbiKPoTEh7kj0ZJxw="; - }."${version}"; + hash = + { + "1.7.2" = "sha256-VaSG/FiO2MDdSSFXGJJrIylQx0LPwtT8AF7TpPVZhCQ="; + "1.6.0" = "sha256-hFvM6kHScaCtcHCc6Vezl9CR7BFbiKPoTEh7kj0ZJxw="; + } + ."${version}"; }; strictDeps = true; - nativeBuildInputs = lib.optional ideSupport - wrapGAppsHook3 - ++ (with ocamlPackages; [ - ocaml findlib menhir - ]) ++ [ - # Coq Support - coqPackages.coq - ]; + nativeBuildInputs = + lib.optional ideSupport wrapGAppsHook3 + ++ (with ocamlPackages; [ + ocaml + findlib + menhir + ]) + ++ [ + # Coq Support + coqPackages.coq + ]; - buildInputs = with ocamlPackages; [ - ocamlgraph zarith - # Emacs compilation of why3.el - emacs - # Documentation - rubber hevea - ] ++ lib.optional ideSupport - # GUI - lablgtk3-sourceview3 - ++ [ - # WebIDE - js_of_ocaml js_of_ocaml-ppx - # S-expression output for why3pp - ppx_deriving ppx_sexp_conv ] + buildInputs = + with ocamlPackages; + [ + ocamlgraph + zarith + # Emacs compilation of why3.el + emacs + # Documentation + rubber + hevea + ] + ++ + lib.optional ideSupport + # GUI + lablgtk3-sourceview3 + ++ [ + # WebIDE + js_of_ocaml + js_of_ocaml-ppx + # S-expression output for why3pp + ppx_deriving + ppx_sexp_conv + ] ++ - # Coq Support - (with coqPackages; [ coq flocq ]) - ; + # Coq Support + (with coqPackages; [ + coq + flocq + ]); - propagatedBuildInputs = with ocamlPackages; [ camlzip menhirLib num re sexplib ]; + propagatedBuildInputs = with ocamlPackages; [ + camlzip + menhirLib + num + re + sexplib + ]; enableParallelBuilding = true; - configureFlags = [ "--enable-verbose-make" + configureFlags = [ + "--enable-verbose-make" (lib.enableFeature ideSupport "ide") ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - installTargets = [ "install" "install-lib" ]; + installTargets = [ + "install" + "install-lib" + ]; postInstall = '' mkdir -p $dev/lib mv $out/lib/ocaml $dev/lib/ ''; - passthru.withProvers = callPackage ./with-provers.nix {}; + passthru.withProvers = callPackage ./with-provers.nix { }; meta = with lib; { description = "Platform for deductive program verification"; - homepage = "https://why3.lri.fr/"; - license = licenses.lgpl21; - platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice vbgl ]; + homepage = "https://why3.lri.fr/"; + license = licenses.lgpl21; + platforms = platforms.unix; + maintainers = with maintainers; [ + thoughtpolice + vbgl + ]; }; } diff --git a/pkgs/applications/science/logic/why3/with-provers.nix b/pkgs/applications/science/logic/why3/with-provers.nix index 95d5b95718dd9d..4d9f06475e974e 100644 --- a/pkgs/applications/science/logic/why3/with-provers.nix +++ b/pkgs/applications/science/logic/why3/with-provers.nix @@ -1,7 +1,12 @@ -{ stdenv, makeWrapper, runCommand, why3 }: +{ + stdenv, + makeWrapper, + runCommand, + why3, +}: provers: -let configAwkScript = runCommand "why3-conf.awk" { inherit provers; } - '' +let + configAwkScript = runCommand "why3-conf.awk" { inherit provers; } '' for p in $provers; do for b in $p/bin/*; do BASENAME=$(basename $b) diff --git a/pkgs/applications/science/logic/yices/default.nix b/pkgs/applications/science/logic/yices/default.nix index f29a5e1f3f51f4..937643c4abdea2 100644 --- a/pkgs/applications/science/logic/yices/default.nix +++ b/pkgs/applications/science/logic/yices/default.nix @@ -1,34 +1,48 @@ -{ lib, stdenv, fetchFromGitHub, cudd, gmp-static, gperf, autoreconfHook, libpoly }: +{ + lib, + stdenv, + fetchFromGitHub, + cudd, + gmp-static, + gperf, + autoreconfHook, + libpoly, +}: stdenv.mkDerivation rec { pname = "yices"; version = "2.6.5"; src = fetchFromGitHub { - owner = "SRI-CSL"; - repo = "yices2"; - rev = "Yices-${version}"; + owner = "SRI-CSL"; + repo = "yices2"; + rev = "Yices-${version}"; hash = "sha256-/sKyHkFW5I5kojNIRPEKojzTvfRZiyVIN5VlBIbAV7k="; }; postPatch = "patchShebangs tests/regress/check.sh"; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ cudd gmp-static gperf libpoly ]; - configureFlags = - [ "--with-static-gmp=${gmp-static.out}/lib/libgmp.a" - "--with-static-gmp-include-dir=${gmp-static.dev}/include" - "--enable-mcsat" - ]; + buildInputs = [ + cudd + gmp-static + gperf + libpoly + ]; + configureFlags = [ + "--with-static-gmp=${gmp-static.out}/lib/libgmp.a" + "--with-static-gmp-include-dir=${gmp-static.dev}/include" + "--enable-mcsat" + ]; enableParallelBuilding = true; doCheck = true; meta = with lib; { description = "High-performance theorem prover and SMT solver"; - homepage = "https://yices.csl.sri.com"; - license = licenses.gpl3; - platforms = with platforms; linux ++ darwin; + homepage = "https://yices.csl.sri.com"; + license = licenses.gpl3; + platforms = with platforms; linux ++ darwin; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/applications/science/logic/z3/tptp.nix b/pkgs/applications/science/logic/z3/tptp.nix index 15f6770404ef20..8e1da19c60085f 100644 --- a/pkgs/applications/science/logic/z3/tptp.nix +++ b/pkgs/applications/science/logic/z3/tptp.nix @@ -1,4 +1,9 @@ -{lib, stdenv, z3, cmake}: +{ + lib, + stdenv, + z3, + cmake, +}: stdenv.mkDerivation rec { pname = "z3-tptp"; version = z3.version; @@ -7,8 +12,8 @@ stdenv.mkDerivation rec { sourceRoot = "${src.name}/examples/tptp"; - nativeBuildInputs = [cmake]; - buildInputs = [z3]; + nativeBuildInputs = [ cmake ]; + buildInputs = [ z3 ]; preConfigure = '' echo 'set(Z3_LIBRARIES "-lz3")' >> CMakeLists.new @@ -25,6 +30,6 @@ stdenv.mkDerivation rec { meta = { inherit (z3.meta) license homepage platforms; description = "TPTP wrapper for Z3 prover"; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; }; } diff --git a/pkgs/applications/science/machine-learning/finalfrontier/default.nix b/pkgs/applications/science/machine-learning/finalfrontier/default.nix index ca495dcc280ac6..c388a55cb5eb80 100644 --- a/pkgs/applications/science/machine-learning/finalfrontier/default.nix +++ b/pkgs/applications/science/machine-learning/finalfrontier/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, libiconv -, openssl -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + libiconv, + openssl, + Security, }: rustPlatform.buildRustPackage rec { @@ -27,10 +28,12 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - Security - ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Security + ]; postInstall = '' installManPage man/*.1 diff --git a/pkgs/applications/science/machine-learning/finalfusion-utils/default.nix b/pkgs/applications/science/machine-learning/finalfusion-utils/default.nix index 2b3bd2776089da..4357b8ca2e550d 100644 --- a/pkgs/applications/science/machine-learning/finalfusion-utils/default.nix +++ b/pkgs/applications/science/machine-learning/finalfusion-utils/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, installShellFiles -, blas -, gfortran -, lapack -, openssl -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + installShellFiles, + blas, + gfortran, + lapack, + openssl, + Security, }: rustPlatform.buildRustPackage rec { @@ -25,14 +26,16 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ installShellFiles ]; - buildInputs = [ - blas - gfortran.cc.lib - lapack - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - ]; + buildInputs = + [ + blas + gfortran.cc.lib + lapack + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + ]; # Enables build against a generic BLAS. buildFeatures = [ "netlib" ]; diff --git a/pkgs/applications/science/machine-learning/sc2-headless/default.nix b/pkgs/applications/science/machine-learning/sc2-headless/default.nix index 37128ce67e39d2..0700580b959846 100644 --- a/pkgs/applications/science/machine-learning/sc2-headless/default.nix +++ b/pkgs/applications/science/machine-learning/sc2-headless/default.nix @@ -1,62 +1,73 @@ -{ config, stdenv -, callPackage -, lib -, fetchurl -, unzip -, licenseAccepted ? config.sc2-headless.accept_license or false +{ + config, + stdenv, + callPackage, + lib, + fetchurl, + unzip, + licenseAccepted ? config.sc2-headless.accept_license or false, }: -if !licenseAccepted then throw '' +if !licenseAccepted then + throw '' You must accept the Blizzard® Starcraft® II AI and Machine Learning License at https://blzdistsc2-a.akamaihd.net/AI_AND_MACHINE_LEARNING_LICENSE.html by setting nixpkgs config option 'sc2-headless.accept_license = true;' '' -else assert licenseAccepted; -let maps = callPackage ./maps.nix {}; -in stdenv.mkDerivation rec { - version = "4.7.1"; - pname = "sc2-headless"; - - src = fetchurl { - url = "https://blzdistsc2-a.akamaihd.net/Linux/SC2.${version}.zip"; - sha256 = "0q1ry9bd3dm8y4hvh57yfq7s05hl2k2sxi2wsl6h0r3w690v1kdd"; - }; - - unpackCmd = '' - unzip -P 'iagreetotheeula' $curSrc - ''; - - nativeBuildInputs = [ unzip ]; - - installPhase = '' - mkdir -p $out - cp -r . "$out" - rm -r $out/Libs - - cp -ur "${maps.minigames}"/* "${maps.melee}"/* "${maps.ladder2017season1}"/* "${maps.ladder2017season2}"/* "${maps.ladder2017season3}"/* \ - "${maps.ladder2017season4}"/* "${maps.ladder2018season1}"/* "${maps.ladder2018season2}"/* \ - "${maps.ladder2018season3}"/* "${maps.ladder2018season4}"/* "${maps.ladder2019season1}"/* "$out"/Maps/ - ''; - - preFixup = '' - find $out -type f -print0 | while IFS=''' read -d ''' -r file; do - isELF "$file" || continue - patchelf \ - --interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath ${lib.makeLibraryPath [stdenv.cc.cc stdenv.cc.libc]} \ - "$file" - done - ''; - - meta = { - platforms = lib.platforms.linux; - description = "Starcraft II headless linux client for machine learning research"; - sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; - license = { - fullName = "BLIZZARD® STARCRAFT® II AI AND MACHINE LEARNING LICENSE"; - url = "https://blzdistsc2-a.akamaihd.net/AI_AND_MACHINE_LEARNING_LICENSE.html"; - free = false; +else + assert licenseAccepted; + let + maps = callPackage ./maps.nix { }; + in + stdenv.mkDerivation rec { + version = "4.7.1"; + pname = "sc2-headless"; + + src = fetchurl { + url = "https://blzdistsc2-a.akamaihd.net/Linux/SC2.${version}.zip"; + sha256 = "0q1ry9bd3dm8y4hvh57yfq7s05hl2k2sxi2wsl6h0r3w690v1kdd"; + }; + + unpackCmd = '' + unzip -P 'iagreetotheeula' $curSrc + ''; + + nativeBuildInputs = [ unzip ]; + + installPhase = '' + mkdir -p $out + cp -r . "$out" + rm -r $out/Libs + + cp -ur "${maps.minigames}"/* "${maps.melee}"/* "${maps.ladder2017season1}"/* "${maps.ladder2017season2}"/* "${maps.ladder2017season3}"/* \ + "${maps.ladder2017season4}"/* "${maps.ladder2018season1}"/* "${maps.ladder2018season2}"/* \ + "${maps.ladder2018season3}"/* "${maps.ladder2018season4}"/* "${maps.ladder2019season1}"/* "$out"/Maps/ + ''; + + preFixup = '' + find $out -type f -print0 | while IFS=''' read -d ''' -r file; do + isELF "$file" || continue + patchelf \ + --interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ + --set-rpath ${ + lib.makeLibraryPath [ + stdenv.cc.cc + stdenv.cc.libc + ] + } \ + "$file" + done + ''; + + meta = { + platforms = lib.platforms.linux; + description = "Starcraft II headless linux client for machine learning research"; + sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; + license = { + fullName = "BLIZZARD® STARCRAFT® II AI AND MACHINE LEARNING LICENSE"; + url = "https://blzdistsc2-a.akamaihd.net/AI_AND_MACHINE_LEARNING_LICENSE.html"; + free = false; + }; + maintainers = [ ]; }; - maintainers = [ ]; - }; -} + } diff --git a/pkgs/applications/science/machine-learning/sc2-headless/maps.nix b/pkgs/applications/science/machine-learning/sc2-headless/maps.nix index 47e14108e37c7a..19019408a18d87 100644 --- a/pkgs/applications/science/machine-learning/sc2-headless/maps.nix +++ b/pkgs/applications/science/machine-learning/sc2-headless/maps.nix @@ -1,7 +1,12 @@ -{ fetchzip +{ + fetchzip, }: let - fetchzip' = args: (fetchzip args).overrideAttrs (old: { UNZIP = "-j -P iagreetotheeula"; }); + fetchzip' = + args: + (fetchzip args).overrideAttrs (old: { + UNZIP = "-j -P iagreetotheeula"; + }); in { minigames = fetchzip { diff --git a/pkgs/applications/science/machine-learning/shogun/default.nix b/pkgs/applications/science/machine-learning/shogun/default.nix index 550b3296dc0010..c84b83ef4542dd 100644 --- a/pkgs/applications/science/machine-learning/shogun/default.nix +++ b/pkgs/applications/science/machine-learning/shogun/default.nix @@ -1,39 +1,40 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, fetchurl +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + fetchurl, # build -, cmake -, ctags -, python3Packages -, swig + cmake, + ctags, + python3Packages, + swig, # math -, eigen -, blas -, lapack -, glpk + eigen, + blas, + lapack, + glpk, # data -, protobuf -, json_c -, libxml2 -, hdf5 -, curl + protobuf, + json_c, + libxml2, + hdf5, + curl, # compression -, libarchive -, bzip2 -, xz -, snappy -, lzo + libarchive, + bzip2, + xz, + snappy, + lzo, # more math -, nlopt -, lp_solve -, colpack + nlopt, + lp_solve, + colpack, # extra support -, pythonSupport ? false -, opencvSupport ? false -, opencv ? null -, withSvmLight ? false + pythonSupport ? false, + opencvSupport ? false, + opencv ? null, + withSvmLight ? false, }: assert pythonSupport -> python3Packages != null; @@ -52,7 +53,7 @@ let toolbox = fetchFromGitHub { owner = "shogun-toolbox"; repo = "shogun"; - rev = "shogun_${version}"; + rev = "shogun_${version}"; hash = "sha256-38aULxK50wQ2+/ERosSpRyBmssmYSGv5aaWfWSlrSRc="; fetchSubmodules = true; }; @@ -73,7 +74,11 @@ in stdenv.mkDerivation (finalAttrs: { inherit pname version; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; src = srcs.toolbox; @@ -108,65 +113,84 @@ stdenv.mkDerivation (finalAttrs: { ] ++ lib.optional (!withSvmLight) ./svmlight-scrubber.patch; - nativeBuildInputs = [ cmake swig ctags ] - ++ (with python3Packages; [ python jinja2 ply ]); - - buildInputs = [ - eigen - blas - lapack - glpk - protobuf - json_c - libxml2 - hdf5 - curl - libarchive - bzip2 - xz - snappy - lzo - nlopt - lp_solve - colpack - ] ++ lib.optionals pythonSupport (with python3Packages; [ python numpy ]) + nativeBuildInputs = + [ + cmake + swig + ctags + ] + ++ (with python3Packages; [ + python + jinja2 + ply + ]); + + buildInputs = + [ + eigen + blas + lapack + glpk + protobuf + json_c + libxml2 + hdf5 + curl + libarchive + bzip2 + xz + snappy + lzo + nlopt + lp_solve + colpack + ] + ++ lib.optionals pythonSupport ( + with python3Packages; + [ + python + numpy + ] + ) ++ lib.optional opencvSupport opencv; - cmakeFlags = let - excludeTestsRegex = lib.concatStringsSep "|" [ - # segfault - "SerializationXML" - "TrainedModelSerialization" - # broken by openblas 0.3.21 - "mathematics_lapack" - # fails on aarch64 - "LinearTimeMMD" - "QuadraticTimeMMD" - "SGVectorTest" - "Statistics" - # hangs on aarch64 - "PRange" - # these take too long on CI - "evaluation_cross_validation" - "modelselection_combined_kernel" - "modelselection_grid_search" + cmakeFlags = + let + excludeTestsRegex = lib.concatStringsSep "|" [ + # segfault + "SerializationXML" + "TrainedModelSerialization" + # broken by openblas 0.3.21 + "mathematics_lapack" + # fails on aarch64 + "LinearTimeMMD" + "QuadraticTimeMMD" + "SGVectorTest" + "Statistics" + # hangs on aarch64 + "PRange" + # these take too long on CI + "evaluation_cross_validation" + "modelselection_combined_kernel" + "modelselection_grid_search" + ]; + in + [ + (lib.cmakeBool "BUILD_META_EXAMPLES" true) + (lib.cmakeBool "CMAKE_DISABLE_FIND_PACKAGE_ARPACK" true) + (lib.cmakeBool "CMAKE_DISABLE_FIND_PACKAGE_ARPREC" true) + (lib.cmakeBool "CMAKE_DISABLE_FIND_PACKAGE_CPLEX" true) + (lib.cmakeBool "CMAKE_DISABLE_FIND_PACKAGE_Mosek" true) + (lib.cmakeBool "CMAKE_DISABLE_FIND_PACKAGE_TFLogger" true) + (lib.cmakeBool "CMAKE_DISABLE_FIND_PACKAGE_ViennaCL" true) + (lib.cmakeFeature "CMAKE_CTEST_ARGUMENTS" "--exclude-regex;'${excludeTestsRegex}'") + (lib.cmakeBool "ENABLE_TESTING" finalAttrs.doCheck) + (lib.cmakeBool "DISABLE_META_INTEGRATION_TESTS" true) + (lib.cmakeBool "TRAVIS_DISABLE_META_CPP" true) + (lib.cmakeBool "INTERFACE_PYTHON" pythonSupport) + (lib.cmakeBool "OpenCV" opencvSupport) + (lib.cmakeBool "USE_SVMLIGHT" withSvmLight) ]; - in [ - (lib.cmakeBool "BUILD_META_EXAMPLES" true) - (lib.cmakeBool "CMAKE_DISABLE_FIND_PACKAGE_ARPACK" true) - (lib.cmakeBool "CMAKE_DISABLE_FIND_PACKAGE_ARPREC" true) - (lib.cmakeBool "CMAKE_DISABLE_FIND_PACKAGE_CPLEX" true) - (lib.cmakeBool "CMAKE_DISABLE_FIND_PACKAGE_Mosek" true) - (lib.cmakeBool "CMAKE_DISABLE_FIND_PACKAGE_TFLogger" true) - (lib.cmakeBool "CMAKE_DISABLE_FIND_PACKAGE_ViennaCL" true) - (lib.cmakeFeature "CMAKE_CTEST_ARGUMENTS" "--exclude-regex;'${excludeTestsRegex}'") - (lib.cmakeBool "ENABLE_TESTING" finalAttrs.doCheck) - (lib.cmakeBool "DISABLE_META_INTEGRATION_TESTS" true) - (lib.cmakeBool "TRAVIS_DISABLE_META_CPP" true) - (lib.cmakeBool "INTERFACE_PYTHON" pythonSupport) - (lib.cmakeBool "OpenCV" opencvSupport) - (lib.cmakeBool "USE_SVMLIGHT" withSvmLight) - ]; CXXFLAGS = "-faligned-new"; @@ -178,21 +202,23 @@ stdenv.mkDerivation (finalAttrs: { ln -s ${srcs.gtest} $sourceRoot/third_party/GoogleMock/release-${gtestVersion}.tar.gz ''; - postPatch = '' - # Fix preprocessing SVMlight code - sed -i \ - -e 's@#ifdef SVMLIGHT@#ifdef USE_SVMLIGHT@' \ - -e '/^#ifdef USE_SVMLIGHT/,/^#endif/ s@#endif@#endif //USE_SVMLIGHT@' \ - src/shogun/kernel/string/CommUlongStringKernel.cpp - sed -i -e 's/#if USE_SVMLIGHT/#ifdef USE_SVMLIGHT/' src/interfaces/swig/Machine.i - sed -i -e 's@// USE_SVMLIGHT@//USE_SVMLIGHT@' src/interfaces/swig/Transfer.i - sed -i -e 's@/\* USE_SVMLIGHT \*/@//USE_SVMLIGHT@' src/interfaces/swig/Transfer_includes.i - '' + lib.optionalString (!withSvmLight) '' - # Run SVMlight scrubber - patchShebangs scripts/light-scrubber.sh - echo "removing SVMlight code" - ./scripts/light-scrubber.sh - ''; + postPatch = + '' + # Fix preprocessing SVMlight code + sed -i \ + -e 's@#ifdef SVMLIGHT@#ifdef USE_SVMLIGHT@' \ + -e '/^#ifdef USE_SVMLIGHT/,/^#endif/ s@#endif@#endif //USE_SVMLIGHT@' \ + src/shogun/kernel/string/CommUlongStringKernel.cpp + sed -i -e 's/#if USE_SVMLIGHT/#ifdef USE_SVMLIGHT/' src/interfaces/swig/Machine.i + sed -i -e 's@// USE_SVMLIGHT@//USE_SVMLIGHT@' src/interfaces/swig/Transfer.i + sed -i -e 's@/\* USE_SVMLIGHT \*/@//USE_SVMLIGHT@' src/interfaces/swig/Transfer_includes.i + '' + + lib.optionalString (!withSvmLight) '' + # Run SVMlight scrubber + patchShebangs scripts/light-scrubber.sh + echo "removing SVMlight code" + ./scripts/light-scrubber.sh + ''; postInstall = '' mkdir -p $doc/share/doc/shogun/examples @@ -211,6 +237,9 @@ stdenv.mkDerivation (finalAttrs: { description = "Toolbox which offers a wide range of efficient and unified machine learning methods"; homepage = "http://shogun-toolbox.org/"; license = if withSvmLight then licenses.unfree else licenses.gpl3Plus; - maintainers = with maintainers; [ edwtjo smancill ]; + maintainers = with maintainers; [ + edwtjo + smancill + ]; }; }) diff --git a/pkgs/applications/science/math/caffe/default.nix b/pkgs/applications/science/math/caffe/default.nix index 65e039991b913f..251245469d7397 100644 --- a/pkgs/applications/science/math/caffe/default.nix +++ b/pkgs/applications/science/math/caffe/default.nix @@ -1,21 +1,31 @@ -{ config, stdenv, lib -, fetchFromGitHub -, fetchurl -, fetchpatch -, cmake -, boost -, gflags -, glog -, hdf5-cpp -, opencv4 -, protobuf -, doxygen -, blas -, Accelerate, CoreGraphics, CoreVideo -, lmdbSupport ? true, lmdb -, leveldbSupport ? true, leveldb, snappy -, pythonSupport ? false, python ? null, numpy ? null -, substituteAll +{ + config, + stdenv, + lib, + fetchFromGitHub, + fetchurl, + fetchpatch, + cmake, + boost, + gflags, + glog, + hdf5-cpp, + opencv4, + protobuf, + doxygen, + blas, + Accelerate, + CoreGraphics, + CoreVideo, + lmdbSupport ? true, + lmdb, + leveldbSupport ? true, + leveldb, + snappy, + pythonSupport ? false, + python ? null, + numpy ? null, + substituteAll, }: let @@ -38,48 +48,92 @@ stdenv.mkDerivation rec { sha256 = "104jp3cm823i3cdph7hgsnj6l77ygbwsy35mdmzhmsi4jxprd9j3"; }; - nativeBuildInputs = [ cmake doxygen ]; + nativeBuildInputs = [ + cmake + doxygen + ]; cmakeFlags = # It's important that caffe is passed the major and minor version only because that's what # boost_python expects - [ (if pythonSupport then "-Dpython_version=${python.pythonVersion}" else "-DBUILD_python=OFF") + [ + (if pythonSupport then "-Dpython_version=${python.pythonVersion}" else "-DBUILD_python=OFF") "-DBLAS=open" "-DCPU_ONLY=ON" - ] ++ ["-DUSE_LEVELDB=${toggle leveldbSupport}"] - ++ ["-DUSE_LMDB=${toggle lmdbSupport}"]; - - buildInputs = [ boost gflags glog protobuf hdf5-cpp opencv4 blas ] - ++ lib.optional lmdbSupport lmdb - ++ lib.optionals leveldbSupport [ leveldb snappy ] - ++ lib.optionals pythonSupport [ python numpy ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Accelerate CoreGraphics CoreVideo ] - ; + ] + ++ [ "-DUSE_LEVELDB=${toggle leveldbSupport}" ] + ++ [ "-DUSE_LMDB=${toggle lmdbSupport}" ]; + + buildInputs = + [ + boost + gflags + glog + protobuf + hdf5-cpp + opencv4 + blas + ] + ++ lib.optional lmdbSupport lmdb + ++ lib.optionals leveldbSupport [ + leveldb + snappy + ] + ++ lib.optionals pythonSupport [ + python + numpy + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Accelerate + CoreGraphics + CoreVideo + ]; propagatedBuildInputs = lib.optionals pythonSupport ( # requirements.txt - let pp = python.pkgs; in ([ - pp.numpy pp.scipy pp.scikit-image pp.h5py - pp.matplotlib pp.ipython pp.networkx - pp.pandas pp.python-dateutil pp.protobuf pp.gflags - pp.pyyaml pp.pillow pp.six - ] ++ lib.optional leveldbSupport pp.leveldb) + let + pp = python.pkgs; + in + ( + [ + pp.numpy + pp.scipy + pp.scikit-image + pp.h5py + pp.matplotlib + pp.ipython + pp.networkx + pp.pandas + pp.python-dateutil + pp.protobuf + pp.gflags + pp.pyyaml + pp.pillow + pp.six + ] + ++ lib.optional leveldbSupport pp.leveldb + ) ); - outputs = [ "bin" "out" ]; - propagatedBuildOutputs = []; # otherwise propagates out -> bin cycle - - patches = [ - ./darwin.patch - (fetchpatch { - name = "support-opencv4"; - url = "https://github.com/BVLC/caffe/pull/6638/commits/0a04cc2ccd37ba36843c18fea2d5cbae6e7dd2b5.patch"; - hash = "sha256-ZegTvp0tTHlopQv+UzHDigs6XLkP2VfqLCWXl6aKJSI="; - }) - ] ++ lib.optional pythonSupport (substituteAll { - src = ./python.patch; - inherit (python.sourceVersion) major minor; # Should be changed in case of PyPy - }); + outputs = [ + "bin" + "out" + ]; + propagatedBuildOutputs = [ ]; # otherwise propagates out -> bin cycle + + patches = + [ + ./darwin.patch + (fetchpatch { + name = "support-opencv4"; + url = "https://github.com/BVLC/caffe/pull/6638/commits/0a04cc2ccd37ba36843c18fea2d5cbae6e7dd2b5.patch"; + hash = "sha256-ZegTvp0tTHlopQv+UzHDigs6XLkP2VfqLCWXl6aKJSI="; + }) + ] + ++ lib.optional pythonSupport (substituteAll { + src = ./python.patch; + inherit (python.sourceVersion) major minor; # Should be changed in case of PyPy + }); postPatch = '' substituteInPlace src/caffe/util/io.cpp --replace \ @@ -92,19 +146,21 @@ stdenv.mkDerivation rec { export BOOST_LIBRARYDIR="${boost.out}/lib"; ''; - postInstall = '' - # Internal static library. - rm $out/lib/libproto.a + postInstall = + '' + # Internal static library. + rm $out/lib/libproto.a - # Install models - cp -a ../models $out/share/Caffe/models + # Install models + cp -a ../models $out/share/Caffe/models - moveToOutput "bin" "$bin" - '' + lib.optionalString pythonSupport '' - mkdir -p $out/${python.sitePackages} - mv $out/python/caffe $out/${python.sitePackages} - rm -rf $out/python - ''; + moveToOutput "bin" "$bin" + '' + + lib.optionalString pythonSupport '' + mkdir -p $out/${python.sitePackages} + mv $out/python/caffe $out/${python.sitePackages} + rm -rf $out/python + ''; doInstallCheck = false; # build takes more than 30 min otherwise installCheckPhase = '' @@ -128,8 +184,7 @@ stdenv.mkDerivation rec { broken = (pythonSupport && (python.isPy310)) || !(leveldbSupport -> (leveldb != null && snappy != null)) - || !(pythonSupport -> (python != null && numpy != null)) - ; + || !(pythonSupport -> (python != null && numpy != null)); license = licenses.bsd2; platforms = platforms.linux ++ platforms.darwin; }; diff --git a/pkgs/applications/science/math/engauge-digitizer/default.nix b/pkgs/applications/science/math/engauge-digitizer/default.nix index 95306a0820fa30..f2f87a42ab8a42 100644 --- a/pkgs/applications/science/math/engauge-digitizer/default.nix +++ b/pkgs/applications/science/math/engauge-digitizer/default.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, fftw, libjpeg, log4cpp, openjpeg -, libpng12, poppler, qtbase, qt5, qmake, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + fftw, + libjpeg, + log4cpp, + openjpeg, + libpng12, + poppler, + qtbase, + qt5, + qmake, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -13,7 +25,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-Wj9o3wWbtHsEi6LFH4xDpwVR9BwcWc472jJ/QFDQZvY="; }; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; buildInputs = [ qtbase diff --git a/pkgs/applications/science/math/geogebra/default.nix b/pkgs/applications/science/math/geogebra/default.nix index 1d5fa4a9ef4508..af4dec8c0c3d70 100644 --- a/pkgs/applications/science/math/geogebra/default.nix +++ b/pkgs/applications/science/math/geogebra/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, libGL, xorg, jre, makeDesktopItem, makeWrapper, unzip, language ? "en_US" }: +{ + lib, + stdenv, + fetchurl, + libGL, + xorg, + jre, + makeDesktopItem, + makeWrapper, + unzip, + language ? "en_US", +}: let pname = "geogebra"; version = "5-0-785-0"; @@ -15,8 +26,15 @@ let desktopName = "Geogebra"; genericName = "Geogebra"; comment = meta.description; - categories = [ "Education" "Science" "Math" ]; - mimeTypes = [ "application/vnd.geogebra.file" "application/vnd.geogebra.tool" ]; + categories = [ + "Education" + "Science" + "Math" + ]; + mimeTypes = [ + "application/vnd.geogebra.file" + "application/vnd.geogebra.tool" + ]; }; meta = with lib; { @@ -27,18 +45,31 @@ let calculus in one easy-to-use package. ''; homepage = "https://www.geogebra.org/"; - maintainers = with maintainers; [ sikmir soupglasses ]; - license = with licenses; [ gpl3 cc-by-nc-sa-30 geogebra ]; + maintainers = with maintainers; [ + sikmir + soupglasses + ]; + license = with licenses; [ + gpl3 + cc-by-nc-sa-30 + geogebra + ]; sourceProvenance = with sourceTypes; [ binaryBytecode - binaryNativeCode # some jars include native binaries + binaryNativeCode # some jars include native binaries ]; platforms = with platforms; linux ++ darwin; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; linuxPkg = stdenv.mkDerivation { - inherit pname version meta srcIcon desktopItem; + inherit + pname + version + meta + srcIcon + desktopItem + ; preferLocalBuild = true; @@ -58,7 +89,12 @@ let # The bundled jogl (required for 3D graphics) links to libXxf86vm, and loads libGL at runtime # OpenGL versions newer than 3.0 cause "javax.media.opengl.GLException: Not a GL2 implementation" makeWrapper "$out/libexec/geogebra/geogebra" "$out/bin/geogebra" \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ libGL xorg.libXxf86vm ]}" \ + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + libGL + xorg.libXxf86vm + ] + }" \ --set MESA_GL_VERSION_OVERRIDE 3.0 \ --set JAVACMD "${jre}/bin/java" \ --set GG_PATH "$out/libexec/geogebra" \ @@ -95,6 +131,4 @@ let ''; }; in -if stdenv.hostPlatform.isDarwin -then darwinPkg -else linuxPkg +if stdenv.hostPlatform.isDarwin then darwinPkg else linuxPkg diff --git a/pkgs/applications/science/math/glsurf/default.nix b/pkgs/applications/science/math/glsurf/default.nix index 0edaa32babd70f..bcf782e1963615 100644 --- a/pkgs/applications/science/math/glsurf/default.nix +++ b/pkgs/applications/science/math/glsurf/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, ocamlPackages -, makeWrapper -, libGLU -, libGL -, libglut -, mpfr -, gmp -, pkgsHostTarget +{ + lib, + stdenv, + fetchurl, + ocamlPackages, + makeWrapper, + libGLU, + libGL, + libglut, + mpfr, + gmp, + pkgsHostTarget, }: let @@ -24,25 +25,29 @@ stdenv.mkDerivation rec { sha256 = "0w8xxfnw2snflz8wdr2ca9f5g91w5vbyp1hwlx1v7vg83d4bwqs7"; }; - nativeBuildInputs = [ - makeWrapper - ] ++ (with ocamlPackages; [ - ocaml - findlib - ]); + nativeBuildInputs = + [ + makeWrapper + ] + ++ (with ocamlPackages; [ + ocaml + findlib + ]); - buildInputs = [ - libglut - libGL - libGLU - mpfr - gmp - ] ++ (with ocamlPackages; [ - camlp4 - lablgl - camlimages - num - ]); + buildInputs = + [ + libglut + libGL + libGLU + mpfr + gmp + ] + ++ (with ocamlPackages; [ + camlp4 + lablgl + camlimages + num + ]); postPatch = '' for f in callbacks*/Makefile src/Makefile; do diff --git a/pkgs/applications/science/math/hmetis/default.nix b/pkgs/applications/science/math/hmetis/default.nix index 1c0152b7bfc77e..c8bacea5acb707 100644 --- a/pkgs/applications/science/math/hmetis/default.nix +++ b/pkgs/applications/science/math/hmetis/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ghostscript }: +{ + lib, + stdenv, + fetchurl, + ghostscript, +}: stdenv.mkDerivation rec { pname = "hmetis"; @@ -38,6 +43,9 @@ stdenv.mkDerivation rec { homepage = "http://glaros.dtc.umn.edu/gkhome/metis/hmetis/overview"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/applications/science/math/labplot/default.nix b/pkgs/applications/science/math/labplot/default.nix index 0aeb232dd03135..7b1a54e46666bc 100644 --- a/pkgs/applications/science/math/labplot/default.nix +++ b/pkgs/applications/science/math/labplot/default.nix @@ -1,44 +1,45 @@ -{ lib -, stdenv -, fetchpatch -, fetchurl -, cmake -, extra-cmake-modules -, shared-mime-info -, wrapQtAppsHook +{ + lib, + stdenv, + fetchpatch, + fetchurl, + cmake, + extra-cmake-modules, + shared-mime-info, + wrapQtAppsHook, -, qtbase + qtbase, -, karchive -, kcompletion -, kconfig -, kcoreaddons -, kcrash -, kdoctools -, ki18n -, kiconthemes -, kio -, knewstuff -, kparts -, ktextwidgets -, kxmlgui -, syntax-highlighting + karchive, + kcompletion, + kconfig, + kcoreaddons, + kcrash, + kdoctools, + ki18n, + kiconthemes, + kio, + knewstuff, + kparts, + ktextwidgets, + kxmlgui, + syntax-highlighting, -, gsl + gsl, -, poppler -, fftw -, hdf5 -, netcdf -, cfitsio -, libcerf -, cantor -, zlib -, lz4 -, readstat -, matio -, qtserialport -, discount + poppler, + fftw, + hdf5, + netcdf, + cfitsio, + libcerf, + cantor, + zlib, + lz4, + readstat, + matio, + qtserialport, + discount, }: stdenv.mkDerivation rec { @@ -108,7 +109,18 @@ stdenv.mkDerivation rec { meta = with lib; { description = "LabPlot is a FREE, open source and cross-platform Data Visualization and Analysis software accessible to everyone"; homepage = "https://labplot.kde.org"; - license = with licenses; [ asl20 bsd3 cc-by-30 cc0 gpl2Only gpl2Plus gpl3Only gpl3Plus lgpl3Plus mit ]; + license = with licenses; [ + asl20 + bsd3 + cc-by-30 + cc0 + gpl2Only + gpl2Plus + gpl3Only + gpl3Plus + lgpl3Plus + mit + ]; maintainers = with maintainers; [ hqurve ]; mainProgram = "labplot2"; platforms = platforms.unix; diff --git a/pkgs/applications/science/math/lp_solve/default.nix b/pkgs/applications/science/math/lp_solve/default.nix index 67d7bfdba90c21..63722349629daf 100644 --- a/pkgs/applications/science/math/lp_solve/default.nix +++ b/pkgs/applications/science/math/lp_solve/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, cctools -, fixDarwinDylibNames -, autoSignDarwinBinariesHook +{ + lib, + stdenv, + fetchurl, + cctools, + fixDarwinDylibNames, + autoSignDarwinBinariesHook, }: stdenv.mkDerivation rec { @@ -15,18 +16,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-bUq/9cxqqpM66ObBeiJt8PwLZxxDj2lxXUHQn+gfkC8="; }; - nativeBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - cctools - fixDarwinDylibNames - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - autoSignDarwinBinariesHook - ]; + nativeBuildInputs = + lib.optionals stdenv.hostPlatform.isDarwin [ + cctools + fixDarwinDylibNames + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + autoSignDarwinBinariesHook + ]; - env = { - NIX_CFLAGS_COMPILE = "-Wno-error=implicit-int"; - } // lib.optionalAttrs (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) { - NIX_LDFLAGS = "-headerpad_max_install_names"; - }; + env = + { + NIX_CFLAGS_COMPILE = "-Wno-error=implicit-int"; + } + // lib.optionalAttrs (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) { + NIX_LDFLAGS = "-headerpad_max_install_names"; + }; dontConfigure = true; diff --git a/pkgs/applications/science/math/mathematica/default.nix b/pkgs/applications/science/math/mathematica/default.nix index 617fd46b050e72..b3dba1b7c6dea2 100644 --- a/pkgs/applications/science/math/mathematica/default.nix +++ b/pkgs/applications/science/math/mathematica/default.nix @@ -1,57 +1,62 @@ -{ callPackage -, config -, lib -, cudaPackages -, cudaSupport ? config.cudaSupport -, lang ? "en" -, webdoc ? false -, version ? null -/* -If you wish to completely override the src, use: -my_mathematica = mathematica.override { - source = pkgs.requireFile { - name = "Mathematica_XX.X.X_BNDL_LINUX.sh"; - # Get this hash via a command similar to this: - # nix-store --query --hash \ - # $(nix store add-path Mathematica_XX.X.X_BNDL_LINUX.sh --name 'Mathematica_XX.X.X_BNDL_LINUX.sh') - sha256 = "0000000000000000000000000000000000000000000000000000"; - message = '' - Your override for Mathematica includes a different src for the installer, - and it is missing. - ''; - hashMode = "recursive"; - }; -} -*/ -, source ? null +{ + callPackage, + config, + lib, + cudaPackages, + cudaSupport ? config.cudaSupport, + lang ? "en", + webdoc ? false, + version ? null, + /* + If you wish to completely override the src, use: + my_mathematica = mathematica.override { + source = pkgs.requireFile { + name = "Mathematica_XX.X.X_BNDL_LINUX.sh"; + # Get this hash via a command similar to this: + # nix-store --query --hash \ + # $(nix store add-path Mathematica_XX.X.X_BNDL_LINUX.sh --name 'Mathematica_XX.X.X_BNDL_LINUX.sh') + sha256 = "0000000000000000000000000000000000000000000000000000"; + message = '' + Your override for Mathematica includes a different src for the installer, + and it is missing. + ''; + hashMode = "recursive"; + }; + } + */ + source ? null, }: -let versions = callPackage ./versions.nix { }; +let + versions = callPackage ./versions.nix { }; - matching-versions = - lib.sort (v1: v2: lib.versionAtLeast v1.version v2.version) (lib.filter - (v: v.lang == lang - && (version == null || isMatching v.version version) - && matchesDoc v) - versions); + matching-versions = lib.sort (v1: v2: lib.versionAtLeast v1.version v2.version) ( + lib.filter ( + v: v.lang == lang && (version == null || isMatching v.version version) && matchesDoc v + ) versions + ); - found-version = - if matching-versions == [] - then throw ("No registered Mathematica version found to match" - + " version=${toString version} and language=${lang}," - + " ${if webdoc - then "using web documentation" - else "and with local documentation"}") - else lib.head matching-versions; + found-version = + if matching-versions == [ ] then + throw ( + "No registered Mathematica version found to match" + + " version=${toString version} and language=${lang}," + + " ${if webdoc then "using web documentation" else "and with local documentation"}" + ) + else + lib.head matching-versions; - isMatching = v1: v2: - let as = lib.splitVersion v1; - bs = lib.splitVersion v2; - n = lib.min (lib.length as) (lib.length bs); - sublist = l: lib.sublist 0 n l; - in lib.compareLists lib.compare (sublist as) (sublist bs) == 0; + isMatching = + v1: v2: + let + as = lib.splitVersion v1; + bs = lib.splitVersion v2; + n = lib.min (lib.length as) (lib.length bs); + sublist = l: lib.sublist 0 n l; + in + lib.compareLists lib.compare (sublist as) (sublist bs) == 0; - matchesDoc = v: (builtins.match ".*[0-9]_LIN(UX)?.sh" v.src.name != null) == webdoc; + matchesDoc = v: (builtins.match ".*[0-9]_LIN(UX)?.sh" v.src.name != null) == webdoc; in @@ -59,16 +64,22 @@ callPackage ./generic.nix { inherit cudaSupport cudaPackages; inherit (found-version) version lang; src = if source == null then found-version.src else source; - name = ("mathematica" - + lib.optionalString cudaSupport "-cuda" - + "-${found-version.version}" - + lib.optionalString (lang != "en") "-${lang}"); + name = ( + "mathematica" + + lib.optionalString cudaSupport "-cuda" + + "-${found-version.version}" + + lib.optionalString (lang != "en") "-${lang}" + ); meta = with lib; { description = "Wolfram Mathematica computational software system"; homepage = "http://www.wolfram.com/mathematica/"; license = licenses.unfree; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - maintainers = with maintainers; [ herberteuler rafaelrc chewblacka ]; + maintainers = with maintainers; [ + herberteuler + rafaelrc + chewblacka + ]; platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/applications/science/math/mathematica/generic.nix b/pkgs/applications/science/math/mathematica/generic.nix index 6bf8992308125e..c734e891f39cdb 100644 --- a/pkgs/applications/science/math/mathematica/generic.nix +++ b/pkgs/applications/science/math/mathematica/generic.nix @@ -1,144 +1,164 @@ -{ addDriverRunpath -, autoPatchelfHook -, lib -, makeWrapper -, requireFile -, runCommand -, stdenv -, symlinkJoin -# arguments from default.nix -, lang -, meta -, name -, src -, version -# dependencies -, alsa-lib -, cudaPackages -, cups -, dbus -, flite -, fontconfig -, freetype -, gcc-unwrapped -, glib -, gmpxx -, keyutils -, libGL -, libGLU -, libpcap -, libtins -, libuuid -, libxkbcommon -, libxml2 -, llvmPackages_12 -, matio -, mpfr -, ncurses -, opencv4 -, openjdk11 -, openssl -, pciutils -, tre -, unixODBC -, xcbutilimage -, xcbutilkeysyms -, xkeyboard_config -, xorg -, zlib -# options -, cudaSupport +{ + addDriverRunpath, + autoPatchelfHook, + lib, + makeWrapper, + requireFile, + runCommand, + stdenv, + symlinkJoin, + # arguments from default.nix + lang, + meta, + name, + src, + version, + # dependencies + alsa-lib, + cudaPackages, + cups, + dbus, + flite, + fontconfig, + freetype, + gcc-unwrapped, + glib, + gmpxx, + keyutils, + libGL, + libGLU, + libpcap, + libtins, + libuuid, + libxkbcommon, + libxml2, + llvmPackages_12, + matio, + mpfr, + ncurses, + opencv4, + openjdk11, + openssl, + pciutils, + tre, + unixODBC, + xcbutilimage, + xcbutilkeysyms, + xkeyboard_config, + xorg, + zlib, + # options + cudaSupport, }: -let cudaEnv = symlinkJoin { - name = "mathematica-cuda-env"; - paths = with cudaPackages; [ - cuda_cudart cuda_nvcc libcublas libcufft libcurand libcusparse - ]; - postBuild = '' - if [ ! -e $out/lib/libcuda.so ]; then - ln -s ${addDriverRunpath.driverLink}/lib/libcuda.so $out/lib - fi - ln -s lib $out/lib64 - ''; - }; - -in stdenv.mkDerivation { - inherit meta name src version; +let + cudaEnv = symlinkJoin { + name = "mathematica-cuda-env"; + paths = with cudaPackages; [ + cuda_cudart + cuda_nvcc + libcublas + libcufft + libcurand + libcusparse + ]; + postBuild = '' + if [ ! -e $out/lib/libcuda.so ]; then + ln -s ${addDriverRunpath.driverLink}/lib/libcuda.so $out/lib + fi + ln -s lib $out/lib64 + ''; + }; + +in +stdenv.mkDerivation { + inherit + meta + name + src + version + ; nativeBuildInputs = [ autoPatchelfHook makeWrapper ] ++ lib.optional cudaSupport addDriverRunpath; - buildInputs = [ - alsa-lib - cups.lib - dbus - flite - fontconfig - freetype - glib - gmpxx - keyutils.lib - libGL - libGLU - libpcap - libtins - libuuid - libxkbcommon - libxml2 - llvmPackages_12.libllvm.lib - matio - mpfr - ncurses - opencv4 - openjdk11 - openssl - pciutils - tre - unixODBC - xcbutilimage - xcbutilkeysyms - xkeyboard_config - ] ++ (with xorg; [ - libICE - libSM - libX11 - libXScrnSaver - libXcomposite - libXcursor - libXdamage - libXext - libXfixes - libXi - libXinerama - libXmu - libXrandr - libXrender - libXtst - libxcb - ]) ++ lib.optional cudaSupport cudaEnv; - - wrapProgramFlags = [ - "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ + buildInputs = + [ + alsa-lib + cups.lib dbus - gcc-unwrapped.lib - zlib - ]}" - "--prefix PATH : ${lib.makeBinPath [ stdenv.cc ]}" - # Fix libQt errors - #96490 - "--set USE_WOLFRAM_LD_LIBRARY_PATH 1" - # Fix xkeyboard config path for Qt - "--set QT_XKB_CONFIG_ROOT ${xkeyboard_config}/share/X11/xkb" - # if wayland isn't supported we fail over to xcb - # see https://github.com/qt/qtbase/blob/35d0f012ee9b95e8cf3563a41d710ff3c023d841/src/gui/kernel/qguiapplication.cpp#L1218 - "--set QT_QPA_PLATFORM wayland;xcb" - ] ++ lib.optionals cudaSupport [ - "--set CUDA_PATH ${cudaEnv}" - "--set NVIDIA_DRIVER_LIBRARY_PATH ${addDriverRunpath.driverLink}/lib/libnvidia-tls.so" - "--set CUDA_LIBRARY_PATH ${addDriverRunpath.driverLink}/lib/libcuda.so" - ]; + flite + fontconfig + freetype + glib + gmpxx + keyutils.lib + libGL + libGLU + libpcap + libtins + libuuid + libxkbcommon + libxml2 + llvmPackages_12.libllvm.lib + matio + mpfr + ncurses + opencv4 + openjdk11 + openssl + pciutils + tre + unixODBC + xcbutilimage + xcbutilkeysyms + xkeyboard_config + ] + ++ (with xorg; [ + libICE + libSM + libX11 + libXScrnSaver + libXcomposite + libXcursor + libXdamage + libXext + libXfixes + libXi + libXinerama + libXmu + libXrandr + libXrender + libXtst + libxcb + ]) + ++ lib.optional cudaSupport cudaEnv; + + wrapProgramFlags = + [ + "--prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + dbus + gcc-unwrapped.lib + zlib + ] + }" + "--prefix PATH : ${lib.makeBinPath [ stdenv.cc ]}" + # Fix libQt errors - #96490 + "--set USE_WOLFRAM_LD_LIBRARY_PATH 1" + # Fix xkeyboard config path for Qt + "--set QT_XKB_CONFIG_ROOT ${xkeyboard_config}/share/X11/xkb" + # if wayland isn't supported we fail over to xcb + # see https://github.com/qt/qtbase/blob/35d0f012ee9b95e8cf3563a41d710ff3c023d841/src/gui/kernel/qguiapplication.cpp#L1218 + "--set QT_QPA_PLATFORM wayland;xcb" + ] + ++ lib.optionals cudaSupport [ + "--set CUDA_PATH ${cudaEnv}" + "--set NVIDIA_DRIVER_LIBRARY_PATH ${addDriverRunpath.driverLink}/lib/libnvidia-tls.so" + "--set CUDA_LIBRARY_PATH ${addDriverRunpath.driverLink}/lib/libcuda.so" + ]; unpackPhase = '' runHook preUnpack diff --git a/pkgs/applications/science/math/mathematica/versions.nix b/pkgs/applications/science/math/mathematica/versions.nix index a88aca6f12a8fa..1fb6003ea25713 100644 --- a/pkgs/applications/science/math/mathematica/versions.nix +++ b/pkgs/applications/science/math/mathematica/versions.nix @@ -1,179 +1,189 @@ { lib, requireFile }: /* - * To calculate the hash of an installer, use a command like this: - * - * nix --extra-experimental-features nix-command hash file - */ + To calculate the hash of an installer, use a command like this: -let versions = [ - { - version = "14.1.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-PCpjwqA6NC+iwvYxddYBlmF5+vl76r+MoIYAL91WFns="; - installer = "Wolfram_14.1.0_LIN.sh"; - } - { - version = "14.1.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-pnu60Pv3xo3+MAkDLiU3yTPVbbQ00diV45vSVL8B310="; - installer = "Wolfram_14.1.0_LIN_Bndl.sh"; - } - { - version = "14.0.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-NzMhGQZq6o6V4UdtJxUH/yyP2s7wjTR86SRA7lW7JfI="; - installer = "Mathematica_14.0.0_LINUX.sh"; - } - { - version = "14.0.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-UrcBEg6G6nbVX++X0z0oG5JjieXL0AquAqtjzY5EBn4="; - installer = "Mathematica_14.0.0_BNDL_LINUX.sh"; - } - { - version = "13.3.1"; - lang = "en"; - language = "English"; - sha256 = "sha256-0+mYVGiF4Qn3eiLIoINSHVIqT8GtlBPFRYIOF+nHyQo="; - installer = "Mathematica_13.3.1_LINUX.sh"; - } - { - version = "13.3.1"; - lang = "en"; - language = "English"; - sha256 = "sha256-03R4s05fmTcZnlZIMSI6xlLER58MIoccoCr27F8BXOk="; - installer = "Mathematica_13.3.1_BNDL_LINUX.sh"; - } - { - version = "13.3.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-24MC0O+kBUe3TrwXUb+7QZt8tQHvWVIT8F9B6Ih+4k8="; - installer = "Mathematica_13.3.0_LINUX.sh"; - } - { - version = "13.3.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-91bw7+4ht+7g+eF32BNYf77yEQWyuPffisj4kB63pcI="; - installer = "Mathematica_13.3.0_BNDL_LINUX.sh"; - } - { - version = "13.2.1"; - lang = "en"; - language = "English"; - sha256 = "sha256-GA2k+jvE4mTJsIbMHce5c516h/glHLnXdthEfnNmk0w="; - installer = "Mathematica_13.2.1_LINUX.sh"; - } - { - version = "13.2.1"; - lang = "en"; - language = "English"; - sha256 = "sha256-ZvgG2W/gjQIo4hyXHsGta5FyTslrz/ltOe/ZK/U2Sx8="; - installer = "Mathematica_13.2.1_BNDL_LINUX.sh"; - } - { - version = "13.2.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-T9XOXA6jpgN6bcO/do9sw1L73ABtyxuZCLzftv4Cl6o="; - installer = "Mathematica_13.2.0_LINUX.sh"; - } - { - version = "13.2.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-YRUvl2H9SwpwDZx04ugd7ZnK5G+t88bzAObXsGGVhk0="; - installer = "Mathematica_13.2.0_BNDL_LINUX.sh"; - } - { - version = "13.1.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-GZyUYslx/M4aFI3Pj9Osw3/w79/Jp/4T3mRE277pNuM="; - installer = "Mathematica_13.1.0_LINUX.sh"; - } - { - version = "13.1.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-LIpGAJ3uTkZgjc0YykwusyyHQKlCnTvrZGStFfSOz60="; - installer = "Mathematica_13.1.0_BNDL_LINUX.sh"; - } - { - version = "13.0.1"; - lang = "en"; - language = "English"; - sha256 = "sha256-NnKpIMG0rxr9SAcz9tZ2Zbr4JYdX3+WabtbXRAzybbo="; - installer = "Mathematica_13.0.1_BNDL_LINUX.sh"; - } - { - version = "13.0.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-FbutOaWZUDEyXR0Xj2OwDnFwbT7JAB66bRaB+8mR0+E="; - installer = "Mathematica_13.0.0_BNDL_LINUX.sh"; - } - { - version = "12.3.1"; - lang = "en"; - language = "English"; - sha256 = "sha256-UbnKsS/ZGwCep61JaKLIpZ6U3FXS5swdcSrNW6LE1Qk="; - installer = "Mathematica_12.3.1_LINUX.sh"; - } - { - version = "12.3.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-BF3wRfbnlt7Vn2TrLg8ZSayI3LodW24F+1PqCkrtchU="; - installer = "Mathematica_12.3.0_LINUX.sh"; - } - { - version = "12.2.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-O2Z2ogPGrbfpxBilSEsDeXQoe1vgnGTn3+p03cDkANc="; - installer = "Mathematica_12.2.0_LINUX.sh"; - } - { - version = "12.1.1"; - lang = "en"; - language = "English"; - sha256 = "sha256-rUe4hr5KmGTXD1I/eSYVoFHU68mH2aD2VLZFtOtDswo="; - installer = "Mathematica_12.1.1_LINUX.sh"; - } - { - version = "12.1.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-56P1KKOTJkQj+K9wppAsnYpej/YB3VUNL7DPLYGgqZY="; - installer = "Mathematica_12.1.0_LINUX.sh"; - } - { - version = "12.0.0"; - lang = "en"; - language = "English"; - sha256 = "sha256-uftx4a/MHXLCABlv+kNFEtII+ikg4geHhDP1BOWK6dc="; - installer = "Mathematica_12.0.0_LINUX.sh"; - } -]; + nix --extra-experimental-features nix-command hash file +*/ + +let + versions = [ + { + version = "14.1.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-PCpjwqA6NC+iwvYxddYBlmF5+vl76r+MoIYAL91WFns="; + installer = "Wolfram_14.1.0_LIN.sh"; + } + { + version = "14.1.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-pnu60Pv3xo3+MAkDLiU3yTPVbbQ00diV45vSVL8B310="; + installer = "Wolfram_14.1.0_LIN_Bndl.sh"; + } + { + version = "14.0.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-NzMhGQZq6o6V4UdtJxUH/yyP2s7wjTR86SRA7lW7JfI="; + installer = "Mathematica_14.0.0_LINUX.sh"; + } + { + version = "14.0.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-UrcBEg6G6nbVX++X0z0oG5JjieXL0AquAqtjzY5EBn4="; + installer = "Mathematica_14.0.0_BNDL_LINUX.sh"; + } + { + version = "13.3.1"; + lang = "en"; + language = "English"; + sha256 = "sha256-0+mYVGiF4Qn3eiLIoINSHVIqT8GtlBPFRYIOF+nHyQo="; + installer = "Mathematica_13.3.1_LINUX.sh"; + } + { + version = "13.3.1"; + lang = "en"; + language = "English"; + sha256 = "sha256-03R4s05fmTcZnlZIMSI6xlLER58MIoccoCr27F8BXOk="; + installer = "Mathematica_13.3.1_BNDL_LINUX.sh"; + } + { + version = "13.3.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-24MC0O+kBUe3TrwXUb+7QZt8tQHvWVIT8F9B6Ih+4k8="; + installer = "Mathematica_13.3.0_LINUX.sh"; + } + { + version = "13.3.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-91bw7+4ht+7g+eF32BNYf77yEQWyuPffisj4kB63pcI="; + installer = "Mathematica_13.3.0_BNDL_LINUX.sh"; + } + { + version = "13.2.1"; + lang = "en"; + language = "English"; + sha256 = "sha256-GA2k+jvE4mTJsIbMHce5c516h/glHLnXdthEfnNmk0w="; + installer = "Mathematica_13.2.1_LINUX.sh"; + } + { + version = "13.2.1"; + lang = "en"; + language = "English"; + sha256 = "sha256-ZvgG2W/gjQIo4hyXHsGta5FyTslrz/ltOe/ZK/U2Sx8="; + installer = "Mathematica_13.2.1_BNDL_LINUX.sh"; + } + { + version = "13.2.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-T9XOXA6jpgN6bcO/do9sw1L73ABtyxuZCLzftv4Cl6o="; + installer = "Mathematica_13.2.0_LINUX.sh"; + } + { + version = "13.2.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-YRUvl2H9SwpwDZx04ugd7ZnK5G+t88bzAObXsGGVhk0="; + installer = "Mathematica_13.2.0_BNDL_LINUX.sh"; + } + { + version = "13.1.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-GZyUYslx/M4aFI3Pj9Osw3/w79/Jp/4T3mRE277pNuM="; + installer = "Mathematica_13.1.0_LINUX.sh"; + } + { + version = "13.1.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-LIpGAJ3uTkZgjc0YykwusyyHQKlCnTvrZGStFfSOz60="; + installer = "Mathematica_13.1.0_BNDL_LINUX.sh"; + } + { + version = "13.0.1"; + lang = "en"; + language = "English"; + sha256 = "sha256-NnKpIMG0rxr9SAcz9tZ2Zbr4JYdX3+WabtbXRAzybbo="; + installer = "Mathematica_13.0.1_BNDL_LINUX.sh"; + } + { + version = "13.0.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-FbutOaWZUDEyXR0Xj2OwDnFwbT7JAB66bRaB+8mR0+E="; + installer = "Mathematica_13.0.0_BNDL_LINUX.sh"; + } + { + version = "12.3.1"; + lang = "en"; + language = "English"; + sha256 = "sha256-UbnKsS/ZGwCep61JaKLIpZ6U3FXS5swdcSrNW6LE1Qk="; + installer = "Mathematica_12.3.1_LINUX.sh"; + } + { + version = "12.3.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-BF3wRfbnlt7Vn2TrLg8ZSayI3LodW24F+1PqCkrtchU="; + installer = "Mathematica_12.3.0_LINUX.sh"; + } + { + version = "12.2.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-O2Z2ogPGrbfpxBilSEsDeXQoe1vgnGTn3+p03cDkANc="; + installer = "Mathematica_12.2.0_LINUX.sh"; + } + { + version = "12.1.1"; + lang = "en"; + language = "English"; + sha256 = "sha256-rUe4hr5KmGTXD1I/eSYVoFHU68mH2aD2VLZFtOtDswo="; + installer = "Mathematica_12.1.1_LINUX.sh"; + } + { + version = "12.1.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-56P1KKOTJkQj+K9wppAsnYpej/YB3VUNL7DPLYGgqZY="; + installer = "Mathematica_12.1.0_LINUX.sh"; + } + { + version = "12.0.0"; + lang = "en"; + language = "English"; + sha256 = "sha256-uftx4a/MHXLCABlv+kNFEtII+ikg4geHhDP1BOWK6dc="; + installer = "Mathematica_12.0.0_LINUX.sh"; + } + ]; in -lib.flip map versions ({ version, lang, language, sha256, installer }: { - inherit version lang; - src = requireFile { - name = installer; - message = '' - This nix expression requires that ${installer} is - already part of the store. Find the file on your Mathematica CD - and add it to the nix store with nix-store --add-fixed sha256 . - ''; - inherit sha256; - }; -}) +lib.flip map versions ( + { + version, + lang, + language, + sha256, + installer, + }: + { + inherit version lang; + src = requireFile { + name = installer; + message = '' + This nix expression requires that ${installer} is + already part of the store. Find the file on your Mathematica CD + and add it to the nix store with nix-store --add-fixed sha256 . + ''; + inherit sha256; + }; + } +) diff --git a/pkgs/applications/science/math/maxima/default.nix b/pkgs/applications/science/math/maxima/default.nix index c1458186b2ae1c..cf6f2f3bb25b31 100644 --- a/pkgs/applications/science/math/maxima/default.nix +++ b/pkgs/applications/science/math/maxima/default.nix @@ -1,22 +1,29 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, texinfo -, perl -, python3 -, makeWrapper -, autoreconfHook -, rlwrap ? null -, tk ? null -, gnuplot ? null -, lisp-compiler +{ + lib, + stdenv, + fetchurl, + fetchpatch, + texinfo, + perl, + python3, + makeWrapper, + autoreconfHook, + rlwrap ? null, + tk ? null, + gnuplot ? null, + lisp-compiler, }: let # Allow to remove some executables from the $PATH of the wrapped binary - searchPath = lib.makeBinPath - (lib.filter (x: x != null) [ lisp-compiler rlwrap tk gnuplot ]); + searchPath = lib.makeBinPath ( + lib.filter (x: x != null) [ + lisp-compiler + rlwrap + tk + gnuplot + ] + ); in stdenv.mkDerivation (finalAttrs: { pname = "maxima"; @@ -45,20 +52,20 @@ stdenv.mkDerivation (finalAttrs: { substituteInPlace doc/info/Makefile.am --replace "/usr/bin/env perl" "${perl}/bin/perl" ''; - postInstall = '' - # Make sure that maxima can find its runtime dependencies. - for prog in "$out/bin/"*; do - wrapProgram "$prog" --prefix PATH ":" "$out/bin:${searchPath}" - done - # Move emacs modules and documentation into the right place. - mkdir -p $out/share/emacs $out/share/doc - ln -s ../maxima/${finalAttrs.version}/emacs $out/share/emacs/site-lisp - ln -s ../maxima/${finalAttrs.version}/doc $out/share/doc/maxima - '' - + (lib.optionalString (lisp-compiler.pname == "ecl") '' - cp src/binary-ecl/maxima.fas* "$out/lib/maxima/${finalAttrs.version}/binary-ecl/" - '') - ; + postInstall = + '' + # Make sure that maxima can find its runtime dependencies. + for prog in "$out/bin/"*; do + wrapProgram "$prog" --prefix PATH ":" "$out/bin:${searchPath}" + done + # Move emacs modules and documentation into the right place. + mkdir -p $out/share/emacs $out/share/doc + ln -s ../maxima/${finalAttrs.version}/emacs $out/share/emacs/site-lisp + ln -s ../maxima/${finalAttrs.version}/doc $out/share/doc/maxima + '' + + (lib.optionalString (lisp-compiler.pname == "ecl") '' + cp src/binary-ecl/maxima.fas* "$out/lib/maxima/${finalAttrs.version}/binary-ecl/" + ''); patches = [ # fix path to info dir (see https://trac.sagemath.org/ticket/11348) @@ -95,7 +102,7 @@ stdenv.mkDerivation (finalAttrs: { # # These failures don't look serious. It would be nice to fix them, but I # don't know how and probably won't have the time to find out. - doCheck = false; # try to re-enable after next version update + doCheck = false; # try to re-enable after next version update enableParallelBuilding = true; diff --git a/pkgs/applications/science/math/mxnet/default.nix b/pkgs/applications/science/math/mxnet/default.nix index 880caaff5afb6e..50576390ee02e4 100644 --- a/pkgs/applications/science/math/mxnet/default.nix +++ b/pkgs/applications/science/math/mxnet/default.nix @@ -1,11 +1,30 @@ -{ config, stdenv, lib, fetchurl, fetchpatch, bash, cmake -, opencv4, gtest, blas, gomp, llvmPackages, perl -, cudaSupport ? config.cudaSupport, cudaPackages ? { }, nvidia_x11 -, cudnnSupport ? cudaSupport +{ + config, + stdenv, + lib, + fetchurl, + fetchpatch, + bash, + cmake, + opencv4, + gtest, + blas, + gomp, + llvmPackages, + perl, + cudaSupport ? config.cudaSupport, + cudaPackages ? { }, + nvidia_x11, + cudnnSupport ? cudaSupport, }: let - inherit (cudaPackages) backendStdenv cudatoolkit cudaFlags cudnn; + inherit (cudaPackages) + backendStdenv + cudatoolkit + cudaFlags + cudnn + ; in assert cudnnSupport -> cudaSupport; @@ -30,28 +49,44 @@ stdenv.mkDerivation rec { (fetchpatch { name = "2-auto-disable-sse-for-non-x86.patch"; url = "https://github.com/apache/incubator-mxnet/commit/c1b96f562f55dfa024ac941d7b104f00e239ee0f.patch"; - excludes = ["ci/docker/runtime_functions.sh"]; + excludes = [ "ci/docker/runtime_functions.sh" ]; hash = "sha256-r1LbC8ueRooW5tTNakAlRSJ+9aR4WXXoEKx895DgOs4="; }) ]; - nativeBuildInputs = [ cmake perl ]; + nativeBuildInputs = [ + cmake + perl + ]; - buildInputs = [ opencv4 gtest blas.provider ] + buildInputs = + [ + opencv4 + gtest + blas.provider + ] ++ lib.optional stdenv.cc.isGNU gomp ++ lib.optional stdenv.cc.isClang llvmPackages.openmp # FIXME: when cuda build is fixed, remove nvidia_x11, and use /run/opengl-driver/lib - ++ lib.optionals cudaSupport [ cudatoolkit nvidia_x11 ] + ++ lib.optionals cudaSupport [ + cudatoolkit + nvidia_x11 + ] ++ lib.optional cudnnSupport cudnn; cmakeFlags = [ "-DUSE_MKL_IF_AVAILABLE=OFF" ] - ++ (if cudaSupport then [ - "-DUSE_OLDCMAKECUDA=ON" # see https://github.com/apache/incubator-mxnet/issues/10743 - "-DCUDA_ARCH_NAME=All" - "-DCUDA_HOST_COMPILER=${backendStdenv.cc}/bin/cc" - "-DMXNET_CUDA_ARCH=${builtins.concatStringsSep ";" cudaFlags.realArches}" - ] else [ "-DUSE_CUDA=OFF" ]) + ++ ( + if cudaSupport then + [ + "-DUSE_OLDCMAKECUDA=ON" # see https://github.com/apache/incubator-mxnet/issues/10743 + "-DCUDA_ARCH_NAME=All" + "-DCUDA_HOST_COMPILER=${backendStdenv.cc}/bin/cc" + "-DMXNET_CUDA_ARCH=${builtins.concatStringsSep ";" cudaFlags.realArches}" + ] + else + [ "-DUSE_CUDA=OFF" ] + ) ++ lib.optional (!cudnnSupport) "-DUSE_CUDNN=OFF"; env.NIX_CFLAGS_COMPILE = toString [ @@ -75,7 +110,12 @@ stdenv.mkDerivation rec { # used to mark cudaSupport in python310Packages.mxnet as broken; # other attributes exposed for consistency passthru = { - inherit cudaSupport cudnnSupport cudatoolkit cudnn; + inherit + cudaSupport + cudnnSupport + cudatoolkit + cudnn + ; }; meta = with lib; { diff --git a/pkgs/applications/science/math/nota/default.nix b/pkgs/applications/science/math/nota/default.nix index 3a98eacd47171d..10a6ec30cb33c5 100644 --- a/pkgs/applications/science/math/nota/default.nix +++ b/pkgs/applications/science/math/nota/default.nix @@ -1,4 +1,9 @@ -{ mkDerivation, haskellPackages, fetchurl, lib }: +{ + mkDerivation, + haskellPackages, + fetchurl, + lib, +}: mkDerivation rec { pname = "nota"; diff --git a/pkgs/applications/science/math/pari/gp2c.nix b/pkgs/applications/science/math/pari/gp2c.nix index 37a671e75cd5d1..935a52934a9a4a 100644 --- a/pkgs/applications/science/math/pari/gp2c.nix +++ b/pkgs/applications/science/math/pari/gp2c.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, pari -, perl +{ + lib, + stdenv, + fetchurl, + pari, + perl, }: stdenv.mkDerivation rec { @@ -26,8 +27,13 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "http://pari.math.u-bordeaux.fr/"; - description = "Compiler to translate GP scripts to PARI programs"; + description = "Compiler to translate GP scripts to PARI programs"; downloadPage = "http://pari.math.u-bordeaux.fr/download.html"; - inherit (pari.meta) license maintainers platforms broken; + inherit (pari.meta) + license + maintainers + platforms + broken + ; }; } diff --git a/pkgs/applications/science/math/qalculate-qt/default.nix b/pkgs/applications/science/math/qalculate-qt/default.nix index fcaf46fbb92b62..2f6992de692743 100644 --- a/pkgs/applications/science/math/qalculate-qt/default.nix +++ b/pkgs/applications/science/math/qalculate-qt/default.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, intltool, pkg-config, qmake, wrapQtAppsHook, libqalculate, qtbase, qttools, qtsvg, qtwayland }: +{ + lib, + stdenv, + fetchFromGitHub, + intltool, + pkg-config, + qmake, + wrapQtAppsHook, + libqalculate, + qtbase, + qttools, + qtsvg, + qtwayland, +}: stdenv.mkDerivation (finalAttrs: { pname = "qalculate-qt"; @@ -11,9 +24,18 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-Tpb/ZN5p3JfPug9NpBHguOi6Okek+g87orD4ISkV+ac="; }; - nativeBuildInputs = [ qmake intltool pkg-config qttools wrapQtAppsHook ]; - buildInputs = [ libqalculate qtbase qtsvg ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ qtwayland ]; + nativeBuildInputs = [ + qmake + intltool + pkg-config + qttools + wrapQtAppsHook + ]; + buildInputs = [ + libqalculate + qtbase + qtsvg + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ qtwayland ]; postPatch = '' substituteInPlace qalculate-qt.pro\ diff --git a/pkgs/applications/science/math/speedcrunch/default.nix b/pkgs/applications/science/math/speedcrunch/default.nix index ed7339ab567750..e2c7760d7a624a 100644 --- a/pkgs/applications/science/math/speedcrunch/default.nix +++ b/pkgs/applications/science/math/speedcrunch/default.nix @@ -1,4 +1,12 @@ -{ stdenv, mkDerivation, lib, fetchFromBitbucket, cmake, qtbase, qttools }: +{ + stdenv, + mkDerivation, + lib, + fetchFromBitbucket, + cmake, + qtbase, + qttools, +}: mkDerivation rec { pname = "speedcrunch"; @@ -11,7 +19,10 @@ mkDerivation rec { sha256 = "sha256-XxQv+A5SfYXFIRK7yacxGHHne1Q93pwCGeHhchIKizU="; }; - buildInputs = [ qtbase qttools ]; + buildInputs = [ + qtbase + qttools + ]; nativeBuildInputs = [ cmake ]; @@ -20,8 +31,8 @@ mkDerivation rec { ''; meta = with lib; { - homepage = "http://speedcrunch.org"; - license = licenses.gpl2Plus; + homepage = "http://speedcrunch.org"; + license = licenses.gpl2Plus; description = "Fast power user calculator"; mainProgram = "speedcrunch"; longDescription = '' @@ -30,7 +41,10 @@ mkDerivation rec { precisions, unlimited variable storage, intelligent automatic completion full keyboard-friendly and more than 15 built-in math function. ''; - maintainers = with maintainers; [ gebner j0hax ]; + maintainers = with maintainers; [ + gebner + j0hax + ]; inherit (qtbase.meta) platforms; broken = stdenv.hostPlatform.isDarwin; }; diff --git a/pkgs/applications/science/math/weka/default.nix b/pkgs/applications/science/math/weka/default.nix index 6f907ba9c0c391..57f3bd1a1100c8 100644 --- a/pkgs/applications/science/math/weka/default.nix +++ b/pkgs/applications/science/math/weka/default.nix @@ -1,15 +1,25 @@ -{ lib, stdenv, fetchurl, jre, unzip, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + unzip, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "weka"; version = "3.9.6"; src = fetchurl { - url = "mirror://sourceforge/weka/${lib.replaceStrings ["."]["-"] "${pname}-${version}"}.zip"; + url = "mirror://sourceforge/weka/${lib.replaceStrings [ "." ] [ "-" ] "${pname}-${version}"}.zip"; sha256 = "sha256-8fVN4MXYqXNEmyVtXh1IrauHTBZWgWG8AvsGI5Y9Aj0="; }; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; # The -Xmx1000M comes suggested from their download page: # https://www.cs.waikato.ac.nz/ml/weka/downloading.html diff --git a/pkgs/applications/science/math/wolfram-engine/default.nix b/pkgs/applications/science/math/wolfram-engine/default.nix index 5eff7513953ca8..bd3d9fbf769ce2 100644 --- a/pkgs/applications/science/math/wolfram-engine/default.nix +++ b/pkgs/applications/science/math/wolfram-engine/default.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, autoPatchelfHook -, requireFile -, alsa-lib -, dbus -, fontconfig -, freetype -, gcc -, glib -, installShellFiles -, libssh2 -, ncurses -, opencv4 -, openssl -, unixODBC -, xkeyboard_config -, xorg -, zlib -, libxml2 -, libuuid -, lang ? "en" -, libGL -, libGLU -, wrapQtAppsHook +{ + lib, + stdenv, + autoPatchelfHook, + requireFile, + alsa-lib, + dbus, + fontconfig, + freetype, + gcc, + glib, + installShellFiles, + libssh2, + ncurses, + opencv4, + openssl, + unixODBC, + xkeyboard_config, + xorg, + zlib, + libxml2, + libuuid, + lang ? "en", + libGL, + libGLU, + wrapQtAppsHook, }: let @@ -42,47 +43,51 @@ stdenv.mkDerivation rec { ]; dontWrapQtApps = true; - buildInputs = [ - alsa-lib - dbus - fontconfig - freetype - gcc.cc - gcc.libc - glib - libssh2 - ncurses - opencv4 - openssl - (lib.getLib stdenv.cc.cc) - unixODBC - xkeyboard_config - libxml2 - libuuid - zlib - libGL - libGLU - ] ++ (with xorg; [ - libX11 - libXext - libXtst - libXi - libXmu - libXrender - libxcb - libXcursor - libXfixes - libXrandr - libICE - libSM - ]); + buildInputs = + [ + alsa-lib + dbus + fontconfig + freetype + gcc.cc + gcc.libc + glib + libssh2 + ncurses + opencv4 + openssl + (lib.getLib stdenv.cc.cc) + unixODBC + xkeyboard_config + libxml2 + libuuid + zlib + libGL + libGLU + ] + ++ (with xorg; [ + libX11 + libXext + libXtst + libXi + libXmu + libXrender + libxcb + libXcursor + libXfixes + libXrandr + libICE + libSM + ]); # some bundled libs are found through LD_LIBRARY_PATH autoPatchelfIgnoreMissingDeps = true; - ldpath = lib.makeLibraryPath buildInputs - + lib.optionalString (stdenv.hostPlatform.system == "x86_64-linux") - (":" + lib.makeSearchPathOutput "lib" "lib64" buildInputs); + ldpath = + lib.makeLibraryPath buildInputs + + lib.optionalString (stdenv.hostPlatform.system == "x86_64-linux") ( + ":" + lib.makeSearchPathOutput "lib" "lib64" buildInputs + ); unpackPhase = '' # find offset from file diff --git a/pkgs/applications/science/math/wolfram-engine/l10ns.nix b/pkgs/applications/science/math/wolfram-engine/l10ns.nix index de9b677ab17a45..b362e6de059450 100644 --- a/pkgs/applications/science/math/wolfram-engine/l10ns.nix +++ b/pkgs/applications/science/math/wolfram-engine/l10ns.nix @@ -1,77 +1,88 @@ -{ lib -, requireFile -, lang -, majorVersion ? null +{ + lib, + requireFile, + lang, + majorVersion ? null, }: -let allVersions = lib.flip map - # N.B. Versions in this list should be ordered from newest to oldest. - [ - { - version = "14.1.0"; - lang = "en"; - language = "English"; - sha256 = "1kxdvm3i7nn3ws784y972h2br1n0y82kkkjvz7c5llssv6d3pgj8"; - installer = "WolframEngine_14.1.0_LIN.sh"; - } - { - version = "13.3.0"; - lang = "en"; - language = "English"; - sha256 = "96106ac8ed6d0e221a68d846117615c14025320f927e5e0ed95b1965eda68e31"; - installer = "WolframEngine_13.3.0_LINUX.sh"; - } - { - version = "13.2.0"; - lang = "en"; - language = "English"; - sha256 = "1xvg1n64iq52jxnk9y551m5iwkkz6cxzwyw28h8d0kq36aaiky24"; - installer = "WolframEngine_13.2.0_LINUX.sh"; - } - { - version = "13.1.0"; - lang = "en"; - language = "English"; - sha256 = "1659kyp38a8xknic95pynx9fsgn96i8jn9lnk89pc8n6vydw1460"; - installer = "WolframEngine_13.1.0_LINUX.sh"; - } - { - version = "13.0.1"; - lang = "en"; - language = "English"; - sha256 = "1rrxi7d51m02407k719fq829jzanh550wr810i22n3irhk8axqga"; - installer = "WolframEngine_13.0.1_LINUX.sh"; - } - { - version = "13.0.0"; - lang = "en"; - language = "English"; - sha256 = "10cpwllz9plxz22iqdh6xgkxqphl9s9nq8ax16pafjll6j9kqy1q"; - installer = "WolframEngine_13.0.0_LINUX.sh"; - } - ] - ({ version, lang, language, sha256, installer }: { - inherit version lang; - name = "wolfram-engine-${version}" + lib.optionalString (lang != "en") "-${lang}"; - src = requireFile { - name = installer; - message = '' - This nix expression requires that ${installer} is - already part of the store. Download the file from - https://www.wolfram.com/engine/ and add it to the nix store - with nix-store --add-fixed sha256 . - ''; - inherit sha256; - }; - }); -minVersion = - if majorVersion == null - then lib.elemAt (builtins.splitVersion (lib.elemAt allVersions 0).version) 0 - else majorVersion; -maxVersion = toString (1 + builtins.fromJSON minVersion); +let + allVersions = + lib.flip map + # N.B. Versions in this list should be ordered from newest to oldest. + [ + { + version = "14.1.0"; + lang = "en"; + language = "English"; + sha256 = "1kxdvm3i7nn3ws784y972h2br1n0y82kkkjvz7c5llssv6d3pgj8"; + installer = "WolframEngine_14.1.0_LIN.sh"; + } + { + version = "13.3.0"; + lang = "en"; + language = "English"; + sha256 = "96106ac8ed6d0e221a68d846117615c14025320f927e5e0ed95b1965eda68e31"; + installer = "WolframEngine_13.3.0_LINUX.sh"; + } + { + version = "13.2.0"; + lang = "en"; + language = "English"; + sha256 = "1xvg1n64iq52jxnk9y551m5iwkkz6cxzwyw28h8d0kq36aaiky24"; + installer = "WolframEngine_13.2.0_LINUX.sh"; + } + { + version = "13.1.0"; + lang = "en"; + language = "English"; + sha256 = "1659kyp38a8xknic95pynx9fsgn96i8jn9lnk89pc8n6vydw1460"; + installer = "WolframEngine_13.1.0_LINUX.sh"; + } + { + version = "13.0.1"; + lang = "en"; + language = "English"; + sha256 = "1rrxi7d51m02407k719fq829jzanh550wr810i22n3irhk8axqga"; + installer = "WolframEngine_13.0.1_LINUX.sh"; + } + { + version = "13.0.0"; + lang = "en"; + language = "English"; + sha256 = "10cpwllz9plxz22iqdh6xgkxqphl9s9nq8ax16pafjll6j9kqy1q"; + installer = "WolframEngine_13.0.0_LINUX.sh"; + } + ] + ( + { + version, + lang, + language, + sha256, + installer, + }: + { + inherit version lang; + name = "wolfram-engine-${version}" + lib.optionalString (lang != "en") "-${lang}"; + src = requireFile { + name = installer; + message = '' + This nix expression requires that ${installer} is + already part of the store. Download the file from + https://www.wolfram.com/engine/ and add it to the nix store + with nix-store --add-fixed sha256 . + ''; + inherit sha256; + }; + } + ); + minVersion = + if majorVersion == null then + lib.elemAt (builtins.splitVersion (lib.elemAt allVersions 0).version) 0 + else + majorVersion; + maxVersion = toString (1 + builtins.fromJSON minVersion); in -lib.findFirst (l: (l.lang == lang - && l.version >= minVersion - && l.version < maxVersion)) - (throw "Version ${minVersion} in language ${lang} not supported") - allVersions +lib.findFirst ( + l: (l.lang == lang && l.version >= minVersion && l.version < maxVersion) +) (throw "Version ${minVersion} in language ${lang} not supported") allVersions diff --git a/pkgs/applications/science/math/wolfram-engine/notebook.nix b/pkgs/applications/science/math/wolfram-engine/notebook.nix index 07cd0afa3099d6..cf55dade56cb3d 100644 --- a/pkgs/applications/science/math/wolfram-engine/notebook.nix +++ b/pkgs/applications/science/math/wolfram-engine/notebook.nix @@ -1,9 +1,18 @@ -{ stdenv, writeScriptBin, jupyter, wolfram-for-jupyter-kernel }: +{ + stdenv, + writeScriptBin, + jupyter, + wolfram-for-jupyter-kernel, +}: let - wolfram-jupyter = jupyter.override { definitions = { wolfram = wolfram-for-jupyter-kernel.definition; }; }; + wolfram-jupyter = jupyter.override { + definitions = { + wolfram = wolfram-for-jupyter-kernel.definition; + }; + }; in - writeScriptBin "wolfram-notebook" '' - #! ${stdenv.shell} - ${wolfram-jupyter}/bin/jupyter-notebook - '' +writeScriptBin "wolfram-notebook" '' + #! ${stdenv.shell} + ${wolfram-jupyter}/bin/jupyter-notebook +'' diff --git a/pkgs/applications/science/math/wxmaxima/default.nix b/pkgs/applications/science/math/wxmaxima/default.nix index 048389d80b5c28..bb363c9f537afb 100644 --- a/pkgs/applications/science/math/wxmaxima/default.nix +++ b/pkgs/applications/science/math/wxmaxima/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, wrapGAppsHook3 -, cmake -, gettext -, maxima -, wxGTK -, adwaita-icon-theme -, glib +{ + lib, + stdenv, + fetchFromGitHub, + wrapGAppsHook3, + cmake, + gettext, + maxima, + wxGTK, + adwaita-icon-theme, + glib, }: -stdenv.mkDerivation (finalAttrs:{ +stdenv.mkDerivation (finalAttrs: { pname = "wxmaxima"; version = "24.11.0"; diff --git a/pkgs/applications/science/math/yacas/default.nix b/pkgs/applications/science/math/yacas/default.nix index ad4e3f37d07ff1..26744a19f86f51 100644 --- a/pkgs/applications/science/math/yacas/default.nix +++ b/pkgs/applications/science/math/yacas/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, perl -, enableGui ? false -, qtbase -, wrapQtAppsHook -, qtwebengine -, enableJupyter ? true -, boost -, jsoncpp -, openssl -, zmqpp -, enableJava ? false -, openjdk -, gtest +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + perl, + enableGui ? false, + qtbase, + wrapQtAppsHook, + qtwebengine, + enableJupyter ? true, + boost, + jsoncpp, + openssl, + zmqpp, + enableJava ? false, + openjdk, + gtest, }: stdenv.mkDerivation rec { @@ -57,24 +58,29 @@ stdenv.mkDerivation rec { ]; doCheck = true; - nativeBuildInputs = [ - cmake - # Perl is only for the documentation - perl - ] ++ lib.optionals enableJava [ - openjdk - ]; - buildInputs = [ - ] ++ lib.optionals enableGui [ - qtbase - wrapQtAppsHook - qtwebengine - ] ++ lib.optionals enableJupyter [ - boost - jsoncpp - openssl - zmqpp - ]; + nativeBuildInputs = + [ + cmake + # Perl is only for the documentation + perl + ] + ++ lib.optionals enableJava [ + openjdk + ]; + buildInputs = + [ + ] + ++ lib.optionals enableGui [ + qtbase + wrapQtAppsHook + qtwebengine + ] + ++ lib.optionals enableJupyter [ + boost + jsoncpp + openssl + zmqpp + ]; meta = { description = "Easy to use, general purpose Computer Algebra System${lib.optionalString enableGui ", built with GUI."}"; diff --git a/pkgs/applications/science/misc/boinc/default.nix b/pkgs/applications/science/misc/boinc/default.nix index b8b57857c02aaa..28ee8e6bbe1e01 100644 --- a/pkgs/applications/science/misc/boinc/default.nix +++ b/pkgs/applications/science/misc/boinc/default.nix @@ -1,28 +1,29 @@ -{ fetchFromGitHub -, lib -, stdenv -, autoconf -, automake -, pkg-config -, m4 -, curl -, libGLU -, libGL -, libXmu -, libXi -, libglut -, libjpeg -, libtool -, wxGTK32 -, xcbutil -, sqlite -, gtk3 -, patchelf -, libXScrnSaver -, libnotify -, libX11 -, libxcb -, headless ? false +{ + fetchFromGitHub, + lib, + stdenv, + autoconf, + automake, + pkg-config, + m4, + curl, + libGLU, + libGL, + libXmu, + libXi, + libglut, + libjpeg, + libtool, + wxGTK32, + xcbutil, + sqlite, + gtk3, + patchelf, + libXScrnSaver, + libnotify, + libX11, + libxcb, + headless ? false, }: stdenv.mkDerivation rec { @@ -37,28 +38,36 @@ stdenv.mkDerivation rec { hash = "sha256-dp0zRMIG0PGXhth+Cc8FDhzl5X/4ud3GFCdE7wqPL/c="; }; - nativeBuildInputs = [ libtool automake autoconf m4 pkg-config ]; - - buildInputs = [ - curl - sqlite - patchelf - ] ++ lib.optionals (!headless) [ - libGLU - libGL - libXmu - libXi - libglut - libjpeg - wxGTK32 - gtk3 - libXScrnSaver - libnotify - libX11 - libxcb - xcbutil + nativeBuildInputs = [ + libtool + automake + autoconf + m4 + pkg-config ]; + buildInputs = + [ + curl + sqlite + patchelf + ] + ++ lib.optionals (!headless) [ + libGLU + libGL + libXmu + libXi + libglut + libjpeg + wxGTK32 + gtk3 + libXScrnSaver + libnotify + libX11 + libxcb + xcbutil + ]; + NIX_LDFLAGS = lib.optionalString (!headless) "-lX11"; preConfigure = '' diff --git a/pkgs/applications/science/misc/convertall/default.nix b/pkgs/applications/science/misc/convertall/default.nix index 534562b028d89f..703bb5b3221e33 100644 --- a/pkgs/applications/science/misc/convertall/default.nix +++ b/pkgs/applications/science/misc/convertall/default.nix @@ -1,8 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, python3, wrapQtAppsHook }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + wrapQtAppsHook, +}: let inherit (python3.pkgs) wrapPython pyqt5; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "convertall"; version = "0.8.0"; @@ -13,7 +20,11 @@ in stdenv.mkDerivation rec { sha256 = "02xxasgbjbivsbhyfpn3cpv52lscdx5kc95s6ns1dvnmdg0fpng0"; }; - nativeBuildInputs = [ python3 wrapPython wrapQtAppsHook ]; + nativeBuildInputs = [ + python3 + wrapPython + wrapQtAppsHook + ]; propagatedBuildInputs = [ pyqt5 ]; diff --git a/pkgs/applications/science/misc/cytoscape/default.nix b/pkgs/applications/science/misc/cytoscape/default.nix index 4396fe135df07c..886fb2ef557621 100644 --- a/pkgs/applications/science/misc/cytoscape/default.nix +++ b/pkgs/applications/science/misc/cytoscape/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper, substituteAll, coreutils }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, + substituteAll, + coreutils, +}: stdenv.mkDerivation rec { pname = "cytoscape"; @@ -39,7 +47,7 @@ stdenv.mkDerivation rec { description = "General platform for complex network analysis and visualization"; mainProgram = "cytoscape"; license = lib.licenses.lgpl21; - maintainers = [lib.maintainers.mimame]; + maintainers = [ lib.maintainers.mimame ]; platforms = lib.platforms.unix; }; } diff --git a/pkgs/applications/science/misc/golly/default.nix b/pkgs/applications/science/misc/golly/default.nix index 8a2bb17d2d53f3..ac8d7fa4ea333c 100644 --- a/pkgs/applications/science/misc/golly/default.nix +++ b/pkgs/applications/science/misc/golly/default.nix @@ -1,19 +1,36 @@ -{lib, stdenv, fetchurl, wxGTK, python3, zlib, libGLU, libGL, libX11, SDL2}: +{ + lib, + stdenv, + fetchurl, + wxGTK, + python3, + zlib, + libGLU, + libGL, + libX11, + SDL2, +}: stdenv.mkDerivation rec { pname = "golly"; version = "4.3"; src = fetchurl { hash = "sha256-UdJHgGPn7FDN4rYTgfPBAoYE5FGC43TP8OFBmYIqCB0="; - url="mirror://sourceforge/project/golly/golly/golly-${version}/golly-${version}-src.tar.gz"; + url = "mirror://sourceforge/project/golly/golly/golly-${version}/golly-${version}-src.tar.gz"; }; buildInputs = [ - wxGTK python3 zlib libGLU libGL libX11 SDL2 + wxGTK + python3 + zlib + libGLU + libGL + libX11 + SDL2 ]; nativeBuildInputs = [ - (python3.withPackages (ps: [ps.setuptools])) + (python3.withPackages (ps: [ ps.setuptools ])) ]; setSourceRoot = '' @@ -27,8 +44,9 @@ stdenv.mkDerivation rec { grep /lib/libpython wxprefs.cpp ''; - makeFlags=[ - "-f" "makefile-gtk" + makeFlags = [ + "-f" + "makefile-gtk" "ENABLE_SOUND=1" "GOLLYDIR=${placeholder "out"}/share/golly" ]; @@ -47,7 +65,7 @@ stdenv.mkDerivation rec { meta = { description = "Cellular automata simulation program"; license = lib.licenses.gpl2; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; downloadPage = "https://sourceforge.net/projects/golly/files/golly"; }; diff --git a/pkgs/applications/science/misc/gplates/default.nix b/pkgs/applications/science/misc/gplates/default.nix index 72504246b6c0af..33468a311162bb 100644 --- a/pkgs/applications/science/misc/gplates/default.nix +++ b/pkgs/applications/science/misc/gplates/default.nix @@ -1,30 +1,33 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, doxygen -, graphviz -, boost -, cgal_5 -, gdal -, glew -, gmp -, libGL -, libGLU -, libSM -, mpfr -, proj -, python3 -, qtxmlpatterns -, qwt -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + doxygen, + graphviz, + boost, + cgal_5, + gdal, + glew, + gmp, + libGL, + libGLU, + libSM, + mpfr, + proj, + python3, + qtxmlpatterns, + qwt, + wrapQtAppsHook, }: let - python = python3.withPackages (ps: with ps; [ - numpy - ]); + python = python3.withPackages ( + ps: with ps; [ + numpy + ] + ); boost' = boost.override { enablePython = true; inherit python; @@ -32,7 +35,8 @@ let cgal = cgal_5.override { boost = boost'; }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "gplates"; version = "2.5"; diff --git a/pkgs/applications/science/misc/megam/default.nix b/pkgs/applications/science/misc/megam/default.nix index cae0fe9b26fdcc..1199a7b71ca9c0 100644 --- a/pkgs/applications/science/misc/megam/default.nix +++ b/pkgs/applications/science/misc/megam/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, ocaml -, ncurses +{ + lib, + stdenv, + fetchurl, + ocaml, + ncurses, }: stdenv.mkDerivation { @@ -14,7 +15,10 @@ stdenv.mkDerivation { sha256 = "dc0e9f59ff8513449fe3bd40b260141f89c88a4edf6ddc8b8a394c758e49724e"; }; - patches = [ ./ocaml-includes.patch ./ocaml-3.12.patch ]; + patches = [ + ./ocaml-includes.patch + ./ocaml-3.12.patch + ]; postPatch = '' # Deprecated in ocaml 3.10 https://github.com/ocaml/ocaml/commit/f6190f3d0c49c5220d443ee8d03ca5072d68aa87 diff --git a/pkgs/applications/science/misc/nextinspace/default.nix b/pkgs/applications/science/misc/nextinspace/default.nix index 742b4cb622c297..4298c889c74f4b 100644 --- a/pkgs/applications/science/misc/nextinspace/default.nix +++ b/pkgs/applications/science/misc/nextinspace/default.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/applications/science/misc/openmodelica/combined/default.nix b/pkgs/applications/science/misc/openmodelica/combined/default.nix index 8d937dddac547e..e7649374cc67e8 100644 --- a/pkgs/applications/science/misc/openmodelica/combined/default.nix +++ b/pkgs/applications/science/misc/openmodelica/combined/default.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, openmodelica, symlinkJoin, gnumake, blas, lapack, makeWrapper }: +{ + stdenv, + lib, + openmodelica, + symlinkJoin, + gnumake, + blas, + lapack, + makeWrapper, +}: symlinkJoin { name = "openmodelica-combined"; paths = with openmodelica; [ @@ -15,8 +24,18 @@ symlinkJoin { postBuild = '' wrapProgram $out/bin/OMEdit \ - --prefix PATH : ${lib.makeBinPath [ gnumake stdenv.cc ]} \ - --prefix LIBRARY_PATH : "${lib.makeLibraryPath [ blas lapack ]}" \ + --prefix PATH : ${ + lib.makeBinPath [ + gnumake + stdenv.cc + ] + } \ + --prefix LIBRARY_PATH : "${ + lib.makeLibraryPath [ + blas + lapack + ] + }" \ --set-default OPENMODELICALIBRARY "${openmodelica.omlibrary}/lib/omlibrary" ''; @@ -24,7 +43,10 @@ symlinkJoin { description = "Open-source Modelica-based modeling and simulation environment intended for industrial and academic usage"; homepage = "https://openmodelica.org"; license = licenses.gpl3Only; - maintainers = with maintainers; [ balodja smironov ]; + maintainers = with maintainers; [ + balodja + smironov + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/science/misc/openmodelica/default.nix b/pkgs/applications/science/misc/openmodelica/default.nix index 10fccfdf6da8e5..ece043751cdcc3 100644 --- a/pkgs/applications/science/misc/openmodelica/default.nix +++ b/pkgs/applications/science/misc/openmodelica/default.nix @@ -1,5 +1,11 @@ -{ lib, newScope, libsForQt5, clangStdenv }: -lib.makeScope newScope (self: +{ + lib, + newScope, + libsForQt5, + clangStdenv, +}: +lib.makeScope newScope ( + self: let callPackage = self.newScope { stdenv = clangStdenv; }; callQtPackage = self.newScope (libsForQt5 // { stdenv = clangStdenv; }); @@ -14,4 +20,5 @@ lib.makeScope newScope (self: omlibrary = callPackage ./omlibrary { }; omshell = callQtPackage ./omshell { }; combined = callPackage ./combined { }; - }) + } +) diff --git a/pkgs/applications/science/misc/openmodelica/mkderivation/default.nix b/pkgs/applications/science/misc/openmodelica/mkderivation/default.nix index ffa0a158ac95ad..e1807fe82bd202 100644 --- a/pkgs/applications/science/misc/openmodelica/mkderivation/default.nix +++ b/pkgs/applications/science/misc/openmodelica/mkderivation/default.nix @@ -1,22 +1,40 @@ # mkOpenModelicaDerivation is an mkDerivation function for packages # from OpenModelica suite. -{ stdenv, lib, fetchgit, autoconf, automake, libtool, cmake, autoreconfHook, symlinkJoin }: +{ + stdenv, + lib, + fetchgit, + autoconf, + automake, + libtool, + cmake, + autoreconfHook, + symlinkJoin, +}: pkg: let - inherit (builtins) hasAttr getAttr length elemAt; + inherit (builtins) + hasAttr + getAttr + length + elemAt + ; inherit (lib) attrByPath concatStringsSep; - # A few helpers functions: # getAttrDef is just a getAttr with default fallback - getAttrDef = attr: default: x: attrByPath [ attr ] default x; + getAttrDef = + attr: default: x: + attrByPath [ attr ] default x; # getAttr-like helper for optional append to string: # "Hello" + appendByAttr "a" " " {a = "world";} = "Hello world" # "Hello" + appendByAttr "a" " " {} = "Hello" - appendByAttr = attr: sep: x: lib.optionalString (hasAttr attr x) (sep + (getAttr attr x)); + appendByAttr = + attr: sep: x: + lib.optionalString (hasAttr attr x) (sep + (getAttr attr x)); # Are there any OM dependencies at all? ifDeps = length pkg.omdeps != 0; @@ -24,8 +42,8 @@ let # Dependencies of current OpenModelica-target joined in one file tree. # Return the dep itself in case it is a single one. joinedDeps = - if length pkg.omdeps == 1 - then elemAt pkg.omdeps 0 + if length pkg.omdeps == 1 then + elemAt pkg.omdeps 0 else symlinkJoin { name = pkg.pname + "-omhome"; @@ -42,18 +60,19 @@ let omdir = getAttrDef "omdir" pkg.pname pkg; # Simple to to m4 configuration scripts - postPatch = lib.optionalString ifDeps '' - sed -i ''$(find -name omhome.m4) -e 's|if test ! -z "$USINGPRESETBUILDDIR"|if test ! -z "$USINGPRESETBUILDDIR" -a -z "$OMHOME"|' - '' + - appendByAttr "postPatch" "\n" pkg; + postPatch = + lib.optionalString ifDeps '' + sed -i ''$(find -name omhome.m4) -e 's|if test ! -z "$USINGPRESETBUILDDIR"|if test ! -z "$USINGPRESETBUILDDIR" -a -z "$OMHOME"|' + '' + + appendByAttr "postPatch" "\n" pkg; # Update shebangs in the scripts before running configuration. - preAutoreconf = "patchShebangs --build common" + - appendByAttr "preAutoreconf" "\n" pkg; + preAutoreconf = "patchShebangs --build common" + appendByAttr "preAutoreconf" "\n" pkg; # Tell OpenModelica where built dependencies are located. - configureFlags = lib.optional ifDeps "--with-openmodelicahome=${joinedDeps}" ++ - getAttrDef "configureFlags" [ ] pkg; + configureFlags = + lib.optional ifDeps "--with-openmodelicahome=${joinedDeps}" + ++ getAttrDef "configureFlags" [ ] pkg; # Our own configurePhase that accounts for omautoconf configurePhase = '' @@ -68,34 +87,48 @@ let deptargets = lib.forEach pkg.omdeps (dep: dep.omtarget); # ... so we ask openmodelica makefile to skip those targets. - preBuild = '' - for target in ${concatStringsSep " " deptargets}; do - touch ''${target}.skip; - done - '' + - appendByAttr "preBuild" "\n" pkg; - - makeFlags = "${omtarget}" + - appendByAttr "makeFlags" " " pkg; + preBuild = + '' + for target in ${concatStringsSep " " deptargets}; do + touch ''${target}.skip; + done + '' + + appendByAttr "preBuild" "\n" pkg; - installFlags = "-i " + - appendByAttr "installFlags" " " pkg; + makeFlags = "${omtarget}" + appendByAttr "makeFlags" " " pkg; + installFlags = "-i " + appendByAttr "installFlags" " " pkg; in -stdenv.mkDerivation (pkg // { - inherit omtarget postPatch preAutoreconf configureFlags configurePhase preBuild makeFlags installFlags; - - src = fetchgit (import ./src-main.nix); - version = "1.18.0"; - - nativeBuildInputs = getAttrDef "nativeBuildInputs" [ ] pkg - ++ [ autoconf automake libtool cmake autoreconfHook ]; - - buildInputs = getAttrDef "buildInputs" [ ] pkg - ++ lib.optional ifDeps joinedDeps; - - dontUseCmakeConfigure = true; - - hardeningDisable = [ "format" ]; -}) +stdenv.mkDerivation ( + pkg + // { + inherit + omtarget + postPatch + preAutoreconf + configureFlags + configurePhase + preBuild + makeFlags + installFlags + ; + + src = fetchgit (import ./src-main.nix); + version = "1.18.0"; + + nativeBuildInputs = getAttrDef "nativeBuildInputs" [ ] pkg ++ [ + autoconf + automake + libtool + cmake + autoreconfHook + ]; + + buildInputs = getAttrDef "buildInputs" [ ] pkg ++ lib.optional ifDeps joinedDeps; + + dontUseCmakeConfigure = true; + + hardeningDisable = [ "format" ]; + } +) diff --git a/pkgs/applications/science/misc/openmodelica/omcompiler/default.nix b/pkgs/applications/science/misc/openmodelica/omcompiler/default.nix index 82b9f8e36fe1d3..3d089164826733 100644 --- a/pkgs/applications/science/misc/openmodelica/omcompiler/default.nix +++ b/pkgs/applications/science/misc/openmodelica/omcompiler/default.nix @@ -1,68 +1,84 @@ -{ stdenv -, lib -, gfortran -, flex -, bison -, jre8 -, blas -, lapack -, curl -, readline -, expat -, pkg-config -, buildPackages -, targetPackages -, libffi -, binutils -, mkOpenModelicaDerivation +{ + stdenv, + lib, + gfortran, + flex, + bison, + jre8, + blas, + lapack, + curl, + readline, + expat, + pkg-config, + buildPackages, + targetPackages, + libffi, + binutils, + mkOpenModelicaDerivation, }: let isCross = stdenv.buildPlatform != stdenv.hostPlatform; nativeOMCompiler = buildPackages.openmodelica.omcompiler; in -mkOpenModelicaDerivation ({ - pname = "omcompiler"; - omtarget = "omc"; - omdir = "OMCompiler"; - omdeps = [ ]; - omautoconf = true; +mkOpenModelicaDerivation ( + { + pname = "omcompiler"; + omtarget = "omc"; + omdir = "OMCompiler"; + omdeps = [ ]; + omautoconf = true; - nativeBuildInputs = [ - jre8 - gfortran - flex - bison - pkg-config - ] ++ lib.optional isCross nativeOMCompiler; + nativeBuildInputs = [ + jre8 + gfortran + flex + bison + pkg-config + ] ++ lib.optional isCross nativeOMCompiler; - buildInputs = [ targetPackages.stdenv.cc.cc blas lapack curl readline expat libffi binutils ]; + buildInputs = [ + targetPackages.stdenv.cc.cc + blas + lapack + curl + readline + expat + libffi + binutils + ]; - postPatch = '' - sed -i -e '/^\s*AR=ar$/ s/ar/${stdenv.cc.targetPrefix}ar/ - /^\s*ar / s/ar /${stdenv.cc.targetPrefix}ar / - /^\s*ranlib/ s/ranlib /${stdenv.cc.targetPrefix}ranlib /' \ - $(find ./OMCompiler -name 'Makefile*') - ''; + postPatch = '' + sed -i -e '/^\s*AR=ar$/ s/ar/${stdenv.cc.targetPrefix}ar/ + /^\s*ar / s/ar /${stdenv.cc.targetPrefix}ar / + /^\s*ranlib/ s/ranlib /${stdenv.cc.targetPrefix}ranlib /' \ + $(find ./OMCompiler -name 'Makefile*') + ''; - env.CFLAGS = toString [ - "-Wno-error=dynamic-exception-spec" - "-Wno-error=implicit-function-declaration" - ]; + env.CFLAGS = toString [ + "-Wno-error=dynamic-exception-spec" + "-Wno-error=implicit-function-declaration" + ]; - preFixup = '' - for entry in $(find $out -name libipopt.so); do - patchelf --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" "$entry" - patchelf --set-rpath '$ORIGIN':"$(patchelf --print-rpath $entry)" "$entry" - done - ''; + preFixup = '' + for entry in $(find $out -name libipopt.so); do + patchelf --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" "$entry" + patchelf --set-rpath '$ORIGIN':"$(patchelf --print-rpath $entry)" "$entry" + done + ''; - meta = with lib; { - description = "Modelica compiler from OpenModelica suite"; - homepage = "https://openmodelica.org"; - license = licenses.gpl3Only; - maintainers = with maintainers; [ balodja smironov ]; - platforms = platforms.linux; - }; -} // lib.optionalAttrs isCross { - configureFlags = [ "--with-omc=${nativeOMCompiler}/bin/omc" ]; -}) + meta = with lib; { + description = "Modelica compiler from OpenModelica suite"; + homepage = "https://openmodelica.org"; + license = licenses.gpl3Only; + maintainers = with maintainers; [ + balodja + smironov + ]; + platforms = platforms.linux; + }; + } + // lib.optionalAttrs isCross { + configureFlags = [ "--with-omc=${nativeOMCompiler}/bin/omc" ]; + } +) diff --git a/pkgs/applications/science/misc/openmodelica/omedit/default.nix b/pkgs/applications/science/misc/openmodelica/omedit/default.nix index 731d64c41755b0..d06b4a40d13b00 100644 --- a/pkgs/applications/science/misc/openmodelica/omedit/default.nix +++ b/pkgs/applications/science/misc/openmodelica/omedit/default.nix @@ -1,26 +1,43 @@ -{ lib -, jre8 -, qmake -, qtbase -, qttools -, qtwebkit -, qtxmlpatterns -, binutils -, wrapQtAppsHook -, openmodelica -, openscenegraph -, mkOpenModelicaDerivation +{ + lib, + jre8, + qmake, + qtbase, + qttools, + qtwebkit, + qtxmlpatterns, + binutils, + wrapQtAppsHook, + openmodelica, + openscenegraph, + mkOpenModelicaDerivation, }: with openmodelica; mkOpenModelicaDerivation rec { pname = "omedit"; omdir = "OMEdit"; - omdeps = [ omcompiler omplot omparser omsimulator ]; + omdeps = [ + omcompiler + omplot + omparser + omsimulator + ]; omautoconf = true; - nativeBuildInputs = [ jre8 qmake qtbase qttools wrapQtAppsHook ]; + nativeBuildInputs = [ + jre8 + qmake + qtbase + qttools + wrapQtAppsHook + ]; - buildInputs = [ qtwebkit openscenegraph qtxmlpatterns binutils ]; + buildInputs = [ + qtwebkit + openscenegraph + qtxmlpatterns + binutils + ]; postPatch = '' sed -i ''$(find -name qmake.m4) -e '/^\s*LRELEASE=/ s|LRELEASE=.*$|LRELEASE=${lib.getDev qttools}/bin/lrelease|' @@ -33,7 +50,10 @@ mkOpenModelicaDerivation rec { description = "Modelica connection editor for OpenModelica"; homepage = "https://openmodelica.org"; license = licenses.gpl3Only; - maintainers = with maintainers; [ balodja smironov ]; + maintainers = with maintainers; [ + balodja + smironov + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/science/misc/openmodelica/omlibrary/default.nix b/pkgs/applications/science/misc/openmodelica/omlibrary/default.nix index dee5aacf66655e..64479fb9096953 100644 --- a/pkgs/applications/science/misc/openmodelica/omlibrary/default.nix +++ b/pkgs/applications/science/misc/openmodelica/omlibrary/default.nix @@ -1,12 +1,20 @@ -{ lib -, stdenv -, fetchgit -, bash -, openmodelica -, mkOpenModelicaDerivation +{ + lib, + stdenv, + fetchgit, + bash, + openmodelica, + mkOpenModelicaDerivation, }: let - fakegit = import ./fakegit.nix { inherit lib stdenv fetchgit bash; }; + fakegit = import ./fakegit.nix { + inherit + lib + stdenv + fetchgit + bash + ; + }; in mkOpenModelicaDerivation { pname = "omlibrary"; @@ -28,7 +36,10 @@ mkOpenModelicaDerivation { including Modelica Standard Library"; homepage = "https://openmodelica.org"; license = licenses.gpl3Only; - maintainers = with maintainers; [ balodja smironov ]; + maintainers = with maintainers; [ + balodja + smironov + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/science/misc/openmodelica/omlibrary/fakegit.nix b/pkgs/applications/science/misc/openmodelica/omlibrary/fakegit.nix index cad21c2a6e444d..b0509a8e97a957 100644 --- a/pkgs/applications/science/misc/openmodelica/omlibrary/fakegit.nix +++ b/pkgs/applications/science/misc/openmodelica/omlibrary/fakegit.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchgit, bash }: +{ + lib, + stdenv, + fetchgit, + bash, +}: let mkscript = path: text: '' mkdir -pv `dirname ${path}` @@ -11,7 +16,8 @@ let chmod +x ${path} ''; - hashname = r: + hashname = + r: let rpl = lib.replaceStrings [ ":" "/" ] [ "_" "_" ]; in @@ -23,9 +29,9 @@ stdenv.mkDerivation { buildCommand = '' mkdir -pv $out/repos - ${lib.concatMapStrings - (r: "cp -r ${fetchgit r} $out/repos/${hashname r}\n") - (import ./src-libs.nix)} + ${lib.concatMapStrings ( + r: "cp -r ${fetchgit r} $out/repos/${hashname r}\n" + ) (import ./src-libs.nix)} ${mkscript "$out/bin/checkout-git.sh" '' if test "$#" -ne 4; then diff --git a/pkgs/applications/science/misc/openmodelica/omlibrary/src-libs.nix b/pkgs/applications/science/misc/openmodelica/omlibrary/src-libs.nix index dff5ee78936a5e..18491010d807bb 100644 --- a/pkgs/applications/science/misc/openmodelica/omlibrary/src-libs.nix +++ b/pkgs/applications/science/misc/openmodelica/omlibrary/src-libs.nix @@ -1,81 +1,476 @@ [ -{ url = "https://github.com/modelica-3rdparty/AdvancedNoise.git"; rev = "5ce57acd279dadd0d25b76a6b02d3f9e9d061246"; sha256 = "07jjbj0y6bak269md3xniqb5lgc33m92ar5qixqxj5yxdjaahfs2"; fetchSubmodules = true; } -{ url = "https://github.com/RWTH-EBC/AixLib.git"; rev = "65e49ddf5c935846888a61aa303e52c909619079"; sha256 = "18xn8j3x3j4x9bpjgqnq0b6p3yzzsg5n62fv1ldqbbjcmi0vimd5"; fetchSubmodules = true; } -{ url = "https://github.com/RWTH-EBC/AixLib.git"; rev = "v0.4.0"; sha256 = "0dw34mjq29n55xh51g1c9a9d0d8gbpn16gj309dfxn4v2hbnfvzx"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/AlgebraTestSuite.git"; rev = "b937e1a7f447138c59abec9b2092f84f16bf02e8"; sha256 = "0406inasx61dk7vcnziiyhxkna7g61a5hn0znnbxj817hz6q11zn"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/ApproxSpline.git"; rev = "28420f5c1a88c9cd069defbd8c05e4a78a090675"; sha256 = "07gpyi2brj5zpvrlsnflqjnhbrgxvpqbdshp8lp4lh9mnj5jv95d"; fetchSubmodules = true; } -{ url = "https://github.com/OpenModelica/BioChem.git"; rev = "v1.0.2"; sha256 = "037bvj2lqrslg8k5r0rjgdzccslj9bj25b55k4g440vabm5p05qm"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/BondGraph.git"; rev = "20c23e60d12989bd4668ccac47659d82d39d29cc"; sha256 = "0yrkk708v4bvf423xb4zgpmnaj8qhq5primdg758ayddgli23wa9"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/BrineProp.git"; rev = "834fb3519ca8f89efe268582d39d00a7c3991150"; sha256 = "1iwqh4kr36wgxc0gci63gdgbqln2sap1w4bkydk1vkss2s302lg4"; fetchSubmodules = true; } -{ url = "https://github.com/EDF-TREE/BuildSysPro.git"; rev = "v3.3.0"; sha256 = "1cvcany3q9p1xndarxa2d8mmqxdnqk22476q8l61nayz5qy25x61"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/BuildingControlLib.git"; rev = "v1.0.0"; sha256 = "0ckdxway0m755mbrl94k4458sijzgknlzsrf7xs5bjymxchm8r2m"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/BuildingSystems.git"; rev = "c3070d48015ee75c1577f349cb388a498bef7270"; sha256 = "0r876wm6f1xx4cli1lqlylpl3zgaddmy06hcafbnzry9j38vbz4y"; fetchSubmodules = true; } -{ url = "https://github.com/lbl-srg/modelica-buildings.git"; rev = "v6.0.0"; sha256 = "0rnnk1clji0myzr7adggki6knbl6v8381vwnqgiz8mkxbmzdwm4f"; fetchSubmodules = true; } -{ url = "https://github.com/lbl-srg/modelica-buildings.git"; rev = "v7.0.0"; sha256 = "04n04pp4zvyg8n8h7h79c3wyk7lmn940mh7qzs0lv76g1ybypnlz"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/Chemical.git"; rev = "5645573fced862430b7b598b4d7ec1a39c7aa0fa"; sha256 = "1kh7kpmjfz55pb8553srlnrh8l00nw21xf5mjzh7nx9b1rndnmyg"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/DeployStructLib.git"; rev = "v1.0"; sha256 = "1k4zw9lnd0javw4zigxc15l58yf7xdz36b7808g65qxy89w6ksr2"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/DisHeatLib.git"; rev = "b11f53379c122870a52f2da9b1705d2c911cd21d"; sha256 = "1vm96a4z0b40r0nisxrrzyvan4yphjdkx4ad655phva2636xb5rr"; fetchSubmodules = true; } -{ url = "https://github.com/AHaumer/DriveControl.git"; rev = "b7233fd97a92867bb4ec2c3647c7f7e888398644"; sha256 = "0nyp1n8wrkjzfypsmjjzac0g9p4wbc1cxxr040fj20bqdg9l3h1b"; fetchSubmodules = true; } -{ url = "https://github.com/christiankral/ElectroMechanicalDrives.git"; rev = "v2.2.0"; sha256 = "0012phmn1y9fgpph45lwbjk0yhm5czidf2z6khm8lddvk93wf31b"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/ExternData.git"; rev = "v2.5.0"; sha256 = "19dsyq1mk5vl54fqaffzqafm5w94l011cy7pg16c7i933dbqnkki"; fetchSubmodules = true; } -{ url = "https://github.com/modelica/ExternalMedia.git"; rev = "6138312c96142ff3c01190147e6277991bfa2fca"; sha256 = "1d9g2hbdvgz13j7kdi1kglkkllj9f00x3dwdp5piyypvs464jsn5"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/ExternalMemoryLib.git"; rev = "6488d5815bda23c665123baa916789e283e16d2c"; sha256 = "06y1i5w690b3b9x23nzls8y67fl7yd7bn4xl5j0dmyi4qx33aqda"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/FMITest.git"; rev = "a67a276083f4010b249802ad8fc70dc30c09adfd"; sha256 = "0mg8jlvlwql2nsjiy7c3rdibv73bkfk149ac0450d5pc0hfn9mln"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/FailureModes.git"; rev = "v1.2.1"; sha256 = "1z8bwrld1rkydgssab5gnrd76frrbky8qxi1lvlaf2jidj6bzn1l"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/FaultTriggering.git"; rev = "v0.6.6"; sha256 = "0a08yyrbg4a49s0bgqgyds6pidx9xr47yspvl9bdak1mq34qibip"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/FeedDriveLibrary.git"; rev = "1.0.1"; sha256 = "15fi9dj6zgl0fr90cwxqjbpphj0dwrrmk74hf25j6zd85w2ycqdz"; fetchSubmodules = true; } -{ url = "https://github.com/DLR-SR/FractionalOrder.git"; rev = "99918820e346c362c3ad52d782c8215e5deeac4c"; sha256 = "1pycss6fqh86frfdbdfffjhaz09fz1558f9azgckhf8drx6ry1qs"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/Greenhouses-Library.git"; rev = "89ae0e8097eb0751abce2013d304fa5f9c09b885"; sha256 = "1q77xj6aysqsn3d7kjmcq7dihbw18iqm35ifzdi75xgf3cgwla4f"; fetchSubmodules = true; } -{ url = "https://github.com/christiankral/HanserModelica.git"; rev = "v1.1.0"; sha256 = "0zwkrhg2y42m18p4z51izrickiv1vikgz0z7fpjia4dbppckav8i"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/HelmholtzMedia.git"; rev = "3b4a4bca94d388744b2d045344ea2f9b0b4d405b"; sha256 = "17fzpan89075vb5vbhw5ylgxcdsmj2vjnmmka7cgzh06izb69nvh"; fetchSubmodules = true; } -{ url = "https://github.com/ibpsa/modelica-ibpsa.git"; rev = "v3.0.0"; sha256 = "0xwgfndlw76zfmiiqadl85l9na9igsqlmfcawx526sdw2lhhgics"; fetchSubmodules = true; } -{ url = "https://github.com/open-ideas/IDEAS.git"; rev = "v2.1.0"; sha256 = "0xp0zg6ib5536d5vl361lsn5w5faqdf6djhcmfxns629wjima8rn"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/IndustrialControlSystems.git"; rev = "v1.1.0"; sha256 = "1nvgx94iy1pws0768anrl7ssjlzslb5mbp21j7xvf6wpqfmj0npc"; fetchSubmodules = true; } -{ url = "https://github.com/christiankral/KeyWordIO.git"; rev = "v0.9.0"; sha256 = "10kvj6zn2r6m3403ja8nkkxbfcchkz0pfk3g70ibr76zivxb5nim"; fetchSubmodules = true; } -{ url = "https://github.com/FishSim/LibRAS.git"; rev = "fca9de50a484a2213f3ca1b39e275c237c471688"; sha256 = "0w1c87sifq8klq0f2l70qxjrlvahyxy1cx9rln80rni4d427yc1k"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/LinearMPC.git"; rev = "v1.0"; sha256 = "1crj60i5f33l9pgip0xbv6ankcga7px0644cj7c2wnzn1fjmn2k8"; fetchSubmodules = true; } -{ url = "https://github.com/looms-polimi/MEV.git"; rev = "v1.0.1"; sha256 = "1a7ih9lc01wzaq8a8aznggpi4aqnczyzq49q5hc4fqvmfwl7l0j3"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/ModPowerSystems.git"; rev = "df3afce27d5e935c4111f392275744a655abe216"; sha256 = "1b1fikm92lv6gj82imka3hxbjwv04i4h33y69yhcxdpqa6z6hm4z"; fetchSubmodules = true; } -{ url = "https://github.com/OpenModelica/OpenModelica-ModelicaStandardLibrary.git"; rev = "4a91d52248b0f17415bba1d58881fc730bd94215"; sha256 = "19caxz6hvlrsls3b2387a24zwwnykbb138jpb42gwpy8jlh93yzi"; fetchSubmodules = true; } -{ url = "https://github.com/OpenModelica/OpenModelica-ModelicaStandardLibrary.git"; rev = "cab27240a4a3ed4ea137226f056bbc0d79543f7a"; sha256 = "06y911i2hs7hg4ykhb8wngvxhwnaww8rsakwa7ssd047a7glzsb0"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/Modelica-Arduino.git"; rev = "v0.1.0"; sha256 = "1n34dksqhrn1synv2mp2ifk4dxyhp15f5v1jb1b3dbw9n19951qb"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/Modelica-GNU_ScientificLibrary.git"; rev = "9235ab28bdd7f0fe3e7abba48af53d73332858ec"; sha256 = "168g9gg12lfa863ifs41bnx6yd0yyjnal6986dgpm51dj5arw6id"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/Modelica-MVEM.git"; rev = "v1.0.1"; sha256 = "1p68691dnl06lgwm4bl9g036brn4vl7m5x3gq4rxc291339frixk"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/ModelicaADS.git"; rev = "v1.0.1"; sha256 = "0fhxrl07d7v3wa79d30psm1gxydc0p7s2akfirdx6dai0633skp9"; fetchSubmodules = true; } -{ url = "https://github.com/xogeny/ModelicaBook.git"; rev = "v0.6.0"; sha256 = "0yqbll6p738yvpi1x11cjngpz2glda07mljrkjlm23p7l53x63dc"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-compliance/compliance.git"; rev = "8a91e75d8a26acc4de30fc0e5d5e9db83c970bd6"; sha256 = "1cym1wlgsvfrryq8zqzzrgs4wam1l7pc20q07hk3d615nhq21lg6"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/ModelicaDFR.git"; rev = "37a441934d05330cf3d13e9ec551954d27eca84c"; sha256 = "13rpcs8cl9x15vi655150zmhmg1iaxpzvxrl3rqif46zpl5dhlj2"; fetchSubmodules = true; } -{ url = "https://github.com/modelica/Modelica_DeviceDrivers.git"; rev = "v1.8.2"; sha256 = "16c0p9zn0qrraz59ivinibmikdd251plm1vqngznzhksjwvz6bja"; fetchSubmodules = true; } -{ url = "https://github.com/modelica/Modelica_LinearSystems2.git"; rev = "v2.3.5"; sha256 = "0rzicynqgayydxqynnairxk7ybg4alv1xnfz8cgkrpicl2g9bacg"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/Modelica_Requirements.git"; rev = "a427b5cb7997e9036c577d219e6b8a5d0c28389a"; sha256 = "1ihx46kifnfi9kw1g8nmd9sarl766whbzdk6a44alczsya4gg45k"; fetchSubmodules = true; } -{ url = "https://github.com/modelica/Modelica_Synchronous.git"; rev = "c8350276bfd945086962cf4150ba941b9c57ed13"; sha256 = "12ad7fpjy50ky3lvl65r9d5xvlzvw5yqdnbp4rsgl3qw7s3wrmja"; fetchSubmodules = true; } -{ url = "https://github.com/jwindahlModelon/MultiPhaseMixtureMedia.git"; rev = "0bda0c58af6384f8e0edf7aa7520afb369af3e38"; sha256 = "11bqm69504bh4h05dxlwdmjfxwls06mr49cz47kl8jmrygkfi4i2"; fetchSubmodules = true; } -{ url = "https://github.com/OpenIPSL/OpenIPSL.git"; rev = "v1.5.0"; sha256 = "09xrcz0rdxdy220ki5zyl7920y0a4lg24p0aibna4ad15vszhhwj"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/Optimisers.git"; rev = "e33c69edaad6dad8029167b0ca00533964a6fe37"; sha256 = "0hcxsrr2n4fzaxdjvgvqayz38kpfk86cclvg5pzcfmjc5bznb8bs"; fetchSubmodules = true; } -{ url = "https://github.com/lochel/PNlib.git"; rev = "059545d48dd9ceeccfa3b4e47689ec8dd334dcd8"; sha256 = "1a0hxkgsi4klw9c8zav1dy2p1c85ald29gx82hfacwv55xl9f127"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/PVSystems.git"; rev = "v0.6.2"; sha256 = "0vcgvdaqfbn46lpzk0kvsif3d55wf8yzhkbdpf5zv04kv7zw25w9"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/PhotoVoltaics.git"; rev = "v1.6.0"; sha256 = "0zqx77z217iln3vfxn2v3c2jl0jz5kgcd96ylvimjnwr30mxr09n"; fetchSubmodules = true; } -{ url = "https://github.com/MarekMatejak/Physiolibrary.git"; rev = "v2.3.1"; sha256 = "0nxfw63m278gaff18zz29n2s1vk4kwdbv2qvbjmcq86fl1i5b3bg"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/Physiomodel.git"; rev = "v1.0.0"; sha256 = "1sdhv5qgjqv3zdq57pkkrh04ainwv9n5zqd8mb9a3ybjmwdjf6f9"; fetchSubmodules = true; } -{ url = "https://github.com/dzimmer/PlanarMechanics.git"; rev = "55224a9e76de8aa7f708236bd4d7dee624ecba50"; sha256 = "0hf7vi44adss86x5ahk5if7bdjgw773d8mb3d8ianq12g8azycyd"; fetchSubmodules = true; } -{ url = "https://github.com/PowerGrids/PowerGrids.git"; rev = "v1.0.0"; sha256 = "06bx8mqvmizhfwg99djdfgh2mblc4wzmg0zq4ilrp586jwfninmz"; fetchSubmodules = true; } -{ url = "https://github.com/modelica/PowerSystems.git"; rev = "v1.0.0"; sha256 = "1xwhwich7gi6vl33zl2r78xdjklchgkjcnvww6390j20l1wjznkn"; fetchSubmodules = true; } -{ url = "https://github.com/modelica/PowerSystems.git"; rev = "f0721333f4875143565147a7d043bee1c300873b"; sha256 = "0gbvx0gzf3akb0w7yvdxfq2y4ps91cy5b93iwnvnw7652x716813"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/RealTimeCoordinationLibrary.git"; rev = "v1.0.2"; sha256 = "0ch4la04hm059ii5wzph9gsbvqhnfqrvvpqi57qn27bm10c4la0m"; fetchSubmodules = true; } -{ url = "https://github.com/casella/ScalableTestSuite.git"; rev = "v1.11.5"; sha256 = "0bhj1q9b8d29nrbr253zszy1w1yvyizvyr3law1pqjj6mhbqmg4i"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/Servomechanisms.git"; rev = "3bf82ba5d3f31b4a0ae05f99ae690037358e153e"; sha256 = "1swka7d58wkg5pqv59lqgfi7gv6rg5vra4j6r76pn9czx9ddal8w"; fetchSubmodules = true; } -{ url = "https://github.com/SolarTherm/SolarTherm.git"; rev = "203fb5af3b95c731c7fcbe2833d51fd420e80796"; sha256 = "1bh4y4igzd0k59xm8j14p52gnlbwkiwwy6bhhyarpr361yrchn33"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/Soltermica.git"; rev = "9f7224bd89335f95dffe1ccdaa094df5a3279fdf"; sha256 = "1bif3cnwjas6x7b8ahwkm7dbrqrfdqwwa26zmdc6zrpfncl3kqd0"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/SystemDynamics.git"; rev = "2f6bd9382c5aac2aff9148cd9113a418767734b6"; sha256 = "0ii2mj6ngwjir3gzyad8wsj86pvd6wzal91nz2y7gzwj1djchb3x"; fetchSubmodules = true; } -{ url = "https://github.com/thom-marx/ThermalSeparation.git"; rev = "ffa0495ba829ecab105be4bfb3b7652625ec9c03"; sha256 = "1czm97bcrpp2jv0a0kd31a929wqlrlzdhdxvyy4w499dn20jzv1l"; fetchSubmodules = true; } -{ url = "https://github.com/casella/ThermoPower.git"; rev = "650be2c8cbd5abc3535e92b865e509073afc8aeb"; sha256 = "08ijrx8xw43dadz5s3kiwa17ax9faq2wyq9gm0vlz9ddbkj0hcaq"; fetchSubmodules = true; } -{ url = "https://openmodelica.org/git/ThermoSysPro.git"; rev = "db81ae1b5a6a85f6c6c7693244cafa6087e18ff5"; sha256 = "12fsf0xxxc1ja6vmm9ff85f8j5sg1lb7w4g57s2w3fkf4d3a7d0c"; fetchSubmodules = true; } -{ url = "https://openmodelica.org/git/ThermoSysPro.git"; rev = "5cef9acb4dedf8af6f4638a4448f08a544ebd30b"; sha256 = "0ihnz1s4rs42yis9zym9nw29ia2lqz2yx2wblc50p6f221w7q78s"; fetchSubmodules = true; } -{ url = "https://github.com/lenaRB/VVDRlib.git"; rev = "eae4981674642eddffc7f2aa3690320fcaddee0e"; sha256 = "0qxxk2xlas5mqyc1h8ndic208qj1sm5mr5y8664kv3py7i8jdqi4"; fetchSubmodules = true; } -{ url = "https://github.com/modelica/VehicleInterfaces.git"; rev = "v1.2.5"; sha256 = "044k17cpc88wprrvw03p6crm6dy6x9a6xj5104d5nln71lqz5sdq"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/WasteWater.git"; rev = "v2.1.0"; sha256 = "1dxr4m9j7b5266daj4klbrhvnkqr73sximdw9bk9v5qf0s28li99"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/WindPowerPlants.git"; rev = "v1.2.0"; sha256 = "1lyrqwsb6sm1wc7vlj72zk5cpjhhzh27fviiqayddqy2b903xish"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/ipsl.git"; rev = "v1.1.1"; sha256 = "1w2iah8c5d8n01wmxydjk0rrcxh88g8yjy2zmv403azcccq7byzp"; fetchSubmodules = true; } -{ url = "https://github.com/modelica-3rdparty/netCDF-DataReader.git"; rev = "v2.5.0"; sha256 = "1pd5xf5bgz010lryv8bj6lvlfqn9p184csiffwj8icx7rycnlcqb"; fetchSubmodules = true; } -{ url = "https://github.com/joewa/open-bldc-modelica.git"; rev = "58a83b5b36f267613de4676c95163489b1ddc2e7"; sha256 = "0wf6dn64d2psv9b3xg5227vzpk109r3dqzi4m2wwhrilaxs3v004"; fetchSubmodules = true; } + { + url = "https://github.com/modelica-3rdparty/AdvancedNoise.git"; + rev = "5ce57acd279dadd0d25b76a6b02d3f9e9d061246"; + sha256 = "07jjbj0y6bak269md3xniqb5lgc33m92ar5qixqxj5yxdjaahfs2"; + fetchSubmodules = true; + } + { + url = "https://github.com/RWTH-EBC/AixLib.git"; + rev = "65e49ddf5c935846888a61aa303e52c909619079"; + sha256 = "18xn8j3x3j4x9bpjgqnq0b6p3yzzsg5n62fv1ldqbbjcmi0vimd5"; + fetchSubmodules = true; + } + { + url = "https://github.com/RWTH-EBC/AixLib.git"; + rev = "v0.4.0"; + sha256 = "0dw34mjq29n55xh51g1c9a9d0d8gbpn16gj309dfxn4v2hbnfvzx"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/AlgebraTestSuite.git"; + rev = "b937e1a7f447138c59abec9b2092f84f16bf02e8"; + sha256 = "0406inasx61dk7vcnziiyhxkna7g61a5hn0znnbxj817hz6q11zn"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/ApproxSpline.git"; + rev = "28420f5c1a88c9cd069defbd8c05e4a78a090675"; + sha256 = "07gpyi2brj5zpvrlsnflqjnhbrgxvpqbdshp8lp4lh9mnj5jv95d"; + fetchSubmodules = true; + } + { + url = "https://github.com/OpenModelica/BioChem.git"; + rev = "v1.0.2"; + sha256 = "037bvj2lqrslg8k5r0rjgdzccslj9bj25b55k4g440vabm5p05qm"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/BondGraph.git"; + rev = "20c23e60d12989bd4668ccac47659d82d39d29cc"; + sha256 = "0yrkk708v4bvf423xb4zgpmnaj8qhq5primdg758ayddgli23wa9"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/BrineProp.git"; + rev = "834fb3519ca8f89efe268582d39d00a7c3991150"; + sha256 = "1iwqh4kr36wgxc0gci63gdgbqln2sap1w4bkydk1vkss2s302lg4"; + fetchSubmodules = true; + } + { + url = "https://github.com/EDF-TREE/BuildSysPro.git"; + rev = "v3.3.0"; + sha256 = "1cvcany3q9p1xndarxa2d8mmqxdnqk22476q8l61nayz5qy25x61"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/BuildingControlLib.git"; + rev = "v1.0.0"; + sha256 = "0ckdxway0m755mbrl94k4458sijzgknlzsrf7xs5bjymxchm8r2m"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/BuildingSystems.git"; + rev = "c3070d48015ee75c1577f349cb388a498bef7270"; + sha256 = "0r876wm6f1xx4cli1lqlylpl3zgaddmy06hcafbnzry9j38vbz4y"; + fetchSubmodules = true; + } + { + url = "https://github.com/lbl-srg/modelica-buildings.git"; + rev = "v6.0.0"; + sha256 = "0rnnk1clji0myzr7adggki6knbl6v8381vwnqgiz8mkxbmzdwm4f"; + fetchSubmodules = true; + } + { + url = "https://github.com/lbl-srg/modelica-buildings.git"; + rev = "v7.0.0"; + sha256 = "04n04pp4zvyg8n8h7h79c3wyk7lmn940mh7qzs0lv76g1ybypnlz"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/Chemical.git"; + rev = "5645573fced862430b7b598b4d7ec1a39c7aa0fa"; + sha256 = "1kh7kpmjfz55pb8553srlnrh8l00nw21xf5mjzh7nx9b1rndnmyg"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/DeployStructLib.git"; + rev = "v1.0"; + sha256 = "1k4zw9lnd0javw4zigxc15l58yf7xdz36b7808g65qxy89w6ksr2"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/DisHeatLib.git"; + rev = "b11f53379c122870a52f2da9b1705d2c911cd21d"; + sha256 = "1vm96a4z0b40r0nisxrrzyvan4yphjdkx4ad655phva2636xb5rr"; + fetchSubmodules = true; + } + { + url = "https://github.com/AHaumer/DriveControl.git"; + rev = "b7233fd97a92867bb4ec2c3647c7f7e888398644"; + sha256 = "0nyp1n8wrkjzfypsmjjzac0g9p4wbc1cxxr040fj20bqdg9l3h1b"; + fetchSubmodules = true; + } + { + url = "https://github.com/christiankral/ElectroMechanicalDrives.git"; + rev = "v2.2.0"; + sha256 = "0012phmn1y9fgpph45lwbjk0yhm5czidf2z6khm8lddvk93wf31b"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/ExternData.git"; + rev = "v2.5.0"; + sha256 = "19dsyq1mk5vl54fqaffzqafm5w94l011cy7pg16c7i933dbqnkki"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica/ExternalMedia.git"; + rev = "6138312c96142ff3c01190147e6277991bfa2fca"; + sha256 = "1d9g2hbdvgz13j7kdi1kglkkllj9f00x3dwdp5piyypvs464jsn5"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/ExternalMemoryLib.git"; + rev = "6488d5815bda23c665123baa916789e283e16d2c"; + sha256 = "06y1i5w690b3b9x23nzls8y67fl7yd7bn4xl5j0dmyi4qx33aqda"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/FMITest.git"; + rev = "a67a276083f4010b249802ad8fc70dc30c09adfd"; + sha256 = "0mg8jlvlwql2nsjiy7c3rdibv73bkfk149ac0450d5pc0hfn9mln"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/FailureModes.git"; + rev = "v1.2.1"; + sha256 = "1z8bwrld1rkydgssab5gnrd76frrbky8qxi1lvlaf2jidj6bzn1l"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/FaultTriggering.git"; + rev = "v0.6.6"; + sha256 = "0a08yyrbg4a49s0bgqgyds6pidx9xr47yspvl9bdak1mq34qibip"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/FeedDriveLibrary.git"; + rev = "1.0.1"; + sha256 = "15fi9dj6zgl0fr90cwxqjbpphj0dwrrmk74hf25j6zd85w2ycqdz"; + fetchSubmodules = true; + } + { + url = "https://github.com/DLR-SR/FractionalOrder.git"; + rev = "99918820e346c362c3ad52d782c8215e5deeac4c"; + sha256 = "1pycss6fqh86frfdbdfffjhaz09fz1558f9azgckhf8drx6ry1qs"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/Greenhouses-Library.git"; + rev = "89ae0e8097eb0751abce2013d304fa5f9c09b885"; + sha256 = "1q77xj6aysqsn3d7kjmcq7dihbw18iqm35ifzdi75xgf3cgwla4f"; + fetchSubmodules = true; + } + { + url = "https://github.com/christiankral/HanserModelica.git"; + rev = "v1.1.0"; + sha256 = "0zwkrhg2y42m18p4z51izrickiv1vikgz0z7fpjia4dbppckav8i"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/HelmholtzMedia.git"; + rev = "3b4a4bca94d388744b2d045344ea2f9b0b4d405b"; + sha256 = "17fzpan89075vb5vbhw5ylgxcdsmj2vjnmmka7cgzh06izb69nvh"; + fetchSubmodules = true; + } + { + url = "https://github.com/ibpsa/modelica-ibpsa.git"; + rev = "v3.0.0"; + sha256 = "0xwgfndlw76zfmiiqadl85l9na9igsqlmfcawx526sdw2lhhgics"; + fetchSubmodules = true; + } + { + url = "https://github.com/open-ideas/IDEAS.git"; + rev = "v2.1.0"; + sha256 = "0xp0zg6ib5536d5vl361lsn5w5faqdf6djhcmfxns629wjima8rn"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/IndustrialControlSystems.git"; + rev = "v1.1.0"; + sha256 = "1nvgx94iy1pws0768anrl7ssjlzslb5mbp21j7xvf6wpqfmj0npc"; + fetchSubmodules = true; + } + { + url = "https://github.com/christiankral/KeyWordIO.git"; + rev = "v0.9.0"; + sha256 = "10kvj6zn2r6m3403ja8nkkxbfcchkz0pfk3g70ibr76zivxb5nim"; + fetchSubmodules = true; + } + { + url = "https://github.com/FishSim/LibRAS.git"; + rev = "fca9de50a484a2213f3ca1b39e275c237c471688"; + sha256 = "0w1c87sifq8klq0f2l70qxjrlvahyxy1cx9rln80rni4d427yc1k"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/LinearMPC.git"; + rev = "v1.0"; + sha256 = "1crj60i5f33l9pgip0xbv6ankcga7px0644cj7c2wnzn1fjmn2k8"; + fetchSubmodules = true; + } + { + url = "https://github.com/looms-polimi/MEV.git"; + rev = "v1.0.1"; + sha256 = "1a7ih9lc01wzaq8a8aznggpi4aqnczyzq49q5hc4fqvmfwl7l0j3"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/ModPowerSystems.git"; + rev = "df3afce27d5e935c4111f392275744a655abe216"; + sha256 = "1b1fikm92lv6gj82imka3hxbjwv04i4h33y69yhcxdpqa6z6hm4z"; + fetchSubmodules = true; + } + { + url = "https://github.com/OpenModelica/OpenModelica-ModelicaStandardLibrary.git"; + rev = "4a91d52248b0f17415bba1d58881fc730bd94215"; + sha256 = "19caxz6hvlrsls3b2387a24zwwnykbb138jpb42gwpy8jlh93yzi"; + fetchSubmodules = true; + } + { + url = "https://github.com/OpenModelica/OpenModelica-ModelicaStandardLibrary.git"; + rev = "cab27240a4a3ed4ea137226f056bbc0d79543f7a"; + sha256 = "06y911i2hs7hg4ykhb8wngvxhwnaww8rsakwa7ssd047a7glzsb0"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/Modelica-Arduino.git"; + rev = "v0.1.0"; + sha256 = "1n34dksqhrn1synv2mp2ifk4dxyhp15f5v1jb1b3dbw9n19951qb"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/Modelica-GNU_ScientificLibrary.git"; + rev = "9235ab28bdd7f0fe3e7abba48af53d73332858ec"; + sha256 = "168g9gg12lfa863ifs41bnx6yd0yyjnal6986dgpm51dj5arw6id"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/Modelica-MVEM.git"; + rev = "v1.0.1"; + sha256 = "1p68691dnl06lgwm4bl9g036brn4vl7m5x3gq4rxc291339frixk"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/ModelicaADS.git"; + rev = "v1.0.1"; + sha256 = "0fhxrl07d7v3wa79d30psm1gxydc0p7s2akfirdx6dai0633skp9"; + fetchSubmodules = true; + } + { + url = "https://github.com/xogeny/ModelicaBook.git"; + rev = "v0.6.0"; + sha256 = "0yqbll6p738yvpi1x11cjngpz2glda07mljrkjlm23p7l53x63dc"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-compliance/compliance.git"; + rev = "8a91e75d8a26acc4de30fc0e5d5e9db83c970bd6"; + sha256 = "1cym1wlgsvfrryq8zqzzrgs4wam1l7pc20q07hk3d615nhq21lg6"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/ModelicaDFR.git"; + rev = "37a441934d05330cf3d13e9ec551954d27eca84c"; + sha256 = "13rpcs8cl9x15vi655150zmhmg1iaxpzvxrl3rqif46zpl5dhlj2"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica/Modelica_DeviceDrivers.git"; + rev = "v1.8.2"; + sha256 = "16c0p9zn0qrraz59ivinibmikdd251plm1vqngznzhksjwvz6bja"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica/Modelica_LinearSystems2.git"; + rev = "v2.3.5"; + sha256 = "0rzicynqgayydxqynnairxk7ybg4alv1xnfz8cgkrpicl2g9bacg"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/Modelica_Requirements.git"; + rev = "a427b5cb7997e9036c577d219e6b8a5d0c28389a"; + sha256 = "1ihx46kifnfi9kw1g8nmd9sarl766whbzdk6a44alczsya4gg45k"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica/Modelica_Synchronous.git"; + rev = "c8350276bfd945086962cf4150ba941b9c57ed13"; + sha256 = "12ad7fpjy50ky3lvl65r9d5xvlzvw5yqdnbp4rsgl3qw7s3wrmja"; + fetchSubmodules = true; + } + { + url = "https://github.com/jwindahlModelon/MultiPhaseMixtureMedia.git"; + rev = "0bda0c58af6384f8e0edf7aa7520afb369af3e38"; + sha256 = "11bqm69504bh4h05dxlwdmjfxwls06mr49cz47kl8jmrygkfi4i2"; + fetchSubmodules = true; + } + { + url = "https://github.com/OpenIPSL/OpenIPSL.git"; + rev = "v1.5.0"; + sha256 = "09xrcz0rdxdy220ki5zyl7920y0a4lg24p0aibna4ad15vszhhwj"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/Optimisers.git"; + rev = "e33c69edaad6dad8029167b0ca00533964a6fe37"; + sha256 = "0hcxsrr2n4fzaxdjvgvqayz38kpfk86cclvg5pzcfmjc5bznb8bs"; + fetchSubmodules = true; + } + { + url = "https://github.com/lochel/PNlib.git"; + rev = "059545d48dd9ceeccfa3b4e47689ec8dd334dcd8"; + sha256 = "1a0hxkgsi4klw9c8zav1dy2p1c85ald29gx82hfacwv55xl9f127"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/PVSystems.git"; + rev = "v0.6.2"; + sha256 = "0vcgvdaqfbn46lpzk0kvsif3d55wf8yzhkbdpf5zv04kv7zw25w9"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/PhotoVoltaics.git"; + rev = "v1.6.0"; + sha256 = "0zqx77z217iln3vfxn2v3c2jl0jz5kgcd96ylvimjnwr30mxr09n"; + fetchSubmodules = true; + } + { + url = "https://github.com/MarekMatejak/Physiolibrary.git"; + rev = "v2.3.1"; + sha256 = "0nxfw63m278gaff18zz29n2s1vk4kwdbv2qvbjmcq86fl1i5b3bg"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/Physiomodel.git"; + rev = "v1.0.0"; + sha256 = "1sdhv5qgjqv3zdq57pkkrh04ainwv9n5zqd8mb9a3ybjmwdjf6f9"; + fetchSubmodules = true; + } + { + url = "https://github.com/dzimmer/PlanarMechanics.git"; + rev = "55224a9e76de8aa7f708236bd4d7dee624ecba50"; + sha256 = "0hf7vi44adss86x5ahk5if7bdjgw773d8mb3d8ianq12g8azycyd"; + fetchSubmodules = true; + } + { + url = "https://github.com/PowerGrids/PowerGrids.git"; + rev = "v1.0.0"; + sha256 = "06bx8mqvmizhfwg99djdfgh2mblc4wzmg0zq4ilrp586jwfninmz"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica/PowerSystems.git"; + rev = "v1.0.0"; + sha256 = "1xwhwich7gi6vl33zl2r78xdjklchgkjcnvww6390j20l1wjznkn"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica/PowerSystems.git"; + rev = "f0721333f4875143565147a7d043bee1c300873b"; + sha256 = "0gbvx0gzf3akb0w7yvdxfq2y4ps91cy5b93iwnvnw7652x716813"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/RealTimeCoordinationLibrary.git"; + rev = "v1.0.2"; + sha256 = "0ch4la04hm059ii5wzph9gsbvqhnfqrvvpqi57qn27bm10c4la0m"; + fetchSubmodules = true; + } + { + url = "https://github.com/casella/ScalableTestSuite.git"; + rev = "v1.11.5"; + sha256 = "0bhj1q9b8d29nrbr253zszy1w1yvyizvyr3law1pqjj6mhbqmg4i"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/Servomechanisms.git"; + rev = "3bf82ba5d3f31b4a0ae05f99ae690037358e153e"; + sha256 = "1swka7d58wkg5pqv59lqgfi7gv6rg5vra4j6r76pn9czx9ddal8w"; + fetchSubmodules = true; + } + { + url = "https://github.com/SolarTherm/SolarTherm.git"; + rev = "203fb5af3b95c731c7fcbe2833d51fd420e80796"; + sha256 = "1bh4y4igzd0k59xm8j14p52gnlbwkiwwy6bhhyarpr361yrchn33"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/Soltermica.git"; + rev = "9f7224bd89335f95dffe1ccdaa094df5a3279fdf"; + sha256 = "1bif3cnwjas6x7b8ahwkm7dbrqrfdqwwa26zmdc6zrpfncl3kqd0"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/SystemDynamics.git"; + rev = "2f6bd9382c5aac2aff9148cd9113a418767734b6"; + sha256 = "0ii2mj6ngwjir3gzyad8wsj86pvd6wzal91nz2y7gzwj1djchb3x"; + fetchSubmodules = true; + } + { + url = "https://github.com/thom-marx/ThermalSeparation.git"; + rev = "ffa0495ba829ecab105be4bfb3b7652625ec9c03"; + sha256 = "1czm97bcrpp2jv0a0kd31a929wqlrlzdhdxvyy4w499dn20jzv1l"; + fetchSubmodules = true; + } + { + url = "https://github.com/casella/ThermoPower.git"; + rev = "650be2c8cbd5abc3535e92b865e509073afc8aeb"; + sha256 = "08ijrx8xw43dadz5s3kiwa17ax9faq2wyq9gm0vlz9ddbkj0hcaq"; + fetchSubmodules = true; + } + { + url = "https://openmodelica.org/git/ThermoSysPro.git"; + rev = "db81ae1b5a6a85f6c6c7693244cafa6087e18ff5"; + sha256 = "12fsf0xxxc1ja6vmm9ff85f8j5sg1lb7w4g57s2w3fkf4d3a7d0c"; + fetchSubmodules = true; + } + { + url = "https://openmodelica.org/git/ThermoSysPro.git"; + rev = "5cef9acb4dedf8af6f4638a4448f08a544ebd30b"; + sha256 = "0ihnz1s4rs42yis9zym9nw29ia2lqz2yx2wblc50p6f221w7q78s"; + fetchSubmodules = true; + } + { + url = "https://github.com/lenaRB/VVDRlib.git"; + rev = "eae4981674642eddffc7f2aa3690320fcaddee0e"; + sha256 = "0qxxk2xlas5mqyc1h8ndic208qj1sm5mr5y8664kv3py7i8jdqi4"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica/VehicleInterfaces.git"; + rev = "v1.2.5"; + sha256 = "044k17cpc88wprrvw03p6crm6dy6x9a6xj5104d5nln71lqz5sdq"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/WasteWater.git"; + rev = "v2.1.0"; + sha256 = "1dxr4m9j7b5266daj4klbrhvnkqr73sximdw9bk9v5qf0s28li99"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/WindPowerPlants.git"; + rev = "v1.2.0"; + sha256 = "1lyrqwsb6sm1wc7vlj72zk5cpjhhzh27fviiqayddqy2b903xish"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/ipsl.git"; + rev = "v1.1.1"; + sha256 = "1w2iah8c5d8n01wmxydjk0rrcxh88g8yjy2zmv403azcccq7byzp"; + fetchSubmodules = true; + } + { + url = "https://github.com/modelica-3rdparty/netCDF-DataReader.git"; + rev = "v2.5.0"; + sha256 = "1pd5xf5bgz010lryv8bj6lvlfqn9p184csiffwj8icx7rycnlcqb"; + fetchSubmodules = true; + } + { + url = "https://github.com/joewa/open-bldc-modelica.git"; + rev = "58a83b5b36f267613de4676c95163489b1ddc2e7"; + sha256 = "0wf6dn64d2psv9b3xg5227vzpk109r3dqzi4m2wwhrilaxs3v004"; + fetchSubmodules = true; + } ] diff --git a/pkgs/applications/science/misc/openmodelica/omparser/default.nix b/pkgs/applications/science/misc/openmodelica/omparser/default.nix index 03030de2cf486c..7f27de2b457bca 100644 --- a/pkgs/applications/science/misc/openmodelica/omparser/default.nix +++ b/pkgs/applications/science/misc/openmodelica/omparser/default.nix @@ -1,9 +1,10 @@ -{ lib -, pkg-config -, jre8 -, libuuid -, openmodelica -, mkOpenModelicaDerivation +{ + lib, + pkg-config, + jre8, + libuuid, + openmodelica, + mkOpenModelicaDerivation, }: mkOpenModelicaDerivation rec { @@ -13,7 +14,10 @@ mkOpenModelicaDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ jre8 libuuid ]; + buildInputs = [ + jre8 + libuuid + ]; patches = [ ./Makefile.in.patch ]; @@ -22,7 +26,10 @@ mkOpenModelicaDerivation rec { suite"; homepage = "https://openmodelica.org"; license = licenses.gpl3Only; - maintainers = with maintainers; [ balodja smironov ]; + maintainers = with maintainers; [ + balodja + smironov + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/science/misc/openmodelica/omplot/default.nix b/pkgs/applications/science/misc/openmodelica/omplot/default.nix index 51ab89407f4ca3..1469022626ee1a 100644 --- a/pkgs/applications/science/misc/openmodelica/omplot/default.nix +++ b/pkgs/applications/science/misc/openmodelica/omplot/default.nix @@ -1,10 +1,11 @@ -{ lib -, qtbase -, qttools -, qmake -, wrapQtAppsHook -, openmodelica -, mkOpenModelicaDerivation +{ + lib, + qtbase, + qttools, + qmake, + wrapQtAppsHook, + openmodelica, + mkOpenModelicaDerivation, }: mkOpenModelicaDerivation rec { @@ -13,7 +14,12 @@ mkOpenModelicaDerivation rec { omdeps = [ openmodelica.omcompiler ]; omautoconf = true; - nativeBuildInputs = [ qtbase qttools qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qtbase + qttools + qmake + wrapQtAppsHook + ]; postPatch = '' sed -i OMPlot/Makefile.in -e 's|bindir = @includedir@|includedir = @includedir@|' @@ -28,7 +34,10 @@ mkOpenModelicaDerivation rec { description = "Plotting tool for OpenModelica-generated results files"; homepage = "https://openmodelica.org"; license = licenses.gpl3Only; - maintainers = with maintainers; [ balodja smironov ]; + maintainers = with maintainers; [ + balodja + smironov + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/science/misc/openmodelica/omshell/default.nix b/pkgs/applications/science/misc/openmodelica/omshell/default.nix index 3c39d62f92d6f9..cbbf445246870a 100644 --- a/pkgs/applications/science/misc/openmodelica/omshell/default.nix +++ b/pkgs/applications/science/misc/openmodelica/omshell/default.nix @@ -1,4 +1,13 @@ -{ lib, qttools, qmake, qtwebkit, wrapQtAppsHook, readline, openmodelica, mkOpenModelicaDerivation }: +{ + lib, + qttools, + qmake, + qtwebkit, + wrapQtAppsHook, + readline, + openmodelica, + mkOpenModelicaDerivation, +}: mkOpenModelicaDerivation rec { pname = "omshell"; @@ -6,9 +15,15 @@ mkOpenModelicaDerivation rec { omdeps = [ openmodelica.omcompiler ]; omautoconf = true; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; - buildInputs = [ readline qtwebkit ]; + buildInputs = [ + readline + qtwebkit + ]; postPatch = with openmodelica; '' sed -i ''$(find -name qmake.m4) -e '/^\s*LRELEASE=/ s|LRELEASE=.*$|LRELEASE=${lib.getDev qttools}/bin/lrelease|' @@ -34,7 +49,10 @@ mkOpenModelicaDerivation rec { description = "Interactive OpenModelica session shell"; homepage = "https://openmodelica.org"; license = licenses.gpl3Only; - maintainers = with maintainers; [ balodja smironov ]; + maintainers = with maintainers; [ + balodja + smironov + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/science/misc/openmodelica/omsimulator/default.nix b/pkgs/applications/science/misc/openmodelica/omsimulator/default.nix index 9e28e3f21f26da..e344bf2494e328 100644 --- a/pkgs/applications/science/misc/openmodelica/omsimulator/default.nix +++ b/pkgs/applications/science/misc/openmodelica/omsimulator/default.nix @@ -1,11 +1,12 @@ -{ lib -, pkg-config -, boost -, readline -, libxml2 -, openmodelica -, mkOpenModelicaDerivation -, fetchpatch +{ + lib, + pkg-config, + boost, + readline, + libxml2, + openmodelica, + mkOpenModelicaDerivation, + fetchpatch, }: mkOpenModelicaDerivation rec { @@ -24,7 +25,11 @@ mkOpenModelicaDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ readline libxml2 boost ]; + buildInputs = [ + readline + libxml2 + boost + ]; env.CFLAGS = toString [ "-Wno-error=implicit-function-declaration" @@ -34,7 +39,10 @@ mkOpenModelicaDerivation rec { description = "OpenModelica FMI & SSP-based co-simulation environment"; homepage = "https://openmodelica.org"; license = licenses.gpl3Only; - maintainers = with maintainers; [ balodja smironov ]; + maintainers = with maintainers; [ + balodja + smironov + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/science/misc/openmvs/default.nix b/pkgs/applications/science/misc/openmvs/default.nix index 689ce1ad554caf..4ee25e9739e28f 100644 --- a/pkgs/applications/science/misc/openmvs/default.nix +++ b/pkgs/applications/science/misc/openmvs/default.nix @@ -1,23 +1,24 @@ -{ lib -, boost -, breakpad -, ceres-solver -, cgal -, cmake -, eigen -, fetchFromGitHub -, glfw -, gmp -, libjpeg -, libpng -, libtiff -, mpfr -, opencv -, openmp -, pkg-config -, stdenv -, vcg -, zstd +{ + lib, + boost, + breakpad, + ceres-solver, + cgal, + cmake, + eigen, + fetchFromGitHub, + glfw, + gmp, + libjpeg, + libpng, + libtiff, + mpfr, + opencv, + openmp, + pkg-config, + stdenv, + vcg, + zstd, }: let @@ -57,7 +58,10 @@ stdenv.mkDerivation rec { vcg ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; postInstall = '' mv $out/bin/OpenMVS/* $out/bin diff --git a/pkgs/applications/science/misc/rink/default.nix b/pkgs/applications/science/misc/rink/default.nix index c0b33b3cbedb22..1a20a122f39bba 100644 --- a/pkgs/applications/science/misc/rink/default.nix +++ b/pkgs/applications/science/misc/rink/default.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, openssl, pkg-config, ncurses -, curl, installShellFiles, asciidoctor, libiconv, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + openssl, + pkg-config, + ncurses, + curl, + installShellFiles, + asciidoctor, + libiconv, + Security, +}: rustPlatform.buildRustPackage rec { version = "0.8.0"; @@ -14,9 +26,23 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-j1pQfMjDNu57otOBTVBQEZIx80p4/beEUQdUkAJhvso="; - nativeBuildInputs = [ pkg-config installShellFiles asciidoctor ]; - buildInputs = [ ncurses ] - ++ (if stdenv.hostPlatform.isDarwin then [ curl libiconv Security ] else [ openssl ]); + nativeBuildInputs = [ + pkg-config + installShellFiles + asciidoctor + ]; + buildInputs = + [ ncurses ] + ++ ( + if stdenv.hostPlatform.isDarwin then + [ + curl + libiconv + Security + ] + else + [ openssl ] + ); # Some tests fail and/or attempt to use internet servers. doCheck = false; @@ -33,7 +59,13 @@ rustPlatform.buildRustPackage rec { description = "Unit-aware calculator"; mainProgram = "rink"; homepage = "https://rinkcalc.app"; - license = with licenses; [ mpl20 gpl3Plus ]; - maintainers = with maintainers; [ sb0 Br1ght0ne ]; + license = with licenses; [ + mpl20 + gpl3Plus + ]; + maintainers = with maintainers; [ + sb0 + Br1ght0ne + ]; }; } diff --git a/pkgs/applications/science/misc/sasview/default.nix b/pkgs/applications/science/misc/sasview/default.nix index e896b19ede8377..068ee6f4244a14 100644 --- a/pkgs/applications/science/misc/sasview/default.nix +++ b/pkgs/applications/science/misc/sasview/default.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, wrapQtAppsHook +{ + lib, + python3, + fetchFromGitHub, + wrapQtAppsHook, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/applications/science/misc/vite/default.nix b/pkgs/applications/science/misc/vite/default.nix index 8cf8ceb497a846..917dc3d3b6a803 100644 --- a/pkgs/applications/science/misc/vite/default.nix +++ b/pkgs/applications/science/misc/vite/default.nix @@ -1,4 +1,17 @@ -{ stdenv, fetchFromGitLab, lib, cmake, qtbase, qttools, qtcharts, libGLU, libGL, glm, glew, wrapQtAppsHook }: +{ + stdenv, + fetchFromGitLab, + lib, + cmake, + qtbase, + qttools, + qtcharts, + libGLU, + libGL, + glm, + glew, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "vite"; @@ -12,8 +25,19 @@ stdenv.mkDerivation rec { hash = "sha256-Yf2jYALZplIXzVtd/sg6gzEYrZ+oU0zLG1ETd/hiTi0="; }; - nativeBuildInputs = [ cmake qttools wrapQtAppsHook ]; - buildInputs = [ qtbase qtcharts libGLU libGL glm glew ]; + nativeBuildInputs = [ + cmake + qttools + wrapQtAppsHook + ]; + buildInputs = [ + qtbase + qtcharts + libGLU + libGL + glm + glew + ]; meta = { description = "Visual Trace Explorer (ViTE), a tool to visualize execution traces"; diff --git a/pkgs/applications/science/molecular-dynamics/raspa/data.nix b/pkgs/applications/science/molecular-dynamics/raspa/data.nix index 3361393eef158f..642548fca205d6 100644 --- a/pkgs/applications/science/molecular-dynamics/raspa/data.nix +++ b/pkgs/applications/science/molecular-dynamics/raspa/data.nix @@ -1,13 +1,17 @@ -{ lib -, stdenvNoCC -, raspa +{ + lib, + stdenvNoCC, + raspa, }: stdenvNoCC.mkDerivation rec { pname = "raspa-data"; inherit (raspa) version src; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; installPhase = '' runHook preInstall @@ -24,7 +28,10 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { inherit (raspa.meta) homepage license maintainers; description = "Example packs and documentation of RASPA"; - outputsToInstall = [ "out" "doc" ]; + outputsToInstall = [ + "out" + "doc" + ]; platforms = lib.platforms.all; }; } diff --git a/pkgs/applications/science/molecular-dynamics/raspa/default.nix b/pkgs/applications/science/molecular-dynamics/raspa/default.nix index 8fd395f9174d35..3830e3e72e06ca 100644 --- a/pkgs/applications/science/molecular-dynamics/raspa/default.nix +++ b/pkgs/applications/science/molecular-dynamics/raspa/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, makeWrapper -, fftw -, lapack -, openblas -, runCommandLocal -, raspa -, raspa-data +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + makeWrapper, + fftw, + lapack, + openblas, + runCommandLocal, + raspa, + raspa-data, }: stdenv.mkDerivation rec { pname = "raspa"; @@ -56,17 +57,16 @@ stdenv.mkDerivation rec { --set RASPA_DIR "$out" ''; - passthru.tests.run-an-example = runCommandLocal "raspa-test-run-an-example" { } - '' - set -eu -o pipefail - exampleDir="${raspa-data}/share/raspa/examples/Basic/1_MC_Methane_in_Box" - exampleDirWritable="$(basename "$exampleDir")" - cp -rT "$exampleDir" "./$exampleDirWritable" - chmod u+rw -R "$exampleDirWritable" - cd "$exampleDirWritable" - ${raspa}/bin/simulate - touch "$out" - ''; + passthru.tests.run-an-example = runCommandLocal "raspa-test-run-an-example" { } '' + set -eu -o pipefail + exampleDir="${raspa-data}/share/raspa/examples/Basic/1_MC_Methane_in_Box" + exampleDirWritable="$(basename "$exampleDir")" + cp -rT "$exampleDir" "./$exampleDirWritable" + chmod u+rw -R "$exampleDirWritable" + cd "$exampleDirWritable" + ${raspa}/bin/simulate + touch "$out" + ''; meta = with lib; { description = "General purpose classical molecular simulation package"; diff --git a/pkgs/applications/science/physics/MCFM/default.nix b/pkgs/applications/science/physics/MCFM/default.nix index 7b6000dfea8daa..dc508d6eefcf21 100644 --- a/pkgs/applications/science/physics/MCFM/default.nix +++ b/pkgs/applications/science/physics/MCFM/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, cmake, gfortran, lhapdf }: +{ + lib, + stdenv, + fetchurl, + cmake, + gfortran, + lhapdf, +}: stdenv.mkDerivation rec { pname = "MCFM"; @@ -15,7 +22,10 @@ stdenv.mkDerivation rec { 'target_link_libraries(mcfm ''${lhapdf_lib})' ''; - nativeBuildInputs = [ cmake gfortran ]; + nativeBuildInputs = [ + cmake + gfortran + ]; buildInputs = [ lhapdf ]; cmakeFlags = [ diff --git a/pkgs/applications/science/physics/crystfel/default.nix b/pkgs/applications/science/physics/crystfel/default.nix index a8f2b65b669f2f..b5a588757ead38 100644 --- a/pkgs/applications/science/physics/crystfel/default.nix +++ b/pkgs/applications/science/physics/crystfel/default.nix @@ -1,39 +1,40 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitHub -, fetchpatch -, fetchzip -, cmake -, lz4 -, gfortran -, bzip2 -, hdf5 -, gsl -, unzip -, makeWrapper -, zlib -, meson -, ninja -, pandoc -, eigen -, pkg-config -, wrapGAppsHook3 -, flex -, bison -, doxygen -, opencl-headers -, ncurses -, msgpack -, fftw -, zeromq -, ocl-icd -, gtk3 -, gdk-pixbuf -, argp-standalone -, memorymappingHook -, withGui ? true -, withBitshuffle ? true +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + fetchpatch, + fetchzip, + cmake, + lz4, + gfortran, + bzip2, + hdf5, + gsl, + unzip, + makeWrapper, + zlib, + meson, + ninja, + pandoc, + eigen, + pkg-config, + wrapGAppsHook3, + flex, + bison, + doxygen, + opencl-headers, + ncurses, + msgpack, + fftw, + zeromq, + ocl-icd, + gtk3, + gdk-pixbuf, + argp-standalone, + memorymappingHook, + withGui ? true, + withBitshuffle ? true, }: let @@ -44,8 +45,14 @@ let url = "https://ftp.ccp4.ac.uk/opensource/libccp4-${version}.tar.gz"; hash = "sha256-y4E66GYSoIZjKd6rfO6W6sVz2BvlskA0HUD5rVMi/y0="; }; - nativeBuildInputs = [ meson ninja ]; - buildInputs = [ hdf5 gsl ]; + nativeBuildInputs = [ + meson + ninja + ]; + buildInputs = [ + hdf5 + gsl + ]; configureFlags = [ "FFLAGS=-fallow-argument-mismatch" ]; @@ -76,14 +83,17 @@ let version = "7.4.0"; src = if stdenv.hostPlatform.isDarwin then - fetchurl - { - url = "https://www.mrc-lmb.cam.ac.uk/mosflm/mosflm/ver${builtins.replaceStrings [ "." ] [ "" ] version}/pre-built/mosflm-osx-64-noX11.zip"; - sha256 = "1da5wimv3kl8bccp49j69vh8gi28cn7axg59lrmb38s68c618h7j"; - } + fetchurl { + url = "https://www.mrc-lmb.cam.ac.uk/mosflm/mosflm/ver${ + builtins.replaceStrings [ "." ] [ "" ] version + }/pre-built/mosflm-osx-64-noX11.zip"; + sha256 = "1da5wimv3kl8bccp49j69vh8gi28cn7axg59lrmb38s68c618h7j"; + } else fetchurl { - url = "https://www.mrc-lmb.cam.ac.uk/mosflm/mosflm/ver${builtins.replaceStrings [ "." ] [ "" ] version}/pre-built/mosflm-linux-64-noX11.zip"; + url = "https://www.mrc-lmb.cam.ac.uk/mosflm/mosflm/ver${ + builtins.replaceStrings [ "." ] [ "" ] version + }/pre-built/mosflm-linux-64-noX11.zip"; hash = "sha256:1f2qins5kaz5v6mkaclncqpirx3mlz177ywm13py9p6s9mk99g32"; }; mosflmBinary = if stdenv.hostPlatform.isDarwin then "bin/mosflm" else "mosflm-linux-64-noX11"; @@ -95,7 +105,10 @@ let dontBuild = true; - nativeBuildInputs = [ unzip makeWrapper ]; + nativeBuildInputs = [ + unzip + makeWrapper + ]; sourceRoot = "."; @@ -116,7 +129,11 @@ let hash = "sha256-/uZlBwAINSoYqgLQFTMz8rS1Rpadu79JkO6Bu/+Nx9E="; }; - nativeBuildInputs = [ meson pkg-config ninja ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + ]; buildInputs = [ eigen ]; }; @@ -128,7 +145,11 @@ let hash = "sha256-v/SCJiHAV05Lc905y/dE8uBXlW+lLX9wau4XORYdbQg="; }; - nativeBuildInputs = [ meson pkg-config ninja ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + ]; buildInputs = [ eigen ]; }; @@ -140,7 +161,11 @@ let hash = "sha256-EaihnW7p//ecgMn+KKlfmBeXrnAqs+HdhN+ovuSrtiQ="; }; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; buildInputs = [ eigen ]; }; @@ -162,7 +187,11 @@ let ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ hdf5 lz4 bzip2 ]; + buildInputs = [ + hdf5 + lz4 + bzip2 + ]; cmakeFlags = [ "-DENABLE_BITSHUFFLE_PLUGIN=yes" @@ -192,29 +221,43 @@ stdenv.mkDerivation rec { url = "https://www.desy.de/~twhite/crystfel/crystfel-${version}.tar.gz"; sha256 = "sha256-vZuN9dYnowySC/OX0EZB0mbhoBOyRiOWfX9d6sl1lKQ="; }; - nativeBuildInputs = [ meson pkg-config ninja flex bison doxygen opencl-headers makeWrapper ] - ++ lib.optionals withGui [ wrapGAppsHook3 ]; - buildInputs = [ - hdf5 - gsl - ncurses - msgpack - fftw - fdip - zeromq - ocl-icd - libccp4 - mosflm - pinkIndexer - xgandalf - pandoc - ] ++ lib.optionals withGui [ gtk3 gdk-pixbuf ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - argp-standalone - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isAarch64) [ - memorymappingHook - ] - ++ lib.optionals withBitshuffle [ hdf5-external-filter-plugins ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + flex + bison + doxygen + opencl-headers + makeWrapper + ] ++ lib.optionals withGui [ wrapGAppsHook3 ]; + buildInputs = + [ + hdf5 + gsl + ncurses + msgpack + fftw + fdip + zeromq + ocl-icd + libccp4 + mosflm + pinkIndexer + xgandalf + pandoc + ] + ++ lib.optionals withGui [ + gtk3 + gdk-pixbuf + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + argp-standalone + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isAarch64) [ + memorymappingHook + ] + ++ lib.optionals withBitshuffle [ hdf5-external-filter-plugins ]; patches = [ # on darwin at least, we need to link to a separate argp library; diff --git a/pkgs/applications/science/physics/xflr5/default.nix b/pkgs/applications/science/physics/xflr5/default.nix index 3090bcbfecd469..853dc377c5181f 100644 --- a/pkgs/applications/science/physics/xflr5/default.nix +++ b/pkgs/applications/science/physics/xflr5/default.nix @@ -1,4 +1,9 @@ -{ mkDerivation, lib, qmake, fetchsvn }: +{ + mkDerivation, + lib, + qmake, + fetchsvn, +}: mkDerivation rec { pname = "xflr5"; diff --git a/pkgs/applications/science/programming/fdr/default.nix b/pkgs/applications/science/programming/fdr/default.nix index 2237d9528701e4..899a7ca3f13763 100644 --- a/pkgs/applications/science/programming/fdr/default.nix +++ b/pkgs/applications/science/programming/fdr/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, qtbase, qtx11extras, ncurses5, xorg, zlib, python27Packages }: +{ + lib, + stdenv, + fetchurl, + qtbase, + qtx11extras, + ncurses5, + xorg, + zlib, + python27Packages, +}: stdenv.mkDerivation { pname = "fdr"; version = "4.2.7"; diff --git a/pkgs/applications/science/robotics/apmplanner2/default.nix b/pkgs/applications/science/robotics/apmplanner2/default.nix index 34509f05daa3d9..e606edb0fe0ecf 100644 --- a/pkgs/applications/science/robotics/apmplanner2/default.nix +++ b/pkgs/applications/science/robotics/apmplanner2/default.nix @@ -1,6 +1,21 @@ -{ lib, mkDerivation, fetchFromGitHub, qmake -, qtbase, qtscript, qtwebkit, qtserialport, qtsvg, qtdeclarative, qtquickcontrols2 -, alsa-lib, libsndfile, flite, openssl, udev, SDL2 +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qtbase, + qtscript, + qtwebkit, + qtserialport, + qtsvg, + qtdeclarative, + qtquickcontrols2, + alsa-lib, + libsndfile, + flite, + openssl, + udev, + SDL2, }: mkDerivation rec { @@ -15,8 +30,19 @@ mkDerivation rec { }; buildInputs = [ - alsa-lib libsndfile flite openssl udev SDL2 - qtbase qtscript qtwebkit qtserialport qtsvg qtdeclarative qtquickcontrols2 + alsa-lib + libsndfile + flite + openssl + udev + SDL2 + qtbase + qtscript + qtwebkit + qtserialport + qtsvg + qtdeclarative + qtquickcontrols2 ]; nativeBuildInputs = [ qmake ]; diff --git a/pkgs/applications/science/robotics/mavproxy/default.nix b/pkgs/applications/science/robotics/mavproxy/default.nix index bae3f747ba1a18..bca0c81a7b706c 100644 --- a/pkgs/applications/science/robotics/mavproxy/default.nix +++ b/pkgs/applications/science/robotics/mavproxy/default.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, buildPythonApplication -, fetchFromGitHub -, lxml -, matplotlib -, numpy -, opencv-python -, pymavlink -, pyserial -, setuptools -, wxpython -, billiard -, gnureadline +{ + stdenv, + lib, + buildPythonApplication, + fetchFromGitHub, + lxml, + matplotlib, + numpy, + opencv-python, + pymavlink, + pyserial, + setuptools, + wxpython, + billiard, + gnureadline, }: buildPythonApplication rec { @@ -25,16 +26,21 @@ buildPythonApplication rec { hash = "sha256-A7tqV1kBCSuWHJUTdUZGcPY/r7X1edGZs6xDctpMbMI="; }; - propagatedBuildInputs = [ - lxml - matplotlib - numpy - opencv-python - pymavlink - pyserial - setuptools - wxpython - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ billiard gnureadline ]; + propagatedBuildInputs = + [ + lxml + matplotlib + numpy + opencv-python + pymavlink + pyserial + setuptools + wxpython + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + billiard + gnureadline + ]; # No tests doCheck = false; diff --git a/pkgs/applications/science/robotics/sumorobot-manager/default.nix b/pkgs/applications/science/robotics/sumorobot-manager/default.nix index a26bd5d5fc288b..32f442fc688a90 100644 --- a/pkgs/applications/science/robotics/sumorobot-manager/default.nix +++ b/pkgs/applications/science/robotics/sumorobot-manager/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, python3, qt5, fetchFromGitHub, wrapPython, pyqt5, pyserial, dos2unix }: +{ + lib, + stdenv, + python3, + qt5, + fetchFromGitHub, + wrapPython, + pyqt5, + pyserial, + dos2unix, +}: stdenv.mkDerivation rec { pname = "sumorobot-manager"; @@ -13,10 +23,15 @@ stdenv.mkDerivation rec { buildInputs = [ python3 ]; pythonPath = [ - pyqt5.dev pyserial + pyqt5.dev + pyserial ]; - nativeBuildInputs = [ wrapPython qt5.wrapQtAppsHook dos2unix ]; + nativeBuildInputs = [ + wrapPython + qt5.wrapQtAppsHook + dos2unix + ]; dontBuild = true; diff --git a/pkgs/applications/search/recoll/default.nix b/pkgs/applications/search/recoll/default.nix index 21618f8ed3eccc..c5ad07c625303d 100644 --- a/pkgs/applications/search/recoll/default.nix +++ b/pkgs/applications/search/recoll/default.nix @@ -1,74 +1,76 @@ -{ stdenv -, fetchurl -, lib -, mkDerivation -, antiword -, aspell -, bison -, catdoc -, catdvi -, chmlib -, djvulibre -, file -, gawk -, ghostscript -, gnugrep -, gnused -, gnutar -, groff -, gzip -, libiconv -, libwpd -, libxslt -, lyx -, makeWrapper -, meson -, ninja -, perl -, perlPackages -, pkg-config -, poppler_utils -, python3Packages -, qtbase -, qttools -, unrtf -, untex -, unzip -, which -, xapian -, zlib -, withGui ? true -, withPython ? with stdenv; buildPlatform.canExecute hostPlatform +{ + stdenv, + fetchurl, + lib, + mkDerivation, + antiword, + aspell, + bison, + catdoc, + catdvi, + chmlib, + djvulibre, + file, + gawk, + ghostscript, + gnugrep, + gnused, + gnutar, + groff, + gzip, + libiconv, + libwpd, + libxslt, + lyx, + makeWrapper, + meson, + ninja, + perl, + perlPackages, + pkg-config, + poppler_utils, + python3Packages, + qtbase, + qttools, + unrtf, + untex, + unzip, + which, + xapian, + zlib, + withGui ? true, + withPython ? with stdenv; buildPlatform.canExecute hostPlatform, }: -let filters = { - # "binary-name = package" where: - # - "${package}/bin/${binary-name}" is the full path to the binary - # - occurrences of `"${binary-name}"` in recoll's filters should be fixed up - awk = gawk; - antiword = antiword; - catppt = catdoc; - catdvi = catdvi; - djvused = djvulibre; - djvutxt = djvulibre; - egrep = gnugrep; - groff = groff; - gunzip = gzip; - iconv = libiconv; - pdftotext = poppler_utils; - ps2ascii = ghostscript; - sed = gnused; - tar = gnutar; - unzip = unzip; - xls2csv = catdoc; - xsltproc = libxslt; - unrtf = unrtf; - untex = untex; - wpd2html = libwpd; - perl = perl.passthru.withPackages (p: [ p.ImageExifTool ]); - }; - filterPath = lib.makeBinPath (map lib.getBin (builtins.attrValues filters)); - useInotify = if stdenv.hostPlatform.isLinux then "true" else "false"; +let + filters = { + # "binary-name = package" where: + # - "${package}/bin/${binary-name}" is the full path to the binary + # - occurrences of `"${binary-name}"` in recoll's filters should be fixed up + awk = gawk; + antiword = antiword; + catppt = catdoc; + catdvi = catdvi; + djvused = djvulibre; + djvutxt = djvulibre; + egrep = gnugrep; + groff = groff; + gunzip = gzip; + iconv = libiconv; + pdftotext = poppler_utils; + ps2ascii = ghostscript; + sed = gnused; + tar = gnutar; + unzip = unzip; + xls2csv = catdoc; + xsltproc = libxslt; + unrtf = unrtf; + untex = untex; + wpd2html = libwpd; + perl = perl.passthru.withPackages (p: [ p.ImageExifTool ]); + }; + filterPath = lib.makeBinPath (map lib.getBin (builtins.attrValues filters)); + useInotify = if stdenv.hostPlatform.isLinux then "true" else "false"; in mkDerivation rec { @@ -80,25 +82,29 @@ mkDerivation rec { hash = "sha256-Eeadj/AnuztCb7VIYEy4hKbduH3CzK53tADvI9+PWmQ="; }; - mesonFlags = [ - "-Drecollq=true" - "-Dwebkit=false" - "-Dsystemd=false" - - # this leaks into the final `librecoll-*.so` binary, so we need - # to be sure it is taken from `pkgs.file` rather than `stdenv`, - # especially when cross-compiling - "-Dfile-command=${file}/bin/file" - - ] ++ lib.optionals (!withPython) [ - "-Dpython-module=false" - "-Dpython-chm=false" - ] ++ lib.optionals (!withGui) [ - "-Dqtgui=false" - "-Dx11mon=false" - ] ++ [ - "-Dinotify=${useInotify}" - ]; + mesonFlags = + [ + "-Drecollq=true" + "-Dwebkit=false" + "-Dsystemd=false" + + # this leaks into the final `librecoll-*.so` binary, so we need + # to be sure it is taken from `pkgs.file` rather than `stdenv`, + # especially when cross-compiling + "-Dfile-command=${file}/bin/file" + + ] + ++ lib.optionals (!withPython) [ + "-Dpython-module=false" + "-Dpython-chm=false" + ] + ++ lib.optionals (!withGui) [ + "-Dqtgui=false" + "-Dx11mon=false" + ] + ++ [ + "-Dinotify=${useInotify}" + ]; env.NIX_CFLAGS_COMPILE = toString [ "-DNIXPKGS" @@ -112,35 +118,43 @@ mkDerivation rec { ./0001-no-qtgui-darwin-bundle.patch ]; - nativeBuildInputs = [ - makeWrapper - meson - ninja - pkg-config - which - ] ++ lib.optionals withGui [ - qtbase - qttools - ] ++ lib.optionals withPython [ - python3Packages.setuptools - ]; - - buildInputs = [ - aspell - bison - chmlib - ] ++ lib.optionals withPython [ - python3Packages.python - python3Packages.mutagen - ] ++ [ - xapian - zlib - file - ] ++ lib.optionals withGui [ - qtbase - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - ]; + nativeBuildInputs = + [ + makeWrapper + meson + ninja + pkg-config + which + ] + ++ lib.optionals withGui [ + qtbase + qttools + ] + ++ lib.optionals withPython [ + python3Packages.setuptools + ]; + + buildInputs = + [ + aspell + bison + chmlib + ] + ++ lib.optionals withPython [ + python3Packages.python + python3Packages.mutagen + ] + ++ [ + xapian + zlib + file + ] + ++ lib.optionals withGui [ + qtbase + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + ]; qtWrapperArgs = [ "--prefix PATH : ${filterPath}" @@ -149,30 +163,39 @@ mkDerivation rec { # the filters search through ${PATH} using a sh proc 'checkcmds' for the # filtering utils. Short circuit this by replacing the filtering command with # the absolute path to the filtering command. - postInstall = '' - substituteInPlace $out/lib/*/site-packages/recoll/rclconfig.py --replace /usr/share/recoll $out/share/recoll - substituteInPlace $out/share/recoll/filters/rclconfig.py --replace /usr/share/recoll $out/share/recoll - for f in $out/share/recoll/filters/* ; do - if [[ ! "$f" =~ \.zip$ ]]; then - '' + lib.concatStrings (lib.mapAttrsToList (k: v: ('' + postInstall = + '' + substituteInPlace $out/lib/*/site-packages/recoll/rclconfig.py --replace /usr/share/recoll $out/share/recoll + substituteInPlace $out/share/recoll/filters/rclconfig.py --replace /usr/share/recoll $out/share/recoll + for f in $out/share/recoll/filters/* ; do + if [[ ! "$f" =~ \.zip$ ]]; then + '' + + lib.concatStrings ( + lib.mapAttrsToList (k: v: ('' substituteInPlace $f --replace '"${k}"' '"${lib.getBin v}/bin/${k}"' - '')) filters) + '' - substituteInPlace $f --replace '"pstotext"' '"${lib.getBin ghostscript}/bin/ps2ascii"' - substituteInPlace $f --replace /usr/bin/perl ${lib.getBin (perl.passthru.withPackages (p: [ p.ImageExifTool ]))}/bin/perl - fi - done - wrapProgram $out/share/recoll/filters/rclaudio.py \ - --prefix PYTHONPATH : $PYTHONPATH - wrapProgram $out/share/recoll/filters/rcljoplin.py \ - --prefix PYTHONPATH : $out/${python3Packages.python.sitePackages} - wrapProgram $out/share/recoll/filters/rclimg \ - --prefix PERL5LIB : "${with perlPackages; makeFullPerlPath [ ImageExifTool ]}" - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace $f --replace '"lyx"' '"${lib.getBin lyx}/bin/lyx"' - '' + lib.optionalString (stdenv.hostPlatform.isDarwin && withGui) '' - mkdir $out/Applications - mv $out/bin/recoll.app $out/Applications - ''; + '')) filters + ) + + '' + substituteInPlace $f --replace '"pstotext"' '"${lib.getBin ghostscript}/bin/ps2ascii"' + substituteInPlace $f --replace /usr/bin/perl ${ + lib.getBin (perl.passthru.withPackages (p: [ p.ImageExifTool ])) + }/bin/perl + fi + done + wrapProgram $out/share/recoll/filters/rclaudio.py \ + --prefix PYTHONPATH : $PYTHONPATH + wrapProgram $out/share/recoll/filters/rcljoplin.py \ + --prefix PYTHONPATH : $out/${python3Packages.python.sitePackages} + wrapProgram $out/share/recoll/filters/rclimg \ + --prefix PERL5LIB : "${with perlPackages; makeFullPerlPath [ ImageExifTool ]}" + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace $f --replace '"lyx"' '"${lib.getBin lyx}/bin/lyx"' + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin && withGui) '' + mkdir $out/Applications + mv $out/bin/recoll.app $out/Applications + ''; # create symlink after fixup to prevent double wrapping of recoll postFixup = lib.optionalString (stdenv.hostPlatform.isDarwin && withGui) '' @@ -191,7 +214,10 @@ mkDerivation rec { changelog = "https://www.recoll.org/pages/release-history.html"; license = licenses.gpl2Plus; platforms = platforms.unix; - maintainers = with maintainers; [ jcumming ehmry ]; + maintainers = with maintainers; [ + jcumming + ehmry + ]; # `Makefile.am` assumes the ability to run the hostPlatform's python binary at build time broken = withPython && (with stdenv; !buildPlatform.canExecute hostPlatform); diff --git a/pkgs/applications/system/monitor/default.nix b/pkgs/applications/system/monitor/default.nix index fada61d6b6a412..635aa584371d6d 100644 --- a/pkgs/applications/system/monitor/default.nix +++ b/pkgs/applications/system/monitor/default.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, gitUpdater -, meson -, ninja -, vala -, pkg-config -, pantheon -, python3 -, curl -, flatpak -, gettext -, glib -, gtk3 -, json-glib -, libwnck -, libgee -, libgtop -, libhandy -, sassc -, udisks2 -, wrapGAppsHook3 -, libX11 -, libXext -, libXNVCtrl +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + meson, + ninja, + vala, + pkg-config, + pantheon, + python3, + curl, + flatpak, + gettext, + glib, + gtk3, + json-glib, + libwnck, + libgee, + libgtop, + libhandy, + sassc, + udisks2, + wrapGAppsHook3, + libX11, + libXext, + libXNVCtrl, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/system/qjournalctl/default.nix b/pkgs/applications/system/qjournalctl/default.nix index fc80c3f69df817..972f688d95962d 100644 --- a/pkgs/applications/system/qjournalctl/default.nix +++ b/pkgs/applications/system/qjournalctl/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, qtbase -, qmake -, pkg-config -, libssh -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + qtbase, + qmake, + pkg-config, + libssh, + wrapQtAppsHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/system/systemdgenie/default.nix b/pkgs/applications/system/systemdgenie/default.nix index c8d747a8e12202..0131be7ebc71fd 100644 --- a/pkgs/applications/system/systemdgenie/default.nix +++ b/pkgs/applications/system/systemdgenie/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, cmake -, extra-cmake-modules -, kxmlgui -, fetchFromGitLab -, kdelibs4support -, wrapQtAppsHook +{ + stdenv, + lib, + cmake, + extra-cmake-modules, + kxmlgui, + fetchFromGitLab, + kdelibs4support, + wrapQtAppsHook, }: -stdenv.mkDerivation rec{ +stdenv.mkDerivation rec { pname = "systemdgenie"; version = "0.99.0"; src = fetchFromGitLab { @@ -18,9 +19,16 @@ stdenv.mkDerivation rec{ hash = "sha256-y+A2OuK1ZooPY5W0SsXEb1aaOAJ2b7QSwiumolmAaR4="; }; - nativeBuildInputs = [ cmake extra-cmake-modules wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + wrapQtAppsHook + ]; - buildInputs = [ kxmlgui kdelibs4support ]; + buildInputs = [ + kxmlgui + kdelibs4support + ]; meta = with lib; { description = "Systemd management utility"; diff --git a/pkgs/applications/terminal-emulators/cool-retro-term/default.nix b/pkgs/applications/terminal-emulators/cool-retro-term/default.nix index c2a87108583181..5386ae950e3454 100644 --- a/pkgs/applications/terminal-emulators/cool-retro-term/default.nix +++ b/pkgs/applications/terminal-emulators/cool-retro-term/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, mkDerivation -, qtbase -, qmltermwidget -, qtquickcontrols2 -, qtgraphicaleffects -, qmake -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + mkDerivation, + qtbase, + qmltermwidget, + qtquickcontrols2, + qtgraphicaleffects, + qmake, + nixosTests, }: mkDerivation rec { @@ -36,13 +37,15 @@ mkDerivation rec { installFlags = [ "INSTALL_ROOT=$(out)" ]; - preFixup = '' - mv $out/usr/share $out/share - mv $out/usr/bin $out/bin - rmdir $out/usr - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - ln -s $out/bin/cool-retro-term.app/Contents/MacOS/cool-retro-term $out/bin/cool-retro-term - ''; + preFixup = + '' + mv $out/usr/share $out/share + mv $out/usr/bin $out/bin + rmdir $out/usr + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + ln -s $out/bin/cool-retro-term.app/Contents/MacOS/cool-retro-term $out/bin/cool-retro-term + ''; passthru.tests.test = nixosTests.terminal-emulators.cool-retro-term; diff --git a/pkgs/applications/terminal-emulators/mlterm/default.nix b/pkgs/applications/terminal-emulators/mlterm/default.nix index dcf581f27a80c5..25f5d5333886fd 100644 --- a/pkgs/applications/terminal-emulators/mlterm/default.nix +++ b/pkgs/applications/terminal-emulators/mlterm/default.nix @@ -1,102 +1,105 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, autoconf -, makeDesktopItem -, nixosTests -, vte -, harfbuzz # can be replaced with libotf -, fribidi -, m17n_lib -, libssh2 #build-in ssh -, fcitx5 -, fcitx5-gtk -, ibus -, uim #IME -, wrapGAppsHook3 #color picker in mlconfig -, gdk-pixbuf -, gtk3 -, gtk ? gtk3 -# List of gui libraries to use. According to `./configure --help` ran on -# release 3.9.3, options are: (xlib|win32|fb|quartz|console|wayland|sdl2|beos) -, enableGuis ? { - xlib = enableX11; - # From some reason, upstream's ./configure script disables compilation of the - # external tool `mlconfig` if `enableGuis.fb == true`. This behavior is not - # documentd in `./configure --help`, and it is reported here: - # https://github.com/arakiken/mlterm/issues/73 - fb = false; - quartz = stdenv.hostPlatform.isDarwin; - wayland = stdenv.hostPlatform.isLinux; - sdl2 = true; -} -, libxkbcommon -, wayland # for the "wayland" --with-gui option -, SDL2 # for the "sdl" --with-gui option -# List of typing engines, the default list enables compiling all of the -# available ones, as recorded on release 3.9.3 -, enableTypeEngines ? { - xcore = false; # Considered legacy - xft = enableX11; - cairo = true; -} -, libX11 -, libXft -, cairo -# List of external tools to create, this default list includes all default -# tools, as recorded on release 3.9.3. -, enableTools ? { - mlclient = true; - mlconfig = true; - mlcc = true; - mlterm-menu = true; - # Note that according to upstream's ./configure script, to disable - # mlimgloader you have to disable _all_ tools. See: - # https://github.com/arakiken/mlterm/issues/69 - mlimgloader = true; - registobmp = true; - mlfc = true; -} -# Whether to enable the X window system -, enableX11 ? stdenv.hostPlatform.isLinux -# Most of the input methods and other build features are enabled by default, -# the following attribute set can be used to disable some of them. It's parsed -# when we set `configureFlags`. If you find other configure Flags that require -# dependencies, it'd be nice to make that contribution here. -, enableFeatures ? { - uim = !stdenv.hostPlatform.isDarwin; - ibus = !stdenv.hostPlatform.isDarwin; - fcitx = !stdenv.hostPlatform.isDarwin; - m17n = !stdenv.hostPlatform.isDarwin; - ssh2 = true; - bidi = true; - # Open Type layout support, (substituting glyphs with opentype fonts) - otl = true; -} -# Configure the Exec directive in the generated .desktop file -, desktopBinary ? ( - if enableGuis.xlib then - "mlterm" - else if enableGuis.wayland then - "mlterm-wl" - else if enableGuis.sdl2 then - "mlterm-sdl2" - else - throw "mlterm: couldn't figure out what desktopBinary to use." - ) +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + autoconf, + makeDesktopItem, + nixosTests, + vte, + harfbuzz, # can be replaced with libotf + fribidi, + m17n_lib, + libssh2, # build-in ssh + fcitx5, + fcitx5-gtk, + ibus, + uim, # IME + wrapGAppsHook3, # color picker in mlconfig + gdk-pixbuf, + gtk3, + gtk ? gtk3, + # List of gui libraries to use. According to `./configure --help` ran on + # release 3.9.3, options are: (xlib|win32|fb|quartz|console|wayland|sdl2|beos) + enableGuis ? { + xlib = enableX11; + # From some reason, upstream's ./configure script disables compilation of the + # external tool `mlconfig` if `enableGuis.fb == true`. This behavior is not + # documentd in `./configure --help`, and it is reported here: + # https://github.com/arakiken/mlterm/issues/73 + fb = false; + quartz = stdenv.hostPlatform.isDarwin; + wayland = stdenv.hostPlatform.isLinux; + sdl2 = true; + }, + libxkbcommon, + wayland, # for the "wayland" --with-gui option + SDL2, # for the "sdl" --with-gui option + # List of typing engines, the default list enables compiling all of the + # available ones, as recorded on release 3.9.3 + enableTypeEngines ? { + xcore = false; # Considered legacy + xft = enableX11; + cairo = true; + }, + libX11, + libXft, + cairo, + # List of external tools to create, this default list includes all default + # tools, as recorded on release 3.9.3. + enableTools ? { + mlclient = true; + mlconfig = true; + mlcc = true; + mlterm-menu = true; + # Note that according to upstream's ./configure script, to disable + # mlimgloader you have to disable _all_ tools. See: + # https://github.com/arakiken/mlterm/issues/69 + mlimgloader = true; + registobmp = true; + mlfc = true; + }, + # Whether to enable the X window system + enableX11 ? stdenv.hostPlatform.isLinux, + # Most of the input methods and other build features are enabled by default, + # the following attribute set can be used to disable some of them. It's parsed + # when we set `configureFlags`. If you find other configure Flags that require + # dependencies, it'd be nice to make that contribution here. + enableFeatures ? { + uim = !stdenv.hostPlatform.isDarwin; + ibus = !stdenv.hostPlatform.isDarwin; + fcitx = !stdenv.hostPlatform.isDarwin; + m17n = !stdenv.hostPlatform.isDarwin; + ssh2 = true; + bidi = true; + # Open Type layout support, (substituting glyphs with opentype fonts) + otl = true; + }, + # Configure the Exec directive in the generated .desktop file + desktopBinary ? ( + if enableGuis.xlib then + "mlterm" + else if enableGuis.wayland then + "mlterm-wl" + else if enableGuis.sdl2 then + "mlterm-sdl2" + else + throw "mlterm: couldn't figure out what desktopBinary to use." + ), }: let # Returns a --with-feature=, or `--without-feature` if all attributes are false or don't # exist. Used later in configureFlags - withFeaturesList = featureName: attrset: let - commaSepList = lib.concatStringsSep "," (builtins.attrNames (lib.filterAttrs (n: v: v) attrset)); - in - lib.withFeatureAs (commaSepList != "") featureName commaSepList - ; -in stdenv.mkDerivation (finalAttrs: { + withFeaturesList = + featureName: attrset: + let + commaSepList = lib.concatStringsSep "," (builtins.attrNames (lib.filterAttrs (n: v: v) attrset)); + in + lib.withFeatureAs (commaSepList != "") featureName commaSepList; +in +stdenv.mkDerivation (finalAttrs: { pname = "mlterm"; version = "3.9.3"; @@ -107,43 +110,58 @@ in stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-gfs5cdwUUwSBWwJJSaxrQGWJvLkI27RMlk5QvDALEDg="; }; - nativeBuildInputs = [ - pkg-config - autoconf - ] ++ lib.optionals enableTools.mlconfig [ - wrapGAppsHook3 - ]; - buildInputs = [ - gtk - vte - gdk-pixbuf - ] ++ lib.optionals enableTypeEngines.xcore [ - libX11 - ] ++ lib.optionals enableTypeEngines.xft [ - libXft - ] ++ lib.optionals enableTypeEngines.cairo [ - cairo - ] ++ lib.optionals enableGuis.wayland [ - libxkbcommon - wayland - ] ++ lib.optionals enableGuis.sdl2 [ - SDL2 - ] ++ lib.optionals enableFeatures.otl [ - harfbuzz - ] ++ lib.optionals enableFeatures.bidi [ - fribidi - ] ++ lib.optionals enableFeatures.ssh2 [ - libssh2 - ] ++ lib.optionals enableFeatures.m17n [ - m17n_lib - ] ++ lib.optionals enableFeatures.fcitx [ - fcitx5 - fcitx5-gtk - ] ++ lib.optionals enableFeatures.ibus [ - ibus - ] ++ lib.optionals enableFeatures.uim [ - uim - ]; + nativeBuildInputs = + [ + pkg-config + autoconf + ] + ++ lib.optionals enableTools.mlconfig [ + wrapGAppsHook3 + ]; + buildInputs = + [ + gtk + vte + gdk-pixbuf + ] + ++ lib.optionals enableTypeEngines.xcore [ + libX11 + ] + ++ lib.optionals enableTypeEngines.xft [ + libXft + ] + ++ lib.optionals enableTypeEngines.cairo [ + cairo + ] + ++ lib.optionals enableGuis.wayland [ + libxkbcommon + wayland + ] + ++ lib.optionals enableGuis.sdl2 [ + SDL2 + ] + ++ lib.optionals enableFeatures.otl [ + harfbuzz + ] + ++ lib.optionals enableFeatures.bidi [ + fribidi + ] + ++ lib.optionals enableFeatures.ssh2 [ + libssh2 + ] + ++ lib.optionals enableFeatures.m17n [ + m17n_lib + ] + ++ lib.optionals enableFeatures.fcitx [ + fcitx5 + fcitx5-gtk + ] + ++ lib.optionals enableFeatures.ibus [ + ibus + ] + ++ lib.optionals enableFeatures.uim [ + uim + ]; #bad configure.ac and Makefile.in everywhere preConfigure = '' @@ -169,27 +187,33 @@ in stdenv.mkDerivation (finalAttrs: { NIX_CFLAGS_COMPILE = "-Wno-error=int-conversion -Wno-error=incompatible-function-pointer-types"; }; - configureFlags = [ - (withFeaturesList "type-engines" enableTypeEngines) - (withFeaturesList "tools" enableTools) - (withFeaturesList "gui" enableGuis) - (lib.withFeature enableX11 "x") - ] ++ lib.optionals (gtk != null) [ - "--with-gtk=${lib.versions.major gtk.version}.0" - ] ++ (lib.mapAttrsToList (n: v: lib.enableFeature v n) enableFeatures) ++ [ - ]; + configureFlags = + [ + (withFeaturesList "type-engines" enableTypeEngines) + (withFeaturesList "tools" enableTools) + (withFeaturesList "gui" enableGuis) + (lib.withFeature enableX11 "x") + ] + ++ lib.optionals (gtk != null) [ + "--with-gtk=${lib.versions.major gtk.version}.0" + ] + ++ (lib.mapAttrsToList (n: v: lib.enableFeature v n) enableFeatures) + ++ [ + ]; enableParallelBuilding = true; - postInstall = '' - install -D contrib/icon/mlterm-icon.svg "$out/share/icons/hicolor/scalable/apps/mlterm.svg" - install -D contrib/icon/mlterm-icon-gnome2.png "$out/share/icons/hicolor/48x48/apps/mlterm.png" - install -D -t $out/share/applications $desktopItem/share/applications/* - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/Applications/ - cp -a cocoa/mlterm.app $out/Applications/ - install $out/bin/mlterm -Dt $out/Applications/mlterm.app/Contents/MacOS/ - ''; + postInstall = + '' + install -D contrib/icon/mlterm-icon.svg "$out/share/icons/hicolor/scalable/apps/mlterm.svg" + install -D contrib/icon/mlterm-icon-gnome2.png "$out/share/icons/hicolor/48x48/apps/mlterm.png" + install -D -t $out/share/applications $desktopItem/share/applications/* + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/Applications/ + cp -a cocoa/mlterm.app $out/Applications/ + install $out/bin/mlterm -Dt $out/Applications/mlterm.app/Contents/MacOS/ + ''; desktopItem = makeDesktopItem { name = "mlterm"; @@ -199,7 +223,10 @@ in stdenv.mkDerivation (finalAttrs: { comment = "Multi Lingual TERMinal emulator"; desktopName = "mlterm"; genericName = "Terminal emulator"; - categories = [ "System" "TerminalEmulator" ]; + categories = [ + "System" + "TerminalEmulator" + ]; startupNotify = false; }; @@ -210,14 +237,18 @@ in stdenv.mkDerivation (finalAttrs: { enableTools enableGuis enableFeatures - ; + ; }; meta = with lib; { description = "Multi Lingual TERMinal emulator"; homepage = "https://mlterm.sourceforge.net/"; license = licenses.bsd3; - maintainers = with maintainers; [ ramkromberg atemu doronbehar ]; + maintainers = with maintainers; [ + ramkromberg + atemu + doronbehar + ]; platforms = platforms.all; mainProgram = desktopBinary; }; diff --git a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-autocomplete-all-the-things/default.nix b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-autocomplete-all-the-things/default.nix index 6217bc0659a221..192b98d32a49df 100644 --- a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-autocomplete-all-the-things/default.nix +++ b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-autocomplete-all-the-things/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "urxvt-autocomplete-all-the-things"; @@ -24,4 +28,3 @@ stdenv.mkDerivation rec { platforms = with platforms; unix; }; } - diff --git a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-bidi/default.nix b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-bidi/default.nix index cb3843cb61ea8b..ec2d08862ecd33 100644 --- a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-bidi/default.nix +++ b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-bidi/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, perlPackages, pkg-config, fribidi }: +{ + lib, + fetchurl, + perlPackages, + pkg-config, + fribidi, +}: perlPackages.buildPerlPackage rec { pname = "urxvt-bidi"; @@ -9,7 +15,10 @@ perlPackages.buildPerlPackage rec { sha256 = "1w65xbi4mw5acsrpv3phyzv82ghb29kpbb3b1b1gcinlfxl6f61m"; }; - nativeBuildInputs = [ pkg-config perlPackages.ExtUtilsPkgConfig ]; + nativeBuildInputs = [ + pkg-config + perlPackages.ExtUtilsPkgConfig + ]; buildInputs = [ fribidi ]; postInstall = '' diff --git a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-font-size/default.nix b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-font-size/default.nix index fa356081a87035..9a32da5427e75e 100644 --- a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-font-size/default.nix +++ b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-font-size/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, xrdb, xlsfonts }: +{ + lib, + stdenv, + fetchFromGitHub, + xrdb, + xlsfonts, +}: stdenv.mkDerivation rec { pname = "urxvt-font-size"; diff --git a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-perl/default.nix b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-perl/default.nix index 64a1ed125ac806..0fb6958f6dda8a 100644 --- a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-perl/default.nix +++ b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-perl/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, wmctrl }: +{ + lib, + stdenv, + fetchFromGitHub, + wmctrl, +}: stdenv.mkDerivation { pname = "urxvt-perl"; diff --git a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-perls/default.nix b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-perls/default.nix index 33bf75c841bf38..1055f7ba19c84d 100644 --- a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-perls/default.nix +++ b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-perls/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "urxvt-perls"; diff --git a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-resize-font/default.nix b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-resize-font/default.nix index 95b369b70f99cb..8b71ccae908542 100644 --- a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-resize-font/default.nix +++ b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-resize-font/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "urxvt-resize-font"; diff --git a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-tabbedex/default.nix b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-tabbedex/default.nix index 4fc32f55e070ca..0c9eec816abb69 100644 --- a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-tabbedex/default.nix +++ b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-tabbedex/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation rec { pname = "urxvt-tabbedex"; diff --git a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-theme-switch/default.nix b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-theme-switch/default.nix index 2bfc9669338ad4..c356ee687e79dd 100644 --- a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-theme-switch/default.nix +++ b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-theme-switch/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "urxvt-theme-switch"; diff --git a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-vtwheel/default.nix b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-vtwheel/default.nix index 7d3d69122f6277..0bdddaa88cb230 100644 --- a/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-vtwheel/default.nix +++ b/pkgs/applications/terminal-emulators/rxvt-unicode-plugins/urxvt-vtwheel/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchgit, perl }: +{ + lib, + stdenv, + fetchgit, + perl, +}: stdenv.mkDerivation { pname = "rxvt-unicode-vtwheel"; diff --git a/pkgs/applications/terminal-emulators/rxvt-unicode/default.nix b/pkgs/applications/terminal-emulators/rxvt-unicode/default.nix index a39099cc4bd46d..e380fe052d266a 100644 --- a/pkgs/applications/terminal-emulators/rxvt-unicode/default.nix +++ b/pkgs/applications/terminal-emulators/rxvt-unicode/default.nix @@ -1,13 +1,26 @@ -{ lib, stdenv, fetchurl, fetchpatch, makeDesktopItem -, libX11, libXt, libXft, libXrender, libXext -, ncurses, fontconfig, freetype -, pkg-config, gdk-pixbuf, perl -, libptytty -, perlSupport ? true -, gdkPixbufSupport ? true -, unicode3Support ? true -, emojiSupport ? false -, nixosTests +{ + lib, + stdenv, + fetchurl, + fetchpatch, + makeDesktopItem, + libX11, + libXt, + libXft, + libXrender, + libXext, + ncurses, + fontconfig, + freetype, + pkg-config, + gdk-pixbuf, + perl, + libptytty, + perlSupport ? true, + gdkPixbufSupport ? true, + unicode3Support ? true, + emojiSupport ? false, + nixosTests, }: let @@ -22,10 +35,19 @@ let comment = description; desktopName = "URxvt"; genericName = pname; - categories = [ "System" "TerminalEmulator" ]; + categories = [ + "System" + "TerminalEmulator" + ]; }; - fetchPatchFromAUR = { package, name, rev, sha256 }: + fetchPatchFromAUR = + { + package, + name, + rev, + sha256, + }: fetchpatch rec { url = "https://aur.archlinux.org/cgit/aur.git/plain/${name}?h=${package}&id=${rev}"; extraPrefix = ""; @@ -44,39 +66,61 @@ stdenv.mkDerivation { nativeBuildInputs = [ pkg-config ]; buildInputs = - [ libX11 libXt libXft ncurses # required to build the terminfo file - fontconfig freetype libXrender + [ + libX11 + libXt + libXft + ncurses # required to build the terminfo file + fontconfig + freetype + libXrender libptytty - ] ++ lib.optionals perlSupport [ perl libXext ] - ++ lib.optional gdkPixbufSupport gdk-pixbuf; + ] + ++ lib.optionals perlSupport [ + perl + libXext + ] + ++ lib.optional gdkPixbufSupport gdk-pixbuf; - outputs = [ "out" "terminfo" ]; + outputs = [ + "out" + "terminfo" + ]; - patches = (if emojiSupport then [ - # the required patches to libXft are in nixpkgs by default, see - # ../../../servers/x11/xorg/overrides.nix - (fetchPatchFromAUR { - name = "enable-wide-glyphs.patch"; - package = "rxvt-unicode-truecolor-wide-glyphs"; - rev = "69701a09c2c206233952b84bc966407f6774f1dc"; - sha256 = "0jfcj0ahky4dxdfrhqvh1v83mblhf5nak56dk1vq3bhyifdg7ffq"; + patches = + ( + if emojiSupport then + [ + # the required patches to libXft are in nixpkgs by default, see + # ../../../servers/x11/xorg/overrides.nix + (fetchPatchFromAUR { + name = "enable-wide-glyphs.patch"; + package = "rxvt-unicode-truecolor-wide-glyphs"; + rev = "69701a09c2c206233952b84bc966407f6774f1dc"; + sha256 = "0jfcj0ahky4dxdfrhqvh1v83mblhf5nak56dk1vq3bhyifdg7ffq"; + }) + (fetchPatchFromAUR { + name = "improve-font-rendering.patch"; + package = "rxvt-unicode-truecolor-wide-glyphs"; + rev = "69701a09c2c206233952b84bc966407f6774f1dc"; + sha256 = "1jj5ai2182nq912279adihi4zph1w4dvbdqa1pwacy4na6y0fz9y"; + }) + ] + else + [ + ./patches/9.06-font-width.patch + ] + ) + ++ [ + ./patches/256-color-resources.patch + ] + ++ lib.optional (perlSupport && lib.versionAtLeast perl.version "5.38") (fetchpatch { + name = "perl538-locale-c.patch"; + url = "https://github.com/exg/rxvt-unicode/commit/16634bc8dd5fc4af62faf899687dfa8f27768d15.patch"; + excludes = [ "Changes" ]; + sha256 = "sha256-JVqzYi3tcWIN2j5JByZSztImKqbbbB3lnfAwUXrumHM="; }) - (fetchPatchFromAUR { - name = "improve-font-rendering.patch"; - package = "rxvt-unicode-truecolor-wide-glyphs"; - rev = "69701a09c2c206233952b84bc966407f6774f1dc"; - sha256 = "1jj5ai2182nq912279adihi4zph1w4dvbdqa1pwacy4na6y0fz9y"; - }) - ] else [ - ./patches/9.06-font-width.patch - ]) ++ [ - ./patches/256-color-resources.patch - ] ++ lib.optional (perlSupport && lib.versionAtLeast perl.version "5.38") (fetchpatch { - name = "perl538-locale-c.patch"; - url = "https://github.com/exg/rxvt-unicode/commit/16634bc8dd5fc4af62faf899687dfa8f27768d15.patch"; - excludes = [ "Changes" ]; - sha256 = "sha256-JVqzYi3tcWIN2j5JByZSztImKqbbbB3lnfAwUXrumHM="; - }) ++ lib.optional stdenv.hostPlatform.isDarwin ./patches/makefile-phony.patch; + ++ lib.optional stdenv.hostPlatform.isDarwin ./patches/makefile-phony.patch; configureFlags = [ "--with-terminfo=${placeholder "terminfo"}/share/terminfo" @@ -85,7 +129,11 @@ stdenv.mkDerivation { (lib.enableFeature unicode3Support "unicode3") ] ++ lib.optional emojiSupport "--enable-wide-glyphs"; - LDFLAGS = [ "-lfontconfig" "-lXrender" "-lpthread" ]; + LDFLAGS = [ + "-lfontconfig" + "-lXrender" + "-lpthread" + ]; CFLAGS = [ "-I${freetype.dev}/include/freetype2" ]; preConfigure = diff --git a/pkgs/applications/terminal-emulators/rxvt-unicode/wrapper.nix b/pkgs/applications/terminal-emulators/rxvt-unicode/wrapper.nix index 2e2cb076c69738..eec7b86883ebc2 100644 --- a/pkgs/applications/terminal-emulators/rxvt-unicode/wrapper.nix +++ b/pkgs/applications/terminal-emulators/rxvt-unicode/wrapper.nix @@ -1,15 +1,18 @@ -{ symlinkJoin -, makeWrapper -, lib -, rxvt-unicode-unwrapped -, rxvt-unicode-plugins -, perlPackages -, nixosTests -, configure ? { availablePlugins, ... }: - { plugins = builtins.attrValues availablePlugins; - extraDeps = [ ]; - perlDeps = [ ]; - } +{ + symlinkJoin, + makeWrapper, + lib, + rxvt-unicode-unwrapped, + rxvt-unicode-plugins, + perlPackages, + nixosTests, + configure ? + { availablePlugins, ... }: + { + plugins = builtins.attrValues availablePlugins; + extraDeps = [ ]; + perlDeps = [ ]; + }, }: let @@ -18,9 +21,12 @@ let # Transform the string "self" to the plugin itself. # It's needed for plugins like bidi who depends on the perl # package they provide themself. - mkPerlDeps = p: - let deps = p.perlPackages or [ ]; - in map (x: if x == "self" then p else x) deps; + mkPerlDeps = + p: + let + deps = p.perlPackages or [ ]; + in + map (x: if x == "self" then p else x) deps; # The wrapper is called with a `configure` function # that takes the urxvt plugins as input and produce @@ -28,36 +34,37 @@ let # extra dependencies and perl dependencies. # This provides simple way to customize urxvt using # the `.override` mechanism. - wrapper = { configure, ... }: + wrapper = + { configure, ... }: let config = configure { inherit availablePlugins; }; plugins = config.plugins or (builtins.attrValues availablePlugins); extraDeps = config.extraDeps or [ ]; perlDeps = (config.perlDeps or [ ]) ++ lib.concatMap mkPerlDeps plugins; in - symlinkJoin { - name = "rxvt-unicode-${rxvt-unicode-unwrapped.version}"; + symlinkJoin { + name = "rxvt-unicode-${rxvt-unicode-unwrapped.version}"; - paths = [ rxvt-unicode-unwrapped ] ++ plugins ++ extraDeps; + paths = [ rxvt-unicode-unwrapped ] ++ plugins ++ extraDeps; - nativeBuildInputs = [ makeWrapper ]; + nativeBuildInputs = [ makeWrapper ]; - postBuild = '' - wrapProgram $out/bin/urxvt \ - --prefix PERL5LIB : "${perlPackages.makePerlPath perlDeps}" \ - --suffix-each URXVT_PERL_LIB ':' "$out/lib/urxvt/perl" - wrapProgram $out/bin/urxvtd \ - --prefix PERL5LIB : "${perlPackages.makePerlPath perlDeps}" \ - --suffix-each URXVT_PERL_LIB ':' "$out/lib/urxvt/perl" - ''; + postBuild = '' + wrapProgram $out/bin/urxvt \ + --prefix PERL5LIB : "${perlPackages.makePerlPath perlDeps}" \ + --suffix-each URXVT_PERL_LIB ':' "$out/lib/urxvt/perl" + wrapProgram $out/bin/urxvtd \ + --prefix PERL5LIB : "${perlPackages.makePerlPath perlDeps}" \ + --suffix-each URXVT_PERL_LIB ':' "$out/lib/urxvt/perl" + ''; - inherit (rxvt-unicode-unwrapped) meta; + inherit (rxvt-unicode-unwrapped) meta; - passthru = { - plugins = plugins; - tests.test = nixosTests.terminal-emulators.urxvt; - }; + passthru = { + plugins = plugins; + tests.test = nixosTests.terminal-emulators.urxvt; }; + }; in - lib.makeOverridable wrapper { inherit configure; } +lib.makeOverridable wrapper { inherit configure; } diff --git a/pkgs/applications/terminal-emulators/st/default.nix b/pkgs/applications/terminal-emulators/st/default.nix index 676ef292def165..7657895061d7ae 100644 --- a/pkgs/applications/terminal-emulators/st/default.nix +++ b/pkgs/applications/terminal-emulators/st/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, fontconfig -, freetype -, libX11 -, libXft -, ncurses -, writeText -, conf ? null -, patches ? [ ] -, extraLibs ? [ ] -, nixosTests -# update script dependencies -, gitUpdater +{ + lib, + stdenv, + fetchurl, + pkg-config, + fontconfig, + freetype, + libX11, + libXft, + ncurses, + writeText, + conf ? null, + patches ? [ ], + extraLibs ? [ ], + nixosTests, + # update script dependencies + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { @@ -25,17 +26,20 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-ayFdT0crIdYjLzDyIRF6d34kvP7miVXd77dCZGf5SUs="; }; - outputs = [ "out" "terminfo" ]; + outputs = [ + "out" + "terminfo" + ]; inherit patches; - configFile = lib.optionalString (conf != null) - (writeText "config.def.h" conf); + configFile = lib.optionalString (conf != null) (writeText "config.def.h" conf); - postPatch = lib.optionalString (conf != null) "cp ${finalAttrs.configFile} config.def.h" + postPatch = + lib.optionalString (conf != null) "cp ${finalAttrs.configFile} config.def.h" + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace config.mk --replace "-lrt" "" - ''; + substituteInPlace config.mk --replace "-lrt" "" + ''; strictDeps = true; diff --git a/pkgs/applications/terminal-emulators/st/mcaimi-st.nix b/pkgs/applications/terminal-emulators/st/mcaimi-st.nix index e13163df0cece6..57085230621a24 100644 --- a/pkgs/applications/terminal-emulators/st/mcaimi-st.nix +++ b/pkgs/applications/terminal-emulators/st/mcaimi-st.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fontconfig -, libX11 -, libXext -, libXft -, ncurses -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + fontconfig, + libX11, + libXext, + libXft, + ncurses, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/terminal-emulators/st/siduck76-st.nix b/pkgs/applications/terminal-emulators/st/siduck76-st.nix index 54ec7117e21111..d981ba481e59f6 100644 --- a/pkgs/applications/terminal-emulators/st/siduck76-st.nix +++ b/pkgs/applications/terminal-emulators/st/siduck76-st.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, fontconfig -, harfbuzz -, libX11 -, libXext -, libXft -, ncurses -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + fontconfig, + harfbuzz, + libX11, + libXext, + libXft, + ncurses, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/terminal-emulators/st/xst.nix b/pkgs/applications/terminal-emulators/st/xst.nix index dda4b49c2aedfd..904f939c6b8e6a 100644 --- a/pkgs/applications/terminal-emulators/st/xst.nix +++ b/pkgs/applications/terminal-emulators/st/xst.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fontconfig -, libX11 -, libXext -, libXft -, ncurses -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + fontconfig, + libX11, + libXext, + libXft, + ncurses, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/terminal-emulators/stupidterm/default.nix b/pkgs/applications/terminal-emulators/stupidterm/default.nix index f10d91229376b3..379bd1d9427833 100644 --- a/pkgs/applications/terminal-emulators/stupidterm/default.nix +++ b/pkgs/applications/terminal-emulators/stupidterm/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, vte, gtk, pcre2, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + vte, + gtk, + pcre2, + nixosTests, +}: stdenv.mkDerivation { pname = "stupidterm"; @@ -6,7 +15,11 @@ stdenv.mkDerivation { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ vte gtk pcre2 ]; + buildInputs = [ + vte + gtk + pcre2 + ]; src = fetchFromGitHub { owner = "esmil"; @@ -15,7 +28,10 @@ stdenv.mkDerivation { sha256 = "1f73wvqqvj5pr3fvb7jjc4bi1iwgkkknz24k8n69mdb75jnfjipp"; }; - makeFlags = [ "PKGCONFIG=${pkg-config}/bin/${pkg-config.targetPrefix}pkg-config" "binary=stupidterm" ]; + makeFlags = [ + "PKGCONFIG=${pkg-config}/bin/${pkg-config.targetPrefix}pkg-config" + "binary=stupidterm" + ]; installPhase = '' install -D stupidterm $out/bin/stupidterm diff --git a/pkgs/applications/terminal-emulators/termite/default.nix b/pkgs/applications/terminal-emulators/termite/default.nix index 3dc6d484d2d3c2..9e03345a63a939 100644 --- a/pkgs/applications/terminal-emulators/termite/default.nix +++ b/pkgs/applications/terminal-emulators/termite/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, pkg-config, vte, gtk3, ncurses, pcre2, wrapGAppsHook3, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + vte, + gtk3, + ncurses, + pcre2, + wrapGAppsHook3, + nixosTests, +}: let @@ -6,8 +18,8 @@ let # https://github.com/thestinger/vte-ng # # three of the patches have been locally modified to cleanly apply on 0.62 - vte-ng = vte.overrideAttrs (attrs: { - patches = attrs.patches or [] ++ [ + vte-ng = vte.overrideAttrs (attrs: { + patches = attrs.patches or [ ] ++ [ (fetchpatch { name = "0001-expose-functions-for-pausing-unpausing-output.patch"; url = "https://github.com/thestinger/vte-ng/commit/342e26574f50dcd40bbeaad9e839c2a6144d0c1c.patch"; @@ -27,7 +39,8 @@ let ]; }); -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "termite"; version = "15"; @@ -40,7 +53,9 @@ in stdenv.mkDerivation rec { }; # https://github.com/thestinger/termite/pull/516 - patches = [ ./url_regexp_trailing.patch ./add_errno_header.patch + patches = [ + ./url_regexp_trailing.patch + ./add_errno_header.patch # Fix off-by-one in select_text() on libvte >= 0.55.0 # Expected to be included in next release (16). (fetchpatch { @@ -49,13 +64,28 @@ in stdenv.mkDerivation rec { }) ] ++ lib.optional stdenv.hostPlatform.isDarwin ./remove_ldflags_macos.patch; - makeFlags = [ "VERSION=v${version}" "PREFIX=" "DESTDIR=$(out)" ]; + makeFlags = [ + "VERSION=v${version}" + "PREFIX=" + "DESTDIR=$(out)" + ]; - buildInputs = [ vte-ng gtk3 ncurses pcre2 ]; + buildInputs = [ + vte-ng + gtk3 + ncurses + pcre2 + ]; - nativeBuildInputs = [ wrapGAppsHook3 pkg-config ]; + nativeBuildInputs = [ + wrapGAppsHook3 + pkg-config + ]; - outputs = [ "out" "terminfo" ]; + outputs = [ + "out" + "terminfo" + ]; passthru = { inherit vte-ng; diff --git a/pkgs/applications/terminal-emulators/termite/wrapper.nix b/pkgs/applications/terminal-emulators/termite/wrapper.nix index 379223d9076d0c..ff4d329e52f3db 100644 --- a/pkgs/applications/terminal-emulators/termite/wrapper.nix +++ b/pkgs/applications/terminal-emulators/termite/wrapper.nix @@ -1,15 +1,23 @@ -{ makeWrapper, symlinkJoin, configFile ? null, termite }: +{ + makeWrapper, + symlinkJoin, + configFile ? null, + termite, +}: -if configFile == null then termite else symlinkJoin { - name = "termite-with-config-${termite.version}"; +if configFile == null then + termite +else + symlinkJoin { + name = "termite-with-config-${termite.version}"; - paths = [ termite ]; - nativeBuildInputs = [ makeWrapper ]; + paths = [ termite ]; + nativeBuildInputs = [ makeWrapper ]; - postBuild = '' - wrapProgram $out/bin/termite \ - --add-flags "--config ${configFile}" - ''; + postBuild = '' + wrapProgram $out/bin/termite \ + --add-flags "--config ${configFile}" + ''; - passthru.terminfo = termite.terminfo; -} + passthru.terminfo = termite.terminfo; + } diff --git a/pkgs/applications/terminal-emulators/wezterm/default.nix b/pkgs/applications/terminal-emulators/wezterm/default.nix index 7fa33f7a822e30..00117185c5564d 100644 --- a/pkgs/applications/terminal-emulators/wezterm/default.nix +++ b/pkgs/applications/terminal-emulators/wezterm/default.nix @@ -1,33 +1,34 @@ -{ stdenv -, rustPlatform -, lib -, fetchFromGitHub -, ncurses -, perl -, pkg-config -, python3 -, fontconfig -, installShellFiles -, openssl -, libGL -, libX11 -, libxcb -, libxkbcommon -, xcbutil -, xcbutilimage -, xcbutilkeysyms -, xcbutilwm -, wayland -, zlib -, CoreGraphics -, Cocoa -, Foundation -, System -, libiconv -, UserNotifications -, nixosTests -, runCommand -, vulkan-loader +{ + stdenv, + rustPlatform, + lib, + fetchFromGitHub, + ncurses, + perl, + pkg-config, + python3, + fontconfig, + installShellFiles, + openssl, + libGL, + libX11, + libxcb, + libxkbcommon, + xcbutil, + xcbutilimage, + xcbutilkeysyms, + xcbutilwm, + wayland, + zlib, + CoreGraphics, + Cocoa, + Foundation, + System, + libiconv, + UserNotifications, + nixosTests, + runCommand, + vulkan-loader, }: rustPlatform.buildRustPackage rec { @@ -72,27 +73,30 @@ rustPlatform.buildRustPackage rec { python3 ] ++ lib.optional stdenv.hostPlatform.isDarwin perl; - buildInputs = [ - fontconfig - zlib - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libX11 - libxcb - libxkbcommon - openssl - wayland - xcbutil - xcbutilimage - xcbutilkeysyms - xcbutilwm # contains xcb-ewmh among others - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Cocoa - CoreGraphics - Foundation - libiconv - System - UserNotifications - ]; + buildInputs = + [ + fontconfig + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libX11 + libxcb + libxkbcommon + openssl + wayland + xcbutil + xcbutilimage + xcbutilkeysyms + xcbutilwm # contains xcb-ewmh among others + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + CoreGraphics + Foundation + libiconv + System + UserNotifications + ]; buildFeatures = [ "distro-defaults" ]; @@ -115,33 +119,43 @@ rustPlatform.buildRustPackage rec { install -Dm644 assets/wezterm-nautilus.py -t $out/share/nautilus-python/extensions ''; - preFixup = lib.optionalString stdenv.hostPlatform.isLinux '' - patchelf \ - --add-needed "${libGL}/lib/libEGL.so.1" \ - --add-needed "${vulkan-loader}/lib/libvulkan.so.1" \ - $out/bin/wezterm-gui - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p "$out/Applications" - OUT_APP="$out/Applications/WezTerm.app" - cp -r assets/macos/WezTerm.app "$OUT_APP" - rm $OUT_APP/*.dylib - cp -r assets/shell-integration/* "$OUT_APP" - ln -s $out/bin/{wezterm,wezterm-mux-server,wezterm-gui,strip-ansi-escapes} "$OUT_APP" - ''; + preFixup = + lib.optionalString stdenv.hostPlatform.isLinux '' + patchelf \ + --add-needed "${libGL}/lib/libEGL.so.1" \ + --add-needed "${vulkan-loader}/lib/libvulkan.so.1" \ + $out/bin/wezterm-gui + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p "$out/Applications" + OUT_APP="$out/Applications/WezTerm.app" + cp -r assets/macos/WezTerm.app "$OUT_APP" + rm $OUT_APP/*.dylib + cp -r assets/shell-integration/* "$OUT_APP" + ln -s $out/bin/{wezterm,wezterm-mux-server,wezterm-gui,strip-ansi-escapes} "$OUT_APP" + ''; passthru = { # the headless variant is useful when deploying wezterm's mux server on remote severs headless = rustPlatform.buildRustPackage { pname = "${pname}-headless"; - inherit version src postPatch cargoLock meta; + inherit + version + src + postPatch + cargoLock + meta + ; nativeBuildInputs = [ pkg-config ]; buildInputs = [ openssl ]; cargoBuildFlags = [ - "--package" "wezterm" - "--package" "wezterm-mux-server" + "--package" + "wezterm" + "--package" + "wezterm-mux-server" ]; doCheck = false; @@ -152,12 +166,15 @@ rustPlatform.buildRustPackage rec { ''; }; - terminfo = runCommand "wezterm-terminfo" { - nativeBuildInputs = [ ncurses ]; - } '' - mkdir -p $out/share/terminfo $out/nix-support - tic -x -o $out/share/terminfo ${src}/termwiz/data/wezterm.terminfo - ''; + terminfo = + runCommand "wezterm-terminfo" + { + nativeBuildInputs = [ ncurses ]; + } + '' + mkdir -p $out/share/terminfo $out/nix-support + tic -x -o $out/share/terminfo ${src}/termwiz/data/wezterm.terminfo + ''; tests = { all-terminfo = nixosTests.allTerminfo; @@ -171,6 +188,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://wezfurlong.org/wezterm"; license = licenses.mit; mainProgram = "wezterm"; - maintainers = with maintainers; [ SuperSandro2000 mimame ]; + maintainers = with maintainers; [ + SuperSandro2000 + mimame + ]; }; } diff --git a/pkgs/applications/version-management/bcompare/default.nix b/pkgs/applications/version-management/bcompare/default.nix index 6b1be920833e15..7acccc3a7a0e9c 100644 --- a/pkgs/applications/version-management/bcompare/default.nix +++ b/pkgs/applications/version-management/bcompare/default.nix @@ -1,5 +1,20 @@ -{ lib, autoPatchelfHook, bzip2, cairo, fetchurl, gdk-pixbuf, glibc, pango, gtk2, kcoreaddons, ki18n, kio, kservice -, stdenv, runtimeShell, unzip +{ + lib, + autoPatchelfHook, + bzip2, + cairo, + fetchurl, + gdk-pixbuf, + glibc, + pango, + gtk2, + kcoreaddons, + ki18n, + kio, + kservice, + stdenv, + runtimeShell, + unzip, }: let @@ -25,7 +40,12 @@ let src = srcs.${stdenv.hostPlatform.system} or throwSystem; linux = stdenv.mkDerivation { - inherit pname version src meta; + inherit + pname + version + src + meta + ; unpackPhase = '' ar x $src tar xfz data.tar.gz @@ -69,7 +89,12 @@ let }; darwin = stdenv.mkDerivation { - inherit pname version src meta; + inherit + pname + version + src + meta + ; nativeBuildInputs = [ unzip ]; installPhase = '' @@ -88,11 +113,12 @@ let homepage = "https://www.scootersoftware.com"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - maintainers = with maintainers; [ ktor arkivm ]; + maintainers = with maintainers; [ + ktor + arkivm + ]; platforms = builtins.attrNames srcs; mainProgram = "bcompare"; }; in -if stdenv.hostPlatform.isDarwin -then darwin -else linux +if stdenv.hostPlatform.isDarwin then darwin else linux diff --git a/pkgs/applications/version-management/bitbucket-server-cli/default.nix b/pkgs/applications/version-management/bitbucket-server-cli/default.nix index 6c38250c2753ac..ae722fd47f4e2e 100644 --- a/pkgs/applications/version-management/bitbucket-server-cli/default.nix +++ b/pkgs/applications/version-management/bitbucket-server-cli/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerEnv, ruby, bundlerUpdateScript }: +{ + lib, + bundlerEnv, + ruby, + bundlerUpdateScript, +}: bundlerEnv rec { name = "bitbucket-server-cli-${version}"; @@ -13,10 +18,13 @@ bundlerEnv rec { meta = with lib; { description = "Command line interface to interact with BitBucket Server (formerly Atlassian Stash)"; - homepage = "https://bitbucket.org/atlassian/bitbucket-server-cli"; - license = licenses.mit; - maintainers = with maintainers; [ jgertm nicknovitski ]; + homepage = "https://bitbucket.org/atlassian/bitbucket-server-cli"; + license = licenses.mit; + maintainers = with maintainers; [ + jgertm + nicknovitski + ]; mainProgram = "stash"; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/applications/version-management/bitbucket-server-cli/gemset.nix b/pkgs/applications/version-management/bitbucket-server-cli/gemset.nix index 844291b09054da..0384c22326e645 100644 --- a/pkgs/applications/version-management/bitbucket-server-cli/gemset.nix +++ b/pkgs/applications/version-management/bitbucket-server-cli/gemset.nix @@ -1,7 +1,7 @@ { addressable = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j5r0anj8m4qlf2psnldip4b8ha2bsscv11lpdgnfh4nnchzjnxw"; type = "gem"; }; @@ -9,7 +9,7 @@ }; atlassian-stash = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rsf9h5w5wiglwv0fqwp45fq06fxbg68cqkc3bpqvps1i1qm0p6i"; type = "gem"; }; @@ -17,7 +17,7 @@ }; commander = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0x9i8hf083wjlgj09nl1p9j8sr5g7amq0fdmxjqs4cxdbg3wpmsb"; type = "gem"; }; @@ -25,7 +25,7 @@ }; git = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1waikaggw7a1d24nw0sh8fd419gbf7awh000qhsf411valycj6q3"; type = "gem"; }; @@ -33,7 +33,7 @@ }; highline = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06bml1fjsnrhd956wqq5k3w8cyd09rv1vixdpa3zzkl6xs72jdn1"; type = "gem"; }; @@ -41,7 +41,7 @@ }; json = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1lhinj9vj7mw59jqid0bjn2hlfcnq02bnvsx9iv81nl2han603s0"; type = "gem"; }; @@ -49,7 +49,7 @@ }; launchy = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "190lfbiy1vwxhbgn4nl4dcbzxvm049jwc158r2x7kq3g5khjrxa2"; type = "gem"; }; @@ -57,7 +57,7 @@ }; public_suffix = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "040jf98jpp6w140ghkhw2hvc1qx41zvywx5gj7r2ylr1148qnj7q"; type = "gem"; }; diff --git a/pkgs/applications/version-management/blackbox/default.nix b/pkgs/applications/version-management/blackbox/default.nix index e5be040f6a25eb..70c0bd6e3597dd 100644 --- a/pkgs/applications/version-management/blackbox/default.nix +++ b/pkgs/applications/version-management/blackbox/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, expect -, which -, gnupg -, coreutils -, git -, pinentry -, gnutar -, procps +{ + lib, + stdenv, + fetchFromGitHub, + expect, + which, + gnupg, + coreutils, + git, + pinentry, + gnutar, + procps, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/version-management/cgit/common.nix b/pkgs/applications/version-management/cgit/common.nix index d5dab65bd4a92f..03300018d135aa 100644 --- a/pkgs/applications/version-management/cgit/common.nix +++ b/pkgs/applications/version-management/cgit/common.nix @@ -1,27 +1,68 @@ -{ pname, version, src, gitSrc, buildInputs ? [] -, homepage, description, maintainers -, passthru ? {} +{ + pname, + version, + src, + gitSrc, + buildInputs ? [ ], + homepage, + description, + maintainers, + passthru ? { }, }: -{ lib, stdenv, openssl, zlib, asciidoc, libxml2, libxslt -, docbook_xsl, pkg-config -, coreutils, gnused, groff, docutils -, gzip, bzip2, lzip, xz, zstd -, python3Packages +{ + lib, + stdenv, + openssl, + zlib, + asciidoc, + libxml2, + libxslt, + docbook_xsl, + pkg-config, + coreutils, + gnused, + groff, + docutils, + gzip, + bzip2, + lzip, + xz, + zstd, + python3Packages, }: stdenv.mkDerivation { - inherit pname version src gitSrc passthru; + inherit + pname + version + src + gitSrc + passthru + ; separateDebugInfo = true; - nativeBuildInputs = [ - pkg-config asciidoc - ] ++ (with python3Packages; [ python wrapPython ]); + nativeBuildInputs = + [ + pkg-config + asciidoc + ] + ++ (with python3Packages; [ + python + wrapPython + ]); buildInputs = buildInputs ++ [ - openssl zlib libxml2 libxslt docbook_xsl + openssl + zlib + libxml2 + libxslt + docbook_xsl + ]; + pythonPath = with python3Packages; [ + pygments + markdown ]; - pythonPath = with python3Packages; [ pygments markdown ]; postPatch = '' sed -e 's|"gzip"|"${gzip}/bin/gzip"|' \ @@ -65,7 +106,12 @@ stdenv.mkDerivation { wrapPythonProgramsIn "$out/lib/cgit/filters" "$out $pythonPath" for script in $out/lib/cgit/filters/*.sh $out/lib/cgit/filters/html-converters/txt2html; do - wrapProgram $script --prefix PATH : '${lib.makeBinPath [ coreutils gnused ]}' + wrapProgram $script --prefix PATH : '${ + lib.makeBinPath [ + coreutils + gnused + ] + }' done ''; diff --git a/pkgs/applications/version-management/cgit/default.nix b/pkgs/applications/version-management/cgit/default.nix index 0fe86683d5fa29..9fcd94ccf5e158 100644 --- a/pkgs/applications/version-management/cgit/default.nix +++ b/pkgs/applications/version-management/cgit/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, callPackage, luajit, nixosTests }: +{ + lib, + fetchurl, + callPackage, + luajit, + nixosTests, +}: callPackage (import ./common.nix rec { pname = "cgit"; @@ -13,7 +19,7 @@ callPackage (import ./common.nix rec { # IMPORTANT: Remember to check which git version cgit needs on every version # bump (look for "GIT_VER" in the top-level Makefile). gitSrc = fetchurl { - url = "mirror://kernel/software/scm/git/git-2.25.1.tar.xz"; + url = "mirror://kernel/software/scm/git/git-2.25.1.tar.xz"; sha256 = "09lzwa183nblr6l8ib35g2xrjf9wm9yhk3szfvyzkwivdv69c9r2"; }; @@ -24,4 +30,4 @@ callPackage (import ./common.nix rec { homepage = "https://git.zx2c4.com/cgit/about/"; description = "Web frontend for git repositories"; maintainers = with lib.maintainers; [ bjornfor ]; -}) {} +}) { } diff --git a/pkgs/applications/version-management/cgit/pink.nix b/pkgs/applications/version-management/cgit/pink.nix index 73523a2d77afd0..3ff14332602720 100644 --- a/pkgs/applications/version-management/cgit/pink.nix +++ b/pkgs/applications/version-management/cgit/pink.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, callPackage }: +{ + lib, + fetchurl, + callPackage, +}: callPackage (import ./common.nix rec { pname = "cgit-pink"; @@ -13,11 +17,11 @@ callPackage (import ./common.nix rec { # IMPORTANT: Remember to check which git version cgit-pink needs on every # version bump (look for "GIT_VER" in the top-level Makefile). gitSrc = fetchurl { - url = "mirror://kernel/software/scm/git/git-2.36.1.tar.xz"; + url = "mirror://kernel/software/scm/git/git-2.36.1.tar.xz"; sha256 = "0w43a35mhc2qf2gjkxjlnkf2lq8g0snf34iy5gqx2678yq7llpa0"; }; homepage = "https://git.causal.agency/cgit-pink/about/"; description = "cgit fork aiming for better maintenance"; maintainers = with lib.maintainers; [ sternenseemann ]; -}) {} +}) { } diff --git a/pkgs/applications/version-management/danger-gitlab/gemset.nix b/pkgs/applications/version-management/danger-gitlab/gemset.nix index 299716a33bd8e4..70b12e0d609fc8 100644 --- a/pkgs/applications/version-management/danger-gitlab/gemset.nix +++ b/pkgs/applications/version-management/danger-gitlab/gemset.nix @@ -1,385 +1,428 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "022r3m9wdxljpbya69y2i3h9g3dhhfaqzidf95m6qjzms792jvgp"; type = "gem"; }; version = "2.8.0"; }; claide = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kasxsms24fgcdsq680nz99d5lazl9rmz1qkil2y5gbbssx89g0z"; type = "gem"; }; version = "1.0.3"; }; claide-plugins = { - dependencies = ["cork" "nap" "open4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "cork" + "nap" + "open4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0bhw5j985qs48v217gnzva31rw5qvkf7qj8mhp73pcks0sy7isn7"; type = "gem"; }; version = "0.9.2"; }; colored2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jlbqa9q4mvrm73aw9mxh23ygzbjiqwisl32d8szfb5fxvbjng5i"; type = "gem"; }; version = "3.1.2"; }; cork = { - dependencies = ["colored2"]; - groups = ["default"]; - platforms = []; + dependencies = [ "colored2" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g6l780z1nj4s3jr11ipwcj8pjbibvli82my396m3y32w98ar850"; type = "gem"; }; version = "0.3.0"; }; danger = { - dependencies = ["claide" "claide-plugins" "colored2" "cork" "faraday" "faraday-http-cache" "git" "kramdown" "kramdown-parser-gfm" "no_proxy_fix" "octokit" "terminal-table"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "claide" + "claide-plugins" + "colored2" + "cork" + "faraday" + "faraday-http-cache" + "git" + "kramdown" + "kramdown-parser-gfm" + "no_proxy_fix" + "octokit" + "terminal-table" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "12nmycrlwr8ca2s0fx76k81gjw12iz15k1n0qanszv5d4l1ykj2l"; type = "gem"; }; version = "8.3.1"; }; danger-gitlab = { - dependencies = ["danger" "gitlab"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "danger" + "gitlab" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1a530kx5s5rbx5yx3jqay56lkksqh0yj468hcpg16faiyv8dfza9"; type = "gem"; }; version = "8.0.0"; }; faraday = { - dependencies = ["faraday-em_http" "faraday-em_synchrony" "faraday-excon" "faraday-httpclient" "faraday-net_http" "faraday-net_http_persistent" "faraday-patron" "faraday-rack" "multipart-post" "ruby2_keywords"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-em_http" + "faraday-em_synchrony" + "faraday-excon" + "faraday-httpclient" + "faraday-net_http" + "faraday-net_http_persistent" + "faraday-patron" + "faraday-rack" + "multipart-post" + "ruby2_keywords" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0r6ik2yvsbx6jj30vck32da2bbvj4m0gf4jhp09vr75i1d6jzfvb"; type = "gem"; }; version = "1.7.0"; }; faraday-em_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12cnqpbak4vhikrh2cdn94assh3yxza8rq2p9w2j34bqg5q4qgbs"; type = "gem"; }; version = "1.0.0"; }; faraday-em_synchrony = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vgrbhkp83sngv6k4mii9f2s9v5lmp693hylfxp2ssfc60fas3a6"; type = "gem"; }; version = "1.0.0"; }; faraday-excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h09wkb0k0bhm6dqsd47ac601qiaah8qdzjh8gvxfd376x1chmdh"; type = "gem"; }; version = "1.1.0"; }; faraday-http-cache = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lhfwlk4mhmw9pdlgdsl2bq4x45w7s51jkxjryf18wym8iiw36g7"; type = "gem"; }; version = "2.2.0"; }; faraday-httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fyk0jd3ks7fdn8nv3spnwjpzx2lmxmg2gh4inz3by1zjzqg33sc"; type = "gem"; }; version = "1.0.1"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fi8sda5hc54v1w3mqfl5yz09nhx35kglyx72w7b8xxvdr0cwi9j"; type = "gem"; }; version = "1.0.1"; }; faraday-net_http_persistent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dc36ih95qw3rlccffcb0vgxjhmipsvxhn6cw71l7ffs0f7vq30b"; type = "gem"; }; version = "1.2.0"; }; faraday-patron = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19wgsgfq0xkski1g7m96snv39la3zxz6x7nbdgiwhg5v82rxfb6w"; type = "gem"; }; version = "1.0.0"; }; faraday-rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h184g4vqql5jv9s9im6igy00jp6mrah2h14py6mpf9bkabfqq7g"; type = "gem"; }; version = "1.0.0"; }; git = { - dependencies = ["rchardet"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rchardet" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0s6426k24ph44kbx1qb16ciar170iczs8ivyl29ckin2ygmrrlvm"; type = "gem"; }; version = "1.9.1"; }; gitlab = { - dependencies = ["httparty" "terminal-table"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "httparty" + "terminal-table" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00p8z8sxk78zik2dwdhflkvaynp5ximy2xc8cw6bz93gkr1xy8n3"; type = "gem"; }; version = "4.17.0"; }; httparty = { - dependencies = ["mime-types" "multi_xml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mime-types" + "multi_xml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "17gpnbf2a7xkvsy20jig3ljvx8hl5520rqm9pffj2jrliq1yi3w7"; type = "gem"; }; version = "0.18.1"; }; kramdown = { - dependencies = ["rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rexml" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jdbcjv4v7sj888bv3vc6d1dg4ackkh7ywlmn9ln2g9alk7kisar"; type = "gem"; }; version = "2.3.1"; }; kramdown-parser-gfm = { - dependencies = ["kramdown"]; - groups = ["default"]; - platforms = []; + dependencies = [ "kramdown" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a8pb3v951f4x7h968rqfsa19c8arz21zw1vaj42jza22rap8fgv"; type = "gem"; }; version = "1.1.0"; }; mime-types = { - dependencies = ["mime-types-data"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mime-types-data" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zj12l9qk62anvk9bjvandpa6vy4xslil15wl6wlivyf51z773vh"; type = "gem"; }; version = "3.3.1"; }; mime-types-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dlxwc75iy0dj23x824cxpvpa7c8aqcpskksrmb32j6m66h5mkcy"; type = "gem"; }; version = "3.2021.0704"; }; multi_xml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lmd4f401mvravi1i1yq7b2qjjli0yq7dfc4p1nj5nwajp7r6hyj"; type = "gem"; }; version = "0.6.0"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zgw9zlwh2a6i1yvhhc4a84ry1hv824d6g2iw2chs3k5aylpmpfj"; type = "gem"; }; version = "2.1.1"; }; nap = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xm5xssxk5s03wjarpipfm39qmgxsalb46v1prsis14x1xk935ll"; type = "gem"; }; version = "1.1.0"; }; no_proxy_fix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "006dmdb640v1kq0sll3dnlwj1b0kpf3i1p27ygyffv8lpcqlr6sf"; type = "gem"; }; version = "0.1.2"; }; octokit = { - dependencies = ["faraday" "sawyer"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "sawyer" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ak64rb48d8z98nw6q70r6i0i3ivv61iqla40ss5l79491qfnn27"; type = "gem"; }; version = "4.21.0"; }; open4 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cgls3f9dlrpil846q0w7h66vsc33jqn84nql4gcqkk221rh7px1"; type = "gem"; }; version = "1.3.4"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xqcgkl7bwws1qrlnmxgh8g4g9m10vg60bhlw40fplninb3ng6d9"; type = "gem"; }; version = "4.0.6"; }; rchardet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1isj1b3ywgg2m1vdlnr41lpvpm3dbyarf1lla4dfibfmad9csfk9"; type = "gem"; }; version = "1.8.0"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08ximcyfjy94pm1rhcx04ny1vx2sk0x4y185gzn86yfsbzwkng53"; type = "gem"; }; version = "3.2.5"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; sawyer = { - dependencies = ["addressable" "faraday"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "faraday" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0yrdchs3psh583rjapkv33mljdivggqn99wkydkjdckcjn43j3cz"; type = "gem"; }; version = "0.8.2"; }; terminal-table = { - dependencies = ["unicode-display_width"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unicode-display_width" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1512cngw35hsmhvw4c05rscihc59mnj09m249sm9p3pik831ydqk"; type = "gem"; }; version = "1.8.0"; }; unicode-display_width = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06i3id27s60141x6fdnjn5rar1cywdwy64ilc59cz937303q3mna"; type = "gem"; }; diff --git a/pkgs/applications/version-management/fnc/default.nix b/pkgs/applications/version-management/fnc/default.nix index 71682501b28fef..af9088d8a068e4 100644 --- a/pkgs/applications/version-management/fnc/default.nix +++ b/pkgs/applications/version-management/fnc/default.nix @@ -1,4 +1,13 @@ -{ lib, fetchurl, stdenv, zlib, ncurses, libiconv, apple-sdk_11, darwinMinVersionHook }: +{ + lib, + fetchurl, + stdenv, + zlib, + ncurses, + libiconv, + apple-sdk_11, + darwinMinVersionHook, +}: stdenv.mkDerivation (finalAttrs: { pname = "fnc"; @@ -9,14 +18,22 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-npS+sOxF0S/9TuFjtEFlev0HpIOsaP6zmcfopPNUehk="; }; - buildInputs = [ libiconv ncurses zlib apple-sdk_11 (darwinMinVersionHook "11.0") ]; + buildInputs = [ + libiconv + ncurses + zlib + apple-sdk_11 + (darwinMinVersionHook "11.0") + ]; makeFlags = [ "PREFIX=$(out)" ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isGNU [ - # Needed with GCC 12 - "-Wno-error=maybe-uninitialized" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isGNU [ + # Needed with GCC 12 + "-Wno-error=maybe-uninitialized" + ] + ); preInstall = '' mkdir -p $out/bin diff --git a/pkgs/applications/version-management/fossil/default.nix b/pkgs/applications/version-management/fossil/default.nix index 8d470d3f852f71..bcbd9cf329df55 100644 --- a/pkgs/applications/version-management/fossil/default.nix +++ b/pkgs/applications/version-management/fossil/default.nix @@ -1,18 +1,20 @@ -{ lib, stdenv -, installShellFiles -, tcl -, libiconv -, fetchurl -, buildPackages -, zlib -, openssl -, readline -, withInternalSqlite ? true -, sqlite -, ed -, which -, tclPackages -, withJson ? true +{ + lib, + stdenv, + installShellFiles, + tcl, + libiconv, + fetchurl, + buildPackages, + zlib, + openssl, + readline, + withInternalSqlite ? true, + sqlite, + ed, + which, + tclPackages, + withJson ? true, }: stdenv.mkDerivation (finalAttrs: { @@ -27,9 +29,19 @@ stdenv.mkDerivation (finalAttrs: { # required for build time tool `./tools/translate.c` depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ installShellFiles tcl ]; + nativeBuildInputs = [ + installShellFiles + tcl + ]; - buildInputs = [ zlib openssl readline which ed ] + buildInputs = + [ + zlib + openssl + readline + which + ed + ] ++ lib.optional stdenv.hostPlatform.isDarwin libiconv ++ lib.optional (!withInternalSqlite) sqlite; diff --git a/pkgs/applications/version-management/git-absorb/default.nix b/pkgs/applications/version-management/git-absorb/default.nix index d2f6173bfe955e..a8cbf03ac3f285 100644 --- a/pkgs/applications/version-management/git-absorb/default.nix +++ b/pkgs/applications/version-management/git-absorb/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "git-absorb"; @@ -15,14 +21,16 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Y/0In33y4mVTaE9yoBZ/3tRWcsSKgGjTCSHdjScNEj0="; - postInstall = '' - installManPage Documentation/git-absorb.1 - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - installShellCompletion --cmd git-absorb \ - --bash <($out/bin/git-absorb --gen-completions bash) \ - --fish <($out/bin/git-absorb --gen-completions fish) \ - --zsh <($out/bin/git-absorb --gen-completions zsh) - ''; + postInstall = + '' + installManPage Documentation/git-absorb.1 + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + installShellCompletion --cmd git-absorb \ + --bash <($out/bin/git-absorb --gen-completions bash) \ + --fish <($out/bin/git-absorb --gen-completions fish) \ + --zsh <($out/bin/git-absorb --gen-completions zsh) + ''; meta = with lib; { homepage = "https://github.com/tummychow/git-absorb"; diff --git a/pkgs/applications/version-management/git-annex-metadata-gui/default.nix b/pkgs/applications/version-management/git-annex-metadata-gui/default.nix index 3fcde8f900cc6c..3622bf842a3c9a 100644 --- a/pkgs/applications/version-management/git-annex-metadata-gui/default.nix +++ b/pkgs/applications/version-management/git-annex-metadata-gui/default.nix @@ -1,4 +1,11 @@ -{ lib, buildPythonApplication, fetchFromGitHub, pyqt5, qt5, git-annex-adapter }: +{ + lib, + buildPythonApplication, + fetchFromGitHub, + pyqt5, + qt5, + git-annex-adapter, +}: buildPythonApplication rec { pname = "git-annex-metadata-gui"; @@ -21,7 +28,10 @@ buildPythonApplication rec { makeWrapperArgs+=("''${qtWrapperArgs[@]}") ''; - propagatedBuildInputs = [ pyqt5 git-annex-adapter ]; + propagatedBuildInputs = [ + pyqt5 + git-annex-adapter + ]; meta = with lib; { homepage = "https://github.com/alpernebbi/git-annex-metadata-gui"; diff --git a/pkgs/applications/version-management/git-annex-remote-dbx/default.nix b/pkgs/applications/version-management/git-annex-remote-dbx/default.nix index 041972e146b7b9..bee106e434e083 100644 --- a/pkgs/applications/version-management/git-annex-remote-dbx/default.nix +++ b/pkgs/applications/version-management/git-annex-remote-dbx/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonApplication -, fetchPypi -, dropbox -, annexremote -, humanfriendly +{ + lib, + buildPythonApplication, + fetchPypi, + dropbox, + annexremote, + humanfriendly, }: buildPythonApplication rec { @@ -15,7 +16,11 @@ buildPythonApplication rec { sha256 = "5b6f8025ed1e9877f06882ddbd81f701a8e094647ab97595e2afc09016835a7c"; }; - propagatedBuildInputs = [ dropbox annexremote humanfriendly ]; + propagatedBuildInputs = [ + dropbox + annexremote + humanfriendly + ]; meta = with lib; { description = "Git-annex special remote for Dropbox"; diff --git a/pkgs/applications/version-management/git-annex-remote-googledrive/default.nix b/pkgs/applications/version-management/git-annex-remote-googledrive/default.nix index 03bd655adcdc8d..0802769513e311 100644 --- a/pkgs/applications/version-management/git-annex-remote-googledrive/default.nix +++ b/pkgs/applications/version-management/git-annex-remote-googledrive/default.nix @@ -1,13 +1,14 @@ -{ lib -, annexremote -, buildPythonApplication -, drivelib -, fetchPypi -, gitpython -, humanfriendly -, tenacity -, setuptools -, distutils +{ + lib, + annexremote, + buildPythonApplication, + drivelib, + fetchPypi, + gitpython, + humanfriendly, + tenacity, + setuptools, + distutils, }: buildPythonApplication rec { diff --git a/pkgs/applications/version-management/git-archive-all/default.nix b/pkgs/applications/version-management/git-archive-all/default.nix index abc8ccbbfe5f75..d43c2359e377c0 100644 --- a/pkgs/applications/version-management/git-archive-all/default.nix +++ b/pkgs/applications/version-management/git-archive-all/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, git -, pytestCheckHook -, pytest-cov-stub -, pytest-mock +{ + lib, + buildPythonApplication, + fetchFromGitHub, + git, + pytestCheckHook, + pytest-cov-stub, + pytest-mock, }: buildPythonApplication rec { diff --git a/pkgs/applications/version-management/git-cinnabar/default.nix b/pkgs/applications/version-management/git-cinnabar/default.nix index ab43dc03091209..5a1661f1ac9d03 100644 --- a/pkgs/applications/version-management/git-cinnabar/default.nix +++ b/pkgs/applications/version-management/git-cinnabar/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, cargo -, pkg-config -, rustPlatform -, bzip2 -, curl -, zlib -, zstd +{ + stdenv, + lib, + fetchFromGitHub, + cargo, + pkg-config, + rustPlatform, + bzip2, + curl, + zlib, + zstd, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/version-management/git-credential-keepassxc/default.nix b/pkgs/applications/version-management/git-credential-keepassxc/default.nix index f327c8a1e53700..e1c658e2324d9f 100644 --- a/pkgs/applications/version-management/git-credential-keepassxc/default.nix +++ b/pkgs/applications/version-management/git-credential-keepassxc/default.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, withNotification ? false -, withYubikey ? false -, withStrictCaller ? false -, withAll ? false +{ + lib, + rustPlatform, + fetchFromGitHub, + withNotification ? false, + withYubikey ? false, + withStrictCaller ? false, + withAll ? false, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,8 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-jBUp0jes4wtr8cmqceEBb6noqGkJUHbIfYgWOw5KMF4="; - buildFeatures = [] + buildFeatures = + [ ] ++ lib.optional withNotification "notification" ++ lib.optional withYubikey "yubikey" ++ lib.optional withStrictCaller "strict-caller" diff --git a/pkgs/applications/version-management/git-fame/default.nix b/pkgs/applications/version-management/git-fame/default.nix index 54af934bde8b68..08009920b61a93 100644 --- a/pkgs/applications/version-management/git-fame/default.nix +++ b/pkgs/applications/version-management/git-fame/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerEnv, ruby, bundlerUpdateScript }: +{ + lib, + bundlerEnv, + ruby, + bundlerUpdateScript, +}: bundlerEnv { inherit ruby; @@ -12,11 +17,11 @@ bundlerEnv { meta = with lib; { description = '' A command-line tool that helps you summarize and pretty-print collaborators based on contributions - ''; - homepage = "http://oleander.io/git-fame-rb"; - license = licenses.mit; + ''; + homepage = "http://oleander.io/git-fame-rb"; + license = licenses.mit; maintainers = with maintainers; [ nicknovitski ]; - platforms = platforms.unix; + platforms = platforms.unix; mainProgram = "git-fame"; }; } diff --git a/pkgs/applications/version-management/git-fame/gemset.nix b/pkgs/applications/version-management/git-fame/gemset.nix index 1bd2081516243c..5212cfbcb8f308 100644 --- a/pkgs/applications/version-management/git-fame/gemset.nix +++ b/pkgs/applications/version-management/git-fame/gemset.nix @@ -1,650 +1,738 @@ { activesupport = { - dependencies = ["concurrent-ruby" "i18n" "minitest" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "i18n" + "minitest" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1cjsf26656996hv48wgv2mkwxf0fy1qc68ikgzq7mzfq2mmvmayk"; type = "gem"; }; version = "7.0.6"; }; ast = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04nc8x27hlzlrr5c2gn7mar4vdr0apw5xg22wp6m8dx3wqr04a0y"; type = "gem"; }; version = "2.4.2"; }; coderay = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jvxqxzply1lwp7ysn94zjhh57vc14mcshw1ygw14ib8lhc00lyw"; type = "gem"; }; version = "1.1.3"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0krcwb6mn0iklajwngwsg850nk8k9b35dhmc2qkbdqvmifdi2y9q"; type = "gem"; }; version = "1.2.2"; }; diff-lcs = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rwvjahnp7cpmracd8x732rjgnilqv2sx7d1gfrysslc3h039fa9"; type = "gem"; }; version = "1.5.0"; }; docile = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1lxqxgq71rqwj1lpl9q1mbhhhhhhdkkj7my341f2889pwayk85sz"; type = "gem"; }; version = "1.4.0"; }; dry-core = { - dependencies = ["concurrent-ruby" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "01gks2hrp7nl3pzb487azvd25dlbrc40d5cpk4n0szwnf2c0k4ks"; type = "gem"; }; version = "1.0.0"; }; dry-inflector = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09hnvna3lg2x36li63988kv664d0zvy7y0z33803yvrdr9hj7lka"; type = "gem"; }; version = "1.0.0"; }; dry-initializer = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1v3dah1r96b10m8xjixmdmymg7dr16wn5715id4vxjkw6vm7s9jd"; type = "gem"; }; version = "3.1.1"; }; dry-logic = { - dependencies = ["concurrent-ruby" "dry-core" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "dry-core" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05nldkc154r0qzlhss7n5klfiyyz05x2fkq08y13s34py6023vcr"; type = "gem"; }; version = "1.5.0"; }; dry-struct = { - dependencies = ["dry-core" "dry-types" "ice_nine" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "dry-core" + "dry-types" + "ice_nine" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1rnlgn4wif0dvkvi10xwh1vd1q6mp35q6a7lwva0zmbc79dh4drp"; type = "gem"; }; version = "1.6.0"; }; dry-types = { - dependencies = ["concurrent-ruby" "dry-core" "dry-inflector" "dry-logic" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "dry-core" + "dry-inflector" + "dry-logic" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1f6dz0hm67rhybh6xq2s3vvr700cp43kf50z2lids62s2i0mh5hj"; type = "gem"; }; version = "1.7.1"; }; equatable = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sjm9zjakyixyvsqziikdrsqfzis6j3fq23crgjkp6fwkfgndj7x"; type = "gem"; }; version = "0.5.0"; }; factory_bot = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pfk942d6qwhw151hxaz7n4knk6whyxqvvywdx2cdw9yhykyaqzq"; type = "gem"; }; version = "6.2.1"; }; faker = { - dependencies = ["i18n"]; - groups = ["default"]; - platforms = []; + dependencies = [ "i18n" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1b8772jybi0vxzbcs5zw17k40z661c8adn2rd6vqqr7ay71bzl09"; type = "gem"; }; version = "3.1.1"; }; git_fame = { - dependencies = ["activesupport" "dry-initializer" "dry-struct" "dry-types" "neatjson" "rugged" "tty-box" "tty-option" "tty-screen" "tty-spinner" "tty-table" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "dry-initializer" + "dry-struct" + "dry-types" + "neatjson" + "rugged" + "tty-box" + "tty-option" + "tty-screen" + "tty-spinner" + "tty-table" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1jqvhzwgvr2bpi4ldqidbcs9prb0xsikp50xx4r8dwhf8m9mh26h"; type = "gem"; }; version = "3.1.1"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qaamqsh5f3szhcakkak8ikxlzxqnv49n2p7504hcz2l0f4nj0wx"; type = "gem"; }; version = "1.14.1"; }; ice_nine = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nv35qg1rps9fsis28hz2cq2fx1i96795f91q4nmkm934xynll2x"; type = "gem"; }; version = "0.11.2"; }; method_source = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pnyh44qycnf9mzi1j6fywd5fkskv3x7nmsqrrws0rjn5dd4ayfp"; type = "gem"; }; version = "1.0.0"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kg9wh7jlc9zsr3hkhpzkbn0ynf4np5ap9m2d8xdrb8shy0y6pmb"; type = "gem"; }; version = "5.18.1"; }; neatjson = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wm1lq8yl6rzysh3wg6fa55w5534k6ppiz0qb7jyvdy582mk5i0s"; type = "gem"; }; version = "0.10.5"; }; necromancer = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0v9nhdkv6zrp7cn48xv7n2vjhsbslpvs0ha36mfkcd56cp27pavz"; type = "gem"; }; version = "0.4.0"; }; parallel = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07vnk6bb54k4yc06xnwck7php50l09vvlw1ga8wdz0pia461zpzb"; type = "gem"; }; version = "1.22.1"; }; parser = { - dependencies = ["ast"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ast" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a2v5f8fw7nxm41xp422p1pbr41hafy62bp95m7vg42cqp5y4grc"; type = "gem"; }; version = "3.2.1.1"; }; pastel = { - dependencies = ["equatable" "tty-color"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "equatable" + "tty-color" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yf30d9kzpm96gw9kwbv31p0qigwfykn8qdis5950plnzgc1vlp1"; type = "gem"; }; version = "0.7.2"; }; pry = { - dependencies = ["coderay" "method_source"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "coderay" + "method_source" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k9kqkd9nps1w1r1rb7wjr31hqzkka2bhi8b518x78dcxppm9zn4"; type = "gem"; }; version = "0.14.2"; }; rainbow = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0smwg4mii0fm38pyb5fddbmrdpifwv22zv3d3px2xx497am93503"; type = "gem"; }; version = "3.1.1"; }; rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15whn7p9nrkxangbs9hh75q585yfn66lv0v2mhj6q6dl6x8bzr2w"; type = "gem"; }; version = "13.0.6"; }; regexp_parser = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0d6241adx6drsfzz74nx1ld3394nm6fjpv3ammzr0g659krvgf7q"; type = "gem"; }; version = "2.7.0"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08ximcyfjy94pm1rhcx04ny1vx2sk0x4y185gzn86yfsbzwkng53"; type = "gem"; }; version = "3.2.5"; }; rspec = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "171rc90vcgjl8p1bdrqa92ymrj8a87qf6w20x05xq29mljcigi6c"; type = "gem"; }; version = "3.12.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rspec-support" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0da45cvllbv39sdbsl65vp5djb2xf5m10mxc9jm7rsqyyxjw4h1f"; type = "gem"; }; version = "3.12.1"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "03ba3lfdsj9zl00v1yvwgcx87lbadf87livlfa5kgqssn9qdnll6"; type = "gem"; }; version = "3.12.2"; }; rspec-github = { - dependencies = ["rspec-core"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rspec-core" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kqjmd85v2fpb06d0rx43dc51f0igc1gmm8y3nz0wvmy7zg02njm"; type = "gem"; }; version = "2.4.0"; }; rspec-its = { - dependencies = ["rspec-core" "rspec-expectations"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15zafd70gxly5i0s00nky14sj2n92dnj3xpj83ysl3c2wx0119ad"; type = "gem"; }; version = "1.3.0"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1dcfh85m3ksir6n8gydsal4d85chpww1b2nahb05nl8xhgh0r2ij"; type = "gem"; }; version = "3.12.4"; }; rspec-support = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12y52zwwb3xr7h91dy9k3ndmyyhr3mjcayk0nnarnrzz8yr48kfx"; type = "gem"; }; version = "3.12.0"; }; rubocop = { - dependencies = ["parallel" "parser" "rainbow" "regexp_parser" "rexml" "rubocop-ast" "ruby-progressbar" "unicode-display_width"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "parallel" + "parser" + "rainbow" + "regexp_parser" + "rexml" + "rubocop-ast" + "ruby-progressbar" + "unicode-display_width" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1sn7ag295blmhpwv6x472m3fd0n25swz9imqwpk0hg21rdcdw7p0"; type = "gem"; }; version = "1.24.1"; }; rubocop-ast = { - dependencies = ["parser"]; - groups = ["default"]; - platforms = []; + dependencies = [ "parser" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0n2gsafg6p7nr1z8i1hkvp2qqkkbg842ba183dnl0h08xd9ms6q5"; type = "gem"; }; version = "1.28.0"; }; rubocop-md = { - dependencies = ["rubocop"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rubocop" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11j802r5r022vxzycvwvzhyg24g8dky4slbvid24xi0ji73q444z"; type = "gem"; }; version = "1.2.0"; }; rubocop-performance = { - dependencies = ["rubocop" "rubocop-ast"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rubocop" + "rubocop-ast" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1n7g0vg06ldjaq4f8c11c7yqy99zng1qdrkkk4kfziippy24yxnc"; type = "gem"; }; version = "1.16.0"; }; rubocop-rake = { - dependencies = ["rubocop"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rubocop" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nyq07sfb3vf3ykc6j2d5yq824lzq1asb474yka36jxgi4hz5djn"; type = "gem"; }; version = "0.6.0"; }; rubocop-rspec = { - dependencies = ["rubocop"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rubocop" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ivc9kgz18cn32iqi9wv5aj903yhamwddw84l7nklbl9xxvwz603"; type = "gem"; }; version = "2.11.1"; }; ruby-progressbar = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cwvyb7j47m7wihpfaq7rc47zwwx9k4v7iqd9s1xch5nm53rrz40"; type = "gem"; }; version = "1.13.0"; }; rugged = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "016bawsahkhxx7p8azxirpl7y2y7i8a027pj8910gwf6ipg329in"; type = "gem"; }; version = "1.6.3"; }; simplecov = { - dependencies = ["docile" "simplecov-html" "simplecov_json_formatter"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "docile" + "simplecov-html" + "simplecov_json_formatter" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "198kcbrjxhhzca19yrdcd6jjj9sb51aaic3b0sc3pwjghg3j49py"; type = "gem"; }; version = "0.22.0"; }; simplecov-cobertura = { - dependencies = ["rexml" "simplecov"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rexml" + "simplecov" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00izmp202y48qvmvwrh5x56cc5ivbjhgkkkjklvqmqzj9pik4r9c"; type = "gem"; }; version = "2.1.0"; }; simplecov-html = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yx01bxa8pbf9ip4hagqkp5m0mqfnwnw2xk8kjraiywz4lrss6jb"; type = "gem"; }; version = "0.12.3"; }; simplecov_json_formatter = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a5l0733hj7sk51j81ykfmlk2vd5vaijlq9d5fn165yyx3xii52j"; type = "gem"; }; version = "0.1.4"; }; strings = { - dependencies = ["strings-ansi" "unicode-display_width" "unicode_utils"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "strings-ansi" + "unicode-display_width" + "unicode_utils" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "111876lcqrykh30w7zzkrl06d6rj9lq24y625m28674vgfxkkcz0"; type = "gem"; }; version = "0.1.8"; }; strings-ansi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "120wa6yjc63b84lprglc52f40hx3fx920n4dmv14rad41rv2s9lh"; type = "gem"; }; version = "0.2.0"; }; tty-box = { - dependencies = ["pastel" "strings" "tty-cursor"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pastel" + "strings" + "tty-cursor" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14g63v0jx87hba50rlv3c521zg9rw0f5d31cihcvym19xxa7v3l5"; type = "gem"; }; version = "0.5.0"; }; tty-color = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zz5xa6xbrj69h334d8nx7z732fz80s1a0b02b53mim95p80s7bk"; type = "gem"; }; version = "0.4.3"; }; tty-cursor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j5zw041jgkmn605ya1zc151bxgxl6v192v2i26qhxx7ws2l2lvr"; type = "gem"; }; version = "0.7.1"; }; tty-option = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xibs7kgbsw401ywfw67wg47fmm7sdcypy85m25af9r2q2hbq7gb"; type = "gem"; }; version = "0.2.0"; }; tty-screen = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0azpjgyhdm8ycblnx9crq3dgb2x8yg454a13n60zfpsc0n138sw1"; type = "gem"; }; version = "0.6.5"; }; tty-spinner = { - dependencies = ["tty-cursor"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-cursor" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hh5awmijnzw9flmh5ak610x1d00xiqagxa5mbr63ysggc26y0qf"; type = "gem"; }; version = "0.9.3"; }; tty-table = { - dependencies = ["equatable" "necromancer" "pastel" "strings" "tty-screen"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "equatable" + "necromancer" + "pastel" + "strings" + "tty-screen" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05krrj1x5pmfbz74paszrsr1316w9b9jlc4wpd9s9gpzqfzwjzcg"; type = "gem"; }; version = "0.10.0"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; unicode-display_width = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1204c1jx2g89pc25qk5150mk7j5k90692i7ihgfzqnad6qni74h2"; type = "gem"; }; version = "1.8.0"; }; unicode_utils = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h1a5yvrxzlf0lxxa1ya31jcizslf774arnsd89vgdhk4g7x08mr"; type = "gem"; }; version = "1.4.0"; }; zeitwerk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "028ld9qmgdllxrl7d0qkl65s58wb1n3gv8yjs28g43a8b1hplxk1"; type = "gem"; }; diff --git a/pkgs/applications/version-management/git-gone/default.nix b/pkgs/applications/version-management/git-gone/default.nix index 1cc039a09fc635..fe29587a05df51 100644 --- a/pkgs/applications/version-management/git-gone/default.nix +++ b/pkgs/applications/version-management/git-gone/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, Security -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, + installShellFiles, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/applications/version-management/git-imerge/default.nix b/pkgs/applications/version-management/git-imerge/default.nix index 66e141ef85ff64..95e971f3cdca18 100644 --- a/pkgs/applications/version-management/git-imerge/default.nix +++ b/pkgs/applications/version-management/git-imerge/default.nix @@ -1,4 +1,9 @@ -{ lib, buildPythonApplication, fetchPypi, installShellFiles }: +{ + lib, + buildPythonApplication, + fetchPypi, + installShellFiles, +}: buildPythonApplication rec { pname = "git-imerge"; diff --git a/pkgs/applications/version-management/git-machete/default.nix b/pkgs/applications/version-management/git-machete/default.nix index 5e1ad5880224c1..4188e3a57ea513 100644 --- a/pkgs/applications/version-management/git-machete/default.nix +++ b/pkgs/applications/version-management/git-machete/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildPythonApplication -, pytest-mock -, pytestCheckHook -, fetchFromGitHub -, installShellFiles -, git -, nix-update-script +{ + lib, + buildPythonApplication, + pytest-mock, + pytestCheckHook, + fetchFromGitHub, + installShellFiles, + git, + nix-update-script, }: buildPythonApplication rec { diff --git a/pkgs/applications/version-management/git-publish/default.nix b/pkgs/applications/version-management/git-publish/default.nix index dd752b94843d25..6596fbeddf3e72 100644 --- a/pkgs/applications/version-management/git-publish/default.nix +++ b/pkgs/applications/version-management/git-publish/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, python, perl, fetchFromGitHub, installShellFiles }: +{ + lib, + stdenv, + python, + perl, + fetchFromGitHub, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "git-publish"; version = "1.8.2"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-jjpbr+ZqG4U8/z0PurnXR+IUKQkG3QB8YqhDkH8uu2Y="; }; - nativeBuildInputs = [ perl installShellFiles ]; + nativeBuildInputs = [ + perl + installShellFiles + ]; buildInputs = [ python ]; installPhase = '' diff --git a/pkgs/applications/version-management/git-quickfix/default.nix b/pkgs/applications/version-management/git-quickfix/default.nix index a9382ee0cb391a..c1b65a3d73189e 100644 --- a/pkgs/applications/version-management/git-quickfix/default.nix +++ b/pkgs/applications/version-management/git-quickfix/default.nix @@ -1,11 +1,13 @@ -{ lib, fetchFromGitHub -, libiconv -, openssl -, pkg-config -, rustPlatform -, stdenv -, Security -, SystemConfiguration +{ + lib, + fetchFromGitHub, + libiconv, + openssl, + pkg-config, + rustPlatform, + stdenv, + Security, + SystemConfiguration, }: rustPlatform.buildRustPackage rec { @@ -22,11 +24,13 @@ rustPlatform.buildRustPackage rec { doCheck = false; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - SystemConfiguration - libiconv - ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + libiconv + ]; cargoHash = "sha256-eTAEf2nRrJ7i2Dw5BBZlLLu8mK2G/wUk40ivtfxk1pI="; diff --git a/pkgs/applications/version-management/git-recent/default.nix b/pkgs/applications/version-management/git-recent/default.nix index 52b4a49d19b99a..91b664b7a748aa 100644 --- a/pkgs/applications/version-management/git-recent/default.nix +++ b/pkgs/applications/version-management/git-recent/default.nix @@ -1,6 +1,12 @@ -{lib, stdenv, git, less, fetchFromGitHub, makeWrapper -# util-linuxMinimal is included because we need the column command -, util-linux +{ + lib, + stdenv, + git, + less, + fetchFromGitHub, + makeWrapper, + # util-linuxMinimal is included because we need the column command + util-linux, }: stdenv.mkDerivation rec { @@ -22,7 +28,13 @@ stdenv.mkDerivation rec { mkdir -p $out/bin cp git-recent $out/bin wrapProgram $out/bin/git-recent \ - --prefix PATH : "${lib.makeBinPath [ git less util-linux ]}" + --prefix PATH : "${ + lib.makeBinPath [ + git + less + util-linux + ] + }" ''; meta = with lib; { diff --git a/pkgs/applications/version-management/git-remote-codecommit/default.nix b/pkgs/applications/version-management/git-remote-codecommit/default.nix index fc9bd9ee02edfa..1b0310de1e76bf 100644 --- a/pkgs/applications/version-management/git-remote-codecommit/default.nix +++ b/pkgs/applications/version-management/git-remote-codecommit/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, python3Packages, awscli }: +{ + lib, + fetchFromGitHub, + python3Packages, + awscli, +}: with python3Packages; @@ -23,15 +28,20 @@ buildPythonApplication rec { propagatedBuildInputs = [ botocore ]; - nativeCheckInputs = [ pytest mock flake8 tox awscli ]; + nativeCheckInputs = [ + pytest + mock + flake8 + tox + awscli + ]; checkPhase = '' pytest ''; meta = { - description = - "Git remote prefix to simplify pushing to and pulling from CodeCommit"; + description = "Git remote prefix to simplify pushing to and pulling from CodeCommit"; maintainers = [ lib.maintainers.zaninime ]; homepage = "https://github.com/awslabs/git-remote-codecommit"; license = lib.licenses.asl20; diff --git a/pkgs/applications/version-management/git-repo-updater/default.nix b/pkgs/applications/version-management/git-repo-updater/default.nix index 5c215644463cc9..8fda8e8b7a1cbd 100644 --- a/pkgs/applications/version-management/git-repo-updater/default.nix +++ b/pkgs/applications/version-management/git-repo-updater/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonApplication -, colorama -, fetchPypi -, gitpython +{ + lib, + buildPythonApplication, + colorama, + fetchPypi, + gitpython, }: buildPythonApplication rec { @@ -26,7 +27,7 @@ buildPythonApplication rec { description = "Easily update multiple Git repositories at once"; homepage = "https://github.com/earwig/git-repo-updater"; license = licenses.mit; - maintainers = with maintainers; [bdesham ]; + maintainers = with maintainers; [ bdesham ]; mainProgram = "gitup"; }; } diff --git a/pkgs/applications/version-management/git-review/default.nix b/pkgs/applications/version-management/git-review/default.nix index 2f7defa3ee55c8..ac6d7879e2bfc0 100644 --- a/pkgs/applications/version-management/git-review/default.nix +++ b/pkgs/applications/version-management/git-review/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitea -, buildPythonApplication -, pbr -, requests -, setuptools -, gitUpdater +{ + lib, + fetchFromGitea, + buildPythonApplication, + pbr, + requests, + setuptools, + gitUpdater, }: buildPythonApplication rec { @@ -23,7 +24,10 @@ buildPythonApplication rec { hash = "sha256-UfYc662NqnQt0+CKc+18jXnNTOcZv8urCNBsWd6x0VQ="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; nativeBuildInputs = [ pbr diff --git a/pkgs/applications/version-management/git-stack/default.nix b/pkgs/applications/version-management/git-stack/default.nix index 67893b122d0695..e3a61ad02fe453 100644 --- a/pkgs/applications/version-management/git-stack/default.nix +++ b/pkgs/applications/version-management/git-stack/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, Security -, testers -, git-stack +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, + testers, + git-stack, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/applications/version-management/git-trim/default.nix b/pkgs/applications/version-management/git-trim/default.nix index 60db7f8ee71e10..1827123ebd7e79 100644 --- a/pkgs/applications/version-management/git-trim/default.nix +++ b/pkgs/applications/version-management/git-trim/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, libgit2 -, IOKit -, CoreFoundation -, Security -, fetchpatch +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + libgit2, + IOKit, + CoreFoundation, + Security, + fetchpatch, }: rustPlatform.buildRustPackage rec { @@ -36,8 +37,16 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl libgit2 ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ IOKit CoreFoundation Security ]; + buildInputs = + [ + openssl + libgit2 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + IOKit + CoreFoundation + Security + ]; postInstall = '' install -Dm644 -t $out/share/man/man1/ docs/git-trim.1 diff --git a/pkgs/applications/version-management/git-up/default.nix b/pkgs/applications/version-management/git-up/default.nix index 2e2bad28068440..6c96b5f9b79cf8 100644 --- a/pkgs/applications/version-management/git-up/default.nix +++ b/pkgs/applications/version-management/git-up/default.nix @@ -1,7 +1,8 @@ -{ lib -, pythonPackages -, fetchPypi -, git +{ + lib, + pythonPackages, + fetchPypi, + git, }: pythonPackages.buildPythonApplication rec { @@ -20,13 +21,15 @@ pythonPackages.buildPythonApplication rec { ]; # git should be on path for tool to work correctly - propagatedBuildInputs = [ - git - ] ++ (with pythonPackages; [ - colorama - gitpython - termcolor - ]); + propagatedBuildInputs = + [ + git + ] + ++ (with pythonPackages; [ + colorama + gitpython + termcolor + ]); nativeCheckInputs = [ git diff --git a/pkgs/applications/version-management/gita/default.nix b/pkgs/applications/version-management/gita/default.nix index 9bb602d2a5cdbe..433ebcb1a38450 100644 --- a/pkgs/applications/version-management/gita/default.nix +++ b/pkgs/applications/version-management/gita/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, pyyaml -, setuptools -, installShellFiles +{ + lib, + buildPythonApplication, + fetchFromGitHub, + pyyaml, + setuptools, + installShellFiles, }: buildPythonApplication rec { diff --git a/pkgs/applications/version-management/gitlab-triage/default.nix b/pkgs/applications/version-management/gitlab-triage/default.nix index 20335e2003a73b..4dbf52f83fba31 100644 --- a/pkgs/applications/version-management/gitlab-triage/default.nix +++ b/pkgs/applications/version-management/gitlab-triage/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "gitlab-triage"; diff --git a/pkgs/applications/version-management/gitlab-triage/gemset.nix b/pkgs/applications/version-management/gitlab-triage/gemset.nix index 34d328d9ee9a61..fb41c8961a71f4 100644 --- a/pkgs/applications/version-management/gitlab-triage/gemset.nix +++ b/pkgs/applications/version-management/gitlab-triage/gemset.nix @@ -1,137 +1,153 @@ { activesupport = { - dependencies = ["concurrent-ruby" "i18n" "minitest" "tzinfo"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "concurrent-ruby" + "i18n" + "minitest" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0z05zyc57f8ywvdvls6nx93vrhyyzzpgz729mwampz1qb8vvcspj"; type = "gem"; }; version = "7.0.3"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0s4fpn3mqiizpmpy2a24k4v365pv75y50292r8ajrv4i1p5b2k14"; type = "gem"; }; version = "1.1.10"; }; gitlab-triage = { - dependencies = ["activesupport" "globalid" "graphql-client" "httparty"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "activesupport" + "globalid" + "graphql-client" + "httparty" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vs120wyqm12xy66nv0723cy3m66g5lhhdd37izbc9qwyq03m729"; type = "gem"; }; version = "1.23.1"; }; globalid = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xk28839pi36yzlqgh7k5wqmiphz7wg2c2r2wzfvs2s7g63hy3nv"; type = "gem"; }; version = "0.6.0"; }; graphql = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18k3wh73mb7rs469wfn4m10d1rlg2v9chd89nf7vy8z3yjbf9nl4"; type = "gem"; }; version = "2.0.11"; }; graphql-client = { - dependencies = ["activesupport" "graphql"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "activesupport" + "graphql" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02r5qvfr176n051mp1c79xbpjhjqm92kk4118r0fbp131y0xralq"; type = "gem"; }; version = "0.18.0"; }; httparty = { - dependencies = ["mime-types" "multi_xml"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "mime-types" + "multi_xml" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rs8c5wga6f1acyaj90d2hlv307gh2flfpb8y48wdk2si812l3a9"; type = "gem"; }; version = "0.20.0"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b2qyvnk4yynlg17ymkq4g5xgr275637fhl1mjh0valw3cb1fhhg"; type = "gem"; }; version = "1.10.0"; }; mime-types = { - dependencies = ["mime-types-data"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mime-types-data" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ipw892jbksbxxcrlx9g5ljq60qx47pm24ywgfbyjskbcl78pkvb"; type = "gem"; }; version = "3.4.1"; }; mime-types-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "003gd7mcay800k2q4pb2zn8lwwgci4bhi42v2jvlidm8ksx03i6q"; type = "gem"; }; version = "3.2022.0105"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14a9ign0hj3z3j4cpfplj2djaskx3skzyx4fl3x53d7saxmhrgn1"; type = "gem"; }; version = "5.16.2"; }; multi_xml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lmd4f401mvravi1i1yq7b2qjjli0yq7dfc4p1nj5nwajp7r6hyj"; type = "gem"; }; version = "0.6.0"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10qp5x7f9hvlc0psv9gsfbxg4a7s0485wsbq1kljkxq94in91l4z"; type = "gem"; }; diff --git a/pkgs/applications/version-management/gitlab/default.nix b/pkgs/applications/version-management/gitlab/default.nix index ec90b0e168a195..f1cf80ead01ef0 100644 --- a/pkgs/applications/version-management/gitlab/default.nix +++ b/pkgs/applications/version-management/gitlab/default.nix @@ -1,37 +1,43 @@ -{ bundlerEnv -, cacert -, defaultGemConfig -, fetchFromGitLab -, fetchYarnDeps -, fixup-yarn-lock -, git -, gitlabEnterprise ? false -, lib -, makeWrapper -, nettools -, nixosTests -, nodejs -, replace -, ruby_3_2 -, stdenv -, tzdata -, yarn - -# gem dependencies: -# gitlab-glfm-markdown -, buildRubyGem, cargo, rustc, rustPlatform - -# gpgme -, pkg-config - -# openssl -, openssl - -# ruby-magic -, file - -# static-holmes -, icu, which, zlib +{ + bundlerEnv, + cacert, + defaultGemConfig, + fetchFromGitLab, + fetchYarnDeps, + fixup-yarn-lock, + git, + gitlabEnterprise ? false, + lib, + makeWrapper, + nettools, + nixosTests, + nodejs, + replace, + ruby_3_2, + stdenv, + tzdata, + yarn, + + # gem dependencies: + # gitlab-glfm-markdown + buildRubyGem, + cargo, + rustc, + rustPlatform, + + # gpgme + pkg-config, + + # openssl + openssl, + + # ruby-magic + file, + + # static-holmes + icu, + which, + zlib, }: let @@ -51,74 +57,85 @@ let gemdir = ./rubyEnv; gemset = import (gemdir + "/gemset.nix") src; gemConfig = defaultGemConfig // { - gpgme = attrs: { - nativeBuildInputs = [ pkg-config ]; - }; - # the openssl needs the openssl include files - openssl = attrs: { - buildInputs = [ openssl ]; - }; - ruby-magic = attrs: { - buildInputs = [ file ]; - buildFlags = [ "--enable-system-libraries" ]; - }; - gitlab-glfm-markdown = attrs: { - cargoDeps = rustPlatform.fetchCargoTarball { - src = stdenv.mkDerivation { - inherit (buildRubyGem { inherit (attrs) gemName version source; }) - name - src - unpackPhase - nativeBuildInputs + gpgme = attrs: { + nativeBuildInputs = [ pkg-config ]; + }; + # the openssl needs the openssl include files + openssl = attrs: { + buildInputs = [ openssl ]; + }; + ruby-magic = attrs: { + buildInputs = [ file ]; + buildFlags = [ "--enable-system-libraries" ]; + }; + gitlab-glfm-markdown = attrs: { + cargoDeps = rustPlatform.fetchCargoTarball { + src = stdenv.mkDerivation { + inherit (buildRubyGem { inherit (attrs) gemName version source; }) + name + src + unpackPhase + nativeBuildInputs ; - dontBuilt = true; - installPhase = '' - cp -R ext/glfm_markdown $out - cp Cargo.lock $out - ''; - }; - hash = "sha256-L/URWw7NoQhi7VV8ZiKLzthbF0wl4rIUqCQdH9wmAV0="; + dontBuilt = true; + installPhase = '' + cp -R ext/glfm_markdown $out + cp Cargo.lock $out + ''; }; + hash = "sha256-L/URWw7NoQhi7VV8ZiKLzthbF0wl4rIUqCQdH9wmAV0="; + }; - dontBuild = false; + dontBuild = false; - nativeBuildInputs = [ - cargo - rustc - rustPlatform.cargoSetupHook - rustPlatform.bindgenHook - ]; + nativeBuildInputs = [ + cargo + rustc + rustPlatform.cargoSetupHook + rustPlatform.bindgenHook + ]; - disallowedReferences = [ - rustc.unwrapped - ]; + disallowedReferences = [ + rustc.unwrapped + ]; - preInstall = '' - export CARGO_HOME="$PWD/../.cargo/" - ''; + preInstall = '' + export CARGO_HOME="$PWD/../.cargo/" + ''; - postInstall = '' - mv -v $GEM_HOME/gems/${attrs.gemName}-${attrs.version}/lib/{glfm_markdown/glfm_markdown.so,} - find $out -type f -name .rustc_info.json -delete - ''; - }; + postInstall = '' + mv -v $GEM_HOME/gems/${attrs.gemName}-${attrs.version}/lib/{glfm_markdown/glfm_markdown.so,} + find $out -type f -name .rustc_info.json -delete + ''; + }; - static_holmes = attrs: { - nativeBuildInputs = [ - icu - which - zlib.dev - ]; - }; + static_holmes = attrs: { + nativeBuildInputs = [ + icu + which + zlib.dev + ]; }; + }; groups = [ - "default" "unicorn" "ed25519" "metrics" "development" "puma" "test" "kerberos" "opentelemetry" + "default" + "unicorn" + "ed25519" + "metrics" + "development" + "puma" + "test" + "kerberos" + "opentelemetry" ]; # N.B. omniauth_oauth2_generic and apollo_upload_server both provide a # `console` executable. ignoreCollisions = true; - extraConfigPaths = [ "${src}/vendor" "${src}/gems" ]; + extraConfigPaths = [ + "${src}/vendor" + "${src}/gems" + ]; }; assets = stdenv.mkDerivation { @@ -130,7 +147,15 @@ let sha256 = data.yarn_hash; }; - nativeBuildInputs = [ rubyEnv.wrappedRuby rubyEnv.bundler nodejs yarn git cacert fixup-yarn-lock ]; + nativeBuildInputs = [ + rubyEnv.wrappedRuby + rubyEnv.bundler + nodejs + yarn + git + cacert + fixup-yarn-lock + ]; patches = [ # Since version 12.6.0, the rake tasks need the location of git, @@ -201,7 +226,12 @@ stdenv.mkDerivation { nativeBuildInputs = [ makeWrapper ]; buildInputs = [ - rubyEnv rubyEnv.wrappedRuby rubyEnv.bundler tzdata git nettools + rubyEnv + rubyEnv.wrappedRuby + rubyEnv.bundler + tzdata + git + nettools ]; patches = [ @@ -275,19 +305,24 @@ stdenv.mkDerivation { }; }; - meta = with lib; { - homepage = "http://www.gitlab.com/"; - platforms = platforms.linux; - maintainers = teams.gitlab.members; - } // (if gitlabEnterprise then + meta = + with lib; { - license = licenses.unfreeRedistributable; # https://gitlab.com/gitlab-org/gitlab-ee/raw/master/LICENSE - description = "GitLab Enterprise Edition"; + homepage = "http://www.gitlab.com/"; + platforms = platforms.linux; + maintainers = teams.gitlab.members; } - else - { - license = licenses.mit; - description = "GitLab Community Edition"; - longDescription = "GitLab Community Edition (CE) is an open source end-to-end software development platform with built-in version control, issue tracking, code review, CI/CD, and more. Self-host GitLab CE on your own servers, in a container, or on a cloud provider."; - }); + // ( + if gitlabEnterprise then + { + license = licenses.unfreeRedistributable; # https://gitlab.com/gitlab-org/gitlab-ee/raw/master/LICENSE + description = "GitLab Enterprise Edition"; + } + else + { + license = licenses.mit; + description = "GitLab Community Edition"; + longDescription = "GitLab Community Edition (CE) is an open source end-to-end software development platform with built-in version control, issue tracking, code review, CI/CD, and more. Self-host GitLab CE on your own servers, in a container, or on a cloud provider."; + } + ); } diff --git a/pkgs/applications/version-management/gitlint/default.nix b/pkgs/applications/version-management/gitlint/default.nix index d29bf08855f079..7bfe3658af5362 100644 --- a/pkgs/applications/version-management/gitlint/default.nix +++ b/pkgs/applications/version-management/gitlint/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, gitMinimal -, python3 +{ + lib, + buildPythonApplication, + fetchFromGitHub, + gitMinimal, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -46,7 +47,10 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://jorisroovers.com/gitlint/"; changelog = "https://github.com/jorisroovers/gitlint/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ ethancedwards8 fab ]; + maintainers = with maintainers; [ + ethancedwards8 + fab + ]; mainProgram = "gitlint"; }; } diff --git a/pkgs/applications/version-management/gitmux/default.nix b/pkgs/applications/version-management/gitmux/default.nix index 8bb5277dc4ec78..b3c1189fe3d1a4 100644 --- a/pkgs/applications/version-management/gitmux/default.nix +++ b/pkgs/applications/version-management/gitmux/default.nix @@ -1,4 +1,11 @@ -{ fetchFromGitHub, buildGoModule, lib, testers, gitmux, git }: +{ + fetchFromGitHub, + buildGoModule, + lib, + testers, + gitmux, + git, +}: buildGoModule rec { pname = "gitmux"; diff --git a/pkgs/applications/version-management/gitoxide/default.nix b/pkgs/applications/version-management/gitoxide/default.nix index 1edbc3e590f648..61b8cfdf68c5eb 100644 --- a/pkgs/applications/version-management/gitoxide/default.nix +++ b/pkgs/applications/version-management/gitoxide/default.nix @@ -1,21 +1,23 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, cmake -, pkg-config -, stdenv -, apple-sdk_11 -, curl -, openssl -, buildPackages -, installShellFiles +{ + lib, + rustPlatform, + fetchFromGitHub, + cmake, + pkg-config, + stdenv, + apple-sdk_11, + curl, + openssl, + buildPackages, + installShellFiles, }: let canRunCmd = stdenv.hostPlatform.emulatorAvailable buildPackages; gix = "${stdenv.hostPlatform.emulator buildPackages} $out/bin/gix"; ein = "${stdenv.hostPlatform.emulator buildPackages} $out/bin/ein"; -in rustPlatform.buildRustPackage rec { +in +rustPlatform.buildRustPackage rec { pname = "gitoxide"; version = "0.39.0"; @@ -28,11 +30,13 @@ in rustPlatform.buildRustPackage rec { cargoHash = "sha256-36ue3f67Btw0/AM5lTaByrJLKU5r1FJA3sFRJ1IbXXc="; - nativeBuildInputs = [ cmake pkg-config installShellFiles ]; + nativeBuildInputs = [ + cmake + pkg-config + installShellFiles + ]; - buildInputs = [ curl ] ++ (if stdenv.hostPlatform.isDarwin - then [ apple-sdk_11 ] - else [ openssl ]); + buildInputs = [ curl ] ++ (if stdenv.hostPlatform.isDarwin then [ apple-sdk_11 ] else [ openssl ]); preFixup = lib.optionalString canRunCmd '' installShellCompletion --cmd gix \ @@ -53,7 +57,10 @@ in rustPlatform.buildRustPackage rec { description = "Command-line application for interacting with git repositories"; homepage = "https://github.com/Byron/gitoxide"; changelog = "https://github.com/Byron/gitoxide/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ syberant ]; }; } diff --git a/pkgs/applications/version-management/gitqlient/default.nix b/pkgs/applications/version-management/gitqlient/default.nix index da140e1b887db2..f396dfeed1775c 100644 --- a/pkgs/applications/version-management/gitqlient/default.nix +++ b/pkgs/applications/version-management/gitqlient/default.nix @@ -1,9 +1,10 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, qmake -, qtwebengine -, gitUpdater +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qtwebengine, + gitUpdater, }: mkDerivation rec { diff --git a/pkgs/applications/version-management/gittyup/default.nix b/pkgs/applications/version-management/gittyup/default.nix index 146f2c7e95251a..aab9b79c0417e0 100644 --- a/pkgs/applications/version-management/gittyup/default.nix +++ b/pkgs/applications/version-management/gittyup/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, cmark -, darwin -, git -, libssh2 -, lua5_4 -, hunspell -, ninja -, openssl -, pkg-config -, qtbase -, qttools -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + cmark, + darwin, + git, + libssh2, + lua5_4, + hunspell, + ninja, + openssl, + pkg-config, + qtbase, + qttools, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -48,19 +49,24 @@ stdenv.mkDerivation rec { wrapQtAppsHook ]; - buildInputs = [ - cmark - git - hunspell - libssh2 - lua5_4 - openssl - qtbase - qttools - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - CoreFoundation - Security - ]); + buildInputs = + [ + cmark + git + hunspell + libssh2 + lua5_4 + openssl + qtbase + qttools + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + CoreFoundation + Security + ] + ); postInstall = '' # Those are not program libs, just some Qt5 libs that the build system leaks for some reason diff --git a/pkgs/applications/version-management/lucky-commit/default.nix b/pkgs/applications/version-management/lucky-commit/default.nix index 6e3cb2c09d5f9c..db35bcc0ec2bdb 100644 --- a/pkgs/applications/version-management/lucky-commit/default.nix +++ b/pkgs/applications/version-management/lucky-commit/default.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, withOpenCL ? true -, stdenv -, OpenCL -, ocl-icd +{ + lib, + rustPlatform, + fetchFromGitHub, + withOpenCL ? true, + stdenv, + OpenCL, + ocl-icd, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/applications/version-management/mercurial/default.nix b/pkgs/applications/version-management/mercurial/default.nix index fd41363e165098..15b71c98c8133e 100644 --- a/pkgs/applications/version-management/mercurial/default.nix +++ b/pkgs/applications/version-management/mercurial/default.nix @@ -1,23 +1,41 @@ -{ lib, stdenv, fetchurl, python3Packages, makeWrapper, gettext, installShellFiles -, re2Support ? true -, rustSupport ? stdenv.hostPlatform.isLinux, cargo, rustPlatform, rustc -, fullBuild ? false -, gitSupport ? fullBuild -, guiSupport ? fullBuild, tk -, highlightSupport ? fullBuild -, ApplicationServices -# test dependencies -, runCommand -, unzip -, which -, sqlite -, git -, cacert -, gnupg +{ + lib, + stdenv, + fetchurl, + python3Packages, + makeWrapper, + gettext, + installShellFiles, + re2Support ? true, + rustSupport ? stdenv.hostPlatform.isLinux, + cargo, + rustPlatform, + rustc, + fullBuild ? false, + gitSupport ? fullBuild, + guiSupport ? fullBuild, + tk, + highlightSupport ? fullBuild, + ApplicationServices, + # test dependencies + runCommand, + unzip, + which, + sqlite, + git, + cacert, + gnupg, }: let - inherit (python3Packages) docutils python fb-re2 pygit2 pygments setuptools; + inherit (python3Packages) + docutils + python + fb-re2 + pygit2 + pygments + setuptools + ; self = python3Packages.buildPythonApplication rec { pname = "mercurial${lib.optionalString fullBuild "-full"}"; @@ -32,55 +50,66 @@ let passthru = { inherit python; }; # pass it so that the same version can be used in hg2git - cargoDeps = if rustSupport then rustPlatform.fetchCargoTarball { - inherit src; - name = "mercurial-${version}"; - hash = "sha256-/HjgGtjKfLLufEqyT7xHYIlC5xnVunYoA+H1xLS1bVw="; - sourceRoot = "mercurial-${version}/rust"; - } else null; + cargoDeps = + if rustSupport then + rustPlatform.fetchCargoTarball { + inherit src; + name = "mercurial-${version}"; + hash = "sha256-/HjgGtjKfLLufEqyT7xHYIlC5xnVunYoA+H1xLS1bVw="; + sourceRoot = "mercurial-${version}/rust"; + } + else + null; cargoRoot = if rustSupport then "rust" else null; - propagatedBuildInputs = lib.optional re2Support fb-re2 + propagatedBuildInputs = + lib.optional re2Support fb-re2 ++ lib.optional gitSupport pygit2 ++ lib.optional highlightSupport pygments; - nativeBuildInputs = [ makeWrapper gettext installShellFiles setuptools ] + nativeBuildInputs = + [ + makeWrapper + gettext + installShellFiles + setuptools + ] ++ lib.optionals rustSupport [ - rustPlatform.cargoSetupHook - cargo - rustc - ]; - buildInputs = [ docutils ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ ApplicationServices ]; - - makeFlags = [ "PREFIX=$(out)" ] - ++ lib.optional rustSupport "PURE=--rust"; - - postInstall = (lib.optionalString guiSupport '' - mkdir -p $out/etc/mercurial - cp contrib/hgk $out/bin - cat >> $out/etc/mercurial/hgrc << EOF - [extensions] - hgk=$out/${python.sitePackages}/hgext/hgk.py - EOF - # setting HG so that hgk can be run itself as well (not only hg view) - WRAP_TK=" --set TK_LIBRARY ${tk}/lib/${tk.libPrefix} - --set HG $out/bin/hg - --prefix PATH : ${tk}/bin " - '') + '' - for i in $(cd $out/bin && ls); do - wrapProgram $out/bin/$i \ - $WRAP_TK - done - - # copy hgweb.cgi to allow use in apache - mkdir -p $out/share/cgi-bin - cp -v hgweb.cgi contrib/hgweb.wsgi $out/share/cgi-bin - chmod u+x $out/share/cgi-bin/hgweb.cgi - - installShellCompletion --cmd hg \ - --bash contrib/bash_completion \ - --zsh contrib/zsh_completion - ''; + rustPlatform.cargoSetupHook + cargo + rustc + ]; + buildInputs = [ docutils ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ ApplicationServices ]; + + makeFlags = [ "PREFIX=$(out)" ] ++ lib.optional rustSupport "PURE=--rust"; + + postInstall = + (lib.optionalString guiSupport '' + mkdir -p $out/etc/mercurial + cp contrib/hgk $out/bin + cat >> $out/etc/mercurial/hgrc << EOF + [extensions] + hgk=$out/${python.sitePackages}/hgext/hgk.py + EOF + # setting HG so that hgk can be run itself as well (not only hg view) + WRAP_TK=" --set TK_LIBRARY ${tk}/lib/${tk.libPrefix} + --set HG $out/bin/hg + --prefix PATH : ${tk}/bin " + '') + + '' + for i in $(cd $out/bin && ls); do + wrapProgram $out/bin/$i \ + $WRAP_TK + done + + # copy hgweb.cgi to allow use in apache + mkdir -p $out/share/cgi-bin + cp -v hgweb.cgi contrib/hgweb.wsgi $out/share/cgi-bin + chmod u+x $out/share/cgi-bin/hgweb.cgi + + installShellCompletion --cmd hg \ + --bash contrib/bash_completion \ + --zsh contrib/zsh_completion + ''; passthru.tests = { mercurial-tests = makeTests { flags = "--with-hg=$MERCURIAL_BASE/bin/hg"; }; @@ -92,119 +121,142 @@ let downloadPage = "https://www.mercurial-scm.org/release/"; changelog = "https://wiki.mercurial-scm.org/Release${versions.majorMinor version}"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ lukegb pacien techknowlogick ]; + maintainers = with maintainers; [ + lukegb + pacien + techknowlogick + ]; platforms = platforms.unix; mainProgram = "hg"; }; }; - makeTests = { mercurial ? self, nameSuffix ? "", flags ? "" }: runCommand "${mercurial.pname}${nameSuffix}-tests" { - inherit (mercurial) src; - - SSL_CERT_FILE = "${cacert}/etc/ssl/certs/ca-bundle.crt"; # needed for git - MERCURIAL_BASE = mercurial; - nativeBuildInputs = [ - python - unzip - which - sqlite - git - gnupg - ]; - - # https://bz.mercurial-scm.org/show_bug.cgi?id=6887 - propagatedBuildInputs = [ setuptools ]; - - postPatch = '' - patchShebangs . - - for f in **/*.{py,c,t}; do - # not only used in shebangs - substituteAllInPlace "$f" '/bin/sh' '${stdenv.shell}' - done - - for f in **/*.t; do - substituteInPlace 2>/dev/null "$f" \ - --replace '*/hg:' '*/*hg*:' \${/* paths emitted by our wrapped hg look like ..hg-wrapped-wrapped */""} - --replace '"$PYTHON" "$BINDIR"/hg' '"$BINDIR"/hg' ${/* 'hg' is a wrapper; don't run using python directly */""} - done - - # https://bz.mercurial-scm.org/show_bug.cgi?id=6887 - # Adding setuptools to the python path is not enough for the distutils - # module to be found, so we patch usage directly: - substituteInPlace tests/hghave.py \ - --replace-fail "distutils" "setuptools._distutils" - ''; - - # This runs Mercurial _a lot_ of times. - requiredSystemFeatures = [ "big-parallel" ]; - - # Don't run tests if not-Linux or if cross-compiling. - meta.broken = !stdenv.hostPlatform.isLinux || stdenv.buildPlatform != stdenv.hostPlatform; - } '' - addToSearchPathWithCustomDelimiter : PYTHONPATH "${mercurial}/${python.sitePackages}" - - unpackPhase - cd "$sourceRoot" - patchPhase - - cat << EOF > tests/blacklists/nix - # tests enforcing "/usr/bin/env" shebangs, which are patched for nix - test-run-tests.t - test-check-shbang.t - - # unstable experimental/unsupported features - # https://bz.mercurial-scm.org/show_bug.cgi?id=6633#c1 - test-git-interop.t - - # doesn't like the extra setlocale warnings emitted by our bash wrappers - test-locale.t - - # Python 3.10-3.12 deprecation warning: asyncore - # https://bz.mercurial-scm.org/show_bug.cgi?id=6727 - test-patchbomb-tls.t - - # Python 3.12 _lsprof module change, breaking profile test - # https://bz.mercurial-scm.org/show_bug.cgi?id=6846 - test-profile.t - - # Python 3.12 deprecation warning: multi-threaded fork in worker.py - # https://bz.mercurial-scm.org/show_bug.cgi?id=6892 - test-clone-stream.t - test-clonebundles.t - test-fix-topology.t - test-fix.t - test-persistent-nodemap.t - test-profile.t - test-simple-update.t - - EOF - - export HGTEST_REAL_HG="${mercurial}/bin/hg" - # include tests for native components - export HGMODULEPOLICY="rust+c" - # extended timeout necessary for tests to pass on the busy CI workers - export HGTESTFLAGS="--blacklist blacklists/nix --timeout 1800 -j$NIX_BUILD_CORES ${flags}" - make check - touch $out - ''; + makeTests = + { + mercurial ? self, + nameSuffix ? "", + flags ? "", + }: + runCommand "${mercurial.pname}${nameSuffix}-tests" + { + inherit (mercurial) src; + + SSL_CERT_FILE = "${cacert}/etc/ssl/certs/ca-bundle.crt"; # needed for git + MERCURIAL_BASE = mercurial; + nativeBuildInputs = [ + python + unzip + which + sqlite + git + gnupg + ]; + + # https://bz.mercurial-scm.org/show_bug.cgi?id=6887 + propagatedBuildInputs = [ setuptools ]; + + postPatch = '' + patchShebangs . + + for f in **/*.{py,c,t}; do + # not only used in shebangs + substituteAllInPlace "$f" '/bin/sh' '${stdenv.shell}' + done + + for f in **/*.t; do + substituteInPlace 2>/dev/null "$f" \ + --replace '*/hg:' '*/*hg*:' \${ + # paths emitted by our wrapped hg look like ..hg-wrapped-wrapped + "" + } + --replace '"$PYTHON" "$BINDIR"/hg' '"$BINDIR"/hg' ${ + # 'hg' is a wrapper; don't run using python directly + "" + } + done + + # https://bz.mercurial-scm.org/show_bug.cgi?id=6887 + # Adding setuptools to the python path is not enough for the distutils + # module to be found, so we patch usage directly: + substituteInPlace tests/hghave.py \ + --replace-fail "distutils" "setuptools._distutils" + ''; + + # This runs Mercurial _a lot_ of times. + requiredSystemFeatures = [ "big-parallel" ]; + + # Don't run tests if not-Linux or if cross-compiling. + meta.broken = !stdenv.hostPlatform.isLinux || stdenv.buildPlatform != stdenv.hostPlatform; + } + '' + addToSearchPathWithCustomDelimiter : PYTHONPATH "${mercurial}/${python.sitePackages}" + + unpackPhase + cd "$sourceRoot" + patchPhase + + cat << EOF > tests/blacklists/nix + # tests enforcing "/usr/bin/env" shebangs, which are patched for nix + test-run-tests.t + test-check-shbang.t + + # unstable experimental/unsupported features + # https://bz.mercurial-scm.org/show_bug.cgi?id=6633#c1 + test-git-interop.t + + # doesn't like the extra setlocale warnings emitted by our bash wrappers + test-locale.t + + # Python 3.10-3.12 deprecation warning: asyncore + # https://bz.mercurial-scm.org/show_bug.cgi?id=6727 + test-patchbomb-tls.t + + # Python 3.12 _lsprof module change, breaking profile test + # https://bz.mercurial-scm.org/show_bug.cgi?id=6846 + test-profile.t + + # Python 3.12 deprecation warning: multi-threaded fork in worker.py + # https://bz.mercurial-scm.org/show_bug.cgi?id=6892 + test-clone-stream.t + test-clonebundles.t + test-fix-topology.t + test-fix.t + test-persistent-nodemap.t + test-profile.t + test-simple-update.t + + EOF + + export HGTEST_REAL_HG="${mercurial}/bin/hg" + # include tests for native components + export HGMODULEPOLICY="rust+c" + # extended timeout necessary for tests to pass on the busy CI workers + export HGTESTFLAGS="--blacklist blacklists/nix --timeout 1800 -j$NIX_BUILD_CORES ${flags}" + make check + touch $out + ''; in - self.overridePythonAttrs (origAttrs: { - passthru = origAttrs.passthru // rec { - # withExtensions takes a function which takes the python packages set and - # returns a list of extensions to install. - # - # for instance: mercurial.withExtension (pm: [ pm.hg-evolve ]) - withExtensions = f: let +self.overridePythonAttrs (origAttrs: { + passthru = origAttrs.passthru // rec { + # withExtensions takes a function which takes the python packages set and + # returns a list of extensions to install. + # + # for instance: mercurial.withExtension (pm: [ pm.hg-evolve ]) + withExtensions = + f: + let python = self.python; - mercurialHighPrio = ps: (ps.toPythonModule self).overrideAttrs (oldAttrs: { - meta = oldAttrs.meta // { - priority = 50; - }; - }); + mercurialHighPrio = + ps: + (ps.toPythonModule self).overrideAttrs (oldAttrs: { + meta = oldAttrs.meta // { + priority = 50; + }; + }); plugins = (f python.pkgs) ++ [ (mercurialHighPrio python.pkgs) ]; env = python.withPackages (ps: plugins); - in stdenv.mkDerivation { + in + stdenv.mkDerivation { pname = "${self.pname}-with-extensions"; inherit (self) src version meta; @@ -243,8 +295,8 @@ in ''; }; - tests = origAttrs.passthru.tests // { - withExtensions = withExtensions (pm: [ pm.hg-evolve ]); - }; + tests = origAttrs.passthru.tests // { + withExtensions = withExtensions (pm: [ pm.hg-evolve ]); }; - }) + }; +}) diff --git a/pkgs/applications/version-management/merge-fmt/default.nix b/pkgs/applications/version-management/merge-fmt/default.nix index 3924650d994d8e..81f2ecfce4c83e 100644 --- a/pkgs/applications/version-management/merge-fmt/default.nix +++ b/pkgs/applications/version-management/merge-fmt/default.nix @@ -1,19 +1,29 @@ -{ lib, fetchurl, buildDunePackage, cmdliner, base, stdio }: +{ + lib, + fetchurl, + buildDunePackage, + cmdliner, + base, + stdio, +}: buildDunePackage rec { pname = "merge-fmt"; version = "0.3"; src = fetchurl { - url = - "https://github.com/hhugo/merge-fmt/releases/download/${version}/merge-fmt-${version}.tbz"; + url = "https://github.com/hhugo/merge-fmt/releases/download/${version}/merge-fmt-${version}.tbz"; hash = "sha256-F+ds0ToWcKD4NJU3yYSVW4B3m2LBnhR+4QVTDO79q14="; }; minimalOCamlVersion = "4.06"; duneVersion = "3"; - buildInputs = [ cmdliner base stdio ]; + buildInputs = [ + cmdliner + base + stdio + ]; # core v0.17 compatibility, obtained by `git diff -r 3e37827~2..3e37827` patches = [ ./merge-fmt.patch ]; diff --git a/pkgs/applications/version-management/monotone-viz/default.nix b/pkgs/applications/version-management/monotone-viz/default.nix index e8eac58e73f613..60ccf5e850c4cc 100644 --- a/pkgs/applications/version-management/monotone-viz/default.nix +++ b/pkgs/applications/version-management/monotone-viz/default.nix @@ -1,27 +1,77 @@ -{ lib, stdenv, fetchurl, fetchpatch, ocamlPackages, gnome2, pkg-config, makeWrapper, glib -, libtool, libpng, bison, expat, fontconfig, gd, pango, libjpeg, libwebp, libX11, libXaw +{ + lib, + stdenv, + fetchurl, + fetchpatch, + ocamlPackages, + gnome2, + pkg-config, + makeWrapper, + glib, + libtool, + libpng, + bison, + expat, + fontconfig, + gd, + pango, + libjpeg, + libwebp, + libX11, + libXaw, }: # We need an old version of Graphviz for format compatibility reasons. # This version is vulnerable, but monotone-viz will never feed it bad input. -let graphviz_2_0 = import ./graphviz-2.0.nix { - inherit lib stdenv fetchurl pkg-config libX11 libpng libjpeg expat libXaw - bison libtool fontconfig pango gd libwebp; - }; in -let inherit (gnome2) libgnomecanvas; in -let inherit (ocamlPackages) ocaml lablgtk camlp4; in +let + graphviz_2_0 = import ./graphviz-2.0.nix { + inherit + lib + stdenv + fetchurl + pkg-config + libX11 + libpng + libjpeg + expat + libXaw + bison + libtool + fontconfig + pango + gd + libwebp + ; + }; +in +let + inherit (gnome2) libgnomecanvas; +in +let + inherit (ocamlPackages) ocaml lablgtk camlp4; +in stdenv.mkDerivation rec { version = "1.0.2"; pname = "monotone-viz"; - nativeBuildInputs = [ pkg-config makeWrapper ocaml camlp4 ]; - buildInputs = [ lablgtk libgnomecanvas glib graphviz_2_0 ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ocaml + camlp4 + ]; + buildInputs = [ + lablgtk + libgnomecanvas + glib + graphviz_2_0 + ]; src = fetchurl { url = "http://oandrieu.nerim.net/monotone-viz/${pname}-${version}-nolablgtk.tar.gz"; sha256 = "1l5x4xqz5g1aaqbc1x80mg0yzkiah9ma9k9mivmn08alkjlakkdk"; }; - prePatch="ln -s . a; ln -s . b"; - patchFlags = ["-p0"]; + prePatch = "ln -s . a; ln -s . b"; + patchFlags = [ "-p0" ]; patches = [ (fetchpatch { url = "https://src.fedoraproject.org/rpms/monotone-viz/raw/c9f4c1bebe01bb471df05d8a37ca4b6d630574ec/f/monotone-viz-1.0.2-dot.patch"; @@ -48,8 +98,8 @@ stdenv.mkDerivation rec { meta = { description = "Monotone ancestry visualiser"; mainProgram = "monotone-viz"; - license = lib.licenses.gpl2Plus ; - maintainers = [lib.maintainers.raskin]; + license = lib.licenses.gpl2Plus; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/applications/version-management/monotone-viz/graphviz-2.0.nix b/pkgs/applications/version-management/monotone-viz/graphviz-2.0.nix index c2a2765b4be7e6..28e55d446ae167 100644 --- a/pkgs/applications/version-management/monotone-viz/graphviz-2.0.nix +++ b/pkgs/applications/version-management/monotone-viz/graphviz-2.0.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, libX11 -, libpng -, libjpeg -, expat -, libXaw -, bison -, libtool -, fontconfig -, pango -, gd -, libwebp +{ + lib, + stdenv, + fetchurl, + pkg-config, + libX11, + libpng, + libjpeg, + expat, + libXaw, + bison, + libtool, + fontconfig, + pango, + gd, + libwebp, }: stdenv.mkDerivation rec { @@ -39,20 +40,21 @@ stdenv.mkDerivation rec { libwebp ]; - hardeningDisable = [ "format" "fortify" ]; + hardeningDisable = [ + "format" + "fortify" + ]; - configureFlags = - [ - "--with-pngincludedir=${libpng.dev}/include" - "--with-pnglibdir=${libpng.out}/lib" - "--with-jpegincludedir=${libjpeg.dev}/include" - "--with-jpeglibdir=${libjpeg.out}/lib" - "--with-expatincludedir=${expat.dev}/include" - "--with-expatlibdir=${expat.out}/lib" - "--with-ltdl-include=${libtool}/include" - "--with-ltdl-lib=${libtool.lib}/lib" - ] - ++ lib.optional (libX11 == null) "--without-x"; + configureFlags = [ + "--with-pngincludedir=${libpng.dev}/include" + "--with-pnglibdir=${libpng.out}/lib" + "--with-jpegincludedir=${libjpeg.dev}/include" + "--with-jpeglibdir=${libjpeg.out}/lib" + "--with-expatincludedir=${expat.dev}/include" + "--with-expatlibdir=${expat.out}/lib" + "--with-ltdl-include=${libtool}/include" + "--with-ltdl-lib=${libtool.lib}/lib" + ] ++ lib.optional (libX11 == null) "--without-x"; meta = { description = "Program for visualising graphs"; diff --git a/pkgs/applications/version-management/monotone/default.nix b/pkgs/applications/version-management/monotone/default.nix index e50395ebfd9903..216175b8ee8892 100644 --- a/pkgs/applications/version-management/monotone/default.nix +++ b/pkgs/applications/version-management/monotone/default.nix @@ -1,8 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, boost, zlib, botan2, libidn -, lua, pcre, sqlite, perl, pkg-config, expect, less -, bzip2, gmp, openssl -, autoreconfHook, texinfo -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + boost, + zlib, + botan2, + libidn, + lua, + pcre, + sqlite, + perl, + pkg-config, + expect, + less, + bzip2, + gmp, + openssl, + autoreconfHook, + texinfo, + fetchpatch, }: let @@ -43,20 +59,38 @@ stdenv.mkDerivation rec { ./monotone-1.1-gcc-14.patch ]; - postPatch = '' - sed -e 's@/usr/bin/less@${less}/bin/less@' -i src/unix/terminal.cc - '' + lib.optionalString (lib.versionAtLeast boost.version "1.73") '' - find . -type f -exec sed -i \ - -e 's/ E(/ internal_E(/g' \ - -e 's/{E(/{internal_E(/g' \ - {} + - ''; + postPatch = + '' + sed -e 's@/usr/bin/less@${less}/bin/less@' -i src/unix/terminal.cc + '' + + lib.optionalString (lib.versionAtLeast boost.version "1.73") '' + find . -type f -exec sed -i \ + -e 's/ E(/ internal_E(/g' \ + -e 's/{E(/{internal_E(/g' \ + {} + + ''; - CXXFLAGS=" --std=c++11 "; + CXXFLAGS = " --std=c++11 "; - nativeBuildInputs = [ pkg-config autoreconfHook texinfo ]; - buildInputs = [ boost zlib botan2 libidn lua pcre sqlite expect - openssl gmp bzip2 perl ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + texinfo + ]; + buildInputs = [ + boost + zlib + botan2 + libidn + lua + pcre + sqlite + expect + openssl + gmp + bzip2 + perl + ]; postInstall = '' mkdir -p $out/share/${pname}-${version} diff --git a/pkgs/applications/version-management/nbstripout/default.nix b/pkgs/applications/version-management/nbstripout/default.nix index 854c66a6d5e414..07edd423c42b77 100644 --- a/pkgs/applications/version-management/nbstripout/default.nix +++ b/pkgs/applications/version-management/nbstripout/default.nix @@ -1,9 +1,10 @@ -{ lib -, python3 -, fetchPypi -, coreutils -, git -, mercurial +{ + lib, + python3, + fetchPypi, + coreutils, + git, + mercurial, }: python3.pkgs.buildPythonApplication rec { @@ -26,14 +27,16 @@ python3.pkgs.buildPythonApplication rec { nbformat ]; - nativeCheckInputs = [ - coreutils - git - mercurial - ] ++ (with python3.pkgs; [ - pytest-cram - pytestCheckHook - ]); + nativeCheckInputs = + [ + coreutils + git + mercurial + ] + ++ (with python3.pkgs; [ + pytest-cram + pytestCheckHook + ]); preCheck = '' export HOME=$(mktemp -d) diff --git a/pkgs/applications/version-management/nitpick/default.nix b/pkgs/applications/version-management/nitpick/default.nix index f1f52baf03366d..06725dae688499 100644 --- a/pkgs/applications/version-management/nitpick/default.nix +++ b/pkgs/applications/version-management/nitpick/default.nix @@ -1,7 +1,8 @@ -{ fetchFromGitHub -, buildPythonPackage -, lib -, isPy27 +{ + fetchFromGitHub, + buildPythonPackage, + lib, + isPy27, }: buildPythonPackage rec { diff --git a/pkgs/applications/version-management/p4/default.nix b/pkgs/applications/version-management/p4/default.nix index 94bbd7cb0df9a6..9bca47e6089254 100644 --- a/pkgs/applications/version-management/p4/default.nix +++ b/pkgs/applications/version-management/p4/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, fetchurl -, fetchzip -, lib -, emptyDirectory -, linkFarm -, jam -, openssl -, CoreServices -, Foundation -, Security -, testers +{ + stdenv, + fetchurl, + fetchzip, + lib, + emptyDirectory, + linkFarm, + jam, + openssl, + CoreServices, + Foundation, + Security, + testers, }: let @@ -28,7 +29,10 @@ let # We only want to keep the contrib directory as the other files conflict # with p4's own zlib files. (For the same reason, we can't use the # cone-based Git sparse checkout, either.) - { name = "contrib"; path = "${src}/contrib"; } + { + name = "contrib"; + path = "${src}/contrib"; + } ]; in stdenv.mkDerivation (finalAttrs: rec { @@ -43,9 +47,17 @@ stdenv.mkDerivation (finalAttrs: rec { nativeBuildInputs = [ jam ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices Foundation Security ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + Foundation + Security + ]; - outputs = [ "out" "bin" "dev" ]; + outputs = [ + "out" + "bin" + "dev" + ]; hardeningDisable = lib.optionals stdenv.hostPlatform.isDarwin [ "strictoverflow" ]; @@ -57,8 +69,14 @@ stdenv.mkDerivation (finalAttrs: rec { "-sSSLINCDIR=${lib.getDev opensslStatic}/include" "-sSSLLIBDIR=${lib.getLib opensslStatic}/lib" ] - ++ lib.optionals stdenv.cc.isClang [ "-sOSCOMP=clang" "-sCLANGVER=${stdenv.cc.cc.version}" ] - ++ lib.optionals stdenv.cc.isGNU [ "-sOSCOMP=gcc" "-sGCCVER=${stdenv.cc.cc.version}" ] + ++ lib.optionals stdenv.cc.isClang [ + "-sOSCOMP=clang" + "-sCLANGVER=${stdenv.cc.cc.version}" + ] + ++ lib.optionals stdenv.cc.isGNU [ + "-sOSCOMP=gcc" + "-sGCCVER=${stdenv.cc.cc.version}" + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ "-sOSVER=26" ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ "-sOSVER=1013" @@ -76,9 +94,15 @@ stdenv.mkDerivation (finalAttrs: rec { # See the "Header dependency changes" section of # https://www.gnu.org/software/gcc/gcc-11/porting_to.html for more # information on why we need to include these. - ++ lib.optionals - (stdenv.cc.isClang || (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.cc.version "11.0.0")) - [ "-include" "limits" "-include" "thread" ]; + ++ + lib.optionals + (stdenv.cc.isClang || (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.cc.version "11.0.0")) + [ + "-include" + "limits" + "-include" + "thread" + ]; preBuild = lib.optionalString stdenv.hostPlatform.isDarwin '' export MACOSX_SDK=$SDKROOT @@ -111,6 +135,9 @@ stdenv.mkDerivation (finalAttrs: rec { license = licenses.bsd2; mainProgram = "p4"; platforms = platforms.unix; - maintainers = with maintainers; [ corngood impl ]; + maintainers = with maintainers; [ + corngood + impl + ]; }; }) diff --git a/pkgs/applications/version-management/p4v/darwin.nix b/pkgs/applications/version-management/p4v/darwin.nix index d3d3568b9f2e29..fed85c3bc31941 100644 --- a/pkgs/applications/version-management/p4v/darwin.nix +++ b/pkgs/applications/version-management/p4v/darwin.nix @@ -1,8 +1,18 @@ { stdenv, undmg }: -{ pname, version, src, meta }: +{ + pname, + version, + src, + meta, +}: stdenv.mkDerivation { - inherit pname version src meta; + inherit + pname + version + src + meta + ; nativeBuildInputs = [ undmg ]; diff --git a/pkgs/applications/version-management/p4v/default.nix b/pkgs/applications/version-management/p4v/default.nix index 82aa6b57a8c516..5466a29ecb0a86 100644 --- a/pkgs/applications/version-management/p4v/default.nix +++ b/pkgs/applications/version-management/p4v/default.nix @@ -1,8 +1,9 @@ -{ stdenv -, fetchurl -, lib -, callPackage -, qt6Packages +{ + stdenv, + fetchurl, + lib, + callPackage, + qt6Packages, }: let @@ -21,13 +22,17 @@ let }; mkDerivation = - if stdenv.hostPlatform.isDarwin then callPackage ./darwin.nix { } - else qt6Packages.callPackage ./linux.nix { }; -in mkDerivation { + if stdenv.hostPlatform.isDarwin then + callPackage ./darwin.nix { } + else + qt6Packages.callPackage ./linux.nix { }; +in +mkDerivation { pname = "p4v"; version = "2024.2/2606884"; - src = srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); meta = { description = "Perforce Helix Visual Client"; @@ -35,6 +40,10 @@ in mkDerivation { sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; license = lib.licenses.unfreeRedistributable; platforms = builtins.attrNames srcs; - maintainers = with lib.maintainers; [ impl nathyong nioncode ]; + maintainers = with lib.maintainers; [ + impl + nathyong + nioncode + ]; }; } diff --git a/pkgs/applications/version-management/p4v/linux.nix b/pkgs/applications/version-management/p4v/linux.nix index 316ff8dbeb1990..f2af8b4056002b 100644 --- a/pkgs/applications/version-management/p4v/linux.nix +++ b/pkgs/applications/version-management/p4v/linux.nix @@ -1,35 +1,41 @@ -{ stdenv -, autoPatchelfHook -, cups -, dbus -, fontconfig -, gccForLibs -, libX11 -, libXcomposite -, libXcursor -, libXdamage -, libXext -, libXi -, libXrandr -, libXrender -, libXtst -, libinput -, libxcb -, libxkbcommon -, nss -, qtbase -, qtmultimedia -, qtsvg -, qttools -, qtwebengine -, qtwebview -, xcbutilimage -, xcbutilkeysyms -, xcbutilrenderutil -, xcbutilwm +{ + stdenv, + autoPatchelfHook, + cups, + dbus, + fontconfig, + gccForLibs, + libX11, + libXcomposite, + libXcursor, + libXdamage, + libXext, + libXi, + libXrandr, + libXrender, + libXtst, + libinput, + libxcb, + libxkbcommon, + nss, + qtbase, + qtmultimedia, + qtsvg, + qttools, + qtwebengine, + qtwebview, + xcbutilimage, + xcbutilkeysyms, + xcbutilrenderutil, + xcbutilwm, }: -{ pname, version, src, meta }: +{ + pname, + version, + src, + meta, +}: let unwrapped = stdenv.mkDerivation { pname = "${pname}-unwrapped"; diff --git a/pkgs/applications/version-management/pass-git-helper/default.nix b/pkgs/applications/version-management/pass-git-helper/default.nix index 590d25428a80d8..8f96bc2b58b85a 100644 --- a/pkgs/applications/version-management/pass-git-helper/default.nix +++ b/pkgs/applications/version-management/pass-git-helper/default.nix @@ -1,13 +1,22 @@ -{ lib, buildPythonApplication, fetchFromGitHub, pyxdg, pytestCheckHook, pytest-cov-stub, pytest-mock, setuptools }: +{ + lib, + buildPythonApplication, + fetchFromGitHub, + pyxdg, + pytestCheckHook, + pytest-cov-stub, + pytest-mock, + setuptools, +}: buildPythonApplication rec { - pname = "pass-git-helper"; + pname = "pass-git-helper"; version = "3.0.0"; pyproject = true; src = fetchFromGitHub { - owner = "languitar"; - repo = "pass-git-helper"; + owner = "languitar"; + repo = "pass-git-helper"; rev = "refs/tags/v${version}"; sha256 = "sha256-DLH3l4wYfBlrc49swLgyHeZXebJ5JSzU7cHjD7Hmw0g="; }; @@ -30,7 +39,10 @@ buildPythonApplication rec { homepage = "https://github.com/languitar/pass-git-helper"; description = "Git credential helper interfacing with pass, the standard unix password manager"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ hmenke vanzef ]; + maintainers = with maintainers; [ + hmenke + vanzef + ]; mainProgram = "pass-git-helper"; }; } diff --git a/pkgs/applications/version-management/qgit/default.nix b/pkgs/applications/version-management/qgit/default.nix index a0038554d86ceb..db3237991893f5 100644 --- a/pkgs/applications/version-management/qgit/default.nix +++ b/pkgs/applications/version-management/qgit/default.nix @@ -1,4 +1,10 @@ -{ mkDerivation, lib, fetchFromGitHub, cmake, qtbase }: +{ + mkDerivation, + lib, + fetchFromGitHub, + cmake, + qtbase, +}: mkDerivation rec { pname = "qgit"; @@ -19,7 +25,10 @@ mkDerivation rec { license = licenses.gpl2Only; homepage = "https://github.com/tibirna/qgit"; description = "Graphical front-end to Git"; - maintainers = with maintainers; [ peterhoeg markuskowa ]; + maintainers = with maintainers; [ + peterhoeg + markuskowa + ]; inherit (qtbase.meta) platforms; mainProgram = "qgit"; }; diff --git a/pkgs/applications/version-management/sapling/default.nix b/pkgs/applications/version-management/sapling/default.nix index e19fbeb4977f80..535abf7926798c 100644 --- a/pkgs/applications/version-management/sapling/default.nix +++ b/pkgs/applications/version-management/sapling/default.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, python311Packages -, fetchFromGitHub -, fetchurl -, cargo -, curl -, pkg-config -, openssl -, rustPlatform -, rustc -, fetchYarnDeps -, yarn -, nodejs -, fixup-yarn-lock -, glibcLocales -, libiconv -, Cocoa -, CoreFoundation -, CoreGraphics -, CoreServices -, Security -, WebKit - -, enableMinimal ? false +{ + lib, + stdenv, + python311Packages, + fetchFromGitHub, + fetchurl, + cargo, + curl, + pkg-config, + openssl, + rustPlatform, + rustc, + fetchYarnDeps, + yarn, + nodejs, + fixup-yarn-lock, + glibcLocales, + libiconv, + Cocoa, + CoreFoundation, + CoreGraphics, + CoreServices, + Security, + WebKit, + + enableMinimal ? false, }: let @@ -118,22 +119,26 @@ python311Packages.buildPythonApplication { "serde_bser-0.4.0" = "sha256-Su1IP3NzQu/87p/+uQaG8JcICL9hit3OV1O9oFiACsQ="; }; }; - postPatch = '' - cp ${./Cargo.lock} Cargo.lock - '' + lib.optionalString (!enableMinimal) '' - # If asked, we optionally patch in a hardcoded path to the - # 'nodejs' package, so that 'sl web' always works. Without the - # patch, 'sl web' will still work if 'nodejs' is in $PATH. - substituteInPlace lib/config/loader/src/builtin_static/core.rs \ - --replace '"#);' $'[web]\nnode-path=${nodejs}/bin/node\n"#);' - ''; + postPatch = + '' + cp ${./Cargo.lock} Cargo.lock + '' + + lib.optionalString (!enableMinimal) '' + # If asked, we optionally patch in a hardcoded path to the + # 'nodejs' package, so that 'sl web' always works. Without the + # patch, 'sl web' will still work if 'nodejs' is in $PATH. + substituteInPlace lib/config/loader/src/builtin_static/core.rs \ + --replace '"#);' $'[web]\nnode-path=${nodejs}/bin/node\n"#);' + ''; # Since the derivation builder doesn't have network access to remain pure, # fetch the artifacts manually and link them. Then replace the hardcoded URLs # with filesystem paths for the curl calls. postUnpack = '' mkdir $sourceRoot/hack_pydeps - ${lib.concatStrings (map (li: "ln -s ${fetchurl li} $sourceRoot/hack_pydeps/${baseNameOf li.url}\n") links)} + ${lib.concatStrings ( + map (li: "ln -s ${fetchurl li} $sourceRoot/hack_pydeps/${baseNameOf li.url}\n") links + )} sed -i "s|https://files.pythonhosted.org/packages/[[:alnum:]]*/[[:alnum:]]*/[[:alnum:]]*/|file://$NIX_BUILD_TOP/$sourceRoot/hack_pydeps/|g" $sourceRoot/setup.py ''; @@ -154,18 +159,20 @@ python311Packages.buildPythonApplication { rustc ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - curl - libiconv - Cocoa - CoreFoundation - CoreGraphics - CoreServices - Security - WebKit - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + curl + libiconv + Cocoa + CoreFoundation + CoreGraphics + CoreServices + Security + WebKit + ]; HGNAME = "sl"; SAPLING_OSS_BUILD = "true"; @@ -193,7 +200,10 @@ python311Packages.buildPythonApplication { description = "Scalable, User-Friendly Source Control System"; homepage = "https://sapling-scm.com"; license = licenses.gpl2Only; - maintainers = with maintainers; [ pbar thoughtpolice ]; + maintainers = with maintainers; [ + pbar + thoughtpolice + ]; platforms = platforms.unix; mainProgram = "sl"; }; diff --git a/pkgs/applications/version-management/silver-platter/default.nix b/pkgs/applications/version-management/silver-platter/default.nix index 368cf8dcf218b5..cf449383a9ac84 100644 --- a/pkgs/applications/version-management/silver-platter/default.nix +++ b/pkgs/applications/version-management/silver-platter/default.nix @@ -1,20 +1,21 @@ -{ buildPythonApplication -, lib -, stdenv -, fetchFromGitHub -, pkg-config -, setuptools -, setuptools-rust -, rustPlatform -, cargo -, rustc -, breezy -, dulwich -, jinja2 -, libiconv -, openssl -, pyyaml -, ruamel-yaml +{ + buildPythonApplication, + lib, + stdenv, + fetchFromGitHub, + pkg-config, + setuptools, + setuptools-rust, + rustPlatform, + cargo, + rustc, + breezy, + dulwich, + jinja2, + libiconv, + openssl, + pyyaml, + ruamel-yaml, }: buildPythonApplication rec { @@ -35,10 +36,22 @@ buildPythonApplication rec { hash = "sha256-+EUj6iBnHF4zlOAAfaHy5V/z6CCD/LFksBClE4FaHHc="; }; - propagatedBuildInputs = [ setuptools breezy dulwich jinja2 pyyaml ruamel-yaml ]; - nativeBuildInputs = [ setuptools-rust rustPlatform.cargoSetupHook cargo rustc ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ openssl ] + propagatedBuildInputs = [ + setuptools + breezy + dulwich + jinja2 + pyyaml + ruamel-yaml + ]; + nativeBuildInputs = [ + setuptools-rust + rustPlatform.cargoSetupHook + cargo + rustc + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; pythonImportsCheck = [ "silver_platter" ]; diff --git a/pkgs/applications/version-management/sourcehut/builds.nix b/pkgs/applications/version-management/sourcehut/builds.nix index 72d69678fb75cc..e4ef91162b11f7 100644 --- a/pkgs/applications/version-management/sourcehut/builds.nix +++ b/pkgs/applications/version-management/sourcehut/builds.nix @@ -1,23 +1,27 @@ -{ lib -, fetchFromSourcehut -, buildGoModule -, buildPythonPackage -, srht -, redis -, celery -, pyyaml -, markdown -, ansi2html -, lxml -, python -, unzip -, pip -, pythonOlder -, setuptools +{ + lib, + fetchFromSourcehut, + buildGoModule, + buildPythonPackage, + srht, + redis, + celery, + pyyaml, + markdown, + ansi2html, + lxml, + python, + unzip, + pip, + pythonOlder, + setuptools, }: let version = "0.89.15"; - gqlgen = import ./fix-gqlgen-trimpath.nix { inherit unzip; gqlgenVersion = "0.17.39"; }; + gqlgen = import ./fix-gqlgen-trimpath.nix { + inherit unzip; + gqlgenVersion = "0.17.39"; + }; src = fetchFromSourcehut { owner = "~sircmpwn"; @@ -26,19 +30,25 @@ let hash = "sha256-rmNaBnTPDDQO/ImkGkMwW8fyjQyBUBchTEnbtAK24pw="; }; - buildsrht-api = buildGoModule ({ - inherit src version; - pname = "buildsrht-api"; - modRoot = "api"; - vendorHash = "sha256-dwpuB+aYqzhGSdGVq/F9FTdHWMBkGMtVuZ7I3hB3b+Q="; - } // gqlgen); + buildsrht-api = buildGoModule ( + { + inherit src version; + pname = "buildsrht-api"; + modRoot = "api"; + vendorHash = "sha256-dwpuB+aYqzhGSdGVq/F9FTdHWMBkGMtVuZ7I3hB3b+Q="; + } + // gqlgen + ); - buildsrht-worker = buildGoModule ({ - inherit src version; - pname = "buildsrht-worker"; - modRoot = "worker"; - vendorHash = "sha256-dwpuB+aYqzhGSdGVq/F9FTdHWMBkGMtVuZ7I3hB3b+Q="; - } // gqlgen); + buildsrht-worker = buildGoModule ( + { + inherit src version; + pname = "buildsrht-worker"; + modRoot = "worker"; + vendorHash = "sha256-dwpuB+aYqzhGSdGVq/F9FTdHWMBkGMtVuZ7I3hB3b+Q="; + } + // gqlgen + ); in buildPythonPackage rec { inherit src version; @@ -89,6 +99,9 @@ buildPythonPackage rec { homepage = "https://git.sr.ht/~sircmpwn/builds.sr.ht"; description = "Continuous integration service for the sr.ht network"; license = licenses.agpl3Only; - maintainers = with maintainers; [ eadwu christoph-heiss ]; + maintainers = with maintainers; [ + eadwu + christoph-heiss + ]; }; } diff --git a/pkgs/applications/version-management/sourcehut/core.nix b/pkgs/applications/version-management/sourcehut/core.nix index c0180cf805fac6..5fa4c086482bad 100644 --- a/pkgs/applications/version-management/sourcehut/core.nix +++ b/pkgs/applications/version-management/sourcehut/core.nix @@ -1,29 +1,30 @@ -{ lib -, fetchFromSourcehut -, buildPythonPackage -, flask -, humanize -, sqlalchemy -, sqlalchemy-utils -, psycopg2 -, markdown -, mistletoe -, bleach -, requests -, beautifulsoup4 -, pygments -, cryptography -, prometheus-client -, alembic -, redis -, celery -, html5lib -, importlib-metadata -, tinycss2 -, sassc -, pythonOlder -, minify -, setuptools +{ + lib, + fetchFromSourcehut, + buildPythonPackage, + flask, + humanize, + sqlalchemy, + sqlalchemy-utils, + psycopg2, + markdown, + mistletoe, + bleach, + requests, + beautifulsoup4, + pygments, + cryptography, + prometheus-client, + alembic, + redis, + celery, + html5lib, + importlib-metadata, + tinycss2, + sassc, + pythonOlder, + minify, + setuptools, }: buildPythonPackage rec { @@ -89,6 +90,9 @@ buildPythonPackage rec { homepage = "https://git.sr.ht/~sircmpwn/srht"; description = "Core modules for sr.ht"; license = licenses.bsd3; - maintainers = with maintainers; [ eadwu christoph-heiss ]; + maintainers = with maintainers; [ + eadwu + christoph-heiss + ]; }; } diff --git a/pkgs/applications/version-management/sourcehut/default.nix b/pkgs/applications/version-management/sourcehut/default.nix index 147257dc3d5d04..b886e2093b3336 100644 --- a/pkgs/applications/version-management/sourcehut/default.nix +++ b/pkgs/applications/version-management/sourcehut/default.nix @@ -1,11 +1,12 @@ -{ lib -, python3 -, callPackage -, recurseIntoAttrs -, nixosTests -, config -, fetchPypi -, fetchpatch +{ + lib, + python3, + callPackage, + recurseIntoAttrs, + nixosTests, + config, + fetchPypi, + fetchpatch, }: # To expose the *srht modules, they have to be a python module so we use `buildPythonModule` @@ -66,7 +67,7 @@ let hash = "sha256-VUslfHS763oNJUFgpPj/4YUkP1KlIDUGC3Ycpi2XfwM="; }; # Fixes a test failure with Pytest 8 - patches = (oldAttrs.patches or []) ++ [ + patches = (oldAttrs.patches or [ ]) ++ [ (fetchpatch { url = "https://github.com/pallets/werkzeug/commit/4e5bdca7f8227d10cae828f8064fb98190ace4aa.patch"; hash = "sha256-83doVvfdpymlAB0EbfrHmuoKE5B2LJbFq+AY2xGpnl4="; @@ -82,37 +83,43 @@ let inherit version; hash = "sha256-+vSNYIoXNfDQo8nL9TbWT5EytUfa57pFLE2Zp56Eo3A="; }; - nativeCheckInputs = (with super; [ - django - mongoengine - pytestCheckHook - ]) ++ (with self; [ - sqlalchemy - flask - flask-sqlalchemy - ]); + nativeCheckInputs = + (with super; [ + django + mongoengine + pytestCheckHook + ]) + ++ (with self; [ + sqlalchemy + flask + flask-sqlalchemy + ]); postPatch = ""; }); }; }; in -with python.pkgs; recurseIntoAttrs ({ - inherit python; - coresrht = toPythonApplication srht; - buildsrht = toPythonApplication buildsrht; - gitsrht = toPythonApplication gitsrht; - hgsrht = toPythonApplication hgsrht; - hubsrht = toPythonApplication hubsrht; - listssrht = toPythonApplication listssrht; - mansrht = toPythonApplication mansrht; - metasrht = toPythonApplication metasrht; - pagessrht = callPackage ./pages.nix { }; - pastesrht = toPythonApplication pastesrht; - todosrht = toPythonApplication todosrht; - passthru.tests = { - nixos-sourcehut = nixosTests.sourcehut; - }; -} // lib.optionalAttrs config.allowAliases { - # Added 2022-10-29 - dispatchsrht = throw "dispatch is deprecated. See https://sourcehut.org/blog/2022-08-01-dispatch-deprecation-plans/ for more information."; -}) +with python.pkgs; +recurseIntoAttrs ( + { + inherit python; + coresrht = toPythonApplication srht; + buildsrht = toPythonApplication buildsrht; + gitsrht = toPythonApplication gitsrht; + hgsrht = toPythonApplication hgsrht; + hubsrht = toPythonApplication hubsrht; + listssrht = toPythonApplication listssrht; + mansrht = toPythonApplication mansrht; + metasrht = toPythonApplication metasrht; + pagessrht = callPackage ./pages.nix { }; + pastesrht = toPythonApplication pastesrht; + todosrht = toPythonApplication todosrht; + passthru.tests = { + nixos-sourcehut = nixosTests.sourcehut; + }; + } + // lib.optionalAttrs config.allowAliases { + # Added 2022-10-29 + dispatchsrht = throw "dispatch is deprecated. See https://sourcehut.org/blog/2022-08-01-dispatch-deprecation-plans/ for more information."; + } +) diff --git a/pkgs/applications/version-management/sourcehut/fix-gqlgen-trimpath.nix b/pkgs/applications/version-management/sourcehut/fix-gqlgen-trimpath.nix index 42ec1589a643c8..562ce6e445d3ae 100644 --- a/pkgs/applications/version-management/sourcehut/fix-gqlgen-trimpath.nix +++ b/pkgs/applications/version-management/sourcehut/fix-gqlgen-trimpath.nix @@ -1,15 +1,18 @@ -{ unzip -, gqlgenVersion +{ + unzip, + gqlgenVersion, }: { - overrideModAttrs = (_: { - # No need to workaround -trimpath: it's not used in goModules, - # but do download `go generate`'s dependencies nonetheless. - preBuild = '' - if [ -d ./loaders ]; then go generate ./loaders; fi - if [ -d ./graph ]; then go generate ./graph; fi - ''; - }); + overrideModAttrs = ( + _: { + # No need to workaround -trimpath: it's not used in goModules, + # but do download `go generate`'s dependencies nonetheless. + preBuild = '' + if [ -d ./loaders ]; then go generate ./loaders; fi + if [ -d ./graph ]; then go generate ./graph; fi + ''; + } + ); # Workaround this error: # go: git.sr.ht/~emersion/go-emailthreads@v0.0.0-20220412093310-4fd792e343ba: module lookup disabled by GOPROXY=off diff --git a/pkgs/applications/version-management/sourcehut/git.nix b/pkgs/applications/version-management/sourcehut/git.nix index d7ffc0e2cf83d1..887dac1a707060 100644 --- a/pkgs/applications/version-management/sourcehut/git.nix +++ b/pkgs/applications/version-management/sourcehut/git.nix @@ -1,20 +1,24 @@ -{ lib -, fetchFromSourcehut -, buildGoModule -, buildPythonPackage -, python -, srht -, scmsrht -, pygit2 -, minio -, pythonOlder -, unzip -, pip -, setuptools +{ + lib, + fetchFromSourcehut, + buildGoModule, + buildPythonPackage, + python, + srht, + scmsrht, + pygit2, + minio, + pythonOlder, + unzip, + pip, + setuptools, }: let version = "0.85.9"; - gqlgen = import ./fix-gqlgen-trimpath.nix { inherit unzip; gqlgenVersion = "0.17.42"; }; + gqlgen = import ./fix-gqlgen-trimpath.nix { + inherit unzip; + gqlgenVersion = "0.17.42"; + }; src = fetchFromSourcehut { owner = "~sircmpwn"; @@ -23,60 +27,75 @@ let hash = "sha256-tmbBw6x3nqN9nRIR3xOXQ+L5EACXLQYLXQYK3lsOsAI="; }; - gitApi = buildGoModule ({ - inherit src version; - pname = "gitsrht-api"; - modRoot = "api"; - vendorHash = "sha256-4KwnUi6ILUagMDXzuBG9CRT2N8uyjvRM74TwJqIzicc="; - } // gqlgen); - - gitDispatch = buildGoModule ({ - inherit src version; - pname = "gitsrht-dispatch"; - modRoot = "gitsrht-dispatch"; - vendorHash = "sha256-4KwnUi6ILUagMDXzuBG9CRT2N8uyjvRM74TwJqIzicc="; - - postPatch = '' - substituteInPlace gitsrht-dispatch/main.go \ - --replace /var/log/gitsrht-dispatch /var/log/sourcehut/gitsrht-dispatch - ''; - } // gqlgen); - - gitKeys = buildGoModule ({ - inherit src version; - pname = "gitsrht-keys"; - modRoot = "gitsrht-keys"; - vendorHash = "sha256-4KwnUi6ILUagMDXzuBG9CRT2N8uyjvRM74TwJqIzicc="; - - postPatch = '' - substituteInPlace gitsrht-keys/main.go \ - --replace /var/log/gitsrht-keys /var/log/sourcehut/gitsrht-keys - ''; - } // gqlgen); - - gitShell = buildGoModule ({ - inherit src version; - pname = "gitsrht-shell"; - modRoot = "gitsrht-shell"; - vendorHash = "sha256-4KwnUi6ILUagMDXzuBG9CRT2N8uyjvRM74TwJqIzicc="; - - postPatch = '' - substituteInPlace gitsrht-shell/main.go \ - --replace /var/log/gitsrht-shell /var/log/sourcehut/gitsrht-shell - ''; - } // gqlgen); - - gitUpdateHook = buildGoModule ({ - inherit src version; - pname = "gitsrht-update-hook"; - modRoot = "gitsrht-update-hook"; - vendorHash = "sha256-4KwnUi6ILUagMDXzuBG9CRT2N8uyjvRM74TwJqIzicc="; - - postPatch = '' - substituteInPlace gitsrht-update-hook/main.go \ - --replace /var/log/gitsrht-update-hook /var/log/sourcehut/gitsrht-update-hook - ''; - } // gqlgen); + gitApi = buildGoModule ( + { + inherit src version; + pname = "gitsrht-api"; + modRoot = "api"; + vendorHash = "sha256-4KwnUi6ILUagMDXzuBG9CRT2N8uyjvRM74TwJqIzicc="; + } + // gqlgen + ); + + gitDispatch = buildGoModule ( + { + inherit src version; + pname = "gitsrht-dispatch"; + modRoot = "gitsrht-dispatch"; + vendorHash = "sha256-4KwnUi6ILUagMDXzuBG9CRT2N8uyjvRM74TwJqIzicc="; + + postPatch = '' + substituteInPlace gitsrht-dispatch/main.go \ + --replace /var/log/gitsrht-dispatch /var/log/sourcehut/gitsrht-dispatch + ''; + } + // gqlgen + ); + + gitKeys = buildGoModule ( + { + inherit src version; + pname = "gitsrht-keys"; + modRoot = "gitsrht-keys"; + vendorHash = "sha256-4KwnUi6ILUagMDXzuBG9CRT2N8uyjvRM74TwJqIzicc="; + + postPatch = '' + substituteInPlace gitsrht-keys/main.go \ + --replace /var/log/gitsrht-keys /var/log/sourcehut/gitsrht-keys + ''; + } + // gqlgen + ); + + gitShell = buildGoModule ( + { + inherit src version; + pname = "gitsrht-shell"; + modRoot = "gitsrht-shell"; + vendorHash = "sha256-4KwnUi6ILUagMDXzuBG9CRT2N8uyjvRM74TwJqIzicc="; + + postPatch = '' + substituteInPlace gitsrht-shell/main.go \ + --replace /var/log/gitsrht-shell /var/log/sourcehut/gitsrht-shell + ''; + } + // gqlgen + ); + + gitUpdateHook = buildGoModule ( + { + inherit src version; + pname = "gitsrht-update-hook"; + modRoot = "gitsrht-update-hook"; + vendorHash = "sha256-4KwnUi6ILUagMDXzuBG9CRT2N8uyjvRM74TwJqIzicc="; + + postPatch = '' + substituteInPlace gitsrht-update-hook/main.go \ + --replace /var/log/gitsrht-update-hook /var/log/sourcehut/gitsrht-update-hook + ''; + } + // gqlgen + ); in buildPythonPackage rec { inherit src version; @@ -122,6 +141,9 @@ buildPythonPackage rec { homepage = "https://git.sr.ht/~sircmpwn/git.sr.ht"; description = "Git repository hosting service for the sr.ht network"; license = licenses.agpl3Only; - maintainers = with maintainers; [ eadwu christoph-heiss ]; + maintainers = with maintainers; [ + eadwu + christoph-heiss + ]; }; } diff --git a/pkgs/applications/version-management/sourcehut/hg.nix b/pkgs/applications/version-management/sourcehut/hg.nix index 3e7e1f55c65a9b..23e99349d24d6e 100644 --- a/pkgs/applications/version-management/sourcehut/hg.nix +++ b/pkgs/applications/version-management/sourcehut/hg.nix @@ -1,21 +1,25 @@ -{ lib -, fetchFromSourcehut -, buildGoModule -, buildPythonPackage -, srht -, python-hglib -, scmsrht -, unidiff -, python -, unzip -, pip -, pythonOlder -, setuptools +{ + lib, + fetchFromSourcehut, + buildGoModule, + buildPythonPackage, + srht, + python-hglib, + scmsrht, + unidiff, + python, + unzip, + pip, + pythonOlder, + setuptools, }: let version = "0.33.0"; - gqlgen = import ./fix-gqlgen-trimpath.nix { inherit unzip; gqlgenVersion = "0.17.45"; }; + gqlgen = import ./fix-gqlgen-trimpath.nix { + inherit unzip; + gqlgenVersion = "0.17.45"; + }; pyproject = true; @@ -29,12 +33,15 @@ let vc = "hg"; }; - hgsrht-api = buildGoModule ({ - inherit src version; - pname = "hgsrht-api"; - modRoot = "api"; - vendorHash = "sha256-K+KMhcvkG/qeQTnlHS4xhLCcvBQNNp2DcScJPm8Dbic="; - } // gqlgen); + hgsrht-api = buildGoModule ( + { + inherit src version; + pname = "hgsrht-api"; + modRoot = "api"; + vendorHash = "sha256-K+KMhcvkG/qeQTnlHS4xhLCcvBQNNp2DcScJPm8Dbic="; + } + // gqlgen + ); hgsrht-keys = buildGoModule { inherit src version; @@ -88,6 +95,9 @@ buildPythonPackage rec { homepage = "https://git.sr.ht/~sircmpwn/hg.sr.ht"; description = "Mercurial repository hosting service for the sr.ht network"; license = licenses.agpl3Only; - maintainers = with maintainers; [ eadwu christoph-heiss ]; + maintainers = with maintainers; [ + eadwu + christoph-heiss + ]; }; } diff --git a/pkgs/applications/version-management/sourcehut/hub.nix b/pkgs/applications/version-management/sourcehut/hub.nix index 4a0d2cda893126..5a800275e4ca80 100644 --- a/pkgs/applications/version-management/sourcehut/hub.nix +++ b/pkgs/applications/version-management/sourcehut/hub.nix @@ -1,19 +1,23 @@ -{ lib -, fetchFromSourcehut -, buildGoModule -, buildPythonPackage -, python -, srht -, setuptools -, pip -, pyyaml -, pythonOlder -, unzip +{ + lib, + fetchFromSourcehut, + buildGoModule, + buildPythonPackage, + python, + srht, + setuptools, + pip, + pyyaml, + pythonOlder, + unzip, }: let version = "0.17.7"; - gqlgen = import ./fix-gqlgen-trimpath.nix { inherit unzip; gqlgenVersion = "0.17.43"; }; + gqlgen = import ./fix-gqlgen-trimpath.nix { + inherit unzip; + gqlgenVersion = "0.17.43"; + }; src = fetchFromSourcehut { owner = "~sircmpwn"; @@ -22,12 +26,15 @@ let hash = "sha256-IyY7Niy/vZSAXjYZMlxY6uuQ8nH/4yT4+MaRjHtl6G4="; }; - hubsrht-api = buildGoModule ({ - inherit src version; - pname = "hubsrht-api"; - modRoot = "api"; - vendorHash = "sha256-GVN11nEJqIHh8MtKvIXe4zcUwJph9eTSkJ2R+ufD+ic="; - } // gqlgen); + hubsrht-api = buildGoModule ( + { + inherit src version; + pname = "hubsrht-api"; + modRoot = "api"; + vendorHash = "sha256-GVN11nEJqIHh8MtKvIXe4zcUwJph9eTSkJ2R+ufD+ic="; + } + // gqlgen + ); in buildPythonPackage rec { inherit src version; @@ -59,7 +66,6 @@ buildPythonPackage rec { ln -s ${hubsrht-api}/bin/api $out/bin/hubsrht-api ''; - # Module has no tests doCheck = false; @@ -71,6 +77,9 @@ buildPythonPackage rec { homepage = "https://git.sr.ht/~sircmpwn/hub.sr.ht"; description = "Project hub service for the sr.ht network"; license = licenses.agpl3Only; - maintainers = with maintainers; [ eadwu christoph-heiss ]; + maintainers = with maintainers; [ + eadwu + christoph-heiss + ]; }; } diff --git a/pkgs/applications/version-management/sourcehut/lists.nix b/pkgs/applications/version-management/sourcehut/lists.nix index 77d499f695e467..8115410b8e3333 100644 --- a/pkgs/applications/version-management/sourcehut/lists.nix +++ b/pkgs/applications/version-management/sourcehut/lists.nix @@ -1,22 +1,26 @@ -{ lib -, fetchFromSourcehut -, buildGoModule -, buildPythonPackage -, srht -, aiosmtpd -, asyncpg -, pygit2 -, emailthreads -, python -, unzip -, pip -, pythonOlder -, setuptools +{ + lib, + fetchFromSourcehut, + buildGoModule, + buildPythonPackage, + srht, + aiosmtpd, + asyncpg, + pygit2, + emailthreads, + python, + unzip, + pip, + pythonOlder, + setuptools, }: let version = "0.57.18"; - gqlgen = import ./fix-gqlgen-trimpath.nix { inherit unzip; gqlgenVersion = "0.17.45"; }; + gqlgen = import ./fix-gqlgen-trimpath.nix { + inherit unzip; + gqlgenVersion = "0.17.45"; + }; src = fetchFromSourcehut { owner = "~sircmpwn"; @@ -25,12 +29,15 @@ let hash = "sha256-l+QPocnwHTjrU+M0wnm4tBrbz8KmSb6DovC+skuAnLc="; }; - listssrht-api = buildGoModule ({ - inherit src version; - pname = "listssrht-api"; - modRoot = "api"; - vendorHash = "sha256-UeVs/+uZNtv296bzXIBio2wcg3Uzu3fBM4APzF9O0hY="; - } // gqlgen); + listssrht-api = buildGoModule ( + { + inherit src version; + pname = "listssrht-api"; + modRoot = "api"; + vendorHash = "sha256-UeVs/+uZNtv296bzXIBio2wcg3Uzu3fBM4APzF9O0hY="; + } + // gqlgen + ); in buildPythonPackage rec { inherit src version; @@ -73,6 +80,9 @@ buildPythonPackage rec { homepage = "https://git.sr.ht/~sircmpwn/lists.sr.ht"; description = "Mailing list service for the sr.ht network"; license = licenses.agpl3Only; - maintainers = with maintainers; [ eadwu christoph-heiss ]; + maintainers = with maintainers; [ + eadwu + christoph-heiss + ]; }; } diff --git a/pkgs/applications/version-management/sourcehut/man.nix b/pkgs/applications/version-management/sourcehut/man.nix index f5cd6be139acdc..a9c2cc8a2c55ed 100644 --- a/pkgs/applications/version-management/sourcehut/man.nix +++ b/pkgs/applications/version-management/sourcehut/man.nix @@ -1,19 +1,23 @@ -{ lib -, fetchFromSourcehut -, buildGoModule -, buildPythonPackage -, srht -, pygit2 -, python -, unzip -, pip -, pythonOlder -, setuptools +{ + lib, + fetchFromSourcehut, + buildGoModule, + buildPythonPackage, + srht, + pygit2, + python, + unzip, + pip, + pythonOlder, + setuptools, }: let version = "0.16.5"; - gqlgen = import ./fix-gqlgen-trimpath.nix { inherit unzip; gqlgenVersion = "0.17.43"; }; + gqlgen = import ./fix-gqlgen-trimpath.nix { + inherit unzip; + gqlgenVersion = "0.17.43"; + }; src = fetchFromSourcehut { owner = "~sircmpwn"; @@ -22,12 +26,15 @@ let hash = "sha256-JFMtif2kIE/fs5PNcQtkJikAFNszgZTU7BG/8fTncTI="; }; - mansrht-api = buildGoModule ({ - inherit src version; - pname = "mansrht-api"; - modRoot = "api"; - vendorHash = "sha256-GVN11nEJqIHh8MtKvIXe4zcUwJph9eTSkJ2R+ufD+ic="; - } // gqlgen); + mansrht-api = buildGoModule ( + { + inherit src version; + pname = "mansrht-api"; + modRoot = "api"; + vendorHash = "sha256-GVN11nEJqIHh8MtKvIXe4zcUwJph9eTSkJ2R+ufD+ic="; + } + // gqlgen + ); in buildPythonPackage rec { inherit src version; @@ -65,6 +72,9 @@ buildPythonPackage rec { homepage = "https://git.sr.ht/~sircmpwn/man.sr.ht"; description = "Wiki service for the sr.ht network"; license = licenses.agpl3Only; - maintainers = with maintainers; [ eadwu christoph-heiss ]; + maintainers = with maintainers; [ + eadwu + christoph-heiss + ]; }; } diff --git a/pkgs/applications/version-management/sourcehut/meta.nix b/pkgs/applications/version-management/sourcehut/meta.nix index 8ae078bea5f1e4..ec1893968c1325 100644 --- a/pkgs/applications/version-management/sourcehut/meta.nix +++ b/pkgs/applications/version-management/sourcehut/meta.nix @@ -1,25 +1,29 @@ -{ lib -, fetchFromSourcehut -, buildPythonPackage -, buildGoModule -, alembic -, bcrypt -, dnspython -, qrcode -, redis -, srht -, stripe -, prometheus-client -, zxcvbn -, python -, unzip -, pip -, pythonOlder -, setuptools +{ + lib, + fetchFromSourcehut, + buildPythonPackage, + buildGoModule, + alembic, + bcrypt, + dnspython, + qrcode, + redis, + srht, + stripe, + prometheus-client, + zxcvbn, + python, + unzip, + pip, + pythonOlder, + setuptools, }: let version = "0.69.8"; - gqlgen = import ./fix-gqlgen-trimpath.nix { inherit unzip; gqlgenVersion = "0.17.43"; }; + gqlgen = import ./fix-gqlgen-trimpath.nix { + inherit unzip; + gqlgenVersion = "0.17.43"; + }; src = fetchFromSourcehut { owner = "~sircmpwn"; @@ -28,12 +32,15 @@ let hash = "sha256-K7p6cytkPYgUuYr7BVfU/+sVbSr2YEmreIDnTatUMyk="; }; - metasrht-api = buildGoModule ({ - inherit src version; - pname = "metasrht-api"; - modRoot = "api"; - vendorHash = "sha256-vIkUK1pigVU8vZL5xpHLeinOga5eXXHTuDkHxwUz6uM="; - } // gqlgen); + metasrht-api = buildGoModule ( + { + inherit src version; + pname = "metasrht-api"; + modRoot = "api"; + vendorHash = "sha256-vIkUK1pigVU8vZL5xpHLeinOga5eXXHTuDkHxwUz6uM="; + } + // gqlgen + ); in buildPythonPackage rec { pname = "metasrht"; @@ -80,6 +87,9 @@ buildPythonPackage rec { homepage = "https://git.sr.ht/~sircmpwn/meta.sr.ht"; description = "Account management service for the sr.ht network"; license = licenses.agpl3Only; - maintainers = with maintainers; [ eadwu christoph-heiss ]; + maintainers = with maintainers; [ + eadwu + christoph-heiss + ]; }; } diff --git a/pkgs/applications/version-management/sourcehut/pages.nix b/pkgs/applications/version-management/sourcehut/pages.nix index 5fc140548dc7ad..03c6ed31fee2fe 100644 --- a/pkgs/applications/version-management/sourcehut/pages.nix +++ b/pkgs/applications/version-management/sourcehut/pages.nix @@ -1,43 +1,53 @@ -{ lib -, fetchFromSourcehut -, buildGoModule -, unzip +{ + lib, + fetchFromSourcehut, + buildGoModule, + unzip, }: -buildGoModule (rec { - pname = "pagessrht"; - version = "0.15.7"; +buildGoModule ( + rec { + pname = "pagessrht"; + version = "0.15.7"; - src = fetchFromSourcehut { - owner = "~sircmpwn"; - repo = "pages.sr.ht"; - rev = version; - hash = "sha256-Lobuf12ybSO7Y4ztOLMFW0dmPFaBSEPCy4Nmh89tylI="; - }; + src = fetchFromSourcehut { + owner = "~sircmpwn"; + repo = "pages.sr.ht"; + rev = version; + hash = "sha256-Lobuf12ybSO7Y4ztOLMFW0dmPFaBSEPCy4Nmh89tylI="; + }; - postPatch = '' - substituteInPlace Makefile \ - --replace "all: server" "" + postPatch = '' + substituteInPlace Makefile \ + --replace "all: server" "" - # fix build failure due to unused import - substituteInPlace server.go \ - --replace-warn ' "fmt"' "" - ''; + # fix build failure due to unused import + substituteInPlace server.go \ + --replace-warn ' "fmt"' "" + ''; - vendorHash = "sha256-9hpOkP6AYSZe7MW1mrwFEKq7TvVt6OcF6eHWY4jARuU="; + vendorHash = "sha256-9hpOkP6AYSZe7MW1mrwFEKq7TvVt6OcF6eHWY4jARuU="; - postInstall = '' - mkdir -p $out/share/sql/ - cp -r -t $out/share/sql/ schema.sql migrations - ''; + postInstall = '' + mkdir -p $out/share/sql/ + cp -r -t $out/share/sql/ schema.sql migrations + ''; - meta = with lib; { - homepage = "https://git.sr.ht/~sircmpwn/pages.sr.ht"; - description = "Web hosting service for the sr.ht network"; - mainProgram = "pages.sr.ht"; - license = licenses.agpl3Only; - maintainers = with maintainers; [ eadwu christoph-heiss ]; - }; - # There is no ./loaders but this does not cause troubles - # to go generate -} // import ./fix-gqlgen-trimpath.nix { inherit unzip; gqlgenVersion = "0.17.42"; }) + meta = with lib; { + homepage = "https://git.sr.ht/~sircmpwn/pages.sr.ht"; + description = "Web hosting service for the sr.ht network"; + mainProgram = "pages.sr.ht"; + license = licenses.agpl3Only; + maintainers = with maintainers; [ + eadwu + christoph-heiss + ]; + }; + # There is no ./loaders but this does not cause troubles + # to go generate + } + // import ./fix-gqlgen-trimpath.nix { + inherit unzip; + gqlgenVersion = "0.17.42"; + } +) diff --git a/pkgs/applications/version-management/sourcehut/paste.nix b/pkgs/applications/version-management/sourcehut/paste.nix index b7e6624928966f..3e0800f6b0149c 100644 --- a/pkgs/applications/version-management/sourcehut/paste.nix +++ b/pkgs/applications/version-management/sourcehut/paste.nix @@ -1,19 +1,23 @@ -{ lib -, fetchFromSourcehut -, buildGoModule -, buildPythonPackage -, srht -, pip -, pyyaml -, python -, pythonOlder -, setuptools -, unzip +{ + lib, + fetchFromSourcehut, + buildGoModule, + buildPythonPackage, + srht, + pip, + pyyaml, + python, + pythonOlder, + setuptools, + unzip, }: let version = "0.15.4"; - gqlgen = import ./fix-gqlgen-trimpath.nix { inherit unzip; gqlgenVersion = "0.17.45"; }; + gqlgen = import ./fix-gqlgen-trimpath.nix { + inherit unzip; + gqlgenVersion = "0.17.45"; + }; src = fetchFromSourcehut { owner = "~sircmpwn"; @@ -22,12 +26,15 @@ let hash = "sha256-M38hAMRdMzcqxJv7j7foOIYEImr/ZYz/lbYOF9R9g2M="; }; - pastesrht-api = buildGoModule ({ - inherit src version; - pname = "pastesrht-api"; - modRoot = "api"; - vendorHash = "sha256-vt5nSPcx+Y/SaWcqjV38DTL3ZtzmdjbkJYMv5Fhhnq4="; - } // gqlgen); + pastesrht-api = buildGoModule ( + { + inherit src version; + pname = "pastesrht-api"; + modRoot = "api"; + vendorHash = "sha256-vt5nSPcx+Y/SaWcqjV38DTL3ZtzmdjbkJYMv5Fhhnq4="; + } + // gqlgen + ); in buildPythonPackage rec { inherit src version; @@ -67,6 +74,10 @@ buildPythonPackage rec { homepage = "https://git.sr.ht/~sircmpwn/paste.sr.ht"; description = "Ad-hoc text file hosting service for the sr.ht network"; license = licenses.agpl3Only; - maintainers = with maintainers; [ eadwu nessdoor christoph-heiss ]; + maintainers = with maintainers; [ + eadwu + nessdoor + christoph-heiss + ]; }; } diff --git a/pkgs/applications/version-management/sourcehut/scm.nix b/pkgs/applications/version-management/sourcehut/scm.nix index 33f9519fd922f3..ea7ba30aa656f9 100644 --- a/pkgs/applications/version-management/sourcehut/scm.nix +++ b/pkgs/applications/version-management/sourcehut/scm.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromSourcehut -, buildPythonPackage -, srht -, pyyaml -, buildsrht -, pythonOlder -, setuptools +{ + lib, + fetchFromSourcehut, + buildPythonPackage, + srht, + pyyaml, + buildsrht, + pythonOlder, + setuptools, }: buildPythonPackage rec { @@ -44,6 +45,9 @@ buildPythonPackage rec { homepage = "https://git.sr.ht/~sircmpwn/scm.sr.ht"; description = "Shared support code for sr.ht source control services"; license = licenses.agpl3Only; - maintainers = with maintainers; [ eadwu christoph-heiss ]; + maintainers = with maintainers; [ + eadwu + christoph-heiss + ]; }; } diff --git a/pkgs/applications/version-management/sourcehut/todo.nix b/pkgs/applications/version-management/sourcehut/todo.nix index 1f817272839111..e920333c31158d 100644 --- a/pkgs/applications/version-management/sourcehut/todo.nix +++ b/pkgs/applications/version-management/sourcehut/todo.nix @@ -1,20 +1,24 @@ -{ lib -, fetchFromSourcehut -, buildGoModule -, buildPythonPackage -, srht -, alembic -, pytest -, factory-boy -, python -, unzip -, pythonOlder -, setuptools +{ + lib, + fetchFromSourcehut, + buildGoModule, + buildPythonPackage, + srht, + alembic, + pytest, + factory-boy, + python, + unzip, + pythonOlder, + setuptools, }: let version = "0.75.10"; - gqlgen = import ./fix-gqlgen-trimpath.nix { inherit unzip; gqlgenVersion = "0.17.45"; }; + gqlgen = import ./fix-gqlgen-trimpath.nix { + inherit unzip; + gqlgenVersion = "0.17.45"; + }; src = fetchFromSourcehut { owner = "~sircmpwn"; @@ -23,12 +27,15 @@ let hash = "sha256-3dVZdupsygM7/6T1Mn7yRc776aa9pKgwF0hgZX6uVQ0="; }; - todosrht-api = buildGoModule ({ - inherit src version; - pname = "todosrht-api"; - modRoot = "api"; - vendorHash = "sha256-fImOQLnQLHTrg5ikuYRZ+u+78exAiYA19DGQoUjQBOM="; - } // gqlgen); + todosrht-api = buildGoModule ( + { + inherit src version; + pname = "todosrht-api"; + modRoot = "api"; + vendorHash = "sha256-fImOQLnQLHTrg5ikuYRZ+u+78exAiYA19DGQoUjQBOM="; + } + // gqlgen + ); in buildPythonPackage rec { inherit src version; @@ -73,6 +80,9 @@ buildPythonPackage rec { homepage = "https://todo.sr.ht/~sircmpwn/todo.sr.ht"; description = "Ticket tracking service for the sr.ht network"; license = licenses.agpl3Only; - maintainers = with maintainers; [ eadwu christoph-heiss ]; + maintainers = with maintainers; [ + eadwu + christoph-heiss + ]; }; } diff --git a/pkgs/applications/version-management/subversion/default.nix b/pkgs/applications/version-management/subversion/default.nix index 07e10ae8156425..afef38d8b8c1c2 100644 --- a/pkgs/applications/version-management/subversion/default.nix +++ b/pkgs/applications/version-management/subversion/default.nix @@ -1,15 +1,34 @@ -{ bdbSupport ? true # build support for Berkeley DB repositories -, httpServer ? false # build Apache DAV module -, httpSupport ? true # client must support http -, pythonBindings ? false -, perlBindings ? false -, javahlBindings ? false -, saslSupport ? false -, lib, stdenv, fetchurl, apr, aprutil, zlib, sqlite, openssl, lz4, utf8proc -, CoreServices, Security -, autoconf, libtool -, apacheHttpd ? null, expat, swig ? null, jdk ? null, python3 ? null, py3c ? null, perl ? null -, sasl ? null, serf ? null +{ + bdbSupport ? true, # build support for Berkeley DB repositories + httpServer ? false, # build Apache DAV module + httpSupport ? true, # client must support http + pythonBindings ? false, + perlBindings ? false, + javahlBindings ? false, + saslSupport ? false, + lib, + stdenv, + fetchurl, + apr, + aprutil, + zlib, + sqlite, + openssl, + lz4, + utf8proc, + CoreServices, + Security, + autoconf, + libtool, + apacheHttpd ? null, + expat, + swig ? null, + jdk ? null, + python3 ? null, + py3c ? null, + perl ? null, + sasl ? null, + serf ? null, }: assert bdbSupport -> aprutil.bdbSupport; @@ -19,122 +38,158 @@ assert javahlBindings -> jdk != null && perl != null; let # Update libtool for macOS 11 support - needsAutogen = stdenv.hostPlatform.isDarwin && lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11"; - - common = { version, sha256, extraPatches ? [ ] }: stdenv.mkDerivation (rec { - inherit version; - pname = "subversion${lib.optionalString (!bdbSupport && perlBindings && pythonBindings) "-client"}"; - - src = fetchurl { - url = "mirror://apache/subversion/subversion-${version}.tar.bz2"; - inherit sha256; - }; - - # Can't do separate $lib and $bin, as libs reference bins - outputs = [ "out" "dev" "man" ]; - - nativeBuildInputs = lib.optionals needsAutogen [ autoconf libtool python3 ]; - - buildInputs = [ zlib apr aprutil sqlite openssl lz4 utf8proc ] - ++ lib.optional httpSupport serf - ++ lib.optionals pythonBindings [ python3 py3c ] - ++ lib.optional perlBindings perl - ++ lib.optional saslSupport sasl - ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices Security ]; - - patches = [ ./apr-1.patch ] ++ extraPatches; - - # We are hitting the following issue even with APR 1.6.x - # -> https://issues.apache.org/jira/browse/SVN-4813 - # "-P" CPPFLAG is needed to build Python bindings and subversionClient - CPPFLAGS = [ "-P" ]; - - env = lib.optionalAttrs stdenv.cc.isClang { - NIX_CFLAGS_COMPILE = lib.concatStringsSep " " [ - "-Wno-error=implicit-function-declaration" - "-Wno-error=implicit-int" - "-Wno-int-conversion" - ]; - }; - - preConfigure = lib.optionalString needsAutogen '' - ./autogen.sh - ''; - - configureFlags = [ - (lib.withFeature bdbSupport "berkeley-db") - (lib.withFeatureAs httpServer "apxs" "${apacheHttpd.dev}/bin/apxs") - (lib.withFeatureAs (pythonBindings || perlBindings) "swig" swig) - (lib.withFeatureAs saslSupport "sasl" sasl) - (lib.withFeatureAs httpSupport "serf" serf) - "--with-zlib=${zlib.dev}" - "--with-sqlite=${sqlite.dev}" - "--with-apr=${apr.dev}" - "--with-apr-util=${aprutil.dev}" - ] ++ lib.optionals javahlBindings [ - "--enable-javahl" - "--with-jdk=${jdk}" - ]; - - preBuild = '' - makeFlagsArray=(APACHE_LIBEXECDIR=$out/modules) - ''; - - postInstall = '' - if test -n "$pythonBindings"; then - make swig-py swig_pydir=$(toPythonPath $out)/libsvn swig_pydir_extra=$(toPythonPath $out)/svn - make install-swig-py swig_pydir=$(toPythonPath $out)/libsvn swig_pydir_extra=$(toPythonPath $out)/svn - fi - - if test -n "$perlBindings"; then - make swig-pl-lib - make install-swig-pl-lib - cd subversion/bindings/swig/perl/native - perl Makefile.PL PREFIX=$out - make install - cd - - fi - - mkdir -p $out/share/bash-completion/completions - cp tools/client-side/bash_completion $out/share/bash-completion/completions/subversion - - for f in $out/lib/*.la $out/lib/python*/site-packages/*/*.la; do - substituteInPlace $f \ - --replace "${expat.dev}/lib" "${expat.out}/lib" \ - --replace "${zlib.dev}/lib" "${zlib.out}/lib" \ - --replace "${sqlite.dev}/lib" "${sqlite.out}/lib" \ - --replace "${openssl.dev}/lib" "${lib.getLib openssl}/lib" - done - ''; - - inherit perlBindings pythonBindings; - - enableParallelBuilding = true; - # Missing install dependencies: - # libtool: error: error: relink 'libsvn_ra_serf-1.la' with the above command before installing it - # make: *** [build-outputs.mk:1316: install-serf-lib] Error 1 - enableParallelInstalling = false; - - nativeCheckInputs = [ python3 ]; - doCheck = false; # fails 10 out of ~2300 tests - - meta = with lib; { - description = "Version control system intended to be a compelling replacement for CVS in the open source community"; - license = licenses.asl20; - homepage = "https://subversion.apache.org/"; - mainProgram = "svn"; - maintainers = with maintainers; [ lovek323 ]; - platforms = platforms.linux ++ platforms.darwin; - }; - - } // lib.optionalAttrs stdenv.hostPlatform.isDarwin { - CXX = "clang++"; - CC = "clang"; - CPP = "clang -E"; - CXXCPP = "clang++ -E"; - }); - -in { + needsAutogen = + stdenv.hostPlatform.isDarwin && lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11"; + + common = + { + version, + sha256, + extraPatches ? [ ], + }: + stdenv.mkDerivation ( + rec { + inherit version; + pname = "subversion${lib.optionalString (!bdbSupport && perlBindings && pythonBindings) "-client"}"; + + src = fetchurl { + url = "mirror://apache/subversion/subversion-${version}.tar.bz2"; + inherit sha256; + }; + + # Can't do separate $lib and $bin, as libs reference bins + outputs = [ + "out" + "dev" + "man" + ]; + + nativeBuildInputs = lib.optionals needsAutogen [ + autoconf + libtool + python3 + ]; + + buildInputs = + [ + zlib + apr + aprutil + sqlite + openssl + lz4 + utf8proc + ] + ++ lib.optional httpSupport serf + ++ lib.optionals pythonBindings [ + python3 + py3c + ] + ++ lib.optional perlBindings perl + ++ lib.optional saslSupport sasl + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + Security + ]; + + patches = [ ./apr-1.patch ] ++ extraPatches; + + # We are hitting the following issue even with APR 1.6.x + # -> https://issues.apache.org/jira/browse/SVN-4813 + # "-P" CPPFLAG is needed to build Python bindings and subversionClient + CPPFLAGS = [ "-P" ]; + + env = lib.optionalAttrs stdenv.cc.isClang { + NIX_CFLAGS_COMPILE = lib.concatStringsSep " " [ + "-Wno-error=implicit-function-declaration" + "-Wno-error=implicit-int" + "-Wno-int-conversion" + ]; + }; + + preConfigure = lib.optionalString needsAutogen '' + ./autogen.sh + ''; + + configureFlags = + [ + (lib.withFeature bdbSupport "berkeley-db") + (lib.withFeatureAs httpServer "apxs" "${apacheHttpd.dev}/bin/apxs") + (lib.withFeatureAs (pythonBindings || perlBindings) "swig" swig) + (lib.withFeatureAs saslSupport "sasl" sasl) + (lib.withFeatureAs httpSupport "serf" serf) + "--with-zlib=${zlib.dev}" + "--with-sqlite=${sqlite.dev}" + "--with-apr=${apr.dev}" + "--with-apr-util=${aprutil.dev}" + ] + ++ lib.optionals javahlBindings [ + "--enable-javahl" + "--with-jdk=${jdk}" + ]; + + preBuild = '' + makeFlagsArray=(APACHE_LIBEXECDIR=$out/modules) + ''; + + postInstall = '' + if test -n "$pythonBindings"; then + make swig-py swig_pydir=$(toPythonPath $out)/libsvn swig_pydir_extra=$(toPythonPath $out)/svn + make install-swig-py swig_pydir=$(toPythonPath $out)/libsvn swig_pydir_extra=$(toPythonPath $out)/svn + fi + + if test -n "$perlBindings"; then + make swig-pl-lib + make install-swig-pl-lib + cd subversion/bindings/swig/perl/native + perl Makefile.PL PREFIX=$out + make install + cd - + fi + + mkdir -p $out/share/bash-completion/completions + cp tools/client-side/bash_completion $out/share/bash-completion/completions/subversion + + for f in $out/lib/*.la $out/lib/python*/site-packages/*/*.la; do + substituteInPlace $f \ + --replace "${expat.dev}/lib" "${expat.out}/lib" \ + --replace "${zlib.dev}/lib" "${zlib.out}/lib" \ + --replace "${sqlite.dev}/lib" "${sqlite.out}/lib" \ + --replace "${openssl.dev}/lib" "${lib.getLib openssl}/lib" + done + ''; + + inherit perlBindings pythonBindings; + + enableParallelBuilding = true; + # Missing install dependencies: + # libtool: error: error: relink 'libsvn_ra_serf-1.la' with the above command before installing it + # make: *** [build-outputs.mk:1316: install-serf-lib] Error 1 + enableParallelInstalling = false; + + nativeCheckInputs = [ python3 ]; + doCheck = false; # fails 10 out of ~2300 tests + + meta = with lib; { + description = "Version control system intended to be a compelling replacement for CVS in the open source community"; + license = licenses.asl20; + homepage = "https://subversion.apache.org/"; + mainProgram = "svn"; + maintainers = with maintainers; [ lovek323 ]; + platforms = platforms.linux ++ platforms.darwin; + }; + + } + // lib.optionalAttrs stdenv.hostPlatform.isDarwin { + CXX = "clang++"; + CC = "clang"; + CPP = "clang -E"; + CXXCPP = "clang++ -E"; + } + ); + +in +{ subversion = common { version = "1.14.5"; sha256 = "sha256-54op53Zri3s1RJfQj3GlVkGrxTZ1zhh1WEeBquNWRKE="; diff --git a/pkgs/applications/version-management/svn-all-fast-export/default.nix b/pkgs/applications/version-management/svn-all-fast-export/default.nix index cf979f3d7dfde9..6b2628f3a4f104 100644 --- a/pkgs/applications/version-management/svn-all-fast-export/default.nix +++ b/pkgs/applications/version-management/svn-all-fast-export/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, qmake, qtbase, qttools, subversion, apr }: +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + qtbase, + qttools, + subversion, + apr, +}: let version = "1.0.18"; @@ -14,8 +23,15 @@ stdenv.mkDerivation { sha256 = "1b5yx2316hbyvw3v30vn1ljma9yd21nd59wis1gi34g92lgvqcd6"; }; - nativeBuildInputs = [ qmake qttools ]; - buildInputs = [ apr.dev subversion.dev qtbase ]; + nativeBuildInputs = [ + qmake + qttools + ]; + buildInputs = [ + apr.dev + subversion.dev + qtbase + ]; qmakeFlags = [ "VERSION=${version}" diff --git a/pkgs/applications/version-management/svn2git/default.nix b/pkgs/applications/version-management/svn2git/default.nix index 89ea5c0e84ae2d..c839b01239c062 100644 --- a/pkgs/applications/version-management/svn2git/default.nix +++ b/pkgs/applications/version-management/svn2git/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, ruby, makeWrapper, git }: +{ + lib, + stdenv, + fetchFromGitHub, + ruby, + makeWrapper, + git, +}: stdenv.mkDerivation rec { pname = "svn2git"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-w649l/WO68vYYxZOBKzI8XhGFkaSwWx/O3oVOtnGg6w="; }; - nativeBuildInputs = [ ruby makeWrapper ]; + nativeBuildInputs = [ + ruby + makeWrapper + ]; dontBuild = true; diff --git a/pkgs/applications/version-management/vcprompt/default.nix b/pkgs/applications/version-management/vcprompt/default.nix index d2ef35c9b66882..7e4c5886c5c80e 100644 --- a/pkgs/applications/version-management/vcprompt/default.nix +++ b/pkgs/applications/version-management/vcprompt/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchhg, autoconf, sqlite }: +{ + lib, + stdenv, + fetchhg, + autoconf, + sqlite, +}: stdenv.mkDerivation rec { pname = "vcprompt"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "03xqvp6bfl98bpacrw4n82qv9cw6a4fxci802s3vrygas989v1kj"; }; - buildInputs = [ sqlite autoconf ]; + buildInputs = [ + sqlite + autoconf + ]; preConfigure = '' autoconf @@ -22,9 +31,9 @@ stdenv.mkDerivation rec { A little C program that prints a short string with barebones information about the current working directory for various version control systems ''; - homepage = "http://hg.gerg.ca/vcprompt"; + homepage = "http://hg.gerg.ca/vcprompt"; maintainers = [ ]; - platforms = with platforms; linux ++ darwin; + platforms = with platforms; linux ++ darwin; license = licenses.gpl2Plus; mainProgram = "vcprompt"; }; diff --git a/pkgs/applications/video/anilibria-winmaclinux/default.nix b/pkgs/applications/video/anilibria-winmaclinux/default.nix index a814406a5c22e0..217b4b9b80d2d9 100644 --- a/pkgs/applications/video/anilibria-winmaclinux/default.nix +++ b/pkgs/applications/video/anilibria-winmaclinux/default.nix @@ -1,19 +1,22 @@ -{ mkDerivation -, lib -, fetchFromGitHub -, qmake -, pkg-config -, qtbase -, qtquickcontrols2 -, qtwebsockets -, qtmultimedia -, gst_all_1 -, wrapQtAppsHook -, makeDesktopItem -, copyDesktopItems +{ + mkDerivation, + lib, + fetchFromGitHub, + qmake, + pkg-config, + qtbase, + qtquickcontrols2, + qtwebsockets, + qtmultimedia, + gst_all_1, + wrapQtAppsHook, + makeDesktopItem, + copyDesktopItems, -, withVLC ? true , libvlc -, withMPV ? true , mpv-unwrapped + withVLC ? true, + libvlc, + withMPV ? true, + mpv-unwrapped, }: mkDerivation rec { @@ -29,7 +32,8 @@ mkDerivation rec { sourceRoot = "${src.name}/src"; - qmakeFlags = [ "PREFIX=${placeholder "out"}" ] + qmakeFlags = + [ "PREFIX=${placeholder "out"}" ] ++ lib.optionals withVLC [ "CONFIG+=unixvlc" ] ++ lib.optionals withMPV [ "CONFIG+=unixmpv" ]; @@ -44,13 +48,18 @@ mkDerivation rec { ''; qtWrapperArgs = [ - "--prefix GST_PLUGIN_PATH : ${(with gst_all_1; lib.makeSearchPathOutput "lib" "lib/gstreamer-1.0" [ - gst-plugins-bad - gst-plugins-good - gst-plugins-base - gst-libav - gstreamer - ])}" + "--prefix GST_PLUGIN_PATH : ${ + ( + with gst_all_1; + lib.makeSearchPathOutput "lib" "lib/gstreamer-1.0" [ + gst-plugins-bad + gst-plugins-good + gst-plugins-base + gst-libav + gstreamer + ] + ) + }" ]; nativeBuildInputs = [ @@ -60,20 +69,22 @@ mkDerivation rec { copyDesktopItems ]; - buildInputs = [ - qtbase - qtquickcontrols2 - qtwebsockets - qtmultimedia - ] ++ (with gst_all_1; [ - gst-plugins-bad - gst-plugins-good - gst-plugins-base - gst-libav - gstreamer - ]) - ++ lib.optionals withVLC [ libvlc ] - ++ lib.optionals withMPV [ mpv-unwrapped.dev ]; + buildInputs = + [ + qtbase + qtquickcontrols2 + qtwebsockets + qtmultimedia + ] + ++ (with gst_all_1; [ + gst-plugins-bad + gst-plugins-good + gst-plugins-base + gst-libav + gstreamer + ]) + ++ lib.optionals withVLC [ libvlc ] + ++ lib.optionals withMPV [ mpv-unwrapped.dev ]; desktopItems = [ (makeDesktopItem (rec { @@ -82,7 +93,11 @@ mkDerivation rec { icon = "anilibria"; comment = meta.description; genericName = "AniLibria desktop client"; - categories = [ "Qt" "AudioVideo" "Player" ]; + categories = [ + "Qt" + "AudioVideo" + "Player" + ]; keywords = [ "anime" ]; exec = name; terminal = false; diff --git a/pkgs/applications/video/animdl/default.nix b/pkgs/applications/video/animdl/default.nix index ebe13e8b12e261..3c0fe37dd06282 100644 --- a/pkgs/applications/video/animdl/default.nix +++ b/pkgs/applications/video/animdl/default.nix @@ -1,4 +1,5 @@ -{ lib, +{ + lib, buildPythonApplication, fetchFromGitHub, poetry-core, @@ -15,7 +16,7 @@ regex, rich, tqdm, - yarl + yarl, }: buildPythonApplication { pname = "animdl"; diff --git a/pkgs/applications/video/anime-downloader/default.nix b/pkgs/applications/video/anime-downloader/default.nix index bf8fa063bd92d0..4d8c2f93262536 100644 --- a/pkgs/applications/video/anime-downloader/default.nix +++ b/pkgs/applications/video/anime-downloader/default.nix @@ -1,4 +1,12 @@ -{ lib, python3, aria2, mpv, nodejs, qt5, fetchFromGitHub }: +{ + lib, + python3, + aria2, + mpv, + nodejs, + qt5, + fetchFromGitHub, +}: python3.pkgs.buildPythonApplication rec { pname = "anime-downloader"; @@ -13,25 +21,27 @@ python3.pkgs.buildPythonApplication rec { nativeBuildInputs = [ qt5.wrapQtAppsHook ]; - propagatedBuildInputs = [ - aria2 - mpv - nodejs - ] ++ (with python3.pkgs; [ - beautifulsoup4 - cfscrape - click - coloredlogs - fuzzywuzzy - jsbeautifier - pycryptodome - pysmartdl - pyqt5 - requests - requests-cache - selenium - tabulate - ]); + propagatedBuildInputs = + [ + aria2 + mpv + nodejs + ] + ++ (with python3.pkgs; [ + beautifulsoup4 + cfscrape + click + coloredlogs + fuzzywuzzy + jsbeautifier + pycryptodome + pysmartdl + pyqt5 + requests + requests-cache + selenium + tabulate + ]); preFixup = '' wrapQtApp "$out/bin/anime" --prefix PATH : ${lib.makeBinPath propagatedBuildInputs} diff --git a/pkgs/applications/video/avidemux/default.nix b/pkgs/applications/video/avidemux/default.nix index c2b6d5be732583..4c1dfaa7a8fa6b 100644 --- a/pkgs/applications/video/avidemux/default.nix +++ b/pkgs/applications/video/avidemux/default.nix @@ -1,22 +1,51 @@ -{ stdenv, lib, fetchurl, fetchpatch, cmake, pkg-config -, zlib, gettext, libvdpau, libva, libXv, sqlite -, yasm, freetype, fontconfig, fribidi -, makeWrapper, libXext, libGLU, qttools, qtbase, wrapQtAppsHook -, alsa-lib -, withX265 ? true, x265 -, withX264 ? true, x264 -, withXvid ? true, xvidcore -, withLAME ? true, lame -, withFAAC ? false, faac -, withVorbis ? true, libvorbis -, withPulse ? true, libpulseaudio -, withFAAD ? true, faad2 -, withOpus ? true, libopus -, withVPX ? true, libvpx -, withQT ? true -, withCLI ? true -, default ? "qt5" -, withPlugins ? true +{ + stdenv, + lib, + fetchurl, + fetchpatch, + cmake, + pkg-config, + zlib, + gettext, + libvdpau, + libva, + libXv, + sqlite, + yasm, + freetype, + fontconfig, + fribidi, + makeWrapper, + libXext, + libGLU, + qttools, + qtbase, + wrapQtAppsHook, + alsa-lib, + withX265 ? true, + x265, + withX264 ? true, + x264, + withXvid ? true, + xvidcore, + withLAME ? true, + lame, + withFAAC ? false, + faac, + withVorbis ? true, + libvorbis, + withPulse ? true, + libpulseaudio, + withFAAD ? true, + faad2, + withOpus ? true, + libopus, + withVPX ? true, + libvpx, + withQT ? true, + withCLI ? true, + default ? "qt5", + withPlugins ? true, }: assert withQT -> qttools != null && qtbase != null; @@ -38,22 +67,39 @@ stdenv.mkDerivation rec { ]; postPatch = '' - cp ${fetchpatch { - # Backport fix for binutils-2.41. - name = "binutils-2.41.patch"; - url = "https://git.ffmpeg.org/gitweb/ffmpeg.git/patch/effadce6c756247ea8bae32dc13bb3e6f464f0eb"; - hash = "sha256-s9PcYbt0mFb2wvgMcFL1J+2OS6Sxyd2wYkGzLr2qd9M="; - stripLen = 1; - }} avidemux_core/ffmpeg_package/patches/ + cp ${ + fetchpatch { + # Backport fix for binutils-2.41. + name = "binutils-2.41.patch"; + url = "https://git.ffmpeg.org/gitweb/ffmpeg.git/patch/effadce6c756247ea8bae32dc13bb3e6f464f0eb"; + hash = "sha256-s9PcYbt0mFb2wvgMcFL1J+2OS6Sxyd2wYkGzLr2qd9M="; + stripLen = 1; + } + } avidemux_core/ffmpeg_package/patches/ ''; - nativeBuildInputs = - [ yasm cmake pkg-config makeWrapper ] - ++ lib.optional withQT wrapQtAppsHook; - buildInputs = [ - zlib gettext libvdpau libva libXv sqlite fribidi fontconfig - freetype alsa-lib libXext libGLU - ] ++ lib.optional withX264 x264 + nativeBuildInputs = [ + yasm + cmake + pkg-config + makeWrapper + ] ++ lib.optional withQT wrapQtAppsHook; + buildInputs = + [ + zlib + gettext + libvdpau + libva + libXv + sqlite + fribidi + fontconfig + freetype + alsa-lib + libXext + libGLU + ] + ++ lib.optional withX264 x264 ++ lib.optional withX265 x265 ++ lib.optional withXvid xvidcore ++ lib.optional withLAME lame @@ -62,53 +108,62 @@ stdenv.mkDerivation rec { ++ lib.optional withPulse libpulseaudio ++ lib.optional withFAAD faad2 ++ lib.optional withOpus libopus - ++ lib.optionals withQT [ qttools qtbase ] + ++ lib.optionals withQT [ + qttools + qtbase + ] ++ lib.optional withVPX libvpx; dontWrapQtApps = true; - buildCommand = let - wrapWith = makeWrapper: filename: - "${makeWrapper} ${filename} --set ADM_ROOT_DIR $out --prefix LD_LIBRARY_PATH : ${libXext}/lib"; - wrapQtApp = wrapWith "wrapQtApp"; - wrapProgram = wrapWith "wrapProgram"; - in '' - unpackPhase - cd "$sourceRoot" - patchPhase + buildCommand = + let + wrapWith = + makeWrapper: filename: + "${makeWrapper} ${filename} --set ADM_ROOT_DIR $out --prefix LD_LIBRARY_PATH : ${libXext}/lib"; + wrapQtApp = wrapWith "wrapQtApp"; + wrapProgram = wrapWith "wrapProgram"; + in + '' + unpackPhase + cd "$sourceRoot" + patchPhase - ${stdenv.shell} bootStrap.bash \ - --with-core \ - ${if withQT then "--with-qt" else "--without-qt"} \ - ${if withCLI then "--with-cli" else "--without-cli"} \ - ${if withPlugins then "--with-plugins" else "--without-plugins"} + ${stdenv.shell} bootStrap.bash \ + --with-core \ + ${if withQT then "--with-qt" else "--without-qt"} \ + ${if withCLI then "--with-cli" else "--without-cli"} \ + ${if withPlugins then "--with-plugins" else "--without-plugins"} - mkdir $out - cp -R install/usr/* $out + mkdir $out + cp -R install/usr/* $out - ${wrapProgram "$out/bin/avidemux3_cli"} + ${wrapProgram "$out/bin/avidemux3_cli"} - ${lib.optionalString withQT '' - ${wrapQtApp "$out/bin/avidemux3_qt5"} - ${wrapQtApp "$out/bin/avidemux3_jobs_qt5"} - ''} + ${lib.optionalString withQT '' + ${wrapQtApp "$out/bin/avidemux3_qt5"} + ${wrapQtApp "$out/bin/avidemux3_jobs_qt5"} + ''} - ln -s "$out/bin/avidemux3_${default}" "$out/bin/avidemux" + ln -s "$out/bin/avidemux3_${default}" "$out/bin/avidemux" - # make the install path match the rpath - if [[ -d ''${!outputLib}/lib64 ]]; then - mv ''${!outputLib}/lib64 ''${!outputLib}/lib - ln -s lib ''${!outputLib}/lib64 - fi - fixupPhase - ''; + # make the install path match the rpath + if [[ -d ''${!outputLib}/lib64 ]]; then + mv ''${!outputLib}/lib64 ''${!outputLib}/lib + ln -s lib ''${!outputLib}/lib64 + fi + fixupPhase + ''; meta = with lib; { homepage = "http://fixounet.free.fr/avidemux/"; description = "Free video editor designed for simple video editing tasks"; maintainers = with maintainers; [ abbradar ]; # "CPU not supported" errors on AArch64 - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; license = licenses.gpl2; }; } diff --git a/pkgs/applications/video/clipgrab/default.nix b/pkgs/applications/video/clipgrab/default.nix index 1625c87e0c0bb7..0ac6cae8d5693a 100644 --- a/pkgs/applications/video/clipgrab/default.nix +++ b/pkgs/applications/video/clipgrab/default.nix @@ -1,7 +1,18 @@ -{ lib, fetchurl, makeDesktopItem, ffmpeg -, qmake, qttools, mkDerivation -, qtbase, qtdeclarative, qtlocation, qtquickcontrols2, qtwebchannel, qtwebengine -, yt-dlp +{ + lib, + fetchurl, + makeDesktopItem, + ffmpeg, + qmake, + qttools, + mkDerivation, + qtbase, + qtdeclarative, + qtlocation, + qtquickcontrols2, + qtwebchannel, + qtwebengine, + yt-dlp, }: mkDerivation rec { @@ -14,22 +25,35 @@ mkDerivation rec { url = "https://download.clipgrab.org/${pname}-${version}.tar.gz"; }; - buildInputs = [ ffmpeg qtbase qtdeclarative qtlocation qtquickcontrols2 qtwebchannel qtwebengine ]; - nativeBuildInputs = [ qmake qttools ]; + buildInputs = [ + ffmpeg + qtbase + qtdeclarative + qtlocation + qtquickcontrols2 + qtwebchannel + qtwebengine + ]; + nativeBuildInputs = [ + qmake + qttools + ]; patches = [ ./yt-dlp-path.patch ]; - postPatch = '' - substituteInPlace youtube_dl.cpp \ - --replace 'QString YoutubeDl::path = QString();' \ - 'QString YoutubeDl::path = QString("${yt-dlp}/bin/yt-dlp");' - '' + lib.optionalString (ffmpeg != null) '' - substituteInPlace converter_ffmpeg.cpp \ - --replace '"ffmpeg"' '"${ffmpeg.bin}/bin/ffmpeg"' \ - --replace '"ffmpeg ' '"${ffmpeg.bin}/bin/ffmpeg ' - ''; + postPatch = + '' + substituteInPlace youtube_dl.cpp \ + --replace 'QString YoutubeDl::path = QString();' \ + 'QString YoutubeDl::path = QString("${yt-dlp}/bin/yt-dlp");' + '' + + lib.optionalString (ffmpeg != null) '' + substituteInPlace converter_ffmpeg.cpp \ + --replace '"ffmpeg"' '"${ffmpeg.bin}/bin/ffmpeg"' \ + --replace '"ffmpeg ' '"${ffmpeg.bin}/bin/ffmpeg ' + ''; qmakeFlags = [ "clipgrab.pro" ]; @@ -40,7 +64,12 @@ mkDerivation rec { desktopName = "ClipGrab"; comment = meta.description; genericName = "Web video downloader"; - categories = [ "Qt" "AudioVideo" "Audio" "Video" ]; + categories = [ + "Qt" + "AudioVideo" + "Audio" + "Video" + ]; }; installPhase = '' diff --git a/pkgs/applications/video/davinci-resolve/default.nix b/pkgs/applications/video/davinci-resolve/default.nix index d66202afcc71d8..d98b2c8cd3224b 100644 --- a/pkgs/applications/video/davinci-resolve/default.nix +++ b/pkgs/applications/video/davinci-resolve/default.nix @@ -1,33 +1,34 @@ -{ stdenv -, lib -, cacert -, curl -, runCommandLocal -, unzip -, appimage-run -, addDriverRunpath -, dbus -, libGLU -, xorg -, buildFHSEnv -, buildFHSEnvChroot -, bash -, writeText -, ocl-icd -, xkeyboard_config -, glib -, libarchive -, libxcrypt -, python3 -, aprutil -, makeDesktopItem -, copyDesktopItems -, jq - -, studioVariant ? false - -, common-updater-scripts -, writeShellApplication +{ + stdenv, + lib, + cacert, + curl, + runCommandLocal, + unzip, + appimage-run, + addDriverRunpath, + dbus, + libGLU, + xorg, + buildFHSEnv, + buildFHSEnvChroot, + bash, + writeText, + ocl-icd, + xkeyboard_config, + glib, + libarchive, + libxcrypt, + python3, + aprutil, + makeDesktopItem, + copyDesktopItems, + jq, + + studioVariant ? false, + + common-updater-scripts, + writeShellApplication, }: let @@ -37,7 +38,7 @@ let version = "19.1"; nativeBuildInputs = [ - (appimage-run.override { buildFHSEnv = buildFHSEnvChroot; } ) + (appimage-run.override { buildFHSEnv = buildFHSEnvChroot; }) addDriverRunpath copyDesktopItems unzip @@ -49,101 +50,109 @@ let xorg.libXxf86vm ]; - src = runCommandLocal "${pname}-src.zip" - rec { - outputHashMode = "recursive"; - outputHashAlgo = "sha256"; - outputHash = - if studioVariant - then "sha256-uEUZt0TQ4XrAag6NoCPUtYSnkwpwh3BNlol1z/EmP9E=" - else "sha256-3VVyfXT/mZFuf2GGkNS47ErSdAGpdUUwwwKY19zBBZo="; - - impureEnvVars = lib.fetchers.proxyImpureEnvVars; - - nativeBuildInputs = [ curl jq ]; - - # ENV VARS - SSL_CERT_FILE = "${cacert}/etc/ssl/certs/ca-bundle.crt"; - - # Get linux.downloadId from HTTP response on https://www.blackmagicdesign.com/products/davinciresolve - REFERID = "263d62f31cbb49e0868005059abcb0c9"; - DOWNLOADSURL = "https://www.blackmagicdesign.com/api/support/us/downloads.json"; - SITEURL = "https://www.blackmagicdesign.com/api/register/us/download"; - PRODUCT = "DaVinci Resolve${lib.optionalString studioVariant " Studio"}"; - VERSION = version; - - USERAGENT = builtins.concatStringsSep " " [ - "User-Agent: Mozilla/5.0 (X11; Linux ${stdenv.hostPlatform.linuxArch})" - "AppleWebKit/537.36 (KHTML, like Gecko)" - "Chrome/77.0.3865.75" - "Safari/537.36" - ]; - - REQJSON = builtins.toJSON { - "firstname" = "NixOS"; - "lastname" = "Linux"; - "email" = "someone@nixos.org"; - "phone" = "+31 71 452 5670"; - "country" = "nl"; - "street" = "-"; - "state" = "Province of Utrecht"; - "city" = "Utrecht"; - "product" = PRODUCT; - }; - - } '' - DOWNLOADID=$( - curl --silent --compressed "$DOWNLOADSURL" \ - | jq --raw-output '.downloads[] | .urls.Linux?[]? | select(.downloadTitle | test("^'"$PRODUCT $VERSION"'( Update)?$")) | .downloadId' - ) - echo "downloadid is $DOWNLOADID" - test -n "$DOWNLOADID" - RESOLVEURL=$(curl \ - --silent \ - --header 'Host: www.blackmagicdesign.com' \ - --header 'Accept: application/json, text/plain, */*' \ - --header 'Origin: https://www.blackmagicdesign.com' \ - --header "$USERAGENT" \ - --header 'Content-Type: application/json;charset=UTF-8' \ - --header "Referer: https://www.blackmagicdesign.com/support/download/$REFERID/Linux" \ - --header 'Accept-Encoding: gzip, deflate, br' \ - --header 'Accept-Language: en-US,en;q=0.9' \ - --header 'Authority: www.blackmagicdesign.com' \ - --header 'Cookie: _ga=GA1.2.1849503966.1518103294; _gid=GA1.2.953840595.1518103294' \ - --data-ascii "$REQJSON" \ - --compressed \ - "$SITEURL/$DOWNLOADID") - echo "resolveurl is $RESOLVEURL" - - curl \ - --retry 3 --retry-delay 3 \ - --header "Upgrade-Insecure-Requests: 1" \ - --header "$USERAGENT" \ - --header "Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8" \ - --header "Accept-Language: en-US,en;q=0.9" \ - --compressed \ - "$RESOLVEURL" \ - > $out - ''; + src = + runCommandLocal "${pname}-src.zip" + rec { + outputHashMode = "recursive"; + outputHashAlgo = "sha256"; + outputHash = + if studioVariant then + "sha256-uEUZt0TQ4XrAag6NoCPUtYSnkwpwh3BNlol1z/EmP9E=" + else + "sha256-3VVyfXT/mZFuf2GGkNS47ErSdAGpdUUwwwKY19zBBZo="; + + impureEnvVars = lib.fetchers.proxyImpureEnvVars; + + nativeBuildInputs = [ + curl + jq + ]; + + # ENV VARS + SSL_CERT_FILE = "${cacert}/etc/ssl/certs/ca-bundle.crt"; + + # Get linux.downloadId from HTTP response on https://www.blackmagicdesign.com/products/davinciresolve + REFERID = "263d62f31cbb49e0868005059abcb0c9"; + DOWNLOADSURL = "https://www.blackmagicdesign.com/api/support/us/downloads.json"; + SITEURL = "https://www.blackmagicdesign.com/api/register/us/download"; + PRODUCT = "DaVinci Resolve${lib.optionalString studioVariant " Studio"}"; + VERSION = version; + + USERAGENT = builtins.concatStringsSep " " [ + "User-Agent: Mozilla/5.0 (X11; Linux ${stdenv.hostPlatform.linuxArch})" + "AppleWebKit/537.36 (KHTML, like Gecko)" + "Chrome/77.0.3865.75" + "Safari/537.36" + ]; + + REQJSON = builtins.toJSON { + "firstname" = "NixOS"; + "lastname" = "Linux"; + "email" = "someone@nixos.org"; + "phone" = "+31 71 452 5670"; + "country" = "nl"; + "street" = "-"; + "state" = "Province of Utrecht"; + "city" = "Utrecht"; + "product" = PRODUCT; + }; + + } + '' + DOWNLOADID=$( + curl --silent --compressed "$DOWNLOADSURL" \ + | jq --raw-output '.downloads[] | .urls.Linux?[]? | select(.downloadTitle | test("^'"$PRODUCT $VERSION"'( Update)?$")) | .downloadId' + ) + echo "downloadid is $DOWNLOADID" + test -n "$DOWNLOADID" + RESOLVEURL=$(curl \ + --silent \ + --header 'Host: www.blackmagicdesign.com' \ + --header 'Accept: application/json, text/plain, */*' \ + --header 'Origin: https://www.blackmagicdesign.com' \ + --header "$USERAGENT" \ + --header 'Content-Type: application/json;charset=UTF-8' \ + --header "Referer: https://www.blackmagicdesign.com/support/download/$REFERID/Linux" \ + --header 'Accept-Encoding: gzip, deflate, br' \ + --header 'Accept-Language: en-US,en;q=0.9' \ + --header 'Authority: www.blackmagicdesign.com' \ + --header 'Cookie: _ga=GA1.2.1849503966.1518103294; _gid=GA1.2.953840595.1518103294' \ + --data-ascii "$REQJSON" \ + --compressed \ + "$SITEURL/$DOWNLOADID") + echo "resolveurl is $RESOLVEURL" + + curl \ + --retry 3 --retry-delay 3 \ + --header "Upgrade-Insecure-Requests: 1" \ + --header "$USERAGENT" \ + --header "Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8" \ + --header "Accept-Language: en-US,en;q=0.9" \ + --compressed \ + "$RESOLVEURL" \ + > $out + ''; # The unpack phase won't generate a directory sourceRoot = "."; - installPhase = let - appimageName = "DaVinci_Resolve_${lib.optionalString studioVariant "Studio_"}${version}_Linux.run"; - in '' - runHook preInstall + installPhase = + let + appimageName = "DaVinci_Resolve_${lib.optionalString studioVariant "Studio_"}${version}_Linux.run"; + in + '' + runHook preInstall - export HOME=$PWD/home - mkdir -p $HOME + export HOME=$PWD/home + mkdir -p $HOME - mkdir -p $out - test -e ${lib.escapeShellArg appimageName} - appimage-run ${lib.escapeShellArg appimageName} -i -y -n -C $out + mkdir -p $out + test -e ${lib.escapeShellArg appimageName} + appimage-run ${lib.escapeShellArg appimageName} -i -y -n -C $out - mkdir -p $out/{configs,DolbyVision,easyDCP,Fairlight,GPUCache,logs,Media,"Resolve Disk Database",.crashreport,.license,.LUT} - runHook postInstall - ''; + mkdir -p $out/{configs,DolbyVision,easyDCP,Fairlight,GPUCache,logs,Media,"Resolve Disk Database",.crashreport,.license,.LUT} + runHook postInstall + ''; dontStrip = true; @@ -185,56 +194,57 @@ in buildFHSEnv { inherit (davinci) pname version; - targetPkgs = pkgs: with pkgs; [ - alsa-lib - aprutil - bzip2 - davinci - dbus - expat - fontconfig - freetype - glib - libGL - libGLU - libarchive - libcap - librsvg - libtool - libuuid - libxcrypt # provides libcrypt.so.1 - libxkbcommon - nspr - ocl-icd - opencl-headers - python3 - python3.pkgs.numpy - udev - xdg-utils # xdg-open needed to open URLs - xorg.libICE - xorg.libSM - xorg.libX11 - xorg.libXcomposite - xorg.libXcursor - xorg.libXdamage - xorg.libXext - xorg.libXfixes - xorg.libXi - xorg.libXinerama - xorg.libXrandr - xorg.libXrender - xorg.libXt - xorg.libXtst - xorg.libXxf86vm - xorg.libxcb - xorg.xcbutil - xorg.xcbutilimage - xorg.xcbutilkeysyms - xorg.xcbutilrenderutil - xorg.xcbutilwm - xorg.xkeyboardconfig - zlib - ]; + targetPkgs = + pkgs: with pkgs; [ + alsa-lib + aprutil + bzip2 + davinci + dbus + expat + fontconfig + freetype + glib + libGL + libGLU + libarchive + libcap + librsvg + libtool + libuuid + libxcrypt # provides libcrypt.so.1 + libxkbcommon + nspr + ocl-icd + opencl-headers + python3 + python3.pkgs.numpy + udev + xdg-utils # xdg-open needed to open URLs + xorg.libICE + xorg.libSM + xorg.libX11 + xorg.libXcomposite + xorg.libXcursor + xorg.libXdamage + xorg.libXext + xorg.libXfixes + xorg.libXi + xorg.libXinerama + xorg.libXrandr + xorg.libXrender + xorg.libXt + xorg.libXtst + xorg.libXxf86vm + xorg.libxcb + xorg.xcbutil + xorg.xcbutilimage + xorg.xcbutilkeysyms + xorg.xcbutilrenderutil + xorg.xcbutilwm + xorg.xkeyboardconfig + zlib + ]; extraPreBwrapCmds = lib.optionalString studioVariant '' mkdir -p ~/.local/share/DaVinciResolve/license || exit 1 @@ -244,15 +254,12 @@ buildFHSEnv { "--bind \"$HOME\"/.local/share/DaVinciResolve/license ${davinci}/.license" ]; - runScript = "${bash}/bin/bash ${ - writeText "davinci-wrapper" - '' + runScript = "${bash}/bin/bash ${writeText "davinci-wrapper" '' export QT_XKB_CONFIG_ROOT="${xkeyboard_config}/share/X11/xkb" export QT_PLUGIN_PATH="${davinci}/libs/plugins:$QT_PLUGIN_PATH" export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/lib:/usr/lib32:${davinci}/libs ${davinci}/bin/resolve - '' - }"; + ''}"; extraInstallCommands = '' mkdir -p $out/share/applications $out/share/icons/hicolor/128x128/apps @@ -264,7 +271,11 @@ buildFHSEnv { inherit davinci; updateScript = lib.getExe (writeShellApplication { name = "update-davinci-resolve"; - runtimeInputs = [ curl jq common-updater-scripts ]; + runtimeInputs = [ + curl + jq + common-updater-scripts + ]; text = '' set -o errexit drv=pkgs/applications/video/davinci-resolve/default.nix @@ -287,7 +298,11 @@ buildFHSEnv { description = "Professional video editing, color, effects and audio post-processing"; homepage = "https://www.blackmagicdesign.com/products/davinciresolve"; license = licenses.unfree; - maintainers = with maintainers; [ amarshall jshcmpbll orivej ]; + maintainers = with maintainers; [ + amarshall + jshcmpbll + orivej + ]; platforms = [ "x86_64-linux" ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; mainProgram = "davinci-resolve${lib.optionalString studioVariant "-studio"}"; diff --git a/pkgs/applications/video/electronplayer/electronplayer.nix b/pkgs/applications/video/electronplayer/electronplayer.nix index 1cb10e65cbb952..a11c8555e76cf9 100644 --- a/pkgs/applications/video/electronplayer/electronplayer.nix +++ b/pkgs/applications/video/electronplayer/electronplayer.nix @@ -1,4 +1,8 @@ -{ appimageTools, lib, fetchurl }: +{ + appimageTools, + lib, + fetchurl, +}: let pname = "electronplayer"; version = "2.0.8"; @@ -10,7 +14,8 @@ let }; appimageContents = appimageTools.extractType2 { inherit pname version src; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; extraInstallCommands = '' diff --git a/pkgs/applications/video/glaxnimate/default.nix b/pkgs/applications/video/glaxnimate/default.nix index 984e5db8f665d7..128e83bd979fa7 100644 --- a/pkgs/applications/video/glaxnimate/default.nix +++ b/pkgs/applications/video/glaxnimate/default.nix @@ -1,40 +1,43 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, cmake -, zlib -, potrace -, ffmpeg -, libarchive -, python3 -, qtbase -, qttools -, wrapQtAppsHook -, testers -, qtsvg -, qtimageformats +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + cmake, + zlib, + potrace, + ffmpeg, + libarchive, + python3, + qtbase, + qttools, + wrapQtAppsHook, + testers, + qtsvg, + qtimageformats, # For the tests -, glaxnimate # Call itself, for the tests -, xvfb-run + glaxnimate, # Call itself, for the tests + xvfb-run, }: let # TODO: try to add a python library, see toPythonModule in doc/languages-frameworks/python.section.md - python3WithLibs = python3.withPackages (ps: with ps; [ - # In data/lib/python-lottie/requirements.txt - numpy - pillow - cairosvg - fonttools - grapheme - opencv4 - pyqt5 - qscintilla - # Not sure if needed, but appears in some files - pyyaml - requests - pybind11 - ]); + python3WithLibs = python3.withPackages ( + ps: with ps; [ + # In data/lib/python-lottie/requirements.txt + numpy + pillow + cairosvg + fonttools + grapheme + opencv4 + pyqt5 + qscintilla + # Not sure if needed, but appears in some files + pyyaml + requests + pybind11 + ] + ); in stdenv.mkDerivation rec { pname = "glaxnimate"; @@ -82,10 +85,12 @@ stdenv.mkDerivation rec { qtWrapperArgs = [ ''--prefix PATH : ${python3WithLibs}/bin'' ]; - passthru.tests.version = lib.optionalAttrs stdenv.hostPlatform.isLinux (testers.testVersion { - package = glaxnimate; - command = "${xvfb-run}/bin/xvfb-run glaxnimate --version"; - }); + passthru.tests.version = lib.optionalAttrs stdenv.hostPlatform.isLinux ( + testers.testVersion { + package = glaxnimate; + command = "${xvfb-run}/bin/xvfb-run glaxnimate --version"; + } + ); meta = with lib; { homepage = "https://gitlab.com/mattbas/glaxnimate"; diff --git a/pkgs/applications/video/go2tv/default.nix b/pkgs/applications/video/go2tv/default.nix index e7ecf293693546..af62de21a778c7 100644 --- a/pkgs/applications/video/go2tv/default.nix +++ b/pkgs/applications/video/go2tv/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, Carbon -, Cocoa -, Kernel -, UserNotifications -, xorg -, libglvnd -, pkg-config -, withGui ? true +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + Carbon, + Cocoa, + Kernel, + UserNotifications, + xorg, + libglvnd, + pkg-config, + withGui ? true, }: buildGoModule rec { @@ -27,16 +28,23 @@ buildGoModule rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - xorg.libX11 - xorg.libXcursor - xorg.libXrandr - xorg.libXinerama - xorg.libXi - xorg.libXext - xorg.libXxf86vm - libglvnd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Carbon Cocoa Kernel UserNotifications ]; + buildInputs = + [ + xorg.libX11 + xorg.libXcursor + xorg.libXrandr + xorg.libXinerama + xorg.libXi + xorg.libXext + xorg.libXxf86vm + libglvnd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + Cocoa + Kernel + UserNotifications + ]; ldflags = [ "-s" diff --git a/pkgs/applications/video/gpac/default.nix b/pkgs/applications/video/gpac/default.nix index 8cd33a1b578f63..3bbb52e5fb7a01 100644 --- a/pkgs/applications/video/gpac/default.nix +++ b/pkgs/applications/video/gpac/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cctools, pkg-config, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + cctools, + pkg-config, + zlib, +}: stdenv.mkDerivation rec { pname = "gpac"; @@ -13,11 +20,13 @@ stdenv.mkDerivation rec { # this is the bare minimum configuration, as I'm only interested in MP4Box # For most other functionality, this should probably be extended - nativeBuildInputs = [ - pkg-config - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - cctools - ]; + nativeBuildInputs = + [ + pkg-config + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + cctools + ]; buildInputs = [ zlib @@ -41,7 +50,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://gpac.wp.imt.fr"; license = licenses.lgpl21; - maintainers = with maintainers; [ bluescreen303 mgdelacroix ]; + maintainers = with maintainers; [ + bluescreen303 + mgdelacroix + ]; platforms = platforms.unix; }; } diff --git a/pkgs/applications/video/haruna/default.nix b/pkgs/applications/video/haruna/default.nix index 96a6235bf9d128..1c0e4e9782b9b2 100644 --- a/pkgs/applications/video/haruna/default.nix +++ b/pkgs/applications/video/haruna/default.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitLab -, breeze-icons -, breeze -, cmake -, extra-cmake-modules -, ffmpeg-headless -, kconfig -, kcoreaddons -, kfilemetadata -, ki18n -, kiconthemes -, kio -, kirigami -, kxmlgui -, kdoctools -, mpvqt -, pkg-config -, wrapQtAppsHook -, qqc2-desktop-style -, qtbase -, yt-dlp +{ + lib, + stdenv, + fetchFromGitLab, + breeze-icons, + breeze, + cmake, + extra-cmake-modules, + ffmpeg-headless, + kconfig, + kcoreaddons, + kfilemetadata, + ki18n, + kiconthemes, + kio, + kirigami, + kxmlgui, + kdoctools, + mpvqt, + pkg-config, + wrapQtAppsHook, + qqc2-desktop-style, + qtbase, + yt-dlp, }: stdenv.mkDerivation rec { @@ -70,8 +71,19 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://invent.kde.org/multimedia/haruna"; description = "Open source video player built with Qt/QML and libmpv"; - license = with licenses; [ bsd3 cc-by-40 cc-by-sa-40 cc0 gpl2Plus gpl3Plus wtfpl ]; - maintainers = with maintainers; [ jojosch kashw2 ]; + license = with licenses; [ + bsd3 + cc-by-40 + cc-by-sa-40 + cc0 + gpl2Plus + gpl3Plus + wtfpl + ]; + maintainers = with maintainers; [ + jojosch + kashw2 + ]; mainProgram = "haruna"; }; } diff --git a/pkgs/applications/video/hyperion-ng/default.nix b/pkgs/applications/video/hyperion-ng/default.nix index 837e5071f440e9..f803f0f694de54 100644 --- a/pkgs/applications/video/hyperion-ng/default.nix +++ b/pkgs/applications/video/hyperion-ng/default.nix @@ -1,10 +1,27 @@ -{ stdenv, lib, fetchFromGitHub -, cmake, wrapQtAppsHook, perl -, flatbuffers, protobuf, mbedtls -, alsa-lib, hidapi, libcec, libusb1 -, libX11, libxcb, libXrandr, python3 -, qtbase, qtserialport, qtsvg, qtx11extras -, withRPiDispmanx ? false, libraspberrypi +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + wrapQtAppsHook, + perl, + flatbuffers, + protobuf, + mbedtls, + alsa-lib, + hidapi, + libcec, + libusb1, + libX11, + libxcb, + libXrandr, + python3, + qtbase, + qtserialport, + qtsvg, + qtx11extras, + withRPiDispmanx ? false, + libraspberrypi, }: stdenv.mkDerivation rec { @@ -22,32 +39,35 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - buildInputs = [ - alsa-lib - hidapi - libusb1 - libX11 - libxcb - libXrandr - flatbuffers - protobuf - mbedtls - python3 - qtbase - qtserialport - qtsvg - qtx11extras - ] ++ lib.optional stdenv.hostPlatform.isLinux libcec + buildInputs = + [ + alsa-lib + hidapi + libusb1 + libX11 + libxcb + libXrandr + flatbuffers + protobuf + mbedtls + python3 + qtbase + qtserialport + qtsvg + qtx11extras + ] + ++ lib.optional stdenv.hostPlatform.isLinux libcec ++ lib.optional withRPiDispmanx libraspberrypi; nativeBuildInputs = [ - cmake wrapQtAppsHook + cmake + wrapQtAppsHook ] ++ lib.optional stdenv.hostPlatform.isDarwin perl; # for macos bundle - patchPhase = '' + patchPhase = '' patchShebangs test/testrunner.sh patchShebangs src/hyperiond/CMakeLists.txt - '' ; + ''; cmakeFlags = [ "-DENABLE_DEPLOY_DEPENDENCIES=OFF" @@ -67,7 +87,10 @@ stdenv.mkDerivation rec { description = "Opensource Bias or Ambient Lighting implementation"; homepage = "https://github.com/hyperion-project/hyperion.ng"; license = licenses.mit; - maintainers = with maintainers; [ algram kazenyuk ]; + maintainers = with maintainers; [ + algram + kazenyuk + ]; platforms = platforms.unix; }; } diff --git a/pkgs/applications/video/jellyfin-mpv-shim/default.nix b/pkgs/applications/video/jellyfin-mpv-shim/default.nix index f810b5403f1bab..d9965291c2ff48 100644 --- a/pkgs/applications/video/jellyfin-mpv-shim/default.nix +++ b/pkgs/applications/video/jellyfin-mpv-shim/default.nix @@ -1,19 +1,20 @@ -{ lib -, buildPythonApplication -, copyDesktopItems -, fetchPypi -, gobject-introspection -, jellyfin-apiclient-python -, jinja2 -, makeDesktopItem -, mpv -, pillow -, pystray -, python -, python-mpv-jsonipc -, pywebview -, tkinter -, wrapGAppsHook3 +{ + lib, + buildPythonApplication, + copyDesktopItems, + fetchPypi, + gobject-introspection, + jellyfin-apiclient-python, + jinja2, + makeDesktopItem, + mpv, + pillow, + pystray, + python, + python-mpv-jsonipc, + pywebview, + tkinter, + wrapGAppsHook3, }: buildPythonApplication rec { @@ -92,7 +93,12 @@ buildPythonApplication rec { exec = pname; icon = pname; desktopName = "Jellyfin MPV Shim"; - categories = [ "Video" "AudioVideo" "TV" "Player" ]; + categories = [ + "Video" + "AudioVideo" + "TV" + "Player" + ]; }) ]; diff --git a/pkgs/applications/video/kmplayer/default.nix b/pkgs/applications/video/kmplayer/default.nix index a3c5b181725a5f..0c3d3d74e8df2a 100644 --- a/pkgs/applications/video/kmplayer/default.nix +++ b/pkgs/applications/video/kmplayer/default.nix @@ -1,9 +1,21 @@ { - mkDerivation, lib, fetchurl, - extra-cmake-modules, makeWrapper, - libpthreadstubs, libXdmcp, - qtsvg, qtx11extras, ki18n, kdelibs4support, kio, kmediaplayer, kwidgetsaddons, - phonon, cairo, mplayer + mkDerivation, + lib, + fetchurl, + extra-cmake-modules, + makeWrapper, + libpthreadstubs, + libXdmcp, + qtsvg, + qtx11extras, + ki18n, + kdelibs4support, + kio, + kmediaplayer, + kwidgetsaddons, + phonon, + cairo, + mplayer, }: mkDerivation rec { @@ -28,14 +40,25 @@ mkDerivation rec { ''; # required for kf5auth to work correctly - cmakeFlags = ["-DCMAKE_POLICY_DEFAULT_CMP0012=NEW"]; + cmakeFlags = [ "-DCMAKE_POLICY_DEFAULT_CMP0012=NEW" ]; - nativeBuildInputs = [ extra-cmake-modules makeWrapper ]; + nativeBuildInputs = [ + extra-cmake-modules + makeWrapper + ]; buildInputs = [ - libpthreadstubs libXdmcp - qtsvg qtx11extras ki18n kdelibs4support kio kmediaplayer kwidgetsaddons - phonon cairo + libpthreadstubs + libXdmcp + qtsvg + qtx11extras + ki18n + kdelibs4support + kio + kmediaplayer + kwidgetsaddons + phonon + cairo ]; postInstall = '' @@ -44,8 +67,15 @@ mkDerivation rec { meta = with lib; { description = "MPlayer front-end for KDE"; - license = with licenses; [ gpl2Plus lgpl2Plus fdl12Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + fdl12Plus + ]; homepage = "https://kmplayer.kde.org/"; - maintainers = with maintainers; [ sander zraexy ]; + maintainers = with maintainers; [ + sander + zraexy + ]; }; } diff --git a/pkgs/applications/video/kodi/addons/a4ksubtitles/default.nix b/pkgs/applications/video/kodi/addons/a4ksubtitles/default.nix index ae32fb7c5a77cf..a9936818c4ffba 100644 --- a/pkgs/applications/video/kodi/addons/a4ksubtitles/default.nix +++ b/pkgs/applications/video/kodi/addons/a4ksubtitles/default.nix @@ -1,4 +1,10 @@ -{ lib, buildKodiAddon, fetchFromGitHub, requests, vfs-libarchive }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, + requests, + vfs-libarchive, +}: buildKodiAddon rec { pname = "a4ksubtitles"; diff --git a/pkgs/applications/video/kodi/addons/addon-update-script/default.nix b/pkgs/applications/video/kodi/addons/addon-update-script/default.nix index f3b363dca0f8b8..9d48ae79586756 100644 --- a/pkgs/applications/video/kodi/addons/addon-update-script/default.nix +++ b/pkgs/applications/video/kodi/addons/addon-update-script/default.nix @@ -1,9 +1,10 @@ -{ writeShellScript -, nix -, curl -, gzip -, xmlstarlet -, common-updater-scripts +{ + writeShellScript, + nix, + curl, + gzip, + xmlstarlet, + common-updater-scripts, }: { attrPath }: @@ -20,4 +21,7 @@ let ${common-updater-scripts}/bin/update-source-version "$attrPath" "$version" ''; in - [ updateScript attrPath ] +[ + updateScript + attrPath +] diff --git a/pkgs/applications/video/kodi/addons/archive_tool/default.nix b/pkgs/applications/video/kodi/addons/archive_tool/default.nix index 03372e17285893..0b90ee1cd5a3a1 100644 --- a/pkgs/applications/video/kodi/addons/archive_tool/default.nix +++ b/pkgs/applications/video/kodi/addons/archive_tool/default.nix @@ -1,4 +1,9 @@ -{ lib, buildKodiAddon, fetchFromGitHub, vfs-libarchive }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, + vfs-libarchive, +}: buildKodiAddon rec { pname = "archive_tool"; namespace = "script.module.archive_tool"; diff --git a/pkgs/applications/video/kodi/addons/arrow/default.nix b/pkgs/applications/video/kodi/addons/arrow/default.nix index 2515ce7853fca6..16c736aab009ff 100644 --- a/pkgs/applications/video/kodi/addons/arrow/default.nix +++ b/pkgs/applications/video/kodi/addons/arrow/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, dateutil, typing_extensions }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + dateutil, + typing_extensions, +}: buildKodiAddon rec { pname = "arrow"; namespace = "script.module.arrow"; diff --git a/pkgs/applications/video/kodi/addons/arteplussept/default.nix b/pkgs/applications/video/kodi/addons/arteplussept/default.nix index 8311a506802137..056b5bb6a817b3 100644 --- a/pkgs/applications/video/kodi/addons/arteplussept/default.nix +++ b/pkgs/applications/video/kodi/addons/arteplussept/default.nix @@ -1,4 +1,13 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, dateutil, requests, xbmcswift2 }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + dateutil, + requests, + xbmcswift2, +}: buildKodiAddon rec { pname = "arteplussept"; diff --git a/pkgs/applications/video/kodi/addons/certifi/default.nix b/pkgs/applications/video/kodi/addons/certifi/default.nix index ecab49746a27e8..b626cb643a1009 100644 --- a/pkgs/applications/video/kodi/addons/certifi/default.nix +++ b/pkgs/applications/video/kodi/addons/certifi/default.nix @@ -1,4 +1,11 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, cacert }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + cacert, +}: buildKodiAddon rec { pname = "certifi"; namespace = "script.module.certifi"; diff --git a/pkgs/applications/video/kodi/addons/chardet/default.nix b/pkgs/applications/video/kodi/addons/chardet/default.nix index 8d385e717b8a40..1d02432a36308e 100644 --- a/pkgs/applications/video/kodi/addons/chardet/default.nix +++ b/pkgs/applications/video/kodi/addons/chardet/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "chardet"; namespace = "script.module.chardet"; diff --git a/pkgs/applications/video/kodi/addons/controller-topology-project/default.nix b/pkgs/applications/video/kodi/addons/controller-topology-project/default.nix index 5b55ab9d1282f9..e060ee1e03bfd0 100644 --- a/pkgs/applications/video/kodi/addons/controller-topology-project/default.nix +++ b/pkgs/applications/video/kodi/addons/controller-topology-project/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, toKodiAddon, addonDir }: +{ + lib, + stdenv, + fetchFromGitHub, + toKodiAddon, + addonDir, +}: let drv = stdenv.mkDerivation rec { pname = "controller-topology-project"; @@ -34,4 +40,4 @@ let }; }; in - toKodiAddon drv +toKodiAddon drv diff --git a/pkgs/applications/video/kodi/addons/dateutil/default.nix b/pkgs/applications/video/kodi/addons/dateutil/default.nix index b0fadcf8a86222..2443c057e8502e 100644 --- a/pkgs/applications/video/kodi/addons/dateutil/default.nix +++ b/pkgs/applications/video/kodi/addons/dateutil/default.nix @@ -1,4 +1,11 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, six }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + six, +}: buildKodiAddon rec { pname = "dateutil"; @@ -24,7 +31,10 @@ buildKodiAddon rec { meta = with lib; { homepage = "https://dateutil.readthedocs.io/en/stable/"; description = "Extensions to the standard Python datetime module"; - license = with licenses; [ asl20 bsd3 ]; + license = with licenses; [ + asl20 + bsd3 + ]; maintainers = teams.kodi.members; }; } diff --git a/pkgs/applications/video/kodi/addons/defusedxml/default.nix b/pkgs/applications/video/kodi/addons/defusedxml/default.nix index 1c6a844e0a30ae..2f93e2bbeb0aeb 100644 --- a/pkgs/applications/video/kodi/addons/defusedxml/default.nix +++ b/pkgs/applications/video/kodi/addons/defusedxml/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "defusedxml"; diff --git a/pkgs/applications/video/kodi/addons/formula1/default.nix b/pkgs/applications/video/kodi/addons/formula1/default.nix index 0d374dc65be1bb..9dc809c571c27f 100644 --- a/pkgs/applications/video/kodi/addons/formula1/default.nix +++ b/pkgs/applications/video/kodi/addons/formula1/default.nix @@ -1,4 +1,11 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, requests }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + requests, +}: buildKodiAddon rec { pname = "formula1"; diff --git a/pkgs/applications/video/kodi/addons/future/default.nix b/pkgs/applications/video/kodi/addons/future/default.nix index c96f28ab9037db..346be9f8d7f5d7 100644 --- a/pkgs/applications/video/kodi/addons/future/default.nix +++ b/pkgs/applications/video/kodi/addons/future/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "future"; diff --git a/pkgs/applications/video/kodi/addons/iagl/default.nix b/pkgs/applications/video/kodi/addons/iagl/default.nix index 90698a10cf9f68..ae8ff5dc19aa8e 100644 --- a/pkgs/applications/video/kodi/addons/iagl/default.nix +++ b/pkgs/applications/video/kodi/addons/iagl/default.nix @@ -1,4 +1,15 @@ -{ lib, buildKodiAddon, fetchFromGitHub, dateutil, requests, routing, vfs-libarchive, archive_tool, youtube, infotagger }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, + dateutil, + requests, + routing, + vfs-libarchive, + archive_tool, + youtube, + infotagger, +}: buildKodiAddon rec { pname = "iagl"; diff --git a/pkgs/applications/video/kodi/addons/idna/default.nix b/pkgs/applications/video/kodi/addons/idna/default.nix index 76a6e81b007285..81c0a42b0dded3 100644 --- a/pkgs/applications/video/kodi/addons/idna/default.nix +++ b/pkgs/applications/video/kodi/addons/idna/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "idna"; namespace = "script.module.idna"; diff --git a/pkgs/applications/video/kodi/addons/infotagger/default.nix b/pkgs/applications/video/kodi/addons/infotagger/default.nix index 7ac5e480710733..40b0399ca3b201 100644 --- a/pkgs/applications/video/kodi/addons/infotagger/default.nix +++ b/pkgs/applications/video/kodi/addons/infotagger/default.nix @@ -1,4 +1,9 @@ -{ lib, buildKodiAddon, fetchFromGitHub, addonUpdateScript }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, + addonUpdateScript, +}: buildKodiAddon rec { pname = "infotagger"; namespace = "script.module.infotagger"; diff --git a/pkgs/applications/video/kodi/addons/inputstream-adaptive/default.nix b/pkgs/applications/video/kodi/addons/inputstream-adaptive/default.nix index a5c7dadf5b509a..73e258f42a1bac 100644 --- a/pkgs/applications/video/kodi/addons/inputstream-adaptive/default.nix +++ b/pkgs/applications/video/kodi/addons/inputstream-adaptive/default.nix @@ -1,4 +1,17 @@ -{ stdenv, lib, rel, addonDir, buildKodiBinaryAddon, fetchFromGitHub, pugixml, glib, nspr, nss, gtest, rapidjson }: +{ + stdenv, + lib, + rel, + addonDir, + buildKodiBinaryAddon, + fetchFromGitHub, + pugixml, + glib, + nspr, + nss, + gtest, + rapidjson, +}: let bento4 = fetchFromGitHub { owner = "xbmc"; @@ -26,13 +39,25 @@ buildKodiBinaryAddon rec { extraNativeBuildInputs = [ gtest ]; - extraBuildInputs = [ pugixml rapidjson ]; + extraBuildInputs = [ + pugixml + rapidjson + ]; - extraRuntimeDependencies = [ glib nspr nss (lib.getLib stdenv.cc.cc) ]; + extraRuntimeDependencies = [ + glib + nspr + nss + (lib.getLib stdenv.cc.cc) + ]; - extraInstallPhase = let n = namespace; in '' - ${lib.optionalString stdenv.hostPlatform.isAarch64 "ln -s $out/lib/addons/${n}/libcdm_aarch64_loader.so $out/${addonDir}/${n}/libcdm_aarch64_loader.so"} - ''; + extraInstallPhase = + let + n = namespace; + in + '' + ${lib.optionalString stdenv.hostPlatform.isAarch64 "ln -s $out/lib/addons/${n}/libcdm_aarch64_loader.so $out/${addonDir}/${n}/libcdm_aarch64_loader.so"} + ''; meta = with lib; { homepage = "https://github.com/xbmc/inputstream.adaptive"; diff --git a/pkgs/applications/video/kodi/addons/inputstream-ffmpegdirect/default.nix b/pkgs/applications/video/kodi/addons/inputstream-ffmpegdirect/default.nix index ffb0a0cf83a765..e48f8e8be2093c 100644 --- a/pkgs/applications/video/kodi/addons/inputstream-ffmpegdirect/default.nix +++ b/pkgs/applications/video/kodi/addons/inputstream-ffmpegdirect/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, kodi, bzip2, zlib }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + kodi, + bzip2, + zlib, +}: buildKodiBinaryAddon rec { pname = "inputstream-ffmpegdirect"; @@ -12,7 +20,11 @@ buildKodiBinaryAddon rec { sha256 = "sha256-pPufkDPHq5EsvC6YTsRX9TjqjIczOL/6Vc5HGDIe9Gk="; }; - extraBuildInputs = [ bzip2 zlib kodi.ffmpeg ]; + extraBuildInputs = [ + bzip2 + zlib + kodi.ffmpeg + ]; meta = with lib; { homepage = "https://github.com/xbmc/inputstream.ffmpegdirect/"; diff --git a/pkgs/applications/video/kodi/addons/inputstream-rtmp/default.nix b/pkgs/applications/video/kodi/addons/inputstream-rtmp/default.nix index 960c50ce09e7d0..33e4bcb0262618 100644 --- a/pkgs/applications/video/kodi/addons/inputstream-rtmp/default.nix +++ b/pkgs/applications/video/kodi/addons/inputstream-rtmp/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, openssl, rtmpdump, zlib }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + openssl, + rtmpdump, + zlib, +}: buildKodiBinaryAddon rec { pname = "inputstream-rtmp"; @@ -12,7 +20,11 @@ buildKodiBinaryAddon rec { sha256 = "sha256-M6LFokWQRzBZ7inzRsMxyWzkV0XsGHh4d0CPhv1NCfI="; }; - extraBuildInputs = [ openssl rtmpdump zlib ]; + extraBuildInputs = [ + openssl + rtmpdump + zlib + ]; meta = with lib; { homepage = "https://github.com/xbmc/inputstream.rtmp/"; diff --git a/pkgs/applications/video/kodi/addons/inputstreamhelper/default.nix b/pkgs/applications/video/kodi/addons/inputstreamhelper/default.nix index deca0d57d7c51a..72af05fb8e1e0d 100644 --- a/pkgs/applications/video/kodi/addons/inputstreamhelper/default.nix +++ b/pkgs/applications/video/kodi/addons/inputstreamhelper/default.nix @@ -1,4 +1,11 @@ -{ lib, rel, buildKodiAddon, fetchzip, fetchpatch, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + fetchpatch, + addonUpdateScript, +}: buildKodiAddon rec { pname = "inputstreamhelper"; namespace = "script.module.inputstreamhelper"; diff --git a/pkgs/applications/video/kodi/addons/invidious/default.nix b/pkgs/applications/video/kodi/addons/invidious/default.nix index ca688ddc0f2e8f..d6a20068a6df1d 100644 --- a/pkgs/applications/video/kodi/addons/invidious/default.nix +++ b/pkgs/applications/video/kodi/addons/invidious/default.nix @@ -1,4 +1,14 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, infotagger, requests, inputstream-adaptive, inputstreamhelper }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + infotagger, + requests, + inputstream-adaptive, + inputstreamhelper, +}: buildKodiAddon rec { pname = "invidious"; diff --git a/pkgs/applications/video/kodi/addons/jellycon/default.nix b/pkgs/applications/video/kodi/addons/jellycon/default.nix index 960a8603e3612f..591202c1620695 100644 --- a/pkgs/applications/video/kodi/addons/jellycon/default.nix +++ b/pkgs/applications/video/kodi/addons/jellycon/default.nix @@ -1,4 +1,16 @@ -{ lib, addonDir, buildKodiAddon, fetchFromGitHub, kodi, requests, dateutil, six, kodi-six, signals, websocket }: +{ + lib, + addonDir, + buildKodiAddon, + fetchFromGitHub, + kodi, + requests, + dateutil, + six, + kodi-six, + signals, + websocket, +}: let python = kodi.pythonPackages.python.withPackages (p: with p; [ pyyaml ]); in diff --git a/pkgs/applications/video/kodi/addons/joystick/default.nix b/pkgs/applications/video/kodi/addons/joystick/default.nix index 47dbb0f5dfc0d8..073f7422ee3311 100644 --- a/pkgs/applications/video/kodi/addons/joystick/default.nix +++ b/pkgs/applications/video/kodi/addons/joystick/default.nix @@ -1,4 +1,11 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, tinyxml, udev }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + tinyxml, + udev, +}: buildKodiBinaryAddon rec { pname = namespace; namespace = "peripheral.joystick"; @@ -11,7 +18,10 @@ buildKodiBinaryAddon rec { sha256 = "sha256-xJh9Rj+PcxrgGomEsKnQcO/yZDQCnG6gNBwfK2JGuNA="; }; - extraBuildInputs = [ tinyxml udev ]; + extraBuildInputs = [ + tinyxml + udev + ]; meta = with lib; { description = "Binary addon for raw joystick input"; diff --git a/pkgs/applications/video/kodi/addons/keymap/default.nix b/pkgs/applications/video/kodi/addons/keymap/default.nix index 4254763d536119..abc3cd7c8095f8 100644 --- a/pkgs/applications/video/kodi/addons/keymap/default.nix +++ b/pkgs/applications/video/kodi/addons/keymap/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, defusedxml, kodi-six }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + defusedxml, + kodi-six, +}: buildKodiAddon rec { pname = "keymap"; diff --git a/pkgs/applications/video/kodi/addons/kodi-platform/default.nix b/pkgs/applications/video/kodi/addons/kodi-platform/default.nix index 6d458f7377d72c..caab2eb806b3ad 100644 --- a/pkgs/applications/video/kodi/addons/kodi-platform/default.nix +++ b/pkgs/applications/video/kodi/addons/kodi-platform/default.nix @@ -1,4 +1,11 @@ -{ stdenv, fetchFromGitHub, cmake, kodi, libcec_platform, tinyxml }: +{ + stdenv, + fetchFromGitHub, + cmake, + kodi, + libcec_platform, + tinyxml, +}: stdenv.mkDerivation rec { pname = "kodi-platform"; version = "17.1"; @@ -11,5 +18,9 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ kodi libcec_platform tinyxml ]; + buildInputs = [ + kodi + libcec_platform + tinyxml + ]; } diff --git a/pkgs/applications/video/kodi/addons/kodi-six/default.nix b/pkgs/applications/video/kodi/addons/kodi-six/default.nix index a9c7547aa37154..96f42525734323 100644 --- a/pkgs/applications/video/kodi/addons/kodi-six/default.nix +++ b/pkgs/applications/video/kodi/addons/kodi-six/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "kodi-six"; diff --git a/pkgs/applications/video/kodi/addons/libretro-2048/default.nix b/pkgs/applications/video/kodi/addons/libretro-2048/default.nix index 67644444d8912c..866fdc3e6da261 100644 --- a/pkgs/applications/video/kodi/addons/libretro-2048/default.nix +++ b/pkgs/applications/video/kodi/addons/libretro-2048/default.nix @@ -1,4 +1,10 @@ -{ lib, buildKodiBinaryAddon, fetchFromGitHub, libretro, twenty-fortyeight }: +{ + lib, + buildKodiBinaryAddon, + fetchFromGitHub, + libretro, + twenty-fortyeight, +}: buildKodiBinaryAddon rec { pname = "libretro-2048"; diff --git a/pkgs/applications/video/kodi/addons/libretro-fuse/default.nix b/pkgs/applications/video/kodi/addons/libretro-fuse/default.nix index 776341b6079694..0524dc485304fe 100644 --- a/pkgs/applications/video/kodi/addons/libretro-fuse/default.nix +++ b/pkgs/applications/video/kodi/addons/libretro-fuse/default.nix @@ -1,4 +1,10 @@ -{ lib, buildKodiBinaryAddon, fetchFromGitHub, libretro, fuse }: +{ + lib, + buildKodiBinaryAddon, + fetchFromGitHub, + libretro, + fuse, +}: buildKodiBinaryAddon rec { pname = "libretro-fuse"; diff --git a/pkgs/applications/video/kodi/addons/libretro-genplus/default.nix b/pkgs/applications/video/kodi/addons/libretro-genplus/default.nix index 3d58ddd64303c2..8bead49157ad98 100644 --- a/pkgs/applications/video/kodi/addons/libretro-genplus/default.nix +++ b/pkgs/applications/video/kodi/addons/libretro-genplus/default.nix @@ -1,4 +1,10 @@ -{ lib, buildKodiBinaryAddon, fetchFromGitHub, libretro, genesis-plus-gx }: +{ + lib, + buildKodiBinaryAddon, + fetchFromGitHub, + libretro, + genesis-plus-gx, +}: buildKodiBinaryAddon rec { pname = "kodi-libretro-genplus"; diff --git a/pkgs/applications/video/kodi/addons/libretro-mgba/default.nix b/pkgs/applications/video/kodi/addons/libretro-mgba/default.nix index 231c769fa7523c..ecca37db0d2a14 100644 --- a/pkgs/applications/video/kodi/addons/libretro-mgba/default.nix +++ b/pkgs/applications/video/kodi/addons/libretro-mgba/default.nix @@ -1,4 +1,10 @@ -{ lib, buildKodiBinaryAddon, fetchFromGitHub, libretro, mgba }: +{ + lib, + buildKodiBinaryAddon, + fetchFromGitHub, + libretro, + mgba, +}: buildKodiBinaryAddon rec { pname = "kodi-libretro-mgba"; diff --git a/pkgs/applications/video/kodi/addons/libretro-nestopia/default.nix b/pkgs/applications/video/kodi/addons/libretro-nestopia/default.nix index 7c6eda2b00436b..4a299720f0a07a 100644 --- a/pkgs/applications/video/kodi/addons/libretro-nestopia/default.nix +++ b/pkgs/applications/video/kodi/addons/libretro-nestopia/default.nix @@ -1,4 +1,11 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, libretro, nestopia }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + libretro, + nestopia, +}: buildKodiBinaryAddon rec { pname = "libretro-nestopia"; diff --git a/pkgs/applications/video/kodi/addons/libretro-snes9x/default.nix b/pkgs/applications/video/kodi/addons/libretro-snes9x/default.nix index 7b52988e80cff2..4e614b8bb61143 100644 --- a/pkgs/applications/video/kodi/addons/libretro-snes9x/default.nix +++ b/pkgs/applications/video/kodi/addons/libretro-snes9x/default.nix @@ -1,4 +1,10 @@ -{ lib, buildKodiBinaryAddon, fetchFromGitHub, libretro, snes9x }: +{ + lib, + buildKodiBinaryAddon, + fetchFromGitHub, + libretro, + snes9x, +}: buildKodiBinaryAddon rec { pname = "kodi-libretro-snes9x"; diff --git a/pkgs/applications/video/kodi/addons/libretro/default.nix b/pkgs/applications/video/kodi/addons/libretro/default.nix index 208f832d694436..f6ab8b81ed39d1 100644 --- a/pkgs/applications/video/kodi/addons/libretro/default.nix +++ b/pkgs/applications/video/kodi/addons/libretro/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, tinyxml }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + tinyxml, +}: buildKodiBinaryAddon rec { pname = "libretro"; diff --git a/pkgs/applications/video/kodi/addons/mediacccde/default.nix b/pkgs/applications/video/kodi/addons/mediacccde/default.nix index a0d334633fe1d7..b61c2f0f9841c4 100644 --- a/pkgs/applications/video/kodi/addons/mediacccde/default.nix +++ b/pkgs/applications/video/kodi/addons/mediacccde/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, requests, routing }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + requests, + routing, +}: buildKodiAddon rec { pname = "media.ccc.de"; diff --git a/pkgs/applications/video/kodi/addons/mediathekview/default.nix b/pkgs/applications/video/kodi/addons/mediathekview/default.nix index 890567d5d6d5f0..dec6c0736e277f 100644 --- a/pkgs/applications/video/kodi/addons/mediathekview/default.nix +++ b/pkgs/applications/video/kodi/addons/mediathekview/default.nix @@ -1,4 +1,9 @@ -{ lib, buildKodiAddon, fetchFromGitHub, myconnpy }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, + myconnpy, +}: buildKodiAddon rec { pname = "mediathekview"; diff --git a/pkgs/applications/video/kodi/addons/myconnpy/default.nix b/pkgs/applications/video/kodi/addons/myconnpy/default.nix index a162e844ed55de..dd2b1dd857e1ba 100644 --- a/pkgs/applications/video/kodi/addons/myconnpy/default.nix +++ b/pkgs/applications/video/kodi/addons/myconnpy/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "myconnpy"; namespace = "script.module.myconnpy"; diff --git a/pkgs/applications/video/kodi/addons/netflix/default.nix b/pkgs/applications/video/kodi/addons/netflix/default.nix index 3b3aa97d53432c..f40dc45da27eb7 100644 --- a/pkgs/applications/video/kodi/addons/netflix/default.nix +++ b/pkgs/applications/video/kodi/addons/netflix/default.nix @@ -1,4 +1,13 @@ -{ lib, buildKodiAddon, fetchFromGitHub, signals, inputstream-adaptive, inputstreamhelper, requests, myconnpy }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, + signals, + inputstream-adaptive, + inputstreamhelper, + requests, + myconnpy, +}: buildKodiAddon rec { pname = "netflix"; diff --git a/pkgs/applications/video/kodi/addons/orftvthek/default.nix b/pkgs/applications/video/kodi/addons/orftvthek/default.nix index 64b822c355107f..f1e202f7ced0c7 100644 --- a/pkgs/applications/video/kodi/addons/orftvthek/default.nix +++ b/pkgs/applications/video/kodi/addons/orftvthek/default.nix @@ -1,4 +1,11 @@ -{ lib, buildKodiAddon, fetchFromGitHub, inputstream-adaptive, inputstreamhelper, routing }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, + inputstream-adaptive, + inputstreamhelper, + routing, +}: buildKodiAddon rec { pname = "orftvthek"; diff --git a/pkgs/applications/video/kodi/addons/osmc-skin/default.nix b/pkgs/applications/video/kodi/addons/osmc-skin/default.nix index 7644a71d71bc92..0fddffde51f8a0 100644 --- a/pkgs/applications/video/kodi/addons/osmc-skin/default.nix +++ b/pkgs/applications/video/kodi/addons/osmc-skin/default.nix @@ -1,4 +1,8 @@ -{ lib, buildKodiAddon, fetchFromGitHub }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, +}: buildKodiAddon rec { pname = "osmc-skin"; namespace = "skin.osmc"; diff --git a/pkgs/applications/video/kodi/addons/pdfreader/default.nix b/pkgs/applications/video/kodi/addons/pdfreader/default.nix index 60a08a9cfbeae9..49783ffef23f9f 100644 --- a/pkgs/applications/video/kodi/addons/pdfreader/default.nix +++ b/pkgs/applications/video/kodi/addons/pdfreader/default.nix @@ -1,4 +1,8 @@ -{ lib, buildKodiAddon, fetchFromGitHub }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, +}: buildKodiAddon rec { pname = "pdfreader"; namespace = "plugin.image.pdf"; diff --git a/pkgs/applications/video/kodi/addons/plugin-cache/default.nix b/pkgs/applications/video/kodi/addons/plugin-cache/default.nix index c21f5e136e41e2..62a445df851387 100644 --- a/pkgs/applications/video/kodi/addons/plugin-cache/default.nix +++ b/pkgs/applications/video/kodi/addons/plugin-cache/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "plugin-cache"; diff --git a/pkgs/applications/video/kodi/addons/pvr-hdhomerun/default.nix b/pkgs/applications/video/kodi/addons/pvr-hdhomerun/default.nix index 4184126842ba0e..64cce5cd061a64 100644 --- a/pkgs/applications/video/kodi/addons/pvr-hdhomerun/default.nix +++ b/pkgs/applications/video/kodi/addons/pvr-hdhomerun/default.nix @@ -1,4 +1,11 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, jsoncpp, libhdhomerun }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + jsoncpp, + libhdhomerun, +}: buildKodiBinaryAddon rec { pname = "pvr-hdhomerun"; namespace = "pvr.hdhomerun"; @@ -11,7 +18,10 @@ buildKodiBinaryAddon rec { sha256 = "sha256-Hb8TcJxRUIKHbevAUgt5q6z26W3uX9NbVwYyvrLnf7U="; }; - extraBuildInputs = [ jsoncpp libhdhomerun ]; + extraBuildInputs = [ + jsoncpp + libhdhomerun + ]; meta = with lib; { homepage = "https://github.com/kodi-pvr/pvr.hdhomerun"; diff --git a/pkgs/applications/video/kodi/addons/pvr-hts/default.nix b/pkgs/applications/video/kodi/addons/pvr-hts/default.nix index 50e12c09c1c8bc..1fa72a866df613 100644 --- a/pkgs/applications/video/kodi/addons/pvr-hts/default.nix +++ b/pkgs/applications/video/kodi/addons/pvr-hts/default.nix @@ -1,4 +1,9 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, +}: buildKodiBinaryAddon rec { pname = "pvr-hts"; namespace = "pvr.hts"; diff --git a/pkgs/applications/video/kodi/addons/pvr-iptvsimple/default.nix b/pkgs/applications/video/kodi/addons/pvr-iptvsimple/default.nix index b976c15371f2f3..473b517456c1f2 100644 --- a/pkgs/applications/video/kodi/addons/pvr-iptvsimple/default.nix +++ b/pkgs/applications/video/kodi/addons/pvr-iptvsimple/default.nix @@ -1,6 +1,14 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub -, xz, pugixml, zlib -, inputstream-adaptive, inputstream-ffmpegdirect, inputstream-rtmp +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + xz, + pugixml, + zlib, + inputstream-adaptive, + inputstream-ffmpegdirect, + inputstream-rtmp, }: buildKodiBinaryAddon rec { diff --git a/pkgs/applications/video/kodi/addons/pvr-vdr-vnsi/default.nix b/pkgs/applications/video/kodi/addons/pvr-vdr-vnsi/default.nix index 85729e1290435e..91a8095de7bcaf 100644 --- a/pkgs/applications/video/kodi/addons/pvr-vdr-vnsi/default.nix +++ b/pkgs/applications/video/kodi/addons/pvr-vdr-vnsi/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, libGL }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + libGL, +}: buildKodiBinaryAddon rec { pname = "pvr-vdr-vnsi"; namespace = "pvr.vdr.vnsi"; diff --git a/pkgs/applications/video/kodi/addons/radioparadise/default.nix b/pkgs/applications/video/kodi/addons/radioparadise/default.nix index 17f9c73b8e9358..545cb8b8072b3f 100644 --- a/pkgs/applications/video/kodi/addons/radioparadise/default.nix +++ b/pkgs/applications/video/kodi/addons/radioparadise/default.nix @@ -1,4 +1,11 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, requests }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + requests, +}: buildKodiAddon rec { pname = "radioparadise"; diff --git a/pkgs/applications/video/kodi/addons/raiplay/default.nix b/pkgs/applications/video/kodi/addons/raiplay/default.nix index ab5bcfedccfdb6..084bc4e596e373 100644 --- a/pkgs/applications/video/kodi/addons/raiplay/default.nix +++ b/pkgs/applications/video/kodi/addons/raiplay/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, inputstreamhelper, plugin-cache }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + inputstreamhelper, + plugin-cache, +}: buildKodiAddon rec { pname = "raiplay"; diff --git a/pkgs/applications/video/kodi/addons/requests-cache/default.nix b/pkgs/applications/video/kodi/addons/requests-cache/default.nix index 3a71019d9ccbdf..b809576e9ffc3d 100644 --- a/pkgs/applications/video/kodi/addons/requests-cache/default.nix +++ b/pkgs/applications/video/kodi/addons/requests-cache/default.nix @@ -1,4 +1,11 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, requests }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + requests, +}: buildKodiAddon rec { pname = "requests-cache"; namespace = "script.module.requests-cache"; diff --git a/pkgs/applications/video/kodi/addons/requests/default.nix b/pkgs/applications/video/kodi/addons/requests/default.nix index 4950d63608eb39..258e1791a3481f 100644 --- a/pkgs/applications/video/kodi/addons/requests/default.nix +++ b/pkgs/applications/video/kodi/addons/requests/default.nix @@ -1,4 +1,14 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, certifi, chardet, idna, urllib3 }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + certifi, + chardet, + idna, + urllib3, +}: buildKodiAddon rec { pname = "requests"; namespace = "script.module.requests"; diff --git a/pkgs/applications/video/kodi/addons/routing/default.nix b/pkgs/applications/video/kodi/addons/routing/default.nix index 211b87242363e1..08131bf4f89114 100644 --- a/pkgs/applications/video/kodi/addons/routing/default.nix +++ b/pkgs/applications/video/kodi/addons/routing/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "routing"; namespace = "script.module.routing"; diff --git a/pkgs/applications/video/kodi/addons/sendtokodi/default.nix b/pkgs/applications/video/kodi/addons/sendtokodi/default.nix index 792f585673dd00..dba58914feb194 100644 --- a/pkgs/applications/video/kodi/addons/sendtokodi/default.nix +++ b/pkgs/applications/video/kodi/addons/sendtokodi/default.nix @@ -1,4 +1,10 @@ -{ lib, buildKodiAddon, fetchFromGitHub, kodi, inputstreamhelper }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, + kodi, + inputstreamhelper, +}: buildKodiAddon rec { pname = "sendtokodi"; diff --git a/pkgs/applications/video/kodi/addons/signals/default.nix b/pkgs/applications/video/kodi/addons/signals/default.nix index 9f7496f3c4ca8a..8016c67366fe7b 100644 --- a/pkgs/applications/video/kodi/addons/signals/default.nix +++ b/pkgs/applications/video/kodi/addons/signals/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "signals"; namespace = "script.module.addon.signals"; @@ -9,7 +15,7 @@ buildKodiAddon rec { sha256 = "sha256-WsLR7iUh5F+LXMISBpWx71dLAtg/AMYF6BsiyKZakuE="; }; - passthru= { + passthru = { pythonPath = "lib"; updateScript = addonUpdateScript { attrPath = "kodi.packages.signals"; diff --git a/pkgs/applications/video/kodi/addons/simplecache/default.nix b/pkgs/applications/video/kodi/addons/simplecache/default.nix index 35c2cc5a1a3360..05f5da9f984838 100644 --- a/pkgs/applications/video/kodi/addons/simplecache/default.nix +++ b/pkgs/applications/video/kodi/addons/simplecache/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "simplecache"; diff --git a/pkgs/applications/video/kodi/addons/simplejson/default.nix b/pkgs/applications/video/kodi/addons/simplejson/default.nix index 2889e38e960f16..e54716d41257dc 100644 --- a/pkgs/applications/video/kodi/addons/simplejson/default.nix +++ b/pkgs/applications/video/kodi/addons/simplejson/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "simplejson"; diff --git a/pkgs/applications/video/kodi/addons/six/default.nix b/pkgs/applications/video/kodi/addons/six/default.nix index 80bbefe39a1135..0f07ec3cae79a8 100644 --- a/pkgs/applications/video/kodi/addons/six/default.nix +++ b/pkgs/applications/video/kodi/addons/six/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "six"; diff --git a/pkgs/applications/video/kodi/addons/skyvideoitalia/default.nix b/pkgs/applications/video/kodi/addons/skyvideoitalia/default.nix index c791391578c701..f2cad94df53bba 100644 --- a/pkgs/applications/video/kodi/addons/skyvideoitalia/default.nix +++ b/pkgs/applications/video/kodi/addons/skyvideoitalia/default.nix @@ -1,4 +1,13 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, requests, inputstreamhelper, simplecache }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + requests, + inputstreamhelper, + simplecache, +}: buildKodiAddon rec { pname = "skyvideoitalia"; diff --git a/pkgs/applications/video/kodi/addons/somafm/default.nix b/pkgs/applications/video/kodi/addons/somafm/default.nix index e2d5ca38bf4431..88a0a205eb376c 100644 --- a/pkgs/applications/video/kodi/addons/somafm/default.nix +++ b/pkgs/applications/video/kodi/addons/somafm/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "somafm"; diff --git a/pkgs/applications/video/kodi/addons/sponsorblock/default.nix b/pkgs/applications/video/kodi/addons/sponsorblock/default.nix index a0c0b04ec82e34..fb9e9cdd6e6faa 100644 --- a/pkgs/applications/video/kodi/addons/sponsorblock/default.nix +++ b/pkgs/applications/video/kodi/addons/sponsorblock/default.nix @@ -1,4 +1,10 @@ -{ lib, buildKodiAddon, fetchFromGitHub, six, requests }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, + six, + requests, +}: buildKodiAddon rec { pname = "sponsorblock"; namespace = "script.service.sponsorblock"; diff --git a/pkgs/applications/video/kodi/addons/steam-controller/default.nix b/pkgs/applications/video/kodi/addons/steam-controller/default.nix index 387f096686587b..7d1c94fbc84344 100644 --- a/pkgs/applications/video/kodi/addons/steam-controller/default.nix +++ b/pkgs/applications/video/kodi/addons/steam-controller/default.nix @@ -1,4 +1,9 @@ -{ lib, buildKodiBinaryAddon, fetchFromGitHub, libusb1 }: +{ + lib, + buildKodiBinaryAddon, + fetchFromGitHub, + libusb1, +}: buildKodiBinaryAddon rec { pname = namespace; namespace = "peripheral.steamcontroller"; diff --git a/pkgs/applications/video/kodi/addons/steam-launcher/default.nix b/pkgs/applications/video/kodi/addons/steam-launcher/default.nix index ef6b866e7e3378..678e2757d6fa65 100644 --- a/pkgs/applications/video/kodi/addons/steam-launcher/default.nix +++ b/pkgs/applications/video/kodi/addons/steam-launcher/default.nix @@ -1,4 +1,13 @@ -{ lib, buildKodiAddon, fetchFromGitHub, steam, which, xdotool, dos2unix, wmctrl }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, + steam, + which, + xdotool, + dos2unix, + wmctrl, +}: buildKodiAddon { pname = "steam-launcher"; namespace = "script.steam.launcher"; @@ -11,7 +20,11 @@ buildKodiAddon { sha256 = "sha256-arBMMOoHQuHRcJ7eXD1jvA45Svei7c0srcBZkdAzqY0="; }; - propagatedBuildInputs = [ steam which xdotool ]; + propagatedBuildInputs = [ + steam + which + xdotool + ]; postInstall = '' substituteInPlace $out/share/kodi/addons/script.steam.launcher/resources/main.py \ diff --git a/pkgs/applications/video/kodi/addons/steam-library/default.nix b/pkgs/applications/video/kodi/addons/steam-library/default.nix index cf1ad1d8653dd2..e4434813c37c89 100644 --- a/pkgs/applications/video/kodi/addons/steam-library/default.nix +++ b/pkgs/applications/video/kodi/addons/steam-library/default.nix @@ -1,4 +1,11 @@ -{ lib, buildKodiAddon, fetchFromGitHub, requests, requests-cache, routing }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, + requests, + requests-cache, + routing, +}: buildKodiAddon rec { pname = "steam-library"; diff --git a/pkgs/applications/video/kodi/addons/svtplay/default.nix b/pkgs/applications/video/kodi/addons/svtplay/default.nix index 8c12ac47ca3fca..c301234682a4e1 100644 --- a/pkgs/applications/video/kodi/addons/svtplay/default.nix +++ b/pkgs/applications/video/kodi/addons/svtplay/default.nix @@ -1,4 +1,8 @@ -{ lib, buildKodiAddon, fetchFromGitHub }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, +}: buildKodiAddon rec { pname = "svtplay"; namespace = "plugin.video.svtplay"; diff --git a/pkgs/applications/video/kodi/addons/trakt-module/default.nix b/pkgs/applications/video/kodi/addons/trakt-module/default.nix index 37816f89e36309..45456d182d18e6 100644 --- a/pkgs/applications/video/kodi/addons/trakt-module/default.nix +++ b/pkgs/applications/video/kodi/addons/trakt-module/default.nix @@ -1,4 +1,13 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, requests, six, arrow }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + requests, + six, + arrow, +}: buildKodiAddon rec { pname = "trakt-module"; namespace = "script.module.trakt"; diff --git a/pkgs/applications/video/kodi/addons/trakt/default.nix b/pkgs/applications/video/kodi/addons/trakt/default.nix index bf360072becc44..11ac06c60d566e 100644 --- a/pkgs/applications/video/kodi/addons/trakt/default.nix +++ b/pkgs/applications/video/kodi/addons/trakt/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, trakt-module, dateutil }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + trakt-module, + dateutil, +}: buildKodiAddon rec { pname = "trakt"; namespace = "script.trakt"; diff --git a/pkgs/applications/video/kodi/addons/typing_extensions/default.nix b/pkgs/applications/video/kodi/addons/typing_extensions/default.nix index d2fc31c99bcd20..af7f94a82aec44 100644 --- a/pkgs/applications/video/kodi/addons/typing_extensions/default.nix +++ b/pkgs/applications/video/kodi/addons/typing_extensions/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "typing_extensions"; namespace = "script.module.typing_extensions"; diff --git a/pkgs/applications/video/kodi/addons/upnext/default.nix b/pkgs/applications/video/kodi/addons/upnext/default.nix index dccfce4c3f0f6d..051cd4788f1e6e 100644 --- a/pkgs/applications/video/kodi/addons/upnext/default.nix +++ b/pkgs/applications/video/kodi/addons/upnext/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "upnext"; diff --git a/pkgs/applications/video/kodi/addons/urllib3/default.nix b/pkgs/applications/video/kodi/addons/urllib3/default.nix index 9cfc54797e875a..72ee3d7fd29b83 100644 --- a/pkgs/applications/video/kodi/addons/urllib3/default.nix +++ b/pkgs/applications/video/kodi/addons/urllib3/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, +}: buildKodiAddon rec { pname = "urllib3"; diff --git a/pkgs/applications/video/kodi/addons/vfs-libarchive/default.nix b/pkgs/applications/video/kodi/addons/vfs-libarchive/default.nix index 674495f9d84866..752908d159ca19 100644 --- a/pkgs/applications/video/kodi/addons/vfs-libarchive/default.nix +++ b/pkgs/applications/video/kodi/addons/vfs-libarchive/default.nix @@ -1,4 +1,16 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, libarchive, xz, bzip2, zlib, lz4, lzo, openssl }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + libarchive, + xz, + bzip2, + zlib, + lz4, + lzo, + openssl, +}: buildKodiBinaryAddon rec { pname = namespace; namespace = "vfs.libarchive"; @@ -11,7 +23,15 @@ buildKodiBinaryAddon rec { sha256 = "sha256-D0eLH+G+qF5xLBBX/FdJC+gKNQpqSb7LjRmi/99rPNg="; }; - extraBuildInputs = [ libarchive xz bzip2 zlib lz4 lzo openssl ]; + extraBuildInputs = [ + libarchive + xz + bzip2 + zlib + lz4 + lzo + openssl + ]; meta = with lib; { description = "LibArchive Virtual Filesystem add-on for Kodi"; diff --git a/pkgs/applications/video/kodi/addons/vfs-rar/default.nix b/pkgs/applications/video/kodi/addons/vfs-rar/default.nix index 259295be7ca799..298abe38e57f1d 100644 --- a/pkgs/applications/video/kodi/addons/vfs-rar/default.nix +++ b/pkgs/applications/video/kodi/addons/vfs-rar/default.nix @@ -1,4 +1,10 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, tinyxml }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + tinyxml, +}: buildKodiBinaryAddon rec { pname = namespace; namespace = "vfs.rar"; diff --git a/pkgs/applications/video/kodi/addons/vfs-sftp/default.nix b/pkgs/applications/video/kodi/addons/vfs-sftp/default.nix index b8e2213fec3a7b..5314cf606c4368 100644 --- a/pkgs/applications/video/kodi/addons/vfs-sftp/default.nix +++ b/pkgs/applications/video/kodi/addons/vfs-sftp/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, openssl, libssh, zlib }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + openssl, + libssh, + zlib, +}: buildKodiBinaryAddon rec { pname = namespace; namespace = "vfs.sftp"; @@ -11,7 +19,11 @@ buildKodiBinaryAddon rec { sha256 = "sha256-Dv/C8PHaSx13JoGp77rQPtp5G5EH5tqKqzjwZZA7+80="; }; - extraBuildInputs = [ openssl libssh zlib ]; + extraBuildInputs = [ + openssl + libssh + zlib + ]; meta = with lib; { description = "SFTP Virtual Filesystem add-on for Kodi"; diff --git a/pkgs/applications/video/kodi/addons/visualization-fishbmc/default.nix b/pkgs/applications/video/kodi/addons/visualization-fishbmc/default.nix index adb37bf770f649..7a54d749e3fe53 100644 --- a/pkgs/applications/video/kodi/addons/visualization-fishbmc/default.nix +++ b/pkgs/applications/video/kodi/addons/visualization-fishbmc/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, pkg-config, glm, libGL }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + pkg-config, + glm, + libGL, +}: buildKodiBinaryAddon rec { pname = "visualization-fishbmc"; @@ -12,7 +20,10 @@ buildKodiBinaryAddon rec { hash = "sha256-MgeSIKAy0N2NMGsU/15tKtDb34CROjcMaKjGyySl9Z0="; }; - extraBuildInputs = [ pkg-config libGL ]; + extraBuildInputs = [ + pkg-config + libGL + ]; propagatedBuildInputs = [ glm ]; meta = with lib; { diff --git a/pkgs/applications/video/kodi/addons/visualization-goom/default.nix b/pkgs/applications/video/kodi/addons/visualization-goom/default.nix index 34eb4c65606ac3..da5ee17c0ee50c 100644 --- a/pkgs/applications/video/kodi/addons/visualization-goom/default.nix +++ b/pkgs/applications/video/kodi/addons/visualization-goom/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, pkg-config, glm, libGL }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + pkg-config, + glm, + libGL, +}: buildKodiBinaryAddon rec { pname = "visualization-goom"; @@ -12,7 +20,10 @@ buildKodiBinaryAddon rec { hash = "sha256-TxXqJQdPT1+3DwAJv0F2Hfksh+ZV4QjfOnp4/k53GpQ="; }; - extraBuildInputs = [ pkg-config libGL ]; + extraBuildInputs = [ + pkg-config + libGL + ]; propagatedBuildInputs = [ glm ]; meta = with lib; { diff --git a/pkgs/applications/video/kodi/addons/visualization-matrix/default.nix b/pkgs/applications/video/kodi/addons/visualization-matrix/default.nix index 0839982ebb66a3..2839edcec79900 100644 --- a/pkgs/applications/video/kodi/addons/visualization-matrix/default.nix +++ b/pkgs/applications/video/kodi/addons/visualization-matrix/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, pkg-config, glm, libGL }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + pkg-config, + glm, + libGL, +}: buildKodiBinaryAddon rec { pname = "visualization-matrix"; @@ -12,7 +20,10 @@ buildKodiBinaryAddon rec { hash = "sha256-tojzPqt6VMccveqnhkl0yXS+/fLdxotmQO3jdtYlkFk="; }; - extraBuildInputs = [ pkg-config libGL ]; + extraBuildInputs = [ + pkg-config + libGL + ]; propagatedBuildInputs = [ glm ]; meta = with lib; { diff --git a/pkgs/applications/video/kodi/addons/visualization-pictureit/default.nix b/pkgs/applications/video/kodi/addons/visualization-pictureit/default.nix index 121850542a9112..df53b1e5489de5 100644 --- a/pkgs/applications/video/kodi/addons/visualization-pictureit/default.nix +++ b/pkgs/applications/video/kodi/addons/visualization-pictureit/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, pkg-config, glm, libGL }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + pkg-config, + glm, + libGL, +}: buildKodiBinaryAddon rec { pname = "visualization-pictureit"; @@ -12,7 +20,10 @@ buildKodiBinaryAddon rec { hash = "sha256-mQDPjpsxStU01H2XJKnX183KAHG+O1CH8JOmApMmwMc="; }; - extraBuildInputs = [ pkg-config libGL ]; + extraBuildInputs = [ + pkg-config + libGL + ]; propagatedBuildInputs = [ glm ]; meta = with lib; { diff --git a/pkgs/applications/video/kodi/addons/visualization-shadertoy/default.nix b/pkgs/applications/video/kodi/addons/visualization-shadertoy/default.nix index 2b0b1b5b6eee56..399674ee40fa77 100644 --- a/pkgs/applications/video/kodi/addons/visualization-shadertoy/default.nix +++ b/pkgs/applications/video/kodi/addons/visualization-shadertoy/default.nix @@ -1,4 +1,13 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, pkg-config, glm, libGL, jsoncpp }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + pkg-config, + glm, + libGL, + jsoncpp, +}: buildKodiBinaryAddon rec { pname = "visualization-shadertoy"; @@ -12,7 +21,11 @@ buildKodiBinaryAddon rec { hash = "sha256-PaHbEcB4gCC8gUzc7T49msI8f0xa2iXqSaYW/eqD8yw="; }; - extraBuildInputs = [ pkg-config libGL jsoncpp ]; + extraBuildInputs = [ + pkg-config + libGL + jsoncpp + ]; propagatedBuildInputs = [ glm ]; meta = with lib; { diff --git a/pkgs/applications/video/kodi/addons/visualization-spectrum/default.nix b/pkgs/applications/video/kodi/addons/visualization-spectrum/default.nix index e4d44dd12beded..19f9c2f0e6bdb9 100644 --- a/pkgs/applications/video/kodi/addons/visualization-spectrum/default.nix +++ b/pkgs/applications/video/kodi/addons/visualization-spectrum/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, pkg-config, glm, libGL }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + pkg-config, + glm, + libGL, +}: buildKodiBinaryAddon rec { pname = "visualization-spectrum"; @@ -12,7 +20,10 @@ buildKodiBinaryAddon rec { hash = "sha256-rl6eydHv0g646H7478UQboVp/OrKExQYJOiaVDeDRhE="; }; - extraBuildInputs = [ pkg-config libGL ]; + extraBuildInputs = [ + pkg-config + libGL + ]; propagatedBuildInputs = [ glm ]; meta = with lib; { diff --git a/pkgs/applications/video/kodi/addons/visualization-starburst/default.nix b/pkgs/applications/video/kodi/addons/visualization-starburst/default.nix index 5774c707397e63..027f16f8e42499 100644 --- a/pkgs/applications/video/kodi/addons/visualization-starburst/default.nix +++ b/pkgs/applications/video/kodi/addons/visualization-starburst/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, pkg-config, glm, libGL }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + pkg-config, + glm, + libGL, +}: buildKodiBinaryAddon rec { pname = "visualization-starburst"; @@ -12,7 +20,10 @@ buildKodiBinaryAddon rec { hash = "sha256-FTGyQqzRywKjywtckkP56Fc8KwF07A8WUAe0LackxSM="; }; - extraBuildInputs = [ pkg-config libGL ]; + extraBuildInputs = [ + pkg-config + libGL + ]; propagatedBuildInputs = [ glm ]; meta = with lib; { diff --git a/pkgs/applications/video/kodi/addons/visualization-waveform/default.nix b/pkgs/applications/video/kodi/addons/visualization-waveform/default.nix index 20acfad234ac3e..ccb3735425ae05 100644 --- a/pkgs/applications/video/kodi/addons/visualization-waveform/default.nix +++ b/pkgs/applications/video/kodi/addons/visualization-waveform/default.nix @@ -1,4 +1,12 @@ -{ lib, rel, buildKodiBinaryAddon, fetchFromGitHub, pkg-config, glm, libGL }: +{ + lib, + rel, + buildKodiBinaryAddon, + fetchFromGitHub, + pkg-config, + glm, + libGL, +}: buildKodiBinaryAddon rec { pname = "visualization-waveform"; @@ -12,7 +20,10 @@ buildKodiBinaryAddon rec { hash = "sha256-e1SIpMmfnS92X4f114MKch4o9Ke80aIzw6OQPrEb8d0="; }; - extraBuildInputs = [ pkg-config libGL ]; + extraBuildInputs = [ + pkg-config + libGL + ]; propagatedBuildInputs = [ glm ]; meta = with lib; { diff --git a/pkgs/applications/video/kodi/addons/websocket/default.nix b/pkgs/applications/video/kodi/addons/websocket/default.nix index 544f86a8bbbd92..d8a4cd381a219d 100644 --- a/pkgs/applications/video/kodi/addons/websocket/default.nix +++ b/pkgs/applications/video/kodi/addons/websocket/default.nix @@ -1,4 +1,11 @@ -{ lib, rel, buildKodiAddon, fetchzip, addonUpdateScript, six }: +{ + lib, + rel, + buildKodiAddon, + fetchzip, + addonUpdateScript, + six, +}: buildKodiAddon rec { pname = "websocket"; diff --git a/pkgs/applications/video/kodi/addons/xbmcswift2/default.nix b/pkgs/applications/video/kodi/addons/xbmcswift2/default.nix index 7d435521f06cae..bb9e68130c7adb 100644 --- a/pkgs/applications/video/kodi/addons/xbmcswift2/default.nix +++ b/pkgs/applications/video/kodi/addons/xbmcswift2/default.nix @@ -1,4 +1,8 @@ -{ lib, buildKodiAddon, fetchFromGitHub }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, +}: buildKodiAddon rec { pname = "xbmcswift2"; diff --git a/pkgs/applications/video/kodi/addons/youtube/default.nix b/pkgs/applications/video/kodi/addons/youtube/default.nix index f9e37e80d509cb..0da50ae480e875 100644 --- a/pkgs/applications/video/kodi/addons/youtube/default.nix +++ b/pkgs/applications/video/kodi/addons/youtube/default.nix @@ -1,4 +1,11 @@ -{ lib, buildKodiAddon, fetchFromGitHub, requests, inputstream-adaptive, inputstreamhelper }: +{ + lib, + buildKodiAddon, + fetchFromGitHub, + requests, + inputstream-adaptive, + inputstreamhelper, +}: buildKodiAddon rec { pname = "youtube"; diff --git a/pkgs/applications/video/kodi/build-kodi-addon.nix b/pkgs/applications/video/kodi/build-kodi-addon.nix index 8f9c05d8fa12ec..5fd1a1769f7426 100644 --- a/pkgs/applications/video/kodi/build-kodi-addon.nix +++ b/pkgs/applications/video/kodi/build-kodi-addon.nix @@ -1,25 +1,36 @@ -{ stdenv, toKodiAddon, addonDir }: -{ name ? "${attrs.pname}-${attrs.version}" -, namespace -, sourceDir ? "" -, ... } @ attrs: -toKodiAddon (stdenv.mkDerivation ({ - name = "kodi-" + name; +{ + stdenv, + toKodiAddon, + addonDir, +}: +{ + name ? "${attrs.pname}-${attrs.version}", + namespace, + sourceDir ? "", + ... +}@attrs: +toKodiAddon ( + stdenv.mkDerivation ( + { + name = "kodi-" + name; - dontStrip = true; + dontStrip = true; - extraRuntimeDependencies = [ ]; + extraRuntimeDependencies = [ ]; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - cd ./$sourceDir - d=$out${addonDir}/${namespace} - mkdir -p $d - sauce="." - [ -d ${namespace} ] && sauce=${namespace} - cp -R "$sauce/"* $d + cd ./$sourceDir + d=$out${addonDir}/${namespace} + mkdir -p $d + sauce="." + [ -d ${namespace} ] && sauce=${namespace} + cp -R "$sauce/"* $d - runHook postInstall - ''; -} // attrs)) + runHook postInstall + ''; + } + // attrs + ) +) diff --git a/pkgs/applications/video/kodi/build-kodi-binary-addon.nix b/pkgs/applications/video/kodi/build-kodi-binary-addon.nix index d1eb38cd0bd4c9..7fbd0f8c3d0765 100644 --- a/pkgs/applications/video/kodi/build-kodi-binary-addon.nix +++ b/pkgs/applications/video/kodi/build-kodi-binary-addon.nix @@ -1,40 +1,64 @@ -{ stdenv, toKodiAddon, addonDir, cmake, kodi, kodi-platform, libcec_platform }: -{ name ? "${attrs.pname}-${attrs.version}" -, namespace -, version -, extraNativeBuildInputs ? [] -, extraBuildInputs ? [] -, extraRuntimeDependencies ? [] -, extraCMakeFlags ? [] -, extraInstallPhase ? "", ... } @ attrs: -toKodiAddon (stdenv.mkDerivation ({ - name = "kodi-" + name; - - dontStrip = true; - - nativeBuildInputs = [ cmake ] ++ extraNativeBuildInputs; - buildInputs = [ kodi kodi-platform libcec_platform ] ++ extraBuildInputs; - - inherit extraRuntimeDependencies; - - # disables check ensuring install prefix is that of kodi - cmakeFlags = [ - "-DOVERRIDE_PATHS=1" - ] ++ extraCMakeFlags; - - # kodi checks for addon .so libs existance in the addon folder (share/...) - # and the non-wrapped kodi lib/... folder before even trying to dlopen - # them. Symlinking .so, as setting LD_LIBRARY_PATH is of no use - installPhase = let n = namespace; in '' - runHook preInstall - - make install - - [[ -f $out/lib/addons/${n}/${n}.so ]] && ln -s $out/lib/addons/${n}/${n}.so $out${addonDir}/${n}/${n}.so || true - [[ -f $out/lib/addons/${n}/${n}.so.${version} ]] && ln -s $out/lib/addons/${n}/${n}.so.${version} $out${addonDir}/${n}/${n}.so.${version} || true - - ${extraInstallPhase} - - runHook postInstall - ''; -} // attrs)) +{ + stdenv, + toKodiAddon, + addonDir, + cmake, + kodi, + kodi-platform, + libcec_platform, +}: +{ + name ? "${attrs.pname}-${attrs.version}", + namespace, + version, + extraNativeBuildInputs ? [ ], + extraBuildInputs ? [ ], + extraRuntimeDependencies ? [ ], + extraCMakeFlags ? [ ], + extraInstallPhase ? "", + ... +}@attrs: +toKodiAddon ( + stdenv.mkDerivation ( + { + name = "kodi-" + name; + + dontStrip = true; + + nativeBuildInputs = [ cmake ] ++ extraNativeBuildInputs; + buildInputs = [ + kodi + kodi-platform + libcec_platform + ] ++ extraBuildInputs; + + inherit extraRuntimeDependencies; + + # disables check ensuring install prefix is that of kodi + cmakeFlags = [ + "-DOVERRIDE_PATHS=1" + ] ++ extraCMakeFlags; + + # kodi checks for addon .so libs existance in the addon folder (share/...) + # and the non-wrapped kodi lib/... folder before even trying to dlopen + # them. Symlinking .so, as setting LD_LIBRARY_PATH is of no use + installPhase = + let + n = namespace; + in + '' + runHook preInstall + + make install + + [[ -f $out/lib/addons/${n}/${n}.so ]] && ln -s $out/lib/addons/${n}/${n}.so $out${addonDir}/${n}/${n}.so || true + [[ -f $out/lib/addons/${n}/${n}.so.${version} ]] && ln -s $out/lib/addons/${n}/${n}.so.${version} $out${addonDir}/${n}/${n}.so.${version} || true + + ${extraInstallPhase} + + runHook postInstall + ''; + } + // attrs + ) +) diff --git a/pkgs/applications/video/kodi/default.nix b/pkgs/applications/video/kodi/default.nix index b028558a61da7b..2c74fde9572e2d 100644 --- a/pkgs/applications/video/kodi/default.nix +++ b/pkgs/applications/video/kodi/default.nix @@ -1,18 +1,21 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: let unwrapped = callPackage ./unwrapped.nix (removeAttrs args [ "callPackage" ]); in - unwrapped.overrideAttrs (oldAttrs: { - passthru = - let - finalKodi = oldAttrs.passthru.kodi; - kodiPackages = callPackage ../../../top-level/kodi-packages.nix { kodi = finalKodi; }; - in - oldAttrs.passthru // { - packages = kodiPackages; - withPackages = func: callPackage ./wrapper.nix { - kodi = finalKodi; - addons = kodiPackages.requiredKodiAddons (func kodiPackages); - }; +unwrapped.overrideAttrs (oldAttrs: { + passthru = + let + finalKodi = oldAttrs.passthru.kodi; + kodiPackages = callPackage ../../../top-level/kodi-packages.nix { kodi = finalKodi; }; + in + oldAttrs.passthru + // { + packages = kodiPackages; + withPackages = + func: + callPackage ./wrapper.nix { + kodi = finalKodi; + addons = kodiPackages.requiredKodiAddons (func kodiPackages); }; - }) + }; +}) diff --git a/pkgs/applications/video/kodi/wrapper.nix b/pkgs/applications/video/kodi/wrapper.nix index 52b7679a325ea1..7e7d36a7ba69c9 100644 --- a/pkgs/applications/video/kodi/wrapper.nix +++ b/pkgs/applications/video/kodi/wrapper.nix @@ -1,10 +1,22 @@ -{ lib, makeWrapper, buildEnv, kodi, addons, callPackage }: +{ + lib, + makeWrapper, + buildEnv, + kodi, + addons, + callPackage, +}: let kodiPackages = callPackage ../../../top-level/kodi-packages.nix { inherit kodi; }; # linux distros are supposed to provide pillow and pycryptodome - requiredPythonPath = with kodi.pythonPackages; makePythonPath ([ pillow pycryptodome ]); + requiredPythonPath = + with kodi.pythonPackages; + makePythonPath ([ + pillow + pycryptodome + ]); # each kodi addon can potentially export a python module which should be included in PYTHONPATH # see any addon which supplies `passthru.pythonPath` and the corresponding entry in the addons `addon.xml` @@ -13,7 +25,9 @@ let let addonsWithPythonPath = lib.filter (addon: addon ? pythonPath) addons; in - lib.concatMapStringsSep ":" (addon: "${addon}${kodiPackages.addonDir}/${addon.namespace}/${addon.pythonPath}") addonsWithPythonPath; + lib.concatMapStringsSep ":" ( + addon: "${addon}${kodiPackages.addonDir}/${addon.namespace}/${addon.pythonPath}" + ) addonsWithPythonPath; in buildEnv { @@ -31,9 +45,9 @@ buildEnv { makeWrapper ${kodi}/bin/$exe $out/bin/$exe \ --prefix PYTHONPATH : ${requiredPythonPath}:${additionalPythonPath} \ --prefix KODI_HOME : $out/share/kodi \ - --prefix LD_LIBRARY_PATH ":" "${lib.makeLibraryPath - (lib.concatMap - (plugin: plugin.extraRuntimeDependencies or []) addons)}" + --prefix LD_LIBRARY_PATH ":" "${ + lib.makeLibraryPath (lib.concatMap (plugin: plugin.extraRuntimeDependencies or [ ]) addons) + }" done ''; } diff --git a/pkgs/applications/video/mapmap/default.nix b/pkgs/applications/video/mapmap/default.nix index 66e670d0534330..0147a07b45ec9c 100644 --- a/pkgs/applications/video/mapmap/default.nix +++ b/pkgs/applications/video/mapmap/default.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, qttools -, qtmultimedia -, liblo -, gst_all_1 -, qmake -, pkg-config -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + qttools, + qtmultimedia, + liblo, + gst_all_1, + qmake, + pkg-config, + wrapQtAppsHook, }: with stdenv; diff --git a/pkgs/applications/video/memento/default.nix b/pkgs/applications/video/memento/default.nix index 1f6981215d39bd..e5c5bc8de5dec2 100644 --- a/pkgs/applications/video/memento/default.nix +++ b/pkgs/applications/video/memento/default.nix @@ -1,19 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qt6 -, wrapQtAppsHook - -# before that => zeal -, sqlite -, json_c -, mecab -, libzip -, mpv -, yt-dlp -# optional -, makeWrapper}: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qt6, + wrapQtAppsHook, + + # before that => zeal + sqlite, + json_c, + mecab, + libzip, + mpv, + yt-dlp, + # optional + makeWrapper, +}: stdenv.mkDerivation (finalAttrs: { pname = "memento"; version = "1.4.1"; @@ -44,8 +46,8 @@ stdenv.mkDerivation (finalAttrs: { propagatedBuildInputs = [ mpv ]; preFixup = '' - wrapProgram "$out/bin/memento" \ - --prefix PATH : "${yt-dlp}/bin" \ + wrapProgram "$out/bin/memento" \ + --prefix PATH : "${yt-dlp}/bin" \ ''; meta = with lib; { @@ -57,4 +59,3 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "memento"; }; }) - diff --git a/pkgs/applications/video/minitube/default.nix b/pkgs/applications/video/minitube/default.nix index 0f290f01459c84..66dc8891988e54 100644 --- a/pkgs/applications/video/minitube/default.nix +++ b/pkgs/applications/video/minitube/default.nix @@ -1,8 +1,19 @@ -{ mkDerivation, lib, fetchFromGitHub, phonon, phonon-backend-vlc, qtbase, qmake -, qtdeclarative, qttools, qtx11extras, mpv +{ + mkDerivation, + lib, + fetchFromGitHub, + phonon, + phonon-backend-vlc, + qtbase, + qmake, + qtdeclarative, + qttools, + qtx11extras, + mpv, -# "Free" key generated by pasqui23 -, withAPIKey ? "AIzaSyBQvZXseEVvgu5Ega_DI-AIJ55v0OsHmVY" }: + # "Free" key generated by pasqui23 + withAPIKey ? "AIzaSyBQvZXseEVvgu5Ega_DI-AIJ55v0OsHmVY", +}: mkDerivation rec { pname = "minitube"; @@ -22,9 +33,19 @@ mkDerivation rec { ./lib_media_src_mpv_mpvwidget.patch ]; - nativeBuildInputs = [ qmake qttools ]; + nativeBuildInputs = [ + qmake + qttools + ]; - buildInputs = [ phonon phonon-backend-vlc qtbase qtdeclarative qtx11extras mpv ]; + buildInputs = [ + phonon + phonon-backend-vlc + qtbase + qtdeclarative + qtx11extras + mpv + ]; qmakeFlags = [ "DEFINES+=APP_GOOGLE_API_KEY=${withAPIKey}" ]; diff --git a/pkgs/applications/video/mkvtoolnix/default.nix b/pkgs/applications/video/mkvtoolnix/default.nix index a180694e98db9e..3577d62b0ce1c7 100644 --- a/pkgs/applications/video/mkvtoolnix/default.nix +++ b/pkgs/applications/video/mkvtoolnix/default.nix @@ -1,51 +1,56 @@ -{ lib -, stdenv -, fetchFromGitLab -, pkg-config -, autoreconfHook -, rake -, boost -, cmark -, docbook_xsl -, expat -, fetchpatch2 -, file -, flac -, fmt -, gettext -, gmp -, gtest -, libdvdread -, libebml -, libiconv -, libmatroska -, libogg -, libvorbis -, libxslt -, nlohmann_json -, pugixml -, qtbase -, qtmultimedia -, qtwayland -, utf8cpp -, xdg-utils -, zlib -, withGUI ? true -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + autoreconfHook, + rake, + boost, + cmark, + docbook_xsl, + expat, + fetchpatch2, + file, + flac, + fmt, + gettext, + gmp, + gtest, + libdvdread, + libebml, + libiconv, + libmatroska, + libogg, + libvorbis, + libxslt, + nlohmann_json, + pugixml, + qtbase, + qtmultimedia, + qtwayland, + utf8cpp, + xdg-utils, + zlib, + withGUI ? true, + wrapQtAppsHook, }: let inherit (lib) - enableFeature getDev getLib optionals optionalString; + enableFeature + getDev + getLib + optionals + optionalString + ; - phase = name: args: - '' - runHook pre${name} + phase = name: args: '' + runHook pre${name} - rake ${args} + rake ${args} - runHook post${name} - ''; + runHook post${name} + ''; in stdenv.mkDerivation rec { @@ -74,32 +79,32 @@ stdenv.mkDerivation rec { libxslt pkg-config rake - ] - ++ optionals withGUI [ wrapQtAppsHook ]; + ] ++ optionals withGUI [ wrapQtAppsHook ]; # qtbase and qtmultimedia are needed without the GUI - buildInputs = [ - boost - expat - file - flac - fmt - gmp - libdvdread - libebml - libmatroska - libogg - libvorbis - nlohmann_json - pugixml - qtbase - qtmultimedia - utf8cpp - xdg-utils - zlib - ] - ++ optionals withGUI [ cmark ] - ++ optionals stdenv.hostPlatform.isLinux [ qtwayland ]; + buildInputs = + [ + boost + expat + file + flac + fmt + gmp + libdvdread + libebml + libmatroska + libogg + libvorbis + nlohmann_json + pugixml + qtbase + qtmultimedia + utf8cpp + xdg-utils + zlib + ] + ++ optionals withGUI [ cmark ] + ++ optionals stdenv.hostPlatform.isLinux [ qtwayland ]; # autoupdate is not needed but it silences a ton of pointless warnings postPatch = '' @@ -141,7 +146,10 @@ stdenv.mkDerivation rec { homepage = "https://mkvtoolnix.download/"; license = licenses.gpl2Only; mainProgram = if withGUI then "mkvtoolnix-gui" else "mkvtoolnix"; - maintainers = with maintainers; [ codyopel rnhmjoj ]; + maintainers = with maintainers; [ + codyopel + rnhmjoj + ]; platforms = platforms.unix; }; } diff --git a/pkgs/applications/video/mlv-app/default.nix b/pkgs/applications/video/mlv-app/default.nix index c4f0f984518e4b..d008e08f3d2bce 100644 --- a/pkgs/applications/video/mlv-app/default.nix +++ b/pkgs/applications/video/mlv-app/default.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, lib -, mkDerivation -, qmake -, qtbase -, qtmultimedia -, stdenv +{ + fetchFromGitHub, + lib, + mkDerivation, + qmake, + qtbase, + qtmultimedia, + stdenv, }: mkDerivation rec { diff --git a/pkgs/applications/video/mpc-qt/default.nix b/pkgs/applications/video/mpc-qt/default.nix index c3f6981503c8ff..70d3a4c200736e 100644 --- a/pkgs/applications/video/mpc-qt/default.nix +++ b/pkgs/applications/video/mpc-qt/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, qmake -, qttools -, qtbase -, mpv -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + qmake, + qttools, + qtbase, + mpv, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/video/mplayer/default.nix b/pkgs/applications/video/mplayer/default.nix index a9f2abb3552d94..f84c8e5c18eff8 100644 --- a/pkgs/applications/video/mplayer/default.nix +++ b/pkgs/applications/video/mplayer/default.nix @@ -1,33 +1,72 @@ -{ config, lib, stdenv, fetchurl, fetchsvn, pkg-config, freetype, yasm, ffmpeg -, aalibSupport ? true, aalib -, fontconfigSupport ? true, fontconfig, freefont_ttf -, fribidiSupport ? true, fribidi -, x11Support ? true, libX11, libXext, libGLU, libGL -, xineramaSupport ? true, libXinerama -, xvSupport ? true, libXv -, alsaSupport ? stdenv.hostPlatform.isLinux, alsa-lib -, screenSaverSupport ? true, libXScrnSaver -, vdpauSupport ? false, libvdpau -, cddaSupport ? !stdenv.hostPlatform.isDarwin, cdparanoia -, dvdnavSupport ? !stdenv.hostPlatform.isDarwin, libdvdnav -, dvdreadSupport ? true, libdvdread -, bluraySupport ? true, libbluray -, amrSupport ? false, amrnb, amrwb -, cacaSupport ? true, libcaca -, lameSupport ? true, lame -, speexSupport ? true, speex -, theoraSupport ? true, libtheora -, x264Support ? false, x264 -, jackaudioSupport ? false, libjack2 -, pulseSupport ? config.pulseaudio or false, libpulseaudio -, bs2bSupport ? false, libbs2b -, v4lSupport ? false, libv4l -# For screenshots -, libpngSupport ? true, libpng -, libjpegSupport ? true, libjpeg -, useUnfreeCodecs ? false -, darwin -, buildPackages +{ + config, + lib, + stdenv, + fetchurl, + fetchsvn, + pkg-config, + freetype, + yasm, + ffmpeg, + aalibSupport ? true, + aalib, + fontconfigSupport ? true, + fontconfig, + freefont_ttf, + fribidiSupport ? true, + fribidi, + x11Support ? true, + libX11, + libXext, + libGLU, + libGL, + xineramaSupport ? true, + libXinerama, + xvSupport ? true, + libXv, + alsaSupport ? stdenv.hostPlatform.isLinux, + alsa-lib, + screenSaverSupport ? true, + libXScrnSaver, + vdpauSupport ? false, + libvdpau, + cddaSupport ? !stdenv.hostPlatform.isDarwin, + cdparanoia, + dvdnavSupport ? !stdenv.hostPlatform.isDarwin, + libdvdnav, + dvdreadSupport ? true, + libdvdread, + bluraySupport ? true, + libbluray, + amrSupport ? false, + amrnb, + amrwb, + cacaSupport ? true, + libcaca, + lameSupport ? true, + lame, + speexSupport ? true, + speex, + theoraSupport ? true, + libtheora, + x264Support ? false, + x264, + jackaudioSupport ? false, + libjack2, + pulseSupport ? config.pulseaudio or false, + libpulseaudio, + bs2bSupport ? false, + libbs2b, + v4lSupport ? false, + libv4l, + # For screenshots + libpngSupport ? true, + libpng, + libjpegSupport ? true, + libjpeg, + useUnfreeCodecs ? false, + darwin, + buildPackages, }: assert xineramaSupport -> x11Support; @@ -40,29 +79,40 @@ let dir = "http://www.mplayerhq.hu/MPlayer/releases/codecs/"; version = "20071007"; in - if stdenv.hostPlatform.system == "i686-linux" then fetchurl { - url = "${dir}/essential-${version}.tar.bz2"; - sha256 = "18vls12n12rjw0mzw4pkp9vpcfmd1c21rzha19d7zil4hn7fs2ic"; - } else if stdenv.hostPlatform.system == "x86_64-linux" then fetchurl { - url = "${dir}/essential-amd64-${version}.tar.bz2"; - sha256 = "13xf5b92w1ra5hw00ck151lypbmnylrnznq9hhb0sj36z5wz290x"; - } else if stdenv.hostPlatform.system == "powerpc-linux" then fetchurl { - url = "${dir}/essential-ppc-${version}.tar.bz2"; - sha256 = "18mlj8dp4wnz42xbhdk1jlz2ygra6fbln9wyrcyvynxh96g1871z"; - } else null; - - codecs = if codecs_src != null then stdenv.mkDerivation { - pname = "MPlayer-codecs-essential"; - - src = codecs_src; - - installPhase = '' - mkdir $out - cp -prv * $out - ''; - - meta.license = lib.licenses.unfree; - } else null; + if stdenv.hostPlatform.system == "i686-linux" then + fetchurl { + url = "${dir}/essential-${version}.tar.bz2"; + sha256 = "18vls12n12rjw0mzw4pkp9vpcfmd1c21rzha19d7zil4hn7fs2ic"; + } + else if stdenv.hostPlatform.system == "x86_64-linux" then + fetchurl { + url = "${dir}/essential-amd64-${version}.tar.bz2"; + sha256 = "13xf5b92w1ra5hw00ck151lypbmnylrnznq9hhb0sj36z5wz290x"; + } + else if stdenv.hostPlatform.system == "powerpc-linux" then + fetchurl { + url = "${dir}/essential-ppc-${version}.tar.bz2"; + sha256 = "18mlj8dp4wnz42xbhdk1jlz2ygra6fbln9wyrcyvynxh96g1871z"; + } + else + null; + + codecs = + if codecs_src != null then + stdenv.mkDerivation { + pname = "MPlayer-codecs-essential"; + + src = codecs_src; + + installPhase = '' + mkdir $out + cp -prv * $out + ''; + + meta.license = lib.licenses.unfree; + } + else + null; crossBuild = stdenv.hostPlatform != stdenv.buildPlatform; @@ -85,12 +135,24 @@ stdenv.mkDerivation rec { ''; depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ pkg-config yasm ]; - buildInputs = [ freetype ffmpeg ] + nativeBuildInputs = [ + pkg-config + yasm + ]; + buildInputs = + [ + freetype + ffmpeg + ] ++ lib.optional aalibSupport aalib ++ lib.optional fontconfigSupport fontconfig ++ lib.optional fribidiSupport fribidi - ++ lib.optionals x11Support [ libX11 libXext libGLU libGL ] + ++ lib.optionals x11Support [ + libX11 + libXext + libGLU + libGL + ] ++ lib.optional alsaSupport alsa-lib ++ lib.optional xvSupport libXv ++ lib.optional theoraSupport libtheora @@ -101,7 +163,10 @@ stdenv.mkDerivation rec { ++ lib.optional bluraySupport libbluray ++ lib.optional cddaSupport cdparanoia ++ lib.optional jackaudioSupport libjack2 - ++ lib.optionals amrSupport [ amrnb amrwb ] + ++ lib.optionals amrSupport [ + amrnb + amrwb + ] ++ lib.optional x264Support x264 ++ lib.optional pulseSupport libpulseaudio ++ lib.optional screenSaverSupport libXScrnSaver @@ -112,48 +177,57 @@ stdenv.mkDerivation rec { ++ lib.optional libjpegSupport libjpeg ++ lib.optional bs2bSupport libbs2b ++ lib.optional v4lSupport libv4l - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Cocoa darwin.apple_sdk.frameworks.OpenGL ] - ; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Cocoa + darwin.apple_sdk.frameworks.OpenGL + ]; configurePlatforms = [ ]; - configureFlags = [ - "--enable-freetype" - (if fontconfigSupport then "--enable-fontconfig" else "--disable-fontconfig") - (if x11Support then "--enable-x11 --enable-gl" else "--disable-x11 --disable-gl") - (if xineramaSupport then "--enable-xinerama" else "--disable-xinerama") - (if xvSupport then "--enable-xv" else "--disable-xv") - (if alsaSupport then "--enable-alsa" else "--disable-alsa") - (if screenSaverSupport then "--enable-xss" else "--disable-xss") - (if vdpauSupport then "--enable-vdpau" else "--disable-vdpau") - (if cddaSupport then "--enable-cdparanoia" else "--disable-cdparanoia") - (if dvdnavSupport then "--enable-dvdnav" else "--disable-dvdnav") - (if bluraySupport then "--enable-bluray" else "--disable-bluray") - (if amrSupport then "--enable-libopencore_amrnb" else "--disable-libopencore_amrnb") - (if cacaSupport then "--enable-caca" else "--disable-caca") - (if lameSupport then "--enable-mp3lame --disable-mp3lame-lavc" else "--disable-mp3lame --enable-mp3lame-lavc") - (if speexSupport then "--enable-speex" else "--disable-speex") - (if theoraSupport then "--enable-theora" else "--disable-theora") - (if x264Support then "--enable-x264 --disable-x264-lavc" else "--disable-x264 --enable-x264-lavc") - (if jackaudioSupport then "" else "--disable-jack") - (if pulseSupport then "--enable-pulse" else "--disable-pulse") - (if v4lSupport then "--enable-v4l2 --enable-tv-v4l2" else "--disable-v4l2 --disable-tv-v4l2") - "--disable-xanim" - "--disable-xvid --disable-xvid-lavc" - "--disable-ossaudio" - "--disable-ffmpeg_a" - "--yasm=${buildPackages.yasm}/bin/yasm" - # Note, the `target` vs `host` confusion is intentional. - "--target=${stdenv.hostPlatform.config}" - ] ++ lib.optional (useUnfreeCodecs && codecs != null && !crossBuild) "--codecsdir=${codecs}" + configureFlags = + [ + "--enable-freetype" + (if fontconfigSupport then "--enable-fontconfig" else "--disable-fontconfig") + (if x11Support then "--enable-x11 --enable-gl" else "--disable-x11 --disable-gl") + (if xineramaSupport then "--enable-xinerama" else "--disable-xinerama") + (if xvSupport then "--enable-xv" else "--disable-xv") + (if alsaSupport then "--enable-alsa" else "--disable-alsa") + (if screenSaverSupport then "--enable-xss" else "--disable-xss") + (if vdpauSupport then "--enable-vdpau" else "--disable-vdpau") + (if cddaSupport then "--enable-cdparanoia" else "--disable-cdparanoia") + (if dvdnavSupport then "--enable-dvdnav" else "--disable-dvdnav") + (if bluraySupport then "--enable-bluray" else "--disable-bluray") + (if amrSupport then "--enable-libopencore_amrnb" else "--disable-libopencore_amrnb") + (if cacaSupport then "--enable-caca" else "--disable-caca") + ( + if lameSupport then + "--enable-mp3lame --disable-mp3lame-lavc" + else + "--disable-mp3lame --enable-mp3lame-lavc" + ) + (if speexSupport then "--enable-speex" else "--disable-speex") + (if theoraSupport then "--enable-theora" else "--disable-theora") + (if x264Support then "--enable-x264 --disable-x264-lavc" else "--disable-x264 --enable-x264-lavc") + (if jackaudioSupport then "" else "--disable-jack") + (if pulseSupport then "--enable-pulse" else "--disable-pulse") + (if v4lSupport then "--enable-v4l2 --enable-tv-v4l2" else "--disable-v4l2 --disable-tv-v4l2") + "--disable-xanim" + "--disable-xvid --disable-xvid-lavc" + "--disable-ossaudio" + "--disable-ffmpeg_a" + "--yasm=${buildPackages.yasm}/bin/yasm" + # Note, the `target` vs `host` confusion is intentional. + "--target=${stdenv.hostPlatform.config}" + ] + ++ lib.optional (useUnfreeCodecs && codecs != null && !crossBuild) "--codecsdir=${codecs}" ++ lib.optional (stdenv.hostPlatform.isx86 && !crossBuild) "--enable-runtime-cpudetection" ++ lib.optional fribidiSupport "--enable-fribidi" ++ lib.optional (stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isAarch64) "--enable-vidix" ++ lib.optional stdenv.hostPlatform.isLinux "--enable-fbdev" ++ lib.optionals (crossBuild) [ - "--enable-cross-compile" - "--disable-vidix-pcidb" - "--with-vidix-drivers=no" - ]; + "--enable-cross-compile" + "--disable-vidix-pcidb" + "--with-vidix-drivers=no" + ]; preConfigure = '' configureFlagsArray+=( @@ -175,10 +249,13 @@ stdenv.mkDerivation rec { NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-int-conversion -Wno-incompatible-function-pointer-types"; NIX_LDFLAGS = toString ( - lib.optional fontconfigSupport "-lfontconfig" - ++ lib.optional fribidiSupport "-lfribidi" - ++ lib.optionals x11Support [ "-lX11" "-lXext" ] - ++ lib.optional x264Support "-lx264" + lib.optional fontconfigSupport "-lfontconfig" + ++ lib.optional fribidiSupport "-lfribidi" + ++ lib.optionals x11Support [ + "-lX11" + "-lXext" + ] + ++ lib.optional x264Support "-lx264" ++ [ "-lfreetype" ] ); @@ -187,20 +264,25 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; # Provide a reasonable standard font when not using fontconfig. Maybe we should symlink here. - postInstall = lib.optionalString (!fontconfigSupport) - '' - mkdir -p $out/share/mplayer - cp ${freefont_ttf}/share/fonts/truetype/FreeSans.ttf $out/share/mplayer/subfont.ttf - if test -f $out/share/applications/mplayer.desktop ; then - echo "NoDisplay=True" >> $out/share/applications/mplayer.desktop - fi - ''; + postInstall = lib.optionalString (!fontconfigSupport) '' + mkdir -p $out/share/mplayer + cp ${freefont_ttf}/share/fonts/truetype/FreeSans.ttf $out/share/mplayer/subfont.ttf + if test -f $out/share/applications/mplayer.desktop ; then + echo "NoDisplay=True" >> $out/share/applications/mplayer.desktop + fi + ''; meta = with lib; { description = "Movie player that supports many video formats"; homepage = "http://mplayerhq.hu"; license = licenses.gpl2Only; maintainers = [ ]; - platforms = [ "i686-linux" "x86_64-linux" "x86_64-darwin" "aarch64-darwin" "aarch64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + "x86_64-darwin" + "aarch64-darwin" + "aarch64-linux" + ]; }; } diff --git a/pkgs/applications/video/mpv/scripts/buildLua.nix b/pkgs/applications/video/mpv/scripts/buildLua.nix index 2e25ee55b28a0d..6d6831c1621bba 100644 --- a/pkgs/applications/video/mpv/scripts/buildLua.nix +++ b/pkgs/applications/video/mpv/scripts/buildLua.nix @@ -67,9 +67,9 @@ lib.makeOverridable ( cp -a "${scriptPath}" "${scriptsDir}/${scriptName}" else install -m644 -Dt "${scriptsDir}" ${escaped scriptPath} - ${ - lib.optionalString (extraScripts != [ ]) ''cp -at "${scriptsDir}/" ${escapedList extraScripts}'' - } + ${lib.optionalString ( + extraScripts != [ ] + ) ''cp -at "${scriptsDir}/" ${escapedList extraScripts}''} fi runHook postInstall diff --git a/pkgs/applications/video/mpv/wrapper.nix b/pkgs/applications/video/mpv/wrapper.nix index 8104921aadbdb9..54fa65890b03a4 100644 --- a/pkgs/applications/video/mpv/wrapper.nix +++ b/pkgs/applications/video/mpv/wrapper.nix @@ -1,70 +1,101 @@ # Arguments that this derivation gets when it is created with `callPackage` -{ stdenv -, buildEnv -, lib -, makeWrapper -, mpvScripts -, symlinkJoin -, writeTextDir -, yt-dlp +{ + stdenv, + buildEnv, + lib, + makeWrapper, + mpvScripts, + symlinkJoin, + writeTextDir, + yt-dlp, # the unwrapped mpv derivation }: let # arguments to the function (exposed as `mpv-unwrapped.wrapper` in top-level) - wrapper = { - mpv, - extraMakeWrapperArgs ? [], - youtubeSupport ? true, - # a set of derivations (probably from `mpvScripts`) where each is expected - # to have a `scriptName` passthru attribute that points to the name of the - # script that would reside in the script's derivation's - # `$out/share/mpv/scripts/`. - # - # A script can optionally also provide `passthru.extraWrapperArgs` - # attribute. - scripts ? [], - extraUmpvWrapperArgs ? [] - }: - let - binPath = lib.makeBinPath ([ - mpv.luaEnv - ] ++ lib.optionals youtubeSupport [ - yt-dlp - ] ++ lib.optionals mpv.vapoursynthSupport [ - mpv.vapoursynth.python3 - ]); - # All arguments besides the input and output binaries (${mpv}/bin/mpv and - # $out/bin/mpv). These are used by the darwin specific makeWrapper call - # used to wrap $out/Applications/mpv.app/Contents/MacOS/mpv as well. - mostMakeWrapperArgs = lib.strings.escapeShellArgs ([ "--inherit-argv0" - # These are always needed (TODO: Explain why) - "--prefix" "LUA_CPATH" ";" "${mpv.luaEnv}/lib/lua/${mpv.lua.luaversion}/?.so" - "--prefix" "LUA_PATH" ";" "${mpv.luaEnv}/share/lua/${mpv.lua.luaversion}/?.lua" - ] ++ lib.optionals mpv.vapoursynthSupport [ - "--prefix" "PYTHONPATH" ":" "${mpv.vapoursynth}/${mpv.vapoursynth.python3.sitePackages}" - ] ++ lib.optionals (binPath != "") [ - "--prefix" "PATH" ":" binPath - ] ++ (lib.lists.flatten (map - # For every script in the `scripts` argument, add the necessary flags to the wrapper - (script: + wrapper = + { + mpv, + extraMakeWrapperArgs ? [ ], + youtubeSupport ? true, + # a set of derivations (probably from `mpvScripts`) where each is expected + # to have a `scriptName` passthru attribute that points to the name of the + # script that would reside in the script's derivation's + # `$out/share/mpv/scripts/`. + # + # A script can optionally also provide `passthru.extraWrapperArgs` + # attribute. + scripts ? [ ], + extraUmpvWrapperArgs ? [ ], + }: + let + binPath = lib.makeBinPath ( [ - "--add-flags" - # Here we rely on the existence of the `scriptName` passthru - # attribute of the script derivation from the `scripts` - "--script=${script}/share/mpv/scripts/${script.scriptName}" + mpv.luaEnv ] - # scripts can also set the `extraWrapperArgs` passthru - ++ (script.extraWrapperArgs or []) - ) scripts - )) ++ extraMakeWrapperArgs) - ; - umpvWrapperArgs = lib.strings.escapeShellArgs ([ - "--inherit-argv0" - "--set" "MPV" "${placeholder "out"}/bin/mpv" - ] ++ extraUmpvWrapperArgs) - ; - in + ++ lib.optionals youtubeSupport [ + yt-dlp + ] + ++ lib.optionals mpv.vapoursynthSupport [ + mpv.vapoursynth.python3 + ] + ); + # All arguments besides the input and output binaries (${mpv}/bin/mpv and + # $out/bin/mpv). These are used by the darwin specific makeWrapper call + # used to wrap $out/Applications/mpv.app/Contents/MacOS/mpv as well. + mostMakeWrapperArgs = lib.strings.escapeShellArgs ( + [ + "--inherit-argv0" + # These are always needed (TODO: Explain why) + "--prefix" + "LUA_CPATH" + ";" + "${mpv.luaEnv}/lib/lua/${mpv.lua.luaversion}/?.so" + "--prefix" + "LUA_PATH" + ";" + "${mpv.luaEnv}/share/lua/${mpv.lua.luaversion}/?.lua" + ] + ++ lib.optionals mpv.vapoursynthSupport [ + "--prefix" + "PYTHONPATH" + ":" + "${mpv.vapoursynth}/${mpv.vapoursynth.python3.sitePackages}" + ] + ++ lib.optionals (binPath != "") [ + "--prefix" + "PATH" + ":" + binPath + ] + ++ (lib.lists.flatten ( + map + # For every script in the `scripts` argument, add the necessary flags to the wrapper + ( + script: + [ + "--add-flags" + # Here we rely on the existence of the `scriptName` passthru + # attribute of the script derivation from the `scripts` + "--script=${script}/share/mpv/scripts/${script.scriptName}" + ] + # scripts can also set the `extraWrapperArgs` passthru + ++ (script.extraWrapperArgs or [ ]) + ) + scripts + )) + ++ extraMakeWrapperArgs + ); + umpvWrapperArgs = lib.strings.escapeShellArgs ( + [ + "--inherit-argv0" + "--set" + "MPV" + "${placeholder "out"}/bin/mpv" + ] + ++ extraUmpvWrapperArgs + ); + in symlinkJoin { name = "mpv-with-scripts-${mpv.version}"; @@ -81,30 +112,39 @@ let # filters "override" "overrideDerivation" "recurseForDerivations" (lib.filterAttrs (key: script: lib.isDerivation script)) # replaces unfree and meta.broken scripts with decent placeholders - (lib.mapAttrsToList (key: script: - if (builtins.tryEval script.outPath).success - then script - else writeTextDir "share/mpv/scripts/${script.scriptName}" "placeholder of ${script.name}" + (lib.mapAttrsToList ( + key: script: + if (builtins.tryEval script.outPath).success then + script + else + writeTextDir "share/mpv/scripts/${script.scriptName}" "placeholder of ${script.name}" )) ]; }; - postBuild = '' - # wrapProgram can't operate on symlinks - rm "$out/bin/mpv" - makeWrapper "${mpv}/bin/mpv" "$out/bin/mpv" ${mostMakeWrapperArgs} - rm "$out/bin/umpv" - makeWrapper "${mpv}/bin/umpv" "$out/bin/umpv" ${umpvWrapperArgs} - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # wrapProgram can't operate on symlinks - rm "$out/Applications/mpv.app/Contents/MacOS/mpv" - makeWrapper "${mpv}/Applications/mpv.app/Contents/MacOS/mpv" "$out/Applications/mpv.app/Contents/MacOS/mpv" ${mostMakeWrapperArgs} - ''; + postBuild = + '' + # wrapProgram can't operate on symlinks + rm "$out/bin/mpv" + makeWrapper "${mpv}/bin/mpv" "$out/bin/mpv" ${mostMakeWrapperArgs} + rm "$out/bin/umpv" + makeWrapper "${mpv}/bin/umpv" "$out/bin/umpv" ${umpvWrapperArgs} + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # wrapProgram can't operate on symlinks + rm "$out/Applications/mpv.app/Contents/MacOS/mpv" + makeWrapper "${mpv}/Applications/mpv.app/Contents/MacOS/mpv" "$out/Applications/mpv.app/Contents/MacOS/mpv" ${mostMakeWrapperArgs} + ''; meta = { - inherit (mpv.meta) homepage description longDescription maintainers; + inherit (mpv.meta) + homepage + description + longDescription + maintainers + ; mainProgram = "mpv"; }; }; in - lib.makeOverridable wrapper +lib.makeOverridable wrapper diff --git a/pkgs/applications/video/mythtv/default.nix b/pkgs/applications/video/mythtv/default.nix index ce3ae604e7d1fa..f8a56225ad093b 100644 --- a/pkgs/applications/video/mythtv/default.nix +++ b/pkgs/applications/video/mythtv/default.nix @@ -1,9 +1,44 @@ -{ lib, mkDerivation, fetchFromGitHub, which, qtbase, qtwebkit, qtscript -, libpulseaudio, fftwSinglePrec , lame, zlib, libGLU, libGL, alsa-lib, freetype -, perl, pkg-config , libsamplerate, libbluray, lzo, libX11, libXv, libXrandr, libXvMC, libXinerama, libXxf86vm -, libXmu , yasm, libuuid, taglib, libtool, autoconf, automake, file, exiv2, linuxHeaders -, soundtouch, libzip, libhdhomerun -, withWebKit ? false +{ + lib, + mkDerivation, + fetchFromGitHub, + which, + qtbase, + qtwebkit, + qtscript, + libpulseaudio, + fftwSinglePrec, + lame, + zlib, + libGLU, + libGL, + alsa-lib, + freetype, + perl, + pkg-config, + libsamplerate, + libbluray, + lzo, + libX11, + libXv, + libXrandr, + libXvMC, + libXinerama, + libXxf86vm, + libXmu, + yasm, + libuuid, + taglib, + libtool, + autoconf, + automake, + file, + exiv2, + linuxHeaders, + soundtouch, + libzip, + libhdhomerun, + withWebKit ? false, }: mkDerivation rec { @@ -25,15 +60,46 @@ mkDerivation rec { setSourceRoot = "sourceRoot=$(echo */mythtv)"; buildInputs = [ - freetype qtbase qtscript lame zlib libGLU libGL - perl libsamplerate libbluray lzo alsa-lib libpulseaudio fftwSinglePrec libX11 libXv libXrandr libXvMC - libXmu libXinerama libXxf86vm libXmu libuuid taglib exiv2 soundtouch libzip + freetype + qtbase + qtscript + lame + zlib + libGLU + libGL + perl + libsamplerate + libbluray + lzo + alsa-lib + libpulseaudio + fftwSinglePrec + libX11 + libXv + libXrandr + libXvMC + libXmu + libXinerama + libXxf86vm + libXmu + libuuid + taglib + exiv2 + soundtouch + libzip libhdhomerun ] ++ lib.optional withWebKit qtwebkit; - nativeBuildInputs = [ pkg-config which yasm libtool autoconf automake file ]; + nativeBuildInputs = [ + pkg-config + which + yasm + libtool + autoconf + automake + file + ]; - configureFlags = - [ "--dvb-path=${linuxHeaders}/include" ]; + configureFlags = [ "--dvb-path=${linuxHeaders}/include" ]; enableParallelBuilding = true; diff --git a/pkgs/applications/video/natron/default.nix b/pkgs/applications/video/natron/default.nix index e02aa4af610dfe..6d11f5aa5f7eb5 100644 --- a/pkgs/applications/video/natron/default.nix +++ b/pkgs/applications/video/natron/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, wrapQtAppsHook -, boost -, cairo -, ceres-solver -, expat -, extra-cmake-modules -, glog -, libXdmcp -, python3 -, wayland +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + wrapQtAppsHook, + boost, + cairo, + ceres-solver, + expat, + extra-cmake-modules, + glog, + libXdmcp, + python3, + wayland, }: let @@ -44,13 +45,13 @@ stdenv.mkDerivation { (fetchpatch { name = "gcc-13.patch"; url = "https://github.com/NatronGitHub/Natron/commit/4b44fb18293035873b35c3a2d2aa29da78cb8740.patch"; - includes = ["Global/GlobalDefines.h"]; + includes = [ "Global/GlobalDefines.h" ]; hash = "sha256-9E1tJCvO7zA1iQAhrlL3GaBFIGpkjxNOr31behQXdhQ="; }) (fetchpatch { name = "gcc-13.patch"; url = "https://github.com/NatronGitHub/Natron/commit/f21f58622e32c1684567c82e2ab361f33030bda7.patch"; - includes = ["Engine/Noise.cpp"]; + includes = [ "Engine/Noise.cpp" ]; hash = "sha256-t2mzTsRuXVs8d1BB/5uAY1OPxWRa3JTK1iAWLAMsrgs="; }) ]; @@ -84,7 +85,12 @@ stdenv.mkDerivation { postFixup = '' wrapProgram $out/bin/Natron \ - --prefix PYTHONPATH : "${python3.pkgs.makePythonPath [ python3.pkgs.qtpy python3.pkgs.pyside2 ]}" \ + --prefix PYTHONPATH : "${ + python3.pkgs.makePythonPath [ + python3.pkgs.qtpy + python3.pkgs.pyside2 + ] + }" \ --set-default OCIO "$out/share/OpenColorIO-Configs/blender/config.ocio" ''; diff --git a/pkgs/applications/video/obs-studio/plugins/droidcam-obs/default.nix b/pkgs/applications/video/obs-studio/plugins/droidcam-obs/default.nix index a1cf5f2e7eef0b..c6f704d08d766f 100644 --- a/pkgs/applications/video/obs-studio/plugins/droidcam-obs/default.nix +++ b/pkgs/applications/video/obs-studio/plugins/droidcam-obs/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, obs-studio -, ffmpeg -, libjpeg -, libimobiledevice -, libusbmuxd -, libplist +{ + lib, + stdenv, + fetchFromGitHub, + obs-studio, + ffmpeg, + libjpeg, + libimobiledevice, + libusbmuxd, + libplist, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/video/obs-studio/plugins/looking-glass-obs.nix b/pkgs/applications/video/obs-studio/plugins/looking-glass-obs.nix index b581dc44022275..c9fbda2b4e3551 100644 --- a/pkgs/applications/video/obs-studio/plugins/looking-glass-obs.nix +++ b/pkgs/applications/video/obs-studio/plugins/looking-glass-obs.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, cmake, libbfd, SDL2, obs-studio -, looking-glass-client }: +{ + lib, + stdenv, + cmake, + libbfd, + SDL2, + obs-studio, + looking-glass-client, +}: stdenv.mkDerivation { pname = "looking-glass-obs"; @@ -10,7 +17,11 @@ stdenv.mkDerivation { sourceRoot = "${looking-glass-client.src.name}/obs"; nativeBuildInputs = [ cmake ]; - buildInputs = [ obs-studio libbfd SDL2 ]; + buildInputs = [ + obs-studio + libbfd + SDL2 + ]; env.NIX_CFLAGS_COMPILE = "-mavx"; diff --git a/pkgs/applications/video/obs-studio/plugins/obs-backgroundremoval/default.nix b/pkgs/applications/video/obs-studio/plugins/obs-backgroundremoval/default.nix index 638d0785f4c803..408e2bb709cc3e 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-backgroundremoval/default.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-backgroundremoval/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -, obs-studio -, onnxruntime -, opencv -, qt6 -, curl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + obs-studio, + onnxruntime, + opencv, + qt6, + curl, }: stdenv.mkDerivation rec { @@ -21,8 +22,17 @@ stdenv.mkDerivation rec { hash = "sha256-QoC9/HkwOXMoFNvcOxQkGCLLAJmsja801LKCNT9O9T0="; }; - nativeBuildInputs = [ cmake ninja ]; - buildInputs = [ obs-studio onnxruntime opencv qt6.qtbase curl ]; + nativeBuildInputs = [ + cmake + ninja + ]; + buildInputs = [ + obs-studio + onnxruntime + opencv + qt6.qtbase + curl + ]; dontWrapQtApps = true; @@ -35,8 +45,8 @@ stdenv.mkDerivation rec { ]; buildPhase = '' - cd .. - cmake --build build_x86_64 --parallel + cd .. + cmake --build build_x86_64 --parallel ''; installPhase = '' diff --git a/pkgs/applications/video/obs-studio/plugins/obs-command-source.nix b/pkgs/applications/video/obs-studio/plugins/obs-command-source.nix index 8a0f9adcca067b..56236261483a50 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-command-source.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-command-source.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, obs-studio +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + obs-studio, }: stdenv.mkDerivation rec { @@ -31,6 +32,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/norihiro/command-source"; maintainers = with maintainers; [ flexiondotorg ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-composite-blur.nix b/pkgs/applications/video/obs-studio/plugins/obs-composite-blur.nix index 16b4b2c34fbf60..c5799c37924eb3 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-composite-blur.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-composite-blur.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, obs-studio -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + obs-studio, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/video/obs-studio/plugins/obs-freeze-filter.nix b/pkgs/applications/video/obs-studio/plugins/obs-freeze-filter.nix index 0bec9181e19c8d..1cc6d312ec381d 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-freeze-filter.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-freeze-filter.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, obs-studio -, qtbase +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + obs-studio, + qtbase, }: stdenv.mkDerivation (finalAttrs: { @@ -19,7 +20,10 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ obs-studio qtbase ]; + buildInputs = [ + obs-studio + qtbase + ]; postInstall = '' rm -rf "$out/share" diff --git a/pkgs/applications/video/obs-studio/plugins/obs-gradient-source.nix b/pkgs/applications/video/obs-studio/plugins/obs-gradient-source.nix index 13255c2898c2d5..23a3c3e41d42f1 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-gradient-source.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-gradient-source.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, obs-studio +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + obs-studio, }: stdenv.mkDerivation rec { @@ -32,6 +33,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/exeldro/obs-gradient-source"; maintainers = with maintainers; [ flexiondotorg ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-hyperion/default.nix b/pkgs/applications/video/obs-studio/plugins/obs-hyperion/default.nix index 6fcd7744fe3df7..d7cb122e8354eb 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-hyperion/default.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-hyperion/default.nix @@ -1,5 +1,14 @@ -{ stdenv, lib, fetchFromGitHub, cmake, pkg-config, obs-studio, libGL -, qtbase, flatbuffers }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + obs-studio, + libGL, + qtbase, + flatbuffers, +}: stdenv.mkDerivation rec { pname = "obs-hyperion"; @@ -12,8 +21,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-UAfjafoZhhhHRSo+eUBLhHaCmn2GYFcYyRb9wHIp/9I="; }; - nativeBuildInputs = [ cmake flatbuffers pkg-config ]; - buildInputs = [ obs-studio flatbuffers libGL qtbase ]; + nativeBuildInputs = [ + cmake + flatbuffers + pkg-config + ]; + buildInputs = [ + obs-studio + flatbuffers + libGL + qtbase + ]; dontWrapQtApps = true; diff --git a/pkgs/applications/video/obs-studio/plugins/obs-livesplit-one/default.nix b/pkgs/applications/video/obs-studio/plugins/obs-livesplit-one/default.nix index 33f953c4e2a6e2..5a24ceaa334ace 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-livesplit-one/default.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-livesplit-one/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, cmake -, fontconfig -, obs-studio -, pkg-config +{ + lib, + fetchFromGitHub, + rustPlatform, + cmake, + fontconfig, + obs-studio, + pkg-config, }: rustPlatform.buildRustPackage rec { @@ -25,8 +26,14 @@ rustPlatform.buildRustPackage rec { }; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ fontconfig obs-studio ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + fontconfig + obs-studio + ]; postInstall = '' mkdir $out/lib/obs-plugins/ @@ -36,7 +43,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "OBS Studio plugin for adding LiveSplit One as a source"; homepage = "https://github.com/LiveSplit/obs-livesplit-one"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = [ maintainers.Bauke ]; platforms = obs-studio.meta.platforms; }; diff --git a/pkgs/applications/video/obs-studio/plugins/obs-move-transition.nix b/pkgs/applications/video/obs-studio/plugins/obs-move-transition.nix index e7a09a69a5eeb8..bdedeeed9c787e 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-move-transition.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-move-transition.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, obs-studio +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + obs-studio, }: stdenv.mkDerivation rec { @@ -28,6 +29,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/exeldro/obs-move-transition"; maintainers = with maintainers; [ starcraft66 ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-multi-rtmp/default.nix b/pkgs/applications/video/obs-studio/plugins/obs-multi-rtmp/default.nix index c2e718b233ab17..b16e35f531516e 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-multi-rtmp/default.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-multi-rtmp/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, obs-studio, cmake, qtbase, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + obs-studio, + cmake, + qtbase, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "obs-multi-rtmp"; @@ -21,7 +29,10 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ obs-studio qtbase ]; + buildInputs = [ + obs-studio + qtbase + ]; cmakeFlags = [ (lib.cmakeBool "ENABLE_QT" true) @@ -45,6 +56,9 @@ stdenv.mkDerivation rec { description = "Multi-site simultaneous broadcast plugin for OBS Studio"; license = licenses.gpl2Only; maintainers = with maintainers; [ jk ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-mute-filter.nix b/pkgs/applications/video/obs-studio/plugins/obs-mute-filter.nix index fd683f3a4ccf73..b235ca6fb20b70 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-mute-filter.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-mute-filter.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, obs-studio +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + obs-studio, }: stdenv.mkDerivation rec { @@ -31,6 +32,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/norihiro/obs-mute-filter"; maintainers = with maintainers; [ flexiondotorg ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-nvfbc.nix b/pkgs/applications/video/obs-studio/plugins/obs-nvfbc.nix index 41b74807e4afc6..cd3b410096cfa8 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-nvfbc.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-nvfbc.nix @@ -1,5 +1,13 @@ -{ stdenv, lib, fetchFromGitLab, meson, ninja, pkg-config -, obs-studio, libGL, libX11 +{ + stdenv, + lib, + fetchFromGitLab, + meson, + ninja, + pkg-config, + obs-studio, + libGL, + libX11, }: stdenv.mkDerivation rec { @@ -13,8 +21,16 @@ stdenv.mkDerivation rec { hash = "sha256-AJ3K0O1vrixskn+/Tpg7LsgRO8N4sgDo1Y6gg3CwGVo="; }; - nativeBuildInputs = [ meson pkg-config ninja ]; - buildInputs = [ obs-studio libGL libX11 ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + ]; + buildInputs = [ + obs-studio + libGL + libX11 + ]; meta = with lib; { description = "OBS Studio source plugin for NVIDIA FBC API"; diff --git a/pkgs/applications/video/obs-studio/plugins/obs-replay-source.nix b/pkgs/applications/video/obs-studio/plugins/obs-replay-source.nix index 42682dd1461424..8d5edcc38c493d 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-replay-source.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-replay-source.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, libcaption -, obs-studio -, qtbase +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + libcaption, + obs-studio, + qtbase, }: stdenv.mkDerivation (finalAttrs: { @@ -19,7 +20,11 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libcaption obs-studio qtbase ]; + buildInputs = [ + libcaption + obs-studio + qtbase + ]; postInstall = '' mkdir -p "$out/lib" "$out/share" diff --git a/pkgs/applications/video/obs-studio/plugins/obs-rgb-levels-filter.nix b/pkgs/applications/video/obs-studio/plugins/obs-rgb-levels-filter.nix index aff227211e4d71..f51d7963089a29 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-rgb-levels-filter.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-rgb-levels-filter.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, obs-studio +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + obs-studio, }: stdenv.mkDerivation rec { @@ -28,6 +29,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/wimpysworld/obs-rgb-levels-filter"; maintainers = with maintainers; [ flexiondotorg ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-scale-to-sound.nix b/pkgs/applications/video/obs-studio/plugins/obs-scale-to-sound.nix index 5716439655d437..3b3f9c6e82201a 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-scale-to-sound.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-scale-to-sound.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, obs-studio +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + obs-studio, }: stdenv.mkDerivation rec { @@ -35,6 +36,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/dimtpap/obs-scale-to-sound"; maintainers = with maintainers; [ flexiondotorg ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-shaderfilter.nix b/pkgs/applications/video/obs-studio/plugins/obs-shaderfilter.nix index b76b6e9d7f2b72..aacff57a8b5f4b 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-shaderfilter.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-shaderfilter.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, obs-studio -, qtbase +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + obs-studio, + qtbase, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ obs-studio qtbase ]; + buildInputs = [ + obs-studio + qtbase + ]; cmakeFlags = [ "-DBUILD_OUT_OF_TREE=On" @@ -36,6 +40,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/exeldro/obs-shaderfilter"; maintainers = with maintainers; [ flexiondotorg ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-source-clone.nix b/pkgs/applications/video/obs-studio/plugins/obs-source-clone.nix index bc27eca43d03f5..605e7e50dd7de1 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-source-clone.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-source-clone.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, obs-studio +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + obs-studio, }: stdenv.mkDerivation { diff --git a/pkgs/applications/video/obs-studio/plugins/obs-source-switcher.nix b/pkgs/applications/video/obs-studio/plugins/obs-source-switcher.nix index b336ddf9120397..268d3f5395ad25 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-source-switcher.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-source-switcher.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, obs-studio +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + obs-studio, }: stdenv.mkDerivation rec { @@ -32,6 +33,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/exeldro/obs-source-switcher"; maintainers = with maintainers; [ flexiondotorg ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-text-pthread.nix b/pkgs/applications/video/obs-studio/plugins/obs-text-pthread.nix index 8ce601f08ea503..8a6e77b51f8752 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-text-pthread.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-text-pthread.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, cairo -, obs-studio -, pango -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + cairo, + obs-studio, + pango, + pkg-config, }: stdenv.mkDerivation rec { @@ -19,8 +20,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-zrgxKs3jmrwQJiEgKfZz1BOVToTLauQXtFYcuFlV71o="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ cairo obs-studio pango ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + cairo + obs-studio + pango + ]; postInstall = '' mkdir $out/lib $out/share @@ -34,6 +42,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/norihiro/obs-text-pthread"; maintainers = with maintainers; [ flexiondotorg ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-transition-table.nix b/pkgs/applications/video/obs-studio/plugins/obs-transition-table.nix index ed8aadb52ae7bd..06c46413287b3a 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-transition-table.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-transition-table.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, obs-studio -, qtbase +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + obs-studio, + qtbase, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ obs-studio qtbase ]; + buildInputs = [ + obs-studio + qtbase + ]; cmakeFlags = [ "-DBUILD_OUT_OF_TREE=On" @@ -35,6 +39,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/exeldro/obs-transition-table"; maintainers = with maintainers; [ flexiondotorg ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-vaapi/default.nix b/pkgs/applications/video/obs-studio/plugins/obs-vaapi/default.nix index 59be77c454de84..31241c74f11934 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-vaapi/default.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-vaapi/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, gst_all_1 -, pciutils -, pkg-config -, meson -, ninja -, obs-studio +{ + lib, + stdenv, + fetchFromGitHub, + gst_all_1, + pciutils, + pkg-config, + meson, + ninja, + obs-studio, }: stdenv.mkDerivation rec { @@ -20,8 +21,17 @@ stdenv.mkDerivation rec { hash = "sha256-ykiLsHL3hoe0ibxMxp4zrqeSeQfgnJfNg7Yb5i9HDJQ="; }; - nativeBuildInputs = [ pkg-config meson ninja ]; - buildInputs = with gst_all_1; [ gstreamer gst-plugins-base obs-studio pciutils ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + ]; + buildInputs = with gst_all_1; [ + gstreamer + gst-plugins-base + obs-studio + pciutils + ]; # - We need "getLib" instead of default derivation, otherwise it brings gstreamer-bin; # - without gst-plugins-base it won't even show proper errors in logs; @@ -30,9 +40,11 @@ stdenv.mkDerivation rec { # Tip: "could not link appsrc to videoconvert1" can mean a lot of things, enable GST_DEBUG=2 for help. passthru.obsWrapperArguments = let - gstreamerHook = package: "--prefix GST_PLUGIN_SYSTEM_PATH_1_0 : ${lib.getLib package}/lib/gstreamer-1.0"; + gstreamerHook = + package: "--prefix GST_PLUGIN_SYSTEM_PATH_1_0 : ${lib.getLib package}/lib/gstreamer-1.0"; in - with gst_all_1; builtins.map gstreamerHook [ + with gst_all_1; + builtins.map gstreamerHook [ gstreamer gst-plugins-base gst-plugins-bad @@ -49,8 +61,14 @@ stdenv.mkDerivation rec { description = "OBS Studio VAAPI support via GStreamer"; homepage = "https://github.com/fzwoch/obs-vaapi"; changelog = "https://github.com/fzwoch/obs-vaapi/releases/tag/${version}"; - maintainers = with maintainers; [ ahuzik pedrohlc ]; + maintainers = with maintainers; [ + ahuzik + pedrohlc + ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-vintage-filter.nix b/pkgs/applications/video/obs-studio/plugins/obs-vintage-filter.nix index 9c3278a3c34eda..9a8967d67df82c 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-vintage-filter.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-vintage-filter.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, obs-studio +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + obs-studio, }: stdenv.mkDerivation rec { @@ -31,6 +32,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/cg2121/obs-vintage-filter"; maintainers = with maintainers; [ flexiondotorg ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/obs-vkcapture.nix b/pkgs/applications/video/obs-studio/plugins/obs-vkcapture.nix index f3384ed2ab21bd..141bf70c2a2d70 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-vkcapture.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-vkcapture.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, ninja -, wayland -, wayland-scanner -, obs-studio -, libffi -, libX11 -, libXau -, libXdmcp -, libxcb -, vulkan-headers -, vulkan-loader -, libGL -, obs-vkcapture32 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + ninja, + wayland, + wayland-scanner, + obs-studio, + libffi, + libX11, + libXau, + libXdmcp, + libxcb, + vulkan-headers, + vulkan-loader, + libGL, + obs-vkcapture32, }: stdenv.mkDerivation (finalAttrs: { @@ -35,21 +36,27 @@ stdenv.mkDerivation (finalAttrs: { "-DBUILD_PLUGIN=OFF" ]; - nativeBuildInputs = [ cmake ninja pkg-config wayland-scanner ]; - buildInputs = [ - libGL - libffi - libX11 - libXau - libXdmcp - libxcb - vulkan-headers - vulkan-loader - wayland - ] - ++ lib.optionals (!stdenv.hostPlatform.isi686) [ - obs-studio + nativeBuildInputs = [ + cmake + ninja + pkg-config + wayland-scanner ]; + buildInputs = + [ + libGL + libffi + libX11 + libXau + libXdmcp + libxcb + vulkan-headers + vulkan-loader + wayland + ] + ++ lib.optionals (!stdenv.hostPlatform.isi686) [ + obs-studio + ]; postPatch = '' substituteInPlace src/glinject.c \ @@ -78,7 +85,10 @@ stdenv.mkDerivation (finalAttrs: { description = "OBS Linux Vulkan/OpenGL game capture"; homepage = "https://github.com/nowrep/obs-vkcapture"; changelog = "https://github.com/nowrep/obs-vkcapture/releases/tag/v${finalAttrs.version}"; - maintainers = with maintainers; [ atila pedrohlc ]; + maintainers = with maintainers; [ + atila + pedrohlc + ]; license = licenses.gpl2Only; platforms = platforms.linux; }; diff --git a/pkgs/applications/video/obs-studio/plugins/obs-webkitgtk.nix b/pkgs/applications/video/obs-studio/plugins/obs-webkitgtk.nix index 51fcb7468b03e9..48daa0a25676dd 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-webkitgtk.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-webkitgtk.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, obs-studio -, webkitgtk_4_0 -, glib-networking -, meson -, cmake -, pkg-config -, ninja -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + obs-studio, + webkitgtk_4_0, + glib-networking, + meson, + cmake, + pkg-config, + ninja, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/video/obs-studio/plugins/obs-websocket.nix b/pkgs/applications/video/obs-studio/plugins/obs-websocket.nix index a9bdff2e30c786..a3198dba06d616 100644 --- a/pkgs/applications/video/obs-studio/plugins/obs-websocket.nix +++ b/pkgs/applications/video/obs-studio/plugins/obs-websocket.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, asio -, obs-studio -, qtbase -, websocketpp +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + asio, + obs-studio, + qtbase, + websocketpp, }: stdenv.mkDerivation rec { @@ -20,7 +21,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ asio obs-studio qtbase websocketpp ]; + buildInputs = [ + asio + obs-studio + qtbase + websocketpp + ]; dontWrapQtApps = true; @@ -36,6 +42,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/obsproject/obs-websocket"; maintainers = with maintainers; [ flexiondotorg ]; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/waveform/default.nix b/pkgs/applications/video/obs-studio/plugins/waveform/default.nix index 8f0cb4077cc5ae..1c432de77d5e23 100644 --- a/pkgs/applications/video/obs-studio/plugins/waveform/default.nix +++ b/pkgs/applications/video/obs-studio/plugins/waveform/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, obs-studio -, pkg-config -, fftwFloat +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + obs-studio, + pkg-config, + fftwFloat, }: stdenv.mkDerivation rec { @@ -19,7 +20,10 @@ stdenv.mkDerivation rec { hash = "sha256-Bg1n1yV4JzNFEXFNayNa1exsSZhmRJ0RLHDjLWmqGZE="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; postFixup = '' mkdir -p $out/lib $out/share/obs/obs-plugins @@ -38,6 +42,6 @@ stdenv.mkDerivation rec { homepage = "https://github.com/phandasm/waveform"; maintainers = with lib.maintainers; [ matthewcroughan ]; license = lib.licenses.gpl3; - platforms = ["x86_64-linux"]; + platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/applications/video/obs-studio/plugins/wlrobs.nix b/pkgs/applications/video/obs-studio/plugins/wlrobs.nix index d6017a649362be..37950307d9e865 100644 --- a/pkgs/applications/video/obs-studio/plugins/wlrobs.nix +++ b/pkgs/applications/video/obs-studio/plugins/wlrobs.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchFromSourcehut -, meson, pkg-config, ninja -, wayland, obs-studio, libX11 +{ + lib, + stdenv, + fetchFromSourcehut, + meson, + pkg-config, + ninja, + wayland, + obs-studio, + libX11, }: stdenv.mkDerivation { @@ -11,12 +18,20 @@ stdenv.mkDerivation { vc = "hg"; owner = "~scoopta"; repo = "wlrobs"; - rev = "f72d5cb3cbbd3983ae6cfd86cb1940be7372681c"; + rev = "f72d5cb3cbbd3983ae6cfd86cb1940be7372681c"; hash = "sha256-hiM0d38SSUqbyisP3fAtKRLBDjVKZdU2U1xyXci7yNk="; }; - nativeBuildInputs = [ meson pkg-config ninja ]; - buildInputs = [ wayland obs-studio libX11 ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + ]; + buildInputs = [ + wayland + obs-studio + libX11 + ]; meta = with lib; { description = "Obs-studio plugin that allows you to screen capture on wlroots based wayland compositors"; diff --git a/pkgs/applications/video/obs-studio/wrapper.nix b/pkgs/applications/video/obs-studio/wrapper.nix index 0c972fc58d371a..c093d64cf6c34d 100644 --- a/pkgs/applications/video/obs-studio/wrapper.nix +++ b/pkgs/applications/video/obs-studio/wrapper.nix @@ -1,6 +1,13 @@ -{ lib, obs-studio, symlinkJoin, makeWrapper }: +{ + lib, + obs-studio, + symlinkJoin, + makeWrapper, +}: -{ plugins ? [] }: +{ + plugins ? [ ], +}: symlinkJoin { name = "wrapped-${obs-studio.name}"; @@ -11,8 +18,7 @@ symlinkJoin { postBuild = let # Some plugins needs extra environment, see obs-gstreamer for an example. - pluginArguments = - lib.lists.concatMap (plugin: plugin.obsWrapperArguments or []) plugins; + pluginArguments = lib.lists.concatMap (plugin: plugin.obsWrapperArguments or [ ]) plugins; pluginsJoined = symlinkJoin { name = "obs-studio-plugins"; @@ -20,19 +26,20 @@ symlinkJoin { }; wrapCommandLine = [ - "wrapProgram" - "$out/bin/obs" - ''--set OBS_PLUGINS_PATH "${pluginsJoined}/lib/obs-plugins"'' - ''--set OBS_PLUGINS_DATA_PATH "${pluginsJoined}/share/obs/obs-plugins"'' - ] ++ lib.lists.unique pluginArguments; - in '' - ${lib.concatStringsSep " " wrapCommandLine} - - # Remove unused obs-plugins dir to not cause confusion - rm -r $out/share/obs/obs-plugins - # Leave some breadcrumbs - echo 'Plugins are at ${pluginsJoined}/share/obs/obs-plugins' > $out/share/obs/obs-plugins-README - ''; + "wrapProgram" + "$out/bin/obs" + ''--set OBS_PLUGINS_PATH "${pluginsJoined}/lib/obs-plugins"'' + ''--set OBS_PLUGINS_DATA_PATH "${pluginsJoined}/share/obs/obs-plugins"'' + ] ++ lib.lists.unique pluginArguments; + in + '' + ${lib.concatStringsSep " " wrapCommandLine} + + # Remove unused obs-plugins dir to not cause confusion + rm -r $out/share/obs/obs-plugins + # Leave some breadcrumbs + echo 'Plugins are at ${pluginsJoined}/share/obs/obs-plugins' > $out/share/obs/obs-plugins-README + ''; inherit (obs-studio) meta; passthru = obs-studio.passthru // { diff --git a/pkgs/applications/video/olive-editor/default.nix b/pkgs/applications/video/olive-editor/default.nix index c033c191436835..b0c39aa7b3b585 100644 --- a/pkgs/applications/video/olive-editor/default.nix +++ b/pkgs/applications/video/olive-editor/default.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, pkg-config -, which -, frei0r -, opencolorio -, ffmpeg_6 -, CoreFoundation -, cmake -, wrapQtAppsHook -, openimageio -, openexr_3 -, portaudio -, imath -, qtwayland -, qtmultimedia -, qttools +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + which, + frei0r, + opencolorio, + ffmpeg_6, + CoreFoundation, + cmake, + wrapQtAppsHook, + openimageio, + openexr_3, + portaudio, + imath, + qtwayland, + qtmultimedia, + qttools, }: let @@ -24,10 +25,12 @@ let # we patch support for 2.3+, but 2.5 fails openimageio' = openimageio.overrideAttrs (old: rec { version = "2.4.15.0"; - src = (old.src.override { - rev = "v${version}"; - hash = "sha256-I2/JPmUBDb0bw7qbSZcAkYHB2q2Uo7En7ZurMwWhg/M="; - }); + src = ( + old.src.override { + rev = "v${version}"; + hash = "sha256-I2/JPmUBDb0bw7qbSZcAkYHB2q2Uo7En7ZurMwWhg/M="; + } + ); }); in diff --git a/pkgs/applications/video/openshot-qt/default.nix b/pkgs/applications/video/openshot-qt/default.nix index 1f1da89340c757..fe1b77937e00a1 100644 --- a/pkgs/applications/video/openshot-qt/default.nix +++ b/pkgs/applications/video/openshot-qt/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, mkDerivationWith -, fetchFromGitHub -, doxygen -, gtk3 -, libopenshot -, python3 -, qtbase -, qtsvg -, qtwayland -, wayland -, waylandSupport ? stdenv.hostPlatform.isLinux -, wrapGAppsHook3 +{ + lib, + stdenv, + mkDerivationWith, + fetchFromGitHub, + doxygen, + gtk3, + libopenshot, + python3, + qtbase, + qtsvg, + qtwayland, + wayland, + waylandSupport ? stdenv.hostPlatform.isLinux, + wrapGAppsHook3, }: let @@ -34,12 +35,14 @@ mkDerivationWith python3.pkgs.buildPythonApplication { wrapGAppsHook3 ]; - buildInputs = [ - gtk3 - ] ++ lib.optionals waylandSupport [ - qtwayland - wayland - ]; + buildInputs = + [ + gtk3 + ] + ++ lib.optionals waylandSupport [ + qtwayland + wayland + ]; propagatedBuildInputs = with python3.pkgs; [ httplib2 @@ -62,16 +65,18 @@ mkDerivationWith python3.pkgs.buildPythonApplication { dontWrapGApps = true; dontWrapQtApps = true; - postFixup = '' - wrapProgram $out/bin/openshot-qt \ - '' - # Fix toolbar icons on Darwin - + lib.optionalString stdenv.hostPlatform.isDarwin '' - --suffix QT_PLUGIN_PATH : "${lib.getBin qtsvg}/${qtbase.qtPluginPrefix}" \ - '' + '' - "''${gappsWrapperArgs[@]}" \ - "''${qtWrapperArgs[@]}" - ''; + postFixup = + '' + wrapProgram $out/bin/openshot-qt \ + '' + # Fix toolbar icons on Darwin + + lib.optionalString stdenv.hostPlatform.isDarwin '' + --suffix QT_PLUGIN_PATH : "${lib.getBin qtsvg}/${qtbase.qtPluginPrefix}" \ + '' + + '' + "''${gappsWrapperArgs[@]}" \ + "''${qtWrapperArgs[@]}" + ''; passthru = { inherit libopenshot; diff --git a/pkgs/applications/video/pipe-viewer/default.nix b/pkgs/applications/video/pipe-viewer/default.nix index a1c7de85ebc440..7cab65a58552fa 100644 --- a/pkgs/applications/video/pipe-viewer/default.nix +++ b/pkgs/applications/video/pipe-viewer/default.nix @@ -1,39 +1,45 @@ -{ lib -, fetchFromGitHub -, perl -, buildPerlModule -, makeWrapper -, wrapGAppsHook3 -, withGtk3 ? false -, ffmpeg -, mpv -, wget -, xdg-utils -, yt-dlp -, TestPod -, Gtk3 +{ + lib, + fetchFromGitHub, + perl, + buildPerlModule, + makeWrapper, + wrapGAppsHook3, + withGtk3 ? false, + ffmpeg, + mpv, + wget, + xdg-utils, + yt-dlp, + TestPod, + Gtk3, }: let - perlEnv = perl.withPackages (ps: with ps; [ - AnyURIEscape - DataDump - Encode - FilePath - GetoptLong - HTTPMessage - JSON - JSONXS - LWPProtocolHttps - LWPUserAgentCached - Memoize - PathTools - ScalarListUtils - TermReadLineGnu - TextParsewords - UnicodeLineBreak - ] ++ lib.optionals withGtk3 [ - FileShareDir - ]); + perlEnv = perl.withPackages ( + ps: + with ps; + [ + AnyURIEscape + DataDump + Encode + FilePath + GetoptLong + HTTPMessage + JSON + JSONXS + LWPProtocolHttps + LWPUserAgentCached + Memoize + PathTools + ScalarListUtils + TermReadLineGnu + TextParsewords + UnicodeLineBreak + ] + ++ lib.optionals withGtk3 [ + FileShareDir + ] + ); in buildPerlModule rec { pname = "pipe-viewer"; @@ -46,10 +52,10 @@ buildPerlModule rec { hash = "sha256-crYdbHIDcecfq1FKoRWX3u9x9wqdlaYrBgr7mGdEHeU="; }; - nativeBuildInputs = [ makeWrapper ] - ++ lib.optionals withGtk3 [ wrapGAppsHook3 ]; + nativeBuildInputs = [ makeWrapper ] ++ lib.optionals withGtk3 [ wrapGAppsHook3 ]; - buildInputs = [ perlEnv ] + buildInputs = + [ perlEnv ] # Can't be in perlEnv for wrapGAppsHook3 to work correctly ++ lib.optional withGtk3 Gtk3; @@ -72,15 +78,31 @@ buildPerlModule rec { cp -r share/* $out/share ''; - postFixup = '' - wrapProgram "$out/bin/pipe-viewer" \ - --prefix PATH : "${lib.makeBinPath [ ffmpeg mpv wget yt-dlp ]}" - '' + lib.optionalString withGtk3 '' - # make xdg-open overrideable at runtime - wrapProgram "$out/bin/gtk-pipe-viewer" ''${gappsWrapperArgs[@]} \ - --prefix PATH : "${lib.makeBinPath [ ffmpeg mpv wget yt-dlp ]}" \ - --suffix PATH : "${lib.makeBinPath [ xdg-utils ]}" - ''; + postFixup = + '' + wrapProgram "$out/bin/pipe-viewer" \ + --prefix PATH : "${ + lib.makeBinPath [ + ffmpeg + mpv + wget + yt-dlp + ] + }" + '' + + lib.optionalString withGtk3 '' + # make xdg-open overrideable at runtime + wrapProgram "$out/bin/gtk-pipe-viewer" ''${gappsWrapperArgs[@]} \ + --prefix PATH : "${ + lib.makeBinPath [ + ffmpeg + mpv + wget + yt-dlp + ] + }" \ + --suffix PATH : "${lib.makeBinPath [ xdg-utils ]}" + ''; meta = with lib; { homepage = "https://github.com/trizen/pipe-viewer"; diff --git a/pkgs/applications/video/plex-media-player/default.nix b/pkgs/applications/video/plex-media-player/default.nix index fb10bff45e3302..deb9819e1be73e 100644 --- a/pkgs/applications/video/plex-media-player/default.nix +++ b/pkgs/applications/video/plex-media-player/default.nix @@ -1,6 +1,22 @@ -{ lib, fetchFromGitHub, fetchurl, pkg-config, cmake, python3, mkDerivation -, libX11, libXrandr, qtbase, qtwebchannel, qtwebengine, qtx11extras -, libvdpau, SDL2, mpv, libGL }: +{ + lib, + fetchFromGitHub, + fetchurl, + pkg-config, + cmake, + python3, + mkDerivation, + libX11, + libXrandr, + qtbase, + qtwebchannel, + qtwebengine, + qtx11extras, + libvdpau, + SDL2, + mpv, + libGL, +}: let # During compilation, a CMake bundle is downloaded from `artifacts.plex.tv`, # which then downloads a handful of web client-related files. To enable @@ -9,7 +25,8 @@ let # plex-media-player use the update.sh script, so the versions and hashes # for these files are also updated! depSrcs = import ./deps.nix { inherit fetchurl; }; -in mkDerivation rec { +in +mkDerivation rec { pname = "plex-media-player"; version = "2.58.1"; vsnHash = "ae73e074"; @@ -21,9 +38,23 @@ in mkDerivation rec { sha256 = "1q20fdp5d0blb0q6p2357bwdc2g65cadkgdp4w533ij2nyaxydjd"; }; - nativeBuildInputs = [ pkg-config cmake python3 ]; - buildInputs = [ libX11 libXrandr qtbase qtwebchannel qtwebengine qtx11extras - libvdpau SDL2 mpv libGL ]; + nativeBuildInputs = [ + pkg-config + cmake + python3 + ]; + buildInputs = [ + libX11 + libXrandr + qtbase + qtwebchannel + qtwebengine + qtx11extras + libvdpau + SDL2 + mpv + libGL + ]; preConfigure = with depSrcs; '' mkdir -p build/dependencies @@ -39,7 +70,11 @@ in mkDerivation rec { cmakeFlags = [ "-DQTROOT=${qtbase}" ]; # plexmediaplayer currently segfaults under wayland - qtWrapperArgs = [ "--set" "QT_QPA_PLATFORM" "xcb" ]; + qtWrapperArgs = [ + "--set" + "QT_QPA_PLATFORM" + "xcb" + ]; passthru.updateScript = ./update.sh; diff --git a/pkgs/applications/video/plex-mpv-shim/default.nix b/pkgs/applications/video/plex-mpv-shim/default.nix index 7d862fb216d7b9..3b82e4621add08 100644 --- a/pkgs/applications/video/plex-mpv-shim/default.nix +++ b/pkgs/applications/video/plex-mpv-shim/default.nix @@ -1,5 +1,18 @@ -{ lib, buildPythonApplication, fetchFromGitHub, fetchpatch, python, mpv, requests, python-mpv-jsonipc, pystray, tkinter -, wrapGAppsHook3, gobject-introspection, mpv-shim-default-shaders }: +{ + lib, + buildPythonApplication, + fetchFromGitHub, + fetchpatch, + python, + mpv, + requests, + python-mpv-jsonipc, + pystray, + tkinter, + wrapGAppsHook3, + gobject-introspection, + mpv-shim-default-shaders, +}: buildPythonApplication rec { pname = "plex-mpv-shim"; @@ -25,7 +38,13 @@ buildPythonApplication rec { gobject-introspection ]; - propagatedBuildInputs = [ mpv requests python-mpv-jsonipc pystray tkinter ]; + propagatedBuildInputs = [ + mpv + requests + python-mpv-jsonipc + pystray + tkinter + ]; # needed for pystray to access appindicator using GI preFixup = '' diff --git a/pkgs/applications/video/qarte/default.nix b/pkgs/applications/video/qarte/default.nix index 60b773d3aede51..3b2ba7dc45f758 100644 --- a/pkgs/applications/video/qarte/default.nix +++ b/pkgs/applications/video/qarte/default.nix @@ -1,8 +1,20 @@ -{ mkDerivation, lib, fetchbzr, python3, rtmpdump }: +{ + mkDerivation, + lib, + fetchbzr, + python3, + rtmpdump, +}: let - pythonEnv = python3.withPackages (ps: with ps; [ m3u8 pyqt5-multimedia ]); -in mkDerivation { + pythonEnv = python3.withPackages ( + ps: with ps; [ + m3u8 + pyqt5-multimedia + ] + ); +in +mkDerivation { pname = "qarte"; version = "5.5.0"; diff --git a/pkgs/applications/video/qctools/default.nix b/pkgs/applications/video/qctools/default.nix index 4f19af79388045..2d80efcc648759 100644 --- a/pkgs/applications/video/qctools/default.nix +++ b/pkgs/applications/video/qctools/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, qmake, wrapQtAppsHook, ffmpeg_6, qtmultimedia, qwt }: +{ + lib, + stdenv, + fetchurl, + qmake, + wrapQtAppsHook, + ffmpeg_6, + qtmultimedia, + qwt, +}: stdenv.mkDerivation rec { pname = "qctools"; @@ -11,9 +20,16 @@ stdenv.mkDerivation rec { sourceRoot = "${pname}/Project/QtCreator"; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; - buildInputs = [ ffmpeg_6 qtmultimedia qwt ]; + buildInputs = [ + ffmpeg_6 + qtmultimedia + qwt + ]; installPhase = '' runHook preInstall diff --git a/pkgs/applications/video/qmediathekview/default.nix b/pkgs/applications/video/qmediathekview/default.nix index d08387669eb3a1..4c532f86b14176 100644 --- a/pkgs/applications/video/qmediathekview/default.nix +++ b/pkgs/applications/video/qmediathekview/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, mkDerivation -, fetchFromGitHub -, boost -, qtbase -, xz -, qmake -, pkg-config +{ + lib, + stdenv, + mkDerivation, + fetchFromGitHub, + boost, + qtbase, + xz, + qmake, + pkg-config, }: mkDerivation rec { @@ -25,9 +26,16 @@ mkDerivation rec { --replace /usr "" ''; - buildInputs = [ qtbase xz boost ]; + buildInputs = [ + qtbase + xz + boost + ]; - nativeBuildInputs = [ qmake pkg-config ]; + nativeBuildInputs = [ + qmake + pkg-config + ]; installFlags = [ "INSTALL_ROOT=$(out)" ]; diff --git a/pkgs/applications/video/qstopmotion/default.nix b/pkgs/applications/video/qstopmotion/default.nix index 2f0c66ecd1d124..6d28bc8417a279 100644 --- a/pkgs/applications/video/qstopmotion/default.nix +++ b/pkgs/applications/video/qstopmotion/default.nix @@ -1,25 +1,27 @@ -{ lib, stdenv -, mkDerivation -, fetchurl -, qtbase -, qtmultimedia -, qtquickcontrols -, qtimageformats -, qtxmlpatterns -, ffmpeg -, guvcview -, cmake -, ninja -, libxml2 -, gettext -, pkg-config -, libgphoto2 -, gphoto2 -, v4l-utils -, libv4l -, pcre -, qwt -, extra-cmake-modules +{ + lib, + stdenv, + mkDerivation, + fetchurl, + qtbase, + qtmultimedia, + qtquickcontrols, + qtimageformats, + qtxmlpatterns, + ffmpeg, + guvcview, + cmake, + ninja, + libxml2, + gettext, + pkg-config, + libgphoto2, + gphoto2, + v4l-utils, + libv4l, + pcre, + qwt, + extra-cmake-modules, }: mkDerivation rec { @@ -27,7 +29,9 @@ mkDerivation rec { version = "2.5.2"; src = fetchurl { - url = "mirror://sourceforge/project/${pname}/Version_${builtins.replaceStrings ["."] ["_"] version}/${pname}-${version}-Source.tar.gz"; + url = "mirror://sourceforge/project/${pname}/Version_${ + builtins.replaceStrings [ "." ] [ "_" ] version + }/${pname}-${version}-Source.tar.gz"; sha256 = "sha256-jyBUyadkSuQKXOrr5XZ1jy6of1Qw8S2HPxuOrPc7RnE="; }; @@ -64,7 +68,10 @@ mkDerivation rec { ''; qtWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath [ ffmpeg ]) + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ ffmpeg ]) ]; meta = with lib; { diff --git a/pkgs/applications/video/simplescreenrecorder/default.nix b/pkgs/applications/video/simplescreenrecorder/default.nix index d02c7cffaad3dc..b99821a64e0534 100644 --- a/pkgs/applications/video/simplescreenrecorder/default.nix +++ b/pkgs/applications/video/simplescreenrecorder/default.nix @@ -1,5 +1,26 @@ -{ lib, stdenv, mkDerivation, fetchFromGitHub, alsa-lib, ffmpeg, libjack2, libX11, libXext, libXinerama, qtx11extras -, libXfixes, libGLU, libGL, pkg-config, libpulseaudio, libv4l, qtbase, qttools, cmake, ninja, nix-update-script +{ + lib, + stdenv, + mkDerivation, + fetchFromGitHub, + alsa-lib, + ffmpeg, + libjack2, + libX11, + libXext, + libXinerama, + qtx11extras, + libXfixes, + libGLU, + libGL, + pkg-config, + libpulseaudio, + libv4l, + qtbase, + qttools, + cmake, + ninja, + nix-update-script, }: mkDerivation rec { @@ -27,10 +48,26 @@ mkDerivation rec { --replace-fail "libssr-glinject.so" "$out/lib/libssr-glinject.so" ''; - nativeBuildInputs = [ pkg-config cmake ninja ]; + nativeBuildInputs = [ + pkg-config + cmake + ninja + ]; buildInputs = [ - alsa-lib ffmpeg libjack2 libX11 libXext libXfixes libXinerama libGLU libGL - libpulseaudio libv4l qtbase qttools qtx11extras + alsa-lib + ffmpeg + libjack2 + libX11 + libXext + libXfixes + libXinerama + libGLU + libGL + libpulseaudio + libv4l + qtbase + qttools + qtx11extras ]; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/applications/video/smtube/default.nix b/pkgs/applications/video/smtube/default.nix index 0f50dc3311df67..afb0d254bfe061 100644 --- a/pkgs/applications/video/smtube/default.nix +++ b/pkgs/applications/video/smtube/default.nix @@ -1,4 +1,11 @@ -{ lib, mkDerivation, fetchurl, qmake, qtscript, qtwebkit }: +{ + lib, + mkDerivation, + fetchurl, + qmake, + qtscript, + qtwebkit, +}: mkDerivation rec { version = "21.10.0"; @@ -16,7 +23,10 @@ mkDerivation rec { dontUseQmakeConfigure = true; nativeBuildInputs = [ qmake ]; - buildInputs = [ qtscript qtwebkit ]; + buildInputs = [ + qtscript + qtwebkit + ]; meta = with lib; { description = "Play and download Youtube videos"; diff --git a/pkgs/applications/video/stremio/default.nix b/pkgs/applications/video/stremio/default.nix index 0b6495c8b1e681..0bfc18fb2e1e7e 100644 --- a/pkgs/applications/video/stremio/default.nix +++ b/pkgs/applications/video/stremio/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchurl -, ffmpeg -, mpv -, nodejs -, qmake -, qtwebengine -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + ffmpeg, + mpv, + nodejs, + qmake, + qtwebengine, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -27,9 +28,15 @@ stdenv.mkDerivation rec { hash = "sha256-aD3niQpgq1EiZLacnEFgmqUV+bc4rvGN9IA+9T4XF10="; }; - buildInputs = [ qtwebengine mpv ]; + buildInputs = [ + qtwebengine + mpv + ]; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; postInstall = '' mkdir -p $out/{bin,share/applications} @@ -49,7 +56,10 @@ stdenv.mkDerivation rec { # (Server-side) web UI is closed source now, apparently they work on open-sourcing it. # server.js appears to be MIT-licensed, but I can't find how they actually build it. # https://www.reddit.com/r/StremioAddons/comments/n2ob04/a_summary_of_how_stremio_works_internally_and/ - license = with licenses; [ gpl3 mit ]; + license = with licenses; [ + gpl3 + mit + ]; maintainers = with maintainers; [ abbradar ]; platforms = platforms.linux; }; diff --git a/pkgs/applications/video/vdr/default.nix b/pkgs/applications/video/vdr/default.nix index 50c0d5ce4ce07d..0b80ad8186b2e7 100644 --- a/pkgs/applications/video/vdr/default.nix +++ b/pkgs/applications/video/vdr/default.nix @@ -1,8 +1,20 @@ -{ stdenv, fetchgit, fontconfig, libjpeg, libcap, freetype, fribidi, pkg-config -, gettext, systemd, perl, lib -, enableSystemd ? true -, enableBidi ? true -}: stdenv.mkDerivation rec { +{ + stdenv, + fetchgit, + fontconfig, + libjpeg, + libcap, + freetype, + fribidi, + pkg-config, + gettext, + systemd, + perl, + lib, + enableSystemd ? true, + enableBidi ? true, +}: +stdenv.mkDerivation rec { pname = "vdr"; version = "2.6.9"; @@ -17,34 +29,57 @@ postPatch = "substituteInPlace Makefile --replace libsystemd-daemon libsystemd"; - buildInputs = [ fontconfig libjpeg libcap freetype perl ] - ++ lib.optional enableSystemd systemd - ++ lib.optional enableBidi fribidi; + buildInputs = + [ + fontconfig + libjpeg + libcap + freetype + perl + ] + ++ lib.optional enableSystemd systemd + ++ lib.optional enableBidi fribidi; - buildFlags = [ "vdr" "i18n" ] - ++ lib.optional enableSystemd "SDNOTIFY=1" - ++ lib.optional enableBidi "BIDI=1"; + buildFlags = + [ + "vdr" + "i18n" + ] + ++ lib.optional enableSystemd "SDNOTIFY=1" + ++ lib.optional enableBidi "BIDI=1"; nativeBuildInputs = [ perl ]; # plugins uses the same build environment as vdr - propagatedNativeBuildInputs = [ pkg-config gettext ]; + propagatedNativeBuildInputs = [ + pkg-config + gettext + ]; installFlags = [ "DESTDIR=$(out)" "PREFIX=" # needs to be empty, otherwise plugins try to install at same prefix ]; - installTargets = [ "install-pc" "install-bin" "install-doc" "install-i18n" - "install-includes" ]; + installTargets = [ + "install-pc" + "install-bin" + "install-doc" + "install-i18n" + "install-includes" + ]; postInstall = '' mkdir -p $out/lib/vdr # only needed if vdr is started without any plugin mkdir -p $out/share/vdr/conf cp *.conf $out/share/vdr/conf - ''; + ''; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; meta = with lib; { homepage = "http://www.tvdr.de/"; diff --git a/pkgs/applications/video/vdr/plugins.nix b/pkgs/applications/video/vdr/plugins.nix index ef497d5a8c9e32..ef35f18b2f86e4 100644 --- a/pkgs/applications/video/vdr/plugins.nix +++ b/pkgs/applications/video/vdr/plugins.nix @@ -1,36 +1,54 @@ -{ lib, stdenv, vdr, fetchFromGitHub -, graphicsmagick -, boost, libgcrypt, ncurses -, callPackage -}: let - mkPlugin = name: stdenv.mkDerivation { - name = "vdr-${name}-${vdr.version}"; - inherit (vdr) src; - buildInputs = [ vdr ]; - preConfigure = "cd PLUGINS/src/${name}"; - installFlags = [ "DESTDIR=$(out)" ]; - }; -in { +{ + lib, + stdenv, + vdr, + fetchFromGitHub, + graphicsmagick, + boost, + libgcrypt, + ncurses, + callPackage, +}: +let + mkPlugin = + name: + stdenv.mkDerivation { + name = "vdr-${name}-${vdr.version}"; + inherit (vdr) src; + buildInputs = [ vdr ]; + preConfigure = "cd PLUGINS/src/${name}"; + installFlags = [ "DESTDIR=$(out)" ]; + }; +in +{ - epgsearch = callPackage ./epgsearch {}; + epgsearch = callPackage ./epgsearch { }; - markad = callPackage ./markad {}; + markad = callPackage ./markad { }; - nopacity = callPackage ./nopacity {}; + nopacity = callPackage ./nopacity { }; - softhddevice = callPackage ./softhddevice {}; + softhddevice = callPackage ./softhddevice { }; - streamdev = callPackage ./streamdev {}; + streamdev = callPackage ./streamdev { }; - xineliboutput = callPackage ./xineliboutput {}; + xineliboutput = callPackage ./xineliboutput { }; - skincurses = (mkPlugin "skincurses").overrideAttrs(oldAttr: { + skincurses = (mkPlugin "skincurses").overrideAttrs (oldAttr: { buildInputs = oldAttr.buildInputs ++ [ ncurses ]; }); - inherit (lib.genAttrs [ - "epgtableid0" "hello" "osddemo" "pictures" "servicedemo" "status" "svdrpdemo" - ] mkPlugin); + inherit + (lib.genAttrs [ + "epgtableid0" + "hello" + "osddemo" + "pictures" + "servicedemo" + "status" + "svdrpdemo" + ] mkPlugin) + ; femon = stdenv.mkDerivation rec { pname = "vdr-femon"; @@ -95,7 +113,10 @@ in { sha256 = "19hkwmaw6nwak38bv6cm2vcjjkf4w5yjyxb98qq6zfjjh5wq54aa"; }; - buildInputs = [ vdr graphicsmagick ]; + buildInputs = [ + vdr + graphicsmagick + ]; buildFlags = [ "DESTDIR=$(out)" @@ -132,7 +153,11 @@ in { fetchSubmodules = true; }; - buildInputs = [ vdr boost libgcrypt ]; + buildInputs = [ + vdr + boost + libgcrypt + ]; installFlags = [ "DESTDIR=$(out)" ]; diff --git a/pkgs/applications/video/vdr/softhddevice/default.nix b/pkgs/applications/video/vdr/softhddevice/default.nix index 612731acdcc10a..fc8798aacf0cdf 100644 --- a/pkgs/applications/video/vdr/softhddevice/default.nix +++ b/pkgs/applications/video/vdr/softhddevice/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, vdr -, alsa-lib -, fetchFromGitHub -, xcbutilwm -, xorgserver -, ffmpeg -, libva -, libvdpau -, xorg -, libGL -, libGLU +{ + lib, + stdenv, + vdr, + alsa-lib, + fetchFromGitHub, + xcbutilwm, + xorgserver, + ffmpeg, + libva, + libvdpau, + xorg, + libGL, + libGLU, }: stdenv.mkDerivation rec { pname = "vdr-softhddevice"; diff --git a/pkgs/applications/video/vdr/streamdev/default.nix b/pkgs/applications/video/vdr/streamdev/default.nix index 248f06538393f4..7c1defec74e74f 100644 --- a/pkgs/applications/video/vdr/streamdev/default.nix +++ b/pkgs/applications/video/vdr/streamdev/default.nix @@ -1,7 +1,8 @@ -{ stdenv -, fetchFromGitHub -, lib -, vdr +{ + stdenv, + fetchFromGitHub, + lib, + vdr, }: stdenv.mkDerivation rec { pname = "vdr-streamdev"; @@ -29,7 +30,7 @@ stdenv.mkDerivation rec { vdr ]; - meta = with lib;{ + meta = with lib; { inherit (src.meta) homepage; description = "This PlugIn is a VDR implementation of the VTP (Video Transfer Protocol) Version 0.0.3 (see file PROTOCOL) and a basic HTTP Streaming Protocol"; maintainers = [ maintainers.ck3d ]; diff --git a/pkgs/applications/video/vdr/wrapper.nix b/pkgs/applications/video/vdr/wrapper.nix index 431d2dae4f0495..9680d4ad3c2e0c 100644 --- a/pkgs/applications/video/vdr/wrapper.nix +++ b/pkgs/applications/video/vdr/wrapper.nix @@ -1,12 +1,18 @@ -{ symlinkJoin, lib, makeWrapper, vdr -, plugins ? [] -}: let +{ + symlinkJoin, + lib, + makeWrapper, + vdr, + plugins ? [ ], +}: +let makeXinePluginPath = l: lib.concatStringsSep ":" (map (p: "${p}/lib/xine/plugins") l); - requiredXinePlugins = lib.flatten (map (p: p.passthru.requiredXinePlugins or []) plugins); + requiredXinePlugins = lib.flatten (map (p: p.passthru.requiredXinePlugins or [ ]) plugins); -in symlinkJoin { +in +symlinkJoin { name = "vdr-with-plugins-${lib.getVersion vdr}"; @@ -22,9 +28,7 @@ in symlinkJoin { meta = with vdr.meta; { inherit license homepage; - description = description - + " (with plugins: " - + lib.concatStringsSep ", " (map (x: ""+x.name) plugins) - + ")"; + description = + description + " (with plugins: " + lib.concatStringsSep ", " (map (x: "" + x.name) plugins) + ")"; }; } diff --git a/pkgs/applications/video/vdr/xineliboutput/default.nix b/pkgs/applications/video/vdr/xineliboutput/default.nix index a01ee1481f8adb..78deb1b0e98a98 100644 --- a/pkgs/applications/video/vdr/xineliboutput/default.nix +++ b/pkgs/applications/video/vdr/xineliboutput/default.nix @@ -1,23 +1,24 @@ -{ stdenv -, fetchurl -, lib -, vdr -, libcap -, libvdpau -, xine-lib -, libjpeg -, libextractor -, libglvnd -, libGLU -, libX11 -, libXext -, libXrender -, libXrandr -, ffmpeg -, avahi -, wayland -, makeWrapper -, dbus-glib +{ + stdenv, + fetchurl, + lib, + vdr, + libcap, + libvdpau, + xine-lib, + libjpeg, + libextractor, + libglvnd, + libGLU, + libX11, + libXext, + libXrender, + libXrandr, + ffmpeg, + avahi, + wayland, + makeWrapper, + dbus-glib, }: let makeXinePluginPath = l: lib.concatStringsSep ":" (map (p: "${p}/lib/xine/plugins") l); @@ -50,7 +51,12 @@ let postFixup = '' for f in $out/bin/*; do wrapProgram $f \ - --prefix XINE_PLUGIN_PATH ":" "${makeXinePluginPath [ "$out" xine-lib ]}" + --prefix XINE_PLUGIN_PATH ":" "${ + makeXinePluginPath [ + "$out" + xine-lib + ] + }" done ''; @@ -75,9 +81,12 @@ let wayland ]; - passthru.requiredXinePlugins = [ xine-lib self ]; + passthru.requiredXinePlugins = [ + xine-lib + self + ]; - meta = with lib;{ + meta = with lib; { homepage = "https://sourceforge.net/projects/xineliboutput/"; description = "Xine-lib based software output device for VDR"; maintainers = [ maintainers.ck3d ]; diff --git a/pkgs/applications/video/vokoscreen/default.nix b/pkgs/applications/video/vokoscreen/default.nix index cb0df69ee2c53e..b691dde96aabfe 100644 --- a/pkgs/applications/video/vokoscreen/default.nix +++ b/pkgs/applications/video/vokoscreen/default.nix @@ -1,6 +1,17 @@ -{ lib, fetchFromGitHub, mkDerivation -, pkg-config, qtbase, qttools, qmake, qtmultimedia, qtx11extras, alsa-lib, libv4l, libXrandr -, ffmpeg +{ + lib, + fetchFromGitHub, + mkDerivation, + pkg-config, + qtbase, + qttools, + qmake, + qtmultimedia, + qtx11extras, + alsa-lib, + libv4l, + libXrandr, + ffmpeg, }: mkDerivation rec { @@ -9,13 +20,16 @@ mkDerivation rec { version = "2.5.8-beta"; src = fetchFromGitHub { - owner = "vkohaupt"; - repo = "vokoscreen"; - rev = version; - sha256 = "1a85vbsi53mhzva49smqwcs61c51wv3ic410nvb9is9nlsbifwan"; + owner = "vkohaupt"; + repo = "vokoscreen"; + rev = version; + sha256 = "1a85vbsi53mhzva49smqwcs61c51wv3ic410nvb9is9nlsbifwan"; }; - nativeBuildInputs = [ pkg-config qmake ]; + nativeBuildInputs = [ + pkg-config + qmake + ]; buildInputs = [ alsa-lib libv4l diff --git a/pkgs/applications/video/webcamoid/default.nix b/pkgs/applications/video/webcamoid/default.nix index 0118d6c09be0f7..3ee2f0db92e943 100644 --- a/pkgs/applications/video/webcamoid/default.nix +++ b/pkgs/applications/video/webcamoid/default.nix @@ -1,7 +1,22 @@ -{ lib, fetchFromGitHub, fetchpatch2, pkg-config, libxcb, mkDerivation, cmake -, qtbase, qtdeclarative, qtquickcontrols, qtquickcontrols2 -, ffmpeg, gst_all_1, libpulseaudio, alsa-lib, jack2 -, v4l-utils }: +{ + lib, + fetchFromGitHub, + fetchpatch2, + pkg-config, + libxcb, + mkDerivation, + cmake, + qtbase, + qtdeclarative, + qtquickcontrols, + qtquickcontrols2, + ffmpeg, + gst_all_1, + libpulseaudio, + alsa-lib, + jack2, + v4l-utils, +}: mkDerivation rec { pname = "webcamoid"; version = "9.1.1"; @@ -23,14 +38,23 @@ mkDerivation rec { buildInputs = [ libxcb - qtbase qtdeclarative qtquickcontrols qtquickcontrols2 + qtbase + qtdeclarative + qtquickcontrols + qtquickcontrols2 ffmpeg - gst_all_1.gstreamer gst_all_1.gst-plugins-base - alsa-lib libpulseaudio jack2 + gst_all_1.gstreamer + gst_all_1.gst-plugins-base + alsa-lib + libpulseaudio + jack2 v4l-utils ]; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; meta = with lib; { description = "Webcam Capture Software"; diff --git a/pkgs/applications/video/youtube-tui/default.nix b/pkgs/applications/video/youtube-tui/default.nix index 70458c7f6235c2..64b18ad5c43b11 100644 --- a/pkgs/applications/video/youtube-tui/default.nix +++ b/pkgs/applications/video/youtube-tui/default.nix @@ -1,17 +1,18 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, xorg -, stdenv -, python3 -, makeBinaryWrapper -, libsixel -, mpv -, CoreFoundation -, Security -, AppKit +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + xorg, + stdenv, + python3, + makeBinaryWrapper, + libsixel, + mpv, + CoreFoundation, + Security, + AppKit, }: rustPlatform.buildRustPackage rec { @@ -38,21 +39,23 @@ rustPlatform.buildRustPackage rec { makeBinaryWrapper ]; - buildInputs = [ - openssl - xorg.libxcb - libsixel - mpv - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreFoundation - Security - AppKit - ]; + buildInputs = + [ + openssl + xorg.libxcb + libsixel + mpv + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreFoundation + Security + AppKit + ]; # sixel-sys is dynamically linked to libsixel postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' wrapProgram $out/bin/youtube-tui \ - --prefix DYLD_LIBRARY_PATH : "${lib.makeLibraryPath [libsixel]}" + --prefix DYLD_LIBRARY_PATH : "${lib.makeLibraryPath [ libsixel ]}" ''; meta = with lib; { diff --git a/pkgs/applications/video/yuview/default.nix b/pkgs/applications/video/yuview/default.nix index a6c7ad6ceb869a..3a15d32c42052a 100644 --- a/pkgs/applications/video/yuview/default.nix +++ b/pkgs/applications/video/yuview/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, qmake -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -16,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-2mNIuyY/ni+zkUc8V/iXUEa7JeBJyOnNod7friMYAm8="; }; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; patches = [ ./disable_version_check.patch ]; diff --git a/pkgs/applications/virtualization/OVMF/default.nix b/pkgs/applications/virtualization/OVMF/default.nix index ac2f2f2302f56f..f9ecceb226debe 100644 --- a/pkgs/applications/virtualization/OVMF/default.nix +++ b/pkgs/applications/virtualization/OVMF/default.nix @@ -1,46 +1,64 @@ -{ stdenv, nixosTests, lib, edk2, util-linux, nasm, acpica-tools, llvmPackages -, fetchFromGitLab, python3, pexpect, xorriso, qemu, dosfstools, mtools -, fdSize2MB ? false -, fdSize4MB ? secureBoot -, secureBoot ? false -, systemManagementModeRequired ? secureBoot && stdenv.hostPlatform.isx86 -# Whether to create an nvram variables template -# which includes the MSFT secure boot keys -, msVarsTemplate ? false -# When creating the nvram variables template with -# the MSFT keys, we also must provide a certificate -# to use as the PK and first KEK for the keystore. -# -# By default, we use Debian's cert. This default -# should change to a NixOS cert once we have our -# own secure boot signing infrastructure. -# -# Ignored if msVarsTemplate is false. -, vendorPkKek ? "$NIX_BUILD_TOP/debian/PkKek-1-Debian.pem" -, httpSupport ? false -, tpmSupport ? false -, tlsSupport ? false -, debug ? false -# Usually, this option is broken, do not use it except if you know what you are -# doing. -, sourceDebug ? false -, projectDscPath ? { - i686 = "OvmfPkg/OvmfPkgIa32.dsc"; - x86_64 = "OvmfPkg/OvmfPkgX64.dsc"; - aarch64 = "ArmVirtPkg/ArmVirtQemu.dsc"; - riscv64 = "OvmfPkg/RiscVVirt/RiscVVirtQemu.dsc"; - loongarch64 = "OvmfPkg/LoongArchVirt/LoongArchVirtQemu.dsc"; - }.${stdenv.hostPlatform.parsed.cpu.name} - or (throw "Unsupported OVMF `projectDscPath` on ${stdenv.hostPlatform.parsed.cpu.name}") -, fwPrefix ? { - i686 = "OVMF"; - x86_64 = "OVMF"; - aarch64 = "AAVMF"; - riscv64 = "RISCV_VIRT"; - loongarch64 = "LOONGARCH_VIRT"; - }.${stdenv.hostPlatform.parsed.cpu.name} - or (throw "Unsupported OVMF `fwPrefix` on ${stdenv.hostPlatform.parsed.cpu.name}") -, metaPlatforms ? edk2.meta.platforms +{ + stdenv, + nixosTests, + lib, + edk2, + util-linux, + nasm, + acpica-tools, + llvmPackages, + fetchFromGitLab, + python3, + pexpect, + xorriso, + qemu, + dosfstools, + mtools, + fdSize2MB ? false, + fdSize4MB ? secureBoot, + secureBoot ? false, + systemManagementModeRequired ? secureBoot && stdenv.hostPlatform.isx86, + # Whether to create an nvram variables template + # which includes the MSFT secure boot keys + msVarsTemplate ? false, + # When creating the nvram variables template with + # the MSFT keys, we also must provide a certificate + # to use as the PK and first KEK for the keystore. + # + # By default, we use Debian's cert. This default + # should change to a NixOS cert once we have our + # own secure boot signing infrastructure. + # + # Ignored if msVarsTemplate is false. + vendorPkKek ? "$NIX_BUILD_TOP/debian/PkKek-1-Debian.pem", + httpSupport ? false, + tpmSupport ? false, + tlsSupport ? false, + debug ? false, + # Usually, this option is broken, do not use it except if you know what you are + # doing. + sourceDebug ? false, + projectDscPath ? + { + i686 = "OvmfPkg/OvmfPkgIa32.dsc"; + x86_64 = "OvmfPkg/OvmfPkgX64.dsc"; + aarch64 = "ArmVirtPkg/ArmVirtQemu.dsc"; + riscv64 = "OvmfPkg/RiscVVirt/RiscVVirtQemu.dsc"; + loongarch64 = "OvmfPkg/LoongArchVirt/LoongArchVirtQemu.dsc"; + } + .${stdenv.hostPlatform.parsed.cpu.name} + or (throw "Unsupported OVMF `projectDscPath` on ${stdenv.hostPlatform.parsed.cpu.name}"), + fwPrefix ? + { + i686 = "OVMF"; + x86_64 = "OVMF"; + aarch64 = "AAVMF"; + riscv64 = "RISCV_VIRT"; + loongarch64 = "LOONGARCH_VIRT"; + } + .${stdenv.hostPlatform.parsed.cpu.name} + or (throw "Unsupported OVMF `fwPrefix` on ${stdenv.hostPlatform.parsed.cpu.name}"), + metaPlatforms ? edk2.meta.platforms, }: let @@ -94,14 +112,37 @@ edk2.mkDerivation projectDscPath (finalAttrs: { pname = "OVMF"; inherit version; - outputs = [ "out" "fd" ]; + outputs = [ + "out" + "fd" + ]; - nativeBuildInputs = [ util-linux nasm acpica-tools ] - ++ lib.optionals stdenv.cc.isClang [ llvmPackages.bintools llvmPackages.llvm ] - ++ lib.optionals msVarsTemplate [ python3 pexpect xorriso qemu dosfstools mtools ]; + nativeBuildInputs = + [ + util-linux + nasm + acpica-tools + ] + ++ lib.optionals stdenv.cc.isClang [ + llvmPackages.bintools + llvmPackages.llvm + ] + ++ lib.optionals msVarsTemplate [ + python3 + pexpect + xorriso + qemu + dosfstools + mtools + ]; strictDeps = true; - hardeningDisable = [ "format" "stackprotector" "pic" "fortify" ]; + hardeningDisable = [ + "format" + "stackprotector" + "pic" + "fortify" + ]; buildFlags = # IPv6 has no reason to be disabled. @@ -110,11 +151,18 @@ edk2.mkDerivation projectDscPath (finalAttrs: { ++ lib.optionals sourceDebug [ "-D SOURCE_DEBUG_ENABLE=TRUE" ] ++ lib.optionals secureBoot [ "-D SECURE_BOOT_ENABLE=TRUE" ] ++ lib.optionals systemManagementModeRequired [ "-D SMM_REQUIRE=TRUE" ] - ++ lib.optionals fdSize2MB ["-D FD_SIZE_2MB"] - ++ lib.optionals fdSize4MB ["-D FD_SIZE_4MB"] - ++ lib.optionals httpSupport [ "-D NETWORK_HTTP_ENABLE=TRUE" "-D NETWORK_HTTP_BOOT_ENABLE=TRUE" ] + ++ lib.optionals fdSize2MB [ "-D FD_SIZE_2MB" ] + ++ lib.optionals fdSize4MB [ "-D FD_SIZE_4MB" ] + ++ lib.optionals httpSupport [ + "-D NETWORK_HTTP_ENABLE=TRUE" + "-D NETWORK_HTTP_BOOT_ENABLE=TRUE" + ] ++ lib.optionals tlsSupport [ "-D NETWORK_TLS_ENABLE=TRUE" ] - ++ lib.optionals tpmSupport [ "-D TPM_ENABLE" "-D TPM2_ENABLE" "-D TPM2_CONFIG_ENABLE"]; + ++ lib.optionals tpmSupport [ + "-D TPM_ENABLE" + "-D TPM2_ENABLE" + "-D TPM2_CONFIG_ENABLE" + ]; buildConfig = if debug then "DEBUG" else "RELEASE"; env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Qunused-arguments"; @@ -132,80 +180,101 @@ edk2.mkDerivation projectDscPath (finalAttrs: { export PYTHONPATH=$NIX_BUILD_TOP/debian/python:$PYTHONPATH ''; - postBuild = lib.optionalString (stdenv.hostPlatform.isAarch || stdenv.hostPlatform.isLoongArch64) '' - ( - cd ${buildPrefix}/FV - cp QEMU_EFI.fd ${fwPrefix}_CODE.fd - cp QEMU_VARS.fd ${fwPrefix}_VARS.fd - ) - '' + lib.optionalString stdenv.hostPlatform.isAarch '' - # QEMU expects 64MiB CODE and VARS files on ARM/AARCH64 architectures - # Truncate the firmware files to the expected size - truncate -s 64M ${buildPrefix}/FV/${fwPrefix}_CODE.fd - truncate -s 64M ${buildPrefix}/FV/${fwPrefix}_VARS.fd - '' + lib.optionalString stdenv.hostPlatform.isRiscV '' - truncate -s 32M ${buildPrefix}/FV/${fwPrefix}_CODE.fd - truncate -s 32M ${buildPrefix}/FV/${fwPrefix}_VARS.fd - '' + lib.optionalString msVarsTemplate '' - ( - cd ${buildPrefix} - # locale must be set on Darwin for invocations of mtools to work correctly - LC_ALL=C python3 $NIX_BUILD_TOP/debian/edk2-vars-generator.py \ - --flavor ${msVarsArgs.flavor} \ - --enrolldefaultkeys ${msVarsArgs.archDir}/EnrollDefaultKeys.efi \ - --shell ${msVarsArgs.archDir}/Shell.efi \ - --code FV/${fwPrefix}_CODE.fd \ - --vars-template FV/${fwPrefix}_VARS.fd \ - --certificate `< $NIX_BUILD_TOP/$sourceRoot/vendor-cert-string` \ - --out-file FV/${fwPrefix}_VARS.ms.fd - ) - ''; + postBuild = + lib.optionalString (stdenv.hostPlatform.isAarch || stdenv.hostPlatform.isLoongArch64) '' + ( + cd ${buildPrefix}/FV + cp QEMU_EFI.fd ${fwPrefix}_CODE.fd + cp QEMU_VARS.fd ${fwPrefix}_VARS.fd + ) + '' + + lib.optionalString stdenv.hostPlatform.isAarch '' + # QEMU expects 64MiB CODE and VARS files on ARM/AARCH64 architectures + # Truncate the firmware files to the expected size + truncate -s 64M ${buildPrefix}/FV/${fwPrefix}_CODE.fd + truncate -s 64M ${buildPrefix}/FV/${fwPrefix}_VARS.fd + '' + + lib.optionalString stdenv.hostPlatform.isRiscV '' + truncate -s 32M ${buildPrefix}/FV/${fwPrefix}_CODE.fd + truncate -s 32M ${buildPrefix}/FV/${fwPrefix}_VARS.fd + '' + + lib.optionalString msVarsTemplate '' + ( + cd ${buildPrefix} + # locale must be set on Darwin for invocations of mtools to work correctly + LC_ALL=C python3 $NIX_BUILD_TOP/debian/edk2-vars-generator.py \ + --flavor ${msVarsArgs.flavor} \ + --enrolldefaultkeys ${msVarsArgs.archDir}/EnrollDefaultKeys.efi \ + --shell ${msVarsArgs.archDir}/Shell.efi \ + --code FV/${fwPrefix}_CODE.fd \ + --vars-template FV/${fwPrefix}_VARS.fd \ + --certificate `< $NIX_BUILD_TOP/$sourceRoot/vendor-cert-string` \ + --out-file FV/${fwPrefix}_VARS.ms.fd + ) + ''; # TODO: Usage of -bios OVMF.fd is discouraged: https://lists.katacontainers.io/pipermail/kata-dev/2021-January/001650.html # We should remove the isx86-specifc block here once we're ready to update nixpkgs to stop using that and update the # release notes accordingly. - postInstall = '' - mkdir -vp $fd/FV - '' + lib.optionalString (builtins.elem fwPrefix [ - "OVMF" "AAVMF" "RISCV_VIRT" "LOONGARCH_VIRT" - ]) '' - mv -v $out/FV/${fwPrefix}_{CODE,VARS}.fd $fd/FV - '' + lib.optionalString stdenv.hostPlatform.isx86 '' - mv -v $out/FV/${fwPrefix}.fd $fd/FV - '' + lib.optionalString msVarsTemplate '' - mv -v $out/FV/${fwPrefix}_VARS.ms.fd $fd/FV - ln -sv $fd/FV/${fwPrefix}_CODE{,.ms}.fd - '' + lib.optionalString stdenv.hostPlatform.isAarch '' - mv -v $out/FV/QEMU_{EFI,VARS}.fd $fd/FV - # Add symlinks for Fedora dir layout: https://src.fedoraproject.org/rpms/edk2/blob/main/f/edk2.spec - mkdir -vp $fd/AAVMF - ln -s $fd/FV/AAVMF_CODE.fd $fd/AAVMF/QEMU_EFI-pflash.raw - ln -s $fd/FV/AAVMF_VARS.fd $fd/AAVMF/vars-template-pflash.raw - ''; + postInstall = + '' + mkdir -vp $fd/FV + '' + + + lib.optionalString + (builtins.elem fwPrefix [ + "OVMF" + "AAVMF" + "RISCV_VIRT" + "LOONGARCH_VIRT" + ]) + '' + mv -v $out/FV/${fwPrefix}_{CODE,VARS}.fd $fd/FV + '' + + lib.optionalString stdenv.hostPlatform.isx86 '' + mv -v $out/FV/${fwPrefix}.fd $fd/FV + '' + + lib.optionalString msVarsTemplate '' + mv -v $out/FV/${fwPrefix}_VARS.ms.fd $fd/FV + ln -sv $fd/FV/${fwPrefix}_CODE{,.ms}.fd + '' + + lib.optionalString stdenv.hostPlatform.isAarch '' + mv -v $out/FV/QEMU_{EFI,VARS}.fd $fd/FV + # Add symlinks for Fedora dir layout: https://src.fedoraproject.org/rpms/edk2/blob/main/f/edk2.spec + mkdir -vp $fd/AAVMF + ln -s $fd/FV/AAVMF_CODE.fd $fd/AAVMF/QEMU_EFI-pflash.raw + ln -s $fd/FV/AAVMF_VARS.fd $fd/AAVMF/vars-template-pflash.raw + ''; dontPatchELF = true; passthru = - let - prefix = "${finalAttrs.finalPackage.fd}/FV/${fwPrefix}"; - in { - firmware = "${prefix}_CODE.fd"; - variables = "${prefix}_VARS.fd"; - variablesMs = - assert msVarsTemplate; - "${prefix}_VARS.ms.fd"; - # This will test the EFI firmware for the host platform as part of the NixOS Tests setup. - tests.basic-systemd-boot = nixosTests.systemd-boot.basic; - tests.secureBoot-systemd-boot = nixosTests.systemd-boot.secureBoot; - inherit secureBoot systemManagementModeRequired; - }; + let + prefix = "${finalAttrs.finalPackage.fd}/FV/${fwPrefix}"; + in + { + firmware = "${prefix}_CODE.fd"; + variables = "${prefix}_VARS.fd"; + variablesMs = + assert msVarsTemplate; + "${prefix}_VARS.ms.fd"; + # This will test the EFI firmware for the host platform as part of the NixOS Tests setup. + tests.basic-systemd-boot = nixosTests.systemd-boot.basic; + tests.secureBoot-systemd-boot = nixosTests.systemd-boot.secureBoot; + inherit secureBoot systemManagementModeRequired; + }; meta = { description = "Sample UEFI firmware for QEMU and KVM"; homepage = "https://github.com/tianocore/tianocore.github.io/wiki/OVMF"; license = lib.licenses.bsd2; platforms = metaPlatforms; - maintainers = with lib.maintainers; [ adamcstephens raitobezarius mjoerg sigmasquadron ]; + maintainers = with lib.maintainers; [ + adamcstephens + raitobezarius + mjoerg + sigmasquadron + ]; broken = stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64; }; }) diff --git a/pkgs/applications/virtualization/cri-o/default.nix b/pkgs/applications/virtualization/cri-o/default.nix index ce7e3bc4965bf8..9e4c406e27b4bc 100644 --- a/pkgs/applications/virtualization/cri-o/default.nix +++ b/pkgs/applications/virtualization/cri-o/default.nix @@ -1,16 +1,17 @@ -{ lib -, btrfs-progs -, buildGoModule -, fetchFromGitHub -, glibc -, gpgme -, installShellFiles -, libapparmor -, libseccomp -, libselinux -, lvm2 -, pkg-config -, nixosTests +{ + lib, + btrfs-progs, + buildGoModule, + fetchFromGitHub, + glibc, + gpgme, + installShellFiles, + libapparmor, + libseccomp, + libselinux, + lvm2, + pkg-config, + nixosTests, }: buildGoModule rec { @@ -27,17 +28,28 @@ buildGoModule rec { doCheck = false; - outputs = [ "out" "man" ]; - nativeBuildInputs = [ installShellFiles pkg-config ]; + outputs = [ + "out" + "man" + ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + ]; - buildInputs = [ - btrfs-progs - gpgme - libapparmor - libseccomp - libselinux - lvm2 - ] ++ lib.optionals (glibc != null) [ glibc glibc.static ]; + buildInputs = + [ + btrfs-progs + gpgme + libapparmor + libseccomp + libselinux + lvm2 + ] + ++ lib.optionals (glibc != null) [ + glibc + glibc.static + ]; BUILDTAGS = "apparmor seccomp selinux containers_image_openpgp containers_image_ostree_stub"; buildPhase = '' diff --git a/pkgs/applications/virtualization/cri-o/wrapper.nix b/pkgs/applications/virtualization/cri-o/wrapper.nix index c8af1b909c8488..e0f546dbe95648 100644 --- a/pkgs/applications/virtualization/cri-o/wrapper.nix +++ b/pkgs/applications/virtualization/cri-o/wrapper.nix @@ -1,52 +1,59 @@ -{ cri-o-unwrapped -, runCommand -, makeWrapper -, lib -, extraPackages ? [] -, runc # Default container runtime -, conntrack-tools -, crun # Container runtime (default with cgroups v2 for podman/buildah) -, conmon # Container runtime monitor -, util-linux # nsenter -, iptables +{ + cri-o-unwrapped, + runCommand, + makeWrapper, + lib, + extraPackages ? [ ], + runc, # Default container runtime + conntrack-tools, + crun, # Container runtime (default with cgroups v2 for podman/buildah) + conmon, # Container runtime monitor + util-linux, # nsenter + iptables, }: let - binPath = lib.makeBinPath ([ - runc - conntrack-tools - crun - conmon - util-linux - iptables - ] ++ extraPackages); - -in runCommand cri-o-unwrapped.name { - name = "${cri-o-unwrapped.pname}-wrapper-${cri-o-unwrapped.version}"; - inherit (cri-o-unwrapped) pname version passthru; - - preferLocalBuild = true; - - meta = builtins.removeAttrs cri-o-unwrapped.meta [ "outputsToInstall" ]; - - outputs = [ - "out" - "man" - ]; - - nativeBuildInputs = [ - makeWrapper - ]; - -} '' - ln -s ${cri-o-unwrapped.man} $man - - mkdir -p $out/bin - ln -s ${cri-o-unwrapped}/etc $out/etc - ln -s ${cri-o-unwrapped}/share $out/share - - for p in ${cri-o-unwrapped}/bin/*; do - makeWrapper $p $out/bin/''${p##*/} \ - --prefix PATH : ${binPath} - done -'' + binPath = lib.makeBinPath ( + [ + runc + conntrack-tools + crun + conmon + util-linux + iptables + ] + ++ extraPackages + ); + +in +runCommand cri-o-unwrapped.name + { + name = "${cri-o-unwrapped.pname}-wrapper-${cri-o-unwrapped.version}"; + inherit (cri-o-unwrapped) pname version passthru; + + preferLocalBuild = true; + + meta = builtins.removeAttrs cri-o-unwrapped.meta [ "outputsToInstall" ]; + + outputs = [ + "out" + "man" + ]; + + nativeBuildInputs = [ + makeWrapper + ]; + + } + '' + ln -s ${cri-o-unwrapped.man} $man + + mkdir -p $out/bin + ln -s ${cri-o-unwrapped}/etc $out/etc + ln -s ${cri-o-unwrapped}/share $out/share + + for p in ${cri-o-unwrapped}/bin/*; do + makeWrapper $p $out/bin/''${p##*/} \ + --prefix PATH : ${binPath} + done + '' diff --git a/pkgs/applications/virtualization/crosvm/default.nix b/pkgs/applications/virtualization/crosvm/default.nix index 0640f7b3f994e8..c74c24050c1000 100644 --- a/pkgs/applications/virtualization/crosvm/default.nix +++ b/pkgs/applications/virtualization/crosvm/default.nix @@ -1,7 +1,20 @@ -{ lib, rustPlatform, fetchgit, fetchpatch -, pkg-config, protobuf, python3, wayland-scanner -, libcap, libdrm, libepoxy, minijail, virglrenderer, wayland, wayland-protocols -, pkgsCross +{ + lib, + rustPlatform, + fetchgit, + fetchpatch, + pkg-config, + protobuf, + python3, + wayland-scanner, + libcap, + libdrm, + libepoxy, + minijail, + virglrenderer, + wayland, + wayland-protocols, + pkgsCross, }: rustPlatform.buildRustPackage rec { @@ -29,11 +42,21 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-FvDJhmrSBShxRTpc23C0jEk9YRbtGyYgC1Z8ekxNnb8="; nativeBuildInputs = [ - pkg-config protobuf python3 rustPlatform.bindgenHook wayland-scanner + pkg-config + protobuf + python3 + rustPlatform.bindgenHook + wayland-scanner ]; buildInputs = [ - libcap libdrm libepoxy minijail virglrenderer wayland wayland-protocols + libcap + libdrm + libepoxy + minijail + virglrenderer + wayland + wayland-protocols ]; preConfigure = '' @@ -58,6 +81,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "crosvm"; maintainers = with maintainers; [ qyliss ]; license = licenses.bsd3; - platforms = [ "aarch64-linux" "x86_64-linux" ]; + platforms = [ + "aarch64-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/applications/virtualization/docker/gc.nix b/pkgs/applications/virtualization/docker/gc.nix index 29df4bfea3a55e..f300cf2e73da3b 100644 --- a/pkgs/applications/virtualization/docker/gc.nix +++ b/pkgs/applications/virtualization/docker/gc.nix @@ -1,4 +1,15 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper, docker, coreutils, procps, gnused, findutils, gnugrep }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + docker, + coreutils, + procps, + gnused, + findutils, + gnugrep, +}: stdenv.mkDerivation rec { pname = "docker-gc"; version = "unstable-2015-10-5"; @@ -17,7 +28,16 @@ stdenv.mkDerivation rec { cp docker-gc $out/bin chmod +x $out/bin/docker-gc wrapProgram $out/bin/docker-gc \ - --prefix PATH : "${lib.makeBinPath [ docker coreutils procps gnused findutils gnugrep ]}" + --prefix PATH : "${ + lib.makeBinPath [ + docker + coreutils + procps + gnused + findutils + gnugrep + ] + }" ''; meta = with lib; { @@ -25,7 +45,7 @@ stdenv.mkDerivation rec { mainProgram = "docker-gc"; license = licenses.asl20; homepage = "https://github.com/spotify/docker-gc"; - maintainers = with maintainers; [offline]; + maintainers = with maintainers; [ offline ]; platforms = docker.meta.platforms; }; } diff --git a/pkgs/applications/virtualization/docker/sbom.nix b/pkgs/applications/virtualization/docker/sbom.nix index 9ab81509b69437..afd78bd165eb74 100644 --- a/pkgs/applications/virtualization/docker/sbom.nix +++ b/pkgs/applications/virtualization/docker/sbom.nix @@ -1,7 +1,8 @@ -{ buildGoModule -, fetchFromGitHub -, docker -, lib +{ + buildGoModule, + fetchFromGitHub, + docker, + lib, }: buildGoModule rec { diff --git a/pkgs/applications/virtualization/krunvm/default.nix b/pkgs/applications/virtualization/krunvm/default.nix index 392ba594189ab1..24c806589db79f 100644 --- a/pkgs/applications/virtualization/krunvm/default.nix +++ b/pkgs/applications/virtualization/krunvm/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, asciidoctor -, buildah -, buildah-unwrapped -, cargo -, libiconv -, libkrun -, makeWrapper -, rustc -, sigtool +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + asciidoctor, + buildah, + buildah-unwrapped, + cargo, + libiconv, + libkrun, + makeWrapper, + rustc, + sigtool, }: stdenv.mkDerivation rec { @@ -37,9 +38,11 @@ stdenv.mkDerivation rec { makeWrapper ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ sigtool ]; - buildInputs = [ libkrun ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - ]; + buildInputs = + [ libkrun ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + ]; makeFlags = [ "PREFIX=${placeholder "out"}" ]; diff --git a/pkgs/applications/virtualization/lima/bin.nix b/pkgs/applications/virtualization/lima/bin.nix index b0a90987d1d298..f9ee61291426f9 100644 --- a/pkgs/applications/virtualization/lima/bin.nix +++ b/pkgs/applications/virtualization/lima/bin.nix @@ -1,11 +1,12 @@ -{ stdenvNoCC -, lib -, fetchurl -, writeScript -, installShellFiles -, qemu -, makeBinaryWrapper -, autoPatchelfHook +{ + stdenvNoCC, + lib, + fetchurl, + writeScript, + installShellFiles, + qemu, + makeBinaryWrapper, + autoPatchelfHook, }: let @@ -41,35 +42,45 @@ stdenvNoCC.mkDerivation { inherit version; pname = "lima"; src = fetchurl { - inherit (dist.${stdenvNoCC.hostPlatform.system} or - (throw "Unsupported system: ${stdenvNoCC.hostPlatform.system}")) url sha256; + inherit + (dist.${stdenvNoCC.hostPlatform.system} + or (throw "Unsupported system: ${stdenvNoCC.hostPlatform.system}") + ) + url + sha256 + ; }; sourceRoot = "."; - nativeBuildInputs = [ makeBinaryWrapper installShellFiles ] - ++ lib.optionals stdenvNoCC.hostPlatform.isLinux [ autoPatchelfHook ]; + nativeBuildInputs = [ + makeBinaryWrapper + installShellFiles + ] ++ lib.optionals stdenvNoCC.hostPlatform.isLinux [ autoPatchelfHook ]; - installPhase = '' - runHook preInstall - mkdir -p $out - cp -r bin share $out - chmod +x $out/bin/limactl - wrapProgram $out/bin/limactl \ - --prefix PATH : ${lib.makeBinPath [ qemu ]} - '' + lib.optionalString (stdenvNoCC.buildPlatform.canExecute stdenvNoCC.hostPlatform) '' - # the shell completion only works with a patched $out/bin/limactl and so - # needs to run after the autoPatchelfHook is executed in postFixup. - doShellCompletion() { - installShellCompletion --cmd limactl \ - --bash <($out/bin/limactl completion bash) \ - --fish <($out/bin/limactl completion fish) \ - --zsh <($out/bin/limactl completion zsh) - } - postFixupHooks+=(doShellCompletion) - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + mkdir -p $out + cp -r bin share $out + chmod +x $out/bin/limactl + wrapProgram $out/bin/limactl \ + --prefix PATH : ${lib.makeBinPath [ qemu ]} + '' + + lib.optionalString (stdenvNoCC.buildPlatform.canExecute stdenvNoCC.hostPlatform) '' + # the shell completion only works with a patched $out/bin/limactl and so + # needs to run after the autoPatchelfHook is executed in postFixup. + doShellCompletion() { + installShellCompletion --cmd limactl \ + --bash <($out/bin/limactl completion bash) \ + --fish <($out/bin/limactl completion fish) \ + --zsh <($out/bin/limactl completion zsh) + } + postFixupHooks+=(doShellCompletion) + '' + + '' + runHook postInstall + ''; doInstallCheck = true; installCheckPhase = '' diff --git a/pkgs/applications/virtualization/lkl/default.nix b/pkgs/applications/virtualization/lkl/default.nix index 751cbd021fc21d..4c4a267632c108 100644 --- a/pkgs/applications/virtualization/lkl/default.nix +++ b/pkgs/applications/virtualization/lkl/default.nix @@ -1,7 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, bc, python3, bison, flex, fuse, libarchive -, buildPackages - -, firewallSupport ? false +{ + lib, + stdenv, + fetchFromGitHub, + bc, + python3, + bison, + flex, + fuse, + libarchive, + buildPackages, + + firewallSupport ? false, }: stdenv.mkDerivation rec { @@ -13,33 +22,48 @@ stdenv.mkDerivation rec { # ref: https://github.com/NixOS/nixpkgs/pull/219434 version = "2022-08-08"; - outputs = [ "dev" "lib" "out" ]; + outputs = [ + "dev" + "lib" + "out" + ]; src = fetchFromGitHub { - owner = "lkl"; - repo = "linux"; - rev = "ffbb4aa67b3e0a64f6963f59385a200d08cb2d8b"; + owner = "lkl"; + repo = "linux"; + rev = "ffbb4aa67b3e0a64f6963f59385a200d08cb2d8b"; sha256 = "sha256-24sNREdnhkF+P+3P0qEh2tF1jHKF7KcbFSn/rPK2zWs="; }; - nativeBuildInputs = [ bc bison flex python3 ]; - - buildInputs = [ fuse libarchive ]; - - postPatch = '' - # Fix a /usr/bin/env reference in here that breaks sandboxed builds - patchShebangs arch/lkl/scripts + nativeBuildInputs = [ + bc + bison + flex + python3 + ]; - patchShebangs scripts/ld-version.sh + buildInputs = [ + fuse + libarchive + ]; - # Fixup build with newer Linux headers: https://github.com/lkl/linux/pull/484 - sed '1i#include ' -i tools/lkl/lib/hijack/xlate.c - '' + lib.optionalString stdenv.hostPlatform.isi686 '' - echo CONFIG_KALLSYMS=n >> arch/lkl/configs/defconfig - echo CONFIG_KALLSYMS_BASE_RELATIVE=n >> arch/lkl/configs/defconfig - '' + lib.optionalString firewallSupport '' - cat ${./lkl-defconfig-enable-nftables} >> arch/lkl/configs/defconfig - ''; + postPatch = + '' + # Fix a /usr/bin/env reference in here that breaks sandboxed builds + patchShebangs arch/lkl/scripts + + patchShebangs scripts/ld-version.sh + + # Fixup build with newer Linux headers: https://github.com/lkl/linux/pull/484 + sed '1i#include ' -i tools/lkl/lib/hijack/xlate.c + '' + + lib.optionalString stdenv.hostPlatform.isi686 '' + echo CONFIG_KALLSYMS=n >> arch/lkl/configs/defconfig + echo CONFIG_KALLSYMS_BASE_RELATIVE=n >> arch/lkl/configs/defconfig + '' + + lib.optionalString firewallSupport '' + cat ${./lkl-defconfig-enable-nftables} >> arch/lkl/configs/defconfig + ''; installPhase = '' mkdir -p $out/bin $lib/lib $dev @@ -63,7 +87,10 @@ stdenv.mkDerivation rec { # We turn off format and fortify because of these errors (fortify implies -O2, which breaks the jitter entropy code): # fs/xfs/xfs_log_recover.c:2575:3: error: format not a string literal and no format arguments [-Werror=format-security] # crypto/jitterentropy.c:54:3: error: #error "The CPU Jitter random number generator must not be compiled with optimizations. See documentation. Use the compiler switch -O0 for compiling jitterentropy.c." - hardeningDisable = [ "format" "fortify" ]; + hardeningDisable = [ + "format" + "fortify" + ]; # Fixes the following error when using liblkl-hijack.so on aarch64-linux: # symbol lookup error: liblkl-hijack.so: undefined symbol: __aarch64_ldadd4_sync @@ -85,9 +112,12 @@ stdenv.mkDerivation rec { extensively as possible with minimal effort and reduced maintenance overhead ''; - homepage = "https://github.com/lkl/linux/"; - platforms = platforms.linux; # Darwin probably works too but I haven't tested it - license = licenses.gpl2; - maintainers = with maintainers; [ copumpkin raitobezarius ]; + homepage = "https://github.com/lkl/linux/"; + platforms = platforms.linux; # Darwin probably works too but I haven't tested it + license = licenses.gpl2; + maintainers = with maintainers; [ + copumpkin + raitobezarius + ]; }; } diff --git a/pkgs/applications/virtualization/podman-compose/default.nix b/pkgs/applications/virtualization/podman-compose/default.nix index 44d9caf260573d..c09713d62fbc9c 100644 --- a/pkgs/applications/virtualization/podman-compose/default.nix +++ b/pkgs/applications/virtualization/podman-compose/default.nix @@ -1,4 +1,12 @@ -{ lib, buildPythonApplication, fetchFromGitHub, python-dotenv, pyyaml, setuptools, pypaBuildHook }: +{ + lib, + buildPythonApplication, + fetchFromGitHub, + python-dotenv, + pyyaml, + setuptools, + pypaBuildHook, +}: buildPythonApplication rec { version = "1.2.0"; @@ -16,7 +24,10 @@ buildPythonApplication rec { setuptools ]; - dependencies = [ python-dotenv pyyaml ]; + dependencies = [ + python-dotenv + pyyaml + ]; propagatedBuildInputs = [ pypaBuildHook ]; meta = { diff --git a/pkgs/applications/virtualization/qboot/default.nix b/pkgs/applications/virtualization/qboot/default.nix index e0d833d0c2d500..5b1c556ea5e52a 100644 --- a/pkgs/applications/virtualization/qboot/default.nix +++ b/pkgs/applications/virtualization/qboot/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, meson, ninja, fetchFromGitHub, nixosTests }: +{ + lib, + stdenv, + meson, + ninja, + fetchFromGitHub, + nixosTests, +}: stdenv.mkDerivation { pname = "qboot"; @@ -11,22 +18,33 @@ stdenv.mkDerivation { sha256 = "1d0h29zz535m0pq18k3aya93q7lqm2858mlcp8mlfkbq54n8c5d8"; }; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; installPhase = '' mkdir -p $out cp bios.bin bios.bin.elf $out/. ''; - hardeningDisable = [ "stackprotector" "pic" ]; + hardeningDisable = [ + "stackprotector" + "pic" + ]; - passthru.tests = { qboot = nixosTests.qboot; }; + passthru.tests = { + qboot = nixosTests.qboot; + }; meta = { description = "Simple x86 firmware for booting Linux"; homepage = "https://github.com/bonzini/qboot"; license = lib.licenses.gpl2; maintainers = [ ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/applications/virtualization/qemu/canokey-qemu.nix b/pkgs/applications/virtualization/qemu/canokey-qemu.nix index b94ba0c1adbe4d..0ad27dd55cfb42 100644 --- a/pkgs/applications/virtualization/qemu/canokey-qemu.nix +++ b/pkgs/applications/virtualization/qemu/canokey-qemu.nix @@ -29,16 +29,24 @@ stdenv.mkDerivation rec { preConfigure = '' cmakeFlagsArray+=( - -DCMAKE_C_FLAGS=${lib.escapeShellArg ([ - "-Wno-error=unused-but-set-parameter" - "-Wno-error=unused-but-set-variable" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-error=documentation" - ])} + -DCMAKE_C_FLAGS=${ + lib.escapeShellArg ( + [ + "-Wno-error=unused-but-set-parameter" + "-Wno-error=unused-but-set-variable" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-error=documentation" + ] + ) + } ) ''; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/applications/virtualization/qtemu/default.nix b/pkgs/applications/virtualization/qtemu/default.nix index d8fda62ccf9043..081075f890650d 100644 --- a/pkgs/applications/virtualization/qtemu/default.nix +++ b/pkgs/applications/virtualization/qtemu/default.nix @@ -1,4 +1,12 @@ -{ lib, mkDerivation, fetchFromGitLab, pkg-config, qmake, qtbase, qemu }: +{ + lib, + mkDerivation, + fetchFromGitLab, + pkg-config, + qmake, + qtbase, + qemu, +}: mkDerivation rec { pname = "qtemu"; diff --git a/pkgs/applications/virtualization/rust-hypervisor-firmware/default.nix b/pkgs/applications/virtualization/rust-hypervisor-firmware/default.nix index baa95b13c9ed56..b7cd6f4386611e 100644 --- a/pkgs/applications/virtualization/rust-hypervisor-firmware/default.nix +++ b/pkgs/applications/virtualization/rust-hypervisor-firmware/default.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, stdenv -, lld +{ + lib, + fetchFromGitHub, + stdenv, + lld, }: let diff --git a/pkgs/applications/virtualization/sail-riscv/default.nix b/pkgs/applications/virtualization/sail-riscv/default.nix index ba98f6b2cd5a7d..18d3c34ddac1d2 100644 --- a/pkgs/applications/virtualization/sail-riscv/default.nix +++ b/pkgs/applications/virtualization/sail-riscv/default.nix @@ -1,15 +1,15 @@ -{ stdenv -, fetchFromGitHub -, fetchpatch -, lib -, arch -, ocamlPackages -, ocaml -, zlib -, z3 +{ + stdenv, + fetchFromGitHub, + fetchpatch, + lib, + arch, + ocamlPackages, + ocaml, + zlib, + z3, }: - stdenv.mkDerivation rec { pname = "sail-riscv"; version = "0.5"; @@ -21,8 +21,17 @@ stdenv.mkDerivation rec { hash = "sha256-7PZNNUMaCZEBf0lOCqkquewRgZPooBOjIbGF7JlLnEo="; }; - nativeBuildInputs = with ocamlPackages; [ ocamlbuild findlib ocaml z3 sail ]; - buildInputs = with ocamlPackages; [ zlib linksem ]; + nativeBuildInputs = with ocamlPackages; [ + ocamlbuild + findlib + ocaml + z3 + sail + ]; + buildInputs = with ocamlPackages; [ + zlib + linksem + ]; strictDeps = true; patches = [ @@ -32,11 +41,13 @@ stdenv.mkDerivation rec { }) ]; - postPatch = '' - rm -r prover_snapshots - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace Makefile --replace "-flto" "" - ''; + postPatch = + '' + rm -r prover_snapshots + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace Makefile --replace "-flto" "" + ''; makeFlags = [ "SAIL=sail" @@ -56,7 +67,6 @@ stdenv.mkDerivation rec { runHook postInstall ''; - meta = with lib; { homepage = "https://github.com/riscv/sail-riscv"; description = "Formal specification of the RISC-V architecture, written in Sail"; diff --git a/pkgs/applications/virtualization/singularity/generic.nix b/pkgs/applications/virtualization/singularity/generic.nix index 1ebe650c11ebe6..6e0b3944fdd2e0 100644 --- a/pkgs/applications/virtualization/singularity/generic.nix +++ b/pkgs/applications/virtualization/singularity/generic.nix @@ -209,16 +209,14 @@ in # Patching the hard-coded defaultPath by prefixing the packages in defaultPathInputs ${lib.concatMapAttrsStringSep "\n" (fileName: originalDefaultPaths: '' substituteInPlace ${lib.escapeShellArg fileName} \ - ${ - lib.concatMapStringsSep " \\\n " ( - originalDefaultPath: - lib.concatStringsSep " " [ - "--replace-fail" - (addShellDoubleQuotes (lib.escapeShellArg originalDefaultPath)) - (addShellDoubleQuotes ''$systemDefaultPath''${systemDefaultPath:+:}${lib.escapeShellArg originalDefaultPath}''${inputsDefaultPath:+:}$inputsDefaultPath'') - ] - ) originalDefaultPaths - } + ${lib.concatMapStringsSep " \\\n " ( + originalDefaultPath: + lib.concatStringsSep " " [ + "--replace-fail" + (addShellDoubleQuotes (lib.escapeShellArg originalDefaultPath)) + (addShellDoubleQuotes ''$systemDefaultPath''${systemDefaultPath:+:}${lib.escapeShellArg originalDefaultPath}''${inputsDefaultPath:+:}$inputsDefaultPath'') + ] + ) originalDefaultPaths} '') sourceFilesWithDefaultPaths} substituteInPlace internal/pkg/util/gpu/nvidia.go \ diff --git a/pkgs/applications/virtualization/virt-manager/qt.nix b/pkgs/applications/virtualization/virt-manager/qt.nix index 103d0a3f4fbb32..c05dbb1444c311 100644 --- a/pkgs/applications/virtualization/virt-manager/qt.nix +++ b/pkgs/applications/virtualization/virt-manager/qt.nix @@ -1,7 +1,24 @@ -{ mkDerivation, lib, fetchFromGitHub, cmake, pkg-config -, qtbase, qtmultimedia, qtsvg, qttools, krdc -, libvncserver, libvirt, pcre, pixman, qtermwidget, spice-gtk, spice-protocol -, libselinux, libsepol, util-linux +{ + mkDerivation, + lib, + fetchFromGitHub, + cmake, + pkg-config, + qtbase, + qtmultimedia, + qtsvg, + qttools, + krdc, + libvncserver, + libvirt, + pcre, + pixman, + qtermwidget, + spice-gtk, + spice-protocol, + libselinux, + libsepol, + util-linux, }: mkDerivation rec { @@ -9,10 +26,10 @@ mkDerivation rec { version = "0.72.99"; src = fetchFromGitHub { - owner = "F1ash"; - repo = "qt-virt-manager"; - rev = version; - hash = "sha256-1aXlGlK+YPOe2X51xycWvSu8YC9uCywyL6ItiScFA04="; + owner = "F1ash"; + repo = "qt-virt-manager"; + rev = version; + hash = "sha256-1aXlGlK+YPOe2X51xycWvSu8YC9uCywyL6ItiScFA04="; }; cmakeFlags = [ @@ -21,22 +38,37 @@ mkDerivation rec { ]; buildInputs = [ - qtbase qtmultimedia qtsvg krdc - libvirt libvncserver pcre pixman qtermwidget spice-gtk spice-protocol - libselinux libsepol util-linux + qtbase + qtmultimedia + qtsvg + krdc + libvirt + libvncserver + pcre + pixman + qtermwidget + spice-gtk + spice-protocol + libselinux + libsepol + util-linux ]; - nativeBuildInputs = [ cmake pkg-config qttools ]; + nativeBuildInputs = [ + cmake + pkg-config + qttools + ]; meta = with lib; { - homepage = "https://f1ash.github.io/qt-virt-manager"; + homepage = "https://f1ash.github.io/qt-virt-manager"; description = "Desktop user interface for managing virtual machines (QT)"; longDescription = '' The virt-manager application is a desktop user interface for managing virtual machines through libvirt. It primarily targets KVM VMs, but also manages Xen and LXC (linux containers). ''; - license = licenses.gpl2; + license = licenses.gpl2; maintainers = with maintainers; [ peterhoeg ]; inherit (qtbase.meta) platforms; }; diff --git a/pkgs/applications/virtualization/virt-top/default.nix b/pkgs/applications/virtualization/virt-top/default.nix index 496cd36cdfe382..1067427447acd7 100644 --- a/pkgs/applications/virtualization/virt-top/default.nix +++ b/pkgs/applications/virtualization/virt-top/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchgit, ocamlPackages, autoreconfHook, libxml2, pkg-config, getopt }: +{ + lib, + stdenv, + fetchgit, + ocamlPackages, + autoreconfHook, + libxml2, + pkg-config, + getopt, +}: stdenv.mkDerivation rec { pname = "virt-top"; @@ -19,13 +28,16 @@ stdenv.mkDerivation rec { ocamlPackages.ocaml ocamlPackages.findlib ]; - buildInputs = with ocamlPackages; [ - ocamlPackages.ocaml - calendar - curses - gettext-stub - ocaml_libvirt - ] ++ [ libxml2 ]; + buildInputs = + with ocamlPackages; + [ + ocamlPackages.ocaml + calendar + curses + gettext-stub + ocaml_libvirt + ] + ++ [ libxml2 ]; prePatch = '' substituteInPlace ocaml-dep.sh.in --replace '#!/bin/bash' '#!${stdenv.shell}' diff --git a/pkgs/applications/virtualization/xhyve/default.nix b/pkgs/applications/virtualization/xhyve/default.nix index a9119975a7ae3f..c994cf7ec8190a 100644 --- a/pkgs/applications/virtualization/xhyve/default.nix +++ b/pkgs/applications/virtualization/xhyve/default.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchFromGitHub, Hypervisor, vmnet, xpc, libobjc, zlib }: +{ + stdenv, + lib, + fetchFromGitHub, + Hypervisor, + vmnet, + xpc, + libobjc, + zlib, +}: stdenv.mkDerivation rec { pname = "xhyve"; @@ -11,7 +20,13 @@ stdenv.mkDerivation rec { sha256 = "1pjdg4ppy6qh3vr1ls5zyw3jzcvwny9wydnmfpadwij1hvns7lj3"; }; - buildInputs = [ Hypervisor vmnet xpc libobjc zlib ]; + buildInputs = [ + Hypervisor + vmnet + xpc + libobjc + zlib + ]; # Don't use git to determine version prePatch = '' @@ -19,8 +34,10 @@ stdenv.mkDerivation rec { --replace 'shell git describe --abbrev=6 --dirty --always --tags' "$version" ''; - - makeFlags = [ "CFLAGS+=-Wno-shift-sign-overflow" ''CFLAGS+=-DVERSION=\"${version}\"'' ]; + makeFlags = [ + "CFLAGS+=-Wno-shift-sign-overflow" + ''CFLAGS+=-DVERSION=\"${version}\"'' + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/applications/window-managers/2bwm/default.nix b/pkgs/applications/window-managers/2bwm/default.nix index 09f3a0ebce6288..4ed3054a42e777 100644 --- a/pkgs/applications/window-managers/2bwm/default.nix +++ b/pkgs/applications/window-managers/2bwm/default.nix @@ -1,22 +1,38 @@ -{ lib, stdenv, fetchFromGitHub, patches -, libxcb, xcbutilkeysyms, xcbutilwm -, libX11, xcbutil, xcbutilxrm }: +{ + lib, + stdenv, + fetchFromGitHub, + patches, + libxcb, + xcbutilkeysyms, + xcbutilwm, + libX11, + xcbutil, + xcbutilxrm, +}: stdenv.mkDerivation rec { version = "0.3"; pname = "2bwm"; src = fetchFromGitHub { - owner = "venam"; - repo = "2bwm"; - rev = "v${version}"; + owner = "venam"; + repo = "2bwm"; + rev = "v${version}"; sha256 = "1xwib612ahv4rg9yl5injck89dlpyp5475xqgag0ydfd0r4sfld7"; }; # Allow users set their own list of patches inherit patches; - buildInputs = [ libxcb xcbutilkeysyms xcbutilwm libX11 xcbutil xcbutilxrm ]; + buildInputs = [ + libxcb + xcbutilkeysyms + xcbutilwm + libX11 + xcbutil + xcbutilxrm + ]; installPhase = "make install DESTDIR=$out PREFIX=\"\""; @@ -24,7 +40,7 @@ stdenv.mkDerivation rec { homepage = "https://github.com/venam/2bwm"; description = "Fast floating WM written over the XCB library and derived from mcwm"; license = licenses.mit; - maintainers = [ maintainers.sternenseemann ]; + maintainers = [ maintainers.sternenseemann ]; platforms = platforms.unix; }; } diff --git a/pkgs/applications/window-managers/awesome/default.nix b/pkgs/applications/window-managers/awesome/default.nix index 3c377d011bd348..2e60bcf41e68ee 100644 --- a/pkgs/applications/window-managers/awesome/default.nix +++ b/pkgs/applications/window-managers/awesome/default.nix @@ -1,20 +1,49 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, lua, cairo, librsvg, cmake, imagemagick, pkg-config, gdk-pixbuf -, xorg, libstartup_notification, libxdg_basedir, libpthreadstubs -, xcb-util-cursor, makeWrapper, pango, gobject-introspection -, which, dbus, nettools, git, doxygen -, xmlto, docbook_xml_dtd_45, docbook_xsl, findXMLCatalogs -, libxkbcommon, xcbutilxrm, hicolor-icon-theme -, asciidoctor -, fontsConf -, gtk3Support ? false, gtk3 ? null +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + lua, + cairo, + librsvg, + cmake, + imagemagick, + pkg-config, + gdk-pixbuf, + xorg, + libstartup_notification, + libxdg_basedir, + libpthreadstubs, + xcb-util-cursor, + makeWrapper, + pango, + gobject-introspection, + which, + dbus, + nettools, + git, + doxygen, + xmlto, + docbook_xml_dtd_45, + docbook_xsl, + findXMLCatalogs, + libxkbcommon, + xcbutilxrm, + hicolor-icon-theme, + asciidoctor, + fontsConf, + gtk3Support ? false, + gtk3 ? null, }: # needed for beautiful.gtk to work assert gtk3Support -> gtk3 != null; let - luaEnv = lua.withPackages(ps: [ ps.lgi ps.ldoc ]); + luaEnv = lua.withPackages (ps: [ + ps.lgi + ps.ldoc + ]); in stdenv.mkDerivation rec { @@ -49,37 +78,59 @@ stdenv.mkDerivation rec { imagemagick makeWrapper pkg-config - xmlto docbook_xml_dtd_45 - docbook_xsl findXMLCatalogs + xmlto + docbook_xml_dtd_45 + docbook_xsl + findXMLCatalogs asciidoctor gobject-introspection ]; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; FONTCONFIG_FILE = toString fontsConf; propagatedUserEnvPkgs = [ hicolor-icon-theme ]; - buildInputs = [ cairo librsvg dbus gdk-pixbuf - git luaEnv libpthreadstubs libstartup_notification - libxdg_basedir lua nettools pango xcb-util-cursor - xorg.libXau xorg.libXdmcp xorg.libxcb xorg.libxshmfence - xorg.xcbutil xorg.xcbutilimage xorg.xcbutilkeysyms - xorg.xcbutilrenderutil xorg.xcbutilwm libxkbcommon - xcbutilxrm ] - ++ lib.optional gtk3Support gtk3; + buildInputs = [ + cairo + librsvg + dbus + gdk-pixbuf + git + luaEnv + libpthreadstubs + libstartup_notification + libxdg_basedir + lua + nettools + pango + xcb-util-cursor + xorg.libXau + xorg.libXdmcp + xorg.libxcb + xorg.libxshmfence + xorg.xcbutil + xorg.xcbutilimage + xorg.xcbutilkeysyms + xorg.xcbutilrenderutil + xorg.xcbutilwm + libxkbcommon + xcbutilxrm + ] ++ lib.optional gtk3Support gtk3; cmakeFlags = [ #"-DGENERATE_MANPAGES=ON" "-DOVERRIDE_VERSION=${version}" - ] ++ lib.optional lua.pkgs.isLuaJIT "-DLUA_LIBRARY=${lua}/lib/libluajit-5.1.so" - ; + ] ++ lib.optional lua.pkgs.isLuaJIT "-DLUA_LIBRARY=${lua}/lib/libluajit-5.1.so"; GI_TYPELIB_PATH = "${pango.out}/lib/girepository-1.0"; # LUA_CPATH and LUA_PATH are used only for *building*, see the --search flags # below for how awesome finds the libraries it needs at runtime. LUA_CPATH = "${luaEnv}/lib/lua/${lua.luaversion}/?.so"; - LUA_PATH = "${luaEnv}/share/lua/${lua.luaversion}/?.lua;;"; + LUA_PATH = "${luaEnv}/share/lua/${lua.luaversion}/?.lua;;"; postInstall = '' # Don't use wrapProgram or the wrapper will duplicate the --search @@ -101,9 +152,12 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Highly configurable, dynamic window manager for X"; - homepage = "https://awesomewm.org/"; - license = licenses.gpl2Plus; - maintainers = with maintainers; [ lovek323 rasendubi ]; - platforms = platforms.linux; + homepage = "https://awesomewm.org/"; + license = licenses.gpl2Plus; + maintainers = with maintainers; [ + lovek323 + rasendubi + ]; + platforms = platforms.linux; }; } diff --git a/pkgs/applications/window-managers/cage/default.nix b/pkgs/applications/window-managers/cage/default.nix index ab9f8c5e234092..69db37cbc95118 100644 --- a/pkgs/applications/window-managers/cage/default.nix +++ b/pkgs/applications/window-managers/cage/default.nix @@ -1,9 +1,25 @@ -{ lib, stdenv, fetchFromGitHub -, meson, ninja, pkg-config, wayland-scanner, scdoc, makeWrapper -, wlroots, wayland, wayland-protocols, pixman, libxkbcommon, xcbutilwm -, systemd, libGL, libX11, mesa -, xwayland ? null -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + wayland-scanner, + scdoc, + makeWrapper, + wlroots, + wayland, + wayland-protocols, + pixman, + libxkbcommon, + xcbutilwm, + systemd, + libGL, + libX11, + mesa, + xwayland ? null, + nixosTests, }: stdenv.mkDerivation rec { @@ -21,12 +37,26 @@ stdenv.mkDerivation rec { pkg-config ]; - nativeBuildInputs = [ meson ninja pkg-config wayland-scanner scdoc makeWrapper ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + wayland-scanner + scdoc + makeWrapper + ]; buildInputs = [ - wlroots wayland wayland-protocols pixman libxkbcommon xcbutilwm + wlroots + wayland + wayland-protocols + pixman + libxkbcommon + xcbutilwm mesa # for libEGL headers - systemd libGL libX11 + systemd + libGL + libX11 ]; postFixup = lib.optionalString wlroots.enableXWayland '' @@ -38,9 +68,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Wayland kiosk that runs a single, maximized application"; - homepage = "https://www.hjdskes.nl/projects/cage/"; - license = licenses.mit; - platforms = platforms.linux; + homepage = "https://www.hjdskes.nl/projects/cage/"; + license = licenses.mit; + platforms = platforms.linux; maintainers = with maintainers; [ primeos ]; mainProgram = "cage"; }; diff --git a/pkgs/applications/window-managers/cagebreak/default.nix b/pkgs/applications/window-managers/cagebreak/default.nix index 13618f6afb336d..9bd7881e641a8d 100644 --- a/pkgs/applications/window-managers/cagebreak/default.nix +++ b/pkgs/applications/window-managers/cagebreak/default.nix @@ -1,27 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, cairo -, fontconfig -, libevdev -, libinput -, libxkbcommon -, xcbutilwm -, makeWrapper -, mesa -, meson -, ninja -, nixosTests -, pango -, pixman -, pkg-config -, scdoc -, systemd -, wayland -, wayland-protocols -, wayland-scanner -, withXwayland ? true , xwayland -, wlroots +{ + lib, + stdenv, + fetchFromGitHub, + cairo, + fontconfig, + libevdev, + libinput, + libxkbcommon, + xcbutilwm, + makeWrapper, + mesa, + meson, + ninja, + nixosTests, + pango, + pixman, + pkg-config, + scdoc, + systemd, + wayland, + wayland-protocols, + wayland-scanner, + withXwayland ? true, + xwayland, + wlroots, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/window-managers/dwm/default.nix b/pkgs/applications/window-managers/dwm/default.nix index 74d5022219a05d..4204fb9590e0f5 100644 --- a/pkgs/applications/window-managers/dwm/default.nix +++ b/pkgs/applications/window-managers/dwm/default.nix @@ -1,6 +1,15 @@ -{ lib, stdenv, fetchurl, libX11, libXinerama, libXft, writeText, patches ? [ ], conf ? null -# update script dependencies -, gitUpdater +{ + lib, + stdenv, + fetchurl, + libX11, + libXinerama, + libXft, + writeText, + patches ? [ ], + conf ? null, + # update script dependencies + gitUpdater, }: stdenv.mkDerivation rec { @@ -12,7 +21,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-Ideev6ny+5MUGDbCZmy4H0eExp1k5/GyNS+blwuglyk="; }; - buildInputs = [ libX11 libXinerama libXft ]; + buildInputs = [ + libX11 + libXinerama + libXft + ]; prePatch = '' sed -i "s@/usr/local@$out@" config.mk @@ -25,8 +38,7 @@ stdenv.mkDerivation rec { postPatch = let configFile = - if lib.isDerivation conf || builtins.isPath conf - then conf else writeText "config.def.h" conf; + if lib.isDerivation conf || builtins.isPath conf then conf else writeText "config.def.h" conf; in lib.optionalString (conf != null) "cp ${configFile} config.def.h"; diff --git a/pkgs/applications/window-managers/dwm/dwm-status.nix b/pkgs/applications/window-managers/dwm/dwm-status.nix index cb303ff268aea8..5448906937f8fa 100644 --- a/pkgs/applications/window-managers/dwm/dwm-status.nix +++ b/pkgs/applications/window-managers/dwm/dwm-status.nix @@ -1,10 +1,33 @@ -{ lib, rustPlatform, fetchFromGitHub, dbus, gdk-pixbuf, libnotify, makeWrapper, pkg-config, xorg -, enableAlsaUtils ? true, alsa-utils, coreutils -, enableNetwork ? true, dnsutils, iproute2, wirelesstools }: +{ + lib, + rustPlatform, + fetchFromGitHub, + dbus, + gdk-pixbuf, + libnotify, + makeWrapper, + pkg-config, + xorg, + enableAlsaUtils ? true, + alsa-utils, + coreutils, + enableNetwork ? true, + dnsutils, + iproute2, + wirelesstools, +}: let - bins = lib.optionals enableAlsaUtils [ alsa-utils coreutils ] - ++ lib.optionals enableNetwork [ dnsutils iproute2 wirelesstools ]; + bins = + lib.optionals enableAlsaUtils [ + alsa-utils + coreutils + ] + ++ lib.optionals enableNetwork [ + dnsutils + iproute2 + wirelesstools + ]; in rustPlatform.buildRustPackage rec { @@ -18,12 +41,20 @@ rustPlatform.buildRustPackage rec { sha256 = "sha256-GkTPEmsnHFLUvbasAOXOQjFKs1Y9aaG87uyPvnQaT8Y="; }; - nativeBuildInputs = [ makeWrapper pkg-config ]; - buildInputs = [ dbus gdk-pixbuf libnotify xorg.libX11 ]; + nativeBuildInputs = [ + makeWrapper + pkg-config + ]; + buildInputs = [ + dbus + gdk-pixbuf + libnotify + xorg.libX11 + ]; cargoHash = "sha256-eRfXUnyzOfVSEiwjLCaNbETUPXVU2Ed2VUNM9FjS5YE="; - postInstall = lib.optionalString (bins != []) '' + postInstall = lib.optionalString (bins != [ ]) '' wrapProgram $out/bin/dwm-status --prefix "PATH" : "${lib.makeBinPath bins}" ''; diff --git a/pkgs/applications/window-managers/evilwm/default.nix b/pkgs/applications/window-managers/evilwm/default.nix index 017a1ab0fe9520..782c80599bed40 100644 --- a/pkgs/applications/window-managers/evilwm/default.nix +++ b/pkgs/applications/window-managers/evilwm/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, libX11 -, libXext -, libXrandr -, libXrender -, xorgproto -, patches ? [ ] +{ + lib, + stdenv, + fetchurl, + libX11, + libXext, + libXrandr, + libXrender, + xorgproto, + patches ? [ ], }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/window-managers/hyprwm/hypr/default.nix b/pkgs/applications/window-managers/hyprwm/hypr/default.nix index 1eb311d4e159e6..e47dd2fde51629 100644 --- a/pkgs/applications/window-managers/hyprwm/hypr/default.nix +++ b/pkgs/applications/window-managers/hyprwm/hypr/default.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, cairo -, cmake -, glib -, gtkmm3 -, harfbuzz -, libX11 -, libXdmcp -, libxcb -, makeWrapper -, pcre2 -, pkg-config -, xcbutilcursor -, xcbutilkeysyms -, xcbutilwm -, xcbutil -, xmodmap +{ + lib, + stdenv, + fetchFromGitHub, + cairo, + cmake, + glib, + gtkmm3, + harfbuzz, + libX11, + libXdmcp, + libxcb, + makeWrapper, + pcre2, + pkg-config, + xcbutilcursor, + xcbutilkeysyms, + xcbutilwm, + xcbutil, + xmodmap, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/window-managers/hyprwm/hyprshade/default.nix b/pkgs/applications/window-managers/hyprwm/hyprshade/default.nix index 0393c6eddd3ba2..02f72471e87676 100644 --- a/pkgs/applications/window-managers/hyprwm/hyprshade/default.nix +++ b/pkgs/applications/window-managers/hyprwm/hyprshade/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, hatchling -, more-itertools -, click -, hyprland -, makeWrapper +{ + lib, + buildPythonPackage, + fetchFromGitHub, + hatchling, + more-itertools, + click, + hyprland, + makeWrapper, }: buildPythonPackage rec { @@ -25,7 +26,10 @@ buildPythonPackage rec { makeWrapper ]; - propagatedBuildInputs = [ more-itertools click ]; + propagatedBuildInputs = [ + more-itertools + click + ]; postFixup = '' wrapProgram $out/bin/hyprshade \ diff --git a/pkgs/applications/window-managers/i3/auto-layout.nix b/pkgs/applications/window-managers/i3/auto-layout.nix index ef6c27de438efe..b72f7f2ffbafb1 100644 --- a/pkgs/applications/window-managers/i3/auto-layout.nix +++ b/pkgs/applications/window-managers/i3/auto-layout.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "i3-auto-layout"; @@ -21,7 +25,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "i3-auto-layout"; homepage = "https://github.com/chmln/i3-auto-layout"; license = licenses.mit; - maintainers = with maintainers; [ mephistophiles perstark ]; + maintainers = with maintainers; [ + mephistophiles + perstark + ]; platforms = platforms.linux; }; } diff --git a/pkgs/applications/window-managers/i3/balance-workspace.nix b/pkgs/applications/window-managers/i3/balance-workspace.nix index de68a06d896e2e..913802294862ae 100644 --- a/pkgs/applications/window-managers/i3/balance-workspace.nix +++ b/pkgs/applications/window-managers/i3/balance-workspace.nix @@ -1,4 +1,9 @@ -{ lib, buildPythonPackage, fetchPypi, i3ipc }: +{ + lib, + buildPythonPackage, + fetchPypi, + i3ipc, +}: buildPythonPackage rec { pname = "i3-balance-workspace"; @@ -11,7 +16,7 @@ buildPythonPackage rec { propagatedBuildInputs = [ i3ipc ]; - doCheck = false; # project has no test + doCheck = false; # project has no test pythonImportsCheck = [ "i3_balance_workspace" ]; meta = { diff --git a/pkgs/applications/window-managers/i3/blocks-gaps.nix b/pkgs/applications/window-managers/i3/blocks-gaps.nix index 6c32583aa0631c..a49cd469d15f1e 100644 --- a/pkgs/applications/window-managers/i3/blocks-gaps.nix +++ b/pkgs/applications/window-managers/i3/blocks-gaps.nix @@ -1,12 +1,34 @@ -{ fetchFromGitHub, lib, stdenv, perl, makeWrapper -, iproute2, acpi, sysstat, alsa-utils -, scripts ? [ "bandwidth" "battery" "cpu_usage" "disk" "iface" - "load_average" "memory" "volume" "wifi" ] +{ + fetchFromGitHub, + lib, + stdenv, + perl, + makeWrapper, + iproute2, + acpi, + sysstat, + alsa-utils, + scripts ? [ + "bandwidth" + "battery" + "cpu_usage" + "disk" + "iface" + "load_average" + "memory" + "volume" + "wifi" + ], }: let - perlscripts = [ "battery" "cpu_usage" "openvpn" "temperature" ]; - contains_any = l1: l2: 0 < lib.length( lib.intersectLists l1 l2 ); + perlscripts = [ + "battery" + "cpu_usage" + "openvpn" + "temperature" + ]; + contains_any = l1: l2: 0 < lib.length (lib.intersectLists l1 l2); in stdenv.mkDerivation rec { @@ -21,27 +43,35 @@ stdenv.mkDerivation rec { }; makeFlags = [ "all" ]; - installFlags = [ "PREFIX=\${out}" "VERSION=${version}" ]; + installFlags = [ + "PREFIX=\${out}" + "VERSION=${version}" + ]; buildInputs = lib.optional (contains_any scripts perlscripts) perl; nativeBuildInputs = [ makeWrapper ]; - postFixup = lib.optionalString (lib.elem "bandwidth" scripts) '' - wrapProgram $out/libexec/i3blocks/bandwidth \ - --prefix PATH : ${lib.makeBinPath [ iproute2 ]} - '' + lib.optionalString (lib.elem "battery" scripts) '' - wrapProgram $out/libexec/i3blocks/battery \ - --prefix PATH : ${lib.makeBinPath [ acpi ]} - '' + lib.optionalString (lib.elem "cpu_usage" scripts) '' - wrapProgram $out/libexec/i3blocks/cpu_usage \ - --prefix PATH : ${lib.makeBinPath [ sysstat ]} - '' + lib.optionalString (lib.elem "iface" scripts) '' - wrapProgram $out/libexec/i3blocks/iface \ - --prefix PATH : ${lib.makeBinPath [ iproute2 ]} - '' + lib.optionalString (lib.elem "volume" scripts) '' - wrapProgram $out/libexec/i3blocks/volume \ - --prefix PATH : ${lib.makeBinPath [ alsa-utils ]} - ''; + postFixup = + lib.optionalString (lib.elem "bandwidth" scripts) '' + wrapProgram $out/libexec/i3blocks/bandwidth \ + --prefix PATH : ${lib.makeBinPath [ iproute2 ]} + '' + + lib.optionalString (lib.elem "battery" scripts) '' + wrapProgram $out/libexec/i3blocks/battery \ + --prefix PATH : ${lib.makeBinPath [ acpi ]} + '' + + lib.optionalString (lib.elem "cpu_usage" scripts) '' + wrapProgram $out/libexec/i3blocks/cpu_usage \ + --prefix PATH : ${lib.makeBinPath [ sysstat ]} + '' + + lib.optionalString (lib.elem "iface" scripts) '' + wrapProgram $out/libexec/i3blocks/iface \ + --prefix PATH : ${lib.makeBinPath [ iproute2 ]} + '' + + lib.optionalString (lib.elem "volume" scripts) '' + wrapProgram $out/libexec/i3blocks/volume \ + --prefix PATH : ${lib.makeBinPath [ alsa-utils ]} + ''; meta = with lib; { description = "Flexible scheduler for your i3bar blocks -- this is a fork to use with i3-gaps"; diff --git a/pkgs/applications/window-managers/i3/blocks.nix b/pkgs/applications/window-managers/i3/blocks.nix index ad495723b6db89..c6905ae0f1997b 100644 --- a/pkgs/applications/window-managers/i3/blocks.nix +++ b/pkgs/applications/window-managers/i3/blocks.nix @@ -1,4 +1,11 @@ -{ fetchFromGitHub, fetchpatch, lib, stdenv, autoreconfHook, pkg-config }: +{ + fetchFromGitHub, + fetchpatch, + lib, + stdenv, + autoreconfHook, + pkg-config, +}: stdenv.mkDerivation { pname = "i3blocks"; @@ -20,7 +27,10 @@ stdenv.mkDerivation { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; meta = with lib; { description = "Flexible scheduler for your i3bar blocks"; diff --git a/pkgs/applications/window-managers/i3/bumblebee-status/default.nix b/pkgs/applications/window-managers/i3/bumblebee-status/default.nix index 99b5b203ee2f37..7e789586cda9f0 100644 --- a/pkgs/applications/window-managers/i3/bumblebee-status/default.nix +++ b/pkgs/applications/window-managers/i3/bumblebee-status/default.nix @@ -1,20 +1,20 @@ -{ pkgs -, lib -, glibcLocales -, python -, fetchpatch -, fetchFromGitHub +{ + pkgs, + lib, + glibcLocales, + python, + fetchpatch, + fetchFromGitHub, # Usage: bumblebee-status.override { plugins = p: [p.arandr p.bluetooth2]; }; -, plugins ? p: [ ] + plugins ? p: [ ], }: let version = "2.2.0"; # { = { name = "..."; propagatedBuildInputs = [ ... ]; buildInputs = [ ... ]; } } - allPlugins = - lib.mapAttrs - (name: value: value // { inherit name; }) - (import ./plugins.nix { inherit pkgs python; }); + allPlugins = lib.mapAttrs (name: value: value // { inherit name; }) ( + import ./plugins.nix { inherit pkgs python; } + ); # [ { name = "..."; propagatedBuildInputs = [ ... ]; buildInputs = [ ... ]; } ] selectedPlugins = plugins allPlugins; @@ -42,7 +42,14 @@ python.pkgs.buildPythonPackage { buildInputs = lib.concatMap (p: p.buildInputs or [ ]) selectedPlugins; propagatedBuildInputs = lib.concatMap (p: p.propagatedBuildInputs or [ ]) selectedPlugins; - checkInputs = with python.pkgs; [ freezegun netifaces psutil pytest pytest-mock requests ]; + checkInputs = with python.pkgs; [ + freezegun + netifaces + psutil + pytest + pytest-mock + requests + ]; checkPhase = '' runHook preCheck diff --git a/pkgs/applications/window-managers/i3/bumblebee-status/plugins.nix b/pkgs/applications/window-managers/i3/bumblebee-status/plugins.nix index d5567ce15e8f14..7881b46eac43fb 100644 --- a/pkgs/applications/window-managers/i3/bumblebee-status/plugins.nix +++ b/pkgs/applications/window-managers/i3/bumblebee-status/plugins.nix @@ -1,6 +1,7 @@ -{ pkgs -, python -, ... +{ + pkgs, + python, + ... }: # propagatedBuildInputs are for Python libraries and executables # buildInputs are for libraries @@ -11,7 +12,11 @@ in amixer.propagatedBuildInputs = [ pkgs.alsa-utils ]; # aptitude is unpackaged # apt.propagatedBuildInputs = [aptitude]; - arandr.propagatedBuildInputs = [ py.tkinter pkgs.arandr pkgs.xorg.xrandr ]; + arandr.propagatedBuildInputs = [ + py.tkinter + pkgs.arandr + pkgs.xorg.xrandr + ]; # checkupdates is unpackaged # arch-update.propagatedBuildInputs = [checkupdates]; # checkupdates is unpackaged @@ -21,20 +26,46 @@ in battery = { }; battery-upower = { }; battery_upower = { }; - bluetooth.propagatedBuildInputs = [ pkgs.bluez pkgs.blueman pkgs.dbus ]; - bluetooth2.propagatedBuildInputs = [ pkgs.bluez pkgs.blueman pkgs.dbus py.dbus-python ]; + bluetooth.propagatedBuildInputs = [ + pkgs.bluez + pkgs.blueman + pkgs.dbus + ]; + bluetooth2.propagatedBuildInputs = [ + pkgs.bluez + pkgs.blueman + pkgs.dbus + py.dbus-python + ]; blugon.propagatedBuildInputs = [ pkgs.blugon ]; # If you do not allow this plugin to query the system's ACPI, i.e. the plugin option `use_acpi` is set to `False`, then you need at least one of [ brightnessctl light xbacklight ] brightness.propagatedBuildInputs = [ ]; - caffeine.propagatedBuildInputs = [ pkgs.xdg-utils pkgs.xdotool pkgs.xorg.xprop pkgs.libnotify ]; + caffeine.propagatedBuildInputs = [ + pkgs.xdg-utils + pkgs.xdotool + pkgs.xorg.xprop + pkgs.libnotify + ]; cmus.propagatedBuildInputs = [ pkgs.cmus ]; - cpu.propagatedBuildInputs = [ py.psutil pkgs.gnome-system-monitor ]; - cpu2.propagatedBuildInputs = [ py.psutil pkgs.lm_sensors ]; - cpu3.propagatedBuildInputs = [ py.psutil pkgs.lm_sensors ]; + cpu.propagatedBuildInputs = [ + py.psutil + pkgs.gnome-system-monitor + ]; + cpu2.propagatedBuildInputs = [ + py.psutil + pkgs.lm_sensors + ]; + cpu3.propagatedBuildInputs = [ + py.psutil + pkgs.lm_sensors + ]; currency.propagatedBuildInputs = [ py.requests ]; date = { }; datetime = { }; - datetimetz.propagatedBuildInputs = [ py.tzlocal py.pytz ]; + datetimetz.propagatedBuildInputs = [ + py.tzlocal + py.pytz + ]; datetz = { }; deadbeef.propagatedBuildInputs = [ pkgs.deadbeef ]; debug = { }; @@ -54,7 +85,10 @@ in py.google-auth-oauthlib ]; getcrypto.propagatedBuildInputs = [ py.requests ]; - git.propagatedBuildInputs = [ pkgs.xcwd pkgs.pygit2 ]; + git.propagatedBuildInputs = [ + pkgs.xcwd + pkgs.pygit2 + ]; github.propagatedBuildInputs = [ py.requests ]; gitlab.propagatedBuildInputs = [ py.requests ]; # gpmdp-remote is unpackaged @@ -90,16 +124,25 @@ in messagereceiver = { }; mocp.propagatedBuildInputs = [ pkgs.moc ]; mpd.propagatedBuildInputs = [ pkgs.mpc ]; - network.propagatedBuildInputs = [ py.netifaces pkgs.iw ]; + network.propagatedBuildInputs = [ + py.netifaces + pkgs.iw + ]; network_traffic.propagatedBuildInputs = [ py.netifaces ]; - nic.propagatedBuildInputs = [ py.netifaces pkgs.iw ]; + nic.propagatedBuildInputs = [ + py.netifaces + pkgs.iw + ]; notmuch_count.propagatedBuildInputs = [ pkgs.notmuch ]; # nvidian-smi is unpackaged # nvidiagpu.propagatedBuildInputs = [nvidia-smi]; octoprint.propagatedBuildInputs = [ py.tkinter ]; # optimus-manager is unpackaged # optman.propagatedBuildInputs = [optimus-manager]; - pacman.propagatedBuildInputs = [ pkgs.fakeroot pkgs.pacman ]; + pacman.propagatedBuildInputs = [ + pkgs.fakeroot + pkgs.pacman + ]; pamixer.propagatedBuildInputs = [ pkgs.pamixer ]; persian_date.propagatedBuildInputs = [ py.jdatetime ]; pihole = { }; @@ -148,9 +191,15 @@ in # Needs `systemctl` twmn.propagatedBuildInputs = [ ]; uptime = { }; - usage.propagatedBuildInputs = [ py.sqlite pkgs.activitywatch ]; + usage.propagatedBuildInputs = [ + py.sqlite + pkgs.activitywatch + ]; vault.propagatedBuildInputs = [ pkgs.pass ]; - vpn.propagatedBuildInputs = [ py.tkinter pkgs.networkmanager ]; + vpn.propagatedBuildInputs = [ + py.tkinter + pkgs.networkmanager + ]; wakatime.propagatedBuildInputs = [ py.requests ]; watson.propagatedBuildInputs = [ pkgs.watson ]; weather.propagatedBuildInputs = [ py.requests ]; diff --git a/pkgs/applications/window-managers/i3/cycle-focus.nix b/pkgs/applications/window-managers/i3/cycle-focus.nix index f6ae488b078912..1ec3b1e67fe980 100644 --- a/pkgs/applications/window-managers/i3/cycle-focus.nix +++ b/pkgs/applications/window-managers/i3/cycle-focus.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage { diff --git a/pkgs/applications/window-managers/i3/easyfocus.nix b/pkgs/applications/window-managers/i3/easyfocus.nix index a1f0895bff6d77..257604baf2d62b 100644 --- a/pkgs/applications/window-managers/i3/easyfocus.nix +++ b/pkgs/applications/window-managers/i3/easyfocus.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, xorgproto, libxcb, xcbutilkeysyms -, xorg , i3ipc-glib , glib +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + xorgproto, + libxcb, + xcbutilkeysyms, + xorg, + i3ipc-glib, + glib, }: stdenv.mkDerivation { @@ -14,7 +23,14 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libxcb xcbutilkeysyms xorgproto xorg.libX11.dev i3ipc-glib glib.dev ]; + buildInputs = [ + libxcb + xcbutilkeysyms + xorgproto + xorg.libX11.dev + i3ipc-glib + glib.dev + ]; # Makefile has no rule for 'install' installPhase = '' @@ -26,7 +42,7 @@ stdenv.mkDerivation { description = "Focus and select windows in i3"; mainProgram = "i3-easyfocus"; homepage = "https://github.com/cornerman/i3-easyfocus"; - maintainers = with maintainers; [teto]; + maintainers = with maintainers; [ teto ]; license = licenses.gpl3; platforms = platforms.linux; }; diff --git a/pkgs/applications/window-managers/i3/i3-ratiosplit.nix b/pkgs/applications/window-managers/i3/i3-ratiosplit.nix index ad585ef08885d8..e7b339177476dc 100644 --- a/pkgs/applications/window-managers/i3/i3-ratiosplit.nix +++ b/pkgs/applications/window-managers/i3/i3-ratiosplit.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "i3-ratiosplit"; diff --git a/pkgs/applications/window-managers/i3/i3-resurrect.nix b/pkgs/applications/window-managers/i3/i3-resurrect.nix index 2040cdba806a10..0fd06d1e34b798 100644 --- a/pkgs/applications/window-managers/i3/i3-resurrect.nix +++ b/pkgs/applications/window-managers/i3/i3-resurrect.nix @@ -1,4 +1,15 @@ -{ lib, buildPythonApplication, click, i3ipc, psutil, natsort, fetchPypi, xprop, xdotool, importlib-metadata }: +{ + lib, + buildPythonApplication, + click, + i3ipc, + psutil, + natsort, + fetchPypi, + xprop, + xdotool, + importlib-metadata, +}: buildPythonApplication rec { pname = "i3-resurrect"; @@ -9,7 +20,15 @@ buildPythonApplication rec { hash = "sha256-13FKRvEE4vHq5G51G1UyBnfNiWeS9Q/SYCG16E1Sn4c="; }; - propagatedBuildInputs = [ click psutil xprop natsort i3ipc xdotool importlib-metadata ]; + propagatedBuildInputs = [ + click + psutil + xprop + natsort + i3ipc + xdotool + importlib-metadata + ]; doCheck = false; # no tests meta = with lib; { @@ -17,7 +36,7 @@ buildPythonApplication rec { description = "Simple but flexible solution to saving and restoring i3 workspaces"; mainProgram = "i3-resurrect"; license = licenses.gpl3; - platforms= platforms.linux; + platforms = platforms.linux; maintainers = with maintainers; [ magnetophon ]; }; } diff --git a/pkgs/applications/window-managers/i3/i3ipc-glib.nix b/pkgs/applications/window-managers/i3/i3ipc-glib.nix index 9362cdcfdcec75..753cb3b4eb9eaa 100644 --- a/pkgs/applications/window-managers/i3/i3ipc-glib.nix +++ b/pkgs/applications/window-managers/i3/i3ipc-glib.nix @@ -1,6 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, xorgproto, libxcb -, autoreconfHook, json-glib, gtk-doc, which -, gobject-introspection +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + xorgproto, + libxcb, + autoreconfHook, + json-glib, + gtk-doc, + which, + gobject-introspection, }: stdenv.mkDerivation rec { @@ -15,9 +24,19 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ autoreconfHook which pkg-config gtk-doc gobject-introspection ]; + nativeBuildInputs = [ + autoreconfHook + which + pkg-config + gtk-doc + gobject-introspection + ]; - buildInputs = [ libxcb json-glib xorgproto ]; + buildInputs = [ + libxcb + json-glib + xorgproto + ]; preAutoreconf = '' gtkdocize @@ -26,7 +45,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "C interface library to i3wm"; homepage = "https://github.com/acrisci/i3ipc-glib"; - maintainers = with maintainers; [teto]; + maintainers = with maintainers; [ teto ]; license = licenses.gpl3; platforms = platforms.linux; }; diff --git a/pkgs/applications/window-managers/i3/kitti3.nix b/pkgs/applications/window-managers/i3/kitti3.nix index 4a88518d508bb2..68e958c497b95a 100644 --- a/pkgs/applications/window-managers/i3/kitti3.nix +++ b/pkgs/applications/window-managers/i3/kitti3.nix @@ -1,8 +1,9 @@ -{ buildPythonApplication -, fetchFromGitHub -, poetry-core -, i3ipc -, lib +{ + buildPythonApplication, + fetchFromGitHub, + poetry-core, + i3ipc, + lib, }: buildPythonApplication rec { diff --git a/pkgs/applications/window-managers/i3/layout-manager.nix b/pkgs/applications/window-managers/i3/layout-manager.nix index df5bb41d85ecc6..c32a9dc777be2e 100644 --- a/pkgs/applications/window-managers/i3/layout-manager.nix +++ b/pkgs/applications/window-managers/i3/layout-manager.nix @@ -1,7 +1,29 @@ -{ lib, stdenv, fetchFromGitHub, vim, makeWrapper, jq, rofi, xrandr, xdotool, i3, gawk, libnotify }: +{ + lib, + stdenv, + fetchFromGitHub, + vim, + makeWrapper, + jq, + rofi, + xrandr, + xdotool, + i3, + gawk, + libnotify, +}: let - path = lib.makeBinPath [ vim jq rofi xrandr xdotool i3 gawk libnotify ]; + path = lib.makeBinPath [ + vim + jq + rofi + xrandr + xdotool + i3 + gawk + libnotify + ]; in stdenv.mkDerivation rec { diff --git a/pkgs/applications/window-managers/i3/lock-blur.nix b/pkgs/applications/window-managers/i3/lock-blur.nix index dc8e8250135b68..68471ad4bc0dfc 100644 --- a/pkgs/applications/window-managers/i3/lock-blur.nix +++ b/pkgs/applications/window-managers/i3/lock-blur.nix @@ -1,6 +1,13 @@ -{ i3lock-color, lib, stdenv, fetchFromGitHub, fetchpatch, libGL }: +{ + i3lock-color, + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + libGL, +}: -i3lock-color.overrideAttrs (oldAttrs : rec { +i3lock-color.overrideAttrs (oldAttrs: rec { pname = "i3lock-blur"; version = "2.10"; diff --git a/pkgs/applications/window-managers/i3/lock-color.nix b/pkgs/applications/window-managers/i3/lock-color.nix index 5a4c12a4474a74..cea706f8e84fe1 100644 --- a/pkgs/applications/window-managers/i3/lock-color.nix +++ b/pkgs/applications/window-managers/i3/lock-color.nix @@ -1,6 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, libxcb, - xcbutilkeysyms , xcbutilimage, pam, libX11, libev, cairo, libxkbcommon, - libxkbfile, libjpeg_turbo, xcbutilxrm, xorg +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libxcb, + xcbutilkeysyms, + xcbutilimage, + pam, + libX11, + libev, + cairo, + libxkbcommon, + libxkbfile, + libjpeg_turbo, + xcbutilxrm, + xorg, }: stdenv.mkDerivation rec { @@ -14,15 +29,34 @@ stdenv.mkDerivation rec { sha256 = "sha256-fuLeglRif2bruyQRqiL3nm3q6qxoHcPdVdL+QjGBR/k="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libxcb xcbutilkeysyms xcbutilimage pam libX11 - libev cairo libxkbcommon libxkbfile libjpeg_turbo xcbutilxrm xorg.xcbutil ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libxcb + xcbutilkeysyms + xcbutilimage + pam + libX11 + libev + cairo + libxkbcommon + libxkbfile + libjpeg_turbo + xcbutilxrm + xorg.xcbutil + ]; makeFlags = [ "all" ]; preInstall = '' mkdir -p $out/share/man/man1 ''; - installFlags = [ "PREFIX=\${out}" "SYSCONFDIR=\${out}/etc" "MANDIR=\${out}/share/man" ]; + installFlags = [ + "PREFIX=\${out}" + "SYSCONFDIR=\${out}/etc" + "MANDIR=\${out}/share/man" + ]; postInstall = '' mv $out/bin/i3lock $out/bin/i3lock-color ln -s $out/bin/i3lock-color $out/bin/i3lock diff --git a/pkgs/applications/window-managers/i3/lock-fancy.nix b/pkgs/applications/window-managers/i3/lock-fancy.nix index a66e52bc40b0d5..dd64a987ed3977 100644 --- a/pkgs/applications/window-managers/i3/lock-fancy.nix +++ b/pkgs/applications/window-managers/i3/lock-fancy.nix @@ -1,17 +1,18 @@ -{ coreutils -, fetchFromGitHub -, fontconfig -, gawk -, getopt -, i3lock-color -, imagemagick -, installShellFiles -, lib -, makeWrapper -, scrot -, stdenv +{ + coreutils, + fetchFromGitHub, + fontconfig, + gawk, + getopt, + i3lock-color, + imagemagick, + installShellFiles, + lib, + makeWrapper, + scrot, + stdenv, -, screenshotCommand ? "" + screenshotCommand ? "", }: stdenv.mkDerivation { @@ -30,15 +31,17 @@ stdenv.mkDerivation { installShellFiles ]; - postPatch = '' - sed -i i3lock-fancy \ - -e 's|icon="/usr/share/i3lock-fancy/icons/lockdark.png"|icon="'$out'/share/i3lock-fancy/icons/lockdark.png"|' \ - -e 's|icon="/usr/share/i3lock-fancy/icons/lock.png"|icon="'$out'/share/i3lock-fancy/icons/lock.png"|' - rm Makefile - '' + lib.optionalString (screenshotCommand != "") '' - sed -i i3lock-fancy \ - -e "s|shot=(import -silent -window root)|shot=(${screenshotCommand})|"; - ''; + postPatch = + '' + sed -i i3lock-fancy \ + -e 's|icon="/usr/share/i3lock-fancy/icons/lockdark.png"|icon="'$out'/share/i3lock-fancy/icons/lockdark.png"|' \ + -e 's|icon="/usr/share/i3lock-fancy/icons/lock.png"|icon="'$out'/share/i3lock-fancy/icons/lock.png"|' + rm Makefile + '' + + lib.optionalString (screenshotCommand != "") '' + sed -i i3lock-fancy \ + -e "s|shot=(import -silent -window root)|shot=(${screenshotCommand})|"; + ''; installPhase = '' runHook preInstall @@ -54,7 +57,17 @@ stdenv.mkDerivation { postInstall = '' wrapProgram $out/bin/i3lock-fancy \ - --prefix PATH : ${lib.makeBinPath [ coreutils fontconfig gawk getopt i3lock-color imagemagick scrot ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + fontconfig + gawk + getopt + i3lock-color + imagemagick + scrot + ] + } ''; meta = with lib; { diff --git a/pkgs/applications/window-managers/i3/lock.nix b/pkgs/applications/window-managers/i3/lock.nix index 8c226ac22ba42d..7eb1bfe9471377 100644 --- a/pkgs/applications/window-managers/i3/lock.nix +++ b/pkgs/applications/window-managers/i3/lock.nix @@ -1,5 +1,22 @@ -{ stdenv, lib, fetchFromGitHub, meson, ninja, pkg-config, libxcb, xcbutilkeysyms, xcbutilimage, - xcbutilxrm, pam, libX11, libev, cairo, libxkbcommon, libxkbfile, xorg }: +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + libxcb, + xcbutilkeysyms, + xcbutilimage, + xcbutilxrm, + pam, + libX11, + libev, + cairo, + libxkbcommon, + libxkbfile, + xorg, +}: stdenv.mkDerivation rec { pname = "i3lock"; @@ -12,9 +29,24 @@ stdenv.mkDerivation rec { sha256 = "sha256-OyV6GSLnNV3GUqrfs3OBnIaBvicH2PXgeY4acOk5dR4="; }; - nativeBuildInputs = [ meson ninja pkg-config ]; - buildInputs = [ libxcb xcbutilkeysyms xcbutilimage xcbutilxrm - pam libX11 libev cairo libxkbcommon libxkbfile xorg.xcbutil ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; + buildInputs = [ + libxcb + xcbutilkeysyms + xcbutilimage + xcbutilxrm + pam + libX11 + libev + cairo + libxkbcommon + libxkbfile + xorg.xcbutil + ]; meta = with lib; { description = "Simple screen locker like slock"; @@ -24,7 +56,10 @@ stdenv.mkDerivation rec { for every keystroke. After entering your password, the screen is unlocked again. ''; homepage = "https://i3wm.org/i3lock/"; - maintainers = with maintainers; [ malyn domenkozar ]; + maintainers = with maintainers; [ + malyn + domenkozar + ]; mainProgram = "i3lock"; license = licenses.bsd3; platforms = platforms.all; diff --git a/pkgs/applications/window-managers/i3/status.nix b/pkgs/applications/window-managers/i3/status.nix index 9b2bdc31743f25..47eabbd838097c 100644 --- a/pkgs/applications/window-managers/i3/status.nix +++ b/pkgs/applications/window-managers/i3/status.nix @@ -1,4 +1,21 @@ -{ fetchurl, lib, stdenv, libconfuse, yajl, alsa-lib, libpulseaudio, libnl, meson, ninja, perl, pkg-config, asciidoc, xmlto, docbook_xml_dtd_45, docbook_xsl }: +{ + fetchurl, + lib, + stdenv, + libconfuse, + yajl, + alsa-lib, + libpulseaudio, + libnl, + meson, + ninja, + perl, + pkg-config, + asciidoc, + xmlto, + docbook_xml_dtd_45, + docbook_xsl, +}: stdenv.mkDerivation rec { pname = "i3status"; @@ -9,8 +26,23 @@ stdenv.mkDerivation rec { sha256 = "sha256-bGf1LK5PE533ZK0cxzZWK+D5d1B5G8IStT80wG6vIgU="; }; - nativeBuildInputs = [ meson ninja perl pkg-config asciidoc xmlto docbook_xml_dtd_45 docbook_xsl ]; - buildInputs = [ libconfuse yajl alsa-lib libpulseaudio libnl ]; + nativeBuildInputs = [ + meson + ninja + perl + pkg-config + asciidoc + xmlto + docbook_xml_dtd_45 + docbook_xsl + ]; + buildInputs = [ + libconfuse + yajl + alsa-lib + libpulseaudio + libnl + ]; meta = { description = "Generates a status line for i3bar, dzen2, xmobar or lemonbar"; diff --git a/pkgs/applications/window-managers/i3/swallow.nix b/pkgs/applications/window-managers/i3/swallow.nix index 7b6644d0a99837..7cb42710e7a94a 100644 --- a/pkgs/applications/window-managers/i3/swallow.nix +++ b/pkgs/applications/window-managers/i3/swallow.nix @@ -1,10 +1,11 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, poetry-core -, i3ipc -, xlib -, six +{ + lib, + buildPythonApplication, + fetchFromGitHub, + poetry-core, + i3ipc, + xlib, + six, }: buildPythonApplication rec { diff --git a/pkgs/applications/window-managers/i3/wk-switch.nix b/pkgs/applications/window-managers/i3/wk-switch.nix index fadcfe9908dae6..330ba5c9a80ad3 100644 --- a/pkgs/applications/window-managers/i3/wk-switch.nix +++ b/pkgs/applications/window-managers/i3/wk-switch.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "i3-wk-switch"; diff --git a/pkgs/applications/window-managers/i3/wmfocus.nix b/pkgs/applications/window-managers/i3/wmfocus.nix index af90b968bd043a..d3828484171b37 100644 --- a/pkgs/applications/window-managers/i3/wmfocus.nix +++ b/pkgs/applications/window-managers/i3/wmfocus.nix @@ -1,5 +1,14 @@ -{ lib, fetchFromGitHub, rustPlatform -, xorg, python3, pkg-config, cairo, expat, libxkbcommon }: +{ + lib, + fetchFromGitHub, + rustPlatform, + xorg, + python3, + pkg-config, + cairo, + expat, + libxkbcommon, +}: rustPlatform.buildRustPackage rec { pname = "wmfocus"; @@ -14,8 +23,16 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-sSJAlDe1vBYs1vZW/X04cU14Wj1OF4Jy8oI4uWkrEjk="; - nativeBuildInputs = [ python3 pkg-config ]; - buildInputs = [ cairo expat libxkbcommon xorg.xcbutilkeysyms ]; + nativeBuildInputs = [ + python3 + pkg-config + ]; + buildInputs = [ + cairo + expat + libxkbcommon + xorg.xcbutilkeysyms + ]; # For now, this is the only available featureset. This is also why the file is # in the i3 folder, even though it might be useful for more than just i3 diff --git a/pkgs/applications/window-managers/i3/workstyle.nix b/pkgs/applications/window-managers/i3/workstyle.nix index 10daf03264cacd..cd1694404ce01e 100644 --- a/pkgs/applications/window-managers/i3/workstyle.nix +++ b/pkgs/applications/window-managers/i3/workstyle.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/applications/window-managers/i3/wsr.nix b/pkgs/applications/window-managers/i3/wsr.nix index f282e38b6dcabb..1f4588be0ed680 100644 --- a/pkgs/applications/window-managers/i3/wsr.nix +++ b/pkgs/applications/window-managers/i3/wsr.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, rustPlatform, libxcb, python3 }: +{ + lib, + fetchFromGitHub, + rustPlatform, + libxcb, + python3, +}: rustPlatform.buildRustPackage rec { pname = "i3wsr"; diff --git a/pkgs/applications/window-managers/ion-3/default.nix b/pkgs/applications/window-managers/ion-3/default.nix index 8b0d3beb1c4862..3ab12933a18b8e 100644 --- a/pkgs/applications/window-managers/ion-3/default.nix +++ b/pkgs/applications/window-managers/ion-3/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, lua, gettext, groff, libICE, libSM, libX11, libXext }: +{ + lib, + stdenv, + fetchurl, + lua, + gettext, + groff, + libICE, + libSM, + libX11, + libXext, +}: stdenv.mkDerivation rec { pname = "ion"; @@ -9,9 +20,21 @@ stdenv.mkDerivation rec { sha256 = "1nkks5a95986nyfkxvg2rik6zmwx0lh7szd5fji7yizccwzc9xns"; }; - buildInputs = [ libICE libSM libX11 libXext lua gettext groff ]; + buildInputs = [ + libICE + libSM + libX11 + libXext + lua + gettext + groff + ]; - buildFlags = [ "LUA_DIR=${lua}" "X11_PREFIX=/no-such-path" "PREFIX=\${out}" ]; + buildFlags = [ + "LUA_DIR=${lua}" + "X11_PREFIX=/no-such-path" + "PREFIX=\${out}" + ]; # Build system is missing depends for autogenerated export headers: # luac -o mod_tiling.lc mod_tiling.lua diff --git a/pkgs/applications/window-managers/jwm/default.nix b/pkgs/applications/window-managers/jwm/default.nix index 8a4be8ea9760f3..a307f359dd94d9 100644 --- a/pkgs/applications/window-managers/jwm/default.nix +++ b/pkgs/applications/window-managers/jwm/default.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, expat -, fontconfig -, freetype -, gettext -, libX11 -, libXau -, libXdmcp -, libXext -, libXft -, libXinerama -, libXmu -, libXpm -, libjpeg -, libpng -, librsvg -, pango -, pkg-config -, which -, xorg -, xorgproto -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + expat, + fontconfig, + freetype, + gettext, + libX11, + libXau, + libXdmcp, + libXext, + libXft, + libXinerama, + libXmu, + libXpm, + libjpeg, + libpng, + librsvg, + pango, + pkg-config, + which, + xorg, + xorgproto, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/applications/window-managers/jwm/jwm-settings-manager.nix b/pkgs/applications/window-managers/jwm/jwm-settings-manager.nix index 20caf7291c5dae..be1493f6051490 100644 --- a/pkgs/applications/window-managers/jwm/jwm-settings-manager.nix +++ b/pkgs/applications/window-managers/jwm/jwm-settings-manager.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchbzr, cmake, pkg-config, gettext, libXpm, libGL, fltk, hicolor-icon-theme, glib, gnome2, which }: +{ + lib, + stdenv, + fetchbzr, + cmake, + pkg-config, + gettext, + libXpm, + libGL, + fltk, + hicolor-icon-theme, + glib, + gnome2, + which, +}: stdenv.mkDerivation rec { pname = "jwm-settings-manager"; diff --git a/pkgs/applications/window-managers/lemonbar/default.nix b/pkgs/applications/window-managers/lemonbar/default.nix index 1c66b6fe7ffda4..f157eee581140f 100644 --- a/pkgs/applications/window-managers/lemonbar/default.nix +++ b/pkgs/applications/window-managers/lemonbar/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, perl, libxcb }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, + libxcb, +}: stdenv.mkDerivation rec { pname = "lemonbar"; @@ -11,14 +17,23 @@ stdenv.mkDerivation rec { sha256 = "sha256-OLhgu0kmMZhjv/VST8AXvIH+ysMq72m4TEOypdnatlU="; }; - buildInputs = [ libxcb perl ]; + buildInputs = [ + libxcb + perl + ]; - installFlags = [ "DESTDIR=$(out)" "PREFIX=" ]; + installFlags = [ + "DESTDIR=$(out)" + "PREFIX=" + ]; meta = with lib; { description = "Lightweight xcb based bar"; homepage = "https://github.com/LemonBoy/bar"; - maintainers = with maintainers; [ meisternu moni ]; + maintainers = with maintainers; [ + meisternu + moni + ]; license = licenses.mit; platforms = platforms.linux; mainProgram = "lemonbar"; diff --git a/pkgs/applications/window-managers/lemonbar/xft.nix b/pkgs/applications/window-managers/lemonbar/xft.nix index 014376a37c4059..109d200a29b131 100644 --- a/pkgs/applications/window-managers/lemonbar/xft.nix +++ b/pkgs/applications/window-managers/lemonbar/xft.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, perl, libxcb, libXft }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, + libxcb, + libXft, +}: stdenv.mkDerivation { pname = "lemonbar-xft"; @@ -11,9 +18,16 @@ stdenv.mkDerivation { sha256 = "sha256-BNYBbUouqqsRQaPkpg+UKg62IV9uI34gKJuiAM94CBU="; }; - buildInputs = [ libxcb libXft perl ]; + buildInputs = [ + libxcb + libXft + perl + ]; - installFlags = [ "DESTDIR=$(out)" "PREFIX=" ]; + installFlags = [ + "DESTDIR=$(out)" + "PREFIX=" + ]; meta = with lib; { description = "Lightweight xcb based bar with XFT-support"; diff --git a/pkgs/applications/window-managers/sommelier/default.nix b/pkgs/applications/window-managers/sommelier/default.nix index 99c6892ba3da1e..aaed7906a22174 100644 --- a/pkgs/applications/window-managers/sommelier/default.nix +++ b/pkgs/applications/window-managers/sommelier/default.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchzip -, meson, ninja, pkg-config, python3, python3Packages, wayland-scanner -, libxkbcommon, mesa, pixman, xorg, wayland, gtest +{ + lib, + stdenv, + fetchzip, + meson, + ninja, + pkg-config, + python3, + python3Packages, + wayland-scanner, + libxkbcommon, + mesa, + pixman, + xorg, + wayland, + gtest, }: stdenv.mkDerivation { @@ -15,9 +28,20 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ - meson ninja pkg-config python3 python3Packages.jinja2 wayland-scanner + meson + ninja + pkg-config + python3 + python3Packages.jinja2 + wayland-scanner + ]; + buildInputs = [ + libxkbcommon + mesa + pixman + wayland + xorg.libxcb ]; - buildInputs = [ libxkbcommon mesa pixman wayland xorg.libxcb ]; preConfigure = '' patchShebangs gen-shim.py diff --git a/pkgs/applications/window-managers/tabbed/default.nix b/pkgs/applications/window-managers/tabbed/default.nix index 9108eec14c34d2..d2c123ebc55c4e 100644 --- a/pkgs/applications/window-managers/tabbed/default.nix +++ b/pkgs/applications/window-managers/tabbed/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchgit, xorgproto, libX11, libXft, customConfig ? null, patches ? [ ] }: +{ + lib, + stdenv, + fetchgit, + xorgproto, + libX11, + libXft, + customConfig ? null, + patches ? [ ], +}: stdenv.mkDerivation (finalAttrs: { pname = "tabbed"; @@ -16,7 +25,11 @@ stdenv.mkDerivation (finalAttrs: { cp ${builtins.toFile "config.h" customConfig} ./config.h ''; - buildInputs = [ xorgproto libX11 libXft ]; + buildInputs = [ + xorgproto + libX11 + libXft + ]; makeFlags = [ "CC:=$(CC)" ]; diff --git a/pkgs/applications/window-managers/taffybar/default.nix b/pkgs/applications/window-managers/taffybar/default.nix index 16f6d38b222c94..97da6cede96ea2 100644 --- a/pkgs/applications/window-managers/taffybar/default.nix +++ b/pkgs/applications/window-managers/taffybar/default.nix @@ -1,10 +1,21 @@ -{ stdenv, ghcWithPackages, taffybar, makeWrapper, packages ? (x: []) }: +{ + stdenv, + ghcWithPackages, + taffybar, + makeWrapper, + packages ? (x: [ ]), +}: let - taffybarEnv = ghcWithPackages (self: [ - self.taffybar - ] ++ packages self); -in stdenv.mkDerivation { + taffybarEnv = ghcWithPackages ( + self: + [ + self.taffybar + ] + ++ packages self + ); +in +stdenv.mkDerivation { pname = "taffybar-with-packages"; inherit (taffybar) version; diff --git a/pkgs/applications/window-managers/tinywl/default.nix b/pkgs/applications/window-managers/tinywl/default.nix index 06d2d8d72f8a3d..c9e5019b946352 100644 --- a/pkgs/applications/window-managers/tinywl/default.nix +++ b/pkgs/applications/window-managers/tinywl/default.nix @@ -1,16 +1,43 @@ -{ lib, stdenv, wlroots, pkg-config, wayland-scanner -, libxkbcommon, pixman, udev, wayland, wayland-protocols -, nixosTests +{ + lib, + stdenv, + wlroots, + pkg-config, + wayland-scanner, + libxkbcommon, + pixman, + udev, + wayland, + wayland-protocols, + nixosTests, }: stdenv.mkDerivation { pname = "tinywl"; - inherit (wlroots) version src patches postPatch; + inherit (wlroots) + version + src + patches + postPatch + ; - nativeBuildInputs = [ pkg-config wayland-scanner ]; - buildInputs = [ libxkbcommon pixman udev wayland wayland-protocols wlroots ]; + nativeBuildInputs = [ + pkg-config + wayland-scanner + ]; + buildInputs = [ + libxkbcommon + pixman + udev + wayland + wayland-protocols + wlroots + ]; - makeFlags = [ "-C" "tinywl" ]; + makeFlags = [ + "-C" + "tinywl" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/applications/window-managers/wayfire/default.nix b/pkgs/applications/window-managers/wayfire/default.nix index 39dbac8b5289b0..be4dff33036dcb 100644 --- a/pkgs/applications/window-managers/wayfire/default.nix +++ b/pkgs/applications/window-managers/wayfire/default.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, nixosTests -, cmake -, meson -, ninja -, pkg-config -, wf-config -, cairo -, doctest -, libGL -, libdrm -, libexecinfo -, libevdev -, libinput -, libjpeg -, libxkbcommon -, wayland -, wayland-protocols -, wayland-scanner -, wlroots -, pango -, nlohmann_json -, xorg +{ + lib, + stdenv, + fetchFromGitHub, + nixosTests, + cmake, + meson, + ninja, + pkg-config, + wf-config, + cairo, + doctest, + libGL, + libdrm, + libexecinfo, + libevdev, + libinput, + libjpeg, + libxkbcommon, + wayland, + wayland-protocols, + wayland-scanner, + wlroots, + pango, + nlohmann_json, + xorg, }: stdenv.mkDerivation (finalAttrs: { @@ -90,7 +91,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://wayfire.org/"; description = "3D Wayland compositor"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ wucke13 rewine ]; + maintainers = with lib.maintainers; [ + wucke13 + rewine + ]; platforms = lib.platforms.unix; mainProgram = "wayfire"; }; diff --git a/pkgs/applications/window-managers/wayfire/firedecor.nix b/pkgs/applications/window-managers/wayfire/firedecor.nix index 6fbe4b5575bba2..573a78abb0bcf7 100644 --- a/pkgs/applications/window-managers/wayfire/firedecor.nix +++ b/pkgs/applications/window-managers/wayfire/firedecor.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, boost -, glib -, libGL -, libinput -, librsvg -, libxkbcommon -, udev -, wayfire -, xcbutilwm -, mate +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + boost, + glib, + libGL, + libinput, + librsvg, + libxkbcommon, + udev, + wayfire, + xcbutilwm, + mate, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/window-managers/wayfire/focus-request.nix b/pkgs/applications/window-managers/wayfire/focus-request.nix index 4c885c7a42fdcf..cae7bc39f06521 100644 --- a/pkgs/applications/window-managers/wayfire/focus-request.nix +++ b/pkgs/applications/window-managers/wayfire/focus-request.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitLab -, meson -, ninja -, pkg-config -, wayfire -, wf-config -, wayland -, pango -, libinput -, libxkbcommon -, librsvg -, libGL -, xcbutilwm +{ + stdenv, + lib, + fetchFromGitLab, + meson, + ninja, + pkg-config, + wayfire, + wf-config, + wayland, + pango, + libinput, + libxkbcommon, + librsvg, + libGL, + xcbutilwm, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/window-managers/wayfire/plugins.nix b/pkgs/applications/window-managers/wayfire/plugins.nix index e6663b477f711e..5675e53b7e33e1 100644 --- a/pkgs/applications/window-managers/wayfire/plugins.nix +++ b/pkgs/applications/window-managers/wayfire/plugins.nix @@ -1,9 +1,11 @@ { lib, pkgs }: -lib.makeScope pkgs.newScope (self: +lib.makeScope pkgs.newScope ( + self: let inherit (self) callPackage; - in { + in + { firedecor = callPackage ./firedecor.nix { }; focus-request = callPackage ./focus-request.nix { }; wayfire-plugins-extra = callPackage ./wayfire-plugins-extra.nix { }; diff --git a/pkgs/applications/window-managers/wayfire/wayfire-plugins-extra.nix b/pkgs/applications/window-managers/wayfire/wayfire-plugins-extra.nix index 5b4161cc45438d..3d86c62fd4b0e3 100644 --- a/pkgs/applications/window-managers/wayfire/wayfire-plugins-extra.nix +++ b/pkgs/applications/window-managers/wayfire/wayfire-plugins-extra.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, wayfire -, wayland-scanner -, wf-config -, libevdev -, libinput -, libxkbcommon -, nlohmann_json -, xcbutilwm -, gtkmm3 +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + wayfire, + wayland-scanner, + wf-config, + libevdev, + libinput, + libxkbcommon, + nlohmann_json, + xcbutilwm, + gtkmm3, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/window-managers/wayfire/wayfire-shadows.nix b/pkgs/applications/window-managers/wayfire/wayfire-shadows.nix index e36f691382ce2e..e2cc98b6c1477b 100644 --- a/pkgs/applications/window-managers/wayfire/wayfire-shadows.nix +++ b/pkgs/applications/window-managers/wayfire/wayfire-shadows.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, unstableGitUpdater -, meson -, ninja -, pkg-config -, wayfire -, libxkbcommon -, libGL -, libinput -, xcbutilwm +{ + stdenv, + lib, + fetchFromGitHub, + unstableGitUpdater, + meson, + ninja, + pkg-config, + wayfire, + libxkbcommon, + libGL, + libinput, + xcbutilwm, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/window-managers/wayfire/wcm.nix b/pkgs/applications/window-managers/wayfire/wcm.nix index f82dac2e516224..01b1d64f252f73 100644 --- a/pkgs/applications/window-managers/wayfire/wcm.nix +++ b/pkgs/applications/window-managers/wayfire/wcm.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, wrapGAppsHook3 -, wayfire -, wf-shell -, wayland-scanner -, wayland-protocols -, gtk3 -, gtkmm3 -, libevdev -, libxml2 -, libxkbcommon +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + wrapGAppsHook3, + wayfire, + wf-shell, + wayland-scanner, + wayland-protocols, + gtk3, + gtkmm3, + libevdev, + libxml2, + libxkbcommon, }: stdenv.mkDerivation (finalAttrs: { @@ -55,7 +56,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/WayfireWM/wcm"; description = "Wayfire Config Manager"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ wucke13 rewine ]; + maintainers = with lib.maintainers; [ + wucke13 + rewine + ]; platforms = lib.platforms.unix; mainProgram = "wcm"; }; diff --git a/pkgs/applications/window-managers/wayfire/wf-config.nix b/pkgs/applications/window-managers/wayfire/wf-config.nix index a61230dec2f92f..8ebbd647bcd771 100644 --- a/pkgs/applications/window-managers/wayfire/wf-config.nix +++ b/pkgs/applications/window-managers/wayfire/wf-config.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, meson -, ninja -, pkg-config -, doctest -, glm -, libevdev -, libxml2 +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + meson, + ninja, + pkg-config, + doctest, + glm, + libevdev, + libxml2, }: stdenv.mkDerivation (finalAttrs: { @@ -54,7 +55,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/WayfireWM/wf-config"; description = "Library for managing configuration files, written for Wayfire"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ wucke13 rewine ]; + maintainers = with lib.maintainers; [ + wucke13 + rewine + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/applications/window-managers/wayfire/wf-shell.nix b/pkgs/applications/window-managers/wayfire/wf-shell.nix index e6d64bd902bc70..479b38bc802a9f 100644 --- a/pkgs/applications/window-managers/wayfire/wf-shell.nix +++ b/pkgs/applications/window-managers/wayfire/wf-shell.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, wayland-scanner -, wayfire -, alsa-lib -, gtkmm3 -, gtk-layer-shell -, pulseaudio -, libdbusmenu-gtk3 +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + wayland-scanner, + wayfire, + alsa-lib, + gtkmm3, + gtk-layer-shell, + pulseaudio, + libdbusmenu-gtk3, }: stdenv.mkDerivation (finalAttrs: { @@ -47,7 +48,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/WayfireWM/wf-shell"; description = "GTK3-based panel for Wayfire"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ wucke13 rewine ]; + maintainers = with lib.maintainers; [ + wucke13 + rewine + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/applications/window-managers/wayfire/windecor.nix b/pkgs/applications/window-managers/wayfire/windecor.nix index a87d95344d41fb..7c80aa9ab3455e 100644 --- a/pkgs/applications/window-managers/wayfire/windecor.nix +++ b/pkgs/applications/window-managers/wayfire/windecor.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitLab -, meson -, ninja -, pkg-config -, wayfire -, eudev -, libinput -, libxkbcommon -, librsvg -, libGL -, xcbutilwm +{ + stdenv, + lib, + fetchFromGitLab, + meson, + ninja, + pkg-config, + wayfire, + eudev, + libinput, + libxkbcommon, + librsvg, + libGL, + xcbutilwm, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/window-managers/wayfire/wrapper.nix b/pkgs/applications/window-managers/wayfire/wrapper.nix index a3ec8572271762..b8193bbc63fd22 100644 --- a/pkgs/applications/window-managers/wayfire/wrapper.nix +++ b/pkgs/applications/window-managers/wayfire/wrapper.nix @@ -1,4 +1,10 @@ -{ symlinkJoin, lib, makeWrapper, wayfire, plugins ? [ ] }: +{ + symlinkJoin, + lib, + makeWrapper, + wayfire, + plugins ? [ ], +}: symlinkJoin { name = "wayfire-wrapped-${lib.getVersion wayfire}"; @@ -25,7 +31,7 @@ symlinkJoin { meta = wayfire.meta // { # To prevent builds on hydra - hydraPlatforms = []; + hydraPlatforms = [ ]; # prefer wrapper over the package priority = (wayfire.meta.priority or lib.meta.defaultPriority) - 1; }; diff --git a/pkgs/applications/window-managers/wayfire/wwp-switcher.nix b/pkgs/applications/window-managers/wayfire/wwp-switcher.nix index 4eb42af6995b77..109ecc6e06e553 100644 --- a/pkgs/applications/window-managers/wayfire/wwp-switcher.nix +++ b/pkgs/applications/window-managers/wayfire/wwp-switcher.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchFromGitHub -, unstableGitUpdater -, meson -, ninja -, pkg-config -, wayfire -, libxkbcommon -, libGL -, libinput -, gtk3 -, glibmm -, xcbutilwm +{ + stdenv, + lib, + fetchFromGitHub, + unstableGitUpdater, + meson, + ninja, + pkg-config, + wayfire, + libxkbcommon, + libGL, + libinput, + gtk3, + glibmm, + xcbutilwm, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/applications/window-managers/xmonad/log-applet/default.nix b/pkgs/applications/window-managers/xmonad/log-applet/default.nix index 2e6d72b91071b2..da3aa7c4286545 100644 --- a/pkgs/applications/window-managers/xmonad/log-applet/default.nix +++ b/pkgs/applications/window-managers/xmonad/log-applet/default.nix @@ -1,11 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, autoreconfHook, glib, dbus-glib -, desktopSupport ? "gnomeflashback", xorg -, gtk2 -, gtk3, gnome-panel, mate -, libxfce4util, xfce4-panel +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + glib, + dbus-glib, + desktopSupport ? "gnomeflashback", + xorg, + gtk2, + gtk3, + gnome-panel, + mate, + libxfce4util, + xfce4-panel, }: -assert desktopSupport == "gnomeflashback" || desktopSupport == "mate" || desktopSupport == "xfce4"; +assert desktopSupport == "gnomeflashback" || desktopSupport == "mate" || desktopSupport == "xfce4"; stdenv.mkDerivation rec { version = "unstable-2017-09-15"; @@ -19,15 +30,32 @@ stdenv.mkDerivation rec { sha256 = "042307grf4zvn61gnflhsj5xsjykrk9sjjsprprm4iij0qpybxcw"; }; - buildInputs = [ glib dbus-glib xorg.xcbutilwm ] - ++ lib.optionals (desktopSupport == "gnomeflashback") [ gtk3 gnome-panel ] - ++ lib.optionals (desktopSupport == "mate") [ gtk3 mate.mate-panel ] - ++ lib.optionals (desktopSupport == "xfce4") [ gtk2 libxfce4util xfce4-panel ] - ; + buildInputs = + [ + glib + dbus-glib + xorg.xcbutilwm + ] + ++ lib.optionals (desktopSupport == "gnomeflashback") [ + gtk3 + gnome-panel + ] + ++ lib.optionals (desktopSupport == "mate") [ + gtk3 + mate.mate-panel + ] + ++ lib.optionals (desktopSupport == "xfce4") [ + gtk2 + libxfce4util + xfce4-panel + ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - configureFlags = [ "--with-panel=${desktopSupport}" ]; + configureFlags = [ "--with-panel=${desktopSupport}" ]; patches = [ ./fix-paths.patch ]; @@ -44,4 +72,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ abbradar ]; }; } - diff --git a/pkgs/applications/window-managers/xmonad/wrapper.nix b/pkgs/applications/window-managers/xmonad/wrapper.nix index 9167b95ddff826..5128f06988272a 100644 --- a/pkgs/applications/window-managers/xmonad/wrapper.nix +++ b/pkgs/applications/window-managers/xmonad/wrapper.nix @@ -1,8 +1,15 @@ -{ stdenv, ghcWithPackages, xmessage, makeWrapper, packages }: +{ + stdenv, + ghcWithPackages, + xmessage, + makeWrapper, + packages, +}: let -xmonadEnv = ghcWithPackages (self: [ self.xmonad ] ++ packages self); -in stdenv.mkDerivation { + xmonadEnv = ghcWithPackages (self: [ self.xmonad ] ++ packages self); +in +stdenv.mkDerivation { pname = "xmonad-with-packages"; inherit (xmonadEnv) version; diff --git a/pkgs/applications/window-managers/xmonad/xmonadctl.nix b/pkgs/applications/window-managers/xmonad/xmonadctl.nix index 23495f5d004186..a755982afda238 100644 --- a/pkgs/applications/window-managers/xmonad/xmonadctl.nix +++ b/pkgs/applications/window-managers/xmonad/xmonadctl.nix @@ -1,7 +1,18 @@ -{ stdenv, lib, ghcWithPackages, haskellPackages, ... }: +{ + stdenv, + lib, + ghcWithPackages, + haskellPackages, + ... +}: -let xmonadctlEnv = ghcWithPackages (self: [ self.xmonad-contrib self.X11 ]); -in stdenv.mkDerivation rec { +let + xmonadctlEnv = ghcWithPackages (self: [ + self.xmonad-contrib + self.X11 + ]); +in +stdenv.mkDerivation rec { pname = "xmonadctl"; inherit (haskellPackages.xmonad-contrib) src version; diff --git a/pkgs/applications/window-managers/yabar/build.nix b/pkgs/applications/window-managers/yabar/build.nix index 25ab000594aa75..b455b32fa7ae57 100644 --- a/pkgs/applications/window-managers/yabar/build.nix +++ b/pkgs/applications/window-managers/yabar/build.nix @@ -1,7 +1,24 @@ -{ stdenv, fetchFromGitHub, cairo, gdk-pixbuf, libconfig, pango, pkg-config -, xcbutilwm, alsa-lib, wirelesstools, asciidoc, libxslt, makeWrapper, docbook_xsl -, configFile ? null, lib -, rev, sha256, version, patches ? [] +{ + stdenv, + fetchFromGitHub, + cairo, + gdk-pixbuf, + libconfig, + pango, + pkg-config, + xcbutilwm, + alsa-lib, + wirelesstools, + asciidoc, + libxslt, + makeWrapper, + docbook_xsl, + configFile ? null, + lib, + rev, + sha256, + version, + patches ? [ ], }: stdenv.mkDerivation { @@ -12,7 +29,7 @@ stdenv.mkDerivation { inherit rev sha256; owner = "geommer"; - repo = "yabar"; + repo = "yabar"; }; inherit patches; @@ -48,27 +65,28 @@ stdenv.mkDerivation { --replace "a2x" "a2x --no-xmllint" ''; - makeFlags = [ "DESTDIR=$(out)" "PREFIX=/" ]; + makeFlags = [ + "DESTDIR=$(out)" + "PREFIX=/" + ]; postInstall = '' mkdir -p $out/share/yabar/examples cp -v examples/*.config $out/share/yabar/examples - ${lib.optionalString (configFile != null) - '' - wrapProgram "$out/bin/yabar" \ - --add-flags "-c ${configFile}" - '' - } + ${lib.optionalString (configFile != null) '' + wrapProgram "$out/bin/yabar" \ + --add-flags "-c ${configFile}" + ''} ''; #passthru.tests = { inherit (nixosTests) yabar; }; # nixos currently uses yabar-unstable meta = with lib; { description = "Modern and lightweight status bar for X window managers"; - homepage = "https://github.com/geommer/yabar"; - license = licenses.mit; - platforms = platforms.linux; + homepage = "https://github.com/geommer/yabar"; + license = licenses.mit; + platforms = platforms.linux; maintainers = [ ]; mainProgram = "yabar"; }; diff --git a/pkgs/applications/window-managers/yabar/default.nix b/pkgs/applications/window-managers/yabar/default.nix index a33a75676ee94b..5a58d086340cbb 100644 --- a/pkgs/applications/window-managers/yabar/default.nix +++ b/pkgs/applications/window-managers/yabar/default.nix @@ -1,4 +1,8 @@ -{ callPackage, attrs ? {}, fetchpatch }: +{ + callPackage, + attrs ? { }, + fetchpatch, +}: let overrides = rec { @@ -15,4 +19,5 @@ let ]; } // attrs; -in callPackage ./build.nix overrides +in +callPackage ./build.nix overrides diff --git a/pkgs/applications/window-managers/yabar/unstable.nix b/pkgs/applications/window-managers/yabar/unstable.nix index cb43c4e0b95eea..44998faaf66759 100644 --- a/pkgs/applications/window-managers/yabar/unstable.nix +++ b/pkgs/applications/window-managers/yabar/unstable.nix @@ -1,30 +1,42 @@ -{ fetchpatch, playerctl, libxkbcommon, callPackage, nixosTests, attrs ? {} }: +{ + fetchpatch, + playerctl, + libxkbcommon, + callPackage, + nixosTests, + attrs ? { }, +}: let - pkg = callPackage ./build.nix ({ - version = "unstable-2018-01-18"; + pkg = callPackage ./build.nix ( + { + version = "unstable-2018-01-18"; - rev = "c516e8e78d39dd2b339acadc4c175347171150bb"; - sha256 = "1p9lx78cayyn7qc2q66id2xfs76jyddnqv2x1ypsvixaxwcvqgdb"; - } // attrs); -in pkg.overrideAttrs (o: { + rev = "c516e8e78d39dd2b339acadc4c175347171150bb"; + sha256 = "1p9lx78cayyn7qc2q66id2xfs76jyddnqv2x1ypsvixaxwcvqgdb"; + } + // attrs + ); +in +pkg.overrideAttrs (o: { buildInputs = o.buildInputs ++ [ - playerctl libxkbcommon + playerctl + libxkbcommon ]; makeFlags = o.makeFlags ++ [ "PLAYERCTL=1" ]; - patches = (o.patches or []) ++ [ + patches = (o.patches or [ ]) ++ [ (fetchpatch { url = "https://github.com/geommer/yabar/commit/008dc1420ff684cf12ce2ef3ac9d642e054e39f5.patch"; sha256 = "1q7nd66ai6nr2m6iqxn55gvbr4r5gjc00c8wyjc3riv31qcbqbhv"; }) ]; - passthru = (o.passthru or {}) // { - tests = (o.passthru.tests or {}) // { + passthru = (o.passthru or { }) // { + tests = (o.passthru.tests or { }) // { inherit (nixosTests) yabar; }; }; diff --git a/pkgs/build-support/agda/default.nix b/pkgs/build-support/agda/default.nix index 12dfdc4b5122ca..957b423c31f6c1 100644 --- a/pkgs/build-support/agda/default.nix +++ b/pkgs/build-support/agda/default.nix @@ -1,6 +1,16 @@ # Builder for Agda packages. -{ stdenv, lib, self, Agda, runCommand, makeWrapper, writeText, ghcWithPackages, nixosTests }: +{ + stdenv, + lib, + self, + Agda, + runCommand, + makeWrapper, + writeText, + ghcWithPackages, + nixosTests, +}: let inherit (lib) @@ -19,40 +29,48 @@ let optionalString ; - mkLibraryFile = pkgs: let - pkgs' = if isList pkgs then pkgs else pkgs self; - in writeText "libraries" '' - ${(concatMapStringsSep "\n" (p: "${p}/${p.libraryFile}") pkgs')} - ''; - - withPackages' = { - pkgs, - ghc ? ghcWithPackages (p: with p; [ ieee754 ]) - }: let - library-file = mkLibraryFile pkgs; - pname = "agdaWithPackages"; - version = Agda.version; - in runCommand "${pname}-${version}" { - inherit pname version; - nativeBuildInputs = [ makeWrapper ]; - passthru = { - unwrapped = Agda; - inherit withPackages; - tests = { - inherit (nixosTests) agda; - allPackages = withPackages (filter self.lib.isUnbrokenAgdaPackage (attrValues self)); - }; - }; - # Agda is a split package with multiple outputs; do not inherit them here. - meta = removeAttrs Agda.meta [ "outputsToInstall" ]; - } '' - mkdir -p $out/bin - makeWrapper ${Agda.bin}/bin/agda $out/bin/agda \ - --add-flags "--with-compiler=${ghc}/bin/ghc" \ - --add-flags "--library-file=${library-file}" - ln -s ${Agda.bin}/bin/agda-mode $out/bin/agda-mode + mkLibraryFile = + pkgs: + let + pkgs' = if isList pkgs then pkgs else pkgs self; + in + writeText "libraries" '' + ${(concatMapStringsSep "\n" (p: "${p}/${p.libraryFile}") pkgs')} ''; + withPackages' = + { + pkgs, + ghc ? ghcWithPackages (p: with p; [ ieee754 ]), + }: + let + library-file = mkLibraryFile pkgs; + pname = "agdaWithPackages"; + version = Agda.version; + in + runCommand "${pname}-${version}" + { + inherit pname version; + nativeBuildInputs = [ makeWrapper ]; + passthru = { + unwrapped = Agda; + inherit withPackages; + tests = { + inherit (nixosTests) agda; + allPackages = withPackages (filter self.lib.isUnbrokenAgdaPackage (attrValues self)); + }; + }; + # Agda is a split package with multiple outputs; do not inherit them here. + meta = removeAttrs Agda.meta [ "outputsToInstall" ]; + } + '' + mkdir -p $out/bin + makeWrapper ${Agda.bin}/bin/agda $out/bin/agda \ + --add-flags "--with-compiler=${ghc}/bin/ghc" \ + --add-flags "--library-file=${library-file}" + ln -s ${Agda.bin}/bin/agda-mode $out/bin/agda-mode + ''; + withPackages = arg: if isAttrs arg then withPackages' arg else withPackages' { pkgs = arg; }; extensions = [ @@ -68,55 +86,70 @@ let ]; defaults = - { pname - , meta - , buildInputs ? [] - , everythingFile ? "./Everything.agda" - , includePaths ? [] - , libraryName ? pname - , libraryFile ? "${libraryName}.agda-lib" - , buildPhase ? null - , installPhase ? null - , extraExtensions ? [] - , ... - }: let + { + pname, + meta, + buildInputs ? [ ], + everythingFile ? "./Everything.agda", + includePaths ? [ ], + libraryName ? pname, + libraryFile ? "${libraryName}.agda-lib", + buildPhase ? null, + installPhase ? null, + extraExtensions ? [ ], + ... + }: + let agdaWithArgs = withPackages (filter (p: p ? isAgdaDerivation) buildInputs); - includePathArgs = concatMapStrings (path: "-i" + path + " ") (includePaths ++ [(dirOf everythingFile)]); + includePathArgs = concatMapStrings (path: "-i" + path + " ") ( + includePaths ++ [ (dirOf everythingFile) ] + ); in - { - inherit libraryName libraryFile; - - isAgdaDerivation = true; - - buildInputs = buildInputs ++ [ agdaWithArgs ]; - - buildPhase = if buildPhase != null then buildPhase else '' - runHook preBuild - agda ${includePathArgs} ${everythingFile} - rm ${everythingFile} ${lib.interfaceFile Agda.version everythingFile} - runHook postBuild - ''; - - installPhase = if installPhase != null then installPhase else '' - runHook preInstall - mkdir -p $out - find \( ${concatMapStringsSep " -or " (p: "-name '*.${p}'") (extensions ++ extraExtensions)} \) -exec cp -p --parents -t "$out" {} + - runHook postInstall - ''; - - # As documented at https://github.com/NixOS/nixpkgs/issues/172752, - # we need to set LC_ALL to an UTF-8-supporting locale. However, on - # darwin, it seems that there is no standard such locale; luckily, - # the referenced issue doesn't seem to surface on darwin. Hence let's - # set this only on non-darwin. - LC_ALL = optionalString (!stdenv.hostPlatform.isDarwin) "C.UTF-8"; - - meta = if meta.broken or false then meta // { hydraPlatforms = platforms.none; } else meta; - - # Retrieve all packages from the finished package set that have the current package as a dependency and build them - passthru.tests = - filterAttrs (name: pkg: self.lib.isUnbrokenAgdaPackage pkg && elem pname (map (pkg: pkg.pname) pkg.buildInputs)) self; - }; + { + inherit libraryName libraryFile; + + isAgdaDerivation = true; + + buildInputs = buildInputs ++ [ agdaWithArgs ]; + + buildPhase = + if buildPhase != null then + buildPhase + else + '' + runHook preBuild + agda ${includePathArgs} ${everythingFile} + rm ${everythingFile} ${lib.interfaceFile Agda.version everythingFile} + runHook postBuild + ''; + + installPhase = + if installPhase != null then + installPhase + else + '' + runHook preInstall + mkdir -p $out + find \( ${ + concatMapStringsSep " -or " (p: "-name '*.${p}'") (extensions ++ extraExtensions) + } \) -exec cp -p --parents -t "$out" {} + + runHook postInstall + ''; + + # As documented at https://github.com/NixOS/nixpkgs/issues/172752, + # we need to set LC_ALL to an UTF-8-supporting locale. However, on + # darwin, it seems that there is no standard such locale; luckily, + # the referenced issue doesn't seem to surface on darwin. Hence let's + # set this only on non-darwin. + LC_ALL = optionalString (!stdenv.hostPlatform.isDarwin) "C.UTF-8"; + + meta = if meta.broken or false then meta // { hydraPlatforms = platforms.none; } else meta; + + # Retrieve all packages from the finished package set that have the current package as a dependency and build them + passthru.tests = filterAttrs ( + name: pkg: self.lib.isUnbrokenAgdaPackage pkg && elem pname (map (pkg: pkg.pname) pkg.buildInputs) + ) self; + }; in { mkDerivation = args: stdenv.mkDerivation (args // defaults args); diff --git a/pkgs/build-support/agda/lib.nix b/pkgs/build-support/agda/lib.nix index 63fa6ccddba6b0..4bdb80a6ca0027 100644 --- a/pkgs/build-support/agda/lib.nix +++ b/pkgs/build-support/agda/lib.nix @@ -1,17 +1,25 @@ { lib }: { - /* Returns the Agda interface file to a given Agda file. - * - * The resulting path may not be normalized. - * - * Examples: - * interfaceFile pkgs.agda.version "./Everything.agda" == "_build/2.6.4.3/agda/./Everything.agdai" - * interfaceFile pkgs.agda.version "src/Everything.lagda.tex" == "_build/2.6.4.3/agda/src/Everything.agdai" + /* + Returns the Agda interface file to a given Agda file. + * + * The resulting path may not be normalized. + * + * Examples: + * interfaceFile pkgs.agda.version "./Everything.agda" == "_build/2.6.4.3/agda/./Everything.agdai" + * interfaceFile pkgs.agda.version "src/Everything.lagda.tex" == "_build/2.6.4.3/agda/src/Everything.agdai" */ - interfaceFile = agdaVersion: agdaFile: "_build/" + agdaVersion + "/agda/" + lib.head (builtins.match ''(.*\.)l?agda(\.(md|org|rst|tex|typ))?'' agdaFile) + "agdai"; + interfaceFile = + agdaVersion: agdaFile: + "_build/" + + agdaVersion + + "/agda/" + + lib.head (builtins.match ''(.*\.)l?agda(\.(md|org|rst|tex|typ))?'' agdaFile) + + "agdai"; - /* Takes an arbitrary derivation and says whether it is an agda library package - * that is not marked as broken. + /* + Takes an arbitrary derivation and says whether it is an agda library package + * that is not marked as broken. */ isUnbrokenAgdaPackage = pkg: pkg.isAgdaDerivation or false && !pkg.meta.broken; } diff --git a/pkgs/build-support/binary-cache/default.nix b/pkgs/build-support/binary-cache/default.nix index 8c610c512276eb..0d8829199827ea 100644 --- a/pkgs/build-support/binary-cache/default.nix +++ b/pkgs/build-support/binary-cache/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, coreutils, jq, python3, nix, xz }: +{ + lib, + stdenv, + coreutils, + jq, + python3, + nix, + xz, +}: # This function is for creating a flat-file binary cache, i.e. the kind created by # nix copy --to file:///some/path and usable as a substituter (with the file:// prefix). @@ -6,8 +14,9 @@ # For example, in the Nixpkgs repo: # nix-build -E 'with import ./. {}; mkBinaryCache { rootPaths = [hello]; }' -{ name ? "binary-cache" -, rootPaths +{ + name ? "binary-cache", + rootPaths, }: stdenv.mkDerivation { @@ -19,7 +28,13 @@ stdenv.mkDerivation { preferLocalBuild = true; - nativeBuildInputs = [ coreutils jq python3 nix xz ]; + nativeBuildInputs = [ + coreutils + jq + python3 + nix + xz + ]; buildCommand = '' mkdir -p $out/nar diff --git a/pkgs/build-support/build-fhsenv-chroot/chrootenv/default.nix b/pkgs/build-support/build-fhsenv-chroot/chrootenv/default.nix index 856d8e9ccdff06..99903f3e4ad6af 100644 --- a/pkgs/build-support/build-fhsenv-chroot/chrootenv/default.nix +++ b/pkgs/build-support/build-fhsenv-chroot/chrootenv/default.nix @@ -1,10 +1,21 @@ -{ lib, stdenv, meson, ninja, pkg-config, glib }: +{ + lib, + stdenv, + meson, + ninja, + pkg-config, + glib, +}: stdenv.mkDerivation { name = "chrootenv"; src = ./src; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; buildInputs = [ glib ]; meta = with lib; { diff --git a/pkgs/build-support/build-fhsenv-chroot/default.nix b/pkgs/build-support/build-fhsenv-chroot/default.nix index b1d9630ae8f91e..10d2af55a7b023 100644 --- a/pkgs/build-support/build-fhsenv-chroot/default.nix +++ b/pkgs/build-support/build-fhsenv-chroot/default.nix @@ -1,53 +1,87 @@ -{ lib, callPackage, runCommandLocal, writeScript, stdenv, coreutils }: +{ + lib, + callPackage, + runCommandLocal, + writeScript, + stdenv, + coreutils, +}: -let buildFHSEnv = callPackage ./env.nix { }; in +let + buildFHSEnv = callPackage ./env.nix { }; +in -args@{ name, version ? null, runScript ? "bash", nativeBuildInputs ? [], extraInstallCommands ? "", meta ? {}, passthru ? {}, ... }: +args@{ + name, + version ? null, + runScript ? "bash", + nativeBuildInputs ? [ ], + extraInstallCommands ? "", + meta ? { }, + passthru ? { }, + ... +}: let - env = buildFHSEnv (removeAttrs args [ "version" "runScript" "extraInstallCommands" "meta" "passthru" ]); + env = buildFHSEnv ( + removeAttrs args [ + "version" + "runScript" + "extraInstallCommands" + "meta" + "passthru" + ] + ); - chrootenv = callPackage ./chrootenv {}; + chrootenv = callPackage ./chrootenv { }; - init = run: writeScript "${name}-init" '' - #! ${stdenv.shell} - for i in ${env}/* /host/*; do - path="/''${i##*/}" - [ -e "$path" ] || ${coreutils}/bin/ln -s "$i" "$path" - done + init = + run: + writeScript "${name}-init" '' + #! ${stdenv.shell} + for i in ${env}/* /host/*; do + path="/''${i##*/}" + [ -e "$path" ] || ${coreutils}/bin/ln -s "$i" "$path" + done - [ -d "$1" ] && [ -r "$1" ] && cd "$1" - shift + [ -d "$1" ] && [ -r "$1" ] && cd "$1" + shift - source /etc/profile - exec ${run} "$@" - ''; + source /etc/profile + exec ${run} "$@" + ''; versionStr = lib.optionalString (version != null) ("-" + version); nameAndVersion = name + versionStr; -in runCommandLocal nameAndVersion { - inherit nativeBuildInputs meta; - - passthru = passthru // { - env = runCommandLocal "${name}-shell-env" { - shellHook = '' - exec ${chrootenv}/bin/chrootenv ${init runScript} "$(pwd)" - ''; - } '' - echo >&2 "" - echo >&2 "*** User chroot 'env' attributes are intended for interactive nix-shell sessions, not for building! ***" - echo >&2 "" - exit 1 - ''; - }; -} '' - mkdir -p $out/bin - cat <$out/bin/${name} - #! ${stdenv.shell} - exec ${chrootenv}/bin/chrootenv ${init runScript} "\$(pwd)" "\$@" - EOF - chmod +x $out/bin/${name} - ${extraInstallCommands} -'' +in +runCommandLocal nameAndVersion + { + inherit nativeBuildInputs meta; + + passthru = passthru // { + env = + runCommandLocal "${name}-shell-env" + { + shellHook = '' + exec ${chrootenv}/bin/chrootenv ${init runScript} "$(pwd)" + ''; + } + '' + echo >&2 "" + echo >&2 "*** User chroot 'env' attributes are intended for interactive nix-shell sessions, not for building! ***" + echo >&2 "" + exit 1 + ''; + }; + } + '' + mkdir -p $out/bin + cat <$out/bin/${name} + #! ${stdenv.shell} + exec ${chrootenv}/bin/chrootenv ${init runScript} "\$(pwd)" "\$@" + EOF + chmod +x $out/bin/${name} + ${extraInstallCommands} + '' diff --git a/pkgs/build-support/build-fhsenv-chroot/env.nix b/pkgs/build-support/build-fhsenv-chroot/env.nix index 9f8bc07a94adaf..7dbbfbf8d508d4 100644 --- a/pkgs/build-support/build-fhsenv-chroot/env.nix +++ b/pkgs/build-support/build-fhsenv-chroot/env.nix @@ -1,13 +1,21 @@ -{ stdenv, lib, buildEnv, writeText, pkgs, pkgsi686Linux }: - -{ name -, profile ? "" -, targetPkgs ? pkgs: [] -, multiPkgs ? pkgs: [] -, nativeBuildInputs ? [] -, extraBuildCommands ? "" -, extraBuildCommandsMulti ? "" -, extraOutputsToInstall ? [] +{ + stdenv, + lib, + buildEnv, + writeText, + pkgs, + pkgsi686Linux, +}: + +{ + name, + profile ? "", + targetPkgs ? pkgs: [ ], + multiPkgs ? pkgs: [ ], + nativeBuildInputs ? [ ], + extraBuildCommands ? "", + extraBuildCommandsMulti ? "", + extraOutputsToInstall ? [ ], }: # HOWTO: @@ -28,12 +36,12 @@ let is64Bit = stdenv.hostPlatform.parsed.cpu.bits == 64; # multi-lib glibc is only supported on x86_64 - isMultiBuild = multiPkgs != null && stdenv.hostPlatform.system == "x86_64-linux"; + isMultiBuild = multiPkgs != null && stdenv.hostPlatform.system == "x86_64-linux"; isTargetBuild = !isMultiBuild; # list of packages (usually programs) which are only be installed for the # host's architecture - targetPaths = targetPkgs pkgs ++ (if multiPkgs == null then [] else multiPkgs pkgs); + targetPaths = targetPkgs pkgs ++ (if multiPkgs == null then [ ] else multiPkgs pkgs); # list of packages which are installed for both x86 and x86_64 on x86_64 # systems @@ -43,16 +51,28 @@ let # these match the host's architecture, glibc_multi is used for multilib # builds. glibcLocales must be before glibc or glibc_multi as otherwiese # the wrong LOCALE_ARCHIVE will be used where only C.UTF-8 is available. - basePkgs = with pkgs; - [ glibcLocales - (if isMultiBuild then glibc_multi else glibc) - (toString gcc.cc.lib) bashInteractiveFHS coreutils less shadow su - gawk diffutils findutils gnused gnugrep - gnutar gzip bzip2 xz - ]; - baseMultiPkgs = with pkgsi686Linux; - [ (toString gcc.cc.lib) - ]; + basePkgs = with pkgs; [ + glibcLocales + (if isMultiBuild then glibc_multi else glibc) + (toString gcc.cc.lib) + bashInteractiveFHS + coreutils + less + shadow + su + gawk + diffutils + findutils + gnused + gnugrep + gnutar + gzip + bzip2 + xz + ]; + baseMultiPkgs = with pkgsi686Linux; [ + (toString gcc.cc.lib) + ]; etcProfile = writeText "profile" '' export PS1='${name}-chrootenv:\u@\h:\w\$ ' @@ -92,7 +112,7 @@ let # Compose /etc for the chroot environment etcPkg = stdenv.mkDerivation { - name = "${name}-chrootenv-etc"; + name = "${name}-chrootenv-etc"; buildCommand = '' mkdir -p $out/etc cd $out/etc @@ -151,7 +171,11 @@ let staticUsrProfileTarget = buildEnv { name = "${name}-usr-target"; paths = [ etcPkg ] ++ basePkgs ++ targetPaths; - extraOutputsToInstall = [ "out" "lib" "bin" ] ++ extraOutputsToInstall; + extraOutputsToInstall = [ + "out" + "lib" + "bin" + ] ++ extraOutputsToInstall; ignoreCollisions = true; postBuild = '' if [[ -d $out/share/gsettings-schemas/ ]]; then @@ -187,7 +211,10 @@ let staticUsrProfileMulti = buildEnv { name = "${name}-usr-multi"; paths = baseMultiPkgs ++ multiPaths; - extraOutputsToInstall = [ "out" "lib" ] ++ extraOutputsToInstall; + extraOutputsToInstall = [ + "out" + "lib" + ] ++ extraOutputsToInstall; ignoreCollisions = true; }; @@ -217,8 +244,7 @@ let ln -Ls ${staticUsrProfileTarget}/lib/32/ld-linux.so.2 lib/ ''; - setupLibDirs = if isTargetBuild then setupLibDirs_target - else setupLibDirs_multi; + setupLibDirs = if isTargetBuild then setupLibDirs_target else setupLibDirs_multi; # the target profile is the actual profile that will be used for the chroot setupTargetProfile = '' @@ -244,8 +270,9 @@ let done ''; -in stdenv.mkDerivation { - name = "${name}-fhs"; +in +stdenv.mkDerivation { + name = "${name}-fhs"; inherit nativeBuildInputs; buildCommand = '' mkdir -p $out diff --git a/pkgs/build-support/build-graalvm-native-image/default.nix b/pkgs/build-support/build-graalvm-native-image/default.nix index 59c77e93e79b01..45680a42e9ed9e 100644 --- a/pkgs/build-support/build-graalvm-native-image/default.nix +++ b/pkgs/build-support/build-graalvm-native-image/default.nix @@ -1,32 +1,35 @@ -{ lib -, stdenv -, apple-sdk_11 -, darwinMinVersionHook -, glibcLocales +{ + lib, + stdenv, + apple-sdk_11, + darwinMinVersionHook, + glibcLocales, # The GraalVM derivation to use -, graalvmDrv -, removeReferencesTo -, executable ? args.pname + graalvmDrv, + removeReferencesTo, + executable ? args.pname, # JAR used as input for GraalVM derivation, defaults to src -, jar ? args.src -, dontUnpack ? (jar == args.src) + jar ? args.src, + dontUnpack ? (jar == args.src), # Default native-image arguments. You probably don't want to set this, # except in special cases. In most cases, use extraNativeBuildArgs instead -, nativeImageBuildArgs ? [ + nativeImageBuildArgs ? [ (lib.optionalString stdenv.hostPlatform.isDarwin "-H:-CheckToolchain") - (lib.optionalString (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) "-H:PageSize=64K") + (lib.optionalString ( + stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64 + ) "-H:PageSize=64K") "-H:Name=${executable}" "-march=compatibility" "--verbose" - ] + ], # Extra arguments to be passed to the native-image -, extraNativeImageBuildArgs ? [ ] + extraNativeImageBuildArgs ? [ ], # XMX size of GraalVM during build -, graalvmXmx ? "-J-Xmx6g" -, meta ? { } -, LC_ALL ? "en_US.UTF-8" -, ... -} @ args: + graalvmXmx ? "-J-Xmx6g", + meta ? { }, + LC_ALL ? "en_US.UTF-8", + ... +}@args: let extraArgs = builtins.removeAttrs args [ @@ -45,49 +48,58 @@ let "postInstall" ]; in -stdenv.mkDerivation ({ - inherit dontUnpack jar; +stdenv.mkDerivation ( + { + inherit dontUnpack jar; - env = { inherit LC_ALL; }; + env = { inherit LC_ALL; }; - nativeBuildInputs = (args.nativeBuildInputs or [ ]) ++ [ graalvmDrv glibcLocales removeReferencesTo ]; + nativeBuildInputs = (args.nativeBuildInputs or [ ]) ++ [ + graalvmDrv + glibcLocales + removeReferencesTo + ]; - buildInputs = lib.optionals (stdenv.hostPlatform.isDarwin) [ - apple-sdk_11 - (darwinMinVersionHook "11.0") - ]; + buildInputs = lib.optionals (stdenv.hostPlatform.isDarwin) [ + apple-sdk_11 + (darwinMinVersionHook "11.0") + ]; - nativeImageBuildArgs = nativeImageBuildArgs ++ extraNativeImageBuildArgs ++ [ graalvmXmx ]; + nativeImageBuildArgs = nativeImageBuildArgs ++ extraNativeImageBuildArgs ++ [ graalvmXmx ]; - buildPhase = args.buildPhase or '' - runHook preBuild + buildPhase = + args.buildPhase or '' + runHook preBuild - native-image -jar "$jar" ''${nativeImageBuildArgs[@]} + native-image -jar "$jar" ''${nativeImageBuildArgs[@]} - runHook postBuild - ''; + runHook postBuild + ''; - installPhase = args.installPhase or '' - runHook preInstall + installPhase = + args.installPhase or '' + runHook preInstall - install -Dm755 ${executable} -t $out/bin + install -Dm755 ${executable} -t $out/bin - runHook postInstall - ''; + runHook postInstall + ''; - postInstall = '' - remove-references-to -t ${graalvmDrv} $out/bin/${executable} - ${args.postInstall or ""} - ''; + postInstall = '' + remove-references-to -t ${graalvmDrv} $out/bin/${executable} + ${args.postInstall or ""} + ''; - disallowedReferences = [ graalvmDrv ]; + disallowedReferences = [ graalvmDrv ]; - passthru = { inherit graalvmDrv; }; + passthru = { inherit graalvmDrv; }; - meta = { - # default to graalvm's platforms - platforms = graalvmDrv.meta.platforms; - # default to executable name - mainProgram = executable; - } // meta; -} // extraArgs) + meta = { + # default to graalvm's platforms + platforms = graalvmDrv.meta.platforms; + # default to executable name + mainProgram = executable; + } // meta; + } + // extraArgs +) diff --git a/pkgs/build-support/build-nim-package.nix b/pkgs/build-support/build-nim-package.nix index 2bff3bf8cc8575..1e8489212cd6bf 100644 --- a/pkgs/build-support/build-nim-package.nix +++ b/pkgs/build-support/build-nim-package.nix @@ -1,13 +1,14 @@ -{ lib -, buildPackages -, callPackage -, stdenv -, nim1 -, nim2 -, nim_builder -, defaultNimVersion ? 2 -, nimOverrides -, buildNimPackage +{ + lib, + buildPackages, + callPackage, + stdenv, + nim1, + nim2, + nim_builder, + defaultNimVersion ? 2, + nimOverrides, + buildNimPackage, }: let @@ -42,34 +43,51 @@ let fodFromLockEntry = let methods = { - fetchzip = { url, sha256, ... }: + fetchzip = + { url, sha256, ... }: buildPackages.fetchzip { name = "source"; inherit url sha256; }; - git = { fetchSubmodules, leaveDotGit, rev, sha256, url, ... }: + git = + { + fetchSubmodules, + leaveDotGit, + rev, + sha256, + url, + ... + }: buildPackages.fetchgit { - inherit fetchSubmodules leaveDotGit rev sha256 url; + inherit + fetchSubmodules + leaveDotGit + rev + sha256 + url + ; }; }; in attrs@{ method, ... }: - let fod = methods.${method} attrs; - in ''--path:"${fod.outPath}/${attrs.srcDir}"''; + let + fod = methods.${method} attrs; + in + ''--path:"${fod.outPath}/${attrs.srcDir}"''; asFunc = x: if builtins.isFunction x then x else (_: x); in buildNimPackageArgs: let - composition = finalAttrs: + composition = + finalAttrs: let - postPkg = baseAttrs - // (asFunc ((asFunc buildNimPackageArgs) finalAttrs)) baseAttrs; + postPkg = baseAttrs // (asFunc ((asFunc buildNimPackageArgs) finalAttrs)) baseAttrs; - lockAttrs = - lib.attrsets.optionalAttrs (builtins.hasAttr "lockFile" postPkg) - (builtins.fromJSON (builtins.readFile postPkg.lockFile)); + lockAttrs = lib.attrsets.optionalAttrs (builtins.hasAttr "lockFile" postPkg) ( + builtins.fromJSON (builtins.readFile postPkg.lockFile) + ); lockDepends = lockAttrs.depends or [ ]; @@ -88,41 +106,51 @@ let ) postPkg lockDepends; finalOverride = - { depsBuildBuild ? [ ] - , nativeBuildInputs ? [ ] - , nimFlags ? [ ] - , requiredNimVersion ? defaultNimVersion - , passthru ? { } - , ... + { + depsBuildBuild ? [ ], + nativeBuildInputs ? [ ], + nimFlags ? [ ], + requiredNimVersion ? defaultNimVersion, + passthru ? { }, + ... }: - (if requiredNimVersion == 1 then { - depsBuildBuild = [ nim_builder ] ++ depsBuildBuild; - nativeBuildInputs = [ nim1 ] ++ nativeBuildInputs; - } else if requiredNimVersion == 2 then { - depsBuildBuild = [ nim_builder ] ++ depsBuildBuild; - nativeBuildInputs = [ nim2 ] ++ nativeBuildInputs; - } else - throw - "requiredNimVersion ${toString requiredNimVersion} is not valid") // { + ( + if requiredNimVersion == 1 then + { + depsBuildBuild = [ nim_builder ] ++ depsBuildBuild; + nativeBuildInputs = [ nim1 ] ++ nativeBuildInputs; + } + else if requiredNimVersion == 2 then + { + depsBuildBuild = [ nim_builder ] ++ depsBuildBuild; + nativeBuildInputs = [ nim2 ] ++ nativeBuildInputs; + } + else + throw "requiredNimVersion ${toString requiredNimVersion} is not valid" + ) + // { nimFlags = lockFileNimFlags ++ nimFlags; passthru = passthru // { # allow overriding the result of buildNimPackageArgs before this composition is applied # this allows overriding the lockFile for packages built using buildNimPackage # this is adapted from mkDerivationExtensible in stdenv.mkDerivation - overrideNimAttrs = f0: + overrideNimAttrs = + f0: let - f = self: super: - let x = f0 super; + f = + self: super: + let + x = f0 super; in - if builtins.isFunction x - then f0 self super - else x; + if builtins.isFunction x then f0 self super else x; in - buildNimPackage - (self: - let super = (asFunc ((asFunc buildNimPackageArgs) self)) baseAttrs; - in - super // (if builtins.isFunction f0 || f0?__functor then f self super else f0)); + buildNimPackage ( + self: + let + super = (asFunc ((asFunc buildNimPackageArgs) self)) baseAttrs; + in + super // (if builtins.isFunction f0 || f0 ? __functor then f self super else f0) + ); }; }; diff --git a/pkgs/build-support/buildenv/default.nix b/pkgs/build-support/buildenv/default.nix index 5183a358ce7019..a6e3df9f3ade5e 100644 --- a/pkgs/build-support/buildenv/default.nix +++ b/pkgs/build-support/buildenv/default.nix @@ -1,7 +1,13 @@ # buildEnv creates a tree of symlinks to the specified paths. This is # a fork of the hardcoded buildEnv in the Nix distribution. -{ buildPackages, runCommand, lib, substituteAll, writeClosure }: +{ + buildPackages, + runCommand, + lib, + substituteAll, + writeClosure, +}: let builder = substituteAll { @@ -10,83 +16,98 @@ let }; in -lib.makeOverridable -({ name +lib.makeOverridable ( + { + name, -, # The manifest file (if any). A symlink $out/manifest will be - # created to it. - manifest ? "" + # The manifest file (if any). A symlink $out/manifest will be + # created to it. + manifest ? "", -, # The paths to symlink. - paths + # The paths to symlink. + paths, -, # Whether to ignore collisions or abort. - ignoreCollisions ? false + # Whether to ignore collisions or abort. + ignoreCollisions ? false, -, # Whether to include closures of all input paths. - includeClosures ? false + # Whether to include closures of all input paths. + includeClosures ? false, -, # If there is a collision, check whether the contents and permissions match - # and only if not, throw a collision error. - checkCollisionContents ? true + # If there is a collision, check whether the contents and permissions match + # and only if not, throw a collision error. + checkCollisionContents ? true, -, # The paths (relative to each element of `paths') that we want to - # symlink (e.g., ["/bin"]). Any file not inside any of the - # directories in the list is not symlinked. - pathsToLink ? ["/"] + # The paths (relative to each element of `paths') that we want to + # symlink (e.g., ["/bin"]). Any file not inside any of the + # directories in the list is not symlinked. + pathsToLink ? [ "/" ], -, # The package outputs to include. By default, only the default - # output is included. - extraOutputsToInstall ? [] + # The package outputs to include. By default, only the default + # output is included. + extraOutputsToInstall ? [ ], -, # Root the result in directory "$out${extraPrefix}", e.g. "/share". - extraPrefix ? "" + # Root the result in directory "$out${extraPrefix}", e.g. "/share". + extraPrefix ? "", -, # Shell commands to run after building the symlink tree. - postBuild ? "" + # Shell commands to run after building the symlink tree. + postBuild ? "", -# Additional inputs -, nativeBuildInputs ? [] # Handy e.g. if using makeWrapper in `postBuild`. -, buildInputs ? [] + # Additional inputs + nativeBuildInputs ? [ ], # Handy e.g. if using makeWrapper in `postBuild`. + buildInputs ? [ ], -, passthru ? {} -, meta ? {} -}: -let - chosenOutputs = map (drv: { - paths = - # First add the usual output(s): respect if user has chosen explicitly, - # and otherwise use `meta.outputsToInstall`. The attribute is guaranteed - # to exist in mkDerivation-created cases. The other cases (e.g. runCommand) - # aren't expected to have multiple outputs. - (if (! drv ? outputSpecified || ! drv.outputSpecified) - && drv.meta.outputsToInstall or null != null - then map (outName: drv.${outName}) drv.meta.outputsToInstall - else [ drv ]) - # Add any extra outputs specified by the caller of `buildEnv`. - ++ lib.filter (p: p!=null) - (builtins.map (outName: drv.${outName} or null) extraOutputsToInstall); - priority = drv.meta.priority or lib.meta.defaultPriority; - }) paths; + passthru ? { }, + meta ? { }, + }: + let + chosenOutputs = map (drv: { + paths = + # First add the usual output(s): respect if user has chosen explicitly, + # and otherwise use `meta.outputsToInstall`. The attribute is guaranteed + # to exist in mkDerivation-created cases. The other cases (e.g. runCommand) + # aren't expected to have multiple outputs. + ( + if + (!drv ? outputSpecified || !drv.outputSpecified) && drv.meta.outputsToInstall or null != null + then + map (outName: drv.${outName}) drv.meta.outputsToInstall + else + [ drv ] + ) + # Add any extra outputs specified by the caller of `buildEnv`. + ++ lib.filter (p: p != null) (builtins.map (outName: drv.${outName} or null) extraOutputsToInstall); + priority = drv.meta.priority or lib.meta.defaultPriority; + }) paths; - pathsForClosure = lib.pipe chosenOutputs [ - (map (p: p.paths)) - lib.flatten - (lib.remove null) - ]; -in runCommand name - rec { - inherit manifest ignoreCollisions checkCollisionContents passthru - meta pathsToLink extraPrefix postBuild - nativeBuildInputs buildInputs; - pkgs = builtins.toJSON chosenOutputs; - extraPathsFrom = lib.optional includeClosures (writeClosure pathsForClosure); - preferLocalBuild = true; - allowSubstitutes = false; - # XXX: The size is somewhat arbitrary - passAsFile = if builtins.stringLength pkgs >= 128*1024 then [ "pkgs" ] else [ ]; - } - '' - ${buildPackages.perl}/bin/perl -w ${builder} - eval "$postBuild" - '') + pathsForClosure = lib.pipe chosenOutputs [ + (map (p: p.paths)) + lib.flatten + (lib.remove null) + ]; + in + runCommand name + rec { + inherit + manifest + ignoreCollisions + checkCollisionContents + passthru + meta + pathsToLink + extraPrefix + postBuild + nativeBuildInputs + buildInputs + ; + pkgs = builtins.toJSON chosenOutputs; + extraPathsFrom = lib.optional includeClosures (writeClosure pathsForClosure); + preferLocalBuild = true; + allowSubstitutes = false; + # XXX: The size is somewhat arbitrary + passAsFile = if builtins.stringLength pkgs >= 128 * 1024 then [ "pkgs" ] else [ ]; + } + '' + ${buildPackages.perl}/bin/perl -w ${builder} + eval "$postBuild" + '' +) diff --git a/pkgs/build-support/checkpoint-build.nix b/pkgs/build-support/checkpoint-build.nix index 11e4f9e3ab03f3..6a28e7556d67be 100644 --- a/pkgs/build-support/checkpoint-build.nix +++ b/pkgs/build-support/checkpoint-build.nix @@ -1,6 +1,7 @@ -{ lib -, buildPackages -, config +{ + lib, + buildPackages, + config, }: let @@ -11,7 +12,8 @@ let rsync ; - /* Build a derivation based on the checkpoint output generated by + /* + Build a derivation based on the checkpoint output generated by * the `prepareCheckpointBuild` function. * * Usage: @@ -19,30 +21,35 @@ let * checkpointArtifacts = prepareCheckpointBuild drv; * in mkCheckpointBuild drv checkpointArtifacts */ - mkCheckpointBuild = drv: checkpointArtifacts: drv.overrideAttrs (old: { - # The actual checkpoint build phase. - # We compare the changed sources from a previous build with the current and create a patch. - # Afterwards we clean the build directory and copy the previous output files (including the sources). - # The source difference patch is then applied to get the latest changes again to allow short build times. - preBuild = (old.preBuild or "") + '' - set +e - sourceDifferencePatchFile=$(${mktemp}/bin/mktemp) - diff -ur ${checkpointArtifacts}/sources ./ > "$sourceDifferencePatchFile" - set -e - shopt -s dotglob - rm -r * - ${rsync}/bin/rsync \ - --checksum --times --atimes --chown=$USER:$USER --chmod=+w \ - -r ${checkpointArtifacts}/outputs/ . - patch -p 1 -i "$sourceDifferencePatchFile" - rm "$sourceDifferencePatchFile" - ''; - }); + mkCheckpointBuild = + drv: checkpointArtifacts: + drv.overrideAttrs (old: { + # The actual checkpoint build phase. + # We compare the changed sources from a previous build with the current and create a patch. + # Afterwards we clean the build directory and copy the previous output files (including the sources). + # The source difference patch is then applied to get the latest changes again to allow short build times. + preBuild = + (old.preBuild or "") + + '' + set +e + sourceDifferencePatchFile=$(${mktemp}/bin/mktemp) + diff -ur ${checkpointArtifacts}/sources ./ > "$sourceDifferencePatchFile" + set -e + shopt -s dotglob + rm -r * + ${rsync}/bin/rsync \ + --checksum --times --atimes --chown=$USER:$USER --chmod=+w \ + -r ${checkpointArtifacts}/outputs/ . + patch -p 1 -i "$sourceDifferencePatchFile" + rm "$sourceDifferencePatchFile" + ''; + }); in rec { inherit mkCheckpointBuild; - /* Prepare a derivation for local builds. + /* + Prepare a derivation for local builds. * * This function prepares checkpoint builds by storing * the build output and the sources for cross checking. @@ -60,38 +67,41 @@ rec { * - use `mkCheckpointBuild changedVBox checkpointArtifacts` * - enjoy shorter build times */ - prepareCheckpointBuild = drv: drv.overrideAttrs (old: { - outputs = [ "out" ]; - name = drv.name + "-checkpointArtifacts"; - # To determine differences between the state of the build directory - # from an earlier build and a later one we store the state of the build - # directory before build, but after patch phases. - # This way, the same derivation can be used multiple times and only changes are detected. - # Additionally, removed files are handled correctly in later builds. - preBuild = (old.preBuild or "") + '' - mkdir -p $out/sources - cp -r ./* $out/sources/ - ''; + prepareCheckpointBuild = + drv: + drv.overrideAttrs (old: { + outputs = [ "out" ]; + name = drv.name + "-checkpointArtifacts"; + # To determine differences between the state of the build directory + # from an earlier build and a later one we store the state of the build + # directory before build, but after patch phases. + # This way, the same derivation can be used multiple times and only changes are detected. + # Additionally, removed files are handled correctly in later builds. + preBuild = + (old.preBuild or "") + + '' + mkdir -p $out/sources + cp -r ./* $out/sources/ + ''; - # After the build, the build directory is copied again - # to get the output files. - # We copy the complete build folder, to take care of - # build tools that build in the source directory, instead of - # having a separate build directory such as the Linux kernel. - installPhase = '' - runHook preCheckpointInstall - mkdir -p $out/outputs - cp -r ./* $out/outputs/ - runHook postCheckpointInstall - unset postPhases - ''; + # After the build, the build directory is copied again + # to get the output files. + # We copy the complete build folder, to take care of + # build tools that build in the source directory, instead of + # having a separate build directory such as the Linux kernel. + installPhase = '' + runHook preCheckpointInstall + mkdir -p $out/outputs + cp -r ./* $out/outputs/ + runHook postCheckpointInstall + unset postPhases + ''; - dontFixup = true; - doInstallCheck = false; - doDist = false; - }); -} // lib.optionalAttrs config.allowAliases { - mkCheckpointedBuild = lib.warn - "`mkCheckpointedBuild` is deprecated, use `mkCheckpointBuild` instead!" - mkCheckpointBuild; + dontFixup = true; + doInstallCheck = false; + doDist = false; + }); +} +// lib.optionalAttrs config.allowAliases { + mkCheckpointedBuild = lib.warn "`mkCheckpointedBuild` is deprecated, use `mkCheckpointBuild` instead!" mkCheckpointBuild; } diff --git a/pkgs/build-support/closure-info.nix b/pkgs/build-support/closure-info.nix index cbeefc0e101c0c..4ccc2b7994151b 100644 --- a/pkgs/build-support/closure-info.nix +++ b/pkgs/build-support/closure-info.nix @@ -4,7 +4,11 @@ # "nix-store --load-db" and "nix-store --register-validity # --hash-given". -{ stdenvNoCC, coreutils, jq }: +{ + stdenvNoCC, + coreutils, + jq, +}: { rootPaths }: @@ -19,24 +23,26 @@ stdenvNoCC.mkDerivation { preferLocalBuild = true; - nativeBuildInputs = [ coreutils jq ]; + nativeBuildInputs = [ + coreutils + jq + ]; - empty = rootPaths == []; + empty = rootPaths == [ ]; - buildCommand = - '' - out=''${outputs[out]} + buildCommand = '' + out=''${outputs[out]} - mkdir $out + mkdir $out - if [[ -n "$empty" ]]; then - echo 0 > $out/total-nar-size - touch $out/registration $out/store-paths - else - jq -r ".closure | map(.narSize) | add" < "$NIX_ATTRS_JSON_FILE" > $out/total-nar-size - jq -r '.closure | map([.path, .narHash, .narSize, "", (.references | length)] + .references) | add | map("\(.)\n") | add' < "$NIX_ATTRS_JSON_FILE" | head -n -1 > $out/registration - jq -r '.closure[].path' < "$NIX_ATTRS_JSON_FILE" > $out/store-paths - fi + if [[ -n "$empty" ]]; then + echo 0 > $out/total-nar-size + touch $out/registration $out/store-paths + else + jq -r ".closure | map(.narSize) | add" < "$NIX_ATTRS_JSON_FILE" > $out/total-nar-size + jq -r '.closure | map([.path, .narHash, .narSize, "", (.references | length)] + .references) | add | map("\(.)\n") | add' < "$NIX_ATTRS_JSON_FILE" | head -n -1 > $out/registration + jq -r '.closure[].path' < "$NIX_ATTRS_JSON_FILE" > $out/store-paths + fi - ''; + ''; } diff --git a/pkgs/build-support/coq/default.nix b/pkgs/build-support/coq/default.nix index 2533875376fc19..01719ce243a1b3 100644 --- a/pkgs/build-support/coq/default.nix +++ b/pkgs/build-support/coq/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, coqPackages, coq, which, fetchzip, fetchurl }@args: +{ + lib, + stdenv, + coqPackages, + coq, + which, + fetchzip, + fetchurl, +}@args: let lib = import ./extra-lib.nix { @@ -28,7 +36,8 @@ let isGitLabDomain = d: match "^gitlab.*" d != null; in -{ pname, +{ + pname, version ? null, fetcher ? null, owner ? "coq-community", @@ -36,119 +45,209 @@ in repo ? pname, defaultVersion ? null, releaseRev ? (v: v), - displayVersion ? {}, - release ? {}, - buildInputs ? [], - nativeBuildInputs ? [], - extraBuildInputs ? [], - extraNativeBuildInputs ? [], - overrideBuildInputs ? [], - overrideNativeBuildInputs ? [], + displayVersion ? { }, + release ? { }, + buildInputs ? [ ], + nativeBuildInputs ? [ ], + extraBuildInputs ? [ ], + extraNativeBuildInputs ? [ ], + overrideBuildInputs ? [ ], + overrideNativeBuildInputs ? [ ], namePrefix ? [ "coq" ], enableParallelBuilding ? true, - extraInstallFlags ? [], + extraInstallFlags ? [ ], setCOQBIN ? true, mlPlugin ? false, useMelquiondRemake ? null, - dropAttrs ? [], - keepAttrs ? [], - dropDerivationAttrs ? [], + dropAttrs ? [ ], + keepAttrs ? [ ], + dropDerivationAttrs ? [ ], useDuneifVersion ? (x: false), useDune ? false, opam-name ? (concatStringsSep "-" (namePrefix ++ [ pname ])), ... }@args: let - args-to-remove = foldl (flip remove) ([ - "version" "fetcher" "repo" "owner" "domain" "releaseRev" - "displayVersion" "defaultVersion" "useMelquiondRemake" - "release" - "buildInputs" "nativeBuildInputs" - "extraBuildInputs" "extraNativeBuildInputs" - "overrideBuildInputs" "overrideNativeBuildInputs" - "namePrefix" - "meta" "useDuneifVersion" "useDune" "opam-name" - "extraInstallFlags" "setCOQBIN" "mlPlugin" - "dropAttrs" "dropDerivationAttrs" "keepAttrs" ] ++ dropAttrs) keepAttrs; - fetch = import ../coq/meta-fetch/default.nix - { inherit lib stdenv fetchzip fetchurl; } ({ - inherit release releaseRev; - location = { inherit domain owner repo; }; - } // optionalAttrs (args?fetcher) {inherit fetcher;}); + args-to-remove = foldl (flip remove) ( + [ + "version" + "fetcher" + "repo" + "owner" + "domain" + "releaseRev" + "displayVersion" + "defaultVersion" + "useMelquiondRemake" + "release" + "buildInputs" + "nativeBuildInputs" + "extraBuildInputs" + "extraNativeBuildInputs" + "overrideBuildInputs" + "overrideNativeBuildInputs" + "namePrefix" + "meta" + "useDuneifVersion" + "useDune" + "opam-name" + "extraInstallFlags" + "setCOQBIN" + "mlPlugin" + "dropAttrs" + "dropDerivationAttrs" + "keepAttrs" + ] + ++ dropAttrs + ) keepAttrs; + fetch = + import ../coq/meta-fetch/default.nix + { + inherit + lib + stdenv + fetchzip + fetchurl + ; + } + ( + { + inherit release releaseRev; + location = { inherit domain owner repo; }; + } + // optionalAttrs (args ? fetcher) { inherit fetcher; } + ); fetched = fetch (if version != null then version else defaultVersion); - display-pkg = n: sep: v: - let d = displayVersion.${n} or (if sep == "" then ".." else true); in - n + optionalString (v != "" && v != null) (switch d [ - { case = true; out = sep + v; } - { case = "."; out = sep + versions.major v; } - { case = ".."; out = sep + versions.majorMinor v; } - { case = "..."; out = sep + versions.majorMinorPatch v; } - { case = isFunction; out = optionalString (d v != "") (sep + d v); } - { case = isString; out = optionalString (d != "") (sep + d); } - ] "") + optionalString (v == null) "-broken"; + display-pkg = + n: sep: v: + let + d = displayVersion.${n} or (if sep == "" then ".." else true); + in + n + + optionalString (v != "" && v != null) ( + switch d [ + { + case = true; + out = sep + v; + } + { + case = "."; + out = sep + versions.major v; + } + { + case = ".."; + out = sep + versions.majorMinor v; + } + { + case = "..."; + out = sep + versions.majorMinorPatch v; + } + { + case = isFunction; + out = optionalString (d v != "") (sep + d v); + } + { + case = isString; + out = optionalString (d != "") (sep + d); + } + ] "" + ) + + optionalString (v == null) "-broken"; append-version = p: n: p + display-pkg n "" coqPackages.${n}.version + "-"; prefix-name = foldl append-version "" namePrefix; useDune = args.useDune or (useDuneifVersion fetched.version); - coqlib-flags = switch coq.coq-version [ - { case = v: versions.isLe "8.6" v && v != "dev" ; - out = [ "COQLIB=$(out)/lib/coq/${coq.coq-version}/" ]; } - ] [ "COQLIBINSTALL=$(out)/lib/coq/${coq.coq-version}/user-contrib" - "COQPLUGININSTALL=$(OCAMLFIND_DESTDIR)" ]; - docdir-flags = switch coq.coq-version [ - { case = v: versions.isLe "8.6" v && v != "dev"; - out = [ "DOCDIR=$(out)/share/coq/${coq.coq-version}/" ]; } - ] [ "COQDOCINSTALL=$(out)/share/coq/${coq.coq-version}/user-contrib" ]; + coqlib-flags = + switch coq.coq-version + [ + { + case = v: versions.isLe "8.6" v && v != "dev"; + out = [ "COQLIB=$(out)/lib/coq/${coq.coq-version}/" ]; + } + ] + [ + "COQLIBINSTALL=$(out)/lib/coq/${coq.coq-version}/user-contrib" + "COQPLUGININSTALL=$(OCAMLFIND_DESTDIR)" + ]; + docdir-flags = + switch coq.coq-version + [ + { + case = v: versions.isLe "8.6" v && v != "dev"; + out = [ "DOCDIR=$(out)/share/coq/${coq.coq-version}/" ]; + } + ] + [ "COQDOCINSTALL=$(out)/share/coq/${coq.coq-version}/user-contrib" ]; in -stdenv.mkDerivation (removeAttrs ({ +stdenv.mkDerivation ( + removeAttrs ( + { - name = prefix-name + (display-pkg pname "-" fetched.version); + name = prefix-name + (display-pkg pname "-" fetched.version); - inherit (fetched) version src; + inherit (fetched) version src; - nativeBuildInputs = args.overrideNativeBuildInputs - or ([ which ] - ++ optional useDune coq.ocamlPackages.dune_3 - ++ optionals (useDune || mlPlugin) [ coq.ocamlPackages.ocaml coq.ocamlPackages.findlib ] - ++ (args.nativeBuildInputs or []) ++ extraNativeBuildInputs); - buildInputs = args.overrideBuildInputs - or ([ coq ] ++ (args.buildInputs or []) ++ extraBuildInputs); - inherit enableParallelBuilding; + nativeBuildInputs = + args.overrideNativeBuildInputs or ( + [ which ] + ++ optional useDune coq.ocamlPackages.dune_3 + ++ optionals (useDune || mlPlugin) [ + coq.ocamlPackages.ocaml + coq.ocamlPackages.findlib + ] + ++ (args.nativeBuildInputs or [ ]) + ++ extraNativeBuildInputs + ); + buildInputs = + args.overrideBuildInputs or ([ coq ] ++ (args.buildInputs or [ ]) ++ extraBuildInputs); + inherit enableParallelBuilding; - meta = ({ platforms = coq.meta.platforms; } // - (switch domain [{ - case = pred.union isGitHubDomain isGitLabDomain; - out = { homepage = "https://${domain}/${owner}/${repo}"; }; - }] {}) // - optionalAttrs (fetched.broken or false) { coqFilter = true; broken = true; }) // - (args.meta or {}) ; + meta = + ( + { + platforms = coq.meta.platforms; + } + // (switch domain [ + { + case = pred.union isGitHubDomain isGitLabDomain; + out = { + homepage = "https://${domain}/${owner}/${repo}"; + }; + } + ] { }) + // optionalAttrs (fetched.broken or false) { + coqFilter = true; + broken = true; + } + ) + // (args.meta or { }); -} -// (optionalAttrs setCOQBIN { COQBIN = "${coq}/bin/"; }) -// (optionalAttrs (!args?installPhase && !args?useMelquiondRemake) { - installFlags = - coqlib-flags ++ docdir-flags ++ - extraInstallFlags; -}) -// (optionalAttrs useDune { - buildPhase = '' - runHook preBuild - dune build -p ${opam-name} ''${enableParallelBuilding:+-j $NIX_BUILD_CORES} - runHook postBuild - ''; - installPhase = '' - runHook preInstall - dune install --prefix=$out --libdir $OCAMLFIND_DESTDIR ${opam-name} - mkdir $out/lib/coq/ - mv $OCAMLFIND_DESTDIR/coq $out/lib/coq/${coq.coq-version} - runHook postInstall - ''; -}) -// (optionalAttrs (args?useMelquiondRemake) rec { - COQUSERCONTRIB = "$out/lib/coq/${coq.coq-version}/user-contrib"; - preConfigurePhases = [ "autoconf" ]; - configureFlags = [ "--libdir=${COQUSERCONTRIB}/${useMelquiondRemake.logpath or ""}" ]; - buildPhase = "./remake -j$NIX_BUILD_CORES"; - installPhase = "./remake install"; -}) -// (removeAttrs args args-to-remove)) dropDerivationAttrs) + } + // (optionalAttrs setCOQBIN { COQBIN = "${coq}/bin/"; }) + // (optionalAttrs (!args ? installPhase && !args ? useMelquiondRemake) { + installFlags = coqlib-flags ++ docdir-flags ++ extraInstallFlags; + }) + // (optionalAttrs useDune { + buildPhase = '' + runHook preBuild + dune build -p ${opam-name} ''${enableParallelBuilding:+-j $NIX_BUILD_CORES} + runHook postBuild + ''; + installPhase = '' + runHook preInstall + dune install --prefix=$out --libdir $OCAMLFIND_DESTDIR ${opam-name} + mkdir $out/lib/coq/ + mv $OCAMLFIND_DESTDIR/coq $out/lib/coq/${coq.coq-version} + runHook postInstall + ''; + }) + // (optionalAttrs (args ? useMelquiondRemake) rec { + COQUSERCONTRIB = "$out/lib/coq/${coq.coq-version}/user-contrib"; + preConfigurePhases = [ "autoconf" ]; + configureFlags = [ "--libdir=${COQUSERCONTRIB}/${useMelquiondRemake.logpath or ""}" ]; + buildPhase = "./remake -j$NIX_BUILD_CORES"; + installPhase = "./remake install"; + }) + // (removeAttrs args args-to-remove) + ) dropDerivationAttrs +) diff --git a/pkgs/build-support/coq/extra-lib.nix b/pkgs/build-support/coq/extra-lib.nix index 76537484e266ff..ec8c228a535370 100644 --- a/pkgs/build-support/coq/extra-lib.nix +++ b/pkgs/build-support/coq/extra-lib.nix @@ -24,70 +24,78 @@ recursiveUpdate lib (rec { versions = let truncate = n: v: concatStringsSep "." (take n (splitVersion v)); - opTruncate = op: v0: v: let n = length (splitVersion v0); in - op (truncate n v) (truncate n v0); - in rec { - - /* Get string of the first n parts of a version string. - - Example: - - truncate 2 "1.2.3-stuff" - => "1.2" - - - truncate 4 "1.2.3-stuff" - => "1.2.3.stuff" - */ - - inherit truncate; - - /* Get string of the first three parts (major, minor and patch) - of a version string. - - Example: - majorMinorPatch "1.2.3-stuff" - => "1.2.3" - */ - majorMinorPatch = truncate 3; - - /* Version comparison predicates, - - isGe v0 v <-> v is greater or equal than v0 [*] - - isLe v0 v <-> v is lesser or equal than v0 [*] - - isGt v0 v <-> v is strictly greater than v0 [*] - - isLt v0 v <-> v is strictly lesser than v0 [*] - - isEq v0 v <-> v is equal to v0 [*] - - range low high v <-> v is between low and high [**] - - [*] truncating v to the same number of digits as v0 - [**] truncating v to low for the lower bound and high for the upper bound - - Examples: - - isGe "8.10" "8.10.1" - => true - - isLe "8.10" "8.10.1" - => true - - isGt "8.10" "8.10.1" - => false - - isGt "8.10.0" "8.10.1" - => true - - isEq "8.10" "8.10.1" - => true - - range "8.10" "8.11" "8.11.1" - => true - - range "8.10" "8.11+" "8.11.0" - => false - - range "8.10" "8.11+" "8.11+beta1" - => false - - */ - isGe = opTruncate versionAtLeast; - isGt = opTruncate (flip versionOlder); - isLe = opTruncate (flip versionAtLeast); - isLt = opTruncate versionOlder; - isEq = opTruncate pred.equal; - range = low: high: pred.inter (versions.isGe low) (versions.isLe high); - }; - - /* Returns a list of list, splitting it using a predicate. + opTruncate = + op: v0: v: + let + n = length (splitVersion v0); + in + op (truncate n v) (truncate n v0); + in + rec { + + /* + Get string of the first n parts of a version string. + + Example: + - truncate 2 "1.2.3-stuff" + => "1.2" + + - truncate 4 "1.2.3-stuff" + => "1.2.3.stuff" + */ + + inherit truncate; + + /* + Get string of the first three parts (major, minor and patch) + of a version string. + + Example: + majorMinorPatch "1.2.3-stuff" + => "1.2.3" + */ + majorMinorPatch = truncate 3; + + /* + Version comparison predicates, + - isGe v0 v <-> v is greater or equal than v0 [*] + - isLe v0 v <-> v is lesser or equal than v0 [*] + - isGt v0 v <-> v is strictly greater than v0 [*] + - isLt v0 v <-> v is strictly lesser than v0 [*] + - isEq v0 v <-> v is equal to v0 [*] + - range low high v <-> v is between low and high [**] + + [*] truncating v to the same number of digits as v0 + [**] truncating v to low for the lower bound and high for the upper bound + + Examples: + - isGe "8.10" "8.10.1" + => true + - isLe "8.10" "8.10.1" + => true + - isGt "8.10" "8.10.1" + => false + - isGt "8.10.0" "8.10.1" + => true + - isEq "8.10" "8.10.1" + => true + - range "8.10" "8.11" "8.11.1" + => true + - range "8.10" "8.11+" "8.11.0" + => false + - range "8.10" "8.11+" "8.11+beta1" + => false + */ + isGe = opTruncate versionAtLeast; + isGt = opTruncate (flip versionOlder); + isLe = opTruncate (flip versionAtLeast); + isLt = opTruncate versionOlder; + isEq = opTruncate pred.equal; + range = low: high: pred.inter (versions.isGe low) (versions.isLe high); + }; + + /* + Returns a list of list, splitting it using a predicate. This is analoguous to builtins.split sep list, with a predicate as a separator and a list instead of a string. @@ -97,117 +105,157 @@ recursiveUpdate lib (rec { splitList (x: x == "x") [ "y" "x" "z" "t" ] => [ [ "y" ] "x" [ "z" "t" ] ] */ - splitList = pred: l: # put in file lists - let loop = (vv: v: l: if l == [] then vv ++ [v] - else let hd = head l; tl = tail l; in - if pred hd then loop (vv ++ [ v hd ]) [] tl else loop vv (v ++ [hd]) tl); - in loop [] [] l; + splitList = + pred: l: # put in file lists + let + loop = ( + vv: v: l: + if l == [ ] then + vv ++ [ v ] + else + let + hd = head l; + tl = tail l; + in + if pred hd then + loop ( + vv + ++ [ + v + hd + ] + ) [ ] tl + else + loop vv (v ++ [ hd ]) tl + ); + in + loop [ ] [ ] l; pred = { - /* Predicate intersection, union, and complement */ - inter = p: q: x: p x && q x; - union = p: q: x: p x || q x; - compl = p: x: ! p x; - true = p: true; + # Predicate intersection, union, and complement + inter = + p: q: x: + p x && q x; + union = + p: q: x: + p x || q x; + compl = p: x: !p x; + true = p: true; false = p: false; - /* predicate "being equal to y" */ - equal = y: x: x == y; + # predicate "being equal to y" + equal = y: x: x == y; }; - /* Emulate a "switch - case" construct, - instead of relying on `if then else if ...` */ - /* Usage: - ```nix - switch-if [ - if-clause-1 - .. - if-clause-k - ] default-out - ``` - where a if-clause has the form `{ cond = b; out = r; }` - the first branch such as `b` is true */ - - switch-if = c: d: (findFirst (getAttr "cond") {} c).out or d; - - /* Usage: - ```nix - switch x [ - simple-clause-1 - .. - simple-clause-k - ] default-out - ``` - where a simple-clause has the form `{ case = p; out = r; }` - the first branch such as `p x` is true - or - ```nix - switch [ x1 .. xn ] [ - complex-clause-1 - .. - complex-clause-k - ] default-out - ``` - where a complex-clause is either a simple-clause - or has the form { cases = [ p1 .. pn ]; out = r; } - in which case the first branch such as all `pi x` are true - - if the variables p are not functions, - they are converted to a equal p - if out is missing the default-out is taken */ - - switch = var: clauses: default: with pred; let - compare = f: if isFunction f then f else equal f; - combine = cl: var: - if cl?case then compare cl.case var - else all (equal true) (zipListsWith compare cl.cases var); in - switch-if (map (cl: { cond = combine cl var; inherit (cl) out; }) clauses) default; - - /* Override arguments to mkCoqDerivation for a Coq library. - - This function allows you to easily override arguments to mkCoqDerivation, - even when they are not exposed by the Coq library directly. - - Type: overrideCoqDerivation :: AttrSet -> CoqLibraryDerivation -> CoqLibraryDerivation - - Example: - - ```nix - coqPackages.lib.overrideCoqDerivation - { - defaultVersion = "9999"; - release."9999".hash = "sha256-fDoP11rtrIM7+OLdMisv2EF7n/IbGuwFxHiPtg3qCNM="; - } - coqPackages.QuickChick; - ``` - - This example overrides the `defaultVersion` and `release` arguments that - are passed to `mkCoqDerivation` in the QuickChick derivation. - - Note that there is a difference between using `.override` on a Coq - library vs this `overrideCoqDerivation` function. `.override` allows you - to modify arguments to the derivation itself, for instance by passing - different versions of dependencies: - - ```nix - coqPackages.QuickChick.override { ssreflect = my-cool-ssreflect; } - ``` - - whereas `overrideCoqDerivation` allows you to override arguments to the - call to `mkCoqDerivation` in the Coq library. - - Note that all Coq libraries in Nixpkgs have a `version` argument for - easily using a different version. So if all you want to do is use a - different version, and the derivation for the Coq library already has - support for the version you want, you likely only need to update the - `version` argument on the library derivation. This is done with - `.override`: - - ```nix - coqPackages.QuickChick.override { version = "1.4.0"; } - ``` + /* + Emulate a "switch - case" construct, + instead of relying on `if then else if ...` + */ + /* + Usage: + ```nix + switch-if [ + if-clause-1 + .. + if-clause-k + ] default-out + ``` + where a if-clause has the form `{ cond = b; out = r; }` + the first branch such as `b` is true + */ + + switch-if = c: d: (findFirst (getAttr "cond") { } c).out or d; + + /* + Usage: + ```nix + switch x [ + simple-clause-1 + .. + simple-clause-k + ] default-out + ``` + where a simple-clause has the form `{ case = p; out = r; }` + the first branch such as `p x` is true + or + ```nix + switch [ x1 .. xn ] [ + complex-clause-1 + .. + complex-clause-k + ] default-out + ``` + where a complex-clause is either a simple-clause + or has the form { cases = [ p1 .. pn ]; out = r; } + in which case the first branch such as all `pi x` are true + + if the variables p are not functions, + they are converted to a equal p + if out is missing the default-out is taken + */ + + switch = + var: clauses: default: + with pred; + let + compare = f: if isFunction f then f else equal f; + combine = + cl: var: + if cl ? case then compare cl.case var else all (equal true) (zipListsWith compare cl.cases var); + in + switch-if (map (cl: { + cond = combine cl var; + inherit (cl) out; + }) clauses) default; + + /* + Override arguments to mkCoqDerivation for a Coq library. + + This function allows you to easily override arguments to mkCoqDerivation, + even when they are not exposed by the Coq library directly. + + Type: overrideCoqDerivation :: AttrSet -> CoqLibraryDerivation -> CoqLibraryDerivation + + Example: + + ```nix + coqPackages.lib.overrideCoqDerivation + { + defaultVersion = "9999"; + release."9999".hash = "sha256-fDoP11rtrIM7+OLdMisv2EF7n/IbGuwFxHiPtg3qCNM="; + } + coqPackages.QuickChick; + ``` + + This example overrides the `defaultVersion` and `release` arguments that + are passed to `mkCoqDerivation` in the QuickChick derivation. + + Note that there is a difference between using `.override` on a Coq + library vs this `overrideCoqDerivation` function. `.override` allows you + to modify arguments to the derivation itself, for instance by passing + different versions of dependencies: + + ```nix + coqPackages.QuickChick.override { ssreflect = my-cool-ssreflect; } + ``` + + whereas `overrideCoqDerivation` allows you to override arguments to the + call to `mkCoqDerivation` in the Coq library. + + Note that all Coq libraries in Nixpkgs have a `version` argument for + easily using a different version. So if all you want to do is use a + different version, and the derivation for the Coq library already has + support for the version you want, you likely only need to update the + `version` argument on the library derivation. This is done with + `.override`: + + ```nix + coqPackages.QuickChick.override { version = "1.4.0"; } + ``` */ - overrideCoqDerivation = f: drv: (drv.override (args: { - mkCoqDerivation = drv_: (args.mkCoqDerivation drv_).override f; - })); + overrideCoqDerivation = + f: drv: + (drv.override (args: { + mkCoqDerivation = drv_: (args.mkCoqDerivation drv_).override f; + })); }) diff --git a/pkgs/build-support/coq/meta-fetch/default.nix b/pkgs/build-support/coq/meta-fetch/default.nix index ad0a69e29f2ce6..7491d0205c2515 100644 --- a/pkgs/build-support/coq/meta-fetch/default.nix +++ b/pkgs/build-support/coq/meta-fetch/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fetchzip }@args: +{ + lib, + stdenv, + fetchurl, + fetchzip, +}@args: let lib = import ../extra-lib.nix { @@ -28,75 +33,162 @@ let inherit (lib.strings) match split; - default-fetcher = {domain ? "github.com", owner ? "", repo, rev, name ? "source", sha256 ? null, artifact ? null, ...}@args: - let kind = switch-if [ - { cond = artifact != null; out = {ext = "tbz"; fmt = "tbz"; fetchfun = fetchurl; }; } - { cond = args?sha256 ; out = {ext = "zip"; fmt = "zip"; fetchfun = fetchzip; }; } - ] {ext = "tar.gz"; fmt = "tarball"; fetchfun = builtins.fetchTarball; }; in - with kind; let - pr = match "^#(.*)$" rev; - url = switch-if [ - { cond = pr == null && (match "^github.*" domain) != null && artifact != null; - out = "https://github.com/${owner}/${repo}/releases/download/${rev}/${artifact}"; } - { cond = pr == null && (match "^github.*" domain) != null; - out = "https://${domain}/${owner}/${repo}/archive/${rev}.${ext}"; } - { cond = pr != null && (match "^github.*" domain) != null; - out = "https://api.${domain}/repos/${owner}/${repo}/${fmt}/pull/${head pr}/head"; } - { cond = pr == null && (match "^gitlab.*" domain) != null; - out = "https://${domain}/${owner}/${repo}/-/archive/${rev}/${repo}-${rev}.${ext}"; } - { cond = (match "(www.)?mpi-sws.org" domain) != null; - out = "https://www.mpi-sws.org/~${owner}/${repo}/download/${repo}-${rev}.${ext}";} - ] (throw "meta-fetch: no fetcher found for domain ${domain} on ${rev}"); - fetch = x: fetchfun (if args?sha256 then (x // { inherit sha256; }) else x); - in fetch { inherit url ; }; + default-fetcher = + { + domain ? "github.com", + owner ? "", + repo, + rev, + name ? "source", + sha256 ? null, + artifact ? null, + ... + }@args: + let + kind = + switch-if + [ + { + cond = artifact != null; + out = { + ext = "tbz"; + fmt = "tbz"; + fetchfun = fetchurl; + }; + } + { + cond = args ? sha256; + out = { + ext = "zip"; + fmt = "zip"; + fetchfun = fetchzip; + }; + } + ] + { + ext = "tar.gz"; + fmt = "tarball"; + fetchfun = builtins.fetchTarball; + }; + in + with kind; + let + pr = match "^#(.*)$" rev; + url = switch-if [ + { + cond = pr == null && (match "^github.*" domain) != null && artifact != null; + out = "https://github.com/${owner}/${repo}/releases/download/${rev}/${artifact}"; + } + { + cond = pr == null && (match "^github.*" domain) != null; + out = "https://${domain}/${owner}/${repo}/archive/${rev}.${ext}"; + } + { + cond = pr != null && (match "^github.*" domain) != null; + out = "https://api.${domain}/repos/${owner}/${repo}/${fmt}/pull/${head pr}/head"; + } + { + cond = pr == null && (match "^gitlab.*" domain) != null; + out = "https://${domain}/${owner}/${repo}/-/archive/${rev}/${repo}-${rev}.${ext}"; + } + { + cond = (match "(www.)?mpi-sws.org" domain) != null; + out = "https://www.mpi-sws.org/~${owner}/${repo}/download/${repo}-${rev}.${ext}"; + } + ] (throw "meta-fetch: no fetcher found for domain ${domain} on ${rev}"); + fetch = x: fetchfun (if args ? sha256 then (x // { inherit sha256; }) else x); + in + fetch { inherit url; }; in { fetcher ? default-fetcher, location, - release ? {}, + release ? { }, releaseRev ? (v: v), - releaseArtifact ? (v: null) + releaseArtifact ? (v: null), }: let - isVersion = x: isString x && match "^/.*" x == null && release?${x}; - shortVersion = x: if (isString x && match "^/.*" x == null) - then findFirst (v: versions.majorMinor v == x) null - (sort versionAtLeast (attrNames release)) - else null; - isShortVersion = x: shortVersion x != null; - isPathString = x: isString x && match "^/.*" x != null && pathExists x; in + isVersion = x: isString x && match "^/.*" x == null && release ? ${x}; + shortVersion = + x: + if (isString x && match "^/.*" x == null) then + findFirst (v: versions.majorMinor v == x) null (sort versionAtLeast (attrNames release)) + else + null; + isShortVersion = x: shortVersion x != null; + isPathString = x: isString x && match "^/.*" x != null && pathExists x; +in arg: switch arg [ - { case = isNull; out = { version = "broken"; src = ""; broken = true; }; } - { case = isPathString; out = { version = "dev"; src = arg; }; } - { case = pred.union isVersion isShortVersion; - out = let - v = if isVersion arg then arg else shortVersion arg; - given-sha256 = release.${v}.sha256 or ""; - sha256 = if given-sha256 == "" then fakeSha256 else given-sha256; - rv = release.${v} // { inherit sha256; }; - in + { + case = isNull; + out = { + version = "broken"; + src = ""; + broken = true; + }; + } + { + case = isPathString; + out = { + version = "dev"; + src = arg; + }; + } + { + case = pred.union isVersion isShortVersion; + out = + let + v = if isVersion arg then arg else shortVersion arg; + given-sha256 = release.${v}.sha256 or ""; + sha256 = if given-sha256 == "" then fakeSha256 else given-sha256; + rv = release.${v} // { + inherit sha256; + }; + in { version = rv.version or v; - src = rv.src or fetcher (location // { rev = releaseRev v; artifact = releaseArtifact v; } // rv); + src = rv.src or fetcher ( + location + // { + rev = releaseRev v; + artifact = releaseArtifact v; + } + // rv + ); }; - } - { case = isString; - out = let - splitted = filter isString (split ":" arg); - rev = last splitted; + } + { + case = isString; + out = + let + splitted = filter isString (split ":" arg); + rev = last splitted; has-owner = length splitted > 1; - version = "dev"; in { - inherit version; - src = fetcher (location // { inherit rev; } // - (optionalAttrs has-owner { owner = head splitted; })); - }; } - { case = isAttrs; + version = "dev"; + in + { + inherit version; + src = fetcher ( + location // { inherit rev; } // (optionalAttrs has-owner { owner = head splitted; }) + ); + }; + } + { + case = isAttrs; out = { version = arg.version or "dev"; - src = (arg.fetcher or fetcher) (location // (arg.location or {})); }; } - { case = isPath; + src = (arg.fetcher or fetcher) (location // (arg.location or { })); + }; + } + { + case = isPath; out = { - version = "dev" ; - src = builtins.path {path = arg; name = location.name or "source";}; }; } + version = "dev"; + src = builtins.path { + path = arg; + name = location.name or "source"; + }; + }; + } ] (throw "not a valid source description") diff --git a/pkgs/build-support/dart/build-dart-application/default.nix b/pkgs/build-support/dart/build-dart-application/default.nix index 7b8057f50a2e87..444930985f8e02 100644 --- a/pkgs/build-support/dart/build-dart-application/default.nix +++ b/pkgs/build-support/dart/build-dart-application/default.nix @@ -1,59 +1,72 @@ -{ lib -, stdenv -, callPackage -, runCommand -, writeText -, pub2nix -, dartHooks -, makeWrapper -, dart -, nodejs -, darwin -, jq -, yq +{ + lib, + stdenv, + callPackage, + runCommand, + writeText, + pub2nix, + dartHooks, + makeWrapper, + dart, + nodejs, + darwin, + jq, + yq, }: -{ src -, sourceRoot ? "source" -, packageRoot ? (lib.removePrefix "/" (lib.removePrefix "source" sourceRoot)) -, gitHashes ? { } -, sdkSourceBuilders ? { } -, customSourceBuilders ? { } +{ + src, + sourceRoot ? "source", + packageRoot ? (lib.removePrefix "/" (lib.removePrefix "source" sourceRoot)), + gitHashes ? { }, + sdkSourceBuilders ? { }, + customSourceBuilders ? { }, -, sdkSetupScript ? "" -, extraPackageConfigSetup ? "" + sdkSetupScript ? "", + extraPackageConfigSetup ? "", # Output type to produce. Can be any kind supported by dart # https://dart.dev/tools/dart-compile#types-of-output # If using jit, you might want to pass some arguments to `dartJitFlags` -, dartOutputType ? "exe" -, dartCompileCommand ? "dart compile" -, dartCompileFlags ? [ ] + dartOutputType ? "exe", + dartCompileCommand ? "dart compile", + dartCompileFlags ? [ ], # These come at the end of the command, useful to pass flags to the jit run -, dartJitFlags ? [ ] + dartJitFlags ? [ ], # Attrset of entry point files to build and install. # Where key is the final binary path and value is the source file path # e.g. { "bin/foo" = "bin/main.dart"; } # Set to null to read executables from pubspec.yaml -, dartEntryPoints ? null + dartEntryPoints ? null, # Used when wrapping aot, jit, kernel, and js builds. # Set to null to disable wrapping. -, dartRuntimeCommand ? if dartOutputType == "aot-snapshot" then "${dart}/bin/dartaotruntime" - else if (dartOutputType == "jit-snapshot" || dartOutputType == "kernel") then "${dart}/bin/dart" - else if dartOutputType == "js" then "${nodejs}/bin/node" - else null - -, runtimeDependencies ? [ ] -, extraWrapProgramArgs ? "" - -, autoPubspecLock ? null -, pubspecLock ? if autoPubspecLock == null then - throw "The pubspecLock argument is required. If import-from-derivation is allowed (it isn't in Nixpkgs), you can set autoPubspecLock to the path to a pubspec.lock instead." - else - assert lib.assertMsg (builtins.pathExists autoPubspecLock) "The pubspec.lock file could not be found!"; - lib.importJSON (runCommand "${lib.getName args}-pubspec-lock-json" { nativeBuildInputs = [ yq ]; } ''yq . '${autoPubspecLock}' > "$out"'') -, ... + dartRuntimeCommand ? + if dartOutputType == "aot-snapshot" then + "${dart}/bin/dartaotruntime" + else if (dartOutputType == "jit-snapshot" || dartOutputType == "kernel") then + "${dart}/bin/dart" + else if dartOutputType == "js" then + "${nodejs}/bin/node" + else + null, + + runtimeDependencies ? [ ], + extraWrapProgramArgs ? "", + + autoPubspecLock ? null, + pubspecLock ? + if autoPubspecLock == null then + throw "The pubspecLock argument is required. If import-from-derivation is allowed (it isn't in Nixpkgs), you can set autoPubspecLock to the path to a pubspec.lock instead." + else + assert lib.assertMsg (builtins.pathExists autoPubspecLock) + "The pubspec.lock file could not be found!"; + lib.importJSON ( + runCommand "${lib.getName args}-pubspec-lock-json" { + nativeBuildInputs = [ yq ]; + } ''yq . '${autoPubspecLock}' > "$out"'' + ), + ... }@args: let @@ -61,22 +74,30 @@ let pubspecLockFile = builtins.toJSON pubspecLock; pubspecLockData = pub2nix.readPubspecLock { - inherit src packageRoot pubspecLock gitHashes customSourceBuilders; - sdkSourceBuilders = { + inherit + src + packageRoot + pubspecLock + gitHashes + customSourceBuilders + ; + sdkSourceBuilders = { # https://github.com/dart-lang/pub/blob/e1fbda73d1ac597474b82882ee0bf6ecea5df108/lib/src/sdk/dart.dart#L80 - "dart" = name: runCommand "dart-sdk-${name}" { passthru.packageRoot = "."; } '' - for path in '${dart}/pkg/${name}'; do - if [ -d "$path" ]; then - ln -s "$path" "$out" - break + "dart" = + name: + runCommand "dart-sdk-${name}" { passthru.packageRoot = "."; } '' + for path in '${dart}/pkg/${name}'; do + if [ -d "$path" ]; then + ln -s "$path" "$out" + break + fi + done + + if [ ! -e "$out" ]; then + echo 1>&2 'The Dart SDK does not contain the requested package: ${name}!' + exit 1 fi - done - - if [ ! -e "$out" ]; then - echo 1>&2 'The Dart SDK does not contain the requested package: ${name}!' - exit 1 - fi - ''; + ''; } // sdkSourceBuilders; }; packageConfig = generators.linkPackageConfig { @@ -98,53 +119,87 @@ let extraSetupCommands = extraPackageConfigSetup; }; - inherit (dartHooks.override { inherit dart; }) dartConfigHook dartBuildHook dartInstallHook dartFixupHook; - - baseDerivation = stdenv.mkDerivation (finalAttrs: (builtins.removeAttrs args [ "gitHashes" "sdkSourceBuilders" "pubspecLock" "customSourceBuilders" ]) // { - inherit pubspecLockFile packageConfig sdkSetupScript - dartCompileCommand dartOutputType dartRuntimeCommand dartCompileFlags - dartJitFlags; - - outputs = [ "out" "pubcache" ] ++ args.outputs or [ ]; - - dartEntryPoints = - if (dartEntryPoints != null) - then writeText "entrypoints.json" (builtins.toJSON dartEntryPoints) - else null; - - runtimeDependencies = map lib.getLib runtimeDependencies; - - nativeBuildInputs = (args.nativeBuildInputs or [ ]) ++ [ - dart - dartConfigHook - dartBuildHook - dartInstallHook - dartFixupHook - makeWrapper - jq - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.sigtool - ] ++ - # Ensure that we inherit the propagated build inputs from the dependencies. - builtins.attrValues pubspecLockData.dependencySources; - - preConfigure = args.preConfigure or "" + '' - ln -sf "$pubspecLockFilePath" pubspec.lock - ''; - - # When stripping, it seems some ELF information is lost and the dart VM cli - # runs instead of the expected program. Don't strip if it's an exe output. - dontStrip = args.dontStrip or (dartOutputType == "exe"); - - passAsFile = [ "pubspecLockFile" ]; - - passthru = { - pubspecLock = pubspecLockData; - } // (args.passthru or { }); - - meta = (args.meta or { }) // { platforms = args.meta.platforms or dart.meta.platforms; }; - }); + inherit (dartHooks.override { inherit dart; }) + dartConfigHook + dartBuildHook + dartInstallHook + dartFixupHook + ; + + baseDerivation = stdenv.mkDerivation ( + finalAttrs: + (builtins.removeAttrs args [ + "gitHashes" + "sdkSourceBuilders" + "pubspecLock" + "customSourceBuilders" + ]) + // { + inherit + pubspecLockFile + packageConfig + sdkSetupScript + dartCompileCommand + dartOutputType + dartRuntimeCommand + dartCompileFlags + dartJitFlags + ; + + outputs = [ + "out" + "pubcache" + ] ++ args.outputs or [ ]; + + dartEntryPoints = + if (dartEntryPoints != null) then + writeText "entrypoints.json" (builtins.toJSON dartEntryPoints) + else + null; + + runtimeDependencies = map lib.getLib runtimeDependencies; + + nativeBuildInputs = + (args.nativeBuildInputs or [ ]) + ++ [ + dart + dartConfigHook + dartBuildHook + dartInstallHook + dartFixupHook + makeWrapper + jq + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.sigtool + ] + ++ + # Ensure that we inherit the propagated build inputs from the dependencies. + builtins.attrValues pubspecLockData.dependencySources; + + preConfigure = + args.preConfigure or "" + + '' + ln -sf "$pubspecLockFilePath" pubspec.lock + ''; + + # When stripping, it seems some ELF information is lost and the dart VM cli + # runs instead of the expected program. Don't strip if it's an exe output. + dontStrip = args.dontStrip or (dartOutputType == "exe"); + + passAsFile = [ "pubspecLockFile" ]; + + passthru = { + pubspecLock = pubspecLockData; + } // (args.passthru or { }); + + meta = (args.meta or { }) // { + platforms = args.meta.platforms or dart.meta.platforms; + }; + } + ); in -assert !(builtins.isString dartOutputType && dartOutputType != "") -> -throw "dartOutputType must be a non-empty string"; +assert + !(builtins.isString dartOutputType && dartOutputType != "") + -> throw "dartOutputType must be a non-empty string"; baseDerivation diff --git a/pkgs/build-support/dart/build-dart-application/hooks/default.nix b/pkgs/build-support/dart/build-dart-application/hooks/default.nix index 253d3132ad02e4..bf4b88da5d2ebc 100644 --- a/pkgs/build-support/dart/build-dart-application/hooks/default.nix +++ b/pkgs/build-support/dart/build-dart-application/hooks/default.nix @@ -1,4 +1,10 @@ -{ lib, makeSetupHook, dart, yq, jq }: +{ + lib, + makeSetupHook, + dart, + yq, + jq, +}: { dartConfigHook = makeSetupHook { diff --git a/pkgs/build-support/dart/pub2nix/pubspec-lock.nix b/pkgs/build-support/dart/pub2nix/pubspec-lock.nix index e1ab4d7d235904..456236e18e5eff 100644 --- a/pkgs/build-support/dart/pub2nix/pubspec-lock.nix +++ b/pkgs/build-support/dart/pub2nix/pubspec-lock.nix @@ -1,28 +1,29 @@ -{ lib -, callPackage -, fetchurl -, fetchgit -, runCommand +{ + lib, + callPackage, + fetchurl, + fetchgit, + runCommand, }: { # The source directory of the package. - src + src, # The package subdirectory within src. # Useful if the package references sibling packages with relative paths. -, packageRoot ? "." + packageRoot ? ".", # The pubspec.lock file, in attribute set form. -, pubspecLock + pubspecLock, # Hashes for Git dependencies. # Pub does not record these itself, so they must be manually provided. -, gitHashes ? { } + gitHashes ? { }, # Functions to generate SDK package sources. # The function names should match the SDK names, and the package name is given as an argument. -, sdkSourceBuilders ? { } + sdkSourceBuilders ? { }, # Functions that create custom package source derivations. # @@ -30,7 +31,7 @@ # source, and source files are given in an attribute set argument. # # The passthru of the source derivation should be propagated. -, customSourceBuilders ? { } + customSourceBuilders ? { }, }: let @@ -43,14 +44,20 @@ let "transitive" = "transitive"; }; - dependencies = lib.foldlAttrs - (dependencies: name: details: dependencies // { ${dependencyTypes.${details.dependency}} = dependencies.${dependencyTypes.${details.dependency}} ++ [ name ]; }) - (lib.genAttrs (builtins.attrValues dependencyTypes) (dependencyType: [ ])) - pubspecLock.packages; + dependencies = lib.foldlAttrs ( + dependencies: name: details: + dependencies + // { + ${dependencyTypes.${details.dependency}} = + dependencies.${dependencyTypes.${details.dependency}} + ++ [ name ]; + } + ) (lib.genAttrs (builtins.attrValues dependencyTypes) (dependencyType: [ ])) pubspecLock.packages; # fetchTarball fails with "tarball contains an unexpected number of top-level files". This is a workaround. # https://discourse.nixos.org/t/fetchtarball-with-multiple-top-level-directories-fails/20556 - mkHostedDependencySource = name: details: + mkHostedDependencySource = + name: details: let archive = fetchurl { name = "pub-${name}-${details.version}.tar.gz"; @@ -63,48 +70,95 @@ let tar xf '${archive}' -C "$out" ''; - mkGitDependencySource = name: details: (fetchgit { - name = "pub-${name}-${details.version}"; - url = details.description.url; - rev = details.description.resolved-ref; - hash = gitHashes.${name} or (throw "A Git hash is required for ${name}! Set to an empty string to obtain it."); - }).overrideAttrs ({ passthru ? { }, ... }: { - passthru = passthru // { - packageRoot = details.description.path; - }; - }); - - mkPathDependencySource = name: details: - assert lib.assertMsg details.description.relative "Only relative paths are supported - ${name} has an absolue path!"; - (if lib.isDerivation src then src else (runCommand "pub-${name}-${details.version}" { } ''cp -r '${src}' "$out"'')).overrideAttrs ({ passthru ? { }, ... }: { - passthru = passthru // { - packageRoot = "${packageRoot}/${details.description.path}"; - }; - }); - - mkSdkDependencySource = name: details: - (sdkSourceBuilders.${details.description} or (throw "No SDK source builder has been given for ${details.description}!")) name; - - addDependencySourceUtils = dependencySource: details: dependencySource.overrideAttrs ({ passthru, ... }: { - passthru = passthru // { - inherit (details) version; - }; - }); - - sourceBuilders = callPackage ../../../development/compilers/dart/package-source-builders { } // customSourceBuilders; - - dependencySources = lib.filterAttrs (name: src: src != null) (builtins.mapAttrs - (name: details: + mkGitDependencySource = + name: details: + (fetchgit { + name = "pub-${name}-${details.version}"; + url = details.description.url; + rev = details.description.resolved-ref; + hash = + gitHashes.${name} + or (throw "A Git hash is required for ${name}! Set to an empty string to obtain it."); + }).overrideAttrs + ( + { + passthru ? { }, + ... + }: + { + passthru = passthru // { + packageRoot = details.description.path; + }; + } + ); + + mkPathDependencySource = + name: details: + assert lib.assertMsg details.description.relative + "Only relative paths are supported - ${name} has an absolue path!"; + ( + if lib.isDerivation src then + src + else + (runCommand "pub-${name}-${details.version}" { } ''cp -r '${src}' "$out"'') + ).overrideAttrs + ( + { + passthru ? { }, + ... + }: + { + passthru = passthru // { + packageRoot = "${packageRoot}/${details.description.path}"; + }; + } + ); + + mkSdkDependencySource = + name: details: + (sdkSourceBuilders.${details.description} + or (throw "No SDK source builder has been given for ${details.description}!") + ) + name; + + addDependencySourceUtils = + dependencySource: details: + dependencySource.overrideAttrs ( + { passthru, ... }: + { + passthru = passthru // { + inherit (details) version; + }; + } + ); + + sourceBuilders = + callPackage ../../../development/compilers/dart/package-source-builders { } // customSourceBuilders; + + dependencySources = lib.filterAttrs (name: src: src != null) ( + builtins.mapAttrs ( + name: details: (sourceBuilders.${name} or ({ src, ... }: src)) { inherit (details) version source; - src = ((addDependencySourceUtils (({ - "hosted" = mkHostedDependencySource; - "git" = mkGitDependencySource; - "path" = mkPathDependencySource; - "sdk" = mkSdkDependencySource; - }.${details.source} name) details)) details); - }) - pubspecLock.packages); + src = ( + (addDependencySourceUtils ( + ( + { + "hosted" = mkHostedDependencySource; + "git" = mkGitDependencySource; + "path" = mkPathDependencySource; + "sdk" = mkSdkDependencySource; + } + .${details.source} + name + ) + details + )) + details + ); + } + ) pubspecLock.packages + ); in { inherit @@ -115,5 +169,6 @@ in dependencyVersions # An attribute set of package names to their sources. - dependencySources; + dependencySources + ; } diff --git a/pkgs/build-support/dev-shell-tools/default.nix b/pkgs/build-support/dev-shell-tools/default.nix index 487be834727f81..264b6a31f07ad8 100644 --- a/pkgs/build-support/dev-shell-tools/default.nix +++ b/pkgs/build-support/dev-shell-tools/default.nix @@ -11,53 +11,63 @@ rec { # This function closely mirrors what this Nix code does: # https://github.com/NixOS/nix/blob/2.8.0/src/libexpr/primops.cc#L1102 # https://github.com/NixOS/nix/blob/2.8.0/src/libexpr/eval.cc#L1981-L2036 - valueToString = value: + valueToString = + value: # We can't just use `toString` on all derivation attributes because that # would not put path literals in the closure. So we explicitly copy # those into the store here - if typeOf value == "path" then "${value}" - else if typeOf value == "list" then toString (map valueToString value) - else toString value; - + if typeOf value == "path" then + "${value}" + else if typeOf value == "list" then + toString (map valueToString value) + else + toString value; # Docs: doc/build-helpers/dev-shell-tools.chapter.md # Tests: ./tests/default.nix # https://github.com/NixOS/nix/blob/2.8.0/src/libstore/build/local-derivation-goal.cc#L992-L1004 - unstructuredDerivationInputEnv = { drvAttrs }: + unstructuredDerivationInputEnv = + { drvAttrs }: # FIXME: this should be `normalAttrs // passAsFileAttrs` lib.mapAttrs' - (name: value: - let str = valueToString value; - in if lib.elem name (drvAttrs.passAsFile or []) - then + ( + name: value: + let + str = valueToString value; + in + if lib.elem name (drvAttrs.passAsFile or [ ]) then let nameHash = - if builtins?convertHash - then builtins.convertHash { - hash = "sha256:" + builtins.hashString "sha256" name; - toHashFormat = "nix32"; - } + if builtins ? convertHash then + builtins.convertHash { + hash = "sha256:" + builtins.hashString "sha256" name; + toHashFormat = "nix32"; + } else builtins.hashString "sha256" name; basename = ".attr-${nameHash}"; in - lib.nameValuePair "${name}Path" "${ - writeTextFile { - name = "shell-passAsFile-${name}"; - text = str; - destination = "/${basename}"; - } - }/${basename}" - else lib.nameValuePair name str + lib.nameValuePair "${name}Path" "${ + writeTextFile { + name = "shell-passAsFile-${name}"; + text = str; + destination = "/${basename}"; + } + }/${basename}" + else + lib.nameValuePair name str ) - (removeAttrs drvAttrs [ - # TODO: there may be more of these - "args" - ]); + ( + removeAttrs drvAttrs [ + # TODO: there may be more of these + "args" + ] + ); # Docs: doc/build-helpers/dev-shell-tools.chapter.md # Tests: ./tests/default.nix - derivationOutputEnv = { outputList, outputMap }: + derivationOutputEnv = + { outputList, outputMap }: # A mapping from output name to the nix store path where they should end up # https://github.com/NixOS/nix/blob/2.8.0/src/libexpr/primops.cc#L1253 lib.genAttrs outputList (output: builtins.unsafeDiscardStringContext outputMap.${output}.outPath); diff --git a/pkgs/build-support/dev-shell-tools/tests/default.nix b/pkgs/build-support/dev-shell-tools/tests/default.nix index 06ef7e393e324d..074aa8462a7c55 100644 --- a/pkgs/build-support/dev-shell-tools/tests/default.nix +++ b/pkgs/build-support/dev-shell-tools/tests/default.nix @@ -23,7 +23,9 @@ lib.recurseIntoAttrs { # nix-build -A tests.devShellTools.valueToString valueToString = - let inherit (devShellTools) valueToString; in + let + inherit (devShellTools) valueToString; + in stdenv.mkDerivation { name = "devShellTools-valueToString-built-tests"; @@ -34,9 +36,16 @@ lib.recurseIntoAttrs { boolTrue = true; boolFalse = false; foo = "foo"; - list = [ 1 2 3 ]; + list = [ + 1 + 2 + 3 + ]; pathDefaultNix = ./default.nix; - packages = [ hello emptyFile ]; + packages = [ + hello + emptyFile + ]; # TODO: nested lists buildCommand = '' @@ -47,8 +56,19 @@ lib.recurseIntoAttrs { [[ "$boolFalse" = ${escapeShellArg (valueToString false)} ]] [[ "$foo" = ${escapeShellArg (valueToString "foo")} ]] [[ "$hello" = ${escapeShellArg (valueToString hello)} ]] - [[ "$list" = ${escapeShellArg (valueToString [ 1 2 3 ])} ]] - [[ "$packages" = ${escapeShellArg (valueToString [ hello emptyFile ])} ]] + [[ "$list" = ${ + escapeShellArg (valueToString [ + 1 + 2 + 3 + ]) + } ]] + [[ "$packages" = ${ + escapeShellArg (valueToString [ + hello + emptyFile + ]) + } ]] [[ "$pathDefaultNix" = ${escapeShellArg (valueToString ./default.nix)} ]] [[ "$emptyFile" = ${escapeShellArg (valueToString emptyFile)} ]] ) >log 2>&1 || { cat log; exit 1; } @@ -65,13 +85,20 @@ lib.recurseIntoAttrs { boolTrue = true; boolFalse = false; foo = "foo"; - list = [ 1 2 3 ]; + list = [ + 1 + 2 + 3 + ]; pathDefaultNix = ./default.nix; stringWithDep = "Exe: ${hello}/bin/hello"; aPackageAttrSet = hello; anOutPath = hello.outPath; anAnAlternateOutput = zlib.dev; - args = [ "args must not be added to the environment" "Nix doesn't do it." ]; + args = [ + "args must not be added to the environment" + "Nix doesn't do it." + ]; passAsFile = [ "bar" ]; bar = '' @@ -81,85 +108,83 @@ lib.recurseIntoAttrs { }; result = unstructuredDerivationInputEnv { inherit drvAttrs; }; in - assert result // { barPath = ""; } == { - one = "1"; - boolTrue = "1"; - boolFalse = ""; - foo = "foo"; - list = "1 2 3"; - pathDefaultNix = "${./default.nix}"; - stringWithDep = "Exe: ${hello}/bin/hello"; - aPackageAttrSet = "${hello}"; - anOutPath = "${hello.outPath}"; - anAnAlternateOutput = "${zlib.dev}"; - - passAsFile = "bar"; - barPath = ""; - }; + assert + result // { barPath = ""; } == { + one = "1"; + boolTrue = "1"; + boolFalse = ""; + foo = "foo"; + list = "1 2 3"; + pathDefaultNix = "${./default.nix}"; + stringWithDep = "Exe: ${hello}/bin/hello"; + aPackageAttrSet = "${hello}"; + anOutPath = "${hello.outPath}"; + anAnAlternateOutput = "${zlib.dev}"; + + passAsFile = "bar"; + barPath = ""; + }; # Not runCommand, because it alters `passAsFile` - stdenv.mkDerivation ({ - name = "devShellTools-unstructuredDerivationInputEnv-built-tests"; - - exampleBarPathString = - assert isString result.barPath; - result.barPath; - - dontUnpack = true; - dontBuild = true; - dontFixup = true; - doCheck = true; - - installPhase = "touch $out"; - - checkPhase = '' - fail() { - echo "$@" >&2 - exit 1 - } - checkAttr() { - echo checking attribute $1... - if [[ "$2" != "$3" ]]; then - echo "expected: $3" - echo "actual: $2" + stdenv.mkDerivation ( + { + name = "devShellTools-unstructuredDerivationInputEnv-built-tests"; + + exampleBarPathString = + assert isString result.barPath; + result.barPath; + + dontUnpack = true; + dontBuild = true; + dontFixup = true; + doCheck = true; + + installPhase = "touch $out"; + + checkPhase = '' + fail() { + echo "$@" >&2 exit 1 - fi - } - ${ - concatLines - (mapAttrsToList - (name: value: - "checkAttr ${name} \"\$${name}\" ${escapeShellArg value}" - ) - (removeAttrs - result - [ - "args" - - # Nix puts it in workdir, which is not a concept for - # unstructuredDerivationInputEnv, so we have to put it in the - # store instead. This means the full path won't match. - "barPath" - ]) + } + checkAttr() { + echo checking attribute $1... + if [[ "$2" != "$3" ]]; then + echo "expected: $3" + echo "actual: $2" + exit 1 + fi + } + ${concatLines ( + mapAttrsToList (name: value: "checkAttr ${name} \"\$${name}\" ${escapeShellArg value}") ( + removeAttrs result [ + "args" + + # Nix puts it in workdir, which is not a concept for + # unstructuredDerivationInputEnv, so we have to put it in the + # store instead. This means the full path won't match. + "barPath" + ] ) - } - ( - set -x + )} + ( + set -x - diff $exampleBarPathString $barPath + diff $exampleBarPathString $barPath - ${lib.optionalString (builtins?convertHash) '' - [[ "$(basename $exampleBarPathString)" = "$(basename $barPath)" ]] - ''} - ) + ${lib.optionalString (builtins ? convertHash) '' + [[ "$(basename $exampleBarPathString)" = "$(basename $barPath)" ]] + ''} + ) - ''${args:+fail "args should not be set by Nix. We don't expect it to and unstructuredDerivationInputEnv removes it."} - if [[ "''${builder:-x}" == x ]]; then - fail "builder should be set by Nix. We don't remove it in unstructuredDerivationInputEnv." - fi - ''; - } // removeAttrs drvAttrs [ - # This would break the derivation. Instead, we have a check in the derivation to make sure Nix doesn't set it. - "args" - ]); + ''${args:+fail "args should not be set by Nix. We don't expect it to and unstructuredDerivationInputEnv removes it."} + if [[ "''${builder:-x}" == x ]]; then + fail "builder should be set by Nix. We don't remove it in unstructuredDerivationInputEnv." + fi + ''; + } + // removeAttrs drvAttrs [ + # This would break the derivation. Instead, we have a check in the derivation to make sure Nix doesn't set it. + "args" + ] + ); } diff --git a/pkgs/build-support/dhall/directory-to-nix.nix b/pkgs/build-support/dhall/directory-to-nix.nix index d751e19df3fc35..ba02ddfd820ded 100644 --- a/pkgs/build-support/dhall/directory-to-nix.nix +++ b/pkgs/build-support/dhall/directory-to-nix.nix @@ -1,4 +1,4 @@ -{ dhallPackages, dhallPackageToNix}: +{ dhallPackages, dhallPackageToNix }: # `dhallDirectoryToNix is a utility function to take a directory of Dhall files # and read them in as a Nix expression. @@ -11,9 +11,10 @@ # `dhallDirectoryToNix` utility. It is not possible to use # `dhallDirectoryToNix` in Nixpkgs, since the Nixpkgs Hydra doesn't allow IFD. -{ src -, # The file to import, relative to the src root directory - file ? "package.dhall" +{ + src, + # The file to import, relative to the src root directory + file ? "package.dhall", }@args: let @@ -22,4 +23,4 @@ let builtPkg = dhallPackages.callPackage generatedPkg { }; in - dhallPackageToNix builtPkg +dhallPackageToNix builtPkg diff --git a/pkgs/build-support/dhall/package-to-nix.nix b/pkgs/build-support/dhall/package-to-nix.nix index 301501ad49df3d..1c47c9cf0ec661 100644 --- a/pkgs/build-support/dhall/package-to-nix.nix +++ b/pkgs/build-support/dhall/package-to-nix.nix @@ -1,4 +1,3 @@ - # `dhallPackageToNix` is a utility function to take a Nixpkgs Dhall package # (created with a function like `dhallPackages.buildDhallDirectoryPackage`) # and read it in as a Nix expression. @@ -14,23 +13,23 @@ { stdenv, dhall-nix }: dhallPackage: - let - drv = stdenv.mkDerivation { - name = "dhall-compiled-package.nix"; +let + drv = stdenv.mkDerivation { + name = "dhall-compiled-package.nix"; - buildCommand = '' - # Dhall requires that the cache is writable, even if it is never written to. - # We copy the cache from the input package to the current directory and - # set the cache as writable. - cp -r "${dhallPackage}/.cache" ./ - export XDG_CACHE_HOME=$PWD/.cache - chmod -R +w ./.cache + buildCommand = '' + # Dhall requires that the cache is writable, even if it is never written to. + # We copy the cache from the input package to the current directory and + # set the cache as writable. + cp -r "${dhallPackage}/.cache" ./ + export XDG_CACHE_HOME=$PWD/.cache + chmod -R +w ./.cache - dhall-to-nix <<< "${dhallPackage}/binary.dhall" > $out - ''; + dhall-to-nix <<< "${dhallPackage}/binary.dhall" > $out + ''; - nativeBuildInputs = [ dhall-nix ]; - }; + nativeBuildInputs = [ dhall-nix ]; + }; - in - import drv +in +import drv diff --git a/pkgs/build-support/dhall/to-nix.nix b/pkgs/build-support/dhall/to-nix.nix index 96cc16e16f3695..e7e9c86b82dd29 100644 --- a/pkgs/build-support/dhall/to-nix.nix +++ b/pkgs/build-support/dhall/to-nix.nix @@ -1,24 +1,30 @@ -/* `dhallToNix` is a utility function to convert expressions in the Dhall - configuration language to their corresponding Nix expressions. - - Example: - dhallToNix "{ foo = 1, bar = True }" - => { foo = 1; bar = true; } - dhallToNix "λ(x : Bool) → x == False" - => x : x == false - dhallToNix "λ(x : Bool) → x == False" false - => true - - See https://hackage.haskell.org/package/dhall-nix/docs/Dhall-Nix.html for - a longer tutorial - - Note that this uses "import from derivation", meaning that Nix will perform - a build during the evaluation phase if you use this `dhallToNix` utility +/* + `dhallToNix` is a utility function to convert expressions in the Dhall + configuration language to their corresponding Nix expressions. + + Example: + dhallToNix "{ foo = 1, bar = True }" + => { foo = 1; bar = true; } + dhallToNix "λ(x : Bool) → x == False" + => x : x == false + dhallToNix "λ(x : Bool) → x == False" false + => true + + See https://hackage.haskell.org/package/dhall-nix/docs/Dhall-Nix.html for + a longer tutorial + + Note that this uses "import from derivation", meaning that Nix will perform + a build during the evaluation phase if you use this `dhallToNix` utility */ -{ stdenv, dhall-nix, writeText }: +{ + stdenv, + dhall-nix, + writeText, +}: let - dhallToNix = code : + dhallToNix = + code: let file = writeText "dhall-expression" code; @@ -33,6 +39,6 @@ let }; in - import drv; + import drv; in - dhallToNix +dhallToNix diff --git a/pkgs/build-support/docker/examples.nix b/pkgs/build-support/docker/examples.nix index f6e09203b455bc..683c8255ca0569 100644 --- a/pkgs/build-support/docker/examples.nix +++ b/pkgs/build-support/docker/examples.nix @@ -7,61 +7,77 @@ # $ nix-build '' -A dockerTools.examples.redis # $ docker load < result -{ pkgs, buildImage, buildLayeredImage, fakeNss, pullImage, shadowSetup, buildImageWithNixDb, pkgsCross, streamNixShellImage }: +{ + pkgs, + buildImage, + buildLayeredImage, + fakeNss, + pullImage, + shadowSetup, + buildImageWithNixDb, + pkgsCross, + streamNixShellImage, +}: let nixosLib = import ../../../nixos/lib { # Experimental features need testing too, but there's no point in warning # about it, so we enable the feature flag. - featureFlags.minimalModules = {}; + featureFlags.minimalModules = { }; }; evalMinimalConfig = module: nixosLib.evalModules { modules = [ module ]; }; - nginxArguments = let - nginxPort = "80"; - nginxConf = pkgs.writeText "nginx.conf" '' - user nobody nobody; - daemon off; - error_log /dev/stdout info; - pid /dev/null; - events {} - http { - access_log /dev/stdout; - server { - listen ${nginxPort}; - index index.html; - location / { - root ${nginxWebRoot}; + nginxArguments = + let + nginxPort = "80"; + nginxConf = pkgs.writeText "nginx.conf" '' + user nobody nobody; + daemon off; + error_log /dev/stdout info; + pid /dev/null; + events {} + http { + access_log /dev/stdout; + server { + listen ${nginxPort}; + index index.html; + location / { + root ${nginxWebRoot}; + } } } - } - ''; - nginxWebRoot = pkgs.writeTextDir "index.html" '' -

Hello from NGINX

- ''; - in - { name = "nginx-container"; - tag = "latest"; - contents = [ - fakeNss - pkgs.nginx - ]; + ''; + nginxWebRoot = pkgs.writeTextDir "index.html" '' +

Hello from NGINX

+ ''; + in + { + name = "nginx-container"; + tag = "latest"; + contents = [ + fakeNss + pkgs.nginx + ]; - extraCommands = '' - mkdir -p tmp/nginx_client_body + extraCommands = '' + mkdir -p tmp/nginx_client_body - # nginx still tries to read this directory even if error_log - # directive is specifying another file :/ - mkdir -p var/log/nginx - ''; + # nginx still tries to read this directory even if error_log + # directive is specifying another file :/ + mkdir -p var/log/nginx + ''; - config = { - Cmd = [ "nginx" "-c" nginxConf ]; - ExposedPorts = { - "${nginxPort}/tcp" = {}; + config = { + Cmd = [ + "nginx" + "-c" + nginxConf + ]; + ExposedPorts = { + "${nginxPort}/tcp" = { }; + }; }; }; - }; in @@ -100,7 +116,7 @@ rec { Cmd = [ "/bin/redis-server" ]; WorkingDir = "/data"; Volumes = { - "/data" = {}; + "/data" = { }; }; }; }; @@ -220,7 +236,11 @@ rec { tag = "latest"; extraCommands = ''echo "(extraCommand)" > extraCommands''; config.Cmd = [ "${pkgs.hello}/bin/hello" ]; - contents = [ pkgs.hello pkgs.bash pkgs.coreutils ]; + contents = [ + pkgs.hello + pkgs.bash + pkgs.coreutils + ]; }; # 11. Create an image on top of a layered image @@ -236,7 +256,9 @@ rec { Env = [ "PATH=${pkgs.coreutils}/bin/" ]; WorkingDir = "/example-output"; Cmd = [ - "${pkgs.bash}/bin/bash" "-c" "echo hello > foo; cat foo" + "${pkgs.bash}/bin/bash" + "-c" + "echo hello > foo; cat foo" ]; }; }; @@ -254,7 +276,9 @@ rec { Env = [ "PATH=${pkgs.coreutils}/bin/" ]; WorkingDir = "/example-output"; Cmd = [ - "${pkgs.bash}/bin/bash" "-c" "echo hello > foo; cat foo" + "${pkgs.bash}/bin/bash" + "-c" + "echo hello > foo; cat foo" ]; }; }; @@ -274,41 +298,43 @@ rec { # - the layer of parent are below # - the order of parent layer is preserved at image build time # (this is why there are 3 images) - layersOrder = let - l1 = pkgs.dockerTools.buildImage { - name = "l1"; - tag = "latest"; - extraCommands = '' - mkdir -p tmp - echo layer1 > tmp/layer1 - echo layer1 > tmp/layer2 - echo layer1 > tmp/layer3 - ''; - }; - l2 = pkgs.dockerTools.buildImage { - name = "l2"; - fromImage = l1; + layersOrder = + let + l1 = pkgs.dockerTools.buildImage { + name = "l1"; + tag = "latest"; + extraCommands = '' + mkdir -p tmp + echo layer1 > tmp/layer1 + echo layer1 > tmp/layer2 + echo layer1 > tmp/layer3 + ''; + }; + l2 = pkgs.dockerTools.buildImage { + name = "l2"; + fromImage = l1; + tag = "latest"; + extraCommands = '' + mkdir -p tmp + echo layer2 > tmp/layer2 + echo layer2 > tmp/layer3 + ''; + }; + in + pkgs.dockerTools.buildImage { + name = "l3"; + fromImage = l2; tag = "latest"; + copyToRoot = pkgs.buildEnv { + name = "image-root"; + pathsToLink = [ "/bin" ]; + paths = [ pkgs.coreutils ]; + }; extraCommands = '' mkdir -p tmp - echo layer2 > tmp/layer2 - echo layer2 > tmp/layer3 + echo layer3 > tmp/layer3 ''; }; - in pkgs.dockerTools.buildImage { - name = "l3"; - fromImage = l2; - tag = "latest"; - copyToRoot = pkgs.buildEnv { - name = "image-root"; - pathsToLink = [ "/bin" ]; - paths = [ pkgs.coreutils ]; - }; - extraCommands = '' - mkdir -p tmp - echo layer3 > tmp/layer3 - ''; - }; # 15. Environment variable inheritance. # Child image should inherit parents environment variables, @@ -366,7 +392,10 @@ rec { name = "two-layered-image"; tag = "latest"; config.Cmd = [ "${pkgs.hello}/bin/hello" ]; - contents = [ pkgs.bash pkgs.hello ]; + contents = [ + pkgs.bash + pkgs.hello + ]; maxLayers = 2; }; @@ -376,7 +405,8 @@ rec { name = "bulk-layer"; tag = "latest"; contents = with pkgs; [ - coreutils hello + coreutils + hello ]; maxLayers = 2; }; @@ -388,7 +418,8 @@ rec { tag = "latest"; fromImage = two-layered-image; contents = with pkgs; [ - coreutils hello + coreutils + hello ]; maxLayers = 4; }; @@ -460,29 +491,31 @@ rec { # 23. Ensure that layers are unpacked in the correct order before the # runAsRoot script is executed. layersUnpackOrder = - let - layerOnTopOf = parent: layerName: - pkgs.dockerTools.buildImage { - name = "layers-unpack-order-${layerName}"; - tag = "latest"; - fromImage = parent; - copyToRoot = pkgs.buildEnv { - name = "image-root"; - pathsToLink = [ "/bin" ]; - paths = [ pkgs.coreutils ]; + let + layerOnTopOf = + parent: layerName: + pkgs.dockerTools.buildImage { + name = "layers-unpack-order-${layerName}"; + tag = "latest"; + fromImage = parent; + copyToRoot = pkgs.buildEnv { + name = "image-root"; + pathsToLink = [ "/bin" ]; + paths = [ pkgs.coreutils ]; + }; + runAsRoot = '' + #!${pkgs.runtimeShell} + echo -n "${layerName}" >> /layer-order + ''; }; - runAsRoot = '' - #!${pkgs.runtimeShell} - echo -n "${layerName}" >> /layer-order - ''; - }; - # When executing the runAsRoot script when building layer C, if layer B is - # not unpacked on top of layer A, the contents of /layer-order will not be - # "ABC". - layerA = layerOnTopOf null "a"; - layerB = layerOnTopOf layerA "b"; - layerC = layerOnTopOf layerB "c"; - in layerC; + # When executing the runAsRoot script when building layer C, if layer B is + # not unpacked on top of layer A, the contents of /layer-order will not be + # "ABC". + layerA = layerOnTopOf null "a"; + layerB = layerOnTopOf layerA "b"; + layerC = layerOnTopOf layerB "c"; + in + layerC; bashUncompressed = pkgs.dockerTools.buildImage { name = "bash-uncompressed"; @@ -537,67 +570,84 @@ rec { # buildLayeredImage with non-root user bashLayeredWithUser = - let - nonRootShadowSetup = { user, uid, gid ? uid }: with pkgs; [ - ( - writeTextDir "etc/shadow" '' - root:!x::::::: - ${user}:!::::::: - '' - ) - ( - writeTextDir "etc/passwd" '' - root:x:0:0::/root:${runtimeShell} - ${user}:x:${toString uid}:${toString gid}::/home/${user}: - '' - ) - ( - writeTextDir "etc/group" '' - root:x:0: - ${user}:x:${toString gid}: - '' - ) - ( - writeTextDir "etc/gshadow" '' - root:x:: - ${user}:x:: - '' - ) - ]; - in + let + nonRootShadowSetup = + { + user, + uid, + gid ? uid, + }: + with pkgs; + [ + (writeTextDir "etc/shadow" '' + root:!x::::::: + ${user}:!::::::: + '') + (writeTextDir "etc/passwd" '' + root:x:0:0::/root:${runtimeShell} + ${user}:x:${toString uid}:${toString gid}::/home/${user}: + '') + (writeTextDir "etc/group" '' + root:x:0: + ${user}:x:${toString gid}: + '') + (writeTextDir "etc/gshadow" '' + root:x:: + ${user}:x:: + '') + ]; + in pkgs.dockerTools.buildLayeredImage { name = "bash-layered-with-user"; tag = "latest"; - contents = [ pkgs.bash pkgs.coreutils ] ++ nonRootShadowSetup { uid = 999; user = "somebody"; }; + contents = + [ + pkgs.bash + pkgs.coreutils + ] + ++ nonRootShadowSetup { + uid = 999; + user = "somebody"; + }; }; # basic example, with cross compilation - cross = let - # Cross compile for x86_64 if on aarch64 - crossPkgs = - if pkgs.stdenv.hostPlatform.system == "aarch64-linux" then pkgsCross.gnu64 - else pkgsCross.aarch64-multiplatform; - in crossPkgs.dockerTools.buildImage { - name = "hello-cross"; - tag = "latest"; - copyToRoot = pkgs.buildEnv { - name = "image-root"; - pathsToLink = [ "/bin" ]; - paths = [ crossPkgs.hello ]; + cross = + let + # Cross compile for x86_64 if on aarch64 + crossPkgs = + if pkgs.stdenv.hostPlatform.system == "aarch64-linux" then + pkgsCross.gnu64 + else + pkgsCross.aarch64-multiplatform; + in + crossPkgs.dockerTools.buildImage { + name = "hello-cross"; + tag = "latest"; + copyToRoot = pkgs.buildEnv { + name = "image-root"; + pathsToLink = [ "/bin" ]; + paths = [ crossPkgs.hello ]; + }; }; - }; # layered image where a store path is itself a symlink layeredStoreSymlink = - let - target = pkgs.writeTextDir "dir/target" "Content doesn't matter."; - symlink = pkgs.runCommand "symlink" {} "ln -s ${target} $out"; - in + let + target = pkgs.writeTextDir "dir/target" "Content doesn't matter."; + symlink = pkgs.runCommand "symlink" { } "ln -s ${target} $out"; + in pkgs.dockerTools.buildLayeredImage { name = "layeredstoresymlink"; tag = "latest"; - contents = [ pkgs.bash symlink ]; - } // { passthru = { inherit symlink; }; }; + contents = [ + pkgs.bash + symlink + ]; + } + // { + passthru = { inherit symlink; }; + }; # image with registry/ prefix prefixedImage = pkgs.dockerTools.buildImage { @@ -623,15 +673,21 @@ rec { fakeRootCommands = '' mkdir -p ./home/alice chown 1000 ./home/alice - ln -s ${pkgs.hello.overrideAttrs (finalAttrs: prevAttrs: { - # A unique `hello` to make sure that it isn't included via another mechanism by accident. - configureFlags = prevAttrs.configureFlags or [] ++ [ " --program-prefix=layeredImageWithFakeRootCommands-" ]; - doCheck = false; - versionCheckProgram = "${builtins.placeholder "out"}/bin/${finalAttrs.meta.mainProgram}"; - meta = prevAttrs.meta // { - mainProgram = "layeredImageWithFakeRootCommands-hello"; - }; - })} ./hello + ln -s ${ + pkgs.hello.overrideAttrs ( + finalAttrs: prevAttrs: { + # A unique `hello` to make sure that it isn't included via another mechanism by accident. + configureFlags = prevAttrs.configureFlags or [ ] ++ [ + " --program-prefix=layeredImageWithFakeRootCommands-" + ]; + doCheck = false; + versionCheckProgram = "${builtins.placeholder "out"}/bin/${finalAttrs.meta.mainProgram}"; + meta = prevAttrs.meta // { + mainProgram = "layeredImageWithFakeRootCommands-hello"; + }; + } + ) + } ./hello ''; }; @@ -702,21 +758,27 @@ rec { etc = let inherit (pkgs) lib; - nixosCore = (evalMinimalConfig ({ config, ... }: { - imports = [ - pkgs.pkgsModule - ../../../nixos/modules/system/etc/etc.nix - ]; - environment.etc."some-config-file" = { - text = '' - 127.0.0.1 localhost - ::1 localhost - ''; - # For executables: - # mode = "0755"; - }; - })); - in pkgs.dockerTools.streamLayeredImage { + nixosCore = ( + evalMinimalConfig ( + { config, ... }: + { + imports = [ + pkgs.pkgsModule + ../../../nixos/modules/system/etc/etc.nix + ]; + environment.etc."some-config-file" = { + text = '' + 127.0.0.1 localhost + ::1 localhost + ''; + # For executables: + # mode = "0755"; + }; + } + ) + ); + in + pkgs.dockerTools.streamLayeredImage { name = "etc"; tag = "latest"; enableFakechroot = true; @@ -751,13 +813,19 @@ rec { name = "build-image-with-path"; tag = "latest"; # Not recommended. Use `buildEnv` between copy and packages to avoid file duplication. - copyToRoot = [ pkgs.bashInteractive ./test-dummy ]; + copyToRoot = [ + pkgs.bashInteractive + ./test-dummy + ]; }; layered-image-with-path = pkgs.dockerTools.streamLayeredImage { name = "layered-image-with-path"; tag = "latest"; - contents = [ pkgs.bashInteractive ./test-dummy ]; + contents = [ + pkgs.bashInteractive + ./test-dummy + ]; }; build-image-with-architecture = buildImage { @@ -765,14 +833,20 @@ rec { tag = "latest"; architecture = "arm64"; # Not recommended. Use `buildEnv` between copy and packages to avoid file duplication. - copyToRoot = [ pkgs.bashInteractive ./test-dummy ]; + copyToRoot = [ + pkgs.bashInteractive + ./test-dummy + ]; }; layered-image-with-architecture = pkgs.dockerTools.streamLayeredImage { name = "layered-image-with-architecture"; tag = "latest"; architecture = "arm64"; - contents = [ pkgs.bashInteractive ./test-dummy ]; + contents = [ + pkgs.bashInteractive + ./test-dummy + ]; }; # ensure that caCertificates builds @@ -837,7 +911,7 @@ rec { nix-shell-run = streamNixShellImage { name = "nix-shell-run"; tag = "latest"; - drv = pkgs.mkShell {}; + drv = pkgs.mkShell { }; run = '' case "$-" in *i*) echo This shell is interactive ;; @@ -849,7 +923,7 @@ rec { nix-shell-command = streamNixShellImage { name = "nix-shell-command"; tag = "latest"; - drv = pkgs.mkShell {}; + drv = pkgs.mkShell { }; command = '' case "$-" in *i*) echo This shell is interactive ;; @@ -861,7 +935,7 @@ rec { nix-shell-writable-home = streamNixShellImage { name = "nix-shell-writable-home"; tag = "latest"; - drv = pkgs.mkShell {}; + drv = pkgs.mkShell { }; run = '' if [[ "$HOME" != "$(eval "echo ~$(whoami)")" ]]; then echo "\$HOME ($HOME) is not the same as ~\$(whoami) ($(eval "echo ~$(whoami)"))" @@ -879,7 +953,7 @@ rec { nix-shell-nonexistent-home = streamNixShellImage { name = "nix-shell-nonexistent-home"; tag = "latest"; - drv = pkgs.mkShell {}; + drv = pkgs.mkShell { }; homeDirectory = "/homeless-shelter"; run = '' if [[ "$HOME" != "$(eval "echo ~$(whoami)")" ]]; then @@ -905,10 +979,13 @@ rec { ''; }; - nix-layered = pkgs.dockerTools.streamLayeredImage { + nix-layered = pkgs.dockerTools.streamLayeredImage { name = "nix-layered"; tag = "latest"; - contents = [ pkgs.nix pkgs.bash ]; + contents = [ + pkgs.nix + pkgs.bash + ]; includeNixDB = true; config = { Env = [ diff --git a/pkgs/build-support/docker/tarsum.nix b/pkgs/build-support/docker/tarsum.nix index f62a8d49389aa0..f97c7a2e113b77 100644 --- a/pkgs/build-support/docker/tarsum.nix +++ b/pkgs/build-support/docker/tarsum.nix @@ -1,4 +1,9 @@ -{ stdenv, go, docker, nixosTests }: +{ + stdenv, + go, + docker, + nixosTests, +}: stdenv.mkDerivation { name = "tarsum"; diff --git a/pkgs/build-support/dotnet/build-dotnet-global-tool/default.nix b/pkgs/build-support/dotnet/build-dotnet-global-tool/default.nix index f6a832386b9fe7..206aea51f26345 100644 --- a/pkgs/build-support/dotnet/build-dotnet-global-tool/default.nix +++ b/pkgs/build-support/dotnet/build-dotnet-global-tool/default.nix @@ -72,7 +72,7 @@ buildDotnetModule ( passthru = { updateScript = ./update.sh; nupkg = nupkg; - } // args.passthru or {}; + } // args.passthru or { }; } ) (if lib.isFunction fnOrAttrs then fnOrAttrs finalAttrs else fnOrAttrs) diff --git a/pkgs/build-support/dotnet/build-dotnet-module/hooks/default.nix b/pkgs/build-support/dotnet/build-dotnet-module/hooks/default.nix index 1110e01f7dd93d..a30b1b19fef752 100644 --- a/pkgs/build-support/dotnet/build-dotnet-module/hooks/default.nix +++ b/pkgs/build-support/dotnet/build-dotnet-module/hooks/default.nix @@ -1,60 +1,54 @@ -{ lib -, stdenv -, which -, coreutils -, zlib -, openssl -, makeSetupHook -, zip +{ + lib, + stdenv, + which, + coreutils, + zlib, + openssl, + makeSetupHook, + zip, # Passed from ../default.nix -, dotnet-sdk -, dotnet-runtime + dotnet-sdk, + dotnet-runtime, }: { - dotnetConfigureHook = makeSetupHook - { - name = "dotnet-configure-hook"; - substitutions = { - dynamicLinker = "${stdenv.cc}/nix-support/dynamic-linker"; - libPath = lib.makeLibraryPath [ - stdenv.cc.cc - stdenv.cc.libc - dotnet-sdk.passthru.icu - zlib - openssl - ]; - }; - } - ./dotnet-configure-hook.sh; + dotnetConfigureHook = makeSetupHook { + name = "dotnet-configure-hook"; + substitutions = { + dynamicLinker = "${stdenv.cc}/nix-support/dynamic-linker"; + libPath = lib.makeLibraryPath [ + stdenv.cc.cc + stdenv.cc.libc + dotnet-sdk.passthru.icu + zlib + openssl + ]; + }; + } ./dotnet-configure-hook.sh; - dotnetBuildHook = makeSetupHook - { - name = "dotnet-build-hook"; - } - ./dotnet-build-hook.sh; + dotnetBuildHook = makeSetupHook { + name = "dotnet-build-hook"; + } ./dotnet-build-hook.sh; - dotnetCheckHook = makeSetupHook - { - name = "dotnet-check-hook"; - } - ./dotnet-check-hook.sh; + dotnetCheckHook = makeSetupHook { + name = "dotnet-check-hook"; + } ./dotnet-check-hook.sh; - dotnetInstallHook = makeSetupHook - { - name = "dotnet-install-hook"; - substitutions = { - inherit zip; - }; - } - ./dotnet-install-hook.sh; + dotnetInstallHook = makeSetupHook { + name = "dotnet-install-hook"; + substitutions = { + inherit zip; + }; + } ./dotnet-install-hook.sh; - dotnetFixupHook = makeSetupHook - { - name = "dotnet-fixup-hook"; - substitutions = { - dotnetRuntime = if (dotnet-runtime != null) then dotnet-runtime else null; - wrapperPath = lib.makeBinPath [ which coreutils ]; - }; - } - ./dotnet-fixup-hook.sh; + dotnetFixupHook = makeSetupHook { + name = "dotnet-fixup-hook"; + substitutions = { + dotnetRuntime = if (dotnet-runtime != null) then dotnet-runtime else null; + wrapperPath = lib.makeBinPath [ + which + coreutils + ]; + }; + } ./dotnet-fixup-hook.sh; } diff --git a/pkgs/build-support/dotnet/build-dotnet-package/default.nix b/pkgs/build-support/dotnet/build-dotnet-package/default.nix index 14446ef05e72a9..64bf19addb274d 100644 --- a/pkgs/build-support/dotnet/build-dotnet-package/default.nix +++ b/pkgs/build-support/dotnet/build-dotnet-package/default.nix @@ -1,116 +1,124 @@ -{ stdenv, lib, makeWrapper, pkg-config, mono, dotnetbuildhelpers }: - -attrsOrig @ -{ pname -, version -, nativeBuildInputs ? [] -, xBuildFiles ? [ ] -, xBuildFlags ? [ "/p:Configuration=Release" ] -, outputFiles ? [ "bin/Release/*" ] -, dllFiles ? [ "*.dll" ] -, exeFiles ? [ "*.exe" ] -# Additional arguments to pass to the makeWrapper function, which wraps -# generated binaries. -, makeWrapperArgs ? [ ] -, ... }: - let - arrayToShell = (a: toString (map (lib.escape (lib.stringToCharacters "\\ ';$`()|<>\t") ) a)); - - attrs = { - inherit pname version; - - nativeBuildInputs = [ - pkg-config - makeWrapper - dotnetbuildhelpers - mono - ] ++ nativeBuildInputs; - - configurePhase = '' - runHook preConfigure - - [ -z "''${dontPlacateNuget-}" ] && placate-nuget.sh - [ -z "''${dontPlacatePaket-}" ] && placate-paket.sh - [ -z "''${dontPatchFSharpTargets-}" ] && patch-fsharp-targets.sh - - runHook postConfigure - ''; - - buildPhase = '' - runHook preBuild - - echo Building dotNET packages... - - # Probably needs to be moved to fsharp - if pkg-config FSharp.Core - then - export FSharpTargetsPath="$(dirname $(pkg-config FSharp.Core --variable=Libraries))/Microsoft.FSharp.Targets" - fi - - ran="" - for xBuildFile in ${arrayToShell xBuildFiles} ''${xBuildFilesExtra} +{ + stdenv, + lib, + makeWrapper, + pkg-config, + mono, + dotnetbuildhelpers, +}: + +attrsOrig@{ + pname, + version, + nativeBuildInputs ? [ ], + xBuildFiles ? [ ], + xBuildFlags ? [ "/p:Configuration=Release" ], + outputFiles ? [ "bin/Release/*" ], + dllFiles ? [ "*.dll" ], + exeFiles ? [ "*.exe" ], + # Additional arguments to pass to the makeWrapper function, which wraps + # generated binaries. + makeWrapperArgs ? [ ], + ... +}: +let + arrayToShell = (a: toString (map (lib.escape (lib.stringToCharacters "\\ ';$`()|<>\t")) a)); + + attrs = { + inherit pname version; + + nativeBuildInputs = [ + pkg-config + makeWrapper + dotnetbuildhelpers + mono + ] ++ nativeBuildInputs; + + configurePhase = '' + runHook preConfigure + + [ -z "''${dontPlacateNuget-}" ] && placate-nuget.sh + [ -z "''${dontPlacatePaket-}" ] && placate-paket.sh + [ -z "''${dontPatchFSharpTargets-}" ] && patch-fsharp-targets.sh + + runHook postConfigure + ''; + + buildPhase = '' + runHook preBuild + + echo Building dotNET packages... + + # Probably needs to be moved to fsharp + if pkg-config FSharp.Core + then + export FSharpTargetsPath="$(dirname $(pkg-config FSharp.Core --variable=Libraries))/Microsoft.FSharp.Targets" + fi + + ran="" + for xBuildFile in ${arrayToShell xBuildFiles} ''${xBuildFilesExtra} + do + ran="yes" + xbuild ${arrayToShell xBuildFlags} ''${xBuildFlagsArray} $xBuildFile + done + + [ -z "$ran" ] && xbuild ${arrayToShell xBuildFlags} ''${xBuildFlagsArray} + + runHook postBuild + ''; + + dontStrip = true; + + installPhase = '' + runHook preInstall + + target="$out/lib/dotnet/${pname}" + mkdir -p "$target" + + cp -rv ${arrayToShell outputFiles} "''${outputFilesArray[@]}" "$target" + + if [ -z "''${dontRemoveDuplicatedDlls-}" ] + then + pushd "$out" + remove-duplicated-dlls.sh + popd + fi + + set -f + for dllPattern in ${arrayToShell dllFiles} ''${dllFilesArray[@]} + do + set +f + for dll in "$target"/$dllPattern do - ran="yes" - xbuild ${arrayToShell xBuildFlags} ''${xBuildFlagsArray} $xBuildFile + [ -f "$dll" ] || continue + if pkg-config $(basename -s .dll "$dll") + then + echo "$dll already exported by a buildInputs, not re-exporting" + else + create-pkg-config-for-dll.sh "$out/lib/pkgconfig" "$dll" + fi done + done - [ -z "$ran" ] && xbuild ${arrayToShell xBuildFlags} ''${xBuildFlagsArray} - - runHook postBuild - ''; - - dontStrip = true; - - installPhase = '' - runHook preInstall - - target="$out/lib/dotnet/${pname}" - mkdir -p "$target" - - cp -rv ${arrayToShell outputFiles} "''${outputFilesArray[@]}" "$target" - - if [ -z "''${dontRemoveDuplicatedDlls-}" ] - then - pushd "$out" - remove-duplicated-dlls.sh - popd - fi - - set -f - for dllPattern in ${arrayToShell dllFiles} ''${dllFilesArray[@]} - do - set +f - for dll in "$target"/$dllPattern - do - [ -f "$dll" ] || continue - if pkg-config $(basename -s .dll "$dll") - then - echo "$dll already exported by a buildInputs, not re-exporting" - else - create-pkg-config-for-dll.sh "$out/lib/pkgconfig" "$dll" - fi - done - done - - set -f - for exePattern in ${arrayToShell exeFiles} ''${exeFilesArray[@]} + set -f + for exePattern in ${arrayToShell exeFiles} ''${exeFilesArray[@]} + do + set +f + for exe in "$target"/$exePattern do - set +f - for exe in "$target"/$exePattern - do - [ -f "$exe" ] || continue - mkdir -p "$out"/bin - commandName="$(basename -s .exe "$(echo "$exe" | tr "[A-Z]" "[a-z]")")" - makeWrapper \ - "${mono}/bin/mono" \ - "$out"/bin/"$commandName" \ - --add-flags "\"$exe\"" \ - ''${makeWrapperArgs} - done + [ -f "$exe" ] || continue + mkdir -p "$out"/bin + commandName="$(basename -s .exe "$(echo "$exe" | tr "[A-Z]" "[a-z]")")" + makeWrapper \ + "${mono}/bin/mono" \ + "$out"/bin/"$commandName" \ + --add-flags "\"$exe\"" \ + ''${makeWrapperArgs} done + done - runHook postInstall - ''; - }; - in - stdenv.mkDerivation (attrs // (builtins.removeAttrs attrsOrig [ "nativeBuildInputs" ] )) + runHook postInstall + ''; + }; +in +stdenv.mkDerivation (attrs // (builtins.removeAttrs attrsOrig [ "nativeBuildInputs" ])) diff --git a/pkgs/build-support/dotnet/dotnetenv/build-solution.nix b/pkgs/build-support/dotnet/dotnetenv/build-solution.nix index 9984db1cb2d3f7..dc811ebfd545df 100644 --- a/pkgs/build-support/dotnet/dotnetenv/build-solution.nix +++ b/pkgs/build-support/dotnet/dotnetenv/build-solution.nix @@ -1,15 +1,20 @@ -{ lib, stdenv, dotnetfx }: -{ name -, src -, baseDir ? "." -, slnFile -, targets ? "ReBuild" -, verbosity ? "detailed" -, options ? "/p:Configuration=Debug;Platform=Win32" -, assemblyInputs ? [] -, preBuild ? "" -, modifyPublicMain ? false -, mainClassFile ? null +{ + lib, + stdenv, + dotnetfx, +}: +{ + name, + src, + baseDir ? ".", + slnFile, + targets ? "ReBuild", + verbosity ? "detailed", + options ? "/p:Configuration=Debug;Platform=Win32", + assemblyInputs ? [ ], + preBuild ? "", + modifyPublicMain ? false, + mainClassFile ? null, }: assert modifyPublicMain -> mainClassFile != null; diff --git a/pkgs/build-support/dotnet/dotnetenv/default.nix b/pkgs/build-support/dotnet/dotnetenv/default.nix index 3015db42b07b16..5468a4916cae37 100644 --- a/pkgs/build-support/dotnet/dotnetenv/default.nix +++ b/pkgs/build-support/dotnet/dotnetenv/default.nix @@ -1,17 +1,26 @@ -{ lib, stdenv, dotnetfx }: - -let dotnetenv = { - buildSolution = import ./build-solution.nix { - inherit lib stdenv; - dotnetfx = dotnetfx.pkg; - }; + lib, + stdenv, + dotnetfx, +}: - buildWrapper = import ./wrapper.nix { - inherit dotnetenv; - }; +let + dotnetenv = { + buildSolution = import ./build-solution.nix { + inherit lib stdenv; + dotnetfx = dotnetfx.pkg; + }; - inherit (dotnetfx) assembly20Path wcfPath referenceAssembly30Path referenceAssembly35Path; -}; + buildWrapper = import ./wrapper.nix { + inherit dotnetenv; + }; + + inherit (dotnetfx) + assembly20Path + wcfPath + referenceAssembly30Path + referenceAssembly35Path + ; + }; in dotnetenv diff --git a/pkgs/build-support/dotnet/dotnetenv/wrapper.nix b/pkgs/build-support/dotnet/dotnetenv/wrapper.nix index 549abd07e2b997..82685abf724f3d 100644 --- a/pkgs/build-support/dotnet/dotnetenv/wrapper.nix +++ b/pkgs/build-support/dotnet/dotnetenv/wrapper.nix @@ -1,23 +1,31 @@ -{dotnetenv}: +{ dotnetenv }: -{ name -, src -, baseDir ? "." -, slnFile -, targets ? "ReBuild" -, verbosity ? "detailed" -, options ? "/p:Configuration=Debug;Platform=Win32" -, assemblyInputs ? [] -, preBuild ? "" -, namespace -, mainClassName -, mainClassFile -, modifyPublicMain ? true +{ + name, + src, + baseDir ? ".", + slnFile, + targets ? "ReBuild", + verbosity ? "detailed", + options ? "/p:Configuration=Debug;Platform=Win32", + assemblyInputs ? [ ], + preBuild ? "", + namespace, + mainClassName, + mainClassFile, + modifyPublicMain ? true, }: let application = dotnetenv.buildSolution { - inherit name src baseDir slnFile targets verbosity; + inherit + name + src + baseDir + slnFile + targets + verbosity + ; inherit options assemblyInputs preBuild; inherit modifyPublicMain mainClassFile; }; diff --git a/pkgs/build-support/dotnet/fetchnuget/default.nix b/pkgs/build-support/dotnet/fetchnuget/default.nix index a8e85270e73faf..eca601a746cfa3 100644 --- a/pkgs/build-support/dotnet/fetchnuget/default.nix +++ b/pkgs/build-support/dotnet/fetchnuget/default.nix @@ -1,13 +1,17 @@ -{ fetchurl, buildDotnetPackage, unzip }: +{ + fetchurl, + buildDotnetPackage, + unzip, +}: -attrs @ -{ pname -, version -, url ? "https://www.nuget.org/api/v2/package/${pname}/${version}" -, sha256 ? "" -, hash ? "" -, md5 ? "" -, ... +attrs@{ + pname, + version, + url ? "https://www.nuget.org/api/v2/package/${pname}/${version}", + sha256 ? "", + hash ? "", + md5 ? "", + ... }: if md5 != "" then throw "fetchnuget does not support md5 anymore, please use 'hash' attribute with SRI hash" @@ -15,33 +19,36 @@ if md5 != "" then else if (sha256 != "" && hash != "") then throw "multiple hashes passed to fetchNuGet" else - buildDotnetPackage ({ - src = fetchurl { - inherit url sha256 hash; - name = "${pname}.${version}.zip"; - }; + buildDotnetPackage ( + { + src = fetchurl { + inherit url sha256 hash; + name = "${pname}.${version}.zip"; + }; - sourceRoot = "."; + sourceRoot = "."; - nativeBuildInputs = [ unzip ]; + nativeBuildInputs = [ unzip ]; - dontBuild = true; + dontBuild = true; - preInstall = '' - function traverseRename () { - for e in * - do - t="$(echo "$e" | sed -e "s/%20/\ /g" -e "s/%2B/+/g")" - [ "$t" != "$e" ] && mv -vn "$e" "$t" - if [ -d "$t" ] - then - cd "$t" - traverseRename - cd .. - fi - done - } + preInstall = '' + function traverseRename () { + for e in * + do + t="$(echo "$e" | sed -e "s/%20/\ /g" -e "s/%2B/+/g")" + [ "$t" != "$e" ] && mv -vn "$e" "$t" + if [ -d "$t" ] + then + cd "$t" + traverseRename + cd .. + fi + done + } - traverseRename - ''; - } // attrs) + traverseRename + ''; + } + // attrs + ) diff --git a/pkgs/build-support/dotnet/make-nuget-source/default.nix b/pkgs/build-support/dotnet/make-nuget-source/default.nix index 4cf9c1a7412af9..fe8814eeb2e2e4 100644 --- a/pkgs/build-support/dotnet/make-nuget-source/default.nix +++ b/pkgs/build-support/dotnet/make-nuget-source/default.nix @@ -1,28 +1,43 @@ -{ lib, python3, stdenvNoCC }: +{ + lib, + python3, + stdenvNoCC, +}: -{ name -, description ? "" -, deps ? [] -, ... +{ + name, + description ? "", + deps ? [ ], + ... }@args: -stdenvNoCC.mkDerivation (lib.recursiveUpdate { - inherit name; +stdenvNoCC.mkDerivation ( + lib.recursiveUpdate + { + inherit name; - nativeBuildInputs = [ python3 ]; + nativeBuildInputs = [ python3 ]; - buildCommand = '' - mkdir -p $out/{lib,share} + buildCommand = '' + mkdir -p $out/{lib,share} - # use -L to follow symbolic links. When `projectReferences` is used in - # buildDotnetModule, one of the deps will be a symlink farm. - find -L ${lib.concatStringsSep " " deps} -type f -name '*.nupkg' -exec \ - ln -s '{}' -t $out/lib ';' + # use -L to follow symbolic links. When `projectReferences` is used in + # buildDotnetModule, one of the deps will be a symlink farm. + find -L ${lib.concatStringsSep " " deps} -type f -name '*.nupkg' -exec \ + ln -s '{}' -t $out/lib ';' - # Generates a list of all licenses' spdx ids, if available. - # Note that this currently ignores any license provided in plain text (e.g. "LICENSE.txt") - python ${./extract-licenses-from-nupkgs.py} $out/lib > $out/share/licenses - ''; + # Generates a list of all licenses' spdx ids, if available. + # Note that this currently ignores any license provided in plain text (e.g. "LICENSE.txt") + python ${./extract-licenses-from-nupkgs.py} $out/lib > $out/share/licenses + ''; - meta.description = description; -} (removeAttrs args [ "name" "description" "deps" ])) + meta.description = description; + } + ( + removeAttrs args [ + "name" + "description" + "deps" + ] + ) +) diff --git a/pkgs/build-support/fetch9front/default.nix b/pkgs/build-support/fetch9front/default.nix index 677fee1decd772..1ddc5eba04ec73 100644 --- a/pkgs/build-support/fetch9front/default.nix +++ b/pkgs/build-support/fetch9front/default.nix @@ -1,35 +1,57 @@ -{ fetchgit, fetchzip, lib }: +{ + fetchgit, + fetchzip, + lib, +}: lib.makeOverridable ( - { owner - , repo - , rev - , domain ? "git.9front.org" - , name ? "source" - , leaveDotGit ? false - , deepClone ? false - , ... # For hash agility - } @ args: + { + owner, + repo, + rev, + domain ? "git.9front.org", + name ? "source", + leaveDotGit ? false, + deepClone ? false, + ... # For hash agility + }@args: let - passthruAttrs = removeAttrs args [ "domain" "owner" "repo" "rev" "leaveDotGit" "deepClone" ]; + passthruAttrs = removeAttrs args [ + "domain" + "owner" + "repo" + "rev" + "leaveDotGit" + "deepClone" + ]; useFetchGit = leaveDotGit || deepClone; fetcher = if useFetchGit then fetchgit else fetchzip; gitRepoUrl = "git://${domain}/${owner}/${repo}"; - fetcherArgs = (if useFetchGit then { - # git9 does not support shallow fetches - inherit rev leaveDotGit; - url = gitRepoUrl; - } else { - url = "https://${domain}/${owner}/${repo}/${rev}/snap.tar.gz"; + fetcherArgs = + ( + if useFetchGit then + { + # git9 does not support shallow fetches + inherit rev leaveDotGit; + url = gitRepoUrl; + } + else + { + url = "https://${domain}/${owner}/${repo}/${rev}/snap.tar.gz"; - passthru = { - inherit gitRepoUrl; + passthru = { + inherit gitRepoUrl; + }; + } + ) + // passthruAttrs + // { + inherit name; }; - }) // passthruAttrs // { inherit name; }; in fetcher fetcherArgs // { inherit rev; } diff --git a/pkgs/build-support/fetchbitbucket/default.nix b/pkgs/build-support/fetchbitbucket/default.nix index 2f9103f2bb3e0e..9e64954bebff62 100644 --- a/pkgs/build-support/fetchbitbucket/default.nix +++ b/pkgs/build-support/fetchbitbucket/default.nix @@ -1,11 +1,26 @@ { fetchzip, lib }: lib.makeOverridable ( -{ owner, repo, rev, name ? "source" -, ... # For hash agility -}@args: fetchzip ({ - inherit name; - url = "https://bitbucket.org/${owner}/${repo}/get/${rev}.tar.gz"; - meta.homepage = "https://bitbucket.org/${owner}/${repo}/"; -} // removeAttrs args [ "owner" "repo" "rev" ]) // { inherit rev; } + { + owner, + repo, + rev, + name ? "source", + ... # For hash agility + }@args: + fetchzip ( + { + inherit name; + url = "https://bitbucket.org/${owner}/${repo}/get/${rev}.tar.gz"; + meta.homepage = "https://bitbucket.org/${owner}/${repo}/"; + } + // removeAttrs args [ + "owner" + "repo" + "rev" + ] + ) + // { + inherit rev; + } ) diff --git a/pkgs/build-support/fetchbower/default.nix b/pkgs/build-support/fetchbower/default.nix index fd971d431df88e..258a09189d991a 100644 --- a/pkgs/build-support/fetchbower/default.nix +++ b/pkgs/build-support/fetchbower/default.nix @@ -1,28 +1,41 @@ -{ stdenvNoCC, lib, bower2nix, cacert }: +{ + stdenvNoCC, + lib, + bower2nix, + cacert, +}: let - bowerVersion = version: + bowerVersion = + version: let components = lib.splitString "#" version; hash = lib.last components; ver = if builtins.length components == 1 then (cleanName version) else hash; - in ver; + in + ver; - cleanName = name: lib.replaceStrings ["/" ":"] ["-" "-"] name; + cleanName = name: lib.replaceStrings [ "/" ":" ] [ "-" "-" ] name; - fetchbower = name: version: target: outputHash: stdenvNoCC.mkDerivation { - name = "${cleanName name}-${bowerVersion version}"; - buildCommand = '' - fetch-bower --quiet --out=$PWD/out "${name}" "${target}" "${version}" - # In some cases, the result of fetchBower is different depending - # on the output directory (e.g. if the bower package contains - # symlinks). So use a local output directory before copying to - # $out. - cp -R out $out - ''; - outputHashMode = "recursive"; - outputHashAlgo = "sha256"; - inherit outputHash; - nativeBuildInputs = [ bower2nix cacert ]; - }; + fetchbower = + name: version: target: outputHash: + stdenvNoCC.mkDerivation { + name = "${cleanName name}-${bowerVersion version}"; + buildCommand = '' + fetch-bower --quiet --out=$PWD/out "${name}" "${target}" "${version}" + # In some cases, the result of fetchBower is different depending + # on the output directory (e.g. if the bower package contains + # symlinks). So use a local output directory before copying to + # $out. + cp -R out $out + ''; + outputHashMode = "recursive"; + outputHashAlgo = "sha256"; + inherit outputHash; + nativeBuildInputs = [ + bower2nix + cacert + ]; + }; -in fetchbower +in +fetchbower diff --git a/pkgs/build-support/fetchbzr/default.nix b/pkgs/build-support/fetchbzr/default.nix index 1f6f0f2a788e20..9468972a0d2f91 100644 --- a/pkgs/build-support/fetchbzr/default.nix +++ b/pkgs/build-support/fetchbzr/default.nix @@ -1,6 +1,15 @@ -{ lib, stdenvNoCC, breezy }: +{ + lib, + stdenvNoCC, + breezy, +}: lib.fetchers.withNormalizedHash { } ( - { url, rev, outputHash, outputHashAlgo }: + { + url, + rev, + outputHash, + outputHashAlgo, + }: stdenvNoCC.mkDerivation { name = "bzr-export"; diff --git a/pkgs/build-support/fetchcvs/default.nix b/pkgs/build-support/fetchcvs/default.nix index 94bbc69bba65ac..b7cd5ffb878b0c 100644 --- a/pkgs/build-support/fetchcvs/default.nix +++ b/pkgs/build-support/fetchcvs/default.nix @@ -3,21 +3,41 @@ # tag="" (get version by tag name) # If you don't specify neither one date="NOW" will be used (get latest) -{stdenvNoCC, cvs, openssh, lib}: +{ + stdenvNoCC, + cvs, + openssh, + lib, +}: lib.makeOverridable ( lib.fetchers.withNormalizedHash { } ( - {cvsRoot, module, tag ? null, date ? null, outputHash, outputHashAlgo}: + { + cvsRoot, + module, + tag ? null, + date ? null, + outputHash, + outputHashAlgo, + }: stdenvNoCC.mkDerivation { name = "cvs-export"; builder = ./builder.sh; - nativeBuildInputs = [cvs openssh]; + nativeBuildInputs = [ + cvs + openssh + ]; inherit outputHash outputHashAlgo; outputHashMode = "recursive"; - inherit cvsRoot module tag date; + inherit + cvsRoot + module + tag + date + ; } ) ) diff --git a/pkgs/build-support/fetchdarcs/default.nix b/pkgs/build-support/fetchdarcs/default.nix index 320b201f2853c8..2d24ddaecbd419 100644 --- a/pkgs/build-support/fetchdarcs/default.nix +++ b/pkgs/build-support/fetchdarcs/default.nix @@ -1,23 +1,37 @@ -{stdenvNoCC, darcs, cacert, lib}: +{ + stdenvNoCC, + darcs, + cacert, + lib, +}: lib.makeOverridable ( lib.fetchers.withNormalizedHash { } ( - { url - , rev ? null - , context ? null - , outputHash ? lib.fakeHash - , outputHashAlgo ? null - , name ? "fetchdarcs" + { + url, + rev ? null, + context ? null, + outputHash ? lib.fakeHash, + outputHashAlgo ? null, + name ? "fetchdarcs", }: stdenvNoCC.mkDerivation { builder = ./builder.sh; - nativeBuildInputs = [cacert darcs]; + nativeBuildInputs = [ + cacert + darcs + ]; inherit outputHash outputHashAlgo; outputHashMode = "recursive"; - inherit url rev context name; + inherit + url + rev + context + name + ; } ) ) diff --git a/pkgs/build-support/fetchdebianpatch/default.nix b/pkgs/build-support/fetchdebianpatch/default.nix index 8d8076bd59d630..0f694f9fd52b8e 100644 --- a/pkgs/build-support/fetchdebianpatch/default.nix +++ b/pkgs/build-support/fetchdebianpatch/default.nix @@ -1,16 +1,21 @@ { lib, fetchpatch }: lib.makeOverridable ( - { pname, version, debianRevision ? null, area ? "main", - patch, name ? patch, hash }: + { + pname, + version, + debianRevision ? null, + area ? "main", + patch, + name ? patch, + hash, + }: let inherit (lib.strings) hasPrefix substring; - prefix = - substring 0 (if hasPrefix "lib" pname then 4 else 1) pname; - versionString = - if debianRevision == null then version - else "${version}-${debianRevision}"; - in fetchpatch { + prefix = substring 0 (if hasPrefix "lib" pname then 4 else 1) pname; + versionString = if debianRevision == null then version else "${version}-${debianRevision}"; + in + fetchpatch { inherit name hash; url = "https://sources.debian.org/data/${area}/${prefix}/" diff --git a/pkgs/build-support/fetchdocker/credentials.nix b/pkgs/build-support/fetchdocker/credentials.nix index f8a229ccb6bb17..6ee63cd9520a50 100644 --- a/pkgs/build-support/fetchdocker/credentials.nix +++ b/pkgs/build-support/fetchdocker/credentials.nix @@ -31,9 +31,6 @@ # given to the nix-build invocation to provide it with the # DOCKER_CREDENTIALS path let - pathParts = - (builtins.filter - ({prefix, path}: "DOCKER_CREDENTIALS" == prefix) - builtins.nixPath); + pathParts = (builtins.filter ({ prefix, path }: "DOCKER_CREDENTIALS" == prefix) builtins.nixPath); in - lib.optionalString (pathParts != []) ((builtins.head pathParts).path) +lib.optionalString (pathParts != [ ]) ((builtins.head pathParts).path) diff --git a/pkgs/build-support/fetchdocker/default.nix b/pkgs/build-support/fetchdocker/default.nix index ef6132bfe3a5ad..795c37b3c69800 100644 --- a/pkgs/build-support/fetchdocker/default.nix +++ b/pkgs/build-support/fetchdocker/default.nix @@ -1,25 +1,31 @@ -{ stdenv, lib, coreutils, bash, gnutar, writeText }: +{ + stdenv, + lib, + coreutils, + bash, + gnutar, + writeText, +}: let - stripScheme = - builtins.replaceStrings [ "https://" "http://" ] [ "" "" ]; - stripNixStore = - s: lib.removePrefix "${builtins.storeDir}/" s; + stripScheme = builtins.replaceStrings [ "https://" "http://" ] [ "" "" ]; + stripNixStore = s: lib.removePrefix "${builtins.storeDir}/" s; in -{ name -, registry ? "https://registry-1.docker.io/v2/" -, repository ? "library" -, imageName -, tag -, imageLayers -, imageConfig -, image ? "${stripScheme registry}/${repository}/${imageName}:${tag}" +{ + name, + registry ? "https://registry-1.docker.io/v2/", + repository ? "library", + imageName, + tag, + imageLayers, + imageConfig, + image ? "${stripScheme registry}/${repository}/${imageName}:${tag}", }: # Make sure there are *no* slashes in the repository or container # names since we use these to make the output derivation name for the # nix-store path. -assert null == lib.findFirst (c: "/"==c) null (lib.stringToCharacters repository); -assert null == lib.findFirst (c: "/"==c) null (lib.stringToCharacters imageName); +assert null == lib.findFirst (c: "/" == c) null (lib.stringToCharacters repository); +assert null == lib.findFirst (c: "/" == c) null (lib.stringToCharacters imageName); let # Abuse paths to collapse possible double slashes @@ -28,31 +34,45 @@ let layers = builtins.map stripNixStore imageLayers; - manifest = - writeText "manifest.json" (builtins.toJSON [ - { Config = stripNixStore imageConfig; - Layers = layers; + manifest = writeText "manifest.json" ( + builtins.toJSON [ + { + Config = stripNixStore imageConfig; + Layers = layers; RepoTags = [ "${repoTag1}:${tag}" ]; - }]); + } + ] + ); - repositories = - writeText "repositories" (builtins.toJSON { + repositories = writeText "repositories" ( + builtins.toJSON { ${repoTag1} = { ${tag} = lib.last layers; }; - }); + } + ); - imageFileStorePaths = - writeText "imageFileStorePaths.txt" - (lib.concatStringsSep "\n" ((lib.unique imageLayers) ++ [imageConfig])); + imageFileStorePaths = writeText "imageFileStorePaths.txt" ( + lib.concatStringsSep "\n" ((lib.unique imageLayers) ++ [ imageConfig ]) + ); in stdenv.mkDerivation { - builder = ./fetchdocker-builder.sh; + builder = ./fetchdocker-builder.sh; buildInputs = [ coreutils ]; preferLocalBuild = true; - inherit name imageName repository tag; - inherit bash gnutar manifest repositories; + inherit + name + imageName + repository + tag + ; + inherit + bash + gnutar + manifest + repositories + ; inherit imageFileStorePaths; passthru = { diff --git a/pkgs/build-support/fetchdocker/fetchDockerConfig.nix b/pkgs/build-support/fetchdocker/fetchDockerConfig.nix index 9fd813bfa575ac..6ff226893ff784 100644 --- a/pkgs/build-support/fetchdocker/fetchDockerConfig.nix +++ b/pkgs/build-support/fetchdocker/fetchDockerConfig.nix @@ -1,13 +1,26 @@ -pkgargs@{ stdenv, lib, haskellPackages, writeText, gawk }: +pkgargs@{ + stdenv, + lib, + haskellPackages, + writeText, + gawk, +}: let - generic-fetcher = - import ./generic-fetcher.nix pkgargs; + generic-fetcher = import ./generic-fetcher.nix pkgargs; in -args@{ repository ? "library", imageName, tag, ... }: +args@{ + repository ? "library", + imageName, + tag, + ... +}: -generic-fetcher ({ - fetcher = "hocker-config"; - name = "${repository}_${imageName}_${tag}-config.json"; - tag = "unused"; -} // args) +generic-fetcher ( + { + fetcher = "hocker-config"; + name = "${repository}_${imageName}_${tag}-config.json"; + tag = "unused"; + } + // args +) diff --git a/pkgs/build-support/fetchdocker/fetchDockerLayer.nix b/pkgs/build-support/fetchdocker/fetchDockerLayer.nix index 869ba637429cdb..87f8f6061f7577 100644 --- a/pkgs/build-support/fetchdocker/fetchDockerLayer.nix +++ b/pkgs/build-support/fetchdocker/fetchDockerLayer.nix @@ -1,13 +1,21 @@ -pkgargs@{ stdenv, lib, haskellPackages, writeText, gawk }: +pkgargs@{ + stdenv, + lib, + haskellPackages, + writeText, + gawk, +}: let - generic-fetcher = - import ./generic-fetcher.nix pkgargs; + generic-fetcher = import ./generic-fetcher.nix pkgargs; in args@{ layerDigest, ... }: -generic-fetcher ({ - fetcher = "hocker-layer"; - name = "docker-layer-${layerDigest}.tar.gz"; - tag = "unused"; -} // args) +generic-fetcher ( + { + fetcher = "hocker-layer"; + name = "docker-layer-${layerDigest}.tar.gz"; + tag = "unused"; + } + // args +) diff --git a/pkgs/build-support/fetchfirefoxaddon/tests.nix b/pkgs/build-support/fetchfirefoxaddon/tests.nix index a29f65c542adb7..809c5cf904a477 100644 --- a/pkgs/build-support/fetchfirefoxaddon/tests.nix +++ b/pkgs/build-support/fetchfirefoxaddon/tests.nix @@ -1,4 +1,9 @@ -{ testers, fetchFirefoxAddon, fetchurl, ... }: +{ + testers, + fetchFirefoxAddon, + fetchurl, + ... +}: { simple = testers.invalidateFetcherByDrvHash fetchFirefoxAddon { diff --git a/pkgs/build-support/fetchfossil/default.nix b/pkgs/build-support/fetchfossil/default.nix index d0fc4cdea703d9..9499841dd3cea8 100644 --- a/pkgs/build-support/fetchfossil/default.nix +++ b/pkgs/build-support/fetchfossil/default.nix @@ -1,17 +1,26 @@ -{stdenv, lib, fossil, cacert}: +{ + stdenv, + lib, + fossil, + cacert, +}: lib.fetchers.withNormalizedHash { } ( - { name ? null - , url - , rev - , outputHash ? lib.fakeHash - , outputHashAlgo ? null + { + name ? null, + url, + rev, + outputHash ? lib.fakeHash, + outputHashAlgo ? null, }: stdenv.mkDerivation { name = "fossil-archive" + (lib.optionalString (name != null) "-${name}"); builder = ./builder.sh; - nativeBuildInputs = [fossil cacert]; + nativeBuildInputs = [ + fossil + cacert + ]; # Envvar docs are hard to find. A link for the future: # https://www.fossil-scm.org/index.html/doc/trunk/www/env-opts.md diff --git a/pkgs/build-support/fetchgitea/default.nix b/pkgs/build-support/fetchgitea/default.nix index 513ceba861cbbd..a7910b671e9bdc 100644 --- a/pkgs/build-support/fetchgitea/default.nix +++ b/pkgs/build-support/fetchgitea/default.nix @@ -3,7 +3,7 @@ { lib, fetchFromGitHub }: lib.makeOverridable ( -{ domain, ... }@args: + { domain, ... }@args: -fetchFromGitHub ((removeAttrs args [ "domain" ]) // { githubBase = domain; }) + fetchFromGitHub ((removeAttrs args [ "domain" ]) // { githubBase = domain; }) ) diff --git a/pkgs/build-support/fetchgitiles/default.nix b/pkgs/build-support/fetchgitiles/default.nix index be81c6e8a4c217..7dc26dfdf2f9e8 100644 --- a/pkgs/build-support/fetchgitiles/default.nix +++ b/pkgs/build-support/fetchgitiles/default.nix @@ -1,12 +1,26 @@ { fetchzip, lib }: lib.makeOverridable ( -{ url, rev, name ? "source", ... } @ args: + { + url, + rev, + name ? "source", + ... + }@args: -fetchzip ({ - inherit name; - url = "${url}/+archive/${rev}.tar.gz"; - stripRoot = false; - meta.homepage = url; -} // removeAttrs args [ "url" "rev" ]) // { inherit rev; } + fetchzip ( + { + inherit name; + url = "${url}/+archive/${rev}.tar.gz"; + stripRoot = false; + meta.homepage = url; + } + // removeAttrs args [ + "url" + "rev" + ] + ) + // { + inherit rev; + } ) diff --git a/pkgs/build-support/fetchgitlocal/default.nix b/pkgs/build-support/fetchgitlocal/default.nix index 02a77b25ae0688..cf6f22e6201e8b 100644 --- a/pkgs/build-support/fetchgitlocal/default.nix +++ b/pkgs/build-support/fetchgitlocal/default.nix @@ -1,44 +1,55 @@ -{ runCommand, git, lib }: +{ + runCommand, + git, + lib, +}: lib.makeOverridable ( -src: - -let - srcStr = toString src; - - # Adds the current directory (respecting ignored files) to the git store, and returns the hash - gitHashFile = runCommand "put-in-git" { - nativeBuildInputs = [ git ]; - dummy = builtins.currentTime; # impure, do every time - preferLocalBuild = true; - } '' - cd ${srcStr} - DOT_GIT=$(git rev-parse --resolve-git-dir .git) # path to repo - - cp $DOT_GIT/index $DOT_GIT/index-user # backup index - git reset # reset index - git add . # add current directory - - # hash of current directory - # remove trailing newline - git rev-parse $(git write-tree) \ - | tr -d '\n' > $out - - mv $DOT_GIT/index-user $DOT_GIT/index # restore index - ''; - - gitHash = builtins.readFile gitHashFile; # cache against git hash - - nixPath = runCommand "put-in-nix" { - nativeBuildInputs = [ git ]; - preferLocalBuild = true; - } '' - mkdir $out - - # dump tar of *current directory* at given revision - git -C ${srcStr} archive --format=tar ${gitHash} \ - | tar xf - -C $out - ''; - -in nixPath + src: + + let + srcStr = toString src; + + # Adds the current directory (respecting ignored files) to the git store, and returns the hash + gitHashFile = + runCommand "put-in-git" + { + nativeBuildInputs = [ git ]; + dummy = builtins.currentTime; # impure, do every time + preferLocalBuild = true; + } + '' + cd ${srcStr} + DOT_GIT=$(git rev-parse --resolve-git-dir .git) # path to repo + + cp $DOT_GIT/index $DOT_GIT/index-user # backup index + git reset # reset index + git add . # add current directory + + # hash of current directory + # remove trailing newline + git rev-parse $(git write-tree) \ + | tr -d '\n' > $out + + mv $DOT_GIT/index-user $DOT_GIT/index # restore index + ''; + + gitHash = builtins.readFile gitHashFile; # cache against git hash + + nixPath = + runCommand "put-in-nix" + { + nativeBuildInputs = [ git ]; + preferLocalBuild = true; + } + '' + mkdir $out + + # dump tar of *current directory* at given revision + git -C ${srcStr} archive --format=tar ${gitHash} \ + | tar xf - -C $out + ''; + + in + nixPath ) diff --git a/pkgs/build-support/fetchgx/default.nix b/pkgs/build-support/fetchgx/default.nix index 5726e7d4e9f14f..49211c44949ccc 100644 --- a/pkgs/build-support/fetchgx/default.nix +++ b/pkgs/build-support/fetchgx/default.nix @@ -1,13 +1,30 @@ -{ lib, stdenvNoCC, gx, gx-go, go, cacert }: +{ + lib, + stdenvNoCC, + gx, + gx-go, + go, + cacert, +}: lib.fetchers.withNormalizedHash { } ( - { name, src, outputHash, outputHashAlgo }: + { + name, + src, + outputHash, + outputHashAlgo, + }: stdenvNoCC.mkDerivation { name = "${name}-gxdeps"; inherit src; - nativeBuildInputs = [ cacert go gx gx-go ]; + nativeBuildInputs = [ + cacert + go + gx + gx-go + ]; inherit outputHash outputHashAlgo; outputHashMode = "recursive"; diff --git a/pkgs/build-support/fetchhg/default.nix b/pkgs/build-support/fetchhg/default.nix index 6af886bf09344a..ee7dc87a7bfbb8 100644 --- a/pkgs/build-support/fetchhg/default.nix +++ b/pkgs/build-support/fetchhg/default.nix @@ -1,34 +1,41 @@ -{ lib, stdenvNoCC, mercurial }: -{ name ? null -, url -, rev ? null -, sha256 ? null -, hash ? null -, fetchSubrepos ? false -, preferLocalBuild ? true }: +{ + lib, + stdenvNoCC, + mercurial, +}: +{ + name ? null, + url, + rev ? null, + sha256 ? null, + hash ? null, + fetchSubrepos ? false, + preferLocalBuild ? true, +}: if hash != null && sha256 != null then throw "Only one of sha256 or hash can be set" else -# TODO: statically check if mercurial as the https support if the url starts woth https. -stdenvNoCC.mkDerivation { - name = "hg-archive" + (lib.optionalString (name != null) "-${name}"); - builder = ./builder.sh; - nativeBuildInputs = [mercurial]; + # TODO: statically check if mercurial as the https support if the url starts woth https. + stdenvNoCC.mkDerivation { + name = "hg-archive" + (lib.optionalString (name != null) "-${name}"); + builder = ./builder.sh; + nativeBuildInputs = [ mercurial ]; - impureEnvVars = lib.fetchers.proxyImpureEnvVars; + impureEnvVars = lib.fetchers.proxyImpureEnvVars; - subrepoClause = lib.optionalString fetchSubrepos "S"; + subrepoClause = lib.optionalString fetchSubrepos "S"; - outputHashAlgo = if hash != null then null else "sha256"; - outputHashMode = "recursive"; - outputHash = if hash != null then - hash - else if sha256 != null then - sha256 - else - lib.fakeSha256; + outputHashAlgo = if hash != null then null else "sha256"; + outputHashMode = "recursive"; + outputHash = + if hash != null then + hash + else if sha256 != null then + sha256 + else + lib.fakeSha256; - inherit url rev; - inherit preferLocalBuild; -} + inherit url rev; + inherit preferLocalBuild; + } diff --git a/pkgs/build-support/fetchipfs/default.nix b/pkgs/build-support/fetchipfs/default.nix index da94200206ba37..10da9cf0a0991b 100644 --- a/pkgs/build-support/fetchipfs/default.nix +++ b/pkgs/build-support/fetchipfs/default.nix @@ -1,36 +1,48 @@ -{ lib -, stdenv -, curl +{ + lib, + stdenv, + curl, }: -lib.fetchers.withNormalizedHash { hashTypes = [ "sha1" "sha256" "sha512" ]; } ( - { ipfs - , url ? "" - , curlOpts ? "" - , outputHash - , outputHashAlgo - , meta ? {} - , port ? "8080" - , postFetch ? "" - , preferLocalBuild ? true - }: - stdenv.mkDerivation { - name = ipfs; - builder = ./builder.sh; - nativeBuildInputs = [ curl ]; +lib.fetchers.withNormalizedHash + { + hashTypes = [ + "sha1" + "sha256" + "sha512" + ]; + } + ( + { + ipfs, + url ? "", + curlOpts ? "", + outputHash, + outputHashAlgo, + meta ? { }, + port ? "8080", + postFetch ? "", + preferLocalBuild ? true, + }: + stdenv.mkDerivation { + name = ipfs; + builder = ./builder.sh; + nativeBuildInputs = [ curl ]; - # New-style output content requirements. - inherit outputHash outputHashAlgo; - outputHashMode = "recursive"; + # New-style output content requirements. + inherit outputHash outputHashAlgo; + outputHashMode = "recursive"; - inherit curlOpts - postFetch - ipfs - url - port - meta; + inherit + curlOpts + postFetch + ipfs + url + port + meta + ; - # Doing the download on a remote machine just duplicates network - # traffic, so don't do that. - inherit preferLocalBuild; - } -) + # Doing the download on a remote machine just duplicates network + # traffic, so don't do that. + inherit preferLocalBuild; + } + ) diff --git a/pkgs/build-support/fetchmavenartifact/default.nix b/pkgs/build-support/fetchmavenartifact/default.nix index 0f3cd4e64dd61d..eca360057a60c7 100644 --- a/pkgs/build-support/fetchmavenartifact/default.nix +++ b/pkgs/build-support/fetchmavenartifact/default.nix @@ -1,6 +1,10 @@ # Adaptation of the MIT-licensed work on `sbt2nix` done by Charles O'Farrell -{ lib, fetchurl, stdenv }: +{ + lib, + fetchurl, + stdenv, +}: let defaultRepos = [ "https://repo1.maven.org/maven2" @@ -10,64 +14,80 @@ let ]; in -args@ -{ # Example: "org.apache.httpcomponents" - groupId -, # Example: "httpclient" - artifactId -, # Example: "4.3.6" - version -, # Example: "jdk11" - classifier ? null -, # List of maven repositories from where to fetch the artifact. +args@{ + # Example: "org.apache.httpcomponents" + groupId, + # Example: "httpclient" + artifactId, + # Example: "4.3.6" + version, + # Example: "jdk11" + classifier ? null, + # List of maven repositories from where to fetch the artifact. # Example: [ http://oss.sonatype.org/content/repositories/public ]. - repos ? defaultRepos + repos ? defaultRepos, # The `url` and `urls` parameters, if specified should point to the JAR # file and will take precedence over the `repos` parameter. Only one of `url` # and `urls` can be specified, not both. -, url ? "" -, urls ? [] -, # The rest of the arguments are just forwarded to `fetchurl`. + url ? "", + urls ? [ ], + # The rest of the arguments are just forwarded to `fetchurl`. ... }: # only one of url and urls can be specified at a time. -assert (url == "") || (urls == []); +assert (url == "") || (urls == [ ]); # if repos is empty, then url or urls must be specified. -assert (repos != []) || (url != "") || (urls != []); +assert (repos != [ ]) || (url != "") || (urls != [ ]); let - pname = (lib.replaceStrings [ "." ] [ "_" ] groupId) + "_" + (lib.replaceStrings [ "." ] [ "_" ] artifactId); + pname = + (lib.replaceStrings [ "." ] [ "_" ] groupId) + + "_" + + (lib.replaceStrings [ "." ] [ "_" ] artifactId); suffix = lib.optionalString (classifier != null) "-${classifier}"; filename = "${artifactId}-${version}${suffix}.jar"; - mkJarUrl = repoUrl: + mkJarUrl = + repoUrl: lib.concatStringsSep "/" [ (lib.removeSuffix "/" repoUrl) - (lib.replaceStrings ["."] ["/"] groupId) + (lib.replaceStrings [ "." ] [ "/" ] groupId) artifactId version filename ]; urls_ = - if url != "" then [url] - else if urls != [] then urls - else map mkJarUrl repos; - jar = - fetchurl ( - builtins.removeAttrs args [ "groupId" "artifactId" "version" "classifier" "repos" "url" ] - // { urls = urls_; name = "${pname}-${version}.jar"; } - ); + if url != "" then + [ url ] + else if urls != [ ] then + urls + else + map mkJarUrl repos; + jar = fetchurl ( + builtins.removeAttrs args [ + "groupId" + "artifactId" + "version" + "classifier" + "repos" + "url" + ] + // { + urls = urls_; + name = "${pname}-${version}.jar"; + } + ); in - stdenv.mkDerivation { - inherit pname version; - dontUnpack = true; - # By moving the jar to $out/share/java we make it discoverable by java - # packages packages that mention this derivation in their buildInputs. - installPhase = '' - mkdir -p $out/share/java - ln -s ${jar} $out/share/java/${filename} - ''; - # We also add a `jar` attribute that can be used to easily obtain the path - # to the downloaded jar file. - passthru.jar = jar; - } +stdenv.mkDerivation { + inherit pname version; + dontUnpack = true; + # By moving the jar to $out/share/java we make it discoverable by java + # packages packages that mention this derivation in their buildInputs. + installPhase = '' + mkdir -p $out/share/java + ln -s ${jar} $out/share/java/${filename} + ''; + # We also add a `jar` attribute that can be used to easily obtain the path + # to the downloaded jar file. + passthru.jar = jar; +} diff --git a/pkgs/build-support/fetchmtn/default.nix b/pkgs/build-support/fetchmtn/default.nix index de208b92193fe6..1332bace3b12c6 100644 --- a/pkgs/build-support/fetchmtn/default.nix +++ b/pkgs/build-support/fetchmtn/default.nix @@ -1,22 +1,38 @@ # You can specify some extra mirrors and a cache DB via options -{lib, stdenvNoCC, monotone, defaultDBMirrors ? [], cacheDB ? "./mtn-checkout.db"}: +{ + lib, + stdenvNoCC, + monotone, + defaultDBMirrors ? [ ], + cacheDB ? "./mtn-checkout.db", +}: lib.fetchers.withNormalizedHash { } ( # dbs is a list of strings, each is an url for sync # selector is mtn selector, like h:org.example.branch - {name ? "mtn-checkout", dbs ? [] - , outputHash, outputHashAlgo - , selector ? "h:" + branch, branch}: + { + name ? "mtn-checkout", + dbs ? [ ], + outputHash, + outputHashAlgo, + selector ? "h:" + branch, + branch, + }: stdenvNoCC.mkDerivation { builder = ./builder.sh; - nativeBuildInputs = [monotone]; + nativeBuildInputs = [ monotone ]; inherit outputHash outputHashAlgo; outputHashMode = "recursive"; dbs = defaultDBMirrors ++ dbs; - inherit branch cacheDB name selector; + inherit + branch + cacheDB + name + selector + ; impureEnvVars = lib.fetchers.proxyImpureEnvVars; diff --git a/pkgs/build-support/fetchnextcloudapp/default.nix b/pkgs/build-support/fetchnextcloudapp/default.nix index 2f5b7504c09143..d2c6e842a165b0 100644 --- a/pkgs/build-support/fetchnextcloudapp/default.nix +++ b/pkgs/build-support/fetchnextcloudapp/default.nix @@ -1,35 +1,48 @@ -{ fetchurl, fetchzip, applyPatches, lib, ... }: -{ url -, hash ? "" -, sha256 ? "" -, appName ? null -, appVersion ? null -, license -, patches ? [ ] -, description ? null -, homepage ? null -, unpack ? false # whether to use fetchzip rather than fetchurl +{ + fetchurl, + fetchzip, + applyPatches, + lib, + ... }: -applyPatches ({ - inherit patches; - src = (if unpack then fetchzip else fetchurl) { - inherit url hash sha256; - meta = { - license = lib.licenses.${license}; - longDescription = description; - inherit homepage; - } // lib.optionalAttrs (description != null) { - longDescription = description; - } // lib.optionalAttrs (homepage != null) { - inherit homepage; +{ + url, + hash ? "", + sha256 ? "", + appName ? null, + appVersion ? null, + license, + patches ? [ ], + description ? null, + homepage ? null, + unpack ? false, # whether to use fetchzip rather than fetchurl +}: +applyPatches ( + { + inherit patches; + src = (if unpack then fetchzip else fetchurl) { + inherit url hash sha256; + meta = + { + license = lib.licenses.${license}; + longDescription = description; + inherit homepage; + } + // lib.optionalAttrs (description != null) { + longDescription = description; + } + // lib.optionalAttrs (homepage != null) { + inherit homepage; + }; }; - }; - prePatch = '' - if [ ! -f ./appinfo/info.xml ]; then - echo "appinfo/info.xml doesn't exist in $out, aborting!" - exit 1 - fi - ''; -} // lib.optionalAttrs (appName != null && appVersion != null) { - name = "nextcloud-app-${appName}-${appVersion}"; -}) + prePatch = '' + if [ ! -f ./appinfo/info.xml ]; then + echo "appinfo/info.xml doesn't exist in $out, aborting!" + exit 1 + fi + ''; + } + // lib.optionalAttrs (appName != null && appVersion != null) { + name = "nextcloud-app-${appName}-${appVersion}"; + } +) diff --git a/pkgs/build-support/fetchpatch/default.nix b/pkgs/build-support/fetchpatch/default.nix index 97b3661bb2d46c..1b1f23b44c690b 100644 --- a/pkgs/build-support/fetchpatch/default.nix +++ b/pkgs/build-support/fetchpatch/default.nix @@ -4,92 +4,118 @@ # often change with updating of git or cgit. # stripLen acts as the -p parameter when applying a patch. -{ lib, fetchurl, patchutils }: +{ + lib, + fetchurl, + patchutils, +}: -{ relative ? null -, stripLen ? 0 -, decode ? "cat" # custom command to decode patch e.g. base64 -d -, extraPrefix ? null -, excludes ? [] -, includes ? [] -, revert ? false -, postFetch ? "" -, nativeBuildInputs ? [] -, ... +{ + relative ? null, + stripLen ? 0, + decode ? "cat", # custom command to decode patch e.g. base64 -d + extraPrefix ? null, + excludes ? [ ], + includes ? [ ], + revert ? false, + postFetch ? "", + nativeBuildInputs ? [ ], + ... }@args: let - args' = if relative != null then { - stripLen = 1 + lib.length (lib.splitString "/" relative) + stripLen; - extraPrefix = lib.optionalString (extraPrefix != null) extraPrefix; - } else { - inherit stripLen extraPrefix; - }; -in let + args' = + if relative != null then + { + stripLen = 1 + lib.length (lib.splitString "/" relative) + stripLen; + extraPrefix = lib.optionalString (extraPrefix != null) extraPrefix; + } + else + { + inherit stripLen extraPrefix; + }; +in +let inherit (args') stripLen extraPrefix; in -lib.throwIfNot (excludes == [] || includes == []) +lib.throwIfNot (excludes == [ ] || includes == [ ]) "fetchpatch: cannot use excludes and includes simultaneously" -fetchurl ({ - nativeBuildInputs = [ patchutils ] ++ nativeBuildInputs; - postFetch = '' - tmpfile="$TMPDIR/patch" + fetchurl + ( + { + nativeBuildInputs = [ patchutils ] ++ nativeBuildInputs; + postFetch = + '' + tmpfile="$TMPDIR/patch" - if [ ! -s "$out" ]; then - echo "error: Fetched patch file '$out' is empty!" 1>&2 - exit 1 - fi + if [ ! -s "$out" ]; then + echo "error: Fetched patch file '$out' is empty!" 1>&2 + exit 1 + fi - set +e - ${decode} < "$out" > "$tmpfile" - if [ $? -ne 0 ] || [ ! -s "$tmpfile" ]; then - echo 'Failed to decode patch with command "'${lib.escapeShellArg decode}'"' >&2 - echo 'Fetched file was (limited to 128 bytes):' >&2 - od -A x -t x1z -v -N 128 "$out" >&2 - exit 1 - fi - set -e - mv "$tmpfile" "$out" + set +e + ${decode} < "$out" > "$tmpfile" + if [ $? -ne 0 ] || [ ! -s "$tmpfile" ]; then + echo 'Failed to decode patch with command "'${lib.escapeShellArg decode}'"' >&2 + echo 'Fetched file was (limited to 128 bytes):' >&2 + od -A x -t x1z -v -N 128 "$out" >&2 + exit 1 + fi + set -e + mv "$tmpfile" "$out" - lsdiff \ - ${lib.optionalString (relative != null) "-p1 -i ${lib.escapeShellArg relative}/'*'"} \ - "$out" \ - | sort -u | sed -e 's/[*?]/\\&/g' \ - | xargs -I{} \ - filterdiff \ - --include={} \ - --strip=${toString stripLen} \ - ${lib.optionalString (extraPrefix != null) '' - --addoldprefix=a/${lib.escapeShellArg extraPrefix} \ - --addnewprefix=b/${lib.escapeShellArg extraPrefix} \ - ''} \ - --clean "$out" > "$tmpfile" + lsdiff \ + ${lib.optionalString (relative != null) "-p1 -i ${lib.escapeShellArg relative}/'*'"} \ + "$out" \ + | sort -u | sed -e 's/[*?]/\\&/g' \ + | xargs -I{} \ + filterdiff \ + --include={} \ + --strip=${toString stripLen} \ + ${ + lib.optionalString (extraPrefix != null) '' + --addoldprefix=a/${lib.escapeShellArg extraPrefix} \ + --addnewprefix=b/${lib.escapeShellArg extraPrefix} \ + '' + } \ + --clean "$out" > "$tmpfile" - if [ ! -s "$tmpfile" ]; then - echo "error: Normalized patch '$tmpfile' is empty (while the fetched file was not)!" 1>&2 - echo "Did you maybe fetch a HTML representation of a patch instead of a raw patch?" 1>&2 - echo "Fetched file was:" 1>&2 - cat "$out" 1>&2 - exit 1 - fi + if [ ! -s "$tmpfile" ]; then + echo "error: Normalized patch '$tmpfile' is empty (while the fetched file was not)!" 1>&2 + echo "Did you maybe fetch a HTML representation of a patch instead of a raw patch?" 1>&2 + echo "Fetched file was:" 1>&2 + cat "$out" 1>&2 + exit 1 + fi - filterdiff \ - -p1 \ - ${builtins.toString (builtins.map (x: "-x ${lib.escapeShellArg x}") excludes)} \ - ${builtins.toString (builtins.map (x: "-i ${lib.escapeShellArg x}") includes)} \ - "$tmpfile" > "$out" + filterdiff \ + -p1 \ + ${builtins.toString (builtins.map (x: "-x ${lib.escapeShellArg x}") excludes)} \ + ${builtins.toString (builtins.map (x: "-i ${lib.escapeShellArg x}") includes)} \ + "$tmpfile" > "$out" - if [ ! -s "$out" ]; then - echo "error: Filtered patch '$out' is empty (while the original patch file was not)!" 1>&2 - echo "Check your includes and excludes." 1>&2 - echo "Normalized patch file was:" 1>&2 - cat "$tmpfile" 1>&2 - exit 1 - fi - '' + lib.optionalString revert '' - interdiff "$out" /dev/null > "$tmpfile" - mv "$tmpfile" "$out" - '' + postFetch; -} // builtins.removeAttrs args [ - "relative" "stripLen" "decode" "extraPrefix" "excludes" "includes" "revert" - "postFetch" "nativeBuildInputs" -]) + if [ ! -s "$out" ]; then + echo "error: Filtered patch '$out' is empty (while the original patch file was not)!" 1>&2 + echo "Check your includes and excludes." 1>&2 + echo "Normalized patch file was:" 1>&2 + cat "$tmpfile" 1>&2 + exit 1 + fi + '' + + lib.optionalString revert '' + interdiff "$out" /dev/null > "$tmpfile" + mv "$tmpfile" "$out" + '' + + postFetch; + } + // builtins.removeAttrs args [ + "relative" + "stripLen" + "decode" + "extraPrefix" + "excludes" + "includes" + "revert" + "postFetch" + "nativeBuildInputs" + ] + ) diff --git a/pkgs/build-support/fetchpatch/tests.nix b/pkgs/build-support/fetchpatch/tests.nix index b7352fff7f9254..82482a8205924d 100644 --- a/pkgs/build-support/fetchpatch/tests.nix +++ b/pkgs/build-support/fetchpatch/tests.nix @@ -7,13 +7,21 @@ in { simple = testers.invalidateFetcherByDrvHash fetchpatch { url = "https://github.com/facebook/zstd/pull/2724/commits/e1f85dbca3a0ed5ef06c8396912a0914db8dea6a.patch"; - sha256 = if isFetchpatch2 then "sha256-w4yU0wt64d0WkuBQPeGf8vn5TH6qSBJvNIgka9QK+/Q=" else "sha256-PuYAqnJWAE+L9bsroOnnBGJhERW8LHrGSLtIEkKU9vg="; + sha256 = + if isFetchpatch2 then + "sha256-w4yU0wt64d0WkuBQPeGf8vn5TH6qSBJvNIgka9QK+/Q=" + else + "sha256-PuYAqnJWAE+L9bsroOnnBGJhERW8LHrGSLtIEkKU9vg="; }; relative = testers.invalidateFetcherByDrvHash fetchpatch { url = "https://github.com/boostorg/math/commit/7d482f6ebc356e6ec455ccb5f51a23971bf6ce5b.patch"; relative = "include"; - sha256 = if isFetchpatch2 then "sha256-1TtmuKeNIl/Yp+sfzBMR8Ue78tPIgjqGgjasa5IN52o=" else "sha256-KlmIbixcds6GyKYt1fx5BxDIrU7msrgDdYo9Va/KJR4="; + sha256 = + if isFetchpatch2 then + "sha256-1TtmuKeNIl/Yp+sfzBMR8Ue78tPIgjqGgjasa5IN52o=" + else + "sha256-KlmIbixcds6GyKYt1fx5BxDIrU7msrgDdYo9Va/KJR4="; }; full = testers.invalidateFetcherByDrvHash fetchpatch { @@ -23,13 +31,21 @@ in extraPrefix = "foo/bar/"; excludes = [ "foo/bar/bernoulli_no_atomic_mp.cpp" ]; revert = true; - sha256 = if isFetchpatch2 then "sha256-+UKmEbr2rIAweCav/hR/7d4ZrYV84ht/domTrHtm8sM=" else "sha256-+UKmEbr2rIAweCav/hR/7d4ZrYV84ht/domTrHtm8sM="; + sha256 = + if isFetchpatch2 then + "sha256-+UKmEbr2rIAweCav/hR/7d4ZrYV84ht/domTrHtm8sM=" + else + "sha256-+UKmEbr2rIAweCav/hR/7d4ZrYV84ht/domTrHtm8sM="; }; decode = testers.invalidateFetcherByDrvHash fetchpatch { name = "gcc.patch"; url = "https://chromium.googlesource.com/aosp/platform/external/libchrome/+/f37ae3b1a873d74182a2ac31d96742ead9c1f523^!?format=TEXT"; decode = "base64 -d"; - sha256 = if isFetchpatch2 then "sha256-oMvPlmzE51ArI+EvFxONXkqmNee39106/O1ikG0Bdso=" else "sha256-SJHk8XrutqAyoIdORlhCpBCN626P+uzed7mjKz5eQYY="; + sha256 = + if isFetchpatch2 then + "sha256-oMvPlmzE51ArI+EvFxONXkqmNee39106/O1ikG0Bdso=" + else + "sha256-SJHk8XrutqAyoIdORlhCpBCN626P+uzed7mjKz5eQYY="; }; } diff --git a/pkgs/build-support/fetchpijul/default.nix b/pkgs/build-support/fetchpijul/default.nix index 3aef7c035e729d..3f056b26c6b77f 100644 --- a/pkgs/build-support/fetchpijul/default.nix +++ b/pkgs/build-support/fetchpijul/default.nix @@ -1,59 +1,70 @@ -{ lib, stdenvNoCC, pijul, cacert }: +{ + lib, + stdenvNoCC, + pijul, + cacert, +}: lib.makeOverridable ( -{ url -, hash ? "" -, change ? null -, state ? null -, channel ? "main" -, name ? "fetchpijul" -, # TODO: Changes in pijul are unordered so there's many ways to end up with the same repository state. + { + url, + hash ? "", + change ? null, + state ? null, + channel ? "main", + name ? "fetchpijul", + # TODO: Changes in pijul are unordered so there's many ways to end up with the same repository state. # This makes leaveDotPijul unfeasible to implement until pijul CLI implements # a way of reordering changes to sort them in a consistent and deterministic manner. # leaveDotPijul ? false -}: -if change != null && state != null then - throw "Only one of 'change' or 'state' can be set" -else - stdenvNoCC.mkDerivation { - inherit name; - nativeBuildInputs = [ pijul cacert ]; - strictDeps = true; - - dontUnpack = true; - dontConfigure = true; - dontBuild = true; - - installPhase = '' - runHook preInstall - - pijul clone \ - ''${change:+--change "$change"} \ - ''${state:+--state "$state"} \ - --channel "$channel" \ - "$url" \ - "$out" - - runHook postInstall - ''; - - fixupPhase = '' - runHook preFixup - - rm -rf "$out/.pijul" - - runHook postFixup - ''; - - outputHashAlgo = null; - outputHashMode = "recursive"; - outputHash = if hash != "" then - hash - else - lib.fakeHash; - - inherit url change state channel; - - impureEnvVars = lib.fetchers.proxyImpureEnvVars; - } + }: + if change != null && state != null then + throw "Only one of 'change' or 'state' can be set" + else + stdenvNoCC.mkDerivation { + inherit name; + nativeBuildInputs = [ + pijul + cacert + ]; + strictDeps = true; + + dontUnpack = true; + dontConfigure = true; + dontBuild = true; + + installPhase = '' + runHook preInstall + + pijul clone \ + ''${change:+--change "$change"} \ + ''${state:+--state "$state"} \ + --channel "$channel" \ + "$url" \ + "$out" + + runHook postInstall + ''; + + fixupPhase = '' + runHook preFixup + + rm -rf "$out/.pijul" + + runHook postFixup + ''; + + outputHashAlgo = null; + outputHashMode = "recursive"; + outputHash = if hash != "" then hash else lib.fakeHash; + + inherit + url + change + state + channel + ; + + impureEnvVars = lib.fetchers.proxyImpureEnvVars; + } ) diff --git a/pkgs/build-support/fetchrepoorcz/default.nix b/pkgs/build-support/fetchrepoorcz/default.nix index 3ac7cace0dcf70..bfa0ff4fa31aa0 100644 --- a/pkgs/build-support/fetchrepoorcz/default.nix +++ b/pkgs/build-support/fetchrepoorcz/default.nix @@ -1,10 +1,23 @@ { fetchzip }: # gitweb example, snapshot support is optional in gitweb -{ repo, rev, name ? "source" -, ... # For hash agility -}@args: fetchzip ({ - inherit name; - url = "https://repo.or.cz/${repo}.git/snapshot/${rev}.tar.gz"; - meta.homepage = "https://repo.or.cz/${repo}.git/"; -} // removeAttrs args [ "repo" "rev" ]) // { inherit rev; } +{ + repo, + rev, + name ? "source", + ... # For hash agility +}@args: +fetchzip ( + { + inherit name; + url = "https://repo.or.cz/${repo}.git/snapshot/${rev}.tar.gz"; + meta.homepage = "https://repo.or.cz/${repo}.git/"; + } + // removeAttrs args [ + "repo" + "rev" + ] +) +// { + inherit rev; +} diff --git a/pkgs/build-support/fetchrepoproject/default.nix b/pkgs/build-support/fetchrepoproject/default.nix index 354913574b0f2c..fb9ac85884645d 100644 --- a/pkgs/build-support/fetchrepoproject/default.nix +++ b/pkgs/build-support/fetchrepoproject/default.nix @@ -1,9 +1,25 @@ -{ lib, stdenvNoCC, gitRepo, cacert, copyPathsToStore }: +{ + lib, + stdenvNoCC, + gitRepo, + cacert, + copyPathsToStore, +}: lib.fetchers.withNormalizedHash { } ( - { name, manifest, rev ? "HEAD", outputHash, outputHashAlgo - # Optional parameters: - , repoRepoURL ? "", repoRepoRev ? "", referenceDir ? "", manifestName ? "" - , localManifests ? [], createMirror ? false, useArchive ? false + { + name, + manifest, + rev ? "HEAD", + outputHash, + outputHashAlgo, + # Optional parameters: + repoRepoURL ? "", + repoRepoRev ? "", + referenceDir ? "", + manifestName ? "", + localManifests ? [ ], + createMirror ? false, + useArchive ? false, }: assert repoRepoRev != "" -> repoRepoURL != ""; @@ -34,10 +50,18 @@ lib.fetchers.withNormalizedHash { } ( local_manifests = copyPathsToStore localManifests; - in stdenvNoCC.mkDerivation { + in + stdenvNoCC.mkDerivation { inherit name; - inherit cacert manifest rev repoRepoURL repoRepoRev referenceDir; # TODO + inherit + cacert + manifest + rev + repoRepoURL + repoRepoRev + referenceDir + ; # TODO inherit outputHash outputHashAlgo; outputHashMode = "recursive"; @@ -46,10 +70,14 @@ lib.fetchers.withNormalizedHash { } ( enableParallelBuilding = true; impureEnvVars = fetchers.proxyImpureEnvVars ++ [ - "GIT_PROXY_COMMAND" "SOCKS_SERVER" + "GIT_PROXY_COMMAND" + "SOCKS_SERVER" ]; - nativeBuildInputs = [ gitRepo cacert ]; + nativeBuildInputs = [ + gitRepo + cacert + ]; GIT_SSL_CAINFO = "${cacert}/etc/ssl/certs/ca-bundle.crt"; @@ -61,7 +89,7 @@ lib.fetchers.withNormalizedHash { } ( cd $out mkdir .repo - ${optionalString (local_manifests != []) '' + ${optionalString (local_manifests != [ ]) '' mkdir .repo/local_manifests for local_manifest in ${concatMapStringsSep " " toString local_manifests}; do cp $local_manifest .repo/local_manifests/$(stripHash $local_manifest) diff --git a/pkgs/build-support/fetchs3/default.nix b/pkgs/build-support/fetchs3/default.nix index 1dd6945a5cb550..4935806ece1893 100644 --- a/pkgs/build-support/fetchs3/default.nix +++ b/pkgs/build-support/fetchs3/default.nix @@ -1,37 +1,59 @@ -{ lib, runCommand, awscli }: +{ + lib, + runCommand, + awscli, +}: lib.fetchers.withNormalizedHash { } ( - { s3url - , name ? builtins.baseNameOf s3url - , outputHash - , outputHashAlgo - , region ? "us-east-1" - , credentials ? null # Default to looking at local EC2 metadata service - , recursiveHash ? false - , postFetch ? null + { + s3url, + name ? builtins.baseNameOf s3url, + outputHash, + outputHashAlgo, + region ? "us-east-1", + credentials ? null, # Default to looking at local EC2 metadata service + recursiveHash ? false, + postFetch ? null, }: let - mkCredentials = { access_key_id, secret_access_key, session_token ? null }: { - AWS_ACCESS_KEY_ID = access_key_id; - AWS_SECRET_ACCESS_KEY = secret_access_key; - AWS_SESSION_TOKEN = session_token; - }; + mkCredentials = + { + access_key_id, + secret_access_key, + session_token ? null, + }: + { + AWS_ACCESS_KEY_ID = access_key_id; + AWS_SECRET_ACCESS_KEY = secret_access_key; + AWS_SESSION_TOKEN = session_token; + }; credentialAttrs = lib.optionalAttrs (credentials != null) (mkCredentials credentials); - in runCommand name ({ - nativeBuildInputs = [ awscli ]; + in + runCommand name + ( + { + nativeBuildInputs = [ awscli ]; - inherit outputHash outputHashAlgo; - outputHashMode = if recursiveHash then "recursive" else "flat"; + inherit outputHash outputHashAlgo; + outputHashMode = if recursiveHash then "recursive" else "flat"; - preferLocalBuild = true; + preferLocalBuild = true; - AWS_DEFAULT_REGION = region; - } // credentialAttrs) (if postFetch != null then '' - downloadedFile="$(mktemp)" - aws s3 cp ${s3url} $downloadedFile - ${postFetch} - '' else '' - aws s3 cp ${s3url} $out - '') + AWS_DEFAULT_REGION = region; + } + // credentialAttrs + ) + ( + if postFetch != null then + '' + downloadedFile="$(mktemp)" + aws s3 cp ${s3url} $downloadedFile + ${postFetch} + '' + else + '' + aws s3 cp ${s3url} $out + '' + ) ) diff --git a/pkgs/build-support/fetchsavannah/default.nix b/pkgs/build-support/fetchsavannah/default.nix index 0849323d582cfb..4e1080d2a1088a 100644 --- a/pkgs/build-support/fetchsavannah/default.nix +++ b/pkgs/build-support/fetchsavannah/default.nix @@ -1,13 +1,26 @@ { fetchzip, lib }: lib.makeOverridable ( -# cgit example, snapshot support is optional in cgit -{ repo, rev, name ? "source" -, ... # For hash agility -}@args: fetchzip ({ - inherit name; - url = "https://git.savannah.gnu.org/cgit/${repo}.git/snapshot/${repo}-${rev}.tar.gz"; - meta.homepage = "https://git.savannah.gnu.org/cgit/${repo}.git/"; - passthru.gitRepoUrl = "https://git.savannah.gnu.org/git/${repo}.git"; -} // removeAttrs args [ "repo" "rev" ]) // { inherit rev; } + # cgit example, snapshot support is optional in cgit + { + repo, + rev, + name ? "source", + ... # For hash agility + }@args: + fetchzip ( + { + inherit name; + url = "https://git.savannah.gnu.org/cgit/${repo}.git/snapshot/${repo}-${rev}.tar.gz"; + meta.homepage = "https://git.savannah.gnu.org/cgit/${repo}.git/"; + passthru.gitRepoUrl = "https://git.savannah.gnu.org/git/${repo}.git"; + } + // removeAttrs args [ + "repo" + "rev" + ] + ) + // { + inherit rev; + } ) diff --git a/pkgs/build-support/fetchsourcehut/default.nix b/pkgs/build-support/fetchsourcehut/default.nix index 42d437b3555e6a..a8f645c351b3c9 100644 --- a/pkgs/build-support/fetchsourcehut/default.nix +++ b/pkgs/build-support/fetchsourcehut/default.nix @@ -1,4 +1,9 @@ -{ fetchgit, fetchhg, fetchzip, lib }: +{ + fetchgit, + fetchhg, + fetchzip, + lib, +}: let inherit (lib) @@ -9,54 +14,75 @@ let in makeOverridable ( -{ owner -, repo, rev -, domain ? "sr.ht" -, vc ? "git" -, name ? "source" -, fetchSubmodules ? false -, ... # For hash agility -} @ args: + { + owner, + repo, + rev, + domain ? "sr.ht", + vc ? "git", + name ? "source", + fetchSubmodules ? false, + ... # For hash agility + }@args: -assert (assertOneOf "vc" vc [ "hg" "git" ]); + assert ( + assertOneOf "vc" vc [ + "hg" + "git" + ] + ); -let - urlFor = resource: "https://${resource}.${domain}/${owner}/${repo}"; - baseUrl = urlFor vc; - baseArgs = { - inherit name; - } // removeAttrs args [ - "owner" "repo" "rev" "domain" "vc" "name" "fetchSubmodules" - ]; - vcArgs = baseArgs // { - inherit rev; - url = baseUrl; - }; - fetcher = if fetchSubmodules then vc else "zip"; - cases = { - git = { - fetch = fetchgit; - arguments = vcArgs // { fetchSubmodules = true; }; + let + urlFor = resource: "https://${resource}.${domain}/${owner}/${repo}"; + baseUrl = urlFor vc; + baseArgs = + { + inherit name; + } + // removeAttrs args [ + "owner" + "repo" + "rev" + "domain" + "vc" + "name" + "fetchSubmodules" + ]; + vcArgs = baseArgs // { + inherit rev; + url = baseUrl; }; - hg = { - fetch = fetchhg; - arguments = vcArgs // { fetchSubrepos = true; }; - }; - zip = { - fetch = fetchzip; - arguments = baseArgs // { - url = "${baseUrl}/archive/${rev}.tar.gz"; - postFetch = optionalString (vc == "hg") '' - rm -f "$out/.hg_archival.txt" - ''; # impure file; see #12002 - passthru = { - gitRepoUrl = urlFor "git"; + fetcher = if fetchSubmodules then vc else "zip"; + cases = { + git = { + fetch = fetchgit; + arguments = vcArgs // { + fetchSubmodules = true; + }; + }; + hg = { + fetch = fetchhg; + arguments = vcArgs // { + fetchSubrepos = true; + }; + }; + zip = { + fetch = fetchzip; + arguments = baseArgs // { + url = "${baseUrl}/archive/${rev}.tar.gz"; + postFetch = optionalString (vc == "hg") '' + rm -f "$out/.hg_archival.txt" + ''; # impure file; see #12002 + passthru = { + gitRepoUrl = urlFor "git"; + }; }; }; }; - }; -in cases.${fetcher}.fetch cases.${fetcher}.arguments // { - inherit rev; - meta.homepage = "${baseUrl}"; -} + in + cases.${fetcher}.fetch cases.${fetcher}.arguments + // { + inherit rev; + meta.homepage = "${baseUrl}"; + } ) diff --git a/pkgs/build-support/fetchsvn/default.nix b/pkgs/build-support/fetchsvn/default.nix index c180ec89969615..70df66af82ab8e 100644 --- a/pkgs/build-support/fetchsvn/default.nix +++ b/pkgs/build-support/fetchsvn/default.nix @@ -1,10 +1,23 @@ -{ lib, stdenvNoCC, buildPackages -, cacert, subversion, glibcLocales, sshSupport ? true, openssh ? null +{ + lib, + stdenvNoCC, + buildPackages, + cacert, + subversion, + glibcLocales, + sshSupport ? true, + openssh ? null, }: -{ url, rev ? "HEAD", sha256 ? "", hash ? "" -, ignoreExternals ? false, ignoreKeywords ? false, name ? null -, preferLocalBuild ? true +{ + url, + rev ? "HEAD", + sha256 ? "", + hash ? "", + ignoreExternals ? false, + ignoreKeywords ? false, + name ? null, + preferLocalBuild ? true, }: assert sshSupport -> openssh != null; @@ -17,17 +30,21 @@ let trd = l: lib.head (lib.tail (lib.tail l)); path_ = (p: if lib.head p == "" then lib.tail p else p) # ~ drop final slash if any - (lib.reverseList (lib.splitString "/" url)); + (lib.reverseList (lib.splitString "/" url)); path = [ (lib.removeSuffix "/" (lib.head path_)) ] ++ (lib.tail path_); in - # ../repo/trunk -> repo - if fst path == "trunk" then snd path - # ../repo/branches/branch -> repo-branch - else if snd path == "branches" then "${trd path}-${fst path}" - # ../repo/tags/tag -> repo-tag - else if snd path == "tags" then "${trd path}-${fst path}" - # ../repo (no trunk) -> repo - else fst path; + # ../repo/trunk -> repo + if fst path == "trunk" then + snd path + # ../repo/branches/branch -> repo-branch + else if snd path == "branches" then + "${trd path}-${fst path}" + # ../repo/tags/tag -> repo-tag + else if snd path == "tags" then + "${trd path}-${fst path}" + # ../repo (no trunk) -> repo + else + fst path; name_ = if name == null then "${repoName}-r${toString rev}" else name; in @@ -35,25 +52,34 @@ in if hash != "" && sha256 != "" then throw "Only one of sha256 or hash can be set" else -stdenvNoCC.mkDerivation { - name = name_; - builder = ./builder.sh; - nativeBuildInputs = [ cacert subversion glibcLocales ] - ++ lib.optional sshSupport openssh; - - SVN_SSH = if sshSupport then "${buildPackages.openssh}/bin/ssh" else null; - - outputHashAlgo = if hash != "" then null else "sha256"; - outputHashMode = "recursive"; - outputHash = if hash != "" then - hash - else if sha256 != "" then - sha256 - else - lib.fakeSha256; - - inherit url rev ignoreExternals ignoreKeywords; - - impureEnvVars = lib.fetchers.proxyImpureEnvVars; - inherit preferLocalBuild; -} + stdenvNoCC.mkDerivation { + name = name_; + builder = ./builder.sh; + nativeBuildInputs = [ + cacert + subversion + glibcLocales + ] ++ lib.optional sshSupport openssh; + + SVN_SSH = if sshSupport then "${buildPackages.openssh}/bin/ssh" else null; + + outputHashAlgo = if hash != "" then null else "sha256"; + outputHashMode = "recursive"; + outputHash = + if hash != "" then + hash + else if sha256 != "" then + sha256 + else + lib.fakeSha256; + + inherit + url + rev + ignoreExternals + ignoreKeywords + ; + + impureEnvVars = lib.fetchers.proxyImpureEnvVars; + inherit preferLocalBuild; + } diff --git a/pkgs/build-support/fetchsvnrevision/default.nix b/pkgs/build-support/fetchsvnrevision/default.nix index f2e2a11da8d52e..c3987f3bbe77fd 100644 --- a/pkgs/build-support/fetchsvnrevision/default.nix +++ b/pkgs/build-support/fetchsvnrevision/default.nix @@ -1,10 +1,13 @@ runCommand: subversion: repository: - import (runCommand "head-revision" - { buildInputs = [ subversion ]; +import ( + runCommand "head-revision" + { + buildInputs = [ subversion ]; dummy = builtins.currentTime; } '' rev=$(echo p | svn ls -v --depth empty ${repository} |awk '{ print $1 }') echo "[ \"$rev\" ]" > $out echo Latest revision is $rev - '') + '' +) diff --git a/pkgs/build-support/fetchsvnssh/default.nix b/pkgs/build-support/fetchsvnssh/default.nix index e798044e2ea16d..a2d6fcef99c342 100644 --- a/pkgs/build-support/fetchsvnssh/default.nix +++ b/pkgs/build-support/fetchsvnssh/default.nix @@ -1,19 +1,41 @@ -{lib, stdenvNoCC, subversion, sshSupport ? true, openssh ? null, expect}: -{username, password -, url, rev ? "HEAD" -, outputHash ? lib.fakeHash, outputHashAlgo ? null}: +{ + lib, + stdenvNoCC, + subversion, + sshSupport ? true, + openssh ? null, + expect, +}: +{ + username, + password, + url, + rev ? "HEAD", + outputHash ? lib.fakeHash, + outputHashAlgo ? null, +}: lib.fetchers.withNormalizedHash { } ( stdenvNoCC.mkDerivation { name = "svn-export-ssh"; builder = ./builder.sh; - nativeBuildInputs = [subversion expect]; + nativeBuildInputs = [ + subversion + expect + ]; inherit outputHash outputHashAlgo; outputHashMode = "recursive"; sshSubversion = ./sshsubversion.exp; - inherit username password url rev sshSupport openssh; + inherit + username + password + url + rev + sshSupport + openssh + ; } ) diff --git a/pkgs/build-support/fetchtorrent/default.nix b/pkgs/build-support/fetchtorrent/default.nix index 041c1b9dcb394f..6e154a07650094 100644 --- a/pkgs/build-support/fetchtorrent/default.nix +++ b/pkgs/build-support/fetchtorrent/default.nix @@ -1,20 +1,34 @@ -{ lib, runCommand, transmission_3_noSystemd, rqbit, writeShellScript, formats, cacert, rsync }: +{ + lib, + runCommand, + transmission_3_noSystemd, + rqbit, + writeShellScript, + formats, + cacert, + rsync, +}: let urlRegexp = ''.*xt=urn:bt[im]h:([^&]{64}|[^&]{40}).*''; in -{ url -, name ? - if (builtins.match urlRegexp url) == null then - "bittorrent" - else - "bittorrent-" + builtins.head (builtins.match urlRegexp url) -, config ? if (backend == "transmission") then { } else throw "json config for configuring fetchFromBitorrent only works with the transmission backend" -, hash -, backend ? "transmission" -, recursiveHash ? true -, postFetch ? "" -, postUnpack ? "" -, meta ? {} +{ + url, + name ? + if (builtins.match urlRegexp url) == null then + "bittorrent" + else + "bittorrent-" + builtins.head (builtins.match urlRegexp url), + config ? + if (backend == "transmission") then + { } + else + throw "json config for configuring fetchFromBitorrent only works with the transmission backend", + hash, + backend ? "transmission", + recursiveHash ? true, + postFetch ? "", + postUnpack ? "", + meta ? { }, }: let afterSuccess = writeShellScript "fetch-bittorrent-done.sh" '' @@ -28,35 +42,49 @@ let ${postFetch} kill $PPID ''; - jsonConfig = (formats.json {}).generate "jsonConfig" config; + jsonConfig = (formats.json { }).generate "jsonConfig" config; in -runCommand name { - inherit meta; - nativeBuildInputs = [ cacert ] ++ (if (backend == "transmission" ) then [ transmission_3_noSystemd ] else if (backend == "rqbit") then [ rqbit ] else throw "rqbit or transmission are the only available backends for fetchtorrent"); - outputHashAlgo = if hash != "" then null else "sha256"; - outputHash = hash; - outputHashMode = if recursiveHash then "recursive" else "flat"; +runCommand name + { + inherit meta; + nativeBuildInputs = + [ cacert ] + ++ ( + if (backend == "transmission") then + [ transmission_3_noSystemd ] + else if (backend == "rqbit") then + [ rqbit ] + else + throw "rqbit or transmission are the only available backends for fetchtorrent" + ); + outputHashAlgo = if hash != "" then null else "sha256"; + outputHash = hash; + outputHashMode = if recursiveHash then "recursive" else "flat"; - # url will be written to the derivation, meaning it can be parsed and utilized - # by external tools, such as tools that may want to seed fetchtorrent calls - # in nixpkgs - inherit url; -} -(if (backend == "transmission") then '' - export HOME=$TMP - export downloadedDirectory=$out/downloadedDirectory - mkdir -p $downloadedDirectory - mkdir -p $HOME/.config/transmission - cp ${jsonConfig} $HOME/.config/transmission/settings.json - function handleChild { - # This detects failures and logs the contents of the transmission fetch - find $out - exit 0 + # url will be written to the derivation, meaning it can be parsed and utilized + # by external tools, such as tools that may want to seed fetchtorrent calls + # in nixpkgs + inherit url; } - trap handleChild CHLD - transmission-cli --port $(shuf -n 1 -i 49152-65535) --portmap --finish ${afterSuccess} --download-dir $downloadedDirectory --config-dir "$HOME"/.config/transmission "$url" -'' else -'' - export HOME=$TMP - rqbit --disable-dht-persistence --http-api-listen-addr "127.0.0.1:$(shuf -n 1 -i 49152-65535)" download -o $out --exit-on-finish "$url" -'') + ( + if (backend == "transmission") then + '' + export HOME=$TMP + export downloadedDirectory=$out/downloadedDirectory + mkdir -p $downloadedDirectory + mkdir -p $HOME/.config/transmission + cp ${jsonConfig} $HOME/.config/transmission/settings.json + function handleChild { + # This detects failures and logs the contents of the transmission fetch + find $out + exit 0 + } + trap handleChild CHLD + transmission-cli --port $(shuf -n 1 -i 49152-65535) --portmap --finish ${afterSuccess} --download-dir $downloadedDirectory --config-dir "$HOME"/.config/transmission "$url" + '' + else + '' + export HOME=$TMP + rqbit --disable-dht-persistence --http-api-listen-addr "127.0.0.1:$(shuf -n 1 -i 49152-65535)" download -o $out --exit-on-finish "$url" + '' + ) diff --git a/pkgs/build-support/fetchzip/default.nix b/pkgs/build-support/fetchzip/default.nix index dd04ccb6e0931c..dfd6321925864e 100644 --- a/pkgs/build-support/fetchzip/default.nix +++ b/pkgs/build-support/fetchzip/default.nix @@ -5,73 +5,105 @@ # (e.g. due to minor changes in the compression algorithm, or changes # in timestamps). -{ lib, fetchurl, withUnzip ? true, unzip, glibcLocalesUtf8 }: +{ + lib, + fetchurl, + withUnzip ? true, + unzip, + glibcLocalesUtf8, +}: -{ name ? "source" -, url ? "" -, urls ? [] -, nativeBuildInputs ? [] -, postFetch ? "" -, extraPostFetch ? "" +{ + name ? "source", + url ? "", + urls ? [ ], + nativeBuildInputs ? [ ], + postFetch ? "", + extraPostFetch ? "", -# Optionally move the contents of the unpacked tree up one level. -, stripRoot ? true -# Allows to set the extension for the intermediate downloaded -# file. This can be used as a hint for the unpackCmdHooks to select -# an appropriate unpacking tool. -, extension ? null + # Optionally move the contents of the unpacked tree up one level. + stripRoot ? true, + # Allows to set the extension for the intermediate downloaded + # file. This can be used as a hint for the unpackCmdHooks to select + # an appropriate unpacking tool. + extension ? null, -# the rest are given to fetchurl as is -, ... } @ args: + # the rest are given to fetchurl as is + ... +}@args: -assert (extraPostFetch != "") -> lib.warn "use 'postFetch' instead of 'extraPostFetch' with 'fetchzip' and 'fetchFromGitHub' or 'fetchFromGitLab'." true; +assert + (extraPostFetch != "") + -> lib.warn "use 'postFetch' instead of 'extraPostFetch' with 'fetchzip' and 'fetchFromGitHub' or 'fetchFromGitLab'." true; let tmpFilename = - if extension != null - then "download.${extension}" - else baseNameOf (if url != "" then url else builtins.head urls); + if extension != null then + "download.${extension}" + else + baseNameOf (if url != "" then url else builtins.head urls); in -fetchurl ({ - inherit name; - recursiveHash = true; +fetchurl ( + { + inherit name; + recursiveHash = true; - downloadToTemp = true; + downloadToTemp = true; - # Have to pull in glibcLocalesUtf8 for unzip in setup-hook.sh to handle - # UTF-8 aware locale: - # https://github.com/NixOS/nixpkgs/issues/176225#issuecomment-1146617263 - nativeBuildInputs = lib.optionals withUnzip [ unzip glibcLocalesUtf8 ] ++ nativeBuildInputs; + # Have to pull in glibcLocalesUtf8 for unzip in setup-hook.sh to handle + # UTF-8 aware locale: + # https://github.com/NixOS/nixpkgs/issues/176225#issuecomment-1146617263 + nativeBuildInputs = + lib.optionals withUnzip [ + unzip + glibcLocalesUtf8 + ] + ++ nativeBuildInputs; - postFetch = - '' - unpackDir="$TMPDIR/unpack" - mkdir "$unpackDir" - cd "$unpackDir" + postFetch = + '' + unpackDir="$TMPDIR/unpack" + mkdir "$unpackDir" + cd "$unpackDir" - renamed="$TMPDIR/${tmpFilename}" - mv "$downloadedFile" "$renamed" - unpackFile "$renamed" - chmod -R +w "$unpackDir" - '' + (if stripRoot then '' - if [ $(ls -A "$unpackDir" | wc -l) != 1 ]; then - echo "error: zip file must contain a single file or directory." - echo "hint: Pass stripRoot=false; to fetchzip to assume flat list of files." - exit 1 - fi - fn=$(cd "$unpackDir" && ls -A) - if [ -f "$unpackDir/$fn" ]; then - mkdir $out - fi - mv "$unpackDir/$fn" "$out" - '' else '' - mv "$unpackDir" "$out" - '') + '' - ${postFetch} - ${extraPostFetch} - chmod 755 "$out" - ''; + renamed="$TMPDIR/${tmpFilename}" + mv "$downloadedFile" "$renamed" + unpackFile "$renamed" + chmod -R +w "$unpackDir" + '' + + ( + if stripRoot then + '' + if [ $(ls -A "$unpackDir" | wc -l) != 1 ]; then + echo "error: zip file must contain a single file or directory." + echo "hint: Pass stripRoot=false; to fetchzip to assume flat list of files." + exit 1 + fi + fn=$(cd "$unpackDir" && ls -A) + if [ -f "$unpackDir/$fn" ]; then + mkdir $out + fi + mv "$unpackDir/$fn" "$out" + '' + else + '' + mv "$unpackDir" "$out" + '' + ) + + '' + ${postFetch} + ${extraPostFetch} + chmod 755 "$out" + ''; # ^ Remove non-owner write permissions # Fixes https://github.com/NixOS/nixpkgs/issues/38649 -} // removeAttrs args [ "stripRoot" "extraPostFetch" "postFetch" "extension" "nativeBuildInputs" ]) + } + // removeAttrs args [ + "stripRoot" + "extraPostFetch" + "postFetch" + "extension" + "nativeBuildInputs" + ] +) diff --git a/pkgs/build-support/fetchzip/tests.nix b/pkgs/build-support/fetchzip/tests.nix index 13175d5ce921e4..66227f0ce6bfb5 100644 --- a/pkgs/build-support/fetchzip/tests.nix +++ b/pkgs/build-support/fetchzip/tests.nix @@ -1,4 +1,9 @@ -{ testers, fetchzip, runCommand, ... }: +{ + testers, + fetchzip, + runCommand, + ... +}: let url = "https://gist.github.com/glandium/01d54cefdb70561b5f6675e08f2990f2/archive/2f430f0c136a69b0886281d0c76708997d8878af.zip"; @@ -16,10 +21,12 @@ in }; hiddenDir = testers.invalidateFetcherByDrvHash fetchzip { - url = "file://${runCommand "hiddendir.tar" {} '' - mkdir .foo - tar -cf $out .foo - ''}"; + url = "file://${ + runCommand "hiddendir.tar" { } '' + mkdir .foo + tar -cf $out .foo + '' + }"; sha256 = "sha256-pQpattmS9VmO3ZIQUFn66az8GSmB4IvYhTTCFn6SUmo="; }; } diff --git a/pkgs/build-support/kernel/compress-firmware.nix b/pkgs/build-support/kernel/compress-firmware.nix index 0949036d5127fb..16d209aed26e8f 100644 --- a/pkgs/build-support/kernel/compress-firmware.nix +++ b/pkgs/build-support/kernel/compress-firmware.nix @@ -1,23 +1,30 @@ -{ runCommand, lib, type ? "zstd", zstd }: +{ + runCommand, + lib, + type ? "zstd", + zstd, +}: firmware: let - compressor = { - xz = { - ext = "xz"; - nativeBuildInputs = [ ]; - cmd = file: target: ''xz -9c -T1 -C crc32 --lzma2=dict=2MiB "${file}" > "${target}"''; - }; - zstd = { - ext = "zst"; - nativeBuildInputs = [ zstd ]; - cmd = file: target: ''zstd -T1 -19 --long --check -f "${file}" -o "${target}"''; - }; - }.${type} or (throw "Unsupported compressor type for firmware."); + compressor = + { + xz = { + ext = "xz"; + nativeBuildInputs = [ ]; + cmd = file: target: ''xz -9c -T1 -C crc32 --lzma2=dict=2MiB "${file}" > "${target}"''; + }; + zstd = { + ext = "zst"; + nativeBuildInputs = [ zstd ]; + cmd = file: target: ''zstd -T1 -19 --long --check -f "${file}" -o "${target}"''; + }; + } + .${type} or (throw "Unsupported compressor type for firmware."); args = { - allowedRequisites = []; + allowedRequisites = [ ]; inherit (compressor) nativeBuildInputs; } // lib.optionalAttrs (firmware ? meta) { inherit (firmware) meta; }; in diff --git a/pkgs/build-support/kernel/initrd-compressor-meta.nix b/pkgs/build-support/kernel/initrd-compressor-meta.nix index 443e599a239e55..52e009967b5018 100644 --- a/pkgs/build-support/kernel/initrd-compressor-meta.nix +++ b/pkgs/build-support/kernel/initrd-compressor-meta.nix @@ -6,7 +6,7 @@ rec { }; gzip = { executable = pkgs: "${pkgs.gzip}/bin/gzip"; - defaultArgs = ["-9n"]; + defaultArgs = [ "-9n" ]; ubootName = "gzip"; extension = ".gz"; }; @@ -17,18 +17,24 @@ rec { }; xz = { executable = pkgs: "${pkgs.xz}/bin/xz"; - defaultArgs = ["--check=crc32" "--lzma2=dict=512KiB"]; + defaultArgs = [ + "--check=crc32" + "--lzma2=dict=512KiB" + ]; extension = ".xz"; }; lzma = { executable = pkgs: "${pkgs.xz}/bin/lzma"; - defaultArgs = ["--check=crc32" "--lzma1=dict=512KiB"]; + defaultArgs = [ + "--check=crc32" + "--lzma1=dict=512KiB" + ]; ubootName = "lzma"; extension = ".lzma"; }; lz4 = { executable = pkgs: "${pkgs.lz4}/bin/lz4"; - defaultArgs = ["-l"]; + defaultArgs = [ "-l" ]; ubootName = "lz4"; extension = ".lz4"; }; @@ -39,7 +45,7 @@ rec { }; zstd = { executable = pkgs: "${pkgs.zstd}/bin/zstd"; - defaultArgs = ["-10"]; + defaultArgs = [ "-10" ]; ubootName = "zstd"; extension = ".zst"; }; @@ -48,6 +54,6 @@ rec { }; pixz = xz // { executable = pkgs: "${pkgs.pixz}/bin/pixz"; - defaultArgs = []; + defaultArgs = [ ]; }; } diff --git a/pkgs/build-support/kernel/make-initrd-ng-tool.nix b/pkgs/build-support/kernel/make-initrd-ng-tool.nix index 7ffa0bf6813a56..9097728fe7a963 100644 --- a/pkgs/build-support/kernel/make-initrd-ng-tool.nix +++ b/pkgs/build-support/kernel/make-initrd-ng-tool.nix @@ -1,4 +1,11 @@ -{ rustPlatform, lib, makeWrapper, patchelf, glibc, binutils }: +{ + rustPlatform, + lib, + makeWrapper, + patchelf, + glibc, + binutils, +}: rustPlatform.buildRustPackage { pname = "make-initrd-ng"; @@ -12,7 +19,11 @@ rustPlatform.buildRustPackage { meta = { description = "Tool for copying binaries and their dependencies"; mainProgram = "make-initrd-ng"; - maintainers = with lib.maintainers; [ das_j elvishjerricco k900 ]; + maintainers = with lib.maintainers; [ + das_j + elvishjerricco + k900 + ]; license = lib.licenses.mit; }; } diff --git a/pkgs/build-support/kernel/make-initrd-ng.nix b/pkgs/build-support/kernel/make-initrd-ng.nix index a7542610a72dd4..4d2ad14a023b5f 100644 --- a/pkgs/build-support/kernel/make-initrd-ng.nix +++ b/pkgs/build-support/kernel/make-initrd-ng.nix @@ -8,90 +8,118 @@ let # compression type and filename extension. compressorName = fullCommand: builtins.elemAt (builtins.match "([^ ]*/)?([^ ]+).*" fullCommand) 1; in -{ stdenvNoCC, cpio, ubootTools, lib, pkgsBuildHost, makeInitrdNGTool, binutils, runCommand -# Name of the derivation (not of the resulting file!) -, name ? "initrd" +{ + stdenvNoCC, + cpio, + ubootTools, + lib, + pkgsBuildHost, + makeInitrdNGTool, + binutils, + runCommand, + # Name of the derivation (not of the resulting file!) + name ? "initrd", -, strip ? true + strip ? true, -# Program used to compress the cpio archive; use "cat" for no compression. -# This can also be a function which takes a package set and returns the path to the compressor, -# such as `pkgs: "${pkgs.lzop}/bin/lzop"`. -, compressor ? "gzip" -, _compressorFunction ? - if lib.isFunction compressor then compressor - else if ! builtins.hasContext compressor && builtins.hasAttr compressor compressors then compressors.${compressor}.executable - else _: compressor -, _compressorExecutable ? _compressorFunction pkgsBuildHost -, _compressorName ? compressorName _compressorExecutable -, _compressorMeta ? compressors.${_compressorName} or {} + # Program used to compress the cpio archive; use "cat" for no compression. + # This can also be a function which takes a package set and returns the path to the compressor, + # such as `pkgs: "${pkgs.lzop}/bin/lzop"`. + compressor ? "gzip", + _compressorFunction ? + if lib.isFunction compressor then + compressor + else if !builtins.hasContext compressor && builtins.hasAttr compressor compressors then + compressors.${compressor}.executable + else + _: compressor, + _compressorExecutable ? _compressorFunction pkgsBuildHost, + _compressorName ? compressorName _compressorExecutable, + _compressorMeta ? compressors.${_compressorName} or { }, -# List of arguments to pass to the compressor program, or null to use its defaults -, compressorArgs ? null -, _compressorArgsReal ? if compressorArgs == null then _compressorMeta.defaultArgs or [] else compressorArgs + # List of arguments to pass to the compressor program, or null to use its defaults + compressorArgs ? null, + _compressorArgsReal ? + if compressorArgs == null then _compressorMeta.defaultArgs or [ ] else compressorArgs, -# Filename extension to use for the compressed initramfs. This is -# included for clarity, but $out/initrd will always be a symlink to -# the final image. -# If this isn't guessed, you may want to complete the metadata above and send a PR :) -, extension ? _compressorMeta.extension or - (throw "Unrecognised compressor ${_compressorName}, please specify filename extension") + # Filename extension to use for the compressed initramfs. This is + # included for clarity, but $out/initrd will always be a symlink to + # the final image. + # If this isn't guessed, you may want to complete the metadata above and send a PR :) + extension ? + _compressorMeta.extension + or (throw "Unrecognised compressor ${_compressorName}, please specify filename extension"), -# List of { source = path_or_derivation; target = "/path"; } -# The paths are copied into the initramfs in their nix store path -# form, then linked at the root according to `target`. -, contents + # List of { source = path_or_derivation; target = "/path"; } + # The paths are copied into the initramfs in their nix store path + # form, then linked at the root according to `target`. + contents, -# List of uncompressed cpio files to prepend to the initramfs. This -# can be used to add files in specified paths without them becoming -# symlinks to store paths. -, prepend ? [] + # List of uncompressed cpio files to prepend to the initramfs. This + # can be used to add files in specified paths without them becoming + # symlinks to store paths. + prepend ? [ ], -# Whether to wrap the initramfs in a u-boot image. -, makeUInitrd ? stdenvNoCC.hostPlatform.linux-kernel.target == "uImage" + # Whether to wrap the initramfs in a u-boot image. + makeUInitrd ? stdenvNoCC.hostPlatform.linux-kernel.target == "uImage", -# If generating a u-boot image, the architecture to use. The default -# guess may not align with u-boot's nomenclature correctly, so it can -# be overridden. -# See https://gitlab.denx.de/u-boot/u-boot/-/blob/9bfb567e5f1bfe7de8eb41f8c6d00f49d2b9a426/common/image.c#L81-106 for a list. -, uInitrdArch ? stdenvNoCC.hostPlatform.ubootArch + # If generating a u-boot image, the architecture to use. The default + # guess may not align with u-boot's nomenclature correctly, so it can + # be overridden. + # See https://gitlab.denx.de/u-boot/u-boot/-/blob/9bfb567e5f1bfe7de8eb41f8c6d00f49d2b9a426/common/image.c#L81-106 for a list. + uInitrdArch ? stdenvNoCC.hostPlatform.ubootArch, -# The name of the compression, as recognised by u-boot. -# See https://gitlab.denx.de/u-boot/u-boot/-/blob/9bfb567e5f1bfe7de8eb41f8c6d00f49d2b9a426/common/image.c#L195-204 for a list. -# If this isn't guessed, you may want to complete the metadata above and send a PR :) -, uInitrdCompression ? _compressorMeta.ubootName or - (throw "Unrecognised compressor ${_compressorName}, please specify uInitrdCompression") -}: runCommand name ({ - compress = "${_compressorExecutable} ${lib.escapeShellArgs _compressorArgsReal}"; - passthru = { - compressorExecutableFunction = _compressorFunction; - compressorArgs = _compressorArgsReal; - }; + # The name of the compression, as recognised by u-boot. + # See https://gitlab.denx.de/u-boot/u-boot/-/blob/9bfb567e5f1bfe7de8eb41f8c6d00f49d2b9a426/common/image.c#L195-204 for a list. + # If this isn't guessed, you may want to complete the metadata above and send a PR :) + uInitrdCompression ? + _compressorMeta.ubootName + or (throw "Unrecognised compressor ${_compressorName}, please specify uInitrdCompression"), +}: +runCommand name + ({ + compress = "${_compressorExecutable} ${lib.escapeShellArgs _compressorArgsReal}"; + passthru = { + compressorExecutableFunction = _compressorFunction; + compressorArgs = _compressorArgsReal; + }; - inherit extension makeUInitrd uInitrdArch prepend; - ${if makeUInitrd then "uInitrdCompression" else null} = uInitrdCompression; + inherit + extension + makeUInitrd + uInitrdArch + prepend + ; + ${if makeUInitrd then "uInitrdCompression" else null} = uInitrdCompression; - passAsFile = ["contents"]; - contents = builtins.toJSON contents; + passAsFile = [ "contents" ]; + contents = builtins.toJSON contents; - nativeBuildInputs = [makeInitrdNGTool cpio] ++ lib.optional makeUInitrd ubootTools ++ lib.optional strip binutils; + nativeBuildInputs = + [ + makeInitrdNGTool + cpio + ] + ++ lib.optional makeUInitrd ubootTools + ++ lib.optional strip binutils; - STRIP = if strip then "${pkgsBuildHost.binutils.targetPrefix}strip" else null; -}) '' - mkdir -p ./root/var/empty - make-initrd-ng "$contentsPath" ./root - mkdir "$out" - (cd root && find . -exec touch -h -d '@1' '{}' +) - for PREP in $prepend; do - cat $PREP >> $out/initrd - done - (cd root && find . -print0 | sort -z | cpio --quiet -o -H newc -R +0:+0 --reproducible --null | eval -- $compress >> "$out/initrd") + STRIP = if strip then "${pkgsBuildHost.binutils.targetPrefix}strip" else null; + }) + '' + mkdir -p ./root/var/empty + make-initrd-ng "$contentsPath" ./root + mkdir "$out" + (cd root && find . -exec touch -h -d '@1' '{}' +) + for PREP in $prepend; do + cat $PREP >> $out/initrd + done + (cd root && find . -print0 | sort -z | cpio --quiet -o -H newc -R +0:+0 --reproducible --null | eval -- $compress >> "$out/initrd") - if [ -n "$makeUInitrd" ]; then - mkimage -A "$uInitrdArch" -O linux -T ramdisk -C "$uInitrdCompression" -d "$out/initrd" $out/initrd.img - # Compatibility symlink - ln -sf "initrd.img" "$out/initrd" - else - ln -s "initrd" "$out/initrd$extension" - fi -'' + if [ -n "$makeUInitrd" ]; then + mkimage -A "$uInitrdArch" -O linux -T ramdisk -C "$uInitrdCompression" -d "$out/initrd" $out/initrd.img + # Compatibility symlink + ln -sf "initrd.img" "$out/initrd" + else + ln -s "initrd" "$out/initrd$extension" + fi + '' diff --git a/pkgs/build-support/kernel/make-initrd.nix b/pkgs/build-support/kernel/make-initrd.nix index e996094d1f8a45..ef591a4d9aa54a 100644 --- a/pkgs/build-support/kernel/make-initrd.nix +++ b/pkgs/build-support/kernel/make-initrd.nix @@ -18,96 +18,119 @@ let # compression type and filename extension. compressorName = fullCommand: builtins.elemAt (builtins.match "([^ ]*/)?([^ ]+).*" fullCommand) 1; in -{ stdenvNoCC, perl, cpio, ubootTools, lib, pkgsBuildHost -# Name of the derivation (not of the resulting file!) -, name ? "initrd" +{ + stdenvNoCC, + perl, + cpio, + ubootTools, + lib, + pkgsBuildHost, + # Name of the derivation (not of the resulting file!) + name ? "initrd", -# Program used to compress the cpio archive; use "cat" for no compression. -# This can also be a function which takes a package set and returns the path to the compressor, -# such as `pkgs: "${pkgs.lzop}/bin/lzop"`. -, compressor ? "gzip" -, _compressorFunction ? - if lib.isFunction compressor then compressor - else if ! builtins.hasContext compressor && builtins.hasAttr compressor compressors then compressors.${compressor}.executable - else _: compressor -, _compressorExecutable ? _compressorFunction pkgsBuildHost -, _compressorName ? compressorName _compressorExecutable -, _compressorMeta ? compressors.${_compressorName} or {} + # Program used to compress the cpio archive; use "cat" for no compression. + # This can also be a function which takes a package set and returns the path to the compressor, + # such as `pkgs: "${pkgs.lzop}/bin/lzop"`. + compressor ? "gzip", + _compressorFunction ? + if lib.isFunction compressor then + compressor + else if !builtins.hasContext compressor && builtins.hasAttr compressor compressors then + compressors.${compressor}.executable + else + _: compressor, + _compressorExecutable ? _compressorFunction pkgsBuildHost, + _compressorName ? compressorName _compressorExecutable, + _compressorMeta ? compressors.${_compressorName} or { }, -# List of arguments to pass to the compressor program, or null to use its defaults -, compressorArgs ? null -, _compressorArgsReal ? if compressorArgs == null then _compressorMeta.defaultArgs or [] else compressorArgs + # List of arguments to pass to the compressor program, or null to use its defaults + compressorArgs ? null, + _compressorArgsReal ? + if compressorArgs == null then _compressorMeta.defaultArgs or [ ] else compressorArgs, -# Filename extension to use for the compressed initramfs. This is -# included for clarity, but $out/initrd will always be a symlink to -# the final image. -# If this isn't guessed, you may want to complete the metadata above and send a PR :) -, extension ? _compressorMeta.extension or - (throw "Unrecognised compressor ${_compressorName}, please specify filename extension") + # Filename extension to use for the compressed initramfs. This is + # included for clarity, but $out/initrd will always be a symlink to + # the final image. + # If this isn't guessed, you may want to complete the metadata above and send a PR :) + extension ? + _compressorMeta.extension + or (throw "Unrecognised compressor ${_compressorName}, please specify filename extension"), -# List of { object = path_or_derivation; symlink = "/path"; } -# The paths are copied into the initramfs in their nix store path -# form, then linked at the root according to `symlink`. -, contents + # List of { object = path_or_derivation; symlink = "/path"; } + # The paths are copied into the initramfs in their nix store path + # form, then linked at the root according to `symlink`. + contents, -# List of uncompressed cpio files to prepend to the initramfs. This -# can be used to add files in specified paths without them becoming -# symlinks to store paths. -, prepend ? [] + # List of uncompressed cpio files to prepend to the initramfs. This + # can be used to add files in specified paths without them becoming + # symlinks to store paths. + prepend ? [ ], -# Whether to wrap the initramfs in a u-boot image. -, makeUInitrd ? stdenvNoCC.hostPlatform.linux-kernel.target or "dummy" == "uImage" + # Whether to wrap the initramfs in a u-boot image. + makeUInitrd ? stdenvNoCC.hostPlatform.linux-kernel.target or "dummy" == "uImage", -# If generating a u-boot image, the architecture to use. The default -# guess may not align with u-boot's nomenclature correctly, so it can -# be overridden. -# See https://gitlab.denx.de/u-boot/u-boot/-/blob/9bfb567e5f1bfe7de8eb41f8c6d00f49d2b9a426/common/image.c#L81-106 for a list. -, uInitrdArch ? stdenvNoCC.hostPlatform.linuxArch + # If generating a u-boot image, the architecture to use. The default + # guess may not align with u-boot's nomenclature correctly, so it can + # be overridden. + # See https://gitlab.denx.de/u-boot/u-boot/-/blob/9bfb567e5f1bfe7de8eb41f8c6d00f49d2b9a426/common/image.c#L81-106 for a list. + uInitrdArch ? stdenvNoCC.hostPlatform.linuxArch, -# The name of the compression, as recognised by u-boot. -# See https://gitlab.denx.de/u-boot/u-boot/-/blob/9bfb567e5f1bfe7de8eb41f8c6d00f49d2b9a426/common/image.c#L195-204 for a list. -# If this isn't guessed, you may want to complete the metadata above and send a PR :) -, uInitrdCompression ? _compressorMeta.ubootName or - (throw "Unrecognised compressor ${_compressorName}, please specify uInitrdCompression") + # The name of the compression, as recognised by u-boot. + # See https://gitlab.denx.de/u-boot/u-boot/-/blob/9bfb567e5f1bfe7de8eb41f8c6d00f49d2b9a426/common/image.c#L195-204 for a list. + # If this isn't guessed, you may want to complete the metadata above and send a PR :) + uInitrdCompression ? + _compressorMeta.ubootName + or (throw "Unrecognised compressor ${_compressorName}, please specify uInitrdCompression"), }: let # !!! Move this into a public lib function, it is probably useful for others - toValidStoreName = x: with builtins; - lib.concatStringsSep "-" (filter (x: !(isList x)) (split "[^a-zA-Z0-9_=.?-]+" x)); + toValidStoreName = + x: with builtins; lib.concatStringsSep "-" (filter (x: !(isList x)) (split "[^a-zA-Z0-9_=.?-]+" x)); -in stdenvNoCC.mkDerivation (rec { - inherit name makeUInitrd extension uInitrdArch prepend; +in +stdenvNoCC.mkDerivation ( + rec { + inherit + name + makeUInitrd + extension + uInitrdArch + prepend + ; - builder = ./make-initrd.sh; + builder = ./make-initrd.sh; - nativeBuildInputs = [ perl cpio ] - ++ lib.optional makeUInitrd ubootTools; + nativeBuildInputs = [ + perl + cpio + ] ++ lib.optional makeUInitrd ubootTools; - compress = "${_compressorExecutable} ${lib.escapeShellArgs _compressorArgsReal}"; + compress = "${_compressorExecutable} ${lib.escapeShellArgs _compressorArgsReal}"; - # Pass the function through, for reuse in append-initrd-secrets. The - # function is used instead of the string, in order to support - # cross-compilation (append-initrd-secrets running on a different - # architecture than what the main initramfs is built on). - passthru = { - compressorExecutableFunction = _compressorFunction; - compressorArgs = _compressorArgsReal; - }; + # Pass the function through, for reuse in append-initrd-secrets. The + # function is used instead of the string, in order to support + # cross-compilation (append-initrd-secrets running on a different + # architecture than what the main initramfs is built on). + passthru = { + compressorExecutableFunction = _compressorFunction; + compressorArgs = _compressorArgsReal; + }; - # !!! should use XML. - objects = map (x: x.object) contents; - symlinks = map (x: x.symlink) contents; - suffices = map (x: if x ? suffix then x.suffix else "none") contents; + # !!! should use XML. + objects = map (x: x.object) contents; + symlinks = map (x: x.symlink) contents; + suffices = map (x: if x ? suffix then x.suffix else "none") contents; - # For obtaining the closure of `contents'. - # Note: we don't use closureInfo yet, as that won't build with nix-1.x. - # See #36268. - exportReferencesGraph = - lib.zipListsWith - (x: i: [("closure-${toValidStoreName (baseNameOf x.symlink)}-${toString i}") x.object]) - contents - (lib.range 0 (lib.length contents - 1)); - pathsFromGraph = ./paths-from-graph.pl; -} // lib.optionalAttrs makeUInitrd { - uInitrdCompression = uInitrdCompression; -}) + # For obtaining the closure of `contents'. + # Note: we don't use closureInfo yet, as that won't build with nix-1.x. + # See #36268. + exportReferencesGraph = lib.zipListsWith (x: i: [ + ("closure-${toValidStoreName (baseNameOf x.symlink)}-${toString i}") + x.object + ]) contents (lib.range 0 (lib.length contents - 1)); + pathsFromGraph = ./paths-from-graph.pl; + } + // lib.optionalAttrs makeUInitrd { + uInitrdCompression = uInitrdCompression; + } +) diff --git a/pkgs/build-support/kernel/modules-closure.nix b/pkgs/build-support/kernel/modules-closure.nix index d82e279799ba35..a830c97eea9a74 100644 --- a/pkgs/build-support/kernel/modules-closure.nix +++ b/pkgs/build-support/kernel/modules-closure.nix @@ -3,13 +3,28 @@ # the modules identified by `rootModules', plus their dependencies. # Also generate an appropriate modules.dep. -{ stdenvNoCC, kernel, firmware, nukeReferences, rootModules -, kmod, allowMissing ? false }: +{ + stdenvNoCC, + kernel, + firmware, + nukeReferences, + rootModules, + kmod, + allowMissing ? false, +}: stdenvNoCC.mkDerivation { name = kernel.name + "-shrunk"; builder = ./modules-closure.sh; - nativeBuildInputs = [ nukeReferences kmod ]; - inherit kernel firmware rootModules allowMissing; - allowedReferences = ["out"]; + nativeBuildInputs = [ + nukeReferences + kmod + ]; + inherit + kernel + firmware + rootModules + allowMissing + ; + allowedReferences = [ "out" ]; } diff --git a/pkgs/build-support/lib/meson.nix b/pkgs/build-support/lib/meson.nix index 9ffc5b8c1710f0..501d4315fdff5f 100644 --- a/pkgs/build-support/lib/meson.nix +++ b/pkgs/build-support/lib/meson.nix @@ -4,10 +4,15 @@ let inherit (lib) boolToString optionals; # See https://mesonbuild.com/Reference-tables.html#cpu-families - cpuFamily = platform: with platform; - /**/ if isAarch32 then "arm" - else if isx86_32 then "x86" - else platform.uname.processor; + cpuFamily = + platform: + with platform; + if isAarch32 then + "arm" + else if isx86_32 then + "x86" + else + platform.uname.processor; crossFile = builtins.toFile "cross-file.conf" '' [properties] @@ -29,9 +34,16 @@ let cmake = 'cmake' ''; - crossFlags = optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ "--cross-file=${crossFile}" ]; + crossFlags = optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "--cross-file=${crossFile}" + ]; - makeMesonFlags = { mesonFlags ? [], ... }: crossFlags ++ mesonFlags; + makeMesonFlags = + { + mesonFlags ? [ ], + ... + }: + crossFlags ++ mesonFlags; in { diff --git a/pkgs/build-support/make-darwin-bundle/default.nix b/pkgs/build-support/make-darwin-bundle/default.nix index a80ebf8fac9e6f..38999ea0646053 100644 --- a/pkgs/build-support/make-darwin-bundle/default.nix +++ b/pkgs/build-support/make-darwin-bundle/default.nix @@ -3,11 +3,16 @@ # applications. If the package conatins a .desktop file use # `desktopToDarwinLauncher` instead. -{ lib, writeShellScript, writeDarwinBundle }: +{ + lib, + writeShellScript, + writeDarwinBundle, +}: -{ name # The name of the Application file. -, exec # Executable file. -, icon ? "" # Optional icon file. +{ + name, # The name of the Application file. + exec, # Executable file. + icon ? "", # Optional icon file. }: writeShellScript "make-darwin-bundle-${name}" ('' diff --git a/pkgs/build-support/make-darwin-bundle/write-darwin-bundle.nix b/pkgs/build-support/make-darwin-bundle/write-darwin-bundle.nix index 752cbbde2a3171..9cf7ab277406ed 100644 --- a/pkgs/build-support/make-darwin-bundle/write-darwin-bundle.nix +++ b/pkgs/build-support/make-darwin-bundle/write-darwin-bundle.nix @@ -1,4 +1,8 @@ -{ writeScriptBin, lib, makeBinaryWrapper }: +{ + writeScriptBin, + lib, + makeBinaryWrapper, +}: let pListText = lib.generators.toPlist { } { @@ -12,36 +16,37 @@ let CFBundlePackageType = "APPL"; CFBundleSignature = "???"; }; -in writeScriptBin "write-darwin-bundle" '' - shopt -s nullglob +in +writeScriptBin "write-darwin-bundle" '' + shopt -s nullglob - readonly prefix=$1 - readonly name=$2 - # TODO: support executables with spaces in their names - readonly execName=''${3%% *} # Before the first space - [[ $3 =~ " " ]] && readonly execArgs=''${3#* } # Everything after the first space - readonly icon=$4.icns - readonly squircle=''${5:-1} - readonly plist=$prefix/Applications/$name.app/Contents/Info.plist - readonly binary=$prefix/bin/$execName - readonly bundleExecutable=$prefix/Applications/$name.app/Contents/MacOS/$name + readonly prefix=$1 + readonly name=$2 + # TODO: support executables with spaces in their names + readonly execName=''${3%% *} # Before the first space + [[ $3 =~ " " ]] && readonly execArgs=''${3#* } # Everything after the first space + readonly icon=$4.icns + readonly squircle=''${5:-1} + readonly plist=$prefix/Applications/$name.app/Contents/Info.plist + readonly binary=$prefix/bin/$execName + readonly bundleExecutable=$prefix/Applications/$name.app/Contents/MacOS/$name - cat > "$plist" < "$plist" <|d' -i "$plist" - fi + if [[ $squircle == 0 || $squircle == "false" ]]; then + sed '/CFBundleIconFiles/,\||d' -i "$plist" + fi - if [[ -n "$execArgs" ]]; then - ( - source ${makeBinaryWrapper}/nix-support/setup-hook - # WORKAROUND: makeBinaryWrapper fails when -u is set - set +u - makeBinaryWrapper "$binary" "$bundleExecutable" --add-flags "$execArgs" - ) - else - ln -s "$binary" "$bundleExecutable" - fi + if [[ -n "$execArgs" ]]; then + ( + source ${makeBinaryWrapper}/nix-support/setup-hook + # WORKAROUND: makeBinaryWrapper fails when -u is set + set +u + makeBinaryWrapper "$binary" "$bundleExecutable" --add-flags "$execArgs" + ) + else + ln -s "$binary" "$bundleExecutable" + fi '' diff --git a/pkgs/build-support/make-hardcode-gsettings-patch/default.nix b/pkgs/build-support/make-hardcode-gsettings-patch/default.nix index 820b003e3c6fa8..f3f78196878879 100644 --- a/pkgs/build-support/make-hardcode-gsettings-patch/default.nix +++ b/pkgs/build-support/make-hardcode-gsettings-patch/default.nix @@ -18,7 +18,6 @@ It will end up in the generated patch as `@EVOLUTION@` placeholder, which should be replaced at build time with a path to the directory containing a `gschemas.compiled` file that includes the schema. - Arguments: - `src`: source to generate the patch for. @@ -57,8 +56,7 @@ schemaIdToVariableMapping, }: -runCommand - "hardcode-gsettings.patch" +runCommand "hardcode-gsettings.patch" { inherit src patches; nativeBuildInputs = [ diff --git a/pkgs/build-support/make-impure-test.nix b/pkgs/build-support/make-impure-test.nix index 84d0b30f426a09..2ff1ed0bcc2d83 100644 --- a/pkgs/build-support/make-impure-test.nix +++ b/pkgs/build-support/make-impure-test.nix @@ -1,4 +1,5 @@ -/* Create tests that run in the nix sandbox with additional access to selected host paths +/* + Create tests that run in the nix sandbox with additional access to selected host paths This is for example useful for testing hardware where a tests needs access to /sys and optionally more. @@ -28,58 +29,62 @@ Rerun an already cached test: $(nix-build -A mypackage.impureTests) --check */ -{ lib -, stdenv -, writeShellScript - -, name -, testedPackage ? null -, testPath ? "${testedPackage}.impureTests.${name}.testDerivation" -, sandboxPaths ? [ "/sys" ] -, prepareRunCommands ? "" -, nixFlags ? [ ] -, testScript -, ... -} @ args: +{ + lib, + stdenv, + writeShellScript, + + name, + testedPackage ? null, + testPath ? "${testedPackage}.impureTests.${name}.testDerivation", + sandboxPaths ? [ "/sys" ], + prepareRunCommands ? "", + nixFlags ? [ ], + testScript, + ... +}@args: let sandboxPathsTests = builtins.map (path: "[[ ! -e '${path}' ]]") sandboxPaths; sandboxPathsTest = lib.concatStringsSep " || " sandboxPathsTests; sandboxPathsList = lib.concatStringsSep " " sandboxPaths; - testDerivation = stdenv.mkDerivation (lib.recursiveUpdate - { - name = "test-run-${name}"; - - requiredSystemFeatures = [ "nixos-test" ]; - - buildCommand = '' - mkdir -p $out - - if ${sandboxPathsTest}; then - echo 'Run this test as *root* with `--option extra-sandbox-paths '"'${sandboxPathsList}'"'`' - exit 1 - fi - - # Run test - ${testScript} - ''; - - passthru.runScript = runScript; - } - (builtins.removeAttrs args [ - "lib" - "stdenv" - "writeShellScript" - - "name" - "testedPackage" - "testPath" - "sandboxPaths" - "prepareRunCommands" - "nixFlags" - "testScript" - ]) + testDerivation = stdenv.mkDerivation ( + lib.recursiveUpdate + { + name = "test-run-${name}"; + + requiredSystemFeatures = [ "nixos-test" ]; + + buildCommand = '' + mkdir -p $out + + if ${sandboxPathsTest}; then + echo 'Run this test as *root* with `--option extra-sandbox-paths '"'${sandboxPathsList}'"'`' + exit 1 + fi + + # Run test + ${testScript} + ''; + + passthru.runScript = runScript; + } + ( + builtins.removeAttrs args [ + "lib" + "stdenv" + "writeShellScript" + + "name" + "testedPackage" + "testPath" + "sandboxPaths" + "prepareRunCommands" + "nixFlags" + "testScript" + ] + ) ); runScript = writeShellScript "run-script-${name}" '' diff --git a/pkgs/build-support/make-pkgconfigitem/default.nix b/pkgs/build-support/make-pkgconfigitem/default.nix index 52c1fd3af9792b..d78d1c022f9e0c 100644 --- a/pkgs/build-support/make-pkgconfigitem/default.nix +++ b/pkgs/build-support/make-pkgconfigitem/default.nix @@ -1,29 +1,36 @@ -{ lib, writeTextFile, buildPackages }: +{ + lib, + writeTextFile, + buildPackages, +}: # See https://people.freedesktop.org/~dbn/pkg-config-guide.html#concepts -{ name # The name of the pc file +{ + name, # The name of the pc file # keywords # provide a default description for convenience. it's not important but still required by pkg-config. -, description ? "Pkg-config file for ${name}" -, url ? "" -, version ? "" -, requires ? [ ] -, requiresPrivate ? [ ] -, conflicts ? [ ] -, cflags ? [ ] -, libs ? [ ] -, libsPrivate ? [ ] -, variables ? { } + description ? "Pkg-config file for ${name}", + url ? "", + version ? "", + requires ? [ ], + requiresPrivate ? [ ], + conflicts ? [ ], + cflags ? [ ], + libs ? [ ], + libsPrivate ? [ ], + variables ? { }, }: let # only 'out' has to be changed, otherwise it would be replaced by the out of the writeTextFile placeholderToSubstVar = builtins.replaceStrings [ "${placeholder "out"}" ] [ "@out@" ]; - replacePlaceholderAndListToString = x: - if builtins.isList x - then placeholderToSubstVar (builtins.concatStringsSep " " x) - else placeholderToSubstVar x; + replacePlaceholderAndListToString = + x: + if builtins.isList x then + placeholderToSubstVar (builtins.concatStringsSep " " x) + else + placeholderToSubstVar x; keywordsSection = let @@ -42,12 +49,19 @@ let "Libs.private" = mustBeAList libsPrivate "libsPrivate"; }; - renderVariable = name: value: - lib.optionalString (value != "" && value != [ ]) "${name}=${replacePlaceholderAndListToString value}"; - renderKeyword = name: value: - lib.optionalString (value != "" && value != [ ]) "${name}: ${replacePlaceholderAndListToString value}"; + renderVariable = + name: value: + lib.optionalString ( + value != "" && value != [ ] + ) "${name}=${replacePlaceholderAndListToString value}"; + renderKeyword = + name: value: + lib.optionalString ( + value != "" && value != [ ] + ) "${name}: ${replacePlaceholderAndListToString value}"; - renderSomething = renderFunc: attrs: + renderSomething = + renderFunc: attrs: lib.pipe attrs [ (lib.mapAttrsToList renderFunc) (builtins.filter (v: v != "")) @@ -57,7 +71,10 @@ let variablesSectionRendered = renderSomething renderVariable variables; keywordsSectionRendered = renderSomething renderKeyword keywordsSection; - content = [ variablesSectionRendered keywordsSectionRendered ]; + content = [ + variablesSectionRendered + keywordsSectionRendered + ]; in writeTextFile { name = "${name}.pc"; diff --git a/pkgs/build-support/make-startupitem/default.nix b/pkgs/build-support/make-startupitem/default.nix index 1cb7096c1cf2bb..03677355b8d689 100644 --- a/pkgs/build-support/make-startupitem/default.nix +++ b/pkgs/build-support/make-startupitem/default.nix @@ -1,15 +1,16 @@ # given a package with a $name.desktop file, makes a copy # as autostart item. -{stdenv, lib}: -{ name # name of the desktop file (without .desktop) -, package # package where the desktop file resides in -, srcPrefix ? "" # additional prefix that the desktop file may have in the 'package' -, after ? null -, condition ? null -, phase ? "2" -, prependExtraArgs ? [] -, appendExtraArgs ? [] +{ stdenv, lib }: +{ + name, # name of the desktop file (without .desktop) + package, # package where the desktop file resides in + srcPrefix ? "", # additional prefix that the desktop file may have in the 'package' + after ? null, + condition ? null, + phase ? "2", + prependExtraArgs ? [ ], + appendExtraArgs ? [ ], }: # the builder requires that @@ -20,23 +21,25 @@ stdenv.mkDerivation { name = "autostart-${name}"; priority = 5; - buildCommand = let - escapeArgs = args: lib.escapeRegex (lib.escapeShellArgs args); - prependArgs = lib.optionalString (prependExtraArgs != []) "${escapeArgs prependExtraArgs} "; - appendArgs = lib.optionalString (appendExtraArgs != []) " ${escapeArgs appendExtraArgs}"; - in '' - mkdir -p $out/etc/xdg/autostart - target=${name}.desktop - cp ${package}/share/applications/${srcPrefix}${name}.desktop $target - ${lib.optionalString (prependExtraArgs != [] || appendExtraArgs != []) '' - sed -i -r "s/(Exec=)([^ \n]*) *(.*)/\1\2 ${prependArgs}\3${appendArgs}/" $target - ''} - chmod +rw $target - echo "X-KDE-autostart-phase=${phase}" >> $target - ${lib.optionalString (after != null) ''echo "${after}" >> $target''} - ${lib.optionalString (condition != null) ''echo "${condition}" >> $target''} - cp $target $out/etc/xdg/autostart - ''; + buildCommand = + let + escapeArgs = args: lib.escapeRegex (lib.escapeShellArgs args); + prependArgs = lib.optionalString (prependExtraArgs != [ ]) "${escapeArgs prependExtraArgs} "; + appendArgs = lib.optionalString (appendExtraArgs != [ ]) " ${escapeArgs appendExtraArgs}"; + in + '' + mkdir -p $out/etc/xdg/autostart + target=${name}.desktop + cp ${package}/share/applications/${srcPrefix}${name}.desktop $target + ${lib.optionalString (prependExtraArgs != [ ] || appendExtraArgs != [ ]) '' + sed -i -r "s/(Exec=)([^ \n]*) *(.*)/\1\2 ${prependArgs}\3${appendArgs}/" $target + ''} + chmod +rw $target + echo "X-KDE-autostart-phase=${phase}" >> $target + ${lib.optionalString (after != null) ''echo "${after}" >> $target''} + ${lib.optionalString (condition != null) ''echo "${condition}" >> $target''} + cp $target $out/etc/xdg/autostart + ''; # this will automatically put 'package' in the environment when you # put its startup item in there. diff --git a/pkgs/build-support/mitm-cache/default.nix b/pkgs/build-support/mitm-cache/default.nix index e3bce225b46b3d..80287e60a33a1a 100644 --- a/pkgs/build-support/mitm-cache/default.nix +++ b/pkgs/build-support/mitm-cache/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, callPackage -, rustPlatform -, substituteAll -, openssl -, Security -, python3Packages +{ + lib, + stdenv, + fetchFromGitHub, + callPackage, + rustPlatform, + substituteAll, + openssl, + Security, + python3Packages, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/build-support/mitm-cache/fetch.nix b/pkgs/build-support/mitm-cache/fetch.nix index 4e1f24ae7d7b22..fb8798c43bc264 100644 --- a/pkgs/build-support/mitm-cache/fetch.nix +++ b/pkgs/build-support/mitm-cache/fetch.nix @@ -1,49 +1,72 @@ -{ lib -, fetchurl -, runCommand -, writeText +{ + lib, + fetchurl, + runCommand, + writeText, }: -{ name ? "deps" -, data -, dontFixup ? true -, ... -} -@ attrs: +{ + name ? "deps", + data, + dontFixup ? true, + ... +}@attrs: let - data' = builtins.removeAttrs - (if builtins.isPath data then lib.importJSON data else data) - [ "!version" ]; + data' = builtins.removeAttrs (if builtins.isPath data then lib.importJSON data else data) [ + "!version" + ]; - urlToPath = url: - if lib.hasPrefix "https://" url then ( - let - url' = lib.drop 2 (lib.splitString "/" url); - in "https/${builtins.concatStringsSep "/" url'}" - ) - else builtins.replaceStrings ["://"] ["/"] url; - code = '' - mkdir -p "$out" - cd "$out" - '' + builtins.concatStringsSep "" (lib.mapAttrsToList (url: info: - let - key = builtins.head (builtins.attrNames info); - val = info.${key}; - path = urlToPath url; - name = baseNameOf path; - source = { - redirect = "$out/${urlToPath val}"; - hash = fetchurl { inherit url; hash = val; }; - text = writeText name val; - }.${key} or (throw "Unknown key: ${url}"); - in '' - mkdir -p "${dirOf path}" - ln -s "${source}" "${path}" - '') data'); + urlToPath = + url: + if lib.hasPrefix "https://" url then + ( + let + url' = lib.drop 2 (lib.splitString "/" url); + in + "https/${builtins.concatStringsSep "/" url'}" + ) + else + builtins.replaceStrings [ "://" ] [ "/" ] url; + code = + '' + mkdir -p "$out" + cd "$out" + '' + + builtins.concatStringsSep "" ( + lib.mapAttrsToList ( + url: info: + let + key = builtins.head (builtins.attrNames info); + val = info.${key}; + path = urlToPath url; + name = baseNameOf path; + source = + { + redirect = "$out/${urlToPath val}"; + hash = fetchurl { + inherit url; + hash = val; + }; + text = writeText name val; + } + .${key} or (throw "Unknown key: ${url}"); + in + '' + mkdir -p "${dirOf path}" + ln -s "${source}" "${path}" + '' + ) data' + ); in - runCommand name (builtins.removeAttrs attrs [ "name" "data" ] // { - passthru = (attrs.passthru or {}) // { +runCommand name ( + builtins.removeAttrs attrs [ + "name" + "data" + ] + // { + passthru = (attrs.passthru or { }) // { data = writeText "deps.json" (builtins.toJSON data); }; - }) code + } +) code diff --git a/pkgs/build-support/nix-gitignore/default.nix b/pkgs/build-support/nix-gitignore/default.nix index 849720675c8924..60a854225e1055 100644 --- a/pkgs/build-support/nix-gitignore/default.nix +++ b/pkgs/build-support/nix-gitignore/default.nix @@ -30,36 +30,58 @@ let trace ; - inherit (lib.strings) match split typeOf; debug = a: trace a a; last = l: elemAt l ((length l) - 1); -in rec { +in +rec { # [["good/relative/source/file" true] ["bad.tmpfile" false]] -> root -> path - filterPattern = patterns: root: - (name: _type: + filterPattern = + patterns: root: + ( + name: _type: let relPath = removePrefix ((toString root) + "/") name; matches = pair: (match (head pair) relPath) != null; - matched = map (pair: [(matches pair) (last pair)]) patterns; + matched = map (pair: [ + (matches pair) + (last pair) + ]) patterns; in - last (last ([[true true]] ++ (filter head matched))) + last ( + last ( + [ + [ + true + true + ] + ] + ++ (filter head matched) + ) + ) ); # string -> [[regex bool]] - gitignoreToPatterns = gitignore: + gitignoreToPatterns = + gitignore: let # ignore -> bool isComment = i: (match "^(#.*|$)" i) != null; # ignore -> [ignore bool] - computeNegation = l: - let split = match "^(!?)(.*)" l; - in [(elemAt split 1) (head split == "!")]; + computeNegation = + l: + let + split = match "^(!?)(.*)" l; + in + [ + (elemAt split 1) + (head split == "!") + ]; # regex -> regex - handleHashesBangs = replaceStrings ["\\#" "\\!"] ["#" "!"]; + handleHashesBangs = replaceStrings [ "\\#" "\\!" ] [ "#" "!" ]; # ignore -> regex substWildcards = @@ -67,74 +89,106 @@ in rec { special = "^$.+{}()"; escs = "\\*?"; splitString = - let recurse = str : [(substring 0 1 str)] ++ - (optionals (str != "") (recurse (substring 1 (stringLength(str)) str) )); - in str : recurse str; + let + recurse = + str: + [ (substring 0 1 str) ] ++ (optionals (str != "") (recurse (substring 1 (stringLength (str)) str))); + in + str: recurse str; chars = s: filter (c: c != "" && !isList c) (splitString s); escape = s: map (c: "\\" + c) (chars s); in - replaceStrings - ((chars special) ++ (escape escs) ++ ["**/" "**" "*" "?"]) - ((escape special) ++ (escape escs) ++ ["(.*/)?" ".*" "[^/]*" "[^/]"]); + replaceStrings + ( + (chars special) + ++ (escape escs) + ++ [ + "**/" + "**" + "*" + "?" + ] + ) + ( + (escape special) + ++ (escape escs) + ++ [ + "(.*/)?" + ".*" + "[^/]*" + "[^/]" + ] + ); # (regex -> regex) -> regex -> regex - mapAroundCharclass = f: r: # rl = regex or list - let slightFix = replaceStrings ["\\]"] ["]"]; + mapAroundCharclass = + f: r: # rl = regex or list + let + slightFix = replaceStrings [ "\\]" ] [ "]" ]; in - concatStringsSep "" - (map (rl: if isList rl then slightFix (elemAt rl 0) else f rl) - (split "(\\[([^\\\\]|\\\\.)+])" r)); + concatStringsSep "" ( + map (rl: if isList rl then slightFix (elemAt rl 0) else f rl) (split "(\\[([^\\\\]|\\\\.)+])" r) + ); # regex -> regex - handleSlashPrefix = l: + handleSlashPrefix = + l: let split = (match "^(/?)(.*)" l); findSlash = l: optionalString ((match ".+/.+" l) == null) l; hasSlash = mapAroundCharclass findSlash l != l; in - (if (elemAt split 0) == "/" || hasSlash - then "^" - else "(^|.*/)" - ) + (elemAt split 1); + (if (elemAt split 0) == "/" || hasSlash then "^" else "(^|.*/)") + (elemAt split 1); # regex -> regex - handleSlashSuffix = l: - let split = (match "^(.*)/$" l); - in if split != null then (elemAt split 0) + "($|/.*)" else l; + handleSlashSuffix = + l: + let + split = (match "^(.*)/$" l); + in + if split != null then (elemAt split 0) + "($|/.*)" else l; # (regex -> regex) -> [regex, bool] -> [regex, bool] - mapPat = f: l: [(f (head l)) (last l)]; + mapPat = f: l: [ + (f (head l)) + (last l) + ]; in - map (l: # `l' for "line" - mapPat (l: handleSlashSuffix (handleSlashPrefix (handleHashesBangs (mapAroundCharclass substWildcards l)))) - (computeNegation l)) - (filter (l: !isList l && !isComment l) - (split "\n" gitignore)); + map ( + l: # `l' for "line" + mapPat ( + l: handleSlashSuffix (handleSlashPrefix (handleHashesBangs (mapAroundCharclass substWildcards l))) + ) (computeNegation l) + ) (filter (l: !isList l && !isComment l) (split "\n" gitignore)); gitignoreFilter = ign: root: filterPattern (gitignoreToPatterns ign) root; # string|[string|file] (→ [string|file] → [string]) -> string - gitignoreCompileIgnore = file_str_patterns: root: + gitignoreCompileIgnore = + file_str_patterns: root: let onPath = f: a: if typeOf a == "path" then f a else a; str_patterns = map (onPath readFile) (toList file_str_patterns); - in concatStringsSep "\n" str_patterns; + in + concatStringsSep "\n" str_patterns; - gitignoreFilterPure = predicate: patterns: root: name: type: - gitignoreFilter (gitignoreCompileIgnore patterns root) root name type - && predicate name type; + gitignoreFilterPure = + predicate: patterns: root: name: type: + gitignoreFilter (gitignoreCompileIgnore patterns root) root name type && predicate name type; # This is a very hacky way of programming this! # A better way would be to reuse existing filtering by making multiple gitignore functions per each root. # Then for each file find the set of roots with gitignores (and functions). # This would make gitignoreFilterSource very different from gitignoreFilterPure. # rootPath → gitignoresConcatenated - compileRecursiveGitignore = root: + compileRecursiveGitignore = + root: let dirOrIgnore = file: type: baseNameOf file == ".gitignore" || type == "directory"; ignores = builtins.filterSource dirOrIgnore root; - in readFile ( - runCommand "${baseNameOf root}-recursive-gitignore" {} '' + in + readFile ( + runCommand "${baseNameOf root}-recursive-gitignore" { } '' cd ${ignores} find -type f -exec sh -c ' @@ -165,34 +219,40 @@ in rec { END { print \"\" } " "$1" ' sh {} \; > $out - ''); + '' + ); - withGitignoreFile = patterns: root: - toList patterns ++ [ ".git" ] ++ [(root + "/.gitignore")]; + withGitignoreFile = patterns: root: toList patterns ++ [ ".git" ] ++ [ (root + "/.gitignore") ]; - withRecursiveGitignoreFile = patterns: root: - toList patterns ++ [ ".git" ] ++ [(compileRecursiveGitignore root)]; + withRecursiveGitignoreFile = + patterns: root: toList patterns ++ [ ".git" ] ++ [ (compileRecursiveGitignore root) ]; # filterSource derivatives - gitignoreFilterSourcePure = predicate: patterns: root: + gitignoreFilterSourcePure = + predicate: patterns: root: filterSource (gitignoreFilterPure predicate patterns root) root; - gitignoreFilterSource = predicate: patterns: root: + gitignoreFilterSource = + predicate: patterns: root: gitignoreFilterSourcePure predicate (withGitignoreFile patterns root) root; - gitignoreFilterRecursiveSource = predicate: patterns: root: + gitignoreFilterRecursiveSource = + predicate: patterns: root: gitignoreFilterSourcePure predicate (withRecursiveGitignoreFile patterns root) root; # "Predicate"-less alternatives gitignoreSourcePure = gitignoreFilterSourcePure (_: _: true); - gitignoreSource = patterns: let type = typeOf patterns; in - if (type == "string" && pathExists patterns) || type == "path" - then throw - "type error in gitignoreSource(patterns -> source -> path), " - "use [] or \"\" if there are no additional patterns" - else gitignoreFilterSource (_: _: true) patterns; + gitignoreSource = + patterns: + let + type = typeOf patterns; + in + if (type == "string" && pathExists patterns) || type == "path" then + throw "type error in gitignoreSource(patterns -> source -> path), " "use [] or \"\" if there are no additional patterns" + else + gitignoreFilterSource (_: _: true) patterns; gitignoreRecursiveSource = gitignoreFilterSourcePure (_: _: true); } diff --git a/pkgs/build-support/node/build-npm-package/default.nix b/pkgs/build-support/node/build-npm-package/default.nix index 372124829b0927..cef4de9f98f7cf 100644 --- a/pkgs/build-support/node/build-npm-package/default.nix +++ b/pkgs/build-support/node/build-npm-package/default.nix @@ -1,63 +1,75 @@ -{ lib -, stdenv -, fetchNpmDeps -, buildPackages -, nodejs -, cctools -} @ topLevelArgs: +{ + lib, + stdenv, + fetchNpmDeps, + buildPackages, + nodejs, + cctools, +}@topLevelArgs: -{ name ? "${args.pname}-${args.version}" -, src ? null -, srcs ? null -, sourceRoot ? null -, prePatch ? "" -, patches ? [ ] -, postPatch ? "" -, patchFlags ? [] -, nativeBuildInputs ? [ ] -, buildInputs ? [ ] +{ + name ? "${args.pname}-${args.version}", + src ? null, + srcs ? null, + sourceRoot ? null, + prePatch ? "", + patches ? [ ], + postPatch ? "", + patchFlags ? [ ], + nativeBuildInputs ? [ ], + buildInputs ? [ ], # The output hash of the dependencies for this project. # Can be calculated in advance with prefetch-npm-deps. -, npmDepsHash ? "" + npmDepsHash ? "", # Whether to force the usage of Git dependencies that have install scripts, but not a lockfile. # Use with care. -, forceGitDeps ? false + forceGitDeps ? false, # Whether to force allow an empty dependency cache. # This can be enabled if there are truly no remote dependencies, but generally an empty cache indicates something is wrong. -, forceEmptyCache ? false + forceEmptyCache ? false, # Whether to make the cache writable prior to installing dependencies. # Don't set this unless npm tries to write to the cache directory, as it can slow down the build. -, makeCacheWritable ? false + makeCacheWritable ? false, # The script to run to build the project. -, npmBuildScript ? "build" + npmBuildScript ? "build", # Flags to pass to all npm commands. -, npmFlags ? [ ] + npmFlags ? [ ], # Flags to pass to `npm ci`. -, npmInstallFlags ? [ ] + npmInstallFlags ? [ ], # Flags to pass to `npm rebuild`. -, npmRebuildFlags ? [ ] + npmRebuildFlags ? [ ], # Flags to pass to `npm run ${npmBuildScript}`. -, npmBuildFlags ? [ ] + npmBuildFlags ? [ ], # Flags to pass to `npm pack`. -, npmPackFlags ? [ ] + npmPackFlags ? [ ], # Flags to pass to `npm prune`. -, npmPruneFlags ? npmInstallFlags + npmPruneFlags ? npmInstallFlags, # Value for npm `--workspace` flag and directory in which the files to be installed are found. -, npmWorkspace ? null -, nodejs ? topLevelArgs.nodejs -, npmDeps ? fetchNpmDeps { - inherit forceGitDeps forceEmptyCache src srcs sourceRoot prePatch patches postPatch patchFlags; - name = "${name}-npm-deps"; - hash = npmDepsHash; -} + npmWorkspace ? null, + nodejs ? topLevelArgs.nodejs, + npmDeps ? fetchNpmDeps { + inherit + forceGitDeps + forceEmptyCache + src + srcs + sourceRoot + prePatch + patches + postPatch + patchFlags + ; + name = "${name}-npm-deps"; + hash = npmDepsHash; + }, # Custom npmConfigHook -, npmConfigHook ? null + npmConfigHook ? null, # Custom npmBuildHook -, npmBuildHook ? null + npmBuildHook ? null, # Custom npmInstallHook -, npmInstallHook ? null -, ... -} @ args: + npmInstallHook ? null, + ... +}@args: let # .override {} negates splicing, so we need to use buildPackages explicitly @@ -65,25 +77,31 @@ let inherit nodejs; }; in -stdenv.mkDerivation (args // { - inherit npmDeps npmBuildScript; +stdenv.mkDerivation ( + args + // { + inherit npmDeps npmBuildScript; - nativeBuildInputs = nativeBuildInputs - ++ [ - nodejs - # Prefer passed hooks - (if npmConfigHook != null then npmConfigHook else npmHooks.npmConfigHook) - (if npmBuildHook != null then npmBuildHook else npmHooks.npmBuildHook) - (if npmInstallHook != null then npmInstallHook else npmHooks.npmInstallHook) - nodejs.python - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools ]; - buildInputs = buildInputs ++ [ nodejs ]; + nativeBuildInputs = + nativeBuildInputs + ++ [ + nodejs + # Prefer passed hooks + (if npmConfigHook != null then npmConfigHook else npmHooks.npmConfigHook) + (if npmBuildHook != null then npmBuildHook else npmHooks.npmBuildHook) + (if npmInstallHook != null then npmInstallHook else npmHooks.npmInstallHook) + nodejs.python + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools ]; + buildInputs = buildInputs ++ [ nodejs ]; - strictDeps = true; + strictDeps = true; - # Stripping takes way too long with the amount of files required by a typical Node.js project. - dontStrip = args.dontStrip or true; + # Stripping takes way too long with the amount of files required by a typical Node.js project. + dontStrip = args.dontStrip or true; - meta = (args.meta or { }) // { platforms = args.meta.platforms or nodejs.meta.platforms; }; -}) + meta = (args.meta or { }) // { + platforms = args.meta.platforms or nodejs.meta.platforms; + }; + } +) diff --git a/pkgs/build-support/node/build-npm-package/hooks/default.nix b/pkgs/build-support/node/build-npm-package/hooks/default.nix index 7a4fed30f5d528..f7cb4aded0e236 100644 --- a/pkgs/build-support/node/build-npm-package/hooks/default.nix +++ b/pkgs/build-support/node/build-npm-package/hooks/default.nix @@ -1,51 +1,49 @@ -{ lib -, srcOnly -, makeSetupHook -, makeWrapper -, nodejs -, jq -, prefetch-npm-deps -, diffutils -, installShellFiles -, nodejsInstallManuals -, nodejsInstallExecutables +{ + lib, + srcOnly, + makeSetupHook, + makeWrapper, + nodejs, + jq, + prefetch-npm-deps, + diffutils, + installShellFiles, + nodejsInstallManuals, + nodejsInstallExecutables, }: { - npmConfigHook = makeSetupHook - { - name = "npm-config-hook"; - substitutions = { - nodeSrc = srcOnly nodejs; - nodeGyp = "${nodejs}/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js"; + npmConfigHook = makeSetupHook { + name = "npm-config-hook"; + substitutions = { + nodeSrc = srcOnly nodejs; + nodeGyp = "${nodejs}/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js"; - # Specify `diff`, `jq`, and `prefetch-npm-deps` by abspath to ensure that the user's build - # inputs do not cause us to find the wrong binaries. - diff = "${diffutils}/bin/diff"; - jq = "${jq}/bin/jq"; - prefetchNpmDeps = "${prefetch-npm-deps}/bin/prefetch-npm-deps"; + # Specify `diff`, `jq`, and `prefetch-npm-deps` by abspath to ensure that the user's build + # inputs do not cause us to find the wrong binaries. + diff = "${diffutils}/bin/diff"; + jq = "${jq}/bin/jq"; + prefetchNpmDeps = "${prefetch-npm-deps}/bin/prefetch-npm-deps"; - nodeVersion = nodejs.version; - nodeVersionMajor = lib.versions.major nodejs.version; - }; - } ./npm-config-hook.sh; + nodeVersion = nodejs.version; + nodeVersionMajor = lib.versions.major nodejs.version; + }; + } ./npm-config-hook.sh; - npmBuildHook = makeSetupHook - { - name = "npm-build-hook"; - } ./npm-build-hook.sh; + npmBuildHook = makeSetupHook { + name = "npm-build-hook"; + } ./npm-build-hook.sh; - npmInstallHook = makeSetupHook - { - name = "npm-install-hook"; - propagatedBuildInputs = [ - installShellFiles - makeWrapper - nodejsInstallManuals - nodejsInstallExecutables - ]; - substitutions = { - jq = "${jq}/bin/jq"; - }; - } ./npm-install-hook.sh; + npmInstallHook = makeSetupHook { + name = "npm-install-hook"; + propagatedBuildInputs = [ + installShellFiles + makeWrapper + nodejsInstallManuals + nodejsInstallExecutables + ]; + substitutions = { + jq = "${jq}/bin/jq"; + }; + } ./npm-install-hook.sh; } diff --git a/pkgs/build-support/node/import-npm-lock/default.nix b/pkgs/build-support/node/import-npm-lock/default.nix index 3c26b98d3992cd..6e4d19914b70ea 100644 --- a/pkgs/build-support/node/import-npm-lock/default.nix +++ b/pkgs/build-support/node/import-npm-lock/default.nix @@ -1,12 +1,18 @@ -{ lib -, fetchurl -, stdenv -, callPackages -, runCommand +{ + lib, + fetchurl, + stdenv, + callPackages, + runCommand, }: let - inherit (builtins) match elemAt toJSON removeAttrs; + inherit (builtins) + match + elemAt + toJSON + removeAttrs + ; inherit (lib) importJSON mapAttrs; matchGitHubReference = match "github(.com)?:.+"; @@ -15,10 +21,12 @@ let # Fetch a module from package-lock.json -> packages fetchModule = - { module - , npmRoot ? null - , fetcherOpts - }: ( + { + module, + npmRoot ? null, + fetcherOpts, + }: + ( if module ? "resolved" then ( let @@ -29,27 +37,32 @@ let ( if mUrl == null then ( - assert npmRoot != null; { + assert npmRoot != null; + { outPath = npmRoot + "/${module.resolved}"; } ) else if (scheme == "http" || scheme == "https") then - ( - fetchurl ({ + (fetchurl ( + { url = module.resolved; hash = module.integrity; - } // fetcherOpts ) - ) + } + // fetcherOpts + )) else if lib.hasPrefix "git" module.resolved then - ( - builtins.fetchGit ({ + (builtins.fetchGit ( + { url = module.resolved; - } // fetcherOpts ) - ) - else throw "Unsupported URL scheme: ${scheme}" + } + // fetcherOpts + )) + else + throw "Unsupported URL scheme: ${scheme}" ) ) - else null + else + null ); cleanModule = lib.flip removeAttrs [ @@ -63,65 +76,78 @@ let in lib.fix (self: { importNpmLock = - { npmRoot ? null - , package ? importJSON (npmRoot + "/package.json") - , packageLock ? importJSON (npmRoot + "/package-lock.json") - , pname ? getName package - , version ? getVersion package - # A map of additional fetcher options forwarded to the fetcher used to download the package. - # Example: { "node_modules/axios" = { curlOptsList = [ "--verbose" ]; }; } - # This will download the axios package with curl's verbose option. - , fetcherOpts ? {} - # A map from node_module path to an alternative package to use instead of fetching the source in package-lock.json. - # Example: { "node_modules/axios" = stdenv.mkDerivation { ... }; } - # This is usefull if you want to inject custom sources for a specific package. - , packageSourceOverrides ? {} + { + npmRoot ? null, + package ? importJSON (npmRoot + "/package.json"), + packageLock ? importJSON (npmRoot + "/package-lock.json"), + pname ? getName package, + version ? getVersion package, + # A map of additional fetcher options forwarded to the fetcher used to download the package. + # Example: { "node_modules/axios" = { curlOptsList = [ "--verbose" ]; }; } + # This will download the axios package with curl's verbose option. + fetcherOpts ? { }, + # A map from node_module path to an alternative package to use instead of fetching the source in package-lock.json. + # Example: { "node_modules/axios" = stdenv.mkDerivation { ... }; } + # This is usefull if you want to inject custom sources for a specific package. + packageSourceOverrides ? { }, }: let - mapLockDependencies = - mapAttrs - (name: version: ( - # Substitute the constraint with the version of the dependency from the top-level of package-lock. - if ( + mapLockDependencies = mapAttrs ( + name: version: + ( + # Substitute the constraint with the version of the dependency from the top-level of package-lock. + if + ( # if the version is `latest` version == "latest" || - # Or if it's a github reference - matchGitHubReference version != null - ) then packageLock'.packages.${"node_modules/${name}"}.version - # But not a regular version constraint - else version - )); + # Or if it's a github reference + matchGitHubReference version != null + ) + then + packageLock'.packages.${"node_modules/${name}"}.version + # But not a regular version constraint + else + version + ) + ); packageLock' = packageLock // { - packages = - mapAttrs - (modulePath: module: - let - src = packageSourceOverrides.${modulePath} or (fetchModule { - inherit module npmRoot; - fetcherOpts = fetcherOpts.${modulePath} or {}; - }); - in - cleanModule module - // lib.optionalAttrs (src != null) { - resolved = "file:${src}"; - } // lib.optionalAttrs (module ? dependencies) { - dependencies = mapLockDependencies module.dependencies; - } // lib.optionalAttrs (module ? optionalDependencies) { - optionalDependencies = mapLockDependencies module.optionalDependencies; - }) - packageLock.packages; + packages = mapAttrs ( + modulePath: module: + let + src = + packageSourceOverrides.${modulePath} or (fetchModule { + inherit module npmRoot; + fetcherOpts = fetcherOpts.${modulePath} or { }; + }); + in + cleanModule module + // lib.optionalAttrs (src != null) { + resolved = "file:${src}"; + } + // lib.optionalAttrs (module ? dependencies) { + dependencies = mapLockDependencies module.dependencies; + } + // lib.optionalAttrs (module ? optionalDependencies) { + optionalDependencies = mapLockDependencies module.optionalDependencies; + } + ) packageLock.packages; }; - mapPackageDependencies = mapAttrs (name: _: packageLock'.packages.${"node_modules/${name}"}.resolved); + mapPackageDependencies = mapAttrs ( + name: _: packageLock'.packages.${"node_modules/${name}"}.resolved + ); # Substitute dependency references in package.json with Nix store paths - packageJSON' = package // lib.optionalAttrs (package ? dependencies) { - dependencies = mapPackageDependencies package.dependencies; - } // lib.optionalAttrs (package ? devDependencies) { - devDependencies = mapPackageDependencies package.devDependencies; - }; + packageJSON' = + package + // lib.optionalAttrs (package ? dependencies) { + dependencies = mapPackageDependencies package.dependencies; + } + // lib.optionalAttrs (package ? devDependencies) { + devDependencies = mapPackageDependencies package.devDependencies; + }; pname = package.name or "unknown"; @@ -130,59 +156,73 @@ lib.fix (self: { { inherit pname version; - passAsFile = [ "package" "packageLock" ]; + passAsFile = [ + "package" + "packageLock" + ]; package = toJSON packageJSON'; packageLock = toJSON packageLock'; - } '' - mkdir $out - cp "$packagePath" $out/package.json - cp "$packageLockPath" $out/package-lock.json - ''; + } + '' + mkdir $out + cp "$packagePath" $out/package.json + cp "$packageLockPath" $out/package-lock.json + ''; # Build node modules from package.json & package-lock.json buildNodeModules = - { npmRoot ? null - , package ? importJSON (npmRoot + "/package.json") - , packageLock ? importJSON (npmRoot + "/package-lock.json") - , nodejs - , derivationArgs ? { } + { + npmRoot ? null, + package ? importJSON (npmRoot + "/package.json"), + packageLock ? importJSON (npmRoot + "/package-lock.json"), + nodejs, + derivationArgs ? { }, }: - stdenv.mkDerivation ({ - pname = derivationArgs.pname or "${getName package}-node-modules"; - version = derivationArgs.version or getVersion package; - - dontUnpack = true; - - npmDeps = self.importNpmLock { - inherit npmRoot package packageLock; - }; - - package = toJSON package; - packageLock = toJSON packageLock; - - installPhase = '' - runHook preInstall - mkdir $out - cp package.json $out/ - cp package-lock.json $out/ - [[ -d node_modules ]] && mv node_modules $out/ - runHook postInstall - ''; - } // derivationArgs // { - nativeBuildInputs = [ - nodejs - nodejs.passthru.python - hooks.npmConfigHook - ] ++ derivationArgs.nativeBuildInputs or [ ]; - - passAsFile = [ "package" "packageLock" ] ++ derivationArgs.passAsFile or [ ]; - - postPatch = '' - cp --no-preserve=mode "$packagePath" package.json - cp --no-preserve=mode "$packageLockPath" package-lock.json - '' + derivationArgs.postPatch or ""; - }); + stdenv.mkDerivation ( + { + pname = derivationArgs.pname or "${getName package}-node-modules"; + version = derivationArgs.version or getVersion package; + + dontUnpack = true; + + npmDeps = self.importNpmLock { + inherit npmRoot package packageLock; + }; + + package = toJSON package; + packageLock = toJSON packageLock; + + installPhase = '' + runHook preInstall + mkdir $out + cp package.json $out/ + cp package-lock.json $out/ + [[ -d node_modules ]] && mv node_modules $out/ + runHook postInstall + ''; + } + // derivationArgs + // { + nativeBuildInputs = [ + nodejs + nodejs.passthru.python + hooks.npmConfigHook + ] ++ derivationArgs.nativeBuildInputs or [ ]; + + passAsFile = [ + "package" + "packageLock" + ] ++ derivationArgs.passAsFile or [ ]; + + postPatch = + '' + cp --no-preserve=mode "$packagePath" package.json + cp --no-preserve=mode "$packageLockPath" package-lock.json + '' + + derivationArgs.postPatch or ""; + } + ); inherit hooks; inherit (hooks) npmConfigHook linkNodeModulesHook; diff --git a/pkgs/build-support/node/import-npm-lock/hooks/default.nix b/pkgs/build-support/node/import-npm-lock/hooks/default.nix index 0140ebf2d47026..4a54628e1d6453 100644 --- a/pkgs/build-support/node/import-npm-lock/hooks/default.nix +++ b/pkgs/build-support/node/import-npm-lock/hooks/default.nix @@ -1,23 +1,27 @@ -{ callPackage, lib, makeSetupHook, srcOnly, nodejs }: { - npmConfigHook = makeSetupHook - { - name = "npm-config-hook"; - substitutions = { - nodeSrc = srcOnly nodejs; - nodeGyp = "${nodejs}/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js"; - canonicalizeSymlinksScript = ./canonicalize-symlinks.js; - storePrefix = builtins.storeDir; - }; - } ./npm-config-hook.sh; + callPackage, + lib, + makeSetupHook, + srcOnly, + nodejs, +}: +{ + npmConfigHook = makeSetupHook { + name = "npm-config-hook"; + substitutions = { + nodeSrc = srcOnly nodejs; + nodeGyp = "${nodejs}/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js"; + canonicalizeSymlinksScript = ./canonicalize-symlinks.js; + storePrefix = builtins.storeDir; + }; + } ./npm-config-hook.sh; - linkNodeModulesHook = makeSetupHook - { - name = "node-modules-hook.sh"; - substitutions = { - nodejs = lib.getExe nodejs; - script = ./link-node-modules.js; - storePrefix = builtins.storeDir; - }; - } ./link-node-modules-hook.sh; + linkNodeModulesHook = makeSetupHook { + name = "node-modules-hook.sh"; + substitutions = { + nodejs = lib.getExe nodejs; + script = ./link-node-modules.js; + storePrefix = builtins.storeDir; + }; + } ./link-node-modules-hook.sh; } diff --git a/pkgs/build-support/ocaml/dune.nix b/pkgs/build-support/ocaml/dune.nix index fbf732958a45f5..1d77d1c1e9b6e5 100644 --- a/pkgs/build-support/ocaml/dune.nix +++ b/pkgs/build-support/ocaml/dune.nix @@ -1,50 +1,88 @@ -{ lib, stdenv, ocaml, findlib, dune_1, dune_2, dune_3 }: +{ + lib, + stdenv, + ocaml, + findlib, + dune_1, + dune_2, + dune_3, +}: -{ pname, version, nativeBuildInputs ? [], enableParallelBuilding ? true, ... }@args: +{ + pname, + version, + nativeBuildInputs ? [ ], + enableParallelBuilding ? true, + ... +}@args: -let Dune = - let dune-version = args.duneVersion or "3"; in - { "1" = dune_1; "2" = dune_2; "3" = dune_3; }."${dune-version}"; +let + Dune = + let + dune-version = args.duneVersion or "3"; + in + { + "1" = dune_1; + "2" = dune_2; + "3" = dune_3; + } + ."${dune-version}"; stdenv' = args.stdenv or stdenv; in -if args ? minimalOCamlVersion && lib.versionOlder ocaml.version args.minimalOCamlVersion -then throw "${pname}-${version} is not available for OCaml ${ocaml.version}" +if args ? minimalOCamlVersion && lib.versionOlder ocaml.version args.minimalOCamlVersion then + throw "${pname}-${version} is not available for OCaml ${ocaml.version}" else -stdenv'.mkDerivation ({ + stdenv'.mkDerivation ( + { - inherit enableParallelBuilding; - dontAddStaticConfigureFlags = true; - configurePlatforms = []; + inherit enableParallelBuilding; + dontAddStaticConfigureFlags = true; + configurePlatforms = [ ]; - buildPhase = '' - runHook preBuild - dune build -p ${pname} ''${enableParallelBuilding:+-j $NIX_BUILD_CORES} - runHook postBuild - ''; - checkPhase = '' - runHook preCheck - dune runtest -p ${pname} ''${enableParallelBuilding:+-j $NIX_BUILD_CORES} - runHook postCheck - ''; - installPhase = '' - runHook preInstall - dune install --prefix $out --libdir $OCAMLFIND_DESTDIR ${pname} \ - ${if lib.versionAtLeast Dune.version "2.9" - then "--docdir $out/share/doc --mandir $out/share/man" - else ""} - runHook postInstall - ''; + buildPhase = '' + runHook preBuild + dune build -p ${pname} ''${enableParallelBuilding:+-j $NIX_BUILD_CORES} + runHook postBuild + ''; + checkPhase = '' + runHook preCheck + dune runtest -p ${pname} ''${enableParallelBuilding:+-j $NIX_BUILD_CORES} + runHook postCheck + ''; + installPhase = '' + runHook preInstall + dune install --prefix $out --libdir $OCAMLFIND_DESTDIR ${pname} \ + ${ + if lib.versionAtLeast Dune.version "2.9" then + "--docdir $out/share/doc --mandir $out/share/man" + else + "" + } + runHook postInstall + ''; - strictDeps = true; + strictDeps = true; -} // (builtins.removeAttrs args [ "minimalOCamlVersion" "duneVersion" ]) // { + } + // (builtins.removeAttrs args [ + "minimalOCamlVersion" + "duneVersion" + ]) + // { - name = "ocaml${ocaml.version}-${pname}-${version}"; + name = "ocaml${ocaml.version}-${pname}-${version}"; - nativeBuildInputs = [ ocaml Dune findlib ] ++ nativeBuildInputs; + nativeBuildInputs = [ + ocaml + Dune + findlib + ] ++ nativeBuildInputs; - meta = (args.meta or {}) // { platforms = args.meta.platforms or ocaml.meta.platforms; }; + meta = (args.meta or { }) // { + platforms = args.meta.platforms or ocaml.meta.platforms; + }; -}) + } + ) diff --git a/pkgs/build-support/ocaml/oasis.nix b/pkgs/build-support/ocaml/oasis.nix index 91daad59050d4a..f4319fcd99cea2 100644 --- a/pkgs/build-support/ocaml/oasis.nix +++ b/pkgs/build-support/ocaml/oasis.nix @@ -1,46 +1,66 @@ -{ lib, stdenv, ocaml_oasis, ocaml, findlib, ocamlbuild }: +{ + lib, + stdenv, + ocaml_oasis, + ocaml, + findlib, + ocamlbuild, +}: -{ pname, version, nativeBuildInputs ? [], meta ? { platforms = ocaml.meta.platforms or []; }, +{ + pname, + version, + nativeBuildInputs ? [ ], + meta ? { + platforms = ocaml.meta.platforms or [ ]; + }, minimumOCamlVersion ? null, createFindlibDestdir ? true, dontStrip ? true, ... }@args: -if args ? minimumOCamlVersion && - lib.versionOlder ocaml.version args.minimumOCamlVersion -then throw "${pname}-${version} is not available for OCaml ${ocaml.version}" +if args ? minimumOCamlVersion && lib.versionOlder ocaml.version args.minimumOCamlVersion then + throw "${pname}-${version} is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation (args // { - name = "ocaml${ocaml.version}-${pname}-${version}"; + stdenv.mkDerivation ( + args + // { + name = "ocaml${ocaml.version}-${pname}-${version}"; - nativeBuildInputs = [ ocaml findlib ocamlbuild ocaml_oasis ] ++ nativeBuildInputs; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ocaml_oasis + ] ++ nativeBuildInputs; - inherit createFindlibDestdir; - inherit dontStrip; + inherit createFindlibDestdir; + inherit dontStrip; - strictDeps = true; + strictDeps = true; - buildPhase = '' - runHook preBuild - oasis setup - ocaml setup.ml -configure --prefix $OCAMLFIND_DESTDIR --exec-prefix $out - ocaml setup.ml -build - runHook postBuild - ''; + buildPhase = '' + runHook preBuild + oasis setup + ocaml setup.ml -configure --prefix $OCAMLFIND_DESTDIR --exec-prefix $out + ocaml setup.ml -build + runHook postBuild + ''; - checkPhase = '' - runHook preCheck - ocaml setup.ml -test - runHook postCheck - ''; + checkPhase = '' + runHook preCheck + ocaml setup.ml -test + runHook postCheck + ''; - installPhase = '' - runHook preInstall - mkdir -p $out - ocaml setup.ml -install - runHook postInstall - ''; + installPhase = '' + runHook preInstall + mkdir -p $out + ocaml setup.ml -install + runHook postInstall + ''; -}) + } + ) diff --git a/pkgs/build-support/ocaml/topkg.nix b/pkgs/build-support/ocaml/topkg.nix index 73be5815e44c73..4b387b16ed8472 100644 --- a/pkgs/build-support/ocaml/topkg.nix +++ b/pkgs/build-support/ocaml/topkg.nix @@ -1,28 +1,53 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, topkg, ocamlbuild, cmdliner, odoc, b0 +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + topkg, + ocamlbuild, + cmdliner, + odoc, + b0, }: -{ pname, version, nativeBuildInputs ? [ ], buildInputs ? [ ], ... }@args: - -lib.throwIf (args ? minimalOCamlVersion - && lib.versionOlder ocaml.version args.minimalOCamlVersion) -"${pname}-${version} is not available for OCaml ${ocaml.version}" - -stdenv.mkDerivation ({ - - dontAddStaticConfigureFlags = true; - configurePlatforms = [ ]; - strictDeps = true; - inherit (topkg) buildPhase installPhase; - -} // (builtins.removeAttrs args [ "minimalOCamlVersion" ]) // { - - name = "ocaml${ocaml.version}-${pname}-${version}"; - - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ] ++ nativeBuildInputs; - buildInputs = [ topkg ] ++ buildInputs; - - meta = (args.meta or { }) // { - platforms = args.meta.platforms or ocaml.meta.platforms; - }; - -}) +{ + pname, + version, + nativeBuildInputs ? [ ], + buildInputs ? [ ], + ... +}@args: + +lib.throwIf (args ? minimalOCamlVersion && lib.versionOlder ocaml.version args.minimalOCamlVersion) + "${pname}-${version} is not available for OCaml ${ocaml.version}" + + stdenv.mkDerivation + ( + { + + dontAddStaticConfigureFlags = true; + configurePlatforms = [ ]; + strictDeps = true; + inherit (topkg) buildPhase installPhase; + + } + // (builtins.removeAttrs args [ "minimalOCamlVersion" ]) + // { + + name = "ocaml${ocaml.version}-${pname}-${version}"; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ] ++ nativeBuildInputs; + buildInputs = [ topkg ] ++ buildInputs; + + meta = (args.meta or { }) // { + platforms = args.meta.platforms or ocaml.meta.platforms; + }; + + } + ) diff --git a/pkgs/build-support/oci-tools/default.nix b/pkgs/build-support/oci-tools/default.nix index 1f5507f2eb753e..a9b67878d791f4 100644 --- a/pkgs/build-support/oci-tools/default.nix +++ b/pkgs/build-support/oci-tools/default.nix @@ -1,78 +1,143 @@ -{ lib, writeText, runCommand, writeClosure }: +{ + lib, + writeText, + runCommand, + writeClosure, +}: { buildContainer = - { args - , mounts ? {} - , os ? "linux" - , arch ? "x86_64" - , readonly ? false + { + args, + mounts ? { }, + os ? "linux", + arch ? "x86_64", + readonly ? false, }: - let - sysMounts = { - "/proc" = { - type = "proc"; - source = "proc"; - }; - "/dev" = { - type = "tmpfs"; - source = "tmpfs"; - options = [ "nosuid" "strictatime" "mode=755" "size=65536k" ]; - }; - "/dev/pts" = { - type = "devpts"; - source = "devpts"; - options = [ "nosuid" "noexec" "newinstance" "ptmxmode=0666" "mode=755" "gid=5" ]; - }; - "/dev/shm" = { - type = "tmpfs"; - source = "shm"; - options = [ "nosuid" "noexec" "nodev" "mode=1777" "size=65536k" ]; - }; - "/dev/mqueue" = { - type = "mqueue"; - source = "mqueue"; - options = [ "nosuid" "noexec" "nodev" ]; - }; - "/sys" = { - type = "sysfs"; - source = "sysfs"; - options = [ "nosuid" "noexec" "nodev" "ro" ]; - }; - "/sys/fs/cgroup" = { - type = "cgroup"; - source = "cgroup"; - options = [ "nosuid" "noexec" "nodev" "relatime" "ro" ]; - }; - }; - config = writeText "config.json" (builtins.toJSON { - ociVersion = "1.0.0"; - platform = { - inherit os arch; + let + sysMounts = { + "/proc" = { + type = "proc"; + source = "proc"; + }; + "/dev" = { + type = "tmpfs"; + source = "tmpfs"; + options = [ + "nosuid" + "strictatime" + "mode=755" + "size=65536k" + ]; + }; + "/dev/pts" = { + type = "devpts"; + source = "devpts"; + options = [ + "nosuid" + "noexec" + "newinstance" + "ptmxmode=0666" + "mode=755" + "gid=5" + ]; + }; + "/dev/shm" = { + type = "tmpfs"; + source = "shm"; + options = [ + "nosuid" + "noexec" + "nodev" + "mode=1777" + "size=65536k" + ]; + }; + "/dev/mqueue" = { + type = "mqueue"; + source = "mqueue"; + options = [ + "nosuid" + "noexec" + "nodev" + ]; + }; + "/sys" = { + type = "sysfs"; + source = "sysfs"; + options = [ + "nosuid" + "noexec" + "nodev" + "ro" + ]; + }; + "/sys/fs/cgroup" = { + type = "cgroup"; + source = "cgroup"; + options = [ + "nosuid" + "noexec" + "nodev" + "relatime" + "ro" + ]; + }; }; + config = writeText "config.json" ( + builtins.toJSON { + ociVersion = "1.0.0"; + platform = { + inherit os arch; + }; - linux = { - namespaces = map (type: { inherit type; }) [ "pid" "network" "mount" "ipc" "uts" ]; - }; + linux = { + namespaces = map (type: { inherit type; }) [ + "pid" + "network" + "mount" + "ipc" + "uts" + ]; + }; - root = { path = "rootfs"; inherit readonly; }; + root = { + path = "rootfs"; + inherit readonly; + }; - process = { - inherit args; - user = { uid = 0; gid = 0; }; - cwd = "/"; - }; + process = { + inherit args; + user = { + uid = 0; + gid = 0; + }; + cwd = "/"; + }; - mounts = lib.mapAttrsToList (destination: { type, source, options ? null }: { - inherit destination type source options; - }) sysMounts; - }); - in - runCommand "join" {} '' + mounts = lib.mapAttrsToList ( + destination: + { + type, + source, + options ? null, + }: + { + inherit + destination + type + source + options + ; + } + ) sysMounts; + } + ); + in + runCommand "join" { } '' set -o pipefail mkdir -p $out/rootfs/{dev,proc,sys} cp ${config} $out/config.json xargs tar c < ${writeClosure args} | tar -xC $out/rootfs/ ''; } - diff --git a/pkgs/build-support/pkg-config-wrapper/default.nix b/pkgs/build-support/pkg-config-wrapper/default.nix index 4a6c189bd0a487..3a7616262c734d 100644 --- a/pkgs/build-support/pkg-config-wrapper/default.nix +++ b/pkgs/build-support/pkg-config-wrapper/default.nix @@ -1,13 +1,15 @@ # The wrapper script ensures variables like PKG_CONFIG_PATH and # PKG_CONFIG_PATH_FOR_BUILD work properly. -{ stdenvNoCC -, lib -, buildPackages -, pkg-config -, baseBinName ? "pkg-config" -, propagateDoc ? pkg-config != null && pkg-config ? man -, extraPackages ? [], extraBuildCommands ? "" +{ + stdenvNoCC, + lib, + buildPackages, + pkg-config, + baseBinName ? "pkg-config", + propagateDoc ? pkg-config != null && pkg-config ? man, + extraPackages ? [ ], + extraBuildCommands ? "", }: let @@ -28,11 +30,10 @@ let # # TODO(@Ericson2314) Make unconditional, or optional but always true by # default. - targetPrefix = optionalString (targetPlatform != hostPlatform) - (targetPlatform.config + "-"); + targetPrefix = optionalString (targetPlatform != hostPlatform) (targetPlatform.config + "-"); # See description in cc-wrapper. - suffixSalt = replaceStrings ["-" "."] ["_" "_"] targetPlatform.config; + suffixSalt = replaceStrings [ "-" "." ] [ "_" "_" ] targetPlatform.config; wrapperBinName = "${targetPrefix}${baseBinName}"; in @@ -105,11 +106,14 @@ stdenv.mkDerivation { ## ## Man page and doc support ## - + optionalString propagateDoc ('' - ln -s ${pkg-config.man} $man - '' + optionalString (pkg-config ? doc) '' - ln -s ${pkg-config.doc} $doc - '') + + optionalString propagateDoc ( + '' + ln -s ${pkg-config.man} $man + '' + + optionalString (pkg-config ? doc) '' + ln -s ${pkg-config.doc} $doc + '' + ) + '' substituteAll ${./add-flags.sh} $out/nix-support/add-flags.sh @@ -128,12 +132,18 @@ stdenv.mkDerivation { }; meta = - let pkg-config_ = optionalAttrs (pkg-config != null) pkg-config; in - (optionalAttrs (pkg-config_ ? meta) (removeAttrs pkg-config.meta ["priority" "mainProgram"])) // - { description = - attrByPath ["meta" "description"] "pkg-config" pkg-config_ - + " (wrapper script)"; + let + pkg-config_ = optionalAttrs (pkg-config != null) pkg-config; + in + (optionalAttrs (pkg-config_ ? meta) ( + removeAttrs pkg-config.meta [ + "priority" + "mainProgram" + ] + )) + // { + description = attrByPath [ "meta" "description" ] "pkg-config" pkg-config_ + " (wrapper script)"; priority = 10; mainProgram = wrapperBinName; - }; + }; } diff --git a/pkgs/build-support/plugins.nix b/pkgs/build-support/plugins.nix index 31b478c6c0deea..192e82f56db051 100644 --- a/pkgs/build-support/plugins.nix +++ b/pkgs/build-support/plugins.nix @@ -2,28 +2,29 @@ # helper functions for packaging programs with plugin systems { - /* Takes a list of expected plugin names - * and compares it to the found plugins given in the file, - * one plugin per line. - * If the lists differ, the build fails with a nice message. - * - * This is helpful to ensure maintainers don’t miss - * the addition or removal of a plugin. - */ + /* + Takes a list of expected plugin names + and compares it to the found plugins given in the file, + one plugin per line. + If the lists differ, the build fails with a nice message. + + This is helpful to ensure maintainers don’t miss + the addition or removal of a plugin. + */ diffPlugins = expectedPlugins: foundPluginsFilePath: '' - # sort both lists first - plugins_expected=$(mktemp) - (${lib.concatMapStrings (s: "echo \"${s}\";") expectedPlugins}) \ - | sort -u > "$plugins_expected" - plugins_found=$(mktemp) - sort -u "${foundPluginsFilePath}" > "$plugins_found" + # sort both lists first + plugins_expected=$(mktemp) + (${lib.concatMapStrings (s: "echo \"${s}\";") expectedPlugins}) \ + | sort -u > "$plugins_expected" + plugins_found=$(mktemp) + sort -u "${foundPluginsFilePath}" > "$plugins_found" - if ! mismatches="$(diff -y "$plugins_expected" "$plugins_found")"; then - echo "The the list of expected plugins (left side) doesn't match" \ - "the list of plugins we found (right side):" >&2 - echo "$mismatches" >&2 - exit 1 - fi - ''; + if ! mismatches="$(diff -y "$plugins_expected" "$plugins_found")"; then + echo "The the list of expected plugins (left side) doesn't match" \ + "the list of plugins we found (right side):" >&2 + echo "$mismatches" >&2 + exit 1 + fi + ''; } diff --git a/pkgs/build-support/portable-service/default.nix b/pkgs/build-support/portable-service/default.nix index 6389e8d66fb1d3..7fd592df3b3130 100644 --- a/pkgs/build-support/portable-service/default.nix +++ b/pkgs/build-support/portable-service/default.nix @@ -1,4 +1,8 @@ -{ pkgs, lib, stdenv }: +{ + pkgs, + lib, + stdenv, +}: /* Create a systemd portable service image https://systemd.io/PORTABLE_SERVICES/ @@ -13,30 +17,30 @@ { # The name and version of the portable service. The resulting image will be # created in result/$pname_$version.raw - pname -, version + pname, + version, # Units is a list of derivations for systemd unit files. Those files will be # copied to /etc/systemd/system in the resulting image. Note that the unit # names must be prefixed with the name of the portable service. -, units + units, # Basic info about the portable service image, used for the generated # /etc/os-release -, description ? null -, homepage ? null + description ? null, + homepage ? null, # A list of attribute sets {object, symlink}. Symlinks will be created # in the root filesystem of the image to objects in the nix store. -, symlinks ? [ ] + symlinks ? [ ], # A list of additional derivations to be included in the image as-is. -, contents ? [ ] + contents ? [ ], # mksquashfs options -, squashfsTools ? pkgs.squashfsTools -, squash-compression ? "xz -Xdict-size 100%" -, squash-block-size ? "1M" + squashfsTools ? pkgs.squashfsTools, + squash-compression ? "xz -Xdict-size 100%", + squash-block-size ? "1M", }: let @@ -53,38 +57,40 @@ let PRETTY_NAME = "NixOS"; BUILD_ID = "rolling"; }; - os-release = pkgs.writeText "os-release" - (envFileGenerator (filterNull os-release-params)); + os-release = pkgs.writeText "os-release" (envFileGenerator (filterNull os-release-params)); in stdenv.mkDerivation { pname = "root-fs-scaffold"; inherit version; - buildCommand = '' - # scaffold a file system layout - mkdir -p $out/etc/systemd/system $out/proc $out/sys $out/dev $out/run \ - $out/tmp $out/var/tmp $out/var/lib $out/var/cache $out/var/log - - # empty files to mount over with host's version - touch $out/etc/resolv.conf $out/etc/machine-id - - # required for portable services - cp ${os-release} $out/etc/os-release - '' - # units **must** be copied to /etc/systemd/system/ - + (lib.concatMapStringsSep "\n" (u: "cp ${u} $out/etc/systemd/system/${u.name};") units) - + (lib.concatMapStringsSep "\n" - ({ object, symlink }: '' - mkdir -p $(dirname $out/${symlink}); - ln -s ${object} $out/${symlink}; - '') - symlinks) - ; + buildCommand = + '' + # scaffold a file system layout + mkdir -p $out/etc/systemd/system $out/proc $out/sys $out/dev $out/run \ + $out/tmp $out/var/tmp $out/var/lib $out/var/cache $out/var/log + + # empty files to mount over with host's version + touch $out/etc/resolv.conf $out/etc/machine-id + + # required for portable services + cp ${os-release} $out/etc/os-release + '' + # units **must** be copied to /etc/systemd/system/ + + (lib.concatMapStringsSep "\n" (u: "cp ${u} $out/etc/systemd/system/${u.name};") units) + + (lib.concatMapStringsSep "\n" ( + { object, symlink }: + '' + mkdir -p $(dirname $out/${symlink}); + ln -s ${object} $out/${symlink}; + '' + ) symlinks); }; in -assert lib.assertMsg (lib.all (u: lib.hasPrefix pname u.name) units) "Unit names must be prefixed with the service name"; +assert lib.assertMsg (lib.all ( + u: lib.hasPrefix pname u.name +) units) "Unit names must be prefixed with the service name"; stdenv.mkDerivation { pname = "${pname}-img"; diff --git a/pkgs/build-support/references-by-popularity/default.nix b/pkgs/build-support/references-by-popularity/default.nix index 2171c622f000aa..f681559411e72e 100644 --- a/pkgs/build-support/references-by-popularity/default.nix +++ b/pkgs/build-support/references-by-popularity/default.nix @@ -1,13 +1,21 @@ -{ runCommand, python3, coreutils }: +{ + runCommand, + python3, + coreutils, +}: # Write the references of `path' to a file, in order of how "popular" each # reference is. Nix 2 only. -path: runCommand "closure-paths" -{ - exportReferencesGraph.graph = path; - __structuredAttrs = true; - preferLocalBuild = true; - nativeBuildInputs = [ coreutils python3 ]; -} -'' - python3 ${./closure-graph.py} "$NIX_ATTRS_JSON_FILE" graph > ''${outputs[out]} -'' +path: +runCommand "closure-paths" + { + exportReferencesGraph.graph = path; + __structuredAttrs = true; + preferLocalBuild = true; + nativeBuildInputs = [ + coreutils + python3 + ]; + } + '' + python3 ${./closure-graph.py} "$NIX_ATTRS_JSON_FILE" graph > ''${outputs[out]} + '' diff --git a/pkgs/build-support/release/binary-tarball.nix b/pkgs/build-support/release/binary-tarball.nix index aeaa8edb52beb4..9166c9d9793474 100644 --- a/pkgs/build-support/release/binary-tarball.nix +++ b/pkgs/build-support/release/binary-tarball.nix @@ -1,18 +1,23 @@ -/* This function builds a binary tarball. The resulting binaries are - usually only useful if they are don't have any runtime dependencies - on any paths in the Nix store, since those aren't distributed in - the tarball. For instance, the binaries should be statically - linked: they can't depend on dynamic libraries in the store - (including Glibc). - - The binaries are built and installed with a prefix of /usr/local by - default. They are installed by setting DESTDIR to a temporary - directory, so the Makefile of the package should support DESTDIR. +/* + This function builds a binary tarball. The resulting binaries are + usually only useful if they are don't have any runtime dependencies + on any paths in the Nix store, since those aren't distributed in + the tarball. For instance, the binaries should be statically + linked: they can't depend on dynamic libraries in the store + (including Glibc). + + The binaries are built and installed with a prefix of /usr/local by + default. They are installed by setting DESTDIR to a temporary + directory, so the Makefile of the package should support DESTDIR. */ -{ src, lib, stdenv -, name ? "binary-tarball" -, ... } @ args: +{ + src, + lib, + stdenv, + name ? "binary-tarball", + ... +}@args: stdenv.mkDerivation ( @@ -27,52 +32,53 @@ stdenv.mkDerivation ( postPhases = [ "finalPhase" ]; } - // args // + // args + // - { - name = name + (lib.optionalString (src ? version) "-${src.version}"); + { + name = name + (lib.optionalString (src ? version) "-${src.version}"); - postHook = '' - mkdir -p $out/nix-support - echo "$system" > $out/nix-support/system - . ${./functions.sh} + postHook = '' + mkdir -p $out/nix-support + echo "$system" > $out/nix-support/system + . ${./functions.sh} - origSrc=$src - src=$(findTarball $src) + origSrc=$src + src=$(findTarball $src) - if test -e $origSrc/nix-support/hydra-release-name; then - releaseName=$(cat $origSrc/nix-support/hydra-release-name) - fi + if test -e $origSrc/nix-support/hydra-release-name; then + releaseName=$(cat $origSrc/nix-support/hydra-release-name) + fi - installFlagsArray=(DESTDIR=$TMPDIR/inst) + installFlagsArray=(DESTDIR=$TMPDIR/inst) - # Prefix hackery because of a bug in stdenv (it tries to `mkdir - # $prefix', which doesn't work due to the DESTDIR). - configureFlags="--prefix=$prefix $configureFlags" - dontAddPrefix=1 - prefix=$TMPDIR/inst$prefix - ''; + # Prefix hackery because of a bug in stdenv (it tries to `mkdir + # $prefix', which doesn't work due to the DESTDIR). + configureFlags="--prefix=$prefix $configureFlags" + dontAddPrefix=1 + prefix=$TMPDIR/inst$prefix + ''; - doDist = true; + doDist = true; - distPhase = '' - mkdir -p $out/tarballs - tar cvfj $out/tarballs/''${releaseName:-binary-dist}.tar.bz2 -C $TMPDIR/inst . - ''; + distPhase = '' + mkdir -p $out/tarballs + tar cvfj $out/tarballs/''${releaseName:-binary-dist}.tar.bz2 -C $TMPDIR/inst . + ''; - finalPhase = '' - for i in $out/tarballs/*; do - echo "file binary-dist $i" >> $out/nix-support/hydra-build-products - done + finalPhase = '' + for i in $out/tarballs/*; do + echo "file binary-dist $i" >> $out/nix-support/hydra-build-products + done - # Propagate the release name of the source tarball. This is - # to get nice package names in channels. - test -n "$releaseName" && (echo "$releaseName" >> $out/nix-support/hydra-release-name) - ''; + # Propagate the release name of the source tarball. This is + # to get nice package names in channels. + test -n "$releaseName" && (echo "$releaseName" >> $out/nix-support/hydra-release-name) + ''; - meta = (lib.optionalAttrs (args ? meta) args.meta) // { - description = "Build of a generic binary distribution"; - }; + meta = (lib.optionalAttrs (args ? meta) args.meta) // { + description = "Build of a generic binary distribution"; + }; - } + } ) diff --git a/pkgs/build-support/release/debian-build.nix b/pkgs/build-support/release/debian-build.nix index e73b39c4e6b627..27afc3a117faaa 100644 --- a/pkgs/build-support/release/debian-build.nix +++ b/pkgs/build-support/release/debian-build.nix @@ -1,94 +1,110 @@ # This function compiles a source tarball in a virtual machine image # that contains a Debian-like (i.e. dpkg-based) OS. -{ name ? "debian-build" -, diskImage -, src, lib, stdenv, vmTools, checkinstall -, fsTranslation ? false -, # Features provided by this package. - debProvides ? [] -, # Features required by this package. - debRequires ? [] -, ... } @ args: - -vmTools.runInLinuxImage (stdenv.mkDerivation ( - - { - doCheck = true; - - prefix = "/usr"; - - prePhases = [ "installExtraDebsPhase" "sysInfoPhase" ]; - } - - // removeAttrs args ["vmTools" "lib"] // - - { - name = name + "-" + diskImage.name + (lib.optionalString (src ? version) "-${src.version}"); - - # !!! cut&paste from rpm-build.nix - postHook = '' - . ${./functions.sh} - propagateImageName - src=$(findTarball $src) - ''; - - installExtraDebsPhase = '' - for i in $extraDebs; do - dpkg --install $(ls $i/debs/*.deb | sort | head -1) - done - ''; - - sysInfoPhase = '' - [ ! -f /etc/lsb-release ] || (source /etc/lsb-release; echo "OS release: $DISTRIB_DESCRIPTION") - echo "System/kernel: $(uname -a)" - if test -e /etc/debian_version; then echo "Debian release: $(cat /etc/debian_version)"; fi - echo "installed Debian packages" - dpkg-query --list - ''; - - installPhase = '' - eval "$preInstall" - export LOGNAME=root - - # otherwise build hangs when it wants to display - # the log file - export PAGER=cat - ${checkinstall}/sbin/checkinstall --nodoc -y -D \ - --fstrans=${if fsTranslation then "yes" else "no"} \ - --requires="${lib.concatStringsSep "," debRequires}" \ - --provides="${lib.concatStringsSep "," debProvides}" \ - ${if (src ? version) then "--pkgversion=$(echo ${src.version} | tr _ -)" - else "--pkgversion=0.0.0"} \ - ''${debMaintainer:+--maintainer="'$debMaintainer'"} \ - ''${debName:+--pkgname="'$debName'"} \ - $checkInstallFlags \ - -- \ - $SHELL -c "''${installCommand:-make install}" - - mkdir -p $out/debs - find . -name "*.deb" -exec cp {} $out/debs \; - - [ "$(echo $out/debs/*.deb)" != "" ] - - for i in $out/debs/*.deb; do - echo "Generated DEB package: $i" - dpkg-deb --info "$i" - pkgName=$(dpkg-deb -W "$i" | awk '{print $1}') - echo "file deb $i" >> $out/nix-support/hydra-build-products - done - dpkg -i $out/debs/*.deb - - for i in $extraDebs; do - echo "file deb-extra $(ls $i/debs/*.deb | sort | head -1)" >> $out/nix-support/hydra-build-products - done - - eval "$postInstall" - ''; - - meta = (lib.optionalAttrs (args ? meta) args.meta) // { - description = "Deb package for ${diskImage.fullName}"; - }; - } - -)) +{ + name ? "debian-build", + diskImage, + src, + lib, + stdenv, + vmTools, + checkinstall, + fsTranslation ? false, + # Features provided by this package. + debProvides ? [ ], + # Features required by this package. + debRequires ? [ ], + ... +}@args: + +vmTools.runInLinuxImage ( + stdenv.mkDerivation ( + + { + doCheck = true; + + prefix = "/usr"; + + prePhases = [ + "installExtraDebsPhase" + "sysInfoPhase" + ]; + } + + // removeAttrs args [ + "vmTools" + "lib" + ] + // + + { + name = name + "-" + diskImage.name + (lib.optionalString (src ? version) "-${src.version}"); + + # !!! cut&paste from rpm-build.nix + postHook = '' + . ${./functions.sh} + propagateImageName + src=$(findTarball $src) + ''; + + installExtraDebsPhase = '' + for i in $extraDebs; do + dpkg --install $(ls $i/debs/*.deb | sort | head -1) + done + ''; + + sysInfoPhase = '' + [ ! -f /etc/lsb-release ] || (source /etc/lsb-release; echo "OS release: $DISTRIB_DESCRIPTION") + echo "System/kernel: $(uname -a)" + if test -e /etc/debian_version; then echo "Debian release: $(cat /etc/debian_version)"; fi + echo "installed Debian packages" + dpkg-query --list + ''; + + installPhase = '' + eval "$preInstall" + export LOGNAME=root + + # otherwise build hangs when it wants to display + # the log file + export PAGER=cat + ${checkinstall}/sbin/checkinstall --nodoc -y -D \ + --fstrans=${if fsTranslation then "yes" else "no"} \ + --requires="${lib.concatStringsSep "," debRequires}" \ + --provides="${lib.concatStringsSep "," debProvides}" \ + ${ + if (src ? version) then "--pkgversion=$(echo ${src.version} | tr _ -)" else "--pkgversion=0.0.0" + } \ + ''${debMaintainer:+--maintainer="'$debMaintainer'"} \ + ''${debName:+--pkgname="'$debName'"} \ + $checkInstallFlags \ + -- \ + $SHELL -c "''${installCommand:-make install}" + + mkdir -p $out/debs + find . -name "*.deb" -exec cp {} $out/debs \; + + [ "$(echo $out/debs/*.deb)" != "" ] + + for i in $out/debs/*.deb; do + echo "Generated DEB package: $i" + dpkg-deb --info "$i" + pkgName=$(dpkg-deb -W "$i" | awk '{print $1}') + echo "file deb $i" >> $out/nix-support/hydra-build-products + done + dpkg -i $out/debs/*.deb + + for i in $extraDebs; do + echo "file deb-extra $(ls $i/debs/*.deb | sort | head -1)" >> $out/nix-support/hydra-build-products + done + + eval "$postInstall" + ''; + + meta = (lib.optionalAttrs (args ? meta) args.meta) // { + description = "Deb package for ${diskImage.fullName}"; + }; + } + + ) +) diff --git a/pkgs/build-support/release/default.nix b/pkgs/build-support/release/default.nix index f5ab2db1a75414..66aec1f74509a2 100644 --- a/pkgs/build-support/release/default.nix +++ b/pkgs/build-support/release/default.nix @@ -22,51 +22,112 @@ in rec { - sourceTarball = args: import ./source-tarball.nix ( - { inherit lib stdenv autoconf automake libtool; - } // args); + sourceTarball = + args: + import ./source-tarball.nix ( + { + inherit + lib + stdenv + autoconf + automake + libtool + ; + } + // args + ); makeSourceTarball = sourceTarball; # compatibility - binaryTarball = args: import ./binary-tarball.nix ( - { inherit lib stdenv; - } // args); - - mvnBuild = args: import ./maven-build.nix ( - { inherit lib stdenv; - } // args); - - nixBuild = args: import ./nix-build.nix ( - { inherit lib stdenv; - } // args); - - coverageAnalysis = args: nixBuild ( - { inherit lcov enableGCOVInstrumentation makeGCOVReport; - doCoverageAnalysis = true; - } // args); - - clangAnalysis = args: nixBuild ( - { inherit clang-analyzer; - doClangAnalysis = true; - } // args); - - coverityAnalysis = args: nixBuild ( - { inherit cov-build xz; - doCoverityAnalysis = true; - } // args); - - rpmBuild = args: import ./rpm-build.nix ( - { inherit lib vmTools; - } // args); - - debBuild = args: import ./debian-build.nix ( - { inherit lib stdenv vmTools checkinstall; - } // args); + binaryTarball = + args: + import ./binary-tarball.nix ( + { + inherit lib stdenv; + } + // args + ); + + mvnBuild = + args: + import ./maven-build.nix ( + { + inherit lib stdenv; + } + // args + ); + + nixBuild = + args: + import ./nix-build.nix ( + { + inherit lib stdenv; + } + // args + ); + + coverageAnalysis = + args: + nixBuild ( + { + inherit lcov enableGCOVInstrumentation makeGCOVReport; + doCoverageAnalysis = true; + } + // args + ); + + clangAnalysis = + args: + nixBuild ( + { + inherit clang-analyzer; + doClangAnalysis = true; + } + // args + ); + + coverityAnalysis = + args: + nixBuild ( + { + inherit cov-build xz; + doCoverityAnalysis = true; + } + // args + ); + + rpmBuild = + args: + import ./rpm-build.nix ( + { + inherit lib vmTools; + } + // args + ); + + debBuild = + args: + import ./debian-build.nix ( + { + inherit + lib + stdenv + vmTools + checkinstall + ; + } + // args + ); aggregate = - { name, constituents, meta ? { } }: + { + name, + constituents, + meta ? { }, + }: pkgs.runCommand name - { inherit constituents meta; + { + inherit constituents meta; preferLocalBuild = true; _hydraAggregate = true; } @@ -83,57 +144,67 @@ rec { done ''; - /* Create a channel job which success depends on the success of all of - its contituents. Channel jobs are a special type of jobs that are - listed in the channel tab of Hydra and that can be suscribed. - A tarball of the src attribute is distributed via the channel. - - - constituents: a list of derivations on which the channel success depends. - - name: the channel name that will be used in the hydra interface. - - src: should point to the root folder of the nix-expressions used by the - channel, typically a folder containing a `default.nix`. - - channel { - constituents = [ foo bar baz ]; - name = "my-channel"; - src = ./.; - }; - + /* + Create a channel job which success depends on the success of all of + its contituents. Channel jobs are a special type of jobs that are + listed in the channel tab of Hydra and that can be suscribed. + A tarball of the src attribute is distributed via the channel. + + - constituents: a list of derivations on which the channel success depends. + - name: the channel name that will be used in the hydra interface. + - src: should point to the root folder of the nix-expressions used by the + channel, typically a folder containing a `default.nix`. + + channel { + constituents = [ foo bar baz ]; + name = "my-channel"; + src = ./.; + }; */ channel = - { name, src, constituents ? [], meta ? {}, isNixOS ? true, ... }@args: - stdenv.mkDerivation ({ - preferLocalBuild = true; - _hydraAggregate = true; + { + name, + src, + constituents ? [ ], + meta ? { }, + isNixOS ? true, + ... + }@args: + stdenv.mkDerivation ( + { + preferLocalBuild = true; + _hydraAggregate = true; - dontConfigure = true; - dontBuild = true; + dontConfigure = true; + dontBuild = true; - patchPhase = optionalString isNixOS '' - touch .update-on-nixos-rebuild - ''; + patchPhase = optionalString isNixOS '' + touch .update-on-nixos-rebuild + ''; - installPhase = '' - mkdir -p $out/{tarballs,nix-support} + installPhase = '' + mkdir -p $out/{tarballs,nix-support} - tar cJf "$out/tarballs/nixexprs.tar.xz" \ - --owner=0 --group=0 --mtime="1970-01-01 00:00:00 UTC" \ - --transform='s!^\.!${name}!' . + tar cJf "$out/tarballs/nixexprs.tar.xz" \ + --owner=0 --group=0 --mtime="1970-01-01 00:00:00 UTC" \ + --transform='s!^\.!${name}!' . - echo "channel - $out/tarballs/nixexprs.tar.xz" > "$out/nix-support/hydra-build-products" - echo $constituents > "$out/nix-support/hydra-aggregate-constituents" + echo "channel - $out/tarballs/nixexprs.tar.xz" > "$out/nix-support/hydra-build-products" + echo $constituents > "$out/nix-support/hydra-aggregate-constituents" - # Propagate build failures. - for i in $constituents; do - if [ -e "$i/nix-support/failed" ]; then - touch "$out/nix-support/failed" - fi - done - ''; + # Propagate build failures. + for i in $constituents; do + if [ -e "$i/nix-support/failed" ]; then + touch "$out/nix-support/failed" + fi + done + ''; - meta = meta // { - isHydraChannel = true; - }; - } // removeAttrs args [ "meta" ]); + meta = meta // { + isHydraChannel = true; + }; + } + // removeAttrs args [ "meta" ] + ); } diff --git a/pkgs/build-support/release/maven-build.nix b/pkgs/build-support/release/maven-build.nix index f618032724c9a0..7ac95a5e73de42 100644 --- a/pkgs/build-support/release/maven-build.nix +++ b/pkgs/build-support/release/maven-build.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, name -, src -, doTest ? true -, doTestCompile ? true -, doJavadoc ? false -, doCheckstyle ? false -, doRelease ? false -, includeTestClasses ? true -, extraMvnFlags ? "" -, ... -} @ args : +{ + stdenv, + lib, + name, + src, + doTest ? true, + doTestCompile ? true, + doJavadoc ? false, + doCheckstyle ? false, + doRelease ? false, + includeTestClasses ? true, + extraMvnFlags ? "", + ... +}@args: let mvnFlags = lib.escapeShellArgs [ @@ -20,84 +21,86 @@ let ]; in -stdenv.mkDerivation ( { - inherit name src; - phases = "setupPhase unpackPhase patchPhase mvnCompile ${lib.optionalString doTestCompile "mvnTestCompile mvnTestJar"} ${lib.optionalString doTest "mvnTest"} ${lib.optionalString doJavadoc "mvnJavadoc"} ${lib.optionalString doCheckstyle "mvnCheckstyle"} mvnJar mvnAssembly mvnRelease finalPhase"; - - setupPhase = '' - runHook preSetupPhase - - mkdir -p $out/nix-support - export LANG="en_US.UTF-8" - export LOCALE_ARCHIVE=$glibcLocales/lib/locale/locale-archive - export M2_REPO=$TMPDIR/repository - - runHook postSetupPhase - ''; - - mvnCompile = '' - mvn compile ${mvnFlags} - ''; - - mvnTestCompile = '' - mvn test-compile ${mvnFlags} - ''; - - mvnTestJar = '' - mvn jar:test-jar ${mvnFlags} - ''; - - mvnTest = '' - mvn test ${mvnFlags} - - if [ -d target/site/cobertura ] ; then - echo "report coverage $out/site/cobertura" >> $out/nix-support/hydra-build-products - fi - - if [ -d target/surefire-reports ] ; then - mvn surefire-report:report-only - echo "report coverage $out/site/surefire-report.html" >> $out/nix-support/hydra-build-products - fi - ''; - - mvnJavadoc = '' - mvn javadoc:javadoc ${mvnFlags} - echo "report javadoc $out/site/apidocs" >> $out/nix-support/hydra-build-products - ''; - - mvnCheckstyle = '' - mvn checkstyle:checkstyle ${mvnFlags} - echo "report checkstyle $out/site/checkstyle.html" >> $out/nix-support/hydra-build-products - ''; - - mvnJar = '' - mvn jar:jar ${mvnFlags} - ''; - - mvnAssembly = '' - mvn assembly:assembly -Dmaven.test.skip=true ${mvnFlags} - ''; - - mvnRelease = '' - mkdir -p $out/release - - zip=$(ls target/*.zip| head -1) - releaseName=$(basename $zip .zip) - releaseName="$releaseName-r${toString src.rev or "0"}" - cp $zip $out/release/$releaseName.zip - - echo "$releaseName" > $out/nix-support/hydra-release-name - - ${lib.optionalString doRelease '' - echo "file zip $out/release/$releaseName.zip" >> $out/nix-support/hydra-build-products - ''} - ''; - - finalPhase = '' - if [ -d target/site ] ; then - cp -R target/site $out/ - echo "report site $out/site" >> $out/nix-support/hydra-build-products - fi - ''; -} // args +stdenv.mkDerivation ( + { + inherit name src; + phases = "setupPhase unpackPhase patchPhase mvnCompile ${lib.optionalString doTestCompile "mvnTestCompile mvnTestJar"} ${lib.optionalString doTest "mvnTest"} ${lib.optionalString doJavadoc "mvnJavadoc"} ${lib.optionalString doCheckstyle "mvnCheckstyle"} mvnJar mvnAssembly mvnRelease finalPhase"; + + setupPhase = '' + runHook preSetupPhase + + mkdir -p $out/nix-support + export LANG="en_US.UTF-8" + export LOCALE_ARCHIVE=$glibcLocales/lib/locale/locale-archive + export M2_REPO=$TMPDIR/repository + + runHook postSetupPhase + ''; + + mvnCompile = '' + mvn compile ${mvnFlags} + ''; + + mvnTestCompile = '' + mvn test-compile ${mvnFlags} + ''; + + mvnTestJar = '' + mvn jar:test-jar ${mvnFlags} + ''; + + mvnTest = '' + mvn test ${mvnFlags} + + if [ -d target/site/cobertura ] ; then + echo "report coverage $out/site/cobertura" >> $out/nix-support/hydra-build-products + fi + + if [ -d target/surefire-reports ] ; then + mvn surefire-report:report-only + echo "report coverage $out/site/surefire-report.html" >> $out/nix-support/hydra-build-products + fi + ''; + + mvnJavadoc = '' + mvn javadoc:javadoc ${mvnFlags} + echo "report javadoc $out/site/apidocs" >> $out/nix-support/hydra-build-products + ''; + + mvnCheckstyle = '' + mvn checkstyle:checkstyle ${mvnFlags} + echo "report checkstyle $out/site/checkstyle.html" >> $out/nix-support/hydra-build-products + ''; + + mvnJar = '' + mvn jar:jar ${mvnFlags} + ''; + + mvnAssembly = '' + mvn assembly:assembly -Dmaven.test.skip=true ${mvnFlags} + ''; + + mvnRelease = '' + mkdir -p $out/release + + zip=$(ls target/*.zip| head -1) + releaseName=$(basename $zip .zip) + releaseName="$releaseName-r${toString src.rev or "0"}" + cp $zip $out/release/$releaseName.zip + + echo "$releaseName" > $out/nix-support/hydra-release-name + + ${lib.optionalString doRelease '' + echo "file zip $out/release/$releaseName.zip" >> $out/nix-support/hydra-build-products + ''} + ''; + + finalPhase = '' + if [ -d target/site ] ; then + cp -R target/site $out/ + echo "report site $out/site" >> $out/nix-support/hydra-build-products + fi + ''; + } + // args ) diff --git a/pkgs/build-support/release/nix-build.nix b/pkgs/build-support/release/nix-build.nix index 8d59809174640c..6686aee601b0d4 100644 --- a/pkgs/build-support/release/nix-build.nix +++ b/pkgs/build-support/release/nix-build.nix @@ -5,22 +5,26 @@ # it turns on GCC's coverage analysis feature. It then runs `make # check' and produces a coverage analysis report using `lcov'. -{ buildOutOfSourceTree ? false -, preConfigure ? null -, doCoverageAnalysis ? false -, doClangAnalysis ? false -, doCoverityAnalysis ? false -, lcovFilter ? [] -, lcovExtraTraceFiles ? [] -, src, lib, stdenv -, name ? if doCoverageAnalysis then "nix-coverage" else "nix-build" -, failureHook ? null -, prePhases ? [] -, postPhases ? [] -, buildInputs ? [] -, preHook ? "" -, postHook ? "" -, ... } @ args: +{ + buildOutOfSourceTree ? false, + preConfigure ? null, + doCoverageAnalysis ? false, + doClangAnalysis ? false, + doCoverityAnalysis ? false, + lcovFilter ? [ ], + lcovExtraTraceFiles ? [ ], + src, + lib, + stdenv, + name ? if doCoverageAnalysis then "nix-coverage" else "nix-build", + failureHook ? null, + prePhases ? [ ], + postPhases ? [ ], + buildInputs ? [ ], + preHook ? "", + postHook ? "", + ... +}@args: let doingAnalysis = doCoverageAnalysis || doClangAnalysis || doCoverityAnalysis; @@ -37,49 +41,49 @@ stdenv.mkDerivation ( showBuildStats = true; - finalPhase = - '' - # Propagate the release name of the source tarball. This is - # to get nice package names in channels. - if test -e $origSrc/nix-support/hydra-release-name; then - cp $origSrc/nix-support/hydra-release-name $out/nix-support/hydra-release-name - fi + finalPhase = '' + # Propagate the release name of the source tarball. This is + # to get nice package names in channels. + if test -e $origSrc/nix-support/hydra-release-name; then + cp $origSrc/nix-support/hydra-release-name $out/nix-support/hydra-release-name + fi - # Package up Coverity analysis results - if [ ! -z "${toString doCoverityAnalysis}" ]; then - if [ -d "_coverity_$name/cov-int" ]; then - mkdir -p $out/tarballs - NAME=`cat $out/nix-support/hydra-release-name` - cd _coverity_$name - tar caf $out/tarballs/$NAME-coverity-int.xz cov-int - echo "file cov-build $out/tarballs/$NAME-coverity-int.xz" >> $out/nix-support/hydra-build-products - fi + # Package up Coverity analysis results + if [ ! -z "${toString doCoverityAnalysis}" ]; then + if [ -d "_coverity_$name/cov-int" ]; then + mkdir -p $out/tarballs + NAME=`cat $out/nix-support/hydra-release-name` + cd _coverity_$name + tar caf $out/tarballs/$NAME-coverity-int.xz cov-int + echo "file cov-build $out/tarballs/$NAME-coverity-int.xz" >> $out/nix-support/hydra-build-products fi + fi - # Package up Clang analysis results - if [ ! -z "${toString doClangAnalysis}" ]; then - if [ ! -z "`ls _clang_analyze_$name`" ]; then - cd _clang_analyze_$name && mv * $out/analysis - else - mkdir -p $out/analysis - echo "No bugs found." >> $out/analysis/index.html - fi - - echo "report analysis $out/analysis" >> $out/nix-support/hydra-build-products + # Package up Clang analysis results + if [ ! -z "${toString doClangAnalysis}" ]; then + if [ ! -z "`ls _clang_analyze_$name`" ]; then + cd _clang_analyze_$name && mv * $out/analysis + else + mkdir -p $out/analysis + echo "No bugs found." >> $out/analysis/index.html fi - ''; - failureHook = (lib.optionalString (failureHook != null) failureHook) + - '' - if test -n "$succeedOnFailure"; then - if test -n "$keepBuildDirectory"; then - KEEPBUILDDIR="$out/`basename $TMPDIR`" - echo "Copying build directory to $KEEPBUILDDIR" - mkdir -p $KEEPBUILDDIR - cp -R "$TMPDIR/"* $KEEPBUILDDIR - fi + echo "report analysis $out/analysis" >> $out/nix-support/hydra-build-products fi ''; + + failureHook = + (lib.optionalString (failureHook != null) failureHook) + + '' + if test -n "$succeedOnFailure"; then + if test -n "$keepBuildDirectory"; then + KEEPBUILDDIR="$out/`basename $TMPDIR`" + echo "Copying build directory to $KEEPBUILDDIR" + mkdir -p $KEEPBUILDDIR + cp -R "$TMPDIR/"* $KEEPBUILDDIR + fi + fi + ''; } // removeAttrs args [ "lib" ] # Propagating lib causes the evaluation to fail, because lib is a function that can't be converted to a string @@ -131,36 +135,36 @@ stdenv.mkDerivation ( fi ''; - prePhases = ["initPhase"] ++ prePhases; + prePhases = [ "initPhase" ] ++ prePhases; buildInputs = - buildInputs ++ - (lib.optional doCoverageAnalysis args.makeGCOVReport) ++ - (lib.optional doClangAnalysis args.clang-analyzer) ++ - (lib.optional doCoverityAnalysis args.cov-build) ++ - (lib.optional doCoverityAnalysis args.xz); + buildInputs + ++ (lib.optional doCoverageAnalysis args.makeGCOVReport) + ++ (lib.optional doClangAnalysis args.clang-analyzer) + ++ (lib.optional doCoverityAnalysis args.cov-build) + ++ (lib.optional doCoverityAnalysis args.xz); - lcovFilter = ["${builtins.storeDir}/*"] ++ lcovFilter; + lcovFilter = [ "${builtins.storeDir}/*" ] ++ lcovFilter; inherit lcovExtraTraceFiles; - postPhases = postPhases ++ ["finalPhase"]; + postPhases = postPhases ++ [ "finalPhase" ]; meta = (lib.optionalAttrs (args ? meta) args.meta) // { - description = if doCoverageAnalysis then "Coverage analysis" else "Nix package for ${stdenv.hostPlatform.system}"; + description = + if doCoverageAnalysis then "Coverage analysis" else "Nix package for ${stdenv.hostPlatform.system}"; }; } // - (lib.optionalAttrs buildOutOfSourceTree - { - preConfigure = - # Build out of source tree and make the source tree read-only. This - # helps catch violations of the GNU Coding Standards (info - # "(standards) Configuration"), like `make distcheck' does. - '' + (lib.optionalAttrs buildOutOfSourceTree { + preConfigure = + # Build out of source tree and make the source tree read-only. This + # helps catch violations of the GNU Coding Standards (info + # "(standards) Configuration"), like `make distcheck' does. + '' mkdir "../build" cd "../build" configureScript="../$sourceRoot/configure" @@ -169,7 +173,6 @@ stdenv.mkDerivation ( echo "building out of source tree, from \`$PWD'..." ${lib.optionalString (preConfigure != null) preConfigure} - ''; - } - ) + ''; + }) ) diff --git a/pkgs/build-support/release/rpm-build.nix b/pkgs/build-support/release/rpm-build.nix index ccbbd57107bdc3..ee50f0a1e63b42 100644 --- a/pkgs/build-support/release/rpm-build.nix +++ b/pkgs/build-support/release/rpm-build.nix @@ -1,54 +1,59 @@ # This function builds an RPM from a source tarball that contains a # RPM spec file (i.e., one that can be built using `rpmbuild -ta'). -{ name ? "rpm-build" -, diskImage -, src, lib, vmTools -, ... } @ args: +{ + name ? "rpm-build", + diskImage, + src, + lib, + vmTools, + ... +}@args: vmTools.buildRPM ( - removeAttrs args ["vmTools"] // - - { - name = name + "-" + diskImage.name + (lib.optionalString (src ? version) "-${src.version}"); - - preBuild = '' - . ${./functions.sh} - propagateImageName - src=$(findTarball $src) - ''; - - postInstall = '' - declare -a rpms rpmNames - for i in $out/rpms/*/*.rpm; do - if echo $i | grep -vq "\.src\.rpm$"; then - echo "file rpm $i" >> $out/nix-support/hydra-build-products - rpms+=($i) - rpmNames+=("$(rpm -qp "$i")") - fi - done - - echo "installing ''${rpms[*]}..." - rpm -Up ''${rpms[*]} --excludepath /nix/store - - eval "$postRPMInstall" - - echo "uninstalling ''${rpmNames[*]}..." - rpm -e ''${rpmNames[*]} --nodeps - - for i in $out/rpms/*/*.src.rpm; do - echo "file srpm $i" >> $out/nix-support/hydra-build-products - done - - for rpmdir in $extraRPMs ; do - echo "file rpm-extra $(ls $rpmdir/rpms/*/*.rpm | grep -v 'src\.rpm' | sort | head -1)" >> $out/nix-support/hydra-build-products - done - ''; - - meta = (lib.optionalAttrs (args ? meta) args.meta) // { - description = "RPM package for ${diskImage.fullName}"; - }; - } + removeAttrs args [ "vmTools" ] + // + + { + name = name + "-" + diskImage.name + (lib.optionalString (src ? version) "-${src.version}"); + + preBuild = '' + . ${./functions.sh} + propagateImageName + src=$(findTarball $src) + ''; + + postInstall = '' + declare -a rpms rpmNames + for i in $out/rpms/*/*.rpm; do + if echo $i | grep -vq "\.src\.rpm$"; then + echo "file rpm $i" >> $out/nix-support/hydra-build-products + rpms+=($i) + rpmNames+=("$(rpm -qp "$i")") + fi + done + + echo "installing ''${rpms[*]}..." + rpm -Up ''${rpms[*]} --excludepath /nix/store + + eval "$postRPMInstall" + + echo "uninstalling ''${rpmNames[*]}..." + rpm -e ''${rpmNames[*]} --nodeps + + for i in $out/rpms/*/*.src.rpm; do + echo "file srpm $i" >> $out/nix-support/hydra-build-products + done + + for rpmdir in $extraRPMs ; do + echo "file rpm-extra $(ls $rpmdir/rpms/*/*.rpm | grep -v 'src\.rpm' | sort | head -1)" >> $out/nix-support/hydra-build-products + done + ''; + + meta = (lib.optionalAttrs (args ? meta) args.meta) // { + description = "RPM package for ${diskImage.fullName}"; + }; + } ) diff --git a/pkgs/build-support/release/source-tarball.nix b/pkgs/build-support/release/source-tarball.nix index 4effd63f740bb7..5abd4e97f327d4 100644 --- a/pkgs/build-support/release/source-tarball.nix +++ b/pkgs/build-support/release/source-tarball.nix @@ -2,18 +2,26 @@ # checkout from a Subversion or CVS repository) into a source tarball # by running `autoreconf', `configure' and `make dist'. -{ officialRelease ? false -, buildInputs ? [] -, name ? "source-tarball" -, version ? "0" -, versionSuffix ? - if officialRelease - then "" - else "pre${toString (src.rev or src.revCount or "")}" -, src, lib, stdenv, autoconf, automake, libtool -, # By default, provide all the GNU Build System as input. - bootstrapBuildInputs ? [ autoconf automake libtool ] -, ... } @ args: +{ + officialRelease ? false, + buildInputs ? [ ], + name ? "source-tarball", + version ? "0", + versionSuffix ? if officialRelease then "" else "pre${toString (src.rev or src.revCount or "")}", + src, + lib, + stdenv, + autoconf, + automake, + libtool, + # By default, provide all the GNU Build System as input. + bootstrapBuildInputs ? [ + autoconf + automake + libtool + ], + ... +}@args: stdenv.mkDerivation ( @@ -73,57 +81,58 @@ stdenv.mkDerivation ( } # Then, the caller-supplied attributes. - // (builtins.removeAttrs args [ "lib" ]) // - - # And finally, our own stuff. - { - name = name + "-" + version + versionSuffix; - - buildInputs = buildInputs ++ bootstrapBuildInputs; - - preUnpack = '' - mkdir -p $out/nix-support - ''; - - postUnpack = '' - # Set all source files to the current date. This is because Nix - # resets the timestamp on all files to 0 (1/1/1970), which some - # people don't like (in particular GNU tar prints harmless but - # frightening warnings about it). - touch now - touch -d "1970-01-01 00:00:00 UTC" then - find $sourceRoot ! -newer then -print0 | xargs -0r touch --reference now - rm now then - eval "$nextPostUnpack" - ''; - - nextPostUnpack = if args ? postUnpack then args.postUnpack else ""; - - # Cause distPhase to copy tar.bz2 in addition to tar.gz. - tarballs = "*.tar.gz *.tar.bz2 *.tar.xz"; - - finalPhase = '' - for i in "$out/tarballs/"*; do - echo "file source-dist $i" >> $out/nix-support/hydra-build-products - done - - # Try to figure out the release name. - releaseName=$( (cd $out/tarballs && ls) | head -n 1 | sed -e 's^\.[a-z].*^^') - test -n "$releaseName" && (echo "$releaseName" >> $out/nix-support/hydra-release-name) - ''; - - passthru = { - inherit src; - version = version + versionSuffix; - }; - - meta = (lib.optionalAttrs (args ? meta) args.meta) // { - description = "Source distribution"; - - # Tarball builds are generally important, so give them a high - # default priority. - schedulingPriority = 200; - }; - } + // (builtins.removeAttrs args [ "lib" ]) + // + + # And finally, our own stuff. + { + name = name + "-" + version + versionSuffix; + + buildInputs = buildInputs ++ bootstrapBuildInputs; + + preUnpack = '' + mkdir -p $out/nix-support + ''; + + postUnpack = '' + # Set all source files to the current date. This is because Nix + # resets the timestamp on all files to 0 (1/1/1970), which some + # people don't like (in particular GNU tar prints harmless but + # frightening warnings about it). + touch now + touch -d "1970-01-01 00:00:00 UTC" then + find $sourceRoot ! -newer then -print0 | xargs -0r touch --reference now + rm now then + eval "$nextPostUnpack" + ''; + + nextPostUnpack = if args ? postUnpack then args.postUnpack else ""; + + # Cause distPhase to copy tar.bz2 in addition to tar.gz. + tarballs = "*.tar.gz *.tar.bz2 *.tar.xz"; + + finalPhase = '' + for i in "$out/tarballs/"*; do + echo "file source-dist $i" >> $out/nix-support/hydra-build-products + done + + # Try to figure out the release name. + releaseName=$( (cd $out/tarballs && ls) | head -n 1 | sed -e 's^\.[a-z].*^^') + test -n "$releaseName" && (echo "$releaseName" >> $out/nix-support/hydra-release-name) + ''; + + passthru = { + inherit src; + version = version + versionSuffix; + }; + + meta = (lib.optionalAttrs (args ? meta) args.meta) // { + description = "Source distribution"; + + # Tarball builds are generally important, so give them a high + # default priority. + schedulingPriority = 200; + }; + } ) diff --git a/pkgs/build-support/remove-references-to/default.nix b/pkgs/build-support/remove-references-to/default.nix index 1277cdb04fd7c7..30c79821b9068b 100644 --- a/pkgs/build-support/remove-references-to/default.nix +++ b/pkgs/build-support/remove-references-to/default.nix @@ -3,7 +3,12 @@ # non-existent path (/nix/store/eeee...). This is useful for getting rid of # dependencies that you know are not actually needed at runtime. -{ lib, stdenvNoCC, signingUtils, shell ? stdenvNoCC.shell }: +{ + lib, + stdenvNoCC, + signingUtils, + shell ? stdenvNoCC.shell, +}: let stdenv = stdenvNoCC; diff --git a/pkgs/build-support/replace-secret/replace-secret.nix b/pkgs/build-support/replace-secret/replace-secret.nix index 41f5cb042558c0..7e661a012bc31c 100644 --- a/pkgs/build-support/replace-secret/replace-secret.nix +++ b/pkgs/build-support/replace-secret/replace-secret.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, python3 }: +{ + stdenv, + lib, + python3, +}: stdenv.mkDerivation { name = "replace-secret"; diff --git a/pkgs/build-support/rust/build-rust-crate/build-crate.nix b/pkgs/build-support/rust/build-rust-crate/build-crate.nix index 4bf1b188cd1c55..32ab0fd55c3b45 100644 --- a/pkgs/build-support/rust/build-rust-crate/build-crate.nix +++ b/pkgs/build-support/rust/build-rust-crate/build-crate.nix @@ -1,98 +1,130 @@ -{ lib, stdenv -, mkRustcDepArgs, mkRustcFeatureArgs, needUnstableCLI, rustc +{ + lib, + stdenv, + mkRustcDepArgs, + mkRustcFeatureArgs, + needUnstableCLI, + rustc, }: -{ crateName, +{ + crateName, dependencies, - crateFeatures, crateRenames, libName, release, libPath, - crateType, metadata, crateBin, hasCrateBin, - extraRustcOpts, verbose, colors, + crateFeatures, + crateRenames, + libName, + release, + libPath, + crateType, + metadata, + crateBin, + hasCrateBin, + extraRustcOpts, + verbose, + colors, buildTests, - codegenUnits + codegenUnits, }: - let - baseRustcOpts = - [ - (if release then "-C opt-level=3" else "-C debuginfo=2") - "-C codegen-units=${toString codegenUnits}" - "--remap-path-prefix=$NIX_BUILD_TOP=/" - (mkRustcDepArgs dependencies crateRenames) - (mkRustcFeatureArgs crateFeatures) - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "--target" stdenv.hostPlatform.rust.rustcTargetSpec - ] ++ lib.optionals (needUnstableCLI dependencies) [ - "-Z" "unstable-options" - ] ++ extraRustcOpts - # since rustc 1.42 the "proc_macro" crate is part of the default crate prelude - # https://github.com/rust-lang/cargo/commit/4d64eb99a4#diff-7f98585dbf9d30aa100c8318e2c77e79R1021-R1022 - ++ lib.optional (lib.elem "proc-macro" crateType) "--extern proc_macro" - ++ lib.optional (stdenv.hostPlatform.linker == "lld" && rustc ? llvmPackages.lld) # Needed when building for targets that use lld. e.g. 'wasm32-unknown-unknown' +let + baseRustcOpts = + [ + (if release then "-C opt-level=3" else "-C debuginfo=2") + "-C codegen-units=${toString codegenUnits}" + "--remap-path-prefix=$NIX_BUILD_TOP=/" + (mkRustcDepArgs dependencies crateRenames) + (mkRustcFeatureArgs crateFeatures) + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "--target" + stdenv.hostPlatform.rust.rustcTargetSpec + ] + ++ lib.optionals (needUnstableCLI dependencies) [ + "-Z" + "unstable-options" + ] + ++ extraRustcOpts + # since rustc 1.42 the "proc_macro" crate is part of the default crate prelude + # https://github.com/rust-lang/cargo/commit/4d64eb99a4#diff-7f98585dbf9d30aa100c8318e2c77e79R1021-R1022 + ++ lib.optional (lib.elem "proc-macro" crateType) "--extern proc_macro" + ++ + lib.optional (stdenv.hostPlatform.linker == "lld" && rustc ? llvmPackages.lld) # Needed when building for targets that use lld. e.g. 'wasm32-unknown-unknown' "-C linker=${rustc.llvmPackages.lld}/bin/lld" - ++ lib.optional (stdenv.hasCC && stdenv.hostPlatform.linker != "lld") - "-C linker=${stdenv.cc}/bin/${stdenv.cc.targetPrefix}cc" - ; - rustcMeta = "-C metadata=${metadata} -C extra-filename=-${metadata}"; - - - # build the final rustc arguments that can be different between different - # crates - libRustcOpts = lib.concatStringsSep " " ( - baseRustcOpts - ++ [rustcMeta] - ++ (map (x: "--crate-type ${x}") crateType) - ); - - binRustcOpts = lib.concatStringsSep " " baseRustcOpts; - - build_bin = if buildTests then "build_bin_test" else "build_bin"; - in '' - runHook preBuild - - # configure & source common build functions - LIB_RUSTC_OPTS="${libRustcOpts}" - BIN_RUSTC_OPTS="${binRustcOpts}" - LIB_EXT="${stdenv.hostPlatform.extensions.library}" - LIB_PATH="${libPath}" - LIB_NAME="${libName}" - - CRATE_NAME='${lib.replaceStrings ["-"] ["_"] libName}' - - setup_link_paths - - if [[ -e "$LIB_PATH" ]]; then - build_lib "$LIB_PATH" - ${lib.optionalString buildTests ''build_lib_test "$LIB_PATH"''} - elif [[ -e src/lib.rs ]]; then - build_lib src/lib.rs - ${lib.optionalString buildTests "build_lib_test src/lib.rs"} - fi - - - - ${lib.optionalString (lib.length crateBin > 0) (lib.concatMapStringsSep "\n" (bin: - let - haveRequiredFeature = if bin ? requiredFeatures then - # Check that all element in requiredFeatures are also present in crateFeatures - lib.intersectLists bin.requiredFeatures crateFeatures == bin.requiredFeatures + ++ lib.optional ( + stdenv.hasCC && stdenv.hostPlatform.linker != "lld" + ) "-C linker=${stdenv.cc}/bin/${stdenv.cc.targetPrefix}cc"; + rustcMeta = "-C metadata=${metadata} -C extra-filename=-${metadata}"; + + # build the final rustc arguments that can be different between different + # crates + libRustcOpts = lib.concatStringsSep " " ( + baseRustcOpts ++ [ rustcMeta ] ++ (map (x: "--crate-type ${x}") crateType) + ); + + binRustcOpts = lib.concatStringsSep " " baseRustcOpts; + + build_bin = if buildTests then "build_bin_test" else "build_bin"; +in +'' + runHook preBuild + + # configure & source common build functions + LIB_RUSTC_OPTS="${libRustcOpts}" + BIN_RUSTC_OPTS="${binRustcOpts}" + LIB_EXT="${stdenv.hostPlatform.extensions.library}" + LIB_PATH="${libPath}" + LIB_NAME="${libName}" + + CRATE_NAME='${lib.replaceStrings [ "-" ] [ "_" ] libName}' + + setup_link_paths + + if [[ -e "$LIB_PATH" ]]; then + build_lib "$LIB_PATH" + ${lib.optionalString buildTests ''build_lib_test "$LIB_PATH"''} + elif [[ -e src/lib.rs ]]; then + build_lib src/lib.rs + ${lib.optionalString buildTests "build_lib_test src/lib.rs"} + fi + + + + ${lib.optionalString (lib.length crateBin > 0) ( + lib.concatMapStringsSep "\n" ( + bin: + let + haveRequiredFeature = + if bin ? requiredFeatures then + # Check that all element in requiredFeatures are also present in crateFeatures + lib.intersectLists bin.requiredFeatures crateFeatures == bin.requiredFeatures + else + true; + in + if haveRequiredFeature then + '' + mkdir -p target/bin + BIN_NAME='${bin.name or crateName}' + ${ + if !bin ? path then + '' + BIN_PATH="" + search_for_bin_path "$BIN_NAME" + '' + else + '' + BIN_PATH='${bin.path}' + '' + } + ${build_bin} "$BIN_NAME" "$BIN_PATH" + '' else - true; - in - if haveRequiredFeature then '' - mkdir -p target/bin - BIN_NAME='${bin.name or crateName}' - ${if !bin ? path then '' - BIN_PATH="" - search_for_bin_path "$BIN_NAME" - '' else '' - BIN_PATH='${bin.path}' - ''} - ${build_bin} "$BIN_NAME" "$BIN_PATH" - '' else '' - echo Binary ${bin.name or crateName} not compiled due to not having all of the required features -- ${lib.escapeShellArg (builtins.toJSON bin.requiredFeatures)} -- enabled. - '') crateBin)} - - ${lib.optionalString buildTests '' + '' + echo Binary ${bin.name or crateName} not compiled due to not having all of the required features -- ${lib.escapeShellArg (builtins.toJSON bin.requiredFeatures)} -- enabled. + '' + ) crateBin + )} + + ${lib.optionalString buildTests '' # When tests are enabled build all the files in the `tests` directory as # test binaries. if [ -d tests ]; then @@ -110,21 +142,21 @@ done fi - ''} + ''} - # If crateBin is empty and hasCrateBin is not set then we must try to - # detect some kind of bin target based on some files that might exist. - ${lib.optionalString (lib.length crateBin == 0 && !hasCrateBin) '' - if [[ -e src/main.rs ]]; then - mkdir -p target/bin - ${build_bin} ${crateName} src/main.rs - fi - for i in src/bin/*.rs; do #*/ - mkdir -p target/bin - ${build_bin} "$(basename $i .rs)" "$i" - done - ''} - # Remove object files to avoid "wrong ELF type" - find target -type f -name "*.o" -print0 | xargs -0 rm -f - runHook postBuild - '' + # If crateBin is empty and hasCrateBin is not set then we must try to + # detect some kind of bin target based on some files that might exist. + ${lib.optionalString (lib.length crateBin == 0 && !hasCrateBin) '' + if [[ -e src/main.rs ]]; then + mkdir -p target/bin + ${build_bin} ${crateName} src/main.rs + fi + for i in src/bin/*.rs; do #*/ + mkdir -p target/bin + ${build_bin} "$(basename $i .rs)" "$i" + done + ''} + # Remove object files to avoid "wrong ELF type" + find target -type f -name "*.o" -print0 | xargs -0 rm -f + runHook postBuild +'' diff --git a/pkgs/build-support/rust/build-rust-crate/configure-crate.nix b/pkgs/build-support/rust/build-rust-crate/configure-crate.nix index c348885e44cab8..30f13b988c6aac 100644 --- a/pkgs/build-support/rust/build-rust-crate/configure-crate.nix +++ b/pkgs/build-support/rust/build-rust-crate/configure-crate.nix @@ -1,63 +1,73 @@ -{ lib, stdenv, echo_colored, noisily, mkRustcDepArgs, mkRustcFeatureArgs }: { - build -, buildDependencies -, codegenUnits -, colors -, completeBuildDeps -, completeDeps -, crateAuthors -, crateDescription -, crateFeatures -, crateHomepage -, crateLicense -, crateLicenseFile -, crateLinks -, crateName -, crateType -, crateReadme -, crateRenames -, crateRepository -, crateRustVersion -, crateVersion -, extraLinkFlags -, extraRustcOptsForBuildRs -, libName -, libPath -, release -, verbose -, workspace_member }: -let version_ = lib.splitString "-" crateVersion; - versionPre = lib.optionalString (lib.tail version_ != []) (lib.elemAt version_ 1); - version = lib.splitVersion (lib.head version_); - rustcOpts = lib.foldl' (opts: opt: opts + " " + opt) - (if release then "-C opt-level=3" else "-C debuginfo=2") - (["-C codegen-units=${toString codegenUnits}"] ++ extraRustcOptsForBuildRs); - buildDeps = mkRustcDepArgs buildDependencies crateRenames; - authors = lib.concatStringsSep ":" crateAuthors; - optLevel = if release then 3 else 0; - completeDepsDir = lib.concatStringsSep " " completeDeps; - completeBuildDepsDir = lib.concatStringsSep " " completeBuildDeps; - envFeatures = lib.concatStringsSep " " ( - map (f: lib.replaceStrings ["-"] ["_"] (lib.toUpper f)) crateFeatures - ); -in '' + lib, + stdenv, + echo_colored, + noisily, + mkRustcDepArgs, + mkRustcFeatureArgs, +}: +{ + build, + buildDependencies, + codegenUnits, + colors, + completeBuildDeps, + completeDeps, + crateAuthors, + crateDescription, + crateFeatures, + crateHomepage, + crateLicense, + crateLicenseFile, + crateLinks, + crateName, + crateType, + crateReadme, + crateRenames, + crateRepository, + crateRustVersion, + crateVersion, + extraLinkFlags, + extraRustcOptsForBuildRs, + libName, + libPath, + release, + verbose, + workspace_member, +}: +let + version_ = lib.splitString "-" crateVersion; + versionPre = lib.optionalString (lib.tail version_ != [ ]) (lib.elemAt version_ 1); + version = lib.splitVersion (lib.head version_); + rustcOpts = lib.foldl' (opts: opt: opts + " " + opt) ( + if release then "-C opt-level=3" else "-C debuginfo=2" + ) ([ "-C codegen-units=${toString codegenUnits}" ] ++ extraRustcOptsForBuildRs); + buildDeps = mkRustcDepArgs buildDependencies crateRenames; + authors = lib.concatStringsSep ":" crateAuthors; + optLevel = if release then 3 else 0; + completeDepsDir = lib.concatStringsSep " " completeDeps; + completeBuildDepsDir = lib.concatStringsSep " " completeBuildDeps; + envFeatures = lib.concatStringsSep " " ( + map (f: lib.replaceStrings [ "-" ] [ "_" ] (lib.toUpper f)) crateFeatures + ); +in +'' ${echo_colored colors} ${noisily colors verbose} source ${./lib.sh} ${lib.optionalString (workspace_member != null) '' - noisily cd "${workspace_member}" -''} + noisily cd "${workspace_member}" + ''} ${lib.optionalString (workspace_member == null) '' - echo_colored "Searching for matching Cargo.toml (${crateName})" - local cargo_toml_dir=$(matching_cargo_toml_dir "${crateName}") - if [ -z "$cargo_toml_dir" ]; then - echo_error "ERROR configuring ${crateName}: No matching Cargo.toml in $(pwd) found." >&2 - exit 23 - fi - noisily cd "$cargo_toml_dir" -''} + echo_colored "Searching for matching Cargo.toml (${crateName})" + local cargo_toml_dir=$(matching_cargo_toml_dir "${crateName}") + if [ -z "$cargo_toml_dir" ]; then + echo_error "ERROR configuring ${crateName}: No matching Cargo.toml in $(pwd) found." >&2 + exit 23 + fi + noisily cd "$cargo_toml_dir" + ''} runHook preConfigure @@ -138,8 +148,12 @@ in '' export CARGO_CFG_TARGET_FAMILY="unix" export CARGO_CFG_UNIX=1 export CARGO_CFG_TARGET_ENV="gnu" - export CARGO_CFG_TARGET_ENDIAN=${if stdenv.hostPlatform.parsed.cpu.significantByte.name == "littleEndian" then "little" else "big"} - export CARGO_CFG_TARGET_POINTER_WIDTH=${with stdenv.hostPlatform; toString (if isILP32 then 32 else parsed.cpu.bits)} + export CARGO_CFG_TARGET_ENDIAN=${ + if stdenv.hostPlatform.parsed.cpu.significantByte.name == "littleEndian" then "little" else "big" + } + export CARGO_CFG_TARGET_POINTER_WIDTH=${ + with stdenv.hostPlatform; toString (if isILP32 then 32 else parsed.cpu.bits) + } export CARGO_CFG_TARGET_VENDOR=${stdenv.hostPlatform.parsed.vendor.name} export CARGO_MANIFEST_DIR=$(pwd) @@ -211,9 +225,9 @@ in '' EXTRA_LINK_SEARCH=$(sed -n "s/^cargo::\{0,1\}rustc-link-search=\(.*\)/\1/p" target/build/${crateName}.opt | tr '\n' ' ' | sort -u) ${lib.optionalString (lib.elem "cdylib" crateType) '' - CRATE_TYPE_IS_CDYLIB="true" - EXTRA_CDYLIB_LINK_ARGS=$(sed -n "s/^cargo::\{0,1\}rustc-cdylib-link-arg=\(.*\)/-C link-arg=\1/p" target/build/${crateName}.opt | tr '\n' ' ') -''} + CRATE_TYPE_IS_CDYLIB="true" + EXTRA_CDYLIB_LINK_ARGS=$(sed -n "s/^cargo::\{0,1\}rustc-cdylib-link-arg=\(.*\)/-C link-arg=\1/p" target/build/${crateName}.opt | tr '\n' ' ') + ''} # We want to read part of every line that has cargo:rustc-env= prefix and # export it as environment variables. This turns out tricky if the lines diff --git a/pkgs/build-support/rust/build-rust-crate/helpers.nix b/pkgs/build-support/rust/build-rust-crate/helpers.nix index 386d0ce7084f04..a72bb505a40148 100644 --- a/pkgs/build-support/rust/build-rust-crate/helpers.nix +++ b/pkgs/build-support/rust/build-rust-crate/helpers.nix @@ -1,26 +1,35 @@ -{stdenv, lib}: +{ stdenv, lib }: { kernel = stdenv.hostPlatform.parsed.kernel.name; abi = stdenv.hostPlatform.parsed.abi.name; cpu = stdenv.hostPlatform.parsed.cpu.name; - updateFeatures = f: up: functions: lib.deepSeq f (lib.foldl' (features: fun: fun features) (lib.attrsets.recursiveUpdate f up) functions); - mapFeatures = features: map (fun: fun { features = features; }); - mkFeatures = feat: lib.foldl (features: featureName: - if feat.${featureName} or false then - [ featureName ] ++ features - else - features - ) [] (lib.attrNames feat); - include = includedFiles: src: builtins.filterSource (path: type: - lib.any (f: - let p = toString (src + ("/" + f)); - in - p == path || (lib.strings.hasPrefix (p + "/") path) - ) includedFiles - ) src; - exclude = excludedFiles: src: builtins.filterSource (path: type: - lib.all (f: - !lib.strings.hasPrefix (toString (src + ("/" + f))) path - ) excludedFiles - ) src; + updateFeatures = + f: up: functions: + lib.deepSeq f ( + lib.foldl' (features: fun: fun features) (lib.attrsets.recursiveUpdate f up) functions + ); + mapFeatures = features: map (fun: fun { features = features; }); + mkFeatures = + feat: + lib.foldl ( + features: featureName: + if feat.${featureName} or false then [ featureName ] ++ features else features + ) [ ] (lib.attrNames feat); + include = + includedFiles: src: + builtins.filterSource ( + path: type: + lib.any ( + f: + let + p = toString (src + ("/" + f)); + in + p == path || (lib.strings.hasPrefix (p + "/") path) + ) includedFiles + ) src; + exclude = + excludedFiles: src: + builtins.filterSource ( + path: type: lib.all (f: !lib.strings.hasPrefix (toString (src + ("/" + f))) path) excludedFiles + ) src; } diff --git a/pkgs/build-support/rust/build-rust-crate/install-crate.nix b/pkgs/build-support/rust/build-rust-crate/install-crate.nix index 7c7c102833d85a..b35652ad454a77 100644 --- a/pkgs/build-support/rust/build-rust-crate/install-crate.nix +++ b/pkgs/build-support/rust/build-rust-crate/install-crate.nix @@ -1,51 +1,53 @@ { stdenv }: crateName: metadata: buildTests: -if !buildTests then '' - runHook preInstall - # always create $out even if we do not have binaries. We are detecting binary targets during compilation, if those are missing there is no way to only have $lib - mkdir $out - if [[ -s target/env ]]; then - mkdir -p $lib - cp target/env $lib/env - fi - if [[ -s target/link.final ]]; then - mkdir -p $lib/lib - cp target/link.final $lib/lib/link - fi - if [[ "$(ls -A target/lib)" ]]; then - mkdir -p $lib/lib - cp -r target/lib/* $lib/lib #*/ - for library in $lib/lib/*.so $lib/lib/*.dylib; do #*/ - ln -s $library $(echo $library | sed -e "s/-${metadata}//") - done - fi - if [[ "$(ls -A target/build)" ]]; then # */ - mkdir -p $lib/lib - cp -r target/build/* $lib/lib # */ - fi - if [[ -d target/bin ]]; then - if [[ "$(ls -A target/bin)" ]]; then - mkdir -p $out/bin - cp -rP target/bin/* $out/bin # */ +if !buildTests then + '' + runHook preInstall + # always create $out even if we do not have binaries. We are detecting binary targets during compilation, if those are missing there is no way to only have $lib + mkdir $out + if [[ -s target/env ]]; then + mkdir -p $lib + cp target/env $lib/env fi - fi - runHook postInstall -'' else -# for tests we just put them all in the output. No execution. -'' - runHook preInstall + if [[ -s target/link.final ]]; then + mkdir -p $lib/lib + cp target/link.final $lib/lib/link + fi + if [[ "$(ls -A target/lib)" ]]; then + mkdir -p $lib/lib + cp -r target/lib/* $lib/lib #*/ + for library in $lib/lib/*.so $lib/lib/*.dylib; do #*/ + ln -s $library $(echo $library | sed -e "s/-${metadata}//") + done + fi + if [[ "$(ls -A target/build)" ]]; then # */ + mkdir -p $lib/lib + cp -r target/build/* $lib/lib # */ + fi + if [[ -d target/bin ]]; then + if [[ "$(ls -A target/bin)" ]]; then + mkdir -p $out/bin + cp -rP target/bin/* $out/bin # */ + fi + fi + runHook postInstall + '' +else + # for tests we just put them all in the output. No execution. + '' + runHook preInstall - mkdir -p $out/tests - if [ -e target/bin ]; then - find target/bin/ -type f -executable -exec cp {} $out/tests \; - fi - if [ -e target/lib ]; then - find target/lib/ -type f \! -name '*.rlib' \ - -a \! -name '*${stdenv.hostPlatform.extensions.library}' \ - -a \! -name '*.d' \ - -executable \ - -print0 | xargs --no-run-if-empty --null install --target $out/tests; - fi + mkdir -p $out/tests + if [ -e target/bin ]; then + find target/bin/ -type f -executable -exec cp {} $out/tests \; + fi + if [ -e target/lib ]; then + find target/lib/ -type f \! -name '*.rlib' \ + -a \! -name '*${stdenv.hostPlatform.extensions.library}' \ + -a \! -name '*.d' \ + -executable \ + -print0 | xargs --no-run-if-empty --null install --target $out/tests; + fi - runHook postInstall -'' + runHook postInstall + '' diff --git a/pkgs/build-support/rust/build-rust-crate/log.nix b/pkgs/build-support/rust/build-rust-crate/log.nix index cb0846190eac93..b1a07f1a9589c2 100644 --- a/pkgs/build-support/rust/build-rust-crate/log.nix +++ b/pkgs/build-support/rust/build-rust-crate/log.nix @@ -1,27 +1,29 @@ { lib }: -let echo_colored_body = start_escape: - # Body of a function that behaves like "echo" but - # has the output colored by the given start_escape - # sequence. E.g. - # - # * echo_x "Building ..." - # * echo_x -n "Running " - # - # This is more complicated than apparent at first sight - # because: - # * The color markers and the text must be print - # in the same echo statement. Otherise, other - # intermingled text from concurrent builds will - # be colored as well. - # * We need to preserve the trailing newline of the - # echo if and only if it is present. Bash likes - # to strip those if we capture the output of echo - # in a variable. - # * Leading "-" will be interpreted by test as an - # option for itself. Therefore, we prefix it with - # an x in `[[ "x$1" =~ ^x- ]]`. - '' +let + echo_colored_body = + start_escape: + # Body of a function that behaves like "echo" but + # has the output colored by the given start_escape + # sequence. E.g. + # + # * echo_x "Building ..." + # * echo_x -n "Running " + # + # This is more complicated than apparent at first sight + # because: + # * The color markers and the text must be print + # in the same echo statement. Otherise, other + # intermingled text from concurrent builds will + # be colored as well. + # * We need to preserve the trailing newline of the + # echo if and only if it is present. Bash likes + # to strip those if we capture the output of echo + # in a variable. + # * Leading "-" will be interpreted by test as an + # option for itself. Therefore, we prefix it with + # an x in `[[ "x$1" =~ ^x- ]]`. + '' local echo_args=""; while [[ "x$1" =~ ^x- ]]; do echo_args+=" $1" @@ -31,12 +33,12 @@ let echo_colored_body = start_escape: local start_escape="$(printf '${start_escape}')" local reset="$(printf '\033[0m')" echo $echo_args $start_escape"$@"$reset - ''; - echo_conditional_colored_body = colors: start_escape: - if colors == "always" - then (echo_colored_body start_escape) - else ''echo "$@"''; -in { + ''; + echo_conditional_colored_body = + colors: start_escape: + if colors == "always" then (echo_colored_body start_escape) else ''echo "$@"''; +in +{ echo_colored = colors: '' echo_colored() { ${echo_conditional_colored_body colors ''\033[0;1;32m''} @@ -45,7 +47,7 @@ in { echo_error() { ${echo_conditional_colored_body colors ''\033[0;1;31m''} } - ''; + ''; noisily = colors: verbose: '' noisily() { diff --git a/pkgs/build-support/rust/build-rust-crate/test/brotli-crates.nix b/pkgs/build-support/rust/build-rust-crate/test/brotli-crates.nix index 4831c10627156a..006045c2060401 100644 --- a/pkgs/build-support/rust/build-rust-crate/test/brotli-crates.nix +++ b/pkgs/build-support/rust/build-rust-crate/test/brotli-crates.nix @@ -1,95 +1,161 @@ -{ lib, stdenv, buildRustCrate, fetchgit }: -let kernel = stdenv.buildPlatform.parsed.kernel.name; - abi = stdenv.buildPlatform.parsed.abi.name; - include = includedFiles: src: builtins.filterSource (path: type: - lib.lists.any (f: - let p = toString (src + ("/" + f)); in +{ + lib, + stdenv, + buildRustCrate, + fetchgit, +}: +let + kernel = stdenv.buildPlatform.parsed.kernel.name; + abi = stdenv.buildPlatform.parsed.abi.name; + include = + includedFiles: src: + builtins.filterSource ( + path: type: + lib.lists.any ( + f: + let + p = toString (src + ("/" + f)); + in (path == p) || (type == "directory" && lib.strings.hasPrefix path p) ) includedFiles ) src; - updateFeatures = f: up: functions: builtins.deepSeq f (lib.lists.foldl' (features: fun: fun features) (lib.attrsets.recursiveUpdate f up) functions); - mapFeatures = features: map (fun: fun { features = features; }); - mkFeatures = feat: lib.lists.foldl (features: featureName: - if feat.${featureName} or false then - [ featureName ] ++ features - else - features - ) [] (builtins.attrNames feat); + updateFeatures = + f: up: functions: + builtins.deepSeq f ( + lib.lists.foldl' (features: fun: fun features) (lib.attrsets.recursiveUpdate f up) functions + ); + mapFeatures = features: map (fun: fun { features = features; }); + mkFeatures = + feat: + lib.lists.foldl ( + features: featureName: + if feat.${featureName} or false then [ featureName ] ++ features else features + ) [ ] (builtins.attrNames feat); in rec { - alloc_no_stdlib_1_3_0_ = { dependencies?[], buildDependencies?[], features?[] }: buildRustCrate { - crateName = "alloc-no-stdlib"; - version = "1.3.0"; - authors = [ "Daniel Reiter Horn " ]; - sha256 = "1jcp27pzmqdszgp80y484g4kwbjbg7x8a589drcwbxg0i8xwkir9"; - crateBin = [ { name = "example"; } ]; - inherit dependencies buildDependencies features; - }; - brotli_2_5_0_ = { dependencies?[], buildDependencies?[], features?[] }: buildRustCrate { - crateName = "brotli"; - version = "2.5.0"; - authors = [ "Daniel Reiter Horn " "The Brotli Authors" ]; - sha256 = "1ynw4hkdwnp0kj30p86ls44ahv4s99258s019bqrq4mya8hlsb5b"; - crateBin = [ { name = "brotli"; } ]; - inherit dependencies buildDependencies features; - }; - brotli_decompressor_1_3_1_ = { dependencies?[], buildDependencies?[], features?[] }: buildRustCrate { - crateName = "brotli-decompressor"; - version = "1.3.1"; - authors = [ "Daniel Reiter Horn " "The Brotli Authors" ]; - sha256 = "022g69q1xzwdj0130qm3fa4qwpn4q1jx3lc8yz0v0v201p7bm8fb"; - crateBin = [ { name = "brotli-decompressor"; } ]; - inherit dependencies buildDependencies features; - }; - alloc_no_stdlib_1_3_0 = { features?(alloc_no_stdlib_1_3_0_features {}) }: alloc_no_stdlib_1_3_0_ { - features = mkFeatures (features.alloc_no_stdlib_1_3_0 or {}); - }; - alloc_no_stdlib_1_3_0_features = f: updateFeatures f ({ - alloc_no_stdlib_1_3_0.default = (f.alloc_no_stdlib_1_3_0.default or true); - }) []; - brotli_2_5_0 = { features?(brotli_2_5_0_features {}) }: brotli_2_5_0_ { - dependencies = mapFeatures features ([ alloc_no_stdlib_1_3_0 brotli_decompressor_1_3_1 ]); - features = mkFeatures (features.brotli_2_5_0 or {}); - }; - brotli_2_5_0_features = f: updateFeatures f (rec { - alloc_no_stdlib_1_3_0.no-stdlib = - (f.alloc_no_stdlib_1_3_0.no-stdlib or false) || - (brotli_2_5_0.no-stdlib or false) || - (f.brotli_2_5_0.no-stdlib or false); - alloc_no_stdlib_1_3_0.default = true; - brotli_2_5_0.default = (f.brotli_2_5_0.default or true); - brotli_decompressor_1_3_1.disable-timer = - (f.brotli_decompressor_1_3_1.disable-timer or false) || - (brotli_2_5_0.disable-timer or false) || - (f.brotli_2_5_0.disable-timer or false); - brotli_decompressor_1_3_1.no-stdlib = - (f.brotli_decompressor_1_3_1.no-stdlib or false) || - (brotli_2_5_0.no-stdlib or false) || - (f.brotli_2_5_0.no-stdlib or false); - brotli_decompressor_1_3_1.benchmark = - (f.brotli_decompressor_1_3_1.benchmark or false) || - (brotli_2_5_0.benchmark or false) || - (f.brotli_2_5_0.benchmark or false); - brotli_decompressor_1_3_1.default = true; - brotli_decompressor_1_3_1.seccomp = - (f.brotli_decompressor_1_3_1.seccomp or false) || - (brotli_2_5_0.seccomp or false) || - (f.brotli_2_5_0.seccomp or false); - }) [ alloc_no_stdlib_1_3_0_features brotli_decompressor_1_3_1_features ]; - brotli_decompressor_1_3_1 = { features?(brotli_decompressor_1_3_1_features {}) }: brotli_decompressor_1_3_1_ { - dependencies = mapFeatures features ([ alloc_no_stdlib_1_3_0 ]); - features = mkFeatures (features.brotli_decompressor_1_3_1 or {}); - }; - brotli_decompressor_1_3_1_features = f: updateFeatures f (rec { - alloc_no_stdlib_1_3_0.no-stdlib = - (f.alloc_no_stdlib_1_3_0.no-stdlib or false) || - (brotli_decompressor_1_3_1.no-stdlib or false) || - (f.brotli_decompressor_1_3_1.no-stdlib or false); - alloc_no_stdlib_1_3_0.default = true; - alloc_no_stdlib_1_3_0.unsafe = - (f.alloc_no_stdlib_1_3_0.unsafe or false) || - (brotli_decompressor_1_3_1.unsafe or false) || - (f.brotli_decompressor_1_3_1.unsafe or false); - brotli_decompressor_1_3_1.default = (f.brotli_decompressor_1_3_1.default or true); - }) [ alloc_no_stdlib_1_3_0_features ]; + alloc_no_stdlib_1_3_0_ = + { + dependencies ? [ ], + buildDependencies ? [ ], + features ? [ ], + }: + buildRustCrate { + crateName = "alloc-no-stdlib"; + version = "1.3.0"; + authors = [ "Daniel Reiter Horn " ]; + sha256 = "1jcp27pzmqdszgp80y484g4kwbjbg7x8a589drcwbxg0i8xwkir9"; + crateBin = [ { name = "example"; } ]; + inherit dependencies buildDependencies features; + }; + brotli_2_5_0_ = + { + dependencies ? [ ], + buildDependencies ? [ ], + features ? [ ], + }: + buildRustCrate { + crateName = "brotli"; + version = "2.5.0"; + authors = [ + "Daniel Reiter Horn " + "The Brotli Authors" + ]; + sha256 = "1ynw4hkdwnp0kj30p86ls44ahv4s99258s019bqrq4mya8hlsb5b"; + crateBin = [ { name = "brotli"; } ]; + inherit dependencies buildDependencies features; + }; + brotli_decompressor_1_3_1_ = + { + dependencies ? [ ], + buildDependencies ? [ ], + features ? [ ], + }: + buildRustCrate { + crateName = "brotli-decompressor"; + version = "1.3.1"; + authors = [ + "Daniel Reiter Horn " + "The Brotli Authors" + ]; + sha256 = "022g69q1xzwdj0130qm3fa4qwpn4q1jx3lc8yz0v0v201p7bm8fb"; + crateBin = [ { name = "brotli-decompressor"; } ]; + inherit dependencies buildDependencies features; + }; + alloc_no_stdlib_1_3_0 = + { + features ? (alloc_no_stdlib_1_3_0_features { }), + }: + alloc_no_stdlib_1_3_0_ { + features = mkFeatures (features.alloc_no_stdlib_1_3_0 or { }); + }; + alloc_no_stdlib_1_3_0_features = + f: + updateFeatures f ({ + alloc_no_stdlib_1_3_0.default = (f.alloc_no_stdlib_1_3_0.default or true); + }) [ ]; + brotli_2_5_0 = + { + features ? (brotli_2_5_0_features { }), + }: + brotli_2_5_0_ { + dependencies = mapFeatures features ([ + alloc_no_stdlib_1_3_0 + brotli_decompressor_1_3_1 + ]); + features = mkFeatures (features.brotli_2_5_0 or { }); + }; + brotli_2_5_0_features = + f: + updateFeatures f + (rec { + alloc_no_stdlib_1_3_0.no-stdlib = + (f.alloc_no_stdlib_1_3_0.no-stdlib or false) + || (brotli_2_5_0.no-stdlib or false) + || (f.brotli_2_5_0.no-stdlib or false); + alloc_no_stdlib_1_3_0.default = true; + brotli_2_5_0.default = (f.brotli_2_5_0.default or true); + brotli_decompressor_1_3_1.disable-timer = + (f.brotli_decompressor_1_3_1.disable-timer or false) + || (brotli_2_5_0.disable-timer or false) + || (f.brotli_2_5_0.disable-timer or false); + brotli_decompressor_1_3_1.no-stdlib = + (f.brotli_decompressor_1_3_1.no-stdlib or false) + || (brotli_2_5_0.no-stdlib or false) + || (f.brotli_2_5_0.no-stdlib or false); + brotli_decompressor_1_3_1.benchmark = + (f.brotli_decompressor_1_3_1.benchmark or false) + || (brotli_2_5_0.benchmark or false) + || (f.brotli_2_5_0.benchmark or false); + brotli_decompressor_1_3_1.default = true; + brotli_decompressor_1_3_1.seccomp = + (f.brotli_decompressor_1_3_1.seccomp or false) + || (brotli_2_5_0.seccomp or false) + || (f.brotli_2_5_0.seccomp or false); + }) + [ + alloc_no_stdlib_1_3_0_features + brotli_decompressor_1_3_1_features + ]; + brotli_decompressor_1_3_1 = + { + features ? (brotli_decompressor_1_3_1_features { }), + }: + brotli_decompressor_1_3_1_ { + dependencies = mapFeatures features ([ alloc_no_stdlib_1_3_0 ]); + features = mkFeatures (features.brotli_decompressor_1_3_1 or { }); + }; + brotli_decompressor_1_3_1_features = + f: + updateFeatures f (rec { + alloc_no_stdlib_1_3_0.no-stdlib = + (f.alloc_no_stdlib_1_3_0.no-stdlib or false) + || (brotli_decompressor_1_3_1.no-stdlib or false) + || (f.brotli_decompressor_1_3_1.no-stdlib or false); + alloc_no_stdlib_1_3_0.default = true; + alloc_no_stdlib_1_3_0.unsafe = + (f.alloc_no_stdlib_1_3_0.unsafe or false) + || (brotli_decompressor_1_3_1.unsafe or false) + || (f.brotli_decompressor_1_3_1.unsafe or false); + brotli_decompressor_1_3_1.default = (f.brotli_decompressor_1_3_1.default or true); + }) [ alloc_no_stdlib_1_3_0_features ]; } diff --git a/pkgs/build-support/rust/build-rust-crate/test/default.nix b/pkgs/build-support/rust/build-rust-crate/test/default.nix index 6069ef802dde28..fdfc8fdef01eff 100644 --- a/pkgs/build-support/rust/build-rust-crate/test/default.nix +++ b/pkgs/build-support/rust/build-rust-crate/test/default.nix @@ -1,733 +1,903 @@ -{ lib -, buildPackages -, buildRustCrate -, callPackage -, releaseTools -, runCommand -, runCommandCC -, stdenv -, symlinkJoin -, writeTextFile -, pkgsCross +{ + lib, + buildPackages, + buildRustCrate, + callPackage, + releaseTools, + runCommand, + runCommandCC, + stdenv, + symlinkJoin, + writeTextFile, + pkgsCross, }: let - mkCrate = buildRustCrate: args: let - p = { - crateName = "nixtestcrate"; - version = "0.1.0"; - authors = [ "Test " ]; - } // args; - in buildRustCrate p; + mkCrate = + buildRustCrate: args: + let + p = { + crateName = "nixtestcrate"; + version = "0.1.0"; + authors = [ "Test " ]; + } // args; + in + buildRustCrate p; mkHostCrate = mkCrate buildRustCrate; mkCargoToml = - { name, crateVersion ? "0.1.0", path ? "Cargo.toml" }: - mkFile path '' - [package] - name = ${builtins.toJSON name} - version = ${builtins.toJSON crateVersion} - ''; - - mkFile = destination: text: writeTextFile { - name = "src"; - destination = "/${destination}"; - inherit text; - }; + { + name, + crateVersion ? "0.1.0", + path ? "Cargo.toml", + }: + mkFile path '' + [package] + name = ${builtins.toJSON name} + version = ${builtins.toJSON crateVersion} + ''; - mkBin = name: mkFile name '' - use std::env; - fn main() { - let name: String = env::args().nth(0).unwrap(); - println!("executed {}", name); - } - ''; - - mkBinExtern = name: extern: mkFile name '' - extern crate ${extern}; - fn main() { - assert_eq!(${extern}::test(), 23); - } - ''; - - mkTestFile = name: functionName: mkFile name '' - #[cfg(test)] - #[test] - fn ${functionName}() { - assert!(true); - } - ''; - mkTestFileWithMain = name: functionName: mkFile name '' - #[cfg(test)] - #[test] - fn ${functionName}() { - assert!(true); - } - - fn main() {} - ''; + mkFile = + destination: text: + writeTextFile { + name = "src"; + destination = "/${destination}"; + inherit text; + }; + + mkBin = + name: + mkFile name '' + use std::env; + fn main() { + let name: String = env::args().nth(0).unwrap(); + println!("executed {}", name); + } + ''; + mkBinExtern = + name: extern: + mkFile name '' + extern crate ${extern}; + fn main() { + assert_eq!(${extern}::test(), 23); + } + ''; + + mkTestFile = + name: functionName: + mkFile name '' + #[cfg(test)] + #[test] + fn ${functionName}() { + assert!(true); + } + ''; + mkTestFileWithMain = + name: functionName: + mkFile name '' + #[cfg(test)] + #[test] + fn ${functionName}() { + assert!(true); + } + + fn main() {} + ''; mkLib = name: mkFile name "pub fn test() -> i32 { return 23; }"; - mkTest = crateArgs: let - crate = mkHostCrate (builtins.removeAttrs crateArgs ["expectedTestOutput"]); - hasTests = crateArgs.buildTests or false; - expectedTestOutputs = crateArgs.expectedTestOutputs or null; - binaries = map (v: lib.escapeShellArg v.name) (crateArgs.crateBin or []); - isLib = crateArgs ? libName || crateArgs ? libPath; - crateName = crateArgs.crateName or "nixtestcrate"; - libName = crateArgs.libName or crateName; - - libTestBinary = if !isLib then null else mkHostCrate { - crateName = "run-test-${crateName}"; - dependencies = [ crate ]; - src = mkBinExtern "src/main.rs" libName; - }; + mkTest = + crateArgs: + let + crate = mkHostCrate (builtins.removeAttrs crateArgs [ "expectedTestOutput" ]); + hasTests = crateArgs.buildTests or false; + expectedTestOutputs = crateArgs.expectedTestOutputs or null; + binaries = map (v: lib.escapeShellArg v.name) (crateArgs.crateBin or [ ]); + isLib = crateArgs ? libName || crateArgs ? libPath; + crateName = crateArgs.crateName or "nixtestcrate"; + libName = crateArgs.libName or crateName; + + libTestBinary = + if !isLib then + null + else + mkHostCrate { + crateName = "run-test-${crateName}"; + dependencies = [ crate ]; + src = mkBinExtern "src/main.rs" libName; + }; in - assert expectedTestOutputs != null -> hasTests; - assert hasTests -> expectedTestOutputs != null; + assert expectedTestOutputs != null -> hasTests; + assert hasTests -> expectedTestOutputs != null; - runCommand "run-buildRustCrate-${crateName}-test" { + runCommand "run-buildRustCrate-${crateName}-test" + { nativeBuildInputs = [ crate ]; - } (if !hasTests then '' - ${lib.concatMapStringsSep "\n" (binary: - # Can't actually run the binary when cross-compiling - (lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) "type ") + binary - ) binaries} - ${lib.optionalString isLib '' + } + ( + if !hasTests then + '' + ${lib.concatMapStringsSep "\n" ( + binary: + # Can't actually run the binary when cross-compiling + (lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) "type ") + binary + ) binaries} + ${lib.optionalString isLib '' test -e ${crate}/lib/*.rlib || exit 1 ${lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) "test -x "} \ ${libTestBinary}/bin/run-test-${crateName} - ''} + ''} + touch $out + '' + else if stdenv.hostPlatform == stdenv.buildPlatform then + '' + for file in ${crate}/tests/*; do + $file 2>&1 >> $out + done + set -e + ${lib.concatMapStringsSep "\n" ( + o: "grep '${o}' $out || { echo 'output \"${o}\" not found in:'; cat $out; exit 23; }" + ) expectedTestOutputs} + '' + else + '' + for file in ${crate}/tests/*; do + test -x "$file" + done + touch "$out" + '' + ); + + /* + Returns a derivation that asserts that the crate specified by `crateArgs` + has the specified files as output. + + `name` is used as part of the derivation name that performs the checking. + + `mkCrate` can be used to override the `mkCrate` call/implementation to use to + override the `buildRustCrate`, useful for cross compilation. Uses `mkHostCrate` by default. + + `crateArgs` is passed to `mkCrate` to build the crate with `buildRustCrate` + + `expectedFiles` contains a list of expected file paths in the output. E.g. + `[ "./bin/my_binary" ]`. + + `output` specifies the name of the output to use. By default, the default + output is used but e.g. `output = "lib";` will cause the lib output + to be checked instead. You do not need to specify any directories. + */ + assertOutputs = + { + name, + mkCrate ? mkHostCrate, + crateArgs, + expectedFiles, + output ? null, + }: + assert (builtins.isString name); + assert (builtins.isAttrs crateArgs); + assert (builtins.isList expectedFiles); + + let + crate = mkCrate (builtins.removeAttrs crateArgs [ "expectedTestOutput" ]); + crateOutput = if output == null then crate else crate."${output}"; + expectedFilesFile = writeTextFile { + name = "expected-files-${name}"; + text = + let + sorted = builtins.sort (a: b: a < b) expectedFiles; + concatenated = builtins.concatStringsSep "\n" sorted; + in + "${concatenated}\n"; + }; + in + runCommand "assert-outputs-${name}" + { + } + ( + '' + local actualFiles=$(mktemp) + + cd "${crateOutput}" + find . -type f \ + | sort \ + '' + # sed out the hash because it differs per platform + + '' + | sed 's/-${crate.metadata}//g' \ + > "$actualFiles" + diff -q ${expectedFilesFile} "$actualFiles" > /dev/null || { + echo -e "\033[0;1;31mERROR: Difference in expected output files in ${crateOutput} \033[0m" >&2 + echo === Got: + sed -e 's/^/ /' $actualFiles + echo === Expected: + sed -e 's/^/ /' ${expectedFilesFile} + echo === Diff: + diff -u ${expectedFilesFile} $actualFiles |\ + tail -n +3 |\ + sed -e 's/^/ /' + exit 1 + } touch $out - '' else if stdenv.hostPlatform == stdenv.buildPlatform then '' - for file in ${crate}/tests/*; do - $file 2>&1 >> $out - done - set -e - ${lib.concatMapStringsSep "\n" (o: "grep '${o}' $out || { echo 'output \"${o}\" not found in:'; cat $out; exit 23; }") expectedTestOutputs} - '' else '' - for file in ${crate}/tests/*; do - test -x "$file" - done - touch "$out" '' ); - /* Returns a derivation that asserts that the crate specified by `crateArgs` - has the specified files as output. - - `name` is used as part of the derivation name that performs the checking. - - `mkCrate` can be used to override the `mkCrate` call/implementation to use to - override the `buildRustCrate`, useful for cross compilation. Uses `mkHostCrate` by default. - - `crateArgs` is passed to `mkCrate` to build the crate with `buildRustCrate` - - `expectedFiles` contains a list of expected file paths in the output. E.g. - `[ "./bin/my_binary" ]`. - - `output` specifies the name of the output to use. By default, the default - output is used but e.g. `output = "lib";` will cause the lib output - to be checked instead. You do not need to specify any directories. - */ - assertOutputs = { name, mkCrate ? mkHostCrate, crateArgs, expectedFiles, output? null, }: - assert (builtins.isString name); - assert (builtins.isAttrs crateArgs); - assert (builtins.isList expectedFiles); - - let - crate = mkCrate (builtins.removeAttrs crateArgs ["expectedTestOutput"]); - crateOutput = if output == null then crate else crate."${output}"; - expectedFilesFile = writeTextFile { - name = "expected-files-${name}"; - text = - let sorted = builtins.sort (a: b: a "$actualFiles" - diff -q ${expectedFilesFile} "$actualFiles" > /dev/null || { - echo -e "\033[0;1;31mERROR: Difference in expected output files in ${crateOutput} \033[0m" >&2 - echo === Got: - sed -e 's/^/ /' $actualFiles - echo === Expected: - sed -e 's/^/ /' ${expectedFilesFile} - echo === Diff: - diff -u ${expectedFilesFile} $actualFiles |\ - tail -n +3 |\ - sed -e 's/^/ /' - exit 1 - } - touch $out - '') - ; - - in rec { - - tests = let - cases = rec { - libPath = { libPath = "src/my_lib.rs"; src = mkLib "src/my_lib.rs"; }; - srcLib = { src = mkLib "src/lib.rs"; }; - - # This used to be supported by cargo but as of 1.40.0 I can't make it work like that with just cargo anymore. - # This might be a regression or deprecated thing they finally removed… - # customLibName = { libName = "test_lib"; src = mkLib "src/test_lib.rs"; }; - # rustLibTestsCustomLibName = { - # libName = "test_lib"; - # src = mkTestFile "src/test_lib.rs" "foo"; - # buildTests = true; - # expectedTestOutputs = [ "test foo ... ok" ]; - # }; - - customLibNameAndLibPath = { libName = "test_lib"; libPath = "src/best-lib.rs"; src = mkLib "src/best-lib.rs"; }; - crateBinWithPath = { crateBin = [{ name = "test_binary1"; path = "src/foobar.rs"; }]; src = mkBin "src/foobar.rs"; }; - crateBinNoPath1 = { crateBin = [{ name = "my-binary2"; }]; src = mkBin "src/my_binary2.rs"; }; - crateBinNoPath2 = { - crateBin = [{ name = "my-binary3"; } { name = "my-binary4"; }]; - src = symlinkJoin { - name = "buildRustCrateMultipleBinariesCase"; - paths = [ (mkBin "src/bin/my_binary3.rs") (mkBin "src/bin/my_binary4.rs") ]; +in +rec { + + tests = + let + cases = rec { + libPath = { + libPath = "src/my_lib.rs"; + src = mkLib "src/my_lib.rs"; }; - }; - crateBinNoPath3 = { crateBin = [{ name = "my-binary5"; }]; src = mkBin "src/bin/main.rs"; }; - crateBinNoPath4 = { crateBin = [{ name = "my-binary6"; }]; src = mkBin "src/main.rs";}; - crateBinRename1 = { - crateBin = [{ name = "my-binary-rename1"; }]; - src = mkBinExtern "src/main.rs" "foo_renamed"; - dependencies = [ (mkHostCrate { crateName = "foo"; src = mkLib "src/lib.rs"; }) ]; - crateRenames = { "foo" = "foo_renamed"; }; - }; - crateBinRename2 = { - crateBin = [{ name = "my-binary-rename2"; }]; - src = mkBinExtern "src/main.rs" "foo_renamed"; - dependencies = [ (mkHostCrate { crateName = "foo"; libName = "foolib"; src = mkLib "src/lib.rs"; }) ]; - crateRenames = { "foo" = "foo_renamed"; }; - }; - crateBinRenameMultiVersion = let - crateWithVersion = version: mkHostCrate { - crateName = "my_lib"; - inherit version; - src = mkFile "src/lib.rs" '' - pub const version: &str = "${version}"; - ''; + srcLib = { + src = mkLib "src/lib.rs"; }; - depCrate01 = crateWithVersion "0.1.2"; - depCrate02 = crateWithVersion "0.2.1"; - in { - crateName = "my_bin"; - src = symlinkJoin { - name = "my_bin_src"; - paths = [ - (mkFile "src/main.rs" '' - #[test] - fn my_lib_01() { assert_eq!(lib01::version, "0.1.2"); } - - #[test] - fn my_lib_02() { assert_eq!(lib02::version, "0.2.1"); } - - fn main() { } - '') - ]; + + # This used to be supported by cargo but as of 1.40.0 I can't make it work like that with just cargo anymore. + # This might be a regression or deprecated thing they finally removed… + # customLibName = { libName = "test_lib"; src = mkLib "src/test_lib.rs"; }; + # rustLibTestsCustomLibName = { + # libName = "test_lib"; + # src = mkTestFile "src/test_lib.rs" "foo"; + # buildTests = true; + # expectedTestOutputs = [ "test foo ... ok" ]; + # }; + + customLibNameAndLibPath = { + libName = "test_lib"; + libPath = "src/best-lib.rs"; + src = mkLib "src/best-lib.rs"; }; - dependencies = [ depCrate01 depCrate02 ]; - crateRenames = { - "my_lib" = [ + crateBinWithPath = { + crateBin = [ { - version = "0.1.2"; - rename = "lib01"; - } - { - version = "0.2.1"; - rename = "lib02"; + name = "test_binary1"; + path = "src/foobar.rs"; } ]; + src = mkBin "src/foobar.rs"; }; - buildTests = true; - expectedTestOutputs = [ - "test my_lib_01 ... ok" - "test my_lib_02 ... ok" - ]; - }; - rustLibTestsDefault = { - src = mkTestFile "src/lib.rs" "baz"; - buildTests = true; - expectedTestOutputs = [ "test baz ... ok" ]; - }; - rustLibTestsCustomLibPath = { - libPath = "src/test_path.rs"; - src = mkTestFile "src/test_path.rs" "bar"; - buildTests = true; - expectedTestOutputs = [ "test bar ... ok" ]; - }; - rustLibTestsCustomLibPathWithTests = { - libPath = "src/test_path.rs"; - src = symlinkJoin { - name = "rust-lib-tests-custom-lib-path-with-tests-dir"; - paths = [ - (mkTestFile "src/test_path.rs" "bar") - (mkTestFile "tests/something.rs" "something") + crateBinNoPath1 = { + crateBin = [ { name = "my-binary2"; } ]; + src = mkBin "src/my_binary2.rs"; + }; + crateBinNoPath2 = { + crateBin = [ + { name = "my-binary3"; } + { name = "my-binary4"; } ]; + src = symlinkJoin { + name = "buildRustCrateMultipleBinariesCase"; + paths = [ + (mkBin "src/bin/my_binary3.rs") + (mkBin "src/bin/my_binary4.rs") + ]; + }; }; - buildTests = true; - expectedTestOutputs = [ - "test bar ... ok" - "test something ... ok" - ]; - }; - rustBinTestsCombined = { - src = symlinkJoin { - name = "rust-bin-tests-combined"; - paths = [ - (mkTestFileWithMain "src/main.rs" "src_main") - (mkTestFile "tests/foo.rs" "tests_foo") - (mkTestFile "tests/bar.rs" "tests_bar") + crateBinNoPath3 = { + crateBin = [ { name = "my-binary5"; } ]; + src = mkBin "src/bin/main.rs"; + }; + crateBinNoPath4 = { + crateBin = [ { name = "my-binary6"; } ]; + src = mkBin "src/main.rs"; + }; + crateBinRename1 = { + crateBin = [ { name = "my-binary-rename1"; } ]; + src = mkBinExtern "src/main.rs" "foo_renamed"; + dependencies = [ + (mkHostCrate { + crateName = "foo"; + src = mkLib "src/lib.rs"; + }) ]; + crateRenames = { + "foo" = "foo_renamed"; + }; }; - buildTests = true; - expectedTestOutputs = [ - "test src_main ... ok" - "test tests_foo ... ok" - "test tests_bar ... ok" - ]; - }; - rustBinTestsSubdirCombined = { - src = symlinkJoin { - name = "rust-bin-tests-subdir-combined"; - paths = [ - (mkTestFileWithMain "src/main.rs" "src_main") - (mkTestFile "tests/foo/main.rs" "tests_foo") - (mkTestFile "tests/bar/main.rs" "tests_bar") + crateBinRename2 = { + crateBin = [ { name = "my-binary-rename2"; } ]; + src = mkBinExtern "src/main.rs" "foo_renamed"; + dependencies = [ + (mkHostCrate { + crateName = "foo"; + libName = "foolib"; + src = mkLib "src/lib.rs"; + }) ]; + crateRenames = { + "foo" = "foo_renamed"; + }; }; - buildTests = true; - expectedTestOutputs = [ - "test src_main ... ok" - "test tests_foo ... ok" - "test tests_bar ... ok" - ]; - }; - linkAgainstRlibCrate = { - crateName = "foo"; - src = mkFile "src/main.rs" '' - extern crate somerlib; - fn main() {} - ''; - dependencies = [ - (mkHostCrate { - crateName = "somerlib"; - type = [ "rlib" ]; - src = mkLib "src/lib.rs"; - }) - ]; - }; - buildScriptDeps = let - depCrate = buildRustCrate: boolVal: mkCrate buildRustCrate { - crateName = "bar"; - src = mkFile "src/lib.rs" '' - pub const baz: bool = ${boolVal}; - ''; + crateBinRenameMultiVersion = + let + crateWithVersion = + version: + mkHostCrate { + crateName = "my_lib"; + inherit version; + src = mkFile "src/lib.rs" '' + pub const version: &str = "${version}"; + ''; + }; + depCrate01 = crateWithVersion "0.1.2"; + depCrate02 = crateWithVersion "0.2.1"; + in + { + crateName = "my_bin"; + src = symlinkJoin { + name = "my_bin_src"; + paths = [ + (mkFile "src/main.rs" '' + #[test] + fn my_lib_01() { assert_eq!(lib01::version, "0.1.2"); } + + #[test] + fn my_lib_02() { assert_eq!(lib02::version, "0.2.1"); } + + fn main() { } + '') + ]; + }; + dependencies = [ + depCrate01 + depCrate02 + ]; + crateRenames = { + "my_lib" = [ + { + version = "0.1.2"; + rename = "lib01"; + } + { + version = "0.2.1"; + rename = "lib02"; + } + ]; + }; + buildTests = true; + expectedTestOutputs = [ + "test my_lib_01 ... ok" + "test my_lib_02 ... ok" + ]; + }; + rustLibTestsDefault = { + src = mkTestFile "src/lib.rs" "baz"; + buildTests = true; + expectedTestOutputs = [ "test baz ... ok" ]; }; - in { - crateName = "foo"; - src = symlinkJoin { - name = "build-script-and-main"; - paths = [ - (mkFile "src/main.rs" '' - extern crate bar; - #[cfg(test)] - #[test] - fn baz_false() { assert!(!bar::baz); } - fn main() { } - '') - (mkFile "build.rs" '' - extern crate bar; - fn main() { assert!(bar::baz); } - '') - ]; + rustLibTestsCustomLibPath = { + libPath = "src/test_path.rs"; + src = mkTestFile "src/test_path.rs" "bar"; + buildTests = true; + expectedTestOutputs = [ "test bar ... ok" ]; }; - buildDependencies = [ (depCrate buildPackages.buildRustCrate "true") ]; - dependencies = [ (depCrate buildRustCrate "false") ]; - buildTests = true; - expectedTestOutputs = [ "test baz_false ... ok" ]; - }; - buildScriptFeatureEnv = { - crateName = "build-script-feature-env"; - features = [ "some-feature" "crate/another_feature" ]; - src = symlinkJoin { - name = "build-script-feature-env"; - paths = [ - (mkFile "src/main.rs" '' - #[cfg(test)] - #[test] - fn feature_not_visible() { - assert!(std::env::var("CARGO_FEATURE_SOME_FEATURE").is_err()); - assert!(option_env!("CARGO_FEATURE_SOME_FEATURE").is_none()); - } - fn main() {} - '') - (mkFile "build.rs" '' - fn main() { - assert!(std::env::var("CARGO_FEATURE_SOME_FEATURE").is_ok()); - assert!(option_env!("CARGO_FEATURE_SOME_FEATURE").is_none()); - } - '') + rustLibTestsCustomLibPathWithTests = { + libPath = "src/test_path.rs"; + src = symlinkJoin { + name = "rust-lib-tests-custom-lib-path-with-tests-dir"; + paths = [ + (mkTestFile "src/test_path.rs" "bar") + (mkTestFile "tests/something.rs" "something") + ]; + }; + buildTests = true; + expectedTestOutputs = [ + "test bar ... ok" + "test something ... ok" ]; }; - buildTests = true; - expectedTestOutputs = [ "test feature_not_visible ... ok" ]; - }; - # Regression test for https://github.com/NixOS/nixpkgs/pull/88054 - # Build script output should be rewritten as valid env vars. - buildScriptIncludeDirDeps = let - depCrate = mkHostCrate { - crateName = "bar"; + rustBinTestsCombined = { src = symlinkJoin { - name = "build-script-and-include-dir-bar"; + name = "rust-bin-tests-combined"; paths = [ - (mkFile "src/lib.rs" '' - fn main() { } - '') - (mkFile "build.rs" '' - use std::path::PathBuf; - fn main() { println!("cargo:include-dir={}/src", std::env::current_dir().unwrap_or(PathBuf::from(".")).to_str().unwrap()); } - '') + (mkTestFileWithMain "src/main.rs" "src_main") + (mkTestFile "tests/foo.rs" "tests_foo") + (mkTestFile "tests/bar.rs" "tests_bar") ]; }; + buildTests = true; + expectedTestOutputs = [ + "test src_main ... ok" + "test tests_foo ... ok" + "test tests_bar ... ok" + ]; }; - in { - crateName = "foo"; - src = symlinkJoin { - name = "build-script-and-include-dir-foo"; - paths = [ - (mkFile "src/main.rs" '' - fn main() { } - '') - (mkFile "build.rs" '' - fn main() { assert!(std::env::var_os("DEP_BAR_INCLUDE_DIR").is_some()); } - '') + rustBinTestsSubdirCombined = { + src = symlinkJoin { + name = "rust-bin-tests-subdir-combined"; + paths = [ + (mkTestFileWithMain "src/main.rs" "src_main") + (mkTestFile "tests/foo/main.rs" "tests_foo") + (mkTestFile "tests/bar/main.rs" "tests_bar") + ]; + }; + buildTests = true; + expectedTestOutputs = [ + "test src_main ... ok" + "test tests_foo ... ok" + "test tests_bar ... ok" ]; }; - buildDependencies = [ depCrate ]; - dependencies = [ depCrate ]; - }; - # Support new invocation prefix for build scripts `cargo::` - # https://doc.rust-lang.org/cargo/reference/build-scripts.html#outputs-of-the-build-script - buildScriptInvocationPrefix = let - depCrate = buildRustCrate: mkCrate buildRustCrate { - crateName = "bar"; - src = mkFile "build.rs" '' - fn main() { - // Old invocation prefix - // We likely won't see be mixing these syntaxes in the same build script in the wild. - println!("cargo:key_old=value_old"); - - // New invocation prefix - println!("cargo::metadata=key=value"); - println!("cargo::metadata=key_complex=complex(value)"); - } + linkAgainstRlibCrate = { + crateName = "foo"; + src = mkFile "src/main.rs" '' + extern crate somerlib; + fn main() {} ''; - }; - in { - crateName = "foo"; - src = symlinkJoin { - name = "build-script-and-main-invocation-prefix"; - paths = [ - (mkFile "src/main.rs" '' - const BUILDFOO: &'static str = env!("BUILDFOO"); - - #[test] - fn build_foo_check() { assert!(BUILDFOO == "yes(check)"); } - - fn main() { } - '') - (mkFile "build.rs" '' - use std::env; - fn main() { - assert!(env::var_os("DEP_BAR_KEY_OLD").expect("metadata key 'key_old' not set in dependency") == "value_old"); - assert!(env::var_os("DEP_BAR_KEY").expect("metadata key 'key' not set in dependency") == "value"); - assert!(env::var_os("DEP_BAR_KEY_COMPLEX").expect("metadata key 'key_complex' not set in dependency") == "complex(value)"); - - println!("cargo::rustc-env=BUILDFOO=yes(check)"); - } - '') + dependencies = [ + (mkHostCrate { + crateName = "somerlib"; + type = [ "rlib" ]; + src = mkLib "src/lib.rs"; + }) ]; }; - buildDependencies = [ (depCrate buildPackages.buildRustCrate) ]; - dependencies = [ (depCrate buildRustCrate) ]; - buildTests = true; - expectedTestOutputs = [ "test build_foo_check ... ok" ]; - }; - # Regression test for https://github.com/NixOS/nixpkgs/issues/74071 - # Whenevever a build.rs file is generating files those should not be overlayed onto the actual source dir - buildRsOutDirOverlay = { - src = symlinkJoin { - name = "buildrs-out-dir-overlay"; - paths = [ - (mkLib "src/lib.rs") - (mkFile "build.rs" '' - use std::env; - use std::ffi::OsString; - use std::fs; - use std::path::Path; - fn main() { - let out_dir = env::var_os("OUT_DIR").expect("OUT_DIR not set"); - let out_file = Path::new(&out_dir).join("lib.rs"); - fs::write(out_file, "invalid rust code!").expect("failed to write lib.rs"); - } - '') + buildScriptDeps = + let + depCrate = + buildRustCrate: boolVal: + mkCrate buildRustCrate { + crateName = "bar"; + src = mkFile "src/lib.rs" '' + pub const baz: bool = ${boolVal}; + ''; + }; + in + { + crateName = "foo"; + src = symlinkJoin { + name = "build-script-and-main"; + paths = [ + (mkFile "src/main.rs" '' + extern crate bar; + #[cfg(test)] + #[test] + fn baz_false() { assert!(!bar::baz); } + fn main() { } + '') + (mkFile "build.rs" '' + extern crate bar; + fn main() { assert!(bar::baz); } + '') + ]; + }; + buildDependencies = [ (depCrate buildPackages.buildRustCrate "true") ]; + dependencies = [ (depCrate buildRustCrate "false") ]; + buildTests = true; + expectedTestOutputs = [ "test baz_false ... ok" ]; + }; + buildScriptFeatureEnv = { + crateName = "build-script-feature-env"; + features = [ + "some-feature" + "crate/another_feature" ]; - }; - }; - # Regression test for https://github.com/NixOS/nixpkgs/pull/83379 - # link flag order should be preserved - linkOrder = { - src = symlinkJoin { - name = "buildrs-out-dir-overlay"; - paths = [ - (mkFile "build.rs" '' - fn main() { - // in the other order, linkage will fail - println!("cargo:rustc-link-lib=b"); - println!("cargo:rustc-link-lib=a"); - } - '') - (mkFile "src/main.rs" '' - extern "C" { - fn hello_world(); - } - fn main() { - unsafe { - hello_world(); + src = symlinkJoin { + name = "build-script-feature-env"; + paths = [ + (mkFile "src/main.rs" '' + #[cfg(test)] + #[test] + fn feature_not_visible() { + assert!(std::env::var("CARGO_FEATURE_SOME_FEATURE").is_err()); + assert!(option_env!("CARGO_FEATURE_SOME_FEATURE").is_none()); } - } - '') - ]; + fn main() {} + '') + (mkFile "build.rs" '' + fn main() { + assert!(std::env::var("CARGO_FEATURE_SOME_FEATURE").is_ok()); + assert!(option_env!("CARGO_FEATURE_SOME_FEATURE").is_none()); + } + '') + ]; + }; + buildTests = true; + expectedTestOutputs = [ "test feature_not_visible ... ok" ]; }; - buildInputs = let - compile = name: text: let - src = writeTextFile { - name = "${name}-src.c"; - inherit text; + # Regression test for https://github.com/NixOS/nixpkgs/pull/88054 + # Build script output should be rewritten as valid env vars. + buildScriptIncludeDirDeps = + let + depCrate = mkHostCrate { + crateName = "bar"; + src = symlinkJoin { + name = "build-script-and-include-dir-bar"; + paths = [ + (mkFile "src/lib.rs" '' + fn main() { } + '') + (mkFile "build.rs" '' + use std::path::PathBuf; + fn main() { println!("cargo:include-dir={}/src", std::env::current_dir().unwrap_or(PathBuf::from(".")).to_str().unwrap()); } + '') + ]; + }; }; - in runCommandCC name {} '' - mkdir -p $out/lib - # Note: On darwin (which defaults to clang) we have to add - # `-undefined dynamic_lookup` as otherwise the compilation fails. - $CC -shared \ - ${lib.optionalString stdenv.hostPlatform.isDarwin "-undefined dynamic_lookup"} \ - -o $out/lib/${name}${stdenv.hostPlatform.extensions.library} ${src} - ''; - b = compile "libb" '' - #include - - void hello(); - - void hello_world() { - hello(); - printf(" world!\n"); - } - ''; - a = compile "liba" '' - #include + in + { + crateName = "foo"; + src = symlinkJoin { + name = "build-script-and-include-dir-foo"; + paths = [ + (mkFile "src/main.rs" '' + fn main() { } + '') + (mkFile "build.rs" '' + fn main() { assert!(std::env::var_os("DEP_BAR_INCLUDE_DIR").is_some()); } + '') + ]; + }; + buildDependencies = [ depCrate ]; + dependencies = [ depCrate ]; + }; + # Support new invocation prefix for build scripts `cargo::` + # https://doc.rust-lang.org/cargo/reference/build-scripts.html#outputs-of-the-build-script + buildScriptInvocationPrefix = + let + depCrate = + buildRustCrate: + mkCrate buildRustCrate { + crateName = "bar"; + src = mkFile "build.rs" '' + fn main() { + // Old invocation prefix + // We likely won't see be mixing these syntaxes in the same build script in the wild. + println!("cargo:key_old=value_old"); + + // New invocation prefix + println!("cargo::metadata=key=value"); + println!("cargo::metadata=key_complex=complex(value)"); + } + ''; + }; + in + { + crateName = "foo"; + src = symlinkJoin { + name = "build-script-and-main-invocation-prefix"; + paths = [ + (mkFile "src/main.rs" '' + const BUILDFOO: &'static str = env!("BUILDFOO"); + + #[test] + fn build_foo_check() { assert!(BUILDFOO == "yes(check)"); } + + fn main() { } + '') + (mkFile "build.rs" '' + use std::env; + fn main() { + assert!(env::var_os("DEP_BAR_KEY_OLD").expect("metadata key 'key_old' not set in dependency") == "value_old"); + assert!(env::var_os("DEP_BAR_KEY").expect("metadata key 'key' not set in dependency") == "value"); + assert!(env::var_os("DEP_BAR_KEY_COMPLEX").expect("metadata key 'key_complex' not set in dependency") == "complex(value)"); + + println!("cargo::rustc-env=BUILDFOO=yes(check)"); + } + '') + ]; + }; + buildDependencies = [ (depCrate buildPackages.buildRustCrate) ]; + dependencies = [ (depCrate buildRustCrate) ]; + buildTests = true; + expectedTestOutputs = [ "test build_foo_check ... ok" ]; + }; + # Regression test for https://github.com/NixOS/nixpkgs/issues/74071 + # Whenevever a build.rs file is generating files those should not be overlayed onto the actual source dir + buildRsOutDirOverlay = { + src = symlinkJoin { + name = "buildrs-out-dir-overlay"; + paths = [ + (mkLib "src/lib.rs") + (mkFile "build.rs" '' + use std::env; + use std::ffi::OsString; + use std::fs; + use std::path::Path; + fn main() { + let out_dir = env::var_os("OUT_DIR").expect("OUT_DIR not set"); + let out_file = Path::new(&out_dir).join("lib.rs"); + fs::write(out_file, "invalid rust code!").expect("failed to write lib.rs"); + } + '') + ]; + }; + }; + # Regression test for https://github.com/NixOS/nixpkgs/pull/83379 + # link flag order should be preserved + linkOrder = { + src = symlinkJoin { + name = "buildrs-out-dir-overlay"; + paths = [ + (mkFile "build.rs" '' + fn main() { + // in the other order, linkage will fail + println!("cargo:rustc-link-lib=b"); + println!("cargo:rustc-link-lib=a"); + } + '') + (mkFile "src/main.rs" '' + extern "C" { + fn hello_world(); + } + fn main() { + unsafe { + hello_world(); + } + } + '') + ]; + }; + buildInputs = + let + compile = + name: text: + let + src = writeTextFile { + name = "${name}-src.c"; + inherit text; + }; + in + runCommandCC name { } '' + mkdir -p $out/lib + # Note: On darwin (which defaults to clang) we have to add + # `-undefined dynamic_lookup` as otherwise the compilation fails. + $CC -shared \ + ${lib.optionalString stdenv.hostPlatform.isDarwin "-undefined dynamic_lookup"} \ + -o $out/lib/${name}${stdenv.hostPlatform.extensions.library} ${src} + ''; + b = compile "libb" '' + #include + + void hello(); + + void hello_world() { + hello(); + printf(" world!\n"); + } + ''; + a = compile "liba" '' + #include - void hello() { - printf("hello"); - } - ''; - in [ a b ]; - }; - rustCargoTomlInSubDir = { - # The "workspace_member" can be set to the sub directory with the crate to build. - # By default ".", meaning the top level directory is assumed. - # Using null will trigger a search. - workspace_member = null; - src = symlinkJoin rec { - name = "find-cargo-toml"; - paths = [ - (mkCargoToml { name = "ignoreMe"; }) - (mkTestFileWithMain "src/main.rs" "ignore_main") - - (mkCargoToml { name = "rustCargoTomlInSubDir"; path = "subdir/Cargo.toml"; }) - (mkTestFileWithMain "subdir/src/main.rs" "src_main") - (mkTestFile "subdir/tests/foo/main.rs" "tests_foo") - (mkTestFile "subdir/tests/bar/main.rs" "tests_bar") + void hello() { + printf("hello"); + } + ''; + in + [ + a + b + ]; + }; + rustCargoTomlInSubDir = { + # The "workspace_member" can be set to the sub directory with the crate to build. + # By default ".", meaning the top level directory is assumed. + # Using null will trigger a search. + workspace_member = null; + src = symlinkJoin rec { + name = "find-cargo-toml"; + paths = [ + (mkCargoToml { name = "ignoreMe"; }) + (mkTestFileWithMain "src/main.rs" "ignore_main") + + (mkCargoToml { + name = "rustCargoTomlInSubDir"; + path = "subdir/Cargo.toml"; + }) + (mkTestFileWithMain "subdir/src/main.rs" "src_main") + (mkTestFile "subdir/tests/foo/main.rs" "tests_foo") + (mkTestFile "subdir/tests/bar/main.rs" "tests_bar") + ]; + }; + buildTests = true; + expectedTestOutputs = [ + "test src_main ... ok" + "test tests_foo ... ok" + "test tests_bar ... ok" ]; }; - buildTests = true; - expectedTestOutputs = [ - "test src_main ... ok" - "test tests_foo ... ok" - "test tests_bar ... ok" - ]; - }; - rustCargoTomlInTopDir = - let - withoutCargoTomlSearch = builtins.removeAttrs rustCargoTomlInSubDir [ "workspace_member" ]; - in - withoutCargoTomlSearch // { + rustCargoTomlInTopDir = + let + withoutCargoTomlSearch = builtins.removeAttrs rustCargoTomlInSubDir [ "workspace_member" ]; + in + withoutCargoTomlSearch + // { expectedTestOutputs = [ "test ignore_main ... ok" ]; }; - procMacroInPrelude = { - procMacro = true; - edition = "2018"; - src = symlinkJoin { - name = "proc-macro-in-prelude"; - paths = [ - (mkFile "src/lib.rs" '' - use proc_macro::TokenTree; - '') - ]; + procMacroInPrelude = { + procMacro = true; + edition = "2018"; + src = symlinkJoin { + name = "proc-macro-in-prelude"; + paths = [ + (mkFile "src/lib.rs" '' + use proc_macro::TokenTree; + '') + ]; + }; }; }; - }; - brotliCrates = (callPackage ./brotli-crates.nix {}); - rcgenCrates = callPackage ./rcgen-crates.nix { - # Suppress deprecation warning - buildRustCrate = null; - }; - tests = lib.mapAttrs (key: value: mkTest (value // lib.optionalAttrs (!value?crateName) { crateName = key; })) cases; - in tests // rec { - - crateBinWithPathOutputs = assertOutputs { - name="crateBinWithPath"; - crateArgs = { - crateBin = [{ name = "test_binary1"; path = "src/foobar.rs"; }]; - src = mkBin "src/foobar.rs"; + brotliCrates = (callPackage ./brotli-crates.nix { }); + rcgenCrates = callPackage ./rcgen-crates.nix { + # Suppress deprecation warning + buildRustCrate = null; }; - expectedFiles = [ - "./bin/test_binary1" - ]; - }; + tests = lib.mapAttrs ( + key: value: mkTest (value // lib.optionalAttrs (!value ? crateName) { crateName = key; }) + ) cases; + in + tests + // rec { - crateBinWithPathOutputsDebug = assertOutputs { - name="crateBinWithPath"; - crateArgs = { - release = false; - crateBin = [{ name = "test_binary1"; path = "src/foobar.rs"; }]; - src = mkBin "src/foobar.rs"; + crateBinWithPathOutputs = assertOutputs { + name = "crateBinWithPath"; + crateArgs = { + crateBin = [ + { + name = "test_binary1"; + path = "src/foobar.rs"; + } + ]; + src = mkBin "src/foobar.rs"; + }; + expectedFiles = [ + "./bin/test_binary1" + ]; }; - expectedFiles = [ - "./bin/test_binary1" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # On Darwin, the debug symbols are in a separate directory. - "./bin/test_binary1.dSYM/Contents/Info.plist" - "./bin/test_binary1.dSYM/Contents/Resources/DWARF/test_binary1" - ]; - }; - crateBinNoPath1Outputs = assertOutputs { - name="crateBinNoPath1"; - crateArgs = { - crateBin = [{ name = "my-binary2"; }]; - src = mkBin "src/my_binary2.rs"; + crateBinWithPathOutputsDebug = assertOutputs { + name = "crateBinWithPath"; + crateArgs = { + release = false; + crateBin = [ + { + name = "test_binary1"; + path = "src/foobar.rs"; + } + ]; + src = mkBin "src/foobar.rs"; + }; + expectedFiles = + [ + "./bin/test_binary1" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # On Darwin, the debug symbols are in a separate directory. + "./bin/test_binary1.dSYM/Contents/Info.plist" + "./bin/test_binary1.dSYM/Contents/Resources/DWARF/test_binary1" + ]; }; - expectedFiles = [ - "./bin/my-binary2" - ]; - }; - crateLibOutputs = assertOutputs { - name="crateLib"; - output="lib"; - crateArgs = { - libName = "test_lib"; - type = [ "rlib" ]; - libPath = "src/lib.rs"; - src = mkLib "src/lib.rs"; + crateBinNoPath1Outputs = assertOutputs { + name = "crateBinNoPath1"; + crateArgs = { + crateBin = [ { name = "my-binary2"; } ]; + src = mkBin "src/my_binary2.rs"; + }; + expectedFiles = [ + "./bin/my-binary2" + ]; + }; + + crateLibOutputs = assertOutputs { + name = "crateLib"; + output = "lib"; + crateArgs = { + libName = "test_lib"; + type = [ "rlib" ]; + libPath = "src/lib.rs"; + src = mkLib "src/lib.rs"; + }; + expectedFiles = [ + "./nix-support/propagated-build-inputs" + "./lib/libtest_lib.rlib" + "./lib/link" + ]; }; - expectedFiles = [ - "./nix-support/propagated-build-inputs" - "./lib/libtest_lib.rlib" - "./lib/link" - ]; - }; - crateLibOutputsDebug = assertOutputs { - name="crateLib"; - output="lib"; - crateArgs = { - release = false; - libName = "test_lib"; - type = [ "rlib" ]; - libPath = "src/lib.rs"; - src = mkLib "src/lib.rs"; + crateLibOutputsDebug = assertOutputs { + name = "crateLib"; + output = "lib"; + crateArgs = { + release = false; + libName = "test_lib"; + type = [ "rlib" ]; + libPath = "src/lib.rs"; + src = mkLib "src/lib.rs"; + }; + expectedFiles = [ + "./nix-support/propagated-build-inputs" + "./lib/libtest_lib.rlib" + "./lib/link" + ]; }; - expectedFiles = [ - "./nix-support/propagated-build-inputs" - "./lib/libtest_lib.rlib" - "./lib/link" - ]; - }; - crateLibOutputsWasm32 = assertOutputs { - name = "wasm32-crate-lib"; - output = "lib"; - mkCrate = mkCrate pkgsCross.wasm32-unknown-none.buildRustCrate; - crateArgs = { - libName = "test_lib"; - type = [ "cdylib" ]; - libPath = "src/lib.rs"; - src = mkLib "src/lib.rs"; + crateLibOutputsWasm32 = assertOutputs { + name = "wasm32-crate-lib"; + output = "lib"; + mkCrate = mkCrate pkgsCross.wasm32-unknown-none.buildRustCrate; + crateArgs = { + libName = "test_lib"; + type = [ "cdylib" ]; + libPath = "src/lib.rs"; + src = mkLib "src/lib.rs"; + }; + expectedFiles = [ + "./nix-support/propagated-build-inputs" + "./lib/test_lib.wasm" + "./lib/link" + ]; }; - expectedFiles = [ - "./nix-support/propagated-build-inputs" - "./lib/test_lib.wasm" - "./lib/link" - ]; - }; - brotliTest = let - pkg = brotliCrates.brotli_2_5_0 {}; - in runCommand "run-brotli-test-cmd" { - nativeBuildInputs = [ pkg ]; - } (if stdenv.hostPlatform == stdenv.buildPlatform then '' - ${pkg}/bin/brotli -c ${pkg}/bin/brotli > /dev/null && touch $out - '' else '' - test -x '${pkg}/bin/brotli' && touch $out - ''); - allocNoStdLibTest = let - pkg = brotliCrates.alloc_no_stdlib_1_3_0 {}; - in runCommand "run-alloc-no-stdlib-test-cmd" { - nativeBuildInputs = [ pkg ]; - } '' - test -e ${pkg}/bin/example && touch $out - ''; - brotliDecompressorTest = let - pkg = brotliCrates.brotli_decompressor_1_3_1 {}; - in runCommand "run-brotli-decompressor-test-cmd" { - nativeBuildInputs = [ pkg ]; - } '' - test -e ${pkg}/bin/brotli-decompressor && touch $out - ''; + brotliTest = + let + pkg = brotliCrates.brotli_2_5_0 { }; + in + runCommand "run-brotli-test-cmd" + { + nativeBuildInputs = [ pkg ]; + } + ( + if stdenv.hostPlatform == stdenv.buildPlatform then + '' + ${pkg}/bin/brotli -c ${pkg}/bin/brotli > /dev/null && touch $out + '' + else + '' + test -x '${pkg}/bin/brotli' && touch $out + '' + ); + allocNoStdLibTest = + let + pkg = brotliCrates.alloc_no_stdlib_1_3_0 { }; + in + runCommand "run-alloc-no-stdlib-test-cmd" + { + nativeBuildInputs = [ pkg ]; + } + '' + test -e ${pkg}/bin/example && touch $out + ''; + brotliDecompressorTest = + let + pkg = brotliCrates.brotli_decompressor_1_3_1 { }; + in + runCommand "run-brotli-decompressor-test-cmd" + { + nativeBuildInputs = [ pkg ]; + } + '' + test -e ${pkg}/bin/brotli-decompressor && touch $out + ''; - rcgenTest = let - pkg = rcgenCrates.rootCrate.build; - in runCommand "run-rcgen-test-cmd" { - nativeBuildInputs = [ pkg ]; - } (if stdenv.hostPlatform == stdenv.buildPlatform then '' - ${pkg}/bin/rcgen && touch $out - '' else '' - test -x '${pkg}/bin/rcgen' && touch $out - ''); - }; + rcgenTest = + let + pkg = rcgenCrates.rootCrate.build; + in + runCommand "run-rcgen-test-cmd" + { + nativeBuildInputs = [ pkg ]; + } + ( + if stdenv.hostPlatform == stdenv.buildPlatform then + '' + ${pkg}/bin/rcgen && touch $out + '' + else + '' + test -x '${pkg}/bin/rcgen' && touch $out + '' + ); + }; test = releaseTools.aggregate { name = "buildRustCrate-tests"; meta = { diff --git a/pkgs/build-support/rust/build-rust-crate/test/rcgen-crates.nix b/pkgs/build-support/rust/build-rust-crate/test/rcgen-crates.nix index ed273c01d26dc4..4400df270666b4 100644 --- a/pkgs/build-support/rust/build-rust-crate/test/rcgen-crates.nix +++ b/pkgs/build-support/rust/build-rust-crate/test/rcgen-crates.nix @@ -1,30 +1,35 @@ - # This file was @generated by crate2nix 0.10.0 with the command: # "generate" # See https://github.com/kolloch/crate2nix for more info. -{ nixpkgs ? -, pkgs ? import nixpkgs { config = {}; } -, lib ? pkgs.lib -, stdenv ? pkgs.stdenv -, buildRustCrateForPkgs ? if buildRustCrate != null - then lib.warn "crate2nix: Passing `buildRustCrate` as argument to Cargo.nix is deprecated. If you don't customize `buildRustCrate`, replace `callPackage ./Cargo.nix {}` by `import ./Cargo.nix { inherit pkgs; }`, and if you need to customize `buildRustCrate`, use `buildRustCrateForPkgs` instead." (_: buildRustCrate) - else pkgs: pkgs.buildRustCrate +{ + nixpkgs ? , + pkgs ? import nixpkgs { config = { }; }, + lib ? pkgs.lib, + stdenv ? pkgs.stdenv, + buildRustCrateForPkgs ? + if buildRustCrate != null then + lib.warn + "crate2nix: Passing `buildRustCrate` as argument to Cargo.nix is deprecated. If you don't customize `buildRustCrate`, replace `callPackage ./Cargo.nix {}` by `import ./Cargo.nix { inherit pkgs; }`, and if you need to customize `buildRustCrate`, use `buildRustCrateForPkgs` instead." + (_: buildRustCrate) + else + pkgs: pkgs.buildRustCrate, # Deprecated -, buildRustCrate ? null + buildRustCrate ? null, # This is used as the `crateOverrides` argument for `buildRustCrate`. -, defaultCrateOverrides ? pkgs.defaultCrateOverrides + defaultCrateOverrides ? pkgs.defaultCrateOverrides, # The features to enable for the root_crate or the workspace_members. -, rootFeatures ? [ "default" ] + rootFeatures ? [ "default" ], # If true, throw errors instead of issueing deprecation warnings. -, strictDeprecation ? false + strictDeprecation ? false, # Used for conditional compilation based on CPU feature detection. -, targetFeatures ? [] + targetFeatures ? [ ], # Whether to perform release builds: longer compile times, faster binaries. -, release ? true + release ? true, # Additional crate2nix configuration if it exists. -, crateConfig - ? lib.optionalAttrs (builtins.pathExists ./crate-config.nix) (pkgs.callPackage ./crate-config.nix {}) + crateConfig ? lib.optionalAttrs (builtins.pathExists ./crate-config.nix) ( + pkgs.callPackage ./crate-config.nix { } + ), }: rec { @@ -63,10 +68,12 @@ rec { # A derivation that joins the outputs of all workspace members together. allWorkspaceMembers = pkgs.symlinkJoin { - name = "all-workspace-members"; - paths = - let members = builtins.attrValues workspaceMembers; - in builtins.map (m: m.build) members; + name = "all-workspace-members"; + paths = + let + members = builtins.attrValues workspaceMembers; + in + builtins.map (m: m.build) members; }; # @@ -128,7 +135,11 @@ rec { name = "time"; packageId = "time"; optional = true; - features = [ "macros" "parsing" "formatting" ]; + features = [ + "macros" + "parsing" + "formatting" + ]; } ]; features = { @@ -142,7 +153,12 @@ rec { "serialize" = [ "cookie-factory" ]; "time" = [ "dep:time" ]; }; - resolvedDefaultFeatures = [ "datetime" "default" "std" "time" ]; + resolvedDefaultFeatures = [ + "datetime" + "default" + "std" + "time" + ]; }; "asn1-rs-derive" = rec { crateName = "asn1-rs-derive"; @@ -230,7 +246,10 @@ rec { features = { "default" = [ "std" ]; }; - resolvedDefaultFeatures = [ "default" "std" ]; + resolvedDefaultFeatures = [ + "default" + "std" + ]; }; "base64ct" = rec { crateName = "base64ct"; @@ -255,7 +274,10 @@ rec { features = { "compiler_builtins" = [ "dep:compiler_builtins" ]; "core" = [ "dep:core" ]; - "rustc-dep-of-std" = [ "core" "compiler_builtins" ]; + "rustc-dep-of-std" = [ + "core" + "compiler_builtins" + ]; }; resolvedDefaultFeatures = [ "default" ]; }; @@ -282,7 +304,10 @@ rec { "no-std" = [ "cstr_core/alloc" ]; "vendored" = [ "botan-sys/vendored" ]; }; - resolvedDefaultFeatures = [ "default" "vendored" ]; + resolvedDefaultFeatures = [ + "default" + "vendored" + ]; }; "botan-src" = rec { crateName = "botan-src"; @@ -320,7 +345,11 @@ rec { "botan-src" = [ "dep:botan-src" ]; "vendored" = [ "botan-src" ]; }; - resolvedDefaultFeatures = [ "botan-src" "default" "vendored" ]; + resolvedDefaultFeatures = [ + "botan-src" + "default" + "vendored" + ]; }; "bumpalo" = rec { crateName = "bumpalo"; @@ -350,7 +379,7 @@ rec { crateName = "cc"; version = "1.0.72"; edition = "2018"; - crateBin = []; + crateBin = [ ]; sha256 = "1vl50h2qh0nh0iddzj6gd1pnxnxpvwmbfxc30578c1pajmxi7a92"; authors = [ "Alex Crichton " @@ -371,7 +400,10 @@ rec { features = { "compiler_builtins" = [ "dep:compiler_builtins" ]; "core" = [ "dep:core" ]; - "rustc-dep-of-std" = [ "core" "compiler_builtins" ]; + "rustc-dep-of-std" = [ + "core" + "compiler_builtins" + ]; }; }; "const-oid" = rec { @@ -418,7 +450,12 @@ rec { "rlp" = [ "dep:rlp" ]; "zeroize" = [ "dep:zeroize" ]; }; - resolvedDefaultFeatures = [ "default" "generic-array" "rand" "rand_core" ]; + resolvedDefaultFeatures = [ + "default" + "generic-array" + "rand" + "rand_core" + ]; }; "cty" = rec { crateName = "cty"; @@ -442,7 +479,11 @@ rec { "default" = [ "std" ]; "std" = [ "alloc" ]; }; - resolvedDefaultFeatures = [ "alloc" "default" "std" ]; + resolvedDefaultFeatures = [ + "alloc" + "default" + "std" + ]; }; "der" = rec { crateName = "der"; @@ -474,7 +515,14 @@ rec { "oid" = [ "const-oid" ]; "std" = [ "alloc" ]; }; - resolvedDefaultFeatures = [ "alloc" "bigint" "const-oid" "crypto-bigint" "oid" "std" ]; + resolvedDefaultFeatures = [ + "alloc" + "bigint" + "const-oid" + "crypto-bigint" + "oid" + "std" + ]; }; "der-parser" = rec { crateName = "der-parser"; @@ -517,9 +565,17 @@ rec { "cookie-factory" = [ "dep:cookie-factory" ]; "default" = [ "std" ]; "num-bigint" = [ "dep:num-bigint" ]; - "serialize" = [ "std" "cookie-factory" ]; + "serialize" = [ + "std" + "cookie-factory" + ]; }; - resolvedDefaultFeatures = [ "bigint" "default" "num-bigint" "std" ]; + resolvedDefaultFeatures = [ + "bigint" + "default" + "num-bigint" + "std" + ]; }; "digest" = rec { crateName = "digest"; @@ -540,7 +596,10 @@ rec { "dev" = [ "blobby" ]; "std" = [ "alloc" ]; }; - resolvedDefaultFeatures = [ "alloc" "std" ]; + resolvedDefaultFeatures = [ + "alloc" + "std" + ]; }; "displaydoc" = rec { crateName = "displaydoc"; @@ -568,7 +627,10 @@ rec { features = { "default" = [ "std" ]; }; - resolvedDefaultFeatures = [ "default" "std" ]; + resolvedDefaultFeatures = [ + "default" + "std" + ]; }; "foreign-types" = rec { crateName = "foreign-types"; @@ -650,9 +712,17 @@ rec { features = { "compiler_builtins" = [ "dep:compiler_builtins" ]; "core" = [ "dep:core" ]; - "js" = [ "wasm-bindgen" "js-sys" ]; + "js" = [ + "wasm-bindgen" + "js-sys" + ]; "js-sys" = [ "dep:js-sys" ]; - "rustc-dep-of-std" = [ "compiler_builtins" "core" "libc/rustc-dep-of-std" "wasi/rustc-dep-of-std" ]; + "rustc-dep-of-std" = [ + "compiler_builtins" + "core" + "libc/rustc-dep-of-std" + "wasi/rustc-dep-of-std" + ]; "wasm-bindgen" = [ "dep:wasm-bindgen" ]; }; resolvedDefaultFeatures = [ "std" ]; @@ -702,7 +772,10 @@ rec { "spin" = [ "dep:spin" ]; "spin_no_std" = [ "spin" ]; }; - resolvedDefaultFeatures = [ "spin" "spin_no_std" ]; + resolvedDefaultFeatures = [ + "spin" + "spin_no_std" + ]; }; "libc" = rec { crateName = "libc"; @@ -714,11 +787,17 @@ rec { ]; features = { "default" = [ "std" ]; - "rustc-dep-of-std" = [ "align" "rustc-std-workspace-core" ]; + "rustc-dep-of-std" = [ + "align" + "rustc-std-workspace-core" + ]; "rustc-std-workspace-core" = [ "dep:rustc-std-workspace-core" ]; "use_std" = [ "std" ]; }; - resolvedDefaultFeatures = [ "default" "std" ]; + resolvedDefaultFeatures = [ + "default" + "std" + ]; }; "libm" = rec { crateName = "libm"; @@ -750,9 +829,21 @@ rec { ]; features = { "kv_unstable" = [ "value-bag" ]; - "kv_unstable_serde" = [ "kv_unstable_std" "value-bag/serde" "serde" ]; - "kv_unstable_std" = [ "std" "kv_unstable" "value-bag/error" ]; - "kv_unstable_sval" = [ "kv_unstable" "value-bag/sval" "sval" ]; + "kv_unstable_serde" = [ + "kv_unstable_std" + "value-bag/serde" + "serde" + ]; + "kv_unstable_std" = [ + "std" + "kv_unstable" + "value-bag/error" + ]; + "kv_unstable_sval" = [ + "kv_unstable" + "value-bag/sval" + "sval" + ]; "serde" = [ "dep:serde" ]; "sval" = [ "dep:sval" ]; "value-bag" = [ "dep:value-bag" ]; @@ -772,7 +863,10 @@ rec { "core" = [ "dep:core" ]; "default" = [ "std" ]; "libc" = [ "dep:libc" ]; - "rustc-dep-of-std" = [ "core" "compiler_builtins" ]; + "rustc-dep-of-std" = [ + "core" + "compiler_builtins" + ]; "use_std" = [ "std" ]; }; resolvedDefaultFeatures = [ "std" ]; @@ -818,9 +912,17 @@ rec { ]; features = { "default" = [ "std" ]; - "std" = [ "alloc" "memchr/std" "minimal-lexical/std" ]; + "std" = [ + "alloc" + "memchr/std" + "minimal-lexical/std" + ]; }; - resolvedDefaultFeatures = [ "alloc" "default" "std" ]; + resolvedDefaultFeatures = [ + "alloc" + "default" + "std" + ]; }; "num-bigint" = rec { crateName = "num-bigint"; @@ -856,9 +958,15 @@ rec { "quickcheck" = [ "dep:quickcheck" ]; "rand" = [ "dep:rand" ]; "serde" = [ "dep:serde" ]; - "std" = [ "num-integer/std" "num-traits/std" ]; + "std" = [ + "num-integer/std" + "num-traits/std" + ]; }; - resolvedDefaultFeatures = [ "default" "std" ]; + resolvedDefaultFeatures = [ + "default" + "std" + ]; }; "num-bigint-dig" = rec { crateName = "num-bigint-dig"; @@ -933,15 +1041,34 @@ rec { } ]; features = { - "default" = [ "std" "i128" "u64_digit" ]; - "i128" = [ "num-integer/i128" "num-traits/i128" ]; + "default" = [ + "std" + "i128" + "u64_digit" + ]; + "i128" = [ + "num-integer/i128" + "num-traits/i128" + ]; "prime" = [ "rand/std_rng" ]; "rand" = [ "dep:rand" ]; "serde" = [ "dep:serde" ]; - "std" = [ "num-integer/std" "num-traits/std" "smallvec/write" "rand/std" "serde/std" ]; + "std" = [ + "num-integer/std" + "num-traits/std" + "smallvec/write" + "rand/std" + "serde/std" + ]; "zeroize" = [ "dep:zeroize" ]; }; - resolvedDefaultFeatures = [ "i128" "prime" "rand" "u64_digit" "zeroize" ]; + resolvedDefaultFeatures = [ + "i128" + "prime" + "rand" + "u64_digit" + "zeroize" + ]; }; "num-integer" = rec { crateName = "num-integer"; @@ -969,7 +1096,10 @@ rec { "i128" = [ "num-traits/i128" ]; "std" = [ "num-traits/std" ]; }; - resolvedDefaultFeatures = [ "i128" "std" ]; + resolvedDefaultFeatures = [ + "i128" + "std" + ]; }; "num-iter" = rec { crateName = "num-iter"; @@ -999,8 +1129,14 @@ rec { ]; features = { "default" = [ "std" ]; - "i128" = [ "num-integer/i128" "num-traits/i128" ]; - "std" = [ "num-integer/std" "num-traits/std" ]; + "i128" = [ + "num-integer/i128" + "num-traits/i128" + ]; + "std" = [ + "num-integer/std" + "num-traits/std" + ]; }; }; "num-traits" = rec { @@ -1028,7 +1164,12 @@ rec { "default" = [ "std" ]; "libm" = [ "dep:libm" ]; }; - resolvedDefaultFeatures = [ "default" "i128" "libm" "std" ]; + resolvedDefaultFeatures = [ + "default" + "i128" + "libm" + "std" + ]; }; "num_threads" = rec { crateName = "num_threads"; @@ -1062,10 +1203,30 @@ rec { } ]; features = { - "crypto" = [ "kdf" "pkcs1" "pkcs7" "pkcs9" "pkcs12" "nist_algs" "x962" ]; + "crypto" = [ + "kdf" + "pkcs1" + "pkcs7" + "pkcs9" + "pkcs12" + "nist_algs" + "x962" + ]; "default" = [ "registry" ]; }; - resolvedDefaultFeatures = [ "crypto" "default" "kdf" "nist_algs" "pkcs1" "pkcs12" "pkcs7" "pkcs9" "registry" "x509" "x962" ]; + resolvedDefaultFeatures = [ + "crypto" + "default" + "kdf" + "nist_algs" + "pkcs1" + "pkcs12" + "pkcs7" + "pkcs9" + "registry" + "x509" + "x962" + ]; }; "once_cell" = rec { crateName = "once_cell"; @@ -1082,7 +1243,12 @@ rec { "parking_lot" = [ "dep:parking_lot" ]; "std" = [ "alloc" ]; }; - resolvedDefaultFeatures = [ "alloc" "default" "race" "std" ]; + resolvedDefaultFeatures = [ + "alloc" + "default" + "race" + "std" + ]; }; "openssl" = rec { crateName = "openssl"; @@ -1155,7 +1321,7 @@ rec { { name = "vcpkg"; packageId = "vcpkg"; - target = {target, features}: (target."env" == "msvc"); + target = { target, features }: (target."env" == "msvc"); } ]; features = { @@ -1210,7 +1376,10 @@ rec { { name = "der"; packageId = "der"; - features = [ "bigint" "oid" ]; + features = [ + "bigint" + "oid" + ]; } { name = "pem-rfc7468"; @@ -1226,12 +1395,24 @@ rec { } ]; features = { - "alloc" = [ "der/alloc" "zeroize" ]; - "pem" = [ "alloc" "pem-rfc7468/alloc" ]; + "alloc" = [ + "der/alloc" + "zeroize" + ]; + "pem" = [ + "alloc" + "pem-rfc7468/alloc" + ]; "pem-rfc7468" = [ "dep:pem-rfc7468" ]; "zeroize" = [ "dep:zeroize" ]; }; - resolvedDefaultFeatures = [ "alloc" "pem" "pem-rfc7468" "std" "zeroize" ]; + resolvedDefaultFeatures = [ + "alloc" + "pem" + "pem-rfc7468" + "std" + "zeroize" + ]; }; "pkcs8" = rec { crateName = "pkcs8"; @@ -1271,20 +1452,50 @@ rec { } ]; features = { - "3des" = [ "encryption" "pkcs5/3des" ]; - "alloc" = [ "der/alloc" "zeroize" ]; - "des-insecure" = [ "encryption" "pkcs5/des-insecure" ]; - "encryption" = [ "alloc" "pkcs5/alloc" "pkcs5/pbes2" "rand_core" ]; - "pem" = [ "alloc" "pem-rfc7468/alloc" ]; + "3des" = [ + "encryption" + "pkcs5/3des" + ]; + "alloc" = [ + "der/alloc" + "zeroize" + ]; + "des-insecure" = [ + "encryption" + "pkcs5/des-insecure" + ]; + "encryption" = [ + "alloc" + "pkcs5/alloc" + "pkcs5/pbes2" + "rand_core" + ]; + "pem" = [ + "alloc" + "pem-rfc7468/alloc" + ]; "pem-rfc7468" = [ "dep:pem-rfc7468" ]; "pkcs1" = [ "dep:pkcs1" ]; "pkcs5" = [ "dep:pkcs5" ]; "rand_core" = [ "dep:rand_core" ]; - "sha1" = [ "encryption" "pkcs5/sha1" ]; - "std" = [ "alloc" "der/std" ]; + "sha1" = [ + "encryption" + "pkcs5/sha1" + ]; + "std" = [ + "alloc" + "der/std" + ]; "zeroize" = [ "dep:zeroize" ]; }; - resolvedDefaultFeatures = [ "alloc" "pem" "pem-rfc7468" "pkcs1" "std" "zeroize" ]; + resolvedDefaultFeatures = [ + "alloc" + "pem" + "pem-rfc7468" + "pkcs1" + "std" + "zeroize" + ]; }; "pkg-config" = rec { crateName = "pkg-config"; @@ -1307,7 +1518,10 @@ rec { features = { "default" = [ "std" ]; }; - resolvedDefaultFeatures = [ "simd" "std" ]; + resolvedDefaultFeatures = [ + "simd" + "std" + ]; }; "proc-macro2" = rec { crateName = "proc-macro2"; @@ -1327,7 +1541,10 @@ rec { features = { "default" = [ "proc-macro" ]; }; - resolvedDefaultFeatures = [ "default" "proc-macro" ]; + resolvedDefaultFeatures = [ + "default" + "proc-macro" + ]; }; "quote" = rec { crateName = "quote"; @@ -1348,7 +1565,10 @@ rec { "default" = [ "proc-macro" ]; "proc-macro" = [ "proc-macro2/proc-macro" ]; }; - resolvedDefaultFeatures = [ "default" "proc-macro" ]; + resolvedDefaultFeatures = [ + "default" + "proc-macro" + ]; }; "rand" = rec { crateName = "rand"; @@ -1393,7 +1613,10 @@ rec { ]; features = { "alloc" = [ "rand_core/alloc" ]; - "default" = [ "std" "std_rng" ]; + "default" = [ + "std" + "std_rng" + ]; "getrandom" = [ "rand_core/getrandom" ]; "libc" = [ "dep:libc" ]; "log" = [ "dep:log" ]; @@ -1401,12 +1624,33 @@ rec { "rand_chacha" = [ "dep:rand_chacha" ]; "rand_hc" = [ "dep:rand_hc" ]; "serde" = [ "dep:serde" ]; - "serde1" = [ "serde" "rand_core/serde1" ]; + "serde1" = [ + "serde" + "rand_core/serde1" + ]; "simd_support" = [ "packed_simd" ]; - "std" = [ "rand_core/std" "rand_chacha/std" "alloc" "getrandom" "libc" ]; - "std_rng" = [ "rand_chacha" "rand_hc" ]; + "std" = [ + "rand_core/std" + "rand_chacha/std" + "alloc" + "getrandom" + "libc" + ]; + "std_rng" = [ + "rand_chacha" + "rand_hc" + ]; }; - resolvedDefaultFeatures = [ "alloc" "default" "getrandom" "libc" "rand_chacha" "rand_hc" "std" "std_rng" ]; + resolvedDefaultFeatures = [ + "alloc" + "default" + "getrandom" + "libc" + "rand_chacha" + "rand_hc" + "std" + "std_rng" + ]; }; "rand_chacha" = rec { crateName = "rand_chacha"; @@ -1458,9 +1702,17 @@ rec { "getrandom" = [ "dep:getrandom" ]; "serde" = [ "dep:serde" ]; "serde1" = [ "serde" ]; - "std" = [ "alloc" "getrandom" "getrandom/std" ]; + "std" = [ + "alloc" + "getrandom" + "getrandom/std" + ]; }; - resolvedDefaultFeatures = [ "alloc" "getrandom" "std" ]; + resolvedDefaultFeatures = [ + "alloc" + "getrandom" + "std" + ]; }; "rand_hc" = rec { crateName = "rand_hc"; @@ -1483,7 +1735,10 @@ rec { version = "0.9.2"; edition = "2018"; crateBin = [ - { name = "rcgen"; path = "src/main.rs"; } + { + name = "rcgen"; + path = "src/main.rs"; + } ]; sha256 = "0ppwfl9g504x2qwk7m7mag8c3l70w9mcfha93013nlzqdlw2vynp"; authors = [ @@ -1513,7 +1768,10 @@ rec { { name = "yasna"; packageId = "yasna"; - features = [ "time" "std" ]; + features = [ + "time" + "std" + ]; } { name = "zeroize"; @@ -1556,7 +1814,12 @@ rec { "x509-parser" = [ "dep:x509-parser" ]; "zeroize" = [ "dep:zeroize" ]; }; - resolvedDefaultFeatures = [ "default" "pem" "x509-parser" "zeroize" ]; + resolvedDefaultFeatures = [ + "default" + "pem" + "x509-parser" + "zeroize" + ]; }; "ring" = rec { crateName = "ring"; @@ -1585,14 +1848,32 @@ rec { name = "once_cell"; packageId = "once_cell"; usesDefaultFeatures = false; - target = { target, features }: ((target."os" == "dragonfly") || (target."os" == "freebsd") || (target."os" == "illumos") || (target."os" == "netbsd") || (target."os" == "openbsd") || (target."os" == "solaris")); + target = + { target, features }: + ( + (target."os" == "dragonfly") + || (target."os" == "freebsd") + || (target."os" == "illumos") + || (target."os" == "netbsd") + || (target."os" == "openbsd") + || (target."os" == "solaris") + ); features = [ "std" ]; } { name = "spin"; packageId = "spin"; usesDefaultFeatures = false; - target = { target, features }: ((target."arch" == "x86") || (target."arch" == "x86_64") || (((target."arch" == "aarch64") || (target."arch" == "arm")) && ((target."os" == "android") || (target."os" == "fuchsia") || (target."os" == "linux")))); + target = + { target, features }: + ( + (target."arch" == "x86") + || (target."arch" == "x86_64") + || ( + ((target."arch" == "aarch64") || (target."arch" == "arm")) + && ((target."os" == "android") || (target."os" == "fuchsia") || (target."os" == "linux")) + ) + ); } { name = "untrusted"; @@ -1602,15 +1883,28 @@ rec { name = "web-sys"; packageId = "web-sys"; usesDefaultFeatures = false; - target = { target, features }: ((target."arch" == "wasm32") && (target."vendor" == "unknown") && (target."os" == "unknown") && (target."env" == "")); - features = [ "Crypto" "Window" ]; + target = + { target, features }: + ( + (target."arch" == "wasm32") + && (target."vendor" == "unknown") + && (target."os" == "unknown") + && (target."env" == "") + ); + features = [ + "Crypto" + "Window" + ]; } { name = "winapi"; packageId = "winapi"; usesDefaultFeatures = false; target = { target, features }: (target."os" == "windows"); - features = [ "ntsecapi" "wtypesbase" ]; + features = [ + "ntsecapi" + "wtypesbase" + ]; } ]; buildDependencies = [ @@ -1625,16 +1919,24 @@ rec { name = "libc"; packageId = "libc"; usesDefaultFeatures = false; - target = {target, features}: ((target."unix" or false) || (target."windows" or false)); + target = { target, features }: ((target."unix" or false) || (target."windows" or false)); } ]; features = { - "default" = [ "alloc" "dev_urandom_fallback" ]; + "default" = [ + "alloc" + "dev_urandom_fallback" + ]; "dev_urandom_fallback" = [ "once_cell" ]; "once_cell" = [ "dep:once_cell" ]; "std" = [ "alloc" ]; }; - resolvedDefaultFeatures = [ "alloc" "default" "dev_urandom_fallback" "once_cell" ]; + resolvedDefaultFeatures = [ + "alloc" + "default" + "dev_urandom_fallback" + "once_cell" + ]; }; "rsa" = rec { crateName = "rsa"; @@ -1666,7 +1968,12 @@ rec { packageId = "num-bigint-dig"; rename = "num-bigint"; usesDefaultFeatures = false; - features = [ "i128" "u64_digit" "prime" "zeroize" ]; + features = [ + "i128" + "u64_digit" + "prime" + "zeroize" + ]; } { name = "num-integer"; @@ -1708,20 +2015,52 @@ rec { { name = "zeroize"; packageId = "zeroize"; - features = [ "alloc" "zeroize_derive" ]; + features = [ + "alloc" + "zeroize_derive" + ]; } ]; features = { - "alloc" = [ "digest/alloc" "pkcs1/alloc" "pkcs8/alloc" "pkcs8/pkcs1" ]; - "default" = [ "std" "pem" ]; - "nightly" = [ "subtle/nightly" "num-bigint/nightly" ]; - "pem" = [ "alloc" "pkcs1/pem" "pkcs8/pem" ]; + "alloc" = [ + "digest/alloc" + "pkcs1/alloc" + "pkcs8/alloc" + "pkcs8/pkcs1" + ]; + "default" = [ + "std" + "pem" + ]; + "nightly" = [ + "subtle/nightly" + "num-bigint/nightly" + ]; + "pem" = [ + "alloc" + "pkcs1/pem" + "pkcs8/pem" + ]; "pkcs5" = [ "pkcs8/encryption" ]; - "serde" = [ "num-bigint/serde" "serde_crate" ]; + "serde" = [ + "num-bigint/serde" + "serde_crate" + ]; "serde_crate" = [ "dep:serde_crate" ]; - "std" = [ "alloc" "digest/std" "pkcs1/std" "pkcs8/std" "rand/std" ]; + "std" = [ + "alloc" + "digest/std" + "pkcs1/std" + "pkcs8/std" + "rand/std" + ]; }; - resolvedDefaultFeatures = [ "alloc" "default" "pem" "std" ]; + resolvedDefaultFeatures = [ + "alloc" + "default" + "pem" + "std" + ]; }; "rusticata-macros" = rec { crateName = "rusticata-macros"; @@ -1795,7 +2134,10 @@ rec { "Henry de Valence " ]; features = { - "default" = [ "std" "i128" ]; + "default" = [ + "std" + "i128" + ]; }; }; "syn" = rec { @@ -1824,13 +2166,33 @@ rec { } ]; features = { - "default" = [ "derive" "parsing" "printing" "clone-impls" "proc-macro" ]; + "default" = [ + "derive" + "parsing" + "printing" + "clone-impls" + "proc-macro" + ]; "printing" = [ "quote" ]; - "proc-macro" = [ "proc-macro2/proc-macro" "quote/proc-macro" ]; + "proc-macro" = [ + "proc-macro2/proc-macro" + "quote/proc-macro" + ]; "quote" = [ "dep:quote" ]; "test" = [ "syn-test-suite/all-features" ]; }; - resolvedDefaultFeatures = [ "clone-impls" "default" "derive" "extra-traits" "full" "parsing" "printing" "proc-macro" "quote" "visit" ]; + resolvedDefaultFeatures = [ + "clone-impls" + "default" + "derive" + "extra-traits" + "full" + "parsing" + "printing" + "proc-macro" + "quote" + "visit" + ]; }; "synstructure" = rec { crateName = "synstructure"; @@ -1855,7 +2217,14 @@ rec { name = "syn"; packageId = "syn"; usesDefaultFeatures = false; - features = [ "derive" "parsing" "printing" "clone-impls" "visit" "extra-traits" ]; + features = [ + "derive" + "parsing" + "printing" + "clone-impls" + "visit" + "extra-traits" + ]; } { name = "unicode-xid"; @@ -1864,9 +2233,16 @@ rec { ]; features = { "default" = [ "proc-macro" ]; - "proc-macro" = [ "proc-macro2/proc-macro" "syn/proc-macro" "quote/proc-macro" ]; + "proc-macro" = [ + "proc-macro2/proc-macro" + "syn/proc-macro" + "quote/proc-macro" + ]; }; - resolvedDefaultFeatures = [ "default" "proc-macro" ]; + resolvedDefaultFeatures = [ + "default" + "proc-macro" + ]; }; "thiserror" = rec { crateName = "thiserror"; @@ -1942,21 +2318,44 @@ rec { ]; features = { "default" = [ "std" ]; - "formatting" = [ "itoa" "std" ]; + "formatting" = [ + "itoa" + "std" + ]; "itoa" = [ "dep:itoa" ]; "large-dates" = [ "time-macros/large-dates" ]; "local-offset" = [ "std" ]; "macros" = [ "time-macros" ]; - "quickcheck" = [ "quickcheck-dep" "alloc" ]; + "quickcheck" = [ + "quickcheck-dep" + "alloc" + ]; "quickcheck-dep" = [ "dep:quickcheck-dep" ]; "rand" = [ "dep:rand" ]; "serde" = [ "dep:serde" ]; - "serde-human-readable" = [ "serde" "formatting" "parsing" ]; - "serde-well-known" = [ "serde/alloc" "formatting" "parsing" ]; + "serde-human-readable" = [ + "serde" + "formatting" + "parsing" + ]; + "serde-well-known" = [ + "serde/alloc" + "formatting" + "parsing" + ]; "std" = [ "alloc" ]; "time-macros" = [ "dep:time-macros" ]; }; - resolvedDefaultFeatures = [ "alloc" "default" "formatting" "itoa" "macros" "parsing" "std" "time-macros" ]; + resolvedDefaultFeatures = [ + "alloc" + "default" + "formatting" + "itoa" + "macros" + "parsing" + "std" + "time-macros" + ]; }; "time-macros" = rec { crateName = "time-macros"; @@ -2043,10 +2442,17 @@ rec { "compiler_builtins" = [ "dep:compiler_builtins" ]; "core" = [ "dep:core" ]; "default" = [ "std" ]; - "rustc-dep-of-std" = [ "compiler_builtins" "core" "rustc-std-workspace-alloc" ]; + "rustc-dep-of-std" = [ + "compiler_builtins" + "core" + "rustc-std-workspace-alloc" + ]; "rustc-std-workspace-alloc" = [ "dep:rustc-std-workspace-alloc" ]; }; - resolvedDefaultFeatures = [ "default" "std" ]; + resolvedDefaultFeatures = [ + "default" + "std" + ]; }; "wasm-bindgen" = rec { crateName = "wasm-bindgen"; @@ -2067,16 +2473,29 @@ rec { } ]; features = { - "default" = [ "spans" "std" ]; + "default" = [ + "spans" + "std" + ]; "enable-interning" = [ "std" ]; "serde" = [ "dep:serde" ]; - "serde-serialize" = [ "serde" "serde_json" "std" ]; + "serde-serialize" = [ + "serde" + "serde_json" + "std" + ]; "serde_json" = [ "dep:serde_json" ]; "spans" = [ "wasm-bindgen-macro/spans" ]; "strict-macro" = [ "wasm-bindgen-macro/strict-macro" ]; - "xxx_debug_only_print_generated_code" = [ "wasm-bindgen-macro/xxx_debug_only_print_generated_code" ]; + "xxx_debug_only_print_generated_code" = [ + "wasm-bindgen-macro/xxx_debug_only_print_generated_code" + ]; }; - resolvedDefaultFeatures = [ "default" "spans" "std" ]; + resolvedDefaultFeatures = [ + "default" + "spans" + "std" + ]; }; "wasm-bindgen-backend" = rec { crateName = "wasm-bindgen-backend"; @@ -2167,7 +2586,10 @@ rec { { name = "syn"; packageId = "syn"; - features = [ "visit" "full" ]; + features = [ + "visit" + "full" + ]; } { name = "wasm-bindgen-backend"; @@ -2214,51 +2636,122 @@ rec { ]; features = { "AbortSignal" = [ "EventTarget" ]; - "AnalyserNode" = [ "AudioNode" "EventTarget" ]; + "AnalyserNode" = [ + "AudioNode" + "EventTarget" + ]; "Animation" = [ "EventTarget" ]; "AnimationEvent" = [ "Event" ]; "AnimationPlaybackEvent" = [ "Event" ]; - "Attr" = [ "EventTarget" "Node" ]; - "AudioBufferSourceNode" = [ "AudioNode" "AudioScheduledSourceNode" "EventTarget" ]; - "AudioContext" = [ "BaseAudioContext" "EventTarget" ]; - "AudioDestinationNode" = [ "AudioNode" "EventTarget" ]; + "Attr" = [ + "EventTarget" + "Node" + ]; + "AudioBufferSourceNode" = [ + "AudioNode" + "AudioScheduledSourceNode" + "EventTarget" + ]; + "AudioContext" = [ + "BaseAudioContext" + "EventTarget" + ]; + "AudioDestinationNode" = [ + "AudioNode" + "EventTarget" + ]; "AudioNode" = [ "EventTarget" ]; "AudioProcessingEvent" = [ "Event" ]; - "AudioScheduledSourceNode" = [ "AudioNode" "EventTarget" ]; - "AudioStreamTrack" = [ "EventTarget" "MediaStreamTrack" ]; + "AudioScheduledSourceNode" = [ + "AudioNode" + "EventTarget" + ]; + "AudioStreamTrack" = [ + "EventTarget" + "MediaStreamTrack" + ]; "AudioTrackList" = [ "EventTarget" ]; "AudioWorklet" = [ "Worklet" ]; "AudioWorkletGlobalScope" = [ "WorkletGlobalScope" ]; - "AudioWorkletNode" = [ "AudioNode" "EventTarget" ]; + "AudioWorkletNode" = [ + "AudioNode" + "EventTarget" + ]; "AuthenticatorAssertionResponse" = [ "AuthenticatorResponse" ]; "AuthenticatorAttestationResponse" = [ "AuthenticatorResponse" ]; "BaseAudioContext" = [ "EventTarget" ]; "BatteryManager" = [ "EventTarget" ]; "BeforeUnloadEvent" = [ "Event" ]; - "BiquadFilterNode" = [ "AudioNode" "EventTarget" ]; + "BiquadFilterNode" = [ + "AudioNode" + "EventTarget" + ]; "BlobEvent" = [ "Event" ]; "Bluetooth" = [ "EventTarget" ]; "BluetoothAdvertisingEvent" = [ "Event" ]; "BluetoothDevice" = [ "EventTarget" ]; - "BluetoothPermissionResult" = [ "EventTarget" "PermissionStatus" ]; + "BluetoothPermissionResult" = [ + "EventTarget" + "PermissionStatus" + ]; "BluetoothRemoteGattCharacteristic" = [ "EventTarget" ]; "BluetoothRemoteGattService" = [ "EventTarget" ]; "BroadcastChannel" = [ "EventTarget" ]; - "CanvasCaptureMediaStream" = [ "EventTarget" "MediaStream" ]; - "CdataSection" = [ "CharacterData" "EventTarget" "Node" "Text" ]; - "ChannelMergerNode" = [ "AudioNode" "EventTarget" ]; - "ChannelSplitterNode" = [ "AudioNode" "EventTarget" ]; - "CharacterData" = [ "EventTarget" "Node" ]; - "ChromeWorker" = [ "EventTarget" "Worker" ]; + "CanvasCaptureMediaStream" = [ + "EventTarget" + "MediaStream" + ]; + "CdataSection" = [ + "CharacterData" + "EventTarget" + "Node" + "Text" + ]; + "ChannelMergerNode" = [ + "AudioNode" + "EventTarget" + ]; + "ChannelSplitterNode" = [ + "AudioNode" + "EventTarget" + ]; + "CharacterData" = [ + "EventTarget" + "Node" + ]; + "ChromeWorker" = [ + "EventTarget" + "Worker" + ]; "Clipboard" = [ "EventTarget" ]; "ClipboardEvent" = [ "Event" ]; "CloseEvent" = [ "Event" ]; - "Comment" = [ "CharacterData" "EventTarget" "Node" ]; - "CompositionEvent" = [ "Event" "UiEvent" ]; - "ConstantSourceNode" = [ "AudioNode" "AudioScheduledSourceNode" "EventTarget" ]; - "ConvolverNode" = [ "AudioNode" "EventTarget" ]; - "CssAnimation" = [ "Animation" "EventTarget" ]; - "CssConditionRule" = [ "CssGroupingRule" "CssRule" ]; + "Comment" = [ + "CharacterData" + "EventTarget" + "Node" + ]; + "CompositionEvent" = [ + "Event" + "UiEvent" + ]; + "ConstantSourceNode" = [ + "AudioNode" + "AudioScheduledSourceNode" + "EventTarget" + ]; + "ConvolverNode" = [ + "AudioNode" + "EventTarget" + ]; + "CssAnimation" = [ + "Animation" + "EventTarget" + ]; + "CssConditionRule" = [ + "CssGroupingRule" + "CssRule" + ]; "CssCounterStyleRule" = [ "CssRule" ]; "CssFontFaceRule" = [ "CssRule" ]; "CssFontFeatureValuesRule" = [ "CssRule" ]; @@ -2266,47 +2759,101 @@ rec { "CssImportRule" = [ "CssRule" ]; "CssKeyframeRule" = [ "CssRule" ]; "CssKeyframesRule" = [ "CssRule" ]; - "CssMediaRule" = [ "CssConditionRule" "CssGroupingRule" "CssRule" ]; + "CssMediaRule" = [ + "CssConditionRule" + "CssGroupingRule" + "CssRule" + ]; "CssNamespaceRule" = [ "CssRule" ]; "CssPageRule" = [ "CssRule" ]; "CssStyleRule" = [ "CssRule" ]; "CssStyleSheet" = [ "StyleSheet" ]; - "CssSupportsRule" = [ "CssConditionRule" "CssGroupingRule" "CssRule" ]; - "CssTransition" = [ "Animation" "EventTarget" ]; + "CssSupportsRule" = [ + "CssConditionRule" + "CssGroupingRule" + "CssRule" + ]; + "CssTransition" = [ + "Animation" + "EventTarget" + ]; "CustomEvent" = [ "Event" ]; - "DedicatedWorkerGlobalScope" = [ "EventTarget" "WorkerGlobalScope" ]; - "DelayNode" = [ "AudioNode" "EventTarget" ]; + "DedicatedWorkerGlobalScope" = [ + "EventTarget" + "WorkerGlobalScope" + ]; + "DelayNode" = [ + "AudioNode" + "EventTarget" + ]; "DeviceLightEvent" = [ "Event" ]; "DeviceMotionEvent" = [ "Event" ]; "DeviceOrientationEvent" = [ "Event" ]; "DeviceProximityEvent" = [ "Event" ]; - "Document" = [ "EventTarget" "Node" ]; - "DocumentFragment" = [ "EventTarget" "Node" ]; + "Document" = [ + "EventTarget" + "Node" + ]; + "DocumentFragment" = [ + "EventTarget" + "Node" + ]; "DocumentTimeline" = [ "AnimationTimeline" ]; - "DocumentType" = [ "EventTarget" "Node" ]; + "DocumentType" = [ + "EventTarget" + "Node" + ]; "DomMatrix" = [ "DomMatrixReadOnly" ]; "DomPoint" = [ "DomPointReadOnly" ]; "DomRect" = [ "DomRectReadOnly" ]; "DomRequest" = [ "EventTarget" ]; - "DragEvent" = [ "Event" "MouseEvent" "UiEvent" ]; - "DynamicsCompressorNode" = [ "AudioNode" "EventTarget" ]; - "Element" = [ "EventTarget" "Node" ]; + "DragEvent" = [ + "Event" + "MouseEvent" + "UiEvent" + ]; + "DynamicsCompressorNode" = [ + "AudioNode" + "EventTarget" + ]; + "Element" = [ + "EventTarget" + "Node" + ]; "ErrorEvent" = [ "Event" ]; "EventSource" = [ "EventTarget" ]; "ExtendableEvent" = [ "Event" ]; - "ExtendableMessageEvent" = [ "Event" "ExtendableEvent" ]; - "FetchEvent" = [ "Event" "ExtendableEvent" ]; + "ExtendableMessageEvent" = [ + "Event" + "ExtendableEvent" + ]; + "FetchEvent" = [ + "Event" + "ExtendableEvent" + ]; "FetchObserver" = [ "EventTarget" ]; "File" = [ "Blob" ]; "FileReader" = [ "EventTarget" ]; "FileSystemDirectoryEntry" = [ "FileSystemEntry" ]; "FileSystemFileEntry" = [ "FileSystemEntry" ]; - "FocusEvent" = [ "Event" "UiEvent" ]; + "FocusEvent" = [ + "Event" + "UiEvent" + ]; "FontFaceSet" = [ "EventTarget" ]; "FontFaceSetLoadEvent" = [ "Event" ]; - "GainNode" = [ "AudioNode" "EventTarget" ]; - "GamepadAxisMoveEvent" = [ "Event" "GamepadEvent" ]; - "GamepadButtonEvent" = [ "Event" "GamepadEvent" ]; + "GainNode" = [ + "AudioNode" + "EventTarget" + ]; + "GamepadAxisMoveEvent" = [ + "Event" + "GamepadEvent" + ]; + "GamepadButtonEvent" = [ + "Event" + "GamepadEvent" + ]; "GamepadEvent" = [ "Event" ]; "GpuDevice" = [ "EventTarget" ]; "GpuUncapturedErrorEvent" = [ "Event" ]; @@ -2315,98 +2862,479 @@ rec { "HidConnectionEvent" = [ "Event" ]; "HidDevice" = [ "EventTarget" ]; "HidInputReportEvent" = [ "Event" ]; - "HtmlAnchorElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlAreaElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlAudioElement" = [ "Element" "EventTarget" "HtmlElement" "HtmlMediaElement" "Node" ]; - "HtmlBaseElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlBodyElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlBrElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlButtonElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlCanvasElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlDListElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlDataElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlDataListElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlDetailsElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlDialogElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlDirectoryElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlDivElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlDocument" = [ "Document" "EventTarget" "Node" ]; - "HtmlElement" = [ "Element" "EventTarget" "Node" ]; - "HtmlEmbedElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlFieldSetElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlFontElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; + "HtmlAnchorElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlAreaElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlAudioElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "HtmlMediaElement" + "Node" + ]; + "HtmlBaseElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlBodyElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlBrElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlButtonElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlCanvasElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlDListElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlDataElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlDataListElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlDetailsElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlDialogElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlDirectoryElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlDivElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlDocument" = [ + "Document" + "EventTarget" + "Node" + ]; + "HtmlElement" = [ + "Element" + "EventTarget" + "Node" + ]; + "HtmlEmbedElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlFieldSetElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlFontElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; "HtmlFormControlsCollection" = [ "HtmlCollection" ]; - "HtmlFormElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlFrameElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlFrameSetElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlHeadElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlHeadingElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlHrElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlHtmlElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlIFrameElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlImageElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlInputElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlLabelElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlLegendElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlLiElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlLinkElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlMapElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlMediaElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlMenuElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlMenuItemElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlMetaElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlMeterElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlModElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlOListElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlObjectElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlOptGroupElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlOptionElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; + "HtmlFormElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlFrameElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlFrameSetElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlHeadElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlHeadingElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlHrElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlHtmlElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlIFrameElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlImageElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlInputElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlLabelElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlLegendElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlLiElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlLinkElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlMapElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlMediaElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlMenuElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlMenuItemElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlMetaElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlMeterElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlModElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlOListElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlObjectElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlOptGroupElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlOptionElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; "HtmlOptionsCollection" = [ "HtmlCollection" ]; - "HtmlOutputElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlParagraphElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlParamElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlPictureElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlPreElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlProgressElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlQuoteElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlScriptElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlSelectElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlSlotElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlSourceElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlSpanElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlStyleElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlTableCaptionElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlTableCellElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlTableColElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlTableElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlTableRowElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlTableSectionElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlTemplateElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlTextAreaElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlTimeElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlTitleElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlTrackElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlUListElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlUnknownElement" = [ "Element" "EventTarget" "HtmlElement" "Node" ]; - "HtmlVideoElement" = [ "Element" "EventTarget" "HtmlElement" "HtmlMediaElement" "Node" ]; + "HtmlOutputElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlParagraphElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlParamElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlPictureElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlPreElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlProgressElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlQuoteElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlScriptElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlSelectElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlSlotElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlSourceElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlSpanElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlStyleElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlTableCaptionElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlTableCellElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlTableColElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlTableElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlTableRowElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlTableSectionElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlTemplateElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlTextAreaElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlTimeElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlTitleElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlTrackElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlUListElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlUnknownElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "Node" + ]; + "HtmlVideoElement" = [ + "Element" + "EventTarget" + "HtmlElement" + "HtmlMediaElement" + "Node" + ]; "IdbCursorWithValue" = [ "IdbCursor" ]; "IdbDatabase" = [ "EventTarget" ]; "IdbFileHandle" = [ "EventTarget" ]; - "IdbFileRequest" = [ "DomRequest" "EventTarget" ]; + "IdbFileRequest" = [ + "DomRequest" + "EventTarget" + ]; "IdbLocaleAwareKeyRange" = [ "IdbKeyRange" ]; "IdbMutableFile" = [ "EventTarget" ]; - "IdbOpenDbRequest" = [ "EventTarget" "IdbRequest" ]; + "IdbOpenDbRequest" = [ + "EventTarget" + "IdbRequest" + ]; "IdbRequest" = [ "EventTarget" ]; "IdbTransaction" = [ "EventTarget" ]; "IdbVersionChangeEvent" = [ "Event" ]; - "IirFilterNode" = [ "AudioNode" "EventTarget" ]; + "IirFilterNode" = [ + "AudioNode" + "EventTarget" + ]; "ImageCaptureErrorEvent" = [ "Event" ]; - "InputEvent" = [ "Event" "UiEvent" ]; - "KeyboardEvent" = [ "Event" "UiEvent" ]; + "InputEvent" = [ + "Event" + "UiEvent" + ]; + "KeyboardEvent" = [ + "Event" + "UiEvent" + ]; "KeyframeEffect" = [ "AnimationEffect" ]; - "LocalMediaStream" = [ "EventTarget" "MediaStream" ]; + "LocalMediaStream" = [ + "EventTarget" + "MediaStream" + ]; "MediaDevices" = [ "EventTarget" ]; - "MediaElementAudioSourceNode" = [ "AudioNode" "EventTarget" ]; + "MediaElementAudioSourceNode" = [ + "AudioNode" + "EventTarget" + ]; "MediaEncryptedEvent" = [ "Event" ]; "MediaKeyError" = [ "Event" ]; "MediaKeyMessageEvent" = [ "Event" ]; @@ -2417,8 +3345,14 @@ rec { "MediaRecorderErrorEvent" = [ "Event" ]; "MediaSource" = [ "EventTarget" ]; "MediaStream" = [ "EventTarget" ]; - "MediaStreamAudioDestinationNode" = [ "AudioNode" "EventTarget" ]; - "MediaStreamAudioSourceNode" = [ "AudioNode" "EventTarget" ]; + "MediaStreamAudioDestinationNode" = [ + "AudioNode" + "EventTarget" + ]; + "MediaStreamAudioSourceNode" = [ + "AudioNode" + "EventTarget" + ]; "MediaStreamEvent" = [ "Event" ]; "MediaStreamTrack" = [ "EventTarget" ]; "MediaStreamTrackEvent" = [ "Event" ]; @@ -2426,34 +3360,70 @@ rec { "MessagePort" = [ "EventTarget" ]; "MidiAccess" = [ "EventTarget" ]; "MidiConnectionEvent" = [ "Event" ]; - "MidiInput" = [ "EventTarget" "MidiPort" ]; + "MidiInput" = [ + "EventTarget" + "MidiPort" + ]; "MidiMessageEvent" = [ "Event" ]; - "MidiOutput" = [ "EventTarget" "MidiPort" ]; + "MidiOutput" = [ + "EventTarget" + "MidiPort" + ]; "MidiPort" = [ "EventTarget" ]; - "MouseEvent" = [ "Event" "UiEvent" ]; - "MouseScrollEvent" = [ "Event" "MouseEvent" "UiEvent" ]; + "MouseEvent" = [ + "Event" + "UiEvent" + ]; + "MouseScrollEvent" = [ + "Event" + "MouseEvent" + "UiEvent" + ]; "MutationEvent" = [ "Event" ]; "NetworkInformation" = [ "EventTarget" ]; "Node" = [ "EventTarget" ]; "Notification" = [ "EventTarget" ]; - "NotificationEvent" = [ "Event" "ExtendableEvent" ]; + "NotificationEvent" = [ + "Event" + "ExtendableEvent" + ]; "OfflineAudioCompletionEvent" = [ "Event" ]; - "OfflineAudioContext" = [ "BaseAudioContext" "EventTarget" ]; + "OfflineAudioContext" = [ + "BaseAudioContext" + "EventTarget" + ]; "OfflineResourceList" = [ "EventTarget" ]; "OffscreenCanvas" = [ "EventTarget" ]; - "OscillatorNode" = [ "AudioNode" "AudioScheduledSourceNode" "EventTarget" ]; + "OscillatorNode" = [ + "AudioNode" + "AudioScheduledSourceNode" + "EventTarget" + ]; "PageTransitionEvent" = [ "Event" ]; "PaintWorkletGlobalScope" = [ "WorkletGlobalScope" ]; - "PannerNode" = [ "AudioNode" "EventTarget" ]; - "PaymentMethodChangeEvent" = [ "Event" "PaymentRequestUpdateEvent" ]; + "PannerNode" = [ + "AudioNode" + "EventTarget" + ]; + "PaymentMethodChangeEvent" = [ + "Event" + "PaymentRequestUpdateEvent" + ]; "PaymentRequestUpdateEvent" = [ "Event" ]; "Performance" = [ "EventTarget" ]; "PerformanceMark" = [ "PerformanceEntry" ]; "PerformanceMeasure" = [ "PerformanceEntry" ]; - "PerformanceNavigationTiming" = [ "PerformanceEntry" "PerformanceResourceTiming" ]; + "PerformanceNavigationTiming" = [ + "PerformanceEntry" + "PerformanceResourceTiming" + ]; "PerformanceResourceTiming" = [ "PerformanceEntry" ]; "PermissionStatus" = [ "EventTarget" ]; - "PointerEvent" = [ "Event" "MouseEvent" "UiEvent" ]; + "PointerEvent" = [ + "Event" + "MouseEvent" + "UiEvent" + ]; "PopStateEvent" = [ "Event" ]; "PopupBlockedEvent" = [ "Event" ]; "PresentationAvailability" = [ "EventTarget" ]; @@ -2462,11 +3432,18 @@ rec { "PresentationConnectionCloseEvent" = [ "Event" ]; "PresentationConnectionList" = [ "EventTarget" ]; "PresentationRequest" = [ "EventTarget" ]; - "ProcessingInstruction" = [ "CharacterData" "EventTarget" "Node" ]; + "ProcessingInstruction" = [ + "CharacterData" + "EventTarget" + "Node" + ]; "ProgressEvent" = [ "Event" ]; "PromiseRejectionEvent" = [ "Event" ]; "PublicKeyCredential" = [ "Credential" ]; - "PushEvent" = [ "Event" "ExtendableEvent" ]; + "PushEvent" = [ + "Event" + "ExtendableEvent" + ]; "RadioNodeList" = [ "NodeList" ]; "RtcDataChannel" = [ "EventTarget" ]; "RtcDataChannelEvent" = [ "Event" ]; @@ -2477,50 +3454,202 @@ rec { "RtcdtmfToneChangeEvent" = [ "Event" ]; "Screen" = [ "EventTarget" ]; "ScreenOrientation" = [ "EventTarget" ]; - "ScriptProcessorNode" = [ "AudioNode" "EventTarget" ]; - "ScrollAreaEvent" = [ "Event" "UiEvent" ]; + "ScriptProcessorNode" = [ + "AudioNode" + "EventTarget" + ]; + "ScrollAreaEvent" = [ + "Event" + "UiEvent" + ]; "SecurityPolicyViolationEvent" = [ "Event" ]; "ServiceWorker" = [ "EventTarget" ]; "ServiceWorkerContainer" = [ "EventTarget" ]; - "ServiceWorkerGlobalScope" = [ "EventTarget" "WorkerGlobalScope" ]; + "ServiceWorkerGlobalScope" = [ + "EventTarget" + "WorkerGlobalScope" + ]; "ServiceWorkerRegistration" = [ "EventTarget" ]; - "ShadowRoot" = [ "DocumentFragment" "EventTarget" "Node" ]; + "ShadowRoot" = [ + "DocumentFragment" + "EventTarget" + "Node" + ]; "SharedWorker" = [ "EventTarget" ]; - "SharedWorkerGlobalScope" = [ "EventTarget" "WorkerGlobalScope" ]; + "SharedWorkerGlobalScope" = [ + "EventTarget" + "WorkerGlobalScope" + ]; "SourceBuffer" = [ "EventTarget" ]; "SourceBufferList" = [ "EventTarget" ]; "SpeechRecognition" = [ "EventTarget" ]; "SpeechRecognitionError" = [ "Event" ]; "SpeechRecognitionEvent" = [ "Event" ]; "SpeechSynthesis" = [ "EventTarget" ]; - "SpeechSynthesisErrorEvent" = [ "Event" "SpeechSynthesisEvent" ]; + "SpeechSynthesisErrorEvent" = [ + "Event" + "SpeechSynthesisEvent" + ]; "SpeechSynthesisEvent" = [ "Event" ]; "SpeechSynthesisUtterance" = [ "EventTarget" ]; - "StereoPannerNode" = [ "AudioNode" "EventTarget" ]; + "StereoPannerNode" = [ + "AudioNode" + "EventTarget" + ]; "StorageEvent" = [ "Event" ]; - "SvgAnimateElement" = [ "Element" "EventTarget" "Node" "SvgAnimationElement" "SvgElement" ]; - "SvgAnimateMotionElement" = [ "Element" "EventTarget" "Node" "SvgAnimationElement" "SvgElement" ]; - "SvgAnimateTransformElement" = [ "Element" "EventTarget" "Node" "SvgAnimationElement" "SvgElement" ]; - "SvgAnimationElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgCircleElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGeometryElement" "SvgGraphicsElement" ]; - "SvgClipPathElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgComponentTransferFunctionElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgDefsElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" ]; - "SvgDescElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgElement" = [ "Element" "EventTarget" "Node" ]; - "SvgEllipseElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGeometryElement" "SvgGraphicsElement" ]; - "SvgFilterElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgForeignObjectElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" ]; - "SvgGeometryElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" ]; - "SvgGradientElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgGraphicsElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgImageElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" ]; - "SvgLineElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGeometryElement" "SvgGraphicsElement" ]; - "SvgLinearGradientElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGradientElement" ]; - "SvgMarkerElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgMaskElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgMetadataElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgPathElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGeometryElement" "SvgGraphicsElement" ]; + "SvgAnimateElement" = [ + "Element" + "EventTarget" + "Node" + "SvgAnimationElement" + "SvgElement" + ]; + "SvgAnimateMotionElement" = [ + "Element" + "EventTarget" + "Node" + "SvgAnimationElement" + "SvgElement" + ]; + "SvgAnimateTransformElement" = [ + "Element" + "EventTarget" + "Node" + "SvgAnimationElement" + "SvgElement" + ]; + "SvgAnimationElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgCircleElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGeometryElement" + "SvgGraphicsElement" + ]; + "SvgClipPathElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgComponentTransferFunctionElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgDefsElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + ]; + "SvgDescElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgElement" = [ + "Element" + "EventTarget" + "Node" + ]; + "SvgEllipseElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGeometryElement" + "SvgGraphicsElement" + ]; + "SvgFilterElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgForeignObjectElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + ]; + "SvgGeometryElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + ]; + "SvgGradientElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgGraphicsElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgImageElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + ]; + "SvgLineElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGeometryElement" + "SvgGraphicsElement" + ]; + "SvgLinearGradientElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGradientElement" + ]; + "SvgMarkerElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgMaskElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgMetadataElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgPathElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGeometryElement" + "SvgGraphicsElement" + ]; "SvgPathSegArcAbs" = [ "SvgPathSeg" ]; "SvgPathSegArcRel" = [ "SvgPathSeg" ]; "SvgPathSegClosePath" = [ "SvgPathSeg" ]; @@ -2540,104 +3669,419 @@ rec { "SvgPathSegLinetoVerticalRel" = [ "SvgPathSeg" ]; "SvgPathSegMovetoAbs" = [ "SvgPathSeg" ]; "SvgPathSegMovetoRel" = [ "SvgPathSeg" ]; - "SvgPatternElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgPolygonElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGeometryElement" "SvgGraphicsElement" ]; - "SvgPolylineElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGeometryElement" "SvgGraphicsElement" ]; - "SvgRadialGradientElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGradientElement" ]; - "SvgRectElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGeometryElement" "SvgGraphicsElement" ]; - "SvgScriptElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgSetElement" = [ "Element" "EventTarget" "Node" "SvgAnimationElement" "SvgElement" ]; - "SvgStopElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgStyleElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgSwitchElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" ]; - "SvgSymbolElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgTextContentElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" ]; - "SvgTextElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" "SvgTextContentElement" "SvgTextPositioningElement" ]; - "SvgTextPathElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" "SvgTextContentElement" ]; - "SvgTextPositioningElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" "SvgTextContentElement" ]; - "SvgTitleElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgUseElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" ]; - "SvgViewElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgaElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" ]; - "SvgfeBlendElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeColorMatrixElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeComponentTransferElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeCompositeElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeConvolveMatrixElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeDiffuseLightingElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeDisplacementMapElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeDistantLightElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeDropShadowElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeFloodElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeFuncAElement" = [ "Element" "EventTarget" "Node" "SvgComponentTransferFunctionElement" "SvgElement" ]; - "SvgfeFuncBElement" = [ "Element" "EventTarget" "Node" "SvgComponentTransferFunctionElement" "SvgElement" ]; - "SvgfeFuncGElement" = [ "Element" "EventTarget" "Node" "SvgComponentTransferFunctionElement" "SvgElement" ]; - "SvgfeFuncRElement" = [ "Element" "EventTarget" "Node" "SvgComponentTransferFunctionElement" "SvgElement" ]; - "SvgfeGaussianBlurElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeImageElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeMergeElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeMergeNodeElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeMorphologyElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeOffsetElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfePointLightElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeSpecularLightingElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeSpotLightElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeTileElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgfeTurbulenceElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvggElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" ]; - "SvgmPathElement" = [ "Element" "EventTarget" "Node" "SvgElement" ]; - "SvgsvgElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" ]; - "SvgtSpanElement" = [ "Element" "EventTarget" "Node" "SvgElement" "SvgGraphicsElement" "SvgTextContentElement" "SvgTextPositioningElement" ]; + "SvgPatternElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgPolygonElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGeometryElement" + "SvgGraphicsElement" + ]; + "SvgPolylineElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGeometryElement" + "SvgGraphicsElement" + ]; + "SvgRadialGradientElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGradientElement" + ]; + "SvgRectElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGeometryElement" + "SvgGraphicsElement" + ]; + "SvgScriptElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgSetElement" = [ + "Element" + "EventTarget" + "Node" + "SvgAnimationElement" + "SvgElement" + ]; + "SvgStopElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgStyleElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgSwitchElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + ]; + "SvgSymbolElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgTextContentElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + ]; + "SvgTextElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + "SvgTextContentElement" + "SvgTextPositioningElement" + ]; + "SvgTextPathElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + "SvgTextContentElement" + ]; + "SvgTextPositioningElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + "SvgTextContentElement" + ]; + "SvgTitleElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgUseElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + ]; + "SvgViewElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgaElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + ]; + "SvgfeBlendElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeColorMatrixElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeComponentTransferElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeCompositeElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeConvolveMatrixElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeDiffuseLightingElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeDisplacementMapElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeDistantLightElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeDropShadowElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeFloodElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeFuncAElement" = [ + "Element" + "EventTarget" + "Node" + "SvgComponentTransferFunctionElement" + "SvgElement" + ]; + "SvgfeFuncBElement" = [ + "Element" + "EventTarget" + "Node" + "SvgComponentTransferFunctionElement" + "SvgElement" + ]; + "SvgfeFuncGElement" = [ + "Element" + "EventTarget" + "Node" + "SvgComponentTransferFunctionElement" + "SvgElement" + ]; + "SvgfeFuncRElement" = [ + "Element" + "EventTarget" + "Node" + "SvgComponentTransferFunctionElement" + "SvgElement" + ]; + "SvgfeGaussianBlurElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeImageElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeMergeElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeMergeNodeElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeMorphologyElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeOffsetElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfePointLightElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeSpecularLightingElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeSpotLightElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeTileElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgfeTurbulenceElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvggElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + ]; + "SvgmPathElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + ]; + "SvgsvgElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + ]; + "SvgtSpanElement" = [ + "Element" + "EventTarget" + "Node" + "SvgElement" + "SvgGraphicsElement" + "SvgTextContentElement" + "SvgTextPositioningElement" + ]; "TcpServerSocket" = [ "EventTarget" ]; "TcpServerSocketEvent" = [ "Event" ]; "TcpSocket" = [ "EventTarget" ]; "TcpSocketErrorEvent" = [ "Event" ]; "TcpSocketEvent" = [ "Event" ]; - "Text" = [ "CharacterData" "EventTarget" "Node" ]; + "Text" = [ + "CharacterData" + "EventTarget" + "Node" + ]; "TextTrack" = [ "EventTarget" ]; "TextTrackCue" = [ "EventTarget" ]; "TextTrackList" = [ "EventTarget" ]; "TimeEvent" = [ "Event" ]; - "TouchEvent" = [ "Event" "UiEvent" ]; + "TouchEvent" = [ + "Event" + "UiEvent" + ]; "TrackEvent" = [ "Event" ]; "TransitionEvent" = [ "Event" ]; "UiEvent" = [ "Event" ]; "Usb" = [ "EventTarget" ]; "UsbConnectionEvent" = [ "Event" ]; - "UsbPermissionResult" = [ "EventTarget" "PermissionStatus" ]; + "UsbPermissionResult" = [ + "EventTarget" + "PermissionStatus" + ]; "UserProximityEvent" = [ "Event" ]; "ValueEvent" = [ "Event" ]; - "VideoStreamTrack" = [ "EventTarget" "MediaStreamTrack" ]; + "VideoStreamTrack" = [ + "EventTarget" + "MediaStreamTrack" + ]; "VideoTrackList" = [ "EventTarget" ]; "VrDisplay" = [ "EventTarget" ]; - "VttCue" = [ "EventTarget" "TextTrackCue" ]; + "VttCue" = [ + "EventTarget" + "TextTrackCue" + ]; "WakeLockSentinel" = [ "EventTarget" ]; - "WaveShaperNode" = [ "AudioNode" "EventTarget" ]; + "WaveShaperNode" = [ + "AudioNode" + "EventTarget" + ]; "WebGlContextEvent" = [ "Event" ]; - "WebKitCssMatrix" = [ "DomMatrix" "DomMatrixReadOnly" ]; + "WebKitCssMatrix" = [ + "DomMatrix" + "DomMatrixReadOnly" + ]; "WebSocket" = [ "EventTarget" ]; - "WheelEvent" = [ "Event" "MouseEvent" "UiEvent" ]; + "WheelEvent" = [ + "Event" + "MouseEvent" + "UiEvent" + ]; "Window" = [ "EventTarget" ]; "WindowClient" = [ "Client" ]; "Worker" = [ "EventTarget" ]; "WorkerDebuggerGlobalScope" = [ "EventTarget" ]; "WorkerGlobalScope" = [ "EventTarget" ]; - "XmlDocument" = [ "Document" "EventTarget" "Node" ]; - "XmlHttpRequest" = [ "EventTarget" "XmlHttpRequestEventTarget" ]; + "XmlDocument" = [ + "Document" + "EventTarget" + "Node" + ]; + "XmlHttpRequest" = [ + "EventTarget" + "XmlHttpRequestEventTarget" + ]; "XmlHttpRequestEventTarget" = [ "EventTarget" ]; - "XmlHttpRequestUpload" = [ "EventTarget" "XmlHttpRequestEventTarget" ]; + "XmlHttpRequestUpload" = [ + "EventTarget" + "XmlHttpRequestEventTarget" + ]; "Xr" = [ "EventTarget" ]; - "XrBoundedReferenceSpace" = [ "EventTarget" "XrReferenceSpace" "XrSpace" ]; + "XrBoundedReferenceSpace" = [ + "EventTarget" + "XrReferenceSpace" + "XrSpace" + ]; "XrInputSourceEvent" = [ "Event" ]; "XrInputSourcesChangeEvent" = [ "Event" ]; - "XrReferenceSpace" = [ "EventTarget" "XrSpace" ]; + "XrReferenceSpace" = [ + "EventTarget" + "XrSpace" + ]; "XrReferenceSpaceEvent" = [ "Event" ]; "XrSession" = [ "EventTarget" ]; "XrSessionEvent" = [ "Event" ]; "XrSpace" = [ "EventTarget" ]; "XrViewerPose" = [ "XrPose" ]; }; - resolvedDefaultFeatures = [ "Crypto" "EventTarget" "Window" ]; + resolvedDefaultFeatures = [ + "Crypto" + "EventTarget" + "Window" + ]; }; "webpki" = rec { crateName = "webpki"; @@ -2662,7 +4106,10 @@ rec { "alloc" = [ "ring/alloc" ]; "std" = [ "alloc" ]; }; - resolvedDefaultFeatures = [ "alloc" "std" ]; + resolvedDefaultFeatures = [ + "alloc" + "std" + ]; }; "winapi" = rec { crateName = "winapi"; @@ -2687,7 +4134,10 @@ rec { features = { "debug" = [ "impl-debug" ]; }; - resolvedDefaultFeatures = [ "ntsecapi" "wtypesbase" ]; + resolvedDefaultFeatures = [ + "ntsecapi" + "wtypesbase" + ]; }; "winapi-i686-pc-windows-gnu" = rec { crateName = "winapi-i686-pc-windows-gnu"; @@ -2747,7 +4197,10 @@ rec { { name = "oid-registry"; packageId = "oid-registry"; - features = [ "crypto" "x509" ]; + features = [ + "crypto" + "x509" + ]; } { name = "ring"; @@ -2772,7 +4225,11 @@ rec { "ring" = [ "dep:ring" ]; "verify" = [ "ring" ]; }; - resolvedDefaultFeatures = [ "default" "ring" "verify" ]; + resolvedDefaultFeatures = [ + "default" + "ring" + "verify" + ]; }; "yasna" = rec { crateName = "yasna"; @@ -2796,7 +4253,11 @@ rec { "num-bigint" = [ "dep:num-bigint" ]; "time" = [ "dep:time" ]; }; - resolvedDefaultFeatures = [ "default" "std" "time" ]; + resolvedDefaultFeatures = [ + "default" + "std" + "time" + ]; }; "zeroize" = rec { crateName = "zeroize"; @@ -2817,7 +4278,11 @@ rec { "default" = [ "alloc" ]; "zeroize_derive" = [ "dep:zeroize_derive" ]; }; - resolvedDefaultFeatures = [ "alloc" "default" "zeroize_derive" ]; + resolvedDefaultFeatures = [ + "alloc" + "default" + "zeroize_derive" + ]; }; "zeroize_derive" = rec { crateName = "zeroize_derive"; @@ -2851,49 +4316,48 @@ rec { }; # -# crate2nix/default.nix (excerpt start) -# - - /* Target (platform) data for conditional dependencies. - This corresponds roughly to what buildRustCrate is setting. - */ - defaultTarget = { - unix = true; - windows = false; - fuchsia = true; - test = false; - - # This doesn't appear to be officially documented anywhere yet. - # See https://github.com/rust-lang-nursery/rust-forge/issues/101. - os = - if stdenv.hostPlatform.isDarwin - then "macos" - else stdenv.hostPlatform.parsed.kernel.name; - arch = stdenv.hostPlatform.parsed.cpu.name; - family = "unix"; - env = "gnu"; - endian = - if stdenv.hostPlatform.parsed.cpu.significantByte.name == "littleEndian" - then "little" else "big"; - pointer_width = toString stdenv.hostPlatform.parsed.cpu.bits; - vendor = stdenv.hostPlatform.parsed.vendor.name; - debug_assertions = false; - }; + # crate2nix/default.nix (excerpt start) + # + + /* + Target (platform) data for conditional dependencies. + This corresponds roughly to what buildRustCrate is setting. + */ + defaultTarget = { + unix = true; + windows = false; + fuchsia = true; + test = false; + + # This doesn't appear to be officially documented anywhere yet. + # See https://github.com/rust-lang-nursery/rust-forge/issues/101. + os = if stdenv.hostPlatform.isDarwin then "macos" else stdenv.hostPlatform.parsed.kernel.name; + arch = stdenv.hostPlatform.parsed.cpu.name; + family = "unix"; + env = "gnu"; + endian = + if stdenv.hostPlatform.parsed.cpu.significantByte.name == "littleEndian" then "little" else "big"; + pointer_width = toString stdenv.hostPlatform.parsed.cpu.bits; + vendor = stdenv.hostPlatform.parsed.vendor.name; + debug_assertions = false; + }; - /* Filters common temp files and build files. */ - # TODO(pkolloch): Substitute with gitignore filter - sourceFilter = name: type: - let - baseName = builtins.baseNameOf (builtins.toString name); - in - ! ( + # Filters common temp files and build files. + # TODO(pkolloch): Substitute with gitignore filter + sourceFilter = + name: type: + let + baseName = builtins.baseNameOf (builtins.toString name); + in + !( # Filter out git baseName == ".gitignore" || (type == "directory" && baseName == ".git") # Filter out build results || ( - type == "directory" && ( + type == "directory" + && ( baseName == "target" || baseName == "_site" || baseName == ".sass-cache" @@ -2903,16 +4367,11 @@ rec { ) # Filter out nix-build result symlinks - || ( - type == "symlink" && lib.hasPrefix "result" baseName - ) + || (type == "symlink" && lib.hasPrefix "result" baseName) # Filter out IDE config - || ( - type == "directory" && ( - baseName == ".idea" || baseName == ".vscode" - ) - ) || lib.hasSuffix ".iml" baseName + || (type == "directory" && (baseName == ".idea" || baseName == ".vscode")) + || lib.hasSuffix ".iml" baseName # Filter out nix build files || baseName == "Cargo.nix" @@ -2926,161 +4385,190 @@ rec { || baseName == "tests.nix" ); - /* Returns a crate which depends on successful test execution - of crate given as the second argument. - - testCrateFlags: list of flags to pass to the test executable - testInputs: list of packages that should be available during test execution - */ - crateWithTest = { crate, testCrate, testCrateFlags, testInputs, testPreRun, testPostRun }: - assert builtins.typeOf testCrateFlags == "list"; - assert builtins.typeOf testInputs == "list"; - assert builtins.typeOf testPreRun == "string"; - assert builtins.typeOf testPostRun == "string"; - let - # override the `crate` so that it will build and execute tests instead of - # building the actual lib and bin targets We just have to pass `--test` - # to rustc and it will do the right thing. We execute the tests and copy - # their log and the test executables to $out for later inspection. - test = - let - drv = testCrate.override - ( - _: { - buildTests = true; - } + /* + Returns a crate which depends on successful test execution + of crate given as the second argument. + + testCrateFlags: list of flags to pass to the test executable + testInputs: list of packages that should be available during test execution + */ + crateWithTest = + { + crate, + testCrate, + testCrateFlags, + testInputs, + testPreRun, + testPostRun, + }: + assert builtins.typeOf testCrateFlags == "list"; + assert builtins.typeOf testInputs == "list"; + assert builtins.typeOf testPreRun == "string"; + assert builtins.typeOf testPostRun == "string"; + let + # override the `crate` so that it will build and execute tests instead of + # building the actual lib and bin targets We just have to pass `--test` + # to rustc and it will do the right thing. We execute the tests and copy + # their log and the test executables to $out for later inspection. + test = + let + drv = testCrate.override (_: { + buildTests = true; + }); + # If the user hasn't set any pre/post commands, we don't want to + # insert empty lines. This means that any existing users of crate2nix + # don't get a spurious rebuild unless they set these explicitly. + testCommand = pkgs.lib.concatStringsSep "\n" ( + pkgs.lib.filter (s: s != "") [ + testPreRun + "$f $testCrateFlags 2>&1 | tee -a $out" + testPostRun + ] ); - # If the user hasn't set any pre/post commands, we don't want to - # insert empty lines. This means that any existing users of crate2nix - # don't get a spurious rebuild unless they set these explicitly. - testCommand = pkgs.lib.concatStringsSep "\n" - (pkgs.lib.filter (s: s != "") [ - testPreRun - "$f $testCrateFlags 2>&1 | tee -a $out" - testPostRun - ]); - in - pkgs.runCommand "run-tests-${testCrate.name}" - { - inherit testCrateFlags; - buildInputs = testInputs; - } '' - set -ex - - export RUST_BACKTRACE=1 - - # recreate a file hierarchy as when running tests with cargo - - # the source for test data - ${pkgs.xorg.lndir}/bin/lndir ${crate.src} - - # build outputs - testRoot=target/debug - mkdir -p $testRoot - - # executables of the crate - # we copy to prevent std::env::current_exe() to resolve to a store location - for i in ${crate}/bin/*; do - cp "$i" "$testRoot" - done - chmod +w -R . - - # test harness executables are suffixed with a hash, like cargo does - # this allows to prevent name collision with the main - # executables of the crate - hash=$(basename $out) - for file in ${drv}/tests/*; do - f=$testRoot/$(basename $file)-$hash - cp $file $f - ${testCommand} - done + in + pkgs.runCommand "run-tests-${testCrate.name}" + { + inherit testCrateFlags; + buildInputs = testInputs; + } + '' + set -ex + + export RUST_BACKTRACE=1 + + # recreate a file hierarchy as when running tests with cargo + + # the source for test data + ${pkgs.xorg.lndir}/bin/lndir ${crate.src} + + # build outputs + testRoot=target/debug + mkdir -p $testRoot + + # executables of the crate + # we copy to prevent std::env::current_exe() to resolve to a store location + for i in ${crate}/bin/*; do + cp "$i" "$testRoot" + done + chmod +w -R . + + # test harness executables are suffixed with a hash, like cargo does + # this allows to prevent name collision with the main + # executables of the crate + hash=$(basename $out) + for file in ${drv}/tests/*; do + f=$testRoot/$(basename $file)-$hash + cp $file $f + ${testCommand} + done + ''; + in + pkgs.runCommand "${crate.name}-linked" + { + inherit (crate) outputs crateName; + passthru = (crate.passthru or { }) // { + inherit test; + }; + } + '' + echo tested by ${test} + ${lib.concatMapStringsSep "\n" (output: "ln -s ${crate.${output}} ${"$"}${output}") crate.outputs} ''; - in - pkgs.runCommand "${crate.name}-linked" + + # A restricted overridable version of builtRustCratesWithFeatures. + buildRustCrateWithFeatures = { - inherit (crate) outputs crateName; - passthru = (crate.passthru or { }) // { - inherit test; - }; - } '' - echo tested by ${test} - ${lib.concatMapStringsSep "\n" (output: "ln -s ${crate.${output}} ${"$"}${output}") crate.outputs} - ''; - - /* A restricted overridable version of builtRustCratesWithFeatures. */ - buildRustCrateWithFeatures = - { packageId - , features ? rootFeatures - , crateOverrides ? defaultCrateOverrides - , buildRustCrateForPkgsFunc ? null - , runTests ? false - , testCrateFlags ? [ ] - , testInputs ? [ ] - # Any command to run immediatelly before a test is executed. - , testPreRun ? "" - # Any command run immediatelly after a test is executed. - , testPostRun ? "" - }: - lib.makeOverridable - ( - { features - , crateOverrides - , runTests - , testCrateFlags - , testInputs - , testPreRun - , testPostRun - }: - let - buildRustCrateForPkgsFuncOverriden = - if buildRustCrateForPkgsFunc != null - then buildRustCrateForPkgsFunc - else - ( - if crateOverrides == pkgs.defaultCrateOverrides - then buildRustCrateForPkgs - else - pkgs: (buildRustCrateForPkgs pkgs).override { - defaultCrateOverrides = crateOverrides; - } - ); - builtRustCrates = builtRustCratesWithFeatures { - inherit packageId features; - buildRustCrateForPkgsFunc = buildRustCrateForPkgsFuncOverriden; - runTests = false; - }; - builtTestRustCrates = builtRustCratesWithFeatures { - inherit packageId features; - buildRustCrateForPkgsFunc = buildRustCrateForPkgsFuncOverriden; - runTests = true; - }; - drv = builtRustCrates.crates.${packageId}; - testDrv = builtTestRustCrates.crates.${packageId}; - derivation = - if runTests then - crateWithTest - { + packageId, + features ? rootFeatures, + crateOverrides ? defaultCrateOverrides, + buildRustCrateForPkgsFunc ? null, + runTests ? false, + testCrateFlags ? [ ], + testInputs ? [ ], + # Any command to run immediatelly before a test is executed. + testPreRun ? "", + # Any command run immediatelly after a test is executed. + testPostRun ? "", + }: + lib.makeOverridable + ( + { + features, + crateOverrides, + runTests, + testCrateFlags, + testInputs, + testPreRun, + testPostRun, + }: + let + buildRustCrateForPkgsFuncOverriden = + if buildRustCrateForPkgsFunc != null then + buildRustCrateForPkgsFunc + else + ( + if crateOverrides == pkgs.defaultCrateOverrides then + buildRustCrateForPkgs + else + pkgs: + (buildRustCrateForPkgs pkgs).override { + defaultCrateOverrides = crateOverrides; + } + ); + builtRustCrates = builtRustCratesWithFeatures { + inherit packageId features; + buildRustCrateForPkgsFunc = buildRustCrateForPkgsFuncOverriden; + runTests = false; + }; + builtTestRustCrates = builtRustCratesWithFeatures { + inherit packageId features; + buildRustCrateForPkgsFunc = buildRustCrateForPkgsFuncOverriden; + runTests = true; + }; + drv = builtRustCrates.crates.${packageId}; + testDrv = builtTestRustCrates.crates.${packageId}; + derivation = + if runTests then + crateWithTest { crate = drv; testCrate = testDrv; - inherit testCrateFlags testInputs testPreRun testPostRun; + inherit + testCrateFlags + testInputs + testPreRun + testPostRun + ; } - else drv; - in - derivation - ) - { inherit features crateOverrides runTests testCrateFlags testInputs testPreRun testPostRun; }; - - /* Returns an attr set with packageId mapped to the result of buildRustCrateForPkgsFunc - for the corresponding crate. - */ - builtRustCratesWithFeatures = - { packageId - , features - , crateConfigs ? crates - , buildRustCrateForPkgsFunc - , runTests - , target ? defaultTarget - } @ args: + else + drv; + in + derivation + ) + { + inherit + features + crateOverrides + runTests + testCrateFlags + testInputs + testPreRun + testPostRun + ; + }; + + /* + Returns an attr set with packageId mapped to the result of buildRustCrateForPkgsFunc + for the corresponding crate. + */ + builtRustCratesWithFeatures = + { + packageId, + features, + crateConfigs ? crates, + buildRustCrateForPkgsFunc, + runTests, + target ? defaultTarget, + }@args: assert (builtins.isAttrs crateConfigs); assert (builtins.isString packageId); assert (builtins.isList features); @@ -3088,65 +4576,66 @@ rec { assert (builtins.isBool runTests); let rootPackageId = packageId; - mergedFeatures = mergePackageFeatures - ( - args // { - inherit rootPackageId; - target = target // { test = runTests; }; - } - ); + mergedFeatures = mergePackageFeatures ( + args + // { + inherit rootPackageId; + target = target // { + test = runTests; + }; + } + ); # Memoize built packages so that reappearing packages are only built once. builtByPackageIdByPkgs = mkBuiltByPackageIdByPkgs pkgs; - mkBuiltByPackageIdByPkgs = pkgs: + mkBuiltByPackageIdByPkgs = + pkgs: let self = { - crates = lib.mapAttrs (packageId: value: buildByPackageIdForPkgsImpl self pkgs packageId) crateConfigs; + crates = lib.mapAttrs ( + packageId: value: buildByPackageIdForPkgsImpl self pkgs packageId + ) crateConfigs; build = mkBuiltByPackageIdByPkgs pkgs.buildPackages; }; in self; - buildByPackageIdForPkgsImpl = self: pkgs: packageId: + buildByPackageIdForPkgsImpl = + self: pkgs: packageId: let features = mergedFeatures."${packageId}" or [ ]; crateConfig' = crateConfigs."${packageId}"; - crateConfig = - builtins.removeAttrs crateConfig' [ "resolvedDefaultFeatures" "devDependencies" ]; - devDependencies = - lib.optionals - (runTests && packageId == rootPackageId) - (crateConfig'.devDependencies or [ ]); - dependencies = - dependencyDerivations { - inherit features target; - buildByPackageId = depPackageId: - # proc_macro crates must be compiled for the build architecture - if crateConfigs.${depPackageId}.procMacro or false - then self.build.crates.${depPackageId} - else self.crates.${depPackageId}; - dependencies = - (crateConfig.dependencies or [ ]) - ++ devDependencies; - }; - buildDependencies = - dependencyDerivations { - inherit features target; - buildByPackageId = depPackageId: - self.build.crates.${depPackageId}; - dependencies = crateConfig.buildDependencies or [ ]; - }; - filterEnabledDependenciesForThis = dependencies: filterEnabledDependencies { - inherit dependencies features target; + crateConfig = builtins.removeAttrs crateConfig' [ + "resolvedDefaultFeatures" + "devDependencies" + ]; + devDependencies = lib.optionals (runTests && packageId == rootPackageId) ( + crateConfig'.devDependencies or [ ] + ); + dependencies = dependencyDerivations { + inherit features target; + buildByPackageId = + depPackageId: + # proc_macro crates must be compiled for the build architecture + if crateConfigs.${depPackageId}.procMacro or false then + self.build.crates.${depPackageId} + else + self.crates.${depPackageId}; + dependencies = (crateConfig.dependencies or [ ]) ++ devDependencies; }; - dependenciesWithRenames = - lib.filter (d: d ? "rename") - ( - filterEnabledDependenciesForThis - ( - (crateConfig.buildDependencies or [ ]) - ++ (crateConfig.dependencies or [ ]) - ++ devDependencies - ) - ); + buildDependencies = dependencyDerivations { + inherit features target; + buildByPackageId = depPackageId: self.build.crates.${depPackageId}; + dependencies = crateConfig.buildDependencies or [ ]; + }; + filterEnabledDependenciesForThis = + dependencies: + filterEnabledDependencies { + inherit dependencies features target; + }; + dependenciesWithRenames = lib.filter (d: d ? "rename") ( + filterEnabledDependenciesForThis ( + (crateConfig.buildDependencies or [ ]) ++ (crateConfig.dependencies or [ ]) ++ devDependencies + ) + ); # Crate renames have the form: # # { @@ -3157,46 +4646,55 @@ rec { # } crateRenames = let - grouped = - lib.groupBy - (dependency: dependency.name) - dependenciesWithRenames; - versionAndRename = dep: + grouped = lib.groupBy (dependency: dependency.name) dependenciesWithRenames; + versionAndRename = + dep: let package = crateConfigs."${dep.packageId}"; in - { inherit (dep) rename; version = package.version; }; + { + inherit (dep) rename; + version = package.version; + }; in lib.mapAttrs (name: choices: builtins.map versionAndRename choices) grouped; in - buildRustCrateForPkgsFunc pkgs - ( - crateConfig // { - src = crateConfig.src or ( - pkgs.fetchurl rec { - name = "${crateConfig.crateName}-${crateConfig.version}.tar.gz"; - # https://www.pietroalbini.org/blog/downloading-crates-io/ - # Not rate-limited, CDN URL. - url = "https://static.crates.io/crates/${crateConfig.crateName}/${crateConfig.crateName}-${crateConfig.version}.crate"; - sha256 = - assert (lib.assertMsg (crateConfig ? sha256) "Missing sha256 for ${name}"); - crateConfig.sha256; - } - ); - extraRustcOpts = lib.lists.optional (targetFeatures != [ ]) "-C target-feature=${lib.concatMapStringsSep "," (x: "+${x}") targetFeatures}"; - inherit features dependencies buildDependencies crateRenames release; - } - ); + buildRustCrateForPkgsFunc pkgs ( + crateConfig + // { + src = + crateConfig.src or (pkgs.fetchurl rec { + name = "${crateConfig.crateName}-${crateConfig.version}.tar.gz"; + # https://www.pietroalbini.org/blog/downloading-crates-io/ + # Not rate-limited, CDN URL. + url = "https://static.crates.io/crates/${crateConfig.crateName}/${crateConfig.crateName}-${crateConfig.version}.crate"; + sha256 = + assert (lib.assertMsg (crateConfig ? sha256) "Missing sha256 for ${name}"); + crateConfig.sha256; + }); + extraRustcOpts = + lib.lists.optional (targetFeatures != [ ]) + "-C target-feature=${lib.concatMapStringsSep "," (x: "+${x}") targetFeatures}"; + inherit + features + dependencies + buildDependencies + crateRenames + release + ; + } + ); in builtByPackageIdByPkgs; - /* Returns the actual derivations for the given dependencies. */ - dependencyDerivations = - { buildByPackageId - , features - , dependencies - , target - }: + # Returns the actual derivations for the given dependencies. + dependencyDerivations = + { + buildByPackageId, + features, + dependencies, + target, + }: assert (builtins.isList features); assert (builtins.isList dependencies); assert (builtins.isAttrs target); @@ -3208,106 +4706,117 @@ rec { in map depDerivation enabledDependencies; - /* Returns a sanitized version of val with all values substituted that cannot - be serialized as JSON. - */ - sanitizeForJson = val: - if builtins.isAttrs val - then lib.mapAttrs (n: v: sanitizeForJson v) val - else if builtins.isList val - then builtins.map sanitizeForJson val - else if builtins.isFunction val - then "function" - else val; - - /* Returns various tools to debug a crate. */ - debugCrate = { packageId, target ? defaultTarget }: - assert (builtins.isString packageId); - let - debug = rec { - # The built tree as passed to buildRustCrate. - buildTree = buildRustCrateWithFeatures { - buildRustCrateForPkgsFunc = _: lib.id; - inherit packageId; - }; - sanitizedBuildTree = sanitizeForJson buildTree; - dependencyTree = sanitizeForJson - ( - buildRustCrateWithFeatures { - buildRustCrateForPkgsFunc = _: crate: { - "01_crateName" = crate.crateName or false; - "02_features" = crate.features or [ ]; - "03_dependencies" = crate.dependencies or [ ]; - }; - inherit packageId; - } - ); - mergedPackageFeatures = mergePackageFeatures { - features = rootFeatures; - inherit packageId target; - }; - diffedDefaultPackageFeatures = diffDefaultPackageFeatures { - inherit packageId target; + /* + Returns a sanitized version of val with all values substituted that cannot + be serialized as JSON. + */ + sanitizeForJson = + val: + if builtins.isAttrs val then + lib.mapAttrs (n: v: sanitizeForJson v) val + else if builtins.isList val then + builtins.map sanitizeForJson val + else if builtins.isFunction val then + "function" + else + val; + + # Returns various tools to debug a crate. + debugCrate = + { + packageId, + target ? defaultTarget, + }: + assert (builtins.isString packageId); + let + debug = rec { + # The built tree as passed to buildRustCrate. + buildTree = buildRustCrateWithFeatures { + buildRustCrateForPkgsFunc = _: lib.id; + inherit packageId; + }; + sanitizedBuildTree = sanitizeForJson buildTree; + dependencyTree = sanitizeForJson (buildRustCrateWithFeatures { + buildRustCrateForPkgsFunc = _: crate: { + "01_crateName" = crate.crateName or false; + "02_features" = crate.features or [ ]; + "03_dependencies" = crate.dependencies or [ ]; + }; + inherit packageId; + }); + mergedPackageFeatures = mergePackageFeatures { + features = rootFeatures; + inherit packageId target; + }; + diffedDefaultPackageFeatures = diffDefaultPackageFeatures { + inherit packageId target; + }; }; + in + { + internal = debug; }; - in - { internal = debug; }; - /* Returns differences between cargo default features and crate2nix default - features. + /* + Returns differences between cargo default features and crate2nix default + features. - This is useful for verifying the feature resolution in crate2nix. - */ - diffDefaultPackageFeatures = - { crateConfigs ? crates - , packageId - , target - }: + This is useful for verifying the feature resolution in crate2nix. + */ + diffDefaultPackageFeatures = + { + crateConfigs ? crates, + packageId, + target, + }: assert (builtins.isAttrs crateConfigs); let prefixValues = prefix: lib.mapAttrs (n: v: { "${prefix}" = v; }); - mergedFeatures = - prefixValues - "crate2nix" - (mergePackageFeatures { inherit crateConfigs packageId target; features = [ "default" ]; }); + mergedFeatures = prefixValues "crate2nix" (mergePackageFeatures { + inherit crateConfigs packageId target; + features = [ "default" ]; + }); configs = prefixValues "cargo" crateConfigs; - combined = lib.foldAttrs (a: b: a // b) { } [ mergedFeatures configs ]; - onlyInCargo = - builtins.attrNames - (lib.filterAttrs (n: v: !(v ? "crate2nix") && (v ? "cargo")) combined); - onlyInCrate2Nix = - builtins.attrNames - (lib.filterAttrs (n: v: (v ? "crate2nix") && !(v ? "cargo")) combined); - differentFeatures = lib.filterAttrs - ( - n: v: - (v ? "crate2nix") - && (v ? "cargo") - && (v.crate2nix.features or [ ]) != (v."cargo".resolved_default_features or [ ]) - ) - combined; + combined = lib.foldAttrs (a: b: a // b) { } [ + mergedFeatures + configs + ]; + onlyInCargo = builtins.attrNames ( + lib.filterAttrs (n: v: !(v ? "crate2nix") && (v ? "cargo")) combined + ); + onlyInCrate2Nix = builtins.attrNames ( + lib.filterAttrs (n: v: (v ? "crate2nix") && !(v ? "cargo")) combined + ); + differentFeatures = lib.filterAttrs ( + n: v: + (v ? "crate2nix") + && (v ? "cargo") + && (v.crate2nix.features or [ ]) != (v."cargo".resolved_default_features or [ ]) + ) combined; in builtins.toJSON { inherit onlyInCargo onlyInCrate2Nix differentFeatures; }; - /* Returns an attrset mapping packageId to the list of enabled features. - - If multiple paths to a dependency enable different features, the - corresponding feature sets are merged. Features in rust are additive. - */ - mergePackageFeatures = - { crateConfigs ? crates - , packageId - , rootPackageId ? packageId - , features ? rootFeatures - , dependencyPath ? [ crates.${packageId}.crateName ] - , featuresByPackageId ? { } - , target - # Adds devDependencies to the crate with rootPackageId. - , runTests ? false - , ... - } @ args: + /* + Returns an attrset mapping packageId to the list of enabled features. + + If multiple paths to a dependency enable different features, the + corresponding feature sets are merged. Features in rust are additive. + */ + mergePackageFeatures = + { + crateConfigs ? crates, + packageId, + rootPackageId ? packageId, + features ? rootFeatures, + dependencyPath ? [ crates.${packageId}.crateName ], + featuresByPackageId ? { }, + target, + # Adds devDependencies to the crate with rootPackageId. + runTests ? false, + ... + }@args: assert (builtins.isAttrs crateConfigs); assert (builtins.isString packageId); assert (builtins.isString rootPackageId); @@ -3320,13 +4829,17 @@ rec { crateConfig = crateConfigs."${packageId}" or (builtins.throw "Package not found: ${packageId}"); expandedFeatures = expandFeatures (crateConfig.features or { }) features; enabledFeatures = enableFeatures (crateConfig.dependencies or [ ]) expandedFeatures; - depWithResolvedFeatures = dependency: + depWithResolvedFeatures = + dependency: let packageId = dependency.packageId; features = dependencyFeatures enabledFeatures dependency; in - { inherit packageId features; }; - resolveDependencies = cache: path: dependencies: + { + inherit packageId features; + }; + resolveDependencies = + cache: path: dependencies: assert (builtins.isAttrs cache); assert (builtins.isList dependencies); let @@ -3337,158 +4850,164 @@ rec { directDependencies = map depWithResolvedFeatures enabledDependencies; foldOverCache = op: lib.foldl op cache directDependencies; in - foldOverCache - ( - cache: { packageId, features }: - let - cacheFeatures = cache.${packageId} or [ ]; - combinedFeatures = sortedUnique (cacheFeatures ++ features); - in - if cache ? ${packageId} && cache.${packageId} == combinedFeatures - then cache - else - mergePackageFeatures { - features = combinedFeatures; - featuresByPackageId = cache; - inherit crateConfigs packageId target runTests rootPackageId; - } - ); + foldOverCache ( + cache: + { packageId, features }: + let + cacheFeatures = cache.${packageId} or [ ]; + combinedFeatures = sortedUnique (cacheFeatures ++ features); + in + if cache ? ${packageId} && cache.${packageId} == combinedFeatures then + cache + else + mergePackageFeatures { + features = combinedFeatures; + featuresByPackageId = cache; + inherit + crateConfigs + packageId + target + runTests + rootPackageId + ; + } + ); cacheWithSelf = let cacheFeatures = featuresByPackageId.${packageId} or [ ]; combinedFeatures = sortedUnique (cacheFeatures ++ enabledFeatures); in - featuresByPackageId // { + featuresByPackageId + // { "${packageId}" = combinedFeatures; }; - cacheWithDependencies = - resolveDependencies cacheWithSelf "dep" - ( - crateConfig.dependencies or [ ] - ++ lib.optionals - (runTests && packageId == rootPackageId) - (crateConfig.devDependencies or [ ]) - ); - cacheWithAll = - resolveDependencies - cacheWithDependencies "build" - (crateConfig.buildDependencies or [ ]); + cacheWithDependencies = resolveDependencies cacheWithSelf "dep" ( + crateConfig.dependencies or [ ] + ++ lib.optionals (runTests && packageId == rootPackageId) (crateConfig.devDependencies or [ ]) + ); + cacheWithAll = resolveDependencies cacheWithDependencies "build" ( + crateConfig.buildDependencies or [ ] + ); in cacheWithAll; - /* Returns the enabled dependencies given the enabled features. */ - filterEnabledDependencies = { dependencies, features, target }: - assert (builtins.isList dependencies); - assert (builtins.isList features); - assert (builtins.isAttrs target); + # Returns the enabled dependencies given the enabled features. + filterEnabledDependencies = + { + dependencies, + features, + target, + }: + assert (builtins.isList dependencies); + assert (builtins.isList features); + assert (builtins.isAttrs target); - lib.filter - ( + lib.filter ( dep: let targetFunc = dep.target or (features: true); in targetFunc { inherit features target; } - && ( - !(dep.optional or false) - || builtins.any (doesFeatureEnableDependency dep) features - ) - ) - dependencies; - - /* Returns whether the given feature should enable the given dependency. */ - doesFeatureEnableDependency = dependency: feature: - let - name = dependency.rename or dependency.name; - prefix = "${name}/"; - len = builtins.stringLength prefix; - startsWithPrefix = builtins.substring 0 len feature == prefix; - in - feature == name || startsWithPrefix; - - /* Returns the expanded features for the given inputFeatures by applying the - rules in featureMap. - - featureMap is an attribute set which maps feature names to lists of further - feature names to enable in case this feature is selected. - */ - expandFeatures = featureMap: inputFeatures: - assert (builtins.isAttrs featureMap); - assert (builtins.isList inputFeatures); - let - expandFeature = feature: - assert (builtins.isString feature); - [ feature ] ++ (expandFeatures featureMap (featureMap."${feature}" or [ ])); - outFeatures = lib.concatMap expandFeature inputFeatures; - in - sortedUnique outFeatures; - - /* This function adds optional dependencies as features if they are enabled - indirectly by dependency features. This function mimics Cargo's behavior - described in a note at: - https://doc.rust-lang.org/nightly/cargo/reference/features.html#dependency-features - */ - enableFeatures = dependencies: features: - assert (builtins.isList features); - assert (builtins.isList dependencies); - let - additionalFeatures = lib.concatMap - ( + && (!(dep.optional or false) || builtins.any (doesFeatureEnableDependency dep) features) + ) dependencies; + + # Returns whether the given feature should enable the given dependency. + doesFeatureEnableDependency = + dependency: feature: + let + name = dependency.rename or dependency.name; + prefix = "${name}/"; + len = builtins.stringLength prefix; + startsWithPrefix = builtins.substring 0 len feature == prefix; + in + feature == name || startsWithPrefix; + + /* + Returns the expanded features for the given inputFeatures by applying the + rules in featureMap. + + featureMap is an attribute set which maps feature names to lists of further + feature names to enable in case this feature is selected. + */ + expandFeatures = + featureMap: inputFeatures: + assert (builtins.isAttrs featureMap); + assert (builtins.isList inputFeatures); + let + expandFeature = + feature: + assert (builtins.isString feature); + [ feature ] ++ (expandFeatures featureMap (featureMap."${feature}" or [ ])); + outFeatures = lib.concatMap expandFeature inputFeatures; + in + sortedUnique outFeatures; + + /* + This function adds optional dependencies as features if they are enabled + indirectly by dependency features. This function mimics Cargo's behavior + described in a note at: + https://doc.rust-lang.org/nightly/cargo/reference/features.html#dependency-features + */ + enableFeatures = + dependencies: features: + assert (builtins.isList features); + assert (builtins.isList dependencies); + let + additionalFeatures = lib.concatMap ( dependency: - assert (builtins.isAttrs dependency); - let - enabled = builtins.any (doesFeatureEnableDependency dependency) features; - in - if (dependency.optional or false) && enabled - then [ (dependency.rename or dependency.name) ] - else [ ] - ) - dependencies; - in - sortedUnique (features ++ additionalFeatures); - - /* - Returns the actual features for the given dependency. - - features: The features of the crate that refers this dependency. - */ - dependencyFeatures = features: dependency: - assert (builtins.isList features); - assert (builtins.isAttrs dependency); - let - defaultOrNil = - if dependency.usesDefaultFeatures or true - then [ "default" ] - else [ ]; - explicitFeatures = dependency.features or [ ]; - additionalDependencyFeatures = - let - dependencyPrefix = (dependency.rename or dependency.name) + "/"; - dependencyFeatures = - builtins.filter (f: lib.hasPrefix dependencyPrefix f) features; - in - builtins.map (lib.removePrefix dependencyPrefix) dependencyFeatures; - in - defaultOrNil ++ explicitFeatures ++ additionalDependencyFeatures; - - /* Sorts and removes duplicates from a list of strings. */ - sortedUnique = features: - assert (builtins.isList features); - assert (builtins.all builtins.isString features); - let - outFeaturesSet = lib.foldl (set: feature: set // { "${feature}" = 1; }) { } features; - outFeaturesUnique = builtins.attrNames outFeaturesSet; - in - builtins.sort (a: b: a < b) outFeaturesUnique; - - deprecationWarning = message: value: - if strictDeprecation - then builtins.throw "strictDeprecation enabled, aborting: ${message}" - else builtins.trace message value; + assert (builtins.isAttrs dependency); + let + enabled = builtins.any (doesFeatureEnableDependency dependency) features; + in + if (dependency.optional or false) && enabled then + [ (dependency.rename or dependency.name) ] + else + [ ] + ) dependencies; + in + sortedUnique (features ++ additionalFeatures); - # - # crate2nix/default.nix (excerpt end) - # + /* + Returns the actual features for the given dependency. + + features: The features of the crate that refers this dependency. + */ + dependencyFeatures = + features: dependency: + assert (builtins.isList features); + assert (builtins.isAttrs dependency); + let + defaultOrNil = if dependency.usesDefaultFeatures or true then [ "default" ] else [ ]; + explicitFeatures = dependency.features or [ ]; + additionalDependencyFeatures = + let + dependencyPrefix = (dependency.rename or dependency.name) + "/"; + dependencyFeatures = builtins.filter (f: lib.hasPrefix dependencyPrefix f) features; + in + builtins.map (lib.removePrefix dependencyPrefix) dependencyFeatures; + in + defaultOrNil ++ explicitFeatures ++ additionalDependencyFeatures; + + # Sorts and removes duplicates from a list of strings. + sortedUnique = + features: + assert (builtins.isList features); + assert (builtins.all builtins.isString features); + let + outFeaturesSet = lib.foldl (set: feature: set // { "${feature}" = 1; }) { } features; + outFeaturesUnique = builtins.attrNames outFeaturesSet; + in + builtins.sort (a: b: a < b) outFeaturesUnique; + + deprecationWarning = + message: value: + if strictDeprecation then + builtins.throw "strictDeprecation enabled, aborting: ${message}" + else + builtins.trace message value; + + # + # crate2nix/default.nix (excerpt end) + # }; } - diff --git a/pkgs/build-support/rust/build-rust-package/default.nix b/pkgs/build-support/rust/build-rust-package/default.nix index 51e9caac1ac38d..0060cb18bf76db 100644 --- a/pkgs/build-support/rust/build-rust-package/default.nix +++ b/pkgs/build-support/rust/build-rust-package/default.nix @@ -1,92 +1,127 @@ -{ lib -, importCargoLock -, fetchCargoTarball -, fetchCargoVendor -, stdenv -, callPackage -, cargoBuildHook -, cargoCheckHook -, cargoInstallHook -, cargoNextestHook -, cargoSetupHook -, cargo -, cargo-auditable -, buildPackages -, rustc -, libiconv -, windows +{ + lib, + importCargoLock, + fetchCargoTarball, + fetchCargoVendor, + stdenv, + callPackage, + cargoBuildHook, + cargoCheckHook, + cargoInstallHook, + cargoNextestHook, + cargoSetupHook, + cargo, + cargo-auditable, + buildPackages, + rustc, + libiconv, + windows, }: -{ name ? "${args.pname}-${args.version}" +{ + name ? "${args.pname}-${args.version}", # Name for the vendored dependencies tarball -, cargoDepsName ? name - -, src ? null -, srcs ? null -, preUnpack ? null -, unpackPhase ? null -, postUnpack ? null -, cargoPatches ? [] -, patches ? [] -, sourceRoot ? null -, cargoRoot ? null -, logLevel ? "" -, buildInputs ? [] -, nativeBuildInputs ? [] -, cargoUpdateHook ? "" -, cargoDepsHook ? "" -, buildType ? "release" -, meta ? {} -, useFetchCargoVendor ? false -, cargoDeps ? null -, cargoLock ? null -, cargoVendorDir ? null -, checkType ? buildType -, buildNoDefaultFeatures ? false -, checkNoDefaultFeatures ? buildNoDefaultFeatures -, buildFeatures ? [ ] -, checkFeatures ? buildFeatures -, useNextest ? false -, auditable ? !cargo-auditable.meta.broken - -, depsExtraArgs ? {} - -# Toggles whether a custom sysroot is created when the target is a .json file. -, __internal_dontAddSysroot ? false - -# Needed to `pushd`/`popd` into a subdir of a tarball if this subdir -# contains a Cargo.toml, but isn't part of a workspace (which is e.g. the -# case for `rustfmt`/etc from the `rust-sources). -# Otherwise, everything from the tarball would've been built/tested. -, buildAndTestSubdir ? null -, ... } @ args: - -assert cargoVendorDir == null && cargoDeps == null && cargoLock == null - -> !(args ? cargoSha256 && args.cargoSha256 != null) && !(args ? cargoHash && args.cargoHash != null) - -> throw "cargoHash, cargoVendorDir, cargoDeps, or cargoLock must be set"; + cargoDepsName ? name, + + src ? null, + srcs ? null, + preUnpack ? null, + unpackPhase ? null, + postUnpack ? null, + cargoPatches ? [ ], + patches ? [ ], + sourceRoot ? null, + cargoRoot ? null, + logLevel ? "", + buildInputs ? [ ], + nativeBuildInputs ? [ ], + cargoUpdateHook ? "", + cargoDepsHook ? "", + buildType ? "release", + meta ? { }, + useFetchCargoVendor ? false, + cargoDeps ? null, + cargoLock ? null, + cargoVendorDir ? null, + checkType ? buildType, + buildNoDefaultFeatures ? false, + checkNoDefaultFeatures ? buildNoDefaultFeatures, + buildFeatures ? [ ], + checkFeatures ? buildFeatures, + useNextest ? false, + auditable ? !cargo-auditable.meta.broken, + + depsExtraArgs ? { }, + + # Toggles whether a custom sysroot is created when the target is a .json file. + __internal_dontAddSysroot ? false, + + # Needed to `pushd`/`popd` into a subdir of a tarball if this subdir + # contains a Cargo.toml, but isn't part of a workspace (which is e.g. the + # case for `rustfmt`/etc from the `rust-sources). + # Otherwise, everything from the tarball would've been built/tested. + buildAndTestSubdir ? null, + ... +}@args: + +assert + cargoVendorDir == null && cargoDeps == null && cargoLock == null + -> + !(args ? cargoSha256 && args.cargoSha256 != null) && !(args ? cargoHash && args.cargoHash != null) + -> throw "cargoHash, cargoVendorDir, cargoDeps, or cargoLock must be set"; let cargoDeps' = - if cargoVendorDir != null then null - else if cargoDeps != null then cargoDeps - else if cargoLock != null then importCargoLock cargoLock - else if useFetchCargoVendor then fetchCargoVendor ({ - inherit src srcs sourceRoot cargoRoot preUnpack unpackPhase postUnpack; - name = cargoDepsName; - patches = cargoPatches; - hash = args.cargoHash; - } // depsExtraArgs) - else fetchCargoTarball ({ - inherit src srcs sourceRoot cargoRoot preUnpack unpackPhase postUnpack cargoUpdateHook; - name = cargoDepsName; - patches = cargoPatches; - } // lib.optionalAttrs (args ? cargoHash) { - hash = args.cargoHash; - } // lib.optionalAttrs (args ? cargoSha256) { - sha256 = lib.warn "cargoSha256 is deprecated. Please use cargoHash with SRI hash instead" args.cargoSha256; - } // depsExtraArgs); + if cargoVendorDir != null then + null + else if cargoDeps != null then + cargoDeps + else if cargoLock != null then + importCargoLock cargoLock + else if useFetchCargoVendor then + fetchCargoVendor ( + { + inherit + src + srcs + sourceRoot + cargoRoot + preUnpack + unpackPhase + postUnpack + ; + name = cargoDepsName; + patches = cargoPatches; + hash = args.cargoHash; + } + // depsExtraArgs + ) + else + fetchCargoTarball ( + { + inherit + src + srcs + sourceRoot + cargoRoot + preUnpack + unpackPhase + postUnpack + cargoUpdateHook + ; + name = cargoDepsName; + patches = cargoPatches; + } + // lib.optionalAttrs (args ? cargoHash) { + hash = args.cargoHash; + } + // lib.optionalAttrs (args ? cargoSha256) { + sha256 = lib.warn "cargoSha256 is deprecated. Please use cargoHash with SRI hash instead" args.cargoSha256; + } + // depsExtraArgs + ); target = stdenv.hostPlatform.rust.rustcTargetSpec; targetIsJSON = lib.hasSuffix ".json" target; @@ -105,72 +140,86 @@ in # See https://os.phil-opp.com/testing/ for more information. assert useSysroot -> !(args.doCheck or true); -stdenv.mkDerivation ((removeAttrs args [ "depsExtraArgs" "cargoUpdateHook" "cargoDeps" "cargoLock" ]) // lib.optionalAttrs useSysroot { - RUSTFLAGS = "--sysroot ${sysroot} " + (args.RUSTFLAGS or ""); -} // lib.optionalAttrs (stdenv.hostPlatform.isDarwin && buildType == "debug") { - RUSTFLAGS = - "-C split-debuginfo=packed " - + lib.optionalString useSysroot "--sysroot ${sysroot} " - + (args.RUSTFLAGS or ""); -} // { - cargoDeps = cargoDeps'; - inherit buildAndTestSubdir; - - cargoBuildType = buildType; - - cargoCheckType = checkType; - - cargoBuildNoDefaultFeatures = buildNoDefaultFeatures; - - cargoCheckNoDefaultFeatures = checkNoDefaultFeatures; - - cargoBuildFeatures = buildFeatures; - - cargoCheckFeatures = checkFeatures; - - patchRegistryDeps = ./patch-registry-deps; - - nativeBuildInputs = nativeBuildInputs ++ lib.optionals auditable [ - (buildPackages.cargo-auditable-cargo-wrapper.override { - inherit cargo cargo-auditable; - }) - ] ++ [ - cargoBuildHook - (if useNextest then cargoNextestHook else cargoCheckHook) - cargoInstallHook - cargoSetupHook - rustc - ]; - - buildInputs = buildInputs - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ] - ++ lib.optionals stdenv.hostPlatform.isMinGW [ windows.pthreads ]; - - patches = cargoPatches ++ patches; - - PKG_CONFIG_ALLOW_CROSS = - if stdenv.buildPlatform != stdenv.hostPlatform then 1 else 0; - - postUnpack = '' - eval "$cargoDepsHook" - - export RUST_LOG=${logLevel} - '' + (args.postUnpack or ""); - - configurePhase = args.configurePhase or '' - runHook preConfigure - runHook postConfigure - ''; - - doCheck = args.doCheck or true; - - strictDeps = true; - - meta = meta // { - badPlatforms = meta.badPlatforms or [] ++ rustc.badTargetPlatforms; - # default to Rust's platforms - platforms = lib.intersectLists - meta.platforms or lib.platforms.all - rustc.targetPlatforms; - }; -}) +stdenv.mkDerivation ( + (removeAttrs args [ + "depsExtraArgs" + "cargoUpdateHook" + "cargoDeps" + "cargoLock" + ]) + // lib.optionalAttrs useSysroot { + RUSTFLAGS = "--sysroot ${sysroot} " + (args.RUSTFLAGS or ""); + } + // lib.optionalAttrs (stdenv.hostPlatform.isDarwin && buildType == "debug") { + RUSTFLAGS = + "-C split-debuginfo=packed " + + lib.optionalString useSysroot "--sysroot ${sysroot} " + + (args.RUSTFLAGS or ""); + } + // { + cargoDeps = cargoDeps'; + inherit buildAndTestSubdir; + + cargoBuildType = buildType; + + cargoCheckType = checkType; + + cargoBuildNoDefaultFeatures = buildNoDefaultFeatures; + + cargoCheckNoDefaultFeatures = checkNoDefaultFeatures; + + cargoBuildFeatures = buildFeatures; + + cargoCheckFeatures = checkFeatures; + + patchRegistryDeps = ./patch-registry-deps; + + nativeBuildInputs = + nativeBuildInputs + ++ lib.optionals auditable [ + (buildPackages.cargo-auditable-cargo-wrapper.override { + inherit cargo cargo-auditable; + }) + ] + ++ [ + cargoBuildHook + (if useNextest then cargoNextestHook else cargoCheckHook) + cargoInstallHook + cargoSetupHook + rustc + ]; + + buildInputs = + buildInputs + ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ] + ++ lib.optionals stdenv.hostPlatform.isMinGW [ windows.pthreads ]; + + patches = cargoPatches ++ patches; + + PKG_CONFIG_ALLOW_CROSS = if stdenv.buildPlatform != stdenv.hostPlatform then 1 else 0; + + postUnpack = + '' + eval "$cargoDepsHook" + + export RUST_LOG=${logLevel} + '' + + (args.postUnpack or ""); + + configurePhase = + args.configurePhase or '' + runHook preConfigure + runHook postConfigure + ''; + + doCheck = args.doCheck or true; + + strictDeps = true; + + meta = meta // { + badPlatforms = meta.badPlatforms or [ ] ++ rustc.badTargetPlatforms; + # default to Rust's platforms + platforms = lib.intersectLists meta.platforms or lib.platforms.all rustc.targetPlatforms; + }; + } +) diff --git a/pkgs/build-support/rust/build-rust-package/sysroot/default.nix b/pkgs/build-support/rust/build-rust-package/sysroot/default.nix index 240866b56e0cfd..d9d071df06cccf 100644 --- a/pkgs/build-support/rust/build-rust-package/sysroot/default.nix +++ b/pkgs/build-support/rust/build-rust-package/sysroot/default.nix @@ -1,16 +1,33 @@ -{ lib, stdenv, rustPlatform, buildPackages }: - -{ shortTarget, originalCargoToml, target, RUSTFLAGS }: +{ + lib, + stdenv, + rustPlatform, + buildPackages, +}: + +{ + shortTarget, + originalCargoToml, + target, + RUSTFLAGS, +}: let cargoSrc = import ../../sysroot/src.nix { - inherit lib stdenv rustPlatform buildPackages originalCargoToml; + inherit + lib + stdenv + rustPlatform + buildPackages + originalCargoToml + ; }; -in rustPlatform.buildRustPackage { +in +rustPlatform.buildRustPackage { inherit target RUSTFLAGS; name = "custom-sysroot"; - src = cargoSrc; + src = cargoSrc; RUSTC_BOOTSTRAP = 1; __internal_dontAddSysroot = true; diff --git a/pkgs/build-support/rust/fetchcrate.nix b/pkgs/build-support/rust/fetchcrate.nix index 423f4d786fde13..63a62950025348 100644 --- a/pkgs/build-support/rust/fetchcrate.nix +++ b/pkgs/build-support/rust/fetchcrate.nix @@ -1,20 +1,35 @@ -{ lib, fetchzip, fetchurl }: +{ + lib, + fetchzip, + fetchurl, +}: -{ crateName ? args.pname -, pname ? null +{ + crateName ? args.pname, + pname ? null, # The `dl` field of the registry's index configuration # https://doc.rust-lang.org/cargo/reference/registry-index.html#index-configuration -, registryDl ? "https://crates.io/api/v1/crates" -, version -, unpack ? true -, ... -} @ args: + registryDl ? "https://crates.io/api/v1/crates", + version, + unpack ? true, + ... +}@args: assert pname == null || pname == crateName; -(if unpack then fetchzip else fetchurl) ({ - name = "${crateName}-${version}.tar.gz"; - url = "${registryDl}/${crateName}/${version}/download"; -} // lib.optionalAttrs unpack { - extension = "tar.gz"; -} // removeAttrs args [ "crateName" "pname" "registryDl" "version" "unpack" ]) +(if unpack then fetchzip else fetchurl) ( + { + name = "${crateName}-${version}.tar.gz"; + url = "${registryDl}/${crateName}/${version}/download"; + } + // lib.optionalAttrs unpack { + extension = "tar.gz"; + } + // removeAttrs args [ + "crateName" + "pname" + "registryDl" + "version" + "unpack" + ] +) diff --git a/pkgs/build-support/rust/rustc-wrapper/default.nix b/pkgs/build-support/rust/rustc-wrapper/default.nix index 0b16740ae5bbf5..0ba21482053d53 100644 --- a/pkgs/build-support/rust/rustc-wrapper/default.nix +++ b/pkgs/build-support/rust/rustc-wrapper/default.nix @@ -1,54 +1,69 @@ -{ lib, runCommand, rustc-unwrapped, sysroot ? null }: +{ + lib, + runCommand, + rustc-unwrapped, + sysroot ? null, +}: -runCommand "${rustc-unwrapped.pname}-wrapper-${rustc-unwrapped.version}" { - preferLocalBuild = true; - strictDeps = true; - inherit (rustc-unwrapped) outputs; +runCommand "${rustc-unwrapped.pname}-wrapper-${rustc-unwrapped.version}" + { + preferLocalBuild = true; + strictDeps = true; + inherit (rustc-unwrapped) outputs; - env = { - sysroot = lib.optionalString (sysroot != null) "--sysroot ${sysroot}"; + env = { + sysroot = lib.optionalString (sysroot != null) "--sysroot ${sysroot}"; - # Upstream rustc still assumes that musl = static[1]. The fix for - # this is to disable crt-static by default for non-static musl - # targets. - # - # Even though Cargo will build build.rs files for the build platform, - # cross-compiling _from_ musl appears to work fine, so we only need - # to do this when rustc's target platform is dynamically linked musl. - # - # [1]: https://github.com/rust-lang/compiler-team/issues/422 - # - # WARNING: using defaultArgs is dangerous, as it will apply to all - # targets used by this compiler (host and target). This means - # that it can't be used to set arguments that should only be - # applied to the target. It's fine to do this for -crt-static, - # because rustc does not support +crt-static host platforms - # anyway. - defaultArgs = lib.optionalString - (with rustc-unwrapped.stdenv.targetPlatform; isMusl && !isStatic) - "-C target-feature=-crt-static"; - }; + # Upstream rustc still assumes that musl = static[1]. The fix for + # this is to disable crt-static by default for non-static musl + # targets. + # + # Even though Cargo will build build.rs files for the build platform, + # cross-compiling _from_ musl appears to work fine, so we only need + # to do this when rustc's target platform is dynamically linked musl. + # + # [1]: https://github.com/rust-lang/compiler-team/issues/422 + # + # WARNING: using defaultArgs is dangerous, as it will apply to all + # targets used by this compiler (host and target). This means + # that it can't be used to set arguments that should only be + # applied to the target. It's fine to do this for -crt-static, + # because rustc does not support +crt-static host platforms + # anyway. + defaultArgs = lib.optionalString ( + with rustc-unwrapped.stdenv.targetPlatform; isMusl && !isStatic + ) "-C target-feature=-crt-static"; + }; - passthru = { - inherit (rustc-unwrapped) - pname version src llvm llvmPackages - tier1TargetPlatforms targetPlatforms badTargetPlatforms; - unwrapped = rustc-unwrapped; - }; + passthru = { + inherit (rustc-unwrapped) + pname + version + src + llvm + llvmPackages + tier1TargetPlatforms + targetPlatforms + badTargetPlatforms + ; + unwrapped = rustc-unwrapped; + }; - meta = rustc-unwrapped.meta // { - description = "${rustc-unwrapped.meta.description} (wrapper script)"; - priority = 10; - }; -} '' - mkdir -p $out/bin - ln -s ${rustc-unwrapped}/bin/* $out/bin - rm $out/bin/{rustc,rustdoc} - prog=${rustc-unwrapped}/bin/rustc extraFlagsVar=NIX_RUSTFLAGS \ - substituteAll ${./rustc-wrapper.sh} $out/bin/rustc - prog=${rustc-unwrapped}/bin/rustdoc extraFlagsVar=NIX_RUSTDOCFLAGS \ - substituteAll ${./rustc-wrapper.sh} $out/bin/rustdoc - chmod +x $out/bin/{rustc,rustdoc} - ${lib.concatMapStrings (output: "ln -s ${rustc-unwrapped.${output}} \$${output}\n") - (lib.remove "out" rustc-unwrapped.outputs)} -'' + meta = rustc-unwrapped.meta // { + description = "${rustc-unwrapped.meta.description} (wrapper script)"; + priority = 10; + }; + } + '' + mkdir -p $out/bin + ln -s ${rustc-unwrapped}/bin/* $out/bin + rm $out/bin/{rustc,rustdoc} + prog=${rustc-unwrapped}/bin/rustc extraFlagsVar=NIX_RUSTFLAGS \ + substituteAll ${./rustc-wrapper.sh} $out/bin/rustc + prog=${rustc-unwrapped}/bin/rustdoc extraFlagsVar=NIX_RUSTDOCFLAGS \ + substituteAll ${./rustc-wrapper.sh} $out/bin/rustdoc + chmod +x $out/bin/{rustc,rustdoc} + ${lib.concatMapStrings (output: "ln -s ${rustc-unwrapped.${output}} \$${output}\n") ( + lib.remove "out" rustc-unwrapped.outputs + )} + '' diff --git a/pkgs/build-support/rust/sysroot/src.nix b/pkgs/build-support/rust/sysroot/src.nix index 664702e82c31be..d41cbf55fcdcff 100644 --- a/pkgs/build-support/rust/sysroot/src.nix +++ b/pkgs/build-support/rust/sysroot/src.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, rustPlatform, buildPackages -, originalCargoToml ? null +{ + lib, + stdenv, + rustPlatform, + buildPackages, + originalCargoToml ? null, }: stdenv.mkDerivation { @@ -10,17 +14,18 @@ stdenv.mkDerivation { dontConfigure = true; dontBuild = true; - installPhase = '' - export RUSTC_SRC=${rustPlatform.rustLibSrc.override { }} - '' - + lib.optionalString (originalCargoToml != null) '' - export ORIG_CARGO=${originalCargoToml} - '' - + '' - ${buildPackages.python3.withPackages (ps: with ps; [ toml ])}/bin/python3 ${./cargo.py} - mkdir -p $out/src - echo '#![no_std]' > $out/src/lib.rs - cp Cargo.toml $out/Cargo.toml - cp ${./Cargo.lock} $out/Cargo.lock - ''; + installPhase = + '' + export RUSTC_SRC=${rustPlatform.rustLibSrc.override { }} + '' + + lib.optionalString (originalCargoToml != null) '' + export ORIG_CARGO=${originalCargoToml} + '' + + '' + ${buildPackages.python3.withPackages (ps: with ps; [ toml ])}/bin/python3 ${./cargo.py} + mkdir -p $out/src + echo '#![no_std]' > $out/src/lib.rs + cp Cargo.toml $out/Cargo.toml + cp ${./Cargo.lock} $out/Cargo.lock + ''; } diff --git a/pkgs/build-support/rust/test/import-cargo-lock/basic-sparse/default.nix b/pkgs/build-support/rust/test/import-cargo-lock/basic-sparse/default.nix index 7a87a69e5dacef..203badd8675547 100644 --- a/pkgs/build-support/rust/test/import-cargo-lock/basic-sparse/default.nix +++ b/pkgs/build-support/rust/test/import-cargo-lock/basic-sparse/default.nix @@ -19,7 +19,7 @@ rustPlatform.buildRustPackage { cargoLock = { lockFile = ./Cargo.lock; extraRegistries = { - "sparse+https://index.crates.io/" = "https://static.crates.io/crates"; + "sparse+https://index.crates.io/" = "https://static.crates.io/crates"; }; }; diff --git a/pkgs/build-support/rust/test/import-cargo-lock/git-dependency-rev-non-workspace-nested-crate/default.nix b/pkgs/build-support/rust/test/import-cargo-lock/git-dependency-rev-non-workspace-nested-crate/default.nix index b616b293fa3971..5b1dcc1aef6164 100644 --- a/pkgs/build-support/rust/test/import-cargo-lock/git-dependency-rev-non-workspace-nested-crate/default.nix +++ b/pkgs/build-support/rust/test/import-cargo-lock/git-dependency-rev-non-workspace-nested-crate/default.nix @@ -1,4 +1,11 @@ -{ rustPlatform, pkg-config, openssl, lib, darwin, stdenv }: +{ + rustPlatform, + pkg-config, + openssl, + lib, + darwin, + stdenv, +}: let fs = lib.fileset; in @@ -19,11 +26,13 @@ rustPlatform.buildRustPackage { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; cargoLock = { lockFile = ./Cargo.lock; diff --git a/pkgs/build-support/setup-hooks/patch-rc-path-hooks/default.nix b/pkgs/build-support/setup-hooks/patch-rc-path-hooks/default.nix index f16644528f002d..e07cc15cacd092 100644 --- a/pkgs/build-support/setup-hooks/patch-rc-path-hooks/default.nix +++ b/pkgs/build-support/setup-hooks/patch-rc-path-hooks/default.nix @@ -1,60 +1,57 @@ -{ lib -, callPackage -, makeSetupHook -, gnused +{ + lib, + callPackage, + makeSetupHook, + gnused, }: let tests = import ./test { inherit callPackage; }; in { - patchRcPathBash = makeSetupHook - { - name = "patch-rc-path-bash"; - meta = with lib; { - description = "Setup-hook to inject source-time PATH prefix to a Bash/Ksh/Zsh script"; - maintainers = with maintainers; [ ShamrockLee ]; - }; - passthru.tests = { - inherit (tests) test-bash; - }; - } ./patch-rc-path-bash.sh; - patchRcPathCsh = makeSetupHook - { - name = "patch-rc-path-csh"; - substitutions = { - sed = "${gnused}/bin/sed"; - }; - meta = with lib; { - description = "Setup-hook to inject source-time PATH prefix to a Csh script"; - maintainers = with maintainers; [ ShamrockLee ]; - }; - passthru.tests = { - inherit (tests) test-csh; - }; - } ./patch-rc-path-csh.sh; - patchRcPathFish = makeSetupHook - { - name = "patch-rc-path-fish"; - meta = with lib; { - description = "Setup-hook to inject source-time PATH prefix to a Fish script"; - maintainers = with maintainers; [ ShamrockLee ]; - }; - passthru.tests = { - inherit (tests) test-fish; - }; - } ./patch-rc-path-fish.sh; - patchRcPathPosix = makeSetupHook - { - name = "patch-rc-path-posix"; - substitutions = { - sed = "${gnused}/bin/sed"; - }; - meta = with lib; { - description = "Setup-hook to inject source-time PATH prefix to a POSIX shell script"; - maintainers = with maintainers; [ ShamrockLee ]; - }; - passthru.tests = { - inherit (tests) test-posix; - }; - } ./patch-rc-path-posix.sh; + patchRcPathBash = makeSetupHook { + name = "patch-rc-path-bash"; + meta = with lib; { + description = "Setup-hook to inject source-time PATH prefix to a Bash/Ksh/Zsh script"; + maintainers = with maintainers; [ ShamrockLee ]; + }; + passthru.tests = { + inherit (tests) test-bash; + }; + } ./patch-rc-path-bash.sh; + patchRcPathCsh = makeSetupHook { + name = "patch-rc-path-csh"; + substitutions = { + sed = "${gnused}/bin/sed"; + }; + meta = with lib; { + description = "Setup-hook to inject source-time PATH prefix to a Csh script"; + maintainers = with maintainers; [ ShamrockLee ]; + }; + passthru.tests = { + inherit (tests) test-csh; + }; + } ./patch-rc-path-csh.sh; + patchRcPathFish = makeSetupHook { + name = "patch-rc-path-fish"; + meta = with lib; { + description = "Setup-hook to inject source-time PATH prefix to a Fish script"; + maintainers = with maintainers; [ ShamrockLee ]; + }; + passthru.tests = { + inherit (tests) test-fish; + }; + } ./patch-rc-path-fish.sh; + patchRcPathPosix = makeSetupHook { + name = "patch-rc-path-posix"; + substitutions = { + sed = "${gnused}/bin/sed"; + }; + meta = with lib; { + description = "Setup-hook to inject source-time PATH prefix to a POSIX shell script"; + maintainers = with maintainers; [ ShamrockLee ]; + }; + passthru.tests = { + inherit (tests) test-posix; + }; + } ./patch-rc-path-posix.sh; } diff --git a/pkgs/build-support/setup-hooks/patch-rc-path-hooks/test/default.nix b/pkgs/build-support/setup-hooks/patch-rc-path-hooks/test/default.nix index 82bc160387ee5b..8479e2c9bbcbf9 100644 --- a/pkgs/build-support/setup-hooks/patch-rc-path-hooks/test/default.nix +++ b/pkgs/build-support/setup-hooks/patch-rc-path-hooks/test/default.nix @@ -1,442 +1,432 @@ { callPackage }: { - test-bash = callPackage - ( - { lib - , runCommandLocal - , bash - , hello - , ksh - , patchRcPathBash - , shellcheck - , zsh - }: - runCommandLocal "patch-rc-path-bash-test" - { - nativeBuildInputs = [ - bash - ksh - patchRcPathBash - shellcheck - zsh - ]; - meta = { - description = "Package test of patchActivateBash"; - inherit (patchRcPathBash.meta) maintainers; - }; - } - '' - set -eu -o pipefail + test-bash = callPackage ( + { + lib, + runCommandLocal, + bash, + hello, + ksh, + patchRcPathBash, + shellcheck, + zsh, + }: + runCommandLocal "patch-rc-path-bash-test" + { + nativeBuildInputs = [ + bash + ksh + patchRcPathBash + shellcheck + zsh + ]; + meta = { + description = "Package test of patchActivateBash"; + inherit (patchRcPathBash.meta) maintainers; + }; + } + '' + set -eu -o pipefail - # Check the setup hook script + # Check the setup hook script - echo "Running shellcheck against ${./test-sourcing-bash}" - shellcheck -s bash --exclude SC1090 ${./test-sourcing-bash} - shellcheck -s ksh --exclude SC1090 ${./test-sourcing-bash} + echo "Running shellcheck against ${./test-sourcing-bash}" + shellcheck -s bash --exclude SC1090 ${./test-sourcing-bash} + shellcheck -s ksh --exclude SC1090 ${./test-sourcing-bash} - # Test patching a blank file + # Test patching a blank file - echo > blank.bash + echo > blank.bash - echo "Generating blank_patched.bash from blank.bash" - cp blank.bash blank_patched.bash - patchRcPathBash blank_patched.bash "$PWD/delta:$PWD/foxtrot" + echo "Generating blank_patched.bash from blank.bash" + cp blank.bash blank_patched.bash + patchRcPathBash blank_patched.bash "$PWD/delta:$PWD/foxtrot" - echo "Running shellcheck against blank_patched.bash" - shellcheck -s bash blank_patched.bash - shellcheck -s ksh blank_patched.bash + echo "Running shellcheck against blank_patched.bash" + shellcheck -s bash blank_patched.bash + shellcheck -s ksh blank_patched.bash - echo "Testing in Bash if blank.bash and blank_patched.bash modifies PATH the same way" - bash ${./test-sourcing-bash} ./blank.bash ./blank_patched.bash + echo "Testing in Bash if blank.bash and blank_patched.bash modifies PATH the same way" + bash ${./test-sourcing-bash} ./blank.bash ./blank_patched.bash - echo "Testing in Ksh if blank.bash and blank_patched.bash modifies PATH the same way" - ksh ${./test-sourcing-bash} "$PWD/blank.bash" "$PWD/blank_patched.bash" + echo "Testing in Ksh if blank.bash and blank_patched.bash modifies PATH the same way" + ksh ${./test-sourcing-bash} "$PWD/blank.bash" "$PWD/blank_patched.bash" - echo "Testing in Zsh if blank.bash and blank_patched.bash modifies PATH the same way" - zsh ${./test-sourcing-bash} ./blank.bash ./blank_patched.bash + echo "Testing in Zsh if blank.bash and blank_patched.bash modifies PATH the same way" + zsh ${./test-sourcing-bash} ./blank.bash ./blank_patched.bash - # Test patching silent_hello + # Test patching silent_hello - echo "hello > /dev/null" > silent_hello.bash + echo "hello > /dev/null" > silent_hello.bash - echo "Generating silent_hello_patched.bash from silent_hello.bash" - cp silent_hello.bash silent_hello_patched.bash - patchRcPathBash silent_hello_patched.bash "${hello}/bin" + echo "Generating silent_hello_patched.bash from silent_hello.bash" + cp silent_hello.bash silent_hello_patched.bash + patchRcPathBash silent_hello_patched.bash "${hello}/bin" - echo "Running shellcheck against silent_hello_patched.bash" - shellcheck -s bash silent_hello_patched.bash + echo "Running shellcheck against silent_hello_patched.bash" + shellcheck -s bash silent_hello_patched.bash - echo "Testing in Bash if silent_hello_patched.bash get sourced without error" - bash -eu -o pipefail -c ". ./silent_hello_patched.bash" + echo "Testing in Bash if silent_hello_patched.bash get sourced without error" + bash -eu -o pipefail -c ". ./silent_hello_patched.bash" - echo "Testing in Ksh if silent_hello_patched.bash get sourced without error" - ksh -eu -o pipefail -c ". ./silent_hello_patched.bash" + echo "Testing in Ksh if silent_hello_patched.bash get sourced without error" + ksh -eu -o pipefail -c ". ./silent_hello_patched.bash" - echo "Testing in Zsh if silent_hello_patched.bash get sourced without error" - zsh -eu -o pipefail -c ". ./silent_hello_patched.bash" + echo "Testing in Zsh if silent_hello_patched.bash get sourced without error" + zsh -eu -o pipefail -c ". ./silent_hello_patched.bash" - # Check the sample source + # Check the sample source - echo "Running shellcheck against sample_source.bash" - shellcheck -s bash ${./sample_source.bash} - shellcheck -s ksh ${./sample_source.bash} + echo "Running shellcheck against sample_source.bash" + shellcheck -s bash ${./sample_source.bash} + shellcheck -s ksh ${./sample_source.bash} - # Test patching the sample source + # Test patching the sample source - cp ${./sample_source.bash} sample_source_patched.bash - chmod u+w sample_source_patched.bash + cp ${./sample_source.bash} sample_source_patched.bash + chmod u+w sample_source_patched.bash - echo "Generating sample_source_patched.bash from ./sample_source.bash" - patchRcPathBash sample_source_patched.bash "$PWD/delta:$PWD/foxtrot" + echo "Generating sample_source_patched.bash from ./sample_source.bash" + patchRcPathBash sample_source_patched.bash "$PWD/delta:$PWD/foxtrot" - echo "Running shellcheck against sample_source_patched.bash" - shellcheck -s bash sample_source_patched.bash + echo "Running shellcheck against sample_source_patched.bash" + shellcheck -s bash sample_source_patched.bash - echo "Testing in Bash if sample_source.bash and sample_source_patched.bash modifies PATH the same way" - bash ${./test-sourcing-bash} ${./sample_source.bash} ./sample_source_patched.bash + echo "Testing in Bash if sample_source.bash and sample_source_patched.bash modifies PATH the same way" + bash ${./test-sourcing-bash} ${./sample_source.bash} ./sample_source_patched.bash - echo "Testing in Ksh if sample_source.bash and sample_source_patched.bash modifies PATH the same way" - ksh ${./test-sourcing-bash} ${./sample_source.bash} "$PWD/sample_source_patched.bash" + echo "Testing in Ksh if sample_source.bash and sample_source_patched.bash modifies PATH the same way" + ksh ${./test-sourcing-bash} ${./sample_source.bash} "$PWD/sample_source_patched.bash" - echo "Testing in Zsh if sample_source.bash and sample_source_patched.bash modifies PATH the same way" - zsh ${./test-sourcing-bash} ${./sample_source.bash} ./sample_source_patched.bash + echo "Testing in Zsh if sample_source.bash and sample_source_patched.bash modifies PATH the same way" + zsh ${./test-sourcing-bash} ${./sample_source.bash} ./sample_source_patched.bash - # Test double-patching the sample source + # Test double-patching the sample source - echo "Patching again sample_source_patched.bash" - patchRcPathBash sample_source_patched.bash "$PWD/foxtrot:$PWD/golf" + echo "Patching again sample_source_patched.bash" + patchRcPathBash sample_source_patched.bash "$PWD/foxtrot:$PWD/golf" - echo "Running shellcheck against sample_source_patched.bash" - shellcheck -s bash sample_source_patched.bash - shellcheck -s ksh sample_source_patched.bash + echo "Running shellcheck against sample_source_patched.bash" + shellcheck -s bash sample_source_patched.bash + shellcheck -s ksh sample_source_patched.bash - echo "Testing in Bash if sample_source.bash and sample_source_patched.bash modifies PATH the same way" - bash ${./test-sourcing-bash} ${./sample_source.bash} ./sample_source_patched.bash + echo "Testing in Bash if sample_source.bash and sample_source_patched.bash modifies PATH the same way" + bash ${./test-sourcing-bash} ${./sample_source.bash} ./sample_source_patched.bash - echo "Testing in Ksh if sample_source.bash and sample_source_patched.bash modifies PATH the same way" - ksh ${./test-sourcing-bash} ${./sample_source.bash} "$PWD/sample_source_patched.bash" + echo "Testing in Ksh if sample_source.bash and sample_source_patched.bash modifies PATH the same way" + ksh ${./test-sourcing-bash} ${./sample_source.bash} "$PWD/sample_source_patched.bash" - echo "Testing in Zsh if sample_source.bash and sample_source_patched.bash modifies PATH the same way" - zsh ${./test-sourcing-bash} ${./sample_source.bash} ./sample_source_patched.bash + echo "Testing in Zsh if sample_source.bash and sample_source_patched.bash modifies PATH the same way" + zsh ${./test-sourcing-bash} ${./sample_source.bash} ./sample_source_patched.bash - # Create a dummy output - touch "$out" - '' - ) - { }; + # Create a dummy output + touch "$out" + '' + ) { }; + test-csh = callPackage ( + { + lib, + runCommandLocal, + gnused, + hello, + patchRcPathCsh, + tcsh, + }: + runCommandLocal "patch-rc-path-csh-test" + { + nativeBuildInputs = [ + patchRcPathCsh + tcsh + ]; + meta = { + description = "Package test of patchActivateCsh"; + inherit (patchRcPathCsh.meta) maintainers; + }; + } + '' + set -eu -o pipefail - test-csh = callPackage - ( - { lib - , runCommandLocal - , gnused - , hello - , patchRcPathCsh - , tcsh - }: - runCommandLocal "patch-rc-path-csh-test" - { - nativeBuildInputs = [ - patchRcPathCsh - tcsh - ]; - meta = { - description = "Package test of patchActivateCsh"; - inherit (patchRcPathCsh.meta) maintainers; - }; - } - '' - set -eu -o pipefail + # Test patching a blank file + echo > blank.csh - # Test patching a blank file + echo "Generating blank_patched.csh from blank.csh" + cp blank.csh blank_patched.csh + patchRcPathCsh blank_patched.csh "$PWD/delta:$PWD/foxtrot" - echo > blank.csh + echo "Testing in Csh if blank.csh and blank_patched.csh modifies PATH the same way" + tcsh -e ${./test-sourcing-csh} blank.csh blank_patched.csh - echo "Generating blank_patched.csh from blank.csh" - cp blank.csh blank_patched.csh - patchRcPathCsh blank_patched.csh "$PWD/delta:$PWD/foxtrot" - echo "Testing in Csh if blank.csh and blank_patched.csh modifies PATH the same way" - tcsh -e ${./test-sourcing-csh} blank.csh blank_patched.csh + # Test patching silent_hello file + echo "hello > /dev/null" > silent_hello.csh - # Test patching silent_hello file + echo "Generating silent_hello_patched.csh from silent_hello.csh" + cp silent_hello.csh silent_hello_patched.csh + patchRcPathCsh silent_hello_patched.csh "${hello}/bin" - echo "hello > /dev/null" > silent_hello.csh + echo "Testing in Csh if silent_hello_patched.csh get sourced without errer" + tcsh -e -c "source silent_hello_patched.csh" - echo "Generating silent_hello_patched.csh from silent_hello.csh" - cp silent_hello.csh silent_hello_patched.csh - patchRcPathCsh silent_hello_patched.csh "${hello}/bin" - echo "Testing in Csh if silent_hello_patched.csh get sourced without errer" - tcsh -e -c "source silent_hello_patched.csh" + # Generate the sample source + substitute ${./sample_source.csh.in} sample_source.csh --replace @sed@ ${gnused}/bin/sed + chmod u+rw sample_source.csh - # Generate the sample source - substitute ${./sample_source.csh.in} sample_source.csh --replace @sed@ ${gnused}/bin/sed - chmod u+rw sample_source.csh + # Test patching the sample source + echo "Generating sample_source_patched.csh from sample_source.csh" + cp sample_source.csh sample_source_patched.csh + chmod u+w sample_source_patched.csh + patchRcPathCsh sample_source_patched.csh "$PWD/delta:$PWD/foxtrot" - # Test patching the sample source + echo "Testing in Csh if sample_source.csh and sample_source_patched.csh modifies PATH the same way" + tcsh -e ${./test-sourcing-csh} sample_source.csh sample_source_patched.csh - echo "Generating sample_source_patched.csh from sample_source.csh" - cp sample_source.csh sample_source_patched.csh - chmod u+w sample_source_patched.csh - patchRcPathCsh sample_source_patched.csh "$PWD/delta:$PWD/foxtrot" - echo "Testing in Csh if sample_source.csh and sample_source_patched.csh modifies PATH the same way" - tcsh -e ${./test-sourcing-csh} sample_source.csh sample_source_patched.csh + # Test double-patching the sample source + echo "Patching again sample_source_patched.csh from sample_source.csh" + patchRcPathCsh sample_source_patched.csh "$PWD/foxtrot:$PWD/golf" - # Test double-patching the sample source + echo "Testing in Csh if sample_source.csh and sample_source_patched.csh modifies PATH the same way" + tcsh -e ${./test-sourcing-csh} sample_source.csh sample_source_patched.csh - echo "Patching again sample_source_patched.csh from sample_source.csh" - patchRcPathCsh sample_source_patched.csh "$PWD/foxtrot:$PWD/golf" - echo "Testing in Csh if sample_source.csh and sample_source_patched.csh modifies PATH the same way" - tcsh -e ${./test-sourcing-csh} sample_source.csh sample_source_patched.csh + # Create a dummy output + touch "$out" + '' + ) { }; + test-fish = callPackage ( + { + lib, + runCommandLocal, + fish, + hello, + patchRcPathFish, + }: + runCommandLocal "patch-rc-path-fish-test" + { + nativeBuildInputs = [ + fish + patchRcPathFish + ]; + meta = { + description = "Package test of patchActivateFish"; + inherit (patchRcPathFish.meta) maintainers; + }; + } + '' + set -eu -o pipefail - # Create a dummy output - touch "$out" - '' - ) - { }; + # Test patching a blank file + echo > blank.fish - test-fish = callPackage - ( - { lib - , runCommandLocal - , fish - , hello - , patchRcPathFish - }: - runCommandLocal "patch-rc-path-fish-test" - { - nativeBuildInputs = [ - fish - patchRcPathFish - ]; - meta = { - description = "Package test of patchActivateFish"; - inherit (patchRcPathFish.meta) maintainers; - }; - } - '' - set -eu -o pipefail + echo "Generating blank_patched.fish from blank.fish" + cp blank.fish blank_patched.fish + patchRcPathFish blank_patched.fish "$PWD/delta:$PWD/foxtrot" + echo "Testing in Fish if blank.fish and blank_patched.fish modifies PATH the same way" + HOME_TEMP="$(mktemp -d temporary_home_XXXXXX)" + HOME="$HOME_TEMP" fish ${./test-sourcing-fish} blank.fish blank_patched.fish + rm -r "$HOME_TEMP" - # Test patching a blank file - echo > blank.fish + # Test patching silent_hello file - echo "Generating blank_patched.fish from blank.fish" - cp blank.fish blank_patched.fish - patchRcPathFish blank_patched.fish "$PWD/delta:$PWD/foxtrot" + echo "hello > /dev/null" > silent_hello.fish - echo "Testing in Fish if blank.fish and blank_patched.fish modifies PATH the same way" - HOME_TEMP="$(mktemp -d temporary_home_XXXXXX)" - HOME="$HOME_TEMP" fish ${./test-sourcing-fish} blank.fish blank_patched.fish - rm -r "$HOME_TEMP" + echo "Generating silent_hello_patched.fish from silent_hello.fish" + cp silent_hello.fish silent_hello_patched.fish + patchRcPathFish silent_hello_patched.fish "${hello}/bin" + echo "Testing in Fish if silent_hello_patched.fish get sourced without error" + HOME_TEMP="$(mktemp -d temporary_home_XXXXXX)" + HOME="$HOME_TEMP" fish -c "source silent_hello_patched.fish" + rm -r "$HOME_TEMP" - # Test patching silent_hello file - echo "hello > /dev/null" > silent_hello.fish + # Test patching the sample source - echo "Generating silent_hello_patched.fish from silent_hello.fish" - cp silent_hello.fish silent_hello_patched.fish - patchRcPathFish silent_hello_patched.fish "${hello}/bin" + cp ${./sample_source.fish} sample_source_patched.fish + chmod u+w sample_source_patched.fish - echo "Testing in Fish if silent_hello_patched.fish get sourced without error" - HOME_TEMP="$(mktemp -d temporary_home_XXXXXX)" - HOME="$HOME_TEMP" fish -c "source silent_hello_patched.fish" - rm -r "$HOME_TEMP" + echo "Generating sample_source_patched.fish from ${./sample_source.fish}" + patchRcPathFish sample_source_patched.fish "$PWD/delta:$PWD/foxtrot" + echo "Testing in Fish if sample_source.fish and sample_source_patched.fish modifies PATH the same way" + HOME_TEMP="$(mktemp -d temporary_home_XXXXXX)" + HOME="$HOME_TEMP" fish ${./test-sourcing-fish} ${./sample_source.fish} sample_source_patched.fish + rm -r "$HOME_TEMP" - # Test patching the sample source + # Test double-patching the sample source - cp ${./sample_source.fish} sample_source_patched.fish - chmod u+w sample_source_patched.fish + echo "Patching again sample_source_patched.fish from ${./sample_source.fish}" + patchRcPathFish sample_source_patched.fish "$PWD/foxtrot:$PWD/golf" - echo "Generating sample_source_patched.fish from ${./sample_source.fish}" - patchRcPathFish sample_source_patched.fish "$PWD/delta:$PWD/foxtrot" - echo "Testing in Fish if sample_source.fish and sample_source_patched.fish modifies PATH the same way" - HOME_TEMP="$(mktemp -d temporary_home_XXXXXX)" - HOME="$HOME_TEMP" fish ${./test-sourcing-fish} ${./sample_source.fish} sample_source_patched.fish - rm -r "$HOME_TEMP" + echo "Testing in Fish if sample_source.fish and sample_source_patched.fish modifies PATH the same way" + HOME_TEMP="$(mktemp -d temporary_home_XXXXXX)" + HOME="$HOME_TEMP" fish ${./test-sourcing-fish} ${./sample_source.fish} sample_source_patched.fish + rm -r "$HOME_TEMP" - # Test double-patching the sample source + # Create a dummy output + touch "$out" + '' + ) { }; - echo "Patching again sample_source_patched.fish from ${./sample_source.fish}" - patchRcPathFish sample_source_patched.fish "$PWD/foxtrot:$PWD/golf" + test-posix = callPackage ( + { + lib, + runCommandLocal, + bash, + dash, + gnused, + hello, + ksh, + patchRcPathPosix, + shellcheck, + }: + runCommandLocal "patch-rc-path-posix-test" + { + nativeBuildInputs = [ + bash + dash + ksh + patchRcPathPosix + shellcheck + ]; + meta = { + description = "Package test of patchActivatePosix"; + inherit (patchRcPathPosix.meta) maintainers; + }; + } + '' + set -eu -o pipefail - echo "Testing in Fish if sample_source.fish and sample_source_patched.fish modifies PATH the same way" - HOME_TEMP="$(mktemp -d temporary_home_XXXXXX)" - HOME="$HOME_TEMP" fish ${./test-sourcing-fish} ${./sample_source.fish} sample_source_patched.fish - rm -r "$HOME_TEMP" + # Check the setup hook script - # Create a dummy output - touch "$out" - '' - ) - { }; + echo "Running shellcheck against ${./test-sourcing-posix}" + shellcheck -s sh --exclude SC1090 ${./test-sourcing-posix} + shellcheck -s dash --exclude SC1090 ${./test-sourcing-posix} + # Test patching a blank file - test-posix = callPackage - ( - { lib - , runCommandLocal - , bash - , dash - , gnused - , hello - , ksh - , patchRcPathPosix - , shellcheck - }: - runCommandLocal "patch-rc-path-posix-test" - { - nativeBuildInputs = [ - bash - dash - ksh - patchRcPathPosix - shellcheck - ]; - meta = { - description = "Package test of patchActivatePosix"; - inherit (patchRcPathPosix.meta) maintainers; - }; - } - '' - set -eu -o pipefail + echo > blank.sh + echo "Generating blank_patched.sh from blank.sh" + cp blank.sh blank_patched.sh + patchRcPathPosix blank_patched.sh "$PWD/delta:$PWD/foxtrot" - # Check the setup hook script + echo "Running shellcheck against blank_patched.sh" + shellcheck -s sh blank_patched.sh + shellcheck -s dash blank_patched.sh - echo "Running shellcheck against ${./test-sourcing-posix}" - shellcheck -s sh --exclude SC1090 ${./test-sourcing-posix} - shellcheck -s dash --exclude SC1090 ${./test-sourcing-posix} + echo "Testing in Bash if blank.sh and blank_patched.sh modifies PATH the same way" + bash --posix ${./test-sourcing-posix} ./blank.sh ./blank_patched.sh + echo "Testing in Dash if blank.sh and blank_patched.sh modifies PATH the same way" + dash ${./test-sourcing-posix} ./blank.sh ./blank_patched.sh - # Test patching a blank file + echo "Testing in Ksh if ./blank.sh and ./blank_patched.sh modifies PATH the same way" + ksh ${./test-sourcing-posix} "$PWD/blank.sh" "$PWD/blank_patched.sh" - echo > blank.sh - echo "Generating blank_patched.sh from blank.sh" - cp blank.sh blank_patched.sh - patchRcPathPosix blank_patched.sh "$PWD/delta:$PWD/foxtrot" + # Test patching silent_hello file - echo "Running shellcheck against blank_patched.sh" - shellcheck -s sh blank_patched.sh - shellcheck -s dash blank_patched.sh + echo "hello > /dev/null" > silent_hello.sh - echo "Testing in Bash if blank.sh and blank_patched.sh modifies PATH the same way" - bash --posix ${./test-sourcing-posix} ./blank.sh ./blank_patched.sh + echo "Generating silent_hello_patched.sh from silent_hello.sh" + cp silent_hello.sh silent_hello_patched.sh + patchRcPathPosix silent_hello_patched.sh "${hello}/bin" - echo "Testing in Dash if blank.sh and blank_patched.sh modifies PATH the same way" - dash ${./test-sourcing-posix} ./blank.sh ./blank_patched.sh + echo "Running shellcheck against silent_hello_patched.sh" + shellcheck -s sh silent_hello_patched.sh + shellcheck -s dash silent_hello_patched.sh - echo "Testing in Ksh if ./blank.sh and ./blank_patched.sh modifies PATH the same way" - ksh ${./test-sourcing-posix} "$PWD/blank.sh" "$PWD/blank_patched.sh" + echo "Testing in Bash if silent_hello_patched.sh get sourced without error" + bash --posix -eu -c ". ./silent_hello_patched.sh" + echo "Testing in Dash if silent_hello_patched.sh get sourced without error" + dash -eu -c ". ./silent_hello_patched.sh" - # Test patching silent_hello file + echo "Testing in Ksh if silent_hello_patched.sh get sourced without error" + ksh -eu -c ". $PWD/silent_hello_patched.sh" - echo "hello > /dev/null" > silent_hello.sh - echo "Generating silent_hello_patched.sh from silent_hello.sh" - cp silent_hello.sh silent_hello_patched.sh - patchRcPathPosix silent_hello_patched.sh "${hello}/bin" + # Generate the sample source "$PWD/delta:$PWD/foxtrot" "$PWD/delta:$PWD/foxtrot" - echo "Running shellcheck against silent_hello_patched.sh" - shellcheck -s sh silent_hello_patched.sh - shellcheck -s dash silent_hello_patched.sh + substitute ${./sample_source.sh.in} sample_source.sh --replace @sed@ ${gnused}/bin/sed + chmod u+rw sample_source.sh - echo "Testing in Bash if silent_hello_patched.sh get sourced without error" - bash --posix -eu -c ". ./silent_hello_patched.sh" - echo "Testing in Dash if silent_hello_patched.sh get sourced without error" - dash -eu -c ". ./silent_hello_patched.sh" + # Check the sample source - echo "Testing in Ksh if silent_hello_patched.sh get sourced without error" - ksh -eu -c ". $PWD/silent_hello_patched.sh" + echo "Running shellcheck against sample_source.sh" + shellcheck -s sh sample_source.sh + shellcheck -s dash sample_source.sh - # Generate the sample source "$PWD/delta:$PWD/foxtrot" "$PWD/delta:$PWD/foxtrot" + # Test patching the sample source - substitute ${./sample_source.sh.in} sample_source.sh --replace @sed@ ${gnused}/bin/sed - chmod u+rw sample_source.sh + echo "Generating sample_source_patched.sh from sample_source.sh" + cp sample_source.sh sample_source_patched.sh + chmod u+w sample_source_patched.sh + patchRcPathPosix sample_source_patched.sh "$PWD/delta:$PWD/foxtrot" + echo "Running shellcheck against sample_source_patched.sh" + shellcheck -s sh sample_source_patched.sh + shellcheck -s dash sample_source_patched.sh - # Check the sample source + echo "Testing in Bash if sample_source.bash and sample_source_patched.bash modifies PATH the same way" + bash --posix ${./test-sourcing-posix} "./sample_source.sh" "./sample_source_patched.sh" - echo "Running shellcheck against sample_source.sh" - shellcheck -s sh sample_source.sh - shellcheck -s dash sample_source.sh + echo "Testing in Dash if sample_source.sh and sample_source_patched.sh modifies PATH the same way" + dash ${./test-sourcing-posix} "./sample_source.sh" "./sample_source_patched.sh" + echo "Testing in Ksh if sample_source.sh and sample_source_patched.sh modifies PATH the same way" + ksh ${./test-sourcing-posix} "$PWD/sample_source.sh" "$PWD/sample_source_patched.sh" - # Test patching the sample source - echo "Generating sample_source_patched.sh from sample_source.sh" - cp sample_source.sh sample_source_patched.sh - chmod u+w sample_source_patched.sh - patchRcPathPosix sample_source_patched.sh "$PWD/delta:$PWD/foxtrot" + # Test double-patching the sample source - echo "Running shellcheck against sample_source_patched.sh" - shellcheck -s sh sample_source_patched.sh - shellcheck -s dash sample_source_patched.sh + echo "Patching again sample_source_patched.sh" + patchRcPathPosix sample_source_patched.sh "$PWD/foxtrot:$PWD/golf" - echo "Testing in Bash if sample_source.bash and sample_source_patched.bash modifies PATH the same way" - bash --posix ${./test-sourcing-posix} "./sample_source.sh" "./sample_source_patched.sh" + echo "Running shellcheck against sample_source_patched.sh" + shellcheck -s sh sample_source_patched.sh + shellcheck -s dash sample_source_patched.sh - echo "Testing in Dash if sample_source.sh and sample_source_patched.sh modifies PATH the same way" - dash ${./test-sourcing-posix} "./sample_source.sh" "./sample_source_patched.sh" + echo "Testing in Bash if sample_source.bash and sample_source_patched.bash modifies PATH the same way" + bash --posix ${./test-sourcing-posix} "./sample_source.sh" "./sample_source_patched.sh" - echo "Testing in Ksh if sample_source.sh and sample_source_patched.sh modifies PATH the same way" - ksh ${./test-sourcing-posix} "$PWD/sample_source.sh" "$PWD/sample_source_patched.sh" + echo "Testing in Dash if sample_source.sh and sample_source_patched.sh modifies PATH the same way" + dash ${./test-sourcing-posix} "./sample_source.sh" "./sample_source_patched.sh" + echo "Testing in Ksh if sample_source.sh and sample_source_patched.sh modifies PATH the same way" + ksh ${./test-sourcing-posix} "$PWD/sample_source.sh" "$PWD/sample_source_patched.sh" - # Test double-patching the sample source - echo "Patching again sample_source_patched.sh" - patchRcPathPosix sample_source_patched.sh "$PWD/foxtrot:$PWD/golf" - - echo "Running shellcheck against sample_source_patched.sh" - shellcheck -s sh sample_source_patched.sh - shellcheck -s dash sample_source_patched.sh - - echo "Testing in Bash if sample_source.bash and sample_source_patched.bash modifies PATH the same way" - bash --posix ${./test-sourcing-posix} "./sample_source.sh" "./sample_source_patched.sh" - - echo "Testing in Dash if sample_source.sh and sample_source_patched.sh modifies PATH the same way" - dash ${./test-sourcing-posix} "./sample_source.sh" "./sample_source_patched.sh" - - echo "Testing in Ksh if sample_source.sh and sample_source_patched.sh modifies PATH the same way" - ksh ${./test-sourcing-posix} "$PWD/sample_source.sh" "$PWD/sample_source_patched.sh" - - - # Create a dummy output - touch "$out" - '' - ) - { }; + # Create a dummy output + touch "$out" + '' + ) { }; } diff --git a/pkgs/build-support/setup-hooks/wrap-gapps-hook/default.nix b/pkgs/build-support/setup-hooks/wrap-gapps-hook/default.nix index b2ce7b4b2654b9..df134ddd63cccf 100644 --- a/pkgs/build-support/setup-hooks/wrap-gapps-hook/default.nix +++ b/pkgs/build-support/setup-hooks/wrap-gapps-hook/default.nix @@ -1,203 +1,257 @@ -{ stdenv -, lib -, makeSetupHook -, makeWrapper -, gobject-introspection -, isGraphical ? false -, gtk3 -, librsvg -, dconf -, callPackage -, wrapGAppsHook3 -, targetPackages +{ + stdenv, + lib, + makeSetupHook, + makeWrapper, + gobject-introspection, + isGraphical ? false, + gtk3, + librsvg, + dconf, + callPackage, + wrapGAppsHook3, + targetPackages, }: makeSetupHook { name = "wrap-gapps-hook"; - propagatedBuildInputs = [ - # We use the wrapProgram function. - makeWrapper - ] ++ lib.optionals isGraphical [ - # TODO: remove this, packages should depend on GTK explicitly. - gtk3 - - librsvg - ]; + propagatedBuildInputs = + [ + # We use the wrapProgram function. + makeWrapper + ] + ++ lib.optionals isGraphical [ + # TODO: remove this, packages should depend on GTK explicitly. + gtk3 + + librsvg + ]; # depsTargetTargetPropagated will essentially be buildInputs when wrapGAppsHook3 is placed into nativeBuildInputs # the librsvg and gtk3 above should be removed but kept to not break anything that implicitly depended on its binaries - depsTargetTargetPropagated = assert (lib.assertMsg (!targetPackages ? raw) "wrapGAppsHook3 must be in nativeBuildInputs"); lib.optionals isGraphical [ - # librsvg provides a module for gdk-pixbuf to allow rendering - # SVG icons. Most icon themes are SVG-based and so are some - # graphics in GTK (e.g. cross for closing window in window title bar) - # so it is pretty much required for applications using GTK. - librsvg - - # TODO: remove this, packages should depend on GTK explicitly. - gtk3 - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - # It is highly probable that a program will use GSettings, - # at minimum through GTK file chooser dialogue. - # Let’s add a GIO module for “dconf” GSettings backend - # to avoid falling back to “memory” backend. This is - # required for GSettings-based settings to be persisted. - # Unfortunately, it also requires the user to have dconf - # D-Bus service enabled globally (e.g. through a NixOS module). - dconf.lib - ]; + depsTargetTargetPropagated = + assert (lib.assertMsg (!targetPackages ? raw) "wrapGAppsHook3 must be in nativeBuildInputs"); + lib.optionals isGraphical [ + # librsvg provides a module for gdk-pixbuf to allow rendering + # SVG icons. Most icon themes are SVG-based and so are some + # graphics in GTK (e.g. cross for closing window in window title bar) + # so it is pretty much required for applications using GTK. + librsvg + + # TODO: remove this, packages should depend on GTK explicitly. + gtk3 + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + # It is highly probable that a program will use GSettings, + # at minimum through GTK file chooser dialogue. + # Let’s add a GIO module for “dconf” GSettings backend + # to avoid falling back to “memory” backend. This is + # required for GSettings-based settings to be persisted. + # Unfortunately, it also requires the user to have dconf + # D-Bus service enabled globally (e.g. through a NixOS module). + dconf.lib + ]; passthru = { - tests = let - sample-project = ./tests/sample-project; - - testLib = callPackage ./tests/lib.nix { }; - inherit (testLib) expectSomeLineContainingYInFileXToMentionZ; - in rec { - # Simple derivation containing a program and a daemon. - basic = stdenv.mkDerivation { - name = "basic"; - - src = sample-project; - - strictDeps = true; - nativeBuildInputs = [ wrapGAppsHook3 ]; - - installFlags = [ "bin-foo" "libexec-bar" ]; - }; - - # The wrapper for executable files should add path to dconf GIO module. - basic-contains-dconf = let - tested = basic; - in testLib.runTest "basic-contains-dconf" ( - testLib.skip stdenv.hostPlatform.isDarwin '' - ${expectSomeLineContainingYInFileXToMentionZ "${tested}/bin/foo" "GIO_EXTRA_MODULES" "${dconf.lib}/lib/gio/modules"} - ${expectSomeLineContainingYInFileXToMentionZ "${tested}/libexec/bar" "GIO_EXTRA_MODULES" "${dconf.lib}/lib/gio/modules"} - '' - ); - - basic-contains-gdk-pixbuf = let - tested = basic; - in testLib.runTest "basic-contains-gdk-pixbuf" ( - testLib.skip stdenv.hostPlatform.isDarwin '' - ${expectSomeLineContainingYInFileXToMentionZ "${tested}/bin/foo" "GDK_PIXBUF_MODULE_FILE" "${lib.getLib librsvg}/lib/gdk-pixbuf-2.0/2.10.0/loaders.cache"} - ${expectSomeLineContainingYInFileXToMentionZ "${tested}/libexec/bar" "GDK_PIXBUF_MODULE_FILE" "${lib.getLib librsvg}/lib/gdk-pixbuf-2.0/2.10.0/loaders.cache"} - '' - ); - - # Simple derivation containing a gobject-introspection typelib. - typelib-Mahjong = stdenv.mkDerivation { - name = "typelib-Mahjong"; - - src = sample-project; - - strictDeps = true; - - installFlags = [ "typelib-Mahjong" ]; - }; - - # Simple derivation using a typelib. - typelib-user = stdenv.mkDerivation { - name = "typelib-user"; - - src = sample-project; - - strictDeps = true; - nativeBuildInputs = [ - gobject-introspection - wrapGAppsHook3 - ]; - - buildInputs = [ - typelib-Mahjong - ]; - - installFlags = [ "bin-foo" "libexec-bar" ]; - }; - - # Testing cooperation with gobject-introspection setup hook, - # which should populate GI_TYPELIB_PATH variable with paths - # to typelibs among the derivation’s dependencies. - # The resulting GI_TYPELIB_PATH should be picked up by the wrapper. - typelib-user-has-gi-typelib-path = let - tested = typelib-user; - in testLib.runTest "typelib-user-has-gi-typelib-path" '' - ${expectSomeLineContainingYInFileXToMentionZ "${tested}/bin/foo" "GI_TYPELIB_PATH" "${typelib-Mahjong}/lib/girepository-1.0"} - ${expectSomeLineContainingYInFileXToMentionZ "${tested}/libexec/bar" "GI_TYPELIB_PATH" "${typelib-Mahjong}/lib/girepository-1.0"} - ''; - - # Simple derivation containing a gobject-introspection typelib in lib output. - typelib-Bechamel = stdenv.mkDerivation { - name = "typelib-Bechamel"; - - outputs = [ "out" "lib" ]; - - src = sample-project; - - strictDeps = true; - - makeFlags = [ - "LIBDIR=${placeholder "lib"}/lib" - ]; - - installFlags = [ "typelib-Bechamel" ]; + tests = + let + sample-project = ./tests/sample-project; + + testLib = callPackage ./tests/lib.nix { }; + inherit (testLib) expectSomeLineContainingYInFileXToMentionZ; + in + rec { + # Simple derivation containing a program and a daemon. + basic = stdenv.mkDerivation { + name = "basic"; + + src = sample-project; + + strictDeps = true; + nativeBuildInputs = [ wrapGAppsHook3 ]; + + installFlags = [ + "bin-foo" + "libexec-bar" + ]; + }; + + # The wrapper for executable files should add path to dconf GIO module. + basic-contains-dconf = + let + tested = basic; + in + testLib.runTest "basic-contains-dconf" ( + testLib.skip stdenv.hostPlatform.isDarwin '' + ${expectSomeLineContainingYInFileXToMentionZ "${tested}/bin/foo" "GIO_EXTRA_MODULES" + "${dconf.lib}/lib/gio/modules" + } + ${expectSomeLineContainingYInFileXToMentionZ "${tested}/libexec/bar" "GIO_EXTRA_MODULES" + "${dconf.lib}/lib/gio/modules" + } + '' + ); + + basic-contains-gdk-pixbuf = + let + tested = basic; + in + testLib.runTest "basic-contains-gdk-pixbuf" ( + testLib.skip stdenv.hostPlatform.isDarwin '' + ${expectSomeLineContainingYInFileXToMentionZ "${tested}/bin/foo" "GDK_PIXBUF_MODULE_FILE" + "${lib.getLib librsvg}/lib/gdk-pixbuf-2.0/2.10.0/loaders.cache" + } + ${expectSomeLineContainingYInFileXToMentionZ "${tested}/libexec/bar" "GDK_PIXBUF_MODULE_FILE" + "${lib.getLib librsvg}/lib/gdk-pixbuf-2.0/2.10.0/loaders.cache" + } + '' + ); + + # Simple derivation containing a gobject-introspection typelib. + typelib-Mahjong = stdenv.mkDerivation { + name = "typelib-Mahjong"; + + src = sample-project; + + strictDeps = true; + + installFlags = [ "typelib-Mahjong" ]; + }; + + # Simple derivation using a typelib. + typelib-user = stdenv.mkDerivation { + name = "typelib-user"; + + src = sample-project; + + strictDeps = true; + nativeBuildInputs = [ + gobject-introspection + wrapGAppsHook3 + ]; + + buildInputs = [ + typelib-Mahjong + ]; + + installFlags = [ + "bin-foo" + "libexec-bar" + ]; + }; + + # Testing cooperation with gobject-introspection setup hook, + # which should populate GI_TYPELIB_PATH variable with paths + # to typelibs among the derivation’s dependencies. + # The resulting GI_TYPELIB_PATH should be picked up by the wrapper. + typelib-user-has-gi-typelib-path = + let + tested = typelib-user; + in + testLib.runTest "typelib-user-has-gi-typelib-path" '' + ${expectSomeLineContainingYInFileXToMentionZ "${tested}/bin/foo" "GI_TYPELIB_PATH" + "${typelib-Mahjong}/lib/girepository-1.0" + } + ${expectSomeLineContainingYInFileXToMentionZ "${tested}/libexec/bar" "GI_TYPELIB_PATH" + "${typelib-Mahjong}/lib/girepository-1.0" + } + ''; + + # Simple derivation containing a gobject-introspection typelib in lib output. + typelib-Bechamel = stdenv.mkDerivation { + name = "typelib-Bechamel"; + + outputs = [ + "out" + "lib" + ]; + + src = sample-project; + + strictDeps = true; + + makeFlags = [ + "LIBDIR=${placeholder "lib"}/lib" + ]; + + installFlags = [ "typelib-Bechamel" ]; + }; + + # Simple derivation using a typelib from non-default output. + typelib-multiout-user = stdenv.mkDerivation { + name = "typelib-multiout-user"; + + src = sample-project; + + strictDeps = true; + nativeBuildInputs = [ + gobject-introspection + wrapGAppsHook3 + ]; + + buildInputs = [ + typelib-Bechamel + ]; + + installFlags = [ + "bin-foo" + "libexec-bar" + ]; + }; + + # Testing cooperation with gobject-introspection setup hook, + # which should populate GI_TYPELIB_PATH variable with paths + # to typelibs among the derivation’s dependencies, + # even when they are not in default output. + # The resulting GI_TYPELIB_PATH should be picked up by the wrapper. + typelib-multiout-user-has-gi-typelib-path = + let + tested = typelib-multiout-user; + in + testLib.runTest "typelib-multiout-user-has-gi-typelib-path" '' + ${expectSomeLineContainingYInFileXToMentionZ "${tested}/bin/foo" "GI_TYPELIB_PATH" + "${typelib-Bechamel.lib}/lib/girepository-1.0" + } + ${expectSomeLineContainingYInFileXToMentionZ "${tested}/libexec/bar" "GI_TYPELIB_PATH" + "${typelib-Bechamel.lib}/lib/girepository-1.0" + } + ''; + + # Simple derivation that contains a typelib as well as a program using it. + typelib-self-user = stdenv.mkDerivation { + name = "typelib-self-user"; + + src = sample-project; + + strictDeps = true; + nativeBuildInputs = [ + gobject-introspection + wrapGAppsHook3 + ]; + + installFlags = [ + "typelib-Cow" + "bin-foo" + "libexec-bar" + ]; + }; + + # Testing cooperation with gobject-introspection setup hook, + # which should add the path to derivation’s own typelibs + # to GI_TYPELIB_PATH variable. + # The resulting GI_TYPELIB_PATH should be picked up by the wrapper. + # https://github.com/NixOS/nixpkgs/issues/85515 + typelib-self-user-has-gi-typelib-path = + let + tested = typelib-self-user; + in + testLib.runTest "typelib-self-user-has-gi-typelib-path" '' + ${expectSomeLineContainingYInFileXToMentionZ "${tested}/bin/foo" "GI_TYPELIB_PATH" + "${typelib-self-user}/lib/girepository-1.0" + } + ${expectSomeLineContainingYInFileXToMentionZ "${tested}/libexec/bar" "GI_TYPELIB_PATH" + "${typelib-self-user}/lib/girepository-1.0" + } + ''; }; - - # Simple derivation using a typelib from non-default output. - typelib-multiout-user = stdenv.mkDerivation { - name = "typelib-multiout-user"; - - src = sample-project; - - strictDeps = true; - nativeBuildInputs = [ - gobject-introspection - wrapGAppsHook3 - ]; - - buildInputs = [ - typelib-Bechamel - ]; - - installFlags = [ "bin-foo" "libexec-bar" ]; - }; - - # Testing cooperation with gobject-introspection setup hook, - # which should populate GI_TYPELIB_PATH variable with paths - # to typelibs among the derivation’s dependencies, - # even when they are not in default output. - # The resulting GI_TYPELIB_PATH should be picked up by the wrapper. - typelib-multiout-user-has-gi-typelib-path = let - tested = typelib-multiout-user; - in testLib.runTest "typelib-multiout-user-has-gi-typelib-path" '' - ${expectSomeLineContainingYInFileXToMentionZ "${tested}/bin/foo" "GI_TYPELIB_PATH" "${typelib-Bechamel.lib}/lib/girepository-1.0"} - ${expectSomeLineContainingYInFileXToMentionZ "${tested}/libexec/bar" "GI_TYPELIB_PATH" "${typelib-Bechamel.lib}/lib/girepository-1.0"} - ''; - - # Simple derivation that contains a typelib as well as a program using it. - typelib-self-user = stdenv.mkDerivation { - name = "typelib-self-user"; - - src = sample-project; - - strictDeps = true; - nativeBuildInputs = [ - gobject-introspection - wrapGAppsHook3 - ]; - - installFlags = [ "typelib-Cow" "bin-foo" "libexec-bar" ]; - }; - - # Testing cooperation with gobject-introspection setup hook, - # which should add the path to derivation’s own typelibs - # to GI_TYPELIB_PATH variable. - # The resulting GI_TYPELIB_PATH should be picked up by the wrapper. - # https://github.com/NixOS/nixpkgs/issues/85515 - typelib-self-user-has-gi-typelib-path = let - tested = typelib-self-user; - in testLib.runTest "typelib-self-user-has-gi-typelib-path" '' - ${expectSomeLineContainingYInFileXToMentionZ "${tested}/bin/foo" "GI_TYPELIB_PATH" "${typelib-self-user}/lib/girepository-1.0"} - ${expectSomeLineContainingYInFileXToMentionZ "${tested}/libexec/bar" "GI_TYPELIB_PATH" "${typelib-self-user}/lib/girepository-1.0"} - ''; - }; }; } ./wrap-gapps-hook.sh diff --git a/pkgs/build-support/setup-hooks/wrap-gapps-hook/tests/lib.nix b/pkgs/build-support/setup-hooks/wrap-gapps-hook/tests/lib.nix index 59fa9de24f9d1b..f717b1bb55de8a 100644 --- a/pkgs/build-support/setup-hooks/wrap-gapps-hook/tests/lib.nix +++ b/pkgs/build-support/setup-hooks/wrap-gapps-hook/tests/lib.nix @@ -1,16 +1,22 @@ { lib, runCommand }: rec { - runTest = name: body: runCommand name { strictDeps = true; } '' - set -o errexit - ${body} - touch $out - ''; + runTest = + name: body: + runCommand name { strictDeps = true; } '' + set -o errexit + ${body} + touch $out + ''; - skip = cond: text: - if cond then '' - echo "Skipping test $name" > /dev/stderr - '' else text; + skip = + cond: text: + if cond then + '' + echo "Skipping test $name" > /dev/stderr + '' + else + text; fail = text: '' echo "FAIL: $name: ${text}" > /dev/stderr diff --git a/pkgs/build-support/setup-systemd-units.nix b/pkgs/build-support/setup-systemd-units.nix index 4c7ee86669f587..3dd970833668bd 100644 --- a/pkgs/build-support/setup-systemd-units.nix +++ b/pkgs/build-support/setup-systemd-units.nix @@ -3,81 +3,82 @@ # # Creates a symlink at /etc/systemd-static/${namespace} for slightly # improved atomicity. -{ writeScriptBin -, bash -, coreutils -, systemd -, runCommand -, lib +{ + writeScriptBin, + bash, + coreutils, + systemd, + runCommand, + lib, }: - { units # : AttrSet String (Either Path { path : Path, wanted-by : [ String ] }) - # ^ A set whose names are unit names and values are - # either paths to the corresponding unit files or a set - # containing the path and the list of units this unit - # should be wanted-by (none by default). - # - # The names should include the unit suffix - # (e.g. ".service") - , namespace # : String - # The namespace for the unit files, to allow for - # multiple independent unit sets managed by - # `setupSystemdUnits`. - }: - let static = runCommand "systemd-static" {} - '' - mkdir -p $out - ${lib.concatStringsSep "\n" (lib.mapAttrsToList (nm: file: - "ln -sv ${file.path or file} $out/${nm}" - ) units)} - ''; - add-unit-snippet = name: file: - '' - oldUnit=$(readlink -f "$unitDir/${name}" || echo "$unitDir/${name}") - if [ -f "$oldUnit" -a "$oldUnit" != "${file.path or file}" ]; then - unitsToStop+=("${name}") - fi - ln -sf "/etc/systemd-static/${namespace}/${name}" \ - "$unitDir/.${name}.tmp" - mv -T "$unitDir/.${name}.tmp" "$unitDir/${name}" - ${lib.concatStringsSep "\n" (map (unit: - '' - mkdir -p "$unitDir/${unit}.wants" - ln -sf "../${name}" \ - "$unitDir/${unit}.wants/.${name}.tmp" - mv -T "$unitDir/${unit}.wants/.${name}.tmp" \ - "$unitDir/${unit}.wants/${name}" - '' - ) file.wanted-by or [])} - unitsToStart+=("${name}") - ''; - in - writeScriptBin "setup-systemd-units" - '' - #!${bash}/bin/bash -e - export PATH=${coreutils}/bin:${systemd}/bin +{ + units, + # : AttrSet String (Either Path { path : Path, wanted-by : [ String ] }) + # ^ A set whose names are unit names and values are + # either paths to the corresponding unit files or a set + # containing the path and the list of units this unit + # should be wanted-by (none by default). + # + # The names should include the unit suffix + # (e.g. ".service") + namespace, +# : String +# The namespace for the unit files, to allow for +# multiple independent unit sets managed by +# `setupSystemdUnits`. +}: +let + static = runCommand "systemd-static" { } '' + mkdir -p $out + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList (nm: file: "ln -sv ${file.path or file} $out/${nm}") units + )} + ''; + add-unit-snippet = name: file: '' + oldUnit=$(readlink -f "$unitDir/${name}" || echo "$unitDir/${name}") + if [ -f "$oldUnit" -a "$oldUnit" != "${file.path or file}" ]; then + unitsToStop+=("${name}") + fi + ln -sf "/etc/systemd-static/${namespace}/${name}" \ + "$unitDir/.${name}.tmp" + mv -T "$unitDir/.${name}.tmp" "$unitDir/${name}" + ${lib.concatStringsSep "\n" ( + map (unit: '' + mkdir -p "$unitDir/${unit}.wants" + ln -sf "../${name}" \ + "$unitDir/${unit}.wants/.${name}.tmp" + mv -T "$unitDir/${unit}.wants/.${name}.tmp" \ + "$unitDir/${unit}.wants/${name}" + '') file.wanted-by or [ ] + )} + unitsToStart+=("${name}") + ''; +in +writeScriptBin "setup-systemd-units" '' + #!${bash}/bin/bash -e + export PATH=${coreutils}/bin:${systemd}/bin - unitDir=/etc/systemd/system - if [ ! -w "$unitDir" ]; then - unitDir=/nix/var/nix/profiles/default/lib/systemd/system - mkdir -p "$unitDir" - fi - declare -a unitsToStop unitsToStart + unitDir=/etc/systemd/system + if [ ! -w "$unitDir" ]; then + unitDir=/nix/var/nix/profiles/default/lib/systemd/system + mkdir -p "$unitDir" + fi + declare -a unitsToStop unitsToStart - oldStatic=$(readlink -f /etc/systemd-static/${namespace} || true) - if [ "$oldStatic" != "${static}" ]; then - ${lib.concatStringsSep "\n" - (lib.mapAttrsToList add-unit-snippet units)} - if [ ''${#unitsToStop[@]} -ne 0 ]; then - echo "Stopping unit(s) ''${unitsToStop[@]}" >&2 - systemctl stop "''${unitsToStop[@]}" - fi - mkdir -p /etc/systemd-static - ln -sfT ${static} /etc/systemd-static/.${namespace}.tmp - mv -T /etc/systemd-static/.${namespace}.tmp /etc/systemd-static/${namespace} - systemctl daemon-reload - echo "Starting unit(s) ''${unitsToStart[@]}" >&2 - systemctl start "''${unitsToStart[@]}" - else - echo "Units unchanged, doing nothing" >&2 - fi - '' + oldStatic=$(readlink -f /etc/systemd-static/${namespace} || true) + if [ "$oldStatic" != "${static}" ]; then + ${lib.concatStringsSep "\n" (lib.mapAttrsToList add-unit-snippet units)} + if [ ''${#unitsToStop[@]} -ne 0 ]; then + echo "Stopping unit(s) ''${unitsToStop[@]}" >&2 + systemctl stop "''${unitsToStop[@]}" + fi + mkdir -p /etc/systemd-static + ln -sfT ${static} /etc/systemd-static/.${namespace}.tmp + mv -T /etc/systemd-static/.${namespace}.tmp /etc/systemd-static/${namespace} + systemctl daemon-reload + echo "Starting unit(s) ''${unitsToStart[@]}" >&2 + systemctl start "''${unitsToStart[@]}" + else + echo "Units unchanged, doing nothing" >&2 + fi +'' diff --git a/pkgs/build-support/source-from-head-fun.nix b/pkgs/build-support/source-from-head-fun.nix index 938df1efd18a05..51719682a5daac 100644 --- a/pkgs/build-support/source-from-head-fun.nix +++ b/pkgs/build-support/source-from-head-fun.nix @@ -7,10 +7,12 @@ to create source snapshots The documentation is availible at https://github.com/MarcWeber/nix-repository-manager/raw/master/README - */ { config }: - localTarName: publishedSrcSnapshot: - if config.sourceFromHead.useLocalRepos or false then - "${config.sourceFromHead.managedRepoDir or "/set/sourceFromHead.managedRepoDir/please"}/dist/${localTarName}" - else publishedSrcSnapshot +localTarName: publishedSrcSnapshot: +if config.sourceFromHead.useLocalRepos or false then + "${ + config.sourceFromHead.managedRepoDir or "/set/sourceFromHead.managedRepoDir/please" + }/dist/${localTarName}" +else + publishedSrcSnapshot diff --git a/pkgs/build-support/substitute/substitute-all.nix b/pkgs/build-support/substitute/substitute-all.nix index c6fc688d50e62f..7f8d55449472c5 100644 --- a/pkgs/build-support/substitute/substitute-all.nix +++ b/pkgs/build-support/substitute/substitute-all.nix @@ -6,15 +6,19 @@ let isInvalidArgName = x: builtins.match "^[a-z][a-zA-Z0-9_]*$" x == null; invalidArgs = builtins.filter isInvalidArgName (builtins.attrNames args); in - if invalidArgs == [] then - stdenvNoCC.mkDerivation ({ +if invalidArgs == [ ] then + stdenvNoCC.mkDerivation ( + { name = if args ? name then args.name else baseNameOf (toString args.src); builder = ./substitute-all.sh; inherit (args) src; preferLocalBuild = true; allowSubstitutes = false; - } // args) - else throw '' + } + // args + ) +else + throw '' Argument names for `pkgs.substituteAll` must: - start with a lower case ASCII letter - only contain ASCII letters, digits and underscores diff --git a/pkgs/build-support/substitute/substitute.nix b/pkgs/build-support/substitute/substitute.nix index e6f0835c8f8e67..ef8571e6beeb2c 100644 --- a/pkgs/build-support/substitute/substitute.nix +++ b/pkgs/build-support/substitute/substitute.nix @@ -1,30 +1,30 @@ { lib, stdenvNoCC }: /* -This is a wrapper around `substitute` in the stdenv. + This is a wrapper around `substitute` in the stdenv. -Attribute arguments: -- `name` (optional): The name of the resulting derivation -- `src`: The path to the file to substitute -- `substitutions`: The list of substitution arguments to pass - See https://nixos.org/manual/nixpkgs/stable/#fun-substitute -- `replacements`: Deprecated version of `substitutions` - that doesn't support spaces in arguments. + Attribute arguments: + - `name` (optional): The name of the resulting derivation + - `src`: The path to the file to substitute + - `substitutions`: The list of substitution arguments to pass + See https://nixos.org/manual/nixpkgs/stable/#fun-substitute + - `replacements`: Deprecated version of `substitutions` + that doesn't support spaces in arguments. -Example: + Example: -```nix -{ substitute }: -substitute { - src = ./greeting.txt; - substitutions = [ - "--replace" - "world" - "paul" - ]; -} -``` + ```nix + { substitute }: + substitute { + src = ./greeting.txt; + substitutions = [ + "--replace" + "world" + "paul" + ]; + } + ``` -See ../../test/substitute for tests + See ../../test/substitute for tests */ args: @@ -43,16 +43,19 @@ let pkgs.substitute: For "${name}", `replacements` is used, which is deprecated since it doesn't support arguments with spaces. Use `substitutions` instead: substitutions = [ ${deprecationReplacement} ];''; in -optionalDeprecationWarning -stdenvNoCC.mkDerivation ({ - inherit name; - builder = ./substitute.sh; - inherit (args) src; - preferLocalBuild = true; - allowSubstitutes = false; -} // args // lib.optionalAttrs (args ? substitutions) { - substitutions = - assert lib.assertMsg (lib.isList args.substitutions) '' - pkgs.substitute: For "${name}", `substitutions` is passed, which is expected to be a list, but it's a ${builtins.typeOf args.substitutions} instead.''; - lib.escapeShellArgs args.substitutions; -}) +optionalDeprecationWarning stdenvNoCC.mkDerivation ( + { + inherit name; + builder = ./substitute.sh; + inherit (args) src; + preferLocalBuild = true; + allowSubstitutes = false; + } + // args + // lib.optionalAttrs (args ? substitutions) { + substitutions = + assert lib.assertMsg (lib.isList args.substitutions) + ''pkgs.substitute: For "${name}", `substitutions` is passed, which is expected to be a list, but it's a ${builtins.typeOf args.substitutions} instead.''; + lib.escapeShellArgs args.substitutions; + } +) diff --git a/pkgs/build-support/testers/hasPkgConfigModules/tests.nix b/pkgs/build-support/testers/hasPkgConfigModules/tests.nix index adad9350798498..9108d62462be98 100644 --- a/pkgs/build-support/testers/hasPkgConfigModules/tests.nix +++ b/pkgs/build-support/testers/hasPkgConfigModules/tests.nix @@ -1,6 +1,13 @@ # cd nixpkgs # nix-build -A tests.testers.hasPkgConfigModules -{ lib, testers, miniz, zlib, openssl, runCommand }: +{ + lib, + testers, + miniz, + zlib, + openssl, + runCommand, +}: lib.recurseIntoAttrs { @@ -9,15 +16,17 @@ lib.recurseIntoAttrs { versionCheck = true; }; - miniz-versions-mismatch = testers.testBuildFailure (testers.hasPkgConfigModules { - package = miniz; - version = "1.2.3"; # Deliberately-incorrect version number - versionCheck = true; - }); + miniz-versions-mismatch = testers.testBuildFailure ( + testers.hasPkgConfigModules { + package = miniz; + version = "1.2.3"; # Deliberately-incorrect version number + versionCheck = true; + } + ); miniz-no-versionCheck = testers.hasPkgConfigModules { package = miniz; - version = "1.2.3"; # Deliberately-incorrect version number + version = "1.2.3"; # Deliberately-incorrect version number }; zlib-has-zlib = testers.hasPkgConfigModules { @@ -38,28 +47,31 @@ lib.recurseIntoAttrs { package = openssl; }; - zlib-does-not-have-ylib = runCommand "zlib-does-not-have-ylib" { - failed = testers.testBuildFailure ( - testers.hasPkgConfigModules { - package = zlib; - moduleNames = [ "ylib" ]; + zlib-does-not-have-ylib = + runCommand "zlib-does-not-have-ylib" + { + failed = testers.testBuildFailure ( + testers.hasPkgConfigModules { + package = zlib; + moduleNames = [ "ylib" ]; + } + ); } - ); - } '' - echo 'it logs a relevant error message' - { - grep -F "pkg-config module ylib was not found" $failed/testBuildFailure.log - } + '' + echo 'it logs a relevant error message' + { + grep -F "pkg-config module ylib was not found" $failed/testBuildFailure.log + } - echo 'it logs which pkg-config modules are available, to be helpful' - { - # grep -v: the string zlib does also occur in a store path in an earlier message, which isn't particularly helpful - grep -v "checking pkg-config module" < $failed/testBuildFailure.log \ - | grep -F "zlib" - } + echo 'it logs which pkg-config modules are available, to be helpful' + { + # grep -v: the string zlib does also occur in a store path in an earlier message, which isn't particularly helpful + grep -v "checking pkg-config module" < $failed/testBuildFailure.log \ + | grep -F "zlib" + } - # done - touch $out - ''; + # done + touch $out + ''; } diff --git a/pkgs/build-support/testers/lychee.nix b/pkgs/build-support/testers/lychee.nix index ba22ba85697321..27ccfd7a7068d0 100644 --- a/pkgs/build-support/testers/lychee.nix +++ b/pkgs/build-support/testers/lychee.nix @@ -1,16 +1,26 @@ -deps@{ formats, lib, lychee, stdenv, writeShellApplication }: +deps@{ + formats, + lib, + lychee, + stdenv, + writeShellApplication, +}: let inherit (lib) mapAttrsToList throwIf; inherit (lib.strings) hasInfix hasPrefix escapeNixString; - toURL = v: - let s = "${v}"; - in if hasPrefix builtins.storeDir s - then # lychee requires that paths on the file system are prefixed with file:// + toURL = + v: + let + s = "${v}"; + in + if hasPrefix builtins.storeDir s then # lychee requires that paths on the file system are prefixed with file:// "file://${s}" - else s; + else + s; - withCheckedName = name: + withCheckedName = + name: throwIf (hasInfix " " name) '' lycheeLinkCheck: remap patterns must not contain spaces. A space marks the end of the regex in lychee.toml. @@ -20,29 +30,32 @@ let # See https://nixos.org/manual/nixpkgs/unstable/#tester-lycheeLinkCheck # or doc/build-helpers/testers.chapter.md - lycheeLinkCheck = { - site, - remap ? { }, - lychee ? deps.lychee, - extraConfig ? { }, - }: + lycheeLinkCheck = + { + site, + remap ? { }, + lychee ? deps.lychee, + extraConfig ? { }, + }: stdenv.mkDerivation (finalAttrs: { name = "lychee-link-check"; inherit site; nativeBuildInputs = [ finalAttrs.passthru.lychee ]; - configFile = (formats.toml {}).generate "lychee.toml" finalAttrs.passthru.config; + configFile = (formats.toml { }).generate "lychee.toml" finalAttrs.passthru.config; # These can be overriden with overrideAttrs if needed. passthru = { inherit lychee remap; - config = { - include_fragments = true; - } // lib.optionalAttrs (finalAttrs.passthru.remap != { }) { - remap = - mapAttrsToList - (name: value: withCheckedName name "${name} ${toURL value}") - finalAttrs.passthru.remap; - } // extraConfig; + config = + { + include_fragments = true; + } + // lib.optionalAttrs (finalAttrs.passthru.remap != { }) { + remap = mapAttrsToList ( + name: value: withCheckedName name "${name} ${toURL value}" + ) finalAttrs.passthru.remap; + } + // extraConfig; online = writeShellApplication { name = "run-lychee-online"; runtimeInputs = [ finalAttrs.passthru.lychee ]; diff --git a/pkgs/build-support/testers/shellcheck/tester.nix b/pkgs/build-support/testers/shellcheck/tester.nix index 66f048f230959b..131a64a851574c 100644 --- a/pkgs/build-support/testers/shellcheck/tester.nix +++ b/pkgs/build-support/testers/shellcheck/tester.nix @@ -1,5 +1,9 @@ # Dependencies (callPackage) -{ lib, stdenv, shellcheck }: +{ + lib, + stdenv, + shellcheck, +}: # testers.shellcheck function # Docs: doc/build-helpers/testers.chapter.md @@ -11,9 +15,15 @@ in stdenv.mkDerivation { name = "run-shellcheck"; src = - if isPath src && pathType src == "regular" # note that for strings this would have been IFD, which we prefer to avoid - then fileset.toSource { root = dirOf src; fileset = src; } - else src; + if + isPath src && pathType src == "regular" # note that for strings this would have been IFD, which we prefer to avoid + then + fileset.toSource { + root = dirOf src; + fileset = src; + } + else + src; nativeBuildInputs = [ shellcheck ]; doCheck = true; dontConfigure = true; diff --git a/pkgs/build-support/testers/shellcheck/tests.nix b/pkgs/build-support/testers/shellcheck/tests.nix index 855aa14afead64..0128670dbe7073 100644 --- a/pkgs/build-support/testers/shellcheck/tests.nix +++ b/pkgs/build-support/testers/shellcheck/tests.nix @@ -1,38 +1,50 @@ # Run: # nix-build -A tests.testers.shellcheck -{ lib, testers, runCommand }: +{ + lib, + testers, + runCommand, +}: let inherit (lib) fileset; in lib.recurseIntoAttrs { - example-dir = runCommand "test-testers-shellcheck-example-dir" { - failure = testers.testBuildFailure - (testers.shellcheck { - src = fileset.toSource { - root = ./.; - fileset = fileset.unions [ - ./example.sh - ]; - }; - }); - } '' - log="$failure/testBuildFailure.log" - echo "Checking $log" - grep SC2068 "$log" - touch $out - ''; + example-dir = + runCommand "test-testers-shellcheck-example-dir" + { + failure = testers.testBuildFailure ( + testers.shellcheck { + src = fileset.toSource { + root = ./.; + fileset = fileset.unions [ + ./example.sh + ]; + }; + } + ); + } + '' + log="$failure/testBuildFailure.log" + echo "Checking $log" + grep SC2068 "$log" + touch $out + ''; - example-file = runCommand "test-testers-shellcheck-example-file" { - failure = testers.testBuildFailure - (testers.shellcheck { - src = ./example.sh; - }); - } '' - log="$failure/testBuildFailure.log" - echo "Checking $log" - grep SC2068 "$log" - touch $out - ''; + example-file = + runCommand "test-testers-shellcheck-example-file" + { + failure = testers.testBuildFailure ( + testers.shellcheck { + src = ./example.sh; + } + ); + } + '' + log="$failure/testBuildFailure.log" + echo "Checking $log" + grep SC2068 "$log" + touch $out + ''; } diff --git a/pkgs/build-support/testers/test-equal-derivation.nix b/pkgs/build-support/testers/test-equal-derivation.nix index 610d5f58557608..497a5cd84a57e7 100644 --- a/pkgs/build-support/testers/test-equal-derivation.nix +++ b/pkgs/build-support/testers/test-equal-derivation.nix @@ -1,13 +1,19 @@ -{ lib, runCommand, emptyFile, nix-diff }: +{ + lib, + runCommand, + emptyFile, + nix-diff, +}: assertion: a: b: let - drvA = builtins.unsafeDiscardOutputDependency a.drvPath or (throw "testEqualDerivation second argument must be a package"); - drvB = builtins.unsafeDiscardOutputDependency b.drvPath or (throw "testEqualDerivation third argument must be a package"); - name = - if a?name - then "testEqualDerivation-${a.name}" - else "testEqualDerivation"; + drvA = + builtins.unsafeDiscardOutputDependency + a.drvPath or (throw "testEqualDerivation second argument must be a package"); + drvB = + builtins.unsafeDiscardOutputDependency + b.drvPath or (throw "testEqualDerivation third argument must be a package"); + name = if a ? name then "testEqualDerivation-${a.name}" else "testEqualDerivation"; in if drvA == drvB then emptyFile @@ -16,7 +22,8 @@ else { inherit assertion drvA drvB; nativeBuildInputs = [ nix-diff ]; - } '' + } + '' echo "$assertion" echo "However, the derivations differ:" echo diff --git a/pkgs/build-support/testers/test/default.nix b/pkgs/build-support/testers/test/default.nix index cc46e3cf4b71ed..a198cc6774ec6d 100644 --- a/pkgs/build-support/testers/test/default.nix +++ b/pkgs/build-support/testers/test/default.nix @@ -1,8 +1,19 @@ -{ testers, lib, pkgs, hello, runCommand, emptyFile, emptyDirectory, ... }: +{ + testers, + lib, + pkgs, + hello, + runCommand, + emptyFile, + emptyDirectory, + ... +}: let - pkgs-with-overlay = pkgs.extend(final: prev: { - proof-of-overlay-hello = prev.hello; - }); + pkgs-with-overlay = pkgs.extend ( + final: prev: { + proof-of-overlay-hello = prev.hello; + } + ); dummyVersioning = { revision = "test"; @@ -41,86 +52,121 @@ lib.recurseIntoAttrs { }; }; - runNixOSTest-example = pkgs-with-overlay.testers.runNixOSTest ({ lib, ... }: { - name = "runNixOSTest-test"; - nodes.machine = { pkgs, ... }: { - system.nixos = dummyVersioning; - environment.systemPackages = [ pkgs.proof-of-overlay-hello pkgs.figlet ]; - }; - testScript = '' - machine.succeed("hello | figlet >/dev/console") - ''; - }); + runNixOSTest-example = pkgs-with-overlay.testers.runNixOSTest ( + { lib, ... }: + { + name = "runNixOSTest-test"; + nodes.machine = + { pkgs, ... }: + { + system.nixos = dummyVersioning; + environment.systemPackages = [ + pkgs.proof-of-overlay-hello + pkgs.figlet + ]; + }; + testScript = '' + machine.succeed("hello | figlet >/dev/console") + ''; + } + ); # Check that the wiring of nixosTest is correct. # Correct operation of the NixOS test driver should be asserted elsewhere. - nixosTest-example = pkgs-with-overlay.testers.nixosTest ({ lib, ... }: { - name = "nixosTest-test"; - nodes.machine = { pkgs, ... }: { - system.nixos = dummyVersioning; - environment.systemPackages = [ pkgs.proof-of-overlay-hello pkgs.figlet ]; - }; - testScript = '' - machine.succeed("hello | figlet >/dev/console") - ''; - }); + nixosTest-example = pkgs-with-overlay.testers.nixosTest ( + { lib, ... }: + { + name = "nixosTest-test"; + nodes.machine = + { pkgs, ... }: + { + system.nixos = dummyVersioning; + environment.systemPackages = [ + pkgs.proof-of-overlay-hello + pkgs.figlet + ]; + }; + testScript = '' + machine.succeed("hello | figlet >/dev/console") + ''; + } + ); testBuildFailure = lib.recurseIntoAttrs { - happy = runCommand "testBuildFailure-happy" { - failed = testers.testBuildFailure (runCommand "fail" {} '' - echo ok-ish >$out + happy = + runCommand "testBuildFailure-happy" + { + failed = testers.testBuildFailure ( + runCommand "fail" { } '' + echo ok-ish >$out - echo failing though - echo also stderr 1>&2 - echo 'line\nwith-\bbackslashes' - printf "incomplete line - no newline" + echo failing though + echo also stderr 1>&2 + echo 'line\nwith-\bbackslashes' + printf "incomplete line - no newline" - exit 3 - ''); - } '' - grep -F 'ok-ish' $failed/result + exit 3 + '' + ); + } + '' + grep -F 'ok-ish' $failed/result - grep -F 'failing though' $failed/testBuildFailure.log - grep -F 'also stderr' $failed/testBuildFailure.log - grep -F 'line\nwith-\bbackslashes' $failed/testBuildFailure.log - grep -F 'incomplete line - no newline' $failed/testBuildFailure.log + grep -F 'failing though' $failed/testBuildFailure.log + grep -F 'also stderr' $failed/testBuildFailure.log + grep -F 'line\nwith-\bbackslashes' $failed/testBuildFailure.log + grep -F 'incomplete line - no newline' $failed/testBuildFailure.log - [[ 3 = $(cat $failed/testBuildFailure.exit) ]] + [[ 3 = $(cat $failed/testBuildFailure.exit) ]] - touch $out - ''; + touch $out + ''; - helloDoesNotFail = runCommand "testBuildFailure-helloDoesNotFail" { - failed = testers.testBuildFailure (testers.testBuildFailure hello); + helloDoesNotFail = + runCommand "testBuildFailure-helloDoesNotFail" + { + failed = testers.testBuildFailure (testers.testBuildFailure hello); - # Add hello itself as a prerequisite, so we don't try to run this test if - # there's an actual failure in hello. - inherit hello; - } '' - echo "Checking $failed/testBuildFailure.log" - grep -F 'testBuildFailure: The builder did not fail, but a failure was expected' $failed/testBuildFailure.log >/dev/null - [[ 1 = $(cat $failed/testBuildFailure.exit) ]] - touch $out - echo 'All good.' - ''; + # Add hello itself as a prerequisite, so we don't try to run this test if + # there's an actual failure in hello. + inherit hello; + } + '' + echo "Checking $failed/testBuildFailure.log" + grep -F 'testBuildFailure: The builder did not fail, but a failure was expected' $failed/testBuildFailure.log >/dev/null + [[ 1 = $(cat $failed/testBuildFailure.exit) ]] + touch $out + echo 'All good.' + ''; - multiOutput = runCommand "testBuildFailure-multiOutput" { - failed = testers.testBuildFailure (runCommand "fail" { - # dev will be the default output - outputs = ["dev" "doc" "out"]; - } '' - echo i am failing - exit 1 - ''); - } '' - grep -F 'i am failing' $failed/testBuildFailure.log >/dev/null - [[ 1 = $(cat $failed/testBuildFailure.exit) ]] + multiOutput = + runCommand "testBuildFailure-multiOutput" + { + failed = testers.testBuildFailure ( + runCommand "fail" + { + # dev will be the default output + outputs = [ + "dev" + "doc" + "out" + ]; + } + '' + echo i am failing + exit 1 + '' + ); + } + '' + grep -F 'i am failing' $failed/testBuildFailure.log >/dev/null + [[ 1 = $(cat $failed/testBuildFailure.exit) ]] - # Checking our note that dev is the default output - echo $failed/_ | grep -- '-dev/_' >/dev/null - echo 'All good.' - touch $out - ''; + # Checking our note that dev is the default output + echo $failed/_ | grep -- '-dev/_' >/dev/null + echo 'All good.' + touch $out + ''; }; testEqualContents = lib.recurseIntoAttrs { diff --git a/pkgs/build-support/testers/testMetaPkgConfig/tester.nix b/pkgs/build-support/testers/testMetaPkgConfig/tester.nix index 7892a29e4c28de..1dd526385738f6 100644 --- a/pkgs/build-support/testers/testMetaPkgConfig/tester.nix +++ b/pkgs/build-support/testers/testMetaPkgConfig/tester.nix @@ -1,12 +1,18 @@ -{ lib, runCommand, testers }: +{ + lib, + runCommand, + testers, +}: package: -runCommand "check-meta-pkg-config-modules-for-${package.name}" { - meta = { - description = "Test whether ${package.name} exposes all pkg-config modules ${toString package.meta.pkgConfigModules}"; - }; - dependsOn = testers.hasPkgConfigModules { inherit package; }; -} '' - echo "found all of ${toString package.meta.pkgConfigModules}" > "$out" -'' +runCommand "check-meta-pkg-config-modules-for-${package.name}" + { + meta = { + description = "Test whether ${package.name} exposes all pkg-config modules ${toString package.meta.pkgConfigModules}"; + }; + dependsOn = testers.hasPkgConfigModules { inherit package; }; + } + '' + echo "found all of ${toString package.meta.pkgConfigModules}" > "$out" + '' diff --git a/pkgs/build-support/trivial-builders/test-overriding.nix b/pkgs/build-support/trivial-builders/test-overriding.nix index a16bbbee1b1b1b..33823aa0cd2552 100644 --- a/pkgs/build-support/trivial-builders/test-overriding.nix +++ b/pkgs/build-support/trivial-builders/test-overriding.nix @@ -4,14 +4,15 @@ # to disable extglob in `writeShellScript`. # # Run using `nix-build -A tests.trivial-builders.overriding`. -{ lib -, stdenv -, runtimeShell -, runCommand -, callPackage -, writeShellScript -, writeTextFile -, writeShellScriptBin +{ + lib, + stdenv, + runtimeShell, + runCommand, + callPackage, + writeShellScript, + writeTextFile, + writeShellScriptBin, }: let @@ -22,16 +23,15 @@ let rm success ''; - simpleCase = case: - writeShellScript "test-trivial-overriding-${case}" extglobScript; + simpleCase = case: writeShellScript "test-trivial-overriding-${case}" extglobScript; - callPackageCase = case: callPackage ( - { writeShellScript }: - writeShellScript "test-trivial-callpackage-overriding-${case}" extglobScript - ) { }; + callPackageCase = + case: + callPackage ( + { writeShellScript }: writeShellScript "test-trivial-callpackage-overriding-${case}" extglobScript + ) { }; - binCase = case: - writeShellScriptBin "test-trivial-overriding-bin-${case}" extglobScript; + binCase = case: writeShellScriptBin "test-trivial-overriding-bin-${case}" extglobScript; # building this derivation would fail without overriding textFileCase = writeTextFile { @@ -44,17 +44,21 @@ let executable = true; }; - disallowExtglob = x: x.overrideAttrs (_: { + disallowExtglob = + x: + x.overrideAttrs (_: { checkPhase = '' ${stdenv.shell} -n "$target" ''; }); - # Run old checkPhase, but only succeed if it fails. - # This HACK is required because we can't introspect build failures - # in nix: With `assertFail` we want to make sure that the default - # `checkPhase` would fail if extglob was used in the script. - assertFail = x: x.overrideAttrs (old: { + # Run old checkPhase, but only succeed if it fails. + # This HACK is required because we can't introspect build failures + # in nix: With `assertFail` we want to make sure that the default + # `checkPhase` would fail if extglob was used in the script. + assertFail = + x: + x.overrideAttrs (old: { checkPhase = '' if ${old.checkPhase} @@ -62,10 +66,18 @@ let ''; }); - mkCase = case: outcome: isBin: + mkCase = + case: outcome: isBin: let - drv = lib.pipe outcome ([ case ] ++ lib.optionals (outcome == "fail") [ disallowExtglob assertFail ]); - in if isBin then "${drv}/bin/${drv.name}" else drv; + drv = lib.pipe outcome ( + [ case ] + ++ lib.optionals (outcome == "fail") [ + disallowExtglob + assertFail + ] + ); + in + if isBin then "${drv}/bin/${drv.name}" else drv; writeTextOverrides = { # Make sure extglob works by default @@ -89,10 +101,12 @@ let # run its `checkPhase` which is our main interest. Additionally # it executes the script and thus makes sure that extglob also # works at run time. - runTest = script: + runTest = + script: let name = script.name or (builtins.baseNameOf script); - in writeShellScript "run-${name}" '' + in + writeShellScript "run-${name}" '' if [ "$(${script})" != "success" ]; then echo "Failed in ${name}" exit 1 @@ -100,11 +114,13 @@ let ''; in -runCommand "test-writeShellScript-overriding" { - passthru = { inherit writeTextOverrides; }; -} '' - ${lib.concatMapStrings (test: '' +runCommand "test-writeShellScript-overriding" + { + passthru = { inherit writeTextOverrides; }; + } + '' + ${lib.concatMapStrings (test: '' ${runTest test} '') (lib.attrValues writeTextOverrides)} - touch "$out" -'' + touch "$out" + '' diff --git a/pkgs/build-support/trivial-builders/test/concat-test.nix b/pkgs/build-support/trivial-builders/test/concat-test.nix index 8f7e7a4200327a..583d0910f4bc94 100644 --- a/pkgs/build-support/trivial-builders/test/concat-test.nix +++ b/pkgs/build-support/trivial-builders/test/concat-test.nix @@ -1,12 +1,21 @@ -{ runCommand, concatText, writeText, hello, emptyFile }: +{ + runCommand, + concatText, + writeText, + hello, + emptyFile, +}: let stri = writeText "pathToTest"; txt1 = stri "abc"; txt2 = stri (builtins.toString hello); - res = concatText "textToTest" [ txt1 txt2 ]; + res = concatText "textToTest" [ + txt1 + txt2 + ]; in runCommand "test-concatPaths" { } '' diff -U3 <(cat ${txt1} ${txt2}) ${res} - diff -U3 ${concatText "void" []} ${emptyFile} + diff -U3 ${concatText "void" [ ]} ${emptyFile} touch $out '' diff --git a/pkgs/build-support/trivial-builders/test/link-farm.nix b/pkgs/build-support/trivial-builders/test/link-farm.nix index 1ebfc707632f31..f74aaa6667fd78 100644 --- a/pkgs/build-support/trivial-builders/test/link-farm.nix +++ b/pkgs/build-support/trivial-builders/test/link-farm.nix @@ -1,4 +1,9 @@ -{ linkFarm, hello, writeTextFile, runCommand }: +{ + linkFarm, + hello, + writeTextFile, + runCommand, +}: let foo = writeTextFile { name = "foo"; @@ -6,14 +11,29 @@ let }; linkFarmFromList = linkFarm "linkFarmFromList" [ - { name = "foo"; path = foo; } - { name = "hello"; path = hello; } + { + name = "foo"; + path = foo; + } + { + name = "hello"; + path = hello; + } ]; linkFarmWithRepeats = linkFarm "linkFarmWithRepeats" [ - { name = "foo"; path = foo; } - { name = "hello"; path = hello; } - { name = "foo"; path = hello; } + { + name = "foo"; + path = foo; + } + { + name = "hello"; + path = hello; + } + { + name = "foo"; + path = hello; + } ]; linkFarmFromAttrs = linkFarm "linkFarmFromAttrs" { diff --git a/pkgs/build-support/trivial-builders/test/references/default.nix b/pkgs/build-support/trivial-builders/test/references/default.nix index 85df57ea210c23..bc9f8913e99afc 100644 --- a/pkgs/build-support/trivial-builders/test/references/default.nix +++ b/pkgs/build-support/trivial-builders/test/references/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenvNoCC -, testers -, callPackage -, writeText +{ + lib, + stdenvNoCC, + testers, + callPackage, + writeText, # nativeBuildInputs -, shellcheck-minimal + shellcheck-minimal, # Samples -, samples ? cleanSamples (callPackage ./samples.nix { }) + samples ? cleanSamples (callPackage ./samples.nix { }), # Filter out the non-string-like attributes such as .override added by # callPackage. -, cleanSamples ? lib.filterAttrs (n: lib.isStringLike) + cleanSamples ? lib.filterAttrs (n: lib.isStringLike), # Test targets -, writeDirectReferencesToFile -, writeClosure + writeDirectReferencesToFile, + writeClosure, }: # -------------------------------------------------------------------------- # @@ -43,8 +44,11 @@ let # Map each attribute to an element specification of Bash associative arrary # and concatenate them with white spaces, to be used to define a # one-line Bash associative array. - samplesToString = attrs: - lib.concatMapStringsSep " " (name: "[${name}]=${lib.escapeShellArg "${attrs.${name}}"}") (builtins.attrNames attrs); + samplesToString = + attrs: + lib.concatMapStringsSep " " (name: "[${name}]=${lib.escapeShellArg "${attrs.${name}}"}") ( + builtins.attrNames attrs + ); closures = lib.mapAttrs (n: v: writeClosure [ v ]) samples; directReferences = lib.mapAttrs (n: v: writeDirectReferencesToFile v) samples; @@ -93,43 +97,51 @@ let }; }); in -testers.runNixOSTest ({ config, lib, ... }: -let - # Use the testScriptBin from guest pkgs. - # The attribute path to access the guest version of testScriptBin is - # tests.trivial-builders.references.config.node.pkgs.tests.trivial-builders.references.testScriptBin - # which is why passthru.guestTestScriptBin is provided. - guestTestScriptBin = config.node.pkgs.tests.trivial-builders.references.testScriptBin; -in -{ - name = "nixpkgs-trivial-builders-references"; - nodes.machine = { config, lib, pkgs, ... }: { - virtualisation.writableStore = true; +testers.runNixOSTest ( + { config, lib, ... }: + let + # Use the testScriptBin from guest pkgs. + # The attribute path to access the guest version of testScriptBin is + # tests.trivial-builders.references.config.node.pkgs.tests.trivial-builders.references.testScriptBin + # which is why passthru.guestTestScriptBin is provided. + guestTestScriptBin = config.node.pkgs.tests.trivial-builders.references.testScriptBin; + in + { + name = "nixpkgs-trivial-builders-references"; + nodes.machine = + { + config, + lib, + pkgs, + ... + }: + { + virtualisation.writableStore = true; - # Test runs without network, so we don't substitute and prepare our deps - nix.settings.substituters = lib.mkForce [ ]; - system.extraDependencies = [ guestTestScriptBin ]; - }; - testScript = - '' + # Test runs without network, so we don't substitute and prepare our deps + nix.settings.substituters = lib.mkForce [ ]; + system.extraDependencies = [ guestTestScriptBin ]; + }; + testScript = '' machine.succeed(""" ${lib.getExe guestTestScriptBin} 2>/dev/console """) ''; - passthru = { - inherit - collectiveClosure - directReferences - closures - samples - testScriptBin - ; - inherit guestTestScriptBin; - }; - meta = { - maintainers = with lib.maintainers; [ - roberth - ShamrockLee - ]; - }; -}) + passthru = { + inherit + collectiveClosure + directReferences + closures + samples + testScriptBin + ; + inherit guestTestScriptBin; + }; + meta = { + maintainers = with lib.maintainers; [ + roberth + ShamrockLee + ]; + }; + } +) diff --git a/pkgs/build-support/trivial-builders/test/references/samples.nix b/pkgs/build-support/trivial-builders/test/references/samples.nix index 5bafdcd8e7d072..c9bccdedee7025 100644 --- a/pkgs/build-support/trivial-builders/test/references/samples.nix +++ b/pkgs/build-support/trivial-builders/test/references/samples.nix @@ -1,11 +1,12 @@ -{ lib -, runCommand -, writeText -, emptyFile -, emptyDirectory -, figlet -, hello -, zlib +{ + lib, + runCommand, + writeText, + emptyFile, + emptyDirectory, + figlet, + hello, + zlib, }: { inherit diff --git a/pkgs/build-support/trivial-builders/test/write-shell-script.nix b/pkgs/build-support/trivial-builders/test/write-shell-script.nix index a5c9f1fae42f6f..2e20588fad6b8c 100644 --- a/pkgs/build-support/trivial-builders/test/write-shell-script.nix +++ b/pkgs/build-support/trivial-builders/test/write-shell-script.nix @@ -1,14 +1,19 @@ -{ lib, writeShellScript }: let +{ lib, writeShellScript }: +let output = "hello"; -in (writeShellScript "test-script" '' +in +(writeShellScript "test-script" '' echo ${lib.escapeShellArg output} -'').overrideAttrs (old: { - checkPhase = old.checkPhase or "" + '' - expected=${lib.escapeShellArg output} - got=$("$target") - if [[ "$got" != "$expected" ]]; then - echo "wrong output: expected $expected, got $got" - exit 1 - fi - ''; -}) +'').overrideAttrs + (old: { + checkPhase = + old.checkPhase or "" + + '' + expected=${lib.escapeShellArg output} + got=$("$target") + if [[ "$got" != "$expected" ]]; then + echo "wrong output: expected $expected, got $got" + exit 1 + fi + ''; + }) diff --git a/pkgs/build-support/trivial-builders/test/write-text-file.nix b/pkgs/build-support/trivial-builders/test/write-text-file.nix index 2e6685c1980bf7..f9d508de748b5d 100644 --- a/pkgs/build-support/trivial-builders/test/write-text-file.nix +++ b/pkgs/build-support/trivial-builders/test/write-text-file.nix @@ -9,7 +9,12 @@ cd nixpkgs nix-build -A tests.trivial-builders.writeTextFile.foo */ -{ lib, runCommand, runtimeShell, writeTextFile }: +{ + lib, + runCommand, + runtimeShell, + writeTextFile, +}: let veryWeirdName = ''here's a name with some "bad" characters, like spaces and quotes''; in @@ -27,15 +32,15 @@ lib.recurseIntoAttrs { ''; }; in - assert pkg.meta.mainProgram == "foo"; - assert baseNameOf (lib.getExe pkg) == "foo"; - assert pkg.name == "bar"; - runCommand "test-writeTextFile-different-exe-name" {} '' - PATH="${lib.makeBinPath [ pkg ]}:$PATH" - x=$(foo) - [[ "$x" == hi ]] - touch $out - ''; + assert pkg.meta.mainProgram == "foo"; + assert baseNameOf (lib.getExe pkg) == "foo"; + assert pkg.name == "bar"; + runCommand "test-writeTextFile-different-exe-name" { } '' + PATH="${lib.makeBinPath [ pkg ]}:$PATH" + x=$(foo) + [[ "$x" == hi ]] + touch $out + ''; weird-name = writeTextFile { name = "weird-names"; diff --git a/pkgs/build-support/trivial-builders/test/writeCBin.nix b/pkgs/build-support/trivial-builders/test/writeCBin.nix index 56cab45b380160..9d6dc3433f198f 100644 --- a/pkgs/build-support/trivial-builders/test/writeCBin.nix +++ b/pkgs/build-support/trivial-builders/test/writeCBin.nix @@ -5,7 +5,11 @@ nix-build -A tests.trivial-builders.writeCBin */ -{ lib, writeCBin, runCommand }: +{ + lib, + writeCBin, + runCommand, +}: let output = "hello"; pkg = writeCBin "test-script" '' @@ -16,28 +20,27 @@ let } ''; in - assert pkg.meta.mainProgram == "test-script"; - runCommand "test-writeCBin" { } '' - - echo Testing with getExe... - - target=${lib.getExe pkg} - expected=${lib.escapeShellArg output} - got=$("$target") - if [[ "$got" != "$expected" ]]; then - echo "wrong output: expected $expected, got $got" - exit 1 - fi - - echo Testing with makeBinPath... - - PATH="${lib.makeBinPath [ pkg ]}:$PATH" - got=$(test-script) - if [[ "$got" != "$expected" ]]; then - echo "wrong output: expected $expected, got $got" - exit 1 - fi - - touch $out - '' - +assert pkg.meta.mainProgram == "test-script"; +runCommand "test-writeCBin" { } '' + + echo Testing with getExe... + + target=${lib.getExe pkg} + expected=${lib.escapeShellArg output} + got=$("$target") + if [[ "$got" != "$expected" ]]; then + echo "wrong output: expected $expected, got $got" + exit 1 + fi + + echo Testing with makeBinPath... + + PATH="${lib.makeBinPath [ pkg ]}:$PATH" + got=$(test-script) + if [[ "$got" != "$expected" ]]; then + echo "wrong output: expected $expected, got $got" + exit 1 + fi + + touch $out +'' diff --git a/pkgs/build-support/trivial-builders/test/writeClosure-union.nix b/pkgs/build-support/trivial-builders/test/writeClosure-union.nix index 92a2bf9f0988d1..bdaefa8e205084 100644 --- a/pkgs/build-support/trivial-builders/test/writeClosure-union.nix +++ b/pkgs/build-support/trivial-builders/test/writeClosure-union.nix @@ -1,23 +1,26 @@ -{ lib -, runCommandLocal +{ + lib, + runCommandLocal, # Test targets -, writeClosure -, samples + writeClosure, + samples, }: -runCommandLocal "test-trivial-builders-writeClosure-union" { - __structuredAttrs = true; - closures = lib.mapAttrs (n: v: writeClosure [ v ]) samples; - collectiveClosure = writeClosure (lib.attrValues samples); - inherit samples; - meta.maintainers = with lib.maintainers; [ - ShamrockLee - ]; -} '' - set -eu -o pipefail - echo >&2 Testing mixed closures... - echo >&2 Checking all samples "(''${samples[*]})" "$collectiveClosure" - diff -U3 \ - <(sort <"$collectiveClosure") \ - <(cat "''${closures[@]}" | sort | uniq) - touch "$out" -'' +runCommandLocal "test-trivial-builders-writeClosure-union" + { + __structuredAttrs = true; + closures = lib.mapAttrs (n: v: writeClosure [ v ]) samples; + collectiveClosure = writeClosure (lib.attrValues samples); + inherit samples; + meta.maintainers = with lib.maintainers; [ + ShamrockLee + ]; + } + '' + set -eu -o pipefail + echo >&2 Testing mixed closures... + echo >&2 Checking all samples "(''${samples[*]})" "$collectiveClosure" + diff -U3 \ + <(sort <"$collectiveClosure") \ + <(cat "''${closures[@]}" | sort | uniq) + touch "$out" + '' diff --git a/pkgs/build-support/trivial-builders/test/writeScriptBin.nix b/pkgs/build-support/trivial-builders/test/writeScriptBin.nix index 1487443130dab9..ed1263d9dc8c34 100644 --- a/pkgs/build-support/trivial-builders/test/writeScriptBin.nix +++ b/pkgs/build-support/trivial-builders/test/writeScriptBin.nix @@ -5,35 +5,38 @@ nix-build -A tests.trivial-builders.writeShellScriptBin */ -{ lib, writeScriptBin, runCommand }: +{ + lib, + writeScriptBin, + runCommand, +}: let output = "hello"; pkg = writeScriptBin "test-script" '' echo ${lib.escapeShellArg output} ''; in - assert pkg.meta.mainProgram == "test-script"; - runCommand "test-writeScriptBin" { } '' - - echo Testing with getExe... - - target=${lib.getExe pkg} - expected=${lib.escapeShellArg output} - got=$("$target") - if [[ "$got" != "$expected" ]]; then - echo "wrong output: expected $expected, got $got" - exit 1 - fi - - echo Testing with makeBinPath... - - PATH="${lib.makeBinPath [ pkg ]}:$PATH" - got=$(test-script) - if [[ "$got" != "$expected" ]]; then - echo "wrong output: expected $expected, got $got" - exit 1 - fi - - touch $out - '' - +assert pkg.meta.mainProgram == "test-script"; +runCommand "test-writeScriptBin" { } '' + + echo Testing with getExe... + + target=${lib.getExe pkg} + expected=${lib.escapeShellArg output} + got=$("$target") + if [[ "$got" != "$expected" ]]; then + echo "wrong output: expected $expected, got $got" + exit 1 + fi + + echo Testing with makeBinPath... + + PATH="${lib.makeBinPath [ pkg ]}:$PATH" + got=$(test-script) + if [[ "$got" != "$expected" ]]; then + echo "wrong output: expected $expected, got $got" + exit 1 + fi + + touch $out +'' diff --git a/pkgs/build-support/trivial-builders/test/writeShellApplication.nix b/pkgs/build-support/trivial-builders/test/writeShellApplication.nix index c50f5a4d283f9e..fa0750ace95071 100644 --- a/pkgs/build-support/trivial-builders/test/writeShellApplication.nix +++ b/pkgs/build-support/trivial-builders/test/writeShellApplication.nix @@ -1,17 +1,19 @@ # Run with: # nix-build -A tests.trivial-builders.writeShellApplication -{ writeShellApplication -, writeTextFile -, runCommand -, lib -, linkFarm -, diffutils -, hello +{ + writeShellApplication, + writeTextFile, + runCommand, + lib, + linkFarm, + diffutils, + hello, }: let - checkShellApplication = args@{name, expected, ...}: + checkShellApplication = + args@{ name, expected, ... }: let - writeShellApplicationArgs = builtins.removeAttrs args ["expected"]; + writeShellApplicationArgs = builtins.removeAttrs args [ "expected" ]; script = writeShellApplication writeShellApplicationArgs; executable = lib.getExe script; expected' = writeTextFile { @@ -43,65 +45,65 @@ linkFarm "writeShellApplication-tests" { assert script.meta.description == "A test for the `writeShellApplication` `meta` argument."; script; - test-runtime-inputs = - checkShellApplication { - name = "test-runtime-inputs"; - text = '' - hello - ''; - runtimeInputs = [ hello ]; - expected = "Hello, world!\n"; - }; + test-runtime-inputs = checkShellApplication { + name = "test-runtime-inputs"; + text = '' + hello + ''; + runtimeInputs = [ hello ]; + expected = "Hello, world!\n"; + }; - test-runtime-env = - checkShellApplication { - name = "test-runtime-env"; - runtimeEnv = { - MY_COOL_ENV_VAR = "my-cool-env-value"; - MY_OTHER_COOL_ENV_VAR = "my-other-cool-env-value"; - # Check that we can serialize a bunch of different types: - BOOL = true; - INT = 1; - LIST = [1 2 3]; - MAP = { - a = "a"; - b = "b"; - }; + test-runtime-env = checkShellApplication { + name = "test-runtime-env"; + runtimeEnv = { + MY_COOL_ENV_VAR = "my-cool-env-value"; + MY_OTHER_COOL_ENV_VAR = "my-other-cool-env-value"; + # Check that we can serialize a bunch of different types: + BOOL = true; + INT = 1; + LIST = [ + 1 + 2 + 3 + ]; + MAP = { + a = "a"; + b = "b"; }; - text = '' - echo "$MY_COOL_ENV_VAR" - echo "$MY_OTHER_COOL_ENV_VAR" - ''; - expected = '' - my-cool-env-value - my-other-cool-env-value - ''; }; + text = '' + echo "$MY_COOL_ENV_VAR" + echo "$MY_OTHER_COOL_ENV_VAR" + ''; + expected = '' + my-cool-env-value + my-other-cool-env-value + ''; + }; - test-check-phase = - checkShellApplication { - name = "test-check-phase"; - text = ""; - checkPhase = '' - echo "echo -n hello" > $target - ''; - expected = "hello"; - }; + test-check-phase = checkShellApplication { + name = "test-check-phase"; + text = ""; + checkPhase = '' + echo "echo -n hello" > $target + ''; + expected = "hello"; + }; - test-argument-forwarding = - checkShellApplication { - name = "test-argument-forwarding"; - text = ""; - derivationArgs.MY_BUILD_TIME_VARIABLE = "puppy"; - derivationArgs.postCheck = '' - if [[ "$MY_BUILD_TIME_VARIABLE" != puppy ]]; then - echo "\$MY_BUILD_TIME_VARIABLE is not set to 'puppy'!" - exit 1 - fi - ''; - meta.description = "A test checking that `writeShellApplication` forwards extra arguments to `stdenv.mkDerivation`."; - expected = ""; - }; + test-argument-forwarding = checkShellApplication { + name = "test-argument-forwarding"; + text = ""; + derivationArgs.MY_BUILD_TIME_VARIABLE = "puppy"; + derivationArgs.postCheck = '' + if [[ "$MY_BUILD_TIME_VARIABLE" != puppy ]]; then + echo "\$MY_BUILD_TIME_VARIABLE is not set to 'puppy'!" + exit 1 + fi + ''; + meta.description = "A test checking that `writeShellApplication` forwards extra arguments to `stdenv.mkDerivation`."; + expected = ""; + }; test-exclude-shell-checks = writeShellApplication { name = "test-exclude-shell-checks"; @@ -122,7 +124,10 @@ linkFarm "writeShellApplication-tests" { true ''; # Don't use `pipefail`: - bashOptions = ["errexit" "nounset"]; + bashOptions = [ + "errexit" + "nounset" + ]; expected = ""; }; @@ -132,7 +137,7 @@ linkFarm "writeShellApplication-tests" { echo -n "$someUndefinedVariable" ''; # Don't use `nounset`: - bashOptions = []; + bashOptions = [ ]; # Don't warn about the undefined variable at build time: excludeShellChecks = [ "SC2154" ]; expected = ""; diff --git a/pkgs/build-support/trivial-builders/test/writeShellScriptBin.nix b/pkgs/build-support/trivial-builders/test/writeShellScriptBin.nix index e93410e25bcb88..94d09473ee9f80 100644 --- a/pkgs/build-support/trivial-builders/test/writeShellScriptBin.nix +++ b/pkgs/build-support/trivial-builders/test/writeShellScriptBin.nix @@ -5,35 +5,38 @@ nix-build -A tests.trivial-builders.writeShellScriptBin */ -{ lib, writeShellScriptBin, runCommand }: +{ + lib, + writeShellScriptBin, + runCommand, +}: let output = "hello"; pkg = writeShellScriptBin "test-script" '' echo ${lib.escapeShellArg output} ''; in - assert pkg.meta.mainProgram == "test-script"; - runCommand "test-writeShellScriptBin" { } '' - - echo Testing with getExe... - - target=${lib.getExe pkg} - expected=${lib.escapeShellArg output} - got=$("$target") - if [[ "$got" != "$expected" ]]; then - echo "wrong output: expected $expected, got $got" - exit 1 - fi - - echo Testing with makeBinPath... - - PATH="${lib.makeBinPath [ pkg ]}:$PATH" - got=$(test-script) - if [[ "$got" != "$expected" ]]; then - echo "wrong output: expected $expected, got $got" - exit 1 - fi - - touch $out - '' - +assert pkg.meta.mainProgram == "test-script"; +runCommand "test-writeShellScriptBin" { } '' + + echo Testing with getExe... + + target=${lib.getExe pkg} + expected=${lib.escapeShellArg output} + got=$("$target") + if [[ "$got" != "$expected" ]]; then + echo "wrong output: expected $expected, got $got" + exit 1 + fi + + echo Testing with makeBinPath... + + PATH="${lib.makeBinPath [ pkg ]}:$PATH" + got=$(test-script) + if [[ "$got" != "$expected" ]]; then + echo "wrong output: expected $expected, got $got" + exit 1 + fi + + touch $out +'' diff --git a/pkgs/build-support/trivial-builders/test/writeStringReferencesToFile.nix b/pkgs/build-support/trivial-builders/test/writeStringReferencesToFile.nix index dedd7e183a1780..c4a743b5c48a4e 100644 --- a/pkgs/build-support/trivial-builders/test/writeStringReferencesToFile.nix +++ b/pkgs/build-support/trivial-builders/test/writeStringReferencesToFile.nix @@ -1,15 +1,24 @@ -{ callPackage, lib, pkgs, runCommand, samples, writeText, writeStringReferencesToFile }: +{ + callPackage, + lib, + pkgs, + runCommand, + samples, + writeText, + writeStringReferencesToFile, +}: let samplePaths = lib.unique (lib.attrValues samples); stri = x: "${x}"; - sampleText = writeText "sample-text" (lib.concatStringsSep "\n" (lib.unique (map stri samplePaths))); - stringReferencesText = - writeStringReferencesToFile - ((lib.concatMapStringsSep "fillertext" - stri - (lib.attrValues samples)) + '' - STORE=${builtins.storeDir};\nsystemctl start bar-foo.service - ''); + sampleText = writeText "sample-text" ( + lib.concatStringsSep "\n" (lib.unique (map stri samplePaths)) + ); + stringReferencesText = writeStringReferencesToFile ( + (lib.concatMapStringsSep "fillertext" stri (lib.attrValues samples)) + + '' + STORE=${builtins.storeDir};\nsystemctl start bar-foo.service + '' + ); in runCommand "test-writeStringReferencesToFile" { } '' diff -U3 <(sort ${stringReferencesText}) <(sort ${sampleText}) diff --git a/pkgs/build-support/vm/test.nix b/pkgs/build-support/vm/test.nix index 620bf232a45c75..313ca50e55f9c5 100644 --- a/pkgs/build-support/vm/test.nix +++ b/pkgs/build-support/vm/test.nix @@ -19,21 +19,21 @@ in { - # Run the PatchELF derivation in a VM. buildPatchelfInVM = runInLinuxVM patchelf; buildHelloInVM = runInLinuxVM hello; buildStructuredAttrsHelloInVM = runInLinuxVM (hello.overrideAttrs { __structuredAttrs = true; }); - buildPcmanrmInVM = runInLinuxVM (pcmanfm.overrideAttrs (old: { - # goes out-of-memory with many cores - enableParallelBuilding = false; - })); + buildPcmanrmInVM = runInLinuxVM ( + pcmanfm.overrideAttrs (old: { + # goes out-of-memory with many cores + enableParallelBuilding = false; + }) + ); testRPMImage = makeImageTestScript diskImages.fedora27x86_64; - buildPatchelfRPM = buildRPM { name = "patchelf-rpm"; src = patchelf.src; @@ -41,19 +41,19 @@ in diskImageFormat = "qcow2"; }; - testUbuntuImage = makeImageTestScript diskImages.ubuntu1804i386; - - buildInDebian = runInLinuxImage (stdenv.mkDerivation { - name = "deb-compile"; - src = patchelf.src; - diskImage = diskImages.ubuntu1804i386; - diskImageFormat = "qcow2"; - memSize = 512; - postHook = '' - dpkg-query --list - ''; - }); + buildInDebian = runInLinuxImage ( + stdenv.mkDerivation { + name = "deb-compile"; + src = patchelf.src; + diskImage = diskImages.ubuntu1804i386; + diskImageFormat = "qcow2"; + memSize = 512; + postHook = '' + dpkg-query --list + ''; + } + ); } diff --git a/pkgs/build-support/writers/aliases.nix b/pkgs/build-support/writers/aliases.nix index 8441abf36ce5ef..09836fbebd44a1 100644 --- a/pkgs/build-support/writers/aliases.nix +++ b/pkgs/build-support/writers/aliases.nix @@ -3,33 +3,31 @@ lib: prev: let # Removing recurseForDerivation prevents derivations of aliased attribute # set to appear while listing all the packages available. - removeRecurseForDerivations = alias: + removeRecurseForDerivations = + alias: if alias.recurseForDerivations or false then - lib.removeAttrs alias ["recurseForDerivations"] - else alias; + lib.removeAttrs alias [ "recurseForDerivations" ] + else + alias; # Disabling distribution prevents top-level aliases for non-recursed package # sets from building on Hydra. - removeDistribute = alias: - if lib.isDerivation alias then - lib.dontDistribute alias - else alias; + removeDistribute = alias: if lib.isDerivation alias then lib.dontDistribute alias else alias; # Make sure that we are not shadowing something from # writers. - checkInPkgs = n: alias: if builtins.hasAttr n prev - then throw "Alias ${n} is still in writers" - else alias; + checkInPkgs = + n: alias: if builtins.hasAttr n prev then throw "Alias ${n} is still in writers" else alias; - mapAliases = aliases: - lib.mapAttrs (n: alias: removeDistribute - (removeRecurseForDerivations - (checkInPkgs n alias))) - aliases; + mapAliases = + aliases: + lib.mapAttrs ( + n: alias: removeDistribute (removeRecurseForDerivations (checkInPkgs n alias)) + ) aliases; in mapAliases ({ - /* Cleanup before 22.05, Added 2021-12-11 */ + # Cleanup before 22.05, Added 2021-12-11 writePython2 = "Python 2 is EOL and the use of writers.writePython2 is deprecated."; writePython2Bin = "Python 2 is EOL and the use of writers.writePython2Bin is deprecated."; }) diff --git a/pkgs/build-support/writers/data.nix b/pkgs/build-support/writers/data.nix index 315150378e699d..c4a1876308d30e 100644 --- a/pkgs/build-support/writers/data.nix +++ b/pkgs/build-support/writers/data.nix @@ -1,4 +1,9 @@ -{ lib, pkgs, formats, runCommand }: +{ + lib, + pkgs, + formats, + runCommand, +}: let inherit (lib) last @@ -29,8 +34,15 @@ in data :: T: the data that will be converted. ``` */ - makeDataWriter = lib.warn "pkgs.writers.makeDataWriter is deprecated. Use pkgs.writeTextFile." ({ input ? lib.id, output ? "cp $inputPath $out" }: nameOrPath: data: - assert (types.path.check nameOrPath) || (builtins.match "([0-9A-Za-z._])[0-9A-Za-z._-]*" nameOrPath != null); + makeDataWriter = lib.warn "pkgs.writers.makeDataWriter is deprecated. Use pkgs.writeTextFile." ( + { + input ? lib.id, + output ? "cp $inputPath $out", + }: + nameOrPath: data: + assert + (types.path.check nameOrPath) + || (builtins.match "([0-9A-Za-z._])[0-9A-Za-z._-]*" nameOrPath != null); let name = last (builtins.split "/" nameOrPath); in @@ -38,15 +50,17 @@ in { input = input data; passAsFile = [ "input" ]; - } '' - ${output} - - ${optionalString (types.path.check nameOrPath) '' - mv $out tmp - mkdir -p $out/$(dirname "${nameOrPath}") - mv tmp $out/${nameOrPath} - ''} - ''); + } + '' + ${output} + + ${optionalString (types.path.check nameOrPath) '' + mv $out tmp + mkdir -p $out/$(dirname "${nameOrPath}") + mv tmp $out/${nameOrPath} + ''} + '' + ); inherit (pkgs) writeText; @@ -59,7 +73,7 @@ in writeJSON "data.json" { hello = "world"; } ``` */ - writeJSON = (pkgs.formats.json {}).generate; + writeJSON = (pkgs.formats.json { }).generate; /** Writes the content to a TOML file. @@ -70,7 +84,7 @@ in writeTOML "data.toml" { hello = "world"; } ``` */ - writeTOML = (pkgs.formats.toml {}).generate; + writeTOML = (pkgs.formats.toml { }).generate; /** Writes the content to a YAML file. @@ -81,5 +95,5 @@ in writeYAML "data.yaml" { hello = "world"; } ``` */ - writeYAML = (pkgs.formats.yaml {}).generate; + writeYAML = (pkgs.formats.yaml { }).generate; } diff --git a/pkgs/build-support/writers/default.nix b/pkgs/build-support/writers/default.nix index cadb6978148158..ad2be96f4b0b35 100644 --- a/pkgs/build-support/writers/default.nix +++ b/pkgs/build-support/writers/default.nix @@ -1,8 +1,12 @@ -{ config, lib, callPackages }: +{ + config, + lib, + callPackages, +}: # If you are reading this, you can test these writers by running: nix-build . -A tests.writers let - aliases = if config.allowAliases then (import ./aliases.nix lib) else prev: {}; + aliases = if config.allowAliases then (import ./aliases.nix lib) else prev: { }; # Writers for JSON-like data structures dataWriters = callPackages ./data.nix { }; diff --git a/pkgs/build-support/writers/test.nix b/pkgs/build-support/writers/test.nix index 7564796191d587..50419d532c409c 100644 --- a/pkgs/build-support/writers/test.nix +++ b/pkgs/build-support/writers/test.nix @@ -1,12 +1,13 @@ -{ haskellPackages -, lib -, nodePackages -, perlPackages -, python3Packages -, runCommand -, testers -, writers -, writeText +{ + haskellPackages, + lib, + nodePackages, + perlPackages, + python3Packages, + runCommand, + testers, + writers, + writeText, }: # If you are reading this, you can test these writers by running: nix-build . -A tests.writers @@ -47,8 +48,9 @@ let writeYAML ; - expectSuccess = test: - runCommand "run-${test.name}" {} '' + expectSuccess = + test: + runCommand "run-${test.name}" { } '' if [[ "$(${test})" != success ]]; then echo 'test ${test.name} failed' exit 1 @@ -57,8 +59,9 @@ let touch $out ''; - expectSuccessBin = test: - runCommand "run-${test.name}" {} '' + expectSuccessBin = + test: + runCommand "run-${test.name}" { } '' if [[ "$(${getExe test})" != success ]]; then echo 'test ${test.name} failed' exit 1 @@ -67,77 +70,102 @@ let touch $out ''; - expectDataEqual = { file, expected }: + expectDataEqual = + { file, expected }: let expectedFile = writeText "${file.name}-expected" expected; in - testers.testEqualContents { expected = expectedFile; actual = file; assertion = "${file.name} matches"; }; + testers.testEqualContents { + expected = expectedFile; + actual = file; + assertion = "${file.name} matches"; + }; in recurseIntoAttrs { bin = recurseIntoAttrs { - bash = expectSuccessBin (writeBashBin "test-writers-bash-bin" '' - if [[ "test" == "test" ]]; then echo "success"; fi - ''); + bash = expectSuccessBin ( + writeBashBin "test-writers-bash-bin" '' + if [[ "test" == "test" ]]; then echo "success"; fi + '' + ); + + dash = expectSuccessBin ( + writeDashBin "test-writers-dash-bin" '' + test '~' = '~' && echo 'success' + '' + ); + + fish = expectSuccessBin ( + writeFishBin "test-writers-fish-bin" '' + if test "test" = "test" + echo "success" + end + '' + ); + + babashka = expectSuccessBin ( + writeBabashkaBin "test-writers-babashka-bin" { } '' + (println "success") + '' + ); + + rust = expectSuccessBin ( + writeRustBin "test-writers-rust-bin" { } '' + fn main(){ + println!("success") + } + '' + ); - dash = expectSuccessBin (writeDashBin "test-writers-dash-bin" '' - test '~' = '~' && echo 'success' - ''); + haskell = expectSuccessBin ( + writeHaskellBin "test-writers-haskell-bin" { libraries = [ haskellPackages.acme-default ]; } '' + import Data.Default + + int :: Int + int = def + + main :: IO () + main = case int of + 18871 -> putStrLn $ id "success" + _ -> print "fail" + '' + ); - fish = expectSuccessBin (writeFishBin "test-writers-fish-bin" '' - if test "test" = "test" + nim = expectSuccessBin ( + writeNimBin "test-writers-nim-bin" { } '' echo "success" - end - ''); - - babashka = expectSuccessBin (writeBabashkaBin "test-writers-babashka-bin" { } '' - (println "success") - ''); - - rust = expectSuccessBin (writeRustBin "test-writers-rust-bin" {} '' - fn main(){ - println!("success") - } - ''); - - haskell = expectSuccessBin (writeHaskellBin "test-writers-haskell-bin" { libraries = [ haskellPackages.acme-default ]; } '' - import Data.Default - - int :: Int - int = def - - main :: IO () - main = case int of - 18871 -> putStrLn $ id "success" - _ -> print "fail" - ''); - - nim = expectSuccessBin (writeNimBin "test-writers-nim-bin" { } '' - echo "success" - ''); - - js = expectSuccessBin (writeJSBin "test-writers-js-bin" { libraries = [ nodePackages.semver ]; } '' - var semver = require('semver'); - - if (semver.valid('1.2.3')) { - console.log('success') - } else { - console.log('fail') - } - ''); - - perl = expectSuccessBin (writePerlBin "test-writers-perl-bin" { libraries = [ perlPackages.boolean ]; } '' - use boolean; - print "success\n" if true; - ''); - - python3 = expectSuccessBin (writePython3Bin "test-writers-python3-bin" { libraries = [ python3Packages.pyyaml ]; } '' - import yaml - - y = yaml.safe_load(""" - - test: success - """) - print(y[0]['test']) - ''); + '' + ); + + js = expectSuccessBin ( + writeJSBin "test-writers-js-bin" { libraries = [ nodePackages.semver ]; } '' + var semver = require('semver'); + + if (semver.valid('1.2.3')) { + console.log('success') + } else { + console.log('fail') + } + '' + ); + + perl = expectSuccessBin ( + writePerlBin "test-writers-perl-bin" { libraries = [ perlPackages.boolean ]; } '' + use boolean; + print "success\n" if true; + '' + ); + + python3 = expectSuccessBin ( + writePython3Bin "test-writers-python3-bin" { libraries = [ python3Packages.pyyaml ]; } '' + import yaml + + y = yaml.safe_load(""" + - test: success + """) + print(y[0]['test']) + '' + ); # Commented out because of this issue: https://github.com/NixOS/nixpkgs/issues/39356 @@ -183,67 +211,87 @@ recurseIntoAttrs { }; simple = recurseIntoAttrs { - bash = expectSuccess (writeBash "test-writers-bash" '' - if [[ "test" == "test" ]]; then echo "success"; fi - ''); + bash = expectSuccess ( + writeBash "test-writers-bash" '' + if [[ "test" == "test" ]]; then echo "success"; fi + '' + ); - dash = expectSuccess (writeDash "test-writers-dash" '' - test '~' = '~' && echo 'success' - ''); + dash = expectSuccess ( + writeDash "test-writers-dash" '' + test '~' = '~' && echo 'success' + '' + ); - fish = expectSuccess (writeFish "test-writers-fish" '' - if test "test" = "test" - echo "success" - end - ''); + fish = expectSuccess ( + writeFish "test-writers-fish" '' + if test "test" = "test" + echo "success" + end + '' + ); - nim = expectSuccess (writeNim "test-writers-nim" { } '' - echo "success" - ''); + nim = expectSuccess ( + writeNim "test-writers-nim" { } '' + echo "success" + '' + ); - nu = expectSuccess (writeNu "test-writers-nushell" '' - echo "success" - ''); + nu = expectSuccess ( + writeNu "test-writers-nushell" '' + echo "success" + '' + ); - babashka = expectSuccess (writeBabashka "test-writers-babashka" { } '' - (println "success") - ''); + babashka = expectSuccess ( + writeBabashka "test-writers-babashka" { } '' + (println "success") + '' + ); - haskell = expectSuccess (writeHaskell "test-writers-haskell" { libraries = [ haskellPackages.acme-default ]; } '' - import Data.Default + haskell = expectSuccess ( + writeHaskell "test-writers-haskell" { libraries = [ haskellPackages.acme-default ]; } '' + import Data.Default - int :: Int - int = def + int :: Int + int = def - main :: IO () - main = case int of - 18871 -> putStrLn $ id "success" - _ -> print "fail" - ''); + main :: IO () + main = case int of + 18871 -> putStrLn $ id "success" + _ -> print "fail" + '' + ); - js = expectSuccess (writeJS "test-writers-js" { libraries = [ nodePackages.semver ]; } '' - var semver = require('semver'); + js = expectSuccess ( + writeJS "test-writers-js" { libraries = [ nodePackages.semver ]; } '' + var semver = require('semver'); - if (semver.valid('1.2.3')) { - console.log('success') - } else { - console.log('fail') - } - ''); + if (semver.valid('1.2.3')) { + console.log('success') + } else { + console.log('fail') + } + '' + ); - perl = expectSuccess (writePerl "test-writers-perl" { libraries = [ perlPackages.boolean ]; } '' - use boolean; - print "success\n" if true; - ''); + perl = expectSuccess ( + writePerl "test-writers-perl" { libraries = [ perlPackages.boolean ]; } '' + use boolean; + print "success\n" if true; + '' + ); - python3 = expectSuccess (writePython3 "test-writers-python3" { libraries = [ python3Packages.pyyaml ]; } '' - import yaml + python3 = expectSuccess ( + writePython3 "test-writers-python3" { libraries = [ python3Packages.pyyaml ]; } '' + import yaml - y = yaml.safe_load(""" - - test: success - """) - print(y[0]['test']) - ''); + y = yaml.safe_load(""" + - test: success + """) + print(y[0]['test']) + '' + ); # Commented out because of this issue: https://github.com/NixOS/nixpkgs/issues/39356 @@ -296,43 +344,61 @@ recurseIntoAttrs { # print("success") #''); - python3NoLibs = expectSuccess (writePython3 "test-writers-python3-no-libs" {} '' - print("success") - ''); + python3NoLibs = expectSuccess ( + writePython3 "test-writers-python3-no-libs" { } '' + print("success") + '' + ); - pypy3NoLibs = expectSuccess (writePyPy3 "test-writers-pypy3-no-libs" {} '' - print("success") - ''); + pypy3NoLibs = expectSuccess ( + writePyPy3 "test-writers-pypy3-no-libs" { } '' + print("success") + '' + ); - fsharpNoNugetDeps = expectSuccess (writeFSharp "test-writers-fsharp-no-nuget-deps" '' - printfn "success" - ''); + fsharpNoNugetDeps = expectSuccess ( + writeFSharp "test-writers-fsharp-no-nuget-deps" '' + printfn "success" + '' + ); - luaNoLibs = expectSuccess (writeLua "test-writers-lua-no-libs" {} '' - print("success") - ''); + luaNoLibs = expectSuccess ( + writeLua "test-writers-lua-no-libs" { } '' + print("success") + '' + ); - rubyNoLibs = expectSuccess (writeRuby "test-writers-ruby-no-libs" {} '' - puts "success" - ''); + rubyNoLibs = expectSuccess ( + writeRuby "test-writers-ruby-no-libs" { } '' + puts "success" + '' + ); }; path = recurseIntoAttrs { - bash = expectSuccess (writeBash "test-writers-bash-path" (writeText "test" '' - if [[ "test" == "test" ]]; then echo "success"; fi - '')); + bash = expectSuccess ( + writeBash "test-writers-bash-path" ( + writeText "test" '' + if [[ "test" == "test" ]]; then echo "success"; fi + '' + ) + ); - haskell = expectSuccess (writeHaskell "test-writers-haskell-path" { libraries = [ haskellPackages.acme-default ]; } (writeText "test" '' - import Data.Default + haskell = expectSuccess ( + writeHaskell "test-writers-haskell-path" { libraries = [ haskellPackages.acme-default ]; } ( + writeText "test" '' + import Data.Default - int :: Int - int = def + int :: Int + int = def - main :: IO () - main = case int of - 18871 -> putStrLn $ id "success" - _ -> print "fail" - '')); + main :: IO () + main = case int of + 18871 -> putStrLn $ id "success" + _ -> print "fail" + '' + ) + ); }; data = { @@ -473,16 +539,18 @@ recurseIntoAttrs { '' ); - no-empty-wrapper = let - bin = writeBashBin "bin" { makeWrapperArgs = []; } ''true''; - in runCommand "run-test-writers-wrapping-no-empty-wrapper" {} '' - ls -A ${bin}/bin - if [ $(ls -A ${bin}/bin | wc -l) -eq 1 ]; then - touch $out - else - echo "Error: Empty wrapper was created" >&2 - exit 1 - fi - ''; + no-empty-wrapper = + let + bin = writeBashBin "bin" { makeWrapperArgs = [ ]; } ''true''; + in + runCommand "run-test-writers-wrapping-no-empty-wrapper" { } '' + ls -A ${bin}/bin + if [ $(ls -A ${bin}/bin | wc -l) -eq 1 ]; then + touch $out + else + echo "Error: Empty wrapper was created" >&2 + exit 1 + fi + ''; }; } diff --git a/pkgs/by-name/_0/_0verkill/package.nix b/pkgs/by-name/_0/_0verkill/package.nix index 22ef6c6b0cc451..66a498d68dc645 100644 --- a/pkgs/by-name/_0/_0verkill/package.nix +++ b/pkgs/by-name/_0/_0verkill/package.nix @@ -1,10 +1,11 @@ -{ lib -, gccStdenv -, fetchFromGitHub -, autoreconfHook269 -, xorgproto -, libX11 -, libXpm +{ + lib, + gccStdenv, + fetchFromGitHub, + autoreconfHook269, + xorgproto, + libX11, + libXpm, }: gccStdenv.mkDerivation rec { @@ -19,7 +20,11 @@ gccStdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook269 ]; - buildInputs = [ libX11 xorgproto libXpm ]; + buildInputs = [ + libX11 + xorgproto + libXpm + ]; configureFlags = [ "--with-x" ]; diff --git a/pkgs/by-name/_0/_0x/package.nix b/pkgs/by-name/_0/_0x/package.nix index c5adee2a19467d..e072cc4b58c539 100644 --- a/pkgs/by-name/_0/_0x/package.nix +++ b/pkgs/by-name/_0/_0x/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage { diff --git a/pkgs/by-name/_0/_0xpropo/package.nix b/pkgs/by-name/_0/_0xpropo/package.nix index 200e9758f778d0..704d8e0fdc055d 100644 --- a/pkgs/by-name/_0/_0xpropo/package.nix +++ b/pkgs/by-name/_0/_0xpropo/package.nix @@ -7,9 +7,10 @@ stdenvNoCC.mkDerivation rec { pname = "0xpropo"; version = "1.100"; - src = let - underscoreVersion = builtins.replaceStrings ["."] ["_"] version; - in + src = + let + underscoreVersion = builtins.replaceStrings [ "." ] [ "_" ] version; + in fetchzip { url = "https://github.com/0xType/0xPropo/releases/download/${version}/0xPropo_${underscoreVersion}.zip"; hash = "sha256-ZlZNvn9xiOxS+dfGI1rGbh6XlXo3/puAm2vhKh63sK4="; @@ -27,7 +28,7 @@ stdenvNoCC.mkDerivation rec { homepage = "https://github.com/0xType/0xPropo"; changelog = "https://github.com/0xType/0xPropo/releases/tag/${version}"; license = licenses.ofl; - maintainers = with maintainers; [vinnymeller]; + maintainers = with maintainers; [ vinnymeller ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/_0/_0xproto/package.nix b/pkgs/by-name/_0/_0xproto/package.nix index 9b7fd3959362e7..91857593b49369 100644 --- a/pkgs/by-name/_0/_0xproto/package.nix +++ b/pkgs/by-name/_0/_0xproto/package.nix @@ -1,14 +1,16 @@ -{ lib -, stdenvNoCC -, fetchzip +{ + lib, + stdenvNoCC, + fetchzip, }: stdenvNoCC.mkDerivation rec { pname = "0xproto"; version = "2.100"; - src = let - underscoreVersion = builtins.replaceStrings ["."] ["_"] version; - in + src = + let + underscoreVersion = builtins.replaceStrings [ "." ] [ "_" ] version; + in fetchzip { url = "https://github.com/0xType/0xProto/releases/download/${version}/0xProto_${underscoreVersion}.zip"; hash = "sha256-hUQGCsktnun9924+k6ECQuQ1Ddl/qGmtuLWERh/vDpc="; diff --git a/pkgs/by-name/_2/_2048-in-terminal/package.nix b/pkgs/by-name/_2/_2048-in-terminal/package.nix index e7347c8fe880ee..c27a4640c850be 100644 --- a/pkgs/by-name/_2/_2048-in-terminal/package.nix +++ b/pkgs/by-name/_2/_2048-in-terminal/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, ncurses, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + pkg-config, +}: stdenv.mkDerivation rec { pname = "2048-in-terminal"; diff --git a/pkgs/by-name/_2/_20kly/package.nix b/pkgs/by-name/_2/_20kly/package.nix index 661feea1730db5..e860a01fe15d75 100644 --- a/pkgs/by-name/_2/_20kly/package.nix +++ b/pkgs/by-name/_2/_20kly/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3Packages +{ + lib, + fetchFromGitHub, + python3Packages, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/_3/_3270font/package.nix b/pkgs/by-name/_3/_3270font/package.nix index 56ee110a4b35c2..3df18ecf8743d9 100644 --- a/pkgs/by-name/_3/_3270font/package.nix +++ b/pkgs/by-name/_3/_3270font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "3270font"; @@ -29,7 +33,10 @@ stdenvNoCC.mkDerivation rec { description = "Monospaced font based on IBM 3270 terminals"; homepage = "https://github.com/rbanffy/3270font"; changelog = "https://github.com/rbanffy/3270font/blob/v${version}/CHANGELOG.md"; - license = [ licenses.bsd3 licenses.ofl ]; + license = [ + licenses.bsd3 + licenses.ofl + ]; maintainers = [ ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/_3/_3mux/package.nix b/pkgs/by-name/_3/_3mux/package.nix index 0a16b853943d97..f56a328ce6448e 100644 --- a/pkgs/by-name/_3/_3mux/package.nix +++ b/pkgs/by-name/_3/_3mux/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch, makeWrapper }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + makeWrapper, +}: buildGoModule rec { pname = "3mux"; @@ -53,7 +59,10 @@ buildGoModule rec { ''; homepage = "https://github.com/aaronjanse/3mux"; license = licenses.mit; - maintainers = with maintainers; [ aaronjanse Br1ght0ne ]; + maintainers = with maintainers; [ + aaronjanse + Br1ght0ne + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/_3/_3proxy/package.nix b/pkgs/by-name/_3/_3proxy/package.nix index ab5ae744d2715d..819c6a13a3c230 100644 --- a/pkgs/by-name/_3/_3proxy/package.nix +++ b/pkgs/by-name/_3/_3proxy/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + nixosTests, +}: stdenv.mkDerivation rec { pname = "3proxy"; diff --git a/pkgs/by-name/_4/_4d-minesweeper/package.nix b/pkgs/by-name/_4/_4d-minesweeper/package.nix index 4cb7b20bcb45ea..a20d776806a423 100644 --- a/pkgs/by-name/_4/_4d-minesweeper/package.nix +++ b/pkgs/by-name/_4/_4d-minesweeper/package.nix @@ -1,24 +1,25 @@ -{ lib -, fetchFromGitHub -, stdenv -, unzip -, alsa-lib -, gcc-unwrapped -, git -, godot3-export-templates -, godot3-headless -, libGLU -, libX11 -, libXcursor -, libXext -, libXfixes -, libXi -, libXinerama -, libXrandr -, libXrender -, libglvnd -, libpulseaudio -, zlib +{ + lib, + fetchFromGitHub, + stdenv, + unzip, + alsa-lib, + gcc-unwrapped, + git, + godot3-export-templates, + godot3-headless, + libGLU, + libX11, + libXcursor, + libXext, + libXfixes, + libXi, + libXinerama, + libXrandr, + libXrender, + libglvnd, + libpulseaudio, + zlib, }: stdenv.mkDerivation { @@ -82,7 +83,7 @@ stdenv.mkDerivation { homepage = "https://github.com/gapophustu/4D-Minesweeper"; description = "4D Minesweeper game written in Godot"; license = licenses.mpl20; - platforms = platforms.linux; + platforms = platforms.linux; maintainers = [ ]; mainProgram = "4d-minesweeper"; }; diff --git a/pkgs/by-name/_4/_4th/package.nix b/pkgs/by-name/_4/_4th/package.nix index abc2d53fe0b606..bcacf1f8fb2975 100644 --- a/pkgs/by-name/_4/_4th/package.nix +++ b/pkgs/by-name/_4/_4th/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { @@ -12,7 +13,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-+W6nTNsqrf3Dvr+NbSz3uJdrXVbBI3OHR5v/rs7en+M="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; patches = [ # Fix install manual; report this patch to upstream diff --git a/pkgs/by-name/_4/_4ti2/package.nix b/pkgs/by-name/_4/_4ti2/package.nix index 940e2e45d5acfb..dc46e01828bf2b 100644 --- a/pkgs/by-name/_4/_4ti2/package.nix +++ b/pkgs/by-name/_4/_4ti2/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, glpk -, gmp +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + glpk, + gmp, }: -stdenv.mkDerivation rec{ +stdenv.mkDerivation rec { pname = "4ti2"; version = "1.6.10"; src = fetchFromGitHub { owner = pname; repo = pname; - rev = "Release_${builtins.replaceStrings ["."] ["_"] version}"; + rev = "Release_${builtins.replaceStrings [ "." ] [ "_" ] version}"; hash = "sha256-Rz8O1Tf81kzpTGPq7dkZJvv444F1/VqKu7VuRvH59kQ="; }; @@ -28,7 +29,7 @@ stdenv.mkDerivation rec{ installFlags = [ "install-exec" ]; - meta = with lib;{ + meta = with lib; { homepage = "https://4ti2.github.io/"; description = "Software package for algebraic, geometric and combinatorial problems on linear spaces"; license = with licenses; [ gpl2Plus ]; diff --git a/pkgs/by-name/_5/_5etools/package.nix b/pkgs/by-name/_5/_5etools/package.nix index 66a0f8dbc77da9..1af299ce97ff6e 100644 --- a/pkgs/by-name/_5/_5etools/package.nix +++ b/pkgs/by-name/_5/_5etools/package.nix @@ -15,6 +15,6 @@ fetchFromGitHub rec { changelog = "https://github.com/5etools-mirror-1/5etools-mirror-1.github.io/releases/tag/v${version}"; license = [ licenses.mit ]; maintainers = with maintainers; [ urandom ]; - hydraPlatforms = []; # src tarball is 4.7G, unpackeed 4.8G, exceeds hydras output limit + hydraPlatforms = [ ]; # src tarball is 4.7G, unpackeed 4.8G, exceeds hydras output limit }; } diff --git a/pkgs/by-name/_6/_6tunnel/package.nix b/pkgs/by-name/_6/_6tunnel/package.nix index b26853ee4ea165..181b23a5bed190 100644 --- a/pkgs/by-name/_6/_6tunnel/package.nix +++ b/pkgs/by-name/_6/_6tunnel/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, autoreconfHook }: +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "6tunnel"; diff --git a/pkgs/by-name/_7/_7kaa/package.nix b/pkgs/by-name/_7/_7kaa/package.nix index 2dd4d672215361..53e60276b3f5a8 100644 --- a/pkgs/by-name/_7/_7kaa/package.nix +++ b/pkgs/by-name/_7/_7kaa/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, gccStdenv -, autoreconfHook -, autoconf-archive -, pkg-config -, fetchurl -, fetchFromGitHub -, openal -, enet -, SDL2 -, curl -, gettext -, libiconv +{ + lib, + stdenv, + gccStdenv, + autoreconfHook, + autoconf-archive, + pkg-config, + fetchurl, + fetchFromGitHub, + openal, + enet, + SDL2, + curl, + gettext, + libiconv, }: let @@ -46,15 +47,28 @@ gccStdenv.mkDerivation (finalAttrs: { hash = "sha256-kkM+kFQ+tGHS5NrVPeDMRWFQb7waESt8xOLfFGaGdgo="; }; - nativeBuildInputs = [ autoreconfHook autoconf-archive pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + autoconf-archive + pkg-config + ]; - buildInputs = [ openal enet SDL2 curl gettext libiconv ]; + buildInputs = [ + openal + enet + SDL2 + curl + gettext + libiconv + ]; preAutoreconf = '' autoupdate ''; - hardeningDisable = lib.optionals (stdenv.hostPlatform.isAarch64 && stdenv.hostPlatform.isDarwin) [ "stackprotector" ]; + hardeningDisable = lib.optionals (stdenv.hostPlatform.isAarch64 && stdenv.hostPlatform.isDarwin) [ + "stackprotector" + ]; postInstall = '' mkdir $out/share/7kaa/MUSIC diff --git a/pkgs/by-name/_9/_915resolution/package.nix b/pkgs/by-name/_9/_915resolution/package.nix index 8a6732d8737fa9..1b2ef09a5789f3 100644 --- a/pkgs/by-name/_9/_915resolution/package.nix +++ b/pkgs/by-name/_9/_915resolution/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "915resolution"; @@ -16,7 +20,10 @@ stdenv.mkDerivation rec { homepage = "http://915resolution.mango-lang.org/"; description = "Tool to modify Intel 800/900 video BIOS"; mainProgram = "915resolution"; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; license = licenses.publicDomain; }; } diff --git a/pkgs/by-name/_9/_9base/package.nix b/pkgs/by-name/_9/_9base/package.nix index 3d523c513eecd3..983b569062bcb5 100644 --- a/pkgs/by-name/_9/_9base/package.nix +++ b/pkgs/by-name/_9/_9base/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchgit -, pkg-config -, patches ? [ ] -, pkgsBuildHost -, enableStatic ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchgit, + pkg-config, + patches ? [ ], + pkgsBuildHost, + enableStatic ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation { @@ -39,18 +40,21 @@ stdenv.mkDerivation { enableParallelBuilding = true; strictDeps = true; nativeBuildInputs = [ pkg-config ]; - env.NIX_CFLAGS_COMPILE = toString ([ - # workaround build failure on -fno-common toolchains like upstream - # gcc-10. Otherwise build fails as: - # ld: diffio.o:(.bss+0x16): multiple definition of `bflag'; diffdir.o:(.bss+0x6): first defined here - "-fcommon" - # hide really common warning that floods the logs: - # warning: #warning "_BSD_SOURCE and _SVID_SOURCE are deprecated, use _DEFAULT_SOURCE" - "-D_DEFAULT_SOURCE" - ] ++ lib.optionals stdenv.cc.isClang [ - # error: call to undeclared function 'p9mbtowc'; ISO C99 and later do not support implicit function declarations - "-Wno-error=implicit-function-declaration" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + [ + # workaround build failure on -fno-common toolchains like upstream + # gcc-10. Otherwise build fails as: + # ld: diffio.o:(.bss+0x16): multiple definition of `bflag'; diffdir.o:(.bss+0x6): first defined here + "-fcommon" + # hide really common warning that floods the logs: + # warning: #warning "_BSD_SOURCE and _SVID_SOURCE are deprecated, use _DEFAULT_SOURCE" + "-D_DEFAULT_SOURCE" + ] + ++ lib.optionals stdenv.cc.isClang [ + # error: call to undeclared function 'p9mbtowc'; ISO C99 and later do not support implicit function declarations + "-Wno-error=implicit-function-declaration" + ] + ); env.LDFLAGS = lib.optionalString enableStatic "-static"; makeFlags = [ "PREFIX=${placeholder "out"}" @@ -59,7 +63,11 @@ stdenv.mkDerivation { "PREFIX_TROFF=${placeholder "troff"}" ]; - outputs = [ "out" "man" "troff" ]; + outputs = [ + "out" + "man" + "troff" + ]; meta = with lib; { homepage = "https://tools.suckless.org/9base/"; @@ -70,7 +78,10 @@ stdenv.mkDerivation { The overall SLOC is about 66kSLOC, so this userland + all libs is much smaller than, e.g. bash. 9base can be used to run werc instead of the full blown plan9port. ''; - license = with licenses; [ mit /* and */ lpl-102 ]; + license = with licenses; [ + mit # and + lpl-102 + ]; maintainers = with maintainers; [ jk ]; platforms = platforms.unix; # needs additional work to support aarch64-darwin diff --git a/pkgs/by-name/_9/_9menu/package.nix b/pkgs/by-name/_9/_9menu/package.nix index e383a2eb6b6fce..91f587a4e7dc1f 100644 --- a/pkgs/by-name/_9/_9menu/package.nix +++ b/pkgs/by-name/_9/_9menu/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, meson -, ninja -, libX11 -, libXext +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + meson, + ninja, + libX11, + libXext, }: stdenv.mkDerivation rec { @@ -19,8 +20,15 @@ stdenv.mkDerivation rec { sha256 = "arca8Gbr4ytiCk43cifmNj7SUrDgn1XB26zAhZrVDs0="; }; - nativeBuildInputs = [ pkg-config meson ninja ]; - buildInputs = [ libX11 libXext ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + ]; + buildInputs = [ + libX11 + libXext + ]; meta = with lib; { homepage = "https://github.com/arnoldrobbins/9menu"; diff --git a/pkgs/by-name/_9/_9pfs/package.nix b/pkgs/by-name/_9/_9pfs/package.nix index 1fb775ec90cec6..7305505aecb282 100644 --- a/pkgs/by-name/_9/_9pfs/package.nix +++ b/pkgs/by-name/_9/_9pfs/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, fuse, gitUpdater }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + fuse, + gitUpdater, +}: stdenv.mkDerivation rec { pname = "9pfs"; @@ -15,7 +22,10 @@ stdenv.mkDerivation rec { substituteInPlace Makefile --replace "pkg-config" "$PKG_CONFIG" ''; - makeFlags = [ "BIN=$(out)/bin" "MAN=$(out)/share/man/man1" ]; + makeFlags = [ + "BIN=$(out)/bin" + "MAN=$(out)/share/man/man1" + ]; nativeBuildInputs = [ pkg-config ]; buildInputs = [ fuse ]; enableParallelBuilding = true; @@ -28,6 +38,9 @@ stdenv.mkDerivation rec { mainProgram = "9pfs"; maintainers = [ ]; platforms = lib.platforms.unix; - license = with lib.licenses; [ lpl-102 bsd2 ]; + license = with lib.licenses; [ + lpl-102 + bsd2 + ]; }; } diff --git a/pkgs/by-name/_9/_9ptls/package.nix b/pkgs/by-name/_9/_9ptls/package.nix index 20fa779ecf61c9..0c34dd53e314a8 100644 --- a/pkgs/by-name/_9/_9ptls/package.nix +++ b/pkgs/by-name/_9/_9ptls/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, tlsclient +{ + lib, + stdenv, + tlsclient, }: stdenv.mkDerivation (finalAttrs: { @@ -10,7 +11,10 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; buildFlags = [ "mount.9ptls" ]; - installFlags = [ "PREFIX=$(out)" "SBIN=$(out)/bin" ]; + installFlags = [ + "PREFIX=$(out)" + "SBIN=$(out)/bin" + ]; installTargets = "mount.9ptls.install"; meta = with lib; { diff --git a/pkgs/by-name/a2/a2jmidid/package.nix b/pkgs/by-name/a2/a2jmidid/package.nix index c82e0012d2bc5f..10b2fa3fe9b25b 100644 --- a/pkgs/by-name/a2/a2jmidid/package.nix +++ b/pkgs/by-name/a2/a2jmidid/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitea, makeWrapper, pkg-config, alsa-lib, dbus, libjack2 -, python3Packages , meson, ninja, gitUpdater }: +{ + lib, + stdenv, + fetchFromGitea, + makeWrapper, + pkg-config, + alsa-lib, + dbus, + libjack2, + python3Packages, + meson, + ninja, + gitUpdater, +}: stdenv.mkDerivation rec { pname = "a2jmidid"; @@ -14,9 +26,22 @@ stdenv.mkDerivation rec { hash = "sha256-PZKGhHmPMf0AucPruOLB9DniM5A3BKdghFCrd5pTzeM="; }; - nativeBuildInputs = [ pkg-config makeWrapper meson ninja ]; - buildInputs = [ alsa-lib dbus libjack2 ] ++ - (with python3Packages; [ python dbus-python ]); + nativeBuildInputs = [ + pkg-config + makeWrapper + meson + ninja + ]; + buildInputs = + [ + alsa-lib + dbus + libjack2 + ] + ++ (with python3Packages; [ + python + dbus-python + ]); postInstall = '' wrapProgram $out/bin/a2j_control --set PYTHONPATH $PYTHONPATH @@ -30,6 +55,10 @@ stdenv.mkDerivation rec { homepage = "https://a2jmidid.ladish.org/"; license = licenses.gpl2Only; maintainers = [ ]; - platforms = [ "i686-linux" "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + "aarch64-linux" + ]; }; } diff --git a/pkgs/by-name/a2/a2ps/package.nix b/pkgs/by-name/a2/a2ps/package.nix index 78d4c4dcad9fc5..bb4ba7c4df320c 100644 --- a/pkgs/by-name/a2/a2ps/package.nix +++ b/pkgs/by-name/a2/a2ps/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, autoconf -, bison -, file -, perl -, pkg-config -, boehmgc -, gperf -, libpaper +{ + lib, + stdenv, + fetchurl, + autoconf, + bison, + file, + perl, + pkg-config, + boehmgc, + gperf, + libpaper, }: stdenv.mkDerivation rec { @@ -25,8 +26,18 @@ stdenv.mkDerivation rec { substituteInPlace tests/defs.in --replace "/bin/rm" "rm" ''; - nativeBuildInputs = [ autoconf bison file perl pkg-config ]; - buildInputs = [ boehmgc gperf libpaper ]; + nativeBuildInputs = [ + autoconf + bison + file + perl + pkg-config + ]; + buildInputs = [ + boehmgc + gperf + libpaper + ]; strictDeps = true; diff --git a/pkgs/by-name/a4/a4/package.nix b/pkgs/by-name/a4/a4/package.nix index 5efd44b893a7f1..a8e3ff44c989dc 100644 --- a/pkgs/by-name/a4/a4/package.nix +++ b/pkgs/by-name/a4/a4/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, libtickit -, libvterm-neovim +{ + lib, + stdenv, + fetchFromGitHub, + libtickit, + libvterm-neovim, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/aa/aaa/package.nix b/pkgs/by-name/aa/aaa/package.nix index 6511df5c997a53..0085f924cfdbb7 100644 --- a/pkgs/by-name/aa/aaa/package.nix +++ b/pkgs/by-name/aa/aaa/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/aa/aaaaxy/package.nix b/pkgs/by-name/aa/aaaaxy/package.nix index fbc93426f381ac..f6fdd10a8fbe56 100644 --- a/pkgs/by-name/aa/aaaaxy/package.nix +++ b/pkgs/by-name/aa/aaaaxy/package.nix @@ -1,21 +1,22 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, alsa-lib -, libGL -, libX11 -, libXcursor -, libXext -, libXi -, libXinerama -, libXrandr -, libXxf86vm -, go-licenses -, pkg-config -, zip -, advancecomp -, makeWrapper -, nixosTests +{ + lib, + fetchFromGitHub, + buildGoModule, + alsa-lib, + libGL, + libX11, + libXcursor, + libXext, + libXi, + libXinerama, + libXrandr, + libXxf86vm, + go-licenses, + pkg-config, + zip, + advancecomp, + makeWrapper, + nixosTests, }: buildGoModule rec { @@ -35,7 +36,12 @@ buildGoModule rec { buildInputs = [ alsa-lib libGL - libX11 libXcursor libXext libXi libXinerama libXrandr + libX11 + libXcursor + libXext + libXi + libXinerama + libXrandr libXxf86vm ]; @@ -47,7 +53,10 @@ buildGoModule rec { makeWrapper ]; - outputs = [ "out" "testing_infra" ]; + outputs = [ + "out" + "testing_infra" + ]; postPatch = '' # Without patching, "go run" fails with the error message: @@ -64,24 +73,26 @@ buildGoModule rec { 'CPPFLAGS ?= -DNDEBUG -D_GLFW_GLX_LIBRARY=\"${lib.getLib libGL}/lib/libGL.so\" -D_GLFW_EGL_LIBRARY=\"${lib.getLib libGL}/lib/libEGL.so\"' ''; - overrideModAttrs = (_: { - # We can't patch in the path to libGL directly because - # this is a fixed output derivation and when the path to libGL - # changes, the hash would change. - # To work around this, use environment variables. - postBuild = '' - substituteInPlace 'vendor/github.com/hajimehoshi/ebiten/v2/internal/graphicsdriver/opengl/gl/procaddr_linbsd.go' \ - --replace-fail \ - 'import (' \ - 'import ("os"' \ - --replace-fail \ - '{"libGL.so", "libGL.so.2", "libGL.so.1", "libGL.so.0"}' \ - '{os.Getenv("EBITENGINE_LIBGL")}' \ - --replace-fail \ - '{"libGLESv2.so", "libGLESv2.so.2", "libGLESv2.so.1", "libGLESv2.so.0"}' \ - '{os.Getenv("EBITENGINE_LIBGLESv2")}' - ''; - }); + overrideModAttrs = ( + _: { + # We can't patch in the path to libGL directly because + # this is a fixed output derivation and when the path to libGL + # changes, the hash would change. + # To work around this, use environment variables. + postBuild = '' + substituteInPlace 'vendor/github.com/hajimehoshi/ebiten/v2/internal/graphicsdriver/opengl/gl/procaddr_linbsd.go' \ + --replace-fail \ + 'import (' \ + 'import ("os"' \ + --replace-fail \ + '{"libGL.so", "libGL.so.2", "libGL.so.1", "libGL.so.0"}' \ + '{os.Getenv("EBITENGINE_LIBGL")}' \ + --replace-fail \ + '{"libGLESv2.so", "libGLESv2.so.2", "libGLESv2.so.1", "libGLESv2.so.0"}' \ + '{os.Getenv("EBITENGINE_LIBGLESv2")}' + ''; + } + ); makeFlags = [ "BUILDTYPE=release" diff --git a/pkgs/by-name/aa/aacgain/package.nix b/pkgs/by-name/aa/aacgain/package.nix index ce0362ba49c036..c91bbbe3f3f817 100644 --- a/pkgs/by-name/aa/aacgain/package.nix +++ b/pkgs/by-name/aa/aacgain/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, autoconf -, automake -, libtool +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + autoconf, + automake, + libtool, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/aa/aaphoto/package.nix b/pkgs/by-name/aa/aaphoto/package.nix index ee9cf9cde5ffda..8dad7cf82d50a3 100644 --- a/pkgs/by-name/aa/aaphoto/package.nix +++ b/pkgs/by-name/aa/aaphoto/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, jasper -, libpng -, libjpeg -, zlib -, llvmPackages +{ + lib, + stdenv, + fetchFromGitHub, + jasper, + libpng, + libjpeg, + zlib, + llvmPackages, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/aa/aapt/package.nix b/pkgs/by-name/aa/aapt/package.nix index 3bdb1e2f96eb7d..84c2f156662e3d 100644 --- a/pkgs/by-name/aa/aapt/package.nix +++ b/pkgs/by-name/aa/aapt/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchzip -, autoPatchelfHook -, libcxx +{ + lib, + stdenvNoCC, + fetchzip, + autoPatchelfHook, + libcxx, }: stdenvNoCC.mkDerivation rec { @@ -12,18 +13,26 @@ stdenvNoCC.mkDerivation rec { src = let urlAndHash = - if stdenvNoCC.hostPlatform.isLinux then { - url = "https://dl.google.com/android/maven2/com/android/tools/build/aapt2/${version}/aapt2-${version}-linux.jar"; - hash = "sha256-eSQaZrRtb5aCG320hrXAL256fxa/oMhBC4hcTA1KRxs="; - } else if stdenvNoCC.hostPlatform.isDarwin then { - url = "https://dl.google.com/android/maven2/com/android/tools/build/aapt2/${version}/aapt2-${version}-osx.jar"; - hash = "sha256-LUihNjase79JbUkHDb10A5d6pJ+VXDVfv7m09hkL8kY="; - } else throw "Unsupport platform: ${stdenvNoCC.system}"; + if stdenvNoCC.hostPlatform.isLinux then + { + url = "https://dl.google.com/android/maven2/com/android/tools/build/aapt2/${version}/aapt2-${version}-linux.jar"; + hash = "sha256-eSQaZrRtb5aCG320hrXAL256fxa/oMhBC4hcTA1KRxs="; + } + else if stdenvNoCC.hostPlatform.isDarwin then + { + url = "https://dl.google.com/android/maven2/com/android/tools/build/aapt2/${version}/aapt2-${version}-osx.jar"; + hash = "sha256-LUihNjase79JbUkHDb10A5d6pJ+VXDVfv7m09hkL8kY="; + } + else + throw "Unsupport platform: ${stdenvNoCC.system}"; in - fetchzip (urlAndHash // { - extension = "zip"; - stripRoot = false; - }); + fetchzip ( + urlAndHash + // { + extension = "zip"; + stripRoot = false; + } + ); nativeBuildInputs = lib.optionals stdenvNoCC.hostPlatform.isLinux [ autoPatchelfHook ]; buildInputs = lib.optionals stdenvNoCC.hostPlatform.isLinux [ libcxx ]; @@ -46,4 +55,3 @@ stdenvNoCC.mkDerivation rec { sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; }; } - diff --git a/pkgs/by-name/aa/aarch64-esr-decoder/package.nix b/pkgs/by-name/aa/aarch64-esr-decoder/package.nix index 3059d5623bac6d..a15252bb3fdfa7 100644 --- a/pkgs/by-name/aa/aarch64-esr-decoder/package.nix +++ b/pkgs/by-name/aa/aarch64-esr-decoder/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/aa/aardvark-dns/package.nix b/pkgs/by-name/aa/aardvark-dns/package.nix index 708c2a93751644..2e7cf4ad42d10c 100644 --- a/pkgs/by-name/aa/aardvark-dns/package.nix +++ b/pkgs/by-name/aa/aardvark-dns/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, nixosTests +{ + lib, + rustPlatform, + fetchFromGitHub, + nixosTests, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/aa/aaxtomp3/package.nix b/pkgs/by-name/aa/aaxtomp3/package.nix index 59bd228d4751ac..38dfb30dffc69c 100644 --- a/pkgs/by-name/aa/aaxtomp3/package.nix +++ b/pkgs/by-name/aa/aaxtomp3/package.nix @@ -1,19 +1,20 @@ -{ bash -, bc -, coreutils -, fetchFromGitHub -, ffmpeg -, findutils -, gawk -, gnugrep -, gnused -, jq -, lame -, lib -, mediainfo -, mp4v2 -, ncurses -, resholve +{ + bash, + bc, + coreutils, + fetchFromGitHub, + ffmpeg, + findutils, + gawk, + gnugrep, + gnused, + jq, + lame, + lib, + mediainfo, + mp4v2, + ncurses, + resholve, }: resholve.mkDerivation rec { diff --git a/pkgs/by-name/ab/aba/package.nix b/pkgs/by-name/ab/aba/package.nix index 76e6203cb0ce38..39896b1322bf9a 100644 --- a/pkgs/by-name/ab/aba/package.nix +++ b/pkgs/by-name/ab/aba/package.nix @@ -1,9 +1,10 @@ -{ fetchFromSourcehut -, just -, lib -, nix-update-script -, rustPlatform -, scdoc +{ + fetchFromSourcehut, + just, + lib, + nix-update-script, + rustPlatform, + scdoc, }: let version = "0.8.0"; diff --git a/pkgs/by-name/ab/abaddon/package.nix b/pkgs/by-name/ab/abaddon/package.nix index a8db4395645faa..7df9c694be083d 100644 --- a/pkgs/by-name/ab/abaddon/package.nix +++ b/pkgs/by-name/ab/abaddon/package.nix @@ -1,23 +1,24 @@ -{ lib -, fetchFromGitHub -, stdenv -, cmake -, copyDesktopItems -, makeDesktopItem -, makeWrapper -, pkg-config -, alsa-lib -, curl -, gtkmm3 -, libhandy -, libopus -, libpulseaudio -, libsecret -, libsodium -, nlohmann_json -, pcre2 -, spdlog -, sqlite +{ + lib, + fetchFromGitHub, + stdenv, + cmake, + copyDesktopItems, + makeDesktopItem, + makeWrapper, + pkg-config, + alsa-lib, + curl, + gtkmm3, + libhandy, + libopus, + libpulseaudio, + libsecret, + libsodium, + nlohmann_json, + pcre2, + spdlog, + sqlite, }: stdenv.mkDerivation rec { @@ -60,7 +61,12 @@ stdenv.mkDerivation rec { mkdir $out/bin cp abaddon $out/bin wrapProgram $out/bin/abaddon \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ alsa-lib libpulseaudio ]}" \ + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + alsa-lib + libpulseaudio + ] + }" \ --chdir $out/share/abaddon runHook postInstall @@ -73,7 +79,10 @@ stdenv.mkDerivation rec { desktopName = "Abaddon"; genericName = meta.description; startupWMClass = pname; - categories = [ "Network" "InstantMessaging" ]; + categories = [ + "Network" + "InstantMessaging" + ]; mimeTypes = [ "x-scheme-handler/discord" ]; }) ]; diff --git a/pkgs/by-name/ab/abbaye-des-morts/package.nix b/pkgs/by-name/ab/abbaye-des-morts/package.nix index 653a9dcc833401..a2908ed9e502ab 100644 --- a/pkgs/by-name/ab/abbaye-des-morts/package.nix +++ b/pkgs/by-name/ab/abbaye-des-morts/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, SDL2, SDL2_image, SDL2_mixer }: +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + SDL2_image, + SDL2_mixer, +}: stdenv.mkDerivation rec { pname = "abbaye-des-morts"; @@ -11,15 +18,21 @@ stdenv.mkDerivation rec { sha256 = "sha256-IU7E1zmeif9CdoBxzmh7MG2jElGGnEZyKnK7eYFrjsQ="; }; - buildInputs = [ SDL2 SDL2_image SDL2_mixer ]; + buildInputs = [ + SDL2 + SDL2_image + SDL2_mixer + ]; - makeFlags = [ "PREFIX=$(out)" "DESTDIR=" ]; + makeFlags = [ + "PREFIX=$(out)" + "DESTDIR=" + ]; - preBuild = lib.optionalString stdenv.cc.isClang - '' - substituteInPlace Makefile \ - --replace -fpredictive-commoning "" - ''; + preBuild = lib.optionalString stdenv.cc.isClang '' + substituteInPlace Makefile \ + --replace -fpredictive-commoning "" + ''; preInstall = '' mkdir -p $out/bin diff --git a/pkgs/by-name/ab/abbreviate/package.nix b/pkgs/by-name/ab/abbreviate/package.nix index 2f1e5bc812abd6..400e168b1ed51f 100644 --- a/pkgs/by-name/ab/abbreviate/package.nix +++ b/pkgs/by-name/ab/abbreviate/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -21,7 +22,10 @@ buildGoModule rec { installShellFiles ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' installShellCompletion --cmd abbreviate \ diff --git a/pkgs/by-name/ab/abc-verifier/package.nix b/pkgs/by-name/ab/abc-verifier/package.nix index a71122c5465c53..45677ec9d697be 100644 --- a/pkgs/by-name/ab/abc-verifier/package.nix +++ b/pkgs/by-name/ab/abc-verifier/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, readline -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + readline, + cmake, }: stdenv.mkDerivation (finalAttrs: { - pname = "abc-verifier"; + pname = "abc-verifier"; version = "unstable-2023-10-13"; src = fetchFromGitHub { owner = "yosyshq"; - repo = "abc"; - rev = "896e5e7dedf9b9b1459fa019f1fa8aa8101fdf43"; - hash = "sha256-ou+E2lvDEOxXRXNygE/TyVi7quqk+CJHRI+HDI0xljE="; + repo = "abc"; + rev = "896e5e7dedf9b9b1459fa019f1fa8aa8101fdf43"; + hash = "sha256-ou+E2lvDEOxXRXNygE/TyVi7quqk+CJHRI+HDI0xljE="; }; nativeBuildInputs = [ cmake ]; @@ -30,10 +31,13 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Tool for squential logic synthesis and formal verification"; - homepage = "https://people.eecs.berkeley.edu/~alanmi/abc"; - license = licenses.mit; - maintainers = with maintainers; [ thoughtpolice Luflosi ]; + homepage = "https://people.eecs.berkeley.edu/~alanmi/abc"; + license = licenses.mit; + maintainers = with maintainers; [ + thoughtpolice + Luflosi + ]; mainProgram = "abc"; - platforms = platforms.unix; + platforms = platforms.unix; }; }) diff --git a/pkgs/by-name/ab/abcm2ps/package.nix b/pkgs/by-name/ab/abcm2ps/package.nix index 4ea58d9c2d77ac..873bbebcd36e19 100644 --- a/pkgs/by-name/ab/abcm2ps/package.nix +++ b/pkgs/by-name/ab/abcm2ps/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, docutils -, pkg-config -, freetype -, pango -, testers +{ + lib, + stdenv, + fetchFromGitHub, + docutils, + pkg-config, + freetype, + pango, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -23,9 +24,15 @@ stdenv.mkDerivation (finalAttrs: { "--INSTALL=install" ]; - nativeBuildInputs = [ docutils pkg-config ]; + nativeBuildInputs = [ + docutils + pkg-config + ]; - buildInputs = [ freetype pango ]; + buildInputs = [ + freetype + pango + ]; passthru.tests = { version = testers.testVersion { diff --git a/pkgs/by-name/ab/abduco/package.nix b/pkgs/by-name/ab/abduco/package.nix index eef5fe0df344d6..df318ca8c34003 100644 --- a/pkgs/by-name/ab/abduco/package.nix +++ b/pkgs/by-name/ab/abduco/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchpatch, fetchzip, writeText, conf ? null }: +{ + lib, + stdenv, + fetchpatch, + fetchzip, + writeText, + conf ? null, +}: let rev = "8c32909a159aaa9484c82b71f05b7a73321eb491"; @@ -15,8 +22,7 @@ stdenv.mkDerivation { hash = "sha256-o7SPK/G31cW/rrLwV3UJOTq6EBHl6AEE/GdeKGlHdyg="; }; - preBuild = lib.optionalString (conf != null) - "cp ${writeText "config.def.h" conf} config.def.h"; + preBuild = lib.optionalString (conf != null) "cp ${writeText "config.def.h" conf} config.def.h"; installFlags = [ "install-completion" ]; CFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin "-D_DARWIN_C_SOURCE"; diff --git a/pkgs/by-name/ab/abi-compliance-checker/package.nix b/pkgs/by-name/ab/abi-compliance-checker/package.nix index b5ccb40d5dc4ff..0d4f133ab16f43 100644 --- a/pkgs/by-name/ab/abi-compliance-checker/package.nix +++ b/pkgs/by-name/ab/abi-compliance-checker/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, ctags, perl, binutils, abi-dumper }: +{ + lib, + stdenv, + fetchFromGitHub, + ctags, + perl, + binutils, + abi-dumper, +}: stdenv.mkDerivation rec { pname = "abi-compliance-checker"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { sha256 = "1f1f9j2nf9j83sfl2ljadch99v6ha8rq8xm7ax5akc05hjpyckij"; }; - buildInputs = [ binutils ctags perl ]; + buildInputs = [ + binutils + ctags + perl + ]; propagatedBuildInputs = [ abi-dumper ]; makeFlags = [ "prefix=$(out)" ]; diff --git a/pkgs/by-name/ab/abi-dumper/package.nix b/pkgs/by-name/ab/abi-dumper/package.nix index 09b30b6c623195..27321eb12325a1 100644 --- a/pkgs/by-name/ab/abi-dumper/package.nix +++ b/pkgs/by-name/ab/abi-dumper/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, ctags, perl, elfutils, vtable-dumper }: +{ + lib, + stdenv, + fetchFromGitHub, + ctags, + perl, + elfutils, + vtable-dumper, +}: stdenv.mkDerivation rec { pname = "abi-dumper"; @@ -18,7 +26,12 @@ stdenv.mkDerivation rec { --replace '"ctags"' '"${ctags}/bin/ctags"' ''; - buildInputs = [ elfutils ctags perl vtable-dumper ]; + buildInputs = [ + elfutils + ctags + perl + vtable-dumper + ]; preBuild = "mkdir -p $out"; makeFlags = [ "prefix=$(out)" ]; diff --git a/pkgs/by-name/ab/abiword/package.nix b/pkgs/by-name/ab/abiword/package.nix index f960a41531a3b0..d26ef4b984c9fe 100644 --- a/pkgs/by-name/ab/abiword/package.nix +++ b/pkgs/by-name/ab/abiword/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, autoreconfHook269 -, autoconf-archive -, pkg-config -, gtk3 -, fribidi -, libpng -, popt -, libgsf -, enchant -, wv -, librsvg -, bzip2 -, libjpeg -, perl -, boost -, libxslt -, goffice -, wrapGAppsHook3 -, gitUpdater +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + autoreconfHook269, + autoconf-archive, + pkg-config, + gtk3, + fribidi, + libpng, + popt, + libgsf, + enchant, + wv, + librsvg, + bzip2, + libjpeg, + perl, + boost, + libxslt, + goffice, + wrapGAppsHook3, + gitUpdater, }: stdenv.mkDerivation rec { @@ -80,6 +81,10 @@ stdenv.mkDerivation rec { homepage = "https://gitlab.gnome.org/World/AbiWord/"; license = licenses.gpl3; platforms = platforms.linux; - maintainers = with maintainers; [ pSub ylwghst sna ]; + maintainers = with maintainers; [ + pSub + ylwghst + sna + ]; }; } diff --git a/pkgs/by-name/ab/ablog/package.nix b/pkgs/by-name/ab/ablog/package.nix index cbede853507b36..b119045439579b 100644 --- a/pkgs/by-name/ab/ablog/package.nix +++ b/pkgs/by-name/ab/ablog/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, gitUpdater +{ + lib, + python3, + fetchFromGitHub, + gitUpdater, }: python3.pkgs.buildPythonApplication rec { @@ -38,9 +39,12 @@ python3.pkgs.buildPythonApplication rec { ]; pytestFlagsArray = [ - "-W" "ignore::sphinx.deprecation.RemovedInSphinx90Warning" - "--rootdir" "src/ablog" - "-W" "ignore::sphinx.deprecation.RemovedInSphinx90Warning" # Ignore ImportError + "-W" + "ignore::sphinx.deprecation.RemovedInSphinx90Warning" + "--rootdir" + "src/ablog" + "-W" + "ignore::sphinx.deprecation.RemovedInSphinx90Warning" # Ignore ImportError ]; passthru.updateScript = gitUpdater { rev-prefix = "v"; }; diff --git a/pkgs/by-name/ab/abook/package.nix b/pkgs/by-name/ab/abook/package.nix index 358ecbcef39bab..0fb3850790c7e2 100644 --- a/pkgs/by-name/ab/abook/package.nix +++ b/pkgs/by-name/ab/abook/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, ncurses, readline, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + ncurses, + readline, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "abook"; @@ -17,8 +26,14 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ ncurses readline ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + ncurses + readline + ]; meta = { homepage = "http://abook.sourceforge.net/"; diff --git a/pkgs/by-name/ab/abootimg/package.nix b/pkgs/by-name/ab/abootimg/package.nix index 85181cdf459f0b..a281480a8c261b 100644 --- a/pkgs/by-name/ab/abootimg/package.nix +++ b/pkgs/by-name/ab/abootimg/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, coreutils, cpio, findutils, gzip, makeWrapper, util-linux }: +{ + lib, + stdenv, + fetchFromGitHub, + coreutils, + cpio, + findutils, + gzip, + makeWrapper, + util-linux, +}: stdenv.mkDerivation rec { pname = "abootimg"; @@ -27,10 +37,22 @@ stdenv.mkDerivation rec { install -D -m444 ./debian/abootimg.1 $out/share/man/man1/abootimg.1; install -D -m 755 abootimg-pack-initrd $out/bin - wrapProgram $out/bin/abootimg-pack-initrd --prefix PATH : ${lib.makeBinPath [ coreutils cpio findutils gzip ]} + wrapProgram $out/bin/abootimg-pack-initrd --prefix PATH : ${ + lib.makeBinPath [ + coreutils + cpio + findutils + gzip + ] + } install -D -m 755 abootimg-unpack-initrd $out/bin - wrapProgram $out/bin/abootimg-unpack-initrd --prefix PATH : ${lib.makeBinPath [ cpio gzip ]} + wrapProgram $out/bin/abootimg-unpack-initrd --prefix PATH : ${ + lib.makeBinPath [ + cpio + gzip + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/ab/abuse/package.nix b/pkgs/by-name/ab/abuse/package.nix index 6b46e61aaf1a29..4b621d53d78757 100644 --- a/pkgs/by-name/ab/abuse/package.nix +++ b/pkgs/by-name/ab/abuse/package.nix @@ -1,11 +1,18 @@ -{ lib, stdenv, fetchzip, fetchFromGitHub -, makeDesktopItem, copyDesktopItems -, cmake -, SDL2, SDL2_mixer, freepats +{ + lib, + stdenv, + fetchzip, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + cmake, + SDL2, + SDL2_mixer, + freepats, }: stdenv.mkDerivation (finalAttrs: { - pname = "abuse"; + pname = "abuse"; version = "0.9.1"; src = fetchFromGitHub { @@ -16,7 +23,7 @@ stdenv.mkDerivation (finalAttrs: { }; data = fetchzip { - url = "http://abuse.zoy.org/raw-attachment/wiki/download/abuse-0.8.tar.gz"; + url = "http://abuse.zoy.org/raw-attachment/wiki/download/abuse-0.8.tar.gz"; hash = "sha256-SOrtBNLWskN7Tqa0B3+KjlZlqPjC64Jp02Pk7to2hFg="; }; @@ -24,14 +31,19 @@ stdenv.mkDerivation (finalAttrs: { cp --reflink=auto -r ${finalAttrs.data}/data/sfx ${finalAttrs.data}/data/music data/ ''; - desktopItems = [ (makeDesktopItem { - name = "abuse"; - exec = "abuse"; - icon = "abuse"; - desktopName = "Abuse"; - comment = "Side-scroller action game that pits you against ruthless alien killers"; - categories = [ "Game" "ActionGame" ]; - }) ]; + desktopItems = [ + (makeDesktopItem { + name = "abuse"; + exec = "abuse"; + icon = "abuse"; + desktopName = "Abuse"; + comment = "Side-scroller action game that pits you against ruthless alien killers"; + categories = [ + "Game" + "ActionGame" + ]; + }) + ]; postInstall = '' mkdir $out/etc @@ -46,19 +58,26 @@ stdenv.mkDerivation (finalAttrs: { env.NIX_CFLAGS_COMPILE = "-I${lib.getDev SDL2}/include/SDL2"; - nativeBuildInputs = [ copyDesktopItems cmake ]; - buildInputs = [ SDL2 SDL2_mixer freepats ]; + nativeBuildInputs = [ + copyDesktopItems + cmake + ]; + buildInputs = [ + SDL2 + SDL2_mixer + freepats + ]; meta = { description = "Side-scroller action game that pits you against ruthless alien killers"; - homepage = "http://abuse.zoy.org/"; - license = lib.licenses.unfree; + homepage = "http://abuse.zoy.org/"; + license = lib.licenses.unfree; # Most of abuse is free (public domain, GPL2+, WTFPL), however the creator # of its sfx and music only gave Debian permission to redistribute the # files. Our friends from Debian thought about it some more: # https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=648272 maintainers = with lib.maintainers; [ iblech ]; - platforms = lib.platforms.unix; - broken = stdenv.hostPlatform.isDarwin; + platforms = lib.platforms.unix; + broken = stdenv.hostPlatform.isDarwin; }; }) diff --git a/pkgs/by-name/ac/acc/package.nix b/pkgs/by-name/ac/acc/package.nix index a74227284a900b..894aa7ce588e02 100644 --- a/pkgs/by-name/ac/acc/package.nix +++ b/pkgs/by-name/ac/acc/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { pname = "acc"; diff --git a/pkgs/by-name/ac/accelergy/package.nix b/pkgs/by-name/ac/accelergy/package.nix index 42609ada09a38c..fbbe84894ebc39 100644 --- a/pkgs/by-name/ac/accelergy/package.nix +++ b/pkgs/by-name/ac/accelergy/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "accelergy"; diff --git a/pkgs/by-name/ac/accerciser/package.nix b/pkgs/by-name/ac/accerciser/package.nix index 9aa630085097f4..bc1fcfe1af0251 100644 --- a/pkgs/by-name/ac/accerciser/package.nix +++ b/pkgs/by-name/ac/accerciser/package.nix @@ -1,19 +1,20 @@ -{ lib -, fetchurl -, desktop-file-utils -, meson -, ninja -, pkg-config -, gnome -, gtk3 -, wrapGAppsHook3 -, gobject-introspection -, itstool -, python3 -, at-spi2-core -, gettext -, libwnck -, librsvg +{ + lib, + fetchurl, + desktop-file-utils, + meson, + ninja, + pkg-config, + gnome, + gtk3, + wrapGAppsHook3, + gobject-introspection, + itstool, + python3, + at-spi2-core, + gettext, + libwnck, + librsvg, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ac/accountsservice/package.nix b/pkgs/by-name/ac/accountsservice/package.nix index 1bb42e9c3fe61c..6456657b7afa56 100644 --- a/pkgs/by-name/ac/accountsservice/package.nix +++ b/pkgs/by-name/ac/accountsservice/package.nix @@ -1,29 +1,33 @@ -{ lib -, stdenv -, fetchurl -, substituteAll -, pkg-config -, glib -, shadow -, gobject-introspection -, polkit -, systemd -, coreutils -, meson -, mesonEmulatorHook -, dbus -, ninja -, python3 -, vala -, gettext -, libxcrypt +{ + lib, + stdenv, + fetchurl, + substituteAll, + pkg-config, + glib, + shadow, + gobject-introspection, + polkit, + systemd, + coreutils, + meson, + mesonEmulatorHook, + dbus, + ninja, + python3, + vala, + gettext, + libxcrypt, }: stdenv.mkDerivation rec { pname = "accountsservice"; version = "23.13.9"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "https://www.freedesktop.org/software/accountsservice/accountsservice-${version}.tar.xz"; @@ -52,18 +56,20 @@ stdenv.mkDerivation rec { ./get-dm-type-from-config.patch ]; - nativeBuildInputs = [ - gettext - gobject-introspection - meson - ninja - pkg-config - python3 - vala - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - # meson.build:88:2: ERROR: Can not run test applications in this cross environment. - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + gettext + gobject-introspection + meson + ninja + pkg-config + python3 + vala + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + # meson.build:88:2: ERROR: Can not run test applications in this cross environment. + mesonEmulatorHook + ]; buildInputs = [ dbus @@ -74,13 +80,15 @@ stdenv.mkDerivation rec { libxcrypt ]; - env = lib.optionalAttrs (stdenv.cc.isGNU && (lib.versionAtLeast (lib.getVersion stdenv.cc.cc) "14")) { - NIX_CFLAGS_COMPILE = toString [ - "-Wno-error=deprecated-declarations" - "-Wno-error=implicit-function-declaration" - "-Wno-error=return-mismatch" - ]; - }; + env = + lib.optionalAttrs (stdenv.cc.isGNU && (lib.versionAtLeast (lib.getVersion stdenv.cc.cc) "14")) + { + NIX_CFLAGS_COMPILE = toString [ + "-Wno-error=deprecated-declarations" + "-Wno-error=implicit-function-declaration" + "-Wno-error=return-mismatch" + ]; + }; mesonFlags = [ "-Dadmin_group=wheel" diff --git a/pkgs/by-name/ac/acct/package.nix b/pkgs/by-name/ac/acct/package.nix index 9a363eb8706e03..e92e5b0aeecd81 100644 --- a/pkgs/by-name/ac/acct/package.nix +++ b/pkgs/by-name/ac/acct/package.nix @@ -1,4 +1,8 @@ -{ fetchurl, lib, stdenv }: +{ + fetchurl, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "acct"; diff --git a/pkgs/by-name/ac/accuraterip-checksum/package.nix b/pkgs/by-name/ac/accuraterip-checksum/package.nix index df4dfef93ba1e4..aa4bee62b4b84b 100644 --- a/pkgs/by-name/ac/accuraterip-checksum/package.nix +++ b/pkgs/by-name/ac/accuraterip-checksum/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libsndfile }: +{ + lib, + stdenv, + fetchFromGitHub, + libsndfile, +}: stdenv.mkDerivation rec { pname = "accuraterip-checksum"; diff --git a/pkgs/by-name/ac/ace-of-penguins/package.nix b/pkgs/by-name/ac/ace-of-penguins/package.nix index fb15aedc1df853..137b312bf57ec1 100644 --- a/pkgs/by-name/ac/ace-of-penguins/package.nix +++ b/pkgs/by-name/ac/ace-of-penguins/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, copyDesktopItems -, libX11 -, libXpm -, libpng -, makeDesktopItem -, zlib +{ + lib, + stdenv, + fetchurl, + copyDesktopItems, + libX11, + libXpm, + libpng, + makeDesktopItem, + zlib, }: stdenv.mkDerivation rec { @@ -34,15 +35,16 @@ stdenv.mkDerivation rec { zlib ]; - desktopItems = let - generateItem = gameName: { - name = "${pname}-${gameName}"; - exec = "${placeholder "out"}/bin/${gameName}"; - comment = "Ace of Penguins ${gameName} Card Game"; - desktopName = gameName; - genericName = gameName; - }; - in + desktopItems = + let + generateItem = gameName: { + name = "${pname}-${gameName}"; + exec = "${placeholder "out"}/bin/${gameName}"; + comment = "Ace of Penguins ${gameName} Card Game"; + desktopName = gameName; + genericName = gameName; + }; + in map (x: makeDesktopItem (generateItem x)) [ "canfield" "freecell" diff --git a/pkgs/by-name/ac/ace/package.nix b/pkgs/by-name/ac/ace/package.nix index 01041c8586239f..f3c0ab54164ea8 100644 --- a/pkgs/by-name/ac/ace/package.nix +++ b/pkgs/by-name/ac/ace/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, libtool, perl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libtool, + perl, +}: stdenv.mkDerivation rec { pname = "ace"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - nativeBuildInputs = [ pkg-config libtool ]; + nativeBuildInputs = [ + pkg-config + libtool + ]; buildInputs = [ perl ]; env.NIX_CFLAGS_COMPILE = toString [ diff --git a/pkgs/by-name/ac/acgtk/package.nix b/pkgs/by-name/ac/acgtk/package.nix index 37c7b527a9134d..fd146618c91fe6 100644 --- a/pkgs/by-name/ac/acgtk/package.nix +++ b/pkgs/by-name/ac/acgtk/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitLab, dune_3, ocamlPackages }: +{ + lib, + stdenv, + fetchFromGitLab, + dune_3, + ocamlPackages, +}: stdenv.mkDerivation { @@ -15,10 +21,25 @@ stdenv.mkDerivation { strictDeps = true; - nativeBuildInputs = with ocamlPackages; [ menhir ocaml findlib dune_3 ]; + nativeBuildInputs = with ocamlPackages; [ + menhir + ocaml + findlib + dune_3 + ]; buildInputs = with ocamlPackages; [ - ansiterminal cairo2 cmdliner fmt logs menhirLib mtime ocamlgraph readline sedlex yojson + ansiterminal + cairo2 + cmdliner + fmt + logs + menhirLib + mtime + ocamlgraph + readline + sedlex + yojson ]; buildPhase = '' diff --git a/pkgs/by-name/ac/acltoolkit/package.nix b/pkgs/by-name/ac/acltoolkit/package.nix index b7c42c2a2574af..fe0e8da71cfa84 100644 --- a/pkgs/by-name/ac/acltoolkit/package.nix +++ b/pkgs/by-name/ac/acltoolkit/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonPackage rec { diff --git a/pkgs/by-name/ac/acme/package.nix b/pkgs/by-name/ac/acme/package.nix index 855abe1844d6e4..d1795552dc8d27 100644 --- a/pkgs/by-name/ac/acme/package.nix +++ b/pkgs/by-name/ac/acme/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchsvn }: +{ + lib, + stdenv, + fetchsvn, +}: stdenv.mkDerivation rec { pname = "acme"; diff --git a/pkgs/by-name/ac/acpi/package.nix b/pkgs/by-name/ac/acpi/package.nix index 2b661e57c4cdd7..2d9decc66244e3 100644 --- a/pkgs/by-name/ac/acpi/package.nix +++ b/pkgs/by-name/ac/acpi/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "acpi"; diff --git a/pkgs/by-name/ac/acpic/package.nix b/pkgs/by-name/ac/acpic/package.nix index eeef043f106ee2..246d6aa67904f6 100644 --- a/pkgs/by-name/ac/acpic/package.nix +++ b/pkgs/by-name/ac/acpic/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchPypi -, python3Packages +{ + lib, + fetchPypi, + python3Packages, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ac/acpid/package.nix b/pkgs/by-name/ac/acpid/package.nix index 5326ba578f75e1..0d626b0fad713a 100644 --- a/pkgs/by-name/ac/acpid/package.nix +++ b/pkgs/by-name/ac/acpid/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "acpid"; diff --git a/pkgs/by-name/ac/acpilight/package.nix b/pkgs/by-name/ac/acpilight/package.nix index 91bb8782913186..ec59a260993539 100644 --- a/pkgs/by-name/ac/acpilight/package.nix +++ b/pkgs/by-name/ac/acpilight/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchgit, python3, coreutils }: +{ + lib, + stdenv, + fetchgit, + python3, + coreutils, +}: stdenv.mkDerivation rec { pname = "acpilight"; @@ -10,9 +16,11 @@ stdenv.mkDerivation rec { sha256 = "1r0r3nx6x6vkpal6vci0zaa1n9dfacypldf6k8fxg7919vzxdn1w"; }; - pyenv = python3.withPackages (pythonPackages: with pythonPackages; [ - configargparse - ]); + pyenv = python3.withPackages ( + pythonPackages: with pythonPackages; [ + configargparse + ] + ); postConfigure = '' substituteInPlace 90-backlight.rules --replace /bin ${coreutils}/bin diff --git a/pkgs/by-name/ac/acpitool/package.nix b/pkgs/by-name/ac/acpitool/package.nix index 86b028697bb620..a8096c07a0c570 100644 --- a/pkgs/by-name/ac/acpitool/package.nix +++ b/pkgs/by-name/ac/acpitool/package.nix @@ -1,12 +1,20 @@ -{lib, stdenv, fetchurl, fetchpatch}: +{ + lib, + stdenv, + fetchurl, + fetchpatch, +}: let - acpitool-patch-051-4 = params: fetchpatch rec { - inherit (params) name sha256; - url = "https://salsa.debian.org/debian/acpitool/raw/33e2ef42a663de820457b212ea2925e506df3b88/debian/patches/${name}"; - }; + acpitool-patch-051-4 = + params: + fetchpatch rec { + inherit (params) name sha256; + url = "https://salsa.debian.org/debian/acpitool/raw/33e2ef42a663de820457b212ea2925e506df3b88/debian/patches/${name}"; + }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "acpitool"; version = "0.5.1"; diff --git a/pkgs/by-name/ac/acr/package.nix b/pkgs/by-name/ac/acr/package.nix index 10e60262487039..3b8ba5727c8be9 100644 --- a/pkgs/by-name/ac/acr/package.nix +++ b/pkgs/by-name/ac/acr/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ac/acsccid/package.nix b/pkgs/by-name/ac/acsccid/package.nix index 8bf7ae9480003a..00a07ee90be1e9 100644 --- a/pkgs/by-name/ac/acsccid/package.nix +++ b/pkgs/by-name/ac/acsccid/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, libtool -, gettext -, flex -, perl -, pkg-config -, pcsclite -, libusb1 -, libiconv +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + gettext, + flex, + perl, + pkg-config, + pcsclite, + libusb1, + libiconv, }: stdenv.mkDerivation rec { @@ -34,12 +35,14 @@ stdenv.mkDerivation rec { perl ]; - buildInputs = [ - pcsclite - libusb1 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - ]; + buildInputs = + [ + pcsclite + libusb1 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + ]; configureFlags = [ "--enable-usbdropdir=${placeholder "out"}/pcsc/drivers" diff --git a/pkgs/by-name/ac/action-validator/package.nix b/pkgs/by-name/ac/action-validator/package.nix index 3b7c803dc3bb53..a82c792b1fca18 100644 --- a/pkgs/by-name/ac/action-validator/package.nix +++ b/pkgs/by-name/ac/action-validator/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ac/activate-linux/package.nix b/pkgs/by-name/ac/activate-linux/package.nix index 143e8cf0809f8b..8bc7f83f5d6020 100644 --- a/pkgs/by-name/ac/activate-linux/package.nix +++ b/pkgs/by-name/ac/activate-linux/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, fetchFromGitHub -, lib -, pkg-config -, xorg -, cairo -, wayland -, wayland-protocols -, wayland-scanner -, libconfig +{ + stdenv, + fetchFromGitHub, + lib, + pkg-config, + xorg, + cairo, + wayland, + wayland-protocols, + wayland-scanner, + libconfig, }: stdenv.mkDerivation (finalAttrs: { @@ -64,7 +65,10 @@ stdenv.mkDerivation (finalAttrs: { description = "\"Activate Windows\" watermark ported to Linux"; homepage = "https://github.com/MrGlockenspiel/activate-linux"; license = licenses.gpl3; - maintainers = with maintainers; [ alexnortung donovanglover ]; + maintainers = with maintainers; [ + alexnortung + donovanglover + ]; platforms = platforms.linux; mainProgram = "activate-linux"; }; diff --git a/pkgs/by-name/ac/actkbd/package.nix b/pkgs/by-name/ac/actkbd/package.nix index 175e405155d431..154d50c4d43afe 100644 --- a/pkgs/by-name/ac/actkbd/package.nix +++ b/pkgs/by-name/ac/actkbd/package.nix @@ -1,4 +1,8 @@ -{ fetchurl, lib, stdenv }: +{ + fetchurl, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "actkbd"; diff --git a/pkgs/by-name/ad/ad-ldap-enum/package.nix b/pkgs/by-name/ad/ad-ldap-enum/package.nix index 983746cbcbf907..3b8f074eba3c04 100644 --- a/pkgs/by-name/ad/ad-ldap-enum/package.nix +++ b/pkgs/by-name/ad/ad-ldap-enum/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, python3 +{ + lib, + stdenvNoCC, + fetchFromGitHub, + python3, }: stdenvNoCC.mkDerivation { @@ -15,11 +16,13 @@ stdenvNoCC.mkDerivation { }; buildInputs = [ - (python3.withPackages (ps: with ps; [ - argcomplete - ldap3 - openpyxl - ])) + (python3.withPackages ( + ps: with ps; [ + argcomplete + ldap3 + openpyxl + ] + )) ]; installPhase = '' diff --git a/pkgs/by-name/ad/adafruit-ampy/package.nix b/pkgs/by-name/ad/adafruit-ampy/package.nix index 66a776935049e3..0cf5ba087a4949 100644 --- a/pkgs/by-name/ad/adafruit-ampy/package.nix +++ b/pkgs/by-name/ad/adafruit-ampy/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchPypi }: +{ + lib, + python3, + fetchPypi, +}: with python3.pkgs; @@ -12,7 +16,11 @@ buildPythonApplication rec { }; nativeBuildInputs = [ setuptools-scm ]; - propagatedBuildInputs = [ click python-dotenv pyserial ]; + propagatedBuildInputs = [ + click + python-dotenv + pyserial + ]; # No tests doCheck = false; diff --git a/pkgs/by-name/ad/adafruit-nrfutil/package.nix b/pkgs/by-name/ad/adafruit-nrfutil/package.nix index 09d8aa66377d24..00d0d8052ab061 100644 --- a/pkgs/by-name/ad/adafruit-nrfutil/package.nix +++ b/pkgs/by-name/ad/adafruit-nrfutil/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3Packages -, fetchFromGitHub -, fetchpatch +{ + lib, + python3Packages, + fetchFromGitHub, + fetchpatch, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ad/adalanche/package.nix b/pkgs/by-name/ad/adalanche/package.nix index 109b327333ac93..7b81c370f22cf7 100644 --- a/pkgs/by-name/ad/adalanche/package.nix +++ b/pkgs/by-name/ad/adalanche/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, libpcap +{ + lib, + buildGoModule, + fetchFromGitHub, + libpcap, }: buildGoModule rec { diff --git a/pkgs/by-name/ad/adapta-backgrounds/package.nix b/pkgs/by-name/ad/adapta-backgrounds/package.nix index 417bd7392b5245..109fe4c512ca57 100644 --- a/pkgs/by-name/ad/adapta-backgrounds/package.nix +++ b/pkgs/by-name/ad/adapta-backgrounds/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, pkg-config, glib }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + glib, +}: stdenv.mkDerivation rec { pname = "adapta-backgrounds"; @@ -12,13 +20,20 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; buildInputs = [ glib ]; meta = with lib; { description = "Wallpaper collection for adapta-project"; homepage = "https://github.com/adapta-project/adapta-backgrounds"; - license = with licenses; [ gpl2 cc-by-sa-40 ]; + license = with licenses; [ + gpl2 + cc-by-sa-40 + ]; platforms = platforms.all; maintainers = with maintainers; [ romildo ]; }; diff --git a/pkgs/by-name/ad/adapta-gtk-theme/package.nix b/pkgs/by-name/ad/adapta-gtk-theme/package.nix index 7b9164ef44249b..67d3ffe76968c5 100644 --- a/pkgs/by-name/ad/adapta-gtk-theme/package.nix +++ b/pkgs/by-name/ad/adapta-gtk-theme/package.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, parallel, sassc, inkscape, libxml2, glib, gdk-pixbuf, librsvg, gtk-engine-murrine, gnome-shell }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + parallel, + sassc, + inkscape, + libxml2, + glib, + gdk-pixbuf, + librsvg, + gtk-engine-murrine, + gnome-shell, +}: stdenv.mkDerivation rec { pname = "adapta-gtk-theme"; @@ -42,7 +57,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Adaptive GTK theme based on Material Design Guidelines"; homepage = "https://github.com/adapta-project/adapta-gtk-theme"; - license = with licenses; [ gpl2 cc-by-sa-30 ]; + license = with licenses; [ + gpl2 + cc-by-sa-30 + ]; platforms = platforms.linux; maintainers = [ maintainers.romildo ]; }; diff --git a/pkgs/by-name/ad/adapta-kde-theme/package.nix b/pkgs/by-name/ad/adapta-kde-theme/package.nix index 42d29f8127ed94..67ba82d4255648 100644 --- a/pkgs/by-name/ad/adapta-kde-theme/package.nix +++ b/pkgs/by-name/ad/adapta-kde-theme/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "adapta-kde-theme"; diff --git a/pkgs/by-name/ad/adbfs-rootless/package.nix b/pkgs/by-name/ad/adbfs-rootless/package.nix index e959b88c6c6a0c..4fb50b55eb1a8e 100644 --- a/pkgs/by-name/ad/adbfs-rootless/package.nix +++ b/pkgs/by-name/ad/adbfs-rootless/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, fuse -, android-tools +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + fuse, + android-tools, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ad/adbtuifm/package.nix b/pkgs/by-name/ad/adbtuifm/package.nix index 4fae8a4956575b..f92b0c16653f9e 100644 --- a/pkgs/by-name/ad/adbtuifm/package.nix +++ b/pkgs/by-name/ad/adbtuifm/package.nix @@ -17,8 +17,8 @@ buildGoModule rec { description = "TUI-based file manager for the Android Debug Bridge"; homepage = "https://github.com/darkhz/adbtuifm"; changelog = "https://github.com/darkhz/adbtuifm/releases/tag/v${version}"; - license = with licenses; [mit]; - maintainers = with maintainers; [daru-san]; + license = with licenses; [ mit ]; + maintainers = with maintainers; [ daru-san ]; mainProgram = "adbtuifm"; platforms = platforms.linux; }; diff --git a/pkgs/by-name/ad/addic7ed-cli/package.nix b/pkgs/by-name/ad/addic7ed-cli/package.nix index 9d5fef14bf253e..8cf1b4eaf011ee 100644 --- a/pkgs/by-name/ad/addic7ed-cli/package.nix +++ b/pkgs/by-name/ad/addic7ed-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchPypi +{ + lib, + python3Packages, + fetchPypi, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ad/addlicense/package.nix b/pkgs/by-name/ad/addlicense/package.nix index 532bf3464fb68f..fdff6455a6301f 100644 --- a/pkgs/by-name/ad/addlicense/package.nix +++ b/pkgs/by-name/ad/addlicense/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, }: buildGoModule rec { diff --git a/pkgs/by-name/ad/adementary-theme/package.nix b/pkgs/by-name/ad/adementary-theme/package.nix index 4b47f6c2d3e36c..67aafe49a29946 100644 --- a/pkgs/by-name/ad/adementary-theme/package.nix +++ b/pkgs/by-name/ad/adementary-theme/package.nix @@ -1,13 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, gtk3, sassc }: +{ + lib, + stdenv, + fetchFromGitHub, + gtk3, + sassc, +}: stdenv.mkDerivation rec { pname = "adementary-theme"; version = "201905r1"; src = fetchFromGitHub { - owner = "hrdwrrsk"; - repo = pname; - rev = version; + owner = "hrdwrrsk"; + repo = pname; + rev = version; sha256 = "14y5s18g9r2c1ciw1skfksn09gvqgy8vjvwbr0z8gacf0jc2apqk"; }; @@ -28,9 +34,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Adwaita-based GTK theme with design influence from elementary OS and Vertex GTK theme"; - homepage = "https://github.com/hrdwrrsk/adementary-theme"; - license = licenses.gpl3; + homepage = "https://github.com/hrdwrrsk/adementary-theme"; + license = licenses.gpl3; maintainers = [ ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/ad/adenum/package.nix b/pkgs/by-name/ad/adenum/package.nix index d547bd5c9ebcf1..3b79044ca6365b 100644 --- a/pkgs/by-name/ad/adenum/package.nix +++ b/pkgs/by-name/ad/adenum/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, john -, python3 +{ + lib, + fetchFromGitHub, + john, + python3, }: python3.pkgs.buildPythonApplication { @@ -16,13 +17,16 @@ python3.pkgs.buildPythonApplication { hash = "sha256-8s4Kmt4ZjYbQGGVDWKfuRZ6kthcL8FiQytoq9Koy7Kc="; }; - propagatedBuildInputs = with python3.pkgs; [ - impacket - pwntools - python-ldap - ] ++ [ - john - ]; + propagatedBuildInputs = + with python3.pkgs; + [ + impacket + pwntools + python-ldap + ] + ++ [ + john + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/ad/adguardian/package.nix b/pkgs/by-name/ad/adguardian/package.nix index 425974fee511e2..855ba2d459f468 100644 --- a/pkgs/by-name/ad/adguardian/package.nix +++ b/pkgs/by-name/ad/adguardian/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ad/adi1090x-plymouth-themes/package.nix b/pkgs/by-name/ad/adi1090x-plymouth-themes/package.nix index d5ff1d0018a9a9..5aa7e78ac11a87 100644 --- a/pkgs/by-name/ad/adi1090x-plymouth-themes/package.nix +++ b/pkgs/by-name/ad/adi1090x-plymouth-themes/package.nix @@ -5,59 +5,63 @@ unzip, # To select only certain themes, pass `selected_themes` as a list of strings. # reference ./shas.nix for available themes - selected_themes ? [], -}: let + selected_themes ? [ ], +}: +let version = "1.0"; # this file is generated via ./update.sh # borrowed from pkgs/data/fonts/nerdfonts themeShas = import ./shas.nix; knownThemes = builtins.attrNames themeShas; selectedThemes = - if (selected_themes == []) - then knownThemes - else let - unknown = lib.subtractLists knownThemes selected_themes; - in - if (unknown != []) - then throw "Unknown theme(s): ${lib.concatStringsSep " " unknown}" - else selected_themes; + if (selected_themes == [ ]) then + knownThemes + else + let + unknown = lib.subtractLists knownThemes selected_themes; + in + if (unknown != [ ]) then + throw "Unknown theme(s): ${lib.concatStringsSep " " unknown}" + else + selected_themes; srcs = lib.lists.forEach selectedThemes ( - name: (fetchurl { + name: + (fetchurl { url = themeShas.${name}.url; sha256 = themeShas.${name}.sha; }) ); in - stdenv.mkDerivation { - pname = "adi1090x-plymouth-themes"; - inherit version srcs; +stdenv.mkDerivation { + pname = "adi1090x-plymouth-themes"; + inherit version srcs; - nativeBuildInputs = [ - unzip - ]; + nativeBuildInputs = [ + unzip + ]; - sourceRoot = "."; - unpackCmd = "tar xzf $curSrc"; + sourceRoot = "."; + unpackCmd = "tar xzf $curSrc"; - installPhase = '' - mkdir -p $out/share/plymouth/themes - for theme in ${toString selectedThemes}; do - mv $theme $out/share/plymouth/themes/$theme - done - find $out/share/plymouth/themes/ -name \*.plymouth -exec sed -i "s@\/usr\/@$out\/@" {} \; - ''; + installPhase = '' + mkdir -p $out/share/plymouth/themes + for theme in ${toString selectedThemes}; do + mv $theme $out/share/plymouth/themes/$theme + done + find $out/share/plymouth/themes/ -name \*.plymouth -exec sed -i "s@\/usr\/@$out\/@" {} \; + ''; - meta = with lib; { - description = "Plymouth boot themes from adi1090x"; - longDescription = '' - A variety of plymouth boot screens by adi1090x. Using the default value - of `selected_themes` will install all themes (~524M). Consider overriding - this with a list of the string names of each theme to install. Check - ./shas.nix for available themes. - ''; - homepage = "https://github.com/adi1090x/plymouth-themes"; - license = licenses.gpl3; - platforms = platforms.linux; - maintainers = with maintainers; [slwst]; - }; - } + meta = with lib; { + description = "Plymouth boot themes from adi1090x"; + longDescription = '' + A variety of plymouth boot screens by adi1090x. Using the default value + of `selected_themes` will install all themes (~524M). Consider overriding + this with a list of the string names of each theme to install. Check + ./shas.nix for available themes. + ''; + homepage = "https://github.com/adi1090x/plymouth-themes"; + license = licenses.gpl3; + platforms = platforms.linux; + maintainers = with maintainers; [ slwst ]; + }; +} diff --git a/pkgs/by-name/ad/adidnsdump/package.nix b/pkgs/by-name/ad/adidnsdump/package.nix index dc2268d892d9f3..97b568ab074aa5 100644 --- a/pkgs/by-name/ad/adidnsdump/package.nix +++ b/pkgs/by-name/ad/adidnsdump/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ad/adif-multitool/package.nix b/pkgs/by-name/ad/adif-multitool/package.nix index 8dc0f816513bf5..16a607c8ddd037 100644 --- a/pkgs/by-name/ad/adif-multitool/package.nix +++ b/pkgs/by-name/ad/adif-multitool/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "adif-multitool"; diff --git a/pkgs/by-name/ad/adl/package.nix b/pkgs/by-name/ad/adl/package.nix index 46e2bc492a87bf..0412846962fc07 100644 --- a/pkgs/by-name/ad/adl/package.nix +++ b/pkgs/by-name/ad/adl/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, makeWrapper -, animdl -, frece -, fzf -, mpv -, perl -, trackma -, ueberzug -, ... +{ + lib, + stdenvNoCC, + fetchFromGitHub, + makeWrapper, + animdl, + frece, + fzf, + mpv, + perl, + trackma, + ueberzug, + ... }: stdenvNoCC.mkDerivation rec { pname = "adl"; diff --git a/pkgs/by-name/ad/adminer/package.nix b/pkgs/by-name/ad/adminer/package.nix index e77aac26641e0b..78a4f0ef6f8563 100644 --- a/pkgs/by-name/ad/adminer/package.nix +++ b/pkgs/by-name/ad/adminer/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, php, nix-update-script }: +{ + lib, + stdenv, + fetchurl, + php, + nix-update-script, +}: stdenv.mkDerivation rec { version = "4.8.1"; @@ -39,7 +45,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Database management in a single PHP file"; homepage = "https://www.adminer.org"; - license = with licenses; [ asl20 gpl2Only ]; + license = with licenses; [ + asl20 + gpl2Only + ]; maintainers = with maintainers; [ jtojnar sstef diff --git a/pkgs/by-name/ad/adminerevo/package.nix b/pkgs/by-name/ad/adminerevo/package.nix index 398d007671002e..d286331b0b609e 100644 --- a/pkgs/by-name/ad/adminerevo/package.nix +++ b/pkgs/by-name/ad/adminerevo/package.nix @@ -1,11 +1,12 @@ -{ lib -, pkgs -, stdenvNoCC -, fetchFromGitHub -, php -, nix-update-script -, theme ? null -, plugins ? [] +{ + lib, + pkgs, + stdenvNoCC, + fetchFromGitHub, + php, + nix-update-script, + theme ? null, + plugins ? [ ], }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -47,7 +48,7 @@ stdenvNoCC.mkDerivation (finalAttrs: { mkdir -p $out/plugins cp plugins/plugin.php $out/plugins/plugin.php - ${lib.optionalString (plugins != []) '' + ${lib.optionalString (plugins != [ ]) '' cp plugins/*.php $out/plugins/ cp ${pkgs.writeText "$out/plugins.json" '' ${toString (builtins.toJSON plugins)} @@ -64,7 +65,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { meta = with lib; { description = "Database management in a single PHP file"; homepage = "https://docs.adminerevo.org"; - license = with licenses; [ asl20 gpl2Only ]; + license = with licenses; [ + asl20 + gpl2Only + ]; maintainers = with maintainers; [ shyim ]; diff --git a/pkgs/by-name/ad/adms/package.nix b/pkgs/by-name/ad/adms/package.nix index 7b7e2a1af63a1c..9546378e01b209 100644 --- a/pkgs/by-name/ad/adms/package.nix +++ b/pkgs/by-name/ad/adms/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, flex, bison, gperf, - libxml2, perl, perlPackages, gd }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + flex, + bison, + gperf, + libxml2, + perl, + perlPackages, + gd, +}: stdenv.mkDerivation rec { version = "2.3.7"; @@ -13,14 +24,22 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ flex bison gperf libxml2 perl gd perlPackages.XMLLibXML ]; + buildInputs = [ + flex + bison + gperf + libxml2 + perl + gd + perlPackages.XMLLibXML + ]; configureFlags = [ "--enable-maintainer-mode" ]; meta = { description = "automatic device model synthesizer"; homepage = "https://github.com/Qucs/adms"; license = lib.licenses.gpl3; - maintainers = with lib.maintainers; [disassembler]; + maintainers = with lib.maintainers; [ disassembler ]; platforms = with lib.platforms; linux; }; } diff --git a/pkgs/by-name/ad/adns/package.nix b/pkgs/by-name/ad/adns/package.nix index eeb6c07bf11d09..22088853570a57 100644 --- a/pkgs/by-name/ad/adns/package.nix +++ b/pkgs/by-name/ad/adns/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, gnum4, gitUpdater }: +{ + stdenv, + lib, + fetchurl, + gnum4, + gitUpdater, +}: stdenv.mkDerivation rec { pname = "adns"; @@ -16,8 +22,7 @@ stdenv.mkDerivation rec { configureFlags = lib.optional stdenv.hostPlatform.isStatic "--disable-dynamic"; - preConfigure = - lib.optionalString stdenv.hostPlatform.isDarwin "sed -i -e 's|-Wl,-soname=$(SHLIBSONAME)||' configure"; + preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin "sed -i -e 's|-Wl,-soname=$(SHLIBSONAME)||' configure"; # Autogenerated headers miss interdependencies in Makefile, fail parallel build: # https://debbugs.gnu.org/cgi/bugreport.cgi?bug=51329 @@ -26,10 +31,13 @@ stdenv.mkDerivation rec { # https://www.mail-archive.com/nix-dev@cs.uu.nl/msg01347.html for details. doCheck = false; - postInstall = let suffix = lib.versions.majorMinor version; - in lib.optionalString stdenv.hostPlatform.isDarwin '' - install_name_tool -id $out/lib/libadns.so.${suffix} $out/lib/libadns.so.${suffix} - ''; + postInstall = + let + suffix = lib.versions.majorMinor version; + in + lib.optionalString stdenv.hostPlatform.isDarwin '' + install_name_tool -id $out/lib/libadns.so.${suffix} $out/lib/libadns.so.${suffix} + ''; # darwin executables fail, but I don't want to fail the 100-500 packages depending on this lib doInstallCheck = !stdenv.hostPlatform.isDarwin; diff --git a/pkgs/by-name/ad/adreaper/package.nix b/pkgs/by-name/ad/adreaper/package.nix index bf5bb470f3ec0b..77c6129d3ea370 100644 --- a/pkgs/by-name/ad/adreaper/package.nix +++ b/pkgs/by-name/ad/adreaper/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ad/adrgen/package.nix b/pkgs/by-name/ad/adrgen/package.nix index caa3af446b0a44..e018fd97c08327 100644 --- a/pkgs/by-name/ad/adrgen/package.nix +++ b/pkgs/by-name/ad/adrgen/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch -, testers -, adrgen +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + testers, + adrgen, }: buildGoModule rec { diff --git a/pkgs/by-name/ad/adriconf/package.nix b/pkgs/by-name/ad/adriconf/package.nix index fae7c99b8a81be..6f69fe466fc953 100644 --- a/pkgs/by-name/ad/adriconf/package.nix +++ b/pkgs/by-name/ad/adriconf/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitLab -, cmake -, pkg-config -, libdrm -, libGL -, atkmm -, pcre -, gtkmm4 -, pugixml -, mesa -, pciutils +{ + stdenv, + lib, + fetchFromGitLab, + cmake, + pkg-config, + libdrm, + libGL, + atkmm, + pcre, + gtkmm4, + pugixml, + mesa, + pciutils, }: stdenv.mkDerivation rec { @@ -25,8 +26,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-0XTsYeS4tNAnGhuJ81fmjHhFS6fVq1lirui5b+ojxTQ="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libdrm libGL atkmm pcre gtkmm4 pugixml mesa pciutils ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + libdrm + libGL + atkmm + pcre + gtkmm4 + pugixml + mesa + pciutils + ]; cmakeFlags = [ "-DENABLE_UNIT_TESTS=off" ]; diff --git a/pkgs/by-name/ad/adrs/package.nix b/pkgs/by-name/ad/adrs/package.nix index 6cd0994989473f..5282a8a9dc8af2 100644 --- a/pkgs/by-name/ad/adrs/package.nix +++ b/pkgs/by-name/ad/adrs/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = { description = "Command-line tool for managing Architectural Decision Records"; homepage = "https://github.com/joshrotenberg/adrs"; - license = with lib.licenses; [ mit asl20 ]; + license = with lib.licenses; [ + mit + asl20 + ]; maintainers = with lib.maintainers; [ dannixon ]; mainProgram = "adrs"; }; diff --git a/pkgs/by-name/ad/adslib/package.nix b/pkgs/by-name/ad/adslib/package.nix index 49b54960b7e685..4b3baa6c80015e 100644 --- a/pkgs/by-name/ad/adslib/package.nix +++ b/pkgs/by-name/ad/adslib/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "adslib"; diff --git a/pkgs/by-name/ad/advancecomp/package.nix b/pkgs/by-name/ad/advancecomp/package.nix index 8175b3a1da8aa0..fe6d79f732ca87 100644 --- a/pkgs/by-name/ad/advancecomp/package.nix +++ b/pkgs/by-name/ad/advancecomp/package.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + zlib, }: stdenv.mkDerivation rec { @@ -27,7 +29,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Set of tools to optimize deflate-compressed files"; - license = licenses.gpl3 ; + license = licenses.gpl3; maintainers = [ maintainers.raskin ]; platforms = platforms.linux ++ platforms.darwin; homepage = "https://github.com/amadvance/advancecomp"; diff --git a/pkgs/by-name/ad/adwaita-icon-theme/package.nix b/pkgs/by-name/ad/adwaita-icon-theme/package.nix index f4bf4257c4a342..567c1e1527a939 100644 --- a/pkgs/by-name/ad/adwaita-icon-theme/package.nix +++ b/pkgs/by-name/ad/adwaita-icon-theme/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, gnome -, gtk3 -, gdk-pixbuf -, librsvg -, hicolor-icon-theme +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + gnome, + gtk3, + gdk-pixbuf, + librsvg, + hicolor-icon-theme, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ad/adwsteamgtk/package.nix b/pkgs/by-name/ad/adwsteamgtk/package.nix index 0dbd582a163f97..2baa58d3c93bc2 100644 --- a/pkgs/by-name/ad/adwsteamgtk/package.nix +++ b/pkgs/by-name/ad/adwsteamgtk/package.nix @@ -1,13 +1,14 @@ -{ blueprint-compiler -, desktop-file-utils -, fetchFromGitHub -, lib -, libadwaita -, libportal-gtk4 -, meson -, ninja -, python3Packages -, wrapGAppsHook4 +{ + blueprint-compiler, + desktop-file-utils, + fetchFromGitHub, + lib, + libadwaita, + libportal-gtk4, + meson, + ninja, + python3Packages, + wrapGAppsHook4, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ae/aefs/package.nix b/pkgs/by-name/ae/aefs/package.nix index c56a4b189e1521..024601c772fd98 100644 --- a/pkgs/by-name/ae/aefs/package.nix +++ b/pkgs/by-name/ae/aefs/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, fuse -, git +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + fuse, + git, }: stdenv.mkDerivation { @@ -27,7 +28,10 @@ stdenv.mkDerivation { # $ grep -R FUSE_USE_VERSION configureFlags = lib.optional stdenv.hostPlatform.isDarwin "CPPFLAGS=-DFUSE_USE_VERSION=26"; - nativeBuildInputs = [ autoreconfHook git ]; + nativeBuildInputs = [ + autoreconfHook + git + ]; buildInputs = [ fuse ]; diff --git a/pkgs/by-name/ae/aemu/package.nix b/pkgs/by-name/ae/aemu/package.nix index c39c68cbce1e4f..03722e15320c6c 100644 --- a/pkgs/by-name/ae/aemu/package.nix +++ b/pkgs/by-name/ae/aemu/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitiles, cmake, darwin }: +{ + lib, + stdenv, + fetchFromGitiles, + cmake, + darwin, +}: stdenv.mkDerivation { pname = "aemu"; @@ -33,8 +39,17 @@ stdenv.mkDerivation { maintainers = with maintainers; [ qyliss ]; # The BSD license comes from host-common/VpxFrameParser.cpp, which # incorporates some code from libvpx, which uses the 3-clause BSD license. - license = with licenses; [ asl20 mit bsd3 ]; + license = with licenses; [ + asl20 + mit + bsd3 + ]; # See base/include/aemu/base/synchronization/Lock.h - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; }; } diff --git a/pkgs/by-name/ae/aerc/package.nix b/pkgs/by-name/ae/aerc/package.nix index 6291681a4fbf3a..4fae126d3c0d3b 100644 --- a/pkgs/by-name/ae/aerc/package.nix +++ b/pkgs/by-name/ae/aerc/package.nix @@ -1,14 +1,15 @@ -{ lib -, buildGoModule -, fetchFromSourcehut -, fetchpatch -, ncurses -, notmuch -, scdoc -, python3Packages -, w3m -, dante -, gawk +{ + lib, + buildGoModule, + fetchFromSourcehut, + fetchpatch, + ncurses, + notmuch, + scdoc, + python3Packages, + w3m, + dante, + gawk, }: buildGoModule rec { @@ -35,7 +36,7 @@ buildGoModule rec { # patch to fix a encoding problem with gpg signed messages (fetchpatch { - url ="https://git.sr.ht/~rjarry/aerc/commit/7346d20.patch"; + url = "https://git.sr.ht/~rjarry/aerc/commit/7346d20.patch"; hash = "sha256-OCm8BcovYN2IDSgslZklQxkGVkSYQ8HLCrf2+DRB2mM="; }) ]; @@ -55,7 +56,11 @@ buildGoModule rec { python3Packages.vobject ]; - buildInputs = [ python3Packages.python notmuch gawk ]; + buildInputs = [ + python3Packages.python + notmuch + gawk + ]; installPhase = '' runHook preInstall @@ -69,9 +74,19 @@ buildGoModule rec { wrapProgram $out/bin/aerc \ --prefix PATH : ${lib.makeBinPath [ ncurses ]} wrapProgram $out/libexec/aerc/filters/html \ - --prefix PATH : ${lib.makeBinPath [ w3m dante ]} + --prefix PATH : ${ + lib.makeBinPath [ + w3m + dante + ] + } wrapProgram $out/libexec/aerc/filters/html-unsafe \ - --prefix PATH : ${lib.makeBinPath [ w3m dante ]} + --prefix PATH : ${ + lib.makeBinPath [ + w3m + dante + ] + } patchShebangs $out/libexec/aerc/filters ''; diff --git a/pkgs/by-name/ae/aeron-cpp/package.nix b/pkgs/by-name/ae/aeron-cpp/package.nix index 630a94d9b49197..4504ed3d27813b 100644 --- a/pkgs/by-name/ae/aeron-cpp/package.nix +++ b/pkgs/by-name/ae/aeron-cpp/package.nix @@ -11,7 +11,7 @@ makeWrapper, patchelf, stdenv, - zlib + zlib, }: let @@ -125,4 +125,3 @@ stdenv.mkDerivation { ]; }; } - diff --git a/pkgs/by-name/ae/aeron/package.nix b/pkgs/by-name/ae/aeron/package.nix index 2addc87feaa8ec..e24a4db1c01226 100644 --- a/pkgs/by-name/ae/aeron/package.nix +++ b/pkgs/by-name/ae/aeron/package.nix @@ -3,7 +3,7 @@ stdenv, fetchMavenArtifact, jdk11, - makeWrapper + makeWrapper, }: let @@ -70,7 +70,8 @@ let aeronAll = aeronAll_1_44_1; aeronSamples = aeronSamples_1_44_1; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname version; diff --git a/pkgs/by-name/ae/aerospike/package.nix b/pkgs/by-name/ae/aerospike/package.nix index 239e7cf675373f..b75d281b3126f2 100644 --- a/pkgs/by-name/ae/aerospike/package.nix +++ b/pkgs/by-name/ae/aerospike/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, cmake, libtool, openssl, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + cmake, + libtool, + openssl, + zlib, +}: stdenv.mkDerivation rec { pname = "aerospike-server"; @@ -12,8 +22,16 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ autoconf automake cmake libtool ]; - buildInputs = [ openssl zlib ]; + nativeBuildInputs = [ + autoconf + automake + cmake + libtool + ]; + buildInputs = [ + openssl + zlib + ]; dontUseCmakeConfigure = true; diff --git a/pkgs/by-name/ae/aescrypt/package.nix b/pkgs/by-name/ae/aescrypt/package.nix index 2517724c8c3926..14cbc18efac564 100644 --- a/pkgs/by-name/ae/aescrypt/package.nix +++ b/pkgs/by-name/ae/aescrypt/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libiconv }: +{ + lib, + stdenv, + fetchurl, + libiconv, +}: stdenv.mkDerivation rec { version = "3.16"; @@ -16,7 +21,7 @@ stdenv.mkDerivation rec { cd src ''; - installPhase= '' + installPhase = '' mkdir -p $out/bin cp aescrypt $out/bin cp aescrypt_keygen $out/bin @@ -26,10 +31,13 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Encrypt files with Advanced Encryption Standard (AES)"; - homepage = "https://www.aescrypt.com/"; - license = licenses.gpl2Only; - maintainers = with maintainers; [ lovek323 qknight ]; - platforms = lib.platforms.all; + homepage = "https://www.aescrypt.com/"; + license = licenses.gpl2Only; + maintainers = with maintainers; [ + lovek323 + qknight + ]; + platforms = lib.platforms.all; hydraPlatforms = with platforms; unix; }; } diff --git a/pkgs/by-name/ae/aesfix/package.nix b/pkgs/by-name/ae/aesfix/package.nix index fed9ace264c46b..4a48a5c553e5be 100644 --- a/pkgs/by-name/ae/aesfix/package.nix +++ b/pkgs/by-name/ae/aesfix/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ae/aeskeyfind/package.nix b/pkgs/by-name/ae/aeskeyfind/package.nix index 4ce27f5eca6605..5a472b82e7b690 100644 --- a/pkgs/by-name/ae/aeskeyfind/package.nix +++ b/pkgs/by-name/ae/aeskeyfind/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { @@ -28,4 +29,3 @@ stdenv.mkDerivation rec { }; } - diff --git a/pkgs/by-name/ae/aespipe/package.nix b/pkgs/by-name/ae/aespipe/package.nix index 83586253cd6392..1538490c19278a 100644 --- a/pkgs/by-name/ae/aespipe/package.nix +++ b/pkgs/by-name/ae/aespipe/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, sharutils, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + sharutils, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "aespipe"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; - configureFlags = [ "--enable-padlock" "--enable-intelaes" ]; + configureFlags = [ + "--enable-padlock" + "--enable-intelaes" + ]; postInstall = '' cp bz2aespipe $out/bin diff --git a/pkgs/by-name/ae/aether-lv2/package.nix b/pkgs/by-name/ae/aether-lv2/package.nix index afec5763022d38..f82464b18404fa 100644 --- a/pkgs/by-name/ae/aether-lv2/package.nix +++ b/pkgs/by-name/ae/aether-lv2/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, lv2, libX11, libGL, libGLU, mesa, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + lv2, + libX11, + libGL, + libGLU, + mesa, + cmake, +}: stdenv.mkDerivation rec { pname = "aether-lv2"; @@ -15,7 +25,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; buildInputs = [ - lv2 libX11 libGL libGLU mesa + lv2 + libX11 + libGL + libGLU + mesa ]; env.NIX_CFLAGS_COMPILE = toString [ diff --git a/pkgs/by-name/ae/aewan/package.nix b/pkgs/by-name/ae/aewan/package.nix index dcc59560a246df..6a93cc9de7744d 100644 --- a/pkgs/by-name/ae/aewan/package.nix +++ b/pkgs/by-name/ae/aewan/package.nix @@ -1,6 +1,14 @@ -{ lib, gccStdenv, fetchurl, fetchpatch, zlib, ncurses }: +{ + lib, + gccStdenv, + fetchurl, + fetchpatch, + zlib, + ncurses, +}: -let stdenv = gccStdenv; +let + stdenv = gccStdenv; in stdenv.mkDerivation rec { pname = "aewan"; @@ -22,7 +30,10 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ zlib ncurses ]; + buildInputs = [ + zlib + ncurses + ]; meta = { description = "Ascii-art Editor Without A Name"; diff --git a/pkgs/by-name/af/afetch/package.nix b/pkgs/by-name/af/afetch/package.nix index 9413666372df35..a959d0786420cb 100644 --- a/pkgs/by-name/af/afetch/package.nix +++ b/pkgs/by-name/af/afetch/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, lib -, fetchFromGitHub +{ + stdenv, + lib, + fetchFromGitHub, }: stdenv.mkDerivation rec { @@ -22,7 +23,10 @@ stdenv.mkDerivation rec { description = "Fetch program written in C"; homepage = "https://github.com/13-CF/afetch"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ dan4ik605743 jk ]; + maintainers = with maintainers; [ + dan4ik605743 + jk + ]; platforms = platforms.linux; mainProgram = "afetch"; }; diff --git a/pkgs/by-name/af/afew/package.nix b/pkgs/by-name/af/afew/package.nix index 993b9862fb2f51..912f7ec3d301c8 100644 --- a/pkgs/by-name/af/afew/package.nix +++ b/pkgs/by-name/af/afew/package.nix @@ -1,4 +1,11 @@ -{ lib, python3Packages, fetchPypi, pkgs, testers, afew }: +{ + lib, + python3Packages, + fetchPypi, + pkgs, + testers, + afew, +}: python3Packages.buildPythonApplication rec { pname = "afew"; @@ -28,12 +35,14 @@ python3Packages.buildPythonApplication rec { setuptools ]; - nativeCheckInputs = [ - pkgs.notmuch - ] ++ (with python3Packages; [ - freezegun - pytestCheckHook - ]); + nativeCheckInputs = + [ + pkgs.notmuch + ] + ++ (with python3Packages; [ + freezegun + pytestCheckHook + ]); makeWrapperArgs = [ ''--prefix PATH ':' "${pkgs.notmuch}/bin"'' diff --git a/pkgs/by-name/af/afflib/package.nix b/pkgs/by-name/af/afflib/package.nix index eff94a276cd84c..2457279e6b58a5 100644 --- a/pkgs/by-name/af/afflib/package.nix +++ b/pkgs/by-name/af/afflib/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, zlib, curl, expat, fuse, openssl -, autoreconfHook, python3, libiconv +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + curl, + expat, + fuse, + openssl, + autoreconfHook, + python3, + libiconv, }: stdenv.mkDerivation rec { @@ -14,7 +24,14 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ zlib curl expat openssl python3 ] + buildInputs = + [ + zlib + curl + expat + openssl + python3 + ] ++ lib.optionals (with stdenv; isLinux || isDarwin) [ fuse ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; diff --git a/pkgs/by-name/af/afio/package.nix b/pkgs/by-name/af/afio/package.nix index 4f01c1c58ba6cf..c33888ee293f5a 100644 --- a/pkgs/by-name/af/afio/package.nix +++ b/pkgs/by-name/af/afio/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch } : +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { version = "2.5.2"; @@ -13,9 +18,9 @@ stdenv.mkDerivation rec { patches = [ /* - * A patch to simplify the installation and for removing the - * hard coded dependency on GCC. - */ + A patch to simplify the installation and for removing the + hard coded dependency on GCC. + */ ./0001-makefile-fix-installation.patch # fix darwin build (include headers) @@ -33,10 +38,10 @@ stdenv.mkDerivation rec { description = "Fault tolerant cpio archiver targeting backups"; platforms = lib.platforms.all; /* - * Licensing is complicated due to the age of the code base, but - * generally free. See the file ``afio_license_issues_v5.txt`` for - * a comprehensive discussion. - */ + Licensing is complicated due to the age of the code base, but + generally free. See the file ``afio_license_issues_v5.txt`` for + a comprehensive discussion. + */ license = lib.licenses.free; mainProgram = "afio"; }; diff --git a/pkgs/by-name/af/afpfs-ng/package.nix b/pkgs/by-name/af/afpfs-ng/package.nix index 10d7c46080f3bd..75199dda96e99a 100644 --- a/pkgs/by-name/af/afpfs-ng/package.nix +++ b/pkgs/by-name/af/afpfs-ng/package.nix @@ -1,13 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, fuse, readline, libgcrypt, gmp }: +{ + lib, + stdenv, + fetchFromGitHub, + fuse, + readline, + libgcrypt, + gmp, +}: stdenv.mkDerivation { pname = "afpfs-ng"; version = "0.8.2"; src = fetchFromGitHub { - owner = "simonvetter"; - repo = "afpfs-ng"; - rev = "f6e24eb73c9283732c3b5d9cb101a1e2e4fade3e"; + owner = "simonvetter"; + repo = "afpfs-ng"; + rev = "f6e24eb73c9283732c3b5d9cb101a1e2e4fade3e"; sha256 = "125jx1rsqkiifcffyjb05b2s36rllckdgjaf1bay15k9gzhwwldz"; }; @@ -17,14 +25,19 @@ stdenv.mkDerivation { # `full_url'; afpcmd-cmdline_afp.o:/build/source/cmdline/cmdline_afp.c:27: first defined here env.NIX_CFLAGS_COMPILE = "-fcommon"; - buildInputs = [ fuse readline libgcrypt gmp ]; + buildInputs = [ + fuse + readline + libgcrypt + gmp + ]; meta = with lib; { - homepage = "https://github.com/simonvetter/afpfs-ng"; + homepage = "https://github.com/simonvetter/afpfs-ng"; description = "Client implementation of the Apple Filing Protocol"; - license = licenses.gpl2Only; + license = licenses.gpl2Only; maintainers = with maintainers; [ rnhmjoj ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/af/aften/package.nix b/pkgs/by-name/af/aften/package.nix index 8dd01cc4eabe33..36e14954197653 100644 --- a/pkgs/by-name/af/aften/package.nix +++ b/pkgs/by-name/af/aften/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, cmake }: +{ + lib, + stdenv, + fetchurl, + cmake, +}: stdenv.mkDerivation rec { pname = "aften"; diff --git a/pkgs/by-name/af/afterburn/package.nix b/pkgs/by-name/af/afterburn/package.nix index 918a9ab7fc200a..13388b785ce5e7 100644 --- a/pkgs/by-name/af/afterburn/package.nix +++ b/pkgs/by-name/af/afterburn/package.nix @@ -1,4 +1,10 @@ -{ lib, openssl, pkg-config, fetchFromGitHub, rustPlatform }: +{ + lib, + openssl, + pkg-config, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "afterburn"; diff --git a/pkgs/by-name/af/afterglow-cursors-recolored/package.nix b/pkgs/by-name/af/afterglow-cursors-recolored/package.nix index 801e2eca40a98d..94f8460645fe53 100644 --- a/pkgs/by-name/af/afterglow-cursors-recolored/package.nix +++ b/pkgs/by-name/af/afterglow-cursors-recolored/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, themeVariants ? [] -, catppuccinColorVariants ? [] -, draculaColorVariants ? [] -, gruvboxColorVariants ? [] -, originalColorVariants ? [] +{ + lib, + stdenvNoCC, + fetchFromGitHub, + themeVariants ? [ ], + catppuccinColorVariants ? [ ], + draculaColorVariants ? [ ], + gruvboxColorVariants ? [ ], + originalColorVariants ? [ ], }: let @@ -68,59 +69,75 @@ let in lib.checkListOfEnum "${pname}: theme variants" availableThemeVariants themeVariants -lib.checkListOfEnum "${pname}: catppuccin color variants" availableColorVariants.Catppuccin catppuccinColorVariants -lib.checkListOfEnum "${pname}: dracula color variants" availableColorVariants.Dracula draculaColorVariants -lib.checkListOfEnum "${pname}: gruvbox color variants" availableColorVariants.Gruvbox gruvboxColorVariants -lib.checkListOfEnum "${pname}: original color variants" availableColorVariants.Original originalColorVariants + lib.checkListOfEnum + "${pname}: catppuccin color variants" + availableColorVariants.Catppuccin + catppuccinColorVariants + lib.checkListOfEnum + "${pname}: dracula color variants" + availableColorVariants.Dracula + draculaColorVariants + lib.checkListOfEnum + "${pname}: gruvbox color variants" + availableColorVariants.Gruvbox + gruvboxColorVariants + lib.checkListOfEnum + "${pname}: original color variants" + availableColorVariants.Original + originalColorVariants -stdenvNoCC.mkDerivation { - inherit pname; - version = "0-unstable-2023-10-04"; + stdenvNoCC.mkDerivation + { + inherit pname; + version = "0-unstable-2023-10-04"; - src = fetchFromGitHub { - owner = "TeddyBearKilla"; - repo = "Afterglow-Cursors-Recolored"; - rev = "940a5d30e52f8c827fa249d2bbcc4af889534888"; - hash = "sha256-GR+d+jrbeIGpqal5krx83PxuQto2PQTO3unQ+jaJf6s="; - }; - - installPhase = let - dist = { - Catppuccin = "cat"; - Dracula = "dracula"; - Gruvbox = "gruvbox"; - }; - withAlternate = xs: xs': if xs != [ ] then xs else xs'; - themeVariants' = withAlternate themeVariants availableThemeVariants; - colorVariants = { - Catppuccin = withAlternate catppuccinColorVariants availableColorVariants.Catppuccin; - Dracula = withAlternate draculaColorVariants availableColorVariants.Dracula; - Gruvbox = withAlternate gruvboxColorVariants availableColorVariants.Gruvbox; - Original = withAlternate originalColorVariants availableColorVariants.Original; + src = fetchFromGitHub { + owner = "TeddyBearKilla"; + repo = "Afterglow-Cursors-Recolored"; + rev = "940a5d30e52f8c827fa249d2bbcc4af889534888"; + hash = "sha256-GR+d+jrbeIGpqal5krx83PxuQto2PQTO3unQ+jaJf6s="; }; - in '' - runHook preInstall - mkdir -p $out/share/icons + installPhase = + let + dist = { + Catppuccin = "cat"; + Dracula = "dracula"; + Gruvbox = "gruvbox"; + }; + withAlternate = xs: xs': if xs != [ ] then xs else xs'; + themeVariants' = withAlternate themeVariants availableThemeVariants; + colorVariants = { + Catppuccin = withAlternate catppuccinColorVariants availableColorVariants.Catppuccin; + Dracula = withAlternate draculaColorVariants availableColorVariants.Dracula; + Gruvbox = withAlternate gruvboxColorVariants availableColorVariants.Gruvbox; + Original = withAlternate originalColorVariants availableColorVariants.Original; + }; + in + '' + runHook preInstall - ${ - lib.concatMapStringsSep "\n" (theme: - lib.concatMapStringsSep "\n" (color: '' - ln -s \ - "$src/colors/${theme}/${color}/dist-${lib.optionalString (theme != "Original") (dist.${theme} + "-")}${lib.toLower color}" \ - "$out/share/icons/Afterglow-Recolored-${theme}-${color}" - '') colorVariants.${theme} - ) themeVariants' - } + mkdir -p $out/share/icons - runHook postInstall - ''; + ${lib.concatMapStringsSep "\n" ( + theme: + lib.concatMapStringsSep "\n" (color: '' + ln -s \ + "$src/colors/${theme}/${color}/dist-${ + lib.optionalString (theme != "Original") (dist.${theme} + "-") + }${lib.toLower color}" \ + "$out/share/icons/Afterglow-Recolored-${theme}-${color}" + '') colorVariants.${theme} + ) themeVariants'} - meta = with lib; { - description = "Recoloring of the Afterglow Cursors x-cursor theme"; - homepage = "https://github.com/TeddyBearKilla/Afterglow-Cursors-Recolored"; - maintainers = with maintainers; [ d3vil0p3r ]; - platforms = platforms.all; - license = licenses.gpl3Plus; - }; -} + runHook postInstall + ''; + + meta = with lib; { + description = "Recoloring of the Afterglow Cursors x-cursor theme"; + homepage = "https://github.com/TeddyBearKilla/Afterglow-Cursors-Recolored"; + maintainers = with maintainers; [ d3vil0p3r ]; + platforms = platforms.all; + license = licenses.gpl3Plus; + }; + } diff --git a/pkgs/by-name/af/afterstep/package.nix b/pkgs/by-name/af/afterstep/package.nix index 6f93f8e1d6a257..efab01fe76ea8d 100644 --- a/pkgs/by-name/af/afterstep/package.nix +++ b/pkgs/by-name/af/afterstep/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, dbus -, fltk13 -, gtk2 -, libICE -, libSM -, libtiff -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + dbus, + fltk13, + gtk2, + libICE, + libSM, + libtiff, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { @@ -58,7 +59,10 @@ stdenv.mkDerivation (finalAttrs: { libtiff ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; strictDeps = true; diff --git a/pkgs/by-name/ag/agave/package.nix b/pkgs/by-name/ag/agave/package.nix index cd0344afb3592f..8aa0b901903479 100644 --- a/pkgs/by-name/ag/agave/package.nix +++ b/pkgs/by-name/ag/agave/package.nix @@ -1,21 +1,28 @@ -{ lib, fetchurl, stdenv }: +{ + lib, + fetchurl, + stdenv, +}: let pname = "agave"; version = "37"; - mkAg = name: hash: fetchurl { - url = "https://github.com/agarick/agave/releases/download/v${version}/Agave-${name}.ttf"; - sha256 = hash; - name = "Agave-${name}.ttf"; - }; + mkAg = + name: hash: + fetchurl { + url = "https://github.com/agarick/agave/releases/download/v${version}/Agave-${name}.ttf"; + sha256 = hash; + name = "Agave-${name}.ttf"; + }; # There are slashed variants, but with same name so only bundle the default versions for now: fonts = [ (mkAg "Regular" "sha256-vX1VhEgqy9rQ7hPmAgBGxKyIs2QSAYqZC/mL/2BIOrA=") (mkAg "Bold" "sha256-Ax/l/RKyc03law0ThiLac/7HHV4+YxibKzcZnjZs6VI=") ]; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname version; srcs = fonts; sourceRoot = "."; @@ -34,4 +41,3 @@ in stdenv.mkDerivation { platforms = platforms.all; }; } - diff --git a/pkgs/by-name/ag/agdsn-zsh-config/package.nix b/pkgs/by-name/ag/agdsn-zsh-config/package.nix index 8dae2edf21b6fd..e430f3c69ccba4 100644 --- a/pkgs/by-name/ag/agdsn-zsh-config/package.nix +++ b/pkgs/by-name/ag/agdsn-zsh-config/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "agdsn-zsh-config"; diff --git a/pkgs/by-name/ag/age-plugin-fido2-hmac/package.nix b/pkgs/by-name/ag/age-plugin-fido2-hmac/package.nix index 6c9571a64d05fb..70effd886ea999 100644 --- a/pkgs/by-name/ag/age-plugin-fido2-hmac/package.nix +++ b/pkgs/by-name/ag/age-plugin-fido2-hmac/package.nix @@ -5,7 +5,7 @@ stdenv, libfido2, openssl, - libcbor + libcbor, }: let darwin_arch = if stdenv.hostPlatform.system == "aarch64-darwin" then "arm64" else "amd64"; @@ -35,7 +35,11 @@ buildGoModule rec { vendorHash = "sha256-h4/tyq9oZt41IfRJmmsLHUpJiPJ7YuFu59ccM7jHsFo="; - ldflags = [ "-s" "-w" "-X main.version=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=v${version}" + ]; buildInputs = [ libfido2 ]; diff --git a/pkgs/by-name/ag/age-plugin-tpm/package.nix b/pkgs/by-name/ag/age-plugin-tpm/package.nix index f95f761c580b30..0e8dc385600dab 100644 --- a/pkgs/by-name/ag/age-plugin-tpm/package.nix +++ b/pkgs/by-name/ag/age-plugin-tpm/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, swtpm -, openssl +{ + lib, + buildGoModule, + fetchFromGitHub, + swtpm, + openssl, }: buildGoModule rec { @@ -39,6 +40,9 @@ buildGoModule rec { homepage = "https://github.com/Foxboron/age-plugin-tpm"; license = licenses.mit; platforms = platforms.linux; - maintainers = with maintainers; [ kranzes sgo ]; + maintainers = with maintainers; [ + kranzes + sgo + ]; }; } diff --git a/pkgs/by-name/ag/age-plugin-yubikey/package.nix b/pkgs/by-name/ag/age-plugin-yubikey/package.nix index 590dd6d495a9a2..4c0446e586fd49 100644 --- a/pkgs/by-name/ag/age-plugin-yubikey/package.nix +++ b/pkgs/by-name/ag/age-plugin-yubikey/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, pcsclite -, apple-sdk_11 +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + pcsclite, + apple-sdk_11, }: rustPlatform.buildRustPackage rec { @@ -30,18 +31,26 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ pcsclite ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ apple-sdk_11 ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ pcsclite ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ apple-sdk_11 ]; meta = with lib; { description = "YubiKey plugin for age"; mainProgram = "age-plugin-yubikey"; homepage = "https://github.com/str4d/age-plugin-yubikey"; changelog = "https://github.com/str4d/age-plugin-yubikey/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ mit asl20 ]; - maintainers = with maintainers; [ kranzes vtuan10 adamcstephens ]; + license = with licenses; [ + mit + asl20 + ]; + maintainers = with maintainers; [ + kranzes + vtuan10 + adamcstephens + ]; }; } diff --git a/pkgs/by-name/ag/age/package.nix b/pkgs/by-name/ag/age/package.nix index 89acb4d14c334a..c02c64538177f9 100644 --- a/pkgs/by-name/ag/age/package.nix +++ b/pkgs/by-name/ag/age/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + installShellFiles, +}: buildGoModule rec { pname = "age"; @@ -14,7 +20,9 @@ buildGoModule rec { vendorHash = "sha256-5We4OYoexzzSF1AkxuGCUwuYJ3Wra+T6mCcT4XYgzhU="; ldflags = [ - "-s" "-w" "-X main.Version=${version}" + "-s" + "-w" + "-X main.Version=${version}" ]; nativeBuildInputs = [ installShellFiles ]; @@ -35,7 +43,8 @@ buildGoModule rec { # plugin test is flaky, see https://github.com/FiloSottile/age/issues/517 checkFlags = [ - "-skip" "TestScript/plugin" + "-skip" + "TestScript/plugin" ]; meta = with lib; { diff --git a/pkgs/by-name/ag/agedu/package.nix b/pkgs/by-name/ag/agedu/package.nix index 7024e166c9f885..24509c5e00307c 100644 --- a/pkgs/by-name/ag/agedu/package.nix +++ b/pkgs/by-name/ag/agedu/package.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchgit -, cmake -, halibut +{ + lib, + stdenv, + fetchgit, + cmake, + halibut, }: let date = "20241013"; @@ -18,20 +20,23 @@ stdenv.mkDerivation { hash = "sha256-ZU2bVVo//mAVtVtrKPQ20wZHip/AZPmlL2uaCBcc7rw="; }; - nativeBuildInputs = [ cmake halibut ]; + nativeBuildInputs = [ + cmake + halibut + ]; meta = with lib; { description = "Unix utility for tracking down wasted disk space"; longDescription = '' - Most Unix file systems, in their default mode, helpfully record when a - file was last accessed. So if you generated a large amount of data years - ago, forgot to clean it up, and have never used it since, then it ought - in principle to be possible to use those last-access time stamps to tell - the difference between that and a large amount of data you're still - using regularly. + Most Unix file systems, in their default mode, helpfully record when a + file was last accessed. So if you generated a large amount of data years + ago, forgot to clean it up, and have never used it since, then it ought + in principle to be possible to use those last-access time stamps to tell + the difference between that and a large amount of data you're still + using regularly. - agedu uses this information to tell you which files waste disk space when - you haven't used them since a long time. + agedu uses this information to tell you which files waste disk space when + you haven't used them since a long time. ''; homepage = "https://www.chiark.greenend.org.uk/~sgtatham/agedu/"; license = licenses.mit; diff --git a/pkgs/by-name/ag/agenda/package.nix b/pkgs/by-name/ag/agenda/package.nix index 8d06589cb4166b..31e4f160488c7f 100644 --- a/pkgs/by-name/ag/agenda/package.nix +++ b/pkgs/by-name/ag/agenda/package.nix @@ -1,17 +1,19 @@ -{ lib, stdenv -, fetchFromGitHub -, nix-update-script -, pantheon -, meson -, ninja -, python3 -, pkg-config -, vala -, gettext -, glib -, gtk3 -, libgee -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pantheon, + meson, + ninja, + python3, + pkg-config, + vala, + gettext, + glib, + gtk3, + libgee, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -63,4 +65,3 @@ stdenv.mkDerivation rec { mainProgram = "com.github.dahenson.agenda"; }; } - diff --git a/pkgs/by-name/ag/agi/package.nix b/pkgs/by-name/ag/agi/package.nix index 7ffdd959b2ec02..7287cd9eba102e 100644 --- a/pkgs/by-name/ag/agi/package.nix +++ b/pkgs/by-name/ag/agi/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenvNoCC -, fetchzip -, autoPatchelfHook -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, wrapGAppsHook3 -, gobject-introspection -, gdk-pixbuf -, jre -, android-tools +{ + lib, + stdenvNoCC, + fetchzip, + autoPatchelfHook, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + wrapGAppsHook3, + gobject-introspection, + gdk-pixbuf, + jre, + android-tools, }: stdenvNoCC.mkDerivation rec { @@ -59,7 +60,12 @@ stdenvNoCC.mkDerivation rec { desktopName = "Android GPU Inspector"; exec = "agi"; icon = "agi"; - categories = [ "Development" "Debugger" "Graphics" "3DGraphics" ]; + categories = [ + "Development" + "Debugger" + "Graphics" + "3DGraphics" + ]; }); meta = with lib; { diff --git a/pkgs/by-name/ag/agkozak-zsh-prompt/package.nix b/pkgs/by-name/ag/agkozak-zsh-prompt/package.nix index 899cda1a5ea5fc..30ce835feda983 100644 --- a/pkgs/by-name/ag/agkozak-zsh-prompt/package.nix +++ b/pkgs/by-name/ag/agkozak-zsh-prompt/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchFromGitHub }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "agkozak-zsh-prompt"; diff --git a/pkgs/by-name/ag/agola/package.nix b/pkgs/by-name/ag/agola/package.nix index e5f59a784910be..65eac2d281e18c 100644 --- a/pkgs/by-name/ag/agola/package.nix +++ b/pkgs/by-name/ag/agola/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: let diff --git a/pkgs/by-name/ag/ags/package.nix b/pkgs/by-name/ag/ags/package.nix index f47dca9aaad48b..09efa681b42ab9 100644 --- a/pkgs/by-name/ag/ags/package.nix +++ b/pkgs/by-name/ag/ags/package.nix @@ -63,7 +63,7 @@ buildNpmPackage rec { chmod u+x ./post_install.sh && patchShebangs ./post_install.sh ''; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = { homepage = "https://github.com/Aylur/ags"; diff --git a/pkgs/by-name/ah/aha/package.nix b/pkgs/by-name/ah/aha/package.nix index 9a545a7f3f31bf..279f148e135928 100644 --- a/pkgs/by-name/ah/aha/package.nix +++ b/pkgs/by-name/ah/aha/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "aha"; @@ -23,7 +27,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://github.com/theZiz/aha"; changelog = "https://github.com/theZiz/aha/blob/${version}/CHANGELOG"; - license = with licenses; [ lgpl2Plus mpl11 ]; + license = with licenses; [ + lgpl2Plus + mpl11 + ]; maintainers = with maintainers; [ pSub ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/ah/ahcpd/package.nix b/pkgs/by-name/ah/ahcpd/package.nix index f6f483602c1f38..054fbb4c36543f 100644 --- a/pkgs/by-name/ah/ahcpd/package.nix +++ b/pkgs/by-name/ah/ahcpd/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ahcpd"; diff --git a/pkgs/by-name/ah/ahoviewer/package.nix b/pkgs/by-name/ah/ahoviewer/package.nix index eaec49ec89bba6..cf1f95645ffd3e 100644 --- a/pkgs/by-name/ah/ahoviewer/package.nix +++ b/pkgs/by-name/ah/ahoviewer/package.nix @@ -1,7 +1,22 @@ -{ config, lib, stdenv, fetchFromGitHub, pkg-config, libconfig -, gtkmm2, glibmm, libxml2, libsecret, curl, libzip -, librsvg, gst_all_1, autoreconfHook, makeWrapper -, useUnrar ? config.ahoviewer.useUnrar or false, unrar +{ + config, + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libconfig, + gtkmm2, + glibmm, + libxml2, + libsecret, + curl, + libzip, + librsvg, + gst_all_1, + autoreconfHook, + makeWrapper, + useUnrar ? config.ahoviewer.useUnrar or false, + unrar, }: assert useUnrar -> unrar != null; @@ -19,10 +34,21 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - nativeBuildInputs = [ autoreconfHook pkg-config makeWrapper ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + makeWrapper + ]; buildInputs = [ - glibmm libconfig gtkmm2 glibmm libxml2 - libsecret curl libzip librsvg + glibmm + libconfig + gtkmm2 + glibmm + libxml2 + libsecret + curl + libzip + librsvg gst_all_1.gstreamer gst_all_1.gst-plugins-good gst_all_1.gst-libav @@ -50,5 +76,3 @@ stdenv.mkDerivation rec { platforms = platforms.linux; }; } - - diff --git a/pkgs/by-name/ai/aiac/package.nix b/pkgs/by-name/ai/aiac/package.nix index ab03b5dac0c692..82b3238ccbb864 100644 --- a/pkgs/by-name/ai/aiac/package.nix +++ b/pkgs/by-name/ai/aiac/package.nix @@ -1,9 +1,13 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "aiac"; version = "5.3.0"; - excludedPackages = [".ci"]; + excludedPackages = [ ".ci" ]; src = fetchFromGitHub { owner = "gofireflyio"; @@ -13,7 +17,11 @@ buildGoModule rec { }; vendorHash = "sha256-uXYin6JITpy3bc7FI/3aJqvCD9cGwGL1qjB8hBUWLQE="; - ldflags = [ "-s" "-w" "-X github.com/gofireflyio/aiac/v4/libaiac.Version=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/gofireflyio/aiac/v4/libaiac.Version=v${version}" + ]; meta = with lib; { description = ''Artificial Intelligence Infrastructure-as-Code Generator.''; diff --git a/pkgs/by-name/ai/aide/package.nix b/pkgs/by-name/ai/aide/package.nix index 6abfd72864f206..43a9849688de51 100644 --- a/pkgs/by-name/ai/aide/package.nix +++ b/pkgs/by-name/ai/aide/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchurl, flex, bison, libmhash, zlib, acl, attr, libselinux, pcre2, pkg-config, libgcrypt }: +{ + lib, + stdenv, + fetchurl, + flex, + bison, + libmhash, + zlib, + acl, + attr, + libselinux, + pcre2, + pkg-config, + libgcrypt, +}: stdenv.mkDerivation rec { pname = "aide"; @@ -9,7 +23,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-FmYtxjLRfixWMLgBdS+XkSqOIml8Bl694XXxzDe4OmA="; }; - buildInputs = [ flex bison libmhash zlib acl attr libselinux pcre2 libgcrypt ]; + buildInputs = [ + flex + bison + libmhash + zlib + acl + attr + libselinux + pcre2 + libgcrypt + ]; nativeBuildInputs = [ pkg-config ]; @@ -18,7 +42,7 @@ stdenv.mkDerivation rec { "--with-selinux" "--with-xattr" "--sysconfdir=/etc" - ]; + ]; meta = with lib; { homepage = "https://aide.github.io/"; diff --git a/pkgs/by-name/ai/aiger/package.nix b/pkgs/by-name/ai/aiger/package.nix index 5b9e8f62aa01c9..32869907085672 100644 --- a/pkgs/by-name/ai/aiger/package.nix +++ b/pkgs/by-name/ai/aiger/package.nix @@ -1,11 +1,16 @@ -{ lib, stdenv, fetchurl, picosat }: +{ + lib, + stdenv, + fetchurl, + picosat, +}: stdenv.mkDerivation rec { pname = "aiger"; version = "1.9.9"; src = fetchurl { - url = "https://fmv.jku.at/aiger/${pname}-${version}.tar.gz"; + url = "https://fmv.jku.at/aiger/${pname}-${version}.tar.gz"; sha256 = "1ish0dw0nf9gyghxsdhpy1jjiy5wp54c993swp85xp7m6vdx6l0y"; }; @@ -48,13 +53,17 @@ stdenv.mkDerivation rec { cp -v aiger.h $dev/include ''; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; meta = { description = "And-Inverter Graph (AIG) utilities"; - homepage = "https://fmv.jku.at/aiger/"; - license = lib.licenses.mit; + homepage = "https://fmv.jku.at/aiger/"; + license = lib.licenses.mit; maintainers = with lib.maintainers; [ thoughtpolice ]; - platforms = lib.platforms.unix; + platforms = lib.platforms.unix; }; } diff --git a/pkgs/by-name/ai/aileron/package.nix b/pkgs/by-name/ai/aileron/package.nix index a178d1e82366fb..f57c084e6eb518 100644 --- a/pkgs/by-name/ai/aileron/package.nix +++ b/pkgs/by-name/ai/aileron/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "0"; @@ -26,7 +30,10 @@ stdenvNoCC.mkDerivation { homepage = "http://dotcolon.net/font/aileron/"; description = "Helvetica font in nine weights"; platforms = platforms.all; - maintainers = with maintainers; [ leenaars minijackson ]; + maintainers = with maintainers; [ + leenaars + minijackson + ]; license = licenses.cc0; }; } diff --git a/pkgs/by-name/ai/ain/package.nix b/pkgs/by-name/ai/ain/package.nix index b5fd8cbf9c4d39..3b6d29815fc989 100644 --- a/pkgs/by-name/ai/ain/package.nix +++ b/pkgs/by-name/ai/ain/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ai/aiodnsbrute/package.nix b/pkgs/by-name/ai/aiodnsbrute/package.nix index 0c2f6512d878f6..ce66080a27b17e 100644 --- a/pkgs/by-name/ai/aiodnsbrute/package.nix +++ b/pkgs/by-name/ai/aiodnsbrute/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ai/airbuddy/package.nix b/pkgs/by-name/ai/airbuddy/package.nix index 19c1ada4408a7e..78d011ee528952 100644 --- a/pkgs/by-name/ai/airbuddy/package.nix +++ b/pkgs/by-name/ai/airbuddy/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, _7zz +{ + lib, + stdenvNoCC, + fetchurl, + _7zz, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -44,6 +45,9 @@ stdenvNoCC.mkDerivation (finalAttrs: { license = with licenses; [ unfree ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; maintainers = with maintainers; [ stepbrobd ]; - platforms = [ "aarch64-darwin" "x86_64-darwin" ]; + platforms = [ + "aarch64-darwin" + "x86_64-darwin" + ]; }; }) diff --git a/pkgs/by-name/ai/aircrack-ng/package.nix b/pkgs/by-name/ai/aircrack-ng/package.nix index b1ee7012573917..fdc2284305e839 100644 --- a/pkgs/by-name/ai/aircrack-ng/package.nix +++ b/pkgs/by-name/ai/aircrack-ng/package.nix @@ -1,40 +1,41 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchzip -, makeWrapper -, autoreconfHook -, pkg-config -, openssl -, libgcrypt -, cmocka -, expect -, sqlite -, pcre2 +{ + lib, + stdenv, + fetchFromGitHub, + fetchzip, + makeWrapper, + autoreconfHook, + pkg-config, + openssl, + libgcrypt, + cmocka, + expect, + sqlite, + pcre2, # Linux -, libpcap -, zlib -, wirelesstools -, iw -, ethtool -, pciutils -, libnl -, usbutils -, tcpdump -, hostapd -, wpa_supplicant -, screen + libpcap, + zlib, + wirelesstools, + iw, + ethtool, + pciutils, + libnl, + usbutils, + tcpdump, + hostapd, + wpa_supplicant, + screen, # Cygwin -, libiconv + libiconv, # options -, enableExperimental ? true -, useGcrypt ? false -, enableAirolib ? true -, enableRegex ? true -, useAirpcap ? stdenv.hostPlatform.isCygwin + enableExperimental ? true, + useGcrypt ? false, + enableAirolib ? true, + enableRegex ? true, + useAirpcap ? stdenv.hostPlatform.isCygwin, }: let airpcap-sdk = fetchzip { @@ -58,9 +59,13 @@ stdenv.mkDerivation rec { }; postPatch = lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace lib/osdep/linux.c --replace-warn /usr/local/bin ${lib.escapeShellArg (lib.makeBinPath [ - wirelesstools - ])} + substituteInPlace lib/osdep/linux.c --replace-warn /usr/local/bin ${ + lib.escapeShellArg ( + lib.makeBinPath [ + wirelesstools + ] + ) + } ''; configureFlags = [ @@ -69,35 +74,73 @@ stdenv.mkDerivation rec { (lib.withFeatureAs useAirpcap "airpcap" airpcap-sdk) ]; - nativeBuildInputs = [ pkg-config makeWrapper autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + autoreconfHook + ]; buildInputs = lib.singleton (if useGcrypt then libgcrypt else openssl) - ++ lib.optionals stdenv.hostPlatform.isLinux [ libpcap zlib libnl iw ethtool pciutils ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libpcap + zlib + libnl + iw + ethtool + pciutils + ] ++ lib.optional (stdenv.hostPlatform.isCygwin && stdenv.hostPlatform.isClang) libiconv ++ lib.optional enableAirolib sqlite ++ lib.optional enableRegex pcre2 ++ lib.optional useAirpcap airpcap-sdk; - nativeCheckInputs = [ cmocka expect ]; + nativeCheckInputs = [ + cmocka + expect + ]; postFixup = lib.optionalString stdenv.hostPlatform.isLinux '' - wrapProgram "$out/bin/airmon-ng" --prefix PATH : ${lib.escapeShellArg (lib.makeBinPath [ - ethtool - iw - pciutils - usbutils - ])} + wrapProgram "$out/bin/airmon-ng" --prefix PATH : ${ + lib.escapeShellArg ( + lib.makeBinPath [ + ethtool + iw + pciutils + usbutils + ] + ) + } ''; installCheckTarget = "integration"; - nativeInstallCheckInputs = [ cmocka expect ] ++ lib.optionals stdenv.hostPlatform.isLinux [ tcpdump hostapd wpa_supplicant screen ]; + nativeInstallCheckInputs = + [ + cmocka + expect + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + tcpdump + hostapd + wpa_supplicant + screen + ]; meta = { description = "WiFi security auditing tools suite"; homepage = "https://www.aircrack-ng.org/"; license = lib.licenses.gpl2Plus; maintainers = with lib.maintainers; [ caralice ]; - platforms = with lib.platforms; builtins.concatLists [ linux darwin cygwin netbsd openbsd freebsd illumos ]; + platforms = + with lib.platforms; + builtins.concatLists [ + linux + darwin + cygwin + netbsd + openbsd + freebsd + illumos + ]; changelog = "https://github.com/aircrack-ng/aircrack-ng/blob/${src.rev}/ChangeLog"; }; } diff --git a/pkgs/by-name/ai/airgeddon/package.nix b/pkgs/by-name/ai/airgeddon/package.nix index a79cf2f70abd9d..cea1d37fd4932f 100644 --- a/pkgs/by-name/ai/airgeddon/package.nix +++ b/pkgs/by-name/ai/airgeddon/package.nix @@ -1,111 +1,117 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, # Required -, aircrack-ng -, bash -, coreutils-full -, gawk -, gnugrep -, gnused -, iproute2 -, iw -, pciutils -, procps -, tmux + aircrack-ng, + bash, + coreutils-full, + gawk, + gnugrep, + gnused, + iproute2, + iw, + pciutils, + procps, + tmux, # X11 Front -, xterm -, xorg + xterm, + xorg, # what the author calls "Internals" -, usbutils -, wget -, ethtool -, util-linux -, ccze + usbutils, + wget, + ethtool, + util-linux, + ccze, # Optionals # Missing in nixpkgs: beef, hostapd-wpe -, asleap -, bettercap -, bully -, crunch -, dnsmasq -, ettercap -, hashcat -, hcxdumptool -, hcxtools -, hostapd -, john -, lighttpd -, mdk4 -, nftables -, openssl -, pixiewps -, reaverwps-t6x # Could be the upstream version too -, wireshark-cli + asleap, + bettercap, + bully, + crunch, + dnsmasq, + ettercap, + hashcat, + hcxdumptool, + hcxtools, + hostapd, + john, + lighttpd, + mdk4, + nftables, + openssl, + pixiewps, + reaverwps-t6x, # Could be the upstream version too + wireshark-cli, # Undocumented requirements (there is also ping) -, apparmor-bin-utils -, curl -, glibc -, ncurses -, networkmanager -, systemd + apparmor-bin-utils, + curl, + glibc, + ncurses, + networkmanager, + systemd, # Support groups -, supportWpaWps ? true # Most common use-case -, supportHashCracking ? false -, supportEvilTwin ? false -, supportX11 ? false # Allow using xterm instead of tmux, hard to test + supportWpaWps ? true, # Most common use-case + supportHashCracking ? false, + supportEvilTwin ? false, + supportX11 ? false, # Allow using xterm instead of tmux, hard to test }: let - deps = [ - aircrack-ng - bash - coreutils-full - curl - gawk - glibc - gnugrep - gnused - iproute2 - iw - networkmanager - ncurses - pciutils - procps - tmux - usbutils - wget - ethtool - util-linux - ccze - systemd - ] ++ lib.optionals supportWpaWps [ - bully - pixiewps - reaverwps-t6x - ] ++ lib.optionals supportHashCracking [ - asleap - crunch - hashcat - hcxdumptool - hcxtools - john - wireshark-cli - ] ++ lib.optionals supportEvilTwin [ - bettercap - dnsmasq - ettercap - hostapd - lighttpd - openssl - mdk4 - nftables - apparmor-bin-utils - ] ++ lib.optionals supportX11 [ - xterm - xorg.xset - xorg.xdpyinfo - ]; + deps = + [ + aircrack-ng + bash + coreutils-full + curl + gawk + glibc + gnugrep + gnused + iproute2 + iw + networkmanager + ncurses + pciutils + procps + tmux + usbutils + wget + ethtool + util-linux + ccze + systemd + ] + ++ lib.optionals supportWpaWps [ + bully + pixiewps + reaverwps-t6x + ] + ++ lib.optionals supportHashCracking [ + asleap + crunch + hashcat + hcxdumptool + hcxtools + john + wireshark-cli + ] + ++ lib.optionals supportEvilTwin [ + bettercap + dnsmasq + ettercap + hostapd + lighttpd + openssl + mdk4 + nftables + apparmor-bin-utils + ] + ++ lib.optionals supportX11 [ + xterm + xorg.xset + xorg.xdpyinfo + ]; in stdenv.mkDerivation rec { pname = "airgeddon"; diff --git a/pkgs/by-name/ai/airlift/package.nix b/pkgs/by-name/ai/airlift/package.nix index 1293a70cdb950a..6f52867db78e56 100644 --- a/pkgs/by-name/ai/airlift/package.nix +++ b/pkgs/by-name/ai/airlift/package.nix @@ -1,9 +1,10 @@ -{ lib -, python3 -, fetchPypi -, kubernetes-helm -, kind -, docker +{ + lib, + python3, + fetchPypi, + kubernetes-helm, + kind, + docker, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ai/airscan/package.nix b/pkgs/by-name/ai/airscan/package.nix index e6001b44f3efe2..bdc11a12677041 100644 --- a/pkgs/by-name/ai/airscan/package.nix +++ b/pkgs/by-name/ai/airscan/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/ai/airsonic/package.nix b/pkgs/by-name/ai/airsonic/package.nix index 0089ee33c27dd9..2bf56ce8f6533a 100644 --- a/pkgs/by-name/ai/airsonic/package.nix +++ b/pkgs/by-name/ai/airsonic/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, nixosTests }: +{ + lib, + stdenv, + fetchurl, + nixosTests, +}: stdenv.mkDerivation rec { pname = "airsonic"; diff --git a/pkgs/by-name/ai/airspy/package.nix b/pkgs/by-name/ai/airspy/package.nix index 3c1fa511aef776..c6f19b1a47bd4c 100644 --- a/pkgs/by-name/ai/airspy/package.nix +++ b/pkgs/by-name/ai/airspy/package.nix @@ -1,5 +1,10 @@ -{ stdenv, lib, fetchFromGitHub -, cmake , pkg-config, libusb1 +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + libusb1, }: stdenv.mkDerivation rec { @@ -17,11 +22,13 @@ stdenv.mkDerivation rec { substituteInPlace airspy-tools/CMakeLists.txt --replace "/etc/udev/rules.d" "$out/etc/udev/rules.d" ''; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libusb1 ]; - cmakeFlags = - lib.optionals stdenv.hostPlatform.isLinux [ "-DINSTALL_UDEV_RULES=ON" ]; + cmakeFlags = lib.optionals stdenv.hostPlatform.isLinux [ "-DINSTALL_UDEV_RULES=ON" ]; meta = with lib; { homepage = "https://github.com/airspy/airspyone_host"; diff --git a/pkgs/by-name/ai/airspyhf/package.nix b/pkgs/by-name/ai/airspyhf/package.nix index a54e8441e36bae..67e45c6f4ec5b7 100644 --- a/pkgs/by-name/ai/airspyhf/package.nix +++ b/pkgs/by-name/ai/airspyhf/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, libusb1 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libusb1, +}: stdenv.mkDerivation rec { pname = "airspyhf"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-RKTMEDPeKcerJZtXTn8eAShxDcZUMgeQg/+7pEpMyVg="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libusb1 ]; diff --git a/pkgs/by-name/ai/airstrike/package.nix b/pkgs/by-name/ai/airstrike/package.nix index 5772b3d0036f4f..53fdb6529c75f4 100644 --- a/pkgs/by-name/ai/airstrike/package.nix +++ b/pkgs/by-name/ai/airstrike/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, makeWrapper, SDL, SDL_image }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + SDL, + SDL_image, +}: stdenv.mkDerivation rec { pname = "airstrike-pre"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ SDL SDL_image ]; + buildInputs = [ + SDL + SDL_image + ]; NIX_LDFLAGS = "-lm"; diff --git a/pkgs/by-name/ai/airwindows-lv2/package.nix b/pkgs/by-name/ai/airwindows-lv2/package.nix index d392db72ca2def..ea906cb3a2177f 100644 --- a/pkgs/by-name/ai/airwindows-lv2/package.nix +++ b/pkgs/by-name/ai/airwindows-lv2/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromSourcehut, meson, ninja, pkg-config, lv2 }: +{ + lib, + stdenv, + fetchFromSourcehut, + meson, + ninja, + pkg-config, + lv2, +}: stdenv.mkDerivation rec { pname = "airwindows-lv2"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-1GWkdNCn98ttsF2rPLZE0+GJdatgkLewFQyx9Frr2sM="; }; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; buildInputs = [ lv2 ]; meta = with lib; { diff --git a/pkgs/by-name/ai/aixlog/package.nix b/pkgs/by-name/ai/aixlog/package.nix index 282b62702c7555..cade21695e9584 100644 --- a/pkgs/by-name/ai/aixlog/package.nix +++ b/pkgs/by-name/ai/aixlog/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/aj/aj-snapshot/package.nix b/pkgs/by-name/aj/aj-snapshot/package.nix index 8de68bca477ca4..9e98fc09dd3107 100644 --- a/pkgs/by-name/aj/aj-snapshot/package.nix +++ b/pkgs/by-name/aj/aj-snapshot/package.nix @@ -1,7 +1,15 @@ -{ lib, stdenv, fetchurl, alsa-lib, jack2, minixml, pkg-config }: +{ + lib, + stdenv, + fetchurl, + alsa-lib, + jack2, + minixml, + pkg-config, +}: stdenv.mkDerivation rec { - pname = "aj-snapshot" ; + pname = "aj-snapshot"; version = "0.9.9"; src = fetchurl { @@ -12,15 +20,19 @@ stdenv.mkDerivation rec { doCheck = false; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ alsa-lib minixml jack2 ]; + buildInputs = [ + alsa-lib + minixml + jack2 + ]; meta = with lib; { description = "Tool for storing/restoring JACK and/or ALSA connections to/from cml files"; longDescription = '' - Aj-snapshot is a small program that can be used to make snapshots of the connections made between JACK and/or ALSA clients. - Because JACK can provide both audio and MIDI support to programs, aj-snapshot can store both types of connections for JACK. - ALSA, on the other hand, only provides routing facilities for MIDI clients. - You can also run aj-snapshot in daemon mode if you want to have your connections continually restored. + Aj-snapshot is a small program that can be used to make snapshots of the connections made between JACK and/or ALSA clients. + Because JACK can provide both audio and MIDI support to programs, aj-snapshot can store both types of connections for JACK. + ALSA, on the other hand, only provides routing facilities for MIDI clients. + You can also run aj-snapshot in daemon mode if you want to have your connections continually restored. ''; homepage = "http://aj-snapshot.sourceforge.net/"; diff --git a/pkgs/by-name/ak/akira-unstable/package.nix b/pkgs/by-name/ak/akira-unstable/package.nix index 03278888c8babc..c6b880c69e5c88 100644 --- a/pkgs/by-name/ak/akira-unstable/package.nix +++ b/pkgs/by-name/ak/akira-unstable/package.nix @@ -1,24 +1,25 @@ -{ stdenv -, lib -, fetchFromGitHub -, appstream-glib -, desktop-file-utils -, meson -, ninja -, pantheon -, pkg-config -, python3 -, vala -, wrapGAppsHook3 -, cairo -, glib -, goocanvas3 -, gtk3 -, gtksourceview3 -, json-glib -, libarchive -, libgee -, libxml2 +{ + stdenv, + lib, + fetchFromGitHub, + appstream-glib, + desktop-file-utils, + meson, + ninja, + pantheon, + pkg-config, + python3, + vala, + wrapGAppsHook3, + cairo, + glib, + goocanvas3, + gtk3, + gtksourceview3, + json-glib, + libarchive, + libgee, + libxml2, }: stdenv.mkDerivation rec { @@ -67,7 +68,13 @@ stdenv.mkDerivation rec { description = "Native Linux Design application built in Vala and GTK"; homepage = "https://github.com/akiraux/Akira"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ Br1ght0ne neonfuz ] ++ teams.pantheon.members; + maintainers = + with maintainers; + [ + Br1ght0ne + neonfuz + ] + ++ teams.pantheon.members; platforms = platforms.linux; mainProgram = "com.github.akiraux.akira"; }; diff --git a/pkgs/by-name/al/alacritty-theme/package.nix b/pkgs/by-name/al/alacritty-theme/package.nix index 9846ccbdf7f93e..de636003d877f7 100644 --- a/pkgs/by-name/al/alacritty-theme/package.nix +++ b/pkgs/by-name/al/alacritty-theme/package.nix @@ -1,8 +1,10 @@ -{ lib -, fetchFromGitHub -, unstableGitUpdater -, stdenvNoCC -, ... }: +{ + lib, + fetchFromGitHub, + unstableGitUpdater, + stdenvNoCC, + ... +}: stdenvNoCC.mkDerivation (self: { pname = "alacritty-theme"; diff --git a/pkgs/by-name/al/alacritty/package.nix b/pkgs/by-name/al/alacritty/package.nix index ff9e28c27b7b2d..5376c79a407280 100644 --- a/pkgs/by-name/al/alacritty/package.nix +++ b/pkgs/by-name/al/alacritty/package.nix @@ -1,43 +1,46 @@ -{ stdenv -, lib -, fetchFromGitHub -, rustPlatform -, nixosTests - -, cmake -, installShellFiles -, makeWrapper -, ncurses -, pkg-config -, python3 -, scdoc - -, expat -, fontconfig -, freetype -, libGL -, xorg -, libxkbcommon -, wayland -, xdg-utils - -, apple-sdk_11 +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + nixosTests, + + cmake, + installShellFiles, + makeWrapper, + ncurses, + pkg-config, + python3, + scdoc, + + expat, + fontconfig, + freetype, + libGL, + xorg, + libxkbcommon, + wayland, + xdg-utils, + + apple-sdk_11, }: let - rpathLibs = [ - expat - fontconfig - freetype - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libGL - xorg.libX11 - xorg.libXcursor - xorg.libXi - xorg.libXxf86vm - xorg.libxcb - libxkbcommon - wayland - ]; + rpathLibs = + [ + expat + fontconfig + freetype + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libGL + xorg.libX11 + xorg.libXcursor + xorg.libXi + xorg.libXxf86vm + xorg.libxcb + libxkbcommon + wayland + ]; in rustPlatform.buildRustPackage rec { pname = "alacritty"; @@ -62,12 +65,16 @@ rustPlatform.buildRustPackage rec { scdoc ]; - buildInputs = rpathLibs + buildInputs = + rpathLibs ++ lib.optionals stdenv.hostPlatform.isDarwin [ - apple-sdk_11 - ]; + apple-sdk_11 + ]; - outputs = [ "out" "terminfo" ]; + outputs = [ + "out" + "terminfo" + ]; postPatch = lib.optionalString stdenv.hostPlatform.isLinux '' substituteInPlace alacritty/src/config/ui_config.rs \ @@ -76,41 +83,46 @@ rustPlatform.buildRustPackage rec { checkFlags = [ "--skip=term::test::mock_term" ]; # broken on aarch64 - postInstall = ( - if stdenv.hostPlatform.isDarwin then '' - mkdir $out/Applications - cp -r extra/osx/Alacritty.app $out/Applications - ln -s $out/bin $out/Applications/Alacritty.app/Contents/MacOS - '' else '' - install -D extra/linux/Alacritty.desktop -t $out/share/applications/ - install -D extra/linux/org.alacritty.Alacritty.appdata.xml -t $out/share/appdata/ - install -D extra/logo/compat/alacritty-term.svg $out/share/icons/hicolor/scalable/apps/Alacritty.svg - - # patchelf generates an ELF that binutils' "strip" doesn't like: - # strip: not enough room for program headers, try linking with -N - # As a workaround, strip manually before running patchelf. - $STRIP -S $out/bin/alacritty - - patchelf --add-rpath "${lib.makeLibraryPath rpathLibs}" $out/bin/alacritty - '' - ) + '' - installShellCompletion --zsh extra/completions/_alacritty - installShellCompletion --bash extra/completions/alacritty.bash - installShellCompletion --fish extra/completions/alacritty.fish - - install -dm 755 "$out/share/man/man1" - install -dm 755 "$out/share/man/man5" - - scdoc < extra/man/alacritty.1.scd | gzip -c > $out/share/man/man1/alacritty.1.gz - scdoc < extra/man/alacritty-msg.1.scd | gzip -c > $out/share/man/man1/alacritty-msg.1.gz - scdoc < extra/man/alacritty.5.scd | gzip -c > $out/share/man/man5/alacritty.5.gz - scdoc < extra/man/alacritty-bindings.5.scd | gzip -c > $out/share/man/man5/alacritty-bindings.5.gz - - install -dm 755 "$terminfo/share/terminfo/a/" - tic -xe alacritty,alacritty-direct -o "$terminfo/share/terminfo" extra/alacritty.info - mkdir -p $out/nix-support - echo "$terminfo" >> $out/nix-support/propagated-user-env-packages - ''; + postInstall = + ( + if stdenv.hostPlatform.isDarwin then + '' + mkdir $out/Applications + cp -r extra/osx/Alacritty.app $out/Applications + ln -s $out/bin $out/Applications/Alacritty.app/Contents/MacOS + '' + else + '' + install -D extra/linux/Alacritty.desktop -t $out/share/applications/ + install -D extra/linux/org.alacritty.Alacritty.appdata.xml -t $out/share/appdata/ + install -D extra/logo/compat/alacritty-term.svg $out/share/icons/hicolor/scalable/apps/Alacritty.svg + + # patchelf generates an ELF that binutils' "strip" doesn't like: + # strip: not enough room for program headers, try linking with -N + # As a workaround, strip manually before running patchelf. + $STRIP -S $out/bin/alacritty + + patchelf --add-rpath "${lib.makeLibraryPath rpathLibs}" $out/bin/alacritty + '' + ) + + '' + installShellCompletion --zsh extra/completions/_alacritty + installShellCompletion --bash extra/completions/alacritty.bash + installShellCompletion --fish extra/completions/alacritty.fish + + install -dm 755 "$out/share/man/man1" + install -dm 755 "$out/share/man/man5" + + scdoc < extra/man/alacritty.1.scd | gzip -c > $out/share/man/man1/alacritty.1.gz + scdoc < extra/man/alacritty-msg.1.scd | gzip -c > $out/share/man/man1/alacritty-msg.1.gz + scdoc < extra/man/alacritty.5.scd | gzip -c > $out/share/man/man5/alacritty.5.gz + scdoc < extra/man/alacritty-bindings.5.scd | gzip -c > $out/share/man/man5/alacritty-bindings.5.gz + + install -dm 755 "$terminfo/share/terminfo/a/" + tic -xe alacritty,alacritty-direct -o "$terminfo/share/terminfo" extra/alacritty.info + mkdir -p $out/nix-support + echo "$terminfo" >> $out/nix-support/propagated-user-env-packages + ''; dontPatchELF = true; @@ -121,7 +133,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/alacritty/alacritty"; license = licenses.asl20; mainProgram = "alacritty"; - maintainers = with maintainers; [ Br1ght0ne mic92 ]; + maintainers = with maintainers; [ + Br1ght0ne + mic92 + ]; platforms = platforms.unix; changelog = "https://github.com/alacritty/alacritty/blob/v${version}/CHANGELOG.md"; }; diff --git a/pkgs/by-name/al/alarm-clock-applet/package.nix b/pkgs/by-name/al/alarm-clock-applet/package.nix index 80275149bfb8e5..1648badc73fdb0 100644 --- a/pkgs/by-name/al/alarm-clock-applet/package.nix +++ b/pkgs/by-name/al/alarm-clock-applet/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, wrapGAppsHook3 -, gst_all_1 -, libnotify -, libayatana-appindicator +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + wrapGAppsHook3, + gst_all_1, + libnotify, + libayatana-appindicator, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/al/alass/package.nix b/pkgs/by-name/al/alass/package.nix index bbbbe91beb64a1..0ae84ada3dfbda 100644 --- a/pkgs/by-name/al/alass/package.nix +++ b/pkgs/by-name/al/alass/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, makeWrapper -, ffmpeg +{ + lib, + fetchFromGitHub, + rustPlatform, + makeWrapper, + ffmpeg, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/al/albatross/package.nix b/pkgs/by-name/al/albatross/package.nix index 04b06ef0684a08..09e220a94d0486 100644 --- a/pkgs/by-name/al/albatross/package.nix +++ b/pkgs/by-name/al/albatross/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "Albatross"; diff --git a/pkgs/by-name/al/alchemy/package.nix b/pkgs/by-name/al/alchemy/package.nix index 2b61004ed0e7ac..658afb3da34f74 100644 --- a/pkgs/by-name/al/alchemy/package.nix +++ b/pkgs/by-name/al/alchemy/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre, runtimeShell }: +{ + lib, + stdenv, + fetchurl, + jre, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "alchemy"; diff --git a/pkgs/by-name/al/aldo/package.nix b/pkgs/by-name/al/aldo/package.nix index 03e775738618a3..f8834125dab93f 100644 --- a/pkgs/by-name/al/aldo/package.nix +++ b/pkgs/by-name/al/aldo/package.nix @@ -1,9 +1,16 @@ -{ lib, stdenv, fetchgit, libao, autoreconfHook }: +{ + lib, + stdenv, + fetchgit, + libao, + autoreconfHook, +}: let pname = "aldo"; version = "0.7.8"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname version; src = fetchgit { diff --git a/pkgs/by-name/al/alegreya-sans/package.nix b/pkgs/by-name/al/alegreya-sans/package.nix index cc0cd6cac9b90c..13b10ac4a9d5a4 100644 --- a/pkgs/by-name/al/alegreya-sans/package.nix +++ b/pkgs/by-name/al/alegreya-sans/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "alegreya-sans"; @@ -21,13 +25,13 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Humanist sans serif family with a calligraphic feeling"; longDescription = '' -Alegreya Sans is a humanist sans serif family with a calligraphic feeling that conveys a dynamic and varied rhythm. This gives a pleasant feeling to readers of long texts. + Alegreya Sans is a humanist sans serif family with a calligraphic feeling that conveys a dynamic and varied rhythm. This gives a pleasant feeling to readers of long texts. -The family follows humanist proportions and principles, just like the serif version of the family, Alegreya. It achieves a ludic and harmonious paragraph through elements carefully designed in an atmosphere of diversity. The italics bring a strong emphasis to the roman styles, and each have seven weights to bring you a wide typographic palette. + The family follows humanist proportions and principles, just like the serif version of the family, Alegreya. It achieves a ludic and harmonious paragraph through elements carefully designed in an atmosphere of diversity. The italics bring a strong emphasis to the roman styles, and each have seven weights to bring you a wide typographic palette. -Alegreya Sans supports expert latin, greek and cyrillic character sets and provides advanced typography OpenType features such as small caps, dynamic ligatures and fractions, four set of figures, super and subscript characters, ordinals, localized accent forms for spanish, catalan, guaraní, dutch, turkish, romanian, serbian among others. + Alegreya Sans supports expert latin, greek and cyrillic character sets and provides advanced typography OpenType features such as small caps, dynamic ligatures and fractions, four set of figures, super and subscript characters, ordinals, localized accent forms for spanish, catalan, guaraní, dutch, turkish, romanian, serbian among others. -The Alegreya type system is a "super family", originally intended for literature, and includes sans and serif sister families. + The Alegreya type system is a "super family", originally intended for literature, and includes sans and serif sister families. ''; homepage = "https://www.huertatipografica.com/en/fonts/alegreya-sans-ht"; license = licenses.ofl; diff --git a/pkgs/by-name/al/alegreya/package.nix b/pkgs/by-name/al/alegreya/package.nix index 03efbff4ebf5b2..b13656ef901fa4 100644 --- a/pkgs/by-name/al/alegreya/package.nix +++ b/pkgs/by-name/al/alegreya/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "alegreya"; @@ -21,19 +25,19 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Elegant and versatile font family for comfortable reading"; longDescription = '' -Alegreya is a typeface originally intended for literature. Among its crowning characteristics, it conveys a dynamic and varied rhythm which facilitates the reading of long texts. Also, it provides freshness to the page while referring to the calligraphic letter, not as a literal interpretation, but rather in a contemporary typographic language. + Alegreya is a typeface originally intended for literature. Among its crowning characteristics, it conveys a dynamic and varied rhythm which facilitates the reading of long texts. Also, it provides freshness to the page while referring to the calligraphic letter, not as a literal interpretation, but rather in a contemporary typographic language. -The italic has just as much care and attention to detail in the design as the roman. The bold weights are strong, and the Black weights are really experimental for the genre. There is also a Small Caps sister family. + The italic has just as much care and attention to detail in the design as the roman. The bold weights are strong, and the Black weights are really experimental for the genre. There is also a Small Caps sister family. -Not only does Alegreya provide great performance, but also achieves a strong and harmonious text by means of elements designed in an atmosphere of diversity. + Not only does Alegreya provide great performance, but also achieves a strong and harmonious text by means of elements designed in an atmosphere of diversity. -The Alegreya type system is a "super family", originally intended for literature, and includes serif and sans serif sister families. + The Alegreya type system is a "super family", originally intended for literature, and includes serif and sans serif sister families. -It supports expert latin, greek and cyrillic character sets and provides advanced typography OpenType features such as small caps, dynamic ligatures and fractions, four set of figures, super and subscript characters, ordinals, localized accent forms for spanish, catalan, guaraní, dutch, turkish, romanian, serbian among others. + It supports expert latin, greek and cyrillic character sets and provides advanced typography OpenType features such as small caps, dynamic ligatures and fractions, four set of figures, super and subscript characters, ordinals, localized accent forms for spanish, catalan, guaraní, dutch, turkish, romanian, serbian among others. -Alegreya was chosen at the ATypI Letter2 competition in September 2011, and one of the top 14 text type systems. It was also selected in the 2nd Bienal Iberoamericana de Diseño, competition held in Madrid in 2010 and Tipos Latinos. + Alegreya was chosen at the ATypI Letter2 competition in September 2011, and one of the top 14 text type systems. It was also selected in the 2nd Bienal Iberoamericana de Diseño, competition held in Madrid in 2010 and Tipos Latinos. -Designed by Juan Pablo del Peral for Huerta Tipográfica. + Designed by Juan Pablo del Peral for Huerta Tipográfica. ''; homepage = "https://www.huertatipografica.com/en/fonts/alegreya-ht-pro"; license = licenses.ofl; diff --git a/pkgs/by-name/al/alejandra/package.nix b/pkgs/by-name/al/alejandra/package.nix index ed5f519fbf3241..5523681d706e4a 100644 --- a/pkgs/by-name/al/alejandra/package.nix +++ b/pkgs/by-name/al/alejandra/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, testers -, alejandra +{ + lib, + rustPlatform, + fetchFromGitHub, + testers, + alejandra, }: rustPlatform.buildRustPackage rec { @@ -27,7 +28,11 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/kamadorueda/alejandra"; changelog = "https://github.com/kamadorueda/alejandra/blob/${version}/CHANGELOG.md"; license = licenses.unlicense; - maintainers = with maintainers; [ _0x4A6F kamadorueda sciencentistguy ]; + maintainers = with maintainers; [ + _0x4A6F + kamadorueda + sciencentistguy + ]; mainProgram = "alejandra"; }; } diff --git a/pkgs/by-name/al/alephone-apotheosis-x/package.nix b/pkgs/by-name/al/alephone-apotheosis-x/package.nix index 7cb7646919f599..c24045c25c6351 100644 --- a/pkgs/by-name/al/alephone-apotheosis-x/package.nix +++ b/pkgs/by-name/al/alephone-apotheosis-x/package.nix @@ -1,4 +1,8 @@ -{ lib, alephone, requireFile }: +{ + lib, + alephone, + requireFile, +}: alephone.makeWrapper rec { pname = "apotheosis-x"; diff --git a/pkgs/by-name/al/alephone-durandal/package.nix b/pkgs/by-name/al/alephone-durandal/package.nix index 25ac05901e5b58..b247ba98f39f19 100644 --- a/pkgs/by-name/al/alephone-durandal/package.nix +++ b/pkgs/by-name/al/alephone-durandal/package.nix @@ -8,8 +8,7 @@ alephone.makeWrapper rec { # nixpkgs-update: no auto update zip = fetchurl { - url = - "https://github.com/Aleph-One-Marathon/alephone/releases/download/release-${version}/Marathon2-${version}-Data.zip"; + url = "https://github.com/Aleph-One-Marathon/alephone/releases/download/release-${version}/Marathon2-${version}-Data.zip"; hash = "sha256-uoBl1/7XlXmMLqpk3tvme9w18q4Yh0WCrmqSzjGxNz0="; }; diff --git a/pkgs/by-name/al/alephone-eternal/package.nix b/pkgs/by-name/al/alephone-eternal/package.nix index d3c7c8333f54d4..dc5f94971f7613 100644 --- a/pkgs/by-name/al/alephone-eternal/package.nix +++ b/pkgs/by-name/al/alephone-eternal/package.nix @@ -13,8 +13,7 @@ alephone.makeWrapper rec { sourceRoot = "Eternal 1.2.1"; meta = { - description = - "Picking up from the end of the Marathon trilogy, you find yourself suddenly ninety-four years in the future, in the year 2905"; + description = "Picking up from the end of the Marathon trilogy, you find yourself suddenly ninety-four years in the future, in the year 2905"; homepage = "http://eternal.bungie.org/"; }; diff --git a/pkgs/by-name/al/alephone-infinity/package.nix b/pkgs/by-name/al/alephone-infinity/package.nix index 592399a9dda616..139924feaabf99 100644 --- a/pkgs/by-name/al/alephone-infinity/package.nix +++ b/pkgs/by-name/al/alephone-infinity/package.nix @@ -8,8 +8,7 @@ alephone.makeWrapper rec { # nixpkgs-update: no auto update zip = fetchurl { - url = - "https://github.com/Aleph-One-Marathon/alephone/releases/download/release-${version}/MarathonInfinity-${version}-Data.zip"; + url = "https://github.com/Aleph-One-Marathon/alephone/releases/download/release-${version}/MarathonInfinity-${version}-Data.zip"; hash = "sha256-+FPym4Avqzyo4cZtfYPHXCS+q21+g9AIdKOImkd/UjU="; }; diff --git a/pkgs/by-name/al/alephone-marathon/package.nix b/pkgs/by-name/al/alephone-marathon/package.nix index df34ae8f20c3a9..7075e010445767 100644 --- a/pkgs/by-name/al/alephone-marathon/package.nix +++ b/pkgs/by-name/al/alephone-marathon/package.nix @@ -8,8 +8,7 @@ alephone.makeWrapper rec { # nixpkgs-update: no auto update zip = fetchurl { - url = - "https://github.com/Aleph-One-Marathon/alephone/releases/download/release-${version}/Marathon-${version}-Data.zip"; + url = "https://github.com/Aleph-One-Marathon/alephone/releases/download/release-${version}/Marathon-${version}-Data.zip"; hash = "sha256-shZ82e7veaaT/petxDQ8Fd7YtJPmTgxSCStf0kGfrFs="; }; diff --git a/pkgs/by-name/al/alephone-pathways-into-darkness/package.nix b/pkgs/by-name/al/alephone-pathways-into-darkness/package.nix index 10c0fcfc04fb27..c74e1158093716 100644 --- a/pkgs/by-name/al/alephone-pathways-into-darkness/package.nix +++ b/pkgs/by-name/al/alephone-pathways-into-darkness/package.nix @@ -11,8 +11,7 @@ alephone.makeWrapper rec { }; meta = { - description = '' - Port of the 1993 mac game "Pathways Into Darkness" by Bungie to the Aleph One engine''; + description = ''Port of the 1993 mac game "Pathways Into Darkness" by Bungie to the Aleph One engine''; homepage = "http://simplici7y.com/items/aleph-one-pathways-into-darkness"; }; diff --git a/pkgs/by-name/al/alephone-yuge/package.nix b/pkgs/by-name/al/alephone-yuge/package.nix index c9e2d05a08fac3..85402ae5c9b684 100644 --- a/pkgs/by-name/al/alephone-yuge/package.nix +++ b/pkgs/by-name/al/alephone-yuge/package.nix @@ -11,8 +11,7 @@ alephone.makeWrapper rec { }; meta = { - description = - "30 level Marathon scenario, plus 225 secret levels for many extra hours of gameplay"; + description = "30 level Marathon scenario, plus 225 secret levels for many extra hours of gameplay"; homepage = "https://lochnits.com/marathon/yuge/"; }; } diff --git a/pkgs/by-name/al/alertmanager-irc-relay/package.nix b/pkgs/by-name/al/alertmanager-irc-relay/package.nix index fb5f524c0afe8b..2d034dc5608cd7 100644 --- a/pkgs/by-name/al/alertmanager-irc-relay/package.nix +++ b/pkgs/by-name/al/alertmanager-irc-relay/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "alertmanager-irc-relay"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-KX+TR0n14+95lldF+0KUo5DbqOKpUDaZNuKMBf0KHFQ="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Alertmanager IRC Relay is a bot relaying Prometheus alerts to IRC"; diff --git a/pkgs/by-name/al/alertmanager-webhook-logger/package.nix b/pkgs/by-name/al/alertmanager-webhook-logger/package.nix index 24e55e8b7607df..b256a389ab043f 100644 --- a/pkgs/by-name/al/alertmanager-webhook-logger/package.nix +++ b/pkgs/by-name/al/alertmanager-webhook-logger/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/by-name/al/alglib/package.nix b/pkgs/by-name/al/alglib/package.nix index 45717082a85860..414a884ce0d9b0 100644 --- a/pkgs/by-name/al/alglib/package.nix +++ b/pkgs/by-name/al/alglib/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, cmake, clang }: +{ + lib, + stdenv, + fetchurl, + cmake, + clang, +}: stdenv.mkDerivation rec { pname = "alglib3"; diff --git a/pkgs/by-name/al/algol68g/package.nix b/pkgs/by-name/al/algol68g/package.nix index 1622952b3ce563..1d3ed222b62256 100644 --- a/pkgs/by-name/al/algol68g/package.nix +++ b/pkgs/by-name/al/algol68g/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, curl -, gmp -, gsl -, mpfr -, ncurses -, plotutils -, postgresql -, pkg-config -, withPDFDoc ? true +{ + lib, + stdenv, + fetchurl, + curl, + gmp, + gsl, + mpfr, + ncurses, + plotutils, + postgresql, + pkg-config, + withPDFDoc ? true, }: stdenv.mkDerivation (finalAttrs: { @@ -21,7 +22,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-hKiRMU98sZhGgHhjgtwUNSIv2iPgb4T+dgYw58IGK8Q="; }; - outputs = [ "out" "man" ] ++ lib.optionals withPDFDoc [ "doc" ]; + outputs = [ + "out" + "man" + ] ++ lib.optionals withPDFDoc [ "doc" ]; nativeBuildInputs = [ pkg-config @@ -39,13 +43,14 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - postInstall = let - pdfdoc = fetchurl { - url = "https://jmvdveer.home.xs4all.nl/learning-algol-68-genie.pdf"; - hash = "sha256-QCwn1e/lVfTYTeolCFErvfMhvwCgsBnASqq2K+NYmlU="; - }; - in lib.optionalString withPDFDoc - '' + postInstall = + let + pdfdoc = fetchurl { + url = "https://jmvdveer.home.xs4all.nl/learning-algol-68-genie.pdf"; + hash = "sha256-QCwn1e/lVfTYTeolCFErvfMhvwCgsBnASqq2K+NYmlU="; + }; + in + lib.optionalString withPDFDoc '' install -m644 ${pdfdoc} ${placeholder "doc"}/share/doc/algol68g/learning-algol-68-genie.pdf ''; diff --git a/pkgs/by-name/al/ali/package.nix b/pkgs/by-name/al/ali/package.nix index 44d80f1b7e199f..effa23aaafcacc 100644 --- a/pkgs/by-name/al/ali/package.nix +++ b/pkgs/by-name/al/ali/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGo122Module -, fetchFromGitHub +{ + lib, + buildGo122Module, + fetchFromGitHub, }: buildGo122Module rec { diff --git a/pkgs/by-name/al/alice/package.nix b/pkgs/by-name/al/alice/package.nix index 985ba09926f49e..244e8afad623da 100644 --- a/pkgs/by-name/al/alice/package.nix +++ b/pkgs/by-name/al/alice/package.nix @@ -1,13 +1,22 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation (attrs: { pname = "Alice"; version = "2.003"; - outputs = [ "out" "woff2" ]; + outputs = [ + "out" + "woff2" + ]; src = fetchzip { - url = with attrs; "https://github.com/cyrealtype/${pname}/releases/download/v${version}/${pname}-v${version}.zip"; + url = + with attrs; + "https://github.com/cyrealtype/${pname}/releases/download/v${version}/${pname}-v${version}.zip"; stripRoot = false; hash = "sha256-p+tE3DECfJyBIPyafGZ8jDYQ1lPb+iAnEwLyaUy7DW0="; }; diff --git a/pkgs/by-name/al/alienarena/package.nix b/pkgs/by-name/al/alienarena/package.nix index 1788d68221a57b..06982ef32274ab 100644 --- a/pkgs/by-name/al/alienarena/package.nix +++ b/pkgs/by-name/al/alienarena/package.nix @@ -1,16 +1,17 @@ -{ curl -, fetchFromGitHub -, freetype -, lib -, libGL -, libjpeg -, libogg -, libvorbis -, libX11 -, libXxf86vm -, openal -, pkg-config -, stdenv +{ + curl, + fetchFromGitHub, + freetype, + lib, + libGL, + libjpeg, + libogg, + libvorbis, + libX11, + libXxf86vm, + openal, + pkg-config, + stdenv, }: stdenv.mkDerivation rec { @@ -61,6 +62,6 @@ stdenv.mkDerivation rec { license = licenses.unfreeRedistributable; maintainers = with maintainers; [ astsmtl ]; platforms = platforms.linux; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/by-name/al/align/package.nix b/pkgs/by-name/al/align/package.nix index fa97b97ad261c1..12666a286b8f9c 100644 --- a/pkgs/by-name/al/align/package.nix +++ b/pkgs/by-name/al/align/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "align"; diff --git a/pkgs/by-name/al/alire/package.nix b/pkgs/by-name/al/alire/package.nix index 17f6f256edb3ea..d4e45430708eb9 100644 --- a/pkgs/by-name/al/alire/package.nix +++ b/pkgs/by-name/al/alire/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, gprbuild -, gnat +{ + lib, + stdenv, + fetchFromGitHub, + gprbuild, + gnat, }: stdenv.mkDerivation (finalAttrs: { @@ -18,7 +19,10 @@ stdenv.mkDerivation (finalAttrs: { fetchSubmodules = true; }; - nativeBuildInputs = [ gprbuild gnat ]; + nativeBuildInputs = [ + gprbuild + gnat + ]; postPatch = '' patchShebangs ./dev/build.sh ./scripts/version-patcher.sh diff --git a/pkgs/by-name/al/aliyun-cli/package.nix b/pkgs/by-name/al/aliyun-cli/package.nix index 066866dc7d0172..3953e3634efc15 100644 --- a/pkgs/by-name/al/aliyun-cli/package.nix +++ b/pkgs/by-name/al/aliyun-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "aliyun-cli"; @@ -16,7 +20,11 @@ buildGoModule rec { subPackages = [ "main" ]; - ldflags = [ "-s" "-w" "-X github.com/aliyun/aliyun-cli/cli.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/aliyun/aliyun-cli/cli.Version=${version}" + ]; postInstall = '' mv $out/bin/main $out/bin/aliyun diff --git a/pkgs/by-name/al/alkalami/package.nix b/pkgs/by-name/al/alkalami/package.nix index b9dfd27e57968e..6b3535bc074a23 100644 --- a/pkgs/by-name/al/alkalami/package.nix +++ b/pkgs/by-name/al/alkalami/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "alkalami"; diff --git a/pkgs/by-name/al/alliance/package.nix b/pkgs/by-name/al/alliance/package.nix index f4333be8475e8a..e905c47735ad42 100644 --- a/pkgs/by-name/al/alliance/package.nix +++ b/pkgs/by-name/al/alliance/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitLab, xorgproto, motif, libX11, libXt, libXpm, bison -, flex, automake, autoconf, libtool +{ + lib, + stdenv, + fetchFromGitLab, + xorgproto, + motif, + libX11, + libXt, + libXpm, + bison, + flex, + automake, + autoconf, + libtool, }: stdenv.mkDerivation rec { @@ -16,8 +28,20 @@ stdenv.mkDerivation rec { prePatch = "cd alliance/src"; - nativeBuildInputs = [ libtool automake autoconf flex ]; - buildInputs = [ xorgproto motif libX11 libXt libXpm bison ]; + nativeBuildInputs = [ + libtool + automake + autoconf + flex + ]; + buildInputs = [ + xorgproto + motif + libX11 + libXt + libXpm + bison + ]; # Disable parallel build, errors: # ./pat_decl_y.y:736:5: error: expected '=', ... @@ -26,7 +50,8 @@ stdenv.mkDerivation rec { ALLIANCE_TOP = placeholder "out"; configureFlags = [ - "--prefix=${placeholder "out"}" "--enable-alc-shared" + "--prefix=${placeholder "out"}" + "--enable-alc-shared" ]; postPatch = '' diff --git a/pkgs/by-name/al/allure/package.nix b/pkgs/by-name/al/allure/package.nix index 371f070367e8bd..1ad9e8e416b7df 100644 --- a/pkgs/by-name/al/allure/package.nix +++ b/pkgs/by-name/al/allure/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, makeWrapper -, fetchurl -, jre +{ + lib, + stdenv, + makeWrapper, + fetchurl, + jre, }: stdenv.mkDerivation (finalAttrs: { @@ -32,7 +33,7 @@ stdenv.mkDerivation (finalAttrs: { runHook postInstall ''; - meta = { + meta = { homepage = "https://docs.qameta.io/allure/"; description = "Allure Report is a flexible, lightweight multi-language test reporting tool"; longDescription = '' @@ -40,7 +41,7 @@ stdenv.mkDerivation (finalAttrs: { tool providing clear graphical reports and allowing everyone involved in the development process to extract the maximum of information from the everyday testing process. - ''; + ''; license = lib.licenses.asl20; mainProgram = "allure"; maintainers = with lib.maintainers; [ happysalada ]; diff --git a/pkgs/by-name/al/almanah/package.nix b/pkgs/by-name/al/almanah/package.nix index f98a569fe6031b..6529d736bc1b24 100644 --- a/pkgs/by-name/al/almanah/package.nix +++ b/pkgs/by-name/al/almanah/package.nix @@ -1,28 +1,29 @@ -{ stdenv -, lib -, fetchurl -, fetchpatch -, atk -, cairo -, desktop-file-utils -, evolution-data-server-gtk4 -, evolution -, gcr_4 -, gettext -, glib -, gnome -, gpgme -, gtk3 -, gtksourceview4 -, gtkspell3 -, libcryptui -, libxml2 -, meson -, ninja -, pkg-config -, python3 -, sqlite -, wrapGAppsHook3 +{ + stdenv, + lib, + fetchurl, + fetchpatch, + atk, + cairo, + desktop-file-utils, + evolution-data-server-gtk4, + evolution, + gcr_4, + gettext, + glib, + gnome, + gpgme, + gtk3, + gtksourceview4, + gtkspell3, + libcryptui, + libxml2, + meson, + ninja, + pkg-config, + python3, + sqlite, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/al/almonds/package.nix b/pkgs/by-name/al/almonds/package.nix index 7717458d0dac23..d8ec911b730409 100644 --- a/pkgs/by-name/al/almonds/package.nix +++ b/pkgs/by-name/al/almonds/package.nix @@ -1,6 +1,12 @@ -{ lib, python3, fetchFromGitHub, ncurses }: +{ + lib, + python3, + fetchFromGitHub, + ncurses, +}: -with python3.pkgs; buildPythonApplication rec { +with python3.pkgs; +buildPythonApplication rec { pname = "almonds"; version = "1.25b"; diff --git a/pkgs/by-name/al/alock/package.nix b/pkgs/by-name/al/alock/package.nix index a8bf0eabbe4429..cf331fe6f3a150 100644 --- a/pkgs/by-name/al/alock/package.nix +++ b/pkgs/by-name/al/alock/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, gitUpdater, pkg-config, autoreconfHook -, libX11, pam, libgcrypt, libXrender, imlib2 }: +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + pkg-config, + autoreconfHook, + libX11, + pam, + libgcrypt, + libXrender, + imlib2, +}: stdenv.mkDerivation rec { pname = "alock"; @@ -21,10 +32,16 @@ stdenv.mkDerivation rec { "--enable-imlib2" ]; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; buildInputs = [ libX11 - pam libgcrypt libXrender imlib2 + pam + libgcrypt + libXrender + imlib2 ]; passthru.updateScript = gitUpdater { @@ -46,7 +63,10 @@ stdenv.mkDerivation rec { X session. ''; platforms = platforms.linux; - maintainers = with maintainers; [ ftrvxmtrx chris-martin ]; + maintainers = with maintainers; [ + ftrvxmtrx + chris-martin + ]; license = licenses.mit; }; } diff --git a/pkgs/by-name/al/alot/package.nix b/pkgs/by-name/al/alot/package.nix index cf0de377e370be..90ceff591aba25 100644 --- a/pkgs/by-name/al/alot/package.nix +++ b/pkgs/by-name/al/alot/package.nix @@ -1,24 +1,28 @@ -{ lib -, python311 -, fetchFromGitHub -, file -, gnupg -, gawk -, procps -, notmuch -, withManpage ? false +{ + lib, + python311, + fetchFromGitHub, + file, + gnupg, + gawk, + procps, + notmuch, + withManpage ? false, }: -with python311.pkgs; buildPythonApplication rec { +with python311.pkgs; +buildPythonApplication rec { pname = "alot"; version = "0.11"; pyproject = true; - outputs = [ - "out" - ] ++ lib.optionals withManpage [ - "man" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals withManpage [ + "man" + ]; disabled = !isPy3k; diff --git a/pkgs/by-name/al/alp/package.nix b/pkgs/by-name/al/alp/package.nix index 1f79cd296bf9e0..e0e18e91939797 100644 --- a/pkgs/by-name/al/alp/package.nix +++ b/pkgs/by-name/al/alp/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, runCommand -, alp +{ + lib, + buildGoModule, + fetchFromGitHub, + runCommand, + alp, }: buildGoModule rec { @@ -39,7 +40,7 @@ buildGoModule rec { ''; passthru.tests = { - test-version = runCommand "${pname}-test" {} '' + test-version = runCommand "${pname}-test" { } '' ${alp}/bin/alp version > $out cat $out | grep '${version}' ''; diff --git a/pkgs/by-name/al/alpaca/package.nix b/pkgs/by-name/al/alpaca/package.nix index 5e98d5eb20c35a..7b8d12bbcca2e4 100644 --- a/pkgs/by-name/al/alpaca/package.nix +++ b/pkgs/by-name/al/alpaca/package.nix @@ -59,7 +59,12 @@ python3Packages.buildPythonApplication rec { makeWrapperArgs = [ "\${gappsWrapperArgs[@]}" - "--prefix PATH : ${lib.makeBinPath [ xdg-utils ollama ]}" + "--prefix PATH : ${ + lib.makeBinPath [ + xdg-utils + ollama + ] + }" # Declared but not used in src/window.py, for later reference # https://github.com/flatpak/flatpak/issues/3229 "--set FLATPAK_DEST ${placeholder "out"}" diff --git a/pkgs/by-name/al/alpine-make-rootfs/package.nix b/pkgs/by-name/al/alpine-make-rootfs/package.nix index 1fcfc23710a5a9..e1a5f68a2048ec 100644 --- a/pkgs/by-name/al/alpine-make-rootfs/package.nix +++ b/pkgs/by-name/al/alpine-make-rootfs/package.nix @@ -1,4 +1,18 @@ -{ stdenvNoCC, lib, fetchFromGitHub, makeWrapper, apk-tools, coreutils, findutils, gnugrep, gnused, gnutar, gzip, rsync, util-linux, wget +{ + stdenvNoCC, + lib, + fetchFromGitHub, + makeWrapper, + apk-tools, + coreutils, + findutils, + gnugrep, + gnused, + gnutar, + gzip, + rsync, + util-linux, + wget, }: stdenvNoCC.mkDerivation rec { pname = "alpine-make-rootfs"; @@ -17,9 +31,20 @@ stdenvNoCC.mkDerivation rec { makeFlags = [ "PREFIX=$(out)" ]; postInstall = '' - wrapProgram $out/bin/alpine-make-rootfs --set PATH ${lib.makeBinPath [ - apk-tools coreutils findutils gnugrep gnused gnutar gzip rsync util-linux wget - ]} + wrapProgram $out/bin/alpine-make-rootfs --set PATH ${ + lib.makeBinPath [ + apk-tools + coreutils + findutils + gnugrep + gnused + gnutar + gzip + rsync + util-linux + wget + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/al/alpine-make-vm-image/package.nix b/pkgs/by-name/al/alpine-make-vm-image/package.nix index bb9679e061db96..0579b6d773d897 100644 --- a/pkgs/by-name/al/alpine-make-vm-image/package.nix +++ b/pkgs/by-name/al/alpine-make-vm-image/package.nix @@ -1,6 +1,19 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper -, apk-tools, coreutils, dosfstools, e2fsprogs, findutils, gnugrep, gnused, kmod, qemu-utils -, rsync, util-linux +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + apk-tools, + coreutils, + dosfstools, + e2fsprogs, + findutils, + gnugrep, + gnused, + kmod, + qemu-utils, + rsync, + util-linux, }: stdenv.mkDerivation rec { @@ -20,10 +33,21 @@ stdenv.mkDerivation rec { makeFlags = [ "PREFIX=$(out)" ]; postInstall = '' - wrapProgram $out/bin/alpine-make-vm-image --set PATH ${lib.makeBinPath [ - apk-tools coreutils dosfstools e2fsprogs findutils gnugrep gnused kmod qemu-utils - rsync util-linux - ]} + wrapProgram $out/bin/alpine-make-vm-image --set PATH ${ + lib.makeBinPath [ + apk-tools + coreutils + dosfstools + e2fsprogs + findutils + gnugrep + gnused + kmod + qemu-utils + rsync + util-linux + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/al/alpine/package.nix b/pkgs/by-name/al/alpine/package.nix index 82239761190e6c..d2df962f8b58f5 100644 --- a/pkgs/by-name/al/alpine/package.nix +++ b/pkgs/by-name/al/alpine/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchgit -, buildPackages -, ncurses -, tcl -, openssl -, pam -, libkrb5 -, openldap -, libxcrypt -, gitUpdater +{ + lib, + stdenv, + fetchgit, + buildPackages, + ncurses, + tcl, + openssl, + pam, + libkrb5, + openldap, + libxcrypt, + gitUpdater, }: stdenv.mkDerivation rec { @@ -25,7 +26,13 @@ stdenv.mkDerivation rec { depsBuildBuild = [ buildPackages.stdenv.cc ]; buildInputs = [ - ncurses tcl openssl pam libkrb5 openldap libxcrypt + ncurses + tcl + openssl + pam + libkrb5 + openldap + libxcrypt ]; hardeningDisable = [ "format" ]; @@ -41,7 +48,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Console mail reader"; license = licenses.asl20; - maintainers = with maintainers; [ raskin rhendric ]; + maintainers = with maintainers; [ + raskin + rhendric + ]; platforms = platforms.linux; homepage = "https://alpineapp.email/"; }; diff --git a/pkgs/by-name/al/alpnpass/package.nix b/pkgs/by-name/al/alpnpass/package.nix index edf8061da4d177..a8d77f9d8cbc84 100644 --- a/pkgs/by-name/al/alpnpass/package.nix +++ b/pkgs/by-name/al/alpnpass/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/al/alps/package.nix b/pkgs/by-name/al/alps/package.nix index 1aeba54ed57fa9..a7bda932279183 100644 --- a/pkgs/by-name/al/alps/package.nix +++ b/pkgs/by-name/al/alps/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromSourcehut, fetchpatch, nixosTests }: +{ + lib, + buildGoModule, + fetchFromSourcehut, + fetchpatch, + nixosTests, +}: buildGoModule rec { pname = "alps"; @@ -39,13 +45,17 @@ buildGoModule rec { proxyVendor = true; - passthru.tests = { inherit(nixosTests) alps; }; + passthru.tests = { inherit (nixosTests) alps; }; meta = with lib; { description = "Simple and extensible webmail"; homepage = "https://git.sr.ht/~migadu/alps"; license = licenses.mit; - maintainers = with maintainers; [ booklearner madonius hmenke ]; + maintainers = with maintainers; [ + booklearner + madonius + hmenke + ]; mainProgram = "alps"; }; } diff --git a/pkgs/by-name/al/alsa-lib/package.nix b/pkgs/by-name/al/alsa-lib/package.nix index 8647c91f3f033b..adb621053e9a33 100644 --- a/pkgs/by-name/al/alsa-lib/package.nix +++ b/pkgs/by-name/al/alsa-lib/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, alsa-topology-conf -, alsa-ucm-conf -, testers +{ + lib, + stdenv, + fetchurl, + alsa-topology-conf, + alsa-ucm-conf, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -30,7 +31,10 @@ stdenv.mkDerivation (finalAttrs: { ln -s ${alsa-topology-conf}/share/alsa/topology $out/share/alsa ''; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; @@ -45,7 +49,10 @@ stdenv.mkDerivation (finalAttrs: { ''; license = licenses.lgpl21Plus; - pkgConfigModules = [ "alsa" "alsa-topology" ]; + pkgConfigModules = [ + "alsa" + "alsa-topology" + ]; platforms = platforms.linux; maintainers = with maintainers; [ l-as ]; }; diff --git a/pkgs/by-name/al/alsa-oss/package.nix b/pkgs/by-name/al/alsa-oss/package.nix index 425c2c49965825..494d56feab9751 100644 --- a/pkgs/by-name/al/alsa-oss/package.nix +++ b/pkgs/by-name/al/alsa-oss/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchurl, alsa-lib, gettext, ncurses, libsamplerate}: +{ + lib, + stdenv, + fetchurl, + alsa-lib, + gettext, + ncurses, + libsamplerate, +}: stdenv.mkDerivation rec { pname = "alsa-oss"; @@ -9,7 +17,11 @@ stdenv.mkDerivation rec { hash = "sha256-ZK3O9ZJ+hI0uAk5kxL+FtvOVlk2ZdOxhkFrky4011o4="; }; - buildInputs = [ alsa-lib ncurses libsamplerate ]; + buildInputs = [ + alsa-lib + ncurses + libsamplerate + ]; nativeBuildInputs = [ gettext ]; configureFlags = [ "--disable-xmlto" ]; diff --git a/pkgs/by-name/al/alsa-plugins-wrapper/package.nix b/pkgs/by-name/al/alsa-plugins-wrapper/package.nix index 992f4886e262cd..5e2525f651668b 100644 --- a/pkgs/by-name/al/alsa-plugins-wrapper/package.nix +++ b/pkgs/by-name/al/alsa-plugins-wrapper/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, alsa-plugins -, writeShellScriptBin +{ + stdenv, + alsa-plugins, + writeShellScriptBin, }: let arch = if stdenv.hostPlatform.system == "i686-linux" then "32" else "64"; diff --git a/pkgs/by-name/al/alsa-scarlett-gui/package.nix b/pkgs/by-name/al/alsa-scarlett-gui/package.nix index 05c409ed72ea60..246b1653a528b5 100644 --- a/pkgs/by-name/al/alsa-scarlett-gui/package.nix +++ b/pkgs/by-name/al/alsa-scarlett-gui/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, makeWrapper -, alsa-utils -, alsa-lib -, gtk4 -, openssl -, wrapGAppsHook4 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + makeWrapper, + alsa-utils, + alsa-lib, + gtk4, + openssl, + wrapGAppsHook4, }: stdenv.mkDerivation rec { @@ -23,7 +24,10 @@ stdenv.mkDerivation rec { NIX_CFLAGS_COMPILE = [ "-Wno-error=deprecated-declarations" ]; - makeFlags = [ "DESTDIR=\${out}" "PREFIX=''" ]; + makeFlags = [ + "DESTDIR=\${out}" + "PREFIX=''" + ]; sourceRoot = "${src.name}/src"; postPatch = '' @@ -31,8 +35,16 @@ stdenv.mkDerivation rec { --replace-fail "/usr/sbin/alsactl" "${alsa-utils}/bin/alsactl" ''; - nativeBuildInputs = [ pkg-config wrapGAppsHook4 makeWrapper ]; - buildInputs = [ gtk4 alsa-lib openssl ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook4 + makeWrapper + ]; + buildInputs = [ + gtk4 + alsa-lib + openssl + ]; postInstall = '' wrapProgram $out/bin/alsa-scarlett-gui --prefix PATH : ${lib.makeBinPath [ alsa-utils ]} diff --git a/pkgs/by-name/al/alsa-tools/package.nix b/pkgs/by-name/al/alsa-tools/package.nix index 54028d12ecf665..222a1124211209 100644 --- a/pkgs/by-name/al/alsa-tools/package.nix +++ b/pkgs/by-name/al/alsa-tools/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, alsa-lib -, fltk13 -, gtk2 -, gtk3 -, makeWrapper -, pkg-config -, psmisc +{ + lib, + stdenv, + fetchurl, + alsa-lib, + fltk13, + gtk2, + gtk3, + makeWrapper, + pkg-config, + psmisc, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/al/alsa-topology-conf/package.nix b/pkgs/by-name/al/alsa-topology-conf/package.nix index 06d3a63dc468ac..7f881bbe6a6671 100644 --- a/pkgs/by-name/al/alsa-topology-conf/package.nix +++ b/pkgs/by-name/al/alsa-topology-conf/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { name = "alsa-topology-conf-${version}"; diff --git a/pkgs/by-name/al/alsa-utils/package.nix b/pkgs/by-name/al/alsa-utils/package.nix index 74c24e18d0c399..afbbb45e92d5f0 100644 --- a/pkgs/by-name/al/alsa-utils/package.nix +++ b/pkgs/by-name/al/alsa-utils/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, directoryListingUpdater -, fetchurl -, alsa-lib -, alsa-plugins -, gettext -, makeWrapper -, ncurses -, libsamplerate -, pciutils -, procps -, which -, fftw -, pipewire -, withPipewireLib ? true -, symlinkJoin +{ + lib, + stdenv, + directoryListingUpdater, + fetchurl, + alsa-lib, + alsa-plugins, + gettext, + makeWrapper, + ncurses, + libsamplerate, + pciutils, + procps, + which, + fftw, + pipewire, + withPipewireLib ? true, + symlinkJoin, }: let @@ -24,9 +25,7 @@ let # This is necessary because ALSA_PLUGIN_DIR must reference only one directory. plugin-dir = symlinkJoin { name = "all-plugins"; - paths = map - (path: "${path}/lib/alsa-lib") - plugin-packages; + paths = map (path: "${path}/lib/alsa-lib") plugin-packages; }; in stdenv.mkDerivation rec { @@ -38,16 +37,33 @@ stdenv.mkDerivation rec { hash = "sha256-mLxmd9DAB0AGZ5BRgiMkoKsIea6lWKj2i1EXgNMM2SQ="; }; - nativeBuildInputs = [ gettext makeWrapper ]; - buildInputs = [ alsa-lib ncurses libsamplerate fftw ]; + nativeBuildInputs = [ + gettext + makeWrapper + ]; + buildInputs = [ + alsa-lib + ncurses + libsamplerate + fftw + ]; - configureFlags = [ "--disable-xmlto" "--with-udev-rules-dir=$(out)/lib/udev/rules.d" ]; + configureFlags = [ + "--disable-xmlto" + "--with-udev-rules-dir=$(out)/lib/udev/rules.d" + ]; installFlags = [ "ASOUND_STATE_DIR=$(TMPDIR)/dummy" ]; postFixup = '' mv $out/bin/alsa-info.sh $out/bin/alsa-info - wrapProgram $out/bin/alsa-info --prefix PATH : "${lib.makeBinPath [ which pciutils procps ]}" + wrapProgram $out/bin/alsa-info --prefix PATH : "${ + lib.makeBinPath [ + which + pciutils + procps + ] + }" wrapProgram $out/bin/aplay --set-default ALSA_PLUGIN_DIR ${plugin-dir} ''; diff --git a/pkgs/by-name/al/alsaequal/package.nix b/pkgs/by-name/al/alsaequal/package.nix index d35facd6c3d97e..d90c73845f6eda 100644 --- a/pkgs/by-name/al/alsaequal/package.nix +++ b/pkgs/by-name/al/alsaequal/package.nix @@ -1,6 +1,10 @@ -{ lib, stdenv, fetchFromGitHub -, alsa-lib, caps, - ladspaH +{ + lib, + stdenv, + fetchFromGitHub, + alsa-lib, + caps, + ladspaH, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/al/alt-ergo/package.nix b/pkgs/by-name/al/alt-ergo/package.nix index 2f58141c3281bf..8aed8f4e701c8e 100644 --- a/pkgs/by-name/al/alt-ergo/package.nix +++ b/pkgs/by-name/al/alt-ergo/package.nix @@ -1,4 +1,10 @@ -{ darwin, fetchurl, lib, ocamlPackages, stdenv }: +{ + darwin, + fetchurl, + lib, + ocamlPackages, + stdenv, +}: let pname = "alt-ergo"; @@ -10,38 +16,53 @@ let }; in -let alt-ergo-lib = ocamlPackages.buildDunePackage rec { - pname = "alt-ergo-lib"; - inherit version src; - buildInputs = with ocamlPackages; [ ppx_blob ]; - propagatedBuildInputs = with ocamlPackages; [ - camlzip - dolmen_loop - dune-build-info - fmt - ocplib-simplex - ppx_deriving - seq - stdlib-shims - zarith - ]; -}; in +let + alt-ergo-lib = ocamlPackages.buildDunePackage rec { + pname = "alt-ergo-lib"; + inherit version src; + buildInputs = with ocamlPackages; [ ppx_blob ]; + propagatedBuildInputs = with ocamlPackages; [ + camlzip + dolmen_loop + dune-build-info + fmt + ocplib-simplex + ppx_deriving + seq + stdlib-shims + zarith + ]; + }; +in -let alt-ergo-parsers = ocamlPackages.buildDunePackage rec { - pname = "alt-ergo-parsers"; - inherit version src; - nativeBuildInputs = [ ocamlPackages.menhir ]; - propagatedBuildInputs = [ alt-ergo-lib ] ++ (with ocamlPackages; [ psmt2-frontend ]); -}; in +let + alt-ergo-parsers = ocamlPackages.buildDunePackage rec { + pname = "alt-ergo-parsers"; + inherit version src; + nativeBuildInputs = [ ocamlPackages.menhir ]; + propagatedBuildInputs = [ alt-ergo-lib ] ++ (with ocamlPackages; [ psmt2-frontend ]); + }; +in ocamlPackages.buildDunePackage { inherit pname version src; - nativeBuildInputs = [ ocamlPackages.menhir ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.sigtool ]; - propagatedBuildInputs = [ alt-ergo-parsers ] ++ (with ocamlPackages; [ cmdliner dune-site ppxlib ]); + nativeBuildInputs = [ + ocamlPackages.menhir + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.sigtool ]; + propagatedBuildInputs = + [ alt-ergo-parsers ] + ++ (with ocamlPackages; [ + cmdliner + dune-site + ppxlib + ]); - outputs = [ "bin" "out" ]; + outputs = [ + "bin" + "out" + ]; installPhase = '' runHook preInstall @@ -53,8 +74,8 @@ ocamlPackages.buildDunePackage { meta = { description = "High-performance theorem prover and SMT solver"; - homepage = "https://alt-ergo.ocamlpro.com/"; - license = lib.licenses.ocamlpro_nc; + homepage = "https://alt-ergo.ocamlpro.com/"; + license = lib.licenses.ocamlpro_nc; maintainers = [ lib.maintainers.thoughtpolice ]; }; } diff --git a/pkgs/by-name/al/alt-tab-macos/package.nix b/pkgs/by-name/al/alt-tab-macos/package.nix index 2f0468d9822c4f..796309702fce57 100644 --- a/pkgs/by-name/al/alt-tab-macos/package.nix +++ b/pkgs/by-name/al/alt-tab-macos/package.nix @@ -34,7 +34,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { description = "Windows alt-tab on macOS"; homepage = "https://alt-tab-macos.netlify.app"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ donteatoreo emilytrau ]; + maintainers = with lib.maintainers; [ + donteatoreo + emilytrau + ]; platforms = lib.platforms.darwin; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; }; diff --git a/pkgs/by-name/al/altair/package.nix b/pkgs/by-name/al/altair/package.nix index 6d64409335bbf5..816555bc8f30fd 100644 --- a/pkgs/by-name/al/altair/package.nix +++ b/pkgs/by-name/al/altair/package.nix @@ -1,4 +1,9 @@ -{ lib, appimageTools, makeWrapper, fetchurl }: +{ + lib, + appimageTools, + makeWrapper, + fetchurl, +}: let pname = "altair"; diff --git a/pkgs/by-name/al/altdns/package.nix b/pkgs/by-name/al/altdns/package.nix index 839173efa64d63..f9e701eb91d5f0 100644 --- a/pkgs/by-name/al/altdns/package.nix +++ b/pkgs/by-name/al/altdns/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication { diff --git a/pkgs/by-name/al/altermime/package.nix b/pkgs/by-name/al/altermime/package.nix index 812da5f8742ef6..41c5ef19e82886 100644 --- a/pkgs/by-name/al/altermime/package.nix +++ b/pkgs/by-name/al/altermime/package.nix @@ -1,4 +1,8 @@ -{ lib, gccStdenv, fetchurl }: +{ + lib, + gccStdenv, + fetchurl, +}: gccStdenv.mkDerivation rec { pname = "altermime"; diff --git a/pkgs/by-name/al/alterx/package.nix b/pkgs/by-name/al/alterx/package.nix index a81d83d2ae3129..08acb62ad0b34d 100644 --- a/pkgs/by-name/al/alterx/package.nix +++ b/pkgs/by-name/al/alterx/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/al/althttpd/package.nix b/pkgs/by-name/al/althttpd/package.nix index 229082d6c1a329..a344ec304eaa11 100644 --- a/pkgs/by-name/al/althttpd/package.nix +++ b/pkgs/by-name/al/althttpd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchfossil, openssl }: +{ + lib, + stdenv, + fetchfossil, + openssl, +}: stdenv.mkDerivation rec { pname = "althttpd"; diff --git a/pkgs/by-name/al/altserver-linux/package.nix b/pkgs/by-name/al/altserver-linux/package.nix index 30d5282949014e..30614f51c7a026 100644 --- a/pkgs/by-name/al/altserver-linux/package.nix +++ b/pkgs/by-name/al/altserver-linux/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, fetchurl -, lib -, avahi-compat +{ + stdenv, + fetchurl, + lib, + avahi-compat, }: stdenv.mkDerivation (finalAttrs: { @@ -35,4 +36,3 @@ stdenv.mkDerivation (finalAttrs: { maintainers = with maintainers; [ max-amb ]; }; }) - diff --git a/pkgs/by-name/al/alttab/package.nix b/pkgs/by-name/al/alttab/package.nix index 99619bd88d2c48..2d6997abb019da 100644 --- a/pkgs/by-name/al/alttab/package.nix +++ b/pkgs/by-name/al/alttab/package.nix @@ -1,5 +1,20 @@ -{ lib, stdenv, coreutils, fetchFromGitHub, autoconf, automake, pkg-config, procps, ronn, -libpng, uthash , which, xnee, xorg, python3Packages }: +{ + lib, + stdenv, + coreutils, + fetchFromGitHub, + autoconf, + automake, + pkg-config, + procps, + ronn, + libpng, + uthash, + which, + xnee, + xorg, + python3Packages, +}: stdenv.mkDerivation rec { version = "1.7.1"; diff --git a/pkgs/by-name/al/alure/package.nix b/pkgs/by-name/al/alure/package.nix index a367b765874bdc..67a36b9b15340b 100644 --- a/pkgs/by-name/al/alure/package.nix +++ b/pkgs/by-name/al/alure/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, cmake, openal }: +{ + lib, + stdenv, + fetchurl, + cmake, + openal, +}: stdenv.mkDerivation rec { pname = "alure"; diff --git a/pkgs/by-name/al/alure2/package.nix b/pkgs/by-name/al/alure2/package.nix index f18a2a3434e164..53659154bc8b5d 100644 --- a/pkgs/by-name/al/alure2/package.nix +++ b/pkgs/by-name/al/alure2/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, openal, libvorbis, opusfile, libsndfile }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openal, + libvorbis, + opusfile, + libsndfile, +}: stdenv.mkDerivation rec { pname = "alure2"; @@ -12,13 +21,18 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ openal libvorbis opusfile libsndfile ]; + buildInputs = [ + openal + libvorbis + opusfile + libsndfile + ]; meta = with lib; { description = "Utility library for OpenAL, providing a C++ API and managing common tasks that include file loading, caching, and streaming"; homepage = "https://github.com/kcat/alure"; license = licenses.zlib; platforms = platforms.linux; - maintainers = with maintainers; [ McSinyx ]; + maintainers = with maintainers; [ McSinyx ]; }; } diff --git a/pkgs/by-name/am/AMB-plugins/package.nix b/pkgs/by-name/am/AMB-plugins/package.nix index 97bd35264bb56e..3dc01d0b2f4ee5 100644 --- a/pkgs/by-name/am/AMB-plugins/package.nix +++ b/pkgs/by-name/am/AMB-plugins/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl, ladspaH +{ + lib, + stdenv, + fetchurl, + ladspaH, }: stdenv.mkDerivation rec { @@ -18,7 +22,7 @@ stdenv.mkDerivation rec { sed -i 's@g++@$(CXX)@g' Makefile ''; - preInstall="mkdir -p $out/lib/ladspa"; + preInstall = "mkdir -p $out/lib/ladspa"; meta = { description = "Set of ambisonics ladspa plugins"; diff --git a/pkgs/by-name/am/amass/package.nix b/pkgs/by-name/am/amass/package.nix index cbd6513905055e..bd280979159677 100644 --- a/pkgs/by-name/am/amass/package.nix +++ b/pkgs/by-name/am/amass/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -42,11 +43,14 @@ buildGoModule rec { Amass ships with a set of wordlist (to be used with the amass -w flag) that are found under the wordlists output. - ''; + ''; homepage = "https://owasp.org/www-project-amass/"; changelog = "https://github.com/OWASP/Amass/releases/tag/v${version}"; license = licenses.asl20; - maintainers = with maintainers; [ kalbasit fab ]; + maintainers = with maintainers; [ + kalbasit + fab + ]; mainProgram = "amass"; }; } diff --git a/pkgs/by-name/am/amazon-ecr-credential-helper/package.nix b/pkgs/by-name/am/amazon-ecr-credential-helper/package.nix index 181e5c722017fd..bc6be8d706eb8a 100644 --- a/pkgs/by-name/am/amazon-ecr-credential-helper/package.nix +++ b/pkgs/by-name/am/amazon-ecr-credential-helper/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, amazon-ecr-credential-helper }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + amazon-ecr-credential-helper, +}: buildGoModule rec { pname = "amazon-ecr-credential-helper"; diff --git a/pkgs/by-name/am/amazon-ecs-cli/package.nix b/pkgs/by-name/am/amazon-ecs-cli/package.nix index cd242a56410f61..7242f8cf113ab0 100644 --- a/pkgs/by-name/am/amazon-ecs-cli/package.nix +++ b/pkgs/by-name/am/amazon-ecs-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "amazon-ecs-cli"; @@ -15,16 +19,16 @@ stdenv.mkDerivation rec { url = "https://s3.amazonaws.com/amazon-ecs-cli/ecs-cli-darwin-amd64-v${version}"; sha256 = "1viala49sifpcmgn3jw24h5bkrlm4ffadjiqagbxj3lr0r78i9nm"; } - else throw "Architecture not supported"; + else + throw "Architecture not supported"; dontUnpack = true; - installPhase = - '' - mkdir -p $out/bin - cp $src $out/bin/ecs-cli - chmod +x $out/bin/ecs-cli - ''; # */ + installPhase = '' + mkdir -p $out/bin + cp $src $out/bin/ecs-cli + chmod +x $out/bin/ecs-cli + ''; # */ meta = with lib; { homepage = "https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ECS_CLI.html"; @@ -33,7 +37,10 @@ stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.asl20; maintainers = with maintainers; [ Scriptkiddi ]; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; mainProgram = "ecs-cli"; }; } diff --git a/pkgs/by-name/am/amazon-ssm-agent/package.nix b/pkgs/by-name/am/amazon-ssm-agent/package.nix index f8a16974485077..e8327b415654d2 100644 --- a/pkgs/by-name/am/amazon-ssm-agent/package.nix +++ b/pkgs/by-name/am/amazon-ssm-agent/package.nix @@ -1,19 +1,20 @@ -{ lib -, writeShellScriptBin -, buildGoModule -, makeWrapper -, darwin -, fetchFromGitHub -, coreutils -, nettools -, util-linux -, stdenv -, dmidecode -, bashInteractive -, nix-update-script -, nixosTests -, testers -, amazon-ssm-agent +{ + lib, + writeShellScriptBin, + buildGoModule, + makeWrapper, + darwin, + fetchFromGitHub, + coreutils, + nettools, + util-linux, + stdenv, + dmidecode, + bashInteractive, + nix-update-script, + nixosTests, + testers, + amazon-ssm-agent, }: let @@ -61,11 +62,13 @@ buildGoModule rec { ./0002-version-gen-don-t-use-unnecessary-constants.patch ]; - nativeBuildInputs = [ - makeWrapper - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.DarwinTools - ]; + nativeBuildInputs = + [ + makeWrapper + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.DarwinTools + ]; # See the list https://github.com/aws/amazon-ssm-agent/blob/3.2.2143.0/makefile#L121-L147 # The updater is not built because it cannot work on NixOS @@ -78,27 +81,32 @@ buildGoModule rec { "agent/session/logging" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; - postPatch = '' - printf "#!/bin/sh\ntrue" > ./Tools/src/checkstyle.sh + postPatch = + '' + printf "#!/bin/sh\ntrue" > ./Tools/src/checkstyle.sh - substituteInPlace agent/platform/platform_unix.go \ - --replace-fail "/usr/bin/uname" "${coreutils}/bin/uname" \ - --replace-fail '"/bin", "hostname"' '"${nettools}/bin/hostname"' \ - --replace-fail '"lsb_release"' '"${fake-lsb-release}/bin/lsb_release"' + substituteInPlace agent/platform/platform_unix.go \ + --replace-fail "/usr/bin/uname" "${coreutils}/bin/uname" \ + --replace-fail '"/bin", "hostname"' '"${nettools}/bin/hostname"' \ + --replace-fail '"lsb_release"' '"${fake-lsb-release}/bin/lsb_release"' - substituteInPlace agent/session/shell/shell_unix.go \ - --replace-fail '"script"' '"${util-linux}/bin/script"' + substituteInPlace agent/session/shell/shell_unix.go \ + --replace-fail '"script"' '"${util-linux}/bin/script"' - substituteInPlace agent/rebooter/rebooter_unix.go \ - --replace-fail "/sbin/shutdown" "shutdown" + substituteInPlace agent/rebooter/rebooter_unix.go \ + --replace-fail "/sbin/shutdown" "shutdown" - echo "${version}" > VERSION - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace agent/managedInstances/fingerprint/hardwareInfo_unix.go \ - --replace-fail /usr/sbin/dmidecode ${dmidecode}/bin/dmidecode - ''; + echo "${version}" > VERSION + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace agent/managedInstances/fingerprint/hardwareInfo_unix.go \ + --replace-fail /usr/sbin/dmidecode ${dmidecode}/bin/dmidecode + ''; preBuild = '' # Note: if this step fails, please patch the code to fix it! Please only skip @@ -112,7 +120,11 @@ buildGoModule rec { installPhase = '' runHook preInstall - declare -A map=(${builtins.concatStringsSep " " (lib.mapAttrsToList (name: value: "[\"${name}\"]=\"${value}\"") binaries)}) + declare -A map=(${ + builtins.concatStringsSep " " ( + lib.mapAttrsToList (name: value: "[\"${name}\"]=\"${value}\"") binaries + ) + }) for key in ''${!map[@]}; do install -D -m 0555 -T "$GOPATH/bin/''${key}" "$out/bin/''${map[''${key}]}" @@ -163,6 +175,11 @@ buildGoModule rec { homepage = "https://github.com/aws/amazon-ssm-agent"; license = licenses.asl20; platforms = platforms.unix; - maintainers = with maintainers; [ copumpkin manveru anthonyroussel arianvp ]; + maintainers = with maintainers; [ + copumpkin + manveru + anthonyroussel + arianvp + ]; }; } diff --git a/pkgs/by-name/am/amber-theme/package.nix b/pkgs/by-name/am/amber-theme/package.nix index e39f0e3f6454b5..aad3b7e398346f 100644 --- a/pkgs/by-name/am/amber-theme/package.nix +++ b/pkgs/by-name/am/amber-theme/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, sassc, gdk-pixbuf, librsvg, gtk_engines, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + sassc, + gdk-pixbuf, + librsvg, + gtk_engines, + gtk-engine-murrine, +}: stdenv.mkDerivation rec { pname = "amber-theme"; @@ -11,9 +22,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-OrdBeAD+gdIu6u8ESE9PtqYadSuJ8nx1Z8fB4D9y4W4="; }; - nativeBuildInputs = [ meson ninja sassc ]; + nativeBuildInputs = [ + meson + ninja + sassc + ]; - buildInputs = [ gdk-pixbuf librsvg gtk_engines ]; + buildInputs = [ + gdk-pixbuf + librsvg + gtk_engines + ]; propagatedUserEnvPkgs = [ gtk-engine-murrine ]; diff --git a/pkgs/by-name/am/amd-blis/package.nix b/pkgs/by-name/am/amd-blis/package.nix index cbbdc52ce42752..9e798a882edd41 100644 --- a/pkgs/by-name/am/amd-blis/package.nix +++ b/pkgs/by-name/am/amd-blis/package.nix @@ -47,10 +47,13 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - configureFlags = [ - "--enable-cblas" - "--blas-int-size=${blasIntSize}" - ] ++ lib.optionals withOpenMP [ "--enable-threading=openmp" ] ++ [ withArchitecture ]; + configureFlags = + [ + "--enable-cblas" + "--blas-int-size=${blasIntSize}" + ] + ++ lib.optionals withOpenMP [ "--enable-threading=openmp" ] + ++ [ withArchitecture ]; postPatch = '' patchShebangs configure build/flatten-headers.py diff --git a/pkgs/by-name/am/amdctl/package.nix b/pkgs/by-name/am/amdctl/package.nix index 3d07d6be1edf7e..cdf983395bc43f 100644 --- a/pkgs/by-name/am/amdctl/package.nix +++ b/pkgs/by-name/am/amdctl/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/am/amdvlk/test.nix b/pkgs/by-name/am/amdvlk/test.nix index e76e6dce9eaf1c..40da948c68369e 100644 --- a/pkgs/by-name/am/amdvlk/test.nix +++ b/pkgs/by-name/am/amdvlk/test.nix @@ -1,9 +1,18 @@ -{ lib, makeImpureTest, coreutils, amdvlk, vulkan-tools }: +{ + lib, + makeImpureTest, + coreutils, + amdvlk, + vulkan-tools, +}: makeImpureTest { name = "amdvlk"; testedPackage = "amdvlk"; - sandboxPaths = [ "/sys" "/dev/dri" ]; + sandboxPaths = [ + "/sys" + "/dev/dri" + ]; nativeBuildInputs = [ vulkan-tools ]; diff --git a/pkgs/by-name/am/ameba/package.nix b/pkgs/by-name/am/ameba/package.nix index 6f15544953b8f2..07aa2de997119d 100644 --- a/pkgs/by-name/am/ameba/package.nix +++ b/pkgs/by-name/am/ameba/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, crystal }: +{ + lib, + fetchFromGitHub, + crystal, +}: crystal.buildCrystalPackage rec { pname = "ameba"; diff --git a/pkgs/by-name/am/amf-headers/package.nix b/pkgs/by-name/am/amf-headers/package.nix index f6cb9aafbb10f3..1fa67faf9cd8f5 100644 --- a/pkgs/by-name/am/amf-headers/package.nix +++ b/pkgs/by-name/am/amf-headers/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "amf-headers"; diff --git a/pkgs/by-name/am/amfora/package.nix b/pkgs/by-name/am/amfora/package.nix index 9b658386725e07..bb335a505bb21b 100644 --- a/pkgs/by-name/am/amfora/package.nix +++ b/pkgs/by-name/am/amfora/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, buildGoModule }: +{ + stdenv, + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "amfora"; diff --git a/pkgs/by-name/am/amidst/package.nix b/pkgs/by-name/am/amidst/package.nix index 7661e04430feb7..422b902f307630 100644 --- a/pkgs/by-name/am/amidst/package.nix +++ b/pkgs/by-name/am/amidst/package.nix @@ -1,21 +1,29 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "amidst"; version = "4.7"; - src = fetchurl { # TODO: Compile from src - url = "https://github.com/toolbox4minecraft/amidst/releases/download/v${version}/amidst-v${lib.replaceStrings [ "." ] [ "-" ] version}.jar"; + src = fetchurl { + # TODO: Compile from src + url = "https://github.com/toolbox4minecraft/amidst/releases/download/v${version}/amidst-v${ + lib.replaceStrings [ "." ] [ "-" ] version + }.jar"; sha256 = "sha256-oecRjD7JUuvFym8N/hSE5cbAFQojS6yxOuxpwWRlW9M="; }; dontUnpack = true; - nativeBuildInputs = [ jre makeWrapper ]; + nativeBuildInputs = [ + jre + makeWrapper + ]; installPhase = '' mkdir -p $out/{bin,lib/amidst} diff --git a/pkgs/by-name/am/amiri/package.nix b/pkgs/by-name/am/amiri/package.nix index 8f2985952c65fd..19f418728f2597 100644 --- a/pkgs/by-name/am/amiri/package.nix +++ b/pkgs/by-name/am/amiri/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "amiri"; @@ -28,4 +32,3 @@ stdenvNoCC.mkDerivation rec { platforms = platforms.all; }; } - diff --git a/pkgs/by-name/am/aml/package.nix b/pkgs/by-name/am/aml/package.nix index 19f3b28262238b..c18e7efcf53e75 100644 --- a/pkgs/by-name/am/aml/package.nix +++ b/pkgs/by-name/am/aml/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, meson, pkg-config, ninja }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + pkg-config, + ninja, +}: stdenv.mkDerivation rec { pname = "aml"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-BX+MRqvnwwLPhz22m0gfJ2EkW31KQEi/YTgOCMcQk2Q="; }; - nativeBuildInputs = [ meson pkg-config ninja ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + ]; meta = with lib; { description = "Another main loop"; diff --git a/pkgs/by-name/am/amoco/package.nix b/pkgs/by-name/am/amoco/package.nix index ff9fcc7efe63af..42e76b5bd4e1aa 100644 --- a/pkgs/by-name/am/amoco/package.nix +++ b/pkgs/by-name/am/amoco/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/am/among-sus/package.nix b/pkgs/by-name/am/among-sus/package.nix index d53d98f5e7afad..b666073e0e7c2a 100644 --- a/pkgs/by-name/am/among-sus/package.nix +++ b/pkgs/by-name/am/among-sus/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromSourcehut, port ? "1234" }: +{ + lib, + stdenv, + fetchFromSourcehut, + port ? "1234", +}: stdenv.mkDerivation { pname = "among-sus-unstable"; diff --git a/pkgs/by-name/am/amphetype/package.nix b/pkgs/by-name/am/amphetype/package.nix index 15363c2a0e377e..286a2cc162cbfa 100644 --- a/pkgs/by-name/am/amphetype/package.nix +++ b/pkgs/by-name/am/amphetype/package.nix @@ -1,11 +1,18 @@ -{ copyDesktopItems, fetchFromGitLab, lib, makeDesktopItem, python3Packages, qt5 +{ + copyDesktopItems, + fetchFromGitLab, + lib, + makeDesktopItem, + python3Packages, + qt5, }: let pname = "amphetype"; version = "1.0.0"; description = "An advanced typing practice program"; -in python3Packages.buildPythonApplication { +in +python3Packages.buildPythonApplication { inherit pname version; src = fetchFromGitLab { @@ -15,7 +22,10 @@ in python3Packages.buildPythonApplication { hash = "sha256-pve2f+XMfFokMCtW3KdeOJ9Ey330Gwv/dk1+WBtrBEQ="; }; - nativeBuildInputs = [ copyDesktopItems qt5.wrapQtAppsHook ]; + nativeBuildInputs = [ + copyDesktopItems + qt5.wrapQtAppsHook + ]; buildInputs = [ qt5.qtbase @@ -41,7 +51,10 @@ in python3Packages.buildPythonApplication { name = pname; desktopName = "Amphetype"; genericName = "Typing Practice"; - categories = [ "Education" "Qt" ]; + categories = [ + "Education" + "Qt" + ]; exec = pname; comment = description; }) diff --git a/pkgs/by-name/am/amqpcat/package.nix b/pkgs/by-name/am/amqpcat/package.nix index 38c0b5302ff180..01c6237acbbaac 100644 --- a/pkgs/by-name/am/amqpcat/package.nix +++ b/pkgs/by-name/am/amqpcat/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, crystal, openssl, testers, amqpcat }: +{ + lib, + fetchFromGitHub, + crystal, + openssl, + testers, + amqpcat, +}: crystal.buildCrystalPackage rec { pname = "amqpcat"; diff --git a/pkgs/by-name/am/amrnb/package.nix b/pkgs/by-name/am/amrnb/package.nix index 4e325932b5e85b..0ebd741fdc9a0e 100644 --- a/pkgs/by-name/am/amrnb/package.nix +++ b/pkgs/by-name/am/amrnb/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, unzip}: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation { pname = "amrnb"; @@ -15,7 +20,10 @@ stdenv.mkDerivation { nativeBuildInputs = [ unzip ]; - configureFlags = [ "--cache-file=config.cache" "--with-downloader=true" ]; + configureFlags = [ + "--cache-file=config.cache" + "--with-downloader=true" + ]; postConfigure = '' cp $srcAmr 26104-b00.zip diff --git a/pkgs/by-name/am/amrwb/package.nix b/pkgs/by-name/am/amrwb/package.nix index 81938bb4cba73d..9361a10d04319e 100644 --- a/pkgs/by-name/am/amrwb/package.nix +++ b/pkgs/by-name/am/amrwb/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "amrwb"; @@ -16,7 +21,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ unzip ]; - configureFlags = [ "--cache-file=config.cache" "--with-downloader=true" ]; + configureFlags = [ + "--cache-file=config.cache" + "--with-downloader=true" + ]; postConfigure = '' cp $srcAmr 26204-b00.zip diff --git a/pkgs/by-name/am/ams-lv2/package.nix b/pkgs/by-name/am/ams-lv2/package.nix index 8f88551ddfb587..00b4916fe55e89 100644 --- a/pkgs/by-name/am/ams-lv2/package.nix +++ b/pkgs/by-name/am/ams-lv2/package.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, cairo, fftw, gtkmm2, lv2, lvtk, pkg-config -, wafHook, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + cairo, + fftw, + gtkmm2, + lv2, + lvtk, + pkg-config, + wafHook, + python3, +}: -stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "ams-lv2"; version = "1.2.2"; @@ -12,8 +23,18 @@ stdenv.mkDerivation rec { sha256 = "1lz2mvk4gqsyf92yxd3aaldx0d0qi28h4rnnvsaz4ls0ccqm80nk"; }; - nativeBuildInputs = [ pkg-config wafHook python3 ]; - buildInputs = [ cairo fftw gtkmm2 lv2 lvtk ]; + nativeBuildInputs = [ + pkg-config + wafHook + python3 + ]; + buildInputs = [ + cairo + fftw + gtkmm2 + lv2 + lvtk + ]; postPatch = '' # U was removed in python 3.11 because it had no effect diff --git a/pkgs/by-name/am/ams/package.nix b/pkgs/by-name/am/ams/package.nix index 9086bfc333878a..8cdeaae8fe9fde 100644 --- a/pkgs/by-name/am/ams/package.nix +++ b/pkgs/by-name/am/ams/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchgit -, alsa-lib -, ladspaH -, libjack2 -, fftw -, zita-alsa-pcmi -, qt5 -, pkg-config -, autoreconfHook +{ + lib, + stdenv, + fetchgit, + alsa-lib, + ladspaH, + libjack2, + fftw, + zita-alsa-pcmi, + qt5, + pkg-config, + autoreconfHook, }: stdenv.mkDerivation rec { @@ -26,16 +28,18 @@ stdenv.mkDerivation rec { qt5.wrapQtAppsHook ]; - buildInputs = [ - alsa-lib - ladspaH - libjack2 - fftw - zita-alsa-pcmi - ] ++ (with qt5; [ - qtbase - qttools - ]); + buildInputs = + [ + alsa-lib + ladspaH + libjack2 + fftw + zita-alsa-pcmi + ] + ++ (with qt5; [ + qtbase + qttools + ]); meta = with lib; { description = "Realtime modular synthesizer for ALSA"; diff --git a/pkgs/by-name/am/amtterm/package.nix b/pkgs/by-name/am/amtterm/package.nix index caa030b8c65f3b..6d6788cd2238f2 100644 --- a/pkgs/by-name/am/amtterm/package.nix +++ b/pkgs/by-name/am/amtterm/package.nix @@ -1,12 +1,28 @@ -{ fetchFromGitHub, lib, stdenv, makeWrapper, openssl, perl, perlPackages, pkg-config }: - +{ + fetchFromGitHub, + lib, + stdenv, + makeWrapper, + openssl, + perl, + perlPackages, + pkg-config, +}: stdenv.mkDerivation (finalAttrs: { pname = "amtterm"; version = "1.7-1-unstable-2023-10-27"; - buildInputs = (with perlPackages; [ perl SOAPLite ]) ++ [ openssl ]; - nativeBuildInputs = [ makeWrapper pkg-config ]; + buildInputs = + (with perlPackages; [ + perl + SOAPLite + ]) + ++ [ openssl ]; + nativeBuildInputs = [ + makeWrapper + pkg-config + ]; src = fetchFromGitHub { owner = "kraxel"; @@ -15,10 +31,13 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-JwS2agmJJ6VcGLkNbkFRb5bzKV8el1DMDjalmLnOdE8="; }; - makeFlags = [ "prefix=$(out)" "STRIP=" "USE_OPENSSL=1" ]; + makeFlags = [ + "prefix=$(out)" + "STRIP=" + "USE_OPENSSL=1" + ]; - postInstall = - "wrapProgram $out/bin/amttool --prefix PERL5LIB : $PERL5LIB"; + postInstall = "wrapProgram $out/bin/amttool --prefix PERL5LIB : $PERL5LIB"; meta = { description = "Intel AMT® SoL client + tools"; diff --git a/pkgs/by-name/am/amule/package.nix b/pkgs/by-name/am/amule/package.nix index 608ce21c999769..74098896d0c7b4 100644 --- a/pkgs/by-name/am/amule/package.nix +++ b/pkgs/by-name/am/amule/package.nix @@ -1,30 +1,32 @@ -{ monolithic ? true # build monolithic amule -, enableDaemon ? false # build amule daemon -, httpServer ? false # build web interface for the daemon -, client ? false # build amule remote gui -, fetchFromGitHub -, fetchpatch -, stdenv -, lib -, cmake -, zlib -, wxGTK32 -, perl -, cryptopp -, libupnp -, boost # Not using boost leads to crashes with gtk3 -, gettext -, libpng -, pkg-config -, makeWrapper -, libX11 +{ + monolithic ? true, # build monolithic amule + enableDaemon ? false, # build amule daemon + httpServer ? false, # build web interface for the daemon + client ? false, # build amule remote gui + fetchFromGitHub, + fetchpatch, + stdenv, + lib, + cmake, + zlib, + wxGTK32, + perl, + cryptopp, + libupnp, + boost, # Not using boost leads to crashes with gtk3 + gettext, + libpng, + pkg-config, + makeWrapper, + libX11, }: # daemon and client are not build monolithic assert monolithic || (!monolithic && (enableDaemon || client || httpServer)); stdenv.mkDerivation rec { - pname = "amule" + pname = + "amule" + lib.optionalString httpServer "-web" + lib.optionalString enableDaemon "-daemon" + lib.optionalString client "-gui"; @@ -44,17 +46,24 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake gettext makeWrapper pkg-config ]; + nativeBuildInputs = [ + cmake + gettext + makeWrapper + pkg-config + ]; - buildInputs = [ - zlib - wxGTK32 - perl - cryptopp.dev - libupnp - boost - ] ++ lib.optional httpServer libpng - ++ lib.optional client libX11; + buildInputs = + [ + zlib + wxGTK32 + perl + cryptopp.dev + libupnp + boost + ] + ++ lib.optional httpServer libpng + ++ lib.optional client libX11; cmakeFlags = [ "-DBUILD_MONOLITHIC=${if monolithic then "ON" else "OFF"}" diff --git a/pkgs/by-name/an/analog/package.nix b/pkgs/by-name/an/analog/package.nix index b47ef9939b1bc3..11777f147a24e4 100644 --- a/pkgs/by-name/an/analog/package.nix +++ b/pkgs/by-name/an/analog/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "analog"; diff --git a/pkgs/by-name/an/ananicy-cpp/package.nix b/pkgs/by-name/an/ananicy-cpp/package.nix index 424df2427495de..1539f89b4f37aa 100644 --- a/pkgs/by-name/an/ananicy-cpp/package.nix +++ b/pkgs/by-name/an/ananicy-cpp/package.nix @@ -42,23 +42,27 @@ clangStdenv.mkDerivation (finalAttrs: { strictDeps = true; - nativeBuildInputs = [ - cmake - pkg-config - ] ++ lib.optionals withBpf [ - bpftools - ]; + nativeBuildInputs = + [ + cmake + pkg-config + ] + ++ lib.optionals withBpf [ + bpftools + ]; - buildInputs = [ - pcre2 - spdlog - nlohmann_json - systemd - zlib - ] ++ lib.optionals withBpf [ - libbpf - elfutils - ]; + buildInputs = + [ + pcre2 + spdlog + nlohmann_json + systemd + zlib + ] + ++ lib.optionals withBpf [ + libbpf + elfutils + ]; # BPF A call to built-in function '__stack_chk_fail' is not supported. hardeningDisable = [ diff --git a/pkgs/by-name/an/ananicy/package.nix b/pkgs/by-name/an/ananicy/package.nix index 9567f2d4d0f7b2..1bafff92033015 100644 --- a/pkgs/by-name/an/ananicy/package.nix +++ b/pkgs/by-name/an/ananicy/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, python3, fetchFromGitHub, makeWrapper, schedtool, sysctl, util-linux, fetchpatch }: +{ + lib, + stdenv, + python3, + fetchFromGitHub, + makeWrapper, + schedtool, + sysctl, + util-linux, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "ananicy"; @@ -35,7 +45,12 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/ananicy \ - --prefix PATH : ${lib.makeBinPath [ schedtool util-linux ]} + --prefix PATH : ${ + lib.makeBinPath [ + schedtool + util-linux + ] + } substituteInPlace $out/lib/systemd/system/ananicy.service \ --replace "/sbin/sysctl" "${sysctl}/bin/sysctl" \ diff --git a/pkgs/by-name/an/anarchism/package.nix b/pkgs/by-name/an/anarchism/package.nix index b9cedffa194846..3fb7048680bddd 100644 --- a/pkgs/by-name/an/anarchism/package.nix +++ b/pkgs/by-name/an/anarchism/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, xdg-utils }: +{ + lib, + stdenv, + fetchFromGitLab, + xdg-utils, +}: stdenv.mkDerivation rec { pname = "anarchism"; diff --git a/pkgs/by-name/an/andagii/package.nix b/pkgs/by-name/an/andagii/package.nix index 22b686684f9890..3900d74f98b474 100644 --- a/pkgs/by-name/an/andagii/package.nix +++ b/pkgs/by-name/an/andagii/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "andagii"; diff --git a/pkgs/by-name/an/anders/package.nix b/pkgs/by-name/an/anders/package.nix index dff6c86703d412..9943da5a735de8 100644 --- a/pkgs/by-name/an/anders/package.nix +++ b/pkgs/by-name/an/anders/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, ocamlPackages }: +{ + lib, + fetchFromGitHub, + ocamlPackages, +}: ocamlPackages.buildDunePackage rec { pname = "anders"; diff --git a/pkgs/by-name/an/andika/package.nix b/pkgs/by-name/an/andika/package.nix index 897c4ab3c5d1bd..8d39ab9ed1096f 100644 --- a/pkgs/by-name/an/andika/package.nix +++ b/pkgs/by-name/an/andika/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "andika"; diff --git a/pkgs/by-name/an/android-backup-extractor/package.nix b/pkgs/by-name/an/android-backup-extractor/package.nix index 3ecbce8555cde5..61d8f55ea53834 100644 --- a/pkgs/by-name/an/android-backup-extractor/package.nix +++ b/pkgs/by-name/an/android-backup-extractor/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchurl -, makeWrapper -, jre +{ + stdenv, + lib, + fetchurl, + makeWrapper, + jre, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/an/android-studio-tools/package.nix b/pkgs/by-name/an/android-studio-tools/package.nix index 2b1bca47984189..699f7405eb34ec 100644 --- a/pkgs/by-name/an/android-studio-tools/package.nix +++ b/pkgs/by-name/an/android-studio-tools/package.nix @@ -17,13 +17,15 @@ stdenvNoCC.mkDerivation { hash = "sha256-NjxJzHRT2/zZ9YzzjqaMVxpOELkDneQgc1/y1GUnZow="; }; - postPatch = '' - find . -type f -not -path "./bin/*" -exec chmod -x {} \; - '' + lib.optionalString stdenvNoCC.hostPlatform.isDarwin '' - for f in cmdline-tools/bin/*; do - sed -i 's|start up script for Linux|start up script for Mac|' $f - done - ''; + postPatch = + '' + find . -type f -not -path "./bin/*" -exec chmod -x {} \; + '' + + lib.optionalString stdenvNoCC.hostPlatform.isDarwin '' + for f in cmdline-tools/bin/*; do + sed -i 's|start up script for Linux|start up script for Mac|' $f + done + ''; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/by-name/an/android-udev-rules/package.nix b/pkgs/by-name/an/android-udev-rules/package.nix index f569f315b36439..61f952a98dcc0a 100644 --- a/pkgs/by-name/an/android-udev-rules/package.nix +++ b/pkgs/by-name/an/android-udev-rules/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: ## Usage # In NixOS, simply add this package to services.udev.packages: diff --git a/pkgs/by-name/an/andyetitmoves/package.nix b/pkgs/by-name/an/andyetitmoves/package.nix index c9e8a0695ba27d..26f1705d2261bb 100644 --- a/pkgs/by-name/an/andyetitmoves/package.nix +++ b/pkgs/by-name/an/andyetitmoves/package.nix @@ -1,40 +1,56 @@ -{ lib, stdenv, fetchurl, libvorbis, libogg, libtheora, SDL, libXft, SDL_image, zlib, libX11, libpng, openal, runtimeShell, requireFile, commercialVersion ? false }: +{ + lib, + stdenv, + fetchurl, + libvorbis, + libogg, + libtheora, + SDL, + libXft, + SDL_image, + zlib, + libX11, + libpng, + openal, + runtimeShell, + requireFile, + commercialVersion ? false, +}: stdenv.mkDerivation rec { pname = "andyetitmoves"; version = "1.2.2"; src = - if stdenv.hostPlatform.system == "i686-linux" || stdenv.hostPlatform.system == "x86_64-linux" - then + if stdenv.hostPlatform.system == "i686-linux" || stdenv.hostPlatform.system == "x86_64-linux" then let postfix = if stdenv.hostPlatform.system == "i686-linux" then "i386" else "x86_64"; commercialName = "${pname}-${version}_${postfix}.tar.gz"; demoUrl = "http://www.andyetitmoves.net/demo/${pname}Demo-${version}_${postfix}.tar.gz"; in - if commercialVersion - then - requireFile - { - message = '' - We cannot download the commercial version automatically, as you require a license. - Once you bought a license, you need to add your downloaded version to the nix store. - You can do this by using "nix-prefetch-url file:///\$PWD/${commercialName}" in the - directory where yousaved it. - ''; - name = commercialName; - sha256 = - if stdenv.hostPlatform.system == "i686-linux" - then "15wvzmmidvykwjrbnq70h5jrvnjx1hcrm0357qj85q4aqbzavh01" - else "1v8z16qa9ka8sf7qq45knsxj87s6sipvv3a7xq11pb5xk08fb2ql"; - } + if commercialVersion then + requireFile { + message = '' + We cannot download the commercial version automatically, as you require a license. + Once you bought a license, you need to add your downloaded version to the nix store. + You can do this by using "nix-prefetch-url file:///\$PWD/${commercialName}" in the + directory where yousaved it. + ''; + name = commercialName; + sha256 = + if stdenv.hostPlatform.system == "i686-linux" then + "15wvzmmidvykwjrbnq70h5jrvnjx1hcrm0357qj85q4aqbzavh01" + else + "1v8z16qa9ka8sf7qq45knsxj87s6sipvv3a7xq11pb5xk08fb2ql"; + } else fetchurl { url = demoUrl; sha256 = - if stdenv.hostPlatform.system == "i686-linux" - then "0f14vrrbq05hsbdajrb5y9za65fpng1lc8f0adb4aaz27x7sh525" - else "0mg41ya0b27blq3b5498kwl4rj46dj21rcd7qd0rw1kyvr7sx4v4"; + if stdenv.hostPlatform.system == "i686-linux" then + "0f14vrrbq05hsbdajrb5y9za65fpng1lc8f0adb4aaz27x7sh525" + else + "0mg41ya0b27blq3b5498kwl4rj46dj21rcd7qd0rw1kyvr7sx4v4"; } else throw "And Yet It Moves nix package only supports linux and intel cpu's."; @@ -59,7 +75,18 @@ stdenv.mkDerivation rec { chmod +x $out/bin/$binName ''; - buildInputs = [ libvorbis libogg libtheora SDL libXft SDL_image zlib libX11 libpng openal ]; + buildInputs = [ + libvorbis + libogg + libtheora + SDL + libXft + SDL_image + zlib + libX11 + libpng + openal + ]; meta = with lib; { description = "Physics/Gravity Platform game"; diff --git a/pkgs/by-name/an/anew/package.nix b/pkgs/by-name/an/anew/package.nix index 35c7d872f3d8b5..01df45bf93806d 100644 --- a/pkgs/by-name/an/anew/package.nix +++ b/pkgs/by-name/an/anew/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Tool for adding new lines to files, skipping duplicates"; diff --git a/pkgs/by-name/an/anewer/package.nix b/pkgs/by-name/an/anewer/package.nix index 009a6264fddde0..8765b6e810af18 100644 --- a/pkgs/by-name/an/anewer/package.nix +++ b/pkgs/by-name/an/anewer/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "anewer"; diff --git a/pkgs/by-name/an/angband/package.nix b/pkgs/by-name/an/angband/package.nix index 54e4fff299d639..ac2d60a7448097 100644 --- a/pkgs/by-name/an/angband/package.nix +++ b/pkgs/by-name/an/angband/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, ncurses5 -, enableSdl2 ? false, SDL2, SDL2_image, SDL2_sound, SDL2_mixer, SDL2_ttf +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + ncurses5, + enableSdl2 ? false, + SDL2, + SDL2_image, + SDL2_sound, + SDL2_mixer, + SDL2_ttf, }: stdenv.mkDerivation (finalAttrs: { @@ -14,14 +24,15 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ ncurses5 ] - ++ lib.optionals enableSdl2 [ - SDL2 - SDL2_image - SDL2_sound - SDL2_mixer - SDL2_ttf - ]; + buildInputs = + [ ncurses5 ] + ++ lib.optionals enableSdl2 [ + SDL2 + SDL2_image + SDL2_sound + SDL2_mixer + SDL2_ttf + ]; configureFlags = lib.optional enableSdl2 "--enable-sdl2"; diff --git a/pkgs/by-name/an/angelscript/package.nix b/pkgs/by-name/an/angelscript/package.nix index 9e38dc8d285fe1..82ae8c96687dd3 100644 --- a/pkgs/by-name/an/angelscript/package.nix +++ b/pkgs/by-name/an/angelscript/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, unzip -, cmake +{ + lib, + stdenv, + fetchurl, + unzip, + cmake, }: stdenv.mkDerivation rec { @@ -14,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-DFLRaIAWoLJITpylSUccTild8GB3DFeEAUTGSBX1TxA="; }; - nativeBuildInputs = [ unzip cmake ]; + nativeBuildInputs = [ + unzip + cmake + ]; preConfigure = '' export ROOT=$PWD diff --git a/pkgs/by-name/an/angsd/package.nix b/pkgs/by-name/an/angsd/package.nix index 71366dc0d3648b..3a63cced60765b 100644 --- a/pkgs/by-name/an/angsd/package.nix +++ b/pkgs/by-name/an/angsd/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, htslib -, zlib -, bzip2 -, xz -, curl -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + htslib, + zlib, + bzip2, + xz, + curl, + openssl, }: stdenv.mkDerivation rec { @@ -31,11 +32,21 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ htslib zlib bzip2 xz curl openssl ]; + buildInputs = [ + htslib + zlib + bzip2 + xz + curl + openssl + ]; enableParallelBuilding = true; - makeFlags = [ "HTSSRC=systemwide" "prefix=$(out)" ]; + makeFlags = [ + "HTSSRC=systemwide" + "prefix=$(out)" + ]; meta = with lib; { description = "Program for analysing NGS data"; @@ -44,4 +55,3 @@ stdenv.mkDerivation rec { license = licenses.gpl2; }; } - diff --git a/pkgs/by-name/an/animatch/package.nix b/pkgs/by-name/an/animatch/package.nix index 7b235c93e03366..91cbba82717c5c 100644 --- a/pkgs/by-name/an/animatch/package.nix +++ b/pkgs/by-name/an/animatch/package.nix @@ -1,10 +1,11 @@ -{ lib -, allegro5 -, cmake -, fetchFromGitLab -, libGL -, stdenv -, xorg +{ + lib, + allegro5, + cmake, + fetchFromGitLab, + libGL, + stdenv, + xorg, }: stdenv.mkDerivation rec { pname = "animatch"; @@ -28,7 +29,7 @@ stdenv.mkDerivation rec { ]; cmakeFlags = [ - "-DLIBSUPERDERPY_STATIC=ON" # recommended by upstream for coexistence with other superderpy games + "-DLIBSUPERDERPY_STATIC=ON" # recommended by upstream for coexistence with other superderpy games ]; meta = { @@ -39,4 +40,3 @@ stdenv.mkDerivation rec { maintainers = with lib.maintainers; [ colinsane ]; }; } - diff --git a/pkgs/by-name/an/anime4k/package.nix b/pkgs/by-name/an/anime4k/package.nix index 7b8d1fbfc1ef86..785227dfdfa76f 100644 --- a/pkgs/by-name/an/anime4k/package.nix +++ b/pkgs/by-name/an/anime4k/package.nix @@ -1,6 +1,7 @@ -{ fetchFromGitHub -, lib -, stdenvNoCC +{ + fetchFromGitHub, + lib, + stdenvNoCC, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/an/anko/package.nix b/pkgs/by-name/an/anko/package.nix index f88534e9ecf831..ddfef902dfc810 100644 --- a/pkgs/by-name/an/anko/package.nix +++ b/pkgs/by-name/an/anko/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; __darwinAllowLocalNetworking = true; diff --git a/pkgs/by-name/an/annapurna-sil/package.nix b/pkgs/by-name/an/annapurna-sil/package.nix index 325a1a5bcd57c4..ef9cdbc6e62ab3 100644 --- a/pkgs/by-name/an/annapurna-sil/package.nix +++ b/pkgs/by-name/an/annapurna-sil/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "annapurna-sil"; diff --git a/pkgs/by-name/an/annextimelog/package.nix b/pkgs/by-name/an/annextimelog/package.nix index 799525ea882458..88a914f94f6330 100644 --- a/pkgs/by-name/an/annextimelog/package.nix +++ b/pkgs/by-name/an/annextimelog/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitLab +{ + lib, + python3, + fetchFromGitLab, }: python3.pkgs.buildPythonApplication rec { @@ -32,4 +33,3 @@ python3.pkgs.buildPythonApplication rec { maintainers = with maintainers; [ matthiasbeyer ]; }; } - diff --git a/pkgs/by-name/an/anonymousPro/package.nix b/pkgs/by-name/an/anonymousPro/package.nix index f498e2780b3c98..ae8644b1547da9 100644 --- a/pkgs/by-name/an/anonymousPro/package.nix +++ b/pkgs/by-name/an/anonymousPro/package.nix @@ -1,11 +1,17 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "anonymouspro"; version = "1.002"; src = fetchzip { - url = "https://www.marksimonson.com/assets/content/fonts/AnonymousPro-${lib.replaceStrings ["."] ["_"] version}.zip"; + url = "https://www.marksimonson.com/assets/content/fonts/AnonymousPro-${ + lib.replaceStrings [ "." ] [ "_" ] version + }.zip"; hash = "sha256-FhyzV4By8XKN9EyukAknzml/7lUuV6Evnt6Ht3H6TUU="; }; diff --git a/pkgs/by-name/an/ansel/package.nix b/pkgs/by-name/an/ansel/package.nix index 36cc07aa6ec667..e334e7e9e89060 100644 --- a/pkgs/by-name/an/ansel/package.nix +++ b/pkgs/by-name/an/ansel/package.nix @@ -1,79 +1,80 @@ -{ libsepol -, libavif -, bash -, curl -, librsvg -, libselinux -, util-linux -, libwebp -, libheif -, lib -, stdenv -, fetchFromGitHub -, libxslt -, libxml2 -, cmake -, exiftool -, openexr_3 -, glib -, python3Packages -, perlPackages -, lensfun -, intltool -, pkg-config -, desktop-file-utils -, libffi -, gtk3 -, libjpeg -, pugixml -, pcre -, pcre2 -, lcms -, sqlite -, json-glib -, jasper -, libsecret -, gmic -, icu -, colord -, colord-gtk -, libaom -, libdatrie -, libsysprof-capture -, libde265 -, isocodes -, libpsl -, libepoxy -, libsoup_2_4 -, exiv2 -, libXtst -, libthai -, x265 -, libXdmcp -, openjpeg -, libgpg-error -, libxkbcommon -, osm-gps-map -, wrapGAppsHook3 -, rav1e -, dav1d -, libgcrypt -, graphicsmagick -, unstableGitUpdater +{ + libsepol, + libavif, + bash, + curl, + librsvg, + libselinux, + util-linux, + libwebp, + libheif, + lib, + stdenv, + fetchFromGitHub, + libxslt, + libxml2, + cmake, + exiftool, + openexr_3, + glib, + python3Packages, + perlPackages, + lensfun, + intltool, + pkg-config, + desktop-file-utils, + libffi, + gtk3, + libjpeg, + pugixml, + pcre, + pcre2, + lcms, + sqlite, + json-glib, + jasper, + libsecret, + gmic, + icu, + colord, + colord-gtk, + libaom, + libdatrie, + libsysprof-capture, + libde265, + isocodes, + libpsl, + libepoxy, + libsoup_2_4, + exiv2, + libXtst, + libthai, + x265, + libXdmcp, + openjpeg, + libgpg-error, + libxkbcommon, + osm-gps-map, + wrapGAppsHook3, + rav1e, + dav1d, + libgcrypt, + graphicsmagick, + unstableGitUpdater, }: let - # requires libavif 0.x, see https://github.com/aurelienpierreeng/ansel/blob/e2c4a0a60cd80f741dd3d3c6ab72be9ac11234fb/src/CMakeLists.txt#L356 - libavif_0_11 = libavif.overrideAttrs rec { - version = "0.11.1"; + # requires libavif 0.x, see https://github.com/aurelienpierreeng/ansel/blob/e2c4a0a60cd80f741dd3d3c6ab72be9ac11234fb/src/CMakeLists.txt#L356 + libavif_0_11 = libavif.overrideAttrs rec { + version = "0.11.1"; - src = fetchFromGitHub { - owner = "AOMediaCodec"; - repo = "libavif"; - rev = "v${version}"; - hash = "sha256-mUi0DU99XV3FzUZ8/9uJZU+W3fc6Bk6+y6Z78IRZ9Qs="; - }; + src = fetchFromGitHub { + owner = "AOMediaCodec"; + repo = "libavif"; + rev = "v${version}"; + hash = "sha256-mUi0DU99XV3FzUZ8/9uJZU+W3fc6Bk6+y6Z78IRZ9Qs="; }; + }; in stdenv.mkDerivation { pname = "ansel"; diff --git a/pkgs/by-name/an/ansi/package.nix b/pkgs/by-name/an/ansi/package.nix index 77ddf81a269abe..20fc58b605d6c1 100644 --- a/pkgs/by-name/an/ansi/package.nix +++ b/pkgs/by-name/an/ansi/package.nix @@ -1,4 +1,8 @@ -{ fetchCrate, lib, rustPlatform }: +{ + fetchCrate, + lib, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "ansi-escape-sequences-cli"; diff --git a/pkgs/by-name/an/ansible-language-server/package.nix b/pkgs/by-name/an/ansible-language-server/package.nix index a6287cc52c0da5..246ba733302fb1 100644 --- a/pkgs/by-name/an/ansible-language-server/package.nix +++ b/pkgs/by-name/an/ansible-language-server/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, nix-update-script +{ + lib, + buildNpmPackage, + fetchFromGitHub, + nix-update-script, }: buildNpmPackage rec { diff --git a/pkgs/by-name/an/ansifilter/package.nix b/pkgs/by-name/an/ansifilter/package.nix index b770af8c4e4b59..aacbb9044ffdaa 100644 --- a/pkgs/by-name/an/ansifilter/package.nix +++ b/pkgs/by-name/an/ansifilter/package.nix @@ -1,4 +1,11 @@ -{ fetchurl, lib, stdenv, pkg-config, boost, lua }: +{ + fetchurl, + lib, + stdenv, + pkg-config, + boost, + lua, +}: stdenv.mkDerivation rec { pname = "ansifilter"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ boost lua ]; + buildInputs = [ + boost + lua + ]; postPatch = '' # avoid timestamp non-determinism with '-n' diff --git a/pkgs/by-name/an/ante/package.nix b/pkgs/by-name/an/ante/package.nix index e3b4738b7b2152..74397c80442750 100644 --- a/pkgs/by-name/an/ante/package.nix +++ b/pkgs/by-name/an/ante/package.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, lib -, libffi -, libxml2 -, llvmPackages_16 -, ncurses -, rustPlatform +{ + fetchFromGitHub, + lib, + libffi, + libxml2, + llvmPackages_16, + ncurses, + rustPlatform, }: rustPlatform.buildRustPackage { @@ -29,7 +30,11 @@ rustPlatform.buildRustPackage { that is not the same as the one included by default with rustPlatform. */ nativeBuildInputs = [ llvmPackages_16.llvm ]; - buildInputs = [ libffi libxml2 ncurses ]; + buildInputs = [ + libffi + libxml2 + ncurses + ]; postPatch = '' substituteInPlace tests/golden_tests.rs --replace \ diff --git a/pkgs/by-name/an/antfs-cli/package.nix b/pkgs/by-name/an/antfs-cli/package.nix index 43fcab337a0573..921c65de58af1f 100644 --- a/pkgs/by-name/an/antfs-cli/package.nix +++ b/pkgs/by-name/an/antfs-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication { pname = "antfs-cli"; diff --git a/pkgs/by-name/an/anthy/package.nix b/pkgs/by-name/an/anthy/package.nix index 23e2da0e41e64a..3cb8497eed1107 100644 --- a/pkgs/by-name/an/anthy/package.nix +++ b/pkgs/by-name/an/anthy/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "anthy"; @@ -6,10 +10,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Hiragana text to Kana Kanji mixed text Japanese input method"; - homepage = "https://anthy.osdn.jp/"; - license = licenses.gpl2Plus; + homepage = "https://anthy.osdn.jp/"; + license = licenses.gpl2Plus; maintainers = with maintainers; [ ericsagnes ]; - platforms = platforms.unix; + platforms = platforms.unix; }; src = fetchurl { diff --git a/pkgs/by-name/an/antibody/package.nix b/pkgs/by-name/an/antibody/package.nix index 7c1f0eb56cbd32..470716d81ce818 100644 --- a/pkgs/by-name/an/antibody/package.nix +++ b/pkgs/by-name/an/antibody/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "antibody"; @@ -15,7 +20,11 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; meta = with lib; { description = "Fastest shell plugin manager"; diff --git a/pkgs/by-name/an/antic/package.nix b/pkgs/by-name/an/antic/package.nix index 3534b40122f14d..bb7c40bafd417f 100644 --- a/pkgs/by-name/an/antic/package.nix +++ b/pkgs/by-name/an/antic/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, mpir -, gmp -, mpfr -, flint +{ + lib, + stdenv, + fetchFromGitHub, + mpir, + gmp, + mpfr, + flint, }: stdenv.mkDerivation rec { @@ -18,7 +19,12 @@ stdenv.mkDerivation rec { sha256 = "sha256-bQ2VvCS+lGro5qxs+qBz3RpUenxQTmTr+lm9BFZWYts="; }; - buildInputs = [ mpir gmp mpfr flint ]; + buildInputs = [ + mpir + gmp + mpfr + flint + ]; configureFlags = [ "--with-gmp=${gmp}" diff --git a/pkgs/by-name/an/antidote/package.nix b/pkgs/by-name/an/antidote/package.nix index a4b29c4bd89196..f1060567983b2d 100644 --- a/pkgs/by-name/an/antidote/package.nix +++ b/pkgs/by-name/an/antidote/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation (finalAttrs: { version = "1.9.7"; diff --git a/pkgs/by-name/an/antigen/package.nix b/pkgs/by-name/an/antigen/package.nix index 1b2795ee971ef1..f5efbc5fa7901f 100644 --- a/pkgs/by-name/an/antigen/package.nix +++ b/pkgs/by-name/an/antigen/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "2.2.3"; diff --git a/pkgs/by-name/an/antimatter-dimensions/package.nix b/pkgs/by-name/an/antimatter-dimensions/package.nix index 84c0348fdb6e7b..9e40ab88bf2952 100644 --- a/pkgs/by-name/an/antimatter-dimensions/package.nix +++ b/pkgs/by-name/an/antimatter-dimensions/package.nix @@ -1,12 +1,13 @@ -{ buildNpmPackage -, copyDesktopItems -, electron -, fetchFromGitHub -, lib -, makeDesktopItem -, unstableGitUpdater -, writeScriptBin -, electronAppName ? "Antimatter Dimensions" +{ + buildNpmPackage, + copyDesktopItems, + electron, + fetchFromGitHub, + lib, + makeDesktopItem, + unstableGitUpdater, + writeScriptBin, + electronAppName ? "Antimatter Dimensions", }: let diff --git a/pkgs/by-name/an/antiword/package.nix b/pkgs/by-name/an/antiword/package.nix index 09e387cb0554c0..62fdbb93dbcead 100644 --- a/pkgs/by-name/an/antiword/package.nix +++ b/pkgs/by-name/an/antiword/package.nix @@ -1,6 +1,10 @@ -{ lib, fetchurl, stdenv }: +{ + lib, + fetchurl, + stdenv, +}: -stdenv.mkDerivation rec{ +stdenv.mkDerivation rec { pname = "antiword"; version = "0.37"; diff --git a/pkgs/by-name/an/antsimulator/package.nix b/pkgs/by-name/an/antsimulator/package.nix index 204b1c50f268bb..70015266a18b5a 100644 --- a/pkgs/by-name/an/antsimulator/package.nix +++ b/pkgs/by-name/an/antsimulator/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, sfml }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + sfml, +}: stdenv.mkDerivation rec { pname = "antsimulator"; diff --git a/pkgs/by-name/an/anttweakbar/package.nix b/pkgs/by-name/an/anttweakbar/package.nix index 6c1eeff941189c..441303c2e37d3c 100644 --- a/pkgs/by-name/an/anttweakbar/package.nix +++ b/pkgs/by-name/an/anttweakbar/package.nix @@ -1,14 +1,28 @@ -{ lib, stdenv, fetchurl, unzip, xorg, libGLU, libGL }: +{ + lib, + stdenv, + fetchurl, + unzip, + xorg, + libGLU, + libGL, +}: stdenv.mkDerivation rec { pname = "AntTweakBar"; version = "1.16"; nativeBuildInputs = [ unzip ]; - buildInputs = [ xorg.libX11 libGLU libGL ]; + buildInputs = [ + xorg.libX11 + libGLU + libGL + ]; src = fetchurl { - url = "mirror://sourceforge/project/anttweakbar/AntTweakBar_${lib.replaceStrings ["."] [""] version}.zip"; + url = "mirror://sourceforge/project/anttweakbar/AntTweakBar_${ + lib.replaceStrings [ "." ] [ "" ] version + }.zip"; sha256 = "0z3frxpzf54cjs07m6kg09p7nljhr7140f4pznwi7srwq4cvgkpv"; }; diff --git a/pkgs/by-name/an/anuko-time-tracker/package.nix b/pkgs/by-name/an/anuko-time-tracker/package.nix index 583f2db81938d0..3050118abeacb4 100644 --- a/pkgs/by-name/an/anuko-time-tracker/package.nix +++ b/pkgs/by-name/an/anuko-time-tracker/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, nixosTests -, php +{ + lib, + stdenvNoCC, + fetchFromGitHub, + nixosTests, + php, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/an/anydesk/package.nix b/pkgs/by-name/an/anydesk/package.nix index 2c664ac34cc983..00f6c2354a45fd 100644 --- a/pkgs/by-name/an/anydesk/package.nix +++ b/pkgs/by-name/an/anydesk/package.nix @@ -1,11 +1,36 @@ -{ lib, stdenv, fetchurl, makeWrapper, makeDesktopItem, genericUpdater, writeShellScript -, atk, cairo, gdk-pixbuf, glib, gnome2, gtk2, libGLU, libGL, pango, xorg, minizip -, lsb-release, freetype, fontconfig, polkit, polkit_gnome, pciutils, copyDesktopItems -, pulseaudio }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + makeDesktopItem, + genericUpdater, + writeShellScript, + atk, + cairo, + gdk-pixbuf, + glib, + gnome2, + gtk2, + libGLU, + libGL, + pango, + xorg, + minizip, + lsb-release, + freetype, + fontconfig, + polkit, + polkit_gnome, + pciutils, + copyDesktopItems, + pulseaudio, +}: let description = "Desktop sharing application, providing remote support and online meetings"; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "anydesk"; version = "6.4.0"; @@ -17,16 +42,46 @@ in stdenv.mkDerivation (finalAttrs: { hash = "sha256-yGzTqbv3SQT6V/DcY8GvRDXilYrZXVsmQOnqy/5+ev8="; }; - buildInputs = [ - atk cairo gdk-pixbuf glib gtk2 stdenv.cc.cc pango - gnome2.gtkglext libGLU libGL minizip freetype - fontconfig polkit polkit_gnome pulseaudio - ] ++ (with xorg; [ - libxcb libxkbfile libX11 libXdamage libXext libXfixes libXi libXmu - libXrandr libXtst libXt libICE libSM libXrender - ]); + buildInputs = + [ + atk + cairo + gdk-pixbuf + glib + gtk2 + stdenv.cc.cc + pango + gnome2.gtkglext + libGLU + libGL + minizip + freetype + fontconfig + polkit + polkit_gnome + pulseaudio + ] + ++ (with xorg; [ + libxcb + libxkbfile + libX11 + libXdamage + libXext + libXfixes + libXi + libXmu + libXrandr + libXtst + libXt + libICE + libSM + libXrender + ]); - nativeBuildInputs = [ copyDesktopItems makeWrapper ]; + nativeBuildInputs = [ + copyDesktopItems + makeWrapper + ]; desktopItems = [ (makeDesktopItem { @@ -63,7 +118,12 @@ in stdenv.mkDerivation (finalAttrs: { $out/bin/anydesk wrapProgram $out/bin/anydesk \ - --prefix PATH : ${lib.makeBinPath [ lsb-release pciutils ]} + --prefix PATH : ${ + lib.makeBinPath [ + lsb-release + pciutils + ] + } ''; passthru = { @@ -83,6 +143,9 @@ in stdenv.mkDerivation (finalAttrs: { sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; license = lib.licenses.unfree; platforms = [ "x86_64-linux" ]; - maintainers = with lib.maintainers; [ shyim cheriimoya ]; + maintainers = with lib.maintainers; [ + shyim + cheriimoya + ]; }; }) diff --git a/pkgs/by-name/an/anyk/package.nix b/pkgs/by-name/an/anyk/package.nix index 445b461759cfff..cb731fde669bb5 100644 --- a/pkgs/by-name/an/anyk/package.nix +++ b/pkgs/by-name/an/anyk/package.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchurl -, fetchzip -, openjdk -, openjfx -, writeScript -, runCommandLocal -, bash -, unzip -, makeWrapper -, libredirect -, xsettingsd -, makeDesktopItem -, copyDesktopItems -, python3 +{ + stdenv, + lib, + fetchurl, + fetchzip, + openjdk, + openjfx, + writeScript, + runCommandLocal, + bash, + unzip, + makeWrapper, + libredirect, + xsettingsd, + makeDesktopItem, + copyDesktopItems, + python3, }: let # Run update.py to update this file. @@ -51,7 +52,7 @@ let }) # Patch one of the ÁNYK classes so it works with the packages above by removing .internal. from the package names. - (runCommandLocal "anyk-patch" {} '' + (runCommandLocal "anyk-patch" { } '' mkdir $out cd $out ${unzip}/bin/unzip ${src}/application/abevjava.jar hu/piller/enykp/niszws/ClientStubBuilder.class @@ -92,14 +93,18 @@ let # ÁNYK crashes with NullPointerException with the GTK look and feel so use the cross-platform one. exec ${jdkWithFX}/bin/java -Dswing.systemlaf=javax.swing.plaf.metal.MetalLookAndFeel $SCALING_PROP "$@" ''; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "anyk"; inherit version src; dontConfigure = true; dontBuild = true; - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; desktopItems = [ (makeDesktopItem rec { @@ -145,4 +150,3 @@ in stdenv.mkDerivation { mainProgram = "anyk"; }; } - diff --git a/pkgs/by-name/an/anytone-emu/package.nix b/pkgs/by-name/an/anytone-emu/package.nix index 8d87096b44077d..c60ac90e816680 100644 --- a/pkgs/by-name/an/anytone-emu/package.nix +++ b/pkgs/by-name/an/anytone-emu/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, udev +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + udev, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ap/apache-airflow/package.nix b/pkgs/by-name/ap/apache-airflow/package.nix index 48df7ea612b4f7..1cf891aa77b812 100644 --- a/pkgs/by-name/ap/apache-airflow/package.nix +++ b/pkgs/by-name/ap/apache-airflow/package.nix @@ -1,6 +1,7 @@ -{ fetchFromGitHub -, fetchPypi -, python3 +{ + fetchFromGitHub, + fetchPypi, + python3, }: let @@ -55,7 +56,7 @@ let inherit version; hash = "sha256-7e6bCn/yZiG9WowQ/0hK4oc3okENmbC7mmhQx/uXeqA="; }; - nativeBuildInputs = (o.nativeBuildInputs or []) ++ [ + nativeBuildInputs = (o.nativeBuildInputs or [ ]) ++ [ pySelf.setuptools ]; }); @@ -101,7 +102,8 @@ let in # See note in ./python-package.nix for # instructions on manually testing the web UI -with python.pkgs; (toPythonApplication apache-airflow).overrideAttrs (previousAttrs: { +with python.pkgs; +(toPythonApplication apache-airflow).overrideAttrs (previousAttrs: { # Provide access to airflow's modified python package set # for the cases where external scripts need to import # airflow modules, though *caveat emptor* because many of diff --git a/pkgs/by-name/ap/apache-airflow/providers.nix b/pkgs/by-name/ap/apache-airflow/providers.nix index 00b31ca04cbdfb..4edb68ac43f4ef 100644 --- a/pkgs/by-name/ap/apache-airflow/providers.nix +++ b/pkgs/by-name/ap/apache-airflow/providers.nix @@ -1,307 +1,1549 @@ # Warning: generated by update-providers.py, do not update manually { airbyte = { - deps = [ "requests" "requests-toolbelt" ]; - imports = [ "airflow.providers.airbyte.hooks.airbyte" "airflow.providers.airbyte.operators.airbyte" ]; + deps = [ + "requests" + "requests-toolbelt" + ]; + imports = [ + "airflow.providers.airbyte.hooks.airbyte" + "airflow.providers.airbyte.operators.airbyte" + ]; }; alibaba = { deps = [ "oss2" ]; - imports = [ "airflow.providers.alibaba.cloud.hooks.oss" "airflow.providers.alibaba.cloud.operators.oss" ]; + imports = [ + "airflow.providers.alibaba.cloud.hooks.oss" + "airflow.providers.alibaba.cloud.operators.oss" + ]; }; amazon = { - deps = [ "adal" "apache-beam" "asgiref" "azure-batch" "azure-cosmos" "azure-datalake-store" "azure-identity" "azure-keyvault-secrets" "azure-mgmt-containerinstance" "azure-mgmt-datafactory" "azure-mgmt-datalake-store" "azure-mgmt-resource" "azure-servicebus" "azure-storage-blob" "azure-storage-common" "azure-storage-file" "azure-synapse-spark" "boto3" "cassandra-driver" "cryptography" "dnspython" "google-api-core" "google-api-python-client" "google-auth" "google-auth-httplib2" "google-cloud-automl" "google-cloud-bigquery-datatransfer" "google-cloud-bigtable" "google-cloud-compute" "google-cloud-container" "google-cloud-datacatalog" "google-cloud-dataproc" "google-cloud-dlp" "google-cloud-kms" "google-cloud-language" "google-cloud-logging" "google-cloud-monitoring" "google-cloud-pubsub" "google-cloud-redis" "google-cloud-secret-manager" "google-cloud-spanner" "google-cloud-speech" "google-cloud-storage" "google-cloud-tasks" "google-cloud-texttospeech" "google-cloud-translate" "google-cloud-videointelligence" "google-cloud-vision" "grpcio-gcp" "httpx" "json-merge-patch" "jsonpath-ng" "kubernetes" "mypy-boto3-appflow" "mypy-boto3-rds" "mypy-boto3-redshift-data" "mysqlclient" "oracledb" "pandas" "paramiko" "proto-plus" "protobuf" "psycopg2" "pymongo" "pyopenssl" "pysftp" "redshift-connector" "simple-salesforce" "smbprotocol" "sshtunnel" "thrift" "vertica-python" ]; - imports = [ "airflow.providers.amazon.aws.hooks.appflow" "airflow.providers.amazon.aws.hooks.athena" "airflow.providers.amazon.aws.hooks.base_aws" "airflow.providers.amazon.aws.hooks.batch_client" "airflow.providers.amazon.aws.hooks.batch_waiters" "airflow.providers.amazon.aws.hooks.cloud_formation" "airflow.providers.amazon.aws.hooks.datasync" "airflow.providers.amazon.aws.hooks.dms" "airflow.providers.amazon.aws.hooks.dynamodb" "airflow.providers.amazon.aws.hooks.ec2" "airflow.providers.amazon.aws.hooks.ecs" "airflow.providers.amazon.aws.hooks.eks" "airflow.providers.amazon.aws.hooks.elasticache_replication_group" "airflow.providers.amazon.aws.hooks.emr" "airflow.providers.amazon.aws.hooks.emr" "airflow.providers.amazon.aws.hooks.glacier" "airflow.providers.amazon.aws.hooks.glue" "airflow.providers.amazon.aws.hooks.glue_catalog" "airflow.providers.amazon.aws.hooks.glue_crawler" "airflow.providers.amazon.aws.hooks.kinesis" "airflow.providers.amazon.aws.hooks.lambda_function" "airflow.providers.amazon.aws.hooks.logs" "airflow.providers.amazon.aws.hooks.quicksight" "airflow.providers.amazon.aws.hooks.rds" "airflow.providers.amazon.aws.hooks.redshift_cluster" "airflow.providers.amazon.aws.hooks.redshift_data" "airflow.providers.amazon.aws.hooks.redshift_sql" "airflow.providers.amazon.aws.hooks.s3" "airflow.providers.amazon.aws.hooks.sagemaker" "airflow.providers.amazon.aws.hooks.secrets_manager" "airflow.providers.amazon.aws.hooks.ses" "airflow.providers.amazon.aws.hooks.sns" "airflow.providers.amazon.aws.hooks.sqs" "airflow.providers.amazon.aws.hooks.step_function" "airflow.providers.amazon.aws.hooks.sts" "airflow.providers.amazon.aws.operators.appflow" "airflow.providers.amazon.aws.operators.athena" "airflow.providers.amazon.aws.operators.aws_lambda" "airflow.providers.amazon.aws.operators.batch" "airflow.providers.amazon.aws.operators.cloud_formation" "airflow.providers.amazon.aws.operators.datasync" "airflow.providers.amazon.aws.operators.dms" "airflow.providers.amazon.aws.operators.ec2" "airflow.providers.amazon.aws.operators.ecs" "airflow.providers.amazon.aws.operators.eks" "airflow.providers.amazon.aws.operators.emr" "airflow.providers.amazon.aws.operators.emr" "airflow.providers.amazon.aws.operators.glacier" "airflow.providers.amazon.aws.operators.glue" "airflow.providers.amazon.aws.operators.glue_crawler" "airflow.providers.amazon.aws.operators.lambda_function" "airflow.providers.amazon.aws.operators.quicksight" "airflow.providers.amazon.aws.operators.rds" "airflow.providers.amazon.aws.operators.redshift_cluster" "airflow.providers.amazon.aws.operators.redshift_data" "airflow.providers.amazon.aws.operators.redshift_sql" "airflow.providers.amazon.aws.operators.s3" "airflow.providers.amazon.aws.operators.sagemaker" "airflow.providers.amazon.aws.operators.sns" "airflow.providers.amazon.aws.operators.sqs" "airflow.providers.amazon.aws.operators.step_function" ]; + deps = [ + "adal" + "apache-beam" + "asgiref" + "azure-batch" + "azure-cosmos" + "azure-datalake-store" + "azure-identity" + "azure-keyvault-secrets" + "azure-mgmt-containerinstance" + "azure-mgmt-datafactory" + "azure-mgmt-datalake-store" + "azure-mgmt-resource" + "azure-servicebus" + "azure-storage-blob" + "azure-storage-common" + "azure-storage-file" + "azure-synapse-spark" + "boto3" + "cassandra-driver" + "cryptography" + "dnspython" + "google-api-core" + "google-api-python-client" + "google-auth" + "google-auth-httplib2" + "google-cloud-automl" + "google-cloud-bigquery-datatransfer" + "google-cloud-bigtable" + "google-cloud-compute" + "google-cloud-container" + "google-cloud-datacatalog" + "google-cloud-dataproc" + "google-cloud-dlp" + "google-cloud-kms" + "google-cloud-language" + "google-cloud-logging" + "google-cloud-monitoring" + "google-cloud-pubsub" + "google-cloud-redis" + "google-cloud-secret-manager" + "google-cloud-spanner" + "google-cloud-speech" + "google-cloud-storage" + "google-cloud-tasks" + "google-cloud-texttospeech" + "google-cloud-translate" + "google-cloud-videointelligence" + "google-cloud-vision" + "grpcio-gcp" + "httpx" + "json-merge-patch" + "jsonpath-ng" + "kubernetes" + "mypy-boto3-appflow" + "mypy-boto3-rds" + "mypy-boto3-redshift-data" + "mysqlclient" + "oracledb" + "pandas" + "paramiko" + "proto-plus" + "protobuf" + "psycopg2" + "pymongo" + "pyopenssl" + "pysftp" + "redshift-connector" + "simple-salesforce" + "smbprotocol" + "sshtunnel" + "thrift" + "vertica-python" + ]; + imports = [ + "airflow.providers.amazon.aws.hooks.appflow" + "airflow.providers.amazon.aws.hooks.athena" + "airflow.providers.amazon.aws.hooks.base_aws" + "airflow.providers.amazon.aws.hooks.batch_client" + "airflow.providers.amazon.aws.hooks.batch_waiters" + "airflow.providers.amazon.aws.hooks.cloud_formation" + "airflow.providers.amazon.aws.hooks.datasync" + "airflow.providers.amazon.aws.hooks.dms" + "airflow.providers.amazon.aws.hooks.dynamodb" + "airflow.providers.amazon.aws.hooks.ec2" + "airflow.providers.amazon.aws.hooks.ecs" + "airflow.providers.amazon.aws.hooks.eks" + "airflow.providers.amazon.aws.hooks.elasticache_replication_group" + "airflow.providers.amazon.aws.hooks.emr" + "airflow.providers.amazon.aws.hooks.emr" + "airflow.providers.amazon.aws.hooks.glacier" + "airflow.providers.amazon.aws.hooks.glue" + "airflow.providers.amazon.aws.hooks.glue_catalog" + "airflow.providers.amazon.aws.hooks.glue_crawler" + "airflow.providers.amazon.aws.hooks.kinesis" + "airflow.providers.amazon.aws.hooks.lambda_function" + "airflow.providers.amazon.aws.hooks.logs" + "airflow.providers.amazon.aws.hooks.quicksight" + "airflow.providers.amazon.aws.hooks.rds" + "airflow.providers.amazon.aws.hooks.redshift_cluster" + "airflow.providers.amazon.aws.hooks.redshift_data" + "airflow.providers.amazon.aws.hooks.redshift_sql" + "airflow.providers.amazon.aws.hooks.s3" + "airflow.providers.amazon.aws.hooks.sagemaker" + "airflow.providers.amazon.aws.hooks.secrets_manager" + "airflow.providers.amazon.aws.hooks.ses" + "airflow.providers.amazon.aws.hooks.sns" + "airflow.providers.amazon.aws.hooks.sqs" + "airflow.providers.amazon.aws.hooks.step_function" + "airflow.providers.amazon.aws.hooks.sts" + "airflow.providers.amazon.aws.operators.appflow" + "airflow.providers.amazon.aws.operators.athena" + "airflow.providers.amazon.aws.operators.aws_lambda" + "airflow.providers.amazon.aws.operators.batch" + "airflow.providers.amazon.aws.operators.cloud_formation" + "airflow.providers.amazon.aws.operators.datasync" + "airflow.providers.amazon.aws.operators.dms" + "airflow.providers.amazon.aws.operators.ec2" + "airflow.providers.amazon.aws.operators.ecs" + "airflow.providers.amazon.aws.operators.eks" + "airflow.providers.amazon.aws.operators.emr" + "airflow.providers.amazon.aws.operators.emr" + "airflow.providers.amazon.aws.operators.glacier" + "airflow.providers.amazon.aws.operators.glue" + "airflow.providers.amazon.aws.operators.glue_crawler" + "airflow.providers.amazon.aws.operators.lambda_function" + "airflow.providers.amazon.aws.operators.quicksight" + "airflow.providers.amazon.aws.operators.rds" + "airflow.providers.amazon.aws.operators.redshift_cluster" + "airflow.providers.amazon.aws.operators.redshift_data" + "airflow.providers.amazon.aws.operators.redshift_sql" + "airflow.providers.amazon.aws.operators.s3" + "airflow.providers.amazon.aws.operators.sagemaker" + "airflow.providers.amazon.aws.operators.sns" + "airflow.providers.amazon.aws.operators.sqs" + "airflow.providers.amazon.aws.operators.step_function" + ]; }; apache_beam = { - deps = [ "adal" "apache-beam" "asgiref" "azure-batch" "azure-cosmos" "azure-datalake-store" "azure-identity" "azure-keyvault-secrets" "azure-mgmt-containerinstance" "azure-mgmt-datafactory" "azure-mgmt-datalake-store" "azure-mgmt-resource" "azure-servicebus" "azure-storage-blob" "azure-storage-common" "azure-storage-file" "azure-synapse-spark" "boto3" "cassandra-driver" "cryptography" "dnspython" "google-api-core" "google-api-python-client" "google-auth" "google-auth-httplib2" "google-cloud-automl" "google-cloud-bigquery-datatransfer" "google-cloud-bigtable" "google-cloud-compute" "google-cloud-container" "google-cloud-datacatalog" "google-cloud-dataproc" "google-cloud-dlp" "google-cloud-kms" "google-cloud-language" "google-cloud-logging" "google-cloud-monitoring" "google-cloud-pubsub" "google-cloud-redis" "google-cloud-secret-manager" "google-cloud-spanner" "google-cloud-speech" "google-cloud-storage" "google-cloud-tasks" "google-cloud-texttospeech" "google-cloud-translate" "google-cloud-videointelligence" "google-cloud-vision" "grpcio-gcp" "httpx" "json-merge-patch" "jsonpath-ng" "kubernetes" "mypy-boto3-appflow" "mypy-boto3-rds" "mypy-boto3-redshift-data" "mysqlclient" "oracledb" "pandas" "paramiko" "proto-plus" "protobuf" "psycopg2" "pymongo" "pyopenssl" "pysftp" "redshift-connector" "simple-salesforce" "smbprotocol" "sshtunnel" "thrift" "vertica-python" ]; - imports = [ "airflow.providers.apache.beam.hooks.beam" "airflow.providers.apache.beam.operators.beam" ]; + deps = [ + "adal" + "apache-beam" + "asgiref" + "azure-batch" + "azure-cosmos" + "azure-datalake-store" + "azure-identity" + "azure-keyvault-secrets" + "azure-mgmt-containerinstance" + "azure-mgmt-datafactory" + "azure-mgmt-datalake-store" + "azure-mgmt-resource" + "azure-servicebus" + "azure-storage-blob" + "azure-storage-common" + "azure-storage-file" + "azure-synapse-spark" + "boto3" + "cassandra-driver" + "cryptography" + "dnspython" + "google-api-core" + "google-api-python-client" + "google-auth" + "google-auth-httplib2" + "google-cloud-automl" + "google-cloud-bigquery-datatransfer" + "google-cloud-bigtable" + "google-cloud-compute" + "google-cloud-container" + "google-cloud-datacatalog" + "google-cloud-dataproc" + "google-cloud-dlp" + "google-cloud-kms" + "google-cloud-language" + "google-cloud-logging" + "google-cloud-monitoring" + "google-cloud-pubsub" + "google-cloud-redis" + "google-cloud-secret-manager" + "google-cloud-spanner" + "google-cloud-speech" + "google-cloud-storage" + "google-cloud-tasks" + "google-cloud-texttospeech" + "google-cloud-translate" + "google-cloud-videointelligence" + "google-cloud-vision" + "grpcio-gcp" + "httpx" + "json-merge-patch" + "jsonpath-ng" + "kubernetes" + "mypy-boto3-appflow" + "mypy-boto3-rds" + "mypy-boto3-redshift-data" + "mysqlclient" + "oracledb" + "pandas" + "paramiko" + "proto-plus" + "protobuf" + "psycopg2" + "pymongo" + "pyopenssl" + "pysftp" + "redshift-connector" + "simple-salesforce" + "smbprotocol" + "sshtunnel" + "thrift" + "vertica-python" + ]; + imports = [ + "airflow.providers.apache.beam.hooks.beam" + "airflow.providers.apache.beam.operators.beam" + ]; }; apache_cassandra = { deps = [ "cassandra-driver" ]; imports = [ "airflow.providers.apache.cassandra.hooks.cassandra" ]; }; apache_drill = { - deps = [ ]; - imports = [ "airflow.providers.apache.drill.hooks.drill" "airflow.providers.apache.drill.operators.drill" ]; + deps = [ ]; + imports = [ + "airflow.providers.apache.drill.hooks.drill" + "airflow.providers.apache.drill.operators.drill" + ]; }; apache_druid = { - deps = [ "adal" "apache-beam" "asgiref" "azure-batch" "azure-cosmos" "azure-datalake-store" "azure-identity" "azure-keyvault-secrets" "azure-mgmt-containerinstance" "azure-mgmt-datafactory" "azure-mgmt-datalake-store" "azure-mgmt-resource" "azure-servicebus" "azure-storage-blob" "azure-storage-common" "azure-storage-file" "azure-synapse-spark" "boto3" "cassandra-driver" "cryptography" "dnspython" "google-api-core" "google-api-python-client" "google-auth" "google-auth-httplib2" "google-cloud-automl" "google-cloud-bigquery-datatransfer" "google-cloud-bigtable" "google-cloud-compute" "google-cloud-container" "google-cloud-datacatalog" "google-cloud-dataproc" "google-cloud-dlp" "google-cloud-kms" "google-cloud-language" "google-cloud-logging" "google-cloud-monitoring" "google-cloud-pubsub" "google-cloud-redis" "google-cloud-secret-manager" "google-cloud-spanner" "google-cloud-speech" "google-cloud-storage" "google-cloud-tasks" "google-cloud-texttospeech" "google-cloud-translate" "google-cloud-videointelligence" "google-cloud-vision" "grpcio-gcp" "httpx" "json-merge-patch" "jsonpath-ng" "kubernetes" "mypy-boto3-appflow" "mypy-boto3-rds" "mypy-boto3-redshift-data" "mysqlclient" "oracledb" "pandas" "paramiko" "proto-plus" "protobuf" "psycopg2" "pydruid" "pymongo" "pyopenssl" "pysftp" "redshift-connector" "simple-salesforce" "smbprotocol" "sshtunnel" "thrift" "vertica-python" ]; - imports = [ "airflow.providers.apache.druid.hooks.druid" "airflow.providers.apache.druid.operators.druid" "airflow.providers.apache.druid.operators.druid_check" ]; + deps = [ + "adal" + "apache-beam" + "asgiref" + "azure-batch" + "azure-cosmos" + "azure-datalake-store" + "azure-identity" + "azure-keyvault-secrets" + "azure-mgmt-containerinstance" + "azure-mgmt-datafactory" + "azure-mgmt-datalake-store" + "azure-mgmt-resource" + "azure-servicebus" + "azure-storage-blob" + "azure-storage-common" + "azure-storage-file" + "azure-synapse-spark" + "boto3" + "cassandra-driver" + "cryptography" + "dnspython" + "google-api-core" + "google-api-python-client" + "google-auth" + "google-auth-httplib2" + "google-cloud-automl" + "google-cloud-bigquery-datatransfer" + "google-cloud-bigtable" + "google-cloud-compute" + "google-cloud-container" + "google-cloud-datacatalog" + "google-cloud-dataproc" + "google-cloud-dlp" + "google-cloud-kms" + "google-cloud-language" + "google-cloud-logging" + "google-cloud-monitoring" + "google-cloud-pubsub" + "google-cloud-redis" + "google-cloud-secret-manager" + "google-cloud-spanner" + "google-cloud-speech" + "google-cloud-storage" + "google-cloud-tasks" + "google-cloud-texttospeech" + "google-cloud-translate" + "google-cloud-videointelligence" + "google-cloud-vision" + "grpcio-gcp" + "httpx" + "json-merge-patch" + "jsonpath-ng" + "kubernetes" + "mypy-boto3-appflow" + "mypy-boto3-rds" + "mypy-boto3-redshift-data" + "mysqlclient" + "oracledb" + "pandas" + "paramiko" + "proto-plus" + "protobuf" + "psycopg2" + "pydruid" + "pymongo" + "pyopenssl" + "pysftp" + "redshift-connector" + "simple-salesforce" + "smbprotocol" + "sshtunnel" + "thrift" + "vertica-python" + ]; + imports = [ + "airflow.providers.apache.druid.hooks.druid" + "airflow.providers.apache.druid.operators.druid" + "airflow.providers.apache.druid.operators.druid_check" + ]; }; apache_hdfs = { - deps = [ ]; - imports = [ "airflow.providers.apache.hdfs.hooks.hdfs" "airflow.providers.apache.hdfs.hooks.webhdfs" ]; + deps = [ ]; + imports = [ + "airflow.providers.apache.hdfs.hooks.hdfs" + "airflow.providers.apache.hdfs.hooks.webhdfs" + ]; }; apache_hive = { - deps = [ "adal" "apache-beam" "asgiref" "azure-batch" "azure-cosmos" "azure-datalake-store" "azure-identity" "azure-keyvault-secrets" "azure-mgmt-containerinstance" "azure-mgmt-datafactory" "azure-mgmt-datalake-store" "azure-mgmt-resource" "azure-servicebus" "azure-storage-blob" "azure-storage-common" "azure-storage-file" "azure-synapse-spark" "boto3" "cassandra-driver" "cryptography" "dnspython" "google-api-core" "google-api-python-client" "google-auth" "google-auth-httplib2" "google-cloud-automl" "google-cloud-bigquery-datatransfer" "google-cloud-bigtable" "google-cloud-compute" "google-cloud-container" "google-cloud-datacatalog" "google-cloud-dataproc" "google-cloud-dlp" "google-cloud-kms" "google-cloud-language" "google-cloud-logging" "google-cloud-monitoring" "google-cloud-pubsub" "google-cloud-redis" "google-cloud-secret-manager" "google-cloud-spanner" "google-cloud-speech" "google-cloud-storage" "google-cloud-tasks" "google-cloud-texttospeech" "google-cloud-translate" "google-cloud-videointelligence" "google-cloud-vision" "grpcio-gcp" "httpx" "json-merge-patch" "jsonpath-ng" "kubernetes" "mypy-boto3-appflow" "mypy-boto3-rds" "mypy-boto3-redshift-data" "mysqlclient" "oracledb" "pandas" "paramiko" "proto-plus" "protobuf" "psycopg2" "pymongo" "pyopenssl" "pysftp" "redshift-connector" "simple-salesforce" "smbprotocol" "sshtunnel" "thrift" "vertica-python" ]; - imports = [ "airflow.providers.apache.hive.hooks.hive" "airflow.providers.apache.hive.operators.hive" "airflow.providers.apache.hive.operators.hive_stats" ]; + deps = [ + "adal" + "apache-beam" + "asgiref" + "azure-batch" + "azure-cosmos" + "azure-datalake-store" + "azure-identity" + "azure-keyvault-secrets" + "azure-mgmt-containerinstance" + "azure-mgmt-datafactory" + "azure-mgmt-datalake-store" + "azure-mgmt-resource" + "azure-servicebus" + "azure-storage-blob" + "azure-storage-common" + "azure-storage-file" + "azure-synapse-spark" + "boto3" + "cassandra-driver" + "cryptography" + "dnspython" + "google-api-core" + "google-api-python-client" + "google-auth" + "google-auth-httplib2" + "google-cloud-automl" + "google-cloud-bigquery-datatransfer" + "google-cloud-bigtable" + "google-cloud-compute" + "google-cloud-container" + "google-cloud-datacatalog" + "google-cloud-dataproc" + "google-cloud-dlp" + "google-cloud-kms" + "google-cloud-language" + "google-cloud-logging" + "google-cloud-monitoring" + "google-cloud-pubsub" + "google-cloud-redis" + "google-cloud-secret-manager" + "google-cloud-spanner" + "google-cloud-speech" + "google-cloud-storage" + "google-cloud-tasks" + "google-cloud-texttospeech" + "google-cloud-translate" + "google-cloud-videointelligence" + "google-cloud-vision" + "grpcio-gcp" + "httpx" + "json-merge-patch" + "jsonpath-ng" + "kubernetes" + "mypy-boto3-appflow" + "mypy-boto3-rds" + "mypy-boto3-redshift-data" + "mysqlclient" + "oracledb" + "pandas" + "paramiko" + "proto-plus" + "protobuf" + "psycopg2" + "pymongo" + "pyopenssl" + "pysftp" + "redshift-connector" + "simple-salesforce" + "smbprotocol" + "sshtunnel" + "thrift" + "vertica-python" + ]; + imports = [ + "airflow.providers.apache.hive.hooks.hive" + "airflow.providers.apache.hive.operators.hive" + "airflow.providers.apache.hive.operators.hive_stats" + ]; }; apache_kylin = { - deps = [ ]; - imports = [ "airflow.providers.apache.kylin.hooks.kylin" "airflow.providers.apache.kylin.operators.kylin_cube" ]; + deps = [ ]; + imports = [ + "airflow.providers.apache.kylin.hooks.kylin" + "airflow.providers.apache.kylin.operators.kylin_cube" + ]; }; apache_livy = { - deps = [ "requests" "requests-toolbelt" ]; - imports = [ "airflow.providers.apache.livy.hooks.livy" "airflow.providers.apache.livy.operators.livy" ]; + deps = [ + "requests" + "requests-toolbelt" + ]; + imports = [ + "airflow.providers.apache.livy.hooks.livy" + "airflow.providers.apache.livy.operators.livy" + ]; }; apache_pig = { - deps = [ ]; - imports = [ "airflow.providers.apache.pig.hooks.pig" "airflow.providers.apache.pig.operators.pig" ]; + deps = [ ]; + imports = [ + "airflow.providers.apache.pig.hooks.pig" + "airflow.providers.apache.pig.operators.pig" + ]; }; apache_pinot = { - deps = [ ]; + deps = [ ]; imports = [ "airflow.providers.apache.pinot.hooks.pinot" ]; }; apache_spark = { deps = [ "pyspark" ]; - imports = [ "airflow.providers.apache.spark.hooks.spark_jdbc" "airflow.providers.apache.spark.hooks.spark_jdbc_script" "airflow.providers.apache.spark.hooks.spark_sql" "airflow.providers.apache.spark.hooks.spark_submit" "airflow.providers.apache.spark.operators.spark_jdbc" "airflow.providers.apache.spark.operators.spark_sql" "airflow.providers.apache.spark.operators.spark_submit" ]; + imports = [ + "airflow.providers.apache.spark.hooks.spark_jdbc" + "airflow.providers.apache.spark.hooks.spark_jdbc_script" + "airflow.providers.apache.spark.hooks.spark_sql" + "airflow.providers.apache.spark.hooks.spark_submit" + "airflow.providers.apache.spark.operators.spark_jdbc" + "airflow.providers.apache.spark.operators.spark_sql" + "airflow.providers.apache.spark.operators.spark_submit" + ]; }; apache_sqoop = { - deps = [ ]; - imports = [ "airflow.providers.apache.sqoop.hooks.sqoop" "airflow.providers.apache.sqoop.operators.sqoop" ]; + deps = [ ]; + imports = [ + "airflow.providers.apache.sqoop.hooks.sqoop" + "airflow.providers.apache.sqoop.operators.sqoop" + ]; }; arangodb = { deps = [ "python-arango" ]; - imports = [ "airflow.providers.arangodb.hooks.arangodb" "airflow.providers.arangodb.operators.arangodb" ]; + imports = [ + "airflow.providers.arangodb.hooks.arangodb" + "airflow.providers.arangodb.operators.arangodb" + ]; }; asana = { deps = [ "asana" ]; - imports = [ "airflow.providers.asana.hooks.asana" "airflow.providers.asana.operators.asana_tasks" ]; + imports = [ + "airflow.providers.asana.hooks.asana" + "airflow.providers.asana.operators.asana_tasks" + ]; }; atlassian_jira = { deps = [ "jira" ]; - imports = [ "airflow.providers.atlassian.jira.hooks.jira" "airflow.providers.atlassian.jira.operators.jira" ]; + imports = [ + "airflow.providers.atlassian.jira.hooks.jira" + "airflow.providers.atlassian.jira.operators.jira" + ]; }; celery = { - deps = [ "celery" "flower" ]; - imports = [ ]; + deps = [ + "celery" + "flower" + ]; + imports = [ ]; }; cloudant = { - deps = [ ]; + deps = [ ]; imports = [ "airflow.providers.cloudant.hooks.cloudant" ]; }; cncf_kubernetes = { - deps = [ "cryptography" "kubernetes" ]; - imports = [ "airflow.providers.cncf.kubernetes.hooks.kubernetes" "airflow.providers.cncf.kubernetes.operators.kubernetes_pod" "airflow.providers.cncf.kubernetes.operators.spark_kubernetes" ]; + deps = [ + "cryptography" + "kubernetes" + ]; + imports = [ + "airflow.providers.cncf.kubernetes.hooks.kubernetes" + "airflow.providers.cncf.kubernetes.operators.kubernetes_pod" + "airflow.providers.cncf.kubernetes.operators.spark_kubernetes" + ]; }; common_sql = { deps = [ "sqlparse" ]; - imports = [ "airflow.providers.common.sql.hooks.sql" "airflow.providers.common.sql.operators.sql" ]; + imports = [ + "airflow.providers.common.sql.hooks.sql" + "airflow.providers.common.sql.operators.sql" + ]; }; databricks = { - deps = [ "aiohttp" "databricks-sql-connector" "requests" ]; - imports = [ "airflow.providers.databricks.hooks.databricks" "airflow.providers.databricks.hooks.databricks_base" "airflow.providers.databricks.hooks.databricks_sql" "airflow.providers.databricks.operators.databricks" "airflow.providers.databricks.operators.databricks_repos" "airflow.providers.databricks.operators.databricks_sql" ]; + deps = [ + "aiohttp" + "databricks-sql-connector" + "requests" + ]; + imports = [ + "airflow.providers.databricks.hooks.databricks" + "airflow.providers.databricks.hooks.databricks_base" + "airflow.providers.databricks.hooks.databricks_sql" + "airflow.providers.databricks.operators.databricks" + "airflow.providers.databricks.operators.databricks_repos" + "airflow.providers.databricks.operators.databricks_sql" + ]; }; datadog = { deps = [ "datadog" ]; imports = [ "airflow.providers.datadog.hooks.datadog" ]; }; dbt_cloud = { - deps = [ "requests" "requests-toolbelt" ]; - imports = [ "airflow.providers.dbt.cloud.hooks.dbt" "airflow.providers.dbt.cloud.operators.dbt" ]; + deps = [ + "requests" + "requests-toolbelt" + ]; + imports = [ + "airflow.providers.dbt.cloud.hooks.dbt" + "airflow.providers.dbt.cloud.operators.dbt" + ]; }; dingding = { - deps = [ "requests" "requests-toolbelt" ]; - imports = [ "airflow.providers.dingding.hooks.dingding" "airflow.providers.dingding.operators.dingding" ]; + deps = [ + "requests" + "requests-toolbelt" + ]; + imports = [ + "airflow.providers.dingding.hooks.dingding" + "airflow.providers.dingding.operators.dingding" + ]; }; discord = { - deps = [ "requests" "requests-toolbelt" ]; - imports = [ "airflow.providers.discord.hooks.discord_webhook" "airflow.providers.discord.operators.discord_webhook" ]; + deps = [ + "requests" + "requests-toolbelt" + ]; + imports = [ + "airflow.providers.discord.hooks.discord_webhook" + "airflow.providers.discord.operators.discord_webhook" + ]; }; docker = { - deps = [ "docker" "python-dotenv" ]; - imports = [ "airflow.providers.docker.hooks.docker" "airflow.providers.docker.operators.docker" "airflow.providers.docker.operators.docker_swarm" ]; + deps = [ + "docker" + "python-dotenv" + ]; + imports = [ + "airflow.providers.docker.hooks.docker" + "airflow.providers.docker.operators.docker" + "airflow.providers.docker.operators.docker_swarm" + ]; }; elasticsearch = { - deps = [ "elasticsearch" "elasticsearch-dsl" ]; + deps = [ + "elasticsearch" + "elasticsearch-dsl" + ]; imports = [ "airflow.providers.elasticsearch.hooks.elasticsearch" ]; }; exasol = { deps = [ "pandas" ]; - imports = [ "airflow.providers.exasol.hooks.exasol" "airflow.providers.exasol.operators.exasol" ]; + imports = [ + "airflow.providers.exasol.hooks.exasol" + "airflow.providers.exasol.operators.exasol" + ]; }; facebook = { - deps = [ ]; + deps = [ ]; imports = [ "airflow.providers.facebook.ads.hooks.ads" ]; }; ftp = { - deps = [ ]; + deps = [ ]; imports = [ "airflow.providers.ftp.hooks.ftp" ]; }; github = { deps = [ "pygithub" ]; - imports = [ "airflow.providers.github.hooks.github" "airflow.providers.github.operators.github" ]; + imports = [ + "airflow.providers.github.hooks.github" + "airflow.providers.github.operators.github" + ]; }; google = { - deps = [ "adal" "apache-beam" "asgiref" "azure-batch" "azure-cosmos" "azure-datalake-store" "azure-identity" "azure-keyvault-secrets" "azure-mgmt-containerinstance" "azure-mgmt-datafactory" "azure-mgmt-datalake-store" "azure-mgmt-resource" "azure-servicebus" "azure-storage-blob" "azure-storage-common" "azure-storage-file" "azure-synapse-spark" "boto3" "cassandra-driver" "cryptography" "dnspython" "google-api-core" "google-api-python-client" "google-auth" "google-auth-httplib2" "google-cloud-automl" "google-cloud-bigquery-datatransfer" "google-cloud-bigtable" "google-cloud-compute" "google-cloud-container" "google-cloud-datacatalog" "google-cloud-dataproc" "google-cloud-dlp" "google-cloud-kms" "google-cloud-language" "google-cloud-logging" "google-cloud-monitoring" "google-cloud-pubsub" "google-cloud-redis" "google-cloud-secret-manager" "google-cloud-spanner" "google-cloud-speech" "google-cloud-storage" "google-cloud-tasks" "google-cloud-texttospeech" "google-cloud-translate" "google-cloud-videointelligence" "google-cloud-vision" "grpcio-gcp" "httpx" "json-merge-patch" "jsonpath-ng" "kubernetes" "mypy-boto3-appflow" "mypy-boto3-rds" "mypy-boto3-redshift-data" "mysqlclient" "oracledb" "pandas" "paramiko" "proto-plus" "protobuf" "psycopg2" "pymongo" "pyopenssl" "pysftp" "redshift-connector" "simple-salesforce" "smbprotocol" "sshtunnel" "thrift" "vertica-python" ]; - imports = [ "airflow.providers.google.ads.hooks.ads" "airflow.providers.google.ads.operators.ads" "airflow.providers.google.cloud.hooks.automl" "airflow.providers.google.cloud.hooks.bigquery" "airflow.providers.google.cloud.hooks.bigquery_dts" "airflow.providers.google.cloud.hooks.bigtable" "airflow.providers.google.cloud.hooks.cloud_build" "airflow.providers.google.cloud.hooks.cloud_composer" "airflow.providers.google.cloud.hooks.cloud_memorystore" "airflow.providers.google.cloud.hooks.cloud_sql" "airflow.providers.google.cloud.hooks.cloud_storage_transfer_service" "airflow.providers.google.cloud.hooks.compute" "airflow.providers.google.cloud.hooks.compute_ssh" "airflow.providers.google.cloud.hooks.datacatalog" "airflow.providers.google.cloud.hooks.dataflow" "airflow.providers.google.cloud.hooks.dataform" "airflow.providers.google.cloud.hooks.datafusion" "airflow.providers.google.cloud.hooks.dataplex" "airflow.providers.google.cloud.hooks.dataprep" "airflow.providers.google.cloud.hooks.dataproc" "airflow.providers.google.cloud.hooks.dataproc_metastore" "airflow.providers.google.cloud.hooks.datastore" "airflow.providers.google.cloud.hooks.dlp" "airflow.providers.google.cloud.hooks.functions" "airflow.providers.google.cloud.hooks.gcs" "airflow.providers.google.cloud.hooks.gdm" "airflow.providers.google.cloud.hooks.kms" "airflow.providers.google.cloud.hooks.kubernetes_engine" "airflow.providers.google.cloud.hooks.life_sciences" "airflow.providers.google.cloud.hooks.looker" "airflow.providers.google.cloud.hooks.mlengine" "airflow.providers.google.cloud.hooks.natural_language" "airflow.providers.google.cloud.hooks.os_login" "airflow.providers.google.cloud.hooks.pubsub" "airflow.providers.google.cloud.hooks.secret_manager" "airflow.providers.google.cloud.hooks.spanner" "airflow.providers.google.cloud.hooks.speech_to_text" "airflow.providers.google.cloud.hooks.stackdriver" "airflow.providers.google.cloud.hooks.tasks" "airflow.providers.google.cloud.hooks.text_to_speech" "airflow.providers.google.cloud.hooks.translate" "airflow.providers.google.cloud.hooks.vertex_ai.auto_ml" "airflow.providers.google.cloud.hooks.vertex_ai.batch_prediction_job" "airflow.providers.google.cloud.hooks.vertex_ai.custom_job" "airflow.providers.google.cloud.hooks.vertex_ai.dataset" "airflow.providers.google.cloud.hooks.vertex_ai.endpoint_service" "airflow.providers.google.cloud.hooks.vertex_ai.hyperparameter_tuning_job" "airflow.providers.google.cloud.hooks.vertex_ai.model_service" "airflow.providers.google.cloud.hooks.video_intelligence" "airflow.providers.google.cloud.hooks.vision" "airflow.providers.google.cloud.hooks.workflows" "airflow.providers.google.cloud.operators.automl" "airflow.providers.google.cloud.operators.bigquery" "airflow.providers.google.cloud.operators.bigquery_dts" "airflow.providers.google.cloud.operators.bigtable" "airflow.providers.google.cloud.operators.cloud_build" "airflow.providers.google.cloud.operators.cloud_composer" "airflow.providers.google.cloud.operators.cloud_memorystore" "airflow.providers.google.cloud.operators.cloud_sql" "airflow.providers.google.cloud.operators.cloud_storage_transfer_service" "airflow.providers.google.cloud.operators.compute" "airflow.providers.google.cloud.operators.datacatalog" "airflow.providers.google.cloud.operators.dataflow" "airflow.providers.google.cloud.operators.dataform" "airflow.providers.google.cloud.operators.datafusion" "airflow.providers.google.cloud.operators.dataplex" "airflow.providers.google.cloud.operators.dataprep" "airflow.providers.google.cloud.operators.dataproc" "airflow.providers.google.cloud.operators.dataproc_metastore" "airflow.providers.google.cloud.operators.datastore" "airflow.providers.google.cloud.operators.dlp" "airflow.providers.google.cloud.operators.functions" "airflow.providers.google.cloud.operators.gcs" "airflow.providers.google.cloud.operators.kubernetes_engine" "airflow.providers.google.cloud.operators.life_sciences" "airflow.providers.google.cloud.operators.looker" "airflow.providers.google.cloud.operators.mlengine" "airflow.providers.google.cloud.operators.natural_language" "airflow.providers.google.cloud.operators.pubsub" "airflow.providers.google.cloud.operators.spanner" "airflow.providers.google.cloud.operators.speech_to_text" "airflow.providers.google.cloud.operators.stackdriver" "airflow.providers.google.cloud.operators.tasks" "airflow.providers.google.cloud.operators.text_to_speech" "airflow.providers.google.cloud.operators.translate" "airflow.providers.google.cloud.operators.translate_speech" "airflow.providers.google.cloud.operators.translate_speech" "airflow.providers.google.cloud.operators.vertex_ai.auto_ml" "airflow.providers.google.cloud.operators.vertex_ai.batch_prediction_job" "airflow.providers.google.cloud.operators.vertex_ai.custom_job" "airflow.providers.google.cloud.operators.vertex_ai.dataset" "airflow.providers.google.cloud.operators.vertex_ai.endpoint_service" "airflow.providers.google.cloud.operators.vertex_ai.hyperparameter_tuning_job" "airflow.providers.google.cloud.operators.vertex_ai.model_service" "airflow.providers.google.cloud.operators.video_intelligence" "airflow.providers.google.cloud.operators.vision" "airflow.providers.google.cloud.operators.workflows" "airflow.providers.google.common.hooks.base_google" "airflow.providers.google.common.hooks.discovery_api" "airflow.providers.google.firebase.hooks.firestore" "airflow.providers.google.firebase.operators.firestore" "airflow.providers.google.leveldb.hooks.leveldb" "airflow.providers.google.leveldb.operators.leveldb" "airflow.providers.google.marketing_platform.hooks.analytics" "airflow.providers.google.marketing_platform.hooks.campaign_manager" "airflow.providers.google.marketing_platform.hooks.display_video" "airflow.providers.google.marketing_platform.hooks.search_ads" "airflow.providers.google.marketing_platform.operators.analytics" "airflow.providers.google.marketing_platform.operators.campaign_manager" "airflow.providers.google.marketing_platform.operators.display_video" "airflow.providers.google.marketing_platform.operators.search_ads" "airflow.providers.google.suite.hooks.calendar" "airflow.providers.google.suite.hooks.drive" "airflow.providers.google.suite.hooks.sheets" "airflow.providers.google.suite.operators.sheets" ]; + deps = [ + "adal" + "apache-beam" + "asgiref" + "azure-batch" + "azure-cosmos" + "azure-datalake-store" + "azure-identity" + "azure-keyvault-secrets" + "azure-mgmt-containerinstance" + "azure-mgmt-datafactory" + "azure-mgmt-datalake-store" + "azure-mgmt-resource" + "azure-servicebus" + "azure-storage-blob" + "azure-storage-common" + "azure-storage-file" + "azure-synapse-spark" + "boto3" + "cassandra-driver" + "cryptography" + "dnspython" + "google-api-core" + "google-api-python-client" + "google-auth" + "google-auth-httplib2" + "google-cloud-automl" + "google-cloud-bigquery-datatransfer" + "google-cloud-bigtable" + "google-cloud-compute" + "google-cloud-container" + "google-cloud-datacatalog" + "google-cloud-dataproc" + "google-cloud-dlp" + "google-cloud-kms" + "google-cloud-language" + "google-cloud-logging" + "google-cloud-monitoring" + "google-cloud-pubsub" + "google-cloud-redis" + "google-cloud-secret-manager" + "google-cloud-spanner" + "google-cloud-speech" + "google-cloud-storage" + "google-cloud-tasks" + "google-cloud-texttospeech" + "google-cloud-translate" + "google-cloud-videointelligence" + "google-cloud-vision" + "grpcio-gcp" + "httpx" + "json-merge-patch" + "jsonpath-ng" + "kubernetes" + "mypy-boto3-appflow" + "mypy-boto3-rds" + "mypy-boto3-redshift-data" + "mysqlclient" + "oracledb" + "pandas" + "paramiko" + "proto-plus" + "protobuf" + "psycopg2" + "pymongo" + "pyopenssl" + "pysftp" + "redshift-connector" + "simple-salesforce" + "smbprotocol" + "sshtunnel" + "thrift" + "vertica-python" + ]; + imports = [ + "airflow.providers.google.ads.hooks.ads" + "airflow.providers.google.ads.operators.ads" + "airflow.providers.google.cloud.hooks.automl" + "airflow.providers.google.cloud.hooks.bigquery" + "airflow.providers.google.cloud.hooks.bigquery_dts" + "airflow.providers.google.cloud.hooks.bigtable" + "airflow.providers.google.cloud.hooks.cloud_build" + "airflow.providers.google.cloud.hooks.cloud_composer" + "airflow.providers.google.cloud.hooks.cloud_memorystore" + "airflow.providers.google.cloud.hooks.cloud_sql" + "airflow.providers.google.cloud.hooks.cloud_storage_transfer_service" + "airflow.providers.google.cloud.hooks.compute" + "airflow.providers.google.cloud.hooks.compute_ssh" + "airflow.providers.google.cloud.hooks.datacatalog" + "airflow.providers.google.cloud.hooks.dataflow" + "airflow.providers.google.cloud.hooks.dataform" + "airflow.providers.google.cloud.hooks.datafusion" + "airflow.providers.google.cloud.hooks.dataplex" + "airflow.providers.google.cloud.hooks.dataprep" + "airflow.providers.google.cloud.hooks.dataproc" + "airflow.providers.google.cloud.hooks.dataproc_metastore" + "airflow.providers.google.cloud.hooks.datastore" + "airflow.providers.google.cloud.hooks.dlp" + "airflow.providers.google.cloud.hooks.functions" + "airflow.providers.google.cloud.hooks.gcs" + "airflow.providers.google.cloud.hooks.gdm" + "airflow.providers.google.cloud.hooks.kms" + "airflow.providers.google.cloud.hooks.kubernetes_engine" + "airflow.providers.google.cloud.hooks.life_sciences" + "airflow.providers.google.cloud.hooks.looker" + "airflow.providers.google.cloud.hooks.mlengine" + "airflow.providers.google.cloud.hooks.natural_language" + "airflow.providers.google.cloud.hooks.os_login" + "airflow.providers.google.cloud.hooks.pubsub" + "airflow.providers.google.cloud.hooks.secret_manager" + "airflow.providers.google.cloud.hooks.spanner" + "airflow.providers.google.cloud.hooks.speech_to_text" + "airflow.providers.google.cloud.hooks.stackdriver" + "airflow.providers.google.cloud.hooks.tasks" + "airflow.providers.google.cloud.hooks.text_to_speech" + "airflow.providers.google.cloud.hooks.translate" + "airflow.providers.google.cloud.hooks.vertex_ai.auto_ml" + "airflow.providers.google.cloud.hooks.vertex_ai.batch_prediction_job" + "airflow.providers.google.cloud.hooks.vertex_ai.custom_job" + "airflow.providers.google.cloud.hooks.vertex_ai.dataset" + "airflow.providers.google.cloud.hooks.vertex_ai.endpoint_service" + "airflow.providers.google.cloud.hooks.vertex_ai.hyperparameter_tuning_job" + "airflow.providers.google.cloud.hooks.vertex_ai.model_service" + "airflow.providers.google.cloud.hooks.video_intelligence" + "airflow.providers.google.cloud.hooks.vision" + "airflow.providers.google.cloud.hooks.workflows" + "airflow.providers.google.cloud.operators.automl" + "airflow.providers.google.cloud.operators.bigquery" + "airflow.providers.google.cloud.operators.bigquery_dts" + "airflow.providers.google.cloud.operators.bigtable" + "airflow.providers.google.cloud.operators.cloud_build" + "airflow.providers.google.cloud.operators.cloud_composer" + "airflow.providers.google.cloud.operators.cloud_memorystore" + "airflow.providers.google.cloud.operators.cloud_sql" + "airflow.providers.google.cloud.operators.cloud_storage_transfer_service" + "airflow.providers.google.cloud.operators.compute" + "airflow.providers.google.cloud.operators.datacatalog" + "airflow.providers.google.cloud.operators.dataflow" + "airflow.providers.google.cloud.operators.dataform" + "airflow.providers.google.cloud.operators.datafusion" + "airflow.providers.google.cloud.operators.dataplex" + "airflow.providers.google.cloud.operators.dataprep" + "airflow.providers.google.cloud.operators.dataproc" + "airflow.providers.google.cloud.operators.dataproc_metastore" + "airflow.providers.google.cloud.operators.datastore" + "airflow.providers.google.cloud.operators.dlp" + "airflow.providers.google.cloud.operators.functions" + "airflow.providers.google.cloud.operators.gcs" + "airflow.providers.google.cloud.operators.kubernetes_engine" + "airflow.providers.google.cloud.operators.life_sciences" + "airflow.providers.google.cloud.operators.looker" + "airflow.providers.google.cloud.operators.mlengine" + "airflow.providers.google.cloud.operators.natural_language" + "airflow.providers.google.cloud.operators.pubsub" + "airflow.providers.google.cloud.operators.spanner" + "airflow.providers.google.cloud.operators.speech_to_text" + "airflow.providers.google.cloud.operators.stackdriver" + "airflow.providers.google.cloud.operators.tasks" + "airflow.providers.google.cloud.operators.text_to_speech" + "airflow.providers.google.cloud.operators.translate" + "airflow.providers.google.cloud.operators.translate_speech" + "airflow.providers.google.cloud.operators.translate_speech" + "airflow.providers.google.cloud.operators.vertex_ai.auto_ml" + "airflow.providers.google.cloud.operators.vertex_ai.batch_prediction_job" + "airflow.providers.google.cloud.operators.vertex_ai.custom_job" + "airflow.providers.google.cloud.operators.vertex_ai.dataset" + "airflow.providers.google.cloud.operators.vertex_ai.endpoint_service" + "airflow.providers.google.cloud.operators.vertex_ai.hyperparameter_tuning_job" + "airflow.providers.google.cloud.operators.vertex_ai.model_service" + "airflow.providers.google.cloud.operators.video_intelligence" + "airflow.providers.google.cloud.operators.vision" + "airflow.providers.google.cloud.operators.workflows" + "airflow.providers.google.common.hooks.base_google" + "airflow.providers.google.common.hooks.discovery_api" + "airflow.providers.google.firebase.hooks.firestore" + "airflow.providers.google.firebase.operators.firestore" + "airflow.providers.google.leveldb.hooks.leveldb" + "airflow.providers.google.leveldb.operators.leveldb" + "airflow.providers.google.marketing_platform.hooks.analytics" + "airflow.providers.google.marketing_platform.hooks.campaign_manager" + "airflow.providers.google.marketing_platform.hooks.display_video" + "airflow.providers.google.marketing_platform.hooks.search_ads" + "airflow.providers.google.marketing_platform.operators.analytics" + "airflow.providers.google.marketing_platform.operators.campaign_manager" + "airflow.providers.google.marketing_platform.operators.display_video" + "airflow.providers.google.marketing_platform.operators.search_ads" + "airflow.providers.google.suite.hooks.calendar" + "airflow.providers.google.suite.hooks.drive" + "airflow.providers.google.suite.hooks.sheets" + "airflow.providers.google.suite.operators.sheets" + ]; }; grpc = { - deps = [ "google-auth" "google-auth-httplib2" "grpcio" ]; - imports = [ "airflow.providers.grpc.hooks.grpc" "airflow.providers.grpc.operators.grpc" ]; + deps = [ + "google-auth" + "google-auth-httplib2" + "grpcio" + ]; + imports = [ + "airflow.providers.grpc.hooks.grpc" + "airflow.providers.grpc.operators.grpc" + ]; }; hashicorp = { - deps = [ "adal" "apache-beam" "asgiref" "azure-batch" "azure-cosmos" "azure-datalake-store" "azure-identity" "azure-keyvault-secrets" "azure-mgmt-containerinstance" "azure-mgmt-datafactory" "azure-mgmt-datalake-store" "azure-mgmt-resource" "azure-servicebus" "azure-storage-blob" "azure-storage-common" "azure-storage-file" "azure-synapse-spark" "boto3" "cassandra-driver" "cryptography" "dnspython" "google-api-core" "google-api-python-client" "google-auth" "google-auth-httplib2" "google-cloud-automl" "google-cloud-bigquery-datatransfer" "google-cloud-bigtable" "google-cloud-compute" "google-cloud-container" "google-cloud-datacatalog" "google-cloud-dataproc" "google-cloud-dlp" "google-cloud-kms" "google-cloud-language" "google-cloud-logging" "google-cloud-monitoring" "google-cloud-pubsub" "google-cloud-redis" "google-cloud-secret-manager" "google-cloud-spanner" "google-cloud-speech" "google-cloud-storage" "google-cloud-tasks" "google-cloud-texttospeech" "google-cloud-translate" "google-cloud-videointelligence" "google-cloud-vision" "grpcio-gcp" "httpx" "hvac" "json-merge-patch" "jsonpath-ng" "kubernetes" "mypy-boto3-appflow" "mypy-boto3-rds" "mypy-boto3-redshift-data" "mysqlclient" "oracledb" "pandas" "paramiko" "proto-plus" "protobuf" "psycopg2" "pymongo" "pyopenssl" "pysftp" "redshift-connector" "simple-salesforce" "smbprotocol" "sshtunnel" "thrift" "vertica-python" ]; + deps = [ + "adal" + "apache-beam" + "asgiref" + "azure-batch" + "azure-cosmos" + "azure-datalake-store" + "azure-identity" + "azure-keyvault-secrets" + "azure-mgmt-containerinstance" + "azure-mgmt-datafactory" + "azure-mgmt-datalake-store" + "azure-mgmt-resource" + "azure-servicebus" + "azure-storage-blob" + "azure-storage-common" + "azure-storage-file" + "azure-synapse-spark" + "boto3" + "cassandra-driver" + "cryptography" + "dnspython" + "google-api-core" + "google-api-python-client" + "google-auth" + "google-auth-httplib2" + "google-cloud-automl" + "google-cloud-bigquery-datatransfer" + "google-cloud-bigtable" + "google-cloud-compute" + "google-cloud-container" + "google-cloud-datacatalog" + "google-cloud-dataproc" + "google-cloud-dlp" + "google-cloud-kms" + "google-cloud-language" + "google-cloud-logging" + "google-cloud-monitoring" + "google-cloud-pubsub" + "google-cloud-redis" + "google-cloud-secret-manager" + "google-cloud-spanner" + "google-cloud-speech" + "google-cloud-storage" + "google-cloud-tasks" + "google-cloud-texttospeech" + "google-cloud-translate" + "google-cloud-videointelligence" + "google-cloud-vision" + "grpcio-gcp" + "httpx" + "hvac" + "json-merge-patch" + "jsonpath-ng" + "kubernetes" + "mypy-boto3-appflow" + "mypy-boto3-rds" + "mypy-boto3-redshift-data" + "mysqlclient" + "oracledb" + "pandas" + "paramiko" + "proto-plus" + "protobuf" + "psycopg2" + "pymongo" + "pyopenssl" + "pysftp" + "redshift-connector" + "simple-salesforce" + "smbprotocol" + "sshtunnel" + "thrift" + "vertica-python" + ]; imports = [ "airflow.providers.hashicorp.hooks.vault" ]; }; http = { - deps = [ "requests" "requests-toolbelt" ]; - imports = [ "airflow.providers.http.hooks.http" "airflow.providers.http.operators.http" ]; + deps = [ + "requests" + "requests-toolbelt" + ]; + imports = [ + "airflow.providers.http.hooks.http" + "airflow.providers.http.operators.http" + ]; }; imap = { - deps = [ ]; + deps = [ ]; imports = [ "airflow.providers.imap.hooks.imap" ]; }; influxdb = { - deps = [ "influxdb-client" "requests" ]; - imports = [ "airflow.providers.influxdb.hooks.influxdb" "airflow.providers.influxdb.operators.influxdb" ]; + deps = [ + "influxdb-client" + "requests" + ]; + imports = [ + "airflow.providers.influxdb.hooks.influxdb" + "airflow.providers.influxdb.operators.influxdb" + ]; }; jdbc = { deps = [ "jaydebeapi" ]; - imports = [ "airflow.providers.jdbc.hooks.jdbc" "airflow.providers.jdbc.operators.jdbc" ]; + imports = [ + "airflow.providers.jdbc.hooks.jdbc" + "airflow.providers.jdbc.operators.jdbc" + ]; }; jenkins = { deps = [ "python-jenkins" ]; - imports = [ "airflow.providers.jenkins.hooks.jenkins" "airflow.providers.jenkins.operators.jenkins_job_trigger" ]; + imports = [ + "airflow.providers.jenkins.hooks.jenkins" + "airflow.providers.jenkins.operators.jenkins_job_trigger" + ]; }; microsoft_azure = { - deps = [ "adal" "apache-beam" "asgiref" "azure-batch" "azure-cosmos" "azure-datalake-store" "azure-identity" "azure-keyvault-secrets" "azure-mgmt-containerinstance" "azure-mgmt-datafactory" "azure-mgmt-datalake-store" "azure-mgmt-resource" "azure-servicebus" "azure-storage-blob" "azure-storage-common" "azure-storage-file" "azure-synapse-spark" "boto3" "cassandra-driver" "cryptography" "dnspython" "google-api-core" "google-api-python-client" "google-auth" "google-auth-httplib2" "google-cloud-automl" "google-cloud-bigquery-datatransfer" "google-cloud-bigtable" "google-cloud-compute" "google-cloud-container" "google-cloud-datacatalog" "google-cloud-dataproc" "google-cloud-dlp" "google-cloud-kms" "google-cloud-language" "google-cloud-logging" "google-cloud-monitoring" "google-cloud-pubsub" "google-cloud-redis" "google-cloud-secret-manager" "google-cloud-spanner" "google-cloud-speech" "google-cloud-storage" "google-cloud-tasks" "google-cloud-texttospeech" "google-cloud-translate" "google-cloud-videointelligence" "google-cloud-vision" "grpcio-gcp" "httpx" "json-merge-patch" "jsonpath-ng" "kubernetes" "mypy-boto3-appflow" "mypy-boto3-rds" "mypy-boto3-redshift-data" "mysqlclient" "oracledb" "pandas" "paramiko" "proto-plus" "protobuf" "psycopg2" "pymongo" "pyopenssl" "pysftp" "redshift-connector" "simple-salesforce" "smbprotocol" "sshtunnel" "thrift" "vertica-python" ]; - imports = [ "airflow.providers.microsoft.azure.hooks.adx" "airflow.providers.microsoft.azure.hooks.asb" "airflow.providers.microsoft.azure.hooks.base_azure" "airflow.providers.microsoft.azure.hooks.batch" "airflow.providers.microsoft.azure.hooks.container_instance" "airflow.providers.microsoft.azure.hooks.container_registry" "airflow.providers.microsoft.azure.hooks.container_volume" "airflow.providers.microsoft.azure.hooks.cosmos" "airflow.providers.microsoft.azure.hooks.data_factory" "airflow.providers.microsoft.azure.hooks.data_lake" "airflow.providers.microsoft.azure.hooks.fileshare" "airflow.providers.microsoft.azure.hooks.synapse" "airflow.providers.microsoft.azure.hooks.wasb" "airflow.providers.microsoft.azure.operators.adls" "airflow.providers.microsoft.azure.operators.adx" "airflow.providers.microsoft.azure.operators.asb" "airflow.providers.microsoft.azure.operators.batch" "airflow.providers.microsoft.azure.operators.container_instances" "airflow.providers.microsoft.azure.operators.cosmos" "airflow.providers.microsoft.azure.operators.data_factory" "airflow.providers.microsoft.azure.operators.synapse" "airflow.providers.microsoft.azure.operators.wasb_delete_blob" ]; + deps = [ + "adal" + "apache-beam" + "asgiref" + "azure-batch" + "azure-cosmos" + "azure-datalake-store" + "azure-identity" + "azure-keyvault-secrets" + "azure-mgmt-containerinstance" + "azure-mgmt-datafactory" + "azure-mgmt-datalake-store" + "azure-mgmt-resource" + "azure-servicebus" + "azure-storage-blob" + "azure-storage-common" + "azure-storage-file" + "azure-synapse-spark" + "boto3" + "cassandra-driver" + "cryptography" + "dnspython" + "google-api-core" + "google-api-python-client" + "google-auth" + "google-auth-httplib2" + "google-cloud-automl" + "google-cloud-bigquery-datatransfer" + "google-cloud-bigtable" + "google-cloud-compute" + "google-cloud-container" + "google-cloud-datacatalog" + "google-cloud-dataproc" + "google-cloud-dlp" + "google-cloud-kms" + "google-cloud-language" + "google-cloud-logging" + "google-cloud-monitoring" + "google-cloud-pubsub" + "google-cloud-redis" + "google-cloud-secret-manager" + "google-cloud-spanner" + "google-cloud-speech" + "google-cloud-storage" + "google-cloud-tasks" + "google-cloud-texttospeech" + "google-cloud-translate" + "google-cloud-videointelligence" + "google-cloud-vision" + "grpcio-gcp" + "httpx" + "json-merge-patch" + "jsonpath-ng" + "kubernetes" + "mypy-boto3-appflow" + "mypy-boto3-rds" + "mypy-boto3-redshift-data" + "mysqlclient" + "oracledb" + "pandas" + "paramiko" + "proto-plus" + "protobuf" + "psycopg2" + "pymongo" + "pyopenssl" + "pysftp" + "redshift-connector" + "simple-salesforce" + "smbprotocol" + "sshtunnel" + "thrift" + "vertica-python" + ]; + imports = [ + "airflow.providers.microsoft.azure.hooks.adx" + "airflow.providers.microsoft.azure.hooks.asb" + "airflow.providers.microsoft.azure.hooks.base_azure" + "airflow.providers.microsoft.azure.hooks.batch" + "airflow.providers.microsoft.azure.hooks.container_instance" + "airflow.providers.microsoft.azure.hooks.container_registry" + "airflow.providers.microsoft.azure.hooks.container_volume" + "airflow.providers.microsoft.azure.hooks.cosmos" + "airflow.providers.microsoft.azure.hooks.data_factory" + "airflow.providers.microsoft.azure.hooks.data_lake" + "airflow.providers.microsoft.azure.hooks.fileshare" + "airflow.providers.microsoft.azure.hooks.synapse" + "airflow.providers.microsoft.azure.hooks.wasb" + "airflow.providers.microsoft.azure.operators.adls" + "airflow.providers.microsoft.azure.operators.adx" + "airflow.providers.microsoft.azure.operators.asb" + "airflow.providers.microsoft.azure.operators.batch" + "airflow.providers.microsoft.azure.operators.container_instances" + "airflow.providers.microsoft.azure.operators.cosmos" + "airflow.providers.microsoft.azure.operators.data_factory" + "airflow.providers.microsoft.azure.operators.synapse" + "airflow.providers.microsoft.azure.operators.wasb_delete_blob" + ]; }; microsoft_mssql = { - deps = [ ]; - imports = [ "airflow.providers.microsoft.mssql.hooks.mssql" "airflow.providers.microsoft.mssql.operators.mssql" ]; + deps = [ ]; + imports = [ + "airflow.providers.microsoft.mssql.hooks.mssql" + "airflow.providers.microsoft.mssql.operators.mssql" + ]; }; microsoft_psrp = { deps = [ "pypsrp" ]; - imports = [ "airflow.providers.microsoft.psrp.hooks.psrp" "airflow.providers.microsoft.psrp.operators.psrp" ]; + imports = [ + "airflow.providers.microsoft.psrp.hooks.psrp" + "airflow.providers.microsoft.psrp.operators.psrp" + ]; }; microsoft_winrm = { deps = [ "pywinrm" ]; - imports = [ "airflow.providers.microsoft.winrm.hooks.winrm" "airflow.providers.microsoft.winrm.operators.winrm" ]; + imports = [ + "airflow.providers.microsoft.winrm.hooks.winrm" + "airflow.providers.microsoft.winrm.operators.winrm" + ]; }; mongo = { - deps = [ "dnspython" "pymongo" ]; + deps = [ + "dnspython" + "pymongo" + ]; imports = [ "airflow.providers.mongo.hooks.mongo" ]; }; mysql = { - deps = [ "adal" "apache-beam" "asgiref" "azure-batch" "azure-cosmos" "azure-datalake-store" "azure-identity" "azure-keyvault-secrets" "azure-mgmt-containerinstance" "azure-mgmt-datafactory" "azure-mgmt-datalake-store" "azure-mgmt-resource" "azure-servicebus" "azure-storage-blob" "azure-storage-common" "azure-storage-file" "azure-synapse-spark" "boto3" "cassandra-driver" "cryptography" "dnspython" "google-api-core" "google-api-python-client" "google-auth" "google-auth-httplib2" "google-cloud-automl" "google-cloud-bigquery-datatransfer" "google-cloud-bigtable" "google-cloud-compute" "google-cloud-container" "google-cloud-datacatalog" "google-cloud-dataproc" "google-cloud-dlp" "google-cloud-kms" "google-cloud-language" "google-cloud-logging" "google-cloud-monitoring" "google-cloud-pubsub" "google-cloud-redis" "google-cloud-secret-manager" "google-cloud-spanner" "google-cloud-speech" "google-cloud-storage" "google-cloud-tasks" "google-cloud-texttospeech" "google-cloud-translate" "google-cloud-videointelligence" "google-cloud-vision" "grpcio-gcp" "httpx" "json-merge-patch" "jsonpath-ng" "kubernetes" "mypy-boto3-appflow" "mypy-boto3-rds" "mypy-boto3-redshift-data" "mysqlclient" "oracledb" "pandas" "paramiko" "proto-plus" "protobuf" "psycopg2" "pymongo" "pyopenssl" "pysftp" "redshift-connector" "simple-salesforce" "smbprotocol" "sshtunnel" "thrift" "vertica-python" ]; - imports = [ "airflow.providers.mysql.hooks.mysql" "airflow.providers.mysql.operators.mysql" ]; + deps = [ + "adal" + "apache-beam" + "asgiref" + "azure-batch" + "azure-cosmos" + "azure-datalake-store" + "azure-identity" + "azure-keyvault-secrets" + "azure-mgmt-containerinstance" + "azure-mgmt-datafactory" + "azure-mgmt-datalake-store" + "azure-mgmt-resource" + "azure-servicebus" + "azure-storage-blob" + "azure-storage-common" + "azure-storage-file" + "azure-synapse-spark" + "boto3" + "cassandra-driver" + "cryptography" + "dnspython" + "google-api-core" + "google-api-python-client" + "google-auth" + "google-auth-httplib2" + "google-cloud-automl" + "google-cloud-bigquery-datatransfer" + "google-cloud-bigtable" + "google-cloud-compute" + "google-cloud-container" + "google-cloud-datacatalog" + "google-cloud-dataproc" + "google-cloud-dlp" + "google-cloud-kms" + "google-cloud-language" + "google-cloud-logging" + "google-cloud-monitoring" + "google-cloud-pubsub" + "google-cloud-redis" + "google-cloud-secret-manager" + "google-cloud-spanner" + "google-cloud-speech" + "google-cloud-storage" + "google-cloud-tasks" + "google-cloud-texttospeech" + "google-cloud-translate" + "google-cloud-videointelligence" + "google-cloud-vision" + "grpcio-gcp" + "httpx" + "json-merge-patch" + "jsonpath-ng" + "kubernetes" + "mypy-boto3-appflow" + "mypy-boto3-rds" + "mypy-boto3-redshift-data" + "mysqlclient" + "oracledb" + "pandas" + "paramiko" + "proto-plus" + "protobuf" + "psycopg2" + "pymongo" + "pyopenssl" + "pysftp" + "redshift-connector" + "simple-salesforce" + "smbprotocol" + "sshtunnel" + "thrift" + "vertica-python" + ]; + imports = [ + "airflow.providers.mysql.hooks.mysql" + "airflow.providers.mysql.operators.mysql" + ]; }; neo4j = { deps = [ "neo4j" ]; - imports = [ "airflow.providers.neo4j.hooks.neo4j" "airflow.providers.neo4j.operators.neo4j" ]; + imports = [ + "airflow.providers.neo4j.hooks.neo4j" + "airflow.providers.neo4j.operators.neo4j" + ]; }; odbc = { deps = [ "pyodbc" ]; imports = [ "airflow.providers.odbc.hooks.odbc" ]; }; openfaas = { - deps = [ ]; + deps = [ ]; imports = [ "airflow.providers.openfaas.hooks.openfaas" ]; }; opsgenie = { - deps = [ ]; - imports = [ "airflow.providers.opsgenie.hooks.opsgenie" "airflow.providers.opsgenie.operators.opsgenie" ]; + deps = [ ]; + imports = [ + "airflow.providers.opsgenie.hooks.opsgenie" + "airflow.providers.opsgenie.operators.opsgenie" + ]; }; oracle = { deps = [ "oracledb" ]; - imports = [ "airflow.providers.oracle.hooks.oracle" "airflow.providers.oracle.operators.oracle" ]; + imports = [ + "airflow.providers.oracle.hooks.oracle" + "airflow.providers.oracle.operators.oracle" + ]; }; pagerduty = { - deps = [ ]; - imports = [ "airflow.providers.pagerduty.hooks.pagerduty" "airflow.providers.pagerduty.hooks.pagerduty_events" ]; + deps = [ ]; + imports = [ + "airflow.providers.pagerduty.hooks.pagerduty" + "airflow.providers.pagerduty.hooks.pagerduty_events" + ]; }; papermill = { - deps = [ ]; + deps = [ ]; imports = [ "airflow.providers.papermill.operators.papermill" ]; }; plexus = { deps = [ "arrow" ]; - imports = [ "airflow.providers.plexus.hooks.plexus" "airflow.providers.plexus.operators.job" ]; + imports = [ + "airflow.providers.plexus.hooks.plexus" + "airflow.providers.plexus.operators.job" + ]; }; postgres = { - deps = [ "adal" "apache-beam" "asgiref" "azure-batch" "azure-cosmos" "azure-datalake-store" "azure-identity" "azure-keyvault-secrets" "azure-mgmt-containerinstance" "azure-mgmt-datafactory" "azure-mgmt-datalake-store" "azure-mgmt-resource" "azure-servicebus" "azure-storage-blob" "azure-storage-common" "azure-storage-file" "azure-synapse-spark" "boto3" "cassandra-driver" "cryptography" "dnspython" "google-api-core" "google-api-python-client" "google-auth" "google-auth-httplib2" "google-cloud-automl" "google-cloud-bigquery-datatransfer" "google-cloud-bigtable" "google-cloud-compute" "google-cloud-container" "google-cloud-datacatalog" "google-cloud-dataproc" "google-cloud-dlp" "google-cloud-kms" "google-cloud-language" "google-cloud-logging" "google-cloud-monitoring" "google-cloud-pubsub" "google-cloud-redis" "google-cloud-secret-manager" "google-cloud-spanner" "google-cloud-speech" "google-cloud-storage" "google-cloud-tasks" "google-cloud-texttospeech" "google-cloud-translate" "google-cloud-videointelligence" "google-cloud-vision" "grpcio-gcp" "httpx" "json-merge-patch" "jsonpath-ng" "kubernetes" "mypy-boto3-appflow" "mypy-boto3-rds" "mypy-boto3-redshift-data" "mysqlclient" "oracledb" "pandas" "paramiko" "proto-plus" "protobuf" "psycopg2" "pymongo" "pyopenssl" "pysftp" "redshift-connector" "simple-salesforce" "smbprotocol" "sshtunnel" "thrift" "vertica-python" ]; - imports = [ "airflow.providers.postgres.hooks.postgres" "airflow.providers.postgres.operators.postgres" ]; + deps = [ + "adal" + "apache-beam" + "asgiref" + "azure-batch" + "azure-cosmos" + "azure-datalake-store" + "azure-identity" + "azure-keyvault-secrets" + "azure-mgmt-containerinstance" + "azure-mgmt-datafactory" + "azure-mgmt-datalake-store" + "azure-mgmt-resource" + "azure-servicebus" + "azure-storage-blob" + "azure-storage-common" + "azure-storage-file" + "azure-synapse-spark" + "boto3" + "cassandra-driver" + "cryptography" + "dnspython" + "google-api-core" + "google-api-python-client" + "google-auth" + "google-auth-httplib2" + "google-cloud-automl" + "google-cloud-bigquery-datatransfer" + "google-cloud-bigtable" + "google-cloud-compute" + "google-cloud-container" + "google-cloud-datacatalog" + "google-cloud-dataproc" + "google-cloud-dlp" + "google-cloud-kms" + "google-cloud-language" + "google-cloud-logging" + "google-cloud-monitoring" + "google-cloud-pubsub" + "google-cloud-redis" + "google-cloud-secret-manager" + "google-cloud-spanner" + "google-cloud-speech" + "google-cloud-storage" + "google-cloud-tasks" + "google-cloud-texttospeech" + "google-cloud-translate" + "google-cloud-videointelligence" + "google-cloud-vision" + "grpcio-gcp" + "httpx" + "json-merge-patch" + "jsonpath-ng" + "kubernetes" + "mypy-boto3-appflow" + "mypy-boto3-rds" + "mypy-boto3-redshift-data" + "mysqlclient" + "oracledb" + "pandas" + "paramiko" + "proto-plus" + "protobuf" + "psycopg2" + "pymongo" + "pyopenssl" + "pysftp" + "redshift-connector" + "simple-salesforce" + "smbprotocol" + "sshtunnel" + "thrift" + "vertica-python" + ]; + imports = [ + "airflow.providers.postgres.hooks.postgres" + "airflow.providers.postgres.operators.postgres" + ]; }; presto = { - deps = [ "adal" "apache-beam" "asgiref" "azure-batch" "azure-cosmos" "azure-datalake-store" "azure-identity" "azure-keyvault-secrets" "azure-mgmt-containerinstance" "azure-mgmt-datafactory" "azure-mgmt-datalake-store" "azure-mgmt-resource" "azure-servicebus" "azure-storage-blob" "azure-storage-common" "azure-storage-file" "azure-synapse-spark" "boto3" "cassandra-driver" "cryptography" "dnspython" "google-api-core" "google-api-python-client" "google-auth" "google-auth-httplib2" "google-cloud-automl" "google-cloud-bigquery-datatransfer" "google-cloud-bigtable" "google-cloud-compute" "google-cloud-container" "google-cloud-datacatalog" "google-cloud-dataproc" "google-cloud-dlp" "google-cloud-kms" "google-cloud-language" "google-cloud-logging" "google-cloud-monitoring" "google-cloud-pubsub" "google-cloud-redis" "google-cloud-secret-manager" "google-cloud-spanner" "google-cloud-speech" "google-cloud-storage" "google-cloud-tasks" "google-cloud-texttospeech" "google-cloud-translate" "google-cloud-videointelligence" "google-cloud-vision" "grpcio-gcp" "httpx" "json-merge-patch" "jsonpath-ng" "kubernetes" "mypy-boto3-appflow" "mypy-boto3-rds" "mypy-boto3-redshift-data" "mysqlclient" "oracledb" "pandas" "paramiko" "proto-plus" "protobuf" "psycopg2" "pymongo" "pyopenssl" "pysftp" "redshift-connector" "simple-salesforce" "smbprotocol" "sshtunnel" "thrift" "vertica-python" ]; + deps = [ + "adal" + "apache-beam" + "asgiref" + "azure-batch" + "azure-cosmos" + "azure-datalake-store" + "azure-identity" + "azure-keyvault-secrets" + "azure-mgmt-containerinstance" + "azure-mgmt-datafactory" + "azure-mgmt-datalake-store" + "azure-mgmt-resource" + "azure-servicebus" + "azure-storage-blob" + "azure-storage-common" + "azure-storage-file" + "azure-synapse-spark" + "boto3" + "cassandra-driver" + "cryptography" + "dnspython" + "google-api-core" + "google-api-python-client" + "google-auth" + "google-auth-httplib2" + "google-cloud-automl" + "google-cloud-bigquery-datatransfer" + "google-cloud-bigtable" + "google-cloud-compute" + "google-cloud-container" + "google-cloud-datacatalog" + "google-cloud-dataproc" + "google-cloud-dlp" + "google-cloud-kms" + "google-cloud-language" + "google-cloud-logging" + "google-cloud-monitoring" + "google-cloud-pubsub" + "google-cloud-redis" + "google-cloud-secret-manager" + "google-cloud-spanner" + "google-cloud-speech" + "google-cloud-storage" + "google-cloud-tasks" + "google-cloud-texttospeech" + "google-cloud-translate" + "google-cloud-videointelligence" + "google-cloud-vision" + "grpcio-gcp" + "httpx" + "json-merge-patch" + "jsonpath-ng" + "kubernetes" + "mypy-boto3-appflow" + "mypy-boto3-rds" + "mypy-boto3-redshift-data" + "mysqlclient" + "oracledb" + "pandas" + "paramiko" + "proto-plus" + "protobuf" + "psycopg2" + "pymongo" + "pyopenssl" + "pysftp" + "redshift-connector" + "simple-salesforce" + "smbprotocol" + "sshtunnel" + "thrift" + "vertica-python" + ]; imports = [ "airflow.providers.presto.hooks.presto" ]; }; qubole = { deps = [ "qds-sdk" ]; - imports = [ "airflow.providers.qubole.hooks.qubole" "airflow.providers.qubole.hooks.qubole_check" "airflow.providers.qubole.operators.qubole" "airflow.providers.qubole.operators.qubole_check" ]; + imports = [ + "airflow.providers.qubole.hooks.qubole" + "airflow.providers.qubole.hooks.qubole_check" + "airflow.providers.qubole.operators.qubole" + "airflow.providers.qubole.operators.qubole_check" + ]; }; redis = { deps = [ "redis" ]; - imports = [ "airflow.providers.redis.hooks.redis" "airflow.providers.redis.operators.redis_publish" ]; + imports = [ + "airflow.providers.redis.hooks.redis" + "airflow.providers.redis.operators.redis_publish" + ]; }; salesforce = { - deps = [ "pandas" "simple-salesforce" ]; - imports = [ "airflow.providers.salesforce.hooks.salesforce" "airflow.providers.salesforce.operators.bulk" "airflow.providers.salesforce.operators.salesforce_apex_rest" ]; + deps = [ + "pandas" + "simple-salesforce" + ]; + imports = [ + "airflow.providers.salesforce.hooks.salesforce" + "airflow.providers.salesforce.operators.bulk" + "airflow.providers.salesforce.operators.salesforce_apex_rest" + ]; }; samba = { deps = [ "smbprotocol" ]; imports = [ "airflow.providers.samba.hooks.samba" ]; }; segment = { - deps = [ ]; - imports = [ "airflow.providers.segment.hooks.segment" "airflow.providers.segment.operators.segment_track_event" ]; + deps = [ ]; + imports = [ + "airflow.providers.segment.hooks.segment" + "airflow.providers.segment.operators.segment_track_event" + ]; }; sendgrid = { deps = [ "sendgrid" ]; - imports = [ ]; + imports = [ ]; }; sftp = { - deps = [ "paramiko" "pysftp" "sshtunnel" ]; - imports = [ "airflow.providers.sftp.hooks.sftp" "airflow.providers.sftp.operators.sftp" ]; + deps = [ + "paramiko" + "pysftp" + "sshtunnel" + ]; + imports = [ + "airflow.providers.sftp.hooks.sftp" + "airflow.providers.sftp.operators.sftp" + ]; }; singularity = { - deps = [ ]; + deps = [ ]; imports = [ "airflow.providers.singularity.operators.singularity" ]; }; slack = { deps = [ "slack-sdk" ]; - imports = [ "airflow.providers.slack.hooks.slack" "airflow.providers.slack.hooks.slack_webhook" "airflow.providers.slack.operators.slack" "airflow.providers.slack.operators.slack_webhook" ]; + imports = [ + "airflow.providers.slack.hooks.slack" + "airflow.providers.slack.hooks.slack_webhook" + "airflow.providers.slack.operators.slack" + "airflow.providers.slack.operators.slack_webhook" + ]; }; snowflake = { - deps = [ "slack-sdk" "snowflake-connector-python" "snowflake-sqlalchemy" ]; - imports = [ "airflow.providers.snowflake.hooks.snowflake" "airflow.providers.snowflake.operators.snowflake" ]; + deps = [ + "slack-sdk" + "snowflake-connector-python" + "snowflake-sqlalchemy" + ]; + imports = [ + "airflow.providers.snowflake.hooks.snowflake" + "airflow.providers.snowflake.operators.snowflake" + ]; }; sqlite = { - deps = [ ]; - imports = [ "airflow.providers.sqlite.hooks.sqlite" "airflow.providers.sqlite.operators.sqlite" ]; + deps = [ ]; + imports = [ + "airflow.providers.sqlite.hooks.sqlite" + "airflow.providers.sqlite.operators.sqlite" + ]; }; ssh = { - deps = [ "paramiko" "sshtunnel" ]; - imports = [ "airflow.providers.ssh.hooks.ssh" "airflow.providers.ssh.operators.ssh" ]; + deps = [ + "paramiko" + "sshtunnel" + ]; + imports = [ + "airflow.providers.ssh.hooks.ssh" + "airflow.providers.ssh.operators.ssh" + ]; }; tableau = { deps = [ "tableauserverclient" ]; - imports = [ "airflow.providers.tableau.hooks.tableau" "airflow.providers.tableau.operators.tableau" ]; + imports = [ + "airflow.providers.tableau.hooks.tableau" + "airflow.providers.tableau.operators.tableau" + ]; }; tabular = { - deps = [ ]; + deps = [ ]; imports = [ "airflow.providers.tabular.hooks.tabular" ]; }; telegram = { deps = [ "python-telegram-bot" ]; - imports = [ "airflow.providers.telegram.hooks.telegram" "airflow.providers.telegram.operators.telegram" ]; + imports = [ + "airflow.providers.telegram.hooks.telegram" + "airflow.providers.telegram.operators.telegram" + ]; }; trino = { - deps = [ "adal" "apache-beam" "asgiref" "azure-batch" "azure-cosmos" "azure-datalake-store" "azure-identity" "azure-keyvault-secrets" "azure-mgmt-containerinstance" "azure-mgmt-datafactory" "azure-mgmt-datalake-store" "azure-mgmt-resource" "azure-servicebus" "azure-storage-blob" "azure-storage-common" "azure-storage-file" "azure-synapse-spark" "boto3" "cassandra-driver" "cryptography" "dnspython" "google-api-core" "google-api-python-client" "google-auth" "google-auth-httplib2" "google-cloud-automl" "google-cloud-bigquery-datatransfer" "google-cloud-bigtable" "google-cloud-compute" "google-cloud-container" "google-cloud-datacatalog" "google-cloud-dataproc" "google-cloud-dlp" "google-cloud-kms" "google-cloud-language" "google-cloud-logging" "google-cloud-monitoring" "google-cloud-pubsub" "google-cloud-redis" "google-cloud-secret-manager" "google-cloud-spanner" "google-cloud-speech" "google-cloud-storage" "google-cloud-tasks" "google-cloud-texttospeech" "google-cloud-translate" "google-cloud-videointelligence" "google-cloud-vision" "grpcio-gcp" "httpx" "json-merge-patch" "jsonpath-ng" "kubernetes" "mypy-boto3-appflow" "mypy-boto3-rds" "mypy-boto3-redshift-data" "mysqlclient" "oracledb" "pandas" "paramiko" "proto-plus" "protobuf" "psycopg2" "pymongo" "pyopenssl" "pysftp" "redshift-connector" "simple-salesforce" "smbprotocol" "sshtunnel" "thrift" "vertica-python" ]; - imports = [ "airflow.providers.trino.hooks.trino" "airflow.providers.trino.operators.trino" ]; + deps = [ + "adal" + "apache-beam" + "asgiref" + "azure-batch" + "azure-cosmos" + "azure-datalake-store" + "azure-identity" + "azure-keyvault-secrets" + "azure-mgmt-containerinstance" + "azure-mgmt-datafactory" + "azure-mgmt-datalake-store" + "azure-mgmt-resource" + "azure-servicebus" + "azure-storage-blob" + "azure-storage-common" + "azure-storage-file" + "azure-synapse-spark" + "boto3" + "cassandra-driver" + "cryptography" + "dnspython" + "google-api-core" + "google-api-python-client" + "google-auth" + "google-auth-httplib2" + "google-cloud-automl" + "google-cloud-bigquery-datatransfer" + "google-cloud-bigtable" + "google-cloud-compute" + "google-cloud-container" + "google-cloud-datacatalog" + "google-cloud-dataproc" + "google-cloud-dlp" + "google-cloud-kms" + "google-cloud-language" + "google-cloud-logging" + "google-cloud-monitoring" + "google-cloud-pubsub" + "google-cloud-redis" + "google-cloud-secret-manager" + "google-cloud-spanner" + "google-cloud-speech" + "google-cloud-storage" + "google-cloud-tasks" + "google-cloud-texttospeech" + "google-cloud-translate" + "google-cloud-videointelligence" + "google-cloud-vision" + "grpcio-gcp" + "httpx" + "json-merge-patch" + "jsonpath-ng" + "kubernetes" + "mypy-boto3-appflow" + "mypy-boto3-rds" + "mypy-boto3-redshift-data" + "mysqlclient" + "oracledb" + "pandas" + "paramiko" + "proto-plus" + "protobuf" + "psycopg2" + "pymongo" + "pyopenssl" + "pysftp" + "redshift-connector" + "simple-salesforce" + "smbprotocol" + "sshtunnel" + "thrift" + "vertica-python" + ]; + imports = [ + "airflow.providers.trino.hooks.trino" + "airflow.providers.trino.operators.trino" + ]; }; vertica = { deps = [ "vertica-python" ]; - imports = [ "airflow.providers.vertica.hooks.vertica" "airflow.providers.vertica.operators.vertica" ]; + imports = [ + "airflow.providers.vertica.hooks.vertica" + "airflow.providers.vertica.operators.vertica" + ]; }; yandex = { - deps = [ ]; - imports = [ "airflow.providers.yandex.hooks.yandex" "airflow.providers.yandex.hooks.yandexcloud_dataproc" "airflow.providers.yandex.operators.yandexcloud_dataproc" ]; + deps = [ ]; + imports = [ + "airflow.providers.yandex.hooks.yandex" + "airflow.providers.yandex.hooks.yandexcloud_dataproc" + "airflow.providers.yandex.operators.yandexcloud_dataproc" + ]; }; zendesk = { - deps = [ ]; + deps = [ ]; imports = [ "airflow.providers.zendesk.hooks.zendesk" ]; }; } diff --git a/pkgs/by-name/ap/apache-airflow/python-package.nix b/pkgs/by-name/ap/apache-airflow/python-package.nix index d178a3d1506448..1c8a6c65858082 100644 --- a/pkgs/by-name/ap/apache-airflow/python-package.nix +++ b/pkgs/by-name/ap/apache-airflow/python-package.nix @@ -1,89 +1,90 @@ -{ lib -, stdenv -, python -, buildPythonPackage -, fetchFromGitHub -, alembic -, argcomplete -, asgiref -, attrs -, blinker -, cached-property -, cattrs -, clickclick -, colorlog -, configupdater -, connexion -, cron-descriptor -, croniter -, cryptography -, deprecated -, dill -, flask -, flask-login -, flask-appbuilder -, flask-caching -, flask-session -, flask-wtf -, gitpython -, google-re2 -, graphviz -, gunicorn -, httpx -, iso8601 -, importlib-resources -, importlib-metadata -, inflection -, itsdangerous -, jinja2 -, jsonschema -, lazy-object-proxy -, linkify-it-py -, lockfile -, markdown -, markupsafe -, marshmallow-oneofschema -, mdit-py-plugins -, numpy -, openapi-spec-validator -, opentelemetry-api -, opentelemetry-exporter-otlp -, pandas -, pathspec -, pendulum -, psutil -, pydantic -, pygments -, pyjwt -, python-daemon -, python-dateutil -, python-nvd3 -, python-slugify -, python3-openid -, pythonOlder -, pyyaml -, rich -, rich-argparse -, setproctitle -, sqlalchemy -, sqlalchemy-jsonfield -, swagger-ui-bundle -, tabulate -, tenacity -, termcolor -, typing-extensions -, unicodecsv -, werkzeug -, freezegun -, pytest-asyncio -, pytestCheckHook -, time-machine -, mkYarnPackage -, fetchYarnDeps -, writeScript - -# Extra airflow providers to enable -, enabledProviders ? [] +{ + lib, + stdenv, + python, + buildPythonPackage, + fetchFromGitHub, + alembic, + argcomplete, + asgiref, + attrs, + blinker, + cached-property, + cattrs, + clickclick, + colorlog, + configupdater, + connexion, + cron-descriptor, + croniter, + cryptography, + deprecated, + dill, + flask, + flask-login, + flask-appbuilder, + flask-caching, + flask-session, + flask-wtf, + gitpython, + google-re2, + graphviz, + gunicorn, + httpx, + iso8601, + importlib-resources, + importlib-metadata, + inflection, + itsdangerous, + jinja2, + jsonschema, + lazy-object-proxy, + linkify-it-py, + lockfile, + markdown, + markupsafe, + marshmallow-oneofschema, + mdit-py-plugins, + numpy, + openapi-spec-validator, + opentelemetry-api, + opentelemetry-exporter-otlp, + pandas, + pathspec, + pendulum, + psutil, + pydantic, + pygments, + pyjwt, + python-daemon, + python-dateutil, + python-nvd3, + python-slugify, + python3-openid, + pythonOlder, + pyyaml, + rich, + rich-argparse, + setproctitle, + sqlalchemy, + sqlalchemy-jsonfield, + swagger-ui-bundle, + tabulate, + tenacity, + termcolor, + typing-extensions, + unicodecsv, + werkzeug, + freezegun, + pytest-asyncio, + pytestCheckHook, + time-machine, + mkYarnPackage, + fetchYarnDeps, + writeScript, + + # Extra airflow providers to enable + enabledProviders ? [ ], }: let version = "2.7.3"; @@ -150,79 +151,82 @@ buildPythonPackage rec { disabled = pythonOlder "3.7"; - propagatedBuildInputs = [ - alembic - argcomplete - asgiref - attrs - blinker - cached-property - cattrs - clickclick - colorlog - configupdater - connexion - cron-descriptor - croniter - cryptography - deprecated - dill - flask - flask-appbuilder - flask-caching - flask-session - flask-wtf - flask-login - gitpython - google-re2 - graphviz - gunicorn - httpx - iso8601 - importlib-resources - inflection - itsdangerous - jinja2 - jsonschema - lazy-object-proxy - linkify-it-py - lockfile - markdown - markupsafe - marshmallow-oneofschema - mdit-py-plugins - numpy - openapi-spec-validator - opentelemetry-api - opentelemetry-exporter-otlp - pandas - pathspec - pendulum - psutil - pydantic - pygments - pyjwt - python-daemon - python-dateutil - python-nvd3 - python-slugify - python3-openid - pyyaml - rich - rich-argparse - setproctitle - sqlalchemy - sqlalchemy-jsonfield - swagger-ui-bundle - tabulate - tenacity - termcolor - typing-extensions - unicodecsv - werkzeug - ] ++ lib.optionals (pythonOlder "3.9") [ - importlib-metadata - ] ++ providerDependencies; + propagatedBuildInputs = + [ + alembic + argcomplete + asgiref + attrs + blinker + cached-property + cattrs + clickclick + colorlog + configupdater + connexion + cron-descriptor + croniter + cryptography + deprecated + dill + flask + flask-appbuilder + flask-caching + flask-session + flask-wtf + flask-login + gitpython + google-re2 + graphviz + gunicorn + httpx + iso8601 + importlib-resources + inflection + itsdangerous + jinja2 + jsonschema + lazy-object-proxy + linkify-it-py + lockfile + markdown + markupsafe + marshmallow-oneofschema + mdit-py-plugins + numpy + openapi-spec-validator + opentelemetry-api + opentelemetry-exporter-otlp + pandas + pathspec + pendulum + psutil + pydantic + pygments + pyjwt + python-daemon + python-dateutil + python-nvd3 + python-slugify + python3-openid + pyyaml + rich + rich-argparse + setproctitle + sqlalchemy + sqlalchemy-jsonfield + swagger-ui-bundle + tabulate + tenacity + termcolor + typing-extensions + unicodecsv + werkzeug + ] + ++ lib.optionals (pythonOlder "3.9") [ + importlib-metadata + ] + ++ providerDependencies; buildInputs = [ airflow-frontend @@ -240,15 +244,17 @@ buildPythonPackage rec { # above INSTALL_PROVIDERS_FROM_SOURCES = "true"; - postPatch = '' - # https://github.com/apache/airflow/issues/33854 - substituteInPlace pyproject.toml \ - --replace '[project]' $'[project]\nname = "apache-airflow"\nversion = "${version}"' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Fix failing test on Hydra - substituteInPlace airflow/utils/db.py \ - --replace "/tmp/sqlite_default.db" "$TMPDIR/sqlite_default.db" - ''; + postPatch = + '' + # https://github.com/apache/airflow/issues/33854 + substituteInPlace pyproject.toml \ + --replace '[project]' $'[project]\nname = "apache-airflow"\nversion = "${version}"' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Fix failing test on Hydra + substituteInPlace airflow/utils/db.py \ + --replace "/tmp/sqlite_default.db" "$TMPDIR/sqlite_default.db" + ''; pythonRelaxDeps = [ "colorlog" @@ -329,7 +335,11 @@ buildPythonPackage rec { description = "Programmatically author, schedule and monitor data pipelines"; homepage = "https://airflow.apache.org/"; license = licenses.asl20; - maintainers = with maintainers; [ bhipple gbpdt ingenieroariel ]; + maintainers = with maintainers; [ + bhipple + gbpdt + ingenieroariel + ]; knownVulnerabilities = [ "CVE-2023-50943" "CVE-2023-50944" diff --git a/pkgs/by-name/ap/apache-directory-server/package.nix b/pkgs/by-name/ap/apache-directory-server/package.nix index 4b7fb4086fba6d..d53e816461eea3 100644 --- a/pkgs/by-name/ap/apache-directory-server/package.nix +++ b/pkgs/by-name/ap/apache-directory-server/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchzip, jdk11, makeWrapper }: +{ + lib, + stdenv, + fetchzip, + jdk11, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "apache-directory-server"; diff --git a/pkgs/by-name/ap/apache-directory-studio/package.nix b/pkgs/by-name/ap/apache-directory-studio/package.nix index 7a051db5363e19..17710a77ebde2f 100644 --- a/pkgs/by-name/ap/apache-directory-studio/package.nix +++ b/pkgs/by-name/ap/apache-directory-studio/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, jdk, makeWrapper, autoPatchelfHook, makeDesktopItem, glib, libsecret, webkitgtk_4_0 }: +{ + lib, + stdenv, + fetchurl, + jdk, + makeWrapper, + autoPatchelfHook, + makeDesktopItem, + glib, + libsecret, + webkitgtk_4_0, +}: stdenv.mkDerivation rec { pname = "apache-directory-studio"; @@ -11,7 +22,8 @@ stdenv.mkDerivation rec { url = "mirror://apache/directory/studio/${versionWithDate}/ApacheDirectoryStudio-${versionWithDate}-linux.gtk.x86_64.tar.gz"; sha256 = "19zdspzv4n3mfgb1g45s3wh0vbvn6a9zjd4xi5x2afmdjkzlwxi4"; } - else throw "Unsupported system: ${stdenv.hostPlatform.system}"; + else + throw "Unsupported system: ${stdenv.hostPlatform.system}"; desktopItem = makeDesktopItem { name = "apache-directory-studio"; @@ -20,11 +32,20 @@ stdenv.mkDerivation rec { comment = "Eclipse-based LDAP browser and directory client"; desktopName = "Apache Directory Studio"; genericName = "Apache Directory Studio"; - categories = [ "Java" "Network" ]; + categories = [ + "Java" + "Network" + ]; }; - buildInputs = [ glib libsecret ]; - nativeBuildInputs = [ makeWrapper autoPatchelfHook ]; + buildInputs = [ + glib + libsecret + ]; + nativeBuildInputs = [ + makeWrapper + autoPatchelfHook + ]; installPhase = '' dest="$out/libexec/ApacheDirectoryStudio" diff --git a/pkgs/by-name/ap/apache-flex-sdk/package.nix b/pkgs/by-name/ap/apache-flex-sdk/package.nix index 527b800551eb84..210efb7ffd44ea 100644 --- a/pkgs/by-name/ap/apache-flex-sdk/package.nix +++ b/pkgs/by-name/ap/apache-flex-sdk/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: let playerglobal_ver = "27.0"; @@ -6,7 +12,8 @@ let url = "https://fpdownload.macromedia.com/get/flashplayer/updaters/27/playerglobal27_0.swc"; sha256 = "0qw2bgls8qsmp80j8vpd4c7s0c8anlrk0ac8z42w89bajcdbwk2f"; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "apache-flex-sdk"; version = "4.16.1"; diff --git a/pkgs/by-name/ap/apache-users/package.nix b/pkgs/by-name/ap/apache-users/package.nix index 8780a13a3f8a36..a60fad578c8701 100644 --- a/pkgs/by-name/ap/apache-users/package.nix +++ b/pkgs/by-name/ap/apache-users/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, perl +{ + lib, + stdenv, + fetchurl, + perl, }: stdenv.mkDerivation (finalAttrs: { @@ -21,7 +22,10 @@ stdenv.mkDerivation (finalAttrs: { ''; buildInputs = [ - (perl.withPackages (p: [ p.ParallelForkManager p.LWP ])) + (perl.withPackages (p: [ + p.ParallelForkManager + p.LWP + ])) ]; installPhase = '' diff --git a/pkgs/by-name/ap/apbs/package.nix b/pkgs/by-name/ap/apbs/package.nix index bb8ba7afeff325..41a05f70f9fc5b 100644 --- a/pkgs/by-name/ap/apbs/package.nix +++ b/pkgs/by-name/ap/apbs/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, blas -, superlu -, suitesparse -, python3 -, libintl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + blas, + superlu, + suitesparse, + python3, + libintl, }: let # this is a fork version of fetk (http://www.fetk.org/) @@ -78,14 +79,16 @@ stdenv.mkDerivation (finalAttrs: { cmake ]; - buildInputs = [ - fetk - suitesparse - blas - python3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libintl - ]; + buildInputs = + [ + fetk + suitesparse + blas + python3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libintl + ]; cmakeFlags = [ "-DPYTHON_VERSION=${python3.version}" diff --git a/pkgs/by-name/ap/apcupsd/package.nix b/pkgs/by-name/ap/apcupsd/package.nix index eeecfa2f0ec488..5d6e8ee1b8c649 100644 --- a/pkgs/by-name/ap/apcupsd/package.nix +++ b/pkgs/by-name/ap/apcupsd/package.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, fetchurl, pkg-config, systemd, util-linux, coreutils, wall, hostname, man -, enableCgiScripts ? true, gd -, nixosTests +{ + lib, + stdenv, + fetchurl, + pkg-config, + systemd, + util-linux, + coreutils, + wall, + hostname, + man, + enableCgiScripts ? true, + gd, + nixosTests, }: assert enableCgiScripts -> gd != null; @@ -14,7 +25,11 @@ stdenv.mkDerivation rec { sha256 = "0rwqiyzlg9p0szf3x6q1ppvrw6f6dbpn2rc5z623fk3bkdalhxyv"; }; - nativeBuildInputs = [ pkg-config man util-linux ]; + nativeBuildInputs = [ + pkg-config + man + util-linux + ]; buildInputs = lib.optional enableCgiScripts gd; prePatch = '' @@ -28,25 +43,27 @@ stdenv.mkDerivation rec { # ./configure ignores --prefix, so we must specify some paths manually # There is no real reason for a bin/sbin split, so just use bin. - configureFlags = [ - "--bindir=${placeholder "out"}/bin" - "--sbindir=${placeholder "out"}/bin" - "--sysconfdir=${placeholder "out"}/etc/apcupsd" - "--mandir=${placeholder "out"}/share/man" - "--with-halpolicydir=${placeholder "out"}/share/halpolicy" - "--localstatedir=/var" - "--with-nologin=/run" - "--with-log-dir=/var/log/apcupsd" - "--with-pwrfail-dir=/run/apcupsd" - "--with-lock-dir=/run/lock" - "--with-pid-dir=/run" - "--enable-usb" - "ac_cv_path_SHUTDOWN=${systemd}/sbin/shutdown" - "ac_cv_path_WALL=${wall}/bin/wall" - ] ++ lib.optionals enableCgiScripts [ - "--enable-cgi" - "--with-cgi-bin=${placeholder "out"}/libexec/cgi-bin" - ]; + configureFlags = + [ + "--bindir=${placeholder "out"}/bin" + "--sbindir=${placeholder "out"}/bin" + "--sysconfdir=${placeholder "out"}/etc/apcupsd" + "--mandir=${placeholder "out"}/share/man" + "--with-halpolicydir=${placeholder "out"}/share/halpolicy" + "--localstatedir=/var" + "--with-nologin=/run" + "--with-log-dir=/var/log/apcupsd" + "--with-pwrfail-dir=/run/apcupsd" + "--with-lock-dir=/run/lock" + "--with-pid-dir=/run" + "--enable-usb" + "ac_cv_path_SHUTDOWN=${systemd}/sbin/shutdown" + "ac_cv_path_WALL=${wall}/bin/wall" + ] + ++ lib.optionals enableCgiScripts [ + "--enable-cgi" + "--with-cgi-bin=${placeholder "out"}/libexec/cgi-bin" + ]; postInstall = '' for file in "$out"/etc/apcupsd/*; do diff --git a/pkgs/by-name/ap/aperture/package.nix b/pkgs/by-name/ap/aperture/package.nix index 043b0311cca89e..7e47e02c12ab5c 100644 --- a/pkgs/by-name/ap/aperture/package.nix +++ b/pkgs/by-name/ap/aperture/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { @@ -23,7 +24,10 @@ buildGoModule rec { homepage = "https://github.com/lightninglabs/aperture"; changelog = "https://github.com/lightninglabs/aperture/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ sputn1ck HannahMR ]; + maintainers = with maintainers; [ + sputn1ck + HannahMR + ]; mainProgram = "aperture"; }; } diff --git a/pkgs/by-name/ap/apfel/package.nix b/pkgs/by-name/ap/apfel/package.nix index da403af44b9bf7..7c8ca609fd2749 100644 --- a/pkgs/by-name/ap/apfel/package.nix +++ b/pkgs/by-name/ap/apfel/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gfortran -, lhapdf -, python3 -, swig -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gfortran, + lhapdf, + python3, + swig, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ap/apfelgrid/package.nix b/pkgs/by-name/ap/apfelgrid/package.nix index 2c6c9702c249da..45b6d88d715b24 100644 --- a/pkgs/by-name/ap/apfelgrid/package.nix +++ b/pkgs/by-name/ap/apfelgrid/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, apfel, applgrid, lhapdf, root5 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + apfel, + applgrid, + lhapdf, + root5, +}: stdenv.mkDerivation rec { pname = "apfelgrid"; @@ -12,16 +21,21 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ apfel applgrid lhapdf root5 ]; + buildInputs = [ + apfel + applgrid + lhapdf + root5 + ]; enableParallelBuilding = true; meta = with lib; { description = "Ultra-fast theory predictions for collider observables"; mainProgram = "apfelgrid-config"; - license = licenses.mit; - homepage = "https://nhartland.github.io/APFELgrid/"; - platforms = platforms.unix; + license = licenses.mit; + homepage = "https://nhartland.github.io/APFELgrid/"; + platforms = platforms.unix; maintainers = with maintainers; [ veprbl ]; }; } diff --git a/pkgs/by-name/ap/apfs-fuse/package.nix b/pkgs/by-name/ap/apfs-fuse/package.nix index 88b2c5d3e6240a..279c6a3e62de8e 100644 --- a/pkgs/by-name/ap/apfs-fuse/package.nix +++ b/pkgs/by-name/ap/apfs-fuse/package.nix @@ -1,13 +1,23 @@ -{ lib, stdenv, fetchFromGitHub, fuse, fuse3, bzip2, zlib, attr, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + fuse, + fuse3, + bzip2, + zlib, + attr, + cmake, +}: stdenv.mkDerivation { pname = "apfs-fuse"; version = "unstable-2023-03-12"; src = fetchFromGitHub { - owner = "sgan81"; - repo = "apfs-fuse"; - rev = "66b86bd525e8cb90f9012543be89b1f092b75cf3"; + owner = "sgan81"; + repo = "apfs-fuse"; + rev = "66b86bd525e8cb90f9012543be89b1f092b75cf3"; hash = "sha256-uYAlqnQp0K880XEWuH1548DUA3ii53+hfsuh/T3Vwzg="; fetchSubmodules = true; }; @@ -34,11 +44,11 @@ stdenv.mkDerivation { ''; meta = with lib; { - homepage = "https://github.com/sgan81/apfs-fuse"; + homepage = "https://github.com/sgan81/apfs-fuse"; description = "FUSE driver for APFS (Apple File System)"; - license = licenses.gpl2Plus; + license = licenses.gpl2Plus; mainProgram = "apfs-fuse"; maintainers = with maintainers; [ ealasu ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ap/apg/package.nix b/pkgs/by-name/ap/apg/package.nix index a283678e0a1619..13b0fd1512acb0 100644 --- a/pkgs/by-name/ap/apg/package.nix +++ b/pkgs/by-name/ap/apg/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, openssl, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "apg"; version = "unstable-2015-01-29"; @@ -17,47 +23,47 @@ stdenv.mkDerivation rec { meta = { description = "Tools for random password generation"; longDescription = '' - APG (Automated Password Generator) is the tool set for random - password generation. + APG (Automated Password Generator) is the tool set for random + password generation. - Standalone version + Standalone version - Generates some random words of required type and prints them - to standard output. + Generates some random words of required type and prints them + to standard output. - Network version + Network version - APG server: When client's request is arrived generates some - random words of predefined type and send them to client over - the network (according to RFC0972). + APG server: When client's request is arrived generates some + random words of predefined type and send them to client over + the network (according to RFC0972). - APG client: Sends the password generation request to the APG - server, wait for generated Passwords arrival and then prints - them to the standard output. + APG client: Sends the password generation request to the APG + server, wait for generated Passwords arrival and then prints + them to the standard output. - Advantages + Advantages - * Built-in ANSI X9.17 RNG (Random Number Generator) (CAST/SHA1) - * Built-in password quality checking system (it has support for - Bloom filter for faster access) - * Two Password Generation Algorithms: - 1. Pronounceable Password Generation Algorithm (according to - NIST FIPS 181) - 2. Random Character Password Generation Algorithm with 35 - configurable modes of operation - * Configurable password length parameters - * Configurable amount of generated passwords - * Ability to initialize RNG with user string - * Support for /dev/random - * Ability to crypt() generated passwords and print them as - additional output - * Special parameters to use APG in script - * Ability to log password generation requests for network version - * Ability to control APG service access using tcpd - * Ability to use password generation service from any type of box - (Mac, WinXX, etc.) that connected to network - * Ability to enforce remote users to use only allowed type of - password generation + * Built-in ANSI X9.17 RNG (Random Number Generator) (CAST/SHA1) + * Built-in password quality checking system (it has support for + Bloom filter for faster access) + * Two Password Generation Algorithms: + 1. Pronounceable Password Generation Algorithm (according to + NIST FIPS 181) + 2. Random Character Password Generation Algorithm with 35 + configurable modes of operation + * Configurable password length parameters + * Configurable amount of generated passwords + * Ability to initialize RNG with user string + * Support for /dev/random + * Ability to crypt() generated passwords and print them as + additional output + * Special parameters to use APG in script + * Ability to log password generation requests for network version + * Ability to control APG service access using tcpd + * Ability to use password generation service from any type of box + (Mac, WinXX, etc.) that connected to network + * Ability to enforce remote users to use only allowed type of + password generation ''; homepage = "https://github.com/wilx/apg"; license = lib.licenses.bsd3; diff --git a/pkgs/by-name/ap/apgdiff/package.nix b/pkgs/by-name/ap/apgdiff/package.nix index 8ce720efd68194..0e09c9bb92bde9 100644 --- a/pkgs/by-name/ap/apgdiff/package.nix +++ b/pkgs/by-name/ap/apgdiff/package.nix @@ -1,8 +1,9 @@ -{ lib -, maven -, fetchFromGitHub -, jre -, makeWrapper +{ + lib, + maven, + fetchFromGitHub, + jre, + makeWrapper, }: maven.buildMavenPackage rec { pname = "apgdiff"; diff --git a/pkgs/by-name/ap/aphorme/package.nix b/pkgs/by-name/ap/aphorme/package.nix index 37b06b0f0d640b..2a379da52aafed 100644 --- a/pkgs/by-name/ap/aphorme/package.nix +++ b/pkgs/by-name/ap/aphorme/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, wayland -, libxkbcommon -, libGL -, stdenv -, testers -, aphorme -, autoPatchelfHook +{ + lib, + fetchFromGitHub, + rustPlatform, + wayland, + libxkbcommon, + libGL, + stdenv, + testers, + aphorme, + autoPatchelfHook, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ap/api-linter/package.nix b/pkgs/by-name/ap/api-linter/package.nix index 45fd194c340c71..16847eb016d4ec 100644 --- a/pkgs/by-name/ap/api-linter/package.nix +++ b/pkgs/by-name/ap/api-linter/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ap/apkg/package.nix b/pkgs/by-name/ap/apkg/package.nix index aaf4d47f4c62d9..be42b1ac9d1ded 100644 --- a/pkgs/by-name/ap/apkg/package.nix +++ b/pkgs/by-name/ap/apkg/package.nix @@ -1,5 +1,11 @@ -{ lib, fetchFromGitLab, python3Packages -, gitMinimal, rpm, dpkg, fakeroot +{ + lib, + fetchFromGitLab, + python3Packages, + gitMinimal, + rpm, + dpkg, + fakeroot, }: python3Packages.buildPythonApplication rec { @@ -17,25 +23,37 @@ python3Packages.buildPythonApplication rec { propagatedBuildInputs = with python3Packages; [ # copy&pasted requirements.txt (almost exactly) - beautifulsoup4 # upstream version detection - blessed # terminal colors - build # apkg distribution - cached-property # for python <= 3.7; but pip complains even with 3.8 - click # nice CLI framework - distro # current distro detection - jinja2 # templating - packaging # version parsing - requests # HTTP for humans™ - toml # config files + beautifulsoup4 # upstream version detection + blessed # terminal colors + build # apkg distribution + cached-property # for python <= 3.7; but pip complains even with 3.8 + click # nice CLI framework + distro # current distro detection + jinja2 # templating + packaging # version parsing + requests # HTTP for humans™ + toml # config files ]; nativeBuildInputs = with python3Packages; [ hatchling ]; - makeWrapperArgs = [ # deps for `srcpkg` operation for other distros; could be optional - "--prefix" "PATH" ":" (lib.makeBinPath [ gitMinimal rpm dpkg fakeroot ]) + makeWrapperArgs = [ + # deps for `srcpkg` operation for other distros; could be optional + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ + gitMinimal + rpm + dpkg + fakeroot + ]) ]; - nativeCheckInputs = with python3Packages; [ pytest dunamai ]; + nativeCheckInputs = with python3Packages; [ + pytest + dunamai + ]; checkPhase = '' runHook preCheck py.test # inspiration: .gitlab-ci.yml @@ -46,7 +64,9 @@ python3Packages.buildPythonApplication rec { description = "Upstream packaging automation tool"; homepage = "https://pkg.labs.nic.cz/pages/apkg"; license = licenses.gpl3Plus; - maintainers = [ maintainers.vcunat /* close to upstream */ ]; + maintainers = [ + maintainers.vcunat # close to upstream + ]; mainProgram = "apkg"; }; } diff --git a/pkgs/by-name/ap/apkid/package.nix b/pkgs/by-name/ap/apkid/package.nix index d54a6564908a05..b77a81bc56eaa2 100644 --- a/pkgs/by-name/ap/apkid/package.nix +++ b/pkgs/by-name/ap/apkid/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ap/apksigcopier/package.nix b/pkgs/by-name/ap/apksigcopier/package.nix index 1262c9eaaa75f1..a63b6b7145ab60 100644 --- a/pkgs/by-name/ap/apksigcopier/package.nix +++ b/pkgs/by-name/ap/apksigcopier/package.nix @@ -1,10 +1,11 @@ -{ lib -, apksigner -, bash -, fetchFromGitHub -, installShellFiles -, pandoc -, python3 +{ + lib, + apksigner, + bash, + fetchFromGitHub, + installShellFiles, + pandoc, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ap/apksigner/package.nix b/pkgs/by-name/ap/apksigner/package.nix index f606b43386cadc..108d15a89e9911 100644 --- a/pkgs/by-name/ap/apksigner/package.nix +++ b/pkgs/by-name/ap/apksigner/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchgit -, jdk_headless -, gradle_8 -, makeWrapper +{ + lib, + stdenv, + fetchgit, + jdk_headless, + gradle_8, + makeWrapper, }: let # "Deprecated Gradle features were used in this build, making it incompatible with Gradle 9.0." @@ -50,7 +51,10 @@ stdenv.mkDerivation rec { doCheck = true; - nativeBuildInputs = [ gradle makeWrapper ]; + nativeBuildInputs = [ + gradle + makeWrapper + ]; installPhase = '' install -Dm444 build/libs/apksigner.jar -t $out/lib diff --git a/pkgs/by-name/ap/apktool/package.nix b/pkgs/by-name/ap/apktool/package.nix index 5b2585f6bce718..77973b83683b47 100644 --- a/pkgs/by-name/ap/apktool/package.nix +++ b/pkgs/by-name/ap/apktool/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, jdk_headless -, aapt +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jdk_headless, + aapt, }: stdenv.mkDerivation rec { @@ -24,14 +25,13 @@ stdenv.mkDerivation rec { sourceRoot = "."; - installPhase = - '' - install -D ${src} "$out/libexec/apktool/apktool.jar" - mkdir -p "$out/bin" - makeWrapper "${jdk_headless}/bin/java" "$out/bin/apktool" \ - --add-flags "-jar $out/libexec/apktool/apktool.jar" \ - --prefix PATH : ${lib.getBin aapt} - ''; + installPhase = '' + install -D ${src} "$out/libexec/apktool/apktool.jar" + mkdir -p "$out/bin" + makeWrapper "${jdk_headless}/bin/java" "$out/bin/apktool" \ + --add-flags "-jar $out/libexec/apktool/apktool.jar" \ + --prefix PATH : ${lib.getBin aapt} + ''; meta = with lib; { description = "Tool for reverse engineering Android apk files"; diff --git a/pkgs/by-name/ap/apl386/package.nix b/pkgs/by-name/ap/apl386/package.nix index bfbb00dedeed60..975307a795ba12 100644 --- a/pkgs/by-name/ap/apl386/package.nix +++ b/pkgs/by-name/ap/apl386/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "apl386"; diff --git a/pkgs/by-name/ap/apng2gif/package.nix b/pkgs/by-name/ap/apng2gif/package.nix index 5fc0e4ef1a7305..9c9f4b09a6e592 100644 --- a/pkgs/by-name/ap/apng2gif/package.nix +++ b/pkgs/by-name/ap/apng2gif/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchzip -, libpng +{ + lib, + stdenv, + fetchzip, + libpng, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ap/apngopt/package.nix b/pkgs/by-name/ap/apngopt/package.nix index e0c09773245293..52a178c6ef0a77 100644 --- a/pkgs/by-name/ap/apngopt/package.nix +++ b/pkgs/by-name/ap/apngopt/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchzip -, libpng -, zlib -, zopfli +{ + lib, + stdenv, + fetchzip, + libpng, + zlib, + zopfli, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ap/apparency/package.nix b/pkgs/by-name/ap/apparency/package.nix index 8fd9af7056a5f1..7eacc1aa7da6a7 100644 --- a/pkgs/by-name/ap/apparency/package.nix +++ b/pkgs/by-name/ap/apparency/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchurl -, stdenv -, undmg +{ + lib, + fetchurl, + stdenv, + undmg, }: let @@ -12,8 +13,8 @@ stdenv.mkDerivation { version = "2.0"; src = fetchurl { - # Use externally archived download URL because - # upstream does not provide stable URLs for versioned releases + # Use externally archived download URL because + # upstream does not provide stable URLs for versioned releases url = "https://web.archive.org/web/${snapshot}/https://www.mothersruin.com/software/downloads/Apparency.dmg"; hash = "sha256-XKxWxqfxy9AQneILLrN9XqLt4/k2N8yumZ5mrSvczFk="; }; diff --git a/pkgs/by-name/ap/apparix/package.nix b/pkgs/by-name/ap/apparix/package.nix index dd0c8cf67b0b4e..da89f91f048e64 100644 --- a/pkgs/by-name/ap/apparix/package.nix +++ b/pkgs/by-name/ap/apparix/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "apparix"; diff --git a/pkgs/by-name/ap/appcleaner/package.nix b/pkgs/by-name/ap/appcleaner/package.nix index 62d9e2b1116fa9..8f03b1dc92c26e 100644 --- a/pkgs/by-name/ap/appcleaner/package.nix +++ b/pkgs/by-name/ap/appcleaner/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, unzip +{ + lib, + stdenvNoCC, + fetchurl, + unzip, }: stdenvNoCC.mkDerivation (finalAttrs: { pname = "appcleaner"; diff --git a/pkgs/by-name/ap/appeditor/package.nix b/pkgs/by-name/ap/appeditor/package.nix index 46adf420932d2d..989345f505cbb1 100644 --- a/pkgs/by-name/ap/appeditor/package.nix +++ b/pkgs/by-name/ap/appeditor/package.nix @@ -1,17 +1,19 @@ -{ lib, stdenv -, fetchFromGitHub -, nix-update-script -, vala -, meson -, ninja -, pkg-config -, pantheon -, python3 -, gettext -, glib -, gtk3 -, libgee -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + vala, + meson, + ninja, + pkg-config, + pantheon, + python3, + gettext, + glib, + gtk3, + libgee, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ap/appgate-sdp/package.nix b/pkgs/by-name/ap/appgate-sdp/package.nix index bd0b9283c54ba9..567f7ba9adc46e 100644 --- a/pkgs/by-name/ap/appgate-sdp/package.nix +++ b/pkgs/by-name/ap/appgate-sdp/package.nix @@ -1,42 +1,43 @@ -{ alsa-lib -, at-spi2-atk -, at-spi2-core -, atk -, autoPatchelfHook -, cairo -, cups -, curl -, dbus -, dnsmasq -, dpkg -, expat -, fetchurl -, gdk-pixbuf -, glib -, gtk3 -, icu -, iproute2 -, krb5 -, lib -, libdrm -, libsecret -, libuuid -, libxcb -, libxkbcommon -, lttng-ust -, makeWrapper -, mesa -, networkmanager -, nspr -, nss -, openssl -, pango -, python3 -, stdenv -, systemd -, xdg-utils -, xorg -, zlib +{ + alsa-lib, + at-spi2-atk, + at-spi2-core, + atk, + autoPatchelfHook, + cairo, + cups, + curl, + dbus, + dnsmasq, + dpkg, + expat, + fetchurl, + gdk-pixbuf, + glib, + gtk3, + icu, + iproute2, + krb5, + lib, + libdrm, + libsecret, + libuuid, + libxcb, + libxkbcommon, + lttng-ust, + makeWrapper, + mesa, + networkmanager, + nspr, + nss, + openssl, + pango, + python3, + stdenv, + systemd, + xdg-utils, + xorg, + zlib, }: let @@ -137,7 +138,13 @@ stdenv.mkDerivation rec { --set LD_LIBRARY_PATH "${lib.makeLibraryPath [ stdenv.cc.cc ]}" wrapProgram $out/opt/appgate/appgate-driver \ - --prefix PATH : ${lib.makeBinPath [ iproute2 networkmanager dnsmasq ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + iproute2 + networkmanager + dnsmasq + ] + } \ --set LD_LIBRARY_PATH $out/opt/appgate/service # make xdg-open overrideable at runtime diff --git a/pkgs/by-name/ap/appimagekit/package.nix b/pkgs/by-name/ap/appimagekit/package.nix index c540b8cfac1e0b..8b7c20fed19bcb 100644 --- a/pkgs/by-name/ap/appimagekit/package.nix +++ b/pkgs/by-name/ap/appimagekit/package.nix @@ -1,9 +1,29 @@ -{ lib, stdenv, fetchFromGitHub -, pkg-config, cmake, autoconf, automake, libtool, makeWrapper -, wget, xxd, desktop-file-utils, file -, gnupg, glib, zlib, cairo, openssl, fuse, xz, squashfuse, inotify-tools, libarchive -, squashfsTools -, gtest +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + autoconf, + automake, + libtool, + makeWrapper, + wget, + xxd, + desktop-file-utils, + file, + gnupg, + glib, + zlib, + cairo, + openssl, + fuse, + xz, + squashfuse, + inotify-tools, + libarchive, + squashfsTools, + gtest, }: let @@ -23,7 +43,7 @@ let src = fetchFromGitHub { owner = "vasi"; - repo = pname; + repo = pname; rev = "1f980303b89c779eabfd0a0fdd36d6a7a311bf92"; sha256 = "sha256-BZd1+7sRYZHthULKk3RlgMIy4uCUei45GbSEiZxLPFM="; }; @@ -48,7 +68,10 @@ let ''; configureFlags = [ - "--disable-demo" "--disable-high-level" "--without-lzo" "--without-lz4" + "--disable-demo" + "--disable-high-level" + "--without-lzo" + "--without-lz4" ]; postConfigure = '' @@ -63,7 +86,8 @@ let ''; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "appimagekit"; version = "unstable-2020-12-31"; @@ -76,13 +100,28 @@ in stdenv.mkDerivation rec { ''; nativeBuildInputs = [ - pkg-config cmake autoconf automake libtool wget xxd - desktop-file-utils makeWrapper + pkg-config + cmake + autoconf + automake + libtool + wget + xxd + desktop-file-utils + makeWrapper ]; buildInputs = [ - glib zlib cairo openssl fuse xz inotify-tools - libarchive squashfsTools appimagekit_squashfuse + glib + zlib + cairo + openssl + fuse + xz + inotify-tools + libarchive + squashfsTools + appimagekit_squashfuse ]; preConfigure = '' @@ -105,7 +144,12 @@ in stdenv.mkDerivation rec { cp "${desktop-file-utils}/bin/desktop-file-validate" "$out/bin" wrapProgram "$out/bin/appimagetool" \ - --prefix PATH : "${lib.makeBinPath [ file gnupg ]}" \ + --prefix PATH : "${ + lib.makeBinPath [ + file + gnupg + ] + }" \ --unset SOURCE_DATE_EPOCH ''; diff --git a/pkgs/by-name/ap/appindicator-sharp/package.nix b/pkgs/by-name/ap/appindicator-sharp/package.nix index 3062074f4cd798..40373d4e61afdb 100644 --- a/pkgs/by-name/ap/appindicator-sharp/package.nix +++ b/pkgs/by-name/ap/appindicator-sharp/package.nix @@ -32,7 +32,7 @@ stdenv.mkDerivation rec { ]; ac_cv_path_MDOC = "no"; - installFlags = ["GAPIXMLDIR=/tmp/gapixml"]; + installFlags = [ "GAPIXMLDIR=/tmp/gapixml" ]; meta = { description = "Bindings for appindicator using gobject-introspection"; diff --git a/pkgs/by-name/ap/apple-cursor/package.nix b/pkgs/by-name/ap/apple-cursor/package.nix index e2f059ecb1fb2b..2dd91c2b0a5510 100644 --- a/pkgs/by-name/ap/apple-cursor/package.nix +++ b/pkgs/by-name/ap/apple-cursor/package.nix @@ -1,20 +1,28 @@ -{ lib -, fetchzip -, stdenv +{ + lib, + fetchzip, + stdenv, }: let - _src = variant: suffix: hash: fetchzip ({ - name = variant; - url = "https://github.com/ful1e5/apple_cursor/releases/download/v${version}/${variant}.${suffix}"; - hash = hash; - } // (lib.optionalAttrs (suffix == "zip") { stripRoot = false; }) // (lib.optionalAttrs (suffix == "tar.xz") { stripRoot = false; })); + _src = + variant: suffix: hash: + fetchzip ( + { + name = variant; + url = "https://github.com/ful1e5/apple_cursor/releases/download/v${version}/${variant}.${suffix}"; + hash = hash; + } + // (lib.optionalAttrs (suffix == "zip") { stripRoot = false; }) + // (lib.optionalAttrs (suffix == "tar.xz") { stripRoot = false; }) + ); srcs = [ (_src "macOS" "tar.xz" "sha256-nS4g+VwM+4q/S1ODb3ySi2SBk7Ha8vF8d9XpP5cEkok=") ]; version = "2.0.1"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "apple_cursor"; inherit version; inherit srcs; @@ -35,6 +43,9 @@ in stdenv.mkDerivation rec { licenses.unfree ]; platforms = platforms.linux; - maintainers = with maintainers; [ colemickens dxwil ]; + maintainers = with maintainers; [ + colemickens + dxwil + ]; }; } diff --git a/pkgs/by-name/ap/approxmc/package.nix b/pkgs/by-name/ap/approxmc/package.nix index 843fe187a3f0ff..20460dc5428bad 100644 --- a/pkgs/by-name/ap/approxmc/package.nix +++ b/pkgs/by-name/ap/approxmc/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, fetchFromGitHub -, cmake -, zlib -, gmp -, cryptominisat -, boost -, arjun-cnf -, louvain-community -, lib +{ + stdenv, + fetchFromGitHub, + cmake, + zlib, + gmp, + cryptominisat, + boost, + arjun-cnf, + louvain-community, + lib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ap/appstream-glib/package.nix b/pkgs/by-name/ap/appstream-glib/package.nix index 7b3e4516bf6bb0..67f5f96c306ebc 100644 --- a/pkgs/by-name/ap/appstream-glib/package.nix +++ b/pkgs/by-name/ap/appstream-glib/package.nix @@ -1,38 +1,45 @@ -{ lib, stdenv -, fetchFromGitHub -, substituteAll -, docbook_xml_dtd_42 -, docbook_xsl -, fontconfig -, freetype -, gdk-pixbuf -, gettext -, glib -, gobject-introspection -, gperf -, gtk-doc -, gtk3 -, json-glib -, libarchive -, curl -, libuuid -, libxslt -, meson -, ninja -, pkg-config -, pngquant +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + docbook_xml_dtd_42, + docbook_xsl, + fontconfig, + freetype, + gdk-pixbuf, + gettext, + glib, + gobject-introspection, + gperf, + gtk-doc, + gtk3, + json-glib, + libarchive, + curl, + libuuid, + libxslt, + meson, + ninja, + pkg-config, + pngquant, }: stdenv.mkDerivation rec { pname = "appstream-glib"; version = "0.8.2"; - outputs = [ "out" "dev" "man" "installedTests" ]; + outputs = [ + "out" + "dev" + "man" + "installedTests" + ]; outputBin = "dev"; src = fetchFromGitHub { owner = "hughsie"; repo = "appstream-glib"; - rev = "${lib.replaceStrings ["-"] ["_"] pname}_${lib.replaceStrings ["."] ["_"] version}"; + rev = "${lib.replaceStrings [ "-" ] [ "_" ] pname}_${lib.replaceStrings [ "." ] [ "_" ] version}"; sha256 = "sha256-3QFiOJ38talA0GGL++n+DaA/AN7l4LOZQ7BJV6o8ius="; }; diff --git a/pkgs/by-name/ap/appvm/package.nix b/pkgs/by-name/ap/appvm/package.nix index c71236d127b680..62378c5072fe09 100644 --- a/pkgs/by-name/ap/appvm/package.nix +++ b/pkgs/by-name/ap/appvm/package.nix @@ -1,15 +1,17 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix -, virt-viewer -, makeWrapper }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nix, + virt-viewer, + makeWrapper, +}: let # Upstream patches fail with newer virt-viewer. These are own ports to the # newest virt-viewer version, see: # https://github.com/jollheef/appvm/issues/28 - virt-manager-without-menu = virt-viewer.overrideAttrs(oldAttrs: { + virt-manager-without-menu = virt-viewer.overrideAttrs (oldAttrs: { patches = oldAttrs.patches ++ [ ./0001-Remove-menu-bar.patch ./0002-Do-not-grab-keyboard-mouse.patch @@ -35,13 +37,22 @@ buildGoModule rec { postFixup = '' wrapProgram $out/bin/appvm \ - --prefix PATH : "${lib.makeBinPath [ nix virt-manager-without-menu ]}" + --prefix PATH : "${ + lib.makeBinPath [ + nix + virt-manager-without-menu + ] + }" ''; meta = with lib; { description = "Nix-based app VMs"; homepage = "https://code.dumpstack.io/tools/${pname}"; - maintainers = with maintainers; [ dump_stack cab404 onny ]; + maintainers = with maintainers; [ + dump_stack + cab404 + onny + ]; license = licenses.gpl3; }; } diff --git a/pkgs/by-name/ap/aprutil/package.nix b/pkgs/by-name/ap/aprutil/package.nix index ea7c9cf8c16804..1f23af533b76a5 100644 --- a/pkgs/by-name/ap/aprutil/package.nix +++ b/pkgs/by-name/ap/aprutil/package.nix @@ -1,9 +1,21 @@ -{ lib, stdenv, fetchurl, makeWrapper, apr, expat, gnused -, sslSupport ? true, openssl -, bdbSupport ? true, db -, ldapSupport ? !stdenv.hostPlatform.isCygwin, openldap -, libiconv, libxcrypt -, cyrus_sasl, autoreconfHook +{ + lib, + stdenv, + fetchurl, + makeWrapper, + apr, + expat, + gnused, + sslSupport ? true, + openssl, + bdbSupport ? true, + db, + ldapSupport ? !stdenv.hostPlatform.isCygwin, + openldap, + libiconv, + libxcrypt, + cyrus_sasl, + autoreconfHook, }: assert sslSupport -> openssl != null; @@ -27,35 +39,57 @@ stdenv.mkDerivation rec { NIX_CFLAGS_LINK = [ "-lcrypt" ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; outputBin = "dev"; - nativeBuildInputs = [ makeWrapper autoreconfHook ]; + nativeBuildInputs = [ + makeWrapper + autoreconfHook + ]; - configureFlags = [ "--with-apr=${apr.dev}" "--with-expat=${expat.dev}" ] + configureFlags = + [ + "--with-apr=${apr.dev}" + "--with-expat=${expat.dev}" + ] ++ lib.optional (!stdenv.hostPlatform.isCygwin) "--with-crypto" ++ lib.optional sslSupport "--with-openssl=${openssl.dev}" ++ lib.optional bdbSupport "--with-berkeley-db=${db.dev}" ++ lib.optional ldapSupport "--with-ldap=ldap" - ++ lib.optionals stdenv.hostPlatform.isCygwin - [ "--without-pgsql" "--without-sqlite2" "--without-sqlite3" - "--without-freetds" "--without-berkeley-db" "--without-crypto" ] - ; + ++ lib.optionals stdenv.hostPlatform.isCygwin [ + "--without-pgsql" + "--without-sqlite2" + "--without-sqlite3" + "--without-freetds" + "--without-berkeley-db" + "--without-crypto" + ]; - postConfigure = '' - echo '#define APR_HAVE_CRYPT_H 1' >> confdefs.h - '' + - # For some reason, db version 6.9 is selected when cross-compiling. - # It's unclear as to why, it requires someone with more autotools / configure knowledge to go deeper into that. - # Always replacing the link flag with a generic link flag seems to help though, so let's do that for now. - lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' - substituteInPlace Makefile \ - --replace "-ldb-6.9" "-ldb" - substituteInPlace apu-1-config \ - --replace "-ldb-6.9" "-ldb" - ''; + postConfigure = + '' + echo '#define APR_HAVE_CRYPT_H 1' >> confdefs.h + '' + + + # For some reason, db version 6.9 is selected when cross-compiling. + # It's unclear as to why, it requires someone with more autotools / configure knowledge to go deeper into that. + # Always replacing the link flag with a generic link flag seems to help though, so let's do that for now. + lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' + substituteInPlace Makefile \ + --replace "-ldb-6.9" "-ldb" + substituteInPlace apu-1-config \ + --replace "-ldb-6.9" "-ldb" + ''; - propagatedBuildInputs = [ apr expat libiconv libxcrypt ] + propagatedBuildInputs = + [ + apr + expat + libiconv + libxcrypt + ] ++ lib.optional sslSupport openssl ++ lib.optional bdbSupport db ++ lib.optional ldapSupport openldap diff --git a/pkgs/by-name/ap/aprx/package.nix b/pkgs/by-name/ap/aprx/package.nix index e6dc23cbef5ce2..6981e074aeed55 100644 --- a/pkgs/by-name/ap/aprx/package.nix +++ b/pkgs/by-name/ap/aprx/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, perl +{ + lib, + stdenv, + fetchFromGitHub, + perl, }: stdenv.mkDerivation { @@ -17,10 +18,13 @@ stdenv.mkDerivation { nativeBuildInputs = [ perl ]; - env.NIX_CFLAGS_COMPILE = toString ([ - "-fcommon" - "-O2" - ] ++ lib.optional stdenv.cc.isClang "-Wno-error=implicit-int"); + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-fcommon" + "-O2" + ] + ++ lib.optional stdenv.cc.isClang "-Wno-error=implicit-int" + ); configureFlags = [ "--with-erlangstorage" diff --git a/pkgs/by-name/ap/apt-cacher-ng/package.nix b/pkgs/by-name/ap/apt-cacher-ng/package.nix index bea5fd3135ae1d..f3dbb4fe8266fe 100644 --- a/pkgs/by-name/ap/apt-cacher-ng/package.nix +++ b/pkgs/by-name/ap/apt-cacher-ng/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, bzip2 -, cmake -, doxygen -, fetchurl -, fetchpatch -, fuse -, libevent -, xz -, openssl -, pkg-config -, systemd -, tcp_wrappers -, zlib -, c-ares +{ + lib, + stdenv, + bzip2, + cmake, + doxygen, + fetchurl, + fetchpatch, + fuse, + libevent, + xz, + openssl, + pkg-config, + systemd, + tcp_wrappers, + zlib, + c-ares, }: stdenv.mkDerivation rec { @@ -34,8 +35,22 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake doxygen pkg-config ]; - buildInputs = [ bzip2 fuse libevent xz openssl systemd tcp_wrappers zlib c-ares ]; + nativeBuildInputs = [ + cmake + doxygen + pkg-config + ]; + buildInputs = [ + bzip2 + fuse + libevent + xz + openssl + systemd + tcp_wrappers + zlib + c-ares + ]; meta = with lib; { description = "Caching proxy specialized for Linux distribution files"; diff --git a/pkgs/by-name/ap/apt-mirror/package.nix b/pkgs/by-name/ap/apt-mirror/package.nix index 0735293986de73..8f606e921af01e 100644 --- a/pkgs/by-name/ap/apt-mirror/package.nix +++ b/pkgs/by-name/ap/apt-mirror/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, perl -, wget -, makeWrapper -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + perl, + wget, + makeWrapper, + nix-update-script, }: stdenv.mkDerivation (finalAttrs: { @@ -34,10 +35,10 @@ stdenv.mkDerivation (finalAttrs: { postInstall = '' wrapProgram $out/bin/apt-mirror \ - --prefix PATH : ${lib.makeBinPath [wget]} + --prefix PATH : ${lib.makeBinPath [ wget ]} ''; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = with lib; { description = "Tool that provides the ability to mirror any parts of apt sources"; diff --git a/pkgs/by-name/ap/apt-offline/package.nix b/pkgs/by-name/ap/apt-offline/package.nix index bfd61098211cc8..e6826e1740d8cc 100644 --- a/pkgs/by-name/ap/apt-offline/package.nix +++ b/pkgs/by-name/ap/apt-offline/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, python3Packages -, gnupg -, installShellFiles +{ + lib, + fetchFromGitHub, + python3Packages, + gnupg, + installShellFiles, }: let @@ -41,7 +42,10 @@ python3Packages.buildPythonApplication { pythonImportsCheck = [ "apt_offline_core" ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; meta = { homepage = "https://github.com/rickysarraf/apt-offline"; diff --git a/pkgs/by-name/ap/apt/package.nix b/pkgs/by-name/ap/apt/package.nix index 691bdce150d871..0daef994325086 100644 --- a/pkgs/by-name/ap/apt/package.nix +++ b/pkgs/by-name/ap/apt/package.nix @@ -1,34 +1,35 @@ -{ lib -, stdenv -, fetchurl -, bzip2 -, cmake -, curl -, db -, docbook_xml_dtd_45 -, docbook_xsl -, doxygen -, dpkg -, gettext -, gnutls -, gtest -, libgcrypt -, libgpg-error -, libseccomp -, libtasn1 -, libxslt -, lz4 -, p11-kit -, perlPackages -, pkg-config -, triehash -, udev -, w3m -, xxHash -, xz -, zstd -, withDocs ? true -, withNLS ? true +{ + lib, + stdenv, + fetchurl, + bzip2, + cmake, + curl, + db, + docbook_xml_dtd_45, + docbook_xsl, + doxygen, + dpkg, + gettext, + gnutls, + gtest, + libgcrypt, + libgpg-error, + libseccomp, + libtasn1, + libxslt, + lz4, + p11-kit, + perlPackages, + pkg-config, + triehash, + udev, + w3m, + xxHash, + xz, + zstd, + withDocs ? true, + withNLS ? true, }: stdenv.mkDerivation (finalAttrs: { @@ -41,7 +42,12 @@ stdenv.mkDerivation (finalAttrs: { }; # cycle detection; lib can't be split - outputs = [ "out" "dev" "doc" "man" ]; + outputs = [ + "out" + "dev" + "doc" + "man" + ]; nativeBuildInputs = [ cmake @@ -51,35 +57,38 @@ stdenv.mkDerivation (finalAttrs: { triehash ]; - buildInputs = [ - bzip2 - curl - db - dpkg - gnutls - libgcrypt - libgpg-error - libseccomp - libtasn1 - lz4 - p11-kit - perlPackages.perl - udev - xxHash - xz - zstd - ] ++ lib.optionals withDocs [ - docbook_xml_dtd_45 - doxygen - perlPackages.Po4a - w3m - ] ++ lib.optionals withNLS [ - gettext - ]; + buildInputs = + [ + bzip2 + curl + db + dpkg + gnutls + libgcrypt + libgpg-error + libseccomp + libtasn1 + lz4 + p11-kit + perlPackages.perl + udev + xxHash + xz + zstd + ] + ++ lib.optionals withDocs [ + docbook_xml_dtd_45 + doxygen + perlPackages.Po4a + w3m + ] + ++ lib.optionals withNLS [ + gettext + ]; cmakeFlags = [ (lib.cmakeOptionType "filepath" "BERKELEY_INCLUDE_DIRS" "${lib.getDev db}/include") - (lib.cmakeOptionType "filepath" "DOCBOOK_XSL""${docbook_xsl}/share/xml/docbook-xsl") + (lib.cmakeOptionType "filepath" "DOCBOOK_XSL" "${docbook_xsl}/share/xml/docbook-xsl") (lib.cmakeOptionType "filepath" "GNUTLS_INCLUDE_DIR" "${lib.getDev gnutls}/include") (lib.cmakeFeature "DROOT_GROUP" "root") (lib.cmakeBool "USE_NLS" withNLS) diff --git a/pkgs/by-name/ap/aptdec/package.nix b/pkgs/by-name/ap/aptdec/package.nix index 2c3c9b3bdfd792..4645933e4c0c64 100644 --- a/pkgs/by-name/ap/aptdec/package.nix +++ b/pkgs/by-name/ap/aptdec/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, libpng -, libsndfile +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libpng, + libsndfile, }: stdenv.mkDerivation rec { @@ -19,8 +20,14 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libpng libsndfile ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + libpng + libsndfile + ]; meta = with lib; { description = "NOAA APT satellite imagery decoding library"; diff --git a/pkgs/by-name/ap/aptly/package.nix b/pkgs/by-name/ap/aptly/package.nix index 6da10fe9b7fce6..f04824a05fb3ff 100644 --- a/pkgs/by-name/ap/aptly/package.nix +++ b/pkgs/by-name/ap/aptly/package.nix @@ -1,4 +1,16 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, makeWrapper, gnupg, bzip2, xz, graphviz, testers, aptly }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + makeWrapper, + gnupg, + bzip2, + xz, + graphviz, + testers, + aptly, +}: buildGoModule rec { pname = "aptly"; @@ -13,15 +25,29 @@ buildGoModule rec { vendorHash = "sha256-6l3OFKFTtFWT68Ylav6woczBlMhD75C9ZoQ6OeLz0Cs="; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; - ldflags = [ "-s" "-w" "-X main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.Version=${version}" + ]; postInstall = '' installShellCompletion --bash --name aptly completion.d/aptly installShellCompletion --zsh --name _aptly completion.d/_aptly wrapProgram "$out/bin/aptly" \ - --prefix PATH ":" "${lib.makeBinPath [ gnupg bzip2 xz graphviz ]}" + --prefix PATH ":" "${ + lib.makeBinPath [ + gnupg + bzip2 + xz + graphviz + ] + }" ''; doCheck = false; @@ -36,8 +62,7 @@ buildGoModule rec { description = "Debian repository management tool"; license = licenses.mit; maintainers = with maintainers; [ montag451 ] ++ teams.bitnomial.members; - changelog = - "https://github.com/aptly-dev/aptly/releases/tag/v${version}"; + changelog = "https://github.com/aptly-dev/aptly/releases/tag/v${version}"; mainProgram = "aptly"; }; } diff --git a/pkgs/by-name/ap/apvlv/package.nix b/pkgs/by-name/ap/apvlv/package.nix index 29be0626520880..1f45f4fb1094eb 100644 --- a/pkgs/by-name/ap/apvlv/package.nix +++ b/pkgs/by-name/ap/apvlv/package.nix @@ -106,7 +106,10 @@ stdenv.mkDerivation (finalAttrs: { with Vim-like behaviour. ''; mainProgram = "apvlv"; - maintainers = with lib.maintainers; [ ardumont anthonyroussel ]; + maintainers = with lib.maintainers; [ + ardumont + anthonyroussel + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/by-name/ap/apx/package.nix b/pkgs/by-name/ap/apx/package.nix index ff21850caafe40..b60e70a45c51c9 100644 --- a/pkgs/by-name/ap/apx/package.nix +++ b/pkgs/by-name/ap/apx/package.nix @@ -21,9 +21,16 @@ buildGoModule rec { vendorHash = "sha256-YHnPLjZWUYoARHF4V1Pm1LYdCJGubPCve0wQ5FpeXUg="; # podman needed for apx to not error when building shell completions - nativeBuildInputs = [ installShellFiles podman ]; + nativeBuildInputs = [ + installShellFiles + podman + ]; - ldflags = [ "-s" "-w" "-X 'main.Version=v${version}'" ]; + ldflags = [ + "-s" + "-w" + "-X 'main.Version=v${version}'" + ]; postPatch = '' substituteInPlace config/apx.json \ @@ -54,7 +61,10 @@ buildGoModule rec { homepage = "https://github.com/Vanilla-OS/apx"; changelog = "https://github.com/Vanilla-OS/apx/releases/tag/v${version}"; license = licenses.gpl3Only; - maintainers = with maintainers; [ dit7ya chewblacka ]; + maintainers = with maintainers; [ + dit7ya + chewblacka + ]; mainProgram = "apx"; }; } diff --git a/pkgs/by-name/aq/aquosctl/package.nix b/pkgs/by-name/aq/aquosctl/package.nix index f8eba27e0fe477..cbc018674c94d5 100644 --- a/pkgs/by-name/aq/aquosctl/package.nix +++ b/pkgs/by-name/aq/aquosctl/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: let @@ -32,4 +33,3 @@ stdenv.mkDerivation { mainProgram = "aquosctl"; }; } - diff --git a/pkgs/by-name/ar/arachne-pnr/package.nix b/pkgs/by-name/ar/arachne-pnr/package.nix index 37b7158c62842b..a9870ca9f6e151 100644 --- a/pkgs/by-name/ar/arachne-pnr/package.nix +++ b/pkgs/by-name/ar/arachne-pnr/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, icestorm }: +{ + lib, + stdenv, + fetchFromGitHub, + icestorm, +}: stdenv.mkDerivation rec { pname = "arachne-pnr"; @@ -37,7 +42,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://github.com/cseed/arachne-pnr"; license = licenses.mit; - maintainers = with maintainers; [ shell thoughtpolice ]; + maintainers = with maintainers; [ + shell + thoughtpolice + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ar/aragorn/package.nix b/pkgs/by-name/ar/aragorn/package.nix index 3ec62ada04c9e3..23a7c12d927c3c 100644 --- a/pkgs/by-name/ar/aragorn/package.nix +++ b/pkgs/by-name/ar/aragorn/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, installShellFiles +{ + lib, + stdenv, + fetchurl, + installShellFiles, }: let man = fetchurl { diff --git a/pkgs/by-name/ar/arandr/package.nix b/pkgs/by-name/ar/arandr/package.nix index c0125fb710da80..9c8f86e2c9b38e 100644 --- a/pkgs/by-name/ar/arandr/package.nix +++ b/pkgs/by-name/ar/arandr/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchurl -, python3Packages -, gobject-introspection -, gsettings-desktop-schemas -, gtk3 -, wrapGAppsHook3 -, xrandr +{ + lib, + fetchurl, + python3Packages, + gobject-introspection, + gsettings-desktop-schemas, + gtk3, + wrapGAppsHook3, + xrandr, }: let @@ -27,9 +28,19 @@ buildPythonApplication rec { # no tests doCheck = false; - buildInputs = [ docutils gsettings-desktop-schemas gtk3 ]; - nativeBuildInputs = [ gobject-introspection wrapGAppsHook3 ]; - propagatedBuildInputs = [ xrandr pygobject3 ]; + buildInputs = [ + docutils + gsettings-desktop-schemas + gtk3 + ]; + nativeBuildInputs = [ + gobject-introspection + wrapGAppsHook3 + ]; + propagatedBuildInputs = [ + xrandr + pygobject3 + ]; meta = with lib; { homepage = "https://christian.amsuess.com/tools/arandr/"; diff --git a/pkgs/by-name/ar/arangodb/package.nix b/pkgs/by-name/ar/arangodb/package.nix index 5b965796de64c6..706c3c503afd91 100644 --- a/pkgs/by-name/ar/arangodb/package.nix +++ b/pkgs/by-name/ar/arangodb/package.nix @@ -2,32 +2,26 @@ # gcc 11.2 suggested on 3.10.5.2. # gcc 11.3.0 unsupported yet, investigate gcc support when upgrading # See https://github.com/arangodb/arangodb/issues/17454 - gcc10Stdenv -, git -, lib -, fetchFromGitHub -, openssl -, zlib -, cmake -, python3 -, perl -, snappy -, lzo -, which -, targetArchitecture ? null -, asmOptimizations ? gcc10Stdenv.hostPlatform.isx86 + gcc10Stdenv, + git, + lib, + fetchFromGitHub, + openssl, + zlib, + cmake, + python3, + perl, + snappy, + lzo, + which, + targetArchitecture ? null, + asmOptimizations ? gcc10Stdenv.hostPlatform.isx86, }: let - defaultTargetArchitecture = - if gcc10Stdenv.hostPlatform.isx86 - then "haswell" - else "core"; + defaultTargetArchitecture = if gcc10Stdenv.hostPlatform.isx86 then "haswell" else "core"; - targetArch = - if targetArchitecture == null - then defaultTargetArchitecture - else targetArchitecture; + targetArch = if targetArchitecture == null then defaultTargetArchitecture else targetArchitecture; in gcc10Stdenv.mkDerivation rec { @@ -42,9 +36,20 @@ gcc10Stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake git perl python3 which ]; + nativeBuildInputs = [ + cmake + git + perl + python3 + which + ]; - buildInputs = [ openssl zlib snappy lzo ]; + buildInputs = [ + openssl + zlib + snappy + lzo + ]; # prevent failing with "cmake-3.13.4/nix-support/setup-hook: line 10: ./3rdParty/rocksdb/RocksDBConfig.cmake.in: No such file or directory" dontFixCmake = true; @@ -64,22 +69,27 @@ gcc10Stdenv.mkDerivation rec { cmakeBuildType = "RelWithDebInfo"; - cmakeFlags = [ - "-DUSE_MAINTAINER_MODE=OFF" - "-DUSE_GOOGLE_TESTS=OFF" + cmakeFlags = + [ + "-DUSE_MAINTAINER_MODE=OFF" + "-DUSE_GOOGLE_TESTS=OFF" - # avoid reading /proc/cpuinfo for feature detection - "-DTARGET_ARCHITECTURE=${targetArch}" - ] ++ lib.optionals asmOptimizations [ - "-DASM_OPTIMIZATIONS=ON" - "-DHAVE_SSE42=${if gcc10Stdenv.hostPlatform.sse4_2Support then "ON" else "OFF"}" - ]; + # avoid reading /proc/cpuinfo for feature detection + "-DTARGET_ARCHITECTURE=${targetArch}" + ] + ++ lib.optionals asmOptimizations [ + "-DASM_OPTIMIZATIONS=ON" + "-DHAVE_SSE42=${if gcc10Stdenv.hostPlatform.sse4_2Support then "ON" else "OFF"}" + ]; meta = with lib; { homepage = "https://www.arangodb.com"; description = "Native multi-model database with flexible data models for documents, graphs, and key-values"; license = licenses.asl20; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ flosse jsoo1 ]; + maintainers = with maintainers; [ + flosse + jsoo1 + ]; }; } diff --git a/pkgs/by-name/ar/aravis/package.nix b/pkgs/by-name/ar/aravis/package.nix index deeed9ebc9cda4..d2e237e0aac104 100644 --- a/pkgs/by-name/ar/aravis/package.nix +++ b/pkgs/by-name/ar/aravis/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, gi-docgen -, glib -, libxml2 -, gobject-introspection +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + gi-docgen, + glib, + libxml2, + gobject-introspection, -, enableGstPlugin ? true -, enableViewer ? true -, gst_all_1 -, gtk3 -, wrapGAppsHook3 + enableGstPlugin ? true, + enableViewer ? true, + gst_all_1, + gtk3, + wrapGAppsHook3, -, enableUsb ? true -, libusb1 + enableUsb ? true, + libusb1, -, enablePacketSocket ? true -, enableFastHeartbeat ? false + enablePacketSocket ? true, + enableFastHeartbeat ? false, }: assert enableGstPlugin -> gst_all_1 != null; @@ -38,7 +39,12 @@ stdenv.mkDerivation rec { sha256 = "sha256-D6zcTCaFJxJ2VhhsgEFu5+3Xx1MJov4ryrtA0VkjZlY="; }; - outputs = [ "bin" "dev" "out" "lib" ]; + outputs = [ + "bin" + "dev" + "out" + "lib" + ]; nativeBuildInputs = [ meson @@ -49,17 +55,30 @@ stdenv.mkDerivation rec { ] ++ lib.optional enableViewer wrapGAppsHook3; buildInputs = - [ glib libxml2 ] + [ + glib + libxml2 + ] ++ lib.optional enableUsb libusb1 - ++ lib.optionals (enableViewer || enableGstPlugin) (with gst_all_1; [ gstreamer gst-plugins-base (gst-plugins-good.override { gtkSupport = true; }) gst-plugins-bad ]) + ++ lib.optionals (enableViewer || enableGstPlugin) ( + with gst_all_1; + [ + gstreamer + gst-plugins-base + (gst-plugins-good.override { gtkSupport = true; }) + gst-plugins-bad + ] + ) ++ lib.optionals (enableViewer) [ gtk3 ]; - mesonFlags = [ - ] ++ lib.optional enableFastHeartbeat "-Dfast-heartbeat=enabled" - ++ lib.optional (!enableGstPlugin) "-Dgst-plugin=disabled" - ++ lib.optional (!enableViewer) "-Dviewer=disabled" - ++ lib.optional (!enableUsb) "-Dviewer=disabled" - ++ lib.optional (!enablePacketSocket) "-Dpacket-socket=disabled"; + mesonFlags = + [ + ] + ++ lib.optional enableFastHeartbeat "-Dfast-heartbeat=enabled" + ++ lib.optional (!enableGstPlugin) "-Dgst-plugin=disabled" + ++ lib.optional (!enableViewer) "-Dviewer=disabled" + ++ lib.optional (!enableUsb) "-Dviewer=disabled" + ++ lib.optional (!enablePacketSocket) "-Dpacket-socket=disabled"; doCheck = true; diff --git a/pkgs/by-name/ar/arb/package.nix b/pkgs/by-name/ar/arb/package.nix index 87072265abb26c..52b8aea77b7eda 100644 --- a/pkgs/by-name/ar/arb/package.nix +++ b/pkgs/by-name/ar/arb/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, mpir -, gmp -, mpfr -, flint +{ + lib, + stdenv, + fetchFromGitHub, + mpir, + gmp, + mpfr, + flint, }: stdenv.mkDerivation rec { @@ -18,7 +19,12 @@ stdenv.mkDerivation rec { sha256 = "sha256-dt9PZ3Xfn60rhmnxYo7CEzNTEUN/wMVAXe8U5PzUO9U="; }; - buildInputs = [ mpir gmp mpfr flint ]; + buildInputs = [ + mpir + gmp + mpfr + flint + ]; configureFlags = [ "--with-gmp=${gmp}" diff --git a/pkgs/by-name/ar/arc-icon-theme/package.nix b/pkgs/by-name/ar/arc-icon-theme/package.nix index 17405d7b78e17e..646a0d14c7da6a 100644 --- a/pkgs/by-name/ar/arc-icon-theme/package.nix +++ b/pkgs/by-name/ar/arc-icon-theme/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenvNoCC, fetchFromGitHub, autoreconfHook, gtk3, adwaita-icon-theme, moka-icon-theme, gnome-icon-theme, hicolor-icon-theme }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + autoreconfHook, + gtk3, + adwaita-icon-theme, + moka-icon-theme, + gnome-icon-theme, + hicolor-icon-theme, +}: stdenvNoCC.mkDerivation rec { pname = "arc-icon-theme"; diff --git a/pkgs/by-name/ar/arc-kde-theme/package.nix b/pkgs/by-name/ar/arc-kde-theme/package.nix index 3e0ac2b530c17c..2cc355efbe6d13 100644 --- a/pkgs/by-name/ar/arc-kde-theme/package.nix +++ b/pkgs/by-name/ar/arc-kde-theme/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "arc-kde-theme"; diff --git a/pkgs/by-name/ar/arc-theme/package.nix b/pkgs/by-name/ar/arc-theme/package.nix index 0f282df8fea676..e77a0caa970972 100644 --- a/pkgs/by-name/ar/arc-theme/package.nix +++ b/pkgs/by-name/ar/arc-theme/package.nix @@ -1,16 +1,18 @@ -{ lib, stdenv -, fetchFromGitHub -, sassc -, meson -, ninja -, glib -, gnome-shell -, gnome-themes-extra -, gtk-engine-murrine -, inkscape -, cinnamon-common -, makeFontsConf -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + sassc, + meson, + ninja, + glib, + gnome-shell, + gnome-themes-extra, + gtk-engine-murrine, + inkscape, + cinnamon-common, + makeFontsConf, + python3, }: stdenv.mkDerivation rec { @@ -64,6 +66,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/jnsh/arc-theme"; license = licenses.gpl3Only; platforms = platforms.linux; - maintainers = with maintainers; [ simonvandel romildo ]; + maintainers = with maintainers; [ + simonvandel + romildo + ]; }; } diff --git a/pkgs/by-name/ar/arc_unpacker/package.nix b/pkgs/by-name/ar/arc_unpacker/package.nix index 24a1d01b64da67..a4ccc53567dc97 100644 --- a/pkgs/by-name/ar/arc_unpacker/package.nix +++ b/pkgs/by-name/ar/arc_unpacker/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, makeWrapper -, boost -, libpng -, libiconv -, libjpeg -, zlib -, openssl -, libwebp -, catch2 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + makeWrapper, + boost, + libpng, + libiconv, + libjpeg, + zlib, + openssl, + libwebp, + catch2, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ar/arcan/package.nix b/pkgs/by-name/ar/arcan/package.nix index 5259b5560cfbaa..70d291bea106a2 100644 --- a/pkgs/by-name/ar/arcan/package.nix +++ b/pkgs/by-name/ar/arcan/package.nix @@ -129,7 +129,12 @@ stdenv.mkDerivation (finalAttrs: { "../src" ]; - outputs = [ "out" "dev" "lib" "man" ]; + outputs = [ + "out" + "dev" + "lib" + "man" + ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/ar/arcan/sources.nix b/pkgs/by-name/ar/arcan/sources.nix index 01f800a4aa4b2f..fbc7645a1bf2ea 100644 --- a/pkgs/by-name/ar/arcan/sources.nix +++ b/pkgs/by-name/ar/arcan/sources.nix @@ -3,19 +3,20 @@ }: { - letoram-arcan = let - self = { - pname = "arcan"; - version = "0.6.3.3"; + letoram-arcan = + let + self = { + pname = "arcan"; + version = "0.6.3.3"; - src = fetchFromGitHub { - owner = "letoram"; - repo = "arcan"; - rev = self.version; - hash = "sha256-YH3VGU3gSR5gqHnAlA2vrzU8vasKd0hOpc+2ludnV+Y="; + src = fetchFromGitHub { + owner = "letoram"; + repo = "arcan"; + rev = self.version; + hash = "sha256-YH3VGU3gSR5gqHnAlA2vrzU8vasKd0hOpc+2ludnV+Y="; + }; }; - }; - in + in self; letoram-openal = { diff --git a/pkgs/by-name/ar/arcan/wrapper.nix b/pkgs/by-name/ar/arcan/wrapper.nix index b61c5a5becd877..114a16956e58da 100644 --- a/pkgs/by-name/ar/arcan/wrapper.nix +++ b/pkgs/by-name/ar/arcan/wrapper.nix @@ -1,8 +1,9 @@ -{ arcan -, makeWrapper -, symlinkJoin -, appls ? [ ] -, name ? "arcan-wrapped" +{ + arcan, + makeWrapper, + symlinkJoin, + appls ? [ ], + name ? "arcan-wrapped", }: symlinkJoin rec { diff --git a/pkgs/by-name/ar/arch-install-scripts/package.nix b/pkgs/by-name/ar/arch-install-scripts/package.nix index 307b298a7ebf0d..18a53354908955 100644 --- a/pkgs/by-name/ar/arch-install-scripts/package.nix +++ b/pkgs/by-name/ar/arch-install-scripts/package.nix @@ -1,23 +1,24 @@ -{ lib -, resholve -, fetchFromGitLab -, asciidoc -, bash -, coreutils -, gawk -, gnugrep -, gnum4 -, gnused -, pacman -, util-linux -, chrootPath ? [ +{ + lib, + resholve, + fetchFromGitLab, + asciidoc, + bash, + coreutils, + gawk, + gnugrep, + gnum4, + gnused, + pacman, + util-linux, + chrootPath ? [ "/usr/local/sbin" "/usr/local/bin" "/usr/bin" "/usr/bin/site_perl" "/usr/bin/vendor_perl" "/usr/bin/core_perl" - ] + ], }: resholve.mkDerivation rec { @@ -32,7 +33,10 @@ resholve.mkDerivation rec { hash = "sha256-XWcZZ+ET3J4dB6M9CdXESf0iQh+2vYxlxoJ6TZ3vFUk="; }; - nativeBuildInputs = [ asciidoc gnum4 ]; + nativeBuildInputs = [ + asciidoc + gnum4 + ]; postPatch = '' substituteInPlace ./Makefile \ @@ -57,13 +61,24 @@ resholve.mkDerivation rec { # Specify 1 or more $out-relative script paths. Unlike many # builders, resholve.mkDerivation modifies the output files during # fixup (to correctly resolve in-package sourcing). - scripts = [ "bin/arch-chroot" "bin/genfstab" "bin/pacstrap" ]; + scripts = [ + "bin/arch-chroot" + "bin/genfstab" + "bin/pacstrap" + ]; # "none" for no shebang, "${bash}/bin/bash" for bash, etc. interpreter = "${bash}/bin/bash"; # packages resholve should resolve executables from - inputs = [ coreutils gawk gnugrep gnused pacman util-linux ]; + inputs = [ + coreutils + gawk + gnugrep + gnused + pacman + util-linux + ]; execer = [ "cannot:${pacman}/bin/pacman-key" ]; @@ -74,7 +89,12 @@ resholve.mkDerivation rec { umount = true; }; - keep = [ "$setup" "$pid_unshare" "$mount_unshare" "${pacman}/bin/pacman" ]; + keep = [ + "$setup" + "$pid_unshare" + "$mount_unshare" + "${pacman}/bin/pacman" + ]; }; }; diff --git a/pkgs/by-name/ar/archimedes/package.nix b/pkgs/by-name/ar/archimedes/package.nix index 9d9498df00da89..19f290dfb37747 100644 --- a/pkgs/by-name/ar/archimedes/package.nix +++ b/pkgs/by-name/ar/archimedes/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "archimedes"; diff --git a/pkgs/by-name/ar/archivebox/package.nix b/pkgs/by-name/ar/archivebox/package.nix index 52f5b627526511..bb222095da2670 100644 --- a/pkgs/by-name/ar/archivebox/package.nix +++ b/pkgs/by-name/ar/archivebox/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, python3 -, fetchFromGitHub -, fetchPypi -, curl -, wget -, git -, ripgrep -, single-file-cli -, postlight-parser -, readability-extractor -, chromium +{ + lib, + stdenv, + python3, + fetchFromGitHub, + fetchPypi, + curl, + wget, + git, + ripgrep, + single-file-cli, + postlight-parser, + readability-extractor, + chromium, }: let @@ -34,7 +35,9 @@ let "CVE-2022-28346" ]; }; - dependencies = (old.dependencies or [ ]) ++ (lib.optionals (python.pythonAtLeast "3.12") [ python.pkgs.distutils ]); + dependencies = + (old.dependencies or [ ]) + ++ (lib.optionals (python.pythonAtLeast "3.12") [ python.pkgs.distutils ]); }); django-extensions = super.django-extensions.overridePythonAttrs (old: rec { version = "3.1.5"; @@ -82,27 +85,37 @@ python.pkgs.buildPythonApplication rec { yt-dlp ]; - makeWrapperArgs = [ - "--set USE_NODE True" # used through dependencies, not needed explicitly - "--set READABILITY_BINARY ${lib.meta.getExe readability-extractor}" - "--set MERCURY_BINARY ${lib.meta.getExe postlight-parser}" - "--set CURL_BINARY ${lib.meta.getExe curl}" - "--set RIPGREP_BINARY ${lib.meta.getExe ripgrep}" - "--set WGET_BINARY ${lib.meta.getExe wget}" - "--set GIT_BINARY ${lib.meta.getExe git}" - "--set YOUTUBEDL_BINARY ${lib.meta.getExe python.pkgs.yt-dlp}" - "--set SINGLEFILE_BINARY ${lib.meta.getExe single-file-cli}" - ] ++ (if (lib.meta.availableOn stdenv.hostPlatform chromium) then [ - "--set CHROME_BINARY ${chromium}/bin/chromium-browser" - ] else [ - "--set-default USE_CHROME False" - ]); + makeWrapperArgs = + [ + "--set USE_NODE True" # used through dependencies, not needed explicitly + "--set READABILITY_BINARY ${lib.meta.getExe readability-extractor}" + "--set MERCURY_BINARY ${lib.meta.getExe postlight-parser}" + "--set CURL_BINARY ${lib.meta.getExe curl}" + "--set RIPGREP_BINARY ${lib.meta.getExe ripgrep}" + "--set WGET_BINARY ${lib.meta.getExe wget}" + "--set GIT_BINARY ${lib.meta.getExe git}" + "--set YOUTUBEDL_BINARY ${lib.meta.getExe python.pkgs.yt-dlp}" + "--set SINGLEFILE_BINARY ${lib.meta.getExe single-file-cli}" + ] + ++ ( + if (lib.meta.availableOn stdenv.hostPlatform chromium) then + [ + "--set CHROME_BINARY ${chromium}/bin/chromium-browser" + ] + else + [ + "--set-default USE_CHROME False" + ] + ); meta = with lib; { description = "Open source self-hosted web archiving"; homepage = "https://archivebox.io"; license = licenses.mit; - maintainers = with maintainers; [ siraben viraptor ]; + maintainers = with maintainers; [ + siraben + viraptor + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ar/archiver/package.nix b/pkgs/by-name/ar/archiver/package.nix index 2389285e99c065..13593168edd8cf 100644 --- a/pkgs/by-name/ar/archiver/package.nix +++ b/pkgs/by-name/ar/archiver/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { @@ -16,7 +17,13 @@ buildGoModule rec { vendorHash = "sha256-sTzjTKQ9m5BicDk6M1wR1EU+o9+87DbHCyGoF35Jm/g="; - ldflags = [ "-s" "-w" "-X main.version=${version}" "-X main.commit=${src.rev}" "-X main.date=unknown" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + "-X main.commit=${src.rev}" + "-X main.date=unknown" + ]; doCheck = false; diff --git a/pkgs/by-name/ar/archivy/package.nix b/pkgs/by-name/ar/archivy/package.nix index 902bc903bf467a..a61d6e267526c1 100644 --- a/pkgs/by-name/ar/archivy/package.nix +++ b/pkgs/by-name/ar/archivy/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: let @@ -33,7 +34,6 @@ buildPythonApplication rec { hash = "sha256-ns1Y0DqqnTAQMEt+oBJ/P2gqKqPsX9P3/Z4561qzuns"; }; - pythonRelaxDeps = true; propagatedBuildInputs = [ diff --git a/pkgs/by-name/ar/arcticons-sans/package.nix b/pkgs/by-name/ar/arcticons-sans/package.nix index da1ccd8a0eaf41..cb16a684ba2901 100644 --- a/pkgs/by-name/ar/arcticons-sans/package.nix +++ b/pkgs/by-name/ar/arcticons-sans/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchzip +{ + lib, + stdenvNoCC, + fetchzip, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ar/ardopc/package.nix b/pkgs/by-name/ar/ardopc/package.nix index fe8491dbc4b3cb..1ca0c08e02aeaf 100644 --- a/pkgs/by-name/ar/ardopc/package.nix +++ b/pkgs/by-name/ar/ardopc/package.nix @@ -1,11 +1,12 @@ -{ fetchFromGitHub -, lib -, makeWrapper -, pkg-config -, stdenv -, alsa-lib -, flrig -, hamlib +{ + fetchFromGitHub, + lib, + makeWrapper, + pkg-config, + stdenv, + alsa-lib, + flrig, + hamlib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ar/arduino-ci/package.nix b/pkgs/by-name/ar/arduino-ci/package.nix index b711f814fd7833..af301786fee711 100644 --- a/pkgs/by-name/ar/arduino-ci/package.nix +++ b/pkgs/by-name/ar/arduino-ci/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, arduino-cli, ruby, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + arduino-cli, + ruby, + python3, +}: let @@ -13,9 +21,9 @@ stdenv.mkDerivation rec { version = "0.2.0"; src = fetchFromGitHub { - owner = "pololu"; - repo = "arduino-ci"; - rev = "v${version}"; + owner = "pololu"; + repo = "arduino-ci"; + rev = "v${version}"; sha256 = "sha256-9RbBxgwsSQ7oGGKr1Vsn9Ug9AsacoRgvQgd9jbRQ034="; }; diff --git a/pkgs/by-name/ar/arduino-language-server/package.nix b/pkgs/by-name/ar/arduino-language-server/package.nix index d1be96454eecd2..1ff285ebbe7eb0 100644 --- a/pkgs/by-name/ar/arduino-language-server/package.nix +++ b/pkgs/by-name/ar/arduino-language-server/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -21,14 +22,16 @@ buildGoModule rec { doCheck = false; - ldflags = [ - "-s" - "-w" - "-X github.com/arduino/arduino-language-server/version.versionString=${version}" - "-X github.com/arduino/arduino-language-server/version.commit=unknown" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "-extldflags '-static'" - ]; + ldflags = + [ + "-s" + "-w" + "-X github.com/arduino/arduino-language-server/version.versionString=${version}" + "-X github.com/arduino/arduino-language-server/version.commit=unknown" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "-extldflags '-static'" + ]; meta = with lib; { description = "Arduino Language Server based on Clangd to Arduino code autocompletion"; diff --git a/pkgs/by-name/ar/arduino-mk/package.nix b/pkgs/by-name/ar/arduino-mk/package.nix index d5f506038ca6c7..eb03147af25bd8 100644 --- a/pkgs/by-name/ar/arduino-mk/package.nix +++ b/pkgs/by-name/ar/arduino-mk/package.nix @@ -1,17 +1,26 @@ -{ stdenv, lib, fetchFromGitHub, python3Packages, installShellFiles }: +{ + stdenv, + lib, + fetchFromGitHub, + python3Packages, + installShellFiles, +}: stdenv.mkDerivation rec { version = "1.6.0"; pname = "arduino-mk"; src = fetchFromGitHub { - owner = "sudar"; - repo = "Arduino-Makefile"; - rev = version; + owner = "sudar"; + repo = "Arduino-Makefile"; + rev = version; sha256 = "0flpl97d2231gp51n3y4qvf3y1l8xzafi1sgpwc305vwc2h4dl2x"; }; - nativeBuildInputs = [ python3Packages.wrapPython installShellFiles ]; + nativeBuildInputs = [ + python3Packages.wrapPython + installShellFiles + ]; propagatedBuildInputs = with python3Packages; [ pyserial ]; installPhase = '' mkdir $out diff --git a/pkgs/by-name/ar/arduinoOTA/package.nix b/pkgs/by-name/ar/arduinoOTA/package.nix index 0ae263ec6e9cdb..218b38db301da9 100644 --- a/pkgs/by-name/ar/arduinoOTA/package.nix +++ b/pkgs/by-name/ar/arduinoOTA/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, }: buildGoModule rec { pname = "arduinoOTA"; diff --git a/pkgs/by-name/ar/arena/package.nix b/pkgs/by-name/ar/arena/package.nix index c0bbc364617ec6..849c1810c2af6c 100644 --- a/pkgs/by-name/ar/arena/package.nix +++ b/pkgs/by-name/ar/arena/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, gtk2-x11, glib, pango, cairo, atk, gdk-pixbuf, libX11 }: +{ + lib, + stdenv, + fetchurl, + gtk2-x11, + glib, + pango, + cairo, + atk, + gdk-pixbuf, + libX11, +}: # Arena is free software in the sense of "free beer" but not as in "free # speech". We can install it as we please, but we cannot re-distribute it in @@ -16,12 +27,23 @@ stdenv.mkDerivation rec { version = "3.10-beta"; src = fetchurl { - url = "http://www.playwitharena.de/downloads/arenalinux_64bit_${lib.replaceStrings ["-"] [""] version}.tar.gz"; + url = "http://www.playwitharena.de/downloads/arenalinux_64bit_${ + lib.replaceStrings [ "-" ] [ "" ] version + }.tar.gz"; sha256 = "1pzb9sg4lzbbi4gbldvlb85p8xyl9xnplxwyb9pkk2mwzvvxkf0d"; }; # stdenv.cc.cc.lib is in that list to pick up libstdc++.so. Is there a better way? - buildInputs = [gtk2-x11 glib pango cairo atk gdk-pixbuf libX11 (lib.getLib stdenv.cc.cc)]; + buildInputs = [ + gtk2-x11 + glib + pango + cairo + atk + gdk-pixbuf + libX11 + (lib.getLib stdenv.cc.cc) + ]; unpackPhase = '' # This is is a tar bomb, i.e. it extract a dozen files and directories to @@ -70,7 +92,7 @@ stdenv.mkDerivation rec { license = lib.licenses.unfree; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; homepage = "http://www.playwitharena.de"; - platforms = ["x86_64-linux"]; + platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/by-name/ar/argagg/package.nix b/pkgs/by-name/ar/argagg/package.nix index bb8507abbe9772..431fad5aa7d2ec 100644 --- a/pkgs/by-name/ar/argagg/package.nix +++ b/pkgs/by-name/ar/argagg/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ar/argbash/package.nix b/pkgs/by-name/ar/argbash/package.nix index bf33e788633e8b..94babc07457893 100644 --- a/pkgs/by-name/ar/argbash/package.nix +++ b/pkgs/by-name/ar/argbash/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, makeWrapper -, python3Packages -, runtimeShell +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + makeWrapper, + python3Packages, + runtimeShell, }: stdenv.mkDerivation (finalAttrs: { @@ -31,7 +32,8 @@ stdenv.mkDerivation (finalAttrs: { ]; makeFlags = [ - "-C" "resources" + "-C" + "resources" "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/ar/argo-rollouts/package.nix b/pkgs/by-name/ar/argo-rollouts/package.nix index b09e8af264eb47..db941e1051915b 100644 --- a/pkgs/by-name/ar/argo-rollouts/package.nix +++ b/pkgs/by-name/ar/argo-rollouts/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, lib, fetchFromGitHub }: +{ + buildGoModule, + lib, + fetchFromGitHub, +}: buildGoModule rec { pname = "argo-rollouts"; @@ -16,7 +20,10 @@ buildGoModule rec { # Disable tests since some test fail because of missing test data doCheck = false; - subPackages = [ "cmd/rollouts-controller" "cmd/kubectl-argo-rollouts" ]; + subPackages = [ + "cmd/rollouts-controller" + "cmd/kubectl-argo-rollouts" + ]; meta = with lib; { description = "Kubernetes Progressive Delivery Controller"; diff --git a/pkgs/by-name/ar/argocd-autopilot/package.nix b/pkgs/by-name/ar/argocd-autopilot/package.nix index 98801506205580..c0e1e590c86069 100644 --- a/pkgs/by-name/ar/argocd-autopilot/package.nix +++ b/pkgs/by-name/ar/argocd-autopilot/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "argocd-autopilot"; @@ -16,7 +20,9 @@ buildGoModule rec { proxyVendor = true; ldflags = - let package_url = "github.com/argoproj-labs/argocd-autopilot/pkg/store"; in + let + package_url = "github.com/argoproj-labs/argocd-autopilot/pkg/store"; + in [ "-s" "-w" @@ -50,6 +56,9 @@ buildGoModule rec { downloadPage = "https://github.com/argoproj-labs/argocd-autopilot"; homepage = "https://argocd-autopilot.readthedocs.io/en/stable/"; license = licenses.asl20; - maintainers = with maintainers; [ sagikazarmark bryanasdev000 ]; + maintainers = with maintainers; [ + sagikazarmark + bryanasdev000 + ]; }; } diff --git a/pkgs/by-name/ar/argocd-vault-plugin/package.nix b/pkgs/by-name/ar/argocd-vault-plugin/package.nix index 3219d0a74e2b8f..e3e7496c5db286 100644 --- a/pkgs/by-name/ar/argocd-vault-plugin/package.nix +++ b/pkgs/by-name/ar/argocd-vault-plugin/package.nix @@ -1,8 +1,9 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, testers -, argocd-vault-plugin +{ + buildGoModule, + fetchFromGitHub, + lib, + testers, + argocd-vault-plugin, }: buildGoModule rec { diff --git a/pkgs/by-name/ar/argocd/package.nix b/pkgs/by-name/ar/argocd/package.nix index 85a15d028f54ba..916c43946171f9 100644 --- a/pkgs/by-name/ar/argocd/package.nix +++ b/pkgs/by-name/ar/argocd/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, stdenv }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + stdenv, +}: buildGoModule rec { pname = "argocd"; @@ -19,9 +25,12 @@ buildGoModule rec { subPackages = [ "cmd" ]; ldflags = - let package_url = "github.com/argoproj/argo-cd/v2/common"; in + let + package_url = "github.com/argoproj/argo-cd/v2/common"; + in [ - "-s" "-w" + "-s" + "-w" "-X ${package_url}.version=${version}" "-X ${package_url}.buildDate=unknown" "-X ${package_url}.gitCommit=${src.rev}" @@ -61,6 +70,10 @@ buildGoModule rec { downloadPage = "https://github.com/argoproj/argo-cd"; homepage = "https://argo-cd.readthedocs.io/en/stable/"; license = licenses.asl20; - maintainers = with maintainers; [ shahrukh330 bryanasdev000 qjoly ]; + maintainers = with maintainers; [ + shahrukh330 + bryanasdev000 + qjoly + ]; }; } diff --git a/pkgs/by-name/ar/argononed/package.nix b/pkgs/by-name/ar/argononed/package.nix index 320aaf3440504b..2f7914a64977ee 100644 --- a/pkgs/by-name/ar/argononed/package.nix +++ b/pkgs/by-name/ar/argononed/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitLab, dtc, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitLab, + dtc, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "argononed"; diff --git a/pkgs/by-name/ar/argp-standalone/package.nix b/pkgs/by-name/ar/argp-standalone/package.nix index f4fc2101e72bea..893aded31cffd4 100644 --- a/pkgs/by-name/ar/argp-standalone/package.nix +++ b/pkgs/by-name/ar/argp-standalone/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, +}: stdenv.mkDerivation rec { pname = "argp-standalone"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "jWnoWVnUVDQlsC9ru7oB9PdtZuyCCNqGnMqF/f2m0ZY="; }; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; doCheck = true; diff --git a/pkgs/by-name/ar/argparse/package.nix b/pkgs/by-name/ar/argparse/package.nix index 3b10b70e20403f..a12aba8b1098a8 100644 --- a/pkgs/by-name/ar/argparse/package.nix +++ b/pkgs/by-name/ar/argparse/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "argparse"; @@ -24,9 +29,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Argument Parser for Modern C++"; - homepage = "https://github.com/p-ranav/argparse"; + homepage = "https://github.com/p-ranav/argparse"; maintainers = with maintainers; [ _2gn ]; - platforms = platforms.unix; + platforms = platforms.unix; license = licenses.mit; }; } diff --git a/pkgs/by-name/ar/argtable/package.nix b/pkgs/by-name/ar/argtable/package.nix index eb751a2a12af23..cb874b99da8006 100644 --- a/pkgs/by-name/ar/argtable/package.nix +++ b/pkgs/by-name/ar/argtable/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ar/arguments/package.nix b/pkgs/by-name/ar/arguments/package.nix index 2924c5cf585cce..da7ef86d16ffd3 100644 --- a/pkgs/by-name/ar/arguments/package.nix +++ b/pkgs/by-name/ar/arguments/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "arguments"; @@ -8,8 +13,8 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { inherit owner; - repo = pname; - rev = "b3aad97f6b6892cb8733455d0d448649a48fa108"; + repo = pname; + rev = "b3aad97f6b6892cb8733455d0d448649a48fa108"; sha256 = "1ar8lm1w1jflz3vdmjr5c4x6y7rscvrj78b8gmrv79y95qrgzv6s"; }; @@ -25,6 +30,6 @@ stdenv.mkDerivation rec { description = "Library for argument handling for MINC programs"; maintainers = with maintainers; [ bcdarwin ]; platforms = platforms.unix; - license = licenses.gpl2Plus; + license = licenses.gpl2Plus; }; } diff --git a/pkgs/by-name/ar/argus-clients/package.nix b/pkgs/by-name/ar/argus-clients/package.nix index a7c56226af829a..11e5235bc1c8bc 100644 --- a/pkgs/by-name/ar/argus-clients/package.nix +++ b/pkgs/by-name/ar/argus-clients/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, libpcap, bison, flex, cyrus_sasl, tcp_wrappers, pkg-config, perl, libtirpc, libnsl }: +{ + lib, + stdenv, + fetchurl, + libpcap, + bison, + flex, + cyrus_sasl, + tcp_wrappers, + pkg-config, + perl, + libtirpc, + libnsl, +}: stdenv.mkDerivation rec { pname = "argus-clients"; @@ -16,12 +29,19 @@ stdenv.mkDerivation rec { substituteInPlace $file \ --subst-var-by PERLBIN ${perl}/bin/perl done - ''; + ''; configureFlags = [ "--with-perl=${perl}/bin/perl" ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libpcap bison cyrus_sasl tcp_wrappers flex libnsl ]; + buildInputs = [ + libpcap + bison + cyrus_sasl + tcp_wrappers + flex + libnsl + ]; meta = with lib; { description = "Clients for ARGUS"; diff --git a/pkgs/by-name/ar/argus/package.nix b/pkgs/by-name/ar/argus/package.nix index 72f87e359c0849..2b7d5ad9b69257 100644 --- a/pkgs/by-name/ar/argus/package.nix +++ b/pkgs/by-name/ar/argus/package.nix @@ -1,5 +1,20 @@ -{ lib, stdenv, fetchurl, libpcap, bison, flex, cyrus_sasl, tcp_wrappers, - pkg-config, procps, which, wget, lsof, net-snmp, perl }: +{ + lib, + stdenv, + fetchurl, + libpcap, + bison, + flex, + cyrus_sasl, + tcp_wrappers, + pkg-config, + procps, + which, + wget, + lsof, + net-snmp, + perl, +}: stdenv.mkDerivation rec { pname = "argus"; @@ -10,9 +25,23 @@ stdenv.mkDerivation rec { sha256 = "1zzf688dbbcb5z2r9v1p28rddns6znzx35nc05ygza6lp7aknkna"; }; - nativeBuildInputs = [ pkg-config bison flex ]; - buildInputs = [ libpcap cyrus_sasl tcp_wrappers ]; - propagatedBuildInputs = [ procps which wget lsof net-snmp ]; + nativeBuildInputs = [ + pkg-config + bison + flex + ]; + buildInputs = [ + libpcap + cyrus_sasl + tcp_wrappers + ]; + propagatedBuildInputs = [ + procps + which + wget + lsof + net-snmp + ]; patchPhase = '' substituteInPlace events/argus-extip.pl \ diff --git a/pkgs/by-name/ar/argyllcms/package.nix b/pkgs/by-name/ar/argyllcms/package.nix index 4c5dad4590c271..139caabe2cda93 100644 --- a/pkgs/by-name/ar/argyllcms/package.nix +++ b/pkgs/by-name/ar/argyllcms/package.nix @@ -1,7 +1,26 @@ -{ stdenv, fetchzip, jam, unzip, libX11, libXxf86vm, libXrandr, libXinerama -, libXrender, libXext, libtiff, libjpeg, libpng, libXScrnSaver, writeText -, libXdmcp, libXau, lib, openssl -, buildPackages, substituteAll, writeScript +{ + stdenv, + fetchzip, + jam, + unzip, + libX11, + libXxf86vm, + libXrandr, + libXinerama, + libXrender, + libXext, + libtiff, + libjpeg, + libpng, + libXScrnSaver, + writeText, + libXdmcp, + libXau, + lib, + openssl, + buildPackages, + substituteAll, + writeScript, }: stdenv.mkDerivation rec { @@ -15,7 +34,10 @@ stdenv.mkDerivation rec { hash = "sha256-xpbj15GzpGS0d1UjzvYiZ1nmmTjNIyv0ST2blmi7ZSk="; }; - nativeBuildInputs = [ jam unzip ]; + nativeBuildInputs = [ + jam + unzip + ]; patches = lib.optional (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) ( # Build process generates files by compiling and then invoking an executable. @@ -30,86 +52,99 @@ stdenv.mkDerivation rec { --replace "-m64" "" ''; - preConfigure = let - # The contents of this file comes from the Jamtop file from the - # root of the ArgyllCMS distribution, rewritten to pick up Nixpkgs - # library paths. When ArgyllCMS is updated, make sure that changes - # in that file is reflected here. - jamTop = writeText "argyllcms_jamtop" '' - DESTDIR = "/" ; - REFSUBDIR = "share/argyllcms" ; + preConfigure = + let + # The contents of this file comes from the Jamtop file from the + # root of the ArgyllCMS distribution, rewritten to pick up Nixpkgs + # library paths. When ArgyllCMS is updated, make sure that changes + # in that file is reflected here. + jamTop = writeText "argyllcms_jamtop" '' + DESTDIR = "/" ; + REFSUBDIR = "share/argyllcms" ; - # Keep this DESTDIR anchored to Jamtop. PREFIX is used literally - ANCHORED_PATH_VARS = DESTDIR ; + # Keep this DESTDIR anchored to Jamtop. PREFIX is used literally + ANCHORED_PATH_VARS = DESTDIR ; - # Tell standalone libraries that they are part of Argyll: - DEFINES += ARGYLLCMS ; + # Tell standalone libraries that they are part of Argyll: + DEFINES += ARGYLLCMS ; - # enable serial instruments & support - USE_SERIAL = true ; + # enable serial instruments & support + USE_SERIAL = true ; - # enable fast serial instruments & support - USE_FAST_SERIAL = true ; # (Implicit in USE_SERIAL too) + # enable fast serial instruments & support + USE_FAST_SERIAL = true ; # (Implicit in USE_SERIAL too) - # enable USB instruments & support - USE_USB = true ; + # enable USB instruments & support + USE_USB = true ; - # enable dummy Demo Instrument (only if code is available) - USE_DEMOINST = true ; + # enable dummy Demo Instrument (only if code is available) + USE_DEMOINST = true ; - # enable Video Test Patch Generator and 3DLUT device support - # (V2.0.0 and above) - USE_VTPGLUT = false ; + # enable Video Test Patch Generator and 3DLUT device support + # (V2.0.0 and above) + USE_VTPGLUT = false ; - # enable Printer device support - USE_PRINTER = false ; + # enable Printer device support + USE_PRINTER = false ; - # enable CMF Measurement device and accessory support (if present) - USE_CMFM = false ; + # enable CMF Measurement device and accessory support (if present) + USE_CMFM = false ; - # Use ArgyllCMS version of libusb (deprecated - don't use) - USE_LIBUSB = false ; + # Use ArgyllCMS version of libusb (deprecated - don't use) + USE_LIBUSB = false ; - # Compile in graph plotting code (Not fully implemented) - USE_PLOT = true ; # [true] + # Compile in graph plotting code (Not fully implemented) + USE_PLOT = true ; # [true] - JPEGLIB = ; - JPEGINC = ; - HAVE_JPEG = true ; + JPEGLIB = ; + JPEGINC = ; + HAVE_JPEG = true ; - TIFFLIB = ; - TIFFINC = ; - HAVE_TIFF = true ; + TIFFLIB = ; + TIFFINC = ; + HAVE_TIFF = true ; - PNGLIB = ; - PNGINC = ; - HAVE_PNG = true ; + PNGLIB = ; + PNGINC = ; + HAVE_PNG = true ; - ZLIB = ; - ZINC = ; - HAVE_Z = true ; + ZLIB = ; + ZINC = ; + HAVE_Z = true ; - SSLLIB = ; - SSLINC = ; - HAVE_SSL = true ; + SSLLIB = ; + SSLINC = ; + HAVE_SSL = true ; - LINKFLAGS += - ${lib.concatStringsSep " " (map (x: "-L${x}/lib") buildInputs)} - -lrt -lX11 -lXext -lXxf86vm -lXinerama -lXrandr -lXau -lXdmcp -lXss - -ljpeg -ltiff -lpng -lssl ; - ''; - in '' - cp ${jamTop} Jamtop - substituteInPlace Makefile --replace "-j 3" "-j $NIX_BUILD_CORES" - # Remove tiff, jpg and png to be sure the nixpkgs-provided ones are used - rm -rf tiff jpg png + LINKFLAGS += + ${lib.concatStringsSep " " (map (x: "-L${x}/lib") buildInputs)} + -lrt -lX11 -lXext -lXxf86vm -lXinerama -lXrandr -lXau -lXdmcp -lXss + -ljpeg -ltiff -lpng -lssl ; + ''; + in + '' + cp ${jamTop} Jamtop + substituteInPlace Makefile --replace "-j 3" "-j $NIX_BUILD_CORES" + # Remove tiff, jpg and png to be sure the nixpkgs-provided ones are used + rm -rf tiff jpg png - export AR="$AR rusc" - ''; + export AR="$AR rusc" + ''; buildInputs = [ - libtiff libjpeg libpng libX11 libXxf86vm libXrandr libXinerama libXext - libXrender libXScrnSaver libXdmcp libXau openssl + libtiff + libjpeg + libpng + libX11 + libXxf86vm + libXrandr + libXinerama + libXext + libXrender + libXScrnSaver + libXdmcp + libXau + openssl ]; buildFlags = [ "all" ]; diff --git a/pkgs/by-name/ar/ariang/package.nix b/pkgs/by-name/ar/ariang/package.nix index 4afff3dcd06329..7e892ed82abc35 100644 --- a/pkgs/by-name/ar/ariang/package.nix +++ b/pkgs/by-name/ar/ariang/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildNpmPackage -, nix-update-script +{ + lib, + fetchFromGitHub, + buildNpmPackage, + nix-update-script, }: buildNpmPackage rec { @@ -28,7 +29,7 @@ buildNpmPackage rec { runHook postInstall ''; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = with lib; { description = "Modern web frontend making aria2 easier to use"; diff --git a/pkgs/by-name/ar/ario/package.nix b/pkgs/by-name/ar/ario/package.nix index cf4065a8e9d15e..f53ba3356b7536 100644 --- a/pkgs/by-name/ar/ario/package.nix +++ b/pkgs/by-name/ar/ario/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, pkg-config -, intltool -, avahi -, curl -, dbus-glib -, gettext -, gtk3 -, libmpdclient -, libsoup_2_4 -, libxml2 -, taglib -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + intltool, + avahi, + curl, + dbus-glib, + gettext, + gtk3, + libmpdclient, + libsoup_2_4, + libxml2, + taglib, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ar/arion/package.nix b/pkgs/by-name/ar/arion/package.nix index 1f4c717accd609..7cb643d7286775 100644 --- a/pkgs/by-name/ar/arion/package.nix +++ b/pkgs/by-name/ar/arion/package.nix @@ -1,40 +1,36 @@ -{ pkgs -, lib -, haskellPackages -, haskell -, runCommand -, buildPackages +{ + pkgs, + lib, + haskellPackages, + haskell, + runCommand, + buildPackages, }: let - /* This derivation builds the arion tool. + /* + This derivation builds the arion tool. - It is based on the arion-compose Haskell package, but adapted and extended to - - have the correct name - - have a smaller closure size - - have functions to use Arion from inside Nix: arion.eval and arion.build - - make it self-contained by including docker-compose - */ - arion = - (justStaticExecutables ( - overrideCabal - cabalOverrides - arion-compose - ) - ).overrideAttrs (o: { - # Patch away the arion-compose name. Unlike the Haskell library, the program - # is called arion (arion was already taken on hackage). - pname = "arion"; - }); + It is based on the arion-compose Haskell package, but adapted and extended to + - have the correct name + - have a smaller closure size + - have functions to use Arion from inside Nix: arion.eval and arion.build + - make it self-contained by including docker-compose + */ + arion = (justStaticExecutables (overrideCabal cabalOverrides arion-compose)).overrideAttrs (o: { + # Patch away the arion-compose name. Unlike the Haskell library, the program + # is called arion (arion was already taken on hackage). + pname = "arion"; + }); inherit (haskell.lib.compose) justStaticExecutables overrideCabal; inherit (haskellPackages) arion-compose; cabalOverrides = o: { - buildTools = (o.buildTools or []) ++ [buildPackages.makeWrapper]; - passthru = (o.passthru or {}) // { + buildTools = (o.buildTools or [ ]) ++ [ buildPackages.makeWrapper ]; + passthru = (o.passthru or { }) // { inherit eval build; }; src = arion-compose.src; @@ -49,38 +45,46 @@ let # feature, but rather to make the program more robustly self- # contained. - postInstall = o.postInstall or "" + '' - mkdir -p $out/libexec - mv $out/bin/arion $out/libexec - makeWrapper $out/libexec/arion $out/bin/arion \ - --unset PYTHONPATH \ - --prefix PATH : ${lib.makeBinPath [ pkgs.docker-compose ]} \ - ; - ''; + postInstall = + o.postInstall or "" + + '' + mkdir -p $out/libexec + mv $out/bin/arion $out/libexec + makeWrapper $out/libexec/arion $out/bin/arion \ + --unset PYTHONPATH \ + --prefix PATH : ${lib.makeBinPath [ pkgs.docker-compose ]} \ + ; + ''; }; # Unpacked sources for evaluation by `eval` - srcUnpacked = runCommand "arion-src" {} - "mkdir $out; tar -C $out --strip-components=1 -xf ${arion-compose.src}"; + srcUnpacked = + runCommand "arion-src" { } + "mkdir $out; tar -C $out --strip-components=1 -xf ${arion-compose.src}"; - /* Function for evaluating a composition + /* + Function for evaluating a composition - Re-uses this Nixpkgs evaluation instead of `arion-pkgs.nix`. + Re-uses this Nixpkgs evaluation instead of `arion-pkgs.nix`. - Returns the module system's `config` and `options` variables. - */ - eval = args@{...}: - import (srcUnpacked + "/src/nix/eval-composition.nix") - ({ inherit pkgs; } // args); + Returns the module system's `config` and `options` variables. + */ + eval = + args@{ ... }: import (srcUnpacked + "/src/nix/eval-composition.nix") ({ inherit pkgs; } // args); - /* Function to derivation of the docker compose yaml file + /* + Function to derivation of the docker compose yaml file NOTE: The output will change: https://github.com/hercules-ci/arion/issues/82 This function is particularly useful on CI, although the references to image tarballs may not always be desirable. - */ - build = args@{...}: - let composition = eval args; - in composition.config.out.dockerComposeYaml; + */ + build = + args@{ ... }: + let + composition = eval args; + in + composition.config.out.dockerComposeYaml; -in arion +in +arion diff --git a/pkgs/by-name/ar/arjun-cnf/package.nix b/pkgs/by-name/ar/arjun-cnf/package.nix index 48e18272fda583..b257a607c94c8e 100644 --- a/pkgs/by-name/ar/arjun-cnf/package.nix +++ b/pkgs/by-name/ar/arjun-cnf/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, cryptominisat -, boost -, louvain-community -, lib +{ + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + cryptominisat, + boost, + louvain-community, + lib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ar/arjun/package.nix b/pkgs/by-name/ar/arjun/package.nix index 685195c91d4297..4c9ffe2fd9ccc8 100644 --- a/pkgs/by-name/ar/arjun/package.nix +++ b/pkgs/by-name/ar/arjun/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ar/arkpandora_ttf/package.nix b/pkgs/by-name/ar/arkpandora_ttf/package.nix index 81a175b944b84f..177f98237f8c8d 100644 --- a/pkgs/by-name/ar/arkpandora_ttf/package.nix +++ b/pkgs/by-name/ar/arkpandora_ttf/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "arkpandora"; diff --git a/pkgs/by-name/ar/armadillo/package.nix b/pkgs/by-name/ar/armadillo/package.nix index 8ec47c8681b7d0..1dd48c2642a61a 100644 --- a/pkgs/by-name/ar/armadillo/package.nix +++ b/pkgs/by-name/ar/armadillo/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, cmake, blas, lapack, superlu, hdf5 }: +{ + lib, + stdenv, + fetchurl, + cmake, + blas, + lapack, + superlu, + hdf5, +}: stdenv.mkDerivation rec { pname = "armadillo"; @@ -10,7 +19,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ blas lapack superlu hdf5 ]; + buildInputs = [ + blas + lapack + superlu + hdf5 + ]; cmakeFlags = [ "-DLAPACK_LIBRARY=${lapack}/lib/liblapack${stdenv.hostPlatform.extensions.sharedLibrary}" @@ -24,6 +38,9 @@ stdenv.mkDerivation rec { homepage = "https://arma.sourceforge.net"; license = licenses.asl20; platforms = platforms.unix; - maintainers = with maintainers; [ juliendehos knedlsepp ]; + maintainers = with maintainers; [ + juliendehos + knedlsepp + ]; }; } diff --git a/pkgs/by-name/ar/armbian-firmware/package.nix b/pkgs/by-name/ar/armbian-firmware/package.nix index 6e97c5908871ee..fbd066cc68cc82 100644 --- a/pkgs/by-name/ar/armbian-firmware/package.nix +++ b/pkgs/by-name/ar/armbian-firmware/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchFromGitHub }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "armbian-firmware"; version = "unstable-2023-09-16"; diff --git a/pkgs/by-name/ar/armitage/package.nix b/pkgs/by-name/ar/armitage/package.nix index a77d9bb9e08abb..de374059dfb2df 100644 --- a/pkgs/by-name/ar/armitage/package.nix +++ b/pkgs/by-name/ar/armitage/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitHub -, jdk11 -, gradle_8 -, metasploit -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, writeDarwinBundle +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + jdk11, + gradle_8, + metasploit, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + writeDarwinBundle, }: let @@ -52,7 +53,12 @@ let in stdenv.mkDerivation (finalAttrs: { - inherit pname version src patches; + inherit + pname + version + src + patches + ; desktopItems = [ (makeDesktopItem { @@ -61,19 +67,24 @@ stdenv.mkDerivation (finalAttrs: { exec = "armitage"; icon = "armitage"; comment = finalAttrs.meta.description; - categories = [ "Network" "Security" ]; + categories = [ + "Network" + "Security" + ]; startupNotify = false; }) ]; - nativeBuildInputs = [ - jdk11 - gradle - makeWrapper - copyDesktopItems - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - writeDarwinBundle - ]; + nativeBuildInputs = + [ + jdk11 + gradle + makeWrapper + copyDesktopItems + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + writeDarwinBundle + ]; mitmCache = gradle.fetchDeps { inherit pname; @@ -92,13 +103,23 @@ stdenv.mkDerivation (finalAttrs: { substituteInPlace $out/bin/armitage \ --replace-fail "armitage.jar" "$JAR" wrapProgram $out/bin/armitage \ - --prefix PATH : "${lib.makeBinPath [ jdk11 metasploit ]}" + --prefix PATH : "${ + lib.makeBinPath [ + jdk11 + metasploit + ] + }" install -Dm755 dist/unix/teamserver $out/bin/teamserver substituteInPlace $out/bin/teamserver \ --replace-fail "armitage.jar" "$JAR" wrapProgram $out/bin/teamserver \ - --prefix PATH : "${lib.makeBinPath [ jdk11 metasploit ]}" + --prefix PATH : "${ + lib.makeBinPath [ + jdk11 + metasploit + ] + }" install -Dm444 dist/unix/armitage-logo.png $out/share/pixmaps/armitage.png ${lib.optionalString stdenv.hostPlatform.isDarwin '' diff --git a/pkgs/by-name/ar/arp-scan/package.nix b/pkgs/by-name/ar/arp-scan/package.nix index 35d52859838124..3f41678c5b21c9 100644 --- a/pkgs/by-name/ar/arp-scan/package.nix +++ b/pkgs/by-name/ar/arp-scan/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libpcap, makeWrapper, perlPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libpcap, + makeWrapper, + perlPackages, +}: stdenv.mkDerivation rec { pname = "arp-scan"; @@ -23,8 +31,14 @@ stdenv.mkDerivation rec { URI ]; - nativeBuildInputs = [ autoreconfHook makeWrapper ]; - buildInputs = [ perlPackages.perl libpcap ]; + nativeBuildInputs = [ + autoreconfHook + makeWrapper + ]; + buildInputs = [ + perlPackages.perl + libpcap + ]; postInstall = '' for binary in get-{oui,iab}; do @@ -41,7 +55,11 @@ stdenv.mkDerivation rec { homepage = "https://github.com/royhills/arp-scan/wiki/arp-scan-User-Guide"; license = licenses.gpl3; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ bjornfor mikoim r-burns ]; + maintainers = with maintainers; [ + bjornfor + mikoim + r-burns + ]; mainProgram = "arp-scan"; }; } diff --git a/pkgs/by-name/ar/arpa2cm/package.nix b/pkgs/by-name/ar/arpa2cm/package.nix index 7951c701347435..e9b1f6cb26f85d 100644 --- a/pkgs/by-name/ar/arpa2cm/package.nix +++ b/pkgs/by-name/ar/arpa2cm/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, cmake }: +{ + lib, + stdenv, + fetchFromGitLab, + cmake, +}: stdenv.mkDerivation rec { pname = "arpa2cm"; @@ -28,6 +33,9 @@ stdenv.mkDerivation rec { ''; homepage = "https://gitlab.com/arpa2/arpa2cm"; license = licenses.bsd2; - maintainers = with maintainers; [ leenaars fufexan ]; + maintainers = with maintainers; [ + leenaars + fufexan + ]; }; } diff --git a/pkgs/by-name/ar/arping/package.nix b/pkgs/by-name/ar/arping/package.nix index baa1b1a98ad459..2b78466c6dbd81 100644 --- a/pkgs/by-name/ar/arping/package.nix +++ b/pkgs/by-name/ar/arping/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, libnet -, libpcap +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libnet, + libpcap, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ar/arpoison/package.nix b/pkgs/by-name/ar/arpoison/package.nix index 347f2bf3ea6fcf..5b6ec393016c85 100644 --- a/pkgs/by-name/ar/arpoison/package.nix +++ b/pkgs/by-name/ar/arpoison/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchzip, libnet }: +{ + lib, + stdenv, + fetchzip, + libnet, +}: stdenv.mkDerivation rec { pname = "arpoison"; diff --git a/pkgs/by-name/ar/arrow-cpp/package.nix b/pkgs/by-name/ar/arrow-cpp/package.nix index 81b230d091798f..e972bf1d308089 100644 --- a/pkgs/by-name/ar/arrow-cpp/package.nix +++ b/pkgs/by-name/ar/arrow-cpp/package.nix @@ -262,11 +262,14 @@ stdenv.mkDerivation (finalAttrs: { __darwinAllowLocalNetworking = true; - nativeInstallCheckInputs = [ - perl - which - sqlite - ] ++ lib.optionals enableS3 [ minio ] ++ lib.optionals enableFlight [ python3 ]; + nativeInstallCheckInputs = + [ + perl + which + sqlite + ] + ++ lib.optionals enableS3 [ minio ] + ++ lib.optionals enableFlight [ python3 ]; installCheckPhase = let diff --git a/pkgs/by-name/ar/arsenal/package.nix b/pkgs/by-name/ar/arsenal/package.nix index 62dd9a59866893..a25e9aa232bc18 100644 --- a/pkgs/by-name/ar/arsenal/package.nix +++ b/pkgs/by-name/ar/arsenal/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ar/art/package.nix b/pkgs/by-name/ar/art/package.nix index 854fcaecce4615..dc0e3a7a2aeb02 100644 --- a/pkgs/by-name/ar/art/package.nix +++ b/pkgs/by-name/ar/art/package.nix @@ -1,40 +1,41 @@ -{ lib -, stdenv -, fetchFromBitbucket -, cmake -, pkg-config -, util-linux -, libselinux -, libsepol -, libthai -, libdatrie -, lerc -, libxkbcommon -, libepoxy -, libXtst -, wrapGAppsHook3 -, pixman -, libpthreadstubs -, gtkmm3 -, libXau -, libXdmcp -, lcms2 -, libraw -, libiptcdata -, fftw -, expat -, pcre2 -, libsigcxx -, lensfun -, librsvg -, libcanberra-gtk3 -, exiv2 -, exiftool -, mimalloc -, openexr_3 -, ilmbase -, opencolorio -, color-transformation-language +{ + lib, + stdenv, + fetchFromBitbucket, + cmake, + pkg-config, + util-linux, + libselinux, + libsepol, + libthai, + libdatrie, + lerc, + libxkbcommon, + libepoxy, + libXtst, + wrapGAppsHook3, + pixman, + libpthreadstubs, + gtkmm3, + libXau, + libXdmcp, + lcms2, + libraw, + libiptcdata, + fftw, + expat, + pcre2, + libsigcxx, + lensfun, + librsvg, + libcanberra-gtk3, + exiv2, + exiftool, + mimalloc, + openexr_3, + ilmbase, + opencolorio, + color-transformation-language, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ar/artem/package.nix b/pkgs/by-name/ar/artem/package.nix index 8f6d27b176a3cb..a2fbf10f4dd655 100644 --- a/pkgs/by-name/ar/artem/package.nix +++ b/pkgs/by-name/ar/artem/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ar/artha/package.nix b/pkgs/by-name/ar/artha/package.nix index e3f42c153ebb72..6e106ce2880ac2 100644 --- a/pkgs/by-name/ar/artha/package.nix +++ b/pkgs/by-name/ar/artha/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, autoreconfHook, fetchurl, dbus-glib, gtk2, pkg-config, wordnet }: +{ + lib, + stdenv, + autoreconfHook, + fetchurl, + dbus-glib, + gtk2, + pkg-config, + wordnet, +}: stdenv.mkDerivation rec { pname = "artha"; @@ -9,8 +18,15 @@ stdenv.mkDerivation rec { sha256 = "034r7vfk5y7705k068cdlq52ikp6ip10w6047a5zjdakbn55c3as"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ dbus-glib gtk2 wordnet ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + dbus-glib + gtk2 + wordnet + ]; meta = with lib; { description = "Offline thesaurus based on WordNet"; diff --git a/pkgs/by-name/ar/artim-dark/package.nix b/pkgs/by-name/ar/artim-dark/package.nix index 9485f46b19a986..d8d1a79863a10c 100644 --- a/pkgs/by-name/ar/artim-dark/package.nix +++ b/pkgs/by-name/ar/artim-dark/package.nix @@ -1,12 +1,16 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: -stdenvNoCC.mkDerivation rec{ +stdenvNoCC.mkDerivation rec { pname = "artim-dark"; version = "unstable-2021-12-29"; src = fetchFromGitHub { - owner="Mrcuve0"; - repo="Aritim-Dark"; + owner = "Mrcuve0"; + repo = "Aritim-Dark"; rev = "99cd330a1ab4814260e28f15431e3338a1103668"; hash = "sha256-xGnw5KpXbVyDdTuAkav1Hec6bitpZdPzZk0xv7WHTdY="; }; diff --git a/pkgs/by-name/ar/artyFX/package.nix b/pkgs/by-name/ar/artyFX/package.nix index e7c909c966378f..79e2ebeed923a7 100644 --- a/pkgs/by-name/ar/artyFX/package.nix +++ b/pkgs/by-name/ar/artyFX/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchFromGitHub , cairomm, cmake, libjack2, libpthreadstubs, libXdmcp, libxshmfence, libsndfile, lv2, ntk, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + cairomm, + cmake, + libjack2, + libpthreadstubs, + libXdmcp, + libxshmfence, + libsndfile, + lv2, + ntk, + pkg-config, +}: stdenv.mkDerivation rec { pname = "artyFX"; @@ -11,8 +25,20 @@ stdenv.mkDerivation rec { hash = "sha256-GD9nwXdXSJX5OvAMxEAnngkvRW+E1jrNfWXK122bsTM="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ cairomm libjack2 libpthreadstubs libXdmcp libxshmfence libsndfile lv2 ntk ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + cairomm + libjack2 + libpthreadstubs + libXdmcp + libxshmfence + libsndfile + lv2 + ntk + ]; meta = with lib; { homepage = "http://openavproductions.com/artyfx/"; diff --git a/pkgs/by-name/ar/arubaotp-seed-extractor/package.nix b/pkgs/by-name/ar/arubaotp-seed-extractor/package.nix index cd13f891cecc75..e1a9e6d187acd4 100644 --- a/pkgs/by-name/ar/arubaotp-seed-extractor/package.nix +++ b/pkgs/by-name/ar/arubaotp-seed-extractor/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication { diff --git a/pkgs/by-name/ar/arxiv-latex-cleaner/package.nix b/pkgs/by-name/ar/arxiv-latex-cleaner/package.nix index 1351611e7e7be6..b9dbbb9f9a1f9d 100644 --- a/pkgs/by-name/ar/arxiv-latex-cleaner/package.nix +++ b/pkgs/by-name/ar/arxiv-latex-cleaner/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, python3Packages -, fetchFromGitHub +{ + lib, + python3, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { pname = "arxiv-latex-cleaner"; diff --git a/pkgs/by-name/as/as-tree/package.nix b/pkgs/by-name/as/as-tree/package.nix index 7a8ec483064283..a3c1502a73ca39 100644 --- a/pkgs/by-name/as/as-tree/package.nix +++ b/pkgs/by-name/as/as-tree/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "as-tree"; diff --git a/pkgs/by-name/as/as31/package.nix b/pkgs/by-name/as/as31/package.nix index 3f7cc35e6d97a0..83952f68d1bfd6 100644 --- a/pkgs/by-name/as/as31/package.nix +++ b/pkgs/by-name/as/as31/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, bison +{ + lib, + stdenv, + fetchurl, + bison, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/as/asahi-bless/package.nix b/pkgs/by-name/as/asahi-bless/package.nix index deacd739318fe4..5d136975cc7dec 100644 --- a/pkgs/by-name/as/asahi-bless/package.nix +++ b/pkgs/by-name/as/asahi-bless/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchCrate -, rustPlatform +{ + lib, + fetchCrate, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/as/asahi-btsync/package.nix b/pkgs/by-name/as/asahi-btsync/package.nix index f776f86a2fc212..1ee528638de178 100644 --- a/pkgs/by-name/as/asahi-btsync/package.nix +++ b/pkgs/by-name/as/asahi-btsync/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchCrate -, rustPlatform +{ + lib, + fetchCrate, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/as/asahi-nvram/package.nix b/pkgs/by-name/as/asahi-nvram/package.nix index 4226a4fe6a5fca..e3cc5b1569b473 100644 --- a/pkgs/by-name/as/asahi-nvram/package.nix +++ b/pkgs/by-name/as/asahi-nvram/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchCrate -, rustPlatform +{ + lib, + fetchCrate, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/as/asahi-wifisync/package.nix b/pkgs/by-name/as/asahi-wifisync/package.nix index 5a0b9c87219da6..23b3ac4f9fb816 100644 --- a/pkgs/by-name/as/asahi-wifisync/package.nix +++ b/pkgs/by-name/as/asahi-wifisync/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchCrate -, rustPlatform +{ + lib, + fetchCrate, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/as/asak/package.nix b/pkgs/by-name/as/asak/package.nix index cd6fd83de9d8cb..07dcb498053ebb 100644 --- a/pkgs/by-name/as/asak/package.nix +++ b/pkgs/by-name/as/asak/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, alsa-lib -, libjack2 +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + alsa-lib, + libjack2, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ alsa-lib libjack2 ]; + buildInputs = [ + alsa-lib + libjack2 + ]; # There is no tests doCheck = false; diff --git a/pkgs/by-name/as/asap/package.nix b/pkgs/by-name/as/asap/package.nix index 7f7b5d9d5fe87a..df54e9102e286d 100644 --- a/pkgs/by-name/as/asap/package.nix +++ b/pkgs/by-name/as/asap/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchzip -, SDL +{ + stdenv, + lib, + fetchzip, + SDL, }: stdenv.mkDerivation rec { @@ -13,7 +14,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-a4RUtFue5wdoGUykLRb46s4+yR/I/7DhwE1SiWPRg8s="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; buildInputs = [ SDL diff --git a/pkgs/by-name/as/asar/package.nix b/pkgs/by-name/as/asar/package.nix index 3d6c017674a82a..4cedace23d1324 100644 --- a/pkgs/by-name/as/asar/package.nix +++ b/pkgs/by-name/as/asar/package.nix @@ -1,7 +1,8 @@ -{ lib -, mkYarnPackage -, fetchFromGitHub -, fetchYarnDeps +{ + lib, + mkYarnPackage, + fetchFromGitHub, + fetchYarnDeps, }: mkYarnPackage rec { diff --git a/pkgs/by-name/as/ascii-draw/package.nix b/pkgs/by-name/as/ascii-draw/package.nix index 178952dc9f5f87..b33e4fa1df7c27 100644 --- a/pkgs/by-name/as/ascii-draw/package.nix +++ b/pkgs/by-name/as/ascii-draw/package.nix @@ -1,13 +1,14 @@ -{ lib -, python3Packages -, fetchFromGitHub -, meson -, ninja -, pkg-config -, gobject-introspection -, wrapGAppsHook4 -, desktop-file-utils -, libadwaita +{ + lib, + python3Packages, + fetchFromGitHub, + meson, + ninja, + pkg-config, + gobject-introspection, + wrapGAppsHook4, + desktop-file-utils, + libadwaita, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/as/ascii-image-converter/package.nix b/pkgs/by-name/as/ascii-image-converter/package.nix index d0ae5420bdfec2..a74990a9b548e0 100644 --- a/pkgs/by-name/as/ascii-image-converter/package.nix +++ b/pkgs/by-name/as/ascii-image-converter/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ascii-image-converter"; diff --git a/pkgs/by-name/as/ascii/package.nix b/pkgs/by-name/as/ascii/package.nix index 6a280bc516f968..699b65083a901c 100644 --- a/pkgs/by-name/as/ascii/package.nix +++ b/pkgs/by-name/as/ascii/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitLab, gitUpdater, asciidoctor }: +{ + lib, + stdenv, + fetchFromGitLab, + gitUpdater, + asciidoctor, +}: stdenv.mkDerivation (finalAttrs: { pname = "ascii"; diff --git a/pkgs/by-name/as/asciicam/package.nix b/pkgs/by-name/as/asciicam/package.nix index 6a600fec308350..39ce7f770ef01d 100644 --- a/pkgs/by-name/as/asciicam/package.nix +++ b/pkgs/by-name/as/asciicam/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule { @@ -16,7 +17,10 @@ buildGoModule { vendorHash = "sha256-Qnt1wo/yKC3Ce4JoZBIWtXyzlkh4bWz9vyE349iRsjk="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Displays your webcam on the terminal"; diff --git a/pkgs/by-name/as/asciidoctorj/package.nix b/pkgs/by-name/as/asciidoctorj/package.nix index 4fe4878faae800..db2d8d46dbf351 100644 --- a/pkgs/by-name/as/asciidoctorj/package.nix +++ b/pkgs/by-name/as/asciidoctorj/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchzip, jdk, makeWrapper }: +{ + lib, + stdenv, + fetchzip, + jdk, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "asciidoctorj"; diff --git a/pkgs/by-name/as/asciigraph/package.nix b/pkgs/by-name/as/asciigraph/package.nix index 1b88b5041f14a8..ec9151cd9a9029 100644 --- a/pkgs/by-name/as/asciigraph/package.nix +++ b/pkgs/by-name/as/asciigraph/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "asciigraph"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/guptarohit/asciigraph"; diff --git a/pkgs/by-name/as/asciinema-automation/package.nix b/pkgs/by-name/as/asciinema-automation/package.nix index 975659da7cdc86..abdaddde453d95 100644 --- a/pkgs/by-name/as/asciinema-automation/package.nix +++ b/pkgs/by-name/as/asciinema-automation/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, asciinema +{ + lib, + python3, + fetchFromGitHub, + asciinema, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/as/asciinema-scenario/package.nix b/pkgs/by-name/as/asciinema-scenario/package.nix index 99446e2ac0c224..dfa26291695086 100644 --- a/pkgs/by-name/as/asciinema-scenario/package.nix +++ b/pkgs/by-name/as/asciinema-scenario/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/as/asciiquarium/package.nix b/pkgs/by-name/as/asciiquarium/package.nix index 7ebf58e34978c0..229078c72041fc 100644 --- a/pkgs/by-name/as/asciiquarium/package.nix +++ b/pkgs/by-name/as/asciiquarium/package.nix @@ -1,7 +1,15 @@ -{ lib, stdenv, fetchurl, makeWrapper, perlPackages }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + perlPackages, +}: -let version = "1.1"; -in stdenv.mkDerivation { +let + version = "1.1"; +in +stdenv.mkDerivation { pname = "asciiquarium"; inherit version; src = fetchurl { @@ -17,7 +25,7 @@ in stdenv.mkDerivation { cp asciiquarium $out/bin chmod +x $out/bin/asciiquarium wrapProgram $out/bin/asciiquarium \ - --set PERL5LIB ${perlPackages.makeFullPerlPath [ perlPackages.TermAnimation ] } + --set PERL5LIB ${perlPackages.makeFullPerlPath [ perlPackages.TermAnimation ]} ''; meta = with lib; { @@ -26,6 +34,9 @@ in stdenv.mkDerivation { homepage = "https://robobunny.com/projects/asciiquarium/html/"; license = licenses.gpl2; platforms = platforms.unix; - maintainers = with maintainers; [ sigmasquadron utdemir ]; + maintainers = with maintainers; [ + sigmasquadron + utdemir + ]; }; } diff --git a/pkgs/by-name/as/asdf-vm/package.nix b/pkgs/by-name/as/asdf-vm/package.nix index 024d70d5c7cbf8..2c2bc6fba12194 100644 --- a/pkgs/by-name/as/asdf-vm/package.nix +++ b/pkgs/by-name/as/asdf-vm/package.nix @@ -1,41 +1,52 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper, installShellFiles, bash, curl, git, writeScript }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + installShellFiles, + bash, + curl, + git, + writeScript, +}: let asdfReshimFile = writeScript "asdf-reshim" '' -#!/usr/bin/env bash - -# asdf-vm create "shim" file like this: -# -# exec $ASDF_DIR/bin/asdf exec "node" "$@" -# -# So we should reshim all installed versions every time shell initialized, -# because $out always change - -asdfDir="''${ASDF_DIR:-$HOME/.asdf}" -asdfDataDir="''${ASDF_DATA_DIR:-$HOME/.asdf}" - -prevAsdfDirFilePath="$asdfDataDir/.nix-prev-asdf-dir-path" - -if [ -r "$prevAsdfDirFilePath" ]; then - prevAsdfDir="$(cat "$prevAsdfDirFilePath")" -else - prevAsdfDir="" -fi - -if [ "$prevAsdfDir" != "$asdfDir" ]; then - rm -rf "$asdfDataDir"/shims - "$asdfDir"/bin/asdf reshim - echo "$asdfDir" > "$prevAsdfDirFilePath" -fi + #!/usr/bin/env bash + + # asdf-vm create "shim" file like this: + # + # exec $ASDF_DIR/bin/asdf exec "node" "$@" + # + # So we should reshim all installed versions every time shell initialized, + # because $out always change + + asdfDir="''${ASDF_DIR:-$HOME/.asdf}" + asdfDataDir="''${ASDF_DATA_DIR:-$HOME/.asdf}" + + prevAsdfDirFilePath="$asdfDataDir/.nix-prev-asdf-dir-path" + + if [ -r "$prevAsdfDirFilePath" ]; then + prevAsdfDir="$(cat "$prevAsdfDirFilePath")" + else + prevAsdfDir="" + fi + + if [ "$prevAsdfDir" != "$asdfDir" ]; then + rm -rf "$asdfDataDir"/shims + "$asdfDir"/bin/asdf reshim + echo "$asdfDir" > "$prevAsdfDirFilePath" + fi ''; asdfPrepareFile = writeScript "asdf-prepare" '' -ASDF_DIR="@asdfDir@" + ASDF_DIR="@asdfDir@" -source "$ASDF_DIR/asdf.sh" -${asdfReshimFile} + source "$ASDF_DIR/asdf.sh" + ${asdfReshimFile} ''; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "asdf-vm"; version = "0.14.1"; diff --git a/pkgs/by-name/as/aseq2json/package.nix b/pkgs/by-name/as/aseq2json/package.nix index d828c808037a61..ed7705687e4a3f 100644 --- a/pkgs/by-name/as/aseq2json/package.nix +++ b/pkgs/by-name/as/aseq2json/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config, alsa-lib, glib, json-glib }: +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + alsa-lib, + glib, + json-glib, +}: stdenv.mkDerivation (finalAttrs: { pname = "aseq2json"; @@ -12,7 +20,11 @@ stdenv.mkDerivation (finalAttrs: { sourceRoot = "${finalAttrs.src.name}/aseq2json"; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ alsa-lib glib json-glib ]; + buildInputs = [ + alsa-lib + glib + json-glib + ]; installPhase = '' install -D --target-directory "$out/bin" aseq2json diff --git a/pkgs/by-name/as/ashpd-demo/package.nix b/pkgs/by-name/as/ashpd-demo/package.nix index 8c9127296b177d..d06352c70581cc 100644 --- a/pkgs/by-name/as/ashpd-demo/package.nix +++ b/pkgs/by-name/as/ashpd-demo/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitHub -, cargo -, meson -, ninja -, rustPlatform -, rustc -, pkg-config -, glib -, libshumate -, gst_all_1 -, gtk4 -, libadwaita -, pipewire -, wayland -, wrapGAppsHook4 -, desktop-file-utils +{ + stdenv, + lib, + fetchFromGitHub, + cargo, + meson, + ninja, + rustPlatform, + rustc, + pkg-config, + glib, + libshumate, + gst_all_1, + gtk4, + libadwaita, + pipewire, + wayland, + wrapGAppsHook4, + desktop-file-utils, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/as/ashuffle/package.nix b/pkgs/by-name/as/ashuffle/package.nix index 3fe5e6716bd336..e809869b43e61c 100644 --- a/pkgs/by-name/as/ashuffle/package.nix +++ b/pkgs/by-name/as/ashuffle/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, meson -, ninja -, libmpdclient -, yaml-cpp +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + meson, + ninja, + libmpdclient, + yaml-cpp, }: stdenv.mkDerivation rec { @@ -22,8 +23,16 @@ stdenv.mkDerivation rec { }; dontUseCmakeConfigure = true; - nativeBuildInputs = [ cmake pkg-config meson ninja ]; - buildInputs = [ libmpdclient yaml-cpp ]; + nativeBuildInputs = [ + cmake + pkg-config + meson + ninja + ]; + buildInputs = [ + libmpdclient + yaml-cpp + ]; mesonFlags = [ "-Dunsupported_use_system_yamlcpp=true" ]; diff --git a/pkgs/by-name/as/askalono/package.nix b/pkgs/by-name/as/askalono/package.nix index 6388be5095117e..6995995515feb7 100644 --- a/pkgs/by-name/as/askalono/package.nix +++ b/pkgs/by-name/as/askalono/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/as/asl/package.nix b/pkgs/by-name/as/asl/package.nix index f6cbe3f46b66c3..2c545e04fdd994 100644 --- a/pkgs/by-name/as/asl/package.nix +++ b/pkgs/by-name/as/asl/package.nix @@ -1,29 +1,40 @@ -{ lib -, stdenv -, fetchzip -, texliveMedium -, buildDocs ? false +{ + lib, + stdenv, + fetchzip, + texliveMedium, + buildDocs ? false, }: stdenv.mkDerivation (finalAttrs: { pname = "asl"; version = "142-bld232"; - src = let inherit (finalAttrs) pname version; in fetchzip { - name = "${pname}-${version}"; - url = "http://john.ccac.rwth-aachen.de:8000/ftp/as/source/c_version/asl-current-${version}.tar.bz2"; - hash = "sha256-Q50GzXBxFMhbt5s9OgHPNH4bdqz2hhEmTnMmKowVn2E="; - }; + src = + let + inherit (finalAttrs) pname version; + in + fetchzip { + name = "${pname}-${version}"; + url = "http://john.ccac.rwth-aachen.de:8000/ftp/as/source/c_version/asl-current-${version}.tar.bz2"; + hash = "sha256-Q50GzXBxFMhbt5s9OgHPNH4bdqz2hhEmTnMmKowVn2E="; + }; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; nativeBuildInputs = lib.optionals buildDocs [ texliveMedium ]; - postPatch = lib.optionalString (!buildDocs) '' - substituteInPlace Makefile --replace "all: binaries docs" "all: binaries" - '' + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' - substituteInPlace sysdefs.h --replace "x86_64" "aarch64" - ''; + postPatch = + lib.optionalString (!buildDocs) '' + substituteInPlace Makefile --replace "all: binaries docs" "all: binaries" + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' + substituteInPlace sysdefs.h --replace "x86_64" "aarch64" + ''; dontConfigure = true; diff --git a/pkgs/by-name/as/asmfmt/package.nix b/pkgs/by-name/as/asmfmt/package.nix index 1c22f3ea178110..598ec7fd563dac 100644 --- a/pkgs/by-name/as/asmfmt/package.nix +++ b/pkgs/by-name/as/asmfmt/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, lib -, fetchFromGitHub +{ + buildGoModule, + lib, + fetchFromGitHub, }: buildGoModule rec { @@ -20,7 +21,10 @@ buildGoModule rec { # but these binaries are outdated and are offered by other packages. subPackages = [ "cmd/asmfmt" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; # There are no tests. doCheck = false; diff --git a/pkgs/by-name/as/asmjit/package.nix b/pkgs/by-name/as/asmjit/package.nix index 7edc7c666a9c40..c8a795e959bed9 100644 --- a/pkgs/by-name/as/asmjit/package.nix +++ b/pkgs/by-name/as/asmjit/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, fetchFromGitHub -, cmake -, ninja -, lib +{ + stdenv, + fetchFromGitHub, + cmake, + ninja, + lib, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/as/asn/package.nix b/pkgs/by-name/as/asn/package.nix index 2530c3b31c474a..5d917507f9cd61 100644 --- a/pkgs/by-name/as/asn/package.nix +++ b/pkgs/by-name/as/asn/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, curl -, whois -, bind -, mtr -, jq -, ipcalc -, grepcidr -, nmap -, aha +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + curl, + whois, + bind, + mtr, + jq, + ipcalc, + grepcidr, + nmap, + aha, }: stdenv.mkDerivation rec { @@ -32,7 +33,19 @@ stdenv.mkDerivation rec { install -Dv asn "$out/bin/asn" wrapProgram $out/bin/asn \ - --prefix PATH : "${lib.makeBinPath [ curl whois bind mtr jq ipcalc grepcidr nmap aha ]}" + --prefix PATH : "${ + lib.makeBinPath [ + curl + whois + bind + mtr + jq + ipcalc + grepcidr + nmap + aha + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/as/asn1c/package.nix b/pkgs/by-name/as/asn1c/package.nix index bcaab6fae8672f..61f45133bf8f5c 100644 --- a/pkgs/by-name/as/asn1c/package.nix +++ b/pkgs/by-name/as/asn1c/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "asn1c"; @@ -9,7 +14,11 @@ stdenv.mkDerivation rec { sha256 = "1fc64g45ykmv73kdndr4zdm4wxhimhrir4rxnygxvwkych5l81w0"; }; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; buildInputs = [ perl ]; diff --git a/pkgs/by-name/as/asn1editor/package.nix b/pkgs/by-name/as/asn1editor/package.nix index 07941a7762c491..fa6c1c6bee9bc4 100644 --- a/pkgs/by-name/as/asn1editor/package.nix +++ b/pkgs/by-name/as/asn1editor/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/as/aspcud/package.nix b/pkgs/by-name/as/aspcud/package.nix index cd290d5e085e56..4c72083c2c76ae 100644 --- a/pkgs/by-name/as/aspcud/package.nix +++ b/pkgs/by-name/as/aspcud/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, boost -, catch2 -, cmake -, clingo -, re2c +{ + lib, + stdenv, + fetchFromGitHub, + boost, + catch2, + cmake, + clingo, + re2c, }: stdenv.mkDerivation rec { @@ -24,7 +25,11 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ cmake ]; - buildInputs = [ boost clingo re2c ]; + buildInputs = [ + boost + clingo + re2c + ]; cmakeFlags = [ "-DASPCUD_GRINGO_PATH=${clingo}/bin/gringo" diff --git a/pkgs/by-name/as/aspino/package.nix b/pkgs/by-name/as/aspino/package.nix index 6b0e75de806613..0352bfe6aba523 100644 --- a/pkgs/by-name/as/aspino/package.nix +++ b/pkgs/by-name/as/aspino/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, fetchFromGitHub, zlib, boost }: +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + zlib, + boost, +}: let glucose' = fetchurl { @@ -18,7 +25,10 @@ stdenv.mkDerivation { hash = "sha256-R1TpBDGdq+NQQzmzqk0wYaz2Hns3qru0AkAyFPQasPA="; }; - buildInputs = [ zlib boost ]; + buildInputs = [ + zlib + boost + ]; postPatch = '' substituteInPlace Makefile \ diff --git a/pkgs/by-name/as/assaultcube/package.nix b/pkgs/by-name/as/assaultcube/package.nix index 7164e66feebf45..ec7fc9f43e2fd6 100644 --- a/pkgs/by-name/as/assaultcube/package.nix +++ b/pkgs/by-name/as/assaultcube/package.nix @@ -1,18 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeDesktopItem -, copyDesktopItems -, openal -, pkg-config -, libogg -, libvorbis -, SDL2 -, SDL2_image -, makeWrapper -, zlib -, file -, client ? true, server ? true +{ + lib, + stdenv, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + openal, + pkg-config, + libogg, + libvorbis, + SDL2, + SDL2_image, + makeWrapper, + zlib, + file, + client ? true, + server ? true, }: stdenv.mkDerivation rec { @@ -21,7 +23,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "assaultcube"; - repo = "AC"; + repo = "AC"; rev = "v${version}"; sha256 = "0qv339zw9q5q1y7bghca03gw7z4v89sl4lbr6h3b7siy08mcwiz9"; }; @@ -32,19 +34,25 @@ stdenv.mkDerivation rec { copyDesktopItems ]; - buildInputs = [ - file - zlib - ] ++ lib.optionals client [ - openal - SDL2 - SDL2_image - libogg - libvorbis - ]; + buildInputs = + [ + file + zlib + ] + ++ lib.optionals client [ + openal + SDL2 + SDL2_image + libogg + libvorbis + ]; targets = (lib.optionalString server "server") + (lib.optionalString client " client"); - makeFlags = [ "-C source/src" "CXX=${stdenv.cc.targetPrefix}c++" targets ]; + makeFlags = [ + "-C source/src" + "CXX=${stdenv.cc.targetPrefix}c++" + targets + ]; desktopItems = [ (makeDesktopItem { @@ -52,7 +60,11 @@ stdenv.mkDerivation rec { desktopName = "AssaultCube"; comment = "A multiplayer, first-person shooter game, based on the CUBE engine. Fast, arcade gameplay."; genericName = "First-person shooter"; - categories = [ "Game" "ActionGame" "Shooter" ]; + categories = [ + "Game" + "ActionGame" + "Shooter" + ]; icon = "assaultcube"; exec = pname; }) diff --git a/pkgs/by-name/as/assemblyscript/package.nix b/pkgs/by-name/as/assemblyscript/package.nix index cb0f0cd25948e7..3faf433d4a431e 100644 --- a/pkgs/by-name/as/assemblyscript/package.nix +++ b/pkgs/by-name/as/assemblyscript/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/as/assetfinder/package.nix b/pkgs/by-name/as/assetfinder/package.nix index 46a2daa1723a18..b27ecc9e1a4b08 100644 --- a/pkgs/by-name/as/assetfinder/package.nix +++ b/pkgs/by-name/as/assetfinder/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { @@ -26,7 +27,10 @@ buildGoModule rec { mainProgram = "assetfinder"; maintainers = with maintainers; [ shard7 ]; platforms = platforms.unix; - sourceProvenance = with sourceTypes; [ fromSource binaryNativeCode ]; + sourceProvenance = with sourceTypes; [ + fromSource + binaryNativeCode + ]; license = with licenses; [ mit ]; }; } diff --git a/pkgs/by-name/as/assh/package.nix b/pkgs/by-name/as/assh/package.nix index 96672515e4d33b..f66cb33959d8f9 100644 --- a/pkgs/by-name/as/assh/package.nix +++ b/pkgs/by-name/as/assh/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, openssh -, makeWrapper -, ps +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + openssh, + makeWrapper, + ps, }: buildGoModule rec { @@ -21,7 +22,9 @@ buildGoModule rec { vendorHash = "sha256-L2Uo/jsMtxQClF1UDa7NIUbOm7BflvncNsjqGnCsPKo="; ldflags = [ - "-s" "-w" "-X moul.io/assh/v2/pkg/version.Version=${version}" + "-s" + "-w" + "-X moul.io/assh/v2/pkg/version.Version=${version}" ]; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/by-name/as/assign-lb-ip/package.nix b/pkgs/by-name/as/assign-lb-ip/package.nix index bc55112dd292ee..f3fa137a639296 100644 --- a/pkgs/by-name/as/assign-lb-ip/package.nix +++ b/pkgs/by-name/as/assign-lb-ip/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "assign-lb-ip"; @@ -16,8 +20,8 @@ buildGoModule rec { meta = with lib; { description = "Assigns loadBalancerIP address to a Kubernetes service for testing purposes"; mainProgram = "assign-lb-ip"; - homepage = "https://github.com/Nordix/assign-lb-ip"; - license = licenses.asl20; + homepage = "https://github.com/Nordix/assign-lb-ip"; + license = licenses.asl20; maintainers = [ maintainers.starcraft66 ]; }; } diff --git a/pkgs/by-name/as/assimp/package.nix b/pkgs/by-name/as/assimp/package.nix index 45eef22e69fbbc..4aaa2ed6087696 100644 --- a/pkgs/by-name/as/assimp/package.nix +++ b/pkgs/by-name/as/assimp/package.nix @@ -1,15 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, boost -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + zlib, }: stdenv.mkDerivation rec { pname = "assimp"; version = "5.4.3"; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; src = fetchFromGitHub { owner = "assimp"; @@ -19,7 +24,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ boost zlib ]; + buildInputs = [ + boost + zlib + ]; cmakeFlags = [ "-DASSIMP_BUILD_ASSIMP_TOOLS=ON" ]; diff --git a/pkgs/by-name/as/ast-grep/package.nix b/pkgs/by-name/as/ast-grep/package.nix index 0d46c85707c3a3..a56a0f8024e0dc 100644 --- a/pkgs/by-name/as/ast-grep/package.nix +++ b/pkgs/by-name/as/ast-grep/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, installShellFiles +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + installShellFiles, }: rustPlatform.buildRustPackage rec { @@ -32,19 +33,21 @@ rustPlatform.buildRustPackage rec { --zsh <($out/bin/sg completions zsh) ''; - checkFlags = [ - # disable flaky test - "--skip=test::test_load_parser_mac" + checkFlags = + [ + # disable flaky test + "--skip=test::test_load_parser_mac" - # BUG: Broke by 0.12.1 update (https://github.com/NixOS/nixpkgs/pull/257385) - # Please check if this is fixed in future updates of the package - "--skip=verify::test_case::tests::test_unmatching_id" - ] ++ lib.optionals (with stdenv.hostPlatform; (isDarwin && isx86_64) || (isLinux && isAarch64)) [ - # x86_64-darwin: source/benches/fixtures/json-mac.so\' (no such file), \'/private/tmp/nix-build-.../source/benches/fixtures/json-mac.so\' (mach-o file, but is an incompatible architecture (have \'arm64\', need \'x86_64h\' or \'x86_64\'))" }) - # aarch64-linux: /build/source/benches/fixtures/json-linux.so: cannot open shared object file: No such file or directory" - "--skip=test::test_load_parser" - "--skip=test::test_register_lang" - ]; + # BUG: Broke by 0.12.1 update (https://github.com/NixOS/nixpkgs/pull/257385) + # Please check if this is fixed in future updates of the package + "--skip=verify::test_case::tests::test_unmatching_id" + ] + ++ lib.optionals (with stdenv.hostPlatform; (isDarwin && isx86_64) || (isLinux && isAarch64)) [ + # x86_64-darwin: source/benches/fixtures/json-mac.so\' (no such file), \'/private/tmp/nix-build-.../source/benches/fixtures/json-mac.so\' (mach-o file, but is an incompatible architecture (have \'arm64\', need \'x86_64h\' or \'x86_64\'))" }) + # aarch64-linux: /build/source/benches/fixtures/json-linux.so: cannot open shared object file: No such file or directory" + "--skip=test::test_load_parser" + "--skip=test::test_register_lang" + ]; meta = with lib; { mainProgram = "sg"; @@ -52,6 +55,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://ast-grep.github.io/"; changelog = "https://github.com/ast-grep/ast-grep/blob/${src.rev}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ montchr lord-valen cafkafk ]; + maintainers = with maintainers; [ + montchr + lord-valen + cafkafk + ]; }; } diff --git a/pkgs/by-name/as/astartectl/package.nix b/pkgs/by-name/as/astartectl/package.nix index ac88b96cfab7f5..f5c5be3aad9cd6 100644 --- a/pkgs/by-name/as/astartectl/package.nix +++ b/pkgs/by-name/as/astartectl/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { pname = "astartectl"; diff --git a/pkgs/by-name/as/astc-encoder/package.nix b/pkgs/by-name/as/astc-encoder/package.nix index 1e08e063decf9a..4ece84c89c5e0c 100644 --- a/pkgs/by-name/as/astc-encoder/package.nix +++ b/pkgs/by-name/as/astc-encoder/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, simdExtensions ? null +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + simdExtensions ? null, }: let @@ -17,23 +18,31 @@ let # SIMD instruction sets to compile for. If none are specified by the user, # an appropriate one is selected based on the detected host system - isas = with stdenv.hostPlatform; - if simdExtensions != null then toList simdExtensions - else if avx2Support then [ "AVX2" ] - else if sse4_1Support then [ "SSE41" ] - else if isx86_64 then [ "SSE2" ] - else if isAarch64 then [ "NEON" ] - else [ "NONE" ]; + isas = + with stdenv.hostPlatform; + if simdExtensions != null then + toList simdExtensions + else if avx2Support then + [ "AVX2" ] + else if sse4_1Support then + [ "SSE41" ] + else if isx86_64 then + [ "SSE2" ] + else if isAarch64 then + [ "NEON" ] + else + [ "NONE" ]; # CMake Build flags for the selected ISAs. For a list of flags, see # https://github.com/ARM-software/astc-encoder/blob/main/Docs/Building.md - isaFlags = map ( isa: "-DASTCENC_ISA_${isa}=ON" ) isas; + isaFlags = map (isa: "-DASTCENC_ISA_${isa}=ON") isas; # The suffix of the binary to link as 'astcenc' - mainBinary = replaceStrings - [ "AVX2" "SSE41" "SSE2" "NEON" "NONE" "NATIVE" ] - [ "avx2" "sse4.1" "sse2" "neon" "none" "native" ] - ( head isas ); + mainBinary = + replaceStrings + [ "AVX2" "SSE41" "SSE2" "NEON" "NONE" "NATIVE" ] + [ "avx2" "sse4.1" "sse2" "neon" "none" "native" ] + (head isas); in stdenv.mkDerivation rec { diff --git a/pkgs/by-name/as/asterisk-module-sccp/package.nix b/pkgs/by-name/as/asterisk-module-sccp/package.nix index 5d60d427813781..a81ef23cca00fe 100644 --- a/pkgs/by-name/as/asterisk-module-sccp/package.nix +++ b/pkgs/by-name/as/asterisk-module-sccp/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, binutils-unwrapped, patchelf, asterisk }: +{ + lib, + stdenv, + fetchFromGitHub, + binutils-unwrapped, + patchelf, + asterisk, +}: stdenv.mkDerivation rec { pname = "asterisk-module-sccp"; version = "4.3.5"; @@ -14,7 +21,10 @@ stdenv.mkDerivation rec { configureFlags = [ "--with-asterisk=${asterisk}" ]; - installFlags = [ "DESTDIR=/build/dest" "DATAROOTDIR=/build/dest" ]; + installFlags = [ + "DESTDIR=/build/dest" + "DATAROOTDIR=/build/dest" + ]; postInstall = '' mkdir -p "$out" diff --git a/pkgs/by-name/as/astral/package.nix b/pkgs/by-name/as/astral/package.nix index 34077949b97d15..6ee623117c63f9 100644 --- a/pkgs/by-name/as/astral/package.nix +++ b/pkgs/by-name/as/astral/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, jdk8 -, jre8 -, strip-nondeterminism -, makeWrapper -, zip +{ + lib, + stdenvNoCC, + fetchFromGitHub, + jdk8, + jre8, + strip-nondeterminism, + makeWrapper, + zip, }: let @@ -74,6 +75,9 @@ stdenvNoCC.mkDerivation (finalAttrs: { binaryBytecode # source bundles dependencies as jars ]; license = licenses.asl20; - maintainers = with maintainers; [ bzizou tomasajt ]; + maintainers = with maintainers; [ + bzizou + tomasajt + ]; }; }) diff --git a/pkgs/by-name/as/astrolabe-generator/package.nix b/pkgs/by-name/as/astrolabe-generator/package.nix index 603fb8087266fe..90cb20eb005ee6 100644 --- a/pkgs/by-name/as/astrolabe-generator/package.nix +++ b/pkgs/by-name/as/astrolabe-generator/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper, unzip }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, + unzip, +}: stdenv.mkDerivation rec { pname = "astrolabe-generator"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; buildInputs = [ jre ]; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; sourceRoot = "."; installPhase = '' @@ -21,7 +31,7 @@ stdenv.mkDerivation rec { --add-flags "-jar $out/share/java/AstrolabeGenerator-${version}.jar" ''; - meta = with lib;{ + meta = with lib; { homepage = "https://www.astrolabeproject.com"; description = "Java-based tool for generating EPS files for constructing astrolabes and related tools"; sourceProvenance = with sourceTypes; [ binaryBytecode ]; diff --git a/pkgs/by-name/as/astrolog/package.nix b/pkgs/by-name/as/astrolog/package.nix index a2e2e0f02cf6d9..75bb669a0d9a62 100644 --- a/pkgs/by-name/as/astrolog/package.nix +++ b/pkgs/by-name/as/astrolog/package.nix @@ -1,7 +1,12 @@ -{ lib, stdenv, fetchzip, fetchurl, xorg -, withBigAtlas ? true -, withEphemeris ? true -, withMoonsEphemeris ? true +{ + lib, + stdenv, + fetchzip, + fetchurl, + xorg, + withBigAtlas ? true, + withEphemeris ? true, + withMoonsEphemeris ? true, }: stdenv.mkDerivation { pname = "astrolog"; @@ -22,37 +27,38 @@ stdenv.mkDerivation { env.NIX_CFLAGS_COMPILE = "-Wno-format-security"; installPhase = - let - ephemeris = fetchzip { - url = "http://astrolog.org/ftp/ephem/astephem.zip"; - sha256 = "1mwvpvfk3lxjcc79zvwl4ypqzgqzipnc01cjldxrmx56xkc35zn7"; - stripRoot = false; - }; - moonsEphemeris = fetchzip { - url = "https://www.astrolog.org/ftp/ephem/moons/sepm.zip"; - sha256 = "0labcidm8mrwvww93nwpp5738m9ff9q48cqzbgd18xny1jf6f8xd"; - stripRoot = false; - }; - atlas = fetchurl { - url = "http://astrolog.org/ftp/atlas/atlasbig.as"; - sha256 = "001bmqyldsbk4bdliqfl4a9ydrh1ff13wccvfniwaxlmvkridx2q"; - }; - in '' - mkdir -p $out/bin $out/astrolog - cp *.as $out/astrolog - install astrolog $out/bin - ${lib.optionalString withBigAtlas "cp ${atlas} $out/astrolog/atlas.as"} - ${lib.optionalString withEphemeris '' - sed -i "/-Yi1/s#\".*\"#\"$out/ephemeris\"#" $out/astrolog/astrolog.as - mkdir -p $out/ephemeris - cp -r ${ephemeris}/*.se1 $out/ephemeris - ''} - ${lib.optionalString withMoonsEphemeris '' - sed -i "/-Yi1/s#\".*\"#\"$out/ephemeris\"#" $out/astrolog/astrolog.as - mkdir -p $out/ephemeris - cp -r ${moonsEphemeris}/*.se1 $out/ephemeris - ''} - ''; + let + ephemeris = fetchzip { + url = "http://astrolog.org/ftp/ephem/astephem.zip"; + sha256 = "1mwvpvfk3lxjcc79zvwl4ypqzgqzipnc01cjldxrmx56xkc35zn7"; + stripRoot = false; + }; + moonsEphemeris = fetchzip { + url = "https://www.astrolog.org/ftp/ephem/moons/sepm.zip"; + sha256 = "0labcidm8mrwvww93nwpp5738m9ff9q48cqzbgd18xny1jf6f8xd"; + stripRoot = false; + }; + atlas = fetchurl { + url = "http://astrolog.org/ftp/atlas/atlasbig.as"; + sha256 = "001bmqyldsbk4bdliqfl4a9ydrh1ff13wccvfniwaxlmvkridx2q"; + }; + in + '' + mkdir -p $out/bin $out/astrolog + cp *.as $out/astrolog + install astrolog $out/bin + ${lib.optionalString withBigAtlas "cp ${atlas} $out/astrolog/atlas.as"} + ${lib.optionalString withEphemeris '' + sed -i "/-Yi1/s#\".*\"#\"$out/ephemeris\"#" $out/astrolog/astrolog.as + mkdir -p $out/ephemeris + cp -r ${ephemeris}/*.se1 $out/ephemeris + ''} + ${lib.optionalString withMoonsEphemeris '' + sed -i "/-Yi1/s#\".*\"#\"$out/ephemeris\"#" $out/astrolog/astrolog.as + mkdir -p $out/ephemeris + cp -r ${moonsEphemeris}/*.se1 $out/ephemeris + ''} + ''; meta = with lib; { maintainers = [ maintainers.kmein ]; diff --git a/pkgs/by-name/as/astromenace/package.nix b/pkgs/by-name/as/astromenace/package.nix index 54fbf7a1c8b0c1..fcfb91b8eae5b9 100644 --- a/pkgs/by-name/as/astromenace/package.nix +++ b/pkgs/by-name/as/astromenace/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, ninja -, makeWrapper -, xorg -, libGLU -, libGL -, SDL2 -, openal -, fontconfig -, freealut -, freetype -, libogg -, libvorbis -, runtimeShell +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + ninja, + makeWrapper, + xorg, + libGLU, + libGL, + SDL2, + openal, + fontconfig, + freealut, + freetype, + libogg, + libvorbis, + runtimeShell, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/as/astronomer/package.nix b/pkgs/by-name/as/astronomer/package.nix index 77b30afa05290a..7df5c42af4e4df 100644 --- a/pkgs/by-name/as/astronomer/package.nix +++ b/pkgs/by-name/as/astronomer/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-EOtpZPIrAVMPIZGnkZoNs7ovaR7Ts3dJsFLXClIoNVI="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Tool to detect illegitimate stars from bot accounts on GitHub projects"; diff --git a/pkgs/by-name/as/asunder/package.nix b/pkgs/by-name/as/asunder/package.nix index 2c734acafdcdb9..eedbdef3393f34 100644 --- a/pkgs/by-name/as/asunder/package.nix +++ b/pkgs/by-name/as/asunder/package.nix @@ -1,11 +1,26 @@ -{ lib, stdenv, fetchurl, makeWrapper, gtk2, libcddb, intltool, pkg-config, cdparanoia -, mp3Support ? false, lame -, oggSupport ? true, vorbis-tools -, flacSupport ? true, flac -, opusSupport ? false, opusTools -, wavpackSupport ? false, wavpack -#, musepackSupport ? false, TODO: mpcenc -, monkeysAudioSupport ? false, monkeysAudio +{ + lib, + stdenv, + fetchurl, + makeWrapper, + gtk2, + libcddb, + intltool, + pkg-config, + cdparanoia, + mp3Support ? false, + lame, + oggSupport ? true, + vorbis-tools, + flacSupport ? true, + flac, + opusSupport ? false, + opusTools, + wavpackSupport ? false, + wavpack, + #, musepackSupport ? false, TODO: mpcenc + monkeysAudioSupport ? false, + monkeysAudio, #, aacSupport ? false, TODO: neroAacEnc }: @@ -17,17 +32,24 @@ stdenv.mkDerivation rec { sha256 = "sha256-iGji4bl7ZofIAOf2EiYqMWu4V+3TmIN2jOYottJTN2s="; }; - nativeBuildInputs = [ intltool makeWrapper pkg-config ]; - buildInputs = [ gtk2 libcddb ]; + nativeBuildInputs = [ + intltool + makeWrapper + pkg-config + ]; + buildInputs = [ + gtk2 + libcddb + ]; runtimeDeps = - lib.optional mp3Support lame ++ - lib.optional oggSupport vorbis-tools ++ - lib.optional flacSupport flac ++ - lib.optional opusSupport opusTools ++ - lib.optional wavpackSupport wavpack ++ - lib.optional monkeysAudioSupport monkeysAudio ++ - [ cdparanoia ]; + lib.optional mp3Support lame + ++ lib.optional oggSupport vorbis-tools + ++ lib.optional flacSupport flac + ++ lib.optional opusSupport opusTools + ++ lib.optional wavpackSupport wavpack + ++ lib.optional monkeysAudioSupport monkeysAudio + ++ [ cdparanoia ]; postInstall = '' wrapProgram "$out/bin/asunder" \ diff --git a/pkgs/by-name/as/asusctl/package.nix b/pkgs/by-name/as/asusctl/package.nix index ab160092f1564a..0ea6dad0640e6e 100644 --- a/pkgs/by-name/as/asusctl/package.nix +++ b/pkgs/by-name/as/asusctl/package.nix @@ -1,17 +1,18 @@ -{ lib -, rustPlatform -, fetchFromGitLab -, systemd -, coreutils -, gnugrep -, pkg-config -, fontconfig -, libGL -, libinput -, libxkbcommon -, mesa -, seatd -, wayland +{ + lib, + rustPlatform, + fetchFromGitLab, + systemd, + coreutils, + gnugrep, + pkg-config, + fontconfig, + libGL, + libinput, + libxkbcommon, + mesa, + seatd, + wayland, }: rustPlatform.buildRustPackage rec { @@ -93,6 +94,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://gitlab.com/asus-linux/asusctl"; license = licenses.mpl20; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ k900 aacebedo ]; + maintainers = with maintainers; [ + k900 + aacebedo + ]; }; } diff --git a/pkgs/by-name/as/async/package.nix b/pkgs/by-name/as/async/package.nix index dd2ea5205335c0..8cd52c38cb5b71 100644 --- a/pkgs/by-name/as/async/package.nix +++ b/pkgs/by-name/as/async/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "async"; @@ -21,7 +25,7 @@ rustPlatform.buildRustPackage rec { able to quickly parallelize shell scripts with minimal changes. It was inspired by GNU Parallel, with the main difference being that async retains state between commands by running a server in the background. - ''; + ''; homepage = "https://github.com/ctbur/async"; license = licenses.gpl3Plus; maintainers = with maintainers; [ minijackson ]; diff --git a/pkgs/by-name/at/at-spi2-core/package.nix b/pkgs/by-name/at/at-spi2-core/package.nix index 709ea738e46b39..97486d5bd03f40 100644 --- a/pkgs/by-name/at/at-spi2-core/package.nix +++ b/pkgs/by-name/at/at-spi2-core/package.nix @@ -1,32 +1,38 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, gobject-introspection -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, gsettings-desktop-schemas -, makeWrapper -, dbus -, glib -, dconf -, libX11 -, libxml2 -, libXtst -, libXi -, libXext -, gnome -, systemd -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + gobject-introspection, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + gsettings-desktop-schemas, + makeWrapper, + dbus, + glib, + dconf, + libX11, + libxml2, + libXtst, + libXi, + libXext, + gnome, + systemd, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, }: stdenv.mkDerivation rec { pname = "at-spi2-core"; version = "2.54.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; separateDebugInfo = true; src = fetchurl { @@ -34,28 +40,32 @@ stdenv.mkDerivation rec { hash = "sha256-1+7n51vt3MJyztwrYFNWAPOq5uSBWJ68Znr8Q3wKYHk="; }; - nativeBuildInputs = [ - glib - meson - ninja - pkg-config - makeWrapper - ] ++ lib.optionals withIntrospection [ - gobject-introspection - ]; + nativeBuildInputs = + [ + glib + meson + ninja + pkg-config + makeWrapper + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + ]; - buildInputs = [ - libX11 - libxml2 - # at-spi2-core can be build without X support, but due it is a client-side library, GUI-less usage is a very rare case - libXtst - libXi - # libXext is a transitive dependency of libXi - libXext - ] ++ lib.optionals systemdSupport [ - # libsystemd is a needed for dbus-broker support - systemd - ]; + buildInputs = + [ + libX11 + libxml2 + # at-spi2-core can be build without X support, but due it is a client-side library, GUI-less usage is a very rare case + libXtst + libXi + # libXext is a transitive dependency of libXi + libXext + ] + ++ lib.optionals systemdSupport [ + # libsystemd is a needed for dbus-broker support + systemd + ]; # In atspi-2.pc dbus-1 glib-2.0 # In atk.pc gobject-2.0 @@ -67,18 +77,21 @@ stdenv.mkDerivation rec { # fails with "AT-SPI: Couldn't connect to accessibility bus. Is at-spi-bus-launcher running?" doCheck = false; - mesonFlags = [ - # Provide dbus-daemon fallback when it is not already running when - # at-spi2-bus-launcher is executed. This allows us to avoid - # including the entire dbus closure in libraries linked with - # the at-spi2-core libraries. - "-Ddbus_daemon=/run/current-system/sw/bin/dbus-daemon" - ] ++ lib.optionals systemdSupport [ - # Same as the above, but for dbus-broker - "-Ddbus_broker=/run/current-system/sw/bin/dbus-broker-launch" - ] ++ lib.optionals (!systemdSupport) [ - "-Duse_systemd=false" - ]; + mesonFlags = + [ + # Provide dbus-daemon fallback when it is not already running when + # at-spi2-bus-launcher is executed. This allows us to avoid + # including the entire dbus closure in libraries linked with + # the at-spi2-core libraries. + "-Ddbus_daemon=/run/current-system/sw/bin/dbus-daemon" + ] + ++ lib.optionals systemdSupport [ + # Same as the above, but for dbus-broker + "-Ddbus_broker=/run/current-system/sw/bin/dbus-broker-launch" + ] + ++ lib.optionals (!systemdSupport) [ + "-Duse_systemd=false" + ]; passthru = { updateScript = gnome.updateScript { diff --git a/pkgs/by-name/at/at/package.nix b/pkgs/by-name/at/at/package.nix index 5990bf4c08fa3b..4b5d03362e4a15 100644 --- a/pkgs/by-name/at/at/package.nix +++ b/pkgs/by-name/at/at/package.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchurl, fetchpatch, bison, flex, pam, perl -, sendmailPath ? "/run/wrappers/bin/sendmail" -, atWrapperPath ? "/run/wrappers/bin/at" +{ + lib, + stdenv, + fetchurl, + fetchpatch, + bison, + flex, + pam, + perl, + sendmailPath ? "/run/wrappers/bin/sendmail", + atWrapperPath ? "/run/wrappers/bin/at", }: stdenv.mkDerivation rec { @@ -37,17 +45,20 @@ stdenv.mkDerivation rec { --replace '6755' '0755' ''; - nativeBuildInputs = [ bison flex perl /* for `prove` (tests) */ ]; + nativeBuildInputs = [ + bison + flex + perl # for `prove` (tests) + ]; buildInputs = [ pam ]; - preConfigure = - '' - export SENDMAIL=${sendmailPath} - # Purity: force atd.pid to be placed in /var/run regardless of - # whether it exists now. - substituteInPlace ./configure --replace "test -d /var/run" "true" - ''; + preConfigure = '' + export SENDMAIL=${sendmailPath} + # Purity: force atd.pid to be placed in /var/run regardless of + # whether it exists now. + substituteInPlace ./configure --replace "test -d /var/run" "true" + ''; configureFlags = [ "--with-etcdir=/etc/at" diff --git a/pkgs/by-name/at/atanks/package.nix b/pkgs/by-name/at/atanks/package.nix index 2d38e909168ee7..3b86071d5bf964 100644 --- a/pkgs/by-name/at/atanks/package.nix +++ b/pkgs/by-name/at/atanks/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, allegro }: +{ + lib, + stdenv, + fetchurl, + allegro, +}: stdenv.mkDerivation rec { pname = "atanks"; @@ -11,7 +16,11 @@ stdenv.mkDerivation rec { buildInputs = [ allegro ]; - makeFlags = [ "PREFIX=$(out)/" "INSTALL=install" "CXX=g++" ]; + makeFlags = [ + "PREFIX=$(out)/" + "INSTALL=install" + "CXX=g++" + ]; meta = with lib; { description = "Atomic Tanks ballistics game"; diff --git a/pkgs/by-name/at/atari800/package.nix b/pkgs/by-name/at/atari800/package.nix index 186dc0f74ca587..b646426731a952 100644 --- a/pkgs/by-name/at/atari800/package.nix +++ b/pkgs/by-name/at/atari800/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, SDL -, autoreconfHook -, fetchFromGitHub -, libGL -, libGLU -, libX11 -, readline -, zlib +{ + lib, + stdenv, + SDL, + autoreconfHook, + fetchFromGitHub, + libGL, + libGLU, + libX11, + readline, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -17,7 +18,7 @@ stdenv.mkDerivation (finalAttrs: { src = fetchFromGitHub { owner = "atari800"; repo = "atari800"; - rev = "ATARI800_${lib.replaceStrings ["."] ["_"] finalAttrs.version}"; + rev = "ATARI800_${lib.replaceStrings [ "." ] [ "_" ] finalAttrs.version}"; hash = "sha256-D66YRRTqdoV9TqDFonJ9XNpfP52AicuYgdiW27RCIuQ="; }; diff --git a/pkgs/by-name/at/ataripp/package.nix b/pkgs/by-name/at/ataripp/package.nix index ff6c26687e7fed..f62dbf3e4b45b1 100644 --- a/pkgs/by-name/at/ataripp/package.nix +++ b/pkgs/by-name/at/ataripp/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, SDL -, alsa-lib -, fetchurl -, gcc-unwrapped -, libICE -, libSM -, libX11 -, libXext +{ + lib, + stdenv, + SDL, + alsa-lib, + fetchurl, + gcc-unwrapped, + libICE, + libSM, + libX11, + libXext, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/at/atasm/package.nix b/pkgs/by-name/at/atasm/package.nix index 4e73fa6d4ecde5..2c37e7f735b722 100644 --- a/pkgs/by-name/at/atasm/package.nix +++ b/pkgs/by-name/at/atasm/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/at/atftp/package.nix b/pkgs/by-name/at/atftp/package.nix index a8db0e93d5d3b8..5bcdff69e44d17 100644 --- a/pkgs/by-name/at/atftp/package.nix +++ b/pkgs/by-name/at/atftp/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, autoreconfHook -, fetchurl -, gcc -, makeWrapper -, pcre2 -, perl -, ps -, readline -, tcp_wrappers +{ + lib, + stdenv, + autoreconfHook, + fetchurl, + gcc, + makeWrapper, + pcre2, + perl, + ps, + readline, + tcp_wrappers, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/at/atheme/package.nix b/pkgs/by-name/at/atheme/package.nix index 1b2f1a25ccfcd0..7fc5cec53ddd20 100644 --- a/pkgs/by-name/at/atheme/package.nix +++ b/pkgs/by-name/at/atheme/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchgit, libmowgli, pkg-config, git, gettext, pcre, libidn, libxcrypt, cracklib, openssl }: +{ + lib, + stdenv, + fetchgit, + libmowgli, + pkg-config, + git, + gettext, + pcre, + libidn, + libxcrypt, + cracklib, + openssl, +}: stdenv.mkDerivation rec { pname = "atheme"; @@ -11,8 +24,19 @@ stdenv.mkDerivation rec { leaveDotGit = true; }; - nativeBuildInputs = [ pkg-config git gettext ]; - buildInputs = [ libmowgli pcre libidn libxcrypt cracklib openssl ]; + nativeBuildInputs = [ + pkg-config + git + gettext + ]; + buildInputs = [ + libmowgli + pcre + libidn + libxcrypt + cracklib + openssl + ]; configureFlags = [ "--with-pcre" diff --git a/pkgs/by-name/at/atinout/package.nix b/pkgs/by-name/at/atinout/package.nix index 1155b2b876bb06..0ec2cfd5f423cb 100644 --- a/pkgs/by-name/at/atinout/package.nix +++ b/pkgs/by-name/at/atinout/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchgit, ronn, mount }: +{ + lib, + stdenv, + fetchgit, + ronn, + mount, +}: stdenv.mkDerivation rec { pname = "atinout"; @@ -6,7 +12,10 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = lib.optionalString (!stdenv.cc.isClang) "-Werror=implicit-fallthrough=0"; LANG = if stdenv.hostPlatform.isDarwin then "en_US.UTF-8" else "C.UTF-8"; - nativeBuildInputs = [ ronn mount ]; + nativeBuildInputs = [ + ronn + mount + ]; src = fetchgit { url = "git://git.code.sf.net/p/atinout/code"; diff --git a/pkgs/by-name/at/atkinson-hyperlegible/package.nix b/pkgs/by-name/at/atkinson-hyperlegible/package.nix index e8b09cfb637cdb..92b769251783e9 100644 --- a/pkgs/by-name/at/atkinson-hyperlegible/package.nix +++ b/pkgs/by-name/at/atkinson-hyperlegible/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "atkinson-hyperlegible"; diff --git a/pkgs/by-name/at/atlantis/package.nix b/pkgs/by-name/at/atlantis/package.nix index e68e9da7e3d1f6..8ad81295734b40 100644 --- a/pkgs/by-name/at/atlantis/package.nix +++ b/pkgs/by-name/at/atlantis/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "atlantis"; diff --git a/pkgs/by-name/at/atlassian-cli/package.nix b/pkgs/by-name/at/atlassian-cli/package.nix index d6c4db65c1504c..3e1d1ddcc3e370 100644 --- a/pkgs/by-name/at/atlassian-cli/package.nix +++ b/pkgs/by-name/at/atlassian-cli/package.nix @@ -1,12 +1,17 @@ -{ lib, stdenv, fetchzip, jre }: +{ + lib, + stdenv, + fetchzip, + jre, +}: stdenv.mkDerivation rec { pname = "atlassian-cli"; version = "9.6.0"; src = fetchzip { - url = "https://bobswift.atlassian.net/wiki/download/attachments/16285777/${pname}-${version}-distribution.zip"; - sha256 = "sha256-55ydhprVC9NdDMUrKbpSAEQBb9zRYgwOc7k8aP4R89A="; + url = "https://bobswift.atlassian.net/wiki/download/attachments/16285777/${pname}-${version}-distribution.zip"; + sha256 = "sha256-55ydhprVC9NdDMUrKbpSAEQBb9zRYgwOc7k8aP4R89A="; }; tools = [ diff --git a/pkgs/by-name/at/atmos/package.nix b/pkgs/by-name/at/atmos/package.nix index 54d7c4fd6824e7..f4f5ac70cf52ae 100644 --- a/pkgs/by-name/at/atmos/package.nix +++ b/pkgs/by-name/at/atmos/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "atmos"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-4pUx8qzptzuGeIrT7m67iidMSUNbDSGV8p+KkHqX3lo="; - ldflags = [ "-s" "-w" "-X github.com/cloudposse/atmos/cmd.Version=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/cloudposse/atmos/cmd.Version=v${version}" + ]; preCheck = '' # Remove tests that depend on a network connection. diff --git a/pkgs/by-name/at/atomic-operator/package.nix b/pkgs/by-name/at/atomic-operator/package.nix index b93b2f809ccdcc..89d7e684045146 100644 --- a/pkgs/by-name/at/atomic-operator/package.nix +++ b/pkgs/by-name/at/atomic-operator/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/at/atomic-swap/package.nix b/pkgs/by-name/at/atomic-swap/package.nix index f652f74be27fd3..5267433fcf697e 100644 --- a/pkgs/by-name/at/atomic-swap/package.nix +++ b/pkgs/by-name/at/atomic-swap/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, nix-update-script, makeWrapper, monero-cli }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + makeWrapper, + monero-cli, +}: let pname = "atomic-swap"; @@ -38,6 +45,9 @@ buildGoModule { changelog = "https://github.com/AthanorLabs/atomic-swap/releases/tag/v${version}"; description = "ETH-XMR atomic swap implementation"; license = with licenses; [ lgpl3Only ]; - maintainers = with maintainers; [ happysalada lord-valen ]; + maintainers = with maintainers; [ + happysalada + lord-valen + ]; }; } diff --git a/pkgs/by-name/at/atool/package.nix b/pkgs/by-name/at/atool/package.nix index daeaec9de3b2ce..4b5110d980943f 100644 --- a/pkgs/by-name/at/atool/package.nix +++ b/pkgs/by-name/at/atool/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, perl, bash}: +{ + lib, + stdenv, + fetchurl, + perl, + bash, +}: stdenv.mkDerivation rec { pname = "atool"; diff --git a/pkgs/by-name/at/atop/package.nix b/pkgs/by-name/at/atop/package.nix index 575ed69bfc79a7..390593e7f1d4f6 100644 --- a/pkgs/by-name/at/atop/package.nix +++ b/pkgs/by-name/at/atop/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, glib -, zlib -, ncurses -, pkg-config -, findutils -, systemd -, python3 -, nixosTests -# makes the package unfree via pynvml -, withAtopgpu ? false +{ + lib, + stdenv, + fetchurl, + glib, + zlib, + ncurses, + pkg-config, + findutils, + systemd, + python3, + nixosTests, + # makes the package unfree via pynvml + withAtopgpu ? false, }: stdenv.mkDerivation rec { @@ -22,19 +23,23 @@ stdenv.mkDerivation rec { hash = "sha256-m5TGZmAu//e/QC7M5wbDR/OMOctjSY+dOWJoYeVkbiA="; }; - nativeBuildInputs = [ - pkg-config - ] ++ lib.optionals withAtopgpu [ - python3.pkgs.wrapPython - ]; + nativeBuildInputs = + [ + pkg-config + ] + ++ lib.optionals withAtopgpu [ + python3.pkgs.wrapPython + ]; - buildInputs = [ - glib - zlib - ncurses - ] ++ lib.optionals withAtopgpu [ - python3 - ]; + buildInputs = + [ + glib + zlib + ncurses + ] + ++ lib.optionals withAtopgpu [ + python3 + ]; pythonPath = lib.optionals withAtopgpu [ python3.pkgs.pynvml @@ -72,14 +77,21 @@ stdenv.mkDerivation rec { mkdir -p $out/bin ''; - postInstall = '' - # Remove extra files we don't need - rm -r $out/{var,etc} $out/bin/atop{sar,}-${version} - '' + (if withAtopgpu then '' - wrapPythonPrograms - '' else '' - rm $out/lib/systemd/system/atopgpu.service $out/bin/atopgpud $out/share/man/man8/atopgpud.8 - ''); + postInstall = + '' + # Remove extra files we don't need + rm -r $out/{var,etc} $out/bin/atop{sar,}-${version} + '' + + ( + if withAtopgpu then + '' + wrapPythonPrograms + '' + else + '' + rm $out/lib/systemd/system/atopgpu.service $out/bin/atopgpud $out/share/man/man8/atopgpud.8 + '' + ); passthru.tests = { inherit (nixosTests) atop; }; diff --git a/pkgs/by-name/at/ats-acc/package.nix b/pkgs/by-name/at/ats-acc/package.nix index b8eef344f20dd8..80cfd7aef6e28f 100644 --- a/pkgs/by-name/at/ats-acc/package.nix +++ b/pkgs/by-name/at/ats-acc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ats2 }: +{ + lib, + stdenv, + fetchFromGitHub, + ats2, +}: stdenv.mkDerivation rec { pname = "ats-acc"; diff --git a/pkgs/by-name/at/ats/package.nix b/pkgs/by-name/at/ats/package.nix index 35e1b1dd1058c3..227702fb316b47 100644 --- a/pkgs/by-name/at/ats/package.nix +++ b/pkgs/by-name/at/ats/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gmp }: +{ + lib, + stdenv, + fetchurl, + gmp, +}: stdenv.mkDerivation rec { pname = "ats"; @@ -15,11 +20,11 @@ stdenv.mkDerivation rec { meta = { description = "Functional programming language with dependent types"; - homepage = "http://www.ats-lang.org"; - license = lib.licenses.gpl3Plus; + homepage = "http://www.ats-lang.org"; + license = lib.licenses.gpl3Plus; # TODO: it looks like ATS requires gcc specifically. Someone with more knowledge # will need to experiment. - platforms = lib.platforms.linux; + platforms = lib.platforms.linux; maintainers = [ lib.maintainers.thoughtpolice ]; }; } diff --git a/pkgs/by-name/at/attic-client/package.nix b/pkgs/by-name/at/attic-client/package.nix index 57afddb3db06d5..6a14ec17c6f588 100644 --- a/pkgs/by-name/at/attic-client/package.nix +++ b/pkgs/by-name/at/attic-client/package.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, nix -, nixosTests -, boost -, pkg-config -, stdenv -, installShellFiles -, darwin -, crates ? [ "attic-client" ] +{ + lib, + rustPlatform, + fetchFromGitHub, + nix, + nixosTests, + boost, + pkg-config, + stdenv, + installShellFiles, + darwin, + crates ? [ "attic-client" ], }: rustPlatform.buildRustPackage { pname = "attic"; @@ -26,12 +27,17 @@ rustPlatform.buildRustPackage { installShellFiles ]; - buildInputs = [ - nix - boost - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - SystemConfiguration - ]); + buildInputs = + [ + nix + boost + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + SystemConfiguration + ] + ); cargoLock = { lockFile = ./Cargo.lock; @@ -66,7 +72,10 @@ rustPlatform.buildRustPackage { description = "Multi-tenant Nix Binary Cache"; homepage = "https://github.com/zhaofengli/attic"; license = licenses.asl20; - maintainers = with maintainers; [ zhaofengli aciceri ]; + maintainers = with maintainers; [ + zhaofengli + aciceri + ]; platforms = platforms.linux ++ platforms.darwin; mainProgram = "attic"; }; diff --git a/pkgs/by-name/at/atuin/package.nix b/pkgs/by-name/at/atuin/package.nix index f863e578a076ff..edf1659aa05250 100644 --- a/pkgs/by-name/at/atuin/package.nix +++ b/pkgs/by-name/at/atuin/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles -, rustPlatform -, buildPackages -, apple-sdk_11 -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + rustPlatform, + buildPackages, + apple-sdk_11, + nixosTests, }: rustPlatform.buildRustPackage rec { @@ -21,15 +22,20 @@ rustPlatform.buildRustPackage rec { # TODO: unify this to one hash because updater do not support this cargoHash = - if stdenv.hostPlatform.isLinux - then "sha256-K4Vw/d0ZOROWujWr76I3QvfKefLhXLeFufUrgStAyjQ=" - else "sha256-8NAfE7cGFT64ntNXK9RT0D/MbDJweN7vvsG/KlrY4K4="; + if stdenv.hostPlatform.isLinux then + "sha256-K4Vw/d0ZOROWujWr76I3QvfKefLhXLeFufUrgStAyjQ=" + else + "sha256-8NAfE7cGFT64ntNXK9RT0D/MbDJweN7vvsG/KlrY4K4="; # atuin's default features include 'check-updates', which do not make sense # for distribution builds. List all other default features. buildNoDefaultFeatures = true; buildFeatures = [ - "client" "sync" "server" "clipboard" "daemon" + "client" + "sync" + "server" + "clipboard" + "daemon" ]; nativeBuildInputs = [ installShellFiles ]; @@ -71,7 +77,11 @@ rustPlatform.buildRustPackage rec { description = "Replacement for a shell history which records additional commands context with optional encrypted synchronization between machines"; homepage = "https://github.com/atuinsh/atuin"; license = licenses.mit; - maintainers = with maintainers; [ SuperSandro2000 sciencentistguy _0x4A6F ]; + maintainers = with maintainers; [ + SuperSandro2000 + sciencentistguy + _0x4A6F + ]; mainProgram = "atuin"; }; } diff --git a/pkgs/by-name/au/aubio/package.nix b/pkgs/by-name/au/aubio/package.nix index 6aba488f2457c9..8fa25d12924715 100644 --- a/pkgs/by-name/au/aubio/package.nix +++ b/pkgs/by-name/au/aubio/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchurl, alsa-lib, fftw, libjack2, libsamplerate -, libsndfile, pkg-config, python311, wafHook +{ + lib, + stdenv, + fetchurl, + alsa-lib, + fftw, + libjack2, + libsamplerate, + libsndfile, + pkg-config, + python311, + wafHook, }: stdenv.mkDerivation rec { @@ -11,8 +21,18 @@ stdenv.mkDerivation rec { sha256 = "1npks71ljc48w6858l9bq30kaf5nph8z0v61jkfb70xb9np850nl"; }; - nativeBuildInputs = [ pkg-config python311 wafHook ]; - buildInputs = [ alsa-lib fftw libjack2 libsamplerate libsndfile ]; + nativeBuildInputs = [ + pkg-config + python311 + wafHook + ]; + buildInputs = [ + alsa-lib + fftw + libjack2 + libsamplerate + libsndfile + ]; strictDeps = true; wafFlags = lib.optional (stdenv.buildPlatform != stdenv.hostPlatform) "--disable-tests"; @@ -28,7 +48,10 @@ stdenv.mkDerivation rec { description = "Library for audio labelling"; homepage = "https://aubio.org/"; license = licenses.gpl2; - maintainers = with maintainers; [ marcweber fpletz ]; + maintainers = with maintainers; [ + marcweber + fpletz + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/au/aucatctl/package.nix b/pkgs/by-name/au/aucatctl/package.nix index 051a1494fd9f5d..2e0671876015c4 100644 --- a/pkgs/by-name/au/aucatctl/package.nix +++ b/pkgs/by-name/au/aucatctl/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, sndio, libbsd }: +{ + lib, + stdenv, + fetchurl, + sndio, + libbsd, +}: stdenv.mkDerivation (finalAttrs: { pname = "aucatctl"; @@ -9,16 +15,20 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "524f2fae47db785234f166551520d9605b9a27551ca438bd807e3509ce246cf0"; }; - buildInputs = [ sndio ] - ++ lib.optional (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isBSD) - libbsd; + buildInputs = [ + sndio + ] ++ lib.optional (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isBSD) libbsd; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - preBuild = '' - makeFlagsArray+=("PREFIX=$out") - '' + lib.optionalString - (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isBSD) '' + preBuild = + '' + makeFlagsArray+=("PREFIX=$out") + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isBSD) '' makeFlagsArray+=(LDADD="-lsndio -lbsd") # Fix warning about implicit declaration of function 'strlcpy' diff --git a/pkgs/by-name/au/auctex/package.nix b/pkgs/by-name/au/auctex/package.nix index dc027b5c470e5d..837130e3e697f3 100644 --- a/pkgs/by-name/au/auctex/package.nix +++ b/pkgs/by-name/au/auctex/package.nix @@ -1,41 +1,56 @@ -{ lib, stdenv, fetchurl, emacs, texliveBasic, ghostscript }: - -let auctex = stdenv.mkDerivation ( rec { - # Make this a valid tex(live-new) package; - # the pkgs attribute is provided with a hack below. - pname = "auctex"; - version = "13.2"; - tlType = "run"; - - outputs = [ "out" "tex" ]; - - src = fetchurl { - url = "mirror://gnu/${pname}/${pname}-${version}.tar.gz"; - hash = "sha256-Hn5AKrz4RmlOuncZklvwlcI+8zpeZgIgHHS2ymCUQDU="; - }; - - buildInputs = [ - emacs - ghostscript - (texliveBasic.withPackages (ps: [ ps.etoolbox ps.hypdoc ])) - ]; - - preConfigure = '' - mkdir -p "$tex" - export HOME=$(mktemp -d) - ''; - - configureFlags = [ - "--with-lispdir=\${out}/share/emacs/site-lisp" - "--with-texmf-dir=\${tex}" - ]; - - meta = with lib; { - homepage = "https://www.gnu.org/software/auctex"; - description = "Extensible package for writing and formatting TeX files in GNU Emacs and XEmacs"; - license = licenses.gpl3Plus; - platforms = platforms.unix; - }; -}); - -in auctex // { pkgs = [ auctex.tex ]; } +{ + lib, + stdenv, + fetchurl, + emacs, + texliveBasic, + ghostscript, +}: + +let + auctex = stdenv.mkDerivation (rec { + # Make this a valid tex(live-new) package; + # the pkgs attribute is provided with a hack below. + pname = "auctex"; + version = "13.2"; + tlType = "run"; + + outputs = [ + "out" + "tex" + ]; + + src = fetchurl { + url = "mirror://gnu/${pname}/${pname}-${version}.tar.gz"; + hash = "sha256-Hn5AKrz4RmlOuncZklvwlcI+8zpeZgIgHHS2ymCUQDU="; + }; + + buildInputs = [ + emacs + ghostscript + (texliveBasic.withPackages (ps: [ + ps.etoolbox + ps.hypdoc + ])) + ]; + + preConfigure = '' + mkdir -p "$tex" + export HOME=$(mktemp -d) + ''; + + configureFlags = [ + "--with-lispdir=\${out}/share/emacs/site-lisp" + "--with-texmf-dir=\${tex}" + ]; + + meta = with lib; { + homepage = "https://www.gnu.org/software/auctex"; + description = "Extensible package for writing and formatting TeX files in GNU Emacs and XEmacs"; + license = licenses.gpl3Plus; + platforms = platforms.unix; + }; + }); + +in +auctex // { pkgs = [ auctex.tex ]; } diff --git a/pkgs/by-name/au/audiality2/package.nix b/pkgs/by-name/au/audiality2/package.nix index 9dfc216a226955..61e83d4fac5d1e 100644 --- a/pkgs/by-name/au/audiality2/package.nix +++ b/pkgs/by-name/au/audiality2/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, pkg-config -# The two audio backends: -, SDL2 -, jack2 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + # The two audio backends: + SDL2, + jack2, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/au/audible-cli/package.nix b/pkgs/by-name/au/audible-cli/package.nix index 682be8b6c27048..926a9ac27d4532 100644 --- a/pkgs/by-name/au/audible-cli/package.nix +++ b/pkgs/by-name/au/audible-cli/package.nix @@ -1,4 +1,10 @@ -{ lib, python3Packages, fetchFromGitHub, installShellFiles, nix-update-script }: +{ + lib, + python3Packages, + fetchFromGitHub, + installShellFiles, + nix-update-script, +}: python3Packages.buildPythonApplication rec { pname = "audible-cli"; @@ -12,11 +18,14 @@ python3Packages.buildPythonApplication rec { hash = "sha256-AYL7lcYYY7gK12Id94aHRWRlCiznnF4r+lpI5VFpAWY="; }; - nativeBuildInputs = with python3Packages; [ - setuptools - ] ++ [ - installShellFiles - ]; + nativeBuildInputs = + with python3Packages; + [ + setuptools + ] + ++ [ + installShellFiles + ]; propagatedBuildInputs = with python3Packages; [ aiofiles @@ -52,7 +61,10 @@ python3Packages.buildPythonApplication rec { ]; passthru.updateScript = nix-update-script { - extraArgs = [ "--version-regex" "[0-9.]+" ]; + extraArgs = [ + "--version-regex" + "[0-9.]+" + ]; }; meta = with lib; { diff --git a/pkgs/by-name/au/audiness/package.nix b/pkgs/by-name/au/audiness/package.nix index d7cff9d14e4bda..61380450349a17 100644 --- a/pkgs/by-name/au/audiness/package.nix +++ b/pkgs/by-name/au/audiness/package.nix @@ -23,14 +23,11 @@ python3.pkgs.buildPythonApplication rec { build-system = with python3.pkgs; [ poetry-core ]; - - dependencies = - with python3.pkgs; - [ - pytenable - typer - validators - ]; + dependencies = with python3.pkgs; [ + pytenable + typer + validators + ]; pythonImportsCheck = [ "audiness" ]; diff --git a/pkgs/by-name/au/audio-recorder/package.nix b/pkgs/by-name/au/audio-recorder/package.nix index ebf9eafcb0d3f7..cd500cc52da8d6 100644 --- a/pkgs/by-name/au/audio-recorder/package.nix +++ b/pkgs/by-name/au/audio-recorder/package.nix @@ -1,8 +1,19 @@ -{ lib, stdenv, fetchurl -, pkg-config, intltool -, glib, dbus, gtk3, libappindicator-gtk3, gst_all_1 -, librsvg, wrapGAppsHook3 -, pulseaudioSupport ? true, libpulseaudio }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + glib, + dbus, + gtk3, + libappindicator-gtk3, + gst_all_1, + librsvg, + wrapGAppsHook3, + pulseaudioSupport ? true, + libpulseaudio, +}: stdenv.mkDerivation rec { pname = "audio-recorder"; @@ -17,13 +28,29 @@ stdenv.mkDerivation rec { # https://bugs.launchpad.net/audio-recorder/+bug/1784622 env.NIX_CFLAGS_COMPILE = "-I${glib.dev}/include/gio-unix-2.0"; - nativeBuildInputs = [ pkg-config intltool wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + intltool + wrapGAppsHook3 + ]; - buildInputs = [ - glib dbus gtk3 librsvg libappindicator-gtk3 - ] ++ (with gst_all_1; [ - gstreamer gst-plugins-base gst-plugins-good gst-plugins-bad gst-plugins-ugly gst-libav - ]) ++ lib.optional pulseaudioSupport libpulseaudio; + buildInputs = + [ + glib + dbus + gtk3 + librsvg + libappindicator-gtk3 + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + gst-plugins-ugly + gst-libav + ]) + ++ lib.optional pulseaudioSupport libpulseaudio; meta = with lib; { description = "Audio recorder for GNOME and Unity Desktops"; diff --git a/pkgs/by-name/au/audio-sharing/package.nix b/pkgs/by-name/au/audio-sharing/package.nix index d1a4ec2b013430..e496bca3176f65 100644 --- a/pkgs/by-name/au/audio-sharing/package.nix +++ b/pkgs/by-name/au/audio-sharing/package.nix @@ -1,23 +1,24 @@ -{ appstream-glib -, cargo -, dbus -, desktop-file-utils -, fetchFromGitLab -, git -, glib -, gst_all_1 -, gtk4 -, lib -, libadwaita -, meson -, ninja -, nix-update-script -, pkg-config -, python3 -, rustPlatform -, rustc -, stdenv -, wrapGAppsHook4 +{ + appstream-glib, + cargo, + dbus, + desktop-file-utils, + fetchFromGitLab, + git, + glib, + gst_all_1, + gtk4, + lib, + libadwaita, + meson, + ninja, + nix-update-script, + pkg-config, + python3, + rustPlatform, + rustc, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { pname = "audio-sharing"; @@ -37,20 +38,22 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-FfjSttXf6WF2w59CP6L/+BIuuXp2yKPTku7FMvdIHg0="; }; - nativeBuildInputs = [ - appstream-glib - cargo - desktop-file-utils - git - meson - ninja - pkg-config - python3 - rustc - wrapGAppsHook4 - ] ++ (with rustPlatform; [ - cargoSetupHook - ]); + nativeBuildInputs = + [ + appstream-glib + cargo + desktop-file-utils + git + meson + ninja + pkg-config + python3 + rustc + wrapGAppsHook4 + ] + ++ (with rustPlatform; [ + cargoSetupHook + ]); buildInputs = [ glib diff --git a/pkgs/by-name/au/audiobookshelf/wrapper.nix b/pkgs/by-name/au/audiobookshelf/wrapper.nix index 4dabeae303b1ad..32d2705b6c62df 100644 --- a/pkgs/by-name/au/audiobookshelf/wrapper.nix +++ b/pkgs/by-name/au/audiobookshelf/wrapper.nix @@ -3,65 +3,66 @@ ffmpeg-full, nunicode, getopt, -}: '' - #!${stdenv.shell} +}: +'' + #!${stdenv.shell} - port=8000 - host=0.0.0.0 - config=$(pwd)/config - metadata=$(pwd)/metadata + port=8000 + host=0.0.0.0 + config=$(pwd)/config + metadata=$(pwd)/metadata - LONGOPTS=host:,port:,config:,metadata:,help - args=$(${getopt}/bin/getopt -l "$LONGOPTS" -o h -- "$@") + LONGOPTS=host:,port:,config:,metadata:,help + args=$(${getopt}/bin/getopt -l "$LONGOPTS" -o h -- "$@") - eval set -- "$args" + eval set -- "$args" - while [ $# -ge 1 ]; do - case "$1" in - --) - # No more options left. - shift - break - ;; - --host) - host="$2" - shift - ;; - --port) - port="$2" - shift - ;; - --config) - if [[ "''${2:0:1}" = "/" ]]; then - config="$2" - else - config="$(pwd)/$2" - fi - shift - ;; - --metadata) - if [[ "''${2:0:1}" = "/" ]]; then - metadata="$2" - else - metadata="$(pwd)/$2" - fi - shift - ;; - --help|-h) - echo "Usage: audiobookshelf [--host ] [--port ] [--metadata ] [--config ]" - exit 0 - ;; - esac - shift - done + while [ $# -ge 1 ]; do + case "$1" in + --) + # No more options left. + shift + break + ;; + --host) + host="$2" + shift + ;; + --port) + port="$2" + shift + ;; + --config) + if [[ "''${2:0:1}" = "/" ]]; then + config="$2" + else + config="$(pwd)/$2" + fi + shift + ;; + --metadata) + if [[ "''${2:0:1}" = "/" ]]; then + metadata="$2" + else + metadata="$(pwd)/$2" + fi + shift + ;; + --help|-h) + echo "Usage: audiobookshelf [--host ] [--port ] [--metadata ] [--config ]" + exit 0 + ;; + esac + shift + done - NODE_ENV=production \ - SOURCE=nixpkgs \ - SKIP_BINARIES_CHECK=1 \ - FFMPEG_PATH=${ffmpeg-full}/bin/ffmpeg \ - FFPROBE_PATH=${ffmpeg-full}/bin/ffprobe \ - NUSQLITE3_PATH=${nunicode.sqlite}/lib/libnusqlite3 \ - CONFIG_PATH="$config" \ - METADATA_PATH="$metadata" \ - PORT="$port" \ - HOST="$host" \'' + NODE_ENV=production \ + SOURCE=nixpkgs \ + SKIP_BINARIES_CHECK=1 \ + FFMPEG_PATH=${ffmpeg-full}/bin/ffmpeg \ + FFPROBE_PATH=${ffmpeg-full}/bin/ffprobe \ + NUSQLITE3_PATH=${nunicode.sqlite}/lib/libnusqlite3 \ + CONFIG_PATH="$config" \ + METADATA_PATH="$metadata" \ + PORT="$port" \ + HOST="$host" \'' diff --git a/pkgs/by-name/au/audion/package.nix b/pkgs/by-name/au/audion/package.nix index 39db0f9d452f5e..304016a1283071 100644 --- a/pkgs/by-name/au/audion/package.nix +++ b/pkgs/by-name/au/audion/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/au/audiowaveform/package.nix b/pkgs/by-name/au/audiowaveform/package.nix index a435ede2e5ccc6..2d5d23cb35bba0 100644 --- a/pkgs/by-name/au/audiowaveform/package.nix +++ b/pkgs/by-name/au/audiowaveform/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, cmake, gtest, boost, gd, libsndfile, libmad, libid3tag }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gtest, + boost, + gd, + libsndfile, + libmad, + libid3tag, +}: stdenv.mkDerivation rec { pname = "audiowaveform"; @@ -16,9 +27,18 @@ stdenv.mkDerivation rec { "-DCMAKE_CXX_STANDARD=14" ]; - nativeBuildInputs = [ cmake gtest ]; + nativeBuildInputs = [ + cmake + gtest + ]; - buildInputs = [ boost gd libsndfile libmad libid3tag ]; + buildInputs = [ + boost + gd + libsndfile + libmad + libid3tag + ]; preConfigure = '' ln -s ${gtest.src} googletest diff --git a/pkgs/by-name/au/audit/package.nix b/pkgs/by-name/au/audit/package.nix index 4a1ecf3ce17a24..62115bfc2b4d3e 100644 --- a/pkgs/by-name/au/audit/package.nix +++ b/pkgs/by-name/au/audit/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, autoreconfHook -, bash -, buildPackages -, linuxHeaders -, python3 -, swig -, pkgsCross +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + bash, + buildPackages, + linuxHeaders, + python3, + swig, + pkgsCross, -# Enabling python support while cross compiling would be possible, but the -# configure script tries executing python to gather info instead of relying on -# python3-config exclusively -, enablePython ? stdenv.hostPlatform == stdenv.buildPlatform, + # Enabling python support while cross compiling would be possible, but the + # configure script tries executing python to gather info instead of relying on + # python3-config exclusively + enablePython ? stdenv.hostPlatform == stdenv.buildPlatform, }: stdenv.mkDerivation (finalAttrs: { @@ -44,7 +45,12 @@ stdenv.mkDerivation (finalAttrs: { "${linuxHeaders}/include/linux/audit.h" ''; - outputs = [ "bin" "dev" "out" "man" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + ]; strictDeps = true; @@ -52,13 +58,14 @@ stdenv.mkDerivation (finalAttrs: { buildPackages.stdenv.cc ]; - nativeBuildInputs = [ - autoreconfHook - ] - ++ lib.optionals enablePython [ - python3 - swig - ]; + nativeBuildInputs = + [ + autoreconfHook + ] + ++ lib.optionals enablePython [ + python3 + swig + ]; buildInputs = [ bash diff --git a/pkgs/by-name/au/augeas/package.nix b/pkgs/by-name/au/augeas/package.nix index e30de64f5ad179..7c735901a4d9e9 100644 --- a/pkgs/by-name/au/augeas/package.nix +++ b/pkgs/by-name/au/augeas/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, bison -, flex -, perl # for pod2man -, pkg-config -, readline -, libxml2 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + bison, + flex, + perl, # for pod2man + pkg-config, + readline, + libxml2, }: stdenv.mkDerivation rec { @@ -39,7 +40,10 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ readline libxml2 ]; + buildInputs = [ + readline + libxml2 + ]; enableParallelBuilding = true; @@ -52,7 +56,10 @@ stdenv.mkDerivation rec { runHook postCheck ''; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = with lib; { description = "Configuration editing tool"; diff --git a/pkgs/by-name/au/august/package.nix b/pkgs/by-name/au/august/package.nix index 2e8aec11763c0e..f23ff2fb43f2ae 100644 --- a/pkgs/by-name/au/august/package.nix +++ b/pkgs/by-name/au/august/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage { @@ -23,7 +24,10 @@ rustPlatform.buildRustPackage { meta = with lib; { description = "Emmet-like language that produces JSON, TOML, or YAML"; homepage = "https://github.com/yoav-lavi/august"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "ag"; }; diff --git a/pkgs/by-name/au/aurulent-sans/package.nix b/pkgs/by-name/au/aurulent-sans/package.nix index f1ee19b3b1579c..162664f9f879ca 100644 --- a/pkgs/by-name/au/aurulent-sans/package.nix +++ b/pkgs/by-name/au/aurulent-sans/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "aurulent-sans"; diff --git a/pkgs/by-name/au/authz0/package.nix b/pkgs/by-name/au/authz0/package.nix index 2230fe2e518d95..fa500b9b80647b 100644 --- a/pkgs/by-name/au/authz0/package.nix +++ b/pkgs/by-name/au/authz0/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/au/auto-epp/package.nix b/pkgs/by-name/au/auto-epp/package.nix index 07e06ba5b4b940..edddaba68e31f6 100644 --- a/pkgs/by-name/au/auto-epp/package.nix +++ b/pkgs/by-name/au/auto-epp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation rec { pname = "auto-epp"; version = "1.2.1"; diff --git a/pkgs/by-name/au/auto-multiple-choice/package.nix b/pkgs/by-name/au/auto-multiple-choice/package.nix index 96fd8e8c5f490a..b6cc032bb152f6 100644 --- a/pkgs/by-name/au/auto-multiple-choice/package.nix +++ b/pkgs/by-name/au/auto-multiple-choice/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchurl -, perlPackages -, makeWrapper -, wrapGAppsHook3 -, cairo -, dblatex -, gnumake -, gobject-introspection -, graphicsmagick -, gsettings-desktop-schemas -, gtk3 -, hicolor-icon-theme -, libnotify -, librsvg -, libxslt -, netpbm -, opencv -, pango -, perl -, pkg-config -, poppler +{ + lib, + stdenv, + fetchurl, + perlPackages, + makeWrapper, + wrapGAppsHook3, + cairo, + dblatex, + gnumake, + gobject-introspection, + graphicsmagick, + gsettings-desktop-schemas, + gtk3, + hicolor-icon-theme, + libnotify, + librsvg, + libxslt, + netpbm, + opencv, + pango, + perl, + pkg-config, + poppler, }: stdenv.mkDerivation (finalAttrs: rec { pname = "auto-multiple-choice"; @@ -71,68 +72,73 @@ stdenv.mkDerivation (finalAttrs: rec { postFixup = '' wrapProgram $out/bin/auto-multiple-choice \ ''${makeWrapperArgs[@]} \ - --prefix PERL5LIB : "${with perlPackages; makeFullPerlPath [ + --prefix PERL5LIB : "${ + with perlPackages; + makeFullPerlPath [ + ArchiveZip + DBDSQLite + Cairo + CairoGObject + DBI + Glib + GlibObjectIntrospection + Gtk3 + LocaleGettext + OpenOfficeOODoc + PerlMagick + TextCSV + XMLParser + XMLSimple + XMLWriter + ] + }:"$out/share/perl5 \ + --prefix XDG_DATA_DIRS : "$out/share:$XDG_ICON_DIRS:$GSETTINGS_SCHEMAS_PATH" \ + --prefix PATH : "$out/bin" \ + --set TEXINPUTS ":.:$out/tex/latex" + ''; + + nativeBuildInputs = [ + pkg-config + makeWrapper + wrapGAppsHook3 + gobject-introspection + ]; + + buildInputs = + [ + cairo + cairo.dev + dblatex + gnumake + graphicsmagick + gsettings-desktop-schemas + gtk3 + hicolor-icon-theme + libnotify + librsvg + libxslt + netpbm + opencv + pango + poppler + ] + ++ (with perlPackages; [ + perl ArchiveZip - DBDSQLite Cairo CairoGObject + DBDSQLite DBI Glib GlibObjectIntrospection Gtk3 LocaleGettext - OpenOfficeOODoc PerlMagick TextCSV XMLParser XMLSimple XMLWriter - ]}:"$out/share/perl5 \ - --prefix XDG_DATA_DIRS : "$out/share:$XDG_ICON_DIRS:$GSETTINGS_SCHEMAS_PATH" \ - --prefix PATH : "$out/bin" \ - --set TEXINPUTS ":.:$out/tex/latex" - ''; - - nativeBuildInputs = [ - pkg-config - makeWrapper - wrapGAppsHook3 - gobject-introspection - ]; - - buildInputs = [ - cairo - cairo.dev - dblatex - gnumake - graphicsmagick - gsettings-desktop-schemas - gtk3 - hicolor-icon-theme - libnotify - librsvg - libxslt - netpbm - opencv - pango - poppler - ] ++ (with perlPackages; [ - perl - ArchiveZip - Cairo - CairoGObject - DBDSQLite - DBI - Glib - GlibObjectIntrospection - Gtk3 - LocaleGettext - PerlMagick - TextCSV - XMLParser - XMLSimple - XMLWriter - ]); + ]); passthru = { tlType = "run"; diff --git a/pkgs/by-name/au/autoAddDriverRunpath/package.nix b/pkgs/by-name/au/autoAddDriverRunpath/package.nix index 36af8c90ffbb2b..1dd962cdeee6ef 100644 --- a/pkgs/by-name/au/autoAddDriverRunpath/package.nix +++ b/pkgs/by-name/au/autoAddDriverRunpath/package.nix @@ -1,6 +1,13 @@ -{ addDriverRunpath, autoFixElfFiles, makeSetupHook }: +{ + addDriverRunpath, + autoFixElfFiles, + makeSetupHook, +}: makeSetupHook { name = "auto-add-driver-runpath-hook"; - propagatedBuildInputs = [ addDriverRunpath autoFixElfFiles ]; + propagatedBuildInputs = [ + addDriverRunpath + autoFixElfFiles + ]; } ./auto-add-driver-runpath-hook.sh diff --git a/pkgs/by-name/au/autoadb/package.nix b/pkgs/by-name/au/autoadb/package.nix index 6b3ef212772a6d..a0bb4f32a5658e 100644 --- a/pkgs/by-name/au/autoadb/package.nix +++ b/pkgs/by-name/au/autoadb/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "autoadb"; diff --git a/pkgs/by-name/au/autobloody/package.nix b/pkgs/by-name/au/autobloody/package.nix index c55689350211d2..c583324a88daea 100644 --- a/pkgs/by-name/au/autobloody/package.nix +++ b/pkgs/by-name/au/autobloody/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/au/autobuild/package.nix b/pkgs/by-name/au/autobuild/package.nix index b6970beb873475..79dacbdebb7cae 100644 --- a/pkgs/by-name/au/autobuild/package.nix +++ b/pkgs/by-name/au/autobuild/package.nix @@ -1,4 +1,12 @@ -{ fetchurl, lib, stdenv, makeWrapper, perl, openssh, rsync }: +{ + fetchurl, + lib, + stdenv, + makeWrapper, + perl, + openssh, + rsync, +}: stdenv.mkDerivation rec { pname = "autobuild"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ perl openssh rsync ]; + buildInputs = [ + perl + openssh + rsync + ]; doCheck = true; diff --git a/pkgs/by-name/au/autoconf-archive/package.nix b/pkgs/by-name/au/autoconf-archive/package.nix index 8ac14c61bda470..f83a75002a9fb3 100644 --- a/pkgs/by-name/au/autoconf-archive/package.nix +++ b/pkgs/by-name/au/autoconf-archive/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, xz }: +{ + lib, + stdenv, + fetchurl, + xz, +}: stdenv.mkDerivation rec { pname = "autoconf-archive"; diff --git a/pkgs/by-name/au/autocutsel/package.nix b/pkgs/by-name/au/autocutsel/package.nix index e1b9a3c1c73a5f..e18db0f9a88041 100644 --- a/pkgs/by-name/au/autocutsel/package.nix +++ b/pkgs/by-name/au/autocutsel/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, libX11, libXaw}: +{ + lib, + stdenv, + fetchurl, + libX11, + libXaw, +}: stdenv.mkDerivation rec { version = "0.10.1"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-8X4G1C90lENtSyb0vgtrDaOUgcBADJZ3jkuQW2NB6xc="; }; - buildInputs = [ libX11 libXaw ]; + buildInputs = [ + libX11 + libXaw + ]; installPhase = '' mkdir -p $out/bin cp autocutsel $out/bin/ diff --git a/pkgs/by-name/au/autofs5/package.nix b/pkgs/by-name/au/autofs5/package.nix index e6595ead546665..f570fcdb32f3eb 100644 --- a/pkgs/by-name/au/autofs5/package.nix +++ b/pkgs/by-name/au/autofs5/package.nix @@ -1,6 +1,26 @@ -{ lib, stdenv, fetchurl, flex, bison, linuxHeaders, libtirpc, mount, umount, nfs-utils, e2fsprogs -, libxml2, libkrb5, kmod, openldap, sssd, cyrus_sasl, openssl, rpcsvc-proto, pkgconf -, fetchpatch, libnsl +{ + lib, + stdenv, + fetchurl, + flex, + bison, + linuxHeaders, + libtirpc, + mount, + umount, + nfs-utils, + e2fsprogs, + libxml2, + libkrb5, + kmod, + openldap, + sssd, + cyrus_sasl, + openssl, + rpcsvc-proto, + pkgconf, + fetchpatch, + libnsl, }: stdenv.mkDerivation rec { @@ -20,7 +40,7 @@ stdenv.mkDerivation rec { url = "mirror://kernel/linux/daemons/autofs/v5/patches-5.2.0/autofs-5.1.9-fix-ldap_parse_page_control-check.patch"; hash = "sha256-W757LU9r9kuzLeThif2a1olRtxNrJy5suemLS7yfbIU="; }) - (fetchpatch { + (fetchpatch { url = "mirror://kernel/linux/daemons/autofs/v5/patches-5.2.0/autofs-5.1.9-fix-crash-in-make_options_string.patch"; hash = "sha256-YjTdJ50iNhJ2UjFdrKYEFNt04z0PfmElbFa4GuSskLA="; }) @@ -47,10 +67,26 @@ stdenv.mkDerivation rec { #make install SUBDIRS="samples" # impure! ''; - buildInputs = [ linuxHeaders libtirpc libxml2 libkrb5 kmod openldap sssd - openssl cyrus_sasl rpcsvc-proto libnsl ]; + buildInputs = [ + linuxHeaders + libtirpc + libxml2 + libkrb5 + kmod + openldap + sssd + openssl + cyrus_sasl + rpcsvc-proto + libnsl + ]; - nativeBuildInputs = [ flex bison pkgconf libnsl.dev ]; + nativeBuildInputs = [ + flex + bison + pkgconf + libnsl.dev + ]; meta = { description = "Kernel-based automounter"; diff --git a/pkgs/by-name/au/autogen/package.nix b/pkgs/by-name/au/autogen/package.nix index e435716667191a..2c8578b8e94999 100644 --- a/pkgs/by-name/au/autogen/package.nix +++ b/pkgs/by-name/au/autogen/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, buildPackages, fetchurl, fetchpatch, autoreconfHook, which, pkg-config, perl, guile_2_2, libxml2 }: +{ + lib, + stdenv, + buildPackages, + fetchurl, + fetchpatch, + autoreconfHook, + which, + pkg-config, + perl, + guile_2_2, + libxml2, +}: stdenv.mkDerivation rec { pname = "autogen"; @@ -9,114 +21,144 @@ stdenv.mkDerivation rec { sha256 = "16mlbdys8q4ckxlvxyhwkdnh1ay9f6g0cyp1kylkpalgnik398gq"; }; - patches = let - dp = { ver ? "1%255.18.16-5", name, sha256 }: fetchurl { - url = "https://salsa.debian.org/debian/autogen/-/raw/debian/${ver}" - + "/debian/patches/${name}?inline=false"; - inherit name sha256; - }; - in [ - (dp { - name = "20_no_Werror.diff"; - sha256 = "08z4s2ifiqyaacjpd9pzr59w8m4j3548kkaq1bwvp2gjn29m680x"; - }) - (dp { - name = "30_ag_macros.m4_syntax_error.diff"; - sha256 = "1z8vmbwbkz3505wd33i2xx91mlf8rwsa7klndq37nw821skxwyh3"; - }) - (dp { - name = "31_allow_overriding_AGexe_for_crossbuild.diff"; - sha256 = "0h9wkc9bqb509knh8mymi43hg6n6sxg2lixvjlchcx7z0j7p8xkf"; - }) - (dp { - name = "40_suse_01-autogen-catch-race-error.patch"; - sha256 = "1cfkym2zds1f85md1m74snxzqmzlj7wd5jivgmyl342856848xav"; - }) - (dp { - name = "40_suse_03-gcc9-fix-wrestrict.patch"; - sha256 = "1ifdwi6gf96jc78jw7q4bfi5fgdldlf2nl55y20h6xb78kv0pznd"; - }) - (dp { - name = "40_suse_05-sprintf-overflow.patch"; - sha256 = "136m62k68w1h5k7iapynvbyipidw35js6pq21lsc6rpxvgp0n469"; - }) - (dp { - name = "40_suse_06-autogen-avoid-GCC-code-analysis-bug.patch"; - sha256 = "1d65zygzw2rpa00s0jy2y1bg29vkbhnjwlb5pv22rfv87zbk6z9q"; - }) - # Next upstream release will contain guile-3 support. We apply non-invasive - # patch meanwhile. - (fetchpatch { - name = "guile-3.patch"; - url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/sys-devel/autogen/files/autogen-5.18.16-guile-3.patch?id=43bcc61c56a5a7de0eaf806efec7d8c0e4c01ae7"; - sha256 = "18d7y1f6164dm1wlh7rzbacfygiwrmbc35a7qqsbdawpkhydm5lr"; - }) - (fetchpatch { - name = "lfs64.patch"; - url = "https://cygwin.com/cgit/cygwin-packages/autogen/plain/5.16.2-cygwin17.patch?id=6f39882873b3d1290ba3739e0557a84bfe05ba60"; - stripLen = 1; - hash = "sha256-6dk2imqForUHKhI82CTronWaS3KUWW/EKfA/JZZcRe0="; - }) - ]; - - outputs = [ "bin" "dev" "lib" "out" "man" "info" ]; + patches = + let + dp = + { + ver ? "1%255.18.16-5", + name, + sha256, + }: + fetchurl { + url = + "https://salsa.debian.org/debian/autogen/-/raw/debian/${ver}" + + "/debian/patches/${name}?inline=false"; + inherit name sha256; + }; + in + [ + (dp { + name = "20_no_Werror.diff"; + sha256 = "08z4s2ifiqyaacjpd9pzr59w8m4j3548kkaq1bwvp2gjn29m680x"; + }) + (dp { + name = "30_ag_macros.m4_syntax_error.diff"; + sha256 = "1z8vmbwbkz3505wd33i2xx91mlf8rwsa7klndq37nw821skxwyh3"; + }) + (dp { + name = "31_allow_overriding_AGexe_for_crossbuild.diff"; + sha256 = "0h9wkc9bqb509knh8mymi43hg6n6sxg2lixvjlchcx7z0j7p8xkf"; + }) + (dp { + name = "40_suse_01-autogen-catch-race-error.patch"; + sha256 = "1cfkym2zds1f85md1m74snxzqmzlj7wd5jivgmyl342856848xav"; + }) + (dp { + name = "40_suse_03-gcc9-fix-wrestrict.patch"; + sha256 = "1ifdwi6gf96jc78jw7q4bfi5fgdldlf2nl55y20h6xb78kv0pznd"; + }) + (dp { + name = "40_suse_05-sprintf-overflow.patch"; + sha256 = "136m62k68w1h5k7iapynvbyipidw35js6pq21lsc6rpxvgp0n469"; + }) + (dp { + name = "40_suse_06-autogen-avoid-GCC-code-analysis-bug.patch"; + sha256 = "1d65zygzw2rpa00s0jy2y1bg29vkbhnjwlb5pv22rfv87zbk6z9q"; + }) + # Next upstream release will contain guile-3 support. We apply non-invasive + # patch meanwhile. + (fetchpatch { + name = "guile-3.patch"; + url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/sys-devel/autogen/files/autogen-5.18.16-guile-3.patch?id=43bcc61c56a5a7de0eaf806efec7d8c0e4c01ae7"; + sha256 = "18d7y1f6164dm1wlh7rzbacfygiwrmbc35a7qqsbdawpkhydm5lr"; + }) + (fetchpatch { + name = "lfs64.patch"; + url = "https://cygwin.com/cgit/cygwin-packages/autogen/plain/5.16.2-cygwin17.patch?id=6f39882873b3d1290ba3739e0557a84bfe05ba60"; + stripLen = 1; + hash = "sha256-6dk2imqForUHKhI82CTronWaS3KUWW/EKfA/JZZcRe0="; + }) + ]; - nativeBuildInputs = [ - which pkg-config perl autoreconfHook/*patches applied*/ - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - # autogen needs a build autogen when cross-compiling - buildPackages.buildPackages.autogen buildPackages.texinfo + outputs = [ + "bin" + "dev" + "lib" + "out" + "man" + "info" ]; + + nativeBuildInputs = + [ + which + pkg-config + perl + autoreconfHook # patches applied + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + # autogen needs a build autogen when cross-compiling + buildPackages.buildPackages.autogen + buildPackages.texinfo + ]; buildInputs = [ - guile_2_2 libxml2 + guile_2_2 + libxml2 ]; preConfigure = '' export MAN_PAGE_DATE=$(date '+%Y-%m-%d' -d "@$SOURCE_DATE_EPOCH") ''; - configureFlags = [ - "--with-libxml2=${libxml2.dev}" - "--with-libxml2-cflags=-I${libxml2.dev}/include/libxml2" - # Make sure to use a static value for the timeout. If we do not set a value - # here autogen will select one based on the execution time of the configure - # phase which is not really reproducible. - # - # If you are curious about the number 78, it has been cargo-culted from - # Debian: https://salsa.debian.org/debian/autogen/-/blob/master/debian/rules#L21 - "--enable-timeout=78" - "CFLAGS=-D_FILE_OFFSET_BITS=64" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - # the configure check for regcomp wants to run a host program - "libopts_cv_with_libregex=yes" - #"MAKEINFO=${buildPackages.texinfo}/bin/makeinfo" - ] - # See: https://sourceforge.net/p/autogen/bugs/187/ - ++ lib.optionals stdenv.hostPlatform.isDarwin [ "ac_cv_func_utimensat=no" ]; + configureFlags = + [ + "--with-libxml2=${libxml2.dev}" + "--with-libxml2-cflags=-I${libxml2.dev}/include/libxml2" + # Make sure to use a static value for the timeout. If we do not set a value + # here autogen will select one based on the execution time of the configure + # phase which is not really reproducible. + # + # If you are curious about the number 78, it has been cargo-culted from + # Debian: https://salsa.debian.org/debian/autogen/-/blob/master/debian/rules#L21 + "--enable-timeout=78" + "CFLAGS=-D_FILE_OFFSET_BITS=64" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + # the configure check for regcomp wants to run a host program + "libopts_cv_with_libregex=yes" + #"MAKEINFO=${buildPackages.texinfo}/bin/makeinfo" + ] + # See: https://sourceforge.net/p/autogen/bugs/187/ + ++ lib.optionals stdenv.hostPlatform.isDarwin [ "ac_cv_func_utimensat=no" ]; #doCheck = true; # not reliable - postInstall = '' - mkdir -p $dev/bin - mv $bin/bin/autoopts-config $dev/bin + postInstall = + '' + mkdir -p $dev/bin + mv $bin/bin/autoopts-config $dev/bin - for f in $lib/lib/autogen/tpl-config.tlib $out/share/autogen/tpl-config.tlib; do - sed -e "s|$dev/include|/no-such-autogen-include-path|" -i $f - sed -e "s|$bin/bin|/no-such-autogen-bin-path|" -i $f - sed -e "s|$lib/lib|/no-such-autogen-lib-path|" -i $f - done + for f in $lib/lib/autogen/tpl-config.tlib $out/share/autogen/tpl-config.tlib; do + sed -e "s|$dev/include|/no-such-autogen-include-path|" -i $f + sed -e "s|$bin/bin|/no-such-autogen-bin-path|" -i $f + sed -e "s|$lib/lib|/no-such-autogen-lib-path|" -i $f + done - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - # remove build directory (/build/**, or /tmp/nix-build-**) from RPATHs - for f in "$bin"/bin/*; do - local nrp="$(patchelf --print-rpath "$f" | sed -E 's@(:|^)'$NIX_BUILD_TOP'[^:]*:@\1@g')" - patchelf --set-rpath "$nrp" "$f" - done - ''; + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + # remove build directory (/build/**, or /tmp/nix-build-**) from RPATHs + for f in "$bin"/bin/*; do + local nrp="$(patchelf --print-rpath "$f" | sed -E 's@(:|^)'$NIX_BUILD_TOP'[^:]*:@\1@g')" + patchelf --set-rpath "$nrp" "$f" + done + ''; meta = with lib; { description = "Automated text and program generation tool"; - license = with licenses; [ gpl3Plus lgpl3Plus ]; + license = with licenses; [ + gpl3Plus + lgpl3Plus + ]; homepage = "https://www.gnu.org/software/autogen/"; platforms = platforms.all; maintainers = [ ]; diff --git a/pkgs/by-name/au/autojump/package.nix b/pkgs/by-name/au/autojump/package.nix index 8305c82937ebd1..d0a60a4abbb5dc 100644 --- a/pkgs/by-name/au/autojump/package.nix +++ b/pkgs/by-name/au/autojump/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation rec { pname = "autojump"; @@ -51,6 +56,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/wting/autojump"; license = licenses.gpl3; platforms = platforms.all; - maintainers = with maintainers; [ domenkozar yurrriq ]; + maintainers = with maintainers; [ + domenkozar + yurrriq + ]; }; } diff --git a/pkgs/by-name/au/autokey/package.nix b/pkgs/by-name/au/autokey/package.nix index 91700299400a24..9e2b40106a2225 100644 --- a/pkgs/by-name/au/autokey/package.nix +++ b/pkgs/by-name/au/autokey/package.nix @@ -1,13 +1,14 @@ -{ lib -, python3Packages -, fetchFromGitHub -, wrapGAppsHook3 -, gobject-introspection -, gtksourceview3 -, libappindicator-gtk3 -, libnotify -, zenity -, wmctrl +{ + lib, + python3Packages, + fetchFromGitHub, + wrapGAppsHook3, + gobject-introspection, + gtksourceview3, + libappindicator-gtk3, + libnotify, + zenity, + wmctrl, }: python3Packages.buildPythonApplication rec { @@ -24,7 +25,10 @@ python3Packages.buildPythonApplication rec { # Tests appear to be broken with import errors within the project structure doCheck = false; - nativeBuildInputs = [ wrapGAppsHook3 gobject-introspection ]; + nativeBuildInputs = [ + wrapGAppsHook3 + gobject-introspection + ]; buildInputs = [ gtksourceview3 @@ -48,7 +52,7 @@ python3Packages.buildPythonApplication rec { dontWrapGApps = true; preFixup = '' - makeWrapperArgs+=(''${gappsWrapperArgs[@]} --prefix PATH : ${ lib.makeBinPath runtimeDeps }) + makeWrapperArgs+=(''${gappsWrapperArgs[@]} --prefix PATH : ${lib.makeBinPath runtimeDeps}) ''; postInstall = '' diff --git a/pkgs/by-name/au/automaticcomponenttoolkit/package.nix b/pkgs/by-name/au/automaticcomponenttoolkit/package.nix index 59a9914891d7e0..b113f228806335 100644 --- a/pkgs/by-name/au/automaticcomponenttoolkit/package.nix +++ b/pkgs/by-name/au/automaticcomponenttoolkit/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, go }: +{ + stdenv, + lib, + fetchFromGitHub, + go, +}: stdenv.mkDerivation rec { pname = "AutomaticComponentToolkit"; diff --git a/pkgs/by-name/au/automirror/package.nix b/pkgs/by-name/au/automirror/package.nix index 457303c6bc2684..8d8376542d28c5 100644 --- a/pkgs/by-name/au/automirror/package.nix +++ b/pkgs/by-name/au/automirror/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchFromGitHub, git, ronn}: +{ + lib, + stdenv, + fetchFromGitHub, + git, + ronn, +}: stdenv.mkDerivation rec { pname = "automirror"; @@ -13,7 +19,10 @@ stdenv.mkDerivation rec { patchPhase = "sed -i s#/usr##g Makefile"; - buildInputs = [ git ronn ]; + buildInputs = [ + git + ronn + ]; installFlags = [ "DESTDIR=$(out)" ]; diff --git a/pkgs/by-name/au/automysqlbackup/package.nix b/pkgs/by-name/au/automysqlbackup/package.nix index ec6d0cdc4afbd6..997b139cf324f1 100644 --- a/pkgs/by-name/au/automysqlbackup/package.nix +++ b/pkgs/by-name/au/automysqlbackup/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, mariadb, mailutils, pbzip2, pigz, bzip2, gzip }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + mariadb, + mailutils, + pbzip2, + pigz, + bzip2, + gzip, +}: stdenv.mkDerivation rec { pname = "automysqlbackup"; @@ -19,7 +30,16 @@ stdenv.mkDerivation rec { cp automysqlbackup $out/bin/ cp automysqlbackup.conf $out/etc/ - wrapProgram $out/bin/automysqlbackup --prefix PATH : ${lib.makeBinPath [ mariadb mailutils pbzip2 pigz bzip2 gzip ]} + wrapProgram $out/bin/automysqlbackup --prefix PATH : ${ + lib.makeBinPath [ + mariadb + mailutils + pbzip2 + pigz + bzip2 + gzip + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/au/autopanosiftc/package.nix b/pkgs/by-name/au/autopanosiftc/package.nix index 20874dd55e763d..b566852cbb0018 100644 --- a/pkgs/by-name/au/autopanosiftc/package.nix +++ b/pkgs/by-name/au/autopanosiftc/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, cmake, libpng, libtiff, libjpeg, panotools, libxml2 }: +{ + lib, + stdenv, + fetchurl, + cmake, + libpng, + libtiff, + libjpeg, + panotools, + libxml2, +}: stdenv.mkDerivation rec { pname = "autopano-sift-C"; @@ -10,7 +20,13 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libpng libtiff libjpeg panotools libxml2 ]; + buildInputs = [ + libpng + libtiff + libjpeg + panotools + libxml2 + ]; patches = [ (fetchurl { diff --git a/pkgs/by-name/au/autoprefixer/package.nix b/pkgs/by-name/au/autoprefixer/package.nix index b1977eba41e852..f3efe088f21fa0 100644 --- a/pkgs/by-name/au/autoprefixer/package.nix +++ b/pkgs/by-name/au/autoprefixer/package.nix @@ -5,8 +5,9 @@ pnpm_9, fetchFromGitHub, callPackage, - nix-update-script -}: stdenv.mkDerivation (finalAttrs: { + nix-update-script, +}: +stdenv.mkDerivation (finalAttrs: { pname = "autoprefixer"; version = "10.4.20"; diff --git a/pkgs/by-name/au/autoprefixer/tests/simple-execution.nix b/pkgs/by-name/au/autoprefixer/tests/simple-execution.nix index 9445a0bded5f4d..9c55e869b500ab 100644 --- a/pkgs/by-name/au/autoprefixer/tests/simple-execution.nix +++ b/pkgs/by-name/au/autoprefixer/tests/simple-execution.nix @@ -4,22 +4,21 @@ let inherit (autoprefixer) pname version; in -runCommand "${pname}-tests" { meta.timeout = 60; } - '' - # get version of installed program and compare with package version - claimed_version="$(${autoprefixer}/bin/autoprefixer --version | awk '{print $2}')" - if [[ "$claimed_version" != "${version}" ]]; then - echo "Error: program version does not match package version ($claimed_version != ${version})" - exit 1 - fi +runCommand "${pname}-tests" { meta.timeout = 60; } '' + # get version of installed program and compare with package version + claimed_version="$(${autoprefixer}/bin/autoprefixer --version | awk '{print $2}')" + if [[ "$claimed_version" != "${version}" ]]; then + echo "Error: program version does not match package version ($claimed_version != ${version})" + exit 1 + fi - # run dummy commands - ${autoprefixer}/bin/autoprefixer --help > /dev/null - ${autoprefixer}/bin/autoprefixer --info > /dev/null + # run dummy commands + ${autoprefixer}/bin/autoprefixer --help > /dev/null + ${autoprefixer}/bin/autoprefixer --info > /dev/null - # Testing the actual functionality is done in the test for postcss - # because autoprefixer is a postcss plugin + # Testing the actual functionality is done in the test for postcss + # because autoprefixer is a postcss plugin - # needed for Nix to register the command as successful - touch $out - '' + # needed for Nix to register the command as successful + touch $out +'' diff --git a/pkgs/by-name/au/autopsy/package.nix b/pkgs/by-name/au/autopsy/package.nix index a2693eb5b8bc36..e9fc15a1007634 100644 --- a/pkgs/by-name/au/autopsy/package.nix +++ b/pkgs/by-name/au/autopsy/package.nix @@ -1,8 +1,21 @@ -{ stdenv, lib, makeWrapper, fetchzip, testdisk, imagemagick, jdk, findutils, sleuthkit, ... }: +{ + stdenv, + lib, + makeWrapper, + fetchzip, + testdisk, + imagemagick, + jdk, + findutils, + sleuthkit, + ... +}: let - jdkWithJfx = jdk.override (lib.optionalAttrs stdenv.hostPlatform.isLinux { - enableJavaFX = true; - }); + jdkWithJfx = jdk.override ( + lib.optionalAttrs stdenv.hostPlatform.isLinux { + enableJavaFX = true; + } + ); in stdenv.mkDerivation rec { pname = "autopsy"; @@ -13,8 +26,15 @@ stdenv.mkDerivation rec { hash = "sha256-32iOQA3+ykltCYW/MpqCVxyhh3mm6eYzY+t0smAsWRw="; }; - nativeBuildInputs = [ makeWrapper findutils ]; - buildInputs = [ testdisk imagemagick jdkWithJfx ]; + nativeBuildInputs = [ + makeWrapper + findutils + ]; + buildInputs = [ + testdisk + imagemagick + jdkWithJfx + ]; installPhase = '' runHook preInstall @@ -29,7 +49,13 @@ stdenv.mkDerivation rec { wrapProgram $out/bin/autopsy \ --run 'export SOLR_LOGS_DIR="$HOME/.autopsy/dev/var/log"' \ --run 'export SOLR_PID_DIR="$HOME/.autopsy/dev"' \ - --prefix PATH : "${lib.makeBinPath [ testdisk imagemagick jdkWithJfx ]}" + --prefix PATH : "${ + lib.makeBinPath [ + testdisk + imagemagick + jdkWithJfx + ] + }" runHook postInstall ''; @@ -39,7 +65,18 @@ stdenv.mkDerivation rec { homepage = "https://www.sleuthkit.org/autopsy"; changelog = "https://github.com/sleuthkit/autopsy/releases/tag/autopsy-${version}"; # Autopsy brings a lot of vendored dependencies - license = with lib.licenses; [ asl20 ipl10 lgpl3Only lgpl21Only zlib wtfpl bsd3 cc-by-30 mit gpl2Only ]; + license = with lib.licenses; [ + asl20 + ipl10 + lgpl3Only + lgpl21Only + zlib + wtfpl + bsd3 + cc-by-30 + mit + gpl2Only + ]; maintainers = with lib.maintainers; [ zebreus ]; mainProgram = "autopsy"; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; diff --git a/pkgs/by-name/au/autorandr/package.nix b/pkgs/by-name/au/autorandr/package.nix index eb7f8c16c86dd3..cd6d1db71f7eb3 100644 --- a/pkgs/by-name/au/autorandr/package.nix +++ b/pkgs/by-name/au/autorandr/package.nix @@ -1,10 +1,11 @@ -{ lib -, python3 -, fetchFromGitHub -, systemd -, xrandr -, installShellFiles -, desktop-file-utils +{ + lib, + python3, + fetchFromGitHub, + systemd, + xrandr, + installShellFiles, + desktop-file-utils, }: python3.pkgs.buildPythonApplication rec { @@ -19,7 +20,10 @@ python3.pkgs.buildPythonApplication rec { hash = "sha256-8FMfy3GCN4z/TnfefU2DbKqV3W35I29/SuGGqeOrjNg"; }; - nativeBuildInputs = [ installShellFiles desktop-file-utils ]; + nativeBuildInputs = [ + installShellFiles + desktop-file-utils + ]; propagatedBuildInputs = with python3.pkgs; [ packaging ]; buildPhase = '' @@ -30,7 +34,10 @@ python3.pkgs.buildPythonApplication rec { patches = [ ./0001-don-t-use-sys.executable.patch ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; installPhase = '' runHook preInstall @@ -48,18 +55,23 @@ python3.pkgs.buildPythonApplication rec { make install TARGETS='manpage' PREFIX=$man - ${if systemd != null then '' - make install TARGETS='systemd udev' PREFIX=$out DESTDIR=$out \ - SYSTEMD_UNIT_DIR=/lib/systemd/system \ - UDEV_RULES_DIR=/etc/udev/rules.d - substituteInPlace $out/etc/udev/rules.d/40-monitor-hotplug.rules \ - --replace /bin/systemctl "/run/current-system/systemd/bin/systemctl" - '' else '' - make install TARGETS='pmutils' DESTDIR=$out \ - PM_SLEEPHOOKS_DIR=/lib/pm-utils/sleep.d - make install TARGETS='udev' PREFIX=$out DESTDIR=$out \ - UDEV_RULES_DIR=/etc/udev/rules.d - ''} + ${ + if systemd != null then + '' + make install TARGETS='systemd udev' PREFIX=$out DESTDIR=$out \ + SYSTEMD_UNIT_DIR=/lib/systemd/system \ + UDEV_RULES_DIR=/etc/udev/rules.d + substituteInPlace $out/etc/udev/rules.d/40-monitor-hotplug.rules \ + --replace /bin/systemctl "/run/current-system/systemd/bin/systemctl" + '' + else + '' + make install TARGETS='pmutils' DESTDIR=$out \ + PM_SLEEPHOOKS_DIR=/lib/pm-utils/sleep.d + make install TARGETS='udev' PREFIX=$out DESTDIR=$out \ + UDEV_RULES_DIR=/etc/udev/rules.d + '' + } runHook postInstall ''; diff --git a/pkgs/by-name/au/autorestic/package.nix b/pkgs/by-name/au/autorestic/package.nix index 2d0f5b019626b6..4df100e0bfaf43 100644 --- a/pkgs/by-name/au/autorestic/package.nix +++ b/pkgs/by-name/au/autorestic/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, installShellFiles, buildGoModule }: +{ + lib, + fetchFromGitHub, + installShellFiles, + buildGoModule, +}: buildGoModule rec { pname = "autorestic"; diff --git a/pkgs/by-name/au/autorevision/package.nix b/pkgs/by-name/au/autorevision/package.nix index f0d97976938095..1fd604895e9cfb 100644 --- a/pkgs/by-name/au/autorevision/package.nix +++ b/pkgs/by-name/au/autorevision/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchurl, asciidoc, libxml2, docbook_xml_dtd_45, libxslt -, docbook_xsl, diffutils, coreutils, gnugrep, gnused +{ + lib, + stdenv, + fetchurl, + asciidoc, + libxml2, + docbook_xml_dtd_45, + libxslt, + docbook_xsl, + diffutils, + coreutils, + gnugrep, + gnused, }: stdenv.mkDerivation rec { @@ -12,7 +23,11 @@ stdenv.mkDerivation rec { }; buildInputs = [ - asciidoc libxml2 docbook_xml_dtd_45 libxslt docbook_xsl + asciidoc + libxml2 + docbook_xml_dtd_45 + libxslt + docbook_xsl ]; installFlags = [ "prefix=$(out)" ]; diff --git a/pkgs/by-name/au/autospotting/package.nix b/pkgs/by-name/au/autospotting/package.nix index 0018102bd8176a..c7d82905bf708d 100644 --- a/pkgs/by-name/au/autospotting/package.nix +++ b/pkgs/by-name/au/autospotting/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "autospotting"; @@ -15,7 +19,10 @@ buildGoModule rec { excludedPackages = [ "scripts" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Automatically convert your existing AutoScaling groups to up to 90% cheaper spot instances with minimal configuration changes"; diff --git a/pkgs/by-name/au/autossh/package.nix b/pkgs/by-name/au/autossh/package.nix index 6d73715d832d25..a533e428dd0cdc 100644 --- a/pkgs/by-name/au/autossh/package.nix +++ b/pkgs/by-name/au/autossh/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, openssh }: +{ + lib, + stdenv, + fetchurl, + openssh, +}: stdenv.mkDerivation rec { pname = "autossh"; diff --git a/pkgs/by-name/au/autosuspend/package.nix b/pkgs/by-name/au/autosuspend/package.nix index 81bdcdc55af65b..85d691a966379a 100644 --- a/pkgs/by-name/au/autosuspend/package.nix +++ b/pkgs/by-name/au/autosuspend/package.nix @@ -1,7 +1,8 @@ -{ lib -, dbus -, fetchFromGitHub -, python3 +{ + lib, + dbus, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -61,7 +62,10 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://autosuspend.readthedocs.io"; changelog = "https://github.com/languitar/autosuspend/releases/tag/v${version}"; license = licenses.gpl2Only; - maintainers = with maintainers; [ bzizou anthonyroussel ]; + maintainers = with maintainers; [ + bzizou + anthonyroussel + ]; mainProgram = "autosuspend"; platforms = platforms.linux; }; diff --git a/pkgs/by-name/au/autotalent/package.nix b/pkgs/by-name/au/autotalent/package.nix index 8e77cc352b1555..214c06fac56553 100644 --- a/pkgs/by-name/au/autotalent/package.nix +++ b/pkgs/by-name/au/autotalent/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { pname = "autotalent"; diff --git a/pkgs/by-name/au/autotiling-rs/package.nix b/pkgs/by-name/au/autotiling-rs/package.nix index 09469401667959..c7ba1ff24dc8a1 100644 --- a/pkgs/by-name/au/autotiling-rs/package.nix +++ b/pkgs/by-name/au/autotiling-rs/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "autotiling-rs"; diff --git a/pkgs/by-name/au/autotools-language-server/package.nix b/pkgs/by-name/au/autotools-language-server/package.nix index 68439d57dcf072..5378476905e6bf 100644 --- a/pkgs/by-name/au/autotools-language-server/package.nix +++ b/pkgs/by-name/au/autotools-language-server/package.nix @@ -1,7 +1,8 @@ -{ lib -, python311 -, fetchFromGitHub -, fetchpatch +{ + lib, + python311, + fetchFromGitHub, + fetchpatch, }: let @@ -9,7 +10,7 @@ let self = python3; packageOverrides = _: super: { tree-sitter = super.tree-sitter_0_21; - lsp-tree-sitter = super.lsp-tree-sitter.overridePythonAttrs(__: { + lsp-tree-sitter = super.lsp-tree-sitter.overridePythonAttrs (__: { pythonRelaxDeps = [ "tree-sitter" ]; }); }; diff --git a/pkgs/by-name/au/autotrace/package.nix b/pkgs/by-name/au/autotrace/package.nix index 82bba3c3fc53d1..40be3cef2fa89b 100644 --- a/pkgs/by-name/au/autotrace/package.nix +++ b/pkgs/by-name/au/autotrace/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, gettext -, intltool -, pkg-config -, glib -, imagemagick -, libpng -, pstoedit -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + gettext, + intltool, + pkg-config, + glib, + imagemagick, + libpng, + pstoedit, + darwin, }: stdenv.mkDerivation rec { @@ -40,14 +41,16 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - glib - imagemagick - libpng - pstoedit - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + glib + imagemagick + libpng + pstoedit + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ]; meta = with lib; { homepage = "https://github.com/autotrace/autotrace"; diff --git a/pkgs/by-name/av/avfs/package.nix b/pkgs/by-name/av/avfs/package.nix index a59c2695c20a51..0613bcc4b6d390 100644 --- a/pkgs/by-name/av/avfs/package.nix +++ b/pkgs/by-name/av/avfs/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, fuse, xz }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + fuse, + xz, +}: stdenv.mkDerivation rec { pname = "avfs"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ fuse xz ]; + buildInputs = [ + fuse + xz + ]; configureFlags = [ "--enable-library" diff --git a/pkgs/by-name/av/aviator/package.nix b/pkgs/by-name/av/aviator/package.nix index 69b076834f7ed5..17b7a7d2e7cf06 100644 --- a/pkgs/by-name/av/aviator/package.nix +++ b/pkgs/by-name/av/aviator/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "aviator"; diff --git a/pkgs/by-name/av/avizo/package.nix b/pkgs/by-name/av/avizo/package.nix index 0b05e9ce5499f5..47a44f05aa730c 100644 --- a/pkgs/by-name/av/avizo/package.nix +++ b/pkgs/by-name/av/avizo/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, vala -, gtk3 -, glib -, gtk-layer-shell -, dbus -, dbus-glib -, librsvg -, gobject-introspection -, gdk-pixbuf -, wrapGAppsHook3 -, pamixer -, brightnessctl +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + vala, + gtk3, + glib, + gtk-layer-shell, + dbus, + dbus-glib, + librsvg, + gobject-introspection, + gdk-pixbuf, + wrapGAppsHook3, + pamixer, + brightnessctl, }: stdenv.mkDerivation rec { @@ -29,9 +30,24 @@ stdenv.mkDerivation rec { sha256 = "sha256-Vj8OrNlAstl0AXTeVAPdEf5JgnAmJwl9s3Jdc0ZiYQc="; }; - nativeBuildInputs = [ meson ninja pkg-config vala gobject-introspection wrapGAppsHook3 ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + vala + gobject-introspection + wrapGAppsHook3 + ]; - buildInputs = [ dbus dbus-glib gdk-pixbuf glib gtk-layer-shell gtk3 librsvg ]; + buildInputs = [ + dbus + dbus-glib + gdk-pixbuf + glib + gtk-layer-shell + gtk3 + librsvg + ]; postInstall = '' wrapProgram $out/bin/volumectl --suffix PATH : $out/bin:${lib.makeBinPath ([ pamixer ])} diff --git a/pkgs/by-name/av/avocode/package.nix b/pkgs/by-name/av/avocode/package.nix index 0878d91bba8a8a..b10fe128b1ef76 100644 --- a/pkgs/by-name/av/avocode/package.nix +++ b/pkgs/by-name/av/avocode/package.nix @@ -1,6 +1,35 @@ -{ lib, stdenv, makeDesktopItem, fetchurl, unzip -, gdk-pixbuf, glib, gtk3, atk, at-spi2-atk, pango, cairo, freetype, fontconfig, dbus, nss, nspr, alsa-lib, cups, expat, udev, adwaita-icon-theme -, xorg, mozjpeg, makeWrapper, wrapGAppsHook3, libuuid, at-spi2-core, libdrm, mesa, libxkbcommon +{ + lib, + stdenv, + makeDesktopItem, + fetchurl, + unzip, + gdk-pixbuf, + glib, + gtk3, + atk, + at-spi2-atk, + pango, + cairo, + freetype, + fontconfig, + dbus, + nss, + nspr, + alsa-lib, + cups, + expat, + udev, + adwaita-icon-theme, + xorg, + mozjpeg, + makeWrapper, + wrapGAppsHook3, + libuuid, + at-spi2-core, + libdrm, + mesa, + libxkbcommon, }: stdenv.mkDerivation rec { @@ -12,43 +41,46 @@ stdenv.mkDerivation rec { sha256 = "sha256-vNQT4jyMIIAk1pV3Hrp40nawFutWCv7xtwg2gU6ejy0="; }; - libPath = lib.makeLibraryPath (with xorg; [ - stdenv.cc.cc - at-spi2-core.out - gdk-pixbuf - glib - gtk3 - atk - at-spi2-atk - pango - cairo - freetype - fontconfig - dbus - nss - nspr - alsa-lib - cups - expat - udev - libX11 - libxcb - libxshmfence - libxkbcommon - libXi - libXcursor - libXdamage - libXrandr - libXcomposite - libXext - libXfixes - libXrender - libXtst - libXScrnSaver - libuuid - libdrm - mesa - ]); + libPath = lib.makeLibraryPath ( + with xorg; + [ + stdenv.cc.cc + at-spi2-core.out + gdk-pixbuf + glib + gtk3 + atk + at-spi2-atk + pango + cairo + freetype + fontconfig + dbus + nss + nspr + alsa-lib + cups + expat + udev + libX11 + libxcb + libxshmfence + libxkbcommon + libXi + libXcursor + libXdamage + libXrandr + libXcomposite + libXext + libXfixes + libXrender + libXtst + libXScrnSaver + libuuid + libdrm + mesa + ] + ); desktopItem = makeDesktopItem { name = "Avocode"; @@ -60,8 +92,15 @@ stdenv.mkDerivation rec { comment = "The bridge between designers and developers"; }; - nativeBuildInputs = [makeWrapper wrapGAppsHook3 unzip]; - buildInputs = [ gtk3 adwaita-icon-theme ]; + nativeBuildInputs = [ + makeWrapper + wrapGAppsHook3 + unzip + ]; + buildInputs = [ + gtk3 + adwaita-icon-theme + ]; # src is producing multiple folder on unzip so we must # override unpackCmd to extract it into newly created folder diff --git a/pkgs/by-name/av/avr-sim/package.nix b/pkgs/by-name/av/avr-sim/package.nix index 38f8b246f62a60..9a4ad182a95fe3 100644 --- a/pkgs/by-name/av/avr-sim/package.nix +++ b/pkgs/by-name/av/avr-sim/package.nix @@ -27,9 +27,20 @@ stdenv.mkDerivation rec { hash = "sha256-7MgUzMs+l+3RVUbORAWyU1OUpgrKIeWhS+ObgRJtOHc="; }; - nativeBuildInputs = [lazarus fpc]; + nativeBuildInputs = [ + lazarus + fpc + ]; - buildInputs = [pango cairo glib atk gtk2 libX11 gdk-pixbuf]; + buildInputs = [ + pango + cairo + glib + atk + gtk2 + libX11 + gdk-pixbuf + ]; NIX_LDFLAGS = "--as-needed -rpath ${lib.makeLibraryPath buildInputs}"; @@ -56,6 +67,6 @@ stdenv.mkDerivation rec { homepage = "http://www.avr-asm-tutorial.net/avr_sim/index_en.html"; license = licenses.unfree; platforms = platforms.unix; - maintainers = with maintainers; [ameer]; + maintainers = with maintainers; [ ameer ]; }; } diff --git a/pkgs/by-name/av/avr8burnomat/package.nix b/pkgs/by-name/av/avr8burnomat/package.nix index 0ee98bb954d48a..04051bcb3fdc09 100644 --- a/pkgs/by-name/av/avr8burnomat/package.nix +++ b/pkgs/by-name/av/avr8burnomat/package.nix @@ -1,11 +1,19 @@ -{ lib, stdenv, fetchurl, unzip, runtimeShell }: +{ + lib, + stdenv, + fetchurl, + unzip, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "avr8-burn-omat"; version = "2.1.2"; src = fetchurl { - url = "http://avr8-burn-o-mat.aaabbb.de/AVR8_Burn-O-Mat_${lib.replaceStrings ["."] ["_"] version}.zip"; + url = "http://avr8-burn-o-mat.aaabbb.de/AVR8_Burn-O-Mat_${ + lib.replaceStrings [ "." ] [ "_" ] version + }.zip"; sha256 = "02k0fd0cd3y1yqip36wr3bkxbywp8913w4y7jdg6qwqxjnii58ln"; }; diff --git a/pkgs/by-name/av/avra/package.nix b/pkgs/by-name/av/avra/package.nix index 8e2d2558c571ac..4b9c90a8c5a8a7 100644 --- a/pkgs/by-name/av/avra/package.nix +++ b/pkgs/by-name/av/avra/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "avra"; diff --git a/pkgs/by-name/av/avrdude/package.nix b/pkgs/by-name/av/avrdude/package.nix index 29edb66f9f5f10..ffa722674445bb 100644 --- a/pkgs/by-name/av/avrdude/package.nix +++ b/pkgs/by-name/av/avrdude/package.nix @@ -1,10 +1,29 @@ -{ lib, callPackage, stdenv, fetchFromGitHub, cmake, bison, flex, pkg-config, libusb1, elfutils -, libftdi1, readline, hidapi, libserialport, libusb-compat-0_1 -# Documentation building doesn't work on Darwin. It fails with: -# Undefined subroutine &Locale::Messages::dgettext called in ... texi2html -# -# https://github.com/NixOS/nixpkgs/issues/224761 -, docSupport ? (!stdenv.hostPlatform.isDarwin), texliveMedium, texinfo, texi2html, unixtools }: +{ + lib, + callPackage, + stdenv, + fetchFromGitHub, + cmake, + bison, + flex, + pkg-config, + libusb1, + elfutils, + libftdi1, + readline, + hidapi, + libserialport, + libusb-compat-0_1, + # Documentation building doesn't work on Darwin. It fails with: + # Undefined subroutine &Locale::Messages::dgettext called in ... texi2html + # + # https://github.com/NixOS/nixpkgs/issues/224761 + docSupport ? (!stdenv.hostPlatform.isDarwin), + texliveMedium, + texinfo, + texi2html, + unixtools, +}: let useElfutils = lib.meta.availableOn stdenv.hostPlatform elfutils; @@ -21,12 +40,19 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "w58HVCvKuWpGJwllupbj7ndeq4iE9LPs/IjFSUN0DOU="; }; - nativeBuildInputs = [ cmake bison flex pkg-config ] ++ lib.optionals docSupport [ - unixtools.more - texliveMedium - texinfo - texi2html - ]; + nativeBuildInputs = + [ + cmake + bison + flex + pkg-config + ] + ++ lib.optionals docSupport [ + unixtools.more + texliveMedium + texinfo + texi2html + ]; buildInputs = [ (if useElfutils then elfutils else finalAttrs.finalPackage.passthru.libelf) @@ -45,8 +71,12 @@ stdenv.mkDerivation (finalAttrs: { # Not used: # -DHAVE_LINUXGPIO=ON because it's incompatible with libgpiod 2.x - cmakeFlags = lib.optionals docSupport [ "-DBUILD_DOC=ON" ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ "-DHAVE_LINUXSPI=ON" "-DHAVE_PARPORT=ON" ]; + cmakeFlags = + lib.optionals docSupport [ "-DBUILD_DOC=ON" ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "-DHAVE_LINUXSPI=ON" + "-DHAVE_PARPORT=ON" + ]; passthru = { # Vendored and mutated copy of libelf for avrdudes use. diff --git a/pkgs/by-name/av/avrdudess/package.nix b/pkgs/by-name/av/avrdudess/package.nix index 01dbf16f007817..6f767e3ae944a2 100644 --- a/pkgs/by-name/av/avrdudess/package.nix +++ b/pkgs/by-name/av/avrdudess/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, runtimeShell, fetchurl, unzip, mono, avrdude, gtk2, xdg-utils }: +{ + lib, + stdenv, + runtimeShell, + fetchurl, + unzip, + mono, + avrdude, + gtk2, + xdg-utils, +}: stdenv.mkDerivation { pname = "avrdudess"; @@ -22,10 +32,20 @@ stdenv.mkDerivation { cat >> "$out/bin/avrdudess" << __EOF__ #!${runtimeShell} - export LD_LIBRARY_PATH="${lib.makeLibraryPath [gtk2 mono]}" + export LD_LIBRARY_PATH="${ + lib.makeLibraryPath [ + gtk2 + mono + ] + }" # We need PATH from user env for xdg-open to find its tools, which # typically depend on the currently running desktop environment. - export PATH="\$PATH:${lib.makeBinPath [ avrdude xdg-utils ]}" + export PATH="\$PATH:${ + lib.makeBinPath [ + avrdude + xdg-utils + ] + }" # avrdudess must have its resource files in its current working directory cd $out/avrdudess && exec ${mono}/bin/mono "$out/avrdudess/avrdudess.exe" "\$@" diff --git a/pkgs/by-name/av/avro-c/package.nix b/pkgs/by-name/av/avro-c/package.nix index 53f1d4430cc97d..ad598d511e0849 100644 --- a/pkgs/by-name/av/avro-c/package.nix +++ b/pkgs/by-name/av/avro-c/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, cmake, fetchurl, pkg-config, jansson, snappy, xz, zlib }: +{ + lib, + stdenv, + cmake, + fetchurl, + pkg-config, + jansson, + snappy, + xz, + zlib, +}: stdenv.mkDerivation rec { pname = "avro-c"; @@ -13,9 +23,17 @@ stdenv.mkDerivation rec { patchShebangs . ''; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; - buildInputs = [ jansson snappy xz zlib ]; + buildInputs = [ + jansson + snappy + xz + zlib + ]; meta = with lib; { description = "C library which implements parts of the Avro Specification"; diff --git a/pkgs/by-name/av/avro-cpp/package.nix b/pkgs/by-name/av/avro-cpp/package.nix index d8735e0b9143df..f82ef1924dbe3a 100644 --- a/pkgs/by-name/av/avro-cpp/package.nix +++ b/pkgs/by-name/av/avro-cpp/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, cmake -, boost -, python3 +{ + lib, + stdenv, + fetchurl, + fetchpatch, + cmake, + boost, + python3, }: stdenv.mkDerivation rec { @@ -26,7 +27,10 @@ stdenv.mkDerivation rec { ]; patchFlags = [ "-p3" ]; - nativeBuildInputs = [ cmake python3 ]; + nativeBuildInputs = [ + cmake + python3 + ]; buildInputs = [ boost ]; preConfigure = '' diff --git a/pkgs/by-name/aw/awatcher/package.nix b/pkgs/by-name/aw/awatcher/package.nix index a1960efd1a7472..a2fbb0b7173d73 100644 --- a/pkgs/by-name/aw/awatcher/package.nix +++ b/pkgs/by-name/aw/awatcher/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, openssl -, pkg-config +{ + lib, + rustPlatform, + fetchFromGitHub, + openssl, + pkg-config, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/aw/awf/package.nix b/pkgs/by-name/aw/awf/package.nix index d72b5dc51ed35d..9423dda218c6cb 100644 --- a/pkgs/by-name/aw/awf/package.nix +++ b/pkgs/by-name/aw/awf/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, gtk2, gtk3, pkg-config -, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gtk2, + gtk3, + pkg-config, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "awf"; @@ -12,9 +20,16 @@ stdenv.mkDerivation rec { sha256 = "0jl2kxwpvf2n8974zzyp69mqhsbjnjcqm39y0jvijvjb1iy8iman"; }; - nativeBuildInputs = [ autoreconfHook pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + wrapGAppsHook3 + ]; - buildInputs = [ gtk2 gtk3 ]; + buildInputs = [ + gtk2 + gtk3 + ]; autoreconfPhase = '' patchShebangs ./autogen.sh diff --git a/pkgs/by-name/aw/aws-azure-login/package.nix b/pkgs/by-name/aw/aws-azure-login/package.nix index fc693e3eed012c..86ff83af091a78 100644 --- a/pkgs/by-name/aw/aws-azure-login/package.nix +++ b/pkgs/by-name/aw/aws-azure-login/package.nix @@ -1,13 +1,14 @@ -{ lib -, callPackage -, stdenv -, chromium -, fetchFromGitHub -, fetchYarnDeps -, makeWrapper -, nodejs -, fixup-yarn-lock -, yarn +{ + lib, + callPackage, + stdenv, + chromium, + fetchFromGitHub, + fetchYarnDeps, + makeWrapper, + nodejs, + fixup-yarn-lock, + yarn, }: stdenv.mkDerivation (finalAttrs: { pname = "aws-azure-login"; diff --git a/pkgs/by-name/aw/aws-azure-login/tests.nix b/pkgs/by-name/aw/aws-azure-login/tests.nix index 694492322c86fd..f4bad22b97399b 100644 --- a/pkgs/by-name/aw/aws-azure-login/tests.nix +++ b/pkgs/by-name/aw/aws-azure-login/tests.nix @@ -1,11 +1,13 @@ -{ lib -, runCommand -, package +{ + lib, + runCommand, + package, }: - runCommand "${package.pname}-tests" - { - HOME = "/tmp/home"; - } '' +runCommand "${package.pname}-tests" + { + HOME = "/tmp/home"; + } + '' mkdir -p "''${HOME}/.aws" cat > "''${HOME}/.aws/config" <<'EOF' [profile my-profile] diff --git a/pkgs/by-name/aw/aws-c-auth/package.nix b/pkgs/by-name/aw/aws-c-auth/package.nix index 70aa863a7ce21a..7de2f221a0e638 100644 --- a/pkgs/by-name/aw/aws-c-auth/package.nix +++ b/pkgs/by-name/aw/aws-c-auth/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, aws-c-cal -, aws-c-common -, aws-c-compression -, aws-c-http -, aws-c-io -, aws-c-sdkutils -, cmake -, nix -, s2n-tls +{ + lib, + stdenv, + fetchFromGitHub, + aws-c-cal, + aws-c-common, + aws-c-compression, + aws-c-http, + aws-c-io, + aws-c-sdkutils, + cmake, + nix, + s2n-tls, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/aw/aws-c-common/package.nix b/pkgs/by-name/aw/aws-c-common/package.nix index 8166497efa5013..8c3bf32db72ca8 100644 --- a/pkgs/by-name/aw/aws-c-common/package.nix +++ b/pkgs/by-name/aw/aws-c-common/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, nix +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + nix, }: stdenv.mkDerivation rec { @@ -18,28 +19,34 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - cmakeFlags = [ - "-DBUILD_SHARED_LIBS=ON" - ] ++ lib.optionals stdenv.hostPlatform.isRiscV [ - "-DCMAKE_C_FLAGS=-fasynchronous-unwind-tables" - ]; + cmakeFlags = + [ + "-DBUILD_SHARED_LIBS=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isRiscV [ + "-DCMAKE_C_FLAGS=-fasynchronous-unwind-tables" + ]; # aws-c-common misuses cmake modules, so we need # to manually add a MODULE_PATH to its consumers setupHook = ./setup-hook.sh; # Prevent the execution of tests known to be flaky. - preCheck = let - ignoreTests = [ - "promise_test_multiple_waiters" - ] ++ lib.optionals stdenv.hostPlatform.isMusl [ - "sba_metrics" # https://github.com/awslabs/aws-c-common/issues/839 - ]; - in '' - cat <CTestCustom.cmake - SET(CTEST_CUSTOM_TESTS_IGNORE ${toString ignoreTests}) - EOW - ''; + preCheck = + let + ignoreTests = + [ + "promise_test_multiple_waiters" + ] + ++ lib.optionals stdenv.hostPlatform.isMusl [ + "sba_metrics" # https://github.com/awslabs/aws-c-common/issues/839 + ]; + in + '' + cat <CTestCustom.cmake + SET(CTEST_CUSTOM_TESTS_IGNORE ${toString ignoreTests}) + EOW + ''; doCheck = true; @@ -52,6 +59,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/awslabs/aws-c-common"; license = licenses.asl20; platforms = platforms.unix; - maintainers = with maintainers; [ orivej r-burns ]; + maintainers = with maintainers; [ + orivej + r-burns + ]; }; } diff --git a/pkgs/by-name/aw/aws-c-compression/package.nix b/pkgs/by-name/aw/aws-c-compression/package.nix index cb115f531f501a..8ef11be4baf884 100644 --- a/pkgs/by-name/aw/aws-c-compression/package.nix +++ b/pkgs/by-name/aw/aws-c-compression/package.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, aws-c-common -, cmake -, nix +{ + lib, + stdenv, + fetchFromGitHub, + aws-c-common, + cmake, + nix, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/aw/aws-c-event-stream/package.nix b/pkgs/by-name/aw/aws-c-event-stream/package.nix index 9b568b3721413b..1e5175a02f2c7d 100644 --- a/pkgs/by-name/aw/aws-c-event-stream/package.nix +++ b/pkgs/by-name/aw/aws-c-event-stream/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, cmake, aws-c-cal, aws-c-common, aws-c-io, aws-checksums, nix, s2n-tls, libexecinfo }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + aws-c-cal, + aws-c-common, + aws-c-io, + aws-checksums, + nix, + s2n-tls, + libexecinfo, +}: stdenv.mkDerivation rec { pname = "aws-c-event-stream"; @@ -13,8 +25,13 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ aws-c-cal aws-c-common aws-c-io aws-checksums s2n-tls ] - ++ lib.optional stdenv.hostPlatform.isMusl libexecinfo; + buildInputs = [ + aws-c-cal + aws-c-common + aws-c-io + aws-checksums + s2n-tls + ] ++ lib.optional stdenv.hostPlatform.isMusl libexecinfo; cmakeFlags = [ "-DBUILD_SHARED_LIBS:BOOL=ON" diff --git a/pkgs/by-name/aw/aws-c-http/package.nix b/pkgs/by-name/aw/aws-c-http/package.nix index ac35fd5d57b052..4939dd9b54c4d3 100644 --- a/pkgs/by-name/aw/aws-c-http/package.nix +++ b/pkgs/by-name/aw/aws-c-http/package.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, fetchFromGitHub -, aws-c-cal -, aws-c-common -, aws-c-compression -, aws-c-io -, cmake -, nix -, s2n-tls +{ + lib, + stdenv, + fetchFromGitHub, + aws-c-cal, + aws-c-common, + aws-c-compression, + aws-c-io, + cmake, + nix, + s2n-tls, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/aw/aws-c-mqtt/package.nix b/pkgs/by-name/aw/aws-c-mqtt/package.nix index 3eadad12ad031f..51f6778bd44a97 100644 --- a/pkgs/by-name/aw/aws-c-mqtt/package.nix +++ b/pkgs/by-name/aw/aws-c-mqtt/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, aws-c-cal -, aws-c-common -, aws-c-compression -, aws-c-http -, aws-c-io -, cmake -, nix -, s2n-tls +{ + lib, + stdenv, + fetchFromGitHub, + aws-c-cal, + aws-c-common, + aws-c-compression, + aws-c-http, + aws-c-io, + cmake, + nix, + s2n-tls, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/aw/aws-c-s3/package.nix b/pkgs/by-name/aw/aws-c-s3/package.nix index 5c834da72cc41b..ef861a87608e39 100644 --- a/pkgs/by-name/aw/aws-c-s3/package.nix +++ b/pkgs/by-name/aw/aws-c-s3/package.nix @@ -1,15 +1,17 @@ -{ lib, stdenv -, fetchFromGitHub -, aws-c-auth -, aws-c-cal -, aws-c-common -, aws-c-compression -, aws-c-http -, aws-c-io -, aws-checksums -, cmake -, nix -, s2n-tls +{ + lib, + stdenv, + fetchFromGitHub, + aws-c-auth, + aws-c-cal, + aws-c-common, + aws-c-compression, + aws-c-http, + aws-c-io, + aws-checksums, + cmake, + nix, + s2n-tls, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/aw/aws-c-sdkutils/package.nix b/pkgs/by-name/aw/aws-c-sdkutils/package.nix index dc5dc02f6242d8..071145b3b871d8 100644 --- a/pkgs/by-name/aw/aws-c-sdkutils/package.nix +++ b/pkgs/by-name/aw/aws-c-sdkutils/package.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, aws-c-common -, cmake -, nix +{ + lib, + stdenv, + fetchFromGitHub, + aws-c-common, + cmake, + nix, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/aw/aws-checksums/package.nix b/pkgs/by-name/aw/aws-checksums/package.nix index f0a9a0cf665f44..f4f6a3a4944206 100644 --- a/pkgs/by-name/aw/aws-checksums/package.nix +++ b/pkgs/by-name/aw/aws-checksums/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, aws-c-common, nix }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + aws-c-common, + nix, +}: stdenv.mkDerivation rec { pname = "aws-checksums"; diff --git a/pkgs/by-name/aw/aws-crt-cpp/package.nix b/pkgs/by-name/aw/aws-crt-cpp/package.nix index 534314443e4f83..97863d65dabba4 100644 --- a/pkgs/by-name/aw/aws-crt-cpp/package.nix +++ b/pkgs/by-name/aw/aws-crt-cpp/package.nix @@ -1,25 +1,30 @@ -{ lib, stdenv -, fetchFromGitHub -, aws-c-auth -, aws-c-cal -, aws-c-common -, aws-c-compression -, aws-c-event-stream -, aws-c-http -, aws-c-io -, aws-c-mqtt -, aws-c-s3 -, aws-checksums -, cmake -, s2n-tls -, nix +{ + lib, + stdenv, + fetchFromGitHub, + aws-c-auth, + aws-c-cal, + aws-c-common, + aws-c-compression, + aws-c-event-stream, + aws-c-http, + aws-c-io, + aws-c-mqtt, + aws-c-s3, + aws-checksums, + cmake, + s2n-tls, + nix, }: stdenv.mkDerivation rec { pname = "aws-crt-cpp"; version = "0.26.12"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "awslabs"; diff --git a/pkgs/by-name/aw/aws-gate/package.nix b/pkgs/by-name/aw/aws-gate/package.nix index 1561d1c17a92e9..b7282325d76167 100644 --- a/pkgs/by-name/aw/aws-gate/package.nix +++ b/pkgs/by-name/aw/aws-gate/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, installShellFiles -, python3Packages -, ssm-session-manager-plugin +{ + lib, + fetchFromGitHub, + installShellFiles, + python3Packages, + ssm-session-manager-plugin, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/aw/aws-iam-authenticator/package.nix b/pkgs/by-name/aw/aws-iam-authenticator/package.nix index c84d24eecd320c..376ddb7d5bbe8c 100644 --- a/pkgs/by-name/aw/aws-iam-authenticator/package.nix +++ b/pkgs/by-name/aw/aws-iam-authenticator/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,13 +17,17 @@ buildGoModule rec { vendorHash = "sha256-gFz1QrzLGMPyjB8yo+/FscZEpb2msshoUfBGmNRbvJM="; - ldflags = let PKG = "sigs.k8s.io/aws-iam-authenticator"; in [ - "-s" - "-w" - "-X=${PKG}/pkg.Version=${version}" - "-X=${PKG}/pkg.BuildDate=1970-01-01T01:01:01Z" - "-X ?${PKG}/pkg.CommitID=${version}" - ]; + ldflags = + let + PKG = "sigs.k8s.io/aws-iam-authenticator"; + in + [ + "-s" + "-w" + "-X=${PKG}/pkg.Version=${version}" + "-X=${PKG}/pkg.BuildDate=1970-01-01T01:01:01Z" + "-X ?${PKG}/pkg.CommitID=${version}" + ]; subPackages = [ "cmd/aws-iam-authenticator" ]; diff --git a/pkgs/by-name/aw/aws-lambda-rie/package.nix b/pkgs/by-name/aw/aws-lambda-rie/package.nix index 04abcfbcbbf1f1..e8a2568c72eb37 100644 --- a/pkgs/by-name/aw/aws-lambda-rie/package.nix +++ b/pkgs/by-name/aw/aws-lambda-rie/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "aws-lambda-runtime-interface-emulator"; diff --git a/pkgs/by-name/aw/aws-nuke/package.nix b/pkgs/by-name/aw/aws-nuke/package.nix index af8acd946fb1b9..301e5bcb770b82 100644 --- a/pkgs/by-name/aw/aws-nuke/package.nix +++ b/pkgs/by-name/aw/aws-nuke/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -29,7 +30,10 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' installShellCompletion --cmd aws-nuke \ diff --git a/pkgs/by-name/aw/aws-rotate-key/package.nix b/pkgs/by-name/aw/aws-rotate-key/package.nix index b2f3a85e439e9c..b75901f3b0dcf1 100644 --- a/pkgs/by-name/aw/aws-rotate-key/package.nix +++ b/pkgs/by-name/aw/aws-rotate-key/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, aws-rotate-key }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + aws-rotate-key, +}: buildGoModule rec { pname = "aws-rotate-key"; @@ -13,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-gXtTd7lU9m9rO1w7Fx8o/s45j63h6GtUZrjOzFI4Q/o="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests.version = testers.testVersion { package = aws-rotate-key; diff --git a/pkgs/by-name/aw/aws-sso-cli/package.nix b/pkgs/by-name/aw/aws-sso-cli/package.nix index b77680f058f29e..99412edca5e077 100644 --- a/pkgs/by-name/aw/aws-sso-cli/package.nix +++ b/pkgs/by-name/aw/aws-sso-cli/package.nix @@ -1,10 +1,11 @@ -{ buildGoModule -, fetchFromGitHub -, getent -, lib -, makeWrapper -, stdenv -, xdg-utils +{ + buildGoModule, + fetchFromGitHub, + getent, + lib, + makeWrapper, + stdenv, + xdg-utils, }: buildGoModule rec { pname = "aws-sso-cli"; @@ -32,13 +33,14 @@ buildGoModule rec { nativeCheckInputs = [ getent ]; - checkFlags = let - skippedTests = [ - "TestAWSConsoleUrl" - "TestAWSFederatedUrl" - "TestServerWithSSL" # https://github.com/synfinatic/aws-sso-cli/issues/1030 -- remove when version >= 2.x - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ "TestDetectShellBash" ]; - in + checkFlags = + let + skippedTests = [ + "TestAWSConsoleUrl" + "TestAWSFederatedUrl" + "TestServerWithSSL" # https://github.com/synfinatic/aws-sso-cli/issues/1030 -- remove when version >= 2.x + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ "TestDetectShellBash" ]; + in [ "-skip=^${builtins.concatStringsSep "$|^" skippedTests}$" ]; meta = with lib; { diff --git a/pkgs/by-name/aw/aws-sso-creds/package.nix b/pkgs/by-name/aw/aws-sso-creds/package.nix index 3dbf8f135f0feb..3a7a5f115f67ee 100644 --- a/pkgs/by-name/aw/aws-sso-creds/package.nix +++ b/pkgs/by-name/aw/aws-sso-creds/package.nix @@ -1,8 +1,9 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, makeWrapper -, xdg-utils +{ + buildGoModule, + fetchFromGitHub, + lib, + makeWrapper, + xdg-utils, }: buildGoModule rec { pname = "aws-sso-creds"; diff --git a/pkgs/by-name/aw/aws-vault/package.nix b/pkgs/by-name/aw/aws-vault/package.nix index a99ed43ea7c0fc..bd08e2269a09b3 100644 --- a/pkgs/by-name/aw/aws-vault/package.nix +++ b/pkgs/by-name/aw/aws-vault/package.nix @@ -1,10 +1,11 @@ -{ buildGoModule -, fetchFromGitHub -, installShellFiles -, lib -, makeWrapper -, stdenv -, xdg-utils +{ + buildGoModule, + fetchFromGitHub, + installShellFiles, + lib, + makeWrapper, + stdenv, + xdg-utils, }: buildGoModule rec { pname = "aws-vault"; @@ -19,19 +20,23 @@ buildGoModule rec { vendorHash = "sha256-4bJKDEZlO0DzEzTQ7m+SQuzhe+wKmL6wLueqgSz/46s="; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; postInstall = '' # make xdg-open overrideable at runtime # aws-vault uses https://github.com/skratchdot/open-golang/blob/master/open/open.go to open links - ${lib.optionalString (!stdenv.hostPlatform.isDarwin) "wrapProgram $out/bin/aws-vault --suffix PATH : ${lib.makeBinPath [ xdg-utils ]}"} + ${lib.optionalString ( + !stdenv.hostPlatform.isDarwin + ) "wrapProgram $out/bin/aws-vault --suffix PATH : ${lib.makeBinPath [ xdg-utils ]}"} installShellCompletion --cmd aws-vault \ --bash $src/contrib/completions/bash/aws-vault.bash \ --fish $src/contrib/completions/fish/aws-vault.fish \ --zsh $src/contrib/completions/zsh/aws-vault.zsh ''; - doCheck = false; subPackages = [ "." ]; @@ -48,8 +53,7 @@ buildGoModule rec { ''; meta = with lib; { - description = - "A vault for securely storing and accessing AWS credentials in development environments"; + description = "A vault for securely storing and accessing AWS credentials in development environments"; mainProgram = "aws-vault"; homepage = "https://github.com/99designs/aws-vault"; license = licenses.mit; diff --git a/pkgs/by-name/aw/aws-workspaces/package.nix b/pkgs/by-name/aw/aws-workspaces/package.nix index 5dad383078962c..6952b24a07c61a 100644 --- a/pkgs/by-name/aw/aws-workspaces/package.nix +++ b/pkgs/by-name/aw/aws-workspaces/package.nix @@ -1,26 +1,27 @@ -{ stdenv -, lib -, makeWrapper -, dpkg -, fetchurl -, autoPatchelfHook -, curl -, libkrb5 -, lttng-ust -, libpulseaudio -, gtk3 -, openssl_1_1 -, icu70 -, webkitgtk_4_0 -, librsvg -, gdk-pixbuf -, libsoup_2_4 -, glib-networking -, graphicsmagick_q16 -, libva -, libusb1 -, hiredis -, xcbutil +{ + stdenv, + lib, + makeWrapper, + dpkg, + fetchurl, + autoPatchelfHook, + curl, + libkrb5, + lttng-ust, + libpulseaudio, + gtk3, + openssl_1_1, + icu70, + webkitgtk_4_0, + librsvg, + gdk-pixbuf, + libsoup_2_4, + glib-networking, + graphicsmagick_q16, + libva, + libusb1, + hiredis, + xcbutil, }: stdenv.mkDerivation (finalAttrs: { @@ -98,7 +99,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://clients.amazonworkspaces.com"; license = licenses.unfree; mainProgram = "workspacesclient"; - maintainers = with maintainers; [ mausch dylanmtaylor ]; + maintainers = with maintainers; [ + mausch + dylanmtaylor + ]; platforms = [ "x86_64-linux" ]; # TODO Mac support sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; diff --git a/pkgs/by-name/aw/aws_mturk_clt/package.nix b/pkgs/by-name/aw/aws_mturk_clt/package.nix index 9b03e2dd1bdbd0..4d6408a0e69dbb 100644 --- a/pkgs/by-name/aw/aws_mturk_clt/package.nix +++ b/pkgs/by-name/aw/aws_mturk_clt/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, jre }: +{ + lib, + stdenv, + fetchurl, + jre, +}: stdenv.mkDerivation rec { pname = "aws-mturk-clt"; @@ -9,41 +14,39 @@ stdenv.mkDerivation rec { sha256 = "00yyc7k3iygg83cknv9i2dsaxwpwzdkc8a2l9j56lg999hw3mqm3"; }; - installPhase = - '' - mkdir -p $out - cp -prvd bin $out/ + installPhase = '' + mkdir -p $out + cp -prvd bin $out/ - for i in $out/bin/*.sh; do - sed -i "$i" -e "s|^MTURK_CMD_HOME=.*|MTURK_CMD_HOME=$out\nexport JAVA_HOME=${jre}|" - done + for i in $out/bin/*.sh; do + sed -i "$i" -e "s|^MTURK_CMD_HOME=.*|MTURK_CMD_HOME=$out\nexport JAVA_HOME=${jre}|" + done - mkdir -p $out/lib - cp -prvd lib/* $out/lib/ - ''; # */ + mkdir -p $out/lib + cp -prvd lib/* $out/lib/ + ''; # */ meta = { homepage = "https://requester.mturk.com/developer"; description = "Command line tools for interacting with the Amazon Mechanical Turk"; license = lib.licenses.amazonsl; - longDescription = - '' - The Amazon Mechanical Turk is a crowdsourcing marketplace that - allows users (“requesters”) to submit tasks to be performed by - other humans (“workers”) for a small fee. This package - contains command-line tools for submitting tasks, querying - results, and so on. - - The command-line tools expect a file - mturk.properties in the current directory, - which should contain the following: - - - access_key=[insert your access key here] - secret_key=[insert your secret key here] - service_url=http://mechanicalturk.amazonaws.com/?Service=AWSMechanicalTurkRequester - - ''; + longDescription = '' + The Amazon Mechanical Turk is a crowdsourcing marketplace that + allows users (“requesters”) to submit tasks to be performed by + other humans (“workers”) for a small fee. This package + contains command-line tools for submitting tasks, querying + results, and so on. + + The command-line tools expect a file + mturk.properties in the current directory, + which should contain the following: + + + access_key=[insert your access key here] + secret_key=[insert your secret key here] + service_url=http://mechanicalturk.amazonaws.com/?Service=AWSMechanicalTurkRequester + + ''; }; } diff --git a/pkgs/by-name/aw/awscli/package.nix b/pkgs/by-name/aw/awscli/package.nix index e9b5af2c1b9d57..1d5b159627e0da 100644 --- a/pkgs/by-name/aw/awscli/package.nix +++ b/pkgs/by-name/aw/awscli/package.nix @@ -1,11 +1,12 @@ -{ lib -, python3 -, fetchPypi -, groff -, less -, nix-update-script -, testers -, awscli +{ + lib, + python3, + fetchPypi, + groff, + less, + nix-update-script, + testers, + awscli, }: let diff --git a/pkgs/by-name/aw/awslogs/package.nix b/pkgs/by-name/aw/awslogs/package.nix index 87285da594929b..e90da6b3fee4ac 100644 --- a/pkgs/by-name/aw/awslogs/package.nix +++ b/pkgs/by-name/aw/awslogs/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -24,7 +25,6 @@ python3.pkgs.buildPythonApplication rec { jmespath ]; - postPatch = '' substituteInPlace setup.py \ --replace "boto3>=1.34.75" "boto3>=1.34.58" \ diff --git a/pkgs/by-name/aw/awsls/package.nix b/pkgs/by-name/aw/awsls/package.nix index 322d3aacaf2895..4ea289d01b55ab 100644 --- a/pkgs/by-name/aw/awsls/package.nix +++ b/pkgs/by-name/aw/awsls/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "awsls"; @@ -14,8 +18,16 @@ buildGoModule rec { vendorHash = "sha256-ZyMO+KCqoePF6MqHFt8X4tZR4nBhuSPgJDrX+emM6jc="; ldflags = - let t = "github.com/jckuester/awsls/internal"; - in [ "-s" "-w" "-X ${t}.version=${version}" "-X ${t}.commit=${src.rev}" "-X ${t}.date=unknown" ]; + let + t = "github.com/jckuester/awsls/internal"; + in + [ + "-s" + "-w" + "-X ${t}.version=${version}" + "-X ${t}.commit=${src.rev}" + "-X ${t}.date=unknown" + ]; doCheck = false; diff --git a/pkgs/by-name/aw/awsrm/package.nix b/pkgs/by-name/aw/awsrm/package.nix index 3fd9896507bea2..20d0e120ed432d 100644 --- a/pkgs/by-name/aw/awsrm/package.nix +++ b/pkgs/by-name/aw/awsrm/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "awsrm"; @@ -14,8 +18,16 @@ buildGoModule rec { vendorHash = "sha256-CldEAeiFH7gdFNLbIe/oTzs8Pdnde7EqLr7vP7SMDGU="; ldflags = - let t = "github.com/jckuester/awsrm/internal"; - in [ "-s" "-w" "-X ${t}.version=${version}" "-X ${t}.commit=${src.rev}" "-X ${t}.date=unknown" ]; + let + t = "github.com/jckuester/awsrm/internal"; + in + [ + "-s" + "-w" + "-X ${t}.version=${version}" + "-X ${t}.commit=${src.rev}" + "-X ${t}.date=unknown" + ]; doCheck = false; diff --git a/pkgs/by-name/aw/awstats/package.nix b/pkgs/by-name/aw/awstats/package.nix index e1479e6192cb9b..2bc8b3cfea4521 100644 --- a/pkgs/by-name/aw/awstats/package.nix +++ b/pkgs/by-name/aw/awstats/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchurl -, perlPackages -, jdk +{ + lib, + fetchurl, + perlPackages, + jdk, }: perlPackages.buildPerlPackage rec { @@ -18,7 +19,11 @@ perlPackages.buildPerlPackage rec { --replace /usr/share/awstats/ "$out/wwwroot/cgi-bin/" ''; - outputs = [ "bin" "out" "doc" ]; # bin just links the user-run executable + outputs = [ + "bin" + "out" + "doc" + ]; # bin just links the user-run executable propagatedBuildOutputs = [ ]; # otherwise out propagates bin -> cycle diff --git a/pkgs/by-name/aw/awsweeper/package.nix b/pkgs/by-name/aw/awsweeper/package.nix index 064d210907a0bc..2a37ef68238e27 100644 --- a/pkgs/by-name/aw/awsweeper/package.nix +++ b/pkgs/by-name/aw/awsweeper/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "awsweeper"; @@ -13,7 +17,13 @@ buildGoModule rec { vendorHash = "sha256-jzK56x5mzQkD3tSs6X0Z2Zn1OLXFHgWHz0YLZ3m3NS4="; - ldflags = [ "-s" "-w" "-X github.com/jckuester/awsweeper/internal.version=${version}" "-X github.com/jckuester/awsweeper/internal.commit=${src.rev}" "-X github.com/jckuester/awsweeper/internal.date=unknown" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/jckuester/awsweeper/internal.version=${version}" + "-X github.com/jckuester/awsweeper/internal.commit=${src.rev}" + "-X github.com/jckuester/awsweeper/internal.date=unknown" + ]; doCheck = false; diff --git a/pkgs/by-name/ax/ax25-apps/package.nix b/pkgs/by-name/ax/ax25-apps/package.nix index ea53d7c38b5a0d..3ec0698d81fc20 100644 --- a/pkgs/by-name/ax/ax25-apps/package.nix +++ b/pkgs/by-name/ax/ax25-apps/package.nix @@ -1,15 +1,19 @@ -{ lib -, stdenv -, fetchurl -, libax25 -, ncurses +{ + lib, + stdenv, + fetchurl, + libax25, + ncurses, }: stdenv.mkDerivation rec { pname = "ax25-apps"; version = "0.0.8-rc5"; - buildInputs = [ libax25 ncurses ]; + buildInputs = [ + libax25 + ncurses + ]; # Due to recent unsolvable administrative domain problems with linux-ax25.org, # the new domain is linux-ax25.in-berlin.de diff --git a/pkgs/by-name/ax/ax25-tools/package.nix b/pkgs/by-name/ax/ax25-tools/package.nix index 80c42da9a3d11f..dd209afa8cd5d6 100644 --- a/pkgs/by-name/ax/ax25-tools/package.nix +++ b/pkgs/by-name/ax/ax25-tools/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, libax25 +{ + lib, + stdenv, + fetchurl, + libax25, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ax/ax25ms/package.nix b/pkgs/by-name/ax/ax25ms/package.nix index 94a5ca9ce6f836..554ce93c0c4e51 100644 --- a/pkgs/by-name/ax/ax25ms/package.nix +++ b/pkgs/by-name/ax/ax25ms/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, protobuf -, pkg-config -, grpc -, libtool -, which -, automake -, libax25 +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + protobuf, + pkg-config, + grpc, + libtool, + which, + automake, + libax25, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ax/axmldec/package.nix b/pkgs/by-name/ax/axmldec/package.nix index f65801b78387b6..7d8fba5a6d0d1e 100644 --- a/pkgs/by-name/ax/axmldec/package.nix +++ b/pkgs/by-name/ax/axmldec/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, doxygen -, boost -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + doxygen, + boost, + zlib, }: stdenv.mkDerivation rec { @@ -19,8 +20,14 @@ stdenv.mkDerivation rec { hash = "sha256-LFDZZbRDa8mQmglgS4DA/OqXp0HJZ2uqg1hbStdgvUw="; }; - nativeBuildInputs = [ cmake doxygen ]; - buildInputs = [ boost zlib ]; + nativeBuildInputs = [ + cmake + doxygen + ]; + buildInputs = [ + boost + zlib + ]; meta = with lib; { description = "Stand-alone binary AndroidManifest.xml decoder"; diff --git a/pkgs/by-name/ay/ayu-theme-gtk/package.nix b/pkgs/by-name/ay/ayu-theme-gtk/package.nix index 1f154f6de2f69c..f9af839c04d6b9 100644 --- a/pkgs/by-name/ay/ayu-theme-gtk/package.nix +++ b/pkgs/by-name/ay/ayu-theme-gtk/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, autoreconfHook -, fetchFromGitHub -, gnome-shell -, gnome-themes-extra -, gtk-engine-murrine -, gtk3 -, inkscape -, lib -, optipng -, pkg-config -, sassc +{ + stdenv, + autoreconfHook, + fetchFromGitHub, + gnome-shell, + gnome-themes-extra, + gtk-engine-murrine, + gtk3, + inkscape, + lib, + optipng, + pkg-config, + sassc, }: stdenv.mkDerivation rec { @@ -66,4 +67,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ lovesegfault ]; }; } - diff --git a/pkgs/by-name/az/azeret-mono/package.nix b/pkgs/by-name/az/azeret-mono/package.nix index dfaf98c965d26a..c76f1064faeaf2 100644 --- a/pkgs/by-name/az/azeret-mono/package.nix +++ b/pkgs/by-name/az/azeret-mono/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "azeret-mono"; diff --git a/pkgs/by-name/az/azimuth/package.nix b/pkgs/by-name/az/azimuth/package.nix index 739336733cda21..3a986d9c5b656a 100644 --- a/pkgs/by-name/az/azimuth/package.nix +++ b/pkgs/by-name/az/azimuth/package.nix @@ -1,13 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, SDL, which, installTool ? false }: +{ + lib, + stdenv, + fetchFromGitHub, + SDL, + which, + installTool ? false, +}: stdenv.mkDerivation rec { pname = "azimuth"; version = "1.0.3"; src = fetchFromGitHub { - owner = "mdsteele"; - repo = "azimuth"; - rev = "v${version}"; + owner = "mdsteele"; + repo = "azimuth"; + rev = "v${version}"; sha256 = "1znfvpmqiixd977jv748glk5zc4cmhw5813zp81waj07r9b0828r"; }; @@ -25,8 +32,7 @@ stdenv.mkDerivation rec { makeFlags = [ "BUILDTYPE=release" "INSTALLDIR=$(out)" - ] ++ (if installTool then ["INSTALLTOOL=true"] else ["INSTALLTOOL=false"]); - + ] ++ (if installTool then [ "INSTALLTOOL=true" ] else [ "INSTALLTOOL=false" ]); enableParallelBuilding = true; diff --git a/pkgs/by-name/az/azmq/package.nix b/pkgs/by-name/az/azmq/package.nix index 83bbd9f98f9eda..2ec9e1cf2bbe3c 100644 --- a/pkgs/by-name/az/azmq/package.nix +++ b/pkgs/by-name/az/azmq/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, boost -, cmake -, ninja -, zeromq -, catch2 +{ + lib, + stdenv, + fetchFromGitHub, + boost, + cmake, + ninja, + zeromq, + catch2, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/az/azure-storage-azcopy/package.nix b/pkgs/by-name/az/azure-storage-azcopy/package.nix index 3ac59c582ab30c..bb79410bb326f0 100644 --- a/pkgs/by-name/az/azure-storage-azcopy/package.nix +++ b/pkgs/by-name/az/azure-storage-azcopy/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { @@ -29,6 +30,9 @@ buildGoModule rec { homepage = "https://github.com/Azure/azure-storage-azcopy"; changelog = "https://github.com/Azure/azure-storage-azcopy/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ colemickens kashw2 ]; + maintainers = with maintainers; [ + colemickens + kashw2 + ]; }; } diff --git a/pkgs/by-name/az/azuredatastudio/package.nix b/pkgs/by-name/az/azuredatastudio/package.nix index 62ddf238f70378..3c3583e7ad4eb4 100644 --- a/pkgs/by-name/az/azuredatastudio/package.nix +++ b/pkgs/by-name/az/azuredatastudio/package.nix @@ -1,34 +1,35 @@ -{ stdenv -, lib -, fetchurl -, copyDesktopItems -, makeDesktopItem -, makeWrapper -, alsa-lib -, at-spi2-atk -, at-spi2-core -, cairo -, cups -, curl -, dbus -, expat -, gdk-pixbuf -, glib -, gnutar -, gtk3 -, icu -, libdrm -, libunwind -, libuuid -, libxkbcommon -, mesa -, nspr -, nss -, openssl -, pango -, systemd -, xorg -, zlib +{ + stdenv, + lib, + fetchurl, + copyDesktopItems, + makeDesktopItem, + makeWrapper, + alsa-lib, + at-spi2-atk, + at-spi2-core, + cairo, + cups, + curl, + dbus, + expat, + gdk-pixbuf, + glib, + gnutar, + gtk3, + icu, + libdrm, + libunwind, + libuuid, + libxkbcommon, + mesa, + nspr, + nss, + openssl, + pango, + systemd, + xorg, + zlib, }: # from justinwoo/azuredatastudio-nix @@ -44,8 +45,17 @@ let icon = "azuredatastudio"; startupNotify = true; startupWMClass = "azuredatastudio"; - categories = [ "Utility" "TextEditor" "Development" "IDE" ]; - mimeTypes = [ "text/plain" "inode/directory" "application/x-azuredatastudio-workspace" ]; + categories = [ + "Utility" + "TextEditor" + "Development" + "IDE" + ]; + mimeTypes = [ + "text/plain" + "inode/directory" + "application/x-azuredatastudio-workspace" + ]; keywords = [ "azuredatastudio" ]; actions.new-empty-window = { name = "New Empty Window"; @@ -63,7 +73,12 @@ let icon = "azuredatastudio"; startupNotify = true; startupWMClass = "azuredatastudio"; - categories = [ "Utility" "TextEditor" "Development" "IDE" ]; + categories = [ + "Utility" + "TextEditor" + "Development" + "IDE" + ]; mimeTypes = [ "x-scheme-handler/azuredatastudio" ]; keywords = [ "azuredatastudio" ]; noDisplay = true; @@ -74,7 +89,10 @@ stdenv.mkDerivation rec { pname = "azuredatastudio"; version = "1.49.1"; - desktopItems = [ desktopItem urlHandlerDesktopItem ]; + desktopItems = [ + desktopItem + urlHandlerDesktopItem + ]; src = fetchurl { name = "${pname}-${version}.tar.gz"; diff --git a/pkgs/by-name/az/azurite/package.nix b/pkgs/by-name/az/azurite/package.nix index bcd118290f785d..1e0fdda3c2879e 100644 --- a/pkgs/by-name/az/azurite/package.nix +++ b/pkgs/by-name/az/azurite/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, stdenv -, darwin -, libsecret -, pkg-config -, python3 +{ + lib, + buildNpmPackage, + fetchFromGitHub, + stdenv, + darwin, + libsecret, + pkg-config, + python3, }: buildNpmPackage rec { @@ -21,13 +22,21 @@ buildNpmPackage rec { npmDepsHash = "sha256-jfa04iWz0aOiFD1YkXn5YEXqQcrY+rIDbVmmUaA5sYc="; - nativeBuildInputs = [ pkg-config python3 ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - libsecret - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin; [ - Security - apple_sdk.frameworks.AppKit - ]); + nativeBuildInputs = [ + pkg-config + python3 + ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + libsecret + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin; + [ + Security + apple_sdk.frameworks.AppKit + ] + ); meta = { description = "An open source Azure Storage API compatible server"; diff --git a/pkgs/by-name/b4/b4/package.nix b/pkgs/by-name/b4/b4/package.nix index c175badcc30049..0b951b320dacfb 100644 --- a/pkgs/by-name/b4/b4/package.nix +++ b/pkgs/by-name/b4/b4/package.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, patatt }: +{ + lib, + python3Packages, + fetchPypi, + patatt, +}: python3Packages.buildPythonApplication rec { pname = "b4"; @@ -30,6 +35,10 @@ python3Packages.buildPythonApplication rec { license = licenses.gpl2Only; description = "Helper utility to work with patches made available via a public-inbox archive"; mainProgram = "b4"; - maintainers = with maintainers; [ jb55 qyliss mfrw ]; + maintainers = with maintainers; [ + jb55 + qyliss + mfrw + ]; }; } diff --git a/pkgs/by-name/b4/b43FirmwareCutter/package.nix b/pkgs/by-name/b4/b43FirmwareCutter/package.nix index 65e2596675167a..ada2eabe099072 100644 --- a/pkgs/by-name/b4/b43FirmwareCutter/package.nix +++ b/pkgs/by-name/b4/b43FirmwareCutter/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "b43-fwcutter"; diff --git a/pkgs/by-name/b6/b612/package.nix b/pkgs/by-name/b6/b612/package.nix index b78f3a9e85bff7..1fee278400e5cb 100644 --- a/pkgs/by-name/b6/b612/package.nix +++ b/pkgs/by-name/b6/b612/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "b612"; @@ -37,7 +41,11 @@ stdenvNoCC.mkDerivation rec { imaginary asteroid of the aviator Saint‑Exupéry, benefited from a complete hinting on all the characters. ''; - license = with licenses; [ ofl epl10 bsd3 ]; + license = with licenses; [ + ofl + epl10 + bsd3 + ]; maintainers = with maintainers; [ leenaars ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/ba/babeld/package.nix b/pkgs/by-name/ba/babeld/package.nix index 4fd86e16f446dc..46b037653afebd 100644 --- a/pkgs/by-name/ba/babeld/package.nix +++ b/pkgs/by-name/ba/babeld/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, nixosTests +{ + lib, + stdenv, + fetchurl, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ba/babl/package.nix b/pkgs/by-name/ba/babl/package.nix index 5322cb029de917..bfccb384280f7d 100644 --- a/pkgs/by-name/ba/babl/package.nix +++ b/pkgs/by-name/ba/babl/package.nix @@ -1,20 +1,25 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, gi-docgen -, gobject-introspection -, lcms2 -, vala +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + gi-docgen, + gobject-introspection, + lcms2, + vala, }: stdenv.mkDerivation (finalAttrs: { pname = "babl"; version = "0.1.110"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "https://download.gimp.org/pub/babl/${lib.versions.majorMinor finalAttrs.version}/babl-${finalAttrs.version}.tar.xz"; @@ -39,13 +44,15 @@ stdenv.mkDerivation (finalAttrs: { lcms2 ]; - mesonFlags = [ - "-Dprefix-dev=${placeholder "dev"}" - ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ - # Docs are opt-out in native but opt-in in cross builds. - "-Dwith-docs=true" - "-Denable-gir=true" - ]; + mesonFlags = + [ + "-Dprefix-dev=${placeholder "dev"}" + ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + # Docs are opt-out in native but opt-in in cross builds. + "-Dwith-docs=true" + "-Denable-gir=true" + ]; postFixup = '' # Cannot be in postInstall, otherwise _multioutDocs hook in preFixup will move right back. @@ -56,7 +63,9 @@ stdenv.mkDerivation (finalAttrs: { description = "Image pixel format conversion library"; mainProgram = "babl"; homepage = "https://gegl.org/babl/"; - changelog = "https://gitlab.gnome.org/GNOME/babl/-/blob/BABL_${replaceStrings [ "." ] [ "_" ] finalAttrs.version}/NEWS"; + changelog = "https://gitlab.gnome.org/GNOME/babl/-/blob/BABL_${ + replaceStrings [ "." ] [ "_" ] finalAttrs.version + }/NEWS"; license = licenses.lgpl3Plus; maintainers = with maintainers; [ jtojnar ]; platforms = platforms.unix; diff --git a/pkgs/by-name/ba/backblaze-b2/package.nix b/pkgs/by-name/ba/backblaze-b2/package.nix index 043547e934302a..46b970698418d1 100644 --- a/pkgs/by-name/ba/backblaze-b2/package.nix +++ b/pkgs/by-name/ba/backblaze-b2/package.nix @@ -1,11 +1,12 @@ -{ lib -, python3Packages -, fetchFromGitHub -, installShellFiles -, testers -, backblaze-b2 -# executable is renamed to backblaze-b2 by default, to avoid collision with boost's 'b2' -, execName ? "backblaze-b2" +{ + lib, + python3Packages, + fetchFromGitHub, + installShellFiles, + testers, + backblaze-b2, + # executable is renamed to backblaze-b2 by default, to avoid collision with boost's 'b2' + execName ? "backblaze-b2", }: python3Packages.buildPythonApplication rec { @@ -73,25 +74,28 @@ python3Packages.buildPythonApplication rec { "test_install_autocomplete" ]; - postInstall = lib.optionalString (execName != "b2") '' - mv "$out/bin/b2" "$out/bin/${execName}" - '' - + '' - installShellCompletion --cmd ${execName} \ - --bash <(register-python-argcomplete ${execName}) \ - --zsh <(register-python-argcomplete ${execName}) - ''; - - passthru.tests.version = (testers.testVersion { - package = backblaze-b2; - command = "${execName} version --short"; - }).overrideAttrs (old: { - # workaround the error: Permission denied: '/homeless-shelter' - # backblaze-b2 fails to create a 'b2' directory under the XDG config path - preHook = '' - export HOME=$(mktemp -d) + postInstall = + lib.optionalString (execName != "b2") '' + mv "$out/bin/b2" "$out/bin/${execName}" + '' + + '' + installShellCompletion --cmd ${execName} \ + --bash <(register-python-argcomplete ${execName}) \ + --zsh <(register-python-argcomplete ${execName}) ''; - }); + + passthru.tests.version = + (testers.testVersion { + package = backblaze-b2; + command = "${execName} version --short"; + }).overrideAttrs + (old: { + # workaround the error: Permission denied: '/homeless-shelter' + # backblaze-b2 fails to create a 'b2' directory under the XDG config path + preHook = '' + export HOME=$(mktemp -d) + ''; + }); meta = with lib; { description = "Command-line tool for accessing the Backblaze B2 storage service"; diff --git a/pkgs/by-name/ba/backdown/package.nix b/pkgs/by-name/ba/backdown/package.nix index 78ad5be3f31ea3..c309b9552e0b5a 100644 --- a/pkgs/by-name/ba/backdown/package.nix +++ b/pkgs/by-name/ba/backdown/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ba/backgroundremover/package.nix b/pkgs/by-name/ba/backgroundremover/package.nix index 1d16ec2071a704..3c9eab61566aa3 100644 --- a/pkgs/by-name/ba/backgroundremover/package.nix +++ b/pkgs/by-name/ba/backgroundremover/package.nix @@ -1,9 +1,10 @@ -{ python3 -, lib -, runCommand -, fetchFromGitHub -, fetchurl -, gitUpdater +{ + python3, + lib, + runCommand, + fetchFromGitHub, + fetchurl, + gitUpdater, }: let @@ -20,7 +21,7 @@ let hash = "sha256-LjVT4j0OzfbVSQgU0z/gzRTLm7N0RQRrfxtTugWwOxs="; }; - models = runCommand "background-remover-models" {} '' + models = runCommand "background-remover-models" { } '' mkdir $out cat ${src}/models/u2a{a,b,c,d} > $out/u2net.pth cat ${src}/models/u2ha{a,b,c,d} > $out/u2net_human_seg.pth @@ -32,9 +33,15 @@ let --replace-fail 'os.path.expanduser(os.path.join("~", ".u2net", model_name + ".pth"))' "os.path.join(\"$models\", model_name + \".pth\")" ''; - nativeBuildInputs = [ p.setuptools p.wheel ]; + nativeBuildInputs = [ + p.setuptools + p.wheel + ]; - pythonRelaxDeps = [ "pillow" "torchvision" ]; + pythonRelaxDeps = [ + "pillow" + "torchvision" + ]; propagatedBuildInputs = [ p.certifi @@ -66,18 +73,22 @@ let passthru = { inherit models; tests = { - image = let - # random no copyright car image from the internet - demoImage = fetchurl { - url = "https://pics.craiyon.com/2023-07-16/38653769ac3b4e068181cb5ab1e542a1.webp"; - hash = "sha256-Kvd06eZdibgDbabVVe0+cNTeS1rDnMXIZZpPlHIlfBo="; - }; - in runCommand "backgroundremover-image-test.png" { - buildInputs = [ self ]; - } '' - export NUMBA_CACHE_DIR=$(mktemp -d) - backgroundremover -i ${demoImage} -o $out - ''; + image = + let + # random no copyright car image from the internet + demoImage = fetchurl { + url = "https://pics.craiyon.com/2023-07-16/38653769ac3b4e068181cb5ab1e542a1.webp"; + hash = "sha256-Kvd06eZdibgDbabVVe0+cNTeS1rDnMXIZZpPlHIlfBo="; + }; + in + runCommand "backgroundremover-image-test.png" + { + buildInputs = [ self ]; + } + '' + export NUMBA_CACHE_DIR=$(mktemp -d) + backgroundremover -i ${demoImage} -o $out + ''; }; updateScript = gitUpdater { rev-prefix = "v"; }; }; @@ -93,4 +104,5 @@ let maintainers = [ maintainers.lucasew ]; }; }; -in self +in +self diff --git a/pkgs/by-name/ba/backlight-auto/package.nix b/pkgs/by-name/ba/backlight-auto/package.nix index 9fa2d1245d10c2..3d8dc7338a9c41 100644 --- a/pkgs/by-name/ba/backlight-auto/package.nix +++ b/pkgs/by-name/ba/backlight-auto/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, zig, libyuv, fetchFromGitHub }: +{ + lib, + stdenv, + zig, + libyuv, + fetchFromGitHub, +}: stdenv.mkDerivation (finalAttrs: { pname = "backlight-auto"; version = "0.0.1"; diff --git a/pkgs/by-name/ba/backward-cpp/package.nix b/pkgs/by-name/ba/backward-cpp/package.nix index 1cea8079024cad..84e877ec9642d5 100644 --- a/pkgs/by-name/ba/backward-cpp/package.nix +++ b/pkgs/by-name/ba/backward-cpp/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "backward"; diff --git a/pkgs/by-name/ba/bacnet-stack/package.nix b/pkgs/by-name/ba/bacnet-stack/package.nix index 23718b291a9773..f3f0f14366ae98 100644 --- a/pkgs/by-name/ba/bacnet-stack/package.nix +++ b/pkgs/by-name/ba/bacnet-stack/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "bacnet-stack"; diff --git a/pkgs/by-name/ba/bada-bib/package.nix b/pkgs/by-name/ba/bada-bib/package.nix index fba37263290947..22bf2189d98dd3 100644 --- a/pkgs/by-name/ba/bada-bib/package.nix +++ b/pkgs/by-name/ba/bada-bib/package.nix @@ -1,20 +1,21 @@ -{ lib -, meson -, ninja -, fetchFromGitHub -, appstream-glib -, desktop-file-utils -, gdk-pixbuf -, gettext -, glib -, gobject-introspection -, gtk4 -, gtksourceview5 -, libadwaita -, libxml2 -, pkg-config -, python3Packages -, wrapGAppsHook4 +{ + lib, + meson, + ninja, + fetchFromGitHub, + appstream-glib, + desktop-file-utils, + gdk-pixbuf, + gettext, + glib, + gobject-introspection, + gtk4, + gtksourceview5, + libadwaita, + libxml2, + pkg-config, + python3Packages, + wrapGAppsHook4, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ba/badger/package.nix b/pkgs/by-name/ba/badger/package.nix index e5128811e9f66f..e4a509fdff743e 100644 --- a/pkgs/by-name/ba/badger/package.nix +++ b/pkgs/by-name/ba/badger/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ba/badlion-client/package.nix b/pkgs/by-name/ba/badlion-client/package.nix index 78278be9fca3eb..f2955ba8244ed2 100644 --- a/pkgs/by-name/ba/badlion-client/package.nix +++ b/pkgs/by-name/ba/badlion-client/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools }: +{ + lib, + fetchurl, + appimageTools, +}: let pname = "badlion-client"; @@ -13,22 +17,22 @@ let appimageContents = appimageTools.extract { inherit pname version src; }; in - appimageTools.wrapType2 rec { - inherit pname version src; +appimageTools.wrapType2 rec { + inherit pname version src; - extraInstallCommands = '' - install -Dm444 ${appimageContents}/BadlionClient.desktop $out/share/applications/BadlionClient.desktop - install -Dm444 ${appimageContents}/BadlionClient.png $out/share/pixmaps/BadlionClient.png - substituteInPlace $out/share/applications/BadlionClient.desktop \ - --replace 'Exec=AppRun --no-sandbox %U' 'Exec=badlion-client' - ''; + extraInstallCommands = '' + install -Dm444 ${appimageContents}/BadlionClient.desktop $out/share/applications/BadlionClient.desktop + install -Dm444 ${appimageContents}/BadlionClient.png $out/share/pixmaps/BadlionClient.png + substituteInPlace $out/share/applications/BadlionClient.desktop \ + --replace 'Exec=AppRun --no-sandbox %U' 'Exec=badlion-client' + ''; - meta = with lib; { - description = "Most Complete All-In-One Mod Library for Minecraft with 100+ Mods, FPS Improvements, and more"; - homepage = "https://client.badlion.net"; - license = with licenses; [ unfree ]; - maintainers = [ ]; - mainProgram = "badlion-client"; - platforms = [ "x86_64-linux" ]; - }; - } + meta = with lib; { + description = "Most Complete All-In-One Mod Library for Minecraft with 100+ Mods, FPS Improvements, and more"; + homepage = "https://client.badlion.net"; + license = with licenses; [ unfree ]; + maintainers = [ ]; + mainProgram = "badlion-client"; + platforms = [ "x86_64-linux" ]; + }; +} diff --git a/pkgs/by-name/ba/badrobot/package.nix b/pkgs/by-name/ba/badrobot/package.nix index ad2a0bd29750fb..eebb26f6f6a5d7 100644 --- a/pkgs/by-name/ba/badrobot/package.nix +++ b/pkgs/by-name/ba/badrobot/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "badrobot"; diff --git a/pkgs/by-name/ba/badvpn/package.nix b/pkgs/by-name/ba/badvpn/package.nix index 04eb96eeefd9f8..d5fc259f190429 100644 --- a/pkgs/by-name/ba/badvpn/package.nix +++ b/pkgs/by-name/ba/badvpn/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, cmake, openssl, nss, pkg-config, nspr, bash, debug ? false }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openssl, + nss, + pkg-config, + nspr, + bash, + debug ? false, +}: stdenv.mkDerivation rec { pname = "badvpn"; @@ -11,7 +22,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-bLTDpq3ohUP+KooPvhv1/AZfdo0HwB3g9QOuE2E/pmY="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ openssl nss @@ -21,7 +35,9 @@ stdenv.mkDerivation rec { preConfigure = '' find . -name '*.sh' -exec sed -e 's@#!/bin/sh@${stdenv.shell}@' -i '{}' ';' find . -name '*.sh' -exec sed -e 's@#!/bin/bash@${bash}/bin/bash@' -i '{}' ';' - cmakeFlagsArray=("-DCMAKE_BUILD_TYPE=" "-DCMAKE_C_FLAGS=-O3 ${lib.optionalString (!debug) "-DNDEBUG"}"); + cmakeFlagsArray=("-DCMAKE_BUILD_TYPE=" "-DCMAKE_C_FLAGS=-O3 ${ + lib.optionalString (!debug) "-DNDEBUG" + }"); ''; meta = with lib; { diff --git a/pkgs/by-name/ba/badwolf/package.nix b/pkgs/by-name/ba/badwolf/package.nix index 1c56fedfbdf0e6..d0a46e9b81eced 100644 --- a/pkgs/by-name/ba/badwolf/package.nix +++ b/pkgs/by-name/ba/badwolf/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchgit -, ninja -, pkg-config -, ed -, wrapGAppsHook3 -, webkitgtk_4_0 -, libxml2 -, glib-networking -, gettext +{ + lib, + stdenv, + fetchgit, + ninja, + pkg-config, + ed, + wrapGAppsHook3, + webkitgtk_4_0, + libxml2, + glib-networking, + gettext, }: stdenv.mkDerivation rec { @@ -42,8 +43,14 @@ stdenv.mkDerivation rec { description = "Minimalist and privacy-oriented WebKitGTK+ browser"; mainProgram = "badwolf"; homepage = "https://hacktivis.me/projects/badwolf"; - license = with licenses; [ bsd3 cc-by-sa-40 ]; + license = with licenses; [ + bsd3 + cc-by-sa-40 + ]; platforms = platforms.linux; - maintainers = with maintainers; [ laalsaas aleksana ]; + maintainers = with maintainers; [ + laalsaas + aleksana + ]; }; } diff --git a/pkgs/by-name/ba/balanceofsatoshis/package.nix b/pkgs/by-name/ba/balanceofsatoshis/package.nix index b1b17e02366bb4..54d611eaec9248 100644 --- a/pkgs/by-name/ba/balanceofsatoshis/package.nix +++ b/pkgs/by-name/ba/balanceofsatoshis/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, installShellFiles -, python3 +{ + lib, + buildNpmPackage, + fetchFromGitHub, + installShellFiles, + python3, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ba/ballerburg/package.nix b/pkgs/by-name/ba/ballerburg/package.nix index c8d5fb793832f8..67a6d9e1a8259d 100644 --- a/pkgs/by-name/ba/ballerburg/package.nix +++ b/pkgs/by-name/ba/ballerburg/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchurl, cmake, SDL, makeDesktopItem, copyDesktopItems -, imagemagick }: +{ + lib, + stdenv, + fetchurl, + cmake, + SDL, + makeDesktopItem, + copyDesktopItems, + imagemagick, +}: let @@ -8,7 +16,8 @@ let sha256 = "1xq2h87s648wjpjl72ds3xnnk2jp8ghbkhjzh2g4hpkq2zdz90hy"; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "ballerburg"; version = "1.2.0"; @@ -17,7 +26,11 @@ in stdenv.mkDerivation rec { sha256 = "sha256-BiX0shPBGA8sshee8rxs41x+mdsrJzBqhpDDic6sYwA="; }; - nativeBuildInputs = [ cmake copyDesktopItems imagemagick ]; + nativeBuildInputs = [ + cmake + copyDesktopItems + imagemagick + ]; buildInputs = [ SDL ]; diff --git a/pkgs/by-name/ba/balsa/package.nix b/pkgs/by-name/ba/balsa/package.nix index acec1b5cf0faeb..6d4bbd0622378f 100644 --- a/pkgs/by-name/ba/balsa/package.nix +++ b/pkgs/by-name/ba/balsa/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchurl -, glib -, gmime3 -, gnutls -, gobject-introspection -, gpgme -, gtk3 -, gtksourceview4 -, gtkspell3 -, intltool -, libcanberra-gtk3 -, libesmtp -, libical -, libnotify -, libsecret -, openssl -, pkg-config -, sqlite -, webkitgtk_4_0 -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + glib, + gmime3, + gnutls, + gobject-introspection, + gpgme, + gtk3, + gtksourceview4, + gtkspell3, + intltool, + libcanberra-gtk3, + libesmtp, + libical, + libnotify, + libsecret, + openssl, + pkg-config, + sqlite, + webkitgtk_4_0, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ba/bam/package.nix b/pkgs/by-name/ba/bam/package.nix index c435e2fa16ec27..21493a5530b1bc 100644 --- a/pkgs/by-name/ba/bam/package.nix +++ b/pkgs/by-name/ba/bam/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, lua5_3, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + lua5_3, + python3, +}: stdenv.mkDerivation rec { pname = "bam"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "13br735ig7lygvzyfd15fc2rdygrqm503j6xj5xkrl1r7w2wipq6"; }; - nativeBuildInputs = [ lua5_3 python3 ]; + nativeBuildInputs = [ + lua5_3 + python3 + ]; buildPhase = "${stdenv.shell} make_unix.sh"; @@ -29,8 +38,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Yet another build manager"; mainProgram = "bam"; - maintainers = with maintainers; - [ + maintainers = with maintainers; [ raskin ]; platforms = platforms.linux; diff --git a/pkgs/by-name/ba/bamf/package.nix b/pkgs/by-name/ba/bamf/package.nix index ce9a3d118973ae..d79106094b6dc9 100644 --- a/pkgs/by-name/ba/bamf/package.nix +++ b/pkgs/by-name/ba/bamf/package.nix @@ -1,30 +1,35 @@ -{ stdenv -, lib -, autoreconfHook -, gitUpdater -, gnome-common -, which -, fetchgit -, libgtop -, libwnck -, glib -, vala -, pkg-config -, libstartup_notification -, gobject-introspection -, gtk-doc -, docbook_xsl -, xorgserver -, dbus -, python3 -, wrapGAppsHook3 +{ + stdenv, + lib, + autoreconfHook, + gitUpdater, + gnome-common, + which, + fetchgit, + libgtop, + libwnck, + glib, + vala, + pkg-config, + libstartup_notification, + gobject-introspection, + gtk-doc, + docbook_xsl, + xorgserver, + dbus, + python3, + wrapGAppsHook3, }: stdenv.mkDerivation rec { pname = "bamf"; version = "0.5.6"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchgit { url = "https://git.launchpad.net/~unity-team/bamf"; diff --git a/pkgs/by-name/ba/bamtools/package.nix b/pkgs/by-name/ba/bamtools/package.nix index 820459e00003bc..b85f703bd9debf 100644 --- a/pkgs/by-name/ba/bamtools/package.nix +++ b/pkgs/by-name/ba/bamtools/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, jsoncpp -, pkg-config -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + jsoncpp, + pkg-config, + zlib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ba/banana-accounting/package.nix b/pkgs/by-name/ba/banana-accounting/package.nix index b1d8d45bccdcb9..b1e455bbf6c372 100644 --- a/pkgs/by-name/ba/banana-accounting/package.nix +++ b/pkgs/by-name/ba/banana-accounting/package.nix @@ -1,15 +1,16 @@ -{ autoPatchelfHook -, cairo -, e2fsprogs -, fetchurl -, gmp -, gtk3 -, libGL -, libX11 -, lib -, stdenv -, libgcrypt -, wrapGAppsHook3 +{ + autoPatchelfHook, + cairo, + e2fsprogs, + fetchurl, + gmp, + gtk3, + libGL, + libX11, + lib, + stdenv, + libgcrypt, + wrapGAppsHook3, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ba/banana-cursor/package.nix b/pkgs/by-name/ba/banana-cursor/package.nix index 2bb9d1ea4f5780..309b476ded8bca 100644 --- a/pkgs/by-name/ba/banana-cursor/package.nix +++ b/pkgs/by-name/ba/banana-cursor/package.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, lib -, stdenvNoCC - -, # build deps - clickgen -, python3Packages +{ + fetchFromGitHub, + lib, + stdenvNoCC, + + # build deps + clickgen, + python3Packages, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -44,7 +45,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { description = "Banana Cursor"; homepage = "https://github.com/ful1e5/banana-cursor"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ getpsyched yrd ]; + maintainers = with maintainers; [ + getpsyched + yrd + ]; platforms = platforms.linux; }; }) diff --git a/pkgs/by-name/ba/banana-vera/package.nix b/pkgs/by-name/ba/banana-vera/package.nix index 704b822fa45e8e..f847f77bc570d4 100644 --- a/pkgs/by-name/ba/banana-vera/package.nix +++ b/pkgs/by-name/ba/banana-vera/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, python310 -, tcl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python310, + tcl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ba/bandwidth/package.nix b/pkgs/by-name/ba/bandwidth/package.nix index eb3f37e00ba178..b6471d2d759741 100644 --- a/pkgs/by-name/ba/bandwidth/package.nix +++ b/pkgs/by-name/ba/bandwidth/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, nasm }: +{ + lib, + stdenv, + fetchurl, + nasm, +}: let inherit (stdenv.hostPlatform.parsed.cpu) bits; diff --git a/pkgs/by-name/ba/banking/package.nix b/pkgs/by-name/ba/banking/package.nix index 4aa70e81fab489..cf19bad0f9e79e 100644 --- a/pkgs/by-name/ba/banking/package.nix +++ b/pkgs/by-name/ba/banking/package.nix @@ -1,18 +1,19 @@ -{ lib -, fetchFromGitLab -, python3 -, appstream-glib -, desktop-file-utils -, glib -, libxml2 -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, gobject-introspection -, libadwaita -, librsvg -, gtk4 +{ + lib, + fetchFromGitLab, + python3, + appstream-glib, + desktop-file-utils, + glib, + libxml2, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + gobject-introspection, + libadwaita, + librsvg, + gtk4, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ba/bankstown-lv2/package.nix b/pkgs/by-name/ba/bankstown-lv2/package.nix index 7cbe4708ff385c..6f36c19d1998e2 100644 --- a/pkgs/by-name/ba/bankstown-lv2/package.nix +++ b/pkgs/by-name/ba/bankstown-lv2/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ba/banner/package.nix b/pkgs/by-name/ba/banner/package.nix index af54f59999c80c..7bbcf4e5057fd9 100644 --- a/pkgs/by-name/ba/banner/package.nix +++ b/pkgs/by-name/ba/banner/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "banner"; diff --git a/pkgs/by-name/ba/bao/package.nix b/pkgs/by-name/ba/bao/package.nix index c36a1f34e96d8d..8e16ed6b720d2c 100644 --- a/pkgs/by-name/ba/bao/package.nix +++ b/pkgs/by-name/ba/bao/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -24,7 +25,10 @@ rustPlatform.buildRustPackage rec { description = "Implementation of BLAKE3 verified streaming"; homepage = "https://github.com/oconnor663/bao"; maintainers = with lib.maintainers; [ amarshall ]; - license = with lib.licenses; [ cc0 asl20 ]; + license = with lib.licenses; [ + cc0 + asl20 + ]; mainProgram = "bao"; }; } diff --git a/pkgs/by-name/ba/baobab/package.nix b/pkgs/by-name/ba/baobab/package.nix index c5aa44bbb5b7c5..5f086e17253153 100644 --- a/pkgs/by-name/ba/baobab/package.nix +++ b/pkgs/by-name/ba/baobab/package.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, gettext -, fetchurl -, vala -, desktop-file-utils -, meson -, ninja -, pkg-config -, gtk4 -, libadwaita -, glib -, libxml2 -, wrapGAppsHook4 -, itstool -, gnome +{ + stdenv, + lib, + gettext, + fetchurl, + vala, + desktop-file-utils, + meson, + ninja, + pkg-config, + gtk4, + libadwaita, + glib, + libxml2, + wrapGAppsHook4, + itstool, + gnome, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ba/bar/package.nix b/pkgs/by-name/ba/bar/package.nix index ee53e9d1cbfbc6..938dde819cfdab 100644 --- a/pkgs/by-name/ba/bar/package.nix +++ b/pkgs/by-name/ba/bar/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "bar"; diff --git a/pkgs/by-name/ba/barcode/package.nix b/pkgs/by-name/ba/barcode/package.nix index 6199a87925d34b..7c27e5cf0ef381 100644 --- a/pkgs/by-name/ba/barcode/package.nix +++ b/pkgs/by-name/ba/barcode/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, +}: stdenv.mkDerivation rec { version = "0.99"; diff --git a/pkgs/by-name/ba/baresip/package.nix b/pkgs/by-name/ba/baresip/package.nix index e607b56d94d5b5..b0d677f0310dd3 100644 --- a/pkgs/by-name/ba/baresip/package.nix +++ b/pkgs/by-name/ba/baresip/package.nix @@ -38,35 +38,48 @@ stdenv.mkDerivation rec { rev = "v${version}"; hash = "sha256-0huZP1hopHaN5R1Hki6YutpvoASfIHzHMl/Y4czHHMo="; }; - prePatch = '' - substituteInPlace cmake/FindGTK3.cmake --replace-fail GTK3_CFLAGS_OTHER "" - '' + lib.optionalString (!dbusSupport) '' - substituteInPlace cmake/modules.cmake --replace-fail 'list(APPEND MODULES ctrl_dbus)' "" - ''; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ - SDL2 - alsa-lib - cairo - celt - ffmpeg - gsm - gtk3 - libre - librem - libsndfile - libuuid - libv4l - libvpx - mpg123 - openssl - pipewire - portaudio - spandsp3 - speex - srtp - zlib - ] ++ (with gst_all_1; [ gstreamer gst-libav gst-plugins-base gst-plugins-bad gst-plugins-good ]); + prePatch = + '' + substituteInPlace cmake/FindGTK3.cmake --replace-fail GTK3_CFLAGS_OTHER "" + '' + + lib.optionalString (!dbusSupport) '' + substituteInPlace cmake/modules.cmake --replace-fail 'list(APPEND MODULES ctrl_dbus)' "" + ''; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = + [ + SDL2 + alsa-lib + cairo + celt + ffmpeg + gsm + gtk3 + libre + librem + libsndfile + libuuid + libv4l + libvpx + mpg123 + openssl + pipewire + portaudio + spandsp3 + speex + srtp + zlib + ] + ++ (with gst_all_1; [ + gstreamer + gst-libav + gst-plugins-base + gst-plugins-bad + gst-plugins-good + ]); cmakeFlags = [ "-DCMAKE_SKIP_BUILD_RPATH=ON" @@ -76,13 +89,13 @@ stdenv.mkDerivation rec { "-DGST_INCLUDE_DIRS=${lib.getDev gst_all_1.gstreamer}/include/gstreamer-1.0" ]; - makeFlags = [ - "PREFIX=$(out)" - "CCACHE_DISABLE=1" - ] - ++ lib.optional (stdenv.cc.cc != null) "SYSROOT_ALT=${stdenv.cc.cc}" - ++ lib.optional (stdenv.cc.libc != null) "SYSROOT=${stdenv.cc.libc}" - ; + makeFlags = + [ + "PREFIX=$(out)" + "CCACHE_DISABLE=1" + ] + ++ lib.optional (stdenv.cc.cc != null) "SYSROOT_ALT=${stdenv.cc.cc}" + ++ lib.optional (stdenv.cc.libc != null) "SYSROOT=${stdenv.cc.libc}"; enableParallelBuilding = true; @@ -162,7 +175,10 @@ stdenv.mkDerivation rec { meta = { description = "Modular SIP User-Agent with audio and video support"; homepage = "https://github.com/baresip/baresip"; - maintainers = with lib.maintainers; [ raskin ehmry ]; + maintainers = with lib.maintainers; [ + raskin + ehmry + ]; mainProgram = "baresip"; license = lib.licenses.bsd3; platforms = lib.platforms.unix; diff --git a/pkgs/by-name/ba/barlow/package.nix b/pkgs/by-name/ba/barlow/package.nix index ebdebb82538466..22d527dc1310b1 100644 --- a/pkgs/by-name/ba/barlow/package.nix +++ b/pkgs/by-name/ba/barlow/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "barlow"; diff --git a/pkgs/by-name/ba/barrage/package.nix b/pkgs/by-name/ba/barrage/package.nix index ff879e56924a3b..c6677d8b708b8e 100644 --- a/pkgs/by-name/ba/barrage/package.nix +++ b/pkgs/by-name/ba/barrage/package.nix @@ -1,8 +1,9 @@ -{ lib -, SDL -, SDL_mixer -, fetchurl -, stdenv +{ + lib, + SDL, + SDL_mixer, + fetchurl, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ba/bartib/package.nix b/pkgs/by-name/ba/bartib/package.nix index 48e131262a9086..0727c86f2675ce 100644 --- a/pkgs/by-name/ba/bartib/package.nix +++ b/pkgs/by-name/ba/bartib/package.nix @@ -1,4 +1,9 @@ -{ lib, rustPlatform, fetchFromGitHub, installShellFiles }: +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "bartib"; diff --git a/pkgs/by-name/ba/base16-schemes/package.nix b/pkgs/by-name/ba/base16-schemes/package.nix index fbc438f8ccc040..55377a415843c0 100644 --- a/pkgs/by-name/ba/base16-schemes/package.nix +++ b/pkgs/by-name/ba/base16-schemes/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ... }: +{ + lib, + stdenv, + fetchFromGitHub, + ... +}: stdenv.mkDerivation (finalAttrs: { pname = "base16-schemes"; diff --git a/pkgs/by-name/ba/base16-shell-preview/package.nix b/pkgs/by-name/ba/base16-shell-preview/package.nix index e047c7e88b2115..c6436a42e00be5 100644 --- a/pkgs/by-name/ba/base16-shell-preview/package.nix +++ b/pkgs/by-name/ba/base16-shell-preview/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchPypi +{ + lib, + python3Packages, + fetchPypi, }: let @@ -12,7 +13,7 @@ python3Packages.buildPythonApplication { src = fetchPypi { inherit version; - pname = "${lib.replaceStrings ["-"] ["_"] pname}"; + pname = "${lib.replaceStrings [ "-" ] [ "_" ] pname}"; hash = "sha256-retnbxjdjo+NeA1B0+jpM9kToAX/Rh0ze0yNF9AfDiU="; }; diff --git a/pkgs/by-name/ba/base16-universal-manager/package.nix b/pkgs/by-name/ba/base16-universal-manager/package.nix index 44b521ae0d1661..8918ddd20f31aa 100644 --- a/pkgs/by-name/ba/base16-universal-manager/package.nix +++ b/pkgs/by-name/ba/base16-universal-manager/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "base16-universal-manager"; diff --git a/pkgs/by-name/ba/base16384/package.nix b/pkgs/by-name/ba/base16384/package.nix index 2d6ffd48a29c7e..73af4ffb96557c 100644 --- a/pkgs/by-name/ba/base16384/package.nix +++ b/pkgs/by-name/ba/base16384/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ba/base45/package.nix b/pkgs/by-name/ba/base45/package.nix index 07e248ad80458d..a02b502f1ede3c 100644 --- a/pkgs/by-name/ba/base45/package.nix +++ b/pkgs/by-name/ba/base45/package.nix @@ -1,4 +1,8 @@ -{ lib, buildNimPackage, fetchFromSourcehut }: +{ + lib, + buildNimPackage, + fetchFromSourcehut, +}: buildNimPackage (finalAttrs: { pname = "base45"; diff --git a/pkgs/by-name/ba/baserow/package.nix b/pkgs/by-name/ba/baserow/package.nix index c42dc0d55a3143..29e34a5505e889 100644 --- a/pkgs/by-name/ba/baserow/package.nix +++ b/pkgs/by-name/ba/baserow/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitLab -, makeWrapper -, python3 -, antlr4_9 +{ + lib, + fetchFromGitLab, + makeWrapper, + python3, + antlr4_9, }: let @@ -36,7 +37,8 @@ let }; in -with python.pkgs; buildPythonApplication rec { +with python.pkgs; +buildPythonApplication rec { pname = "baserow"; version = "1.12.1"; format = "setuptools"; diff --git a/pkgs/by-name/ba/basex/package.nix b/pkgs/by-name/ba/basex/package.nix index 887435a47a3e31..3e79178c62b5c5 100644 --- a/pkgs/by-name/ba/basex/package.nix +++ b/pkgs/by-name/ba/basex/package.nix @@ -1,15 +1,29 @@ -{ lib, stdenv, fetchurl, unzip, jre, coreutils, makeDesktopItem, copyDesktopItems }: +{ + lib, + stdenv, + fetchurl, + unzip, + jre, + coreutils, + makeDesktopItem, + copyDesktopItems, +}: stdenv.mkDerivation rec { pname = "basex"; version = "11.6"; src = fetchurl { - url = "http://files.basex.org/releases/${version}/BaseX${builtins.replaceStrings ["."] [""] version}.zip"; + url = "http://files.basex.org/releases/${version}/BaseX${ + builtins.replaceStrings [ "." ] [ "" ] version + }.zip"; hash = "sha256-JGf+eBBlzbg0UYQqpx/IjGhjOKWCvl5rfnYpYE+JWM4="; }; - nativeBuildInputs = [ unzip copyDesktopItems ]; + nativeBuildInputs = [ + unzip + copyDesktopItems + ]; buildInputs = [ jre ]; desktopItems = lib.optional (!stdenv.hostPlatform.isDarwin) (makeDesktopItem { @@ -19,7 +33,11 @@ stdenv.mkDerivation rec { comment = "Visually query and analyse your XML data"; desktopName = "BaseX XML Database"; genericName = "XML database tool"; - categories = [ "Development" "Utility" "Database" ]; + categories = [ + "Development" + "Utility" + "Database" + ]; mimeTypes = [ "text/xml" ]; }); diff --git a/pkgs/by-name/ba/basez/package.nix b/pkgs/by-name/ba/basez/package.nix index e7fe906836e37e..fb34b61677d543 100644 --- a/pkgs/by-name/ba/basez/package.nix +++ b/pkgs/by-name/ba/basez/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl } : +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "basez"; @@ -14,9 +18,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Base 16/32/64 encode/decode data to standard output"; longDescription = '' - Encode data into/decode data from base16, base32, base32hex, base64 or - base64url stream per RFC 4648; MIME base64 Content-Transfer-Encoding - per RFC 2045; or PEM Printable Encoding per RFC 1421. + Encode data into/decode data from base16, base32, base32hex, base64 or + base64url stream per RFC 4648; MIME base64 Content-Transfer-Encoding + per RFC 2045; or PEM Printable Encoding per RFC 1421. ''; homepage = "http://www.quarkline.net/basez/"; license = licenses.gpl3Plus; diff --git a/pkgs/by-name/ba/bash-completion/package.nix b/pkgs/by-name/ba/bash-completion/package.nix index 40d4c564ff9e3a..6329a1412fa5ed 100644 --- a/pkgs/by-name/ba/bash-completion/package.nix +++ b/pkgs/by-name/ba/bash-completion/package.nix @@ -1,9 +1,12 @@ -{ lib, stdenv, fetchurl -, autoreconfHook -, perl -, ps -, python3Packages -, bashInteractive +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + perl, + ps, + python3Packages, + bashInteractive, }: stdenv.mkDerivation rec { @@ -59,12 +62,14 @@ stdenv.mkDerivation rec { --ignore=test/t/test_screen.py ''; - prePatch = lib.optionalString stdenv.hostPlatform.isDarwin '' - sed -i -e 's/readlink -f/readlink/g' bash_completion completions/* - '' + lib.optionalString stdenv.hostPlatform.isFreeBSD '' - # please remove this next release! - touch completions/{pkg_delete,freebsd-update,kldload,kldunload,portinstall,portsnap,portupgrade} - ''; + prePatch = + lib.optionalString stdenv.hostPlatform.isDarwin '' + sed -i -e 's/readlink -f/readlink/g' bash_completion completions/* + '' + + lib.optionalString stdenv.hostPlatform.isFreeBSD '' + # please remove this next release! + touch completions/{pkg_delete,freebsd-update,kldload,kldunload,portinstall,portsnap,portupgrade} + ''; meta = with lib; { homepage = "https://github.com/scop/bash-completion"; diff --git a/pkgs/by-name/ba/bash-language-server/package.nix b/pkgs/by-name/ba/bash-language-server/package.nix index a5853aeb9e2cf0..f625b702df3094 100644 --- a/pkgs/by-name/ba/bash-language-server/package.nix +++ b/pkgs/by-name/ba/bash-language-server/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, pnpm_8 -, nodejs -, makeBinaryWrapper -, shellcheck -, versionCheckHook +{ + lib, + stdenv, + fetchFromGitHub, + pnpm_8, + nodejs, + makeBinaryWrapper, + shellcheck, + versionCheckHook, }: stdenv.mkDerivation (finalAttrs: { @@ -21,7 +22,12 @@ stdenv.mkDerivation (finalAttrs: { pnpmWorkspaces = [ "bash-language-server" ]; pnpmDeps = pnpm_8.fetchDeps { - inherit (finalAttrs) pname version src pnpmWorkspaces; + inherit (finalAttrs) + pname + version + src + pnpmWorkspaces + ; hash = "sha256-W25xehcxncBs9QgQBt17F5YHK0b+GDEmt27XzTkyYWg="; }; diff --git a/pkgs/by-name/ba/bash-my-aws/package.nix b/pkgs/by-name/ba/bash-my-aws/package.nix index 9ca14bbe3376ea..0c932a0f57f418 100644 --- a/pkgs/by-name/ba/bash-my-aws/package.nix +++ b/pkgs/by-name/ba/bash-my-aws/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, makeWrapper -, awscli -, jq -, unixtools -, fetchFromGitHub -, installShellFiles -, bashInteractive +{ + lib, + stdenv, + makeWrapper, + awscli, + jq, + unixtools, + fetchFromGitHub, + installShellFiles, + bashInteractive, }: stdenv.mkDerivation rec { @@ -28,7 +30,10 @@ stdenv.mkDerivation rec { unixtools.column bashInteractive ]; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; checkPhase = '' pushd test @@ -36,7 +41,7 @@ stdenv.mkDerivation rec { ./stack-spec.sh popd ''; - installPhase='' + installPhase = '' mkdir -p $out cp -r . $out ''; @@ -54,7 +59,14 @@ stdenv.mkDerivation rec { --replace .bash-my-aws "" substituteInPlace bin/bma \ --replace '~/.bash-my-aws' $out - wrapProgram $out/bin/bma --prefix PATH : ${lib.makeBinPath [awscli jq unixtools.column bashInteractive ]} + wrapProgram $out/bin/bma --prefix PATH : ${ + lib.makeBinPath [ + awscli + jq + unixtools.column + bashInteractive + ] + } installShellCompletion --bash --name bash-my-aws.bash bash_completion.sh chmod +x $out/lib/* patchShebangs --host $out/lib diff --git a/pkgs/by-name/ba/bash-preexec/package.nix b/pkgs/by-name/ba/bash-preexec/package.nix index 166b73b1daf6c0..74c76239599d25 100644 --- a/pkgs/by-name/ba/bash-preexec/package.nix +++ b/pkgs/by-name/ba/bash-preexec/package.nix @@ -1,7 +1,14 @@ -{ stdenvNoCC, lib, fetchFromGitHub, bats }: - -let version = "0.5.0"; -in stdenvNoCC.mkDerivation { +{ + stdenvNoCC, + lib, + fetchFromGitHub, + bats, +}: + +let + version = "0.5.0"; +in +stdenvNoCC.mkDerivation { pname = "bash-preexec"; inherit version; @@ -39,7 +46,10 @@ in stdenvNoCC.mkDerivation { description = "preexec and precmd functions for Bash just like Zsh"; license = licenses.mit; homepage = "https://github.com/rcaloras/bash-preexec"; - maintainers = [ maintainers.hawkw maintainers.rycee ]; + maintainers = [ + maintainers.hawkw + maintainers.rycee + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ba/bash-supergenpass/package.nix b/pkgs/by-name/ba/bash-supergenpass/package.nix index 7bf7c36424886e..bc83a9d6345d78 100644 --- a/pkgs/by-name/ba/bash-supergenpass/package.nix +++ b/pkgs/by-name/ba/bash-supergenpass/package.nix @@ -1,10 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, unstableGitUpdater -, makeWrapper -, openssl -, coreutils -, gnugrep }: +{ + lib, + stdenv, + fetchFromGitHub, + unstableGitUpdater, + makeWrapper, + openssl, + coreutils, + gnugrep, +}: stdenv.mkDerivation { pname = "bash-supergenpass"; @@ -21,7 +24,13 @@ stdenv.mkDerivation { installPhase = '' install -m755 -D supergenpass.sh "$out/bin/supergenpass" - wrapProgram "$out/bin/supergenpass" --prefix PATH : "${lib.makeBinPath [ openssl coreutils gnugrep ]}" + wrapProgram "$out/bin/supergenpass" --prefix PATH : "${ + lib.makeBinPath [ + openssl + coreutils + gnugrep + ] + }" ''; passthru.updateScript = unstableGitUpdater { diff --git a/pkgs/by-name/ba/bashSnippets/package.nix b/pkgs/by-name/ba/bashSnippets/package.nix index f0f82a6f626cd2..0dc28d54d75a0a 100644 --- a/pkgs/by-name/ba/bashSnippets/package.nix +++ b/pkgs/by-name/ba/bashSnippets/package.nix @@ -1,5 +1,15 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper -, curl, python3, bind, iproute2, bc, gitMinimal }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + curl, + python3, + bind, + iproute2, + bc, + gitMinimal, +}: let version = "1.23.0"; deps = lib.makeBinPath [ diff --git a/pkgs/by-name/ba/bash_unit/package.nix b/pkgs/by-name/ba/bash_unit/package.nix index ebf7d6916b32d9..f796eb03bf98a8 100644 --- a/pkgs/by-name/ba/bash_unit/package.nix +++ b/pkgs/by-name/ba/bash_unit/package.nix @@ -1,5 +1,7 @@ -{ fetchFromGitHub -, lib, stdenv +{ + fetchFromGitHub, + lib, + stdenv, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ba/bashblog/package.nix b/pkgs/by-name/ba/bashblog/package.nix index 0c43e6eecf1cea..91a34e9b3e70b4 100644 --- a/pkgs/by-name/ba/bashblog/package.nix +++ b/pkgs/by-name/ba/bashblog/package.nix @@ -1,13 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, makeWrapper -, substituteAll -, perlPackages -# Flags to enable processors -# Currently, Markdown.pl does not work -, usePandoc ? true -, pandoc }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + substituteAll, + perlPackages, + # Flags to enable processors + # Currently, Markdown.pl does not work + usePandoc ? true, + pandoc, +}: let inherit (perlPackages) TextMarkdown; @@ -16,7 +18,8 @@ let markdownpl_path = "${perlPackages.TextMarkdown}/bin/Markdown.pl"; pandoc_path = "${pandoc}/bin/pandoc"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "bashblog"; version = "unstable-2022-03-26"; @@ -29,8 +32,7 @@ in stdenv.mkDerivation { nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ TextMarkdown ] - ++ lib.optionals usePandoc [ pandoc ]; + buildInputs = [ TextMarkdown ] ++ lib.optionals usePandoc [ pandoc ]; patches = [ (substituteAll { diff --git a/pkgs/by-name/ba/bashcards/package.nix b/pkgs/by-name/ba/bashcards/package.nix index bce5ab40e2dd6f..48bea6020f3ce2 100644 --- a/pkgs/by-name/ba/bashcards/package.nix +++ b/pkgs/by-name/ba/bashcards/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ba/bashdb/package.nix b/pkgs/by-name/ba/bashdb/package.nix index 52119250f69c12..5ec0a5999c3fa4 100644 --- a/pkgs/by-name/ba/bashdb/package.nix +++ b/pkgs/by-name/ba/bashdb/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, makeWrapper -, python3Packages +{ + lib, + stdenv, + fetchurl, + fetchpatch, + makeWrapper, + python3Packages, }: stdenv.mkDerivation rec { @@ -11,7 +12,7 @@ stdenv.mkDerivation rec { version = "5.0-1.1.2"; src = fetchurl { - url = "mirror://sourceforge/bashdb/${pname}-${version}.tar.bz2"; + url = "mirror://sourceforge/bashdb/${pname}-${version}.tar.bz2"; sha256 = "sha256-MBdtKtKMWwCy4tIcXqGu+PuvQKj52fcjxnxgUx87czA="; }; diff --git a/pkgs/by-name/ba/bashly/gemset.nix b/pkgs/by-name/ba/bashly/gemset.nix index 9a95ade58ccf9e..0bfcd463529f81 100644 --- a/pkgs/by-name/ba/bashly/gemset.nix +++ b/pkgs/by-name/ba/bashly/gemset.nix @@ -1,280 +1,309 @@ { bashly = { - dependencies = ["colsole" "completely" "filewatcher" "gtx" "logger" "lp" "mister_bin" "ostruct" "psych" "requires" "tty-markdown"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "colsole" + "completely" + "filewatcher" + "gtx" + "logger" + "lp" + "mister_bin" + "ostruct" + "psych" + "requires" + "tty-markdown" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dzyqwf43i92jq5j66j31qvsbfcpd6zk74ssqz14kj51wn2d8vw3"; type = "gem"; }; version = "1.2.6"; }; cgi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0c5494n3n6l51n1w1vc118zckbqdzk7r6b656hswg72w0bif2ja3"; type = "gem"; }; version = "0.4.1"; }; colsole = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fvf6dz2wsvjk7q24z0dm8lajq3p2l6i5ywf3mxj683rmhwq49bg"; type = "gem"; }; version = "1.0.0"; }; completely = { - dependencies = ["colsole" "mister_bin"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "colsole" + "mister_bin" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ci8iza647hvc4f1cmf9mpsm3i78ysf6g6213wkyrr5jk296hjjb"; type = "gem"; }; version = "0.6.3"; }; docopt_ng = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rsnl5s7k2s1gl4n4dg68ssg577kf11sl4a4l2lb2fpswj718950"; type = "gem"; }; version = "0.7.1"; }; erb = { - dependencies = ["cgi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "cgi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05wpc7pn1k6jik7i57vfrj6k5lda39hrny0q3706pi05c886w4fy"; type = "gem"; }; version = "4.0.4"; }; filewatcher = { - dependencies = ["module_methods"]; - groups = ["default"]; - platforms = []; + dependencies = [ "module_methods" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03f9v57c5zag09mi10yjhdx7y0vv2w5wrnwzbij9hhkwh43rk077"; type = "gem"; }; version = "2.1.0"; }; gtx = { - dependencies = ["erb"]; - groups = ["default"]; - platforms = []; + dependencies = [ "erb" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1w0hbr9i6jpn9spbb13ipg2fajkwa51y56jw21ziwsddmv997274"; type = "gem"; }; version = "0.1.1"; }; kramdown = { - dependencies = ["rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rexml" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ic14hdcqxn821dvzki99zhmcy130yhv5fqfffkcf87asv5mnbmn"; type = "gem"; }; version = "2.4.0"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; lp = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ns1aza32n929w7smg1dsn4g6qlfi7k1jrvssyn35cicmwn0gyyr"; type = "gem"; }; version = "0.2.1"; }; mister_bin = { - dependencies = ["colsole" "docopt_ng"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "colsole" + "docopt_ng" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xx8cxvzcn47zsnshcllf477x4rbssrchvp76929qnsg5k9q7fas"; type = "gem"; }; version = "0.7.6"; }; module_methods = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1886wjscfripgzlmyvcd0jmlzwr6hxvklm2a5rm32dw5bf7bvjki"; type = "gem"; }; version = "0.1.0"; }; ostruct = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05xqijcf80sza5pnlp1c8whdaay8x5dc13214ngh790zrizgp8q9"; type = "gem"; }; version = "0.6.1"; }; pastel = { - dependencies = ["tty-color"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-color" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xash2gj08dfjvq4hy6l1z22s5v30fhizwgs10d6nviggpxsj7a8"; type = "gem"; }; version = "0.8.0"; }; psych = { - dependencies = ["stringio"]; - groups = ["default"]; - platforms = []; + dependencies = [ "stringio" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wq567f615x1ilgaqlh4yzf322f96rgn45xw4nm4vwfaddszw0v6"; type = "gem"; }; version = "5.2.0"; }; requires = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dlibxp6jfdl4favj2pgsm2pw84hhr2cdiizfs51ldkpddm50njp"; type = "gem"; }; version = "1.1.0"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j9p66pmfgxnzp76ksssyfyqqrg7281dyi3xyknl3wwraaw7a66p"; type = "gem"; }; version = "3.3.9"; }; rouge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dllqyxlxsmsy4xdpgwbn6w9w6qsha9ay6cl5kq06jgw63k5dp10"; type = "gem"; }; version = "4.5.0"; }; stringio = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cd1kdrf62p2ya3ia4rz49d5012bqinvqjmcgkakknswz0l1hkr0"; type = "gem"; }; version = "3.1.2"; }; strings = { - dependencies = ["strings-ansi" "unicode-display_width" "unicode_utils"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "strings-ansi" + "unicode-display_width" + "unicode_utils" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yynb0qhhhplmpzavfrrlwdnd1rh7rkwzcs4xf0mpy2wr6rr6clk"; type = "gem"; }; version = "0.2.1"; }; strings-ansi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "120wa6yjc63b84lprglc52f40hx3fx920n4dmv14rad41rv2s9lh"; type = "gem"; }; version = "0.2.0"; }; tty-color = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0aik4kmhwwrmkysha7qibi2nyzb4c8kp42bd5vxnf8sf7b53g73g"; type = "gem"; }; version = "0.6.0"; }; tty-markdown = { - dependencies = ["kramdown" "pastel" "rouge" "strings" "tty-color" "tty-screen"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "kramdown" + "pastel" + "rouge" + "strings" + "tty-color" + "tty-screen" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04f599zn5rfndq4d9l0acllfpc041bzdkkz2h6x0dl18f2wivn0y"; type = "gem"; }; version = "0.7.2"; }; tty-screen = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0l4vh6g333jxm9lakilkva2gn17j6gb052626r1pdbmy2lhnb460"; type = "gem"; }; version = "0.8.2"; }; unicode-display_width = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nkz7fadlrdbkf37m0x7sw8bnz8r355q3vwcfb9f9md6pds9h9qj"; type = "gem"; }; version = "2.6.0"; }; unicode_utils = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h1a5yvrxzlf0lxxa1ya31jcizslf774arnsd89vgdhk4g7x08mr"; type = "gem"; }; diff --git a/pkgs/by-name/ba/bashmount/package.nix b/pkgs/by-name/ba/bashmount/package.nix index e1995474abc751..915d09a2c5cfb2 100644 --- a/pkgs/by-name/ba/bashmount/package.nix +++ b/pkgs/by-name/ba/bashmount/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchFromGitHub}: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "bashmount"; diff --git a/pkgs/by-name/ba/bashplotlib/package.nix b/pkgs/by-name/ba/bashplotlib/package.nix index d35d9ebcbcc04d..153e02d6d4a24f 100644 --- a/pkgs/by-name/ba/bashplotlib/package.nix +++ b/pkgs/by-name/ba/bashplotlib/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication { pname = "bashplotlib"; diff --git a/pkgs/by-name/ba/basiliskii/package.nix b/pkgs/by-name/ba/basiliskii/package.nix index a81f50b5421133..a6e77d3e523219 100644 --- a/pkgs/by-name/ba/basiliskii/package.nix +++ b/pkgs/by-name/ba/basiliskii/package.nix @@ -1,4 +1,14 @@ -{ stdenv, lib, fetchFromGitHub, autoconf, automake, pkg-config, SDL2, gtk2, mpfr }: +{ + stdenv, + lib, + fetchFromGitHub, + autoconf, + automake, + pkg-config, + SDL2, + gtk2, + mpfr, +}: stdenv.mkDerivation (finalAttrs: { pname = "basiliskii"; version = "unstable-2022-09-30"; @@ -11,12 +21,24 @@ stdenv.mkDerivation (finalAttrs: { }; sourceRoot = "${finalAttrs.src.name}/BasiliskII/src/Unix"; patches = [ ./remove-redhat-6-workaround-for-scsi-sg.h.patch ]; - nativeBuildInputs = [ autoconf automake pkg-config ]; - buildInputs = [ SDL2 gtk2 mpfr ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + ]; + buildInputs = [ + SDL2 + gtk2 + mpfr + ]; preConfigure = '' NO_CONFIGURE=1 ./autogen.sh ''; - configureFlags = [ "--enable-sdl-video" "--enable-sdl-audio" "--with-bincue" ]; + configureFlags = [ + "--enable-sdl-video" + "--enable-sdl-audio" + "--with-bincue" + ]; meta = with lib; { description = "68k Macintosh emulator"; diff --git a/pkgs/by-name/ba/bastet/package.nix b/pkgs/by-name/ba/bastet/package.nix index 5fde8064d7553a..ef77b94218b3ac 100644 --- a/pkgs/by-name/ba/bastet/package.nix +++ b/pkgs/by-name/ba/bastet/package.nix @@ -1,9 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, ncurses, boost }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + ncurses, + boost, +}: stdenv.mkDerivation rec { pname = "bastet"; version = "0.43.2"; - buildInputs = [ ncurses boost ]; + buildInputs = [ + ncurses + boost + ]; src = fetchFromGitHub { owner = "fph"; diff --git a/pkgs/by-name/ba/basu/package.nix b/pkgs/by-name/ba/basu/package.nix index a3bd836ee83fc2..b98b7cbd16e101 100644 --- a/pkgs/by-name/ba/basu/package.nix +++ b/pkgs/by-name/ba/basu/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromSourcehut -, audit -, pkg-config -, libcap -, gperf -, meson -, ninja -, python3 -, getent +{ + lib, + stdenv, + fetchFromSourcehut, + audit, + pkg-config, + libcap, + gperf, + meson, + ninja, + python3, + getent, }: stdenv.mkDerivation (finalAttrs: { @@ -22,7 +23,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-zIaEIIo8lJeas2gVjMezO2hr8RnMIT7iiCBilZx5lRQ="; }; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; buildInputs = [ audit diff --git a/pkgs/by-name/ba/bat/package.nix b/pkgs/by-name/ba/bat/package.nix index 978ca06a47f340..2084af6469faba 100644 --- a/pkgs/by-name/ba/bat/package.nix +++ b/pkgs/by-name/ba/bat/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, less -, libiconv -, installShellFiles -, makeWrapper -, apple-sdk_11 +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + less, + libiconv, + installShellFiles, + makeWrapper, + apple-sdk_11, }: rustPlatform.buildRustPackage rec { @@ -22,9 +23,16 @@ rustPlatform.buildRustPackage rec { }; cargoHash = "sha256-b7wNWdKQ4QLeCf7bNZRfzT9hD/D/oDglU7Xyb65IrGY="; - nativeBuildInputs = [ pkg-config installShellFiles makeWrapper ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + makeWrapper + ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv apple-sdk_11 ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + apple-sdk_11 + ]; postInstall = '' installManPage $releaseDir/build/bat-*/out/assets/manual/bat.1 @@ -73,8 +81,16 @@ rustPlatform.buildRustPackage rec { description = "Cat(1) clone with syntax highlighting and Git integration"; homepage = "https://github.com/sharkdp/bat"; changelog = "https://github.com/sharkdp/bat/raw/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; mainProgram = "bat"; - maintainers = with maintainers; [ dywedir zowoq SuperSandro2000 sigmasquadron ]; + maintainers = with maintainers; [ + dywedir + zowoq + SuperSandro2000 + sigmasquadron + ]; }; } diff --git a/pkgs/by-name/ba/bats/libraries.nix b/pkgs/by-name/ba/bats/libraries.nix index b780bce13fd0aa..cfd55ef6483097 100644 --- a/pkgs/by-name/ba/bats/libraries.nix +++ b/pkgs/by-name/ba/bats/libraries.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub }: { +{ + lib, + stdenv, + fetchFromGitHub, +}: +{ bats-assert = stdenv.mkDerivation (finalAttrs: { pname = "bats-assert"; version = "2.1.0"; diff --git a/pkgs/by-name/ba/bats/package.nix b/pkgs/by-name/ba/bats/package.nix index 12e40444c50040..91683dc96c3f47 100644 --- a/pkgs/by-name/ba/bats/package.nix +++ b/pkgs/by-name/ba/bats/package.nix @@ -1,28 +1,29 @@ -{ resholve -, lib -, stdenv -, fetchFromGitHub -, bash -, coreutils -, gnugrep -, ncurses -, findutils -, hostname -, parallel -, flock -, procps -, bats -, lsof -, callPackages -, symlinkJoin -, makeWrapper -, runCommand -, doInstallCheck ? true -# packages that use bats (for update testing) -, bash-preexec -, kikit -, locate-dominating-file -, packcc +{ + resholve, + lib, + stdenv, + fetchFromGitHub, + bash, + coreutils, + gnugrep, + ncurses, + findutils, + hostname, + parallel, + flock, + procps, + bats, + lsof, + callPackages, + symlinkJoin, + makeWrapper, + runCommand, + doInstallCheck ? true, + # packages that use bats (for update testing) + bash-preexec, + kikit, + locate-dominating-file, + packcc, }: resholve.mkDerivation rec { @@ -66,12 +67,14 @@ resholve.mkDerivation rec { procps ]; fake = { - external = [ - "greadlink" - "shlock" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "pkill" # procps doesn't supply this on darwin - ]; + external = + [ + "greadlink" + "shlock" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "pkill" # procps doesn't supply this on darwin + ]; }; fix = { "$BATS_ROOT" = [ "${placeholder "out"}" ]; @@ -103,32 +106,35 @@ resholve.mkDerivation rec { "$parallel_binary_name" = "${parallel}/bin/parallel"; "${placeholder "out"}/libexec/bats-core/bats-preprocess" = true; }; - execer = [ - /* - both blatant lies for expedience; these can certainly exec args - they may be safe here, because they may always run things that - are ultimately in libexec? - TODO: handle parallel and flock in binlore/resholve - */ - "cannot:${parallel}/bin/parallel" - "cannot:${flock}/bin/flock" - - "cannot:libexec/bats-core/bats-preprocess" - - # these do exec, but other internal files - "cannot:libexec/bats-core/bats-exec-file" - "cannot:libexec/bats-core/bats-exec-suite" - "cannot:libexec/bats-core/bats-gather-tests" - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - # checked invocations for exec - "cannot:${procps}/bin/pkill" - ]; + execer = + [ + /* + both blatant lies for expedience; these can certainly exec args + they may be safe here, because they may always run things that + are ultimately in libexec? + TODO: handle parallel and flock in binlore/resholve + */ + "cannot:${parallel}/bin/parallel" + "cannot:${flock}/bin/flock" + + "cannot:libexec/bats-core/bats-preprocess" + + # these do exec, but other internal files + "cannot:libexec/bats-core/bats-exec-file" + "cannot:libexec/bats-core/bats-exec-suite" + "cannot:libexec/bats-core/bats-gather-tests" + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + # checked invocations for exec + "cannot:${procps}/bin/pkill" + ]; }; }; - passthru.libraries = callPackages ./libraries.nix {}; + passthru.libraries = callPackages ./libraries.nix { }; - passthru.withLibraries = selector: + passthru.withLibraries = + selector: symlinkJoin { name = "bats-with-libraries-${bats.version}"; @@ -146,90 +152,105 @@ resholve.mkDerivation rec { ''; }; - passthru.tests = { - libraries = runCommand "${bats.name}-with-libraries-test" { - testScript = '' - setup() { - bats_load_library bats-support - bats_load_library bats-assert - bats_load_library bats-file - bats_load_library bats-detik/detik.bash - - bats_require_minimum_version 1.5.0 - - TEST_TEMP_DIR="$(temp_make --prefix 'nixpkgs-bats-test')" - } - - teardown() { - temp_del "$TEST_TEMP_DIR" - } - - @test echo_hi { - run -0 echo hi - assert_output "hi" - } - - @test cp_failure { - run ! cp - assert_line --index 0 "cp: missing file operand" - assert_line --index 1 "Try 'cp --help' for more information." - } - - @test file_exists { - echo "hi" > "$TEST_TEMP_DIR/hello.txt" - assert_file_exist "$TEST_TEMP_DIR/hello.txt" - run cat "$TEST_TEMP_DIR/hello.txt" - assert_output "hi" - } - ''; - passAsFile = [ "testScript" ]; - } '' - ${bats.withLibraries (p: [ p.bats-support p.bats-assert p.bats-file p.bats-detik ])}/bin/bats "$testScriptPath" - touch "$out" - ''; - - upstream = bats.unresholved.overrideAttrs (old: { - name = "${bats.name}-tests"; - dontInstall = true; # just need the build directory - nativeInstallCheckInputs = [ - ncurses - parallel # skips some tests if it can't detect - flock # skips some tests if it can't detect - procps - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ lsof ]; - inherit doInstallCheck; - installCheckPhase = '' - # TODO: cut if https://github.com/bats-core/bats-core/issues/418 allows - sed -i '/test works even if PATH is reset/a skip "disabled for nix build"' test/bats.bats - - # skip tests that assume bats `install.sh` will be in BATS_ROOT - rm test/root.bats - - '' + (lib.optionalString stdenv.hostPlatform.isDarwin '' - # skip new timeout tests which are failing on macOS for unclear reasons - # This might relate to procps not having a pkill? - rm test/timeout.bats - '') + '' - - # test generates file with absolute shebang dynamically - substituteInPlace test/install.bats --replace \ - "/usr/bin/env bash" "${bash}/bin/bash" - - ${bats}/bin/bats test - touch $out - ''; - }); - - # to see when updates would break things, include packages - # that use nixpkgs' bats for testing (as long as they - # aren't massive builds) - inherit bash-preexec locate-dominating-file packcc; - resholve = resholve.tests.cli; - } // lib.optionalAttrs (!stdenv.hostPlatform.isDarwin) { - # TODO: kikit's kicad dependency is marked broken on darwin atm - # may be able to fold this up if that resolves. - inherit kikit; - }; + passthru.tests = + { + libraries = + runCommand "${bats.name}-with-libraries-test" + { + testScript = '' + setup() { + bats_load_library bats-support + bats_load_library bats-assert + bats_load_library bats-file + bats_load_library bats-detik/detik.bash + + bats_require_minimum_version 1.5.0 + + TEST_TEMP_DIR="$(temp_make --prefix 'nixpkgs-bats-test')" + } + + teardown() { + temp_del "$TEST_TEMP_DIR" + } + + @test echo_hi { + run -0 echo hi + assert_output "hi" + } + + @test cp_failure { + run ! cp + assert_line --index 0 "cp: missing file operand" + assert_line --index 1 "Try 'cp --help' for more information." + } + + @test file_exists { + echo "hi" > "$TEST_TEMP_DIR/hello.txt" + assert_file_exist "$TEST_TEMP_DIR/hello.txt" + run cat "$TEST_TEMP_DIR/hello.txt" + assert_output "hi" + } + ''; + passAsFile = [ "testScript" ]; + } + '' + ${ + bats.withLibraries (p: [ + p.bats-support + p.bats-assert + p.bats-file + p.bats-detik + ]) + }/bin/bats "$testScriptPath" + touch "$out" + ''; + + upstream = bats.unresholved.overrideAttrs (old: { + name = "${bats.name}-tests"; + dontInstall = true; # just need the build directory + nativeInstallCheckInputs = [ + ncurses + parallel # skips some tests if it can't detect + flock # skips some tests if it can't detect + procps + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ lsof ]; + inherit doInstallCheck; + installCheckPhase = + '' + # TODO: cut if https://github.com/bats-core/bats-core/issues/418 allows + sed -i '/test works even if PATH is reset/a skip "disabled for nix build"' test/bats.bats + + # skip tests that assume bats `install.sh` will be in BATS_ROOT + rm test/root.bats + + '' + + (lib.optionalString stdenv.hostPlatform.isDarwin '' + # skip new timeout tests which are failing on macOS for unclear reasons + # This might relate to procps not having a pkill? + rm test/timeout.bats + '') + + '' + + # test generates file with absolute shebang dynamically + substituteInPlace test/install.bats --replace \ + "/usr/bin/env bash" "${bash}/bin/bash" + + ${bats}/bin/bats test + touch $out + ''; + }); + + # to see when updates would break things, include packages + # that use nixpkgs' bats for testing (as long as they + # aren't massive builds) + inherit bash-preexec locate-dominating-file packcc; + resholve = resholve.tests.cli; + } + // lib.optionalAttrs (!stdenv.hostPlatform.isDarwin) { + # TODO: kikit's kicad dependency is marked broken on darwin atm + # may be able to fold this up if that resolves. + inherit kikit; + }; meta = with lib; { homepage = "https://github.com/bats-core/bats-core"; diff --git a/pkgs/by-name/ba/batsignal/package.nix b/pkgs/by-name/ba/batsignal/package.nix index 94a1a45fe107a8..ef6e34c57e8f94 100644 --- a/pkgs/by-name/ba/batsignal/package.nix +++ b/pkgs/by-name/ba/batsignal/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, libnotify, pkg-config, glib }: +{ + lib, + stdenv, + fetchFromGitHub, + libnotify, + pkg-config, + glib, +}: stdenv.mkDerivation rec { pname = "batsignal"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-yngd2yP6XtRp8y8ZUd0NISdf8+8wJvpLogrQQMdB0lA="; }; - buildInputs = [ libnotify glib ]; + buildInputs = [ + libnotify + glib + ]; nativeBuildInputs = [ pkg-config ]; installFlags = [ "PREFIX=${placeholder "out"}" ]; diff --git a/pkgs/by-name/ba/baudline/package.nix b/pkgs/by-name/ba/baudline/package.nix index 4856a0ed017a4e..92bedea2b83f25 100644 --- a/pkgs/by-name/ba/baudline/package.nix +++ b/pkgs/by-name/ba/baudline/package.nix @@ -1,10 +1,25 @@ -{ lib, stdenv, fetchurl, libXmu, libXt, libX11, libXext, libXxf86vm, libjack2 -, makeWrapper +{ + lib, + stdenv, + fetchurl, + libXmu, + libXt, + libX11, + libXext, + libXxf86vm, + libjack2, + makeWrapper, }: let - rpath = lib.makeLibraryPath - [ libXmu libXt libX11 libXext libXxf86vm libjack2 ]; + rpath = lib.makeLibraryPath [ + libXmu + libXt + libX11 + libXext + libXxf86vm + libjack2 + ]; in stdenv.mkDerivation rec { pname = "baudline"; @@ -64,7 +79,10 @@ stdenv.mkDerivation rec { # (Do NOT (re)distribute on hydra.) license = licenses.unfree; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ maintainers.bjornfor ]; }; diff --git a/pkgs/by-name/ba/bayescan/package.nix b/pkgs/by-name/ba/bayescan/package.nix index e715ff4b45b069..7fc5e767c47092 100644 --- a/pkgs/by-name/ba/bayescan/package.nix +++ b/pkgs/by-name/ba/bayescan/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, unzip, llvmPackages }: +{ + lib, + stdenv, + fetchurl, + unzip, + llvmPackages, +}: stdenv.mkDerivation rec { pname = "bayescan"; diff --git a/pkgs/by-name/ba/bazarr/package.nix b/pkgs/by-name/ba/bazarr/package.nix index 86541b67996ac3..d08dfe0e14a993 100644 --- a/pkgs/by-name/ba/bazarr/package.nix +++ b/pkgs/by-name/ba/bazarr/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchzip, makeWrapper, python3, unar, ffmpeg, nixosTests }: +{ + stdenv, + lib, + fetchzip, + makeWrapper, + python3, + unar, + ffmpeg, + nixosTests, +}: let runtimeProgDeps = [ diff --git a/pkgs/by-name/ba/bazel-buildtools/package.nix b/pkgs/by-name/ba/bazel-buildtools/package.nix index f3cb1a9313e135..8a4a7c37785b5b 100644 --- a/pkgs/by-name/ba/bazel-buildtools/package.nix +++ b/pkgs/by-name/ba/bazel-buildtools/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "bazel-buildtools"; @@ -23,15 +27,24 @@ buildGoModule rec { excludedPackages = [ "generatetables" ]; - ldflags = [ "-s" "-w" "-X main.buildVersion=${version}" "-X main.buildScmRevision=${src.rev}" ]; + ldflags = [ + "-s" + "-w" + "-X main.buildVersion=${version}" + "-X main.buildScmRevision=${src.rev}" + ]; meta = with lib; { description = "Tools for working with Google's bazel buildtool. Includes buildifier, buildozer, and unused_deps"; homepage = "https://github.com/bazelbuild/buildtools"; changelog = "https://github.com/bazelbuild/buildtools/releases/tag/v${version}"; license = licenses.asl20; - maintainers = with maintainers; - [ elasticdog uri-canva ] + maintainers = + with maintainers; + [ + elasticdog + uri-canva + ] ++ lib.teams.bazel.members; }; } diff --git a/pkgs/by-name/ba/bazel-gazelle/package.nix b/pkgs/by-name/ba/bazel-gazelle/package.nix index 2a733e9fed9e2c..5bfcb0b5ad6ead 100644 --- a/pkgs/by-name/ba/bazel-gazelle/package.nix +++ b/pkgs/by-name/ba/bazel-gazelle/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/ba/bazel-kazel/package.nix b/pkgs/by-name/ba/bazel-kazel/package.nix index 8d7ceb04f0eba0..9144af8cf614f2 100644 --- a/pkgs/by-name/ba/bazel-kazel/package.nix +++ b/pkgs/by-name/ba/bazel-kazel/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "bazel-kazel"; diff --git a/pkgs/by-name/ba/bazel-remote/package.nix b/pkgs/by-name/ba/bazel-remote/package.nix index 182b66c8db085f..642416e16f5f25 100644 --- a/pkgs/by-name/ba/bazel-remote/package.nix +++ b/pkgs/by-name/ba/bazel-remote/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { @@ -20,7 +21,11 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X main.gitCommit=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.gitCommit=${version}" + ]; meta = with lib; { homepage = "https://github.com/buchgr/bazel-remote"; diff --git a/pkgs/by-name/ba/bazelisk/package.nix b/pkgs/by-name/ba/bazelisk/package.nix index 00b1ca67f1dfc3..aefc25cd0d4136 100644 --- a/pkgs/by-name/ba/bazelisk/package.nix +++ b/pkgs/by-name/ba/bazelisk/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "bazelisk"; @@ -15,7 +19,11 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X main.BazeliskVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.BazeliskVersion=${version}" + ]; meta = with lib; { description = "User-friendly launcher for Bazel"; diff --git a/pkgs/by-name/bb/bb/package.nix b/pkgs/by-name/bb/bb/package.nix index 1c7eedc565700d..07aff0992d81db 100644 --- a/pkgs/by-name/bb/bb/package.nix +++ b/pkgs/by-name/bb/bb/package.nix @@ -1,11 +1,20 @@ -{ stdenv, lib, fetchurl, autoreconfHook, aalib, ncurses, xorg, libmikmod }: +{ + stdenv, + lib, + fetchurl, + autoreconfHook, + aalib, + ncurses, + xorg, + libmikmod, +}: stdenv.mkDerivation rec { pname = "bb"; version = "1.3rc1"; src = fetchurl { - url = "mirror://sourceforge/aa-project/bb/${version}/${pname}-${version}.tar.gz"; + url = "mirror://sourceforge/aa-project/bb/${version}/${pname}-${version}.tar.gz"; sha256 = "1i411glxh7g4pfg4gw826lpwngi89yrbmxac8jmnsfvrfb48hgbr"; }; @@ -17,8 +26,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; buildInputs = [ - aalib ncurses libmikmod - xorg.libXau xorg.libXdmcp xorg.libX11 + aalib + ncurses + libmikmod + xorg.libXau + xorg.libXdmcp + xorg.libX11 ]; # regparm attribute is not supported by clang @@ -28,11 +41,11 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - homepage = "http://aa-project.sourceforge.net/bb"; + homepage = "http://aa-project.sourceforge.net/bb"; description = "AA-lib demo"; - license = licenses.gpl2Plus; + license = licenses.gpl2Plus; maintainers = [ maintainers.rnhmjoj ]; - platforms = platforms.unix; + platforms = platforms.unix; mainProgram = "bb"; }; } diff --git a/pkgs/by-name/bb/bbe/package.nix b/pkgs/by-name/bb/bbe/package.nix index 519c272902b4ad..d300c7dea3698c 100644 --- a/pkgs/by-name/bb/bbe/package.nix +++ b/pkgs/by-name/bb/bbe/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv , fetchurl, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "bbe"; version = "0.2.2"; @@ -10,7 +15,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; meta = with lib; { description = "Sed-like editor for binary files"; diff --git a/pkgs/by-name/bb/bbin/package.nix b/pkgs/by-name/bb/bbin/package.nix index a5c165c77c7180..f4a69d09e79b9a 100644 --- a/pkgs/by-name/bb/bbin/package.nix +++ b/pkgs/by-name/bb/bbin/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gitUpdater -, makeWrapper -, babashka-unwrapped +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gitUpdater, + makeWrapper, + babashka-unwrapped, }: stdenvNoCC.mkDerivation rec { @@ -29,7 +30,12 @@ stdenvNoCC.mkDerivation rec { mkdir -p $out/share cp -r docs $out/share/docs wrapProgram $out/bin/bbin \ - --prefix PATH : "${lib.makeBinPath [ babashka-unwrapped babashka-unwrapped.graalvmDrv ]}" + --prefix PATH : "${ + lib.makeBinPath [ + babashka-unwrapped + babashka-unwrapped.graalvmDrv + ] + }" runHook postInstall ''; diff --git a/pkgs/by-name/bc/bc-decaf/package.nix b/pkgs/by-name/bc/bc-decaf/package.nix index 162eb8a4dd2518..ebd22cae8be4a8 100644 --- a/pkgs/by-name/bc/bc-decaf/package.nix +++ b/pkgs/by-name/bc/bc-decaf/package.nix @@ -1,8 +1,9 @@ -{ cmake -, fetchFromGitLab -, lib -, python3 -, stdenv +{ + cmake, + fetchFromGitLab, + lib, + python3, + stdenv, }: stdenv.mkDerivation rec { @@ -24,7 +25,10 @@ stdenv.mkDerivation rec { }; # Do not build static libraries and do not enable -Werror - cmakeFlags = [ "-DENABLE_STATIC=NO" "-DENABLE_STRICT=NO" ]; + cmakeFlags = [ + "-DENABLE_STATIC=NO" + "-DENABLE_STRICT=NO" + ]; meta = with lib; { description = "Elliptic curve library supporting Ed448-Goldilocks and Curve25519. Belledonne Communications' fork for Linphone"; diff --git a/pkgs/by-name/bc/bc-ur/package.nix b/pkgs/by-name/bc/bc-ur/package.nix index 2e7cda7764b580..62c7cf0d8a203a 100644 --- a/pkgs/by-name/bc/bc-ur/package.nix +++ b/pkgs/by-name/bc/bc-ur/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fetchpatch, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/bc/bcache-tools/package.nix b/pkgs/by-name/bc/bcache-tools/package.nix index 84ecc7ebd9f5fb..795e453e1b4e58 100644 --- a/pkgs/by-name/bc/bcache-tools/package.nix +++ b/pkgs/by-name/bc/bcache-tools/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, util-linux, bash, substituteAll }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + util-linux, + bash, + substituteAll, +}: stdenv.mkDerivation rec { pname = "bcache-tools"; diff --git a/pkgs/by-name/bc/bcal/package.nix b/pkgs/by-name/bc/bcal/package.nix index 6e87136170c641..20e29c252b8c01 100644 --- a/pkgs/by-name/bc/bcal/package.nix +++ b/pkgs/by-name/bc/bcal/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, readline -, bc -, python3Packages +{ + lib, + stdenv, + fetchFromGitHub, + readline, + bc, + python3Packages, }: stdenv.mkDerivation rec { @@ -23,7 +24,10 @@ stdenv.mkDerivation rec { doCheck = true; - nativeCheckInputs = [ bc python3Packages.pytestCheckHook ]; + nativeCheckInputs = [ + bc + python3Packages.pytestCheckHook + ]; pytestFlagsArray = [ "test.py" ]; diff --git a/pkgs/by-name/bc/bcc/package.nix b/pkgs/by-name/bc/bcc/package.nix index 90b68f71cf78c7..ce6b5919291fc9 100644 --- a/pkgs/by-name/bc/bcc/package.nix +++ b/pkgs/by-name/bc/bcc/package.nix @@ -1,21 +1,22 @@ -{ audit -, bash -, bison -, cmake -, elfutils -, fetchFromGitHub -, flex -, iperf -, lib -, libbpf -, llvmPackages -, luajit -, makeWrapper -, netperf -, nixosTests -, python3Packages -, stdenv -, zip +{ + audit, + bash, + bison, + cmake, + elfutils, + fetchFromGitHub, + flex, + iperf, + lib, + libbpf, + llvmPackages, + luajit, + makeWrapper, + netperf, + nixosTests, + python3Packages, + stdenv, + zip, }: python3Packages.buildPythonApplication rec { @@ -33,9 +34,16 @@ python3Packages.buildPythonApplication rec { format = "other"; buildInputs = with llvmPackages; [ - llvm llvm.dev libclang - elfutils luajit netperf iperf - flex bash libbpf + llvm + llvm.dev + libclang + elfutils + luajit + netperf + iperf + flex + bash + libbpf ]; patches = [ @@ -107,7 +115,10 @@ python3Packages.buildPythonApplication rec { wrapPythonProgramsIn "$out/share/bcc/tools" "$out $pythonPath" ''; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; passthru.tests = { bpf = nixosTests.bpf; @@ -115,9 +126,15 @@ python3Packages.buildPythonApplication rec { meta = with lib; { description = "Dynamic Tracing Tools for Linux"; - homepage = "https://iovisor.github.io/bcc/"; - license = licenses.asl20; - maintainers = with maintainers; [ ragge mic92 thoughtpolice martinetd ryan4yin ]; - platforms = platforms.linux; + homepage = "https://iovisor.github.io/bcc/"; + license = licenses.asl20; + maintainers = with maintainers; [ + ragge + mic92 + thoughtpolice + martinetd + ryan4yin + ]; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/bc/bcftools/package.nix b/pkgs/by-name/bc/bcftools/package.nix index 1e448353023857..a2300f28073da4 100644 --- a/pkgs/by-name/bc/bcftools/package.nix +++ b/pkgs/by-name/bc/bcftools/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, htslib, zlib, bzip2, xz, curl, perl, python3, bash }: +{ + lib, + stdenv, + fetchurl, + htslib, + zlib, + bzip2, + xz, + curl, + perl, + python3, + bash, +}: stdenv.mkDerivation rec { pname = "bcftools"; @@ -14,7 +26,13 @@ stdenv.mkDerivation rec { python3 ]; - buildInputs = [ htslib zlib bzip2 xz curl ]; + buildInputs = [ + htslib + zlib + bzip2 + xz + curl + ]; strictDeps = true; diff --git a/pkgs/by-name/bc/bcg729/package.nix b/pkgs/by-name/bc/bcg729/package.nix index ff5840b8373fce..25e47082a7aba9 100644 --- a/pkgs/by-name/bc/bcg729/package.nix +++ b/pkgs/by-name/bc/bcg729/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitLab -, cmake +{ + lib, + stdenv, + fetchFromGitLab, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/bc/bchoppr/package.nix b/pkgs/by-name/bc/bchoppr/package.nix index b841764f796181..73b8ec9616f60d 100644 --- a/pkgs/by-name/bc/bchoppr/package.nix +++ b/pkgs/by-name/bc/bchoppr/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, cairo, libX11, lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cairo, + libX11, + lv2, +}: stdenv.mkDerivation rec { pname = "bchoppr"; @@ -13,7 +21,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ cairo libX11 lv2 ]; + buildInputs = [ + cairo + libX11 + lv2 + ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/bc/bchunk/package.nix b/pkgs/by-name/bc/bchunk/package.nix index 17b46536b53f1b..02792a1b2355e9 100644 --- a/pkgs/by-name/bc/bchunk/package.nix +++ b/pkgs/by-name/bc/bchunk/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "bchunk"; @@ -9,7 +13,10 @@ stdenv.mkDerivation rec { sha256 = "12dxx98kbpc5z4dgni25280088bhlsb677rp832r82zzc1drpng7"; }; - makeFlags = lib.optionals stdenv.cc.isClang [ "CC=${stdenv.cc.targetPrefix}cc" "LD=${stdenv.cc.targetPrefix}cc" ]; + makeFlags = lib.optionals stdenv.cc.isClang [ + "CC=${stdenv.cc.targetPrefix}cc" + "LD=${stdenv.cc.targetPrefix}cc" + ]; installPhase = '' install -Dt $out/bin bchunk diff --git a/pkgs/by-name/bc/bctoolbox/package.nix b/pkgs/by-name/bc/bctoolbox/package.nix index 1da254093b1b35..8cf80c7a8c9439 100644 --- a/pkgs/by-name/bc/bctoolbox/package.nix +++ b/pkgs/by-name/bc/bctoolbox/package.nix @@ -1,10 +1,11 @@ -{ bcunit -, cmake -, bc-decaf -, fetchFromGitLab -, mbedtls_2 -, lib -, stdenv +{ + bcunit, + cmake, + bc-decaf, + fetchFromGitLab, + mbedtls_2, + lib, + stdenv, }: stdenv.mkDerivation rec { @@ -34,7 +35,10 @@ stdenv.mkDerivation rec { }; # Do not build static libraries - cmakeFlags = [ "-DENABLE_STATIC=NO" "-DENABLE_STRICT=NO" ]; + cmakeFlags = [ + "-DENABLE_STATIC=NO" + "-DENABLE_STRICT=NO" + ]; strictDeps = true; @@ -43,7 +47,10 @@ stdenv.mkDerivation rec { mainProgram = "bctoolbox_tester"; homepage = "https://gitlab.linphone.org/BC/public/bctoolbox"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ raskin jluttine ]; + maintainers = with maintainers; [ + raskin + jluttine + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/bc/bcunit/package.nix b/pkgs/by-name/bc/bcunit/package.nix index 14cf183f5878f5..ad3d75b11be831 100644 --- a/pkgs/by-name/bc/bcunit/package.nix +++ b/pkgs/by-name/bc/bcunit/package.nix @@ -1,6 +1,8 @@ -{ cmake -, fetchFromGitLab -, lib, stdenv +{ + cmake, + fetchFromGitLab, + lib, + stdenv, }: stdenv.mkDerivation rec { @@ -21,7 +23,10 @@ stdenv.mkDerivation rec { description = "Belledonne Communications' fork of CUnit test framework. Part of the Linphone project"; homepage = "https://gitlab.linphone.org/BC/public/bcunit"; license = licenses.lgpl2Plus; - maintainers = with maintainers; [ raskin jluttine ]; + maintainers = with maintainers; [ + raskin + jluttine + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/bd/bdf2psf/package.nix b/pkgs/by-name/bd/bdf2psf/package.nix index 6dc173231ad2f0..6ddc161c7c1431 100644 --- a/pkgs/by-name/bd/bdf2psf/package.nix +++ b/pkgs/by-name/bd/bdf2psf/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, perl, dpkg }: +{ + lib, + stdenv, + fetchurl, + perl, + dpkg, +}: stdenv.mkDerivation rec { pname = "bdf2psf"; @@ -29,7 +35,7 @@ stdenv.mkDerivation rec { Font converter to generate console fonts from BDF source fonts ''; license = licenses.gpl2Plus; - maintainers = with maintainers; [ rnhmjoj ]; + maintainers = with maintainers; [ rnhmjoj ]; platforms = platforms.all; mainProgram = "bdf2psf"; }; diff --git a/pkgs/by-name/bd/bdf2sfd/package.nix b/pkgs/by-name/bd/bdf2sfd/package.nix index da3375ac6d68be..72b576d8e978c6 100644 --- a/pkgs/by-name/bd/bdf2sfd/package.nix +++ b/pkgs/by-name/bd/bdf2sfd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "bdf2sfd"; diff --git a/pkgs/by-name/bd/bdf2ttf/package.nix b/pkgs/by-name/bd/bdf2ttf/package.nix index 399c07ee0b654c..e34ec685680805 100644 --- a/pkgs/by-name/bd/bdf2ttf/package.nix +++ b/pkgs/by-name/bd/bdf2ttf/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "bdf2ttf"; diff --git a/pkgs/by-name/bd/bdfresize/package.nix b/pkgs/by-name/bd/bdfresize/package.nix index 5d77a962296f03..e6ac782a44ff54 100644 --- a/pkgs/by-name/bd/bdfresize/package.nix +++ b/pkgs/by-name/bd/bdfresize/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "bdfresize"; diff --git a/pkgs/by-name/bd/bdsync/package.nix b/pkgs/by-name/bd/bdsync/package.nix index 55aff33b03d982..47800507b52953 100644 --- a/pkgs/by-name/bd/bdsync/package.nix +++ b/pkgs/by-name/bd/bdsync/package.nix @@ -1,7 +1,10 @@ -{ lib, stdenv, fetchFromGitHub -, openssl -, pandoc -, which +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + pandoc, + which, }: stdenv.mkDerivation rec { @@ -15,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-58yoF6s0WjH+1mTY7X5OX53YgcnDmGxoCR8Kvl6lP+A="; }; - nativeBuildInputs = [ pandoc which ]; + nativeBuildInputs = [ + pandoc + which + ]; buildInputs = [ openssl ]; postPatch = '' diff --git a/pkgs/by-name/bd/bdt/package.nix b/pkgs/by-name/bd/bdt/package.nix index 997b15cee39fb0..23f6b9fd5e4128 100644 --- a/pkgs/by-name/bd/bdt/package.nix +++ b/pkgs/by-name/bd/bdt/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { pname = "bdt"; diff --git a/pkgs/by-name/be/beancount-language-server/package.nix b/pkgs/by-name/be/beancount-language-server/package.nix index ed65cd8ee86e1e..6645f183092af9 100644 --- a/pkgs/by-name/be/beancount-language-server/package.nix +++ b/pkgs/by-name/be/beancount-language-server/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/be/beanstalkd/package.nix b/pkgs/by-name/be/beanstalkd/package.nix index 42a0f01d01688d..f7cce03717edbd 100644 --- a/pkgs/by-name/be/beanstalkd/package.nix +++ b/pkgs/by-name/be/beanstalkd/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, installShellFiles, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + nixosTests, +}: stdenv.mkDerivation rec { version = "1.13"; diff --git a/pkgs/by-name/be/bearssl/package.nix b/pkgs/by-name/be/bearssl/package.nix index 7301f8c889ce9d..4dc9a2c488a57b 100644 --- a/pkgs/by-name/be/bearssl/package.nix +++ b/pkgs/by-name/be/bearssl/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "bearssl"; @@ -9,7 +13,12 @@ stdenv.mkDerivation rec { sha256 = "057zhgy9w4y8z2996r0pq5k2k39lpvmmvz4df8db8qa9f6hvn1b7"; }; - outputs = [ "bin" "lib" "dev" "out" ]; + outputs = [ + "bin" + "lib" + "dev" + "out" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/be/beats/package.nix b/pkgs/by-name/be/beats/package.nix index a8ad2436f08cee..2c21e45952ab7b 100644 --- a/pkgs/by-name/be/beats/package.nix +++ b/pkgs/by-name/be/beats/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "beats"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1rdvsqrjpily74y8vwch711401585xckb4p41cfwrmj6vf44jhif"; }; - makeFlags = [ "PREFIX=$(out)" "CC=cc" ]; + makeFlags = [ + "PREFIX=$(out)" + "CC=cc" + ]; meta = with lib; { homepage = "https://github.com/j0hax/beats"; diff --git a/pkgs/by-name/be/bedops/package.nix b/pkgs/by-name/be/bedops/package.nix index d455e98264cc13..70e8a99a7d7a26 100644 --- a/pkgs/by-name/be/bedops/package.nix +++ b/pkgs/by-name/be/bedops/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, zlib, bzip2, jansson, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + bzip2, + jansson, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "bedops"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-VJBoi1+tHA4oOVOsClUfimB+mOV5ZSQsDcDq3vAZwBA="; }; - buildInputs = [ zlib bzip2 jansson ]; + buildInputs = [ + zlib + bzip2 + jansson + ]; nativeBuildInputs = [ makeWrapper ]; preConfigure = '' diff --git a/pkgs/by-name/be/bedtools/package.nix b/pkgs/by-name/be/bedtools/package.nix index 19df156ae17ccf..67ba0d019e477a 100644 --- a/pkgs/by-name/be/bedtools/package.nix +++ b/pkgs/by-name/be/bedtools/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchFromGitHub, zlib, python3, bzip2, xz}: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + python3, + bzip2, + xz, +}: stdenv.mkDerivation rec { pname = "bedtools"; @@ -17,7 +25,11 @@ stdenv.mkDerivation rec { python3 ]; - buildInputs = [ zlib bzip2 xz ]; + buildInputs = [ + zlib + bzip2 + xz + ]; cxx = if stdenv.cc.isClang then "clang++" else "g++"; cc = if stdenv.cc.isClang then "clang" else "gcc"; diff --git a/pkgs/by-name/be/beecrypt/package.nix b/pkgs/by-name/be/beecrypt/package.nix index f6c61254c10103..f38ead8ebbf04b 100644 --- a/pkgs/by-name/be/beecrypt/package.nix +++ b/pkgs/by-name/be/beecrypt/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, m4}: +{ + lib, + stdenv, + fetchurl, + m4, +}: stdenv.mkDerivation rec { pname = "beecrypt"; @@ -9,7 +14,10 @@ stdenv.mkDerivation rec { sha256 = "0pf5k1c4nsj77jfq5ip0ra1gzx2q47xaa0s008fnn6hd11b1yvr8"; }; buildInputs = [ m4 ]; - configureFlags = [ "--disable-optimized" "--enable-static" ]; + configureFlags = [ + "--disable-optimized" + "--enable-static" + ]; meta = { platforms = lib.platforms.linux; diff --git a/pkgs/by-name/be/beefi/package.nix b/pkgs/by-name/be/beefi/package.nix index 57ab2d7c8574cb..1c8c084711a099 100644 --- a/pkgs/by-name/be/beefi/package.nix +++ b/pkgs/by-name/be/beefi/package.nix @@ -1,9 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, installShellFiles -, binutils-unwrapped -, systemd }: +{ + stdenv, + lib, + fetchFromGitHub, + installShellFiles, + binutils-unwrapped, + systemd, +}: stdenv.mkDerivation rec { pname = "beefi"; diff --git a/pkgs/by-name/be/beekeeper-studio/package.nix b/pkgs/by-name/be/beekeeper-studio/package.nix index 5b633f12bcd40e..06fab85f22fb98 100644 --- a/pkgs/by-name/be/beekeeper-studio/package.nix +++ b/pkgs/by-name/be/beekeeper-studio/package.nix @@ -1,23 +1,28 @@ -{ appimageTools -, fetchurl -, lib -, makeWrapper -, stdenv +{ + appimageTools, + fetchurl, + lib, + makeWrapper, + stdenv, }: let pname = "beekeeper-studio"; version = "4.6.8"; - plat = { - aarch64-linux = "-arm64"; - x86_64-linux = ""; - }.${stdenv.hostPlatform.system}; + plat = + { + aarch64-linux = "-arm64"; + x86_64-linux = ""; + } + .${stdenv.hostPlatform.system}; - hash = { - aarch64-linux = "sha256-EKGL+aeuCcBuSh+VtkdgFhI1LccuvO8WHoqbZ/JdX7c="; - x86_64-linux = "sha256-LyO9xCqZG5gNAvCIX9wacSb59wiLjXPDta+Fipu24fk="; - }.${stdenv.hostPlatform.system}; + hash = + { + aarch64-linux = "sha256-EKGL+aeuCcBuSh+VtkdgFhI1LccuvO8WHoqbZ/JdX7c="; + x86_64-linux = "sha256-LyO9xCqZG5gNAvCIX9wacSb59wiLjXPDta+Fipu24fk="; + } + .${stdenv.hostPlatform.system}; src = fetchurl { url = "https://github.com/beekeeper-studio/beekeeper-studio/releases/download/v${version}/Beekeeper-Studio-${version}${plat}.AppImage"; @@ -47,7 +52,13 @@ appimageTools.wrapType2 { license = lib.licenses.gpl3Only; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; mainProgram = "beekeeper-studio"; - maintainers = with lib.maintainers; [ milogert alexnortung ]; - platforms = [ "aarch64-linux" "x86_64-linux" ]; + maintainers = with lib.maintainers; [ + milogert + alexnortung + ]; + platforms = [ + "aarch64-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/be/beep/package.nix b/pkgs/by-name/be/beep/package.nix index a11b4ca38ad4d5..b1a37e5f985100 100644 --- a/pkgs/by-name/be/beep/package.nix +++ b/pkgs/by-name/be/beep/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: # this package is working only as root # in order to work as a non privileged user you would need to suid the bin @@ -14,7 +18,7 @@ stdenv.mkDerivation rec { sha256 = "sha256-gDgGI9F+wW2cN89IwP93PkMv6vixJA2JckF78nxZ+TU="; }; - makeFlags = [ "prefix=${placeholder "out"}"]; + makeFlags = [ "prefix=${placeholder "out"}" ]; # causes redefinition of _FORTIFY_SOURCE hardeningDisable = [ "fortify3" ]; diff --git a/pkgs/by-name/be/beeper-bridge-manager/package.nix b/pkgs/by-name/be/beeper-bridge-manager/package.nix index 3beaa9cfc512df..a45069a9a8980a 100644 --- a/pkgs/by-name/be/beeper-bridge-manager/package.nix +++ b/pkgs/by-name/be/beeper-bridge-manager/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/be/beeper/package.nix b/pkgs/by-name/be/beeper/package.nix index 407a20b8433e24..e25728089d55f0 100644 --- a/pkgs/by-name/be/beeper/package.nix +++ b/pkgs/by-name/be/beeper/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenvNoCC -, fetchurl -, appimageTools -, makeWrapper -, writeShellApplication -, curl -, yq -, common-updater-scripts +{ + lib, + stdenvNoCC, + fetchurl, + appimageTools, + makeWrapper, + writeShellApplication, + curl, + yq, + common-updater-scripts, }: let pname = "beeper"; @@ -53,7 +54,11 @@ stdenvNoCC.mkDerivation rec { passthru = { updateScript = lib.getExe (writeShellApplication { name = "update-beeper"; - runtimeInputs = [ curl yq common-updater-scripts ]; + runtimeInputs = [ + curl + yq + common-updater-scripts + ]; text = '' set -o errexit latestLinux="$(curl -s https://download.todesktop.com/2003241lzgn20jd/latest-linux.yml)" @@ -72,7 +77,11 @@ stdenvNoCC.mkDerivation rec { ''; homepage = "https://beeper.com"; license = licenses.unfree; - maintainers = with maintainers; [ jshcmpbll mjm edmundmiller ]; + maintainers = with maintainers; [ + jshcmpbll + mjm + edmundmiller + ]; platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/by-name/be/bees/package.nix b/pkgs/by-name/be/bees/package.nix index a014f449079c41..8bff2ce41d704f 100644 --- a/pkgs/by-name/be/bees/package.nix +++ b/pkgs/by-name/be/bees/package.nix @@ -1,16 +1,17 @@ -{ lib -, fetchFromGitHub -, makeWrapper -, nixosTests +{ + lib, + fetchFromGitHub, + makeWrapper, + nixosTests, -, stdenv -# Build inputs -, btrfs-progs -, util-linux -, python3Packages -# bees-service-wrapper -, bash -, coreutils + stdenv, + # Build inputs + btrfs-progs, + util-linux, + python3Packages, + # bees-service-wrapper + bash, + coreutils, }: stdenv.mkDerivation rec { @@ -45,7 +46,14 @@ stdenv.mkDerivation rec { postInstall = '' makeWrapper ${./bees-service-wrapper} "$out"/bin/bees-service-wrapper \ - --prefix PATH : ${lib.makeBinPath [ bash coreutils util-linux btrfs-progs ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + bash + coreutils + util-linux + btrfs-progs + ] + } \ --set beesd_bin "$out"/lib/bees/bees ''; diff --git a/pkgs/by-name/be/behdad-fonts/package.nix b/pkgs/by-name/be/behdad-fonts/package.nix index f7305e9de9872e..d61be96642314b 100644 --- a/pkgs/by-name/be/behdad-fonts/package.nix +++ b/pkgs/by-name/be/behdad-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "behdad-fonts"; diff --git a/pkgs/by-name/be/belcard/package.nix b/pkgs/by-name/be/belcard/package.nix index cb16a3fe0fd866..37a168b13661a2 100644 --- a/pkgs/by-name/be/belcard/package.nix +++ b/pkgs/by-name/be/belcard/package.nix @@ -1,9 +1,10 @@ -{ bctoolbox -, belr -, cmake -, fetchFromGitLab -, lib -, stdenv +{ + bctoolbox, + belr, + cmake, + fetchFromGitLab, + lib, + stdenv, }: stdenv.mkDerivation rec { @@ -19,7 +20,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-pRNJ1bDS2v0Cn+6cxMeFa0JQ27UZR6kCI9P6gQ5W2GA="; }; - buildInputs = [ bctoolbox belr ]; + buildInputs = [ + bctoolbox + belr + ]; nativeBuildInputs = [ cmake ]; cmakeFlags = [ diff --git a/pkgs/by-name/be/belle-sip/package.nix b/pkgs/by-name/be/belle-sip/package.nix index efc62bc9a5a1fd..dd9d46102dbfab 100644 --- a/pkgs/by-name/be/belle-sip/package.nix +++ b/pkgs/by-name/be/belle-sip/package.nix @@ -1,12 +1,13 @@ -{ bctoolbox -, belr -, cmake -, fetchFromGitLab -, lib -, libantlr3c -, mbedtls_2 -, stdenv -, zlib +{ + bctoolbox, + belr, + cmake, + fetchFromGitLab, + lib, + libantlr3c, + mbedtls_2, + stdenv, + zlib, }: stdenv.mkDerivation rec { @@ -29,17 +30,25 @@ stdenv.mkDerivation rec { # Do not build static libraries cmakeFlags = [ "-DENABLE_STATIC=NO" ]; - env.NIX_CFLAGS_COMPILE = toString ([ - "-Wno-error=cast-function-type" - "-Wno-error=deprecated-declarations" - "-Wno-error=format-truncation" - "-Wno-error=stringop-overflow" - ] ++ lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ - # Needed with GCC 12 but problematic with some old GCCs and probably clang - "-Wno-error=use-after-free" - ]); - - propagatedBuildInputs = [ libantlr3c mbedtls_2 bctoolbox belr ]; + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-Wno-error=cast-function-type" + "-Wno-error=deprecated-declarations" + "-Wno-error=format-truncation" + "-Wno-error=stringop-overflow" + ] + ++ lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ + # Needed with GCC 12 but problematic with some old GCCs and probably clang + "-Wno-error=use-after-free" + ] + ); + + propagatedBuildInputs = [ + libantlr3c + mbedtls_2 + bctoolbox + belr + ]; meta = with lib; { homepage = "https://linphone.org/technical-corner/belle-sip"; diff --git a/pkgs/by-name/be/below/package.nix b/pkgs/by-name/be/below/package.nix index dc7754a7793ebb..4ae575272be08a 100644 --- a/pkgs/by-name/be/below/package.nix +++ b/pkgs/by-name/be/below/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, clang -, pkg-config -, elfutils -, rustfmt -, zlib +{ + lib, + fetchFromGitHub, + rustPlatform, + clang, + pkg-config, + elfutils, + rustfmt, + zlib, }: rustPlatform.buildRustPackage rec { @@ -28,10 +29,20 @@ rustPlatform.buildRustPackage rec { ''; # bpf code compilation - hardeningDisable = [ "stackprotector" "zerocallusedregs" ]; - - nativeBuildInputs = [ clang pkg-config rustfmt ]; - buildInputs = [ elfutils zlib ]; + hardeningDisable = [ + "stackprotector" + "zerocallusedregs" + ]; + + nativeBuildInputs = [ + clang + pkg-config + rustfmt + ]; + buildInputs = [ + elfutils + zlib + ]; # needs /sys/fs/cgroup doCheck = false; diff --git a/pkgs/by-name/be/belr/package.nix b/pkgs/by-name/be/belr/package.nix index 95517eabed26c9..11fa75878341f4 100644 --- a/pkgs/by-name/be/belr/package.nix +++ b/pkgs/by-name/be/belr/package.nix @@ -1,8 +1,9 @@ -{ bctoolbox -, cmake -, fetchFromGitLab -, lib -, stdenv +{ + bctoolbox, + cmake, + fetchFromGitLab, + lib, + stdenv, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/be/beluga/package.nix b/pkgs/by-name/be/beluga/package.nix index d85f375f9f89d5..6c97064a52cb3c 100644 --- a/pkgs/by-name/be/beluga/package.nix +++ b/pkgs/by-name/be/beluga/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, ocamlPackages }: +{ + lib, + fetchFromGitHub, + ocamlPackages, +}: ocamlPackages.buildDunePackage rec { pname = "beluga"; diff --git a/pkgs/by-name/be/bemenu/package.nix b/pkgs/by-name/be/bemenu/package.nix index 7c4cd0f935424d..ace85ff9ec1b55 100644 --- a/pkgs/by-name/be/bemenu/package.nix +++ b/pkgs/by-name/be/bemenu/package.nix @@ -1,8 +1,22 @@ -{ stdenv, lib, fetchFromGitHub, cairo, libxkbcommon -, pango, fribidi, harfbuzz, pkg-config, scdoc -, ncursesSupport ? true, ncurses -, waylandSupport ? true, wayland, wayland-protocols, wayland-scanner -, x11Support ? true, xorg +{ + stdenv, + lib, + fetchFromGitHub, + cairo, + libxkbcommon, + pango, + fribidi, + harfbuzz, + pkg-config, + scdoc, + ncursesSupport ? true, + ncurses, + waylandSupport ? true, + wayland, + wayland-protocols, + wayland-scanner, + x11Support ? true, + xorg, }: stdenv.mkDerivation (finalAttrs: { @@ -17,25 +31,37 @@ stdenv.mkDerivation (finalAttrs: { }; strictDeps = true; - nativeBuildInputs = [ pkg-config scdoc ] - ++ lib.optionals waylandSupport [ wayland-scanner ]; + nativeBuildInputs = [ + pkg-config + scdoc + ] ++ lib.optionals waylandSupport [ wayland-scanner ]; - buildInputs = [ - cairo - fribidi - harfbuzz - libxkbcommon - pango - ] ++ lib.optional ncursesSupport ncurses - ++ lib.optionals waylandSupport [ wayland wayland-protocols ] + buildInputs = + [ + cairo + fribidi + harfbuzz + libxkbcommon + pango + ] + ++ lib.optional ncursesSupport ncurses + ++ lib.optionals waylandSupport [ + wayland + wayland-protocols + ] ++ lib.optionals x11Support [ - xorg.libX11 xorg.libXinerama xorg.libXft - xorg.libXdmcp xorg.libpthreadstubs xorg.libxcb + xorg.libX11 + xorg.libXinerama + xorg.libXft + xorg.libXdmcp + xorg.libpthreadstubs + xorg.libxcb ]; - makeFlags = ["PREFIX=$(out)"]; + makeFlags = [ "PREFIX=$(out)" ]; - buildFlags = ["clients"] + buildFlags = + [ "clients" ] ++ lib.optional ncursesSupport "curses" ++ lib.optional waylandSupport "wayland" ++ lib.optional x11Support "x11"; diff --git a/pkgs/by-name/be/bemoji/package.nix b/pkgs/by-name/be/bemoji/package.nix index 37e2155ca1d3b3..976ee9bd3344df 100644 --- a/pkgs/by-name/be/bemoji/package.nix +++ b/pkgs/by-name/be/bemoji/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/be/benchexec/package.nix b/pkgs/by-name/be/benchexec/package.nix index 213aeee6d919d5..be860eaad4d0f8 100644 --- a/pkgs/by-name/be/benchexec/package.nix +++ b/pkgs/by-name/be/benchexec/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, python3 -, libseccomp -, nixosTests -, testers -, benchexec +{ + lib, + fetchFromGitHub, + python3, + libseccomp, + nixosTests, + testers, + benchexec, }: python3.pkgs.buildPythonApplication rec { pname = "benchexec"; @@ -39,10 +40,12 @@ python3.pkgs.buildPythonApplication rec { passthru.tests = let - testVersion = result: testers.testVersion { - command = "${result} --version"; - package = benchexec; - }; + testVersion = + result: + testers.testVersion { + command = "${result} --version"; + package = benchexec; + }; in { nixos = nixosTests.benchexec; diff --git a/pkgs/by-name/be/bencode/package.nix b/pkgs/by-name/be/bencode/package.nix index 1dc68be26052aa..b3df112d910185 100644 --- a/pkgs/by-name/be/bencode/package.nix +++ b/pkgs/by-name/be/bencode/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, catch2 -, cmake -, expected-lite -, fmt -, gsl-lite -, ninja +{ + lib, + stdenv, + fetchFromGitHub, + catch2, + cmake, + expected-lite, + fmt, + gsl-lite, + ninja, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/be/bento4/package.nix b/pkgs/by-name/be/bento4/package.nix index 5059cfa0c83823..2b7dc79faf2d9d 100644 --- a/pkgs/by-name/be/bento4/package.nix +++ b/pkgs/by-name/be/bento4/package.nix @@ -1,5 +1,8 @@ -{ lib, stdenv, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { pname = "bento4"; @@ -18,11 +21,13 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - cmakeFlags = [ - "-DBUILD_SHARED_LIBS=ON" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DCMAKE_OSX_ARCHITECTURES=" - ]; + cmakeFlags = + [ + "-DBUILD_SHARED_LIBS=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DCMAKE_OSX_ARCHITECTURES=" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/be/bepass/package.nix b/pkgs/by-name/be/bepass/package.nix index fb9de741a90d76..02d8b58a220835 100644 --- a/pkgs/by-name/be/bepass/package.nix +++ b/pkgs/by-name/be/bepass/package.nix @@ -1,18 +1,19 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, enableGUI ? false # upstream working in progress -, pkg-config -, glfw -, xorg -, libXcursor -, libXrandr -, libXinerama -, xinput -, libXi -, libXxf86vm +{ + lib, + buildGoModule, + fetchFromGitHub, + enableGUI ? false, # upstream working in progress + pkg-config, + glfw, + xorg, + libXcursor, + libXrandr, + libXinerama, + xinput, + libXi, + libXxf86vm, }: -buildGoModule rec{ +buildGoModule rec { pname = "bepass"; version = "1.6.2"; diff --git a/pkgs/by-name/be/bepasty/package.nix b/pkgs/by-name/be/bepasty/package.nix index 8e67cbab611115..51309a35da9bd0 100644 --- a/pkgs/by-name/be/bepasty/package.nix +++ b/pkgs/by-name/be/bepasty/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: let @@ -9,7 +10,7 @@ let bepastyPython = python3.override { self = bepastyPython; packageOverrides = self: super: { - xstatic-font-awesome = super.xstatic-font-awesome.overridePythonAttrs(oldAttrs: rec { + xstatic-font-awesome = super.xstatic-font-awesome.overridePythonAttrs (oldAttrs: rec { version = "4.7.0.0"; src = oldAttrs.src.override { inherit version; @@ -76,6 +77,9 @@ bepastyPython.pkgs.buildPythonPackage rec { homepage = "https://github.com/bepasty/bepasty-server"; description = "Binary pastebin server"; license = licenses.bsd2; - maintainers = with maintainers; [ aither64 makefu ]; + maintainers = with maintainers; [ + aither64 + makefu + ]; }; } diff --git a/pkgs/by-name/be/berglas/package.nix b/pkgs/by-name/be/berglas/package.nix index b541c7fb7f17f2..f44b06b8631e58 100644 --- a/pkgs/by-name/be/berglas/package.nix +++ b/pkgs/by-name/be/berglas/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, berglas }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + berglas, +}: let skipTests = { @@ -13,16 +19,18 @@ let update = "Update"; }; - skipTestsCommand = - builtins.foldl' (acc: goFileName: - let testName = builtins.getAttr goFileName skipTests; in - '' - ${acc} - substituteInPlace pkg/berglas/${goFileName}_test.go \ - --replace "TestClient_${testName}_storage" "SkipClient_${testName}_storage" \ - --replace "TestClient_${testName}_secretManager" "SkipClient_${testName}_secretManager" - '' - ) "" (builtins.attrNames skipTests); + skipTestsCommand = builtins.foldl' ( + acc: goFileName: + let + testName = builtins.getAttr goFileName skipTests; + in + '' + ${acc} + substituteInPlace pkg/berglas/${goFileName}_test.go \ + --replace "TestClient_${testName}_storage" "SkipClient_${testName}_storage" \ + --replace "TestClient_${testName}_secretManager" "SkipClient_${testName}_secretManager" + '' + ) "" (builtins.attrNames skipTests); in buildGoModule rec { diff --git a/pkgs/by-name/be/besu/package.nix b/pkgs/by-name/be/besu/package.nix index 4c61c75a4f07c8..208377db95a8fa 100644 --- a/pkgs/by-name/be/besu/package.nix +++ b/pkgs/by-name/be/besu/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, makeWrapper, jemalloc, jre, runCommand, testers }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jemalloc, + jre, + runCommand, + testers, +}: stdenv.mkDerivation (finalAttrs: rec { pname = "besu"; @@ -19,7 +28,9 @@ stdenv.mkDerivation (finalAttrs: rec { cp -r lib $out/ wrapProgram $out/bin/${pname} \ --set JAVA_HOME "${jre}" \ - --suffix ${if stdenv.hostPlatform.isDarwin then "DYLD_LIBRARY_PATH" else "LD_LIBRARY_PATH"} : ${lib.makeLibraryPath buildInputs} + --suffix ${ + if stdenv.hostPlatform.isDarwin then "DYLD_LIBRARY_PATH" else "LD_LIBRARY_PATH" + } : ${lib.makeLibraryPath buildInputs} ''; passthru.tests = { @@ -27,15 +38,17 @@ stdenv.mkDerivation (finalAttrs: rec { package = finalAttrs.finalPackage; version = "v${version}"; }; - jemalloc = runCommand "${pname}-test-jemalloc" - { - nativeBuildInputs = [ finalAttrs.finalPackage ]; - meta.platforms = with lib.platforms; linux; - } '' - # Expect to find this string in the output, ignore other failures. - (besu 2>&1 || true) | grep -q "# jemalloc: ${jemalloc.version}" - mkdir $out - ''; + jemalloc = + runCommand "${pname}-test-jemalloc" + { + nativeBuildInputs = [ finalAttrs.finalPackage ]; + meta.platforms = with lib.platforms; linux; + } + '' + # Expect to find this string in the output, ignore other failures. + (besu 2>&1 || true) | grep -q "# jemalloc: ${jemalloc.version}" + mkdir $out + ''; }; meta = with lib; { diff --git a/pkgs/by-name/be/bettercap/package.nix b/pkgs/by-name/be/bettercap/package.nix index ebd49d4a12cb0c..84d732016e6838 100644 --- a/pkgs/by-name/be/bettercap/package.nix +++ b/pkgs/by-name/be/bettercap/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, buildGo122Module -, fetchFromGitHub -, pkg-config -, libpcap -, libnfnetlink -, libnetfilter_queue -, libusb1 +{ + lib, + stdenv, + buildGo122Module, + fetchFromGitHub, + pkg-config, + libpcap, + libnfnetlink, + libnetfilter_queue, + libusb1, }: buildGo122Module rec { @@ -24,8 +26,15 @@ buildGo122Module rec { doCheck = false; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libpcap libusb1 ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libnfnetlink libnetfilter_queue ]; + buildInputs = + [ + libpcap + libusb1 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libnfnetlink + libnetfilter_queue + ]; meta = with lib; { description = "Man in the middle tool"; diff --git a/pkgs/by-name/be/betterdiscord-installer/package.nix b/pkgs/by-name/be/betterdiscord-installer/package.nix index 0b317077594054..35e66add048afb 100644 --- a/pkgs/by-name/be/betterdiscord-installer/package.nix +++ b/pkgs/by-name/be/betterdiscord-installer/package.nix @@ -1,4 +1,8 @@ -{ appimageTools, lib, fetchurl }: +{ + appimageTools, + lib, + fetchurl, +}: let pname = "betterdiscord-installer"; version = "1.0.0-beta"; @@ -9,7 +13,8 @@ let }; appimageContents = appimageTools.extract { inherit pname version src; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; extraInstallCommands = '' diff --git a/pkgs/by-name/be/betterlockscreen/package.nix b/pkgs/by-name/be/betterlockscreen/package.nix index d9dde026f98c69..ba1fce2551e0e2 100644 --- a/pkgs/by-name/be/betterlockscreen/package.nix +++ b/pkgs/by-name/be/betterlockscreen/package.nix @@ -1,27 +1,39 @@ -{ fetchFromGitHub -, lib -, makeWrapper -, stdenv +{ + fetchFromGitHub, + lib, + makeWrapper, + stdenv, # Dependencies (@see https://github.com/pavanjadhaw/betterlockscreen/blob/master/shell.nix) -, bc -, coreutils -, dbus -, withDunst ? true -, dunst -, i3lock-color -, gawk -, gnugrep -, gnused -, imagemagick -, procps -, xorg + bc, + coreutils, + dbus, + withDunst ? true, + dunst, + i3lock-color, + gawk, + gnugrep, + gnused, + imagemagick, + procps, + xorg, }: let - runtimeDeps = - [ bc coreutils dbus i3lock-color gawk gnugrep gnused imagemagick procps xorg.xdpyinfo xorg.xrandr xorg.xset ] - ++ lib.optionals withDunst [ dunst ]; + runtimeDeps = [ + bc + coreutils + dbus + i3lock-color + gawk + gnugrep + gnused + imagemagick + procps + xorg.xdpyinfo + xorg.xrandr + xorg.xset + ] ++ lib.optionals withDunst [ dunst ]; in stdenv.mkDerivation rec { @@ -54,6 +66,9 @@ stdenv.mkDerivation rec { mainProgram = "betterlockscreen"; license = licenses.mit; platforms = platforms.linux; - maintainers = with maintainers; [ eyjhb sebtm ]; + maintainers = with maintainers; [ + eyjhb + sebtm + ]; }; } diff --git a/pkgs/by-name/be/beyond-identity/package.nix b/pkgs/by-name/be/beyond-identity/package.nix index 229d61be1d8aa9..b4d99eac4dbe9a 100644 --- a/pkgs/by-name/be/beyond-identity/package.nix +++ b/pkgs/by-name/be/beyond-identity/package.nix @@ -1,19 +1,42 @@ -{ lib, stdenv, fetchurl, dpkg, buildFHSEnv -, glibc, glib, openssl, tpm2-tss -, gtk3, gnome-keyring, polkit, polkit_gnome +{ + lib, + stdenv, + fetchurl, + dpkg, + buildFHSEnv, + glibc, + glib, + openssl, + tpm2-tss, + gtk3, + gnome-keyring, + polkit, + polkit_gnome, }: let pname = "beyond-identity"; version = "2.97.0-0"; - libPath = lib.makeLibraryPath ([ glib glibc openssl tpm2-tss gtk3 gnome-keyring polkit polkit_gnome ]); + libPath = lib.makeLibraryPath ([ + glib + glibc + openssl + tpm2-tss + gtk3 + gnome-keyring + polkit + polkit_gnome + ]); meta = with lib; { description = "Passwordless MFA identities for workforces, customers, and developers"; homepage = "https://www.beyondidentity.com"; downloadPage = "https://app.byndid.com/downloads"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - maintainers = with maintainers; [ klden hornwall ]; + maintainers = with maintainers; [ + klden + hornwall + ]; platforms = [ "x86_64-linux" ]; }; @@ -66,21 +89,26 @@ let $out/bin/byndid ''; }; +in # /usr/bin/pkcheck is hardcoded in binary - we need FHS -in buildFHSEnv { - inherit pname version meta; +buildFHSEnv { + inherit pname version meta; - targetPkgs = pkgs: [ - beyond-identity - glib glibc openssl tpm2-tss - gtk3 gnome-keyring - polkit polkit_gnome - ]; + targetPkgs = pkgs: [ + beyond-identity + glib + glibc + openssl + tpm2-tss + gtk3 + gnome-keyring + polkit + polkit_gnome + ]; - extraInstallCommands = '' - ln -s ${beyond-identity}/share $out - ''; + extraInstallCommands = '' + ln -s ${beyond-identity}/share $out + ''; - runScript = "beyond-identity"; + runScript = "beyond-identity"; } - diff --git a/pkgs/by-name/bf/bfc/package.nix b/pkgs/by-name/bf/bfc/package.nix index 660f130225c856..c22bb6526620ca 100644 --- a/pkgs/by-name/bf/bfc/package.nix +++ b/pkgs/by-name/bf/bfc/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, llvmPackages_13 -, libxml2 -, ncurses -, zlib -, stdenv +{ + lib, + rustPlatform, + fetchFromGitHub, + llvmPackages_13, + libxml2, + ncurses, + zlib, + stdenv, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/bf/bfetch/package.nix b/pkgs/by-name/bf/bfetch/package.nix index 687b3c1280167d..07e559e4156ae4 100644 --- a/pkgs/by-name/bf/bfetch/package.nix +++ b/pkgs/by-name/bf/bfetch/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchFromGitHub, bash }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + bash, +}: stdenvNoCC.mkDerivation rec { pname = "bfetch"; diff --git a/pkgs/by-name/bf/bfr/package.nix b/pkgs/by-name/bf/bfr/package.nix index 6d67d4d2067723..fe44dcbef0bb50 100644 --- a/pkgs/by-name/bf/bfr/package.nix +++ b/pkgs/by-name/bf/bfr/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "bfr"; @@ -9,12 +14,12 @@ stdenv.mkDerivation rec { sha256 = "0fadfssvj9klj4dq9wdrzys1k2a1z2j0p6kgnfgbjv0n1bq6h4cy"; }; - patches = - [ (fetchurl { - url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/app-misc/bfr/files/bfr-1.6-perl.patch"; - sha256 = "1pk9jm3c1qzs727lh0bw61w3qbykaqg4jblywf9pvq5bypk88qfj"; - }) - ]; + patches = [ + (fetchurl { + url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/app-misc/bfr/files/bfr-1.6-perl.patch"; + sha256 = "1pk9jm3c1qzs727lh0bw61w3qbykaqg4jblywf9pvq5bypk88qfj"; + }) + ]; buildInputs = [ perl ]; diff --git a/pkgs/by-name/bf/bfs/package.nix b/pkgs/by-name/bf/bfs/package.nix index 569e64aa467dc2..285b047eaf9b6f 100644 --- a/pkgs/by-name/bf/bfs/package.nix +++ b/pkgs/by-name/bf/bfs/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, attr, acl, libcap, liburing, oniguruma }: +{ + lib, + stdenv, + fetchFromGitHub, + attr, + acl, + libcap, + liburing, + oniguruma, +}: stdenv.mkDerivation rec { pname = "bfs"; @@ -11,8 +20,14 @@ stdenv.mkDerivation rec { hash = "sha256-KcXbLYITTxNq2r8Bqf4FRy7cOZw1My9Ii6O/FDLhCGY="; }; - buildInputs = [ oniguruma ] ++ - lib.optionals stdenv.hostPlatform.isLinux [ acl attr libcap liburing ]; + buildInputs = + [ oniguruma ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + acl + attr + libcap + liburing + ]; configureFlags = [ "--enable-release" ]; makeFlags = [ "PREFIX=$(out)" ]; @@ -26,7 +41,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/tavianator/bfs"; license = licenses.bsd0; platforms = platforms.unix; - maintainers = with maintainers; [ yesbox cafkafk ]; + maintainers = with maintainers; [ + yesbox + cafkafk + ]; mainProgram = "bfs"; }; } diff --git a/pkgs/by-name/bf/bfscripts/package.nix b/pkgs/by-name/bf/bfscripts/package.nix index 537cab8697a399..322183078c2ad2 100644 --- a/pkgs/by-name/bf/bfscripts/package.nix +++ b/pkgs/by-name/bf/bfscripts/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, fetchFromGitHub -, lib -, python3 +{ + stdenv, + fetchFromGitHub, + lib, + python3, }: let @@ -52,12 +53,11 @@ stdenv.mkDerivation rec { ${lib.concatStringsSep "\n" (map (b: "install -D ${b} $out/bin/${b}") binaries)} ''; - meta = with lib; - { - description = "Collection of scripts used for BlueField SoC system management"; - homepage = "https://github.com/Mellanox/bfscripts"; - license = licenses.bsd2; - platforms = platforms.linux; - maintainers = with maintainers; [ nikstur ]; - }; + meta = with lib; { + description = "Collection of scripts used for BlueField SoC system management"; + homepage = "https://github.com/Mellanox/bfscripts"; + license = licenses.bsd2; + platforms = platforms.linux; + maintainers = with maintainers; [ nikstur ]; + }; } diff --git a/pkgs/by-name/bf/bftools/package.nix b/pkgs/by-name/bf/bftools/package.nix index 6b8a7fd96d099d..2e60748d162e28 100644 --- a/pkgs/by-name/bf/bftools/package.nix +++ b/pkgs/by-name/bf/bftools/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, makeWrapper, fetchzip, jre }: +{ + stdenv, + lib, + makeWrapper, + fetchzip, + jre, +}: stdenv.mkDerivation rec { pname = "bftools"; diff --git a/pkgs/by-name/bf/bftpd/package.nix b/pkgs/by-name/bf/bftpd/package.nix index b244bec5fddc0a..f195306c784eed 100644 --- a/pkgs/by-name/bf/bftpd/package.nix +++ b/pkgs/by-name/bf/bftpd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libxcrypt }: +{ + lib, + stdenv, + fetchurl, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "bftpd"; diff --git a/pkgs/by-name/bg/bgnet/package.nix b/pkgs/by-name/bg/bgnet/package.nix index a69a2d7a64f931..c8d8e5ccb8536c 100644 --- a/pkgs/by-name/bg/bgnet/package.nix +++ b/pkgs/by-name/bg/bgnet/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, python3, pandoc }: +{ + stdenv, + lib, + fetchFromGitHub, + python3, + pandoc, +}: stdenv.mkDerivation { pname = "bgnet"; @@ -23,7 +29,10 @@ stdenv.mkDerivation { install -Dm644 src/bgnet.html $out/share/doc/bgnet/html/index.html ''; - nativeBuildInputs = [ python3 pandoc ]; + nativeBuildInputs = [ + python3 + pandoc + ]; meta = { description = "Beej’s Guide to Network Programming"; diff --git a/pkgs/by-name/bg/bgpdump/package.nix b/pkgs/by-name/bg/bgpdump/package.nix index 4ca75a53c254b2..93b5528f16ae4f 100644 --- a/pkgs/by-name/bg/bgpdump/package.nix +++ b/pkgs/by-name/bg/bgpdump/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, zlib, bzip2 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + zlib, + bzip2, +}: stdenv.mkDerivation rec { pname = "bgpdump"; @@ -16,7 +23,10 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ zlib bzip2 ]; + buildInputs = [ + zlib + bzip2 + ]; meta = { homepage = "https://github.com/RIPE-NCC/bgpdump"; diff --git a/pkgs/by-name/bg/bgpq3/package.nix b/pkgs/by-name/bg/bgpq3/package.nix index 7d92aa4ee995a7..9ad73d7bc037e0 100644 --- a/pkgs/by-name/bg/bgpq3/package.nix +++ b/pkgs/by-name/bg/bgpq3/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "bgpq3"; diff --git a/pkgs/by-name/bg/bgpq4/package.nix b/pkgs/by-name/bg/bgpq4/package.nix index ea47cf4b2cae0f..c7de15d1456f86 100644 --- a/pkgs/by-name/bg/bgpq4/package.nix +++ b/pkgs/by-name/bg/bgpq4/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "bgpq4"; diff --git a/pkgs/by-name/bg/bgs/package.nix b/pkgs/by-name/bg/bgs/package.nix index b50f15a1929cb6..c37dfa311cbe2c 100644 --- a/pkgs/by-name/bg/bgs/package.nix +++ b/pkgs/by-name/bg/bgs/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, libX11, libXinerama, imlib2 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libX11, + libXinerama, + imlib2, +}: stdenv.mkDerivation rec { @@ -14,7 +22,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libX11 libXinerama imlib2 ]; + buildInputs = [ + libX11 + libXinerama + imlib2 + ]; preConfigure = ''sed -i "s@PREFIX = /usr/local@PREFIX = $out@g" config.mk''; diff --git a/pkgs/by-name/bi/bibata-cursors/package.nix b/pkgs/by-name/bi/bibata-cursors/package.nix index e450314cef1ce1..0c0253b4ae8e41 100644 --- a/pkgs/by-name/bi/bibata-cursors/package.nix +++ b/pkgs/by-name/bi/bibata-cursors/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, fetchzip -, clickgen +{ + lib, + stdenvNoCC, + fetchFromGitHub, + fetchzip, + clickgen, }: stdenvNoCC.mkDerivation rec { @@ -61,6 +62,9 @@ stdenvNoCC.mkDerivation rec { homepage = "https://github.com/ful1e5/Bibata_Cursor"; license = lib.licenses.gpl3Only; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ rawkode AdsonCicilioti ]; + maintainers = with lib.maintainers; [ + rawkode + AdsonCicilioti + ]; }; } diff --git a/pkgs/by-name/bi/bibclean/package.nix b/pkgs/by-name/bi/bibclean/package.nix index eb84ff8d7037df..a87569b0213e78 100644 --- a/pkgs/by-name/bi/bibclean/package.nix +++ b/pkgs/by-name/bi/bibclean/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "bibclean"; diff --git a/pkgs/by-name/bi/biber-ms/package.nix b/pkgs/by-name/bi/biber-ms/package.nix index 38452d7f9638d9..b2f7000539c83f 100644 --- a/pkgs/by-name/bi/biber-ms/package.nix +++ b/pkgs/by-name/bi/biber-ms/package.nix @@ -1,14 +1,23 @@ -{ lib, stdenv, fetchFromGitHub, perlPackages, shortenPerlShebang, texlive }: +{ + lib, + stdenv, + fetchFromGitHub, + perlPackages, + shortenPerlShebang, + texlive, +}: let biberSource = texlive.pkgs.biber-ms.texsource; # missing test file - multiscriptBltxml = (fetchFromGitHub { - owner = "plk"; - repo = "biber"; - rev = "e8d056433063add7800f24589de76f89c4b64c20"; - hash = "sha256-QnN6Iyw6iOjfTX7DLVptsfAO/QNn9vOIk5IZlI15EvQ="; - }) + "/t/tdata/multiscript.bltxml"; + multiscriptBltxml = + (fetchFromGitHub { + owner = "plk"; + repo = "biber"; + rev = "e8d056433063add7800f24589de76f89c4b64c20"; + hash = "sha256-QnN6Iyw6iOjfTX7DLVptsfAO/QNn9vOIk5IZlI15EvQ="; + }) + + "/t/tdata/multiscript.bltxml"; in perlPackages.buildPerlModule { @@ -21,17 +30,53 @@ perlPackages.buildPerlModule { # evaluation errors with config.allowAliases = false) buildInputs = with perlPackages; [ # build deps - ConfigAutoConf ExtUtilsLibBuilder FileWhich TestDifferences - /*TestMore=TestSimple=null*/ + ConfigAutoConf + ExtUtilsLibBuilder + FileWhich + TestDifferences + # TestMore=TestSimple=null # runtime deps - BusinessISBN BusinessISMN BusinessISSN ClassAccessor DataCompare DataDump - DataUniqid DateTimeCalendarJulian DateTimeFormatBuilder EncodeEUCJPASCII - EncodeHanExtra EncodeJIS2K EncodeLocale FileSlurper IOString IPCRun3 - LWPProtocolHttps LWP/*LWPUserAgent*/ libwwwperl LinguaTranslit ListAllUtils - ListMoreUtils ListMoreUtilsXS LogLog4perl MozillaCA ParseRecDescent - PerlIOutf8_strict RegexpCommon SortKey TextBalanced TextBibTeX TextCSV - TextCSV_XS TextRoman URI UnicodeLineBreak XMLLibXML XMLLibXMLSimple - XMLLibXSLT XMLWriter autovivification + BusinessISBN + BusinessISMN + BusinessISSN + ClassAccessor + DataCompare + DataDump + DataUniqid + DateTimeCalendarJulian + DateTimeFormatBuilder + EncodeEUCJPASCII + EncodeHanExtra + EncodeJIS2K + EncodeLocale + FileSlurper + IOString + IPCRun3 + LWPProtocolHttps + LWP # LWPUserAgent + libwwwperl + LinguaTranslit + ListAllUtils + ListMoreUtils + ListMoreUtilsXS + LogLog4perl + MozillaCA + ParseRecDescent + PerlIOutf8_strict + RegexpCommon + SortKey + TextBalanced + TextBibTeX + TextCSV + TextCSV_XS + TextRoman + URI + UnicodeLineBreak + XMLLibXML + XMLLibXMLSimple + XMLLibXSLT + XMLWriter + autovivification ]; nativeBuildInputs = lib.optional stdenv.hostPlatform.isDarwin shortenPerlShebang; @@ -39,11 +84,13 @@ perlPackages.buildPerlModule { cp '${multiscriptBltxml}' t/tdata/multiscript.bltxml ''; - postInstall = '' - mv "$out"/bin/biber{,-ms} - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - shortenPerlShebang "$out"/bin/biber-ms - ''; + postInstall = + '' + mv "$out"/bin/biber{,-ms} + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + shortenPerlShebang "$out"/bin/biber-ms + ''; meta = with lib; { description = "Backend for BibLaTeX (multiscript version)"; diff --git a/pkgs/by-name/bi/biber/package.nix b/pkgs/by-name/bi/biber/package.nix index 1e5a4ec21666d7..0d6dbed8467666 100644 --- a/pkgs/by-name/bi/biber/package.nix +++ b/pkgs/by-name/bi/biber/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, perlPackages, shortenPerlShebang, texlive }: +{ + lib, + stdenv, + perlPackages, + shortenPerlShebang, + texlive, +}: let biberSource = texlive.pkgs.biber.texsource; @@ -10,13 +16,46 @@ perlPackages.buildPerlModule { src = "${biberSource}/source/bibtex/biber/biblatex-biber.tar.gz"; buildInputs = with perlPackages; [ - autovivification BusinessISBN BusinessISMN BusinessISSN ConfigAutoConf - DataCompare DataDump DateSimple EncodeEUCJPASCII EncodeHanExtra EncodeJIS2K - DateTime DateTimeFormatBuilder DateTimeCalendarJulian - ExtUtilsLibBuilder FileSlurper FileWhich IPCRun3 LogLog4perl LWPProtocolHttps ListAllUtils - ListMoreUtils MozillaCA ParseRecDescent IOString ReadonlyXS RegexpCommon TextBibTeX - UnicodeLineBreak URI XMLLibXMLSimple XMLLibXSLT XMLWriter - ClassAccessor TextCSV TextCSV_XS TextRoman DataUniqid LinguaTranslit SortKey + autovivification + BusinessISBN + BusinessISMN + BusinessISSN + ConfigAutoConf + DataCompare + DataDump + DateSimple + EncodeEUCJPASCII + EncodeHanExtra + EncodeJIS2K + DateTime + DateTimeFormatBuilder + DateTimeCalendarJulian + ExtUtilsLibBuilder + FileSlurper + FileWhich + IPCRun3 + LogLog4perl + LWPProtocolHttps + ListAllUtils + ListMoreUtils + MozillaCA + ParseRecDescent + IOString + ReadonlyXS + RegexpCommon + TextBibTeX + UnicodeLineBreak + URI + XMLLibXMLSimple + XMLLibXSLT + XMLWriter + ClassAccessor + TextCSV + TextCSV_XS + TextRoman + DataUniqid + LinguaTranslit + SortKey TestDifferences PerlIOutf8_strict ]; diff --git a/pkgs/by-name/bi/biblatex-check/package.nix b/pkgs/by-name/bi/biblatex-check/package.nix index beff041561909d..79cc1264a05720 100644 --- a/pkgs/by-name/bi/biblatex-check/package.nix +++ b/pkgs/by-name/bi/biblatex-check/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation rec { pname = "biblatex-check"; diff --git a/pkgs/by-name/bi/biblesync/package.nix b/pkgs/by-name/bi/biblesync/package.nix index 1ac53a0b9b8fda..fd1a11d305c9bd 100644 --- a/pkgs/by-name/bi/biblesync/package.nix +++ b/pkgs/by-name/bi/biblesync/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, cmake, libuuid }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + libuuid, +}: stdenv.mkDerivation rec { @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "0prmd12jq2cjdhsph5v89y38j7hhd51dr3r1hivgkhczr3m5hf4s"; }; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; buildInputs = [ libuuid ]; meta = with lib; { diff --git a/pkgs/by-name/bi/biboumi/package.nix b/pkgs/by-name/bi/biboumi/package.nix index 9d63356abd6ba3..2228ae64ac1ea3 100644 --- a/pkgs/by-name/bi/biboumi/package.nix +++ b/pkgs/by-name/bi/biboumi/package.nix @@ -1,5 +1,20 @@ -{ lib, stdenv, fetchurl, fetchgit, cmake, libuuid, expat, sqlite, libidn -, libiconv, botan2, systemd, pkg-config, udns, python3Packages } : +{ + lib, + stdenv, + fetchurl, + fetchgit, + cmake, + libuuid, + expat, + sqlite, + libidn, + libiconv, + botan2, + systemd, + pkg-config, + udns, + python3Packages, +}: let louiz_catch = fetchgit { @@ -19,10 +34,26 @@ stdenv.mkDerivation rec { patches = [ ./catch.patch ]; - nativeBuildInputs = [ cmake pkg-config python3Packages.sphinx ]; - buildInputs = [ libuuid expat sqlite libiconv libidn botan2 systemd udns ]; + nativeBuildInputs = [ + cmake + pkg-config + python3Packages.sphinx + ]; + buildInputs = [ + libuuid + expat + sqlite + libiconv + libidn + botan2 + systemd + udns + ]; - buildFlags = [ "all" "man" ]; + buildFlags = [ + "all" + "man" + ]; preConfigure = '' substituteInPlace CMakeLists.txt --replace /etc/biboumi $out/etc/biboumi diff --git a/pkgs/by-name/bi/bibtex-tidy/package.nix b/pkgs/by-name/bi/bibtex-tidy/package.nix index 862c82c9d5c903..24d58f7c72998c 100644 --- a/pkgs/by-name/bi/bibtex-tidy/package.nix +++ b/pkgs/by-name/bi/bibtex-tidy/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, testers -, bibtex-tidy +{ + lib, + buildNpmPackage, + fetchFromGitHub, + testers, + bibtex-tidy, }: buildNpmPackage rec { diff --git a/pkgs/by-name/bi/bibtex2html/package.nix b/pkgs/by-name/bi/bibtex2html/package.nix index 2af4aaa0812833..eae4f6624673b1 100644 --- a/pkgs/by-name/bi/bibtex2html/package.nix +++ b/pkgs/by-name/bi/bibtex2html/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, ocaml, perl }: +{ + lib, + stdenv, + fetchurl, + ocaml, + perl, +}: stdenv.mkDerivation { pname = "bibtex2html"; @@ -11,13 +17,16 @@ stdenv.mkDerivation { strictDeps = true; - nativeBuildInputs = [ ocaml perl ]; + nativeBuildInputs = [ + ocaml + perl + ]; meta = with lib; { description = "Collection of tools for translating from BibTeX to HTML"; homepage = "https://www.lri.fr/~filliatr/bibtex2html/"; license = licenses.gpl2Only; - platforms = ocaml.meta.platforms or []; + platforms = ocaml.meta.platforms or [ ]; maintainers = [ maintainers.scolobb ]; }; } diff --git a/pkgs/by-name/bi/bibtool/package.nix b/pkgs/by-name/bi/bibtool/package.nix index 46c798f12c6dc1..e52c0bd97929f1 100644 --- a/pkgs/by-name/bi/bibtool/package.nix +++ b/pkgs/by-name/bi/bibtool/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "bibtool"; @@ -12,7 +17,10 @@ stdenv.mkDerivation rec { # Perl for running test suite. buildInputs = [ perl ]; - installTargets = [ "install" "install.man" ]; + installTargets = [ + "install" + "install.man" + ]; doCheck = true; checkTarget = "test"; diff --git a/pkgs/by-name/bi/bibutils/package.nix b/pkgs/by-name/bi/bibutils/package.nix index c6dd28777b4d21..54cc64412ac59a 100644 --- a/pkgs/by-name/bi/bibutils/package.nix +++ b/pkgs/by-name/bi/bibutils/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, static ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchurl, + static ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { @@ -24,8 +25,10 @@ stdenv.mkDerivation rec { configureFlags = [ (if static then "--static" else "--dynamic") - "--install-dir" "$(out)/bin" - "--install-lib" "$(out)/lib" + "--install-dir" + "$(out)/bin" + "--install-lib" + "$(out)/lib" ]; dontAddPrefix = true; diff --git a/pkgs/by-name/bi/bic/package.nix b/pkgs/by-name/bi/bic/package.nix index 1571e93e071f61..43893b684b337d 100644 --- a/pkgs/by-name/bi/bic/package.nix +++ b/pkgs/by-name/bi/bic/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, readline -, autoreconfHook -, autoconf-archive -, gmp -, flex -, bison +{ + lib, + stdenv, + fetchFromGitHub, + readline, + autoreconfHook, + autoconf-archive, + gmp, + flex, + bison, }: stdenv.mkDerivation rec { @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { sha256 = "1ws46h1ngzk14dspmsggj9535yl04v9wh8v4gb234n34rdkdsyyw"; }; - buildInputs = [ readline gmp ]; + buildInputs = [ + readline + gmp + ]; nativeBuildInputs = [ autoreconfHook autoconf-archive diff --git a/pkgs/by-name/bi/bicgl/package.nix b/pkgs/by-name/bi/bicgl/package.nix index 89f4220f92f412..96a56fb5245c94 100644 --- a/pkgs/by-name/bi/bicgl/package.nix +++ b/pkgs/by-name/bi/bicgl/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libminc, bicpl, libGLU, libglut }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libminc, + bicpl, + libGLU, + libglut, +}: stdenv.mkDerivation rec { pname = "bicgl"; @@ -14,7 +23,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libminc bicpl libGLU libglut ]; + buildInputs = [ + libminc + bicpl + libGLU + libglut + ]; cmakeFlags = [ "-DLIBMINC_DIR=${libminc}/lib/cmake" diff --git a/pkgs/by-name/bi/bicon/package.nix b/pkgs/by-name/bi/bicon/package.nix index 11f63b7a868f43..d5055459e2d1fb 100644 --- a/pkgs/by-name/bi/bicon/package.nix +++ b/pkgs/by-name/bi/bicon/package.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, pkg-config -, perl -, fribidi -, kbd -, xkbutils +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + perl, + fribidi, + kbd, + xkbutils, }: stdenv.mkDerivation rec { @@ -30,8 +32,16 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ fribidi kbd xkbutils perl ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + buildInputs = [ + fribidi + kbd + xkbutils + perl + ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; preConfigure = '' patchShebangs . @@ -39,8 +49,12 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Bidirectional console"; - homepage = "https://github.com/behdad/bicon"; - license = [ licenses.lgpl21 licenses.psfl licenses.bsd0 ]; + homepage = "https://github.com/behdad/bicon"; + license = [ + licenses.lgpl21 + licenses.psfl + licenses.bsd0 + ]; maintainers = [ ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/bi/bigloo/package.nix b/pkgs/by-name/bi/bigloo/package.nix index c3ff5334cadb57..53f76870a4fc26 100644 --- a/pkgs/by-name/bi/bigloo/package.nix +++ b/pkgs/by-name/bi/bigloo/package.nix @@ -1,5 +1,13 @@ -{ fetchurl, lib, stdenv, autoconf, automake, libtool, gmp -, darwin, libunistring +{ + fetchurl, + lib, + stdenv, + autoconf, + automake, + libtool, + gmp, + darwin, + libunistring, }: stdenv.mkDerivation rec { @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-oxOSJwKWmwo7PYAwmeoFrKaYdYvmvQquWXyutolc488="; }; - nativeBuildInputs = [ autoconf automake libtool ]; + nativeBuildInputs = [ + autoconf + automake + libtool + ]; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.ApplicationServices @@ -24,7 +36,8 @@ stdenv.mkDerivation rec { # For libuv on darwin lib.optionalString stdenv.hostPlatform.isDarwin '' export LIBTOOLIZE=libtoolize - '' + '' + '' + + '' # Help libgc's configure. export CXXCPP="$CXX -E" ''; @@ -56,11 +69,11 @@ stdenv.mkDerivation rec { meta = { description = "Efficient Scheme compiler"; - homepage = "http://www-sop.inria.fr/indes/fp/Bigloo/"; - license = lib.licenses.gpl2Plus; - platforms = lib.platforms.unix; + homepage = "http://www-sop.inria.fr/indes/fp/Bigloo/"; + license = lib.licenses.gpl2Plus; + platforms = lib.platforms.unix; maintainers = with lib.maintainers; [ thoughtpolice ]; - broken = stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64; # segfault during build + broken = stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64; # segfault during build longDescription = '' Bigloo is a Scheme implementation devoted to one goal: enabling diff --git a/pkgs/by-name/bi/bin2c/package.nix b/pkgs/by-name/bi/bin2c/package.nix index 7ac93c4539b9f8..76407d1f3e3cc0 100644 --- a/pkgs/by-name/bi/bin2c/package.nix +++ b/pkgs/by-name/bi/bin2c/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, util-linux +{ + lib, + stdenv, + fetchFromGitHub, + util-linux, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/bi/binbloom/package.nix b/pkgs/by-name/bi/binbloom/package.nix index 766e40f8f0594e..5d445544613788 100644 --- a/pkgs/by-name/bi/binbloom/package.nix +++ b/pkgs/by-name/bi/binbloom/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/bi/bind/package.nix b/pkgs/by-name/bi/bind/package.nix index 545474200bf848..73b0651c704d32 100644 --- a/pkgs/by-name/bi/bind/package.nix +++ b/pkgs/by-name/bi/bind/package.nix @@ -1,26 +1,27 @@ -{ stdenv -, lib -, fetchurl -, darwin -, perl -, pkg-config -, libcap -, libidn2 -, libtool -, libxml2 -, openssl -, libuv -, nghttp2 -, jemalloc -, enablePython ? false -, python3 -, enableGSSAPI ? true -, libkrb5 -, buildPackages -, nixosTests -, cmocka -, tzdata -, gitUpdater +{ + stdenv, + lib, + fetchurl, + darwin, + perl, + pkg-config, + libcap, + libidn2, + libtool, + libxml2, + openssl, + libuv, + nghttp2, + jemalloc, + enablePython ? false, + python3, + enableGSSAPI ? true, + libkrb5, + buildPackages, + nixosTests, + cmocka, + tzdata, + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { @@ -32,14 +33,33 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-58zpoWX3thnu/Egy8KjcFrAF0p44kK7WAIxQbqKGpec="; }; - outputs = [ "out" "lib" "dev" "man" "dnsutils" "host" ]; + outputs = [ + "out" + "lib" + "dev" + "man" + "dnsutils" + "host" + ]; patches = [ ./dont-keep-configure-flags.patch ]; - nativeBuildInputs = [ perl pkg-config ]; - buildInputs = [ libidn2 libtool libxml2 openssl libuv nghttp2 jemalloc ] + nativeBuildInputs = [ + perl + pkg-config + ]; + buildInputs = + [ + libidn2 + libtool + libxml2 + openssl + libuv + nghttp2 + jemalloc + ] ++ lib.optional stdenv.hostPlatform.isLinux libcap ++ lib.optional enableGSSAPI libkrb5 ++ lib.optional enablePython (python3.withPackages (ps: with ps; [ ply ])) @@ -47,12 +67,14 @@ stdenv.mkDerivation (finalAttrs: { depsBuildBuild = [ buildPackages.stdenv.cc ]; - configureFlags = [ - "--localstatedir=/var" - "--without-lmdb" - "--with-libidn2" - ] ++ lib.optional enableGSSAPI "--with-gssapi=${libkrb5.dev}/bin/krb5-config" - ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "BUILD_CC=$(CC_FOR_BUILD)"; + configureFlags = + [ + "--localstatedir=/var" + "--without-lmdb" + "--with-libidn2" + ] + ++ lib.optional enableGSSAPI "--with-gssapi=${libkrb5.dev}/bin/krb5-config" + ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "BUILD_CC=$(CC_FOR_BUILD)"; postInstall = '' moveToOutput bin/bind9-config $dev @@ -84,23 +106,27 @@ stdenv.mkDerivation (finalAttrs: { # TODO: investigate failures; see this and linked discussions: # https://github.com/NixOS/nixpkgs/pull/192962 /* - doCheck = with stdenv.hostPlatform; !isStatic && !(isAarch64 && isLinux) - # https://gitlab.isc.org/isc-projects/bind9/-/issues/4269 - && !is32bit; + doCheck = with stdenv.hostPlatform; !isStatic && !(isAarch64 && isLinux) + # https://gitlab.isc.org/isc-projects/bind9/-/issues/4269 + && !is32bit; */ checkTarget = "unit"; - checkInputs = [ - cmocka - ] ++ lib.optionals (!stdenv.hostPlatform.isMusl) [ - tzdata - ]; - preCheck = lib.optionalString stdenv.hostPlatform.isMusl '' - # musl doesn't respect TZDIR, skip timezone-related tests - sed -i '/^ISC_TEST_ENTRY(isc_time_formatISO8601L/d' tests/isc/time_test.c - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Test timeouts on Darwin - sed -i '/^ISC_TEST_ENTRY(tcpdns_recv_one/d' tests/isc/netmgr_test.c - ''; + checkInputs = + [ + cmocka + ] + ++ lib.optionals (!stdenv.hostPlatform.isMusl) [ + tzdata + ]; + preCheck = + lib.optionalString stdenv.hostPlatform.isMusl '' + # musl doesn't respect TZDIR, skip timezone-related tests + sed -i '/^ISC_TEST_ENTRY(isc_time_formatISO8601L/d' tests/isc/time_test.c + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Test timeouts on Darwin + sed -i '/^ISC_TEST_ENTRY(tcpdns_recv_one/d' tests/isc/netmgr_test.c + ''; passthru = { tests = { @@ -128,6 +154,10 @@ stdenv.mkDerivation (finalAttrs: { maintainers = with maintainers; [ globin ]; platforms = platforms.unix; - outputsToInstall = [ "out" "dnsutils" "host" ]; + outputsToInstall = [ + "out" + "dnsutils" + "host" + ]; }; }) diff --git a/pkgs/by-name/bi/bindfs/package.nix b/pkgs/by-name/bi/bindfs/package.nix index f086e9416ad6ec..f84391880f5788 100644 --- a/pkgs/by-name/bi/bindfs/package.nix +++ b/pkgs/by-name/bi/bindfs/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, fuse -, fuse3 +{ + lib, + stdenv, + fetchurl, + pkg-config, + fuse, + fuse3, }: stdenv.mkDerivation (finalAttrs: { @@ -32,7 +33,10 @@ stdenv.mkDerivation (finalAttrs: { description = "FUSE filesystem for mounting a directory to another location"; homepage = "https://bindfs.org"; license = lib.licenses.gpl2Only; - maintainers = with lib.maintainers; [ lovek323 lovesegfault ]; + maintainers = with lib.maintainers; [ + lovek323 + lovesegfault + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/by-name/bi/bingrep/package.nix b/pkgs/by-name/bi/bingrep/package.nix index 6a5e2041e57dd6..43a820f56d9a9e 100644 --- a/pkgs/by-name/bi/bingrep/package.nix +++ b/pkgs/by-name/bi/bingrep/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "bingrep"; diff --git a/pkgs/by-name/bi/binsort/package.nix b/pkgs/by-name/bi/binsort/package.nix index b1100dabad8cb3..d1296d8334ae3d 100644 --- a/pkgs/by-name/bi/binsort/package.nix +++ b/pkgs/by-name/bi/binsort/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/bi/bioawk/package.nix b/pkgs/by-name/bi/bioawk/package.nix index f7da30fc4f72a6..8caee2afea0d25 100644 --- a/pkgs/by-name/bi/bioawk/package.nix +++ b/pkgs/by-name/bi/bioawk/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles -, bison -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + bison, + zlib, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/bi/biodiff/package.nix b/pkgs/by-name/bi/biodiff/package.nix index adbb69f486e8c4..37d8fe6c9513a8 100644 --- a/pkgs/by-name/bi/biodiff/package.nix +++ b/pkgs/by-name/bi/biodiff/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, rustPlatform, wfa2-lib }: +{ + lib, + fetchFromGitHub, + rustPlatform, + wfa2-lib, +}: rustPlatform.buildRustPackage rec { pname = "biodiff"; diff --git a/pkgs/by-name/bi/biosdevname/package.nix b/pkgs/by-name/bi/biosdevname/package.nix index ce8265520da5e3..c1085956f00b23 100644 --- a/pkgs/by-name/bi/biosdevname/package.nix +++ b/pkgs/by-name/bi/biosdevname/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, zlib, pciutils }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + zlib, + pciutils, +}: stdenv.mkDerivation rec { pname = "biosdevname"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ zlib pciutils ]; + buildInputs = [ + zlib + pciutils + ]; # Don't install /lib/udev/rules.d/*-biosdevname.rules patches = [ ./makefile.patch ]; @@ -22,7 +32,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Udev helper for naming devices per BIOS names"; license = licenses.gpl2Only; - platforms = ["x86_64-linux" "i686-linux"]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ ]; mainProgram = "biosdevname"; }; diff --git a/pkgs/by-name/bi/bip/package.nix b/pkgs/by-name/bi/bip/package.nix index 75f31d1ba9b591..1d4655cc83ab38 100644 --- a/pkgs/by-name/bi/bip/package.nix +++ b/pkgs/by-name/bi/bip/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, pkg-config -, bison -, flex -, openssl +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + bison, + flex, + openssl, }: stdenv.mkDerivation { @@ -18,7 +19,11 @@ stdenv.mkDerivation { hash = "sha256-K+6AC8mg0aLQsCgiDoFBM5w2XrR+V2tfWnI8ByeRmOI="; }; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; postPatch = '' # Drop blanket -Werror to avoid build failure on fresh toolchains @@ -27,8 +32,15 @@ stdenv.mkDerivation { substituteInPlace src/Makefile.am --replace-fail ' -Werror ' ' ' ''; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ bison flex openssl ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + bison + flex + openssl + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/bi/bird-lg/package.nix b/pkgs/by-name/bi/bird-lg/package.nix index b459e0b304afd6..db6fb798c0d48d 100644 --- a/pkgs/by-name/bi/bird-lg/package.nix +++ b/pkgs/by-name/bi/bird-lg/package.nix @@ -1,6 +1,12 @@ -{ buildGoModule, fetchFromGitHub, lib, symlinkJoin }: +{ + buildGoModule, + fetchFromGitHub, + lib, + symlinkJoin, +}: let - generic = { modRoot, vendorHash }: + generic = + { modRoot, vendorHash }: buildGoModule rec { pname = "bird-lg-${modRoot}"; version = "1.3.5"; @@ -45,7 +51,11 @@ let in symlinkJoin { name = "bird-lg-${bird-lg-frontend.version}"; - paths = [ bird-lg-frontend bird-lg-proxy ]; -} // { + paths = [ + bird-lg-frontend + bird-lg-proxy + ]; +} +// { inherit (bird-lg-frontend) version meta; } diff --git a/pkgs/by-name/bi/bird/package.nix b/pkgs/by-name/bi/bird/package.nix index 70a55af9829d20..29aa83416ddc04 100644 --- a/pkgs/by-name/bi/bird/package.nix +++ b/pkgs/by-name/bi/bird/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, flex, bison, readline, libssh, nixosTests }: +{ + lib, + stdenv, + fetchurl, + flex, + bison, + readline, + libssh, + nixosTests, +}: stdenv.mkDerivation rec { pname = "bird"; @@ -9,14 +18,20 @@ stdenv.mkDerivation rec { hash = "sha256-ZikRApOvbxcnlnEh1k+cjclO1hgcTvix3FHH/dZphxw="; }; - nativeBuildInputs = [ flex bison ]; - buildInputs = [ readline libssh ]; + nativeBuildInputs = [ + flex + bison + ]; + buildInputs = [ + readline + libssh + ]; patches = [ ./dont-create-sysconfdir-2.patch ]; - CPP="${stdenv.cc.targetPrefix}cpp -E"; + CPP = "${stdenv.cc.targetPrefix}cpp -E"; configureFlags = [ "--localstatedir=/var" diff --git a/pkgs/by-name/bi/biscuit-cli/package.nix b/pkgs/by-name/bi/biscuit-cli/package.nix index c04d8ea0c11892..e043049d2a6719 100644 --- a/pkgs/by-name/bi/biscuit-cli/package.nix +++ b/pkgs/by-name/bi/biscuit-cli/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, testers -, nix-update-script -, biscuit-cli +{ + lib, + fetchFromGitHub, + rustPlatform, + testers, + nix-update-script, + biscuit-cli, }: rustPlatform.buildRustPackage rec { @@ -31,7 +32,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "CLI to generate and inspect biscuit tokens"; homepage = "https://www.biscuitsec.org/"; - maintainers = with maintainers; [ shlevy gaelreyrol ]; + maintainers = with maintainers; [ + shlevy + gaelreyrol + ]; license = licenses.bsd3; mainProgram = "biscuit"; }; diff --git a/pkgs/by-name/bi/bison/package.nix b/pkgs/by-name/bi/bison/package.nix index 80a2ad835c2852..f4b83b2bdec3d1 100644 --- a/pkgs/by-name/bi/bison/package.nix +++ b/pkgs/by-name/bi/bison/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, m4, perl, help2man }: +{ + lib, + stdenv, + fetchurl, + m4, + perl, + help2man, +}: # Note: this package is used for bootstrapping fetchurl, and thus # cannot use fetchpatch! All mutable patches (generated by GitHub or @@ -16,14 +23,20 @@ stdenv.mkDerivation rec { # gnulib relies on --host= to detect iconv() features on musl(). # Otherwise tests fail due to incorrect unicode symbol oconversion. - configurePlatforms = [ "build" "host" ]; + configurePlatforms = [ + "build" + "host" + ]; # there's a /bin/sh shebang in bin/yacc which when no strictDeps is patched with the build stdenv shell # however when cross-compiling it would still be patched with the build stdenv shell which would be wrong # cannot add bash to buildInputs due to infinite recursion strictDeps = stdenv.hostPlatform != stdenv.buildPlatform; - nativeBuildInputs = [ m4 perl ] ++ lib.optional stdenv.hostPlatform.isSunOS help2man; + nativeBuildInputs = [ + m4 + perl + ] ++ lib.optional stdenv.hostPlatform.isSunOS help2man; propagatedBuildInputs = [ m4 ]; enableParallelBuilding = true; @@ -54,5 +67,7 @@ stdenv.mkDerivation rec { platforms = lib.platforms.unix; }; - passthru = { glrSupport = true; }; + passthru = { + glrSupport = true; + }; } diff --git a/pkgs/by-name/bi/bisoncpp/package.nix b/pkgs/by-name/bi/bisoncpp/package.nix index 16d8e13cdfda7f..d4a2d08259fffb 100644 --- a/pkgs/by-name/bi/bisoncpp/package.nix +++ b/pkgs/by-name/bi/bisoncpp/package.nix @@ -1,5 +1,12 @@ -{lib, stdenv, fetchurl, fetchFromGitLab -, yodl, icmake, flexcpp, bobcat +{ + lib, + stdenv, + fetchurl, + fetchFromGitLab, + yodl, + icmake, + flexcpp, + bobcat, }: stdenv.mkDerivation rec { pname = "bisonc++"; @@ -15,7 +22,11 @@ stdenv.mkDerivation rec { buildInputs = [ bobcat ]; - nativeBuildInputs = [ yodl icmake flexcpp ]; + nativeBuildInputs = [ + yodl + icmake + flexcpp + ]; setSourceRoot = '' sourceRoot="$(echo */bisonc++)" diff --git a/pkgs/by-name/bi/bit/package.nix b/pkgs/by-name/bi/bit/package.nix index a1242c43a9ca5d..38750cf58f8760 100644 --- a/pkgs/by-name/bi/bit/package.nix +++ b/pkgs/by-name/bi/bit/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, git +{ + lib, + buildGoModule, + fetchFromGitHub, + git, }: buildGoModule rec { diff --git a/pkgs/by-name/bi/bitbake-language-server/package.nix b/pkgs/by-name/bi/bitbake-language-server/package.nix index fe19310ab29d25..d0f441fad9dc9d 100644 --- a/pkgs/by-name/bi/bitbake-language-server/package.nix +++ b/pkgs/by-name/bi/bitbake-language-server/package.nix @@ -1,8 +1,9 @@ -{ lib -, nix-update-script -, python3 -, oelint-adv -, fetchFromGitHub +{ + lib, + nix-update-script, + python3, + oelint-adv, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { @@ -22,9 +23,12 @@ python3.pkgs.buildPythonApplication rec { setuptools-generate ]; - propagatedBuildInputs = with python3.pkgs; [ - pygls - ] ++ [ oelint-adv ]; + propagatedBuildInputs = + with python3.pkgs; + [ + pygls + ] + ++ [ oelint-adv ]; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/by-name/bi/bitlbee-discord/package.nix b/pkgs/by-name/bi/bitlbee-discord/package.nix index a763ed6e81e0e2..4be2d69cf9f088 100644 --- a/pkgs/by-name/bi/bitlbee-discord/package.nix +++ b/pkgs/by-name/bi/bitlbee-discord/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, stdenv, bitlbee, autoreconfHook, pkg-config }: +{ + lib, + fetchFromGitHub, + stdenv, + bitlbee, + autoreconfHook, + pkg-config, +}: stdenv.mkDerivation rec { pname = "bitlbee-discord"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "00qgdvrp7hv02n0ns685igp810zxmv3adsama8601122al6x041n"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ bitlbee ]; preConfigure = '' diff --git a/pkgs/by-name/bi/bitlbee-facebook/package.nix b/pkgs/by-name/bi/bitlbee-facebook/package.nix index 707e7ffd9e469d..086675c4f043c2 100644 --- a/pkgs/by-name/bi/bitlbee-facebook/package.nix +++ b/pkgs/by-name/bi/bitlbee-facebook/package.nix @@ -1,4 +1,14 @@ -{ lib, fetchFromGitHub, stdenv, bitlbee, autoconf, automake, libtool, pkg-config, json-glib }: +{ + lib, + fetchFromGitHub, + stdenv, + bitlbee, + autoconf, + automake, + libtool, + pkg-config, + json-glib, +}: stdenv.mkDerivation rec { pname = "bitlbee-facebook"; @@ -11,9 +21,17 @@ stdenv.mkDerivation rec { sha256 = "1qiiiq17ybylbhwgbwsvmshb517589r8yy5rsh1rfaylmlcxyy7z"; }; - nativeBuildInputs = [ autoconf automake libtool pkg-config ]; + nativeBuildInputs = [ + autoconf + automake + libtool + pkg-config + ]; - buildInputs = [ bitlbee json-glib ]; + buildInputs = [ + bitlbee + json-glib + ]; preConfigure = '' export BITLBEE_PLUGINDIR=$out/lib/bitlbee diff --git a/pkgs/by-name/bi/bitlbee-mastodon/package.nix b/pkgs/by-name/bi/bitlbee-mastodon/package.nix index 0e014ea9a79066..1483602490ab93 100644 --- a/pkgs/by-name/bi/bitlbee-mastodon/package.nix +++ b/pkgs/by-name/bi/bitlbee-mastodon/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchgit, stdenv, bitlbee, autoreconfHook, pkg-config }: +{ + lib, + fetchgit, + stdenv, + bitlbee, + autoreconfHook, + pkg-config, +}: stdenv.mkDerivation rec { pname = "bitlbee-mastodon"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-8vmq/YstuBYUxe00P4NrxD/eMYI++R9uvn1sCcMTr7I="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ bitlbee ]; preConfigure = '' diff --git a/pkgs/by-name/bi/bitlbee-steam/package.nix b/pkgs/by-name/bi/bitlbee-steam/package.nix index 441963f57ddfc6..02e6f5468c9d02 100644 --- a/pkgs/by-name/bi/bitlbee-steam/package.nix +++ b/pkgs/by-name/bi/bitlbee-steam/package.nix @@ -1,4 +1,14 @@ -{ lib, fetchFromGitHub, stdenv, bitlbee, autoconf, automake, libtool, pkg-config, libgcrypt }: +{ + lib, + fetchFromGitHub, + stdenv, + bitlbee, + autoconf, + automake, + libtool, + pkg-config, + libgcrypt, +}: stdenv.mkDerivation rec { version = "1.4.2"; @@ -11,8 +21,16 @@ stdenv.mkDerivation rec { sha256 = "121r92mgwv445wwxzh35n19fs5k81ihr0j19k256ia5502b1xxaq"; }; - nativeBuildInputs = [ pkg-config autoconf automake ]; - buildInputs = [ bitlbee libtool libgcrypt ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; + buildInputs = [ + bitlbee + libtool + libgcrypt + ]; preConfigure = '' export BITLBEE_PLUGINDIR=$out/lib/bitlbee diff --git a/pkgs/by-name/bi/bitmagnet/package.nix b/pkgs/by-name/bi/bitmagnet/package.nix index 565d53048851bb..6cee45afd8e0c4 100644 --- a/pkgs/by-name/bi/bitmagnet/package.nix +++ b/pkgs/by-name/bi/bitmagnet/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGo122Module # builds, but does not start on 1.23 -, fetchFromGitHub -, nix-update-script +{ + lib, + buildGo122Module, # builds, but does not start on 1.23 + fetchFromGitHub, + nix-update-script, }: buildGo122Module rec { @@ -17,7 +18,11 @@ buildGo122Module rec { vendorHash = "sha256-aauXgHPZbSiTW9utuHXzJr7GsWs/2aFiGuukA/B9BRc="; - ldflags = [ "-s" "-w" "-X github.com/bitmagnet-io/bitmagnet/internal/version.GitTag=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/bitmagnet-io/bitmagnet/internal/version.GitTag=v${version}" + ]; passthru = { updateScript = nix-update-script { }; diff --git a/pkgs/by-name/bi/bitmeter/package.nix b/pkgs/by-name/bi/bitmeter/package.nix index 9ae4bd7e79fbf9..94328a663678f8 100644 --- a/pkgs/by-name/bi/bitmeter/package.nix +++ b/pkgs/by-name/bi/bitmeter/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, autoreconfHook, fetchurl, libjack2, gtk2, pkg-config }: +{ + lib, + stdenv, + autoreconfHook, + fetchurl, + libjack2, + gtk2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "bitmeter"; @@ -9,8 +17,14 @@ stdenv.mkDerivation rec { sha256 = "09ck2gxqky701dc1p0ip61rrn16v0pdc7ih2hc2sd63zcw53g2a7"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libjack2 gtk2 ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libjack2 + gtk2 + ]; patches = [ (fetchurl { diff --git a/pkgs/by-name/bi/bitwarden-cli/package.nix b/pkgs/by-name/bi/bitwarden-cli/package.nix index b39c7640d9d959..b7bd61bb99d80d 100644 --- a/pkgs/by-name/bi/bitwarden-cli/package.nix +++ b/pkgs/by-name/bi/bitwarden-cli/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, buildNpmPackage -, nodejs_20 -, fetchFromGitHub -, cctools -, nix-update-script -, nixosTests -, perl -, xcbuild +{ + lib, + stdenv, + buildNpmPackage, + nodejs_20, + fetchFromGitHub, + cctools, + nix-update-script, + nixosTests, + perl, + xcbuild, }: buildNpmPackage rec { @@ -54,7 +55,11 @@ buildNpmPackage rec { vaultwarden = nixosTests.vaultwarden.sqlite; }; updateScript = nix-update-script { - extraArgs = [ "--commit" "--version=stable" "--version-regex=^cli-v(.*)$" ]; + extraArgs = [ + "--commit" + "--version=stable" + "--version-regex=^cli-v(.*)$" + ]; }; }; diff --git a/pkgs/by-name/bi/bitwarden-desktop/package.nix b/pkgs/by-name/bi/bitwarden-desktop/package.nix index 8c6a0ee69d2e7d..d2179a6501721d 100644 --- a/pkgs/by-name/bi/bitwarden-desktop/package.nix +++ b/pkgs/by-name/bi/bitwarden-desktop/package.nix @@ -1,26 +1,27 @@ -{ lib -, buildNpmPackage -, cargo -, copyDesktopItems -, electron_32 -, fetchFromGitHub -, glib -, gnome-keyring -, gtk3 -, jq -, libsecret -, makeDesktopItem -, makeWrapper -, napi-rs-cli -, nix-update-script -, nodejs_20 -, patchutils_0_4_2 -, pkg-config -, python3 -, runCommand -, rustc -, rustPlatform -, stdenv +{ + lib, + buildNpmPackage, + cargo, + copyDesktopItems, + electron_32, + fetchFromGitHub, + glib, + gnome-keyring, + gtk3, + jq, + libsecret, + makeDesktopItem, + makeWrapper, + napi-rs-cli, + nix-update-script, + nodejs_20, + patchutils_0_4_2, + pkg-config, + python3, + runCommand, + rustc, + rustPlatform, + stdenv, }: let @@ -28,12 +29,16 @@ let icon = "bitwarden"; electron = electron_32; - bitwardenDesktopNativeArch = { - aarch64 = "arm64"; - x86_64 = "x64"; - }.${stdenv.hostPlatform.parsed.cpu.name} or (throw "bitwarden-desktop: unsupported CPU family ${stdenv.hostPlatform.parsed.cpu.name}"); + bitwardenDesktopNativeArch = + { + aarch64 = "arm64"; + x86_64 = "x64"; + } + .${stdenv.hostPlatform.parsed.cpu.name} + or (throw "bitwarden-desktop: unsupported CPU family ${stdenv.hostPlatform.parsed.cpu.name}"); -in buildNpmPackage rec { +in +buildNpmPackage rec { pname = "bitwarden-desktop"; version = "2024.11.1"; @@ -61,22 +66,22 @@ in buildNpmPackage rec { nodejs = nodejs_20; makeCacheWritable = true; - npmFlags = [ "--engine-strict" "--legacy-peer-deps" ]; + npmFlags = [ + "--engine-strict" + "--legacy-peer-deps" + ]; npmWorkspace = "apps/desktop"; npmDepsHash = "sha256-YzhCyNMvfXGmgOpl3qWj1Pqd1hY8CJ9QLwQds5ZMnqg="; cargoDeps = rustPlatform.fetchCargoTarball { name = "${pname}-${version}"; inherit src; - patches = map - (patch: runCommand - (builtins.baseNameOf patch) - { nativeBuildInputs = [ patchutils_0_4_2 ]; } - '' - < ${patch} filterdiff -p1 --include=${lib.escapeShellArg cargoRoot}'/*' > $out - '' - ) - patches; + patches = map ( + patch: + runCommand (builtins.baseNameOf patch) { nativeBuildInputs = [ patchutils_0_4_2 ]; } '' + < ${patch} filterdiff -p1 --include=${lib.escapeShellArg cargoRoot}'/*' > $out + '' + ) patches; patchFlags = [ "-p4" ]; sourceRoot = "${src.name}/${cargoRoot}"; hash = "sha256-aurjpVzWET30O+ysyE4ZzauMe8kHjOL169tfKUR1Vpg="; @@ -197,7 +202,11 @@ in buildNpmPackage rec { passthru = { updateScript = nix-update-script { - extraArgs = [ "--commit" "--version=stable" "--version-regex=^desktop-v(.*)$" ]; + extraArgs = [ + "--commit" + "--version=stable" + "--version-regex=^desktop-v(.*)$" + ]; }; }; @@ -207,7 +216,10 @@ in buildNpmPackage rec { homepage = "https://bitwarden.com"; license = lib.licenses.gpl3; maintainers = with lib.maintainers; [ amarshall ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; mainProgram = "bitwarden"; }; } diff --git a/pkgs/by-name/bi/bitwise/package.nix b/pkgs/by-name/bi/bitwise/package.nix index a01fa83b3c79ec..44744927c45ba5 100644 --- a/pkgs/by-name/bi/bitwise/package.nix +++ b/pkgs/by-name/bi/bitwise/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, ncurses, readline, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + readline, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "bitwise"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-x+ky1X0c0bQZnkNvNNuXN2BoMDtDSCt/8dBAG92jCCQ="; }; - buildInputs = [ ncurses readline ]; + buildInputs = [ + ncurses + readline + ]; nativeBuildInputs = [ autoreconfHook ]; meta = with lib; { diff --git a/pkgs/by-name/bi/bitwuzla/package.nix b/pkgs/by-name/bi/bitwuzla/package.nix index 3c56fbde4d454e..2f797610eae6c4 100644 --- a/pkgs/by-name/bi/bitwuzla/package.nix +++ b/pkgs/by-name/bi/bitwuzla/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, fetchFromGitHub -, lib -, python3 -, meson -, ninja -, git -, btor2tools -, symfpu -, gtest -, gmp -, cadical -, cryptominisat -, zlib -, pkg-config +{ + stdenv, + fetchFromGitHub, + lib, + python3, + meson, + ninja, + git, + btor2tools, + symfpu, + gtest, + gmp, + cadical, + cryptominisat, + zlib, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { @@ -28,7 +29,12 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - nativeBuildInputs = [ meson pkg-config git ninja ]; + nativeBuildInputs = [ + meson + pkg-config + git + ninja + ]; buildInputs = [ cadical cryptominisat diff --git a/pkgs/by-name/bj/bjumblr/package.nix b/pkgs/by-name/bj/bjumblr/package.nix index 5e3919e04d347b..af4c7d0d64075d 100644 --- a/pkgs/by-name/bj/bjumblr/package.nix +++ b/pkgs/by-name/bj/bjumblr/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, libX11, cairo, lv2, pkg-config, libsndfile }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + cairo, + lv2, + pkg-config, + libsndfile, +}: stdenv.mkDerivation rec { pname = "bjumblr"; @@ -13,7 +22,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - libX11 cairo lv2 libsndfile + libX11 + cairo + lv2 + libsndfile ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/bk/bk/package.nix b/pkgs/by-name/bk/bk/package.nix index 0fbd1a779dd0cd..1e12d4403a449f 100644 --- a/pkgs/by-name/bk/bk/package.nix +++ b/pkgs/by-name/bk/bk/package.nix @@ -1,8 +1,9 @@ -{ fetchCrate -, go-md2man -, installShellFiles -, lib -, rustPlatform +{ + fetchCrate, + go-md2man, + installShellFiles, + lib, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -16,7 +17,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-pE5loMwNMdHL3GODiw3kVVHj374hf3+vIDEYTqvx5WI="; - nativeBuildInputs = [ go-md2man installShellFiles ]; + nativeBuildInputs = [ + go-md2man + installShellFiles + ]; postBuild = '' sed -i '$ a # Source and further info' README.md diff --git a/pkgs/by-name/bk/bkcrack/package.nix b/pkgs/by-name/bk/bkcrack/package.nix index 1af16ffe14dff0..3dd3bb22d926a0 100644 --- a/pkgs/by-name/bk/bkcrack/package.nix +++ b/pkgs/by-name/bk/bkcrack/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + nix-update-script, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/bk/bklk/package.nix b/pkgs/by-name/bk/bklk/package.nix index a62eed5f8e1bc8..3fe7397f359807 100644 --- a/pkgs/by-name/bk/bklk/package.nix +++ b/pkgs/by-name/bk/bklk/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { pname = "bklk"; diff --git a/pkgs/by-name/bk/bkt/package.nix b/pkgs/by-name/bk/bkt/package.nix index 5f6053ec9de969..e9a27eebb2d112 100644 --- a/pkgs/by-name/bk/bkt/package.nix +++ b/pkgs/by-name/bk/bkt/package.nix @@ -1,7 +1,9 @@ -{ rustPlatform -, fetchFromGitHub -, lib -}: rustPlatform.buildRustPackage rec { +{ + rustPlatform, + fetchFromGitHub, + lib, +}: +rustPlatform.buildRustPackage rec { pname = "bkt"; version = "0.8.0"; diff --git a/pkgs/by-name/bk/bkyml/package.nix b/pkgs/by-name/bk/bkyml/package.nix index cfd996f6089130..01135cb948403e 100644 --- a/pkgs/by-name/bk/bkyml/package.nix +++ b/pkgs/by-name/bk/bkyml/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: with python3.pkgs; diff --git a/pkgs/by-name/bl/blackbird/package.nix b/pkgs/by-name/bl/blackbird/package.nix index a3f481b6d4eeca..56c3d1a104489f 100644 --- a/pkgs/by-name/bl/blackbird/package.nix +++ b/pkgs/by-name/bl/blackbird/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gtk-engine-murrine, +}: stdenv.mkDerivation rec { pname = "Blackbird"; @@ -18,7 +24,10 @@ stdenv.mkDerivation rec { meta = { description = "Dark Desktop Suite for Gtk, Xfce and Metacity"; homepage = "https://github.com/shimmerproject/Blackbird"; - license = with lib.licenses; [ gpl2Plus cc-by-nc-sa-30 ]; + license = with lib.licenses; [ + gpl2Plus + cc-by-nc-sa-30 + ]; platforms = lib.platforms.linux; maintainers = [ lib.maintainers.romildo ]; }; diff --git a/pkgs/by-name/bl/blackbox-terminal/marble.nix b/pkgs/by-name/bl/blackbox-terminal/marble.nix index e6c3850416f63c..01a3f2362814dd 100644 --- a/pkgs/by-name/bl/blackbox-terminal/marble.nix +++ b/pkgs/by-name/bl/blackbox-terminal/marble.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, vala -, gobject-introspection -, gtk4 -, gtk3 -, desktop-file-utils +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + vala, + gobject-introspection, + gtk4, + gtk3, + desktop-file-utils, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/bl/blackbox-terminal/package.nix b/pkgs/by-name/bl/blackbox-terminal/package.nix index c1323a89c031d1..23bb6bb4bde54d 100644 --- a/pkgs/by-name/bl/blackbox-terminal/package.nix +++ b/pkgs/by-name/bl/blackbox-terminal/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, meson -, ninja -, pkg-config -, vala -, gtk4 -, vte-gtk4 -, json-glib -, sassc -, libadwaita -, pcre2 -, libsixel -, libxml2 -, librsvg -, libgee -, callPackage -, python3 -, desktop-file-utils -, wrapGAppsHook4 -, sixelSupport ? false +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + meson, + ninja, + pkg-config, + vala, + gtk4, + vte-gtk4, + json-glib, + sassc, + libadwaita, + pcre2, + libsixel, + libxml2, + librsvg, + libgee, + callPackage, + python3, + desktop-file-utils, + wrapGAppsHook4, + sixelSupport ? false, }: let @@ -72,22 +73,28 @@ stdenv.mkDerivation rec { ]; buildInputs = [ gtk4 - (vte-gtk4.overrideAttrs (old: { - src = fetchFromGitLab { - domain = "gitlab.gnome.org"; - owner = "GNOME"; - repo = "vte"; - rev = "3c8f66be867aca6656e4109ce880b6ea7431b895"; - hash = "sha256-vz9ircmPy2Q4fxNnjurkgJtuTSS49rBq/m61p1B43eU="; - }; - patches = lib.optional (old ? patches) (lib.head old.patches); - postPatch = (old.postPatch or "") + '' - patchShebangs src/box_drawing_generate.sh - ''; - } // lib.optionalAttrs sixelSupport { - buildInputs = old.buildInputs ++ [ libsixel ]; - mesonFlags = old.mesonFlags ++ [ "-Dsixel=true" ]; - })) + (vte-gtk4.overrideAttrs ( + old: + { + src = fetchFromGitLab { + domain = "gitlab.gnome.org"; + owner = "GNOME"; + repo = "vte"; + rev = "3c8f66be867aca6656e4109ce880b6ea7431b895"; + hash = "sha256-vz9ircmPy2Q4fxNnjurkgJtuTSS49rBq/m61p1B43eU="; + }; + patches = lib.optional (old ? patches) (lib.head old.patches); + postPatch = + (old.postPatch or "") + + '' + patchShebangs src/box_drawing_generate.sh + ''; + } + // lib.optionalAttrs sixelSupport { + buildInputs = old.buildInputs ++ [ libsixel ]; + mesonFlags = old.mesonFlags ++ [ "-Dsixel=true" ]; + } + )) json-glib marble libadwaita @@ -105,7 +112,10 @@ stdenv.mkDerivation rec { homepage = "https://gitlab.gnome.org/raggesilver/blackbox"; changelog = "https://gitlab.gnome.org/raggesilver/blackbox/-/raw/v${version}/CHANGELOG.md"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ chuangzhu linsui ]; + maintainers = with maintainers; [ + chuangzhu + linsui + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/bl/blackmagic-desktop-video/package.nix b/pkgs/by-name/bl/blackmagic-desktop-video/package.nix index 8888ba83a8c3dc..55cbe53320899e 100644 --- a/pkgs/by-name/bl/blackmagic-desktop-video/package.nix +++ b/pkgs/by-name/bl/blackmagic-desktop-video/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, cacert -, curl -, runCommandLocal -, lib -, autoPatchelfHook -, libcxx -, libGL -, gcc +{ + stdenv, + cacert, + curl, + runCommandLocal, + lib, + autoPatchelfHook, + libcxx, + libGL, + gcc, }: stdenv.mkDerivation (finalAttrs: { pname = "blackmagic-desktop-video"; @@ -58,21 +59,22 @@ stdenv.mkDerivation (finalAttrs: { "policy" = true; }; - } '' - RESOLVEURL=$(curl \ - -s \ - -H "$USERAGENT" \ - -H 'Content-Type: application/json;charset=UTF-8' \ - -H "Referer: https://www.blackmagicdesign.com/support/download/$REFERID/Linux" \ - --data-ascii "$REQJSON" \ - --compressed \ - "$SITEURL") - curl \ - --retry 3 --retry-delay 3 \ - --compressed \ - "$RESOLVEURL" \ - > $out - ''; + } + '' + RESOLVEURL=$(curl \ + -s \ + -H "$USERAGENT" \ + -H 'Content-Type: application/json;charset=UTF-8' \ + -H "Referer: https://www.blackmagicdesign.com/support/download/$REFERID/Linux" \ + --data-ascii "$REQJSON" \ + --compressed \ + "$SITEURL") + curl \ + --retry 3 --retry-delay 3 \ + --compressed \ + "$RESOLVEURL" \ + > $out + ''; postUnpack = let diff --git a/pkgs/by-name/bl/blackmagic/package.nix b/pkgs/by-name/bl/blackmagic/package.nix index bb09ade35f2ffc..de9749036feae2 100644 --- a/pkgs/by-name/bl/blackmagic/package.nix +++ b/pkgs/by-name/bl/blackmagic/package.nix @@ -1,11 +1,13 @@ -{ stdenv, lib -, fetchFromGitHub -, gcc-arm-embedded -, pkg-config -, python3 -, hidapi -, libftdi1 -, libusb1 +{ + stdenv, + lib, + fetchFromGitHub, + gcc-arm-embedded, + pkg-config, + python3, + hidapi, + libftdi1, + libusb1, }: stdenv.mkDerivation rec { @@ -73,7 +75,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://github.com/blacksphere/blackmagic"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ pjones sorki ]; + maintainers = with maintainers; [ + pjones + sorki + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/bl/blackout/package.nix b/pkgs/by-name/bl/blackout/package.nix index ecd3fcbc24548e..1fa0f8e704f2b7 100644 --- a/pkgs/by-name/bl/blackout/package.nix +++ b/pkgs/by-name/bl/blackout/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, +}: stdenvNoCC.mkDerivation { pname = "blackout"; diff --git a/pkgs/by-name/bl/blackshades/package.nix b/pkgs/by-name/bl/blackshades/package.nix index a8467dc167c466..acdc2e38584932 100644 --- a/pkgs/by-name/bl/blackshades/package.nix +++ b/pkgs/by-name/bl/blackshades/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromSourcehut -, glfw -, libGL -, libGLU -, libsndfile -, openal -, zig_0_11 +{ + lib, + stdenv, + fetchFromSourcehut, + glfw, + libGL, + libGLU, + libsndfile, + openal, + zig_0_11, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/bl/blahaj/package.nix b/pkgs/by-name/bl/blahaj/package.nix index a37d37bf418434..258da854cfb883 100644 --- a/pkgs/by-name/bl/blahaj/package.nix +++ b/pkgs/by-name/bl/blahaj/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, crystal -, fetchFromGitHub +{ + lib, + stdenv, + crystal, + fetchFromGitHub, # https://crystal-lang.org/2019/09/06/parallelism-in-crystal/ -, multithreading ? true -, static ? stdenv.hostPlatform.isStatic + multithreading ? true, + static ? stdenv.hostPlatform.isStatic, }: crystal.buildCrystalPackage rec { @@ -24,7 +25,10 @@ crystal.buildCrystalPackage rec { description = "Gay sharks at your local terminal - lolcat-like CLI tool"; homepage = "https://blahaj.queer.software"; license = licenses.bsd2; - maintainers = with maintainers; [ aleksana cafkafk ]; + maintainers = with maintainers; [ + aleksana + cafkafk + ]; mainProgram = "blahaj"; }; } diff --git a/pkgs/by-name/bl/blahtexml/package.nix b/pkgs/by-name/bl/blahtexml/package.nix index 8f4b1980d31325..a17992b13601df 100644 --- a/pkgs/by-name/bl/blahtexml/package.nix +++ b/pkgs/by-name/bl/blahtexml/package.nix @@ -1,4 +1,11 @@ -{ fetchFromGitHub, lib, stdenv, libiconv, texliveFull, xercesc }: +{ + fetchFromGitHub, + lib, + stdenv, + libiconv, + texliveFull, + xercesc, +}: stdenv.mkDerivation rec { pname = "blahtexml"; @@ -11,26 +18,40 @@ stdenv.mkDerivation rec { hash = "sha256-DL5DyfARHHbwWBVHSa/VwHzNaAx/v7EDdnw1GLOk+y0="; }; - postPatch = lib.optionalString stdenv.cc.isClang '' - substituteInPlace makefile \ - --replace "\$(CXX)" "\$(CXX) -std=c++98" - '' + - # fix the doc build on TeX Live 2023 - '' - substituteInPlace Documentation/manual.tex \ - --replace '\usepackage[utf8x]{inputenc}' '\usepackage[utf8]{inputenc}' - ''; + postPatch = + lib.optionalString stdenv.cc.isClang '' + substituteInPlace makefile \ + --replace "\$(CXX)" "\$(CXX) -std=c++98" + '' + + + # fix the doc build on TeX Live 2023 + '' + substituteInPlace Documentation/manual.tex \ + --replace '\usepackage[utf8x]{inputenc}' '\usepackage[utf8]{inputenc}' + ''; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; nativeBuildInputs = [ texliveFull ]; # scheme-full needed for ucs package buildInputs = [ xercesc ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; buildFlags = - [ "doc" ] ++ - (if stdenv.hostPlatform.isDarwin - then [ "blahtex-mac" "blahtexml-mac" ] - else [ "blahtex-linux" "blahtexml-linux" ]); + [ "doc" ] + ++ ( + if stdenv.hostPlatform.isDarwin then + [ + "blahtex-mac" + "blahtexml-mac" + ] + else + [ + "blahtex-linux" + "blahtexml-linux" + ] + ); installPhase = '' install -D -t "$out/bin" blahtex blahtexml diff --git a/pkgs/by-name/bl/blas-reference/package.nix b/pkgs/by-name/bl/blas-reference/package.nix index fcb78767678eab..155e23add19665 100644 --- a/pkgs/by-name/bl/blas-reference/package.nix +++ b/pkgs/by-name/bl/blas-reference/package.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, fetchurl, cmake, gfortran -# Whether to build with ILP64 interface -, blas64 ? false +{ + lib, + stdenv, + fetchurl, + cmake, + gfortran, + # Whether to build with ILP64 interface + blas64 ? false, }: stdenv.mkDerivation rec { @@ -14,18 +19,24 @@ stdenv.mkDerivation rec { passthru = { inherit blas64; }; - nativeBuildInputs = [ cmake gfortran ]; - - cmakeFlags = [ "-DBUILD_SHARED_LIBS=ON" ] - ++ lib.optional blas64 "-DBUILD_INDEX64=ON"; - - postInstall = let - canonicalExtension = if stdenv.hostPlatform.isLinux - then "${stdenv.hostPlatform.extensions.sharedLibrary}.${lib.versions.major version}" - else stdenv.hostPlatform.extensions.sharedLibrary; - in lib.optionalString blas64 '' - ln -s $out/lib/libblas64${canonicalExtension} $out/lib/libblas${canonicalExtension} - ''; + nativeBuildInputs = [ + cmake + gfortran + ]; + + cmakeFlags = [ "-DBUILD_SHARED_LIBS=ON" ] ++ lib.optional blas64 "-DBUILD_INDEX64=ON"; + + postInstall = + let + canonicalExtension = + if stdenv.hostPlatform.isLinux then + "${stdenv.hostPlatform.extensions.sharedLibrary}.${lib.versions.major version}" + else + stdenv.hostPlatform.extensions.sharedLibrary; + in + lib.optionalString blas64 '' + ln -s $out/lib/libblas64${canonicalExtension} $out/lib/libblas${canonicalExtension} + ''; preFixup = lib.optionalString stdenv.hostPlatform.isDarwin '' for fn in $(find $out/lib -name "*.so*"); do diff --git a/pkgs/by-name/bl/blas/package.nix b/pkgs/by-name/bl/blas/package.nix index 91001bc85377a2..0372753c8ef420 100644 --- a/pkgs/by-name/bl/blas/package.nix +++ b/pkgs/by-name/bl/blas/package.nix @@ -1,40 +1,177 @@ -{ lib, stdenv -, lapack-reference, openblas -, isILP64 ? false -, blasProvider ? openblas }: +{ + lib, + stdenv, + lapack-reference, + openblas, + isILP64 ? false, + blasProvider ? openblas, +}: let blasFortranSymbols = [ - "caxpy" "ccopy" "cdotc" "cdotu" "cgbmv" "cgemm" "cgemv" "cgerc" "cgeru" - "chbmv" "chemm" "chemv" "cher" "cher2" "cher2k" "cherk" "chpmv" "chpr" - "chpr2" "crotg" "cscal" "csrot" "csscal" "cswap" "csymm" "csyr2k" "csyrk" - "ctbmv" "ctbsv" "ctpmv" "ctpsv" "ctrmm" "ctrmv" "ctrsm" "ctrsv" "dasum" - "daxpy" "dcabs1" "dcopy" "ddot" "dgbmv" "dgemm" "dgemv" "dger" "dnrm2" - "drot" "drotg" "drotm" "drotmg" "dsbmv" "dscal" "dsdot" "dspmv" "dspr" - "dspr2" "dswap" "dsymm" "dsymv" "dsyr" "dsyr2" "dsyr2k" "dsyrk" "dtbmv" - "dtbsv" "dtpmv" "dtpsv" "dtrmm" "dtrmv" "dtrsm" "dtrsv" "dzasum" "dznrm2" - "icamax" "idamax" "isamax" "izamax" "lsame" "sasum" "saxpy" "scabs1" - "scasum" "scnrm2" "scopy" "sdot" "sdsdot" "sgbmv" "sgemm" "sgemv" - "sger" "snrm2" "srot" "srotg" "srotm" "srotmg" "ssbmv" "sscal" "sspmv" - "sspr" "sspr2" "sswap" "ssymm" "ssymv" "ssyr" "ssyr2" "ssyr2k" "ssyrk" - "stbmv" "stbsv" "stpmv" "stpsv" "strmm" "strmv" "strsm" "strsv" "xerbla" - "xerbla_array" "zaxpy" "zcopy" "zdotc" "zdotu" "zdrot" "zdscal" "zgbmv" - "zgemm" "zgemv" "zgerc" "zgeru" "zhbmv" "zhemm" "zhemv" "zher" "zher2" - "zher2k" "zherk" "zhpmv" "zhpr" "zhpr2" "zrotg" "zscal" "zswap" "zsymm" - "zsyr2k" "zsyrk" "ztbmv" "ztbsv" "ztpmv" "ztpsv" "ztrmm" "ztrmv" "ztrsm" + "caxpy" + "ccopy" + "cdotc" + "cdotu" + "cgbmv" + "cgemm" + "cgemv" + "cgerc" + "cgeru" + "chbmv" + "chemm" + "chemv" + "cher" + "cher2" + "cher2k" + "cherk" + "chpmv" + "chpr" + "chpr2" + "crotg" + "cscal" + "csrot" + "csscal" + "cswap" + "csymm" + "csyr2k" + "csyrk" + "ctbmv" + "ctbsv" + "ctpmv" + "ctpsv" + "ctrmm" + "ctrmv" + "ctrsm" + "ctrsv" + "dasum" + "daxpy" + "dcabs1" + "dcopy" + "ddot" + "dgbmv" + "dgemm" + "dgemv" + "dger" + "dnrm2" + "drot" + "drotg" + "drotm" + "drotmg" + "dsbmv" + "dscal" + "dsdot" + "dspmv" + "dspr" + "dspr2" + "dswap" + "dsymm" + "dsymv" + "dsyr" + "dsyr2" + "dsyr2k" + "dsyrk" + "dtbmv" + "dtbsv" + "dtpmv" + "dtpsv" + "dtrmm" + "dtrmv" + "dtrsm" + "dtrsv" + "dzasum" + "dznrm2" + "icamax" + "idamax" + "isamax" + "izamax" + "lsame" + "sasum" + "saxpy" + "scabs1" + "scasum" + "scnrm2" + "scopy" + "sdot" + "sdsdot" + "sgbmv" + "sgemm" + "sgemv" + "sger" + "snrm2" + "srot" + "srotg" + "srotm" + "srotmg" + "ssbmv" + "sscal" + "sspmv" + "sspr" + "sspr2" + "sswap" + "ssymm" + "ssymv" + "ssyr" + "ssyr2" + "ssyr2k" + "ssyrk" + "stbmv" + "stbsv" + "stpmv" + "stpsv" + "strmm" + "strmv" + "strsm" + "strsv" + "xerbla" + "xerbla_array" + "zaxpy" + "zcopy" + "zdotc" + "zdotu" + "zdrot" + "zdscal" + "zgbmv" + "zgemm" + "zgemv" + "zgerc" + "zgeru" + "zhbmv" + "zhemm" + "zhemv" + "zher" + "zher2" + "zher2k" + "zherk" + "zhpmv" + "zhpr" + "zhpr2" + "zrotg" + "zscal" + "zswap" + "zsymm" + "zsyr2k" + "zsyrk" + "ztbmv" + "ztbsv" + "ztpmv" + "ztpsv" + "ztrmm" + "ztrmv" + "ztrsm" "ztrsv" ]; version = "3"; - canonicalExtension = if stdenv.hostPlatform.isLinux - then "${stdenv.hostPlatform.extensions.sharedLibrary}.${version}" - else stdenv.hostPlatform.extensions.sharedLibrary; - + canonicalExtension = + if stdenv.hostPlatform.isLinux then + "${stdenv.hostPlatform.extensions.sharedLibrary}.${version}" + else + stdenv.hostPlatform.extensions.sharedLibrary; blasImplementation = lib.getName blasProvider; - blasProvider' = if blasImplementation == "mkl" - then blasProvider - else blasProvider.override { blas64 = isILP64; }; + blasProvider' = + if blasImplementation == "mkl" then blasProvider else blasProvider.override { blas64 = isILP64; }; in @@ -44,9 +181,12 @@ stdenv.mkDerivation { pname = "blas"; inherit version; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - meta = (blasProvider'.meta or {}) // { + meta = (blasProvider'.meta or { }) // { description = "${lib.getName blasProvider} with just the BLAS C and FORTRAN ABI"; }; @@ -62,82 +202,99 @@ stdenv.mkDerivation { dontPatchELF = true; - installPhase = ('' - mkdir -p $out/lib $dev/include $dev/lib/pkgconfig - - libblas="${lib.getLib blasProvider'}/lib/libblas${canonicalExtension}" - - if ! [ -e "$libblas" ]; then - echo "$libblas does not exist, ${blasProvider'.name} does not provide libblas." - exit 1 - fi - - $NM -an "$libblas" | cut -f3 -d' ' > symbols - for symbol in ${toString blasFortranSymbols}; do - grep -q "^$symbol_$" symbols || { echo "$symbol" was not found in "$libblas"; exit 1; } - done - - cp -L "$libblas" $out/lib/libblas${canonicalExtension} - chmod +w $out/lib/libblas${canonicalExtension} - -'' + (if stdenv.hostPlatform.isElf then '' - patchelf --set-soname libblas${canonicalExtension} $out/lib/libblas${canonicalExtension} - patchelf --set-rpath "$(patchelf --print-rpath $out/lib/libblas${canonicalExtension}):${lib.getLib blasProvider'}/lib" $out/lib/libblas${canonicalExtension} -'' else lib.optionalString (stdenv.hostPlatform.isDarwin) '' - install_name_tool \ - -id $out/lib/libblas${canonicalExtension} \ - -add_rpath ${lib.getLib blasProvider'}/lib \ - $out/lib/libblas${canonicalExtension} -'') + '' - - if [ "$out/lib/libblas${canonicalExtension}" != "$out/lib/libblas${stdenv.hostPlatform.extensions.sharedLibrary}" ]; then - ln -s $out/lib/libblas${canonicalExtension} "$out/lib/libblas${stdenv.hostPlatform.extensions.sharedLibrary}" - fi - - cat < $dev/lib/pkgconfig/blas.pc -Name: blas -Version: ${version} -Description: BLAS FORTRAN implementation -Libs: -L$out/lib -lblas -Cflags: -I$dev/include -EOF - - libcblas="${lib.getLib blasProvider'}/lib/libcblas${canonicalExtension}" - - if ! [ -e "$libcblas" ]; then - echo "$libcblas does not exist, ${blasProvider'.name} does not provide libcblas." - exit 1 - fi - - cp -L "$libcblas" $out/lib/libcblas${canonicalExtension} - chmod +w $out/lib/libcblas${canonicalExtension} - -'' + (if stdenv.hostPlatform.isElf then '' - patchelf --set-soname libcblas${canonicalExtension} $out/lib/libcblas${canonicalExtension} - patchelf --set-rpath "$(patchelf --print-rpath $out/lib/libcblas${canonicalExtension}):${lib.getLib blasProvider'}/lib" $out/lib/libcblas${canonicalExtension} -'' else lib.optionalString stdenv.hostPlatform.isDarwin '' - install_name_tool \ - -id $out/lib/libcblas${canonicalExtension} \ - -add_rpath ${lib.getLib blasProvider'}/lib \ - $out/lib/libcblas${canonicalExtension} -'') + '' - if [ "$out/lib/libcblas${canonicalExtension}" != "$out/lib/libcblas${stdenv.hostPlatform.extensions.sharedLibrary}" ]; then - ln -s $out/lib/libcblas${canonicalExtension} "$out/lib/libcblas${stdenv.hostPlatform.extensions.sharedLibrary}" - fi - - cp ${lib.getDev lapack-reference}/include/cblas{,_mangling}.h $dev/include - - cat < $dev/lib/pkgconfig/cblas.pc -Name: cblas -Version: ${version} -Description: BLAS C implementation -Cflags: -I$dev/include -Libs: -L$out/lib -lcblas -EOF -'' + lib.optionalString (blasImplementation == "mkl") '' - mkdir -p $out/nix-support - echo 'export MKL_INTERFACE_LAYER=${lib.optionalString isILP64 "I"}LP64,GNU' > $out/nix-support/setup-hook - ln -s $out/lib/libblas${canonicalExtension} $out/lib/libmkl_rt${stdenv.hostPlatform.extensions.sharedLibrary} - ln -sf ${blasProvider'}/include/* $dev/include -''); + installPhase = ( + '' + mkdir -p $out/lib $dev/include $dev/lib/pkgconfig + + libblas="${lib.getLib blasProvider'}/lib/libblas${canonicalExtension}" + + if ! [ -e "$libblas" ]; then + echo "$libblas does not exist, ${blasProvider'.name} does not provide libblas." + exit 1 + fi + + $NM -an "$libblas" | cut -f3 -d' ' > symbols + for symbol in ${toString blasFortranSymbols}; do + grep -q "^$symbol_$" symbols || { echo "$symbol" was not found in "$libblas"; exit 1; } + done + + cp -L "$libblas" $out/lib/libblas${canonicalExtension} + chmod +w $out/lib/libblas${canonicalExtension} + + '' + + ( + if stdenv.hostPlatform.isElf then + '' + patchelf --set-soname libblas${canonicalExtension} $out/lib/libblas${canonicalExtension} + patchelf --set-rpath "$(patchelf --print-rpath $out/lib/libblas${canonicalExtension}):${lib.getLib blasProvider'}/lib" $out/lib/libblas${canonicalExtension} + '' + else + lib.optionalString (stdenv.hostPlatform.isDarwin) '' + install_name_tool \ + -id $out/lib/libblas${canonicalExtension} \ + -add_rpath ${lib.getLib blasProvider'}/lib \ + $out/lib/libblas${canonicalExtension} + '' + ) + + '' + + if [ "$out/lib/libblas${canonicalExtension}" != "$out/lib/libblas${stdenv.hostPlatform.extensions.sharedLibrary}" ]; then + ln -s $out/lib/libblas${canonicalExtension} "$out/lib/libblas${stdenv.hostPlatform.extensions.sharedLibrary}" + fi + + cat < $dev/lib/pkgconfig/blas.pc + Name: blas + Version: ${version} + Description: BLAS FORTRAN implementation + Libs: -L$out/lib -lblas + Cflags: -I$dev/include + EOF + + libcblas="${lib.getLib blasProvider'}/lib/libcblas${canonicalExtension}" + + if ! [ -e "$libcblas" ]; then + echo "$libcblas does not exist, ${blasProvider'.name} does not provide libcblas." + exit 1 + fi + + cp -L "$libcblas" $out/lib/libcblas${canonicalExtension} + chmod +w $out/lib/libcblas${canonicalExtension} + + '' + + ( + if stdenv.hostPlatform.isElf then + '' + patchelf --set-soname libcblas${canonicalExtension} $out/lib/libcblas${canonicalExtension} + patchelf --set-rpath "$(patchelf --print-rpath $out/lib/libcblas${canonicalExtension}):${lib.getLib blasProvider'}/lib" $out/lib/libcblas${canonicalExtension} + '' + else + lib.optionalString stdenv.hostPlatform.isDarwin '' + install_name_tool \ + -id $out/lib/libcblas${canonicalExtension} \ + -add_rpath ${lib.getLib blasProvider'}/lib \ + $out/lib/libcblas${canonicalExtension} + '' + ) + + '' + if [ "$out/lib/libcblas${canonicalExtension}" != "$out/lib/libcblas${stdenv.hostPlatform.extensions.sharedLibrary}" ]; then + ln -s $out/lib/libcblas${canonicalExtension} "$out/lib/libcblas${stdenv.hostPlatform.extensions.sharedLibrary}" + fi + + cp ${lib.getDev lapack-reference}/include/cblas{,_mangling}.h $dev/include + + cat < $dev/lib/pkgconfig/cblas.pc + Name: cblas + Version: ${version} + Description: BLAS C implementation + Cflags: -I$dev/include + Libs: -L$out/lib -lcblas + EOF + '' + + lib.optionalString (blasImplementation == "mkl") '' + mkdir -p $out/nix-support + echo 'export MKL_INTERFACE_LAYER=${lib.optionalString isILP64 "I"}LP64,GNU' > $out/nix-support/setup-hook + ln -s $out/lib/libblas${canonicalExtension} $out/lib/libmkl_rt${stdenv.hostPlatform.extensions.sharedLibrary} + ln -sf ${blasProvider'}/include/* $dev/include + '' + ); } diff --git a/pkgs/by-name/bl/blaze/package.nix b/pkgs/by-name/bl/blaze/package.nix index d52176518da993..4a0ecbbdd96560 100644 --- a/pkgs/by-name/bl/blaze/package.nix +++ b/pkgs/by-name/bl/blaze/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromBitbucket -, cmake -, blas -, lapack-reference +{ + lib, + stdenv, + fetchFromBitbucket, + cmake, + blas, + lapack-reference, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/bl/bleachbit/package.nix b/pkgs/by-name/bl/bleachbit/package.nix index 57d55cedbc6843..44290eb6c51f2e 100644 --- a/pkgs/by-name/bl/bleachbit/package.nix +++ b/pkgs/by-name/bl/bleachbit/package.nix @@ -1,12 +1,13 @@ -{ lib -, python3Packages -, fetchurl -, gettext -, gobject-introspection -, wrapGAppsHook3 -, glib -, gtk3 -, libnotify +{ + lib, + python3Packages, + fetchurl, + gettext, + gobject-introspection, + wrapGAppsHook3, + glib, + gtk3, + libnotify, }: python3Packages.buildPythonApplication rec { @@ -64,7 +65,10 @@ python3Packages.buildPythonApplication rec { description = "Program to clean your computer"; longDescription = "BleachBit helps you easily clean your computer to free space and maintain privacy."; license = licenses.gpl3; - maintainers = with maintainers; [ leonardoce mbprtpmnr ]; + maintainers = with maintainers; [ + leonardoce + mbprtpmnr + ]; mainProgram = "bleachbit"; }; } diff --git a/pkgs/by-name/bl/blesh/package.nix b/pkgs/by-name/bl/blesh/package.nix index 88633760fdc05d..2ae1f5914b6699 100644 --- a/pkgs/by-name/bl/blesh/package.nix +++ b/pkgs/by-name/bl/blesh/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, fetchzip -, runtimeShell -, bashInteractive -, glibcLocales +{ + lib, + stdenvNoCC, + fetchzip, + runtimeShell, + bashInteractive, + glibcLocales, }: stdenvNoCC.mkDerivation rec { @@ -18,7 +19,10 @@ stdenvNoCC.mkDerivation rec { dontBuild = true; doCheck = true; - nativeCheckInputs = [ bashInteractive glibcLocales ]; + nativeCheckInputs = [ + bashInteractive + glibcLocales + ]; preCheck = "export LC_ALL=en_US.UTF-8"; installPhase = '' diff --git a/pkgs/by-name/bl/blflash/package.nix b/pkgs/by-name/bl/blflash/package.nix index 36bdca12de8744..f11bd482917619 100644 --- a/pkgs/by-name/bl/blflash/package.nix +++ b/pkgs/by-name/bl/blflash/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "blflash"; @@ -16,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Bl602 serial flasher written in Rust"; homepage = "https://github.com/spacemeowx2/blflash"; - license = with licenses; [ mit asl20 ]; + license = with licenses; [ + mit + asl20 + ]; maintainers = with maintainers; [ _0x4A6F ]; mainProgram = "blflash"; }; diff --git a/pkgs/by-name/bl/blink1-tool/package.nix b/pkgs/by-name/bl/blink1-tool/package.nix index df994593d99b4c..0d52efe9ba1137 100644 --- a/pkgs/by-name/bl/blink1-tool/package.nix +++ b/pkgs/by-name/bl/blink1-tool/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, libusb1 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libusb1, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/bl/blis/package.nix b/pkgs/by-name/bl/blis/package.nix index b31de4b84a70ef..c2a0bf8ac3a42d 100644 --- a/pkgs/by-name/bl/blis/package.nix +++ b/pkgs/by-name/bl/blis/package.nix @@ -1,21 +1,24 @@ -{ lib, stdenv -, fetchFromGitHub -, perl -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + perl, + python3, -# Enable BLAS interface with 64-bit integer width. -, blas64 ? false + # Enable BLAS interface with 64-bit integer width. + blas64 ? false, -# Target architecture. x86_64 builds Intel and AMD kernels. -, withArchitecture ? "x86_64" + # Target architecture. x86_64 builds Intel and AMD kernels. + withArchitecture ? "x86_64", -# Enable OpenMP-based threading. -, withOpenMP ? true + # Enable OpenMP-based threading. + withOpenMP ? true, }: let blasIntSize = if blas64 then "64" else "32"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "blis"; version = "1.0"; @@ -37,10 +40,12 @@ in stdenv.mkDerivation rec { enableParallelBuilding = true; - configureFlags = [ - "--enable-cblas" - "--blas-int-size=${blasIntSize}" - ] ++ lib.optionals withOpenMP [ "--enable-threading=openmp" ] + configureFlags = + [ + "--enable-cblas" + "--blas-int-size=${blasIntSize}" + ] + ++ lib.optionals withOpenMP [ "--enable-threading=openmp" ] ++ [ withArchitecture ]; postPatch = '' diff --git a/pkgs/by-name/bl/bliss/package.nix b/pkgs/by-name/bl/bliss/package.nix index 5673fcc34d959b..a277e257fe3f34 100644 --- a/pkgs/by-name/bl/bliss/package.nix +++ b/pkgs/by-name/bl/bliss/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, unzip, doxygen }: +{ + lib, + stdenv, + fetchurl, + unzip, + doxygen, +}: stdenv.mkDerivation rec { pname = "bliss"; @@ -14,7 +20,10 @@ stdenv.mkDerivation rec { sha256 = "815868d6586bcd49ff3c28e14ccb536d38b2661151088fe08187c13909c5dab0"; }; - nativeBuildInputs = [ unzip doxygen ]; + nativeBuildInputs = [ + unzip + doxygen + ]; preBuild = '' doxygen Doxyfile @@ -33,6 +42,10 @@ stdenv.mkDerivation rec { mainProgram = "bliss"; homepage = "http://www.tcs.hut.fi/Software/bliss/"; license = licenses.lgpl3; - platforms = [ "i686-linux" "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + "aarch64-linux" + ]; }; } diff --git a/pkgs/by-name/bl/blitz/package.nix b/pkgs/by-name/bl/blitz/package.nix index 4351e0ac729cbd..f54c1861deba4c 100644 --- a/pkgs/by-name/bl/blitz/package.nix +++ b/pkgs/by-name/bl/blitz/package.nix @@ -1,23 +1,24 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, gfortran -, texinfo -, python3 -, boost +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + gfortran, + texinfo, + python3, + boost, # Select SIMD alignment width (in bytes) for vectorization. -, simdWidth ? 1 + simdWidth ? 1, # Pad arrays to simdWidth by default? # Note: Only useful if simdWidth > 1 -, enablePadding ? false + enablePadding ? false, # Activate serialization through Boost.Serialize? -, enableSerialization ? true + enableSerialization ? true, # Activate test-suite? # WARNING: Some of the tests require up to 1700MB of memory to compile. -, doCheck ? true + doCheck ? true, }: let @@ -50,12 +51,17 @@ stdenv.mkDerivation rec { texinfo ]; - buildInputs = [ gfortran texinfo boost ]; + buildInputs = [ + gfortran + texinfo + boost + ]; - cmakeFlags = optional enablePadding "-DARRAY_LENGTH_PADDING=ON" + cmakeFlags = + optional enablePadding "-DARRAY_LENGTH_PADDING=ON" ++ optional enableSerialization "-DENABLE_SERIALISATION=ON" ++ optional stdenv.hostPlatform.is64bit "-DBZ_FULLY64BIT=ON"; - # FIXME ++ optional doCheck "-DBUILD_TESTING=ON"; + # FIXME ++ optional doCheck "-DBUILD_TESTING=ON"; # skip broken library name detection ax_boost_user_serialization_lib = lib.optionalString stdenv.hostPlatform.isDarwin "boost_serialization"; @@ -67,7 +73,11 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Fast multi-dimensional array library for C++"; homepage = "https://sourceforge.net/projects/blitz/"; - license = with licenses; [ artistic2 /* or */ bsd3 /* or */ lgpl3Plus ]; + license = with licenses; [ + artistic2 # or + bsd3 # or + lgpl3Plus + ]; platforms = platforms.unix; maintainers = with maintainers; [ ToxicFrog ]; longDescription = '' diff --git a/pkgs/by-name/bl/blktrace/package.nix b/pkgs/by-name/bl/blktrace/package.nix index d1b2376e7bd2d3..d08a341860f4b6 100644 --- a/pkgs/by-name/bl/blktrace/package.nix +++ b/pkgs/by-name/bl/blktrace/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libaio }: +{ + lib, + stdenv, + fetchurl, + libaio, +}: stdenv.mkDerivation rec { pname = "blktrace"; diff --git a/pkgs/by-name/bl/bloat/package.nix b/pkgs/by-name/bl/bloat/package.nix index e4181ceac57559..bfb5b1f1339507 100644 --- a/pkgs/by-name/bl/bloat/package.nix +++ b/pkgs/by-name/bl/bloat/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchgit -, unstableGitUpdater +{ + lib, + buildGoModule, + fetchgit, + unstableGitUpdater, }: buildGoModule { diff --git a/pkgs/by-name/bl/blobby/package.nix b/pkgs/by-name/bl/blobby/package.nix index e4afb474b3a48a..8a3bfbbde3410f 100644 --- a/pkgs/by-name/bl/blobby/package.nix +++ b/pkgs/by-name/bl/blobby/package.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchurl, SDL2, SDL2_image, libGLU, libGL, cmake, physfs, boost, zip, zlib, unzip, pkg-config }: +{ + lib, + stdenv, + fetchurl, + SDL2, + SDL2_image, + libGLU, + libGL, + cmake, + physfs, + boost, + zip, + zlib, + unzip, + pkg-config, +}: stdenv.mkDerivation rec { pname = "blobby-volley"; @@ -9,10 +24,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-NX7lE+adO1D2f8Bj1Ky3lZpf6Il3gX8KqxTMxw2yFLo="; }; - nativeBuildInputs = [ cmake pkg-config zip ]; - buildInputs = [ SDL2 SDL2_image libGLU libGL physfs boost zlib ]; + nativeBuildInputs = [ + cmake + pkg-config + zip + ]; + buildInputs = [ + SDL2 + SDL2_image + libGLU + libGL + physfs + boost + zlib + ]; - preConfigure='' + preConfigure = '' sed -e '1i#include ' -i src/NetworkMessage.cpp ''; diff --git a/pkgs/by-name/bl/blobfuse/package.nix b/pkgs/by-name/bl/blobfuse/package.nix index 2acd137be736da..6ec9a31943f413 100644 --- a/pkgs/by-name/bl/blobfuse/package.nix +++ b/pkgs/by-name/bl/blobfuse/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, fuse3, testers, blobfuse }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fuse3, + testers, + blobfuse, +}: let version = "2.1.2"; @@ -8,7 +15,8 @@ let rev = "blobfuse2-${version}"; sha256 = "sha256-KzpD+6g1WwviydYE0v5pSH35zC41MrPlk5MitwAIgnE="; }; -in buildGoModule { +in +buildGoModule { pname = "blobfuse"; inherit version src; diff --git a/pkgs/by-name/bl/blobwars/package.nix b/pkgs/by-name/bl/blobwars/package.nix index 6c01e8d5a60444..945f90300c5bb7 100644 --- a/pkgs/by-name/bl/blobwars/package.nix +++ b/pkgs/by-name/bl/blobwars/package.nix @@ -1,4 +1,16 @@ -{ stdenv, lib, fetchurl, pkg-config, gettext, SDL2, SDL2_image, SDL2_mixer, SDL2_net, SDL2_ttf, zlib }: +{ + stdenv, + lib, + fetchurl, + pkg-config, + gettext, + SDL2, + SDL2_image, + SDL2_mixer, + SDL2_net, + SDL2_ttf, + zlib, +}: stdenv.mkDerivation rec { pname = "blobwars"; @@ -11,11 +23,24 @@ stdenv.mkDerivation rec { patches = [ ./blobwars-2.00-glibc-2.38.patch ]; - nativeBuildInputs = [ pkg-config gettext ]; - buildInputs = [ SDL2 SDL2_image SDL2_mixer SDL2_net SDL2_ttf zlib ]; + nativeBuildInputs = [ + pkg-config + gettext + ]; + buildInputs = [ + SDL2 + SDL2_image + SDL2_mixer + SDL2_net + SDL2_ttf + zlib + ]; env.NIX_CFLAGS_COMPILE = toString [ "-Wno-error" ]; - makeFlags = [ "PREFIX=$(out)" "RELEASE=1" ]; + makeFlags = [ + "PREFIX=$(out)" + "RELEASE=1" + ]; postInstall = '' install -Dm755 $out/games/blobwars -t $out/bin @@ -30,7 +55,10 @@ stdenv.mkDerivation rec { description = "Platform action game featuring a blob with lots of weapons"; mainProgram = "blobwars"; homepage = "https://www.parallelrealities.co.uk/games/metalBlobSolid/"; - license = with licenses; [ gpl2Plus free ]; + license = with licenses; [ + gpl2Plus + free + ]; maintainers = with maintainers; [ iblech ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/bl/blockhash/package.nix b/pkgs/by-name/bl/blockhash/package.nix index 3638d34dc384e8..aa956b0360fa02 100644 --- a/pkgs/by-name/bl/blockhash/package.nix +++ b/pkgs/by-name/bl/blockhash/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, python3, pkg-config, imagemagick, wafHook }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + pkg-config, + imagemagick, + wafHook, +}: stdenv.mkDerivation rec { pname = "blockhash"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-QoqFTCfWtXIrFF3Yx4NfOa9cSjHtCSKz3k3i0u9Qx9M="; }; - nativeBuildInputs = [ python3 pkg-config wafHook ]; + nativeBuildInputs = [ + python3 + pkg-config + wafHook + ]; buildInputs = [ imagemagick ]; strictDeps = true; diff --git a/pkgs/by-name/bl/blocky/package.nix b/pkgs/by-name/bl/blocky/package.nix index 47ed6a85b8abbc..fdf27dffb6a2b6 100644 --- a/pkgs/by-name/bl/blocky/package.nix +++ b/pkgs/by-name/bl/blocky/package.nix @@ -1,7 +1,8 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, nixosTests +{ + buildGoModule, + fetchFromGitHub, + lib, + nixosTests, }: buildGoModule rec { @@ -21,7 +22,11 @@ buildGoModule rec { vendorHash = "sha256-I4UXTynulsRuu9U8tsLbPQO1MMPfUC5dAZE420sW1sU="; - ldflags = [ "-s" "-w" "-X github.com/0xERR0R/blocky/util.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/0xERR0R/blocky/util.Version=${version}" + ]; passthru.tests = { inherit (nixosTests) blocky; }; diff --git a/pkgs/by-name/bl/blogc/package.nix b/pkgs/by-name/bl/blogc/package.nix index 4360cc6f20a04a..3ab9524c044592 100644 --- a/pkgs/by-name/bl/blogc/package.nix +++ b/pkgs/by-name/bl/blogc/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, ronn, git, cmocka }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + ronn, + git, + cmocka, +}: stdenv.mkDerivation rec { pname = "blogc"; @@ -11,9 +20,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-YAwGgV5Vllz8JlIASbGIkdRzpciQbgPiXl5DjiSEJyE="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ ronn git cmocka ]; + buildInputs = [ + ronn + git + cmocka + ]; configureFlags = [ "--enable-git-receiver" diff --git a/pkgs/by-name/bl/bloodhound/package.nix b/pkgs/by-name/bl/bloodhound/package.nix index f4e67ecacf122d..9987f5f16608db 100644 --- a/pkgs/by-name/bl/bloodhound/package.nix +++ b/pkgs/by-name/bl/bloodhound/package.nix @@ -1,38 +1,39 @@ -{ lib -, stdenv -, fetchzip -, makeWrapper -, alsa-lib -, at-spi2-atk -, at-spi2-core -, atk -, cairo -, cups -, dbus -, expat -, fontconfig -, freetype -, gdk-pixbuf -, glib -, gtk3 -, libGL -, libappindicator-gtk3 -, libdrm -, libnotify -, libpulseaudio -, libuuid -, libxcb -, libxkbcommon -, libxshmfence -, mesa -, nspr -, nss -, pango -, systemd -, udev -, unzip -, xdg-utils -, xorg +{ + lib, + stdenv, + fetchzip, + makeWrapper, + alsa-lib, + at-spi2-atk, + at-spi2-core, + atk, + cairo, + cups, + dbus, + expat, + fontconfig, + freetype, + gdk-pixbuf, + glib, + gtk3, + libGL, + libappindicator-gtk3, + libdrm, + libnotify, + libpulseaudio, + libuuid, + libxcb, + libxkbcommon, + libxshmfence, + mesa, + nspr, + nss, + pango, + systemd, + udev, + unzip, + xdg-utils, + xorg, }: stdenv.mkDerivation (finalAttrs: { pname = "bloodhound"; @@ -91,7 +92,10 @@ stdenv.mkDerivation (finalAttrs: { gtk3 # needed for GSETTINGS_SCHEMAS_PATH ]; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; dontBuild = true; @@ -107,7 +111,7 @@ stdenv.mkDerivation (finalAttrs: { makeWrapper $out/lib/BloodHound/BloodHound $out/bin/BloodHound \ --prefix XDG_DATA_DIRS : $GSETTINGS_SCHEMAS_PATH \ - --suffix PATH : ${lib.makeBinPath [xdg-utils]} \ + --suffix PATH : ${lib.makeBinPath [ xdg-utils ]} \ --append-flags "--in-process-gpu" # fix for sandbox issues runHook postInstall diff --git a/pkgs/by-name/bl/bloomrpc/package.nix b/pkgs/by-name/bl/bloomrpc/package.nix index b2f3dbae4a2561..764b4082990ac0 100644 --- a/pkgs/by-name/bl/bloomrpc/package.nix +++ b/pkgs/by-name/bl/bloomrpc/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools }: +{ + lib, + fetchurl, + appimageTools, +}: let pname = "bloomrpc"; diff --git a/pkgs/by-name/bl/bloop/package.nix b/pkgs/by-name/bl/bloop/package.nix index fd634380491ac3..8a53d1bca9b339 100644 --- a/pkgs/by-name/bl/bloop/package.nix +++ b/pkgs/by-name/bl/bloop/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, fetchurl -, autoPatchelfHook -, installShellFiles -, makeWrapper -, jre -, lib -, zlib +{ + stdenv, + fetchurl, + autoPatchelfHook, + installShellFiles, + makeWrapper, + jre, + lib, + zlib, }: stdenv.mkDerivation rec { @@ -13,10 +14,14 @@ stdenv.mkDerivation rec { version = "2.0.5"; platform = - if stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isx86_64 then "x86_64-pc-linux" - else if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64 then "x86_64-apple-darwin" - else if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 then "aarch64-apple-darwin" - else throw "unsupported platform"; + if stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isx86_64 then + "x86_64-pc-linux" + else if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64 then + "x86_64-apple-darwin" + else if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 then + "aarch64-apple-darwin" + else + throw "unsupported platform"; bloop-bash = fetchurl { url = "https://github.com/scalacenter/bloop/releases/download/v${version}/bash-completions"; @@ -36,16 +41,25 @@ stdenv.mkDerivation rec { bloop-binary = fetchurl rec { url = "https://github.com/scalacenter/bloop/releases/download/v${version}/bloop-${platform}"; sha256 = - if stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isx86_64 then "sha256-COsGPMCsl3hTcw9JOZ6/LnQAhsNCXMvC0sDLqhHrY1o=" - else if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64 then "sha256-oXfdHIvmEtjh+Ohpu8R2VbrR+YbEQKI6l2cYiG/kQnk=" - else if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 then "sha256-+C8uY1TsqCy0Ml7GBovjGN4rAzkTqRSv5M0EI0l2tds=" - else throw "unsupported platform"; + if stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isx86_64 then + "sha256-COsGPMCsl3hTcw9JOZ6/LnQAhsNCXMvC0sDLqhHrY1o=" + else if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64 then + "sha256-oXfdHIvmEtjh+Ohpu8R2VbrR+YbEQKI6l2cYiG/kQnk=" + else if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 then + "sha256-+C8uY1TsqCy0Ml7GBovjGN4rAzkTqRSv5M0EI0l2tds=" + else + throw "unsupported platform"; }; dontUnpack = true; - nativeBuildInputs = [ installShellFiles makeWrapper ] - ++ lib.optional stdenv.hostPlatform.isLinux autoPatchelfHook; - buildInputs = [ (lib.getLib stdenv.cc.cc) zlib ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ] ++ lib.optional stdenv.hostPlatform.isLinux autoPatchelfHook; + buildInputs = [ + (lib.getLib stdenv.cc.cc) + zlib + ]; propagatedBuildInputs = [ jre ]; installPhase = '' @@ -69,7 +83,15 @@ stdenv.mkDerivation rec { license = licenses.asl20; description = "Scala build server and command-line tool to make the compile and test developer workflows fast and productive in a build-tool-agnostic way"; mainProgram = "bloop"; - platforms = [ "x86_64-linux" "x86_64-darwin" "aarch64-darwin" ]; - maintainers = with maintainers; [ agilesteel kubukoz tomahna ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; + maintainers = with maintainers; [ + agilesteel + kubukoz + tomahna + ]; }; } diff --git a/pkgs/by-name/bl/blst/package.nix b/pkgs/by-name/bl/blst/package.nix index 50d080b9bf9108..0148fe0d0a9452 100644 --- a/pkgs/by-name/bl/blst/package.nix +++ b/pkgs/by-name/bl/blst/package.nix @@ -1,6 +1,10 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: -stdenv.mkDerivation ( finalAttrs: { +stdenv.mkDerivation (finalAttrs: { pname = "blst"; version = "0.3.13"; @@ -71,7 +75,10 @@ stdenv.mkDerivation ( finalAttrs: { description = "Multilingual BLS12-381 signature library"; homepage = "https://github.com/supranational/blst"; license = licenses.isc; - maintainers = with maintainers; [ iquerejeta yvan-sraka ]; + maintainers = with maintainers; [ + iquerejeta + yvan-sraka + ]; platforms = platforms.all; }; }) diff --git a/pkgs/by-name/bl/blueberry/package.nix b/pkgs/by-name/bl/blueberry/package.nix index 4bc7736e06edc6..f32e619f56f55b 100644 --- a/pkgs/by-name/bl/blueberry/package.nix +++ b/pkgs/by-name/bl/blueberry/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, bluez-tools -, gnome-bluetooth_1_0 -, gobject-introspection -, libnotify -, pavucontrol -, python3Packages -, util-linux -, wrapGAppsHook3 -, xapp +{ + stdenv, + lib, + fetchFromGitHub, + bluez-tools, + gnome-bluetooth_1_0, + gobject-introspection, + libnotify, + pavucontrol, + python3Packages, + util-linux, + wrapGAppsHook3, + xapp, }: stdenv.mkDerivation rec { @@ -92,6 +93,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/linuxmint/blueberry"; license = licenses.gpl3Plus; platforms = platforms.linux; - maintainers = with maintainers; [ bobby285271 romildo ]; + maintainers = with maintainers; [ + bobby285271 + romildo + ]; }; } diff --git a/pkgs/by-name/bl/bluemail/package.nix b/pkgs/by-name/bl/bluemail/package.nix index 40d861faaf5cd1..0511eba95e0bbb 100644 --- a/pkgs/by-name/bl/bluemail/package.nix +++ b/pkgs/by-name/bl/bluemail/package.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchurl -, dpkg -, autoPatchelfHook -, copyDesktopItems -, pango -, gtk3 -, alsa-lib -, nss -, libXdamage -, libdrm -, mesa -, libxshmfence -, makeDesktopItem -, makeWrapper -, wrapGAppsHook3 -, gcc-unwrapped -, udev +{ + stdenv, + lib, + fetchurl, + dpkg, + autoPatchelfHook, + copyDesktopItems, + pango, + gtk3, + alsa-lib, + nss, + libXdamage, + libdrm, + mesa, + libxshmfence, + makeDesktopItem, + makeWrapper, + wrapGAppsHook3, + gcc-unwrapped, + udev, }: stdenv.mkDerivation rec { @@ -39,7 +40,10 @@ stdenv.mkDerivation rec { desktopName = "BlueMail"; comment = meta.description; genericName = "Email Reader"; - mimeTypes = [ "x-scheme-handler/me.blueone.linux" "x-scheme-handler/mailto" ]; + mimeTypes = [ + "x-scheme-handler/me.blueone.linux" + "x-scheme-handler/mailto" + ]; categories = [ "Office" ]; }) ]; @@ -82,7 +86,13 @@ stdenv.mkDerivation rec { ''; makeWrapperArgs = [ - "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ gcc-unwrapped.lib gtk3 udev ]}" + "--prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + gcc-unwrapped.lib + gtk3 + udev + ] + }" "--prefix PATH : ${lib.makeBinPath [ stdenv.cc ]}" ]; diff --git a/pkgs/by-name/bl/blueman/package.nix b/pkgs/by-name/bl/blueman/package.nix index effde184d1f84a..47832d528d7ca2 100644 --- a/pkgs/by-name/bl/blueman/package.nix +++ b/pkgs/by-name/bl/blueman/package.nix @@ -1,12 +1,32 @@ -{ config, stdenv, lib, fetchurl, intltool, pkg-config, python3Packages, bluez, gtk3 -, obex_data_server, xdg-utils, dnsmasq, dhcpcd, iproute2 -, adwaita-icon-theme, librsvg, wrapGAppsHook3, gobject-introspection -, networkmanager, withPulseAudio ? config.pulseaudio or stdenv.hostPlatform.isLinux, libpulseaudio }: +{ + config, + stdenv, + lib, + fetchurl, + intltool, + pkg-config, + python3Packages, + bluez, + gtk3, + obex_data_server, + xdg-utils, + dnsmasq, + dhcpcd, + iproute2, + adwaita-icon-theme, + librsvg, + wrapGAppsHook3, + gobject-introspection, + networkmanager, + withPulseAudio ? config.pulseaudio or stdenv.hostPlatform.isLinux, + libpulseaudio, +}: let pythonPackages = python3Packages; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "blueman"; version = "2.4.3"; @@ -16,20 +36,34 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ - gobject-introspection intltool pkg-config pythonPackages.cython - pythonPackages.wrapPython wrapGAppsHook3 + gobject-introspection + intltool + pkg-config + pythonPackages.cython + pythonPackages.wrapPython + wrapGAppsHook3 ]; - buildInputs = [ bluez gtk3 pythonPackages.python librsvg - adwaita-icon-theme networkmanager ] - ++ pythonPath - ++ lib.optional withPulseAudio libpulseaudio; + buildInputs = + [ + bluez + gtk3 + pythonPackages.python + librsvg + adwaita-icon-theme + networkmanager + ] + ++ pythonPath + ++ lib.optional withPulseAudio libpulseaudio; postPatch = lib.optionalString withPulseAudio '' sed -i 's,CDLL(",CDLL("${libpulseaudio.out}/lib/,g' blueman/main/PulseAudioUtils.py ''; - pythonPath = with pythonPackages; [ pygobject3 pycairo ]; + pythonPath = with pythonPackages; [ + pygobject3 + pycairo + ]; propagatedUserEnvPkgs = [ obex_data_server ]; @@ -42,7 +76,13 @@ in stdenv.mkDerivation rec { ]; makeWrapperArgs = [ - "--prefix PATH ':' ${lib.makeBinPath [ dnsmasq dhcpcd iproute2 ]}" + "--prefix PATH ':' ${ + lib.makeBinPath [ + dnsmasq + dhcpcd + iproute2 + ] + }" "--suffix PATH ':' ${lib.makeBinPath [ xdg-utils ]}" ]; diff --git a/pkgs/by-name/bl/bluemix-cli/package.nix b/pkgs/by-name/bl/bluemix-cli/package.nix index ebfcd17064ed23..38e715c0f3d6f2 100644 --- a/pkgs/by-name/bl/bluemix-cli/package.nix +++ b/pkgs/by-name/bl/bluemix-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "bluemix-cli"; @@ -16,8 +20,7 @@ stdenv.mkDerivation rec { name = "linux64-${version}.tar.gz"; url = "https://clis.ng.bluemix.net/download/bluemix-cli/${version}/linux64"; sha256 = "056zbaca430ldcn0s86vy40m5abvwpfrmvqybbr6fjwfv9zngywx"; - } - ; + }; installPhase = '' install -m755 -D -t $out/bin bin/ibmcloud bin/ibmcloud-analytics @@ -29,12 +32,18 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = "Administration CLI for IBM BlueMix"; - homepage = "https://console.bluemix.net/docs/cli/index.html"; + description = "Administration CLI for IBM BlueMix"; + homepage = "https://console.bluemix.net/docs/cli/index.html"; downloadPage = "https://console.bluemix.net/docs/cli/reference/bluemix_cli/download_cli.html#download_install"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.unfree; - maintainers = [ maintainers.tazjin maintainers.jensbin ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + license = licenses.unfree; + maintainers = [ + maintainers.tazjin + maintainers.jensbin + ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/by-name/bl/blueprint-compiler/package.nix b/pkgs/by-name/bl/blueprint-compiler/package.nix index e426503c5487b6..e9b4230b6348a0 100644 --- a/pkgs/by-name/bl/blueprint-compiler/package.nix +++ b/pkgs/by-name/bl/blueprint-compiler/package.nix @@ -1,14 +1,15 @@ -{ dbus -, fetchFromGitLab -, gobject-introspection -, lib -, libadwaita -, meson -, ninja -, python3 -, stdenv -, testers -, xvfb-run +{ + dbus, + fetchFromGitLab, + gobject-introspection, + lib, + libadwaita, + meson, + ninja, + python3, + stdenv, + testers, + xvfb-run, }: stdenv.mkDerivation (finalAttrs: { pname = "blueprint-compiler"; @@ -29,9 +30,11 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ libadwaita - (python3.withPackages (ps: with ps; [ - pygobject3 - ])) + (python3.withPackages ( + ps: with ps; [ + pygobject3 + ] + )) ]; propagatedBuildInputs = [ @@ -45,8 +48,7 @@ stdenv.mkDerivation (finalAttrs: { ]; # requires xvfb-run - doCheck = !stdenv.hostPlatform.isDarwin - && false; # tests time out + doCheck = !stdenv.hostPlatform.isDarwin && false; # tests time out checkPhase = '' runHook preCheck @@ -67,7 +69,10 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "blueprint-compiler"; homepage = "https://gitlab.gnome.org/jwestman/blueprint-compiler"; license = licenses.lgpl3Plus; - maintainers = with maintainers; [ benediktbroich ranfdev ]; + maintainers = with maintainers; [ + benediktbroich + ranfdev + ]; platforms = platforms.unix; }; }) diff --git a/pkgs/by-name/bl/bluespec/package.nix b/pkgs/by-name/bl/bluespec/package.nix index 720dbe84743b6c..3c9f871db9de65 100644 --- a/pkgs/by-name/bl/bluespec/package.nix +++ b/pkgs/by-name/bl/bluespec/package.nix @@ -1,32 +1,42 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchurl -, autoconf -, automake -, fontconfig -, libX11 -, perl -, flex -, bison -, pkg-config -, tcl -, tk -, xorg -, yices # bsc uses a patched version of yices -, zlib -, ghc -, gmp-static -, iverilog -, asciidoctor -, texliveFull -, which +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + autoconf, + automake, + fontconfig, + libX11, + perl, + flex, + bison, + pkg-config, + tcl, + tk, + xorg, + yices, # bsc uses a patched version of yices + zlib, + ghc, + gmp-static, + iverilog, + asciidoctor, + texliveFull, + which, }: let - ghcWithPackages = ghc.withPackages (g: (with g; [ old-time regex-compat syb split ])); - -in stdenv.mkDerivation rec { + ghcWithPackages = ghc.withPackages ( + g: + (with g; [ + old-time + regex-compat + syb + split + ]) + ); + +in +stdenv.mkDerivation rec { pname = "bluespec"; version = "2024.07"; @@ -44,7 +54,10 @@ in stdenv.mkDerivation rec { enableParallelBuilding = true; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; # https://github.com/B-Lang-org/bsc/pull/278 is still applicable, but will probably not be applied as such # there is work ongoing: https://github.com/B-Lang-org/bsc/issues/595 https://github.com/B-Lang-org/bsc/pull/600 @@ -133,6 +146,9 @@ in stdenv.mkDerivation rec { mainProgram = "bsc"; # darwin fails at https://github.com/B-Lang-org/bsc/pull/35#issuecomment-583731562 # aarch64 fails, as GHC fails with "ghc: could not execute: opt" - maintainers = with lib.maintainers; [ jcumming thoughtpolice ]; + maintainers = with lib.maintainers; [ + jcumming + thoughtpolice + ]; }; } diff --git a/pkgs/by-name/bl/bluetility/package.nix b/pkgs/by-name/bl/bluetility/package.nix index 8aadf48b026cf4..7a2241a2f5e105 100644 --- a/pkgs/by-name/bl/bluetility/package.nix +++ b/pkgs/by-name/bl/bluetility/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, unzip +{ + lib, + stdenvNoCC, + fetchurl, + unzip, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/bl/bluewalker/package.nix b/pkgs/by-name/bl/bluewalker/package.nix index 6cc25523d74c64..8f2872f6045bf6 100644 --- a/pkgs/by-name/bl/bluewalker/package.nix +++ b/pkgs/by-name/bl/bluewalker/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitLab }: +{ + lib, + buildGoModule, + fetchFromGitLab, +}: buildGoModule rec { pname = "bluewalker"; diff --git a/pkgs/by-name/bl/bluez-alsa/package.nix b/pkgs/by-name/bl/bluez-alsa/package.nix index eb42c8402cab76..8b144b85c7817e 100644 --- a/pkgs/by-name/bl/bluez-alsa/package.nix +++ b/pkgs/by-name/bl/bluez-alsa/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, aacSupport ? true -, alsa-lib -, autoreconfHook -, bluez -, dbus -, fdk_aac -, fetchFromGitHub -, gitUpdater -, glib -, libbsd -, ncurses -, pkg-config -, readline -, sbc +{ + lib, + stdenv, + aacSupport ? true, + alsa-lib, + autoreconfHook, + bluez, + dbus, + fdk_aac, + fetchFromGitHub, + gitUpdater, + glib, + libbsd, + ncurses, + pkg-config, + readline, + sbc, }: stdenv.mkDerivation (finalAttrs: { @@ -32,18 +33,20 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - alsa-lib - bluez - glib - sbc - dbus - readline - libbsd - ncurses - ] ++ lib.optionals aacSupport [ - fdk_aac - ]; + buildInputs = + [ + alsa-lib + bluez + glib + sbc + dbus + readline + libbsd + ncurses + ] + ++ lib.optionals aacSupport [ + fdk_aac + ]; configureFlags = [ (lib.enableFeature aacSupport "aac") diff --git a/pkgs/by-name/bl/bluez-tools/package.nix b/pkgs/by-name/bl/bluez-tools/package.nix index d6fa89154d93ce..916ad45949b6f2 100644 --- a/pkgs/by-name/bl/bluez-tools/package.nix +++ b/pkgs/by-name/bl/bluez-tools/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, glib -, pkg-config -, readline -, unstableGitUpdater +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + glib, + pkg-config, + readline, + unstableGitUpdater, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/bl/bluez/package.nix b/pkgs/by-name/bl/bluez/package.nix index 4337cd90b5193f..ccdac6ccc0412d 100644 --- a/pkgs/by-name/bl/bluez/package.nix +++ b/pkgs/by-name/bl/bluez/package.nix @@ -1,25 +1,28 @@ -{ lib -, stdenv -, alsa-lib -, dbus -, docutils -, ell -, enableExperimental ? false -, fetchpatch -, fetchurl -, glib -, json_c -, libical -, pkg-config -, python3Packages -, readline -, systemdMinimal -, udev -# Test gobject-introspection instead of pygobject because the latter -# causes an infinite recursion. -, gobject-introspection -, buildPackages -, installTests ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages +{ + lib, + stdenv, + alsa-lib, + dbus, + docutils, + ell, + enableExperimental ? false, + fetchpatch, + fetchurl, + glib, + json_c, + libical, + pkg-config, + python3Packages, + readline, + systemdMinimal, + udev, + # Test gobject-introspection instead of pygobject because the latter + # causes an infinite recursion. + gobject-introspection, + buildPackages, + installTests ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, }: stdenv.mkDerivation (finalAttrs: { @@ -31,21 +34,25 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-gw/tGRXF03W43g9eb0X83qDcxf9f+z0x227Q8A1zxeM="; }; - patches = [ - # Upstream fix is wrong: - # https://github.com/bluez/bluez/issues/843#issuecomment-2352696535 - (fetchurl { - name = "basename.patch"; - url = "https://github.com/void-linux/void-packages/raw/187b45d47d93b6857a95cae10c2132d76e4955fc/srcpkgs/bluez/patches/basename.patch"; - hash = "sha256-Jb4u7rxIShDp1yUgaQVDJo2HJfZBzRoVlcDEWxooFgk="; - }) - ] ++ lib.optional (stdenv.hostPlatform.isMusl && stdenv.hostPlatform.isx86_64) - # Disable one failing test with musl libc, also seen by alpine - # https://github.com/bluez/bluez/issues/726 - (fetchurl { - url = "https://git.alpinelinux.org/aports/plain/main/bluez/disable_aics_unit_testcases.patch?id=8e96f7faf01a45f0ad8449c1cd825db63a8dfd48"; - hash = "sha256-1PJkipqBO3qxxOqRFQKfpWlne1kzTCgtnTFYI1cFQt4="; - }); + patches = + [ + # Upstream fix is wrong: + # https://github.com/bluez/bluez/issues/843#issuecomment-2352696535 + (fetchurl { + name = "basename.patch"; + url = "https://github.com/void-linux/void-packages/raw/187b45d47d93b6857a95cae10c2132d76e4955fc/srcpkgs/bluez/patches/basename.patch"; + hash = "sha256-Jb4u7rxIShDp1yUgaQVDJo2HJfZBzRoVlcDEWxooFgk="; + }) + ] + ++ lib.optional (stdenv.hostPlatform.isMusl && stdenv.hostPlatform.isx86_64) + # Disable one failing test with musl libc, also seen by alpine + # https://github.com/bluez/bluez/issues/726 + ( + fetchurl { + url = "https://git.alpinelinux.org/aports/plain/main/bluez/disable_aics_unit_testcases.patch?id=8e96f7faf01a45f0ad8449c1cd825db63a8dfd48"; + hash = "sha256-1PJkipqBO3qxxOqRFQKfpWlne1kzTCgtnTFYI1cFQt4="; + } + ); buildInputs = [ alsa-lib @@ -66,24 +73,28 @@ stdenv.mkDerivation (finalAttrs: { python3Packages.wrapPython ]; - outputs = [ "out" "dev" ] - ++ lib.optional installTests "test"; - - postPatch = '' - substituteInPlace tools/hid2hci.rules \ - --replace-fail /sbin/udevadm ${systemdMinimal}/bin/udevadm \ - --replace-fail "hid2hci " "$out/lib/udev/hid2hci " - '' + - # Disable some tests: - # - test-mesh-crypto depends on the following kernel settings: - # CONFIG_CRYPTO_[USER|USER_API|USER_API_AEAD|USER_API_HASH|AES|CCM|AEAD|CMAC] - '' - if [[ ! -f unit/test-mesh-crypto.c ]]; then - echo "unit/test-mesh-crypto.c no longer exists" - false - fi - echo 'int main() { return 77; }' > unit/test-mesh-crypto.c - ''; + outputs = [ + "out" + "dev" + ] ++ lib.optional installTests "test"; + + postPatch = + '' + substituteInPlace tools/hid2hci.rules \ + --replace-fail /sbin/udevadm ${systemdMinimal}/bin/udevadm \ + --replace-fail "hid2hci " "$out/lib/udev/hid2hci " + '' + + + # Disable some tests: + # - test-mesh-crypto depends on the following kernel settings: + # CONFIG_CRYPTO_[USER|USER_API|USER_API_AEAD|USER_API_HASH|AES|CCM|AEAD|CMAC] + '' + if [[ ! -f unit/test-mesh-crypto.c ]]; then + echo "unit/test-mesh-crypto.c no longer exists" + false + fi + echo 'int main() { return 77; }' > unit/test-mesh-crypto.c + ''; configureFlags = [ "--localstatedir=/var" @@ -122,49 +133,51 @@ stdenv.mkDerivation (finalAttrs: { doCheck = stdenv.hostPlatform.isx86_64; - postInstall = let - pythonPath = with python3Packages; [ - dbus-python - pygobject3 - ]; - in - '' - # for bluez4 compatibility for NixOS - mkdir $out/sbin - ln -s ../libexec/bluetooth/bluetoothd $out/sbin/bluetoothd - ln -s ../libexec/bluetooth/obexd $out/sbin/obexd - - # Add extra configuration - rm $out/etc/bluetooth/{main,input,network}.conf - ln -s /etc/bluetooth/main.conf $out/etc/bluetooth/main.conf - - # https://github.com/NixOS/nixpkgs/issues/204418 - ln -s /etc/bluetooth/input.conf $out/etc/bluetooth/input.conf - ln -s /etc/bluetooth/network.conf $out/etc/bluetooth/network.conf - - # Add missing tools, ref https://git.archlinux.org/svntogit/packages.git/tree/trunk/PKGBUILD?h=packages/bluez - for files in $(find tools/ -type f -perm -755); do - filename=$(basename $files) - install -Dm755 tools/$filename $out/bin/$filename - done - install -Dm755 attrib/gatttool $out/bin/gatttool - '' + lib.optionalString installTests '' - mkdir -p $test/{bin,test} - cp -a test $test - pushd $test/test - for t in \ - list-devices \ - monitor-bluetooth \ - simple-agent \ - test-adapter \ - test-device \ - test-thermometer \ - ; do - ln -s ../test/$t $test/bin/bluez-$t - done - popd - wrapPythonProgramsIn $test/test "$test/test ${toString pythonPath}" - ''; + postInstall = + let + pythonPath = with python3Packages; [ + dbus-python + pygobject3 + ]; + in + '' + # for bluez4 compatibility for NixOS + mkdir $out/sbin + ln -s ../libexec/bluetooth/bluetoothd $out/sbin/bluetoothd + ln -s ../libexec/bluetooth/obexd $out/sbin/obexd + + # Add extra configuration + rm $out/etc/bluetooth/{main,input,network}.conf + ln -s /etc/bluetooth/main.conf $out/etc/bluetooth/main.conf + + # https://github.com/NixOS/nixpkgs/issues/204418 + ln -s /etc/bluetooth/input.conf $out/etc/bluetooth/input.conf + ln -s /etc/bluetooth/network.conf $out/etc/bluetooth/network.conf + + # Add missing tools, ref https://git.archlinux.org/svntogit/packages.git/tree/trunk/PKGBUILD?h=packages/bluez + for files in $(find tools/ -type f -perm -755); do + filename=$(basename $files) + install -Dm755 tools/$filename $out/bin/$filename + done + install -Dm755 attrib/gatttool $out/bin/gatttool + '' + + lib.optionalString installTests '' + mkdir -p $test/{bin,test} + cp -a test $test + pushd $test/test + for t in \ + list-devices \ + monitor-bluetooth \ + simple-agent \ + test-adapter \ + test-device \ + test-thermometer \ + ; do + ln -s ../test/$t $test/bin/bluez-$t + done + popd + wrapPythonProgramsIn $test/test "$test/test ${toString pythonPath}" + ''; enableParallelBuilding = true; @@ -172,7 +185,12 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.bluez.org/"; description = "Official Linux Bluetooth protocol stack"; changelog = "https://git.kernel.org/pub/scm/bluetooth/bluez.git/tree/ChangeLog?h=${finalAttrs.version}"; - license = with lib.licenses; [ bsd2 gpl2Plus lgpl21Plus mit ]; + license = with lib.licenses; [ + bsd2 + gpl2Plus + lgpl21Plus + mit + ]; mainProgram = "btinfo"; maintainers = with lib.maintainers; [ ]; platforms = lib.platforms.linux; diff --git a/pkgs/by-name/bl/blugon/package.nix b/pkgs/by-name/bl/blugon/package.nix index 5aab73ef1467cc..5f1aa6eb922d1f 100644 --- a/pkgs/by-name/bl/blugon/package.nix +++ b/pkgs/by-name/bl/blugon/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, python3, libX11, libXrandr }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + libX11, + libXrandr, +}: stdenv.mkDerivation rec { pname = "blugon"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "1i67v8jxvavgax3dwvns200iwwdcvgki04liq0x64q52lg0vrh7m"; }; - buildInputs = [ python3 libX11 libXrandr ]; + buildInputs = [ + python3 + libX11 + libXrandr + ]; # Remove at next release # https://github.com/jumper149/blugon/commit/d262cd05 diff --git a/pkgs/by-name/bl/blur-effect/package.nix b/pkgs/by-name/bl/blur-effect/package.nix index cc88bb08894988..4ac0dc55e6dca8 100644 --- a/pkgs/by-name/bl/blur-effect/package.nix +++ b/pkgs/by-name/bl/blur-effect/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, cmake, gdk-pixbuf, libGL, mesa }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + gdk-pixbuf, + libGL, + mesa, +}: stdenv.mkDerivation rec { pname = "blur-effect"; diff --git a/pkgs/by-name/bm/bmaptool/package.nix b/pkgs/by-name/bm/bmaptool/package.nix index dedc16bd23fac2..c97b13d26a3888 100644 --- a/pkgs/by-name/bm/bmaptool/package.nix +++ b/pkgs/by-name/bm/bmaptool/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "bmaptool"; diff --git a/pkgs/by-name/bm/bmon/package.nix b/pkgs/by-name/bm/bmon/package.nix index a123a3380f1bed..9f50559b3817f9 100644 --- a/pkgs/by-name/bm/bmon/package.nix +++ b/pkgs/by-name/bm/bmon/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, pkg-config, ncurses, libconfuse -, libnl }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + ncurses, + libconfuse, + libnl, +}: stdenv.mkDerivation rec { pname = "bmon"; @@ -22,9 +31,15 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ ncurses libconfuse ] ++ lib.optional stdenv.hostPlatform.isLinux libnl; + buildInputs = [ + ncurses + libconfuse + ] ++ lib.optional stdenv.hostPlatform.isLinux libnl; preConfigure = '' # Must be an absolute path @@ -39,7 +54,10 @@ stdenv.mkDerivation rec { # - https://github.com/tgraf/bmon/blob/master/LICENSE.MIT license = licenses.bsd2; platforms = platforms.unix; - maintainers = with maintainers; [ bjornfor pSub ]; + maintainers = with maintainers; [ + bjornfor + pSub + ]; mainProgram = "bmon"; }; } diff --git a/pkgs/by-name/bo/boa/package.nix b/pkgs/by-name/bo/boa/package.nix index 9f695ff7d7939a..3c2e0c188bbd23 100644 --- a/pkgs/by-name/bo/boa/package.nix +++ b/pkgs/by-name/bo/boa/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, fetchpatch -, pkg-config -, bzip2 -, openssl -, zstd -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + fetchpatch, + pkg-config, + bzip2, + openssl, + zstd, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -32,25 +33,37 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-UIUXayJwTrWbLm1UKnIXy1Df8a7ZoBzdNm/uZ1+H+SQ="; - cargoBuildFlags = [ "--package" "boa_cli" ]; + cargoBuildFlags = [ + "--package" + "boa_cli" + ]; nativeBuildInputs = [ pkg-config ]; buildInputs = - [ bzip2 openssl zstd ] + [ + bzip2 + openssl + zstd + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.CoreFoundation darwin.apple_sdk.frameworks.Security ]; - env = { ZSTD_SYS_USE_PKG_CONFIG = true; }; + env = { + ZSTD_SYS_USE_PKG_CONFIG = true; + }; meta = with lib; { description = "Embeddable and experimental Javascript engine written in Rust"; mainProgram = "boa"; homepage = "https://github.com/boa-dev/boa"; changelog = "https://github.com/boa-dev/boa/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ mit /* or */ unlicense ]; + license = with licenses; [ + mit # or + unlicense + ]; maintainers = with maintainers; [ dit7ya ]; }; } diff --git a/pkgs/by-name/bo/boatswain/package.nix b/pkgs/by-name/bo/boatswain/package.nix index fc2842ebe52fc2..c5ee5f941cfab9 100644 --- a/pkgs/by-name/bo/boatswain/package.nix +++ b/pkgs/by-name/bo/boatswain/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, gtk4 -, libgee -, libadwaita -, wrapGAppsHook4 -, appstream-glib -, desktop-file-utils -, libpeas -, libportal-gtk4 -, gusb -, hidapi -, json-glib -, libsecret -, libsoup_3 -, libpeas2 +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + gtk4, + libgee, + libadwaita, + wrapGAppsHook4, + appstream-glib, + desktop-file-utils, + libpeas, + libportal-gtk4, + gusb, + hidapi, + json-glib, + libsecret, + libsoup_3, + libpeas2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/bo/bob/package.nix b/pkgs/by-name/bo/bob/package.nix index ba93433b686261..2b4f0769f68ce3 100644 --- a/pkgs/by-name/bo/bob/package.nix +++ b/pkgs/by-name/bo/bob/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles -, fetchpatch +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, + fetchpatch, }: buildGoModule rec { @@ -26,11 +27,19 @@ buildGoModule rec { }) ]; - ldflags = [ "-s" "-w" "-X main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.Version=${version}" + ]; vendorHash = "sha256-u0nFaTQWU9O7A/RAhGaLcBka+YNGjSlpycDF8TLQALw="; - excludedPackages = [ "example/server-db" "test/e2e" "tui-example" ]; + excludedPackages = [ + "example/server-db" + "test/e2e" + "tui-example" + ]; nativeBuildInputs = [ installShellFiles ]; diff --git a/pkgs/by-name/bo/bobcat/package.nix b/pkgs/by-name/bo/bobcat/package.nix index b873862fe7ed1b..51423f2f38bf9d 100644 --- a/pkgs/by-name/bo/bobcat/package.nix +++ b/pkgs/by-name/bo/bobcat/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitLab -, icmake -, yodl -, libmilter -, libX11 -, openssl -, readline -, util-linux +{ + lib, + stdenv, + fetchFromGitLab, + icmake, + yodl, + libmilter, + libX11, + openssl, + readline, + util-linux, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/bo/boca/package.nix b/pkgs/by-name/bo/boca/package.nix index f0a1f3bc6a775a..93bde7439f4076 100644 --- a/pkgs/by-name/bo/boca/package.nix +++ b/pkgs/by-name/bo/boca/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, -, expat -, libcdio -, libcdio-paranoia -, libpulseaudio -, smooth -, uriparser -, zlib + expat, + libcdio, + libcdio-paranoia, + libpulseaudio, + smooth, + uriparser, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/bo/bodyclose/package.nix b/pkgs/by-name/bo/bodyclose/package.nix index 2665fcafe745e7..ed791e7546c6ce 100644 --- a/pkgs/by-name/bo/bodyclose/package.nix +++ b/pkgs/by-name/bo/bodyclose/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, unstableGitUpdater +{ + lib, + buildGoModule, + fetchFromGitHub, + unstableGitUpdater, }: buildGoModule { @@ -17,9 +18,12 @@ buildGoModule { vendorHash = "sha256-8grdJuV8aSETsJr2VazC/3ctfnGh3UgjOWD4/xf3uC8="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; - passthru.updateScript = unstableGitUpdater {}; + passthru.updateScript = unstableGitUpdater { }; meta = with lib; { description = "Golang linter to check whether HTTP response body is closed and a re-use of TCP connection is not blocked"; diff --git a/pkgs/by-name/bo/boehmgc/package.nix b/pkgs/by-name/bo/boehmgc/package.nix index 35dbf8f7b79eeb..e950ad42f9a3a6 100644 --- a/pkgs/by-name/bo/boehmgc/package.nix +++ b/pkgs/by-name/bo/boehmgc/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -# doc: https://github.com/ivmai/bdwgc/blob/v8.2.8/doc/README.macros (LARGE_CONFIG) -, enableLargeConfig ? false -, enableMmap ? true -, enableStatic ? false -, nixVersions +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + # doc: https://github.com/ivmai/bdwgc/blob/v8.2.8/doc/README.macros (LARGE_CONFIG) + enableLargeConfig ? false, + enableMmap ? true, + enableStatic ? false, + nixVersions, }: stdenv.mkDerivation (finalAttrs: { @@ -20,20 +21,25 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-UQSLK/05uPal6/m+HMz0QwXVII1leonlmtSZsXjJ+/c="; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; separateDebugInfo = stdenv.hostPlatform.isLinux && stdenv.hostPlatform.libc != "musl"; nativeBuildInputs = [ autoreconfHook ]; - configureFlags = [ - "--enable-cplusplus" - "--with-libatomic-ops=none" - ] - ++ lib.optional enableStatic "--enable-static" - ++ lib.optional enableMmap "--enable-mmap" - ++ lib.optional enableLargeConfig "--enable-large-config"; + configureFlags = + [ + "--enable-cplusplus" + "--with-libatomic-ops=none" + ] + ++ lib.optional enableStatic "--enable-static" + ++ lib.optional enableMmap "--enable-mmap" + ++ lib.optional enableLargeConfig "--enable-large-config"; # This stanza can be dropped when a release fixes this issue: # https://github.com/ivmai/bdwgc/issues/376 @@ -41,18 +47,20 @@ stdenv.mkDerivation (finalAttrs: { # don't forget to disable the fix (and if the next release does # not fix the problem the test failure will be a reminder to # extend the set of versions requiring the workaround). - makeFlags = lib.optionals (stdenv.hostPlatform.isPower64 && - finalAttrs.version == "8.2.8") - [ - # do not use /proc primitives to track dirty bits; see: - # https://github.com/ivmai/bdwgc/issues/479#issuecomment-1279687537 - # https://github.com/ivmai/bdwgc/blob/54522af853de28f45195044dadfd795c4e5942aa/include/private/gcconfig.h#L741 - "CFLAGS_EXTRA=-DNO_SOFT_VDB" - ]; + makeFlags = lib.optionals (stdenv.hostPlatform.isPower64 && finalAttrs.version == "8.2.8") [ + # do not use /proc primitives to track dirty bits; see: + # https://github.com/ivmai/bdwgc/issues/479#issuecomment-1279687537 + # https://github.com/ivmai/bdwgc/blob/54522af853de28f45195044dadfd795c4e5942aa/include/private/gcconfig.h#L741 + "CFLAGS_EXTRA=-DNO_SOFT_VDB" + ]; # `gctest` fails under x86_64 emulation on aarch64-darwin # and also on aarch64-linux (qemu-user) - doCheck = !((stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) || (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64)); + doCheck = + !( + (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) + || (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) + ); enableParallelBuilding = true; diff --git a/pkgs/by-name/bo/bogofilter/package.nix b/pkgs/by-name/bo/bogofilter/package.nix index f5fcbc831c898f..e5df341474052b 100644 --- a/pkgs/by-name/bo/bogofilter/package.nix +++ b/pkgs/by-name/bo/bogofilter/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, flex -, db -, makeWrapper -, pax +{ + lib, + stdenv, + fetchurl, + flex, + db, + makeWrapper, + pax, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ flex db ]; + buildInputs = [ + flex + db + ]; doCheck = false; # needs "y" tool diff --git a/pkgs/by-name/bo/boinctui/package.nix b/pkgs/by-name/bo/boinctui/package.nix index eca32ef3773171..b0ff4f34831631 100644 --- a/pkgs/by-name/bo/boinctui/package.nix +++ b/pkgs/by-name/bo/boinctui/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, expat, ncurses, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + expat, + ncurses, + openssl, +}: stdenv.mkDerivation { pname = "boinctui"; @@ -17,14 +25,21 @@ stdenv.mkDerivation { --replace 'DOCDIR = $(DATAROOTDIR)@docdir@' 'DOCDIR = @docdir@' ''; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; separateDebugInfo = stdenv.hostPlatform.isLinux; enableParallelBuilding = true; configureFlags = [ "--without-gnutls" ]; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ expat ncurses openssl ]; + buildInputs = [ + expat + ncurses + openssl + ]; meta = with lib; { description = "Curses based fullscreen BOINC manager"; diff --git a/pkgs/by-name/bo/bolliedelayxt-lv2/package.nix b/pkgs/by-name/bo/bolliedelayxt-lv2/package.nix index 5fd5ec43268b70..25caec2b879a99 100644 --- a/pkgs/by-name/bo/bolliedelayxt-lv2/package.nix +++ b/pkgs/by-name/bo/bolliedelayxt-lv2/package.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + lv2, +}: -stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "bolliedelayxt.lv2"; version = "unstable-2017-11-02"; diff --git a/pkgs/by-name/bo/bolt/package.nix b/pkgs/by-name/bo/bolt/package.nix index 11973ba5a57084..c63df50bf2f95d 100644 --- a/pkgs/by-name/bo/bolt/package.nix +++ b/pkgs/by-name/bo/bolt/package.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, meson -, ninja -, pkg-config -, fetchFromGitLab -, fetchpatch -, python3 -, umockdev -, gobject-introspection -, dbus -, asciidoc -, libxml2 -, libxslt -, docbook_xml_dtd_45 -, docbook-xsl-nons -, glib -, systemd -, polkit +{ + stdenv, + lib, + meson, + ninja, + pkg-config, + fetchFromGitLab, + fetchpatch, + python3, + umockdev, + gobject-introspection, + dbus, + asciidoc, + libxml2, + libxslt, + docbook_xml_dtd_45, + docbook-xsl-nons, + glib, + systemd, + polkit, }: stdenv.mkDerivation rec { @@ -76,8 +77,11 @@ stdenv.mkDerivation rec { dbus gobject-introspection umockdev - (python3.pythonOnBuildForHost.withPackages - (p: [ p.pygobject3 p.dbus-python p.python-dbusmock ])) + (python3.pythonOnBuildForHost.withPackages (p: [ + p.pygobject3 + p.dbus-python + p.python-dbusmock + ])) ]; postPatch = '' diff --git a/pkgs/by-name/bo/boltbrowser/package.nix b/pkgs/by-name/bo/boltbrowser/package.nix index f4603ab3b4adb9..48c6c3eb93eb13 100644 --- a/pkgs/by-name/bo/boltbrowser/package.nix +++ b/pkgs/by-name/bo/boltbrowser/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/bo/bom/package.nix b/pkgs/by-name/bo/bom/package.nix index 0cdc4f6ec6e44d..9a057938d52542 100644 --- a/pkgs/by-name/bo/bom/package.nix +++ b/pkgs/by-name/bo/bom/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/bo/bombadillo/package.nix b/pkgs/by-name/bo/bombadillo/package.nix index bd39100aab38bf..74ae6582393968 100644 --- a/pkgs/by-name/bo/bombadillo/package.nix +++ b/pkgs/by-name/bo/bombadillo/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchgit, buildGoModule, installShellFiles }: +{ + lib, + fetchgit, + buildGoModule, + installShellFiles, +}: buildGoModule rec { pname = "bombadillo"; @@ -14,7 +19,10 @@ buildGoModule rec { vendorHash = null; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; postInstall = '' installManPage bombadillo.1 diff --git a/pkgs/by-name/bo/bombardier/package.nix b/pkgs/by-name/bo/bombardier/package.nix index 89f20860836c9a..9c7a1f26736c50 100644 --- a/pkgs/by-name/bo/bombardier/package.nix +++ b/pkgs/by-name/bo/bombardier/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, bombardier +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + bombardier, }: buildGoModule rec { diff --git a/pkgs/by-name/bo/bomber-go/package.nix b/pkgs/by-name/bo/bomber-go/package.nix index 7857dff0302a24..97e8d4ce1531d8 100644 --- a/pkgs/by-name/bo/bomber-go/package.nix +++ b/pkgs/by-name/bo/bomber-go/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/bo/bombono/package.nix b/pkgs/by-name/bo/bombono/package.nix index ebbdf9dbeb0872..e309785aec6c22 100644 --- a/pkgs/by-name/bo/bombono/package.nix +++ b/pkgs/by-name/bo/bombono/package.nix @@ -1,22 +1,24 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config -, fetchpatch -, fetchpatch2 -, scons -, boost -, dvdauthor -, dvdplusrwtools -, enca -, cdrkit -, ffmpeg_6 -, gettext -, gtk2 -, gtkmm2 -, libdvdread -, libxmlxx -, mjpegtools -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + fetchpatch, + fetchpatch2, + scons, + boost, + dvdauthor, + dvdplusrwtools, + enca, + cdrkit, + ffmpeg_6, + gettext, + gtk2, + gtkmm2, + libdvdread, + libxmlxx, + mjpegtools, + wrapGAppsHook3, }: stdenv.mkDerivation { @@ -50,7 +52,12 @@ stdenv.mkDerivation { --replace "lib_mbase_env['CPPDEFINES']" "list(lib_mbase_env['CPPDEFINES'])" ''; - nativeBuildInputs = [ wrapGAppsHook3 scons pkg-config gettext ]; + nativeBuildInputs = [ + wrapGAppsHook3 + scons + pkg-config + gettext + ]; buildInputs = [ boost @@ -73,7 +80,13 @@ stdenv.mkDerivation { # fix iso authoring install -Dt $out/share/bombono/resources/scons_authoring tools/scripts/SConsTwin.py - wrapProgram $out/bin/bombono-dvd --prefix PATH : ${lib.makeBinPath [ ffmpeg_6 dvdauthor cdrkit ]} + wrapProgram $out/bin/bombono-dvd --prefix PATH : ${ + lib.makeBinPath [ + ffmpeg_6 + dvdauthor + cdrkit + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/bo/bomutils/package.nix b/pkgs/by-name/bo/bomutils/package.nix index 1b147d10ec284e..ad9671ae25691e 100644 --- a/pkgs/by-name/bo/bomutils/package.nix +++ b/pkgs/by-name/bo/bomutils/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/bo/bonk/package.nix b/pkgs/by-name/bo/bonk/package.nix index b4a65329dc96fe..7f281db1dd85ac 100644 --- a/pkgs/by-name/bo/bonk/package.nix +++ b/pkgs/by-name/bo/bonk/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/bo/bonmin/package.nix b/pkgs/by-name/bo/bonmin/package.nix index 1cf64101face30..8104e34ad4bdb3 100644 --- a/pkgs/by-name/bo/bonmin/package.nix +++ b/pkgs/by-name/bo/bonmin/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, fontconfig -, gfortran -, pkg-config -, blas -, bzip2 -, cbc -, clp -, doxygen -, graphviz -, ipopt -, lapack -, libamplsolver -, osi -, texliveSmall -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + fontconfig, + gfortran, + pkg-config, + blas, + bzip2, + cbc, + clp, + doxygen, + graphviz, + ipopt, + lapack, + libamplsolver, + osi, + texliveSmall, + zlib, }: assert (!blas.isILP64) && (!lapack.isILP64); diff --git a/pkgs/by-name/bo/bonnie/package.nix b/pkgs/by-name/bo/bonnie/package.nix index a2f1c51e7e123a..7d912d103504d4 100644 --- a/pkgs/by-name/bo/bonnie/package.nix +++ b/pkgs/by-name/bo/bonnie/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch +{ + lib, + stdenv, + fetchurl, + fetchpatch, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/bo/bonnmotion/package.nix b/pkgs/by-name/bo/bonnmotion/package.nix index dc77da6d7e1818..502cd8c70d6931 100644 --- a/pkgs/by-name/bo/bonnmotion/package.nix +++ b/pkgs/by-name/bo/bonnmotion/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchzip, substituteAll, bash, jre }: +{ + stdenv, + lib, + fetchzip, + substituteAll, + bash, + jre, +}: stdenv.mkDerivation rec { pname = "bonnmotion"; @@ -47,7 +54,7 @@ stdenv.mkDerivation rec { homepage = "https://sys.cs.uos.de/bonnmotion/"; sourceProvenance = with sourceTypes; [ fromSource - binaryBytecode # source bundles dependency jars + binaryBytecode # source bundles dependency jars ]; license = licenses.gpl2Plus; maintainers = with maintainers; [ oxzi ]; diff --git a/pkgs/by-name/bo/bonzomatic/package.nix b/pkgs/by-name/bo/bonzomatic/package.nix index 886e42414da139..009a82e33abcf1 100644 --- a/pkgs/by-name/bo/bonzomatic/package.nix +++ b/pkgs/by-name/bo/bonzomatic/package.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, makeWrapper -, alsa-lib, fontconfig, mesa_glu, libXcursor, libXinerama, libXrandr, xorg +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + makeWrapper, + alsa-lib, + fontconfig, + mesa_glu, + libXcursor, + libXinerama, + libXrandr, + xorg, }: stdenv.mkDerivation rec { @@ -14,10 +24,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-hwK3C+p1hRwnuY2/vBrA0QsJGIcJatqq+U5/hzVCXEg="; }; - nativeBuildInputs = [ cmake makeWrapper ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; buildInputs = [ - alsa-lib fontconfig mesa_glu - libXcursor libXinerama libXrandr xorg.xinput xorg.libXi xorg.libXext + alsa-lib + fontconfig + mesa_glu + libXcursor + libXinerama + libXrandr + xorg.xinput + xorg.libXi + xorg.libXext ]; postFixup = '' @@ -29,7 +49,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/gargaj/bonzomatic"; license = licenses.unlicense; maintainers = [ maintainers.ilian ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; mainProgram = "bonzomatic"; }; } diff --git a/pkgs/by-name/bo/boofuzz/package.nix b/pkgs/by-name/bo/boofuzz/package.nix index b254b9d3d191f3..05e5dc72263382 100644 --- a/pkgs/by-name/bo/boofuzz/package.nix +++ b/pkgs/by-name/bo/boofuzz/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -41,14 +42,16 @@ python3.pkgs.buildPythonApplication rec { pytestCheckHook ]; - disabledTests = [ - "TestNetworkMonitor" - "TestNoResponseFailure" - "TestProcessMonitor" - "TestSocketConnection" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "test_time_repeater" - ]; + disabledTests = + [ + "TestNetworkMonitor" + "TestNoResponseFailure" + "TestProcessMonitor" + "TestSocketConnection" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "test_time_repeater" + ]; pythonImportsCheck = [ "boofuzz" diff --git a/pkgs/by-name/bo/boohu/package.nix b/pkgs/by-name/bo/boohu/package.nix index 14aa6d43a58701..e6b7b1bbe010d6 100644 --- a/pkgs/by-name/bo/boohu/package.nix +++ b/pkgs/by-name/bo/boohu/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, buildGoModule }: +{ + lib, + fetchurl, + buildGoModule, +}: buildGoModule rec { pname = "boohu"; @@ -11,7 +15,10 @@ buildGoModule rec { vendorHash = "sha256-AVK4zE/Hs9SN8Qj2WYj/am2B0R74QKYoMNf3sRRjnU4="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "New coffee-break roguelike game"; diff --git a/pkgs/by-name/bo/book-summary/package.nix b/pkgs/by-name/bo/book-summary/package.nix index 374c107f9a3df6..70244b9907eb6c 100644 --- a/pkgs/by-name/bo/book-summary/package.nix +++ b/pkgs/by-name/bo/book-summary/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/bo/bookworm/package.nix b/pkgs/by-name/bo/bookworm/package.nix index 48ad4ce47244ee..5f8345bd6ab7e4 100644 --- a/pkgs/by-name/bo/bookworm/package.nix +++ b/pkgs/by-name/bo/bookworm/package.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchFromGitHub -, appstream -, coreutils -, curl -, desktop-file-utils -, glib -, gnugrep -, gobject-introspection -, gtk3 -, html2text -, libgee -, libxml2 -, meson -, ninja -, pantheon -, pkg-config -, poppler -, poppler_utils -, python3 -, sqlite -, unar -, unzip -, vala -, webkitgtk_4_0 -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + appstream, + coreutils, + curl, + desktop-file-utils, + glib, + gnugrep, + gobject-introspection, + gtk3, + html2text, + libgee, + libxml2, + meson, + ninja, + pantheon, + pkg-config, + poppler, + poppler_utils, + python3, + sqlite, + unar, + unzip, + vala, + webkitgtk_4_0, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -70,7 +71,17 @@ stdenv.mkDerivation rec { # These programs are expected in PATH from the source code and scripts preFixup = '' gappsWrapperArgs+=( - --prefix PATH : "${lib.makeBinPath [ unzip unar poppler_utils html2text coreutils curl gnugrep ]}" + --prefix PATH : "${ + lib.makeBinPath [ + unzip + unar + poppler_utils + html2text + coreutils + curl + gnugrep + ] + }" --prefix PATH : $out/bin ) ''; diff --git a/pkgs/by-name/bo/boolector/package.nix b/pkgs/by-name/bo/boolector/package.nix index 30e3cf5002114c..d9c6d5de82ccea 100644 --- a/pkgs/by-name/bo/boolector/package.nix +++ b/pkgs/by-name/bo/boolector/package.nix @@ -1,5 +1,14 @@ -{ stdenv, fetchFromGitHub, lib, python3, fetchpatch -, cmake, lingeling, btor2tools, gtest, gmp +{ + stdenv, + fetchFromGitHub, + lib, + python3, + fetchpatch, + cmake, + lingeling, + btor2tools, + gtest, + gmp, }: stdenv.mkDerivation rec { @@ -7,10 +16,10 @@ stdenv.mkDerivation rec { version = "3.2.3"; src = fetchFromGitHub { - owner = "boolector"; - repo = "boolector"; - rev = version; - hash = "sha256-CdfpXUbU1+yEmrNyl+hvHlJfpzzzx356naim6vRafDg="; + owner = "boolector"; + repo = "boolector"; + rev = version; + hash = "sha256-CdfpXUbU1+yEmrNyl+hvHlJfpzzzx356naim6vRafDg="; }; patches = [ @@ -22,29 +31,38 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake gtest ]; - buildInputs = [ lingeling btor2tools gmp ]; + nativeBuildInputs = [ + cmake + gtest + ]; + buildInputs = [ + lingeling + btor2tools + gmp + ]; - cmakeFlags = - [ "-DBUILD_SHARED_LIBS=ON" - "-DUSE_LINGELING=YES" - "-DBtor2Tools_INCLUDE_DIR=${btor2tools.dev}/include/btor2parser" - ] ++ (lib.optional (gmp != null) "-DUSE_GMP=YES"); + cmakeFlags = [ + "-DBUILD_SHARED_LIBS=ON" + "-DUSE_LINGELING=YES" + "-DBtor2Tools_INCLUDE_DIR=${btor2tools.dev}/include/btor2parser" + ] ++ (lib.optional (gmp != null) "-DUSE_GMP=YES"); nativeCheckInputs = [ python3 ]; doCheck = true; preCheck = - let var = if stdenv.hostPlatform.isDarwin then "DYLD_LIBRARY_PATH" else "LD_LIBRARY_PATH"; + let + var = if stdenv.hostPlatform.isDarwin then "DYLD_LIBRARY_PATH" else "LD_LIBRARY_PATH"; in - # tests modelgen and modelgensmt2 spawn boolector in another processes and - # macOS strips DYLD_LIBRARY_PATH, hardcode it for testing - lib.optionalString stdenv.hostPlatform.isDarwin '' - cp -r bin bin.back - install_name_tool -change libboolector.dylib $(pwd)/lib/libboolector.dylib bin/boolector - '' + '' - export ${var}=$(readlink -f lib) - patchShebangs .. - ''; + # tests modelgen and modelgensmt2 spawn boolector in another processes and + # macOS strips DYLD_LIBRARY_PATH, hardcode it for testing + lib.optionalString stdenv.hostPlatform.isDarwin '' + cp -r bin bin.back + install_name_tool -change libboolector.dylib $(pwd)/lib/libboolector.dylib bin/boolector + '' + + '' + export ${var}=$(readlink -f lib) + patchShebangs .. + ''; postCheck = lib.optionalString stdenv.hostPlatform.isDarwin '' rm -rf bin @@ -59,9 +77,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Extremely fast SMT solver for bit-vectors and arrays"; - homepage = "https://boolector.github.io"; - license = licenses.mit; - platforms = with platforms; linux ++ darwin; + homepage = "https://boolector.github.io"; + license = licenses.mit; + platforms = with platforms; linux ++ darwin; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/bo/boolstuff/package.nix b/pkgs/by-name/bo/boolstuff/package.nix index c54cffb5285169..1f8495be5519ff 100644 --- a/pkgs/by-name/bo/boolstuff/package.nix +++ b/pkgs/by-name/bo/boolstuff/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, pkg-config }: +{ + lib, + stdenv, + fetchurl, + pkg-config, +}: stdenv.mkDerivation rec { pname = "boolstuff"; version = "0.1.17"; diff --git a/pkgs/by-name/bo/boops/package.nix b/pkgs/by-name/bo/boops/package.nix index 2f4156675392ef..8e5cfe9865ea61 100644 --- a/pkgs/by-name/bo/boops/package.nix +++ b/pkgs/by-name/bo/boops/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchFromGitHub, xorg, cairo, lv2, libsndfile, pkg-config }: +{ + stdenv, + lib, + fetchFromGitHub, + xorg, + cairo, + lv2, + libsndfile, + pkg-config, +}: stdenv.mkDerivation rec { pname = "boops"; @@ -13,7 +22,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - xorg.libX11 cairo lv2 libsndfile + xorg.libX11 + cairo + lv2 + libsndfile ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/bo/boost-build/package.nix b/pkgs/by-name/bo/boost-build/package.nix index 25911809695e70..89eefca6ba2508 100644 --- a/pkgs/by-name/bo/boost-build/package.nix +++ b/pkgs/by-name/bo/boost-build/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, bison -# boost derivation to use for the src and version. -# This is used by the boost derivation to build -# a b2 matching their version (by overriding this -# argument). Infinite recursion is not an issue -# since we only look at src and version of boost. -, useBoost ? {} +{ + lib, + stdenv, + fetchFromGitHub, + bison, + # boost derivation to use for the src and version. + # This is used by the boost derivation to build + # a b2 matching their version (by overriding this + # argument). Infinite recursion is not an issue + # since we only look at src and version of boost. + useBoost ? { }, }: let @@ -16,36 +17,40 @@ in stdenv.mkDerivation { pname = "boost-build"; - version = - if useBoost ? version - then "boost-${useBoost.version}" - else defaultVersion; + version = if useBoost ? version then "boost-${useBoost.version}" else defaultVersion; - src = useBoost.src or (fetchFromGitHub { - owner = "boostorg"; - repo = "build"; - rev = defaultVersion; - sha256 = "1r4rwlq87ydmsdqrik4ly5iai796qalvw7603mridg2nwcbbnf54"; - }); + src = + useBoost.src or (fetchFromGitHub { + owner = "boostorg"; + repo = "build"; + rev = defaultVersion; + sha256 = "1r4rwlq87ydmsdqrik4ly5iai796qalvw7603mridg2nwcbbnf54"; + }); # b2 is in a subdirectory of boost source tarballs postUnpack = lib.optionalString (useBoost ? src) '' sourceRoot="$sourceRoot/tools/build" ''; - patches = useBoost.boostBuildPatches or [] - ++ lib.optional (useBoost ? version && lib.versionAtLeast useBoost.version "1.81") ./fix-clang-target.patch; + patches = + useBoost.boostBuildPatches or [ ] + ++ lib.optional ( + useBoost ? version && lib.versionAtLeast useBoost.version "1.81" + ) ./fix-clang-target.patch; - postPatch = lib.optionalString (useBoost ? version && lib.versionAtLeast useBoost.version "1.80") '' - # Upstream uses arm64, but nixpkgs uses aarch64. - substituteInPlace src/tools/clang.jam \ - --replace-fail 'arch = arm64' 'arch = aarch64' - '' + lib.optionalString (useBoost ? version && lib.versionOlder useBoost.version "1.77") '' - substituteInPlace src/build-system.jam \ - --replace-fail "default-toolset = darwin" "default-toolset = clang-darwin" - '' + lib.optionalString (useBoost ? version && lib.versionAtLeast useBoost.version "1.82") '' - patchShebangs --build src/engine/build.sh - ''; + postPatch = + lib.optionalString (useBoost ? version && lib.versionAtLeast useBoost.version "1.80") '' + # Upstream uses arm64, but nixpkgs uses aarch64. + substituteInPlace src/tools/clang.jam \ + --replace-fail 'arch = arm64' 'arch = aarch64' + '' + + lib.optionalString (useBoost ? version && lib.versionOlder useBoost.version "1.77") '' + substituteInPlace src/build-system.jam \ + --replace-fail "default-toolset = darwin" "default-toolset = clang-darwin" + '' + + lib.optionalString (useBoost ? version && lib.versionAtLeast useBoost.version "1.82") '' + patchShebangs --build src/engine/build.sh + ''; nativeBuildInputs = [ bison diff --git a/pkgs/by-name/bo/boost-sml/package.nix b/pkgs/by-name/bo/boost-sml/package.nix index 7987629b60d3b5..1817a64b537152 100644 --- a/pkgs/by-name/bo/boost-sml/package.nix +++ b/pkgs/by-name/bo/boost-sml/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, cmake -, fetchFromGitHub -, boost +{ + stdenv, + lib, + cmake, + fetchFromGitHub, + boost, }: stdenv.mkDerivation rec { @@ -36,4 +37,3 @@ stdenv.mkDerivation rec { platforms = platforms.all; }; } - diff --git a/pkgs/by-name/bo/boot/package.nix b/pkgs/by-name/bo/boot/package.nix index dd296aa83188eb..a89623da102c8a 100644 --- a/pkgs/by-name/bo/boot/package.nix +++ b/pkgs/by-name/bo/boot/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, jdk }: +{ + lib, + stdenv, + fetchurl, + jdk, +}: stdenv.mkDerivation rec { version = "2.7.2"; diff --git a/pkgs/by-name/bo/bootil/package.nix b/pkgs/by-name/bo/bootil/package.nix index dab559afdace4f..a3157202b36dc1 100644 --- a/pkgs/by-name/bo/bootil/package.nix +++ b/pkgs/by-name/bo/bootil/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, premake4 +{ + lib, + stdenv, + fetchFromGitHub, + premake4, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/bo/bootiso/package.nix b/pkgs/by-name/bo/bootiso/package.nix index 243989d0494893..8b54e2ace61dd7 100644 --- a/pkgs/by-name/bo/bootiso/package.nix +++ b/pkgs/by-name/bo/bootiso/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, fetchpatch -, bash -, makeWrapper -, bc -, jq -, coreutils -, util-linux -, wimlib -, file -, syslinux -, busybox -, gnugrep # We can't use busybox's 'grep' as it doesn't support perl '-P' expressions. +{ + lib, + stdenvNoCC, + fetchFromGitHub, + fetchpatch, + bash, + makeWrapper, + bc, + jq, + coreutils, + util-linux, + wimlib, + file, + syslinux, + busybox, + gnugrep, # We can't use busybox's 'grep' as it doesn't support perl '-P' expressions. }: stdenvNoCC.mkDerivation rec { @@ -47,7 +48,19 @@ stdenvNoCC.mkDerivation rec { postInstall = '' wrapProgram $out/bin/bootiso \ - --prefix PATH : ${lib.makeBinPath [ bc jq coreutils util-linux wimlib file syslinux gnugrep busybox ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + bc + jq + coreutils + util-linux + wimlib + file + syslinux + gnugrep + busybox + ] + } \ ''; meta = with lib; { diff --git a/pkgs/by-name/bo/bootspec/package.nix b/pkgs/by-name/bo/bootspec/package.nix index 2ffa6c47ab09e1..1a01eb2b3a17ac 100644 --- a/pkgs/by-name/bo/bootspec/package.nix +++ b/pkgs/by-name/bo/bootspec/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, fetchpatch +{ + lib, + rustPlatform, + fetchFromGitHub, + fetchpatch, }: rustPlatform.buildRustPackage rec { pname = "bootspec"; diff --git a/pkgs/by-name/bo/borealis-cursors/package.nix b/pkgs/by-name/bo/borealis-cursors/package.nix index e88f5fb72269f3..7d1b99953ad4fc 100644 --- a/pkgs/by-name/bo/borealis-cursors/package.nix +++ b/pkgs/by-name/bo/borealis-cursors/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/bo/borg-sans-mono/package.nix b/pkgs/by-name/bo/borg-sans-mono/package.nix index 8037e5dc645f9d..2341003ae24aad 100644 --- a/pkgs/by-name/bo/borg-sans-mono/package.nix +++ b/pkgs/by-name/bo/borg-sans-mono/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { pname = "borg-sans-mono"; diff --git a/pkgs/by-name/bo/borgbackup/package.nix b/pkgs/by-name/bo/borgbackup/package.nix index e0c148108362a2..cdff7c1cd067b0 100644 --- a/pkgs/by-name/bo/borgbackup/package.nix +++ b/pkgs/by-name/bo/borgbackup/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, acl -, e2fsprogs -, fetchFromGitHub -, libb2 -, lz4 -, openssh -, openssl -, python3 -, xxHash -, zstd -, installShellFiles -, nixosTests +{ + lib, + stdenv, + acl, + e2fsprogs, + fetchFromGitHub, + libb2, + lz4, + openssh, + openssl, + python3, + xxHash, + zstd, + installShellFiles, + nixosTests, }: let @@ -50,18 +51,23 @@ python.pkgs.buildPythonApplication rec { installShellFiles ]; - sphinxBuilders = [ "singlehtml" "man" ]; - - buildInputs = [ - libb2 - lz4 - xxHash - zstd - openssl - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - acl + sphinxBuilders = [ + "singlehtml" + "man" ]; + buildInputs = + [ + libb2 + lz4 + xxHash + zstd + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + acl + ]; + dependencies = with python.pkgs; [ msgpack packaging @@ -89,7 +95,8 @@ python.pkgs.buildPythonApplication rec { pytestFlagsArray = [ "--benchmark-skip" - "--pyargs" "borg.testsuite" + "--pyargs" + "borg.testsuite" ]; disabledTests = [ @@ -118,7 +125,11 @@ python.pkgs.buildPythonApplication rec { inherit (nixosTests) borgbackup; }; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; disabled = python.pythonOlder "3.9"; @@ -129,6 +140,9 @@ python.pkgs.buildPythonApplication rec { license = licenses.bsd3; platforms = platforms.unix; # Darwin and FreeBSD mentioned on homepage mainProgram = "borg"; - maintainers = with maintainers; [ dotlambda globin ]; + maintainers = with maintainers; [ + dotlambda + globin + ]; }; } diff --git a/pkgs/by-name/bo/borgmatic/package.nix b/pkgs/by-name/bo/borgmatic/package.nix index 8a55cef2b9d2c7..9bfa633e63e550 100644 --- a/pkgs/by-name/bo/borgmatic/package.nix +++ b/pkgs/by-name/bo/borgmatic/package.nix @@ -21,7 +21,14 @@ python3Packages.buildPythonApplication rec { hash = "sha256-WYs7wiwZ1TvTdeUpWv7FbREXWfdGcYRarP4FXFOfp0Y="; }; - nativeCheckInputs = with python3Packages; [ flexmock pytestCheckHook pytest-cov ] ++ optional-dependencies.apprise; + nativeCheckInputs = + with python3Packages; + [ + flexmock + pytestCheckHook + pytest-cov + ] + ++ optional-dependencies.apprise; # - test_borgmatic_version_matches_news_version # The file NEWS not available on the pypi source, and this test is useless @@ -45,20 +52,22 @@ python3Packages.buildPythonApplication rec { apprise = [ python3Packages.apprise ]; }; - postInstall = '' - installShellCompletion --cmd borgmatic \ - --bash <($out/bin/borgmatic --bash-completion) - '' + lib.optionalString enableSystemd '' - mkdir -p $out/lib/systemd/system - cp sample/systemd/borgmatic.timer $out/lib/systemd/system/ - # there is another "sleep", so choose the one with the space after it - # due to https://github.com/borgmatic-collective/borgmatic/commit/2e9f70d49647d47fb4ca05f428c592b0e4319544 - substitute sample/systemd/borgmatic.service \ - $out/lib/systemd/system/borgmatic.service \ - --replace /root/.local/bin/borgmatic $out/bin/borgmatic \ - --replace systemd-inhibit ${systemd}/bin/systemd-inhibit \ - --replace "sleep " "${coreutils}/bin/sleep " - ''; + postInstall = + '' + installShellCompletion --cmd borgmatic \ + --bash <($out/bin/borgmatic --bash-completion) + '' + + lib.optionalString enableSystemd '' + mkdir -p $out/lib/systemd/system + cp sample/systemd/borgmatic.timer $out/lib/systemd/system/ + # there is another "sleep", so choose the one with the space after it + # due to https://github.com/borgmatic-collective/borgmatic/commit/2e9f70d49647d47fb4ca05f428c592b0e4319544 + substitute sample/systemd/borgmatic.service \ + $out/lib/systemd/system/borgmatic.service \ + --replace /root/.local/bin/borgmatic $out/bin/borgmatic \ + --replace systemd-inhibit ${systemd}/bin/systemd-inhibit \ + --replace "sleep " "${coreutils}/bin/sleep " + ''; passthru.tests = { version = testers.testVersion { package = borgmatic; }; @@ -72,6 +81,9 @@ python3Packages.buildPythonApplication rec { homepage = "https://torsion.org/borgmatic/"; license = lib.licenses.gpl3Plus; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ imlonghao x123 ]; + maintainers = with lib.maintainers; [ + imlonghao + x123 + ]; }; } diff --git a/pkgs/by-name/bo/boringssl/package.nix b/pkgs/by-name/bo/boringssl/package.nix index 68ca686403aeac..9c8ea8edad61f9 100644 --- a/pkgs/by-name/bo/boringssl/package.nix +++ b/pkgs/by-name/bo/boringssl/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchgit -, cmake -, ninja -, perl -, buildGoModule +{ + lib, + stdenv, + fetchgit, + cmake, + ninja, + perl, + buildGoModule, }: # reference: https://boringssl.googlesource.com/boringssl/+/2661/BUILDING.md @@ -18,30 +19,40 @@ buildGoModule { hash = "sha256-TdSObRECiGRQcgz6N2LhKvSi9yRYOZYJdK6MyfJX2Bo="; }; - nativeBuildInputs = [ cmake ninja perl ]; + nativeBuildInputs = [ + cmake + ninja + perl + ]; vendorHash = "sha256-GlhLsPD+yp2LdqsIsfXNEaNKKlc76p0kBCyu4rlEmMg="; proxyVendor = true; # hack to get both go and cmake configure phase # (if we use postConfigure then cmake will loop runHook postConfigure) - preBuild = '' - cmakeConfigurePhase - '' + lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' - export GOARCH=$(go env GOHOSTARCH) - ''; + preBuild = + '' + cmakeConfigurePhase + '' + + lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' + export GOARCH=$(go env GOHOSTARCH) + ''; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isGNU [ - # Needed with GCC 12 but breaks on darwin (with clang) - "-Wno-error=stringop-overflow" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isGNU [ + # Needed with GCC 12 but breaks on darwin (with clang) + "-Wno-error=stringop-overflow" + ] + ); buildPhase = '' ninjaBuildPhase ''; # CMAKE_OSX_ARCHITECTURES is set to x86_64 by Nix, but it confuses boringssl on aarch64-linux. - cmakeFlags = [ "-GNinja" ] ++ lib.optionals (stdenv.hostPlatform.isLinux) [ "-DCMAKE_OSX_ARCHITECTURES=" ]; + cmakeFlags = [ + "-GNinja" + ] ++ lib.optionals (stdenv.hostPlatform.isLinux) [ "-DCMAKE_OSX_ARCHITECTURES=" ]; installPhase = '' mkdir -p $bin/bin $dev $out/lib @@ -55,13 +66,22 @@ buildGoModule { mv ../include $dev ''; - outputs = [ "out" "bin" "dev" ]; + outputs = [ + "out" + "bin" + "dev" + ]; meta = with lib; { description = "Free TLS/SSL implementation"; mainProgram = "bssl"; - homepage = "https://boringssl.googlesource.com"; + homepage = "https://boringssl.googlesource.com"; maintainers = [ maintainers.thoughtpolice ]; - license = with licenses; [ openssl isc mit bsd3 ]; + license = with licenses; [ + openssl + isc + mit + bsd3 + ]; }; } diff --git a/pkgs/by-name/bo/boringtun/package.nix b/pkgs/by-name/bo/boringtun/package.nix index 30bb243454f8da..1c9bb07062bf02 100644 --- a/pkgs/by-name/bo/boringtun/package.nix +++ b/pkgs/by-name/bo/boringtun/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, darwin }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "boringtun"; diff --git a/pkgs/by-name/bo/boron/package.nix b/pkgs/by-name/bo/boron/package.nix index e6570c2e89194e..a7b278ba50b510 100644 --- a/pkgs/by-name/bo/boron/package.nix +++ b/pkgs/by-name/bo/boron/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, zlib +{ + lib, + stdenv, + fetchurl, + zlib, }: stdenv.mkDerivation rec { @@ -28,7 +29,10 @@ stdenv.mkDerivation rec { zlib ]; - installTargets = [ "install" "install-dev" ]; + installTargets = [ + "install" + "install-dev" + ]; doCheck = true; @@ -46,4 +50,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ mausch ]; }; } - diff --git a/pkgs/by-name/bo/bosh-cli/package.nix b/pkgs/by-name/bo/bosh-cli/package.nix index ac3b5e4f5fe0eb..15e88ef060f1ed 100644 --- a/pkgs/by-name/bo/bosh-cli/package.nix +++ b/pkgs/by-name/bo/bosh-cli/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, makeWrapper -, openssh +{ + lib, + fetchFromGitHub, + buildGoModule, + makeWrapper, + openssh, }: buildGoModule rec { diff --git a/pkgs/by-name/bo/bosun/package.nix b/pkgs/by-name/bo/bosun/package.nix index 3158f9b2424b92..65de68f8250c53 100644 --- a/pkgs/by-name/bo/bosun/package.nix +++ b/pkgs/by-name/bo/bosun/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, buildGoModule }: +{ + lib, + stdenv, + fetchFromGitHub, + buildGoModule, +}: buildGoModule { pname = "bosun"; @@ -13,9 +18,15 @@ buildGoModule { vendorHash = "sha256-5mVI5cyuIB+6KHlTpDxSNGU7yBsGQC4IA+iDgvVFVZM="; - subPackages = [ "cmd/bosun" "cmd/scollector" ]; + subPackages = [ + "cmd/bosun" + "cmd/scollector" + ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Time Series Alerting Framework"; diff --git a/pkgs/by-name/bo/botamusique/package.nix b/pkgs/by-name/bo/botamusique/package.nix index 86cb6e22294554..7f46613e2b4170 100644 --- a/pkgs/by-name/bo/botamusique/package.nix +++ b/pkgs/by-name/bo/botamusique/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3Packages -, ffmpeg-headless -, makeWrapper -, nixosTests -, nodejs -, npmHooks -, fetchNpmDeps - -# For the update script -, coreutils -, curl -, nix-prefetch-git -, prefetch-npm-deps -, jq -, writeShellScript +{ + lib, + stdenv, + fetchFromGitHub, + python3Packages, + ffmpeg-headless, + makeWrapper, + nixosTests, + nodejs, + npmHooks, + fetchNpmDeps, + + # For the update script + coreutils, + curl, + nix-prefetch-git, + prefetch-npm-deps, + jq, + writeShellScript, }: let srcJson = lib.importJSON ./src.json; @@ -121,7 +122,15 @@ stdenv.mkDerivation rec { ''; passthru.updateScript = writeShellScript "botamusique-updater" '' - export PATH=${lib.makeBinPath [ coreutils curl nix-prefetch-git jq prefetch-npm-deps ]} + export PATH=${ + lib.makeBinPath [ + coreutils + curl + nix-prefetch-git + jq + prefetch-npm-deps + ] + } set -ex OWNER=azlux diff --git a/pkgs/by-name/bo/bottom-rs/package.nix b/pkgs/by-name/bo/bottom-rs/package.nix index d9d2ab079c7b4d..46172fd039fded 100644 --- a/pkgs/by-name/bo/bottom-rs/package.nix +++ b/pkgs/by-name/bo/bottom-rs/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "bottom-rs"; diff --git a/pkgs/by-name/bo/bowtie/package.nix b/pkgs/by-name/bo/bowtie/package.nix index 2009788ead6a51..b9b539e8db4919 100644 --- a/pkgs/by-name/bo/bowtie/package.nix +++ b/pkgs/by-name/bo/bowtie/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + zlib, +}: stdenv.mkDerivation rec { pname = "bowtie"; diff --git a/pkgs/by-name/bo/bowtie2/package.nix b/pkgs/by-name/bo/bowtie2/package.nix index 2a1358f2e5b77f..519913e6ef1b51 100644 --- a/pkgs/by-name/bo/bowtie2/package.nix +++ b/pkgs/by-name/bo/bowtie2/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, perl -, python3 -, tbb -, zlib -, runCommand -, bowtie2 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + perl, + python3, + tbb, + zlib, + runCommand, + bowtie2, }: stdenv.mkDerivation (finalAttrs: { @@ -32,9 +33,16 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ cmake ]; - buildInputs = [ tbb zlib python3 perl ]; + buildInputs = [ + tbb + zlib + python3 + perl + ]; - cmakeFlags = lib.optional (!stdenv.hostPlatform.isx86) ["-DCMAKE_CXX_FLAGS=-I${finalAttrs.src}/third_party"]; + cmakeFlags = lib.optional (!stdenv.hostPlatform.isx86) [ + "-DCMAKE_CXX_FLAGS=-I${finalAttrs.src}/third_party" + ]; # ctest fails because of missing dependencies between tests doCheck = false; diff --git a/pkgs/by-name/bo/boxbuddy/package.nix b/pkgs/by-name/bo/boxbuddy/package.nix index 37b5a7acc26bb5..724f45587f78ed 100644 --- a/pkgs/by-name/bo/boxbuddy/package.nix +++ b/pkgs/by-name/bo/boxbuddy/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, wrapGAppsHook4 -, libadwaita -, distrobox +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + wrapGAppsHook4, + libadwaita, + distrobox, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/bo/boxed-cpp/package.nix b/pkgs/by-name/bo/boxed-cpp/package.nix index 3ce5a5c9c60848..a6ba4a21e10f39 100644 --- a/pkgs/by-name/bo/boxed-cpp/package.nix +++ b/pkgs/by-name/bo/boxed-cpp/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, catch2 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + catch2, +}: stdenv.mkDerivation (final: { pname = "boxed-cpp"; diff --git a/pkgs/by-name/bo/boxes/package.nix b/pkgs/by-name/bo/boxes/package.nix index d7ef5515480531..fcbdaf62778970 100644 --- a/pkgs/by-name/bo/boxes/package.nix +++ b/pkgs/by-name/bo/boxes/package.nix @@ -1,4 +1,13 @@ -{ lib, gccStdenv, fetchFromGitHub, bison, flex, pcre2, libunistring, ncurses }: +{ + lib, + gccStdenv, + fetchFromGitHub, + bison, + flex, + pcre2, + libunistring, + ncurses, +}: gccStdenv.mkDerivation rec { pname = "boxes"; @@ -13,9 +22,16 @@ gccStdenv.mkDerivation rec { # Building instructions: # https://boxes.thomasjensen.com/build.html#building-on-linux--unix - nativeBuildInputs = [ bison flex ]; - - buildInputs = [ pcre2 libunistring ncurses ]; + nativeBuildInputs = [ + bison + flex + ]; + + buildInputs = [ + pcre2 + libunistring + ncurses + ]; dontConfigure = true; diff --git a/pkgs/by-name/bo/boxfort/package.nix b/pkgs/by-name/bo/boxfort/package.nix index 855f86a3c36f95..65ab07307b4200 100644 --- a/pkgs/by-name/bo/boxfort/package.nix +++ b/pkgs/by-name/bo/boxfort/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, python3Packages }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + python3Packages, +}: stdenv.mkDerivation rec { pname = "boxfort"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "jmtWTOkOlqVZ7tFya3IrQjr714Y8TzAVY5Cq+RzDuRs="; }; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; preConfigure = '' patchShebangs ci/isdir.py @@ -21,13 +31,19 @@ stdenv.mkDerivation rec { doCheck = true; - outputs = [ "dev" "out" ]; + outputs = [ + "dev" + "out" + ]; meta = with lib; { description = "Convenient & cross-platform sandboxing C library"; homepage = "https://github.com/Snaipe/BoxFort"; license = licenses.mit; - maintainers = with maintainers; [ thesola10 Yumasi ]; + maintainers = with maintainers; [ + thesola10 + Yumasi + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/bo/boxfs/package.nix b/pkgs/by-name/bo/boxfs/package.nix index b12966541c9971..b1d699928dbc0b 100644 --- a/pkgs/by-name/bo/boxfs/package.nix +++ b/pkgs/by-name/bo/boxfs/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, curl, fuse, libxml2, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + curl, + fuse, + libxml2, + pkg-config, +}: let srcs = { @@ -21,7 +29,8 @@ let owner = "vincenthz"; }; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "boxfs"; version = "2-20150109"; @@ -37,7 +46,11 @@ in stdenv.mkDerivation { ./libapp-include-ctype.diff ]; - buildInputs = [ curl fuse libxml2 ]; + buildInputs = [ + curl + fuse + libxml2 + ]; nativeBuildInputs = [ pkg-config ]; buildFlags = [ diff --git a/pkgs/by-name/bo/boxxy/package.nix b/pkgs/by-name/bo/boxxy/package.nix index 845ccf532b8ebd..03b2d1030ac775 100644 --- a/pkgs/by-name/bo/boxxy/package.nix +++ b/pkgs/by-name/bo/boxxy/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, oniguruma -, stdenv +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + oniguruma, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -35,7 +36,10 @@ rustPlatform.buildRustPackage rec { description = "Puts bad Linux applications in a box with only their files"; homepage = "https://github.com/queer/boxxy"; license = licenses.mit; - maintainers = with maintainers; [ dit7ya figsoda ]; + maintainers = with maintainers; [ + dit7ya + figsoda + ]; platforms = platforms.linux; broken = stdenv.hostPlatform.isAarch64; mainProgram = "boxxy"; diff --git a/pkgs/by-name/bp/bpf-linker/package.nix b/pkgs/by-name/bp/bpf-linker/package.nix index 8c044c58622c85..721c910d78336b 100644 --- a/pkgs/by-name/bp/bpf-linker/package.nix +++ b/pkgs/by-name/bp/bpf-linker/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, llvmPackages_19 -, zlib -, ncurses -, libxml2 +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + llvmPackages_19, + zlib, + ncurses, + libxml2, }: rustPlatform.buildRustPackage rec { @@ -29,7 +30,11 @@ rustPlatform.buildRustPackage rec { buildNoDefaultFeatures = true; nativeBuildInputs = [ llvmPackages_19.llvm ]; - buildInputs = [ zlib ncurses libxml2 ]; + buildInputs = [ + zlib + ncurses + libxml2 + ]; # fails with: couldn't find crate `core` with expected target triple bpfel-unknown-none # rust-src and `-Z build-std=core` are required to properly run the tests @@ -39,7 +44,10 @@ rustPlatform.buildRustPackage rec { description = "Simple BPF static linker"; mainProgram = "bpf-linker"; homepage = "https://github.com/aya-rs/bpf-linker"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ nickcao ]; # llvm-sys crate locates llvm by calling llvm-config # which is not available when cross compiling diff --git a/pkgs/by-name/bp/bpfmon/package.nix b/pkgs/by-name/bp/bpfmon/package.nix index f502bfab45ce47..b1858b012c1b3d 100644 --- a/pkgs/by-name/bp/bpfmon/package.nix +++ b/pkgs/by-name/bp/bpfmon/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, libpcap -, yascreen +{ + lib, + stdenv, + fetchFromGitHub, + libpcap, + yascreen, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/bp/bpftools/package.nix b/pkgs/by-name/bp/bpftools/package.nix index eda3fe62fa8043..8ed9b2723d1887 100644 --- a/pkgs/by-name/bp/bpftools/package.nix +++ b/pkgs/by-name/bp/bpftools/package.nix @@ -1,9 +1,17 @@ -{ lib, stdenv, linuxHeaders -, libopcodes, libopcodes_2_38 -, libbfd, libbfd_2_38 -, elfutils, readline -, zlib -, python3, bison, flex +{ + lib, + stdenv, + linuxHeaders, + libopcodes, + libopcodes_2_38, + libbfd, + libbfd_2_38, + elfutils, + readline, + zlib, + python3, + bison, + flex, }: stdenv.mkDerivation rec { @@ -18,11 +26,29 @@ stdenv.mkDerivation rec { ./include-asm-types-for-ppc64le.patch ]; - nativeBuildInputs = [ python3 bison flex ]; - buildInputs = (if (lib.versionAtLeast version "5.20") - then [ libopcodes libbfd ] - else [ libopcodes_2_38 libbfd_2_38 ]) - ++ [ elfutils zlib readline ]; + nativeBuildInputs = [ + python3 + bison + flex + ]; + buildInputs = + ( + if (lib.versionAtLeast version "5.20") then + [ + libopcodes + libbfd + ] + else + [ + libopcodes_2_38 + libbfd_2_38 + ] + ) + ++ [ + elfutils + zlib + readline + ]; preConfigure = '' patchShebangs scripts/bpf_doc.py @@ -34,7 +60,11 @@ stdenv.mkDerivation rec { --replace '/sbin' '/bin' ''; - buildFlags = [ "bpftool" "bpf_asm" "bpf_dbg" ]; + buildFlags = [ + "bpftool" + "bpf_asm" + "bpf_dbg" + ]; installPhase = '' make -C bpftool install @@ -43,10 +73,13 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - homepage = "https://github.com/libbpf/bpftool"; + homepage = "https://github.com/libbpf/bpftool"; description = "Debugging/program analysis tools for the eBPF subsystem"; - license = [ licenses.gpl2Only licenses.bsd2 ]; - platforms = platforms.linux; + license = [ + licenses.gpl2Only + licenses.bsd2 + ]; + platforms = platforms.linux; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/bp/bpftrace/package.nix b/pkgs/by-name/bp/bpftrace/package.nix index d4002ac1fb6dd4..129f62375eed3a 100644 --- a/pkgs/by-name/bp/bpftrace/package.nix +++ b/pkgs/by-name/bp/bpftrace/package.nix @@ -1,11 +1,23 @@ -{ lib, stdenv, fetchFromGitHub -, llvmPackages, elfutils, bcc -, libbpf, libbfd, libopcodes, glibc -, cereal, asciidoctor -, cmake, pkg-config, flex, bison -, util-linux -, fetchpatch -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + llvmPackages, + elfutils, + bcc, + libbpf, + libbfd, + libopcodes, + glibc, + cereal, + asciidoctor, + cmake, + pkg-config, + flex, + bison, + util-linux, + fetchpatch, + nixosTests, }: stdenv.mkDerivation rec { @@ -14,21 +26,28 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "bpftrace"; - repo = "bpftrace"; - rev = "v${version}"; - hash = "sha256-/2m+5iFE7R+ZEc/VcgWAhkLD/jEK88roUUOUyYODi0U="; + repo = "bpftrace"; + rev = "v${version}"; + hash = "sha256-/2m+5iFE7R+ZEc/VcgWAhkLD/jEK88roUUOUyYODi0U="; }; - buildInputs = with llvmPackages; [ - llvm libclang - elfutils bcc - libbpf libbfd libopcodes - cereal asciidoctor + llvm + libclang + elfutils + bcc + libbpf + libbfd + libopcodes + cereal + asciidoctor ]; nativeBuildInputs = [ - cmake pkg-config flex bison + cmake + pkg-config + flex + bison llvmPackages.llvm.dev util-linux ]; @@ -68,7 +87,10 @@ stdenv.mkDerivation rec { sed -i -e "1s:#!/usr/bin/env bpftrace:#!$out/bin/bpftrace:" $out/share/bpftrace/tools/*.bt ''; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; passthru.tests = { bpf = nixosTests.bpf; @@ -76,11 +98,16 @@ stdenv.mkDerivation rec { meta = with lib; { description = "High-level tracing language for Linux eBPF"; - homepage = "https://github.com/bpftrace/bpftrace"; - changelog = "https://github.com/bpftrace/bpftrace/releases/tag/v${version}"; + homepage = "https://github.com/bpftrace/bpftrace"; + changelog = "https://github.com/bpftrace/bpftrace/releases/tag/v${version}"; mainProgram = "bpftrace"; - license = licenses.asl20; - maintainers = with maintainers; [ rvl thoughtpolice martinetd mfrw ]; - platforms = platforms.linux; + license = licenses.asl20; + maintainers = with maintainers; [ + rvl + thoughtpolice + martinetd + mfrw + ]; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/bp/bpftune/package.nix b/pkgs/by-name/bp/bpftune/package.nix index 3ba11b746f4fd0..30a9a9bc5e969e 100644 --- a/pkgs/by-name/bp/bpftune/package.nix +++ b/pkgs/by-name/bp/bpftune/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, clang -, bpftools -, docutils -, libbpf -, libcap -, libnl -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + clang, + bpftools, + docutils, + libbpf, + libcap, + libnl, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/bp/bpm-tools/package.nix b/pkgs/by-name/bp/bpm-tools/package.nix index 2a9dbcb82e18d9..b3d7d8f7aceb89 100644 --- a/pkgs/by-name/bp/bpm-tools/package.nix +++ b/pkgs/by-name/bp/bpm-tools/package.nix @@ -1,16 +1,23 @@ -{ stdenv -, lib -, fetchurl -, gnuplot -, sox -, flac -, id3v2 -, vorbis-tools -, makeWrapper +{ + stdenv, + lib, + fetchurl, + gnuplot, + sox, + flac, + id3v2, + vorbis-tools, + makeWrapper, }: let - path = lib.makeBinPath [ gnuplot sox flac id3v2 vorbis-tools ]; + path = lib.makeBinPath [ + gnuplot + sox + flac + id3v2 + vorbis-tools + ]; in stdenv.mkDerivation (finalAttrs: { pname = "bpm-tools"; @@ -42,4 +49,3 @@ stdenv.mkDerivation (finalAttrs: { maintainers = with maintainers; [ doronbehar ]; }; }) - diff --git a/pkgs/by-name/bp/bpp-core/package.nix b/pkgs/by-name/bp/bpp-core/package.nix index 673cebe59e8ed3..4f5a705fed6937 100644 --- a/pkgs/by-name/bp/bpp-core/package.nix +++ b/pkgs/by-name/bp/bpp-core/package.nix @@ -1,10 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, +}: stdenv.mkDerivation rec { pname = "bpp-core"; version = "2.4.1"; - src = fetchFromGitHub { owner = "BioPP"; + src = fetchFromGitHub { + owner = "BioPP"; repo = pname; rev = "v${version}"; sha256 = "0ma2cl677l7s0n5sffh66cy9lxp5wycm50f121g8rx85p95vkgwv"; diff --git a/pkgs/by-name/bp/bpp-phyl/package.nix b/pkgs/by-name/bp/bpp-phyl/package.nix index 62425161747967..c119d389cd45a5 100644 --- a/pkgs/by-name/bp/bpp-phyl/package.nix +++ b/pkgs/by-name/bp/bpp-phyl/package.nix @@ -1,4 +1,10 @@ -{ stdenv, fetchFromGitHub, cmake, bpp-core, bpp-seq }: +{ + stdenv, + fetchFromGitHub, + cmake, + bpp-core, + bpp-seq, +}: stdenv.mkDerivation rec { pname = "bpp-phyl"; @@ -13,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ bpp-core bpp-seq ]; + buildInputs = [ + bpp-core + bpp-seq + ]; postFixup = '' substituteInPlace $out/lib/cmake/${pname}/${pname}-targets.cmake \ diff --git a/pkgs/by-name/bp/bpp-popgen/package.nix b/pkgs/by-name/bp/bpp-popgen/package.nix index f7662766fb2c45..b9bfdc311aabe7 100644 --- a/pkgs/by-name/bp/bpp-popgen/package.nix +++ b/pkgs/by-name/bp/bpp-popgen/package.nix @@ -1,4 +1,10 @@ -{ stdenv, fetchFromGitHub, cmake, bpp-core, bpp-seq }: +{ + stdenv, + fetchFromGitHub, + cmake, + bpp-core, + bpp-seq, +}: stdenv.mkDerivation rec { pname = "bpp-popgen"; @@ -13,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ bpp-core bpp-seq ]; + buildInputs = [ + bpp-core + bpp-seq + ]; postFixup = '' substituteInPlace $out/lib/cmake/${pname}/${pname}-targets.cmake \ diff --git a/pkgs/by-name/bp/bpp-seq/package.nix b/pkgs/by-name/bp/bpp-seq/package.nix index 0699c5316835a2..1f9955a8d8eefb 100644 --- a/pkgs/by-name/bp/bpp-seq/package.nix +++ b/pkgs/by-name/bp/bpp-seq/package.nix @@ -1,4 +1,9 @@ -{ stdenv, fetchFromGitHub, cmake, bpp-core }: +{ + stdenv, + fetchFromGitHub, + cmake, + bpp-core, +}: stdenv.mkDerivation rec { pname = "bpp-seq"; diff --git a/pkgs/by-name/bp/bppsuite/package.nix b/pkgs/by-name/bp/bppsuite/package.nix index a465ca04910d31..cc8e94672f49f1 100644 --- a/pkgs/by-name/bp/bppsuite/package.nix +++ b/pkgs/by-name/bp/bppsuite/package.nix @@ -1,4 +1,12 @@ -{ stdenv, fetchFromGitHub, cmake, bpp-core, bpp-seq, bpp-phyl, bpp-popgen }: +{ + stdenv, + fetchFromGitHub, + cmake, + bpp-core, + bpp-seq, + bpp-phyl, + bpp-popgen, +}: stdenv.mkDerivation rec { pname = "bppsuite"; @@ -13,7 +21,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ bpp-core bpp-seq bpp-phyl bpp-popgen ]; + buildInputs = [ + bpp-core + bpp-seq + bpp-phyl + bpp-popgen + ]; meta = bpp-core.meta // { homepage = "https://github.com/BioPP/bppsuite"; diff --git a/pkgs/by-name/bq/bqn/package.nix b/pkgs/by-name/bq/bqn/package.nix index 5d96a2cbbf9046..d49547e4020d7b 100644 --- a/pkgs/by-name/bq/bqn/package.nix +++ b/pkgs/by-name/bq/bqn/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, makeWrapper -, nodejs +{ + lib, + stdenvNoCC, + fetchFromGitHub, + makeWrapper, + nodejs, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/bq/bqn386/package.nix b/pkgs/by-name/bq/bqn386/package.nix index 35c59a39f37cea..a6a434ffd94c9a 100644 --- a/pkgs/by-name/bq/bqn386/package.nix +++ b/pkgs/by-name/bq/bqn386/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "bqn386"; @@ -11,7 +15,10 @@ stdenvNoCC.mkDerivation { hash = "sha256-f0MbrxdkEiOqod41U07BvdDFDbFCqJuGyDIcx2Y24D0="; }; - outputs = [ "out" "woff2" ]; + outputs = [ + "out" + "woff2" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/br/braa/package.nix b/pkgs/by-name/br/braa/package.nix index b4a482bfa8e417..b08403987090a6 100644 --- a/pkgs/by-name/br/braa/package.nix +++ b/pkgs/by-name/br/braa/package.nix @@ -13,7 +13,7 @@ stdenv.mkDerivation rec { hash = "sha256-GS3kk432BdGx/sLzzjXvotD9Qn4S3U4XtMmM0fWMhGA="; }; - buildInputs = [zlib]; + buildInputs = [ zlib ]; installPhase = '' runHook preInstall @@ -26,7 +26,7 @@ stdenv.mkDerivation rec { homepage = "http://s-tech.elsat.net.pl"; license = licenses.gpl2Only; platforms = platforms.unix; - maintainers = with maintainers; [bycEEE]; + maintainers = with maintainers; [ bycEEE ]; mainProgram = "braa"; }; } diff --git a/pkgs/by-name/br/braincurses/package.nix b/pkgs/by-name/br/braincurses/package.nix index bf346b44816ea6..2a6a67b17aed39 100644 --- a/pkgs/by-name/br/braincurses/package.nix +++ b/pkgs/by-name/br/braincurses/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { pname = "braincurses"; diff --git a/pkgs/by-name/br/brave/make-brave.nix b/pkgs/by-name/br/brave/make-brave.nix index 0321d609effff3..9a95a4422a685d 100644 --- a/pkgs/by-name/br/brave/make-brave.nix +++ b/pkgs/by-name/br/brave/make-brave.nix @@ -94,50 +94,53 @@ let escapeShellArg ; - deps = [ - alsa-lib - at-spi2-atk - at-spi2-core - atk - cairo - cups - dbus - expat - fontconfig - freetype - gdk-pixbuf - glib - gtk3 - gtk4 - libdrm - libX11 - libGL - libxkbcommon - libXScrnSaver - libXcomposite - libXcursor - libXdamage - libXext - libXfixes - libXi - libXrandr - libXrender - libxshmfence - libXtst - libuuid - mesa - nspr - nss - pango - pipewire - udev - wayland - xorg.libxcb - zlib - snappy - libkrb5 - qt6.qtbase - ] ++ optional pulseSupport libpulseaudio ++ optional libvaSupport libva; + deps = + [ + alsa-lib + at-spi2-atk + at-spi2-core + atk + cairo + cups + dbus + expat + fontconfig + freetype + gdk-pixbuf + glib + gtk3 + gtk4 + libdrm + libX11 + libGL + libxkbcommon + libXScrnSaver + libXcomposite + libXcursor + libXdamage + libXext + libXfixes + libXi + libXrandr + libXrender + libxshmfence + libXtst + libuuid + mesa + nspr + nss + pango + pipewire + udev + wayland + xorg.libxcb + zlib + snappy + libkrb5 + qt6.qtbase + ] + ++ optional pulseSupport libpulseaudio + ++ optional libvaSupport libva; rpath = makeLibraryPath deps + ":" + makeSearchPathOutput "lib" "lib64" deps; binpath = makeBinPath deps; @@ -260,16 +263,12 @@ stdenv.mkDerivation { coreutils ] } - ${ - optionalString (enableFeatures != [ ]) '' - --add-flags "--enable-features=${strings.concatStringsSep "," enableFeatures}\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+,WaylandWindowDecorations --enable-wayland-ime=true}}" - '' - } - ${ - optionalString (disableFeatures != [ ]) '' - --add-flags "--disable-features=${strings.concatStringsSep "," disableFeatures}" - '' - } + ${optionalString (enableFeatures != [ ]) '' + --add-flags "--enable-features=${strings.concatStringsSep "," enableFeatures}\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+,WaylandWindowDecorations --enable-wayland-ime=true}}" + ''} + ${optionalString (disableFeatures != [ ]) '' + --add-flags "--disable-features=${strings.concatStringsSep "," disableFeatures}" + ''} --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto}}" ${optionalString vulkanSupport '' --prefix XDG_DATA_DIRS : "${addDriverRunpath.driverLink}/share" diff --git a/pkgs/by-name/br/break-time/package.nix b/pkgs/by-name/br/break-time/package.nix index 2b6263e3223e74..141d8d0b2765fb 100644 --- a/pkgs/by-name/br/break-time/package.nix +++ b/pkgs/by-name/br/break-time/package.nix @@ -1,12 +1,13 @@ -{ fetchFromGitHub -, glib -, gtk3 -, openssl -, pkg-config -, python3 -, rustPlatform -, lib -, wrapGAppsHook3 +{ + fetchFromGitHub, + glib, + gtk3, + openssl, + pkg-config, + python3, + rustPlatform, + lib, + wrapGAppsHook3, }: rustPlatform.buildRustPackage rec { @@ -15,7 +16,7 @@ rustPlatform.buildRustPackage rec { src = fetchFromGitHub { owner = "cdepillabout"; - repo = "break-time"; + repo = "break-time"; rev = "v${version}"; sha256 = "sha256-q79JXaBwd/oKtJPvK2+72pY2YvaR3of2CMC8cF6wwQ8="; }; @@ -44,10 +45,9 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Break timer that forces you to take a break"; mainProgram = "break-time"; - homepage = "https://github.com/cdepillabout/break-time"; - license = with licenses; [ mit ]; + homepage = "https://github.com/cdepillabout/break-time"; + license = with licenses; [ mit ]; maintainers = with maintainers; [ cdepillabout ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } - diff --git a/pkgs/by-name/br/breakpad/package.nix b/pkgs/by-name/br/breakpad/package.nix index 249dab01b229b3..5539543a33ac9f 100644 --- a/pkgs/by-name/br/breakpad/package.nix +++ b/pkgs/by-name/br/breakpad/package.nix @@ -1,11 +1,17 @@ -{ lib, stdenv, fetchgit, zlib }: +{ + lib, + stdenv, + fetchgit, + zlib, +}: let lss = fetchgit { url = "https://chromium.googlesource.com/linux-syscall-support"; rev = "v2022.10.12"; hash = "sha256-rF10v5oH4u9i9vnmFCVVl2Ew3h+QTiOsW64HeB0nRQU="; }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "breakpad"; version = "2023.06.01"; diff --git a/pkgs/by-name/br/breeze-hacked-cursor-theme/package.nix b/pkgs/by-name/br/breeze-hacked-cursor-theme/package.nix index f9a85806aec755..42d1d2125e255e 100644 --- a/pkgs/by-name/br/breeze-hacked-cursor-theme/package.nix +++ b/pkgs/by-name/br/breeze-hacked-cursor-theme/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, inkscape -, xcursorgen -, accentColor ? null -, baseColor ? null -, borderColor ? null -, logoColor ? null +{ + lib, + stdenvNoCC, + fetchFromGitHub, + inkscape, + xcursorgen, + accentColor ? null, + baseColor ? null, + borderColor ? null, + logoColor ? null, }: stdenvNoCC.mkDerivation rec { @@ -20,20 +21,25 @@ stdenvNoCC.mkDerivation rec { hash = "sha256-gm50qgHdbjDYMz/ksbDD8tMqY9AqJ23DKl4rPFNEDX8="; }; - postPatch = '' - patchShebangs build.sh recolor-cursor.sh - substituteInPlace Makefile \ - --replace "~/.icons" "$out/share/icons" - ./recolor-cursor.sh \ - '' + lib.optionalString (accentColor != null) '' - --accent-color "${accentColor}" \ - '' + lib.optionalString (baseColor != null) '' - --base-color "${baseColor}" \ - '' + lib.optionalString (borderColor != null) '' - --border-color "${borderColor}" \ - '' + lib.optionalString (logoColor != null) '' - --logo-color "${logoColor}" - ''; + postPatch = + '' + patchShebangs build.sh recolor-cursor.sh + substituteInPlace Makefile \ + --replace "~/.icons" "$out/share/icons" + ./recolor-cursor.sh \ + '' + + lib.optionalString (accentColor != null) '' + --accent-color "${accentColor}" \ + '' + + lib.optionalString (baseColor != null) '' + --base-color "${baseColor}" \ + '' + + lib.optionalString (borderColor != null) '' + --border-color "${borderColor}" \ + '' + + lib.optionalString (logoColor != null) '' + --logo-color "${logoColor}" + ''; nativeBuildInputs = [ inkscape diff --git a/pkgs/by-name/br/brgenml1cupswrapper/package.nix b/pkgs/by-name/br/brgenml1cupswrapper/package.nix index e309e8e8b26492..5dcf1e7600718e 100644 --- a/pkgs/by-name/br/brgenml1cupswrapper/package.nix +++ b/pkgs/by-name/br/brgenml1cupswrapper/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchurl, makeWrapper, cups, perl, coreutils, gnused, gnugrep -, brgenml1lpr, debugLvl ? "0"}: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + cups, + perl, + coreutils, + gnused, + gnugrep, + brgenml1lpr, + debugLvl ? "0", +}: /* [Setup instructions](http://support.brother.com/g/s/id/linux/en/instruction_prn1a.html). @@ -66,7 +77,14 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ cups perl coreutils gnused gnugrep brgenml1lpr ]; + buildInputs = [ + cups + perl + coreutils + gnused + gnugrep + brgenml1lpr + ]; dontBuild = true; @@ -90,7 +108,6 @@ stdenv.mkDerivation rec { --replace "/etc/cups/ppd" "$out/share/cups/model" ''; - installPhase = '' CUPSFILTER_DIR=$out/lib/cups/filter CUPSPPD_DIR=$out/share/cups/model diff --git a/pkgs/by-name/br/brial/package.nix b/pkgs/by-name/br/brial/package.nix index 6ec28ba1c2266b..d82ac052d73749 100644 --- a/pkgs/by-name/br/brial/package.nix +++ b/pkgs/by-name/br/brial/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, boost -, m4ri -, gd +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + boost, + m4ri, + gd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/br/briar-desktop/package.nix b/pkgs/by-name/br/briar-desktop/package.nix index 9ce9801ae2ed05..55c5bcedce1035 100644 --- a/pkgs/by-name/br/briar-desktop/package.nix +++ b/pkgs/by-name/br/briar-desktop/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, openjdk -, libnotify -, makeWrapper -, tor -, p7zip -, bash -, writeScript +{ + lib, + stdenv, + fetchurl, + openjdk, + libnotify, + makeWrapper, + tor, + p7zip, + bash, + writeScript, }: let @@ -38,9 +39,11 @@ stdenv.mkDerivation rec { cp ${src} $out/lib/briar-desktop.jar makeWrapper ${openjdk}/bin/java $out/bin/briar-desktop \ --add-flags "-jar $out/lib/briar-desktop.jar" \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ - libnotify - ]}" + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + libnotify + ] + }" ''; fixupPhase = '' diff --git a/pkgs/by-name/br/brickd/package.nix b/pkgs/by-name/br/brickd/package.nix index be087b0525bcc2..95eafd3d7a97ea 100644 --- a/pkgs/by-name/br/brickd/package.nix +++ b/pkgs/by-name/br/brickd/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libusb1, pkg-config, pmutils, udev} : +{ + lib, + stdenv, + fetchFromGitHub, + libusb1, + pkg-config, + pmutils, + udev, +}: let version = "2.1.1"; @@ -22,7 +30,11 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libusb1 pmutils udev ]; + buildInputs = [ + libusb1 + pmutils + udev + ]; # shell thing didn't work so i replaced it using nix prePatch = '' diff --git a/pkgs/by-name/br/bridge-utils/package.nix b/pkgs/by-name/br/bridge-utils/package.nix index b10cca4cc592d2..1a2acae1f3f6fc 100644 --- a/pkgs/by-name/br/bridge-utils/package.nix +++ b/pkgs/by-name/br/bridge-utils/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, autoreconfHook, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "bridge-utils"; diff --git a/pkgs/by-name/br/brig/package.nix b/pkgs/by-name/br/brig/package.nix index b20543c0c58a40..f4914eeda8736f 100644 --- a/pkgs/by-name/br/brig/package.nix +++ b/pkgs/by-name/br/brig/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -21,16 +22,19 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" ] ++ - lib.mapAttrsToList (n: v: "-X github.com/sahib/brig/version.${n}=${v}") - { - Major = lib.versions.major version; - Minor = lib.versions.minor version; - Patch = lib.versions.patch version; - ReleaseType = ""; - BuildTime = "1970-01-01T00:00:00+0000"; - GitRev = src.rev; - }; + ldflags = + [ + "-s" + "-w" + ] + ++ lib.mapAttrsToList (n: v: "-X github.com/sahib/brig/version.${n}=${v}") { + Major = lib.versions.major version; + Minor = lib.versions.minor version; + Patch = lib.versions.patch version; + ReleaseType = ""; + BuildTime = "1970-01-01T00:00:00+0000"; + GitRev = src.rev; + }; postInstall = '' installShellCompletion --cmd brig \ diff --git a/pkgs/by-name/br/brigand/package.nix b/pkgs/by-name/br/brigand/package.nix index 3c0778de1d30ad..d1cdee16f2e17f 100644 --- a/pkgs/by-name/br/brigand/package.nix +++ b/pkgs/by-name/br/brigand/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation { pname = "brigand"; diff --git a/pkgs/by-name/br/brightnessctl/package.nix b/pkgs/by-name/br/brightnessctl/package.nix index 460b8199d697ad..35c5935f4f4ded 100644 --- a/pkgs/by-name/br/brightnessctl/package.nix +++ b/pkgs/by-name/br/brightnessctl/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, systemd }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + systemd, +}: stdenv.mkDerivation rec { pname = "brightnessctl"; @@ -16,7 +22,11 @@ stdenv.mkDerivation rec { --replace "pkg-config" "$PKG_CONFIG" ''; - makeFlags = [ "PREFIX=" "DESTDIR=$(out)" "ENABLE_SYSTEMD=1" ]; + makeFlags = [ + "PREFIX=" + "DESTDIR=$(out)" + "ENABLE_SYSTEMD=1" + ]; nativeBuildInputs = [ pkg-config ]; buildInputs = [ systemd ]; diff --git a/pkgs/by-name/br/brill/package.nix b/pkgs/by-name/br/brill/package.nix index 0ea130064e3d04..0fd0c940a83903 100644 --- a/pkgs/by-name/br/brill/package.nix +++ b/pkgs/by-name/br/brill/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "brill"; diff --git a/pkgs/by-name/br/brillo/package.nix b/pkgs/by-name/br/brillo/package.nix index 658b15b70e9301..fb4358628cdbf0 100644 --- a/pkgs/by-name/br/brillo/package.nix +++ b/pkgs/by-name/br/brillo/package.nix @@ -1,13 +1,20 @@ -{ lib, stdenv, fetchFromGitLab , go-md2man, coreutils, substituteAll }: +{ + lib, + stdenv, + fetchFromGitLab, + go-md2man, + coreutils, + substituteAll, +}: stdenv.mkDerivation rec { pname = "brillo"; version = "1.4.12"; src = fetchFromGitLab { - owner= "cameronnemo"; - repo= "brillo"; - rev= "v${version}"; + owner = "cameronnemo"; + repo = "brillo"; + rev = "v${version}"; hash = "sha256-dKGNioWGVAFuB4kySO+QGTnstyAD0bt4/6FBVwuRxJo="; }; @@ -20,7 +27,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ go-md2man ]; - makeFlags = [ "PREFIX=$(out)" "AADIR=$(out)/etc/apparmor.d" ]; + makeFlags = [ + "PREFIX=$(out)" + "AADIR=$(out)/etc/apparmor.d" + ]; installTargets = [ "install-dist" ]; @@ -28,7 +38,10 @@ stdenv.mkDerivation rec { description = "Backlight and Keyboard LED control tool"; homepage = "https://gitlab.com/cameronnemo/brillo"; mainProgram = "brillo"; - license = [ licenses.gpl3 licenses.bsd0 ]; + license = [ + licenses.gpl3 + licenses.bsd0 + ]; platforms = platforms.linux; maintainers = [ maintainers.alexarice ]; }; diff --git a/pkgs/by-name/br/brise/fetchPackages.nix b/pkgs/by-name/br/brise/fetchPackages.nix index 50ad1113aa93b4..bcf7a5a94d65af 100644 --- a/pkgs/by-name/br/brise/fetchPackages.nix +++ b/pkgs/by-name/br/brise/fetchPackages.nix @@ -1,130 +1,172 @@ fetchFromGitHub: # generated using https://gist.github.com/sifmelcara/895c71f99500b9d56d68e9a866b58821 '' -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-array"; - rev = "d10f2f8b2aec7c7e736ace01e8a399e5ae5e7c3a"; - sha256 = "sha256-4t6+gh2V57SueDp9Tn6vTuxQCZNGzjLdJEhzIEqRjdI="; -}} array -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-bopomofo"; - rev = "7046ffe42b46915947117f80d901fb9a6e19c1a7"; - sha256 = "09w8jl2dlgp72k49x0l2jiaqb359v576kai4xww6cljgr24ng8pl"; -}} bopomofo -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-cangjie"; - rev = "64242be99c1e6793c9f40fef296a81d07a84e976"; - sha256 = "0v5sk8zrm5p5gg8lszqm0imj9jswjlnfq87nw6m9pg5h5al230ja"; -}} cangjie -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-combo-pinyin"; - rev = "97a7dc4670e0f90ad28e7d67c1543f4f0adc531d"; - sha256 = "0y8iyvq7z6xj3lk2ppk4ggz297wn1r2xxbv53f2710jc7gyzf04q"; -}} combo-pinyin -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-double-pinyin"; - rev = "1b75af4239897fd1e4c99d625b62093e66baff14"; - sha256 = "0p54qx5a6rr55hl997kdcfxjczd9lcddrc5xsy7nhlfyc6108s2v"; -}} double-pinyin -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-emoji"; - rev = "7e527056fe055237fee59463e0d445f3909aaf0c"; - sha256 = "04d35n254viw29yyjf3ml7xljmi63sqgg870swlbi5bikcx7n9jf"; -}} emoji -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-essay"; - rev = "595e35756d16d57d09405e243302b65b4384b5b4"; - sha256 = "10kqhvrz8x17b2pf6x2x2znz5y6cj05c4rgwi1f0xhxiyrgjw9gm"; -}} essay -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-ipa"; - rev = "9e02f8a02e9febb7b2df25f6906881a1df934811"; - sha256 = "1g4v4j1gnv1qspfz88liwj1aa4gaa3aax0x2cif4vxicsm7w372m"; -}} ipa -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-jyutping"; - rev = "3cc76e6e15cc05f1f94b89e750c21f87ce8fc0e4"; - sha256 = "1yggz0yb84z8810s2gmsxkm9lh57fdzddx5v2rb5mqcwnimsd6ap"; -}} jyutping -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-luna-pinyin"; - rev = "da00c3a6f932f094666e98a09f6ce9c7d74c334c"; - sha256 = "0q3g1hj9bay5865h3pz7gv46d7wfka1jdxnddxcbp4zn7gjpsd48"; -}} luna-pinyin -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-middle-chinese"; - rev = "6f9731bac8f289f77d35f1090159f1937e38c1f7"; - sha256 = "0xd9iwk4j5043gfmp7rb57hbarfm6sxr32wiasi6p3c5g355zn89"; -}} middle-chinese -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-pinyin-simp"; - rev = "38c08403c22845f7e2965c1d7a1514b41755d7dc"; - sha256 = "1c0cqljx3d93w27y2flxyqcfd3rd9fvixbw6mxgfjzdb3s42bn8h"; -}} pinyin-simp -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-prelude"; - rev = "120c2aa73b1b5e1bce904901bf13f506295004a5"; - sha256 = "1aah9z58gkqrc18zadsq598ybj8ra22bgka3gma2jmi3rls2znq4"; -}} prelude -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-quick"; - rev = "638abf270e121bc2bfc6029a14ee85a3f4c2188b"; - sha256 = "0l1pma0yxrypnb5cq7jiczy0wa42kdqsc1brqkkccdnp08pa1p1m"; -}} quick -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-scj"; - rev = "6b74ce14be0464bf076d7adc40aea4b120f233ec"; - sha256 = "0lr92knr41mlqd1s0g2lh2h2qr8xka1s46x7iv4d6ghjf0id4gz6"; -}} scj -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-soutzoe"; - rev = "3ab93d1b9ca9ca7cf17ff32bb4418b7a095afc3c"; - sha256 = "1glbvgzx4psasq23511k8ymd7mf1pqvm3z18nzszhs00iif66s3m"; -}} soutzoe -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-stenotype"; - rev = "766f22565f83f5c63c0ea195c936779ec6ae824d"; - sha256 = "0jsvfq7xim99zs5imyk7rpknlaimk6nlxy38fmfxa1r843781mfd"; -}} stenotype -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-stroke"; - rev = "e048967a4c1b956575828f1a20e565efed4b1137"; - sha256 = "10asdz5bj12pnji7afzls6jd9dn2v90l2dgdjf0jfp2kfzd6pxnl"; -}} stroke -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-terra-pinyin"; - rev = "e303507e728def38739f5761c50722eae1f06dd5"; - sha256 = "1krbmx2iq3zw4q1x4aa9c72b9xgrnjrhyxa4h5hnq5l29p9qms4d"; -}} terra-pinyin -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-wubi"; - rev = "97b7d9f93378e98fd11167bd80d54c40e67076aa"; - sha256 = "1cdpbqqkqjbizja0w3f7a826a5bxb39nlf9qf2130x9havmkc89z"; -}} wubi -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-wugniu"; - rev = "de40b29f8218cc852bf82b315c7070f1d50bda02"; - sha256 = "1m7miwsqpy49cgqd1bl7z5lkkirj3lc2bdwd1zqfg5zbgfwn0rp8"; -}} wugniu + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-array"; + rev = "d10f2f8b2aec7c7e736ace01e8a399e5ae5e7c3a"; + sha256 = "sha256-4t6+gh2V57SueDp9Tn6vTuxQCZNGzjLdJEhzIEqRjdI="; + } + } array + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-bopomofo"; + rev = "7046ffe42b46915947117f80d901fb9a6e19c1a7"; + sha256 = "09w8jl2dlgp72k49x0l2jiaqb359v576kai4xww6cljgr24ng8pl"; + } + } bopomofo + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-cangjie"; + rev = "64242be99c1e6793c9f40fef296a81d07a84e976"; + sha256 = "0v5sk8zrm5p5gg8lszqm0imj9jswjlnfq87nw6m9pg5h5al230ja"; + } + } cangjie + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-combo-pinyin"; + rev = "97a7dc4670e0f90ad28e7d67c1543f4f0adc531d"; + sha256 = "0y8iyvq7z6xj3lk2ppk4ggz297wn1r2xxbv53f2710jc7gyzf04q"; + } + } combo-pinyin + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-double-pinyin"; + rev = "1b75af4239897fd1e4c99d625b62093e66baff14"; + sha256 = "0p54qx5a6rr55hl997kdcfxjczd9lcddrc5xsy7nhlfyc6108s2v"; + } + } double-pinyin + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-emoji"; + rev = "7e527056fe055237fee59463e0d445f3909aaf0c"; + sha256 = "04d35n254viw29yyjf3ml7xljmi63sqgg870swlbi5bikcx7n9jf"; + } + } emoji + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-essay"; + rev = "595e35756d16d57d09405e243302b65b4384b5b4"; + sha256 = "10kqhvrz8x17b2pf6x2x2znz5y6cj05c4rgwi1f0xhxiyrgjw9gm"; + } + } essay + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-ipa"; + rev = "9e02f8a02e9febb7b2df25f6906881a1df934811"; + sha256 = "1g4v4j1gnv1qspfz88liwj1aa4gaa3aax0x2cif4vxicsm7w372m"; + } + } ipa + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-jyutping"; + rev = "3cc76e6e15cc05f1f94b89e750c21f87ce8fc0e4"; + sha256 = "1yggz0yb84z8810s2gmsxkm9lh57fdzddx5v2rb5mqcwnimsd6ap"; + } + } jyutping + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-luna-pinyin"; + rev = "da00c3a6f932f094666e98a09f6ce9c7d74c334c"; + sha256 = "0q3g1hj9bay5865h3pz7gv46d7wfka1jdxnddxcbp4zn7gjpsd48"; + } + } luna-pinyin + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-middle-chinese"; + rev = "6f9731bac8f289f77d35f1090159f1937e38c1f7"; + sha256 = "0xd9iwk4j5043gfmp7rb57hbarfm6sxr32wiasi6p3c5g355zn89"; + } + } middle-chinese + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-pinyin-simp"; + rev = "38c08403c22845f7e2965c1d7a1514b41755d7dc"; + sha256 = "1c0cqljx3d93w27y2flxyqcfd3rd9fvixbw6mxgfjzdb3s42bn8h"; + } + } pinyin-simp + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-prelude"; + rev = "120c2aa73b1b5e1bce904901bf13f506295004a5"; + sha256 = "1aah9z58gkqrc18zadsq598ybj8ra22bgka3gma2jmi3rls2znq4"; + } + } prelude + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-quick"; + rev = "638abf270e121bc2bfc6029a14ee85a3f4c2188b"; + sha256 = "0l1pma0yxrypnb5cq7jiczy0wa42kdqsc1brqkkccdnp08pa1p1m"; + } + } quick + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-scj"; + rev = "6b74ce14be0464bf076d7adc40aea4b120f233ec"; + sha256 = "0lr92knr41mlqd1s0g2lh2h2qr8xka1s46x7iv4d6ghjf0id4gz6"; + } + } scj + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-soutzoe"; + rev = "3ab93d1b9ca9ca7cf17ff32bb4418b7a095afc3c"; + sha256 = "1glbvgzx4psasq23511k8ymd7mf1pqvm3z18nzszhs00iif66s3m"; + } + } soutzoe + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-stenotype"; + rev = "766f22565f83f5c63c0ea195c936779ec6ae824d"; + sha256 = "0jsvfq7xim99zs5imyk7rpknlaimk6nlxy38fmfxa1r843781mfd"; + } + } stenotype + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-stroke"; + rev = "e048967a4c1b956575828f1a20e565efed4b1137"; + sha256 = "10asdz5bj12pnji7afzls6jd9dn2v90l2dgdjf0jfp2kfzd6pxnl"; + } + } stroke + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-terra-pinyin"; + rev = "e303507e728def38739f5761c50722eae1f06dd5"; + sha256 = "1krbmx2iq3zw4q1x4aa9c72b9xgrnjrhyxa4h5hnq5l29p9qms4d"; + } + } terra-pinyin + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-wubi"; + rev = "97b7d9f93378e98fd11167bd80d54c40e67076aa"; + sha256 = "1cdpbqqkqjbizja0w3f7a826a5bxb39nlf9qf2130x9havmkc89z"; + } + } wubi + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-wugniu"; + rev = "de40b29f8218cc852bf82b315c7070f1d50bda02"; + sha256 = "1m7miwsqpy49cgqd1bl7z5lkkirj3lc2bdwd1zqfg5zbgfwn0rp8"; + } + } wugniu '' diff --git a/pkgs/by-name/br/brise/package.nix b/pkgs/by-name/br/brise/package.nix index 45f86f6be21cf8..4d4ab988cfec9e 100644 --- a/pkgs/by-name/br/brise/package.nix +++ b/pkgs/by-name/br/brise/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, librime }: +{ + lib, + stdenv, + fetchFromGitHub, + librime, +}: stdenv.mkDerivation { pname = "brise"; @@ -21,7 +26,10 @@ stdenv.mkDerivation { # since nix won't allow networking during 'make' preBuild = import ./fetchPackages.nix fetchFromGitHub; - makeFlags = [ "BRISE_BUILD_BINARIES=yes" "PREFIX=$(out)" ]; + makeFlags = [ + "BRISE_BUILD_BINARIES=yes" + "PREFIX=$(out)" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/br/briss/package.nix b/pkgs/by-name/br/briss/package.nix index 801b8f5a4862c0..73cde5730b8c26 100644 --- a/pkgs/by-name/br/briss/package.nix +++ b/pkgs/by-name/br/briss/package.nix @@ -1,6 +1,12 @@ # The releases of this project are apparently precompiled to .jar files. -{ lib, stdenv, fetchurl, jre, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "briss"; @@ -10,7 +16,7 @@ stdenv.mkDerivation rec { sha256 = "45dd668a9ceb9cd59529a9fefe422a002ee1554a61be07e6fc8b3baf33d733d9"; }; - nativeBuildInputs = [makeWrapper]; + nativeBuildInputs = [ makeWrapper ]; installPhase = '' mkdir -p "$out/bin"; diff --git a/pkgs/by-name/br/bristol/package.nix b/pkgs/by-name/br/bristol/package.nix index 94754a3b1cc518..2251225e68d7b0 100644 --- a/pkgs/by-name/br/bristol/package.nix +++ b/pkgs/by-name/br/bristol/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, alsa-lib, libjack2, pkg-config, libpulseaudio, xorg, copyDesktopItems, makeDesktopItem }: +{ + lib, + stdenv, + fetchurl, + alsa-lib, + libjack2, + pkg-config, + libpulseaudio, + xorg, + copyDesktopItems, + makeDesktopItem, +}: stdenv.mkDerivation rec { pname = "bristol"; @@ -9,7 +20,10 @@ stdenv.mkDerivation rec { sha256 = "1fi2m4gmvxdi260821y09lxsimq82yv4k5bbgk3kyc3x1nyhn7vx"; }; - nativeBuildInputs = [ pkg-config copyDesktopItems ]; + nativeBuildInputs = [ + pkg-config + copyDesktopItems + ]; buildInputs = [ alsa-lib libjack2 @@ -54,7 +68,10 @@ stdenv.mkDerivation rec { description = "Range of synthesiser, electric piano and organ emulations"; homepage = "https://bristol.sourceforge.net"; license = licenses.gpl3; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ ]; }; } diff --git a/pkgs/by-name/br/brlaser/package.nix b/pkgs/by-name/br/brlaser/package.nix index c0f4e1854379d5..fff6673a9cf8a9 100644 --- a/pkgs/by-name/br/brlaser/package.nix +++ b/pkgs/by-name/br/brlaser/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, zlib, cups }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, + cups, +}: stdenv.mkDerivation rec { pname = "brlaser"; @@ -12,49 +19,54 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ zlib cups ]; + buildInputs = [ + zlib + cups + ]; - cmakeFlags = [ "-DCUPS_SERVER_BIN=lib/cups" "-DCUPS_DATA_DIR=share/cups" ]; + cmakeFlags = [ + "-DCUPS_SERVER_BIN=lib/cups" + "-DCUPS_DATA_DIR=share/cups" + ]; meta = with lib; { description = "CUPS driver for Brother laser printers"; - longDescription = - '' - Although most Brother printers support a standard printer language such as PCL or PostScript, not all do. If you have a monochrome Brother laser printer (or multi-function device) and the other open source drivers don't work, this one might help. + longDescription = '' + Although most Brother printers support a standard printer language such as PCL or PostScript, not all do. If you have a monochrome Brother laser printer (or multi-function device) and the other open source drivers don't work, this one might help. - This driver is known to work with these printers: + This driver is known to work with these printers: - Brother DCP-1510 - Brother DCP-1602 - Brother DCP-7030 - Brother DCP-7040 - Brother DCP-7055 - Brother DCP-7055W - Brother DCP-7060D - Brother DCP-7065DN - Brother DCP-7080 - Brother DCP-L2500D - Brother DCP-L2520D - Brother DCP-L2540DW - Brother HL-1110 - Brother HL-1200 - Brother HL-2030 - Brother HL-2140 - Brother HL-2220 - Brother HL-2270DW - Brother HL-5030 - Brother HL-L2300D - Brother HL-L2320D - Brother HL-L2340D - Brother HL-L2360D - Brother MFC-1910W - Brother MFC-7240 - Brother MFC-7360N - Brother MFC-7365DN - Brother MFC-7840W - Brother MFC-L2710DW - Lenovo M7605D - ''; + Brother DCP-1510 + Brother DCP-1602 + Brother DCP-7030 + Brother DCP-7040 + Brother DCP-7055 + Brother DCP-7055W + Brother DCP-7060D + Brother DCP-7065DN + Brother DCP-7080 + Brother DCP-L2500D + Brother DCP-L2520D + Brother DCP-L2540DW + Brother HL-1110 + Brother HL-1200 + Brother HL-2030 + Brother HL-2140 + Brother HL-2220 + Brother HL-2270DW + Brother HL-5030 + Brother HL-L2300D + Brother HL-L2320D + Brother HL-L2340D + Brother HL-L2360D + Brother MFC-1910W + Brother MFC-7240 + Brother MFC-7360N + Brother MFC-7365DN + Brother MFC-7840W + Brother MFC-L2710DW + Lenovo M7605D + ''; homepage = "https://github.com/pdewacht/brlaser"; license = licenses.gpl2Plus; platforms = platforms.linux; diff --git a/pkgs/by-name/br/brltty/package.nix b/pkgs/by-name/br/brltty/package.nix index 745f39b4363a71..1663be03aa5f76 100644 --- a/pkgs/by-name/br/brltty/package.nix +++ b/pkgs/by-name/br/brltty/package.nix @@ -1,7 +1,20 @@ -{ lib, stdenv, fetchurl, pkg-config, python3, bluez -, tcl, acl, kmod, coreutils, shadow, util-linux -, alsaSupport ? stdenv.hostPlatform.isLinux, alsa-lib -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, systemd +{ + lib, + stdenv, + fetchurl, + pkg-config, + python3, + bluez, + tcl, + acl, + kmod, + coreutils, + shadow, + util-linux, + alsaSupport ? stdenv.hostPlatform.isLinux, + alsa-lib, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, }: stdenv.mkDerivation rec { @@ -13,10 +26,13 @@ stdenv.mkDerivation rec { sha256 = "E+j2mb8UTuGx6PkAOt03hQkvf1XvEHxJEuPBT2zMpPw="; }; - nativeBuildInputs = [ pkg-config python3.pkgs.cython python3.pkgs.setuptools tcl ]; - buildInputs = [ bluez ] - ++ lib.optional alsaSupport alsa-lib - ++ lib.optional systemdSupport systemd; + nativeBuildInputs = [ + pkg-config + python3.pkgs.cython + python3.pkgs.setuptools + tcl + ]; + buildInputs = [ bluez ] ++ lib.optional alsaSupport alsa-lib ++ lib.optional systemdSupport systemd; meta = { description = "Access software for a blind person using a braille display"; @@ -49,7 +65,11 @@ stdenv.mkDerivation rec { "--with-updatable-directory=/var/lib/brltty" "--with-api-socket-path=/var/lib/BrlAPI" ]; - installFlags = [ "install-systemd" "install-udev" "install-polkit" ]; + installFlags = [ + "install-systemd" + "install-udev" + "install-polkit" + ]; preConfigure = '' substituteInPlace configure --replace /sbin/ldconfig ldconfig diff --git a/pkgs/by-name/br/brmodelo/package.nix b/pkgs/by-name/br/brmodelo/package.nix index 09225fcd5948ce..bcc9e5c2df60ba 100644 --- a/pkgs/by-name/br/brmodelo/package.nix +++ b/pkgs/by-name/br/brmodelo/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, ant -, jdk8 -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, strip-nondeterminism -, stripJavaArchivesHook +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + ant, + jdk8, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + strip-nondeterminism, + stripJavaArchivesHook, }: stdenv.mkDerivation (finalAttrs: { @@ -78,7 +79,16 @@ stdenv.mkDerivation (finalAttrs: { exec = "brmodelo"; icon = "brmodelo"; comment = finalAttrs.meta.description; - categories = [ "Development" "Education" "Database" "2DGraphics" "ComputerScience" "DataVisualization" "Engineering" "Java" ]; + categories = [ + "Development" + "Education" + "Database" + "2DGraphics" + "ComputerScience" + "DataVisualization" + "Engineering" + "Java" + ]; }) ]; diff --git a/pkgs/by-name/br/broadcom-bt-firmware/package.nix b/pkgs/by-name/br/broadcom-bt-firmware/package.nix index 073d443bee414f..aacf0451891f3a 100644 --- a/pkgs/by-name/br/broadcom-bt-firmware/package.nix +++ b/pkgs/by-name/br/broadcom-bt-firmware/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenvNoCC, fetchurl, cabextract, bt-fw-converter }: +{ + lib, + stdenvNoCC, + fetchurl, + cabextract, + bt-fw-converter, +}: stdenvNoCC.mkDerivation rec { pname = "broadcom-bt-firmware"; @@ -9,7 +15,10 @@ stdenvNoCC.mkDerivation rec { sha256 = "1b1qjwxjk4y91l3iz157kms8601n0mmiik32cs6w9b1q4sl4pxx9"; }; - nativeBuildInputs = [ cabextract bt-fw-converter ]; + nativeBuildInputs = [ + cabextract + bt-fw-converter + ]; unpackCmd = '' mkdir -p ${pname}-${version} diff --git a/pkgs/by-name/br/broadlink-cli/package.nix b/pkgs/by-name/br/broadlink-cli/package.nix index c9438ff3583f32..6056c5ea33750e 100644 --- a/pkgs/by-name/br/broadlink-cli/package.nix +++ b/pkgs/by-name/br/broadlink-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "broadlink-cli"; @@ -7,8 +11,8 @@ python3Packages.buildPythonApplication rec { # the tools are available as part of the source distribution from GH but # not pypi, so we have to fetch them here. src = fetchFromGitHub { - owner = "mjg59"; - repo = "python-broadlink"; + owner = "mjg59"; + repo = "python-broadlink"; rev = "refs/tags/${version}"; sha256 = "sha256-fqhi4K8Ceh8Rs0ExteCfAuVfEamFjMCjCFm6DRAJDmI="; }; diff --git a/pkgs/by-name/br/brogue-ce/package.nix b/pkgs/by-name/br/brogue-ce/package.nix index 32f1dda3e4854e..09f2ac7c7d942b 100644 --- a/pkgs/by-name/br/brogue-ce/package.nix +++ b/pkgs/by-name/br/brogue-ce/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeDesktopItem -, copyDesktopItems -, SDL2 -, SDL2_image +{ + lib, + stdenv, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + SDL2, + SDL2_image, }: stdenv.mkDerivation (finalAttrs: { @@ -34,15 +35,20 @@ stdenv.mkDerivation (finalAttrs: { makeFlags = [ "DATADIR=$(out)/opt/brogue-ce" ]; - desktopItems = [(makeDesktopItem { - name = "brogue-ce"; - desktopName = "Brogue CE"; - genericName = "Roguelike"; - comment = "Brave the Dungeons of Doom!"; - icon = "brogue-ce"; - exec = "brogue-ce"; - categories = [ "Game" "AdventureGame" ]; - })]; + desktopItems = [ + (makeDesktopItem { + name = "brogue-ce"; + desktopName = "Brogue CE"; + genericName = "Roguelike"; + comment = "Brave the Dungeons of Doom!"; + icon = "brogue-ce"; + exec = "brogue-ce"; + categories = [ + "Game" + "AdventureGame" + ]; + }) + ]; installPhase = '' runHook preInstall @@ -58,7 +64,10 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "brogue-ce"; homepage = "https://github.com/tmewett/BrogueCE"; license = licenses.agpl3Plus; - maintainers = with maintainers; [ AndersonTorres fgaz ]; + maintainers = with maintainers; [ + AndersonTorres + fgaz + ]; platforms = platforms.all; }; }) diff --git a/pkgs/by-name/br/brogue/package.nix b/pkgs/by-name/br/brogue/package.nix index bf19e6c4225b61..7f133c1dae99f8 100644 --- a/pkgs/by-name/br/brogue/package.nix +++ b/pkgs/by-name/br/brogue/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, fetchpatch, SDL, ncurses, libtcod, makeDesktopItem }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + SDL, + ncurses, + libtcod, + makeDesktopItem, +}: stdenv.mkDerivation (finalAttrs: { pname = "brogue"; @@ -26,7 +35,11 @@ stdenv.mkDerivation (finalAttrs: { rm -rf src/libtcod* ''; - buildInputs = [ SDL ncurses libtcod ]; + buildInputs = [ + SDL + ncurses + libtcod + ]; desktopItem = makeDesktopItem { name = "brogue"; @@ -35,7 +48,10 @@ stdenv.mkDerivation (finalAttrs: { comment = "Brave the Dungeons of Doom!"; icon = "brogue"; exec = "brogue"; - categories = [ "Game" "AdventureGame" ]; + categories = [ + "Game" + "AdventureGame" + ]; }; installPhase = '' @@ -47,14 +63,20 @@ stdenv.mkDerivation (finalAttrs: { ''; # fix crash; shouldn’t be a security risk because it’s an offline game - hardeningDisable = [ "stackprotector" "fortify" ]; + hardeningDisable = [ + "stackprotector" + "fortify" + ]; meta = with lib; { description = "Roguelike game"; mainProgram = "brogue"; homepage = "https://sites.google.com/site/broguegame/"; license = licenses.agpl3Plus; - maintainers = with maintainers; [ AndersonTorres fgaz ]; + maintainers = with maintainers; [ + AndersonTorres + fgaz + ]; platforms = [ "x86_64-linux" ]; }; }) diff --git a/pkgs/by-name/br/bront_fonts/package.nix b/pkgs/by-name/br/bront_fonts/package.nix index 36e6adb380dfd8..fe31a6e0bfabcd 100644 --- a/pkgs/by-name/br/bront_fonts/package.nix +++ b/pkgs/by-name/br/bront_fonts/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchFromGitHub }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "bront_fonts"; @@ -19,7 +23,10 @@ stdenvNoCC.mkDerivation { description = "Bront Fonts"; longDescription = "Ubuntu Mono Bront and DejaVu Sans Mono Bront fonts."; homepage = "https://github.com/chrismwendt/bront"; - license = with licenses; [ bitstreamVera ufl ]; + license = with licenses; [ + bitstreamVera + ufl + ]; platforms = platforms.all; maintainers = [ maintainers.grburst ]; }; diff --git a/pkgs/by-name/br/brook/package.nix b/pkgs/by-name/br/brook/package.nix index 6bb6f9ab8bcf33..19ed8ed89519fa 100644 --- a/pkgs/by-name/br/brook/package.nix +++ b/pkgs/by-name/br/brook/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "brook"; diff --git a/pkgs/by-name/br/broom/package.nix b/pkgs/by-name/br/broom/package.nix index fa3e7af0927d18..6c7d0cb264c516 100644 --- a/pkgs/by-name/br/broom/package.nix +++ b/pkgs/by-name/br/broom/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-zNklqGjMt89b+JOZfKjTO6c75SXO10e7YtQOqqQZpnA="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Interactive CLI tool for managing local git branches"; diff --git a/pkgs/by-name/br/broot/package.nix b/pkgs/by-name/br/broot/package.nix index c1c705a7d40b48..f42b934c69090f 100644 --- a/pkgs/by-name/br/broot/package.nix +++ b/pkgs/by-name/br/broot/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, installShellFiles -, makeWrapper -, pkg-config -, libgit2 -, oniguruma -, zlib -, buildPackages -, withClipboard ? true -, withTrash ? !stdenv.hostPlatform.isDarwin +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + installShellFiles, + makeWrapper, + pkg-config, + libgit2, + oniguruma, + zlib, + buildPackages, + withClipboard ? true, + withTrash ? !stdenv.hostPlatform.isDarwin, }: rustPlatform.buildRustPackage rec { @@ -33,9 +34,14 @@ rustPlatform.buildRustPackage rec { ]; # TODO: once https://github.com/Canop/broot/issues/956 is released, oniguruma can be removed. - buildInputs = [ libgit2 oniguruma ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - zlib - ]; + buildInputs = + [ + libgit2 + oniguruma + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + zlib + ]; buildFeatures = lib.optionals withTrash [ "trash" ] ++ lib.optionals withClipboard [ "clipboard" ]; @@ -48,34 +54,36 @@ rustPlatform.buildRustPackage rec { --replace "#version" "${version}" ''; - postInstall = lib.optionalString (stdenv.hostPlatform.emulatorAvailable buildPackages) '' - # Install shell function for bash. - ${stdenv.hostPlatform.emulator buildPackages} $out/bin/broot --print-shell-function bash > br.bash - install -Dm0444 -t $out/etc/profile.d br.bash + postInstall = + lib.optionalString (stdenv.hostPlatform.emulatorAvailable buildPackages) '' + # Install shell function for bash. + ${stdenv.hostPlatform.emulator buildPackages} $out/bin/broot --print-shell-function bash > br.bash + install -Dm0444 -t $out/etc/profile.d br.bash - # Install shell function for zsh. - ${stdenv.hostPlatform.emulator buildPackages} $out/bin/broot --print-shell-function zsh > br.zsh - install -Dm0444 br.zsh $out/share/zsh/site-functions/br + # Install shell function for zsh. + ${stdenv.hostPlatform.emulator buildPackages} $out/bin/broot --print-shell-function zsh > br.zsh + install -Dm0444 br.zsh $out/share/zsh/site-functions/br - # Install shell function for fish - ${stdenv.hostPlatform.emulator buildPackages} $out/bin/broot --print-shell-function fish > br.fish - install -Dm0444 -t $out/share/fish/vendor_functions.d br.fish + # Install shell function for fish + ${stdenv.hostPlatform.emulator buildPackages} $out/bin/broot --print-shell-function fish > br.fish + install -Dm0444 -t $out/share/fish/vendor_functions.d br.fish - '' + '' - # install shell completion files - OUT_DIR=$releaseDir/build/broot-*/out + '' + + '' + # install shell completion files + OUT_DIR=$releaseDir/build/broot-*/out - installShellCompletion --bash $OUT_DIR/{br,broot}.bash - installShellCompletion --fish $OUT_DIR/{br,broot}.fish - installShellCompletion --zsh $OUT_DIR/{_br,_broot} + installShellCompletion --bash $OUT_DIR/{br,broot}.bash + installShellCompletion --fish $OUT_DIR/{br,broot}.fish + installShellCompletion --zsh $OUT_DIR/{_br,_broot} - installManPage man/broot.1 + installManPage man/broot.1 - # Do not nag users about installing shell integration, since - # it is impure. - wrapProgram $out/bin/broot \ - --set BR_INSTALL no - ''; + # Do not nag users about installing shell integration, since + # it is impure. + wrapProgram $out/bin/broot \ + --set BR_INSTALL no + ''; doInstallCheck = true; installCheckPhase = '' diff --git a/pkgs/by-name/br/brotli/package.nix b/pkgs/by-name/br/brotli/package.nix index 0a7bbfe1746c6b..ec7ea22ddaa46a 100644 --- a/pkgs/by-name/br/brotli/package.nix +++ b/pkgs/by-name/br/brotli/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, staticOnly ? stdenv.hostPlatform.isStatic -, testers +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + staticOnly ? stdenv.hostPlatform.isStatic, + testers, }: # ?TODO: there's also python lib in there @@ -35,7 +36,11 @@ stdenv.mkDerivation (finalAttrs: { cmakeFlags = lib.optional staticOnly "-DBUILD_SHARED_LIBS=OFF"; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; doCheck = true; diff --git a/pkgs/by-name/br/browserpass/package.nix b/pkgs/by-name/br/browserpass/package.nix index 4c58039e899add..3c8fbaad9a7bcf 100644 --- a/pkgs/by-name/br/browserpass/package.nix +++ b/pkgs/by-name/br/browserpass/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, gnupg -, makeWrapper -, autoPatchelfHook -, testers -, browserpass +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + gnupg, + makeWrapper, + autoPatchelfHook, + testers, + browserpass, }: buildGoModule rec { @@ -20,7 +21,9 @@ buildGoModule rec { sha256 = "sha256-UZzOPRRiCUIG7uSSp9AEPMDN/+4cgyK47RhrI8oUx8U="; }; - nativeBuildInputs = [ makeWrapper ] ++ lib.optionals stdenv.hostPlatform.isLinux [ autoPatchelfHook ]; + nativeBuildInputs = [ + makeWrapper + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ autoPatchelfHook ]; vendorHash = "sha256-CjuH4ANP2bJDeA+o+1j+obbtk5/NVLet/OFS3Rms4r0="; diff --git a/pkgs/by-name/br/browsh/package.nix b/pkgs/by-name/br/browsh/package.nix index 29ddb1475ed9d2..f14b7662e8cbf4 100644 --- a/pkgs/by-name/br/browsh/package.nix +++ b/pkgs/by-name/br/browsh/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchurl, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchurl, + fetchFromGitHub, +}: let version = "1.8.2"; @@ -40,7 +45,10 @@ buildGoModule rec { description = "Fully-modern text-based browser, rendering to TTY and browsers"; mainProgram = "browsh"; homepage = "https://www.brow.sh/"; - maintainers = with maintainers; [ kalbasit siraben ]; + maintainers = with maintainers; [ + kalbasit + siraben + ]; license = lib.licenses.lgpl21; platforms = lib.platforms.linux ++ lib.platforms.darwin; }; diff --git a/pkgs/by-name/br/browsr/package.nix b/pkgs/by-name/br/browsr/package.nix index 435577aa567b80..2e564787e44358 100644 --- a/pkgs/by-name/br/browsr/package.nix +++ b/pkgs/by-name/br/browsr/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, extras ? [ "all" ] +{ + lib, + python3, + fetchFromGitHub, + extras ? [ "all" ], }: python3.pkgs.buildPythonApplication rec { @@ -20,19 +21,22 @@ python3.pkgs.buildPythonApplication rec { hatchling ]; - propagatedBuildInputs = with python3.pkgs; [ - art - click - pandas - pillow - pymupdf - pyperclip - rich - rich-click - rich-pixels - textual - textual-universal-directorytree - ] ++ lib.attrVals extras optional-dependencies; + propagatedBuildInputs = + with python3.pkgs; + [ + art + click + pandas + pillow + pymupdf + pyperclip + rich + rich-click + rich-pixels + textual + textual-universal-directorytree + ] + ++ lib.attrVals extras optional-dependencies; optional-dependencies = with python3.pkgs; { all = [ diff --git a/pkgs/by-name/br/brscan4/package.nix b/pkgs/by-name/br/brscan4/package.nix index f4c516ef569815..009232d7b96964 100644 --- a/pkgs/by-name/br/brscan4/package.nix +++ b/pkgs/by-name/br/brscan4/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchurl, callPackage, patchelf, makeWrapper, libusb-compat-0_1 }: +{ + stdenv, + lib, + fetchurl, + callPackage, + patchelf, + makeWrapper, + libusb-compat-0_1, +}: let myPatchElf = file: '' patchelf --set-interpreter \ @@ -12,23 +20,29 @@ in stdenv.mkDerivation rec { pname = "brscan4"; version = "0.4.10-1"; - src = { - "i686-linux" = fetchurl { - url = "http://download.brother.com/welcome/dlf006646/${pname}-${version}.i386.deb"; - sha256 = "sha256-ymIAg+rfSYP5uzsAM1hUYZacJ0PXmKEoljNtb0pgGMw="; - }; - "x86_64-linux" = fetchurl { - url = "https://download.brother.com/welcome/dlf006645/${pname}-${version}.amd64.deb"; - sha256 = "sha256-Gpr5456MCNpyam3g2qPo7S3aEZFMaUGR8bu7YmRY8xk="; - }; - }."${stdenv.hostPlatform.system}" or (throw "unsupported system ${stdenv.hostPlatform.system}"); + src = + { + "i686-linux" = fetchurl { + url = "http://download.brother.com/welcome/dlf006646/${pname}-${version}.i386.deb"; + sha256 = "sha256-ymIAg+rfSYP5uzsAM1hUYZacJ0PXmKEoljNtb0pgGMw="; + }; + "x86_64-linux" = fetchurl { + url = "https://download.brother.com/welcome/dlf006645/${pname}-${version}.amd64.deb"; + sha256 = "sha256-Gpr5456MCNpyam3g2qPo7S3aEZFMaUGR8bu7YmRY8xk="; + }; + } + ."${stdenv.hostPlatform.system}" or (throw "unsupported system ${stdenv.hostPlatform.system}"); unpackPhase = '' ar x $src tar xfvz data.tar.gz ''; - nativeBuildInputs = [ makeWrapper patchelf udevRules ]; + nativeBuildInputs = [ + makeWrapper + patchelf + udevRules + ]; buildInputs = [ libusb-compat-0_1 ]; dontBuild = true; @@ -88,7 +102,10 @@ stdenv.mkDerivation rec { meta = { description = "Brother brscan4 sane backend driver"; homepage = "http://www.brother.com"; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; license = lib.licenses.unfree; maintainers = with lib.maintainers; [ jraygauthier ]; diff --git a/pkgs/by-name/br/brscan4/udev_rules_type1.nix b/pkgs/by-name/br/brscan4/udev_rules_type1.nix index 05b018215bb1bb..87ab8be689e74d 100644 --- a/pkgs/by-name/br/brscan4/udev_rules_type1.nix +++ b/pkgs/by-name/br/brscan4/udev_rules_type1.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libsaneUDevRuleNumber ? "49" }: +{ + lib, + stdenv, + fetchurl, + libsaneUDevRuleNumber ? "49", +}: stdenv.mkDerivation rec { pname = "brother-udev-rule-type1"; diff --git a/pkgs/by-name/br/brscan5/package.nix b/pkgs/by-name/br/brscan5/package.nix index 91be20f3abbcee..2a0490da9ed59c 100644 --- a/pkgs/by-name/br/brscan5/package.nix +++ b/pkgs/by-name/br/brscan5/package.nix @@ -1,4 +1,15 @@ -{ stdenv, lib, fetchurl, patchelf, makeWrapper, libusb1, avahi-compat, glib, libredirect, nixosTests }: +{ + stdenv, + lib, + fetchurl, + patchelf, + makeWrapper, + libusb1, + avahi-compat, + glib, + libredirect, + nixosTests, +}: let myPatchElf = file: '' patchelf --set-interpreter \ @@ -11,24 +22,34 @@ in stdenv.mkDerivation rec { pname = "brscan5"; version = "1.3.1-0"; - src = { - "i686-linux" = fetchurl { - url = "https://download.brother.com/welcome/dlf104034/${pname}-${version}.i386.deb"; - hash = "sha256-BgS64vwsKESJBDz9H2MDwcGiresROSNFP1b+7+zlE5c="; - }; - "x86_64-linux" = fetchurl { - url = "https://download.brother.com/welcome/dlf104033/${pname}-${version}.amd64.deb"; - hash = "sha256-0UMbXMBlyiZI90WG5FWEP2mIZEBsxXd11dtgtyuSDnY="; - }; - }."${system}" or (throw "Unsupported system: ${system}"); + src = + { + "i686-linux" = fetchurl { + url = "https://download.brother.com/welcome/dlf104034/${pname}-${version}.i386.deb"; + hash = "sha256-BgS64vwsKESJBDz9H2MDwcGiresROSNFP1b+7+zlE5c="; + }; + "x86_64-linux" = fetchurl { + url = "https://download.brother.com/welcome/dlf104033/${pname}-${version}.amd64.deb"; + hash = "sha256-0UMbXMBlyiZI90WG5FWEP2mIZEBsxXd11dtgtyuSDnY="; + }; + } + ."${system}" or (throw "Unsupported system: ${system}"); unpackPhase = '' ar x $src tar xfv data.tar.xz ''; - nativeBuildInputs = [ makeWrapper patchelf ]; - buildInputs = [ libusb1 avahi-compat stdenv.cc.cc glib ]; + nativeBuildInputs = [ + makeWrapper + patchelf + ]; + buildInputs = [ + libusb1 + avahi-compat + stdenv.cc.cc + glib + ]; dontBuild = true; postPatch = @@ -37,9 +58,12 @@ stdenv.mkDerivation rec { # to get the offset, run: # strings -n 10 --radix=d opt/brother/scanner/brscan5/libsane-brother5.so.1.0.7 | grep "/opt/brother/scanner/brscan5/models" patchOffsetBytes = - if system == "x86_64-linux" then 86592 - else if system == "i686-linux" then 79236 - else throw "Unsupported system: ${system}"; + if system == "x86_64-linux" then + 86592 + else if system == "i686-linux" then + 79236 + else + throw "Unsupported system: ${system}"; in '' ${myPatchElf "opt/brother/scanner/brscan5/brsaneconfig5"} @@ -104,7 +128,10 @@ stdenv.mkDerivation rec { meta = { description = "Brother brscan5 sane backend driver"; homepage = "https://www.brother.com"; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; license = lib.licenses.unfree; maintainers = with lib.maintainers; [ mattchrist ]; diff --git a/pkgs/by-name/br/brunsli/package.nix b/pkgs/by-name/br/brunsli/package.nix index e9d379a74d31d9..398d7b0346985c 100644 --- a/pkgs/by-name/br/brunsli/package.nix +++ b/pkgs/by-name/br/brunsli/package.nix @@ -1,16 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, brotli +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + brotli, }: stdenv.mkDerivation rec { pname = "brunsli"; version = "0.1"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "google"; @@ -33,11 +37,13 @@ stdenv.mkDerivation rec { }) ]; - postPatch = '' - rm -r third_party - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - rm -r build - ''; + postPatch = + '' + rm -r third_party + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + rm -r build + ''; nativeBuildInputs = [ cmake diff --git a/pkgs/by-name/br/brutalmaze/package.nix b/pkgs/by-name/br/brutalmaze/package.nix index 124134eafc1420..2846fcabdc7d80 100644 --- a/pkgs/by-name/br/brutalmaze/package.nix +++ b/pkgs/by-name/br/brutalmaze/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromSourcehut, python3Packages }: +{ + lib, + fetchFromSourcehut, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "brutalmaze"; diff --git a/pkgs/by-name/br/brutefir/package.nix b/pkgs/by-name/br/brutefir/package.nix index 47f4648943a1e4..c83c8a2461312b 100644 --- a/pkgs/by-name/br/brutefir/package.nix +++ b/pkgs/by-name/br/brutefir/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, alsa-lib, fftw, fftwFloat, flex, libjack2 }: +{ + lib, + stdenv, + fetchurl, + alsa-lib, + fftw, + fftwFloat, + flex, + libjack2, +}: stdenv.mkDerivation rec { pname = "brutefir"; @@ -27,7 +36,10 @@ stdenv.mkDerivation rec { description = "Software convolution engine"; license = licenses.gpl2Only; maintainers = with maintainers; [ auchter ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; mainProgram = "brutefir"; }; } diff --git a/pkgs/by-name/br/bruteforce-salted-openssl/package.nix b/pkgs/by-name/br/bruteforce-salted-openssl/package.nix index 93a2d66d4edeb8..c7f77cf9926a75 100644 --- a/pkgs/by-name/br/bruteforce-salted-openssl/package.nix +++ b/pkgs/by-name/br/bruteforce-salted-openssl/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + openssl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/br/bruteforce-wallet/package.nix b/pkgs/by-name/br/bruteforce-wallet/package.nix index 19344499bd49d3..b97d94dd537316 100644 --- a/pkgs/by-name/br/bruteforce-wallet/package.nix +++ b/pkgs/by-name/br/bruteforce-wallet/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, openssl -, db +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + openssl, + db, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/br/brutespray/package.nix b/pkgs/by-name/br/brutespray/package.nix index f954f666def132..52bbdf16113af2 100644 --- a/pkgs/by-name/br/brutespray/package.nix +++ b/pkgs/by-name/br/brutespray/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, python3 -, fetchFromGitHub -, makeWrapper -, medusa +{ + lib, + stdenv, + python3, + fetchFromGitHub, + makeWrapper, + medusa, }: stdenv.mkDerivation rec { @@ -23,7 +24,10 @@ stdenv.mkDerivation rec { ''; dontBuild = true; - nativeBuildInputs = [ python3.pkgs.wrapPython makeWrapper ]; + nativeBuildInputs = [ + python3.pkgs.wrapPython + makeWrapper + ]; buildInputs = [ python3 ]; installPhase = '' diff --git a/pkgs/by-name/bs/bschaffl/package.nix b/pkgs/by-name/bs/bschaffl/package.nix index c6dd879152295f..e35a04cf453e9d 100644 --- a/pkgs/by-name/bs/bschaffl/package.nix +++ b/pkgs/by-name/bs/bschaffl/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, cairo, libX11, lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cairo, + libX11, + lv2, +}: stdenv.mkDerivation rec { pname = "bschaffl"; @@ -12,7 +20,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ cairo libX11 lv2 ]; + buildInputs = [ + cairo + libX11 + lv2 + ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/bs/bsdbuild/package.nix b/pkgs/by-name/bs/bsdbuild/package.nix index e7b16547d383b5..067d7ebbc8ad67 100644 --- a/pkgs/by-name/bs/bsdbuild/package.nix +++ b/pkgs/by-name/bs/bsdbuild/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, perl, libtool, pkg-config, gettext, mandoc, ed }: +{ + lib, + stdenv, + fetchurl, + perl, + libtool, + pkg-config, + gettext, + mandoc, + ed, +}: stdenv.mkDerivation rec { pname = "bsdbuild"; @@ -9,35 +19,43 @@ stdenv.mkDerivation rec { sha256 = "1zrdjh7a6z4khhfw9zrp490afq306cpl5v8wqz2z55ys7k1n5ifl"; }; - buildInputs = [ perl mandoc ed ]; - nativeBuildInputs = [ pkg-config libtool gettext ]; + buildInputs = [ + perl + mandoc + ed + ]; + nativeBuildInputs = [ + pkg-config + libtool + gettext + ]; prePatch = '' - #ignore unfamiliar flags - substituteInPlace configure \ - --replace '--sbindir=*' '--sbindir=* | --includedir=* | --oldincludedir=*' - #same for packages using bsdbuild - substituteInPlace mkconfigure.pl \ - --replace '--sbindir=*' '--sbindir=* | --includedir=* | --oldincludedir=*' - #insert header for missing NULL macro - for f in db4.pm sdl_ttf.pm mysql.pm uim.pm strlcpy.pm getpwuid.pm \ - getaddrinfo.pm strtoll.pm free_null.pm getpwnam_r.pm \ - gettimeofday.pm gethostbyname.pm xinerama.pm strsep.pm \ - fontconfig.pm gettext.pm pthreads.pm strlcat.pm kqueue.pm wgl.pm \ - alsa.pm crypt.pm cracklib.pm freesg-rg.pm edacious.pm mmap.pm \ - agar.pm x11.pm x11.pm execvp.pm agar-core.pm dyld.pm getopt.pm \ - strtold.pm sdl_image.pm shl_load.pm glx.pm percgi.pm timerfd.pm \ - glob.pm dlopen.pm freesg.pm csidl.pm perl.pm select.pm \ - portaudio.pm etubestore.pm; - do -ed -s -v BSDBuild/$f << EOF -/#include -i -#include -. -w -EOF - done + #ignore unfamiliar flags + substituteInPlace configure \ + --replace '--sbindir=*' '--sbindir=* | --includedir=* | --oldincludedir=*' + #same for packages using bsdbuild + substituteInPlace mkconfigure.pl \ + --replace '--sbindir=*' '--sbindir=* | --includedir=* | --oldincludedir=*' + #insert header for missing NULL macro + for f in db4.pm sdl_ttf.pm mysql.pm uim.pm strlcpy.pm getpwuid.pm \ + getaddrinfo.pm strtoll.pm free_null.pm getpwnam_r.pm \ + gettimeofday.pm gethostbyname.pm xinerama.pm strsep.pm \ + fontconfig.pm gettext.pm pthreads.pm strlcat.pm kqueue.pm wgl.pm \ + alsa.pm crypt.pm cracklib.pm freesg-rg.pm edacious.pm mmap.pm \ + agar.pm x11.pm x11.pm execvp.pm agar-core.pm dyld.pm getopt.pm \ + strtold.pm sdl_image.pm shl_load.pm glx.pm percgi.pm timerfd.pm \ + glob.pm dlopen.pm freesg.pm csidl.pm perl.pm select.pm \ + portaudio.pm etubestore.pm; + do + ed -s -v BSDBuild/$f << EOF + /#include + i + #include + . + w + EOF + done ''; configureFlags = [ diff --git a/pkgs/by-name/bs/bsdgames/package.nix b/pkgs/by-name/bs/bsdgames/package.nix index c837ba39b444a7..a134b4c8c29131 100644 --- a/pkgs/by-name/bs/bsdgames/package.nix +++ b/pkgs/by-name/bs/bsdgames/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, ncurses, openssl, flex, bison, less, miscfiles }: +{ + lib, + stdenv, + fetchurl, + ncurses, + openssl, + flex, + bison, + less, + miscfiles, +}: stdenv.mkDerivation rec { pname = "bsd-games"; @@ -9,7 +19,12 @@ stdenv.mkDerivation rec { hash = "sha256-Bm+SSu9sHF6pRvWI428wMCH138CTlEc48CXY7bxv/2A="; }; - buildInputs = [ ncurses openssl flex bison ]; + buildInputs = [ + ncurses + openssl + flex + bison + ]; patches = [ # Remove UTMPX support on Makefrag file @@ -63,7 +78,7 @@ stdenv.mkDerivation rec { homepage = "http://www.t2-project.org/packages/bsd-games.html"; description = "Ports of all the games from NetBSD-current that are free"; license = lib.licenses.free; - maintainers = with lib.maintainers; [viric]; + maintainers = with lib.maintainers; [ viric ]; platforms = with lib.platforms; linux; }; } diff --git a/pkgs/by-name/bs/bsdiff/package.nix b/pkgs/by-name/bs/bsdiff/package.nix index e5be1e515b5aeb..666d9c2690fd4b 100644 --- a/pkgs/by-name/bs/bsdiff/package.nix +++ b/pkgs/by-name/bs/bsdiff/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fetchpatch, bzip2 }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + bzip2, +}: stdenv.mkDerivation rec { pname = "bsdiff"; @@ -10,27 +16,29 @@ stdenv.mkDerivation rec { }; buildInputs = [ bzip2 ]; - patches = [ - (fetchpatch { - url = "https://sources.debian.org/data/main/b/bsdiff/4.3-22/debian/patches/20-CVE-2014-9862.patch"; - sha256 = "sha256-3UuUfNvShQ8fLqxCKUTb/n4BmjL4+Nl7aEqCxYrrERQ="; - }) - ./CVE-2020-14315.patch - ./include-systypes.patch - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - (fetchpatch { - url = "https://sources.debian.org/data/main/b/bsdiff/4.3-22/debian/patches/30-bug-632585-mmap-src-file-instead-of-malloc-read-it.patch"; - sha256 = "sha256-esbhz2/efUiuQDuF7LGfSeEn3/f1WbqCxQpTs2A0ulI="; - }) - (fetchpatch { - url = "https://sources.debian.org/data/main/b/bsdiff/4.3-22/debian/patches/31-bug-632585-mmap-dst-file-instead-of-malloc-read-it.patch"; - sha256 = "sha256-Of4aOcI0rsgdRzPqyw2VRn2p9wQuo3hdlgDTBdXGzoc="; - }) - (fetchpatch { - url = "https://sources.debian.org/data/main/b/bsdiff/4.3-22/debian/patches/32-bug-632585-use-int32_t-instead-off_t-for-file-size.patch"; - sha256 = "sha256-SooFnFK4uKNXvXQb/LEcH8GocnRtkryExI4b3BZTsAY="; - }) - ]; + patches = + [ + (fetchpatch { + url = "https://sources.debian.org/data/main/b/bsdiff/4.3-22/debian/patches/20-CVE-2014-9862.patch"; + sha256 = "sha256-3UuUfNvShQ8fLqxCKUTb/n4BmjL4+Nl7aEqCxYrrERQ="; + }) + ./CVE-2020-14315.patch + ./include-systypes.patch + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + (fetchpatch { + url = "https://sources.debian.org/data/main/b/bsdiff/4.3-22/debian/patches/30-bug-632585-mmap-src-file-instead-of-malloc-read-it.patch"; + sha256 = "sha256-esbhz2/efUiuQDuF7LGfSeEn3/f1WbqCxQpTs2A0ulI="; + }) + (fetchpatch { + url = "https://sources.debian.org/data/main/b/bsdiff/4.3-22/debian/patches/31-bug-632585-mmap-dst-file-instead-of-malloc-read-it.patch"; + sha256 = "sha256-Of4aOcI0rsgdRzPqyw2VRn2p9wQuo3hdlgDTBdXGzoc="; + }) + (fetchpatch { + url = "https://sources.debian.org/data/main/b/bsdiff/4.3-22/debian/patches/32-bug-632585-use-int32_t-instead-off_t-for-file-size.patch"; + sha256 = "sha256-SooFnFK4uKNXvXQb/LEcH8GocnRtkryExI4b3BZTsAY="; + }) + ]; buildPhase = '' $CC -O3 -lbz2 bspatch.c -o bspatch diff --git a/pkgs/by-name/bs/bsequencer/package.nix b/pkgs/by-name/bs/bsequencer/package.nix index 00f99adf7bac29..965195fe0360a8 100644 --- a/pkgs/by-name/bs/bsequencer/package.nix +++ b/pkgs/by-name/bs/bsequencer/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, xorg, cairo, lv2, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + xorg, + cairo, + lv2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "bsequencer"; @@ -13,7 +21,9 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - xorg.libX11 cairo lv2 + xorg.libX11 + cairo + lv2 ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/bs/bshapr/package.nix b/pkgs/by-name/bs/bshapr/package.nix index 728c60b2e86fde..884ae2cb47bdd3 100644 --- a/pkgs/by-name/bs/bshapr/package.nix +++ b/pkgs/by-name/bs/bshapr/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, xorg, cairo, lv2, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + xorg, + cairo, + lv2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "bshapr"; @@ -13,7 +21,9 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - xorg.libX11 cairo lv2 + xorg.libX11 + cairo + lv2 ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/bs/bslizr/package.nix b/pkgs/by-name/bs/bslizr/package.nix index df81e0960b31af..ecd0622094cd4b 100644 --- a/pkgs/by-name/bs/bslizr/package.nix +++ b/pkgs/by-name/bs/bslizr/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, xorg, cairo, lv2, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + xorg, + cairo, + lv2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "bslizr"; @@ -13,7 +21,9 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - xorg.libX11 cairo lv2 + xorg.libX11 + cairo + lv2 ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/bs/bsp-layout/package.nix b/pkgs/by-name/bs/bsp-layout/package.nix index e0348fb9207efe..ddc296c550f7b2 100644 --- a/pkgs/by-name/bs/bsp-layout/package.nix +++ b/pkgs/by-name/bs/bsp-layout/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, git -, bc -, bspwm +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + git, + bc, + bspwm, }: stdenv.mkDerivation rec { @@ -18,7 +19,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-7bBVWJdgAnXLWzjQGZxVqhku2rsxX2kMxU4xkI9/DHE="; }; - nativeBuildInputs = [ makeWrapper git bc ]; + nativeBuildInputs = [ + makeWrapper + git + bc + ]; buildInputs = [ bspwm ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/bs/bspwm/package.nix b/pkgs/by-name/bs/bspwm/package.nix index bfd18f2f02a9c9..83aa6961c2fff7 100644 --- a/pkgs/by-name/bs/bspwm/package.nix +++ b/pkgs/by-name/bs/bspwm/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libxcb, libXinerama -, xcbutil, xcbutilkeysyms, xcbutilwm +{ + lib, + stdenv, + fetchFromGitHub, + libxcb, + libXinerama, + xcbutil, + xcbutilkeysyms, + xcbutilwm, }: stdenv.mkDerivation rec { @@ -7,13 +14,19 @@ stdenv.mkDerivation rec { version = "0.9.10"; src = fetchFromGitHub { - owner = "baskerville"; - repo = "bspwm"; - rev = version; + owner = "baskerville"; + repo = "bspwm"; + rev = version; sha256 = "0qlv7b4c2mmjfd65y100d11x8iqyg5f6lfiws3cgmpjidhdygnxc"; }; - buildInputs = [ libxcb libXinerama xcbutil xcbutilkeysyms xcbutilwm ]; + buildInputs = [ + libxcb + libXinerama + xcbutil + xcbutilkeysyms + xcbutilwm + ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/bs/bstone/package.nix b/pkgs/by-name/bs/bstone/package.nix index c43cc70bacf39b..5ac23cb98b21c7 100644 --- a/pkgs/by-name/bs/bstone/package.nix +++ b/pkgs/by-name/bs/bstone/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, cmake -, gcc12Stdenv -, SDL2 -, libGL +{ + lib, + fetchFromGitHub, + cmake, + gcc12Stdenv, + SDL2, + libGL, }: gcc12Stdenv.mkDerivation (finalAttrs: { @@ -41,6 +42,6 @@ gcc12Stdenv.mkDerivation (finalAttrs: { ]; maintainers = with lib.maintainers; [ keenanweaver ]; mainProgram = "bstone"; - platforms = lib.platforms.linux; #TODO: macOS / Darwin support + platforms = lib.platforms.linux; # TODO: macOS / Darwin support }; }) diff --git a/pkgs/by-name/bs/bsync/package.nix b/pkgs/by-name/bs/bsync/package.nix index 0a49bea9eefae6..571b98ddb86438 100644 --- a/pkgs/by-name/bs/bsync/package.nix +++ b/pkgs/by-name/bs/bsync/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, stdenv -, makeWrapper -, python3 -, openssh -, rsync -, findutils -, which +{ + lib, + fetchFromGitHub, + stdenv, + makeWrapper, + python3, + openssh, + rsync, + findutils, + which, }: stdenv.mkDerivation { @@ -14,10 +15,10 @@ stdenv.mkDerivation { version = "unstable-2023-12-21"; src = fetchFromGitHub { - owner = "dooblem"; - repo = "bsync"; - rev = "25f77730750720ad68b0ab2773e79d9ca98c3647"; - hash = "sha256-k25MjLis0/dp1TTS4aFeJZq/c0T01LmNcWtC+dw/kKY="; + owner = "dooblem"; + repo = "bsync"; + rev = "25f77730750720ad68b0ab2773e79d9ca98c3647"; + hash = "sha256-k25MjLis0/dp1TTS4aFeJZq/c0T01LmNcWtC+dw/kKY="; }; installPhase = '' @@ -26,24 +27,31 @@ stdenv.mkDerivation { runHook postInstall ''; -nativeBuildInputs = [ makeWrapper ]; -buildInputs = [ python3 ]; + nativeBuildInputs = [ makeWrapper ]; + buildInputs = [ python3 ]; -fixupPhase = '' - runHook preFixup + fixupPhase = '' + runHook preFixup - patchShebangs $out/bin/bsync - wrapProgram $out/bin/bsync \ - --prefix PATH ":" ${lib.makeLibraryPath [ openssh rsync findutils which ]} + patchShebangs $out/bin/bsync + wrapProgram $out/bin/bsync \ + --prefix PATH ":" ${ + lib.makeLibraryPath [ + openssh + rsync + findutils + which + ] + } - runHook postFixup -''; + runHook postFixup + ''; meta = with lib; { homepage = "https://github.com/dooblem/bsync"; description = "Bidirectional Synchronization using Rsync"; license = licenses.gpl3Only; - maintainers = with maintainers; [ dietmarw ]; + maintainers = with maintainers; [ dietmarw ]; platforms = platforms.unix; mainProgram = "bsync"; }; diff --git a/pkgs/by-name/bt/bt-fw-converter/package.nix b/pkgs/by-name/bt/bt-fw-converter/package.nix index 655b8f7ddedd94..5a0175069e306c 100644 --- a/pkgs/by-name/bt/bt-fw-converter/package.nix +++ b/pkgs/by-name/bt/bt-fw-converter/package.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchurl, makeWrapper, perl, perlPackages, bluez }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + perl, + perlPackages, + bluez, +}: -stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "bt-fw-converter"; version = "2017-02-19"; rev = "2d8b34402df01c6f7f4b8622de9e8b82fadf4153"; @@ -12,7 +20,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ perl perlPackages.RegexpGrammars bluez ]; + buildInputs = [ + perl + perlPackages.RegexpGrammars + bluez + ]; unpackCmd = '' mkdir -p ${pname}-${version} diff --git a/pkgs/by-name/bt/bt-migrate/package.nix b/pkgs/by-name/bt/bt-migrate/package.nix index 26701d1dc4f259..e10258e9c8c1f5 100644 --- a/pkgs/by-name/bt/bt-migrate/package.nix +++ b/pkgs/by-name/bt/bt-migrate/package.nix @@ -1,14 +1,15 @@ -{ lib -, boost -, cmake -, cxxopts -, digestpp -, fetchFromGitHub -, fmt -, jsoncons -, pugixml -, sqlite_orm -, stdenv +{ + lib, + boost, + cmake, + cxxopts, + digestpp, + fetchFromGitHub, + fmt, + jsoncons, + pugixml, + sqlite_orm, + stdenv, }: stdenv.mkDerivation { pname = "bt-migrate"; diff --git a/pkgs/by-name/bt/btar/package.nix b/pkgs/by-name/bt/btar/package.nix index f5ac2ce65d4137..9c92464bf481d6 100644 --- a/pkgs/by-name/bt/btar/package.nix +++ b/pkgs/by-name/bt/btar/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fetchpatch, librsync }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + librsync, +}: stdenv.mkDerivation rec { pname = "btar"; diff --git a/pkgs/by-name/bt/btc-rpc-explorer/package.nix b/pkgs/by-name/bt/btc-rpc-explorer/package.nix index babfe9400532ff..912c34f69ed8a3 100644 --- a/pkgs/by-name/bt/btc-rpc-explorer/package.nix +++ b/pkgs/by-name/bt/btc-rpc-explorer/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, pkg-config -, python3 -, vips +{ + lib, + buildNpmPackage, + fetchFromGitHub, + pkg-config, + python3, + vips, }: buildNpmPackage rec { @@ -43,7 +44,8 @@ buildNpmPackage rec { license = lib.licenses.mit; mainProgram = "btc-rpc-explorer"; maintainers = with lib.maintainers; [ d-xo ]; - broken = true; # At 2024-06-29 - # https://hydra.nixos.org/build/264232177/nixlog/1 + broken = true; + # At 2024-06-29 + # https://hydra.nixos.org/build/264232177/nixlog/1 }; } diff --git a/pkgs/by-name/bt/btcd/package.nix b/pkgs/by-name/bt/btcd/package.nix index aeda8019c10dda..3ea386726b76a3 100644 --- a/pkgs/by-name/bt/btcd/package.nix +++ b/pkgs/by-name/bt/btcd/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "btcd"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-ek+gaolwpwoEEWHKYpK2OxCpk/0vywF784J3CC0UCZ4="; - subPackages = [ "." "cmd/*" ]; + subPackages = [ + "." + "cmd/*" + ]; preCheck = '' DIR="github.com/btcsuite/btcd/" diff --git a/pkgs/by-name/bt/btcdeb/package.nix b/pkgs/by-name/bt/btcdeb/package.nix index 81f9241453f57b..2ffe238390b0f1 100644 --- a/pkgs/by-name/bt/btcdeb/package.nix +++ b/pkgs/by-name/bt/btcdeb/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, openssl -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + openssl, + unstableGitUpdater, }: stdenv.mkDerivation { @@ -17,12 +19,15 @@ stdenv.mkDerivation { hash = "sha256-heV5VByNZ/2doGVtYhGEei4fV4847UPVgOyU0PDDHc8="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; buildInputs = [ openssl ]; enableParallelBuilding = true; - passthru.updateScript = unstableGitUpdater {}; + passthru.updateScript = unstableGitUpdater { }; meta = with lib; { description = "Bitcoin Script Debugger"; diff --git a/pkgs/by-name/bt/btdu/package.nix b/pkgs/by-name/bt/btdu/package.nix index 833d3392779129..2bd50fc95878bb 100644 --- a/pkgs/by-name/bt/btdu/package.nix +++ b/pkgs/by-name/bt/btdu/package.nix @@ -36,7 +36,10 @@ buildDubPackage rec { changelog = "https://github.com/CyberShadow/btdu/releases/tag/${src.rev}"; license = licenses.gpl2Only; platforms = platforms.linux; - maintainers = with maintainers; [ atila cybershadow ]; + maintainers = with maintainers; [ + atila + cybershadow + ]; mainProgram = "btdu"; }; } diff --git a/pkgs/by-name/bt/btfs/package.nix b/pkgs/by-name/bt/btfs/package.nix index 04a3e104c1cf27..d63950aac6acc6 100644 --- a/pkgs/by-name/bt/btfs/package.nix +++ b/pkgs/by-name/bt/btfs/package.nix @@ -1,27 +1,44 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config -, python3, boost, fuse, libtorrent-rasterbar, curl }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + python3, + boost, + fuse, + libtorrent-rasterbar, + curl, +}: stdenv.mkDerivation rec { pname = "btfs"; version = "2.24"; src = fetchFromGitHub { - owner = "johang"; - repo = pname; - rev = "v${version}"; + owner = "johang"; + repo = pname; + rev = "v${version}"; sha256 = "sha256-fkS0U/MqFRQNi+n7NE4e1cnNICvfST2IQ9FMoJUyj6w="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ - boost fuse libtorrent-rasterbar curl python3 + boost + fuse + libtorrent-rasterbar + curl + python3 ]; meta = with lib; { description = "Bittorrent filesystem based on FUSE"; - homepage = "https://github.com/johang/btfs"; - license = licenses.gpl3; + homepage = "https://github.com/johang/btfs"; + license = licenses.gpl3; maintainers = with maintainers; [ rnhmjoj ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/bt/btor2tools/package.nix b/pkgs/by-name/bt/btor2tools/package.nix index 19bb53fb766b0a..cd361ebca743e6 100644 --- a/pkgs/by-name/bt/btor2tools/package.nix +++ b/pkgs/by-name/bt/btor2tools/package.nix @@ -1,13 +1,20 @@ -{ lib, stdenv, cmake, fetchFromGitHub, fetchpatch, fixDarwinDylibNames }: +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + fetchpatch, + fixDarwinDylibNames, +}: stdenv.mkDerivation rec { pname = "btor2tools"; version = "unstable-2024-08-07"; src = fetchFromGitHub { - owner = "boolector"; - repo = "btor2tools"; - rev = "44bcadbfede292ff4c4a4a8962cc18130de522fb"; + owner = "boolector"; + repo = "btor2tools"; + rev = "44bcadbfede292ff4c4a4a8962cc18130de522fb"; sha256 = "0ncl4xwms8d656x95ga8v8zjybx4cmdl5hlcml7dpcgm3p8qj4ks"; }; @@ -32,20 +39,26 @@ stdenv.mkDerivation rec { runHook postInstallCheck ''; - outputs = [ "out" "dev" "lib" ]; - - cmakeFlags = [ - # RPATH of binary /nix/store/.../bin/btorsim contains a forbidden reference to /build/ - "-DCMAKE_SKIP_BUILD_RPATH=ON" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DCMAKE_BUILD_WITH_INSTALL_NAME_DIR=ON" + outputs = [ + "out" + "dev" + "lib" ]; + cmakeFlags = + [ + # RPATH of binary /nix/store/.../bin/btorsim contains a forbidden reference to /build/ + "-DCMAKE_SKIP_BUILD_RPATH=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DCMAKE_BUILD_WITH_INSTALL_NAME_DIR=ON" + ]; + meta = with lib; { description = "Generic parser and tool package for the BTOR2 format"; - homepage = "https://github.com/Boolector/btor2tools"; - license = licenses.mit; - platforms = platforms.unix; + homepage = "https://github.com/Boolector/btor2tools"; + license = licenses.mit; + platforms = platforms.unix; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/bt/btrbk/package.nix b/pkgs/by-name/bt/btrbk/package.nix index 19dcb047f2e9e8..dad8be36e5947d 100644 --- a/pkgs/by-name/bt/btrbk/package.nix +++ b/pkgs/by-name/bt/btrbk/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, bash -, btrfs-progs -, openssh -, perl -, perlPackages -, util-linux -, asciidoctor -, mbuffer -, makeWrapper -, genericUpdater -, curl -, writeShellScript -, nixosTests +{ + lib, + stdenv, + fetchurl, + bash, + btrfs-progs, + openssh, + perl, + perlPackages, + util-linux, + asciidoctor, + mbuffer, + makeWrapper, + genericUpdater, + curl, + writeShellScript, + nixosTests, }: stdenv.mkDerivation rec { @@ -25,9 +26,15 @@ stdenv.mkDerivation rec { sha256 = "AuKsZHyRhGMgLL5ge7lVV6T3/SNwaRJDM8VNpbK7t2s="; }; - nativeBuildInputs = [ asciidoctor makeWrapper ]; + nativeBuildInputs = [ + asciidoctor + makeWrapper + ]; - buildInputs = with perlPackages; [ perl DateCalc ]; + buildInputs = with perlPackages; [ + perl + DateCalc + ]; preInstall = '' for f in $(find . -name Makefile); do @@ -50,11 +57,23 @@ stdenv.mkDerivation rec { wrapProgram $out/bin/btrbk \ --set PERL5LIB $PERL5LIB \ --run 'export program_name=$0' \ - --prefix PATH ':' "${lib.makeBinPath [ btrfs-progs bash mbuffer openssh ]}" + --prefix PATH ':' "${ + lib.makeBinPath [ + btrfs-progs + bash + mbuffer + openssh + ] + }" ''; passthru.tests = { - inherit (nixosTests) btrbk btrbk-no-timer btrbk-section-order btrbk-doas; + inherit (nixosTests) + btrbk + btrbk-no-timer + btrbk-section-order + btrbk-doas + ; }; passthru.updateScript = genericUpdater { diff --git a/pkgs/by-name/bt/btrfs-heatmap/package.nix b/pkgs/by-name/bt/btrfs-heatmap/package.nix index ee09a25ceb1462..ff7bc2a9462d7d 100644 --- a/pkgs/by-name/bt/btrfs-heatmap/package.nix +++ b/pkgs/by-name/bt/btrfs-heatmap/package.nix @@ -1,7 +1,9 @@ -{ stdenv, lib -, fetchFromGitHub -, python3 -, installShellFiles +{ + stdenv, + lib, + fetchFromGitHub, + python3, + installShellFiles, }: stdenv.mkDerivation rec { @@ -16,9 +18,15 @@ stdenv.mkDerivation rec { }; buildInputs = [ python3 ]; - nativeBuildInputs = [ python3.pkgs.wrapPython installShellFiles ]; - - outputs = [ "out" "man" ]; + nativeBuildInputs = [ + python3.pkgs.wrapPython + installShellFiles + ]; + + outputs = [ + "out" + "man" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/bt/btrfs-progs/package.nix b/pkgs/by-name/bt/btrfs-progs/package.nix index cb3e12d8271e3b..93b7916135befd 100644 --- a/pkgs/by-name/bt/btrfs-progs/package.nix +++ b/pkgs/by-name/bt/btrfs-progs/package.nix @@ -1,11 +1,21 @@ -{ lib, stdenv, fetchurl -, buildPackages -, pkg-config -, zstd -, acl, attr, e2fsprogs, libuuid, lzo, udev, zlib -, runCommand, btrfs-progs -, gitUpdater -, udevSupport ? true +{ + lib, + stdenv, + fetchurl, + buildPackages, + pkg-config, + zstd, + acl, + attr, + e2fsprogs, + libuuid, + lzo, + udev, + zlib, + runCommand, + btrfs-progs, + gitUpdater, + udevSupport ? true, }: stdenv.mkDerivation rec { @@ -17,16 +27,29 @@ stdenv.mkDerivation rec { hash = "sha256-mn2WUf/VL75SEqjkhSo82weePSI/xVBOalCwupbNIKE="; }; - nativeBuildInputs = [ - pkg-config - ] ++ [ - (buildPackages.python3.withPackages (ps: with ps; [ - sphinx - sphinx-rtd-theme - ])) - ]; + nativeBuildInputs = + [ + pkg-config + ] + ++ [ + (buildPackages.python3.withPackages ( + ps: with ps; [ + sphinx + sphinx-rtd-theme + ] + )) + ]; - buildInputs = [ acl attr e2fsprogs libuuid lzo udev zlib zstd ]; + buildInputs = [ + acl + attr + e2fsprogs + libuuid + lzo + udev + zlib + zstd + ]; # gcc bug with -O1 on ARM with gcc 4.8 # This should be fine on all platforms so apply universally @@ -36,21 +59,24 @@ stdenv.mkDerivation rec { install -v -m 444 -D btrfs-completion $out/share/bash-completion/completions/btrfs ''; - configureFlags = [ - # Built separately, see python3Packages.btrfsutil - "--disable-python" - ] ++ lib.optionals stdenv.hostPlatform.isMusl [ - "--disable-backtrace" - ] ++ lib.optionals (!udevSupport) [ - "--disable-libudev" - ]; + configureFlags = + [ + # Built separately, see python3Packages.btrfsutil + "--disable-python" + ] + ++ lib.optionals stdenv.hostPlatform.isMusl [ + "--disable-backtrace" + ] + ++ lib.optionals (!udevSupport) [ + "--disable-libudev" + ]; makeFlags = [ "udevruledir=$(out)/lib/udev/rules.d" ]; enableParallelBuilding = true; passthru.tests = { - simple-filesystem = runCommand "btrfs-progs-create-fs" {} '' + simple-filesystem = runCommand "btrfs-progs-create-fs" { } '' mkdir -p $out truncate -s110M $out/disc ${btrfs-progs}/bin/mkfs.btrfs $out/disc | tee $out/success diff --git a/pkgs/by-name/bt/btrfs-snap/package.nix b/pkgs/by-name/bt/btrfs-snap/package.nix index 40838c1fed62e7..9244674ef113b6 100644 --- a/pkgs/by-name/bt/btrfs-snap/package.nix +++ b/pkgs/by-name/bt/btrfs-snap/package.nix @@ -1,4 +1,14 @@ -{ bash, btrfs-progs, coreutils, fetchFromGitHub, gnugrep, lib, makeWrapper, stdenvNoCC, util-linuxMinimal }: +{ + bash, + btrfs-progs, + coreutils, + fetchFromGitHub, + gnugrep, + lib, + makeWrapper, + stdenvNoCC, + util-linuxMinimal, +}: stdenvNoCC.mkDerivation rec { pname = "btrfs-snap"; version = "1.7.3"; @@ -15,12 +25,14 @@ stdenvNoCC.mkDerivation rec { installPhase = '' mkdir -p $out/bin cp btrfs-snap $out/bin/ - wrapProgram $out/bin/btrfs-snap --prefix PATH : ${lib.makeBinPath [ - btrfs-progs # btrfs - coreutils # cut, date, head, ls, mkdir, readlink, stat, tail, touch, test, [ - gnugrep # grep - util-linuxMinimal # logger, mount - ]} + wrapProgram $out/bin/btrfs-snap --prefix PATH : ${ + lib.makeBinPath [ + btrfs-progs # btrfs + coreutils # cut, date, head, ls, mkdir, readlink, stat, tail, touch, test, [ + gnugrep # grep + util-linuxMinimal # logger, mount + ] + } ''; meta = with lib; { description = "Create and maintain the history of snapshots of btrfs filesystems"; @@ -29,5 +41,5 @@ stdenvNoCC.mkDerivation rec { license = licenses.gpl3Only; maintainers = with maintainers; [ lionello ]; platforms = platforms.linux; - }; + }; } diff --git a/pkgs/by-name/bu/bubblemail/package.nix b/pkgs/by-name/bu/bubblemail/package.nix index add8f6c4e09861..f1d3150034f6e6 100644 --- a/pkgs/by-name/bu/bubblemail/package.nix +++ b/pkgs/by-name/bu/bubblemail/package.nix @@ -1,19 +1,20 @@ -{ lib -, fetchFromGitLab -, gettext -, gtk3 -, python3Packages -, gdk-pixbuf -, libnotify -, gst_all_1 -, libsecret -, wrapGAppsHook3 -, gsettings-desktop-schemas -, gnome-online-accounts -, glib -, gobject-introspection -, folks -, bash +{ + lib, + fetchFromGitLab, + gettext, + gtk3, + python3Packages, + gdk-pixbuf, + libnotify, + gst_all_1, + libsecret, + wrapGAppsHook3, + gsettings-desktop-schemas, + gnome-online-accounts, + glib, + gobject-introspection, + folks, + bash, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/bu/bubblewrap/package.nix b/pkgs/by-name/bu/bubblewrap/package.nix index e4a028cb59002f..eba4f666e176ee 100644 --- a/pkgs/by-name/bu/bubblewrap/package.nix +++ b/pkgs/by-name/bu/bubblewrap/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, docbook_xsl -, libxslt -, meson -, ninja -, pkg-config -, bash-completion -, libcap -, libselinux +{ + lib, + stdenv, + fetchFromGitHub, + docbook_xsl, + libxslt, + meson, + ninja, + pkg-config, + bash-completion, + libcap, + libselinux, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/bu/buddy/package.nix b/pkgs/by-name/bu/buddy/package.nix index eb9d146291d9bf..9ca2ad864f4b23 100644 --- a/pkgs/by-name/bu/buddy/package.nix +++ b/pkgs/by-name/bu/buddy/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, bison }: +{ + lib, + stdenv, + fetchurl, + bison, +}: stdenv.mkDerivation rec { pname = "buddy"; @@ -11,7 +16,10 @@ stdenv.mkDerivation rec { buildInputs = [ bison ]; patches = [ ./gcc-4.3.3-fixes.patch ]; - configureFlags = [ "CFLAGS=-O3" "CXXFLAGS=-O3" ]; + configureFlags = [ + "CFLAGS=-O3" + "CXXFLAGS=-O3" + ]; env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-error=register"; NIX_LDFLAGS = "-lm"; doCheck = true; diff --git a/pkgs/by-name/bu/buffer/package.nix b/pkgs/by-name/bu/buffer/package.nix index 862b64f7748d89..1482119defbf48 100644 --- a/pkgs/by-name/bu/buffer/package.nix +++ b/pkgs/by-name/bu/buffer/package.nix @@ -1,17 +1,18 @@ -{ lib -, desktop-file-utils -, fetchFromGitLab -, gobject-introspection -, gtk4 -, gtksourceview5 -, libadwaita -, libspelling -, meson -, ninja -, pkg-config -, python3 -, stdenv -, wrapGAppsHook4 +{ + lib, + desktop-file-utils, + fetchFromGitLab, + gobject-introspection, + gtk4, + gtksourceview5, + libadwaita, + libspelling, + meson, + ninja, + pkg-config, + python3, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { @@ -40,9 +41,11 @@ stdenv.mkDerivation (finalAttrs: { gtksourceview5 libadwaita libspelling - (python3.withPackages (ps: with ps; [ - pygobject3 - ])) + (python3.withPackages ( + ps: with ps; [ + pygobject3 + ] + )) ]; preFixup = '' diff --git a/pkgs/by-name/bu/bufisk/package.nix b/pkgs/by-name/bu/bufisk/package.nix index 6cc70a24563caf..930c15f6087958 100644 --- a/pkgs/by-name/bu/bufisk/package.nix +++ b/pkgs/by-name/bu/bufisk/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-iv5zIn9C56AQB87T+n5fJzm/fhBFBUObFwrlJ72A/J4="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/bufbuild/bufisk"; diff --git a/pkgs/by-name/bu/bugstalker/package.nix b/pkgs/by-name/bu/bugstalker/package.nix index ac1174f5cdd3fb..9ac50950fb398e 100644 --- a/pkgs/by-name/bu/bugstalker/package.nix +++ b/pkgs/by-name/bu/bugstalker/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libunwind +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libunwind, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/bu/buildkite-agent-metrics/package.nix b/pkgs/by-name/bu/buildkite-agent-metrics/package.nix index 9d6dc124795ae2..7f1428fcff83ec 100644 --- a/pkgs/by-name/bu/buildkite-agent-metrics/package.nix +++ b/pkgs/by-name/bu/buildkite-agent-metrics/package.nix @@ -1,12 +1,16 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "buildkite-agent-metrics"; version = "5.9.10"; - outputs = [ "out" "lambda" ]; + outputs = [ + "out" + "lambda" + ]; src = fetchFromGitHub { owner = "buildkite"; diff --git a/pkgs/by-name/bu/buildkite-agent/package.nix b/pkgs/by-name/bu/buildkite-agent/package.nix index 5eec3d1ebbea0d..a846606d836e8f 100644 --- a/pkgs/by-name/bu/buildkite-agent/package.nix +++ b/pkgs/by-name/bu/buildkite-agent/package.nix @@ -1,15 +1,16 @@ -{ fetchFromGitHub -, lib -, buildGoModule -, makeWrapper -, coreutils -, git -, openssh -, bash -, gnused -, gnugrep -, gitUpdater -, nixosTests +{ + fetchFromGitHub, + lib, + buildGoModule, + makeWrapper, + coreutils, + git, + openssh, + bash, + gnused, + gnugrep, + gitUpdater, + nixosTests, }: buildGoModule rec { pname = "buildkite-agent"; @@ -38,7 +39,15 @@ buildGoModule rec { # These are runtime dependencies wrapProgram $out/bin/buildkite-agent \ - --prefix PATH : '${lib.makeBinPath [ openssh git coreutils gnused gnugrep ]}' + --prefix PATH : '${ + lib.makeBinPath [ + openssh + git + coreutils + gnused + gnugrep + ] + }' ''; passthru = { @@ -59,7 +68,12 @@ buildGoModule rec { ''; homepage = "https://buildkite.com/docs/agent"; license = licenses.mit; - maintainers = with maintainers; [ pawelpacana zimbatm jsoo1 techknowlogick ]; + maintainers = with maintainers; [ + pawelpacana + zimbatm + jsoo1 + techknowlogick + ]; platforms = with platforms; unix ++ darwin; }; } diff --git a/pkgs/by-name/bu/buildkite-cli/package.nix b/pkgs/by-name/bu/buildkite-cli/package.nix index 9a9957a99aa7ab..37491a5a9697a1 100644 --- a/pkgs/by-name/bu/buildkite-cli/package.nix +++ b/pkgs/by-name/bu/buildkite-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "buildkite-cli"; @@ -21,7 +25,11 @@ buildGoModule rec { subPackages = [ "cmd/bk" ]; - ldflags = [ "-s" "-w" "-X main.VERSION=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.VERSION=${version}" + ]; meta = with lib; { description = "Command line interface for Buildkite"; diff --git a/pkgs/by-name/bu/buildtorrent/package.nix b/pkgs/by-name/bu/buildtorrent/package.nix index e6a800dc54675f..001cb8da5b929a 100644 --- a/pkgs/by-name/bu/buildtorrent/package.nix +++ b/pkgs/by-name/bu/buildtorrent/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "buildtorrent"; diff --git a/pkgs/by-name/bu/buku/package.nix b/pkgs/by-name/bu/buku/package.nix index 36d4000214adc8..edd09870b81329 100644 --- a/pkgs/by-name/bu/buku/package.nix +++ b/pkgs/by-name/bu/buku/package.nix @@ -1,4 +1,9 @@ -{ lib, python3, fetchFromGitHub, withServer ? false }: +{ + lib, + python3, + fetchFromGitHub, + withServer ? false, +}: let serverRequire = with python3.pkgs; [ @@ -16,7 +21,8 @@ let toml ]; in -with python3.pkgs; buildPythonApplication rec { +with python3.pkgs; +buildPythonApplication rec { version = "4.8"; pname = "buku"; pyproject = true; @@ -53,28 +59,32 @@ with python3.pkgs; buildPythonApplication rec { html5lib ] ++ lib.optionals withServer serverRequire; - preCheck = '' - # Disables a test which requires internet - substituteInPlace tests/test_bukuDb.py \ - --replace "@pytest.mark.slowtest" "@unittest.skip('skipping')" \ - --replace "self.assertEqual(shorturl, \"http://tny.im/yt\")" "" \ - --replace "self.assertEqual(url, \"https://www.google.com\")" "" - substituteInPlace setup.py \ - --replace mypy-extensions==0.4.1 mypy-extensions>=0.4.1 - '' + lib.optionalString (!withServer) '' - rm tests/test_{server,views}.py - ''; + preCheck = + '' + # Disables a test which requires internet + substituteInPlace tests/test_bukuDb.py \ + --replace "@pytest.mark.slowtest" "@unittest.skip('skipping')" \ + --replace "self.assertEqual(shorturl, \"http://tny.im/yt\")" "" \ + --replace "self.assertEqual(url, \"https://www.google.com\")" "" + substituteInPlace setup.py \ + --replace mypy-extensions==0.4.1 mypy-extensions>=0.4.1 + '' + + lib.optionalString (!withServer) '' + rm tests/test_{server,views}.py + ''; - postInstall = '' - make install PREFIX=$out + postInstall = + '' + make install PREFIX=$out - mkdir -p $out/share/zsh/site-functions $out/share/bash-completion/completions $out/share/fish/vendor_completions.d - cp auto-completion/zsh/* $out/share/zsh/site-functions - cp auto-completion/bash/* $out/share/bash-completion/completions - cp auto-completion/fish/* $out/share/fish/vendor_completions.d - '' + lib.optionalString (!withServer) '' - rm $out/bin/bukuserver - ''; + mkdir -p $out/share/zsh/site-functions $out/share/bash-completion/completions $out/share/fish/vendor_completions.d + cp auto-completion/zsh/* $out/share/zsh/site-functions + cp auto-completion/bash/* $out/share/bash-completion/completions + cp auto-completion/fish/* $out/share/fish/vendor_completions.d + '' + + lib.optionalString (!withServer) '' + rm $out/bin/bukuserver + ''; meta = with lib; { description = "Private cmdline bookmark manager"; diff --git a/pkgs/by-name/bu/bukubrow/package.nix b/pkgs/by-name/bu/bukubrow/package.nix index ee40cb0f10482a..92c3c56b8be667 100644 --- a/pkgs/by-name/bu/bukubrow/package.nix +++ b/pkgs/by-name/bu/bukubrow/package.nix @@ -1,13 +1,20 @@ -{ lib, rustPlatform, fetchFromGitHub, sqlite }: let +{ + lib, + rustPlatform, + fetchFromGitHub, + sqlite, +}: +let -manifest = { - description = "Bukubrow extension host application"; - name = "com.samhh.bukubrow"; - path = "@out@/bin/bukubrow"; - type = "stdio"; -}; + manifest = { + description = "Bukubrow extension host application"; + name = "com.samhh.bukubrow"; + path = "@out@/bin/bukubrow"; + type = "stdio"; + }; -in rustPlatform.buildRustPackage rec { +in +rustPlatform.buildRustPackage rec { pname = "bukubrow-host"; version = "5.4.0"; @@ -22,13 +29,22 @@ in rustPlatform.buildRustPackage rec { buildInputs = [ sqlite ]; - passAsFile = [ "firefoxManifest" "chromeManifest" ]; - firefoxManifest = builtins.toJSON (manifest // { - allowed_extensions = [ "bukubrow@samhh.com" ]; - }); - chromeManifest = builtins.toJSON (manifest // { - allowed_origins = [ "chrome-extension://ghniladkapjacfajiooekgkfopkjblpn/" ]; - }); + passAsFile = [ + "firefoxManifest" + "chromeManifest" + ]; + firefoxManifest = builtins.toJSON ( + manifest + // { + allowed_extensions = [ "bukubrow@samhh.com" ]; + } + ); + chromeManifest = builtins.toJSON ( + manifest + // { + allowed_origins = [ "chrome-extension://ghniladkapjacfajiooekgkfopkjblpn/" ]; + } + ); postBuild = '' substituteAll $firefoxManifestPath firefox.json substituteAll $chromeManifestPath chrome.json @@ -46,4 +62,3 @@ in rustPlatform.buildRustPackage rec { mainProgram = "bukubrow"; }; } - diff --git a/pkgs/by-name/bu/bulk_extractor/package.nix b/pkgs/by-name/bu/bulk_extractor/package.nix index 25d38c6c35caeb..9af14298ec42ae 100644 --- a/pkgs/by-name/bu/bulk_extractor/package.nix +++ b/pkgs/by-name/bu/bulk_extractor/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, exiv2 -, flex -, libewf -, libxml2 -, openssl -, zlib -, pkg-config -, python310 -, re2 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + exiv2, + flex, + libewf, + libxml2, + openssl, + zlib, + pkg-config, + python310, + re2, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/bu/bulky/package.nix b/pkgs/by-name/bu/bulky/package.nix index a9510f37b9167f..1c3d39c3fcad69 100644 --- a/pkgs/by-name/bu/bulky/package.nix +++ b/pkgs/by-name/bu/bulky/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, wrapGAppsHook3 -, python3 -, gobject-introspection -, gsettings-desktop-schemas -, gettext -, gtk3 -, glib -, common-licenses +{ + stdenv, + lib, + fetchFromGitHub, + wrapGAppsHook3, + python3, + gobject-introspection, + gsettings-desktop-schemas, + gettext, + gtk3, + glib, + common-licenses, }: stdenv.mkDerivation rec { @@ -30,7 +31,14 @@ stdenv.mkDerivation rec { ]; buildInputs = [ - (python3.withPackages (p: with p; [ pygobject3 magic setproctitle unidecode ])) + (python3.withPackages ( + p: with p; [ + pygobject3 + magic + setproctitle + unidecode + ] + )) gsettings-desktop-schemas gtk3 glib diff --git a/pkgs/by-name/bu/bulletml/package.nix b/pkgs/by-name/bu/bulletml/package.nix index 8d562b58e24afe..344afc966811c9 100644 --- a/pkgs/by-name/bu/bulletml/package.nix +++ b/pkgs/by-name/bu/bulletml/package.nix @@ -1,13 +1,22 @@ -{ lib, stdenv, fetchpatch, fetchurl, bison, perl }: +{ + lib, + stdenv, + fetchpatch, + fetchurl, + bison, + perl, +}: let version = "0.0.6"; debianRevision = "7"; - debianPatch = patchname: hash: fetchpatch { - name = "${patchname}.patch"; - url = "https://sources.debian.org/data/main/b/bulletml/${version}-${debianRevision}/debian/patches/${patchname}.patch"; - sha256 = hash; - }; + debianPatch = + patchname: hash: + fetchpatch { + name = "${patchname}.patch"; + url = "https://sources.debian.org/data/main/b/bulletml/${version}-${debianRevision}/debian/patches/${patchname}.patch"; + sha256 = hash; + }; lib_src = fetchurl { url = "http://shinh.skr.jp/libbulletml/libbulletml-${version}.tar.bz2"; @@ -24,7 +33,10 @@ stdenv.mkDerivation { pname = "bulletml"; inherit version; - srcs = [ lib_src cpp_src ]; + srcs = [ + lib_src + cpp_src + ]; postUnpack = "mv d_cpp bulletml/"; sourceRoot = "bulletml"; @@ -41,7 +53,10 @@ stdenv.mkDerivation { makeFlags = [ "-C src" ]; - nativeBuildInputs = [ bison perl ]; + nativeBuildInputs = [ + bison + perl + ]; hardeningDisable = [ "format" ]; installPhase = '' diff --git a/pkgs/by-name/bu/bullshit/package.nix b/pkgs/by-name/bu/bullshit/package.nix index 9345d2ae7d9294..6756a87e0a1e5a 100644 --- a/pkgs/by-name/bu/bullshit/package.nix +++ b/pkgs/by-name/bu/bullshit/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gawk -, nix-update-script +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gawk, + nix-update-script, }: stdenvNoCC.mkDerivation { pname = "bullshit"; diff --git a/pkgs/by-name/bu/bully/package.nix b/pkgs/by-name/bu/bully/package.nix index 3b2f62281ef19e..91cf6c834dfb76 100644 --- a/pkgs/by-name/bu/bully/package.nix +++ b/pkgs/by-name/bu/bully/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libpcap }: +{ + lib, + stdenv, + fetchFromGitHub, + libpcap, +}: stdenv.mkDerivation rec { pname = "bully"; diff --git a/pkgs/by-name/bu/bump/package.nix b/pkgs/by-name/bu/bump/package.nix index 52c3117b1ef962..e73a8713cb72d5 100644 --- a/pkgs/by-name/bu/bump/package.nix +++ b/pkgs/by-name/bu/bump/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "bump"; @@ -16,7 +20,9 @@ buildGoModule rec { doCheck = false; ldflags = [ - "-X main.buildVersion=${version}" "-X main.buildCommit=${version}" "-X main.buildDate=1970-01-01" + "-X main.buildVersion=${version}" + "-X main.buildCommit=${version}" + "-X main.buildDate=1970-01-01" ]; meta = with lib; { diff --git a/pkgs/by-name/bu/bumpver/package.nix b/pkgs/by-name/bu/bumpver/package.nix index d540d42110736a..b28a533f19ca35 100644 --- a/pkgs/by-name/bu/bumpver/package.nix +++ b/pkgs/by-name/bu/bumpver/package.nix @@ -1,4 +1,10 @@ -{ lib, python3, fetchPypi, git, mercurial }: +{ + lib, + python3, + fetchPypi, + git, + mercurial, +}: python3.pkgs.buildPythonApplication rec { pname = "bumpver"; @@ -16,9 +22,20 @@ python3.pkgs.buildPythonApplication rec { --replace "package_dir = lib3to6.fix(package_dir)" "" ''; - propagatedBuildInputs = with python3.pkgs; [ pathlib2 click toml lexid colorama setuptools ]; + propagatedBuildInputs = with python3.pkgs; [ + pathlib2 + click + toml + lexid + colorama + setuptools + ]; - nativeCheckInputs = [ python3.pkgs.pytestCheckHook git mercurial ]; + nativeCheckInputs = [ + python3.pkgs.pytestCheckHook + git + mercurial + ]; disabledTests = [ # fails due to more aggressive setuptools version specifier validation diff --git a/pkgs/by-name/bu/bundix/package.nix b/pkgs/by-name/bu/bundix/package.nix index a595649cac9be8..7a79eae438d534 100644 --- a/pkgs/by-name/bu/bundix/package.nix +++ b/pkgs/by-name/bu/bundix/package.nix @@ -1,10 +1,11 @@ -{ buildRubyGem -, fetchFromGitHub -, makeWrapper -, lib -, bundler -, nix -, nix-prefetch-git +{ + buildRubyGem, + fetchFromGitHub, + makeWrapper, + lib, + bundler, + nix, + nix-prefetch-git, }: buildRubyGem rec { @@ -21,7 +22,10 @@ buildRubyGem rec { hash = "sha256-QnNdseCSwQYhO/ybzWsflMEk68TMgPU3HqXJ7av3SHE="; }; - buildInputs = [ ruby bundler ]; + buildInputs = [ + ruby + bundler + ]; nativeBuildInputs = [ makeWrapper ]; preFixup = '' @@ -43,7 +47,10 @@ buildRubyGem rec { ''; homepage = "https://github.com/nix-community/bundix"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ manveru zimbatm ]; + maintainers = with lib.maintainers; [ + manveru + zimbatm + ]; platforms = lib.platforms.all; }; } diff --git a/pkgs/by-name/bu/bundler/package.nix b/pkgs/by-name/bu/bundler/package.nix index ac81e5b797bf25..d6fdf014474d9f 100644 --- a/pkgs/by-name/bu/bundler/package.nix +++ b/pkgs/by-name/bu/bundler/package.nix @@ -1,4 +1,11 @@ -{ lib, buildRubyGem, ruby, writeScript, testers, bundler }: +{ + lib, + buildRubyGem, + ruby, + writeScript, + testers, + bundler, +}: buildRubyGem rec { inherit ruby; diff --git a/pkgs/by-name/bu/bunnyfetch/package.nix b/pkgs/by-name/bu/bunnyfetch/package.nix index e14fe824431318..f4cc317f6010e8 100644 --- a/pkgs/by-name/bu/bunnyfetch/package.nix +++ b/pkgs/by-name/bu/bunnyfetch/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "bunnyfetch"; diff --git a/pkgs/by-name/bu/bunyan-rs/package.nix b/pkgs/by-name/bu/bunyan-rs/package.nix index 35fc322b05679c..ca07660a86c5eb 100644 --- a/pkgs/by-name/bu/bunyan-rs/package.nix +++ b/pkgs/by-name/bu/bunyan-rs/package.nix @@ -1,6 +1,7 @@ -{ rustPlatform -, fetchFromGitHub -, lib +{ + rustPlatform, + fetchFromGitHub, + lib, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "CLI to pretty print logs in bunyan format (Rust port of the original JavaScript bunyan CLI)"; homepage = "https://github.com/LukeMathWalker/bunyan"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ netcrns ]; mainProgram = "bunyan"; }; diff --git a/pkgs/by-name/bu/bup/package.nix b/pkgs/by-name/bu/bup/package.nix index c9fe3986611c7b..de3e74f257d1e6 100644 --- a/pkgs/by-name/bu/bup/package.nix +++ b/pkgs/by-name/bu/bup/package.nix @@ -62,12 +62,16 @@ stdenv.mkDerivation { "LIBDIR=$(out)/lib/bup" ]; - env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang - "-Wno-error=implicit-function-declaration -Wno-error=implicit-int"; + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-error=implicit-function-declaration -Wno-error=implicit-int"; postInstall = '' wrapProgram $out/bin/bup \ - --prefix PATH : ${lib.makeBinPath [ git par2cmdline ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + git + par2cmdline + ] + } \ --prefix NIX_PYTHONPATH : ${lib.makeSearchPathOutput "lib" python3.sitePackages pythonDeps} ''; diff --git a/pkgs/by-name/bu/bupc/package.nix b/pkgs/by-name/bu/bupc/package.nix index 228de48e603ade..b193adbeba1153 100644 --- a/pkgs/by-name/bu/bupc/package.nix +++ b/pkgs/by-name/bu/bupc/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, perl, coreutils }: +{ + lib, + stdenv, + fetchurl, + perl, + coreutils, +}: stdenv.mkDerivation rec { pname = "berkeley_upc"; diff --git a/pkgs/by-name/bu/burp/package.nix b/pkgs/by-name/bu/burp/package.nix index dad8fefced89f0..6479c15eeb76b2 100644 --- a/pkgs/by-name/bu/burp/package.nix +++ b/pkgs/by-name/bu/burp/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, pkg-config -, acl, librsync, ncurses, openssl_legacy, zlib, uthash }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + acl, + librsync, + ncurses, + openssl_legacy, + zlib, + uthash, +}: stdenv.mkDerivation rec { pname = "burp"; @@ -21,11 +33,19 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; # use openssl_legacy due to burp-2.4.0 not supporting file encryption with openssl 3.0 # replace with 'openssl' once burp-3.x has been declared stable and this package upgraded - buildInputs = [ librsync ncurses openssl_legacy zlib uthash ] - ++ lib.optional (!stdenv.hostPlatform.isDarwin) acl; + buildInputs = [ + librsync + ncurses + openssl_legacy + zlib + uthash + ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) acl; configureFlags = [ "--localstatedir=/var" ]; @@ -33,9 +53,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "BURP - BackUp and Restore Program"; - homepage = "https://burp.grke.org"; - license = licenses.agpl3Plus; + homepage = "https://burp.grke.org"; + license = licenses.agpl3Plus; maintainers = with maintainers; [ arjan-s ]; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/bu/butane/package.nix b/pkgs/by-name/bu/butane/package.nix index ae5ab10e7fa2e3..ddd3d18e237ddf 100644 --- a/pkgs/by-name/bu/butane/package.nix +++ b/pkgs/by-name/bu/butane/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "butane"; @@ -30,6 +34,9 @@ buildGoModule rec { mainProgram = "butane"; license = licenses.asl20; homepage = "https://github.com/coreos/butane"; - maintainers = with maintainers; [ elijahcaine ruuda ]; + maintainers = with maintainers; [ + elijahcaine + ruuda + ]; }; } diff --git a/pkgs/by-name/bu/butt/package.nix b/pkgs/by-name/bu/butt/package.nix index 558d044d34d93d..15044904ddead4 100644 --- a/pkgs/by-name/bu/butt/package.nix +++ b/pkgs/by-name/bu/butt/package.nix @@ -1,5 +1,22 @@ -{ lib, stdenv, fetchurl, pkg-config, fltk13, portaudio, lame, libvorbis, libogg -, flac, libopus, libsamplerate, fdk_aac, dbus, openssl, curl, portmidi }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + fltk13, + portaudio, + lame, + libvorbis, + libogg, + flac, + libopus, + libsamplerate, + fdk_aac, + dbus, + openssl, + curl, + portmidi, +}: stdenv.mkDerivation (finalAttrs: { pname = "butt"; @@ -43,8 +60,7 @@ stdenv.mkDerivation (finalAttrs: { meta = { changelog = "https://danielnoethen.de/butt/Changelog.html"; - description = - "butt (broadcast using this tool) is an easy to use, multi OS streaming tool"; + description = "butt (broadcast using this tool) is an easy to use, multi OS streaming tool"; homepage = "https://danielnoethen.de/butt/"; license = lib.licenses.gpl2; maintainers = with lib.maintainers; [ ehmry ]; diff --git a/pkgs/by-name/bu/buttercup-desktop/package.nix b/pkgs/by-name/bu/buttercup-desktop/package.nix index 3ba3ee4c2c2d2f..31d03a5243133b 100644 --- a/pkgs/by-name/bu/buttercup-desktop/package.nix +++ b/pkgs/by-name/bu/buttercup-desktop/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools }: +{ + lib, + fetchurl, + appimageTools, +}: let pname = "buttercup-desktop"; @@ -9,7 +13,8 @@ let }; appimageContents = appimageTools.extractType2 { inherit pname src version; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname src version; extraPkgs = pkgs: [ pkgs.libsecret ]; diff --git a/pkgs/by-name/bu/buttermanager/package.nix b/pkgs/by-name/bu/buttermanager/package.nix index 8127703d0e01ed..7c15ca68290afa 100644 --- a/pkgs/by-name/bu/buttermanager/package.nix +++ b/pkgs/by-name/bu/buttermanager/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, python3Packages -, wrapGAppsHook3 -, qt5 +{ + lib, + fetchFromGitHub, + python3Packages, + wrapGAppsHook3, + qt5, }: python3Packages.buildPythonApplication rec { @@ -31,7 +32,10 @@ python3Packages.buildPythonApplication rec { dontWrapQtApps = true; dontWrapGApps = true; - makeWrapperArgs = [ "\${qtWrapperArgs[@]}" "\${gappsWrapperArgs[@]}"]; + makeWrapperArgs = [ + "\${qtWrapperArgs[@]}" + "\${gappsWrapperArgs[@]}" + ]; postInstall = '' substituteInPlace packaging/buttermanager.desktop \ diff --git a/pkgs/by-name/bu/buzztrax/package.nix b/pkgs/by-name/bu/buzztrax/package.nix index 30961d5b320aba..35795e6cdaed74 100644 --- a/pkgs/by-name/bu/buzztrax/package.nix +++ b/pkgs/by-name/bu/buzztrax/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, gtk-doc -, intltool -, itstool -, libtool -, pkg-config -, wrapGAppsHook3 -, yelp-tools -, clutter-gtk -, gst_all_1 -, glib -, gtk2 -, libgsf -, libxml2 -, fluidsynth -, orc +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gtk-doc, + intltool, + itstool, + libtool, + pkg-config, + wrapGAppsHook3, + yelp-tools, + clutter-gtk, + gst_all_1, + glib, + gtk2, + libgsf, + libxml2, + fluidsynth, + orc, }: stdenv.mkDerivation { @@ -62,7 +63,8 @@ stdenv.mkDerivation { ]; # 'g_memdup' is deprecated: Use 'g_memdup2' instead - env.NIX_CFLAGS_COMPILE = "-Wno-error=deprecated-declarations" + env.NIX_CFLAGS_COMPILE = + "-Wno-error=deprecated-declarations" # Suppress incompatible function pointer error in clang due to libxml2 2.12 const changes + lib.optionalString stdenv.cc.isClang " -Wno-error=incompatible-function-pointer-types"; diff --git a/pkgs/by-name/bv/bvi/package.nix b/pkgs/by-name/bv/bvi/package.nix index d032435a6fb79c..91b480c9f836d7 100644 --- a/pkgs/by-name/bv/bvi/package.nix +++ b/pkgs/by-name/bv/bvi/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "bvi"; diff --git a/pkgs/by-name/bv/bviplus/package.nix b/pkgs/by-name/bv/bviplus/package.nix index ebc3c246518a8e..d322b27c759804 100644 --- a/pkgs/by-name/bv/bviplus/package.nix +++ b/pkgs/by-name/bv/bviplus/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fetchpatch, ncurses }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + ncurses, +}: stdenv.mkDerivation rec { pname = "bviplus"; diff --git a/pkgs/by-name/bw/bwa-mem2/package.nix b/pkgs/by-name/bw/bwa-mem2/package.nix index eb6b01b147f9fe..ad1bc23399cd67 100644 --- a/pkgs/by-name/bw/bwa-mem2/package.nix +++ b/pkgs/by-name/bw/bwa-mem2/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -28,11 +29,18 @@ stdenv.mkDerivation (finalAttrs: { ''; buildFlags = [ - (if stdenv.hostPlatform.sse4_2Support then "arch=sse42" - else if stdenv.hostPlatform.avxSupport then "arch=avx" - else if stdenv.hostPlatform.avx2Support then "arch=avx2" - else if stdenv.hostPlatform.avx512Support then "arch=avx512" - else "arch=sse41") + ( + if stdenv.hostPlatform.sse4_2Support then + "arch=sse42" + else if stdenv.hostPlatform.avxSupport then + "arch=avx" + else if stdenv.hostPlatform.avx2Support then + "arch=avx2" + else if stdenv.hostPlatform.avx512Support then + "arch=avx512" + else + "arch=sse41" + ) ]; env = lib.optionalAttrs stdenv.hostPlatform.isDarwin { diff --git a/pkgs/by-name/bw/bwa/package.nix b/pkgs/by-name/bw/bwa/package.nix index c70eba475d2336..c306c2755d7ee5 100644 --- a/pkgs/by-name/bw/bwa/package.nix +++ b/pkgs/by-name/bw/bwa/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, +}: stdenv.mkDerivation { pname = "bwa"; @@ -39,8 +44,8 @@ stdenv.mkDerivation { meta = with lib; { description = "Software package for mapping low-divergent sequences against a large reference genome, such as the human genome"; mainProgram = "bwa"; - license = licenses.gpl3Plus; - homepage = "https://bio-bwa.sourceforge.net/"; + license = licenses.gpl3Plus; + homepage = "https://bio-bwa.sourceforge.net/"; maintainers = with maintainers; [ luispedro ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/bw/bwm_ng/package.nix b/pkgs/by-name/bw/bwm_ng/package.nix index e6e1907a25d8b6..aec275e41c24d2 100644 --- a/pkgs/by-name/bw/bwm_ng/package.nix +++ b/pkgs/by-name/bw/bwm_ng/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, autoreconfHook -, fetchurl -, fetchpatch -, ncurses +{ + lib, + stdenv, + autoreconfHook, + fetchurl, + fetchpatch, + ncurses, }: stdenv.mkDerivation rec { @@ -18,12 +19,16 @@ stdenv.mkDerivation rec { patches = [ # Pull upstream fix for ncurses-6.3 support. (fetchpatch { - name = "ncurses-6.3.patch"; + name = "ncurses-6.3.patch"; url = "https://github.com/vgropp/bwm-ng/commit/6a2087db6cc7ac5b5f667fcd17c262c079e8dcf2.patch"; sha256 = "1l5dii9d52v0x0sq458ybw7m9p8aan2vl94gwx5s8mgxsnbcmzzx"; # accidentally committed changes - excludes = [ "config.h.in~" "configure.in" "configure~" ]; - }) + excludes = [ + "config.h.in~" + "configure.in" + "configure~" + ]; + }) ]; nativeBuildInputs = [ diff --git a/pkgs/by-name/bw/bws/package.nix b/pkgs/by-name/bw/bws/package.nix index b1a0a0b1eac5df..2ac9c5a0a26c90 100644 --- a/pkgs/by-name/bw/bws/package.nix +++ b/pkgs/by-name/bw/bws/package.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, oniguruma -, openssl -, stdenv -, darwin -, python3 -, perl +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + oniguruma, + openssl, + stdenv, + darwin, + python3, + perl, }: rustPlatform.buildRustPackage rec { @@ -29,17 +30,20 @@ rustPlatform.buildRustPackage rec { }; }; - nativeBuildInputs = [ - installShellFiles - pkg-config - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - perl - ]; + nativeBuildInputs = + [ + installShellFiles + pkg-config + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + perl + ]; buildInputs = [ oniguruma - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ @@ -51,9 +55,15 @@ rustPlatform.buildRustPackage rec { RUSTONIG_SYSTEM_LIBONIG = true; }; - cargoBuildFlags = [ "--package" "bws" ]; + cargoBuildFlags = [ + "--package" + "bws" + ]; - cargoTestFlags = [ "--package" "bws" ]; + cargoTestFlags = [ + "--package" + "bws" + ]; postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' installShellCompletion --cmd bws \ diff --git a/pkgs/by-name/by/byacc/package.nix b/pkgs/by-name/by/byacc/package.nix index 23c2894ae57444..5122b08f67cbb7 100644 --- a/pkgs/by-name/by/byacc/package.nix +++ b/pkgs/by-name/by/byacc/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/by/byobu/package.nix b/pkgs/by-name/by/byobu/package.nix index bf6896f3153ae3..462b2ef3a7bde3 100644 --- a/pkgs/by-name/by/byobu/package.nix +++ b/pkgs/by-name/by/byobu/package.nix @@ -1,15 +1,16 @@ -{ lib -, autoreconfHook -, bc -, fetchFromGitHub -, gettext -, makeWrapper -, perl -, python3 -, screen -, stdenv -, vim -, tmux +{ + lib, + autoreconfHook, + bc, + fetchFromGitHub, + gettext, + makeWrapper, + perl, + python3, + screen, + stdenv, + vim, + tmux, }: let @@ -72,7 +73,12 @@ stdenv.mkDerivation (finalAttrs: { makeWrapper "$out/bin/.$bname" "$out/bin/$bname" \ --argv0 $bname \ --prefix PATH ":" "$out/bin" \ - --set BYOBU_PATH ${lib.makeBinPath [ vim bc ]} \ + --set BYOBU_PATH ${ + lib.makeBinPath [ + vim + bc + ] + } \ --set BYOBU_PYTHON "${pythonEnv}/bin/python" done ''; diff --git a/pkgs/by-name/by/bytecode-viewer/package.nix b/pkgs/by-name/by/bytecode-viewer/package.nix index 1431301a84ee71..13aa8359eb69f8 100644 --- a/pkgs/by-name/by/bytecode-viewer/package.nix +++ b/pkgs/by-name/by/bytecode-viewer/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, jre -, makeWrapper -, maven -, icoutils -, copyDesktopItems -, makeDesktopItem +{ + lib, + fetchFromGitHub, + jre, + makeWrapper, + maven, + icoutils, + copyDesktopItems, + makeDesktopItem, }: maven.buildMavenPackage rec { @@ -70,11 +71,14 @@ maven.buildMavenPackage rec { homepage = "https://bytecodeviewer.com"; description = "Lightweight user-friendly Java/Android Bytecode Viewer, Decompiler & More"; mainProgram = "bytecode-viewer"; - maintainers = with maintainers; [ shard7 d3vil0p3r ]; + maintainers = with maintainers; [ + shard7 + d3vil0p3r + ]; platforms = platforms.unix; sourceProvenance = with sourceTypes; [ fromSource - binaryBytecode # deps + binaryBytecode # deps ]; license = with licenses; [ gpl3Only ]; }; diff --git a/pkgs/by-name/by/byzanz/package.nix b/pkgs/by-name/by/byzanz/package.nix index a19f03727023b2..36e477751c88f0 100644 --- a/pkgs/by-name/by/byzanz/package.nix +++ b/pkgs/by-name/by/byzanz/package.nix @@ -1,16 +1,18 @@ -{ lib, stdenv -, fetchgit -, wrapGAppsHook3 -, cairo -, glib -, gnome-common -, gst_all_1 -, gtk3 -, intltool -, libtool -, pkg-config -, which -, xorg +{ + lib, + stdenv, + fetchgit, + wrapGAppsHook3, + cairo, + glib, + gnome-common, + gst_all_1, + gtk3, + intltool, + libtool, + pkg-config, + which, + xorg, }: stdenv.mkDerivation { @@ -34,25 +36,30 @@ stdenv.mkDerivation { "-Wno-error=incompatible-pointer-types" ]; - nativeBuildInputs = [ pkg-config intltool ]; - buildInputs = [ - which - gnome-common - glib - libtool - cairo - gtk3 - xorg.xwininfo - xorg.libXdamage - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-bad - gst-plugins-good - gst-plugins-ugly - gst-libav - wrapGAppsHook3 - ]); + nativeBuildInputs = [ + pkg-config + intltool + ]; + buildInputs = + [ + which + gnome-common + glib + libtool + cairo + gtk3 + xorg.xwininfo + xorg.libXdamage + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-bad + gst-plugins-good + gst-plugins-ugly + gst-libav + wrapGAppsHook3 + ]); meta = with lib; { description = "Tool to record a running X desktop to an animation suitable for presentation in a web browser"; diff --git a/pkgs/by-name/bz/bzrtp/package.nix b/pkgs/by-name/bz/bzrtp/package.nix index 966190a6556754..dff70855b3f1f4 100644 --- a/pkgs/by-name/bz/bzrtp/package.nix +++ b/pkgs/by-name/bz/bzrtp/package.nix @@ -1,9 +1,10 @@ -{ bctoolbox -, cmake -, fetchFromGitLab -, sqlite -, lib -, stdenv +{ + bctoolbox, + cmake, + fetchFromGitLab, + sqlite, + lib, + stdenv, }: stdenv.mkDerivation rec { @@ -19,7 +20,10 @@ stdenv.mkDerivation rec { hash = "sha256-sLvvQhJ9uVt/dx57xs9ftY/ETi46xmyGDH8372zpqj8="; }; - buildInputs = [ bctoolbox sqlite ]; + buildInputs = [ + bctoolbox + sqlite + ]; nativeBuildInputs = [ cmake ]; # Do not build static libraries diff --git a/pkgs/by-name/c-/c-graph/package.nix b/pkgs/by-name/c-/c-graph/package.nix index 950962bc5654f7..4b586eef0e7aae 100644 --- a/pkgs/by-name/c-/c-graph/package.nix +++ b/pkgs/by-name/c-/c-graph/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, gfortran, gnuplot, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + gfortran, + gnuplot, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "c-graph"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { hash = "sha256-LSZ948nXXY3pXltR2hHnql6YEpHumjTvbtz4/qUIRCQ="; }; - nativeBuildInputs = [ gfortran makeWrapper ]; + nativeBuildInputs = [ + gfortran + makeWrapper + ]; postInstall = '' wrapProgram $out/bin/c-graph --prefix PATH : ${lib.makeBinPath [ gnuplot ]} diff --git a/pkgs/by-name/c-/c-periphery/package.nix b/pkgs/by-name/c-/c-periphery/package.nix index 86661fe819311d..f43e3520223a6f 100644 --- a/pkgs/by-name/c-/c-periphery/package.nix +++ b/pkgs/by-name/c-/c-periphery/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -15,7 +16,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-uUSXvMQcntUqD412UWkMif0wLxPhpPdnMb96Pqqh/B4="; }; - outputs = [ "dev" "lib" "out" ]; + outputs = [ + "dev" + "lib" + "out" + ]; postPatch = '' substituteInPlace src/libperiphery.pc.in \ diff --git a/pkgs/by-name/c2/c2ffi/package.nix b/pkgs/by-name/c2/c2ffi/package.nix index d83381080a5fe8..eaeebe044e4f23 100644 --- a/pkgs/by-name/c2/c2ffi/package.nix +++ b/pkgs/by-name/c2/c2ffi/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, cmake -, llvmPackages_16 -, unstableGitUpdater +{ + lib, + fetchFromGitHub, + cmake, + llvmPackages_16, + unstableGitUpdater, }: let @@ -48,7 +49,7 @@ llvmPackages.stdenv.mkDerivation { # LLVM may be compiled with -fno-rtti, so let's just turn it off. # A mismatch between lib{clang,LLVM}* and us can lead to the link time error: # undefined reference to `typeinfo for clang::ASTConsumer' - env.CXXFLAGS="-fno-rtti"; + env.CXXFLAGS = "-fno-rtti"; meta = with lib; { homepage = "https://github.com/rpav/c2ffi"; @@ -56,5 +57,5 @@ llvmPackages.stdenv.mkDerivation { mainProgram = "c2ffi"; license = licenses.lgpl21Only; maintainers = [ ]; - }; + }; } diff --git a/pkgs/by-name/c2/c2fmzq/package.nix b/pkgs/by-name/c2/c2fmzq/package.nix index 69942a05fdd13e..70f861a9265b02 100644 --- a/pkgs/by-name/c2/c2fmzq/package.nix +++ b/pkgs/by-name/c2/c2fmzq/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { @@ -15,13 +16,19 @@ buildGoModule rec { hash = "sha256-1c2C+BVgf7NumOoCCMfGFpn1qwQ2V4524aG5yZO98vI="; }; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; sourceRoot = "${src.name}/c2FmZQ"; vendorHash = "sha256-9eWLg0+HkpwUC+De62Izh3vadV3dnwPpf8ksH8KwGqQ="; - subPackages = [ "c2FmZQ-client" "c2FmZQ-server" ]; + subPackages = [ + "c2FmZQ-client" + "c2FmZQ-server" + ]; passthru.tests = { inherit (nixosTests) c2fmzq; }; diff --git a/pkgs/by-name/c2/c2nim/package.nix b/pkgs/by-name/c2/c2nim/package.nix index f5e0cad7a02e96..7aeee7f6505858 100644 --- a/pkgs/by-name/c2/c2nim/package.nix +++ b/pkgs/by-name/c2/c2nim/package.nix @@ -1,4 +1,8 @@ -{ lib, buildNimPackage, fetchFromGitHub }: +{ + lib, + buildNimPackage, + fetchFromGitHub, +}: buildNimPackage (finalAttrs: { pname = "c2nim"; diff --git a/pkgs/by-name/c6/c64-debugger/package.nix b/pkgs/by-name/c6/c64-debugger/package.nix index ad0da506b4ffba..a39e0d27416782 100644 --- a/pkgs/by-name/c6/c64-debugger/package.nix +++ b/pkgs/by-name/c6/c64-debugger/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchgit -, alsa-lib -, gtk3 -, libGL -, libGLU -, libX11 -, pkg-config -, upx -, xcbutil +{ + lib, + stdenv, + fetchgit, + alsa-lib, + gtk3, + libGL, + libGLU, + libX11, + pkg-config, + upx, + xcbutil, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ca/cabextract/package.nix b/pkgs/by-name/ca/cabextract/package.nix index 6860b52267717d..36cd8ff6bece56 100644 --- a/pkgs/by-name/ca/cabextract/package.nix +++ b/pkgs/by-name/ca/cabextract/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "cabextract"; diff --git a/pkgs/by-name/ca/cabin/package.nix b/pkgs/by-name/ca/cabin/package.nix index 0c6327d1e542d6..87b866fe2d4110 100644 --- a/pkgs/by-name/ca/cabin/package.nix +++ b/pkgs/by-name/ca/cabin/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "cabin"; diff --git a/pkgs/by-name/ca/cachefilesd/package.nix b/pkgs/by-name/ca/cachefilesd/package.nix index 12b9e1cf991902..c6e2f2467d57fb 100644 --- a/pkgs/by-name/ca/cachefilesd/package.nix +++ b/pkgs/by-name/ca/cachefilesd/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "cachefilesd"; diff --git a/pkgs/by-name/ca/cadical/package.nix b/pkgs/by-name/ca/cadical/package.nix index 8f324f077d8f57..ea2c0a162792f2 100644 --- a/pkgs/by-name/ca/cadical/package.nix +++ b/pkgs/by-name/ca/cadical/package.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, copyPkgconfigItems, makePkgconfigItem -, version ? "2.1.0" +{ + lib, + stdenv, + fetchFromGitHub, + copyPkgconfigItems, + makePkgconfigItem, + version ? "2.1.0", }: stdenv.mkDerivation rec { @@ -10,13 +15,19 @@ stdenv.mkDerivation rec { owner = "arminbiere"; repo = "cadical"; rev = "rel-${version}"; - hash = { - "2.1.0" = "sha256-sSvJgHxsRaJ/xHEK32fox0MFI7u+pj5ERLfNn2s8kC8="; - "2.0.0" = "sha256-qoeEM9SdpuFuBPeQlCzuhPLcJ+bMQkTUTGiT8QdU8rc="; - }.${version}; + hash = + { + "2.1.0" = "sha256-sSvJgHxsRaJ/xHEK32fox0MFI7u+pj5ERLfNn2s8kC8="; + "2.0.0" = "sha256-qoeEM9SdpuFuBPeQlCzuhPLcJ+bMQkTUTGiT8QdU8rc="; + } + .${version}; }; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; doCheck = true; nativeBuildInputs = [ copyPkgconfigItems ]; @@ -26,7 +37,10 @@ stdenv.mkDerivation rec { name = "cadical"; inherit version; cflags = [ "-I\${includedir}" ]; - libs = [ "-L\${libdir}" "-lcadical" ]; + libs = [ + "-L\${libdir}" + "-lcadical" + ]; variables = { includedir = "@includedir@"; libdir = "@libdir@"; diff --git a/pkgs/by-name/ca/cadzinho/package.nix b/pkgs/by-name/ca/cadzinho/package.nix index 5a12cd1e54bc50..56c333fb6caedd 100644 --- a/pkgs/by-name/ca/cadzinho/package.nix +++ b/pkgs/by-name/ca/cadzinho/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, SDL2, SDL2_net, glew, lua5_4, desktopToDarwinBundle }: +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + SDL2_net, + glew, + lua5_4, + desktopToDarwinBundle, +}: stdenv.mkDerivation rec { pname = "cadzinho"; @@ -18,17 +27,25 @@ stdenv.mkDerivation rec { nativeBuildInputs = lib.optional stdenv.hostPlatform.isDarwin desktopToDarwinBundle; - buildInputs = [ SDL2 SDL2_net glew lua5_4 ]; + buildInputs = [ + SDL2 + SDL2_net + glew + lua5_4 + ]; makeFlags = [ "CC:=$(CC)" ]; - env.NIX_CFLAGS_COMPILE = toString ([ - "-I${SDL2.dev}/include/SDL2" - "-I${SDL2_net.dev}/include/SDL2" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # https://github.com/llvm/llvm-project/issues/62254 - "-fno-builtin-strrchr" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-I${SDL2.dev}/include/SDL2" + "-I${SDL2_net.dev}/include/SDL2" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # https://github.com/llvm/llvm-project/issues/62254 + "-fno-builtin-strrchr" + ] + ); hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/ca/caeml/package.nix b/pkgs/by-name/ca/caeml/package.nix index f109ccfc3137e9..a518e2cd1d3ec9 100644 --- a/pkgs/by-name/ca/caeml/package.nix +++ b/pkgs/by-name/ca/caeml/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "caeml"; diff --git a/pkgs/by-name/ca/caerbannog/package.nix b/pkgs/by-name/ca/caerbannog/package.nix index 0ca33877d124f8..f83bf38ec907cb 100644 --- a/pkgs/by-name/ca/caerbannog/package.nix +++ b/pkgs/by-name/ca/caerbannog/package.nix @@ -1,17 +1,18 @@ -{ lib -, fetchFromSourcehut -, python3 -, glib -, gobject-introspection -, meson -, ninja -, pkg-config -, wrapGAppsHook3 -, gtk3 -, atk -, libhandy -, libnotify -, pango +{ + lib, + fetchFromSourcehut, + python3, + glib, + gobject-introspection, + meson, + ninja, + pkg-config, + wrapGAppsHook3, + gtk3, + atk, + libhandy, + libnotify, + pango, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ca/caffeine-ng/package.nix b/pkgs/by-name/ca/caffeine-ng/package.nix index 7e99dd19b80147..59baf698693ab6 100644 --- a/pkgs/by-name/ca/caffeine-ng/package.nix +++ b/pkgs/by-name/ca/caffeine-ng/package.nix @@ -1,19 +1,20 @@ -{ fetchFromGitea -, meson -, ninja -, pkg-config -, scdoc -, gobject-introspection -, lib -, libayatana-appindicator -, libnotify -, python3Packages -, procps -, xset -, xautolock -, xscreensaver -, xfce -, wrapGAppsHook3 +{ + fetchFromGitea, + meson, + ninja, + pkg-config, + scdoc, + gobject-introspection, + lib, + libayatana-appindicator, + libnotify, + python3Packages, + procps, + xset, + xautolock, + xscreensaver, + xfce, + wrapGAppsHook3, }: python3Packages.buildPythonApplication rec { @@ -29,7 +30,13 @@ python3Packages.buildPythonApplication rec { hash = "sha256-uYzLRZ+6ZgIwhSuJWRBpLYHgonX7sFXgUZid0V26V0Q="; }; - nativeBuildInputs = [ gobject-introspection meson ninja pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + gobject-introspection + meson + ninja + pkg-config + wrapGAppsHook3 + ]; buildInputs = [ libayatana-appindicator @@ -62,7 +69,15 @@ python3Packages.buildPythonApplication rec { preFixup = '' gappsWrapperArgs+=( - --prefix PATH : ${lib.makeBinPath [ procps xautolock xscreensaver xfce.xfconf xset ]} + --prefix PATH : ${ + lib.makeBinPath [ + procps + xautolock + xscreensaver + xfce.xfconf + xset + ] + } ) makeWrapperArgs+=("''${gappsWrapperArgs[@]}") ''; diff --git a/pkgs/by-name/ca/caffeine/package.nix b/pkgs/by-name/ca/caffeine/package.nix index 1e547a5533ba7a..4d4c5c8682e996 100644 --- a/pkgs/by-name/ca/caffeine/package.nix +++ b/pkgs/by-name/ca/caffeine/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, undmg +{ + lib, + stdenvNoCC, + fetchurl, + undmg, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ca/cairo-lang/package.nix b/pkgs/by-name/ca/cairo-lang/package.nix index 687a254b40a4e3..c7c6fb5d55b0b2 100644 --- a/pkgs/by-name/ca/cairo-lang/package.nix +++ b/pkgs/by-name/ca/cairo-lang/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, rustfmt -, perl +{ + lib, + rustPlatform, + fetchFromGitHub, + rustfmt, + perl, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ca/cairo/package.nix b/pkgs/by-name/ca/cairo/package.nix index 8ed46ae3efb501..a76132ed8e3a5e 100644 --- a/pkgs/by-name/ca/cairo/package.nix +++ b/pkgs/by-name/ca/cairo/package.nix @@ -1,116 +1,163 @@ -{ lib, stdenv, fetchurl, gtk-doc, meson, ninja, pkg-config, python3 -, docbook_xsl, fontconfig, freetype, libpng, pixman, zlib -, x11Support? !stdenv.hostPlatform.isDarwin || true, libXext, libXrender -, gobjectSupport ? true, glib -, xcbSupport ? x11Support, libxcb -, darwin -, testers +{ + lib, + stdenv, + fetchurl, + gtk-doc, + meson, + ninja, + pkg-config, + python3, + docbook_xsl, + fontconfig, + freetype, + libpng, + pixman, + zlib, + x11Support ? !stdenv.hostPlatform.isDarwin || true, + libXext, + libXrender, + gobjectSupport ? true, + glib, + xcbSupport ? x11Support, + libxcb, + darwin, + testers, }: let inherit (lib) optional optionals; -in stdenv.mkDerivation (finalAttrs: let - inherit (finalAttrs) pname version; -in { - pname = "cairo"; - version = "1.18.2"; - - src = fetchurl { - url = "https://cairographics.org/${if lib.mod (builtins.fromJSON (lib.versions.minor version)) 2 == 0 then "releases" else "snapshots"}/${pname}-${version}.tar.xz"; - hash = "sha256-piubtCQl6ETMPW3d4EP/Odur7dFULrpXout5+FiJ1Fo="; - }; - - outputs = [ "out" "dev" "devdoc" ]; - outputBin = "dev"; # very small - separateDebugInfo = true; - - nativeBuildInputs = [ - gtk-doc - meson - ninja - pkg-config - python3 - ]; - - buildInputs = [ - docbook_xsl - ] ++ optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - CoreGraphics - CoreText - ApplicationServices - Carbon - ]); - - propagatedBuildInputs = [ fontconfig freetype pixman libpng zlib ] - ++ optionals x11Support [ libXext libXrender ] - ++ optionals xcbSupport [ libxcb ] - ++ optional gobjectSupport glib - ; # TODO: maybe liblzo but what would it be for here? - - mesonFlags = [ - "-Dgtk_doc=true" - - # error: #error config.h must be included before this header - "-Dsymbol-lookup=disabled" - - # Only used in tests, causes a dependency cycle - "-Dspectre=disabled" - - (lib.mesonEnable "glib" gobjectSupport) - (lib.mesonEnable "tests" finalAttrs.finalPackage.doCheck) - (lib.mesonEnable "xlib" x11Support) - (lib.mesonEnable "xcb" xcbSupport) - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - "--cross-file=${builtins.toFile "cross-file.conf" '' - [properties] - ipc_rmid_deferred_release = ${ - { - linux = "true"; - freebsd = "true"; - netbsd = "false"; - }.${stdenv.hostPlatform.parsed.kernel.name} or - (throw "Unknown value for ipc_rmid_deferred_release") - } - ''}" - ]; - - preConfigure = '' - patchShebangs version.py - ''; - - enableParallelBuilding = true; - - doCheck = false; # fails - - postInstall = '' - # Work around broken `Requires.private' that prevents Freetype - # `-I' flags to be propagated. - sed -i "$out/lib/pkgconfig/cairo.pc" \ - -es'|^Cflags:\(.*\)$|Cflags: \1 -I${freetype.dev}/include/freetype2 -I${freetype.dev}/include|g' - ''; - - passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; - - meta = with lib; { - description = "2D graphics library with support for multiple output devices"; - mainProgram = "cairo-trace"; - longDescription = '' - Cairo is a 2D graphics library with support for multiple output - devices. Currently supported output targets include the X - Window System, XCB, Quartz, Win32, image buffers, PostScript, - PDF, and SVG file output. - - Cairo is designed to produce consistent output on all output - media while taking advantage of display hardware acceleration - when available (e.g., through the X Render Extension). +in +stdenv.mkDerivation ( + finalAttrs: + let + inherit (finalAttrs) pname version; + in + { + pname = "cairo"; + version = "1.18.2"; + + src = fetchurl { + url = "https://cairographics.org/${ + if lib.mod (builtins.fromJSON (lib.versions.minor version)) 2 == 0 then "releases" else "snapshots" + }/${pname}-${version}.tar.xz"; + hash = "sha256-piubtCQl6ETMPW3d4EP/Odur7dFULrpXout5+FiJ1Fo="; + }; + + outputs = [ + "out" + "dev" + "devdoc" + ]; + outputBin = "dev"; # very small + separateDebugInfo = true; + + nativeBuildInputs = [ + gtk-doc + meson + ninja + pkg-config + python3 + ]; + + buildInputs = + [ + docbook_xsl + ] + ++ optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + CoreGraphics + CoreText + ApplicationServices + Carbon + ] + ); + + propagatedBuildInputs = + [ + fontconfig + freetype + pixman + libpng + zlib + ] + ++ optionals x11Support [ + libXext + libXrender + ] + ++ optionals xcbSupport [ libxcb ] + ++ optional gobjectSupport glib; # TODO: maybe liblzo but what would it be for here? + + mesonFlags = + [ + "-Dgtk_doc=true" + + # error: #error config.h must be included before this header + "-Dsymbol-lookup=disabled" + + # Only used in tests, causes a dependency cycle + "-Dspectre=disabled" + + (lib.mesonEnable "glib" gobjectSupport) + (lib.mesonEnable "tests" finalAttrs.finalPackage.doCheck) + (lib.mesonEnable "xlib" x11Support) + (lib.mesonEnable "xcb" xcbSupport) + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + "--cross-file=${builtins.toFile "cross-file.conf" '' + [properties] + ipc_rmid_deferred_release = ${ + { + linux = "true"; + freebsd = "true"; + netbsd = "false"; + } + .${stdenv.hostPlatform.parsed.kernel.name} or (throw "Unknown value for ipc_rmid_deferred_release") + } + ''}" + ]; + + preConfigure = '' + patchShebangs version.py ''; - homepage = "http://cairographics.org/"; - license = with licenses; [ lgpl2Plus mpl10 ]; - pkgConfigModules = [ - "cairo-pdf" - "cairo-ps" - "cairo-svg" - ] ++ lib.optional gobjectSupport "cairo-gobject"; - platforms = platforms.all; - }; -}) + + enableParallelBuilding = true; + + doCheck = false; # fails + + postInstall = '' + # Work around broken `Requires.private' that prevents Freetype + # `-I' flags to be propagated. + sed -i "$out/lib/pkgconfig/cairo.pc" \ + -es'|^Cflags:\(.*\)$|Cflags: \1 -I${freetype.dev}/include/freetype2 -I${freetype.dev}/include|g' + ''; + + passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; + + meta = with lib; { + description = "2D graphics library with support for multiple output devices"; + mainProgram = "cairo-trace"; + longDescription = '' + Cairo is a 2D graphics library with support for multiple output + devices. Currently supported output targets include the X + Window System, XCB, Quartz, Win32, image buffers, PostScript, + PDF, and SVG file output. + + Cairo is designed to produce consistent output on all output + media while taking advantage of display hardware acceleration + when available (e.g., through the X Render Extension). + ''; + homepage = "http://cairographics.org/"; + license = with licenses; [ + lgpl2Plus + mpl10 + ]; + pkgConfigModules = [ + "cairo-pdf" + "cairo-ps" + "cairo-svg" + ] ++ lib.optional gobjectSupport "cairo-gobject"; + platforms = platforms.all; + }; + } +) diff --git a/pkgs/by-name/ca/cakelisp/package.nix b/pkgs/by-name/ca/cakelisp/package.nix index 48e3e9efa5fbb8..53db7144b23375 100644 --- a/pkgs/by-name/ca/cakelisp/package.nix +++ b/pkgs/by-name/ca/cakelisp/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchgit, gcc, unstableGitUpdater }: +{ + lib, + stdenv, + fetchgit, + gcc, + unstableGitUpdater, +}: stdenv.mkDerivation { pname = "cakelisp"; @@ -13,16 +19,18 @@ stdenv.mkDerivation { buildInputs = [ gcc ]; - postPatch = '' - substituteInPlace runtime/HotReloading.cake \ - --replace '"/usr/bin/g++"' '"${gcc}/bin/g++"' - substituteInPlace src/ModuleManager.cpp \ - --replace '"/usr/bin/g++"' '"${gcc}/bin/g++"' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace Build.sh --replace '--export-dynamic' '-export_dynamic' - substituteInPlace runtime/HotReloading.cake --replace '--export-dynamic' '-export_dynamic' - substituteInPlace Bootstrap.cake --replace '--export-dynamic' '-export_dynamic' - ''; + postPatch = + '' + substituteInPlace runtime/HotReloading.cake \ + --replace '"/usr/bin/g++"' '"${gcc}/bin/g++"' + substituteInPlace src/ModuleManager.cpp \ + --replace '"/usr/bin/g++"' '"${gcc}/bin/g++"' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace Build.sh --replace '--export-dynamic' '-export_dynamic' + substituteInPlace runtime/HotReloading.cake --replace '--export-dynamic' '-export_dynamic' + substituteInPlace Bootstrap.cake --replace '--export-dynamic' '-export_dynamic' + ''; buildPhase = '' runHook preBuild diff --git a/pkgs/by-name/ca/caladea/package.nix b/pkgs/by-name/ca/caladea/package.nix index b97dae690d9c79..604ed6ab3dcc45 100644 --- a/pkgs/by-name/ca/caladea/package.nix +++ b/pkgs/by-name/ca/caladea/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "caladea"; diff --git a/pkgs/by-name/ca/calamares-nixos-extensions/package.nix b/pkgs/by-name/ca/calamares-nixos-extensions/package.nix index 5a01ac7defd497..2e9c407c5ae834 100644 --- a/pkgs/by-name/ca/calamares-nixos-extensions/package.nix +++ b/pkgs/by-name/ca/calamares-nixos-extensions/package.nix @@ -1,4 +1,8 @@ -{ stdenv, fetchFromGitHub, lib }: +{ + stdenv, + fetchFromGitHub, + lib, +}: stdenv.mkDerivation (finalAttrs: { pname = "calamares-nixos-extensions"; @@ -23,7 +27,13 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Calamares modules for NixOS"; homepage = "https://github.com/NixOS/calamares-nixos-extensions"; - license = with licenses; [ gpl3Plus bsd2 cc-by-40 cc-by-sa-40 cc0 ]; + license = with licenses; [ + gpl3Plus + bsd2 + cc-by-40 + cc-by-sa-40 + cc0 + ]; maintainers = with maintainers; [ vlinkz ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/ca/calc/package.nix b/pkgs/by-name/ca/calc/package.nix index 699f3d25caf748..79ae9befe1eafb 100644 --- a/pkgs/by-name/ca/calc/package.nix +++ b/pkgs/by-name/ca/calc/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, ncurses -, readline -, unixtools -, enableReadline ? true +{ + lib, + stdenv, + fetchurl, + makeWrapper, + ncurses, + readline, + unixtools, + enableReadline ? true, }: stdenv.mkDerivation (finalAttrs: { @@ -36,22 +37,23 @@ stdenv.mkDerivation (finalAttrs: { readline ]; - makeFlags = [ - "T=$(out)" - "INCDIR=" - "BINDIR=/bin" - "LIBDIR=/lib" - "CALC_SHAREDIR=/share/calc" - "CALC_INCDIR=/include" - "MANDIR=/share/man/man1" + makeFlags = + [ + "T=$(out)" + "INCDIR=" + "BINDIR=/bin" + "LIBDIR=/lib" + "CALC_SHAREDIR=/share/calc" + "CALC_INCDIR=/include" + "MANDIR=/share/man/man1" - # Handle LDFLAGS defaults in calc - "DEFAULT_LIB_INSTALL_PATH=$(out)/lib" - ] - ++ lib.optionals enableReadline [ - "READLINE_LIB=-lreadline" - "USE_READLINE=-DUSE_READLINE" - ]; + # Handle LDFLAGS defaults in calc + "DEFAULT_LIB_INSTALL_PATH=$(out)/lib" + ] + ++ lib.optionals enableReadline [ + "READLINE_LIB=-lreadline" + "USE_READLINE=-DUSE_READLINE" + ]; meta = { homepage = "http://www.isthe.com/chongo/tech/comp/calc/"; @@ -60,9 +62,7 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://github.com/lcn2/calc/blob/v${finalAttrs.version}/CHANGES"; # The licensing situation depends on readline (see section 3 of the LGPL) # If linked against readline then GPLv2 otherwise LGPLv2.1 - license = if enableReadline - then lib.licenses.gpl2Only - else lib.licenses.lgpl21Only; + license = if enableReadline then lib.licenses.gpl2Only else lib.licenses.lgpl21Only; maintainers = with lib.maintainers; [ matthewbauer ]; platforms = lib.platforms.all; }; diff --git a/pkgs/by-name/ca/calcium/package.nix b/pkgs/by-name/ca/calcium/package.nix index 03e27e1fce152b..5ecb97953114a1 100644 --- a/pkgs/by-name/ca/calcium/package.nix +++ b/pkgs/by-name/ca/calcium/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, mpir -, gmp -, mpfr -, flint -, arb -, antic +{ + lib, + stdenv, + fetchFromGitHub, + mpir, + gmp, + mpfr, + flint, + arb, + antic, }: stdenv.mkDerivation rec { @@ -20,7 +21,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-Ony2FGMnWyNqD7adGeiDtysHNZ4ClMvQ1ijVPSHJmyc="; }; - buildInputs = [ mpir gmp mpfr flint arb antic ]; + buildInputs = [ + mpir + gmp + mpfr + flint + arb + antic + ]; configureFlags = [ "--with-gmp=${gmp}" diff --git a/pkgs/by-name/ca/calcoo/package.nix b/pkgs/by-name/ca/calcoo/package.nix index 462b56d50ce099..dfba85b2e66723 100644 --- a/pkgs/by-name/ca/calcoo/package.nix +++ b/pkgs/by-name/ca/calcoo/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchzip -, ant -, stripJavaArchivesHook -, jdk -, makeWrapper +{ + lib, + stdenv, + fetchzip, + ant, + stripJavaArchivesHook, + jdk, + makeWrapper, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ca/calculix/package.nix b/pkgs/by-name/ca/calculix/package.nix index 8af2ea9f4bceb0..aae21451339197 100644 --- a/pkgs/by-name/ca/calculix/package.nix +++ b/pkgs/by-name/ca/calculix/package.nix @@ -1,8 +1,15 @@ -{ lib, stdenv, fetchurl, gfortran, arpack, spooles, blas, lapack }: - -assert (blas.isILP64 == lapack.isILP64 && - blas.isILP64 == arpack.isILP64 && - !blas.isILP64); +{ + lib, + stdenv, + fetchurl, + gfortran, + arpack, + spooles, + blas, + lapack, +}: + +assert (blas.isILP64 == lapack.isILP64 && blas.isILP64 == arpack.isILP64 && !blas.isILP64); stdenv.mkDerivation rec { pname = "calculix"; @@ -15,7 +22,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ gfortran ]; - buildInputs = [ arpack spooles blas lapack ]; + buildInputs = [ + arpack + spooles + blas + lapack + ]; env.NIX_CFLAGS_COMPILE = toString [ "-I${spooles}/include/spooles" diff --git a/pkgs/by-name/ca/calcure/package.nix b/pkgs/by-name/ca/calcure/package.nix index 29fc8c6c91ca4f..50e5346a70db14 100644 --- a/pkgs/by-name/ca/calcure/package.nix +++ b/pkgs/by-name/ca/calcure/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ca/calcurse/package.nix b/pkgs/by-name/ca/calcurse/package.nix index 49d8a9e42d421b..6820b0cbedab50 100644 --- a/pkgs/by-name/ca/calcurse/package.nix +++ b/pkgs/by-name/ca/calcurse/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, ncurses, gettext, python3, python3Packages, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + ncurses, + gettext, + python3, + python3Packages, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "calcurse"; @@ -9,7 +18,12 @@ stdenv.mkDerivation rec { hash = "sha256-2GuzcBT9abjYPMuQSsl5xrjd9Z7j28gPWidFJeTVgwo="; }; - buildInputs = [ ncurses gettext python3 python3Packages.wrapPython ]; + buildInputs = [ + ncurses + gettext + python3 + python3Packages.wrapPython + ]; nativeBuildInputs = [ makeWrapper ]; postInstall = '' diff --git a/pkgs/by-name/ca/calendar-cli/package.nix b/pkgs/by-name/ca/calendar-cli/package.nix index 7cac9f4ae0f325..38c5e282c063d5 100644 --- a/pkgs/by-name/ca/calendar-cli/package.nix +++ b/pkgs/by-name/ca/calendar-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, nixosTests +{ + lib, + python3, + fetchFromGitHub, + nixosTests, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ca/caligula/package.nix b/pkgs/by-name/ca/caligula/package.nix index 75cc0534138c8b..65aef91be6774f 100644 --- a/pkgs/by-name/ca/caligula/package.nix +++ b/pkgs/by-name/ca/caligula/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -26,7 +27,10 @@ rustPlatform.buildRustPackage rec { description = "User-friendly, lightweight TUI for disk imaging"; homepage = "https://github.com/ifd3f/caligula/"; license = licenses.gpl3Only; - maintainers = with maintainers; [ ifd3f sodiboo ]; + maintainers = with maintainers; [ + ifd3f + sodiboo + ]; platforms = platforms.linux ++ platforms.darwin; mainProgram = "caligula"; }; diff --git a/pkgs/by-name/ca/callaudiod/package.nix b/pkgs/by-name/ca/callaudiod/package.nix index 51dc15f4ec5450..e77fe107acdb39 100644 --- a/pkgs/by-name/ca/callaudiod/package.nix +++ b/pkgs/by-name/ca/callaudiod/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, glib -, alsa-lib -, libpulseaudio +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + glib, + alsa-lib, + libpulseaudio, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ca/calls/package.nix b/pkgs/by-name/ca/calls/package.nix index 1497e7deda600c..fbb00089be878a 100644 --- a/pkgs/by-name/ca/calls/package.nix +++ b/pkgs/by-name/ca/calls/package.nix @@ -1,35 +1,36 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, libadwaita -, libsecret -, modemmanager -, gtk4 -, gom -, gsound -, feedbackd -, callaudiod -, evolution-data-server-gtk4 -, folks -, desktop-file-utils -, appstream-glib -, libpeas2 -, dbus -, vala -, wrapGAppsHook4 -, xvfb-run -, gtk-doc -, bubblewrap -, docbook-xsl-nons -, docbook_xml_dtd_43 -, docutils -, gst_all_1 -, shared-mime-info -, sofia_sip -, writeShellScriptBin +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + libadwaita, + libsecret, + modemmanager, + gtk4, + gom, + gsound, + feedbackd, + callaudiod, + evolution-data-server-gtk4, + folks, + desktop-file-utils, + appstream-glib, + libpeas2, + dbus, + vala, + wrapGAppsHook4, + xvfb-run, + gtk-doc, + bubblewrap, + docbook-xsl-nons, + docbook_xml_dtd_43, + docutils, + gst_all_1, + shared-mime-info, + sofia_sip, + writeShellScriptBin, }: stdenv.mkDerivation (finalAttrs: { @@ -45,7 +46,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-HzQz5jmlXwUHLXC6nhHCa8E8zczaA89YxteZgxSV0YY="; }; - outputs = [ "out" "devdoc" ]; + outputs = [ + "out" + "devdoc" + ]; nativeBuildInputs = [ meson diff --git a/pkgs/by-name/ca/cambalache/package.nix b/pkgs/by-name/ca/cambalache/package.nix index 6af8672e03e349..a664bdc6ac1cd0 100644 --- a/pkgs/by-name/ca/cambalache/package.nix +++ b/pkgs/by-name/ca/cambalache/package.nix @@ -1,22 +1,23 @@ -{ lib -, fetchFromGitLab -, python3 -, meson -, ninja -, pkg-config -, gobject-introspection -, desktop-file-utils -, shared-mime-info -, wrapGAppsHook4 -, glib -, gtk3 -, gtk4 -, gtksourceview5 -, libadwaita -, libhandy -, webkitgtk_4_1 -, webkitgtk_6_0 -, nix-update-script +{ + lib, + fetchFromGitLab, + python3, + meson, + ninja, + pkg-config, + gobject-introspection, + desktop-file-utils, + shared-mime-info, + wrapGAppsHook4, + glib, + gtk3, + gtk4, + gtksourceview5, + libadwaita, + libhandy, + webkitgtk_4_1, + webkitgtk_6_0, + nix-update-script, }: python3.pkgs.buildPythonApplication rec { @@ -77,7 +78,12 @@ python3.pkgs.buildPythonApplication rec { # Let python wrapper use GNOME flags. makeWrapperArgs+=( # For broadway daemons - --prefix PATH : "${lib.makeBinPath [ gtk3 gtk4 ]}" + --prefix PATH : "${ + lib.makeBinPath [ + gtk3 + gtk4 + ] + }" "''${gappsWrapperArgs[@]}" ) ''; diff --git a/pkgs/by-name/ca/camingo-code/package.nix b/pkgs/by-name/ca/camingo-code/package.nix index 6bb3f02d7b1fa2..6fceebb1a6f9a2 100644 --- a/pkgs/by-name/ca/camingo-code/package.nix +++ b/pkgs/by-name/ca/camingo-code/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "camingo-code"; diff --git a/pkgs/by-name/ca/camunda-modeler/package.nix b/pkgs/by-name/ca/camunda-modeler/package.nix index 089587f81382a7..94cf4bda222020 100644 --- a/pkgs/by-name/ca/camunda-modeler/package.nix +++ b/pkgs/by-name/ca/camunda-modeler/package.nix @@ -1,10 +1,11 @@ -{ stdenvNoCC -, lib -, fetchurl -, electron -, makeWrapper -, makeDesktopItem -, copyDesktopItems +{ + stdenvNoCC, + lib, + fetchurl, + electron, + makeWrapper, + makeDesktopItem, + copyDesktopItems, }: stdenvNoCC.mkDerivation rec { @@ -50,10 +51,22 @@ stdenvNoCC.mkDerivation rec { exec = pname; desktopName = "Camunda Modeler"; icon = pname; - keywords = [ "bpmn" "cmmn" "dmn" "form" "modeler" "camunda"]; + keywords = [ + "bpmn" + "cmmn" + "dmn" + "form" + "modeler" + "camunda" + ]; genericName = "Process Modeling Tool"; comment = meta.description; - mimeTypes = [ "application/bpmn" "application/cmmn" "application/dmn" "application/camunda-form" ]; + mimeTypes = [ + "application/bpmn" + "application/cmmn" + "application/dmn" + "application/camunda-form" + ]; extraConfig = { X-Ayatana-Desktop-Shortcuts = "NewWindow;RepositoryBrowser"; }; @@ -69,4 +82,3 @@ stdenvNoCC.mkDerivation rec { mainProgram = "camunda-modeler"; }; } - diff --git a/pkgs/by-name/ca/can-utils/package.nix b/pkgs/by-name/ca/can-utils/package.nix index 6d5b7e0d650643..3dd97b7e8f64dd 100644 --- a/pkgs/by-name/ca/can-utils/package.nix +++ b/pkgs/by-name/ca/can-utils/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "can-utils"; @@ -18,6 +22,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/linux-can/can-utils"; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ bjornfor Luflosi ]; + maintainers = with maintainers; [ + bjornfor + Luflosi + ]; }; } diff --git a/pkgs/by-name/ca/cannelloni/package.nix b/pkgs/by-name/ca/cannelloni/package.nix index 9d2c199a234031..d86ea862d935af 100644 --- a/pkgs/by-name/ca/cannelloni/package.nix +++ b/pkgs/by-name/ca/cannelloni/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, lksctp-tools, sctpSupport ? true }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + lksctp-tools, + sctpSupport ? true, +}: stdenv.mkDerivation (finalAttrs: { pname = "cannelloni"; diff --git a/pkgs/by-name/ca/canon-cups-ufr2/package.nix b/pkgs/by-name/ca/canon-cups-ufr2/package.nix index 9f34deeeff942d..dfc33e0ea7a8dc 100644 --- a/pkgs/by-name/ca/canon-cups-ufr2/package.nix +++ b/pkgs/by-name/ca/canon-cups-ufr2/package.nix @@ -1,34 +1,38 @@ -{ lib -, stdenv -, fetchurl -, unzip -, autoconf -, automake -, libtool_1_5 -, makeWrapper -, cups -, jbigkit -, libjpeg -, libgcrypt -, glib -, gtk3 -, gdk-pixbuf -, pango -, cairo -, atk -, pkg-config -, libxml2 -, libredirect -, ghostscript -, pkgs -, zlib +{ + lib, + stdenv, + fetchurl, + unzip, + autoconf, + automake, + libtool_1_5, + makeWrapper, + cups, + jbigkit, + libjpeg, + libgcrypt, + glib, + gtk3, + gdk-pixbuf, + pango, + cairo, + atk, + pkg-config, + libxml2, + libredirect, + ghostscript, + pkgs, + zlib, }: let system = - if stdenv.hostPlatform.system == "x86_64-linux" then "intel" - else if stdenv.hostPlatform.system == "aarch64-linux" then "arm" - else throw "Unsupported platform for Canon UFR2 Drivers: ${stdenv.hostPlatform.system}"; + if stdenv.hostPlatform.system == "x86_64-linux" then + "intel" + else if stdenv.hostPlatform.system == "aarch64-linux" then + "arm" + else + throw "Unsupported platform for Canon UFR2 Drivers: ${stdenv.hostPlatform.system}"; ld64 = "${stdenv.cc}/nix-support/dynamic-linker"; libs = pkgs: lib.makeLibraryPath buildInputs; @@ -43,7 +47,20 @@ let hash = "sha256-JQAe/avYG+9TAsH26UGai6u8/upRXwZrGBc/hd4jZe8="; }; - buildInputs = [ cups zlib jbigkit libjpeg libgcrypt glib gtk3 libxml2 gdk-pixbuf pango cairo atk ]; + buildInputs = [ + cups + zlib + jbigkit + libjpeg + libgcrypt + glib + gtk3 + libxml2 + gdk-pixbuf + pango + cairo + atk + ]; in stdenv.mkDerivation rec { pname = "canon-cups-ufr2"; @@ -76,7 +93,14 @@ stdenv.mkDerivation rec { ) ''; - nativeBuildInputs = [ makeWrapper unzip autoconf automake libtool_1_5 pkg-config ]; + nativeBuildInputs = [ + makeWrapper + unzip + autoconf + automake + libtool_1_5 + pkg-config + ]; inherit buildInputs; diff --git a/pkgs/by-name/ca/cansina/package.nix b/pkgs/by-name/ca/cansina/package.nix index 11e8d9fad487e9..d0cc43ce38f7f8 100644 --- a/pkgs/by-name/ca/cansina/package.nix +++ b/pkgs/by-name/ca/cansina/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ca/canta-theme/package.nix b/pkgs/by-name/ca/canta-theme/package.nix index 8f06327b9706ca..9a9d574c7425b9 100644 --- a/pkgs/by-name/ca/canta-theme/package.nix +++ b/pkgs/by-name/ca/canta-theme/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, gdk-pixbuf -, librsvg -, gtk-engine-murrine -, gtk3 -, adwaita-icon-theme -, gnome-icon-theme -, numix-icon-theme-circle -, hicolor-icon-theme +{ + lib, + stdenv, + fetchFromGitHub, + gdk-pixbuf, + librsvg, + gtk-engine-murrine, + gtk3, + adwaita-icon-theme, + gnome-icon-theme, + numix-icon-theme-circle, + hicolor-icon-theme, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ca/cantarell-fonts/package.nix b/pkgs/by-name/ca/cantarell-fonts/package.nix index 4dc5cc2d73344d..10a8e71838dcca 100644 --- a/pkgs/by-name/ca/cantarell-fonts/package.nix +++ b/pkgs/by-name/ca/cantarell-fonts/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, python3 -, gettext -, appstream-glib -, gnome +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + python3, + gettext, + appstream-glib, + gnome, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ca/canto-curses/package.nix b/pkgs/by-name/ca/canto-curses/package.nix index 0c69125ebf9f19..78be4ecaeb2d01 100644 --- a/pkgs/by-name/ca/canto-curses/package.nix +++ b/pkgs/by-name/ca/canto-curses/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, python3Packages, readline, ncurses, canto-daemon }: +{ + lib, + fetchFromGitHub, + python3Packages, + readline, + ncurses, + canto-daemon, +}: python3Packages.buildPythonApplication rec { version = "0.9.9"; @@ -11,7 +18,11 @@ python3Packages.buildPythonApplication rec { sha256 = "1vzb9n1j4gxigzll6654ln79lzbrrm6yy0lyazd9kldyl349b8sr"; }; - buildInputs = [ readline ncurses canto-daemon ]; + buildInputs = [ + readline + ncurses + canto-daemon + ]; propagatedBuildInputs = [ canto-daemon ]; meta = { diff --git a/pkgs/by-name/ca/canto-daemon/package.nix b/pkgs/by-name/ca/canto-daemon/package.nix index 5eb8c9d74379fd..1a26d98de25327 100644 --- a/pkgs/by-name/ca/canto-daemon/package.nix +++ b/pkgs/by-name/ca/canto-daemon/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages, }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { version = "0.9.8"; @@ -30,6 +34,6 @@ python3Packages.buildPythonApplication rec { homepage = "https://codezen.org/canto-ng/"; license = licenses.gpl2; platforms = platforms.linux; - maintainers = with maintainers;[ devhell ]; + maintainers = with maintainers; [ devhell ]; }; } diff --git a/pkgs/by-name/ca/cantoolz/package.nix b/pkgs/by-name/ca/cantoolz/package.nix index 9da4923400071e..7d2d8d9c8c8377 100644 --- a/pkgs/by-name/ca/cantoolz/package.nix +++ b/pkgs/by-name/ca/cantoolz/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, python3 +{ + lib, + fetchFromGitHub, + fetchpatch, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ca/capitaine-cursors-themed/package.nix b/pkgs/by-name/ca/capitaine-cursors-themed/package.nix index e29c38dc5df6bb..c2e39c68664b18 100644 --- a/pkgs/by-name/ca/capitaine-cursors-themed/package.nix +++ b/pkgs/by-name/ca/capitaine-cursors-themed/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "capitaine-cursors-themed"; diff --git a/pkgs/by-name/ca/capitaine-cursors/package.nix b/pkgs/by-name/ca/capitaine-cursors/package.nix index 1bb855790055d3..b3e735687af859 100644 --- a/pkgs/by-name/ca/capitaine-cursors/package.nix +++ b/pkgs/by-name/ca/capitaine-cursors/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenvNoCC, fetchFromGitHub, fetchpatch, makeFontsConf -, inkscape, xcursorgen, bc }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + fetchpatch, + makeFontsConf, + inkscape, + xcursorgen, + bc, +}: stdenvNoCC.mkDerivation rec { pname = "capitaine-cursors"; diff --git a/pkgs/by-name/ca/capnproto-java/package.nix b/pkgs/by-name/ca/capnproto-java/package.nix index 73c068543fb3bc..d54eac703abb5e 100644 --- a/pkgs/by-name/ca/capnproto-java/package.nix +++ b/pkgs/by-name/ca/capnproto-java/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, capnproto, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + capnproto, + pkg-config, +}: stdenv.mkDerivation rec { pname = "capnproto-java"; @@ -23,6 +29,9 @@ stdenv.mkDerivation rec { longDescription = "Only includes compiler plugin, the Java runtime/library that the generated code will link to must be built separately with Maven."; homepage = "https://dwrensha.github.io/capnproto-java/index.html"; license = licenses.mit; - maintainers = with maintainers; [ bhipple solson ]; + maintainers = with maintainers; [ + bhipple + solson + ]; }; } diff --git a/pkgs/by-name/ca/capnproto-rust/package.nix b/pkgs/by-name/ca/capnproto-rust/package.nix index e63cca6a5e90db..087dcf2745ac96 100644 --- a/pkgs/by-name/ca/capnproto-rust/package.nix +++ b/pkgs/by-name/ca/capnproto-rust/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchCrate -, rustPlatform -, capnproto +{ + lib, + fetchCrate, + rustPlatform, + capnproto, }: rustPlatform.buildRustPackage rec { @@ -29,6 +30,9 @@ rustPlatform.buildRustPackage rec { description = "Cap'n Proto codegen plugin for Rust"; homepage = "https://github.com/capnproto/capnproto-rust"; license = licenses.mit; - maintainers = with maintainers; [ mikroskeem solson ]; + maintainers = with maintainers; [ + mikroskeem + solson + ]; }; } diff --git a/pkgs/by-name/ca/capnproto/package.nix b/pkgs/by-name/ca/capnproto/package.nix index 4e96d6a6b9931d..c32231997e7d5b 100644 --- a/pkgs/by-name/ca/capnproto/package.nix +++ b/pkgs/by-name/ca/capnproto/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, openssl -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openssl, + zlib, }: stdenv.mkDerivation rec { @@ -19,18 +20,21 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - propagatedBuildInputs = [ openssl zlib ]; + propagatedBuildInputs = [ + openssl + zlib + ]; meta = with lib; { - homepage = "https://capnproto.org/"; + homepage = "https://capnproto.org/"; description = "Cap'n Proto cerealization protocol"; longDescription = '' Cap’n Proto is an insanely fast data interchange format and capability-based RPC system. Think JSON, except binary. Or think Protocol Buffers, except faster. ''; - license = licenses.mit; - platforms = platforms.all; + license = licenses.mit; + platforms = platforms.all; maintainers = [ ]; }; } diff --git a/pkgs/by-name/ca/caprice32/package.nix b/pkgs/by-name/ca/caprice32/package.nix index 54ebfc49964f52..a5dde1c577e3de 100644 --- a/pkgs/by-name/ca/caprice32/package.nix +++ b/pkgs/by-name/ca/caprice32/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, desktop-file-utils, libpng -, pkg-config, SDL, freetype, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + desktop-file-utils, + libpng, + pkg-config, + SDL, + freetype, + zlib, +}: stdenv.mkDerivation rec { @@ -16,8 +25,16 @@ stdenv.mkDerivation rec { sha256 = "0hng5krwgc1h9bz1xlkp2hwnvas965nd7sb3z9mb2m6x9ghxlacz"; }; - nativeBuildInputs = [ desktop-file-utils pkg-config ]; - buildInputs = [ libpng SDL freetype zlib ]; + nativeBuildInputs = [ + desktop-file-utils + pkg-config + ]; + buildInputs = [ + libpng + SDL + freetype + zlib + ]; patches = [ ./string.patch ]; diff --git a/pkgs/by-name/ca/caprine-bin/build-from-appimage.nix b/pkgs/by-name/ca/caprine-bin/build-from-appimage.nix index ed0e978c1524fb..51307ae91d124a 100644 --- a/pkgs/by-name/ca/caprine-bin/build-from-appimage.nix +++ b/pkgs/by-name/ca/caprine-bin/build-from-appimage.nix @@ -1,10 +1,11 @@ -{ fetchurl -, appimageTools -, xorg -, pname -, version -, sha256 -, metaCommon ? { } +{ + fetchurl, + appimageTools, + xorg, + pname, + version, + sha256, + metaCommon ? { }, }: let diff --git a/pkgs/by-name/ca/caprine-bin/build-from-dmg.nix b/pkgs/by-name/ca/caprine-bin/build-from-dmg.nix index 6a53bba026c5a8..dce0b0b6395f81 100644 --- a/pkgs/by-name/ca/caprine-bin/build-from-dmg.nix +++ b/pkgs/by-name/ca/caprine-bin/build-from-dmg.nix @@ -1,11 +1,12 @@ -{ stdenvNoCC -, lib -, fetchurl -, undmg -, pname -, version -, sha256 -, metaCommon ? { } +{ + stdenvNoCC, + lib, + fetchurl, + undmg, + pname, + version, + sha256, + metaCommon ? { }, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/ca/caprine-bin/package.nix b/pkgs/by-name/ca/caprine-bin/package.nix index f82ae2ac42201e..076c9533e647ef 100644 --- a/pkgs/by-name/ca/caprine-bin/package.nix +++ b/pkgs/by-name/ca/caprine-bin/package.nix @@ -1,4 +1,8 @@ -{ lib, callPackage, stdenvNoCC }: +{ + lib, + callPackage, + stdenvNoCC, +}: let pname = "caprine"; version = "2.59.1"; @@ -18,10 +22,13 @@ let sha256 = "sha256-WMT4yrLjDSMsI/lFbYODu3/0whcF+++4ShoChfMyLfQ="; }; in -(if stdenvNoCC.hostPlatform.isDarwin then x86_64-dmg else x86_64-appimage).overrideAttrs (oldAttrs: { - passthru = (oldAttrs.passthru or { }) // { inherit x86_64-appimage x86_64-dmg; }; - meta = oldAttrs.meta // { - platforms = x86_64-appimage.meta.platforms ++ x86_64-dmg.meta.platforms; - mainProgram = "caprine"; - }; -}) +(if stdenvNoCC.hostPlatform.isDarwin then x86_64-dmg else x86_64-appimage).overrideAttrs + (oldAttrs: { + passthru = (oldAttrs.passthru or { }) // { + inherit x86_64-appimage x86_64-dmg; + }; + meta = oldAttrs.meta // { + platforms = x86_64-appimage.meta.platforms ++ x86_64-dmg.meta.platforms; + mainProgram = "caprine"; + }; + }) diff --git a/pkgs/by-name/ca/caps/package.nix b/pkgs/by-name/ca/caps/package.nix index 90b361aeef7623..4c58ee2c316cb5 100644 --- a/pkgs/by-name/ca/caps/package.nix +++ b/pkgs/by-name/ca/caps/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "caps"; version = "0.9.26"; diff --git a/pkgs/by-name/ca/captive-browser/package.nix b/pkgs/by-name/ca/captive-browser/package.nix index ec24158635eeb7..14e5ade875c80c 100644 --- a/pkgs/by-name/ca/captive-browser/package.nix +++ b/pkgs/by-name/ca/captive-browser/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, fetchpatch }: +{ + lib, + fetchFromGitHub, + buildGoModule, + fetchpatch, +}: buildGoModule rec { pname = "captive-browser"; @@ -22,7 +27,10 @@ buildGoModule rec { }) ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Dedicated Chrome instance to log into captive portals without messing with DNS settings"; diff --git a/pkgs/by-name/ca/capture/package.nix b/pkgs/by-name/ca/capture/package.nix index 9eac4dd0bbc553..30632cd00f7448 100644 --- a/pkgs/by-name/ca/capture/package.nix +++ b/pkgs/by-name/ca/capture/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, slop, ffmpeg, fetchFromGitHub, makeWrapper}: +{ + lib, + stdenv, + slop, + ffmpeg, + fetchFromGitHub, + makeWrapper, +}: stdenv.mkDerivation { pname = "capture-unstable"; @@ -7,7 +14,7 @@ stdenv.mkDerivation { src = fetchFromGitHub { owner = "buhman"; repo = "capture"; - rev = "80dd9e7195aad5c132badef610f19509f3935b24"; + rev = "80dd9e7195aad5c132badef610f19509f3935b24"; sha256 = "0zyyg4mvrny7cc2xgvfip97b6yc75ka5ni39rwls93971jbk83d6"; }; @@ -18,7 +25,12 @@ stdenv.mkDerivation { patchShebangs $out/bin/capture wrapProgram $out/bin/capture \ - --prefix PATH : '${lib.makeBinPath [ slop ffmpeg ]}' + --prefix PATH : '${ + lib.makeBinPath [ + slop + ffmpeg + ] + }' ''; meta = with lib; { diff --git a/pkgs/by-name/ca/carbon-now-cli/package.nix b/pkgs/by-name/ca/carbon-now-cli/package.nix index 7d35283ab74c62..bb6ea656a022a5 100644 --- a/pkgs/by-name/ca/carbon-now-cli/package.nix +++ b/pkgs/by-name/ca/carbon-now-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ca/cardboard/package.nix b/pkgs/by-name/ca/cardboard/package.nix index e8bc82fd1cf014..4a09103c91d0e8 100644 --- a/pkgs/by-name/ca/cardboard/package.nix +++ b/pkgs/by-name/ca/cardboard/package.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchurl -, fetchgit -, ffmpeg -, libGL -, libX11 -, libcap -, libdrm -, libinput -, libpng -, libxcb -, libxkbcommon -, mesa -, meson -, ninja -, pandoc -, pixman -, pkg-config -, unzip -, wayland -, wayland-protocols -, wayland-scanner -, xcbutilerrors -, xcbutilimage -, xcbutilwm +{ + lib, + stdenv, + fetchFromGitLab, + fetchurl, + fetchgit, + ffmpeg, + libGL, + libX11, + libcap, + libdrm, + libinput, + libpng, + libxcb, + libxkbcommon, + mesa, + meson, + ninja, + pandoc, + pixman, + pkg-config, + unzip, + wayland, + wayland-protocols, + wayland-scanner, + xcbutilerrors, + xcbutilimage, + xcbutilwm, }: let @@ -72,7 +73,12 @@ stdenv.mkDerivation { src = allSources.cardboard; - outputs = [ "out" "dev" "lib" "man" ]; + outputs = [ + "out" + "dev" + "lib" + "man" + ]; nativeBuildInputs = [ meson diff --git a/pkgs/by-name/ca/carddav-util/package.nix b/pkgs/by-name/ca/carddav-util/package.nix index 539cfa67aa5a03..482e564d202218 100644 --- a/pkgs/by-name/ca/carddav-util/package.nix +++ b/pkgs/by-name/ca/carddav-util/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, python3Packages, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + python3Packages, + makeWrapper, +}: stdenv.mkDerivation { pname = "carddav"; @@ -13,7 +19,11 @@ stdenv.mkDerivation { nativeBuildInputs = [ makeWrapper ]; - propagatedBuildInputs = with python3Packages; [ requests vobject lxml ]; + propagatedBuildInputs = with python3Packages; [ + requests + vobject + lxml + ]; strictDeps = true; diff --git a/pkgs/by-name/ca/cardo/package.nix b/pkgs/by-name/ca/cardo/package.nix index c862ea7ce8895e..becc77735beda0 100644 --- a/pkgs/by-name/ca/cardo/package.nix +++ b/pkgs/by-name/ca/cardo/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { pname = "cardo"; diff --git a/pkgs/by-name/ca/cargo-all-features/package.nix b/pkgs/by-name/ca/cargo-all-features/package.nix index bb00a230a85e89..96d9942b515842 100644 --- a/pkgs/by-name/ca/cargo-all-features/package.nix +++ b/pkgs/by-name/ca/cargo-all-features/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -17,7 +18,13 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Cargo subcommand to build and test all feature flag combinations"; homepage = "https://github.com/frewsxcv/cargo-all-features"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-apk/package.nix b/pkgs/by-name/ca/cargo-apk/package.nix index c889f643b5cbdb..090b22ed4384a7 100644 --- a/pkgs/by-name/ca/cargo-apk/package.nix +++ b/pkgs/by-name/ca/cargo-apk/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -18,7 +19,10 @@ rustPlatform.buildRustPackage rec { description = "Tool for creating Android packages"; mainProgram = "cargo-apk"; homepage = "https://github.com/rust-windowing/android-ndk-rs"; - license = with licenses;[ mit asl20 ]; + license = with licenses; [ + mit + asl20 + ]; maintainers = with maintainers; [ nickcao ]; }; } diff --git a/pkgs/by-name/ca/cargo-autoinherit/package.nix b/pkgs/by-name/ca/cargo-autoinherit/package.nix index 0e3fc9e7c72b6d..dc462acbf2080b 100644 --- a/pkgs/by-name/ca/cargo-autoinherit/package.nix +++ b/pkgs/by-name/ca/cargo-autoinherit/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "cargo-autoinherit"; @@ -16,10 +20,12 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Automatically DRY up your Rust dependencies"; homepage = "https://github.com/mainmatter/cargo-autoinherit"; - license = with licenses; [ asl20 /* OR */ mit ]; + license = with licenses; [ + asl20 # OR + mit + ]; platforms = platforms.unix; maintainers = with maintainers; [ matthiasbeyer ]; mainProgram = "cargo-autoinherit"; }; } - diff --git a/pkgs/by-name/ca/cargo-benchcmp/package.nix b/pkgs/by-name/ca/cargo-benchcmp/package.nix index 132aa0bc2ffc89..cbb86ed458e631 100644 --- a/pkgs/by-name/ca/cargo-benchcmp/package.nix +++ b/pkgs/by-name/ca/cargo-benchcmp/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, substituteAll -, stdenv +{ + lib, + rustPlatform, + fetchFromGitHub, + substituteAll, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -35,7 +36,10 @@ rustPlatform.buildRustPackage rec { description = "Small utility to compare Rust micro-benchmarks"; mainProgram = "cargo-benchcmp"; homepage = "https://github.com/BurntSushi/cargo-benchcmp"; - license = with licenses; [ mit unlicense ]; + license = with licenses; [ + mit + unlicense + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ca/cargo-binstall/package.nix b/pkgs/by-name/ca/cargo-binstall/package.nix index 83bc587b9c33f3..8aee9dfb5642c2 100644 --- a/pkgs/by-name/ca/cargo-binstall/package.nix +++ b/pkgs/by-name/ca/cargo-binstall/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, bzip2 -, xz -, zstd -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + bzip2, + xz, + zstd, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -26,13 +27,15 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - bzip2 - xz - zstd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + bzip2 + xz + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; buildNoDefaultFeatures = true; buildFeatures = [ @@ -44,8 +47,14 @@ rustPlatform.buildRustPackage rec { "zstd-thin" ]; - cargoBuildFlags = [ "-p" "cargo-binstall" ]; - cargoTestFlags = [ "-p" "cargo-binstall" ]; + cargoBuildFlags = [ + "-p" + "cargo-binstall" + ]; + cargoTestFlags = [ + "-p" + "cargo-binstall" + ]; checkFlags = [ # requires internet access diff --git a/pkgs/by-name/ca/cargo-binutils/package.nix b/pkgs/by-name/ca/cargo-binutils/package.nix index 0f7e53474f6f68..4fa0efde04af04 100644 --- a/pkgs/by-name/ca/cargo-binutils/package.nix +++ b/pkgs/by-name/ca/cargo-binutils/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "cargo-binutils"; @@ -18,7 +22,13 @@ rustPlatform.buildRustPackage rec { ''; homepage = "https://github.com/rust-embedded/cargo-binutils"; changelog = "https://github.com/rust-embedded/cargo-binutils/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; - maintainers = with maintainers; [ stupremee matthiasbeyer ]; + license = with licenses; [ + asl20 + mit + ]; + maintainers = with maintainers; [ + stupremee + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-bitbake/package.nix b/pkgs/by-name/ca/cargo-bitbake/package.nix index 91b49120222090..3836e251003a7a 100644 --- a/pkgs/by-name/ca/cargo-bitbake/package.nix +++ b/pkgs/by-name/ca/cargo-bitbake/package.nix @@ -1,4 +1,10 @@ -{ lib, pkg-config, rustPlatform, fetchFromGitHub, openssl }: +{ + lib, + pkg-config, + rustPlatform, + fetchFromGitHub, + openssl, +}: rustPlatform.buildRustPackage rec { pname = "cargo-bitbake"; @@ -20,7 +26,10 @@ rustPlatform.buildRustPackage rec { description = "Cargo extension that can generate BitBake recipes utilizing the classes from meta-rust"; mainProgram = "cargo-bitbake"; homepage = "https://github.com/meta-rust/cargo-bitbake"; - license = with licenses; [ mit asl20 ]; + license = with licenses; [ + mit + asl20 + ]; maintainers = with maintainers; [ rvarago ]; platforms = [ "x86_64-linux" ]; }; diff --git a/pkgs/by-name/ca/cargo-bloat/package.nix b/pkgs/by-name/ca/cargo-bloat/package.nix index 093f6db75f9617..90e307891cc3f2 100644 --- a/pkgs/by-name/ca/cargo-bloat/package.nix +++ b/pkgs/by-name/ca/cargo-bloat/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "cargo-bloat"; @@ -18,7 +22,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/RazrFalcon/cargo-bloat"; license = licenses.mit; platforms = platforms.unix; - maintainers = with maintainers; [ xrelkd matthiasbeyer ]; + maintainers = with maintainers; [ + xrelkd + matthiasbeyer + ]; mainProgram = "cargo-bloat"; }; } diff --git a/pkgs/by-name/ca/cargo-bolero/package.nix b/pkgs/by-name/ca/cargo-bolero/package.nix index 6183b080040501..4d18ec63ae603e 100644 --- a/pkgs/by-name/ca/cargo-bolero/package.nix +++ b/pkgs/by-name/ca/cargo-bolero/package.nix @@ -1,4 +1,12 @@ -{ lib, rustPlatform, fetchCrate, libbfd, libopcodes, libunwind, nix-update-script }: +{ + lib, + rustPlatform, + fetchCrate, + libbfd, + libopcodes, + libunwind, + nix-update-script, +}: rustPlatform.buildRustPackage rec { pname = "cargo-bolero"; @@ -11,7 +19,11 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-5F72vjEu0qrE3fYPbiw/UFUUnAZcEBcuhDkuqqCBbrM="; - buildInputs = [ libbfd libopcodes libunwind ]; + buildInputs = [ + libbfd + libopcodes + libunwind + ]; passthru = { updateScript = nix-update-script { }; diff --git a/pkgs/by-name/ca/cargo-bootimage/package.nix b/pkgs/by-name/ca/cargo-bootimage/package.nix index 16dc55b64fbc07..5b7a44dc1df362 100644 --- a/pkgs/by-name/ca/cargo-bootimage/package.nix +++ b/pkgs/by-name/ca/cargo-bootimage/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Creates a bootable disk image from a Rust OS kernel"; homepage = "https://github.com/rust-osdev/bootimage"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ dbeckwith ]; }; } diff --git a/pkgs/by-name/ca/cargo-bump/package.nix b/pkgs/by-name/ca/cargo-bump/package.nix index e40d79a14089f3..486d9096761e00 100644 --- a/pkgs/by-name/ca/cargo-bump/package.nix +++ b/pkgs/by-name/ca/cargo-bump/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ca/cargo-bundle-licenses/package.nix b/pkgs/by-name/ca/cargo-bundle-licenses/package.nix index 1a6cc5ca07461e..c9d6943efc5515 100644 --- a/pkgs/by-name/ca/cargo-bundle-licenses/package.nix +++ b/pkgs/by-name/ca/cargo-bundle-licenses/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,13 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-bundle-licenses"; homepage = "https://github.com/sstadick/cargo-bundle-licenses"; changelog = "https://github.com/sstadick/cargo-bundle-licenses/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ mit asl20 ]; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + mit + asl20 + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-bundle/package.nix b/pkgs/by-name/ca/cargo-bundle/package.nix index 7d302da1003b55..213cc492d1b055 100644 --- a/pkgs/by-name/ca/cargo-bundle/package.nix +++ b/pkgs/by-name/ca/cargo-bundle/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, stdenv -, darwin -, libxkbcommon -, wayland +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + stdenv, + darwin, + libxkbcommon, + wayland, }: rustPlatform.buildRustPackage { @@ -26,18 +27,23 @@ rustPlatform.buildRustPackage { pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AppKit - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libxkbcommon - wayland - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AppKit + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libxkbcommon + wayland + ]; meta = with lib; { description = "Wrap rust executables in OS-specific app bundles"; mainProgram = "cargo-bundle"; homepage = "https://github.com/burtonageo/cargo-bundle"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ca/cargo-careful/package.nix b/pkgs/by-name/ca/cargo-careful/package.nix index 125a8a9b8056eb..260b6d92c64379 100644 --- a/pkgs/by-name/ca/cargo-careful/package.nix +++ b/pkgs/by-name/ca/cargo-careful/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,13 @@ rustPlatform.buildRustPackage rec { description = "Tool to execute Rust code carefully, with extra checking along the way"; mainProgram = "cargo-careful"; homepage = "https://github.com/RalfJung/cargo-careful"; - license = with licenses; [ asl20 mit ]; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + asl20 + mit + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-chef/package.nix b/pkgs/by-name/ca/cargo-chef/package.nix index b307704c76fb7c..f5e20e0f1f348c 100644 --- a/pkgs/by-name/ca/cargo-chef/package.nix +++ b/pkgs/by-name/ca/cargo-chef/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "cargo-chef"; diff --git a/pkgs/by-name/ca/cargo-component/package.nix b/pkgs/by-name/ca/cargo-component/package.nix index fd0c1806e27d24..49b1ac6770c9bf 100644 --- a/pkgs/by-name/ca/cargo-component/package.nix +++ b/pkgs/by-name/ca/cargo-component/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -24,11 +25,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; # requires the wasm32-wasi target doCheck = false; diff --git a/pkgs/by-name/ca/cargo-cranky/package.nix b/pkgs/by-name/ca/cargo-cranky/package.nix index cb83bf72b528ba..168b9a97984202 100644 --- a/pkgs/by-name/ca/cargo-cranky/package.nix +++ b/pkgs/by-name/ca/cargo-cranky/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-cranky"; homepage = "https://github.com/ericseppanen/cargo-cranky"; changelog = "https://github.com/ericseppanen/cargo-cranky/releases/tag/${src.rev}"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ca/cargo-criterion/package.nix b/pkgs/by-name/ca/cargo-criterion/package.nix index b139a4ce3a0cb3..96dda36ab06703 100644 --- a/pkgs/by-name/ca/cargo-criterion/package.nix +++ b/pkgs/by-name/ca/cargo-criterion/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "cargo-criterion"; @@ -17,7 +21,13 @@ rustPlatform.buildRustPackage rec { description = "Cargo extension for running Criterion.rs benchmarks"; mainProgram = "cargo-criterion"; homepage = "https://github.com/bheisler/cargo-criterion"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ humancalico matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + humancalico + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-deadlinks/package.nix b/pkgs/by-name/ca/cargo-deadlinks/package.nix index 13cfbcced456a7..e461c80cd04bcb 100644 --- a/pkgs/by-name/ca/cargo-deadlinks/package.nix +++ b/pkgs/by-name/ca/cargo-deadlinks/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, apple-sdk_11 }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + apple-sdk_11, +}: rustPlatform.buildRustPackage rec { pname = "cargo-deadlinks"; @@ -13,15 +19,17 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Bs6WyeHBeZDWLSidoFBLaa2ZEr8oAQcr8JmHCtw34AE="; - checkFlags = [ - # uses internet - "--skip non_existent_http_link --skip working_http_check" - # makes assumption about HTML paths that changed in rust 1.82.0 - "--skip simple_project::it_checks_okay_project_correctly" - "--skip cli_args::it_passes_arguments_through_to_cargo" - ] ++ lib.optional (stdenv.hostPlatform.system != "x86_64-linux") - # assumes the target is x86_64-unknown-linux-gnu - "--skip simple_project::it_checks_okay_project_correctly"; + checkFlags = + [ + # uses internet + "--skip non_existent_http_link --skip working_http_check" + # makes assumption about HTML paths that changed in rust 1.82.0 + "--skip simple_project::it_checks_okay_project_correctly" + "--skip cli_args::it_passes_arguments_through_to_cargo" + ] + ++ lib.optional (stdenv.hostPlatform.system != "x86_64-linux") + # assumes the target is x86_64-unknown-linux-gnu + "--skip simple_project::it_checks_okay_project_correctly"; buildInputs = lib.optional stdenv.hostPlatform.isDarwin apple-sdk_11; @@ -29,7 +37,13 @@ rustPlatform.buildRustPackage rec { description = "Cargo subcommand to check rust documentation for broken links"; homepage = "https://github.com/deadlinks/cargo-deadlinks"; changelog = "https://github.com/deadlinks/cargo-deadlinks/blob/${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ newam matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + newam + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-deny/package.nix b/pkgs/by-name/ca/cargo-deny/package.nix index 146dd01a6d5f54..7a9417ecef7ba3 100644 --- a/pkgs/by-name/ca/cargo-deny/package.nix +++ b/pkgs/by-name/ca/cargo-deny/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, zstd -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + zstd, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -24,12 +25,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - zstd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; env = { ZSTD_SYS_USE_PKG_CONFIG = true; @@ -43,7 +46,14 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-deny"; homepage = "https://github.com/EmbarkStudios/cargo-deny"; changelog = "https://github.com/EmbarkStudios/cargo-deny/blob/${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ figsoda matthiasbeyer jk ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + jk + ]; }; } diff --git a/pkgs/by-name/ca/cargo-depgraph/package.nix b/pkgs/by-name/ca/cargo-depgraph/package.nix index c4379974a6abbf..a1928b19e85923 100644 --- a/pkgs/by-name/ca/cargo-depgraph/package.nix +++ b/pkgs/by-name/ca/cargo-depgraph/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromSourcehut }: +{ + lib, + rustPlatform, + fetchFromSourcehut, +}: rustPlatform.buildRustPackage rec { pname = "cargo-depgraph"; @@ -19,6 +23,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://sr.ht/~jplatte/cargo-depgraph"; changelog = "https://git.sr.ht/~jplatte/cargo-depgraph/tree/${src.rev}/item/CHANGELOG.md"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-dephell/package.nix b/pkgs/by-name/ca/cargo-dephell/package.nix index b1f390f77388fe..2cbdbafe3d0361 100644 --- a/pkgs/by-name/ca/cargo-dephell/package.nix +++ b/pkgs/by-name/ca/cargo-dephell/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, stdenv -, curl -, openssl -, darwin -, libgit2 +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + stdenv, + curl, + openssl, + darwin, + libgit2, }: rustPlatform.buildRustPackage rec { @@ -24,19 +25,23 @@ rustPlatform.buildRustPackage rec { lockFile = ./Cargo.lock; }; - nativeBuildInputs = [ - pkg-config - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - curl - ]; + nativeBuildInputs = + [ + pkg-config + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + curl + ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - curl - darwin.apple_sdk.frameworks.Security - libgit2 - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + curl + darwin.apple_sdk.frameworks.Security + libgit2 + ]; # update Cargo.lock to work with openssl 3 postPatch = '' @@ -51,7 +56,13 @@ rustPlatform.buildRustPackage rec { description = "Tool to analyze the third-party dependencies imported by a rust crate or rust workspace"; mainProgram = "cargo-dephell"; homepage = "https://github.com/mimoo/cargo-dephell"; - license = with licenses; [ mit /* or */ asl20 ]; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + mit # or + asl20 + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-diet/package.nix b/pkgs/by-name/ca/cargo-diet/package.nix index b7b4e2d11d1bb2..90448aa7adbb65 100644 --- a/pkgs/by-name/ca/cargo-diet/package.nix +++ b/pkgs/by-name/ca/cargo-diet/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "cargo-diet"; @@ -19,6 +23,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/the-lean-crate/cargo-diet"; changelog = "https://github.com/the-lean-crate/cargo-diet/blob/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-dist/package.nix b/pkgs/by-name/ca/cargo-dist/package.nix index 22152eed30d716..5d8a41b16ec716 100644 --- a/pkgs/by-name/ca/cargo-dist/package.nix +++ b/pkgs/by-name/ca/cargo-dist/package.nix @@ -1,15 +1,16 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, nix-update-script -, pkg-config -, bzip2 -, xz -, zstd -, stdenv -, darwin -, git -, rustup +{ + lib, + rustPlatform, + fetchFromGitHub, + nix-update-script, + pkg-config, + bzip2, + xz, + zstd, + stdenv, + darwin, + git, + rustup, }: rustPlatform.buildRustPackage rec { @@ -29,13 +30,15 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - bzip2 - xz - zstd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + bzip2 + xz + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; nativeCheckInputs = [ git @@ -58,7 +61,14 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-dist"; homepage = "https://github.com/axodotdev/cargo-dist"; changelog = "https://github.com/axodotdev/cargo-dist/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; - maintainers = with maintainers; [ figsoda matthiasbeyer mistydemeo ]; + license = with licenses; [ + asl20 + mit + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + mistydemeo + ]; }; } diff --git a/pkgs/by-name/ca/cargo-docset/package.nix b/pkgs/by-name/ca/cargo-docset/package.nix index 54328186e8b756..1148261d034b8a 100644 --- a/pkgs/by-name/ca/cargo-docset/package.nix +++ b/pkgs/by-name/ca/cargo-docset/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, gitUpdater -, rustPlatform -, sqlite +{ + lib, + fetchFromGitHub, + gitUpdater, + rustPlatform, + sqlite, }: rustPlatform.buildRustPackage rec { @@ -30,6 +31,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/Robzz/cargo-docset"; changelog = "https://github.com/Robzz/cargo-docset/blob/${version}/CHANGELOG.md"; license = licenses.asl20; - maintainers = with maintainers; [ colinsane matthiasbeyer ]; + maintainers = with maintainers; [ + colinsane + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-duplicates/package.nix b/pkgs/by-name/ca/cargo-duplicates/package.nix index c04dc2ac571dac..30e5f66b9b6a95 100644 --- a/pkgs/by-name/ca/cargo-duplicates/package.nix +++ b/pkgs/by-name/ca/cargo-duplicates/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, curl -, pkg-config -, libgit2 -, openssl -, zlib -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + curl, + pkg-config, + libgit2, + openssl, + zlib, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -28,20 +29,25 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - curl - libgit2 - openssl - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + curl + libgit2 + openssl + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; meta = with lib; { description = "Cargo subcommand for displaying when different versions of a same dependency are pulled in"; mainProgram = "cargo-duplicates"; homepage = "https://github.com/Keruspe/cargo-duplicates"; license = licenses.mit; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-espmonitor/package.nix b/pkgs/by-name/ca/cargo-espmonitor/package.nix index 4c65c7bba3b29d..4d81694e385e70 100644 --- a/pkgs/by-name/ca/cargo-espmonitor/package.nix +++ b/pkgs/by-name/ca/cargo-espmonitor/package.nix @@ -1,7 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { pname = "espmonitor"; diff --git a/pkgs/by-name/ca/cargo-expand/package.nix b/pkgs/by-name/ca/cargo-expand/package.nix index 739dab9a7ec1cf..6530954a1ed93c 100644 --- a/pkgs/by-name/ca/cargo-expand/package.nix +++ b/pkgs/by-name/ca/cargo-expand/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -20,8 +21,14 @@ rustPlatform.buildRustPackage rec { description = "Cargo subcommand to show result of macro expansion"; homepage = "https://github.com/dtolnay/cargo-expand"; changelog = "https://github.com/dtolnay/cargo-expand/releases/tag/${version}"; - license = with licenses; [ mit asl20 ]; - maintainers = with maintainers; [ figsoda xrelkd ]; + license = with licenses; [ + mit + asl20 + ]; + maintainers = with maintainers; [ + figsoda + xrelkd + ]; mainProgram = "cargo-expand"; }; } diff --git a/pkgs/by-name/ca/cargo-fuzz/package.nix b/pkgs/by-name/ca/cargo-fuzz/package.nix index c23108abcf4040..bd30411f16d271 100644 --- a/pkgs/by-name/ca/cargo-fuzz/package.nix +++ b/pkgs/by-name/ca/cargo-fuzz/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "cargo-fuzz"; @@ -19,7 +23,13 @@ rustPlatform.buildRustPackage rec { description = "Command line helpers for fuzzing"; mainProgram = "cargo-fuzz"; homepage = "https://github.com/rust-fuzz/cargo-fuzz"; - license = with licenses; [ mit asl20 ]; - maintainers = with maintainers; [ ekleog matthiasbeyer ]; + license = with licenses; [ + mit + asl20 + ]; + maintainers = with maintainers; [ + ekleog + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-geiger/package.nix b/pkgs/by-name/ca/cargo-geiger/package.nix index c29825cb86b5d4..77c232c50da9cf 100644 --- a/pkgs/by-name/ca/cargo-geiger/package.nix +++ b/pkgs/by-name/ca/cargo-geiger/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, openssl +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, # darwin dependencies -, darwin -, libiconv -, curl + darwin, + libiconv, + curl, }: rustPlatform.buildRustPackage rec { @@ -32,9 +33,19 @@ rustPlatform.buildRustPackage rec { ./allow-warnings.patch ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ CoreFoundation Security libiconv curl ]); - nativeBuildInputs = [ pkg-config ] + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + CoreFoundation + Security + libiconv + curl + ] + ); + nativeBuildInputs = + [ pkg-config ] # curl-sys wants to run curl-config on darwin ++ lib.optionals stdenv.hostPlatform.isDarwin [ curl.dev ]; @@ -70,7 +81,15 @@ rustPlatform.buildRustPackage rec { dependency selection but it can not help you decide when and why unsafe code is appropriate. ''; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ evanjs gepbird jk matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + evanjs + gepbird + jk + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-generate/package.nix b/pkgs/by-name/ca/cargo-generate/package.nix index 162860caae229f..3d2fa1c091d4df 100644 --- a/pkgs/by-name/ca/cargo-generate/package.nix +++ b/pkgs/by-name/ca/cargo-generate/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libgit2 -, openssl -, stdenv -, darwin -, git +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libgit2, + openssl, + stdenv, + darwin, + git, }: rustPlatform.buildRustPackage rec { @@ -24,9 +25,14 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libgit2 openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + libgit2 + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; nativeCheckInputs = [ git ]; @@ -42,16 +48,18 @@ rustPlatform.buildRustPackage rec { # Exclude some tests that don't work in sandbox: # - favorites_default_to_git_if_not_defined: requires network access to github.com # - should_canonicalize: the test assumes that it will be called from the /Users// folder on darwin variant. - checkFlags = [ - "--skip=favorites::favorites_default_to_git_if_not_defined" - "--skip=git_instead_of::should_read_the_instead_of_config_and_rewrite_an_git_at_url_to_https" - "--skip=git_instead_of::should_read_the_instead_of_config_and_rewrite_an_ssh_url_to_https" - "--skip=git_over_ssh::it_should_retrieve_the_private_key_from_ssh_agent" - "--skip=git_over_ssh::it_should_support_a_public_repo" - "--skip=git_over_ssh::it_should_use_a_ssh_key_provided_by_identity_argument" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "--skip=git::utils::should_canonicalize" - ]; + checkFlags = + [ + "--skip=favorites::favorites_default_to_git_if_not_defined" + "--skip=git_instead_of::should_read_the_instead_of_config_and_rewrite_an_git_at_url_to_https" + "--skip=git_instead_of::should_read_the_instead_of_config_and_rewrite_an_ssh_url_to_https" + "--skip=git_over_ssh::it_should_retrieve_the_private_key_from_ssh_agent" + "--skip=git_over_ssh::it_should_support_a_public_repo" + "--skip=git_over_ssh::it_should_use_a_ssh_key_provided_by_identity_argument" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "--skip=git::utils::should_canonicalize" + ]; env = { LIBGIT2_NO_VENDOR = 1; @@ -62,7 +70,14 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-generate"; homepage = "https://github.com/cargo-generate/cargo-generate"; changelog = "https://github.com/cargo-generate/cargo-generate/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ figsoda turbomack matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + figsoda + turbomack + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-guppy/package.nix b/pkgs/by-name/ca/cargo-guppy/package.nix index 68a696ab1ae9d3..3b917cd6762c1e 100644 --- a/pkgs/by-name/ca/cargo-guppy/package.nix +++ b/pkgs/by-name/ca/cargo-guppy/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -22,18 +23,29 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; - cargoBuildFlags = [ "-p" "cargo-guppy" ]; - cargoTestFlags = [ "-p" "cargo-guppy" ]; + cargoBuildFlags = [ + "-p" + "cargo-guppy" + ]; + cargoTestFlags = [ + "-p" + "cargo-guppy" + ]; meta = with lib; { description = "Command-line frontend for guppy"; mainProgram = "cargo-guppy"; homepage = "https://github.com/guppy-rs/guppy/tree/main/cargo-guppy"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ca/cargo-hack/package.nix b/pkgs/by-name/ca/cargo-hack/package.nix index 5308cfca115848..5d0b3a520c1eba 100644 --- a/pkgs/by-name/ca/cargo-hack/package.nix +++ b/pkgs/by-name/ca/cargo-hack/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "cargo-hack"; @@ -19,7 +23,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-hack"; homepage = "https://github.com/taiki-e/cargo-hack"; changelog = "https://github.com/taiki-e/cargo-hack/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ca/cargo-i18n/package.nix b/pkgs/by-name/ca/cargo-i18n/package.nix index 8ca8dda553d9ad..19f5dfb9691c86 100644 --- a/pkgs/by-name/ca/cargo-i18n/package.nix +++ b/pkgs/by-name/ca/cargo-i18n/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, gettext +{ + lib, + rustPlatform, + fetchFromGitHub, + gettext, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ca/cargo-info/package.nix b/pkgs/by-name/ca/cargo-info/package.nix index 70700aa4ee2db2..2cb797cb2a3256 100644 --- a/pkgs/by-name/ca/cargo-info/package.nix +++ b/pkgs/by-name/ca/cargo-info/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitLab -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitLab, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -24,18 +25,26 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; meta = with lib; { description = "Cargo subcommand to show crates info from crates.io"; mainProgram = "cargo-info"; homepage = "https://gitlab.com/imp/cargo-info"; changelog = "https://gitlab.com/imp/cargo-info/-/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ mit asl20 ]; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + mit + asl20 + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-information/package.nix b/pkgs/by-name/ca/cargo-information/package.nix index fe7f950fce852d..510f87ebe27918 100644 --- a/pkgs/by-name/ca/cargo-information/package.nix +++ b/pkgs/by-name/ca/cargo-information/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, makeWrapper -, pkg-config -, openssl -, curl -, rustc -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + makeWrapper, + pkg-config, + openssl, + curl, + rustc, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -42,12 +43,14 @@ rustPlatform.buildRustPackage rec { makeWrapper ]; - buildInputs = [ - openssl - curl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + openssl + curl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; postFixup = '' wrapProgram $out/bin/cargo-info \ diff --git a/pkgs/by-name/ca/cargo-kcov/package.nix b/pkgs/by-name/ca/cargo-kcov/package.nix index 2517ac37c712ae..aa2adfe12dfe7d 100644 --- a/pkgs/by-name/ca/cargo-kcov/package.nix +++ b/pkgs/by-name/ca/cargo-kcov/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, makeWrapper -, kcov +{ + lib, + rustPlatform, + fetchFromGitHub, + makeWrapper, + kcov, }: rustPlatform.buildRustPackage rec { @@ -31,6 +32,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-kcov"; homepage = "https://github.com/kennytm/cargo-kcov"; license = with licenses; [ mit ]; - maintainers = with maintainers; [ saschagrunert matthiasbeyer ]; + maintainers = with maintainers; [ + saschagrunert + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-leptos/package.nix b/pkgs/by-name/ca/cargo-leptos/package.nix index 47972d82dcfd42..fa77aa892dde32 100644 --- a/pkgs/by-name/ca/cargo-leptos/package.nix +++ b/pkgs/by-name/ca/cargo-leptos/package.nix @@ -1,14 +1,16 @@ -{ darwin -, fetchFromGitHub -, lib -, rustPlatform -, stdenv +{ + darwin, + fetchFromGitHub, + lib, + rustPlatform, + stdenv, }: let inherit (darwin.apple_sdk.frameworks) CoreServices SystemConfiguration - Security; + Security + ; inherit (lib) optionals; inherit (stdenv.hostPlatform) isDarwin; in diff --git a/pkgs/by-name/ca/cargo-license/package.nix b/pkgs/by-name/ca/cargo-license/package.nix index 868ad03f5068a3..6fdbead5c0a324 100644 --- a/pkgs/by-name/ca/cargo-license/package.nix +++ b/pkgs/by-name/ca/cargo-license/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "cargo-license"; @@ -16,6 +20,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-license"; homepage = "https://github.com/onur/cargo-license"; license = with licenses; [ mit ]; - maintainers = with maintainers; [ basvandijk figsoda matthiasbeyer ]; + maintainers = with maintainers; [ + basvandijk + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-limit/package.nix b/pkgs/by-name/ca/cargo-limit/package.nix index 2a143699f5ac0b..5a05c61547551a 100644 --- a/pkgs/by-name/ca/cargo-limit/package.nix +++ b/pkgs/by-name/ca/cargo-limit/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, nix-update-script +{ + lib, + rustPlatform, + fetchFromGitHub, + nix-update-script, }: rustPlatform.buildRustPackage rec { @@ -24,7 +25,13 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Cargo subcommand \"limit\": reduces the noise of compiler messages"; homepage = "https://github.com/alopatindev/cargo-limit"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ otavio matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + otavio + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-llvm-cov/package.nix b/pkgs/by-name/ca/cargo-llvm-cov/package.nix index 7f55d8e7f814d3..b70ed7d24c3809 100644 --- a/pkgs/by-name/ca/cargo-llvm-cov/package.nix +++ b/pkgs/by-name/ca/cargo-llvm-cov/package.nix @@ -13,13 +13,14 @@ # [0]: https://github.com/taiki-e/cargo-llvm-cov/issues/242 # [1]: https://github.com/NixOS/nixpkgs/pull/197478 -{ stdenv -, lib -, fetchurl -, fetchFromGitHub -, rustPlatform -, llvmPackages_19 -, git +{ + stdenv, + lib, + fetchurl, + fetchFromGitHub, + rustPlatform, + llvmPackages_19, + git, }: let @@ -88,8 +89,15 @@ rustPlatform.buildRustPackage { tools-preview` or install the `llvm-tools-preview` component using your Nix library (e.g. fenix or rust-overlay) ''; - license = with lib.licenses; [ asl20 /* or */ mit ]; - maintainers = with lib.maintainers; [ wucke13 matthiasbeyer CobaltCause ]; + license = with lib.licenses; [ + asl20 # or + mit + ]; + maintainers = with lib.maintainers; [ + wucke13 + matthiasbeyer + CobaltCause + ]; # The profiler runtime is (currently) disabled on non-Linux platforms broken = !(stdenv.hostPlatform.isLinux && !stdenv.targetPlatform.isRedox); diff --git a/pkgs/by-name/ca/cargo-llvm-lines/package.nix b/pkgs/by-name/ca/cargo-llvm-lines/package.nix index ab50c9c54a390e..612775f92d1da8 100644 --- a/pkgs/by-name/ca/cargo-llvm-lines/package.nix +++ b/pkgs/by-name/ca/cargo-llvm-lines/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "cargo-llvm-lines"; @@ -18,7 +22,13 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-llvm-lines"; homepage = "https://github.com/dtolnay/cargo-llvm-lines"; changelog = "https://github.com/dtolnay/cargo-llvm-lines/releases/tag/${src.rev}"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-local-registry/package.nix b/pkgs/by-name/ca/cargo-local-registry/package.nix index 7e6c0c917a7345..97ea6ccf834678 100644 --- a/pkgs/by-name/ca/cargo-local-registry/package.nix +++ b/pkgs/by-name/ca/cargo-local-registry/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, curl -, pkg-config -, libgit2 -, openssl -, zlib -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + curl, + pkg-config, + libgit2, + openssl, + zlib, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -28,16 +29,19 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - curl - libgit2 - openssl - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ - darwin.apple_sdk.frameworks.CoreFoundation - ]; + buildInputs = + [ + curl + libgit2 + openssl + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + darwin.apple_sdk.frameworks.CoreFoundation + ]; # tests require internet access doCheck = false; @@ -47,7 +51,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-local-registry"; homepage = "https://github.com/dhovart/cargo-local-registry"; changelog = "https://github.com/dhovart/cargo-local-registry/releases/tag/${src.rev}"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ca/cargo-lock/package.nix b/pkgs/by-name/ca/cargo-lock/package.nix index bac23c49185614..8c1b74ccabc743 100644 --- a/pkgs/by-name/ca/cargo-lock/package.nix +++ b/pkgs/by-name/ca/cargo-lock/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "cargo-lock"; @@ -18,7 +22,13 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-lock"; homepage = "https://github.com/rustsec/rustsec/tree/main/cargo-lock"; changelog = "https://github.com/rustsec/rustsec/blob/cargo-lock/v${version}/cargo-lock/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-machete/package.nix b/pkgs/by-name/ca/cargo-machete/package.nix index c18bea07a1bb73..b595fd71550dab 100644 --- a/pkgs/by-name/ca/cargo-machete/package.nix +++ b/pkgs/by-name/ca/cargo-machete/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -25,6 +26,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/bnjbvr/cargo-machete"; changelog = "https://github.com/bnjbvr/cargo-machete/blob/${src.rev}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-make/package.nix b/pkgs/by-name/ca/cargo-make/package.nix index ad3a30c98d8f87..4c9f177700a472 100644 --- a/pkgs/by-name/ca/cargo-make/package.nix +++ b/pkgs/by-name/ca/cargo-make/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, installShellFiles -, bzip2 -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + installShellFiles, + bzip2, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -27,12 +28,14 @@ rustPlatform.buildRustPackage rec { installShellFiles ]; - buildInputs = [ - bzip2 - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + bzip2 + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; postInstall = '' installShellCompletion extra/shell/*.bash @@ -49,7 +52,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/sagiegurari/cargo-make"; changelog = "https://github.com/sagiegurari/cargo-make/blob/${version}/CHANGELOG.md"; license = licenses.asl20; - maintainers = with maintainers; [ figsoda xrelkd ]; + maintainers = with maintainers; [ + figsoda + xrelkd + ]; mainProgram = "cargo-make"; }; } diff --git a/pkgs/by-name/ca/cargo-mobile2/package.nix b/pkgs/by-name/ca/cargo-mobile2/package.nix index efce68a5297886..7907f9a5a16eec 100644 --- a/pkgs/by-name/ca/cargo-mobile2/package.nix +++ b/pkgs/by-name/ca/cargo-mobile2/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, git -, darwin -, makeWrapper +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + git, + darwin, + makeWrapper, }: let @@ -36,7 +37,11 @@ rustPlatform.buildRustPackage { ''; buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices ]; - nativeBuildInputs = [ pkg-config git makeWrapper ]; + nativeBuildInputs = [ + pkg-config + git + makeWrapper + ]; preFixup = '' for bin in $out/bin/cargo-*; do @@ -48,7 +53,10 @@ rustPlatform.buildRustPackage { meta = with lib; { description = "Rust on mobile made easy!"; homepage = "https://tauri.app/"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ happysalada ]; }; } diff --git a/pkgs/by-name/ca/cargo-mommy/package.nix b/pkgs/by-name/ca/cargo-mommy/package.nix index e62f87969d7c4c..ca9e2e93f665ef 100644 --- a/pkgs/by-name/ca/cargo-mommy/package.nix +++ b/pkgs/by-name/ca/cargo-mommy/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "cargo-mommy"; @@ -15,7 +19,10 @@ rustPlatform.buildRustPackage rec { description = "Cargo wrapper that encourages you after running commands"; mainProgram = "cargo-mommy"; homepage = "https://github.com/Gankra/cargo-mommy"; - license = with licenses; [ mit asl20 ]; + license = with licenses; [ + mit + asl20 + ]; maintainers = with maintainers; [ GoldsteinE ]; }; } diff --git a/pkgs/by-name/ca/cargo-pgo/package.nix b/pkgs/by-name/ca/cargo-pgo/package.nix index d7140a3f1523f2..8ababffbe753d2 100644 --- a/pkgs/by-name/ca/cargo-pgo/package.nix +++ b/pkgs/by-name/ca/cargo-pgo/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ca/cargo-pio/package.nix b/pkgs/by-name/ca/cargo-pio/package.nix index 5942627f4aec04..c5cc84ad31ec8e 100644 --- a/pkgs/by-name/ca/cargo-pio/package.nix +++ b/pkgs/by-name/ca/cargo-pio/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { pname = "cargo-pio"; @@ -20,7 +21,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Build Rust embedded projects with PlatformIO"; homepage = "https://github.com/esp-rs/embuild/tree/master/cargo-pio"; - license = with lib.licenses; [ asl20 mit ]; + license = with lib.licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ dannixon ]; mainProgram = "cargo-pio"; }; diff --git a/pkgs/by-name/ca/cargo-play/package.nix b/pkgs/by-name/ca/cargo-play/package.nix index a95f2c10c32ebe..955e84ef6249aa 100644 --- a/pkgs/by-name/ca/cargo-play/package.nix +++ b/pkgs/by-name/ca/cargo-play/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "cargo-play"; diff --git a/pkgs/by-name/ca/cargo-profiler/package.nix b/pkgs/by-name/ca/cargo-profiler/package.nix index d8e4def6b75663..adceadd6ccc2e4 100644 --- a/pkgs/by-name/ca/cargo-profiler/package.nix +++ b/pkgs/by-name/ca/cargo-profiler/package.nix @@ -1,6 +1,8 @@ -{ fetchFromGitHub -, lib -, rustPlatform }: +{ + fetchFromGitHub, + lib, + rustPlatform, +}: let # Constants @@ -14,7 +16,8 @@ let cargoHash = "sha256-qt3S6ZcLEP9ZQoP5+kSQdmBlxdMgGUqLszdU7JkFNVI="; inherit (rustPlatform) buildRustPackage; -in buildRustPackage rec { +in +buildRustPackage rec { inherit pname version; src = fetchFromGitHub { diff --git a/pkgs/by-name/ca/cargo-public-api/package.nix b/pkgs/by-name/ca/cargo-public-api/package.nix index be9564d5256087..8142273039bb4c 100644 --- a/pkgs/by-name/ca/cargo-public-api/package.nix +++ b/pkgs/by-name/ca/cargo-public-api/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, curl -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + curl, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -21,8 +22,10 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ curl openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Security ]; + buildInputs = [ + curl + openssl + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Security ]; # Tests fail doCheck = false; @@ -36,4 +39,3 @@ rustPlatform.buildRustPackage rec { maintainers = with maintainers; [ matthiasbeyer ]; }; } - diff --git a/pkgs/by-name/ca/cargo-rdme/package.nix b/pkgs/by-name/ca/cargo-rdme/package.nix index 19c36419771650..c17780fc15ec58 100644 --- a/pkgs/by-name/ca/cargo-rdme/package.nix +++ b/pkgs/by-name/ca/cargo-rdme/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchCrate, stdenv, Security }: +{ + lib, + rustPlatform, + fetchCrate, + stdenv, + Security, +}: rustPlatform.buildRustPackage rec { pname = "cargo-rdme"; diff --git a/pkgs/by-name/ca/cargo-readme/package.nix b/pkgs/by-name/ca/cargo-readme/package.nix index 8924195b4e760e..4dc684154999cd 100644 --- a/pkgs/by-name/ca/cargo-readme/package.nix +++ b/pkgs/by-name/ca/cargo-readme/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "cargo-readme"; @@ -15,14 +19,21 @@ rustPlatform.buildRustPackage rec { # disable doc tests cargoTestFlags = [ - "--bins" "--lib" + "--bins" + "--lib" ]; meta = with lib; { description = "Generate README.md from docstrings"; mainProgram = "cargo-readme"; homepage = "https://github.com/livioribeiro/cargo-readme"; - license = with licenses; [ mit asl20 ]; - maintainers = with maintainers; [ baloo matthiasbeyer ]; + license = with licenses; [ + mit + asl20 + ]; + maintainers = with maintainers; [ + baloo + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-release/package.nix b/pkgs/by-name/ca/cargo-release/package.nix index c818582433a2ff..ad9a9d648ee421 100644 --- a/pkgs/by-name/ca/cargo-release/package.nix +++ b/pkgs/by-name/ca/cargo-release/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libgit2 -, openssl -, stdenv -, curl -, darwin -, git +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libgit2, + openssl, + stdenv, + curl, + darwin, + git, }: rustPlatform.buildRustPackage rec { @@ -32,13 +33,15 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - libgit2 - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - curl - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + libgit2 + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + curl + darwin.apple_sdk.frameworks.SystemConfiguration + ]; nativeCheckInputs = [ git @@ -52,7 +55,13 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-release"; homepage = "https://github.com/crate-ci/cargo-release"; changelog = "https://github.com/crate-ci/cargo-release/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ figsoda gerschtli ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + figsoda + gerschtli + ]; }; } diff --git a/pkgs/by-name/ca/cargo-rr/package.nix b/pkgs/by-name/ca/cargo-rr/package.nix index cccd1368a80250..c49c4f3759b290 100644 --- a/pkgs/by-name/ca/cargo-rr/package.nix +++ b/pkgs/by-name/ca/cargo-rr/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, nix-update-script -, makeWrapper -, rr +{ + lib, + rustPlatform, + fetchFromGitHub, + nix-update-script, + makeWrapper, + rr, }: rustPlatform.buildRustPackage rec { @@ -34,6 +35,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-rr"; homepage = "https://github.com/danielzfranklin/cargo-rr"; license = with licenses; [ mit ]; - maintainers = with maintainers; [ otavio matthiasbeyer ]; + maintainers = with maintainers; [ + otavio + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-run-bin/package.nix b/pkgs/by-name/ca/cargo-run-bin/package.nix index fa4d2a5a33ed78..df868de9952b86 100644 --- a/pkgs/by-name/ca/cargo-run-bin/package.nix +++ b/pkgs/by-name/ca/cargo-run-bin/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -23,7 +24,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/dustinblackman/cargo-run-bin"; changelog = "https://github.com/dustinblackman/cargo-run-bin/blob/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ mightyiam matthiasbeyer ]; + maintainers = with maintainers; [ + mightyiam + matthiasbeyer + ]; }; } - diff --git a/pkgs/by-name/ca/cargo-semver-checks/package.nix b/pkgs/by-name/ca/cargo-semver-checks/package.nix index ad2e4b7f337e67..b01afc4e4bd366 100644 --- a/pkgs/by-name/ca/cargo-semver-checks/package.nix +++ b/pkgs/by-name/ca/cargo-semver-checks/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, cmake -, zlib -, stdenv -, darwin -, git +{ + lib, + rustPlatform, + fetchFromGitHub, + cmake, + zlib, + stdenv, + darwin, + git, }: rustPlatform.buildRustPackage rec { @@ -25,11 +26,13 @@ rustPlatform.buildRustPackage rec { cmake ]; - buildInputs = [ - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; checkFlags = [ # requires internet access @@ -50,7 +53,13 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-semver-checks"; homepage = "https://github.com/obi1kenobi/cargo-semver-checks"; changelog = "https://github.com/obi1kenobi/cargo-semver-checks/releases/tag/v${version}"; - license = with licenses; [ mit /* or */ asl20 ]; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + mit # or + asl20 + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-show-asm/package.nix b/pkgs/by-name/ca/cargo-show-asm/package.nix index e769be4b200273..38c01290725cfa 100644 --- a/pkgs/by-name/ca/cargo-show-asm/package.nix +++ b/pkgs/by-name/ca/cargo-show-asm/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchCrate -, installShellFiles -, stdenv -, nix-update-script -, callPackage +{ + lib, + rustPlatform, + fetchCrate, + installShellFiles, + stdenv, + nix-update-script, + callPackage, }: rustPlatform.buildRustPackage rec { @@ -40,8 +41,15 @@ rustPlatform.buildRustPackage rec { description = "Cargo subcommand showing the assembly, LLVM-IR and MIR generated for Rust code"; homepage = "https://github.com/pacak/cargo-show-asm"; changelog = "https://github.com/pacak/cargo-show-asm/blob/${version}/Changelog.md"; - license = with licenses; [ asl20 mit ]; - maintainers = with maintainers; [ figsoda oxalica matthiasbeyer ]; + license = with licenses; [ + asl20 + mit + ]; + maintainers = with maintainers; [ + figsoda + oxalica + matthiasbeyer + ]; mainProgram = "cargo-asm"; }; } diff --git a/pkgs/by-name/ca/cargo-show-asm/test-basic-x86_64.nix b/pkgs/by-name/ca/cargo-show-asm/test-basic-x86_64.nix index ca1738f02185e7..f332c5e0f4354d 100644 --- a/pkgs/by-name/ca/cargo-show-asm/test-basic-x86_64.nix +++ b/pkgs/by-name/ca/cargo-show-asm/test-basic-x86_64.nix @@ -1,18 +1,29 @@ -{ runCommand, cargo, rustc, cargo-show-asm }: -runCommand "test-basic" { - nativeBuildInputs = [ cargo rustc cargo-show-asm ]; -} '' - mkdir -p src - cat >Cargo.toml <src/lib.rs < u32 { a + b } -EOF +{ + runCommand, + cargo, + rustc, + cargo-show-asm, +}: +runCommand "test-basic" + { + nativeBuildInputs = [ + cargo + rustc + cargo-show-asm + ]; + } + '' + mkdir -p src + cat >Cargo.toml <src/lib.rs < u32 { a + b } + EOF - [[ "$(cargo asm add::add | tee /dev/stderr)" == *"lea eax, "* ]] - [[ "$(cargo asm --mir add | tee /dev/stderr)" == *"= Add("* ]] - touch $out -'' + [[ "$(cargo asm add::add | tee /dev/stderr)" == *"lea eax, "* ]] + [[ "$(cargo asm --mir add | tee /dev/stderr)" == *"= Add("* ]] + touch $out + '' diff --git a/pkgs/by-name/ca/cargo-sort/package.nix b/pkgs/by-name/ca/cargo-sort/package.nix index 51994805f3dd86..41aa18ab9de1f7 100644 --- a/pkgs/by-name/ca/cargo-sort/package.nix +++ b/pkgs/by-name/ca/cargo-sort/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, lib, rustPlatform }: +{ + fetchFromGitHub, + lib, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "cargo-sort"; @@ -18,7 +22,13 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-sort"; homepage = "https://github.com/devinr528/cargo-sort"; changelog = "https://github.com/devinr528/cargo-sort/blob/v${version}/changelog.md"; - license = with licenses; [ mit /* or */ asl20 ]; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + mit # or + asl20 + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-spellcheck/package.nix b/pkgs/by-name/ca/cargo-spellcheck/package.nix index 1ac4ec1265f935..f33a0f385b67a5 100644 --- a/pkgs/by-name/ca/cargo-spellcheck/package.nix +++ b/pkgs/by-name/ca/cargo-spellcheck/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, apple-sdk_11 +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + apple-sdk_11, }: rustPlatform.buildRustPackage rec { @@ -33,7 +34,13 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-spellcheck"; homepage = "https://github.com/drahnr/cargo-spellcheck"; changelog = "https://github.com/drahnr/cargo-spellcheck/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ newam matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + newam + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-supply-chain/package.nix b/pkgs/by-name/ca/cargo-supply-chain/package.nix index 073500a16e2f48..92d978d45f220f 100644 --- a/pkgs/by-name/ca/cargo-supply-chain/package.nix +++ b/pkgs/by-name/ca/cargo-supply-chain/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -27,7 +28,14 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-supply-chain"; homepage = "https://github.com/rust-secure-code/cargo-supply-chain"; changelog = "https://github.com/rust-secure-code/cargo-supply-chain/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 mit zlib ]; # any of three - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + asl20 + mit + zlib + ]; # any of three + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-swift/package.nix b/pkgs/by-name/ca/cargo-swift/package.nix index 53aefb56374e76..faef07415d80d6 100644 --- a/pkgs/by-name/ca/cargo-swift/package.nix +++ b/pkgs/by-name/ca/cargo-swift/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,10 @@ rustPlatform.buildRustPackage rec { description = "Cargo plugin to easily build Swift packages from Rust code"; mainProgram = "cargo-swift"; homepage = "https://github.com/antoniusnaumann/cargo-swift"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ elliot ]; }; } diff --git a/pkgs/by-name/ca/cargo-sync-readme/package.nix b/pkgs/by-name/ca/cargo-sync-readme/package.nix index 953553cb948c36..b705a61fb29d56 100644 --- a/pkgs/by-name/ca/cargo-sync-readme/package.nix +++ b/pkgs/by-name/ca/cargo-sync-readme/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "cargo-sync-readme"; @@ -19,6 +23,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/phaazon/cargo-sync-readme"; changelog = "https://github.com/phaazon/cargo-sync-readme/blob/${version}/CHANGELOG.md"; license = licenses.bsd3; - maintainers = with maintainers; [ b4dm4n matthiasbeyer ]; + maintainers = with maintainers; [ + b4dm4n + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-tally/package.nix b/pkgs/by-name/ca/cargo-tally/package.nix index 007ee27cdaf2c3..c26c414ea0bc3a 100644 --- a/pkgs/by-name/ca/cargo-tally/package.nix +++ b/pkgs/by-name/ca/cargo-tally/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchCrate, stdenv, darwin }: +{ + lib, + rustPlatform, + fetchCrate, + stdenv, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "cargo-tally"; @@ -11,18 +17,27 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-uPlilomHib10/v2HKBjU/ln0B4QkKpFJPpKf37RO7Oo="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk_11_0.frameworks; [ - DiskArbitration - Foundation - IOKit - ]); + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk_11_0.frameworks; + [ + DiskArbitration + Foundation + IOKit + ] + ); meta = with lib; { description = "Graph the number of crates that depend on your crate over time"; mainProgram = "cargo-tally"; homepage = "https://github.com/dtolnay/cargo-tally"; changelog = "https://github.com/dtolnay/cargo-tally/releases/tag/${version}"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-toml-lint/package.nix b/pkgs/by-name/ca/cargo-toml-lint/package.nix index a32f6e4bc69560..b518051e8e85d9 100644 --- a/pkgs/by-name/ca/cargo-toml-lint/package.nix +++ b/pkgs/by-name/ca/cargo-toml-lint/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,13 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-toml-lint"; homepage = "https://github.com/fuellabs/cargo-toml-lint"; changelog = "https://github.com/fuellabs/cargo-toml-lint/releases/tag/v${version}"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ mitchmindtree matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + mitchmindtree + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-ui/package.nix b/pkgs/by-name/ca/cargo-ui/package.nix index fedd72458c8ed8..f94d6478e70420 100644 --- a/pkgs/by-name/ca/cargo-ui/package.nix +++ b/pkgs/by-name/ca/cargo-ui/package.nix @@ -1,15 +1,16 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, libgit2 -, openssl -, stdenv -, expat -, fontconfig -, libGL -, xorg -, darwin +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + libgit2, + openssl, + stdenv, + expat, + fontconfig, + libGL, + xorg, + darwin, }: rustPlatform.buildRustPackage rec { @@ -27,25 +28,33 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - libgit2 - openssl - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - expat - fontconfig - libGL - xorg.libX11 - xorg.libXcursor - xorg.libXi - xorg.libXrandr - xorg.libxcb - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AppKit - ]; + buildInputs = + [ + libgit2 + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + expat + fontconfig + libGL + xorg.libX11 + xorg.libXcursor + xorg.libXi + xorg.libXrandr + xorg.libxcb + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AppKit + ]; postFixup = lib.optionalString stdenv.hostPlatform.isLinux '' patchelf $out/bin/cargo-ui \ - --add-rpath ${lib.makeLibraryPath [ fontconfig libGL ]} + --add-rpath ${ + lib.makeLibraryPath [ + fontconfig + libGL + ] + } ''; env = { @@ -57,7 +66,14 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-ui"; homepage = "https://github.com/slint-ui/cargo-ui"; changelog = "https://github.com/slint-ui/cargo-ui/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ mit asl20 gpl3Only ]; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + mit + asl20 + gpl3Only + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-unfmt/package.nix b/pkgs/by-name/ca/cargo-unfmt/package.nix index 42a1ea9b57f88a..e8163bb02488c1 100644 --- a/pkgs/by-name/ca/cargo-unfmt/package.nix +++ b/pkgs/by-name/ca/cargo-unfmt/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage { diff --git a/pkgs/by-name/ca/cargo-unused-features/package.nix b/pkgs/by-name/ca/cargo-unused-features/package.nix index cf1fd1deb39811..a5d457c20eb725 100644 --- a/pkgs/by-name/ca/cargo-unused-features/package.nix +++ b/pkgs/by-name/ca/cargo-unused-features/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchCrate -, curl -, pkg-config -, libgit2 -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + curl, + pkg-config, + libgit2, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -25,14 +26,16 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - curl - libgit2 - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreFoundation - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + curl + libgit2 + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreFoundation + darwin.apple_sdk.frameworks.Security + ]; env = { LIBGIT2_NO_VENDOR = 1; @@ -42,7 +45,10 @@ rustPlatform.buildRustPackage rec { description = "Tool to find potential unused enabled feature flags and prune them"; homepage = "https://github.com/timonpost/cargo-unused-features"; license = licenses.mit; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; mainProgram = "unused-features"; }; } diff --git a/pkgs/by-name/ca/cargo-update/package.nix b/pkgs/by-name/ca/cargo-update/package.nix index 2a41ee0cfae61e..2b30adb1c6c82c 100644 --- a/pkgs/by-name/ca/cargo-update/package.nix +++ b/pkgs/by-name/ca/cargo-update/package.nix @@ -1,17 +1,18 @@ -{ lib -, rustPlatform -, fetchCrate -, cmake -, installShellFiles -, pkg-config -, ronn -, stdenv -, curl -, libgit2 -, libssh2 -, openssl -, zlib -, darwin +{ + lib, + rustPlatform, + fetchCrate, + cmake, + installShellFiles, + pkg-config, + ronn, + stdenv, + curl, + libgit2, + libssh2, + openssl, + zlib, + darwin, }: rustPlatform.buildRustPackage rec { @@ -25,24 +26,28 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-rwXpQkL6ysMBraLIMk2zQe0vmb9uuePWufBjRVzaBOA="; - nativeBuildInputs = [ - cmake - installShellFiles - pkg-config - ronn - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - curl - ]; + nativeBuildInputs = + [ + cmake + installShellFiles + pkg-config + ronn + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + curl + ]; - buildInputs = [ - libgit2 - libssh2 - openssl - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - curl - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + libgit2 + libssh2 + openssl + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + curl + darwin.apple_sdk.frameworks.Security + ]; postBuild = '' # Man pages contain non-ASCII, so explicitly set encoding to UTF-8. @@ -64,6 +69,11 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/nabijaczleweli/cargo-update"; changelog = "https://github.com/nabijaczleweli/cargo-update/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ gerschtli Br1ght0ne johntitor matthiasbeyer ]; + maintainers = with maintainers; [ + gerschtli + Br1ght0ne + johntitor + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-valgrind/package.nix b/pkgs/by-name/ca/cargo-valgrind/package.nix index 1020caad551baa..b14b2cce68da8e 100644 --- a/pkgs/by-name/ca/cargo-valgrind/package.nix +++ b/pkgs/by-name/ca/cargo-valgrind/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, nix-update-script -, makeWrapper -, valgrind +{ + lib, + rustPlatform, + fetchFromGitHub, + nix-update-script, + makeWrapper, + valgrind, }: rustPlatform.buildRustPackage rec { @@ -38,7 +39,13 @@ rustPlatform.buildRustPackage rec { description = ''Cargo subcommand "valgrind": runs valgrind and collects its output in a helpful manner''; mainProgram = "cargo-valgrind"; homepage = "https://github.com/jfrimmel/cargo-valgrind"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ otavio matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + otavio + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ca/cargo-vibe/package.nix b/pkgs/by-name/ca/cargo-vibe/package.nix index ba7a5882b5bb15..761e33f5caca92 100644 --- a/pkgs/by-name/ca/cargo-vibe/package.nix +++ b/pkgs/by-name/ca/cargo-vibe/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, dbus -, udev -, openssl -, darwin +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + dbus, + udev, + openssl, + darwin, }: rustPlatform.buildRustPackage rec { pname = "cargo-vibe"; @@ -24,12 +25,20 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - dbus - openssl - ] - ++ lib.optional stdenv.hostPlatform.isLinux udev - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ AppKit IOKit CoreBluetooth ]); + buildInputs = + [ + dbus + openssl + ] + ++ lib.optional stdenv.hostPlatform.isLinux udev + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + AppKit + IOKit + CoreBluetooth + ] + ); meta = with lib; { description = "Cargo x Buttplug.io"; diff --git a/pkgs/by-name/ca/cargo-wasi/package.nix b/pkgs/by-name/ca/cargo-wasi/package.nix index a42b98da205414..2bbdfdeb40a529 100644 --- a/pkgs/by-name/ca/cargo-wasi/package.nix +++ b/pkgs/by-name/ca/cargo-wasi/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, stdenv -, openssl -, darwin +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + stdenv, + openssl, + darwin, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,8 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ openssl ] + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ Security ]); # Checks need to be disabled here because the current test suite makes assumptions diff --git a/pkgs/by-name/ca/cargo-wipe/package.nix b/pkgs/by-name/ca/cargo-wipe/package.nix index af9ae57c7cb879..331cc9e18e6024 100644 --- a/pkgs/by-name/ca/cargo-wipe/package.nix +++ b/pkgs/by-name/ca/cargo-wipe/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, nix-update-script +{ + lib, + rustPlatform, + fetchFromGitHub, + nix-update-script, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ca/cargo-wizard/package.nix b/pkgs/by-name/ca/cargo-wizard/package.nix index 69f106795239a9..6313415d9724f8 100644 --- a/pkgs/by-name/ca/cargo-wizard/package.nix +++ b/pkgs/by-name/ca/cargo-wizard/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ca/cargo-workspaces/package.nix b/pkgs/by-name/ca/cargo-workspaces/package.nix index 5e0b5483e75456..3daa583e85f31d 100644 --- a/pkgs/by-name/ca/cargo-workspaces/package.nix +++ b/pkgs/by-name/ca/cargo-workspaces/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, libssh2 -, openssl -, zlib -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + libssh2, + openssl, + zlib, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -24,14 +25,16 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - libssh2 - openssl - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + libssh2 + openssl + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; env = { LIBSSH2_SYS_USE_PKG_CONFIG = true; @@ -47,7 +50,11 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/pksunkara/cargo-workspaces"; changelog = "https://github.com/pksunkara/cargo-workspaces/blob/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ figsoda macalinao matthiasbeyer ]; + maintainers = with maintainers; [ + figsoda + macalinao + matthiasbeyer + ]; mainProgram = "cargo-workspaces"; }; } diff --git a/pkgs/by-name/ca/cargo-xbuild/package.nix b/pkgs/by-name/ca/cargo-xbuild/package.nix index 55911b7f8a6243..dec26b666cd7d4 100644 --- a/pkgs/by-name/ca/cargo-xbuild/package.nix +++ b/pkgs/by-name/ca/cargo-xbuild/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "cargo-xbuild"; @@ -16,7 +20,13 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Automatically cross-compiles the sysroot crates core, compiler_builtins, and alloc"; homepage = "https://github.com/rust-osdev/cargo-xbuild"; - license = with licenses; [ mit asl20 ]; - maintainers = with maintainers; [ johntitor xrelkd ]; + license = with licenses; [ + mit + asl20 + ]; + maintainers = with maintainers; [ + johntitor + xrelkd + ]; }; } diff --git a/pkgs/by-name/ca/cargo-xwin/package.nix b/pkgs/by-name/ca/cargo-xwin/package.nix index f49c16b2170b38..542fb55504c860 100644 --- a/pkgs/by-name/ca/cargo-xwin/package.nix +++ b/pkgs/by-name/ca/cargo-xwin/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ca/cariddi/package.nix b/pkgs/by-name/ca/cariddi/package.nix index acada9b12567f8..681ffadd1c273d 100644 --- a/pkgs/by-name/ca/cariddi/package.nix +++ b/pkgs/by-name/ca/cariddi/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ca/carlito/package.nix b/pkgs/by-name/ca/carlito/package.nix index a83d8a547a15c5..c7d11fab15fd79 100644 --- a/pkgs/by-name/ca/carlito/package.nix +++ b/pkgs/by-name/ca/carlito/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, stdenvNoCC }: +{ + lib, + fetchurl, + stdenvNoCC, +}: stdenvNoCC.mkDerivation rec { pname = "carlito"; diff --git a/pkgs/by-name/ca/caroline/package.nix b/pkgs/by-name/ca/caroline/package.nix index 6b94df2f64a150..662c228f15bb90 100644 --- a/pkgs/by-name/ca/caroline/package.nix +++ b/pkgs/by-name/ca/caroline/package.nix @@ -1,4 +1,15 @@ -{ stdenv, lib, fetchFromGitHub, vala, meson, ninja, pkg-config, glib, libgee, gtk3 }: +{ + stdenv, + lib, + fetchFromGitHub, + vala, + meson, + ninja, + pkg-config, + glib, + libgee, + gtk3, +}: stdenv.mkDerivation rec { pname = "caroline"; diff --git a/pkgs/by-name/ca/carp/package.nix b/pkgs/by-name/ca/carp/package.nix index 9e54e19ba699e8..5325019c7785b6 100644 --- a/pkgs/by-name/ca/carp/package.nix +++ b/pkgs/by-name/ca/carp/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, fetchpatch, makeWrapper, clang, haskellPackages }: +{ + lib, + fetchFromGitHub, + fetchpatch, + makeWrapper, + clang, + haskellPackages, +}: haskellPackages.mkDerivation rec { pname = "carp"; @@ -30,8 +37,16 @@ haskellPackages.mkDerivation rec { buildTools = [ makeWrapper ]; executableHaskellDepends = with haskellPackages; [ - HUnit blaze-markup blaze-html split ansi-terminal cmark - edit-distance hashable open-browser optparse-applicative + HUnit + blaze-markup + blaze-html + split + ansi-terminal + cmark + edit-distance + hashable + open-browser + optparse-applicative ]; isExecutable = true; @@ -53,12 +68,12 @@ haskellPackages.mkDerivation rec { ''; description = "Statically typed lisp, without a GC, for real-time applications"; - homepage = "https://github.com/carp-lang/Carp"; - license = lib.licenses.asl20; + homepage = "https://github.com/carp-lang/Carp"; + license = lib.licenses.asl20; maintainers = with lib.maintainers; [ jluttine ]; # Not actively maintained at the moment - broken = true; + broken = true; # Windows not (yet) supported. - platforms = with lib.platforms; unix ++ darwin; + platforms = with lib.platforms; unix ++ darwin; } diff --git a/pkgs/by-name/ca/carps-cups/package.nix b/pkgs/by-name/ca/carps-cups/package.nix index 32e92da1608477..f7a3572ba622ce 100644 --- a/pkgs/by-name/ca/carps-cups/package.nix +++ b/pkgs/by-name/ca/carps-cups/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, cups +{ + stdenv, + lib, + fetchFromGitHub, + cups, }: stdenv.mkDerivation { @@ -41,4 +42,3 @@ stdenv.mkDerivation { ]; }; } - diff --git a/pkgs/by-name/ca/carto/package.nix b/pkgs/by-name/ca/carto/package.nix index f48244111a8486..1183c7bdd983ec 100644 --- a/pkgs/by-name/ca/carto/package.nix +++ b/pkgs/by-name/ca/carto/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ca/cascadia-code/package.nix b/pkgs/by-name/ca/cascadia-code/package.nix index a0d4f44f143484..0451f431f1be8f 100644 --- a/pkgs/by-name/ca/cascadia-code/package.nix +++ b/pkgs/by-name/ca/cascadia-code/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "cascadia-code"; diff --git a/pkgs/by-name/ca/cassette/package.nix b/pkgs/by-name/ca/cassette/package.nix index 7bdd756f59ab25..9056830b1046ff 100644 --- a/pkgs/by-name/ca/cassette/package.nix +++ b/pkgs/by-name/ca/cassette/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, blueprint-compiler -, desktop-file-utils -, meson -, ninja -, pkg-config -, vala -, wrapGAppsHook4 -, glib-networking -, gst_all_1 -, gtk4 -, json-glib -, libadwaita -, libgee -, libsoup_3 -, libxml2 -, sqlite -, webkitgtk_6_0 +{ + lib, + stdenv, + fetchFromGitHub, + blueprint-compiler, + desktop-file-utils, + meson, + ninja, + pkg-config, + vala, + wrapGAppsHook4, + glib-networking, + gst_all_1, + gtk4, + json-glib, + libadwaita, + libgee, + libsoup_3, + libxml2, + sqlite, + webkitgtk_6_0, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ca/cassowary/package.nix b/pkgs/by-name/ca/cassowary/package.nix index 5cb699531b1a35..9977033e23f32c 100644 --- a/pkgs/by-name/ca/cassowary/package.nix +++ b/pkgs/by-name/ca/cassowary/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "cassowary"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-YP9q9lL2A9ERhzbJBIFKsYsgvy5xYeUO3ekyQdh97f8="; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; meta = with lib; { homepage = "https://github.com/rogerwelin/cassowary"; diff --git a/pkgs/by-name/ca/castero/package.nix b/pkgs/by-name/ca/castero/package.nix index f625771452ef9a..2b08d81fba0739 100644 --- a/pkgs/by-name/ca/castero/package.nix +++ b/pkgs/by-name/ca/castero/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -19,16 +20,19 @@ python3.pkgs.buildPythonApplication rec { wheel ]; - propagatedBuildInputs = with python3.pkgs; [ - requests - grequests - cjkwrap - pytz - beautifulsoup4 - lxml - mpv - python-vlc - ] ++ requests.optional-dependencies.socks; + propagatedBuildInputs = + with python3.pkgs; + [ + requests + grequests + cjkwrap + pytz + beautifulsoup4 + lxml + mpv + python-vlc + ] + ++ requests.optional-dependencies.socks; nativeCheckInputs = with python3.pkgs; [ pytestCheckHook diff --git a/pkgs/by-name/ca/castget/package.nix b/pkgs/by-name/ca/castget/package.nix index c3937f996086fd..5d23ba1edc10a5 100644 --- a/pkgs/by-name/ca/castget/package.nix +++ b/pkgs/by-name/ca/castget/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, glib -, ronn -, curl -, id3lib -, libxml2 -, glibcLocales +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + ronn, + curl, + id3lib, + libxml2, + glibcLocales, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ca/castnow/package.nix b/pkgs/by-name/ca/castnow/package.nix index 1c00ab22c0280c..cff938b1155199 100644 --- a/pkgs/by-name/ca/castnow/package.nix +++ b/pkgs/by-name/ca/castnow/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ca/castopod/package.nix b/pkgs/by-name/ca/castopod/package.nix index 3f098c3653444b..72bc5d4025574e 100644 --- a/pkgs/by-name/ca/castopod/package.nix +++ b/pkgs/by-name/ca/castopod/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, fetchurl -, ffmpeg-headless -, lib -, nixosTests -, dataDir ? "/var/lib/castopod" +{ + stdenv, + fetchurl, + ffmpeg-headless, + lib, + nixosTests, + dataDir ? "/var/lib/castopod", }: stdenv.mkDerivation { pname = "castopod"; diff --git a/pkgs/by-name/ca/castor/package.nix b/pkgs/by-name/ca/castor/package.nix index b3f7abedba965c..2acd9a42e4357d 100644 --- a/pkgs/by-name/ca/castor/package.nix +++ b/pkgs/by-name/ca/castor/package.nix @@ -1,14 +1,15 @@ -{ lib -, fetchFromSourcehut -, rustPlatform -, pkg-config -, wrapGAppsHook3 -, openssl -, gtk3 -, gdk-pixbuf -, pango -, atk -, cairo +{ + lib, + fetchFromSourcehut, + rustPlatform, + pkg-config, + wrapGAppsHook3, + openssl, + gtk3, + gdk-pixbuf, + pango, + atk, + cairo, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ca/castty/package.nix b/pkgs/by-name/ca/castty/package.nix index 86dae729790b89..8de42b4c6d1729 100644 --- a/pkgs/by-name/ca/castty/package.nix +++ b/pkgs/by-name/ca/castty/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, libsoundio, lame }: +{ + stdenv, + lib, + fetchFromGitHub, + libsoundio, + lame, +}: stdenv.mkDerivation { pname = "castty"; @@ -11,7 +17,10 @@ stdenv.mkDerivation { sha256 = "0p84ivwsp8ds4drn0hx2ax04gp0xyq6blj1iqfsmrs4slrajdmqs"; }; - buildInputs = [ libsoundio lame ]; + buildInputs = [ + libsoundio + lame + ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" diff --git a/pkgs/by-name/ca/catatonit/package.nix b/pkgs/by-name/ca/catatonit/package.nix index 1c9f310ed86a1a..bdd522f042ee23 100644 --- a/pkgs/by-name/ca/catatonit/package.nix +++ b/pkgs/by-name/ca/catatonit/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, autoreconfHook -, fetchFromGitHub -, glibc -, nixosTests +{ + stdenv, + lib, + autoreconfHook, + fetchFromGitHub, + glibc, + nixosTests, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = lib.optionals (!stdenv.hostPlatform.isMusl) [ glibc glibc.static ]; + buildInputs = lib.optionals (!stdenv.hostPlatform.isMusl) [ + glibc + glibc.static + ]; enableParallelBuilding = true; strictDeps = true; diff --git a/pkgs/by-name/ca/catch/package.nix b/pkgs/by-name/ca/catch/package.nix index e17bbbaf4b7661..07a79619b49d19 100644 --- a/pkgs/by-name/ca/catch/package.nix +++ b/pkgs/by-name/ca/catch/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, +}: stdenv.mkDerivation rec { pname = "catch"; @@ -35,7 +41,10 @@ stdenv.mkDerivation rec { description = "Multi-paradigm automated test framework for C++ and Objective-C (and, maybe, C)"; homepage = "http://catch-lib.net"; license = licenses.boost; - maintainers = with maintainers; [ edwtjo knedlsepp ]; + maintainers = with maintainers; [ + edwtjo + knedlsepp + ]; platforms = with platforms; unix; }; } diff --git a/pkgs/by-name/ca/catclock/package.nix b/pkgs/by-name/ca/catclock/package.nix index e65bcd2ff2e2d5..4d2d81aa282b3d 100644 --- a/pkgs/by-name/ca/catclock/package.nix +++ b/pkgs/by-name/ca/catclock/package.nix @@ -1,5 +1,13 @@ -{ stdenv, lib, fetchFromGitHub, motif, xorg -, withAudioTracking ? false, libpulseaudio, aubio }: +{ + stdenv, + lib, + fetchFromGitHub, + motif, + xorg, + withAudioTracking ? false, + libpulseaudio, + aubio, +}: stdenv.mkDerivation { pname = "catclock"; @@ -18,11 +26,19 @@ stdenv.mkDerivation { cp xclock.man $out/share/man/man1/xclock.1 ''; - makeFlags = [ "DESTINATION=$(out)/bin/" ] - ++ lib.optional withAudioTracking "WITH_TEMPO_TRACKER=1"; + makeFlags = [ "DESTINATION=$(out)/bin/" ] ++ lib.optional withAudioTracking "WITH_TEMPO_TRACKER=1"; - buildInputs = [ motif xorg.libX11 xorg.libXext xorg.libXt ] - ++ lib.optionals withAudioTracking [ libpulseaudio aubio ]; + buildInputs = + [ + motif + xorg.libX11 + xorg.libXext + xorg.libXt + ] + ++ lib.optionals withAudioTracking [ + libpulseaudio + aubio + ]; meta = with lib; { homepage = "http://codefromabove.com/2014/05/catclock/"; diff --git a/pkgs/by-name/ca/catdoc/package.nix b/pkgs/by-name/ca/catdoc/package.nix index 1fdaf78a6769d6..998d3e74841e42 100644 --- a/pkgs/by-name/ca/catdoc/package.nix +++ b/pkgs/by-name/ca/catdoc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "catdoc"; diff --git a/pkgs/by-name/ca/catdocx/package.nix b/pkgs/by-name/ca/catdocx/package.nix index 27eb964eb3c23b..657e7bbd790090 100644 --- a/pkgs/by-name/ca/catdocx/package.nix +++ b/pkgs/by-name/ca/catdocx/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper, unzip, catdoc }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + unzip, + catdoc, +}: stdenv.mkDerivation { pname = "catdocx"; @@ -17,7 +24,12 @@ stdenv.mkDerivation { mkdir -p $out/libexec $out/bin cp catdocx.sh $out/libexec chmod +x $out/libexec/catdocx.sh - wrapProgram $out/libexec/catdocx.sh --prefix PATH : "${lib.makeBinPath [ unzip catdoc ]}" + wrapProgram $out/libexec/catdocx.sh --prefix PATH : "${ + lib.makeBinPath [ + unzip + catdoc + ] + }" ln -s $out/libexec/catdocx.sh $out/bin/catdocx ''; diff --git a/pkgs/by-name/ca/catdvi/package.nix b/pkgs/by-name/ca/catdvi/package.nix index 03fedbbc386d92..f6c3becb41fd19 100644 --- a/pkgs/by-name/ca/catdvi/package.nix +++ b/pkgs/by-name/ca/catdvi/package.nix @@ -1,14 +1,18 @@ -{ stdenv -, lib -, fetchurl -, fetchpatch -, texlive -, texliveInfraOnly -, buildPackages +{ + stdenv, + lib, + fetchurl, + fetchpatch, + texlive, + texliveInfraOnly, + buildPackages, }: let - buildPlatformTools = [ "pse2unic" "adobe2h" ]; + buildPlatformTools = [ + "pse2unic" + "adobe2h" + ]; tex = texliveInfraOnly.withPackages (ps: [ ps.collection-fontsrecommended ]); in @@ -41,10 +45,11 @@ stdenv.mkDerivation (finalAttrs: { enableParallelBuilding = true; - preBuild = lib.optionalString (with stdenv; !buildPlatform.canExecute hostPlatform) - (lib.concatMapStringsSep "\n" (tool: '' + preBuild = lib.optionalString (with stdenv; !buildPlatform.canExecute hostPlatform) ( + lib.concatMapStringsSep "\n" (tool: '' cp ${lib.getDev buildPackages.catdvi}/bin/${tool} . - '') buildPlatformTools); + '') buildPlatformTools + ); nativeBuildInputs = [ texlive.bin.core @@ -55,10 +60,13 @@ stdenv.mkDerivation (finalAttrs: { tex ]; - makeFlags = [ - "catdvi" # to avoid running tests until checkPhase - ] ++ lib.optionals (with stdenv; !buildPlatform.canExecute hostPlatform) - (map (tool: "--assume-old=${tool}") buildPlatformTools); + makeFlags = + [ + "catdvi" # to avoid running tests until checkPhase + ] + ++ lib.optionals (with stdenv; !buildPlatform.canExecute hostPlatform) ( + map (tool: "--assume-old=${tool}") buildPlatformTools + ); nativeCheckInputs = [ texlive @@ -72,15 +80,17 @@ stdenv.mkDerivation (finalAttrs: { mkdir -p $out/{bin,man/man1} ''; - postInstall = lib.optionalString (with stdenv; buildPlatform.canExecute hostPlatform) '' - mkdir -p $dev/bin - ${lib.concatMapStringsSep "\n" (tool: '' - cp ${tool} $dev/bin/ - '') buildPlatformTools} - '' + '' - mkdir -p $out/share - ln -s ${tex}/share/texmf-var $out/share/texmf - ''; + postInstall = + lib.optionalString (with stdenv; buildPlatform.canExecute hostPlatform) '' + mkdir -p $dev/bin + ${lib.concatMapStringsSep "\n" (tool: '' + cp ${tool} $dev/bin/ + '') buildPlatformTools} + '' + + '' + mkdir -p $out/share + ln -s ${tex}/share/texmf-var $out/share/texmf + ''; meta = with lib; { homepage = "http://catdvi.sourceforge.net"; diff --git a/pkgs/by-name/ca/catfs/package.nix b/pkgs/by-name/ca/catfs/package.nix index 52ade30af00079..2699bd992e70fb 100644 --- a/pkgs/by-name/ca/catfs/package.nix +++ b/pkgs/by-name/ca/catfs/package.nix @@ -1,6 +1,9 @@ -{ lib, rustPlatform, fetchFromGitHub -, fuse -, pkg-config +{ + lib, + rustPlatform, + fetchFromGitHub, + fuse, + pkg-config, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ca/catgirl/package.nix b/pkgs/by-name/ca/catgirl/package.nix index 318a3ec5fdb3cf..cd6ba40d1c4f2b 100644 --- a/pkgs/by-name/ca/catgirl/package.nix +++ b/pkgs/by-name/ca/catgirl/package.nix @@ -1,4 +1,12 @@ -{ ctags, fetchurl, lib, libressl, ncurses, pkg-config, stdenv }: +{ + ctags, + fetchurl, + lib, + libressl, + ncurses, + pkg-config, + stdenv, +}: stdenv.mkDerivation rec { pname = "catgirl"; @@ -19,8 +27,14 @@ stdenv.mkDerivation rec { "${lib.getBin libressl}" ''; - nativeBuildInputs = [ ctags pkg-config ]; - buildInputs = [ libressl ncurses ]; + nativeBuildInputs = [ + ctags + pkg-config + ]; + buildInputs = [ + libressl + ncurses + ]; strictDeps = true; enableParallelBuilding = true; diff --git a/pkgs/by-name/ca/catimg/package.nix b/pkgs/by-name/ca/catimg/package.nix index 9edfc576837d92..8bc3ba1f875011 100644 --- a/pkgs/by-name/ca/catimg/package.nix +++ b/pkgs/by-name/ca/catimg/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake } : +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "catimg"; diff --git a/pkgs/by-name/ca/catnip-gtk4/package.nix b/pkgs/by-name/ca/catnip-gtk4/package.nix index 5d0f9182ce243a..fa7334bdd6b43c 100644 --- a/pkgs/by-name/ca/catnip-gtk4/package.nix +++ b/pkgs/by-name/ca/catnip-gtk4/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, pkg-config -, wrapGAppsHook4 -, gobject-introspection -, gtk4 -, libadwaita +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + wrapGAppsHook4, + gobject-introspection, + gtk4, + libadwaita, }: buildGoModule { @@ -32,7 +33,10 @@ buildGoModule { libadwaita ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/ca/catnip/package.nix b/pkgs/by-name/ca/catnip/package.nix index fea82e71cd865e..7687535405e815 100644 --- a/pkgs/by-name/ca/catnip/package.nix +++ b/pkgs/by-name/ca/catnip/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, pkg-config -, portaudio -, testers -, catnip +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + portaudio, + testers, + catnip, }: buildGoModule rec { diff --git a/pkgs/by-name/ca/catppuccin-fcitx5/package.nix b/pkgs/by-name/ca/catppuccin-fcitx5/package.nix index 804dd90b6ab154..bcdff788b103b0 100644 --- a/pkgs/by-name/ca/catppuccin-fcitx5/package.nix +++ b/pkgs/by-name/ca/catppuccin-fcitx5/package.nix @@ -31,7 +31,10 @@ stdenvNoCC.mkDerivation { description = "Soothing pastel theme for Fcitx5"; homepage = "https://github.com/catppuccin/fcitx5"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ pluiedev Guanran928 ]; + maintainers = with lib.maintainers; [ + pluiedev + Guanran928 + ]; platforms = lib.platforms.all; }; } diff --git a/pkgs/by-name/ca/catppuccin-grub/package.nix b/pkgs/by-name/ca/catppuccin-grub/package.nix index 7c3a16348e9b6f..7472007f022086 100644 --- a/pkgs/by-name/ca/catppuccin-grub/package.nix +++ b/pkgs/by-name/ca/catppuccin-grub/package.nix @@ -31,7 +31,10 @@ stdenvNoCC.mkDerivation { description = "Soothing pastel theme for GRUB"; homepage = "https://github.com/catppuccin/grub"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [isabelroses mimvoid]; + maintainers = with lib.maintainers; [ + isabelroses + mimvoid + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/ca/catppuccin-gtk/package.nix b/pkgs/by-name/ca/catppuccin-gtk/package.nix index 964e631c9cade9..f2a30186c45604 100644 --- a/pkgs/by-name/ca/catppuccin-gtk/package.nix +++ b/pkgs/by-name/ca/catppuccin-gtk/package.nix @@ -1,77 +1,119 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gtk3 -, git -, python3 -, sassc -, nix-update-script -, accents ? [ "blue" ] -, size ? "standard" -, tweaks ? [ ] -, variant ? "frappe" +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + git, + python3, + sassc, + nix-update-script, + accents ? [ "blue" ], + size ? "standard", + tweaks ? [ ], + variant ? "frappe", }: let - validAccents = [ "blue" "flamingo" "green" "lavender" "maroon" "mauve" "peach" "pink" "red" "rosewater" "sapphire" "sky" "teal" "yellow" ]; - validSizes = [ "standard" "compact" ]; - validTweaks = [ "black" "rimless" "normal" "float" ]; - validVariants = [ "latte" "frappe" "macchiato" "mocha" ]; + validAccents = [ + "blue" + "flamingo" + "green" + "lavender" + "maroon" + "mauve" + "peach" + "pink" + "red" + "rosewater" + "sapphire" + "sky" + "teal" + "yellow" + ]; + validSizes = [ + "standard" + "compact" + ]; + validTweaks = [ + "black" + "rimless" + "normal" + "float" + ]; + validVariants = [ + "latte" + "frappe" + "macchiato" + "mocha" + ]; pname = "catppuccin-gtk"; version = "1.0.3"; in -lib.checkListOfEnum "${pname}: theme accent" validAccents accents -lib.checkListOfEnum "${pname}: color variant" validVariants [variant] -lib.checkListOfEnum "${pname}: size variant" validSizes [size] -lib.checkListOfEnum "${pname}: tweaks" validTweaks tweaks +lib.checkListOfEnum "${pname}: theme accent" validAccents accents lib.checkListOfEnum + "${pname}: color variant" + validVariants + [ variant ] + lib.checkListOfEnum + "${pname}: size variant" + validSizes + [ size ] + lib.checkListOfEnum + "${pname}: tweaks" + validTweaks + tweaks -stdenvNoCC.mkDerivation { - inherit pname version; + stdenvNoCC.mkDerivation + { + inherit pname version; - src = fetchFromGitHub { - owner = "catppuccin"; - repo = "gtk"; - rev = "v${version}"; - fetchSubmodules = true; - hash = "sha256-q5/VcFsm3vNEw55zq/vcM11eo456SYE5TQA3g2VQjGc="; - }; + src = fetchFromGitHub { + owner = "catppuccin"; + repo = "gtk"; + rev = "v${version}"; + fetchSubmodules = true; + hash = "sha256-q5/VcFsm3vNEw55zq/vcM11eo456SYE5TQA3g2VQjGc="; + }; - patches = [ ./fix-inconsistent-theme-name.patch ]; + patches = [ ./fix-inconsistent-theme-name.patch ]; - nativeBuildInputs = [ - gtk3 - sassc - # git is needed here since "git apply" is being used for patches - # see - git - (python3.withPackages (ps: [ ps.catppuccin ])) - ]; + nativeBuildInputs = [ + gtk3 + sassc + # git is needed here since "git apply" is being used for patches + # see + git + (python3.withPackages (ps: [ ps.catppuccin ])) + ]; - dontConfigure = true; - dontBuild = true; + dontConfigure = true; + dontBuild = true; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $out/share/themes + mkdir -p $out/share/themes - python3 build.py ${variant} \ - --accent ${builtins.toString accents} \ - ${lib.optionalString (size != [ ]) "--size " + size} \ - ${lib.optionalString (tweaks != [ ]) "--tweaks " + builtins.toString tweaks} \ - --dest $out/share/themes + python3 build.py ${variant} \ + --accent ${builtins.toString accents} \ + ${lib.optionalString (size != [ ]) "--size " + size} \ + ${lib.optionalString (tweaks != [ ]) "--tweaks " + builtins.toString tweaks} \ + --dest $out/share/themes - runHook postInstall - ''; + runHook postInstall + ''; - passthru.updateScript = nix-update-script { }; + passthru.updateScript = nix-update-script { }; - meta = { - description = "Soothing pastel theme for GTK"; - homepage = "https://github.com/catppuccin/gtk"; - license = lib.licenses.gpl3Plus; - platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ fufexan dixslyf isabelroses ]; - }; -} + meta = { + description = "Soothing pastel theme for GTK"; + homepage = "https://github.com/catppuccin/gtk"; + license = lib.licenses.gpl3Plus; + platforms = lib.platforms.all; + maintainers = with lib.maintainers; [ + fufexan + dixslyf + isabelroses + ]; + }; + } diff --git a/pkgs/by-name/ca/catppuccin-kde/package.nix b/pkgs/by-name/ca/catppuccin-kde/package.nix index b4ce9ed5d39f0a..78ab534f82969f 100644 --- a/pkgs/by-name/ca/catppuccin-kde/package.nix +++ b/pkgs/by-name/ca/catppuccin-kde/package.nix @@ -1,62 +1,97 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, fetchpatch -, flavour ? [ "frappe" ] -, accents ? [ "blue" ] -, winDecStyles ? [ "modern" ] +{ + lib, + stdenvNoCC, + fetchFromGitHub, + fetchpatch, + flavour ? [ "frappe" ], + accents ? [ "blue" ], + winDecStyles ? [ "modern" ], }: let - validFlavours = [ "mocha" "macchiato" "frappe" "latte" ]; - validAccents = [ "rosewater" "flamingo" "pink" "mauve" "red" "maroon" "peach" "yellow" "green" "teal" "sky" "sapphire" "blue" "lavender" ]; - validWinDecStyles = [ "modern" "classic" ]; + validFlavours = [ + "mocha" + "macchiato" + "frappe" + "latte" + ]; + validAccents = [ + "rosewater" + "flamingo" + "pink" + "mauve" + "red" + "maroon" + "peach" + "yellow" + "green" + "teal" + "sky" + "sapphire" + "blue" + "lavender" + ]; + validWinDecStyles = [ + "modern" + "classic" + ]; colorScript = ./color.sh; in - lib.checkListOfEnum "Invalid accent, valid accents are ${toString validAccents}" validAccents accents - lib.checkListOfEnum "Invalid flavour, valid flavours are ${toString validFlavours}" validFlavours flavour - lib.checkListOfEnum "Invalid window decoration style, valid styles are ${toString validWinDecStyles}" validWinDecStyles winDecStyles - -stdenvNoCC.mkDerivation rec { - pname = "kde"; - version = "0.2.6"; - - src = fetchFromGitHub { - owner = "catppuccin"; - repo = pname; - rev = "v${version}"; - hash = "sha256-pfG0L4eSXLYLZM8Mhla4yalpEro74S9kc0sOmQtnG3w="; - }; - - patches = [ - (fetchpatch { - url = "https://github.com/GiggleSquid/catppuccin-kde/commit/f0291c17d2e4711b0d0aac00e3dbb94ee89b4a82.patch"; - hash = "sha256-iD+mEX2LRFmrCwLr3VAs6kzcTuZ231TKDn+U188iOss="; - }) - ]; +lib.checkListOfEnum "Invalid accent, valid accents are ${toString validAccents}" validAccents + accents + lib.checkListOfEnum + "Invalid flavour, valid flavours are ${toString validFlavours}" + validFlavours + flavour + lib.checkListOfEnum + "Invalid window decoration style, valid styles are ${toString validWinDecStyles}" + validWinDecStyles + winDecStyles + + stdenvNoCC.mkDerivation + rec { + pname = "kde"; + version = "0.2.6"; - installPhase = '' - runHook preInstall - patchShebangs . + src = fetchFromGitHub { + owner = "catppuccin"; + repo = pname; + rev = "v${version}"; + hash = "sha256-pfG0L4eSXLYLZM8Mhla4yalpEro74S9kc0sOmQtnG3w="; + }; - for WINDECSTYLE in ${toString winDecStyles}; do - for FLAVOUR in ${toString flavour}; do - for ACCENT in ${toString accents}; do - source ${colorScript} - ./install.sh $FLAVOUR $ACCENT $WINDECSTYLE + patches = [ + (fetchpatch { + url = "https://github.com/GiggleSquid/catppuccin-kde/commit/f0291c17d2e4711b0d0aac00e3dbb94ee89b4a82.patch"; + hash = "sha256-iD+mEX2LRFmrCwLr3VAs6kzcTuZ231TKDn+U188iOss="; + }) + ]; + + installPhase = '' + runHook preInstall + patchShebangs . + + for WINDECSTYLE in ${toString winDecStyles}; do + for FLAVOUR in ${toString flavour}; do + for ACCENT in ${toString accents}; do + source ${colorScript} + ./install.sh $FLAVOUR $ACCENT $WINDECSTYLE + done; done; done; - done; - - runHook postInstall - ''; - - meta = with lib; { - description = "Soothing pastel theme for KDE"; - homepage = "https://github.com/catppuccin/kde"; - license = licenses.mit; - maintainers = with maintainers; [ michaelBelsanti gigglesquid ]; - }; -} + + runHook postInstall + ''; + + meta = with lib; { + description = "Soothing pastel theme for KDE"; + homepage = "https://github.com/catppuccin/kde"; + license = licenses.mit; + maintainers = with maintainers; [ + michaelBelsanti + gigglesquid + ]; + }; + } diff --git a/pkgs/by-name/ca/catppuccin-kvantum/package.nix b/pkgs/by-name/ca/catppuccin-kvantum/package.nix index a595edbd6de5f0..c7f0e0cf6070c4 100644 --- a/pkgs/by-name/ca/catppuccin-kvantum/package.nix +++ b/pkgs/by-name/ca/catppuccin-kvantum/package.nix @@ -5,13 +5,33 @@ unstableGitUpdater, accent ? "blue", variant ? "frappe", -}: let +}: +let pname = "catppuccin-kvantum"; in - lib.checkListOfEnum "${pname}: theme accent" ["blue" "flamingo" "green" "lavender" "maroon" "mauve" "peach" "pink" "red" "rosewater" "sapphire" "sky" "teal" "yellow"] [accent] - lib.checkListOfEnum "${pname}: color variant" ["latte" "frappe" "macchiato" "mocha"] [variant] +lib.checkListOfEnum "${pname}: theme accent" + [ + "blue" + "flamingo" + "green" + "lavender" + "maroon" + "mauve" + "peach" + "pink" + "red" + "rosewater" + "sapphire" + "sky" + "teal" + "yellow" + ] + [ accent ] + lib.checkListOfEnum + "${pname}: color variant" [ "latte" "frappe" "macchiato" "mocha" ] [ variant ] - stdenvNoCC.mkDerivation { + stdenvNoCC.mkDerivation + { inherit pname; version = "0-unstable-2024-10-25"; diff --git a/pkgs/by-name/ca/catppuccin-papirus-folders/package.nix b/pkgs/by-name/ca/catppuccin-papirus-folders/package.nix index 70529a6337b7ee..b5baf4d614ed2d 100644 --- a/pkgs/by-name/ca/catppuccin-papirus-folders/package.nix +++ b/pkgs/by-name/ca/catppuccin-papirus-folders/package.nix @@ -5,16 +5,40 @@ gtk3, papirus-icon-theme, flavor ? "mocha", - accent ? "blue" -}: let - validAccents = ["blue" "flamingo" "green" "lavender" "maroon" "mauve" "peach" "pink" "red" "rosewater" "sapphire" "sky" "teal" "yellow"]; - validFlavors = ["latte" "frappe" "macchiato" "mocha"]; + accent ? "blue", +}: +let + validAccents = [ + "blue" + "flamingo" + "green" + "lavender" + "maroon" + "mauve" + "peach" + "pink" + "red" + "rosewater" + "sapphire" + "sky" + "teal" + "yellow" + ]; + validFlavors = [ + "latte" + "frappe" + "macchiato" + "mocha" + ]; pname = "catppuccin-papirus-folders"; in - lib.checkListOfEnum "${pname}: accent colors" validAccents [ accent ] - lib.checkListOfEnum "${pname}: flavors" validFlavors [ flavor ] +lib.checkListOfEnum "${pname}: accent colors" validAccents [ accent ] lib.checkListOfEnum + "${pname}: flavors" + validFlavors + [ flavor ] - stdenvNoCC.mkDerivation { + stdenvNoCC.mkDerivation + { inherit pname; version = "unstable-2023-08-02"; diff --git a/pkgs/by-name/ca/catppuccin-qt5ct/package.nix b/pkgs/by-name/ca/catppuccin-qt5ct/package.nix index f9b7a85c8cfb91..d0b4c538093191 100644 --- a/pkgs/by-name/ca/catppuccin-qt5ct/package.nix +++ b/pkgs/by-name/ca/catppuccin-qt5ct/package.nix @@ -25,7 +25,7 @@ stdenvNoCC.mkDerivation { description = "Soothing pastel theme for qt5ct"; homepage = "https://github.com/catppuccin/qt5ct"; license = licenses.mit; - maintainers = with maintainers; [pluiedev]; + maintainers = with maintainers; [ pluiedev ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/ca/catppuccin-sddm-corners/package.nix b/pkgs/by-name/ca/catppuccin-sddm-corners/package.nix index e43792fc4a9fe4..1665eeffc02e2b 100644 --- a/pkgs/by-name/ca/catppuccin-sddm-corners/package.nix +++ b/pkgs/by-name/ca/catppuccin-sddm-corners/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, libsForQt5 -, unstableGitUpdater +{ + lib, + stdenvNoCC, + fetchFromGitHub, + libsForQt5, + unstableGitUpdater, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/ca/catppuccin-sddm/package.nix b/pkgs/by-name/ca/catppuccin-sddm/package.nix index 1daab09ae646db..1de2521a5f42f4 100644 --- a/pkgs/by-name/ca/catppuccin-sddm/package.nix +++ b/pkgs/by-name/ca/catppuccin-sddm/package.nix @@ -74,7 +74,7 @@ stdenvNoCC.mkDerivation rec { description = "Soothing pastel theme for SDDM"; homepage = "https://github.com/catppuccin/sddm"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [elysasrc]; + maintainers = with lib.maintainers; [ elysasrc ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/ca/catppuccin-whiskers/package.nix b/pkgs/by-name/ca/catppuccin-whiskers/package.nix index a24ba429388e45..2f69b8cd504e6e 100644 --- a/pkgs/by-name/ca/catppuccin-whiskers/package.nix +++ b/pkgs/by-name/ca/catppuccin-whiskers/package.nix @@ -1,6 +1,12 @@ -{ lib, fetchFromGitHub, rustPlatform }: -let version = "2.5.1"; -in rustPlatform.buildRustPackage { +{ + lib, + fetchFromGitHub, + rustPlatform, +}: +let + version = "2.5.1"; +in +rustPlatform.buildRustPackage { pname = "catppuccin-whiskers"; inherit version; diff --git a/pkgs/by-name/ca/catppuccin/package.nix b/pkgs/by-name/ca/catppuccin/package.nix index c547de3b3c47e2..069c9a326961e9 100644 --- a/pkgs/by-name/ca/catppuccin/package.nix +++ b/pkgs/by-name/ca/catppuccin/package.nix @@ -1,18 +1,56 @@ let - validThemes = [ "bat" "bottom" "btop" "grub" "hyprland" "k9s" "kvantum" "lazygit" "lxqt" "plymouth" "qt5ct" "refind" "rofi" "starship" "thunderbird" "waybar" ]; + validThemes = [ + "bat" + "bottom" + "btop" + "grub" + "hyprland" + "k9s" + "kvantum" + "lazygit" + "lxqt" + "plymouth" + "qt5ct" + "refind" + "rofi" + "starship" + "thunderbird" + "waybar" + ]; in -{ fetchFromGitHub -, lib -, stdenvNoCC -, accent ? "blue" -, variant ? "macchiato" -, themeList ? validThemes +{ + fetchFromGitHub, + lib, + stdenvNoCC, + accent ? "blue", + variant ? "macchiato", + themeList ? validThemes, }: let pname = "catppuccin"; - validAccents = [ "rosewater" "flamingo" "pink" "mauve" "red" "maroon" "peach" "yellow" "green" "teal" "sky" "sapphire" "blue" "lavender" ]; - validVariants = [ "latte" "frappe" "macchiato" "mocha" ]; + validAccents = [ + "rosewater" + "flamingo" + "pink" + "mauve" + "red" + "maroon" + "peach" + "yellow" + "green" + "teal" + "sky" + "sapphire" + "blue" + "lavender" + ]; + validVariants = [ + "latte" + "frappe" + "macchiato" + "mocha" + ]; selectedSources = map (themeName: builtins.getAttr themeName sources) themeList; sources = { @@ -145,106 +183,130 @@ let }; }; in -lib.checkListOfEnum "${pname}: variant" validVariants [ variant ] -lib.checkListOfEnum "${pname}: accent" validAccents [ accent ] -lib.checkListOfEnum "${pname}: themes" validThemes themeList - -stdenvNoCC.mkDerivation { - inherit pname; - version = "unstable-2024-03-12"; - - srcs = selectedSources; - - unpackPhase = '' - for s in $selectedSources; do - b=$(basename $s) - cp $s ''${b#*-} - done - ''; - - installPhase = '' - runHook preInstall - - local capitalizedVariant=$(sed 's/^\(.\)/\U\1/' <<< "${variant}") - local capitalizedAccent=$(sed 's/^\(.\)/\U\1/' <<< "${accent}") - - '' + lib.optionalString (lib.elem "bat" themeList) '' - mkdir -p $out/bat - cp "${sources.bat}/themes/Catppuccin "$capitalizedVariant".tmTheme" "$out/bat/" - - '' + lib.optionalString (lib.elem "btop" themeList) '' - mkdir -p $out/btop - cp "${sources.btop}/themes/catppuccin_${variant}.theme" "$out/btop/" - - '' + lib.optionalString (lib.elem "bottom" themeList) '' - mkdir -p $out/bottom - cp "${sources.bottom}/themes/${variant}.toml" "$out/bottom/" - - '' + lib.optionalString (lib.elem "grub" themeList) '' - mkdir -p $out/grub - cp -r ${sources.grub}/src/catppuccin-${variant}-grub-theme/* "$out/grub/" - - '' + lib.optionalString (lib.elem "hyprland" themeList) '' - mkdir -p $out/hyprland - cp "${sources.hyprland}/themes/${variant}.conf" "$out/hyprland/" - - '' + lib.optionalString (lib.elem "k9s" themeList) '' - mkdir -p $out/k9s - cp "${sources.k9s}/dist/catppuccin-${variant}.yaml" "$out/k9s/" - cp "${sources.k9s}/dist/catppuccin-${variant}-transparent.yaml" "$out/k9s/" - - '' + lib.optionalString (lib.elem "kvantum" themeList) '' - mkdir -p $out/share/Kvantum - cp -r ${sources.kvantum}/src/Catppuccin-"$capitalizedVariant"-"$capitalizedAccent" $out/share/Kvantum - - '' + lib.optionalString (lib.elem "lazygit" themeList) '' - mkdir -p $out/lazygit/{themes,themes-mergable} - cp "${sources.lazygit}/themes/${variant}/${accent}.yml" "$out/lazygit/themes/" - cp "${sources.lazygit}/themes-mergable/${variant}/${accent}.yml" "$out/lazygit/themes-mergable/" - - '' + lib.optionalString (lib.elem "lxqt" themeList) '' - mkdir -p $out/share/lxqt/themes/catppuccin-${variant} - cp -r ${sources.lxqt}/src/catppuccin-${variant}/* $out/share/lxqt/themes/catppuccin-${variant}/ - - '' + lib.optionalString (lib.elem "plymouth" themeList) '' - mkdir -p $out/share/plymouth/themes/catppuccin-${variant} - cp ${sources.plymouth}/themes/catppuccin-${variant}/* $out/share/plymouth/themes/catppuccin-${variant} - sed -i 's:\(^ImageDir=\)/usr:\1'"$out"':' $out/share/plymouth/themes/catppuccin-${variant}/catppuccin-${variant}.plymouth - - '' + lib.optionalString (lib.elem "qt5ct" themeList) '' - mkdir -p $out/qt5ct - cp ${sources.qt5ct}/themes/Catppuccin-"$capitalizedVariant".conf $out/qt5ct/ - - '' + lib.optionalString (lib.elem "rofi" themeList) '' - mkdir -p $out/rofi - cp ${sources.rofi}/basic/.local/share/rofi/themes/catppuccin-${variant}.rasi $out/rofi/ - - '' + lib.optionalString (lib.elem "refind" themeList) '' - mkdir -p $out/refind/assets - cp ${sources.refind}/${variant}.conf $out/refind/ - cp -r ${sources.refind}/assets/${variant} $out/refind/assets/ - - '' + lib.optionalString (lib.elem "starship" themeList) '' - mkdir -p $out/starship - cp ${sources.starship}/palettes/${variant}.toml $out/starship/ - - '' + lib.optionalString (lib.elem "thunderbird" themeList) '' - mkdir -p $out/thunderbird - cp ${sources.thunderbird}/themes/${variant}/${variant}-${accent}.xpi $out/thunderbird/ - - '' + lib.optionalString (lib.elem "waybar" themeList) '' - mkdir -p $out/waybar - cp ${sources.waybar}/${variant}.css $out/waybar/ - - '' + '' - runHook postInstall - ''; - - meta = { - description = "Soothing pastel themes"; - homepage = "https://github.com/catppuccin/catppuccin"; - license = lib.licenses.mit; - platforms = lib.platforms.all; - maintainers = [ lib.maintainers.khaneliman ]; - }; -} +lib.checkListOfEnum "${pname}: variant" validVariants [ variant ] lib.checkListOfEnum + "${pname}: accent" + validAccents + [ accent ] + lib.checkListOfEnum + "${pname}: themes" + validThemes + themeList + + stdenvNoCC.mkDerivation + { + inherit pname; + version = "unstable-2024-03-12"; + + srcs = selectedSources; + + unpackPhase = '' + for s in $selectedSources; do + b=$(basename $s) + cp $s ''${b#*-} + done + ''; + + installPhase = + '' + runHook preInstall + + local capitalizedVariant=$(sed 's/^\(.\)/\U\1/' <<< "${variant}") + local capitalizedAccent=$(sed 's/^\(.\)/\U\1/' <<< "${accent}") + + '' + + lib.optionalString (lib.elem "bat" themeList) '' + mkdir -p $out/bat + cp "${sources.bat}/themes/Catppuccin "$capitalizedVariant".tmTheme" "$out/bat/" + + '' + + lib.optionalString (lib.elem "btop" themeList) '' + mkdir -p $out/btop + cp "${sources.btop}/themes/catppuccin_${variant}.theme" "$out/btop/" + + '' + + lib.optionalString (lib.elem "bottom" themeList) '' + mkdir -p $out/bottom + cp "${sources.bottom}/themes/${variant}.toml" "$out/bottom/" + + '' + + lib.optionalString (lib.elem "grub" themeList) '' + mkdir -p $out/grub + cp -r ${sources.grub}/src/catppuccin-${variant}-grub-theme/* "$out/grub/" + + '' + + lib.optionalString (lib.elem "hyprland" themeList) '' + mkdir -p $out/hyprland + cp "${sources.hyprland}/themes/${variant}.conf" "$out/hyprland/" + + '' + + lib.optionalString (lib.elem "k9s" themeList) '' + mkdir -p $out/k9s + cp "${sources.k9s}/dist/catppuccin-${variant}.yaml" "$out/k9s/" + cp "${sources.k9s}/dist/catppuccin-${variant}-transparent.yaml" "$out/k9s/" + + '' + + lib.optionalString (lib.elem "kvantum" themeList) '' + mkdir -p $out/share/Kvantum + cp -r ${sources.kvantum}/src/Catppuccin-"$capitalizedVariant"-"$capitalizedAccent" $out/share/Kvantum + + '' + + lib.optionalString (lib.elem "lazygit" themeList) '' + mkdir -p $out/lazygit/{themes,themes-mergable} + cp "${sources.lazygit}/themes/${variant}/${accent}.yml" "$out/lazygit/themes/" + cp "${sources.lazygit}/themes-mergable/${variant}/${accent}.yml" "$out/lazygit/themes-mergable/" + + '' + + lib.optionalString (lib.elem "lxqt" themeList) '' + mkdir -p $out/share/lxqt/themes/catppuccin-${variant} + cp -r ${sources.lxqt}/src/catppuccin-${variant}/* $out/share/lxqt/themes/catppuccin-${variant}/ + + '' + + lib.optionalString (lib.elem "plymouth" themeList) '' + mkdir -p $out/share/plymouth/themes/catppuccin-${variant} + cp ${sources.plymouth}/themes/catppuccin-${variant}/* $out/share/plymouth/themes/catppuccin-${variant} + sed -i 's:\(^ImageDir=\)/usr:\1'"$out"':' $out/share/plymouth/themes/catppuccin-${variant}/catppuccin-${variant}.plymouth + + '' + + lib.optionalString (lib.elem "qt5ct" themeList) '' + mkdir -p $out/qt5ct + cp ${sources.qt5ct}/themes/Catppuccin-"$capitalizedVariant".conf $out/qt5ct/ + + '' + + lib.optionalString (lib.elem "rofi" themeList) '' + mkdir -p $out/rofi + cp ${sources.rofi}/basic/.local/share/rofi/themes/catppuccin-${variant}.rasi $out/rofi/ + + '' + + lib.optionalString (lib.elem "refind" themeList) '' + mkdir -p $out/refind/assets + cp ${sources.refind}/${variant}.conf $out/refind/ + cp -r ${sources.refind}/assets/${variant} $out/refind/assets/ + + '' + + lib.optionalString (lib.elem "starship" themeList) '' + mkdir -p $out/starship + cp ${sources.starship}/palettes/${variant}.toml $out/starship/ + + '' + + lib.optionalString (lib.elem "thunderbird" themeList) '' + mkdir -p $out/thunderbird + cp ${sources.thunderbird}/themes/${variant}/${variant}-${accent}.xpi $out/thunderbird/ + + '' + + lib.optionalString (lib.elem "waybar" themeList) '' + mkdir -p $out/waybar + cp ${sources.waybar}/${variant}.css $out/waybar/ + + '' + + '' + runHook postInstall + ''; + + meta = { + description = "Soothing pastel themes"; + homepage = "https://github.com/catppuccin/catppuccin"; + license = lib.licenses.mit; + platforms = lib.platforms.all; + maintainers = [ lib.maintainers.khaneliman ]; + }; + } diff --git a/pkgs/by-name/ca/catppuccinifier-cli/package.nix b/pkgs/by-name/ca/catppuccinifier-cli/package.nix index f9a3b4431fc5e9..fc9ff4e2347dbe 100644 --- a/pkgs/by-name/ca/catppuccinifier-cli/package.nix +++ b/pkgs/by-name/ca/catppuccinifier-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -28,7 +29,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/lighttigerXIV/catppuccinifier"; license = lib.licenses.mit; mainProgram = "catppuccinifier-cli"; - maintainers = with lib.maintainers; [ aleksana isabelroses ]; + maintainers = with lib.maintainers; [ + aleksana + isabelroses + ]; platforms = with lib.platforms; linux ++ windows; }; } diff --git a/pkgs/by-name/ca/catt/package.nix b/pkgs/by-name/ca/catt/package.nix index f6bdde3577be67..433b60f53a3629 100644 --- a/pkgs/by-name/ca/catt/package.nix +++ b/pkgs/by-name/ca/catt/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchPypi -, fetchpatch -, python3 +{ + lib, + fetchPypi, + fetchpatch, + python3, }: let diff --git a/pkgs/by-name/ca/caudec/package.nix b/pkgs/by-name/ca/caudec/package.nix index c1fd7acc90bd1c..7d4a971e6b42e8 100644 --- a/pkgs/by-name/ca/caudec/package.nix +++ b/pkgs/by-name/ca/caudec/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, makeWrapper, bc, findutils, flac, lame, opusTools, procps, sox }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + bc, + findutils, + flac, + lame, + opusTools, + procps, + sox, +}: stdenv.mkDerivation rec { pname = "caudec"; @@ -20,16 +32,26 @@ stdenv.mkDerivation rec { ''; postFixup = '' - for executable in $(cd $out/bin && ls); do - wrapProgram $out/bin/$executable \ - --prefix PATH : "${lib.makeBinPath [ bc findutils sox procps opusTools lame flac ]}" - done + for executable in $(cd $out/bin && ls); do + wrapProgram $out/bin/$executable \ + --prefix PATH : "${ + lib.makeBinPath [ + bc + findutils + sox + procps + opusTools + lame + flac + ] + }" + done ''; - meta = with lib; { + meta = with lib; { homepage = "https://caudec.cocatre.net/"; description = "Multiprocess audio converter that supports many formats (FLAC, MP3, Ogg Vorbis, Windows codecs and many more)"; - license = licenses.gpl3; - platforms = platforms.linux ++ platforms.darwin; + license = licenses.gpl3; + platforms = platforms.linux ++ platforms.darwin; }; } diff --git a/pkgs/by-name/ca/cauwugo/package.nix b/pkgs/by-name/ca/cauwugo/package.nix index 1f497a270b939d..45902062bc141a 100644 --- a/pkgs/by-name/ca/cauwugo/package.nix +++ b/pkgs/by-name/ca/cauwugo/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchCrate, installShellFiles, stdenv }: +{ + lib, + rustPlatform, + fetchCrate, + installShellFiles, + stdenv, +}: rustPlatform.buildRustPackage rec { pname = "cauwugo"; @@ -25,7 +31,10 @@ rustPlatform.buildRustPackage rec { description = "Alternative cargo frontend that implements dynamic shell completion for usual cargo commands"; mainProgram = "cauwugo"; homepage = "https://github.com/pacak/bpaf/tree/master/bpaf_cauwugo"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ca/cayley/package.nix b/pkgs/by-name/ca/cayley/package.nix index b5222f41b3b1d9..f6afb01a2e4290 100644 --- a/pkgs/by-name/ca/cayley/package.nix +++ b/pkgs/by-name/ca/cayley/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -19,12 +20,16 @@ buildGoModule rec { subPackages = [ "cmd/cayley" ]; - ldflags = let basename = "github.com/cayleygraph/cayley/version"; in [ - "-s" - "-w" - "-X ${basename}.Version=${src.rev}" - "-X ${basename}.GitHash=${rev}" - ]; + ldflags = + let + basename = "github.com/cayleygraph/cayley/version"; + in + [ + "-s" + "-w" + "-X ${basename}.Version=${src.rev}" + "-X ${basename}.GitHash=${rev}" + ]; meta = with lib; { description = "Graph database designed for ease of use and storing complex data"; diff --git a/pkgs/by-name/cb/cbatticon/package.nix b/pkgs/by-name/cb/cbatticon/package.nix index 12217030063221..69d563edb4bae6 100644 --- a/pkgs/by-name/cb/cbatticon/package.nix +++ b/pkgs/by-name/cb/cbatticon/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, gettext, glib, gtk3, libnotify, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + gettext, + glib, + gtk3, + libnotify, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "cbatticon"; @@ -11,9 +21,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-VQjJujF9lnVvQxV+0YqodLgnI9F90JKDAGBu5nM/Q/c="; }; - nativeBuildInputs = [ pkg-config gettext wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + gettext + wrapGAppsHook3 + ]; - buildInputs = [ glib gtk3 libnotify ]; + buildInputs = [ + glib + gtk3 + libnotify + ]; patchPhase = '' sed -i -e 's/ -Wno-format//g' Makefile diff --git a/pkgs/by-name/cb/cbc/package.nix b/pkgs/by-name/cb/cbc/package.nix index dbe7b6d241ab5c..c96cbc2e7a7d0a 100644 --- a/pkgs/by-name/cb/cbc/package.nix +++ b/pkgs/by-name/cb/cbc/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, zlib, bzip2 }: +{ + lib, + stdenv, + fetchurl, + zlib, + bzip2, +}: stdenv.mkDerivation rec { pname = "cbc"; @@ -13,14 +19,19 @@ stdenv.mkDerivation rec { }; # or-tools has a hard dependency on Cbc static libraries, so we build both - configureFlags = [ "-C" "--enable-static" ] - ++ lib.optionals stdenv.cc.isClang [ "CXXFLAGS=-std=c++14" ]; + configureFlags = [ + "-C" + "--enable-static" + ] ++ lib.optionals stdenv.cc.isClang [ "CXXFLAGS=-std=c++14" ]; enableParallelBuilding = true; hardeningDisable = [ "format" ]; - buildInputs = [ zlib bzip2 ]; + buildInputs = [ + zlib + bzip2 + ]; # FIXME: move share/coin/Data to a separate output? diff --git a/pkgs/by-name/cb/cbfmt/package.nix b/pkgs/by-name/cb/cbfmt/package.nix index 099a2a7f9f87d6..9f803cfbfd83d9 100644 --- a/pkgs/by-name/cb/cbfmt/package.nix +++ b/pkgs/by-name/cb/cbfmt/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, testers, cbfmt }: +{ + lib, + rustPlatform, + fetchFromGitHub, + testers, + cbfmt, +}: rustPlatform.buildRustPackage rec { pname = "cbfmt"; diff --git a/pkgs/by-name/cb/cbftp/package.nix b/pkgs/by-name/cb/cbftp/package.nix index 73e11f27b27764..7e7c99986fabfc 100644 --- a/pkgs/by-name/cb/cbftp/package.nix +++ b/pkgs/by-name/cb/cbftp/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, ncurses -, openssl +{ + lib, + stdenv, + fetchurl, + ncurses, + openssl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cb/cbmbasic/package.nix b/pkgs/by-name/cb/cbmbasic/package.nix index a7d6d841012fa7..0864eea30e1f1b 100644 --- a/pkgs/by-name/cb/cbmbasic/package.nix +++ b/pkgs/by-name/cb/cbmbasic/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, runCommand +{ + lib, + stdenv, + fetchFromGitHub, + runCommand, }: stdenv.mkDerivation (finalAttrs: { @@ -16,34 +17,37 @@ stdenv.mkDerivation (finalAttrs: { }; installPhase = '' - runHook preInstall + runHook preInstall - mkdir -p $out/bin/ - mv cbmbasic $out/bin/ + mkdir -p $out/bin/ + mv cbmbasic $out/bin/ - runHook postInstall + runHook postInstall ''; # NOTE: cbmbasic uses microsoft style linebreaks `\r\n`, and testing has to # accommodate that, else you get very cryptic diffs passthru = { - tests.run = runCommand "cbmbasic-test-run" { - nativeBuildInputs = [finalAttrs.finalPackage]; - } '' - echo '#!${lib.getExe finalAttrs.finalPackage}' > helloI.bas; - echo 'PRINT"Hello, World!"' >> helloI.bas; - chmod +x helloI.bas + tests.run = + runCommand "cbmbasic-test-run" + { + nativeBuildInputs = [ finalAttrs.finalPackage ]; + } + '' + echo '#!${lib.getExe finalAttrs.finalPackage}' > helloI.bas; + echo 'PRINT"Hello, World!"' >> helloI.bas; + chmod +x helloI.bas - diff -U3 --color=auto <(./helloI.bas) <(echo -e "Hello, World!\r"); + diff -U3 --color=auto <(./helloI.bas) <(echo -e "Hello, World!\r"); - echo '#!/usr/bin/env cbmbasic' > hello.bas; - echo 'PRINT"Hello, World!"' >> hello.bas; - chmod +x hello.bas + echo '#!/usr/bin/env cbmbasic' > hello.bas; + echo 'PRINT"Hello, World!"' >> hello.bas; + chmod +x hello.bas - diff -U3 --color=auto <(cbmbasic ./hello.bas) <(echo -e "Hello, World!\r"); + diff -U3 --color=auto <(cbmbasic ./hello.bas) <(echo -e "Hello, World!\r"); - touch $out; - ''; + touch $out; + ''; }; meta = with lib; { @@ -56,7 +60,7 @@ stdenv.mkDerivation (finalAttrs: { This source does not emulate 6502 code; all code is completely native. On a 1 GHz CPU you get about 1000x speed compared to a 1 MHz 6502. ''; - homepage = "https://github.com/mist64/cbmbasic"; + homepage = "https://github.com/mist64/cbmbasic"; license = licenses.bsd2; maintainers = [ maintainers.cafkafk ]; mainProgram = "cbmbasic"; diff --git a/pkgs/by-name/cb/cbonsai/package.nix b/pkgs/by-name/cb/cbonsai/package.nix index 28eb5967315f8e..bad317b1514a78 100644 --- a/pkgs/by-name/cb/cbonsai/package.nix +++ b/pkgs/by-name/cb/cbonsai/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitLab, ncurses, pkg-config, nix-update-script, scdoc }: +{ + stdenv, + lib, + fetchFromGitLab, + ncurses, + pkg-config, + nix-update-script, + scdoc, +}: stdenv.mkDerivation rec { pname = "cbonsai"; @@ -11,7 +19,10 @@ stdenv.mkDerivation rec { hash = "sha256-XFK6DiIb8CzVubTnEMkqRW8xZkX/SWjUsrfS+I7LOs8="; }; - nativeBuildInputs = [ pkg-config scdoc ]; + nativeBuildInputs = [ + pkg-config + scdoc + ]; buildInputs = [ ncurses ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; diff --git a/pkgs/by-name/cb/cbor-diag/gemset.nix b/pkgs/by-name/cb/cbor-diag/gemset.nix index 647be4ab65352d..65789a0348e052 100644 --- a/pkgs/by-name/cb/cbor-diag/gemset.nix +++ b/pkgs/by-name/cb/cbor-diag/gemset.nix @@ -1,81 +1,88 @@ { cbor-canonical = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fhj51s5d9b9spw096sb0p92bgilw9hrsay383563dh913j2jn11"; type = "gem"; }; version = "0.1.2"; }; cbor-deterministic = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1w1mg4mn1dhlxlbijxpzja8m8ggrjs0hzkzvnaazw9zm1ji6dpba"; type = "gem"; }; version = "0.1.3"; }; cbor-diag = { - dependencies = ["cbor-canonical" "cbor-deterministic" "cbor-packed" "json_pure" "neatjson" "treetop"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "cbor-canonical" + "cbor-deterministic" + "cbor-packed" + "json_pure" + "neatjson" + "treetop" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12gicnz857iin9lhbrigyqz4v8fan9lq4sd56rfcb2c7a8azvmz9"; type = "gem"; }; version = "0.8.8"; }; cbor-packed = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dijyj7rivi39h34f32fx7k4xvngldf569i0372n1z6w01nv761l"; type = "gem"; }; version = "0.1.5"; }; json_pure = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13b4dminf6znfwvj8d61w6dar9zrxnndrmiig19adbliv0haxmlr"; type = "gem"; }; version = "2.7.2"; }; neatjson = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wm1lq8yl6rzysh3wg6fa55w5534k6ppiz0qb7jyvdy582mk5i0s"; type = "gem"; }; version = "0.10.5"; }; polyglot = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bqnxwyip623d8pr29rg6m8r0hdg08fpr2yb74f46rn1wgsnxmjr"; type = "gem"; }; version = "0.3.5"; }; treetop = { - dependencies = ["polyglot"]; - groups = ["default"]; - platforms = []; + dependencies = [ "polyglot" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0adc8qblz8ii668r3rksjx83p675iryh52rvdvysimx2hkbasj7d"; type = "gem"; }; diff --git a/pkgs/by-name/cb/cbor-diag/package.nix b/pkgs/by-name/cb/cbor-diag/package.nix index d0fb1a2cffa184..4ff0cb33fcad1c 100644 --- a/pkgs/by-name/cb/cbor-diag/package.nix +++ b/pkgs/by-name/cb/cbor-diag/package.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "cbor-diag"; @@ -27,9 +31,13 @@ bundlerApp { meta = with lib; { description = "CBOR diagnostic utilities"; - homepage = "https://github.com/cabo/cbor-diag"; - license = with licenses; asl20; - maintainers = with maintainers; [ fdns nicknovitski amesgen ]; - platforms = platforms.unix; + homepage = "https://github.com/cabo/cbor-diag"; + license = with licenses; asl20; + maintainers = with maintainers; [ + fdns + nicknovitski + amesgen + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/cb/cbrowser/package.nix b/pkgs/by-name/cb/cbrowser/package.nix index 72a177a17f9346..3c728b4ad5f46f 100644 --- a/pkgs/by-name/cb/cbrowser/package.nix +++ b/pkgs/by-name/cb/cbrowser/package.nix @@ -1,4 +1,10 @@ -{ fetchurl, lib, stdenv, tk, makeWrapper }: +{ + fetchurl, + lib, + stdenv, + tk, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "cbrowser"; diff --git a/pkgs/by-name/cb/cbtemulator/package.nix b/pkgs/by-name/cb/cbtemulator/package.nix index 916d349e633fe9..9fdf25879294f2 100644 --- a/pkgs/by-name/cb/cbtemulator/package.nix +++ b/pkgs/by-name/cb/cbtemulator/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, runCommand -, cbtemulator -, google-cloud-bigtable-tool +{ + lib, + buildGoModule, + fetchFromGitHub, + runCommand, + cbtemulator, + google-cloud-bigtable-tool, }: buildGoModule rec { @@ -32,31 +33,33 @@ buildGoModule rec { passthru = { # Sets up a table and family, then inserts, and ensures it gets back the value. - tests.smoketest = runCommand "cbtemulator-smoketest" - { - nativeBuildInputs = [ google-cloud-bigtable-tool ]; - } '' - # Start the emulator - ${lib.getExe cbtemulator} & - EMULATOR_PID=$! + tests.smoketest = + runCommand "cbtemulator-smoketest" + { + nativeBuildInputs = [ google-cloud-bigtable-tool ]; + } + '' + # Start the emulator + ${lib.getExe cbtemulator} & + EMULATOR_PID=$! - cleanup() { - kill $EMULATOR_PID - } + cleanup() { + kill $EMULATOR_PID + } - trap cleanup EXIT + trap cleanup EXIT - export BIGTABLE_EMULATOR_HOST=localhost:9000 + export BIGTABLE_EMULATOR_HOST=localhost:9000 - cbt -instance instance-1 -project project-1 createtable table-1 - cbt -instance instance-1 -project project-1 createfamily table-1 cf1 - cbt -instance instance-1 -project project-1 ls table-1 - cbt -instance instance-1 -project project-1 set table-1 key1 cf1:c1=value1 + cbt -instance instance-1 -project project-1 createtable table-1 + cbt -instance instance-1 -project project-1 createfamily table-1 cf1 + cbt -instance instance-1 -project project-1 ls table-1 + cbt -instance instance-1 -project project-1 set table-1 key1 cf1:c1=value1 - cbt -instance instance-1 -project project-1 read table-1 | grep -q value1 + cbt -instance instance-1 -project project-1 read table-1 | grep -q value1 - touch $out; - ''; + touch $out; + ''; }; meta = with lib; { diff --git a/pkgs/by-name/cc/cc-tool/package.nix b/pkgs/by-name/cc/cc-tool/package.nix index 5d8e671b6fcd05..941c30a56e93ea 100644 --- a/pkgs/by-name/cc/cc-tool/package.nix +++ b/pkgs/by-name/cc/cc-tool/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, boost -, libusb1 -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + boost, + libusb1, + pkg-config, }: stdenv.mkDerivation rec { @@ -17,8 +19,14 @@ stdenv.mkDerivation rec { hash = "sha256:1f78j498fdd36xbci57jkgh25gq14g3b6xmp76imdpar0jkpyljv"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ boost libusb1 ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + boost + libusb1 + ]; postPatch = '' substituteInPlace udev/90-cc-debugger.rules \ diff --git a/pkgs/by-name/cc/cc1541/package.nix b/pkgs/by-name/cc/cc1541/package.nix index f0f5fd7a02ca9e..e6bc0e56a7d3b1 100644 --- a/pkgs/by-name/cc/cc1541/package.nix +++ b/pkgs/by-name/cc/cc1541/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromBitbucket -, asciidoc +{ + lib, + stdenv, + fetchFromBitbucket, + asciidoc, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/cc/cc2538-bsl/package.nix b/pkgs/by-name/cc/cc2538-bsl/package.nix index a4b3c992544a9c..1716511e545f86 100644 --- a/pkgs/by-name/cc/cc2538-bsl/package.nix +++ b/pkgs/by-name/cc/cc2538-bsl/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, python3Packages +{ + lib, + fetchFromGitHub, + fetchpatch, + python3Packages, }: python3Packages.buildPythonPackage rec { @@ -54,4 +55,3 @@ python3Packages.buildPythonPackage rec { mainProgram = "cc2538-bsl"; }; } - diff --git a/pkgs/by-name/cc/cc65/package.nix b/pkgs/by-name/cc/cc65/package.nix index cb2410ba06a434..1d9a4d582570ec 100644 --- a/pkgs/by-name/cc/cc65/package.nix +++ b/pkgs/by-name/cc/cc65/package.nix @@ -1,4 +1,8 @@ -{ lib, gccStdenv, fetchFromGitHub }: +{ + lib, + gccStdenv, + fetchFromGitHub, +}: gccStdenv.mkDerivation rec { pname = "cc65"; diff --git a/pkgs/by-name/cc/ccal/package.nix b/pkgs/by-name/cc/ccal/package.nix index dd3465669ab79e..31de2947e76320 100644 --- a/pkgs/by-name/cc/ccal/package.nix +++ b/pkgs/by-name/cc/ccal/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchurl -, makeWrapper -, ghostscript_headless # for ps2pdf binary +{ + stdenv, + lib, + fetchurl, + makeWrapper, + ghostscript_headless, # for ps2pdf binary }: stdenv.mkDerivation rec { @@ -15,8 +16,15 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; - makeFlags = [ "CXX:=$(CXX)" "BINDIR=$(out)/bin" "MANDIR=$(out)/share/man" ]; - installTargets = [ "install" "install-man" ]; + makeFlags = [ + "CXX:=$(CXX)" + "BINDIR=$(out)/bin" + "MANDIR=$(out)/share/man" + ]; + installTargets = [ + "install" + "install-man" + ]; # ccalpdf depends on a `ps2pdf` binary in PATH postFixup = '' diff --git a/pkgs/by-name/cc/cccc/package.nix b/pkgs/by-name/cc/cccc/package.nix index b0fd8769bdbe3f..0629cda4e5c8d7 100644 --- a/pkgs/by-name/cc/cccc/package.nix +++ b/pkgs/by-name/cc/cccc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "cccc"; @@ -17,7 +21,10 @@ stdenv.mkDerivation rec { substituteInPlace install/install.mak --replace /usr/local/bin $out/bin substituteInPlace install/install.mak --replace MKDIR=mkdir "MKDIR=mkdir -p" ''; - buildFlags = [ "CCC=c++" "LD=c++" ]; + buildFlags = [ + "CCC=c++" + "LD=c++" + ]; meta = { description = "C and C++ Code Counter"; diff --git a/pkgs/by-name/cc/ccd2iso/package.nix b/pkgs/by-name/cc/ccd2iso/package.nix index 8606614d0186be..60b863bddbcfd2 100644 --- a/pkgs/by-name/cc/ccd2iso/package.nix +++ b/pkgs/by-name/cc/ccd2iso/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ccd2iso"; diff --git a/pkgs/by-name/cc/ccemux/package.nix b/pkgs/by-name/cc/ccemux/package.nix index 0aba58f5f10a6a..b0efaa8b42bb7a 100644 --- a/pkgs/by-name/cc/ccemux/package.nix +++ b/pkgs/by-name/cc/ccemux/package.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchurl, makeDesktopItem, makeWrapper, jre -, useCCTweaked ? true +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + makeWrapper, + jre, + useCCTweaked ? true, }: let @@ -8,21 +14,22 @@ let baseUrl = "https://emux.cc/versions/${lib.substring 0 8 rev}/CCEmuX"; jar = - if useCCTweaked - then fetchurl { - url = "${baseUrl}-cct.jar"; - hash = "sha256-nna5KRp6jVLkbWKOHGtQqaPr3Zl05mVkCf/8X9C5lRY="; - } - else fetchurl { - url = "${baseUrl}-cc.jar"; - hash = "sha256-2Z38O6z7OrHKe8GdLnexin749uJzQaCZglS+SwVD5YE="; - }; + if useCCTweaked then + fetchurl { + url = "${baseUrl}-cct.jar"; + hash = "sha256-nna5KRp6jVLkbWKOHGtQqaPr3Zl05mVkCf/8X9C5lRY="; + } + else + fetchurl { + url = "${baseUrl}-cc.jar"; + hash = "sha256-2Z38O6z7OrHKe8GdLnexin749uJzQaCZglS+SwVD5YE="; + }; desktopIcon = fetchurl { url = "https://github.com/CCEmuX/CCEmuX/raw/${rev}/src/main/resources/img/icon.png"; hash = "sha256-gqWURXaOFD/4aZnjmgtKb0T33NbrOdyRTMmLmV42q+4="; }; - desktopItem = makeDesktopItem { + desktopItem = makeDesktopItem { name = "CCEmuX"; exec = "ccemux"; icon = desktopIcon; @@ -63,7 +70,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/CCEmuX/CCEmuX"; sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.mit; - maintainers = with maintainers; [ CrazedProgrammer viluon ]; + maintainers = with maintainers; [ + CrazedProgrammer + viluon + ]; mainProgram = "ccemux"; }; } diff --git a/pkgs/by-name/cc/cconv/package.nix b/pkgs/by-name/cc/cconv/package.nix index c47b6371d34536..cc739c86ce3be1 100644 --- a/pkgs/by-name/cc/cconv/package.nix +++ b/pkgs/by-name/cc/cconv/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libiconv }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libiconv, +}: stdenv.mkDerivation rec { pname = "cconv"; diff --git a/pkgs/by-name/cc/ccrtp/package.nix b/pkgs/by-name/cc/ccrtp/package.nix index 5fa86a9589d48b..e1177402c00329 100644 --- a/pkgs/by-name/cc/ccrtp/package.nix +++ b/pkgs/by-name/cc/ccrtp/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, ucommon, openssl, libgcrypt }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + ucommon, + openssl, + libgcrypt, +}: stdenv.mkDerivation rec { pname = "ccrtp"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ ucommon openssl libgcrypt ]; + propagatedBuildInputs = [ + ucommon + openssl + libgcrypt + ]; configureFlags = [ "--disable-demos" diff --git a/pkgs/by-name/cc/ccrypt/package.nix b/pkgs/by-name/cc/ccrypt/package.nix index d8fb66753269cd..bdfef537e8a88c 100644 --- a/pkgs/by-name/cc/ccrypt/package.nix +++ b/pkgs/by-name/cc/ccrypt/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, perl}: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "ccrypt"; diff --git a/pkgs/by-name/cc/ccsymbols/package.nix b/pkgs/by-name/cc/ccsymbols/package.nix index f31dc65a8a5680..f3eff1e6432a70 100644 --- a/pkgs/by-name/cc/ccsymbols/package.nix +++ b/pkgs/by-name/cc/ccsymbols/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchurl, unzip }: +{ + lib, + stdenvNoCC, + fetchurl, + unzip, +}: stdenvNoCC.mkDerivation rec { pname = "ccsymbols"; diff --git a/pkgs/by-name/cd/cddl/gemset.nix b/pkgs/by-name/cd/cddl/gemset.nix index 1f19c3920bdf1b..ed326674323c9b 100644 --- a/pkgs/by-name/cd/cddl/gemset.nix +++ b/pkgs/by-name/cd/cddl/gemset.nix @@ -1,142 +1,157 @@ { abnc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yj09gc9w208wsy0d45vzha4zfwxdpsqvkm9vms0chm4lxdwdg9x"; type = "gem"; }; version = "0.1.1"; }; abnftt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1z7ibh0xv9mqk61rvvmz9fnfk6hffvnppqd8fx61vazjhisi9bcs"; type = "gem"; }; version = "0.2.4"; }; base32 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fjs0l3c5g9qxwp43kcnhc45slx29yjb6m6jxbb2x1krgjmi166b"; type = "gem"; }; version = "0.3.4"; }; cbor-canonical = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fhj51s5d9b9spw096sb0p92bgilw9hrsay383563dh913j2jn11"; type = "gem"; }; version = "0.1.2"; }; cbor-deterministic = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1w1mg4mn1dhlxlbijxpzja8m8ggrjs0hzkzvnaazw9zm1ji6dpba"; type = "gem"; }; version = "0.1.3"; }; cbor-diag = { - dependencies = ["cbor-canonical" "cbor-deterministic" "cbor-packed" "json_pure" "neatjson" "treetop"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "cbor-canonical" + "cbor-deterministic" + "cbor-packed" + "json_pure" + "neatjson" + "treetop" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rwd88xngbjamgydj9rg3wvgl53pfzhal2n702s9afa1yp8mjm51"; type = "gem"; }; version = "0.8.7"; }; cbor-packed = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dijyj7rivi39h34f32fx7k4xvngldf569i0372n1z6w01nv761l"; type = "gem"; }; version = "0.1.5"; }; cddl = { - dependencies = ["abnc" "abnftt" "base32" "cbor-diag" "colorize" "json_pure" "regexp-examples"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "abnc" + "abnftt" + "base32" + "cbor-diag" + "colorize" + "json_pure" + "regexp-examples" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qll1qvn3g75r742kr4da7240zdk2qj4vh325965rrjqp8brz23q"; type = "gem"; }; version = "0.10.3"; }; colorize = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dy8ryhcdzgmbvj7jpa1qq3bhhk1m7a2pz6ip0m6dxh30rzj7d9h"; type = "gem"; }; version = "1.1.0"; }; json_pure = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09w7f7xlcas9irlaavhz0rnh17cjvjmmqm07drgghx5gwjcrar31"; type = "gem"; }; version = "2.7.1"; }; neatjson = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wm1lq8yl6rzysh3wg6fa55w5534k6ppiz0qb7jyvdy582mk5i0s"; type = "gem"; }; version = "0.10.5"; }; polyglot = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bqnxwyip623d8pr29rg6m8r0hdg08fpr2yb74f46rn1wgsnxmjr"; type = "gem"; }; version = "0.3.5"; }; regexp-examples = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wfkwczjn62qq3z96dxk43m0gh6d5cajx9pxkanvk88d3yqnx29v"; type = "gem"; }; version = "1.5.1"; }; treetop = { - dependencies = ["polyglot"]; - groups = ["default"]; - platforms = []; + dependencies = [ "polyglot" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0adc8qblz8ii668r3rksjx83p675iryh52rvdvysimx2hkbasj7d"; type = "gem"; }; diff --git a/pkgs/by-name/cd/cddl/package.nix b/pkgs/by-name/cd/cddl/package.nix index 3192a1d4ffbec0..5f67e2c4b83f06 100644 --- a/pkgs/by-name/cd/cddl/package.nix +++ b/pkgs/by-name/cd/cddl/package.nix @@ -1,7 +1,8 @@ -{ lib -, bundlerApp -, bundlerUpdateScript -, makeBinaryWrapper +{ + lib, + bundlerApp, + bundlerUpdateScript, + makeBinaryWrapper, }: bundlerApp rec { @@ -33,9 +34,13 @@ bundlerApp rec { meta = with lib; { description = "Parser, generator, and validator for CDDL"; - homepage = "https://rubygems.org/gems/cddl"; - license = with licenses; mit; - maintainers = with maintainers; [ fdns nicknovitski amesgen ]; - platforms = platforms.unix; + homepage = "https://rubygems.org/gems/cddl"; + license = with licenses; mit; + maintainers = with maintainers; [ + fdns + nicknovitski + amesgen + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/cd/cddlib/package.nix b/pkgs/by-name/cd/cddlib/package.nix index a170a0f92449e8..a745c3a5b42e12 100644 --- a/pkgs/by-name/cd/cddlib/package.nix +++ b/pkgs/by-name/cd/cddlib/package.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, gmp -, autoreconfHook -, texliveSmall +{ + lib, + stdenv, + fetchFromGitHub, + gmp, + autoreconfHook, + texliveSmall, }: stdenv.mkDerivation rec { @@ -14,7 +16,7 @@ stdenv.mkDerivation rec { rev = version; sha256 = "09s8323h5w9j6mpl1yc6lm770dkskfxd2ayyafkcjllmnncxzfa0"; }; - buildInputs = [gmp]; + buildInputs = [ gmp ]; nativeBuildInputs = [ autoreconfHook texliveSmall # for building the documentation diff --git a/pkgs/by-name/cd/cde/package.nix b/pkgs/by-name/cd/cde/package.nix index 8eefb923bcd3e0..d61c888d482bc8 100644 --- a/pkgs/by-name/cd/cde/package.nix +++ b/pkgs/by-name/cd/cde/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libxcrypt }: +{ + lib, + stdenv, + fetchFromGitHub, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "cde"; diff --git a/pkgs/by-name/cd/cdecl/package.nix b/pkgs/by-name/cd/cdecl/package.nix index 07a2656299424a..8819963e50b794 100644 --- a/pkgs/by-name/cd/cdecl/package.nix +++ b/pkgs/by-name/cd/cdecl/package.nix @@ -23,7 +23,12 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; preConfigure = "./bootstrap"; - nativeBuildInputs = [ autoconf automake bison flex ]; + nativeBuildInputs = [ + autoconf + automake + bison + flex + ]; buildInputs = [ readline ]; env = { @@ -55,7 +60,10 @@ stdenv.mkDerivation (finalAttrs: { mkdir -p $out/bin; ''; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; meta = { description = "Composing and deciphering C (or C++) declarations or casts, aka ''gibberish.''"; diff --git a/pkgs/by-name/cd/cdecrypt/package.nix b/pkgs/by-name/cd/cdecrypt/package.nix index 4965eb31e98cc1..2c2e8dcf49709b 100644 --- a/pkgs/by-name/cd/cdecrypt/package.nix +++ b/pkgs/by-name/cd/cdecrypt/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cd/cdesktopenv/package.nix b/pkgs/by-name/cd/cdesktopenv/package.nix index fd8de27b2fde59..55f2ad40ac74a9 100644 --- a/pkgs/by-name/cd/cdesktopenv/package.nix +++ b/pkgs/by-name/cd/cdesktopenv/package.nix @@ -1,11 +1,39 @@ -{ lib, stdenv, fetchurl -, libX11, bison, ksh, perl -, libXinerama, libXt, libXext, libtirpc, motif, libXft, xbitmaps -, libjpeg, libXmu, libXdmcp, libXScrnSaver, bdftopcf -, ncompress, mkfontdir, tcl, libXaw, libxcrypt, glibcLocales -, autoPatchelfHook, makeWrapper, xset, xrdb -, autoreconfHook, opensp, flex, libXpm -, rpcsvc-proto }: +{ + lib, + stdenv, + fetchurl, + libX11, + bison, + ksh, + perl, + libXinerama, + libXt, + libXext, + libtirpc, + motif, + libXft, + xbitmaps, + libjpeg, + libXmu, + libXdmcp, + libXScrnSaver, + bdftopcf, + ncompress, + mkfontdir, + tcl, + libXaw, + libxcrypt, + glibcLocales, + autoPatchelfHook, + makeWrapper, + xset, + xrdb, + autoreconfHook, + opensp, + flex, + libXpm, + rpcsvc-proto, +}: stdenv.mkDerivation rec { pname = "cde"; @@ -40,13 +68,37 @@ stdenv.mkDerivation rec { ''; buildInputs = [ - libX11 libXinerama libXt libXext libtirpc motif libXft xbitmaps - libjpeg libXmu libXdmcp libXScrnSaver tcl libXaw ksh libxcrypt + libX11 + libXinerama + libXt + libXext + libtirpc + motif + libXft + xbitmaps + libjpeg + libXmu + libXdmcp + libXScrnSaver + tcl + libXaw + ksh + libxcrypt libXpm ]; nativeBuildInputs = [ - bison ncompress autoPatchelfHook makeWrapper - autoreconfHook bdftopcf mkfontdir xset xrdb opensp perl flex + bison + ncompress + autoPatchelfHook + makeWrapper + autoreconfHook + bdftopcf + mkfontdir + xset + xrdb + opensp + perl + flex rpcsvc-proto ]; diff --git a/pkgs/by-name/cd/cdi2iso/package.nix b/pkgs/by-name/cd/cdi2iso/package.nix index c6c4c3f3ab35c2..3cf014ad311d36 100644 --- a/pkgs/by-name/cd/cdi2iso/package.nix +++ b/pkgs/by-name/cd/cdi2iso/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "cdi2iso"; diff --git a/pkgs/by-name/cd/cdimgtools/package.nix b/pkgs/by-name/cd/cdimgtools/package.nix index 37951654c7b9bc..c7eb90c088e65d 100644 --- a/pkgs/by-name/cd/cdimgtools/package.nix +++ b/pkgs/by-name/cd/cdimgtools/package.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchFromRepoOrCz, autoreconfHook, makeWrapper, libdvdcss, libdvdread, perl, perlPackages, asciidoc, xmlto, sourceHighlight, docbook_xsl, docbook_xml_dtd_45 }: +{ + lib, + stdenv, + fetchFromRepoOrCz, + autoreconfHook, + makeWrapper, + libdvdcss, + libdvdread, + perl, + perlPackages, + asciidoc, + xmlto, + sourceHighlight, + docbook_xsl, + docbook_xml_dtd_45, +}: stdenv.mkDerivation { pname = "cdimgtools"; @@ -10,11 +25,29 @@ stdenv.mkDerivation { hash = "sha256-HFlXGmi6YcYP+ZAdu79lJHLBmtMEhW17gs4I2ekbr8M="; }; - nativeBuildInputs = [ autoreconfHook makeWrapper asciidoc perlPackages.PodPerldoc xmlto sourceHighlight docbook_xsl docbook_xml_dtd_45 ]; + nativeBuildInputs = [ + autoreconfHook + makeWrapper + asciidoc + perlPackages.PodPerldoc + xmlto + sourceHighlight + docbook_xsl + docbook_xml_dtd_45 + ]; - buildInputs = [ perl perlPackages.StringEscape perlPackages.DataHexdumper libdvdcss libdvdread ]; + buildInputs = [ + perl + perlPackages.StringEscape + perlPackages.DataHexdumper + libdvdcss + libdvdread + ]; - patches = [ ./nrgtool_fix_my.patch ./removed_dvdcss_interface_2.patch]; + patches = [ + ./nrgtool_fix_my.patch + ./removed_dvdcss_interface_2.patch + ]; postFixup = '' for cmd in raw96cdconv nrgtool; do @@ -22,9 +55,15 @@ stdenv.mkDerivation { done ''; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; - installTargets = [ "install" "install-doc" ]; + installTargets = [ + "install" + "install-doc" + ]; meta = with lib; { homepage = "https://repo.or.cz/cdimgtools.git/blob_plain/refs/heads/release:/README.html"; diff --git a/pkgs/by-name/cd/cdk-go/package.nix b/pkgs/by-name/cd/cdk-go/package.nix index b7561f27ecbe82..02bd3a04453828 100644 --- a/pkgs/by-name/cd/cdk-go/package.nix +++ b/pkgs/by-name/cd/cdk-go/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/cd/cdk/package.nix b/pkgs/by-name/cd/cdk/package.nix index 2d4968e5ce5878..c3fff25e35a8ad 100644 --- a/pkgs/by-name/cd/cdk/package.nix +++ b/pkgs/by-name/cd/cdk/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, ncurses +{ + lib, + stdenv, + fetchurl, + ncurses, }: stdenv.mkDerivation (finalAttrs: { @@ -25,7 +26,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://invisible-island.net/cdk/"; changelog = "https://invisible-island.net/cdk/CHANGES.html"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ raskin AndersonTorres ]; + maintainers = with lib.maintainers; [ + raskin + AndersonTorres + ]; inherit (ncurses.meta) platforms; }; }) diff --git a/pkgs/by-name/cd/cdncheck/package.nix b/pkgs/by-name/cd/cdncheck/package.nix index 52f28bf9a851c4..b18d0625a29155 100644 --- a/pkgs/by-name/cd/cdncheck/package.nix +++ b/pkgs/by-name/cd/cdncheck/package.nix @@ -19,7 +19,6 @@ buildGoModule rec { subPackages = [ "cmd/cdncheck/" ]; - ldflags = [ "-s" "-w" diff --git a/pkgs/by-name/cd/cdo/package.nix b/pkgs/by-name/cd/cdo/package.nix index 3c63b23d1ce28d..886aa98be83d9e 100644 --- a/pkgs/by-name/cd/cdo/package.nix +++ b/pkgs/by-name/cd/cdo/package.nix @@ -1,10 +1,18 @@ -{ lib, stdenv, fetchurl, curl, hdf5, netcdf, eccodes, python3 -, # build, install and link to a CDI library [default=no] - enable_cdi_lib ? false -, # build a completely statically linked CDO binary - enable_all_static ? stdenv.hostPlatform.isStatic -, # Use CXX as default compiler [default=no] - enable_cxx ? false +{ + lib, + stdenv, + fetchurl, + curl, + hdf5, + netcdf, + eccodes, + python3, + # build, install and link to a CDI library [default=no] + enable_cdi_lib ? false, + # build a completely statically linked CDO binary + enable_all_static ? stdenv.hostPlatform.isStatic, + # Use CXX as default compiler [default=no] + enable_cxx ? false, }: stdenv.mkDerivation rec { @@ -12,21 +20,27 @@ stdenv.mkDerivation rec { version = "2.4.2"; # Dependencies - buildInputs = [ curl netcdf hdf5 python3 ]; + buildInputs = [ + curl + netcdf + hdf5 + python3 + ]; src = fetchurl { url = "https://code.mpimet.mpg.de/attachments/download/29481/${pname}-${version}.tar.gz"; sha256 = "sha256-TfH+K4+S9Uwn6585nt+rQNkyIAWmcyyhUk71wWJ6xOc="; }; - configureFlags = [ - "--with-netcdf=${netcdf}" - "--with-hdf5=${hdf5}" - "--with-eccodes=${eccodes}" - ] - ++ lib.optional enable_cdi_lib "--enable-cdi-lib" - ++ lib.optional enable_all_static "--enable-all-static" - ++ lib.optional enable_cxx "--enable-cxx"; + configureFlags = + [ + "--with-netcdf=${netcdf}" + "--with-hdf5=${hdf5}" + "--with-eccodes=${eccodes}" + ] + ++ lib.optional enable_cdi_lib "--enable-cdi-lib" + ++ lib.optional enable_all_static "--enable-all-static" + ++ lib.optional enable_cxx "--enable-cxx"; # address error: 'TARGET_OS_MACCATALYST' is not defined, # evaluates to 0 [-Werror,-Wundef-prefix=TARGET_OS_] diff --git a/pkgs/by-name/cd/cdpr/package.nix b/pkgs/by-name/cd/cdpr/package.nix index 5e86d58cfb3119..8ccf2b1788a47a 100644 --- a/pkgs/by-name/cd/cdpr/package.nix +++ b/pkgs/by-name/cd/cdpr/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libpcap }: +{ + lib, + stdenv, + fetchurl, + libpcap, +}: stdenv.mkDerivation rec { pname = "cdpr"; diff --git a/pkgs/by-name/cd/cdrkit/package.nix b/pkgs/by-name/cd/cdrkit/package.nix index 7aa400e51f07dd..319ba72cb54a97 100644 --- a/pkgs/by-name/cd/cdrkit/package.nix +++ b/pkgs/by-name/cd/cdrkit/package.nix @@ -1,4 +1,13 @@ -{lib, stdenv, fetchurl, cmake, libcap, zlib, bzip2, perl}: +{ + lib, + stdenv, + fetchurl, + cmake, + libcap, + zlib, + bzip2, + perl, +}: stdenv.mkDerivation rec { pname = "cdrkit"; @@ -10,19 +19,29 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ zlib bzip2 perl ] ++ - lib.optionals stdenv.hostPlatform.isLinux [ libcap ]; + buildInputs = [ + zlib + bzip2 + perl + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libcap ]; hardeningDisable = [ "format" ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isMusl [ - "-D__THROW=" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-error=int-conversion" - "-Wno-error=implicit-function-declaration" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isMusl [ + "-D__THROW=" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-error=int-conversion" + "-Wno-error=implicit-function-declaration" + ] + ); # efi-boot-patch extracted from http://arm.koji.fedoraproject.org/koji/rpminfo?rpmID=174244 - patches = [ ./include-path.patch ./cdrkit-1.1.9-efi-boot.patch ./cdrkit-1.1.11-fno-common.patch ]; + patches = [ + ./include-path.patch + ./cdrkit-1.1.9-efi-boot.patch + ./cdrkit-1.1.11-fno-common.patch + ]; postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' substituteInPlace libusal/scsi-mac-iokit.c \ diff --git a/pkgs/by-name/cd/cdwe/package.nix b/pkgs/by-name/cd/cdwe/package.nix index b891daee2980ce..72d3479d45123b 100644 --- a/pkgs/by-name/cd/cdwe/package.nix +++ b/pkgs/by-name/cd/cdwe/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ce/cegui/package.nix b/pkgs/by-name/ce/cegui/package.nix index e92ddafc4322f9..cf7c9707744f0f 100644 --- a/pkgs/by-name/ce/cegui/package.nix +++ b/pkgs/by-name/ce/cegui/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ogre -, freetype -, boost -, expat -, darwin -, libiconv -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ogre, + freetype, + boost, + expat, + darwin, + libiconv, + unstableGitUpdater, }: stdenv.mkDerivation { @@ -28,22 +29,26 @@ stdenv.mkDerivation { cmake ]; - buildInputs = [ - ogre - freetype - boost - expat - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Cocoa - darwin.apple_sdk.frameworks.Foundation - libiconv - ]; + buildInputs = + [ + ogre + freetype + boost + expat + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Cocoa + darwin.apple_sdk.frameworks.Foundation + libiconv + ]; - cmakeFlags = [ - "-DCEGUI_OPTION_DEFAULT_IMAGECODEC=OgreRenderer-0" - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ - "-DCMAKE_OSX_ARCHITECTURES=${stdenv.hostPlatform.darwinArch}" - ]; + cmakeFlags = + [ + "-DCEGUI_OPTION_DEFAULT_IMAGECODEC=OgreRenderer-0" + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ + "-DCMAKE_OSX_ARCHITECTURES=${stdenv.hostPlatform.darwinArch}" + ]; passthru.updateScript = unstableGitUpdater { branch = "v0"; diff --git a/pkgs/by-name/ce/cel-go/package.nix b/pkgs/by-name/ce/cel-go/package.nix index 3da3e1be2d621d..e4c1fdaba998e5 100644 --- a/pkgs/by-name/ce/cel-go/package.nix +++ b/pkgs/by-name/ce/cel-go/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -22,7 +23,10 @@ buildGoModule rec { "main" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' mv $out/bin/{main,cel-go} diff --git a/pkgs/by-name/ce/celeste-classic/package.nix b/pkgs/by-name/ce/celeste-classic/package.nix index f862c1b7a5a2fd..963d28651d6257 100644 --- a/pkgs/by-name/ce/celeste-classic/package.nix +++ b/pkgs/by-name/ce/celeste-classic/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, fetchzip -, autoPatchelfHook -, SDL2 -, practiceMod ? false +{ + lib, + stdenvNoCC, + fetchzip, + autoPatchelfHook, + SDL2, + practiceMod ? false, }: let diff --git a/pkgs/by-name/ce/celeste/package.nix b/pkgs/by-name/ce/celeste/package.nix index b1a946f244f931..efb0b5458c9f68 100644 --- a/pkgs/by-name/ce/celeste/package.nix +++ b/pkgs/by-name/ce/celeste/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, darwin -, just -, pkg-config -, wrapGAppsHook4 -, cairo -, dbus -, gdk-pixbuf -, glib -, graphene -, gtk4 -, libadwaita -, librclone -, pango -, rclone +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + darwin, + just, + pkg-config, + wrapGAppsHook4, + cairo, + dbus, + gdk-pixbuf, + glib, + graphene, + gtk4, + libadwaita, + librclone, + pango, + rclone, }: rustPlatform.buildRustPackage rec { @@ -56,24 +57,28 @@ rustPlatform.buildRustPackage rec { wrapGAppsHook4 ]; - buildInputs = [ - cairo - dbus - gdk-pixbuf - glib - graphene - gtk4 - libadwaita - librclone - pango - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + cairo + dbus + gdk-pixbuf + glib + graphene + gtk4 + libadwaita + librclone + pango + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + darwin.apple_sdk.frameworks.Security + ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-Wno-error=incompatible-function-pointer-types" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-Wno-error=incompatible-function-pointer-types" + ] + ); preFixup = '' gappsWrapperArgs+=( diff --git a/pkgs/by-name/ce/celf/package.nix b/pkgs/by-name/ce/celf/package.nix index e1f0c237f6732a..7c485c9aab6151 100644 --- a/pkgs/by-name/ce/celf/package.nix +++ b/pkgs/by-name/ce/celf/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, smlnj }: +{ + lib, + stdenv, + fetchFromGitHub, + smlnj, +}: stdenv.mkDerivation rec { pname = "celf"; @@ -6,9 +11,9 @@ stdenv.mkDerivation rec { name = "${pname}-${pversion}"; src = fetchFromGitHub { - owner = "clf"; - repo = pname; - rev = "d61d95900ab316468ae850fa34a2fe9488bc5b59"; + owner = "clf"; + repo = pname; + rev = "d61d95900ab316468ae850fa34a2fe9488bc5b59"; sha256 = "0slrwcxglp0sdbp6wr65cdkl5wcap2i0fqxbwqfi1q3cpb6ph6hq"; }; diff --git a/pkgs/by-name/ce/celluloid/package.nix b/pkgs/by-name/ce/celluloid/package.nix index 4b8743c90952d4..35f1841c4ab450 100644 --- a/pkgs/by-name/ce/celluloid/package.nix +++ b/pkgs/by-name/ce/celluloid/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, appstream-glib -, desktop-file-utils -, glib -, gtk4 -, libGL -, libepoxy -, libadwaita -, meson -, mpv -, ninja -, nix-update-script -, pkg-config -, python3 -, wrapGAppsHook4 -, yt-dlp -, youtubeSupport ? true +{ + lib, + stdenv, + fetchFromGitHub, + appstream-glib, + desktop-file-utils, + glib, + gtk4, + libGL, + libepoxy, + libadwaita, + meson, + mpv, + ninja, + nix-update-script, + pkg-config, + python3, + wrapGAppsHook4, + yt-dlp, + youtubeSupport ? true, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ce/cen64/package.nix b/pkgs/by-name/ce/cen64/package.nix index d9c0048b7b34b8..1a2450ee63040b 100644 --- a/pkgs/by-name/ce/cen64/package.nix +++ b/pkgs/by-name/ce/cen64/package.nix @@ -1,4 +1,13 @@ -{ lib, cmake, fetchFromGitHub, libGL, libiconv, libX11, openal, stdenv }: +{ + lib, + cmake, + fetchFromGitHub, + libGL, + libiconv, + libX11, + openal, + stdenv, +}: stdenv.mkDerivation rec { pname = "cen64"; @@ -12,7 +21,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libGL libiconv openal libX11 ]; + buildInputs = [ + libGL + libiconv + openal + libX11 + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/ce/centerim/package.nix b/pkgs/by-name/ce/centerim/package.nix index 2e4dc6dbb55ea9..44abb6a12e6ab0 100644 --- a/pkgs/by-name/ce/centerim/package.nix +++ b/pkgs/by-name/ce/centerim/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchurl, gnused, openssl, curl, ncurses, libjpeg -, withGpg ? true, gpgme ? null}: +{ + lib, + stdenv, + fetchurl, + gnused, + openssl, + curl, + ncurses, + libjpeg, + withGpg ? true, + gpgme ? null, +}: stdenv.mkDerivation rec { version = "5.0.1"; @@ -12,8 +22,12 @@ stdenv.mkDerivation rec { CXXFLAGS = "-std=gnu++98"; - buildInputs = [ openssl curl ncurses libjpeg ] - ++ lib.optional withGpg gpgme; + buildInputs = [ + openssl + curl + ncurses + libjpeg + ] ++ lib.optional withGpg gpgme; preConfigure = '' ${gnused}/bin/sed -i '1,1i#include ' libicq2000/libicq2000/sigslot.h diff --git a/pkgs/by-name/ce/centerpiece/package.nix b/pkgs/by-name/ce/centerpiece/package.nix index 7d7c7512d8760d..867b4d6ddcb75c 100644 --- a/pkgs/by-name/ce/centerpiece/package.nix +++ b/pkgs/by-name/ce/centerpiece/package.nix @@ -1,14 +1,16 @@ -{ lib -, stdenv -, pkg-config -, dbus -, vulkan-loader -, libGL -, fetchFromGitHub -, rustPlatform -, libxkbcommon -, wayland -, enableX11 ? true, xorg +{ + lib, + stdenv, + pkg-config, + dbus, + vulkan-loader, + libGL, + fetchFromGitHub, + rustPlatform, + libxkbcommon, + wayland, + enableX11 ? true, + xorg, }: rustPlatform.buildRustPackage rec { @@ -25,18 +27,23 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-d5qGuQ8EnIkE/PhI9t4JxtnNbvh3rse9NpowZ+ESZuU="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - dbus - libGL - libxkbcommon - vulkan-loader - wayland - ] ++ lib.optionals enableX11 (with xorg; [ - libX11 - libXcursor - libXi - libXrandr - ]); + buildInputs = + [ + dbus + libGL + libxkbcommon + vulkan-loader + wayland + ] + ++ lib.optionals enableX11 ( + with xorg; + [ + libX11 + libXcursor + libXi + libXrandr + ] + ); postFixup = lib.optional stdenv.hostPlatform.isLinux '' rpath=$(patchelf --print-rpath $out/bin/centerpiece) @@ -54,7 +61,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/friedow/centerpiece"; description = "Your trusty omnibox search"; license = licenses.mit; - maintainers = with maintainers; [ a-kenji friedow ]; + maintainers = with maintainers; [ + a-kenji + friedow + ]; platforms = platforms.linux; mainProgram = "centerpiece"; }; diff --git a/pkgs/by-name/ce/cereal_1_3_0/package.nix b/pkgs/by-name/ce/cereal_1_3_0/package.nix index 9cd1e04d8f4db8..d1fb82a6267db2 100644 --- a/pkgs/by-name/ce/cereal_1_3_0/package.nix +++ b/pkgs/by-name/ce/cereal_1_3_0/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ce/cereal_1_3_2/package.nix b/pkgs/by-name/ce/cereal_1_3_2/package.nix index adf796cfe5b4f1..eaf481144c2c00 100644 --- a/pkgs/by-name/ce/cereal_1_3_2/package.nix +++ b/pkgs/by-name/ce/cereal_1_3_2/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ce/cernlib/package.nix b/pkgs/by-name/ce/cernlib/package.nix index 0673aeefffb1de..264ae7b59e21a0 100644 --- a/pkgs/by-name/ce/cernlib/package.nix +++ b/pkgs/by-name/ce/cernlib/package.nix @@ -45,17 +45,20 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ cmake ]; - buildInputs = with xorg; [ - freetype - gfortran - openssl - libX11 - libXaw - libXft - libXt - libxcrypt - motif - ] ++ lib.optional stdenv.hostPlatform.isLinux libnsl; + buildInputs = + with xorg; + [ + freetype + gfortran + openssl + libX11 + libXaw + libXft + libXt + libxcrypt + motif + ] + ++ lib.optional stdenv.hostPlatform.isLinux libnsl; setupHook = ./setup-hook.sh; diff --git a/pkgs/by-name/ce/cert-viewer/package.nix b/pkgs/by-name/ce/cert-viewer/package.nix index 6cd594e13d6c97..85f16a1a419c03 100644 --- a/pkgs/by-name/ce/cert-viewer/package.nix +++ b/pkgs/by-name/ce/cert-viewer/package.nix @@ -1,9 +1,10 @@ -{ buildGoModule -, buildPackages -, fetchFromGitHub -, lib -, installShellFiles -, stdenv +{ + buildGoModule, + buildPackages, + fetchFromGitHub, + lib, + installShellFiles, + stdenv, }: buildGoModule rec { @@ -26,14 +27,15 @@ buildGoModule rec { postInstall = let prog = - if stdenv.buildPlatform.canExecute stdenv.hostPlatform - then "$out/bin/cert-viewer" - else lib.getExe buildPackages.cert-viewer; + if stdenv.buildPlatform.canExecute stdenv.hostPlatform then + "$out/bin/cert-viewer" + else + lib.getExe buildPackages.cert-viewer; in - '' - ${prog} --help-man > cert-viewer.1 - installManPage cert-viewer.1 - ''; + '' + ${prog} --help-man > cert-viewer.1 + installManPage cert-viewer.1 + ''; meta = { description = "Admin tool to view and inspect multiple x509 Certificates"; diff --git a/pkgs/by-name/ce/certgraph/package.nix b/pkgs/by-name/ce/certgraph/package.nix index 3af3078d6b8b1c..7f5eac96c4e525 100644 --- a/pkgs/by-name/ce/certgraph/package.nix +++ b/pkgs/by-name/ce/certgraph/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ce/certi/package.nix b/pkgs/by-name/ce/certi/package.nix index 90e929114b4d17..d2a57932b99241 100644 --- a/pkgs/by-name/ce/certi/package.nix +++ b/pkgs/by-name/ce/certi/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ce/certificate-ripper/package.nix b/pkgs/by-name/ce/certificate-ripper/package.nix index 72cdd6787a9379..ea76132ab5b72b 100644 --- a/pkgs/by-name/ce/certificate-ripper/package.nix +++ b/pkgs/by-name/ce/certificate-ripper/package.nix @@ -1,7 +1,8 @@ -{ lib -, maven -, fetchFromGitHub -, buildGraalvmNativeImage +{ + lib, + maven, + fetchFromGitHub, + buildGraalvmNativeImage, }: let diff --git a/pkgs/by-name/ce/certigo/package.nix b/pkgs/by-name/ce/certigo/package.nix index aec517a20fe4b2..bf5286c1a6936d 100644 --- a/pkgs/by-name/ce/certigo/package.nix +++ b/pkgs/by-name/ce/certigo/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "certigo"; diff --git a/pkgs/by-name/ce/certinfo/package.nix b/pkgs/by-name/ce/certinfo/package.nix index f8ec56585c4f11..073c6ce3ed9c59 100644 --- a/pkgs/by-name/ce/certinfo/package.nix +++ b/pkgs/by-name/ce/certinfo/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, buildGo123Module, fetchFromGitHub, libX11, darwin }: +{ + stdenv, + lib, + buildGo123Module, + fetchFromGitHub, + libX11, + darwin, +}: buildGo123Module rec { pname = "certinfo"; @@ -14,7 +21,8 @@ buildGo123Module rec { # clipboard functionality not working on Darwin doCheck = !(stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64); - buildInputs = [ ] + buildInputs = + [ ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libX11 ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Cocoa ]; diff --git a/pkgs/by-name/ce/certspotter/package.nix b/pkgs/by-name/ce/certspotter/package.nix index 72cb1e54c0b8f8..51993f07cd4e4f 100644 --- a/pkgs/by-name/ce/certspotter/package.nix +++ b/pkgs/by-name/ce/certspotter/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, lowdown-unsandboxed +{ + lib, + fetchFromGitHub, + buildGoModule, + lowdown-unsandboxed, }: buildGoModule rec { @@ -17,7 +18,10 @@ buildGoModule rec { vendorHash = "sha256-6dV9FoPV8UfS0z5RuuopE99fHcT3RAWCdDi7jpHzVRE="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeBuildInputs = [ lowdown-unsandboxed ]; diff --git a/pkgs/by-name/ce/certstrap/package.nix b/pkgs/by-name/ce/certstrap/package.nix index 2537d1ecbbfec0..3cc981bf68a6fe 100644 --- a/pkgs/by-name/ce/certstrap/package.nix +++ b/pkgs/by-name/ce/certstrap/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ce/certsync/package.nix b/pkgs/by-name/ce/certsync/package.nix index e12868ac7f9c89..0aa95f40d137cd 100644 --- a/pkgs/by-name/ce/certsync/package.nix +++ b/pkgs/by-name/ce/certsync/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ce/cewler/package.nix b/pkgs/by-name/ce/cewler/package.nix index 92399307e6a776..a146ef653f648a 100644 --- a/pkgs/by-name/ce/cewler/package.nix +++ b/pkgs/by-name/ce/cewler/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, gitUpdater +{ + lib, + python3, + fetchFromGitHub, + gitUpdater, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/cf/cf-terraforming/package.nix b/pkgs/by-name/cf/cf-terraforming/package.nix index 5eb7ed9e914c14..2ad714e935ff19 100644 --- a/pkgs/by-name/cf/cf-terraforming/package.nix +++ b/pkgs/by-name/cf/cf-terraforming/package.nix @@ -1,4 +1,12 @@ -{ buildGoModule, fetchFromGitHub, lib, cf-terraforming, testers, installShellFiles, stdenv }: +{ + buildGoModule, + fetchFromGitHub, + lib, + cf-terraforming, + testers, + installShellFiles, + stdenv, +}: buildGoModule rec { pname = "cf-terraforming"; @@ -12,7 +20,9 @@ buildGoModule rec { }; vendorHash = "sha256-NNeJ6QfTV8X3WIFge+Ln38ym9uagLl3IpNWuPqMjeBA="; - ldflags = [ "-X github.com/cloudflare/cf-terraforming/internal/app/cf-terraforming/cmd.versionString=${version}" ]; + ldflags = [ + "-X github.com/cloudflare/cf-terraforming/internal/app/cf-terraforming/cmd.versionString=${version}" + ]; # The test suite insists on downloading a binary release of Terraform from # Hashicorp at runtime, which isn't going to work in a nix build @@ -25,7 +35,7 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform)'' + postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' installShellCompletion --cmd cf-terraforming \ --bash <($out/bin/cf-terraforming completion bash) \ --fish <($out/bin/cf-terraforming completion fish) \ diff --git a/pkgs/by-name/cf/cf-vault/package.nix b/pkgs/by-name/cf/cf-vault/package.nix index 0a5e805a51db17..47f49ab1b817a0 100644 --- a/pkgs/by-name/cf/cf-vault/package.nix +++ b/pkgs/by-name/cf/cf-vault/package.nix @@ -1,4 +1,10 @@ -{buildGoModule, fetchFromGitHub, lib, testers, cf-vault}: +{ + buildGoModule, + fetchFromGitHub, + lib, + testers, + cf-vault, +}: buildGoModule rec { pname = "cf-vault"; version = "0.0.18"; diff --git a/pkgs/by-name/cf/cfdg/package.nix b/pkgs/by-name/cf/cfdg/package.nix index 496255c57953b7..77077e01acb9c2 100644 --- a/pkgs/by-name/cf/cfdg/package.nix +++ b/pkgs/by-name/cf/cfdg/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, libpng, bison, flex, ffmpeg, icu }: +{ + lib, + stdenv, + fetchFromGitHub, + libpng, + bison, + flex, + ffmpeg, + icu, +}: stdenv.mkDerivation rec { pname = "cfdg"; @@ -10,8 +19,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-f2VMb0TM50afKf/lGdZBP2z13UrCVgG4/IYi5gnD+ow="; }; - nativeBuildInputs = [ bison flex ]; - buildInputs = [ libpng ffmpeg icu ]; + nativeBuildInputs = [ + bison + flex + ]; + buildInputs = [ + libpng + ffmpeg + icu + ]; postPatch = '' sed -e "/YY_NO_UNISTD/a#include " -i src-common/cfdg.l diff --git a/pkgs/by-name/cf/cfdyndns/package.nix b/pkgs/by-name/cf/cfdyndns/package.nix index 9659e9777a2e97..8ee036e18f1af0 100644 --- a/pkgs/by-name/cf/cfdyndns/package.nix +++ b/pkgs/by-name/cf/cfdyndns/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, rustPlatform, pkg-config, openssl }: +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, +}: rustPlatform.buildRustPackage rec { pname = "cfdyndns"; @@ -22,7 +28,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "cfdyndns"; homepage = "https://github.com/nrdxp/cfdyndns"; license = lib.licenses.mit; - maintainers = with maintainers; [ colemickens nrdxp ]; + maintainers = with maintainers; [ + colemickens + nrdxp + ]; platforms = with platforms; linux; }; } diff --git a/pkgs/by-name/cf/cfitsio/package.nix b/pkgs/by-name/cf/cfitsio/package.nix index a12e00f9676d53..3cc37833a80bd9 100644 --- a/pkgs/by-name/cf/cfitsio/package.nix +++ b/pkgs/by-name/cf/cfitsio/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchurl -, bzip2 -, curl -, zlib +{ + stdenv, + lib, + fetchurl, + bzip2, + curl, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -53,7 +54,10 @@ stdenv.mkDerivation (finalAttrs: { ''; changelog = "https://heasarc.gsfc.nasa.gov/FTP/software/fitsio/c/docs/changes.txt"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ xbreak hjones2199 ]; + maintainers = with lib.maintainers; [ + xbreak + hjones2199 + ]; platforms = lib.platforms.linux ++ lib.platforms.darwin; }; }) diff --git a/pkgs/by-name/cf/cflow/package.nix b/pkgs/by-name/cf/cflow/package.nix index a1a116b46d07ac..b8d5ad52753211 100644 --- a/pkgs/by-name/cf/cflow/package.nix +++ b/pkgs/by-name/cf/cflow/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, gettext, emacs }: +{ + lib, + stdenv, + fetchurl, + gettext, + emacs, +}: stdenv.mkDerivation rec { pname = "cflow"; @@ -15,12 +21,11 @@ stdenv.mkDerivation rec { "$(cat ${stdenv.cc}/nix-support/orig-cc)/bin/cpp" ''; - buildInputs = [ gettext ] ++ + buildInputs = + [ gettext ] + ++ # We don't have Emacs/GTK/etc. on {Dar,Cyg}win. - lib.optional - (! (lib.lists.any (x: stdenv.hostPlatform.system == x) - [ "i686-cygwin" ])) - emacs; + lib.optional (!(lib.lists.any (x: stdenv.hostPlatform.system == x) [ "i686-cygwin" ])) emacs; doCheck = true; diff --git a/pkgs/by-name/cf/cfm/package.nix b/pkgs/by-name/cf/cfm/package.nix index 640067d527f2d5..06c51f957769c0 100644 --- a/pkgs/by-name/cf/cfm/package.nix +++ b/pkgs/by-name/cf/cfm/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cf/cfonts/package.nix b/pkgs/by-name/cf/cfonts/package.nix index 12d9687c59be7f..2ec26c040b69bb 100644 --- a/pkgs/by-name/cf/cfonts/package.nix +++ b/pkgs/by-name/cf/cfonts/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "cfonts"; version = "1.1.3"; @@ -12,8 +16,7 @@ rustPlatform.buildRustPackage rec { meta = with lib; { homepage = "https://github.com/dominikwilkowski/cfonts"; - description = - "A silly little command line tool for sexy ANSI fonts in the console"; + description = "A silly little command line tool for sexy ANSI fonts in the console"; license = licenses.gpl3Plus; maintainers = with maintainers; [ leifhelm ]; mainProgram = "cfonts"; diff --git a/pkgs/by-name/cf/cfr/package.nix b/pkgs/by-name/cf/cfr/package.nix index 9604b8df2ff187..f6eec5e8cdb061 100644 --- a/pkgs/by-name/cf/cfr/package.nix +++ b/pkgs/by-name/cf/cfr/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, makeWrapper, fetchurl, jre }: +{ + lib, + stdenv, + makeWrapper, + fetchurl, + jre, +}: stdenv.mkDerivation rec { pname = "cfr"; diff --git a/pkgs/by-name/cf/cfripper/package.nix b/pkgs/by-name/cf/cfripper/package.nix index f3e901999cea43..f2d0f138aa8d91 100644 --- a/pkgs/by-name/cf/cfripper/package.nix +++ b/pkgs/by-name/cf/cfripper/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/cf/cfs-zen-tweaks/package.nix b/pkgs/by-name/cf/cfs-zen-tweaks/package.nix index d7a06ed6e737fa..509978486d46f2 100644 --- a/pkgs/by-name/cf/cfs-zen-tweaks/package.nix +++ b/pkgs/by-name/cf/cfs-zen-tweaks/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, makeWrapper -, gawk +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + makeWrapper, + gawk, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cf/cfspeedtest/package.nix b/pkgs/by-name/cf/cfspeedtest/package.nix index 2b64a5946a4239..b9010abb2567f5 100644 --- a/pkgs/by-name/cf/cfspeedtest/package.nix +++ b/pkgs/by-name/cf/cfspeedtest/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/cf/cfssl/package.nix b/pkgs/by-name/cf/cfssl/package.nix index df13c004b1a741..8d18fe922bd3ff 100644 --- a/pkgs/by-name/cf/cfssl/package.nix +++ b/pkgs/by-name/cf/cfssl/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "cfssl"; @@ -27,7 +32,8 @@ buildGoModule rec { doCheck = false; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/cloudflare/cfssl/cli/version.version=v${version}" ]; diff --git a/pkgs/by-name/cg/cg3/package.nix b/pkgs/by-name/cg/cg3/package.nix index 8aa0d412c1cf3b..3cfe7de5f09f22 100644 --- a/pkgs/by-name/cg/cg3/package.nix +++ b/pkgs/by-name/cg/cg3/package.nix @@ -1,66 +1,70 @@ -{ lib -, stdenv -, fetchFromGitHub -, runCommand -, dieHook -, cmake -, icu -, boost +{ + lib, + stdenv, + fetchFromGitHub, + runCommand, + dieHook, + cmake, + icu, + boost, }: -let cg3 = stdenv.mkDerivation rec { - pname = "cg3"; - version = "1.3.9"; +let + cg3 = stdenv.mkDerivation rec { + pname = "cg3"; + version = "1.3.9"; - src = fetchFromGitHub { - owner = "GrammarSoft"; - repo = "${pname}"; - rev = "v${version}"; - sha256 = "sha256-TiEhhk90w5GibGZ4yalIf+4qLA8NoU6+GIPN6QNTz2A="; - }; - - nativeBuildInputs = [ - cmake - ]; + src = fetchFromGitHub { + owner = "GrammarSoft"; + repo = "${pname}"; + rev = "v${version}"; + sha256 = "sha256-TiEhhk90w5GibGZ4yalIf+4qLA8NoU6+GIPN6QNTz2A="; + }; - buildInputs = [ - icu - boost - ]; + nativeBuildInputs = [ + cmake + ]; - doCheck = true; + buildInputs = [ + icu + boost + ]; - postFixup = '' - substituteInPlace "$out"/lib/pkgconfig/cg3.pc \ - --replace '=''${prefix}//' '=/' - ''; + doCheck = true; - passthru.tests.minimal = runCommand "${pname}-test" { - buildInputs = [ - cg3 - dieHook - ]; - } '' - echo 'DELIMITERS = "."; ADD (tag) (*);' >grammar.cg3 - printf '""\n\t"a" tag\n\n' >want.txt - printf '""\n\t"a"\n\n' | vislcg3 -g grammar.cg3 >got.txt - diff -s want.txt got.txt || die "Grammar application did not produce expected parse" - touch $out + postFixup = '' + substituteInPlace "$out"/lib/pkgconfig/cg3.pc \ + --replace '=''${prefix}//' '=/' ''; + passthru.tests.minimal = + runCommand "${pname}-test" + { + buildInputs = [ + cg3 + dieHook + ]; + } + '' + echo 'DELIMITERS = "."; ADD (tag) (*);' >grammar.cg3 + printf '""\n\t"a" tag\n\n' >want.txt + printf '""\n\t"a"\n\n' | vislcg3 -g grammar.cg3 >got.txt + diff -s want.txt got.txt || die "Grammar application did not produce expected parse" + touch $out + ''; - # TODO, consider optionals: - # - Enable tcmalloc unless darwin? - # - Enable python bindings? + # TODO, consider optionals: + # - Enable tcmalloc unless darwin? + # - Enable python bindings? - meta = with lib; { - homepage = "https://github.com/GrammarSoft/cg3"; - description = "Constraint Grammar interpreter, compiler and applicator vislcg3"; - maintainers = with maintainers; [ unhammer ]; - license = licenses.gpl3Plus; - platforms = platforms.all; + meta = with lib; { + homepage = "https://github.com/GrammarSoft/cg3"; + description = "Constraint Grammar interpreter, compiler and applicator vislcg3"; + maintainers = with maintainers; [ unhammer ]; + license = licenses.gpl3Plus; + platforms = platforms.all; + }; }; -}; in - cg3 +cg3 diff --git a/pkgs/by-name/cg/cgdb/package.nix b/pkgs/by-name/cg/cgdb/package.nix index bb5a792fa4dc33..91524004fce9c6 100644 --- a/pkgs/by-name/cg/cgdb/package.nix +++ b/pkgs/by-name/cg/cgdb/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, ncurses, readline, flex, texinfo }: +{ + lib, + stdenv, + fetchurl, + ncurses, + readline, + flex, + texinfo, +}: stdenv.mkDerivation rec { pname = "cgdb"; @@ -9,7 +17,12 @@ stdenv.mkDerivation rec { sha256 = "sha256-DTi1JNN3JXsQa61thW2K4zBBQOHuJAhTQ+bd8bZYEfE="; }; - buildInputs = [ ncurses readline flex texinfo ]; + buildInputs = [ + ncurses + readline + flex + texinfo + ]; meta = with lib; { description = "Curses interface to gdb"; diff --git a/pkgs/by-name/cg/cgif/package.nix b/pkgs/by-name/cg/cgif/package.nix index 7f35f42ccae263..dc6fb3dcf885cd 100644 --- a/pkgs/by-name/cg/cgif/package.nix +++ b/pkgs/by-name/cg/cgif/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, fetchFromGitHub -, lib -, meson -, ninja +{ + stdenv, + fetchFromGitHub, + lib, + meson, + ninja, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/cg/cgiserver/package.nix b/pkgs/by-name/cg/cgiserver/package.nix index f68216eb934855..f26d44a1d0b480 100644 --- a/pkgs/by-name/cg/cgiserver/package.nix +++ b/pkgs/by-name/cg/cgiserver/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchzip, zstd }: +{ + lib, + buildGoModule, + fetchzip, + zstd, +}: buildGoModule rec { pname = "cgiserver"; diff --git a/pkgs/by-name/cg/cgl/package.nix b/pkgs/by-name/cg/cgl/package.nix index 3de53c12256166..3f4ebde2354edf 100644 --- a/pkgs/by-name/cg/cgl/package.nix +++ b/pkgs/by-name/cg/cgl/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, clp -, coin-utils -, osi +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + clp, + coin-utils, + osi, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/cg/cglm/package.nix b/pkgs/by-name/cg/cglm/package.nix index 3ad9c33bb3cff7..69d05316785a1f 100644 --- a/pkgs/by-name/cg/cglm/package.nix +++ b/pkgs/by-name/cg/cglm/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cg/cgminer/package.nix b/pkgs/by-name/cg/cgminer/package.nix index 1f8cf152e0803a..2104e05a834b02 100644 --- a/pkgs/by-name/cg/cgminer/package.nix +++ b/pkgs/by-name/cg/cgminer/package.nix @@ -1,16 +1,19 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config -, libtool -, autoconf -, automake -, curl -, ncurses -, ocl-icd -, opencl-headers -, libusb1 -, xorg -, jansson }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libtool, + autoconf, + automake, + curl, + ncurses, + ocl-icd, + opencl-headers, + libusb1, + xorg, + jansson, +}: stdenv.mkDerivation rec { pname = "cgminer"; @@ -23,21 +26,37 @@ stdenv.mkDerivation rec { sha256 = "0l1ms3nxnjzh4mpiadikvngcr9k3jnjqy3yna207za0va0c28dj5"; }; - nativeBuildInputs = [ pkg-config autoconf automake ]; - buildInputs = [ libtool curl ncurses ocl-icd opencl-headers - xorg.libX11 xorg.libXext xorg.libXinerama jansson libusb1 ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; + buildInputs = [ + libtool + curl + ncurses + ocl-icd + opencl-headers + xorg.libX11 + xorg.libXext + xorg.libXinerama + jansson + libusb1 + ]; configureScript = "./autogen.sh"; - configureFlags = [ "--enable-scrypt" - "--enable-opencl" - "--enable-bitforce" - "--enable-icarus" - "--enable-modminer" - "--enable-ztex" - "--enable-avalon" - "--enable-klondike" - "--enable-keccak" - "--enable-bflsc"]; + configureFlags = [ + "--enable-scrypt" + "--enable-opencl" + "--enable-bitforce" + "--enable-icarus" + "--enable-modminer" + "--enable-ztex" + "--enable-avalon" + "--enable-klondike" + "--enable-keccak" + "--enable-bflsc" + ]; # Workaround build failure on -fno-common toolchains like upstream # gcc-10. Otherwise build fails as: @@ -51,7 +70,10 @@ stdenv.mkDerivation rec { mainProgram = "cgminer"; homepage = "https://github.com/ckolivas/cgminer"; license = licenses.gpl3; - maintainers = with maintainers; [ offline mmahut ]; + maintainers = with maintainers; [ + offline + mmahut + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/cg/cgoban/package.nix b/pkgs/by-name/cg/cgoban/package.nix index 73dd262173eeaf..a143f4eb560ff2 100644 --- a/pkgs/by-name/cg/cgoban/package.nix +++ b/pkgs/by-name/cg/cgoban/package.nix @@ -1,14 +1,18 @@ -{ lib -, stdenv -, temurin-jre-bin-17 -, fetchurl -, makeWrapper +{ + lib, + stdenv, + temurin-jre-bin-17, + fetchurl, + makeWrapper, }: stdenv.mkDerivation rec { pname = "cgoban"; version = "3.5.144"; - nativeBuildInputs = [ temurin-jre-bin-17 makeWrapper ]; + nativeBuildInputs = [ + temurin-jre-bin-17 + makeWrapper + ]; src = fetchurl { url = "https://web.archive.org/web/20240314222506/https://files.gokgs.com/javaBin/cgoban.jar"; diff --git a/pkgs/by-name/cg/cgreen/package.nix b/pkgs/by-name/cg/cgreen/package.nix index c6394a456efd9c..6aabd82ef00acb 100644 --- a/pkgs/by-name/cg/cgreen/package.nix +++ b/pkgs/by-name/cg/cgreen/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/cg/cgterm/package.nix b/pkgs/by-name/cg/cgterm/package.nix index 3e3b075d9cdc36..a9ee641df1d318 100644 --- a/pkgs/by-name/cg/cgterm/package.nix +++ b/pkgs/by-name/cg/cgterm/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL +{ + lib, + stdenv, + fetchFromGitHub, + SDL, }: stdenv.mkDerivation (finalAttrs: { @@ -19,7 +20,10 @@ stdenv.mkDerivation (finalAttrs: { SDL ]; - makeFlags = [ "CC:=$(CC)" "PREFIX=$(out)" ]; + makeFlags = [ + "CC:=$(CC)" + "PREFIX=$(out)" + ]; meta = with lib; { description = "C/G telnet client for C64 BBS's"; diff --git a/pkgs/by-name/cg/cgui/package.nix b/pkgs/by-name/cg/cgui/package.nix index 6c536ec5767144..3e416d14f73b44 100644 --- a/pkgs/by-name/cg/cgui/package.nix +++ b/pkgs/by-name/cg/cgui/package.nix @@ -1,15 +1,28 @@ -{ lib, stdenv, fetchurl, texinfo, allegro, perl, libX11 }: +{ + lib, + stdenv, + fetchurl, + texinfo, + allegro, + perl, + libX11, +}: stdenv.mkDerivation rec { pname = "cgui"; - version="2.1.0"; + version = "2.1.0"; src = fetchurl { url = "mirror://sourceforge/project/cgui/${version}/${pname}-${version}.tar.gz"; sha256 = "1pp1hvidpilq37skkmbgba4lvzi01rasy04y0cnas9ck0canv00s"; }; - buildInputs = [ texinfo allegro perl libX11 ]; + buildInputs = [ + texinfo + allegro + perl + libX11 + ]; configurePhase = '' sh fix.sh unix diff --git a/pkgs/by-name/ch/chain-bench/package.nix b/pkgs/by-name/ch/chain-bench/package.nix index 1fc50d665002a4..4fde0f9ce10c4c 100644 --- a/pkgs/by-name/ch/chain-bench/package.nix +++ b/pkgs/by-name/ch/chain-bench/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/ch/changedetection-io/package.nix b/pkgs/by-name/ch/changedetection-io/package.nix index bce23a1042fcd6..797c6096e2d044 100644 --- a/pkgs/by-name/ch/changedetection-io/package.nix +++ b/pkgs/by-name/ch/changedetection-io/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -17,47 +18,50 @@ python3.pkgs.buildPythonApplication rec { pythonRelaxDeps = true; - propagatedBuildInputs = with python3.pkgs; [ - apprise - beautifulsoup4 - brotli - babel - chardet - cryptography - dnspython - elementpath - eventlet - feedgen - flask - flask-compress - flask-cors - flask-expects-json - flask-login - flask-paginate - flask-restful - flask-wtf - greenlet - inscriptis - jinja2 - jinja2-time - jsonpath-ng - jq - loguru - lxml - paho-mqtt - playwright - pyee - pyppeteer - pytz - requests - selenium - setuptools - timeago - urllib3 - validators - werkzeug - wtforms - ] ++ requests.optional-dependencies.socks; + propagatedBuildInputs = + with python3.pkgs; + [ + apprise + beautifulsoup4 + brotli + babel + chardet + cryptography + dnspython + elementpath + eventlet + feedgen + flask + flask-compress + flask-cors + flask-expects-json + flask-login + flask-paginate + flask-restful + flask-wtf + greenlet + inscriptis + jinja2 + jinja2-time + jsonpath-ng + jq + loguru + lxml + paho-mqtt + playwright + pyee + pyppeteer + pytz + requests + selenium + setuptools + timeago + urllib3 + validators + werkzeug + wtforms + ] + ++ requests.optional-dependencies.socks; # tests can currently not be run in one pytest invocation and without docker doCheck = false; diff --git a/pkgs/by-name/ch/changelog-d/package.nix b/pkgs/by-name/ch/changelog-d/package.nix index a5bff1bfe1dee4..b9ad1fb887fff3 100644 --- a/pkgs/by-name/ch/changelog-d/package.nix +++ b/pkgs/by-name/ch/changelog-d/package.nix @@ -8,13 +8,12 @@ let hsPkg = haskellPackages.changelog-d; - addCompletions = haskellPackages.generateOptparseApplicativeCompletions ["changelog-d"]; + addCompletions = haskellPackages.generateOptparseApplicativeCompletions [ "changelog-d" ]; - haskellModifications = - lib.flip lib.pipe [ - addCompletions - haskell.lib.justStaticExecutables - ]; + haskellModifications = lib.flip lib.pipe [ + addCompletions + haskell.lib.justStaticExecutables + ]; mkDerivationOverrides = finalAttrs: oldAttrs: { @@ -30,4 +29,4 @@ let }; in - (haskellModifications hsPkg).overrideAttrs mkDerivationOverrides +(haskellModifications hsPkg).overrideAttrs mkDerivationOverrides diff --git a/pkgs/by-name/ch/changelog-d/tests/basic.nix b/pkgs/by-name/ch/changelog-d/tests/basic.nix index 25d434f0729fc4..0ee9ef6de73c03 100644 --- a/pkgs/by-name/ch/changelog-d/tests/basic.nix +++ b/pkgs/by-name/ch/changelog-d/tests/basic.nix @@ -1,25 +1,27 @@ { runCommand, changelog-d }: -runCommand "changelog-d-basic-test" { - nativeBuildInputs = [ changelog-d ]; -} '' - mkdir changelogs - cat > changelogs/config < changelogs/a <$out - cat -n $out - echo Checking the generated output - set -x - grep -F 'Support numbers with incrementing base-10 digits' $out >/dev/null - grep -F 'https://github.com/NixOS/boondoggle/issues/1234' $out >/dev/null - set +x -'' + '' + mkdir changelogs + cat > changelogs/config < changelogs/a <$out + cat -n $out + echo Checking the generated output + set -x + grep -F 'Support numbers with incrementing base-10 digits' $out >/dev/null + grep -F 'https://github.com/NixOS/boondoggle/issues/1234' $out >/dev/null + set +x + '' diff --git a/pkgs/by-name/ch/changelogger/package.nix b/pkgs/by-name/ch/changelogger/package.nix index fa46e7b10752c9..f0b911d15c18d6 100644 --- a/pkgs/by-name/ch/changelogger/package.nix +++ b/pkgs/by-name/ch/changelogger/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/ch/changetower/package.nix b/pkgs/by-name/ch/changetower/package.nix index f5d63bb4336a29..e3496e4fe279fc 100644 --- a/pkgs/by-name/ch/changetower/package.nix +++ b/pkgs/by-name/ch/changetower/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ch/changie/package.nix b/pkgs/by-name/ch/changie/package.nix index 5c32c6bcd078e4..37d0b8f7403097 100644 --- a/pkgs/by-name/ch/changie/package.nix +++ b/pkgs/by-name/ch/changie/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -21,7 +22,11 @@ buildGoModule rec { installShellFiles ]; - ldflags = [ "-s" "-w" "-X=main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.version=${version}" + ]; postInstall = '' installShellCompletion --cmd changie \ @@ -36,6 +41,9 @@ buildGoModule rec { homepage = "https://changie.dev"; changelog = "https://github.com/miniscruff/changie/blob/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/ch/charasay/package.nix b/pkgs/by-name/ch/charasay/package.nix index 5048b9dd655a1e..067d009c0fbb21 100644 --- a/pkgs/by-name/ch/charasay/package.nix +++ b/pkgs/by-name/ch/charasay/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ch/charis-sil/package.nix b/pkgs/by-name/ch/charis-sil/package.nix index a75fabb9ae3548..9d2614f965c94e 100644 --- a/pkgs/by-name/ch/charis-sil/package.nix +++ b/pkgs/by-name/ch/charis-sil/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "charis-sil"; diff --git a/pkgs/by-name/ch/charliecloud/package.nix b/pkgs/by-name/ch/charliecloud/package.nix index 2889d09183d77a..dd831bd34ebd2d 100644 --- a/pkgs/by-name/ch/charliecloud/package.nix +++ b/pkgs/by-name/ch/charliecloud/package.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, python3, docker, autoreconfHook, coreutils, makeWrapper, gnused, gnutar, gzip, findutils, sudo, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + docker, + autoreconfHook, + coreutils, + makeWrapper, + gnused, + gnutar, + gzip, + findutils, + sudo, + nixosTests, +}: stdenv.mkDerivation rec { @@ -12,17 +27,28 @@ stdenv.mkDerivation rec { sha256 = "sha256-kdaVlwE3vdCxsmJTOUwx8J+9UcBuXbKDwS2MHX2ZPPM="; }; - nativeBuildInputs = [ autoreconfHook makeWrapper ]; + nativeBuildInputs = [ + autoreconfHook + makeWrapper + ]; buildInputs = [ docker - (python3.withPackages (ps: [ ps.lark ps.requests ])) + (python3.withPackages (ps: [ + ps.lark + ps.requests + ])) ]; - configureFlags = let - pythonEnv = python3.withPackages (ps: [ ps.lark ps.requests ]); - in [ - "--with-python=${pythonEnv}/bin/python3" - ]; + configureFlags = + let + pythonEnv = python3.withPackages (ps: [ + ps.lark + ps.requests + ]); + in + [ + "--with-python=${pythonEnv}/bin/python3" + ]; preConfigure = '' patchShebangs test/ @@ -38,7 +64,17 @@ stdenv.mkDerivation rec { # Here we wrap those deps so they are resolved inside nixpkgs. postInstall = '' for file in $out/bin/* ; do \ - wrapProgram $file --prefix PATH : ${lib.makeBinPath [ coreutils docker gnused gnutar gzip findutils sudo ]} + wrapProgram $file --prefix PATH : ${ + lib.makeBinPath [ + coreutils + docker + gnused + gnutar + gzip + findutils + sudo + ] + } done ''; diff --git a/pkgs/by-name/ch/charls/package.nix b/pkgs/by-name/ch/charls/package.nix index f8591dc92bca5d..0595b4629aeaa0 100644 --- a/pkgs/by-name/ch/charls/package.nix +++ b/pkgs/by-name/ch/charls/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "charls"; diff --git a/pkgs/by-name/ch/charm-freeze/package.nix b/pkgs/by-name/ch/charm-freeze/package.nix index c9002e244e53d3..25cdaee8639478 100644 --- a/pkgs/by-name/ch/charm-freeze/package.nix +++ b/pkgs/by-name/ch/charm-freeze/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "charm-freeze"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-AUFzxmQOb/h0UgcprY09IVI7Auitn3JTDU/ptKicIAU="; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; meta = with lib; { description = "Tool to generate images of code and terminal output"; @@ -21,6 +29,9 @@ buildGoModule rec { homepage = "https://github.com/charmbracelet/freeze"; changelog = "https://github.com/charmbracelet/freeze/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ caarlos0 maaslalani ]; + maintainers = with maintainers; [ + caarlos0 + maaslalani + ]; }; } diff --git a/pkgs/by-name/ch/charm/package.nix b/pkgs/by-name/ch/charm/package.nix index bf3520d4634e15..908df7793a2d71 100644 --- a/pkgs/by-name/ch/charm/package.nix +++ b/pkgs/by-name/ch/charm/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "charm"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-V5azvQ8vMkgF2Myt6h5Gw09b+Xwg1XLyTImG52qQ+20="; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; meta = with lib; { description = "Manage your charm account on the CLI"; diff --git a/pkgs/by-name/ch/chart-testing/package.nix b/pkgs/by-name/ch/chart-testing/package.nix index a19f5b474f678e..97193bf3b38379 100644 --- a/pkgs/by-name/ch/chart-testing/package.nix +++ b/pkgs/by-name/ch/chart-testing/package.nix @@ -1,14 +1,15 @@ -{ buildGoModule -, coreutils -, fetchFromGitHub -, git -, installShellFiles -, kubectl -, kubernetes-helm -, lib -, makeWrapper -, yamale -, yamllint +{ + buildGoModule, + coreutils, + fetchFromGitHub, + git, + installShellFiles, + kubectl, + kubernetes-helm, + lib, + makeWrapper, + yamale, + yamllint, }: buildGoModule rec { @@ -37,7 +38,10 @@ buildGoModule rec { "-X github.com/helm/chart-testing/v3/ct/cmd.BuildDate=19700101-00:00:00" ]; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; postInstall = '' install -Dm644 -t $out/etc/ct etc/chart_schema.yaml @@ -48,14 +52,16 @@ buildGoModule rec { --zsh <($out/bin/ct completion zsh) \ --fish <($out/bin/ct completion fish) \ - wrapProgram $out/bin/ct --prefix PATH : ${lib.makeBinPath [ - coreutils - git - kubectl - kubernetes-helm - yamale - yamllint - ]} + wrapProgram $out/bin/ct --prefix PATH : ${ + lib.makeBinPath [ + coreutils + git + kubectl + kubernetes-helm + yamale + yamllint + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/ch/chase/package.nix b/pkgs/by-name/ch/chase/package.nix index 40f09089fdff17..240e9a85bebff9 100644 --- a/pkgs/by-name/ch/chase/package.nix +++ b/pkgs/by-name/ch/chase/package.nix @@ -1,23 +1,36 @@ -{ lib, stdenv, fetchurl ,pkg-config, libatomic_ops , boehmgc }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libatomic_ops, + boehmgc, +}: stdenv.mkDerivation rec { pname = "chase"; version = "0.5.2"; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libatomic_ops boehmgc ] ; + buildInputs = [ + libatomic_ops + boehmgc + ]; src = fetchurl { url = "mirror://debian/pool/main/c/chase/chase_${version}.orig.tar.gz"; sha256 = "68d95c2d4dc45553b75790fcea4413b7204a2618dff148116ca9bdb0310d737f"; }; doCheck = true; - makeFlags = [ "-e" "LIBS=-lgc" ]; + makeFlags = [ + "-e" + "LIBS=-lgc" + ]; - meta = with lib ; { + meta = with lib; { description = "Follow a symlink and print out its target file"; longDescription = '' - A commandline program that chases symbolic filesystems links to the original file + A commandline program that chases symbolic filesystems links to the original file ''; homepage = "https://qa.debian.org/developer.php?login=rotty%40debian.org"; license = licenses.gpl2Plus; diff --git a/pkgs/by-name/ch/chatblade/package.nix b/pkgs/by-name/ch/chatblade/package.nix index 3927c57950aca5..3e360e95dca736 100644 --- a/pkgs/by-name/ch/chatblade/package.nix +++ b/pkgs/by-name/ch/chatblade/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "chatblade"; diff --git a/pkgs/by-name/ch/chatgpt-cli/package.nix b/pkgs/by-name/ch/chatgpt-cli/package.nix index a7712aee4116cb..61982d798fdb62 100644 --- a/pkgs/by-name/ch/chatgpt-cli/package.nix +++ b/pkgs/by-name/ch/chatgpt-cli/package.nix @@ -1,7 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { pname = "chatgpt"; diff --git a/pkgs/by-name/ch/chatgpt-retrieval-plugin/package.nix b/pkgs/by-name/ch/chatgpt-retrieval-plugin/package.nix index 05f7216209cd01..535d6808cc4660 100644 --- a/pkgs/by-name/ch/chatgpt-retrieval-plugin/package.nix +++ b/pkgs/by-name/ch/chatgpt-retrieval-plugin/package.nix @@ -1,9 +1,10 @@ -{ lib -, python3Packages -, fetchFromGitHub -, python3 -, nix-update-script -, dasel +{ + lib, + python3Packages, + fetchFromGitHub, + python3, + nix-update-script, + dasel, }: python3Packages.buildPythonApplication { diff --git a/pkgs/by-name/ch/chatgpt-shell-cli/package.nix b/pkgs/by-name/ch/chatgpt-shell-cli/package.nix index 25ab95c94127d7..f18028cac42abc 100644 --- a/pkgs/by-name/ch/chatgpt-shell-cli/package.nix +++ b/pkgs/by-name/ch/chatgpt-shell-cli/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, jq -, curl -, glow -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + jq, + curl, + glow, + makeWrapper, }: let @@ -14,35 +15,41 @@ let version = "master"; in stdenv.mkDerivation { - inherit pname version; - - src = fetchFromGitHub { - owner = "0xacx"; - repo = "chatgpt-shell-cli"; - rev = version; - hash = "sha256-hYLrUya4UCsIB1J/n+jp1jFRCEqnGFJOr3ATxm0zwdY="; - }; - - nativeBuildInputs = [ makeWrapper ]; - - installPhase = '' - runHook preInstall - - mkdir -p $out/bin - install -Dm755 chatgpt.sh -t $out/bin - - runHook postInstall - ''; - - postInstall = '' - wrapProgram $out/bin/chatgpt.sh \ - --prefix PATH : ${lib.makeBinPath [ jq curl glow ]} - ''; - - meta = with lib; { - homepage = "https://github.com/0xacx/chatGPT-shell-cli"; - description = "Simple shell script to use OpenAI's ChatGPT and DALL-E from the terminal. No Python or JS required."; - license = licenses.mit; - maintainers = with maintainers; [ jfvillablanca ]; - }; - } + inherit pname version; + + src = fetchFromGitHub { + owner = "0xacx"; + repo = "chatgpt-shell-cli"; + rev = version; + hash = "sha256-hYLrUya4UCsIB1J/n+jp1jFRCEqnGFJOr3ATxm0zwdY="; + }; + + nativeBuildInputs = [ makeWrapper ]; + + installPhase = '' + runHook preInstall + + mkdir -p $out/bin + install -Dm755 chatgpt.sh -t $out/bin + + runHook postInstall + ''; + + postInstall = '' + wrapProgram $out/bin/chatgpt.sh \ + --prefix PATH : ${ + lib.makeBinPath [ + jq + curl + glow + ] + } + ''; + + meta = with lib; { + homepage = "https://github.com/0xacx/chatGPT-shell-cli"; + description = "Simple shell script to use OpenAI's ChatGPT and DALL-E from the terminal. No Python or JS required."; + license = licenses.mit; + maintainers = with maintainers; [ jfvillablanca ]; + }; +} diff --git a/pkgs/by-name/ch/chatty/package.nix b/pkgs/by-name/ch/chatty/package.nix index a18ba2c1b96acd..909e13940a6ab5 100644 --- a/pkgs/by-name/ch/chatty/package.nix +++ b/pkgs/by-name/ch/chatty/package.nix @@ -1,32 +1,33 @@ -{ lib -, stdenv -, fetchFromGitLab -, appstream-glib -, desktop-file-utils -, itstool -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, evolution-data-server -, feedbackd -, glibmm -, libsecret -, gnome-desktop -, gspell -, gtk4 -, gtksourceview5 -, gst_all_1 -, json-glib -, libgcrypt -, libadwaita -, libphonenumber -, modemmanager -, olm -, pidgin -, protobuf -, sqlite -, plugins ? [ ] +{ + lib, + stdenv, + fetchFromGitLab, + appstream-glib, + desktop-file-utils, + itstool, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + evolution-data-server, + feedbackd, + glibmm, + libsecret, + gnome-desktop, + gspell, + gtk4, + gtksourceview5, + gst_all_1, + json-glib, + libgcrypt, + libadwaita, + libphonenumber, + modemmanager, + olm, + pidgin, + protobuf, + sqlite, + plugins ? [ ], }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ch/chayang/package.nix b/pkgs/by-name/ch/chayang/package.nix index d92a729bd28e13..0be994cdda62cb 100644 --- a/pkgs/by-name/ch/chayang/package.nix +++ b/pkgs/by-name/ch/chayang/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromSourcehut -, meson -, ninja -, pkg-config -, wayland-scanner -, wayland-protocols -, wayland +{ + lib, + stdenv, + fetchFromSourcehut, + meson, + ninja, + pkg-config, + wayland-scanner, + wayland-protocols, + wayland, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ch/cheat/package.nix b/pkgs/by-name/ch/cheat/package.nix index 07b4eaa3982622..6d964df186b1ca 100644 --- a/pkgs/by-name/ch/cheat/package.nix +++ b/pkgs/by-name/ch/cheat/package.nix @@ -1,5 +1,9 @@ -{ lib, fetchFromGitHub -, buildGoModule, installShellFiles }: +{ + lib, + fetchFromGitHub, + buildGoModule, + installShellFiles, +}: buildGoModule rec { pname = "cheat"; @@ -43,7 +47,10 @@ buildGoModule rec { meta = with lib; { description = "Create and view interactive cheatsheets on the command-line"; maintainers = with maintainers; [ mic92 ]; - license = with licenses; [ gpl3 mit ]; + license = with licenses; [ + gpl3 + mit + ]; inherit (src.meta) homepage; mainProgram = "cheat"; }; diff --git a/pkgs/by-name/ch/check-jsonschema/package.nix b/pkgs/by-name/ch/check-jsonschema/package.nix index 0b373d686e8e12..7c5094242d40ca 100644 --- a/pkgs/by-name/ch/check-jsonschema/package.nix +++ b/pkgs/by-name/ch/check-jsonschema/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3 }: +{ + lib, + fetchFromGitHub, + python3, +}: with python3.pkgs; diff --git a/pkgs/by-name/ch/checkinstall/package.nix b/pkgs/by-name/ch/checkinstall/package.nix index 875b757d1fbdeb..ec7c274b95dab2 100644 --- a/pkgs/by-name/ch/checkinstall/package.nix +++ b/pkgs/by-name/ch/checkinstall/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, gettext }: +{ + lib, + stdenv, + fetchurl, + gettext, +}: stdenv.mkDerivation rec { pname = "checkinstall"; @@ -9,44 +14,46 @@ stdenv.mkDerivation rec { sha256 = "1x4kslyvfd6lm6zd1ylbq2pjxrafb77ydfjaqi16sa5qywn1jqfw"; }; - patches = [ - # Include empty directories created by the installation script in - # generated packages. (E.g., if a `make install' does `mkdir - # /var/lib/mystuff', then /var/lib/mystuff should be included in - # the package.) - ./empty-dirs.patch + patches = + [ + # Include empty directories created by the installation script in + # generated packages. (E.g., if a `make install' does `mkdir + # /var/lib/mystuff', then /var/lib/mystuff should be included in + # the package.) + ./empty-dirs.patch - # Implement the getxattr(), lgetxattr(), __open_2() and - # __open64_2() functions. Needed for doing builds on Ubuntu 8.10. - ./missing-functions.patch + # Implement the getxattr(), lgetxattr(), __open_2() and + # __open64_2() functions. Needed for doing builds on Ubuntu 8.10. + ./missing-functions.patch - # Don't include directories in the Debian `conffiles' file. - ./etc-dirs.patch + # Don't include directories in the Debian `conffiles' file. + ./etc-dirs.patch - # Support Glibc >= 2.8. - ./glibc-check.patch + # Support Glibc >= 2.8. + ./glibc-check.patch - # Fix a `conflicting types for 'scandir'' error on Glibc 2.11. - ./scandir.patch + # Fix a `conflicting types for 'scandir'' error on Glibc 2.11. + ./scandir.patch - # Fix a `conflicting types for 'readlink'' error since Glibc 2.19 - ./readlink-types.patch + # Fix a `conflicting types for 'readlink'' error since Glibc 2.19 + ./readlink-types.patch - # Fix BuildRoot handling in RPM builds. - ./set-buildroot.patch + # Fix BuildRoot handling in RPM builds. + ./set-buildroot.patch - (fetchurl { - url = "https://salsa.debian.org/debian/checkinstall/-/raw/7175ae9de0e45f42fdd7f185ab9a12043d5efeeb/debian/patches/0016-Define-_STAT_VER-_MKNOD_VER-locally-dropped-in-glibc.patch"; - hash = "sha256-InodEfvVMuN708yjXPrVXb+q8aUcyFhCLx35PHls0Eo="; - }) - ] + (fetchurl { + url = "https://salsa.debian.org/debian/checkinstall/-/raw/7175ae9de0e45f42fdd7f185ab9a12043d5efeeb/debian/patches/0016-Define-_STAT_VER-_MKNOD_VER-locally-dropped-in-glibc.patch"; + hash = "sha256-InodEfvVMuN708yjXPrVXb+q8aUcyFhCLx35PHls0Eo="; + }) + ] - ++ lib.optional (stdenv.hostPlatform.system == "x86_64-linux") - # Force use of old memcpy so that installwatch works on Glibc < - # 2.14. - ./use-old-memcpy.patch; + ++ + lib.optional (stdenv.hostPlatform.system == "x86_64-linux") + # Force use of old memcpy so that installwatch works on Glibc < + # 2.14. + ./use-old-memcpy.patch; - buildInputs = [gettext]; + buildInputs = [ gettext ]; hardeningDisable = [ "fortify" ]; @@ -65,7 +72,7 @@ stdenv.mkDerivation rec { # as an LD_PRELOADed library on applications that load against a # different Glibc. '' - patchelf --set-rpath "" $out/lib/installwatch.so + patchelf --set-rpath "" $out/lib/installwatch.so ''; meta = { diff --git a/pkgs/by-name/ch/checkip/package.nix b/pkgs/by-name/ch/checkip/package.nix index 9ef38a197efff1..01aa5785f9adeb 100644 --- a/pkgs/by-name/ch/checkip/package.nix +++ b/pkgs/by-name/ch/checkip/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ch/checkmake/package.nix b/pkgs/by-name/ch/checkmake/package.nix index 8e4d4c326141e5..400552061f8b32 100644 --- a/pkgs/by-name/ch/checkmake/package.nix +++ b/pkgs/by-name/ch/checkmake/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, pandoc -, go +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + pandoc, + go, }: buildGoModule rec { diff --git a/pkgs/by-name/ch/checkmate/package.nix b/pkgs/by-name/ch/checkmate/package.nix index ca036f967661c8..64b8bf9b2fd64b 100644 --- a/pkgs/by-name/ch/checkmate/package.nix +++ b/pkgs/by-name/ch/checkmate/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ch/checkpolicy/package.nix b/pkgs/by-name/ch/checkpolicy/package.nix index 65b4516d3b2b28..1703e5db68cee9 100644 --- a/pkgs/by-name/ch/checkpolicy/package.nix +++ b/pkgs/by-name/ch/checkpolicy/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, bison, flex, libsepol }: +{ + lib, + stdenv, + fetchurl, + bison, + flex, + libsepol, +}: stdenv.mkDerivation rec { pname = "checkpolicy"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-/T4ZJUd9SZRtERaThmGvRMH4bw1oFGb9nwLqoGACoH8="; }; - nativeBuildInputs = [ bison flex ]; + nativeBuildInputs = [ + bison + flex + ]; buildInputs = [ libsepol ]; makeFlags = [ @@ -18,7 +28,7 @@ stdenv.mkDerivation rec { "LIBSEPOLA=${lib.getLib libsepol}/lib/libsepol.a" ]; - meta = removeAttrs libsepol.meta ["outputsToInstall"] // { + meta = removeAttrs libsepol.meta [ "outputsToInstall" ] // { description = "SELinux policy compiler"; }; } diff --git a/pkgs/by-name/ch/checkpwn/package.nix b/pkgs/by-name/ch/checkpwn/package.nix index e89e6b88009714..fa20d0753b49e1 100644 --- a/pkgs/by-name/ch/checkpwn/package.nix +++ b/pkgs/by-name/ch/checkpwn/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchCrate -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ch/checkra1n/package.nix b/pkgs/by-name/ch/checkra1n/package.nix index a44a6d8b2b8d2e..3c58885a27774c 100644 --- a/pkgs/by-name/ch/checkra1n/package.nix +++ b/pkgs/by-name/ch/checkra1n/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "checkra1n"; diff --git a/pkgs/by-name/ch/checksec/package.nix b/pkgs/by-name/ch/checksec/package.nix index 488bfdff1a6add..c479c7f1451049 100644 --- a/pkgs/by-name/ch/checksec/package.nix +++ b/pkgs/by-name/ch/checksec/package.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchpatch -, fetchFromGitHub -, makeWrapper -, testers -, runCommand +{ + lib, + stdenv, + fetchpatch, + fetchFromGitHub, + makeWrapper, + testers, + runCommand, # dependencies -, binutils -, coreutils -, curl -, elfutils -, file -, findutils -, gawk -, glibc -, gnugrep -, gnused -, openssl -, procps -, sysctl -, wget -, which + binutils, + coreutils, + curl, + elfutils, + file, + findutils, + gawk, + glibc, + gnugrep, + gnused, + openssl, + procps, + sysctl, + wget, + which, # tests -, checksec + checksec, }: stdenv.mkDerivation rec { @@ -101,6 +102,9 @@ stdenv.mkDerivation rec { homepage = "https://www.trapkit.de/tools/checksec/"; license = licenses.bsd3; platforms = platforms.linux; - maintainers = with maintainers; [ thoughtpolice globin ]; + maintainers = with maintainers; [ + thoughtpolice + globin + ]; }; } diff --git a/pkgs/by-name/ch/cheese/package.nix b/pkgs/by-name/ch/cheese/package.nix index db260a067a3991..4da934e9d8eb50 100644 --- a/pkgs/by-name/ch/cheese/package.nix +++ b/pkgs/by-name/ch/cheese/package.nix @@ -1,41 +1,46 @@ -{ lib -, stdenv -, gettext -, fetchurl -, wrapGAppsHook3 -, gnome-video-effects -, libcanberra-gtk3 -, pkg-config -, gtk3 -, glib -, clutter-gtk -, clutter-gst -, gst_all_1 -, itstool -, vala -, docbook_xml_dtd_43 -, docbook-xsl-nons -, appstream-glib -, libxslt -, gtk-doc -, adwaita-icon-theme -, librsvg -, totem -, gdk-pixbuf -, gnome -, gnome-desktop -, libxml2 -, meson -, ninja -, dbus -, pipewire +{ + lib, + stdenv, + gettext, + fetchurl, + wrapGAppsHook3, + gnome-video-effects, + libcanberra-gtk3, + pkg-config, + gtk3, + glib, + clutter-gtk, + clutter-gst, + gst_all_1, + itstool, + vala, + docbook_xml_dtd_43, + docbook-xsl-nons, + appstream-glib, + libxslt, + gtk-doc, + adwaita-icon-theme, + librsvg, + totem, + gdk-pixbuf, + gnome, + gnome-desktop, + libxml2, + meson, + ninja, + dbus, + pipewire, }: stdenv.mkDerivation rec { pname = "cheese"; version = "44.1"; - outputs = [ "out" "man" "devdoc" ]; + outputs = [ + "out" + "man" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/cheese/${lib.versions.major version}/cheese-${version}.tar.xz"; diff --git a/pkgs/by-name/ch/cheesecutter/package.nix b/pkgs/by-name/ch/cheesecutter/package.nix index b1c44f2bebc8b9..ef7037ca43bef4 100644 --- a/pkgs/by-name/ch/cheesecutter/package.nix +++ b/pkgs/by-name/ch/cheesecutter/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, acme -, ldc -, patchelf -, SDL +{ + stdenv, + lib, + fetchFromGitHub, + acme, + ldc, + patchelf, + SDL, }: stdenv.mkDerivation rec { pname = "cheesecutter"; @@ -17,13 +18,16 @@ stdenv.mkDerivation rec { sha256 = "sha256:0q4a791nayya6n01l0f4kk497rdq6kiq0n72fqdpwqy138pfwydn"; }; - patches = [ - ./0001-Drop-baked-in-build-date-for-r13y.patch - ] - ++ lib.optional stdenv.hostPlatform.isDarwin ./0002-Prepend-libSDL.dylib-to-macOS-SDL-loader.patch; + patches = + [ + ./0001-Drop-baked-in-build-date-for-r13y.patch + ] + ++ lib.optional stdenv.hostPlatform.isDarwin ./0002-Prepend-libSDL.dylib-to-macOS-SDL-loader.patch; - nativeBuildInputs = [ acme ldc ] - ++ lib.optional (!stdenv.hostPlatform.isDarwin) patchelf; + nativeBuildInputs = [ + acme + ldc + ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) patchelf; buildInputs = [ SDL ]; @@ -47,18 +51,25 @@ stdenv.mkDerivation rec { let rpathSDL = lib.makeLibraryPath [ SDL ]; in - if stdenv.hostPlatform.isDarwin then '' - install_name_tool -add_rpath ${rpathSDL} $out/bin/ccutter - '' else '' - rpath=$(patchelf --print-rpath $out/bin/ccutter) - patchelf --set-rpath "$rpath:${rpathSDL}" $out/bin/ccutter - ''; + if stdenv.hostPlatform.isDarwin then + '' + install_name_tool -add_rpath ${rpathSDL} $out/bin/ccutter + '' + else + '' + rpath=$(patchelf --print-rpath $out/bin/ccutter) + patchelf --set-rpath "$rpath:${rpathSDL}" $out/bin/ccutter + ''; meta = with lib; { description = "Tracker program for composing music for the SID chip"; homepage = "https://github.com/theyamo/CheeseCutter/"; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + "x86_64-darwin" + ]; maintainers = with maintainers; [ OPNA2608 ]; }; } diff --git a/pkgs/by-name/ch/chelf/package.nix b/pkgs/by-name/ch/chelf/package.nix index 7dd84eba1e4417..940a74cfb2dea8 100644 --- a/pkgs/by-name/ch/chelf/package.nix +++ b/pkgs/by-name/ch/chelf/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "chelf"; diff --git a/pkgs/by-name/ch/chemacs2/package.nix b/pkgs/by-name/ch/chemacs2/package.nix index 4b85dbfe871426..15e2dc7741e9f6 100644 --- a/pkgs/by-name/ch/chemacs2/package.nix +++ b/pkgs/by-name/ch/chemacs2/package.nix @@ -16,7 +16,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { hash = "sha256-/WtacZPr45lurS0hv+W8UGzsXY3RujkU5oGGGqjqG0Q="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; dontConfigure = true; dontBuild = true; diff --git a/pkgs/by-name/ch/chemtool/package.nix b/pkgs/by-name/ch/chemtool/package.nix index 82b1834671619c..deb9b01700ea26 100644 --- a/pkgs/by-name/ch/chemtool/package.nix +++ b/pkgs/by-name/ch/chemtool/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, libX11 -, gtk2 -, fig2dev -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + pkg-config, + libX11, + gtk2, + fig2dev, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -17,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "hhYaBGE4azNKX/sXzfCUpJGUGIRngnL0V0mBNRTdr8s="; }; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; buildInputs = [ libX11 gtk2 diff --git a/pkgs/by-name/ch/cherry/package.nix b/pkgs/by-name/ch/cherry/package.nix index c69bb0715dc67a..da418ecee128cc 100644 --- a/pkgs/by-name/ch/cherry/package.nix +++ b/pkgs/by-name/ch/cherry/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, xorg }: +{ + lib, + stdenv, + fetchFromGitHub, + xorg, +}: stdenv.mkDerivation rec { pname = "cherry"; @@ -11,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "13zkxwp6r6kcxv4x459vwscr0n0sik4a3kcz5xnmlpvcdnbxi586"; }; - nativeBuildInputs = [ xorg.fonttosfnt xorg.mkfontdir ]; + nativeBuildInputs = [ + xorg.fonttosfnt + xorg.mkfontdir + ]; buildPhase = '' patchShebangs make.sh @@ -34,4 +42,3 @@ stdenv.mkDerivation rec { platforms = platforms.all; }; } - diff --git a/pkgs/by-name/ch/cherrybomb/package.nix b/pkgs/by-name/ch/cherrybomb/package.nix index 38783319e7c721..9ce60696a621c8 100644 --- a/pkgs/by-name/ch/cherrybomb/package.nix +++ b/pkgs/by-name/ch/cherrybomb/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchCrate -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ch/cherrytree/package.nix b/pkgs/by-name/ch/cherrytree/package.nix index 69b457a4f0703f..98f219022afe33 100644 --- a/pkgs/by-name/ch/cherrytree/package.nix +++ b/pkgs/by-name/ch/cherrytree/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, python3 -, wrapGAppsHook3 -, gtkmm3 -, gtksourceview -, gtksourceviewmm -, gspell -, libxmlxx -, sqlite -, curl -, libuchardet -, spdlog -, fribidi -, vte +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + python3, + wrapGAppsHook3, + gtkmm3, + gtksourceview, + gtksourceviewmm, + gspell, + libxmlxx, + sqlite, + curl, + libuchardet, + spdlog, + fribidi, + vte, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ch/chess-clock/package.nix b/pkgs/by-name/ch/chess-clock/package.nix index 2074e5404c414e..4811cc807d8fd8 100644 --- a/pkgs/by-name/ch/chess-clock/package.nix +++ b/pkgs/by-name/ch/chess-clock/package.nix @@ -1,16 +1,17 @@ -{ lib -, desktop-file-utils -, fetchFromGitLab -, gobject-introspection -, gsound -, gtk4 -, libadwaita -, meson -, ninja -, pkg-config -, python3 -, stdenv -, wrapGAppsHook4 +{ + lib, + desktop-file-utils, + fetchFromGitLab, + gobject-introspection, + gsound, + gtk4, + libadwaita, + meson, + ninja, + pkg-config, + python3, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation rec { @@ -38,9 +39,11 @@ stdenv.mkDerivation rec { gsound gtk4 libadwaita - (python3.withPackages (ps: with ps; [ - pygobject3 - ])) + (python3.withPackages ( + ps: with ps; [ + pygobject3 + ] + )) ]; meta = with lib; { diff --git a/pkgs/by-name/ch/chess-tui/package.nix b/pkgs/by-name/ch/chess-tui/package.nix index e2c4f5fe1edbe2..9dee8dd57e3f88 100644 --- a/pkgs/by-name/ch/chess-tui/package.nix +++ b/pkgs/by-name/ch/chess-tui/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -16,7 +17,7 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-RUnT5b9pBcopTPT/1J48xZ4pfn3C0mIuYTDvgf3zvn0="; - meta = with lib;{ + meta = with lib; { description = "Chess TUI implementation in rust"; homepage = "https://github.com/thomas-mauran/chess-tui"; maintainers = with maintainers; [ ByteSudoer ]; diff --git a/pkgs/by-name/ch/chessdb/package.nix b/pkgs/by-name/ch/chessdb/package.nix index 4acfc4d18e3d29..987906795e402e 100644 --- a/pkgs/by-name/ch/chessdb/package.nix +++ b/pkgs/by-name/ch/chessdb/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, tcl, tk, libX11, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + tcl, + tk, + libX11, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "chessdb"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ tcl tk libX11 ]; + buildInputs = [ + tcl + tk + libX11 + ]; makeFlags = [ "BINDIR=$(out)/bin" diff --git a/pkgs/by-name/ch/chez-matchable/package.nix b/pkgs/by-name/ch/chez-matchable/package.nix index b815567e4b4ff9..1b595f432ce596 100644 --- a/pkgs/by-name/ch/chez-matchable/package.nix +++ b/pkgs/by-name/ch/chez-matchable/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, chez }: +{ + stdenv, + lib, + fetchFromGitHub, + chez, +}: stdenv.mkDerivation rec { pname = "chez-matchable"; @@ -13,7 +18,10 @@ stdenv.mkDerivation rec { buildInputs = [ chez ]; - makeFlags = [ "CHEZ=${lib.getExe chez}" "PREFIX=$(out)" ]; + makeFlags = [ + "CHEZ=${lib.getExe chez}" + "PREFIX=$(out)" + ]; doCheck = false; diff --git a/pkgs/by-name/ch/chez-mit/package.nix b/pkgs/by-name/ch/chez-mit/package.nix index 154c7362de18c6..a12f7a7a06d839 100644 --- a/pkgs/by-name/ch/chez-mit/package.nix +++ b/pkgs/by-name/ch/chez-mit/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, chez, chez-srfi }: +{ + stdenv, + lib, + fetchFromGitHub, + chez, + chez-srfi, +}: stdenv.mkDerivation rec { pname = "chez-mit"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-TmoLA0zLETKE+PsrGS5dce9xLQUIKwSNixRSVjbrOlk="; }; - buildInputs = [ chez chez-srfi ]; + buildInputs = [ + chez + chez-srfi + ]; makeFlags = [ "CHEZ=${lib.getExe chez}" diff --git a/pkgs/by-name/ch/chez-racket/package.nix b/pkgs/by-name/ch/chez-racket/package.nix index 158dfa05293346..37a0dd0cce7c78 100644 --- a/pkgs/by-name/ch/chez-racket/package.nix +++ b/pkgs/by-name/ch/chez-racket/package.nix @@ -1,20 +1,35 @@ -{ stdenv, buildPackages, callPackage }: +{ + stdenv, + buildPackages, + callPackage, +}: let chezArch = - /**/ if stdenv.hostPlatform.isAarch then "arm${toString stdenv.hostPlatform.parsed.cpu.bits}" - else if stdenv.hostPlatform.isx86_32 then "i3" - else if stdenv.hostPlatform.isx86_64 then "a6" - else if stdenv.hostPlatform.isPower then "ppc${toString stdenv.hostPlatform.parsed.cpu.bits}" - else throw "Add ${stdenv.hostPlatform.parsed.cpu.arch} to chezArch to enable building chez-racket"; + if stdenv.hostPlatform.isAarch then + "arm${toString stdenv.hostPlatform.parsed.cpu.bits}" + else if stdenv.hostPlatform.isx86_32 then + "i3" + else if stdenv.hostPlatform.isx86_64 then + "a6" + else if stdenv.hostPlatform.isPower then + "ppc${toString stdenv.hostPlatform.parsed.cpu.bits}" + else + throw "Add ${stdenv.hostPlatform.parsed.cpu.arch} to chezArch to enable building chez-racket"; chezOs = - /**/ if stdenv.hostPlatform.isDarwin then "osx" - else if stdenv.hostPlatform.isFreeBSD then "fb" - else if stdenv.hostPlatform.isLinux then "le" - else if stdenv.hostPlatform.isNetBSD then "nb" - else if stdenv.hostPlatform.isOpenBSD then "ob" - else throw "Add ${stdenv.hostPlatform.uname.system} to chezOs to enable building chez-racket"; + if stdenv.hostPlatform.isDarwin then + "osx" + else if stdenv.hostPlatform.isFreeBSD then + "fb" + else if stdenv.hostPlatform.isLinux then + "le" + else if stdenv.hostPlatform.isNetBSD then + "nb" + else if stdenv.hostPlatform.isOpenBSD then + "ob" + else + throw "Add ${stdenv.hostPlatform.uname.system} to chezOs to enable building chez-racket"; inherit (stdenv.hostPlatform) system; chezSystem = "t${chezArch}${chezOs}"; @@ -37,7 +52,7 @@ let runHook postInstall ''; }; - boot = buildPackages.callPackage (import ./shared.nix forBoot) {}; + boot = buildPackages.callPackage (import ./shared.nix forBoot) { }; forFinal = { pname = "chez-scheme-racket"; configurePhase = '' @@ -54,6 +69,6 @@ let ''; setupHook = ./setup-hook.sh; }; - final = callPackage (import ./shared.nix forFinal) {}; + final = callPackage (import ./shared.nix forFinal) { }; in final diff --git a/pkgs/by-name/ch/chez-racket/shared.nix b/pkgs/by-name/ch/chez-racket/shared.nix index 71bb710d20487f..f68063bf1a7fa3 100644 --- a/pkgs/by-name/ch/chez-racket/shared.nix +++ b/pkgs/by-name/ch/chez-racket/shared.nix @@ -1,40 +1,62 @@ args: -{ stdenv, lib, fetchFromGitHub, coreutils, cctools, darwin -, ncurses, libiconv, libX11, zlib, lz4 +{ + stdenv, + lib, + fetchFromGitHub, + coreutils, + cctools, + darwin, + ncurses, + libiconv, + libX11, + zlib, + lz4, }: -stdenv.mkDerivation (args // { - version = "unstable-2021-12-11"; - - src = fetchFromGitHub { - owner = "racket"; - repo = "ChezScheme"; - rev = "8846c96b08561f05a937d5ecfe4edc96cc99be39"; - sha256 = "IYJQzT88T8kFahx2BusDOyzz6lQDCbZIfSz9rZoNF7A="; - fetchSubmodules = true; - }; - - prePatch = '' - rm -rf zlib/*.c lz4/lib/*.c - ''; - - postPatch = '' - export ZLIB="$(find ${zlib.out}/lib -type f | sort | head -n1)" - export LZ4="$(find ${lz4.lib}/lib -type f | sort | head -n1)" - ''; - - nativeBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin ([ cctools darwin.autoSignDarwinBinariesHook ]); - buildInputs = [ libiconv libX11 lz4 ncurses zlib ]; - - enableParallelBuilding = true; - - env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isGNU "-Wno-error=format-truncation"; - - meta = { - description = "Fork of Chez Scheme for Racket"; - homepage = "https://github.com/racket/ChezScheme"; - license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ l-as ]; - platforms = lib.platforms.unix; - }; -}) +stdenv.mkDerivation ( + args + // { + version = "unstable-2021-12-11"; + + src = fetchFromGitHub { + owner = "racket"; + repo = "ChezScheme"; + rev = "8846c96b08561f05a937d5ecfe4edc96cc99be39"; + sha256 = "IYJQzT88T8kFahx2BusDOyzz6lQDCbZIfSz9rZoNF7A="; + fetchSubmodules = true; + }; + + prePatch = '' + rm -rf zlib/*.c lz4/lib/*.c + ''; + + postPatch = '' + export ZLIB="$(find ${zlib.out}/lib -type f | sort | head -n1)" + export LZ4="$(find ${lz4.lib}/lib -type f | sort | head -n1)" + ''; + + nativeBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin ([ + cctools + darwin.autoSignDarwinBinariesHook + ]); + buildInputs = [ + libiconv + libX11 + lz4 + ncurses + zlib + ]; + + enableParallelBuilding = true; + + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isGNU "-Wno-error=format-truncation"; + + meta = { + description = "Fork of Chez Scheme for Racket"; + homepage = "https://github.com/racket/ChezScheme"; + license = lib.licenses.asl20; + maintainers = with lib.maintainers; [ l-as ]; + platforms = lib.platforms.unix; + }; + } +) diff --git a/pkgs/by-name/ch/chez-scmutils/package.nix b/pkgs/by-name/ch/chez-scmutils/package.nix index 843a8752df3872..853a4aa1a72d5d 100644 --- a/pkgs/by-name/ch/chez-scmutils/package.nix +++ b/pkgs/by-name/ch/chez-scmutils/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, chez, chez-srfi, chez-mit }: +{ + stdenv, + lib, + fetchFromGitHub, + chez, + chez-srfi, + chez-mit, +}: stdenv.mkDerivation rec { pname = "chez-scmutils"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-y2ug7GfmkJC6jddgB8YllsumjmGxFJxTGTpPf1Vcs/s="; }; - buildInputs = [ chez chez-srfi chez-mit ]; + buildInputs = [ + chez + chez-srfi + chez-mit + ]; lib-path = "lib/csv${lib.versions.majorMinor chez.version}-site"; diff --git a/pkgs/by-name/ch/chez-srfi/package.nix b/pkgs/by-name/ch/chez-srfi/package.nix index 317ce8f713baaa..5b1e72851ba651 100644 --- a/pkgs/by-name/ch/chez-srfi/package.nix +++ b/pkgs/by-name/ch/chez-srfi/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, chez }: +{ + stdenv, + lib, + fetchFromGitHub, + chez, +}: stdenv.mkDerivation rec { pname = "chez-srfi"; @@ -13,7 +18,10 @@ stdenv.mkDerivation rec { buildInputs = [ chez ]; - makeFlags = [ "CHEZ=${lib.getExe chez}" "PREFIX=$(out)" ]; + makeFlags = [ + "CHEZ=${lib.getExe chez}" + "PREFIX=$(out)" + ]; doCheck = false; diff --git a/pkgs/by-name/ch/chez/package.nix b/pkgs/by-name/ch/chez/package.nix index 52c8821bd2d1e7..7e76fb762934cd 100644 --- a/pkgs/by-name/ch/chez/package.nix +++ b/pkgs/by-name/ch/chez/package.nix @@ -1,7 +1,15 @@ -{ lib, stdenv, fetchurl -, coreutils, cctools -, darwin -, ncurses, libiconv, libX11, libuuid, testers +{ + lib, + stdenv, + fetchurl, + coreutils, + cctools, + darwin, + ncurses, + libiconv, + libX11, + libuuid, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -13,21 +21,28 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-kYGmyMSrXl0y2Hn/FZ0zWlDU+LOIYRriKiY+kyw1OYs="; }; - nativeBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - cctools - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - darwin.autoSignDarwinBinariesHook + nativeBuildInputs = + lib.optionals stdenv.hostPlatform.isDarwin [ + cctools + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + darwin.autoSignDarwinBinariesHook + ]; + buildInputs = [ + ncurses + libiconv + libX11 + libuuid ]; - buildInputs = [ ncurses libiconv libX11 libuuid ]; enableParallelBuilding = true; env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isGNU "-Wno-error=format-truncation"; /* - ** We have to fix a few occurrences to tools with absolute - ** paths in some helper scripts, otherwise the build will fail on - ** NixOS or in any chroot build. + ** We have to fix a few occurrences to tools with absolute + ** paths in some helper scripts, otherwise the build will fail on + ** NixOS or in any chroot build. */ patchPhase = '' substituteInPlace ./makefiles/installsh \ @@ -38,21 +53,19 @@ stdenv.mkDerivation (finalAttrs: { ''; /* - ** Don't use configureFlags, since that just implicitly appends - ** everything onto a --prefix flag, which ./configure gets very angry - ** about. - ** - ** Also, carefully set a manual workarea argument, so that we - ** can later easily find the machine type that we built Chez - ** for. + ** Don't use configureFlags, since that just implicitly appends + ** everything onto a --prefix flag, which ./configure gets very angry + ** about. + ** + ** Also, carefully set a manual workarea argument, so that we + ** can later easily find the machine type that we built Chez + ** for. */ configurePhase = '' ./configure --as-is --threads --installprefix=$out --installman=$out/share/man ''; - /* - ** Clean up some of the examples from the build output. - */ + # ** Clean up some of the examples from the build output. postInstall = '' rm -rf $out/lib/csv${finalAttrs.version}/examples ''; @@ -66,11 +79,11 @@ stdenv.mkDerivation (finalAttrs: { }; meta = { - description = "Powerful and incredibly fast R6RS Scheme compiler"; - homepage = "https://cisco.github.io/ChezScheme/"; - license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ thoughtpolice ]; - platforms = lib.platforms.unix; - mainProgram = "scheme"; + description = "Powerful and incredibly fast R6RS Scheme compiler"; + homepage = "https://cisco.github.io/ChezScheme/"; + license = lib.licenses.asl20; + maintainers = with lib.maintainers; [ thoughtpolice ]; + platforms = lib.platforms.unix; + mainProgram = "scheme"; }; }) diff --git a/pkgs/by-name/ch/chibi/package.nix b/pkgs/by-name/ch/chibi/package.nix index 9cdd21a6b955dd..5108d2c707f2e9 100644 --- a/pkgs/by-name/ch/chibi/package.nix +++ b/pkgs/by-name/ch/chibi/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, +}: stdenv.mkDerivation rec { version = "0.11"; diff --git a/pkgs/by-name/ch/chipmunk/package.nix b/pkgs/by-name/ch/chipmunk/package.nix index a0b34f0aa30f88..9e27bce8dcda66 100644 --- a/pkgs/by-name/ch/chipmunk/package.nix +++ b/pkgs/by-name/ch/chipmunk/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchurl, cmake, libglut, libGLU, libGL, glfw2, glew, libX11, xorgproto -, libXi, libXmu, fetchpatch, libXrandr +{ + lib, + stdenv, + fetchurl, + cmake, + libglut, + libGLU, + libGL, + glfw2, + glew, + libX11, + xorgproto, + libXi, + libXmu, + fetchpatch, + libXrandr, }: stdenv.mkDerivation rec { @@ -20,8 +34,18 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ cmake ]; - buildInputs = - [ libglut libGLU libGL glfw2 glew libX11 xorgproto libXi libXmu libXrandr ]; + buildInputs = [ + libglut + libGLU + libGL + glfw2 + glew + libX11 + xorgproto + libXi + libXmu + libXrandr + ]; postInstall = '' mkdir -p $out/bin diff --git a/pkgs/by-name/ch/chisel/package.nix b/pkgs/by-name/ch/chisel/package.nix index 293721cc63a3c9..8bcd2ccb54cc7f 100644 --- a/pkgs/by-name/ch/chisel/package.nix +++ b/pkgs/by-name/ch/chisel/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ch/chit/package.nix b/pkgs/by-name/ch/chit/package.nix index 7d140bf2a794e6..41ea368bc0250a 100644 --- a/pkgs/by-name/ch/chit/package.nix +++ b/pkgs/by-name/ch/chit/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, stdenv -, openssl -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + stdenv, + openssl, + darwin, }: rustPlatform.buildRustPackage rec { @@ -24,11 +25,13 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; # update Carg.lock to work with openssl 3 postPatch = '' diff --git a/pkgs/by-name/ch/chkcrontab/package.nix b/pkgs/by-name/ch/chkcrontab/package.nix index fa93446fa4fa72..f7aa1733c4749c 100644 --- a/pkgs/by-name/ch/chkcrontab/package.nix +++ b/pkgs/by-name/ch/chkcrontab/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchPypi }: +{ + lib, + python3, + fetchPypi, +}: with python3.pkgs; diff --git a/pkgs/by-name/ch/chkrootkit/package.nix b/pkgs/by-name/ch/chkrootkit/package.nix index ad14c1cd399739..c4f7a017803ebc 100644 --- a/pkgs/by-name/ch/chkrootkit/package.nix +++ b/pkgs/by-name/ch/chkrootkit/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, binutils-unwrapped }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + binutils-unwrapped, +}: stdenv.mkDerivation rec { pname = "chkrootkit"; diff --git a/pkgs/by-name/ch/chmlib/package.nix b/pkgs/by-name/ch/chmlib/package.nix index baa67d8fb267aa..6c3ce72e35760f 100644 --- a/pkgs/by-name/ch/chmlib/package.nix +++ b/pkgs/by-name/ch/chmlib/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "chmlib"; diff --git a/pkgs/by-name/ch/chntpw/package.nix b/pkgs/by-name/ch/chntpw/package.nix index 60cbed0f3d3d20..6687cd9ad69353 100644 --- a/pkgs/by-name/ch/chntpw/package.nix +++ b/pkgs/by-name/ch/chntpw/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, unzip, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + unzip, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "chntpw"; diff --git a/pkgs/by-name/ch/cholmod-extra/package.nix b/pkgs/by-name/ch/cholmod-extra/package.nix index 88053a41af69ec..8b6041fbb844c9 100644 --- a/pkgs/by-name/ch/cholmod-extra/package.nix +++ b/pkgs/by-name/ch/cholmod-extra/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, gfortran, suitesparse, blas, lapack }: +{ + lib, + stdenv, + fetchFromGitHub, + gfortran, + suitesparse, + blas, + lapack, +}: stdenv.mkDerivation rec { pname = "cholmod-extra"; version = "1.2.0"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ gfortran ]; - buildInputs = [ suitesparse blas lapack ]; + buildInputs = [ + suitesparse + blas + lapack + ]; makeFlags = [ "BLAS=-lcblas" diff --git a/pkgs/by-name/ch/chonburi-font/package.nix b/pkgs/by-name/ch/chonburi-font/package.nix index e3c4cddd7cae94..86e909d0038567 100644 --- a/pkgs/by-name/ch/chonburi-font/package.nix +++ b/pkgs/by-name/ch/chonburi-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "chonburi"; diff --git a/pkgs/by-name/ch/choose/package.nix b/pkgs/by-name/ch/choose/package.nix index b8508a82751135..179f53ad75b9de 100644 --- a/pkgs/by-name/ch/choose/package.nix +++ b/pkgs/by-name/ch/choose/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ch/chopchop/package.nix b/pkgs/by-name/ch/chopchop/package.nix index fc7bd0326fd468..5d75efb611d819 100644 --- a/pkgs/by-name/ch/chopchop/package.nix +++ b/pkgs/by-name/ch/chopchop/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ch/chow-centaur/package.nix b/pkgs/by-name/ch/chow-centaur/package.nix index 3b281aa9607848..3eced1b2fa2fac 100644 --- a/pkgs/by-name/ch/chow-centaur/package.nix +++ b/pkgs/by-name/ch/chow-centaur/package.nix @@ -1,6 +1,22 @@ -{ stdenv, lib, fetchFromGitHub, cmake, pkg-config, cairo, libxkbcommon -, xcbutilcursor, xcbutilkeysyms, xcbutil, libXrandr, libXinerama, libXcursor -, alsa-lib, libjack2, lv2, gcc-unwrapped }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + cairo, + libxkbcommon, + xcbutilcursor, + xcbutilkeysyms, + xcbutil, + libXrandr, + libXinerama, + libXcursor, + alsa-lib, + libjack2, + lv2, + gcc-unwrapped, +}: stdenv.mkDerivation (finalAttrs: { pname = "chow-centaur"; @@ -14,7 +30,10 @@ stdenv.mkDerivation (finalAttrs: { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ cairo libxkbcommon @@ -43,8 +62,7 @@ stdenv.mkDerivation (finalAttrs: { ''; meta = with lib; { - description = - "Digital emulation of the Klon Centaur guitar pedal using RNNs, Wave Digital Filters, and more"; + description = "Digital emulation of the Klon Centaur guitar pedal using RNNs, Wave Digital Filters, and more"; homepage = "https://github.com/jatinchowdhury18/KlonCentaur"; license = licenses.bsd3; platforms = [ "x86_64-linux" ]; diff --git a/pkgs/by-name/ch/chow-kick/package.nix b/pkgs/by-name/ch/chow-kick/package.nix index 435b8e0c9b0b9f..21291574d7c64c 100644 --- a/pkgs/by-name/ch/chow-kick/package.nix +++ b/pkgs/by-name/ch/chow-kick/package.nix @@ -1,38 +1,39 @@ -{ alsa-lib -, at-spi2-core -, brotli -, cmake -, curl -, dbus -, libepoxy -, fetchFromGitHub -, libglut -, freetype -, gtk2-x11 -, lib -, libGL -, libXcursor -, libXdmcp -, libXext -, libXinerama -, libXrandr -, libXtst -, libdatrie -, libjack2 -, libpsl -, libselinux -, libsepol -, libsysprof-capture -, libthai -, libxkbcommon -, lv2 -, pcre -, pkg-config -, python3 -, sqlite -, stdenv -, util-linuxMinimal -, webkitgtk_4_0 +{ + alsa-lib, + at-spi2-core, + brotli, + cmake, + curl, + dbus, + libepoxy, + fetchFromGitHub, + libglut, + freetype, + gtk2-x11, + lib, + libGL, + libXcursor, + libXdmcp, + libXext, + libXinerama, + libXrandr, + libXtst, + libdatrie, + libjack2, + libpsl, + libselinux, + libsepol, + libsysprof-capture, + libthai, + libxkbcommon, + lv2, + pcre, + pkg-config, + python3, + sqlite, + stdenv, + util-linuxMinimal, + webkitgtk_4_0, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ch/chow-phaser/package.nix b/pkgs/by-name/ch/chow-phaser/package.nix index 87f22c9da1c57b..bce17eeef4a959 100644 --- a/pkgs/by-name/ch/chow-phaser/package.nix +++ b/pkgs/by-name/ch/chow-phaser/package.nix @@ -1,8 +1,37 @@ -{ alsa-lib, at-spi2-core, cmake, curl, dbus, libepoxy, fetchFromGitHub, libglut -, freetype, gcc-unwrapped, gtk3, lib, libGL, libXcursor, libXdmcp, libXext -, libXinerama, libXrandr, libXtst, libdatrie, libjack2, libpsl, libselinux -, libsepol, libsysprof-capture, libthai, libxkbcommon, pcre, pkg-config -, python3, sqlite, stdenv }: +{ + alsa-lib, + at-spi2-core, + cmake, + curl, + dbus, + libepoxy, + fetchFromGitHub, + libglut, + freetype, + gcc-unwrapped, + gtk3, + lib, + libGL, + libXcursor, + libXdmcp, + libXext, + libXinerama, + libXrandr, + libXtst, + libdatrie, + libjack2, + libpsl, + libselinux, + libsepol, + libsysprof-capture, + libthai, + libxkbcommon, + pcre, + pkg-config, + python3, + sqlite, + stdenv, +}: stdenv.mkDerivation (finalAttrs: { pname = "chow-phaser"; @@ -16,7 +45,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-9wo7ZFMruG3QNvlpILSvrFh/Sx6J1qnlWc8+aQyS4tQ="; }; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; buildInputs = [ alsa-lib diff --git a/pkgs/by-name/ch/chow-tape-model/package.nix b/pkgs/by-name/ch/chow-tape-model/package.nix index 9e9e3ae6b3417b..a0fb380ed79178 100644 --- a/pkgs/by-name/ch/chow-tape-model/package.nix +++ b/pkgs/by-name/ch/chow-tape-model/package.nix @@ -1,38 +1,39 @@ -{ alsa-lib -, at-spi2-core -, cmake -, curl -, dbus -, libepoxy -, fetchFromGitHub -, libglut -, freetype -, gtk3 -, lib -, libGL -, libXcursor -, libXdmcp -, libXext -, libXinerama -, libXrandr -, libXtst -, libdatrie -, libjack2 -, libpsl -, libselinux -, libsepol -, libsysprof-capture -, libthai -, libuuid -, libxkbcommon -, lv2 -, pcre -, pcre2 -, pkg-config -, python3 -, sqlite -, gcc11Stdenv -, webkitgtk_4_0 +{ + alsa-lib, + at-spi2-core, + cmake, + curl, + dbus, + libepoxy, + fetchFromGitHub, + libglut, + freetype, + gtk3, + lib, + libGL, + libXcursor, + libXdmcp, + libXext, + libXinerama, + libXrandr, + libXtst, + libdatrie, + libjack2, + libpsl, + libselinux, + libsepol, + libsysprof-capture, + libthai, + libuuid, + libxkbcommon, + lv2, + pcre, + pcre2, + pkg-config, + python3, + sqlite, + gcc11Stdenv, + webkitgtk_4_0, }: let # JUCE version in submodules is incompatible with GCC12 @@ -51,7 +52,10 @@ stdenv.mkDerivation (finalAttrs: { fetchSubmodules = true; }; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; buildInputs = [ alsa-lib @@ -109,18 +113,19 @@ stdenv.mkDerivation (finalAttrs: { # JUCE dlopens these, make sure they are in rpath # Otherwise, segfault will happen - NIX_LDFLAGS = (toString [ - "-lX11" - "-lXext" - "-lXcursor" - "-lXinerama" - "-lXrandr" - ]); + NIX_LDFLAGS = ( + toString [ + "-lX11" + "-lXext" + "-lXcursor" + "-lXinerama" + "-lXrandr" + ] + ); meta = with lib; { homepage = "https://github.com/jatinchowdhury18/AnalogTapeModel"; - description = - "Physical modelling signal processing for analog tape recording. LV2, VST3, CLAP, and standalone"; + description = "Physical modelling signal processing for analog tape recording. LV2, VST3, CLAP, and standalone"; license = with licenses; [ gpl3Only ]; maintainers = with maintainers; [ magnetophon ]; platforms = platforms.linux; diff --git a/pkgs/by-name/ch/chroma/package.nix b/pkgs/by-name/ch/chroma/package.nix index e577451af16575..379fd6384bdcd8 100644 --- a/pkgs/by-name/ch/chroma/package.nix +++ b/pkgs/by-name/ch/chroma/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: let srcInfo = lib.importJSON ./src.json; @@ -11,9 +15,9 @@ buildGoModule rec { # To update: # nix-prefetch-git --rev v${version} https://github.com/alecthomas/chroma.git > src.json src = fetchFromGitHub { - owner = "alecthomas"; - repo = pname; - rev = "v${version}"; + owner = "alecthomas"; + repo = pname; + rev = "v${version}"; inherit (srcInfo) sha256; }; @@ -23,9 +27,12 @@ buildGoModule rec { # substitute version info as done in goreleaser builds ldflags = [ - "-X" "main.version=${version}" - "-X" "main.commit=${srcInfo.rev}" - "-X" "main.date=${srcInfo.date}" + "-X" + "main.version=${version}" + "-X" + "main.commit=${srcInfo.rev}" + "-X" + "main.date=${srcInfo.date}" ]; meta = with lib; { diff --git a/pkgs/by-name/ch/chromatic/package.nix b/pkgs/by-name/ch/chromatic/package.nix index 0598bababaa66a..32a518b36ce99b 100644 --- a/pkgs/by-name/ch/chromatic/package.nix +++ b/pkgs/by-name/ch/chromatic/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, meson -, ninja -, pkg-config -, rustc -, cargo -, wrapGAppsHook4 -, desktop-file-utils -, libxml2 -, libadwaita -, portaudio -, libpulseaudio +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + meson, + ninja, + pkg-config, + rustc, + cargo, + wrapGAppsHook4, + desktop-file-utils, + libxml2, + libadwaita, + portaudio, + libpulseaudio, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ch/chrome-export/package.nix b/pkgs/by-name/ch/chrome-export/package.nix index d3f4878ee6918d..0825613aad5948 100644 --- a/pkgs/by-name/ch/chrome-export/package.nix +++ b/pkgs/by-name/ch/chrome-export/package.nix @@ -1,5 +1,8 @@ -{ lib, stdenv, fetchFromGitHub -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + python3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ch/chromium-bsu/package.nix b/pkgs/by-name/ch/chromium-bsu/package.nix index 135110028f431a..dffa9617c7f669 100644 --- a/pkgs/by-name/ch/chromium-bsu/package.nix +++ b/pkgs/by-name/ch/chromium-bsu/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchurl -, SDL2 -, SDL2_image -, SDL2_mixer -, fontconfig -, freealut -, libglut -, ftgl -, gettext -, glpng -, libGL -, libGLU -, openal -, pkg-config -, quesoglc +{ + lib, + stdenv, + fetchurl, + SDL2, + SDL2_image, + SDL2_mixer, + fontconfig, + freealut, + libglut, + ftgl, + gettext, + glpng, + libGL, + libGLU, + openal, + pkg-config, + quesoglc, }: stdenv.mkDerivation rec { @@ -51,7 +52,6 @@ stdenv.mkDerivation rec { "--disable-sdlmixer" ]; - postInstall = '' install -D misc/chromium-bsu.png $out/share/pixmaps/chromium-bsu.png install -D misc/chromium-bsu.desktop $out/share/applications/chromium-bsu.desktop diff --git a/pkgs/by-name/ch/chrpath/package.nix b/pkgs/by-name/ch/chrpath/package.nix index 6116eb7d467958..f1834792006bef 100644 --- a/pkgs/by-name/ch/chrpath/package.nix +++ b/pkgs/by-name/ch/chrpath/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "chrpath"; diff --git a/pkgs/by-name/ch/chruby-fish/package.nix b/pkgs/by-name/ch/chruby-fish/package.nix index 6268c740e21270..620a63c1fa524d 100644 --- a/pkgs/by-name/ch/chruby-fish/package.nix +++ b/pkgs/by-name/ch/chruby-fish/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, chruby }: +{ + stdenv, + lib, + fetchFromGitHub, + chruby, +}: stdenv.mkDerivation rec { pname = "chruby-fish"; diff --git a/pkgs/by-name/ch/cht-sh/package.nix b/pkgs/by-name/ch/cht-sh/package.nix index a8b3f62d5a3a4c..0cba6cd2e58c2a 100644 --- a/pkgs/by-name/ch/cht-sh/package.nix +++ b/pkgs/by-name/ch/cht-sh/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, unstableGitUpdater -, makeWrapper -, curl -, ncurses -, rlwrap -, xsel +{ + lib, + stdenv, + fetchFromGitHub, + unstableGitUpdater, + makeWrapper, + curl, + ncurses, + rlwrap, + xsel, }: stdenv.mkDerivation { @@ -33,7 +35,14 @@ stdenv.mkDerivation { cp share/zsh.txt $out/share/zsh/site-functions/_cht wrapProgram "$out/bin/cht.sh" \ - --prefix PATH : "${lib.makeBinPath [ curl rlwrap ncurses xsel ]}" + --prefix PATH : "${ + lib.makeBinPath [ + curl + rlwrap + ncurses + xsel + ] + }" ''; passthru.updateScript = unstableGitUpdater { @@ -43,7 +52,10 @@ stdenv.mkDerivation { meta = with lib; { description = "CLI client for cheat.sh, a community driven cheat sheet"; license = licenses.mit; - maintainers = with maintainers; [ fgaz evanjs ]; + maintainers = with maintainers; [ + fgaz + evanjs + ]; homepage = "https://github.com/chubin/cheat.sh"; mainProgram = "cht.sh"; }; diff --git a/pkgs/by-name/ch/chunk/package.nix b/pkgs/by-name/ch/chunk/package.nix index eb25cdf40f7326..829593338f232f 100644 --- a/pkgs/by-name/ch/chunk/package.nix +++ b/pkgs/by-name/ch/chunk/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, +}: stdenvNoCC.mkDerivation { pname = "chunk"; diff --git a/pkgs/by-name/ch/chunkfs/package.nix b/pkgs/by-name/ch/chunkfs/package.nix index e77da2d712bb84..60efcdf476671e 100644 --- a/pkgs/by-name/ch/chunkfs/package.nix +++ b/pkgs/by-name/ch/chunkfs/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, perl, fuse }: +{ + lib, + stdenv, + fetchurl, + perl, + fuse, +}: stdenv.mkDerivation rec { version = "0.7"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "4c168fc2b265a6ba34afc565707ea738f34375325763c0596f2cfa1c9b8d40f1"; }; - buildInputs = [perl fuse]; + buildInputs = [ + perl + fuse + ]; makeFlags = [ "DESTDIR=$(out)" diff --git a/pkgs/by-name/ch/chunksync/package.nix b/pkgs/by-name/ch/chunksync/package.nix index 49142f77807c82..fe49a2747df13f 100644 --- a/pkgs/by-name/ch/chunksync/package.nix +++ b/pkgs/by-name/ch/chunksync/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, openssl, perl }: +{ + lib, + stdenv, + fetchurl, + openssl, + perl, +}: stdenv.mkDerivation rec { version = "0.4"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1gwqp1kjwhcmwhynilakhzpzgc0c6kk8c9vkpi30gwwrwpz3cf00"; }; - buildInputs = [openssl perl]; + buildInputs = [ + openssl + perl + ]; NIX_LDFLAGS = "-lgcc_s"; diff --git a/pkgs/by-name/ci/ci-edit/package.nix b/pkgs/by-name/ci/ci-edit/package.nix index 3d8a4b541dd4e8..02963c7e382cfa 100644 --- a/pkgs/by-name/ci/ci-edit/package.nix +++ b/pkgs/by-name/ci/ci-edit/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication { diff --git a/pkgs/by-name/ci/ciao/package.nix b/pkgs/by-name/ci/ciao/package.nix index d7c215de005fe1..025ec757b86b5a 100644 --- a/pkgs/by-name/ci/ciao/package.nix +++ b/pkgs/by-name/ci/ciao/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "ciao"; diff --git a/pkgs/by-name/ci/cicero-tui/package.nix b/pkgs/by-name/ci/cicero-tui/package.nix index 0ab33112a6e3b5..fef7e630400d75 100644 --- a/pkgs/by-name/ci/cicero-tui/package.nix +++ b/pkgs/by-name/ci/cicero-tui/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, cmake -, pkg-config -, expat -, fontconfig -, freetype +{ + lib, + rustPlatform, + fetchFromGitHub, + cmake, + pkg-config, + expat, + fontconfig, + freetype, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ci/cider/package.nix b/pkgs/by-name/ci/cider/package.nix index 9941cbe79b5d8a..c4754a06da6bde 100644 --- a/pkgs/by-name/ci/cider/package.nix +++ b/pkgs/by-name/ci/cider/package.nix @@ -1,4 +1,9 @@ -{ appimageTools, lib, fetchurl, makeWrapper}: +{ + appimageTools, + lib, + fetchurl, + makeWrapper, +}: appimageTools.wrapType2 rec { pname = "cider"; @@ -12,8 +17,10 @@ appimageTools.wrapType2 rec { nativeBuildInputs = [ makeWrapper ]; extraInstallCommands = - let contents = appimageTools.extract { inherit pname version src; }; - in '' + let + contents = appimageTools.extract { inherit pname version src; }; + in + '' wrapProgram $out/bin/${pname} \ --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" diff --git a/pkgs/by-name/ci/cidr-merger/package.nix b/pkgs/by-name/ci/cidr-merger/package.nix index d9e7591573fe15..5626be5d1d91b8 100644 --- a/pkgs/by-name/ci/cidr-merger/package.nix +++ b/pkgs/by-name/ci/cidr-merger/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ci/cidrgrep/package.nix b/pkgs/by-name/ci/cidrgrep/package.nix index ddc67097fb28af..df286927c489de 100644 --- a/pkgs/by-name/ci/cidrgrep/package.nix +++ b/pkgs/by-name/ci/cidrgrep/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule { pname = "cidrgrep"; diff --git a/pkgs/by-name/ci/cie-middleware-linux/package.nix b/pkgs/by-name/ci/cie-middleware-linux/package.nix index 11c0567bb6f081..ed97589ec95a92 100644 --- a/pkgs/by-name/ci/cie-middleware-linux/package.nix +++ b/pkgs/by-name/ci/cie-middleware-linux/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitHub -, makeWrapper -, stripJavaArchivesHook -, meson -, ninja -, pkg-config -, gradle_8 -, curl -, cryptopp -, fontconfig -, jre -, libxml2 -, openssl -, pcsclite -, podofo -, ghostscript +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + stripJavaArchivesHook, + meson, + ninja, + pkg-config, + gradle_8, + curl, + cryptopp, + fontconfig, + jre, + libxml2, + openssl, + pcsclite, + podofo, + ghostscript, }: let @@ -79,7 +80,8 @@ stdenv.mkDerivation { gradleFlags = [ "-Dorg.gradle.java.home=${jre}" - "--build-file" "cie-java/build.gradle" + "--build-file" + "cie-java/build.gradle" ]; gradleBuildTask = "standalone"; diff --git a/pkgs/by-name/ci/ciel/package.nix b/pkgs/by-name/ci/ciel/package.nix index cb138486955703..fa603f3d9f267c 100644 --- a/pkgs/by-name/ci/ciel/package.nix +++ b/pkgs/by-name/ci/ciel/package.nix @@ -1,16 +1,17 @@ -{ lib -, bash -, dbus -, fetchFromGitHub -, installShellFiles -, libgit2 -, libssh2 -, openssl -, pkg-config -, rustPlatform -, systemd -, xz -, zlib +{ + lib, + bash, + dbus, + fetchFromGitHub, + installShellFiles, + libgit2, + libssh2, + openssl, + pkg-config, + rustPlatform, + systemd, + xz, + zlib, }: rustPlatform.buildRustPackage rec { @@ -31,11 +32,23 @@ rustPlatform.buildRustPackage rec { }; }; - nativeBuildInputs = [ pkg-config installShellFiles ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; # ciel has plugins which is actually bash scripts. # Therefore, bash is required for plugins to work. - buildInputs = [ bash systemd dbus openssl libssh2 libgit2 xz zlib ]; + buildInputs = [ + bash + systemd + dbus + openssl + libssh2 + libgit2 + xz + zlib + ]; postInstall = '' mv -v "$out/bin/ciel-rs" "$out/bin/ciel" @@ -55,7 +68,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/AOSC-Dev/ciel-rs"; license = licenses.mit; platforms = platforms.linux; - maintainers = with maintainers; [ A1ca7raz yisuidenghua ]; + maintainers = with maintainers; [ + A1ca7raz + yisuidenghua + ]; mainProgram = "ciel"; }; } diff --git a/pkgs/by-name/ci/ciftilib/package.nix b/pkgs/by-name/ci/ciftilib/package.nix index 85b0b1c8a0e5b0..e50f84820b52ac 100644 --- a/pkgs/by-name/ci/ciftilib/package.nix +++ b/pkgs/by-name/ci/ciftilib/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, boost -, libxmlxx -, pkg-config -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + libxmlxx, + pkg-config, + zlib, }: stdenv.mkDerivation rec { @@ -19,8 +20,15 @@ stdenv.mkDerivation rec { hash = "sha256-xc2dpMse4SozYEV/w3rXCrh1LKpTThq5nHB2y5uAD0A="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ boost libxmlxx zlib ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + boost + libxmlxx + zlib + ]; cmakeFlags = [ "-DCMAKE_CTEST_ARGUMENTS=--exclude-regex;'big|datatype-md5'" ]; diff --git a/pkgs/by-name/ci/cimg/package.nix b/pkgs/by-name/ci/cimg/package.nix index a5112b2107203a..3c0b917a81a043 100644 --- a/pkgs/by-name/ci/cimg/package.nix +++ b/pkgs/by-name/ci/cimg/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, gmic -, gmic-qt +{ + lib, + stdenv, + fetchFromGitHub, + gmic, + gmic-qt, }: stdenv.mkDerivation (finalAttrs: { @@ -16,7 +17,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-Abe7mSbdj06MossUQXCKZPzzfyvJyRVeLfzINYNPv4g="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/ci/cinelerra/package.nix b/pkgs/by-name/ci/cinelerra/package.nix index 6bad50d9e453e2..adbaf1de6f806b 100644 --- a/pkgs/by-name/ci/cinelerra/package.nix +++ b/pkgs/by-name/ci/cinelerra/package.nix @@ -1,45 +1,46 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, libtool -, pkg-config -, faad2 -, faac -, a52dec -, alsa-lib -, fftw -, lame -, libavc1394 -, libiec61883 -, libraw1394 -, libsndfile -, libvorbis -, libogg -, libjpeg -, libtiff -, freetype -, mjpegtools -, x264 -, gettext -, openexr -, libXext -, libXxf86vm -, libXv -, libXi -, libX11 -, libXft -, xorgproto -, libtheora -, libpng -, libdv -, libuuid -, file -, nasm -, perl -, fontconfig -, intltool +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + pkg-config, + faad2, + faac, + a52dec, + alsa-lib, + fftw, + lame, + libavc1394, + libiec61883, + libraw1394, + libsndfile, + libvorbis, + libogg, + libjpeg, + libtiff, + freetype, + mjpegtools, + x264, + gettext, + openexr, + libXext, + libXxf86vm, + libXv, + libXi, + libX11, + libXft, + xorgproto, + libtheora, + libpng, + libdv, + libuuid, + file, + nasm, + perl, + fontconfig, + intltool, }: stdenv.mkDerivation { @@ -66,7 +67,14 @@ stdenv.mkDerivation { enableParallelBuilding = true; - nativeBuildInputs = [ automake autoconf libtool pkg-config file intltool ]; + nativeBuildInputs = [ + automake + autoconf + libtool + pkg-config + file + intltool + ]; buildInputs = [ faad2 diff --git a/pkgs/by-name/ci/cinnamon-common/package.nix b/pkgs/by-name/ci/cinnamon-common/package.nix index 473b96380662c2..8b4fd0a6bbd465 100644 --- a/pkgs/by-name/ci/cinnamon-common/package.nix +++ b/pkgs/by-name/ci/cinnamon-common/package.nix @@ -1,74 +1,77 @@ -{ atk -, cacert -, dbus -, cinnamon-control-center -, cinnamon-desktop -, cinnamon-menus -, cinnamon-session -, cinnamon-translations -, cjs -, evolution-data-server -, fetchFromGitHub -, gcr -, gdk-pixbuf -, gettext -, libgnomekbd -, glib -, gobject-introspection -, gsound -, gtk3 -, intltool -, json-glib -, libsecret -, libstartup_notification -, libXtst -, libXdamage -, mesa -, muffin -, networkmanager -, pkg-config -, polkit -, lib -, stdenv -, wrapGAppsHook3 -, libxml2 -, gtk-doc -, caribou -, python3 -, keybinder3 -, cairo -, xapp -, upower -, nemo -, libnotify -, accountsservice -, gnome-online-accounts -, glib-networking -, pciutils -, timezonemap -, libnma -, meson -, ninja -, gst_all_1 -, perl +{ + atk, + cacert, + dbus, + cinnamon-control-center, + cinnamon-desktop, + cinnamon-menus, + cinnamon-session, + cinnamon-translations, + cjs, + evolution-data-server, + fetchFromGitHub, + gcr, + gdk-pixbuf, + gettext, + libgnomekbd, + glib, + gobject-introspection, + gsound, + gtk3, + intltool, + json-glib, + libsecret, + libstartup_notification, + libXtst, + libXdamage, + mesa, + muffin, + networkmanager, + pkg-config, + polkit, + lib, + stdenv, + wrapGAppsHook3, + libxml2, + gtk-doc, + caribou, + python3, + keybinder3, + cairo, + xapp, + upower, + nemo, + libnotify, + accountsservice, + gnome-online-accounts, + glib-networking, + pciutils, + timezonemap, + libnma, + meson, + ninja, + gst_all_1, + perl, }: let - pythonEnv = python3.withPackages (pp: with pp; [ - dbus-python - setproctitle - pygobject3 - pycairo - python-xapp - pillow - pyinotify # for looking-glass - pytz - tinycss2 - python-pam - pexpect - distro - requests - ]); + pythonEnv = python3.withPackages ( + pp: with pp; [ + dbus-python + setproctitle + pygobject3 + pycairo + python-xapp + pillow + pyinotify # for looking-glass + pytz + tinycss2 + python-pam + pexpect + distro + requests + ] + ); in # TODO (after 25.05 branch-off): Rename to pkgs.cinnamon stdenv.mkDerivation rec { @@ -198,7 +201,11 @@ stdenv.mkDerivation rec { ''; passthru = { - providedSessions = [ "cinnamon" "cinnamon2d" "cinnamon-wayland" ]; + providedSessions = [ + "cinnamon" + "cinnamon2d" + "cinnamon-wayland" + ]; }; meta = with lib; { diff --git a/pkgs/by-name/ci/cinnamon-control-center/package.nix b/pkgs/by-name/ci/cinnamon-control-center/package.nix index 34ca22fab3af86..4bceb08d110f83 100644 --- a/pkgs/by-name/ci/cinnamon-control-center/package.nix +++ b/pkgs/by-name/ci/cinnamon-control-center/package.nix @@ -1,34 +1,35 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, glib -, glib-networking -, gettext -, cinnamon-desktop -, gtk3 -, libnotify -, libxml2 -, colord -, polkit -, libxkbfile -, cinnamon-menus -, libgnomekbd -, libxklavier -, networkmanager -, libgudev -, libwacom -, wrapGAppsHook3 -, glibc -, libnma -, modemmanager -, xorg -, gdk-pixbuf -, meson -, ninja -, cinnamon-translations -, python3 -, upower +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + glib, + glib-networking, + gettext, + cinnamon-desktop, + gtk3, + libnotify, + libxml2, + colord, + polkit, + libxkbfile, + cinnamon-menus, + libgnomekbd, + libxklavier, + networkmanager, + libgudev, + libwacom, + wrapGAppsHook3, + glibc, + libnma, + modemmanager, + xorg, + gdk-pixbuf, + meson, + ninja, + cinnamon-translations, + python3, + upower, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ci/cinnamon-desktop/package.nix b/pkgs/by-name/ci/cinnamon-desktop/package.nix index d69797b0d77601..9855c58eaf6e38 100644 --- a/pkgs/by-name/ci/cinnamon-desktop/package.nix +++ b/pkgs/by-name/ci/cinnamon-desktop/package.nix @@ -1,21 +1,22 @@ -{ fetchFromGitHub -, gdk-pixbuf -, gobject-introspection -, gtk3 -, intltool -, isocodes -, meson -, ninja -, pkg-config -, pulseaudio -, python3 -, lib -, stdenv -, systemd -, xkeyboard_config -, xorg -, wrapGAppsHook3 -, glib +{ + fetchFromGitHub, + gdk-pixbuf, + gobject-introspection, + gtk3, + intltool, + isocodes, + meson, + ninja, + pkg-config, + pulseaudio, + python3, + lib, + stdenv, + systemd, + xkeyboard_config, + xorg, + wrapGAppsHook3, + glib, }: stdenv.mkDerivation rec { @@ -29,7 +30,10 @@ stdenv.mkDerivation rec { hash = "sha256-YKGVuT28MLcLO9T8ZJqbHqMN0SAn1P1l8JTDBo4n838="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; propagatedBuildInputs = [ glib @@ -75,7 +79,10 @@ stdenv.mkDerivation rec { gtk-doc. ''; - license = [ licenses.gpl2 licenses.lgpl2 ]; + license = [ + licenses.gpl2 + licenses.lgpl2 + ]; platforms = platforms.linux; maintainers = teams.cinnamon.members; }; diff --git a/pkgs/by-name/ci/cinnamon-gsettings-overrides/package.nix b/pkgs/by-name/ci/cinnamon-gsettings-overrides/package.nix index 0969fb11233903..52bf50d5abb869 100644 --- a/pkgs/by-name/ci/cinnamon-gsettings-overrides/package.nix +++ b/pkgs/by-name/ci/cinnamon-gsettings-overrides/package.nix @@ -1,21 +1,22 @@ -{ lib -, runCommand -, glib -, gnome-terminal -, gtk3 -, gsettings-desktop-schemas -, extraGSettingsOverrides ? "" -, extraGSettingsOverridePackages ? [ ] -, mint-artwork +{ + lib, + runCommand, + glib, + gnome-terminal, + gtk3, + gsettings-desktop-schemas, + extraGSettingsOverrides ? "", + extraGSettingsOverridePackages ? [ ], + mint-artwork, -, muffin -, nemo -, xapp -, cinnamon-desktop -, cinnamon-session -, cinnamon-settings-daemon -, cinnamon-common -, bulky + muffin, + nemo, + xapp, + cinnamon-desktop, + cinnamon-session, + cinnamon-settings-daemon, + cinnamon-common, + bulky, }: let @@ -53,20 +54,22 @@ let in # TODO: Having https://github.com/NixOS/nixpkgs/issues/54150 would supersede this -runCommand "cinnamon-gsettings-overrides" { preferLocalBuild = true; } - '' - data_dir="$out/share/gsettings-schemas/nixos-gsettings-overrides" - schema_dir="$data_dir/glib-2.0/schemas" +runCommand "cinnamon-gsettings-overrides" { preferLocalBuild = true; } '' + data_dir="$out/share/gsettings-schemas/nixos-gsettings-overrides" + schema_dir="$data_dir/glib-2.0/schemas" - mkdir -p "$schema_dir" + mkdir -p "$schema_dir" - ${concatMapStringsSep "\n" (pkg: "cp -rf \"${glib.getSchemaPath pkg}\"/*.xml \"${glib.getSchemaPath pkg}\"/*.gschema.override \"$schema_dir\"") gsettingsOverridePackages} + ${concatMapStringsSep "\n" ( + pkg: + "cp -rf \"${glib.getSchemaPath pkg}\"/*.xml \"${glib.getSchemaPath pkg}\"/*.gschema.override \"$schema_dir\"" + ) gsettingsOverridePackages} - chmod -R a+w "$data_dir" + chmod -R a+w "$data_dir" - cat - > "$schema_dir/nixos-defaults.gschema.override" <<- EOF - ${gsettingsOverrides} - EOF + cat - > "$schema_dir/nixos-defaults.gschema.override" <<- EOF + ${gsettingsOverrides} + EOF - ${glib.dev}/bin/glib-compile-schemas --strict "$schema_dir" - '' + ${glib.dev}/bin/glib-compile-schemas --strict "$schema_dir" +'' diff --git a/pkgs/by-name/ci/cinnamon-menus/package.nix b/pkgs/by-name/ci/cinnamon-menus/package.nix index 6177303fa9db21..69b5656f5c0b8c 100644 --- a/pkgs/by-name/ci/cinnamon-menus/package.nix +++ b/pkgs/by-name/ci/cinnamon-menus/package.nix @@ -1,12 +1,13 @@ -{ fetchFromGitHub -, glib -, gobject-introspection -, meson -, ninja -, pkg-config -, lib -, stdenv -, wrapGAppsHook3 +{ + fetchFromGitHub, + glib, + gobject-introspection, + meson, + ninja, + pkg-config, + lib, + stdenv, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -35,7 +36,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/linuxmint/cinnamon-menus"; description = "Menu system for the Cinnamon project"; - license = [ licenses.gpl2 licenses.lgpl2 ]; + license = [ + licenses.gpl2 + licenses.lgpl2 + ]; platforms = platforms.linux; maintainers = teams.cinnamon.members; }; diff --git a/pkgs/by-name/ci/cinnamon-screensaver/package.nix b/pkgs/by-name/ci/cinnamon-screensaver/package.nix index 23e963088e19a9..003587cc15f6f4 100644 --- a/pkgs/by-name/ci/cinnamon-screensaver/package.nix +++ b/pkgs/by-name/ci/cinnamon-screensaver/package.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, meson -, ninja -, glib -, dbus -, gettext -, cinnamon-desktop -, cinnamon-common -, intltool -, libxslt -, gtk3 -, libgnomekbd -, caribou -, libtool -, wrapGAppsHook3 -, gobject-introspection -, python3 -, pam -, cairo -, xapp -, xdotool -, xorg -, iso-flags-png-320x240 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + meson, + ninja, + glib, + dbus, + gettext, + cinnamon-desktop, + cinnamon-common, + intltool, + libxslt, + gtk3, + libgnomekbd, + caribou, + libtool, + wrapGAppsHook3, + gobject-introspection, + python3, + pam, + cairo, + xapp, + xdotool, + xorg, + iso-flags-png-320x240, }: stdenv.mkDerivation rec { @@ -66,12 +67,14 @@ stdenv.mkDerivation rec { xorg.libX11 xorg.libXrandr - (python3.withPackages (pp: with pp; [ - pygobject3 - setproctitle - python-xapp - pycairo - ])) + (python3.withPackages ( + pp: with pp; [ + pygobject3 + setproctitle + python-xapp + pycairo + ] + )) xapp xdotool pam @@ -105,7 +108,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/linuxmint/cinnamon-screensaver"; description = "Cinnamon screen locker and screensaver program"; - license = [ licenses.gpl2 licenses.lgpl2 ]; + license = [ + licenses.gpl2 + licenses.lgpl2 + ]; platforms = platforms.linux; maintainers = teams.cinnamon.members; }; diff --git a/pkgs/by-name/ci/cinnamon-session/package.nix b/pkgs/by-name/ci/cinnamon-session/package.nix index d6c58c0ac8a897..d56661073c6c0d 100644 --- a/pkgs/by-name/ci/cinnamon-session/package.nix +++ b/pkgs/by-name/ci/cinnamon-session/package.nix @@ -1,33 +1,36 @@ -{ fetchFromGitHub -, cinnamon-desktop -, cinnamon-settings-daemon -, cinnamon-translations -, dbus-glib -, glib -, gsettings-desktop-schemas -, gtk3 -, libcanberra -, libxslt -, meson -, ninja -, pkg-config -, python3 -, lib -, stdenv -, systemd -, wrapGAppsHook3 -, xapp -, xorg -, libexecinfo -, pango +{ + fetchFromGitHub, + cinnamon-desktop, + cinnamon-settings-daemon, + cinnamon-translations, + dbus-glib, + glib, + gsettings-desktop-schemas, + gtk3, + libcanberra, + libxslt, + meson, + ninja, + pkg-config, + python3, + lib, + stdenv, + systemd, + wrapGAppsHook3, + xapp, + xorg, + libexecinfo, + pango, }: let - pythonEnv = python3.withPackages (pp: with pp; [ - python-xapp - pygobject3 - setproctitle - ]); + pythonEnv = python3.withPackages ( + pp: with pp; [ + python-xapp + pygobject3 + setproctitle + ] + ); in stdenv.mkDerivation rec { pname = "cinnamon-session"; diff --git a/pkgs/by-name/ci/cinnamon-settings-daemon/package.nix b/pkgs/by-name/ci/cinnamon-settings-daemon/package.nix index 1844fd9795afef..9df1417065872f 100644 --- a/pkgs/by-name/ci/cinnamon-settings-daemon/package.nix +++ b/pkgs/by-name/ci/cinnamon-settings-daemon/package.nix @@ -1,33 +1,34 @@ -{ fetchFromGitHub -, cinnamon-desktop -, cinnamon-translations -, colord -, glib -, gsettings-desktop-schemas -, gtk3 -, lcms2 -, libcanberra-gtk3 -, libgnomekbd -, libnotify -, libxklavier -, wrapGAppsHook3 -, pkg-config -, lib -, stdenv -, systemd -, upower -, dconf -, cups -, polkit -, librsvg -, libwacom -, xorg -, fontconfig -, tzdata -, nss -, libgudev -, meson -, ninja +{ + fetchFromGitHub, + cinnamon-desktop, + cinnamon-translations, + colord, + glib, + gsettings-desktop-schemas, + gtk3, + lcms2, + libcanberra-gtk3, + libgnomekbd, + libnotify, + libxklavier, + wrapGAppsHook3, + pkg-config, + lib, + stdenv, + systemd, + upower, + dconf, + cups, + polkit, + librsvg, + libwacom, + xorg, + fontconfig, + tzdata, + nss, + libgudev, + meson, + ninja, }: stdenv.mkDerivation rec { @@ -79,7 +80,10 @@ stdenv.mkDerivation rec { pkg-config ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postPatch = '' sed "s|/usr/share/zoneinfo|${tzdata}/share/zoneinfo|g" -i plugins/datetime/system-timezone.h diff --git a/pkgs/by-name/ci/cinnamon-translations/package.nix b/pkgs/by-name/ci/cinnamon-translations/package.nix index d00203246da873..e2a7a7fc042907 100644 --- a/pkgs/by-name/ci/cinnamon-translations/package.nix +++ b/pkgs/by-name/ci/cinnamon-translations/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, gettext +{ + lib, + stdenv, + fetchFromGitHub, + gettext, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ci/cinzel/package.nix b/pkgs/by-name/ci/cinzel/package.nix index 21e22474a342e9..db499054965e0f 100644 --- a/pkgs/by-name/ci/cinzel/package.nix +++ b/pkgs/by-name/ci/cinzel/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenvNoCC, fetchFromGitHub, rename, nix-update-script }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + rename, + nix-update-script, +}: stdenvNoCC.mkDerivation { pname = "cinzel"; @@ -11,7 +17,10 @@ stdenvNoCC.mkDerivation { hash = "sha256-V3vSxe5eHN0BUplzmmBchzuV+gz36WfgZZezJ6NfaWg="; }; - outputs = [ "out" "variable" ]; + outputs = [ + "out" + "variable" + ]; nativeBuildInputs = [ rename ]; diff --git a/pkgs/by-name/ci/ciopfs/package.nix b/pkgs/by-name/ci/ciopfs/package.nix index 56de051012bd38..b2f0c62fc109b8 100644 --- a/pkgs/by-name/ci/ciopfs/package.nix +++ b/pkgs/by-name/ci/ciopfs/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, fuse, glib, attr }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + fuse, + glib, + attr, +}: stdenv.mkDerivation rec { pname = "ciopfs"; @@ -10,9 +18,16 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ fuse glib attr ]; + buildInputs = [ + fuse + glib + attr + ]; - makeFlags = [ "DESTDIR=$(out)" "PREFIX=" ]; + makeFlags = [ + "DESTDIR=$(out)" + "PREFIX=" + ]; meta = { homepage = "https://www.brain-dump.org/projects/ciopfs/"; diff --git a/pkgs/by-name/ci/cipher/package.nix b/pkgs/by-name/ci/cipher/package.nix index f4416738e0e83d..b93049e9d4d218 100644 --- a/pkgs/by-name/ci/cipher/package.nix +++ b/pkgs/by-name/ci/cipher/package.nix @@ -1,17 +1,20 @@ -{ lib, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, vala -, pkg-config -, pantheon -, python3 -, gettext -, glib -, gtk3 -, libgee -, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + vala, + pkg-config, + pantheon, + python3, + gettext, + glib, + gtk3, + libgee, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "cipher"; diff --git a/pkgs/by-name/ci/circle-flags/package.nix b/pkgs/by-name/ci/circle-flags/package.nix index eed82fbdbb47ab..5f7bd2ece3032b 100644 --- a/pkgs/by-name/ci/circle-flags/package.nix +++ b/pkgs/by-name/ci/circle-flags/package.nix @@ -1,7 +1,8 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, nix-update-script +{ + stdenvNoCC, + lib, + fetchFromGitHub, + nix-update-script, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ci/circleci-cli/package.nix b/pkgs/by-name/ci/circleci-cli/package.nix index dae7e367214590..111cc27f1e2968 100644 --- a/pkgs/by-name/ci/circleci-cli/package.nix +++ b/pkgs/by-name/ci/circleci-cli/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, installShellFiles }: +{ + lib, + fetchFromGitHub, + buildGoModule, + installShellFiles, +}: buildGoModule rec { pname = "circleci-cli"; @@ -17,7 +22,13 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X github.com/CircleCI-Public/circleci-cli/version.Version=${version}" "-X github.com/CircleCI-Public/circleci-cli/version.Commit=${src.rev}" "-X github.com/CircleCI-Public/circleci-cli/version.packageManager=nix" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/CircleCI-Public/circleci-cli/version.Version=${version}" + "-X github.com/CircleCI-Public/circleci-cli/version.Commit=${src.rev}" + "-X github.com/CircleCI-Public/circleci-cli/version.packageManager=nix" + ]; postInstall = '' mv $out/bin/circleci-cli $out/bin/circleci diff --git a/pkgs/by-name/ci/circom/package.nix b/pkgs/by-name/ci/circom/package.nix index 7728755ffac77e..e1ec6888dae56a 100644 --- a/pkgs/by-name/ci/circom/package.nix +++ b/pkgs/by-name/ci/circom/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ci/circumflex/package.nix b/pkgs/by-name/ci/circumflex/package.nix index 354bc383271ade..926a660f0a663c 100644 --- a/pkgs/by-name/ci/circumflex/package.nix +++ b/pkgs/by-name/ci/circumflex/package.nix @@ -1,4 +1,11 @@ -{ lib, less, ncurses, buildGoModule, fetchFromGitHub, makeWrapper }: +{ + lib, + less, + ncurses, + buildGoModule, + fetchFromGitHub, + makeWrapper, +}: buildGoModule rec { pname = "circumflex"; @@ -17,7 +24,12 @@ buildGoModule rec { postInstall = '' wrapProgram $out/bin/clx \ - --prefix PATH : ${lib.makeBinPath [ less ncurses ]} + --prefix PATH : ${ + lib.makeBinPath [ + less + ncurses + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/ci/cirrus-cli/package.nix b/pkgs/by-name/ci/cirrus-cli/package.nix index ed0d08ac6381cf..38615c75551d19 100644 --- a/pkgs/by-name/ci/cirrus-cli/package.nix +++ b/pkgs/by-name/ci/cirrus-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, installShellFiles +{ + lib, + fetchFromGitHub, + buildGoModule, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/ci/cirrusgo/package.nix b/pkgs/by-name/ci/cirrusgo/package.nix index d7301dd604bda6..27b88bc477dfcd 100644 --- a/pkgs/by-name/ci/cirrusgo/package.nix +++ b/pkgs/by-name/ci/cirrusgo/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ci/ciscoPacketTracer7/package.nix b/pkgs/by-name/ci/ciscoPacketTracer7/package.nix index b4faca4118f267..f91e6612a00405 100644 --- a/pkgs/by-name/ci/ciscoPacketTracer7/package.nix +++ b/pkgs/by-name/ci/ciscoPacketTracer7/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, buildFHSEnv -, copyDesktopItems -, dpkg -, lndir -, makeDesktopItem -, makeWrapper -, requireFile +{ + stdenv, + lib, + buildFHSEnv, + copyDesktopItems, + dpkg, + lndir, + makeDesktopItem, + makeWrapper, + requireFile, }: let @@ -18,12 +19,15 @@ let dontUnpack = true; src = requireFile { - name = "PacketTracer_${builtins.replaceStrings ["."] [""] version}_amd64.deb"; + name = "PacketTracer_${builtins.replaceStrings [ "." ] [ "" ] version}_amd64.deb"; hash = "sha256-w5gC0V3WHQC6J/uMEW2kX9hWKrS0mZZVWtZriN6s4n8="; url = "https://www.netacad.com"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; installPhase = '' dpkg-deb -x $src $out @@ -37,7 +41,11 @@ let desktopName = "Cisco Packet Tracer 7"; icon = "${ptFiles}/opt/pt/art/app.png"; exec = "packettracer7 %f"; - mimeTypes = [ "application/x-pkt" "application/x-pka" "application/x-pkz" ]; + mimeTypes = [ + "application/x-pkt" + "application/x-pka" + "application/x-pkz" + ]; }; fhs = buildFHSEnv { @@ -45,27 +53,29 @@ let inherit version; runScript = "${ptFiles}/bin/packettracer7"; - targetPkgs = pkgs: with pkgs; [ - alsa-lib - dbus - expat - fontconfig - glib - libglvnd - libpulseaudio - libudev0-shim - libxkbcommon - libxml2 - libxslt - nspr - nss - xorg.libICE - xorg.libSM - xorg.libX11 - xorg.libXScrnSaver - ]; + targetPkgs = + pkgs: with pkgs; [ + alsa-lib + dbus + expat + fontconfig + glib + libglvnd + libpulseaudio + libudev0-shim + libxkbcommon + libxml2 + libxslt + nspr + nss + xorg.libICE + xorg.libSM + xorg.libX11 + xorg.libXScrnSaver + ]; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "ciscoPacketTracer7"; inherit version; diff --git a/pkgs/by-name/ci/citations/package.nix b/pkgs/by-name/ci/citations/package.nix index 178a0e25cbf6a7..f515dbf72567b0 100644 --- a/pkgs/by-name/ci/citations/package.nix +++ b/pkgs/by-name/ci/citations/package.nix @@ -1,23 +1,24 @@ -{ cargo -, darwin -, desktop-file-utils -, fetchFromGitLab -, gettext -, glib -, gtk4 -, gtksourceview5 -, lib -, libadwaita -, meson -, ninja -, pkg-config -, poppler -, rustPlatform -, rustc -, stdenv -, testers -, wrapGAppsHook4 -, clippy +{ + cargo, + darwin, + desktop-file-utils, + fetchFromGitLab, + gettext, + glib, + gtk4, + gtksourceview5, + lib, + libadwaita, + meson, + ninja, + pkg-config, + poppler, + rustPlatform, + rustc, + stdenv, + testers, + wrapGAppsHook4, + clippy, }: stdenv.mkDerivation (finalAttrs: { @@ -50,22 +51,26 @@ stdenv.mkDerivation (finalAttrs: { wrapGAppsHook4 ]; - buildInputs = [ - glib - gtk4 - gtksourceview5 - libadwaita - poppler - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + glib + gtk4 + gtksourceview5 + libadwaita + poppler + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ]; - env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang (lib.concatStringsSep " " [ - "-Wno-typedef-redefinition" - "-Wno-unused-parameter" - "-Wno-missing-field-initializers" - "-Wno-incompatible-function-pointer-types" - ]); + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang ( + lib.concatStringsSep " " [ + "-Wno-typedef-redefinition" + "-Wno-unused-parameter" + "-Wno-missing-field-initializers" + "-Wno-incompatible-function-pointer-types" + ] + ); doCheck = true; diff --git a/pkgs/by-name/ci/citron/package.nix b/pkgs/by-name/ci/citron/package.nix index d40c8c93692832..b04f6f2a7fe05b 100644 --- a/pkgs/by-name/ci/citron/package.nix +++ b/pkgs/by-name/ci/citron/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchCrate -, dbus -, installShellFiles -, pkg-config +{ + lib, + rustPlatform, + fetchCrate, + dbus, + installShellFiles, + pkg-config, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { buildInputs = [ dbus ]; - nativeBuildInputs = [ installShellFiles pkg-config ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + ]; postInstall = '' installManPage doc/citron.1 diff --git a/pkgs/by-name/ci/civetweb/package.nix b/pkgs/by-name/ci/civetweb/package.nix index f6fe616957d600..319813b40e76db 100644 --- a/pkgs/by-name/ci/civetweb/package.nix +++ b/pkgs/by-name/ci/civetweb/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { @@ -15,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-Qh6BGPk7a01YzCeX42+Og9M+fjXRs7kzNUCyT4mYab4="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; strictDeps = true; diff --git a/pkgs/by-name/cj/cjdns-tools/package.nix b/pkgs/by-name/cj/cjdns-tools/package.nix index dc76ce190760bb..9e68412928e663 100644 --- a/pkgs/by-name/cj/cjdns-tools/package.nix +++ b/pkgs/by-name/cj/cjdns-tools/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, cjdns -, nodejs -, makeWrapper -, lib +{ + stdenv, + cjdns, + nodejs, + makeWrapper, + lib, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/cj/cjdns/package.nix b/pkgs/by-name/cj/cjdns/package.nix index c60e853a7d2154..9d4bd485c7994e 100644 --- a/pkgs/by-name/cj/cjdns/package.nix +++ b/pkgs/by-name/cj/cjdns/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, nodejs -, which -, python39 -, libuv -, util-linux -, nixosTests -, libsodium -, pkg-config -, substituteAll +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + nodejs, + which, + python39, + libuv, + util-linux, + nixosTests, + libsodium, + pkg-config, + substituteAll, }: rustPlatform.buildRustPackage rec { @@ -38,12 +39,14 @@ rustPlatform.buildRustPackage rec { }; }; - nativeBuildInputs = [ - which - python39 - nodejs - pkg-config - ] ++ + nativeBuildInputs = + [ + which + python39 + nodejs + pkg-config + ] + ++ # for flock lib.optional stdenv.hostPlatform.isLinux util-linux; @@ -53,14 +56,17 @@ rustPlatform.buildRustPackage rec { ]; env.SODIUM_USE_PKG_CONFIG = 1; - env.NIX_CFLAGS_COMPILE = toString ([ - "-O2" - "-Wno-error=array-bounds" - "-Wno-error=stringop-overflow" - "-Wno-error=stringop-truncation" - ] ++ lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "11") [ - "-Wno-error=stringop-overread" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-O2" + "-Wno-error=array-bounds" + "-Wno-error=stringop-overflow" + "-Wno-error=stringop-truncation" + ] + ++ lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "11") [ + "-Wno-error=stringop-overread" + ] + ); passthru.tests.basic = nixosTests.cjdns; diff --git a/pkgs/by-name/cj/cjose/package.nix b/pkgs/by-name/cj/cjose/package.nix index 3b0d448a353035..53785ab7cec04f 100644 --- a/pkgs/by-name/cj/cjose/package.nix +++ b/pkgs/by-name/cj/cjose/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, pkg-config -, doxygen -, check -, jansson -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + doxygen, + check, + jansson, + openssl, }: stdenv.mkDerivation rec { @@ -29,8 +30,15 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config doxygen ]; - buildInputs = [ jansson openssl ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + doxygen + ]; + buildInputs = [ + jansson + openssl + ]; nativeCheckInputs = [ check ]; configureFlags = [ diff --git a/pkgs/by-name/cj/cjs/package.nix b/pkgs/by-name/cj/cjs/package.nix index 8203ad4a9ecd38..0c9fce38f4153d 100644 --- a/pkgs/by-name/cj/cjs/package.nix +++ b/pkgs/by-name/cj/cjs/package.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchFromGitHub -, gobject-introspection -, pkg-config -, cairo -, glib -, readline -, libsysprof-capture -, spidermonkey_115 -, meson -, mesonEmulatorHook -, dbus -, ninja -, which -, libxml2 +{ + stdenv, + lib, + fetchFromGitHub, + gobject-introspection, + pkg-config, + cairo, + glib, + readline, + libsysprof-capture, + spidermonkey_115, + meson, + mesonEmulatorHook, + dbus, + ninja, + which, + libxml2, }: stdenv.mkDerivation rec { @@ -27,21 +28,26 @@ stdenv.mkDerivation rec { hash = "sha256-2lkIWroOo3hxu9/L/Ty7CADzVrZ0ohyHVmm65NoNlD4="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; strictDeps = true; - nativeBuildInputs = [ - meson - ninja - pkg-config - which # for locale detection - libxml2 # for xml-stripblanks - dbus # for dbus-run-session - gobject-introspection - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + which # for locale detection + libxml2 # for xml-stripblanks + dbus # for dbus-run-session + gobject-introspection + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ cairo diff --git a/pkgs/by-name/cj/cjson/package.nix b/pkgs/by-name/cj/cjson/package.nix index 38be1c30cd468f..d344e5ad45ec13 100644 --- a/pkgs/by-name/cj/cjson/package.nix +++ b/pkgs/by-name/cj/cjson/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, cmake }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "cjson"; diff --git a/pkgs/by-name/ck/ckan/package.nix b/pkgs/by-name/ck/ckan/package.nix index e0a73c0d0a0ad7..ba33a673758238 100644 --- a/pkgs/by-name/ck/ckan/package.nix +++ b/pkgs/by-name/ck/ckan/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeWrapper, mono, gtk2, curl }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + mono, + gtk2, + curl, +}: stdenv.mkDerivation rec { pname = "ckan"; @@ -14,7 +22,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; buildInputs = [ mono ]; - libraries = lib.makeLibraryPath [ gtk2 curl ]; + libraries = lib.makeLibraryPath [ + gtk2 + curl + ]; dontBuild = true; @@ -30,7 +41,10 @@ stdenv.mkDerivation rec { mainProgram = "ckan"; homepage = "https://github.com/KSP-CKAN/CKAN"; license = licenses.mit; - maintainers = with maintainers; [ Baughn ymarkus ]; + maintainers = with maintainers; [ + Baughn + ymarkus + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/ck/cksfv/package.nix b/pkgs/by-name/ck/cksfv/package.nix index aae8f227ddeb78..6d78486c8d6f4f 100644 --- a/pkgs/by-name/ck/cksfv/package.nix +++ b/pkgs/by-name/ck/cksfv/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "cksfv"; diff --git a/pkgs/by-name/cl/cl-launch/package.nix b/pkgs/by-name/cl/cl-launch/package.nix index 35cfd01ff9252b..3b1f8b6bad4b79 100644 --- a/pkgs/by-name/cl/cl-launch/package.nix +++ b/pkgs/by-name/cl/cl-launch/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "cl-launch"; version = "4.1.4.1"; diff --git a/pkgs/by-name/cl/cl-wordle/package.nix b/pkgs/by-name/cl/cl-wordle/package.nix index 8765638b051c06..1c36860d212215 100644 --- a/pkgs/by-name/cl/cl-wordle/package.nix +++ b/pkgs/by-name/cl/cl-wordle/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "cl-wordle"; diff --git a/pkgs/by-name/cl/cl/package.nix b/pkgs/by-name/cl/cl/package.nix index 1f98635f15ddc8..67058ed6bf859b 100644 --- a/pkgs/by-name/cl/cl/package.nix +++ b/pkgs/by-name/cl/cl/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, rebar, erlang, opencl-headers, ocl-icd }: +{ + lib, + stdenv, + fetchFromGitHub, + rebar, + erlang, + opencl-headers, + ocl-icd, +}: stdenv.mkDerivation rec { version = "1.2.4"; @@ -17,7 +25,12 @@ stdenv.mkDerivation rec { --replace "-m64" "" ''; - buildInputs = [ erlang rebar opencl-headers ocl-icd ]; + buildInputs = [ + erlang + rebar + opencl-headers + ocl-icd + ]; buildPhase = '' rebar compile diff --git a/pkgs/by-name/cl/clac/package.nix b/pkgs/by-name/cl/clac/package.nix index f154a9fa7ab32f..515817e4189da8 100644 --- a/pkgs/by-name/cl/clac/package.nix +++ b/pkgs/by-name/cl/clac/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "clac"; diff --git a/pkgs/by-name/cl/clair/package.nix b/pkgs/by-name/cl/clair/package.nix index 3c07a5e7756c51..c0f1450e05c111 100644 --- a/pkgs/by-name/cl/clair/package.nix +++ b/pkgs/by-name/cl/clair/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, rpm -, xz +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + rpm, + xz, }: buildGoModule rec { @@ -36,7 +37,12 @@ buildGoModule rec { postInstall = '' wrapProgram $out/bin/clair \ - --prefix PATH : "${lib.makeBinPath [ rpm xz ]}" + --prefix PATH : "${ + lib.makeBinPath [ + rpm + xz + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/cl/clairvoyance/package.nix b/pkgs/by-name/cl/clairvoyance/package.nix index ca308604749435..b89f785c642a5a 100644 --- a/pkgs/by-name/cl/clairvoyance/package.nix +++ b/pkgs/by-name/cl/clairvoyance/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/cl/clairvoyant/package.nix b/pkgs/by-name/cl/clairvoyant/package.nix index 80ca50a0934ff6..68a68dcb37d13c 100644 --- a/pkgs/by-name/cl/clairvoyant/package.nix +++ b/pkgs/by-name/cl/clairvoyant/package.nix @@ -1,14 +1,15 @@ -{ lib -, fetchFromGitHub -, gtk4 -, libadwaita -, libportal -, meson -, ninja -, pkg-config -, stdenv -, vala -, wrapGAppsHook4 +{ + lib, + fetchFromGitHub, + gtk4, + libadwaita, + libportal, + meson, + ninja, + pkg-config, + stdenv, + vala, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/cl/clamsmtp/package.nix b/pkgs/by-name/cl/clamsmtp/package.nix index b3f825f7148b96..a54a48da5bc83c 100644 --- a/pkgs/by-name/cl/clamsmtp/package.nix +++ b/pkgs/by-name/cl/clamsmtp/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "clamsmtp"; diff --git a/pkgs/by-name/cl/clamtk/package.nix b/pkgs/by-name/cl/clamtk/package.nix index 67c82e52a400a8..32d807ee32f720 100644 --- a/pkgs/by-name/cl/clamtk/package.nix +++ b/pkgs/by-name/cl/clamtk/package.nix @@ -1,10 +1,11 @@ -{ lib -, perlPackages -, fetchFromGitHub -, wrapGAppsHook3 -, gobject-introspection -, perl -, clamav +{ + lib, + perlPackages, + fetchFromGitHub, + wrapGAppsHook3, + gobject-introspection, + perl, + clamav, }: perlPackages.buildPerlPackage rec { @@ -18,14 +19,31 @@ perlPackages.buildPerlPackage rec { hash = "sha256-ClBsBXbGj67zgrkA9EjgK7s3OmXOJA+xV5xLGOcMsbI="; }; - nativeBuildInputs = [ wrapGAppsHook3 gobject-introspection ]; - buildInputs = [ perl clamav ]; - propagatedBuildInputs = with perlPackages; [ Glib LWP LWPProtocolHttps TextCSV JSON LocaleGettext Gtk3 ]; + nativeBuildInputs = [ + wrapGAppsHook3 + gobject-introspection + ]; + buildInputs = [ + perl + clamav + ]; + propagatedBuildInputs = with perlPackages; [ + Glib + LWP + LWPProtocolHttps + TextCSV + JSON + LocaleGettext + Gtk3 + ]; preConfigure = "touch Makefile.PL"; # no tests implemented doCheck = false; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; postPatch = '' # Set correct nix paths in perl scripts @@ -71,7 +89,10 @@ perlPackages.buildPerlPackage rec { license = licenses.gpl1Plus; homepage = "https://github.com/dave-theunsub/clamtk"; platforms = platforms.linux; - maintainers = with maintainers; [ chewblacka ShamrockLee ]; + maintainers = with maintainers; [ + chewblacka + ShamrockLee + ]; }; } diff --git a/pkgs/by-name/cl/clangbuildanalyzer/package.nix b/pkgs/by-name/cl/clangbuildanalyzer/package.nix index 5fa21806f2d4f1..e2f3828e393d14 100644 --- a/pkgs/by-name/cl/clangbuildanalyzer/package.nix +++ b/pkgs/by-name/cl/clangbuildanalyzer/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, cmake, fetchFromGitHub }: +{ + stdenv, + lib, + cmake, + fetchFromGitHub, +}: stdenv.mkDerivation (finalAttrs: { pname = "clangbuildanalyzer"; version = "1.5.0"; diff --git a/pkgs/by-name/cl/clap/package.nix b/pkgs/by-name/cl/clap/package.nix index 7bd9dca846f1d6..15543b4c50b714 100644 --- a/pkgs/by-name/cl/clap/package.nix +++ b/pkgs/by-name/cl/clap/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, testers +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + testers, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/cl/clapboard/package.nix b/pkgs/by-name/cl/clapboard/package.nix index 4f14de873375ef..022e17029826da 100644 --- a/pkgs/by-name/cl/clapboard/package.nix +++ b/pkgs/by-name/cl/clapboard/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/cl/clapper/package.nix b/pkgs/by-name/cl/clapper/package.nix index d33f1d27608147..9d23eda1830ccf 100644 --- a/pkgs/by-name/cl/clapper/package.nix +++ b/pkgs/by-name/cl/clapper/package.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchFromGitHub -, gobject-introspection -, pkg-config -, ninja -, desktop-file-utils -, makeWrapper -, shared-mime-info -, wrapGAppsHook4 -, meson -, gtk4 -, gst_all_1 -, libGL -, libadwaita -, libsoup_3 -, vala -, cmake -, libmicrodns -, gtuber -, glib-networking +{ + lib, + stdenv, + fetchFromGitHub, + gobject-introspection, + pkg-config, + ninja, + desktop-file-utils, + makeWrapper, + shared-mime-info, + wrapGAppsHook4, + meson, + gtk4, + gst_all_1, + libGL, + libadwaita, + libsoup_3, + vala, + cmake, + libmicrodns, + gtuber, + glib-networking, }: stdenv.mkDerivation (finalAttrs: { @@ -26,9 +27,9 @@ stdenv.mkDerivation (finalAttrs: { version = "0.6.1"; src = fetchFromGitHub { - owner = "Rafostar"; - repo = "clapper"; - rev = finalAttrs.version; + owner = "Rafostar"; + repo = "clapper"; + rev = finalAttrs.version; hash = "sha256-IQJTnLB6FzYYPONOqBkvi89iF0U6fx/aWYvNOOJpBvc="; }; diff --git a/pkgs/by-name/cl/clarity-city/package.nix b/pkgs/by-name/cl/clarity-city/package.nix index ef332436b1a9a6..b8d68fa7c15d43 100644 --- a/pkgs/by-name/cl/clarity-city/package.nix +++ b/pkgs/by-name/cl/clarity-city/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "clarity-city"; diff --git a/pkgs/by-name/cl/clash-meta/package.nix b/pkgs/by-name/cl/clash-meta/package.nix index 552a8729e861df..be36755d7ac6a9 100644 --- a/pkgs/by-name/cl/clash-meta/package.nix +++ b/pkgs/by-name/cl/clash-meta/package.nix @@ -1,13 +1,15 @@ { mihomo }: -mihomo.overrideAttrs (finalAttrs: previousAttrs: { - pname = "clash-meta"; +mihomo.overrideAttrs ( + finalAttrs: previousAttrs: { + pname = "clash-meta"; - postInstall = '' - mv $out/bin/${previousAttrs.meta.mainProgram} $out/bin/${finalAttrs.meta.mainProgram} - ''; + postInstall = '' + mv $out/bin/${previousAttrs.meta.mainProgram} $out/bin/${finalAttrs.meta.mainProgram} + ''; - meta = previousAttrs.meta // { - mainProgram = "clash-meta"; - }; -}) + meta = previousAttrs.meta // { + mainProgram = "clash-meta"; + }; + } +) diff --git a/pkgs/by-name/cl/classads/package.nix b/pkgs/by-name/cl/classads/package.nix index 0442c7d21209d9..7902c5672cf467 100644 --- a/pkgs/by-name/cl/classads/package.nix +++ b/pkgs/by-name/cl/classads/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pcre }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pcre, +}: stdenv.mkDerivation rec { pname = "classads"; @@ -14,11 +20,14 @@ stdenv.mkDerivation rec { buildInputs = [ pcre ]; configureFlags = [ - "--enable-namespace" "--enable-flexible-member" + "--enable-namespace" + "--enable-flexible-member" ]; # error: use of undeclared identifier 'finite'; did you mean 'isfinite'? - env.NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) "-Dfinite=isfinite"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 + ) "-Dfinite=isfinite"; meta = { homepage = "http://www.cs.wisc.edu/condor/classad/"; diff --git a/pkgs/by-name/cl/classicube/package.nix b/pkgs/by-name/cl/classicube/package.nix index e17c8bffd33606..dd5beefbafe682 100644 --- a/pkgs/by-name/cl/classicube/package.nix +++ b/pkgs/by-name/cl/classicube/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, dos2unix -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, libX11 -, libXi -, libGL -, curl -, openal -, liberation_ttf +{ + lib, + stdenv, + fetchFromGitHub, + dos2unix, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + libX11, + libXi, + libGL, + curl, + openal, + liberation_ttf, }: stdenv.mkDerivation rec { @@ -24,7 +25,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-ZITyfxkQB4Jpm2ZsQyM+ouPLqCVmGB7UZRXDSU/BX0k="; }; - nativeBuildInputs = [ dos2unix makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + dos2unix + makeWrapper + copyDesktopItems + ]; desktopItems = [ (makeDesktopItem { @@ -68,7 +73,14 @@ stdenv.mkDerivation rec { --replace 'JOBS=1' "JOBS=$NIX_BUILD_CORES" ''; - buildInputs = [ libX11 libXi libGL curl openal liberation_ttf ]; + buildInputs = [ + libX11 + libXi + libGL + curl + openal + liberation_ttf + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/cl/clatd/package.nix b/pkgs/by-name/cl/clatd/package.nix index 8bbee164ecb269..fc5e9a792cee6b 100644 --- a/pkgs/by-name/cl/clatd/package.nix +++ b/pkgs/by-name/cl/clatd/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, perl -, perlPackages -, tayga -, iproute2 -, iptables -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + perl, + perlPackages, + tayga, + iproute2, + iptables, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cl/claws-mail/package.nix b/pkgs/by-name/cl/claws-mail/package.nix index 523d6971dfdb5a..fab432500bdac6 100644 --- a/pkgs/by-name/cl/claws-mail/package.nix +++ b/pkgs/by-name/cl/claws-mail/package.nix @@ -1,100 +1,279 @@ -{ stdenv, lib, fetchurl, wrapGAppsHook3, autoreconfHook, bison, flex -, curl, gtk3, pkg-config, python3, shared-mime-info -, glib-networking, gsettings-desktop-schemas - -# Package compatibility: old parameters whose name were not directly derived -, enablePgp ? true -, enablePluginNotificationDialogs ? true -, enablePluginNotificationSounds ? true -, enablePluginPdf ? true -, enablePluginRavatar ? true -, enableSpellcheck ? true - -# Arguments to include external libraries -, enableLibSM ? true, xorg -, enableGnuTLS ? true, gnutls -, enableEnchant ? enableSpellcheck, enchant -, enableDbus ? true, dbus, dbus-glib -, enableLdap ? true, openldap -, enableNetworkManager ? true, networkmanager -, enableLibetpan ? true, libetpan -, enableValgrind ? !stdenv.hostPlatform.isDarwin && lib.meta.availableOn stdenv.hostPlatform valgrind, valgrind -, enableSvg ? true, librsvg - -# Configure claws-mail's plugins -, enablePluginAcpiNotifier ? true -, enablePluginAddressKeeper ? true -, enablePluginArchive ? true, libarchive -, enablePluginAttRemover ? true -, enablePluginAttachWarner ? true -, enablePluginBogofilter ? true -, enablePluginBsfilter ? true -, enablePluginClamd ? true -, enablePluginDillo ? true -, enablePluginFancy ? true, webkitgtk_4_0 -, enablePluginFetchInfo ? true -, enablePluginKeywordWarner ? true -, enablePluginLibravatar ? enablePluginRavatar -, enablePluginLitehtmlViewer ? true, gumbo -, enablePluginMailmbox ? true -, enablePluginManageSieve ? true -, enablePluginNewMail ? true -, enablePluginNotification ? (enablePluginNotificationDialogs || enablePluginNotificationSounds), libcanberra-gtk3, libnotify -, enablePluginPdfViewer ? enablePluginPdf, poppler -, enablePluginPerl ? true, perl -, enablePluginPython ? true -, enablePluginPgp ? enablePgp, gnupg, gpgme -, enablePluginRssyl ? true, libxml2 -, enablePluginSmime ? true -, enablePluginSpamassassin ? true -, enablePluginSpamReport ? true -, enablePluginTnefParse ? true, libytnef -, enablePluginVcalendar ? true, libical +{ + stdenv, + lib, + fetchurl, + wrapGAppsHook3, + autoreconfHook, + bison, + flex, + curl, + gtk3, + pkg-config, + python3, + shared-mime-info, + glib-networking, + gsettings-desktop-schemas, + + # Package compatibility: old parameters whose name were not directly derived + enablePgp ? true, + enablePluginNotificationDialogs ? true, + enablePluginNotificationSounds ? true, + enablePluginPdf ? true, + enablePluginRavatar ? true, + enableSpellcheck ? true, + + # Arguments to include external libraries + enableLibSM ? true, + xorg, + enableGnuTLS ? true, + gnutls, + enableEnchant ? enableSpellcheck, + enchant, + enableDbus ? true, + dbus, + dbus-glib, + enableLdap ? true, + openldap, + enableNetworkManager ? true, + networkmanager, + enableLibetpan ? true, + libetpan, + enableValgrind ? !stdenv.hostPlatform.isDarwin && lib.meta.availableOn stdenv.hostPlatform valgrind, + valgrind, + enableSvg ? true, + librsvg, + + # Configure claws-mail's plugins + enablePluginAcpiNotifier ? true, + enablePluginAddressKeeper ? true, + enablePluginArchive ? true, + libarchive, + enablePluginAttRemover ? true, + enablePluginAttachWarner ? true, + enablePluginBogofilter ? true, + enablePluginBsfilter ? true, + enablePluginClamd ? true, + enablePluginDillo ? true, + enablePluginFancy ? true, + webkitgtk_4_0, + enablePluginFetchInfo ? true, + enablePluginKeywordWarner ? true, + enablePluginLibravatar ? enablePluginRavatar, + enablePluginLitehtmlViewer ? true, + gumbo, + enablePluginMailmbox ? true, + enablePluginManageSieve ? true, + enablePluginNewMail ? true, + enablePluginNotification ? (enablePluginNotificationDialogs || enablePluginNotificationSounds), + libcanberra-gtk3, + libnotify, + enablePluginPdfViewer ? enablePluginPdf, + poppler, + enablePluginPerl ? true, + perl, + enablePluginPython ? true, + enablePluginPgp ? enablePgp, + gnupg, + gpgme, + enablePluginRssyl ? true, + libxml2, + enablePluginSmime ? true, + enablePluginSpamassassin ? true, + enablePluginSpamReport ? true, + enablePluginTnefParse ? true, + libytnef, + enablePluginVcalendar ? true, + libical, }: let - pythonPkgs = with python3.pkgs; [ python3 wrapPython pygobject3 ]; + pythonPkgs = with python3.pkgs; [ + python3 + wrapPython + pygobject3 + ]; features = [ - { flags = [ "acpi_notifier-plugin" ]; enabled = enablePluginAcpiNotifier; } - { flags = [ "address_keeper-plugin" ]; enabled = enablePluginAddressKeeper; } - { flags = [ "archive-plugin" ]; enabled = enablePluginArchive; deps = [ libarchive ]; } - { flags = [ "att_remover-plugin" ]; enabled = enablePluginAttRemover; } - { flags = [ "attachwarner-plugin" ]; enabled = enablePluginAttachWarner; } - { flags = [ "bogofilter-plugin" ]; enabled = enablePluginBogofilter; } - { flags = [ "bsfilter-plugin" ]; enabled = enablePluginBsfilter; } - { flags = [ "clamd-plugin" ]; enabled = enablePluginClamd; } - { flags = [ "dbus" ]; enabled = enableDbus; deps = [ dbus dbus-glib ]; } - { flags = [ "dillo-plugin" ]; enabled = enablePluginDillo; } - { flags = [ "enchant" ]; enabled = enableEnchant; deps = [ enchant ]; } - { flags = [ "fancy-plugin" ]; enabled = enablePluginFancy; deps = [ webkitgtk_4_0 ]; } - { flags = [ "fetchinfo-plugin" ]; enabled = enablePluginFetchInfo; } - { flags = [ "keyword_warner-plugin" ]; enabled = enablePluginKeywordWarner; } - { flags = [ "gnutls" ]; enabled = enableGnuTLS; deps = [ gnutls ]; } - { flags = [ "ldap" ]; enabled = enableLdap; deps = [ openldap ]; } - { flags = [ "libetpan" ]; enabled = enableLibetpan; deps = [ libetpan ]; } - { flags = [ "libravatar-plugin" ]; enabled = enablePluginLibravatar; } - { flags = [ "libsm" ]; enabled = enableLibSM; deps = [ xorg.libSM ]; } - { flags = [ "litehtml_viewer-plugin" ]; enabled = enablePluginLitehtmlViewer; deps = [ gumbo ]; } - { flags = [ "mailmbox-plugin" ]; enabled = enablePluginMailmbox; } - { flags = [ "managesieve-plugin" ]; enabled = enablePluginManageSieve; } - { flags = [ "networkmanager" ]; enabled = enableNetworkManager; deps = [ networkmanager ]; } - { flags = [ "newmail-plugin" ]; enabled = enablePluginNewMail; } - { flags = [ "notification-plugin" ]; enabled = enablePluginNotification; deps = [ libnotify ] ++ [libcanberra-gtk3]; } - { flags = [ "pdf_viewer-plugin" ]; enabled = enablePluginPdfViewer; deps = [ poppler ]; } - { flags = [ "perl-plugin" ]; enabled = enablePluginPerl; deps = [ perl ]; } - { flags = [ "pgpcore-plugin" "pgpinline-plugin" "pgpmime-plugin" ]; enabled = enablePluginPgp; deps = [ gnupg gpgme ]; } - { flags = [ "python-plugin" ]; enabled = enablePluginPython; } - { flags = [ "rssyl-plugin" ]; enabled = enablePluginRssyl; deps = [ libxml2 ]; } - { flags = [ "smime-plugin" ]; enabled = enablePluginSmime; } - { flags = [ "spam_report-plugin" ]; enabled = enablePluginSpamReport; } - { flags = [ "spamassassin-plugin" ]; enabled = enablePluginSpamassassin; } - { flags = [ "svg" ]; enabled = enableSvg; deps = [ librsvg ]; } - { flags = [ "tnef_parse-plugin" ]; enabled = enablePluginTnefParse; deps = [ libytnef ]; } - { flags = [ "valgrind" ]; enabled = enableValgrind; deps = [ valgrind ]; } - { flags = [ "vcalendar-plugin" ]; enabled = enablePluginVcalendar; deps = [ libical ]; } + { + flags = [ "acpi_notifier-plugin" ]; + enabled = enablePluginAcpiNotifier; + } + { + flags = [ "address_keeper-plugin" ]; + enabled = enablePluginAddressKeeper; + } + { + flags = [ "archive-plugin" ]; + enabled = enablePluginArchive; + deps = [ libarchive ]; + } + { + flags = [ "att_remover-plugin" ]; + enabled = enablePluginAttRemover; + } + { + flags = [ "attachwarner-plugin" ]; + enabled = enablePluginAttachWarner; + } + { + flags = [ "bogofilter-plugin" ]; + enabled = enablePluginBogofilter; + } + { + flags = [ "bsfilter-plugin" ]; + enabled = enablePluginBsfilter; + } + { + flags = [ "clamd-plugin" ]; + enabled = enablePluginClamd; + } + { + flags = [ "dbus" ]; + enabled = enableDbus; + deps = [ + dbus + dbus-glib + ]; + } + { + flags = [ "dillo-plugin" ]; + enabled = enablePluginDillo; + } + { + flags = [ "enchant" ]; + enabled = enableEnchant; + deps = [ enchant ]; + } + { + flags = [ "fancy-plugin" ]; + enabled = enablePluginFancy; + deps = [ webkitgtk_4_0 ]; + } + { + flags = [ "fetchinfo-plugin" ]; + enabled = enablePluginFetchInfo; + } + { + flags = [ "keyword_warner-plugin" ]; + enabled = enablePluginKeywordWarner; + } + { + flags = [ "gnutls" ]; + enabled = enableGnuTLS; + deps = [ gnutls ]; + } + { + flags = [ "ldap" ]; + enabled = enableLdap; + deps = [ openldap ]; + } + { + flags = [ "libetpan" ]; + enabled = enableLibetpan; + deps = [ libetpan ]; + } + { + flags = [ "libravatar-plugin" ]; + enabled = enablePluginLibravatar; + } + { + flags = [ "libsm" ]; + enabled = enableLibSM; + deps = [ xorg.libSM ]; + } + { + flags = [ "litehtml_viewer-plugin" ]; + enabled = enablePluginLitehtmlViewer; + deps = [ gumbo ]; + } + { + flags = [ "mailmbox-plugin" ]; + enabled = enablePluginMailmbox; + } + { + flags = [ "managesieve-plugin" ]; + enabled = enablePluginManageSieve; + } + { + flags = [ "networkmanager" ]; + enabled = enableNetworkManager; + deps = [ networkmanager ]; + } + { + flags = [ "newmail-plugin" ]; + enabled = enablePluginNewMail; + } + { + flags = [ "notification-plugin" ]; + enabled = enablePluginNotification; + deps = [ libnotify ] ++ [ libcanberra-gtk3 ]; + } + { + flags = [ "pdf_viewer-plugin" ]; + enabled = enablePluginPdfViewer; + deps = [ poppler ]; + } + { + flags = [ "perl-plugin" ]; + enabled = enablePluginPerl; + deps = [ perl ]; + } + { + flags = [ + "pgpcore-plugin" + "pgpinline-plugin" + "pgpmime-plugin" + ]; + enabled = enablePluginPgp; + deps = [ + gnupg + gpgme + ]; + } + { + flags = [ "python-plugin" ]; + enabled = enablePluginPython; + } + { + flags = [ "rssyl-plugin" ]; + enabled = enablePluginRssyl; + deps = [ libxml2 ]; + } + { + flags = [ "smime-plugin" ]; + enabled = enablePluginSmime; + } + { + flags = [ "spam_report-plugin" ]; + enabled = enablePluginSpamReport; + } + { + flags = [ "spamassassin-plugin" ]; + enabled = enablePluginSpamassassin; + } + { + flags = [ "svg" ]; + enabled = enableSvg; + deps = [ librsvg ]; + } + { + flags = [ "tnef_parse-plugin" ]; + enabled = enablePluginTnefParse; + deps = [ libytnef ]; + } + { + flags = [ "valgrind" ]; + enabled = enableValgrind; + deps = [ valgrind ]; + } + { + flags = [ "vcalendar-plugin" ]; + enabled = enablePluginVcalendar; + deps = [ libical ]; + } ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "claws-mail"; version = "4.3.0"; @@ -103,7 +282,10 @@ in stdenv.mkDerivation rec { hash = "sha256-ldwdiI65FvAoRn+gw8v0W6/2Z4eTt7+zX6u6Ap1YHOE="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; patches = [ ./mime.patch @@ -123,21 +305,31 @@ in stdenv.mkDerivation rec { --subst-var-by MIMEROOTDIR ${shared-mime-info}/share ''; - nativeBuildInputs = [ autoreconfHook pkg-config bison flex wrapGAppsHook3 ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + bison + flex + wrapGAppsHook3 + ]; propagatedBuildInputs = pythonPkgs; - buildInputs = - [ curl gsettings-desktop-schemas glib-networking gtk3 ] - ++ lib.concatMap (f: lib.optionals f.enabled f.deps) (lib.filter (f: f ? deps) features) - ; + buildInputs = [ + curl + gsettings-desktop-schemas + glib-networking + gtk3 + ] ++ lib.concatMap (f: lib.optionals f.enabled f.deps) (lib.filter (f: f ? deps) features); configureFlags = [ - "--disable-manual" # Missing docbook-tools, e.g., docbook2html + "--disable-manual" # Missing docbook-tools, e.g., docbook2html "--disable-compface" # Missing compface library - "--disable-jpilot" # Missing jpilot library - ] ++ - (map (feature: map (flag: lib.strings.enableFeature feature.enabled flag) feature.flags) features); + "--disable-jpilot" # Missing jpilot library + ] + ++ (map ( + feature: map (flag: lib.strings.enableFeature feature.enabled flag) feature.flags + ) features); enableParallelBuilding = true; @@ -157,6 +349,12 @@ in stdenv.mkDerivation rec { homepage = "https://www.claws-mail.org/"; license = licenses.gpl3Plus; platforms = platforms.linux; - maintainers = with maintainers; [ fpletz globin orivej oxzi ajs124 ]; + maintainers = with maintainers; [ + fpletz + globin + orivej + oxzi + ajs124 + ]; }; } diff --git a/pkgs/by-name/cl/claws/package.nix b/pkgs/by-name/cl/claws/package.nix index cb1a55b0695786..d189fa3690c03e 100644 --- a/pkgs/by-name/cl/claws/package.nix +++ b/pkgs/by-name/cl/claws/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "claws"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-FP+3Rw5IdCahhx9giQrpepMMtF1pWcyjNglrlu9ju0Q="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/thehowl/claws"; diff --git a/pkgs/by-name/cl/clblast/package.nix b/pkgs/by-name/cl/clblast/package.nix index 3bf38086ca2fa3..8f93b2d236a559 100644 --- a/pkgs/by-name/cl/clblast/package.nix +++ b/pkgs/by-name/cl/clblast/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -, opencl-headers -, ocl-icd +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + opencl-headers, + ocl-icd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cl/clboss/package.nix b/pkgs/by-name/cl/clboss/package.nix index e443aac8d03aaf..88a8e32d8cbf35 100644 --- a/pkgs/by-name/cl/clboss/package.nix +++ b/pkgs/by-name/cl/clboss/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchzip -, autoconf-archive -, autoreconfHook -, pkg-config -, curlWithGnuTls -, libev -, sqlite +{ + lib, + stdenv, + fetchzip, + autoconf-archive, + autoreconfHook, + pkg-config, + curlWithGnuTls, + libev, + sqlite, }: stdenv.mkDerivation rec { @@ -19,7 +20,14 @@ stdenv.mkDerivation rec { hash = "sha256-Qp8br4ZxiqaxFZ6Tb+wFpqp2APmnU9QdNkM8MyGAtrw="; }; - nativeBuildInputs = [ autoconf-archive autoreconfHook pkg-config libev curlWithGnuTls sqlite ]; + nativeBuildInputs = [ + autoconf-archive + autoreconfHook + pkg-config + libev + curlWithGnuTls + sqlite + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/cl/cld2/package.nix b/pkgs/by-name/cl/cld2/package.nix index bf28b160f2bab7..315330529f3802 100644 --- a/pkgs/by-name/cl/cld2/package.nix +++ b/pkgs/by-name/cl/cld2/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fetchpatch, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/cl/cldr-annotations/package.nix b/pkgs/by-name/cl/cldr-annotations/package.nix index f393875eb390be..0778a9c70c59b5 100644 --- a/pkgs/by-name/cl/cldr-annotations/package.nix +++ b/pkgs/by-name/cl/cldr-annotations/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "cldr-annotations"; diff --git a/pkgs/by-name/cl/clean/package.nix b/pkgs/by-name/cl/clean/package.nix index e360bb05f40dc7..603c753cac60c5 100644 --- a/pkgs/by-name/cl/clean/package.nix +++ b/pkgs/by-name/cl/clean/package.nix @@ -1,21 +1,31 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "clean"; version = "3.0"; src = - if stdenv.hostPlatform.system == "i686-linux" then (fetchurl { - url = "https://ftp.cs.ru.nl/Clean/Clean30/linux/clean3.0_32_boot.tar.gz"; - sha256 = "0cjxv3vqrg6pz3aicwfdz1zyhk0q650464j3qyl0wzaikh750010"; - }) - else if stdenv.hostPlatform.system == "x86_64-linux" then (fetchurl { + if stdenv.hostPlatform.system == "i686-linux" then + (fetchurl { + url = "https://ftp.cs.ru.nl/Clean/Clean30/linux/clean3.0_32_boot.tar.gz"; + sha256 = "0cjxv3vqrg6pz3aicwfdz1zyhk0q650464j3qyl0wzaikh750010"; + }) + else if stdenv.hostPlatform.system == "x86_64-linux" then + (fetchurl { url = "https://ftp.cs.ru.nl/Clean/Clean30/linux/clean3.0_64_boot.tar.gz"; sha256 = "06k283y9adbi28f78k3m5ssg6py73qqkz3sm8dgxc89drv4krl2i"; - }) - else throw "Architecture not supported"; + }) + else + throw "Architecture not supported"; - hardeningDisable = [ "format" "pic" ]; + hardeningDisable = [ + "format" + "pic" + ]; # clm uses timestamps of dcl, icl, abc and o files to decide what must be rebuild # and for chroot builds all of the library files will have equal timestamps. This @@ -48,6 +58,9 @@ stdenv.mkDerivation { homepage = "http://wiki.clean.cs.ru.nl/Clean"; license = lib.licenses.bsd2; maintainers = [ lib.maintainers.erin ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/cl/clearlooks-phenix/package.nix b/pkgs/by-name/cl/clearlooks-phenix/package.nix index 0157914d8fcc45..9b5ff579e7069c 100644 --- a/pkgs/by-name/cl/clearlooks-phenix/package.nix +++ b/pkgs/by-name/cl/clearlooks-phenix/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { version = "7.0.1"; diff --git a/pkgs/by-name/cl/clearlyU/package.nix b/pkgs/by-name/cl/clearlyU/package.nix index c0824cf7d40e7b..8bd54eac6ceff9 100644 --- a/pkgs/by-name/cl/clearlyU/package.nix +++ b/pkgs/by-name/cl/clearlyU/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, xorg, libfaketime }: +{ + lib, + stdenv, + fetchurl, + xorg, + libfaketime, +}: stdenv.mkDerivation rec { pname = "clearlyU"; @@ -9,7 +15,11 @@ stdenv.mkDerivation rec { sha256 = "1xn14jbv3m1khy7ydvad9ydkn7yygdbhjy9wm1v000jzjwr3lv21"; }; - nativeBuildInputs = [ xorg.fonttosfnt xorg.mkfontscale libfaketime ]; + nativeBuildInputs = [ + xorg.fonttosfnt + xorg.mkfontscale + libfaketime + ]; buildPhase = '' # convert bdf fonts to otb diff --git a/pkgs/by-name/cl/clematis/package.nix b/pkgs/by-name/cl/clematis/package.nix index cba0b6cd5f9562..c97a1e0cb07fde 100644 --- a/pkgs/by-name/cl/clematis/package.nix +++ b/pkgs/by-name/cl/clematis/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/cl/clex/package.nix b/pkgs/by-name/cl/clex/package.nix index 507da73bbc533d..ba3a3251b0bbf1 100644 --- a/pkgs/by-name/cl/clex/package.nix +++ b/pkgs/by-name/cl/clex/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "clex"; diff --git a/pkgs/by-name/cl/clfft/package.nix b/pkgs/by-name/cl/clfft/package.nix index 52ff8e4e056929..a7eedd6457383b 100644 --- a/pkgs/by-name/cl/clfft/package.nix +++ b/pkgs/by-name/cl/clfft/package.nix @@ -1,4 +1,15 @@ -{ lib, gccStdenv, fetchFromGitHub, cmake, fftw, fftwFloat, boost, opencl-clhpp, ocl-icd, darwin }: +{ + lib, + gccStdenv, + fetchFromGitHub, + cmake, + fftw, + fftwFloat, + boost, + opencl-clhpp, + ocl-icd, + darwin, +}: let inherit (darwin.apple_sdk.frameworks) OpenCL; @@ -23,8 +34,16 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ fftw fftwFloat boost ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ opencl-clhpp ocl-icd ] + buildInputs = + [ + fftw + fftwFloat + boost + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + opencl-clhpp + ocl-icd + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ OpenCL ]; # https://github.com/clMathLibraries/clFFT/issues/237 diff --git a/pkgs/by-name/cl/clhep/package.nix b/pkgs/by-name/cl/clhep/package.nix index 589233a1959316..ffa1945aed5e8c 100644 --- a/pkgs/by-name/cl/clhep/package.nix +++ b/pkgs/by-name/cl/clhep/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, cmake +{ + lib, + stdenv, + fetchurl, + cmake, }: stdenv.mkDerivation rec { @@ -29,7 +30,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Set of HEP-specific foundation and utility classes such as random generators, physics vectors, geometry and linear algebra"; homepage = "https://cern.ch/clhep"; - license = with licenses; [ gpl3Only lgpl3Only ]; + license = with licenses; [ + gpl3Only + lgpl3Only + ]; maintainers = with maintainers; [ veprbl ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/cl/cli-visualizer/package.nix b/pkgs/by-name/cl/cli-visualizer/package.nix index 1559a5401ffad1..5fa6cd2f51436c 100644 --- a/pkgs/by-name/cl/cli-visualizer/package.nix +++ b/pkgs/by-name/cl/cli-visualizer/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, fftw, ncurses5, libpulseaudio, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fftw, + ncurses5, + libpulseaudio, + makeWrapper, +}: stdenv.mkDerivation rec { version = "1.8"; @@ -15,9 +24,16 @@ stdenv.mkDerivation rec { sed '1i#include ' -i src/Transformer/SpectrumCircleTransformer.cpp ''; - nativeBuildInputs = [ cmake makeWrapper ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; - buildInputs = [ fftw ncurses5 libpulseaudio ]; + buildInputs = [ + fftw + ncurses5 + libpulseaudio + ]; buildFlags = [ "ENABLE_PULSE=1" ]; diff --git a/pkgs/by-name/cl/cli53/package.nix b/pkgs/by-name/cl/cli53/package.nix index a6f677b287cfc4..14508c89ca6dec 100644 --- a/pkgs/by-name/cl/cli53/package.nix +++ b/pkgs/by-name/cl/cli53/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, cli53 }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + cli53, +}: buildGoModule rec { pname = "cli53"; diff --git a/pkgs/by-name/cl/cliam/package.nix b/pkgs/by-name/cl/cliam/package.nix index 1089a352d54cbf..c1084bf82620db 100644 --- a/pkgs/by-name/cl/cliam/package.nix +++ b/pkgs/by-name/cl/cliam/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/cl/clib/package.nix b/pkgs/by-name/cl/clib/package.nix index a4cd170e90e44e..37c0841d75b49c 100644 --- a/pkgs/by-name/cl/clib/package.nix +++ b/pkgs/by-name/cl/clib/package.nix @@ -1,13 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, curl }: +{ + lib, + stdenv, + fetchFromGitHub, + curl, +}: stdenv.mkDerivation rec { version = "2.8.7"; pname = "clib"; src = fetchFromGitHub { - rev = version; - owner = "clibs"; - repo = "clib"; + rev = version; + owner = "clibs"; + repo = "clib"; sha256 = "sha256-uL8prMk2DrYLjCmZW8DdbCg5FJ5uksT3vIATyOW2ZzY="; }; diff --git a/pkgs/by-name/cl/click/package.nix b/pkgs/by-name/cl/click/package.nix index a471c5827c7628..5a6ae5cb1507ac 100644 --- a/pkgs/by-name/cl/click/package.nix +++ b/pkgs/by-name/cl/click/package.nix @@ -1,4 +1,12 @@ -{ darwin, fetchFromGitHub, rustPlatform, lib, stdenv, pkg-config, openssl }: +{ + darwin, + fetchFromGitHub, + rustPlatform, + lib, + stdenv, + pkg-config, + openssl, +}: rustPlatform.buildRustPackage rec { pname = "click"; @@ -15,7 +23,8 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ openssl ] + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Security ]; meta = with lib; { @@ -23,7 +32,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/databricks/click"; license = [ licenses.asl20 ]; maintainers = [ maintainers.mbode ]; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; mainProgram = "click"; }; } diff --git a/pkgs/by-name/cl/clickclack/package.nix b/pkgs/by-name/cl/clickclack/package.nix index 15fe00486d3e6e..2f2f3b18cd6a2c 100644 --- a/pkgs/by-name/cl/clickclack/package.nix +++ b/pkgs/by-name/cl/clickclack/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromSourcehut -, SDL2 +{ + lib, + stdenv, + fetchFromSourcehut, + SDL2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cl/clickhouse-backup/package.nix b/pkgs/by-name/cl/clickhouse-backup/package.nix index 3568824e1da08f..5f9b04a38e0739 100644 --- a/pkgs/by-name/cl/clickhouse-backup/package.nix +++ b/pkgs/by-name/cl/clickhouse-backup/package.nix @@ -1,8 +1,9 @@ -{ buildGoModule -, clickhouse-backup -, fetchFromGitHub -, lib -, testers +{ + buildGoModule, + clickhouse-backup, + fetchFromGitHub, + lib, + testers, }: buildGoModule rec { diff --git a/pkgs/by-name/cl/client-ip-echo/client-ip-echo.nix b/pkgs/by-name/cl/client-ip-echo/client-ip-echo.nix index a02daa1798336e..2de93fb1a3d014 100644 --- a/pkgs/by-name/cl/client-ip-echo/client-ip-echo.nix +++ b/pkgs/by-name/cl/client-ip-echo/client-ip-echo.nix @@ -1,4 +1,11 @@ -{ mkDerivation, fetchFromGitHub, base, bytestring, network, lib }: +{ + mkDerivation, + fetchFromGitHub, + base, + bytestring, + network, + lib, +}: mkDerivation { pname = "client-ip-echo"; version = "0.1.0.5"; @@ -10,7 +17,11 @@ mkDerivation { }; isLibrary = false; isExecutable = true; - executableHaskellDepends = [ base bytestring network ]; + executableHaskellDepends = [ + base + bytestring + network + ]; description = "accepts TCP connections and echoes the client's IP address back to it"; license = lib.licenses.lgpl3; mainProgram = "client-ip-echo"; diff --git a/pkgs/by-name/cl/client-ip-echo/package.nix b/pkgs/by-name/cl/client-ip-echo/package.nix index 5bc0ea45e2b629..153f1d691ba35c 100644 --- a/pkgs/by-name/cl/client-ip-echo/package.nix +++ b/pkgs/by-name/cl/client-ip-echo/package.nix @@ -1,2 +1 @@ -{ pkgs }: -pkgs.haskellPackages.callPackage ./client-ip-echo.nix { } +{ pkgs }: pkgs.haskellPackages.callPackage ./client-ip-echo.nix { } diff --git a/pkgs/by-name/cl/clightning/package.nix b/pkgs/by-name/cl/clightning/package.nix index 0b18bdc622242a..38ee7892c2b9d8 100644 --- a/pkgs/by-name/cl/clightning/package.nix +++ b/pkgs/by-name/cl/clightning/package.nix @@ -1,26 +1,30 @@ -{ lib -, stdenv -, cctools -, darwin -, fetchurl -, autoconf -, autogen -, automake -, gettext -, libtool -, lowdown-unsandboxed -, protobuf -, unzip -, which -, gmp -, libsodium -, python3 -, sqlite -, zlib -, jq +{ + lib, + stdenv, + cctools, + darwin, + fetchurl, + autoconf, + autogen, + automake, + gettext, + libtool, + lowdown-unsandboxed, + protobuf, + unzip, + which, + gmp, + libsodium, + python3, + sqlite, + zlib, + jq, }: let - py3 = python3.withPackages (p: [ p.distutils p.mako ]); + py3 = python3.withPackages (p: [ + p.distutils + p.mako + ]); in stdenv.mkDerivation rec { pname = "clightning"; @@ -34,24 +38,49 @@ stdenv.mkDerivation rec { # when building on darwin we need cctools to provide the correct libtool # as libwally-core detects the host as darwin and tries to add the -static # option to libtool, also we have to add the modified gsed package. - nativeBuildInputs = [ autoconf autogen automake gettext libtool lowdown-unsandboxed protobuf py3 unzip which ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools darwin.autoSignDarwinBinariesHook ]; + nativeBuildInputs = + [ + autoconf + autogen + automake + gettext + libtool + lowdown-unsandboxed + protobuf + py3 + unzip + which + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + cctools + darwin.autoSignDarwinBinariesHook + ]; - buildInputs = [ gmp libsodium sqlite zlib jq ]; + buildInputs = [ + gmp + libsodium + sqlite + zlib + jq + ]; # this causes some python trouble on a darwin host so we skip this step. # also we have to tell libwally-core to use sed instead of gsed. - postPatch = if !stdenv.hostPlatform.isDarwin then '' - patchShebangs \ - tools/generate-wire.py \ - tools/update-mocks.sh \ - tools/mockup.sh \ - tools/fromschema.py \ - devtools/sql-rewrite.py - '' else '' - substituteInPlace external/libwally-core/tools/autogen.sh --replace gsed sed && \ - substituteInPlace external/libwally-core/configure.ac --replace gsed sed - ''; + postPatch = + if !stdenv.hostPlatform.isDarwin then + '' + patchShebangs \ + tools/generate-wire.py \ + tools/update-mocks.sh \ + tools/mockup.sh \ + tools/fromschema.py \ + devtools/sql-rewrite.py + '' + else + '' + substituteInPlace external/libwally-core/tools/autogen.sh --replace gsed sed && \ + substituteInPlace external/libwally-core/configure.ac --replace gsed sed + ''; configureFlags = [ "--disable-valgrind" ]; @@ -62,7 +91,9 @@ stdenv.mkDerivation rec { # workaround for build issue, happens only x86_64-darwin, not aarch64-darwin # ccan/ccan/fdpass/fdpass.c:16:8: error: variable length array folded to constant array as an extension [-Werror,-Wgnu-folding-constant] # char buf[CMSG_SPACE(sizeof(fd))]; - env.NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) "-Wno-error=gnu-folding-constant"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64 + ) "-Wno-error=gnu-folding-constant"; # The `clnrest` plugin requires a Python environment to run postInstall = '' @@ -78,7 +109,10 @@ stdenv.mkDerivation rec { parties for any amount. ''; homepage = "https://github.com/ElementsProject/lightning"; - maintainers = with maintainers; [ jb55 prusnak ]; + maintainers = with maintainers; [ + jb55 + prusnak + ]; license = licenses.mit; platforms = platforms.linux ++ platforms.darwin; }; diff --git a/pkgs/by-name/cl/clima/package.nix b/pkgs/by-name/cl/clima/package.nix index f7e6ee15d7f83d..6b41f6deda3798 100644 --- a/pkgs/by-name/cl/clima/package.nix +++ b/pkgs/by-name/cl/clima/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/cl/cling/package.nix b/pkgs/by-name/cl/cling/package.nix index 6b8fefa43a5999..63b4a681745c02 100644 --- a/pkgs/by-name/cl/cling/package.nix +++ b/pkgs/by-name/cl/cling/package.nix @@ -1,32 +1,33 @@ -{ cmake -, fetchFromGitHub -, git -, lib -, libffi -, llvmPackages_13 -, makeWrapper -, ncurses -, python3 -, zlib - -# *NOT* from LLVM 9! -# The compiler used to compile Cling may affect the runtime include and lib -# directories it expects to be run with. Cling builds against (a fork of) Clang, -# so we prefer to use Clang as the compiler as well for consistency. -# It would be cleanest to use LLVM 9's clang, but it errors. So, we use a later -# version of Clang to compile, but we check out the Cling fork of Clang 9 to -# build Cling against. -, clangStdenv - -# For runtime C++ standard library -, gcc-unwrapped - -# Build with debug symbols -, debug ? false - -# Build with libc++ (LLVM) rather than stdlibc++ (GCC). -# This is experimental and not all features work. -, useLLVMLibcxx ? clangStdenv.hostPlatform.isDarwin +{ + cmake, + fetchFromGitHub, + git, + lib, + libffi, + llvmPackages_13, + makeWrapper, + ncurses, + python3, + zlib, + + # *NOT* from LLVM 9! + # The compiler used to compile Cling may affect the runtime include and lib + # directories it expects to be run with. Cling builds against (a fork of) Clang, + # so we prefer to use Clang as the compiler as well for consistency. + # It would be cleanest to use LLVM 9's clang, but it errors. So, we use a later + # version of Clang to compile, but we check out the Cling fork of Clang 9 to + # build Cling against. + clangStdenv, + + # For runtime C++ standard library + gcc-unwrapped, + + # Build with debug symbols + debug ? false, + + # Build with libc++ (LLVM) rather than stdlibc++ (GCC). + # This is experimental and not all features work. + useLLVMLibcxx ? clangStdenv.hostPlatform.isDarwin, }: let @@ -39,7 +40,7 @@ let # cling-llvm13 branch rev = "3610201fbe0352a63efb5cb45f4ea4987702c735"; sha256 = "sha256-Cb7BvV7yobG+mkaYe7zD2KcnPvm8/vmVATNWssklXyk="; - sparseCheckout = ["clang"]; + sparseCheckout = [ "clang" ]; }; llvm = llvmPackages_13.llvm.override { enableSharedLibraries = false; }; @@ -68,36 +69,47 @@ let ./no-clang-cpp.patch ]; - nativeBuildInputs = [ python3 git cmake ]; - buildInputs = [ libffi ncurses zlib ]; + nativeBuildInputs = [ + python3 + git + cmake + ]; + buildInputs = [ + libffi + ncurses + zlib + ]; strictDeps = true; - cmakeFlags = [ - "-DLLVM_BINARY_DIR=${llvm.out}" - "-DLLVM_CONFIG=${llvm.dev}/bin/llvm-config" - "-DLLVM_LIBRARY_DIR=${llvm.lib}/lib" - "-DLLVM_MAIN_INCLUDE_DIR=${llvm.dev}/include" - "-DLLVM_TABLEGEN_EXE=${llvm.out}/bin/llvm-tblgen" - "-DLLVM_TOOLS_BINARY_DIR=${llvm.out}/bin" - "-DLLVM_BUILD_TOOLS=Off" - "-DLLVM_TOOL_CLING_BUILD=ON" - - "-DLLVM_TARGETS_TO_BUILD=host;NVPTX" - "-DLLVM_ENABLE_RTTI=ON" - - # Setting -DCLING_INCLUDE_TESTS=ON causes the cling/tools targets to be built; - # see cling/tools/CMakeLists.txt - "-DCLING_INCLUDE_TESTS=ON" - "-DCLANG-TOOLS=OFF" - ] ++ lib.optionals debug [ - "-DCMAKE_BUILD_TYPE=Debug" - ] ++ lib.optionals useLLVMLibcxx [ - "-DLLVM_ENABLE_LIBCXX=ON" - "-DLLVM_ENABLE_LIBCXXABI=ON" - ]; - - CPPFLAGS = if useLLVMLibcxx then [ "-stdlib=libc++" ] else []; + cmakeFlags = + [ + "-DLLVM_BINARY_DIR=${llvm.out}" + "-DLLVM_CONFIG=${llvm.dev}/bin/llvm-config" + "-DLLVM_LIBRARY_DIR=${llvm.lib}/lib" + "-DLLVM_MAIN_INCLUDE_DIR=${llvm.dev}/include" + "-DLLVM_TABLEGEN_EXE=${llvm.out}/bin/llvm-tblgen" + "-DLLVM_TOOLS_BINARY_DIR=${llvm.out}/bin" + "-DLLVM_BUILD_TOOLS=Off" + "-DLLVM_TOOL_CLING_BUILD=ON" + + "-DLLVM_TARGETS_TO_BUILD=host;NVPTX" + "-DLLVM_ENABLE_RTTI=ON" + + # Setting -DCLING_INCLUDE_TESTS=ON causes the cling/tools targets to be built; + # see cling/tools/CMakeLists.txt + "-DCLING_INCLUDE_TESTS=ON" + "-DCLANG-TOOLS=OFF" + ] + ++ lib.optionals debug [ + "-DCMAKE_BUILD_TYPE=Debug" + ] + ++ lib.optionals useLLVMLibcxx [ + "-DLLVM_ENABLE_LIBCXX=ON" + "-DLLVM_ENABLE_LIBCXXABI=ON" + ]; + + CPPFLAGS = if useLLVMLibcxx then [ "-stdlib=libc++" ] else [ ]; postInstall = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' mkdir -p $out/share/Jupyter @@ -110,21 +122,33 @@ let description = "Interactive C++ Interpreter"; mainProgram = "cling"; homepage = "https://root.cern/cling/"; - license = with licenses; [ lgpl21 ncsa ]; + license = with licenses; [ + lgpl21 + ncsa + ]; maintainers = with maintainers; [ thomasjm ]; platforms = platforms.unix; }; }; # Runtime flags for the C++ standard library - cxxFlags = if useLLVMLibcxx then [ - "-I" "${lib.getDev llvmPackages_13.libcxx}/include/c++/v1" - "-L" "${llvmPackages_13.libcxx}/lib" - "-l" "${llvmPackages_13.libcxx}/lib/libc++${stdenv.hostPlatform.extensions.sharedLibrary}" - ] else [ - "-I" "${gcc-unwrapped}/include/c++/${gcc-unwrapped.version}" - "-I" "${gcc-unwrapped}/include/c++/${gcc-unwrapped.version}/${stdenv.hostPlatform.config}" - ]; + cxxFlags = + if useLLVMLibcxx then + [ + "-I" + "${lib.getDev llvmPackages_13.libcxx}/include/c++/v1" + "-L" + "${llvmPackages_13.libcxx}/lib" + "-l" + "${llvmPackages_13.libcxx}/lib/libc++${stdenv.hostPlatform.extensions.sharedLibrary}" + ] + else + [ + "-I" + "${gcc-unwrapped}/include/c++/${gcc-unwrapped.version}" + "-I" + "${gcc-unwrapped}/include/c++/${gcc-unwrapped.version}/${stdenv.hostPlatform.config}" + ]; # The flags passed to the wrapped cling should # a) prevent it from searching for system include files and libs, and @@ -137,22 +161,27 @@ let # Thus, if you're packaging a Jupyter kernel, you either need to pass these flags as extra # args to xcpp (for xeus-cling) or put them in the environment variable CLING_OPTS # (for jupyter-cling-kernel). - flags = [ - "-nostdinc" - "-nostdinc++" - - "-resource-dir" "${llvm.lib}/lib" - - "-isystem" "${lib.getLib unwrapped}/lib/clang/${llvmPackages_13.clang.version}/include" - ] - ++ cxxFlags - ++ [ - # System libc - "-isystem" "${lib.getDev stdenv.cc.libc}/include" - - # cling includes - "-isystem" "${lib.getDev unwrapped}/include" - ]; + flags = + [ + "-nostdinc" + "-nostdinc++" + + "-resource-dir" + "${llvm.lib}/lib" + + "-isystem" + "${lib.getLib unwrapped}/lib/clang/${llvmPackages_13.clang.version}/include" + ] + ++ cxxFlags + ++ [ + # System libc + "-isystem" + "${lib.getDev stdenv.cc.libc}/include" + + # cling includes + "-isystem" + "${lib.getDev unwrapped}/include" + ]; in diff --git a/pkgs/by-name/cl/clini/package.nix b/pkgs/by-name/cl/clini/package.nix index b6190a1141d9d7..65d94561a0a745 100644 --- a/pkgs/by-name/cl/clini/package.nix +++ b/pkgs/by-name/cl/clini/package.nix @@ -1,4 +1,8 @@ -{ fetchCrate, lib, rustPlatform }: +{ + fetchCrate, + lib, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "clini"; diff --git a/pkgs/by-name/cl/clipcat/package.nix b/pkgs/by-name/cl/clipcat/package.nix index 1630253966e412..22f828a3f9b04b 100644 --- a/pkgs/by-name/cl/clipcat/package.nix +++ b/pkgs/by-name/cl/clipcat/package.nix @@ -52,7 +52,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/xrelkd/clipcat"; license = lib.licenses.gpl3Only; platforms = lib.platforms.linux ++ lib.platforms.darwin; - maintainers = with lib.maintainers; [ xrelkd bot-wxt1221 ]; + maintainers = with lib.maintainers; [ + xrelkd + bot-wxt1221 + ]; mainProgram = "clipcatd"; }; } diff --git a/pkgs/by-name/cl/clipit/package.nix b/pkgs/by-name/cl/clipit/package.nix index 0bd48d2adf63de..c19ae440579d78 100644 --- a/pkgs/by-name/cl/clipit/package.nix +++ b/pkgs/by-name/cl/clipit/package.nix @@ -1,6 +1,16 @@ -{ fetchFromGitHub, lib, stdenv -, autoreconfHook, intltool, pkg-config -, gtk3, libayatana-appindicator, xdotool, which, wrapGAppsHook3 }: +{ + fetchFromGitHub, + lib, + stdenv, + autoreconfHook, + intltool, + pkg-config, + gtk3, + libayatana-appindicator, + xdotool, + which, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "clipit"; @@ -17,19 +27,36 @@ stdenv.mkDerivation rec { intltoolize --copy --force --automake ''; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 autoreconfHook intltool ]; - configureFlags = [ "--with-gtk3" "--enable-appindicator=yes" ]; - buildInputs = [ gtk3 libayatana-appindicator ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + autoreconfHook + intltool + ]; + configureFlags = [ + "--with-gtk3" + "--enable-appindicator=yes" + ]; + buildInputs = [ + gtk3 + libayatana-appindicator + ]; gappsWrapperArgs = [ - "--prefix" "PATH" ":" "${lib.makeBinPath [ xdotool which ]}" + "--prefix" + "PATH" + ":" + "${lib.makeBinPath [ + xdotool + which + ]}" ]; meta = with lib; { description = "Lightweight GTK Clipboard Manager"; inherit (src.meta) homepage; license = licenses.gpl3Plus; - platforms = platforms.linux; + platforms = platforms.linux; mainProgram = "clipit"; maintainers = with maintainers; [ kamilchm ]; }; diff --git a/pkgs/by-name/cl/clipman/package.nix b/pkgs/by-name/cl/clipman/package.nix index 95cdab616a44bd..2db613c3fb1033 100644 --- a/pkgs/by-name/cl/clipman/package.nix +++ b/pkgs/by-name/cl/clipman/package.nix @@ -1,9 +1,10 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, wl-clipboard -, makeWrapper -, installShellFiles +{ + buildGoModule, + fetchFromGitHub, + lib, + wl-clipboard, + makeWrapper, + installShellFiles, }: buildGoModule rec { @@ -19,11 +20,17 @@ buildGoModule rec { vendorHash = "sha256-I1RWyjyOfppGi+Z5nvAei5zEvl0eQctcH8NP0MYSTbg="; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; doCheck = false; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; postInstall = '' wrapProgram $out/bin/clipman \ diff --git a/pkgs/by-name/cl/clipmenu/package.nix b/pkgs/by-name/cl/clipmenu/package.nix index b12dc7f04c36f9..bf2c414a61dfb2 100644 --- a/pkgs/by-name/cl/clipmenu/package.nix +++ b/pkgs/by-name/cl/clipmenu/package.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchFromGitHub -, makeWrapper -, clipnotify -, coreutils -, gawk -, util-linux -, xdotool -, xsel +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + clipnotify, + coreutils, + gawk, + util-linux, + xdotool, + xsel, }: stdenv.mkDerivation rec { pname = "clipmenu"; version = "6.2.0"; src = fetchFromGitHub { - owner = "cdown"; - repo = "clipmenu"; - rev = version; + owner = "cdown"; + repo = "clipmenu"; + rev = version; sha256 = "sha256-nvctEwyho6kl4+NXi76jT2kG7nchmI2a7mgxlgjXA5A="; }; @@ -26,7 +27,11 @@ stdenv.mkDerivation rec { ''; makeFlags = [ "PREFIX=$(out)" ]; - nativeBuildInputs = [ makeWrapper xsel clipnotify ]; + nativeBuildInputs = [ + makeWrapper + xsel + clipnotify + ]; postFixup = '' sed -i "$out/bin/clipctl" -e 's,clipmenud\$,\.clipmenud-wrapped\$,' @@ -35,7 +40,16 @@ stdenv.mkDerivation rec { --prefix PATH : "${lib.makeBinPath [ xsel ]}" wrapProgram "$out/bin/clipmenud" \ - --set PATH "${lib.makeBinPath [ clipnotify coreutils gawk util-linux xdotool xsel ]}" + --set PATH "${ + lib.makeBinPath [ + clipnotify + coreutils + gawk + util-linux + xdotool + xsel + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/cl/clipnotify/package.nix b/pkgs/by-name/cl/clipnotify/package.nix index 8f94f974b058de..d8e6cf5b469cf2 100644 --- a/pkgs/by-name/cl/clipnotify/package.nix +++ b/pkgs/by-name/cl/clipnotify/package.nix @@ -1,4 +1,10 @@ -{ libX11, libXfixes, lib, stdenv, fetchFromGitHub }: +{ + libX11, + libXfixes, + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "clipnotify"; version = "unstable-2018-02-20"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "1x9avjq0fgw0svcbw6b6873qnsqxbacls9sipmcv86xia4bxh8dn"; }; - buildInputs = [ libX11 libXfixes ]; + buildInputs = [ + libX11 + libXfixes + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/cl/clipp/package.nix b/pkgs/by-name/cl/clipp/package.nix index 12b393e597d403..b9a2f3eb54cc7b 100644 --- a/pkgs/by-name/cl/clipp/package.nix +++ b/pkgs/by-name/cl/clipp/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "clipp"; diff --git a/pkgs/by-name/cl/clipper/package.nix b/pkgs/by-name/cl/clipper/package.nix index 8dc649b6b5fe5a..e9297156cf121f 100644 --- a/pkgs/by-name/cl/clipper/package.nix +++ b/pkgs/by-name/cl/clipper/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, cmake, ninja, unzip }: +{ + lib, + stdenv, + fetchurl, + cmake, + ninja, + unzip, +}: stdenv.mkDerivation rec { version = "6.4.2"; @@ -10,7 +17,11 @@ stdenv.mkDerivation rec { sourceRoot = "cpp"; - nativeBuildInputs = [ cmake ninja unzip ]; + nativeBuildInputs = [ + cmake + ninja + unzip + ]; meta = with lib; { description = "Polygon and line clipping and offsetting library (C++, C#, Delphi)"; diff --git a/pkgs/by-name/cl/clipper2/package.nix b/pkgs/by-name/cl/clipper2/package.nix index 37ec3967793962..a2e088acaa7323 100644 --- a/pkgs/by-name/cl/clipper2/package.nix +++ b/pkgs/by-name/cl/clipper2/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cl/clipqr/package.nix b/pkgs/by-name/cl/clipqr/package.nix index 90d4e0b66b5254..7e71cda67eb30d 100644 --- a/pkgs/by-name/cl/clipqr/package.nix +++ b/pkgs/by-name/cl/clipqr/package.nix @@ -1,19 +1,20 @@ -{ buildGoModule -, copyDesktopItems -, fetchFromGitLab -, lib -, libGL -, libX11 -, libXcursor -, libXext -, libXi -, libXinerama -, libXrandr -, libXxf86vm -, makeDesktopItem -, mesa -, pkg-config -, stdenv +{ + buildGoModule, + copyDesktopItems, + fetchFromGitLab, + lib, + libGL, + libX11, + libXcursor, + libXext, + libXi, + libXinerama, + libXrandr, + libXxf86vm, + makeDesktopItem, + mesa, + pkg-config, + stdenv, }: buildGoModule rec { @@ -29,7 +30,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; buildInputs = [ libGL diff --git a/pkgs/by-name/cl/clips/package.nix b/pkgs/by-name/cl/clips/package.nix index c5c4d4321ce137..df9916098d33a9 100644 --- a/pkgs/by-name/cl/clips/package.nix +++ b/pkgs/by-name/cl/clips/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "6.4.1"; @@ -6,8 +10,8 @@ stdenv.mkDerivation rec { src = fetchurl { url = "mirror://sourceforge/clipsrules/CLIPS/${version}/clips_core_source_${ - builtins.replaceStrings [ "." ] [ "" ] version - }.tar.gz"; + builtins.replaceStrings [ "." ] [ "" ] version + }.tar.gz"; hash = "sha256-qk87uLFZZL9HNPNlyVh+Mplr3dP1C/z1O5UVS+rnbuM="; }; @@ -15,7 +19,10 @@ stdenv.mkDerivation rec { substituteInPlace core/makefile --replace 'gcc' '${stdenv.cc.targetPrefix}cc' ''; - makeFlags = [ "-C" "core" ]; + makeFlags = [ + "-C" + "core" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/cl/clipse/package.nix b/pkgs/by-name/cl/clipse/package.nix index cc200b0c6b5147..5cda92da789237 100644 --- a/pkgs/by-name/cl/clipse/package.nix +++ b/pkgs/by-name/cl/clipse/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/cl/clipster/package.nix b/pkgs/by-name/cl/clipster/package.nix index 5c9c2cd1054ca1..f73265d4fccf3f 100644 --- a/pkgs/by-name/cl/clipster/package.nix +++ b/pkgs/by-name/cl/clipster/package.nix @@ -1,7 +1,15 @@ -{fetchFromGitHub , lib, stdenv, python3, gtk3, libwnck, - gobject-introspection, wrapGAppsHook3 }: +{ + fetchFromGitHub, + lib, + stdenv, + python3, + gtk3, + libwnck, + gobject-introspection, + wrapGAppsHook3, +}: -stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "clipster"; version = "2.1.1"; @@ -12,10 +20,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-MLLkFsBBQtb7RFQN+uoEmuCn5bnbkYsqoyWGZtTCI2U="; }; - pythonEnv = python3.withPackages(ps: with ps; [ pygobject3 ]); + pythonEnv = python3.withPackages (ps: with ps; [ pygobject3 ]); nativeBuildInputs = [ gobject-introspection ]; - buildInputs = [ pythonEnv gtk3 libwnck wrapGAppsHook3 ]; + buildInputs = [ + pythonEnv + gtk3 + libwnck + wrapGAppsHook3 + ]; installPhase = '' sed -i 's/python/python3/g' clipster diff --git a/pkgs/by-name/cl/cliquer/package.nix b/pkgs/by-name/cl/cliquer/package.nix index 55a1b9dcb4c977..33d9c0704a9846 100644 --- a/pkgs/by-name/cl/cliquer/package.nix +++ b/pkgs/by-name/cl/cliquer/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cl/clj-kondo/package.nix b/pkgs/by-name/cl/clj-kondo/package.nix index 984a0767c1fc52..6106e79c3ca265 100644 --- a/pkgs/by-name/cl/clj-kondo/package.nix +++ b/pkgs/by-name/cl/clj-kondo/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGraalvmNativeImage, graalvmCEPackages, fetchurl +{ + lib, + buildGraalvmNativeImage, + graalvmCEPackages, + fetchurl, }: buildGraalvmNativeImage rec { @@ -6,23 +10,26 @@ buildGraalvmNativeImage rec { version = "2024.11.14"; src = fetchurl { - url = - "https://github.com/clj-kondo/${pname}/releases/download/v${version}/${pname}-${version}-standalone.jar"; + url = "https://github.com/clj-kondo/${pname}/releases/download/v${version}/${pname}-${version}-standalone.jar"; sha256 = "sha256-/pzRKx6fqcbVwp+Eif3a1mh/awmwhhLVtFldRYibp/g="; }; graalvmDrv = graalvmCEPackages.graalvm-ce; - extraNativeImageBuildArgs = - [ "-H:+ReportExceptionStackTraces" "--no-fallback" ]; + extraNativeImageBuildArgs = [ + "-H:+ReportExceptionStackTraces" + "--no-fallback" + ]; meta = with lib; { description = "Linter for Clojure code that sparks joy"; homepage = "https://github.com/clj-kondo/clj-kondo"; sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.epl10; - changelog = - "https://github.com/clj-kondo/clj-kondo/blob/v${version}/CHANGELOG.md"; - maintainers = with maintainers; [ jlesquembre bandresen ]; + changelog = "https://github.com/clj-kondo/clj-kondo/blob/v${version}/CHANGELOG.md"; + maintainers = with maintainers; [ + jlesquembre + bandresen + ]; }; } diff --git a/pkgs/by-name/cl/cljfmt/package.nix b/pkgs/by-name/cl/cljfmt/package.nix index 2005215f8fc42e..11b3a776bd94e0 100644 --- a/pkgs/by-name/cl/cljfmt/package.nix +++ b/pkgs/by-name/cl/cljfmt/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGraalvmNativeImage -, fetchurl -, nix-update-script -, testers -, cljfmt +{ + lib, + buildGraalvmNativeImage, + fetchurl, + nix-update-script, + testers, + cljfmt, }: buildGraalvmNativeImage rec { diff --git a/pkgs/by-name/cl/clmagma/package.nix b/pkgs/by-name/cl/clmagma/package.nix index c5efbb757df8a8..c639c31db6f553 100644 --- a/pkgs/by-name/cl/clmagma/package.nix +++ b/pkgs/by-name/cl/clmagma/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, gfortran, opencl-headers, clblas, ocl-icd, mkl, intel-ocl }: +{ + lib, + stdenv, + fetchurl, + gfortran, + opencl-headers, + clblas, + ocl-icd, + mkl, + intel-ocl, +}: let incfile = builtins.toFile "make.inc.custom" '' @@ -29,7 +39,8 @@ let INC = -I$(clBLAS)/include #-I$(AMDAPP)/include ''; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "clmagma"; version = "1.3.0"; src = fetchurl { @@ -47,14 +58,14 @@ in stdenv.mkDerivation rec { intel-ocl ]; - enableParallelBuilding=true; + enableParallelBuilding = true; - MKLROOT = "${mkl}"; - clBLAS = "${clblas}"; + MKLROOT = "${mkl}"; + clBLAS = "${clblas}"; # Otherwise build looks for it in /run/opengl-driver/etc/OpenCL/vendors, # which is not available. - OPENCL_VENDOR_PATH="${intel-ocl}/etc/OpenCL/vendors"; + OPENCL_VENDOR_PATH = "${intel-ocl}/etc/OpenCL/vendors"; preBuild = '' # By default it tries to use GPU, and thus fails for CPUs diff --git a/pkgs/by-name/cl/cln/package.nix b/pkgs/by-name/cl/cln/package.nix index ae3ed853a026cb..4cbe9688ce5f10 100644 --- a/pkgs/by-name/cl/cln/package.nix +++ b/pkgs/by-name/cl/cln/package.nix @@ -1,4 +1,9 @@ -{ lib, gccStdenv, fetchurl, gmp }: +{ + lib, + gccStdenv, + fetchurl, + gmp, +}: gccStdenv.mkDerivation rec { pname = "cln"; diff --git a/pkgs/by-name/cl/cloak/package.nix b/pkgs/by-name/cl/cloak/package.nix index 3857e458864aa5..e4161bbdd43768 100644 --- a/pkgs/by-name/cl/cloak/package.nix +++ b/pkgs/by-name/cl/cloak/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "cloak"; diff --git a/pkgs/by-name/cl/cloc/package.nix b/pkgs/by-name/cl/cloc/package.nix index 39215caa63a5f2..4841e86bba8760 100644 --- a/pkgs/by-name/cl/cloc/package.nix +++ b/pkgs/by-name/cl/cloc/package.nix @@ -1,7 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, perlPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + perlPackages, +}: -let version = "2.02"; -in stdenv.mkDerivation { +let + version = "2.02"; +in +stdenv.mkDerivation { pname = "cloc"; inherit version; @@ -24,7 +32,11 @@ in stdenv.mkDerivation { RegexpCommon ]; - makeFlags = [ "prefix=" "DESTDIR=$(out)" "INSTALL=install" ]; + makeFlags = [ + "prefix=" + "DESTDIR=$(out)" + "INSTALL=install" + ]; postFixup = "wrapProgram $out/bin/cloc --prefix PERL5LIB : $PERL5LIB"; diff --git a/pkgs/by-name/cl/clockify/package.nix b/pkgs/by-name/cl/clockify/package.nix index 8bcd2785bc22c2..54824d13ef60a6 100644 --- a/pkgs/by-name/cl/clockify/package.nix +++ b/pkgs/by-name/cl/clockify/package.nix @@ -1,6 +1,8 @@ -{ lib -, appimageTools -, fetchurl }: +{ + lib, + appimageTools, + fetchurl, +}: appimageTools.wrapType2 rec { pname = "clockify"; @@ -12,8 +14,10 @@ appimageTools.wrapType2 rec { }; extraInstallCommands = - let appimageContents = appimageTools.extract { inherit pname version src; }; - in '' + let + appimageContents = appimageTools.extract { inherit pname version src; }; + in + '' install -Dm 444 ${appimageContents}/clockify.desktop -t $out/share/applications install -Dm 444 ${appimageContents}/clockify.png -t $out/share/pixmaps diff --git a/pkgs/by-name/cl/clog-cli/package.nix b/pkgs/by-name/cl/clog-cli/package.nix index 6f4fa62cb53350..06c498f6762d2c 100644 --- a/pkgs/by-name/cl/clog-cli/package.nix +++ b/pkgs/by-name/cl/clog-cli/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, rustPlatform, lib }: +{ + fetchFromGitHub, + rustPlatform, + lib, +}: rustPlatform.buildRustPackage rec { pname = "clog-cli"; @@ -18,7 +22,7 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/clog-tool/clog-cli"; license = lib.licenses.mit; platforms = lib.platforms.unix; - maintainers = [lib.maintainers.nthorne]; + maintainers = [ lib.maintainers.nthorne ]; mainProgram = "clog"; # error: could not compile `rustc-serialize` broken = true; # Added 2024-03-16 diff --git a/pkgs/by-name/cl/clolcat/package.nix b/pkgs/by-name/cl/clolcat/package.nix index 5ba22c69b41b3a..328fd8c27779d8 100644 --- a/pkgs/by-name/cl/clolcat/package.nix +++ b/pkgs/by-name/cl/clolcat/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, fetchFromGitHub -, lib +{ + stdenv, + fetchFromGitHub, + lib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cl/clonehero/package.nix b/pkgs/by-name/cl/clonehero/package.nix index d7dcdee911e7aa..82f88a4acc22d3 100644 --- a/pkgs/by-name/cl/clonehero/package.nix +++ b/pkgs/by-name/cl/clonehero/package.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, gtk3 -, zlib -, alsa-lib -, dbus -, libGL -, libXcursor -, libXext -, libXi -, libXinerama -, libxkbcommon -, libXrandr -, libXScrnSaver -, libXxf86vm -, udev -, vulkan-loader # (not used by default, enable in settings menu) -, wayland # (not used by default, enable with SDL_VIDEODRIVER=wayland - doesn't support HiDPI) -, makeDesktopItem +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + gtk3, + zlib, + alsa-lib, + dbus, + libGL, + libXcursor, + libXext, + libXi, + libXinerama, + libxkbcommon, + libXrandr, + libXScrnSaver, + libXxf86vm, + udev, + vulkan-loader, # (not used by default, enable in settings menu) + wayland, # (not used by default, enable with SDL_VIDEODRIVER=wayland - doesn't support HiDPI) + makeDesktopItem, }: stdenv.mkDerivation (finalAttrs: { @@ -30,7 +31,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-YWLV+wgQ9RfKRSSWh/x0PMjB6tFA4YpHb9WtYOOgZZI="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; nativeBuildInputs = [ autoPatchelfHook ]; @@ -117,7 +121,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Clone of Guitar Hero and Rockband-style games"; homepage = "https://clonehero.net"; license = licenses.unfree; - maintainers = with maintainers; [ kira-bruneau syboxez ]; + maintainers = with maintainers; [ + kira-bruneau + syboxez + ]; platforms = [ "x86_64-linux" ]; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; }; diff --git a/pkgs/by-name/cl/closurecompiler/package.nix b/pkgs/by-name/cl/closurecompiler/package.nix index 2bb2340261c214..e2f0033080ef7f 100644 --- a/pkgs/by-name/cl/closurecompiler/package.nix +++ b/pkgs/by-name/cl/closurecompiler/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "closure-compiler"; diff --git a/pkgs/by-name/cl/cloud-custodian/package.nix b/pkgs/by-name/cl/cloud-custodian/package.nix index 42ba013670b86d..932df60ce48787 100644 --- a/pkgs/by-name/cl/cloud-custodian/package.nix +++ b/pkgs/by-name/cl/cloud-custodian/package.nix @@ -25,7 +25,6 @@ python3.pkgs.buildPythonApplication rec { build-system = with python3.pkgs; [ poetry-core ]; - dependencies = with python3.pkgs; [ argcomplete boto3 diff --git a/pkgs/by-name/cl/cloud-hypervisor/package.nix b/pkgs/by-name/cl/cloud-hypervisor/package.nix index 42f6593ef8f89e..a7a0c60737c094 100644 --- a/pkgs/by-name/cl/cloud-hypervisor/package.nix +++ b/pkgs/by-name/cl/cloud-hypervisor/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, rustPlatform, pkg-config, dtc, openssl +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + rustPlatform, + pkg-config, + dtc, + openssl, }: rustPlatform.buildRustPackage rec { @@ -26,18 +33,30 @@ rustPlatform.buildRustPackage rec { cargoTestFlags = [ "--workspace" - "--bins" "--lib" # Integration tests require root. - "--exclude" "net_util" # /dev/net/tun - "--exclude" "vmm" # /dev/kvm + "--bins" + "--lib" # Integration tests require root. + "--exclude" + "net_util" # /dev/net/tun + "--exclude" + "vmm" # /dev/kvm ]; meta = with lib; { homepage = "https://github.com/cloud-hypervisor/cloud-hypervisor"; description = "Open source Virtual Machine Monitor (VMM) that runs on top of KVM"; changelog = "https://github.com/cloud-hypervisor/cloud-hypervisor/releases/tag/v${version}"; - license = with licenses; [ asl20 bsd3 ]; + license = with licenses; [ + asl20 + bsd3 + ]; mainProgram = "cloud-hypervisor"; - maintainers = with maintainers; [ offline qyliss ]; - platforms = [ "aarch64-linux" "x86_64-linux" ]; + maintainers = with maintainers; [ + offline + qyliss + ]; + platforms = [ + "aarch64-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/cl/cloud-nuke/package.nix b/pkgs/by-name/cl/cloud-nuke/package.nix index f17bad02615b87..45daf1eed52b25 100644 --- a/pkgs/by-name/cl/cloud-nuke/package.nix +++ b/pkgs/by-name/cl/cloud-nuke/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeBinaryWrapper +{ + lib, + buildGoModule, + fetchFromGitHub, + makeBinaryWrapper, }: buildGoModule rec { diff --git a/pkgs/by-name/cl/cloud-utils/package.nix b/pkgs/by-name/cl/cloud-utils/package.nix index 294746ae9a360a..9074fc4b319ad1 100644 --- a/pkgs/by-name/cl/cloud-utils/package.nix +++ b/pkgs/by-name/cl/cloud-utils/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, gitUpdater -, makeWrapper -, gawk -, gnused -, util-linux -, file -, wget -, python3 -, qemu-utils -, e2fsprogs -, cdrkit -, gptfdisk +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + makeWrapper, + gawk, + gnused, + util-linux, + file, + wget, + python3, + qemu-utils, + e2fsprogs, + cdrkit, + gptfdisk, }: let # according to https://packages.debian.org/sid/cloud-image-utils + https://packages.debian.org/sid/admin/cloud-guest-utils @@ -44,12 +45,20 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; buildInputs = [ python3 ]; - installFlags = [ "LIBDIR=$(out)/lib" "BINDIR=$(out)/bin" "MANDIR=$(out)/man/man1" "DOCDIR=$(out)/doc" ]; + installFlags = [ + "LIBDIR=$(out)/lib" + "BINDIR=$(out)/bin" + "MANDIR=$(out)/man/man1" + "DOCDIR=$(out)/doc" + ]; # $guest output contains all executables needed for cloud-init and $out the rest + $guest # This is similar to debian's package split into cloud-image-utils and cloud-guest-utils # The reason is to reduce the closure size - outputs = [ "out" "guest" ]; + outputs = [ + "out" + "guest" + ]; postFixup = '' moveToOutput bin/ec2metadata $guest diff --git a/pkgs/by-name/cl/cloudbrute/package.nix b/pkgs/by-name/cl/cloudbrute/package.nix index cae471ce9aec82..b3695975e9c914 100644 --- a/pkgs/by-name/cl/cloudbrute/package.nix +++ b/pkgs/by-name/cl/cloudbrute/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/cl/cloudflare-utils/package.nix b/pkgs/by-name/cl/cloudflare-utils/package.nix index 005cea868e7766..ce3079bcc3d98f 100644 --- a/pkgs/by-name/cl/cloudflare-utils/package.nix +++ b/pkgs/by-name/cl/cloudflare-utils/package.nix @@ -20,6 +20,6 @@ buildGoModule rec { description = "Helpful Cloudflare utility program"; homepage = "https://github.com/Cyb3r-Jak3/cloudflare-utils"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [yelite]; + maintainers = with lib.maintainers; [ yelite ]; }; } diff --git a/pkgs/by-name/cl/cloudhunter/package.nix b/pkgs/by-name/cl/cloudhunter/package.nix index 7fdfa44031d1ba..890527a1b6fefa 100644 --- a/pkgs/by-name/cl/cloudhunter/package.nix +++ b/pkgs/by-name/cl/cloudhunter/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/cl/cloudlens/package.nix b/pkgs/by-name/cl/cloudlens/package.nix index 677b9acf005198..c36a5a50a13184 100644 --- a/pkgs/by-name/cl/cloudlens/package.nix +++ b/pkgs/by-name/cl/cloudlens/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, autoPatchelfHook -, xclip -, stdenv +{ + lib, + buildGoModule, + fetchFromGitHub, + autoPatchelfHook, + xclip, + stdenv, }: buildGoModule rec { diff --git a/pkgs/by-name/cl/cloudlog/package.nix b/pkgs/by-name/cl/cloudlog/package.nix index 22713841cccbab..e4f573221a5a3a 100644 --- a/pkgs/by-name/cl/cloudlog/package.nix +++ b/pkgs/by-name/cl/cloudlog/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, nix-update-script -, nixosTests -, php +{ + lib, + stdenvNoCC, + fetchFromGitHub, + nix-update-script, + nixosTests, + php, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/cl/cloudlogoffline/package.nix b/pkgs/by-name/cl/cloudlogoffline/package.nix index 027e91d5eb3a26..6732d3ec92a254 100644 --- a/pkgs/by-name/cl/cloudlogoffline/package.nix +++ b/pkgs/by-name/cl/cloudlogoffline/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, qt6 -, makeDesktopItem -, copyDesktopItems +{ + lib, + stdenv, + fetchFromGitHub, + qt6, + makeDesktopItem, + copyDesktopItems, }: stdenv.mkDerivation (self: { pname = "cloudlogoffline"; @@ -17,13 +18,14 @@ stdenv.mkDerivation (self: { repo = "cloudLogOffline"; }; - nativeBuildInputs = [ - qt6.qmake - qt6.wrapQtAppsHook - ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - copyDesktopItems - ]; + nativeBuildInputs = + [ + qt6.qmake + qt6.wrapQtAppsHook + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + copyDesktopItems + ]; buildInputs = [ qt6.qtbase @@ -32,26 +34,30 @@ stdenv.mkDerivation (self: { qt6.qtsvg ]; - postPatch = let - targetDir = if stdenv.hostPlatform.isDarwin then "Applications" else "bin"; - in '' - substituteInPlace CloudLogOffline.pro \ - --replace 'target.path = /opt/$''${TARGET}/bin' "target.path = $out/${targetDir}" - ''; + postPatch = + let + targetDir = if stdenv.hostPlatform.isDarwin then "Applications" else "bin"; + in + '' + substituteInPlace CloudLogOffline.pro \ + --replace 'target.path = /opt/$''${TARGET}/bin' "target.path = $out/${targetDir}" + ''; - postInstall = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - install -d $out/share/pixmaps - install -m644 images/logo_circle.svg $out/share/pixmaps/cloudlogoffline.svg - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # FIXME: For some reason, the Info.plist isn't copied correctly to - # the application bundle when building normally, instead creating an - # empty file. This doesn't happen when building in a dev shell with - # genericBuild. - # So, just copy the file manually. - plistPath="$out/Applications/CloudLogOffline.app/Contents/Info.plist" - [[ -s "$plistPath" ]] && { echo "expected Info.plist to be empty; workaround no longer needed?"; exit 1; } - install -m644 macos/Info.plist $out/Applications/CloudLogOffline.app/Contents/Info.plist - ''; + postInstall = + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + install -d $out/share/pixmaps + install -m644 images/logo_circle.svg $out/share/pixmaps/cloudlogoffline.svg + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # FIXME: For some reason, the Info.plist isn't copied correctly to + # the application bundle when building normally, instead creating an + # empty file. This doesn't happen when building in a dev shell with + # genericBuild. + # So, just copy the file manually. + plistPath="$out/Applications/CloudLogOffline.app/Contents/Info.plist" + [[ -s "$plistPath" ]] && { echo "expected Info.plist to be empty; workaround no longer needed?"; exit 1; } + install -m644 macos/Info.plist $out/Applications/CloudLogOffline.app/Contents/Info.plist + ''; desktopItems = lib.optionals (!stdenv.hostPlatform.isDarwin) [ (makeDesktopItem { @@ -61,7 +67,11 @@ stdenv.mkDerivation (self: { icon = "cloudlogoffline"; comment = self.meta.description; genericName = "Ham radio contact logbook"; - categories = [ "Network" "Utility" "HamRadio" ]; + categories = [ + "Network" + "Utility" + "HamRadio" + ]; }) ]; diff --git a/pkgs/by-name/cl/cloudmonkey/package.nix b/pkgs/by-name/cl/cloudmonkey/package.nix index ffde81b8f1b030..8505984541dba6 100644 --- a/pkgs/by-name/cl/cloudmonkey/package.nix +++ b/pkgs/by-name/cl/cloudmonkey/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "cloudmonkey"; diff --git a/pkgs/by-name/cl/cloudrecon/package.nix b/pkgs/by-name/cl/cloudrecon/package.nix index 45b50ffcaed8fa..fda6f1e81c74b9 100644 --- a/pkgs/by-name/cl/cloudrecon/package.nix +++ b/pkgs/by-name/cl/cloudrecon/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/cl/cloudsmith-cli/package.nix b/pkgs/by-name/cl/cloudsmith-cli/package.nix index ed4cde502a5c89..427c85fea92613 100644 --- a/pkgs/by-name/cl/cloudsmith-cli/package.nix +++ b/pkgs/by-name/cl/cloudsmith-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, fetchpatch +{ + lib, + python3, + fetchFromGitHub, + fetchpatch, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/cl/clp/package.nix b/pkgs/by-name/cl/clp/package.nix index c01337b8d969e6..ce042141b9374d 100644 --- a/pkgs/by-name/cl/clp/package.nix +++ b/pkgs/by-name/cl/clp/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, coin-utils, zlib, osi }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + coin-utils, + zlib, + osi, +}: stdenv.mkDerivation rec { version = "1.17.10"; @@ -12,7 +20,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ zlib coin-utils osi ]; + propagatedBuildInputs = [ + zlib + coin-utils + osi + ]; doCheck = true; diff --git a/pkgs/by-name/cl/clpeak/package.nix b/pkgs/by-name/cl/clpeak/package.nix index 6060a2078113ed..bf8285ca896959 100644 --- a/pkgs/by-name/cl/clpeak/package.nix +++ b/pkgs/by-name/cl/clpeak/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, ocl-icd, opencl-clhpp }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ocl-icd, + opencl-clhpp, +}: stdenv.mkDerivation rec { pname = "clpeak"; @@ -22,7 +29,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ ocl-icd opencl-clhpp ]; + buildInputs = [ + ocl-icd + opencl-clhpp + ]; meta = with lib; { description = "Tool which profiles OpenCL devices to find their peak capacities"; diff --git a/pkgs/by-name/cl/clubhouse-cli/package.nix b/pkgs/by-name/cl/clubhouse-cli/package.nix index 8e44b2c0cec86c..f77b9419988b1a 100644 --- a/pkgs/by-name/cl/clubhouse-cli/package.nix +++ b/pkgs/by-name/cl/clubhouse-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/cl/clustal-omega/package.nix b/pkgs/by-name/cl/clustal-omega/package.nix index 6a39a889f55fb4..1004082dcf7e14 100644 --- a/pkgs/by-name/cl/clustal-omega/package.nix +++ b/pkgs/by-name/cl/clustal-omega/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, argtable }: +{ + lib, + stdenv, + fetchurl, + argtable, +}: stdenv.mkDerivation rec { version = "1.2.4"; diff --git a/pkgs/by-name/cl/clusterctl/package.nix b/pkgs/by-name/cl/clusterctl/package.nix index 6d55e8fb1b91a9..9ff60625252b70 100644 --- a/pkgs/by-name/cl/clusterctl/package.nix +++ b/pkgs/by-name/cl/clusterctl/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, testers, clusterctl }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + clusterctl, +}: buildGoModule rec { pname = "clusterctl"; @@ -17,11 +24,15 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - ldflags = let t = "sigs.k8s.io/cluster-api/version"; in [ - "-X ${t}.gitMajor=${lib.versions.major version}" - "-X ${t}.gitMinor=${lib.versions.minor version}" - "-X ${t}.gitVersion=v${version}" - ]; + ldflags = + let + t = "sigs.k8s.io/cluster-api/version"; + in + [ + "-X ${t}.gitMajor=${lib.versions.major version}" + "-X ${t}.gitMinor=${lib.versions.minor version}" + "-X ${t}.gitVersion=v${version}" + ]; postInstall = '' # errors attempting to write config to read-only $HOME diff --git a/pkgs/by-name/cl/clutter-gtk/package.nix b/pkgs/by-name/cl/clutter-gtk/package.nix index 7800e82ff27aca..30a4607056c445 100644 --- a/pkgs/by-name/cl/clutter-gtk/package.nix +++ b/pkgs/by-name/cl/clutter-gtk/package.nix @@ -1,13 +1,14 @@ -{ fetchurl -, lib -, stdenv -, pkg-config -, meson -, ninja -, gobject-introspection -, clutter -, gtk3 -, gnome +{ + fetchurl, + lib, + stdenv, + pkg-config, + meson, + ninja, + gobject-introspection, + clutter, + gtk3, + gnome, }: let @@ -23,10 +24,21 @@ stdenv.mkDerivation rec { sha256 = "01ibniy4ich0fgpam53q252idm7f4fn5xg5qvizcfww90gn9652j"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - propagatedBuildInputs = [ clutter gtk3 ]; - nativeBuildInputs = [ meson ninja pkg-config gobject-introspection ]; + propagatedBuildInputs = [ + clutter + gtk3 + ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + gobject-introspection + ]; postPatch = '' # ld: malformed 32-bit x.y.z version number: =1 diff --git a/pkgs/by-name/cl/clutter/package.nix b/pkgs/by-name/cl/clutter/package.nix index 3831e310520878..8d3fa575cf7157 100644 --- a/pkgs/by-name/cl/clutter/package.nix +++ b/pkgs/by-name/cl/clutter/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, libGLU -, libGL -, libX11 -, libXext -, libXfixes -, libXdamage -, libXcomposite -, libXi -, libxcb -, cogl -, pango -, atk -, json-glib -, gobject-introspection -, gtk3 -, gnome -, libinput -, libgudev -, libxkbcommon +{ + lib, + stdenv, + fetchurl, + pkg-config, + libGLU, + libGL, + libX11, + libXext, + libXfixes, + libXdamage, + libXcomposite, + libXi, + libxcb, + cogl, + pango, + atk, + json-glib, + gobject-introspection, + gtk3, + gnome, + libinput, + libgudev, + libxkbcommon, }: let @@ -35,38 +36,48 @@ stdenv.mkDerivation rec { sha256 = "1rn4cd1an6a9dfda884aqpcwcgq8dgydpqvb19nmagw4b70zlj4b"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; buildInputs = [ gtk3 ]; - nativeBuildInputs = [ pkg-config gobject-introspection ]; - propagatedBuildInputs = [ - cogl - pango - atk - json-glib + nativeBuildInputs = [ + pkg-config gobject-introspection - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - libX11 - libGL - libGLU - libXext - libXfixes - libXdamage - libXcomposite - libXi - libxcb - libinput - libgudev - libxkbcommon ]; + propagatedBuildInputs = + [ + cogl + pango + atk + json-glib + gobject-introspection + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libX11 + libGL + libGLU + libXext + libXfixes + libXdamage + libXcomposite + libXi + libxcb + libinput + libgudev + libxkbcommon + ]; - configureFlags = [ - "--enable-introspection" # needed by muffin AFAIK - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "--without-x" - "--enable-x11-backend=no" - "--enable-quartz-backend=yes" - ]; + configureFlags = + [ + "--enable-introspection" # needed by muffin AFAIK + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "--without-x" + "--enable-x11-backend=no" + "--enable-quartz-backend=yes" + ]; env = lib.optionalAttrs stdenv.cc.isClang { NIX_CFLAGS_COMPILE = "-Wno-error=implicit-function-declaration"; diff --git a/pkgs/by-name/cl/clzip/package.nix b/pkgs/by-name/cl/clzip/package.nix index 8220d8b7bfa7c1..ebce63d5a1dabc 100644 --- a/pkgs/by-name/cl/clzip/package.nix +++ b/pkgs/by-name/cl/clzip/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/cm/cm256cc/package.nix b/pkgs/by-name/cm/cm256cc/package.nix index 0e8b03aa723662..a608a421eda19e 100644 --- a/pkgs/by-name/cm/cm256cc/package.nix +++ b/pkgs/by-name/cm/cm256cc/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, boost } : +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + boost, +}: stdenv.mkDerivation rec { pname = "cm256cc"; diff --git a/pkgs/by-name/cm/cm_unicode/package.nix b/pkgs/by-name/cm/cm_unicode/package.nix index fc59baa5f9d202..12500e18882cbe 100644 --- a/pkgs/by-name/cm/cm_unicode/package.nix +++ b/pkgs/by-name/cm/cm_unicode/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "cm-unicode"; @@ -21,7 +25,10 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { homepage = "https://cm-unicode.sourceforge.io/"; description = "Computer Modern Unicode fonts"; - maintainers = with maintainers; [ raskin rycee ]; + maintainers = with maintainers; [ + raskin + rycee + ]; license = licenses.ofl; platforms = platforms.all; }; diff --git a/pkgs/by-name/cm/cmakerc/package.nix b/pkgs/by-name/cm/cmakerc/package.nix index 6876bc52a2cf13..d7635c735f146e 100644 --- a/pkgs/by-name/cm/cmakerc/package.nix +++ b/pkgs/by-name/cm/cmakerc/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/cm/cmark-gfm/package.nix b/pkgs/by-name/cm/cmark-gfm/package.nix index 75ff3acdb94748..48c1b6ec8b3b03 100644 --- a/pkgs/by-name/cm/cmark-gfm/package.nix +++ b/pkgs/by-name/cm/cmark-gfm/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "cmark-gfm"; version = "0.29.0.gfm.13"; diff --git a/pkgs/by-name/cm/cmark/package.nix b/pkgs/by-name/cm/cmark/package.nix index 83407c64384db7..5f0d4a9c383fea 100644 --- a/pkgs/by-name/cm/cmark/package.nix +++ b/pkgs/by-name/cm/cmark/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "cmark"; @@ -21,11 +26,13 @@ stdenv.mkDerivation rec { doCheck = true; - preCheck = let - lib_path = if stdenv.hostPlatform.isDarwin then "DYLD_FALLBACK_LIBRARY_PATH" else "LD_LIBRARY_PATH"; - in '' - export ${lib_path}=$(readlink -f ./src) - ''; + preCheck = + let + lib_path = if stdenv.hostPlatform.isDarwin then "DYLD_FALLBACK_LIBRARY_PATH" else "LD_LIBRARY_PATH"; + in + '' + export ${lib_path}=$(readlink -f ./src) + ''; meta = with lib; { description = "CommonMark parsing and rendering library and program in C"; diff --git a/pkgs/by-name/cm/cmatrix/package.nix b/pkgs/by-name/cm/cmatrix/package.nix index 7aca6851df2171..a3a330effccfb3 100644 --- a/pkgs/by-name/cm/cmatrix/package.nix +++ b/pkgs/by-name/cm/cmatrix/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + ncurses, +}: stdenv.mkDerivation rec { pname = "cmatrix"; diff --git a/pkgs/by-name/cm/cmctl/package.nix b/pkgs/by-name/cm/cmctl/package.nix index b103450942c759..7f72b847e4d836 100644 --- a/pkgs/by-name/cm/cmctl/package.nix +++ b/pkgs/by-name/cm/cmctl/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles -, nix-update-script +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, + nix-update-script, }: buildGoModule rec { @@ -37,14 +38,16 @@ buildGoModule rec { # Trusted by this computer: no: x509: “cert-manager” certificate is not trusted doCheck = !stdenv.hostPlatform.isDarwin; - postInstall = '' - mv $out/bin/ctl $out/bin/cmctl - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - installShellCompletion --cmd cmctl \ - --bash <($out/bin/cmctl completion bash) \ - --fish <($out/bin/cmctl completion fish) \ - --zsh <($out/bin/cmctl completion zsh) - ''; + postInstall = + '' + mv $out/bin/ctl $out/bin/cmctl + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + installShellCompletion --cmd cmctl \ + --bash <($out/bin/cmctl completion bash) \ + --fish <($out/bin/cmctl completion fish) \ + --zsh <($out/bin/cmctl completion zsh) + ''; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/by-name/cm/cmd-wrapped/package.nix b/pkgs/by-name/cm/cmd-wrapped/package.nix index f98ba3bee930b4..a3081227d97668 100644 --- a/pkgs/by-name/cm/cmd-wrapped/package.nix +++ b/pkgs/by-name/cm/cmd-wrapped/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/cm/cmdstan/package.nix b/pkgs/by-name/cm/cmdstan/package.nix index 5199d457f4df6c..6ddbcaedff10f3 100644 --- a/pkgs/by-name/cm/cmdstan/package.nix +++ b/pkgs/by-name/cm/cmdstan/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 -, stanc -, buildPackages -, runtimeShell -, runCommandCC -, cmdstan +{ + lib, + stdenv, + fetchFromGitHub, + python3, + stanc, + buildPackages, + runtimeShell, + runCommandCC, + cmdstan, }: stdenv.mkDerivation rec { @@ -31,23 +32,26 @@ stdenv.mkDerivation rec { stanc ]; - preConfigure = '' - patchShebangs test-all.sh runCmdStanTests.py stan/ - '' - # Fix inclusion of hardcoded paths in PCH files, by building in the store. - + '' - mkdir -p $out/opt - cp -R . $out/opt/cmdstan - cd $out/opt/cmdstan - mkdir -p bin - ln -s ${buildPackages.stanc}/bin/stanc bin/stanc - ''; + preConfigure = + '' + patchShebangs test-all.sh runCmdStanTests.py stan/ + '' + # Fix inclusion of hardcoded paths in PCH files, by building in the store. + + '' + mkdir -p $out/opt + cp -R . $out/opt/cmdstan + cd $out/opt/cmdstan + mkdir -p bin + ln -s ${buildPackages.stanc}/bin/stanc bin/stanc + ''; - makeFlags = [ - "build" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "arch=${stdenv.hostPlatform.darwinArch}" - ]; + makeFlags = + [ + "build" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "arch=${stdenv.hostPlatform.darwinArch}" + ]; # Disable inclusion of timestamps in PCH files when using Clang. env.CXXFLAGS = lib.optionalString stdenv.cc.isClang "-Xclang -fno-pch-timestamp"; diff --git a/pkgs/by-name/cm/cmigemo/package.nix b/pkgs/by-name/cm/cmigemo/package.nix index 74f5a5100d2799..cd85f7d3d83e6a 100644 --- a/pkgs/by-name/cm/cmigemo/package.nix +++ b/pkgs/by-name/cm/cmigemo/package.nix @@ -1,6 +1,12 @@ -{ lib, stdenv, fetchFromGitHub -, iconv, nkf, perl, which -, skkDictionaries +{ + lib, + stdenv, + fetchFromGitHub, + iconv, + nkf, + perl, + which, + skkDictionaries, }: stdenv.mkDerivation { @@ -14,7 +20,12 @@ stdenv.mkDerivation { sha256 = "00a6kdmxp16b8x0p04ws050y39qspd1bqlfq74bkirc55b77a2m1"; }; - nativeBuildInputs = [ iconv nkf perl which ]; + nativeBuildInputs = [ + iconv + nkf + perl + which + ]; postUnpack = '' cp ${skkDictionaries.l}/share/skk/SKK-JISYO.L source/dict/ diff --git a/pkgs/by-name/cm/cminpack/package.nix b/pkgs/by-name/cm/cminpack/package.nix index 81224c0fdaa366..08f5ea016148d6 100644 --- a/pkgs/by-name/cm/cminpack/package.nix +++ b/pkgs/by-name/cm/cminpack/package.nix @@ -1,9 +1,11 @@ -{ lib -, stdenv -, cmake -, darwin -, fetchFromGitHub -, withBlas ? true, blas +{ + lib, + stdenv, + cmake, + darwin, + fetchFromGitHub, + withBlas ? true, + blas, }: stdenv.mkDerivation rec { @@ -23,13 +25,15 @@ stdenv.mkDerivation rec { cmake ]; - buildInputs = lib.optionals withBlas [ - blas - ] ++ lib.optionals (withBlas && stdenv.hostPlatform.isDarwin) [ - darwin.apple_sdk.frameworks.Accelerate - darwin.apple_sdk.frameworks.CoreGraphics - darwin.apple_sdk.frameworks.CoreVideo - ]; + buildInputs = + lib.optionals withBlas [ + blas + ] + ++ lib.optionals (withBlas && stdenv.hostPlatform.isDarwin) [ + darwin.apple_sdk.frameworks.Accelerate + darwin.apple_sdk.frameworks.CoreGraphics + darwin.apple_sdk.frameworks.CoreVideo + ]; cmakeFlags = [ "-DUSE_BLAS=${if withBlas then "ON" else "OFF"}" diff --git a/pkgs/by-name/cm/cmocka/package.nix b/pkgs/by-name/cm/cmocka/package.nix index 9a7ea037785bfc..74de381fbe52fe 100644 --- a/pkgs/by-name/cm/cmocka/package.nix +++ b/pkgs/by-name/cm/cmocka/package.nix @@ -1,4 +1,9 @@ -{ fetchurl, lib, stdenv, cmake }: +{ + fetchurl, + lib, + stdenv, + cmake, +}: stdenv.mkDerivation rec { pname = "cmocka"; @@ -16,7 +21,8 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - cmakeFlags = lib.optional doCheck "-DUNIT_TESTING=ON" + cmakeFlags = + lib.optional doCheck "-DUNIT_TESTING=ON" ++ lib.optional stdenv.hostPlatform.isStatic "-DBUILD_SHARED_LIBS=OFF"; doCheck = true; @@ -51,6 +57,9 @@ stdenv.mkDerivation rec { homepage = "https://cmocka.org/"; license = licenses.asl20; platforms = platforms.all; - maintainers = with maintainers; [ kragniz rasendubi ]; + maintainers = with maintainers; [ + kragniz + rasendubi + ]; }; } diff --git a/pkgs/by-name/cm/cmospwd/package.nix b/pkgs/by-name/cm/cmospwd/package.nix index 9243afa1aad75c..e9cdf0fc263f97 100644 --- a/pkgs/by-name/cm/cmospwd/package.nix +++ b/pkgs/by-name/cm/cmospwd/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchurl -, stdenv +{ + lib, + fetchurl, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/cm/cmrt/package.nix b/pkgs/by-name/cm/cmrt/package.nix index 2e3fc7a3a1982b..60d17e593c6bf0 100644 --- a/pkgs/by-name/cm/cmrt/package.nix +++ b/pkgs/by-name/cm/cmrt/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, libdrm, libva }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libdrm, + libva, +}: stdenv.mkDerivation rec { pname = "cmrt"; @@ -11,9 +19,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-W6MQI41J9CKeM1eILCkvmW34cbCC8YeEF2mE+Ci8o7s="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ libdrm libva ]; + buildInputs = [ + libdrm + libva + ]; meta = with lib; { broken = (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64); diff --git a/pkgs/by-name/cm/cmt/package.nix b/pkgs/by-name/cm/cmt/package.nix index bf7ed0ee37d4b1..87caa2d32603fa 100644 --- a/pkgs/by-name/cm/cmt/package.nix +++ b/pkgs/by-name/cm/cmt/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchurl -, ladspaH +{ + lib, + stdenv, + fetchurl, + ladspaH, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cm/cmtk/package.nix b/pkgs/by-name/cm/cmtk/package.nix index f454bfc4f41540..c7fa4fb79e5ff0 100644 --- a/pkgs/by-name/cm/cmtk/package.nix +++ b/pkgs/by-name/cm/cmtk/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, bzip2 -, cmake -, fetchurl -, fftw -, llvmPackages -, zlib +{ + lib, + stdenv, + bzip2, + cmake, + fetchurl, + fftw, + llvmPackages, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -26,19 +27,23 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ cmake ]; - buildInputs = [ - bzip2 - fftw - zlib - ] ++ lib.optionals stdenv.cc.isClang [ - llvmPackages.openmp - ]; + buildInputs = + [ + bzip2 + fftw + zlib + ] + ++ lib.optionals stdenv.cc.isClang [ + llvmPackages.openmp + ]; - cmakeFlags = [ - (lib.cmakeFeature "CMAKE_CXX_STANDARD" "14") - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - (lib.cmakeFeature "CMAKE_CXX_FLAGS" "-Dfinite=isfinite") - ]; + cmakeFlags = + [ + (lib.cmakeFeature "CMAKE_CXX_STANDARD" "14") + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + (lib.cmakeFeature "CMAKE_CXX_FLAGS" "-Dfinite=isfinite") + ]; meta = with lib; { description = "Computational Morphometry Toolkit"; diff --git a/pkgs/by-name/cm/cmusfm/package.nix b/pkgs/by-name/cm/cmusfm/package.nix index 117356bf948e7b..c46dd39415690c 100644 --- a/pkgs/by-name/cm/cmusfm/package.nix +++ b/pkgs/by-name/cm/cmusfm/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, curl, libnotify -, gdk-pixbuf, libnotifySupport ? stdenv.hostPlatform.isLinux, debug ? false }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + curl, + libnotify, + gdk-pixbuf, + libnotifySupport ? stdenv.hostPlatform.isLinux, + debug ? false, +}: stdenv.mkDerivation rec { pname = "cmusfm"; @@ -12,13 +22,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-CA585ZpkxMMLgzv81QB2kKMFg5R5CwKS9xAYrU+pAxs="; }; - configureFlags = lib.optional libnotifySupport "--enable-libnotify" + configureFlags = + lib.optional libnotifySupport "--enable-libnotify" ++ lib.optional debug "--enable-debug"; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ curl gdk-pixbuf ] - ++ lib.optional libnotifySupport libnotify; + buildInputs = [ + curl + gdk-pixbuf + ] ++ lib.optional libnotifySupport libnotify; meta = with lib; { description = "Last.fm and Libre.fm standalone scrobbler for the cmus music player"; @@ -35,7 +51,10 @@ stdenv.mkDerivation rec { + Inside cmus run `:set status_display_program=cmusfm` to set up cmusfm ''; homepage = "https://github.com/Arkq/cmusfm/"; - maintainers = with lib.maintainers; [ CharlesHD mudri ]; + maintainers = with lib.maintainers; [ + CharlesHD + mudri + ]; license = licenses.gpl3Plus; platforms = platforms.linux ++ platforms.darwin; mainProgram = "cmusfm"; diff --git a/pkgs/by-name/cn/cnijfilter2/package.nix b/pkgs/by-name/cn/cnijfilter2/package.nix index 5be4e17581b6e9..c040987773cd04 100644 --- a/pkgs/by-name/cn/cnijfilter2/package.nix +++ b/pkgs/by-name/cn/cnijfilter2/package.nix @@ -1,5 +1,16 @@ -{ stdenv, lib, fetchzip, autoconf, automake, cups, glib, libxml2, libusb1, libtool -, withDebug ? false }: +{ + stdenv, + lib, + fetchzip, + autoconf, + automake, + cups, + glib, + libxml2, + libusb1, + libtool, + withDebug ? false, +}: stdenv.mkDerivation { pname = "cnijfilter2"; @@ -11,9 +22,16 @@ stdenv.mkDerivation { sha256 = "3RoG83jLOsdTEmvUkkxb7wa8oBrJA4v1mGtxTGwSowU="; }; - nativeBuildInputs = [ automake autoconf ]; + nativeBuildInputs = [ + automake + autoconf + ]; buildInputs = [ - cups glib libxml2 libusb1 libtool + cups + glib + libxml2 + libusb1 + libtool ]; patches = [ @@ -27,67 +45,70 @@ stdenv.mkDerivation { # # Note that the drivers attempt to dlopen # $out/lib/cups/filter/libcnbpcnclapicom2.so - buildPhase = '' - mkdir -p $out/lib - cp com/libs_bin_x86_64/* $out/lib - mkdir -p $out/lib/cups/filter - ln -s $out/lib/libcnbpcnclapicom2.so $out/lib/cups/filter - - export NIX_LDFLAGS="$NIX_LDFLAGS -L$out/lib" - '' + lib.optionalString withDebug '' - export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -D__DEBUG__ -DDEBUG_LOG" - '' + '' - - ( - cd lgmon3 - substituteInPlace src/Makefile.am \ - --replace /usr/include/libusb-1.0 \ - ${libusb1.dev}/include/libusb-1.0 - ./autogen.sh --prefix=$out --enable-progpath=$out/bin \ - --datadir=$out/share \ - --enable-libdir=/var/cache/cups - make - ) - - ( - cd cmdtocanonij2 - ./autogen.sh --prefix=$out - make - ) - - ( - cd cmdtocanonij3 - ./autogen.sh --prefix=$out - make - ) - - ( - cd cnijbe2 - substituteInPlace src/Makefile.am \ - --replace "/usr/lib/cups/backend" \ - "$out/lib/cups/backend" - ./autogen.sh --prefix=$out --enable-progpath=$out/bin - make - ) - - ( - cd rastertocanonij - ./autogen.sh --prefix=$out --enable-progpath=$out/bin - make - ) - - ( - cd tocanonij - ./autogen.sh --prefix=$out --enable-progpath=$out/bin - make - ) - - ( - cd tocnpwg - ./autogen.sh --prefix=$out --enable-progpath=$out/bin - make - ) - ''; + buildPhase = + '' + mkdir -p $out/lib + cp com/libs_bin_x86_64/* $out/lib + mkdir -p $out/lib/cups/filter + ln -s $out/lib/libcnbpcnclapicom2.so $out/lib/cups/filter + + export NIX_LDFLAGS="$NIX_LDFLAGS -L$out/lib" + '' + + lib.optionalString withDebug '' + export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -D__DEBUG__ -DDEBUG_LOG" + '' + + '' + + ( + cd lgmon3 + substituteInPlace src/Makefile.am \ + --replace /usr/include/libusb-1.0 \ + ${libusb1.dev}/include/libusb-1.0 + ./autogen.sh --prefix=$out --enable-progpath=$out/bin \ + --datadir=$out/share \ + --enable-libdir=/var/cache/cups + make + ) + + ( + cd cmdtocanonij2 + ./autogen.sh --prefix=$out + make + ) + + ( + cd cmdtocanonij3 + ./autogen.sh --prefix=$out + make + ) + + ( + cd cnijbe2 + substituteInPlace src/Makefile.am \ + --replace "/usr/lib/cups/backend" \ + "$out/lib/cups/backend" + ./autogen.sh --prefix=$out --enable-progpath=$out/bin + make + ) + + ( + cd rastertocanonij + ./autogen.sh --prefix=$out --enable-progpath=$out/bin + make + ) + + ( + cd tocanonij + ./autogen.sh --prefix=$out --enable-progpath=$out/bin + make + ) + + ( + cd tocnpwg + ./autogen.sh --prefix=$out --enable-progpath=$out/bin + make + ) + ''; installPhase = '' ( @@ -144,7 +165,10 @@ stdenv.mkDerivation { ''; homepage = "https://hk.canon/en/support/0101048401/1"; license = licenses.unfree; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; maintainers = [ ]; }; } diff --git a/pkgs/by-name/cn/cnijfilter_4_00/package.nix b/pkgs/by-name/cn/cnijfilter_4_00/package.nix index d632ed12d89bdf..4ae5a908bf8722 100644 --- a/pkgs/by-name/cn/cnijfilter_4_00/package.nix +++ b/pkgs/by-name/cn/cnijfilter_4_00/package.nix @@ -1,28 +1,49 @@ -{ stdenv, lib, fetchzip, - autoconf, automake, libtool, - cups, popt, libtiff, libpng, - ghostscript, glib, libusb1, libxml2 }: - -/* this derivation is basically just a transcription of the rpm .spec - file included in the tarball */ - -let arch = - if stdenv.hostPlatform.system == "x86_64-linux" then "64" - else if stdenv.hostPlatform.system == "i686-linux" then "32" - else throw "Unsupported system ${stdenv.hostPlatform.system}"; - -in stdenv.mkDerivation { +{ + stdenv, + lib, + fetchzip, + autoconf, + automake, + libtool, + cups, + popt, + libtiff, + libpng, + ghostscript, + glib, + libusb1, + libxml2, +}: + +/* + this derivation is basically just a transcription of the rpm .spec + file included in the tarball +*/ + +let + arch = + if stdenv.hostPlatform.system == "x86_64-linux" then + "64" + else if stdenv.hostPlatform.system == "i686-linux" then + "32" + else + throw "Unsupported system ${stdenv.hostPlatform.system}"; + +in +stdenv.mkDerivation { pname = "cnijfilter"; - /* important note about versions: cnijfilter packages seem to use - versions in a non-standard way. the version indicates which - printers are supported in the package. so this package should - not be "upgraded" in the usual way. - - instead, if you want to include another version supporting your - printer, you should try to abstract out the common things (which - should be pretty much everything except the version and the 'pr' - and 'pr_id' values to loop over). */ + /* + important note about versions: cnijfilter packages seem to use + versions in a non-standard way. the version indicates which + printers are supported in the package. so this package should + not be "upgraded" in the usual way. + + instead, if you want to include another version supporting your + printer, you should try to abstract out the common things (which + should be pretty much everything except the version and the 'pr' + and 'pr_id' values to loop over). + */ version = "4.00"; src = fetchzip { @@ -30,10 +51,21 @@ in stdenv.mkDerivation { sha256 = "1f6vpx1z3qa88590i5m0s49j9n90vpk81xmw6pvj0nfd3qbvzkya"; }; - nativeBuildInputs = [ autoconf automake ]; - buildInputs = [ libtool - cups popt libtiff libpng - ghostscript glib libusb1 libxml2 ]; + nativeBuildInputs = [ + autoconf + automake + ]; + buildInputs = [ + libtool + cups + popt + libtiff + libpng + ghostscript + glib + libusb1 + libxml2 + ]; # patches from https://github.com/tokiclover/bar-overlay/tree/master/net-print/cnijfilter patches = [ @@ -132,14 +164,16 @@ in stdenv.mkDerivation { popd; ''; - /* the tarball includes some pre-built shared libraries. we run - 'patchelf --set-rpath' on them just a few lines above, so that - they can find each other. but that's not quite enough. some of - those libraries load each other in non-standard ways -- they - don't list each other in the DT_NEEDED section. so, if the - standard 'patchelf --shrink-rpath' (from - pkgs/development/tools/misc/patchelf/setup-hook.sh) is run on - them, it undoes the --set-rpath. this prevents that. */ + /* + the tarball includes some pre-built shared libraries. we run + 'patchelf --set-rpath' on them just a few lines above, so that + they can find each other. but that's not quite enough. some of + those libraries load each other in non-standard ways -- they + don't list each other in the DT_NEEDED section. so, if the + standard 'patchelf --shrink-rpath' (from + pkgs/development/tools/misc/patchelf/setup-hook.sh) is run on + them, it undoes the --set-rpath. this prevents that. + */ dontPatchELF = true; meta = with lib; { diff --git a/pkgs/by-name/cn/cnping/package.nix b/pkgs/by-name/cn/cnping/package.nix index 9058bcb674c8c6..2fe587f6e5b1c1 100644 --- a/pkgs/by-name/cn/cnping/package.nix +++ b/pkgs/by-name/cn/cnping/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, libglvnd, xorg }: +{ + lib, + stdenv, + fetchFromGitHub, + libglvnd, + xorg, +}: stdenv.mkDerivation rec { pname = "cnping"; @@ -12,7 +18,12 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - buildInputs = [ libglvnd xorg.libXinerama xorg.libXext xorg.libX11 ]; + buildInputs = [ + libglvnd + xorg.libXinerama + xorg.libXext + xorg.libX11 + ]; # The "linuxinstall" target won't work for us: # it tries to setcap and copy to a FHS directory @@ -25,7 +36,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Minimal Graphical IPV4 Ping Tool"; homepage = "https://github.com/cntools/cnping"; - license = with licenses; [ mit bsd3 ]; # dual licensed, MIT-x11 & BSD-3-Clause + license = with licenses; [ + mit + bsd3 + ]; # dual licensed, MIT-x11 & BSD-3-Clause maintainers = [ ]; platforms = platforms.linux; mainProgram = "cnping"; diff --git a/pkgs/by-name/cn/cnstrokeorder/package.nix b/pkgs/by-name/cn/cnstrokeorder/package.nix index 66803b1b63ff8e..d6908d08ecf711 100644 --- a/pkgs/by-name/cn/cnstrokeorder/package.nix +++ b/pkgs/by-name/cn/cnstrokeorder/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "cnstrokeorder"; diff --git a/pkgs/by-name/cn/cntb/package.nix b/pkgs/by-name/cn/cntb/package.nix index 75efd4e0727c09..69622e914a10f0 100644 --- a/pkgs/by-name/cn/cntb/package.nix +++ b/pkgs/by-name/cn/cntb/package.nix @@ -1,7 +1,9 @@ -{ buildGoModule -, lib -, fetchFromGitHub -}: buildGoModule rec { +{ + buildGoModule, + lib, + fetchFromGitHub, +}: +buildGoModule rec { pname = "cntb"; version = "1.4.12"; diff --git a/pkgs/by-name/cn/cntlm/package.nix b/pkgs/by-name/cn/cntlm/package.nix index 8750967107efec..da0446ac3ac05d 100644 --- a/pkgs/by-name/cn/cntlm/package.nix +++ b/pkgs/by-name/cn/cntlm/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, which}: +{ + lib, + stdenv, + fetchurl, + which, +}: stdenv.mkDerivation rec { pname = "cntlm"; @@ -26,11 +31,10 @@ stdenv.mkDerivation rec { description = "NTLM/NTLMv2 authenticating HTTP proxy"; homepage = "https://cntlm.sourceforge.net/"; license = licenses.gpl2Only; - maintainers = - [ - maintainers.qknight - maintainers.carlosdagos - ]; + maintainers = [ + maintainers.qknight + maintainers.carlosdagos + ]; platforms = platforms.linux ++ platforms.darwin; mainProgram = "cntlm"; }; diff --git a/pkgs/by-name/cn/cntr/package.nix b/pkgs/by-name/cn/cntr/package.nix index 0a4f9b999d9464..01cdabf3ce77f9 100644 --- a/pkgs/by-name/cn/cntr/package.nix +++ b/pkgs/by-name/cn/cntr/package.nix @@ -1,4 +1,9 @@ -{ lib, rustPlatform, fetchFromGitHub, nixosTests }: +{ + lib, + rustPlatform, + fetchFromGitHub, + nixosTests, +}: rustPlatform.buildRustPackage rec { pname = "cntr"; @@ -20,7 +25,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/Mic92/cntr"; license = licenses.mit; platforms = platforms.linux; - maintainers = with maintainers; [ mic92 sigmasquadron ]; + maintainers = with maintainers; [ + mic92 + sigmasquadron + ]; mainProgram = "cntr"; }; } diff --git a/pkgs/by-name/co/coan/package.nix b/pkgs/by-name/co/coan/package.nix index 94c45614ed8447..4d8b9564271212 100644 --- a/pkgs/by-name/co/coan/package.nix +++ b/pkgs/by-name/co/coan/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, autoreconfHook, perl }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + perl, +}: stdenv.mkDerivation rec { version = "6.0.1"; @@ -14,7 +20,10 @@ stdenv.mkDerivation rec { ./fix-big-endian-config-check.diff ]; - nativeBuildInputs = [ autoreconfHook perl ]; + nativeBuildInputs = [ + autoreconfHook + perl + ]; configureFlags = [ "CXXFLAGS=-std=c++11" ]; diff --git a/pkgs/by-name/co/cobra-cli/package.nix b/pkgs/by-name/co/cobra-cli/package.nix index d94ef657d74145..c0883a60c71bfb 100644 --- a/pkgs/by-name/co/cobra-cli/package.nix +++ b/pkgs/by-name/co/cobra-cli/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, makeWrapper, go }: +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + go, +}: buildGoModule rec { pname = "cobra-cli"; diff --git a/pkgs/by-name/co/cockpit/package.nix b/pkgs/by-name/co/cockpit/package.nix index 586368222857cc..51ee6fcc3d97dc 100644 --- a/pkgs/by-name/co/cockpit/package.nix +++ b/pkgs/by-name/co/cockpit/package.nix @@ -1,39 +1,40 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, bashInteractive -, cacert -, coreutils -, dbus -, docbook_xml_dtd_43 -, docbook_xsl -, findutils -, gettext -, git -, glib -, glib-networking -, gnused -, gnutls -, json-glib -, krb5 -, libssh -, libxcrypt -, libxslt -, makeWrapper -, nodejs -, nixosTests -, nix-update-script -, openssh -, openssl -, pam -, pkg-config -, polkit -, python3Packages -, runtimeShell -, systemd -, udev -, xmlto +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + bashInteractive, + cacert, + coreutils, + dbus, + docbook_xml_dtd_43, + docbook_xsl, + findutils, + gettext, + git, + glib, + glib-networking, + gnused, + gnutls, + json-glib, + krb5, + libssh, + libxcrypt, + libxslt, + makeWrapper, + nodejs, + nixosTests, + nix-update-script, + openssh, + openssl, + pam, + pkg-config, + polkit, + python3Packages, + runtimeShell, + systemd, + udev, + xmlto, }: stdenv.mkDerivation rec { @@ -168,7 +169,12 @@ stdenv.mkDerivation rec { runHook preFixup wrapProgram $out/libexec/cockpit-certificate-helper \ - --prefix PATH : ${lib.makeBinPath [ coreutils openssl ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + openssl + ] + } \ --run 'cd $(mktemp -d)' wrapProgram $out/share/cockpit/motd/update-motd \ @@ -210,7 +216,7 @@ stdenv.mkDerivation rec { passthru = { tests = { inherit (nixosTests) cockpit; }; - updateScript = nix-update-script {}; + updateScript = nix-update-script { }; }; meta = with lib; { diff --git a/pkgs/by-name/co/cockroachdb/package.nix b/pkgs/by-name/co/cockroachdb/package.nix index c155e0aa076e8e..e362eb8c8d23e7 100644 --- a/pkgs/by-name/co/cockroachdb/package.nix +++ b/pkgs/by-name/co/cockroachdb/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchzip -, buildFHSEnv +{ + lib, + stdenv, + fetchzip, + buildFHSEnv, }: let @@ -24,7 +25,8 @@ let hash = "sha256-goCBE+zv9KArdoMsI48rlISurUM0bL/l1OEYWQKqzv0="; }; }; - src = srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); in buildFHSEnv { @@ -45,7 +47,13 @@ buildFHSEnv { cockroachdb-community-license ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - platforms = [ "aarch64-linux" "x86_64-linux" ]; - maintainers = with maintainers; [ rushmorem thoughtpolice ]; + platforms = [ + "aarch64-linux" + "x86_64-linux" + ]; + maintainers = with maintainers; [ + rushmorem + thoughtpolice + ]; }; } diff --git a/pkgs/by-name/co/coconutbattery/package.nix b/pkgs/by-name/co/coconutbattery/package.nix index d3e67c96cfddf5..cef8e8b2776918 100644 --- a/pkgs/by-name/co/coconutbattery/package.nix +++ b/pkgs/by-name/co/coconutbattery/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchzip +{ + lib, + stdenvNoCC, + fetchzip, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -8,7 +9,9 @@ stdenvNoCC.mkDerivation (finalAttrs: { version = "3.9.14"; src = fetchzip { - url = "https://coconut-flavour.com/downloads/coconutBattery_${builtins.replaceStrings [ "." ] [ "" ] finalAttrs.version}.zip"; + url = "https://coconut-flavour.com/downloads/coconutBattery_${ + builtins.replaceStrings [ "." ] [ "" ] finalAttrs.version + }.zip"; hash = "sha256-zKSPKwDBwxlyNJFurCLLGtba9gpizJCjOOAd81vdD5Q="; }; @@ -36,6 +39,9 @@ stdenvNoCC.mkDerivation (finalAttrs: { license = with licenses; [ unfree ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; maintainers = with maintainers; [ stepbrobd ]; - platforms = [ "aarch64-darwin" "x86_64-darwin" ]; + platforms = [ + "aarch64-darwin" + "x86_64-darwin" + ]; }; }) diff --git a/pkgs/by-name/co/cod/package.nix b/pkgs/by-name/co/cod/package.nix index 08ea681eedb8b7..6dd5ef4d82a589 100644 --- a/pkgs/by-name/co/cod/package.nix +++ b/pkgs/by-name/co/cod/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, buildGoModule, python3 }: +{ + stdenv, + lib, + fetchFromGitHub, + buildGoModule, + python3, +}: buildGoModule rec { pname = "cod"; @@ -13,7 +19,11 @@ buildGoModule rec { vendorHash = "sha256-kezfBDTgpOTBYKTNlwuP+M5tXU2w/MXz0B5nBJcL1io="; - ldflags = [ "-s" "-w" "-X main.GitSha=${src.rev}" ]; + ldflags = [ + "-s" + "-w" + "-X main.GitSha=${src.rev}" + ]; nativeCheckInputs = [ python3 ]; diff --git a/pkgs/by-name/co/code-maat/package.nix b/pkgs/by-name/co/code-maat/package.nix index 2046322390c111..5713fb7ee08487 100644 --- a/pkgs/by-name/co/code-maat/package.nix +++ b/pkgs/by-name/co/code-maat/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchurl -, makeBinaryWrapper -, jre +{ + lib, + stdenvNoCC, + fetchurl, + makeBinaryWrapper, + jre, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/co/code-minimap/package.nix b/pkgs/by-name/co/code-minimap/package.nix index 2bc64b425e5ff7..726989ca8a94b9 100644 --- a/pkgs/by-name/co/code-minimap/package.nix +++ b/pkgs/by-name/co/code-minimap/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, libiconv +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + libiconv, }: rustPlatform.buildRustPackage rec { @@ -23,7 +24,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "High performance code minimap render"; homepage = "https://github.com/wfxr/code-minimap"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ bsima ]; mainProgram = "code-minimap"; }; diff --git a/pkgs/by-name/co/codeberg-pages/package.nix b/pkgs/by-name/co/codeberg-pages/package.nix index 90252be0619975..9b424cf6d1b0dc 100644 --- a/pkgs/by-name/co/codeberg-pages/package.nix +++ b/pkgs/by-name/co/codeberg-pages/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitea, buildGoModule, nix-update-script }: +{ + lib, + fetchFromGitea, + buildGoModule, + nix-update-script, +}: buildGoModule rec { pname = "codeberg-pages"; @@ -19,15 +24,25 @@ buildGoModule rec { rm server/handler/handler_test.go ''; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; - tags = [ "sqlite" "sqlite_unlock_notify" "netgo" ]; + tags = [ + "sqlite" + "sqlite_unlock_notify" + "netgo" + ]; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = with lib; { mainProgram = "pages"; - maintainers = with maintainers; [ laurent-f1z1 christoph-heiss ]; + maintainers = with maintainers; [ + laurent-f1z1 + christoph-heiss + ]; license = licenses.eupl12; homepage = "https://codeberg.org/Codeberg/pages-server"; description = "Static websites hosting from Gitea repositories"; diff --git a/pkgs/by-name/co/codeblocks/package.nix b/pkgs/by-name/co/codeblocks/package.nix index 80fbe5674635dc..a62b5d690346ef 100644 --- a/pkgs/by-name/co/codeblocks/package.nix +++ b/pkgs/by-name/co/codeblocks/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, file, zip, wxGTK32, gtk3 -, contribPlugins ? false, hunspell, boost, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + file, + zip, + wxGTK32, + gtk3, + contribPlugins ? false, + hunspell, + boost, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -12,9 +24,21 @@ stdenv.mkDerivation rec { sha256 = "1idaksw1vacmm83krxh5zlb12kad3dkz9ixh70glw1gaibib7vhm"; }; - nativeBuildInputs = [ pkg-config file zip wrapGAppsHook3 ]; - buildInputs = [ wxGTK32 gtk3 ] - ++ lib.optionals contribPlugins [ hunspell boost ]; + nativeBuildInputs = [ + pkg-config + file + zip + wrapGAppsHook3 + ]; + buildInputs = + [ + wxGTK32 + gtk3 + ] + ++ lib.optionals contribPlugins [ + hunspell + boost + ]; enableParallelBuilding = true; patches = [ ./writable-projects.patch @@ -118,10 +142,15 @@ stdenv.mkDerivation rec { ]; preConfigure = "substituteInPlace ./configure --replace /usr/bin/file ${file}/bin/file"; postConfigure = lib.optionalString stdenv.hostPlatform.isLinux "substituteInPlace libtool --replace ldconfig ${stdenv.cc.libc.bin}/bin/ldconfig"; - configureFlags = [ "--enable-pch=no" ] ++ lib.optionals contribPlugins [ - ("--with-contrib-plugins=all,-FileManager" + lib.optionalString stdenv.hostPlatform.isDarwin ",-NassiShneiderman") - "--with-boost-libdir=${boost}/lib" - ]; + configureFlags = + [ "--enable-pch=no" ] + ++ lib.optionals contribPlugins [ + ( + "--with-contrib-plugins=all,-FileManager" + + lib.optionalString stdenv.hostPlatform.isDarwin ",-NassiShneiderman" + ) + "--with-boost-libdir=${boost}/lib" + ]; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' ln -s $out/lib/codeblocks/plugins $out/share/codeblocks/plugins ''; @@ -130,12 +159,11 @@ stdenv.mkDerivation rec { maintainers = [ maintainers.linquize ]; platforms = platforms.all; description = "Open source, cross platform, free C, C++ and Fortran IDE"; - longDescription = - '' - Code::Blocks is a free C, C++ and Fortran IDE built to meet the most demanding needs of its users. - It is designed to be very extensible and fully configurable. - Finally, an IDE with all the features you need, having a consistent look, feel and operation across platforms. - ''; + longDescription = '' + Code::Blocks is a free C, C++ and Fortran IDE built to meet the most demanding needs of its users. + It is designed to be very extensible and fully configurable. + Finally, an IDE with all the features you need, having a consistent look, feel and operation across platforms. + ''; homepage = "http://www.codeblocks.org"; license = licenses.gpl3; }; diff --git a/pkgs/by-name/co/codebraid/package.nix b/pkgs/by-name/co/codebraid/package.nix index 516dd66cf01b0b..9c31dc62450137 100644 --- a/pkgs/by-name/co/codebraid/package.nix +++ b/pkgs/by-name/co/codebraid/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "codebraid"; diff --git a/pkgs/by-name/co/codec2/package.nix b/pkgs/by-name/co/codec2/package.nix index 308db170bc329c..f5c82cfb8a51d2 100644 --- a/pkgs/by-name/co/codec2/package.nix +++ b/pkgs/by-name/co/codec2/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, freedvSupport ? false -, lpcnetfreedv +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + freedvSupport ? false, + lpcnetfreedv, }: stdenv.mkDerivation rec { @@ -32,12 +33,14 @@ stdenv.mkDerivation rec { sed -r -i 's/(\<_Complex)(\s+)(float|double)/\3\2\1/' $out/include/$pname/freedv_api.h ''; - cmakeFlags = [ - # RPATH of binary /nix/store/.../bin/freedv_rx contains a forbidden reference to /build/ - "-DCMAKE_SKIP_BUILD_RPATH=ON" - ] ++ lib.optionals freedvSupport [ - "-DLPCNET=ON" - ]; + cmakeFlags = + [ + # RPATH of binary /nix/store/.../bin/freedv_rx contains a forbidden reference to /build/ + "-DCMAKE_SKIP_BUILD_RPATH=ON" + ] + ++ lib.optionals freedvSupport [ + "-DLPCNET=ON" + ]; meta = with lib; { description = "Speech codec designed for communications quality speech at low data rates"; diff --git a/pkgs/by-name/co/codefresh/package.nix b/pkgs/by-name/co/codefresh/package.nix index fc6829cba2c39c..cfba4df8298d08 100644 --- a/pkgs/by-name/co/codefresh/package.nix +++ b/pkgs/by-name/co/codefresh/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchYarnDeps, yarnConfigHook, yarnInstallHook, nodejs, testers }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + yarnConfigHook, + yarnInstallHook, + nodejs, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "codefresh"; diff --git a/pkgs/by-name/co/codemov/package.nix b/pkgs/by-name/co/codemov/package.nix index 2134a7300f13ba..f667279800531c 100644 --- a/pkgs/by-name/co/codemov/package.nix +++ b/pkgs/by-name/co/codemov/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, makeBinaryWrapper -, pkg-config -, oniguruma -, ffmpeg -, git +{ + lib, + rustPlatform, + fetchFromGitHub, + makeBinaryWrapper, + pkg-config, + oniguruma, + ffmpeg, + git, }: rustPlatform.buildRustPackage { @@ -42,7 +43,12 @@ rustPlatform.buildRustPackage { postInstall = '' wrapProgram $out/bin/codemov \ - --prefix PATH : ${lib.makeBinPath [ ffmpeg git ]} + --prefix PATH : ${ + lib.makeBinPath [ + ffmpeg + git + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/co/codeowners/package.nix b/pkgs/by-name/co/codeowners/package.nix index 3c7bdb1ff222a8..067870f13b797d 100644 --- a/pkgs/by-name/co/codeowners/package.nix +++ b/pkgs/by-name/co/codeowners/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, lib, fetchFromGitHub }: +{ + buildGoModule, + lib, + fetchFromGitHub, +}: buildGoModule rec { pname = "codeowners"; diff --git a/pkgs/by-name/co/codeql/package.nix b/pkgs/by-name/co/codeql/package.nix index 4d64ba892f529f..9c3eb34894f3fe 100644 --- a/pkgs/by-name/co/codeql/package.nix +++ b/pkgs/by-name/co/codeql/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchzip, zlib, xorg, freetype, jdk17, curl }: +{ + lib, + stdenv, + fetchzip, + zlib, + xorg, + freetype, + jdk17, + curl, +}: stdenv.mkDerivation rec { pname = "codeql"; diff --git a/pkgs/by-name/co/codesearch/package.nix b/pkgs/by-name/co/codesearch/package.nix index 7a948388e09ca7..fb93208c1020c6 100644 --- a/pkgs/by-name/co/codesearch/package.nix +++ b/pkgs/by-name/co/codesearch/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "codesearch"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Fast, indexed regexp search over large file trees"; diff --git a/pkgs/by-name/co/codespell/package.nix b/pkgs/by-name/co/codespell/package.nix index da39f0f7599217..d46e981168554b 100644 --- a/pkgs/by-name/co/codespell/package.nix +++ b/pkgs/by-name/co/codespell/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, aspellDicts -, python3 +{ + lib, + fetchFromGitHub, + aspellDicts, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -43,7 +44,13 @@ python3.pkgs.buildPythonApplication rec { description = "Fix common misspellings in source code"; mainProgram = "codespell"; homepage = "https://github.com/codespell-project/codespell"; - license = with licenses; [ gpl2Only cc-by-sa-30 ]; - maintainers = with maintainers; [ johnazoidberg SuperSandro2000 ]; + license = with licenses; [ + gpl2Only + cc-by-sa-30 + ]; + maintainers = with maintainers; [ + johnazoidberg + SuperSandro2000 + ]; }; } diff --git a/pkgs/by-name/co/codespelunker/package.nix b/pkgs/by-name/co/codespelunker/package.nix index 185fcf1e60e319..a0c6ea79870305 100644 --- a/pkgs/by-name/co/codespelunker/package.nix +++ b/pkgs/by-name/co/codespelunker/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "codespelunker"; @@ -18,7 +22,10 @@ buildGoModule rec { meta = with lib; { description = "Command code search tool"; homepage = "https://github.com/boyter/cs"; - license = with licenses; [ mit unlicense ]; + license = with licenses; [ + mit + unlicense + ]; maintainers = with maintainers; [ viraptor ]; mainProgram = "cs"; }; diff --git a/pkgs/by-name/co/codevis/package.nix b/pkgs/by-name/co/codevis/package.nix index 3ef5e899b4ac19..10f390228c6ba0 100644 --- a/pkgs/by-name/co/codevis/package.nix +++ b/pkgs/by-name/co/codevis/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, oniguruma +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + oniguruma, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/co/codux/package.nix b/pkgs/by-name/co/codux/package.nix index 940a097a37e8b5..f932c66161de83 100644 --- a/pkgs/by-name/co/codux/package.nix +++ b/pkgs/by-name/co/codux/package.nix @@ -1,6 +1,7 @@ -{ lib -, appimageTools -, fetchurl +{ + lib, + appimageTools, + fetchurl, }: let @@ -29,7 +30,10 @@ appimageTools.wrapType2 rec { homepage = "https://www.codux.com"; license = licenses.unfree; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ dit7ya kashw2 ]; + maintainers = with maintainers; [ + dit7ya + kashw2 + ]; mainProgram = "codux"; }; } diff --git a/pkgs/by-name/co/coffeegrindsize/package.nix b/pkgs/by-name/co/coffeegrindsize/package.nix index ea23de82bbce2d..5df497e4bd1eae 100644 --- a/pkgs/by-name/co/coffeegrindsize/package.nix +++ b/pkgs/by-name/co/coffeegrindsize/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchFromGitHub }: +{ + lib, + python3, + fetchFromGitHub, +}: python3.pkgs.buildPythonApplication { pname = "coffeegrindsize"; diff --git a/pkgs/by-name/co/coffeescript/package.nix b/pkgs/by-name/co/coffeescript/package.nix index a5ef29967e075c..0153c233d76acb 100644 --- a/pkgs/by-name/co/coffeescript/package.nix +++ b/pkgs/by-name/co/coffeescript/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/co/cog/package.nix b/pkgs/by-name/co/cog/package.nix index 35194301772b27..1dcef0357088ff 100644 --- a/pkgs/by-name/co/cog/package.nix +++ b/pkgs/by-name/co/cog/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, wayland -, wayland-protocols -, libwpe -, libwpe-fdo -, glib-networking -, webkitgtk_4_0 -, makeWrapper -, wrapGAppsHook3 -, adwaita-icon-theme -, gdk-pixbuf +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + wayland, + wayland-protocols, + libwpe, + libwpe-fdo, + glib-networking, + webkitgtk_4_0, + makeWrapper, + wrapGAppsHook3, + adwaita-icon-theme, + gdk-pixbuf, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/co/coin-utils/package.nix b/pkgs/by-name/co/coin-utils/package.nix index 60b9de0ab33a70..45681a7213570a 100644 --- a/pkgs/by-name/co/coin-utils/package.nix +++ b/pkgs/by-name/co/coin-utils/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { version = "2.11.10"; diff --git a/pkgs/by-name/co/coin3d/package.nix b/pkgs/by-name/co/coin3d/package.nix index a0d1ae07d636f7..7b23954b762f4c 100644 --- a/pkgs/by-name/co/coin3d/package.nix +++ b/pkgs/by-name/co/coin3d/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, boost -, cmake -, libGL -, libGLU -, libX11 +{ + lib, + stdenv, + fetchFromGitHub, + boost, + cmake, + libGL, + libGLU, + libX11, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/co/coinmp/package.nix b/pkgs/by-name/co/coinmp/package.nix index 5aff27ceb93d42..632fd2da873b44 100644 --- a/pkgs/by-name/co/coinmp/package.nix +++ b/pkgs/by-name/co/coinmp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, +}: stdenv.mkDerivation (finalAttrs: { pname = "coinmp"; diff --git a/pkgs/by-name/co/cointop/package.nix b/pkgs/by-name/co/cointop/package.nix index 99841742786e13..14f2c8a17c60a9 100644 --- a/pkgs/by-name/co/cointop/package.nix +++ b/pkgs/by-name/co/cointop/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "cointop"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Fastest and most interactive terminal based UI application for tracking cryptocurrencies"; diff --git a/pkgs/by-name/co/colemak-dh/package.nix b/pkgs/by-name/co/colemak-dh/package.nix index 6acf1488d79b7d..76113c08a4c90f 100644 --- a/pkgs/by-name/co/colemak-dh/package.nix +++ b/pkgs/by-name/co/colemak-dh/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/co/collapseos-cvm/package.nix b/pkgs/by-name/co/collapseos-cvm/package.nix index 798d58467af6e5..3d5a89de174427 100644 --- a/pkgs/by-name/co/collapseos-cvm/package.nix +++ b/pkgs/by-name/co/collapseos-cvm/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "collapseos-cvm"; diff --git a/pkgs/by-name/co/colloid-gtk-theme/package.nix b/pkgs/by-name/co/colloid-gtk-theme/package.nix index 449caed8ec3fa8..de4cdee70ffe06 100644 --- a/pkgs/by-name/co/colloid-gtk-theme/package.nix +++ b/pkgs/by-name/co/colloid-gtk-theme/package.nix @@ -1,73 +1,108 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gnome-themes-extra -, gtk-engine-murrine -, jdupes -, sassc -, themeVariants ? [] # default: blue -, colorVariants ? [] # default: all -, sizeVariants ? [] # default: standard -, tweaks ? [] +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gnome-themes-extra, + gtk-engine-murrine, + jdupes, + sassc, + themeVariants ? [ ], # default: blue + colorVariants ? [ ], # default: all + sizeVariants ? [ ], # default: standard + tweaks ? [ ], }: let pname = "colloid-gtk-theme"; in -lib.checkListOfEnum "${pname}: theme variants" [ "default" "purple" "pink" "red" "orange" "yellow" "green" "teal" "grey" "all" ] themeVariants -lib.checkListOfEnum "${pname}: color variants" [ "standard" "light" "dark" ] colorVariants -lib.checkListOfEnum "${pname}: size variants" [ "standard" "compact" ] sizeVariants -lib.checkListOfEnum "${pname}: tweaks" [ "nord" "dracula" "gruvbox" "everforest" "catppuccin" "all" "black" "rimless" "normal" "float" ] tweaks +lib.checkListOfEnum "${pname}: theme variants" + [ + "default" + "purple" + "pink" + "red" + "orange" + "yellow" + "green" + "teal" + "grey" + "all" + ] + themeVariants + lib.checkListOfEnum + "${pname}: color variants" + [ "standard" "light" "dark" ] + colorVariants + lib.checkListOfEnum + "${pname}: size variants" + [ "standard" "compact" ] + sizeVariants + lib.checkListOfEnum + "${pname}: tweaks" + [ + "nord" + "dracula" + "gruvbox" + "everforest" + "catppuccin" + "all" + "black" + "rimless" + "normal" + "float" + ] + tweaks -stdenvNoCC.mkDerivation rec { - inherit pname; - version = "2024-11-16"; + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "2024-11-16"; - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = version; - hash = "sha256-70HDn87acG0me+zbXk6AoGmakY6VLuawq1ubgGcRZVk="; - }; + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = version; + hash = "sha256-70HDn87acG0me+zbXk6AoGmakY6VLuawq1ubgGcRZVk="; + }; - nativeBuildInputs = [ - jdupes - sassc - ]; + nativeBuildInputs = [ + jdupes + sassc + ]; - buildInputs = [ - gnome-themes-extra - ]; + buildInputs = [ + gnome-themes-extra + ]; - propagatedUserEnvPkgs = [ - gtk-engine-murrine - ]; + propagatedUserEnvPkgs = [ + gtk-engine-murrine + ]; - postPatch = '' - patchShebangs install.sh - ''; + postPatch = '' + patchShebangs install.sh + ''; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - name= HOME="$TMPDIR" ./install.sh \ - ${lib.optionalString (themeVariants != []) "--theme " + builtins.toString themeVariants} \ - ${lib.optionalString (colorVariants != []) "--color " + builtins.toString colorVariants} \ - ${lib.optionalString (sizeVariants != []) "--size " + builtins.toString sizeVariants} \ - ${lib.optionalString (tweaks != []) "--tweaks " + builtins.toString tweaks} \ - --dest $out/share/themes + name= HOME="$TMPDIR" ./install.sh \ + ${lib.optionalString (themeVariants != [ ]) "--theme " + builtins.toString themeVariants} \ + ${lib.optionalString (colorVariants != [ ]) "--color " + builtins.toString colorVariants} \ + ${lib.optionalString (sizeVariants != [ ]) "--size " + builtins.toString sizeVariants} \ + ${lib.optionalString (tweaks != [ ]) "--tweaks " + builtins.toString tweaks} \ + --dest $out/share/themes - jdupes --quiet --link-soft --recurse $out/share + jdupes --quiet --link-soft --recurse $out/share - runHook postInstall - ''; + runHook postInstall + ''; - meta = with lib; { - description = "Modern and clean Gtk theme"; - homepage = "https://github.com/vinceliuice/Colloid-gtk-theme"; - license = licenses.gpl3Only; - platforms = platforms.unix; - maintainers = [ maintainers.romildo ]; - }; -} + meta = with lib; { + description = "Modern and clean Gtk theme"; + homepage = "https://github.com/vinceliuice/Colloid-gtk-theme"; + license = licenses.gpl3Only; + platforms = platforms.unix; + maintainers = [ maintainers.romildo ]; + }; + } diff --git a/pkgs/by-name/co/colloid-icon-theme/package.nix b/pkgs/by-name/co/colloid-icon-theme/package.nix index 25ffaf87b4931a..3b2ea4b9987ad4 100644 --- a/pkgs/by-name/co/colloid-icon-theme/package.nix +++ b/pkgs/by-name/co/colloid-icon-theme/package.nix @@ -1,72 +1,98 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gitUpdater -, gtk3 -, hicolor-icon-theme -, jdupes -, schemeVariants ? [] -, colorVariants ? [] # default is blue +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gitUpdater, + gtk3, + hicolor-icon-theme, + jdupes, + schemeVariants ? [ ], + colorVariants ? [ ], # default is blue }: let pname = "colloid-icon-theme"; in -lib.checkListOfEnum "${pname}: scheme variants" [ "default" "nord" "dracula" "gruvbox" "everforest" "catppuccin" "all" ] schemeVariants -lib.checkListOfEnum "${pname}: color variants" [ "default" "purple" "pink" "red" "orange" "yellow" "green" "teal" "grey" "all" ] colorVariants +lib.checkListOfEnum "${pname}: scheme variants" + [ + "default" + "nord" + "dracula" + "gruvbox" + "everforest" + "catppuccin" + "all" + ] + schemeVariants + lib.checkListOfEnum + "${pname}: color variants" + [ + "default" + "purple" + "pink" + "red" + "orange" + "yellow" + "green" + "teal" + "grey" + "all" + ] + colorVariants -stdenvNoCC.mkDerivation rec { - inherit pname; - version = "2024-10-18"; + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "2024-10-18"; - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = version; - hash = "sha256-xpRgOt/FqZSbtOlZKlZS1ILQn6OAwqKAXX3hj41Wo+0="; - }; + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = version; + hash = "sha256-xpRgOt/FqZSbtOlZKlZS1ILQn6OAwqKAXX3hj41Wo+0="; + }; - nativeBuildInputs = [ - gtk3 - jdupes - ]; + nativeBuildInputs = [ + gtk3 + jdupes + ]; - propagatedBuildInputs = [ - hicolor-icon-theme - ]; + propagatedBuildInputs = [ + hicolor-icon-theme + ]; - dontDropIconThemeCache = true; + dontDropIconThemeCache = true; - # These fixup steps are slow and unnecessary for this package. - # Package may install almost 400 000 small files. - dontPatchELF = true; - dontRewriteSymlinks = true; + # These fixup steps are slow and unnecessary for this package. + # Package may install almost 400 000 small files. + dontPatchELF = true; + dontRewriteSymlinks = true; - postPatch = '' - patchShebangs install.sh - ''; + postPatch = '' + patchShebangs install.sh + ''; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - name= ./install.sh \ - ${lib.optionalString (schemeVariants != []) ("--scheme " + builtins.toString schemeVariants)} \ - ${lib.optionalString (colorVariants != []) ("--theme " + builtins.toString colorVariants)} \ - --dest $out/share/icons + name= ./install.sh \ + ${lib.optionalString (schemeVariants != [ ]) ("--scheme " + builtins.toString schemeVariants)} \ + ${lib.optionalString (colorVariants != [ ]) ("--theme " + builtins.toString colorVariants)} \ + --dest $out/share/icons - jdupes --quiet --link-soft --recurse $out/share + jdupes --quiet --link-soft --recurse $out/share - runHook postInstall - ''; + runHook postInstall + ''; - passthru.updateScript = gitUpdater { }; + passthru.updateScript = gitUpdater { }; - meta = with lib; { - description = "Colloid icon theme"; - homepage = "https://github.com/vinceliuice/colloid-icon-theme"; - license = licenses.gpl3Only; - platforms = platforms.unix; - maintainers = with maintainers; [ romildo ]; - }; -} + meta = with lib; { + description = "Colloid icon theme"; + homepage = "https://github.com/vinceliuice/colloid-icon-theme"; + license = licenses.gpl3Only; + platforms = platforms.unix; + maintainers = with maintainers; [ romildo ]; + }; + } diff --git a/pkgs/by-name/co/colm/package.nix b/pkgs/by-name/co/colm/package.nix index 7db574022bfa2e..19d8744aa1e2c9 100644 --- a/pkgs/by-name/co/colm/package.nix +++ b/pkgs/by-name/co/colm/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeWrapper, gcc, asciidoc, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + gcc, + asciidoc, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "colm"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { patches = [ ./cross-compile.patch ]; - nativeBuildInputs = [ makeWrapper asciidoc autoreconfHook ]; + nativeBuildInputs = [ + makeWrapper + asciidoc + autoreconfHook + ]; env = lib.optionalAttrs stdenv.cc.isGNU { NIX_CFLAGS_COMPILE = "-Wno-error=int-conversion"; diff --git a/pkgs/by-name/co/colmena/package.nix b/pkgs/by-name/co/colmena/package.nix index bffb3f2564653c..9f6fd8f4425d51 100644 --- a/pkgs/by-name/co/colmena/package.nix +++ b/pkgs/by-name/co/colmena/package.nix @@ -1,5 +1,16 @@ -{ stdenv, lib, fetchpatch, rustPlatform, fetchFromGitHub, installShellFiles, makeBinaryWrapper, nix-eval-jobs, nix -, colmena, testers }: +{ + stdenv, + lib, + fetchpatch, + rustPlatform, + fetchFromGitHub, + installShellFiles, + makeBinaryWrapper, + nix-eval-jobs, + nix, + colmena, + testers, +}: rustPlatform.buildRustPackage rec { pname = "colmena"; @@ -14,7 +25,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-rk2atWWJIR95duUXxAiARegjeCyfAsqTDwEr5P0eIr8="; - nativeBuildInputs = [ installShellFiles makeBinaryWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeBinaryWrapper + ]; buildInputs = [ nix-eval-jobs ]; diff --git a/pkgs/by-name/co/colobot/data.nix b/pkgs/by-name/co/colobot/data.nix index 761c68c15e816b..d2fcedee561dd7 100644 --- a/pkgs/by-name/co/colobot/data.nix +++ b/pkgs/by-name/co/colobot/data.nix @@ -1,6 +1,14 @@ -{ stdenv, lib, fetchFromGitHub, cmake -, gettext, vorbis-tools -, xmlstarlet, doxygen, python3 }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + gettext, + vorbis-tools, + xmlstarlet, + doxygen, + python3, +}: stdenv.mkDerivation rec { pname = "colobot-data"; @@ -13,7 +21,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-yzIbAzrGsDe6hO0GHF9gjnj7IE8B7+5LDbvjZi4Wtms="; }; - nativeBuildInputs = [ cmake vorbis-tools xmlstarlet doxygen python3 ]; + nativeBuildInputs = [ + cmake + vorbis-tools + xmlstarlet + doxygen + python3 + ]; buildInputs = [ gettext ]; enableParallelBuilding = false; diff --git a/pkgs/by-name/co/colobot/package.nix b/pkgs/by-name/co/colobot/package.nix index 58edbea1881b83..8ddbbe00998cf6 100644 --- a/pkgs/by-name/co/colobot/package.nix +++ b/pkgs/by-name/co/colobot/package.nix @@ -1,9 +1,28 @@ -{ lib, stdenv, fetchFromGitHub, cmake, boost, SDL2, SDL2_image, SDL2_ttf, libpng -, glew, gettext, libsndfile, libvorbis, libogg, physfs, openal -, xmlstarlet, doxygen, python3, callPackage }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + SDL2, + SDL2_image, + SDL2_ttf, + libpng, + glew, + gettext, + libsndfile, + libvorbis, + libogg, + physfs, + openal, + xmlstarlet, + doxygen, + python3, + callPackage, +}: let - colobot-data = callPackage ./data.nix {}; + colobot-data = callPackage ./data.nix { }; in stdenv.mkDerivation rec { pname = "colobot"; @@ -18,8 +37,26 @@ stdenv.mkDerivation rec { hash = "sha256-3iea2+5xCT0//NAjMHrynZKSoiOSgLTNMUQkRhXuXg8="; }; - nativeBuildInputs = [ cmake xmlstarlet doxygen python3 ]; - buildInputs = [ boost SDL2 SDL2_image SDL2_ttf libpng glew gettext libsndfile libvorbis libogg physfs openal ]; + nativeBuildInputs = [ + cmake + xmlstarlet + doxygen + python3 + ]; + buildInputs = [ + boost + SDL2 + SDL2_image + SDL2_ttf + libpng + glew + gettext + libsndfile + libvorbis + libogg + physfs + openal + ]; enableParallelBuilding = false; diff --git a/pkgs/by-name/co/coloquinte/package.nix b/pkgs/by-name/co/coloquinte/package.nix index 6946080c100e92..8a326beca66b53 100644 --- a/pkgs/by-name/co/coloquinte/package.nix +++ b/pkgs/by-name/co/coloquinte/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, lemon-graph -, eigen -, boost +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + lemon-graph, + eigen, + boost, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/co/colord-gtk/package.nix b/pkgs/by-name/co/colord-gtk/package.nix index 6f7e41964247c7..46d7e1cfb3e223 100644 --- a/pkgs/by-name/co/colord-gtk/package.nix +++ b/pkgs/by-name/co/colord-gtk/package.nix @@ -1,29 +1,34 @@ -{ lib -, stdenv -, fetchurl -, colord -, gettext -, meson -, ninja -, gobject-introspection -, gtk-doc -, docbook-xsl-ns -, docbook-xsl-nons -, docbook_xml_dtd_412 -, libxslt -, glib -, withGtk4 ? false -, gtk3 -, gtk4 -, pkg-config -, lcms2 +{ + lib, + stdenv, + fetchurl, + colord, + gettext, + meson, + ninja, + gobject-introspection, + gtk-doc, + docbook-xsl-ns, + docbook-xsl-nons, + docbook_xml_dtd_412, + libxslt, + glib, + withGtk4 ? false, + gtk3, + gtk4, + pkg-config, + lcms2, }: stdenv.mkDerivation rec { pname = "colord-gtk"; version = "0.3.1"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "https://www.freedesktop.org/software/colord/releases/colord-gtk-${version}.tar.xz"; @@ -48,13 +53,20 @@ stdenv.mkDerivation rec { lcms2 ]; - propagatedBuildInputs = [ - colord - ] ++ (if withGtk4 then [ - gtk4 - ] else [ - gtk3 - ]); + propagatedBuildInputs = + [ + colord + ] + ++ ( + if withGtk4 then + [ + gtk4 + ] + else + [ + gtk3 + ] + ); mesonFlags = [ "-Dgtk4=${lib.boolToString withGtk4}" diff --git a/pkgs/by-name/co/colord/package.nix b/pkgs/by-name/co/colord/package.nix index da893702d9d53b..963b8567fa0baa 100644 --- a/pkgs/by-name/co/colord/package.nix +++ b/pkgs/by-name/co/colord/package.nix @@ -1,42 +1,49 @@ -{ lib -, stdenv -, fetchurl -, nixosTests -, bash-completion -, glib -, polkit -, pkg-config -, gettext -, gusb -, lcms2 -, sqlite -, udev -, systemd -, enableSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, dbus -, gobject-introspection -, argyllcms -, meson -, mesonEmulatorHook -, ninja -, vala -, libgudev -, wrapGAppsNoGuiHook -, shared-mime-info -, sane-backends -, docbook_xsl -, docbook_xsl_ns -, docbook_xml_dtd_412 -, gtk-doc -, libxslt -, enableDaemon ? true +{ + lib, + stdenv, + fetchurl, + nixosTests, + bash-completion, + glib, + polkit, + pkg-config, + gettext, + gusb, + lcms2, + sqlite, + udev, + systemd, + enableSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + dbus, + gobject-introspection, + argyllcms, + meson, + mesonEmulatorHook, + ninja, + vala, + libgudev, + wrapGAppsNoGuiHook, + shared-mime-info, + sane-backends, + docbook_xsl, + docbook_xsl_ns, + docbook_xml_dtd_412, + gtk-doc, + libxslt, + enableDaemon ? true, }: stdenv.mkDerivation rec { pname = "colord"; version = "1.4.6"; - outputs = [ "out" "dev" "devdoc" "man" "installedTests" ]; + outputs = [ + "out" + "dev" + "devdoc" + "man" + "installedTests" + ]; src = fetchurl { url = "https://www.freedesktop.org/software/colord/releases/colord-${version}.tar.xz"; @@ -69,40 +76,45 @@ stdenv.mkDerivation rec { (lib.mesonBool "udev_rules" (lib.elem "udev" udev.meta.pkgConfigModules)) ]; - nativeBuildInputs = [ - docbook_xml_dtd_412 - docbook_xsl - docbook_xsl_ns - gettext - gobject-introspection - gtk-doc - libxslt - meson - ninja - pkg-config - shared-mime-info - vala - wrapGAppsNoGuiHook - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + docbook_xml_dtd_412 + docbook_xsl + docbook_xsl_ns + gettext + gobject-introspection + gtk-doc + libxslt + meson + ninja + pkg-config + shared-mime-info + vala + wrapGAppsNoGuiHook + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; - buildInputs = [ - argyllcms - bash-completion - dbus - glib - gusb - lcms2 - libgudev - sane-backends - sqlite - udev - ] ++ lib.optionals enableSystemd [ - systemd - ] ++ lib.optionals enableDaemon [ - polkit - ]; + buildInputs = + [ + argyllcms + bash-completion + dbus + glib + gusb + lcms2 + libgudev + sane-backends + sqlite + udev + ] + ++ lib.optionals enableSystemd [ + systemd + ] + ++ lib.optionals enableDaemon [ + polkit + ]; postInstall = '' glib-compile-schemas $out/share/glib-2.0/schemas diff --git a/pkgs/by-name/co/colordiff/package.nix b/pkgs/by-name/co/colordiff/package.nix index 69473bd2c6f6f1..11b906b06f3b2e 100644 --- a/pkgs/by-name/co/colordiff/package.nix +++ b/pkgs/by-name/co/colordiff/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, docbook_xml_dtd_412, docbook_xsl, perl, w3m-batch, xmlto, diffutils }: +{ + lib, + stdenv, + fetchFromGitHub, + docbook_xml_dtd_412, + docbook_xsl, + perl, + w3m-batch, + xmlto, + diffutils, +}: stdenv.mkDerivation rec { pname = "colordiff"; @@ -11,7 +21,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-TNOw6dqsT0dOIddRoGwEF85CaQF8ICMFUi+GiG5WWpk="; }; - nativeBuildInputs = [ docbook_xml_dtd_412 docbook_xsl perl w3m-batch xmlto ]; + nativeBuildInputs = [ + docbook_xml_dtd_412 + docbook_xsl + perl + w3m-batch + xmlto + ]; buildInputs = [ perl ]; diff --git a/pkgs/by-name/co/colorgrind/package.nix b/pkgs/by-name/co/colorgrind/package.nix index 1f89ad865583ae..70b9ce0d16e442 100644 --- a/pkgs/by-name/co/colorgrind/package.nix +++ b/pkgs/by-name/co/colorgrind/package.nix @@ -2,7 +2,7 @@ lib, stdenvNoCC, fetchFromGitHub, - perl + perl, }: stdenvNoCC.mkDerivation { pname = "colorgrind"; diff --git a/pkgs/by-name/co/colorized-logs/package.nix b/pkgs/by-name/co/colorized-logs/package.nix index 9913d0d765babc..15aef5d3ea8b05 100644 --- a/pkgs/by-name/co/colorized-logs/package.nix +++ b/pkgs/by-name/co/colorized-logs/package.nix @@ -1,7 +1,8 @@ -{ cmake -, fetchFromGitHub -, lib -, stdenv +{ + cmake, + fetchFromGitHub, + lib, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/co/colorless/package.nix b/pkgs/by-name/co/colorless/package.nix index 024b70343e2aac..9e5c69360430b2 100644 --- a/pkgs/by-name/co/colorless/package.nix +++ b/pkgs/by-name/co/colorless/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchurl -, stdenvNoCC -, coreutils -, bash -, binSh ? "${bash}/bin/bash" -, gnused -, less +{ + lib, + fetchurl, + stdenvNoCC, + coreutils, + bash, + binSh ? "${bash}/bin/bash", + gnused, + less, }: stdenvNoCC.mkDerivation rec { @@ -18,7 +19,13 @@ stdenvNoCC.mkDerivation rec { }; makeFlags = [ - "TOOLPATH=${lib.makeBinPath [ coreutils gnused less ]}" + "TOOLPATH=${ + lib.makeBinPath [ + coreutils + gnused + less + ] + }" "PREFIX=$(out)" "SHELL=${binSh}" ]; diff --git a/pkgs/by-name/co/colormake/package.nix b/pkgs/by-name/co/colormake/package.nix index 251268a449d41c..6d897f5de8fcd1 100644 --- a/pkgs/by-name/co/colormake/package.nix +++ b/pkgs/by-name/co/colormake/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation { pname = "colormake"; diff --git a/pkgs/by-name/co/colorpanes/package.nix b/pkgs/by-name/co/colorpanes/package.nix index 72209cf217a910..534b153aa95e5f 100644 --- a/pkgs/by-name/co/colorpanes/package.nix +++ b/pkgs/by-name/co/colorpanes/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitea }: +{ + lib, + rustPlatform, + fetchFromGitea, +}: rustPlatform.buildRustPackage rec { pname = "colorpanes"; diff --git a/pkgs/by-name/co/colorstorm/package.nix b/pkgs/by-name/co/colorstorm/package.nix index da612b33c2baf3..0f997fa2cc8a19 100644 --- a/pkgs/by-name/co/colorstorm/package.nix +++ b/pkgs/by-name/co/colorstorm/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, zig_0_9 +{ + lib, + stdenv, + fetchFromGitHub, + zig_0_9, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/co/colort/package.nix b/pkgs/by-name/co/colort/package.nix index e7f3429fe8d7cc..1ba0343d555db4 100644 --- a/pkgs/by-name/co/colort/package.nix +++ b/pkgs/by-name/co/colort/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "colort"; diff --git a/pkgs/by-name/co/colorz/package.nix b/pkgs/by-name/co/colorz/package.nix index f60843afcfb05a..1c5b54014823e3 100644 --- a/pkgs/by-name/co/colorz/package.nix +++ b/pkgs/by-name/co/colorz/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "colorz"; @@ -9,7 +13,10 @@ python3Packages.buildPythonApplication rec { sha256 = "0ghd90lgplf051fs5n5bb42zffd3fqpgzkbv6bhjw7r8jqwgcky0"; }; - propagatedBuildInputs = with python3Packages; [ pillow scipy ]; + propagatedBuildInputs = with python3Packages; [ + pillow + scipy + ]; checkPhase = '' $out/bin/colorz --help > /dev/null diff --git a/pkgs/by-name/co/colpack/package.nix b/pkgs/by-name/co/colpack/package.nix index 591ac3281e5e8c..32914f925a73bd 100644 --- a/pkgs/by-name/co/colpack/package.nix +++ b/pkgs/by-name/co/colpack/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/co/colstr/package.nix b/pkgs/by-name/co/colstr/package.nix index a1ea23668277a6..8e0185c10281dd 100644 --- a/pkgs/by-name/co/colstr/package.nix +++ b/pkgs/by-name/co/colstr/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitea -, nix-update-script +{ + lib, + stdenv, + fetchFromGitea, + nix-update-script, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/co/coltrane/gemset.nix b/pkgs/by-name/co/coltrane/gemset.nix index 3463fc8d66d913..fbdf8a1aadb128 100644 --- a/pkgs/by-name/co/coltrane/gemset.nix +++ b/pkgs/by-name/co/coltrane/gemset.nix @@ -1,156 +1,177 @@ { activesupport = { - dependencies = ["concurrent-ruby" "i18n" "minitest" "tzinfo"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "concurrent-ruby" + "i18n" + "minitest" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dmywys50074vj5rivpx188b00qimlc4jn84xzqlialrgp3ckq5f"; type = "gem"; }; version = "7.0.4.2"; }; cli-ui = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1aghiy4qrh6y6q421lcpal81c98zypj8jki4wymqnc8vjvqsyiv4"; type = "gem"; }; version = "1.5.1"; }; color = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10kgsdy86p72q6cf2k92larmbjc0crvd5xq7hy919zm8yvn1518a"; type = "gem"; }; version = "1.8"; }; coltrane = { - dependencies = ["activesupport" "color" "dry-monads" "gambiarra" "paint"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "activesupport" + "color" + "dry-monads" + "gambiarra" + "paint" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hchdllbbx2n2fl3ydidl17rsl18mb9953c8k1r6rw1ibzw8sm7f"; type = "gem"; }; version = "4.1.1"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0krcwb6mn0iklajwngwsg850nk8k9b35dhmc2qkbdqvmifdi2y9q"; type = "gem"; }; version = "1.2.2"; }; dry-core = { - dependencies = ["concurrent-ruby" "zeitwerk"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "concurrent-ruby" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dpm9dk11x2zcjsymkl5jcz5nxhffsg7qqy5p6h92cppzbwmm656"; type = "gem"; }; version = "0.9.1"; }; dry-equalizer = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rsqpk0gjja6j6pjm0whx2px06cxr3h197vrwxp6k042p52r4v46"; type = "gem"; }; version = "0.3.0"; }; dry-monads = { - dependencies = ["dry-core" "dry-equalizer"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "dry-core" + "dry-equalizer" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fbji6crgqh88j0p4j1qlfpjnhyf8h1b991dh5wypib0xwzlc5an"; type = "gem"; }; version = "0.4.0"; }; gambiarra = { - dependencies = ["activesupport" "cli-ui" "thor"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "activesupport" + "cli-ui" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19kpbqp27fy6w990ciw3vx0z0bdmrcf14fr6dlfcn3r8xqpq56fr"; type = "gem"; }; version = "0.0.5"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vdcchz7jli1p0gnc669a7bj3q1fv09y9ppf0y3k0vb1jwdwrqwi"; type = "gem"; }; version = "1.12.0"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ic7i5z88zcaqnpzprf7saimq2f6sad57g5mkkqsrqrcd6h3mx06"; type = "gem"; }; version = "5.18.0"; }; paint = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1r9vx3wcx0x2xqlh6zqc81wcsn9qjw3xprcsv5drsq9q80z64z9j"; type = "gem"; }; version = "2.3.0"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18yhlvmfya23cs3pvhr1qy38y41b6mhr5q9vwv5lrgk16wmf3jna"; type = "gem"; }; version = "1.1.0"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; zeitwerk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "028ld9qmgdllxrl7d0qkl65s58wb1n3gv8yjs28g43a8b1hplxk1"; type = "gem"; }; diff --git a/pkgs/by-name/co/coltrane/package.nix b/pkgs/by-name/co/coltrane/package.nix index f4c1ccb41e9abe..5faba57d645345 100644 --- a/pkgs/by-name/co/coltrane/package.nix +++ b/pkgs/by-name/co/coltrane/package.nix @@ -1,6 +1,7 @@ -{ lib -, bundlerApp -, bundlerUpdateScript +{ + lib, + bundlerApp, + bundlerUpdateScript, }: bundlerApp rec { diff --git a/pkgs/by-name/co/combinatorial_designs/package.nix b/pkgs/by-name/co/combinatorial_designs/package.nix index 5457b4e54d4bf4..f3dc999ca4346f 100644 --- a/pkgs/by-name/co/combinatorial_designs/package.nix +++ b/pkgs/by-name/co/combinatorial_designs/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/co/comedilib/package.nix b/pkgs/by-name/co/comedilib/package.nix index 95de887242bf55..42d9ca0a5de230 100644 --- a/pkgs/by-name/co/comedilib/package.nix +++ b/pkgs/by-name/co/comedilib/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, flex -, bison -, xmlto -, docbook_xsl -, docbook_xml_dtd_44 -, swig -, perl -, python3 +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + flex, + bison, + xmlto, + docbook_xsl, + docbook_xml_dtd_44, + swig, + perl, + python3, }: stdenv.mkDerivation (finalAttrs: { @@ -44,7 +45,12 @@ stdenv.mkDerivation (finalAttrs: { "--sysconfdir=${placeholder "out"}/etc" ]; - outputs = [ "out" "dev" "man" "doc" ]; + outputs = [ + "out" + "dev" + "man" + "doc" + ]; meta = with lib; { description = "Linux Control and Measurement Device Interface Library"; diff --git a/pkgs/by-name/co/comfortaa/package.nix b/pkgs/by-name/co/comfortaa/package.nix index defdd9b86bba1c..f2b8a884609ed9 100644 --- a/pkgs/by-name/co/comfortaa/package.nix +++ b/pkgs/by-name/co/comfortaa/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "comfortaa"; diff --git a/pkgs/by-name/co/comic-mandown/package.nix b/pkgs/by-name/co/comic-mandown/package.nix index 90f2ef21550030..04fc1bbab70f61 100644 --- a/pkgs/by-name/co/comic-mandown/package.nix +++ b/pkgs/by-name/co/comic-mandown/package.nix @@ -1,15 +1,19 @@ -{ lib -, python3Packages +{ + lib, + python3Packages, -, withGUI ? true + withGUI ? true, }: let mandown' = python3Packages.mandown.overridePythonAttrs (prev: { - propagatedBuildInputs = prev.propagatedBuildInputs ++ lib.optionals withGUI prev.optional-dependencies.gui; + propagatedBuildInputs = + prev.propagatedBuildInputs + ++ lib.optionals withGUI prev.optional-dependencies.gui; }); mandownApp = python3Packages.toPythonApplication mandown'; in -mandownApp // { +mandownApp +// { meta = mandownApp.meta // { mainProgram = "mandown"; }; diff --git a/pkgs/by-name/co/comic-mono/package.nix b/pkgs/by-name/co/comic-mono/package.nix index b635c1379489d7..d843337d1dc73d 100644 --- a/pkgs/by-name/co/comic-mono/package.nix +++ b/pkgs/by-name/co/comic-mono/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "comic-mono-font"; @@ -33,7 +37,10 @@ stdenvNoCC.mkDerivation { homepage = "https://dtinth.github.io/comic-mono-font/"; license = licenses.mit; - maintainers = with maintainers; [ an-empty-string totoroot ]; + maintainers = with maintainers; [ + an-empty-string + totoroot + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/co/comic-neue/package.nix b/pkgs/by-name/co/comic-neue/package.nix index 66eb4087efaa74..006364609a81ef 100644 --- a/pkgs/by-name/co/comic-neue/package.nix +++ b/pkgs/by-name/co/comic-neue/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { pname = "comic-neue"; diff --git a/pkgs/by-name/co/comic-relief/package.nix b/pkgs/by-name/co/comic-relief/package.nix index fe1c1b5128123c..748fdd17a71682 100644 --- a/pkgs/by-name/co/comic-relief/package.nix +++ b/pkgs/by-name/co/comic-relief/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "comic-relief"; diff --git a/pkgs/by-name/co/comixcursors/package.nix b/pkgs/by-name/co/comixcursors/package.nix index be1fa347535b94..d9a1f64e11909b 100644 --- a/pkgs/by-name/co/comixcursors/package.nix +++ b/pkgs/by-name/co/comixcursors/package.nix @@ -1,14 +1,42 @@ -{ lib, stdenvNoCC, fetchFromGitLab, bc, librsvg, xcursorgen }: +{ + lib, + stdenvNoCC, + fetchFromGitLab, + bc, + librsvg, + xcursorgen, +}: let dimensions = { - color = [ "Black" "Blue" "Green" "Orange" "Red" "White" ]; - opacity = [ "" "Opaque_" ]; # Translucent or opaque. - thickness = [ "" "Slim_" ]; # Thick or slim edges. - handedness = [ "" "LH_" ]; # Right- or left-handed. + color = [ + "Black" + "Blue" + "Green" + "Orange" + "Red" + "White" + ]; + opacity = [ + "" + "Opaque_" + ]; # Translucent or opaque. + thickness = [ + "" + "Slim_" + ]; # Thick or slim edges. + handedness = [ + "" + "LH_" + ]; # Right- or left-handed. }; variantName = - { color, opacity, thickness, handedness }: + { + color, + opacity, + thickness, + handedness, + }: "${handedness}${opacity}${thickness}${color}"; variants = # (The order of this list is already good looking enough to show in the @@ -27,7 +55,11 @@ stdenvNoCC.mkDerivation rec { sha256 = "0bpxqw4izj7m0zb9lnxnmsjicfw60ppkdyv5nwrrz4x865wb296a"; }; - nativeBuildInputs = [ bc librsvg xcursorgen ]; + nativeBuildInputs = [ + bc + librsvg + xcursorgen + ]; patches = [ ./makefile-shell-var.patch ]; @@ -68,19 +100,21 @@ stdenvNoCC.mkDerivation rec { mkdir -p $out ''; - outputs = let - default = "Opaque_Black"; - in + outputs = + let + default = "Opaque_Black"; + in # Have the most-traditional variant be the default output (as the first). # Even with outputsToInstall=[], the default/first still has an effect on # some Nix tools (e.g. nix-build). - [ default ] ++ (lib.remove default variants) + [ default ] + ++ (lib.remove default variants) # Need a dummy "out" output to prevent the builder scripts from breaking. ++ [ "out" ]; # No default output (to the extent possible). Instead, the outputs' # attributes are used to choose which variant(s) to have. - outputsToInstall = []; + outputsToInstall = [ ]; meta = with lib; { description = "Comix Cursors mouse themes"; diff --git a/pkgs/by-name/co/comma/package.nix b/pkgs/by-name/co/comma/package.nix index 2f86a714d506c1..36543e955e4e16 100644 --- a/pkgs/by-name/co/comma/package.nix +++ b/pkgs/by-name/co/comma/package.nix @@ -1,11 +1,12 @@ -{ comma -, fetchFromGitHub -, fzy -, lib -, makeBinaryWrapper -, nix-index-unwrapped -, rustPlatform -, testers +{ + comma, + fetchFromGitHub, + fzy, + lib, + makeBinaryWrapper, + nix-index-unwrapped, + rustPlatform, + testers, }: rustPlatform.buildRustPackage rec { @@ -25,7 +26,12 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram $out/bin/comma \ - --prefix PATH : ${lib.makeBinPath [ fzy nix-index-unwrapped ]} + --prefix PATH : ${ + lib.makeBinPath [ + fzy + nix-index-unwrapped + ] + } ln -s $out/bin/comma $out/bin/, ''; diff --git a/pkgs/by-name/co/commandergenius/package.nix b/pkgs/by-name/co/commandergenius/package.nix index d3549fd211f2ad..6008490dac178e 100644 --- a/pkgs/by-name/co/commandergenius/package.nix +++ b/pkgs/by-name/co/commandergenius/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitLab -, SDL2 -, SDL2_image -, pkg-config -, libvorbis -, libGL -, boost -, cmake -, zlib -, curl -, SDL2_mixer -, SDL2_ttf -, python3 +{ + lib, + stdenv, + fetchFromGitLab, + SDL2, + SDL2_image, + pkg-config, + libvorbis, + libGL, + boost, + cmake, + zlib, + curl, + SDL2_mixer, + SDL2_ttf, + python3, }: stdenv.mkDerivation rec { @@ -26,7 +27,18 @@ stdenv.mkDerivation rec { hash = "sha256-sWnx2UdnuuLcTxhuXhfG2ssnFvuGi9kOBrpc4jiKgTs="; }; - buildInputs = [ SDL2 SDL2_image SDL2_mixer SDL2_ttf libGL boost libvorbis zlib curl python3 ]; + buildInputs = [ + SDL2 + SDL2_image + SDL2_mixer + SDL2_ttf + libGL + boost + libvorbis + zlib + curl + python3 + ]; cmakeFlags = [ "-DCMAKE_INSTALL_PREFIX=${placeholder "out"}" @@ -37,7 +49,10 @@ stdenv.mkDerivation rec { "DESTDIR=${placeholder "out"}" ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; postPatch = '' NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE $(sdl2-config --cflags)" diff --git a/pkgs/by-name/co/commit-formatter/package.nix b/pkgs/by-name/co/commit-formatter/package.nix index 8ed831d886570f..640a952d12626a 100644 --- a/pkgs/by-name/co/commit-formatter/package.nix +++ b/pkgs/by-name/co/commit-formatter/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "commit-formatter"; @@ -16,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "CLI tool to help you write git commit"; homepage = "https://github.com/Eliot00/commit-formatter"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ elliot ]; mainProgram = "git-cf"; }; diff --git a/pkgs/by-name/co/commit-mono/package.nix b/pkgs/by-name/co/commit-mono/package.nix index 0d952d17cbaf3f..574e45163bd02c 100644 --- a/pkgs/by-name/co/commit-mono/package.nix +++ b/pkgs/by-name/co/commit-mono/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchzip +{ + lib, + stdenvNoCC, + fetchzip, }: stdenvNoCC.mkDerivation rec { pname = "commit-mono"; diff --git a/pkgs/by-name/co/commitmsgfmt/package.nix b/pkgs/by-name/co/commitmsgfmt/package.nix index e653fce2671a73..4cb72323ed1c65 100644 --- a/pkgs/by-name/co/commitmsgfmt/package.nix +++ b/pkgs/by-name/co/commitmsgfmt/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitLab -, testers -, commitmsgfmt +{ + lib, + rustPlatform, + fetchFromGitLab, + testers, + commitmsgfmt, }: rustPlatform.buildRustPackage rec { pname = "commitmsgfmt"; diff --git a/pkgs/by-name/co/committed/package.nix b/pkgs/by-name/co/committed/package.nix index 27c2a452f71c7a..1134d60d6f0f0e 100644 --- a/pkgs/by-name/co/committed/package.nix +++ b/pkgs/by-name/co/committed/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, darwin -, testers -, nix-update-script -, committed +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, + testers, + nix-update-script, + committed, }: let version = "1.1.2"; diff --git a/pkgs/by-name/co/commix/package.nix b/pkgs/by-name/co/commix/package.nix index 6197b59172ca15..56bdcc1bceabbc 100644 --- a/pkgs/by-name/co/commix/package.nix +++ b/pkgs/by-name/co/commix/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -20,7 +21,6 @@ python3.pkgs.buildPythonApplication rec { --replace-warn "-stable" "" ''; - nativeBuildInputs = with python3.pkgs; [ setuptools ]; diff --git a/pkgs/by-name/co/common-licenses/package.nix b/pkgs/by-name/co/common-licenses/package.nix index d3888fde615c01..05ea1e51c96e25 100644 --- a/pkgs/by-name/co/common-licenses/package.nix +++ b/pkgs/by-name/co/common-licenses/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, fetchurl -, lib +{ + stdenv, + fetchurl, + lib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/co/commonsBcel/package.nix b/pkgs/by-name/co/commonsBcel/package.nix index f9ffad1028abe9..3be849e9332e5c 100644 --- a/pkgs/by-name/co/commonsBcel/package.nix +++ b/pkgs/by-name/co/commonsBcel/package.nix @@ -1,12 +1,16 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "6.10.0"; pname = "commons-bcel"; src = fetchurl { - url = "mirror://apache/commons/bcel/binaries/bcel-${version}-bin.tar.gz"; - hash = "sha256-RRVXxPtwbT9AX92T60uDJpFWF6DiotcG1KvKrlFfEWU="; + url = "mirror://apache/commons/bcel/binaries/bcel-${version}-bin.tar.gz"; + hash = "sha256-RRVXxPtwbT9AX92T60uDJpFWF6DiotcG1KvKrlFfEWU="; }; installPhase = '' @@ -16,11 +20,11 @@ stdenv.mkDerivation rec { ''; meta = { - homepage = "https://commons.apache.org/proper/commons-bcel/"; + homepage = "https://commons.apache.org/proper/commons-bcel/"; description = "Gives users a convenient way to analyze, create, and manipulate (binary) Java class files"; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; maintainers = with lib.maintainers; [ copumpkin ]; - license = lib.licenses.asl20; + license = lib.licenses.asl20; platforms = with lib.platforms; unix; }; } diff --git a/pkgs/by-name/co/commonsBsf/package.nix b/pkgs/by-name/co/commonsBsf/package.nix index f55029335e588b..1050cca9c6eeb5 100644 --- a/pkgs/by-name/co/commonsBsf/package.nix +++ b/pkgs/by-name/co/commonsBsf/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "commons-bsf"; @@ -22,4 +26,3 @@ stdenv.mkDerivation rec { platforms = lib.platforms.unix; }; } - diff --git a/pkgs/by-name/co/commonsCompress/package.nix b/pkgs/by-name/co/commonsCompress/package.nix index cce498c21f5347..73ca1feda9b842 100644 --- a/pkgs/by-name/co/commonsCompress/package.nix +++ b/pkgs/by-name/co/commonsCompress/package.nix @@ -1,11 +1,15 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "1.27.1"; pname = "commons-compress"; src = fetchurl { - url = "mirror://apache/commons/compress/binaries/${pname}-${version}-bin.tar.gz"; + url = "mirror://apache/commons/compress/binaries/${pname}-${version}-bin.tar.gz"; sha256 = "sha256-psD9VseWxx2ovdUGjEbUCm+fjnQ/D2S70NuyZ2nsXwA="; }; @@ -16,11 +20,11 @@ stdenv.mkDerivation rec { ''; meta = { - homepage = "https://commons.apache.org/proper/commons-compress"; + homepage = "https://commons.apache.org/proper/commons-compress"; description = "Allows manipulation of ar, cpio, Unix dump, tar, zip, gzip, XZ, Pack200, bzip2, 7z, arj, lzma, snappy, DEFLATE and Z files"; maintainers = with lib.maintainers; [ copumpkin ]; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; - license = lib.licenses.asl20; + license = lib.licenses.asl20; platforms = with lib.platforms; unix; }; } diff --git a/pkgs/by-name/co/commonsDaemon/package.nix b/pkgs/by-name/co/commonsDaemon/package.nix index 63cc3d41a0c39c..a5a8c84c66d71f 100644 --- a/pkgs/by-name/co/commonsDaemon/package.nix +++ b/pkgs/by-name/co/commonsDaemon/package.nix @@ -1,11 +1,15 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "1.4.0"; pname = "commons-daemon"; src = fetchurl { - url = "mirror://apache/commons/daemon/binaries/commons-daemon-${version}-bin.tar.gz"; + url = "mirror://apache/commons/daemon/binaries/commons-daemon-${version}-bin.tar.gz"; sha256 = "sha256-Cnsd15yREDtkoNFRAsIpACnChncVNgddTJ1CEvhKn48="; }; @@ -16,11 +20,11 @@ stdenv.mkDerivation rec { ''; meta = { - homepage = "https://commons.apache.org/proper/commons-daemon"; + homepage = "https://commons.apache.org/proper/commons-daemon"; description = "Apache Commons Daemon software is a set of utilities and Java support classes for running Java applications as server processes"; maintainers = with lib.maintainers; [ rsynnest ]; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; - license = lib.licenses.asl20; + license = lib.licenses.asl20; platforms = with lib.platforms; unix; }; } diff --git a/pkgs/by-name/co/commonsFileUpload/package.nix b/pkgs/by-name/co/commonsFileUpload/package.nix index 6c9235117355ab..e21b8078c2a2c5 100644 --- a/pkgs/by-name/co/commonsFileUpload/package.nix +++ b/pkgs/by-name/co/commonsFileUpload/package.nix @@ -1,11 +1,15 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "1.5"; pname = "commons-fileupload"; src = fetchurl { - url = "mirror://apache/commons/fileupload/binaries/${pname}-${version}-bin.tar.gz"; + url = "mirror://apache/commons/fileupload/binaries/${pname}-${version}-bin.tar.gz"; sha256 = "sha256-r7EGiih4qOCbjaL7Wg+plbe0m3CuFWXs/RmbfGLmj1g="; }; installPhase = '' @@ -15,11 +19,11 @@ stdenv.mkDerivation rec { ''; meta = { - homepage = "https://commons.apache.org/proper/commons-fileupload"; + homepage = "https://commons.apache.org/proper/commons-fileupload"; description = "Makes it easy to add robust, high-performance, file upload capability to your servlets and web applications"; maintainers = with lib.maintainers; [ copumpkin ]; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; - license = lib.licenses.asl20; + license = lib.licenses.asl20; platforms = with lib.platforms; unix; }; } diff --git a/pkgs/by-name/co/commonsIo/package.nix b/pkgs/by-name/co/commonsIo/package.nix index 077adb9547c067..92156099c10311 100644 --- a/pkgs/by-name/co/commonsIo/package.nix +++ b/pkgs/by-name/co/commonsIo/package.nix @@ -1,11 +1,15 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "2.18.0"; pname = "commons-io"; src = fetchurl { - url = "mirror://apache/commons/io/binaries/${pname}-${version}-bin.tar.gz"; + url = "mirror://apache/commons/io/binaries/${pname}-${version}-bin.tar.gz"; sha256 = "sha256-qrB4cLnvaTQaZJWrrDO8IYsYI2hp6/nN7nCRcFhKTeE="; }; @@ -16,11 +20,11 @@ stdenv.mkDerivation rec { ''; meta = { - homepage = "https://commons.apache.org/proper/commons-io"; + homepage = "https://commons.apache.org/proper/commons-io"; description = "Library of utilities to assist with developing IO functionality"; maintainers = with lib.maintainers; [ copumpkin ]; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; - license = lib.licenses.asl20; + license = lib.licenses.asl20; platforms = with lib.platforms; unix; }; } diff --git a/pkgs/by-name/co/commonsLang/package.nix b/pkgs/by-name/co/commonsLang/package.nix index cea5958100a64b..44850f72f064dd 100644 --- a/pkgs/by-name/co/commonsLang/package.nix +++ b/pkgs/by-name/co/commonsLang/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/co/commonsLogging/package.nix b/pkgs/by-name/co/commonsLogging/package.nix index fbd622927aaa9b..b9bbaacf5d4354 100644 --- a/pkgs/by-name/co/commonsLogging/package.nix +++ b/pkgs/by-name/co/commonsLogging/package.nix @@ -1,11 +1,15 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "commons-logging"; version = "1.3.4"; src = fetchurl { - url = "mirror://apache/commons/logging/binaries/commons-logging-${version}-bin.tar.gz"; + url = "mirror://apache/commons/logging/binaries/commons-logging-${version}-bin.tar.gz"; sha256 = "sha256-asHQ0i4bBICkRK2Hzfo7+/EmT9gX5jcv8KmFMz1qCGI="; }; @@ -22,4 +26,3 @@ stdenv.mkDerivation rec { platforms = lib.platforms.unix; }; } - diff --git a/pkgs/by-name/co/commonsMath/package.nix b/pkgs/by-name/co/commonsMath/package.nix index ddb3b17c1dae2d..0353b1dc682b36 100644 --- a/pkgs/by-name/co/commonsMath/package.nix +++ b/pkgs/by-name/co/commonsMath/package.nix @@ -1,11 +1,15 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "3.6.1"; pname = "commons-math"; src = fetchurl { - url = "mirror://apache/commons/math/binaries/commons-math3-${version}-bin.tar.gz"; + url = "mirror://apache/commons/math/binaries/commons-math3-${version}-bin.tar.gz"; sha256 = "0x4nx5pngv2n4ga11c1s4w2mf6cwydwkgs7da6wwvcjraw57bhkz"; }; @@ -16,11 +20,11 @@ stdenv.mkDerivation rec { ''; meta = { - homepage = "https://commons.apache.org/proper/commons-math/"; + homepage = "https://commons.apache.org/proper/commons-math/"; description = "Library of lightweight, self-contained mathematics and statistics components"; maintainers = with lib.maintainers; [ copumpkin ]; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; - license = lib.licenses.asl20; + license = lib.licenses.asl20; platforms = with lib.platforms; unix; }; } diff --git a/pkgs/by-name/co/comodoro/package.nix b/pkgs/by-name/co/comodoro/package.nix index 79022f72400580..12fe8e3c0d7b3c 100644 --- a/pkgs/by-name/co/comodoro/package.nix +++ b/pkgs/by-name/co/comodoro/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, installShellFiles -, installShellCompletions ? stdenv.buildPlatform.canExecute stdenv.hostPlatform -, installManPages ? stdenv.buildPlatform.canExecute stdenv.hostPlatform -, withTcp ? true +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + installShellFiles, + installShellCompletions ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, + installManPages ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, + withTcp ? true, }: rustPlatform.buildRustPackage rec { @@ -26,16 +27,18 @@ rustPlatform.buildRustPackage rec { buildNoDefaultFeatures = true; buildFeatures = lib.optional withTcp "tcp"; - postInstall = lib.optionalString installManPages '' - mkdir -p $out/man - $out/bin/comodoro man $out/man - installManPage $out/man/* - '' + lib.optionalString installShellCompletions '' - installShellCompletion --cmd comodoro \ - --bash <($out/bin/comodoro completion bash) \ - --fish <($out/bin/comodoro completion fish) \ - --zsh <($out/bin/comodoro completion zsh) - ''; + postInstall = + lib.optionalString installManPages '' + mkdir -p $out/man + $out/bin/comodoro man $out/man + installManPage $out/man/* + '' + + lib.optionalString installShellCompletions '' + installShellCompletion --cmd comodoro \ + --bash <($out/bin/comodoro completion bash) \ + --fish <($out/bin/comodoro completion fish) \ + --zsh <($out/bin/comodoro completion zsh) + ''; meta = with lib; { description = "CLI to manage your time"; diff --git a/pkgs/by-name/co/compdb/package.nix b/pkgs/by-name/co/compdb/package.nix index 0a5e689bb4b8f5..c840cd85b1fd82 100644 --- a/pkgs/by-name/co/compdb/package.nix +++ b/pkgs/by-name/co/compdb/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/co/compile-daemon/package.nix b/pkgs/by-name/co/compile-daemon/package.nix index 65ae92d90479a6..d348a82e7f2175 100644 --- a/pkgs/by-name/co/compile-daemon/package.nix +++ b/pkgs/by-name/co/compile-daemon/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "compile-daemon"; @@ -20,7 +25,10 @@ buildGoModule rec { }) ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Very simple compile daemon for Go"; diff --git a/pkgs/by-name/co/complete-alias/package.nix b/pkgs/by-name/co/complete-alias/package.nix index fdf0c1ae0ab261..97bae7640e4f72 100644 --- a/pkgs/by-name/co/complete-alias/package.nix +++ b/pkgs/by-name/co/complete-alias/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, stdenvNoCC +{ + lib, + fetchFromGitHub, + stdenvNoCC, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/co/completely/gemset.nix b/pkgs/by-name/co/completely/gemset.nix index f99da8f722189c..f823d1203a0755 100644 --- a/pkgs/by-name/co/completely/gemset.nix +++ b/pkgs/by-name/co/completely/gemset.nix @@ -1,41 +1,47 @@ { colsole = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fvf6dz2wsvjk7q24z0dm8lajq3p2l6i5ywf3mxj683rmhwq49bg"; type = "gem"; }; version = "1.0.0"; }; completely = { - dependencies = ["colsole" "mister_bin"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "colsole" + "mister_bin" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ci8iza647hvc4f1cmf9mpsm3i78ysf6g6213wkyrr5jk296hjjb"; type = "gem"; }; version = "0.6.3"; }; docopt_ng = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rsnl5s7k2s1gl4n4dg68ssg577kf11sl4a4l2lb2fpswj718950"; type = "gem"; }; version = "0.7.1"; }; mister_bin = { - dependencies = ["colsole" "docopt_ng"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "colsole" + "docopt_ng" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xx8cxvzcn47zsnshcllf477x4rbssrchvp76929qnsg5k9q7fas"; type = "gem"; }; diff --git a/pkgs/by-name/co/complexity/package.nix b/pkgs/by-name/co/complexity/package.nix index ce4cf1de1f18a0..d6d114be81c4cd 100644 --- a/pkgs/by-name/co/complexity/package.nix +++ b/pkgs/by-name/co/complexity/package.nix @@ -1,4 +1,9 @@ -{ fetchurl, lib, stdenv, autogen }: +{ + fetchurl, + lib, + stdenv, + autogen, +}: stdenv.mkDerivation rec { pname = "complexity"; diff --git a/pkgs/by-name/co/complgen/package.nix b/pkgs/by-name/co/complgen/package.nix index 8a540e77cfe2ee..aab5659855a1c6 100644 --- a/pkgs/by-name/co/complgen/package.nix +++ b/pkgs/by-name/co/complgen/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/co/composefs/package.nix b/pkgs/by-name/co/composefs/package.nix index 6d9e0eb45321f8..2eb790a00e5b9c 100644 --- a/pkgs/by-name/co/composefs/package.nix +++ b/pkgs/by-name/co/composefs/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, go-md2man -, pkg-config -, openssl -, fuse3 -, libcap -, python3 -, which -, valgrind -, erofs-utils -, fsverity-utils -, nix-update-script -, testers -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + go-md2man, + pkg-config, + openssl, + fuse3, + libcap, + python3, + which, + valgrind, + erofs-utils, + fsverity-utils, + nix-update-script, + testers, + nixosTests, -, fuseSupport ? lib.meta.availableOn stdenv.hostPlatform fuse3 -, enableValgrindCheck ? false -, installExperimentalTools ? false + fuseSupport ? lib.meta.availableOn stdenv.hostPlatform fuse3, + enableValgrindCheck ? false, + installExperimentalTools ? false, }: stdenv.mkDerivation (finalAttrs: { pname = "composefs"; @@ -33,7 +34,11 @@ stdenv.mkDerivation (finalAttrs: { }; strictDeps = true; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; postPatch = # 'both_libraries' as an install target always builds both versions. @@ -48,20 +53,31 @@ stdenv.mkDerivation (finalAttrs: { --replace-fail "install : false" "install : true" ''; - nativeBuildInputs = [ meson ninja go-md2man pkg-config ]; - buildInputs = [ openssl ] + nativeBuildInputs = [ + meson + ninja + go-md2man + pkg-config + ]; + buildInputs = + [ openssl ] ++ lib.optional fuseSupport fuse3 - ++ lib.filter (lib.meta.availableOn stdenv.hostPlatform) ( - [ + ++ lib.filter (lib.meta.availableOn stdenv.hostPlatform) ([ libcap - ] - ); + ]); doCheck = true; - nativeCheckInputs = [ python3 which ] + nativeCheckInputs = + [ + python3 + which + ] ++ lib.optional enableValgrindCheck valgrind ++ lib.optional fuseSupport fuse3 - ++ lib.filter (lib.meta.availableOn stdenv.buildPlatform) [ erofs-utils fsverity-utils ]; + ++ lib.filter (lib.meta.availableOn stdenv.buildPlatform) [ + erofs-utils + fsverity-utils + ]; mesonCheckFlags = lib.optionals enableValgrindCheck "--setup=valgrind"; @@ -82,7 +98,10 @@ stdenv.mkDerivation (finalAttrs: { description = "File system for mounting container images"; homepage = "https://github.com/containers/composefs"; changelog = "https://github.com/containers/composefs/releases/tag/v${finalAttrs.version}"; - license = with lib.licenses; [ gpl2Only asl20 ]; + license = with lib.licenses; [ + gpl2Only + asl20 + ]; maintainers = with lib.maintainers; [ kiskae ]; mainProgram = "mkcomposefs"; pkgConfigModules = [ "composefs" ]; diff --git a/pkgs/by-name/co/composer-require-checker/package.nix b/pkgs/by-name/co/composer-require-checker/package.nix index 5d2ca96d1389ca..a8da571f0befea 100644 --- a/pkgs/by-name/co/composer-require-checker/package.nix +++ b/pkgs/by-name/co/composer-require-checker/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchgit -, php +{ + lib, + fetchgit, + php, }: php.buildComposerProject2 (finalAttrs: { diff --git a/pkgs/by-name/co/compsize/package.nix b/pkgs/by-name/co/compsize/package.nix index a1175df2062967..160669a0ac78eb 100644 --- a/pkgs/by-name/co/compsize/package.nix +++ b/pkgs/by-name/co/compsize/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl, btrfs-progs }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + btrfs-progs, +}: let # https://github.com/kilobyte/compsize/issues/52 diff --git a/pkgs/by-name/co/computecpp-unwrapped/package.nix b/pkgs/by-name/co/computecpp-unwrapped/package.nix index 4572820336d16e..8ee55d6dde8785 100644 --- a/pkgs/by-name/co/computecpp-unwrapped/package.nix +++ b/pkgs/by-name/co/computecpp-unwrapped/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchzip -, pkg-config -, autoPatchelfHook -, installShellFiles -, ocl-icd -, zlib +{ + lib, + stdenv, + fetchzip, + pkg-config, + autoPatchelfHook, + installShellFiles, + ocl-icd, + zlib, }: stdenv.mkDerivation rec { @@ -19,8 +21,16 @@ stdenv.mkDerivation rec { dontStrip = true; - buildInputs = [ (lib.getLib stdenv.cc.cc) ocl-icd zlib ]; - nativeBuildInputs = [ autoPatchelfHook pkg-config installShellFiles ]; + buildInputs = [ + (lib.getLib stdenv.cc.cc) + ocl-icd + zlib + ]; + nativeBuildInputs = [ + autoPatchelfHook + pkg-config + installShellFiles + ]; installPhase = '' runHook preInstall @@ -39,8 +49,7 @@ stdenv.mkDerivation rec { }; meta = with lib; { - description = - "Accelerate Complex C++ Applications on Heterogeneous Compute Systems using Open Standards"; + description = "Accelerate Complex C++ Applications on Heterogeneous Compute Systems using Open Standards"; homepage = "https://www.codeplay.com/products/computesuite/computecpp"; license = licenses.unfree; maintainers = with maintainers; [ davidtwco ]; diff --git a/pkgs/by-name/co/comrak/package.nix b/pkgs/by-name/co/comrak/package.nix index 4ff52c7734924f..7438b31bc5e2b0 100644 --- a/pkgs/by-name/co/comrak/package.nix +++ b/pkgs/by-name/co/comrak/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "comrak"; @@ -19,6 +23,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/kivikakk/comrak"; changelog = "https://github.com/kivikakk/comrak/blob/v${version}/changelog.txt"; license = licenses.bsd2; - maintainers = with maintainers; [ figsoda kivikakk ]; + maintainers = with maintainers; [ + figsoda + kivikakk + ]; }; } diff --git a/pkgs/by-name/co/conan/package.nix b/pkgs/by-name/co/conan/package.nix index ebd96f12693cb0..d9fad07293aea2 100644 --- a/pkgs/by-name/co/conan/package.nix +++ b/pkgs/by-name/co/conan/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, git -, pkg-config -, xcbuild -, python3 -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + git, + pkg-config, + xcbuild, + python3, + zlib, }: python3.pkgs.buildPythonApplication rec { @@ -23,41 +24,47 @@ python3.pkgs.buildPythonApplication rec { nativeBuildInputs = with python3.pkgs; [ ]; - propagatedBuildInputs = with python3.pkgs; [ - bottle - colorama - python-dateutil - distro - fasteners - jinja2 - patch-ng - pluginbase - pygments - pyjwt - pylint # Not in `requirements.txt` but used in hooks, see https://github.com/conan-io/conan/pull/6152 - pyyaml - requests - tqdm - urllib3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - idna - cryptography - pyopenssl - ]; + propagatedBuildInputs = + with python3.pkgs; + [ + bottle + colorama + python-dateutil + distro + fasteners + jinja2 + patch-ng + pluginbase + pygments + pyjwt + pylint # Not in `requirements.txt` but used in hooks, see https://github.com/conan-io/conan/pull/6152 + pyyaml + requests + tqdm + urllib3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + idna + cryptography + pyopenssl + ]; - nativeCheckInputs = [ - git - pkg-config - zlib - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ - xcbuild.xcrun - ] ++ (with python3.pkgs; [ - mock - parameterized - pytest-xdist - pytestCheckHook - webtest - ]); + nativeCheckInputs = + [ + git + pkg-config + zlib + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ + xcbuild.xcrun + ] + ++ (with python3.pkgs; [ + mock + parameterized + pytest-xdist + pytestCheckHook + webtest + ]); __darwinAllowLocalNetworking = true; @@ -65,23 +72,25 @@ python3.pkgs.buildPythonApplication rec { "conan" ]; - disabledTests = [ - # Tests require network access - "TestFTP" - # Unstable test - "test_shared_windows_find_libraries" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # Rejects paths containing nix - "test_conditional_os" - # Requires Apple Clang - "test_detect_default_compilers" - "test_detect_default_in_mac_os_using_gcc_as_default" - # Incompatible with darwin.xattr and xcbuild from nixpkgs - "test_dot_files" - "test_xcrun" - "test_xcrun_in_required_by_tool_requires" - "test_xcrun_in_tool_requires" - ]; + disabledTests = + [ + # Tests require network access + "TestFTP" + # Unstable test + "test_shared_windows_find_libraries" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # Rejects paths containing nix + "test_conditional_os" + # Requires Apple Clang + "test_detect_default_compilers" + "test_detect_default_in_mac_os_using_gcc_as_default" + # Incompatible with darwin.xattr and xcbuild from nixpkgs + "test_dot_files" + "test_xcrun" + "test_xcrun_in_required_by_tool_requires" + "test_xcrun_in_tool_requires" + ]; disabledTestPaths = [ # Requires cmake, meson, autotools, apt-get, etc. diff --git a/pkgs/by-name/co/conceal/package.nix b/pkgs/by-name/co/conceal/package.nix index 5ce8d147fbbfc8..7cbd4015a5f844 100644 --- a/pkgs/by-name/co/conceal/package.nix +++ b/pkgs/by-name/co/conceal/package.nix @@ -1,4 +1,12 @@ -{ lib, rustPlatform, fetchFromGitHub, installShellFiles, stdenv, testers, conceal }: +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + testers, + conceal, +}: rustPlatform.buildRustPackage rec { pname = "conceal"; @@ -34,7 +42,10 @@ rustPlatform.buildRustPackage rec { description = "Trash collector written in Rust"; homepage = "https://github.com/TD-Sky/conceal"; license = licenses.mit; - maintainers = with maintainers; [ jedsek kashw2 ]; + maintainers = with maintainers; [ + jedsek + kashw2 + ]; broken = stdenv.hostPlatform.isDarwin; }; } diff --git a/pkgs/by-name/co/conduktor/package.nix b/pkgs/by-name/co/conduktor/package.nix index e45edf248b41d6..e78f4bd35e228e 100644 --- a/pkgs/by-name/co/conduktor/package.nix +++ b/pkgs/by-name/co/conduktor/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchurl, fetchzip, jdk11, makeWrapper, makeDesktopItem, copyDesktopItems }: +{ + stdenv, + lib, + fetchurl, + fetchzip, + jdk11, + makeWrapper, + makeDesktopItem, + copyDesktopItems, +}: stdenv.mkDerivation rec { pname = "conduktor"; @@ -9,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-9y/7jni5zIITUWd75AxsfG/b5vCYotmeMeC9aYM2WEs="; }; - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; desktopItems = [ (makeDesktopItem { diff --git a/pkgs/by-name/co/confd/package.nix b/pkgs/by-name/co/confd/package.nix index 5d4ebbed7d7446..aff9d6d5942f42 100644 --- a/pkgs/by-name/co/confd/package.nix +++ b/pkgs/by-name/co/confd/package.nix @@ -1,10 +1,13 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule { pname = "confd"; version = "0.16-unstable-2023-12-09"; - src = fetchFromGitHub { owner = "kelseyhightower"; repo = "confd"; @@ -16,7 +19,10 @@ buildGoModule { subPackages = [ "." ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = { description = "Manage local application configuration files using templates and data from etcd or consul"; diff --git a/pkgs/by-name/co/confetty/package.nix b/pkgs/by-name/co/confetty/package.nix index a9e838c84b014f..fa4ba1f8ae3354 100644 --- a/pkgs/by-name/co/confetty/package.nix +++ b/pkgs/by-name/co/confetty/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule { @@ -16,7 +17,10 @@ buildGoModule { vendorHash = "sha256-RymdnueY674Zd231O8CIw/TEIDaWDzc+AaI6yk9hFgc="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Confetti in your TTY"; diff --git a/pkgs/by-name/co/configurable-http-proxy/package.nix b/pkgs/by-name/co/configurable-http-proxy/package.nix index 7dc9a403b42431..cf8d346d85ff7c 100644 --- a/pkgs/by-name/co/configurable-http-proxy/package.nix +++ b/pkgs/by-name/co/configurable-http-proxy/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/co/confluencepot/package.nix b/pkgs/by-name/co/confluencepot/package.nix index 89233d2063d5a3..1bbcd0d4b3bd0f 100644 --- a/pkgs/by-name/co/confluencepot/package.nix +++ b/pkgs/by-name/co/confluencepot/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/co/confluent-cli/package.nix b/pkgs/by-name/co/confluent-cli/package.nix index 09ca1e7ff8f1d9..9358210fb25621 100644 --- a/pkgs/by-name/co/confluent-cli/package.nix +++ b/pkgs/by-name/co/confluent-cli/package.nix @@ -1,4 +1,9 @@ -{ stdenv, autoPatchelfHook, fetchurl, lib }: +{ + stdenv, + autoPatchelfHook, + fetchurl, + lib, +}: stdenv.mkDerivation rec { pname = "confluent-cli"; @@ -6,24 +11,26 @@ stdenv.mkDerivation rec { # To get the latest version: # curl -L https://cnfl.io/cli | sh -s -- -l | grep -v latest | sort -V | tail -n1 - src = { - x86_64-linux = fetchurl { - url = "https://s3-us-west-2.amazonaws.com/confluent.cloud/confluent-cli/archives/${version}/confluent_${version}_linux_amd64.tar.gz"; - hash = "sha256-GYA7T2yRcSNStvd9ZqI2iTJC3d6ymH9Dg5FVkIsM1f0="; - }; - aarch64-linux = fetchurl { - url = "https://s3-us-west-2.amazonaws.com/confluent.cloud/confluent-cli/archives/${version}/confluent_${version}_linux_arm64.tar.gz"; - hash = "sha256-BJJaZtRInKT6S0W22f96RCM8H18dIpOTP5lu357zh18="; - }; - x86_64-darwin = fetchurl { - url = "https://s3-us-west-2.amazonaws.com/confluent.cloud/confluent-cli/archives/${version}/confluent_${version}_darwin_amd64.tar.gz"; - hash = "sha256-94ur/FXxQWL4EOkEI1FSoWduRaMaY7DCNMiucpNC0B0="; - }; - aarch64-darwin = fetchurl { - url = "https://s3-us-west-2.amazonaws.com/confluent.cloud/confluent-cli/archives/${version}/confluent_${version}_darwin_arm64.tar.gz"; - hash = "sha256-aEIKSrO0/6dJCAyzwBH2ZDAmwvURugx6jTzaepbRvH8="; - }; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + { + x86_64-linux = fetchurl { + url = "https://s3-us-west-2.amazonaws.com/confluent.cloud/confluent-cli/archives/${version}/confluent_${version}_linux_amd64.tar.gz"; + hash = "sha256-GYA7T2yRcSNStvd9ZqI2iTJC3d6ymH9Dg5FVkIsM1f0="; + }; + aarch64-linux = fetchurl { + url = "https://s3-us-west-2.amazonaws.com/confluent.cloud/confluent-cli/archives/${version}/confluent_${version}_linux_arm64.tar.gz"; + hash = "sha256-BJJaZtRInKT6S0W22f96RCM8H18dIpOTP5lu357zh18="; + }; + x86_64-darwin = fetchurl { + url = "https://s3-us-west-2.amazonaws.com/confluent.cloud/confluent-cli/archives/${version}/confluent_${version}_darwin_amd64.tar.gz"; + hash = "sha256-94ur/FXxQWL4EOkEI1FSoWduRaMaY7DCNMiucpNC0B0="; + }; + aarch64-darwin = fetchurl { + url = "https://s3-us-west-2.amazonaws.com/confluent.cloud/confluent-cli/archives/${version}/confluent_${version}_darwin_arm64.tar.gz"; + hash = "sha256-aEIKSrO0/6dJCAyzwBH2ZDAmwvURugx6jTzaepbRvH8="; + }; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ autoPatchelfHook ]; @@ -41,7 +48,10 @@ stdenv.mkDerivation rec { homepage = "https://docs.confluent.io/confluent-cli/current/overview.html"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - maintainers = with maintainers; [ rguevara84 autophagy ]; + maintainers = with maintainers; [ + rguevara84 + autophagy + ]; # TODO: There's support for i686 systems but I do not have any such system # to build it locally on, it's also unfree so I cannot rely on ofborg to diff --git a/pkgs/by-name/co/confluent-platform/package.nix b/pkgs/by-name/co/confluent-platform/package.nix index 340a9dc36c15ef..05f1395ceda59c 100644 --- a/pkgs/by-name/co/confluent-platform/package.nix +++ b/pkgs/by-name/co/confluent-platform/package.nix @@ -1,11 +1,11 @@ { - bash -, fetchurl -, gnused -, jre -, lib -, makeBinaryWrapper -, stdenv + bash, + fetchurl, + gnused, + jre, + lib, + makeBinaryWrapper, + stdenv, }: stdenv.mkDerivation (finalAttrs: { @@ -56,7 +56,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Confluent event streaming platform based on Apache Kafka"; homepage = "https://www.confluent.io/"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ zoedsoupe autophagy ]; + maintainers = with lib.maintainers; [ + zoedsoupe + autophagy + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/by-name/co/conform/package.nix b/pkgs/by-name/co/conform/package.nix index 65ce7e63d603a5..77136883345645 100644 --- a/pkgs/by-name/co/conform/package.nix +++ b/pkgs/by-name/co/conform/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, git }: +{ + lib, + buildGoModule, + fetchFromGitHub, + git, +}: buildGoModule rec { pname = "conform"; @@ -25,7 +30,10 @@ buildGoModule rec { description = "Policy enforcement for your pipelines"; homepage = "https://github.com/siderolabs/conform"; license = licenses.mpl20; - maintainers = with maintainers; [ jmgilman jk ]; + maintainers = with maintainers; [ + jmgilman + jk + ]; mainProgram = "conform"; }; } diff --git a/pkgs/by-name/co/conftest/package.nix b/pkgs/by-name/co/conftest/package.nix index 2fc0e95d75eeae..c0e62aff582e34 100644 --- a/pkgs/by-name/co/conftest/package.nix +++ b/pkgs/by-name/co/conftest/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -60,6 +61,9 @@ buildGoModule rec { assertions. You can read more about Rego in 'How do I write policies' in the Open Policy Agent documentation. ''; - maintainers = with maintainers; [ jk yurrriq ]; + maintainers = with maintainers; [ + jk + yurrriq + ]; }; } diff --git a/pkgs/by-name/co/confy/package.nix b/pkgs/by-name/co/confy/package.nix index 89110aead938bc..68fe0c31ffe7aa 100644 --- a/pkgs/by-name/co/confy/package.nix +++ b/pkgs/by-name/co/confy/package.nix @@ -1,17 +1,18 @@ -{ lib -, blueprint-compiler -, desktop-file-utils -, fetchFromSourcehut -, gobject-introspection -, gtk4 -, libadwaita -, libnotify -, meson -, ninja -, pkg-config -, python3 -, stdenv -, wrapGAppsHook4 +{ + lib, + blueprint-compiler, + desktop-file-utils, + fetchFromSourcehut, + gobject-introspection, + gtk4, + libadwaita, + libnotify, + meson, + ninja, + pkg-config, + python3, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { @@ -39,10 +40,12 @@ stdenv.mkDerivation (finalAttrs: { gtk4 libadwaita libnotify - (python3.withPackages (ps: with ps; [ - icalendar - pygobject3 - ])) + (python3.withPackages ( + ps: with ps; [ + icalendar + pygobject3 + ] + )) ]; postPatch = '' diff --git a/pkgs/by-name/co/conjure/package.nix b/pkgs/by-name/co/conjure/package.nix index 105b8577bd64e8..5a8ea6082a419b 100644 --- a/pkgs/by-name/co/conjure/package.nix +++ b/pkgs/by-name/co/conjure/package.nix @@ -1,15 +1,16 @@ -{ fetchFromGitHub -, gobject-introspection -, lib -, libadwaita -, python3Packages -, wrapGAppsHook4 -, meson -, ninja -, desktop-file-utils -, pkg-config -, appstream-glib -, gtk4 +{ + fetchFromGitHub, + gobject-introspection, + lib, + libadwaita, + python3Packages, + wrapGAppsHook4, + meson, + ninja, + desktop-file-utils, + pkg-config, + appstream-glib, + gtk4, }: python3Packages.buildPythonApplication rec { pname = "conjure"; diff --git a/pkgs/by-name/co/conmon-rs/package.nix b/pkgs/by-name/co/conmon-rs/package.nix index a68f48ebaa4044..6990bf85bd76f7 100644 --- a/pkgs/by-name/co/conmon-rs/package.nix +++ b/pkgs/by-name/co/conmon-rs/package.nix @@ -1,8 +1,9 @@ -{ capnproto -, lib -, fetchFromGitHub -, protobuf -, rustPlatform +{ + capnproto, + lib, + fetchFromGitHub, + protobuf, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -16,7 +17,10 @@ rustPlatform.buildRustPackage rec { hash = "sha256-1kGAUAmiPI9zE8LE7G2r0Gy0YM+BUy2MxY7IQOu2ZDQ="; }; - nativeBuildInputs = [ capnproto protobuf ]; + nativeBuildInputs = [ + capnproto + protobuf + ]; doCheck = false; cargoVendorDir = ".cargo-vendor"; diff --git a/pkgs/by-name/co/conmon/package.nix b/pkgs/by-name/co/conmon/package.nix index 0e7ece1b5f82a0..e7add38b3c2b8c 100644 --- a/pkgs/by-name/co/conmon/package.nix +++ b/pkgs/by-name/co/conmon/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, glib -, glibc -, libseccomp -, systemd -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + glib, + glibc, + libseccomp, + systemd, + nixosTests, }: stdenv.mkDerivation rec { @@ -21,11 +22,22 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib libseccomp systemd ] - ++ lib.optionals (!stdenv.hostPlatform.isMusl) [ glibc glibc.static ]; + buildInputs = + [ + glib + libseccomp + systemd + ] + ++ lib.optionals (!stdenv.hostPlatform.isMusl) [ + glibc + glibc.static + ]; # manpage requires building the vendored go-md2man - makeFlags = [ "bin/conmon" "VERSION=${version}" ]; + makeFlags = [ + "bin/conmon" + "VERSION=${version}" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/co/connect/package.nix b/pkgs/by-name/co/connect/package.nix index 408bbbf66708c9..3e1834c11e8c7a 100644 --- a/pkgs/by-name/co/connect/package.nix +++ b/pkgs/by-name/co/connect/package.nix @@ -1,15 +1,19 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "connect"; - version ="1.105"; + version = "1.105"; src = fetchurl { url = "https://bitbucket.org/gotoh/connect/get/${version}.tar.bz2"; sha256 = "00yld6yinc8s4xv3b8kbvzn2f4rja5dmp6ysv3n4847qn4k60dh7"; }; - makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; # gcc and/or clang compat + makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; # gcc and/or clang compat installPhase = '' install -D -m ugo=rx connect $out/bin/connect @@ -20,7 +24,7 @@ stdenv.mkDerivation rec { longDescription = '' This proxy traversal tool is intended to assist OpenSSH (via ProxyCommand in ~/.ssh/config) and GIT (via $GIT_PROXY_COMMAND) utilize SOCKS and https proxies. - ''; + ''; homepage = "https://bitbucket.org/gotoh/connect/wiki/Home"; license = lib.licenses.gpl2Plus; platforms = lib.platforms.gnu ++ lib.platforms.linux ++ lib.platforms.darwin; diff --git a/pkgs/by-name/co/connectome-workbench/package.nix b/pkgs/by-name/co/connectome-workbench/package.nix index bcffc4161cc3c0..dd0a3467d1a9f2 100644 --- a/pkgs/by-name/co/connectome-workbench/package.nix +++ b/pkgs/by-name/co/connectome-workbench/package.nix @@ -1,4 +1,5 @@ -{ lib, +{ + lib, stdenv, fetchFromGitHub, fetchpatch, @@ -47,18 +48,24 @@ stdenv.mkDerivation (finalAttrs: { libsForQt5.wrapQtAppsHook ]; - buildInputs = [ - libGL - libGLU - ] ++ (with libsForQt5; [ - qtbase - ]); + buildInputs = + [ + libGL + libGLU + ] + ++ (with libsForQt5; [ + qtbase + ]); # note: we should be able to unvendor a few libs (ftgl, quazip, qwt) but they aren't detected properly meta = { description = "Visualization and discovery tool used to map neuroimaging data"; homepage = "https://www.humanconnectome.org/software/connectome-workbench"; - license = with lib.licenses; [ gpl2Plus gpl3Plus mit ]; + license = with lib.licenses; [ + gpl2Plus + gpl3Plus + mit + ]; changelog = "https://github.com/Washington-University/workbench/releases/tag/v${finalAttrs.version}"; maintainers = with lib.maintainers; [ bcdarwin ]; mainProgram = "wb_command"; diff --git a/pkgs/by-name/co/connman-gtk/package.nix b/pkgs/by-name/co/connman-gtk/package.nix index d721b3551b0444..9475a30d849f88 100644 --- a/pkgs/by-name/co/connman-gtk/package.nix +++ b/pkgs/by-name/co/connman-gtk/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, intltool, pkg-config, -gtk3, connman, openconnect, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + intltool, + pkg-config, + gtk3, + connman, + openconnect, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "connman-gtk"; diff --git a/pkgs/by-name/co/connman-ncurses/package.nix b/pkgs/by-name/co/connman-ncurses/package.nix index 9b63dcd7b3aa74..7add30d1d9eb33 100644 --- a/pkgs/by-name/co/connman-ncurses/package.nix +++ b/pkgs/by-name/co/connman-ncurses/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchpatch, fetchFromGitHub, autoreconfHook, pkg-config, dbus, json_c, ncurses, connman }: +{ + lib, + stdenv, + fetchpatch, + fetchFromGitHub, + autoreconfHook, + pkg-config, + dbus, + json_c, + ncurses, + connman, +}: stdenv.mkDerivation { pname = "connman-ncurses"; @@ -20,9 +31,17 @@ stdenv.mkDerivation { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ dbus ncurses json_c connman ]; + buildInputs = [ + dbus + ncurses + json_c + connman + ]; env.NIX_CFLAGS_COMPILE = "-Wno-error"; diff --git a/pkgs/by-name/co/connman-notify/package.nix b/pkgs/by-name/co/connman-notify/package.nix index fad8e477ada72c..90a27db9a2dd1a 100644 --- a/pkgs/by-name/co/connman-notify/package.nix +++ b/pkgs/by-name/co/connman-notify/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitLab, python3Packages, glib, gobject-introspection, wrapGAppsHook3 }: +{ + lib, + fetchFromGitLab, + python3Packages, + glib, + gobject-introspection, + wrapGAppsHook3, +}: python3Packages.buildPythonApplication { pname = "connman-notify"; @@ -13,11 +20,17 @@ python3Packages.buildPythonApplication { format = "other"; - nativeBuildInputs = [ gobject-introspection wrapGAppsHook3 ]; + nativeBuildInputs = [ + gobject-introspection + wrapGAppsHook3 + ]; buildInputs = [ glib ]; - pythonPath = with python3Packages; [ dbus-python pygobject3 ]; + pythonPath = with python3Packages; [ + dbus-python + pygobject3 + ]; strictDeps = false; diff --git a/pkgs/by-name/co/connman/package.nix b/pkgs/by-name/co/connman/package.nix index 17c54f8906eb48..44737f4f49eec9 100644 --- a/pkgs/by-name/co/connman/package.nix +++ b/pkgs/by-name/co/connman/package.nix @@ -1,54 +1,56 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, dbus -, file -, glib -, gnutls -, iptables -, libmnl -, libnftnl # for nftables -, nixosTests -, openconnect -, openvpn -, pkg-config -, polkit -, ppp -, pptp -, readline -, vpnc -, dnsType ? "internal" # or "systemd-resolved" -, enableBluetooth ? true -, enableClient ? true -, enableDatafiles ? true -, enableDundee ? true -, enableEthernet ? true -, enableGadget ? true -, enableHh2serialGps ? false -, enableIospm ? false -, enableL2tp ? false -, enableLoopback ? true -, enableNeard ? true -, enableNetworkManager ? null -, enableNetworkManagerCompatibility ? - if enableNetworkManager == null - then false - else lib.warn "enableNetworkManager option is deprecated; use enableNetworkManagerCompatibility instead" enableNetworkManager -, enableOfono ? true -, enableOpenconnect ? true -, enableOpenvpn ? true -, enablePacrunner ? true -, enablePolkit ? true -, enablePptp ? true -, enableStats ? true -, enableTist ? false -, enableTools ? true -, enableVpnc ? true -, enableWifi ? true -, enableWireguard ? true -, enableWispr ? true -, firewallType ? "iptables" # or "nftables" +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + dbus, + file, + glib, + gnutls, + iptables, + libmnl, + libnftnl, # for nftables + nixosTests, + openconnect, + openvpn, + pkg-config, + polkit, + ppp, + pptp, + readline, + vpnc, + dnsType ? "internal", # or "systemd-resolved" + enableBluetooth ? true, + enableClient ? true, + enableDatafiles ? true, + enableDundee ? true, + enableEthernet ? true, + enableGadget ? true, + enableHh2serialGps ? false, + enableIospm ? false, + enableL2tp ? false, + enableLoopback ? true, + enableNeard ? true, + enableNetworkManager ? null, + enableNetworkManagerCompatibility ? + if enableNetworkManager == null then + false + else + lib.warn "enableNetworkManager option is deprecated; use enableNetworkManagerCompatibility instead" enableNetworkManager, + enableOfono ? true, + enableOpenconnect ? true, + enableOpenvpn ? true, + enablePacrunner ? true, + enablePolkit ? true, + enablePptp ? true, + enableStats ? true, + enableTist ? false, + enableTools ? true, + enableVpnc ? true, + enableWifi ? true, + enableWireguard ? true, + enableWispr ? true, + firewallType ? "iptables", # or "nftables" }: let @@ -56,10 +58,17 @@ let enableFeature enableFeatureAs optionals - withFeatureAs; + withFeatureAs + ; in -assert lib.asserts.assertOneOf "firewallType" firewallType [ "iptables" "nftables" ]; -assert lib.asserts.assertOneOf "dnsType" dnsType [ "internal" "systemd-resolved" ]; +assert lib.asserts.assertOneOf "firewallType" firewallType [ + "iptables" + "nftables" +]; +assert lib.asserts.assertOneOf "dnsType" dnsType [ + "internal" + "systemd-resolved" +]; stdenv.mkDerivation (finalAttrs: { pname = "connman"; version = "1.43"; @@ -83,78 +92,85 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - glib - dbus - libmnl - gnutls - readline - ] - ++ optionals (firewallType == "iptables") [ iptables ] - ++ optionals (firewallType == "nftables") [ libnftnl ] - ++ optionals (enableOpenconnect) [ openconnect ] - ++ optionals (enablePolkit) [ polkit ] - ++ optionals (enablePptp) [ pptp ppp ] - ; + buildInputs = + [ + glib + dbus + libmnl + gnutls + readline + ] + ++ optionals (firewallType == "iptables") [ iptables ] + ++ optionals (firewallType == "nftables") [ libnftnl ] + ++ optionals (enableOpenconnect) [ openconnect ] + ++ optionals (enablePolkit) [ polkit ] + ++ optionals (enablePptp) [ + pptp + ppp + ]; postPatch = '' sed -i "s@/usr/bin/file@file@g" ./configure ''; - configureFlags = [ - # directories flags - "--sysconfdir=/etc" - "--localstatedir=/var" - ] ++ [ - # production build flags - (enableFeature false "maintainer-mode") - (enableFeatureAs true "session-policy-local" "builtin") - # for building and running tests - # (enableFeature true "tests") # installs the tests, we don't want that - (enableFeature true "tools") - (enableFeature enableLoopback "loopback") - (enableFeature enableEthernet "ethernet") - (enableFeature enableWireguard "wireguard") - (enableFeature enableGadget "gadget") - (enableFeature enableWifi "wifi") - # enable IWD support for wifi as it doesn't require any new dependencies and - # it's easier for the NixOS module to use only one connman package when IWD - # is requested - (enableFeature enableWifi "iwd") - (enableFeature enableBluetooth "bluetooth") - (enableFeature enableOfono "ofono") - (enableFeature enableDundee "dundee") - (enableFeature enablePacrunner "pacrunner") - (enableFeature enableNeard "neard") - (enableFeature enableWispr "wispr") - (enableFeature enableTools "tools") - (enableFeature enableStats "stats") - (enableFeature enableClient "client") - (enableFeature enableDatafiles "datafiles") - (enableFeature enablePolkit "polkit") - (enableFeature enablePptp "pptp") - (enableFeature enableWireguard "wireguard") - (enableFeature enableNetworkManagerCompatibility "nmcompat") - (enableFeature enableHh2serialGps "hh2serial-gps") - (enableFeature enableL2tp "l2tp") - (enableFeature enableIospm "iospm") - (enableFeature enableTist "tist") - ] ++ [ - (enableFeatureAs enableOpenconnect "openconnect" "builtin") - (enableFeatureAs enableOpenvpn "openvpn" "builtin") - (enableFeatureAs enableVpnc "vpnc" "builtin") - ] ++ [ - (withFeatureAs true "dbusconfdir" "${placeholder "out"}/share") - (withFeatureAs true "dbusdatadir" "${placeholder "out"}/share") - (withFeatureAs true "tmpfilesdir" "${placeholder "out"}/tmpfiles.d") - (withFeatureAs true "systemdunitdir" "${placeholder "out"}/systemd/system") - (withFeatureAs true "dns-backend" "${dnsType}") - (withFeatureAs true "firewall" "${firewallType}") - (withFeatureAs enableOpenconnect "openconnect" "${openconnect}/sbin/openconnect") - (withFeatureAs enableOpenvpn "openvpn" "${openvpn}/sbin/openvpn") - (withFeatureAs enableVpnc "vpnc" "${vpnc}/sbin/vpnc") - (withFeatureAs enablePptp "pptp" "${pptp}/sbin/pptp") - ]; + configureFlags = + [ + # directories flags + "--sysconfdir=/etc" + "--localstatedir=/var" + ] + ++ [ + # production build flags + (enableFeature false "maintainer-mode") + (enableFeatureAs true "session-policy-local" "builtin") + # for building and running tests + # (enableFeature true "tests") # installs the tests, we don't want that + (enableFeature true "tools") + (enableFeature enableLoopback "loopback") + (enableFeature enableEthernet "ethernet") + (enableFeature enableWireguard "wireguard") + (enableFeature enableGadget "gadget") + (enableFeature enableWifi "wifi") + # enable IWD support for wifi as it doesn't require any new dependencies and + # it's easier for the NixOS module to use only one connman package when IWD + # is requested + (enableFeature enableWifi "iwd") + (enableFeature enableBluetooth "bluetooth") + (enableFeature enableOfono "ofono") + (enableFeature enableDundee "dundee") + (enableFeature enablePacrunner "pacrunner") + (enableFeature enableNeard "neard") + (enableFeature enableWispr "wispr") + (enableFeature enableTools "tools") + (enableFeature enableStats "stats") + (enableFeature enableClient "client") + (enableFeature enableDatafiles "datafiles") + (enableFeature enablePolkit "polkit") + (enableFeature enablePptp "pptp") + (enableFeature enableWireguard "wireguard") + (enableFeature enableNetworkManagerCompatibility "nmcompat") + (enableFeature enableHh2serialGps "hh2serial-gps") + (enableFeature enableL2tp "l2tp") + (enableFeature enableIospm "iospm") + (enableFeature enableTist "tist") + ] + ++ [ + (enableFeatureAs enableOpenconnect "openconnect" "builtin") + (enableFeatureAs enableOpenvpn "openvpn" "builtin") + (enableFeatureAs enableVpnc "vpnc" "builtin") + ] + ++ [ + (withFeatureAs true "dbusconfdir" "${placeholder "out"}/share") + (withFeatureAs true "dbusdatadir" "${placeholder "out"}/share") + (withFeatureAs true "tmpfilesdir" "${placeholder "out"}/tmpfiles.d") + (withFeatureAs true "systemdunitdir" "${placeholder "out"}/systemd/system") + (withFeatureAs true "dns-backend" "${dnsType}") + (withFeatureAs true "firewall" "${firewallType}") + (withFeatureAs enableOpenconnect "openconnect" "${openconnect}/sbin/openconnect") + (withFeatureAs enableOpenvpn "openvpn" "${openvpn}/sbin/openvpn") + (withFeatureAs enableVpnc "vpnc" "${vpnc}/sbin/vpnc") + (withFeatureAs enablePptp "pptp" "${pptp}/sbin/pptp") + ]; doCheck = true; diff --git a/pkgs/by-name/co/connman_dmenu/package.nix b/pkgs/by-name/co/connman_dmenu/package.nix index 9e9bf070a14d99..b986c9a405962c 100644 --- a/pkgs/by-name/co/connman_dmenu/package.nix +++ b/pkgs/by-name/co/connman_dmenu/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, connman, dmenu }: +{ + lib, + stdenv, + fetchFromGitHub, + connman, + dmenu, +}: stdenv.mkDerivation { pname = "connman_dmenu"; @@ -11,7 +17,10 @@ stdenv.mkDerivation { hash = "sha256-05MjFg+8rliYIAdOOHmP7DQhOTeYn5ZoCpZEdQeKLhg="; }; - buildInputs = [ connman dmenu ]; + buildInputs = [ + connman + dmenu + ]; dontBuild = true; diff --git a/pkgs/by-name/co/conntrack-tools/package.nix b/pkgs/by-name/co/conntrack-tools/package.nix index 42741fae5b6c9c..ad16b2d4dfa746 100644 --- a/pkgs/by-name/co/conntrack-tools/package.nix +++ b/pkgs/by-name/co/conntrack-tools/package.nix @@ -1,7 +1,19 @@ -{ fetchurl, lib, stdenv, flex, bison, pkg-config, libmnl, libnfnetlink -, libnetfilter_conntrack, libnetfilter_queue, libnetfilter_cttimeout -, libnetfilter_cthelper, libtirpc -, systemdSupport ? true, systemd +{ + fetchurl, + lib, + stdenv, + flex, + bison, + pkg-config, + libmnl, + libnfnetlink, + libnetfilter_conntrack, + libnetfilter_queue, + libnetfilter_cttimeout, + libnetfilter_cthelper, + libtirpc, + systemdSupport ? true, + systemd, }: stdenv.mkDerivation rec { @@ -13,13 +25,24 @@ stdenv.mkDerivation rec { hash = "sha256-BnZ39MX2VkgZ547TqdSomAk16pJz86uyKkIOowq13tY="; }; - buildInputs = [ - libmnl libnfnetlink libnetfilter_conntrack libnetfilter_queue - libnetfilter_cttimeout libnetfilter_cthelper libtirpc - ] ++ lib.optionals systemdSupport [ - systemd + buildInputs = + [ + libmnl + libnfnetlink + libnetfilter_conntrack + libnetfilter_queue + libnetfilter_cttimeout + libnetfilter_cthelper + libtirpc + ] + ++ lib.optionals systemdSupport [ + systemd + ]; + nativeBuildInputs = [ + flex + bison + pkg-config ]; - nativeBuildInputs = [ flex bison pkg-config ]; configureFlags = [ (lib.enableFeature systemdSupport "systemd") diff --git a/pkgs/by-name/co/conserve/package.nix b/pkgs/by-name/co/conserve/package.nix index 1d7de926c55157..c5f459db1b4579 100644 --- a/pkgs/by-name/co/conserve/package.nix +++ b/pkgs/by-name/co/conserve/package.nix @@ -3,7 +3,7 @@ stdenv, rustPlatform, fetchFromGitHub, - darwin + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/co/conserver/package.nix b/pkgs/by-name/co/conserver/package.nix index 1c550033c3ea81..cb741ecc459055 100644 --- a/pkgs/by-name/co/conserver/package.nix +++ b/pkgs/by-name/co/conserver/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, libxcrypt -, gssapiSupport ? false -, libkrb5 -, freeipmiSupport ? false -, freeipmi -, ipv6Support ? true -, opensslSupport ? true -, openssl -, trustUdsCredSupport ? false -, udsSupport ? false +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + libxcrypt, + gssapiSupport ? false, + libkrb5, + freeipmiSupport ? false, + freeipmi, + ipv6Support ? true, + opensslSupport ? true, + openssl, + trustUdsCredSupport ? false, + udsSupport ? false, }: stdenv.mkDerivation rec { @@ -37,12 +38,17 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ libxcrypt ] + buildInputs = + [ libxcrypt ] ++ lib.optionals freeipmiSupport [ freeipmi ] ++ lib.optionals gssapiSupport [ libkrb5 ] ++ lib.optionals opensslSupport [ openssl ]; - configureFlags = [ "--with-ccffile=/dev/null" "--with-cffile=/dev/null" ] + configureFlags = + [ + "--with-ccffile=/dev/null" + "--with-cffile=/dev/null" + ] ++ lib.optionals freeipmiSupport [ "--with-freeipmi=${freeipmi}/include" ] ++ lib.optionals gssapiSupport [ "--with-gssapi=${libkrb5.dev}/include" ] ++ lib.optionals ipv6Support [ "--with-ipv6" ] diff --git a/pkgs/by-name/co/console-bridge/package.nix b/pkgs/by-name/co/console-bridge/package.nix index f02ac839a3e021..384f305977c942 100644 --- a/pkgs/by-name/co/console-bridge/package.nix +++ b/pkgs/by-name/co/console-bridge/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, validatePkgConfig }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + validatePkgConfig, +}: stdenv.mkDerivation rec { pname = "console-bridge"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-M3GocT0hodw3Sc2NHcFDiPVZ1XN7BqIUuYLW8OaXMqM="; }; - nativeBuildInputs = [ cmake validatePkgConfig ]; + nativeBuildInputs = [ + cmake + validatePkgConfig + ]; meta = with lib; { description = "ROS-independent package for logging that seamlessly pipes into rosconsole/rosout for ROS-dependent packages"; diff --git a/pkgs/by-name/co/conspy/package.nix b/pkgs/by-name/co/conspy/package.nix index 19b1565e435d61..6612322744ba52 100644 --- a/pkgs/by-name/co/conspy/package.nix +++ b/pkgs/by-name/co/conspy/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, autoconf, automake, ncurses }: +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + ncurses, +}: stdenv.mkDerivation rec { pname = "conspy"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { curlOpts = " -A application/octet-stream "; }; - nativeBuildInputs = [ autoconf automake ]; + nativeBuildInputs = [ + autoconf + automake + ]; buildInputs = [ ncurses ]; diff --git a/pkgs/by-name/co/construct/package.nix b/pkgs/by-name/co/construct/package.nix index 89833c8176088d..1869e1acd7add6 100644 --- a/pkgs/by-name/co/construct/package.nix +++ b/pkgs/by-name/co/construct/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, lib -, fetchFromGitHub +{ + stdenv, + lib, + fetchFromGitHub, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/co/consul-alerts/package.nix b/pkgs/by-name/co/consul-alerts/package.nix index f50d30d3aa04d1..5cf18d05c0b1a8 100644 --- a/pkgs/by-name/co/consul-alerts/package.nix +++ b/pkgs/by-name/co/consul-alerts/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "consul-alerts"; diff --git a/pkgs/by-name/co/consul-template/package.nix b/pkgs/by-name/co/consul-template/package.nix index dff8d8347dacfe..be77105fd98829 100644 --- a/pkgs/by-name/co/consul-template/package.nix +++ b/pkgs/by-name/co/consul-template/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "consul-template"; @@ -26,7 +31,10 @@ buildGoModule rec { description = "Generic template rendering and notifications with Consul"; platforms = platforms.linux ++ platforms.darwin; license = licenses.mpl20; - maintainers = with maintainers; [ cpcloud pradeepchhetri ]; + maintainers = with maintainers; [ + cpcloud + pradeepchhetri + ]; mainProgram = "consul-template"; }; } diff --git a/pkgs/by-name/co/controku/package.nix b/pkgs/by-name/co/controku/package.nix index a52d2e32646488..029b4a37c61bb7 100644 --- a/pkgs/by-name/co/controku/package.nix +++ b/pkgs/by-name/co/controku/package.nix @@ -1,4 +1,6 @@ -{ python3Packages +{ + python3Packages, }: -with python3Packages; toPythonApplication (controku.override { buildApplication = true; }) +with python3Packages; +toPythonApplication (controku.override { buildApplication = true; }) diff --git a/pkgs/by-name/co/convchain/package.nix b/pkgs/by-name/co/convchain/package.nix index 20f29b2a0ad5bb..544887e01947bc 100644 --- a/pkgs/by-name/co/convchain/package.nix +++ b/pkgs/by-name/co/convchain/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchFromGitHub, mono}: +{ + lib, + stdenv, + fetchFromGitHub, + mono, +}: stdenv.mkDerivation rec { pname = "convchain"; version = "0.0pre20160901"; @@ -29,11 +34,11 @@ stdenv.mkDerivation rec { echo "'${mono}/bin/mono' '$out/bin/convchainfast.exe' \"\$@\"" >> "$out/bin/convchainfast" chmod a+x "$out/bin/convchainfast" ''; - buildInputs = [mono]; + buildInputs = [ mono ]; meta = { description = "Bitmap generation from a single example with convolutions and MCMC"; license = lib.licenses.mit; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/co/convco/package.nix b/pkgs/by-name/co/convco/package.nix index c0f780b5bb3c54..8e76730abb155c 100644 --- a/pkgs/by-name/co/convco/package.nix +++ b/pkgs/by-name/co/convco/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, rustPlatform -, fetchFromGitHub -, cmake -, libiconv -, openssl -, pkg-config -, darwin +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + cmake, + libiconv, + openssl, + pkg-config, + darwin, }: rustPlatform.buildRustPackage rec { @@ -22,9 +23,17 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-oQBCPfwlMJ0hLZskv+KUNVBHH550yAUI1jY40Eah3Bc="; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv darwin.apple_sdk.frameworks.Security ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + darwin.apple_sdk.frameworks.Security + ]; checkFlags = [ # disable test requiring networking @@ -36,6 +45,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "convco"; homepage = "https://github.com/convco/convco"; license = with licenses; [ mit ]; - maintainers = with maintainers; [ hoverbear cafkafk ]; + maintainers = with maintainers; [ + hoverbear + cafkafk + ]; }; } diff --git a/pkgs/by-name/co/converseen/package.nix b/pkgs/by-name/co/converseen/package.nix index 7d409889e37441..94f6ffef5ac5e6 100644 --- a/pkgs/by-name/co/converseen/package.nix +++ b/pkgs/by-name/co/converseen/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, imagemagick -, pkg-config -, qt5 -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + imagemagick, + pkg-config, + qt5, + nix-update-script, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/co/convertlit/package.nix b/pkgs/by-name/co/convertlit/package.nix index 417007fbd3ba9c..6bc9cd4ffaef2d 100644 --- a/pkgs/by-name/co/convertlit/package.nix +++ b/pkgs/by-name/co/convertlit/package.nix @@ -1,16 +1,21 @@ -{lib, stdenv, fetchzip, libtommath}: +{ + lib, + stdenv, + fetchzip, + libtommath, +}: stdenv.mkDerivation rec { pname = "convertlit"; version = "1.8"; src = fetchzip { - url = "http://www.convertlit.com/convertlit${lib.replaceStrings ["."] [""] version}src.zip"; + url = "http://www.convertlit.com/convertlit${lib.replaceStrings [ "." ] [ "" ] version}src.zip"; sha256 = "182nsin7qscgbw2h92m0zadh3h8q410h5cza6v486yjfvla3dxjx"; stripRoot = false; }; - buildInputs = [libtommath]; + buildInputs = [ libtommath ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/co/convimg/package.nix b/pkgs/by-name/co/convimg/package.nix index 4ac8fac7375268..4984bdb72ea5c0 100644 --- a/pkgs/by-name/co/convimg/package.nix +++ b/pkgs/by-name/co/convimg/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/co/convos/package.nix b/pkgs/by-name/co/convos/package.nix index c456875d016ba5..356d08b3635bea 100644 --- a/pkgs/by-name/co/convos/package.nix +++ b/pkgs/by-name/co/convos/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, perl, perlPackages, makeWrapper, shortenPerlShebang, openssl -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + perl, + perlPackages, + makeWrapper, + shortenPerlShebang, + openssl, + nixosTests, }: perlPackages.buildPerlPackage rec { @@ -13,15 +21,34 @@ perlPackages.buildPerlPackage rec { sha256 = "sha256-dBvXo8y4OMKcb0imgnnzoklnPN3YePHDvy5rIBOkTfs="; }; - nativeBuildInputs = [ makeWrapper ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ shortenPerlShebang ]; + nativeBuildInputs = [ + makeWrapper + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ shortenPerlShebang ]; buildInputs = with perlPackages; [ - CryptPassphrase CryptPassphraseArgon2 CryptPassphraseBcrypt - FileHomeDir FileReadBackwards HTTPAcceptLanguage SyntaxKeywordTry FutureAsyncAwait - IOSocketSSL IRCUtils JSONValidator LinkEmbedder ModuleInstall - Mojolicious MojoliciousPluginOpenAPI MojoliciousPluginSyslog ParseIRC - TextMarkdownHoedown TimePiece UnicodeUTF8 CpanelJSONXS EV YAMLLibYAML + CryptPassphrase + CryptPassphraseArgon2 + CryptPassphraseBcrypt + FileHomeDir + FileReadBackwards + HTTPAcceptLanguage + SyntaxKeywordTry + FutureAsyncAwait + IOSocketSSL + IRCUtils + JSONValidator + LinkEmbedder + ModuleInstall + Mojolicious + MojoliciousPluginOpenAPI + MojoliciousPluginSyslog + ParseIRC + TextMarkdownHoedown + TimePiece + UnicodeUTF8 + CpanelJSONXS + EV + YAMLLibYAML ]; propagatedBuildInputs = [ openssl ]; @@ -72,18 +99,21 @@ perlPackages.buildPerlPackage rec { # Convos expects to find assets in both auto/share/dist/Convos, and $MOJO_HOME # which is set to $out # - postInstall = '' - AUTO_SHARE_PATH=$out/${perl.libPrefix}/auto/share/dist/Convos - mkdir -p $AUTO_SHARE_PATH - cp -vR public assets $AUTO_SHARE_PATH/ - ln -s $AUTO_SHARE_PATH/public/assets $out/assets - cp -vR templates $out/templates - cp Makefile.PL $out/Makefile.PL - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - shortenPerlShebang $out/bin/convos - '' + '' - wrapProgram $out/bin/convos --set MOJO_HOME $out - ''; + postInstall = + '' + AUTO_SHARE_PATH=$out/${perl.libPrefix}/auto/share/dist/Convos + mkdir -p $AUTO_SHARE_PATH + cp -vR public assets $AUTO_SHARE_PATH/ + ln -s $AUTO_SHARE_PATH/public/assets $out/assets + cp -vR templates $out/templates + cp Makefile.PL $out/Makefile.PL + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + shortenPerlShebang $out/bin/convos + '' + + '' + wrapProgram $out/bin/convos --set MOJO_HOME $out + ''; passthru.tests = nixosTests.convos; diff --git a/pkgs/by-name/co/cook-cli/package.nix b/pkgs/by-name/co/cook-cli/package.nix index 846d3fb5277773..5990e30bfe5a5c 100644 --- a/pkgs/by-name/co/cook-cli/package.nix +++ b/pkgs/by-name/co/cook-cli/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildNpmPackage -, rustPlatform -, pkg-config -, openssl -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + buildNpmPackage, + rustPlatform, + pkg-config, + openssl, + darwin, }: rustPlatform.buildRustPackage rec { pname = "cook-cli"; @@ -20,7 +21,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-6lnURuE1cgNAniHl5ozXo1W3cLYYje7er+ZhvZDKdVg="; - nativeBuildInputs = [ pkg-config openssl ]; + nativeBuildInputs = [ + pkg-config + openssl + ]; buildInputs = [ openssl diff --git a/pkgs/by-name/co/cooper-hewitt/package.nix b/pkgs/by-name/co/cooper-hewitt/package.nix index 743c1ed8a6b869..a85b832f2d54db 100644 --- a/pkgs/by-name/co/cooper-hewitt/package.nix +++ b/pkgs/by-name/co/cooper-hewitt/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "cooper-hewitt"; diff --git a/pkgs/by-name/co/coordgenlibs/package.nix b/pkgs/by-name/co/coordgenlibs/package.nix index 4febe03ef04d91..a02ce722480f80 100644 --- a/pkgs/by-name/co/coordgenlibs/package.nix +++ b/pkgs/by-name/co/coordgenlibs/package.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, lib -, stdenv -, boost -, zlib -, cmake -, maeparser +{ + fetchFromGitHub, + lib, + stdenv, + boost, + zlib, + cmake, + maeparser, }: stdenv.mkDerivation (finalAttrs: { @@ -19,7 +20,11 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ boost zlib maeparser ]; + buildInputs = [ + boost + zlib + maeparser + ]; env = lib.optionalAttrs stdenv.cc.isClang { NIX_CFLAGS_COMPILE = "-Wno-unused-but-set-variable"; diff --git a/pkgs/by-name/co/coost/package.nix b/pkgs/by-name/co/coost/package.nix index 667fc74dab69d3..9b07ee0aca15f5 100644 --- a/pkgs/by-name/co/coost/package.nix +++ b/pkgs/by-name/co/coost/package.nix @@ -30,11 +30,17 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ cmake ]; buildInputs = lib.optional withCurl curl ++ lib.optional withOpenSSL openssl; - cmakeFlags = [ - "-DBUILD_SHARED_LIBS=ON" - ] ++ lib.optional withCurl "-DWITH_LIBCURL=ON" ++ lib.optional withOpenSSL "-DWITH_OPENSSL=ON"; + cmakeFlags = + [ + "-DBUILD_SHARED_LIBS=ON" + ] + ++ lib.optional withCurl "-DWITH_LIBCURL=ON" + ++ lib.optional withOpenSSL "-DWITH_OPENSSL=ON"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; passthru.updateScript = gitUpdater { }; meta = with lib; { diff --git a/pkgs/by-name/co/copier/package.nix b/pkgs/by-name/co/copier/package.nix index 382e4d574857f5..2bbec86bbdc6bf 100644 --- a/pkgs/by-name/co/copier/package.nix +++ b/pkgs/by-name/co/copier/package.nix @@ -1,7 +1,8 @@ -{ lib -, git -, python3 -, fetchFromGitHub +{ + lib, + git, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { @@ -49,7 +50,7 @@ python3.pkgs.buildPythonApplication rec { ]; makeWrapperArgs = [ - "--suffix PATH : ${lib.makeBinPath [ git ] }" + "--suffix PATH : ${lib.makeBinPath [ git ]}" ]; meta = with lib; { diff --git a/pkgs/by-name/co/copilot-cli/package.nix b/pkgs/by-name/co/copilot-cli/package.nix index b748b90cb7e9ad..a04f46bf5f4249 100644 --- a/pkgs/by-name/co/copilot-cli/package.nix +++ b/pkgs/by-name/co/copilot-cli/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, testers, copilot-cli }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + copilot-cli, +}: buildGoModule rec { pname = "copilot-cli"; diff --git a/pkgs/by-name/co/copper/package.nix b/pkgs/by-name/co/copper/package.nix index f202932743f1f1..d6b24177d291a1 100644 --- a/pkgs/by-name/co/copper/package.nix +++ b/pkgs/by-name/co/copper/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, libffi +{ + lib, + stdenv, + fetchurl, + libffi, }: stdenv.mkDerivation rec { pname = "copper"; diff --git a/pkgs/by-name/co/copyright-update/package.nix b/pkgs/by-name/co/copyright-update/package.nix index 72cecf1e9246ad..9ec1b850af2222 100644 --- a/pkgs/by-name/co/copyright-update/package.nix +++ b/pkgs/by-name/co/copyright-update/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation rec { pname = "copyright-update"; @@ -14,7 +19,10 @@ stdenv.mkDerivation rec { buildInputs = [ perl ]; - installFlags = [ "INSTALL=install" "prefix=$(out)" ]; + installFlags = [ + "INSTALL=install" + "prefix=$(out)" + ]; meta = with lib; { homepage = "https://github.com/jaalto/project--copyright-update"; diff --git a/pkgs/by-name/co/coq2html/package.nix b/pkgs/by-name/co/coq2html/package.nix index 049a48089aea64..5768962265cd98 100644 --- a/pkgs/by-name/co/coq2html/package.nix +++ b/pkgs/by-name/co/coq2html/package.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, ocaml }: +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, +}: -stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "coq2html"; version = "1.4"; @@ -30,7 +35,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://github.com/xavierleroy/coq2html"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ jwiegley siraben ]; + maintainers = with maintainers; [ + jwiegley + siraben + ]; platforms = platforms.unix; mainProgram = "coq2html"; }; diff --git a/pkgs/by-name/co/cordless/package.nix b/pkgs/by-name/co/cordless/package.nix index 35c2c0dbffb311..af2729c9db6bd6 100644 --- a/pkgs/by-name/co/cordless/package.nix +++ b/pkgs/by-name/co/cordless/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "cordless"; diff --git a/pkgs/by-name/co/cordova/package.nix b/pkgs/by-name/co/cordova/package.nix index 0a4fec58c2c56d..394fc87059ac19 100644 --- a/pkgs/by-name/co/cordova/package.nix +++ b/pkgs/by-name/co/cordova/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/co/corefonts/package.nix b/pkgs/by-name/co/corefonts/package.nix index f2c9533b01fc32..b58089d1ad3319 100644 --- a/pkgs/by-name/co/corefonts/package.nix +++ b/pkgs/by-name/co/corefonts/package.nix @@ -1,19 +1,60 @@ -{ lib, stdenv, fetchurl, cabextract }: +{ + lib, + stdenv, + fetchurl, + cabextract, +}: let fonts = [ - { name = "andale"; hash = "sha256-BST+QpUa3Dp+uHDjLwkgMTxx8XDIWbX3cNgrTuER6XA="; } - { name = "arial"; hash = "sha256-hSl6TRRunIesb3SCJzS97l9LKnItfqpYS38sv3b0ePY="; } - { name = "arialb"; hash = "sha256-pCXw/7ahpe3luXntYXf09PT972rnwwKnt3IO8zL+wKg="; } - { name = "comic"; hash = "sha256-nG3z/u/eJtTkHUpP5dsqifkSOncllNf1mv0GJiXNIE4="; } - { name = "courie"; hash = "sha256-u1EdhhZV3eh5rlUuuGsTTW+uZ8tYUC5v9z7F2RUfM4Q="; } - { name = "georgi"; hash = "sha256-LCx9zaZgbqXPCJGPt80/M1np6EM43GkAE/IM1C6TAwE="; } - { name = "impact"; hash = "sha256-YGHvO3QB2WQvXf218rN2qhRmP2J15gpRIHrU+s8vzPs="; } - { name = "times"; hash = "sha256-21ZZXsbvXT3lwkmU8AHwOyoT43zuJ7wlxY9vQ+j4B6s="; } - { name = "trebuc"; hash = "sha256-WmkNm7hRC+G4tP5J8fIxllH+UbvlR3Xd3djvC9B/2sk="; } - { name = "webdin"; hash = "sha256-ZFlbWrwQgPuoYQxcNPq1hjQI6Aaq/oRlPKhXW+0X11o="; } - { name = "verdan"; hash = "sha256-wcthJV42MWZ5TkdmTi8hr446JstjRuuNKuL6hd1arZY="; } - { name = "wd97vwr"; hash = "sha256-9hEmptF7LRJqfzGxQlBNzkk095icVfHBPGR3s/6As9I="; } + { + name = "andale"; + hash = "sha256-BST+QpUa3Dp+uHDjLwkgMTxx8XDIWbX3cNgrTuER6XA="; + } + { + name = "arial"; + hash = "sha256-hSl6TRRunIesb3SCJzS97l9LKnItfqpYS38sv3b0ePY="; + } + { + name = "arialb"; + hash = "sha256-pCXw/7ahpe3luXntYXf09PT972rnwwKnt3IO8zL+wKg="; + } + { + name = "comic"; + hash = "sha256-nG3z/u/eJtTkHUpP5dsqifkSOncllNf1mv0GJiXNIE4="; + } + { + name = "courie"; + hash = "sha256-u1EdhhZV3eh5rlUuuGsTTW+uZ8tYUC5v9z7F2RUfM4Q="; + } + { + name = "georgi"; + hash = "sha256-LCx9zaZgbqXPCJGPt80/M1np6EM43GkAE/IM1C6TAwE="; + } + { + name = "impact"; + hash = "sha256-YGHvO3QB2WQvXf218rN2qhRmP2J15gpRIHrU+s8vzPs="; + } + { + name = "times"; + hash = "sha256-21ZZXsbvXT3lwkmU8AHwOyoT43zuJ7wlxY9vQ+j4B6s="; + } + { + name = "trebuc"; + hash = "sha256-WmkNm7hRC+G4tP5J8fIxllH+UbvlR3Xd3djvC9B/2sk="; + } + { + name = "webdin"; + hash = "sha256-ZFlbWrwQgPuoYQxcNPq1hjQI6Aaq/oRlPKhXW+0X11o="; + } + { + name = "verdan"; + hash = "sha256-wcthJV42MWZ5TkdmTi8hr446JstjRuuNKuL6hd1arZY="; + } + { + name = "wd97vwr"; + hash = "sha256-9hEmptF7LRJqfzGxQlBNzkk095icVfHBPGR3s/6As9I="; + } ]; eula = fetchurl { @@ -25,10 +66,13 @@ stdenv.mkDerivation { pname = "corefonts"; version = "1"; - exes = map ({name, hash}: fetchurl { - url = "mirror://sourceforge/corefonts/the%20fonts/final/${name}32.exe"; - inherit hash; - }) fonts; + exes = map ( + { name, hash }: + fetchurl { + url = "mirror://sourceforge/corefonts/the%20fonts/final/${name}32.exe"; + inherit hash; + } + ) fonts; nativeBuildInputs = [ cabextract ]; diff --git a/pkgs/by-name/co/coreth/package.nix b/pkgs/by-name/co/coreth/package.nix index 242c6da0424c25..9cdb4bdbde9c30 100644 --- a/pkgs/by-name/co/coreth/package.nix +++ b/pkgs/by-name/co/coreth/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/co/corkscrew/package.nix b/pkgs/by-name/co/corkscrew/package.nix index 6c433981aeb335..1fb800d9f4dec5 100644 --- a/pkgs/by-name/co/corkscrew/package.nix +++ b/pkgs/by-name/co/corkscrew/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "corkscrew"; @@ -20,4 +25,3 @@ stdenv.mkDerivation rec { mainProgram = "corkscrew"; }; } - diff --git a/pkgs/by-name/co/corrosion/package.nix b/pkgs/by-name/co/corrosion/package.nix index 500e56e9cfcc6e..cec87380364b59 100644 --- a/pkgs/by-name/co/corrosion/package.nix +++ b/pkgs/by-name/co/corrosion/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cargo -, cmake -, rustc -, libiconv +{ + lib, + stdenv, + fetchFromGitHub, + cargo, + cmake, + rustc, + libiconv, }: stdenv.mkDerivation rec { @@ -28,23 +29,25 @@ stdenv.mkDerivation rec { doCheck = true; - checkPhase = let - excludedTests = [ - "cbindgen_rust2cpp_build" - "cbindgen_rust2cpp_run_cpp-exe" - "hostbuild_build" - "hostbuild_run_rust-host-program" - "parse_target_triple_build" - "rustup_proxy_build" - ]; - excludedTestsRegex = lib.concatStringsSep "|" excludedTests; - in '' - runHook preCheck - - ctest -E "${excludedTestsRegex}" - - runHook postCheck - ''; + checkPhase = + let + excludedTests = [ + "cbindgen_rust2cpp_build" + "cbindgen_rust2cpp_run_cpp-exe" + "hostbuild_build" + "hostbuild_run_rust-host-program" + "parse_target_triple_build" + "rustup_proxy_build" + ]; + excludedTestsRegex = lib.concatStringsSep "|" excludedTests; + in + '' + runHook preCheck + + ctest -E "${excludedTestsRegex}" + + runHook postCheck + ''; meta = with lib; { description = "Tool for integrating Rust into an existing CMake project"; diff --git a/pkgs/by-name/co/corrscope/package.nix b/pkgs/by-name/co/corrscope/package.nix index 97751960af61ed..34f72de0c145d5 100644 --- a/pkgs/by-name/co/corrscope/package.nix +++ b/pkgs/by-name/co/corrscope/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, python3Packages -, fetchFromGitHub -, ffmpeg -, libsForQt5 -, testers -, corrscope +{ + stdenv, + lib, + python3Packages, + fetchFromGitHub, + ffmpeg, + libsForQt5, + testers, + corrscope, }: python3Packages.buildPythonApplication rec { @@ -20,21 +21,32 @@ python3Packages.buildPythonApplication rec { hash = "sha256-WSv65jEu/w6iNrL/f5PN147FBjmR0j30H1D39dd+KN8="; }; - pythonRelaxDeps = [ "attrs" "ruamel.yaml" ]; + pythonRelaxDeps = [ + "attrs" + "ruamel.yaml" + ]; - nativeBuildInputs = (with libsForQt5; [ - wrapQtAppsHook - ]) ++ (with python3Packages; [ - poetry-core - ]); + nativeBuildInputs = + (with libsForQt5; [ + wrapQtAppsHook + ]) + ++ (with python3Packages; [ + poetry-core + ]); - buildInputs = [ - ffmpeg - ] ++ (with libsForQt5; [ - qtbase - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qtwayland - ]); + buildInputs = + [ + ffmpeg + ] + ++ ( + with libsForQt5; + [ + qtbase + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qtwayland + ] + ); propagatedBuildInputs = with python3Packages; [ appdirs diff --git a/pkgs/by-name/co/corrupter/package.nix b/pkgs/by-name/co/corrupter/package.nix index bd70ddaf44bba7..161727916ff1a3 100644 --- a/pkgs/by-name/co/corrupter/package.nix +++ b/pkgs/by-name/co/corrupter/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, unstableGitUpdater +{ + lib, + buildGoModule, + fetchFromGitHub, + unstableGitUpdater, }: buildGoModule { diff --git a/pkgs/by-name/co/corsix-th/package.nix b/pkgs/by-name/co/corsix-th/package.nix index fd5260679ce786..9d6a78b361a442 100644 --- a/pkgs/by-name/co/corsix-th/package.nix +++ b/pkgs/by-name/co/corsix-th/package.nix @@ -1,24 +1,25 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, curl -, doxygen -, ffmpeg -, freetype -, lua -, makeWrapper -, SDL2 -, SDL2_mixer -, timidity -# Darwin dependencies -, libiconv -, apple-sdk_11 -# Update -, nix-update-script +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + curl, + doxygen, + ffmpeg, + freetype, + lua, + makeWrapper, + SDL2, + SDL2_mixer, + timidity, + # Darwin dependencies + libiconv, + apple-sdk_11, + # Update + nix-update-script, }: -stdenv.mkDerivation(finalAttrs: { +stdenv.mkDerivation (finalAttrs: { pname = "corsix-th"; version = "0.68.0"; @@ -33,34 +34,50 @@ stdenv.mkDerivation(finalAttrs: { ./darwin-cmake-no-fixup-bundle.patch ]; - nativeBuildInputs = [ cmake doxygen makeWrapper ]; + nativeBuildInputs = [ + cmake + doxygen + makeWrapper + ]; - buildInputs = let - luaEnv = lua.withPackages(p: with p; [ luafilesystem lpeg luasec luasocket ]); - in [ - curl - ffmpeg - freetype - lua - luaEnv - SDL2 - SDL2_mixer - timidity - ] ++ lib.optional stdenv.hostPlatform.isDarwin apple-sdk_11; + buildInputs = + let + luaEnv = lua.withPackages ( + p: with p; [ + luafilesystem + lpeg + luasec + luasocket + ] + ); + in + [ + curl + ffmpeg + freetype + lua + luaEnv + SDL2 + SDL2_mixer + timidity + ] + ++ lib.optional stdenv.hostPlatform.isDarwin apple-sdk_11; cmakeFlags = [ "-Wno-dev" ]; - postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' - wrapProgram $out/bin/corsix-th \ - --set LUA_PATH "$LUA_PATH" \ - --set LUA_CPATH "$LUA_CPATH" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/Applications - mv $out/CorsixTH.app $out/Applications - wrapProgram $out/Applications/CorsixTH.app/Contents/MacOS/CorsixTH \ + postInstall = + lib.optionalString stdenv.hostPlatform.isLinux '' + wrapProgram $out/bin/corsix-th \ --set LUA_PATH "$LUA_PATH" \ --set LUA_CPATH "$LUA_CPATH" - ''; + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/Applications + mv $out/CorsixTH.app $out/Applications + wrapProgram $out/Applications/CorsixTH.app/Contents/MacOS/CorsixTH \ + --set LUA_PATH "$LUA_PATH" \ + --set LUA_CPATH "$LUA_CPATH" + ''; passthru.updateScript = nix-update-script { }; @@ -69,7 +86,10 @@ stdenv.mkDerivation(finalAttrs: { mainProgram = "corsix-th"; homepage = "https://corsixth.com/"; license = licenses.mit; - maintainers = with maintainers; [ hughobrien matteopacini ]; + maintainers = with maintainers; [ + hughobrien + matteopacini + ]; platforms = platforms.linux ++ platforms.darwin; }; }) diff --git a/pkgs/by-name/co/cosmic-applets/package.nix b/pkgs/by-name/co/cosmic-applets/package.nix index 43d340484bc849..5a4a0522f8bae0 100644 --- a/pkgs/by-name/co/cosmic-applets/package.nix +++ b/pkgs/by-name/co/cosmic-applets/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, just -, pkg-config -, udev -, util-linuxMinimal -, dbus -, glib -, libinput -, libxkbcommon -, pulseaudio -, wayland +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + just, + pkg-config, + udev, + util-linuxMinimal, + dbus, + glib, + libinput, + libxkbcommon, + pulseaudio, + wayland, }: rustPlatform.buildRustPackage rec { @@ -28,29 +29,49 @@ rustPlatform.buildRustPackage rec { useFetchCargoVendor = true; cargoHash = "sha256-f5OV//qzWQqIvq8BNtd2H1dWl7aqR0WJwmdimL4wcKQ="; - nativeBuildInputs = [ just pkg-config util-linuxMinimal ]; - buildInputs = [ dbus glib libinput libxkbcommon pulseaudio wayland udev ]; + nativeBuildInputs = [ + just + pkg-config + util-linuxMinimal + ]; + buildInputs = [ + dbus + glib + libinput + libxkbcommon + pulseaudio + wayland + udev + ]; dontUseJustBuild = true; justFlags = [ - "--set" "prefix" (placeholder "out") - "--set" "target" "${stdenv.hostPlatform.rust.cargoShortTarget}/release" + "--set" + "prefix" + (placeholder "out") + "--set" + "target" + "${stdenv.hostPlatform.rust.cargoShortTarget}/release" ]; # Force linking to libwayland-client, which is always dlopen()ed. "CARGO_TARGET_${stdenv.hostPlatform.rust.cargoEnvVarTarget}_RUSTFLAGS" = - map (a: "-C link-arg=${a}") [ - "-Wl,--push-state,--no-as-needed" - "-lwayland-client" - "-Wl,--pop-state" - ]; + map (a: "-C link-arg=${a}") + [ + "-Wl,--push-state,--no-as-needed" + "-lwayland-client" + "-Wl,--pop-state" + ]; meta = with lib; { homepage = "https://github.com/pop-os/cosmic-applets"; description = "Applets for the COSMIC Desktop Environment"; license = licenses.gpl3Only; - maintainers = with maintainers; [ qyliss nyabinary ]; + maintainers = with maintainers; [ + qyliss + nyabinary + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/co/cosmic-applibrary/package.nix b/pkgs/by-name/co/cosmic-applibrary/package.nix index 792026af21ddc6..0dd7624df4ed15 100644 --- a/pkgs/by-name/co/cosmic-applibrary/package.nix +++ b/pkgs/by-name/co/cosmic-applibrary/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, stdenv -, rustPlatform -, just -, pkg-config -, makeBinaryWrapper -, libxkbcommon -, wayland +{ + lib, + fetchFromGitHub, + stdenv, + rustPlatform, + just, + pkg-config, + makeBinaryWrapper, + libxkbcommon, + wayland, }: rustPlatform.buildRustPackage rec { pname = "cosmic-applibrary"; diff --git a/pkgs/by-name/co/cosmic-bg/package.nix b/pkgs/by-name/co/cosmic-bg/package.nix index e3d162d471ba2a..627247a66e8bfb 100644 --- a/pkgs/by-name/co/cosmic-bg/package.nix +++ b/pkgs/by-name/co/cosmic-bg/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, just -, pkg-config -, makeBinaryWrapper -, libxkbcommon -, wayland +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + just, + pkg-config, + makeBinaryWrapper, + libxkbcommon, + wayland, }: rustPlatform.buildRustPackage rec { @@ -27,8 +28,15 @@ rustPlatform.buildRustPackage rec { substituteInPlace justfile --replace-fail '#!/usr/bin/env' "#!$(command -v env)" ''; - nativeBuildInputs = [ just pkg-config makeBinaryWrapper ]; - buildInputs = [ libxkbcommon wayland ]; + nativeBuildInputs = [ + just + pkg-config + makeBinaryWrapper + ]; + buildInputs = [ + libxkbcommon + wayland + ]; dontUseJustBuild = true; @@ -43,7 +51,7 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram $out/bin/cosmic-bg \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [wayland]}" + --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ wayland ]}" ''; meta = with lib; { diff --git a/pkgs/by-name/co/cosmic-comp/package.nix b/pkgs/by-name/co/cosmic-comp/package.nix index 065a0f4b006f2c..e053b88b4d66fb 100644 --- a/pkgs/by-name/co/cosmic-comp/package.nix +++ b/pkgs/by-name/co/cosmic-comp/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, makeBinaryWrapper -, pixman -, pkg-config -, libinput -, libglvnd -, libxkbcommon -, mesa -, seatd -, udev -, xwayland -, wayland -, xorg -, useXWayland ? true -, systemd -, useSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + makeBinaryWrapper, + pixman, + pkg-config, + libinput, + libglvnd, + libxkbcommon, + mesa, + seatd, + udev, + xwayland, + wayland, + xorg, + useXWayland ? true, + systemd, + useSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, }: rustPlatform.buildRustPackage rec { @@ -35,17 +36,20 @@ rustPlatform.buildRustPackage rec { separateDebugInfo = true; - nativeBuildInputs = [ makeBinaryWrapper pkg-config ]; + nativeBuildInputs = [ + makeBinaryWrapper + pkg-config + ]; buildInputs = [ - libglvnd - libinput - libxkbcommon - mesa - pixman - seatd - udev - wayland - ] ++ lib.optional useSystemd systemd; + libglvnd + libinput + libxkbcommon + mesa + pixman + seatd + udev + wayland + ] ++ lib.optional useSystemd systemd; # Only default feature is systemd buildNoDefaultFeatures = !useSystemd; @@ -69,22 +73,32 @@ rustPlatform.buildRustPackage rec { # These libraries are only used by the X11 backend, which will not # be the common case, so just make them available, don't link them. - postInstall = '' - wrapProgramArgs=(--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ - xorg.libX11 xorg.libXcursor xorg.libXi - ]}) - '' + lib.optionalString useXWayland '' - wrapProgramArgs+=(--prefix PATH : ${lib.makeBinPath [ xwayland ]}) - '' + '' - wrapProgram $out/bin/cosmic-comp "''${wrapProgramArgs[@]}" - ''; + postInstall = + '' + wrapProgramArgs=(--prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + xorg.libX11 + xorg.libXcursor + xorg.libXi + ] + }) + '' + + lib.optionalString useXWayland '' + wrapProgramArgs+=(--prefix PATH : ${lib.makeBinPath [ xwayland ]}) + '' + + '' + wrapProgram $out/bin/cosmic-comp "''${wrapProgramArgs[@]}" + ''; meta = with lib; { homepage = "https://github.com/pop-os/cosmic-comp"; description = "Compositor for the COSMIC Desktop Environment"; mainProgram = "cosmic-comp"; license = licenses.gpl3Only; - maintainers = with maintainers; [ qyliss nyabinary ]; + maintainers = with maintainers; [ + qyliss + nyabinary + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/co/cosmic-design-demo/package.nix b/pkgs/by-name/co/cosmic-design-demo/package.nix index 241f8c7b310f38..2f003b482f2ffe 100644 --- a/pkgs/by-name/co/cosmic-design-demo/package.nix +++ b/pkgs/by-name/co/cosmic-design-demo/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, cmake -, just -, pkg-config -, expat -, libxkbcommon -, fontconfig -, freetype -, wayland -, makeBinaryWrapper -, cosmic-icons +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + cmake, + just, + pkg-config, + expat, + libxkbcommon, + fontconfig, + freetype, + wayland, + makeBinaryWrapper, + cosmic-icons, }: rustPlatform.buildRustPackage rec { @@ -28,8 +29,19 @@ rustPlatform.buildRustPackage rec { useFetchCargoVendor = true; cargoHash = "sha256-czfDtiSEmzmcLfpqv0/8sP8zDAEKh+pkQkGXdd5NskM="; - nativeBuildInputs = [ cmake just pkg-config makeBinaryWrapper ]; - buildInputs = [ libxkbcommon expat fontconfig freetype wayland ]; + nativeBuildInputs = [ + cmake + just + pkg-config + makeBinaryWrapper + ]; + buildInputs = [ + libxkbcommon + expat + fontconfig + freetype + wayland + ]; dontUseJustBuild = true; @@ -45,7 +57,7 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram "$out/bin/cosmic-design-demo" \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [wayland]}" \ + --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ wayland ]}" \ --suffix XDG_DATA_DIRS : "${cosmic-icons}/share" ''; diff --git a/pkgs/by-name/co/cosmic-edit/package.nix b/pkgs/by-name/co/cosmic-edit/package.nix index cd4d2aa7ac816c..bab9cc12d303a8 100644 --- a/pkgs/by-name/co/cosmic-edit/package.nix +++ b/pkgs/by-name/co/cosmic-edit/package.nix @@ -41,7 +41,11 @@ rustPlatform.buildRustPackage rec { substituteInPlace justfile --replace '#!/usr/bin/env' "#!$(command -v env)" ''; - nativeBuildInputs = [ just pkg-config makeBinaryWrapper ]; + nativeBuildInputs = [ + just + pkg-config + makeBinaryWrapper + ]; buildInputs = [ libxkbcommon xorg.libX11 @@ -79,9 +83,16 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram "$out/bin/cosmic-edit" \ --suffix XDG_DATA_DIRS : "${cosmic-icons}/share" \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ - xorg.libX11 xorg.libXcursor xorg.libXi vulkan-loader libxkbcommon wayland - ]} + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + xorg.libX11 + xorg.libXcursor + xorg.libXi + vulkan-loader + libxkbcommon + wayland + ] + } ''; meta = with lib; { @@ -89,7 +100,10 @@ rustPlatform.buildRustPackage rec { description = "Text Editor for the COSMIC Desktop Environment"; mainProgram = "cosmic-edit"; license = licenses.gpl3Only; - maintainers = with maintainers; [ ahoneybun nyabinary ]; + maintainers = with maintainers; [ + ahoneybun + nyabinary + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/co/cosmic-files/package.nix b/pkgs/by-name/co/cosmic-files/package.nix index 39c285b62613f6..350071d1f6259d 100644 --- a/pkgs/by-name/co/cosmic-files/package.nix +++ b/pkgs/by-name/co/cosmic-files/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, makeBinaryWrapper -, cosmic-icons -, just -, pkg-config -, glib -, libxkbcommon -, wayland -, xorg +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + makeBinaryWrapper, + cosmic-icons, + just, + pkg-config, + glib, + libxkbcommon, + wayland, + xorg, }: rustPlatform.buildRustPackage rec { @@ -35,8 +36,16 @@ rustPlatform.buildRustPackage rec { substituteInPlace justfile --replace '#!/usr/bin/env' "#!$(command -v env)" ''; - nativeBuildInputs = [ just pkg-config makeBinaryWrapper ]; - buildInputs = [ glib libxkbcommon wayland ]; + nativeBuildInputs = [ + just + pkg-config + makeBinaryWrapper + ]; + buildInputs = [ + glib + libxkbcommon + wayland + ]; dontUseJustBuild = true; @@ -53,14 +62,25 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram "$out/bin/cosmic-files" \ --suffix XDG_DATA_DIRS : "${cosmic-icons}/share" \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ xorg.libX11 xorg.libXcursor xorg.libXrandr xorg.libXi wayland ]} + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + xorg.libX11 + xorg.libXcursor + xorg.libXrandr + xorg.libXi + wayland + ] + } ''; meta = with lib; { homepage = "https://github.com/pop-os/cosmic-files"; description = "File Manager for the COSMIC Desktop Environment"; license = licenses.gpl3Only; - maintainers = with maintainers; [ ahoneybun nyabinary ]; + maintainers = with maintainers; [ + ahoneybun + nyabinary + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/co/cosmic-greeter/package.nix b/pkgs/by-name/co/cosmic-greeter/package.nix index fef6608dc6b975..b6c1d204c40ee9 100644 --- a/pkgs/by-name/co/cosmic-greeter/package.nix +++ b/pkgs/by-name/co/cosmic-greeter/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, cmake -, coreutils -, just -, libinput -, libxkbcommon -, linux-pam -, pkg-config -, udev -, wayland +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + cmake, + coreutils, + just, + libinput, + libxkbcommon, + linux-pam, + pkg-config, + udev, + wayland, }: rustPlatform.buildRustPackage rec { @@ -31,8 +32,19 @@ rustPlatform.buildRustPackage rec { "--all" ]; - nativeBuildInputs = [ rustPlatform.bindgenHook cmake just pkg-config ]; - buildInputs = [ libinput libxkbcommon linux-pam udev wayland ]; + nativeBuildInputs = [ + rustPlatform.bindgenHook + cmake + just + pkg-config + ]; + buildInputs = [ + libinput + libxkbcommon + linux-pam + udev + wayland + ]; dontUseJustBuild = true; diff --git a/pkgs/by-name/co/cosmic-launcher/package.nix b/pkgs/by-name/co/cosmic-launcher/package.nix index f04ab30a2a28d3..58dd4db3aa978b 100644 --- a/pkgs/by-name/co/cosmic-launcher/package.nix +++ b/pkgs/by-name/co/cosmic-launcher/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, just -, pkg-config -, makeBinaryWrapper -, libxkbcommon -, wayland -, appstream-glib -, desktop-file-utils -, intltool +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + just, + pkg-config, + makeBinaryWrapper, + libxkbcommon, + wayland, + appstream-glib, + desktop-file-utils, + intltool, }: rustPlatform.buildRustPackage rec { @@ -26,8 +27,18 @@ rustPlatform.buildRustPackage rec { useFetchCargoVendor = true; cargoHash = "sha256-bHJUsXHnPH6aV2vTQv1Cdx+p4/Pplg6HMguw5BK9qJ8="; - nativeBuildInputs = [ just pkg-config makeBinaryWrapper ]; - buildInputs = [ libxkbcommon wayland appstream-glib desktop-file-utils intltool ]; + nativeBuildInputs = [ + just + pkg-config + makeBinaryWrapper + ]; + buildInputs = [ + libxkbcommon + wayland + appstream-glib + desktop-file-utils + intltool + ]; dontUseJustBuild = true; @@ -46,7 +57,7 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram $out/bin/cosmic-launcher \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [wayland]}" + --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ wayland ]}" ''; RUSTFLAGS = "--cfg tokio_unstable"; diff --git a/pkgs/by-name/co/cosmic-notifications/package.nix b/pkgs/by-name/co/cosmic-notifications/package.nix index 3a4db2e74269be..c27427c89c7822 100644 --- a/pkgs/by-name/co/cosmic-notifications/package.nix +++ b/pkgs/by-name/co/cosmic-notifications/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, just -, which -, pkg-config -, makeBinaryWrapper -, libxkbcommon -, wayland -, appstream-glib -, desktop-file-utils -, intltool +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + just, + which, + pkg-config, + makeBinaryWrapper, + libxkbcommon, + wayland, + appstream-glib, + desktop-file-utils, + intltool, }: rustPlatform.buildRustPackage rec { @@ -31,8 +32,19 @@ rustPlatform.buildRustPackage rec { substituteInPlace justfile --replace-fail '#!/usr/bin/env' "#!$(command -v env)" ''; - nativeBuildInputs = [ just which pkg-config makeBinaryWrapper ]; - buildInputs = [ libxkbcommon wayland appstream-glib desktop-file-utils intltool ]; + nativeBuildInputs = [ + just + which + pkg-config + makeBinaryWrapper + ]; + buildInputs = [ + libxkbcommon + wayland + appstream-glib + desktop-file-utils + intltool + ]; dontUseJustBuild = true; @@ -47,7 +59,7 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram $out/bin/cosmic-notifications \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [wayland]}" + --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ wayland ]}" ''; meta = with lib; { diff --git a/pkgs/by-name/co/cosmic-osd/package.nix b/pkgs/by-name/co/cosmic-osd/package.nix index a3cf2b700d3fce..005826ba40b6b5 100644 --- a/pkgs/by-name/co/cosmic-osd/package.nix +++ b/pkgs/by-name/co/cosmic-osd/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, libxkbcommon -, pulseaudio -, udev -, wayland +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + libxkbcommon, + pulseaudio, + udev, + wayland, }: rustPlatform.buildRustPackage rec { @@ -23,7 +24,12 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Db1a1FusUdO7rQb0jfznaFNaJjdS9XSDGCMuzV1D79A="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libxkbcommon pulseaudio wayland udev ]; + buildInputs = [ + libxkbcommon + pulseaudio + wayland + udev + ]; env.POLKIT_AGENT_HELPER_1 = "/run/wrappers/bin/polkit-agent-helper-1"; diff --git a/pkgs/by-name/co/cosmic-panel/package.nix b/pkgs/by-name/co/cosmic-panel/package.nix index 1ec02b9a3f8a2e..f7502bca95a21f 100644 --- a/pkgs/by-name/co/cosmic-panel/package.nix +++ b/pkgs/by-name/co/cosmic-panel/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, just -, pkg-config -, rust -, rustPlatform -, libglvnd -, libxkbcommon -, wayland +{ + lib, + stdenv, + fetchFromGitHub, + just, + pkg-config, + rust, + rustPlatform, + libglvnd, + libxkbcommon, + wayland, }: rustPlatform.buildRustPackage { @@ -24,30 +25,45 @@ rustPlatform.buildRustPackage { useFetchCargoVendor = true; cargoHash = "sha256-1XtW72KPdRM5gHIM3Fw2PZCobBXYDMAqjZ//Ebr51tc="; - nativeBuildInputs = [ just pkg-config ]; - buildInputs = [ libglvnd libxkbcommon wayland ]; + nativeBuildInputs = [ + just + pkg-config + ]; + buildInputs = [ + libglvnd + libxkbcommon + wayland + ]; dontUseJustBuild = true; justFlags = [ - "--set" "prefix" (placeholder "out") - "--set" "bin-src" "target/${stdenv.hostPlatform.rust.cargoShortTarget}/release/cosmic-panel" + "--set" + "prefix" + (placeholder "out") + "--set" + "bin-src" + "target/${stdenv.hostPlatform.rust.cargoShortTarget}/release/cosmic-panel" ]; # Force linking to libEGL, which is always dlopen()ed. "CARGO_TARGET_${stdenv.hostPlatform.rust.cargoEnvVarTarget}_RUSTFLAGS" = - map (a: "-C link-arg=${a}") [ - "-Wl,--push-state,--no-as-needed" - "-lEGL" - "-Wl,--pop-state" - ]; + map (a: "-C link-arg=${a}") + [ + "-Wl,--push-state,--no-as-needed" + "-lEGL" + "-Wl,--pop-state" + ]; meta = with lib; { homepage = "https://github.com/pop-os/cosmic-panel"; description = "Panel for the COSMIC Desktop Environment"; mainProgram = "cosmic-panel"; license = licenses.gpl3Only; - maintainers = with maintainers; [ qyliss nyabinary ]; + maintainers = with maintainers; [ + qyliss + nyabinary + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/co/cosmic-protocols/package.nix b/pkgs/by-name/co/cosmic-protocols/package.nix index f4ba351d5c456d..ab312107546a0d 100644 --- a/pkgs/by-name/co/cosmic-protocols/package.nix +++ b/pkgs/by-name/co/cosmic-protocols/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, stdenv -, wayland-scanner +{ + lib, + fetchFromGitHub, + stdenv, + wayland-scanner, }: stdenv.mkDerivation rec { @@ -21,7 +22,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/pop-os/cosmic-protocols"; description = "Additional wayland-protocols used by the COSMIC desktop environment"; - license = [ licenses.mit licenses.gpl3Only ]; + license = [ + licenses.mit + licenses.gpl3Only + ]; maintainers = with maintainers; [ nyabinary ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/co/cosmic-randr/package.nix b/pkgs/by-name/co/cosmic-randr/package.nix index db4fe5df9524a3..d898ae8733fd18 100644 --- a/pkgs/by-name/co/cosmic-randr/package.nix +++ b/pkgs/by-name/co/cosmic-randr/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, just -, pkg-config -, wayland +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + just, + pkg-config, + wayland, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage rec { useFetchCargoVendor = true; cargoHash = "sha256-S5zvh/pJA3JMwQ3K5RPPHuHKLQA9g1Ae7NLWgy9b5FA="; - nativeBuildInputs = [ just pkg-config ]; + nativeBuildInputs = [ + just + pkg-config + ]; buildInputs = [ wayland ]; dontUseJustBuild = true; diff --git a/pkgs/by-name/co/cosmic-screenshot/package.nix b/pkgs/by-name/co/cosmic-screenshot/package.nix index 0319585a0449ef..fb6a4218ada143 100644 --- a/pkgs/by-name/co/cosmic-screenshot/package.nix +++ b/pkgs/by-name/co/cosmic-screenshot/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, just -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + just, + pkg-config, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-fzIVyxzNknEjGJoR9sgXkY+gyuTC0T4Sy513X8umbWA="; - nativeBuildInputs = [ just pkg-config ]; + nativeBuildInputs = [ + just + pkg-config + ]; dontUseJustBuild = true; diff --git a/pkgs/by-name/co/cosmic-settings/package.nix b/pkgs/by-name/co/cosmic-settings/package.nix index 25803cca9b8b95..05d77af668b846 100644 --- a/pkgs/by-name/co/cosmic-settings/package.nix +++ b/pkgs/by-name/co/cosmic-settings/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, cmake -, makeBinaryWrapper -, cosmic-icons -, cosmic-randr -, just -, pkg-config -, libxkbcommon -, libinput -, fontconfig -, freetype -, wayland -, expat -, udev -, util-linux +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + cmake, + makeBinaryWrapper, + cosmic-icons, + cosmic-randr, + just, + pkg-config, + libxkbcommon, + libinput, + fontconfig, + freetype, + wayland, + expat, + udev, + util-linux, }: rustPlatform.buildRustPackage rec { @@ -36,8 +37,22 @@ rustPlatform.buildRustPackage rec { substituteInPlace justfile --replace '#!/usr/bin/env' "#!$(command -v env)" ''; - nativeBuildInputs = [ cmake just pkg-config makeBinaryWrapper ]; - buildInputs = [ libxkbcommon libinput fontconfig freetype wayland expat udev util-linux ]; + nativeBuildInputs = [ + cmake + just + pkg-config + makeBinaryWrapper + ]; + buildInputs = [ + libxkbcommon + libinput + fontconfig + freetype + wayland + expat + udev + util-linux + ]; dontUseJustBuild = true; diff --git a/pkgs/by-name/co/cosmic-store/package.nix b/pkgs/by-name/co/cosmic-store/package.nix index e513de50d1ca98..a5e1d0ed5d9dc7 100644 --- a/pkgs/by-name/co/cosmic-store/package.nix +++ b/pkgs/by-name/co/cosmic-store/package.nix @@ -1,7 +1,26 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, appstream, makeBinaryWrapper -, cosmic-icons, glib, just, pkg-config, libglvnd, libxkbcommon, libinput -, fontconfig, flatpak, freetype, openssl, wayland, xorg, vulkan-loader -, vulkan-validation-layers, }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + appstream, + makeBinaryWrapper, + cosmic-icons, + glib, + just, + pkg-config, + libglvnd, + libxkbcommon, + libinput, + fontconfig, + flatpak, + freetype, + openssl, + wayland, + xorg, + vulkan-loader, + vulkan-validation-layers, +}: rustPlatform.buildRustPackage rec { pname = "cosmic-store"; @@ -22,7 +41,11 @@ rustPlatform.buildRustPackage rec { substituteInPlace justfile --replace '#!/usr/bin/env' "#!$(command -v env)" ''; - nativeBuildInputs = [ just pkg-config makeBinaryWrapper ]; + nativeBuildInputs = [ + just + pkg-config + makeBinaryWrapper + ]; buildInputs = [ appstream glib @@ -80,7 +103,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/pop-os/cosmic-store"; description = "App Store for the COSMIC Desktop Environment"; license = licenses.gpl3Only; - maintainers = with maintainers; [ ahoneybun nyabinary ]; + maintainers = with maintainers; [ + ahoneybun + nyabinary + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/co/cosmic-term/package.nix b/pkgs/by-name/co/cosmic-term/package.nix index e44230a90c8437..d4c18e6a96880d 100644 --- a/pkgs/by-name/co/cosmic-term/package.nix +++ b/pkgs/by-name/co/cosmic-term/package.nix @@ -1,19 +1,20 @@ -{ lib -, cosmic-icons -, fetchFromGitHub -, fontconfig -, freetype -, just -, libglvnd -, libinput -, libxkbcommon -, makeBinaryWrapper -, pkg-config -, rustPlatform -, stdenv -, vulkan-loader -, wayland -, xorg +{ + lib, + cosmic-icons, + fetchFromGitHub, + fontconfig, + freetype, + just, + libglvnd, + libinput, + libxkbcommon, + makeBinaryWrapper, + pkg-config, + rustPlatform, + stdenv, + vulkan-loader, + wayland, + xorg, }: rustPlatform.buildRustPackage rec { @@ -81,20 +82,25 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram "$out/bin/cosmic-term" \ --suffix XDG_DATA_DIRS : "${cosmic-icons}/share" \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ - libxkbcommon - vulkan-loader - xorg.libX11 - xorg.libXcursor - xorg.libXi - ]} + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + libxkbcommon + vulkan-loader + xorg.libX11 + xorg.libXcursor + xorg.libXi + ] + } ''; meta = with lib; { homepage = "https://github.com/pop-os/cosmic-term"; description = "Terminal for the COSMIC Desktop Environment"; license = licenses.gpl3Only; - maintainers = with maintainers; [ ahoneybun nyabinary ]; + maintainers = with maintainers; [ + ahoneybun + nyabinary + ]; platforms = platforms.linux; mainProgram = "cosmic-term"; }; diff --git a/pkgs/by-name/co/cosmic-workspaces-epoch/package.nix b/pkgs/by-name/co/cosmic-workspaces-epoch/package.nix index 7e7e53306a41e1..c8566601240e3a 100644 --- a/pkgs/by-name/co/cosmic-workspaces-epoch/package.nix +++ b/pkgs/by-name/co/cosmic-workspaces-epoch/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libxkbcommon -, libinput -, libglvnd -, mesa -, udev -, wayland +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libxkbcommon, + libinput, + libglvnd, + mesa, + udev, + wayland, }: rustPlatform.buildRustPackage rec { @@ -27,7 +28,14 @@ rustPlatform.buildRustPackage rec { separateDebugInfo = true; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libxkbcommon libinput libglvnd mesa udev wayland ]; + buildInputs = [ + libxkbcommon + libinput + libglvnd + mesa + udev + wayland + ]; postInstall = '' mkdir -p $out/share/{applications,icons/hicolor/scalable/apps} diff --git a/pkgs/by-name/co/cosmopolitan/cosmocc.nix b/pkgs/by-name/co/cosmopolitan/cosmocc.nix index fb3ca66025a5e2..ee882d69148323 100644 --- a/pkgs/by-name/co/cosmopolitan/cosmocc.nix +++ b/pkgs/by-name/co/cosmopolitan/cosmocc.nix @@ -1,22 +1,24 @@ { runCommand, cosmopolitan }: let - cosmocc = runCommand "cosmocc-${cosmopolitan.version}" - { - pname = "cosmocc"; - inherit (cosmopolitan) version; + cosmocc = + runCommand "cosmocc-${cosmopolitan.version}" + { + pname = "cosmocc"; + inherit (cosmopolitan) version; - passthru.tests = { - cc = runCommand "c-test" { } '' - ${cosmocc}/bin/cosmocc ${./hello.c} - ./a.out > $out - ''; - }; + passthru.tests = { + cc = runCommand "c-test" { } '' + ${cosmocc}/bin/cosmocc ${./hello.c} + ./a.out > $out + ''; + }; - meta = cosmopolitan.meta // { - description = "compilers for Cosmopolitan C/C++ programs"; - }; - } '' + meta = cosmopolitan.meta // { + description = "compilers for Cosmopolitan C/C++ programs"; + }; + } + '' mkdir -p $out/bin install ${cosmopolitan.dist}/tool/scripts/{cosmocc,cosmoc++} $out/bin sed 's|/opt/cosmo\([ /]\)|${cosmopolitan.dist}\1|g' -i $out/bin/* diff --git a/pkgs/by-name/co/cosmopolitan/package.nix b/pkgs/by-name/co/cosmopolitan/package.nix index defc3efb8d13d3..f38c2778ba4e65 100644 --- a/pkgs/by-name/co/cosmopolitan/package.nix +++ b/pkgs/by-name/co/cosmopolitan/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, bintools-unwrapped -, callPackage -, coreutils -, substituteAll -, unzip +{ + lib, + stdenv, + fetchFromGitHub, + bintools-unwrapped, + callPackage, + coreutils, + substituteAll, + unzip, }: stdenv.mkDerivation (finalAttrs: { @@ -34,7 +35,10 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - outputs = [ "out" "dist" ]; + outputs = [ + "out" + "dist" + ]; # slashes are significant because upstream uses o/$(MODE)/foo.o buildFlags = [ @@ -53,16 +57,18 @@ stdenv.mkDerivation (finalAttrs: { dontConfigure = true; dontFixup = true; - preCheck = let - failingTests = [ - # some syscall tests fail because we're in a sandbox - "test/libc/calls/sched_setscheduler_test.c" - "test/libc/thread/pthread_create_test.c" - "test/libc/calls/getgroups_test.c" - # fails - "test/libc/stdio/posix_spawn_test.c" - ]; - in lib.concatStringsSep ";\n" (map (t: "rm -v ${t}") failingTests); + preCheck = + let + failingTests = [ + # some syscall tests fail because we're in a sandbox + "test/libc/calls/sched_setscheduler_test.c" + "test/libc/thread/pthread_create_test.c" + "test/libc/calls/getgroups_test.c" + # fails + "test/libc/stdio/posix_spawn_test.c" + ]; + in + lib.concatStringsSep ";\n" (map (t: "rm -v ${t}") failingTests); installPhase = '' runHook preInstall diff --git a/pkgs/by-name/co/costa/package.nix b/pkgs/by-name/co/costa/package.nix index fcc644edadf436..30c3c94a32025a 100644 --- a/pkgs/by-name/co/costa/package.nix +++ b/pkgs/by-name/co/costa/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, mpi -, scalapack -, llvmPackages +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + mpi, + scalapack, + llvmPackages, }: stdenv.mkDerivation rec { @@ -29,7 +30,6 @@ stdenv.mkDerivation rec { "-DSCALAPACK_ROOT=${scalapack}" ]; - meta = with lib; { description = "Distributed Communication-Optimal Shuffle and Transpose Algorithm"; homepage = "https://github.com/eth-cscs/COSTA"; diff --git a/pkgs/by-name/co/cotp/package.nix b/pkgs/by-name/co/cotp/package.nix index e7880a90412f1d..fb625cf570a787 100644 --- a/pkgs/by-name/co/cotp/package.nix +++ b/pkgs/by-name/co/cotp/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, libxcb +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + libxcb, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/co/coturn/package.nix b/pkgs/by-name/co/coturn/package.nix index 4014d566068e1f..73a014a358a01b 100644 --- a/pkgs/by-name/co/coturn/package.nix +++ b/pkgs/by-name/co/coturn/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, openssl -, libevent -, pkg-config -, libprom -, libpromhttp -, libmicrohttpd -, sqlite -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + libevent, + pkg-config, + libprom, + libpromhttp, + libmicrohttpd, + sqlite, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/co/courier-prime/package.nix b/pkgs/by-name/co/courier-prime/package.nix index 1226966d5e6cd1..7558ad3dadff42 100644 --- a/pkgs/by-name/co/courier-prime/package.nix +++ b/pkgs/by-name/co/courier-prime/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "courier-prime"; diff --git a/pkgs/by-name/co/coursier/package.nix b/pkgs/by-name/co/coursier/package.nix index 775db4796cbd12..37bf0f40d9a3bd 100644 --- a/pkgs/by-name/co/coursier/package.nix +++ b/pkgs/by-name/co/coursier/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre, writeScript, common-updater-scripts -, coreutils, git, gnused, nix, zlib }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, + writeScript, + common-updater-scripts, + coreutils, + git, + gnused, + nix, + zlib, +}: let libPath = lib.makeLibraryPath [ @@ -34,7 +46,15 @@ stdenv.mkDerivation rec { passthru.updateScript = writeScript "update.sh" '' #!${stdenv.shell} set -o errexit - PATH=${lib.makeBinPath [ common-updater-scripts coreutils git gnused nix ]} + PATH=${ + lib.makeBinPath [ + common-updater-scripts + coreutils + git + gnused + nix + ] + } oldVersion="$(nix-instantiate --eval -E "with import ./. {}; lib.getVersion ${pname}" | tr -d '"')" latestTag="$(git -c 'versionsort.suffix=-' ls-remote --exit-code --refs --sort='version:refname' --tags https://github.com/coursier/coursier.git 'v*.*.*' | tail --lines=1 | cut --delimiter='/' --fields=3 | sed 's|^v||g')" if [ "$oldVersion" != "$latestTag" ]; then @@ -51,7 +71,10 @@ stdenv.mkDerivation rec { description = "Scala library to fetch dependencies from Maven / Ivy repositories"; mainProgram = "cs"; license = licenses.asl20; - maintainers = with maintainers; [ adelbertc nequissimus ]; + maintainers = with maintainers; [ + adelbertc + nequissimus + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/co/cov-build/package.nix b/pkgs/by-name/co/cov-build/package.nix index 61c8dda2e6da6c..46c79b66f898f9 100644 --- a/pkgs/by-name/co/cov-build/package.nix +++ b/pkgs/by-name/co/cov-build/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, -, autoPatchelfHook + autoPatchelfHook, -, alsa-lib -, libxcrypt-legacy -, lttng-ust_2_12 -, xorg -, zlib + alsa-lib, + libxcrypt-legacy, + lttng-ust_2_12, + xorg, + zlib, }: stdenv.mkDerivation rec { @@ -16,17 +17,18 @@ stdenv.mkDerivation rec { version = "2022.12.2"; src = - if stdenv.hostPlatform.system == "i686-linux" - then fetchurl { - url = "https://archive.org/download/cov-analysis-linux-${version}.tar/cov-analysis-linux-${version}.tar.gz"; - hash = "sha256-Jr9bMUo9GRp+dgoAPqKxaTqWYWh4djGArdG9ukUK+ZY="; - } - else if stdenv.hostPlatform.system == "x86_64-linux" - then fetchurl { - url = "https://archive.org/download/cov-analysis-linux64-${version}.tar/cov-analysis-linux64-${version}.tar.gz"; - hash = "sha256-CyNKILJXlDMOCXbZZF4r/knz0orRx32oSj+Kpq/nxXQ="; - } - else throw "Unsupported platform '${stdenv.hostPlatform.system}'"; + if stdenv.hostPlatform.system == "i686-linux" then + fetchurl { + url = "https://archive.org/download/cov-analysis-linux-${version}.tar/cov-analysis-linux-${version}.tar.gz"; + hash = "sha256-Jr9bMUo9GRp+dgoAPqKxaTqWYWh4djGArdG9ukUK+ZY="; + } + else if stdenv.hostPlatform.system == "x86_64-linux" then + fetchurl { + url = "https://archive.org/download/cov-analysis-linux64-${version}.tar/cov-analysis-linux64-${version}.tar.gz"; + hash = "sha256-CyNKILJXlDMOCXbZZF4r/knz0orRx32oSj+Kpq/nxXQ="; + } + else + throw "Unsupported platform '${stdenv.hostPlatform.system}'"; nativeBuildInputs = [ autoPatchelfHook ]; @@ -61,9 +63,9 @@ stdenv.mkDerivation rec { meta = { description = "Coverity Scan build tools"; - homepage = "https://scan.coverity.com"; - license = lib.licenses.unfreeRedistributable; - platforms = lib.platforms.linux; + homepage = "https://scan.coverity.com"; + license = lib.licenses.unfreeRedistributable; + platforms = lib.platforms.linux; maintainers = [ lib.maintainers.thoughtpolice ]; }; } diff --git a/pkgs/by-name/co/cowpatty/package.nix b/pkgs/by-name/co/cowpatty/package.nix index 2c6e0cfa414f74..4599339409aaec 100644 --- a/pkgs/by-name/co/cowpatty/package.nix +++ b/pkgs/by-name/co/cowpatty/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, clang -, fetchFromGitHub -, fetchpatch -, installShellFiles -, openssl -, libpcap +{ + lib, + stdenv, + clang, + fetchFromGitHub, + fetchpatch, + installShellFiles, + openssl, + libpcap, }: stdenv.mkDerivation rec { @@ -55,7 +56,10 @@ stdenv.mkDerivation rec { description = "Offline dictionary attack against WPA/WPA2 networks"; homepage = "https://github.com/joswr1ght/cowpatty"; license = licenses.bsd3; - maintainers = with maintainers; [ nico202 fab ]; + maintainers = with maintainers; [ + nico202 + fab + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/co/coze/package.nix b/pkgs/by-name/co/coze/package.nix index ca7b8f3d1d7e4e..2149283645f636 100644 --- a/pkgs/by-name/co/coze/package.nix +++ b/pkgs/by-name/co/coze/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "coze"; diff --git a/pkgs/by-name/co/cozette/package.nix b/pkgs/by-name/co/cozette/package.nix index a198a9c63b0d62..38ac3c054cf5bc 100644 --- a/pkgs/by-name/co/cozette/package.nix +++ b/pkgs/by-name/co/cozette/package.nix @@ -1,11 +1,17 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "cozette"; version = "1.25.2"; src = fetchzip { - url = "https://github.com/slavfox/Cozette/releases/download/v.${version}/CozetteFonts-v-${builtins.replaceStrings ["."] ["-"] version}.zip"; + url = "https://github.com/slavfox/Cozette/releases/download/v.${version}/CozetteFonts-v-${ + builtins.replaceStrings [ "." ] [ "-" ] version + }.zip"; hash = "sha256-LtZHbsma9EuegS349gQo4W+ZT8x+Vb3CD/5vRKjwkzc="; }; diff --git a/pkgs/by-name/co/cozy-drive/package.nix b/pkgs/by-name/co/cozy-drive/package.nix index b9e44ebbab7710..732356fdf543f7 100644 --- a/pkgs/by-name/co/cozy-drive/package.nix +++ b/pkgs/by-name/co/cozy-drive/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchurl -, appimageTools +{ + lib, + fetchurl, + appimageTools, }: let diff --git a/pkgs/by-name/co/cozy/package.nix b/pkgs/by-name/co/cozy/package.nix index 22ebd11c77253a..d0182f75792ad6 100644 --- a/pkgs/by-name/co/cozy/package.nix +++ b/pkgs/by-name/co/cozy/package.nix @@ -1,15 +1,16 @@ -{ lib -, python3Packages -, fetchFromGitHub -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, appstream-glib -, desktop-file-utils -, gobject-introspection -, libadwaita -, gst_all_1 +{ + lib, + python3Packages, + fetchFromGitHub, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + appstream-glib, + desktop-file-utils, + gobject-introspection, + libadwaita, + gst_all_1, }: python3Packages.buildPythonApplication rec { @@ -42,15 +43,17 @@ python3Packages.buildPythonApplication rec { gobject-introspection ]; - buildInputs = [ - libadwaita - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-good - gst-plugins-ugly - gst-plugins-base - gst-plugins-bad - ]); + buildInputs = + [ + libadwaita + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-good + gst-plugins-ugly + gst-plugins-base + gst-plugins-bad + ]); propagatedBuildInputs = with python3Packages; [ distro @@ -74,7 +77,10 @@ python3Packages.buildPythonApplication rec { meta = with lib; { description = "Modern audio book player for Linux"; homepage = "https://cozy.geigi.de/"; - maintainers = with maintainers; [ makefu aleksana ]; + maintainers = with maintainers; [ + makefu + aleksana + ]; license = licenses.gpl3Plus; mainProgram = "com.github.geigi.cozy"; platforms = platforms.linux; diff --git a/pkgs/by-name/cp/cp210x-program/package.nix b/pkgs/by-name/cp/cp210x-program/package.nix index 50c6daab1bfae8..908b92c7cb3397 100644 --- a/pkgs/by-name/cp/cp210x-program/package.nix +++ b/pkgs/by-name/cp/cp210x-program/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/cp/cp2k/package.nix b/pkgs/by-name/cp/cp2k/package.nix index 646e9d5aba780f..47568f174da64b 100644 --- a/pkgs/by-name/cp/cp2k/package.nix +++ b/pkgs/by-name/cp/cp2k/package.nix @@ -180,9 +180,9 @@ stdenv.mkDerivation rec { gpuBackend == "cuda" ) "-D__OFFLOAD_CUDA -D__ACC -D__DBCSR_ACC -D__NO_OFFLOAD_PW" } \ - ${ - lib.strings.optionalString (gpuBackend == "rocm") "-D__OFFLOAD_HIP -D__DBCSR_ACC -D__NO_OFFLOAD_PW" - } + ${lib.strings.optionalString ( + gpuBackend == "rocm" + ) "-D__OFFLOAD_HIP -D__DBCSR_ACC -D__NO_OFFLOAD_PW"} CFLAGS = -fopenmp FCFLAGS = \$(DFLAGS) -O2 -ffree-form -ffree-line-length-none \ -ftree-vectorize -funroll-loops -msse2 \ @@ -211,9 +211,9 @@ stdenv.mkDerivation rec { -lcudart -lnvrtc -lcuda -lcublas '' } \ - ${ - lib.strings.optionalString (gpuBackend == "rocm") "-lamdhip64 -lhipfft -lhipblas -lrocblas" - } + ${lib.strings.optionalString ( + gpuBackend == "rocm" + ) "-lamdhip64 -lhipfft -lhipblas -lrocblas"} LDFLAGS = \$(FCFLAGS) \$(LIBS) include ${plumed}/lib/plumed/src/lib/Plumed.inc EOF diff --git a/pkgs/by-name/cp/cp437/package.nix b/pkgs/by-name/cp/cp437/package.nix index cb4b1b8508cb90..e5cae69edd0eeb 100644 --- a/pkgs/by-name/cp/cp437/package.nix +++ b/pkgs/by-name/cp/cp437/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "cp437"; @@ -6,8 +10,8 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "keaston"; - repo = "cp437"; - rev = "v${version}"; + repo = "cp437"; + rev = "v${version}"; sha256 = "18f4mnfnyviqclbhmbhix80k823481ypkwbp26qfvhnxdgzbggcc"; }; diff --git a/pkgs/by-name/cp/cpcfs/package.nix b/pkgs/by-name/cp/cpcfs/package.nix index 654a8896144065..b726e17a1f66dd 100644 --- a/pkgs/by-name/cp/cpcfs/package.nix +++ b/pkgs/by-name/cp/cpcfs/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, ncurses, readline, ronn }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + ncurses, + readline, + ronn, +}: stdenv.mkDerivation rec { @@ -14,7 +22,12 @@ stdenv.mkDerivation rec { sourceRoot = "${src.name}/src"; - nativeBuildInputs = [ makeWrapper ncurses readline ronn ]; + nativeBuildInputs = [ + makeWrapper + ncurses + readline + ronn + ]; env.NIX_CFLAGS_COMPILE = "-std=gnu89"; @@ -36,7 +49,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Manipulating CPC dsk images and files"; mainProgram = "cpcfs"; - homepage = "https://github.com/derikz/cpcfs/" ; + homepage = "https://github.com/derikz/cpcfs/"; license = licenses.bsd2; maintainers = [ ]; platforms = platforms.all; diff --git a/pkgs/by-name/cp/cpio/package.nix b/pkgs/by-name/cp/cpio/package.nix index ba178fb3eb7e38..879b52a98c7d5a 100644 --- a/pkgs/by-name/cp/cpio/package.nix +++ b/pkgs/by-name/cp/cpio/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook - -# for passthru.tests -, git -, libguestfs -, nixosTests -, rpm +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + + # for passthru.tests + git, + libguestfs, + nixosTests, + rpm, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cp/cplay-ng/package.nix b/pkgs/by-name/cp/cplay-ng/package.nix index f5eca18966722c..82b331616607e0 100644 --- a/pkgs/by-name/cp/cplay-ng/package.nix +++ b/pkgs/by-name/cp/cplay-ng/package.nix @@ -1,9 +1,10 @@ -{ lib -, python3 -, fetchFromGitHub -, makeWrapper -, mpv -, pulseaudio +{ + lib, + python3, + fetchFromGitHub, + makeWrapper, + mpv, + pulseaudio, }: python3.pkgs.buildPythonApplication rec { @@ -29,7 +30,12 @@ python3.pkgs.buildPythonApplication rec { postInstall = '' wrapProgram $out/bin/cplay-ng \ - --prefix PATH : ${lib.makeBinPath [ mpv pulseaudio ]} + --prefix PATH : ${ + lib.makeBinPath [ + mpv + pulseaudio + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/cp/cpp-hocon/package.nix b/pkgs/by-name/cp/cpp-hocon/package.nix index 0b34bd05c7dc54..7d6a65aa61c901 100644 --- a/pkgs/by-name/cp/cpp-hocon/package.nix +++ b/pkgs/by-name/cp/cpp-hocon/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, boost, curl, leatherman }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + curl, + leatherman, +}: stdenv.mkDerivation rec { pname = "cpp-hocon"; @@ -19,7 +27,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ boost curl leatherman ]; + buildInputs = [ + boost + curl + leatherman + ]; meta = with lib; { inherit (src.meta) homepage; diff --git a/pkgs/by-name/cp/cpp-ipfs-http-client/package.nix b/pkgs/by-name/cp/cpp-ipfs-http-client/package.nix index d44eed5e76f0fa..322f911d302673 100644 --- a/pkgs/by-name/cp/cpp-ipfs-http-client/package.nix +++ b/pkgs/by-name/cp/cpp-ipfs-http-client/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, curl, cmake, nlohmann_json }: +{ + lib, + stdenv, + fetchFromGitHub, + curl, + cmake, + nlohmann_json, +}: stdenv.mkDerivation { pname = "cpp-ipfs-http-client"; @@ -32,6 +39,9 @@ stdenv.mkDerivation { description = "IPFS C++ API client library"; homepage = "https://github.com/vasild/cpp-ipfs-http-client"; license = licenses.mit; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; }; } diff --git a/pkgs/by-name/cp/cpp-jwt/package.nix b/pkgs/by-name/cp/cpp-jwt/package.nix index a9295629bf20cf..692dc73502006d 100644 --- a/pkgs/by-name/cp/cpp-jwt/package.nix +++ b/pkgs/by-name/cp/cpp-jwt/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, openssl, gtest, nlohmann_json }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openssl, + gtest, + nlohmann_json, +}: stdenv.mkDerivation rec { pname = "cpp-jwt"; @@ -21,7 +29,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ gtest openssl nlohmann_json ]; + buildInputs = [ + gtest + openssl + nlohmann_json + ]; doCheck = true; diff --git a/pkgs/by-name/cp/cpp-netlib/package.nix b/pkgs/by-name/cp/cpp-netlib/package.nix index af57944a453d6b..f70795a462bfb5 100644 --- a/pkgs/by-name/cp/cpp-netlib/package.nix +++ b/pkgs/by-name/cp/cpp-netlib/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, boost, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + openssl, +}: stdenv.mkDerivation rec { pname = "cpp-netlib"; @@ -13,7 +20,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ boost openssl ]; + buildInputs = [ + boost + openssl + ]; cmakeFlags = [ "-DCPP-NETLIB_BUILD_SHARED_LIBS=ON" @@ -27,8 +37,8 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Collection of open-source libraries for high level network programming"; - homepage = "https://cpp-netlib.org"; - license = licenses.boost; - platforms = platforms.all; + homepage = "https://cpp-netlib.org"; + license = licenses.boost; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/cp/cpp-utilities/package.nix b/pkgs/by-name/cp/cpp-utilities/package.nix index fc4cea2f40f469..12c67d70e14644 100644 --- a/pkgs/by-name/cp/cpp-utilities/package.nix +++ b/pkgs/by-name/cp/cpp-utilities/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, cppunit -, libiconv +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + cppunit, + libiconv, }: stdenv.mkDerivation (finalAttrs: { @@ -23,7 +24,7 @@ stdenv.mkDerivation (finalAttrs: { libiconv # needed on Darwin, see https://github.com/Martchus/cpp-utilities/issues/4 ]; - cmakeFlags = ["-DBUILD_SHARED_LIBS=ON"]; + cmakeFlags = [ "-DBUILD_SHARED_LIBS=ON" ]; # Otherwise, tests fail since the resulting shared object libc++utilities.so is only available in PWD of the make files preCheck = '' diff --git a/pkgs/by-name/cp/cppclean/package.nix b/pkgs/by-name/cp/cppclean/package.nix index d48e21fffb5dae..c260929b2d9ef9 100644 --- a/pkgs/by-name/cp/cppclean/package.nix +++ b/pkgs/by-name/cp/cppclean/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: with python3Packages; @@ -7,26 +11,26 @@ buildPythonApplication rec { version = "0.13"; src = fetchFromGitHub { - owner = "myint"; - repo = "cppclean"; - rev = "v${version}"; + owner = "myint"; + repo = "cppclean"; + rev = "v${version}"; sha256 = "081bw7kkl7mh3vwyrmdfrk3fgq8k5laacx7hz8fjpchrvdrkqph0"; }; postUnpack = '' patchShebangs . - ''; + ''; checkPhase = '' ./test.bash - ''; + ''; meta = with lib; { description = "Finds problems in C++ source that slow development of large code bases"; mainProgram = "cppclean"; - homepage = "https://github.com/myint/cppclean"; - license = licenses.asl20; + homepage = "https://github.com/myint/cppclean"; + license = licenses.asl20; maintainers = with maintainers; [ nthorne ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/cp/cppcms/package.nix b/pkgs/by-name/cp/cppcms/package.nix index 86aa687aaa71ea..d9c59640ba5d56 100644 --- a/pkgs/by-name/cp/cppcms/package.nix +++ b/pkgs/by-name/cp/cppcms/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, cmake, pcre, zlib, python3, openssl }: +{ + lib, + stdenv, + fetchurl, + cmake, + pcre, + zlib, + python3, + openssl, +}: stdenv.mkDerivation rec { pname = "cppcms"; @@ -9,8 +18,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-aXAxx9FB/dIVxr5QkLZuIQamO7PlLwnugSDo78bAiiE="; }; - nativeBuildInputs = [ cmake python3 ]; - buildInputs = [ pcre zlib openssl ]; + nativeBuildInputs = [ + cmake + python3 + ]; + buildInputs = [ + pcre + zlib + openssl + ]; strictDeps = true; diff --git a/pkgs/by-name/cp/cppcodec/package.nix b/pkgs/by-name/cp/cppcodec/package.nix index 99a8eda1477c64..0f08e3ee636da7 100644 --- a/pkgs/by-name/cp/cppcodec/package.nix +++ b/pkgs/by-name/cp/cppcodec/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -26,6 +27,9 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://github.com/tplgy/cppcodec"; license = licenses.mit; - maintainers = with maintainers; [ panicgh raitobezarius ]; + maintainers = with maintainers; [ + panicgh + raitobezarius + ]; }; }) diff --git a/pkgs/by-name/cp/cppdb/package.nix b/pkgs/by-name/cp/cppdb/package.nix index b71a6c07303101..0e92f0f2df815c 100644 --- a/pkgs/by-name/cp/cppdb/package.nix +++ b/pkgs/by-name/cp/cppdb/package.nix @@ -1,16 +1,30 @@ -{ lib, stdenv, fetchurl, cmake, sqlite, libmysqlclient, postgresql, unixODBC }: +{ + lib, + stdenv, + fetchurl, + cmake, + sqlite, + libmysqlclient, + postgresql, + unixODBC, +}: stdenv.mkDerivation rec { pname = "cppdb"; version = "0.3.1"; src = fetchurl { - url = "mirror://sourceforge/cppcms/${pname}-${version}.tar.bz2"; - sha256 = "0blr1casmxickic84dxzfmn3lm7wrsl4aa2abvpq93rdfddfy3nn"; + url = "mirror://sourceforge/cppcms/${pname}-${version}.tar.bz2"; + sha256 = "0blr1casmxickic84dxzfmn3lm7wrsl4aa2abvpq93rdfddfy3nn"; }; nativeBuildInputs = [ cmake ]; - buildInputs = [ sqlite libmysqlclient postgresql unixODBC ]; + buildInputs = [ + sqlite + libmysqlclient + postgresql + unixODBC + ]; cmakeFlags = [ "--no-warn-unused-cli" ]; env.NIX_CFLAGS_COMPILE = "-I${libmysqlclient}/include/mysql -L${libmysqlclient}/lib/mysql"; @@ -18,7 +32,7 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "http://cppcms.com/sql/cppdb/"; description = "C++ Connectivity library that supports MySQL, PostgreSQL, Sqlite3 databases and generic ODBC drivers"; - platforms = platforms.linux ; + platforms = platforms.linux; license = licenses.boost; maintainers = [ maintainers.juliendehos ]; }; diff --git a/pkgs/by-name/cp/cppe/package.nix b/pkgs/by-name/cp/cppe/package.nix index 9781ce78066057..a976ee843e77ff 100644 --- a/pkgs/by-name/cp/cppe/package.nix +++ b/pkgs/by-name/cp/cppe/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, cmake, llvmPackages }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + llvmPackages, +}: stdenv.mkDerivation rec { pname = "cppe"; @@ -11,8 +17,7 @@ stdenv.mkDerivation rec { sha256 = "sha256-guM7+ZWDJLcAUJtPkKLvC4LYSA2eBvER7cgwPZ7FxHw="; }; - nativeBuildInputs = [ cmake ] - ++ lib.optionals stdenv.cc.isClang [ llvmPackages.openmp ]; + nativeBuildInputs = [ cmake ] ++ lib.optionals stdenv.cc.isClang [ llvmPackages.openmp ]; cmakeFlags = [ "-DCMAKE_INSTALL_LIBDIR=lib" ]; diff --git a/pkgs/by-name/cp/cppi/package.nix b/pkgs/by-name/cp/cppi/package.nix index 13d45957982632..df2c073d0589ae 100644 --- a/pkgs/by-name/cp/cppi/package.nix +++ b/pkgs/by-name/cp/cppi/package.nix @@ -1,4 +1,8 @@ -{ fetchurl, lib, stdenv }: +{ + fetchurl, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "cppi"; diff --git a/pkgs/by-name/cp/cppreference-doc/package.nix b/pkgs/by-name/cp/cppreference-doc/package.nix index c2ec04efaaab50..33827e12132e18 100644 --- a/pkgs/by-name/cp/cppreference-doc/package.nix +++ b/pkgs/by-name/cp/cppreference-doc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "cppreference-doc"; diff --git a/pkgs/by-name/cp/cpptest/package.nix b/pkgs/by-name/cp/cpptest/package.nix index a3558e0ef49376..77045357c1a296 100644 --- a/pkgs/by-name/cp/cpptest/package.nix +++ b/pkgs/by-name/cp/cpptest/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "cpptest"; diff --git a/pkgs/by-name/cp/cpptoml/package.nix b/pkgs/by-name/cp/cpptoml/package.nix index 421f67b8260a5f..1dac726cc7b5ac 100644 --- a/pkgs/by-name/cp/cpptoml/package.nix +++ b/pkgs/by-name/cp/cpptoml/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libcxxCmakeModule ? false }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libcxxCmakeModule ? false, +}: stdenv.mkDerivation rec { pname = "cpptoml"; diff --git a/pkgs/by-name/cp/cppunit/package.nix b/pkgs/by-name/cp/cppunit/package.nix index 73c96de4ff245e..c131e8f84be976 100644 --- a/pkgs/by-name/cp/cppunit/package.nix +++ b/pkgs/by-name/cp/cppunit/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "cppunit"; diff --git a/pkgs/by-name/cp/cpputest/package.nix b/pkgs/by-name/cp/cpputest/package.nix index 39bed602523222..3d272be32fea2a 100644 --- a/pkgs/by-name/cp/cpputest/package.nix +++ b/pkgs/by-name/cp/cpputest/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "cpputest"; diff --git a/pkgs/by-name/cp/cppzmq/package.nix b/pkgs/by-name/cp/cppzmq/package.nix index eb3f03d57e40c1..a100bbdb9bc831 100644 --- a/pkgs/by-name/cp/cppzmq/package.nix +++ b/pkgs/by-name/cp/cppzmq/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, zeromq }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zeromq, +}: stdenv.mkDerivation rec { pname = "cppzmq"; diff --git a/pkgs/by-name/cp/cproto/package.nix b/pkgs/by-name/cp/cproto/package.nix index faf0e8e5a4ee4d..eb473627c45d44 100644 --- a/pkgs/by-name/cp/cproto/package.nix +++ b/pkgs/by-name/cp/cproto/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, flex, bison }: +{ + lib, + stdenv, + fetchurl, + flex, + bison, +}: stdenv.mkDerivation rec { pname = "cproto"; @@ -16,7 +22,10 @@ stdenv.mkDerivation rec { # patch made by Joe Khoobyar copied from gentoo bugs patches = [ ./cproto.patch ]; - nativeBuildInputs = [ flex bison ]; + nativeBuildInputs = [ + flex + bison + ]; doCheck = true; diff --git a/pkgs/by-name/cp/cpu-energy-meter/package.nix b/pkgs/by-name/cp/cpu-energy-meter/package.nix index 7ddbf8f6d283ac..42d496badab35c 100644 --- a/pkgs/by-name/cp/cpu-energy-meter/package.nix +++ b/pkgs/by-name/cp/cpu-energy-meter/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, libcap +{ + lib, + stdenv, + fetchFromGitHub, + libcap, }: stdenv.mkDerivation rec { pname = "cpu-energy-meter"; diff --git a/pkgs/by-name/cp/cpufetch/package.nix b/pkgs/by-name/cp/cpufetch/package.nix index c9a2a1dd7fd85c..cc3d961d8149ce 100644 --- a/pkgs/by-name/cp/cpufetch/package.nix +++ b/pkgs/by-name/cp/cpufetch/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cp/cpufrequtils/package.nix b/pkgs/by-name/cp/cpufrequtils/package.nix index f62d8463714e7e..3acd772bdd3c36 100644 --- a/pkgs/by-name/cp/cpufrequtils/package.nix +++ b/pkgs/by-name/cp/cpufrequtils/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libtool, gettext }: +{ + lib, + stdenv, + fetchurl, + libtool, + gettext, +}: stdenv.mkDerivation rec { pname = "cpufrequtils"; @@ -20,7 +26,11 @@ stdenv.mkDerivation rec { -i Makefile ''; - buildInputs = [ stdenv.cc.libc.linuxHeaders libtool gettext ]; + buildInputs = [ + stdenv.cc.libc.linuxHeaders + libtool + gettext + ]; meta = with lib; { description = "Tools to display or change the CPU governor settings"; diff --git a/pkgs/by-name/cp/cpulimit/package.nix b/pkgs/by-name/cp/cpulimit/package.nix index 4788bc57befe30..3e143ac49887e8 100644 --- a/pkgs/by-name/cp/cpulimit/package.nix +++ b/pkgs/by-name/cp/cpulimit/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "cpulimit"; @@ -11,8 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1dz045yhcsw1rdamzpz4bk8mw888in7fyqk1q1b3m1yk4pd1ahkh"; }; - patches = [ ./remove-sys-sysctl.h.patch ./get-missing-basename.patch ]; - + patches = [ + ./remove-sys-sysctl.h.patch + ./get-missing-basename.patch + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/cp/cpuminer/package.nix b/pkgs/by-name/cp/cpuminer/package.nix index 8b9e07762c83de..6f17492b89ccb3 100644 --- a/pkgs/by-name/cp/cpuminer/package.nix +++ b/pkgs/by-name/cp/cpuminer/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, curl -, jansson -, perl -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + curl, + jansson, + perl, + autoreconfHook, }: stdenv.mkDerivation rec { @@ -30,7 +31,10 @@ stdenv.mkDerivation rec { postPatch = if stdenv.cc.isClang then "${perl}/bin/perl ./nomacro.pl" else null; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ curl jansson ]; + buildInputs = [ + curl + jansson + ]; configureFlags = [ "CFLAGS=-O3" ]; diff --git a/pkgs/by-name/cp/cpuset/package.nix b/pkgs/by-name/cp/cpuset/package.nix index f6fcf609c0c1e9..f9af9b8893b6af 100644 --- a/pkgs/by-name/cp/cpuset/package.nix +++ b/pkgs/by-name/cp/cpuset/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/cp/cpustat/package.nix b/pkgs/by-name/cp/cpustat/package.nix index fbf7c1f48fad43..62f5d9d328f041 100644 --- a/pkgs/by-name/cp/cpustat/package.nix +++ b/pkgs/by-name/cp/cpustat/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, ncurses +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, }: stdenv.mkDerivation rec { @@ -10,7 +11,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "ColinIanKing"; - repo ="cpustat"; + repo = "cpustat"; rev = "refs/tags/V${version}"; hash = "sha256-Rxoj2pnQ/tEUzcsFT1F+rU960b4Th3hqZU2YR6YGwZQ="; }; diff --git a/pkgs/by-name/cq/cq/package.nix b/pkgs/by-name/cq/cq/package.nix index 82fc31a7bbdd3b..a993515af39694 100644 --- a/pkgs/by-name/cq/cq/package.nix +++ b/pkgs/by-name/cq/cq/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, fetchurl -, buildGraalvmNativeImage -, graalvmCEPackages +{ + lib, + fetchFromGitHub, + fetchurl, + buildGraalvmNativeImage, + graalvmCEPackages, }: buildGraalvmNativeImage rec { diff --git a/pkgs/by-name/cr/crabz/package.nix b/pkgs/by-name/cr/crabz/package.nix index bbdbdacadc7937..245e14ae4397a6 100644 --- a/pkgs/by-name/cr/crabz/package.nix +++ b/pkgs/by-name/cr/crabz/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, cmake +{ + lib, + rustPlatform, + fetchFromGitHub, + cmake, }: rustPlatform.buildRustPackage rec { @@ -23,7 +24,10 @@ rustPlatform.buildRustPackage rec { description = "Cross platform, fast, compression and decompression tool"; homepage = "https://github.com/sstadick/crabz"; changelog = "https://github.com/sstadick/crabz/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ unlicense /* or */ mit ]; + license = with licenses; [ + unlicense # or + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "crabz"; }; diff --git a/pkgs/by-name/cr/crackle/package.nix b/pkgs/by-name/cr/crackle/package.nix index f84d44ca091788..a6099418574eef 100644 --- a/pkgs/by-name/cr/crackle/package.nix +++ b/pkgs/by-name/cr/crackle/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, libpcap, coreutils }: +{ + lib, + stdenv, + fetchFromGitHub, + libpcap, + coreutils, +}: stdenv.mkDerivation { pname = "crackle"; @@ -13,7 +19,11 @@ stdenv.mkDerivation { buildInputs = [ libpcap ]; - installFlags = [ "DESTDIR=$(out)" "PREFIX=" "INSTALL=${coreutils}/bin/install" ]; + installFlags = [ + "DESTDIR=$(out)" + "PREFIX=" + "INSTALL=${coreutils}/bin/install" + ]; meta = with lib; { description = "Crack and decrypt BLE encryption"; diff --git a/pkgs/by-name/cr/cracklib/package.nix b/pkgs/by-name/cr/cracklib/package.nix index bc69141bb98894..76bdad640f0b00 100644 --- a/pkgs/by-name/cr/cracklib/package.nix +++ b/pkgs/by-name/cr/cracklib/package.nix @@ -1,9 +1,20 @@ -let version = "2.10.0"; in -{ stdenv, lib, buildPackages, fetchurl, zlib, gettext, fetchpatch2 -, lists ? [ (fetchurl { - url = "https://github.com/cracklib/cracklib/releases/download/v${version}/cracklib-words-${version}.gz"; - hash = "sha256-JDLo/bSLIijC2DUl+8Q704i2zgw5cxL6t68wvuivPpY="; -}) ] +let + version = "2.10.0"; +in +{ + stdenv, + lib, + buildPackages, + fetchurl, + zlib, + gettext, + fetchpatch2, + lists ? [ + (fetchurl { + url = "https://github.com/cracklib/cracklib/releases/download/v${version}/cracklib-words-${version}.gz"; + hash = "sha256-JDLo/bSLIijC2DUl+8Q704i2zgw5cxL6t68wvuivPpY="; + }) + ], }: stdenv.mkDerivation rec { @@ -25,16 +36,23 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) buildPackages.cracklib; - buildInputs = [ zlib gettext ]; + nativeBuildInputs = lib.optional ( + stdenv.hostPlatform != stdenv.buildPlatform + ) buildPackages.cracklib; + buildInputs = [ + zlib + gettext + ]; - postPatch = lib.optionalString (stdenv.hostPlatform == stdenv.buildPlatform) '' - chmod +x util/cracklib-format - patchShebangs util + postPatch = + lib.optionalString (stdenv.hostPlatform == stdenv.buildPlatform) '' + chmod +x util/cracklib-format + patchShebangs util - '' + '' - ln -vs ${toString lists} dicts/ - ''; + '' + + '' + ln -vs ${toString lists} dicts/ + ''; postInstall = '' make dict-local @@ -43,10 +61,10 @@ stdenv.mkDerivation rec { installCheckTarget = "test"; meta = with lib; { - homepage = "https://github.com/cracklib/cracklib"; + homepage = "https://github.com/cracklib/cracklib"; description = "Library for checking the strength of passwords"; license = licenses.lgpl21; # Different license for the wordlist: http://www.openwall.com/wordlists maintainers = with maintainers; [ lovek323 ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/cr/crackql/package.nix b/pkgs/by-name/cr/crackql/package.nix index 121ed522afae93..f0292a51c9a5f0 100644 --- a/pkgs/by-name/cr/crackql/package.nix +++ b/pkgs/by-name/cr/crackql/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/cr/crackxls/package.nix b/pkgs/by-name/cr/crackxls/package.nix index 7ff6de5deff0c0..b14153eb44bc5e 100644 --- a/pkgs/by-name/cr/crackxls/package.nix +++ b/pkgs/by-name/cr/crackxls/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, pkg-config, autoconf, automake, openssl, libgsf, gmp }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + autoconf, + automake, + openssl, + libgsf, + gmp, +}: stdenv.mkDerivation rec { @@ -22,14 +33,21 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config autoconf automake ]; - buildInputs = [ openssl libgsf gmp ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; + buildInputs = [ + openssl + libgsf + gmp + ]; # Avoid "-O5 -march=native" makeFlags = [ "OPTIM_FLAGS=" ]; - installPhase = - '' + installPhase = '' mkdir -p $out/bin cp crackxls2003 $out/bin/ ''; diff --git a/pkgs/by-name/cr/craftos-pc/test-eval-hello-world/default.nix b/pkgs/by-name/cr/craftos-pc/test-eval-hello-world/default.nix index 90b86a16fa7238..2c468472461862 100644 --- a/pkgs/by-name/cr/craftos-pc/test-eval-hello-world/default.nix +++ b/pkgs/by-name/cr/craftos-pc/test-eval-hello-world/default.nix @@ -1,12 +1,16 @@ -{ stdenv -, craftos-pc -, gnugrep +{ + stdenv, + craftos-pc, + gnugrep, }: stdenv.mkDerivation { name = "craftos-pc-test-eval-hello-world"; meta.timeout = 60; - nativeBuildInputs = [ craftos-pc gnugrep ]; + nativeBuildInputs = [ + craftos-pc + gnugrep + ]; buildCommand = '' export HOME=$(pwd) mkdir $HOME/.local $HOME/.config diff --git a/pkgs/by-name/cr/craftos-pc/test-eval-periphemu/default.nix b/pkgs/by-name/cr/craftos-pc/test-eval-periphemu/default.nix index af1cca9c27a752..cdeba3e1c28288 100644 --- a/pkgs/by-name/cr/craftos-pc/test-eval-periphemu/default.nix +++ b/pkgs/by-name/cr/craftos-pc/test-eval-periphemu/default.nix @@ -1,11 +1,15 @@ -{ stdenv -, craftos-pc -, gnugrep +{ + stdenv, + craftos-pc, + gnugrep, }: stdenv.mkDerivation { name = "craftos-pc-test-eval-periphemu"; meta.timeout = 60; - nativeBuildInputs = [ craftos-pc gnugrep ]; + nativeBuildInputs = [ + craftos-pc + gnugrep + ]; buildCommand = '' export HOME=$(pwd) mkdir $HOME/.local $HOME/.config diff --git a/pkgs/by-name/cr/cramfsprogs/package.nix b/pkgs/by-name/cr/cramfsprogs/package.nix index bde2686624d3c8..f626203c0bfa25 100644 --- a/pkgs/by-name/cr/cramfsprogs/package.nix +++ b/pkgs/by-name/cr/cramfsprogs/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchurl -, zlib +{ + lib, + stdenv, + fetchurl, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cr/cramfsswap/package.nix b/pkgs/by-name/cr/cramfsswap/package.nix index c696df6f00849f..922f7323dd3c34 100644 --- a/pkgs/by-name/cr/cramfsswap/package.nix +++ b/pkgs/by-name/cr/cramfsswap/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, zlib}: +{ + lib, + stdenv, + fetchurl, + zlib, +}: stdenv.mkDerivation rec { pname = "cramfsswap"; @@ -16,7 +21,7 @@ stdenv.mkDerivation rec { substituteInPlace Makefile --replace 'strip ' '$(STRIP) ' ''; - buildInputs = [zlib]; + buildInputs = [ zlib ]; installPhase = '' install --target $out/bin -D cramfsswap diff --git a/pkgs/by-name/cr/crawley/package.nix b/pkgs/by-name/cr/crawley/package.nix index dd2f1c7a07b89d..fa0e0b0fc9fab4 100644 --- a/pkgs/by-name/cr/crawley/package.nix +++ b/pkgs/by-name/cr/crawley/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -19,7 +20,10 @@ buildGoModule rec { vendorHash = "sha256-jj8FNZs/bkFQxveOkqmGVO3MNPPv5O9ebodoi7hhzIs="; - ldflags = [ "-w" "-s" ]; + ldflags = [ + "-w" + "-s" + ]; postInstall = '' installShellCompletion --cmd crawley \ diff --git a/pkgs/by-name/cr/crc/package.nix b/pkgs/by-name/cr/crc/package.nix index 18f9b852a24396..f94350a168f695 100644 --- a/pkgs/by-name/cr/crc/package.nix +++ b/pkgs/by-name/cr/crc/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, crc -, coreutils +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + crc, + coreutils, }: let @@ -68,6 +69,10 @@ buildGoModule rec { changelog = "https://github.com/crc-org/crc/releases/tag/v${version}"; license = licenses.asl20; mainProgram = "crc"; - maintainers = with maintainers; [ matthewpi shikanime tricktron ]; + maintainers = with maintainers; [ + matthewpi + shikanime + tricktron + ]; }; } diff --git a/pkgs/by-name/cr/crc32c/package.nix b/pkgs/by-name/cr/crc32c/package.nix index 07da71e3267068..e1f51021685796 100644 --- a/pkgs/by-name/cr/crc32c/package.nix +++ b/pkgs/by-name/cr/crc32c/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, gflags -, staticOnly ? stdenv.hostPlatform.isStatic +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + gflags, + staticOnly ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cr/crcpp/package.nix b/pkgs/by-name/cr/crcpp/package.nix index 6162d8935be382..89b9d4a7d56c13 100644 --- a/pkgs/by-name/cr/crcpp/package.nix +++ b/pkgs/by-name/cr/crcpp/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cr/crd2pulumi/package.nix b/pkgs/by-name/cr/crd2pulumi/package.nix index cfb5acb30107c7..f14c9851b715a3 100644 --- a/pkgs/by-name/cr/crd2pulumi/package.nix +++ b/pkgs/by-name/cr/crd2pulumi/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "crd2pulumi"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-4L1KfpZ+KICPko74x3STRQFtkcNVU/5KFGhKEJ64+Jk="; - ldflags = [ "-s" "-w" "-X github.com/pulumi/crd2pulumi/gen.Version=${src.rev}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/pulumi/crd2pulumi/gen.Version=${src.rev}" + ]; subPackages = [ "." ]; diff --git a/pkgs/by-name/cr/cre2/package.nix b/pkgs/by-name/cr/cre2/package.nix index d85843a54f7c7e..af76bad7020eeb 100644 --- a/pkgs/by-name/cr/cre2/package.nix +++ b/pkgs/by-name/cr/cre2/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, - libtool, pkg-config, re2, texinfo }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libtool, + pkg-config, + re2, + texinfo, +}: stdenv.mkDerivation rec { pname = "cre2"; @@ -17,9 +25,12 @@ stdenv.mkDerivation rec { libtool pkg-config ]; - buildInputs = [ re2 texinfo ]; + buildInputs = [ + re2 + texinfo + ]; - NIX_LDFLAGS="-lre2 -lpthread"; + NIX_LDFLAGS = "-lre2 -lpthread"; configureFlags = [ "--enable-maintainer-mode" diff --git a/pkgs/by-name/cr/create-react-app/package.nix b/pkgs/by-name/cr/create-react-app/package.nix index bf7d23c0b2b3fb..2a2d2172d9f405 100644 --- a/pkgs/by-name/cr/create-react-app/package.nix +++ b/pkgs/by-name/cr/create-react-app/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/cr/createrepo_c/package.nix b/pkgs/by-name/cr/createrepo_c/package.nix index fc0628e09088a9..553c91b8fff333 100644 --- a/pkgs/by-name/cr/createrepo_c/package.nix +++ b/pkgs/by-name/cr/createrepo_c/package.nix @@ -1,5 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, bzip2, expat, glib, curl, libxml2, python3, rpm -, openssl, sqlite, file, xz, pcre, bash-completion, zstd, zchunk, libmodulemd +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + bzip2, + expat, + glib, + curl, + libxml2, + python3, + rpm, + openssl, + sqlite, + file, + xz, + pcre, + bash-completion, + zstd, + zchunk, + libmodulemd, }: stdenv.mkDerivation rec { @@ -7,9 +27,9 @@ stdenv.mkDerivation rec { version = "0.17.2"; src = fetchFromGitHub { - owner = "rpm-software-management"; - repo = "createrepo_c"; - rev = version; + owner = "rpm-software-management"; + repo = "createrepo_c"; + rev = version; sha256 = "sha256-rcrJjcWj+cTAE3k11Ynr7CQCOWD+rb60lcar0G2w06A="; }; @@ -27,16 +47,35 @@ stdenv.mkDerivation rec { --replace "@PYTHON_INSTALL_DIR@" "$out/${python3.sitePackages}" ''; - nativeBuildInputs = [ cmake pkg-config rpm ]; + nativeBuildInputs = [ + cmake + pkg-config + rpm + ]; - buildInputs = [ bzip2 expat glib curl libxml2 python3 openssl sqlite file xz pcre bash-completion zstd zchunk libmodulemd ]; + buildInputs = [ + bzip2 + expat + glib + curl + libxml2 + python3 + openssl + sqlite + file + xz + pcre + bash-completion + zstd + zchunk + libmodulemd + ]; meta = with lib; { description = "C implementation of createrepo"; - homepage = "https://rpm-software-management.github.io/createrepo_c/"; - license = licenses.gpl2Plus; - platforms = platforms.unix; + homepage = "https://rpm-software-management.github.io/createrepo_c/"; + license = licenses.gpl2Plus; + platforms = platforms.unix; maintainers = with maintainers; [ copumpkin ]; }; } - diff --git a/pkgs/by-name/cr/credential-detector/package.nix b/pkgs/by-name/cr/credential-detector/package.nix index 1297d158efe587..145f12910e8227 100644 --- a/pkgs/by-name/cr/credential-detector/package.nix +++ b/pkgs/by-name/cr/credential-detector/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-VWmfATUbfnI3eJbFTUp6MR1wGESuI15PHZWuon5M5rg="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Tool to detect potentially hard-coded credentials"; diff --git a/pkgs/by-name/cr/creds/package.nix b/pkgs/by-name/cr/creds/package.nix index ed34ad0df7c2e8..9758afeafbfa42 100644 --- a/pkgs/by-name/cr/creds/package.nix +++ b/pkgs/by-name/cr/creds/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/cr/credslayer/package.nix b/pkgs/by-name/cr/credslayer/package.nix index b6ed44c4f6ef69..8f660ca1725227 100644 --- a/pkgs/by-name/cr/credslayer/package.nix +++ b/pkgs/by-name/cr/credslayer/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3 -, wireshark-cli +{ + lib, + fetchFromGitHub, + python3, + wireshark-cli, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/cr/creep/package.nix b/pkgs/by-name/cr/creep/package.nix index fa4938798edc68..365f91e84909d5 100644 --- a/pkgs/by-name/cr/creep/package.nix +++ b/pkgs/by-name/cr/creep/package.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libfaketime -, xorg +{ + lib, + stdenv, + fetchFromGitHub, + libfaketime, + xorg, }: stdenv.mkDerivation rec { @@ -13,7 +17,11 @@ stdenv.mkDerivation rec { sha256 = "0zs21kznh1q883jfdgz74bb63i4lxlv98hj3ipp0wvsi6zw0vs8n"; }; - nativeBuildInputs = [ libfaketime xorg.fonttosfnt xorg.mkfontscale ]; + nativeBuildInputs = [ + libfaketime + xorg.fonttosfnt + xorg.mkfontscale + ]; buildPhase = '' faketime -f "1970-01-01 00:00:01" fonttosfnt -g 2 -m 2 -o creep.otb creep.bdf diff --git a/pkgs/by-name/cr/crex/package.nix b/pkgs/by-name/cr/crex/package.nix index d173457d719019..3958fd61d1e11d 100644 --- a/pkgs/by-name/cr/crex/package.nix +++ b/pkgs/by-name/cr/crex/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "crex"; diff --git a/pkgs/by-name/cr/cri-tools/package.nix b/pkgs/by-name/cr/cri-tools/package.nix index 7923f73ca52865..c0da20906e8668 100644 --- a/pkgs/by-name/cr/cri-tools/package.nix +++ b/pkgs/by-name/cr/cri-tools/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -28,17 +29,20 @@ buildGoModule rec { runHook postBuild ''; - installPhase = '' - runHook preInstall - make install BINDIR=$out/bin - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - for shell in bash fish zsh; do - installShellCompletion --cmd crictl \ - --$shell <($out/bin/crictl completion $shell) - done - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + make install BINDIR=$out/bin + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + for shell in bash fish zsh; do + installShellCompletion --cmd crictl \ + --$shell <($out/bin/crictl completion $shell) + done + '' + + '' + runHook postInstall + ''; meta = with lib; { description = "CLI and validation tools for Kubelet Container Runtime Interface (CRI)"; diff --git a/pkgs/by-name/cr/crimson-pro/package.nix b/pkgs/by-name/cr/crimson-pro/package.nix index 7b302b61eb9155..346737be8f107f 100644 --- a/pkgs/by-name/cr/crimson-pro/package.nix +++ b/pkgs/by-name/cr/crimson-pro/package.nix @@ -1,10 +1,17 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "crimson-pro"; version = "unstable-2022-08-30"; - outputs = [ "out" "woff2" ]; + outputs = [ + "out" + "woff2" + ]; src = fetchFromGitHub { owner = "Fonthausen"; diff --git a/pkgs/by-name/cr/crimson/package.nix b/pkgs/by-name/cr/crimson/package.nix index 82c9c9ace6c70f..4fc3b3e7af8dec 100644 --- a/pkgs/by-name/cr/crimson/package.nix +++ b/pkgs/by-name/cr/crimson/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "crimson"; diff --git a/pkgs/by-name/cr/cringify/package.nix b/pkgs/by-name/cr/cringify/package.nix index f9e4bc2f905003..bdd28b3c0233e2 100644 --- a/pkgs/by-name/cr/cringify/package.nix +++ b/pkgs/by-name/cr/cringify/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, python3 -, testers -, cringify +{ + lib, + rustPlatform, + fetchFromGitHub, + python3, + testers, + cringify, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/cr/crip/package.nix b/pkgs/by-name/cr/crip/package.nix index 67ccc367be0e8a..a244fc6d34fa7f 100644 --- a/pkgs/by-name/cr/crip/package.nix +++ b/pkgs/by-name/cr/crip/package.nix @@ -1,19 +1,21 @@ -{ lib, stdenv -, fetchurl -, makeWrapper +{ + lib, + stdenv, + fetchurl, + makeWrapper, -, perlPackages + perlPackages, -, cdparanoia -, coreutils -, eject -, flac -, gnugrep -, nano -, sox -, vorbis-tools -, vorbisgain -, which + cdparanoia, + coreutils, + eject, + flac, + gnugrep, + nano, + sox, + vorbis-tools, + vorbisgain, + which, }: stdenv.mkDerivation rec { @@ -24,7 +26,10 @@ stdenv.mkDerivation rec { sha256 = "0pk9152wll6fmkj1pki3fz3ijlf06jyk32v31yarwvdkwrk7s9xz"; }; - buildInputs = [ perlPackages.perl perlPackages.CDDB_get ]; + buildInputs = [ + perlPackages.perl + perlPackages.CDDB_get + ]; nativeBuildInputs = [ makeWrapper ]; toolDeps = lib.makeBinPath [ @@ -39,7 +44,11 @@ stdenv.mkDerivation rec { which ]; - scripts = [ "crip" "editcomment" "editfilenames" ]; + scripts = [ + "crip" + "editcomment" + "editfilenames" + ]; installPhase = '' mkdir -p $out/bin/ diff --git a/pkgs/by-name/cr/crispy-doom/package.nix b/pkgs/by-name/cr/crispy-doom/package.nix index 5da041f55fa786..7c4cc2cbb24645 100644 --- a/pkgs/by-name/cr/crispy-doom/package.nix +++ b/pkgs/by-name/cr/crispy-doom/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, autoreconfHook, pkg-config, SDL2, SDL2_mixer, SDL2_net, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + autoreconfHook, + pkg-config, + SDL2, + SDL2_mixer, + SDL2_net, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation rec { pname = "crispy-doom"; @@ -16,8 +26,16 @@ stdenv.mkDerivation rec { for script in $(grep -lr '^#!/usr/bin/env python3$'); do patchShebangs $script; done ''; - nativeBuildInputs = [ autoreconfHook pkg-config python3 ]; - buildInputs = [ SDL2 SDL2_mixer SDL2_net ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + python3 + ]; + buildInputs = [ + SDL2 + SDL2_mixer + SDL2_net + ]; enableParallelBuilding = true; strictDeps = true; diff --git a/pkgs/by-name/cr/critcmp/package.nix b/pkgs/by-name/cr/critcmp/package.nix index 0c142bbf251491..b15754fdf12e9f 100644 --- a/pkgs/by-name/cr/critcmp/package.nix +++ b/pkgs/by-name/cr/critcmp/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,10 @@ rustPlatform.buildRustPackage rec { description = "Command line tool for comparing benchmarks run by Criterion"; mainProgram = "critcmp"; homepage = "https://github.com/BurntSushi/critcmp"; - license = with licenses; [ mit unlicense ]; + license = with licenses; [ + mit + unlicense + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/cr/criterion/package.nix b/pkgs/by-name/cr/criterion/package.nix index 1b48227dcb33b5..958a9a7c89ed53 100644 --- a/pkgs/by-name/cr/criterion/package.nix +++ b/pkgs/by-name/cr/criterion/package.nix @@ -18,7 +18,7 @@ python3Packages, testers, criterion, - callPackage + callPackage, }: let @@ -95,7 +95,7 @@ stdenv.mkDerivation rec { passthru.tests.version = let - tester = callPackage ./tests/001-version.nix {}; + tester = callPackage ./tests/001-version.nix { }; in testers.testVersion { package = criterion; diff --git a/pkgs/by-name/cr/criu/package.nix b/pkgs/by-name/cr/criu/package.nix index 5a6df6e44c1434..b49c526af18373 100644 --- a/pkgs/by-name/cr/criu/package.nix +++ b/pkgs/by-name/cr/criu/package.nix @@ -1,7 +1,29 @@ -{ stdenv, lib, fetchFromGitHub, protobuf, protobufc, asciidoc, iptables -, xmlto, docbook_xsl, libpaper, libnl, libcap, libnet, pkg-config, iproute2, gzip -, which, python3, makeWrapper, docbook_xml_dtd_45, perl, nftables, libbsd, gnutar -, buildPackages +{ + stdenv, + lib, + fetchFromGitHub, + protobuf, + protobufc, + asciidoc, + iptables, + xmlto, + docbook_xsl, + libpaper, + libnl, + libcap, + libnet, + pkg-config, + iproute2, + gzip, + which, + python3, + makeWrapper, + docbook_xml_dtd_45, + perl, + nftables, + libbsd, + gnutar, + buildPackages, }: stdenv.mkDerivation rec { @@ -16,7 +38,10 @@ stdenv.mkDerivation rec { }; enableParallelBuilding = true; - depsBuildBuild = [ protobufc buildPackages.stdenv.cc ]; + depsBuildBuild = [ + protobufc + buildPackages.stdenv.cc + ]; nativeBuildInputs = [ pkg-config asciidoc @@ -38,12 +63,14 @@ stdenv.mkDerivation rec { nftables libbsd ]; - propagatedBuildInputs = [ - protobufc - ] ++ (with python3.pkgs; [ - python - python3.pkgs.protobuf - ]); + propagatedBuildInputs = + [ + protobufc + ] + ++ (with python3.pkgs; [ + python + python3.pkgs.protobuf + ]); postPatch = '' substituteInPlace ./Documentation/Makefile \ @@ -53,36 +80,46 @@ stdenv.mkDerivation rec { ln -sf ${protobuf}/include/google/protobuf/descriptor.proto ./images/google/protobuf/descriptor.proto ''; - makeFlags = let - # criu's Makefile infrastructure expects to be passed a target architecture - # which neither matches the config-tuple's first part, nor the - # targetPlatform.linuxArch attribute. Thus we take the latter and map it - # onto the expected string: - linuxArchMapping = { - "x86_64" = "x86"; - "arm" = "arm"; - "arm64" = "aarch64"; - "powerpc" = "ppc64"; - "s390" = "s390"; - "mips" = "mips"; - }; - in [ - "PREFIX=$(out)" - "ASCIIDOC=${buildPackages.asciidoc}/bin/asciidoc" - "XMLTO=${buildPackages.xmlto}/bin/xmlto" - ] ++ (lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ - "ARCH=${linuxArchMapping."${stdenv.hostPlatform.linuxArch}"}" - "CROSS_COMPILE=${stdenv.hostPlatform.config}-" - ]); + makeFlags = + let + # criu's Makefile infrastructure expects to be passed a target architecture + # which neither matches the config-tuple's first part, nor the + # targetPlatform.linuxArch attribute. Thus we take the latter and map it + # onto the expected string: + linuxArchMapping = { + "x86_64" = "x86"; + "arm" = "arm"; + "arm64" = "aarch64"; + "powerpc" = "ppc64"; + "s390" = "s390"; + "mips" = "mips"; + }; + in + [ + "PREFIX=$(out)" + "ASCIIDOC=${buildPackages.asciidoc}/bin/asciidoc" + "XMLTO=${buildPackages.xmlto}/bin/xmlto" + ] + ++ (lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "ARCH=${linuxArchMapping."${stdenv.hostPlatform.linuxArch}"}" + "CROSS_COMPILE=${stdenv.hostPlatform.config}-" + ]); - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; preBuild = '' # No idea why but configure scripts break otherwise. export SHELL="" ''; - hardeningDisable = [ "stackprotector" "fortify" ]; + hardeningDisable = [ + "stackprotector" + "fortify" + ]; # dropping fortify here as well as package uses it by default: # command-line>:0:0: error: "_FORTIFY_SOURCE" redefined [-Werror] @@ -90,15 +127,24 @@ stdenv.mkDerivation rec { wrapProgram $out/bin/criu \ --set-default CR_IPTABLES ${iptables}/bin/iptables \ --set-default CR_IP_TOOL ${iproute2}/bin/ip \ - --prefix PATH : ${lib.makeBinPath [ gnutar gzip ]} + --prefix PATH : ${ + lib.makeBinPath [ + gnutar + gzip + ] + } wrapPythonPrograms ''; meta = with lib; { description = "Userspace checkpoint/restore for Linux"; - homepage = "https://criu.org"; - license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "aarch64-linux" "armv7l-linux" ]; + homepage = "https://criu.org"; + license = licenses.gpl2Plus; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "armv7l-linux" + ]; maintainers = [ maintainers.thoughtpolice ]; }; } diff --git a/pkgs/by-name/cr/crlfsuite/package.nix b/pkgs/by-name/cr/crlfsuite/package.nix index dfd1c7098c2f97..0a0d68d0b117d9 100644 --- a/pkgs/by-name/cr/crlfsuite/package.nix +++ b/pkgs/by-name/cr/crlfsuite/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -32,6 +33,9 @@ python3.pkgs.buildPythonApplication rec { mainProgram = "crlfsuite"; homepage = "https://github.com/Nefcore/CRLFsuite"; license = licenses.mit; - maintainers = with maintainers; [ c0bw3b fab ]; + maintainers = with maintainers; [ + c0bw3b + fab + ]; }; } diff --git a/pkgs/by-name/cr/crlfuzz/package.nix b/pkgs/by-name/cr/crlfuzz/package.nix index ab2ee1e7a46efb..f9b750da7642ef 100644 --- a/pkgs/by-name/cr/crlfuzz/package.nix +++ b/pkgs/by-name/cr/crlfuzz/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/cr/cro-mag-rally/package.nix b/pkgs/by-name/cr/cro-mag-rally/package.nix index 93ca67f0a86a97..0cc55c3fb0f6d0 100644 --- a/pkgs/by-name/cr/cro-mag-rally/package.nix +++ b/pkgs/by-name/cr/cro-mag-rally/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL2 -, cmake -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + cmake, + makeWrapper, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/cr/croaring/package.nix b/pkgs/by-name/cr/croaring/package.nix index 88643c00195ae2..70d6a688470912 100644 --- a/pkgs/by-name/cr/croaring/package.nix +++ b/pkgs/by-name/cr/croaring/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "croaring"; @@ -22,18 +27,23 @@ stdenv.mkDerivation rec { preConfigure = '' mkdir -p dependencies/.cache - ln -s ${fetchFromGitHub { - owner = "clibs"; - repo = "cmocka"; - rev = "f5e2cd7"; - hash = "sha256-Oq0nFsZhl8IF7kQN/LgUq8VBy+P7gO98ep/siy5A7Js="; - }} dependencies/.cache/cmocka + ln -s ${ + fetchFromGitHub { + owner = "clibs"; + repo = "cmocka"; + rev = "f5e2cd7"; + hash = "sha256-Oq0nFsZhl8IF7kQN/LgUq8VBy+P7gO98ep/siy5A7Js="; + } + } dependencies/.cache/cmocka ''; meta = with lib; { description = "Compressed bitset library for C and C++"; homepage = "https://roaringbitmap.org/"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = [ maintainers.orivej ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/cr/croc/package.nix b/pkgs/by-name/cr/croc/package.nix index cfd0d2c7f0573a..9274cc315732df 100644 --- a/pkgs/by-name/cr/croc/package.nix +++ b/pkgs/by-name/cr/croc/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, callPackage, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + callPackage, + nixosTests, +}: buildGoModule rec { pname = "croc"; @@ -38,7 +44,10 @@ buildGoModule rec { ''; homepage = "https://github.com/schollz/croc"; license = licenses.mit; - maintainers = with maintainers; [ equirosa SuperSandro2000 ]; + maintainers = with maintainers; [ + equirosa + SuperSandro2000 + ]; mainProgram = "croc"; }; } diff --git a/pkgs/by-name/cr/cromfs/package.nix b/pkgs/by-name/cr/cromfs/package.nix index f3bacd2c40fa1d..99e9dff260cccf 100644 --- a/pkgs/by-name/cr/cromfs/package.nix +++ b/pkgs/by-name/cr/cromfs/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, fuse, perl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + fuse, + perl, +}: stdenv.mkDerivation rec { pname = "cromfs"; @@ -20,7 +27,10 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ fuse perl ]; + buildInputs = [ + fuse + perl + ]; makeFlags = [ "CXXFLAGS=-std=c++03" ]; diff --git a/pkgs/by-name/cr/crossguid/package.nix b/pkgs/by-name/cr/crossguid/package.nix index cd8f95957c4ebf..238d4e834daf71 100644 --- a/pkgs/by-name/cr/crossguid/package.nix +++ b/pkgs/by-name/cr/crossguid/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, libuuid, unstableGitUpdater }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + libuuid, + unstableGitUpdater, +}: stdenv.mkDerivation rec { pname = "crossguid"; diff --git a/pkgs/by-name/cr/crossplane-cli/package.nix b/pkgs/by-name/cr/crossplane-cli/package.nix index 66b0fd3e7592cf..1578a2b576408a 100644 --- a/pkgs/by-name/cr/crossplane-cli/package.nix +++ b/pkgs/by-name/cr/crossplane-cli/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script -, testers -, crossplane-cli +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + testers, + crossplane-cli, }: buildGoModule rec { diff --git a/pkgs/by-name/cr/crosswords/package.nix b/pkgs/by-name/cr/crosswords/package.nix index 91bbd5c6e88f84..bd1003ab86473f 100644 --- a/pkgs/by-name/cr/crosswords/package.nix +++ b/pkgs/by-name/cr/crosswords/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, desktop-file-utils -, libadwaita -, isocodes -, json-glib -, libipuz +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + desktop-file-utils, + libadwaita, + isocodes, + json-glib, + libipuz, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cr/crow-translate/package.nix b/pkgs/by-name/cr/crow-translate/package.nix index 304a4dbac53a41..3b8dc307fa124d 100644 --- a/pkgs/by-name/cr/crow-translate/package.nix +++ b/pkgs/by-name/cr/crow-translate/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitLab -, cmake -, extra-cmake-modules -, leptonica -, libsForQt5 -, qt5 -, tesseract4 -, gst_all_1 -, testers +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + extra-cmake-modules, + leptonica, + libsForQt5, + qt5, + tesseract4, + gst_all_1, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -36,18 +37,20 @@ stdenv.mkDerivation (finalAttrs: { qt5.wrapQtAppsHook ]; - buildInputs = [ - libsForQt5.kwayland - leptonica - tesseract4 - qt5.qtmultimedia - qt5.qtx11extras - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-good - gst-plugins-bad - ]); + buildInputs = + [ + libsForQt5.kwayland + leptonica + tesseract4 + qt5.qtmultimedia + qt5.qtx11extras + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + ]); preFixup = '' qtWrapperArgs+=(--prefix GST_PLUGIN_SYSTEM_PATH_1_0 : "$GST_PLUGIN_SYSTEM_PATH_1_0") diff --git a/pkgs/by-name/cr/crowbar/package.nix b/pkgs/by-name/cr/crowbar/package.nix index 114fdca5a85dca..8cd303b6b72f15 100644 --- a/pkgs/by-name/cr/crowbar/package.nix +++ b/pkgs/by-name/cr/crowbar/package.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, freerdp -, nmap -, openvpn -, python3Packages -, lib -, tigervnc +{ + fetchFromGitHub, + freerdp, + nmap, + openvpn, + python3Packages, + lib, + tigervnc, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/cr/crowdin-cli/package.nix b/pkgs/by-name/cr/crowdin-cli/package.nix index d0431f3569fade..4b80ed83fee286 100644 --- a/pkgs/by-name/cr/crowdin-cli/package.nix +++ b/pkgs/by-name/cr/crowdin-cli/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, gawk -, git -, gnugrep -, installShellFiles -, jre -, makeWrapper -, testers -, unzip +{ + lib, + stdenv, + fetchurl, + gawk, + git, + gnugrep, + installShellFiles, + jre, + makeWrapper, + testers, + unzip, }: stdenv.mkDerivation (finalAttrs: { @@ -20,7 +21,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-u1drLK/eLvNijCL3BupXyAO7yb+FD9EQwD0+9hQJsgQ="; }; - nativeBuildInputs = [ installShellFiles makeWrapper unzip ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + unzip + ]; installPhase = '' runHook preInstall @@ -32,7 +37,13 @@ stdenv.mkDerivation (finalAttrs: { makeWrapper ${jre}/bin/java $out/bin/crowdin \ --argv0 crowdin \ --add-flags "-jar $out/lib/crowdin-cli.jar" \ - --prefix PATH : ${lib.makeBinPath [ gawk gnugrep git ]} + --prefix PATH : ${ + lib.makeBinPath [ + gawk + gnugrep + git + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/cr/crowdsec/package.nix b/pkgs/by-name/cr/crowdsec/package.nix index 5729969a9cd962..4a982cf61810d3 100644 --- a/pkgs/by-name/cr/crowdsec/package.nix +++ b/pkgs/by-name/cr/crowdsec/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "crowdsec"; @@ -64,6 +69,9 @@ buildGoModule rec { being shared among all users to further improve everyone's security. ''; license = licenses.mit; - maintainers = with maintainers; [ jk urandom ]; + maintainers = with maintainers; [ + jk + urandom + ]; }; } diff --git a/pkgs/by-name/cr/crrcsim/package.nix b/pkgs/by-name/cr/crrcsim/package.nix index 29aa64c3459ee7..c4bd7f1e1a146e 100644 --- a/pkgs/by-name/cr/crrcsim/package.nix +++ b/pkgs/by-name/cr/crrcsim/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, libGLU, libGL, SDL, SDL_mixer, plib, libjpeg }: +{ + lib, + stdenv, + fetchurl, + libGLU, + libGL, + SDL, + SDL_mixer, + plib, + libjpeg, +}: let version = "0.9.13"; in @@ -12,7 +22,12 @@ stdenv.mkDerivation rec { }; buildInputs = [ - libGLU libGL SDL SDL_mixer plib libjpeg + libGLU + libGL + SDL + SDL_mixer + plib + libjpeg ]; patches = [ @@ -23,7 +38,10 @@ stdenv.mkDerivation rec { description = "Model-airplane flight simulator"; mainProgram = "crrcsim"; maintainers = with lib.maintainers; [ raskin ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; license = lib.licenses.gpl2Only; }; } diff --git a/pkgs/by-name/cr/crudini/package.nix b/pkgs/by-name/cr/crudini/package.nix index 041a0095fb1c78..ae8387c374b36c 100644 --- a/pkgs/by-name/cr/crudini/package.nix +++ b/pkgs/by-name/cr/crudini/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, python3Packages -, help2man -, installShellFiles +{ + lib, + fetchFromGitHub, + python3Packages, + help2man, + installShellFiles, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/cr/crumbs/package.nix b/pkgs/by-name/cr/crumbs/package.nix index 7dbcf74faf7ec0..cc0a7aab71e705 100644 --- a/pkgs/by-name/cr/crumbs/package.nix +++ b/pkgs/by-name/cr/crumbs/package.nix @@ -1,15 +1,19 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "crumbs"; version = "0.0.3"; - src = fetchFromGitHub - { owner = "fasseg"; - repo = "crumbs"; - rev = version; - sha256 = "0jjvydn4i4n9xv8vsal2jxpa95mk2lw6myv0gx9wih242k9vy0l7"; - }; + src = fetchFromGitHub { + owner = "fasseg"; + repo = "crumbs"; + rev = version; + sha256 = "0jjvydn4i4n9xv8vsal2jxpa95mk2lw6myv0gx9wih242k9vy0l7"; + }; prePatch = '' sed -i 's|gfind|find|' crumbs-completion.fish @@ -23,12 +27,12 @@ stdenv.mkDerivation rec { cp crumbs-completion.fish $out/share/fish/vendor_completions.d/crumbs.fish ''; - meta = with lib; - { description = "Bookmarks for the command line"; - homepage = "https://github.com/fasseg/crumbs"; - license = licenses.wtfpl; - platforms = platforms.all; - maintainers = with maintainers; [ thesola10 ]; - mainProgram = "crumbs"; - }; + meta = with lib; { + description = "Bookmarks for the command line"; + homepage = "https://github.com/fasseg/crumbs"; + license = licenses.wtfpl; + platforms = platforms.all; + maintainers = with maintainers; [ thesola10 ]; + mainProgram = "crumbs"; + }; } diff --git a/pkgs/by-name/cr/crunch/package.nix b/pkgs/by-name/cr/crunch/package.nix index 146a67605847fc..e09c652b988dca 100644 --- a/pkgs/by-name/cr/crunch/package.nix +++ b/pkgs/by-name/cr/crunch/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, which }: +{ + lib, + stdenv, + fetchurl, + which, +}: stdenv.mkDerivation rec { pname = "crunch"; diff --git a/pkgs/by-name/cr/crunchy-cli/package.nix b/pkgs/by-name/cr/crunchy-cli/package.nix index 21a8a5b8cb3445..d895a383dd7df4 100644 --- a/pkgs/by-name/cr/crunchy-cli/package.nix +++ b/pkgs/by-name/cr/crunchy-cli/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, darwin -, fetchFromGitHub -, openssl -, pkg-config -, rustPlatform -, nix-update-script +{ + lib, + stdenv, + darwin, + fetchFromGitHub, + openssl, + pkg-config, + rustPlatform, + nix-update-script, }: rustPlatform.buildRustPackage rec { @@ -30,11 +31,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; env = { OPENSSL_NO_VENDOR = true; diff --git a/pkgs/by-name/cr/cryfs/package.nix b/pkgs/by-name/cr/cryfs/package.nix index 6d64973e8cebeb..e5e6596766008c 100644 --- a/pkgs/by-name/cr/cryfs/package.nix +++ b/pkgs/by-name/cr/cryfs/package.nix @@ -1,9 +1,19 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, pkg-config, python3 -, boost, curl, fuse, openssl, range-v3, spdlog -# cryptopp and gtest on standby - using the vendored ones for now -# see https://github.com/cryfs/cryfs/issues/369 -, llvmPackages +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + python3, + boost, + curl, + fuse, + openssl, + range-v3, + spdlog, + # cryptopp and gtest on standby - using the vendored ones for now + # see https://github.com/cryfs/cryfs/issues/369 + llvmPackages, }: stdenv.mkDerivation rec { @@ -37,12 +47,22 @@ stdenv.mkDerivation rec { --replace "(4.5L*1024*1024*1024)" "(0.5L*1024*1024*1024)" ''; - nativeBuildInputs = [ cmake pkg-config python3 ]; + nativeBuildInputs = [ + cmake + pkg-config + python3 + ]; strictDeps = true; - buildInputs = [ boost curl fuse openssl range-v3 spdlog ] - ++ lib.optional stdenv.cc.isClang llvmPackages.openmp; + buildInputs = [ + boost + curl + fuse + openssl + range-v3 + spdlog + ] ++ lib.optional stdenv.cc.isClang llvmPackages.openmp; #nativeCheckInputs = [ gtest ]; @@ -72,10 +92,14 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Cryptographic filesystem for the cloud"; - homepage = "https://www.cryfs.org/"; - changelog = "https://github.com/cryfs/cryfs/raw/${version}/ChangeLog.txt"; - license = licenses.lgpl3Only; - maintainers = with maintainers; [ peterhoeg c0bw3b sigmasquadron ]; - platforms = platforms.unix; + homepage = "https://www.cryfs.org/"; + changelog = "https://github.com/cryfs/cryfs/raw/${version}/ChangeLog.txt"; + license = licenses.lgpl3Only; + maintainers = with maintainers; [ + peterhoeg + c0bw3b + sigmasquadron + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/cr/crypto-org-wallet/package.nix b/pkgs/by-name/cr/crypto-org-wallet/package.nix index 6132fd9af3ecc5..8d9dd44be874b0 100644 --- a/pkgs/by-name/cr/crypto-org-wallet/package.nix +++ b/pkgs/by-name/cr/crypto-org-wallet/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, appimageTools, imagemagick }: +{ + lib, + fetchurl, + appimageTools, + imagemagick, +}: let pname = "chain-desktop-wallet"; @@ -10,7 +15,8 @@ let }; appimageContents = appimageTools.extractType2 { inherit pname version src; }; -in appimageTools.wrapType2 rec { +in +appimageTools.wrapType2 rec { inherit pname version src; extraInstallCommands = '' diff --git a/pkgs/by-name/cr/crypto-tracker/package.nix b/pkgs/by-name/cr/crypto-tracker/package.nix index 273a0aa63e4c03..34c3c634095951 100644 --- a/pkgs/by-name/cr/crypto-tracker/package.nix +++ b/pkgs/by-name/cr/crypto-tracker/package.nix @@ -1,13 +1,17 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "crypto-tracker"; version = "0.1.8"; src = fetchFromGitHub { - owner = "Nox04"; - repo = "crypto-tracker"; - rev = "v${version}"; + owner = "Nox04"; + repo = "crypto-tracker"; + rev = "v${version}"; hash = "sha256-8tTaXpHZWcDq0Jfa9Hf258VYwfimLhYjCAzD4X/Ow0s="; }; diff --git a/pkgs/by-name/cr/cryptominisat/package.nix b/pkgs/by-name/cr/cryptominisat/package.nix index 7c2ee23d36cb88..9c99d0c0555f3e 100644 --- a/pkgs/by-name/cr/cryptominisat/package.nix +++ b/pkgs/by-name/cr/cryptominisat/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, python3 -, boost +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, + boost, }: stdenv.mkDerivation rec { @@ -19,7 +20,10 @@ stdenv.mkDerivation rec { strictDeps = true; buildInputs = [ boost ]; - nativeBuildInputs = [ python3 cmake ]; + nativeBuildInputs = [ + python3 + cmake + ]; # musl does not have sys/unistd.h postPatch = '' diff --git a/pkgs/by-name/cr/cryptopp/package.nix b/pkgs/by-name/cr/cryptopp/package.nix index 741e9677f7102e..bb7e856d3ccee1 100644 --- a/pkgs/by-name/cr/cryptopp/package.nix +++ b/pkgs/by-name/cr/cryptopp/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, enableStatic ? stdenv.hostPlatform.isStatic -, enableShared ? !enableStatic -# Multi-threading with OpenMP is disabled by default -# more info on https://www.cryptopp.com/wiki/OpenMP -, withOpenMP ? false -, llvmPackages +{ + lib, + stdenv, + fetchFromGitHub, + enableStatic ? stdenv.hostPlatform.isStatic, + enableShared ? !enableStatic, + # Multi-threading with OpenMP is disabled by default + # more info on https://www.cryptopp.com/wiki/OpenMP + withOpenMP ? false, + llvmPackages, }: stdenv.mkDerivation rec { pname = "crypto++"; version = "8.9.0"; - underscoredVersion = lib.strings.replaceStrings ["."] ["_"] version; + underscoredVersion = lib.strings.replaceStrings [ "." ] [ "_" ] version; src = fetchFromGitHub { owner = "weidai11"; @@ -21,7 +22,10 @@ stdenv.mkDerivation rec { hash = "sha256-HV+afSFkiXdy840JbHBTR8lLL0GMwsN3QdwaoQmicpQ="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postPatch = '' substituteInPlace GNUmakefile \ @@ -34,9 +38,7 @@ stdenv.mkDerivation rec { makeFlags = [ "PREFIX=${placeholder "out"}" ]; buildFlags = - lib.optional enableStatic "static" - ++ lib.optional enableShared "shared" - ++ [ "libcryptopp.pc" ]; + lib.optional enableStatic "static" ++ lib.optional enableShared "shared" ++ [ "libcryptopp.pc" ]; enableParallelBuilding = true; hardeningDisable = [ "fortify" ]; @@ -57,7 +59,10 @@ stdenv.mkDerivation rec { "https://raw.githubusercontent.com/weidai11/cryptopp/CRYPTOPP_${underscoredVersion}/History.txt" "https://github.com/weidai11/cryptopp/releases/tag/CRYPTOPP_${underscoredVersion}" ]; - license = with licenses; [ boost publicDomain ]; + license = with licenses; [ + boost + publicDomain + ]; platforms = platforms.all; maintainers = with maintainers; [ c0bw3b ]; }; diff --git a/pkgs/by-name/cr/cryptor/package.nix b/pkgs/by-name/cr/cryptor/package.nix index b48662b2992fc1..7620fd0b912173 100644 --- a/pkgs/by-name/cr/cryptor/package.nix +++ b/pkgs/by-name/cr/cryptor/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeBinaryWrapper -, meson -, ninja -, pkg-config -, vala -, wrapGAppsHook3 -, gocryptfs -, gtk3 -, json-glib -, libgee +{ + lib, + stdenv, + fetchFromGitHub, + makeBinaryWrapper, + meson, + ninja, + pkg-config, + vala, + wrapGAppsHook3, + gocryptfs, + gtk3, + json-glib, + libgee, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/cr/cryptoverif/package.nix b/pkgs/by-name/cr/cryptoverif/package.nix index 7d0a93d144f7a5..e23707651298cd 100644 --- a/pkgs/by-name/cr/cryptoverif/package.nix +++ b/pkgs/by-name/cr/cryptoverif/package.nix @@ -1,17 +1,25 @@ -{ lib, stdenv, fetchurl, ocaml, writeScript }: +{ + lib, + stdenv, + fetchurl, + ocaml, + writeScript, +}: stdenv.mkDerivation (finalAttrs: { pname = "cryptoverif"; version = "2.11"; src = fetchurl { - url = "http://prosecco.gforge.inria.fr/personal/bblanche/cryptoverif/cryptoverif${finalAttrs.version}.tar.gz"; + url = "http://prosecco.gforge.inria.fr/personal/bblanche/cryptoverif/cryptoverif${finalAttrs.version}.tar.gz"; hash = "sha256-duc7t0Qpr1Z2FZEoufdQ7kcBlLbXHO+r9ivEgUxqK9s="; }; - /* Fix up the frontend to load the 'default' cryptoverif library - ** from under $out/libexec. By default, it expects to find the files - ** in $CWD which doesn't work. */ + /* + Fix up the frontend to load the 'default' cryptoverif library + ** from under $out/libexec. By default, it expects to find the files + ** in $CWD which doesn't work. + */ postPatch = '' substituteInPlace ./src/syntax.ml \ --replace \"default\" \"$out/libexec/default\" @@ -55,9 +63,9 @@ stdenv.mkDerivation (finalAttrs: { meta = { description = "Cryptographic protocol verifier in the computational model"; mainProgram = "cryptoverif"; - homepage = "https://bblanche.gitlabpages.inria.fr/CryptoVerif/"; - license = lib.licenses.cecill-b; - platforms = lib.platforms.unix; + homepage = "https://bblanche.gitlabpages.inria.fr/CryptoVerif/"; + license = lib.licenses.cecill-b; + platforms = lib.platforms.unix; maintainers = [ lib.maintainers.thoughtpolice ]; }; }) diff --git a/pkgs/by-name/cr/cryptsetup/package.nix b/pkgs/by-name/cr/cryptsetup/package.nix index 8713325b00bcde..8c35acda3e72a8 100644 --- a/pkgs/by-name/cr/cryptsetup/package.nix +++ b/pkgs/by-name/cr/cryptsetup/package.nix @@ -1,22 +1,38 @@ -{ lib, stdenv, fetchurl, lvm2, json_c, asciidoctor -, openssl, libuuid, pkg-config, popt, nixosTests -, libargon2, withInternalArgon2 ? false +{ + lib, + stdenv, + fetchurl, + lvm2, + json_c, + asciidoctor, + openssl, + libuuid, + pkg-config, + popt, + nixosTests, + libargon2, + withInternalArgon2 ? false, # Programs enabled by default upstream are implicitly enabled unless # manually set to false. -, programs ? {} + programs ? { }, # The release tarballs contain precomputed manpage files, so we don't need # to run asciidoctor on the man sources. By avoiding asciidoctor, we make # the bare NixOS build hash independent of changes to the ruby ecosystem, # saving mass-rebuilds. -, rebuildMan ? false + rebuildMan ? false, }: stdenv.mkDerivation rec { pname = "cryptsetup"; version = "2.7.5"; - outputs = [ "bin" "out" "dev" "man" ]; + outputs = [ + "bin" + "out" + "dev" + "man" + ]; separateDebugInfo = true; src = fetchurl { @@ -40,23 +56,34 @@ stdenv.mkDerivation rec { NIX_LDFLAGS = lib.optionalString (stdenv.cc.isGNU && !stdenv.hostPlatform.isStatic) "-lgcc_s"; - configureFlags = [ - "--with-crypto_backend=openssl" - "--disable-ssh-token" - ] ++ lib.optionals (!rebuildMan) [ - "--disable-asciidoc" - ] ++ lib.optionals (!withInternalArgon2) [ - "--enable-libargon2" - ] ++ lib.optionals stdenv.hostPlatform.isStatic [ - "--disable-external-tokens" - # We have to override this even though we're removing token - # support, because the path still gets included in the binary even - # though it isn't used. - "--with-luks2-external-tokens-path=/" - ] ++ (lib.mapAttrsToList (lib.flip lib.enableFeature)) programs; + configureFlags = + [ + "--with-crypto_backend=openssl" + "--disable-ssh-token" + ] + ++ lib.optionals (!rebuildMan) [ + "--disable-asciidoc" + ] + ++ lib.optionals (!withInternalArgon2) [ + "--enable-libargon2" + ] + ++ lib.optionals stdenv.hostPlatform.isStatic [ + "--disable-external-tokens" + # We have to override this even though we're removing token + # support, because the path still gets included in the binary even + # though it isn't used. + "--with-luks2-external-tokens-path=/" + ] + ++ (lib.mapAttrsToList (lib.flip lib.enableFeature)) programs; nativeBuildInputs = [ pkg-config ] ++ lib.optionals rebuildMan [ asciidoctor ]; - buildInputs = [ lvm2 json_c openssl libuuid popt ] ++ lib.optional (!withInternalArgon2) libargon2; + buildInputs = [ + lvm2 + json_c + openssl + libuuid + popt + ] ++ lib.optional (!withInternalArgon2) libargon2; # The test [7] header backup in compat-test fails with a mysterious # "out of memory" error, even though tons of memory is available. @@ -65,14 +92,11 @@ stdenv.mkDerivation rec { passthru = { tests = { - nixos = - lib.optionalAttrs stdenv.hostPlatform.isLinux ( - lib.recurseIntoAttrs ( - lib.filterAttrs - (name: _value: lib.hasPrefix "luks" name) - nixosTests.installer - ) - ); + nixos = lib.optionalAttrs stdenv.hostPlatform.isLinux ( + lib.recurseIntoAttrs ( + lib.filterAttrs (name: _value: lib.hasPrefix "luks" name) nixosTests.installer + ) + ); }; }; diff --git a/pkgs/by-name/cr/crystal2nix/package.nix b/pkgs/by-name/cr/crystal2nix/package.nix index 2ba0fefd6aba6a..8232e8e42d7ed8 100644 --- a/pkgs/by-name/cr/crystal2nix/package.nix +++ b/pkgs/by-name/cr/crystal2nix/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, crystal, makeWrapper, nix-prefetch-git }: +{ + lib, + fetchFromGitHub, + crystal, + makeWrapper, + nix-prefetch-git, +}: crystal.buildCrystalPackage rec { pname = "crystal2nix"; @@ -31,6 +37,9 @@ crystal.buildCrystalPackage rec { description = "Utility to convert Crystal's shard.lock files to a Nix file"; mainProgram = "crystal2nix"; license = licenses.mit; - maintainers = with maintainers; [ manveru peterhoeg ]; + maintainers = with maintainers; [ + manveru + peterhoeg + ]; }; } diff --git a/pkgs/by-name/cs/csa/package.nix b/pkgs/by-name/cs/csa/package.nix index a861d8b0a47798..a839c9b9f5da54 100644 --- a/pkgs/by-name/cs/csa/package.nix +++ b/pkgs/by-name/cs/csa/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "csa"; diff --git a/pkgs/by-name/cs/cscope/package.nix b/pkgs/by-name/cs/cscope/package.nix index f306478948bc1f..6e836948008cd0 100644 --- a/pkgs/by-name/cs/cscope/package.nix +++ b/pkgs/by-name/cs/cscope/package.nix @@ -1,5 +1,10 @@ -{ fetchurl, lib, stdenv, ncurses -, emacsSupport ? true, emacs +{ + fetchurl, + lib, + stdenv, + ncurses, + emacsSupport ? true, + emacs, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cs/csdp/package.nix b/pkgs/by-name/cs/csdp/package.nix index c0f863a6d26b58..305e98e851a62c 100644 --- a/pkgs/by-name/cs/csdp/package.nix +++ b/pkgs/by-name/cs/csdp/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, blas, gfortran, lapack }: +{ + lib, + stdenv, + fetchurl, + blas, + gfortran, + lapack, +}: stdenv.mkDerivation rec { pname = "csdp"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "1f9ql6cjy2gwiyc51ylfan24v1ca9sjajxkbhszlds1lqmma8n05"; }; - buildInputs = [ blas gfortran.cc.lib lapack ]; + buildInputs = [ + blas + gfortran.cc.lib + lapack + ]; postPatch = '' substituteInPlace Makefile --replace /usr/local/bin $out/bin diff --git a/pkgs/by-name/cs/csdr/package.nix b/pkgs/by-name/cs/csdr/package.nix index 65bbdbb05dac52..9170ea63cd0b10 100644 --- a/pkgs/by-name/cs/csdr/package.nix +++ b/pkgs/by-name/cs/csdr/package.nix @@ -1,5 +1,11 @@ -{ stdenv, lib, fetchFromGitHub -, cmake, pkg-config, fftwFloat, libsamplerate +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + fftwFloat, + libsamplerate, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cs/csfml/package.nix b/pkgs/by-name/cs/csfml/package.nix index 397d5186a1c4f7..08d98928d77e9f 100644 --- a/pkgs/by-name/cs/csfml/package.nix +++ b/pkgs/by-name/cs/csfml/package.nix @@ -1,12 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, cmake, sfml }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + sfml, +}: stdenv.mkDerivation rec { pname = "csfml"; version = "2.5.2"; src = fetchFromGitHub { owner = "SFML"; - repo = "CSFML"; - rev = version; + repo = "CSFML"; + rev = version; sha256 = "sha256-A5C/4SnxUX7mW1wkPWJWX3dwMhrJ79DkBuZ7UYzTOqE="; }; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/by-name/cs/cshatag/package.nix b/pkgs/by-name/cs/cshatag/package.nix index 8ef9425231fbbd..16dedcf39cffdd 100644 --- a/pkgs/by-name/cs/cshatag/package.nix +++ b/pkgs/by-name/cs/cshatag/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "cshatag"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-OYMnZub4Yi11uMHzL1O5l6/J1md6ORS5cWm9K4yP92Q="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' # Install man page diff --git a/pkgs/by-name/cs/csmith/package.nix b/pkgs/by-name/cs/csmith/package.nix index 52955577ee7fb9..f14f2644aac5a3 100644 --- a/pkgs/by-name/cs/csmith/package.nix +++ b/pkgs/by-name/cs/csmith/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, m4, makeWrapper, libbsd, perlPackages }: +{ + lib, + stdenv, + fetchurl, + m4, + makeWrapper, + libbsd, + perlPackages, +}: stdenv.mkDerivation rec { pname = "csmith"; @@ -9,8 +17,16 @@ stdenv.mkDerivation rec { sha256 = "1mb5zgixsyf86slggs756k8a5ddmj980md3ic9sa1y75xl5cqizj"; }; - nativeBuildInputs = [ m4 makeWrapper ]; - buildInputs = [ libbsd ] ++ (with perlPackages; [ perl SysCPU ]); + nativeBuildInputs = [ + m4 + makeWrapper + ]; + buildInputs = + [ libbsd ] + ++ (with perlPackages; [ + perl + SysCPU + ]); CXXFLAGS = "-std=c++98"; diff --git a/pkgs/by-name/cs/csound-manual/package.nix b/pkgs/by-name/cs/csound-manual/package.nix index bb4db74e22ab4a..7cfdd0a1fdcc7f 100644 --- a/pkgs/by-name/cs/csound-manual/package.nix +++ b/pkgs/by-name/cs/csound-manual/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, docbook_xsl -, docbook_xml_dtd_45 -, python3 -, libxslt +{ + lib, + stdenv, + fetchFromGitHub, + docbook_xsl, + docbook_xml_dtd_45, + python3, + libxslt, }: stdenv.mkDerivation rec { @@ -24,7 +25,12 @@ stdenv.mkDerivation rec { "${docbook_xml_dtd_45}/xml/dtd/docbook/docbookx.dtd" ''; - nativeBuildInputs = [ libxslt.bin docbook_xsl python3 python3.pkgs.pygments ]; + nativeBuildInputs = [ + libxslt.bin + docbook_xsl + python3 + python3.pkgs.pygments + ]; buildPhase = '' make XSL_BASE_PATH=${docbook_xsl}/share/xml/docbook-xsl html-dist diff --git a/pkgs/by-name/cs/css-checker/package.nix b/pkgs/by-name/cs/css-checker/package.nix index 43e2fb536706ff..ef5038ec9cb77f 100644 --- a/pkgs/by-name/cs/css-checker/package.nix +++ b/pkgs/by-name/cs/css-checker/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-4ZCma8Q7FXAWdA1m2M1ltm360Fu65JhELyfIbJBP14M="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Command-line tool for identifying similar or duplicated CSS code"; diff --git a/pkgs/by-name/cs/csv2latex/package.nix b/pkgs/by-name/cs/csv2latex/package.nix index acfe07f2622845..cf214a2720a67f 100644 --- a/pkgs/by-name/cs/csv2latex/package.nix +++ b/pkgs/by-name/cs/csv2latex/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "csv2latex"; @@ -10,8 +14,8 @@ stdenv.mkDerivation rec { }; installPhase = '' - mkdir -p $out/bin - make PREFIX=$out install + mkdir -p $out/bin + make PREFIX=$out install ''; meta = with lib; { diff --git a/pkgs/by-name/cs/csv2odf/package.nix b/pkgs/by-name/cs/csv2odf/package.nix index 3ab5ff356b6e21..b3f5c30177271b 100644 --- a/pkgs/by-name/cs/csv2odf/package.nix +++ b/pkgs/by-name/cs/csv2odf/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchurl }: +{ + lib, + python3, + fetchurl, +}: python3.pkgs.buildPythonApplication rec { pname = "csv2odf"; diff --git a/pkgs/by-name/cs/csv2parquet/package.nix b/pkgs/by-name/cs/csv2parquet/package.nix index 0d6050d703a7c9..8261242f2da2df 100644 --- a/pkgs/by-name/cs/csv2parquet/package.nix +++ b/pkgs/by-name/cs/csv2parquet/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "csv2parquet"; diff --git a/pkgs/by-name/cs/csv2svg/package.nix b/pkgs/by-name/cs/csv2svg/package.nix index e8c28cf51a6146..d9c56f76bb68e4 100644 --- a/pkgs/by-name/cs/csv2svg/package.nix +++ b/pkgs/by-name/cs/csv2svg/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/cs/csvdiff/package.nix b/pkgs/by-name/cs/csvdiff/package.nix index 90faa060bed09e..7653b8479c8a25 100644 --- a/pkgs/by-name/cs/csvdiff/package.nix +++ b/pkgs/by-name/cs/csvdiff/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/cs/csview/package.nix b/pkgs/by-name/cs/csview/package.nix index 172963858e25bf..f25f63ce74f54c 100644 --- a/pkgs/by-name/cs/csview/package.nix +++ b/pkgs/by-name/cs/csview/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, lib, rustPlatform }: +{ + fetchFromGitHub, + lib, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "csview"; @@ -17,7 +21,10 @@ rustPlatform.buildRustPackage rec { description = "High performance csv viewer with cjk/emoji support"; mainProgram = "csview"; homepage = "https://github.com/wfxr/csview"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/cs/csvkit/package.nix b/pkgs/by-name/cs/csvkit/package.nix index f9b3c6f3c71fea..b3981deaa69de8 100644 --- a/pkgs/by-name/cs/csvkit/package.nix +++ b/pkgs/by-name/cs/csvkit/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: let diff --git a/pkgs/by-name/cs/csvlens/package.nix b/pkgs/by-name/cs/csvlens/package.nix index fbaece4d42c734..ea1873f05f0c3b 100644 --- a/pkgs/by-name/cs/csvlens/package.nix +++ b/pkgs/by-name/cs/csvlens/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, darwin -, rustPlatform -, fetchFromGitHub +{ + lib, + stdenv, + darwin, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/cs/csvq/package.nix b/pkgs/by-name/cs/csvq/package.nix index aa1816082b3969..fa1b244dec0f88 100644 --- a/pkgs/by-name/cs/csvq/package.nix +++ b/pkgs/by-name/cs/csvq/package.nix @@ -1,4 +1,10 @@ -{ buildGoModule, fetchFromGitHub, testers, lib, csvq }: +{ + buildGoModule, + fetchFromGitHub, + testers, + lib, + csvq, +}: buildGoModule rec { pname = "csvq"; diff --git a/pkgs/by-name/cs/csvquote/package.nix b/pkgs/by-name/cs/csvquote/package.nix index e4bf9b5a3377fa..7a3b1c8bab1575 100644 --- a/pkgs/by-name/cs/csvquote/package.nix +++ b/pkgs/by-name/cs/csvquote/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, patsh +{ + lib, + stdenv, + fetchFromGitHub, + patsh, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cs/csvs-to-sqlite/package.nix b/pkgs/by-name/cs/csvs-to-sqlite/package.nix index 2ed4af000f560f..171c2c418d67ea 100644 --- a/pkgs/by-name/cs/csvs-to-sqlite/package.nix +++ b/pkgs/by-name/cs/csvs-to-sqlite/package.nix @@ -1,6 +1,12 @@ -{ lib, python3, fetchFromGitHub, fetchpatch }: +{ + lib, + python3, + fetchFromGitHub, + fetchpatch, +}: -with python3.pkgs; buildPythonApplication rec { +with python3.pkgs; +buildPythonApplication rec { pname = "csvs-to-sqlite"; version = "1.3"; format = "setuptools"; diff --git a/pkgs/by-name/cs/csxcad/package.nix b/pkgs/by-name/cs/csxcad/package.nix index bc1f4287c11587..5482166b4d76f8 100644 --- a/pkgs/by-name/cs/csxcad/package.nix +++ b/pkgs/by-name/cs/csxcad/package.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, fparser -, tinyxml -, hdf5 -, cgal -, vtk -, boost -, gmp -, mpfr +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fparser, + tinyxml, + hdf5, + cgal, + vtk, + boost, + gmp, + mpfr, }: stdenv.mkDerivation rec { @@ -22,7 +24,7 @@ stdenv.mkDerivation rec { sha256 = "sha256-SSV5ulx3rCJg99I/oOQbqe+gOSs+BfcCo6UkWHVhnSs="; }; - patches = [./searchPath.patch ]; + patches = [ ./searchPath.patch ]; buildInputs = [ cgal diff --git a/pkgs/by-name/ct/ctlptl/package.nix b/pkgs/by-name/ct/ctlptl/package.nix index 2e41456a5eb159..3c0998d238ae6e 100644 --- a/pkgs/by-name/ct/ctlptl/package.nix +++ b/pkgs/by-name/ct/ctlptl/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "ctlptl"; diff --git a/pkgs/by-name/ct/ctmg/package.nix b/pkgs/by-name/ct/ctmg/package.nix index 63c9004bcbc9fb..6faac6f8d3d441 100644 --- a/pkgs/by-name/ct/ctmg/package.nix +++ b/pkgs/by-name/ct/ctmg/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { pname = "ctmg"; diff --git a/pkgs/by-name/ct/ctodo/package.nix b/pkgs/by-name/ct/ctodo/package.nix index 16c1ac90aea945..294735bc107e59 100644 --- a/pkgs/by-name/ct/ctodo/package.nix +++ b/pkgs/by-name/ct/ctodo/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, ncurses, readline }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ncurses, + readline, +}: stdenv.mkDerivation rec { pname = "ctodo"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ ncurses readline ]; + buildInputs = [ + ncurses + readline + ]; meta = with lib; { homepage = "http://ctodo.apakoh.dk/"; diff --git a/pkgs/by-name/ct/ctop/package.nix b/pkgs/by-name/ct/ctop/package.nix index 0ddaac6352310d..1af537b225d245 100644 --- a/pkgs/by-name/ct/ctop/package.nix +++ b/pkgs/by-name/ct/ctop/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ctop"; @@ -13,7 +17,12 @@ buildGoModule rec { vendorHash = "sha256-UAja7XuoLqJFNcK1PgHGcuf/HbvSrWyRvW2D3T7Hg0g="; - ldflags = [ "-s" "-w" "-X main.version=${version}" "-X main.build=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + "-X main.build=v${version}" + ]; meta = with lib; { description = "Top-like interface for container metrics"; diff --git a/pkgs/by-name/ct/ctpl/package.nix b/pkgs/by-name/ct/ctpl/package.nix index ad8e192c0a7adf..d83bd2c456ea1d 100644 --- a/pkgs/by-name/ct/ctpl/package.nix +++ b/pkgs/by-name/ct/ctpl/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, glib }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, +}: stdenv.mkDerivation rec { pname = "ctpl"; diff --git a/pkgs/by-name/ct/ctpp2/package.nix b/pkgs/by-name/ct/ctpp2/package.nix index 2d3b07e5e01f2a..d03830f8069da4 100644 --- a/pkgs/by-name/ct/ctpp2/package.nix +++ b/pkgs/by-name/ct/ctpp2/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, cmake }: +{ + lib, + stdenv, + fetchurl, + cmake, +}: stdenv.mkDerivation rec { pname = "ctpp2"; diff --git a/pkgs/by-name/ct/ctre/package.nix b/pkgs/by-name/ct/ctre/package.nix index e35e2d1244c67b..f0418ae956e83b 100644 --- a/pkgs/by-name/ct/ctre/package.nix +++ b/pkgs/by-name/ct/ctre/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ct/ctrtool/package.nix b/pkgs/by-name/ct/ctrtool/package.nix index aa9dffc12944ba..0adf9db5087c74 100644 --- a/pkgs/by-name/ct/ctrtool/package.nix +++ b/pkgs/by-name/ct/ctrtool/package.nix @@ -1,13 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, gitUpdater }: +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, +}: stdenv.mkDerivation rec { pname = "ctrtool"; version = "1.2.0"; src = fetchFromGitHub { - owner = "jakcron"; - repo = "Project_CTR"; - rev = "ctrtool-v${version}"; + owner = "jakcron"; + repo = "Project_CTR"; + rev = "ctrtool-v${version}"; sha256 = "wjU/DJHrAHE3MSB7vy+swUDVPzw0Jrv4ymOjhfr0BBk="; }; @@ -16,7 +21,7 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; preBuild = '' - make -j $NIX_BUILD_CORES deps + make -j $NIX_BUILD_CORES deps ''; # workaround for https://github.com/3DSGuy/Project_CTR/issues/145 diff --git a/pkgs/by-name/ct/ctx/package.nix b/pkgs/by-name/ct/ctx/package.nix index b329fd221247ba..dde97bcf01c707 100644 --- a/pkgs/by-name/ct/ctx/package.nix +++ b/pkgs/by-name/ct/ctx/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchgit -, SDL2 -, alsa-lib -, babl -, bash -, curl -, libdrm # Not documented -, pkg-config -, xxd -, enableFb ? false -, nixosTests +{ + lib, + stdenv, + fetchgit, + SDL2, + alsa-lib, + babl, + bash, + curl, + libdrm, # Not documented + pkg-config, + xxd, + enableFb ? false, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { @@ -57,7 +58,7 @@ stdenv.mkDerivation (finalAttrs: { configureScript = "./configure.sh"; configureFlags = lib.optional enableFb "--enable-fb"; - configurePlatforms = []; + configurePlatforms = [ ]; dontAddPrefix = true; dontDisableStatic = true; diff --git a/pkgs/by-name/ct/ctypes_sh/package.nix b/pkgs/by-name/ct/ctypes_sh/package.nix index 44f71982062cdb..032edc5f7d2228 100644 --- a/pkgs/by-name/ct/ctypes_sh/package.nix +++ b/pkgs/by-name/ct/ctypes_sh/package.nix @@ -1,7 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook, pkg-config -, zlib, libffi, elfutils, libdwarf +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + zlib, + libffi, + elfutils, + libdwarf, }: stdenv.mkDerivation rec { @@ -15,8 +21,16 @@ stdenv.mkDerivation rec { sha256 = "1wafyfhwd7nf7xdici0djpwgykizaz7jlarn0r1b4spnpjx1zbx4"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ zlib libffi elfutils libdwarf ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + zlib + libffi + elfutils + libdwarf + ]; meta = with lib; { description = "Foreign function interface for bash"; diff --git a/pkgs/by-name/cu/cucumber/gemset.nix b/pkgs/by-name/cu/cucumber/gemset.nix index c716c0165c9cc7..ae0dee703c99b4 100644 --- a/pkgs/by-name/cu/cucumber/gemset.nix +++ b/pkgs/by-name/cu/cucumber/gemset.nix @@ -1,155 +1,171 @@ { bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cq1c29zbkcxgdihqisirhcw76xc768z2zpd5vbccpq0l1lv76g7"; type = "gem"; }; version = "3.1.7"; }; builder = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "045wzckxpwcqzrjr353cxnyaxgf0qg22jh00dcx7z38cys5g1jlr"; type = "gem"; }; version = "3.2.4"; }; cucumber = { - dependencies = ["builder" "cucumber-ci-environment" "cucumber-core" "cucumber-cucumber-expressions" "cucumber-gherkin" "cucumber-html-formatter" "cucumber-messages" "diff-lcs" "mini_mime" "multi_test" "sys-uname"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "builder" + "cucumber-ci-environment" + "cucumber-core" + "cucumber-cucumber-expressions" + "cucumber-gherkin" + "cucumber-html-formatter" + "cucumber-messages" + "diff-lcs" + "mini_mime" + "multi_test" + "sys-uname" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19qsfgahkah4k0pajxc04mjn8pig7g4n9nkcarg1nzs2612c29s8"; type = "gem"; }; version = "9.2.0"; }; cucumber-ci-environment = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cc6w7dqlmnp59ymi7pyspm3w4m7fn37x6b18pziv62wr373yvmv"; type = "gem"; }; version = "10.0.1"; }; cucumber-core = { - dependencies = ["cucumber-gherkin" "cucumber-messages" "cucumber-tag-expressions"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "cucumber-gherkin" + "cucumber-messages" + "cucumber-tag-expressions" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jf5ngxfc1q2y7l2nci3p91gp253aqdhkhazkz0yxq72n6zrszvm"; type = "gem"; }; version = "13.0.1"; }; cucumber-cucumber-expressions = { - dependencies = ["bigdecimal"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bigdecimal" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wsczwaqws1hbkirjhl0lh5s5xhc7cpmj2f790lkx10nr85rbpxi"; type = "gem"; }; version = "17.0.2"; }; cucumber-gherkin = { - dependencies = ["cucumber-messages"]; - groups = ["default"]; - platforms = []; + dependencies = [ "cucumber-messages" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "063p0slf6fvigdn3jynp5pjf9b05byyyi0jhsyapy46hq4984sif"; type = "gem"; }; version = "27.0.0"; }; cucumber-html-formatter = { - dependencies = ["cucumber-messages"]; - groups = ["default"]; - platforms = []; + dependencies = [ "cucumber-messages" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wznhl3b8b47zff0yx69828bx33n0vc60kh6110ml0xni7lx8xw1"; type = "gem"; }; version = "21.3.0"; }; cucumber-messages = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06d7dnixz68ivngf6qflmi6xrjshjyi85gmyjrl07pbmhqi6r2nh"; type = "gem"; }; version = "22.0.0"; }; cucumber-tag-expressions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g0fl6v1677q71nkaib2g3p03jdzrwgfanpi96srb1743qd54bk1"; type = "gem"; }; version = "6.1.0"; }; diff-lcs = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znxccz83m4xgpd239nyqxlifdb7m8rlfayk6s259186nkgj6ci7"; type = "gem"; }; version = "1.5.1"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yvii03hcgqj30maavddqamqy50h7y6xcn2wcyq72wn823zl4ckd"; type = "gem"; }; version = "1.16.3"; }; mini_mime = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vycif7pjzkr29mfk4dlqv3disc5dn0va04lkwajlpr1wkibg0c6"; type = "gem"; }; version = "1.1.5"; }; multi_test = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "042d6a1416h3di57z107ygmjdgacrpyswi73ryz75yv3v36m1rg9"; type = "gem"; }; version = "1.1.0"; }; sys-uname = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03j9qpqip89a0vk6s0gvhxzhbvafjcj5rss7i3jwha0831aivib3"; type = "gem"; }; diff --git a/pkgs/by-name/cu/cucumber/package.nix b/pkgs/by-name/cu/cucumber/package.nix index 55dcd9f49ac82d..00354c0eb35ffb 100644 --- a/pkgs/by-name/cu/cucumber/package.nix +++ b/pkgs/by-name/cu/cucumber/package.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "cucumber"; @@ -13,7 +17,11 @@ bundlerApp { changelog = "https://github.com/cucumber/cucumber-ruby/blob/main/CHANGELOG.md"; license = licenses.mit; mainProgram = "cucumber"; - maintainers = with maintainers; [ manveru nicknovitski anthonyroussel ]; + maintainers = with maintainers; [ + manveru + nicknovitski + anthonyroussel + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/cu/cudd/package.nix b/pkgs/by-name/cu/cudd/package.nix index 4e8cf59fbffd35..030c18b8724869 100644 --- a/pkgs/by-name/cu/cudd/package.nix +++ b/pkgs/by-name/cu/cudd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "cudd"; diff --git a/pkgs/by-name/cu/cue/tests/001-all-good.nix b/pkgs/by-name/cu/cue/tests/001-all-good.nix index f7fc46eebea6b5..874ac2d338d5d1 100644 --- a/pkgs/by-name/cu/cue/tests/001-all-good.nix +++ b/pkgs/by-name/cu/cue/tests/001-all-good.nix @@ -1,10 +1,13 @@ -{ cue -, runCommand +{ + cue, + runCommand, }: -runCommand "cue-test-001-all-good-${cue.version}" { - nativeBuildInputs = [ cue ]; - meta.timeout = 10; -} '' +runCommand "cue-test-001-all-good-${cue.version}" + { + nativeBuildInputs = [ cue ]; + meta.timeout = 10; + } + '' cue eval - <<<'a: "all good"' > $out '' diff --git a/pkgs/by-name/cu/cue/validator.nix b/pkgs/by-name/cu/cue/validator.nix index 09e852347341dc..48c69f6c9bf1b0 100644 --- a/pkgs/by-name/cu/cue/validator.nix +++ b/pkgs/by-name/cu/cue/validator.nix @@ -1,17 +1,24 @@ -{ cue, writeShellScript, lib }: +{ + cue, + writeShellScript, + lib, +}: # `document` must be a fragment of definition or structure that the input data will be matched against. # `document` must exist in the Cue schema file provided (`cueSchemaFile`). # The result is a script that can be used to validate the input data (JSON/YAML and more can be supported depending on Cue) # against the fragment described by `document` or the whole definition. # The script will be strict and enforce concrete values, i.e. partial documents are not supported. -cueSchemaFile: { document ? null }: - writeShellScript "validate-using-cue" '' - ${cue}/bin/cue \ - --all-errors \ - --strict \ - vet \ - --concrete \ - "$1" \ - ${cueSchemaFile} \ - ${lib.optionalString (document != null) "-d \"${document}\""} - '' +cueSchemaFile: +{ + document ? null, +}: +writeShellScript "validate-using-cue" '' + ${cue}/bin/cue \ + --all-errors \ + --strict \ + vet \ + --concrete \ + "$1" \ + ${cueSchemaFile} \ + ${lib.optionalString (document != null) "-d \"${document}\""} +'' diff --git a/pkgs/by-name/cu/cue2pops/package.nix b/pkgs/by-name/cu/cue2pops/package.nix index 3cce608ffdc8f5..69a353f20550e7 100644 --- a/pkgs/by-name/cu/cue2pops/package.nix +++ b/pkgs/by-name/cu/cue2pops/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/cu/cuelsp/package.nix b/pkgs/by-name/cu/cuelsp/package.nix index b7a269843b352b..948478fc080683 100644 --- a/pkgs/by-name/cu/cuelsp/package.nix +++ b/pkgs/by-name/cu/cuelsp/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "cuelsp"; diff --git a/pkgs/by-name/cu/cuetools/package.nix b/pkgs/by-name/cu/cuetools/package.nix index 8b2cd28e4a0270..8bc52e23dbc422 100644 --- a/pkgs/by-name/cu/cuetools/package.nix +++ b/pkgs/by-name/cu/cuetools/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook -, bison, flac, flex, id3v2, vorbis-tools +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + bison, + flac, + flex, + id3v2, + vorbis-tools, }: stdenv.mkDerivation rec { @@ -15,7 +23,13 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ bison flac flex id3v2 vorbis-tools ]; + buildInputs = [ + bison + flac + flex + id3v2 + vorbis-tools + ]; postInstall = '' # add link for compatibility with Debian-based distros, which package `cuetag.sh` as `cuetag` @@ -26,7 +40,10 @@ stdenv.mkDerivation rec { description = "Set of utilities for working with cue files and toc files"; homepage = "https://github.com/svend/cuetools"; license = licenses.gpl2Only; - maintainers = with maintainers; [ codyopel jcumming ]; + maintainers = with maintainers; [ + codyopel + jcumming + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/cu/culmus/package.nix b/pkgs/by-name/cu/culmus/package.nix index 28a7f4385a01a6..c724357e7e357e 100644 --- a/pkgs/by-name/cu/culmus/package.nix +++ b/pkgs/by-name/cu/culmus/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "culmus"; diff --git a/pkgs/by-name/cu/cum/package.nix b/pkgs/by-name/cu/cum/package.nix index e1ea239b43fc45..158ce2015da9ea 100644 --- a/pkgs/by-name/cu/cum/package.nix +++ b/pkgs/by-name/cu/cum/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: with python3Packages; @@ -12,7 +16,12 @@ buildPythonApplication rec { }; propagatedBuildInputs = [ - alembic beautifulsoup4 click natsort requests sqlalchemy + alembic + beautifulsoup4 + click + natsort + requests + sqlalchemy ]; # tests seem to fail for `config` not being defined, diff --git a/pkgs/by-name/cu/cuneiform/package.nix b/pkgs/by-name/cu/cuneiform/package.nix index 9332b25babfb17..6c54a577bc041e 100644 --- a/pkgs/by-name/cu/cuneiform/package.nix +++ b/pkgs/by-name/cu/cuneiform/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, cmake, imagemagick, testers }: +{ + lib, + stdenv, + fetchurl, + cmake, + imagemagick, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "cuneiform"; @@ -10,14 +17,14 @@ stdenv.mkDerivation (finalAttrs: { }; patches = [ - (fetchurl { - url = "https://raw.githubusercontent.com/archlinux/svntogit-community/a2ec92f05de006b56d16ac6a6c370d54a554861a/cuneiform/trunk/build-fix.patch"; - sha256 = "19cmrlx4khn30qqrpyayn7bicg8yi0wpz1x1bvqqrbvr3kwldxyj"; - }) - (fetchurl { - url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/app-text/cuneiform/files/cuneiform-1.1.0-gcc11.patch"; - sha256 = "14bp2f4dvlgxnpdza1rgszhkbxhp6p7lhgnb1s7c1x7vwdrx0ri7"; - }) + (fetchurl { + url = "https://raw.githubusercontent.com/archlinux/svntogit-community/a2ec92f05de006b56d16ac6a6c370d54a554861a/cuneiform/trunk/build-fix.patch"; + sha256 = "19cmrlx4khn30qqrpyayn7bicg8yi0wpz1x1bvqqrbvr3kwldxyj"; + }) + (fetchurl { + url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/app-text/cuneiform/files/cuneiform-1.1.0-gcc11.patch"; + sha256 = "14bp2f4dvlgxnpdza1rgszhkbxhp6p7lhgnb1s7c1x7vwdrx0ri7"; + }) ]; # Workaround build failure on -fno-common toolchains like upstream diff --git a/pkgs/by-name/cu/cunit/package.nix b/pkgs/by-name/cu/cunit/package.nix index af623c659d513e..756b9aa49f8e75 100644 --- a/pkgs/by-name/cu/cunit/package.nix +++ b/pkgs/by-name/cu/cunit/package.nix @@ -1,11 +1,23 @@ -{ lib, stdenv, fetchurl, autoconf, automake, libtool, autoreconfHook}: +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + libtool, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "CUnit"; version = "2.1-3"; - nativeBuildInputs = [ autoreconfHook autoconf automake ]; - buildInputs = [libtool]; + nativeBuildInputs = [ + autoreconfHook + autoconf + automake + ]; + buildInputs = [ libtool ]; src = fetchurl { url = "mirror://sourceforge/cunit/CUnit/${version}/CUnit-${version}.tar.bz2"; diff --git a/pkgs/by-name/cu/cups-bjnp/package.nix b/pkgs/by-name/cu/cups-bjnp/package.nix index 6c8c8f21a3a26c..bf842bead91288 100644 --- a/pkgs/by-name/cu/cups-bjnp/package.nix +++ b/pkgs/by-name/cu/cups-bjnp/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, cups}: +{ + lib, + stdenv, + fetchurl, + cups, +}: stdenv.mkDerivation rec { pname = "cups-bjnp"; @@ -11,7 +16,7 @@ stdenv.mkDerivation rec { preConfigure = ''configureFlags="--with-cupsbackenddir=$out/lib/cups/backend"''; - buildInputs = [cups]; + buildInputs = [ cups ]; env.NIX_CFLAGS_COMPILE = toString [ "-include stdio.h" "-Wno-error=stringop-truncation" diff --git a/pkgs/by-name/cu/cups-brother-hl3170cdw/package.nix b/pkgs/by-name/cu/cups-brother-hl3170cdw/package.nix index 5450997a5afcdb..ffc6b6832d6000 100644 --- a/pkgs/by-name/cu/cups-brother-hl3170cdw/package.nix +++ b/pkgs/by-name/cu/cups-brother-hl3170cdw/package.nix @@ -1,4 +1,20 @@ -{lib, stdenv, fetchurl, dpkg, makeWrapper, gnused, coreutils, psutils, gnugrep, ghostscript, file, a2ps, gawk, which, pkgsi686Linux }: +{ + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + gnused, + coreutils, + psutils, + gnugrep, + ghostscript, + file, + a2ps, + gawk, + which, + pkgsi686Linux, +}: stdenv.mkDerivation rec { pname = "cups-brother-${model}"; @@ -19,7 +35,10 @@ stdenv.mkDerivation rec { hash = "sha256-N1GjQHth5k4qhbfWLInzub9DcNsee4gKc3EW2WIfrko="; }; - nativeBuildInputs = [ makeWrapper dpkg ]; + nativeBuildInputs = [ + makeWrapper + dpkg + ]; preUnpack = '' dpkg-deb -x ${lprdeb} $out @@ -70,13 +89,34 @@ stdenv.mkDerivation rec { --replace-fail printcap.local printcap wrapProgram $dir/lpd/filter${model} \ - --prefix PATH ":" ${ lib.makeBinPath [ ghostscript a2ps file gnused coreutils ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + ghostscript + a2ps + file + gnused + coreutils + ] + } wrapProgram $dir/inf/setupPrintcapij \ - --prefix PATH ":" ${ lib.makeBinPath [ coreutils gnused ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + coreutils + gnused + ] + } wrapProgram $dir/lpd/psconvertij2 \ - --prefix PATH ":" ${ lib.makeBinPath [ ghostscript gnused coreutils gawk which ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + ghostscript + gnused + coreutils + gawk + which + ] + } patchelf --set-interpreter "$interpreter" "$dir/lpd/br${model}filter" patchelf --set-interpreter "$interpreter" "$out/usr/bin/brprintconf_${model}" @@ -96,15 +136,31 @@ stdenv.mkDerivation rec { --replace-fail /usr/share/cups/model/Brother "$out/share/cups/model/Brother" wrapProgram $out/lib/cups/filter/brother_lpdwrapper_${model} \ - --prefix PATH ":" ${ lib.makeBinPath [ coreutils psutils gnused gnugrep ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + coreutils + psutils + gnused + gnugrep + ] + } ''; meta = with lib; { homepage = "https://www.brother.com/"; description = "Brother ${model} printer driver"; - sourceProvenance = with sourceTypes; [ binaryNativeCode fromSource ]; - license = with licenses; [ unfree gpl2Plus ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + sourceProvenance = with sourceTypes; [ + binaryNativeCode + fromSource + ]; + license = with licenses; [ + unfree + gpl2Plus + ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; downloadPage = "https://support.brother.com/g/b/downloadlist.aspx?c=us&lang=en&prod=${model}_all&os=128"; maintainers = with maintainers; [ luna_1024 ]; }; diff --git a/pkgs/by-name/cu/cups-brother-hll2350dw/package.nix b/pkgs/by-name/cu/cups-brother-hll2350dw/package.nix index f018c8b64544f2..c793308aa5b103 100644 --- a/pkgs/by-name/cu/cups-brother-hll2350dw/package.nix +++ b/pkgs/by-name/cu/cups-brother-hll2350dw/package.nix @@ -1,20 +1,25 @@ -{ lib -, stdenv -, fetchurl -, dpkg -, autoPatchelfHook -, makeWrapper -, perl -, gnused -, ghostscript -, file -, coreutils -, gnugrep -, which +{ + lib, + stdenv, + fetchurl, + dpkg, + autoPatchelfHook, + makeWrapper, + perl, + gnused, + ghostscript, + file, + coreutils, + gnugrep, + which, }: let - arches = [ "x86_64" "i686" "armv7l" ]; + arches = [ + "x86_64" + "i686" + "armv7l" + ]; runtimeDeps = [ ghostscript @@ -30,7 +35,11 @@ stdenv.mkDerivation rec { pname = "cups-brother-hll2350dw"; version = "4.0.0-1"; - nativeBuildInputs = [ dpkg makeWrapper autoPatchelfHook ]; + nativeBuildInputs = [ + dpkg + makeWrapper + autoPatchelfHook + ]; buildInputs = [ perl ]; dontUnpack = true; @@ -40,17 +49,20 @@ stdenv.mkDerivation rec { sha256 = "0b7hhln105agc3rwpi7cjlx5nf4d2yk9iksahdv3725nnd06lg46"; }; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - mkdir -p $out - dpkg-deb -x $src $out + mkdir -p $out + dpkg-deb -x $src $out - # delete unnecessary files for the current architecture - '' + lib.concatMapStrings (arch: '' - echo Deleting files for ${arch} - rm -r "$out/opt/brother/Printers/HLL2350DW/lpd/${arch}" - '') (builtins.filter (arch: arch != stdenv.hostPlatform.linuxArch) arches) + '' + # delete unnecessary files for the current architecture + '' + + lib.concatMapStrings (arch: '' + echo Deleting files for ${arch} + rm -r "$out/opt/brother/Printers/HLL2350DW/lpd/${arch}" + '') (builtins.filter (arch: arch != stdenv.hostPlatform.linuxArch) arches) + + '' # bundled scripts don't understand the arch subdirectories for some reason ln -s \ diff --git a/pkgs/by-name/cu/cups-brother-hll2375dw/package.nix b/pkgs/by-name/cu/cups-brother-hll2375dw/package.nix index 5f27b6364d858e..99d1dc12527dae 100644 --- a/pkgs/by-name/cu/cups-brother-hll2375dw/package.nix +++ b/pkgs/by-name/cu/cups-brother-hll2375dw/package.nix @@ -1,20 +1,25 @@ -{ lib -, stdenv -, fetchurl -, dpkg -, autoPatchelfHook -, makeWrapper -, perl -, gnused -, ghostscript -, file -, coreutils -, gnugrep -, which +{ + lib, + stdenv, + fetchurl, + dpkg, + autoPatchelfHook, + makeWrapper, + perl, + gnused, + ghostscript, + file, + coreutils, + gnugrep, + which, }: let - arches = [ "x86_64" "i686" "armv7l" ]; + arches = [ + "x86_64" + "i686" + "armv7l" + ]; runtimeDeps = [ ghostscript @@ -30,7 +35,11 @@ stdenv.mkDerivation rec { pname = "cups-brother-hll2375dw"; version = "4.0.0-1"; - nativeBuildInputs = [ dpkg makeWrapper autoPatchelfHook ]; + nativeBuildInputs = [ + dpkg + makeWrapper + autoPatchelfHook + ]; buildInputs = [ perl ]; src = fetchurl { @@ -47,50 +56,51 @@ stdenv.mkDerivation rec { ./fix-perm.patch ]; - installPhase = '' - runHook preInstall - mkdir -p $out - cp -ar opt $out/opt - # delete unnecessary files for the current architecture - '' + lib.concatMapStrings - (arch: '' + installPhase = + '' + runHook preInstall + mkdir -p $out + cp -ar opt $out/opt + # delete unnecessary files for the current architecture + '' + + lib.concatMapStrings (arch: '' echo Deleting files for ${arch} rm -r "$out/opt/brother/Printers/HLL2375DW/lpd/${arch}" - '') - (builtins.filter (arch: arch != stdenv.hostPlatform.linuxArch) arches) + '' - # bundled scripts don't understand the arch subdirectories for some reason - ln -s \ - "$out/opt/brother/Printers/HLL2375DW/lpd/${stdenv.hostPlatform.linuxArch}/"* \ - "$out/opt/brother/Printers/HLL2375DW/lpd/" + '') (builtins.filter (arch: arch != stdenv.hostPlatform.linuxArch) arches) + + '' + # bundled scripts don't understand the arch subdirectories for some reason + ln -s \ + "$out/opt/brother/Printers/HLL2375DW/lpd/${stdenv.hostPlatform.linuxArch}/"* \ + "$out/opt/brother/Printers/HLL2375DW/lpd/" - # Fix global references and replace auto discovery mechanism with hardcoded values - substituteInPlace $out/opt/brother/Printers/HLL2375DW/lpd/lpdfilter \ - --replace "my \$BR_PRT_PATH =" "my \$BR_PRT_PATH = \"$out/opt/brother/Printers/HLL2375DW\"; #" \ - --replace "PRINTER =~" "PRINTER = \"HLL2375DW\"; #" - substituteInPlace $out/opt/brother/Printers/HLL2375DW/cupswrapper/lpdwrapper \ - --replace "my \$basedir = C" "my \$basedir = \"$out/opt/brother/Printers/HLL2375DW\" ; #" \ - --replace "PRINTER =~" "PRINTER = \"HLL2375DW\"; #" + # Fix global references and replace auto discovery mechanism with hardcoded values + substituteInPlace $out/opt/brother/Printers/HLL2375DW/lpd/lpdfilter \ + --replace "my \$BR_PRT_PATH =" "my \$BR_PRT_PATH = \"$out/opt/brother/Printers/HLL2375DW\"; #" \ + --replace "PRINTER =~" "PRINTER = \"HLL2375DW\"; #" + substituteInPlace $out/opt/brother/Printers/HLL2375DW/cupswrapper/lpdwrapper \ + --replace "my \$basedir = C" "my \$basedir = \"$out/opt/brother/Printers/HLL2375DW\" ; #" \ + --replace "PRINTER =~" "PRINTER = \"HLL2375DW\"; #" - # Make sure all executables have the necessary runtime dependencies available - find "$out" -executable -and -type f | while read file; do - wrapProgram "$file" --prefix PATH : "${lib.makeBinPath runtimeDeps}" - done + # Make sure all executables have the necessary runtime dependencies available + find "$out" -executable -and -type f | while read file; do + wrapProgram "$file" --prefix PATH : "${lib.makeBinPath runtimeDeps}" + done - # Symlink filter and ppd into a location where CUPS will discover it - mkdir -p $out/lib/cups/filter - mkdir -p $out/share/cups/model - mkdir -p $out/etc/opt/brother/Printers/HLL2375DW/inf + # Symlink filter and ppd into a location where CUPS will discover it + mkdir -p $out/lib/cups/filter + mkdir -p $out/share/cups/model + mkdir -p $out/etc/opt/brother/Printers/HLL2375DW/inf - ln -s $out/opt/brother/Printers/HLL2375DW/inf/brHLL2375DWrc \ - $out/etc/opt/brother/Printers/HLL2375DW/inf/brHLL2375DWrc - ln -s \ - $out/opt/brother/Printers/HLL2375DW/cupswrapper/lpdwrapper \ - $out/lib/cups/filter/brother_lpdwrapper_HLL2375DW - ln -s \ - $out/opt/brother/Printers/HLL2375DW/cupswrapper/brother-HLL2375DW-cups-en.ppd \ - $out/share/cups/model/ - runHook postInstall - ''; + ln -s $out/opt/brother/Printers/HLL2375DW/inf/brHLL2375DWrc \ + $out/etc/opt/brother/Printers/HLL2375DW/inf/brHLL2375DWrc + ln -s \ + $out/opt/brother/Printers/HLL2375DW/cupswrapper/lpdwrapper \ + $out/lib/cups/filter/brother_lpdwrapper_HLL2375DW + ln -s \ + $out/opt/brother/Printers/HLL2375DW/cupswrapper/brother-HLL2375DW-cups-en.ppd \ + $out/share/cups/model/ + runHook postInstall + ''; meta = with lib; { homepage = "http://www.brother.com/"; diff --git a/pkgs/by-name/cu/cups-brother-mfcl2750dw/package.nix b/pkgs/by-name/cu/cups-brother-mfcl2750dw/package.nix index 73753b0dea076d..25485338be510d 100644 --- a/pkgs/by-name/cu/cups-brother-mfcl2750dw/package.nix +++ b/pkgs/by-name/cu/cups-brother-mfcl2750dw/package.nix @@ -1,20 +1,25 @@ -{ lib -, stdenv -, fetchurl -, dpkg -, autoPatchelfHook -, makeWrapper -, perl -, gnused -, ghostscript -, file -, coreutils -, gnugrep -, which +{ + lib, + stdenv, + fetchurl, + dpkg, + autoPatchelfHook, + makeWrapper, + perl, + gnused, + ghostscript, + file, + coreutils, + gnugrep, + which, }: let - arches = [ "x86_64" "i686" "armv7l" ]; + arches = [ + "x86_64" + "i686" + "armv7l" + ]; runtimeDeps = [ ghostscript @@ -30,7 +35,11 @@ stdenv.mkDerivation rec { pname = "cups-brother-mfcl2750dw"; version = "4.0.0-1"; - nativeBuildInputs = [ dpkg makeWrapper autoPatchelfHook ]; + nativeBuildInputs = [ + dpkg + makeWrapper + autoPatchelfHook + ]; buildInputs = [ perl ]; dontUnpack = true; @@ -40,17 +49,20 @@ stdenv.mkDerivation rec { hash = "sha256-3uDwzLQTF8r1tsGZ7ChGhk4ryQmVsZYdUaj9eFaC0jc="; }; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - mkdir -p $out - dpkg-deb -x $src $out + mkdir -p $out + dpkg-deb -x $src $out - # delete unnecessary files for the current architecture - '' + lib.concatMapStrings (arch: '' - echo Deleting files for ${arch} - rm -r "$out/opt/brother/Printers/MFCL2750DW/lpd/${arch}" - '') (builtins.filter (arch: arch != stdenv.hostPlatform.linuxArch) arches) + '' + # delete unnecessary files for the current architecture + '' + + lib.concatMapStrings (arch: '' + echo Deleting files for ${arch} + rm -r "$out/opt/brother/Printers/MFCL2750DW/lpd/${arch}" + '') (builtins.filter (arch: arch != stdenv.hostPlatform.linuxArch) arches) + + '' # bundled scripts don't understand the arch subdirectories for some reason ln -s \ diff --git a/pkgs/by-name/cu/cups-drv-rastertosag-gdi/package.nix b/pkgs/by-name/cu/cups-drv-rastertosag-gdi/package.nix index 162910827f8920..bedf2d8a4340f6 100644 --- a/pkgs/by-name/cu/cups-drv-rastertosag-gdi/package.nix +++ b/pkgs/by-name/cu/cups-drv-rastertosag-gdi/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchzip -, fetchpatch -, cups -, python3Packages -, patchPpdFilesHook +{ + lib, + fetchzip, + fetchpatch, + cups, + python3Packages, + patchPpdFilesHook, }: python3Packages.buildPythonApplication rec { @@ -15,13 +16,16 @@ python3Packages.buildPythonApplication rec { }; patches = [ # port to python 3 - ( fetchpatch { + (fetchpatch { url = "https://sources.debian.org/data/main/r/${pname}/0.1-7/debian/patches/0001-${pname}-python3.patch"; sha256 = "1l3xbrs67025595k9ba5794q3s74anizpbxwsshcfhmbrzd9h8hg"; }) ]; format = "other"; - nativeBuildInputs = [ (lib.getBin cups) patchPpdFilesHook ]; + nativeBuildInputs = [ + (lib.getBin cups) + patchPpdFilesHook + ]; # The source image also brings pre-built ppd files, # but we prefer to generate from source where possible, so # the following line generates ppd files from the drv file. @@ -45,7 +49,7 @@ python3Packages.buildPythonApplication rec { mainProgram = "rastertosag-gdi"; downloadPage = "https://www.openprinting.org/download/printing/rastertosag-gdi/"; homepage = "https://www.openprinting.org/driver/rastertosag-gdi/"; - license = lib.licenses.free; # just "GPL", according to README + license = lib.licenses.free; # just "GPL", according to README maintainers = [ lib.maintainers.yarny ]; longDescription = '' This package brings CUPS raster filter diff --git a/pkgs/by-name/cu/cups-dymo/package.nix b/pkgs/by-name/cu/cups-dymo/package.nix index c3186cafa264d0..f1556eb1fd5c17 100644 --- a/pkgs/by-name/cu/cups-dymo/package.nix +++ b/pkgs/by-name/cu/cups-dymo/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, cups, ... }: +{ + stdenv, + lib, + fetchurl, + cups, + ... +}: stdenv.mkDerivation rec { pname = "cups-dymo"; @@ -17,7 +23,10 @@ stdenv.mkDerivation rec { buildInputs = [ cups ]; patches = [ ./fix-includes.patch ]; - makeFlags = [ "cupsfilterdir=$(out)/lib/cups/filter" "cupsmodeldir=$(out)/share/cups/model" ]; + makeFlags = [ + "cupsfilterdir=$(out)/lib/cups/filter" + "cupsmodeldir=$(out)/share/cups/model" + ]; meta = { description = "CUPS Linux drivers and SDK for DYMO printers"; diff --git a/pkgs/by-name/cu/cups-kyocera-3500-4500/package.nix b/pkgs/by-name/cu/cups-kyocera-3500-4500/package.nix index 69043725654729..14336727019520 100644 --- a/pkgs/by-name/cu/cups-kyocera-3500-4500/package.nix +++ b/pkgs/by-name/cu/cups-kyocera-3500-4500/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, cups -, autoPatchelfHook -, python3Packages - -# Sets the default paper format: use "EU" for A4, or "Global" for Letter -, region ? "EU" +{ + lib, + stdenv, + fetchurl, + cups, + autoPatchelfHook, + python3Packages, + + # Sets the default paper format: use "EU" for A4, or "Global" for Letter + region ? "EU", }: assert region == "Global" || region == "EU"; @@ -56,23 +57,34 @@ stdenv.mkDerivation rec { sourceRoot = "."; - unpackCmd = let - platforms = { - x86_64-linux = "amd64"; - i686-linux = "i386"; - }; - platform = platforms.${stdenv.hostPlatform.system} or (throw "unsupported system: ${stdenv.hostPlatform.system}"); - in '' - ar p "$src/Debian/${region}/kyodialog_${platform}/kyodialog_${kyodialog_version_long}-0_${platform}.deb" data.tar.gz | tar -xz - ''; + unpackCmd = + let + platforms = { + x86_64-linux = "amd64"; + i686-linux = "i386"; + }; + platform = + platforms.${stdenv.hostPlatform.system} + or (throw "unsupported system: ${stdenv.hostPlatform.system}"); + in + '' + ar p "$src/Debian/${region}/kyodialog_${platform}/kyodialog_${kyodialog_version_long}-0_${platform}.deb" data.tar.gz | tar -xz + ''; - nativeBuildInputs = [ autoPatchelfHook python3Packages.wrapPython ]; + nativeBuildInputs = [ + autoPatchelfHook + python3Packages.wrapPython + ]; buildInputs = [ cups ]; # For lib/cups/filter/kyofilter_pre_H. # The source already contains a copy of pypdf3, but we use the Nix package - propagatedBuildInputs = with python3Packages; [ reportlab pypdf3 setuptools ]; + propagatedBuildInputs = with python3Packages; [ + reportlab + pypdf3 + setuptools + ]; installPhase = '' # allow cups to find the ppd files @@ -96,6 +108,9 @@ stdenv.mkDerivation rec { sourceProvenance = [ sourceTypes.binaryNativeCode ]; license = licenses.unfree; maintainers = [ maintainers.me-and ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/cu/cups-kyocera-ecosys-m2x35-40-p2x35-40dnw/package.nix b/pkgs/by-name/cu/cups-kyocera-ecosys-m2x35-40-p2x35-40dnw/package.nix index 985a172d8731bd..4c5fb5839c116d 100644 --- a/pkgs/by-name/cu/cups-kyocera-ecosys-m2x35-40-p2x35-40dnw/package.nix +++ b/pkgs/by-name/cu/cups-kyocera-ecosys-m2x35-40-p2x35-40dnw/package.nix @@ -1,22 +1,25 @@ -{ stdenv -, lib -, fetchzip +{ + stdenv, + lib, + fetchzip, # can either be "EU" or "Global"; it's unclear what the difference is -, region ? "Global" + region ? "Global", # can be either "English", "French", "German", "Italian", "Portguese" or "Spanish" -, language ? "English" + language ? "English", }: stdenv.mkDerivation rec { pname = "cups-kyocera-ecosys-m2x35-40-p2x35-40dnw"; version = "8.1606"; - src = let - urlVersion = builtins.replaceStrings [ "." ] [ "_" ] version; - in fetchzip { - url = "https://www.kyoceradocumentsolutions.de/content/download-center/de/drivers/all/Linux_${urlVersion}_ECOSYS_M2x35_40_P2x35_40dnw_zip.download.zip"; - sha256 = "10crxdfj62ini70vv471445zi6q0l9fmg2jsd74sp6fr0qa0kvr7"; - }; + src = + let + urlVersion = builtins.replaceStrings [ "." ] [ "_" ] version; + in + fetchzip { + url = "https://www.kyoceradocumentsolutions.de/content/download-center/de/drivers/all/Linux_${urlVersion}_ECOSYS_M2x35_40_P2x35_40dnw_zip.download.zip"; + sha256 = "10crxdfj62ini70vv471445zi6q0l9fmg2jsd74sp6fr0qa0kvr7"; + }; installPhase = '' mkdir -p $out/share/cups/model/Kyocera diff --git a/pkgs/by-name/cu/cups-kyocera-ecosys-m552x-p502x/package.nix b/pkgs/by-name/cu/cups-kyocera-ecosys-m552x-p502x/package.nix index 66e3d036bcc638..2a263b04cfcc3d 100644 --- a/pkgs/by-name/cu/cups-kyocera-ecosys-m552x-p502x/package.nix +++ b/pkgs/by-name/cu/cups-kyocera-ecosys-m552x-p502x/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchzip +{ + stdenv, + lib, + fetchzip, # can either be "EU" or "Global"; it's unclear what the difference is -, region ? "Global" + region ? "Global", }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cu/cups-kyocera/package.nix b/pkgs/by-name/cu/cups-kyocera/package.nix index cd435bc4966229..3b2d3b6ba504cc 100644 --- a/pkgs/by-name/cu/cups-kyocera/package.nix +++ b/pkgs/by-name/cu/cups-kyocera/package.nix @@ -1,15 +1,19 @@ -{ lib -, stdenv -, cups -, fetchzip -, patchPpdFilesHook +{ + lib, + stdenv, + cups, + fetchzip, + patchPpdFilesHook, }: let platform = - if stdenv.hostPlatform.system == "x86_64-linux" then "64bit" - else if stdenv.hostPlatform.system == "i686-linux" then "32bit" - else throw "Unsupported system: ${stdenv.hostPlatform.system}"; + if stdenv.hostPlatform.system == "x86_64-linux" then + "64bit" + else if stdenv.hostPlatform.system == "i686-linux" then + "32bit" + else + throw "Unsupported system: ${stdenv.hostPlatform.system}"; libPath = lib.makeLibraryPath [ cups ]; in diff --git a/pkgs/by-name/cu/cups-kyodialog/package.nix b/pkgs/by-name/cu/cups-kyodialog/package.nix index ad2d113465ce70..2cd8ea91114057 100644 --- a/pkgs/by-name/cu/cups-kyodialog/package.nix +++ b/pkgs/by-name/cu/cups-kyodialog/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchzip -, cups -, autoPatchelfHook -, python3Packages - -# Sets the default paper format: use "EU" for A4, or "Global" for Letter -, region ? "EU" -# optional GUI, quite redundant to CUPS admin web GUI -, withQtGui ? false -, qt5 +{ + lib, + stdenv, + fetchzip, + cups, + autoPatchelfHook, + python3Packages, + + # Sets the default paper format: use "EU" for A4, or "Global" for Letter + region ? "EU", + # optional GUI, quite redundant to CUPS admin web GUI + withQtGui ? false, + qt5, }: # Open issues: @@ -52,52 +53,64 @@ stdenv.mkDerivation rec { sourceRoot = "."; - unpackCmd = let - platforms = { - x86_64-linux = "amd64"; - i686-linux = "i386"; - }; - platform = platforms.${stdenv.hostPlatform.system} or (throw "unsupported system: ${stdenv.hostPlatform.system}"); - in '' - ar p "$src/Debian/${region}/kyodialog_${platform}/kyodialog_${kyodialog_version}-0_${platform}.deb" data.tar.gz | tar -xz - ''; + unpackCmd = + let + platforms = { + x86_64-linux = "amd64"; + i686-linux = "i386"; + }; + platform = + platforms.${stdenv.hostPlatform.system} + or (throw "unsupported system: ${stdenv.hostPlatform.system}"); + in + '' + ar p "$src/Debian/${region}/kyodialog_${platform}/kyodialog_${kyodialog_version}-0_${platform}.deb" data.tar.gz | tar -xz + ''; - nativeBuildInputs = [ autoPatchelfHook python3Packages.wrapPython ] - ++ lib.optionals withQtGui [ qt5.wrapQtAppsHook ]; + nativeBuildInputs = [ + autoPatchelfHook + python3Packages.wrapPython + ] ++ lib.optionals withQtGui [ qt5.wrapQtAppsHook ]; buildInputs = [ cups ] ++ lib.optionals withQtGui [ qt5.qtbase ]; # For lib/cups/filter/kyofilter_pre_H. # The source already contains a copy of pypdf3, but we use the Nix package - propagatedBuildInputs = with python3Packages; [ reportlab pypdf3 setuptools ]; + propagatedBuildInputs = with python3Packages; [ + reportlab + pypdf3 + setuptools + ]; - installPhase = '' - # allow cups to find the ppd files - mkdir -p $out/share/cups/model - mv ./usr/share/kyocera${kyodialog_version}/ppd${kyodialog_version} $out/share/cups/model/Kyocera + installPhase = + '' + # allow cups to find the ppd files + mkdir -p $out/share/cups/model + mv ./usr/share/kyocera${kyodialog_version}/ppd${kyodialog_version} $out/share/cups/model/Kyocera - # remove absolute path prefixes to filters in ppd - find $out -name "*.ppd" -exec sed -E -i "s:/usr/lib/cups/filter/::g" {} \; + # remove absolute path prefixes to filters in ppd + find $out -name "*.ppd" -exec sed -E -i "s:/usr/lib/cups/filter/::g" {} \; - mkdir -p $out/lib/cups/ - mv ./usr/lib/cups/filter/ $out/lib/cups/ - # for lib/cups/filter/kyofilter_pre_H - wrapPythonProgramsIn $out/lib/cups/filter "$propagatedBuildInputs" + mkdir -p $out/lib/cups/ + mv ./usr/lib/cups/filter/ $out/lib/cups/ + # for lib/cups/filter/kyofilter_pre_H + wrapPythonProgramsIn $out/lib/cups/filter "$propagatedBuildInputs" - install -Dm444 usr/share/doc/kyodialog/copyright $out/share/doc/${pname}/copyright - '' + lib.optionalString withQtGui '' - install -D usr/bin/kyoPPDWrite_H $out/bin/kyoPPDWrite_H - install -D usr/bin/kyodialog${kyodialog_version} $out/bin/kyodialog + install -Dm444 usr/share/doc/kyodialog/copyright $out/share/doc/${pname}/copyright + '' + + lib.optionalString withQtGui '' + install -D usr/bin/kyoPPDWrite_H $out/bin/kyoPPDWrite_H + install -D usr/bin/kyodialog${kyodialog_version} $out/bin/kyodialog - install -Dm444 usr/share/kyocera${kyodialog_version}/appicon_H.png $out/share/${pname}/icons/appicon_H.png + install -Dm444 usr/share/kyocera${kyodialog_version}/appicon_H.png $out/share/${pname}/icons/appicon_H.png - install -Dm444 usr/share/applications/kyodialog${kyodialog_version}.desktop $out/share/applications/kyodialog.desktop - substituteInPlace $out/share/applications/kyodialog.desktop \ - --replace Exec=\"/usr/bin/kyodialog${kyodialog_version}\" Exec=\"$out/bin/kyodialog\" \ - --replace Icon=/usr/share/kyocera/appicon_H.png Icon=$out/share/${pname}/icons/appicon_H.png - ''; + install -Dm444 usr/share/applications/kyodialog${kyodialog_version}.desktop $out/share/applications/kyodialog.desktop + substituteInPlace $out/share/applications/kyodialog.desktop \ + --replace Exec=\"/usr/bin/kyodialog${kyodialog_version}\" Exec=\"$out/bin/kyodialog\" \ + --replace Icon=/usr/share/kyocera/appicon_H.png Icon=$out/share/${pname}/icons/appicon_H.png + ''; meta = with lib; { description = "CUPS drivers for several Kyocera printers"; @@ -105,6 +118,9 @@ stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; maintainers = [ maintainers.steveej ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/cu/cups-pdf-to-pdf/package.nix b/pkgs/by-name/cu/cups-pdf-to-pdf/package.nix index 7eb957af643fd9..3ea77ae473201d 100644 --- a/pkgs/by-name/cu/cups-pdf-to-pdf/package.nix +++ b/pkgs/by-name/cu/cups-pdf-to-pdf/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cups -, coreutils -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + cups, + coreutils, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cu/cups-printers/package.nix b/pkgs/by-name/cu/cups-printers/package.nix index 7b0cf99298a87d..be8f8a12cd29a6 100644 --- a/pkgs/by-name/cu/cups-printers/package.nix +++ b/pkgs/by-name/cu/cups-printers/package.nix @@ -23,14 +23,11 @@ python3.pkgs.buildPythonApplication rec { build-system = with python3.pkgs; [ poetry-core ]; - - dependencies = - with python3.pkgs; - [ - pycups - typer - validators - ]; + dependencies = with python3.pkgs; [ + pycups + typer + validators + ]; # Project has no tests doCheck = false; diff --git a/pkgs/by-name/cu/cups-toshiba-estudio/package.nix b/pkgs/by-name/cu/cups-toshiba-estudio/package.nix index 1af8d1f575b861..e73abb435ff204 100644 --- a/pkgs/by-name/cu/cups-toshiba-estudio/package.nix +++ b/pkgs/by-name/cu/cups-toshiba-estudio/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation { pname = "cups-toshiba-estudio"; diff --git a/pkgs/by-name/cu/cups-zj-58/package.nix b/pkgs/by-name/cu/cups-zj-58/package.nix index 0e2534997e350a..d36607d7624948 100644 --- a/pkgs/by-name/cu/cups-zj-58/package.nix +++ b/pkgs/by-name/cu/cups-zj-58/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchFromGitHub, cups}: +{ + lib, + stdenv, + fetchFromGitHub, + cups, +}: stdenv.mkDerivation { pname = "cups-zj-58"; diff --git a/pkgs/by-name/cu/curie/package.nix b/pkgs/by-name/cu/curie/package.nix index ba7d43055f95bf..63d14ddfc34e68 100644 --- a/pkgs/by-name/cu/curie/package.nix +++ b/pkgs/by-name/cu/curie/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "curie"; diff --git a/pkgs/by-name/cu/curlftpfs/package.nix b/pkgs/by-name/cu/curlftpfs/package.nix index 06a86a74b523d3..794544a22aaef8 100644 --- a/pkgs/by-name/cu/curlftpfs/package.nix +++ b/pkgs/by-name/cu/curlftpfs/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, autoreconfHook, fuse, curl, pkg-config, glib, zlib }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + fuse, + curl, + pkg-config, + glib, + zlib, +}: stdenv.mkDerivation rec { pname = "curlftpfs"; @@ -18,8 +28,16 @@ stdenv.mkDerivation rec { ./suse-bug-955687.patch ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ fuse curl glib zlib ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + fuse + curl + glib + zlib + ]; CFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin "-D__off_t=off_t"; diff --git a/pkgs/by-name/cu/curlie/package.nix b/pkgs/by-name/cu/curlie/package.nix index db70b9a51f0ec1..b215a3dfb105d7 100644 --- a/pkgs/by-name/cu/curlie/package.nix +++ b/pkgs/by-name/cu/curlie/package.nix @@ -1,4 +1,10 @@ -{ buildGoModule, fetchFromGitHub, lib, curlie, testers }: +{ + buildGoModule, + fetchFromGitHub, + lib, + curlie, + testers, +}: buildGoModule rec { pname = "curlie"; @@ -17,7 +23,11 @@ buildGoModule rec { vendorHash = "sha256-VsPdMUfS4UVem6uJgFISfFHQEKtIumDQktHQFPC1muc="; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; passthru.tests.version = testers.testVersion { package = curlie; diff --git a/pkgs/by-name/cu/curlpp/package.nix b/pkgs/by-name/cu/curlpp/package.nix index 26f52d9dbaed0a..eb2c8f8f95e610 100644 --- a/pkgs/by-name/cu/curlpp/package.nix +++ b/pkgs/by-name/cu/curlpp/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, curl }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + curl, +}: stdenv.mkDerivation rec { pname = "curlpp"; diff --git a/pkgs/by-name/cu/curseradio/package.nix b/pkgs/by-name/cu/curseradio/package.nix index 0faa58b9988435..ef38287b2d328b 100644 --- a/pkgs/by-name/cu/curseradio/package.nix +++ b/pkgs/by-name/cu/curseradio/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, substituteAll, python3Packages, mpv }: +{ + lib, + fetchFromGitHub, + substituteAll, + python3Packages, + mpv, +}: python3Packages.buildPythonApplication rec { version = "0.2"; diff --git a/pkgs/by-name/cu/cursewords/package.nix b/pkgs/by-name/cu/cursewords/package.nix index d73705090e1d65..f4f3d808cab3fd 100644 --- a/pkgs/by-name/cu/cursewords/package.nix +++ b/pkgs/by-name/cu/cursewords/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { pname = "cursewords"; diff --git a/pkgs/by-name/cu/curtail/package.nix b/pkgs/by-name/cu/curtail/package.nix index 591394d76a066e..82eb25d5e8afa3 100644 --- a/pkgs/by-name/cu/curtail/package.nix +++ b/pkgs/by-name/cu/curtail/package.nix @@ -1,21 +1,22 @@ -{ lib -, python3 -, fetchFromGitHub -, wrapGAppsHook4 -, appstream-glib -, desktop-file-utils -, gettext -, gtk4 -, libadwaita -, meson -, ninja -, pkg-config -, gobject-introspection -, jpegoptim -, libwebp -, optipng -, pngquant -, oxipng +{ + lib, + python3, + fetchFromGitHub, + wrapGAppsHook4, + appstream-glib, + desktop-file-utils, + gettext, + gtk4, + libadwaita, + meson, + ninja, + pkg-config, + gobject-introspection, + jpegoptim, + libwebp, + optipng, + pngquant, + oxipng, }: python3.pkgs.buildPythonApplication rec { @@ -63,7 +64,15 @@ python3.pkgs.buildPythonApplication rec { preFixup = '' makeWrapperArgs+=( "''${gappsWrapperArgs[@]}" - "--prefix" "PATH" ":" "${lib.makeBinPath [ jpegoptim libwebp optipng pngquant oxipng ]}" + "--prefix" "PATH" ":" "${ + lib.makeBinPath [ + jpegoptim + libwebp + optipng + pngquant + oxipng + ] + }" ) ''; diff --git a/pkgs/by-name/cu/curv/package.nix b/pkgs/by-name/cu/curv/package.nix index f1f66784aa510f..88a270fd62950b 100644 --- a/pkgs/by-name/cu/curv/package.nix +++ b/pkgs/by-name/cu/curv/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, boost -, eigen -, glm -, libGL -, libpng -, openexr -, tbb -, xorg -, ilmbase -, llvmPackages +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + eigen, + glm, + libGL, + libpng, + openexr, + tbb, + xorg, + ilmbase, + llvmPackages, }: stdenv.mkDerivation rec { @@ -31,24 +32,26 @@ stdenv.mkDerivation rec { cmake ]; - buildInputs = [ - boost - eigen - glm - libGL - libpng - openexr - tbb - xorg.libX11 - xorg.libXcursor - xorg.libXext - xorg.libXi - xorg.libXinerama - xorg.libXrandr - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ilmbase - llvmPackages.openmp - ]; + buildInputs = + [ + boost + eigen + glm + libGL + libpng + openexr + tbb + xorg.libX11 + xorg.libXcursor + xorg.libXext + xorg.libXi + xorg.libXinerama + xorg.libXrandr + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ilmbase + llvmPackages.openmp + ]; # GPU tests do not work in sandbox, instead we do this for sanity checkPhase = '' diff --git a/pkgs/by-name/cu/cutecapture/package.nix b/pkgs/by-name/cu/cutecapture/package.nix index 238249883ef99b..77859e6b47557c 100644 --- a/pkgs/by-name/cu/cutecapture/package.nix +++ b/pkgs/by-name/cu/cutecapture/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, libusb1 -, sfml +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libusb1, + sfml, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/cu/cutee/package.nix b/pkgs/by-name/cu/cutee/package.nix index eb5f51cbcfeb47..a25111f7a3ddf7 100644 --- a/pkgs/by-name/cu/cutee/package.nix +++ b/pkgs/by-name/cu/cutee/package.nix @@ -1,11 +1,15 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "cutee"; version = "0.4.2"; src = fetchurl { - url = "http://www.codesink.org/download/${pname}-${version}.tar.gz"; + url = "http://www.codesink.org/download/${pname}-${version}.tar.gz"; sha256 = "18bzvhzx8k24mpcim5669n3wg9hd0sfsxj8zjpbr24hywrlppgc2"; }; @@ -19,9 +23,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "C++ Unit Testing Easy Environment"; mainProgram = "cutee"; - homepage = "https://www.codesink.org/cutee_unit_testing.html"; - license = licenses.gpl2Plus; - maintainers = with maintainers; [ leenaars]; + homepage = "https://www.codesink.org/cutee_unit_testing.html"; + license = licenses.gpl2Plus; + maintainers = with maintainers; [ leenaars ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/cu/cuyo/package.nix b/pkgs/by-name/cu/cuyo/package.nix index 6132b33a3b890c..f95a9d3b5a91e6 100644 --- a/pkgs/by-name/cu/cuyo/package.nix +++ b/pkgs/by-name/cu/cuyo/package.nix @@ -1,21 +1,32 @@ -{ lib, stdenv, fetchurl, SDL, SDL_mixer, zlib }: +{ + lib, + stdenv, + fetchurl, + SDL, + SDL_mixer, + zlib, +}: stdenv.mkDerivation { pname = "cuyo"; version = "2.1.0"; src = fetchurl { - url = "https://download.savannah.gnu.org/releases/cuyo/cuyo-2.1.0.tar.gz"; - sha256 = "17yqv924x7yvwix7yz9jdhgyar8lzdhqvmpvv0any8rdkajhj23c"; - }; + url = "https://download.savannah.gnu.org/releases/cuyo/cuyo-2.1.0.tar.gz"; + sha256 = "17yqv924x7yvwix7yz9jdhgyar8lzdhqvmpvv0any8rdkajhj23c"; + }; - buildInputs = [ SDL SDL_mixer zlib ]; + buildInputs = [ + SDL + SDL_mixer + zlib + ]; meta = { - homepage = "http://karimmi.de/cuyo"; - description = "Stacking blocks game, with different rules for each level"; - mainProgram = "cuyo"; - license = lib.licenses.gpl2Plus; + homepage = "http://karimmi.de/cuyo"; + description = "Stacking blocks game, with different rules for each level"; + mainProgram = "cuyo"; + license = lib.licenses.gpl2Plus; platforms = lib.platforms.linux; }; diff --git a/pkgs/by-name/cv/cvc4/package.nix b/pkgs/by-name/cv/cvc4/package.nix index c44b495f2caef6..9cd516c7aa8ba7 100644 --- a/pkgs/by-name/cv/cvc4/package.nix +++ b/pkgs/by-name/cv/cvc4/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, cmake, cln, gmp, git, swig, pkg-config -, readline, libantlr3c, boost, jdk, python3, antlr3_4 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + cln, + gmp, + git, + swig, + pkg-config, + readline, + libantlr3c, + boost, + jdk, + python3, + antlr3_4, }: stdenv.mkDerivation rec { @@ -7,15 +21,28 @@ stdenv.mkDerivation rec { version = "1.8"; src = fetchFromGitHub { - owner = "cvc4"; - repo = "cvc4"; - rev = version; + owner = "cvc4"; + repo = "cvc4"; + rev = version; sha256 = "1rhs4pvzaa1wk00czrczp58b2cxfghpsnq534m0l3snnya2958jp"; }; - nativeBuildInputs = [ pkg-config cmake ]; - buildInputs = [ gmp git python3.pkgs.toml readline swig libantlr3c antlr3_4 boost jdk python3 ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ cln ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; + buildInputs = [ + gmp + git + python3.pkgs.toml + readline + swig + libantlr3c + antlr3_4 + boost + jdk + python3 + ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ cln ]; configureFlags = [ "--enable-language-bindings=c,c++,java" "--enable-gpl" @@ -41,9 +68,13 @@ stdenv.mkDerivation rec { meta = with lib; { description = "High-performance theorem prover and SMT solver"; mainProgram = "cvc4"; - homepage = "http://cvc4.cs.stanford.edu/web/"; - license = licenses.gpl3; - platforms = platforms.unix; - maintainers = with maintainers; [ vbgl thoughtpolice gebner ]; + homepage = "http://cvc4.cs.stanford.edu/web/"; + license = licenses.gpl3; + platforms = platforms.unix; + maintainers = with maintainers; [ + vbgl + thoughtpolice + gebner + ]; }; } diff --git a/pkgs/by-name/cv/cvehound/package.nix b/pkgs/by-name/cv/cvehound/package.nix index 9eedade72dd9cc..5e86d13d1e23f9 100644 --- a/pkgs/by-name/cv/cvehound/package.nix +++ b/pkgs/by-name/cv/cvehound/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, coccinelle -, gnugrep -, python3 +{ + lib, + fetchFromGitHub, + coccinelle, + gnugrep, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -17,7 +18,12 @@ python3.pkgs.buildPythonApplication rec { }; makeWrapperArgs = [ - "--prefix PATH : ${lib.makeBinPath [ coccinelle gnugrep ]}" + "--prefix PATH : ${ + lib.makeBinPath [ + coccinelle + gnugrep + ] + }" ]; propagatedBuildInputs = with python3.pkgs; [ @@ -40,7 +46,10 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://github.com/evdenis/cvehound"; changelog = "https://github.com/evdenis/cvehound/blob/${src.rev}/ChangeLog"; # See https://github.com/evdenis/cvehound/issues/22 - license = with licenses; [ gpl2Only gpl3Plus ]; + license = with licenses; [ + gpl2Only + gpl3Plus + ]; maintainers = with maintainers; [ ambroisie ]; }; } diff --git a/pkgs/by-name/cv/cvemap/package.nix b/pkgs/by-name/cv/cvemap/package.nix index a9709006e2fc7e..0146986657db36 100644 --- a/pkgs/by-name/cv/cvemap/package.nix +++ b/pkgs/by-name/cv/cvemap/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/cv/cvs-fast-export/package.nix b/pkgs/by-name/cv/cvs-fast-export/package.nix index a58cda54365844..86d78a751d3ce4 100644 --- a/pkgs/by-name/cv/cvs-fast-export/package.nix +++ b/pkgs/by-name/cv/cvs-fast-export/package.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchurl, makeWrapper, asciidoc, docbook_xml_dtd_45, docbook_xsl -, coreutils, cvs, diffutils, findutils, git, python3, rsync +{ + lib, + stdenv, + fetchurl, + makeWrapper, + asciidoc, + docbook_xml_dtd_45, + docbook_xsl, + coreutils, + cvs, + diffutils, + findutils, + git, + python3, + rsync, }: stdenv.mkDerivation rec { @@ -12,7 +25,10 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ makeWrapper asciidoc ]; + nativeBuildInputs = [ + makeWrapper + asciidoc + ]; buildInputs = [ python3 ]; postPatch = '' @@ -33,9 +49,15 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/cvssync --prefix PATH : ${lib.makeBinPath [ rsync ]} - wrapProgram $out/bin/cvsconvert --prefix PATH : $out/bin:${lib.makeBinPath [ - coreutils cvs diffutils findutils git - ]} + wrapProgram $out/bin/cvsconvert --prefix PATH : $out/bin:${ + lib.makeBinPath [ + coreutils + cvs + diffutils + findutils + git + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/cv/cvs2svn/package.nix b/pkgs/by-name/cv/cvs2svn/package.nix index 5ddb9a0da84b32..c493c07d97bbcc 100644 --- a/pkgs/by-name/cv/cvs2svn/package.nix +++ b/pkgs/by-name/cv/cvs2svn/package.nix @@ -1,10 +1,16 @@ -{ lib, fetchurl, makeWrapper -, pypy2Packages -, cvs, subversion, git, breezy -, installShellFiles +{ + lib, + fetchurl, + makeWrapper, + pypy2Packages, + cvs, + subversion, + git, + breezy, + installShellFiles, }: -pypy2Packages.buildPythonApplication rec { +pypy2Packages.buildPythonApplication rec { pname = "cvs2svn"; version = "2.5.0"; @@ -13,9 +19,16 @@ pypy2Packages.buildPythonApplication rec { sha256 = "1ska0z15sjhyfi860rjazz9ya1gxbf5c0h8dfqwz88h7fccd22b4"; }; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; - nativeCheckInputs = [ subversion git breezy ]; + nativeCheckInputs = [ + subversion + git + breezy + ]; checkPhase = "${pypy2Packages.python.interpreter} run-tests.py"; @@ -33,7 +46,10 @@ pypy2Packages.buildPythonApplication rec { meta = with lib; { description = "Tool to convert CVS repositories to Subversion repositories"; homepage = "https://github.com/mhagger/cvs2svn"; - maintainers = with maintainers; [ makefu viraptor ]; + maintainers = with maintainers; [ + makefu + viraptor + ]; platforms = platforms.unix; license = licenses.asl20; }; diff --git a/pkgs/by-name/cv/cvsps/package.nix b/pkgs/by-name/cv/cvsps/package.nix index 85c092ffe7a61c..cd2d043539d4a1 100644 --- a/pkgs/by-name/cv/cvsps/package.nix +++ b/pkgs/by-name/cv/cvsps/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, fetchpatch, cvs, zlib }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + cvs, + zlib, +}: stdenv.mkDerivation rec { pname = "cvsps"; @@ -10,39 +17,42 @@ stdenv.mkDerivation rec { }; # Patches from https://sources.debian.net/src/cvsps/2.1-7/debian/patches - patches = - [ (fetchpatch { - url = "https://sources.debian.net/data/main/c/cvsps/2.1-7/debian/patches/01_ignoretrunk.patch"; - sha256 = "1gzb97dw2a6bm0bmim7p7wvsn0r82y3a8n22ln6rbbkkd8vlnzcb"; - }) - - (fetchpatch { - url = "https://sources.debian.net/data/main/c/cvsps/2.1-7/debian/patches/02_dynamicbufferalloc.patch"; - sha256 = "0dm7azxnw0g9pdqkb3y4y2h047zgrclbh40av6c868wfp2j6l9sc"; - }) - - (fetchpatch { - url = "https://sources.debian.net/data/main/c/cvsps/2.1-7/debian/patches/03_diffoptstypo.patch"; - sha256 = "06n8652g7inpv8cgqir7ijq00qw1fr0v44m2pbmgx7ilmna2vrcw"; - }) - - (fetchpatch { - url = "https://sources.debian.net/data/main/c/cvsps/2.1-7/debian/patches/05-inet_addr_fix.patch"; - sha256 = "10w6px96dz8bb69asjzshvp787ccazmqnjsggqc4gwdal95q3cn7"; - }) - - (fetchpatch { - url = "https://sources.debian.net/data/main/c/cvsps/2.1-7/debian/patches/fix-makefile"; - sha256 = "0m92b55hgldwg6lwdaybbj0n3lw1b3wj2xkk1cz1ywq073bpf3jm"; - }) - - (fetchpatch { - url = "https://sources.debian.net/data/main/c/cvsps/2.1-7/debian/patches/fix-manpage"; - sha256 = "0gky14rhx82wv0gj8bkc74ki5xilhv5i3k1jc7khklr4lb6mmhpx"; - }) - ]; - - buildInputs = [ cvs zlib ]; + patches = [ + (fetchpatch { + url = "https://sources.debian.net/data/main/c/cvsps/2.1-7/debian/patches/01_ignoretrunk.patch"; + sha256 = "1gzb97dw2a6bm0bmim7p7wvsn0r82y3a8n22ln6rbbkkd8vlnzcb"; + }) + + (fetchpatch { + url = "https://sources.debian.net/data/main/c/cvsps/2.1-7/debian/patches/02_dynamicbufferalloc.patch"; + sha256 = "0dm7azxnw0g9pdqkb3y4y2h047zgrclbh40av6c868wfp2j6l9sc"; + }) + + (fetchpatch { + url = "https://sources.debian.net/data/main/c/cvsps/2.1-7/debian/patches/03_diffoptstypo.patch"; + sha256 = "06n8652g7inpv8cgqir7ijq00qw1fr0v44m2pbmgx7ilmna2vrcw"; + }) + + (fetchpatch { + url = "https://sources.debian.net/data/main/c/cvsps/2.1-7/debian/patches/05-inet_addr_fix.patch"; + sha256 = "10w6px96dz8bb69asjzshvp787ccazmqnjsggqc4gwdal95q3cn7"; + }) + + (fetchpatch { + url = "https://sources.debian.net/data/main/c/cvsps/2.1-7/debian/patches/fix-makefile"; + sha256 = "0m92b55hgldwg6lwdaybbj0n3lw1b3wj2xkk1cz1ywq073bpf3jm"; + }) + + (fetchpatch { + url = "https://sources.debian.net/data/main/c/cvsps/2.1-7/debian/patches/fix-manpage"; + sha256 = "0gky14rhx82wv0gj8bkc74ki5xilhv5i3k1jc7khklr4lb6mmhpx"; + }) + ]; + + buildInputs = [ + cvs + zlib + ]; installFlags = [ "prefix=$(out)" ]; diff --git a/pkgs/by-name/cv/cvsq/package.nix b/pkgs/by-name/cv/cvsq/package.nix index 09e687af7ba392..13f7ee5547d4a4 100644 --- a/pkgs/by-name/cv/cvsq/package.nix +++ b/pkgs/by-name/cv/cvsq/package.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, fetchurl -, makeWrapper -, cvs -, perl -, nettools -, findutils -, rsync -, coreutils -, diffutils -} : +{ + lib, + stdenv, + fetchurl, + makeWrapper, + cvs, + perl, + nettools, + findutils, + rsync, + coreutils, + diffutils, +}: stdenv.mkDerivation rec { pname = "cvsq"; @@ -20,24 +22,71 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ cvs perl nettools findutils rsync coreutils diffutils ]; - + buildInputs = [ + cvs + perl + nettools + findutils + rsync + coreutils + diffutils + ]; makeFlags = [ "prefix=$(out)" ]; postInstall = '' substituteInPlace $out/bin/cvsq --replace "/bin/sh" "${stdenv.shell}" substituteInPlace $out/bin/lcvs --replace "/bin/sh" "${stdenv.shell}" - wrapProgram $out/bin/cvsq --prefix PATH : ${lib.makeBinPath - [ cvs nettools findutils rsync coreutils diffutils ]} - wrapProgram $out/bin/cvsq-branch --prefix PATH : ${lib.makeBinPath - [ cvs nettools findutils rsync coreutils diffutils ]} - wrapProgram $out/bin/cvsq-merge --prefix PATH : ${lib.makeBinPath - [ cvs nettools findutils rsync coreutils diffutils ]} - wrapProgram $out/bin/cvsq-switch --prefix PATH : ${lib.makeBinPath - [ cvs nettools findutils rsync coreutils diffutils ]} - wrapProgram $out/bin/lcvs --prefix PATH : ${lib.makeBinPath - [ cvs nettools findutils rsync coreutils diffutils ]} + wrapProgram $out/bin/cvsq --prefix PATH : ${ + lib.makeBinPath [ + cvs + nettools + findutils + rsync + coreutils + diffutils + ] + } + wrapProgram $out/bin/cvsq-branch --prefix PATH : ${ + lib.makeBinPath [ + cvs + nettools + findutils + rsync + coreutils + diffutils + ] + } + wrapProgram $out/bin/cvsq-merge --prefix PATH : ${ + lib.makeBinPath [ + cvs + nettools + findutils + rsync + coreutils + diffutils + ] + } + wrapProgram $out/bin/cvsq-switch --prefix PATH : ${ + lib.makeBinPath [ + cvs + nettools + findutils + rsync + coreutils + diffutils + ] + } + wrapProgram $out/bin/lcvs --prefix PATH : ${ + lib.makeBinPath [ + cvs + nettools + findutils + rsync + coreutils + diffutils + ] + } ''; meta = { diff --git a/pkgs/by-name/cw/cw/package.nix b/pkgs/by-name/cw/cw/package.nix index 4fb987abd5e691..8e3da631217e35 100644 --- a/pkgs/by-name/cw/cw/package.nix +++ b/pkgs/by-name/cw/cw/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "cw"; diff --git a/pkgs/by-name/cw/cwebbin/package.nix b/pkgs/by-name/cw/cwebbin/package.nix index fc07a523ff0b50..c6ec2f0dbd7284 100644 --- a/pkgs/by-name/cw/cwebbin/package.nix +++ b/pkgs/by-name/cw/cwebbin/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl, tie }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + tie, +}: let cweb = fetchurl { diff --git a/pkgs/by-name/cw/cwiid/package.nix b/pkgs/by-name/cw/cwiid/package.nix index d8c472870c4341..98e5fc9c1a845d 100644 --- a/pkgs/by-name/cw/cwiid/package.nix +++ b/pkgs/by-name/cw/cwiid/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, bison -, flex -, bluez -, pkg-config -, gtk2 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + bison, + flex, + bluez, + pkg-config, + gtk2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cw/cwm/package.nix b/pkgs/by-name/cw/cwm/package.nix index 89187c89d6cab0..24fa80afbd2233 100644 --- a/pkgs/by-name/cw/cwm/package.nix +++ b/pkgs/by-name/cw/cwm/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, libX11, libXinerama, libXrandr, libXft, bison, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + libXinerama, + libXrandr, + libXft, + bison, + pkg-config, +}: stdenv.mkDerivation rec { @@ -14,17 +24,28 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ pkg-config bison ]; - buildInputs = [ libX11 libXinerama libXrandr libXft ]; + nativeBuildInputs = [ + pkg-config + bison + ]; + buildInputs = [ + libX11 + libXinerama + libXrandr + libXft + ]; prePatch = ''sed -i "s@/usr/local@$out@" Makefile''; meta = with lib; { description = "Lightweight and efficient window manager for X11"; - homepage = "https://github.com/leahneukirchen/cwm"; - maintainers = with maintainers; [ _0x4A6F mkf ]; - license = licenses.isc; - platforms = platforms.linux; + homepage = "https://github.com/leahneukirchen/cwm"; + maintainers = with maintainers; [ + _0x4A6F + mkf + ]; + license = licenses.isc; + platforms = platforms.linux; mainProgram = "cwm"; }; } diff --git a/pkgs/by-name/cx/cxx-prettyprint/package.nix b/pkgs/by-name/cx/cxx-prettyprint/package.nix index f632fca714cf59..2745dfe61a2f14 100644 --- a/pkgs/by-name/cx/cxx-prettyprint/package.nix +++ b/pkgs/by-name/cx/cxx-prettyprint/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "cxx-prettyprint-unstable"; @@ -18,12 +22,12 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = "Header only C++ library for pretty printing standard containers"; - homepage = "https://github.com/louisdx/cxx-prettyprint"; - license = lib.licenses.boost; - platforms = platforms.all; + description = "Header only C++ library for pretty printing standard containers"; + homepage = "https://github.com/louisdx/cxx-prettyprint"; + license = lib.licenses.boost; + platforms = platforms.all; # This is a header-only library, no point in hydra building it: - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/by-name/cx/cxx-rs/package.nix b/pkgs/by-name/cx/cxx-rs/package.nix index fb1ce99fda6dea..88d0bf8d66376a 100644 --- a/pkgs/by-name/cx/cxx-rs/package.nix +++ b/pkgs/by-name/cx/cxx-rs/package.nix @@ -1,4 +1,10 @@ -{ cxx-rs, fetchFromGitHub, lib, rustPlatform, testers }: +{ + cxx-rs, + fetchFromGitHub, + lib, + rustPlatform, + testers, +}: rustPlatform.buildRustPackage rec { pname = "cxx-rs"; @@ -30,7 +36,11 @@ rustPlatform.buildRustPackage rec { cargoTestFlags = [ "--workspace" ]; - outputs = [ "out" "doc" "dev" ]; + outputs = [ + "out" + "doc" + "dev" + ]; postInstall = '' mkdir -p $doc diff --git a/pkgs/by-name/cx/cxxopts/package.nix b/pkgs/by-name/cx/cxxopts/package.nix index 89276c7a0b44f7..9fa2156ce30081 100644 --- a/pkgs/by-name/cx/cxxopts/package.nix +++ b/pkgs/by-name/cx/cxxopts/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, icu -, pkg-config -, enableUnicodeHelp ? true +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + icu, + pkg-config, + enableUnicodeHelp ? true, }: stdenv.mkDerivation rec { @@ -19,8 +20,9 @@ stdenv.mkDerivation rec { }; buildInputs = lib.optionals enableUnicodeHelp [ icu.dev ]; - cmakeFlags = [ "-DCXXOPTS_BUILD_EXAMPLES=OFF" ] - ++ lib.optional enableUnicodeHelp "-DCXXOPTS_USE_UNICODE_HELP=TRUE"; + cmakeFlags = [ + "-DCXXOPTS_BUILD_EXAMPLES=OFF" + ] ++ lib.optional enableUnicodeHelp "-DCXXOPTS_USE_UNICODE_HELP=TRUE"; nativeBuildInputs = [ cmake ] ++ lib.optionals enableUnicodeHelp [ pkg-config ]; doCheck = true; diff --git a/pkgs/by-name/cx/cxxtools/package.nix b/pkgs/by-name/cx/cxxtools/package.nix index 8682c8ba819657..356440e046b6d4 100644 --- a/pkgs/by-name/cx/cxxtools/package.nix +++ b/pkgs/by-name/cx/cxxtools/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, tzdata -, autoreconfHook -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + tzdata, + autoreconfHook, + openssl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cy/cyan/package.nix b/pkgs/by-name/cy/cyan/package.nix index 22fab6cc8d9269..0e625169ab3aca 100644 --- a/pkgs/by-name/cy/cyan/package.nix +++ b/pkgs/by-name/cy/cyan/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, qt5 -, cmake -, pkg-config -, imagemagick -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + qt5, + cmake, + pkg-config, + imagemagick, + nix-update-script, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cy/cyanrip/package.nix b/pkgs/by-name/cy/cyanrip/package.nix index 149d370ba49587..2af30984eecc66 100644 --- a/pkgs/by-name/cy/cyanrip/package.nix +++ b/pkgs/by-name/cy/cyanrip/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, ffmpeg-headless -, libcdio -, libcdio-paranoia -, libmusicbrainz5 -, curl +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + ffmpeg-headless, + libcdio, + libcdio-paranoia, + libmusicbrainz5, + curl, }: stdenv.mkDerivation (finalAttrs: { pname = "cyanrip"; diff --git a/pkgs/by-name/cy/cyber/package.nix b/pkgs/by-name/cy/cyber/package.nix index 19d266da0e4150..651e8aed7d6d0e 100644 --- a/pkgs/by-name/cy/cyber/package.nix +++ b/pkgs/by-name/cy/cyber/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, zig_0_11 +{ + lib, + stdenv, + fetchFromGitHub, + zig_0_11, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cy/cyberchef/package.nix b/pkgs/by-name/cy/cyberchef/package.nix index 2d29f582ff2c19..bc819b64064fa9 100644 --- a/pkgs/by-name/cy/cyberchef/package.nix +++ b/pkgs/by-name/cy/cyberchef/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchzip -, stdenv +{ + lib, + fetchzip, + stdenv, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cy/cyclone-scheme/package.nix b/pkgs/by-name/cy/cyclone-scheme/package.nix index 75a4b763ae7d82..178c427c63ae0c 100644 --- a/pkgs/by-name/cy/cyclone-scheme/package.nix +++ b/pkgs/by-name/cy/cyclone-scheme/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, libck, cctools }: +{ + lib, + stdenv, + fetchFromGitHub, + libck, + cctools, +}: let version = "0.34.0"; @@ -35,8 +41,7 @@ stdenv.mkDerivation { enableParallelBuilding = true; - nativeBuildInputs = [ bootstrap ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools ]; + nativeBuildInputs = [ bootstrap ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools ]; buildInputs = [ libck ]; diff --git a/pkgs/by-name/cy/cyclone/package.nix b/pkgs/by-name/cy/cyclone/package.nix index db46c1224ee6ca..d14695e858b434 100644 --- a/pkgs/by-name/cy/cyclone/package.nix +++ b/pkgs/by-name/cy/cyclone/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, puredata }: +{ + lib, + stdenv, + fetchFromGitHub, + puredata, +}: stdenv.mkDerivation rec { pname = "cyclone"; @@ -27,7 +32,10 @@ stdenv.mkDerivation rec { description = "Library of PureData classes, bringing some level of compatibility between Max/MSP and Pd environments"; homepage = "http://puredata.info/downloads/cyclone"; license = licenses.tcltk; - maintainers = with maintainers; [ magnetophon carlthome ]; + maintainers = with maintainers; [ + magnetophon + carlthome + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/cy/cyclonedds-cxx/package.nix b/pkgs/by-name/cy/cyclonedds-cxx/package.nix index e3c4aec9e8f537..4e556d718c268d 100644 --- a/pkgs/by-name/cy/cyclonedds-cxx/package.nix +++ b/pkgs/by-name/cy/cyclonedds-cxx/package.nix @@ -1,15 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, cyclonedds +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + cyclonedds, }: stdenv.mkDerivation rec { pname = "cyclonedds-cxx"; version = "0.10.5"; - outputs = ["out" "dev"]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "eclipse-cyclonedds"; @@ -23,9 +27,12 @@ stdenv.mkDerivation rec { buildInputs = [ cyclonedds ]; meta = with lib; { - description = "C++ binding for Eclipse Cyclone DDS"; - homepage = "https://cyclonedds.io/"; - license = with licenses; [ epl20 asl20 ]; - maintainers = with maintainers; [ linbreux ]; - }; + description = "C++ binding for Eclipse Cyclone DDS"; + homepage = "https://cyclonedds.io/"; + license = with licenses; [ + epl20 + asl20 + ]; + maintainers = with maintainers; [ linbreux ]; + }; } diff --git a/pkgs/by-name/cy/cyclonedds/package.nix b/pkgs/by-name/cy/cyclonedds/package.nix index bdea4b68138a6c..dca6111c6cc501 100644 --- a/pkgs/by-name/cy/cyclonedds/package.nix +++ b/pkgs/by-name/cy/cyclonedds/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/cy/cyclonedx-python/package.nix b/pkgs/by-name/cy/cyclonedx-python/package.nix index fe37119359519e..4e7c16d2e769be 100644 --- a/pkgs/by-name/cy/cyclonedx-python/package.nix +++ b/pkgs/by-name/cy/cyclonedx-python/package.nix @@ -18,14 +18,17 @@ python3Packages.buildPythonApplication rec { build-system = with python3Packages; [ poetry-core ]; - dependencies = with python3Packages; [ - chardet - cyclonedx-python-lib - packageurl-python - pip-requirements-parser - packaging - tomli - ] ++ cyclonedx-python-lib.optional-dependencies.validation; + dependencies = + with python3Packages; + [ + chardet + cyclonedx-python-lib + packageurl-python + pip-requirements-parser + packaging + tomli + ] + ++ cyclonedx-python-lib.optional-dependencies.validation; pythonImportsCheck = [ "cyclonedx" ]; diff --git a/pkgs/by-name/cy/cyme/package.nix b/pkgs/by-name/cy/cyme/package.nix index 329f92521f8fd3..b524e843dfcc13 100644 --- a/pkgs/by-name/cy/cyme/package.nix +++ b/pkgs/by-name/cy/cyme/package.nix @@ -1,14 +1,14 @@ { - lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, stdenv -, darwin -, libusb1 -, nix-update-script -, testers -, cyme + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + stdenv, + darwin, + libusb1, + nix-update-script, + testers, + cyme, }: rustPlatform.buildRustPackage rec { @@ -24,23 +24,27 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-sg6nIIiHUXHLnvn25kKWqqa8WV86D/arl4t3EUByQBQ="; - nativeBuildInputs = [ - pkg-config - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.DarwinTools - ]; + nativeBuildInputs = + [ + pkg-config + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.DarwinTools + ]; buildInputs = [ libusb1 ]; - checkFlags = [ - # doctest that requires access outside sandbox - "--skip=udev::hwdb::get" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # system_profiler is not available in the sandbox - "--skip=test_run" - ]; + checkFlags = + [ + # doctest that requires access outside sandbox + "--skip=udev::hwdb::get" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # system_profiler is not available in the sandbox + "--skip=test_run" + ]; passthru = { updateScript = nix-update-script { }; diff --git a/pkgs/by-name/cy/cyrus-sasl-xoauth2/package.nix b/pkgs/by-name/cy/cyrus-sasl-xoauth2/package.nix index bc81574a0cdf65..922d38422877ee 100644 --- a/pkgs/by-name/cy/cyrus-sasl-xoauth2/package.nix +++ b/pkgs/by-name/cy/cyrus-sasl-xoauth2/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, libtool, automake, cyrus_sasl }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + libtool, + automake, + cyrus_sasl, +}: stdenv.mkDerivation rec { pname = "cyrus-sasl-xoauth2"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-lI8uKtVxrziQ8q/Ss+QTgg1xTObZUTAzjL3MYmtwyd8="; }; - nativeBuildInputs = [ autoconf libtool automake ]; + nativeBuildInputs = [ + autoconf + libtool + automake + ]; buildInputs = [ cyrus_sasl ]; diff --git a/pkgs/by-name/cy/cyrus_sasl/package.nix b/pkgs/by-name/cy/cyrus_sasl/package.nix index e98ae4cbb109cb..68d019ca2619bf 100644 --- a/pkgs/by-name/cy/cyrus_sasl/package.nix +++ b/pkgs/by-name/cy/cyrus_sasl/package.nix @@ -1,17 +1,33 @@ -{ lib, stdenv, fetchurl, fetchpatch, openssl, openldap, libkrb5, db, gettext -, pam, libxcrypt, fixDarwinDylibNames, autoreconfHook, enableLdap ? false -, buildPackages, pruneLibtoolFiles, nixosTests }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + openssl, + openldap, + libkrb5, + db, + gettext, + pam, + libxcrypt, + fixDarwinDylibNames, + autoreconfHook, + enableLdap ? false, + buildPackages, + pruneLibtoolFiles, + nixosTests, +}: stdenv.mkDerivation rec { pname = "cyrus-sasl"; version = "2.1.28"; src = fetchurl { - urls = - [ "https://github.com/cyrusimap/${pname}/releases/download/${pname}-${version}/${pname}-${version}.tar.gz" - "http://www.cyrusimap.org/releases/${pname}-${version}.tar.gz" - "http://www.cyrusimap.org/releases/old/${pname}-${version}.tar.gz" - ]; + urls = [ + "https://github.com/cyrusimap/${pname}/releases/download/${pname}-${version}/${pname}-${version}.tar.gz" + "http://www.cyrusimap.org/releases/${pname}-${version}.tar.gz" + "http://www.cyrusimap.org/releases/old/${pname}-${version}.tar.gz" + ]; sha256 = "sha256-fM/Gq9Ae1nwaCSSzU+Um8bdmsh9C1FYu5jWo6/xbs4w="; }; @@ -25,23 +41,39 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "bin" "dev" "out" "man" "devdoc" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + "devdoc" + ]; depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ autoreconfHook pruneLibtoolFiles ] - ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; + nativeBuildInputs = [ + autoreconfHook + pruneLibtoolFiles + ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; buildInputs = - [ openssl db gettext libkrb5 libxcrypt ] + [ + openssl + db + gettext + libkrb5 + libxcrypt + ] ++ lib.optional enableLdap openldap ++ lib.optional stdenv.hostPlatform.isLinux pam; - configureFlags = [ - "--with-openssl=${openssl.dev}" - "--with-plugindir=${placeholder "out"}/lib/sasl2" - "--with-saslauthd=/run/saslauthd" - "--enable-login" - "--enable-shared" - ] ++ lib.optional enableLdap "--with-ldap=${openldap.dev}" + configureFlags = + [ + "--with-openssl=${openssl.dev}" + "--with-plugindir=${placeholder "out"}/lib/sasl2" + "--with-saslauthd=/run/saslauthd" + "--enable-login" + "--enable-shared" + ] + ++ lib.optional enableLdap "--with-ldap=${openldap.dev}" ++ lib.optionals (stdenv.targetPlatform.useLLVM or false) [ "--disable-sample" "CFLAGS=-DTIME_WITH_SYS_TIME" @@ -51,7 +83,9 @@ stdenv.mkDerivation rec { NIX_CFLAGS_COMPILE = "-Wno-error=implicit-function-declaration"; }; - installFlags = lib.optionals stdenv.hostPlatform.isDarwin [ "framedir=$(out)/Library/Frameworks/SASL2.framework" ]; + installFlags = lib.optionals stdenv.hostPlatform.isDarwin [ + "framedir=$(out)/Library/Frameworks/SASL2.framework" + ]; passthru.tests = { inherit (nixosTests) parsedmarc postfix; diff --git a/pkgs/by-name/cz/cz-cli/package.nix b/pkgs/by-name/cz/cz-cli/package.nix index e268b6d164f838..c3b5f7600ad02b 100644 --- a/pkgs/by-name/cz/cz-cli/package.nix +++ b/pkgs/by-name/cz/cz-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { @@ -20,7 +21,10 @@ buildNpmPackage rec { description = "Commitizen command line utility"; homepage = "https://commitizen.github.io/cz-cli"; changelog = "https://github.com/commitizen/cz-cli/releases/tag/v${version}"; - maintainers = with maintainers; [ freezeboy natsukium ]; + maintainers = with maintainers; [ + freezeboy + natsukium + ]; license = licenses.mit; }; } diff --git a/pkgs/by-name/cz/czmq/package.nix b/pkgs/by-name/cz/czmq/package.nix index db2b99c9665020..8ae99d51d61ce2 100644 --- a/pkgs/by-name/cz/czmq/package.nix +++ b/pkgs/by-name/cz/czmq/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, zeromq }: +{ + lib, + stdenv, + fetchurl, + zeromq, +}: stdenv.mkDerivation rec { version = "4.2.1"; diff --git a/pkgs/by-name/d-/d-seams/package.nix b/pkgs/by-name/d-/d-seams/package.nix index 5b5d8cfbd9d42e..2ac502514a8a52 100644 --- a/pkgs/by-name/d-/d-seams/package.nix +++ b/pkgs/by-name/d-/d-seams/package.nix @@ -1,5 +1,21 @@ -{ clangStdenv, fetchFromGitHub, fetchpatch, catch2, rang, fmt, yaml-cpp, cmake -, eigen, lua, luaPackages, liblapack, blas, lib, boost, gsl }: +{ + clangStdenv, + fetchFromGitHub, + fetchpatch, + catch2, + rang, + fmt, + yaml-cpp, + cmake, + eigen, + lua, + luaPackages, + liblapack, + blas, + lib, + boost, + gsl, +}: clangStdenv.mkDerivation rec { version = "1.0.1"; @@ -19,12 +35,25 @@ clangStdenv.mkDerivation rec { hash = "sha256-PLbT1lqdw+69lIHH96MPcGRjfIeZyb88vc875QLYyqw="; }) ]; - nativeBuildInputs = [ cmake lua luaPackages.luafilesystem ]; - buildInputs = [ fmt rang yaml-cpp eigen catch2 boost gsl liblapack blas ]; + nativeBuildInputs = [ + cmake + lua + luaPackages.luafilesystem + ]; + buildInputs = [ + fmt + rang + yaml-cpp + eigen + catch2 + boost + gsl + liblapack + blas + ]; meta = with lib; { - description = - "d-SEAMS: Deferred Structural Elucidation Analysis for Molecular Simulations"; + description = "d-SEAMS: Deferred Structural Elucidation Analysis for Molecular Simulations"; mainProgram = "yodaStruct"; longDescription = '' d-SEAMS, is a free and open-source postprocessing engine for the analysis diff --git a/pkgs/by-name/d-/d-spy/package.nix b/pkgs/by-name/d-/d-spy/package.nix index 7ed2a9890f96a7..860e9cea1574f8 100644 --- a/pkgs/by-name/d-/d-spy/package.nix +++ b/pkgs/by-name/d-/d-spy/package.nix @@ -1,23 +1,28 @@ -{ stdenv -, lib -, desktop-file-utils -, fetchurl -, glib -, gettext -, gtk4 -, libadwaita -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, gnome +{ + stdenv, + lib, + desktop-file-utils, + fetchurl, + glib, + gettext, + gtk4, + libadwaita, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + gnome, }: stdenv.mkDerivation rec { pname = "d-spy"; version = "47.0"; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/d-spy/${lib.versions.major version}/d-spy-${version}.tar.xz"; diff --git a/pkgs/by-name/d2/d2/package.nix b/pkgs/by-name/d2/d2/package.nix index dcfac802de436a..fc41c44b0ea477 100644 --- a/pkgs/by-name/d2/d2/package.nix +++ b/pkgs/by-name/d2/d2/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGo123Module -, fetchFromGitHub -, installShellFiles -, git -, testers -, d2 +{ + lib, + buildGo123Module, + fetchFromGitHub, + installShellFiles, + git, + testers, + d2, }: buildGo123Module rec { @@ -52,6 +53,9 @@ buildGo123Module rec { homepage = "https://d2lang.com"; changelog = "https://github.com/terrastruct/d2/releases/tag/v${version}"; license = licenses.mpl20; - maintainers = with maintainers; [ dit7ya kashw2 ]; + maintainers = with maintainers; [ + dit7ya + kashw2 + ]; }; } diff --git a/pkgs/by-name/d2/d2coding/package.nix b/pkgs/by-name/d2/d2coding/package.nix index 867345c3a85654..02c5c61b6b3865 100644 --- a/pkgs/by-name/d2/d2coding/package.nix +++ b/pkgs/by-name/d2/d2coding/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "d2codingfont"; diff --git a/pkgs/by-name/da/dab_lib/package.nix b/pkgs/by-name/da/dab_lib/package.nix index 82d591abc139b4..fd3cb016e54e32 100644 --- a/pkgs/by-name/da/dab_lib/package.nix +++ b/pkgs/by-name/da/dab_lib/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config -, faad2, fftwFloat, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + faad2, + fftwFloat, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -15,8 +22,15 @@ stdenv.mkDerivation (finalAttrs: { sourceRoot = "${finalAttrs.src.name}/library"; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ faad2 fftwFloat zlib ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + faad2 + fftwFloat + zlib + ]; meta = with lib; { description = "DAB/DAB+ decoding library"; diff --git a/pkgs/by-name/da/dabet/package.nix b/pkgs/by-name/da/dabet/package.nix index acdc66cbad8fe8..617be31860bfc3 100644 --- a/pkgs/by-name/da/dabet/package.nix +++ b/pkgs/by-name/da/dabet/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitea }: +{ + lib, + rustPlatform, + fetchFromGitea, +}: rustPlatform.buildRustPackage rec { pname = "dabet"; @@ -22,4 +26,3 @@ rustPlatform.buildRustPackage rec { mainProgram = "dabet"; }; } - diff --git a/pkgs/by-name/da/dabtools/package.nix b/pkgs/by-name/da/dabtools/package.nix index a288d93b40ab6a..176909ca543106 100644 --- a/pkgs/by-name/da/dabtools/package.nix +++ b/pkgs/by-name/da/dabtools/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config -, libusb1, rtl-sdr, fftw -} : +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libusb1, + rtl-sdr, + fftw, +}: stdenv.mkDerivation { pname = "dabtools"; @@ -13,8 +20,15 @@ stdenv.mkDerivation { sha256 = "18nkdybgg2w6zh56g6xwmg49sifalvraz4rynw8w5d8cqi3dm9sm"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ rtl-sdr fftw libusb1 ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + rtl-sdr + fftw + libusb1 + ]; meta = with lib; { description = "Commandline tools for DAB and DAB+ digital radio broadcasts"; @@ -24,4 +38,3 @@ stdenv.mkDerivation { maintainers = [ maintainers.markuskowa ]; }; } - diff --git a/pkgs/by-name/da/dadadodo/package.nix b/pkgs/by-name/da/dadadodo/package.nix index dc1a18ae23f2a7..e922158b90b1c8 100644 --- a/pkgs/by-name/da/dadadodo/package.nix +++ b/pkgs/by-name/da/dadadodo/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "dadadodo"; diff --git a/pkgs/by-name/da/daemon/package.nix b/pkgs/by-name/da/daemon/package.nix index 0a7b579347176a..3a323e12f27729 100644 --- a/pkgs/by-name/da/daemon/package.nix +++ b/pkgs/by-name/da/daemon/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "daemon"; diff --git a/pkgs/by-name/da/daemonize/package.nix b/pkgs/by-name/da/daemonize/package.nix index 3a1340e606d0a6..6d8339f3900074 100644 --- a/pkgs/by-name/da/daemonize/package.nix +++ b/pkgs/by-name/da/daemonize/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "daemonize"; diff --git a/pkgs/by-name/da/daemontools/package.nix b/pkgs/by-name/da/daemontools/package.nix index 491a03bb81e2b5..7832af18ade691 100644 --- a/pkgs/by-name/da/daemontools/package.nix +++ b/pkgs/by-name/da/daemontools/package.nix @@ -1,4 +1,11 @@ -{ fetchurl, bash, glibc, lib, stdenv, installShellFiles }: +{ + fetchurl, + bash, + glibc, + lib, + stdenv, + installShellFiles, +}: let man-pages = fetchurl { @@ -17,7 +24,10 @@ stdenv.mkDerivation rec { patches = [ ./fix-nix-usernamespace-build.patch ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; nativeBuildInputs = [ installShellFiles ]; diff --git a/pkgs/by-name/da/daktilo/package.nix b/pkgs/by-name/da/daktilo/package.nix index 3d9b4161e2991f..7a9d8a0243bf84 100644 --- a/pkgs/by-name/da/daktilo/package.nix +++ b/pkgs/by-name/da/daktilo/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv -, darwin -, unixtools -, pkg-config -, alsa-lib -, xorg +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + darwin, + unixtools, + pkg-config, + alsa-lib, + xorg, }: rustPlatform.buildRustPackage rec { @@ -28,14 +29,16 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - alsa-lib - xorg.libX11 - xorg.libXi - xorg.libXtst - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + alsa-lib + xorg.libX11 + xorg.libXi + xorg.libXtst + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; nativeCheckInputs = [ unixtools.script @@ -59,7 +62,10 @@ rustPlatform.buildRustPackage rec { description = "Turn your keyboard into a typewriter"; homepage = "https://github.com/orhun/daktilo"; changelog = "https://github.com/orhun/daktilo/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ orhun ]; mainProgram = "daktilo"; }; diff --git a/pkgs/by-name/da/dale/package.nix b/pkgs/by-name/da/dale/package.nix index 816e8e08f4a71b..350a54f650cc90 100644 --- a/pkgs/by-name/da/dale/package.nix +++ b/pkgs/by-name/da/dale/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, libffi -, llvm_13 -, perl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libffi, + llvm_13, + perl, }: stdenv.mkDerivation { @@ -18,8 +20,15 @@ stdenv.mkDerivation { sha256 = "sha256-LNWqrFuEjtL7zuPTBfe4qQWr8IrT/ldQWSeDTK3Wqmo="; }; - nativeBuildInputs = [ cmake pkg-config llvm_13.dev ]; - buildInputs = [ libffi llvm_13 ]; + nativeBuildInputs = [ + cmake + pkg-config + llvm_13.dev + ]; + buildInputs = [ + libffi + llvm_13 + ]; nativeCheckInputs = [ perl ]; @@ -34,7 +43,11 @@ stdenv.mkDerivation { homepage = "https://github.com/tomhrr/dale"; license = licenses.bsd3; maintainers = with maintainers; [ amiloradovsky ]; - platforms = [ "i686-linux" "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + "aarch64-linux" + ]; # failed on Darwin: linker couldn't find the FFI lib }; } diff --git a/pkgs/by-name/da/dalfox/package.nix b/pkgs/by-name/da/dalfox/package.nix index b12b23a29b1de7..5c0a9d1d4bd0ae 100644 --- a/pkgs/by-name/da/dalfox/package.nix +++ b/pkgs/by-name/da/dalfox/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/da/damon/package.nix b/pkgs/by-name/da/damon/package.nix index f64926d16b7be2..81f227a3c8fbd4 100644 --- a/pkgs/by-name/da/damon/package.nix +++ b/pkgs/by-name/da/damon/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "damon"; diff --git a/pkgs/by-name/da/dancing-script/package.nix b/pkgs/by-name/da/dancing-script/package.nix index 7960691959907c..118c07d448167a 100644 --- a/pkgs/by-name/da/dancing-script/package.nix +++ b/pkgs/by-name/da/dancing-script/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "dancing-script"; diff --git a/pkgs/by-name/da/dante/package.nix b/pkgs/by-name/da/dante/package.nix index 9b99f51aef5989..d772741b093fea 100644 --- a/pkgs/by-name/da/dante/package.nix +++ b/pkgs/by-name/da/dante/package.nix @@ -1,8 +1,19 @@ -{ lib, stdenv, fetchurl, fetchpatch, autoreconfHook -, pam, libkrb5, cyrus_sasl, miniupnpc, libxcrypt }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + pam, + libkrb5, + cyrus_sasl, + miniupnpc, + libxcrypt, +}: let - remove_getaddrinfo_checks = stdenv.hostPlatform.isMips64 || !(stdenv.buildPlatform.canExecute stdenv.hostPlatform); + remove_getaddrinfo_checks = + stdenv.hostPlatform.isMips64 || !(stdenv.buildPlatform.canExecute stdenv.hostPlatform); in stdenv.mkDerivation rec { pname = "dante"; @@ -14,27 +25,37 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ pam libkrb5 cyrus_sasl miniupnpc libxcrypt ]; + buildInputs = [ + pam + libkrb5 + cyrus_sasl + miniupnpc + libxcrypt + ]; - configureFlags = if !stdenv.hostPlatform.isDarwin - then [ "--with-libc=libc.so.6" ] - else [ "--with-libc=libc${stdenv.hostPlatform.extensions.sharedLibrary}" ]; + configureFlags = + if !stdenv.hostPlatform.isDarwin then + [ "--with-libc=libc.so.6" ] + else + [ "--with-libc=libc${stdenv.hostPlatform.extensions.sharedLibrary}" ]; dontAddDisableDepTrack = stdenv.hostPlatform.isDarwin; - patches = [ - # Fixes several issues with `osint.m4` that causes incorrect check failures when using newer - # versions of clang: missing `stdint.h` for `uint8_t` and unused `sa_len_ptr`. - ./clang-osint-m4.patch - # Fixes build with miniupnpc 2.2.8. - ./dante-1.4.3-miniupnpc-2.2.8.patch - ] ++ lib.optionals remove_getaddrinfo_checks [ - (fetchpatch { - name = "0002-osdep-m4-Remove-getaddrinfo-too-low-checks.patch"; - url = "https://raw.githubusercontent.com/buildroot/buildroot/master/package/dante/0002-osdep-m4-Remove-getaddrinfo-too-low-checks.patch"; - sha256 = "sha256-e+qF8lB5tkiA7RlJ+tX5O6KxQrQp33RSPdP1TxU961Y="; - }) - ]; + patches = + [ + # Fixes several issues with `osint.m4` that causes incorrect check failures when using newer + # versions of clang: missing `stdint.h` for `uint8_t` and unused `sa_len_ptr`. + ./clang-osint-m4.patch + # Fixes build with miniupnpc 2.2.8. + ./dante-1.4.3-miniupnpc-2.2.8.patch + ] + ++ lib.optionals remove_getaddrinfo_checks [ + (fetchpatch { + name = "0002-osdep-m4-Remove-getaddrinfo-too-low-checks.patch"; + url = "https://raw.githubusercontent.com/buildroot/buildroot/master/package/dante/0002-osdep-m4-Remove-getaddrinfo-too-low-checks.patch"; + sha256 = "sha256-e+qF8lB5tkiA7RlJ+tX5O6KxQrQp33RSPdP1TxU961Y="; + }) + ]; postPatch = '' substituteInPlace include/redefgen.sh --replace 'PATH=/bin:/usr/bin:/sbin:/usr/sbin' "" @@ -42,9 +63,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Circuit-level SOCKS client/server that can be used to provide convenient and secure network connectivity"; - homepage = "https://www.inet.no/dante/"; + homepage = "https://www.inet.no/dante/"; maintainers = [ maintainers.arobyn ]; - license = licenses.bsdOriginal; - platforms = platforms.linux ++ platforms.darwin; + license = licenses.bsdOriginal; + platforms = platforms.linux ++ platforms.darwin; }; } diff --git a/pkgs/by-name/da/dap/package.nix b/pkgs/by-name/da/dap/package.nix index 40ce12f66ebd0e..84608185922809 100644 --- a/pkgs/by-name/da/dap/package.nix +++ b/pkgs/by-name/da/dap/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/da/dapper/package.nix b/pkgs/by-name/da/dapper/package.nix index 5e141bfee8525b..f367aae65d9f83 100644 --- a/pkgs/by-name/da/dapper/package.nix +++ b/pkgs/by-name/da/dapper/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/da/dapr-cli/package.nix b/pkgs/by-name/da/dapr-cli/package.nix index ffdf5b50769eff..eed817b61e7693 100644 --- a/pkgs/by-name/da/dapr-cli/package.nix +++ b/pkgs/by-name/da/dapr-cli/package.nix @@ -1,4 +1,9 @@ -{ buildGoModule, fetchFromGitHub, installShellFiles, lib }: +{ + buildGoModule, + fetchFromGitHub, + installShellFiles, + lib, +}: buildGoModule rec { pname = "dapr-cli"; @@ -42,7 +47,10 @@ buildGoModule rec { description = "CLI for managing Dapr, the distributed application runtime"; homepage = "https://dapr.io"; license = licenses.asl20; - maintainers = with maintainers; [ joshvanl lucperkins ]; + maintainers = with maintainers; [ + joshvanl + lucperkins + ]; mainProgram = "dapr"; }; } diff --git a/pkgs/by-name/da/daq/package.nix b/pkgs/by-name/da/daq/package.nix index a8d2f52052dc77..40401df9ba88fa 100644 --- a/pkgs/by-name/da/daq/package.nix +++ b/pkgs/by-name/da/daq/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, flex, bison, libpcap, libdnet, libnfnetlink, libnetfilter_queue}: +{ + lib, + stdenv, + fetchurl, + flex, + bison, + libpcap, + libdnet, + libnfnetlink, + libnetfilter_queue, +}: stdenv.mkDerivation rec { pname = "daq"; @@ -10,7 +20,14 @@ stdenv.mkDerivation rec { sha256 = "0yvzscy7vqj7s5rccza0f7p6awghfm3yaxihx1h57lqspg51in3w"; }; - buildInputs = [ flex bison libpcap libdnet libnfnetlink libnetfilter_queue]; + buildInputs = [ + flex + bison + libpcap + libdnet + libnfnetlink + libnetfilter_queue + ]; configureFlags = [ "--enable-nfq-module=yes" diff --git a/pkgs/by-name/da/darcnes/package.nix b/pkgs/by-name/da/darcnes/package.nix index 7919e0a9009c3a..7a68ff5bf713ee 100644 --- a/pkgs/by-name/da/darcnes/package.nix +++ b/pkgs/by-name/da/darcnes/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, libX11, libXt, libXext, libXaw }: +{ + lib, + stdenv, + fetchurl, + libX11, + libXt, + libXext, + libXaw, +}: stdenv.mkDerivation rec { pname = "darcnes"; @@ -11,7 +19,12 @@ stdenv.mkDerivation rec { patches = [ ./label.patch ]; - buildInputs = [ libX11 libXt libXext libXaw ]; + buildInputs = [ + libX11 + libXt + libXext + libXaw + ]; installPhase = "install -Dt $out/bin darcnes"; meta = { diff --git a/pkgs/by-name/da/dark-mode-notify/package.nix b/pkgs/by-name/da/dark-mode-notify/package.nix index 51ecb1d38397ac..e749b0769c7ff2 100644 --- a/pkgs/by-name/da/dark-mode-notify/package.nix +++ b/pkgs/by-name/da/dark-mode-notify/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, stdenv -, swift -, swiftpm -, swiftPackages -, darwin +{ + lib, + fetchFromGitHub, + stdenv, + swift, + swiftpm, + swiftPackages, + darwin, }: # Use the same stdenv, including clang, as Swift itself diff --git a/pkgs/by-name/da/darkhttpd/package.nix b/pkgs/by-name/da/darkhttpd/package.nix index 0d55b3b6b58868..de0610557de43f 100644 --- a/pkgs/by-name/da/darkhttpd/package.nix +++ b/pkgs/by-name/da/darkhttpd/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/da/darkice/package.nix b/pkgs/by-name/da/darkice/package.nix index c1b7eab31f9a99..7701433b367a53 100644 --- a/pkgs/by-name/da/darkice/package.nix +++ b/pkgs/by-name/da/darkice/package.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, fetchurl, pkg-config -, libjack2, alsa-lib, libpulseaudio -, faac, lame, libogg, libopus, libvorbis, libsamplerate +{ + lib, + stdenv, + fetchurl, + pkg-config, + libjack2, + alsa-lib, + libpulseaudio, + faac, + lame, + libogg, + libopus, + libvorbis, + libsamplerate, }: stdenv.mkDerivation rec { @@ -14,7 +25,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - libopus libvorbis libogg libpulseaudio alsa-lib libsamplerate libjack2 lame + libopus + libvorbis + libogg + libpulseaudio + alsa-lib + libsamplerate + libjack2 + lame ]; env.NIX_CFLAGS_COMPILE = "-fpermissive"; diff --git a/pkgs/by-name/da/darkman/package.nix b/pkgs/by-name/da/darkman/package.nix index 66b67be5b60757..34c4748a374311 100644 --- a/pkgs/by-name/da/darkman/package.nix +++ b/pkgs/by-name/da/darkman/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitLab -, buildGoModule -, scdoc -, nix-update-script +{ + lib, + fetchFromGitLab, + buildGoModule, + scdoc, + nix-update-script, }: buildGoModule rec { diff --git a/pkgs/by-name/da/darkplaces/package.nix b/pkgs/by-name/da/darkplaces/package.nix index 6ea4ae241d5a9f..dd0bf83fceb70e 100644 --- a/pkgs/by-name/da/darkplaces/package.nix +++ b/pkgs/by-name/da/darkplaces/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, zlib -, libjpeg -, SDL2 -, libvorbis +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + libjpeg, + SDL2, + libvorbis, }: stdenv.mkDerivation rec { pname = "darkplaces"; diff --git a/pkgs/by-name/da/darkstat/package.nix b/pkgs/by-name/da/darkstat/package.nix index 0dc03b0c0db617..1266f308c531b4 100644 --- a/pkgs/by-name/da/darkstat/package.nix +++ b/pkgs/by-name/da/darkstat/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, fetchpatch -, libpcap -, zlib +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + fetchpatch, + libpcap, + zlib, }: stdenv.mkDerivation rec { @@ -22,8 +23,8 @@ stdenv.mkDerivation rec { # Avoid multiple definitions of CLOCK_REALTIME on macOS 11, # see https://github.com/emikulic/darkstat/pull/2 (fetchpatch { - url = "https://github.com/emikulic/darkstat/commit/d2fd232e1167dee6e7a2d88b9ab7acf2a129f697.diff"; - sha256 = "0z5mpyc0q65qb6cn4xcrxl0vx21d8ibzaam5kjyrcw4icd8yg4jb"; + url = "https://github.com/emikulic/darkstat/commit/d2fd232e1167dee6e7a2d88b9ab7acf2a129f697.diff"; + sha256 = "0z5mpyc0q65qb6cn4xcrxl0vx21d8ibzaam5kjyrcw4icd8yg4jb"; }) ]; diff --git a/pkgs/by-name/da/darktable/package.nix b/pkgs/by-name/da/darktable/package.nix index ee1a83dd1da9ae..040411accf8317 100644 --- a/pkgs/by-name/da/darktable/package.nix +++ b/pkgs/by-name/da/darktable/package.nix @@ -1,58 +1,59 @@ -{ lib -, stdenv -, fetchurl -, libsoup_2_4 -, graphicsmagick -, json-glib -, wrapGAppsHook3 -, cairo -, cmake -, ninja -, curl -, perl -, desktop-file-utils -, exiv2 -, glib -, glib-networking -, ilmbase -, gtk3 -, intltool -, lcms2 -, lensfun -, libX11 -, libexif -, libgphoto2 -, libjpeg -, libpng -, librsvg -, libtiff -, libjxl -, openexr_3 -, osm-gps-map -, pkg-config -, sqlite -, libxslt -, openjpeg -, pugixml -, colord -, colord-gtk -, libwebp -, libsecret -, adwaita-icon-theme -, SDL2 -, ocl-icd -, pcre -, gtk-mac-integration -, isocodes -, llvmPackages -, gmic -, libavif -, icu -, jasper -, libheif -, libaom -, portmidi -, lua +{ + lib, + stdenv, + fetchurl, + libsoup_2_4, + graphicsmagick, + json-glib, + wrapGAppsHook3, + cairo, + cmake, + ninja, + curl, + perl, + desktop-file-utils, + exiv2, + glib, + glib-networking, + ilmbase, + gtk3, + intltool, + lcms2, + lensfun, + libX11, + libexif, + libgphoto2, + libjpeg, + libpng, + librsvg, + libtiff, + libjxl, + openexr_3, + osm-gps-map, + pkg-config, + sqlite, + libxslt, + openjpeg, + pugixml, + colord, + colord-gtk, + libwebp, + libsecret, + adwaita-icon-theme, + SDL2, + ocl-icd, + pcre, + gtk-mac-integration, + isocodes, + llvmPackages, + gmic, + libavif, + icu, + jasper, + libheif, + libaom, + portmidi, + lua, }: stdenv.mkDerivation rec { @@ -64,62 +65,76 @@ stdenv.mkDerivation rec { hash = "sha256-kBsOLK7Tb7hhn99MYO37jTETS5R9MFS1xm/VXDivWZE="; }; - nativeBuildInputs = [ cmake ninja llvmPackages.llvm pkg-config intltool perl desktop-file-utils wrapGAppsHook3 ]; + nativeBuildInputs = [ + cmake + ninja + llvmPackages.llvm + pkg-config + intltool + perl + desktop-file-utils + wrapGAppsHook3 + ]; - buildInputs = [ - cairo - curl - exiv2 - glib - glib-networking - gtk3 - ilmbase - lcms2 - lensfun - libexif - libgphoto2 - libjpeg - libpng - librsvg - libtiff - libjxl - openexr_3 - sqlite - libxslt - libsoup_2_4 - graphicsmagick - json-glib - openjpeg - pugixml - libwebp - libsecret - SDL2 - adwaita-icon-theme - osm-gps-map - pcre - isocodes - gmic - libavif - icu - jasper - libheif - libaom - portmidi - lua - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - colord - colord-gtk - libX11 - ocl-icd - ] ++ lib.optional stdenv.hostPlatform.isDarwin gtk-mac-integration - ++ lib.optional stdenv.cc.isClang llvmPackages.openmp; + buildInputs = + [ + cairo + curl + exiv2 + glib + glib-networking + gtk3 + ilmbase + lcms2 + lensfun + libexif + libgphoto2 + libjpeg + libpng + librsvg + libtiff + libjxl + openexr_3 + sqlite + libxslt + libsoup_2_4 + graphicsmagick + json-glib + openjpeg + pugixml + libwebp + libsecret + SDL2 + adwaita-icon-theme + osm-gps-map + pcre + isocodes + gmic + libavif + icu + jasper + libheif + libaom + portmidi + lua + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + colord + colord-gtk + libX11 + ocl-icd + ] + ++ lib.optional stdenv.hostPlatform.isDarwin gtk-mac-integration + ++ lib.optional stdenv.cc.isClang llvmPackages.openmp; - cmakeFlags = [ - "-DBUILD_USERMANUAL=False" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DUSE_COLORD=OFF" - "-DUSE_KWALLET=OFF" - ]; + cmakeFlags = + [ + "-DBUILD_USERMANUAL=False" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DUSE_COLORD=OFF" + "-DUSE_KWALLET=OFF" + ]; # darktable changed its rpath handling in commit # 83c70b876af6484506901e6b381304ae0d073d3c and as a result the @@ -128,7 +143,8 @@ stdenv.mkDerivation rec { preFixup = let libPathEnvVar = if stdenv.hostPlatform.isDarwin then "DYLD_LIBRARY_PATH" else "LD_LIBRARY_PATH"; - libPathPrefix = "$out/lib/darktable" + lib.optionalString stdenv.hostPlatform.isLinux ":${ocl-icd}/lib"; + libPathPrefix = + "$out/lib/darktable" + lib.optionalString stdenv.hostPlatform.isLinux ":${ocl-icd}/lib"; in '' for f in $out/share/darktable/kernels/*.cl; do @@ -145,6 +161,11 @@ stdenv.mkDerivation rec { homepage = "https://www.darktable.org"; license = licenses.gpl3Plus; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ flosse mrVanDalo paperdigits freyacodes ]; + maintainers = with maintainers; [ + flosse + mrVanDalo + paperdigits + freyacodes + ]; }; } diff --git a/pkgs/by-name/da/darktile/package.nix b/pkgs/by-name/da/darktile/package.nix index 9bd7e16d74b78f..c2e7928fbdad31 100644 --- a/pkgs/by-name/da/darktile/package.nix +++ b/pkgs/by-name/da/darktile/package.nix @@ -1,16 +1,17 @@ -{ fetchFromGitHub -, lib -, pkg-config -, libX11 -, libXcursor -, libXrandr -, libXinerama -, libXi -, libXext -, libXxf86vm -, libGL -, nixosTests -, buildGoModule +{ + fetchFromGitHub, + lib, + pkg-config, + libX11, + libXcursor, + libXrandr, + libXinerama, + libXi, + libXext, + libXxf86vm, + libGL, + nixosTests, + buildGoModule, }: buildGoModule rec { diff --git a/pkgs/by-name/da/darling-dmg/package.nix b/pkgs/by-name/da/darling-dmg/package.nix index 3053982a647659..9f4f436275c6e6 100644 --- a/pkgs/by-name/da/darling-dmg/package.nix +++ b/pkgs/by-name/da/darling-dmg/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, cmake, fuse, zlib, bzip2, openssl, libxml2, icu, lzfse, libiconv -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fuse, + zlib, + bzip2, + openssl, + libxml2, + icu, + lzfse, + libiconv, + nixosTests, }: stdenv.mkDerivation { @@ -14,8 +26,15 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ fuse openssl zlib bzip2 libxml2 icu lzfse ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; + buildInputs = [ + fuse + openssl + zlib + bzip2 + libxml2 + icu + lzfse + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; CXXFLAGS = [ "-DCOMPILE_WITH_LZFSE=1" diff --git a/pkgs/by-name/da/darling/package.nix b/pkgs/by-name/da/darling/package.nix index 581dd0cacea993..2a161397bca25e 100644 --- a/pkgs/by-name/da/darling/package.nix +++ b/pkgs/by-name/da/darling/package.nix @@ -1,83 +1,87 @@ -{ clangStdenv -, lib -, runCommandWith -, writeShellScript -, fetchFromGitHub -, fetchpatch -, nixosTests - -, freetype -, libjpeg -, libpng -, libtiff -, giflib -, libX11 -, libXext -, libXrandr -, libXcursor -, libxkbfile -, cairo -, libglvnd -, fontconfig -, dbus -, libGLU -, fuse -, ffmpeg -, pulseaudio - -, makeWrapper -, python2 -, python3 -, cmake -, ninja -, pkg-config -, bison -, flex - -, libbsd -, openssl - -, xdg-user-dirs - -, addDriverRunpath - -# Whether to pre-compile Python 2 bytecode for performance. -, compilePy2Bytecode ? false +{ + clangStdenv, + lib, + runCommandWith, + writeShellScript, + fetchFromGitHub, + fetchpatch, + nixosTests, + + freetype, + libjpeg, + libpng, + libtiff, + giflib, + libX11, + libXext, + libXrandr, + libXcursor, + libxkbfile, + cairo, + libglvnd, + fontconfig, + dbus, + libGLU, + fuse, + ffmpeg, + pulseaudio, + + makeWrapper, + python2, + python3, + cmake, + ninja, + pkg-config, + bison, + flex, + + libbsd, + openssl, + + xdg-user-dirs, + + addDriverRunpath, + + # Whether to pre-compile Python 2 bytecode for performance. + compilePy2Bytecode ? false, }: let stdenv = clangStdenv; # The build system invokes clang to compile Darwin executables. # In this case, our cc-wrapper must not be used. - ccWrapperBypass = runCommandWith { - inherit stdenv; - name = "cc-wrapper-bypass"; - runLocal = false; - derivationArgs = { - template = writeShellScript "template" '' - for (( i=1; i<=$#; i++)); do - j=$((i+1)) - if [[ "''${!i}" == "-target" && "''${!j}" == *"darwin"* ]]; then - # their flags must take precedence - exec @unwrapped@ "$@" $NIX_CFLAGS_COMPILE - fi - done - exec @wrapped@ "$@" + ccWrapperBypass = + runCommandWith + { + inherit stdenv; + name = "cc-wrapper-bypass"; + runLocal = false; + derivationArgs = { + template = writeShellScript "template" '' + for (( i=1; i<=$#; i++)); do + j=$((i+1)) + if [[ "''${!i}" == "-target" && "''${!j}" == *"darwin"* ]]; then + # their flags must take precedence + exec @unwrapped@ "$@" $NIX_CFLAGS_COMPILE + fi + done + exec @wrapped@ "$@" + ''; + }; + } + '' + unwrapped_bin=${stdenv.cc.cc}/bin + wrapped_bin=${stdenv.cc}/bin + + mkdir -p $out/bin + + unwrapped=$unwrapped_bin/$CC wrapped=$wrapped_bin/$CC \ + substituteAll $template $out/bin/$CC + unwrapped=$unwrapped_bin/$CXX wrapped=$wrapped_bin/$CXX \ + substituteAll $template $out/bin/$CXX + + chmod +x $out/bin/$CC $out/bin/$CXX ''; - }; - } '' - unwrapped_bin=${stdenv.cc.cc}/bin - wrapped_bin=${stdenv.cc}/bin - - mkdir -p $out/bin - - unwrapped=$unwrapped_bin/$CC wrapped=$wrapped_bin/$CC \ - substituteAll $template $out/bin/$CC - unwrapped=$unwrapped_bin/$CXX wrapped=$wrapped_bin/$CXX \ - substituteAll $template $out/bin/$CXX - - chmod +x $out/bin/$CC $out/bin/$CXX - ''; wrappedLibs = [ # To find all of them: rg -w wrap_elf @@ -106,7 +110,8 @@ let ffmpeg pulseaudio ]; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "darling"; version = "unstable-2024-02-03"; @@ -124,7 +129,10 @@ in stdenv.mkDerivation { ''; }; - outputs = [ "out" "sdk" ]; + outputs = [ + "out" + "sdk" + ]; patches = [ # Fix 'clang: error: no such file or directory: .../signal/mach_excUser.c' @@ -166,8 +174,7 @@ in stdenv.mkDerivation { ninja pkg-config python3 - ] - ++ lib.optional compilePy2Bytecode python2; + ] ++ lib.optional compilePy2Bytecode python2; buildInputs = wrappedLibs ++ [ libbsd openssl diff --git a/pkgs/by-name/da/das_watchdog/package.nix b/pkgs/by-name/da/das_watchdog/package.nix index 141e16181cec63..31a33eee2bde5b 100644 --- a/pkgs/by-name/da/das_watchdog/package.nix +++ b/pkgs/by-name/da/das_watchdog/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libgtop, xmessage, which, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + libgtop, + xmessage, + which, + pkg-config, +}: stdenv.mkDerivation { pname = "das_watchdog"; @@ -12,7 +20,11 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libgtop xmessage which ]; + buildInputs = [ + libgtop + xmessage + which + ]; installPhase = '' mkdir -p $out/bin/ diff --git a/pkgs/by-name/da/dasel/package.nix b/pkgs/by-name/da/dasel/package.nix index f135a39a41e629..efdc7eaa41e960 100644 --- a/pkgs/by-name/da/dasel/package.nix +++ b/pkgs/by-name/da/dasel/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -19,7 +20,9 @@ buildGoModule rec { vendorHash = "sha256-edyFs5oURklkqsTF7JA1in3XteSBx/6YEVu4MjIcGN4="; ldflags = [ - "-s" "-w" "-X github.com/tomwright/dasel/v2/internal.Version=${version}" + "-s" + "-w" + "-X github.com/tomwright/dasel/v2/internal.Version=${version}" ]; nativeBuildInputs = [ installShellFiles ]; diff --git a/pkgs/by-name/da/dash/package.nix b/pkgs/by-name/da/dash/package.nix index 17de97660344cf..6fe83258a58a81 100644 --- a/pkgs/by-name/da/dash/package.nix +++ b/pkgs/by-name/da/dash/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, buildPackages -, pkg-config -, fetchurl -, libedit -, runCommand -, dash +{ + lib, + stdenv, + buildPackages, + pkg-config, + fetchurl, + libedit, + runCommand, + dash, }: stdenv.mkDerivation (finalAttrs: { @@ -47,7 +48,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "http://gondor.apana.org.au/~herbert/dash/"; description = "POSIX-compliant implementation of /bin/sh that aims to be as small as possible"; platforms = platforms.unix; - license = with licenses; [ bsd3 gpl2Plus ]; + license = with licenses; [ + bsd3 + gpl2Plus + ]; mainProgram = "dash"; }; }) diff --git a/pkgs/by-name/da/dasher/package.nix b/pkgs/by-name/da/dasher/package.nix index 13dee55628a5cd..dadc218e6fd124 100644 --- a/pkgs/by-name/da/dasher/package.nix +++ b/pkgs/by-name/da/dasher/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitLab -, autoreconfHook -, pkg-config -, wrapGAppsHook3 -, glib -, gtk3 -, expat -, itstool -, gnome-doc-utils -, which -, at-spi2-core -, dbus -, libxslt -, libxml2 -, speechSupport ? true -, speechd-minimal +{ + stdenv, + lib, + fetchFromGitLab, + autoreconfHook, + pkg-config, + wrapGAppsHook3, + glib, + gtk3, + expat, + itstool, + gnome-doc-utils, + which, + at-spi2-core, + dbus, + libxslt, + libxml2, + speechSupport ? true, + speechd-minimal, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/da/dashing/package.nix b/pkgs/by-name/da/dashing/package.nix index 600dc5dd850e1b..58fb7f68b1ba76 100644 --- a/pkgs/by-name/da/dashing/package.nix +++ b/pkgs/by-name/da/dashing/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, dashing }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + dashing, +}: buildGoModule rec { pname = "dashing"; @@ -13,7 +19,11 @@ buildGoModule rec { vendorHash = "sha256-XeUFmzf6y0S82gMOzkj4AUNFkVvkVOwauYpqY4jeWLM="; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; passthru.tests.version = testers.testVersion { package = dashing; diff --git a/pkgs/by-name/da/dasht/package.nix b/pkgs/by-name/da/dasht/package.nix index 4ab9cfdd0e0fe9..b2da7e8af22cef 100644 --- a/pkgs/by-name/da/dasht/package.nix +++ b/pkgs/by-name/da/dasht/package.nix @@ -1,26 +1,27 @@ -{ stdenv -, lib -, fetchFromGitHub -, makeWrapper -, installShellFiles -, coreutils -, gnused -, gnugrep -, sqlite -, wget -, w3m -, socat -, gawk +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + installShellFiles, + coreutils, + gnused, + gnugrep, + sqlite, + wget, + w3m, + socat, + gawk, }: stdenv.mkDerivation rec { - pname = "dasht"; + pname = "dasht"; version = "2.4.0"; src = fetchFromGitHub { - owner = "sunaku"; - repo = pname; - rev = "v${version}"; + owner = "sunaku"; + repo = pname; + rev = "v${version}"; sha256 = "08wssmifxi7pnvn9gqrvpzpkc2qpkfbzbhxh0dk1gff2y2211qqk"; }; @@ -36,7 +37,10 @@ stdenv.mkDerivation rec { (placeholder "out") ]; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; installPhase = '' runHook preInstall @@ -57,9 +61,9 @@ stdenv.mkDerivation rec { meta = { description = "Search API docs offline, in terminal or browser"; - homepage = "https://sunaku.github.io/dasht/man"; - license = lib.licenses.isc; - platforms = lib.platforms.unix; #cannot test other + homepage = "https://sunaku.github.io/dasht/man"; + license = lib.licenses.isc; + platforms = lib.platforms.unix; # cannot test other maintainers = with lib.maintainers; [ matthiasbeyer ]; }; } diff --git a/pkgs/by-name/da/dasm/package.nix b/pkgs/by-name/da/dasm/package.nix index 7f57f47f2ed6a3..578d49a7639fc7 100644 --- a/pkgs/by-name/da/dasm/package.nix +++ b/pkgs/by-name/da/dasm/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "dasm"; diff --git a/pkgs/by-name/da/dataexplorer/package.nix b/pkgs/by-name/da/dataexplorer/package.nix index 09406b6b3bebe1..10e77127efca7f 100644 --- a/pkgs/by-name/da/dataexplorer/package.nix +++ b/pkgs/by-name/da/dataexplorer/package.nix @@ -1,15 +1,18 @@ -{ lib -, stdenv -, fetchurl -, ant -# executable fails to start for jdk > 17 -, jdk17 -, swt -, makeWrapper -, strip-nondeterminism -}: let +{ + lib, + stdenv, + fetchurl, + ant, + # executable fails to start for jdk > 17 + jdk17, + swt, + makeWrapper, + strip-nondeterminism, +}: +let swt-jdk17 = swt.override { jdk = jdk17; }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "dataexplorer"; version = "3.9.0"; @@ -80,8 +83,8 @@ in stdenv.mkDerivation (finalAttrs: { platforms = [ "x86_64-linux" ]; sourceProvenance = with sourceTypes; [ fromSource - binaryNativeCode # contains RXTXcomm (JNI library with *.so files) - binaryBytecode # contains thirdparty jar files, e.g. javax.json, org.glassfish.json + binaryNativeCode # contains RXTXcomm (JNI library with *.so files) + binaryBytecode # contains thirdparty jar files, e.g. javax.json, org.glassfish.json ]; }; }) diff --git a/pkgs/by-name/da/datamash/package.nix b/pkgs/by-name/da/datamash/package.nix index 7d6318928292a9..abd51be89721df 100644 --- a/pkgs/by-name/da/datamash/package.nix +++ b/pkgs/by-name/da/datamash/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "datamash"; diff --git a/pkgs/by-name/da/datefmt/package.nix b/pkgs/by-name/da/datefmt/package.nix index 1c1efd792a203f..2e794bda64003f 100644 --- a/pkgs/by-name/da/datefmt/package.nix +++ b/pkgs/by-name/da/datefmt/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, testers }: +{ + lib, + stdenv, + fetchurl, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "datefmt"; diff --git a/pkgs/by-name/da/datefudge/package.nix b/pkgs/by-name/da/datefudge/package.nix index a0ba2eafcace42..89b83a0284cee1 100644 --- a/pkgs/by-name/da/datefudge/package.nix +++ b/pkgs/by-name/da/datefudge/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchgit, makeWrapper, coreutils }: +{ + lib, + stdenv, + fetchgit, + makeWrapper, + coreutils, +}: stdenv.mkDerivation rec { pname = "datefudge"; diff --git a/pkgs/by-name/da/dateutils/package.nix b/pkgs/by-name/da/dateutils/package.nix index 45adc23832ab41..8cb31c4ef83af2 100644 --- a/pkgs/by-name/da/dateutils/package.nix +++ b/pkgs/by-name/da/dateutils/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, autoreconfHook, tzdata }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + tzdata, +}: stdenv.mkDerivation rec { version = "0.4.11"; diff --git a/pkgs/by-name/da/datree/package.nix b/pkgs/by-name/da/datree/package.nix index 79e352deb5321b..9d671a0fb734a9 100644 --- a/pkgs/by-name/da/datree/package.nix +++ b/pkgs/by-name/da/datree/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, testers -, datree +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + datree, }: buildGoModule rec { @@ -54,6 +55,9 @@ buildGoModule rec { homepage = "https://datree.io/"; changelog = "https://github.com/datreeio/datree/releases/tag/${version}"; license = licenses.asl20; - maintainers = with maintainers; [ azahi jceb ]; + maintainers = with maintainers; [ + azahi + jceb + ]; }; } diff --git a/pkgs/by-name/da/dav1d/package.nix b/pkgs/by-name/da/dav1d/package.nix index dc7efc22e852f3..a17e26b2981f43 100644 --- a/pkgs/by-name/da/dav1d/package.nix +++ b/pkgs/by-name/da/dav1d/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, nasm -, pkg-config -, xxHash -, withTools ? false # "dav1d" binary -, withExamples ? false -, SDL2 # "dav1dplay" binary -, useVulkan ? false -, libplacebo -, vulkan-loader -, vulkan-headers +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + nasm, + pkg-config, + xxHash, + withTools ? false, # "dav1d" binary + withExamples ? false, + SDL2, # "dav1dplay" binary + useVulkan ? false, + libplacebo, + vulkan-loader, + vulkan-headers, # for passthru.tests -, ffmpeg -, gdal -, handbrake -, libavif -, libheif + ffmpeg, + gdal, + handbrake, + libavif, + libheif, }: assert useVulkan -> withExamples; @@ -35,13 +36,26 @@ stdenv.mkDerivation rec { hash = "sha256-eOMQj88vlgoxguV+eK4iWXFjUPiXwqRTJlhehev+yGY="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ meson ninja nasm pkg-config ]; + nativeBuildInputs = [ + meson + ninja + nasm + pkg-config + ]; # TODO: doxygen (currently only HTML and not build by default). - buildInputs = [ xxHash ] + buildInputs = + [ xxHash ] ++ lib.optional withExamples SDL2 - ++ lib.optionals useVulkan [ libplacebo vulkan-loader vulkan-headers ]; + ++ lib.optionals useVulkan [ + libplacebo + vulkan-loader + vulkan-headers + ]; mesonFlags = [ "-Denable_tools=${lib.boolToString withTools}" @@ -56,7 +70,8 @@ stdenv.mkDerivation rec { gdal handbrake libavif - libheif; + libheif + ; }; meta = with lib; { diff --git a/pkgs/by-name/da/dave/package.nix b/pkgs/by-name/da/dave/package.nix index 8950b0b3d20d7f..265efcc5d908a9 100644 --- a/pkgs/by-name/da/dave/package.nix +++ b/pkgs/by-name/da/dave/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, mage }: +{ + lib, + buildGoModule, + fetchFromGitHub, + mage, +}: buildGoModule rec { pname = "dave"; @@ -21,9 +26,17 @@ buildGoModule rec { ./go-modules.patch ]; - subPackages = [ "cmd/dave" "cmd/davecli" ]; + subPackages = [ + "cmd/dave" + "cmd/davecli" + ]; - ldflags = [ "-s" "-w" "-X main.version=${version}" "-X main.builtBy=nixpkgs" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + "-X main.builtBy=nixpkgs" + ]; meta = with lib; { homepage = "https://github.com/micromata/dave"; diff --git a/pkgs/by-name/da/davtest/package.nix b/pkgs/by-name/da/davtest/package.nix index 226ead57ffdee1..99d2c18ec5803e 100644 --- a/pkgs/by-name/da/davtest/package.nix +++ b/pkgs/by-name/da/davtest/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, perl, fetchurl }: +{ + lib, + stdenv, + perl, + fetchurl, +}: stdenv.mkDerivation rec { pname = "davtest"; diff --git a/pkgs/by-name/da/dawn/package.nix b/pkgs/by-name/da/dawn/package.nix index a32311baca935e..172e40beec6821 100644 --- a/pkgs/by-name/da/dawn/package.nix +++ b/pkgs/by-name/da/dawn/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, tk -, makeWrapper +{ + lib, + stdenv, + fetchurl, + tk, + makeWrapper, }: stdenv.mkDerivation rec { @@ -10,7 +11,9 @@ stdenv.mkDerivation rec { version = "3.91a"; src = fetchurl { - url = "https://geant4.kek.jp/~tanaka/src/dawn_${builtins.replaceStrings ["."] ["_"] version}.tgz"; + url = "https://geant4.kek.jp/~tanaka/src/dawn_${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.tgz"; hash = "sha256-gdhV6tERdoGxiCQt0L46JOAF2b1AY/0r2pp6eU689fQ="; }; diff --git a/pkgs/by-name/da/dawncut/package.nix b/pkgs/by-name/da/dawncut/package.nix index 2c1b9878488108..58da095f898553 100644 --- a/pkgs/by-name/da/dawncut/package.nix +++ b/pkgs/by-name/da/dawncut/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { @@ -9,7 +10,9 @@ stdenv.mkDerivation rec { src = fetchurl { name = "${pname}-${version}.tar.gz"; - url = "https://geant4.kek.jp/~tanaka/src/dawncut_${builtins.replaceStrings ["."] ["_"] version}.taz"; + url = "https://geant4.kek.jp/~tanaka/src/dawncut_${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.taz"; hash = "sha256-Ux4fDi7TXePisYAxCMDvtzLYOgxnbxQIO9QacTRrT6k="; }; diff --git a/pkgs/by-name/da/daytona-bin/package.nix b/pkgs/by-name/da/daytona-bin/package.nix index 0dbebf98949ed6..bf26c54e94eae0 100644 --- a/pkgs/by-name/da/daytona-bin/package.nix +++ b/pkgs/by-name/da/daytona-bin/package.nix @@ -1,7 +1,8 @@ -{ stdenvNoCC -, lib -, fetchurl -, makeWrapper +{ + stdenvNoCC, + lib, + fetchurl, + makeWrapper, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/db/db-rest/package.nix b/pkgs/by-name/db/db-rest/package.nix index c6e3c55eee1d76..c41f73db114ec0 100644 --- a/pkgs/by-name/db/db-rest/package.nix +++ b/pkgs/by-name/db/db-rest/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, nodejs_18 -, nix-update-script -, nixosTests +{ + lib, + buildNpmPackage, + fetchFromGitHub, + nodejs_18, + nix-update-script, + nixosTests, }: buildNpmPackage rec { pname = "db-rest"; diff --git a/pkgs/by-name/db/dbacl/package.nix b/pkgs/by-name/db/dbacl/package.nix index a7069ad92bb3c4..6cc65fb8cae44c 100644 --- a/pkgs/by-name/db/dbacl/package.nix +++ b/pkgs/by-name/db/dbacl/package.nix @@ -1,4 +1,8 @@ -{fetchurl, lib, stdenv}: +{ + fetchurl, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "dbacl"; diff --git a/pkgs/by-name/db/dbcsr/package.nix b/pkgs/by-name/db/dbcsr/package.nix index e758e1c8fcc214..ab5f27ec805d1c 100644 --- a/pkgs/by-name/db/dbcsr/package.nix +++ b/pkgs/by-name/db/dbcsr/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, mpiCheckPhaseHook -, pkg-config -, fypp -, gfortran -, blas -, lapack -, python3 -, libxsmm -, mpi +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + mpiCheckPhaseHook, + pkg-config, + fypp, + gfortran, + blas, + lapack, + python3, + libxsmm, + mpi, }: stdenv.mkDerivation rec { @@ -45,7 +46,11 @@ stdenv.mkDerivation rec { fypp ]; - buildInputs = [ blas lapack libxsmm ]; + buildInputs = [ + blas + lapack + libxsmm + ]; propagatedBuildInputs = [ mpi ]; diff --git a/pkgs/by-name/db/dbd/package.nix b/pkgs/by-name/db/dbd/package.nix index 1df459cb326705..d7c2b69649fc13 100644 --- a/pkgs/by-name/db/dbd/package.nix +++ b/pkgs/by-name/db/dbd/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation { @@ -14,10 +15,13 @@ stdenv.mkDerivation { hash = "sha256-b2yBZ2/Ab+SviKNlyZgdfiZ7GGZ1sonZnblD0i+vuFw="; }; - makeFlags = [ - "PREFIX=${placeholder "out"}" - "CC=${stdenv.cc.targetPrefix}cc" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ "darwin" ] ++ lib.optionals (stdenv.hostPlatform.isUnix && !stdenv.hostPlatform.isDarwin) [ "unix" ]; + makeFlags = + [ + "PREFIX=${placeholder "out"}" + "CC=${stdenv.cc.targetPrefix}cc" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ "darwin" ] + ++ lib.optionals (stdenv.hostPlatform.isUnix && !stdenv.hostPlatform.isDarwin) [ "unix" ]; meta = with lib; { description = "Netcat-clone, designed to be portable and offer strong encryption"; diff --git a/pkgs/by-name/db/dbench/package.nix b/pkgs/by-name/db/dbench/package.nix index 796536b9e2aadd..456d99a66939e0 100644 --- a/pkgs/by-name/db/dbench/package.nix +++ b/pkgs/by-name/db/dbench/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchgit, autoconf, popt, zlib, rpcsvc-proto, libtirpc }: +{ + lib, + stdenv, + fetchgit, + autoconf, + popt, + zlib, + rpcsvc-proto, + libtirpc, +}: stdenv.mkDerivation rec { pname = "dbench"; @@ -10,8 +19,15 @@ stdenv.mkDerivation rec { sha256 = "16lcbwmmx8z5i73k3dnf54yffrpx7ql3y9k3cpkss9dcyxb1p83i"; }; - nativeBuildInputs = [ autoconf rpcsvc-proto ]; - buildInputs = [ popt zlib libtirpc ]; + nativeBuildInputs = [ + autoconf + rpcsvc-proto + ]; + buildInputs = [ + popt + zlib + libtirpc + ]; env.NIX_CFLAGS_COMPILE = toString [ "-I${libtirpc.dev}/include/tirpc" ]; NIX_LDFLAGS = [ "-ltirpc" ]; diff --git a/pkgs/by-name/db/dblatex/package.nix b/pkgs/by-name/db/dblatex/package.nix index 39069029e57c5d..a73f0b92771c0e 100644 --- a/pkgs/by-name/db/dblatex/package.nix +++ b/pkgs/by-name/db/dblatex/package.nix @@ -1,13 +1,53 @@ -{ lib, stdenv, fetchurl, python311, libxslt, texliveBasic -, enableAllFeatures ? false, imagemagick, fig2dev, inkscape, fontconfig, ghostscript +{ + lib, + stdenv, + fetchurl, + python311, + libxslt, + texliveBasic, + enableAllFeatures ? false, + imagemagick, + fig2dev, + inkscape, + fontconfig, + ghostscript, -, tex ? texliveBasic.withPackages (ps: with ps; [ # satisfy all packages that ./configure mentions - epstopdf anysize appendix changebar - fancybox fancyvrb float footmisc listings jknapltx/*for mathrsfs.sty*/ - multirow overpic pdfpages pdflscape graphics stmaryrd subfigure titlesec wasysym - # pkgs below don't seem requested by dblatex, but our manual fails without them - ec zapfding symbol eepic times rsfs cs tex4ht courier helvetic ly1 - ]) + tex ? texliveBasic.withPackages ( + ps: with ps; [ + # satisfy all packages that ./configure mentions + epstopdf + anysize + appendix + changebar + fancybox + fancyvrb + float + footmisc + listings + jknapltx # for mathrsfs.sty + multirow + overpic + pdfpages + pdflscape + graphics + stmaryrd + subfigure + titlesec + wasysym + # pkgs below don't seem requested by dblatex, but our manual fails without them + ec + zapfding + symbol + eepic + times + rsfs + cs + tex4ht + courier + helvetic + ly1 + ] + ), }: # NOTE: enableAllFeatures just purifies the expression, it doesn't actually @@ -22,32 +62,42 @@ stdenv.mkDerivation rec { sha256 = "0yd09nypswy3q4scri1dg7dr99d7gd6r2dwx0xm81l9f4y32gs0n"; }; - buildInputs = [ python311 libxslt tex ] - ++ lib.optionals enableAllFeatures [ imagemagick fig2dev ]; + buildInputs = + [ + python311 + libxslt + tex + ] + ++ lib.optionals enableAllFeatures [ + imagemagick + fig2dev + ]; # TODO: dblatex tries to execute texindy command, but nixpkgs doesn't have # that yet. In Ubuntu, texindy is a part of the xindy package. - preConfigure = '' - sed -i 's|self.install_layout == "deb"|False|' setup.py - '' + lib.optionalString enableAllFeatures '' - for file in $(find -name "*.py"); do - sed -e 's|cmd = \["xsltproc|cmd = \["${libxslt.bin}/bin/xsltproc|g' \ - -e 's|Popen(\["xsltproc|Popen(\["${libxslt.bin}/bin/xsltproc|g' \ - -e 's|cmd = \["texindy|cmd = ["nixpkgs_is_missing_texindy|g' \ - -e 's|cmd = "epstopdf|cmd = "${tex}/bin/epstopdf|g' \ - -e 's|cmd = \["makeindex|cmd = ["${tex}/bin/makeindex|g' \ - -e 's|doc.program = "pdflatex"|doc.program = "${tex}/bin/pdflatex"|g' \ - -e 's|self.program = "latex"|self.program = "${tex}/bin/latex"|g' \ - -e 's|Popen("pdflatex|Popen("${tex}/bin/pdflatex|g' \ - -e 's|"fc-match"|"${fontconfig.bin}/bin/fc-match"|g' \ - -e 's|"fc-list"|"${fontconfig.bin}/bin/fc-list"|g' \ - -e 's|cmd = "inkscape|cmd = "${inkscape}/bin/inkscape|g' \ - -e 's|cmd = "fig2dev|cmd = "${fig2dev}/bin/fig2dev|g' \ - -e 's|cmd = \["ps2pdf|cmd = ["${ghostscript}/bin/ps2pdf|g' \ - -e 's|cmd = "convert|cmd = "${imagemagick.out}/bin/convert|g' \ - -i "$file" - done - ''; + preConfigure = + '' + sed -i 's|self.install_layout == "deb"|False|' setup.py + '' + + lib.optionalString enableAllFeatures '' + for file in $(find -name "*.py"); do + sed -e 's|cmd = \["xsltproc|cmd = \["${libxslt.bin}/bin/xsltproc|g' \ + -e 's|Popen(\["xsltproc|Popen(\["${libxslt.bin}/bin/xsltproc|g' \ + -e 's|cmd = \["texindy|cmd = ["nixpkgs_is_missing_texindy|g' \ + -e 's|cmd = "epstopdf|cmd = "${tex}/bin/epstopdf|g' \ + -e 's|cmd = \["makeindex|cmd = ["${tex}/bin/makeindex|g' \ + -e 's|doc.program = "pdflatex"|doc.program = "${tex}/bin/pdflatex"|g' \ + -e 's|self.program = "latex"|self.program = "${tex}/bin/latex"|g' \ + -e 's|Popen("pdflatex|Popen("${tex}/bin/pdflatex|g' \ + -e 's|"fc-match"|"${fontconfig.bin}/bin/fc-match"|g' \ + -e 's|"fc-list"|"${fontconfig.bin}/bin/fc-list"|g' \ + -e 's|cmd = "inkscape|cmd = "${inkscape}/bin/inkscape|g' \ + -e 's|cmd = "fig2dev|cmd = "${fig2dev}/bin/fig2dev|g' \ + -e 's|cmd = \["ps2pdf|cmd = ["${ghostscript}/bin/ps2pdf|g' \ + -e 's|cmd = "convert|cmd = "${imagemagick.out}/bin/convert|g' \ + -i "$file" + done + ''; dontBuild = true; diff --git a/pkgs/by-name/db/dbmonster/package.nix b/pkgs/by-name/db/dbmonster/package.nix index 13d0cded0a3ecc..164be1d4024809 100644 --- a/pkgs/by-name/db/dbmonster/package.nix +++ b/pkgs/by-name/db/dbmonster/package.nix @@ -1,11 +1,12 @@ -{ lib -, aircrack-ng -, fetchFromGitHub -, iproute2 -, networkmanager -, python3 -, tshark -, wirelesstools +{ + lib, + aircrack-ng, + fetchFromGitHub, + iproute2, + networkmanager, + python3, + tshark, + wirelesstools, }: python3.pkgs.buildPythonApplication rec { @@ -20,15 +21,17 @@ python3.pkgs.buildPythonApplication rec { hash = "sha256-9RP3LmZF7P2c0+Jt/kMSVPb4cBtyH6P3FZ5UrQpBP0I="; }; - propagatedBuildInputs = [ - aircrack-ng - iproute2 - networkmanager - tshark - wirelesstools - ] ++ (with python3.pkgs; [ - matplotlib - ]); + propagatedBuildInputs = + [ + aircrack-ng + iproute2 + networkmanager + tshark + wirelesstools + ] + ++ (with python3.pkgs; [ + matplotlib + ]); dontBuild = true; diff --git a/pkgs/by-name/db/dbqn/package.nix b/pkgs/by-name/db/dbqn/package.nix index 7ec4dea0534292..8352bb2b57ad2a 100644 --- a/pkgs/by-name/db/dbqn/package.nix +++ b/pkgs/by-name/db/dbqn/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, jdk -, makeWrapper -, buildNativeImage ? false +{ + lib, + stdenv, + fetchFromGitHub, + jdk, + makeWrapper, + buildNativeImage ? false, }: stdenv.mkDerivation rec { @@ -28,42 +29,57 @@ stdenv.mkDerivation rec { patchShebangs --build ./build8 ''; - buildPhase = '' - runHook preBuild + buildPhase = + '' + runHook preBuild - ./build8 - '' + lib.optionalString buildNativeImage '' - native-image --report-unsupported-elements-at-runtime \ - -H:CLibraryPath=${lib.getLib jdk}/lib -J-Dfile.encoding=UTF-8 \ - -jar BQN.jar dbqn - '' + '' - runHook postBuild - ''; + ./build8 + '' + + lib.optionalString buildNativeImage '' + native-image --report-unsupported-elements-at-runtime \ + -H:CLibraryPath=${lib.getLib jdk}/lib -J-Dfile.encoding=UTF-8 \ + -jar BQN.jar dbqn + '' + + '' + runHook postBuild + ''; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - mkdir -p $out/bin + mkdir -p $out/bin - '' + (if buildNativeImage then '' - mv dbqn $out/bin - '' else '' - mkdir -p $out/share/dbqn - mv BQN.jar $out/share/dbqn/ + '' + + ( + if buildNativeImage then + '' + mv dbqn $out/bin + '' + else + '' + mkdir -p $out/share/dbqn + mv BQN.jar $out/share/dbqn/ - makeWrapper "${lib.getBin jdk}/bin/java" "$out/bin/dbqn" \ - --add-flags "-jar $out/share/dbqn/BQN.jar" - '') + '' - ln -s $out/bin/dbqn $out/bin/bqn + makeWrapper "${lib.getBin jdk}/bin/java" "$out/bin/dbqn" \ + --add-flags "-jar $out/share/dbqn/BQN.jar" + '' + ) + + '' + ln -s $out/bin/dbqn $out/bin/bqn - runHook postInstall - ''; + runHook postInstall + ''; meta = with lib; { homepage = "https://github.com/dzaima/BQN"; - description = "BQN implementation in Java" + lib.optionalString buildNativeImage ", compiled as a native image"; + description = + "BQN implementation in Java" + lib.optionalString buildNativeImage ", compiled as a native image"; license = licenses.mit; - maintainers = with maintainers; [ AndersonTorres sternenseemann ]; + maintainers = with maintainers; [ + AndersonTorres + sternenseemann + ]; inherit (jdk.meta) platforms; broken = stdenv.hostPlatform.isDarwin; # never built on Hydra https://hydra.nixos.org/job/nixpkgs/staging-next/dbqn-native.x86_64-darwin }; diff --git a/pkgs/by-name/db/dbus-cpp/package.nix b/pkgs/by-name/db/dbus-cpp/package.nix index b11ffb330b94e3..96086f64dcfb38 100644 --- a/pkgs/by-name/db/dbus-cpp/package.nix +++ b/pkgs/by-name/db/dbus-cpp/package.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, gitUpdater -, testers -, boost -, cmake -, dbus -, doxygen -, graphviz -, gtest -, libxml2 -, lomiri -, pkg-config -, process-cpp -, properties-cpp +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + gitUpdater, + testers, + boost, + cmake, + dbus, + doxygen, + graphviz, + gtest, + libxml2, + lomiri, + pkg-config, + process-cpp, + properties-cpp, }: stdenv.mkDerivation (finalAttrs: { @@ -53,20 +54,22 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - postPatch = '' - substituteInPlace doc/CMakeLists.txt \ - --replace 'DESTINATION share/''${CMAKE_PROJECT_NAME}/doc' 'DESTINATION ''${CMAKE_INSTALL_DOCDIR}' - - # Warning on aarch64-linux breaks build due to -Werror - substituteInPlace CMakeLists.txt \ - --replace '-Werror' "" - - # pkg-config output patching hook expects prefix variable here - substituteInPlace data/dbus-cpp.pc.in \ - --replace 'includedir=''${exec_prefix}' 'includedir=''${prefix}' - '' + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' - sed -i -e '/add_subdirectory(tests)/d' CMakeLists.txt - ''; + postPatch = + '' + substituteInPlace doc/CMakeLists.txt \ + --replace 'DESTINATION share/''${CMAKE_PROJECT_NAME}/doc' 'DESTINATION ''${CMAKE_INSTALL_DOCDIR}' + + # Warning on aarch64-linux breaks build due to -Werror + substituteInPlace CMakeLists.txt \ + --replace '-Werror' "" + + # pkg-config output patching hook expects prefix variable here + substituteInPlace data/dbus-cpp.pc.in \ + --replace 'includedir=''${exec_prefix}' 'includedir=''${prefix}' + '' + + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' + sed -i -e '/add_subdirectory(tests)/d' CMakeLists.txt + ''; strictDeps = true; diff --git a/pkgs/by-name/db/dbus-glib/package.nix b/pkgs/by-name/db/dbus-glib/package.nix index b2946872fbbd69..291c5c069661e4 100644 --- a/pkgs/by-name/db/dbus-glib/package.nix +++ b/pkgs/by-name/db/dbus-glib/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchurl, buildPackages -, pkg-config, expat, gettext, libiconv, dbus, glib +{ + lib, + stdenv, + fetchurl, + buildPackages, + pkg-config, + expat, + gettext, + libiconv, + dbus, + glib, }: stdenv.mkDerivation rec { @@ -11,18 +20,34 @@ stdenv.mkDerivation rec { sha256 = "sha256-fVUNzN/NKG4ziVUBgp7Zce62XGFOc6rbSgiu73GbFDo="; }; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "dev"; - nativeBuildInputs = [ pkg-config gettext glib ]; + nativeBuildInputs = [ + pkg-config + gettext + glib + ]; - buildInputs = [ expat libiconv ]; + buildInputs = [ + expat + libiconv + ]; - propagatedBuildInputs = [ dbus glib ]; + propagatedBuildInputs = [ + dbus + glib + ]; - configureFlags = [ "--exec-prefix=${placeholder "dev"}" ] ++ - lib.optional (stdenv.buildPlatform != stdenv.hostPlatform) - "--with-dbus-binding-tool=${buildPackages.dbus-glib.dev}/bin/dbus-binding-tool"; + configureFlags = + [ "--exec-prefix=${placeholder "dev"}" ] + ++ lib.optional ( + stdenv.buildPlatform != stdenv.hostPlatform + ) "--with-dbus-binding-tool=${buildPackages.dbus-glib.dev}/bin/dbus-binding-tool"; doCheck = false; @@ -30,7 +55,10 @@ stdenv.mkDerivation rec { meta = { homepage = "https://dbus.freedesktop.org"; - license = with lib.licenses; [ afl21 gpl2Plus ]; + license = with lib.licenses; [ + afl21 + gpl2Plus + ]; description = "Obsolete glib bindings for D-Bus lightweight IPC mechanism"; mainProgram = "dbus-binding-tool"; maintainers = [ ]; diff --git a/pkgs/by-name/db/dbus-test-runner/package.nix b/pkgs/by-name/db/dbus-test-runner/package.nix index 93b18609592341..10d110e648a2e8 100644 --- a/pkgs/by-name/db/dbus-test-runner/package.nix +++ b/pkgs/by-name/db/dbus-test-runner/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchbzr -, testers -, autoreconfHook -, bash -, dbus -, dbus-glib -, glib -, intltool -, pkg-config -, python3 -, xvfb-run +{ + stdenv, + lib, + fetchbzr, + testers, + autoreconfHook, + bash, + dbus, + dbus-glib, + glib, + intltool, + pkg-config, + python3, + xvfb-run, }: stdenv.mkDerivation (finalAttrs: { @@ -50,9 +51,11 @@ stdenv.mkDerivation (finalAttrs: { nativeCheckInputs = [ bash dbus - (python3.withPackages (ps: with ps; [ - python-dbusmock - ])) + (python3.withPackages ( + ps: with ps; [ + python-dbusmock + ] + )) xvfb-run ]; diff --git a/pkgs/by-name/db/dbus_cplusplus/package.nix b/pkgs/by-name/db/dbus_cplusplus/package.nix index 95dbdce239c798..48b81897de0773 100644 --- a/pkgs/by-name/db/dbus_cplusplus/package.nix +++ b/pkgs/by-name/db/dbus_cplusplus/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, fetchpatch, dbus, glib, pkg-config, expat }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + dbus, + glib, + pkg-config, + expat, +}: stdenv.mkDerivation rec { pname = "dbus-cplusplus"; @@ -13,8 +22,9 @@ stdenv.mkDerivation rec { patches = [ (fetchurl { name = "gcc-4.7.patch"; - url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/dev-libs/" - + "dbus-c++/files/dbus-c++-0.9.0-gcc-4.7.patch"; + url = + "https://gitweb.gentoo.org/repo/gentoo.git/plain/dev-libs/" + + "dbus-c++/files/dbus-c++-0.9.0-gcc-4.7.patch"; sha256 = "0rwcz9pvc13b3yfr0lkifnfz0vb5q6dg240bzgf37ni4s8rpc72g"; }) (fetchpatch { @@ -50,15 +60,21 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dbus glib expat ]; - - configureFlags = [ - "--disable-ecore" - "--disable-tests" - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - "--disable-examples" + buildInputs = [ + dbus + glib + expat ]; + configureFlags = + [ + "--disable-ecore" + "--disable-tests" + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + "--disable-examples" + ]; + meta = with lib; { homepage = "https://dbus-cplusplus.sourceforge.net"; description = "C++ API for D-BUS"; diff --git a/pkgs/by-name/db/dbus_java/package.nix b/pkgs/by-name/db/dbus_java/package.nix index c8e67edfe2b573..ab2e92aa21be48 100644 --- a/pkgs/by-name/db/dbus_java/package.nix +++ b/pkgs/by-name/db/dbus_java/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, gettext, jdk8, libmatthew_java }: +{ + lib, + stdenv, + fetchurl, + gettext, + jdk8, + libmatthew_java, +}: stdenv.mkDerivation rec { pname = "dbus-java"; @@ -8,12 +15,15 @@ stdenv.mkDerivation rec { url = "https://dbus.freedesktop.org/releases/dbus-java/dbus-java-${version}.tar.gz"; sha256 = "0cyaxd8x6sxmi6pklkkx45j311a6w51fxl4jc5j3inc4cailwh5y"; }; - JAVA_HOME=jdk8; - JAVA="${jdk8}/bin/java"; - PREFIX="\${out}"; - JAVAUNIXLIBDIR="${libmatthew_java}/lib/jni"; - JAVAUNIXJARDIR="${libmatthew_java}/share/java"; - buildInputs = [ gettext jdk8 ]; + JAVA_HOME = jdk8; + JAVA = "${jdk8}/bin/java"; + PREFIX = "\${out}"; + JAVAUNIXLIBDIR = "${libmatthew_java}/lib/jni"; + JAVAUNIXJARDIR = "${libmatthew_java}/share/java"; + buildInputs = [ + gettext + jdk8 + ]; # I'm too lazy to build the documentation preBuild = '' sed -i -e "s|all: bin doc man|all: bin|" \ diff --git a/pkgs/by-name/db/dbx/package.nix b/pkgs/by-name/db/dbx/package.nix index f3f34094344151..b1fcd6f53916b9 100644 --- a/pkgs/by-name/db/dbx/package.nix +++ b/pkgs/by-name/db/dbx/package.nix @@ -5,7 +5,10 @@ python3, }: let - python = python3.override { self = python; packageOverrides = self: super: { pydantic = super.pydantic_1; }; }; + python = python3.override { + self = python; + packageOverrides = self: super: { pydantic = super.pydantic_1; }; + }; in python.pkgs.buildPythonApplication rec { pname = "dbx"; @@ -30,27 +33,24 @@ python.pkgs.buildPythonApplication rec { build-system = with python.pkgs; [ setuptools ]; - - propagatedBuildInputs = - with python.pkgs; - [ - aiohttp - click - cookiecutter - cryptography - databricks-cli - jinja2 - mlflow - pathspec - pydantic - pyyaml - requests - retry - rich - tenacity - typer - watchdog - ]; + propagatedBuildInputs = with python.pkgs; [ + aiohttp + click + cookiecutter + cryptography + databricks-cli + jinja2 + mlflow + pathspec + pydantic + pyyaml + requests + retry + rich + tenacity + typer + watchdog + ]; optional-dependencies = with python3.pkgs; { aws = [ boto3 ]; diff --git a/pkgs/by-name/db/dbxml/package.nix b/pkgs/by-name/db/dbxml/package.nix index 207904b96cdc90..d2fb83e6d7a78a 100644 --- a/pkgs/by-name/db/dbxml/package.nix +++ b/pkgs/by-name/db/dbxml/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, db62, xercesc, xqilla }: +{ + lib, + stdenv, + fetchurl, + db62, + xercesc, + xqilla, +}: stdenv.mkDerivation rec { pname = "dbxml"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "a8fc8f5e0c3b6e42741fa4dfc3b878c982ff8f5e5f14843f6a7e20d22e64251a"; }; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; patches = [ ./cxx11.patch @@ -17,7 +28,8 @@ stdenv.mkDerivation rec { ]; buildInputs = [ - xercesc xqilla + xercesc + xqilla ]; propagatedBuildInputs = [ diff --git a/pkgs/by-name/dc/dc3dd/package.nix b/pkgs/by-name/dc/dc3dd/package.nix index c6cd3c7f396785..0a1f90f9e7a134 100644 --- a/pkgs/by-name/dc/dc3dd/package.nix +++ b/pkgs/by-name/dc/dc3dd/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchzip -, perlPackages +{ + lib, + stdenv, + fetchzip, + perlPackages, }: stdenv.mkDerivation (finalAttrs: { @@ -13,7 +14,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-SYDoqGlsROHX1a0jJX11F+yp6CeFK+tZbYOOnScC6Ig="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; preConfigure = '' chmod +x configure diff --git a/pkgs/by-name/dc/dcadec/package.nix b/pkgs/by-name/dc/dcadec/package.nix index bf531476566e70..0e1d8d9b911a91 100644 --- a/pkgs/by-name/dc/dcadec/package.nix +++ b/pkgs/by-name/dc/dcadec/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "dcadec"; diff --git a/pkgs/by-name/dc/dcap/package.nix b/pkgs/by-name/dc/dcap/package.nix index de3a484f5dee9d..ad9697885c8fe4 100644 --- a/pkgs/by-name/dc/dcap/package.nix +++ b/pkgs/by-name/dc/dcap/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoconf -, automake -, libtool -, zlib -, cunit -, libxcrypt +{ + stdenv, + lib, + fetchFromGitHub, + autoconf, + automake, + libtool, + zlib, + cunit, + libxcrypt, }: stdenv.mkDerivation rec { pname = "dcap"; @@ -19,8 +20,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-hn4nkFTIbSUUhvf9UfsEqVhphAdNWmATaCrv8jOuC0Y="; }; - nativeBuildInputs = [ autoconf automake libtool ]; - buildInputs = [ zlib libxcrypt ]; + nativeBuildInputs = [ + autoconf + automake + libtool + ]; + buildInputs = [ + zlib + libxcrypt + ]; preConfigure = '' patchShebangs bootstrap.sh @@ -31,7 +39,13 @@ stdenv.mkDerivation rec { nativeCheckInputs = [ cunit ]; - outputs = [ "bin" "dev" "out" "man" "doc" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + "doc" + ]; meta = with lib; { broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/by-name/dc/dcfldd/package.nix b/pkgs/by-name/dc/dcfldd/package.nix index 01439e6aa49bb9..fff7ad2036950b 100644 --- a/pkgs/by-name/dc/dcfldd/package.nix +++ b/pkgs/by-name/dc/dcfldd/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "dcfldd"; diff --git a/pkgs/by-name/dc/dcgm/package.nix b/pkgs/by-name/dc/dcgm/package.nix index e0de192b3dafbb..382ecad9142bc1 100644 --- a/pkgs/by-name/dc/dcgm/package.nix +++ b/pkgs/by-name/dc/dcgm/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoAddDriverRunpath -, catch2 -, cmake -, ninja -, cudaPackages_11_8 -, cudaPackages_12 -, boost -, fmt_9 -, git -, jsoncpp -, libevent -, plog -, python3 -, symlinkJoin -, tclap_1_4 -, yaml-cpp +{ + lib, + stdenv, + fetchFromGitHub, + autoAddDriverRunpath, + catch2, + cmake, + ninja, + cudaPackages_11_8, + cudaPackages_12, + boost, + fmt_9, + git, + jsoncpp, + libevent, + plog, + python3, + symlinkJoin, + tclap_1_4, + yaml-cpp, }: let # DCGM depends on 2 different versions of CUDA at the same time. @@ -29,18 +30,20 @@ let # Select needed redist packages from cudaPackages # C.f. https://github.com/NVIDIA/DCGM/blob/7e1012302679e4bb7496483b32dcffb56e528c92/dcgmbuild/scripts/0080_cuda.sh#L24-L39 - getCudaPackages = p: with p; [ - cuda_cccl - cuda_cudart - cuda_nvcc - cuda_nvml_dev - libcublas - libcufft - libcurand - ]; + getCudaPackages = + p: with p; [ + cuda_cccl + cuda_cudart + cuda_nvcc + cuda_nvml_dev + libcublas + libcufft + libcurand + ]; # Builds CMake flags to add CUDA paths for include and lib. - mkCudaFlags = cudaPackages: + mkCudaFlags = + cudaPackages: let version = cudaPackages.cudaMajorVersion; # The DCGM CMake assumes that the folder containing cuda.h contains all headers, so we must @@ -49,16 +52,20 @@ let name = "cuda-headers-combined-${version}"; paths = lib.map (pkg: "${lib.getInclude pkg}/include") (getCudaPackages cudaPackages); }; - in [ + in + [ (lib.cmakeFeature "CUDA${version}_INCLUDE_DIR" "${headers}") (lib.cmakeFeature "CUDA${version}_LIBS" "${cudaPackages.cuda_cudart.stubs}/lib/stubs/libcuda.so") (lib.cmakeFeature "CUDA${version}_STATIC_LIBS" "${lib.getLib cudaPackages.cuda_cudart}/lib/libcudart.so") - (lib.cmakeFeature "CUDA${version}_STATIC_CUBLAS_LIBS" (lib.concatStringsSep ";" [ - "${lib.getLib cudaPackages.libcublas}/lib/libcublas.so" - "${lib.getLib cudaPackages.libcublas}/lib/libcublasLt.so" - ])) + (lib.cmakeFeature "CUDA${version}_STATIC_CUBLAS_LIBS" ( + lib.concatStringsSep ";" [ + "${lib.getLib cudaPackages.libcublas}/lib/libcublas.so" + "${lib.getLib cudaPackages.libcublas}/lib/libcublasLt.so" + ] + )) ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "dcgm"; version = "3.3.9"; # N.B: If you change this, be sure prometheus-dcgm-exporter supports this version. diff --git a/pkgs/by-name/dc/dclib/package.nix b/pkgs/by-name/dc/dclib/package.nix index 083e968c11bb99..d95faed969ed01 100644 --- a/pkgs/by-name/dc/dclib/package.nix +++ b/pkgs/by-name/dc/dclib/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchurl, libxml2, openssl, bzip2, zlib}: +{ + lib, + stdenv, + fetchurl, + libxml2, + openssl, + bzip2, + zlib, +}: stdenv.mkDerivation rec { pname = "dclib"; @@ -9,12 +17,20 @@ stdenv.mkDerivation rec { sha256 = "02jdzm5hqzs1dv2rd596vgpcjaapm55pqqapz5m94l30v4q72rfc"; }; - buildInputs = [libxml2 openssl bzip2 zlib]; + buildInputs = [ + libxml2 + openssl + bzip2 + zlib + ]; meta = with lib; { description = "Peer-to-Peer file sharing client"; homepage = "http://dcgui.berlios.de"; platforms = platforms.linux; - license = [ licenses.openssl licenses.gpl2 ]; + license = [ + licenses.openssl + licenses.gpl2 + ]; }; } diff --git a/pkgs/by-name/dc/dclxvi/package.nix b/pkgs/by-name/dc/dclxvi/package.nix index 34340a406a508c..870cf8a211a141 100644 --- a/pkgs/by-name/dc/dclxvi/package.nix +++ b/pkgs/by-name/dc/dclxvi/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "dclxvi"; @@ -13,13 +17,15 @@ stdenv.mkDerivation { buildFlags = [ "libdclxvipairing.so" ]; - patchPhase = '' - substituteInPlace Makefile \ - --replace "gcc" "cc" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace Makefile \ - --replace "-soname=libdclxvipairing.so" "-install_name,libdclxvipairing.so" - ''; + patchPhase = + '' + substituteInPlace Makefile \ + --replace "gcc" "cc" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace Makefile \ + --replace "-soname=libdclxvipairing.so" "-install_name,libdclxvipairing.so" + ''; installPhase = '' mkdir -p $out/{include,lib} diff --git a/pkgs/by-name/dc/dcm2niix/package.nix b/pkgs/by-name/dc/dcm2niix/package.nix index acf43e52764da3..5d73f8d5b46039 100644 --- a/pkgs/by-name/dc/dcm2niix/package.nix +++ b/pkgs/by-name/dc/dcm2niix/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, substituteAll -, cmake -, openjpeg -, yaml-cpp -, batchVersion ? false -, withJpegLs ? true -, withOpenJpeg ? true -, withCloudflareZlib ? true +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + cmake, + openjpeg, + yaml-cpp, + batchVersion ? false, + withJpegLs ? true, + withOpenJpeg ? true, + withCloudflareZlib ? true, }: let @@ -40,20 +41,28 @@ stdenv.mkDerivation (finalAttrs: { ]; nativeBuildInputs = [ cmake ]; - buildInputs = lib.optionals batchVersion [ yaml-cpp ] - ++ lib.optionals withOpenJpeg [ openjpeg openjpeg.dev ]; + buildInputs = + lib.optionals batchVersion [ yaml-cpp ] + ++ lib.optionals withOpenJpeg [ + openjpeg + openjpeg.dev + ]; - cmakeFlags = lib.optionals batchVersion [ - "-DBATCH_VERSION=ON" - "-DYAML-CPP_DIR=${yaml-cpp}/lib/cmake/yaml-cpp" - ] ++ lib.optionals withJpegLs [ - "-DUSE_JPEGLS=ON" - ] ++ lib.optionals withOpenJpeg [ - "-DUSE_OPENJPEG=ON" - "-DOpenJPEG_DIR=${openjpeg}/lib/${openjpeg.pname}-${lib.versions.majorMinor openjpeg.version}" - ] ++ lib.optionals withCloudflareZlib [ - "-DZLIB_IMPLEMENTATION=Cloudflare" - ]; + cmakeFlags = + lib.optionals batchVersion [ + "-DBATCH_VERSION=ON" + "-DYAML-CPP_DIR=${yaml-cpp}/lib/cmake/yaml-cpp" + ] + ++ lib.optionals withJpegLs [ + "-DUSE_JPEGLS=ON" + ] + ++ lib.optionals withOpenJpeg [ + "-DUSE_OPENJPEG=ON" + "-DOpenJPEG_DIR=${openjpeg}/lib/${openjpeg.pname}-${lib.versions.majorMinor openjpeg.version}" + ] + ++ lib.optionals withCloudflareZlib [ + "-DZLIB_IMPLEMENTATION=Cloudflare" + ]; meta = { description = "DICOM to NIfTI converter"; @@ -64,7 +73,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.nitrc.org/projects/dcm2nii"; changelog = "https://github.com/rordenlab/dcm2niix/releases/tag/v${finalAttrs.version}"; license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [ ashgillman rbreslow ]; + maintainers = with lib.maintainers; [ + ashgillman + rbreslow + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/by-name/dc/dcmtk/package.nix b/pkgs/by-name/dc/dcmtk/package.nix index 8dc85e2ee10779..c191ba70d489d2 100644 --- a/pkgs/by-name/dc/dcmtk/package.nix +++ b/pkgs/by-name/dc/dcmtk/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, zlib, libtiff, libxml2, openssl, libiconv -, libpng, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + libtiff, + libxml2, + openssl, + libiconv, + libpng, + cmake, +}: stdenv.mkDerivation rec { pname = "dcmtk"; @@ -12,13 +22,19 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libpng zlib libtiff libxml2 openssl libiconv ]; + buildInputs = [ + libpng + zlib + libtiff + libxml2 + openssl + libiconv + ]; doCheck = true; meta = with lib; { - description = - "Collection of libraries and applications implementing large parts of the DICOM standard"; + description = "Collection of libraries and applications implementing large parts of the DICOM standard"; longDescription = '' DCMTK is a collection of libraries and applications implementing large parts of the DICOM standard. It includes software for examining, constructing and converting DICOM image files, handling offline media, diff --git a/pkgs/by-name/dc/dconf-editor/package.nix b/pkgs/by-name/dc/dconf-editor/package.nix index aaf39f2ca14daa..2a1d45a1eb6d42 100644 --- a/pkgs/by-name/dc/dconf-editor/package.nix +++ b/pkgs/by-name/dc/dconf-editor/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, desktop-file-utils -, meson -, ninja -, vala -, libxslt -, pkg-config -, glib -, gtk3 -, libhandy -, gnome -, dconf -, libxml2 -, gettext -, docbook-xsl-nons -, wrapGAppsHook3 -, gobject-introspection +{ + lib, + stdenv, + fetchurl, + fetchpatch, + desktop-file-utils, + meson, + ninja, + vala, + libxslt, + pkg-config, + glib, + gtk3, + libhandy, + gnome, + dconf, + libxml2, + gettext, + docbook-xsl-nons, + wrapGAppsHook3, + gobject-introspection, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dc/dconf/package.nix b/pkgs/by-name/dc/dconf/package.nix index 6d56ba075f49ef..e98add24382e20 100644 --- a/pkgs/by-name/dc/dconf/package.nix +++ b/pkgs/by-name/dc/dconf/package.nix @@ -1,60 +1,70 @@ -{ lib, stdenv -, fetchurl -, meson -, mesonEmulatorHook -, ninja -, python3 -, vala -, libxslt -, pkg-config -, glib -, bash-completion -, dbus -, gnome -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_42 -, nixosTests -, buildPackages -, gobject-introspection -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, withDocs ? withIntrospection +{ + lib, + stdenv, + fetchurl, + meson, + mesonEmulatorHook, + ninja, + python3, + vala, + libxslt, + pkg-config, + glib, + bash-completion, + dbus, + gnome, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_42, + nixosTests, + buildPackages, + gobject-introspection, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + withDocs ? withIntrospection, }: stdenv.mkDerivation rec { pname = "dconf"; version = "0.40.0"; - outputs = [ "out" "lib" "dev" ] - ++ lib.optional withDocs "devdoc"; + outputs = [ + "out" + "lib" + "dev" + ] ++ lib.optional withDocs "devdoc"; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; sha256 = "0cs5nayg080y8pb9b7qccm1ni8wkicdmqp1jsgc22110r6j24zyg"; }; - nativeBuildInputs = [ - meson - ninja - pkg-config - python3 - libxslt - glib - docbook-xsl-nons - docbook_xml_dtd_42 - gtk-doc - ] ++ lib.optionals (withDocs && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook # gtkdoc invokes the host binary to produce documentation - ]; - + nativeBuildInputs = + [ + meson + ninja + pkg-config + python3 + libxslt + glib + docbook-xsl-nons + docbook_xml_dtd_42 + gtk-doc + ] + ++ lib.optionals (withDocs && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook # gtkdoc invokes the host binary to produce documentation + ]; - buildInputs = [ - glib - bash-completion - dbus - ] ++ lib.optionals withIntrospection [ - vala - ]; + buildInputs = + [ + glib + bash-completion + dbus + ] + ++ lib.optionals withIntrospection [ + vala + ]; mesonFlags = [ "--sysconfdir=/etc" @@ -66,7 +76,8 @@ stdenv.mkDerivation rec { dbus # for dbus-daemon ]; - doCheck = !stdenv.hostPlatform.isAarch32 && !stdenv.hostPlatform.isAarch64 && !stdenv.hostPlatform.isDarwin; + doCheck = + !stdenv.hostPlatform.isAarch32 && !stdenv.hostPlatform.isAarch64 && !stdenv.hostPlatform.isDarwin; postPatch = '' chmod +x meson_post_install.py tests/test-dconf.py diff --git a/pkgs/by-name/dc/dcraw/package.nix b/pkgs/by-name/dc/dcraw/package.nix index 9e35c1bfdc863b..4c76548c2b35c6 100644 --- a/pkgs/by-name/dc/dcraw/package.nix +++ b/pkgs/by-name/dc/dcraw/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchurl, libjpeg, lcms2, gettext, libiconv }: +{ + lib, + stdenv, + fetchurl, + libjpeg, + lcms2, + gettext, + libiconv, +}: stdenv.mkDerivation rec { pname = "dcraw"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = lib.optional stdenv.hostPlatform.isDarwin libiconv; - buildInputs = [ libjpeg lcms2 gettext ]; + buildInputs = [ + libjpeg + lcms2 + gettext + ]; # Jasper is disabled because the library is abandoned and has many # CVEs. diff --git a/pkgs/by-name/dc/dcrctl/package.nix b/pkgs/by-name/dc/dcrctl/package.nix index eb8f53d1cda59a..e1e8d222ca299f 100644 --- a/pkgs/by-name/dc/dcrctl/package.nix +++ b/pkgs/by-name/dc/dcrctl/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "dcrctl"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-Ry3wR2u+vr97icP9jwAVWcFO98JVDo9TrDg9D8hfv5I="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = { homepage = "https://decred.org"; diff --git a/pkgs/by-name/dc/dcrd/package.nix b/pkgs/by-name/dc/dcrd/package.nix index d62a901c99fe4e..077494f05a7a90 100644 --- a/pkgs/by-name/dc/dcrd/package.nix +++ b/pkgs/by-name/dc/dcrd/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "dcrd"; @@ -21,7 +26,10 @@ buildGoModule rec { vendorHash = "sha256-Napcfj1+KjQ21Jb/qpIzg2W/grzun2Pz5FV5yIBXoTo="; - subPackages = [ "." "cmd/promptsecret" ]; + subPackages = [ + "." + "cmd/promptsecret" + ]; __darwinAllowLocalNetworking = true; diff --git a/pkgs/by-name/dc/dcrwallet/package.nix b/pkgs/by-name/dc/dcrwallet/package.nix index 0450bbf6b0a05d..40c6c4564cb10b 100644 --- a/pkgs/by-name/dc/dcrwallet/package.nix +++ b/pkgs/by-name/dc/dcrwallet/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "dcrwallet"; diff --git a/pkgs/by-name/dc/dcs/package.nix b/pkgs/by-name/dc/dcs/package.nix index 458a76cf591331..dc3b9c35788511 100644 --- a/pkgs/by-name/dc/dcs/package.nix +++ b/pkgs/by-name/dc/dcs/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, yuicompressor -, zopfli -, stdenv +{ + lib, + buildGoModule, + fetchFromGitHub, + yuicompressor, + zopfli, + stdenv, }: buildGoModule { pname = "dcs"; @@ -41,7 +42,6 @@ buildGoModule { homepage = "https://github.com/Debian/dcs"; license = licenses.bsd3; maintainers = [ ]; - broken = stdenv.hostPlatform.isAarch64 - || stdenv.hostPlatform.isDarwin; # never built on Hydra https://hydra.nixos.org/job/nixpkgs/staging-next/dcs.x86_64-darwin + broken = stdenv.hostPlatform.isAarch64 || stdenv.hostPlatform.isDarwin; # never built on Hydra https://hydra.nixos.org/job/nixpkgs/staging-next/dcs.x86_64-darwin }; } diff --git a/pkgs/by-name/dd/dd_rescue/package.nix b/pkgs/by-name/dd/dd_rescue/package.nix index e58499d2b2d451..78e35bec67488a 100644 --- a/pkgs/by-name/dd/dd_rescue/package.nix +++ b/pkgs/by-name/dd/dd_rescue/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, autoconf }: +{ + lib, + stdenv, + fetchurl, + autoconf, +}: stdenv.mkDerivation rec { version = "1.99.8"; @@ -6,7 +11,7 @@ stdenv.mkDerivation rec { src = fetchurl { sha256 = "1gbxm8gr9sx5g1q9dycs21hkxikcy97q09lp1lvs59pnd9qpdnwh"; - url="http://www.garloff.de/kurt/linux/ddrescue/${pname}-${version}.tar.bz2"; + url = "http://www.garloff.de/kurt/linux/ddrescue/${pname}-${version}.tar.bz2"; }; dd_rhelp_src = fetchurl { @@ -32,7 +37,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Tool to copy data from a damaged block device"; - maintainers = with maintainers; [ raskin domenkozar ]; + maintainers = with maintainers; [ + raskin + domenkozar + ]; platforms = platforms.linux; homepage = "http://www.garloff.de/kurt/linux/ddrescue/"; license = licenses.gpl2Plus; diff --git a/pkgs/by-name/dd/ddate/package.nix b/pkgs/by-name/dd/ddate/package.nix index 012e00c8f97243..fd4b7ab868b704 100644 --- a/pkgs/by-name/dd/ddate/package.nix +++ b/pkgs/by-name/dd/ddate/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "ddate"; diff --git a/pkgs/by-name/dd/ddccontrol-db/package.nix b/pkgs/by-name/dd/ddccontrol-db/package.nix index f0eb0492f3adee..10e089fcbc8ba7 100644 --- a/pkgs/by-name/dd/ddccontrol-db/package.nix +++ b/pkgs/by-name/dd/ddccontrol-db/package.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, autoreconfHook -, intltool -, fetchFromGitHub +{ + lib, + stdenv, + autoreconfHook, + intltool, + fetchFromGitHub, }: stdenv.mkDerivation rec { @@ -15,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-u+buByJ7w1VHs4fGWNRy2EDFYheztbzpFga3tS6PnKk="; }; - nativeBuildInputs = [ autoreconfHook intltool ]; + nativeBuildInputs = [ + autoreconfHook + intltool + ]; meta = with lib; { description = "Monitor database for DDCcontrol"; diff --git a/pkgs/by-name/dd/ddccontrol/package.nix b/pkgs/by-name/dd/ddccontrol/package.nix index 5886d2e18318c7..6089c8c6d7b940 100644 --- a/pkgs/by-name/dd/ddccontrol/package.nix +++ b/pkgs/by-name/dd/ddccontrol/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, intltool -, libxml2 -, pciutils -, pkg-config -, gtk2 -, ddccontrol-db +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + intltool, + libxml2, + pciutils, + pkg-config, + gtk2, + ddccontrol-db, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dd/ddclient/package.nix b/pkgs/by-name/dd/ddclient/package.nix index ec84c7c526cb62..86847869864bdb 100644 --- a/pkgs/by-name/dd/ddclient/package.nix +++ b/pkgs/by-name/dd/ddclient/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, perlPackages, autoreconfHook, perl, curl }: +{ + lib, + fetchFromGitHub, + perlPackages, + autoreconfHook, + perl, + curl, +}: let myPerl = perl.withPackages (ps: [ ps.JSONPP ]); @@ -22,7 +29,10 @@ perlPackages.buildPerlPackage rec { nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ curl myPerl ]; + buildInputs = [ + curl + myPerl + ]; # Prevent ddclient from picking up build time perl which is implicitly added # by buildPerlPackage. diff --git a/pkgs/by-name/dd/ddcutil/package.nix b/pkgs/by-name/dd/ddcutil/package.nix index baf41aac70417d..cd0ad0b319908e 100644 --- a/pkgs/by-name/dd/ddcutil/package.nix +++ b/pkgs/by-name/dd/ddcutil/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, pkg-config -, glib -, jansson -, udev -, libgudev -, libusb1 -, libdrm -, xorg +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + glib, + jansson, + udev, + libgudev, + libusb1, + libdrm, + xorg, }: stdenv.mkDerivation rec { @@ -21,7 +22,10 @@ stdenv.mkDerivation rec { hash = "sha256-4U/igqtgw2rwyuhEkV1pWYPIyNZEt2N6hlXJ9bDUyRw="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ glib @@ -46,4 +50,3 @@ stdenv.mkDerivation rec { mainProgram = "ddcutil"; }; } - diff --git a/pkgs/by-name/dd/ddgr/package.nix b/pkgs/by-name/dd/ddgr/package.nix index 04f27117f8e2db..01a331802e5dff 100644 --- a/pkgs/by-name/dd/ddgr/package.nix +++ b/pkgs/by-name/dd/ddgr/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, python3, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + installShellFiles, +}: stdenv.mkDerivation rec { version = "2.2"; @@ -27,7 +33,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/jarun/ddgr"; description = "Search DuckDuckGo from the terminal"; license = licenses.gpl3; - maintainers = with maintainers; [ ceedubs markus1189 ]; + maintainers = with maintainers; [ + ceedubs + markus1189 + ]; platforms = python3.meta.platforms; mainProgram = "ddgr"; }; diff --git a/pkgs/by-name/dd/ddh/package.nix b/pkgs/by-name/dd/ddh/package.nix index b042f5549a199d..ecfa8c702ab9cb 100644 --- a/pkgs/by-name/dd/ddh/package.nix +++ b/pkgs/by-name/dd/ddh/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, rustPlatform, ... }: +{ + lib, + fetchFromGitHub, + rustPlatform, + ... +}: rustPlatform.buildRustPackage rec { pname = "ddh"; version = "0.13.0"; diff --git a/pkgs/by-name/dd/ddns-go/package.nix b/pkgs/by-name/dd/ddns-go/package.nix index 5ad845467a7f5f..3e6d219715f559 100644 --- a/pkgs/by-name/dd/ddns-go/package.nix +++ b/pkgs/by-name/dd/ddns-go/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -23,7 +24,7 @@ buildGoModule rec { # network required doCheck = false; - meta = with lib;{ + meta = with lib; { homepage = "https://github.com/jeessy2/ddns-go"; description = "Simple and easy to use DDNS"; license = licenses.mit; diff --git a/pkgs/by-name/dd/ddosify/package.nix b/pkgs/by-name/dd/ddosify/package.nix index 0f47035721e680..77b29c41d25e4a 100644 --- a/pkgs/by-name/dd/ddosify/package.nix +++ b/pkgs/by-name/dd/ddosify/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/dd/ddrescue/package.nix b/pkgs/by-name/dd/ddrescue/package.nix index 2e90558d386337..087f1057ce2291 100644 --- a/pkgs/by-name/dd/ddrescue/package.nix +++ b/pkgs/by-name/dd/ddrescue/package.nix @@ -1,5 +1,8 @@ -{ lib, stdenv -, fetchurl, lzip +{ + lib, + stdenv, + fetchurl, + lzip, }: stdenv.mkDerivation rec { @@ -47,6 +50,9 @@ stdenv.mkDerivation rec { license = licenses.gpl3Plus; platforms = platforms.all; - maintainers = with maintainers; [ domenkozar fpletz ]; + maintainers = with maintainers; [ + domenkozar + fpletz + ]; }; } diff --git a/pkgs/by-name/dd/ddrescueview/package.nix b/pkgs/by-name/dd/ddrescueview/package.nix index d3a2e46da14bf6..91e834ec937650 100644 --- a/pkgs/by-name/dd/ddrescueview/package.nix +++ b/pkgs/by-name/dd/ddrescueview/package.nix @@ -1,4 +1,17 @@ -{ stdenv, lib, fetchurl, fpc, lazarus, atk, cairo, gdk-pixbuf, glib, gtk2, libX11, pango }: +{ + stdenv, + lib, + fetchurl, + fpc, + lazarus, + atk, + cairo, + gdk-pixbuf, + glib, + gtk2, + libX11, + pango, +}: stdenv.mkDerivation rec { pname = "ddrescueview"; @@ -10,9 +23,20 @@ stdenv.mkDerivation rec { }; sourceRoot = "ddrescueview-source-${version}/source"; - nativeBuildInputs = [ fpc lazarus ]; - - buildInputs = [ atk cairo gdk-pixbuf glib gtk2 libX11 pango ]; + nativeBuildInputs = [ + fpc + lazarus + ]; + + buildInputs = [ + atk + cairo + gdk-pixbuf + glib + gtk2 + libX11 + pango + ]; NIX_LDFLAGS = "--as-needed -rpath ${lib.makeLibraryPath buildInputs}"; diff --git a/pkgs/by-name/dd/ddrutility/package.nix b/pkgs/by-name/dd/ddrutility/package.nix index ee1c549fca9a9c..7756e23b2b11c6 100644 --- a/pkgs/by-name/dd/ddrutility/package.nix +++ b/pkgs/by-name/dd/ddrutility/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ddrutility"; diff --git a/pkgs/by-name/dd/ddsmt/package.nix b/pkgs/by-name/dd/ddsmt/package.nix index a4a4a399916873..74616fd67e15aa 100644 --- a/pkgs/by-name/dd/ddsmt/package.nix +++ b/pkgs/by-name/dd/ddsmt/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchPypi +{ + lib, + python3Packages, + fetchPypi, }: let diff --git a/pkgs/by-name/dd/dduper/package.nix b/pkgs/by-name/dd/dduper/package.nix index c63846e2c46a20..2735242abb300f 100644 --- a/pkgs/by-name/dd/dduper/package.nix +++ b/pkgs/by-name/dd/dduper/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchpatch, fetchFromGitHub, btrfs-progs, python3 }: +{ + lib, + stdenv, + fetchpatch, + fetchFromGitHub, + btrfs-progs, + python3, +}: let btrfsProgsPatched = btrfs-progs.overrideAttrs { @@ -9,10 +16,12 @@ let }) ]; }; - py3 = python3.withPackages (ps: with ps; [ - prettytable - numpy - ]); + py3 = python3.withPackages ( + ps: with ps; [ + prettytable + numpy + ] + ); in stdenv.mkDerivation rec { pname = "dduper"; diff --git a/pkgs/by-name/de/deadnix/package.nix b/pkgs/by-name/de/deadnix/package.nix index daea07c9ba3e5b..a15e628d04e51a 100644 --- a/pkgs/by-name/de/deadnix/package.nix +++ b/pkgs/by-name/de/deadnix/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/de/deadpixi-sam-unstable/package.nix b/pkgs/by-name/de/deadpixi-sam-unstable/package.nix index 4321119156e0e3..503895f882f735 100644 --- a/pkgs/by-name/de/deadpixi-sam-unstable/package.nix +++ b/pkgs/by-name/de/deadpixi-sam-unstable/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, freetype, libX11, libXi, libXt, libXft }: +{ + lib, + stdenv, + fetchFromGitHub, + freetype, + libX11, + libXi, + libXt, + libXft, +}: stdenv.mkDerivation rec { pname = "deadpixi-sam-unstable"; @@ -20,7 +29,12 @@ stdenv.mkDerivation rec { CFLAGS = "-D_DARWIN_C_SOURCE"; makeFlags = [ "DESTDIR=$(out)" ]; - buildInputs = [ libX11 libXi libXt libXft ]; + buildInputs = [ + libX11 + libXi + libXt + libXft + ]; # build fails when run in parallel enableParallelBuilding = false; diff --git a/pkgs/by-name/de/debian-devscripts/package.nix b/pkgs/by-name/de/debian-devscripts/package.nix index d70994753dbdff..2d92cac2eea7f3 100644 --- a/pkgs/by-name/de/debian-devscripts/package.nix +++ b/pkgs/by-name/de/debian-devscripts/package.nix @@ -1,8 +1,24 @@ -{lib, stdenv, fetchurl, fetchpatch, xz, dpkg -, libxslt, docbook_xsl, makeWrapper, writeShellScript -, python3Packages -, perlPackages, curl, gnupg, diffutils, nano, pkg-config, bash-completion, help2man -, sendmailPath ? "/run/wrappers/bin/sendmail" +{ + lib, + stdenv, + fetchurl, + fetchpatch, + xz, + dpkg, + libxslt, + docbook_xsl, + makeWrapper, + writeShellScript, + python3Packages, + perlPackages, + curl, + gnupg, + diffutils, + nano, + pkg-config, + bash-completion, + help2man, + sendmailPath ? "/run/wrappers/bin/sendmail", }: let @@ -10,7 +26,8 @@ let sensible-editor = writeShellScript "sensible-editor" '' exec ''${EDITOR-${nano}/bin/nano} "$@" ''; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { version = "2.23.5"; pname = "debian-devscripts"; @@ -33,9 +50,38 @@ in stdenv.mkDerivation rec { patchShebangs scripts ''; - nativeBuildInputs = [ makeWrapper pkg-config ]; - buildInputs = [ xz dpkg libxslt python setuptools curl gnupg diffutils bash-completion help2man ] ++ - (with perlPackages; [ perl CryptSSLeay LWP TimeDate DBFile FileDesktopEntry ParseDebControl LWPProtocolHttps Moo FileHomeDir IPCRun FileDirList FileTouch ]); + nativeBuildInputs = [ + makeWrapper + pkg-config + ]; + buildInputs = + [ + xz + dpkg + libxslt + python + setuptools + curl + gnupg + diffutils + bash-completion + help2man + ] + ++ (with perlPackages; [ + perl + CryptSSLeay + LWP + TimeDate + DBFile + FileDesktopEntry + ParseDebControl + LWPProtocolHttps + Moo + FileHomeDir + IPCRun + FileDirList + FileTouch + ]); preConfigure = '' export PERL5LIB="$PERL5LIB''${PERL5LIB:+:}${dpkg}"; @@ -83,7 +129,7 @@ in stdenv.mkDerivation rec { meta = with lib; { description = "Debian package maintenance scripts"; license = licenses.free; # Mix of public domain, Artistic+GPL, GPL1+, GPL2+, GPL3+, and GPL2-only... TODO - maintainers = with maintainers; [raskin]; + maintainers = with maintainers; [ raskin ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/de/debian-goodies/package.nix b/pkgs/by-name/de/debian-goodies/package.nix index 6e0fc3a0fb4aba..d6857bfa18281f 100644 --- a/pkgs/by-name/de/debian-goodies/package.nix +++ b/pkgs/by-name/de/debian-goodies/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitLab -, curl -, dialog -, installShellFiles -, perl -, python3 +{ + lib, + stdenv, + fetchFromGitLab, + curl, + dialog, + installShellFiles, + perl, + python3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/de/debianutils/package.nix b/pkgs/by-name/de/debianutils/package.nix index a500ae63de68c3..c6b2c75d88f5fd 100644 --- a/pkgs/by-name/de/debianutils/package.nix +++ b/pkgs/by-name/de/debianutils/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitLab -, autoreconfHook -, perl -, po4a +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + perl, + po4a, }: stdenv.mkDerivation (finalAttrs: { @@ -26,7 +27,10 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; meta = { homepage = "https://packages.debian.org/sid/debianutils"; @@ -39,7 +43,11 @@ stdenv.mkDerivation (finalAttrs: { The specific utilities included are: add-shell installkernel ischroot remove-shell run-parts savelog tempfile which ''; - license = with lib.licenses; [ gpl2Plus publicDomain smail ]; + license = with lib.licenses; [ + gpl2Plus + publicDomain + smail + ]; mainProgram = "ischroot"; maintainers = with lib.maintainers; [ ]; platforms = lib.platforms.all; diff --git a/pkgs/by-name/de/debootstrap/package.nix b/pkgs/by-name/de/debootstrap/package.nix index c22dfdb148655f..83657427129caa 100644 --- a/pkgs/by-name/de/debootstrap/package.nix +++ b/pkgs/by-name/de/debootstrap/package.nix @@ -1,29 +1,31 @@ -{ lib -, stdenv -, fetchFromGitLab -, dpkg -, gawk -, perl -, wget -, binutils -, bzip2 -, coreutils -, util-linux -, gnugrep -, gnupg1 -, gnutar -, gnused -, gzip -, xz -, makeWrapper -, nix-update-script -, testers -, debootstrap +{ + lib, + stdenv, + fetchFromGitLab, + dpkg, + gawk, + perl, + wget, + binutils, + bzip2, + coreutils, + util-linux, + gnugrep, + gnupg1, + gnutar, + gnused, + gzip, + xz, + makeWrapper, + nix-update-script, + testers, + debootstrap, }: # USAGE like this: debootstrap sid /tmp/target-chroot-directory # There is also cdebootstrap now. Is that easier to maintain? -let binPath = lib.makeBinPath [ +let + binPath = lib.makeBinPath [ binutils bzip2 coreutils @@ -38,7 +40,8 @@ let binPath = lib.makeBinPath [ wget xz ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "debootstrap"; version = "1.0.137"; diff --git a/pkgs/by-name/de/debugedit/package.nix b/pkgs/by-name/de/debugedit/package.nix index 8da0effe7be533..a0b5e9b49988e1 100644 --- a/pkgs/by-name/de/debugedit/package.nix +++ b/pkgs/by-name/de/debugedit/package.nix @@ -1,10 +1,23 @@ #TODO@deliciouslytyped The tool seems to unnecessarily force mutable access for the debugedit `-l` feature -{fetchgit, lib, stdenv, autoreconfHook, pkg-config, elfutils, help2man, util-linux}: +{ + fetchgit, + lib, + stdenv, + autoreconfHook, + pkg-config, + elfutils, + help2man, + util-linux, +}: stdenv.mkDerivation rec { pname = "debugedit"; version = "5.0"; - nativeBuildInputs = [ autoreconfHook pkg-config help2man ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + help2man + ]; buildInputs = [ elfutils ]; nativeCheckInputs = [ util-linux ]; # Tests use `rev` diff --git a/pkgs/by-name/de/dec-decode/package.nix b/pkgs/by-name/de/dec-decode/package.nix index 621e119dc0908d..f3146c682a8940 100644 --- a/pkgs/by-name/de/dec-decode/package.nix +++ b/pkgs/by-name/de/dec-decode/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/de/decent-sampler/package.nix b/pkgs/by-name/de/decent-sampler/package.nix index 7e936f69ce0041..c388cef5aa75c3 100644 --- a/pkgs/by-name/de/decent-sampler/package.nix +++ b/pkgs/by-name/de/decent-sampler/package.nix @@ -92,6 +92,9 @@ buildFHSEnv { # that it is released under. license = licenses.unfree; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ adam248 chewblacka ]; + maintainers = with maintainers; [ + adam248 + chewblacka + ]; }; } diff --git a/pkgs/by-name/de/deckmaster/package.nix b/pkgs/by-name/de/deckmaster/package.nix index eb913847221d57..70d1d5fb7c4477 100644 --- a/pkgs/by-name/de/deckmaster/package.nix +++ b/pkgs/by-name/de/deckmaster/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, roboto +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + roboto, }: buildGoModule rec { diff --git a/pkgs/by-name/de/deco/package.nix b/pkgs/by-name/de/deco/package.nix index 5efa22e8843c97..238e7e2810e66a 100644 --- a/pkgs/by-name/de/deco/package.nix +++ b/pkgs/by-name/de/deco/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, scsh, feh, xorg }: +{ + lib, + stdenv, + fetchFromGitHub, + scsh, + feh, + xorg, +}: stdenv.mkDerivation rec { pname = "deco"; diff --git a/pkgs/by-name/de/decode-spam-headers/package.nix b/pkgs/by-name/de/decode-spam-headers/package.nix index 2ccab2956aed81..cb9bf70a67da05 100644 --- a/pkgs/by-name/de/decode-spam-headers/package.nix +++ b/pkgs/by-name/de/decode-spam-headers/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3Packages }: +{ + lib, + stdenv, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "decode-spam-headers"; @@ -13,7 +18,10 @@ python3Packages.buildPythonApplication rec { format = "other"; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; installPhase = '' install -D decode-spam-headers.py $out/bin/decode-spam-headers diff --git a/pkgs/by-name/de/decoder/package.nix b/pkgs/by-name/de/decoder/package.nix index 1463e132bb7281..92478c1ab0d328 100644 --- a/pkgs/by-name/de/decoder/package.nix +++ b/pkgs/by-name/de/decoder/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + openssl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/de/dedup/package.nix b/pkgs/by-name/de/dedup/package.nix index 15daab4751e972..2b90f9b62a5a79 100644 --- a/pkgs/by-name/de/dedup/package.nix +++ b/pkgs/by-name/de/dedup/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchurl, lz4, snappy, libsodium -# For testing -, coreutils, gawk +{ + lib, + stdenv, + fetchurl, + lz4, + snappy, + libsodium, + # For testing + coreutils, + gawk, }: stdenv.mkDerivation rec { @@ -18,17 +25,27 @@ stdenv.mkDerivation rec { "MANPREFIX=${placeholder "out"}/share/man" ]; - buildInputs = [ lz4 snappy libsodium ]; + buildInputs = [ + lz4 + snappy + libsodium + ]; doCheck = true; - nativeCheckInputs = [ coreutils gawk ]; + nativeCheckInputs = [ + coreutils + gawk + ]; checkTarget = "test"; meta = with lib; { description = "Data deduplication program"; homepage = "https://git.2f30.org/dedup/file/README.html"; - license = with licenses; [ bsd0 isc ]; + license = with licenses; [ + bsd0 + isc + ]; maintainers = with maintainers; [ dtzWill ]; }; } diff --git a/pkgs/by-name/de/deepfilternet/package.nix b/pkgs/by-name/de/deepfilternet/package.nix index 0c1ee6bdb2dd68..7294a12500b147 100644 --- a/pkgs/by-name/de/deepfilternet/package.nix +++ b/pkgs/by-name/de/deepfilternet/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -39,7 +40,10 @@ rustPlatform.buildRustPackage rec { meta = { description = "Noise supression using deep filtering"; homepage = "https://github.com/Rikorose/DeepFilterNet"; - license = with lib.licenses; [ mit asl20 ]; + license = with lib.licenses; [ + mit + asl20 + ]; maintainers = with lib.maintainers; [ ralismark ]; changelog = "https://github.com/Rikorose/DeepFilterNet/releases/tag/${src.rev}"; }; diff --git a/pkgs/by-name/de/deepgit/package.nix b/pkgs/by-name/de/deepgit/package.nix index acaf26b2c5c88b..71845d9ee0abaf 100644 --- a/pkgs/by-name/de/deepgit/package.nix +++ b/pkgs/by-name/de/deepgit/package.nix @@ -1,13 +1,14 @@ -{ copyDesktopItems -, fetchurl -, glib -, adwaita-icon-theme -, gtk3 -, jre -, lib -, makeDesktopItem -, stdenv -, wrapGAppsHook3 +{ + copyDesktopItems, + fetchurl, + glib, + adwaita-icon-theme, + gtk3, + jre, + lib, + makeDesktopItem, + stdenv, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -15,7 +16,9 @@ stdenv.mkDerivation rec { version = "4.4"; src = fetchurl { - url = "https://www.syntevo.com/downloads/deepgit/deepgit-linux-${lib.replaceStrings [ "." ] [ "_" ] version}.tar.gz"; + url = "https://www.syntevo.com/downloads/deepgit/deepgit-linux-${ + lib.replaceStrings [ "." ] [ "_" ] version + }.tar.gz"; hash = "sha256-ILqwXDyW7/hZzoSxxaxv4bF5xsB/JFaOBYAJFb7xmdk="; }; @@ -32,31 +35,38 @@ stdenv.mkDerivation rec { preFixup = '' gappsWrapperArgs+=( - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ glib gtk3 ]} + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + glib + gtk3 + ] + } --set DEEPGIT_JAVA_HOME ${jre} ) patchShebangs bin/deepgit.sh ''; - desktopItems = [(makeDesktopItem rec { - name = pname; - desktopName = "DeepGit"; - keywords = [ "git" ]; - comment = "Git-Client"; - categories = [ - "Development" - "RevisionControl" - ]; - terminal = false; - startupNotify = true; - startupWMClass = desktopName; - exec = pname; - mimeTypes = [ - "x-scheme-handler/${pname}" - "x-scheme-handler/sourcetree" - ]; - icon = pname; - })]; + desktopItems = [ + (makeDesktopItem rec { + name = pname; + desktopName = "DeepGit"; + keywords = [ "git" ]; + comment = "Git-Client"; + categories = [ + "Development" + "RevisionControl" + ]; + terminal = false; + startupNotify = true; + startupWMClass = desktopName; + exec = pname; + mimeTypes = [ + "x-scheme-handler/${pname}" + "x-scheme-handler/sourcetree" + ]; + icon = pname; + }) + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/de/deepsea/package.nix b/pkgs/by-name/de/deepsea/package.nix index 2f0a9f175f3958..5fb90e4ab991f6 100644 --- a/pkgs/by-name/de/deepsea/package.nix +++ b/pkgs/by-name/de/deepsea/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/de/deeptools/package.nix b/pkgs/by-name/de/deeptools/package.nix index 2abd0825e6e399..162141847c4407 100644 --- a/pkgs/by-name/de/deeptools/package.nix +++ b/pkgs/by-name/de/deeptools/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { @@ -59,7 +60,10 @@ python3.pkgs.buildPythonApplication rec { publication-ready visualizations to identify enrichments and for functional annotations of the genome. ''; - license = with licenses; [ mit bsd3 ]; + license = with licenses; [ + mit + bsd3 + ]; maintainers = with maintainers; [ scalavision ]; }; } diff --git a/pkgs/by-name/de/deer/package.nix b/pkgs/by-name/de/deer/package.nix index 0d3a6bc9ee61a4..9cee98d1ff4ced 100644 --- a/pkgs/by-name/de/deer/package.nix +++ b/pkgs/by-name/de/deer/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation rec { pname = "deer"; diff --git a/pkgs/by-name/de/deface/package.nix b/pkgs/by-name/de/deface/package.nix index 5b80ed6e2528c3..ff66a7f02cfeb0 100644 --- a/pkgs/by-name/de/deface/package.nix +++ b/pkgs/by-name/de/deface/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, python3 -, fetchFromGitHub -, pkgs +{ + lib, + stdenv, + python3, + fetchFromGitHub, + pkgs, }: python3.pkgs.buildPythonApplication rec { @@ -39,7 +40,11 @@ python3.pkgs.buildPythonApplication rec { ''--prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ pkgs.onnxruntime ]}"'' ]; - pythonImportsCheck = [ "deface" "onnx" "onnxruntime" ]; + pythonImportsCheck = [ + "deface" + "onnx" + "onnxruntime" + ]; meta = { description = "Video anonymization by face detection"; diff --git a/pkgs/by-name/de/degit/package.nix b/pkgs/by-name/de/degit/package.nix index b126569c599129..8d044a9e2f2a0d 100644 --- a/pkgs/by-name/de/degit/package.nix +++ b/pkgs/by-name/de/degit/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/de/deheader/package.nix b/pkgs/by-name/de/deheader/package.nix index 23325c2a02e51f..716de25f2b59b8 100644 --- a/pkgs/by-name/de/deheader/package.nix +++ b/pkgs/by-name/de/deheader/package.nix @@ -1,16 +1,20 @@ -{ lib -, stdenv -, python3 -, xmlto -, docbook-xsl-nons -, fetchFromGitLab -, installShellFiles +{ + lib, + stdenv, + python3, + xmlto, + docbook-xsl-nons, + fetchFromGitLab, + installShellFiles, }: stdenv.mkDerivation rec { pname = "deheader"; version = "1.11"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchFromGitLab { owner = "esr"; @@ -21,7 +25,11 @@ stdenv.mkDerivation rec { buildInputs = [ python3 ]; - nativeBuildInputs = [ xmlto docbook-xsl-nons installShellFiles ]; + nativeBuildInputs = [ + xmlto + docbook-xsl-nons + installShellFiles + ]; # With upstream Makefile, xmlto is called without "--skip-validation". It # makes it require a lot of dependencies, yet ultimately it fails diff --git a/pkgs/by-name/de/dehydrated/package.nix b/pkgs/by-name/de/dehydrated/package.nix index 93a4c4f740d7d4..236b71c8c29a04 100644 --- a/pkgs/by-name/de/dehydrated/package.nix +++ b/pkgs/by-name/de/dehydrated/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, coreutils, curl, diffutils, gawk, gnugrep, gnused, hexdump, openssl, makeWrapper, fetchFromGitHub, installShellFiles }: +{ + lib, + stdenv, + coreutils, + curl, + diffutils, + gawk, + gnugrep, + gnused, + hexdump, + openssl, + makeWrapper, + fetchFromGitHub, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "dehydrated"; version = "0.7.1"; @@ -10,7 +24,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-K08eeruyT5vKzK3PzfCkubZiHbf9Yq7wzD1z69MeDtY="; }; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; installPhase = '' installManPage docs/man/dehydrated.1 @@ -22,7 +39,18 @@ stdenv.mkDerivation rec { mkdir -p $out/bin cp -a dehydrated $out/bin - wrapProgram "$out/bin/dehydrated" --prefix PATH : "${lib.makeBinPath [ openssl coreutils gnused gnugrep diffutils curl gawk hexdump ]}" + wrapProgram "$out/bin/dehydrated" --prefix PATH : "${ + lib.makeBinPath [ + openssl + coreutils + gnused + gnugrep + diffutils + curl + gawk + hexdump + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/de/deja-dup/package.nix b/pkgs/by-name/de/deja-dup/package.nix index 8f4663316b01be..e0e13085bdf1f3 100644 --- a/pkgs/by-name/de/deja-dup/package.nix +++ b/pkgs/by-name/de/deja-dup/package.nix @@ -1,24 +1,26 @@ -{ lib, stdenv -, fetchFromGitLab -, substituteAll -, meson -, ninja -, pkg-config -, vala -, gettext -, itstool -, desktop-file-utils -, glib -, gtk4 -, coreutils -, libsoup_3 -, libsecret -, libadwaita -, wrapGAppsHook4 -, libgpg-error -, json-glib -, duplicity -, rclone +{ + lib, + stdenv, + fetchFromGitLab, + substituteAll, + meson, + ninja, + pkg-config, + vala, + gettext, + itstool, + desktop-file-utils, + glib, + gtk4, + coreutils, + libsoup_3, + libsecret, + libadwaita, + wrapGAppsHook4, + libgpg-error, + json-glib, + duplicity, + rclone, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/de/dejagnu/package.nix b/pkgs/by-name/de/dejagnu/package.nix index 015e7ff991d121..02c25fe2817d6b 100644 --- a/pkgs/by-name/de/dejagnu/package.nix +++ b/pkgs/by-name/de/dejagnu/package.nix @@ -1,4 +1,11 @@ -{ fetchurl, lib, stdenv, expect, makeWrapper, updateAutotoolsGnuConfigScriptsHook }: +{ + fetchurl, + lib, + stdenv, + expect, + makeWrapper, + updateAutotoolsGnuConfigScriptsHook, +}: stdenv.mkDerivation rec { pname = "dejagnu"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "1qx2cv6qkxbiqg87jh217jb62hk3s7dmcs4cz1llm2wmsynfznl7"; }; - nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook makeWrapper ]; + nativeBuildInputs = [ + updateAutotoolsGnuConfigScriptsHook + makeWrapper + ]; buildInputs = [ expect ]; # dejagnu-1.6.3 can't successfully run tests in source tree: diff --git a/pkgs/by-name/de/dejsonlz4/package.nix b/pkgs/by-name/de/dejsonlz4/package.nix index 51c5d485cfa9d3..736470b504102e 100644 --- a/pkgs/by-name/de/dejsonlz4/package.nix +++ b/pkgs/by-name/de/dejsonlz4/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "dejsonlz4"; diff --git a/pkgs/by-name/de/delayarchitect/package.nix b/pkgs/by-name/de/delayarchitect/package.nix index c422549d6617b5..10febc979382b2 100644 --- a/pkgs/by-name/de/delayarchitect/package.nix +++ b/pkgs/by-name/de/delayarchitect/package.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, libGL, libX11, libXext, libXrandr, libXinerama, libXcursor, freetype, alsa-lib, cmake, pkg-config, gcc-unwrapped }: +{ + lib, + stdenv, + fetchFromGitHub, + libGL, + libX11, + libXext, + libXrandr, + libXinerama, + libXcursor, + freetype, + alsa-lib, + cmake, + pkg-config, + gcc-unwrapped, +}: stdenv.mkDerivation rec { pname = "delayarchitect"; @@ -12,10 +27,20 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ - libGL libX11 libXext libXrandr libXinerama libXcursor freetype alsa-lib + libGL + libX11 + libXext + libXrandr + libXinerama + libXcursor + freetype + alsa-lib ]; cmakeFlags = [ diff --git a/pkgs/by-name/de/delfin/package.nix b/pkgs/by-name/de/delfin/package.nix index 6100416ed8d276..05ab8c25203d27 100644 --- a/pkgs/by-name/de/delfin/package.nix +++ b/pkgs/by-name/de/delfin/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, appstream -, cargo -, desktop-file-utils -, fetchFromGitea -, gitUpdater -, gtk4 -, libadwaita -, libepoxy -, libglvnd -, meson -, mpv -, ninja -, openssl -, pkg-config -, rustPlatform -, rustc -, wrapGAppsHook4 +{ + lib, + stdenv, + appstream, + cargo, + desktop-file-utils, + fetchFromGitea, + gitUpdater, + gtk4, + libadwaita, + libepoxy, + libglvnd, + meson, + mpv, + ninja, + openssl, + pkg-config, + rustPlatform, + rustc, + wrapGAppsHook4, }: stdenv.mkDerivation rec { @@ -70,7 +71,10 @@ stdenv.mkDerivation rec { description = "Stream movies and TV shows from Jellyfin"; homepage = "https://www.delfin.avery.cafe/"; license = licenses.gpl3Only; - maintainers = with maintainers; [ colinsane avery ]; + maintainers = with maintainers; [ + colinsane + avery + ]; mainProgram = "delfin"; platforms = platforms.linux; }; diff --git a/pkgs/by-name/de/dell-530cdn/package.nix b/pkgs/by-name/de/dell-530cdn/package.nix index 9cabd8fa3396ba..6c72c3498c9870 100644 --- a/pkgs/by-name/de/dell-530cdn/package.nix +++ b/pkgs/by-name/de/dell-530cdn/package.nix @@ -1,11 +1,18 @@ -{ runCommand, fetchurl, rpm, cpio }: let +{ + runCommand, + fetchurl, + rpm, + cpio, +}: +let version = "1.3-1"; src = fetchurl { url = "http://downloads.dell.com/printer/Dell-5130cdn-Color-Laser-${version}.noarch.rpm"; sha256 = "0pj32sj6jcdnpa5v75af0hnvx4z0ky0m1k2522cfdx4cb1r2lna9"; }; -in runCommand "Dell-5130cdn-Color-Laser-1.3-1" {} '' +in +runCommand "Dell-5130cdn-Color-Laser-1.3-1" { } '' mkdir -p usr/share/cups/model ${rpm}/bin/rpm2cpio ${src} | ${cpio}/bin/cpio -i mkdir -p $out/share/ppd diff --git a/pkgs/by-name/de/dell-command-configure/package.nix b/pkgs/by-name/de/dell-command-configure/package.nix index b22fd6746a9b3c..52e79a25082e32 100644 --- a/pkgs/by-name/de/dell-command-configure/package.nix +++ b/pkgs/by-name/de/dell-command-configure/package.nix @@ -69,11 +69,15 @@ let ''; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { inherit version; pname = "dell-command-configure"; - buildInputs = [ openssl (lib.getLib stdenv.cc.cc) ]; + buildInputs = [ + openssl + (lib.getLib stdenv.cc.cc) + ]; nativeBuildInputs = [ autoPatchelfHook ]; dontConfigure = true; @@ -102,8 +106,7 @@ in stdenv.mkDerivation rec { meta = with lib; { description = "Configure BIOS settings on Dell laptops"; - homepage = - "https://www.dell.com/support/article/us/en/19/sln311302/dell-command-configure"; + homepage = "https://www.dell.com/support/article/us/en/19/sln311302/dell-command-configure"; license = licenses.unfree; maintainers = with maintainers; [ ryangibb ]; platforms = [ "x86_64-linux" ]; diff --git a/pkgs/by-name/de/delly/package.nix b/pkgs/by-name/de/delly/package.nix index bb6845b30a12d7..2bcb0954ad5fc0 100644 --- a/pkgs/by-name/de/delly/package.nix +++ b/pkgs/by-name/de/delly/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, boost -, bzip2 -, htslib -, llvmPackages -, xz -, zlib -, delly -, runCommand +{ + lib, + stdenv, + fetchFromGitHub, + boost, + bzip2, + htslib, + llvmPackages, + xz, + zlib, + delly, + runCommand, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/de/delta/package.nix b/pkgs/by-name/de/delta/package.nix index fbeed74f7b5971..5f74dde527de20 100644 --- a/pkgs/by-name/de/delta/package.nix +++ b/pkgs/by-name/de/delta/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, oniguruma -, stdenv -, apple-sdk_11 -, git +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + oniguruma, + stdenv, + apple-sdk_11, + git, }: rustPlatform.buildRustPackage rec { @@ -27,11 +28,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - oniguruma - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - apple-sdk_11 - ]; + buildInputs = + [ + oniguruma + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + apple-sdk_11 + ]; nativeCheckInputs = [ git ]; @@ -60,7 +63,11 @@ rustPlatform.buildRustPackage rec { description = "Syntax-highlighting pager for git"; changelog = "https://github.com/dandavison/delta/releases/tag/${version}"; license = licenses.mit; - maintainers = with maintainers; [ zowoq SuperSandro2000 figsoda ]; + maintainers = with maintainers; [ + zowoq + SuperSandro2000 + figsoda + ]; mainProgram = "delta"; }; } diff --git a/pkgs/by-name/de/deltachat-cursed/package.nix b/pkgs/by-name/de/deltachat-cursed/package.nix index a8299361d928b8..67b87b7d6e1f4a 100644 --- a/pkgs/by-name/de/deltachat-cursed/package.nix +++ b/pkgs/by-name/de/deltachat-cursed/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3 -, fetchFromGitHub -, testers -, deltachat-cursed +{ + lib, + python3, + fetchFromGitHub, + testers, + deltachat-cursed, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/de/deltachat-repl/package.nix b/pkgs/by-name/de/deltachat-repl/package.nix index 2cf3bc5f42cca7..936c519102ad5c 100644 --- a/pkgs/by-name/de/deltachat-repl/package.nix +++ b/pkgs/by-name/de/deltachat-repl/package.nix @@ -1,12 +1,18 @@ -{ rustPlatform -, libdeltachat -, pkg-config +{ + rustPlatform, + libdeltachat, + pkg-config, }: rustPlatform.buildRustPackage { pname = "deltachat-repl"; - inherit (libdeltachat) version src cargoDeps buildInputs; + inherit (libdeltachat) + version + src + cargoDeps + buildInputs + ; nativeBuildInputs = [ pkg-config @@ -16,7 +22,10 @@ rustPlatform.buildRustPackage { OPENSSL_NO_VENDOR = true; }; - cargoBuildFlags = [ "--package" "deltachat-repl" ]; + cargoBuildFlags = [ + "--package" + "deltachat-repl" + ]; doCheck = false; diff --git a/pkgs/by-name/de/deltachat-rpc-server/package.nix b/pkgs/by-name/de/deltachat-rpc-server/package.nix index 7dfd75ef8f661a..4a0f148ff4421a 100644 --- a/pkgs/by-name/de/deltachat-rpc-server/package.nix +++ b/pkgs/by-name/de/deltachat-rpc-server/package.nix @@ -1,12 +1,18 @@ -{ rustPlatform -, libdeltachat -, pkg-config +{ + rustPlatform, + libdeltachat, + pkg-config, }: rustPlatform.buildRustPackage { pname = "deltachat-rpc-server"; - inherit (libdeltachat) version src cargoDeps buildInputs; + inherit (libdeltachat) + version + src + cargoDeps + buildInputs + ; nativeBuildInputs = [ pkg-config @@ -16,7 +22,10 @@ rustPlatform.buildRustPackage { OPENSSL_NO_VENDOR = true; }; - cargoBuildFlags = [ "--package" "deltachat-rpc-server" ]; + cargoBuildFlags = [ + "--package" + "deltachat-rpc-server" + ]; doCheck = false; diff --git a/pkgs/by-name/de/deltatouch/package.nix b/pkgs/by-name/de/deltatouch/package.nix index f22a776f93db29..810f34ae7d8f4b 100644 --- a/pkgs/by-name/de/deltatouch/package.nix +++ b/pkgs/by-name/de/deltatouch/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitea -, cmake -, intltool -, libdeltachat -, lomiri -, qt5 -, quirc +{ + lib, + stdenv, + fetchFromGitea, + cmake, + intltool, + libdeltachat, + lomiri, + qt5, + quirc, }: stdenv.mkDerivation (finalAttrs: { @@ -22,7 +23,6 @@ stdenv.mkDerivation (finalAttrs: { fetchSubmodules = true; }; - nativeBuildInputs = [ qt5.wrapQtAppsHook intltool diff --git a/pkgs/by-name/de/delve/package.nix b/pkgs/by-name/de/delve/package.nix index a6e73420bc72d4..24fb3e82c73dbe 100644 --- a/pkgs/by-name/de/delve/package.nix +++ b/pkgs/by-name/de/delve/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, makeWrapper, stdenv }: +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + stdenv, +}: buildGoModule rec { pname = "delve"; diff --git a/pkgs/by-name/de/demoit/package.nix b/pkgs/by-name/de/demoit/package.nix index 253642bbdddd17..a67e01f2423982 100644 --- a/pkgs/by-name/de/demoit/package.nix +++ b/pkgs/by-name/de/demoit/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/de/dendrite/package.nix b/pkgs/by-name/de/dendrite/package.nix index bb72aeb170db51..c3c8784cc9089d 100644 --- a/pkgs/by-name/de/dendrite/package.nix +++ b/pkgs/by-name/de/dendrite/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, nix-update-script -, nixosTests -, postgresql -, postgresqlTestHook +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + nix-update-script, + nixosTests, + postgresql, + postgresqlTestHook, }: buildGoModule rec { @@ -58,7 +59,10 @@ buildGoModule rec { inherit (nixosTests) dendrite; }; passthru.updateScript = nix-update-script { - extraArgs = [ "--version-regex" "v(.+)" ]; + extraArgs = [ + "--version-regex" + "v(.+)" + ]; }; meta = with lib; { diff --git a/pkgs/by-name/de/denemo/package.nix b/pkgs/by-name/de/denemo/package.nix index 1a5ce4c77e6e0d..1b4c0e30d46ed4 100644 --- a/pkgs/by-name/de/denemo/package.nix +++ b/pkgs/by-name/de/denemo/package.nix @@ -1,9 +1,31 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config -, libjack2, gettext, intltool, guile, lilypond -, glib, libxml2, librsvg, libsndfile, aubio -, gtk3, gtksourceview, evince, fluidsynth, rubberband -, autoreconfHook, gtk-doc -, portaudio, portmidi, fftw, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + libjack2, + gettext, + intltool, + guile, + lilypond, + glib, + libxml2, + librsvg, + libsndfile, + aubio, + gtk3, + gtksourceview, + evince, + fluidsynth, + rubberband, + autoreconfHook, + gtk-doc, + portaudio, + portmidi, + fftw, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "denemo"; @@ -28,8 +50,22 @@ stdenv.mkDerivation rec { ]; buildInputs = [ - libjack2 guile lilypond glib libxml2 librsvg libsndfile - aubio gtk3 gtksourceview evince fluidsynth rubberband portaudio fftw portmidi + libjack2 + guile + lilypond + glib + libxml2 + librsvg + libsndfile + aubio + gtk3 + gtksourceview + evince + fluidsynth + rubberband + portaudio + fftw + portmidi ]; preFixup = '' diff --git a/pkgs/by-name/de/dependency-track-exporter/package.nix b/pkgs/by-name/de/dependency-track-exporter/package.nix index 8a66db363c2c6b..0cd1ab979defd1 100644 --- a/pkgs/by-name/de/dependency-track-exporter/package.nix +++ b/pkgs/by-name/de/dependency-track-exporter/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/de/deqp-runner/package.nix b/pkgs/by-name/de/deqp-runner/package.nix index cafd083de5286f..b8daa3098022c3 100644 --- a/pkgs/by-name/de/deqp-runner/package.nix +++ b/pkgs/by-name/de/deqp-runner/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitLab, rustPlatform }: +{ + lib, + fetchFromGitLab, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "deqp-runner"; diff --git a/pkgs/by-name/de/der-ascii/package.nix b/pkgs/by-name/de/der-ascii/package.nix index 28cab27731b131..212f190b277744 100644 --- a/pkgs/by-name/de/der-ascii/package.nix +++ b/pkgs/by-name/de/der-ascii/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "der-ascii"; @@ -12,7 +16,10 @@ buildGoModule rec { }; vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = '' @@ -21,7 +28,11 @@ buildGoModule rec { ''; homepage = "https://github.com/google/der-ascii"; license = licenses.asl20; - maintainers = with maintainers; [ alexshpilkin cpu hawkw ]; + maintainers = with maintainers; [ + alexshpilkin + cpu + hawkw + ]; mainProgram = "ascii2der"; # has stable output, unlike its inverse }; } diff --git a/pkgs/by-name/de/design/package.nix b/pkgs/by-name/de/design/package.nix index fc6b5f2fc4b470..bdafc2d99ec735 100644 --- a/pkgs/by-name/de/design/package.nix +++ b/pkgs/by-name/de/design/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, wrapGAppsHook4 -, appstream-glib -, blueprint-compiler -, desktop-file-utils -, meson -, ninja -, pkg-config -, glib -, gjs -, libadwaita +{ + lib, + stdenv, + fetchFromGitHub, + wrapGAppsHook4, + appstream-glib, + blueprint-compiler, + desktop-file-utils, + meson, + ninja, + pkg-config, + glib, + gjs, + libadwaita, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/de/deskew/package.nix b/pkgs/by-name/de/deskew/package.nix index 71ed3051d084f3..9a9d3b20869686 100644 --- a/pkgs/by-name/de/deskew/package.nix +++ b/pkgs/by-name/de/deskew/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, libtiff, fpc }: +{ + lib, + stdenv, + fetchFromGitHub, + libtiff, + fpc, +}: stdenv.mkDerivation rec { @@ -37,8 +43,11 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Command line tool for deskewing scanned text documents"; homepage = "https://galfar.vevb.net/deskew"; - license = with licenses; [ mit mpl11 ]; - maintainers = with maintainers; [ryantm]; + license = with licenses; [ + mit + mpl11 + ]; + maintainers = with maintainers; [ ryantm ]; platforms = platforms.all; mainProgram = "deskew"; }; diff --git a/pkgs/by-name/de/deskreen/package.nix b/pkgs/by-name/de/deskreen/package.nix index 517a38dd37d8e3..255d9b0a309c3c 100644 --- a/pkgs/by-name/de/deskreen/package.nix +++ b/pkgs/by-name/de/deskreen/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, appimageTools +{ + lib, + stdenvNoCC, + fetchurl, + appimageTools, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -38,7 +39,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { homepage = "https://deskreen.com"; license = lib.licenses.agpl3Only; mainProgram = "deskreen"; - maintainers = with lib.maintainers; [ leo248 drupol ]; + maintainers = with lib.maintainers; [ + leo248 + drupol + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/by-name/de/desktop-postflop/package.nix b/pkgs/by-name/de/desktop-postflop/package.nix index 98136e89ea97ba..fb3b8269c9f9f9 100644 --- a/pkgs/by-name/de/desktop-postflop/package.nix +++ b/pkgs/by-name/de/desktop-postflop/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, buildNpmPackage -, fetchFromGitHub -, copyDesktopItems -, makeDesktopItem -, pkg-config -, gtk3 -, libsoup_2_4 -, webkitgtk_4_0 +{ + lib, + rustPlatform, + buildNpmPackage, + fetchFromGitHub, + copyDesktopItems, + makeDesktopItem, + pkg-config, + gtk3, + libsoup_2_4, + webkitgtk_4_0, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/de/desmume/package.nix b/pkgs/by-name/de/desmume/package.nix index 19f28f7962f659..888f9ca3c7f6eb 100644 --- a/pkgs/by-name/de/desmume/package.nix +++ b/pkgs/by-name/de/desmume/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, SDL2 -, agg -, alsa-lib -, desktop-file-utils -, wrapGAppsHook3 -, gtk3 -, intltool -, libGLU -, libXmu -, libpcap -, libtool -, lua -, meson -, ninja -, openal -, pkg-config -, soundtouch -, tinyxml -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + SDL2, + agg, + alsa-lib, + desktop-file-utils, + wrapGAppsHook3, + gtk3, + intltool, + libGLU, + libXmu, + libpcap, + libtool, + lua, + meson, + ninja, + openal, + pkg-config, + soundtouch, + tinyxml, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -30,7 +31,7 @@ stdenv.mkDerivation (finalAttrs: { src = fetchFromGitHub { owner = "TASVideos"; repo = "desmume"; - rev = "release_${lib.replaceStrings ["."] ["_"] finalAttrs.version}"; + rev = "release_${lib.replaceStrings [ "." ] [ "_" ] finalAttrs.version}"; hash = "sha256-vmjKXa/iXLTwtqnG+ZUvOnOQPZROeMpfM5J3Jh/Ynfo="; }; diff --git a/pkgs/by-name/de/desync/package.nix b/pkgs/by-name/de/desync/package.nix index 88fc9be1a9ea0e..eac341a9a7940c 100644 --- a/pkgs/by-name/de/desync/package.nix +++ b/pkgs/by-name/de/desync/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/de/detekt/package.nix b/pkgs/by-name/de/detekt/package.nix index 45ef24e4b1f7cd..1e7d18c15d1750 100644 --- a/pkgs/by-name/de/detekt/package.nix +++ b/pkgs/by-name/de/detekt/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre_headless, testers }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre_headless, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "detekt"; version = "1.23.7"; diff --git a/pkgs/by-name/de/detox/package.nix b/pkgs/by-name/de/detox/package.nix index aa9220da60d192..776845f209d673 100644 --- a/pkgs/by-name/de/detox/package.nix +++ b/pkgs/by-name/de/detox/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, flex, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + flex, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "detox"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-cTuK5EIimRVZ1nfuTa1ds6xrawYIAbwNNIkNONd9y4Q="; }; - nativeBuildInputs = [ flex autoreconfHook ]; + nativeBuildInputs = [ + flex + autoreconfHook + ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/de/devd/package.nix b/pkgs/by-name/de/devd/package.nix index 271f9048db1dca..8d1ea06b40fa10 100644 --- a/pkgs/by-name/de/devd/package.nix +++ b/pkgs/by-name/de/devd/package.nix @@ -1,4 +1,9 @@ -{ buildGoModule, fetchFromGitHub, fetchpatch, lib }: +{ + buildGoModule, + fetchFromGitHub, + fetchpatch, + lib, +}: buildGoModule rec { pname = "devd"; @@ -23,7 +28,10 @@ buildGoModule rec { subPackages = [ "cmd/devd" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Local webserver for developers"; diff --git a/pkgs/by-name/de/devdash/package.nix b/pkgs/by-name/de/devdash/package.nix index a694da0c8029ba..21a605db475fd9 100644 --- a/pkgs/by-name/de/devdash/package.nix +++ b/pkgs/by-name/de/devdash/package.nix @@ -1,9 +1,9 @@ { - lib -, buildGo122Module -, fetchFromGitHub -, nix-update-script -, coreutils + lib, + buildGo122Module, + fetchFromGitHub, + nix-update-script, + coreutils, }: buildGo122Module rec { diff --git a/pkgs/by-name/de/devdocs-desktop/package.nix b/pkgs/by-name/de/devdocs-desktop/package.nix index 21cf63adc89481..a0fb3d6cfffbb1 100644 --- a/pkgs/by-name/de/devdocs-desktop/package.nix +++ b/pkgs/by-name/de/devdocs-desktop/package.nix @@ -1,4 +1,8 @@ -{ lib, appimageTools, fetchurl }: +{ + lib, + appimageTools, + fetchurl, +}: let version = "0.7.2"; @@ -13,7 +17,8 @@ let inherit pname version src; }; -in appimageTools.wrapType2 rec { +in +appimageTools.wrapType2 rec { inherit pname version src; extraInstallCommands = '' diff --git a/pkgs/by-name/de/devede/package.nix b/pkgs/by-name/de/devede/package.nix index 798e64ff837208..b856203e0eae90 100644 --- a/pkgs/by-name/de/devede/package.nix +++ b/pkgs/by-name/de/devede/package.nix @@ -1,9 +1,29 @@ -{ lib, fetchFromGitLab, python3Packages, ffmpeg, mplayer, vcdimager, cdrkit, dvdauthor -, gtk3, gettext, wrapGAppsHook3, gdk-pixbuf, gobject-introspection }: +{ + lib, + fetchFromGitLab, + python3Packages, + ffmpeg, + mplayer, + vcdimager, + cdrkit, + dvdauthor, + gtk3, + gettext, + wrapGAppsHook3, + gdk-pixbuf, + gobject-introspection, +}: let - inherit (python3Packages) dbus-python buildPythonApplication pygobject3 urllib3 setuptools; -in buildPythonApplication rec { + inherit (python3Packages) + dbus-python + buildPythonApplication + pygobject3 + urllib3 + setuptools + ; +in +buildPythonApplication rec { pname = "devede"; version = "4.17.0"; namePrefix = ""; @@ -16,7 +36,8 @@ in buildPythonApplication rec { }; nativeBuildInputs = [ - gettext wrapGAppsHook3 + gettext + wrapGAppsHook3 gobject-introspection ]; @@ -25,7 +46,17 @@ in buildPythonApplication rec { ]; propagatedBuildInputs = [ - gtk3 pygobject3 gdk-pixbuf dbus-python ffmpeg mplayer dvdauthor vcdimager cdrkit urllib3 setuptools + gtk3 + pygobject3 + gdk-pixbuf + dbus-python + ffmpeg + mplayer + dvdauthor + vcdimager + cdrkit + urllib3 + setuptools ]; postPatch = '' diff --git a/pkgs/by-name/de/devenv/package.nix b/pkgs/by-name/de/devenv/package.nix index 5e1ab56f7026c2..6edbaa63d213e2 100644 --- a/pkgs/by-name/de/devenv/package.nix +++ b/pkgs/by-name/de/devenv/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, rustPlatform -, testers -, cachix -, darwin -, sqlx-cli -, nixVersions -, openssl -, pkg-config -, devenv # required to run version test +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + rustPlatform, + testers, + cachix, + darwin, + sqlx-cli, + nixVersions, + openssl, + pkg-config, + devenv, # required to run version test }: let @@ -27,7 +28,8 @@ let }); version = "1.3.1"; -in rustPlatform.buildRustPackage { +in +rustPlatform.buildRustPackage { pname = "devenv"; inherit version; @@ -52,12 +54,18 @@ in rustPlatform.buildRustPackage { cargo sqlx prepare --workspace ''; - nativeBuildInputs = [ makeWrapper pkg-config sqlx-cli ]; - - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration + nativeBuildInputs = [ + makeWrapper + pkg-config + sqlx-cli ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; + postInstall = '' wrapProgram $out/bin/devenv --set DEVENV_NIX ${devenv_nix} --prefix PATH ":" "$out/bin:${cachix}/bin" ''; diff --git a/pkgs/by-name/de/devhelp/package.nix b/pkgs/by-name/de/devhelp/package.nix index 085374e32b5478..9cfa44a0f6df33 100644 --- a/pkgs/by-name/de/devhelp/package.nix +++ b/pkgs/by-name/de/devhelp/package.nix @@ -1,28 +1,32 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, gnome -, adwaita-icon-theme -, gtk3 -, wrapGAppsHook3 -, glib -, gobject-introspection -, gi-docgen -, webkitgtk_4_1 -, gettext -, itstool -, gsettings-desktop-schemas -, shared-mime-info +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + gnome, + adwaita-icon-theme, + gtk3, + wrapGAppsHook3, + glib, + gobject-introspection, + gi-docgen, + webkitgtk_4_1, + gettext, + itstool, + gsettings-desktop-schemas, + shared-mime-info, }: stdenv.mkDerivation rec { pname = "devhelp"; version = "43.0"; - outputs = [ "out" "devdoc" ]; + outputs = [ + "out" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/devhelp/${lib.versions.major version}/devhelp-${version}.tar.xz"; diff --git a/pkgs/by-name/de/devmem2/package.nix b/pkgs/by-name/de/devmem2/package.nix index 88a3877c37f2c2..a31b197e989113 100644 --- a/pkgs/by-name/de/devmem2/package.nix +++ b/pkgs/by-name/de/devmem2/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "devmem2"; @@ -12,7 +16,7 @@ stdenv.mkDerivation { sha256 = "14f1k7v6i1yaxg4xcaaf5i4aqn0yabba857zjnbg9wiymy82qf7c"; }; - hardeningDisable = [ "format" ]; # fix compile error + hardeningDisable = [ "format" ]; # fix compile error buildCommand = '' $CC "$src" -o devmem2 diff --git a/pkgs/by-name/de/devour/package.nix b/pkgs/by-name/de/devour/package.nix index 861eaf905f9d1f..3550652c54b5f3 100644 --- a/pkgs/by-name/de/devour/package.nix +++ b/pkgs/by-name/de/devour/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libX11 }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, +}: stdenv.mkDerivation rec { pname = "devour"; diff --git a/pkgs/by-name/de/devspace/package.nix b/pkgs/by-name/de/devspace/package.nix index 01da33fd7486da..1a28a2992eb5e4 100644 --- a/pkgs/by-name/de/devspace/package.nix +++ b/pkgs/by-name/de/devspace/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, devspace +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + devspace, }: buildGoModule rec { diff --git a/pkgs/by-name/de/devtodo/package.nix b/pkgs/by-name/de/devtodo/package.nix index 1cc83d7fd97978..552f6807d998f0 100644 --- a/pkgs/by-name/de/devtodo/package.nix +++ b/pkgs/by-name/de/devtodo/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, readline, ncurses }: +{ + lib, + stdenv, + fetchurl, + readline, + ncurses, +}: stdenv.mkDerivation rec { pname = "devtodo"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "029y173njydzlznxmdizrrz4wcky47vqhl87fsb7xjcz9726m71p"; }; - buildInputs = [ readline ncurses ]; + buildInputs = [ + readline + ncurses + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/de/dex-oidc/package.nix b/pkgs/by-name/de/dex-oidc/package.nix index 4ca9781eea63e1..df0a6ec66c3994 100644 --- a/pkgs/by-name/de/dex-oidc/package.nix +++ b/pkgs/by-name/de/dex-oidc/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests, testers, dex-oidc }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, + testers, + dex-oidc, +}: buildGoModule rec { pname = "dex"; @@ -18,7 +25,9 @@ buildGoModule rec { ]; ldflags = [ - "-w" "-s" "-X main.version=${src.rev}" + "-w" + "-s" + "-X main.version=${src.rev}" ]; postInstall = '' @@ -39,7 +48,10 @@ buildGoModule rec { description = "OpenID Connect and OAuth2 identity provider with pluggable connectors"; homepage = "https://github.com/dexidp/dex"; license = licenses.asl20; - maintainers = with maintainers; [ benley techknowlogick ]; + maintainers = with maintainers; [ + benley + techknowlogick + ]; mainProgram = "dex"; }; } diff --git a/pkgs/by-name/de/dex/package.nix b/pkgs/by-name/de/dex/package.nix index c602d2c6a24884..eb07b675650849 100644 --- a/pkgs/by-name/de/dex/package.nix +++ b/pkgs/by-name/de/dex/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 -, sphinx +{ + lib, + stdenv, + fetchFromGitHub, + python3, + sphinx, }: stdenv.mkDerivation rec { @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ sphinx ]; buildInputs = [ python3 ]; - makeFlags = [ "PREFIX=$(out)" "VERSION=$(version)" ]; + makeFlags = [ + "PREFIX=$(out)" + "VERSION=$(version)" + ]; meta = with lib; { description = "Program to generate and execute DesktopEntry files of the Application type"; diff --git a/pkgs/by-name/de/dex2jar/package.nix b/pkgs/by-name/de/dex2jar/package.nix index e0ce19dc8d2f8c..5b1bc31b915dbe 100644 --- a/pkgs/by-name/de/dex2jar/package.nix +++ b/pkgs/by-name/de/dex2jar/package.nix @@ -1,21 +1,25 @@ -{ lib -, stdenvNoCC -, fetchurl -, jre -, makeWrapper -, unzip +{ + lib, + stdenvNoCC, + fetchurl, + jre, + makeWrapper, + unzip, }: stdenvNoCC.mkDerivation (finalAttrs: { pname = "dex2jar"; - version = "2.4"; + version = "2.4"; src = fetchurl { url = "https://github.com/pxb1988/dex2jar/releases/download/v${finalAttrs.version}/dex-tools-v${finalAttrs.version}.zip"; hash = "sha256-7nxF6zwdJHSmFF2NRH5lGnNqItlmS209O+WlqBfdojo="; }; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; postPatch = '' rm *.bat @@ -30,7 +34,7 @@ stdenvNoCC.mkDerivation (finalAttrs: { mv * $f for i in $f/*.sh; do n=$(basename ''${i%.sh}) - makeWrapper $i $out/bin/$n --prefix PATH : ${lib.makeBinPath [ jre ] } + makeWrapper $i $out/bin/$n --prefix PATH : ${lib.makeBinPath [ jre ]} done ''; diff --git a/pkgs/by-name/df/dfc/package.nix b/pkgs/by-name/df/dfc/package.nix index 0ad1d745b066cd..53cf879438b977 100644 --- a/pkgs/by-name/df/dfc/package.nix +++ b/pkgs/by-name/df/dfc/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, cmake, gettext}: +{ + lib, + stdenv, + fetchurl, + cmake, + gettext, +}: stdenv.mkDerivation rec { pname = "dfc"; @@ -9,13 +15,16 @@ stdenv.mkDerivation rec { sha256 = "0m1fd7l85ckb7bq4c5c3g257bkjglm8gq7x42pkmpp87fkknc94n"; }; - nativeBuildInputs = [ cmake gettext ]; + nativeBuildInputs = [ + cmake + gettext + ]; meta = { homepage = "https://projects.gw-computing.net/projects/dfc"; description = "Displays file system space usage using graphs and colors"; license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [qknight]; + maintainers = with lib.maintainers; [ qknight ]; platforms = lib.platforms.all; mainProgram = "dfc"; }; diff --git a/pkgs/by-name/df/dfmt/package.nix b/pkgs/by-name/df/dfmt/package.nix index c31335e560f1ad..7c858386e6704d 100644 --- a/pkgs/by-name/df/dfmt/package.nix +++ b/pkgs/by-name/df/dfmt/package.nix @@ -1,12 +1,14 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: let inherit (python3.pkgs) buildPythonApplication - pythonOlder; + pythonOlder + ; in buildPythonApplication rec { pname = "dfmt"; diff --git a/pkgs/by-name/df/dfrs/package.nix b/pkgs/by-name/df/dfrs/package.nix index abef6bb05d675c..a834ac374055ec 100644 --- a/pkgs/by-name/df/dfrs/package.nix +++ b/pkgs/by-name/df/dfrs/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "dfrs"; diff --git a/pkgs/by-name/df/dftd4/package.nix b/pkgs/by-name/df/dftd4/package.nix index 818155cd37268f..57fa3723d3a67f 100644 --- a/pkgs/by-name/df/dftd4/package.nix +++ b/pkgs/by-name/df/dftd4/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, gfortran -, meson -, ninja -, pkg-config -, python3 -, blas -, lapack -, mctc-lib -, mstore -, multicharge +{ + stdenv, + lib, + fetchFromGitHub, + gfortran, + meson, + ninja, + pkg-config, + python3, + blas, + lapack, + mctc-lib, + mstore, + multicharge, }: assert !blas.isILP64 && !lapack.isILP64; @@ -31,11 +32,26 @@ stdenv.mkDerivation rec { ./fortran-module-dir.patch ]; - nativeBuildInputs = [ gfortran meson ninja pkg-config python3 ]; + nativeBuildInputs = [ + gfortran + meson + ninja + pkg-config + python3 + ]; - buildInputs = [ blas lapack mctc-lib mstore multicharge ]; + buildInputs = [ + blas + lapack + mctc-lib + mstore + multicharge + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; doCheck = true; @@ -52,7 +68,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Generally Applicable Atomic-Charge Dependent London Dispersion Correction"; mainProgram = "dftd4"; - license = with licenses; [ lgpl3Plus gpl3Plus ]; + license = with licenses; [ + lgpl3Plus + gpl3Plus + ]; homepage = "https://github.com/grimme-lab/dftd4"; platforms = platforms.linux; maintainers = [ maintainers.sheepforce ]; diff --git a/pkgs/by-name/df/dfu-programmer/package.nix b/pkgs/by-name/df/dfu-programmer/package.nix index a4c091bfbe7e81..215999a051357b 100644 --- a/pkgs/by-name/df/dfu-programmer/package.nix +++ b/pkgs/by-name/df/dfu-programmer/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libusb-compat-0_1 }: +{ + lib, + stdenv, + fetchurl, + libusb-compat-0_1, +}: stdenv.mkDerivation rec { pname = "dfu-programmer"; version = "0.7.2"; diff --git a/pkgs/by-name/df/dfu-util/package.nix b/pkgs/by-name/df/dfu-util/package.nix index 26610c2c78d710..0b77ea470893ef 100644 --- a/pkgs/by-name/df/dfu-util/package.nix +++ b/pkgs/by-name/df/dfu-util/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libusb1 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libusb1, +}: stdenv.mkDerivation rec { pname = "dfu-util"; diff --git a/pkgs/by-name/dg/dgen-sdl/package.nix b/pkgs/by-name/dg/dgen-sdl/package.nix index 172fb567753345..baa76c59a0a2eb 100644 --- a/pkgs/by-name/dg/dgen-sdl/package.nix +++ b/pkgs/by-name/dg/dgen-sdl/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, libarchive -, SDL +{ + lib, + stdenv, + fetchurl, + libarchive, + SDL, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dg/dgoss/package.nix b/pkgs/by-name/dg/dgoss/package.nix index 55014119c8265e..090946d89f96c4 100644 --- a/pkgs/by-name/dg/dgoss/package.nix +++ b/pkgs/by-name/dg/dgoss/package.nix @@ -42,7 +42,10 @@ resholve.mkDerivation rec { description = "Convenience wrapper around goss that aims to bring the simplicity of goss to docker containers"; license = licenses.asl20; platforms = platforms.linux; - maintainers = with maintainers; [ hyzual anthonyroussel ]; + maintainers = with maintainers; [ + hyzual + anthonyroussel + ]; mainProgram = "dgoss"; }; } diff --git a/pkgs/by-name/dg/dgraph/package.nix b/pkgs/by-name/dg/dgraph/package.nix index 1e7babdec14b63..599f3ca4963c46 100644 --- a/pkgs/by-name/dg/dgraph/package.nix +++ b/pkgs/by-name/dg/dgraph/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, jemalloc, nodejs }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + jemalloc, + nodejs, +}: buildGoModule rec { pname = "dgraph"; @@ -27,7 +34,10 @@ buildGoModule rec { # todo those dependencies are required in the makefile, but verify how they are used # actually - buildInputs = [ jemalloc nodejs ]; + buildInputs = [ + jemalloc + nodejs + ]; subPackages = [ "dgraph" ]; diff --git a/pkgs/by-name/dh/dhcpcd/package.nix b/pkgs/by-name/dh/dhcpcd/package.nix index 2e0dbb90d63fc2..4da80eb7d471e3 100644 --- a/pkgs/by-name/dh/dhcpcd/package.nix +++ b/pkgs/by-name/dh/dhcpcd/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, udev -, freebsd -, runtimeShellPackage -, runtimeShell -, nixosTests -, enablePrivSep ? false +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + udev, + freebsd, + runtimeShellPackage, + runtimeShell, + nixosTests, + enablePrivSep ? false, }: stdenv.mkDerivation rec { @@ -22,14 +23,17 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - runtimeShellPackage # So patchShebangs finds a bash suitable for the installed scripts - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - udev - ] ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ - freebsd.libcapsicum - freebsd.libcasper - ]; + buildInputs = + [ + runtimeShellPackage # So patchShebangs finds a bash suitable for the installed scripts + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + udev + ] + ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ + freebsd.libcapsicum + freebsd.libcasper + ]; postPatch = '' substituteInPlace hooks/dhcpcd-run-hooks.in --replace /bin/sh ${runtimeShell} @@ -47,10 +51,15 @@ stdenv.mkDerivation rec { # Hack to make installation succeed. dhcpcd will still use /var/lib # at runtime. - installFlags = [ "DBDIR=$(TMPDIR)/db" "SYSCONFDIR=${placeholder "out"}/etc" ]; + installFlags = [ + "DBDIR=$(TMPDIR)/db" + "SYSCONFDIR=${placeholder "out"}/etc" + ]; # Check that the udev plugin got built. - postInstall = lib.optionalString (udev != null && stdenv.hostPlatform.isLinux) "[ -e ${placeholder "out"}/lib/dhcpcd/dev/udev.so ]"; + postInstall = lib.optionalString ( + udev != null && stdenv.hostPlatform.isLinux + ) "[ -e ${placeholder "out"}/lib/dhcpcd/dev/udev.so ]"; passthru.tests = { inherit (nixosTests.networking.scripted) macvlan dhcpSimple dhcpOneIf; diff --git a/pkgs/by-name/dh/dhcpdump/package.nix b/pkgs/by-name/dh/dhcpdump/package.nix index 979dd0d463f53d..a3391322051002 100644 --- a/pkgs/by-name/dh/dhcpdump/package.nix +++ b/pkgs/by-name/dh/dhcpdump/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, perl -, installShellFiles -, libpcap +{ + lib, + stdenv, + fetchFromGitHub, + perl, + installShellFiles, + libpcap, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dh/dhcpig/package.nix b/pkgs/by-name/dh/dhcpig/package.nix index 679a91e4b0c956..6582556241ae4c 100644 --- a/pkgs/by-name/dh/dhcpig/package.nix +++ b/pkgs/by-name/dh/dhcpig/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/dh/dhcping/package.nix b/pkgs/by-name/dh/dhcping/package.nix index 87c84c5795affa..a25246feea03fd 100644 --- a/pkgs/by-name/dh/dhcping/package.nix +++ b/pkgs/by-name/dh/dhcping/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "dhcping"; diff --git a/pkgs/by-name/dh/dhewm3/package.nix b/pkgs/by-name/dh/dhewm3/package.nix index 81bf7ec2108c61..fe6d3059c1722f 100644 --- a/pkgs/by-name/dh/dhewm3/package.nix +++ b/pkgs/by-name/dh/dhewm3/package.nix @@ -1,5 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, cmake, SDL2, libGLU, libGL, zlib, libjpeg, libogg, libvorbis -, openal, curl, copyDesktopItems, makeDesktopItem }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + SDL2, + libGLU, + libGL, + zlib, + libjpeg, + libogg, + libvorbis, + openal, + curl, + copyDesktopItems, + makeDesktopItem, +}: stdenv.mkDerivation rec { pname = "dhewm3"; @@ -21,8 +36,21 @@ stdenv.mkDerivation rec { cd "$(ls -d dhewm3-*.src)"/neo ''; - nativeBuildInputs = [ cmake copyDesktopItems ]; - buildInputs = [ SDL2 libGLU libGL zlib libjpeg libogg libvorbis openal curl ]; + nativeBuildInputs = [ + cmake + copyDesktopItems + ]; + buildInputs = [ + SDL2 + libGLU + libGL + zlib + libjpeg + libogg + libvorbis + openal + curl + ]; desktopItems = [ (makeDesktopItem { diff --git a/pkgs/by-name/dh/dhex/package.nix b/pkgs/by-name/dh/dhex/package.nix index af6e547e63d398..80cafbb765a207 100644 --- a/pkgs/by-name/dh/dhex/package.nix +++ b/pkgs/by-name/dh/dhex/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "dhex"; @@ -27,7 +32,7 @@ stdenv.mkDerivation rec { description = "Themeable hex editor with diff mode"; homepage = "http://www.dettus.net/dhex/"; license = lib.licenses.gpl2; - maintainers = with lib.maintainers; [qknight]; + maintainers = with lib.maintainers; [ qknight ]; platforms = with lib.platforms; linux; mainProgram = "dhex"; }; diff --git a/pkgs/by-name/dh/dht/package.nix b/pkgs/by-name/dh/dht/package.nix index 6765c029ffe253..17cafd2003387b 100644 --- a/pkgs/by-name/dh/dht/package.nix +++ b/pkgs/by-name/dh/dht/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, cmake }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "dht"; diff --git a/pkgs/by-name/di/dia/package.nix b/pkgs/by-name/di/dia/package.nix index 9977224dd761c9..6331ed8b496bdb 100644 --- a/pkgs/by-name/di/dia/package.nix +++ b/pkgs/by-name/di/dia/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitLab -, appstream-glib -, dblatex -, desktop-file-utils -, graphene -, gtk3 -, gtk-mac-integration-gtk3 -, intltool -, libxml2 -, libxslt -, meson -, ninja -, pkg-config -, poppler -, python3 -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitLab, + appstream-glib, + dblatex, + desktop-file-utils, + graphene, + gtk3, + gtk-mac-integration-gtk3, + intltool, + libxml2, + libxslt, + meson, + ninja, + pkg-config, + poppler, + python3, + wrapGAppsHook3, # Building with docs are still failing in unstable-2023-09-28 -, withDocs ? false + withDocs ? false, }: stdenv.mkDerivation { @@ -39,32 +40,34 @@ stdenv.mkDerivation { patchShebangs . ''; - buildInputs = [ - graphene - gtk3 - libxml2 - python3 - poppler - ] ++ - lib.optionals withDocs [ - libxslt - ] ++ - lib.optionals stdenv.hostPlatform.isDarwin [ - gtk-mac-integration-gtk3 - ]; + buildInputs = + [ + graphene + gtk3 + libxml2 + python3 + poppler + ] + ++ lib.optionals withDocs [ + libxslt + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + gtk-mac-integration-gtk3 + ]; - nativeBuildInputs = [ - appstream-glib - desktop-file-utils - intltool - meson - ninja - pkg-config - wrapGAppsHook3 - ] ++ - lib.optionals withDocs [ - dblatex - ]; + nativeBuildInputs = + [ + appstream-glib + desktop-file-utils + intltool + meson + ninja + pkg-config + wrapGAppsHook3 + ] + ++ lib.optionals withDocs [ + dblatex + ]; meta = with lib; { description = "Gnome Diagram drawing software"; diff --git a/pkgs/by-name/di/dialog/package.nix b/pkgs/by-name/di/dialog/package.nix index 9ef36472993305..a48cd4268796a7 100644 --- a/pkgs/by-name/di/dialog/package.nix +++ b/pkgs/by-name/di/dialog/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, libtool -, ncurses -, enableShared ? !stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isStatic -, unicodeSupport ? true -, withLibrary ? true +{ + lib, + stdenv, + fetchurl, + libtool, + ncurses, + enableShared ? !stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isStatic, + unicodeSupport ? true, + withLibrary ? true, }: assert unicodeSupport -> ncurses.unicodeSupport; @@ -44,7 +45,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Display dialog boxes from shell"; license = lib.licenses.lgpl21Plus; mainProgram = "dialog"; - maintainers = with lib.maintainers; [ AndersonTorres spacefrogg ]; + maintainers = with lib.maintainers; [ + AndersonTorres + spacefrogg + ]; inherit (ncurses.meta) platforms; }; }) diff --git a/pkgs/by-name/di/diamond/package.nix b/pkgs/by-name/di/diamond/package.nix index 314cbd56b67bf2..f1641699804c5b 100644 --- a/pkgs/by-name/di/diamond/package.nix +++ b/pkgs/by-name/di/diamond/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, +}: stdenv.mkDerivation rec { pname = "diamond"; @@ -11,7 +17,6 @@ stdenv.mkDerivation rec { sha256 = "sha256-rNwoHb2jbQwL1bnP5KsI/SsHNN9EeXzsGnMpFhXrc1o="; }; - nativeBuildInputs = [ cmake ]; buildInputs = [ zlib ]; diff --git a/pkgs/by-name/di/dico/package.nix b/pkgs/by-name/di/dico/package.nix index de43d3389b0bfa..584049ef84a547 100644 --- a/pkgs/by-name/di/dico/package.nix +++ b/pkgs/by-name/di/dico/package.nix @@ -1,5 +1,19 @@ -{ fetchurl, lib, stdenv, libtool, gettext, zlib, readline, gsasl -, guile, python3, pcre, libffi, groff, libxcrypt }: +{ + fetchurl, + lib, + stdenv, + libtool, + gettext, + zlib, + readline, + gsasl, + guile, + python3, + pcre, + libffi, + groff, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "dico"; @@ -14,8 +28,18 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ groff ]; - buildInputs = - [ libtool gettext zlib readline gsasl guile python3 pcre libffi libxcrypt ]; + buildInputs = [ + libtool + gettext + zlib + readline + gsasl + guile + python3 + pcre + libffi + libxcrypt + ]; strictDeps = true; @@ -24,10 +48,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Flexible dictionary server and client implementing RFC 2229"; - homepage = "https://www.gnu.org/software/dico/"; - license = licenses.gpl3Plus; + homepage = "https://www.gnu.org/software/dico/"; + license = licenses.gpl3Plus; maintainers = with maintainers; [ lovek323 ]; - platforms = platforms.unix; + platforms = platforms.unix; longDescription = '' GNU Dico is a flexible modular implementation of DICT server diff --git a/pkgs/by-name/di/dict-cc-py/package.nix b/pkgs/by-name/di/dict-cc-py/package.nix index 6742d020cd98c3..3b5316cd633f21 100644 --- a/pkgs/by-name/di/dict-cc-py/package.nix +++ b/pkgs/by-name/di/dict-cc-py/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonPackage rec { diff --git a/pkgs/by-name/di/diction/package.nix b/pkgs/by-name/di/diction/package.nix index be486cccf5496c..e6fb9f5d48bd89 100644 --- a/pkgs/by-name/di/diction/package.nix +++ b/pkgs/by-name/di/diction/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "diction"; diff --git a/pkgs/by-name/di/dictu/package.nix b/pkgs/by-name/di/dictu/package.nix index a178abc70b3e50..a6f2740829708c 100644 --- a/pkgs/by-name/di/dictu/package.nix +++ b/pkgs/by-name/di/dictu/package.nix @@ -1,12 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, sqlite -, httpSupport ? true, curl -, cliSupport ? true -, linenoiseSupport ? cliSupport, linenoise -, enableLTO ? stdenv.cc.isGNU +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + sqlite, + httpSupport ? true, + curl, + cliSupport ? true, + linenoiseSupport ? cliSupport, + linenoise, + enableLTO ? stdenv.cc.isGNU, }: assert enableLTO -> stdenv.cc.isGNU; @@ -24,10 +27,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ - sqlite - ] ++ lib.optional httpSupport curl - ++ lib.optional linenoiseSupport linenoise; + buildInputs = + [ + sqlite + ] + ++ lib.optional httpSupport curl + ++ lib.optional linenoiseSupport linenoise; patches = [ ./0001-force-sqlite-to-be-found.patch @@ -38,14 +43,17 @@ stdenv.mkDerivation rec { -e 's/-flto/${lib.optionalString stdenv.cc.isGNU "-Wno-error=format-truncation"}/' ''; - cmakeFlags = [ - "-DBUILD_CLI=${if cliSupport then "ON" else "OFF"}" - "-DDISABLE_HTTP=${if httpSupport then "OFF" else "ON"}" - "-DDISABLE_LINENOISE=${if linenoiseSupport then "OFF" else "ON"}" - ] ++ lib.optionals enableLTO [ # TODO: LTO with LLVM - "-DCMAKE_AR=${stdenv.cc.cc}/bin/gcc-ar" - "-DCMAKE_RANLIB=${stdenv.cc.cc}/bin/gcc-ranlib" - ]; + cmakeFlags = + [ + "-DBUILD_CLI=${if cliSupport then "ON" else "OFF"}" + "-DDISABLE_HTTP=${if httpSupport then "OFF" else "ON"}" + "-DDISABLE_LINENOISE=${if linenoiseSupport then "OFF" else "ON"}" + ] + ++ lib.optionals enableLTO [ + # TODO: LTO with LLVM + "-DCMAKE_AR=${stdenv.cc.cc}/bin/gcc-ar" + "-DCMAKE_RANLIB=${stdenv.cc.cc}/bin/gcc-ranlib" + ]; postBuild = '' cd .. # move out of cmakeBuildDir @@ -68,14 +76,16 @@ stdenv.mkDerivation rec { ./dictu tests/runTests.du ''; - installPhase = '' - mkdir -p $out - cp -r src/include $out/include - mkdir -p $out/lib - cp build/src/libdictu_api* $out/lib - '' + lib.optionalString cliSupport '' - install -Dm755 dictu $out/bin/dictu - ''; + installPhase = + '' + mkdir -p $out + cp -r src/include $out/include + mkdir -p $out/lib + cp build/src/libdictu_api* $out/lib + '' + + lib.optionalString cliSupport '' + install -Dm755 dictu $out/bin/dictu + ''; meta = with lib; { description = "High-level dynamically typed, multi-paradigm, interpreted programming language"; diff --git a/pkgs/by-name/di/didder/package.nix b/pkgs/by-name/di/didder/package.nix index 3862c15996867a..bb58cde741aa97 100644 --- a/pkgs/by-name/di/didder/package.nix +++ b/pkgs/by-name/di/didder/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, pandoc }: +{ + lib, + buildGoModule, + fetchFromGitHub, + pandoc, +}: buildGoModule rec { pname = "didder"; @@ -25,8 +30,7 @@ buildGoModule rec { ''; meta = src.meta // { - description = - "An extensive, fast, and accurate command-line image dithering tool"; + description = "An extensive, fast, and accurate command-line image dithering tool"; license = lib.licenses.gpl3; maintainers = with lib.maintainers; [ ehmry ]; mainProgram = "didder"; diff --git a/pkgs/by-name/di/didu/package.nix b/pkgs/by-name/di/didu/package.nix index 6db10b058ae559..bdf1b51a7cb80a 100644 --- a/pkgs/by-name/di/didu/package.nix +++ b/pkgs/by-name/di/didu/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitea }: +{ + lib, + rustPlatform, + fetchFromGitea, +}: rustPlatform.buildRustPackage rec { pname = "didu"; diff --git a/pkgs/by-name/di/diebahn/package.nix b/pkgs/by-name/di/diebahn/package.nix index 22cc9374df3b64..a211b180dee51c 100644 --- a/pkgs/by-name/di/diebahn/package.nix +++ b/pkgs/by-name/di/diebahn/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitLab -, cargo -, desktop-file-utils -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, wrapGAppsHook4 -, cairo -, gdk-pixbuf -, glib -, gtk4 -, libadwaita -, pango -, gettext -, darwin -, blueprint-compiler +{ + lib, + stdenv, + fetchFromGitLab, + cargo, + desktop-file-utils, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + wrapGAppsHook4, + cairo, + gdk-pixbuf, + glib, + gtk4, + libadwaita, + pango, + gettext, + darwin, + blueprint-compiler, }: stdenv.mkDerivation rec { @@ -49,18 +50,23 @@ stdenv.mkDerivation rec { blueprint-compiler ]; - buildInputs = [ - cairo - gdk-pixbuf - glib - gtk4 - libadwaita - pango - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - CoreFoundation - Foundation - Security - ]); + buildInputs = + [ + cairo + gdk-pixbuf + glib + gtk4 + libadwaita + pango + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + CoreFoundation + Foundation + Security + ] + ); # Darwin needs to link against gettext from nixpkgs instead of the one vendored by gettext-sys # because the vendored copy does not build with newer versions of clang. @@ -76,6 +82,9 @@ stdenv.mkDerivation rec { homepage = "https://gitlab.com/schmiddi-on-mobile/railway"; license = lib.licenses.gpl3Plus; mainProgram = "diebahn"; - maintainers = with lib.maintainers; [ dotlambda lilacious ]; + maintainers = with lib.maintainers; [ + dotlambda + lilacious + ]; }; } diff --git a/pkgs/by-name/di/dieharder/package.nix b/pkgs/by-name/di/dieharder/package.nix index c7804f0c5f4dfc..2beb0a4d640e94 100644 --- a/pkgs/by-name/di/dieharder/package.nix +++ b/pkgs/by-name/di/dieharder/package.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchurl, gsl -, testers }: +{ + lib, + stdenv, + fetchurl, + gsl, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "dieharder"; diff --git a/pkgs/by-name/di/diesel-cli-ext/package.nix b/pkgs/by-name/di/diesel-cli-ext/package.nix index 7b118b3ce7e079..a4d09dac4df3d8 100644 --- a/pkgs/by-name/di/diesel-cli-ext/package.nix +++ b/pkgs/by-name/di/diesel-cli-ext/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -18,7 +19,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Provides different tools for projects using the diesel_cli"; homepage = "https://crates.io/crates/diesel_cli_ext"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; mainProgram = "diesel_ext"; maintainers = with maintainers; [ siph ]; }; diff --git a/pkgs/by-name/di/diff-so-fancy/package.nix b/pkgs/by-name/di/diff-so-fancy/package.nix index ef9b81f6d031b4..8fdb73636830e3 100644 --- a/pkgs/by-name/di/diff-so-fancy/package.nix +++ b/pkgs/by-name/di/diff-so-fancy/package.nix @@ -1,4 +1,14 @@ -{lib, stdenv, git, perl, ncurses, coreutils, fetchFromGitHub, makeWrapper, ...}: +{ + lib, + stdenv, + git, + perl, + ncurses, + coreutils, + fetchFromGitHub, + makeWrapper, + ... +}: stdenv.mkDerivation rec { pname = "diff-so-fancy"; @@ -52,7 +62,10 @@ stdenv.mkDerivation rec { diff-so-fancy builds on the good-lookin' output of git contrib's diff-highlight to upgrade your diffs' appearances. ''; - maintainers = with maintainers; [ fpletz ma27 ]; + maintainers = with maintainers; [ + fpletz + ma27 + ]; mainProgram = "diff-so-fancy"; }; } diff --git a/pkgs/by-name/di/diffedit3/package.nix b/pkgs/by-name/di/diffedit3/package.nix index 6c342dba52f1eb..49a94fbb9ea02e 100644 --- a/pkgs/by-name/di/diffedit3/package.nix +++ b/pkgs/by-name/di/diffedit3/package.nix @@ -1,5 +1,10 @@ -{ lib, rustPlatform, fetchCrate -, testers, nix-update-script, diffedit3 +{ + lib, + rustPlatform, + fetchCrate, + testers, + nix-update-script, + diffedit3, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/di/diffoci/package.nix b/pkgs/by-name/di/diffoci/package.nix index b2142cfc227e43..26ef0709ec2502 100644 --- a/pkgs/by-name/di/diffoci/package.nix +++ b/pkgs/by-name/di/diffoci/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, buildPackages -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + stdenv, + buildPackages, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -29,7 +30,11 @@ buildGoModule rec { postInstall = let - diffoci = if stdenv.buildPlatform.canExecute stdenv.hostPlatform then placeholder "out" else buildPackages.diffoci; + diffoci = + if stdenv.buildPlatform.canExecute stdenv.hostPlatform then + placeholder "out" + else + buildPackages.diffoci; in '' installShellCompletion --cmd trivy \ diff --git a/pkgs/by-name/di/diffsitter/package.nix b/pkgs/by-name/di/diffsitter/package.nix index 6089af84b44baa..db0d041d4ca71a 100644 --- a/pkgs/by-name/di/diffsitter/package.nix +++ b/pkgs/by-name/di/diffsitter/package.nix @@ -1,34 +1,33 @@ -{ lib -, fetchFromGitHub -, linkFarm -, makeWrapper -, rustPlatform -, tree-sitter -, gitUpdater -, versionCheckHook +{ + lib, + fetchFromGitHub, + linkFarm, + makeWrapper, + rustPlatform, + tree-sitter, + gitUpdater, + versionCheckHook, }: let # based on https://github.com/NixOS/nixpkgs/blob/aa07b78b9606daf1145a37f6299c6066939df075/pkgs/development/tools/parsing/tree-sitter/default.nix#L85-L104 - withPlugins = grammarFn: + withPlugins = + grammarFn: let grammars = grammarFn tree-sitter.builtGrammars; in - linkFarm "grammars" - (map - (drv: - let - name = lib.strings.getName drv; - in - { - name = - "lib" + - (lib.strings.removeSuffix "-grammar" name) - + ".so"; - path = "${drv}/parser"; - } - ) - grammars); + linkFarm "grammars" ( + map ( + drv: + let + name = lib.strings.getName drv; + in + { + name = "lib" + (lib.strings.removeSuffix "-grammar" name) + ".so"; + path = "${drv}/parser"; + } + ) grammars + ); libPath = withPlugins (_: tree-sitter.allGrammars); in diff --git a/pkgs/by-name/di/diffstat/package.nix b/pkgs/by-name/di/diffstat/package.nix index aafe1ad1e91856..e1d8a43e804b90 100644 --- a/pkgs/by-name/di/diffstat/package.nix +++ b/pkgs/by-name/di/diffstat/package.nix @@ -1,4 +1,10 @@ -{ fetchurl, lib, stdenv, zstd, directoryListingUpdater }: +{ + fetchurl, + lib, + stdenv, + zstd, + directoryListingUpdater, +}: stdenv.mkDerivation rec { pname = "diffstat"; diff --git a/pkgs/by-name/di/difftastic/package.nix b/pkgs/by-name/di/difftastic/package.nix index d34b83c46c0f58..e3cb661863b30a 100644 --- a/pkgs/by-name/di/difftastic/package.nix +++ b/pkgs/by-name/di/difftastic/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchpatch -, rustPlatform -, fetchFromGitHub -, testers -, difftastic +{ + lib, + fetchpatch, + rustPlatform, + fetchFromGitHub, + testers, + difftastic, }: let @@ -47,7 +48,11 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/Wilfred/difftastic"; changelog = "https://github.com/Wilfred/difftastic/blob/${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ ethancedwards8 figsoda matthiasbeyer ]; + maintainers = with maintainers; [ + ethancedwards8 + figsoda + matthiasbeyer + ]; mainProgram = "difft"; }; } diff --git a/pkgs/by-name/di/diffuse/package.nix b/pkgs/by-name/di/diffuse/package.nix index a4a9e73db86ed9..41f5c6ba08dacd 100644 --- a/pkgs/by-name/di/diffuse/package.nix +++ b/pkgs/by-name/di/diffuse/package.nix @@ -1,16 +1,18 @@ -{ lib, gitUpdater -, fetchFromGitHub -, meson -, ninja -, gettext -, wrapGAppsHook3 -, gobject-introspection -, pango -, gdk-pixbuf -, python3 -, atk -, gtk3 -, hicolor-icon-theme +{ + lib, + gitUpdater, + fetchFromGitHub, + meson, + ninja, + gettext, + wrapGAppsHook3, + gobject-introspection, + pango, + gdk-pixbuf, + python3, + atk, + gtk3, + hicolor-icon-theme, }: python3.pkgs.buildPythonApplication rec { @@ -59,7 +61,7 @@ python3.pkgs.buildPythonApplication rec { DESTDIR = "/"; makeWrapperArgs = [ - "--prefix XDG_DATA_DIRS : ${hicolor-icon-theme}/share" + "--prefix XDG_DATA_DIRS : ${hicolor-icon-theme}/share" ]; passthru = { diff --git a/pkgs/by-name/di/digestpp/package.nix b/pkgs/by-name/di/digestpp/package.nix index 84d88d8b662335..a817c542f1b698 100644 --- a/pkgs/by-name/di/digestpp/package.nix +++ b/pkgs/by-name/di/digestpp/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, stdenvNoCC +{ + lib, + fetchFromGitHub, + stdenvNoCC, }: stdenvNoCC.mkDerivation { pname = "digestpp"; diff --git a/pkgs/by-name/di/digiham/package.nix b/pkgs/by-name/di/digiham/package.nix index c5f08e1b778a7c..78847bf00236b2 100644 --- a/pkgs/by-name/di/digiham/package.nix +++ b/pkgs/by-name/di/digiham/package.nix @@ -1,5 +1,12 @@ -{ stdenv, lib, fetchFromGitHub -, cmake, protobuf, icu, csdr, codecserver +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + protobuf, + icu, + csdr, + codecserver, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/di/digital/package.nix b/pkgs/by-name/di/digital/package.nix index a929b962481b08..2925915ea9bf51 100644 --- a/pkgs/by-name/di/digital/package.nix +++ b/pkgs/by-name/di/digital/package.nix @@ -1,5 +1,11 @@ -{ lib, fetchFromGitHub, makeDesktopItem, copyDesktopItems, makeWrapper -, jre, maven +{ + lib, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + makeWrapper, + jre, + maven, }: let @@ -15,10 +21,17 @@ let comment = "Easy-to-use digital logic designer and circuit simulator"; exec = pname; icon = pname; - categories = [ "Education" "Electronics" ]; + categories = [ + "Education" + "Electronics" + ]; mimeTypes = [ "text/x-digital" ]; terminal = false; - keywords = [ "simulator" "digital" "circuits" ]; + keywords = [ + "simulator" + "digital" + "circuits" + ]; }; # Use the "no-git-rev" maven profile, which deactivates the plugin that @@ -41,7 +54,10 @@ maven.buildMavenPackage rec { inherit mvnParameters; mvnHash = "sha256-wm/axWJucoW9P98dKqHI4bjrUnmBTfosCOdJg9VBJ+4="; - nativeBuildInputs = [ copyDesktopItems makeWrapper ]; + nativeBuildInputs = [ + copyDesktopItems + makeWrapper + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/di/digitemp/package.nix b/pkgs/by-name/di/digitemp/package.nix index c26968c276c42a..f42c44fbcf5a5b 100644 --- a/pkgs/by-name/di/digitemp/package.nix +++ b/pkgs/by-name/di/digitemp/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, lib, stdenv }: +{ + fetchFromGitHub, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "digitemp"; diff --git a/pkgs/by-name/di/dillo/package.nix b/pkgs/by-name/di/dillo/package.nix index 916d199520ca44..2574e362fd7bad 100644 --- a/pkgs/by-name/di/dillo/package.nix +++ b/pkgs/by-name/di/dillo/package.nix @@ -17,15 +17,17 @@ stdenv, which, # Configurable options - tlsLibrary? "libressl" + tlsLibrary ? "libressl", }: let - ssl = { - "libressl" = libressl; - "mbedtls" = mbedtls; - "openssl" = openssl; - }.${tlsLibrary} or (throw "Unrecognized tlsLibrary option: ${tlsLibrary}"); + ssl = + { + "libressl" = libressl; + "mbedtls" = mbedtls; + "openssl" = openssl; + } + .${tlsLibrary} or (throw "Unrecognized tlsLibrary option: ${tlsLibrary}"); in stdenv.mkDerivation (finalAttrs: { pname = "dillo"; @@ -57,7 +59,11 @@ stdenv.mkDerivation (finalAttrs: { ssl ]; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; strictDeps = true; diff --git a/pkgs/by-name/di/dina-font/package.nix b/pkgs/by-name/di/dina-font/package.nix index 37bf08611f3511..410dd1a0fef5bf 100644 --- a/pkgs/by-name/di/dina-font/package.nix +++ b/pkgs/by-name/di/dina-font/package.nix @@ -1,12 +1,20 @@ -{ lib, stdenv, fetchzip, fontforge -, bdftopcf, xorg +{ + lib, + stdenv, + fetchzip, + fontforge, + bdftopcf, + xorg, }: stdenv.mkDerivation { pname = "dina-font"; version = "2.92"; - outputs = [ "out" "bdf" ]; + outputs = [ + "out" + "bdf" + ]; src = fetchzip { url = "https://www.dcmembers.com/jibsen/download/61/?wpdmdl=61"; @@ -15,8 +23,12 @@ stdenv.mkDerivation { stripRoot = false; }; - nativeBuildInputs = - [ fontforge bdftopcf xorg.mkfontscale xorg.fonttosfnt ]; + nativeBuildInputs = [ + fontforge + bdftopcf + xorg.mkfontscale + xorg.fonttosfnt + ]; buildPhase = '' runHook preBuild @@ -73,6 +85,9 @@ stdenv.mkDerivation { ''; homepage = "https://www.dcmembers.com/jibsen/download/61/"; license = licenses.free; - maintainers = with maintainers; [ prikhi ncfavier ]; + maintainers = with maintainers; [ + prikhi + ncfavier + ]; }; } diff --git a/pkgs/by-name/di/ding-libs/package.nix b/pkgs/by-name/di/ding-libs/package.nix index 211e694f2fdfa9..2f375904165eee 100644 --- a/pkgs/by-name/di/ding-libs/package.nix +++ b/pkgs/by-name/di/ding-libs/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, check }: +{ + lib, + stdenv, + fetchurl, + check, +}: stdenv.mkDerivation rec { pname = "ding-libs"; @@ -19,6 +24,9 @@ stdenv.mkDerivation rec { homepage = "https://pagure.io/SSSD/ding-libs"; platforms = with lib.platforms; linux; maintainers = [ ]; - license = [ lib.licenses.gpl3 lib.licenses.lgpl3 ]; + license = [ + lib.licenses.gpl3 + lib.licenses.lgpl3 + ]; }; } diff --git a/pkgs/by-name/di/diopser/package.nix b/pkgs/by-name/di/diopser/package.nix index cba5d4615b385c..95a93c440967e2 100644 --- a/pkgs/by-name/di/diopser/package.nix +++ b/pkgs/by-name/di/diopser/package.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, pkg-config -, libjack2, alsa-lib, freetype, libX11, libXrandr, libXinerama, libXext, libXcursor +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + libjack2, + alsa-lib, + freetype, + libX11, + libXrandr, + libXinerama, + libXext, + libXcursor, }: let @@ -21,12 +34,12 @@ let owner = "juce-framework"; repo = "JUCE"; rev = "1a5fb5992a1a4e28e998708ed8dce2cc864a30d7"; - sha256= "1ri7w4sz3sy5xilibg53ls9526fx7jwbv8rc54ccrqfhxqyin308"; + sha256 = "1ri7w4sz3sy5xilibg53ls9526fx7jwbv8rc54ccrqfhxqyin308"; }; }; - -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "diopser"; version = "unstable-2021-5-13"; @@ -62,10 +75,19 @@ in stdenv.mkDerivation rec { cp -r Diopser_artefacts/Release/VST3/Diopser.vst3 $out/lib/vst3 ''; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ - libjack2 alsa-lib freetype libX11 libXrandr libXinerama libXext + libjack2 + alsa-lib + freetype + libX11 + libXrandr + libXinerama + libXext libXcursor ]; diff --git a/pkgs/by-name/di/dipc/package.nix b/pkgs/by-name/di/dipc/package.nix index 4f8ab5fde7dec9..1c4668143531d2 100644 --- a/pkgs/by-name/di/dipc/package.nix +++ b/pkgs/by-name/di/dipc/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Convert your favorite images and wallpapers with your favorite color palettes/themes"; homepage = "https://github.com/doprz/dipc"; - license = with licenses; [ mit asl20 ]; + license = with licenses; [ + mit + asl20 + ]; maintainers = with maintainers; [ ByteSudoer ]; mainProgram = "dipc"; }; diff --git a/pkgs/by-name/di/dirb/package.nix b/pkgs/by-name/di/dirb/package.nix index 9165d4db383d1f..c0093d37919348 100644 --- a/pkgs/by-name/di/dirb/package.nix +++ b/pkgs/by-name/di/dirb/package.nix @@ -1,9 +1,16 @@ -{ fetchurl, lib, stdenv, autoreconfHook, curl }: +{ + fetchurl, + lib, + stdenv, + autoreconfHook, + curl, +}: let major = "2"; minor = "22"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "dirb"; version = "${major}.${minor}"; diff --git a/pkgs/by-name/di/dirbuster/package.nix b/pkgs/by-name/di/dirbuster/package.nix index 59b41efab6ea79..895d74e19a87db 100644 --- a/pkgs/by-name/di/dirbuster/package.nix +++ b/pkgs/by-name/di/dirbuster/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, makeBinaryWrapper -, copyDesktopItems -, makeDesktopItem -, unzip -, jdk8 +{ + lib, + stdenv, + fetchurl, + makeBinaryWrapper, + copyDesktopItems, + makeDesktopItem, + unzip, + jdk8, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/di/dirdiff/package.nix b/pkgs/by-name/di/dirdiff/package.nix index c0347aface0942..0fd816a12bc4ec 100644 --- a/pkgs/by-name/di/dirdiff/package.nix +++ b/pkgs/by-name/di/dirdiff/package.nix @@ -1,4 +1,12 @@ -{ copyDesktopItems, fetchurl, lib, makeDesktopItem, stdenv, tcl, tk }: +{ + copyDesktopItems, + fetchurl, + lib, + makeDesktopItem, + stdenv, + tcl, + tk, +}: stdenv.mkDerivation rec { pname = "dirdiff"; @@ -10,7 +18,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ copyDesktopItems ]; - buildInputs = [ tcl tk ]; + buildInputs = [ + tcl + tk + ]; # Some light path patching. patches = [ ./dirdiff-2.1-vars.patch ]; diff --git a/pkgs/by-name/di/directfb/package.nix b/pkgs/by-name/di/directfb/package.nix index d761804cac23ff..d2506fd97e817e 100644 --- a/pkgs/by-name/di/directfb/package.nix +++ b/pkgs/by-name/di/directfb/package.nix @@ -1,8 +1,22 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch -, autoreconfHook, perl, pkg-config, flux, zlib -, libjpeg, freetype, libpng, giflib -, enableX11 ? true, xorg -, enableSDL ? true, SDL }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + perl, + pkg-config, + flux, + zlib, + libjpeg, + freetype, + libpng, + giflib, + enableX11 ? true, + xorg, + enableSDL ? true, + SDL, +}: stdenv.mkDerivation rec { pname = "directfb"; @@ -11,7 +25,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "deniskropp"; repo = "DirectFB"; - rev = "DIRECTFB_${lib.replaceStrings ["."] ["_"] version}"; + rev = "DIRECTFB_${lib.replaceStrings [ "." ] [ "_" ] version}"; sha256 = "0bs3yzb7hy3mgydrj8ycg7pllrd2b6j0gxj596inyr7ihssr3i0y"; }; @@ -42,48 +56,69 @@ stdenv.mkDerivation rec { }) ]; - postPatch = '' - # https://github.com/deniskropp/DirectFB/blob/master/src/core/Makefile.am#L15 - # BUILDTIME is embedded in the result - # if switching to cmake then a similar substitution has to be done - substituteInPlace src/core/Makefile.am \ - --replace '`date -u "+%Y-%m-%d %H:%M"`' "`date -u \"+%Y-%m-%d %H:%M\" --date="@''${SOURCE_DATE_EPOCH}"`" - '' + lib.optionalString stdenv.hostPlatform.isMusl '' - # Specifically patch out two drivers that have build errors with musl libc, - # while leaving the rest of the default selection enabled - substituteInPlace configure.in \ - --replace checkfor_lirc={yes,no} \ - --replace checkfor_matrox={yes,no} - ''; + postPatch = + '' + # https://github.com/deniskropp/DirectFB/blob/master/src/core/Makefile.am#L15 + # BUILDTIME is embedded in the result + # if switching to cmake then a similar substitution has to be done + substituteInPlace src/core/Makefile.am \ + --replace '`date -u "+%Y-%m-%d %H:%M"`' "`date -u \"+%Y-%m-%d %H:%M\" --date="@''${SOURCE_DATE_EPOCH}"`" + '' + + lib.optionalString stdenv.hostPlatform.isMusl '' + # Specifically patch out two drivers that have build errors with musl libc, + # while leaving the rest of the default selection enabled + substituteInPlace configure.in \ + --replace checkfor_lirc={yes,no} \ + --replace checkfor_matrox={yes,no} + ''; - nativeBuildInputs = [ autoreconfHook perl pkg-config flux ]; + nativeBuildInputs = [ + autoreconfHook + perl + pkg-config + flux + ]; - buildInputs = [ zlib libjpeg freetype giflib libpng ] + buildInputs = + [ + zlib + libjpeg + freetype + giflib + libpng + ] ++ lib.optional enableSDL SDL - ++ lib.optionals enableX11 (with xorg; [ - xorgproto libX11 libXext - libXrender - ]); + ++ lib.optionals enableX11 ( + with xorg; + [ + xorgproto + libX11 + libXext + libXrender + ] + ); - env = { - NIX_LDFLAGS = "-lgcc_s"; - } // lib.optionalAttrs stdenv.cc.isGNU { - NIX_CFLAGS_COMPILE = "-fpermissive"; - }; + env = + { + NIX_LDFLAGS = "-lgcc_s"; + } + // lib.optionalAttrs stdenv.cc.isGNU { + NIX_CFLAGS_COMPILE = "-fpermissive"; + }; - configureFlags = [ - "--enable-sdl" - "--enable-zlib" - "--with-gfxdrivers=all" - "--enable-devmem" - "--enable-fbdev" - "--enable-mmx" - "--enable-sse" - "--with-software" - ] + configureFlags = + [ + "--enable-sdl" + "--enable-zlib" + "--with-gfxdrivers=all" + "--enable-devmem" + "--enable-fbdev" + "--enable-mmx" + "--enable-sse" + "--with-software" + ] ++ lib.optional (!stdenv.hostPlatform.isMusl) "--with-smooth-scaling" - ++ lib.optional enableX11 "--enable-x11" - ; + ++ lib.optional enableX11 "--enable-x11"; # Disable parallel building as parallel builds fail due to incomplete # depends between autogenerated CoreSlave.h and it's include sites: diff --git a/pkgs/by-name/di/directvnc/package.nix b/pkgs/by-name/di/directvnc/package.nix index 5ec40370bbbaa1..d37ffa86ae3565 100644 --- a/pkgs/by-name/di/directvnc/package.nix +++ b/pkgs/by-name/di/directvnc/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, pkg-config, directfb, zlib, libjpeg, xorgproto }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + directfb, + zlib, + libjpeg, + xorgproto, +}: stdenv.mkDerivation { pname = "directvnc"; @@ -22,9 +33,17 @@ stdenv.mkDerivation { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ directfb zlib libjpeg xorgproto ]; + buildInputs = [ + directfb + zlib + libjpeg + xorgproto + ]; meta = with lib; { description = "DirectFB VNC client"; diff --git a/pkgs/by-name/di/directx-headers/package.nix b/pkgs/by-name/di/directx-headers/package.nix index f1830f54035efd..0acb2db0edc0e8 100644 --- a/pkgs/by-name/di/directx-headers/package.nix +++ b/pkgs/by-name/di/directx-headers/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, +}: stdenv.mkDerivation rec { pname = "directx-headers"; version = "1.614.1"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { hash = "sha256-CDmzKdV40EExLpOHPAUnytqG9x1+IGW4AZldfYs5YJk="; }; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; # tests require WSL2 mesonFlags = [ "-Dbuild-test=false" ]; diff --git a/pkgs/by-name/di/direnv/package.nix b/pkgs/by-name/di/direnv/package.nix index 6ff13328ebbf21..b2ef901d02b068 100644 --- a/pkgs/by-name/di/direnv/package.nix +++ b/pkgs/by-name/di/direnv/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, buildGoModule, bash, fish, zsh }: +{ + lib, + stdenv, + fetchFromGitHub, + buildGoModule, + bash, + fish, + zsh, +}: buildGoModule rec { pname = "direnv"; @@ -14,9 +22,7 @@ buildGoModule rec { vendorHash = "sha256-O2NZgWn00uKLstYPIj9LwyF4kmitJ1FXltazv8RrmZg="; # we have no bash at the moment for windows - BASH_PATH = - lib.optionalString (!stdenv.hostPlatform.isWindows) - "${bash}/bin/bash"; + BASH_PATH = lib.optionalString (!stdenv.hostPlatform.isWindows) "${bash}/bin/bash"; # replace the build phase to use the GNUMakefile instead buildPhase = '' @@ -27,7 +33,10 @@ buildGoModule rec { make install PREFIX=$out ''; - nativeCheckInputs = [ fish zsh ]; + nativeCheckInputs = [ + fish + zsh + ]; checkPhase = '' export HOME=$(mktemp -d) diff --git a/pkgs/by-name/di/direvent/package.nix b/pkgs/by-name/di/direvent/package.nix index 3e3de9f26676e0..0b776f44124b8a 100644 --- a/pkgs/by-name/di/direvent/package.nix +++ b/pkgs/by-name/di/direvent/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/di/dirstalk/package.nix b/pkgs/by-name/di/dirstalk/package.nix index d0cdc4b4813495..a1bc915da1d598 100644 --- a/pkgs/by-name/di/dirstalk/package.nix +++ b/pkgs/by-name/di/dirstalk/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, }: buildGoModule rec { diff --git a/pkgs/by-name/di/dirt/package.nix b/pkgs/by-name/di/dirt/package.nix index 6b3ea6320638c2..1791a0a6c31a56 100644 --- a/pkgs/by-name/di/dirt/package.nix +++ b/pkgs/by-name/di/dirt/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, libsndfile, libsamplerate, liblo, libjack2 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + libsndfile, + libsamplerate, + liblo, + libjack2, +}: stdenv.mkDerivation { pname = "dirt"; @@ -19,11 +28,16 @@ stdenv.mkDerivation { sha256 = "08r34ylzs31wwf0la995pb149ccq0vr7qg4792pkhca57zi0bff8"; }) ]; - buildInputs = [ libsndfile libsamplerate liblo libjack2 ]; + buildInputs = [ + libsndfile + libsamplerate + liblo + libjack2 + ]; postPatch = '' sed -i "s|./samples|$out/share/dirt/samples|" dirt.c ''; - makeFlags = ["PREFIX=$(out)"]; + makeFlags = [ "PREFIX=$(out)" ]; postInstall = '' mkdir -p $out/share/dirt/ cp -r samples $out/share/dirt/ diff --git a/pkgs/by-name/di/dirvish/package.nix b/pkgs/by-name/di/dirvish/package.nix index 4f99e60f4dbe09..432662f0fd1afd 100644 --- a/pkgs/by-name/di/dirvish/package.nix +++ b/pkgs/by-name/di/dirvish/package.nix @@ -1,4 +1,11 @@ -{ fetchurl, lib, stdenv, makeWrapper, perl, perlPackages }: +{ + fetchurl, + lib, + stdenv, + makeWrapper, + perl, + perlPackages, +}: stdenv.mkDerivation rec { pname = "dirvish"; @@ -10,10 +17,27 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ perl ] ++ (with perlPackages; [ GetoptLong TimeParseDate TimePeriod ]); + buildInputs = + [ perl ] + ++ (with perlPackages; [ + GetoptLong + TimeParseDate + TimePeriod + ]); - executables = [ "dirvish" "dirvish-runall" "dirvish-expire" "dirvish-locate" ]; - manpages = [ "dirvish.8" "dirvish-runall.8" "dirvish-expire.8" "dirvish-locate.8" "dirvish.conf.5" ]; + executables = [ + "dirvish" + "dirvish-runall" + "dirvish-expire" + "dirvish-locate" + ]; + manpages = [ + "dirvish.8" + "dirvish-runall.8" + "dirvish-expire.8" + "dirvish-locate.8" + "dirvish.conf.5" + ]; buildPhase = '' HEADER="#!${perl}/bin/perl diff --git a/pkgs/by-name/di/disarchive/package.nix b/pkgs/by-name/di/disarchive/package.nix index 8b908d40a65989..a009cd411cc6b1 100644 --- a/pkgs/by-name/di/disarchive/package.nix +++ b/pkgs/by-name/di/disarchive/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchurl -, guile -, autoreconfHook -, guile-gcrypt -, guile-lzma -, guile-quickcheck -, makeWrapper -, pkg-config -, zlib +{ + stdenv, + lib, + fetchurl, + guile, + autoreconfHook, + guile-gcrypt, + guile-lzma, + guile-quickcheck, + makeWrapper, + pkg-config, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/di/discocss/package.nix b/pkgs/by-name/di/discocss/package.nix index 102b75aee71f34..e63d512d944e3d 100644 --- a/pkgs/by-name/di/discocss/package.nix +++ b/pkgs/by-name/di/discocss/package.nix @@ -1,9 +1,10 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, discordAlias ? false -, discord -, makeWrapper +{ + stdenvNoCC, + lib, + fetchFromGitHub, + discordAlias ? false, + discord, + makeWrapper, }: stdenvNoCC.mkDerivation rec { @@ -21,15 +22,17 @@ stdenvNoCC.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; - installPhase = '' - install -Dm755 discocss $out/bin/discocss - '' + lib.optionalString discordAlias '' - wrapProgram $out/bin/discocss --set DISCOCSS_DISCORD_BIN ${discord}/bin/Discord - ln -s $out/bin/discocss $out/bin/Discord - ln -s $out/bin/discocss $out/bin/discord - mkdir -p $out/share - ln -s ${discord}/share/* $out/share - ''; + installPhase = + '' + install -Dm755 discocss $out/bin/discocss + '' + + lib.optionalString discordAlias '' + wrapProgram $out/bin/discocss --set DISCOCSS_DISCORD_BIN ${discord}/bin/Discord + ln -s $out/bin/discocss $out/bin/Discord + ln -s $out/bin/discocss $out/bin/discord + mkdir -p $out/share + ln -s ${discord}/share/* $out/share + ''; meta = with lib; { description = "Tiny Discord css-injector"; diff --git a/pkgs/by-name/di/discord-sh/package.nix b/pkgs/by-name/di/discord-sh/package.nix index cb6821ab4bc889..7276a9529d3b62 100644 --- a/pkgs/by-name/di/discord-sh/package.nix +++ b/pkgs/by-name/di/discord-sh/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenvNoCC, fetchFromGitHub, makeWrapper, curl, jq, coreutils, file }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + makeWrapper, + curl, + jq, + coreutils, + file, +}: stdenvNoCC.mkDerivation rec { pname = "discord-sh"; @@ -36,7 +45,14 @@ stdenvNoCC.mkDerivation rec { runHook preInstall install -Dm555 discord.sh $out/bin/discord.sh wrapProgram $out/bin/discord.sh \ - --set PATH "${lib.makeBinPath [ curl jq coreutils file ]}" + --set PATH "${ + lib.makeBinPath [ + curl + jq + coreutils + file + ] + }" runHook postInstall ''; diff --git a/pkgs/by-name/di/discount/package.nix b/pkgs/by-name/di/discount/package.nix index d2219955d3dce5..adc433eb489466 100644 --- a/pkgs/by-name/di/discount/package.nix +++ b/pkgs/by-name/di/discount/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { version = "3.0.0d"; diff --git a/pkgs/by-name/di/discourse-mail-receiver/package.nix b/pkgs/by-name/di/discourse-mail-receiver/package.nix index b44f5eb113c1dc..40fa65bdb5b4d1 100644 --- a/pkgs/by-name/di/discourse-mail-receiver/package.nix +++ b/pkgs/by-name/di/discourse-mail-receiver/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, ruby, makeWrapper, replace }: +{ + stdenv, + lib, + fetchFromGitHub, + ruby, + makeWrapper, + replace, +}: stdenv.mkDerivation rec { pname = "discourse-mail-receiver"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-ob4Hb88odlFf5vSC9qhikhJowo4C5LksVmMuJRMNoI4="; }; - nativeBuildInputs = [ replace makeWrapper ]; + nativeBuildInputs = [ + replace + makeWrapper + ]; buildInputs = [ ruby ]; dontBuild = true; diff --git a/pkgs/by-name/di/discover-overlay/package.nix b/pkgs/by-name/di/discover-overlay/package.nix index 4488c4953336fc..4d400b97d4c2bd 100644 --- a/pkgs/by-name/di/discover-overlay/package.nix +++ b/pkgs/by-name/di/discover-overlay/package.nix @@ -1,4 +1,12 @@ -{ lib, python3, fetchFromGitHub, gtk3, gobject-introspection, gtk-layer-shell, wrapGAppsHook3 }: +{ + lib, + python3, + fetchFromGitHub, + gtk3, + gobject-introspection, + gtk-layer-shell, + wrapGAppsHook3, +}: python3.pkgs.buildPythonApplication rec { pname = "discover-overlay"; version = "0.7.8"; @@ -11,7 +19,10 @@ python3.pkgs.buildPythonApplication rec { hash = "sha256-0b0uZDa9Q3pQ6X65C+E31dMpdTPt4vvHDEqFEtRoedg="; }; - buildInputs = [ gtk3 gtk-layer-shell ]; + buildInputs = [ + gtk3 + gtk-layer-shell + ]; nativeBuildInputs = [ gobject-introspection @@ -20,7 +31,10 @@ python3.pkgs.buildPythonApplication rec { dontWrapGApps = true; - makeWrapperArgs = [ "\${gappsWrapperArgs[@]}" "--set DISPLAY ':0.0'" ]; + makeWrapperArgs = [ + "\${gappsWrapperArgs[@]}" + "--set DISPLAY ':0.0'" + ]; propagatedBuildInputs = with python3.pkgs; [ pulsectl-asyncio diff --git a/pkgs/by-name/di/disfetch/package.nix b/pkgs/by-name/di/disfetch/package.nix index 6cd7a2683d604f..a1ebd5275efee6 100644 --- a/pkgs/by-name/di/disfetch/package.nix +++ b/pkgs/by-name/di/disfetch/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "disfetch"; diff --git a/pkgs/by-name/di/disk-filltest/package.nix b/pkgs/by-name/di/disk-filltest/package.nix index 5d97977aab0144..d66357c405403c 100644 --- a/pkgs/by-name/di/disk-filltest/package.nix +++ b/pkgs/by-name/di/disk-filltest/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation (finalAttrs: { @@ -14,7 +15,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-cppofTzzJHrvG5SsafKgvCIiHc6E5740NyQdWWZxrGI="; }; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" diff --git a/pkgs/by-name/di/disk-inventory-x/package.nix b/pkgs/by-name/di/disk-inventory-x/package.nix index 2ed895eeb3d20c..bb64c955b80ac1 100644 --- a/pkgs/by-name/di/disk-inventory-x/package.nix +++ b/pkgs/by-name/di/disk-inventory-x/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, undmg +{ + lib, + stdenvNoCC, + fetchurl, + undmg, }: stdenvNoCC.mkDerivation (finalAttrs: { pname = "disk-inventory-x"; diff --git a/pkgs/by-name/di/disk_indicator/package.nix b/pkgs/by-name/di/disk_indicator/package.nix index 4eef4fdb112001..1f2e4d3b6f5531 100644 --- a/pkgs/by-name/di/disk_indicator/package.nix +++ b/pkgs/by-name/di/disk_indicator/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libX11 }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, +}: stdenv.mkDerivation { pname = "disk-indicator"; diff --git a/pkgs/by-name/di/disko/package.nix b/pkgs/by-name/di/disko/package.nix index 8e580594efec87..32164ba9c680e6 100644 --- a/pkgs/by-name/di/disko/package.nix +++ b/pkgs/by-name/di/disko/package.nix @@ -1,12 +1,13 @@ -{ stdenvNoCC -, makeWrapper -, lib -, fetchFromGitHub -, bash -, nix -, nixos-install -, coreutils -, testers +{ + stdenvNoCC, + makeWrapper, + lib, + fetchFromGitHub, + bash, + nix, + nixos-install, + coreutils, + testers, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -30,7 +31,13 @@ stdenvNoCC.mkDerivation (finalAttrs: { chmod 755 "$out/bin/$i" wrapProgram "$out/bin/$i" \ --set DISKO_VERSION "${finalAttrs.version}" \ - --prefix PATH : ${lib.makeBinPath [ nix coreutils nixos-install ]} + --prefix PATH : ${ + lib.makeBinPath [ + nix + coreutils + nixos-install + ] + } done runHook postInstall ''; @@ -49,7 +56,11 @@ stdenvNoCC.mkDerivation (finalAttrs: { description = "Declarative disk partitioning and formatting using nix"; license = lib.licenses.mit; mainProgram = "disko"; - maintainers = with lib.maintainers; [ mic92 lassulus iFreilicht ]; + maintainers = with lib.maintainers; [ + mic92 + lassulus + iFreilicht + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/by-name/di/diskonaut/package.nix b/pkgs/by-name/di/diskonaut/package.nix index fa9d7f00a83b70..36ddb1488f9768 100644 --- a/pkgs/by-name/di/diskonaut/package.nix +++ b/pkgs/by-name/di/diskonaut/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "diskonaut"; @@ -20,7 +25,10 @@ rustPlatform.buildRustPackage rec { description = "Terminal disk space navigator"; homepage = "https://github.com/imsnif/diskonaut"; license = licenses.mit; - maintainers = with maintainers; [ evanjs figsoda ]; + maintainers = with maintainers; [ + evanjs + figsoda + ]; mainProgram = "diskonaut"; }; } diff --git a/pkgs/by-name/di/diskrsync/package.nix b/pkgs/by-name/di/diskrsync/package.nix index 5506a197fd1d10..94b2c5a0f495bb 100644 --- a/pkgs/by-name/di/diskrsync/package.nix +++ b/pkgs/by-name/di/diskrsync/package.nix @@ -1,4 +1,10 @@ -{ buildGoModule, fetchFromGitHub, lib, openssh, makeWrapper }: +{ + buildGoModule, + fetchFromGitHub, + lib, + openssh, + makeWrapper, +}: buildGoModule rec { pname = "diskrsync"; @@ -13,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-lJaM/sC5/qmmo7Zu7nGR6ZdXa1qw4SuVxawQ+d/m+Aw="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/by-name/di/diskscan/package.nix b/pkgs/by-name/di/diskscan/package.nix index 7471089f45f9e1..bbb737a7d49828 100644 --- a/pkgs/by-name/di/diskscan/package.nix +++ b/pkgs/by-name/di/diskscan/package.nix @@ -1,17 +1,27 @@ -{ lib, stdenv, fetchFromGitHub, cmake, ncurses, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ncurses, + zlib, +}: stdenv.mkDerivation rec { pname = "diskscan"; version = "0.21"; src = fetchFromGitHub { - owner = "baruch"; - repo = "diskscan"; - rev = version; + owner = "baruch"; + repo = "diskscan"; + rev = version; sha256 = "sha256-2y1ncPg9OKxqImBN5O5kXrTsuwZ/Cg/8exS7lWyZY1c="; }; - buildInputs = [ ncurses zlib ]; + buildInputs = [ + ncurses + zlib + ]; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/by-name/di/dislocker/package.nix b/pkgs/by-name/di/dislocker/package.nix index f73c49d9799ec4..d84ae19dbb0d23 100644 --- a/pkgs/by-name/di/dislocker/package.nix +++ b/pkgs/by-name/di/dislocker/package.nix @@ -1,13 +1,14 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, mbedtls_2 -, fuse +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + mbedtls_2, + fuse, }: - stdenv.mkDerivation rec { pname = "dislocker"; version = "0.7.3"; @@ -32,14 +33,20 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ fuse mbedtls_2 ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + fuse + mbedtls_2 + ]; meta = with lib; { description = "Read BitLocker encrypted partitions in Linux"; - homepage = "https://github.com/aorimn/dislocker"; - license = licenses.gpl2Plus; + homepage = "https://github.com/aorimn/dislocker"; + license = licenses.gpl2Plus; maintainers = with maintainers; [ elitak ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/di/dismap/package.nix b/pkgs/by-name/di/dismap/package.nix index d80e853dae62d9..4d84aed8961d83 100644 --- a/pkgs/by-name/di/dismap/package.nix +++ b/pkgs/by-name/di/dismap/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/di/dismember/package.nix b/pkgs/by-name/di/dismember/package.nix index cb2dd99b45c577..e8f09eb8f89bab 100644 --- a/pkgs/by-name/di/dismember/package.nix +++ b/pkgs/by-name/di/dismember/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/di/disnixos/package.nix b/pkgs/by-name/di/disnixos/package.nix index 15e5f3e0e94780..23efd2ecf65974 100644 --- a/pkgs/by-name/di/disnixos/package.nix +++ b/pkgs/by-name/di/disnixos/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, dysnomia, disnix, socat, pkg-config, getopt }: +{ + lib, + stdenv, + fetchurl, + dysnomia, + disnix, + socat, + pkg-config, + getopt, +}: stdenv.mkDerivation rec { pname = "disnixos"; @@ -10,7 +19,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ socat dysnomia disnix getopt ]; + buildInputs = [ + socat + dysnomia + disnix + getopt + ]; meta = { description = "Provides complementary NixOS infrastructure deployment to Disnix"; diff --git a/pkgs/by-name/di/dispad/package.nix b/pkgs/by-name/di/dispad/package.nix index 7abea6a785f154..c74e108ded0646 100644 --- a/pkgs/by-name/di/dispad/package.nix +++ b/pkgs/by-name/di/dispad/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, libX11, libXi, libconfuse }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + libXi, + libconfuse, +}: stdenv.mkDerivation rec { pname = "dispad"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { hash = "sha256-PtwvaNtnCm3Y+6vlxPDc21RyIA2v3vkMOHpoGFxNFng="; }; - buildInputs = [ libX11 libXi libconfuse ]; + buildInputs = [ + libX11 + libXi + libconfuse + ]; meta = with lib; { description = "Small daemon for disabling trackpads while typing"; diff --git a/pkgs/by-name/di/displaycal/package.nix b/pkgs/by-name/di/displaycal/package.nix index e8a7f90ad9a1a4..f476067fa42757 100644 --- a/pkgs/by-name/di/displaycal/package.nix +++ b/pkgs/by-name/di/displaycal/package.nix @@ -1,11 +1,12 @@ -{ lib -, python3 -, fetchPypi -, wrapGAppsHook3 -, gtk3 -, librsvg -, xorg -, argyllcms +{ + lib, + python3, + fetchPypi, + wrapGAppsHook3, + gtk3, + librsvg, + xorg, + argyllcms, }: python3.pkgs.buildPythonApplication rec { @@ -37,16 +38,18 @@ python3.pkgs.buildPythonApplication rec { zeroconf ]; - buildInputs = [ - gtk3 - librsvg - ] ++ (with xorg; [ - libX11 - libXxf86vm - libXext - libXinerama - libXrandr - ]); + buildInputs = + [ + gtk3 + librsvg + ] + ++ (with xorg; [ + libX11 + libXxf86vm + libXext + libXinerama + libXrandr + ]); # Workaround for eoyilmaz/displaycal-py3#261 setupPyGlobalFlags = [ "appdata" ]; diff --git a/pkgs/by-name/di/dissent/package.nix b/pkgs/by-name/di/dissent/package.nix index f5aef15df5bc3b..0854e9bd20a467 100644 --- a/pkgs/by-name/di/dissent/package.nix +++ b/pkgs/by-name/di/dissent/package.nix @@ -1,16 +1,17 @@ -{ buildGoModule -, fetchFromGitLab -, fetchFromGitHub -, gobject-introspection -, gst_all_1 -, lib -, libadwaita -, libcanberra-gtk3 -, pkg-config -, sound-theme-freedesktop -, libspelling -, gtksourceview5 -, wrapGAppsHook4 +{ + buildGoModule, + fetchFromGitLab, + fetchFromGitHub, + gobject-introspection, + gst_all_1, + lib, + libadwaita, + libcanberra-gtk3, + pkg-config, + sound-theme-freedesktop, + libspelling, + gtksourceview5, + wrapGAppsHook4, }: let @@ -74,8 +75,15 @@ buildGoModule rec { meta = with lib; { description = "A third-party Discord client designed for a smooth, native experience (formerly gtkcord4)"; homepage = "https://github.com/diamondburned/dissent"; - license = with licenses; [ gpl3Plus cc0 ]; + license = with licenses; [ + gpl3Plus + cc0 + ]; mainProgram = "dissent"; - maintainers = with maintainers; [ hmenke urandom aleksana ]; + maintainers = with maintainers; [ + hmenke + urandom + aleksana + ]; }; } diff --git a/pkgs/by-name/di/distgen/package.nix b/pkgs/by-name/di/distgen/package.nix index 7450e7c10d2942..fc2f68fdf22f1c 100644 --- a/pkgs/by-name/di/distgen/package.nix +++ b/pkgs/by-name/di/distgen/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchPypi }: +{ + lib, + python3, + fetchPypi, +}: python3.pkgs.buildPythonApplication rec { pname = "distgen"; diff --git a/pkgs/by-name/di/distrobox/package.nix b/pkgs/by-name/di/distrobox/package.nix index ce3c4e075a954d..cac3dd04da6bbf 100644 --- a/pkgs/by-name/di/distrobox/package.nix +++ b/pkgs/by-name/di/distrobox/package.nix @@ -1,4 +1,10 @@ -{ stdenvNoCC, lib, fetchFromGitHub, makeWrapper, wget }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, + makeWrapper, + wget, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "distrobox"; diff --git a/pkgs/by-name/di/diswall/package.nix b/pkgs/by-name/di/diswall/package.nix index d2c0b2a0742550..1edb44b59f1d26 100644 --- a/pkgs/by-name/di/diswall/package.nix +++ b/pkgs/by-name/di/diswall/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, darwin }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + darwin, +}: let inherit (darwin.apple_sdk.frameworks) Security; diff --git a/pkgs/by-name/di/dit/package.nix b/pkgs/by-name/di/dit/package.nix index d809348b3f5223..102bb0fe202a8a 100644 --- a/pkgs/by-name/di/dit/package.nix +++ b/pkgs/by-name/di/dit/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, stdenv, libiconv, ncurses, lua }: +{ + lib, + fetchurl, + stdenv, + libiconv, + ncurses, + lua, +}: stdenv.mkDerivation rec { pname = "dit"; @@ -9,8 +16,10 @@ stdenv.mkDerivation rec { hash = "sha256-p1uD0Q2kqB40fbAEk7/fdOVg9T7SW+2aACSn7hDAD+E="; }; - buildInputs = [ ncurses lua ] - ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; + buildInputs = [ + ncurses + lua + ] ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; # fix paths prePatch = '' diff --git a/pkgs/by-name/di/ditaa/package.nix b/pkgs/by-name/di/ditaa/package.nix index c6823fbed36960..862dfcfef05654 100644 --- a/pkgs/by-name/di/ditaa/package.nix +++ b/pkgs/by-name/di/ditaa/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, jre }: +{ + lib, + stdenv, + fetchurl, + jre, +}: stdenv.mkDerivation rec { pname = "ditaa"; diff --git a/pkgs/by-name/di/dive/package.nix b/pkgs/by-name/di/dive/package.nix index 06cb34499a7269..a6b005d2d0347e 100644 --- a/pkgs/by-name/di/dive/package.nix +++ b/pkgs/by-name/di/dive/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, fetchpatch -, pkg-config -, btrfs-progs -, gpgme -, lvm2 +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + fetchpatch, + pkg-config, + btrfs-progs, + gpgme, + lvm2, }: buildGoModule rec { @@ -24,7 +25,11 @@ buildGoModule rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ btrfs-progs gpgme lvm2 ]; + buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ + btrfs-progs + gpgme + lvm2 + ]; patches = [ # fix scrolling @@ -46,8 +51,11 @@ buildGoModule rec { }) ]; - - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; meta = with lib; { description = "Tool for exploring each layer in a docker image"; diff --git a/pkgs/by-name/di/diylc/package.nix b/pkgs/by-name/di/diylc/package.nix index 072faf3a8a5b9b..14a2949fb3aef6 100644 --- a/pkgs/by-name/di/diylc/package.nix +++ b/pkgs/by-name/di/diylc/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeDesktopItem, unzip, bash, jre8 }: +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + unzip, + bash, + jre8, +}: let pname = "diylc"; @@ -27,7 +35,10 @@ let comment = "Multi platform circuit layout and schematic drawing tool"; exec = "diylc"; icon = "diylc_icon"; - categories = [ "Development" "Electronics" ]; + categories = [ + "Development" + "Electronics" + ]; }; in stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dj/djbdns/package.nix b/pkgs/by-name/dj/djbdns/package.nix index 21a8d55a6aecbf..9ce49ccf46fbe1 100644 --- a/pkgs/by-name/dj/djbdns/package.nix +++ b/pkgs/by-name/dj/djbdns/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, glibc, dns-root-data, nixosTests } : +{ + lib, + stdenv, + fetchurl, + glibc, + dns-root-data, + nixosTests, +}: let version = "1.05"; diff --git a/pkgs/by-name/dj/djenrandom/package.nix b/pkgs/by-name/dj/djenrandom/package.nix index 51f892a5a45302..2f955f7cd365c2 100644 --- a/pkgs/by-name/dj/djenrandom/package.nix +++ b/pkgs/by-name/dj/djenrandom/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { @@ -14,12 +15,13 @@ stdenv.mkDerivation rec { hash = "sha256-r5UT8z8vvFZDffsl6CqBXuvBaZ/sl1WLxJi26CxkpAw="; }; - preBuild = '' - sed -i s/gcc/${stdenv.cc.targetPrefix}gcc/g Makefile - '' - + lib.optionalString (!stdenv.hostPlatform.isx86_64) '' - sed -i s/-m64//g Makefile - ''; + preBuild = + '' + sed -i s/gcc/${stdenv.cc.targetPrefix}gcc/g Makefile + '' + + lib.optionalString (!stdenv.hostPlatform.isx86_64) '' + sed -i s/-m64//g Makefile + ''; installPhase = '' runHook preInstall @@ -38,7 +40,10 @@ stdenv.mkDerivation rec { license = lib.licenses.gpl2Only; # djenrandom uses x86 specific instructions, therefore we can only compile for the x86 architechture platforms = lib.platforms.x86; - maintainers = with lib.maintainers; [ orichter thillux ]; + maintainers = with lib.maintainers; [ + orichter + thillux + ]; mainProgram = "djenrandom"; }; } diff --git a/pkgs/by-name/dj/djent/package.nix b/pkgs/by-name/dj/djent/package.nix index 06cff41ec358ec..a5d0d45313a780 100644 --- a/pkgs/by-name/dj/djent/package.nix +++ b/pkgs/by-name/dj/djent/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, mpfr +{ + lib, + stdenv, + fetchFromGitHub, + mpfr, }: stdenv.mkDerivation rec { @@ -17,12 +18,13 @@ stdenv.mkDerivation rec { buildInputs = [ mpfr ]; - preBuild = '' - sed -i s/gcc/${stdenv.cc.targetPrefix}gcc/g Makefile - '' - + lib.optionalString (!stdenv.hostPlatform.isx86_64) '' - sed -i s/-m64//g Makefile - ''; + preBuild = + '' + sed -i s/gcc/${stdenv.cc.targetPrefix}gcc/g Makefile + '' + + lib.optionalString (!stdenv.hostPlatform.isx86_64) '' + sed -i s/-m64//g Makefile + ''; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; @@ -43,6 +45,9 @@ stdenv.mkDerivation rec { mainProgram = "djent"; license = lib.licenses.gpl2Only; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ orichter thillux ]; + maintainers = with lib.maintainers; [ + orichter + thillux + ]; }; } diff --git a/pkgs/by-name/dj/djlint/package.nix b/pkgs/by-name/dj/djlint/package.nix index 84cfb65522ecbf..1013e4be617bea 100644 --- a/pkgs/by-name/dj/djlint/package.nix +++ b/pkgs/by-name/dj/djlint/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/dj/djmount/package.nix b/pkgs/by-name/dj/djmount/package.nix index bcd8521b6a15ed..d28e6ea0e612d5 100644 --- a/pkgs/by-name/dj/djmount/package.nix +++ b/pkgs/by-name/dj/djmount/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, fuse }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + fuse, +}: stdenv.mkDerivation rec { pname = "djmount"; diff --git a/pkgs/by-name/dj/djot-js/package.nix b/pkgs/by-name/dj/djot-js/package.nix index 656d7d0f6ba8c3..441475f816b5f4 100644 --- a/pkgs/by-name/dj/djot-js/package.nix +++ b/pkgs/by-name/dj/djot-js/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, installShellFiles +{ + lib, + buildNpmPackage, + fetchFromGitHub, + installShellFiles, }: buildNpmPackage rec { diff --git a/pkgs/by-name/dj/djv/package.nix b/pkgs/by-name/dj/djv/package.nix index b2ba5c891c4c64..d16d765b68060f 100644 --- a/pkgs/by-name/dj/djv/package.nix +++ b/pkgs/by-name/dj/djv/package.nix @@ -1,23 +1,24 @@ -{ stdenv -, cmake -, fetchFromGitHub -, fetchpatch -, lib -, alsa-lib -, libGL -, libX11 -, libXinerama -, libXi -, zlib -, rtaudio -, rapidjson -, ilmbase -, glm -, glfw3 -, libpng -, opencolorio_1 -, freetype -, openexr +{ + stdenv, + cmake, + fetchFromGitHub, + fetchpatch, + lib, + alsa-lib, + libGL, + libX11, + libXinerama, + libXi, + zlib, + rtaudio, + rapidjson, + ilmbase, + glm, + glfw3, + libpng, + opencolorio_1, + freetype, + openexr, }: let diff --git a/pkgs/by-name/dj/djvu2pdf/package.nix b/pkgs/by-name/dj/djvu2pdf/package.nix index 9396d43b3962cf..cb2e4fe7cdaaf9 100644 --- a/pkgs/by-name/dj/djvu2pdf/package.nix +++ b/pkgs/by-name/dj/djvu2pdf/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, makeWrapper, fetchurl, djvulibre, ghostscript, which }: +{ + lib, + stdenv, + makeWrapper, + fetchurl, + djvulibre, + ghostscript, + which, +}: stdenv.mkDerivation rec { version = "0.9.2"; @@ -14,7 +22,13 @@ stdenv.mkDerivation rec { installPhase = '' mkdir -p $out/bin cp -p djvu2pdf $out/bin - wrapProgram $out/bin/djvu2pdf --prefix PATH : ${lib.makeBinPath [ ghostscript djvulibre which ]} + wrapProgram $out/bin/djvu2pdf --prefix PATH : ${ + lib.makeBinPath [ + ghostscript + djvulibre + which + ] + } mkdir -p $out/man/man1 cp -p djvu2pdf.1.gz $out/man/man1 diff --git a/pkgs/by-name/dj/djvulibre/package.nix b/pkgs/by-name/dj/djvulibre/package.nix index 584ede1831fb04..76b097316dac61 100644 --- a/pkgs/by-name/dj/djvulibre/package.nix +++ b/pkgs/by-name/dj/djvulibre/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchurl -, libjpeg -, libtiff -, librsvg -, libiconv -, bash +{ + lib, + stdenv, + fetchurl, + libjpeg, + libtiff, + librsvg, + libiconv, + bash, }: stdenv.mkDerivation rec { @@ -16,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "1p1fiygq9ny8aimwc4vxwjc6k9ykgdsq1sq06slfbzalfvm0kl7w"; }; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; strictDeps = true; nativeBuildInputs = [ diff --git a/pkgs/by-name/dk/dk/package.nix b/pkgs/by-name/dk/dk/package.nix index 27d0e15492a702..f0bfbba4c52801 100644 --- a/pkgs/by-name/dk/dk/package.nix +++ b/pkgs/by-name/dk/dk/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromBitbucket -, xcbutil -, xcbutilkeysyms -, xcbutilwm -, xcb-util-cursor +{ + lib, + stdenv, + fetchFromBitbucket, + xcbutil, + xcbutilkeysyms, + xcbutilwm, + xcb-util-cursor, }: stdenv.mkDerivation (finalAttrs: { @@ -31,7 +32,10 @@ stdenv.mkDerivation (finalAttrs: { --replace "-I/usr/X11R6/include" "" ''; - makeFlags = [ "PREFIX=$(out)" "SES=$(out)/share/xsessions" ]; + makeFlags = [ + "PREFIX=$(out)" + "SES=$(out)/share/xsessions" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/dk/dkh/package.nix b/pkgs/by-name/dk/dkh/package.nix index a0bed24336a992..1cc339419fb299 100644 --- a/pkgs/by-name/dk/dkh/package.nix +++ b/pkgs/by-name/dk/dkh/package.nix @@ -1,14 +1,20 @@ -{ lib, stdenv, gfortran, fetchFromGitHub, cmake } : +{ + lib, + stdenv, + gfortran, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "dkh"; version = "1.2"; - src = fetchFromGitHub { + src = fetchFromGitHub { owner = "psi4"; repo = pname; rev = "v${version}"; - sha256= "1wb4qmb9f8rnrwnnw1gdhzx1fmhy628bxfrg56khxy3j5ljxkhck"; + sha256 = "1wb4qmb9f8rnrwnnw1gdhzx1fmhy628bxfrg56khxy3j5ljxkhck"; }; nativeBuildInputs = [ diff --git a/pkgs/by-name/dk/dkimproxy/package.nix b/pkgs/by-name/dk/dkimproxy/package.nix index b34d3a1ed5665a..770e61e4f33650 100644 --- a/pkgs/by-name/dk/dkimproxy/package.nix +++ b/pkgs/by-name/dk/dkimproxy/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, perlPackages, fetchurl }: +{ + lib, + stdenv, + perlPackages, + fetchurl, +}: stdenv.mkDerivation rec { pname = "dkimproxy"; @@ -21,7 +26,13 @@ stdenv.mkDerivation rec { ''; buildInputs = [ perlPackages.perl ]; - propagatedBuildInputs = with perlPackages; [ CryptX Error MailDKIM MIMETools NetServer ]; + propagatedBuildInputs = with perlPackages; [ + CryptX + Error + MailDKIM + MIMETools + NetServer + ]; meta = with lib; { description = "SMTP-proxy that signs and/or verifies emails"; diff --git a/pkgs/by-name/dl/dl-poly-classic-mpi/package.nix b/pkgs/by-name/dl/dl-poly-classic-mpi/package.nix index 75ab576212d769..0c6972e1d9be5f 100644 --- a/pkgs/by-name/dl/dl-poly-classic-mpi/package.nix +++ b/pkgs/by-name/dl/dl-poly-classic-mpi/package.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, fetchurl -, gfortran, mpi +{ + lib, + stdenv, + fetchurl, + gfortran, + mpi, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/dl/dleyna-connector-dbus/package.nix b/pkgs/by-name/dl/dleyna-connector-dbus/package.nix index 4cdd66ba9cfef1..9d3ce402abf4eb 100644 --- a/pkgs/by-name/dl/dleyna-connector-dbus/package.nix +++ b/pkgs/by-name/dl/dleyna-connector-dbus/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, meson -, ninja -, pkg-config -, fetchFromGitHub -, fetchpatch -, dleyna-core -, glib +{ + stdenv, + lib, + meson, + ninja, + pkg-config, + fetchFromGitHub, + fetchpatch, + dleyna-core, + glib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dl/dleyna-core/package.nix b/pkgs/by-name/dl/dleyna-core/package.nix index c9bbae74611e22..e25e1a1da44a40 100644 --- a/pkgs/by-name/dl/dleyna-core/package.nix +++ b/pkgs/by-name/dl/dleyna-core/package.nix @@ -1,17 +1,21 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, gupnp +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + gupnp, }: stdenv.mkDerivation rec { pname = "dleyna-core"; version = "0.7.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; setupHook = ./setup-hook.sh; @@ -32,10 +36,12 @@ stdenv.mkDerivation rec { gupnp ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-error=implicit-function-declaration" - "-Wno-error=int-conversion" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-error=implicit-function-declaration" + "-Wno-error=int-conversion" + ] + ); meta = with lib; { description = "Library of utility functions that are used by the higher level dLeyna"; diff --git a/pkgs/by-name/dl/dleyna-renderer/package.nix b/pkgs/by-name/dl/dleyna-renderer/package.nix index cefe7e90fd0f0d..565e6519e6e1c6 100644 --- a/pkgs/by-name/dl/dleyna-renderer/package.nix +++ b/pkgs/by-name/dl/dleyna-renderer/package.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, meson -, ninja -, pkg-config -, dleyna-connector-dbus -, dleyna-core -, gssdp -, gupnp -, gupnp-av -, gupnp-dlna -, libsoup_2_4 -, makeWrapper -, docbook-xsl-nons -, libxslt +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + meson, + ninja, + pkg-config, + dleyna-connector-dbus, + dleyna-core, + gssdp, + gupnp, + gupnp-av, + gupnp-dlna, + libsoup_2_4, + makeWrapper, + docbook-xsl-nons, + libxslt, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dl/dleyna-server/package.nix b/pkgs/by-name/dl/dleyna-server/package.nix index ff24f5bf7c5686..cbaf5e1e266702 100644 --- a/pkgs/by-name/dl/dleyna-server/package.nix +++ b/pkgs/by-name/dl/dleyna-server/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, meson -, ninja -, makeWrapper -, pkg-config -, dleyna-core -, dleyna-connector-dbus -, gssdp -, gupnp -, gupnp-av -, gupnp-dlna -, libsoup_2_4 +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + meson, + ninja, + makeWrapper, + pkg-config, + dleyna-core, + dleyna-connector-dbus, + gssdp, + gupnp, + gupnp-av, + gupnp-dlna, + libsoup_2_4, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dl/dlib/package.nix b/pkgs/by-name/dl/dlib/package.nix index 8d85fc3325e228..debaf686da04c6 100644 --- a/pkgs/by-name/dl/dlib/package.nix +++ b/pkgs/by-name/dl/dlib/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, libpng -, libjpeg -, libwebp -, blas -, lapack -, config -, guiSupport ? false -, libX11 -, enableShared ? !stdenv.hostPlatform.isStatic # dlib has a build system that forces the user to choose between either shared or static libraries. See https://github.com/davisking/dlib/issues/923#issuecomment-2175865174 -, sse4Support ? stdenv.hostPlatform.sse4_1Support -, avxSupport ? stdenv.hostPlatform.avxSupport -, cudaSupport ? config.cudaSupport -, cudaPackages +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + libpng, + libjpeg, + libwebp, + blas, + lapack, + config, + guiSupport ? false, + libX11, + enableShared ? !stdenv.hostPlatform.isStatic, # dlib has a build system that forces the user to choose between either shared or static libraries. See https://github.com/davisking/dlib/issues/923#issuecomment-2175865174 + sse4Support ? stdenv.hostPlatform.sse4_1Support, + avxSupport ? stdenv.hostPlatform.avxSupport, + cudaSupport ? config.cudaSupport, + cudaPackages, }@inputs: (if cudaSupport then cudaPackages.backendStdenv else inputs.stdenv).mkDerivation rec { pname = "dlib"; @@ -32,44 +33,60 @@ rm -rf dlib/external ''; - cmakeFlags = [ - (lib.cmakeBool "BUILD_SHARED_LIBS" enableShared) - (lib.cmakeBool "USE_SSE4_INSTRUCTIONS" sse4Support) - (lib.cmakeBool "USE_AVX_INSTRUCTIONS" avxSupport) - (lib.cmakeBool "DLIB_USE_CUDA" cudaSupport) - ] ++ lib.optionals cudaSupport [ - (lib.cmakeFeature "DLIB_USE_CUDA_COMPUTE_CAPABILITIES" (builtins.concatStringsSep "," (with cudaPackages.flags; map dropDot cudaCapabilities))) - ]; + cmakeFlags = + [ + (lib.cmakeBool "BUILD_SHARED_LIBS" enableShared) + (lib.cmakeBool "USE_SSE4_INSTRUCTIONS" sse4Support) + (lib.cmakeBool "USE_AVX_INSTRUCTIONS" avxSupport) + (lib.cmakeBool "DLIB_USE_CUDA" cudaSupport) + ] + ++ lib.optionals cudaSupport [ + (lib.cmakeFeature "DLIB_USE_CUDA_COMPUTE_CAPABILITIES" ( + builtins.concatStringsSep "," (with cudaPackages.flags; map dropDot cudaCapabilities) + )) + ]; - nativeBuildInputs = [ - cmake - pkg-config - ] ++ lib.optionals cudaSupport (with cudaPackages; [ - cuda_nvcc - ]); + nativeBuildInputs = + [ + cmake + pkg-config + ] + ++ lib.optionals cudaSupport ( + with cudaPackages; + [ + cuda_nvcc + ] + ); - buildInputs = [ - libpng - libjpeg - libwebp - blas - lapack - ] - ++ lib.optionals guiSupport [ libX11 ] - ++ lib.optionals cudaSupport (with cudaPackages; [ - cuda_cudart - cuda_nvcc - libcublas - libcurand - libcusolver - cudnn - cuda_cccl - ]); + buildInputs = + [ + libpng + libjpeg + libwebp + blas + lapack + ] + ++ lib.optionals guiSupport [ libX11 ] + ++ lib.optionals cudaSupport ( + with cudaPackages; + [ + cuda_cudart + cuda_nvcc + libcublas + libcurand + libcusolver + cudnn + cuda_cccl + ] + ); passthru = { inherit - cudaSupport cudaPackages - sse4Support avxSupport; + cudaSupport + cudaPackages + sse4Support + avxSupport + ; }; meta = with lib; { diff --git a/pkgs/by-name/dl/dlx/package.nix b/pkgs/by-name/dl/dlx/package.nix index 8230f2b52c9c86..e1a9e7a435adf9 100644 --- a/pkgs/by-name/dl/dlx/package.nix +++ b/pkgs/by-name/dl/dlx/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { pname = "dlx"; @@ -9,7 +13,11 @@ stdenv.mkDerivation rec { sha256 = "0508linnar9ivy3xr99gzrb2l027ngx12dlxaxs7w67cnwqnb0dg"; }; - makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "LINK=${stdenv.cc.targetPrefix}cc" "CFLAGS=-O2" ]; + makeFlags = [ + "CC=${stdenv.cc.targetPrefix}cc" + "LINK=${stdenv.cc.targetPrefix}cc" + "CFLAGS=-O2" + ]; hardeningDisable = [ "format" ]; installPhase = '' diff --git a/pkgs/by-name/dm/dm-sans/package.nix b/pkgs/by-name/dm/dm-sans/package.nix index e8d51945254d22..95a1f9e23c4dee 100644 --- a/pkgs/by-name/dm/dm-sans/package.nix +++ b/pkgs/by-name/dm/dm-sans/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "dm-sans"; diff --git a/pkgs/by-name/dm/dmalloc/package.nix b/pkgs/by-name/dm/dmalloc/package.nix index a92761f749cc87..d7ef4faa06d2e4 100644 --- a/pkgs/by-name/dm/dmalloc/package.nix +++ b/pkgs/by-name/dm/dmalloc/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, testers -, dmalloc +{ + lib, + stdenv, + fetchFromGitHub, + testers, + dmalloc, }: stdenv.mkDerivation rec { @@ -12,7 +13,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "j256"; repo = "dmalloc"; - rev = "dmalloc_release_${lib.replaceStrings ["."] ["_"] version}"; + rev = "dmalloc_release_${lib.replaceStrings [ "." ] [ "_" ] version}"; hash = "sha256-P63I9s32C3v1q+Sy9joK0HKYb0ebBu9g72tTTwxvkz8="; }; diff --git a/pkgs/by-name/dm/dmd/binary.nix b/pkgs/by-name/dm/dmd/binary.nix index 3a5d6b76cec871..096580ea4a23d8 100644 --- a/pkgs/by-name/dm/dmd/binary.nix +++ b/pkgs/by-name/dm/dmd/binary.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchurl, curl, tzdata, autoPatchelfHook, fixDarwinDylibNames, glibc -, version, hashes }: +{ + lib, + stdenv, + fetchurl, + curl, + tzdata, + autoPatchelfHook, + fixDarwinDylibNames, + glibc, + version, + hashes, +}: let inherit (stdenv) hostPlatform; @@ -23,18 +33,22 @@ stdenv.mkDerivation { dontConfigure = true; dontBuild = true; - nativeBuildInputs = lib.optionals hostPlatform.isLinux [ - autoPatchelfHook - ] ++ lib.optionals hostPlatform.isDarwin [ - fixDarwinDylibNames - ]; - propagatedBuildInputs = [ - curl - tzdata - ] ++ lib.optionals hostPlatform.isLinux [ - glibc - stdenv.cc.cc.libgcc - ]; + nativeBuildInputs = + lib.optionals hostPlatform.isLinux [ + autoPatchelfHook + ] + ++ lib.optionals hostPlatform.isDarwin [ + fixDarwinDylibNames + ]; + propagatedBuildInputs = + [ + curl + tzdata + ] + ++ lib.optionals hostPlatform.isLinux [ + glibc + stdenv.cc.cc.libgcc + ]; installPhase = '' runHook preInstall @@ -72,6 +86,10 @@ stdenv.mkDerivation { license = licenses.boost; maintainers = [ maintainers.lionello ]; homepage = "https://dlang.org/"; - platforms = [ "x86_64-darwin" "i686-linux" "x86_64-linux" ]; + platforms = [ + "x86_64-darwin" + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/dm/dmd/generic.nix b/pkgs/by-name/dm/dmd/generic.nix index 1c68817ead2e3e..b88373a23fc9a1 100644 --- a/pkgs/by-name/dm/dmd/generic.nix +++ b/pkgs/by-name/dm/dmd/generic.nix @@ -1,46 +1,48 @@ -{ version -, dmdHash -, phobosHash +{ + version, + dmdHash, + phobosHash, }: -{ stdenv -, lib -, fetchFromGitHub -, removeReferencesTo -, makeWrapper -, which -, writeTextFile -, curl -, tzdata -, gdb -, Foundation -, callPackage -, targetPackages -, fetchpatch -, bash -, installShellFiles -, git -, unzip -, dmdBootstrap ? callPackage ./bootstrap.nix { } -, dmdBin ? "${dmdBootstrap}/bin" +{ + stdenv, + lib, + fetchFromGitHub, + removeReferencesTo, + makeWrapper, + which, + writeTextFile, + curl, + tzdata, + gdb, + Foundation, + callPackage, + targetPackages, + fetchpatch, + bash, + installShellFiles, + git, + unzip, + dmdBootstrap ? callPackage ./bootstrap.nix { }, + dmdBin ? "${dmdBootstrap}/bin", }: let dmdConfFile = writeTextFile { name = "dmd.conf"; - text = (lib.generators.toINI { } { - Environment = { - DFLAGS = ''-I@out@/include/dmd -L-L@out@/lib -fPIC ${lib.optionalString (!targetPackages.stdenv.cc.isClang) "-L--export-dynamic"}''; - }; - }); + text = ( + lib.generators.toINI { } { + Environment = { + DFLAGS = ''-I@out@/include/dmd -L-L@out@/lib -fPIC ${ + lib.optionalString (!targetPackages.stdenv.cc.isClang) "-L--export-dynamic" + }''; + }; + } + ); }; bits = builtins.toString stdenv.hostPlatform.parsed.cpu.bits; - osname = - if stdenv.hostPlatform.isDarwin then - "osx" - else - stdenv.hostPlatform.parsed.kernel.name; + osname = if stdenv.hostPlatform.isDarwin then "osx" else stdenv.hostPlatform.parsed.kernel.name; pathToDmd = "\${NIX_BUILD_TOP}/dmd/generated/${osname}/release/${bits}/dmd"; in @@ -73,72 +75,85 @@ stdenv.mkDerivation (finalAttrs: { # https://issues.dlang.org/show_bug.cgi?id=19553 hardeningDisable = [ "fortify" ]; - patches = lib.optionals (lib.versionOlder version "2.088.0") [ - # Migrates D1-style operator overloads in DMD source, to allow building with - # a newer DMD - (fetchpatch { - url = "https://github.com/dlang/dmd/commit/c4d33e5eb46c123761ac501e8c52f33850483a8a.patch"; - stripLen = 1; - extraPrefix = "dmd/"; - hash = "sha256-N21mAPfaTo+zGCip4njejasraV5IsWVqlGR5eOdFZZE="; - }) - ] ++ lib.optionals (lib.versionOlder version "2.110.0") [ - (fetchpatch { - url = "https://github.com/dlang/dmd/commit/fdd25893e0ac04893d6eba8652903d499b7b0dfc.patch"; - stripLen = 1; - extraPrefix = "dmd/"; - hash = "sha256-Uccb8rBPBLAEPWbOYWgdR5xN3wJoIkKKhLGu58IK1sM="; - }) - ]; - - postPatch = '' - patchShebangs dmd/compiler/test/{runnable,fail_compilation,compilable,tools}{,/extra-files}/*.sh - - rm dmd/compiler/test/runnable/gdb1.d - rm dmd/compiler/test/runnable/gdb10311.d - rm dmd/compiler/test/runnable/gdb14225.d - rm dmd/compiler/test/runnable/gdb14276.d - rm dmd/compiler/test/runnable/gdb14313.d - rm dmd/compiler/test/runnable/gdb14330.d - rm dmd/compiler/test/runnable/gdb15729.sh - rm dmd/compiler/test/runnable/gdb4149.d - rm dmd/compiler/test/runnable/gdb4181.d - rm dmd/compiler/test/compilable/ddocYear.d - - # Disable tests that rely on objdump whitespace until fixed upstream: - # https://issues.dlang.org/show_bug.cgi?id=23317 - rm dmd/compiler/test/runnable/cdvecfill.sh - rm dmd/compiler/test/compilable/cdcmp.d - '' + lib.optionalString (lib.versionAtLeast version "2.089.0" && lib.versionOlder version "2.092.2") '' - rm dmd/compiler/test/dshell/test6952.d - '' + lib.optionalString (lib.versionAtLeast version "2.092.2") '' - substituteInPlace dmd/compiler/test/dshell/test6952.d --replace-fail "/usr/bin/env bash" "${bash}/bin/bash" - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace phobos/std/socket.d --replace-fail "assert(ih.addrList[0] == 0x7F_00_00_01);" "" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace phobos/std/socket.d --replace-fail "foreach (name; names)" "names = []; foreach (name; names)" - ''; - - nativeBuildInputs = [ - makeWrapper - which - installShellFiles - ] ++ lib.optionals (lib.versionOlder version "2.088.0") [ - git - ]; - - buildInputs = [ - curl - tzdata - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Foundation - ]; - - nativeCheckInputs = [ - gdb - ] ++ lib.optionals (lib.versionOlder version "2.089.0") [ - unzip - ]; + patches = + lib.optionals (lib.versionOlder version "2.088.0") [ + # Migrates D1-style operator overloads in DMD source, to allow building with + # a newer DMD + (fetchpatch { + url = "https://github.com/dlang/dmd/commit/c4d33e5eb46c123761ac501e8c52f33850483a8a.patch"; + stripLen = 1; + extraPrefix = "dmd/"; + hash = "sha256-N21mAPfaTo+zGCip4njejasraV5IsWVqlGR5eOdFZZE="; + }) + ] + ++ lib.optionals (lib.versionOlder version "2.110.0") [ + (fetchpatch { + url = "https://github.com/dlang/dmd/commit/fdd25893e0ac04893d6eba8652903d499b7b0dfc.patch"; + stripLen = 1; + extraPrefix = "dmd/"; + hash = "sha256-Uccb8rBPBLAEPWbOYWgdR5xN3wJoIkKKhLGu58IK1sM="; + }) + ]; + + postPatch = + '' + patchShebangs dmd/compiler/test/{runnable,fail_compilation,compilable,tools}{,/extra-files}/*.sh + + rm dmd/compiler/test/runnable/gdb1.d + rm dmd/compiler/test/runnable/gdb10311.d + rm dmd/compiler/test/runnable/gdb14225.d + rm dmd/compiler/test/runnable/gdb14276.d + rm dmd/compiler/test/runnable/gdb14313.d + rm dmd/compiler/test/runnable/gdb14330.d + rm dmd/compiler/test/runnable/gdb15729.sh + rm dmd/compiler/test/runnable/gdb4149.d + rm dmd/compiler/test/runnable/gdb4181.d + rm dmd/compiler/test/compilable/ddocYear.d + + # Disable tests that rely on objdump whitespace until fixed upstream: + # https://issues.dlang.org/show_bug.cgi?id=23317 + rm dmd/compiler/test/runnable/cdvecfill.sh + rm dmd/compiler/test/compilable/cdcmp.d + '' + + lib.optionalString (lib.versionAtLeast version "2.089.0" && lib.versionOlder version "2.092.2") '' + rm dmd/compiler/test/dshell/test6952.d + '' + + lib.optionalString (lib.versionAtLeast version "2.092.2") '' + substituteInPlace dmd/compiler/test/dshell/test6952.d --replace-fail "/usr/bin/env bash" "${bash}/bin/bash" + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace phobos/std/socket.d --replace-fail "assert(ih.addrList[0] == 0x7F_00_00_01);" "" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace phobos/std/socket.d --replace-fail "foreach (name; names)" "names = []; foreach (name; names)" + ''; + + nativeBuildInputs = + [ + makeWrapper + which + installShellFiles + ] + ++ lib.optionals (lib.versionOlder version "2.088.0") [ + git + ]; + + buildInputs = + [ + curl + tzdata + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Foundation + ]; + + nativeCheckInputs = + [ + gdb + ] + ++ lib.optionals (lib.versionOlder version "2.089.0") [ + unzip + ]; buildFlags = [ "BUILD=release" @@ -227,8 +242,16 @@ stdenv.mkDerivation (finalAttrs: { # https://github.com/dlang/dmd/pull/6680 license = licenses.boost; mainProgram = "dmd"; - maintainers = with maintainers; [ lionello dukc jtbx ]; - platforms = [ "x86_64-linux" "i686-linux" "x86_64-darwin" ]; + maintainers = with maintainers; [ + lionello + dukc + jtbx + ]; + platforms = [ + "x86_64-linux" + "i686-linux" + "x86_64-darwin" + ]; # ld: section __DATA/__thread_bss has type zero-fill but non-zero file offset file '/private/tmp/nix-build-dmd-2.109.1.drv-0/.rdmd-301/rdmd-build.d-A1CF043A7D87C5E88A58F3C0EF5A0DF7/objs/build.o' for architecture x86_64 # clang-16: error: linker command failed with exit code 1 (use -v to see invocation) broken = stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64; diff --git a/pkgs/by-name/dm/dmenu-bluetooth/package.nix b/pkgs/by-name/dm/dmenu-bluetooth/package.nix index 13f169ebc23ba2..8d44013cb44b49 100644 --- a/pkgs/by-name/dm/dmenu-bluetooth/package.nix +++ b/pkgs/by-name/dm/dmenu-bluetooth/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, bluez -, dmenu -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + bluez, + dmenu, + nix-update-script, }: stdenv.mkDerivation (finalAttrs: { @@ -26,7 +27,12 @@ stdenv.mkDerivation (finalAttrs: { install -D --target-directory=$out/bin/ ./dmenu-bluetooth wrapProgram $out/bin/dmenu-bluetooth \ - --prefix PATH ":" ${lib.makeBinPath [ dmenu bluez ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + dmenu + bluez + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/dm/dmidecode/package.nix b/pkgs/by-name/dm/dmidecode/package.nix index 2425a053e37a8f..40bbcbeb0ab07a 100644 --- a/pkgs/by-name/dm/dmidecode/package.nix +++ b/pkgs/by-name/dm/dmidecode/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "dmidecode"; diff --git a/pkgs/by-name/dm/dmitry/package.nix b/pkgs/by-name/dm/dmitry/package.nix index 49e986db03e5cc..5a641d1bf03ecd 100644 --- a/pkgs/by-name/dm/dmitry/package.nix +++ b/pkgs/by-name/dm/dmitry/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/dm/dmrconfig/package.nix b/pkgs/by-name/dm/dmrconfig/package.nix index e235d68d365bde..2821b9996c461c 100644 --- a/pkgs/by-name/dm/dmrconfig/package.nix +++ b/pkgs/by-name/dm/dmrconfig/package.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, libusb1, systemd }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + libusb1, + systemd, +}: stdenv.mkDerivation rec { pname = "dmrconfig"; @@ -22,7 +28,8 @@ stdenv.mkDerivation rec { ]; buildInputs = [ - libusb1 systemd + libusb1 + systemd ]; preConfigure = '' @@ -30,7 +37,10 @@ stdenv.mkDerivation rec { --replace /usr/local/bin/dmrconfig $out/bin/dmrconfig ''; - makeFlags = [ "VERSION=${version}" "GITCOUNT=0" ]; + makeFlags = [ + "VERSION=${version}" + "GITCOUNT=0" + ]; installPhase = '' mkdir -p $out/bin $out/lib/udev/rules.d diff --git a/pkgs/by-name/dm/dmtcp/package.nix b/pkgs/by-name/dm/dmtcp/package.nix index 6315d361ed686e..f5e173d78d322a 100644 --- a/pkgs/by-name/dm/dmtcp/package.nix +++ b/pkgs/by-name/dm/dmtcp/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, bash, perl, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + bash, + perl, + python3, +}: stdenv.mkDerivation rec { pname = "dmtcp"; diff --git a/pkgs/by-name/dn/dnadd/package.nix b/pkgs/by-name/dn/dnadd/package.nix index eccda0bd7c5ffe..9841597acf69d0 100644 --- a/pkgs/by-name/dn/dnadd/package.nix +++ b/pkgs/by-name/dn/dnadd/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "dnadd"; diff --git a/pkgs/by-name/dn/dnd-tools/package.nix b/pkgs/by-name/dn/dnd-tools/package.nix index 4959f29ec7e144..227de3abe70141 100644 --- a/pkgs/by-name/dn/dnd-tools/package.nix +++ b/pkgs/by-name/dn/dnd-tools/package.nix @@ -1,4 +1,9 @@ -{ python3, fetchFromGitHub, fetchpatch, lib }: +{ + python3, + fetchFromGitHub, + fetchpatch, + lib, +}: python3.pkgs.buildPythonApplication rec { pname = "dnd-tools"; diff --git a/pkgs/by-name/dn/dnglab/package.nix b/pkgs/by-name/dn/dnglab/package.nix index 3d9ffbeba2ef0f..cf228bbb41e5f9 100644 --- a/pkgs/by-name/dn/dnglab/package.nix +++ b/pkgs/by-name/dn/dnglab/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { pname = "dnglab"; diff --git a/pkgs/by-name/dn/dns-root-data/package.nix b/pkgs/by-name/dn/dns-root-data/package.nix index 4d07bce350209e..76c420f7d05674 100644 --- a/pkgs/by-name/dn/dns-root-data/package.nix +++ b/pkgs/by-name/dn/dns-root-data/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchurl }: +{ + stdenv, + lib, + fetchurl, +}: let @@ -31,7 +35,10 @@ stdenv.mkDerivation { meta = with lib; { description = "DNS root data including root zone and DNSSEC key"; - maintainers = with maintainers; [ fpletz vcunat ]; + maintainers = with maintainers; [ + fpletz + vcunat + ]; license = licenses.gpl3Plus; }; } diff --git a/pkgs/by-name/dn/dns2tcp/package.nix b/pkgs/by-name/dn/dns2tcp/package.nix index fb1b1ddc47c39c..c798f34ac10630 100644 --- a/pkgs/by-name/dn/dns2tcp/package.nix +++ b/pkgs/by-name/dn/dns2tcp/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, }: stdenv.mkDerivation (finalAttrs: { @@ -28,7 +29,6 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - meta = with lib; { description = "Tool for relaying TCP connections over DNS"; homepage = "https://github.com/alex-sector/dns2tcp"; diff --git a/pkgs/by-name/dn/dnscontrol/package.nix b/pkgs/by-name/dn/dnscontrol/package.nix index d865e1adaee00a..5ee693f3df65e9 100644 --- a/pkgs/by-name/dn/dnscontrol/package.nix +++ b/pkgs/by-name/dn/dnscontrol/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, testers, dnscontrol }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + dnscontrol, +}: buildGoModule rec { pname = "dnscontrol"; @@ -17,7 +24,11 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" "-X=main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.version=${version}" + ]; postInstall = '' installShellCompletion --cmd dnscontrol \ diff --git a/pkgs/by-name/dn/dnscrypt-proxy/package.nix b/pkgs/by-name/dn/dnscrypt-proxy/package.nix index 1a3f06ef0cac60..4d11703a59be0a 100644 --- a/pkgs/by-name/dn/dnscrypt-proxy/package.nix +++ b/pkgs/by-name/dn/dnscrypt-proxy/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "dnscrypt-proxy"; @@ -22,7 +27,10 @@ buildGoModule rec { license = licenses.isc; homepage = "https://dnscrypt.info/"; - maintainers = with maintainers; [ atemu waynr ]; + maintainers = with maintainers; [ + atemu + waynr + ]; mainProgram = "dnscrypt-proxy"; platforms = with platforms; unix; }; diff --git a/pkgs/by-name/dn/dnsdist/package.nix b/pkgs/by-name/dn/dnsdist/package.nix index e3afc6c8956d05..3365ce60972231 100644 --- a/pkgs/by-name/dn/dnsdist/package.nix +++ b/pkgs/by-name/dn/dnsdist/package.nix @@ -1,7 +1,21 @@ -{ lib, stdenv, fetchurl, pkg-config, systemd -, boost, libsodium, libedit, re2 -, net-snmp, lua, protobuf, openssl, zlib, h2o -, nghttp2, nixosTests +{ + lib, + stdenv, + fetchurl, + pkg-config, + systemd, + boost, + libsodium, + libedit, + re2, + net-snmp, + lua, + protobuf, + openssl, + zlib, + h2o, + nghttp2, + nixosTests, }: stdenv.mkDerivation rec { @@ -19,8 +33,23 @@ stdenv.mkDerivation rec { ./disable-network-tests.patch ]; - nativeBuildInputs = [ pkg-config protobuf ]; - buildInputs = [ systemd boost libsodium libedit re2 net-snmp lua openssl zlib h2o nghttp2 ]; + nativeBuildInputs = [ + pkg-config + protobuf + ]; + buildInputs = [ + systemd + boost + libsodium + libedit + re2 + net-snmp + lua + openssl + zlib + h2o + nghttp2 + ]; configureFlags = [ "--with-libsodium" diff --git a/pkgs/by-name/dn/dnsenum/package.nix b/pkgs/by-name/dn/dnsenum/package.nix index 4fa5c0e26207e7..b21e60a73bd82c 100644 --- a/pkgs/by-name/dn/dnsenum/package.nix +++ b/pkgs/by-name/dn/dnsenum/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, perl, perlPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + perl, + perlPackages, +}: stdenv.mkDerivation rec { pname = "dnsenum"; @@ -12,7 +19,14 @@ stdenv.mkDerivation rec { }; propagatedBuildInputs = with perlPackages; [ - perl NetDNS NetIP NetNetmask StringRandom XMLWriter NetWhoisIP WWWMechanize + perl + NetDNS + NetIP + NetNetmask + StringRandom + XMLWriter + NetWhoisIP + WWWMechanize ]; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/by-name/dn/dnsmasq/package.nix b/pkgs/by-name/dn/dnsmasq/package.nix index 99744769fff663..9761f1a55fef95 100644 --- a/pkgs/by-name/dn/dnsmasq/package.nix +++ b/pkgs/by-name/dn/dnsmasq/package.nix @@ -1,20 +1,32 @@ -{ lib, stdenv, fetchurl, pkg-config, nettle -, libidn, libnetfilter_conntrack, nftables, buildPackages -, dbusSupport ? stdenv.hostPlatform.isLinux -, dbus -, nixosTests +{ + lib, + stdenv, + fetchurl, + pkg-config, + nettle, + libidn, + libnetfilter_conntrack, + nftables, + buildPackages, + dbusSupport ? stdenv.hostPlatform.isLinux, + dbus, + nixosTests, }: let - copts = lib.concatStringsSep " " ([ - "-DHAVE_IDN" - "-DHAVE_DNSSEC" - ] ++ lib.optionals dbusSupport [ - "-DHAVE_DBUS" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "-DHAVE_CONNTRACK" - "-DHAVE_NFTSET" - ]); + copts = lib.concatStringsSep " " ( + [ + "-DHAVE_IDN" + "-DHAVE_DNSSEC" + ] + ++ lib.optionals dbusSupport [ + "-DHAVE_DBUS" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "-DHAVE_CONNTRACK" + "-DHAVE_NFTSET" + ] + ); in stdenv.mkDerivation rec { pname = "dnsmasq"; @@ -49,34 +61,45 @@ stdenv.mkDerivation rec { # XXX: Does the systemd service definition really belong here when our NixOS # module can create it in Nix-land? - postInstall = '' - install -Dm644 trust-anchors.conf $out/share/dnsmasq/trust-anchors.conf - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install -Dm644 contrib/MacOSX-launchd/uk.org.thekelleys.dnsmasq.plist \ - $out/Library/LaunchDaemons/uk.org.thekelleys.dnsmasq.plist - substituteInPlace $out/Library/LaunchDaemons/uk.org.thekelleys.dnsmasq.plist \ - --replace "/usr/local/sbin" "$out/bin" - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - install -Dm755 contrib/lease-tools/dhcp_lease_time $out/bin/dhcp_lease_time - install -Dm755 contrib/lease-tools/dhcp_release $out/bin/dhcp_release - install -Dm755 contrib/lease-tools/dhcp_release6 $out/bin/dhcp_release6 + postInstall = + '' + install -Dm644 trust-anchors.conf $out/share/dnsmasq/trust-anchors.conf + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install -Dm644 contrib/MacOSX-launchd/uk.org.thekelleys.dnsmasq.plist \ + $out/Library/LaunchDaemons/uk.org.thekelleys.dnsmasq.plist + substituteInPlace $out/Library/LaunchDaemons/uk.org.thekelleys.dnsmasq.plist \ + --replace "/usr/local/sbin" "$out/bin" + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + install -Dm755 contrib/lease-tools/dhcp_lease_time $out/bin/dhcp_lease_time + install -Dm755 contrib/lease-tools/dhcp_release $out/bin/dhcp_release + install -Dm755 contrib/lease-tools/dhcp_release6 $out/bin/dhcp_release6 - '' + lib.optionalString dbusSupport '' - install -Dm644 dbus/dnsmasq.conf $out/share/dbus-1/system.d/dnsmasq.conf - mkdir -p $out/share/dbus-1/system-services - cat < $out/share/dbus-1/system-services/uk.org.thekelleys.dnsmasq.service - [D-BUS Service] - Name=uk.org.thekelleys.dnsmasq - Exec=$out/bin/dnsmasq -k -1 - User=root - SystemdService=dnsmasq.service - END - ''; + '' + + lib.optionalString dbusSupport '' + install -Dm644 dbus/dnsmasq.conf $out/share/dbus-1/system.d/dnsmasq.conf + mkdir -p $out/share/dbus-1/system-services + cat < $out/share/dbus-1/system-services/uk.org.thekelleys.dnsmasq.service + [D-BUS Service] + Name=uk.org.thekelleys.dnsmasq + Exec=$out/bin/dnsmasq -k -1 + User=root + SystemdService=dnsmasq.service + END + ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ nettle libidn ] + buildInputs = + [ + nettle + libidn + ] ++ lib.optionals dbusSupport [ dbus ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libnetfilter_conntrack nftables ]; + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libnetfilter_conntrack + nftables + ]; passthru.tests = { prometheus-exporter = nixosTests.prometheus-exporters.dnsmasq; @@ -93,6 +116,9 @@ stdenv.mkDerivation rec { license = licenses.gpl2Only; mainProgram = "dnsmasq"; platforms = with platforms; linux ++ darwin; - maintainers = with maintainers; [ fpletz globin ]; + maintainers = with maintainers; [ + fpletz + globin + ]; }; } diff --git a/pkgs/by-name/dn/dnsmon-go/package.nix b/pkgs/by-name/dn/dnsmon-go/package.nix index 2a0dea59c7f947..69164d6d5cace0 100644 --- a/pkgs/by-name/dn/dnsmon-go/package.nix +++ b/pkgs/by-name/dn/dnsmon-go/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, libpcap +{ + lib, + buildGoModule, + fetchFromGitHub, + libpcap, }: buildGoModule rec { diff --git a/pkgs/by-name/dn/dnsperf/package.nix b/pkgs/by-name/dn/dnsperf/package.nix index 5be21155feea87..d93cc772420ea2 100644 --- a/pkgs/by-name/dn/dnsperf/package.nix +++ b/pkgs/by-name/dn/dnsperf/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, ldns -, libck -, nghttp2 -, openssl -, pkg-config +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + ldns, + libck, + nghttp2, + openssl, + pkg-config, }: stdenv.mkDerivation rec { @@ -41,6 +42,9 @@ stdenv.mkDerivation rec { license = licenses.isc; platforms = platforms.unix; mainProgram = "dnsperf"; - maintainers = with maintainers; [ vcunat mfrw ]; + maintainers = with maintainers; [ + vcunat + mfrw + ]; }; } diff --git a/pkgs/by-name/dn/dnss/package.nix b/pkgs/by-name/dn/dnss/package.nix index 00796cf8df1798..72a8907a301a7d 100644 --- a/pkgs/by-name/dn/dnss/package.nix +++ b/pkgs/by-name/dn/dnss/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule { diff --git a/pkgs/by-name/dn/dnstake/package.nix b/pkgs/by-name/dn/dnstake/package.nix index 37e5e0c38af7d0..21d922961273b4 100644 --- a/pkgs/by-name/dn/dnstake/package.nix +++ b/pkgs/by-name/dn/dnstake/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, }: buildGoModule rec { diff --git a/pkgs/by-name/dn/dnstop/package.nix b/pkgs/by-name/dn/dnstop/package.nix index 05cd8f67d8697f..eaf08d72820f7a 100644 --- a/pkgs/by-name/dn/dnstop/package.nix +++ b/pkgs/by-name/dn/dnstop/package.nix @@ -1,15 +1,26 @@ -{ lib, stdenv, fetchurl, libpcap, ncurses }: +{ + lib, + stdenv, + fetchurl, + libpcap, + ncurses, +}: stdenv.mkDerivation rec { pname = "dnstop"; version = "2014-09-15"; src = fetchurl { - url = "http://dns.measurement-factory.com/tools/dnstop/src/dnstop-${lib.replaceStrings ["-"] [""] version}.tar.gz"; + url = "http://dns.measurement-factory.com/tools/dnstop/src/dnstop-${ + lib.replaceStrings [ "-" ] [ "" ] version + }.tar.gz"; sha256 = "0yn5s2825l826506gclbcfk3lzllx9brk9rzja6yj5jv0013vc5l"; }; - buildInputs = [ libpcap ncurses ]; + buildInputs = [ + libpcap + ncurses + ]; preInstall = '' mkdir -p $out/share/man/man8 $out/bin diff --git a/pkgs/by-name/dn/dnstwist/package.nix b/pkgs/by-name/dn/dnstwist/package.nix index 51f6f5287fcc2b..ec35004d476eb5 100644 --- a/pkgs/by-name/dn/dnstwist/package.nix +++ b/pkgs/by-name/dn/dnstwist/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/do/do-agent/package.nix b/pkgs/by-name/do/do-agent/package.nix index ca7efa4cd0dade..1625101db10868 100644 --- a/pkgs/by-name/do/do-agent/package.nix +++ b/pkgs/by-name/do/do-agent/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "do-agent"; diff --git a/pkgs/by-name/do/doas-sudo-shim/package.nix b/pkgs/by-name/do/doas-sudo-shim/package.nix index 86f111da9f5e1b..cf780eaa3e4586 100644 --- a/pkgs/by-name/do/doas-sudo-shim/package.nix +++ b/pkgs/by-name/do/doas-sudo-shim/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, runCommand -, asciidoctor -, coreutils -, gawk -, glibc -, util-linux -, bash -, makeBinaryWrapper -, doas-sudo-shim +{ + lib, + stdenv, + fetchFromGitHub, + runCommand, + asciidoctor, + coreutils, + gawk, + glibc, + util-linux, + bash, + makeBinaryWrapper, + doas-sudo-shim, }: stdenv.mkDerivation rec { @@ -23,21 +24,41 @@ stdenv.mkDerivation rec { sha256 = "QYVqGxeWC7Tiz8aNY/LukwG4EW0km/RunGEfkzY/A38="; }; - nativeBuildInputs = [ asciidoctor makeBinaryWrapper ]; - buildInputs = [ bash coreutils gawk glibc util-linux ]; + nativeBuildInputs = [ + asciidoctor + makeBinaryWrapper + ]; + buildInputs = [ + bash + coreutils + gawk + glibc + util-linux + ]; dontConfigure = true; dontBuild = true; - installFlags = [ "DESTDIR=$(out)" "PREFIX=\"\"" ]; + installFlags = [ + "DESTDIR=$(out)" + "PREFIX=\"\"" + ]; postInstall = '' wrapProgram $out/bin/sudo \ - --prefix PATH : ${lib.makeBinPath [ bash coreutils gawk glibc util-linux ]} + --prefix PATH : ${ + lib.makeBinPath [ + bash + coreutils + gawk + glibc + util-linux + ] + } ''; passthru.tests = { - helpTest = runCommand "${pname}-helpTest" {} '' + helpTest = runCommand "${pname}-helpTest" { } '' ${doas-sudo-shim}/bin/sudo -h > $out grep -q "Execute a command as another user using doas(1)" $out ''; diff --git a/pkgs/by-name/do/doas/package.nix b/pkgs/by-name/do/doas/package.nix index 3a43a575589aa3..7da262cacbae35 100644 --- a/pkgs/by-name/do/doas/package.nix +++ b/pkgs/by-name/do/doas/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, bison -, pam -, libxcrypt -, nixosTests - -, withPAM ? true -, withTimestamp ? true +{ + lib, + stdenv, + fetchFromGitHub, + bison, + pam, + libxcrypt, + nixosTests, + + withPAM ? true, + withTimestamp ? true, }: stdenv.mkDerivation rec { @@ -38,16 +39,16 @@ stdenv.mkDerivation rec { # ./configure script does not understand `--disable-shared` dontAddStaticConfigureFlags = true; - postPatch = '' - sed -i '/\(chown\|chmod\)/d' GNUmakefile - '' + lib.optionalString (withPAM && stdenv.hostPlatform.isStatic) '' - sed -i 's/-lpam/-lpam -laudit/' configure - ''; + postPatch = + '' + sed -i '/\(chown\|chmod\)/d' GNUmakefile + '' + + lib.optionalString (withPAM && stdenv.hostPlatform.isStatic) '' + sed -i 's/-lpam/-lpam -laudit/' configure + ''; nativeBuildInputs = [ bison ]; - buildInputs = [ ] - ++ lib.optional withPAM pam - ++ lib.optional (!withPAM) libxcrypt; + buildInputs = [ ] ++ lib.optional withPAM pam ++ lib.optional (!withPAM) libxcrypt; passthru.tests = { inherit (nixosTests) doas; }; diff --git a/pkgs/by-name/do/doc2go/package.nix b/pkgs/by-name/do/doc2go/package.nix index 68b0f7f5e1e804..e2b3d2edc3e7d0 100644 --- a/pkgs/by-name/do/doc2go/package.nix +++ b/pkgs/by-name/do/doc2go/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -15,7 +16,11 @@ buildGoModule rec { }; vendorHash = "sha256-d5ZRMFi7GIfDHsYRNvMnDdfnGhTM1sA0WDYD2aDoEd0="; - ldflags = [ "-s" "-w" "-X main._version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main._version=${version}" + ]; subPackages = [ "." ]; # integration is it's own module diff --git a/pkgs/by-name/do/docbook2mdoc/package.nix b/pkgs/by-name/do/docbook2mdoc/package.nix index dccafba41713b3..4a87e025ce99e4 100644 --- a/pkgs/by-name/do/docbook2mdoc/package.nix +++ b/pkgs/by-name/do/docbook2mdoc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, expat }: +{ + lib, + stdenv, + fetchurl, + expat, +}: stdenv.mkDerivation rec { pname = "docbook2mdoc"; diff --git a/pkgs/by-name/do/docbook2odf/package.nix b/pkgs/by-name/do/docbook2odf/package.nix index 7608fb1228ed1a..be8a1fe11b6b57 100644 --- a/pkgs/by-name/do/docbook2odf/package.nix +++ b/pkgs/by-name/do/docbook2odf/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, perlPackages, makeWrapper, zip, libxslt }: +{ + lib, + stdenv, + fetchurl, + perlPackages, + makeWrapper, + zip, + libxslt, +}: stdenv.mkDerivation rec { pname = "docbook2odf"; @@ -28,7 +36,12 @@ stdenv.mkDerivation rec { sed -i "s|/usr/share/docbook2odf|$out/share/docbook2odf|" "$out/bin/docbook2odf" wrapProgram "$out/bin/docbook2odf" \ - --prefix PATH : "${lib.makeBinPath [ zip libxslt ]}" \ + --prefix PATH : "${ + lib.makeBinPath [ + zip + libxslt + ] + }" \ --prefix PERL5PATH : "${perlPackages.makePerlPath [ perlPackages.ImageMagick ]}" ''; diff --git a/pkgs/by-name/do/docbook_xml_ebnf_dtd/package.nix b/pkgs/by-name/do/docbook_xml_ebnf_dtd/package.nix index 6be2e89dcd2efa..fe1d11111a9269 100644 --- a/pkgs/by-name/do/docbook_xml_ebnf_dtd/package.nix +++ b/pkgs/by-name/do/docbook_xml_ebnf_dtd/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "docbook-xml-ebnf"; diff --git a/pkgs/by-name/do/dockbarx/package.nix b/pkgs/by-name/do/dockbarx/package.nix index a3cccb9f859f92..3b478a8606f7fe 100644 --- a/pkgs/by-name/do/dockbarx/package.nix +++ b/pkgs/by-name/do/dockbarx/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, glib -, gobject-introspection -, gtk3 -, keybinder3 -, libwnck -, python3Packages -, wrapGAppsHook3 +{ + lib, + fetchFromGitHub, + glib, + gobject-introspection, + gtk3, + keybinder3, + libwnck, + python3Packages, + wrapGAppsHook3, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/do/docker-compose-language-service/package.nix b/pkgs/by-name/do/docker-compose-language-service/package.nix index e699d8a26dff7a..412836babbbd3b 100644 --- a/pkgs/by-name/do/docker-compose-language-service/package.nix +++ b/pkgs/by-name/do/docker-compose-language-service/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/do/docker-credential-helpers/package.nix b/pkgs/by-name/do/docker-credential-helpers/package.nix index 54de6d17e36e72..69ea21c8c9dd01 100644 --- a/pkgs/by-name/do/docker-credential-helpers/package.nix +++ b/pkgs/by-name/do/docker-credential-helpers/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, pkg-config, libsecret, testers, docker-credential-helpers }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + pkg-config, + libsecret, + testers, + docker-credential-helpers, +}: buildGoModule rec { pname = "docker-credential-helpers"; @@ -25,7 +34,17 @@ buildGoModule rec { buildPhase = let - cmds = if stdenv.hostPlatform.isDarwin then [ "osxkeychain" "pass" ] else [ "secretservice" "pass" ]; + cmds = + if stdenv.hostPlatform.isDarwin then + [ + "osxkeychain" + "pass" + ] + else + [ + "secretservice" + "pass" + ]; in '' for cmd in ${builtins.toString cmds}; do @@ -42,12 +61,15 @@ buildGoModule rec { command = "docker-credential-pass version"; }; - meta = with lib; { - description = "Suite of programs to use native stores to keep Docker credentials safe"; - homepage = "https://github.com/docker/docker-credential-helpers"; - license = licenses.mit; - maintainers = [ ]; - } // lib.optionalAttrs stdenv.hostPlatform.isDarwin { - mainProgram = "docker-credential-osxkeychain"; - }; + meta = + with lib; + { + description = "Suite of programs to use native stores to keep Docker credentials safe"; + homepage = "https://github.com/docker/docker-credential-helpers"; + license = licenses.mit; + maintainers = [ ]; + } + // lib.optionalAttrs stdenv.hostPlatform.isDarwin { + mainProgram = "docker-credential-osxkeychain"; + }; } diff --git a/pkgs/by-name/do/docker-ls/package.nix b/pkgs/by-name/do/docker-ls/package.nix index ad28d569c6e29c..bde78aad278fd7 100644 --- a/pkgs/by-name/do/docker-ls/package.nix +++ b/pkgs/by-name/do/docker-ls/package.nix @@ -1,4 +1,9 @@ -{ buildGoModule, fetchFromGitHub, lib, docker }: +{ + buildGoModule, + fetchFromGitHub, + lib, + docker, +}: buildGoModule rec { pname = "docker-ls"; diff --git a/pkgs/by-name/do/docker-slim/package.nix b/pkgs/by-name/do/docker-slim/package.nix index 13c8e4f4ce3644..20fa9f7faf31cb 100644 --- a/pkgs/by-name/do/docker-slim/package.nix +++ b/pkgs/by-name/do/docker-slim/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, makeBinaryWrapper }: +{ + lib, + buildGoModule, + fetchFromGitHub, + makeBinaryWrapper, +}: buildGoModule rec { pname = "docker-slim"; @@ -13,7 +18,10 @@ buildGoModule rec { vendorHash = null; - subPackages = [ "cmd/slim" "cmd/slim-sensor" ]; + subPackages = [ + "cmd/slim" + "cmd/slim-sensor" + ]; nativeBuildInputs = [ makeBinaryWrapper ]; @@ -39,6 +47,9 @@ buildGoModule rec { homepage = "https://slimtoolkit.org/"; changelog = "https://github.com/slimtoolkit/slim/raw/${version}/CHANGELOG.md"; license = licenses.asl20; - maintainers = with maintainers; [ Br1ght0ne mbrgm ]; + maintainers = with maintainers; [ + Br1ght0ne + mbrgm + ]; }; } diff --git a/pkgs/by-name/do/dockerfile-language-server-nodejs/package.nix b/pkgs/by-name/do/dockerfile-language-server-nodejs/package.nix index 8c96dd227d7c44..e4e481b9e988ed 100644 --- a/pkgs/by-name/do/dockerfile-language-server-nodejs/package.nix +++ b/pkgs/by-name/do/dockerfile-language-server-nodejs/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { @@ -26,6 +27,9 @@ buildNpmPackage rec { homepage = "https://github.com/rcjsuen/dockerfile-language-server-nodejs"; license = lib.licenses.mit; mainProgram = "docker-langserver"; - maintainers = with lib.maintainers; [ rvolosatovs net-mist ]; + maintainers = with lib.maintainers; [ + rvolosatovs + net-mist + ]; }; } diff --git a/pkgs/by-name/do/dockfmt/package.nix b/pkgs/by-name/do/dockfmt/package.nix index 3ca4fc9a162447..8319eef0cde992 100644 --- a/pkgs/by-name/do/dockfmt/package.nix +++ b/pkgs/by-name/do/dockfmt/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/do/dockle/package.nix b/pkgs/by-name/do/dockle/package.nix index 6dc04fef038b73..a7411d3bc41323 100644 --- a/pkgs/by-name/do/dockle/package.nix +++ b/pkgs/by-name/do/dockle/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, pkg-config, btrfs-progs, lvm2 }: +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + btrfs-progs, + lvm2, +}: buildGoModule rec { pname = "dockle"; @@ -14,7 +21,10 @@ buildGoModule rec { vendorHash = "sha256-+AtvnplvPWkUwmxfB7rjYcLTQibQsObFT1QRR0FXAe0="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ btrfs-progs lvm2 ]; + buildInputs = [ + btrfs-progs + lvm2 + ]; ldflags = [ "-s" diff --git a/pkgs/by-name/do/dockstarter/package.nix b/pkgs/by-name/do/dockstarter/package.nix index 40c6858da6a850..2b9f15bc6c60df 100644 --- a/pkgs/by-name/do/dockstarter/package.nix +++ b/pkgs/by-name/do/dockstarter/package.nix @@ -1,11 +1,12 @@ -{ bash -, coreutils -, fetchFromGitHub -, git -, lib -, makeWrapper -, ncurses -, stdenv +{ + bash, + coreutils, + fetchFromGitHub, + git, + lib, + makeWrapper, + ncurses, + stdenv, }: stdenv.mkDerivation rec { @@ -25,12 +26,14 @@ stdenv.mkDerivation rec { installPhase = '' install -Dm755 main.sh $out/bin/ds - wrapProgram $out/bin/ds --prefix PATH : ${lib.makeBinPath [ - bash - coreutils - git - ncurses - ]} + wrapProgram $out/bin/ds --prefix PATH : ${ + lib.makeBinPath [ + bash + coreutils + git + ncurses + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/do/dockutil/package.nix b/pkgs/by-name/do/dockutil/package.nix index 64a8a984438867..264523e970fda8 100644 --- a/pkgs/by-name/do/dockutil/package.nix +++ b/pkgs/by-name/do/dockutil/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, stdenvNoCC -, fetchFromGitHub -, fetchurl -, swift -, swiftpm -, swiftpm2nix -, swiftPackages -, darwin -, libarchive -, p7zip -# Building from source on x86_64 fails (among other things) due to: -# error: cannot load underlying module for 'Darwin' -, fromSource ? (stdenv.system != "x86_64-darwin") +{ + lib, + stdenv, + stdenvNoCC, + fetchFromGitHub, + fetchurl, + swift, + swiftpm, + swiftpm2nix, + swiftPackages, + darwin, + libarchive, + p7zip, + # Building from source on x86_64 fails (among other things) due to: + # error: cannot load underlying module for 'Darwin' + fromSource ? (stdenv.system != "x86_64-darwin"), }: let @@ -50,7 +51,10 @@ let "path" ''; - nativeBuildInputs = [ swift swiftpm ]; + nativeBuildInputs = [ + swift + swiftpm + ]; buildInputs = with darwin.apple_sdk.frameworks; [ Cocoa ]; @@ -75,7 +79,10 @@ let dontConfigure = true; dontBuild = true; - nativeBuildInputs = [ libarchive p7zip ]; + nativeBuildInputs = [ + libarchive + p7zip + ]; unpackPhase = '' 7z x $src @@ -94,6 +101,4 @@ let }; }); in -if fromSource - then buildFromSource - else installBinary +if fromSource then buildFromSource else installBinary diff --git a/pkgs/by-name/do/docopt_cpp/package.nix b/pkgs/by-name/do/docopt_cpp/package.nix index 2e37e073fb6561..4fb99e3458821b 100644 --- a/pkgs/by-name/do/docopt_cpp/package.nix +++ b/pkgs/by-name/do/docopt_cpp/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + python3, +}: stdenv.mkDerivation rec { version = "0.6.3"; @@ -19,9 +26,12 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake python3 ]; + nativeBuildInputs = [ + cmake + python3 + ]; - cmakeFlags = ["-DWITH_TESTS=ON"]; + cmakeFlags = [ "-DWITH_TESTS=ON" ]; strictDeps = true; @@ -38,7 +48,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "C++11 port of docopt"; homepage = "https://github.com/docopt/docopt.cpp"; - license = with licenses; [ mit boost ]; + license = with licenses; [ + mit + boost + ]; platforms = platforms.all; maintainers = with maintainers; [ knedlsepp ]; }; diff --git a/pkgs/by-name/do/docopts/package.nix b/pkgs/by-name/do/docopts/package.nix index cb63a666973ebf..24098bca701d4d 100644 --- a/pkgs/by-name/do/docopts/package.nix +++ b/pkgs/by-name/do/docopts/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, }: buildGoModule rec { pname = "docopts"; diff --git a/pkgs/by-name/do/doctest/package.nix b/pkgs/by-name/do/doctest/package.nix index 1ce0855444927d..11ad954f6b762a 100644 --- a/pkgs/by-name/do/doctest/package.nix +++ b/pkgs/by-name/do/doctest/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, +}: stdenv.mkDerivation rec { pname = "doctest"; diff --git a/pkgs/by-name/do/docui/package.nix b/pkgs/by-name/do/docui/package.nix index a42e57ebc5aece..5c8c5302f5c30b 100644 --- a/pkgs/by-name/do/docui/package.nix +++ b/pkgs/by-name/do/docui/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "docui"; diff --git a/pkgs/by-name/do/documenso/package.nix b/pkgs/by-name/do/documenso/package.nix index 00ef8c0e7bbea3..71b15e2b29b841 100644 --- a/pkgs/by-name/do/documenso/package.nix +++ b/pkgs/by-name/do/documenso/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildNpmPackage -, prisma -, nix-update-script +{ + lib, + fetchFromGitHub, + buildNpmPackage, + prisma, + nix-update-script, }: let version = "0.9"; @@ -43,7 +44,7 @@ buildNpmPackage { runHook postInstall ''; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = with lib; { description = "Open Source DocuSign Alternative"; diff --git a/pkgs/by-name/do/documize-community/package.nix b/pkgs/by-name/do/documize-community/package.nix index 129993903db4f1..842428c7991443 100644 --- a/pkgs/by-name/do/documize-community/package.nix +++ b/pkgs/by-name/do/documize-community/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, go-bindata, go-bindata-assetfs, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + go-bindata, + go-bindata-assetfs, + nixosTests, +}: buildGoModule rec { pname = "documize-community"; @@ -15,7 +22,10 @@ buildGoModule rec { doCheck = false; - nativeBuildInputs = [ go-bindata go-bindata-assetfs ]; + nativeBuildInputs = [ + go-bindata + go-bindata-assetfs + ]; # This is really weird, but they've managed to screw up # their folder structure enough, you can only build by diff --git a/pkgs/by-name/do/docuum/package.nix b/pkgs/by-name/do/docuum/package.nix index 68409ca05651bb..820217861601ff 100644 --- a/pkgs/by-name/do/docuum/package.nix +++ b/pkgs/by-name/do/docuum/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/do/dog/package.nix b/pkgs/by-name/do/dog/package.nix index b8ed50c0c63e8f..9a58dd08cebe82 100644 --- a/pkgs/by-name/do/dog/package.nix +++ b/pkgs/by-name/do/dog/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "dog"; diff --git a/pkgs/by-name/do/doge/package.nix b/pkgs/by-name/do/doge/package.nix index 4b64f8a7dfff29..c12e8345abf804 100644 --- a/pkgs/by-name/do/doge/package.nix +++ b/pkgs/by-name/do/doge/package.nix @@ -15,14 +15,17 @@ python3Packages.buildPythonApplication rec { }; pyproject = true; - nativeBuildInputs = [python3Packages.setuptools]; - propagatedBuildInputs = [python3Packages.python-dateutil]; + nativeBuildInputs = [ python3Packages.setuptools ]; + propagatedBuildInputs = [ python3Packages.python-dateutil ]; meta = { homepage = "https://github.com/Olivia5k/doge"; description = "Wow very terminal doge"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [Gonzih quantenzitrone]; + maintainers = with lib.maintainers; [ + Gonzih + quantenzitrone + ]; mainProgram = "doge"; }; } diff --git a/pkgs/by-name/do/doggo/package.nix b/pkgs/by-name/do/doggo/package.nix index 08f65a5a40c8d7..1a7d51e2c935b2 100644 --- a/pkgs/by-name/do/doggo/package.nix +++ b/pkgs/by-name/do/doggo/package.nix @@ -1,8 +1,9 @@ -{ buildGoModule -, fetchFromGitHub -, installShellFiles -, nix-update-script -, lib +{ + buildGoModule, + fetchFromGitHub, + installShellFiles, + nix-update-script, + lib, }: buildGoModule rec { @@ -43,6 +44,9 @@ buildGoModule rec { It outputs information in a neat concise manner and supports protocols like DoH, DoT, DoQ, and DNSCrypt as well ''; license = licenses.gpl3Only; - maintainers = with maintainers; [ georgesalkhouri ma27 ]; + maintainers = with maintainers; [ + georgesalkhouri + ma27 + ]; }; } diff --git a/pkgs/by-name/do/doing/gemset.nix b/pkgs/by-name/do/doing/gemset.nix index 1e39123a83badd..99db704ef42bd2 100644 --- a/pkgs/by-name/do/doing/gemset.nix +++ b/pkgs/by-name/do/doing/gemset.nix @@ -1,7 +1,7 @@ { chronic = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1hrdkn4g8x7dlzxwb1rfgr8kw3bp4ywg5l4y4i9c2g5cwv62yvvn"; type = "gem"; }; @@ -9,16 +9,22 @@ }; deep_merge = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q3picw7zx1xdkybmrnhmk2hycxzaa0jv4gqrby1s90dy5n7fmsb"; type = "gem"; }; version = "1.2.1"; }; doing = { - dependencies = ["chronic" "deep_merge" "gli" "haml" "json"]; + dependencies = [ + "chronic" + "deep_merge" + "gli" + "haml" + "json" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1y42yc7h45sz9hqj3g1dd77ipx58l7v64i7mrsj3is2f5rszd1rv"; type = "gem"; }; @@ -26,16 +32,16 @@ }; gli = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0g7g3lxhh2b4h4im58zywj9vcfixfgndfsvp84cr3x67b5zm4kaq"; type = "gem"; }; version = "2.17.1"; }; haml = { - dependencies = ["tilt"]; + dependencies = [ "tilt" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l9zhfdk9z7xjfdp108r9fw4xa55hflin7hh3lpafbf9bdz96knr"; type = "gem"; }; @@ -43,7 +49,7 @@ }; json = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qmj7fypgb9vag723w1a49qihxrcf5shzars106ynw2zk352gbv5"; type = "gem"; }; @@ -51,7 +57,7 @@ }; tilt = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0020mrgdf11q23hm1ddd6fv691l51vi10af00f137ilcdb2ycfra"; type = "gem"; }; diff --git a/pkgs/by-name/do/doing/package.nix b/pkgs/by-name/do/doing/package.nix index 2c49361c2bb4c2..5136966d40c431 100644 --- a/pkgs/by-name/do/doing/package.nix +++ b/pkgs/by-name/do/doing/package.nix @@ -1,4 +1,8 @@ -{ lib, bundlerEnv, ruby, bundlerUpdateScript +{ + lib, + bundlerEnv, + ruby, + bundlerUpdateScript, }: bundlerEnv { @@ -17,10 +21,13 @@ bundlerEnv { in a TaskPaper-formatted text file. It allows for multiple sections/categories and flexible output formatting. ''; - homepage = "https://brettterpstra.com/projects/doing/"; - license = licenses.mit; - maintainers = with maintainers; [ ktf nicknovitski ]; - platforms = platforms.unix; + homepage = "https://brettterpstra.com/projects/doing/"; + license = licenses.mit; + maintainers = with maintainers; [ + ktf + nicknovitski + ]; + platforms = platforms.unix; mainProgram = "doing"; }; } diff --git a/pkgs/by-name/do/doitlive/package.nix b/pkgs/by-name/do/doitlive/package.nix index 9e1d83bb4d9844..00014928191cc8 100644 --- a/pkgs/by-name/do/doitlive/package.nix +++ b/pkgs/by-name/do/doitlive/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "doitlive"; @@ -12,7 +16,11 @@ python3Packages.buildPythonApplication rec { nativeBuildInputs = with python3Packages; [ setuptools ]; - propagatedBuildInputs = with python3Packages; [ click click-completion click-didyoumean ]; + propagatedBuildInputs = with python3Packages; [ + click + click-completion + click-didyoumean + ]; # disable tests (too many failures) doCheck = false; diff --git a/pkgs/by-name/do/dokuwiki/package.nix b/pkgs/by-name/do/dokuwiki/package.nix index cf20b3cc993e45..2cca5f6d0852a9 100644 --- a/pkgs/by-name/do/dokuwiki/package.nix +++ b/pkgs/by-name/do/dokuwiki/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, writeText -, nixosTests -, dokuwiki +{ + lib, + stdenv, + fetchFromGitHub, + writeText, + nixosTests, + dokuwiki, }: stdenv.mkDerivation rec { @@ -18,29 +19,29 @@ stdenv.mkDerivation rec { }; preload = writeText "preload.php" '' - array( - 'default' => getenv('DOKUWIKI_ACL_AUTH_CONFIG'), - ), - 'plainauth.users' => array( - 'default' => getenv('DOKUWIKI_USERS_AUTH_CONFIG'), - 'protected' => "" // not used by default - ), - ); + $config_cascade = array( + 'acl' => array( + 'default' => getenv('DOKUWIKI_ACL_AUTH_CONFIG'), + ), + 'plainauth.users' => array( + 'default' => getenv('DOKUWIKI_USERS_AUTH_CONFIG'), + 'protected' => "" // not used by default + ), + ); ''; phpLocalConfig = writeText "local.php" '' - + ''; phpPluginsLocalConfig = writeText "plugins.local.php" '' - + ''; installPhase = '' @@ -56,26 +57,43 @@ stdenv.mkDerivation rec { ''; passthru = { - combine = { basePackage ? dokuwiki - , plugins ? [] - , templates ? [] - , localConfig ? null - , pluginsConfig ? null - , aclConfig ? null - , pname ? (p: "${p.pname}-combined") - }: let - isNotEmpty = x: lib.optionalString (! builtins.elem x [ null "" ]); - in basePackage.overrideAttrs (prev: { - pname = if builtins.isFunction pname then pname prev else pname; + combine = + { + basePackage ? dokuwiki, + plugins ? [ ], + templates ? [ ], + localConfig ? null, + pluginsConfig ? null, + aclConfig ? null, + pname ? (p: "${p.pname}-combined"), + }: + let + isNotEmpty = + x: + lib.optionalString ( + !builtins.elem x [ + null + "" + ] + ); + in + basePackage.overrideAttrs (prev: { + pname = if builtins.isFunction pname then pname prev else pname; - postInstall = prev.postInstall or "" + '' - ${lib.concatMapStringsSep "\n" (tpl: "cp -r ${toString tpl} $out/share/dokuwiki/lib/tpl/${tpl.name}") templates} - ${lib.concatMapStringsSep "\n" (plugin: "cp -r ${toString plugin} $out/share/dokuwiki/lib/plugins/${plugin.name}") plugins} - ${isNotEmpty localConfig "ln -sf ${localConfig} $out/share/dokuwiki/conf/local.php" } - ${isNotEmpty pluginsConfig "ln -sf ${pluginsConfig} $out/share/dokuwiki/conf/plugins.local.php" } - ${isNotEmpty aclConfig "ln -sf ${aclConfig} $out/share/dokuwiki/acl.auth.php" } - ''; - }); + postInstall = + prev.postInstall or "" + + '' + ${lib.concatMapStringsSep "\n" ( + tpl: "cp -r ${toString tpl} $out/share/dokuwiki/lib/tpl/${tpl.name}" + ) templates} + ${lib.concatMapStringsSep "\n" ( + plugin: "cp -r ${toString plugin} $out/share/dokuwiki/lib/plugins/${plugin.name}" + ) plugins} + ${isNotEmpty localConfig "ln -sf ${localConfig} $out/share/dokuwiki/conf/local.php"} + ${isNotEmpty pluginsConfig "ln -sf ${pluginsConfig} $out/share/dokuwiki/conf/plugins.local.php"} + ${isNotEmpty aclConfig "ln -sf ${aclConfig} $out/share/dokuwiki/acl.auth.php"} + ''; + }); tests = { inherit (nixosTests) dokuwiki; }; diff --git a/pkgs/by-name/do/dolbybcsoftwaredecode/package.nix b/pkgs/by-name/do/dolbybcsoftwaredecode/package.nix index 1e54e25ec98aa3..a4d6c750a314ca 100644 --- a/pkgs/by-name/do/dolbybcsoftwaredecode/package.nix +++ b/pkgs/by-name/do/dolbybcsoftwaredecode/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, stdenv, unzip, fpc }: +{ + lib, + fetchurl, + stdenv, + unzip, + fpc, +}: stdenv.mkDerivation rec { pname = "dolbybcsoftwaredecode"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-uLcsRIpwmJlstlGV8I4+/30+D9GDpUt7DOIP/GkXWp4="; }; - nativeBuildInputs = [ unzip fpc ]; + nativeBuildInputs = [ + unzip + fpc + ]; buildPhase = '' fpc DolbyBi64.PP ''; diff --git a/pkgs/by-name/do/dolibarr/package.nix b/pkgs/by-name/do/dolibarr/package.nix index 763180a516b455..81660a85cf2f98 100644 --- a/pkgs/by-name/do/dolibarr/package.nix +++ b/pkgs/by-name/do/dolibarr/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, nixosTests, stateDir ? "/var/lib/dolibarr" }: +{ + stdenv, + lib, + fetchFromGitHub, + nixosTests, + stateDir ? "/var/lib/dolibarr", +}: stdenv.mkDerivation rec { pname = "dolibarr"; diff --git a/pkgs/by-name/do/domination/package.nix b/pkgs/by-name/do/domination/package.nix index 232a8d7b23c8ef..4b236657ba25b2 100644 --- a/pkgs/by-name/do/domination/package.nix +++ b/pkgs/by-name/do/domination/package.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, fetchsvn -# jdk8 is needed for building, but the game runs on newer jres as well -, jdk8 -, jre -, ant -, stripJavaArchivesHook -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, nixosTests +{ + lib, + stdenv, + fetchsvn, + # jdk8 is needed for building, but the game runs on newer jres as well + jdk8, + jre, + ant, + stripJavaArchivesHook, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + nixosTests, }: let @@ -25,7 +27,8 @@ let icon = "domination"; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "domination"; version = "1.3.1"; @@ -105,7 +108,7 @@ in stdenv.mkDerivation { ''; sourceProvenance = with sourceTypes; [ fromSource - binaryBytecode # source bundles dependencies as jars + binaryBytecode # source bundles dependencies as jars ]; license = licenses.gpl3Plus; mainProgram = "domination"; diff --git a/pkgs/by-name/do/domine/package.nix b/pkgs/by-name/do/domine/package.nix index a85275acab0e8c..dbf77009577f36 100644 --- a/pkgs/by-name/do/domine/package.nix +++ b/pkgs/by-name/do/domine/package.nix @@ -1,4 +1,8 @@ -{ buildDartApplication, fetchFromGitHub, lib }: +{ + buildDartApplication, + fetchFromGitHub, + lib, +}: buildDartApplication rec { pname = "domine"; diff --git a/pkgs/by-name/do/domoticz/package.nix b/pkgs/by-name/do/domoticz/package.nix index 7f89645b3f9703..ac98513ac698da 100644 --- a/pkgs/by-name/do/domoticz/package.nix +++ b/pkgs/by-name/do/domoticz/package.nix @@ -1,4 +1,6 @@ -{ lib, stdenv, +{ + lib, + stdenv, fetchFromGitHub, makeWrapper, cmake, @@ -14,7 +16,7 @@ curl, git, libusb-compat-0_1, - cereal + cereal, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/do/done/package.nix b/pkgs/by-name/do/done/package.nix index 095d77b1ee8354..7c44157b21d8b2 100644 --- a/pkgs/by-name/do/done/package.nix +++ b/pkgs/by-name/do/done/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, cargo -, glib -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, wrapGAppsHook4 -, gdk-pixbuf -, gtk4 -, libadwaita -, libsecret -, openssl -, sqlite -, darwin -, gettext +{ + lib, + stdenv, + fetchFromGitHub, + cargo, + glib, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + wrapGAppsHook4, + gdk-pixbuf, + gtk4, + libadwaita, + libsecret, + openssl, + sqlite, + darwin, + gettext, }: stdenv.mkDerivation rec { @@ -47,16 +48,18 @@ stdenv.mkDerivation rec { wrapGAppsHook4 ]; - buildInputs = [ - gdk-pixbuf - gtk4 - libadwaita - libsecret - openssl - sqlite - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AppKit - ]; + buildInputs = + [ + gdk-pixbuf + gtk4 + libadwaita + libsecret + openssl + sqlite + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AppKit + ]; env = lib.optionalAttrs stdenv.hostPlatform.isDarwin { GETTEXT_DIR = gettext; diff --git a/pkgs/by-name/do/donkey/package.nix b/pkgs/by-name/do/donkey/package.nix index e481744ee7d577..5d039a42fcf04d 100644 --- a/pkgs/by-name/do/donkey/package.nix +++ b/pkgs/by-name/do/donkey/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, fetchFromGitLab -, libmd -, coreutils -, lib -, testers +{ + stdenv, + fetchFromGitLab, + libmd, + coreutils, + lib, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -31,19 +32,19 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Alternative for S/KEY's 'key' command"; longDescription = '' -Donkey is an alternative for S/KEY's "key" command. The new feature that -the original key doesn't have is print an entry for skeykeys as -follows; + Donkey is an alternative for S/KEY's "key" command. The new feature that + the original key doesn't have is print an entry for skeykeys as + follows; - kazu 0099 al02004 115d83956f1089b6 Apr 26,1995 22:13:27 + kazu 0099 al02004 115d83956f1089b6 Apr 26,1995 22:13:27 -This means that donkey is also an alternative for "keyinit". Since the -entry is printed to stdout (not to /etc/skeykeys), you can easily send -it to a remote operator by e-mail (with a PGP signature or something). -So, it is possible to initiate S/KEY without logging in from the console of -the host. + This means that donkey is also an alternative for "keyinit". Since the + entry is printed to stdout (not to /etc/skeykeys), you can easily send + it to a remote operator by e-mail (with a PGP signature or something). + So, it is possible to initiate S/KEY without logging in from the console of + the host. -The name "Donkey" is an acronym of "Don't Key". + The name "Donkey" is an acronym of "Don't Key". ''; homepage = "https://devel.ringlet.net/security/donkey"; license = licenses.gpl2Only; diff --git a/pkgs/by-name/do/donpapi/package.nix b/pkgs/by-name/do/donpapi/package.nix index c2a777b3dc4313..e8c62da2fcaeeb 100644 --- a/pkgs/by-name/do/donpapi/package.nix +++ b/pkgs/by-name/do/donpapi/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/do/dontgo403/package.nix b/pkgs/by-name/do/dontgo403/package.nix index 7fab0dac0425f9..12f81ebbb24148 100644 --- a/pkgs/by-name/do/dontgo403/package.nix +++ b/pkgs/by-name/do/dontgo403/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/do/doodle/package.nix b/pkgs/by-name/do/doodle/package.nix index ced330bd647ed7..40e42515039311 100644 --- a/pkgs/by-name/do/doodle/package.nix +++ b/pkgs/by-name/do/doodle/package.nix @@ -1,10 +1,19 @@ -{ lib, stdenv, fetchurl, libextractor, gettext }: +{ + lib, + stdenv, + fetchurl, + libextractor, + gettext, +}: stdenv.mkDerivation rec { pname = "doodle"; version = "0.7.3"; - buildInputs = [ libextractor gettext ]; + buildInputs = [ + libextractor + gettext + ]; src = fetchurl { url = "https://grothoff.org/christian/doodle/download/doodle-${version}.tar.gz"; diff --git a/pkgs/by-name/do/dool/package.nix b/pkgs/by-name/do/dool/package.nix index b7ff128131e85d..fb3f22885a9ce8 100644 --- a/pkgs/by-name/do/dool/package.nix +++ b/pkgs/by-name/do/dool/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + python3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/do/doona/package.nix b/pkgs/by-name/do/doona/package.nix index bc890d52abb5a6..55ce8e4e96b78b 100644 --- a/pkgs/by-name/do/doona/package.nix +++ b/pkgs/by-name/do/doona/package.nix @@ -1,6 +1,8 @@ -{ fetchFromGitHub -, lib, stdenv -, perl +{ + fetchFromGitHub, + lib, + stdenv, + perl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/do/door-knocker/package.nix b/pkgs/by-name/do/door-knocker/package.nix index c45ff499c3911a..ea8df94b01b3cb 100644 --- a/pkgs/by-name/do/door-knocker/package.nix +++ b/pkgs/by-name/do/door-knocker/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitea -, blueprint-compiler -, desktop-file-utils -, glib -, gtk4 -, libadwaita -, meson -, ninja -, pkg-config -, wrapGAppsHook4 +{ + stdenv, + lib, + fetchFromGitea, + blueprint-compiler, + desktop-file-utils, + glib, + gtk4, + libadwaita, + meson, + ninja, + pkg-config, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/do/dopewars/package.nix b/pkgs/by-name/do/dopewars/package.nix index 8f550abc8e2d2c..3618dbc19fa0c9 100644 --- a/pkgs/by-name/do/dopewars/package.nix +++ b/pkgs/by-name/do/dopewars/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, makeWrapper -, curl -, ncurses -, gtk3 -, pkg-config -, scoreDirectory ? "$HOME/.local/share" +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + makeWrapper, + curl, + ncurses, + gtk3, + pkg-config, + scoreDirectory ? "$HOME/.local/share", }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/do/doppler/package.nix b/pkgs/by-name/do/doppler/package.nix index b9fe13814dc77e..2c64639e4db3de 100644 --- a/pkgs/by-name/do/doppler/package.nix +++ b/pkgs/by-name/do/doppler/package.nix @@ -1,10 +1,11 @@ -{ buildGoModule -, doppler -, fetchFromGitHub -, installShellFiles -, lib -, testers -, stdenv +{ + buildGoModule, + doppler, + fetchFromGitHub, + installShellFiles, + lib, + testers, + stdenv, }: buildGoModule rec { @@ -27,16 +28,18 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - postInstall = '' - mv $out/bin/cli $out/bin/doppler - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - export HOME=$TMPDIR - mkdir $HOME/.doppler # to avoid race conditions below - installShellCompletion --cmd doppler \ - --bash <($out/bin/doppler completion bash) \ - --fish <($out/bin/doppler completion fish) \ - --zsh <($out/bin/doppler completion zsh) - ''; + postInstall = + '' + mv $out/bin/cli $out/bin/doppler + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + export HOME=$TMPDIR + mkdir $HOME/.doppler # to avoid race conditions below + installShellCompletion --cmd doppler \ + --bash <($out/bin/doppler completion bash) \ + --fish <($out/bin/doppler completion fish) \ + --zsh <($out/bin/doppler completion zsh) + ''; passthru.tests.version = testers.testVersion { package = doppler; diff --git a/pkgs/by-name/do/doq/package.nix b/pkgs/by-name/do/doq/package.nix index 78672046509710..4427fe31064300 100644 --- a/pkgs/by-name/do/doq/package.nix +++ b/pkgs/by-name/do/doq/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/do/dorkscout/package.nix b/pkgs/by-name/do/dorkscout/package.nix index 57ba965033bb4d..28991f77b5f2ef 100644 --- a/pkgs/by-name/do/dorkscout/package.nix +++ b/pkgs/by-name/do/dorkscout/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/do/dos2unix/package.nix b/pkgs/by-name/do/dos2unix/package.nix index 9785b21e0dcb3d..cd35d1d5fd8cb1 100644 --- a/pkgs/by-name/do/dos2unix/package.nix +++ b/pkgs/by-name/do/dos2unix/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, perl, gettext }: +{ + lib, + stdenv, + fetchurl, + perl, + gettext, +}: stdenv.mkDerivation rec { pname = "dos2unix"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-JkdCRGYIRC60j5bCCvbaMDyzqSs2TnLLfiT4gjnEvzo="; }; - nativeBuildInputs = [ perl gettext ]; + nativeBuildInputs = [ + perl + gettext + ]; makeFlags = [ "prefix=${placeholder "out"}" ]; meta = with lib; { diff --git a/pkgs/by-name/do/dosemu_fonts/package.nix b/pkgs/by-name/do/dosemu_fonts/package.nix index 7de0e6d0602732..8b568e3efd6cd1 100644 --- a/pkgs/by-name/do/dosemu_fonts/package.nix +++ b/pkgs/by-name/do/dosemu_fonts/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, bdftopcf, mkfontdir, mkfontscale }: +{ + lib, + stdenv, + fetchurl, + bdftopcf, + mkfontdir, + mkfontscale, +}: stdenv.mkDerivation rec { pname = "dosemu-fonts"; diff --git a/pkgs/by-name/do/dosfstools/package.nix b/pkgs/by-name/do/dosfstools/package.nix index 0305e651464047..9446485273d308 100644 --- a/pkgs/by-name/do/dosfstools/package.nix +++ b/pkgs/by-name/do/dosfstools/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, pkg-config, libiconv, gettext, xxd }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + libiconv, + gettext, + xxd, +}: stdenv.mkDerivation rec { pname = "dosfstools"; @@ -31,8 +41,10 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ] - ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ] ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; # configure.ac:75: error: required file './config.rpath' not found # https://github.com/dosfstools/dosfstools/blob/master/autogen.sh diff --git a/pkgs/by-name/do/dosis/package.nix b/pkgs/by-name/do/dosis/package.nix index 5a9470a43ec8ee..8ccf74ba93c14e 100644 --- a/pkgs/by-name/do/dosis/package.nix +++ b/pkgs/by-name/do/dosis/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "dosis"; diff --git a/pkgs/by-name/do/dot-language-server/package.nix b/pkgs/by-name/do/dot-language-server/package.nix index 98d76d8d1aaab6..cb94613eb58890 100644 --- a/pkgs/by-name/do/dot-language-server/package.nix +++ b/pkgs/by-name/do/dot-language-server/package.nix @@ -1,4 +1,8 @@ -{ lib, buildNpmPackage, fetchFromGitHub }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, +}: buildNpmPackage rec { pname = "dot-language-server"; diff --git a/pkgs/by-name/do/dotacat/package.nix b/pkgs/by-name/do/dotacat/package.nix index 2512ff20d8d577..da6ab11c5548c0 100644 --- a/pkgs/by-name/do/dotacat/package.nix +++ b/pkgs/by-name/do/dotacat/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitLab +{ + lib, + rustPlatform, + fetchFromGitLab, }: rustPlatform.buildRustPackage { diff --git a/pkgs/by-name/do/dotcolon-fonts/package.nix b/pkgs/by-name/do/dotcolon-fonts/package.nix index fcd439ce30c74f..23239b5593f305 100644 --- a/pkgs/by-name/do/dotcolon-fonts/package.nix +++ b/pkgs/by-name/do/dotcolon-fonts/package.nix @@ -1,19 +1,20 @@ -{ lib -, symlinkJoin -, aileron -, vegur -, f5_6 -, tenderness -, medio -, ferrum -, seshat -, penna -, eunomia -, route159 -, f1_8 -, nacelle -, melete -, fa_1 +{ + lib, + symlinkJoin, + aileron, + vegur, + f5_6, + tenderness, + medio, + ferrum, + seshat, + penna, + eunomia, + route159, + f1_8, + nacelle, + melete, + fa_1, }: symlinkJoin { @@ -41,7 +42,10 @@ symlinkJoin { homepage = "https://dotcolon.net/"; - license = with lib.licenses; [ cc0 ofl ]; + license = with lib.licenses; [ + cc0 + ofl + ]; platforms = lib.platforms.all; maintainers = with lib.maintainers; [ minijackson ]; diff --git a/pkgs/by-name/do/dotconf/package.nix b/pkgs/by-name/do/dotconf/package.nix index eda770f7e090cc..02d999ce46d5df 100644 --- a/pkgs/by-name/do/dotconf/package.nix +++ b/pkgs/by-name/do/dotconf/package.nix @@ -1,4 +1,9 @@ -{ fetchFromGitHub, lib, stdenv, autoreconfHook }: +{ + fetchFromGitHub, + lib, + stdenv, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "dotconf"; diff --git a/pkgs/by-name/do/dotenvy/package.nix b/pkgs/by-name/do/dotenvy/package.nix index 210f75fe8cd345..97b4b1a4a42f39 100644 --- a/pkgs/by-name/do/dotenvy/package.nix +++ b/pkgs/by-name/do/dotenvy/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchCrate, rustPlatform }: +{ + lib, + fetchCrate, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "dotenvy"; @@ -11,7 +15,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-qjFTv15FSvgYgQ4nTEIo0KUqaCbg6E+W5B2B5BH6sp4="; - cargoBuildFlags = [ "--bin=dotenvy" "--features=cli" ]; + cargoBuildFlags = [ + "--bin=dotenvy" + "--features=cli" + ]; # just run unittests and skip doc-tests cargoTestFlags = [ "--lib" ]; diff --git a/pkgs/by-name/do/dotfiles/package.nix b/pkgs/by-name/do/dotfiles/package.nix index 655aa60b27cc11..d901548326ba83 100644 --- a/pkgs/by-name/do/dotfiles/package.nix +++ b/pkgs/by-name/do/dotfiles/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "dotfiles"; diff --git a/pkgs/by-name/do/dotnetbuildhelpers/package.nix b/pkgs/by-name/do/dotnetbuildhelpers/package.nix index 4348832ac04c70..8ce5e346be8193 100644 --- a/pkgs/by-name/do/dotnetbuildhelpers/package.nix +++ b/pkgs/by-name/do/dotnetbuildhelpers/package.nix @@ -1,18 +1,19 @@ -{ runCommand, mono, pkg-config }: - runCommand - "dotnetbuildhelpers" - { preferLocalBuild = true; } - '' - target="$out/bin" - mkdir -p "$target" +{ + runCommand, + mono, + pkg-config, +}: +runCommand "dotnetbuildhelpers" { preferLocalBuild = true; } '' + target="$out/bin" + mkdir -p "$target" - for script in ${./create-pkg-config-for-dll.sh} ${./patch-fsharp-targets.sh} ${./remove-duplicated-dlls.sh} ${./placate-nuget.sh} ${./placate-paket.sh} - do - scriptName="$(basename "$script" | cut -f 2- -d -)" - cp -v "$script" "$target"/"$scriptName" - chmod 755 "$target"/"$scriptName" - patchShebangs "$target"/"$scriptName" - substituteInPlace "$target"/"$scriptName" --replace pkg-config ${pkg-config}/bin/${pkg-config.targetPrefix}pkg-config - substituteInPlace "$target"/"$scriptName" --replace monodis ${mono}/bin/monodis - done - '' + for script in ${./create-pkg-config-for-dll.sh} ${./patch-fsharp-targets.sh} ${./remove-duplicated-dlls.sh} ${./placate-nuget.sh} ${./placate-paket.sh} + do + scriptName="$(basename "$script" | cut -f 2- -d -)" + cp -v "$script" "$target"/"$scriptName" + chmod 755 "$target"/"$scriptName" + patchShebangs "$target"/"$scriptName" + substituteInPlace "$target"/"$scriptName" --replace pkg-config ${pkg-config}/bin/${pkg-config.targetPrefix}pkg-config + substituteInPlace "$target"/"$scriptName" --replace monodis ${mono}/bin/monodis + done +'' diff --git a/pkgs/by-name/do/dotool/package.nix b/pkgs/by-name/do/dotool/package.nix index ac71a666ac6358..7cbadfcbee3423 100644 --- a/pkgs/by-name/do/dotool/package.nix +++ b/pkgs/by-name/do/dotool/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromSourcehut -, libxkbcommon -, pkg-config -, installShellFiles -, scdoc +{ + lib, + buildGoModule, + fetchFromSourcehut, + libxkbcommon, + pkg-config, + installShellFiles, + scdoc, }: buildGoModule rec { @@ -29,9 +30,17 @@ buildGoModule rec { ''; buildInputs = [ libxkbcommon ]; - nativeBuildInputs = [ installShellFiles pkg-config scdoc ]; - - ldflags = [ "-s" "-w" "-X main.Version=${version}" ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + scdoc + ]; + + ldflags = [ + "-s" + "-w" + "-X main.Version=${version}" + ]; postInstall = '' mkdir -p $out/bin diff --git a/pkgs/by-name/do/dotslash/package.nix b/pkgs/by-name/do/dotslash/package.nix index 6583539267257b..8fe0c96c818713 100644 --- a/pkgs/by-name/do/dotslash/package.nix +++ b/pkgs/by-name/do/dotslash/package.nix @@ -1,5 +1,10 @@ -{ lib, rustPlatform, fetchCrate -, testers, nix-update-script, dotslash +{ + lib, + rustPlatform, + fetchCrate, + testers, + nix-update-script, + dotslash, }: rustPlatform.buildRustPackage rec { @@ -33,7 +38,10 @@ rustPlatform.buildRustPackage rec { your developers seamlessly get the tools they need, ensuring consistent builds across platforms. ''; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; mainProgram = "dotslash"; maintainers = with maintainers; [ thoughtpolice ]; }; diff --git a/pkgs/by-name/do/double-conversion/package.nix b/pkgs/by-name/do/double-conversion/package.nix index 857bb48c11543a..40f87f1ec44426 100644 --- a/pkgs/by-name/do/double-conversion/package.nix +++ b/pkgs/by-name/do/double-conversion/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, cmake, enableStatic ? stdenv.hostPlatform.isStatic }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + enableStatic ? stdenv.hostPlatform.isStatic, +}: stdenv.mkDerivation rec { pname = "double-conversion"; @@ -13,7 +19,7 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - cmakeFlags = lib.optional (! enableStatic) "-DBUILD_SHARED_LIBS=ON"; + cmakeFlags = lib.optional (!enableStatic) "-DBUILD_SHARED_LIBS=ON"; # Case sensitivity issue preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin '' diff --git a/pkgs/by-name/do/doublecmd/package.nix b/pkgs/by-name/do/doublecmd/package.nix index db12c0f1c90ffb..4c9f7e3d49cc45 100644 --- a/pkgs/by-name/do/doublecmd/package.nix +++ b/pkgs/by-name/do/doublecmd/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, dbus -, fpc -, getopt -, glib -, lazarus -, libX11 -, libqt5pas -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + dbus, + fpc, + getopt, + glib, + lazarus, + libX11, + libqt5pas, + wrapQtAppsHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/do/doulos-sil/package.nix b/pkgs/by-name/do/doulos-sil/package.nix index d4a21382bbfaa7..b275d6e0df2541 100644 --- a/pkgs/by-name/do/doulos-sil/package.nix +++ b/pkgs/by-name/do/doulos-sil/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "doulos-sil"; diff --git a/pkgs/by-name/do/dovecot_exporter/package.nix b/pkgs/by-name/do/dovecot_exporter/package.nix index 2ef6fd97d8dbb8..4c836ff85038cc 100644 --- a/pkgs/by-name/do/dovecot_exporter/package.nix +++ b/pkgs/by-name/do/dovecot_exporter/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + nixosTests, }: buildGoModule rec { pname = "dovecot_exporter"; @@ -33,6 +34,9 @@ buildGoModule rec { description = "Prometheus metrics exporter for Dovecot"; mainProgram = "dovecot_exporter"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ willibutz globin ]; + maintainers = with lib.maintainers; [ + willibutz + globin + ]; }; } diff --git a/pkgs/by-name/do/dovecot_fts_xapian/package.nix b/pkgs/by-name/do/dovecot_fts_xapian/package.nix index debe1fb8cbb6a0..5739d5fff0096b 100644 --- a/pkgs/by-name/do/dovecot_fts_xapian/package.nix +++ b/pkgs/by-name/do/dovecot_fts_xapian/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, sqlite, pkg-config, dovecot, xapian, icu }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + sqlite, + pkg-config, + dovecot, + xapian, + icu, +}: stdenv.mkDerivation rec { pname = "dovecot-fts-xapian"; @@ -11,9 +21,16 @@ stdenv.mkDerivation rec { hash = "sha256-WKUHy9/PpaDSgZYyydCm5odo3kAb2M/50oVdLjGRQ6I="; }; - buildInputs = [ xapian icu sqlite ]; + buildInputs = [ + xapian + icu + sqlite + ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; preConfigure = '' export PANDOC=false @@ -29,7 +46,10 @@ stdenv.mkDerivation rec { description = "Dovecot FTS plugin based on Xapian"; changelog = "https://github.com/grosjo/fts-xapian/releases"; license = licenses.lgpl21Only; - maintainers = with maintainers; [ julm symphorien ]; + maintainers = with maintainers; [ + julm + symphorien + ]; platforms = platforms.unix; broken = stdenv.hostPlatform.isDarwin; # never built on Hydra https://hydra.nixos.org/job/nixpkgs/trunk/dovecot_fts_xapian.x86_64-darwin }; diff --git a/pkgs/by-name/do/dovecot_pigeonhole/package.nix b/pkgs/by-name/do/dovecot_pigeonhole/package.nix index 5ed0d4be3ed16b..9db66908806f5c 100644 --- a/pkgs/by-name/do/dovecot_pigeonhole/package.nix +++ b/pkgs/by-name/do/dovecot_pigeonhole/package.nix @@ -1,7 +1,14 @@ -{ lib, stdenv, fetchurl, dovecot, openssl }: +{ + lib, + stdenv, + fetchurl, + dovecot, + openssl, +}: let dovecotMajorMinor = lib.versions.majorMinor dovecot.version; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "dovecot-pigeonhole"; version = "0.5.21.1"; @@ -10,7 +17,10 @@ in stdenv.mkDerivation rec { hash = "sha256-A3fbKEtiByPeBgQxEV+y53keHfQyFBGvcYIB1pJcRpI="; }; - buildInputs = [ dovecot openssl ]; + buildInputs = [ + dovecot + openssl + ]; preConfigure = '' substituteInPlace src/managesieve/managesieve-settings.c --replace \ diff --git a/pkgs/by-name/do/downonspot/package.nix b/pkgs/by-name/do/downonspot/package.nix index aaf49a13d26a8f..3f6ea6bdc7d28f 100644 --- a/pkgs/by-name/do/downonspot/package.nix +++ b/pkgs/by-name/do/downonspot/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, makeWrapper -, alsa-lib -, lame -, openssl +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + makeWrapper, + alsa-lib, + lame, + openssl, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/do/dozenal/package.nix b/pkgs/by-name/do/dozenal/package.nix index 5991f260f53ea4..4cef1375f4e8bd 100644 --- a/pkgs/by-name/do/dozenal/package.nix +++ b/pkgs/by-name/do/dozenal/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, ncurses, hdate, lua5_2 }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + hdate, + lua5_2, +}: stdenv.mkDerivation rec { version = "12010904"; @@ -10,17 +17,21 @@ stdenv.mkDerivation rec { sha256 = "1ic63gpdda762x6ks3al71dwgmsy2isicqyr2935bd245jx8s209"; }; makeFlags = [ - # author do not use configure and prefix directly using $prefix - "prefix=$(out)" - # graphical version of dozdc requires xforms, which is not i nixpkgs so I turned it down - "XFORMS_FLAGS=-UXFORMS" - "LUALIB=-llua" - "bindir=$(prefix)/bin/" - ]; + # author do not use configure and prefix directly using $prefix + "prefix=$(out)" + # graphical version of dozdc requires xforms, which is not i nixpkgs so I turned it down + "XFORMS_FLAGS=-UXFORMS" + "LUALIB=-llua" + "bindir=$(prefix)/bin/" + ]; # some include hardcodes the lua libraries path. This is a patch for that patches = [ ./lua-header.patch ]; preBuild = "cd dozenal"; - buildInputs = [ ncurses hdate lua5_2 ]; + buildInputs = [ + ncurses + hdate + lua5_2 + ]; # Parallel builds fail due to no dependencies between subdirs. # As a result some subdirs are atempted to build twice: diff --git a/pkgs/by-name/dp/dpic/package.nix b/pkgs/by-name/dp/dpic/package.nix index ff2f7c24f8f534..fb5acef4157df2 100644 --- a/pkgs/by-name/dp/dpic/package.nix +++ b/pkgs/by-name/dp/dpic/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "dpic"; @@ -21,4 +25,3 @@ stdenv.mkDerivation rec { mainProgram = "dpic"; }; } - diff --git a/pkgs/by-name/dp/dpp/package.nix b/pkgs/by-name/dp/dpp/package.nix index d6a55fcceb59a7..47d162ab565fb7 100644 --- a/pkgs/by-name/dp/dpp/package.nix +++ b/pkgs/by-name/dp/dpp/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, fetchFromGitHub -, cmake -, libopus -, openssl -, zlib -, libsodium -, pkg-config -, lib +{ + stdenv, + fetchFromGitHub, + cmake, + libopus, + openssl, + zlib, + libsodium, + pkg-config, + lib, }: stdenv.mkDerivation (finalAttrs: { pname = "dpp"; diff --git a/pkgs/by-name/dp/dps8m/package.nix b/pkgs/by-name/dp/dps8m/package.nix index a31c95eb416572..be699921829c73 100644 --- a/pkgs/by-name/dp/dps8m/package.nix +++ b/pkgs/by-name/dp/dps8m/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitLab -, libuv -, coreutils-full -, pkg-config -, gnugrep -, gnused +{ + lib, + stdenv, + fetchFromGitLab, + libuv, + coreutils-full, + pkg-config, + gnugrep, + gnused, }: stdenv.mkDerivation rec { @@ -41,7 +42,10 @@ stdenv.mkDerivation rec { homepage = "https://gitlab.com/dps8m/dps8m"; changelog = "https://gitlab.com/dps8m/dps8m/-/wikis/DPS8M-${src.rev}-Release-Notes"; license = licenses.icu; - maintainers = with maintainers; [ matthewcroughan sarcasticadmin ]; + maintainers = with maintainers; [ + matthewcroughan + sarcasticadmin + ]; mainProgram = "dps8m"; platforms = platforms.all; }; diff --git a/pkgs/by-name/dp/dpt-rp1-py/package.nix b/pkgs/by-name/dp/dpt-rp1-py/package.nix index 5f1e53f8105fbe..27be986648ef5c 100644 --- a/pkgs/by-name/dp/dpt-rp1-py/package.nix +++ b/pkgs/by-name/dp/dpt-rp1-py/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "dpt-rp1-py"; version = "0.1.16"; diff --git a/pkgs/by-name/dq/dq/package.nix b/pkgs/by-name/dq/dq/package.nix index 93a260c1d90ac8..60e5b429896ced 100644 --- a/pkgs/by-name/dq/dq/package.nix +++ b/pkgs/by-name/dq/dq/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "dq"; diff --git a/pkgs/by-name/dr/dr14_tmeter/package.nix b/pkgs/by-name/dr/dr14_tmeter/package.nix index 90ce4b28a0d4d5..fe141c096fb185 100644 --- a/pkgs/by-name/dr/dr14_tmeter/package.nix +++ b/pkgs/by-name/dr/dr14_tmeter/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, python3Packages, pkgs }: +{ + lib, + fetchFromGitHub, + python3Packages, + pkgs, +}: python3Packages.buildPythonApplication rec { pname = "dr14_tmeter"; @@ -14,7 +19,12 @@ python3Packages.buildPythonApplication rec { }; propagatedBuildInputs = with pkgs; [ - python3Packages.numpy flac vorbis-tools ffmpeg faad2 lame + python3Packages.numpy + flac + vorbis-tools + ffmpeg + faad2 + lame ]; # There are no tests diff --git a/pkgs/by-name/dr/dracula-icon-theme/package.nix b/pkgs/by-name/dr/dracula-icon-theme/package.nix index 4a6fe773f471d8..92441b185ed402 100644 --- a/pkgs/by-name/dr/dracula-icon-theme/package.nix +++ b/pkgs/by-name/dr/dracula-icon-theme/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchFromGitHub, jdupes }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + jdupes, +}: stdenvNoCC.mkDerivation { pname = "dracula-icon-theme"; diff --git a/pkgs/by-name/dr/dracula-qt5-theme/package.nix b/pkgs/by-name/dr/dracula-qt5-theme/package.nix index 5a618c9618bcd5..57085a65ecd3f4 100644 --- a/pkgs/by-name/dr/dracula-qt5-theme/package.nix +++ b/pkgs/by-name/dr/dracula-qt5-theme/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "dracula-theme"; diff --git a/pkgs/by-name/dr/dracula-theme/package.nix b/pkgs/by-name/dr/dracula-theme/package.nix index 42eb10effc9e9e..5b1cc00383d4a9 100644 --- a/pkgs/by-name/dr/dracula-theme/package.nix +++ b/pkgs/by-name/dr/dracula-theme/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenvNoCC, fetchFromGitHub, unstableGitUpdater, gtk-engine-murrine }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + unstableGitUpdater, + gtk-engine-murrine, +}: let themeName = "Dracula"; diff --git a/pkgs/by-name/dr/dracut/package.nix b/pkgs/by-name/dr/dracut/package.nix index c915222b1d786e..071a70095adff9 100644 --- a/pkgs/by-name/dr/dracut/package.nix +++ b/pkgs/by-name/dr/dracut/package.nix @@ -1,29 +1,30 @@ -{ stdenv -, lib -, fetchFromGitHub -, gitUpdater -, makeBinaryWrapper -, pkg-config -, asciidoc -, libxslt -, docbook_xsl -, bash -, kmod -, binutils -, bzip2 -, coreutils -, cpio -, findutils -, gnugrep -, gnused -, gnutar -, gzip -, lz4 -, lzop -, squashfsTools -, util-linux -, xz -, zstd +{ + stdenv, + lib, + fetchFromGitHub, + gitUpdater, + makeBinaryWrapper, + pkg-config, + asciidoc, + libxslt, + docbook_xsl, + bash, + kmod, + binutils, + bzip2, + coreutils, + cpio, + findutils, + gnugrep, + gnused, + gnutar, + gzip, + lz4, + lzop, + squashfsTools, + util-linux, + xz, + zstd, }: stdenv.mkDerivation rec { @@ -62,40 +63,48 @@ stdenv.mkDerivation rec { ''; postFixup = '' - wrapProgram $out/bin/dracut --prefix PATH : ${lib.makeBinPath [ - coreutils - util-linux - ]} --suffix DRACUT_PATH : ${lib.makeBinPath [ - bash - binutils - coreutils - findutils - gnugrep - gnused - gnutar - stdenv.cc.libc # for ldd command - util-linux - ]} - wrapProgram $out/bin/dracut-catimages --set PATH ${lib.makeBinPath [ - coreutils - cpio - findutils - gzip - ]} - wrapProgram $out/bin/lsinitrd --set PATH ${lib.makeBinPath [ - binutils - bzip2 - coreutils - cpio - gnused - gzip - lz4 - lzop - squashfsTools - util-linux - xz - zstd - ]} + wrapProgram $out/bin/dracut --prefix PATH : ${ + lib.makeBinPath [ + coreutils + util-linux + ] + } --suffix DRACUT_PATH : ${ + lib.makeBinPath [ + bash + binutils + coreutils + findutils + gnugrep + gnused + gnutar + stdenv.cc.libc # for ldd command + util-linux + ] + } + wrapProgram $out/bin/dracut-catimages --set PATH ${ + lib.makeBinPath [ + coreutils + cpio + findutils + gzip + ] + } + wrapProgram $out/bin/lsinitrd --set PATH ${ + lib.makeBinPath [ + binutils + bzip2 + coreutils + cpio + gnused + gzip + lz4 + lzop + squashfsTools + util-linux + xz + zstd + ] + } ''; passthru.updateScript = gitUpdater { }; diff --git a/pkgs/by-name/dr/dragonfly-reverb/package.nix b/pkgs/by-name/dr/dragonfly-reverb/package.nix index 3ec98c9bd71728..f741bcb7c02c6a 100644 --- a/pkgs/by-name/dr/dragonfly-reverb/package.nix +++ b/pkgs/by-name/dr/dragonfly-reverb/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libjack2, libGL, pkg-config, xorg }: +{ + lib, + stdenv, + fetchFromGitHub, + libjack2, + libGL, + pkg-config, + xorg, +}: stdenv.mkDerivation rec { pname = "dragonfly-reverb"; @@ -18,7 +26,9 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - libjack2 xorg.libX11 libGL + libjack2 + xorg.libX11 + libGL ]; installPhase = '' @@ -40,6 +50,6 @@ stdenv.mkDerivation rec { description = "Hall-style reverb based on freeverb3 algorithms"; maintainers = [ maintainers.magnetophon ]; license = licenses.gpl3Plus; - platforms = ["x86_64-linux"]; + platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/by-name/dr/dragonflydb/package.nix b/pkgs/by-name/dr/dragonflydb/package.nix index 2d949fc78a45d0..5a38c54c07e78c 100644 --- a/pkgs/by-name/dr/dragonflydb/package.nix +++ b/pkgs/by-name/dr/dragonflydb/package.nix @@ -1,27 +1,28 @@ -{ fetchFromGitHub -, fetchurl -, lib -, stdenv -, double-conversion -, gperftools -, mimalloc -, rapidjson -, liburing -, xxHash -, gbenchmark -, glog -, gtest -, jemalloc -, gcc-unwrapped -, autoconf -, autoconf-archive -, automake -, cmake -, ninja -, boost -, libunwind -, libtool -, openssl +{ + fetchFromGitHub, + fetchurl, + lib, + stdenv, + double-conversion, + gperftools, + mimalloc, + rapidjson, + liburing, + xxHash, + gbenchmark, + glog, + gtest, + jemalloc, + gcc-unwrapped, + autoconf, + autoconf-archive, + automake, + cmake, + ninja, + boost, + libunwind, + libtool, + openssl, }: let diff --git a/pkgs/by-name/dr/drat-trim/package.nix b/pkgs/by-name/dr/drat-trim/package.nix index fb8468f4fbda65..c4070e3f45e7e7 100644 --- a/pkgs/by-name/dr/drat-trim/package.nix +++ b/pkgs/by-name/dr/drat-trim/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "drat-trim"; diff --git a/pkgs/by-name/dr/drawing/package.nix b/pkgs/by-name/dr/drawing/package.nix index 6f464a1ec0b4ae..b41473f8867d6a 100644 --- a/pkgs/by-name/dr/drawing/package.nix +++ b/pkgs/by-name/dr/drawing/package.nix @@ -1,19 +1,20 @@ -{ lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, python3 -, gtk3 -, appstream-glib -, desktop-file-utils -, gobject-introspection -, wrapGAppsHook3 -, glib -, gdk-pixbuf -, pango -, gettext -, itstool +{ + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + python3, + gtk3, + appstream-glib, + desktop-file-utils, + gobject-introspection, + wrapGAppsHook3, + glib, + gdk-pixbuf, + pango, + gettext, + itstool, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/dr/dreamchess/package.nix b/pkgs/by-name/dr/dreamchess/package.nix index 65df152c7a16fc..21622ff9aefbcc 100644 --- a/pkgs/by-name/dr/dreamchess/package.nix +++ b/pkgs/by-name/dr/dreamchess/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, bison -, flex -, gettext -, SDL2 -, SDL2_image -, SDL2_mixer -, expat -, glew -, freetype -, libSM -, libXext -, libGL -, libGLU -, xorg +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + bison, + flex, + gettext, + SDL2, + SDL2_image, + SDL2_mixer, + expat, + glew, + freetype, + libSM, + libXext, + libGL, + libGLU, + xorg, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/dr/driftctl/package.nix b/pkgs/by-name/dr/driftctl/package.nix index b976308c4d8aa2..9a95d19f4e4f68 100644 --- a/pkgs/by-name/dr/driftctl/package.nix +++ b/pkgs/by-name/dr/driftctl/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "driftctl"; @@ -52,6 +57,10 @@ buildGoModule rec { and fills in the missing piece in your DevSecOps toolbox. ''; license = licenses.asl20; - maintainers = with maintainers; [ kaction jk qjoly ]; + maintainers = with maintainers; [ + kaction + jk + qjoly + ]; }; } diff --git a/pkgs/by-name/dr/driftnet/package.nix b/pkgs/by-name/dr/driftnet/package.nix index 7957d90f05d3db..0a533f4211312c 100644 --- a/pkgs/by-name/dr/driftnet/package.nix +++ b/pkgs/by-name/dr/driftnet/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, autoreconfHook -, cairo -, fetchFromGitHub -, giflib -, glib -, gtk2-x11 -, libjpeg -, libpcap -, libpng -, libuv -, libwebsockets -, libwebp -, openssl -, pkg-config +{ + lib, + stdenv, + autoreconfHook, + cairo, + fetchFromGitHub, + giflib, + glib, + gtk2-x11, + libjpeg, + libpcap, + libpng, + libuv, + libwebsockets, + libwebp, + openssl, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dr/drip/package.nix b/pkgs/by-name/dr/drip/package.nix index 30684d20252f6c..217b62c251e0a5 100644 --- a/pkgs/by-name/dr/drip/package.nix +++ b/pkgs/by-name/dr/drip/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, jdk8, which, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + jdk8, + which, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "drip"; diff --git a/pkgs/by-name/dr/drive/package.nix b/pkgs/by-name/dr/drive/package.nix index c28b48bba16396..7eb4412744eec3 100644 --- a/pkgs/by-name/dr/drive/package.nix +++ b/pkgs/by-name/dr/drive/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "drive"; @@ -23,7 +28,10 @@ buildGoModule rec { subPackages = [ "cmd/drive" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/odeke-em/drive"; diff --git a/pkgs/by-name/dr/drogon/package.nix b/pkgs/by-name/dr/drogon/package.nix index eeda204d6175cf..03067cd6ec4cf0 100644 --- a/pkgs/by-name/dr/drogon/package.nix +++ b/pkgs/by-name/dr/drogon/package.nix @@ -1,11 +1,26 @@ -{ stdenv, fetchFromGitHub, cmake, jsoncpp, libossp_uuid, zlib, lib -# optional but of negligible size -, openssl, brotli, c-ares -# optional databases -, sqliteSupport ? true, sqlite -, postgresSupport ? false, postgresql -, redisSupport ? false, hiredis -, mysqlSupport ? false, libmysqlclient, mariadb }: +{ + stdenv, + fetchFromGitHub, + cmake, + jsoncpp, + libossp_uuid, + zlib, + lib, + # optional but of negligible size + openssl, + brotli, + c-ares, + # optional databases + sqliteSupport ? true, + sqlite, + postgresSupport ? false, + postgresql, + redisSupport ? false, + hiredis, + mysqlSupport ? false, + libmysqlclient, + mariadb, +}: stdenv.mkDerivation (finalAttrs: { pname = "drogon"; @@ -26,18 +41,23 @@ stdenv.mkDerivation (finalAttrs: { (lib.cmakeBool "BUILD_EXAMPLES" false) ]; - propagatedBuildInputs = [ - jsoncpp - libossp_uuid - zlib - openssl - brotli - c-ares - ] ++ lib.optional sqliteSupport sqlite + propagatedBuildInputs = + [ + jsoncpp + libossp_uuid + zlib + openssl + brotli + c-ares + ] + ++ lib.optional sqliteSupport sqlite ++ lib.optional postgresSupport postgresql ++ lib.optional redisSupport hiredis # drogon uses mariadb for mysql (see https://github.com/drogonframework/drogon/wiki/ENG-02-Installation#Library-Dependencies) - ++ lib.optionals mysqlSupport [ libmysqlclient mariadb ]; + ++ lib.optionals mysqlSupport [ + libmysqlclient + mariadb + ]; patches = [ # this part of the test would normally fail because it attempts to configure a CMake project that uses find_package on itself diff --git a/pkgs/by-name/dr/droidcam/package.nix b/pkgs/by-name/dr/droidcam/package.nix index a0841cda69bf95..b7f9ce79874a7a 100644 --- a/pkgs/by-name/dr/droidcam/package.nix +++ b/pkgs/by-name/dr/droidcam/package.nix @@ -1,6 +1,15 @@ -{ lib, stdenv, fetchFromGitHub -, ffmpeg, libjpeg_turbo, gtk3, alsa-lib, speex, libusbmuxd, libappindicator-gtk3 -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + ffmpeg, + libjpeg_turbo, + gtk3, + alsa-lib, + speex, + libusbmuxd, + libappindicator-gtk3, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dr/droidmote/package.nix b/pkgs/by-name/dr/droidmote/package.nix index 017c548f84d3ef..76224c8ee8e274 100644 --- a/pkgs/by-name/dr/droidmote/package.nix +++ b/pkgs/by-name/dr/droidmote/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, autoPatchelfHook }: +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, +}: let srcs = { @@ -36,7 +41,8 @@ stdenv.mkDerivation rec { pname = "droidmote"; version = "3.0.6"; - src = srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); dontUnpack = true; dontBuild = true; diff --git a/pkgs/by-name/dr/drone-cli/package.nix b/pkgs/by-name/dr/drone-cli/package.nix index 84432b82d495db..5ee21e80782246 100644 --- a/pkgs/by-name/dr/drone-cli/package.nix +++ b/pkgs/by-name/dr/drone-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { diff --git a/pkgs/by-name/dr/drone-runner-docker/package.nix b/pkgs/by-name/dr/drone-runner-docker/package.nix index 05347f153c7a46..278d17379d6f0f 100644 --- a/pkgs/by-name/dr/drone-runner-docker/package.nix +++ b/pkgs/by-name/dr/drone-runner-docker/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "drone-runner-docker"; diff --git a/pkgs/by-name/dr/drone-runner-exec/package.nix b/pkgs/by-name/dr/drone-runner-exec/package.nix index 1e9d1e96a9a970..75436cfc8e4e59 100644 --- a/pkgs/by-name/dr/drone-runner-exec/package.nix +++ b/pkgs/by-name/dr/drone-runner-exec/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/dr/drone-runner-ssh/package.nix b/pkgs/by-name/dr/drone-runner-ssh/package.nix index 92a015f8e95ae8..0e5b7519ee0955 100644 --- a/pkgs/by-name/dr/drone-runner-ssh/package.nix +++ b/pkgs/by-name/dr/drone-runner-ssh/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "drone-runner-ssh"; diff --git a/pkgs/by-name/dr/drone-scp/package.nix b/pkgs/by-name/dr/drone-scp/package.nix index 976d5f6f124bbc..07d38d2e6623d1 100644 --- a/pkgs/by-name/dr/drone-scp/package.nix +++ b/pkgs/by-name/dr/drone-scp/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "drone-scp"; diff --git a/pkgs/by-name/dr/dropbear/package.nix b/pkgs/by-name/dr/dropbear/package.nix index 5e4e0be603c7da..72369b720249cb 100644 --- a/pkgs/by-name/dr/dropbear/package.nix +++ b/pkgs/by-name/dr/dropbear/package.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, fetchurl, zlib, libxcrypt -, enableSCP ? false -, sftpPath ? "/run/current-system/sw/libexec/sftp-server" +{ + lib, + stdenv, + fetchurl, + zlib, + libxcrypt, + enableSCP ? false, + sftpPath ? "/run/current-system/sw/libexec/sftp-server", }: let @@ -31,7 +36,17 @@ stdenv.mkDerivation rec { preConfigure = '' makeFlagsArray=( VPATH=$(cat $NIX_CC/nix-support/orig-libc)/lib - PROGRAMS="${lib.concatStringsSep " " ([ "dropbear" "dbclient" "dropbearkey" "dropbearconvert" ] ++ lib.optionals enableSCP ["scp"])}" + PROGRAMS="${ + lib.concatStringsSep " " ( + [ + "dropbear" + "dbclient" + "dropbearkey" + "dropbearconvert" + ] + ++ lib.optionals enableSCP [ "scp" ] + ) + }" ) ''; @@ -45,7 +60,10 @@ stdenv.mkDerivation rec { ./pass-path.patch ]; - buildInputs = [ zlib libxcrypt ]; + buildInputs = [ + zlib + libxcrypt + ]; meta = with lib; { description = "Small footprint implementation of the SSH 2 protocol"; diff --git a/pkgs/by-name/dr/dropwatch/package.nix b/pkgs/by-name/dr/dropwatch/package.nix index 470b5901870449..2e1d3b29b76142 100644 --- a/pkgs/by-name/dr/dropwatch/package.nix +++ b/pkgs/by-name/dr/dropwatch/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libbfd -, libnl -, libpcap -, ncurses -, readline -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libbfd, + libnl, + libpcap, + ncurses, + readline, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dr/drumgizmo/package.nix b/pkgs/by-name/dr/drumgizmo/package.nix index fb0483dcdf9c88..20e0b7ccf9b502 100644 --- a/pkgs/by-name/dr/drumgizmo/package.nix +++ b/pkgs/by-name/dr/drumgizmo/package.nix @@ -1,5 +1,21 @@ -{ lib, stdenv, fetchurl, fetchDebianPatch, alsa-lib, expat, glib, libjack2, libXext, libX11, libpng -, libpthreadstubs, libsmf, libsndfile, lv2, pkg-config, zita-resampler +{ + lib, + stdenv, + fetchurl, + fetchDebianPatch, + alsa-lib, + expat, + glib, + libjack2, + libXext, + libX11, + libpng, + libpthreadstubs, + libsmf, + libsndfile, + lv2, + pkg-config, + zita-resampler, }: stdenv.mkDerivation rec { @@ -26,8 +42,18 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - alsa-lib expat glib libjack2 libXext libX11 libpng libpthreadstubs - libsmf libsndfile lv2 zita-resampler + alsa-lib + expat + glib + libjack2 + libXext + libX11 + libpng + libpthreadstubs + libsmf + libsndfile + lv2 + zita-resampler ]; meta = with lib; { diff --git a/pkgs/by-name/ds/dsd/package.nix b/pkgs/by-name/ds/dsd/package.nix index f23add32157608..cc91139b1871da 100644 --- a/pkgs/by-name/ds/dsd/package.nix +++ b/pkgs/by-name/ds/dsd/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, mbelib, libsndfile, itpp -, portaudioSupport ? true, portaudio ? null +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + mbelib, + libsndfile, + itpp, + portaudioSupport ? true, + portaudio ? null, }: assert portaudioSupport -> portaudio != null; @@ -18,7 +25,9 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; buildInputs = [ - mbelib libsndfile itpp + mbelib + libsndfile + itpp ] ++ lib.optionals portaudioSupport [ portaudio ]; doCheck = true; diff --git a/pkgs/by-name/ds/dsda-launcher/package.nix b/pkgs/by-name/ds/dsda-launcher/package.nix index 8e73ae10e74f88..b384911a9c356c 100644 --- a/pkgs/by-name/ds/dsda-launcher/package.nix +++ b/pkgs/by-name/ds/dsda-launcher/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, qt6 +{ + lib, + stdenv, + fetchFromGitHub, + qt6, }: stdenv.mkDerivation rec { pname = "dsda-launcher"; @@ -16,7 +17,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ qt6.wrapQtAppsHook ]; - buildInputs = [ qt6.qtbase qt6.qtwayland ]; + buildInputs = [ + qt6.qtbase + qt6.qtwayland + ]; buildPhase = '' runHook preBuild diff --git a/pkgs/by-name/ds/dsdcc/package.nix b/pkgs/by-name/ds/dsdcc/package.nix index 9397c747e66770..421da5890b805f 100644 --- a/pkgs/by-name/ds/dsdcc/package.nix +++ b/pkgs/by-name/ds/dsdcc/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, mbelib -, serialdv +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + mbelib, + serialdv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ds/dsf2flac/package.nix b/pkgs/by-name/ds/dsf2flac/package.nix index 0a7eaf0a2dac5e..0426125212eed5 100644 --- a/pkgs/by-name/ds/dsf2flac/package.nix +++ b/pkgs/by-name/ds/dsf2flac/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, boost, flac, id3lib, pkg-config -, taglib, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + boost, + flac, + id3lib, + pkg-config, + taglib, + zlib, +}: stdenv.mkDerivation rec { pname = "dsf2flac"; @@ -12,9 +22,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-VlXfywgYhI2QuGQvpD33BspTTgT0jOKUV3gENq4HiBU="; }; - buildInputs = [ boost flac id3lib taglib zlib ]; - - nativeBuildInputs = [ autoreconfHook pkg-config ]; + buildInputs = [ + boost + flac + id3lib + taglib + zlib + ]; + + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/ds/dsniff/package.nix b/pkgs/by-name/ds/dsniff/package.nix index 5f40fa4ea3745a..cdf1361ee6fcb7 100644 --- a/pkgs/by-name/ds/dsniff/package.nix +++ b/pkgs/by-name/ds/dsniff/package.nix @@ -1,16 +1,33 @@ -{ stdenv, lib, fetchFromGitLab, autoreconfHook, libpcap, db, glib, libnet, libnids, symlinkJoin, openssl -, rpcsvc-proto, libtirpc, libnsl, libnl +{ + stdenv, + lib, + fetchFromGitLab, + autoreconfHook, + libpcap, + db, + glib, + libnet, + libnids, + symlinkJoin, + openssl, + rpcsvc-proto, + libtirpc, + libnsl, + libnl, }: let /* - dsniff's build system unconditionnaly wants static libraries and does not - support multi output derivations. We do some overriding to give it - satisfaction. + dsniff's build system unconditionnaly wants static libraries and does not + support multi output derivations. We do some overriding to give it + satisfaction. */ staticdb = symlinkJoin { inherit (db) name; - paths = with db.overrideAttrs { dontDisableStatic = true; }; [ out dev ]; + paths = with db.overrideAttrs { dontDisableStatic = true; }; [ + out + dev + ]; postBuild = '' rm $out/lib/*.so* ''; @@ -37,9 +54,13 @@ let }; ssl = symlinkJoin { inherit (openssl) name; - paths = with openssl.override { static = true; }; [ out dev ]; + paths = with openssl.override { static = true; }; [ + out + dev + ]; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "dsniff"; version = "2.4b1"; # upstream is so old that nearly every distribution packages the beta version. @@ -55,8 +76,17 @@ in stdenv.mkDerivation rec { name = "dsniff.tar.gz"; }; - nativeBuildInputs = [ autoreconfHook rpcsvc-proto ]; - buildInputs = [ glib pcap libtirpc libnsl libnl ]; + nativeBuildInputs = [ + autoreconfHook + rpcsvc-proto + ]; + buildInputs = [ + glib + pcap + libtirpc + libnsl + libnl + ]; NIX_CFLAGS_LINK = "-lglib-2.0 -lpthread -ltirpc -lnl-3 -lnl-genl-3"; env.NIX_CFLAGS_COMPILE = toString [ "-I${libtirpc.dev}/include/tirpc" ]; postPatch = '' diff --git a/pkgs/by-name/ds/dsp/package.nix b/pkgs/by-name/ds/dsp/package.nix index 9e2e815a17600c..b62eaa0fac1235 100644 --- a/pkgs/by-name/ds/dsp/package.nix +++ b/pkgs/by-name/ds/dsp/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, fftw -, zita-convolver -, fftwFloat -, libsndfile -, ffmpeg -, alsa-lib -, libao -, libmad -, ladspaH -, libtool -, libpulseaudio -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + fftw, + zita-convolver, + fftwFloat, + libsndfile, + ffmpeg, + alsa-lib, + libao, + libmad, + ladspaH, + libtool, + libpulseaudio, + fetchpatch, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ds/dspam/package.nix b/pkgs/by-name/ds/dspam/package.nix index f32316428a693f..60af92243c76cd 100644 --- a/pkgs/by-name/ds/dspam/package.nix +++ b/pkgs/by-name/ds/dspam/package.nix @@ -1,23 +1,43 @@ -{ stdenv, lib, fetchurl, makeWrapper -, gawk, gnused, gnugrep, coreutils, which -, perlPackages -, withMySQL ? false, zlib, mariadb-connector-c -, withPgSQL ? false, postgresql -, withSQLite ? false, sqlite -, withDB ? false, db +{ + stdenv, + lib, + fetchurl, + makeWrapper, + gawk, + gnused, + gnugrep, + coreutils, + which, + perlPackages, + withMySQL ? false, + zlib, + mariadb-connector-c, + withPgSQL ? false, + postgresql, + withSQLite ? false, + sqlite, + withDB ? false, + db, }: let - drivers = lib.concatStringsSep "," - ([ "hash_drv" ] - ++ lib.optional withMySQL "mysql_drv" - ++ lib.optional withPgSQL "pgsql_drv" - ++ lib.optional withSQLite "sqlite3_drv" - ++ lib.optional withDB "libdb4_drv" - ); - maintenancePath = lib.makeBinPath [ gawk gnused gnugrep coreutils which ]; + drivers = lib.concatStringsSep "," ( + [ "hash_drv" ] + ++ lib.optional withMySQL "mysql_drv" + ++ lib.optional withPgSQL "pgsql_drv" + ++ lib.optional withSQLite "sqlite3_drv" + ++ lib.optional withDB "libdb4_drv" + ); + maintenancePath = lib.makeBinPath [ + gawk + gnused + gnugrep + coreutils + which + ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "dspam"; version = "3.10.2"; @@ -30,38 +50,44 @@ in stdenv.mkDerivation rec { ./mariadb.patch ]; - buildInputs = [ perlPackages.perl ] - ++ lib.optionals withMySQL [ zlib mariadb-connector-c.out ] - ++ lib.optional withPgSQL postgresql - ++ lib.optional withSQLite sqlite - ++ lib.optional withDB db; + buildInputs = + [ perlPackages.perl ] + ++ lib.optionals withMySQL [ + zlib + mariadb-connector-c.out + ] + ++ lib.optional withPgSQL postgresql + ++ lib.optional withSQLite sqlite + ++ lib.optional withDB db; nativeBuildInputs = [ makeWrapper ]; # patch out libmysql >= 5 check, since mariadb-connector is at 3.x postPatch = '' sed -i 's/atoi(m) >= 5/1/g' configure m4/mysql_drv.m4 ''; - configureFlags = [ - "--with-storage-driver=${drivers}" - "--sysconfdir=/etc/dspam" - "--localstatedir=/var" - "--with-dspam-home=/var/lib/dspam" - "--with-logdir=/var/log/dspam" - "--with-logfile=/var/log/dspam/dspam.log" + configureFlags = + [ + "--with-storage-driver=${drivers}" + "--sysconfdir=/etc/dspam" + "--localstatedir=/var" + "--with-dspam-home=/var/lib/dspam" + "--with-logdir=/var/log/dspam" + "--with-logfile=/var/log/dspam/dspam.log" - "--enable-daemon" - "--enable-clamav" - "--enable-syslog" - "--enable-large-scale" - "--enable-virtual-users" - "--enable-split-configuration" - "--enable-preferences-extension" - "--enable-long-usernames" - "--enable-external-lookup" - ] ++ lib.optionals withMySQL [ - "--with-mysql-includes=${mariadb-connector-c.dev}/include/mysql" - "--with-mysql-libraries=${mariadb-connector-c.out}/lib/mysql" - ] + "--enable-daemon" + "--enable-clamav" + "--enable-syslog" + "--enable-large-scale" + "--enable-virtual-users" + "--enable-split-configuration" + "--enable-preferences-extension" + "--enable-long-usernames" + "--enable-external-lookup" + ] + ++ lib.optionals withMySQL [ + "--with-mysql-includes=${mariadb-connector-c.dev}/include/mysql" + "--with-mysql-libraries=${mariadb-connector-c.out}/lib/mysql" + ] ++ lib.optional withPgSQL "--with-pgsql-libraries=${postgresql.lib}/lib"; # Workaround build failure on -fno-common toolchains like upstream diff --git a/pkgs/by-name/ds/dsq/package.nix b/pkgs/by-name/ds/dsq/package.nix index 9d05e567fb1026..b32ca150c12fe0 100644 --- a/pkgs/by-name/ds/dsq/package.nix +++ b/pkgs/by-name/ds/dsq/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, nix-update-script -, testers -, python3 -, curl -, jq -, p7zip -, dsq +{ + lib, + fetchFromGitHub, + buildGoModule, + nix-update-script, + testers, + python3, + curl, + jq, + p7zip, + dsq, }: buildGoModule rec { @@ -23,9 +24,17 @@ buildGoModule rec { vendorHash = "sha256-MbBR+OC1OGhZZGcZqc+Jzmabdc5ZfFEwzqP5YMrj6mY="; - ldflags = [ "-X" "main.Version=${version}" ]; + ldflags = [ + "-X" + "main.Version=${version}" + ]; - nativeCheckInputs = [ python3 curl jq p7zip ]; + nativeCheckInputs = [ + python3 + curl + jq + p7zip + ]; preCheck = '' substituteInPlace scripts/test.py \ diff --git a/pkgs/by-name/ds/dsseries/package.nix b/pkgs/by-name/ds/dsseries/package.nix index 941db899721cbb..b49d661949340d 100644 --- a/pkgs/by-name/ds/dsseries/package.nix +++ b/pkgs/by-name/ds/dsseries/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, rpmextract }: +{ + lib, + stdenv, + fetchurl, + rpmextract, +}: stdenv.mkDerivation rec { pname = "libsane-dsseries"; diff --git a/pkgs/by-name/ds/dssi/package.nix b/pkgs/by-name/ds/dssi/package.nix index b3dad8e2018bc4..9e55c6f66a35ff 100644 --- a/pkgs/by-name/ds/dssi/package.nix +++ b/pkgs/by-name/ds/dssi/package.nix @@ -1,5 +1,21 @@ -{ lib, stdenv, fetchurl, ladspaH, libjack2, liblo, alsa-lib, libX11, libsndfile, libSM -, libsamplerate, libtool, autoconf, automake, xorgproto, libICE, pkg-config +{ + lib, + stdenv, + fetchurl, + ladspaH, + libjack2, + liblo, + alsa-lib, + libX11, + libsndfile, + libSM, + libsamplerate, + libtool, + autoconf, + automake, + xorgproto, + libICE, + pkg-config, }: stdenv.mkDerivation rec { @@ -11,16 +27,28 @@ stdenv.mkDerivation rec { sha256 = "0kl1hzhb7cykzkrqcqgq1dk4xcgrcxv0jja251aq4z4l783jpj7j"; }; - nativeBuildInputs = [ autoconf automake pkg-config ]; - buildInputs = - [ ladspaH libjack2 liblo alsa-lib libX11 libsndfile libSM - libsamplerate libtool xorgproto libICE - ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + ]; + buildInputs = [ + ladspaH + libjack2 + liblo + alsa-lib + libX11 + libsndfile + libSM + libsamplerate + libtool + xorgproto + libICE + ]; meta = with lib; { description = "Plugin SDK for virtual instruments"; - maintainers = with maintainers; - [ + maintainers = with maintainers; [ raskin ]; platforms = platforms.linux; diff --git a/pkgs/by-name/ds/dssp/package.nix b/pkgs/by-name/ds/dssp/package.nix index 9f5c25b04cff49..ac5d5dce68f9a9 100644 --- a/pkgs/by-name/ds/dssp/package.nix +++ b/pkgs/by-name/ds/dssp/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, cmake -, eigen -, fetchFromGitHub -, libcifpp -, libmcfp -, zlib +{ + lib, + stdenv, + cmake, + eigen, + fetchFromGitHub, + libcifpp, + libmcfp, + zlib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ds/dstask/package.nix b/pkgs/by-name/ds/dstask/package.nix index 571763be5fef97..54e8a95355b794 100644 --- a/pkgs/by-name/ds/dstask/package.nix +++ b/pkgs/by-name/ds/dstask/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "dstask"; @@ -25,7 +29,8 @@ buildGoModule rec { # git ref and the release version from github. # Ref ldflags = [ - "-w" "-s" + "-w" + "-s" "-X github.com/naggie/dstask.VERSION=${version}" "-X github.com/naggie/dstask.GIT_COMMIT=v${version}" ]; diff --git a/pkgs/by-name/ds/dstat/package.nix b/pkgs/by-name/ds/dstat/package.nix index 99a6b37e95e98c..124590934026b1 100644 --- a/pkgs/by-name/ds/dstat/package.nix +++ b/pkgs/by-name/ds/dstat/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, fetchpatch, python3Packages }: +{ + lib, + fetchFromGitHub, + fetchpatch, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "dstat"; diff --git a/pkgs/by-name/ds/dstep/package.nix b/pkgs/by-name/ds/dstep/package.nix index 8c847242e702af..14a3c3b7cd584b 100644 --- a/pkgs/by-name/ds/dstep/package.nix +++ b/pkgs/by-name/ds/dstep/package.nix @@ -1,4 +1,11 @@ -{ lib, buildDubPackage, fetchFromGitHub, clang, ldc, which }: +{ + lib, + buildDubPackage, + fetchFromGitHub, + clang, + ldc, + which, +}: buildDubPackage rec { pname = "dstep"; version = "1.0.4"; @@ -12,7 +19,11 @@ buildDubPackage rec { dubLock = ./dub-lock.json; - nativeBuildInputs = [ ldc which clang ]; + nativeBuildInputs = [ + ldc + which + clang + ]; preConfigure = '' ./configure --llvm-path ${lib.getLib clang.cc} diff --git a/pkgs/by-name/ds/dstp/package.nix b/pkgs/by-name/ds/dstp/package.nix index bbfac9b19941b3..66fd89f7d8f3dc 100644 --- a/pkgs/by-name/ds/dstp/package.nix +++ b/pkgs/by-name/ds/dstp/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "dstp"; diff --git a/pkgs/by-name/ds/dsvpn/package.nix b/pkgs/by-name/ds/dsvpn/package.nix index 92f877022adde9..90c07c11455498 100644 --- a/pkgs/by-name/ds/dsvpn/package.nix +++ b/pkgs/by-name/ds/dsvpn/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "dsvpn"; diff --git a/pkgs/by-name/dt/dt-schema/package.nix b/pkgs/by-name/dt/dt-schema/package.nix index c1a16d729bb6b8..098f74517f05c3 100644 --- a/pkgs/by-name/dt/dt-schema/package.nix +++ b/pkgs/by-name/dt/dt-schema/package.nix @@ -1,30 +1,40 @@ -{ lib -, python3 +{ + lib, + python3, }: -let python = python3.override { - self = python; - packageOverrides = self: super: { - # see https://github.com/devicetree-org/dt-schema/issues/108 - jsonschema = super.jsonschema.overridePythonAttrs (old: rec { - version = "4.17.3"; - disabled = self.pythonOlder "3.7"; +let + python = python3.override { + self = python; + packageOverrides = self: super: { + # see https://github.com/devicetree-org/dt-schema/issues/108 + jsonschema = super.jsonschema.overridePythonAttrs (old: rec { + version = "4.17.3"; + disabled = self.pythonOlder "3.7"; - src = old.src.override { - inherit version; - hash = "sha256-D4ZEN6uLYHa6ZwdFPvj5imoNUSqA6T+KvbZ29zfstg0="; - }; + src = old.src.override { + inherit version; + hash = "sha256-D4ZEN6uLYHa6ZwdFPvj5imoNUSqA6T+KvbZ29zfstg0="; + }; - propagatedBuildInputs = with self; ([ - attrs - pyrsistent - ] ++ lib.optionals (pythonOlder "3.8") [ - importlib-metadata - typing-extensions - ] ++ lib.optionals (pythonOlder "3.9") [ - importlib-resources - pkgutil-resolve-name - ]); - }); + propagatedBuildInputs = + with self; + ( + [ + attrs + pyrsistent + ] + ++ lib.optionals (pythonOlder "3.8") [ + importlib-metadata + typing-extensions + ] + ++ lib.optionals (pythonOlder "3.9") [ + importlib-resources + pkgutil-resolve-name + ] + ); + }); + }; }; -}; in python.pkgs.toPythonApplication python.pkgs.dtschema +in +python.pkgs.toPythonApplication python.pkgs.dtschema diff --git a/pkgs/by-name/dt/dt/package.nix b/pkgs/by-name/dt/dt/package.nix index aa478b16dd6949..550d137b206c52 100644 --- a/pkgs/by-name/dt/dt/package.nix +++ b/pkgs/by-name/dt/dt/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, testers -, zig_0_11 +{ + lib, + stdenv, + fetchFromGitHub, + testers, + zig_0_11, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/dt/dtach/package.nix b/pkgs/by-name/dt/dtach/package.nix index 9daabbf81b5aa2..1d1be03dcd2c9f 100644 --- a/pkgs/by-name/dt/dtach/package.nix +++ b/pkgs/by-name/dt/dtach/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "dtach"; diff --git a/pkgs/by-name/dt/dtc/package.nix b/pkgs/by-name/dt/dtc/package.nix index f407fba956a159..9eaf13b6a7c6a9 100644 --- a/pkgs/by-name/dt/dtc/package.nix +++ b/pkgs/by-name/dt/dtc/package.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchpatch2 -, fetchzip -, meson -, ninja -, flex -, bison -, pkg-config -, which -, pythonSupport ? false -, python ? null -, swig -, libyaml +{ + stdenv, + lib, + fetchpatch2, + fetchzip, + meson, + ninja, + flex, + bison, + pkg-config, + which, + pythonSupport ? false, + python ? null, + swig, + libyaml, }: stdenv.mkDerivation (finalAttrs: { @@ -33,18 +34,20 @@ stdenv.mkDerivation (finalAttrs: { env.SETUPTOOLS_SCM_PRETEND_VERSION = finalAttrs.version; - nativeBuildInputs = [ - meson - ninja - flex - bison - pkg-config - which - ] ++ lib.optionals pythonSupport [ - python - python.pkgs.setuptools-scm - swig - ]; + nativeBuildInputs = + [ + meson + ninja + flex + bison + pkg-config + which + ] + ++ lib.optionals pythonSupport [ + python + python.pkgs.setuptools-scm + swig + ]; buildInputs = [ libyaml ]; @@ -64,17 +67,19 @@ stdenv.mkDerivation (finalAttrs: { doCheck = # Checks are broken on aarch64 darwin # https://github.com/NixOS/nixpkgs/pull/118700#issuecomment-885892436 - !stdenv.hostPlatform.isDarwin && - # Checks are broken when building statically on x86_64 linux with musl - # One of the test tries to build a shared library and this causes the linker: - # x86_64-unknown-linux-musl-ld: /nix/store/h9gcvnp90mpniyx2v0d0p3s06hkx1v2p-x86_64-unknown-linux-musl-gcc-13.3.0/lib/gcc/x86_64-unknown-linux-musl/13.3.0/crtbeginT.o: relocation R_X86_64_32 against hidden symbol `__TMC_END__' can not be used when making a shared object - # x86_64-unknown-linux-musl-ld: failed to set dynamic section sizes: bad value - !stdenv.hostPlatform.isStatic && + !stdenv.hostPlatform.isDarwin + && + # Checks are broken when building statically on x86_64 linux with musl + # One of the test tries to build a shared library and this causes the linker: + # x86_64-unknown-linux-musl-ld: /nix/store/h9gcvnp90mpniyx2v0d0p3s06hkx1v2p-x86_64-unknown-linux-musl-gcc-13.3.0/lib/gcc/x86_64-unknown-linux-musl/13.3.0/crtbeginT.o: relocation R_X86_64_32 against hidden symbol `__TMC_END__' can not be used when making a shared object + # x86_64-unknown-linux-musl-ld: failed to set dynamic section sizes: bad value + !stdenv.hostPlatform.isStatic + && - # we must explicitly disable this here so that mesonFlags receives - # `-Dtests=disabled`; without it meson will attempt to run - # hostPlatform binaries during the configurePhase. - (with stdenv; buildPlatform.canExecute hostPlatform); + # we must explicitly disable this here so that mesonFlags receives + # `-Dtests=disabled`; without it meson will attempt to run + # hostPlatform binaries during the configurePhase. + (with stdenv; buildPlatform.canExecute hostPlatform); meta = with lib; { description = "Device Tree Compiler"; diff --git a/pkgs/by-name/dt/dtcmp/package.nix b/pkgs/by-name/dt/dtcmp/package.nix index cd8f54e25d313b..abf24f17ec908e 100644 --- a/pkgs/by-name/dt/dtcmp/package.nix +++ b/pkgs/by-name/dt/dtcmp/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, mpi, lwgrp }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + mpi, + lwgrp, +}: stdenv.mkDerivation rec { pname = "dtcmp"; @@ -11,9 +19,15 @@ stdenv.mkDerivation rec { hash = "sha256-Dc+c8JCc5D23CtpwiWkHCqngywEZXw7cYsRiSYiQdWk="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ lwgrp ]; configureFlags = [ "--with-lwgrp=${lib.getDev lwgrp}" ]; diff --git a/pkgs/by-name/dt/dterm/package.nix b/pkgs/by-name/dt/dterm/package.nix index d77cf6e4d2c9c3..f69892f41dd3b9 100644 --- a/pkgs/by-name/dt/dterm/package.nix +++ b/pkgs/by-name/dt/dterm/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, readline +{ + lib, + stdenv, + fetchurl, + readline, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dt/dtool/package.nix b/pkgs/by-name/dt/dtool/package.nix index 0e62d91cdbc958..64d526e51249ae 100644 --- a/pkgs/by-name/dt/dtool/package.nix +++ b/pkgs/by-name/dt/dtool/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/dt/dtools/package.nix b/pkgs/by-name/dt/dtools/package.nix index 9d5812ec9fd2a3..ad3047806aeb9e 100644 --- a/pkgs/by-name/dt/dtools/package.nix +++ b/pkgs/by-name/dt/dtools/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, ldc -, curl +{ + lib, + stdenv, + fetchFromGitHub, + ldc, + curl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/dt/dtrx/package.nix b/pkgs/by-name/dt/dtrx/package.nix index 9890112171d86c..837f434fb98167 100644 --- a/pkgs/by-name/dt/dtrx/package.nix +++ b/pkgs/by-name/dt/dtrx/package.nix @@ -1,23 +1,24 @@ -{ lib -, fetchFromGitHub -, gitUpdater -, python3Packages -, gnutar -, unzip -, lhasa -, rpm -, binutils -, cpio -, gzip -, p7zip -, cabextract -, unrar -, unshield -, bzip2 -, xz -, lzip -, unzipSupport ? false -, unrarSupport ? false +{ + lib, + fetchFromGitHub, + gitUpdater, + python3Packages, + gnutar, + unzip, + lhasa, + rpm, + binutils, + cpio, + gzip, + p7zip, + cabextract, + unrar, + unshield, + bzip2, + xz, + lzip, + unzipSupport ? false, + unrarSupport ? false, }: python3Packages.buildPythonApplication rec { @@ -34,11 +35,25 @@ python3Packages.buildPythonApplication rec { makeWrapperArgs = let archivers = lib.makeBinPath ( - [ gnutar lhasa rpm binutils cpio gzip p7zip cabextract unshield bzip2 xz lzip ] + [ + gnutar + lhasa + rpm + binutils + cpio + gzip + p7zip + cabextract + unshield + bzip2 + xz + lzip + ] ++ lib.optional (unzipSupport) unzip ++ lib.optional (unrarSupport) unrar ); - in [ + in + [ ''--prefix PATH : "${archivers}"'' ]; diff --git a/pkgs/by-name/dt/dtv-scan-tables/package.nix b/pkgs/by-name/dt/dtv-scan-tables/package.nix index 0009fdb63ab431..5293158f989304 100644 --- a/pkgs/by-name/dt/dtv-scan-tables/package.nix +++ b/pkgs/by-name/dt/dtv-scan-tables/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, v4l-utils +{ + lib, + stdenv, + fetchurl, + v4l-utils, }: stdenv.mkDerivation (finalAttrs: { @@ -33,7 +34,10 @@ stdenv.mkDerivation (finalAttrs: { # but sometimes they lag behind several weeks or even months. description = "Digital TV (DVB) channel/transponder scan tables"; homepage = "https://www.linuxtv.org/wiki/index.php/Dtv-scan-tables"; - license = with lib.licenses; [ gpl2Only lgpl21Only ]; + license = with lib.licenses; [ + gpl2Only + lgpl21Only + ]; longDescription = '' When scanning for dvb channels, most applications require an initial set of diff --git a/pkgs/by-name/du/dub/package.nix b/pkgs/by-name/du/dub/package.nix index c6782b49070ebd..3f4bc2dae80eb0 100644 --- a/pkgs/by-name/du/dub/package.nix +++ b/pkgs/by-name/du/dub/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, curl -, ldc -, libevent -, rsync +{ + lib, + stdenv, + fetchFromGitHub, + curl, + ldc, + libevent, + rsync, }: stdenv.mkDerivation (finalAttrs: { @@ -24,7 +25,11 @@ stdenv.mkDerivation (finalAttrs: { patchShebangs test ''; - nativeBuildInputs = [ ldc libevent rsync ]; + nativeBuildInputs = [ + ldc + libevent + rsync + ]; buildInputs = [ curl ]; buildPhase = '' @@ -154,6 +159,12 @@ stdenv.mkDerivation (finalAttrs: { license = licenses.mit; mainProgram = "dub"; maintainers = with maintainers; [ jtbx ]; - platforms = [ "x86_64-linux" "i686-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; }; }) diff --git a/pkgs/by-name/du/dublin-traceroute/package.nix b/pkgs/by-name/du/dublin-traceroute/package.nix index 0ec5ac87ef61c4..a070e05fa52e8c 100644 --- a/pkgs/by-name/du/dublin-traceroute/package.nix +++ b/pkgs/by-name/du/dublin-traceroute/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, jsoncpp, libtins, libpcap, openssl, unstableGitUpdater, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + jsoncpp, + libtins, + libpcap, + openssl, + unstableGitUpdater, + nixosTests, +}: stdenv.mkDerivation { pname = "dublin-traceroute"; @@ -11,9 +23,17 @@ stdenv.mkDerivation { hash = "sha256-UJeFPVi3423Jh72fVk8QbLX1tTNAQ504xYs9HwVCkZc="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ jsoncpp libtins libpcap openssl ]; + buildInputs = [ + jsoncpp + libtins + libpcap + openssl + ]; outputs = [ "out" diff --git a/pkgs/by-name/du/duc/package.nix b/pkgs/by-name/du/duc/package.nix index 8ef860f32e0508..ad33cea6cae26b 100644 --- a/pkgs/by-name/du/duc/package.nix +++ b/pkgs/by-name/du/duc/package.nix @@ -1,7 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config -, tokyocabinet, ncurses -, cairo ? null, pango ? null -, enableCairo ? stdenv.hostPlatform.isLinux +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + tokyocabinet, + ncurses, + cairo ? null, + pango ? null, + enableCairo ? stdenv.hostPlatform.isLinux, }: assert enableCairo -> cairo != null && pango != null; @@ -17,12 +24,24 @@ stdenv.mkDerivation rec { sha256 = "sha256-ZLNsyp82UnsveEfDKzH8WfRh/Y/PQlXq8Ma+jIZl9Gk="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ tokyocabinet ncurses ] ++ - lib.optionals enableCairo [ cairo pango ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = + [ + tokyocabinet + ncurses + ] + ++ lib.optionals enableCairo [ + cairo + pango + ]; - configureFlags = - lib.optionals (!enableCairo) [ "--disable-x11" "--disable-cairo" ]; + configureFlags = lib.optionals (!enableCairo) [ + "--disable-x11" + "--disable-cairo" + ]; meta = with lib; { homepage = "http://duc.zevv.nl/"; diff --git a/pkgs/by-name/du/duckling-proxy/package.nix b/pkgs/by-name/du/duckling-proxy/package.nix index 057d4f03f3b5e5..8c8d9518b9db3c 100644 --- a/pkgs/by-name/du/duckling-proxy/package.nix +++ b/pkgs/by-name/du/duckling-proxy/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule { pname = "duckling-proxy"; diff --git a/pkgs/by-name/du/duckstation/package.nix b/pkgs/by-name/du/duckstation/package.nix index 4b96fc1707b209..f65be766b7c6f5 100644 --- a/pkgs/by-name/du/duckstation/package.nix +++ b/pkgs/by-name/du/duckstation/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, SDL2 -, callPackage -, cmake -, cubeb -, curl -, extra-cmake-modules -, libXrandr -, libbacktrace -, libwebp -, makeWrapper -, ninja -, pkg-config -, qt6 -, vulkan-loader -, wayland +{ + lib, + stdenv, + SDL2, + callPackage, + cmake, + cubeb, + curl, + extra-cmake-modules, + libXrandr, + libbacktrace, + libwebp, + makeWrapper, + ninja, + pkg-config, + qt6, + vulkan-loader, + wayland, }: let @@ -25,7 +26,7 @@ let qttools qtwayland wrapQtAppsHook - ; + ; in stdenv.mkDerivation (finalAttrs: { inherit (sources.duckstation) pname version src; @@ -57,8 +58,7 @@ stdenv.mkDerivation (finalAttrs: { qtwayland sources.shaderc-patched wayland - ] - ++ cubeb.passthru.backendLibs; + ] ++ cubeb.passthru.backendLibs; cmakeFlags = [ (lib.cmakeBool "BUILD_TESTS" true) @@ -103,10 +103,14 @@ stdenv.mkDerivation (finalAttrs: { qtWrapperArgs = let - libPath = lib.makeLibraryPath ([ - vulkan-loader - ] ++ cubeb.passthru.backendLibs); - in [ + libPath = lib.makeLibraryPath ( + [ + vulkan-loader + ] + ++ cubeb.passthru.backendLibs + ); + in + [ "--prefix LD_LIBRARY_PATH : ${libPath}" ]; @@ -123,7 +127,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Fast PlayStation 1 emulator for x86-64/AArch32/AArch64"; license = lib.licenses.gpl3Only; mainProgram = "duckstation-qt"; - maintainers = with lib.maintainers; [ guibou AndersonTorres ]; + maintainers = with lib.maintainers; [ + guibou + AndersonTorres + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/by-name/du/duckstation/sources.nix b/pkgs/by-name/du/duckstation/sources.nix index 34478629f93d32..3978dcbf7de647 100644 --- a/pkgs/by-name/du/duckstation/sources.nix +++ b/pkgs/by-name/du/duckstation/sources.nix @@ -7,50 +7,53 @@ }: { - duckstation = let - self = { - pname = "duckstation"; - version = "0.1-6759"; - src = fetchFromGitHub { - owner = "stenzek"; - repo = "duckstation"; - rev = "refs/tags/v${self.version}"; - # - # Some files are filled by using Git commands; it requires deepClone. - # More info at `checkout_ref` function in nix-prefetch-git. - # However, `.git` is a bit nondeterministic (and Git itself makes no - # guarrantees whatsoever). - # Then, in order to enhance reproducibility, what we will do here is: - # - # - Execute the desired Git commands; - # - Save the obtained info into files; - # - Remove `.git` afterwards. - # - deepClone = true; - postFetch = '' - cd $out - mkdir -p .nixpkgs-auxfiles/ - git rev-parse HEAD > .nixpkgs-auxfiles/git_hash - git rev-parse --abbrev-ref HEAD | tr -d '\r\n' > .nixpkgs-auxfiles/git_branch - git describe --dirty | tr -d '\r\n' > .nixpkgs-auxfiles/git_tag - git log -1 --date=iso8601-strict --format=%cd > .nixpkgs-auxfiles/git_date - find $out -name .git -print0 | xargs -0 rm -fr - ''; - hash = "sha256-HETo7mChBASnr5prPUWcOhS4TIESFdrs1haEXQpnuzs="; + duckstation = + let + self = { + pname = "duckstation"; + version = "0.1-6759"; + src = fetchFromGitHub { + owner = "stenzek"; + repo = "duckstation"; + rev = "refs/tags/v${self.version}"; + # + # Some files are filled by using Git commands; it requires deepClone. + # More info at `checkout_ref` function in nix-prefetch-git. + # However, `.git` is a bit nondeterministic (and Git itself makes no + # guarrantees whatsoever). + # Then, in order to enhance reproducibility, what we will do here is: + # + # - Execute the desired Git commands; + # - Save the obtained info into files; + # - Remove `.git` afterwards. + # + deepClone = true; + postFetch = '' + cd $out + mkdir -p .nixpkgs-auxfiles/ + git rev-parse HEAD > .nixpkgs-auxfiles/git_hash + git rev-parse --abbrev-ref HEAD | tr -d '\r\n' > .nixpkgs-auxfiles/git_branch + git describe --dirty | tr -d '\r\n' > .nixpkgs-auxfiles/git_tag + git log -1 --date=iso8601-strict --format=%cd > .nixpkgs-auxfiles/git_date + find $out -name .git -print0 | xargs -0 rm -fr + ''; + hash = "sha256-HETo7mChBASnr5prPUWcOhS4TIESFdrs1haEXQpnuzs="; + }; }; - }; - in + in self; - shaderc-patched = shaderc.overrideAttrs (old: let - version = "2024.0"; - src = fetchFromGitHub { - owner = "google"; - repo = "shaderc"; - rev = "v${version}"; - hash = "sha256-Cwp7WbaKWw/wL9m70wfYu47xoUGQW+QGeoYhbyyzstQ="; - }; - in + shaderc-patched = shaderc.overrideAttrs ( + old: + let + version = "2024.0"; + src = fetchFromGitHub { + owner = "google"; + repo = "shaderc"; + rev = "v${version}"; + hash = "sha256-Cwp7WbaKWw/wL9m70wfYu47xoUGQW+QGeoYhbyyzstQ="; + }; + in { pname = "shaderc-patched-for-duckstation"; inherit version src; diff --git a/pkgs/by-name/du/duf/package.nix b/pkgs/by-name/du/duf/package.nix index 0fb2846297d735..dce3c1588834da 100644 --- a/pkgs/by-name/du/duf/package.nix +++ b/pkgs/by-name/du/duf/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, installShellFiles }: +{ + lib, + fetchFromGitHub, + buildGoModule, + installShellFiles, +}: buildGoModule rec { pname = "duf"; @@ -13,7 +18,11 @@ buildGoModule rec { vendorHash = "sha256-oihi7E67VQmym9U1gdD802AYxWRrSowhzBiKg0CBDPc="; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; nativeBuildInputs = [ installShellFiles ]; @@ -25,7 +34,11 @@ buildGoModule rec { homepage = "https://github.com/muesli/duf/"; description = "Disk Usage/Free Utility"; license = licenses.mit; - maintainers = with maintainers; [ figsoda penguwin sigmasquadron ]; + maintainers = with maintainers; [ + figsoda + penguwin + sigmasquadron + ]; mainProgram = "duf"; }; } diff --git a/pkgs/by-name/du/dufs/package.nix b/pkgs/by-name/du/dufs/package.nix index d863342e1aa549..27809dd4b82573 100644 --- a/pkgs/by-name/du/dufs/package.nix +++ b/pkgs/by-name/du/dufs/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -45,7 +46,13 @@ rustPlatform.buildRustPackage rec { mainProgram = "dufs"; homepage = "https://github.com/sigoden/dufs"; changelog = "https://github.com/sigoden/dufs/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ figsoda holymonson ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + figsoda + holymonson + ]; }; } diff --git a/pkgs/by-name/du/duktape/package.nix b/pkgs/by-name/du/duktape/package.nix index 8e33a5013ff543..c285f44a5e4ad6 100644 --- a/pkgs/by-name/du/duktape/package.nix +++ b/pkgs/by-name/du/duktape/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fixDarwinDylibNames, validatePkgConfig }: +{ + lib, + stdenv, + fetchurl, + fixDarwinDylibNames, + validatePkgConfig, +}: stdenv.mkDerivation (finalAttrs: { pname = "duktape"; @@ -11,8 +17,9 @@ stdenv.mkDerivation (finalAttrs: { # https://github.com/svaarala/duktape/issues/2464 LDFLAGS = [ "-lm" ]; - nativeBuildInputs = [ validatePkgConfig ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ fixDarwinDylibNames ]; + nativeBuildInputs = [ + validatePkgConfig + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ fixDarwinDylibNames ]; buildPhase = '' make -f Makefile.sharedlibrary diff --git a/pkgs/by-name/du/dum/package.nix b/pkgs/by-name/du/dum/package.nix index 201c81f3fd6cad..d369fd571dd2a7 100644 --- a/pkgs/by-name/du/dum/package.nix +++ b/pkgs/by-name/du/dum/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "dum"; diff --git a/pkgs/by-name/du/dumb-init/package.nix b/pkgs/by-name/du/dumb-init/package.nix index 207400aaca0bce..d9f1513daf0240 100644 --- a/pkgs/by-name/du/dumb-init/package.nix +++ b/pkgs/by-name/du/dumb-init/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, glibc }: +{ + lib, + stdenv, + fetchFromGitHub, + glibc, +}: stdenv.mkDerivation rec { pname = "dumb-init"; diff --git a/pkgs/by-name/du/dumb/package.nix b/pkgs/by-name/du/dumb/package.nix index f80dea534a67aa..48d25f2601fdd2 100644 --- a/pkgs/by-name/du/dumb/package.nix +++ b/pkgs/by-name/du/dumb/package.nix @@ -1,11 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, cmake, allegro, SDL2 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + allegro, + SDL2, +}: stdenv.mkDerivation rec { pname = "dumb"; version = "2.0.3"; nativeBuildInputs = [ cmake ]; - buildInputs = [ allegro SDL2 ]; + buildInputs = [ + allegro + SDL2 + ]; src = fetchFromGitHub { owner = "kode54"; @@ -21,7 +31,7 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/kode54/dumb"; description = "Module/tracker based music format parser and player library"; - license = licenses.free; # Derivative of GPL + license = licenses.free; # Derivative of GPL maintainers = with maintainers; [ Madouura ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/du/dumbpipe/package.nix b/pkgs/by-name/du/dumbpipe/package.nix index 2f5d7a87349c8d..f5c1c4adff357a 100644 --- a/pkgs/by-name/du/dumbpipe/package.nix +++ b/pkgs/by-name/du/dumbpipe/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,8 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-bQSJ3vbkFVk/9tA+7VD4o303+iF7pmQoZsrrfw/X3TY="; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( - with darwin.apple_sdk.frameworks; [ + with darwin.apple_sdk.frameworks; + [ SystemConfiguration ] ); @@ -27,7 +29,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Connect A to B - Send Data"; homepage = "https://www.dumbpipe.dev/"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ cameronfyfe ]; mainProgram = "dumbpipe"; }; diff --git a/pkgs/by-name/du/dummyhttp/package.nix b/pkgs/by-name/du/dummyhttp/package.nix index 59ca3d3344a01c..fc394a85fca108 100644 --- a/pkgs/by-name/du/dummyhttp/package.nix +++ b/pkgs/by-name/du/dummyhttp/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, darwin -, stdenv +{ + lib, + fetchFromGitHub, + rustPlatform, + darwin, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -30,4 +31,3 @@ rustPlatform.buildRustPackage rec { mainProgram = "dummyhttp"; }; } - diff --git a/pkgs/by-name/du/dump1090/package.nix b/pkgs/by-name/du/dump1090/package.nix index c34e18be8696f0..ce4746f8ec75f5 100644 --- a/pkgs/by-name/du/dump1090/package.nix +++ b/pkgs/by-name/du/dump1090/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config -, hackrf -, libbladeRF -, libusb1 -, limesuite -, ncurses -, rtl-sdr -, soapysdr-with-plugins +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + hackrf, + libbladeRF, + libusb1, + limesuite, + ncurses, + rtl-sdr, + soapysdr-with-plugins, }: stdenv.mkDerivation rec { @@ -32,10 +34,14 @@ stdenv.mkDerivation rec { soapysdr-with-plugins ] ++ lib.optional stdenv.hostPlatform.isLinux limesuite; - env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang - "-Wno-implicit-function-declaration -Wno-int-conversion -Wno-unknown-warning-option"; + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-implicit-function-declaration -Wno-int-conversion -Wno-unknown-warning-option"; - buildFlags = [ "DUMP1090_VERSION=${version}" "showconfig" "dump1090" "view1090" ]; + buildFlags = [ + "DUMP1090_VERSION=${version}" + "showconfig" + "dump1090" + "view1090" + ]; doCheck = true; diff --git a/pkgs/by-name/du/dumpasn1/package.nix b/pkgs/by-name/du/dumpasn1/package.nix index 030d73a447be9b..e3314ff389fcc9 100644 --- a/pkgs/by-name/du/dumpasn1/package.nix +++ b/pkgs/by-name/du/dumpasn1/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation (finalAttrs: { pname = "dumpasn1"; diff --git a/pkgs/by-name/du/dumpnar/package.nix b/pkgs/by-name/du/dumpnar/package.nix index 77ce4649b39932..9206ae22c9563a 100644 --- a/pkgs/by-name/du/dumpnar/package.nix +++ b/pkgs/by-name/du/dumpnar/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "dumpnar"; diff --git a/pkgs/by-name/du/dumptorrent/package.nix b/pkgs/by-name/du/dumptorrent/package.nix index c80a696f8cba19..244e79109a3fc0 100644 --- a/pkgs/by-name/du/dumptorrent/package.nix +++ b/pkgs/by-name/du/dumptorrent/package.nix @@ -1,30 +1,34 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { - pname = "dumptorrent"; - version = "1.2"; + pname = "dumptorrent"; + version = "1.2"; - src = fetchurl { - url = "mirror://sourceforge/dumptorrent/dumptorrent-${version}.tar.gz"; - sha256 = "073h03bmpfdy15qh37lvppayld2747i4acpyk0pm5nf2raiak0zm"; - }; + src = fetchurl { + url = "mirror://sourceforge/dumptorrent/dumptorrent-${version}.tar.gz"; + sha256 = "073h03bmpfdy15qh37lvppayld2747i4acpyk0pm5nf2raiak0zm"; + }; - postPatch = '' - substituteInPlace Makefile \ - --replace "gcc" "$CC" - ''; + postPatch = '' + substituteInPlace Makefile \ + --replace "gcc" "$CC" + ''; - installPhase = '' - mkdir -p $out/bin - cp ./dumptorrent $out/bin - ''; + installPhase = '' + mkdir -p $out/bin + cp ./dumptorrent $out/bin + ''; - meta = with lib; { - description = "Dump .torrent file information"; - homepage = "https://sourceforge.net/projects/dumptorrent/"; - license = licenses.gpl2Only; - maintainers = [ maintainers.zohl ]; - platforms = platforms.all; - mainProgram = "dumptorrent"; - }; + meta = with lib; { + description = "Dump .torrent file information"; + homepage = "https://sourceforge.net/projects/dumptorrent/"; + license = licenses.gpl2Only; + maintainers = [ maintainers.zohl ]; + platforms = platforms.all; + mainProgram = "dumptorrent"; + }; } diff --git a/pkgs/by-name/du/dune3d/package.nix b/pkgs/by-name/du/dune3d/package.nix index 01d3d45a78175d..bf5c4a64dacb14 100644 --- a/pkgs/by-name/du/dune3d/package.nix +++ b/pkgs/by-name/du/dune3d/package.nix @@ -68,7 +68,10 @@ stdenv'.mkDerivation (finalAttrs: { description = "3D CAD application"; homepage = "https://dune3d.org"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ _0x4A6F jue89 ]; + maintainers = with lib.maintainers; [ + _0x4A6F + jue89 + ]; mainProgram = "dune3d"; platforms = lib.platforms.linux ++ lib.platforms.darwin; }; diff --git a/pkgs/by-name/du/dupd/package.nix b/pkgs/by-name/du/dupd/package.nix index cf5ab77e7d4700..71cd9e53c19434 100644 --- a/pkgs/by-name/du/dupd/package.nix +++ b/pkgs/by-name/du/dupd/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, perl, which -, openssl, sqlite }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, + which, + openssl, + sqlite, +}: # Instead of writing directly into $HOME, we change the default db location # from $HOME/.dupd_sqlite to $HOME/.cache/dupd.sqlite3 @@ -10,8 +17,8 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "jvirkki"; - repo = "dupd"; - rev = version; + repo = "dupd"; + rev = version; sha256 = "sha256-ZiQroJ5fjBCIjU+M8KRA0N3Mrg9h0NVtfYUIS4cYyhw="; }; @@ -28,9 +35,15 @@ stdenv.mkDerivation rec { done ''; - buildInputs = [ openssl sqlite ]; + buildInputs = [ + openssl + sqlite + ]; - nativeBuildInputs = [ perl which ]; + nativeBuildInputs = [ + perl + which + ]; makeFlags = [ "INSTALL_PREFIX=$(out)" diff --git a/pkgs/by-name/du/dupe-krill/package.nix b/pkgs/by-name/du/dupe-krill/package.nix index be0b3cc5ff37f0..1f9b2349ada173 100644 --- a/pkgs/by-name/du/dupe-krill/package.nix +++ b/pkgs/by-name/du/dupe-krill/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "dupe-krill"; diff --git a/pkgs/by-name/du/duperemove/package.nix b/pkgs/by-name/du/duperemove/package.nix index 66a3fac4a10a87..46a5522d597df0 100644 --- a/pkgs/by-name/du/duperemove/package.nix +++ b/pkgs/by-name/du/duperemove/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, libgcrypt -, pkg-config -, glib -, linuxHeaders ? stdenv.cc.libc.linuxHeaders -, sqlite -, util-linux -, testers -, duperemove +{ + lib, + stdenv, + fetchFromGitHub, + libgcrypt, + pkg-config, + glib, + linuxHeaders ? stdenv.cc.libc.linuxHeaders, + sqlite, + util-linux, + testers, + duperemove, }: stdenv.mkDerivation rec { @@ -28,7 +29,13 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libgcrypt glib linuxHeaders sqlite util-linux ]; + buildInputs = [ + libgcrypt + glib + linuxHeaders + sqlite + util-linux + ]; makeFlags = [ "PREFIX=${placeholder "out"}" @@ -45,7 +52,10 @@ stdenv.mkDerivation rec { description = "Simple tool for finding duplicated extents and submitting them for deduplication"; homepage = "https://github.com/markfasheh/duperemove"; license = licenses.gpl2Only; - maintainers = with maintainers; [ bluescreen303 thoughtpolice ]; + maintainers = with maintainers; [ + bluescreen303 + thoughtpolice + ]; platforms = platforms.linux; mainProgram = "duperemove"; }; diff --git a/pkgs/by-name/du/duplicacy/package.nix b/pkgs/by-name/du/duplicacy/package.nix index a8503ac84b6fa6..d1a4ea570da769 100644 --- a/pkgs/by-name/du/duplicacy/package.nix +++ b/pkgs/by-name/du/duplicacy/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "duplicacy"; @@ -20,6 +24,9 @@ buildGoModule rec { description = "New generation cloud backup tool"; platforms = platforms.linux ++ platforms.darwin; license = lib.licenses.unfree; - maintainers = with maintainers; [ ffinkdevs devusb ]; + maintainers = with maintainers; [ + ffinkdevs + devusb + ]; }; } diff --git a/pkgs/by-name/du/duplicati/package.nix b/pkgs/by-name/du/duplicati/package.nix index d818b7c5b537f7..83b32d450dd645 100644 --- a/pkgs/by-name/du/duplicati/package.nix +++ b/pkgs/by-name/du/duplicati/package.nix @@ -44,7 +44,10 @@ stdenv.mkDerivation rec { description = "Free backup client that securely stores encrypted, incremental, compressed backups on cloud storage services and remote file servers"; homepage = "https://www.duplicati.com/"; license = licenses.lgpl21; - maintainers = with maintainers; [ nyanloutre bot-wxt1221 ]; + maintainers = with maintainers; [ + nyanloutre + bot-wxt1221 + ]; sourceProvenance = with sourceTypes; [ binaryBytecode ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/du/duplicity/package.nix b/pkgs/by-name/du/duplicity/package.nix index ca30df472e4085..fcb24859fea2ff 100644 --- a/pkgs/by-name/du/duplicity/package.nix +++ b/pkgs/by-name/du/duplicity/package.nix @@ -1,158 +1,179 @@ -{ lib -, stdenv -, fetchFromGitLab -, python3 -, librsync -, glib -, ncftp -, gnupg -, gnutar -, par2cmdline -, util-linux -, rsync -, makeWrapper -, wrapGAppsNoGuiHook -, gettext -, getconf -, testers -, nix-update-script +{ + lib, + stdenv, + fetchFromGitLab, + python3, + librsync, + glib, + ncftp, + gnupg, + gnutar, + par2cmdline, + util-linux, + rsync, + makeWrapper, + wrapGAppsNoGuiHook, + gettext, + getconf, + testers, + nix-update-script, }: -let self = python3.pkgs.buildPythonApplication rec { - pname = "duplicity"; - version = "3.0.3.1"; +let + self = python3.pkgs.buildPythonApplication rec { + pname = "duplicity"; + version = "3.0.3.1"; - src = fetchFromGitLab { - owner = "duplicity"; - repo = "duplicity"; - rev = "rel.${version}"; - hash = "sha256-s8yPmuGivvmqAKsdaGouP/UoK6Ea27HjvSm39eQuKF0="; - }; - - patches = [ - ./keep-pythonpath-in-testing.patch - ]; - - postPatch = '' - patchShebangs duplicity/__main__.py - - # don't try to use gtar on darwin/bsd - substituteInPlace testing/functional/test_restart.py \ - --replace-fail 'tarcmd = "gtar"' 'tarcmd = "tar"' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # tests try to access these files in the sandbox, but can't deal with EPERM - substituteInPlace testing/unit/test_globmatch.py \ - --replace-fail /var/log /test/log - substituteInPlace testing/unit/test_selection.py \ - --replace-fail /usr/bin /dev - # don't use /tmp/ in tests - substituteInPlace duplicity/backends/_testbackend.py \ - --replace-fail '"/tmp/' 'os.environ.get("TMPDIR")+"/' - ''; - - disabledTests = lib.optionals stdenv.hostPlatform.isDarwin [ - # uses /tmp/ - "testing/unit/test_cli_main.py::CommandlineTest::test_intermixed_args" - ]; - - nativeBuildInputs = [ - makeWrapper - gettext - python3.pkgs.wrapPython - wrapGAppsNoGuiHook - python3.pkgs.setuptools-scm - ]; - - buildInputs = [ - librsync - # For Gio typelib - glib - ]; - - pythonPath = with python3.pkgs; [ - b2sdk - boto3 - cffi - cryptography - ecdsa - idna - pygobject3 - fasteners - lockfile - paramiko - pyasn1 - pycrypto - pydrive2 - future - ] ++ paramiko.optional-dependencies.invoke; - - nativeCheckInputs = [ - gnupg # Add 'gpg' to PATH. - gnutar # Add 'tar' to PATH. - librsync # Add 'rdiff' to PATH. - par2cmdline # Add 'par2' to PATH. - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - util-linux # Add 'setsid' to PATH. - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - getconf - ] ++ (with python3.pkgs; [ - lockfile - mock - pexpect - pytestCheckHook - fasteners - ]); - - # Prevent double wrapping, let the Python wrapper use the args in preFixup. - dontWrapGApps = true; - - preFixup = let - binPath = lib.makeBinPath ([ - gnupg - ncftp - rsync - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - getconf - ]); in '' - makeWrapperArgsBak=("''${makeWrapperArgs[@]}") - makeWrapperArgs+=( - "''${gappsWrapperArgs[@]}" - --prefix PATH : "${binPath}" - ) - ''; - - postFixup = '' - # Restore previous value for tests wrapping in preInstallCheck - makeWrapperArgs=("''${makeWrapperArgsBak[@]}") - ''; - - preCheck = '' - # tests need writable $HOME - HOME=$PWD/.home - - wrapPythonProgramsIn "$PWD/testing/overrides/bin" "$pythonPath" - ''; - - doCheck = true; - - passthru = { - updateScript = nix-update-script { - extraArgs = [ "--version-regex" "rel\.(.*)" ]; + src = fetchFromGitLab { + owner = "duplicity"; + repo = "duplicity"; + rev = "rel.${version}"; + hash = "sha256-s8yPmuGivvmqAKsdaGouP/UoK6Ea27HjvSm39eQuKF0="; }; - tests.version = testers.testVersion { - package = self; + patches = [ + ./keep-pythonpath-in-testing.patch + ]; + + postPatch = + '' + patchShebangs duplicity/__main__.py + + # don't try to use gtar on darwin/bsd + substituteInPlace testing/functional/test_restart.py \ + --replace-fail 'tarcmd = "gtar"' 'tarcmd = "tar"' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # tests try to access these files in the sandbox, but can't deal with EPERM + substituteInPlace testing/unit/test_globmatch.py \ + --replace-fail /var/log /test/log + substituteInPlace testing/unit/test_selection.py \ + --replace-fail /usr/bin /dev + # don't use /tmp/ in tests + substituteInPlace duplicity/backends/_testbackend.py \ + --replace-fail '"/tmp/' 'os.environ.get("TMPDIR")+"/' + ''; + + disabledTests = lib.optionals stdenv.hostPlatform.isDarwin [ + # uses /tmp/ + "testing/unit/test_cli_main.py::CommandlineTest::test_intermixed_args" + ]; + + nativeBuildInputs = [ + makeWrapper + gettext + python3.pkgs.wrapPython + wrapGAppsNoGuiHook + python3.pkgs.setuptools-scm + ]; + + buildInputs = [ + librsync + # For Gio typelib + glib + ]; + + pythonPath = + with python3.pkgs; + [ + b2sdk + boto3 + cffi + cryptography + ecdsa + idna + pygobject3 + fasteners + lockfile + paramiko + pyasn1 + pycrypto + pydrive2 + future + ] + ++ paramiko.optional-dependencies.invoke; + + nativeCheckInputs = + [ + gnupg # Add 'gpg' to PATH. + gnutar # Add 'tar' to PATH. + librsync # Add 'rdiff' to PATH. + par2cmdline # Add 'par2' to PATH. + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + util-linux # Add 'setsid' to PATH. + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + getconf + ] + ++ (with python3.pkgs; [ + lockfile + mock + pexpect + pytestCheckHook + fasteners + ]); + + # Prevent double wrapping, let the Python wrapper use the args in preFixup. + dontWrapGApps = true; + + preFixup = + let + binPath = lib.makeBinPath ( + [ + gnupg + ncftp + rsync + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + getconf + ] + ); + in + '' + makeWrapperArgsBak=("''${makeWrapperArgs[@]}") + makeWrapperArgs+=( + "''${gappsWrapperArgs[@]}" + --prefix PATH : "${binPath}" + ) + ''; + + postFixup = '' + # Restore previous value for tests wrapping in preInstallCheck + makeWrapperArgs=("''${makeWrapperArgsBak[@]}") + ''; + + preCheck = '' + # tests need writable $HOME + HOME=$PWD/.home + + wrapPythonProgramsIn "$PWD/testing/overrides/bin" "$pythonPath" + ''; + + doCheck = true; + + passthru = { + updateScript = nix-update-script { + extraArgs = [ + "--version-regex" + "rel\.(.*)" + ]; + }; + + tests.version = testers.testVersion { + package = self; + }; }; - }; - meta = with lib; { - changelog = "https://gitlab.com/duplicity/duplicity/-/blob/${src.rev}/CHANGELOG.md"; - description = "Encrypted bandwidth-efficient backup using the rsync algorithm"; - homepage = "https://duplicity.gitlab.io/duplicity-web/"; - license = licenses.gpl2Plus; - mainProgram = "duplicity"; - maintainers = with maintainers; [ corngood ]; + meta = with lib; { + changelog = "https://gitlab.com/duplicity/duplicity/-/blob/${src.rev}/CHANGELOG.md"; + description = "Encrypted bandwidth-efficient backup using the rsync algorithm"; + homepage = "https://duplicity.gitlab.io/duplicity-web/"; + license = licenses.gpl2Plus; + mainProgram = "duplicity"; + maintainers = with maintainers; [ corngood ]; + }; }; -}; -in self +in +self diff --git a/pkgs/by-name/du/duply/package.nix b/pkgs/by-name/du/duply/package.nix index 77da73a412bb83..c963bc589be8bf 100644 --- a/pkgs/by-name/du/duply/package.nix +++ b/pkgs/by-name/du/duply/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchurl, coreutils, python3, duplicity, gawk, gnupg, bash -, gnugrep, txt2man, makeWrapper, which +{ + lib, + stdenv, + fetchurl, + coreutils, + python3, + duplicity, + gawk, + gnupg, + bash, + gnugrep, + txt2man, + makeWrapper, + which, }: stdenv.mkDerivation rec { @@ -21,7 +33,17 @@ stdenv.mkDerivation rec { mkdir -p "$out/share/man/man1" install -vD duply "$out/bin" wrapProgram "$out/bin/duply" --prefix PATH : \ - ${lib.makeBinPath [ coreutils python3 duplicity gawk gnupg bash gnugrep txt2man which ]} + ${lib.makeBinPath [ + coreutils + python3 + duplicity + gawk + gnupg + bash + gnugrep + txt2man + which + ]} "$out/bin/duply" txt2man > "$out/share/man/man1/duply.1" ''; diff --git a/pkgs/by-name/du/dust/package.nix b/pkgs/by-name/du/dust/package.nix index 6721942945e5c0..b7ce82c4995d44 100644 --- a/pkgs/by-name/du/dust/package.nix +++ b/pkgs/by-name/du/dust/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, rustPlatform, apple-sdk_11, installShellFiles }: +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + apple-sdk_11, + installShellFiles, +}: rustPlatform.buildRustPackage rec { # Originally, this package was under the attribute `du-dust`, since `dust` was taken. diff --git a/pkgs/by-name/du/dutree/package.nix b/pkgs/by-name/du/dutree/package.nix index 421af51aef5140..741a579a1283dc 100644 --- a/pkgs/by-name/du/dutree/package.nix +++ b/pkgs/by-name/du/dutree/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, lib, rustPlatform }: +{ + fetchFromGitHub, + lib, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "dutree"; diff --git a/pkgs/by-name/dv/dvb-apps/package.nix b/pkgs/by-name/dv/dvb-apps/package.nix index ad28bcd0ce6ed0..43b4f13c7d86e9 100644 --- a/pkgs/by-name/dv/dvb-apps/package.nix +++ b/pkgs/by-name/dv/dvb-apps/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, perl -, fetchpatch +{ + lib, + stdenv, + fetchurl, + perl, + fetchpatch, }: stdenv.mkDerivation { pname = "dvb-apps"; diff --git a/pkgs/by-name/dv/dvd-slideshow/package.nix b/pkgs/by-name/dv/dvd-slideshow/package.nix index 6499b6153c8da1..619fda45439337 100644 --- a/pkgs/by-name/dv/dvd-slideshow/package.nix +++ b/pkgs/by-name/dv/dvd-slideshow/package.nix @@ -1,33 +1,59 @@ -{ stdenv, lib, fetchurl, writeScript, cdrtools, dvdauthor, ffmpeg, imagemagick, lame, mjpegtools, sox, transcode, vorbis-tools, runtimeShell }: +{ + stdenv, + lib, + fetchurl, + writeScript, + cdrtools, + dvdauthor, + ffmpeg, + imagemagick, + lame, + mjpegtools, + sox, + transcode, + vorbis-tools, + runtimeShell, +}: let - binPath = lib.makeBinPath [ cdrtools dvdauthor ffmpeg imagemagick lame mjpegtools sox transcode vorbis-tools ]; + binPath = lib.makeBinPath [ + cdrtools + dvdauthor + ffmpeg + imagemagick + lame + mjpegtools + sox + transcode + vorbis-tools + ]; wrapper = writeScript "dvd-slideshow.sh" '' - #!${runtimeShell} - # wrapper script for dvd-slideshow programs - export PATH=${binPath}:$PATH + #!${runtimeShell} + # wrapper script for dvd-slideshow programs + export PATH=${binPath}:$PATH - dir=`dirname "$0"` - exe=`basename "$0"` - case "$exe" in - dvd-slideshow) - # use mpeg2enc by default as ffmpeg is known to crash. - # run dvd-slideshow.ffmpeg to force ffmpeg. - "$dir/dvd-slideshow.real" -mpeg2enc $@ - ;; + dir=`dirname "$0"` + exe=`basename "$0"` + case "$exe" in + dvd-slideshow) + # use mpeg2enc by default as ffmpeg is known to crash. + # run dvd-slideshow.ffmpeg to force ffmpeg. + "$dir/dvd-slideshow.real" -mpeg2enc $@ + ;; - dvd-slideshow.ffmpeg) - "$dir/dvd-slideshow.real" $@ - ;; + dvd-slideshow.ffmpeg) + "$dir/dvd-slideshow.real" $@ + ;; - *) - "$dir/$exe.real" $@ - ;; - esac - ''; + *) + "$dir/$exe.real" $@ + ;; + esac + ''; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "dvd-slideshow"; version = "0.8.4-2"; diff --git a/pkgs/by-name/dv/dvd-vr/package.nix b/pkgs/by-name/dv/dvd-vr/package.nix index cd207ec6ec6eda..3a807f009d2df4 100644 --- a/pkgs/by-name/dv/dvd-vr/package.nix +++ b/pkgs/by-name/dv/dvd-vr/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation (finalAttrs: { pname = "dvd-vr"; @@ -17,5 +21,4 @@ stdenv.mkDerivation (finalAttrs: { maintainers = with maintainers; [ fgaz ]; mainProgram = "dvd-vr"; }; -} -) +}) diff --git a/pkgs/by-name/dv/dvdauthor/package.nix b/pkgs/by-name/dv/dvdauthor/package.nix index 721368ae390ae6..2f5f423342b0a5 100644 --- a/pkgs/by-name/dv/dvdauthor/package.nix +++ b/pkgs/by-name/dv/dvdauthor/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, libdvdread -, libxml2 -, freetype -, fribidi -, libpng -, zlib -, pkg-config -, flex -, bison +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + libdvdread, + libxml2, + freetype, + fribidi, + libpng, + zlib, + pkg-config, + flex, + bison, }: stdenv.mkDerivation rec { @@ -22,7 +23,16 @@ stdenv.mkDerivation rec { hash = "sha256-MCCpLen3jrNvSLbyLVoAHEcQeCZjSnhaYt/NCA9hLrc="; }; - buildInputs = [ libpng freetype libdvdread libxml2 zlib fribidi flex bison ]; + buildInputs = [ + libpng + freetype + libdvdread + libxml2 + zlib + fribidi + flex + bison + ]; nativeBuildInputs = [ pkg-config diff --git a/pkgs/by-name/dv/dvdbackup/package.nix b/pkgs/by-name/dv/dvdbackup/package.nix index 5e791da598a7f7..690b793b5123d4 100644 --- a/pkgs/by-name/dv/dvdbackup/package.nix +++ b/pkgs/by-name/dv/dvdbackup/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchpatch, libdvdread, libdvdcss, dvdauthor }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libdvdread, + libdvdcss, + dvdauthor, +}: stdenv.mkDerivation rec { version = "0.4.2"; @@ -9,14 +17,20 @@ stdenv.mkDerivation rec { sha256 = "1rl3h7waqja8blmbpmwy01q9fgr5r0c32b8dy3pbf59bp3xmd37g"; }; - buildInputs = [ libdvdread libdvdcss dvdauthor ]; + buildInputs = [ + libdvdread + libdvdcss + dvdauthor + ]; # see https://bugs.launchpad.net/dvdbackup/+bug/1869226 patchFlags = [ "-p0" ]; - patches = [ (fetchpatch { - url = "https://git.slackbuilds.org/slackbuilds/plain/multimedia/dvdbackup/patches/dvdbackup-dvdread-6.1.patch"; - sha256 = "1v3xl01bwq1592i5x5dyh95r0mmm1zvvwf92fgjc0smr0k3davfz"; - })]; + patches = [ + (fetchpatch { + url = "https://git.slackbuilds.org/slackbuilds/plain/multimedia/dvdbackup/patches/dvdbackup-dvdread-6.1.patch"; + sha256 = "1v3xl01bwq1592i5x5dyh95r0mmm1zvvwf92fgjc0smr0k3davfz"; + }) + ]; meta = { description = "Tool to rip video DVDs from the command line"; diff --git a/pkgs/by-name/dv/dvdisaster/package.nix b/pkgs/by-name/dv/dvdisaster/package.nix index cb448ef157e143..c5e2921ce507e8 100644 --- a/pkgs/by-name/dv/dvdisaster/package.nix +++ b/pkgs/by-name/dv/dvdisaster/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, gettext -, pkg-config -, which -, glib -, gtk2 -, enableSoftening ? true +{ + lib, + stdenv, + fetchurl, + gettext, + pkg-config, + which, + glib, + gtk2, + enableSoftening ? true, }: stdenv.mkDerivation rec { @@ -18,8 +19,15 @@ stdenv.mkDerivation rec { hash = "sha256-3Qqf9i8aSL9z2uJvm8P/QOPp83nODC3fyLL1iBIgf+g="; }; - nativeBuildInputs = [ gettext pkg-config which ]; - buildInputs = [ glib gtk2 ]; + nativeBuildInputs = [ + gettext + pkg-config + which + ]; + buildInputs = [ + glib + gtk2 + ]; patches = lib.optionals enableSoftening [ ./encryption.patch diff --git a/pkgs/by-name/dv/dvdplusrwtools/package.nix b/pkgs/by-name/dv/dvdplusrwtools/package.nix index 5b0287efed81c3..e16f95fe74127d 100644 --- a/pkgs/by-name/dv/dvdplusrwtools/package.nix +++ b/pkgs/by-name/dv/dvdplusrwtools/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchpatch, cdrtools, m4, darwin }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + cdrtools, + m4, + darwin, +}: let inherit (darwin.apple_sdk.frameworks) IOKit; @@ -12,27 +20,63 @@ stdenv.mkDerivation rec { sha256 = "1jkjvvnjcyxpql97xjjx0kwvy70kxpiznr2zpjy2hhci5s10zmpq"; }; - patches = [ ./darwin.patch ] - # Patches from Gentoo - ++ builtins.map ({pfile, sha256}: fetchpatch { - url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/app-cdr/dvd+rw-tools/files/${pfile}?id=b510df361241e8f16314b1f14642305f0111dac6"; - inherit sha256; - }) - [{ pfile = "dvd+rw-tools-7.0-dvddl-r1.patch"; sha256 = "12l33jq6405shfwdycrj52qmd07h5bsp1vjaddknfri456azjny5"; } - { pfile = "dvd+rw-tools-7.0-glibc2.6.90.patch"; sha256 = "1fb3gap2in782pa4164h1w0ha8ggsq3inissa1k0zn2p2r3rb5ln"; } - { pfile = "dvd+rw-tools-7.0-reload.patch"; sha256 = "12v2y2y6ci5hh6lbmsk97dzgznrm4bxwhc81mq684ix0qspb9mq4"; } - { pfile = "dvd+rw-tools-7.0-sysmacros.patch"; sha256 = "1rkb26cyhfxklkmna3l9b4797f6gzlxyqqin44jwnq3jmwfrs6v0"; } - { pfile = "dvd+rw-tools-7.0-wctomb-r1.patch"; sha256 = "1xg770l0b4bjn30y7nqg619v4m5ickcn2n8hv9k2an6r191daq58"; } - { pfile = "dvd+rw-tools-7.0-wexit.patch"; sha256 = "0sqzlkm19fmjx4lzxkxwn2ymrj9fq0zk0jkys3xm6xvd2ibb6kxl"; } - { pfile = "dvd+rw-tools-7.1-bluray_pow_freespace.patch"; sha256 = "0iscz8fs5002ymk6wl2fz4x06b7bdnc57rfz8kbv3216acqi5rv3"; } - { pfile = "dvd+rw-tools-7.1-bluray_srm+pow.patch"; sha256 = "0sy40m12w987i6g0cyxv8cfmab4vp7cd222lv05apknfi2y7smmw"; } - { pfile = "dvd+rw-tools-7.1-lastshort.patch"; sha256 = "01wspv70sil20khkg5kj086b1x8rrig4yhcq9s88bdjd42nv0vpx"; } - { pfile = "dvd+rw-tools-7.1-noevent.patch"; sha256 = "1kbmxpg15wci33f2h6pxxvf3qm0kpyzx9wj5a3l67sk34hvza3z6"; } - ]; + patches = + [ ./darwin.patch ] + # Patches from Gentoo + ++ + builtins.map + ( + { pfile, sha256 }: + fetchpatch { + url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/app-cdr/dvd+rw-tools/files/${pfile}?id=b510df361241e8f16314b1f14642305f0111dac6"; + inherit sha256; + } + ) + [ + { + pfile = "dvd+rw-tools-7.0-dvddl-r1.patch"; + sha256 = "12l33jq6405shfwdycrj52qmd07h5bsp1vjaddknfri456azjny5"; + } + { + pfile = "dvd+rw-tools-7.0-glibc2.6.90.patch"; + sha256 = "1fb3gap2in782pa4164h1w0ha8ggsq3inissa1k0zn2p2r3rb5ln"; + } + { + pfile = "dvd+rw-tools-7.0-reload.patch"; + sha256 = "12v2y2y6ci5hh6lbmsk97dzgznrm4bxwhc81mq684ix0qspb9mq4"; + } + { + pfile = "dvd+rw-tools-7.0-sysmacros.patch"; + sha256 = "1rkb26cyhfxklkmna3l9b4797f6gzlxyqqin44jwnq3jmwfrs6v0"; + } + { + pfile = "dvd+rw-tools-7.0-wctomb-r1.patch"; + sha256 = "1xg770l0b4bjn30y7nqg619v4m5ickcn2n8hv9k2an6r191daq58"; + } + { + pfile = "dvd+rw-tools-7.0-wexit.patch"; + sha256 = "0sqzlkm19fmjx4lzxkxwn2ymrj9fq0zk0jkys3xm6xvd2ibb6kxl"; + } + { + pfile = "dvd+rw-tools-7.1-bluray_pow_freespace.patch"; + sha256 = "0iscz8fs5002ymk6wl2fz4x06b7bdnc57rfz8kbv3216acqi5rv3"; + } + { + pfile = "dvd+rw-tools-7.1-bluray_srm+pow.patch"; + sha256 = "0sy40m12w987i6g0cyxv8cfmab4vp7cd222lv05apknfi2y7smmw"; + } + { + pfile = "dvd+rw-tools-7.1-lastshort.patch"; + sha256 = "01wspv70sil20khkg5kj086b1x8rrig4yhcq9s88bdjd42nv0vpx"; + } + { + pfile = "dvd+rw-tools-7.1-noevent.patch"; + sha256 = "1kbmxpg15wci33f2h6pxxvf3qm0kpyzx9wj5a3l67sk34hvza3z6"; + } + ]; nativeBuildInputs = [ m4 ]; - buildInputs = [ cdrtools ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ IOKit ]; + buildInputs = [ cdrtools ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ IOKit ]; makeFlags = [ "prefix=${placeholder "out"}" @@ -40,17 +84,22 @@ stdenv.mkDerivation rec { "CXX=${stdenv.cc.targetPrefix}c++" ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - # error: invalid suffix on literal; C++11 requires a space between literal and identifier - "-Wno-reserved-user-defined-literal" - # error: non-constant-expression cannot be narrowed from type 'size_t' (aka 'unsigned long') to 'IOByteCount' (aka 'unsigned int') in initializer list - "-Wno-c++11-narrowing" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + # error: invalid suffix on literal; C++11 requires a space between literal and identifier + "-Wno-reserved-user-defined-literal" + # error: non-constant-expression cannot be narrowed from type 'size_t' (aka 'unsigned long') to 'IOByteCount' (aka 'unsigned int') in initializer list + "-Wno-c++11-narrowing" + ] + ); meta = with lib; { homepage = "http://fy.chalmers.se/~appro/linux/DVD+RW/tools"; description = "Tools for mastering Blu-ray and DVD+-RW/+-R media"; platforms = platforms.unix; - license = with licenses; [ gpl2Only publicDomain ]; + license = with licenses; [ + gpl2Only + publicDomain + ]; }; } diff --git a/pkgs/by-name/dv/dvdstyler/package.nix b/pkgs/by-name/dv/dvdstyler/package.nix index 55c2c271980de2..c882ff1050864c 100644 --- a/pkgs/by-name/dv/dvdstyler/package.nix +++ b/pkgs/by-name/dv/dvdstyler/package.nix @@ -1,36 +1,41 @@ -{ lib -, stdenv -, fetchurl -, bison -, cdrtools -, docbook_xml_dtd_412 -, docbook-xsl-nons -, dvdauthor -, dvdplusrwtools -, ffmpeg -, flex -, fontconfig -, gettext -, glib -, gobject-introspection -, libexif -, libjpeg -, pkg-config -, wrapGAppsHook3 -, wxGTK32 -, wxSVG -, xine-ui -, xmlto -, zip +{ + lib, + stdenv, + fetchurl, + bison, + cdrtools, + docbook_xml_dtd_412, + docbook-xsl-nons, + dvdauthor, + dvdplusrwtools, + ffmpeg, + flex, + fontconfig, + gettext, + glib, + gobject-introspection, + libexif, + libjpeg, + pkg-config, + wrapGAppsHook3, + wxGTK32, + wxSVG, + xine-ui, + xmlto, + zip, -, dvdisasterSupport ? true, dvdisaster ? null -, udevSupport ? true, udev ? null -, dbusSupport ? true, dbus ? null + dvdisasterSupport ? true, + dvdisaster ? null, + udevSupport ? true, + udev ? null, + dbusSupport ? true, + dbus ? null, }: let inherit (lib) optionals makeBinPath; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "dvdstyler"; version = "3.3b4"; @@ -51,38 +56,42 @@ in stdenv.mkDerivation rec { xmlto zip ]; - buildInputs = [ - cdrtools - dvdauthor - dvdplusrwtools - ffmpeg - fontconfig - glib - libexif - libjpeg - wxSVG - wxGTK32 - xine-ui - ] - ++ optionals dvdisasterSupport [ dvdisaster ] - ++ optionals udevSupport [ udev ] - ++ optionals dbusSupport [ dbus ]; - - enableParallelBuilding = true; - - preFixup = let - binPath = makeBinPath ([ + buildInputs = + [ cdrtools dvdauthor dvdplusrwtools - ] ++ optionals dvdisasterSupport [ dvdisaster ]); + ffmpeg + fontconfig + glib + libexif + libjpeg + wxSVG + wxGTK32 + xine-ui + ] + ++ optionals dvdisasterSupport [ dvdisaster ] + ++ optionals udevSupport [ udev ] + ++ optionals dbusSupport [ dbus ]; + + enableParallelBuilding = true; + + preFixup = + let + binPath = makeBinPath ( + [ + cdrtools + dvdauthor + dvdplusrwtools + ] + ++ optionals dvdisasterSupport [ dvdisaster ] + ); in '' gappsWrapperArgs+=( --prefix PATH : "${binPath}" ) - ''; - + ''; meta = with lib; { homepage = "https://www.dvdstyler.org/"; diff --git a/pkgs/by-name/dv/dvgrab/package.nix b/pkgs/by-name/dv/dvgrab/package.nix index de5c5e906bf58b..01e2a3ac1d1a51 100644 --- a/pkgs/by-name/dv/dvgrab/package.nix +++ b/pkgs/by-name/dv/dvgrab/package.nix @@ -1,5 +1,16 @@ -{ fetchFromGitHub, lib, stdenv, libunwind, libraw1394, libjpeg, libiec61883, libdv -, libavc1394, pkg-config, autoreconfHook }: +{ + fetchFromGitHub, + lib, + stdenv, + libunwind, + libraw1394, + libjpeg, + libiec61883, + libdv, + libavc1394, + pkg-config, + autoreconfHook, +}: stdenv.mkDerivation { pname = "dvgrab"; @@ -14,11 +25,17 @@ stdenv.mkDerivation { }; buildInputs = [ - libunwind libraw1394 libjpeg libiec61883 libdv libavc1394 + libunwind + libraw1394 + libjpeg + libiec61883 + libdv + libavc1394 ]; nativeBuildInputs = [ - autoreconfHook pkg-config + autoreconfHook + pkg-config ]; meta = with lib; { diff --git a/pkgs/by-name/dw/dwarf2json/package.nix b/pkgs/by-name/dw/dwarf2json/package.nix index 3bd0fa4b94a874..05e3983dd41f36 100644 --- a/pkgs/by-name/dw/dwarf2json/package.nix +++ b/pkgs/by-name/dw/dwarf2json/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "dwarf2json"; diff --git a/pkgs/by-name/dw/dwarfs/package.nix b/pkgs/by-name/dw/dwarfs/package.nix index 50c2121997daeb..91174d41d7ade7 100644 --- a/pkgs/by-name/dw/dwarfs/package.nix +++ b/pkgs/by-name/dw/dwarfs/package.nix @@ -108,7 +108,7 @@ stdenv.mkDerivation (finalAttrs: { "dwarfs/tools_test.categorize/*" ]; in - "-${lib.concatStringsSep ":" disabledTests}"; + "-${lib.concatStringsSep ":" disabledTests}"; meta = { description = "Fast high compression read-only file system"; diff --git a/pkgs/by-name/dw/dwdiff/package.nix b/pkgs/by-name/dw/dwdiff/package.nix index 320f8e25bcb75a..9db502a2b367e3 100644 --- a/pkgs/by-name/dw/dwdiff/package.nix +++ b/pkgs/by-name/dw/dwdiff/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, gettext -, pkg-config -, icu +{ + lib, + stdenv, + fetchurl, + gettext, + pkg-config, + icu, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/dw/dwfv/package.nix b/pkgs/by-name/dw/dwfv/package.nix index 950182954af1d6..fd1dee2057345d 100644 --- a/pkgs/by-name/dw/dwfv/package.nix +++ b/pkgs/by-name/dw/dwfv/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "dwfv"; diff --git a/pkgs/by-name/dw/dwmbar/package.nix b/pkgs/by-name/dw/dwmbar/package.nix index e2fa8155edd760..e649e508731fff 100644 --- a/pkgs/by-name/dw/dwmbar/package.nix +++ b/pkgs/by-name/dw/dwmbar/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, lib -, fetchFromGitHub +{ + stdenv, + lib, + fetchFromGitHub, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/dw/dwmblocks/package.nix b/pkgs/by-name/dw/dwmblocks/package.nix index 91e08995c9af03..d861dfb009f635 100644 --- a/pkgs/by-name/dw/dwmblocks/package.nix +++ b/pkgs/by-name/dw/dwmblocks/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libX11, patches ? [ ], writeText, conf ? null }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + patches ? [ ], + writeText, + conf ? null, +}: stdenv.mkDerivation { pname = "dwmblocks"; @@ -18,10 +26,9 @@ stdenv.mkDerivation { postPatch = let configFile = - if lib.isDerivation conf || builtins.isPath conf - then conf else writeText "blocks.def.h" conf; + if lib.isDerivation conf || builtins.isPath conf then conf else writeText "blocks.def.h" conf; in - lib.optionalString (conf != null) "cp ${configFile} blocks.def.h"; + lib.optionalString (conf != null) "cp ${configFile} blocks.def.h"; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/dw/dwt1-shell-color-scripts/package.nix b/pkgs/by-name/dw/dwt1-shell-color-scripts/package.nix index 0843962703fe52..013557a892fb88 100644 --- a/pkgs/by-name/dw/dwt1-shell-color-scripts/package.nix +++ b/pkgs/by-name/dw/dwt1-shell-color-scripts/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchFromGitLab -, installShellFiles +{ + lib, + stdenvNoCC, + fetchFromGitLab, + installShellFiles, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/dw/dwz/package.nix b/pkgs/by-name/dw/dwz/package.nix index 852201cf71144c..361f614770b07e 100644 --- a/pkgs/by-name/dw/dwz/package.nix +++ b/pkgs/by-name/dw/dwz/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, elfutils }: +{ + lib, + stdenv, + fetchurl, + elfutils, +}: stdenv.mkDerivation rec { pname = "dwz"; diff --git a/pkgs/by-name/dx/dxa/package.nix b/pkgs/by-name/dx/dxa/package.nix index 5eec63c171d21c..0b55bffdcccaa2 100644 --- a/pkgs/by-name/dx/dxa/package.nix +++ b/pkgs/by-name/dx/dxa/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, installShellFiles +{ + lib, + stdenv, + fetchurl, + installShellFiles, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/dy/dyalog/package.nix b/pkgs/by-name/dy/dyalog/package.nix index a0c7be275547b6..633dfeb64f17f0 100644 --- a/pkgs/by-name/dy/dyalog/package.nix +++ b/pkgs/by-name/dy/dyalog/package.nix @@ -1,32 +1,33 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, -, config -, acceptLicense ? config.dyalog.acceptLicense or false + config, + acceptLicense ? config.dyalog.acceptLicense or false, -, autoPatchelfHook -, dpkg -, makeWrapper -, ncurses5 + autoPatchelfHook, + dpkg, + makeWrapper, + ncurses5, -, dotnet-sdk_8 -, dotnetSupport ? false + dotnet-sdk_8, + dotnetSupport ? false, -, alsa-lib -, gtk3 -, libdrm -, libGL -, mesa -, nss -, htmlRendererSupport ? false + alsa-lib, + gtk3, + libdrm, + libGL, + mesa, + nss, + htmlRendererSupport ? false, -, unixODBC -, sqaplSupport ? false + unixODBC, + sqaplSupport ? false, -, zeroFootprintRideSupport ? false + zeroFootprintRideSupport ? false, -, enableDocs ? false + enableDocs ? false, }: let @@ -75,86 +76,91 @@ stdenv.mkDerivation (finalAttrs: { makeWrapper ]; - buildInputs = [ - (lib.getLib stdenv.cc.cc) # Used by Conga and .NET Bridge - ncurses5 # Used by the dyalog binary to correctly display in the terminal - ] - ++ lib.optionals htmlRendererSupport [ - alsa-lib - gtk3 - libdrm - libGL - mesa - nss - ] - ++ lib.optional sqaplSupport unixODBC; + buildInputs = + [ + (lib.getLib stdenv.cc.cc) # Used by Conga and .NET Bridge + ncurses5 # Used by the dyalog binary to correctly display in the terminal + ] + ++ lib.optionals htmlRendererSupport [ + alsa-lib + gtk3 + libdrm + libGL + mesa + nss + ] + ++ lib.optional sqaplSupport unixODBC; # See which files are not really important: `https://github.com/Dyalog/DyalogDocker/blob/master/rmfiles.sh` - installPhase = '' - runHook preInstall - - mkdir -p ${dyalogHome} - cp -r aplfmt aplkeys apltrans Experimental fonts Library PublicCACerts SALT StartupSession ${dyalogHome} - cp aplkeys.sh default.dse dyalog dyalogc dyalog.rt dyalog.dcfg.template dyalog.ver.dcfg.template languagebar.json mapl StartupSession.aplf ${dyalogHome} - - mkdir ${dyalogHome}/lib - cp lib/{conga35_64.so,dyalog64.so,libconga35ssl64.so} ${dyalogHome}/lib - - # Only keep the most useful workspaces - mkdir ${dyalogHome}/ws - cp ws/{conga,dfns,isolate,loaddata,salt,sharpplot,util}.dws ${dyalogHome}/ws - '' - + lib.optionalString dotnetSupport '' - cp libnethost.so Dyalog.Net.Bridge.* Lokad.ILPack.dll ${dyalogHome} - '' - + lib.optionalString htmlRendererSupport '' - cp -r locales ${dyalogHome} - cp libcef.so libEGL.so libGLESv2.so libvk_swiftshader.so libvulkan.so.1 ${dyalogHome} - cp chrome-sandbox icudtl.dat snapshot_blob.bin v8_context_snapshot.bin vk_swiftshader_icd.json *.pak ${dyalogHome} - cp lib/htmlrenderer.so ${dyalogHome}/lib - '' - + lib.optionalString sqaplSupport '' - cp lib/cxdya65u64u.so ${dyalogHome}/lib - cp ws/sqapl.dws ${dyalogHome}/ws - cp odbc.ini.sample sqapl.err sqapl.ini ${dyalogHome} - '' - + lib.optionalString zeroFootprintRideSupport '' - cp -r RIDEapp ${dyalogHome} - '' - + lib.optionalString enableDocs '' - mkdir -p $doc/share/doc/dyalog - cp -r help/* $doc/share/doc/dyalog - ln -s $doc/share/doc/dyalog ${dyalogHome}/help - '' - + '' - install -Dm644 dyalog.svg -t $out/share/icons/hicolor/scalable/apps - install -Dm644 dyalog.desktop -t $out/share/applications - - for exec in "dyalog" "mapl"; do - makeWrapper ${dyalogHome}/$exec $out/bin/$exec ${toString makeWrapperArgs} - done - - install -Dm755 scriptbin/dyalogscript $out/bin/dyalogscript - substituteInPlace $out/bin/dyalogscript \ - --subst-var-by installdir ${dyalogHome} \ - --subst-var-by scriptdir $out/bin - - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + + mkdir -p ${dyalogHome} + cp -r aplfmt aplkeys apltrans Experimental fonts Library PublicCACerts SALT StartupSession ${dyalogHome} + cp aplkeys.sh default.dse dyalog dyalogc dyalog.rt dyalog.dcfg.template dyalog.ver.dcfg.template languagebar.json mapl StartupSession.aplf ${dyalogHome} + + mkdir ${dyalogHome}/lib + cp lib/{conga35_64.so,dyalog64.so,libconga35ssl64.so} ${dyalogHome}/lib + + # Only keep the most useful workspaces + mkdir ${dyalogHome}/ws + cp ws/{conga,dfns,isolate,loaddata,salt,sharpplot,util}.dws ${dyalogHome}/ws + '' + + lib.optionalString dotnetSupport '' + cp libnethost.so Dyalog.Net.Bridge.* Lokad.ILPack.dll ${dyalogHome} + '' + + lib.optionalString htmlRendererSupport '' + cp -r locales ${dyalogHome} + cp libcef.so libEGL.so libGLESv2.so libvk_swiftshader.so libvulkan.so.1 ${dyalogHome} + cp chrome-sandbox icudtl.dat snapshot_blob.bin v8_context_snapshot.bin vk_swiftshader_icd.json *.pak ${dyalogHome} + cp lib/htmlrenderer.so ${dyalogHome}/lib + '' + + lib.optionalString sqaplSupport '' + cp lib/cxdya65u64u.so ${dyalogHome}/lib + cp ws/sqapl.dws ${dyalogHome}/ws + cp odbc.ini.sample sqapl.err sqapl.ini ${dyalogHome} + '' + + lib.optionalString zeroFootprintRideSupport '' + cp -r RIDEapp ${dyalogHome} + '' + + lib.optionalString enableDocs '' + mkdir -p $doc/share/doc/dyalog + cp -r help/* $doc/share/doc/dyalog + ln -s $doc/share/doc/dyalog ${dyalogHome}/help + '' + + '' + install -Dm644 dyalog.svg -t $out/share/icons/hicolor/scalable/apps + install -Dm644 dyalog.desktop -t $out/share/applications + + for exec in "dyalog" "mapl"; do + makeWrapper ${dyalogHome}/$exec $out/bin/$exec ${toString makeWrapperArgs} + done + + install -Dm755 scriptbin/dyalogscript $out/bin/dyalogscript + substituteInPlace $out/bin/dyalogscript \ + --subst-var-by installdir ${dyalogHome} \ + --subst-var-by scriptdir $out/bin + + runHook postInstall + ''; # Register some undeclared runtime dependencies to be patched in by autoPatchelfHook # Note: dyalog.rt is used internally to run child APL processes in - preFixup = '' - for exec in "dyalog" "dyalog.rt"; do - patchelf ${dyalogHome}/$exec --add-needed libncurses.so - done - '' - + lib.optionalString htmlRendererSupport '' - patchelf ${dyalogHome}/libcef.so --add-needed libudev.so --add-needed libGL.so - ''; + preFixup = + '' + for exec in "dyalog" "dyalog.rt"; do + patchelf ${dyalogHome}/$exec --add-needed libncurses.so + done + '' + + lib.optionalString htmlRendererSupport '' + patchelf ${dyalogHome}/libcef.so --add-needed libudev.so --add-needed libGL.so + ''; meta = { - changelog = "https://dyalog.com/dyalog/dyalog-versions/${lib.replaceStrings [ "." ] [ "" ] finalAttrs.shortVersion}.htm"; + changelog = "https://dyalog.com/dyalog/dyalog-versions/${ + lib.replaceStrings [ "." ] [ "" ] finalAttrs.shortVersion + }.htm"; description = "Dyalog APL interpreter"; homepage = "https://www.dyalog.com"; license = { @@ -163,7 +169,10 @@ stdenv.mkDerivation (finalAttrs: { free = false; }; mainProgram = "dyalog"; - maintainers = with lib.maintainers; [ tomasajt markus1189 ]; + maintainers = with lib.maintainers; [ + tomasajt + markus1189 + ]; platforms = [ "x86_64-linux" ]; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; }; diff --git a/pkgs/by-name/dy/dydisnix/package.nix b/pkgs/by-name/dy/dydisnix/package.nix index e6670ff2e1142a..0a9f6473d130cf 100644 --- a/pkgs/by-name/dy/dydisnix/package.nix +++ b/pkgs/by-name/dy/dydisnix/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libtool, pkg-config, glib -, libxml2, libxslt, getopt, libiconv, gettext, nix, disnix +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + pkg-config, + glib, + libxml2, + libxslt, + getopt, + libiconv, + gettext, + nix, + disnix, }: stdenv.mkDerivation rec { @@ -13,8 +27,22 @@ stdenv.mkDerivation rec { sha256 = "00f341274hwwil8mlgcgq331vfca9sscvpdbgkxsjvbhcqd8qa52"; }; - nativeBuildInputs = [ pkg-config autoconf automake libtool ]; - buildInputs = [ glib libxml2 libxslt getopt nix disnix libiconv gettext ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + libtool + ]; + buildInputs = [ + glib + libxml2 + libxslt + getopt + nix + disnix + libiconv + gettext + ]; preConfigure = '' ./bootstrap diff --git a/pkgs/by-name/dy/dyff/package.nix b/pkgs/by-name/dy/dyff/package.nix index 8ee17a2e382ded..cb57f6b2daccbd 100644 --- a/pkgs/by-name/dy/dyff/package.nix +++ b/pkgs/by-name/dy/dyff/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "dyff"; @@ -53,6 +58,9 @@ buildGoModule rec { ''; homepage = "https://github.com/homeport/dyff"; license = licenses.mit; - maintainers = with maintainers; [ edlimerkaj jceb ]; + maintainers = with maintainers; [ + edlimerkaj + jceb + ]; }; } diff --git a/pkgs/by-name/dy/dynamic-colors/package.nix b/pkgs/by-name/dy/dynamic-colors/package.nix index 0c04f70f26f303..b59e413cf87a99 100644 --- a/pkgs/by-name/dy/dynamic-colors/package.nix +++ b/pkgs/by-name/dy/dynamic-colors/package.nix @@ -1,13 +1,17 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "dynamic-colors"; version = "0.2.5"; src = fetchFromGitHub { - owner = "peterhoeg"; - repo = "dynamic-colors"; - rev = "v${version}"; + owner = "peterhoeg"; + repo = "dynamic-colors"; + rev = "v${version}"; sha256 = "sha256-jSdwq9WwYZP8MK6z7zJa0q93xfanr6iuvAt8YQkQxxE="; }; @@ -20,10 +24,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Change terminal colors on the fly"; - homepage = "https://github.com/peterhoeg/dynamic-colors"; - license = licenses.mit; + homepage = "https://github.com/peterhoeg/dynamic-colors"; + license = licenses.mit; maintainers = with maintainers; [ peterhoeg ]; - platforms = platforms.unix; + platforms = platforms.unix; mainProgram = "dynamic-colors"; }; } diff --git a/pkgs/by-name/dy/dynamic-wallpaper/package.nix b/pkgs/by-name/dy/dynamic-wallpaper/package.nix index 9b30aba12ac429..786db004d7a31c 100644 --- a/pkgs/by-name/dy/dynamic-wallpaper/package.nix +++ b/pkgs/by-name/dy/dynamic-wallpaper/package.nix @@ -1,17 +1,18 @@ -{ lib -, python3 -, fetchFromGitHub -, meson -, ninja -, pkg-config -, blueprint-compiler -, wrapGAppsHook4 -, appstream-glib -, desktop-file-utils -, glib -, gtk4 -, libadwaita -, librsvg +{ + lib, + python3, + fetchFromGitHub, + meson, + ninja, + pkg-config, + blueprint-compiler, + wrapGAppsHook4, + appstream-glib, + desktop-file-utils, + glib, + gtk4, + libadwaita, + librsvg, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/dy/dynamodb-local/package.nix b/pkgs/by-name/dy/dynamodb-local/package.nix index cf1498bd4a1b06..c7e92369be6e9c 100644 --- a/pkgs/by-name/dy/dynamodb-local/package.nix +++ b/pkgs/by-name/dy/dynamodb-local/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenvNoCC -, fetchurl -, jdk_headless -, jre_minimal -, makeBinaryWrapper -, curl -, jq -, yq -, dynamodb-local -, testers -, common-updater-scripts -, writeShellScript +{ + lib, + stdenvNoCC, + fetchurl, + jdk_headless, + jre_minimal, + makeBinaryWrapper, + curl, + jq, + yq, + dynamodb-local, + testers, + common-updater-scripts, + writeShellScript, }: let jre = jre_minimal.override { @@ -55,7 +56,14 @@ stdenvNoCC.mkDerivation (finalAttrs: { }; updateScript = writeShellScript "update-dynamodb-local" '' set -o errexit - export PATH="${lib.makeBinPath [ curl jq yq common-updater-scripts ]}:$PATH" + export PATH="${ + lib.makeBinPath [ + curl + jq + yq + common-updater-scripts + ] + }:$PATH" NEW_VERSION=$(curl -s https://repo1.maven.org/maven2/com/amazonaws/DynamoDBLocal/maven-metadata.xml | xq -r '.metadata.versioning.latest') NEW_VERSION_DATE=$(curl -s https://repo1.maven.org/maven2/com/amazonaws/DynamoDBLocal/maven-metadata.xml | xq -r '.metadata.versioning.lastUpdated | "\(.[:4])-\(.[4:6])-\(.[6:8])"') @@ -77,7 +85,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { homepage = "https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/DynamoDBLocal.html"; license = licenses.unfree; mainProgram = "dynamodb-local"; - maintainers = with maintainers; [ shyim martinjlowm ]; + maintainers = with maintainers; [ + shyim + martinjlowm + ]; platforms = platforms.all; sourceProvenance = with lib.sourceTypes; [ binaryBytecode diff --git a/pkgs/by-name/dy/dyncall/package.nix b/pkgs/by-name/dy/dyncall/package.nix index 75841b5d0d71bc..604438b4d3dabc 100644 --- a/pkgs/by-name/dy/dyncall/package.nix +++ b/pkgs/by-name/dy/dyncall/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "dyncall"; diff --git a/pkgs/by-name/dy/dysk/package.nix b/pkgs/by-name/dy/dysk/package.nix index 5d447e4eccbc6a..f8d7abf7511cdf 100644 --- a/pkgs/by-name/dy/dysk/package.nix +++ b/pkgs/by-name/dy/dysk/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, }: rustPlatform.buildRustPackage rec { @@ -31,7 +32,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/Canop/dysk"; changelog = "https://github.com/Canop/dysk/blob/${src.rev}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ figsoda koral ]; + maintainers = with maintainers; [ + figsoda + koral + ]; mainProgram = "dysk"; }; } diff --git a/pkgs/by-name/dz/dzen2/package.nix b/pkgs/by-name/dz/dzen2/package.nix index df7521cd2c414b..ae7910ad2c0b5e 100644 --- a/pkgs/by-name/dz/dzen2/package.nix +++ b/pkgs/by-name/dz/dzen2/package.nix @@ -1,11 +1,25 @@ -{ lib, stdenv, fetchurl, pkg-config, libX11, libXft, libXinerama, libXpm }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libX11, + libXft, + libXinerama, + libXpm, +}: stdenv.mkDerivation rec { pname = "dzen2"; version = "0.9.5"; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libX11 libXft libXinerama libXpm ]; + buildInputs = [ + libX11 + libXft + libXinerama + libXpm + ]; src = fetchurl { url = "https://github.com/robm/dzen/tarball/master/dzen2-${version}git.tar.gz"; diff --git a/pkgs/by-name/e1/e16/package.nix b/pkgs/by-name/e1/e16/package.nix index b143a4bec27db0..7036c2db65104d 100644 --- a/pkgs/by-name/e1/e16/package.nix +++ b/pkgs/by-name/e1/e16/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, freetype -, imlib2 -, libSM -, libXcomposite -, libXdamage -, libXext -, libXfixes -, libXft -, libXinerama -, libXrandr -, libpulseaudio -, libsndfile -, pango -, perl -, python3 -, gitUpdater +{ + lib, + stdenv, + fetchurl, + pkg-config, + freetype, + imlib2, + libSM, + libXcomposite, + libXdamage, + libXext, + libXfixes, + libXft, + libXinerama, + libXrandr, + libpulseaudio, + libsndfile, + pango, + perl, + python3, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/e1/e17gtk/package.nix b/pkgs/by-name/e1/e17gtk/package.nix index 46a1f926402f00..b18de393621546 100644 --- a/pkgs/by-name/e1/e17gtk/package.nix +++ b/pkgs/by-name/e1/e17gtk/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "e17gtk"; diff --git a/pkgs/by-name/e1/e1s/package.nix b/pkgs/by-name/e1/e1s/package.nix index ce1ce7dd3cd9f0..fbbeed852974d5 100644 --- a/pkgs/by-name/e1/e1s/package.nix +++ b/pkgs/by-name/e1/e1s/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: let pname = "e1s"; version = "1.0.42"; diff --git a/pkgs/by-name/e2/e2fsprogs/package.nix b/pkgs/by-name/e2/e2fsprogs/package.nix index 43549c233b8280..6210299c3645c4 100644 --- a/pkgs/by-name/e2/e2fsprogs/package.nix +++ b/pkgs/by-name/e2/e2fsprogs/package.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, buildPackages, fetchurl, fetchpatch, pkg-config, libuuid, gettext, texinfo -, withFuse ? stdenv.hostPlatform.isLinux, fuse3 -, shared ? !stdenv.hostPlatform.isStatic -, e2fsprogs, runCommand +{ + lib, + stdenv, + buildPackages, + fetchurl, + fetchpatch, + pkg-config, + libuuid, + gettext, + texinfo, + withFuse ? stdenv.hostPlatform.isLinux, + fuse3, + shared ? !stdenv.hostPlatform.isStatic, + e2fsprogs, + runCommand, }: stdenv.mkDerivation rec { @@ -14,13 +25,23 @@ stdenv.mkDerivation rec { }; # fuse2fs adds 14mb of dependencies - outputs = [ "bin" "dev" "out" "man" "info" ] - ++ lib.optionals withFuse [ "fuse2fs" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + "info" + ] ++ lib.optionals withFuse [ "fuse2fs" ]; depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ pkg-config texinfo ]; - buildInputs = [ libuuid gettext ] - ++ lib.optionals withFuse [ fuse3 ]; + nativeBuildInputs = [ + pkg-config + texinfo + ]; + buildInputs = [ + libuuid + gettext + ] ++ lib.optionals withFuse [ fuse3 ]; patches = [ (fetchurl { @@ -36,39 +57,44 @@ stdenv.mkDerivation rec { ]; configureFlags = - if stdenv.hostPlatform.isLinux then [ - # It seems that the e2fsprogs is one of the few packages that cannot be - # build with shared and static libs. - (if shared then "--enable-elf-shlibs" else "--disable-elf-shlibs") - "--enable-symlink-install" - "--enable-relative-symlinks" - "--with-crond-dir=no" - # fsck, libblkid, libuuid and uuidd are in util-linux-ng (the "libuuid" dependency) - "--disable-fsck" - "--disable-libblkid" - "--disable-libuuid" - "--disable-uuidd" - ] else [ - "--enable-libuuid --disable-e2initrd-helper" - ]; + if stdenv.hostPlatform.isLinux then + [ + # It seems that the e2fsprogs is one of the few packages that cannot be + # build with shared and static libs. + (if shared then "--enable-elf-shlibs" else "--disable-elf-shlibs") + "--enable-symlink-install" + "--enable-relative-symlinks" + "--with-crond-dir=no" + # fsck, libblkid, libuuid and uuidd are in util-linux-ng (the "libuuid" dependency) + "--disable-fsck" + "--disable-libblkid" + "--disable-libuuid" + "--disable-uuidd" + ] + else + [ + "--enable-libuuid --disable-e2initrd-helper" + ]; nativeCheckInputs = [ buildPackages.perl ]; doCheck = true; - postInstall = '' - # avoid cycle between outputs - if [ -f $out/lib/${pname}/e2scrub_all_cron ]; then - mv $out/lib/${pname}/e2scrub_all_cron $bin/bin/ - fi - '' + lib.optionalString withFuse '' - mkdir -p $fuse2fs/bin - mv $bin/bin/fuse2fs $fuse2fs/bin/fuse2fs - ''; + postInstall = + '' + # avoid cycle between outputs + if [ -f $out/lib/${pname}/e2scrub_all_cron ]; then + mv $out/lib/${pname}/e2scrub_all_cron $bin/bin/ + fi + '' + + lib.optionalString withFuse '' + mkdir -p $fuse2fs/bin + mv $bin/bin/fuse2fs $fuse2fs/bin/fuse2fs + ''; enableParallelBuilding = true; passthru.tests = { - simple-filesystem = runCommand "e2fsprogs-create-fs" {} '' + simple-filesystem = runCommand "e2fsprogs-create-fs" { } '' mkdir -p $out truncate -s10M $out/disc ${e2fsprogs}/bin/mkfs.ext4 $out/disc | tee $out/success @@ -83,8 +109,8 @@ stdenv.mkDerivation rec { license = with licenses; [ gpl2Plus lgpl2Plus # lib/ext2fs, lib/e2p - bsd3 # lib/uuid - mit # lib/et, lib/ss + bsd3 # lib/uuid + mit # lib/et, lib/ss ]; platforms = platforms.unix; maintainers = [ ]; diff --git a/pkgs/by-name/e2/e2tools/package.nix b/pkgs/by-name/e2/e2tools/package.nix index 02c97f88daa1d9..a4544c5fa0931a 100644 --- a/pkgs/by-name/e2/e2tools/package.nix +++ b/pkgs/by-name/e2/e2tools/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, e2fsprogs }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + e2fsprogs, +}: stdenv.mkDerivation rec { pname = "e2tools"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "0nlqynrhj6ww7bnfhhfcx6bawii8iyvhgp6vz60zbnpgd68ifcx7"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ e2fsprogs ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/ea/ea/package.nix b/pkgs/by-name/ea/ea/package.nix index 7ea3b5c11ca85c..21b1ba0c7bf49a 100644 --- a/pkgs/by-name/ea/ea/package.nix +++ b/pkgs/by-name/ea/ea/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, rustPlatform -, installShellFiles -, libiconv +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + rustPlatform, + installShellFiles, + libiconv, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ea/each/package.nix b/pkgs/by-name/ea/each/package.nix index 688a9adf88473c..f4d4de5f4ab7ad 100644 --- a/pkgs/by-name/ea/each/package.nix +++ b/pkgs/by-name/ea/each/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ea/earlybird/package.nix b/pkgs/by-name/ea/earlybird/package.nix index 46b94e9d708ee8..336082800ba4bb 100644 --- a/pkgs/by-name/ea/earlybird/package.nix +++ b/pkgs/by-name/ea/earlybird/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-39jXqCXAwg/C+9gEXiS1X58OD61nMNQifnhgVGEF6ck="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Sensitive data detection tool capable of scanning source code repositories for passwords, key files, and more"; diff --git a/pkgs/by-name/ea/eartag/package.nix b/pkgs/by-name/ea/eartag/package.nix index d3df0295802c62..868b0884494bb4 100644 --- a/pkgs/by-name/ea/eartag/package.nix +++ b/pkgs/by-name/ea/eartag/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitLab -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, libadwaita -, gettext -, glib -, gobject-introspection -, desktop-file-utils -, appstream -, appstream-glib -, gtk4 -, librsvg -, python3Packages -, blueprint-compiler +{ + stdenv, + lib, + fetchFromGitLab, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + libadwaita, + gettext, + glib, + gobject-introspection, + desktop-file-utils, + appstream, + appstream-glib, + gtk4, + librsvg, + python3Packages, + blueprint-compiler, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ea/easyeasm/package.nix b/pkgs/by-name/ea/easyeasm/package.nix index fc15fe0ab84066..8dd436666d3235 100644 --- a/pkgs/by-name/ea/easyeasm/package.nix +++ b/pkgs/by-name/ea/easyeasm/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, amass -, alterx -, oam-tools -, subfinder +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + amass, + alterx, + oam-tools, + subfinder, }: buildGoModule rec { @@ -32,12 +33,14 @@ buildGoModule rec { postFixup = '' wrapProgram $out/bin/easyeasm \ - --prefix PATH : "${lib.makeBinPath [ - amass - alterx - oam-tools - subfinder - ]}" + --prefix PATH : "${ + lib.makeBinPath [ + amass + alterx + oam-tools + subfinder + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/ea/easyjson/package.nix b/pkgs/by-name/ea/easyjson/package.nix index 6b97424e0e46fa..3ceb45839b8da9 100644 --- a/pkgs/by-name/ea/easyjson/package.nix +++ b/pkgs/by-name/ea/easyjson/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ea/easyloggingpp/package.nix b/pkgs/by-name/ea/easyloggingpp/package.nix index a3b891253bf415..8aa369284f6f04 100644 --- a/pkgs/by-name/ea/easyloggingpp/package.nix +++ b/pkgs/by-name/ea/easyloggingpp/package.nix @@ -1,7 +1,13 @@ # To use this package with a CMake and pkg-config build: # pkg_check_modules(EASYLOGGINGPP REQUIRED easyloggingpp) # add_executable(main src/main.cpp ${EASYLOGGINGPP_PREFIX}/include/easylogging++.cc) -{ lib, stdenv, fetchFromGitHub, cmake, gtest }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gtest, +}: stdenv.mkDerivation rec { pname = "easyloggingpp"; version = "9.97.1"; @@ -12,11 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-R4NdwsUywgJoK5E/OdZXFds6iBKOsMa0E+2PDdQbV6E="; }; - nativeBuildInputs = [cmake]; - buildInputs = [gtest]; + nativeBuildInputs = [ cmake ]; + buildInputs = [ gtest ]; cmakeFlags = [ "-Dtest=ON" ]; - env.NIX_CFLAGS_COMPILE = "-std=c++14" + - lib.optionalString stdenv.hostPlatform.isLinux " -pthread"; + env.NIX_CFLAGS_COMPILE = "-std=c++14" + lib.optionalString stdenv.hostPlatform.isLinux " -pthread"; postInstall = '' mkdir -p $out/include cp ../src/easylogging++.cc $out/include @@ -25,7 +30,7 @@ stdenv.mkDerivation rec { description = "C++ logging library"; homepage = "https://github.com/amrayn/easyloggingpp"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [acowley]; + maintainers = with lib.maintainers; [ acowley ]; platforms = lib.platforms.all; }; } diff --git a/pkgs/by-name/ea/easypdkprog/package.nix b/pkgs/by-name/ea/easypdkprog/package.nix index 4e9b8f1722bc94..b4c86551e142ad 100644 --- a/pkgs/by-name/ea/easypdkprog/package.nix +++ b/pkgs/by-name/ea/easypdkprog/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "easypdkprog"; @@ -11,11 +15,13 @@ stdenv.mkDerivation rec { sha256 = "0hc3gdmn6l01z63hzzwdhbdyy288gh5v219bsfm8fb1498vpnd6f"; }; - installPhase = '' - install -Dm755 -t $out/bin easypdkprog - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - install -Dm644 -t $out/etc/udev/rules.d Linux_udevrules/70-stm32vcp.rules - ''; + installPhase = + '' + install -Dm755 -t $out/bin easypdkprog + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + install -Dm644 -t $out/etc/udev/rules.d Linux_udevrules/70-stm32vcp.rules + ''; meta = with lib; { description = "Read, write and execute programs on PADAUK microcontroller"; diff --git a/pkgs/by-name/ea/easyrsa/package.nix b/pkgs/by-name/ea/easyrsa/package.nix index 9705315f8dd064..2305745bd28f1a 100644 --- a/pkgs/by-name/ea/easyrsa/package.nix +++ b/pkgs/by-name/ea/easyrsa/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, openssl, makeWrapper, runtimeShell }: +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + makeWrapper, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "easyrsa"; @@ -56,7 +63,10 @@ stdenv.mkDerivation rec { description = "Simple shell based CA utility"; homepage = "https://openvpn.net/"; license = licenses.gpl2Only; - maintainers = [ maintainers.offline maintainers.numinit ]; + maintainers = [ + maintainers.offline + maintainers.numinit + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ea/easysnap/package.nix b/pkgs/by-name/ea/easysnap/package.nix index 46952ce5327a35..6d88b2c00f6d0d 100644 --- a/pkgs/by-name/ea/easysnap/package.nix +++ b/pkgs/by-name/ea/easysnap/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchFromGitHub, zfs }: +{ + lib, + stdenv, + fetchFromGitHub, + zfs, +}: stdenv.mkDerivation { pname = "easysnap"; @@ -22,9 +27,9 @@ stdenv.mkDerivation { ''; meta = with lib; { - homepage = "https://github.com/sjau/easysnap"; + homepage = "https://github.com/sjau/easysnap"; description = "Customizable ZFS Snapshotting tool with zfs send/recv pulling"; - license = licenses.gpl3; + license = licenses.gpl3; maintainers = with maintainers; [ sjau ]; }; diff --git a/pkgs/by-name/eb/eb-garamond/package.nix b/pkgs/by-name/eb/eb-garamond/package.nix index 7a57d9308cf9cd..cbe42f1d132c5a 100644 --- a/pkgs/by-name/eb/eb-garamond/package.nix +++ b/pkgs/by-name/eb/eb-garamond/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "eb-garamond"; @@ -21,7 +25,10 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { homepage = "http://www.georgduffner.at/ebgaramond/"; description = "Digitization of the Garamond shown on the Egenolff-Berner specimen"; - maintainers = with maintainers; [ relrod rycee ]; + maintainers = with maintainers; [ + relrod + rycee + ]; license = licenses.ofl; platforms = platforms.all; }; diff --git a/pkgs/by-name/eb/ebook2cw/package.nix b/pkgs/by-name/eb/ebook2cw/package.nix index 4c1d2a3424e738..730b10af6f3b30 100644 --- a/pkgs/by-name/eb/ebook2cw/package.nix +++ b/pkgs/by-name/eb/ebook2cw/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchgit, fetchpatch, lame, libvorbis, gettext }: +{ + lib, + stdenv, + fetchgit, + fetchpatch, + lame, + libvorbis, + gettext, +}: stdenv.mkDerivation rec { pname = "ebook2cw"; @@ -18,7 +26,11 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ lame libvorbis gettext ]; + buildInputs = [ + lame + libvorbis + gettext + ]; makeFlags = [ "DESTDIR=$(out)" ]; diff --git a/pkgs/by-name/eb/ebook_tools/package.nix b/pkgs/by-name/eb/ebook_tools/package.nix index 5efdb69fe453ca..8f09811d83fb3e 100644 --- a/pkgs/by-name/eb/ebook_tools/package.nix +++ b/pkgs/by-name/eb/ebook_tools/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, cmake, pkg-config, libxml2, libzip }: +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + libxml2, + libzip, +}: stdenv.mkDerivation rec { pname = "ebook-tools"; @@ -9,8 +17,14 @@ stdenv.mkDerivation rec { sha256 = "1bi7wsz3p5slb43kj7lgb3r6lb91lvb6ldi556k4y50ix6b5khyb"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libxml2 libzip ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + libxml2 + libzip + ]; meta = with lib; { homepage = "http://ebook-tools.sourceforge.net"; diff --git a/pkgs/by-name/eb/ebpf-usb/package.nix b/pkgs/by-name/eb/ebpf-usb/package.nix index 42a6956a34b186..6b721e968981f2 100644 --- a/pkgs/by-name/eb/ebpf-usb/package.nix +++ b/pkgs/by-name/eb/ebpf-usb/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3Packages -, bcc +{ + lib, + fetchFromGitHub, + python3Packages, + bcc, }: python3Packages.buildPythonApplication rec { @@ -20,9 +21,11 @@ python3Packages.buildPythonApplication rec { "--set PYTHONUNBUFFERED 1" ]; - pythonPath = [ bcc ] ++ (with python3Packages; [ - hexdump - ]); + pythonPath = + [ bcc ] + ++ (with python3Packages; [ + hexdump + ]); postPatch = '' substituteInPlace ebpf-usb.py \ diff --git a/pkgs/by-name/eb/ebtables/package.nix b/pkgs/by-name/eb/ebtables/package.nix index bd39175050e946..56afed5ce29c8e 100644 --- a/pkgs/by-name/eb/ebtables/package.nix +++ b/pkgs/by-name/eb/ebtables/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ebtables"; @@ -10,8 +14,12 @@ stdenv.mkDerivation rec { }; makeFlags = [ - "LIBDIR=$(out)/lib" "BINDIR=$(out)/sbin" "MANDIR=$(out)/share/man" - "ETCDIR=$(out)/etc" "INITDIR=$(TMPDIR)" "SYSCONFIGDIR=$(out)/etc/sysconfig" + "LIBDIR=$(out)/lib" + "BINDIR=$(out)/sbin" + "MANDIR=$(out)/share/man" + "ETCDIR=$(out)/etc" + "INITDIR=$(TMPDIR)" + "SYSCONFIGDIR=$(out)/etc/sysconfig" "LOCALSTATEDIR=/var" ]; diff --git a/pkgs/by-name/eb/ebtks/package.nix b/pkgs/by-name/eb/ebtks/package.nix index 664882305a0abf..e1d62ad41d0daf 100644 --- a/pkgs/by-name/eb/ebtks/package.nix +++ b/pkgs/by-name/eb/ebtks/package.nix @@ -1,25 +1,32 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libminc }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libminc, +}: stdenv.mkDerivation { pname = "ebtks"; - version = "unstable-2017-09-23"; + version = "unstable-2017-09-23"; src = fetchFromGitHub { - owner = "BIC-MNI"; - repo = "EBTKS"; - rev = "67e4e197d8a32d6462c9bdc7af44d64ebde4fb5c"; + owner = "BIC-MNI"; + repo = "EBTKS"; + rev = "67e4e197d8a32d6462c9bdc7af44d64ebde4fb5c"; hash = "sha256-+MIRE2NdRH7IQrstK3WRqft6l9I+UGD6j0G7Q6LhOKg="; }; # error: use of undeclared identifier 'finite'; did you mean 'isfinite'? - postPatch = '' - substituteInPlace templates/EBTKS/SimpleArray.h \ - --replace "#define FINITE(x) finite(x)" "#define FINITE(x) isfinite(x)" - '' - # error: ISO C++17 does not allow 'register' storage class specifier - + '' - find . -type f -exec sed -i -e 's/register //g' {} + - ''; + postPatch = + '' + substituteInPlace templates/EBTKS/SimpleArray.h \ + --replace "#define FINITE(x) finite(x)" "#define FINITE(x) isfinite(x)" + '' + # error: ISO C++17 does not allow 'register' storage class specifier + + '' + find . -type f -exec sed -i -e 's/register //g' {} + + ''; nativeBuildInputs = [ cmake ]; buildInputs = [ libminc ]; @@ -31,6 +38,6 @@ stdenv.mkDerivation { description = "Library for working with MINC files"; maintainers = with maintainers; [ bcdarwin ]; platforms = platforms.unix; - license = licenses.free; + license = licenses.free; }; } diff --git a/pkgs/by-name/eb/ebumeter/package.nix b/pkgs/by-name/eb/ebumeter/package.nix index 9c00f3dfcb5e80..3249c179cead3f 100644 --- a/pkgs/by-name/eb/ebumeter/package.nix +++ b/pkgs/by-name/eb/ebumeter/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchurl -, libX11, libXft, libclthreads, libclxclient, libjack2, libpng, libsndfile, zita-resampler +{ + lib, + stdenv, + fetchurl, + libX11, + libXft, + libclthreads, + libclxclient, + libjack2, + libpng, + libsndfile, + zita-resampler, }: stdenv.mkDerivation rec { @@ -12,7 +22,14 @@ stdenv.mkDerivation rec { }; buildInputs = [ - libX11 libXft libclthreads libclxclient libjack2 libpng libsndfile zita-resampler + libX11 + libXft + libclthreads + libclxclient + libjack2 + libpng + libsndfile + zita-resampler ]; preConfigure = '' diff --git a/pkgs/by-name/eb/ebusd/package.nix b/pkgs/by-name/eb/ebusd/package.nix index bc20b930aef067..4527d330a1ccfd 100644 --- a/pkgs/by-name/eb/ebusd/package.nix +++ b/pkgs/by-name/eb/ebusd/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, pkgs, fetchFromGitHub, fetchpatch, argparse, mosquitto, cmake, autoconf, automake, libtool, pkg-config, openssl }: +{ + lib, + stdenv, + pkgs, + fetchFromGitHub, + fetchpatch, + argparse, + mosquitto, + cmake, + autoconf, + automake, + libtool, + pkg-config, + openssl, +}: stdenv.mkDerivation rec { pname = "ebusd"; @@ -52,5 +66,5 @@ stdenv.mkDerivation rec { license = licenses.gpl3Only; maintainers = with maintainers; [ nathan-gs ]; platforms = platforms.linux; - }; + }; } diff --git a/pkgs/by-name/ec/ec2-ami-tools/package.nix b/pkgs/by-name/ec/ec2-ami-tools/package.nix index 0eaa1bb04a37a3..9143d6238342d4 100644 --- a/pkgs/by-name/ec/ec2-ami-tools/package.nix +++ b/pkgs/by-name/ec/ec2-ami-tools/package.nix @@ -1,11 +1,22 @@ -{ lib, stdenv, fetchurl, unzip, ruby, openssl, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + unzip, + ruby, + openssl, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "ec2-ami-tools"; version = "1.5.19"; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; src = fetchurl { url = "https://s3.amazonaws.com/ec2-downloads/${pname}-${version}.zip"; @@ -20,20 +31,24 @@ stdenv.mkDerivation rec { # tar invocation. patches = [ ./writable.patch ]; - installPhase = - '' - mkdir -p $out - mv * $out - rm $out/*.txt - - for i in $out/bin/*; do - wrapProgram $i \ - --set EC2_HOME $out \ - --prefix PATH : ${lib.makeBinPath [ ruby openssl ]} - done - - sed -i 's|/bin/bash|${stdenv.shell}|' $out/lib/ec2/platform/base/pipeline.rb - ''; # */ + installPhase = '' + mkdir -p $out + mv * $out + rm $out/*.txt + + for i in $out/bin/*; do + wrapProgram $i \ + --set EC2_HOME $out \ + --prefix PATH : ${ + lib.makeBinPath [ + ruby + openssl + ] + } + done + + sed -i 's|/bin/bash|${stdenv.shell}|' $out/lib/ec2/platform/base/pipeline.rb + ''; # */ meta = { homepage = "https://aws.amazon.com/developertools/Amazon-EC2/368"; diff --git a/pkgs/by-name/ec/ec2-api-tools/package.nix b/pkgs/by-name/ec/ec2-api-tools/package.nix index 97545204bfd4bd..372ffd0e7d95fd 100644 --- a/pkgs/by-name/ec/ec2-api-tools/package.nix +++ b/pkgs/by-name/ec/ec2-api-tools/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, unzip -, makeWrapper -, jre +{ + lib, + stdenv, + fetchurl, + unzip, + makeWrapper, + jre, }: stdenv.mkDerivation rec { @@ -15,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-hRq+MEA+4chqPr3d9bS//X70tYcRBTD+rfAJVNmuLzo="; }; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; installPhase = '' d=$out/libexec/ec2-api-tools diff --git a/pkgs/by-name/ec/ec2-metadata-mock/package.nix b/pkgs/by-name/ec/ec2-metadata-mock/package.nix index 5663782852c1bc..d8a00b2261352f 100644 --- a/pkgs/by-name/ec/ec2-metadata-mock/package.nix +++ b/pkgs/by-name/ec/ec2-metadata-mock/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ec2-metadata-mock"; diff --git a/pkgs/by-name/ec/ec2stepshell/package.nix b/pkgs/by-name/ec/ec2stepshell/package.nix index 6b5031ffebe2ea..760b873fd97ca0 100644 --- a/pkgs/by-name/ec/ec2stepshell/package.nix +++ b/pkgs/by-name/ec/ec2stepshell/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ec/ecasound/package.nix b/pkgs/by-name/ec/ecasound/package.nix index f23b11d1a67e44..4d991d2a7fbe37 100644 --- a/pkgs/by-name/ec/ecasound/package.nix +++ b/pkgs/by-name/ec/ecasound/package.nix @@ -1,18 +1,20 @@ -{ lib, stdenv -, fetchurl -, fetchpatch -, pkg-config -, alsa-lib -, audiofile -, libjack2 -, liblo -, liboil -, libsamplerate -, libsndfile -, lilv -, lv2 -, ncurses -, readline +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + alsa-lib, + audiofile, + libjack2, + liblo, + liboil, + libsamplerate, + libsndfile, + lilv, + lv2, + ncurses, + readline, }: # TODO: fix python. See configure log. @@ -60,7 +62,10 @@ stdenv.mkDerivation rec { strictDeps = true; CXXFLAGS = "-std=c++11"; - configureFlags = [ "--enable-liblilv" "--with-extra-cppflags=-Dnullptr=0" ]; + configureFlags = [ + "--enable-liblilv" + "--with-extra-cppflags=-Dnullptr=0" + ]; postPatch = '' sed -i -e ' @@ -71,7 +76,10 @@ stdenv.mkDerivation rec { meta = { description = "Software package designed for multitrack audio processing"; - license = with lib.licenses; [ gpl2 lgpl21 ]; + license = with lib.licenses; [ + gpl2 + lgpl21 + ]; homepage = "http://nosignal.fi/ecasound/"; }; } diff --git a/pkgs/by-name/ec/ecc/package.nix b/pkgs/by-name/ec/ecc/package.nix index dadd152c13c77d..0c71830775e31e 100644 --- a/pkgs/by-name/ec/ecc/package.nix +++ b/pkgs/by-name/ec/ecc/package.nix @@ -1,10 +1,11 @@ -{ lib -, makeWrapper -, fetchFromGitHub -, rustPackages -, pkg-config -, elfutils -, zlib +{ + lib, + makeWrapper, + fetchFromGitHub, + rustPackages, + pkg-config, + elfutils, + zlib, }: let inherit (rustPackages.rustc) llvmPackages; @@ -111,7 +112,15 @@ rustPlatform.buildRustPackage rec { postFixup = '' wrapProgram $out/bin/ecc-rs \ --prefix LIBCLANG_PATH : ${lib.getLib llvmPackages.libclang}/lib \ - --prefix PATH : ${lib.makeBinPath (with llvmPackages; [clang bintools-unwrapped])} + --prefix PATH : ${ + lib.makeBinPath ( + with llvmPackages; + [ + clang + bintools-unwrapped + ] + ) + } ''; meta = with lib; { diff --git a/pkgs/by-name/ec/ecdsatool/package.nix b/pkgs/by-name/ec/ecdsatool/package.nix index 439ffac563c7a5..f0ffe858c20292 100644 --- a/pkgs/by-name/ec/ecdsatool/package.nix +++ b/pkgs/by-name/ec/ecdsatool/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, pkgs }: +{ + lib, + stdenv, + pkgs, +}: stdenv.mkDerivation { version = "0.0.1"; @@ -21,14 +25,18 @@ stdenv.mkDerivation { ./openssl-header-c99-implicit-function-declaration.patch ]; - nativeBuildInputs = with pkgs; [openssl autoconf automake]; - buildInputs = with pkgs; [libuecc]; + nativeBuildInputs = with pkgs; [ + openssl + autoconf + automake + ]; + buildInputs = with pkgs; [ libuecc ]; meta = with lib; { description = "Create and manipulate ECC NISTP256 keypairs"; mainProgram = "ecdsatool"; homepage = "https://github.com/kaniini/ecdsatool/"; - license = with licenses; [free]; + license = with licenses; [ free ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ec/ecdsautils/package.nix b/pkgs/by-name/ec/ecdsautils/package.nix index efc6f6f8e53fd5..6b7dec6e11e627 100644 --- a/pkgs/by-name/ec/ecdsautils/package.nix +++ b/pkgs/by-name/ec/ecdsautils/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, pkgs }: +{ + lib, + stdenv, + pkgs, +}: let pname = "ecdsautils"; @@ -14,13 +18,20 @@ stdenv.mkDerivation { sha256 = "sha256-vGHLAX/XOtePvdT/rljCOdlILHVO20mCt6p+MUi13dg="; }; - nativeBuildInputs = with pkgs; [ cmake pkg-config doxygen ]; - buildInputs = with pkgs; [ libuecc ]; + nativeBuildInputs = with pkgs; [ + cmake + pkg-config + doxygen + ]; + buildInputs = with pkgs; [ libuecc ]; meta = with lib; { description = "Tiny collection of programs used for ECDSA (keygen, sign, verify)"; homepage = "https://github.com/freifunk-gluon/ecdsautils/"; - license = with licenses; [ mit bsd2 ]; + license = with licenses; [ + mit + bsd2 + ]; maintainers = [ ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/ec/echoip/package.nix b/pkgs/by-name/ec/echoip/package.nix index ae450ddae833e8..7c8d1f13114bb7 100644 --- a/pkgs/by-name/ec/echoip/package.nix +++ b/pkgs/by-name/ec/echoip/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, }: buildGoModule { @@ -31,7 +32,10 @@ buildGoModule { description = "IP address lookup service"; homepage = "https://github.com/mpolden/echoip"; license = licenses.bsd3; - maintainers = with maintainers; [ rvolosatovs SuperSandro2000 ]; + maintainers = with maintainers; [ + rvolosatovs + SuperSandro2000 + ]; mainProgram = "echoip"; }; } diff --git a/pkgs/by-name/ec/eclair/package.nix b/pkgs/by-name/ec/eclair/package.nix index c1abd9f265b795..df47d3a05d445a 100644 --- a/pkgs/by-name/ec/eclair/package.nix +++ b/pkgs/by-name/ec/eclair/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchzip -, jq -, openjdk11 +{ + lib, + stdenv, + fetchzip, + jq, + openjdk11, }: stdenv.mkDerivation rec { @@ -15,7 +16,10 @@ stdenv.mkDerivation rec { hash = "sha256-jkXdt1aQRVgItfFPuyh45uXjUFgJtKng/17Po5i7ang="; }; - propagatedBuildInputs = [ jq openjdk11 ]; + propagatedBuildInputs = [ + jq + openjdk11 + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/ec/eclint/package.nix b/pkgs/by-name/ec/eclint/package.nix index 218ca24d28207b..6480efde0136ba 100644 --- a/pkgs/by-name/ec/eclint/package.nix +++ b/pkgs/by-name/ec/eclint/package.nix @@ -1,10 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitLab +{ + lib, + buildGoModule, + fetchFromGitLab, }: -buildGoModule -rec { +buildGoModule rec { pname = "eclint"; version = "0.5.0"; diff --git a/pkgs/by-name/ec/eclipse-mat/package.nix b/pkgs/by-name/ec/eclipse-mat/package.nix index 6c698c3a517f7c..fff8bb0c2ab951 100644 --- a/pkgs/by-name/ec/eclipse-mat/package.nix +++ b/pkgs/by-name/ec/eclipse-mat/package.nix @@ -1,21 +1,22 @@ -{ fetchurl -, fontconfig -, freetype -, glib -, gsettings-desktop-schemas -, gtk3 -, jdk17 -, lib -, libX11 -, libXrender -, libXtst -, makeDesktopItem -, makeWrapper -, shared-mime-info -, stdenv -, unzip -, webkitgtk_4_0 -, zlib +{ + fetchurl, + fontconfig, + freetype, + glib, + gsettings-desktop-schemas, + gtk3, + jdk17, + lib, + libX11, + libXrender, + libXtst, + makeDesktopItem, + makeWrapper, + shared-mime-info, + stdenv, + unzip, + webkitgtk_4_0, + zlib, }: let @@ -60,13 +61,26 @@ stdenv.mkDerivation rec { libCairo=$out/eclipse/libcairo-swt.so patchelf --set-interpreter $interpreter $out/mat/MemoryAnalyzer [ -f $libCairo ] && patchelf --set-rpath ${ - lib.makeLibraryPath [ freetype fontconfig libX11 libXrender zlib ] + lib.makeLibraryPath [ + freetype + fontconfig + libX11 + libXrender + zlib + ] } $libCairo # Create wrapper script. Pass -configuration to store settings in ~/.eclipse-mat/ makeWrapper $out/mat/MemoryAnalyzer $out/bin/eclipse-mat \ --prefix PATH : ${jdk}/bin \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath ([ glib gtk3 libXtst webkitgtk_4_0 ])} \ + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath ([ + glib + gtk3 + libXtst + webkitgtk_4_0 + ]) + } \ --prefix XDG_DATA_DIRS : "$GSETTINGS_SCHEMAS_PATH" \ --add-flags "-configuration \$HOME/.eclipse-mat/''${version}/configuration" @@ -78,7 +92,10 @@ stdenv.mkDerivation rec { mv $out/share/pixmaps/eclipse64.png $out/share/pixmaps/eclipse.png ''; - nativeBuildInputs = [ unzip makeWrapper ]; + nativeBuildInputs = [ + unzip + makeWrapper + ]; buildInputs = [ fontconfig freetype diff --git a/pkgs/by-name/ec/ecm/package.nix b/pkgs/by-name/ec/ecm/package.nix index ed1c07d87ec1a6..e8c0ce289dc867 100644 --- a/pkgs/by-name/ec/ecm/package.nix +++ b/pkgs/by-name/ec/ecm/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, gmp, m4 }: +{ + lib, + stdenv, + fetchurl, + gmp, + m4, +}: let pname = "ecm"; @@ -17,7 +23,10 @@ stdenv.mkDerivation { # See https://trac.sagemath.org/ticket/19233 configureFlags = lib.optional stdenv.hostPlatform.isDarwin "--disable-asm-redc"; - buildInputs = [ m4 gmp ]; + buildInputs = [ + m4 + gmp + ]; doCheck = true; diff --git a/pkgs/by-name/ec/ecmtools/package.nix b/pkgs/by-name/ec/ecmtools/package.nix index 54d7e44f9fcf41..4db1efe0b2c8b8 100644 --- a/pkgs/by-name/ec/ecmtools/package.nix +++ b/pkgs/by-name/ec/ecmtools/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ec/ecopcr/package.nix b/pkgs/by-name/ec/ecopcr/package.nix index c5ab32a68838df..b49f26826d625d 100644 --- a/pkgs/by-name/ec/ecopcr/package.nix +++ b/pkgs/by-name/ec/ecopcr/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, gcc, zlib, python3 }: +{ + lib, + stdenv, + fetchurl, + gcc, + zlib, + python3, +}: stdenv.mkDerivation rec { pname = "ecopcr"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { hash = "sha256-ssvWpi7HuuRRAkpqqrX3ijLuBqM3QsrmrG+t7/m6fZA="; }; - buildInputs = [ gcc python3 zlib ]; + buildInputs = [ + gcc + python3 + zlib + ]; preConfigure = '' cd src diff --git a/pkgs/by-name/ec/ecos/package.nix b/pkgs/by-name/ec/ecos/package.nix index 73874641e477e3..ed8104e73a5961 100644 --- a/pkgs/by-name/ec/ecos/package.nix +++ b/pkgs/by-name/ec/ecos/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "ecos"; diff --git a/pkgs/by-name/ec/ecwolf/package.nix b/pkgs/by-name/ec/ecwolf/package.nix index bc9c216e7adcdf..e1b571f52e7437 100644 --- a/pkgs/by-name/ec/ecwolf/package.nix +++ b/pkgs/by-name/ec/ecwolf/package.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchFromBitbucket -, cmake -, pkg-config -, makeWrapper -, zlib -, bzip2 -, libjpeg -, SDL2 -, SDL2_net -, SDL2_mixer -, gtk3 -, writers -, python3Packages -, nix-update +{ + stdenv, + lib, + fetchFromBitbucket, + cmake, + pkg-config, + makeWrapper, + zlib, + bzip2, + libjpeg, + SDL2, + SDL2_net, + SDL2_mixer, + gtk3, + writers, + python3Packages, + nix-update, }: stdenv.mkDerivation rec { @@ -27,55 +28,81 @@ stdenv.mkDerivation rec { sha256 = "V2pSP8i20zB50WtUMujzij+ISSupdQQ/oCYYrOaTU1g="; }; - nativeBuildInputs = [ cmake pkg-config ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ makeWrapper ]; - buildInputs = [ zlib bzip2 libjpeg SDL2 SDL2_net SDL2_mixer gtk3 ]; + nativeBuildInputs = [ + cmake + pkg-config + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ makeWrapper ]; + buildInputs = [ + zlib + bzip2 + libjpeg + SDL2 + SDL2_net + SDL2_mixer + gtk3 + ]; NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin "-framework AppKit"; # ECWolf installs its binary to the games/ directory, but Nix only adds bin/ # directories to the PATH. - postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' - mv "$out/games" "$out/bin" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/{Applications,bin} - cp -R ecwolf.app $out/Applications - makeWrapper $out/{Applications/ecwolf.app/Contents/MacOS,bin}/ecwolf - ''; + postInstall = + lib.optionalString stdenv.hostPlatform.isLinux '' + mv "$out/games" "$out/bin" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/{Applications,bin} + cp -R ecwolf.app $out/Applications + makeWrapper $out/{Applications/ecwolf.app/Contents/MacOS,bin}/ecwolf + ''; - passthru.updateScript = let - updateScriptPkg = writers.writePython3 "ecwolf_update_script" { - libraries = with python3Packages; [ debian-inspector requests ]; - } '' - from os import execl - from sys import argv + passthru.updateScript = + let + updateScriptPkg = + writers.writePython3 "ecwolf_update_script" + { + libraries = with python3Packages; [ + debian-inspector + requests + ]; + } + '' + from os import execl + from sys import argv - from debian_inspector.debcon import get_paragraphs_data - from requests import get + from debian_inspector.debcon import get_paragraphs_data + from requests import get - # The debian.drdteam.org repo is a primary source of information. It’s - # run by Blzut3, the creator and primary developer of ECWolf. It’s also - # listed on ECWolf’s download page: - # . - url = 'https://debian.drdteam.org/dists/stable/multiverse/binary-amd64/Packages' # noqa: E501 - response = get(url) - packages = get_paragraphs_data(response.text) - for package in packages: - if package['package'] == 'ecwolf': - latest_version = package['version'] - break - nix_update_path = argv[1] + # The debian.drdteam.org repo is a primary source of information. It’s + # run by Blzut3, the creator and primary developer of ECWolf. It’s also + # listed on ECWolf’s download page: + # . + url = 'https://debian.drdteam.org/dists/stable/multiverse/binary-amd64/Packages' # noqa: E501 + response = get(url) + packages = get_paragraphs_data(response.text) + for package in packages: + if package['package'] == 'ecwolf': + latest_version = package['version'] + break + nix_update_path = argv[1] - execl(nix_update_path, nix_update_path, '--version', latest_version) - ''; - in [ updateScriptPkg (lib.getExe nix-update) ]; + execl(nix_update_path, nix_update_path, '--version', latest_version) + ''; + in + [ + updateScriptPkg + (lib.getExe nix-update) + ]; meta = with lib; { description = "Enhanched SDL-based port of Wolfenstein 3D for various platforms"; mainProgram = "ecwolf"; homepage = "https://maniacsvault.net/ecwolf/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ jayman2000 sander ]; + maintainers = with maintainers; [ + jayman2000 + sander + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/ed/edac-utils/package.nix b/pkgs/by-name/ed/edac-utils/package.nix index db106c14b434a3..ce70e919732f04 100644 --- a/pkgs/by-name/ed/edac-utils/package.nix +++ b/pkgs/by-name/ed/edac-utils/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, perl -, sysfsutils, dmidecode, kmod }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, + sysfsutils, + dmidecode, + kmod, +}: stdenv.mkDerivation { pname = "edac-utils"; @@ -30,7 +37,10 @@ stdenv.mkDerivation { # fixupPhase to update the hash bang line. strictDeps = true; nativeBuildInputs = [ perl ]; - buildInputs = [ perl sysfsutils ]; + buildInputs = [ + perl + sysfsutils + ]; installFlags = [ "sbindir=${placeholder "out"}/bin" diff --git a/pkgs/by-name/ed/edbrowse/package.nix b/pkgs/by-name/ed/edbrowse/package.nix index 4561e0b9027229..a2bd5f4847c1af 100644 --- a/pkgs/by-name/ed/edbrowse/package.nix +++ b/pkgs/by-name/ed/edbrowse/package.nix @@ -1,18 +1,19 @@ -{ lib -, curl -, duktape -, fetchFromGitHub -, html-tidy -, openssl -, pcre -, perl -, pkg-config -, quickjs -, readline -, stdenv -, unixODBC -, which -, withODBC ? true +{ + lib, + curl, + duktape, + fetchFromGitHub, + html-tidy, + openssl, + pcre, + perl, + pkg-config, + quickjs, + readline, + stdenv, + unixODBC, + which, + withODBC ? true, }: stdenv.mkDerivation (finalAttrs: { @@ -30,10 +31,10 @@ stdenv.mkDerivation (finalAttrs: { patches = [ # Fixes some small annoyances on src/makefile - ./0001-small-fixes.patch + ./0001-small-fixes.patch ]; - patchFlags = [ + patchFlags = [ "-p2" ]; @@ -48,18 +49,20 @@ stdenv.mkDerivation (finalAttrs: { which ]; - buildInputs = [ - curl - duktape - html-tidy - openssl - pcre - perl - quickjs - readline - ] ++ lib.optionals withODBC [ - unixODBC - ]; + buildInputs = + [ + curl + duktape + html-tidy + openssl + pcre + perl + quickjs + readline + ] + ++ lib.optionals withODBC [ + unixODBC + ]; makeFlags = [ "PREFIX=${placeholder "out"}" diff --git a/pkgs/by-name/ed/edgetpu-compiler/package.nix b/pkgs/by-name/ed/edgetpu-compiler/package.nix index dbb62fd24f0612..589ed88bda483c 100644 --- a/pkgs/by-name/ed/edgetpu-compiler/package.nix +++ b/pkgs/by-name/ed/edgetpu-compiler/package.nix @@ -1,9 +1,10 @@ -{ autoPatchelfHook -, dpkg -, fetchurl -, lib -, libcxx -, stdenv +{ + autoPatchelfHook, + dpkg, + fetchurl, + lib, + libcxx, + stdenv, }: stdenv.mkDerivation rec { pname = "edgetpu-compiler"; diff --git a/pkgs/by-name/ed/edid-decode/package.nix b/pkgs/by-name/ed/edid-decode/package.nix index fbee1797992d4e..f5ac1176221ea1 100644 --- a/pkgs/by-name/ed/edid-decode/package.nix +++ b/pkgs/by-name/ed/edid-decode/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchgit -, unstableGitUpdater +{ + lib, + stdenv, + fetchgit, + unstableGitUpdater, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ed/edid-generator/package.nix b/pkgs/by-name/ed/edid-generator/package.nix index e3855fc76f2f8f..fd8735ff4226a0 100644 --- a/pkgs/by-name/ed/edid-generator/package.nix +++ b/pkgs/by-name/ed/edid-generator/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, dos2unix -, edid-decode -, hexdump -, zsh +{ + lib, + stdenv, + fetchFromGitHub, + dos2unix, + edid-decode, + hexdump, + zsh, }: # Usage: @@ -31,7 +32,12 @@ stdenv.mkDerivation { sha256 = "sha256-UGxze273VB5cQDWrv9X/Lam6WbOu9U3bro8GcVbEvws="; }; - nativeBuildInputs = [ dos2unix edid-decode hexdump zsh ]; + nativeBuildInputs = [ + dos2unix + edid-decode + hexdump + zsh + ]; postPatch = '' patchShebangs modeline2edid @@ -72,7 +78,10 @@ stdenv.mkDerivation { description = "Hackerswork to generate an EDID blob from given Xorg Modelines"; homepage = "https://github.com/akatrevorjay/edid-generator"; license = lib.licenses.gpl3; - maintainers = with lib.maintainers; [ flokli nazarewk ]; + maintainers = with lib.maintainers; [ + flokli + nazarewk + ]; platforms = lib.platforms.all; broken = stdenv.hostPlatform.isDarwin; # never built on Hydra https://hydra.nixos.org/job/nixpkgs/trunk/edid-generator.x86_64-darwin }; diff --git a/pkgs/by-name/ed/edido/package.nix b/pkgs/by-name/ed/edido/package.nix index 2572a0dc2af85d..f060b9602574a5 100644 --- a/pkgs/by-name/ed/edido/package.nix +++ b/pkgs/by-name/ed/edido/package.nix @@ -1,16 +1,22 @@ -{ writeShellApplication -, bc -, diffutils -, findutils -, coreutils -, firmwarePaths ? [ +{ + writeShellApplication, + bc, + diffutils, + findutils, + coreutils, + firmwarePaths ? [ "/run/current-system/firmware" - ] + ], }: writeShellApplication { name = "edido"; meta.description = "A tool to apply display configuration from `boot.kernelParams`."; - runtimeInputs = [ diffutils findutils coreutils bc ]; + runtimeInputs = [ + diffutils + findutils + coreutils + bc + ]; text = '' FIRMWARE_PATH="''${FIRMWARE_PATH:-"${builtins.concatStringsSep ":" firmwarePaths}"}" ${builtins.readFile ./edido.sh} diff --git a/pkgs/by-name/ed/edir/package.nix b/pkgs/by-name/ed/edir/package.nix index 85fc426fc57cd5..2402de5127cc7d 100644 --- a/pkgs/by-name/ed/edir/package.nix +++ b/pkgs/by-name/ed/edir/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "edir"; diff --git a/pkgs/by-name/ed/edit/package.nix b/pkgs/by-name/ed/edit/package.nix index c6e48e63c4a3fc..e2c545172aab4d 100644 --- a/pkgs/by-name/ed/edit/package.nix +++ b/pkgs/by-name/ed/edit/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchgit -, cwebbin -, libX11 -, libXft -, ncurses -, pkg-config -, unzip +{ + lib, + stdenv, + fetchgit, + cwebbin, + libX11, + libXft, + ncurses, + pkg-config, + unzip, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ed/editline/package.nix b/pkgs/by-name/ed/editline/package.nix index 95776d885f06b3..c8f7558f62f779 100644 --- a/pkgs/by-name/ed/editline/package.nix +++ b/pkgs/by-name/ed/editline/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, nix-update-script, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + nix-update-script, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "editline"; @@ -30,7 +37,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; - outputs = [ "out" "dev" "man" "doc" ]; + outputs = [ + "out" + "dev" + "man" + "doc" + ]; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/by-name/ed/editorconfig-checker/package.nix b/pkgs/by-name/ed/editorconfig-checker/package.nix index ad61dcded73dff..8c500487e41b2b 100644 --- a/pkgs/by-name/ed/editorconfig-checker/package.nix +++ b/pkgs/by-name/ed/editorconfig-checker/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, testers, editorconfig-checker }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + editorconfig-checker, +}: buildGoModule rec { pname = "editorconfig-checker"; @@ -33,6 +40,9 @@ buildGoModule rec { mainProgram = "editorconfig-checker"; homepage = "https://editorconfig-checker.github.io/"; license = licenses.mit; - maintainers = with maintainers; [ uri-canva zowoq ]; + maintainers = with maintainers; [ + uri-canva + zowoq + ]; }; } diff --git a/pkgs/by-name/ed/editorconfig-core-c/package.nix b/pkgs/by-name/ed/editorconfig-core-c/package.nix index 7c3eb4e1942352..bdf1b640508fa6 100644 --- a/pkgs/by-name/ed/editorconfig-core-c/package.nix +++ b/pkgs/by-name/ed/editorconfig-core-c/package.nix @@ -1,16 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pcre2 -, doxygen +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pcre2, + doxygen, }: stdenv.mkDerivation (finalAttrs: { pname = "editorconfig-core-c"; version = "0.12.9"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "editorconfig"; @@ -45,7 +49,10 @@ stdenv.mkDerivation (finalAttrs: { editors, see the EditorConfig website. ''; downloadPage = "https://github.com/editorconfig/editorconfig-core-c"; - license = with licenses; [ bsd2 bsd3 ]; + license = with licenses; [ + bsd2 + bsd3 + ]; maintainers = with maintainers; [ dochang ]; platforms = platforms.unix; mainProgram = "editorconfig"; diff --git a/pkgs/by-name/ed/editres/package.nix b/pkgs/by-name/ed/editres/package.nix index d1da7d2c5a5f8e..63ec3f9d74d720 100644 --- a/pkgs/by-name/ed/editres/package.nix +++ b/pkgs/by-name/ed/editres/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, libXt, libXaw, libXres, utilmacros }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libXt, + libXaw, + libXres, + utilmacros, +}: stdenv.mkDerivation rec { pname = "editres"; @@ -10,7 +19,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libXt libXaw libXres utilmacros ]; + buildInputs = [ + libXt + libXaw + libXres + utilmacros + ]; configureFlags = [ "--with-appdefaultdir=$(out)/share/X11/app-defaults/editres" ]; diff --git a/pkgs/by-name/ed/edk2-uefi-shell/package.nix b/pkgs/by-name/ed/edk2-uefi-shell/package.nix index 723833ab45cf4c..dd79e1ac4d1692 100644 --- a/pkgs/by-name/ed/edk2-uefi-shell/package.nix +++ b/pkgs/by-name/ed/edk2-uefi-shell/package.nix @@ -1,20 +1,34 @@ -{ lib -, stdenv -, edk2 -, llvmPackages -, util-linux -, nasm -, python3 +{ + lib, + stdenv, + edk2, + llvmPackages, + util-linux, + nasm, + python3, }: edk2.mkDerivation "ShellPkg/ShellPkg.dsc" (finalAttrs: { pname = "edk2-uefi-shell"; inherit (edk2) version; - nativeBuildInputs = [ util-linux nasm python3 ] - ++ lib.optionals stdenv.cc.isClang [ llvmPackages.bintools llvmPackages.llvm ]; + nativeBuildInputs = + [ + util-linux + nasm + python3 + ] + ++ lib.optionals stdenv.cc.isClang [ + llvmPackages.bintools + llvmPackages.llvm + ]; strictDeps = true; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ "-fno-pic" "-Qunused-arguments" ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-fno-pic" + "-Qunused-arguments" + ] + ); # Set explicitly to use Python 3 from nixpkgs. Otherwise, the build system will detect and try to # use `/usr/bin/python3` on Darwin when sandboxing is disabled. @@ -37,7 +51,10 @@ edk2.mkDerivation "ShellPkg/ShellPkg.dsc" (finalAttrs: { inherit (edk2.meta) license platforms; description = "UEFI Shell from Tianocore EFI development kit"; homepage = "https://github.com/tianocore/tianocore.github.io/wiki/ShellPkg"; - maintainers = with lib.maintainers; [ LunNova mjoerg ]; + maintainers = with lib.maintainers; [ + LunNova + mjoerg + ]; broken = stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64; }; }) diff --git a/pkgs/by-name/ed/edk2/package.nix b/pkgs/by-name/ed/edk2/package.nix index 30abd6c1d226dd..b552a7675fe129 100644 --- a/pkgs/by-name/ed/edk2/package.nix +++ b/pkgs/by-name/ed/edk2/package.nix @@ -1,198 +1,215 @@ -{ stdenv -, fetchFromGitHub -, fetchpatch -, applyPatches -, libuuid -, bc -, lib -, buildPackages -, nixosTests -, writeScript +{ + stdenv, + fetchFromGitHub, + fetchpatch, + applyPatches, + libuuid, + bc, + lib, + buildPackages, + nixosTests, + writeScript, }: let - pythonEnv = buildPackages.python3.withPackages (ps: [ps.tkinter]); - -targetArch = if stdenv.hostPlatform.isi686 then - "IA32" -else if stdenv.hostPlatform.isx86_64 then - "X64" -else if stdenv.hostPlatform.isAarch32 then - "ARM" -else if stdenv.hostPlatform.isAarch64 then - "AARCH64" -else if stdenv.hostPlatform.isRiscV64 then - "RISCV64" -else if stdenv.hostPlatform.isLoongArch64 then - "LOONGARCH64" -else - throw "Unsupported architecture"; - -buildType = if stdenv.hostPlatform.isDarwin then - "CLANGPDB" - else - "GCC5"; - -edk2 = stdenv.mkDerivation { - pname = "edk2"; - version = "202411"; - - srcWithVendoring = fetchFromGitHub { - owner = "tianocore"; - repo = "edk2"; - rev = "edk2-stable${edk2.version}"; - fetchSubmodules = true; - hash = "sha256-KYaTGJ3DHtWbPEbP+n8MTk/WwzLv5Vugty/tvzuEUf0="; - }; + pythonEnv = buildPackages.python3.withPackages (ps: [ ps.tkinter ]); + + targetArch = + if stdenv.hostPlatform.isi686 then + "IA32" + else if stdenv.hostPlatform.isx86_64 then + "X64" + else if stdenv.hostPlatform.isAarch32 then + "ARM" + else if stdenv.hostPlatform.isAarch64 then + "AARCH64" + else if stdenv.hostPlatform.isRiscV64 then + "RISCV64" + else if stdenv.hostPlatform.isLoongArch64 then + "LOONGARCH64" + else + throw "Unsupported architecture"; + + buildType = if stdenv.hostPlatform.isDarwin then "CLANGPDB" else "GCC5"; + + edk2 = stdenv.mkDerivation { + pname = "edk2"; + version = "202411"; + + srcWithVendoring = fetchFromGitHub { + owner = "tianocore"; + repo = "edk2"; + rev = "edk2-stable${edk2.version}"; + fetchSubmodules = true; + hash = "sha256-KYaTGJ3DHtWbPEbP+n8MTk/WwzLv5Vugty/tvzuEUf0="; + }; + + src = applyPatches { + name = "edk2-${edk2.version}-unvendored-src"; + src = edk2.srcWithVendoring; + + patches = [ + # pass targetPrefix as an env var + (fetchpatch { + url = "https://src.fedoraproject.org/rpms/edk2/raw/08f2354cd280b4ce5a7888aa85cf520e042955c3/f/0021-Tweak-the-tools_def-to-support-cross-compiling.patch"; + hash = "sha256-E1/fiFNVx0aB1kOej2DJ2DlBIs9tAAcxoedym2Zhjxw="; + }) + # https://github.com/tianocore/edk2/pull/5658 + (fetchpatch { + name = "fix-cross-compilation-antlr-dlg.patch"; + url = "https://github.com/tianocore/edk2/commit/a34ff4a8f69a7b8a52b9b299153a8fac702c7df1.patch"; + hash = "sha256-u+niqwjuLV5tNPykW4xhb7PW2XvUmXhx5uvftG1UIbU="; + }) + ]; + + # EDK2 is currently working on OpenSSL 3.3.x support. Use buildpackages.openssl again, + # when "https://github.com/tianocore/edk2/pull/6167" is merged. + postPatch = '' + # We don't want EDK2 to keep track of OpenSSL, they're frankly bad at it. + rm -r CryptoPkg/Library/OpensslLib/openssl + mkdir -p CryptoPkg/Library/OpensslLib/openssl + ( + cd CryptoPkg/Library/OpensslLib/openssl + tar --strip-components=1 -xf ${buildPackages.openssl_3.src} + + # Apply OpenSSL patches. + ${lib.pipe buildPackages.openssl_3.patches [ + (builtins.filter ( + patch: + !builtins.elem (baseNameOf patch) [ + # Exclude patches not required in this context. + "nix-ssl-cert-file.patch" + "openssl-disable-kernel-detection.patch" + "use-etc-ssl-certs-darwin.patch" + "use-etc-ssl-certs.patch" + ] + )) + (map (patch: "patch -p1 < ${patch}\n")) + lib.concatStrings + ]} + ) + + # enable compilation using Clang + # https://bugzilla.tianocore.org/show_bug.cgi?id=4620 + substituteInPlace BaseTools/Conf/tools_def.template --replace-fail \ + 'DEFINE CLANGPDB_WARNING_OVERRIDES = ' \ + 'DEFINE CLANGPDB_WARNING_OVERRIDES = -Wno-unneeded-internal-declaration ' + ''; + }; - src = applyPatches { - name = "edk2-${edk2.version}-unvendored-src"; - src = edk2.srcWithVendoring; - - patches = [ - # pass targetPrefix as an env var - (fetchpatch { - url = "https://src.fedoraproject.org/rpms/edk2/raw/08f2354cd280b4ce5a7888aa85cf520e042955c3/f/0021-Tweak-the-tools_def-to-support-cross-compiling.patch"; - hash = "sha256-E1/fiFNVx0aB1kOej2DJ2DlBIs9tAAcxoedym2Zhjxw="; - }) - # https://github.com/tianocore/edk2/pull/5658 - (fetchpatch { - name = "fix-cross-compilation-antlr-dlg.patch"; - url = "https://github.com/tianocore/edk2/commit/a34ff4a8f69a7b8a52b9b299153a8fac702c7df1.patch"; - hash = "sha256-u+niqwjuLV5tNPykW4xhb7PW2XvUmXhx5uvftG1UIbU="; - }) + nativeBuildInputs = [ pythonEnv ]; + depsBuildBuild = [ + buildPackages.stdenv.cc + buildPackages.bash ]; + depsHostHost = [ libuuid ]; + strictDeps = true; - # EDK2 is currently working on OpenSSL 3.3.x support. Use buildpackages.openssl again, - # when "https://github.com/tianocore/edk2/pull/6167" is merged. - postPatch = '' - # We don't want EDK2 to keep track of OpenSSL, they're frankly bad at it. - rm -r CryptoPkg/Library/OpensslLib/openssl - mkdir -p CryptoPkg/Library/OpensslLib/openssl - ( - cd CryptoPkg/Library/OpensslLib/openssl - tar --strip-components=1 -xf ${buildPackages.openssl_3.src} - - # Apply OpenSSL patches. - ${lib.pipe buildPackages.openssl_3.patches [ - (builtins.filter ( - patch: - !builtins.elem (baseNameOf patch) [ - # Exclude patches not required in this context. - "nix-ssl-cert-file.patch" - "openssl-disable-kernel-detection.patch" - "use-etc-ssl-certs-darwin.patch" - "use-etc-ssl-certs.patch" - ] - )) - (map (patch: "patch -p1 < ${patch}\n")) - lib.concatStrings - ]} - ) - - # enable compilation using Clang - # https://bugzilla.tianocore.org/show_bug.cgi?id=4620 - substituteInPlace BaseTools/Conf/tools_def.template --replace-fail \ - 'DEFINE CLANGPDB_WARNING_OVERRIDES = ' \ - 'DEFINE CLANGPDB_WARNING_OVERRIDES = -Wno-unneeded-internal-declaration ' - ''; - }; - - nativeBuildInputs = [ pythonEnv ]; - depsBuildBuild = [ buildPackages.stdenv.cc buildPackages.bash ]; - depsHostHost = [ libuuid ]; - strictDeps = true; - - # trick taken from https://src.fedoraproject.org/rpms/edk2/blob/08f2354cd280b4ce5a7888aa85cf520e042955c3/f/edk2.spec#_319 - ${"GCC5_${targetArch}_PREFIX"} = stdenv.cc.targetPrefix; - - makeFlags = [ "-C BaseTools" ]; - - env.NIX_CFLAGS_COMPILE = "-Wno-return-type" - + lib.optionalString (stdenv.cc.isGNU) " -Wno-error=stringop-truncation" - + lib.optionalString (stdenv.hostPlatform.isDarwin) " -Wno-error=macro-redefined"; - - hardeningDisable = [ "format" "fortify" ]; - - installPhase = '' - mkdir -vp $out - mv -v BaseTools $out - mv -v edksetup.sh $out - # patchShebangs fails to see these when cross compiling - for i in $out/BaseTools/BinWrappers/PosixLike/*; do - chmod +x "$i" - patchShebangs --build "$i" - done - ''; - - enableParallelBuilding = true; - - meta = { - description = "Intel EFI development kit"; - homepage = "https://github.com/tianocore/tianocore.github.io/wiki/EDK-II/"; - changelog = "https://github.com/tianocore/edk2/releases/tag/edk2-stable${edk2.version}"; - license = lib.licenses.bsd2; - platforms = with lib.platforms; aarch64 ++ arm ++ i686 ++ x86_64 ++ loongarch64 ++ riscv64; - maintainers = [ lib.maintainers.mjoerg ]; - }; - - passthru = { - # exercise a channel blocker - tests.uefiUsb = nixosTests.boot.uefiCdrom; - - updateScript = writeScript "update-edk2" '' - #!/usr/bin/env nix-shell - #!nix-shell -i bash -p common-updater-scripts coreutils gnused - set -eu -o pipefail - version="$(list-git-tags --url="${edk2.srcWithVendoring.url}" | - sed -E --quiet 's/^edk2-stable([0-9]{6})$/\1/p' | - sort --reverse --numeric-sort | - head -n 1)" - if [[ "x$UPDATE_NIX_OLD_VERSION" != "x$version" ]]; then - update-source-version --source-key=srcWithVendoring \ - "$UPDATE_NIX_ATTR_PATH" "$version" - fi - ''; - - mkDerivation = projectDscPath: attrsOrFun: stdenv.mkDerivation (finalAttrs: - let - attrs = lib.toFunction attrsOrFun finalAttrs; - in - { - inherit (edk2) src; + # trick taken from https://src.fedoraproject.org/rpms/edk2/blob/08f2354cd280b4ce5a7888aa85cf520e042955c3/f/edk2.spec#_319 + ${"GCC5_${targetArch}_PREFIX"} = stdenv.cc.targetPrefix; - depsBuildBuild = [ buildPackages.stdenv.cc ] ++ attrs.depsBuildBuild or []; - nativeBuildInputs = [ bc pythonEnv ] ++ attrs.nativeBuildInputs or []; - strictDeps = true; + makeFlags = [ "-C BaseTools" ]; - ${"GCC5_${targetArch}_PREFIX"}=stdenv.cc.targetPrefix; + env.NIX_CFLAGS_COMPILE = + "-Wno-return-type" + + lib.optionalString (stdenv.cc.isGNU) " -Wno-error=stringop-truncation" + + lib.optionalString (stdenv.hostPlatform.isDarwin) " -Wno-error=macro-redefined"; - prePatch = '' - rm -rf BaseTools - ln -sv ${buildPackages.edk2}/BaseTools BaseTools - ''; + hardeningDisable = [ + "format" + "fortify" + ]; - configurePhase = '' - runHook preConfigure - export WORKSPACE="$PWD" - . ${buildPackages.edk2}/edksetup.sh BaseTools - runHook postConfigure - ''; + installPhase = '' + mkdir -vp $out + mv -v BaseTools $out + mv -v edksetup.sh $out + # patchShebangs fails to see these when cross compiling + for i in $out/BaseTools/BinWrappers/PosixLike/*; do + chmod +x "$i" + patchShebangs --build "$i" + done + ''; - buildPhase = '' - runHook preBuild - build -a ${targetArch} -b ${attrs.buildConfig or "RELEASE"} -t ${buildType} -p ${projectDscPath} -n $NIX_BUILD_CORES $buildFlags - runHook postBuild + enableParallelBuilding = true; + + meta = { + description = "Intel EFI development kit"; + homepage = "https://github.com/tianocore/tianocore.github.io/wiki/EDK-II/"; + changelog = "https://github.com/tianocore/edk2/releases/tag/edk2-stable${edk2.version}"; + license = lib.licenses.bsd2; + platforms = with lib.platforms; aarch64 ++ arm ++ i686 ++ x86_64 ++ loongarch64 ++ riscv64; + maintainers = [ lib.maintainers.mjoerg ]; + }; + + passthru = { + # exercise a channel blocker + tests.uefiUsb = nixosTests.boot.uefiCdrom; + + updateScript = writeScript "update-edk2" '' + #!/usr/bin/env nix-shell + #!nix-shell -i bash -p common-updater-scripts coreutils gnused + set -eu -o pipefail + version="$(list-git-tags --url="${edk2.srcWithVendoring.url}" | + sed -E --quiet 's/^edk2-stable([0-9]{6})$/\1/p' | + sort --reverse --numeric-sort | + head -n 1)" + if [[ "x$UPDATE_NIX_OLD_VERSION" != "x$version" ]]; then + update-source-version --source-key=srcWithVendoring \ + "$UPDATE_NIX_ATTR_PATH" "$version" + fi ''; - installPhase = '' - runHook preInstall - mv -v Build/*/* $out - runHook postInstall - ''; - } // removeAttrs attrs [ "nativeBuildInputs" "depsBuildBuild" ]); + mkDerivation = + projectDscPath: attrsOrFun: + stdenv.mkDerivation ( + finalAttrs: + let + attrs = lib.toFunction attrsOrFun finalAttrs; + in + { + inherit (edk2) src; + + depsBuildBuild = [ buildPackages.stdenv.cc ] ++ attrs.depsBuildBuild or [ ]; + nativeBuildInputs = [ + bc + pythonEnv + ] ++ attrs.nativeBuildInputs or [ ]; + strictDeps = true; + + ${"GCC5_${targetArch}_PREFIX"} = stdenv.cc.targetPrefix; + + prePatch = '' + rm -rf BaseTools + ln -sv ${buildPackages.edk2}/BaseTools BaseTools + ''; + + configurePhase = '' + runHook preConfigure + export WORKSPACE="$PWD" + . ${buildPackages.edk2}/edksetup.sh BaseTools + runHook postConfigure + ''; + + buildPhase = '' + runHook preBuild + build -a ${targetArch} -b ${attrs.buildConfig or "RELEASE"} -t ${buildType} -p ${projectDscPath} -n $NIX_BUILD_CORES $buildFlags + runHook postBuild + ''; + + installPhase = '' + runHook preInstall + mv -v Build/*/* $out + runHook postInstall + ''; + } + // removeAttrs attrs [ + "nativeBuildInputs" + "depsBuildBuild" + ] + ); + }; }; -}; in diff --git a/pkgs/by-name/ed/edlib/package.nix b/pkgs/by-name/ed/edlib/package.nix index b8ea4a55291a89..dae63438985d76 100644 --- a/pkgs/by-name/ed/edlib/package.nix +++ b/pkgs/by-name/ed/edlib/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "edlib"; diff --git a/pkgs/by-name/ed/edlin/package.nix b/pkgs/by-name/ed/edlin/package.nix index f8baa9aa67bc19..4575b117ccf867 100644 --- a/pkgs/by-name/ed/edlin/package.nix +++ b/pkgs/by-name/ed/edlin/package.nix @@ -1,18 +1,21 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { pname = "edlin"; version = "2.21"; - src = let - inherit (finalAttrs) version; - in fetchurl { - url = "mirror://sourceforge/freedos-edlin/freedos-edlin/${version}/edlin-${version}.tar.bz2"; - hash = "sha256-lQ/tw8dvEKV81k5GV05o49glOmfYcEeJBmgPUmL3S2I="; - }; + src = + let + inherit (finalAttrs) version; + in + fetchurl { + url = "mirror://sourceforge/freedos-edlin/freedos-edlin/${version}/edlin-${version}.tar.bz2"; + hash = "sha256-lQ/tw8dvEKV81k5GV05o49glOmfYcEeJBmgPUmL3S2I="; + }; postInstall = '' mkdir -p $out/share/doc/edlin-${finalAttrs.version}/ diff --git a/pkgs/by-name/ed/edukai/package.nix b/pkgs/by-name/ed/edukai/package.nix index d5b9e25c2eb54b..6abb9723f8efc1 100644 --- a/pkgs/by-name/ed/edukai/package.nix +++ b/pkgs/by-name/ed/edukai/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchzip }: +{ + stdenvNoCC, + lib, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "edukai"; @@ -6,8 +10,7 @@ stdenvNoCC.mkDerivation rec { src = fetchzip { name = "${pname}-${version}"; - url = - "http://language.moe.gov.tw/001/Upload/Files/site_content/M0001/edukai-4.0.zip"; + url = "http://language.moe.gov.tw/001/Upload/Files/site_content/M0001/edukai-4.0.zip"; sha256 = "10m9srvbazvg9gc43943dc89rjzcfc8mm4lx9gb5hnplrn22zrcn"; }; @@ -17,16 +20,14 @@ stdenvNoCC.mkDerivation rec { ''; meta = { - description = - "The MOE Standard Kai Font, a Chinese font by the Ministry of Education, ROC (Taiwan)"; + description = "The MOE Standard Kai Font, a Chinese font by the Ministry of Education, ROC (Taiwan)"; longDescription = '' The MOE Standard Kai Font is a kai (regular srcipt) font provided by the Midistry of Education, Republic of China (Taiwan). It currently includes 13,076 Chinese characters. ''; - homepage = - "http://language.moe.gov.tw/result.aspx?classify_sn=23&subclassify_sn=436&content_sn=47"; + homepage = "http://language.moe.gov.tw/result.aspx?classify_sn=23&subclassify_sn=436&content_sn=47"; license = lib.licenses.cc-by-nd-30; maintainers = with lib.maintainers; [ ShamrockLee ]; }; diff --git a/pkgs/by-name/ed/eduli/package.nix b/pkgs/by-name/ed/eduli/package.nix index beb89d49fc364f..e6fea3a303b43c 100644 --- a/pkgs/by-name/ed/eduli/package.nix +++ b/pkgs/by-name/ed/eduli/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchzip }: +{ + stdenvNoCC, + lib, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "eduli"; @@ -6,8 +10,7 @@ stdenvNoCC.mkDerivation rec { src = fetchzip { name = "${pname}-${version}"; - url = - "http://language.moe.gov.tw/001/Upload/Files/site_content/M0001/MoeLI-3.0.zip"; + url = "http://language.moe.gov.tw/001/Upload/Files/site_content/M0001/MoeLI-3.0.zip"; sha256 = "0b4kjdk0h0hx446swi0wzawia0mf16qh9b6v4h4nqg8qx0p2sd3c"; }; @@ -19,8 +22,7 @@ stdenvNoCC.mkDerivation rec { ''; meta = { - description = - "The MOE Li Font, a clerical Chinese font by the Ministry of Education, ROC (Taiwan)"; + description = "The MOE Li Font, a clerical Chinese font by the Ministry of Education, ROC (Taiwan)"; longDescription = '' The MOE Li Font is a li (clerical srcipt) font provided by @@ -28,8 +30,7 @@ stdenvNoCC.mkDerivation rec { It currently includes 4,808 Chinese characters. The clerical script (lishu) is an archaic style of Chinese calligraphy. ''; - homepage = - "http://language.moe.gov.tw/result.aspx?classify_sn=23&subclassify_sn=436&content_sn=49"; + homepage = "http://language.moe.gov.tw/result.aspx?classify_sn=23&subclassify_sn=436&content_sn=49"; license = lib.licenses.cc-by-nd-30; maintainers = with lib.maintainers; [ ShamrockLee ]; }; diff --git a/pkgs/by-name/ed/edusong/package.nix b/pkgs/by-name/ed/edusong/package.nix index fa4d13693b12fd..4c9901f0c76670 100644 --- a/pkgs/by-name/ed/edusong/package.nix +++ b/pkgs/by-name/ed/edusong/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchzip }: +{ + stdenvNoCC, + lib, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "edusong"; @@ -6,8 +10,7 @@ stdenvNoCC.mkDerivation rec { src = fetchzip { name = "${pname}-${version}"; - url = - "https://language.moe.gov.tw/001/Upload/Files/site_content/M0001/eduSong_Unicode.zip"; + url = "https://language.moe.gov.tw/001/Upload/Files/site_content/M0001/eduSong_Unicode.zip"; hash = "sha256-pIG1EbFGf2O2AzM4+HCCvGPodBBwUt7ozpb+BpPk5Kw="; }; @@ -17,15 +20,13 @@ stdenvNoCC.mkDerivation rec { ''; meta = { - description = - "The MOE Standard Song Font, a Chinese font by the Ministry of Education, ROC (Taiwan)"; + description = "The MOE Standard Song Font, a Chinese font by the Ministry of Education, ROC (Taiwan)"; longDescription = '' The MOE Standard Song Font is a Chinese Song font provided by the Midistry of Education, Republic of China (Taiwan). Song or Ming is a category of CKJ typefaces in print. ''; - homepage = - "https://language.moe.gov.tw/result.aspx?classify_sn=23&subclassify_sn=436&content_sn=48"; + homepage = "https://language.moe.gov.tw/result.aspx?classify_sn=23&subclassify_sn=436&content_sn=48"; license = lib.licenses.cc-by-nd-30; maintainers = with lib.maintainers; [ ShamrockLee ]; }; diff --git a/pkgs/by-name/ed/eduvpn-client/package.nix b/pkgs/by-name/ed/eduvpn-client/package.nix index d5313bdeff0057..c0325f50d9c48b 100644 --- a/pkgs/by-name/ed/eduvpn-client/package.nix +++ b/pkgs/by-name/ed/eduvpn-client/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchurl -, gdk-pixbuf -, gobject-introspection -, gtk3 -, libnotify -, libsecret -, networkmanager -, python3Packages -, wrapGAppsHook3 +{ + lib, + fetchurl, + gdk-pixbuf, + gobject-introspection, + gtk3, + libnotify, + libsecret, + networkmanager, + python3Packages, + wrapGAppsHook3, }: python3Packages.buildPythonApplication rec { @@ -49,7 +50,10 @@ python3Packages.buildPythonApplication rec { homepage = "https://github.com/eduvpn/python-eduvpn-client"; license = licenses.gpl3Plus; mainProgram = "eduvpn-gui"; - maintainers = with maintainers; [ benneti jwijenbergh ]; + maintainers = with maintainers; [ + benneti + jwijenbergh + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/ed/edwin/package.nix b/pkgs/by-name/ed/edwin/package.nix index 58a2ed3e3ec68b..fc2a84215fa918 100644 --- a/pkgs/by-name/ed/edwin/package.nix +++ b/pkgs/by-name/ed/edwin/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "edwin"; diff --git a/pkgs/by-name/ed/edwood/package.nix b/pkgs/by-name/ed/edwood/package.nix index fc32c5ed393782..04fc2084ffb17f 100644 --- a/pkgs/by-name/ed/edwood/package.nix +++ b/pkgs/by-name/ed/edwood/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, plan9port +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + plan9port, }: buildGoModule rec { @@ -41,7 +42,10 @@ buildGoModule rec { meta = with lib; { description = "Go version of Plan9 Acme Editor"; homepage = "https://github.com/rjkroege/edwood"; - license = with licenses; [ mit bsd3 ]; + license = with licenses; [ + mit + bsd3 + ]; maintainers = with maintainers; [ kranzes ]; mainProgram = "edwood"; }; diff --git a/pkgs/by-name/ef/eff/package.nix b/pkgs/by-name/ef/eff/package.nix index 998efe0c790e10..95e041383fdfe3 100644 --- a/pkgs/by-name/ef/eff/package.nix +++ b/pkgs/by-name/ef/eff/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, ocamlPackages }: +{ + lib, + fetchFromGitHub, + ocamlPackages, +}: let inherit (ocamlPackages) buildDunePackage js_of_ocaml menhir; diff --git a/pkgs/by-name/ef/efficient-compression-tool/package.nix b/pkgs/by-name/ef/efficient-compression-tool/package.nix index 52a0820abaeae3..7b01069437d9e2 100644 --- a/pkgs/by-name/ef/efficient-compression-tool/package.nix +++ b/pkgs/by-name/ef/efficient-compression-tool/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, boost -, cmake -, nasm -, libpng +{ + lib, + stdenv, + fetchFromGitHub, + boost, + cmake, + nasm, + libpng, }: stdenv.mkDerivation rec { @@ -19,11 +20,17 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake nasm ]; + nativeBuildInputs = [ + cmake + nasm + ]; patches = [ ./use-nixpkgs-libpng.patch ]; - buildInputs = [ boost libpng ]; + buildInputs = [ + boost + libpng + ]; cmakeDir = "../src"; diff --git a/pkgs/by-name/ef/effitask/package.nix b/pkgs/by-name/ef/effitask/package.nix index 345f87d84a1cfa..4e28dcc89da925 100644 --- a/pkgs/by-name/ef/effitask/package.nix +++ b/pkgs/by-name/ef/effitask/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, gtk3 -, stdenv +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + gtk3, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -22,7 +23,10 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl gtk3 ]; + buildInputs = [ + openssl + gtk3 + ]; # default installPhase don't install assets installPhase = '' diff --git a/pkgs/by-name/ef/efitools/package.nix b/pkgs/by-name/ef/efitools/package.nix index fac59ef8d77379..8f793128f4beb9 100644 --- a/pkgs/by-name/ef/efitools/package.nix +++ b/pkgs/by-name/ef/efitools/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, gnu-efi, openssl, sbsigntool, perl, perlPackages, -help2man, fetchzip }: +{ + lib, + stdenv, + gnu-efi, + openssl, + sbsigntool, + perl, + perlPackages, + help2man, + fetchzip, +}: stdenv.mkDerivation rec { pname = "efitools"; version = "1.9.2"; diff --git a/pkgs/by-name/ef/efivar/package.nix b/pkgs/by-name/ef/efivar/package.nix index 1fdbba4284b4f6..982e7cff6c16e5 100644 --- a/pkgs/by-name/ef/efivar/package.nix +++ b/pkgs/by-name/ef/efivar/package.nix @@ -1,10 +1,24 @@ -{ lib, stdenv, buildPackages, fetchFromGitHub, fetchpatch, pkg-config, popt, mandoc }: +{ + lib, + stdenv, + buildPackages, + fetchFromGitHub, + fetchpatch, + pkg-config, + popt, + mandoc, +}: stdenv.mkDerivation rec { pname = "efivar"; version = "39"; - outputs = [ "bin" "out" "dev" "man" ]; + outputs = [ + "bin" + "out" + "dev" + "man" + ]; src = fetchFromGitHub { owner = "rhboot"; @@ -13,7 +27,10 @@ stdenv.mkDerivation rec { hash = "sha256-s/1k5a3n33iLmSpKQT5u08xoj8ypjf2Vzln88OBrqf0="; }; - nativeBuildInputs = [ pkg-config mandoc ]; + nativeBuildInputs = [ + pkg-config + mandoc + ]; buildInputs = [ popt ]; depsBuildBuild = [ buildPackages.stdenv.cc ]; diff --git a/pkgs/by-name/ef/efm-langserver/package.nix b/pkgs/by-name/ef/efm-langserver/package.nix index a40097db269b2e..d87544198d2768 100644 --- a/pkgs/by-name/ef/efm-langserver/package.nix +++ b/pkgs/by-name/ef/efm-langserver/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "efm-langserver"; diff --git a/pkgs/by-name/ef/efont-unicode/package.nix b/pkgs/by-name/ef/efont-unicode/package.nix index cc41646a1263f7..5f62f9eb627f70 100644 --- a/pkgs/by-name/ef/efont-unicode/package.nix +++ b/pkgs/by-name/ef/efont-unicode/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libfaketime, xorg }: +{ + lib, + stdenv, + fetchurl, + libfaketime, + xorg, +}: stdenv.mkDerivation rec { pname = "efont-unicode"; @@ -9,8 +15,12 @@ stdenv.mkDerivation rec { sha256 = "sha256-fT7SsYlV3dCQrf0IZfiNI1grj3ngDgr8IkWdg+f9m3M="; }; - nativeBuildInputs = with xorg; - [ libfaketime bdftopcf fonttosfnt mkfontscale ]; + nativeBuildInputs = with xorg; [ + libfaketime + bdftopcf + fonttosfnt + mkfontscale + ]; buildPhase = '' runHook preBuild @@ -42,7 +52,10 @@ stdenv.mkDerivation rec { runHook postInstall ''; - outputs = [ "out" "bdf" ]; + outputs = [ + "out" + "bdf" + ]; meta = with lib; { description = "/efont/ Unicode bitmap font"; diff --git a/pkgs/by-name/eg/eget/package.nix b/pkgs/by-name/eg/eget/package.nix index 89aa759741ae8d..401795ba0e4f61 100644 --- a/pkgs/by-name/eg/eget/package.nix +++ b/pkgs/by-name/eg/eget/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, pandoc -, installShellFiles -, nix-update-script -, testers -, eget +{ + lib, + fetchFromGitHub, + buildGoModule, + pandoc, + installShellFiles, + nix-update-script, + testers, + eget, }: buildGoModule rec { @@ -21,9 +22,16 @@ buildGoModule rec { vendorHash = "sha256-A3lZtV0pXh4KxINl413xGbw2Pz7OzvIQiFSRubH428c="; - ldflags = [ "-s" "-w" "-X main.Version=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.Version=v${version}" + ]; - nativeBuildInputs = [ pandoc installShellFiles ]; + nativeBuildInputs = [ + pandoc + installShellFiles + ]; postInstall = '' pandoc man/eget.md -s -t man -o eget.1 diff --git a/pkgs/by-name/eg/eggdbus/package.nix b/pkgs/by-name/eg/eggdbus/package.nix index c5ede8488511fb..69797db314cdb4 100644 --- a/pkgs/by-name/eg/eggdbus/package.nix +++ b/pkgs/by-name/eg/eggdbus/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, dbus, dbus-glib }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + dbus, + dbus-glib, +}: stdenv.mkDerivation rec { pname = "eggdbus"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib dbus dbus-glib ]; + buildInputs = [ + glib + dbus + dbus-glib + ]; meta = with lib; { homepage = "https://hal.freedesktop.org/releases/"; diff --git a/pkgs/by-name/eg/eggdrop/package.nix b/pkgs/by-name/eg/eggdrop/package.nix index 7f5b7afb32e721..da007bc129f7d6 100644 --- a/pkgs/by-name/eg/eggdrop/package.nix +++ b/pkgs/by-name/eg/eggdrop/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, tcl }: +{ + lib, + stdenv, + fetchurl, + tcl, +}: stdenv.mkDerivation rec { pname = "eggdrop"; diff --git a/pkgs/by-name/eg/egglog/package.nix b/pkgs/by-name/eg/egglog/package.nix index f730d0ec55eaf9..1e947e1cfcb314 100644 --- a/pkgs/by-name/eg/egglog/package.nix +++ b/pkgs/by-name/eg/egglog/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage { diff --git a/pkgs/by-name/eg/eggnog-mapper/package.nix b/pkgs/by-name/eg/eggnog-mapper/package.nix index d7bba930abca64..8a8cfe376028ff 100644 --- a/pkgs/by-name/eg/eggnog-mapper/package.nix +++ b/pkgs/by-name/eg/eggnog-mapper/package.nix @@ -1,9 +1,10 @@ -{ lib -, autoPatchelfHook -, fetchFromGitHub -, python3Packages -, wget -, zlib +{ + lib, + autoPatchelfHook, + fetchFromGitHub, + python3Packages, + wget, + zlib, }: python3Packages.buildPythonApplication rec { @@ -31,13 +32,15 @@ python3Packages.buildPythonApplication rec { zlib ]; - propagatedBuildInputs = [ - wget - ] ++ (with python3Packages; [ - biopython - psutil - xlsxwriter - ]); + propagatedBuildInputs = + [ + wget + ] + ++ (with python3Packages; [ + biopython + psutil + xlsxwriter + ]); # Tests rely on some of the databases being available, which is not bundled # with this package as (1) in total, they represent >100GB of data, and (2) diff --git a/pkgs/by-name/eg/eglexternalplatform/package.nix b/pkgs/by-name/eg/eglexternalplatform/package.nix index cd545f69f048ac..51f865708ddd16 100644 --- a/pkgs/by-name/eg/eglexternalplatform/package.nix +++ b/pkgs/by-name/eg/eglexternalplatform/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, }: stdenv.mkDerivation rec { @@ -16,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-t0dka5aUv5hB4G8PbSGiIY74XIFAsmo5a7dfWb2QCLM="; }; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; meta = with lib; { description = "EGL External Platform interface"; diff --git a/pkgs/by-name/eg/ego/package.nix b/pkgs/by-name/eg/ego/package.nix index 67a71a196bd766..afc427fd2e5742 100644 --- a/pkgs/by-name/eg/ego/package.nix +++ b/pkgs/by-name/eg/ego/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, makeBinaryWrapper -, acl -, xorg +{ + lib, + rustPlatform, + fetchFromGitHub, + makeBinaryWrapper, + acl, + xorg, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/eg/egoboo/package.nix b/pkgs/by-name/eg/egoboo/package.nix index ba89e4ca7afded..91c9a44935ed16 100644 --- a/pkgs/by-name/eg/egoboo/package.nix +++ b/pkgs/by-name/eg/egoboo/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, libGLU, libGL, SDL, SDL_mixer, SDL_image, SDL_ttf }: +{ + lib, + stdenv, + fetchurl, + libGLU, + libGL, + SDL, + SDL_mixer, + SDL_image, + SDL_ttf, +}: stdenv.mkDerivation rec { # pf5234 (a developer?) at freenode #egoboo told me that I better use 2.7.3 until @@ -29,7 +39,14 @@ stdenv.mkDerivation rec { cp -v -Rd controls.txt setup.txt players modules basicdat $out/share/egoboo-${version} ''; - buildInputs = [ libGLU libGL SDL SDL_mixer SDL_image SDL_ttf ]; + buildInputs = [ + libGLU + libGL + SDL + SDL_mixer + SDL_image + SDL_ttf + ]; /* This big commented thing may be needed for versions 2.8.0 or beyond diff --git a/pkgs/by-name/eg/egypt/package.nix b/pkgs/by-name/eg/egypt/package.nix index 5c9b4ef0453dff..71edbdb891f59f 100644 --- a/pkgs/by-name/eg/egypt/package.nix +++ b/pkgs/by-name/eg/egypt/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, perlPackages }: +{ + lib, + fetchurl, + perlPackages, +}: perlPackages.buildPerlPackage rec { pname = "egypt"; @@ -27,7 +31,10 @@ perlPackages.buildPerlPackage rec { together. ''; homepage = "http://www.gson.org/egypt/"; - license = with licenses; [ artistic1 gpl1Plus ]; + license = with licenses; [ + artistic1 + gpl1Plus + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ei/eiciel/package.nix b/pkgs/by-name/ei/eiciel/package.nix index 4e9112a237f9bb..0866b0070c3223 100644 --- a/pkgs/by-name/ei/eiciel/package.nix +++ b/pkgs/by-name/ei/eiciel/package.nix @@ -1,23 +1,27 @@ -{ lib -, fetchFromGitHub -, stdenv -, acl -, glibmm_2_68 -, gtkmm4 -, meson -, nautilus -, ninja -, pkg-config -, itstool -, wrapGAppsHook4 -, gtk4 +{ + lib, + fetchFromGitHub, + stdenv, + acl, + glibmm_2_68, + gtkmm4, + meson, + nautilus, + ninja, + pkg-config, + itstool, + wrapGAppsHook4, + gtk4, }: stdenv.mkDerivation rec { pname = "eiciel"; version = "0.10.1"; - outputs = [ "out" "nautilusExtension" ]; + outputs = [ + "out" + "nautilusExtension" + ]; src = fetchFromGitHub { owner = "rofirrim"; diff --git a/pkgs/by-name/ei/eigenmath/package.nix b/pkgs/by-name/ei/eigenmath/package.nix index 6bc426b2680102..dc37ce7776effb 100644 --- a/pkgs/by-name/ei/eigenmath/package.nix +++ b/pkgs/by-name/ei/eigenmath/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildPackages -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + buildPackages, + unstableGitUpdater, }: stdenv.mkDerivation rec { @@ -16,15 +17,19 @@ stdenv.mkDerivation rec { hash = "sha256-YnSNXlH8l8+2WeoiLpPuzepv/Mtxa1ltGpgcln+Emgw="; }; - checkPhase = let emulator = stdenv.hostPlatform.emulator buildPackages; in '' - runHook preCheck + checkPhase = + let + emulator = stdenv.hostPlatform.emulator buildPackages; + in + '' + runHook preCheck - for testcase in selftest1 selftest2; do - ${emulator} ./eigenmath "test/$testcase" - done + for testcase in selftest1 selftest2; do + ${emulator} ./eigenmath "test/$testcase" + done - runHook postCheck - ''; + runHook postCheck + ''; installPhase = '' runHook preInstall @@ -38,7 +43,7 @@ stdenv.mkDerivation rec { updateScript = unstableGitUpdater { }; }; - meta = with lib;{ + meta = with lib; { description = "Computer algebra system written in C"; mainProgram = "eigenmath"; homepage = "https://georgeweigt.github.io"; diff --git a/pkgs/by-name/ei/eiwd/package.nix b/pkgs/by-name/ei/eiwd/package.nix index 281837fd4bd4f6..91c06efbb0d142 100644 --- a/pkgs/by-name/ei/eiwd/package.nix +++ b/pkgs/by-name/ei/eiwd/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, python3Packages # for tests -, openssl # for tests -, enableManpages ? true -, docutils # for manpages +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + python3Packages, # for tests + openssl, # for tests + enableManpages ? true, + docutils, # for manpages }: stdenv.mkDerivation (finalAttrs: { @@ -21,35 +22,43 @@ stdenv.mkDerivation (finalAttrs: { fetchSubmodules = true; }; - outputs = [ - "out" "doc" - ] ++ lib.optionals enableManpages [ - "man" - ] ++ lib.optionals finalAttrs.doCheck [ - "test" - ]; + outputs = + [ + "out" + "doc" + ] + ++ lib.optionals enableManpages [ + "man" + ] + ++ lib.optionals finalAttrs.doCheck [ + "test" + ]; postUnpack = '' patchShebangs . ''; - nativeBuildInputs = [ - autoreconfHook - pkg-config - ] ++ lib.optionals enableManpages [ - docutils # only for the man pages - ]; + nativeBuildInputs = + [ + autoreconfHook + pkg-config + ] + ++ lib.optionals enableManpages [ + docutils # only for the man pages + ]; checkInputs = [ python3Packages.python (lib.getBin openssl) ]; - configureFlags = [ - "--disable-dbus" - ] ++ lib.optionals (!enableManpages) [ - "--disable-manual-pages" - ]; + configureFlags = + [ + "--disable-dbus" + ] + ++ lib.optionals (!enableManpages) [ + "--disable-manual-pages" + ]; enableParallelBuilding = true; @@ -65,14 +74,16 @@ stdenv.mkDerivation (finalAttrs: { 'true' ''; - postInstall = '' - mkdir -p $doc/share/doc - cp -a doc $doc/share/doc/iwd - cp -a README AUTHORS TODO $doc/share/doc/iwd - '' + lib.optionalString finalAttrs.finalPackage.doCheck '' - mkdir -p $test/bin - cp -a test/* $test/bin/ - ''; + postInstall = + '' + mkdir -p $doc/share/doc + cp -a doc $doc/share/doc/iwd + cp -a README AUTHORS TODO $doc/share/doc/iwd + '' + + lib.optionalString finalAttrs.finalPackage.doCheck '' + mkdir -p $test/bin + cp -a test/* $test/bin/ + ''; meta = with lib; { homepage = "https://github.com/illiliti/eiwd/"; diff --git a/pkgs/by-name/ej/ejabberd/package.nix b/pkgs/by-name/ej/ejabberd/package.nix index 106a46d6c1452d..c8fe8997962b05 100644 --- a/pkgs/by-name/ej/ejabberd/package.nix +++ b/pkgs/by-name/ej/ejabberd/package.nix @@ -139,7 +139,7 @@ let ]; in -stdenv.mkDerivation (finalAttrs:{ +stdenv.mkDerivation (finalAttrs: { pname = "ejabberd"; version = "24.10"; diff --git a/pkgs/by-name/ej/ejson2env/package.nix b/pkgs/by-name/ej/ejson2env/package.nix index 784d32b20c4574..2d1a57df40fe45 100644 --- a/pkgs/by-name/ej/ejson2env/package.nix +++ b/pkgs/by-name/ej/ejson2env/package.nix @@ -1,4 +1,12 @@ -{ lib, buildGoModule, fetchFromGitHub, nix-update-script, testers, callPackage, ejson2env }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + testers, + callPackage, + ejson2env, +}: buildGoModule rec { pname = "ejson2env"; @@ -23,7 +31,7 @@ buildGoModule rec { updateScript = nix-update-script { }; tests = { version = testers.testVersion { package = ejson2env; }; - decryption = callPackage ./test-decryption.nix {}; + decryption = callPackage ./test-decryption.nix { }; }; }; diff --git a/pkgs/by-name/ej/ejson2env/test-decryption.nix b/pkgs/by-name/ej/ejson2env/test-decryption.nix index d4402a68f9d69c..8f6d7c6a72a4ca 100644 --- a/pkgs/by-name/ej/ejson2env/test-decryption.nix +++ b/pkgs/by-name/ej/ejson2env/test-decryption.nix @@ -1,19 +1,21 @@ { ejson2env, runCommand }: -runCommand "check-ejson2env.sh" { - nativeBuildInputs = [ ejson2env ]; -} '' - cat > $TMP/abc.ejson < $TMP/abc.ejson < dwfl_thread_getframes: No DWARF information found - sed -i s/run-backtrace-dwarf.sh//g tests/Makefile.in - ''; + postPatch = + '' + patchShebangs tests/*.sh + '' + + lib.optionalString stdenv.hostPlatform.isRiscV '' + # disable failing test: + # + # > dwfl_thread_getframes: No DWARF information found + sed -i s/run-backtrace-dwarf.sh//g tests/Makefile.in + ''; - outputs = [ "bin" "dev" "out" "man" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + ]; # We need bzip2 in NativeInputs because otherwise we can't unpack the src, # as the host-bzip2 will be in the path. - nativeBuildInputs = [ m4 bison flex gettext bzip2 ] + nativeBuildInputs = + [ + m4 + bison + flex + gettext + bzip2 + ] ++ lib.optional enableDebuginfod pkg-config ++ lib.optional (stdenv.targetPlatform.useLLVM or false) autoreconfHook; - buildInputs = [ zlib zstd bzip2 xz ] + buildInputs = + [ + zlib + zstd + bzip2 + xz + ] ++ lib.optionals stdenv.hostPlatform.isMusl [ - argp-standalone - musl-fts - musl-obstack - ] ++ lib.optionals enableDebuginfod [ - sqlite - curl - libmicrohttpd - libarchive - ]; + argp-standalone + musl-fts + musl-obstack + ] + ++ lib.optionals enableDebuginfod [ + sqlite + curl + libmicrohttpd + libarchive + ]; propagatedNativeBuildInputs = [ setupDebugInfoDirs ]; - configureFlags = [ - "--program-prefix=eu-" # prevent collisions with binutils - "--enable-deterministic-archives" - (lib.enableFeature enableDebuginfod "libdebuginfod") - (lib.enableFeature enableDebuginfod "debuginfod") + configureFlags = + [ + "--program-prefix=eu-" # prevent collisions with binutils + "--enable-deterministic-archives" + (lib.enableFeature enableDebuginfod "libdebuginfod") + (lib.enableFeature enableDebuginfod "debuginfod") - # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101766 - # Versioned symbols are nice to have, but we can do without. - (lib.enableFeature (!stdenv.hostPlatform.isMicroBlaze) "symbol-versioning") - ] ++ lib.optional (stdenv.targetPlatform.useLLVM or false) "--disable-demangler" + # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101766 + # Versioned symbols are nice to have, but we can do without. + (lib.enableFeature (!stdenv.hostPlatform.isMicroBlaze) "symbol-versioning") + ] + ++ lib.optional (stdenv.targetPlatform.useLLVM or false) "--disable-demangler" ++ lib.optionals stdenv.cc.isClang [ "CFLAGS=-Wno-unused-private-field" "CXXFLAGS=-Wno-unused-private-field" @@ -89,7 +134,6 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - doCheck = # Backtrace unwinding tests rely on glibc-internal symbol names. # Musl provides slightly different forms and fails. @@ -98,8 +142,7 @@ stdenv.mkDerivation rec { # Test suite tries using `uname` to determine whether certain tests # can be executed, so we need to match build and host platform exactly. && (stdenv.hostPlatform == stdenv.buildPlatform); - doInstallCheck = !stdenv.hostPlatform.isMusl - && (stdenv.hostPlatform == stdenv.buildPlatform); + doInstallCheck = !stdenv.hostPlatform.isMusl && (stdenv.hostPlatform == stdenv.buildPlatform); passthru.updateScript = gitUpdater { url = "https://sourceware.org/git/elfutils.git"; @@ -114,7 +157,11 @@ stdenv.mkDerivation rec { badPlatforms = [ lib.systems.inspect.platformPatterns.isStatic ]; # licenses are GPL2 or LGPL3+ for libraries, GPL3+ for bins, # but since this package isn't split that way, all three are listed. - license = with licenses; [ gpl2Only lgpl3Plus gpl3Plus ]; + license = with licenses; [ + gpl2Only + lgpl3Plus + gpl3Plus + ]; maintainers = with maintainers; [ r-burns ]; }; } diff --git a/pkgs/by-name/el/elfx86exts/package.nix b/pkgs/by-name/el/elfx86exts/package.nix index 727102b9dccb70..0f4aa3e756628e 100644 --- a/pkgs/by-name/el/elfx86exts/package.nix +++ b/pkgs/by-name/el/elfx86exts/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/el/eli/package.nix b/pkgs/by-name/el/eli/package.nix index 7cd9413991fc6e..fb052cc170a6a0 100644 --- a/pkgs/by-name/el/eli/package.nix +++ b/pkgs/by-name/el/eli/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchurl -, symlinkJoin -, makeWrapper -, tcl -, fontconfig -, tk -, ncurses -, xorg -, file +{ + lib, + stdenv, + fetchurl, + symlinkJoin, + makeWrapper, + tcl, + fontconfig, + tk, + ncurses, + xorg, + file, }: let @@ -33,18 +35,20 @@ stdenv.mkDerivation rec { src = fetchurl { url = "mirror://sourceforge/project/eli-project/Eli/Eli%20${version}/${pname}-${version}.tar.bz2"; - sha256="1vran8583hbwrr5dciji4zkhz3f88w4mn8n9sdpr6zw0plpf1whj"; + sha256 = "1vran8583hbwrr5dciji4zkhz3f88w4mn8n9sdpr6zw0plpf1whj"; }; - buildInputs = [ - ncurses - fontconfig - ] ++ (with xorg; [ - libX11.dev - libXt.dev - libXaw.dev - libXext.dev - ]); + buildInputs = + [ + ncurses + fontconfig + ] + ++ (with xorg; [ + libX11.dev + libXt.dev + libXaw.dev + libXext.dev + ]); nativeBuildInputs = [ file @@ -58,7 +62,7 @@ stdenv.mkDerivation rec { # ld: cexp.o:(.bss+0x40): multiple definition of `obstck'; cccp.o:(.bss+0x0): first defined here env.NIX_CFLAGS_COMPILE = "-fcommon"; - preConfigure='' + preConfigure = '' configureFlagsArray=( --with-tcltk="${tcl} ${tk_combined}" --with-curses="${curses_combined}" diff --git a/pkgs/by-name/el/elkhound/package.nix b/pkgs/by-name/el/elkhound/package.nix index 562c11a5278a7f..a5f4b3543fc42c 100644 --- a/pkgs/by-name/el/elkhound/package.nix +++ b/pkgs/by-name/el/elkhound/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, bison -, cmake -, flex -, perl +{ + stdenv, + lib, + fetchFromGitHub, + bison, + cmake, + flex, + perl, }: stdenv.mkDerivation rec { @@ -24,7 +25,12 @@ stdenv.mkDerivation rec { sourceRoot = "${src.name}/src"; - nativeBuildInputs = [ bison cmake flex perl ]; + nativeBuildInputs = [ + bison + cmake + flex + perl + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/el/elliptic_curves/package.nix b/pkgs/by-name/el/elliptic_curves/package.nix index 55c03afbc4c203..314d6b9b310b91 100644 --- a/pkgs/by-name/el/elliptic_curves/package.nix +++ b/pkgs/by-name/el/elliptic_curves/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchurl -, python3 +{ + lib, + stdenv, + fetchurl, + python3, }: stdenv.mkDerivation rec { @@ -12,7 +14,6 @@ stdenv.mkDerivation rec { sha256 = "0l7xh4abw5sb4d37r0ylr3vwb88fpx2zrvfm5ql0c7yrv5q59fjz"; }; - # Script that creates the sqlite database from the allcurves textfile spkg-install = fetchurl { url = "https://raw.githubusercontent.com/sagemath/sage/07d6c37d18811e2b377a9689790a7c5e24da16ba/build/pkgs/${pname}/spkg-install.py"; diff --git a/pkgs/by-name/el/elmerfem/package.nix b/pkgs/by-name/el/elmerfem/package.nix index 309e81fad74637..820781d98759a1 100644 --- a/pkgs/by-name/el/elmerfem/package.nix +++ b/pkgs/by-name/el/elmerfem/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gfortran -, mpi -, blas -, liblapack -, pkg-config -, libGL -, libGLU -, opencascade-occt_7_6 -, libsForQt5 -, tbb -, vtkWithQt5 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gfortran, + mpi, + blas, + liblapack, + pkg-config, + libGL, + libGLU, + opencascade-occt_7_6, + libsForQt5, + tbb, + vtkWithQt5, }: let opencascade-occt = opencascade-occt_7_6; @@ -58,23 +59,26 @@ stdenv.mkDerivation rec { storepath = placeholder "out"; cmakeFlags = [ - "-DELMER_INSTALL_LIB_DIR=${storepath}/lib" - "-DWITH_OpenMP:BOOLEAN=TRUE" - "-DWITH_MPI:BOOLEAN=TRUE" - "-DWITH_QT5:BOOLEAN=TRUE" - "-DWITH_OCC:BOOLEAN=TRUE" - "-DWITH_VTK:BOOLEAN=TRUE" - "-DWITH_ELMERGUI:BOOLEAN=TRUE" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - "-DCMAKE_OpenGL_GL_PREFERENCE=GLVND" + "-DELMER_INSTALL_LIB_DIR=${storepath}/lib" + "-DWITH_OpenMP:BOOLEAN=TRUE" + "-DWITH_MPI:BOOLEAN=TRUE" + "-DWITH_QT5:BOOLEAN=TRUE" + "-DWITH_OCC:BOOLEAN=TRUE" + "-DWITH_VTK:BOOLEAN=TRUE" + "-DWITH_ELMERGUI:BOOLEAN=TRUE" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + "-DCMAKE_OpenGL_GL_PREFERENCE=GLVND" ]; meta = with lib; { homepage = "https://elmerfem.org"; description = "Finite element software for multiphysical problems"; platforms = platforms.unix; - maintainers = with maintainers; [ wulfsta broke ]; + maintainers = with maintainers; [ + wulfsta + broke + ]; license = licenses.lgpl21; }; diff --git a/pkgs/by-name/el/elogind/package.nix b/pkgs/by-name/el/elogind/package.nix index 3d23056e69d117..95b90e030d9475 100644 --- a/pkgs/by-name/el/elogind/package.nix +++ b/pkgs/by-name/el/elogind/package.nix @@ -1,36 +1,37 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchurl -, fetchpatch -, meson -, ninja -, m4 -, gperf -, getent -, acl -, audit -, dbus -, libcap -, libselinux -, pam -, gettext -, pkg-config -, udev -, eudev -, util-linux -, libxslt -, python3Packages -, docbook5 -, docbook_xsl -, docbook_xsl_ns -, docbook_xml_dtd_42 -, docbook_xml_dtd_45 +{ + stdenv, + lib, + fetchFromGitHub, + fetchurl, + fetchpatch, + meson, + ninja, + m4, + gperf, + getent, + acl, + audit, + dbus, + libcap, + libselinux, + pam, + gettext, + pkg-config, + udev, + eudev, + util-linux, + libxslt, + python3Packages, + docbook5, + docbook_xsl, + docbook_xsl_ns, + docbook_xml_dtd_42, + docbook_xml_dtd_45, -# Defaulting to false because usually the rationale for using elogind is to -# use it in situation where a systemd dependency does not work (especially -# when building with musl, which elogind explicitly supports). -, enableSystemd ? false + # Defaulting to false because usually the rationale for using elogind is to + # use it in situation where a systemd dependency does not work (especially + # when building with musl, which elogind explicitly supports). + enableSystemd ? false, }: stdenv.mkDerivation rec { @@ -54,14 +55,25 @@ stdenv.mkDerivation rec { libcap gettext libxslt.bin # xsltproc - docbook5 docbook_xsl docbook_xsl_ns docbook_xml_dtd_42 docbook_xml_dtd_45 # needed for docbook without Internet + docbook5 + docbook_xsl + docbook_xsl_ns + docbook_xml_dtd_42 + docbook_xml_dtd_45 # needed for docbook without Internet python3Packages.python python3Packages.jinja2 ]; - buildInputs = [ acl audit dbus libcap libselinux pam util-linux ] - ++ (if enableSystemd then [ udev ] else [ eudev ]); + buildInputs = [ + acl + audit + dbus + libcap + libselinux + pam + util-linux + ] ++ (if enableSystemd then [ udev ] else [ eudev ]); postPatch = '' substituteInPlace meson.build --replace-fail "install_emptydir(elogindstatedir)" "" diff --git a/pkgs/by-name/el/elpa/package.nix b/pkgs/by-name/el/elpa/package.nix index 03e6595d123966..c4e7c82f01b3ff 100644 --- a/pkgs/by-name/el/elpa/package.nix +++ b/pkgs/by-name/el/elpa/package.nix @@ -1,18 +1,27 @@ -{ lib, stdenv, fetchurl, autoreconfHook, mpiCheckPhaseHook -, perl, mpi, blas, lapack, scalapack -# CPU optimizations -, avxSupport ? stdenv.hostPlatform.avxSupport -, avx2Support ? stdenv.hostPlatform.avx2Support -, avx512Support ? stdenv.hostPlatform.avx512Support -, config -# Enable NIVIA GPU support -# Note, that this needs to be built on a system with a GPU -# present for the tests to succeed. -, enableCuda ? config.cudaSupport -# type of GPU architecture -, nvidiaArch ? "sm_60" -, cudaPackages -} : +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + mpiCheckPhaseHook, + perl, + mpi, + blas, + lapack, + scalapack, + # CPU optimizations + avxSupport ? stdenv.hostPlatform.avxSupport, + avx2Support ? stdenv.hostPlatform.avx2Support, + avx512Support ? stdenv.hostPlatform.avx512Support, + config, + # Enable NIVIA GPU support + # Note, that this needs to be built on a system with a GPU + # present for the tests to succeed. + enableCuda ? config.cudaSupport, + # type of GPU architecture + nvidiaArch ? "sm_60", + cudaPackages, +}: assert blas.isILP64 == lapack.isILP64; assert blas.isILP64 == scalapack.isILP64; @@ -41,12 +50,25 @@ stdenv.mkDerivation rec { substituteInPlace Makefile.am --replace '#!/bin/bash' '#!${stdenv.shell}' ''; - outputs = [ "out" "doc" "man" "dev" ]; - - nativeBuildInputs = [ autoreconfHook perl ] - ++ lib.optionals enableCuda [ cudaPackages.cuda_nvcc ]; + outputs = [ + "out" + "doc" + "man" + "dev" + ]; - buildInputs = [ mpi blas lapack scalapack ] + nativeBuildInputs = [ + autoreconfHook + perl + ] ++ lib.optionals enableCuda [ cudaPackages.cuda_nvcc ]; + + buildInputs = + [ + mpi + blas + lapack + scalapack + ] ++ lib.optionals enableCuda [ cudaPackages.cuda_cudart cudaPackages.libcublas @@ -59,26 +81,33 @@ stdenv.mkDerivation rec { export CPP="cpp" # These need to be set for configure to succeed - export FCFLAGS="${lib.optionalString stdenv.hostPlatform.isx86_64 "-msse3 " + export FCFLAGS="${ + lib.optionalString stdenv.hostPlatform.isx86_64 "-msse3 " + lib.optionalString avxSupport "-mavx " + lib.optionalString avx2Support "-mavx2 -mfma " - + lib.optionalString avx512Support "-mavx512"}" + + lib.optionalString avx512Support "-mavx512" + }" export CFLAGS=$FCFLAGS ''; - configureFlags = [ - "--with-mpi" - "--enable-openmp" - "--without-threading-support-check-during-build" - ] ++ lib.optional blas.isILP64 "--enable-64bit-integer-math-support" + configureFlags = + [ + "--with-mpi" + "--enable-openmp" + "--without-threading-support-check-during-build" + ] + ++ lib.optional blas.isILP64 "--enable-64bit-integer-math-support" ++ lib.optional (!avxSupport) "--disable-avx" ++ lib.optional (!avx2Support) "--disable-avx2" ++ lib.optional (!avx512Support) "--disable-avx512" ++ lib.optional (!stdenv.hostPlatform.isx86_64) "--disable-sse" ++ lib.optional (!stdenv.hostPlatform.isx86_64) "--disable-sse-assembly" ++ lib.optional stdenv.hostPlatform.isx86_64 "--enable-sse-assembly" - ++ lib.optionals enableCuda [ "--enable-nvidia-gpu" "--with-NVIDIA-GPU-compute-capability=${nvidiaArch}" ]; + ++ lib.optionals enableCuda [ + "--enable-nvidia-gpu" + "--with-NVIDIA-GPU-compute-capability=${nvidiaArch}" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/el/eltclsh/package.nix b/pkgs/by-name/el/eltclsh/package.nix index ec54952406cf55..9753cd7200346f 100644 --- a/pkgs/by-name/el/eltclsh/package.nix +++ b/pkgs/by-name/el/eltclsh/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchgit -, automake -, autoconf -, libtool -, libedit -, tcl -, tk +{ + lib, + fetchgit, + automake, + autoconf, + libtool, + libedit, + tcl, + tk, }: tcl.mkTclDerivation rec { diff --git a/pkgs/by-name/el/elvish/package.nix b/pkgs/by-name/el/elvish/package.nix index 36d2214a2a13ee..b321018b3c3193 100644 --- a/pkgs/by-name/el/elvish/package.nix +++ b/pkgs/by-name/el/elvish/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, callPackage +{ + lib, + buildGoModule, + fetchFromGitHub, + callPackage, }: let diff --git a/pkgs/by-name/el/elvish/tests/expect-version.nix b/pkgs/by-name/el/elvish/tests/expect-version.nix index b7935ceea6710b..123b94e3cbd026 100644 --- a/pkgs/by-name/el/elvish/tests/expect-version.nix +++ b/pkgs/by-name/el/elvish/tests/expect-version.nix @@ -1,6 +1,7 @@ -{ stdenv -, elvish -, substituteAll +{ + stdenv, + elvish, + substituteAll, }: stdenv.mkDerivation { @@ -12,10 +13,12 @@ stdenv.mkDerivation { dontInstall = true; buildCommand = '' - elvish ${substituteAll { - src = ./expect-version.elv; - inherit (elvish) version; - }} + elvish ${ + substituteAll { + src = ./expect-version.elv; + inherit (elvish) version; + } + } touch $out ''; diff --git a/pkgs/by-name/em/em/package.nix b/pkgs/by-name/em/em/package.nix index 89da2d719fa8cb..a70e2d19d779c8 100644 --- a/pkgs/by-name/em/em/package.nix +++ b/pkgs/by-name/em/em/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/em/emacs-all-the-icons-fonts/package.nix b/pkgs/by-name/em/emacs-all-the-icons-fonts/package.nix index 256084a320fce5..b5a443e9f0905f 100644 --- a/pkgs/by-name/em/emacs-all-the-icons-fonts/package.nix +++ b/pkgs/by-name/em/emacs-all-the-icons-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "emacs-all-the-icons-fonts"; diff --git a/pkgs/by-name/em/emacs-lsp-booster/package.nix b/pkgs/by-name/em/emacs-lsp-booster/package.nix index b3f6af1b9dc6e2..a901b2ade7530e 100644 --- a/pkgs/by-name/em/emacs-lsp-booster/package.nix +++ b/pkgs/by-name/em/emacs-lsp-booster/package.nix @@ -17,13 +17,13 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-CvIJ56QrIzQULFeXYQXTpX9PoGx1/DWtgwzfJ+mljEI="; - nativeCheckInputs = [emacs]; # tests/bytecode_test + nativeCheckInputs = [ emacs ]; # tests/bytecode_test meta = with lib; { description = "Emacs LSP performance booster"; homepage = "https://github.com/blahgeek/emacs-lsp-booster"; license = licenses.mit; - maintainers = with maintainers; [icy-thought]; + maintainers = with maintainers; [ icy-thought ]; mainProgram = "emacs-lsp-booster"; }; } diff --git a/pkgs/by-name/em/emacsclient-commands/package.nix b/pkgs/by-name/em/emacsclient-commands/package.nix index 6eb42ec0b534ae..31a0472baa0cd9 100644 --- a/pkgs/by-name/em/emacsclient-commands/package.nix +++ b/pkgs/by-name/em/emacsclient-commands/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, gnumake +{ + lib, + fetchFromGitHub, + buildGoModule, + gnumake, }: buildGoModule { diff --git a/pkgs/by-name/em/email/package.nix b/pkgs/by-name/em/email/package.nix index 3472fdc172252a..2b168ad5d11104 100644 --- a/pkgs/by-name/em/email/package.nix +++ b/pkgs/by-name/em/email/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, openssl }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + openssl, +}: let eMailSrc = fetchFromGitHub { diff --git a/pkgs/by-name/em/emblem/package.nix b/pkgs/by-name/em/emblem/package.nix index c0f9046fa9c821..2936a48c550744 100644 --- a/pkgs/by-name/em/emblem/package.nix +++ b/pkgs/by-name/em/emblem/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitLab -, rustPlatform -, cargo -, desktop-file-utils -, glib -, meson -, ninja -, pkg-config -, rustc -, wrapGAppsHook4 -, libadwaita -, libxml2 -, darwin +{ + lib, + stdenv, + fetchFromGitLab, + rustPlatform, + cargo, + desktop-file-utils, + glib, + meson, + ninja, + pkg-config, + rustc, + wrapGAppsHook4, + libadwaita, + libxml2, + darwin, }: stdenv.mkDerivation rec { @@ -46,16 +47,20 @@ stdenv.mkDerivation rec { rustc ]; - buildInputs = [ - libadwaita - libxml2 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + libadwaita + libxml2 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-Wno-error=incompatible-function-pointer-types" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-Wno-error=incompatible-function-pointer-types" + ] + ); meta = { description = "Generate project icons and avatars from a symbolic icon"; @@ -63,6 +68,10 @@ stdenv.mkDerivation rec { homepage = "https://gitlab.gnome.org/World/design/emblem"; license = lib.licenses.gpl3Plus; platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ figsoda foo-dogsquared aleksana ]; + maintainers = with lib.maintainers; [ + figsoda + foo-dogsquared + aleksana + ]; }; } diff --git a/pkgs/by-name/em/emboss/package.nix b/pkgs/by-name/em/emboss/package.nix index ef501c12f6b4f1..fd0d2cac319277 100644 --- a/pkgs/by-name/em/emboss/package.nix +++ b/pkgs/by-name/em/emboss/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, readline, perl, libharu, libX11, libpng, libXt, zlib }: +{ + lib, + stdenv, + fetchurl, + readline, + perl, + libharu, + libX11, + libpng, + libXt, + zlib, +}: stdenv.mkDerivation rec { pname = "emboss"; @@ -9,9 +20,20 @@ stdenv.mkDerivation rec { sha256 = "7184a763d39ad96bb598bfd531628a34aa53e474db9e7cac4416c2a40ab10c6e"; }; - buildInputs = [ readline perl libharu libpng libX11 libXt zlib ]; + buildInputs = [ + readline + perl + libharu + libpng + libX11 + libXt + zlib + ]; - configureFlags = [ "--with-hpdf=${libharu}" "--with-pngdriver=${zlib}" ]; + configureFlags = [ + "--with-hpdf=${libharu}" + "--with-pngdriver=${zlib}" + ]; postConfigure = '' sed -i 's@$(bindir)/embossupdate@true@' Makefile diff --git a/pkgs/by-name/em/emem/package.nix b/pkgs/by-name/em/emem/package.nix index 043be629fd28ed..4fa8d670c4c5f6 100644 --- a/pkgs/by-name/em/emem/package.nix +++ b/pkgs/by-name/em/emem/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, jdk }: +{ + lib, + stdenv, + fetchurl, + jdk, +}: stdenv.mkDerivation rec { pname = "emem"; @@ -18,14 +23,14 @@ stdenv.mkDerivation rec { ''; installPhase = '' - cp $src $out/share/java/${pname}.jar + cp $src $out/share/java/${pname}.jar - cat > $out/bin/${pname} << EOF -#! $SHELL -$jdk/bin/java -jar $out/share/java/${pname}.jar "\$@" -EOF + cat > $out/bin/${pname} << EOF + #! $SHELL + $jdk/bin/java -jar $out/share/java/${pname}.jar "\$@" + EOF - chmod +x $out/bin/${pname} + chmod +x $out/bin/${pname} ''; meta = with lib; { diff --git a/pkgs/by-name/em/emma/package.nix b/pkgs/by-name/em/emma/package.nix index 4a284ac0d60328..f7067726da72f4 100644 --- a/pkgs/by-name/em/emma/package.nix +++ b/pkgs/by-name/em/emma/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, unzip}: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "emma"; diff --git a/pkgs/by-name/em/emmet-ls/package.nix b/pkgs/by-name/em/emmet-ls/package.nix index 5950dc5438555f..fa988b483e7162 100644 --- a/pkgs/by-name/em/emmet-ls/package.nix +++ b/pkgs/by-name/em/emmet-ls/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, fetchpatch +{ + lib, + buildNpmPackage, + fetchFromGitHub, + fetchpatch, }: buildNpmPackage rec { diff --git a/pkgs/by-name/em/emocli/package.nix b/pkgs/by-name/em/emocli/package.nix index edf6b8dfc24d05..023046fc1b51d4 100644 --- a/pkgs/by-name/em/emocli/package.nix +++ b/pkgs/by-name/em/emocli/package.nix @@ -1,4 +1,9 @@ -{ lib, buildNimPackage, fetchFromGitLab, unicode-emoji }: +{ + lib, + buildNimPackage, + fetchFromGitLab, + unicode-emoji, +}: buildNimPackage (finalAttrs: { pname = "emocli"; diff --git a/pkgs/by-name/em/emoji-picker/package.nix b/pkgs/by-name/em/emoji-picker/package.nix index 6a6d9a4815b05a..76a5c8edda73c6 100644 --- a/pkgs/by-name/em/emoji-picker/package.nix +++ b/pkgs/by-name/em/emoji-picker/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { pname = "emoji-picker"; @@ -13,7 +14,7 @@ buildGoModule rec { hash = "sha256-ElUsmuJ43kOsu4cGvNytM+xHTfuzMo0jcG8Z1cIeHJs="; }; - patches = [./xsys.patch]; + patches = [ ./xsys.patch ]; vendorHash = "sha256-Xeh5JKIBiyOXRGVx9udoUNs+Wv49BMyFvmnAbDfG3rA="; diff --git a/pkgs/by-name/em/emojify/package.nix b/pkgs/by-name/em/emojify/package.nix index 05833d93165493..f812a206920a02 100644 --- a/pkgs/by-name/em/emojify/package.nix +++ b/pkgs/by-name/em/emojify/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/em/emojipick/package.nix b/pkgs/by-name/em/emojipick/package.nix index 9c28c98bf04736..bb2bf0c3fede89 100644 --- a/pkgs/by-name/em/emojipick/package.nix +++ b/pkgs/by-name/em/emojipick/package.nix @@ -1,17 +1,18 @@ -{ stdenvNoCC -, fetchFromGitHub -, lib -, python3 -, xclip -, libnotify -, dmenu -, rofi -, emojipick-use-rofi ? false -, emojipick-copy-to-clipboard ? true -, emojipick-show-notifications ? true -, emojipick-print-emoji ? true -, emojipick-font-family ? "Noto Color Emoji" -, emojipick-font-size ? "18" +{ + stdenvNoCC, + fetchFromGitHub, + lib, + python3, + xclip, + libnotify, + dmenu, + rofi, + emojipick-use-rofi ? false, + emojipick-copy-to-clipboard ? true, + emojipick-show-notifications ? true, + emojipick-print-emoji ? true, + emojipick-font-family ? "Noto Color Emoji", + emojipick-font-size ? "18", }: let @@ -49,7 +50,7 @@ stdenvNoCC.mkDerivation { python3 xclip libnotify - ] ++ (if emojipick-use-rofi then [rofi] else [dmenu]); + ] ++ (if emojipick-use-rofi then [ rofi ] else [ dmenu ]); installPhase = '' runHook preInstall diff --git a/pkgs/by-name/em/emptty/package.nix b/pkgs/by-name/em/emptty/package.nix index b4a55ece767573..c87ea85fe6b250 100644 --- a/pkgs/by-name/em/emptty/package.nix +++ b/pkgs/by-name/em/emptty/package.nix @@ -1,9 +1,10 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, libX11 -, pam -, stdenv +{ + buildGoModule, + fetchFromGitHub, + lib, + libX11, + pam, + stdenv, }: buildGoModule rec { @@ -17,7 +18,10 @@ buildGoModule rec { hash = "sha256-xZfR4sn20fDaTNAxuxVflpr+8AFg5Z7vesO7P8Jxw6A="; }; - buildInputs = [ pam libX11 ]; + buildInputs = [ + pam + libX11 + ]; vendorHash = "sha256-PLyemAUcCz9H7+nAxftki3G7rQoEeyPzY3YUEj2RFn4="; diff --git a/pkgs/by-name/em/empty-epsilon/package.nix b/pkgs/by-name/em/empty-epsilon/package.nix index 5408d1f340d95d..c61e1bce970236 100644 --- a/pkgs/by-name/em/empty-epsilon/package.nix +++ b/pkgs/by-name/em/empty-epsilon/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, cmake, sfml, libX11, glew, python3, glm, meshoptimizer, SDL2, ninja }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + sfml, + libX11, + glew, + python3, + glm, + meshoptimizer, + SDL2, + ninja, +}: let version = { @@ -26,7 +39,12 @@ let }; nativeBuildInputs = [ cmake ]; - buildInputs = [ sfml libX11 glm SDL2 ]; + buildInputs = [ + sfml + libX11 + glm + SDL2 + ]; cmakeFlags = [ (lib.cmakeFeature "FETCHCONTENT_SOURCE_DIR_BASIS" "${basis-universal}") @@ -56,7 +74,16 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ serious-proton sfml glew libX11 python3 glm SDL2 ninja ]; + buildInputs = [ + serious-proton + sfml + glew + libX11 + python3 + glm + SDL2 + ninja + ]; cmakeFlags = [ (lib.cmakeFeature "SERIOUS_PROTON_DIR" "${serious-proton.src}") @@ -77,7 +104,10 @@ stdenv.mkDerivation { mainProgram = "EmptyEpsilon"; homepage = "https://daid.github.io/EmptyEpsilon/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ fpletz ma27 ]; + maintainers = with maintainers; [ + fpletz + ma27 + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/em/empty/package.nix b/pkgs/by-name/em/empty/package.nix index 40e53ca2395068..193d1b7d977349 100644 --- a/pkgs/by-name/em/empty/package.nix +++ b/pkgs/by-name/em/empty/package.nix @@ -1,4 +1,9 @@ -{ fetchzip, lib, stdenv, which }: +{ + fetchzip, + lib, + stdenv, + which, +}: stdenv.mkDerivation rec { pname = "empty"; diff --git a/pkgs/by-name/em/emu2/package.nix b/pkgs/by-name/em/emu2/package.nix index 22f2e17902e848..2900dc5ab83a4f 100644 --- a/pkgs/by-name/em/emu2/package.nix +++ b/pkgs/by-name/em/emu2/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/em/emuflight-configurator/package.nix b/pkgs/by-name/em/emuflight-configurator/package.nix index 66b9cf0efa8ea5..86979a6cec624f 100644 --- a/pkgs/by-name/em/emuflight-configurator/package.nix +++ b/pkgs/by-name/em/emuflight-configurator/package.nix @@ -1,5 +1,15 @@ -{lib, stdenv, fetchurl, unzip, makeDesktopItem, copyDesktopItems, nwjs -, wrapGAppsHook3, gsettings-desktop-schemas, gtk3 }: +{ + lib, + stdenv, + fetchurl, + unzip, + makeDesktopItem, + copyDesktopItems, + nwjs, + wrapGAppsHook3, + gsettings-desktop-schemas, + gtk3, +}: stdenv.mkDerivation rec { pname = "emuflight-configurator"; @@ -10,9 +20,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-7NcN1wF3BUClJBVm13VnV80N/+a2jAEIRqB/x9+GDEg="; }; - nativeBuildInputs = [ wrapGAppsHook3 unzip copyDesktopItems ]; + nativeBuildInputs = [ + wrapGAppsHook3 + unzip + copyDesktopItems + ]; - buildInputs = [ gsettings-desktop-schemas gtk3 ]; + buildInputs = [ + gsettings-desktop-schemas + gtk3 + ]; installPhase = '' mkdir -p $out/bin $out/share/${pname} @@ -43,10 +60,10 @@ stdenv.mkDerivation rec { quadcopters, hexacopters, octocopters and fixed-wing aircraft. The application allows you to configure the Emuflight software running on any supported Emuflight target. ''; - homepage = "https://github.com/emuflight/EmuConfigurator"; + homepage = "https://github.com/emuflight/EmuConfigurator"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.gpl3Only; + license = licenses.gpl3Only; maintainers = with maintainers; [ beezow ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/em/emulsion-palette/package.nix b/pkgs/by-name/em/emulsion-palette/package.nix index 3c2173826697fc..a55fde901ff6ce 100644 --- a/pkgs/by-name/em/emulsion-palette/package.nix +++ b/pkgs/by-name/em/emulsion-palette/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, vala -, wrapGAppsHook4 -, libadwaita -, json-glib -, libgee -, pkg-config -, gtk3 -, desktop-file-utils +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + vala, + wrapGAppsHook4, + libadwaita, + json-glib, + libgee, + pkg-config, + gtk3, + desktop-file-utils, }: stdenv.mkDerivation rec { @@ -24,7 +25,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-xG7yZKbbNao/pzFhdTMof/lw9K12NKZi47YRaEd65ok="; }; - nativeBuildInputs = [ meson ninja pkg-config vala wrapGAppsHook4 ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + vala + wrapGAppsHook4 + ]; buildInputs = [ desktop-file-utils diff --git a/pkgs/by-name/em/emv/package.nix b/pkgs/by-name/em/emv/package.nix index a317805e463ce6..d8a5682b53a93a 100644 --- a/pkgs/by-name/em/emv/package.nix +++ b/pkgs/by-name/em/emv/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "emv"; diff --git a/pkgs/by-name/en/enblend-enfuse/package.nix b/pkgs/by-name/en/enblend-enfuse/package.nix index 26645cea6a594f..c0065c1bdb8223 100644 --- a/pkgs/by-name/en/enblend-enfuse/package.nix +++ b/pkgs/by-name/en/enblend-enfuse/package.nix @@ -1,19 +1,22 @@ -{ lib, stdenv, fetchhg -, autoreconfHook -, boost -, libglut -, glew -, gsl -, lcms2 -, libpng -, libtiff -, libGLU -, libGL -, vigra -, help2man -, pkg-config -, perl -, texliveSmall +{ + lib, + stdenv, + fetchhg, + autoreconfHook, + boost, + libglut, + glew, + gsl, + lcms2, + libpng, + libtiff, + libGLU, + libGL, + vigra, + help2man, + pkg-config, + perl, + texliveSmall, }: stdenv.mkDerivation rec { @@ -26,9 +29,26 @@ stdenv.mkDerivation rec { sha256 = "sha256-0gCUSdg3HR3YeIbOByEBCZh2zGlYur6DeCOzUM53fdc="; }; - buildInputs = [ boost libglut glew gsl lcms2 libpng libtiff libGLU libGL vigra ]; + buildInputs = [ + boost + libglut + glew + gsl + lcms2 + libpng + libtiff + libGLU + libGL + vigra + ]; - nativeBuildInputs = [ autoreconfHook help2man perl pkg-config texliveSmall ]; + nativeBuildInputs = [ + autoreconfHook + help2man + perl + pkg-config + texliveSmall + ]; preConfigure = '' patchShebangs src/embrace diff --git a/pkgs/by-name/en/enc/package.nix b/pkgs/by-name/en/enc/package.nix index cec98aff115119..3243d4da82ae94 100644 --- a/pkgs/by-name/en/enc/package.nix +++ b/pkgs/by-name/en/enc/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, git -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + git, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/en/enca/package.nix b/pkgs/by-name/en/enca/package.nix index f3098a22f41a64..9d213277bf92fe 100644 --- a/pkgs/by-name/en/enca/package.nix +++ b/pkgs/by-name/en/enca/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libiconv, recode }: +{ + lib, + stdenv, + fetchurl, + libiconv, + recode, +}: stdenv.mkDerivation rec { pname = "enca"; @@ -9,17 +15,20 @@ stdenv.mkDerivation rec { sha256 = "1f78jmrggv3jymql8imm5m9yc8nqjw5l99mpwki2245l8357wj1s"; }; - buildInputs = [ recode libiconv ]; + buildInputs = [ + recode + libiconv + ]; meta = with lib; { description = "Detects the encoding of text files and reencodes them"; longDescription = '' - Enca detects the encoding of text files, on the basis of knowledge - of their language. It can also convert them to other encodings, - allowing you to recode files without knowing their current encoding. - It supports most of Central and East European languages, and a few - Unicode variants, independently on language. + Enca detects the encoding of text files, on the basis of knowledge + of their language. It can also convert them to other encodings, + allowing you to recode files without knowing their current encoding. + It supports most of Central and East European languages, and a few + Unicode variants, independently on language. ''; license = licenses.gpl2Only; diff --git a/pkgs/by-name/en/enchive/package.nix b/pkgs/by-name/en/enchive/package.nix index 8db8f466f9aea5..51f7113b09dd59 100644 --- a/pkgs/by-name/en/enchive/package.nix +++ b/pkgs/by-name/en/enchive/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "enchive"; @@ -10,7 +14,7 @@ stdenv.mkDerivation rec { sha256 = "0fdrfc5l42lj2bvmv9dmkmhmm7qiszwk7cmdvnqad3fs7652g0qa"; }; - makeFlags = ["PREFIX=$(out)"]; + makeFlags = [ "PREFIX=$(out)" ]; postInstall = '' mkdir -p $out/share/emacs/site-lisp/ diff --git a/pkgs/by-name/en/encled/package.nix b/pkgs/by-name/en/encled/package.nix index 474b790775cc98..5f7fbb4aa156d7 100644 --- a/pkgs/by-name/en/encled/package.nix +++ b/pkgs/by-name/en/encled/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, python3 }: +{ + stdenv, + lib, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation { pname = "encled"; version = "unstable-2022-07-23"; diff --git a/pkgs/by-name/en/encode-sans/package.nix b/pkgs/by-name/en/encode-sans/package.nix index ec48dc9ee009fb..f81d9c386e688c 100644 --- a/pkgs/by-name/en/encode-sans/package.nix +++ b/pkgs/by-name/en/encode-sans/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "encode-sans"; diff --git a/pkgs/by-name/en/encpipe/package.nix b/pkgs/by-name/en/encpipe/package.nix index c48fa9d162f430..6d9f09b9c74f4d 100644 --- a/pkgs/by-name/en/encpipe/package.nix +++ b/pkgs/by-name/en/encpipe/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/en/endeavour/package.nix b/pkgs/by-name/en/endeavour/package.nix index 806e0249857722..165910b5b536c0 100644 --- a/pkgs/by-name/en/endeavour/package.nix +++ b/pkgs/by-name/en/endeavour/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, gettext -, adwaita-icon-theme -, glib -, gtk4 -, wayland -, libadwaita -, libpeas -, gnome-online-accounts -, gsettings-desktop-schemas -, evolution-data-server-gtk4 -, libical -, itstool -, gitUpdater +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + gettext, + adwaita-icon-theme, + glib, + gtk4, + wayland, + libadwaita, + libpeas, + gnome-online-accounts, + gsettings-desktop-schemas, + evolution-data-server-gtk4, + libical, + itstool, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/en/endgame-singularity/package.nix b/pkgs/by-name/en/endgame-singularity/package.nix index fb68885b936ff2..c32eccacdb0f3c 100644 --- a/pkgs/by-name/en/endgame-singularity/package.nix +++ b/pkgs/by-name/en/endgame-singularity/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchurl -, fetchFromGitHub -, unzip -, python3 -, enableDefaultMusicPack ? true +{ + lib, + fetchurl, + fetchFromGitHub, + unzip, + python3, + enableDefaultMusicPack ? true, }: let @@ -30,7 +31,11 @@ python3.pkgs.buildPythonApplication rec { sourceRoot = main_src.name; nativeBuildInputs = [ unzip ]; # The music is zipped - propagatedBuildInputs = with python3.pkgs; [ pygame numpy polib ]; + propagatedBuildInputs = with python3.pkgs; [ + pygame + numpy + polib + ]; # Add the music postInstall = lib.optionalString enableDefaultMusicPack '' diff --git a/pkgs/by-name/en/endless-sky/package.nix b/pkgs/by-name/en/endless-sky/package.nix index 6a0c2e24c0939a..a27bc6e31024c5 100644 --- a/pkgs/by-name/en/endless-sky/package.nix +++ b/pkgs/by-name/en/endless-sky/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL2 -, libpng -, libjpeg -, glew -, openal -, scons -, libmad -, libuuid +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + libpng, + libjpeg, + glew, + openal, + scons, + libmad, + libuuid, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/en/endlessh/package.nix b/pkgs/by-name/en/endlessh/package.nix index 584a43920fe7aa..77b1d97fb69b02 100644 --- a/pkgs/by-name/en/endlessh/package.nix +++ b/pkgs/by-name/en/endlessh/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, testers -, endlessh -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + testers, + endlessh, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/en/enet/package.nix b/pkgs/by-name/en/enet/package.nix index f9583a097a6ab6..92542b2b5993bf 100644 --- a/pkgs/by-name/en/enet/package.nix +++ b/pkgs/by-name/en/enet/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "enet"; diff --git a/pkgs/by-name/en/engage/package.nix b/pkgs/by-name/en/engage/package.nix index b355f96513c97e..1f05fdd5f990a6 100644 --- a/pkgs/by-name/en/engage/package.nix +++ b/pkgs/by-name/en/engage/package.nix @@ -1,8 +1,9 @@ -{ lib -, installShellFiles -, rustPlatform -, fetchFromGitLab -, stdenv +{ + lib, + installShellFiles, + rustPlatform, + fetchFromGitLab, + stdenv, }: let @@ -28,24 +29,24 @@ rustPlatform.buildRustPackage { postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) ( "installShellCompletion --cmd engage " - + builtins.concatStringsSep - " " - (builtins.map - (shell: "--${shell} <($out/bin/engage completions ${shell})") - [ - "bash" - "fish" - "zsh" - ] - ) - ); + + builtins.concatStringsSep " " ( + builtins.map (shell: "--${shell} <($out/bin/engage completions ${shell})") [ + "bash" + "fish" + "zsh" + ] + ) + ); meta = { description = "Task runner with DAG-based parallelism"; mainProgram = "engage"; homepage = "https://gitlab.computer.surgery/charles/engage"; changelog = "https://gitlab.computer.surgery/charles/engage/-/blob/v${version}/CHANGELOG.md"; - license = with lib.licenses; [ asl20 mit ]; + license = with lib.licenses; [ + asl20 + mit + ]; maintainers = with lib.maintainers; [ CobaltCause ]; }; } diff --git a/pkgs/by-name/en/engelsystem/package.nix b/pkgs/by-name/en/engelsystem/package.nix index fd3de6d6958ffa..e8f0625e5cdba5 100644 --- a/pkgs/by-name/en/engelsystem/package.nix +++ b/pkgs/by-name/en/engelsystem/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchzip -, nixosTests -, php -, stdenv -, writeText +{ + lib, + fetchzip, + nixosTests, + php, + stdenv, + writeText, }: stdenv.mkDerivation rec { @@ -42,8 +43,7 @@ stdenv.mkDerivation rec { meta = with lib; { changelog = "https://github.com/engelsystem/engelsystem/releases/tag/v${version}"; - description = - "Coordinate your volunteers in teams, assign them to work shifts or let them decide for themselves when and where they want to help with what"; + description = "Coordinate your volunteers in teams, assign them to work shifts or let them decide for themselves when and where they want to help with what"; homepage = "https://engelsystem.de"; license = licenses.gpl2Only; mainProgram = "migrate"; diff --git a/pkgs/by-name/en/enhanced-ctorrent/package.nix b/pkgs/by-name/en/enhanced-ctorrent/package.nix index 5074690228045e..598a8ae6da5061 100644 --- a/pkgs/by-name/en/enhanced-ctorrent/package.nix +++ b/pkgs/by-name/en/enhanced-ctorrent/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, +}: stdenv.mkDerivation { version = "3.3.2"; diff --git a/pkgs/by-name/en/enjarify/package.nix b/pkgs/by-name/en/enjarify/package.nix index 37daac6c06b300..cf46e3c7e912da 100644 --- a/pkgs/by-name/en/enjarify/package.nix +++ b/pkgs/by-name/en/enjarify/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, python3, runtimeShell }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "enjarify"; diff --git a/pkgs/by-name/en/enpass/package.nix b/pkgs/by-name/en/enpass/package.nix index 20582a6d5c6bd2..3d10bdf5bf62b7 100644 --- a/pkgs/by-name/en/enpass/package.nix +++ b/pkgs/by-name/en/enpass/package.nix @@ -1,8 +1,29 @@ -{ stdenv, fetchurl, dpkg, xorg -, glib, libGLU, libGL, libpulseaudio, zlib, dbus, fontconfig, freetype -, gtk3, pango -, makeWrapper , python3Packages, lib, libcap -, lsof, curl, libuuid, cups, mesa, xz, libxkbcommon +{ + stdenv, + fetchurl, + dpkg, + xorg, + glib, + libGLU, + libGL, + libpulseaudio, + zlib, + dbus, + fontconfig, + freetype, + gtk3, + pango, + makeWrapper, + python3Packages, + lib, + libcap, + lsof, + curl, + libuuid, + cups, + mesa, + xz, + libxkbcommon, }: let @@ -12,39 +33,47 @@ let x86_64-linux = "amd64"; }; - data = all_data.${system_map.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}")}; + data = + all_data.${ + system_map.${stdenv.hostPlatform.system} + or (throw "Unsupported system: ${stdenv.hostPlatform.system}") + }; baseUrl = "https://apt.enpass.io"; # used of both wrappers and libpath - libPath = lib.makeLibraryPath (with xorg; [ - libGLU libGL - fontconfig - freetype - libpulseaudio - zlib - dbus - libX11 - libXi - libSM - libICE - libXrender - libXScrnSaver - libxcb - libcap - glib - gtk3 - pango - curl - libuuid - cups - xcbutilwm # libxcb-icccm.so.4 - xcbutilimage # libxcb-image.so.0 - xcbutilkeysyms # libxcb-keysyms.so.1 - xcbutilrenderutil # libxcb-render-util.so.0 - xz - libxkbcommon - ]); + libPath = lib.makeLibraryPath ( + with xorg; + [ + libGLU + libGL + fontconfig + freetype + libpulseaudio + zlib + dbus + libX11 + libXi + libSM + libICE + libXrender + libXScrnSaver + libxcb + libcap + glib + gtk3 + pango + curl + libuuid + cups + xcbutilwm # libxcb-icccm.so.4 + xcbutilimage # libxcb-image.so.0 + xcbutilkeysyms # libxcb-keysyms.so.1 + xcbutilrenderutil # libxcb-render-util.so.0 + xz + libxkbcommon + ] + ); package = stdenv.mkDerivation { inherit (data) version; @@ -60,15 +89,21 @@ let homepage = "https://www.enpass.io/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - platforms = [ "x86_64-linux" "i686-linux"]; - maintainers = with maintainers; [ ewok dritter ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; + maintainers = with maintainers; [ + ewok + dritter + ]; }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [dpkg]; + buildInputs = [ dpkg ]; unpackPhase = "dpkg -X $src ."; - installPhase='' + installPhase = '' mkdir -p $out/bin cp -r opt/enpass/* $out/bin cp -r usr/* $out @@ -92,13 +127,20 @@ let updater = { update = stdenv.mkDerivation { name = "enpass-update-script"; - SCRIPT =./update_script.py; + SCRIPT = ./update_script.py; - buildInputs = with python3Packages; [python requests pathlib2 six attrs ]; + buildInputs = with python3Packages; [ + python + requests + pathlib2 + six + attrs + ]; shellHook = '' exec python $SCRIPT --target pkgs/tools/security/enpass/data.json --repo ${baseUrl} ''; }; }; -in (package // {refresh = updater;}) +in +(package // { refresh = updater; }) diff --git a/pkgs/by-name/en/enscript/package.nix b/pkgs/by-name/en/enscript/package.nix index 5908b9fd529a97..fb2efa08fd5d03 100644 --- a/pkgs/by-name/en/enscript/package.nix +++ b/pkgs/by-name/en/enscript/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gettext }: +{ + lib, + stdenv, + fetchurl, + gettext, +}: stdenv.mkDerivation rec { pname = "enscript"; diff --git a/pkgs/by-name/en/ensemble-chorus/package.nix b/pkgs/by-name/en/ensemble-chorus/package.nix index a83719a5e4161e..735d2be3afed58 100644 --- a/pkgs/by-name/en/ensemble-chorus/package.nix +++ b/pkgs/by-name/en/ensemble-chorus/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, fltk, alsa-lib, freetype, libXrandr, libXinerama, libXcursor, lv2, libjack2, cmake, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + fltk, + alsa-lib, + freetype, + libXrandr, + libXinerama, + libXcursor, + lv2, + libjack2, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "ensemble-chorus"; @@ -17,10 +31,20 @@ stdenv.mkDerivation rec { ./juice-cxx-packing-fix.diff ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ - fltk alsa-lib freetype libXrandr libXinerama libXcursor lv2 libjack2 + fltk + alsa-lib + freetype + libXrandr + libXinerama + libXcursor + lv2 + libjack2 ]; meta = with lib; { diff --git a/pkgs/by-name/en/ent-go/package.nix b/pkgs/by-name/en/ent-go/package.nix index acb35c912eaba9..acd896da42fea7 100644 --- a/pkgs/by-name/en/ent-go/package.nix +++ b/pkgs/by-name/en/ent-go/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "ent-go"; diff --git a/pkgs/by-name/en/ent/package.nix b/pkgs/by-name/en/ent/package.nix index 3152e00503bb3d..9cf35294a41f0e 100644 --- a/pkgs/by-name/en/ent/package.nix +++ b/pkgs/by-name/en/ent/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, unzip}: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation { pname = "ent"; diff --git a/pkgs/by-name/en/entr/package.nix b/pkgs/by-name/en/entr/package.nix index ab29aca97d4999..571557c7b75a6f 100644 --- a/pkgs/by-name/en/entr/package.nix +++ b/pkgs/by-name/en/entr/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, coreutils }: +{ + lib, + stdenv, + fetchurl, + coreutils, +}: stdenv.mkDerivation rec { pname = "entr"; @@ -26,7 +31,10 @@ stdenv.mkDerivation rec { changelog = "https://github.com/eradman/entr/raw/${version}/NEWS"; license = licenses.isc; platforms = platforms.all; - maintainers = with maintainers; [ pSub synthetica ]; + maintainers = with maintainers; [ + pSub + synthetica + ]; mainProgram = "entr"; }; } diff --git a/pkgs/by-name/en/entt/package.nix b/pkgs/by-name/en/entt/package.nix index 77033e6c67748d..c871e15d046954 100644 --- a/pkgs/by-name/en/entt/package.nix +++ b/pkgs/by-name/en/entt/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "entt"; version = "3.14.0"; diff --git a/pkgs/by-name/en/entwine/package.nix b/pkgs/by-name/en/entwine/package.nix index 0ab59737cd61c2..6331900b107cda 100644 --- a/pkgs/by-name/en/entwine/package.nix +++ b/pkgs/by-name/en/entwine/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, gitUpdater -, cmake -, pdal -, curl -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + cmake, + pdal, + curl, + openssl, }: stdenv.mkDerivation rec { @@ -29,7 +30,7 @@ stdenv.mkDerivation rec { cmake ]; - passthru.updateScript = gitUpdater {}; + passthru.updateScript = gitUpdater { }; meta = with lib; { description = "Point cloud organization for massive datasets"; diff --git a/pkgs/by-name/en/enum4linux/package.nix b/pkgs/by-name/en/enum4linux/package.nix index 4703bae488db9b..cd88688cb3c6de 100644 --- a/pkgs/by-name/en/enum4linux/package.nix +++ b/pkgs/by-name/en/enum4linux/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, samba -, perl -, openldap +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + samba, + perl, + openldap, }: stdenv.mkDerivation rec { @@ -35,7 +36,12 @@ stdenv.mkDerivation rec { cp enum4linux.pl $out/bin/enum4linux wrapProgram $out/bin/enum4linux \ - --prefix PATH : ${lib.makeBinPath [ samba openldap ]} + --prefix PATH : ${ + lib.makeBinPath [ + samba + openldap + ] + } ''; meta = with lib; { @@ -47,4 +53,3 @@ stdenv.mkDerivation rec { platforms = platforms.unix; }; } - diff --git a/pkgs/by-name/en/enumer/package.nix b/pkgs/by-name/en/enumer/package.nix index c10cfdccd91f72..ed2fe3869a6bcd 100644 --- a/pkgs/by-name/en/enumer/package.nix +++ b/pkgs/by-name/en/enumer/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/en/enumerepo/package.nix b/pkgs/by-name/en/enumerepo/package.nix index 3c6849af44ff0c..a97320dc350195 100644 --- a/pkgs/by-name/en/enumerepo/package.nix +++ b/pkgs/by-name/en/enumerepo/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/en/envconsul/package.nix b/pkgs/by-name/en/envconsul/package.nix index f3e5609d9abd9a..202832ea3ba702 100644 --- a/pkgs/by-name/en/envconsul/package.nix +++ b/pkgs/by-name/en/envconsul/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, envconsul }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + envconsul, +}: buildGoModule rec { pname = "envconsul"; diff --git a/pkgs/by-name/en/envfs/package.nix b/pkgs/by-name/en/envfs/package.nix index c5de89fdfffd67..69d6a67bc48fd8 100644 --- a/pkgs/by-name/en/envfs/package.nix +++ b/pkgs/by-name/en/envfs/package.nix @@ -1,4 +1,9 @@ -{ rustPlatform, lib, fetchFromGitHub, nixosTests }: +{ + rustPlatform, + lib, + fetchFromGitHub, + nixosTests, +}: rustPlatform.buildRustPackage rec { pname = "envfs"; version = "1.0.6"; diff --git a/pkgs/by-name/en/envsubst/package.nix b/pkgs/by-name/en/envsubst/package.nix index 8fc8ff2bb2d761..ddd786cc5ce95b 100644 --- a/pkgs/by-name/en/envsubst/package.nix +++ b/pkgs/by-name/en/envsubst/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "envsubst"; diff --git a/pkgs/by-name/en/envypn-font/package.nix b/pkgs/by-name/en/envypn-font/package.nix index fc69e398e44d5e..d0b6867f39c163 100644 --- a/pkgs/by-name/en/envypn-font/package.nix +++ b/pkgs/by-name/en/envypn-font/package.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, fetchurl, libfaketime -, xorg +{ + lib, + stdenv, + fetchurl, + libfaketime, + xorg, }: stdenv.mkDerivation rec { @@ -11,7 +15,11 @@ stdenv.mkDerivation rec { sha256 = "bda67b6bc6d5d871a4d46565d4126729dfb8a0de9611dae6c68132a7b7db1270"; }; - nativeBuildInputs = [ libfaketime xorg.fonttosfnt xorg.mkfontscale ]; + nativeBuildInputs = [ + libfaketime + xorg.fonttosfnt + xorg.mkfontscale + ]; unpackPhase = '' tar -xzf $src --strip-components=1 diff --git a/pkgs/by-name/eo/eog/package.nix b/pkgs/by-name/eo/eog/package.nix index 527b8a6d72cded..1c8e35193f4fe0 100644 --- a/pkgs/by-name/eo/eog/package.nix +++ b/pkgs/by-name/eo/eog/package.nix @@ -1,40 +1,45 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, gettext -, itstool -, pkg-config -, libxml2 -, libjpeg -, libpeas -, libportal-gtk3 -, gnome -, gtk3 -, libhandy -, glib -, gsettings-desktop-schemas -, gnome-desktop -, lcms2 -, gdk-pixbuf -, exempi -, shared-mime-info -, wrapGAppsHook3 -, libjxl -, librsvg -, webp-pixbuf-loader -, libheif -, libexif -, gobject-introspection -, gi-docgen +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + gettext, + itstool, + pkg-config, + libxml2, + libjpeg, + libpeas, + libportal-gtk3, + gnome, + gtk3, + libhandy, + glib, + gsettings-desktop-schemas, + gnome-desktop, + lcms2, + gdk-pixbuf, + exempi, + shared-mime-info, + wrapGAppsHook3, + libjxl, + librsvg, + webp-pixbuf-loader, + libheif, + libexif, + gobject-introspection, + gi-docgen, }: stdenv.mkDerivation rec { pname = "eog"; version = "47.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/eog/${lib.versions.major version}/eog-${version}.tar.xz"; @@ -84,14 +89,16 @@ stdenv.mkDerivation rec { postInstall = '' # Pull in WebP and JXL support for gnome-backgrounds. # In postInstall to run before gappsWrapperArgsHook. - export GDK_PIXBUF_MODULE_FILE="${gnome._gdkPixbufCacheBuilder_DO_NOT_USE { - extraLoaders = [ - libjxl - librsvg - webp-pixbuf-loader - libheif.out - ]; - }}" + export GDK_PIXBUF_MODULE_FILE="${ + gnome._gdkPixbufCacheBuilder_DO_NOT_USE { + extraLoaders = [ + libjxl + librsvg + webp-pixbuf-loader + libheif.out + ]; + } + }" ''; preFixup = '' diff --git a/pkgs/by-name/eo/eolie/package.nix b/pkgs/by-name/eo/eolie/package.nix index 6b68cbb4a02722..bf691b1a42c0a3 100644 --- a/pkgs/by-name/eo/eolie/package.nix +++ b/pkgs/by-name/eo/eolie/package.nix @@ -1,7 +1,24 @@ -{ lib, fetchgit, meson, ninja, pkg-config, nix-update-script -, python3, gtk3, libsecret, gst_all_1, webkitgtk_4_0, glib -, glib-networking, gtkspell3, hunspell, desktop-file-utils -, gobject-introspection, wrapGAppsHook3, gnome-settings-daemon }: +{ + lib, + fetchgit, + meson, + ninja, + pkg-config, + nix-update-script, + python3, + gtk3, + libsecret, + gst_all_1, + webkitgtk_4_0, + glib, + glib-networking, + gtkspell3, + hunspell, + desktop-file-utils, + gobject-introspection, + wrapGAppsHook3, + gnome-settings-daemon, +}: python3.pkgs.buildPythonApplication rec { pname = "eolie"; @@ -73,7 +90,7 @@ python3.pkgs.buildPythonApplication rec { description = "New GNOME web browser"; mainProgram = "eolie"; homepage = "https://gitlab.gnome.org/World/eolie"; - license = licenses.gpl3Plus; + license = licenses.gpl3Plus; maintainers = with maintainers; [ samdroid-apps ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/eo/eos-installer/package.nix b/pkgs/by-name/eo/eos-installer/package.nix index 5d4ea2e8c60c90..9bdfbccf6a1dcf 100644 --- a/pkgs/by-name/eo/eos-installer/package.nix +++ b/pkgs/by-name/eo/eos-installer/package.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, writeText -, glib, meson, ninja, pkg-config, python3 -, coreutils, gnome-desktop, gnupg, gtk3, systemdMinimal, udisks +{ + lib, + stdenv, + fetchFromGitHub, + writeText, + glib, + meson, + ninja, + pkg-config, + python3, + coreutils, + gnome-desktop, + gnupg, + gtk3, + systemdMinimal, + udisks, }: stdenv.mkDerivation rec { @@ -17,9 +30,19 @@ stdenv.mkDerivation rec { strictDeps = true; nativeBuildInputs = [ - glib gnupg meson ninja pkg-config python3 + glib + gnupg + meson + ninja + pkg-config + python3 + ]; + buildInputs = [ + gnome-desktop + gtk3 + systemdMinimal + udisks ]; - buildInputs = [ gnome-desktop gtk3 systemdMinimal udisks ]; preConfigure = '' patchShebangs tests diff --git a/pkgs/by-name/eo/eot_utilities/package.nix b/pkgs/by-name/eo/eot_utilities/package.nix index bb9279687b1bc1..0de37da5c83d22 100644 --- a/pkgs/by-name/eo/eot_utilities/package.nix +++ b/pkgs/by-name/eo/eot_utilities/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, pkg-config }: +{ + lib, + stdenv, + fetchurl, + pkg-config, +}: stdenv.mkDerivation rec { pname = "eot_utilities"; diff --git a/pkgs/by-name/ep/epeg/package.nix b/pkgs/by-name/ep/epeg/package.nix index 8134771f5688df..6f02069ab7311c 100644 --- a/pkgs/by-name/ep/epeg/package.nix +++ b/pkgs/by-name/ep/epeg/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, libtool, autoconf, automake -, libjpeg, libexif +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libtool, + autoconf, + automake, + libjpeg, + libexif, }: stdenv.mkDerivation rec { @@ -15,9 +23,17 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - nativeBuildInputs = [ pkg-config libtool autoconf automake ]; + nativeBuildInputs = [ + pkg-config + libtool + autoconf + automake + ]; - propagatedBuildInputs = [ libjpeg libexif ]; + propagatedBuildInputs = [ + libjpeg + libexif + ]; preConfigure = '' ./autogen.sh diff --git a/pkgs/by-name/ep/epgstation/package.nix b/pkgs/by-name/ep/epgstation/package.nix index 63c1e050e7de16..5d71ece6e0cc51 100644 --- a/pkgs/by-name/ep/epgstation/package.nix +++ b/pkgs/by-name/ep/epgstation/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchpatch -, fetchFromGitHub -, buildNpmPackage -, installShellFiles -, makeWrapper -, bash -, nodejs -, python3 +{ + lib, + fetchpatch, + fetchFromGitHub, + buildNpmPackage, + installShellFiles, + makeWrapper, + bash, + nodejs, + python3, }: buildNpmPackage rec { @@ -39,11 +40,20 @@ buildNpmPackage rec { npmRootPath = "/lib/node_modules/epgstation"; buildInputs = [ bash ]; - nativeBuildInputs = [ installShellFiles makeWrapper python3 ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + python3 + ]; clientDir = buildNpmPackage { pname = "${pname}-client"; - inherit version src installPhase meta; + inherit + version + src + installPhase + meta + ; npmDepsHash = "sha256-a/cDPABWI4lPxvSOI4D90O71A9lm8icPMak/g6DPYQY="; npmRootPath = ""; @@ -75,7 +85,10 @@ buildNpmPackage rec { postInstall = let - runtimeDeps = [ nodejs bash ]; + runtimeDeps = [ + nodejs + bash + ]; in '' mkdir -p $out/{bin,libexec,share/doc/epgstation} diff --git a/pkgs/by-name/ep/ephemeral/package.nix b/pkgs/by-name/ep/ephemeral/package.nix index 5036f0c6265e15..2d755b3ee37138 100644 --- a/pkgs/by-name/ep/ephemeral/package.nix +++ b/pkgs/by-name/ep/ephemeral/package.nix @@ -1,21 +1,23 @@ -{ lib, stdenv -, fetchFromGitHub -, nix-update-script -, desktop-file-utils -, vala -, gettext -, glib -, gtk3 -, libgee -, libdazzle -, meson -, ninja -, pantheon -, pkg-config -, python3 -, webkitgtk_4_0 -, wrapGAppsHook3 -, glib-networking +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + desktop-file-utils, + vala, + gettext, + glib, + gtk3, + libgee, + libdazzle, + meson, + ninja, + pantheon, + pkg-config, + python3, + webkitgtk_4_0, + wrapGAppsHook3, + glib-networking, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ep/ephemeralpg/package.nix b/pkgs/by-name/ep/ephemeralpg/package.nix index b50d22d76e78f2..59ddbab10ec8ae 100644 --- a/pkgs/by-name/ep/ephemeralpg/package.nix +++ b/pkgs/by-name/ep/ephemeralpg/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, postgresql, getopt, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + postgresql, + getopt, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "ephemeralpg"; version = "3.3"; @@ -10,13 +17,21 @@ stdenv.mkDerivation rec { installPhase = '' mkdir -p $out PREFIX=$out make install - wrapProgram $out/bin/pg_tmp --prefix PATH : ${lib.makeBinPath [ postgresql getopt ]} + wrapProgram $out/bin/pg_tmp --prefix PATH : ${ + lib.makeBinPath [ + postgresql + getopt + ] + } ''; meta = with lib; { description = "Run tests on an isolated, temporary PostgreSQL database"; license = licenses.isc; homepage = "https://eradman.com/ephemeralpg/"; platforms = platforms.all; - maintainers = with maintainers; [ hrdinka medv ]; + maintainers = with maintainers; [ + hrdinka + medv + ]; }; } diff --git a/pkgs/by-name/ep/epilys-bb/package.nix b/pkgs/by-name/ep/epilys-bb/package.nix index e368c7c9ec483a..c30a2865f6934f 100644 --- a/pkgs/by-name/ep/epilys-bb/package.nix +++ b/pkgs/by-name/ep/epilys-bb/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "epilys-bb"; diff --git a/pkgs/by-name/ep/epiphany/package.nix b/pkgs/by-name/ep/epiphany/package.nix index 435e81e065c492..af5c0efec06161 100644 --- a/pkgs/by-name/ep/epiphany/package.nix +++ b/pkgs/by-name/ep/epiphany/package.nix @@ -1,37 +1,38 @@ -{ lib -, stdenv -, meson -, ninja -, gettext -, fetchurl -, pkg-config -, gtk4 -, glib -, icu -, wrapGAppsHook4 -, gnome -, libportal-gtk4 -, libxml2 -, itstool -, webkitgtk_6_0 -, libsoup_3 -, glib-networking -, libsecret -, gnome-desktop -, libarchive -, p11-kit -, sqlite -, gcr_4 -, isocodes -, desktop-file-utils -, nettle -, gdk-pixbuf -, gst_all_1 -, json-glib -, libadwaita -, buildPackages -, withPantheon ? false -, pantheon +{ + lib, + stdenv, + meson, + ninja, + gettext, + fetchurl, + pkg-config, + gtk4, + glib, + icu, + wrapGAppsHook4, + gnome, + libportal-gtk4, + libxml2, + itstool, + webkitgtk_6_0, + libsoup_3, + glib-networking, + libsecret, + gnome-desktop, + libarchive, + p11-kit, + sqlite, + gcr_4, + isocodes, + desktop-file-utils, + nettle, + gdk-pixbuf, + gst_all_1, + json-glib, + libadwaita, + buildPackages, + withPantheon ? false, + pantheon, }: stdenv.mkDerivation (finalAttrs: { @@ -55,42 +56,46 @@ stdenv.mkDerivation (finalAttrs: { buildPackages.gtk4 ]; - buildInputs = [ - gcr_4 - gdk-pixbuf - glib - glib-networking - gnome-desktop - gst_all_1.gst-libav - gst_all_1.gst-plugins-bad - gst_all_1.gst-plugins-base - gst_all_1.gst-plugins-good - gst_all_1.gst-plugins-ugly - gst_all_1.gstreamer - gtk4 - icu - isocodes - json-glib - libadwaita - libportal-gtk4 - libarchive - libsecret - libsoup_3 - libxml2 - nettle - p11-kit - sqlite - webkitgtk_6_0 - ] ++ lib.optionals withPantheon [ - pantheon.granite7 - ]; + buildInputs = + [ + gcr_4 + gdk-pixbuf + glib + glib-networking + gnome-desktop + gst_all_1.gst-libav + gst_all_1.gst-plugins-bad + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-good + gst_all_1.gst-plugins-ugly + gst_all_1.gstreamer + gtk4 + icu + isocodes + json-glib + libadwaita + libportal-gtk4 + libarchive + libsecret + libsoup_3 + libxml2 + nettle + p11-kit + sqlite + webkitgtk_6_0 + ] + ++ lib.optionals withPantheon [ + pantheon.granite7 + ]; # Tests need an X display - mesonFlags = [ - "-Dunit_tests=disabled" - ] ++ lib.optionals withPantheon [ - "-Dgranite=enabled" - ]; + mesonFlags = + [ + "-Dunit_tests=disabled" + ] + ++ lib.optionals withPantheon [ + "-Dgranite=enabled" + ]; passthru = { updateScript = gnome.updateScript { diff --git a/pkgs/by-name/ep/eplot/package.nix b/pkgs/by-name/ep/eplot/package.nix index 2e69bc8a263729..a3b9221398b252 100644 --- a/pkgs/by-name/ep/eplot/package.nix +++ b/pkgs/by-name/ep/eplot/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, gnuplot, ruby }: +{ + lib, + stdenv, + fetchurl, + gnuplot, + ruby, +}: stdenv.mkDerivation { pname = "eplot"; @@ -47,6 +53,9 @@ stdenv.mkDerivation { homepage = "https://perso.liris.cnrs.fr/christian.wolf/software/eplot/"; license = licenses.gpl2Plus; platforms = platforms.all; - maintainers = with maintainers; [ bjornfor shamilton ]; + maintainers = with maintainers; [ + bjornfor + shamilton + ]; }; } diff --git a/pkgs/by-name/ep/epm/package.nix b/pkgs/by-name/ep/epm/package.nix index 93a6a6d7343b7c..9d9c070e8c55eb 100644 --- a/pkgs/by-name/ep/epm/package.nix +++ b/pkgs/by-name/ep/epm/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, rpm +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + rpm, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ep/epoll-shim/package.nix b/pkgs/by-name/ep/epoll-shim/package.nix index 63deaaf9df9edb..42fe6cea9c6ed1 100644 --- a/pkgs/by-name/ep/epoll-shim/package.nix +++ b/pkgs/by-name/ep/epoll-shim/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ep/epr/package.nix b/pkgs/by-name/ep/epr/package.nix index 5728972f2bd84b..0cdda2e4553557 100644 --- a/pkgs/by-name/ep/epr/package.nix +++ b/pkgs/by-name/ep/epr/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "epr"; diff --git a/pkgs/by-name/ep/epson-201106w/package.nix b/pkgs/by-name/ep/epson-201106w/package.nix index a5a32644c3a5da..9b50ae13ab2739 100644 --- a/pkgs/by-name/ep/epson-201106w/package.nix +++ b/pkgs/by-name/ep/epson-201106w/package.nix @@ -1,77 +1,96 @@ -{ lib, stdenv, fetchurl, rpmextract, autoreconfHook, file, libjpeg, cups }: +{ + lib, + stdenv, + fetchurl, + rpmextract, + autoreconfHook, + file, + libjpeg, + cups, +}: let version = "1.0.1"; filterVersion = "1.0.0"; in - stdenv.mkDerivation { +stdenv.mkDerivation { - pname = "epson-201106w"; - inherit version; + pname = "epson-201106w"; + inherit version; - src = fetchurl { - # NOTE: Don't forget to update the webarchive link too! - urls = [ - "https://download.ebz.epson.net/dsc/op/stable/SRPMS/epson-inkjet-printer-201106w-${version}-1lsb3.2.src.rpm" - "https://web.archive.org/web/https://download.ebz.epson.net/dsc/op/stable/SRPMS/epson-inkjet-printer-201106w-${version}-1lsb3.2.src.rpm" - ]; + src = fetchurl { + # NOTE: Don't forget to update the webarchive link too! + urls = [ + "https://download.ebz.epson.net/dsc/op/stable/SRPMS/epson-inkjet-printer-201106w-${version}-1lsb3.2.src.rpm" + "https://web.archive.org/web/https://download.ebz.epson.net/dsc/op/stable/SRPMS/epson-inkjet-printer-201106w-${version}-1lsb3.2.src.rpm" + ]; - sha256 = "1yig1xrh1ikblbp7sx706n5nnc237wy4mbch23ymy6akbgqg4aig"; - }; + sha256 = "1yig1xrh1ikblbp7sx706n5nnc237wy4mbch23ymy6akbgqg4aig"; + }; - nativeBuildInputs = [ rpmextract autoreconfHook file ]; + nativeBuildInputs = [ + rpmextract + autoreconfHook + file + ]; - buildInputs = [ libjpeg cups ]; + buildInputs = [ + libjpeg + cups + ]; - unpackPhase = '' - rpmextract $src - tar -zxf epson-inkjet-printer-201106w-${version}.tar.gz - tar -zxf epson-inkjet-printer-filter-${filterVersion}.tar.gz - for ppd in epson-inkjet-printer-201106w-${version}/ppds/*; do - substituteInPlace $ppd --replace "/opt/epson-inkjet-printer-201106w" "$out" - substituteInPlace $ppd --replace "/cups/lib" "/lib/cups" - done - cd epson-inkjet-printer-filter-${filterVersion} - ''; + unpackPhase = '' + rpmextract $src + tar -zxf epson-inkjet-printer-201106w-${version}.tar.gz + tar -zxf epson-inkjet-printer-filter-${filterVersion}.tar.gz + for ppd in epson-inkjet-printer-201106w-${version}/ppds/*; do + substituteInPlace $ppd --replace "/opt/epson-inkjet-printer-201106w" "$out" + substituteInPlace $ppd --replace "/cups/lib" "/lib/cups" + done + cd epson-inkjet-printer-filter-${filterVersion} + ''; - preConfigure = '' - chmod +x configure - export LDFLAGS="$LDFLAGS -Wl,--no-as-needed" - ''; + preConfigure = '' + chmod +x configure + export LDFLAGS="$LDFLAGS -Wl,--no-as-needed" + ''; - postInstall = '' - cd ../epson-inkjet-printer-201106w-${version} - cp -a lib64 resource watermark $out - mkdir -p $out/share/cups/model/epson-inkjet-printer-201106w - cp -a ppds $out/share/cups/model/epson-inkjet-printer-201106w/ - cp -a Manual.txt $out/doc/ - cp -a README $out/doc/README.driver - ''; + postInstall = '' + cd ../epson-inkjet-printer-201106w-${version} + cp -a lib64 resource watermark $out + mkdir -p $out/share/cups/model/epson-inkjet-printer-201106w + cp -a ppds $out/share/cups/model/epson-inkjet-printer-201106w/ + cp -a Manual.txt $out/doc/ + cp -a README $out/doc/README.driver + ''; - meta = with lib; { - homepage = "https://www.openprinting.org/driver/epson-201106w"; - description = "Epson printer driver (BX535WD, BX630FW, BX635FWD, ME940FW, NX530, NX635, NX635, SX535WD, WorkForce 545, WorkForce 645"; - longDescription = '' - This software is a filter program used with the Common UNIX Printing - System (CUPS) under Linux. It supplies high quality printing with - Seiko Epson Color Ink Jet Printers. - List of printers supported by this package: - Epson BX535WD Series - Epson BX630FW Series - Epson BX635FWD Series - Epson ME940FW Series - Epson NX530 Series - Epson SX535WD Series - Epson WorkForce 545 Series - Epson WorkForce 645 Series - To use the driver adjust your configuration.nix file: - services.printing = { - enable = true; - drivers = [ pkgs.epson-201106w ]; - }; - ''; - license = with licenses; [ lgpl21 epson ]; - platforms = platforms.linux; - maintainers = [ maintainers.nphilou ]; - }; - } + meta = with lib; { + homepage = "https://www.openprinting.org/driver/epson-201106w"; + description = "Epson printer driver (BX535WD, BX630FW, BX635FWD, ME940FW, NX530, NX635, NX635, SX535WD, WorkForce 545, WorkForce 645"; + longDescription = '' + This software is a filter program used with the Common UNIX Printing + System (CUPS) under Linux. It supplies high quality printing with + Seiko Epson Color Ink Jet Printers. + List of printers supported by this package: + Epson BX535WD Series + Epson BX630FW Series + Epson BX635FWD Series + Epson ME940FW Series + Epson NX530 Series + Epson SX535WD Series + Epson WorkForce 545 Series + Epson WorkForce 645 Series + To use the driver adjust your configuration.nix file: + services.printing = { + enable = true; + drivers = [ pkgs.epson-201106w ]; + }; + ''; + license = with licenses; [ + lgpl21 + epson + ]; + platforms = platforms.linux; + maintainers = [ maintainers.nphilou ]; + }; +} diff --git a/pkgs/by-name/ep/epson-201401w/package.nix b/pkgs/by-name/ep/epson-201401w/package.nix index cffa631cfe33ab..58c27cbeecc970 100644 --- a/pkgs/by-name/ep/epson-201401w/package.nix +++ b/pkgs/by-name/ep/epson-201401w/package.nix @@ -1,9 +1,19 @@ -{ lib, stdenv, fetchurl, rpmextract, autoreconfHook, file, libjpeg, cups }: +{ + lib, + stdenv, + fetchurl, + rpmextract, + autoreconfHook, + file, + libjpeg, + cups, +}: let version = "1.0.0"; filterVersion = "1.0.0"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "epson-201401w"; inherit version; @@ -17,9 +27,16 @@ in stdenv.mkDerivation { }; patches = [ ./fixbuild.patch ]; - nativeBuildInputs = [ rpmextract autoreconfHook file ]; + nativeBuildInputs = [ + rpmextract + autoreconfHook + file + ]; - buildInputs = [ libjpeg cups ]; + buildInputs = [ + libjpeg + cups + ]; unpackPhase = '' rpmextract $src @@ -47,8 +64,7 @@ in stdenv.mkDerivation { meta = with lib; { homepage = "https://www.openprinting.org/driver/epson-201401w"; - description = - "Epson printer driver (L456, L455, L366, L365, L362, L360, L312, L310, L222, L220, L132, L130)"; + description = "Epson printer driver (L456, L455, L366, L365, L362, L360, L312, L310, L222, L220, L132, L130)"; longDescription = '' This software is a filter program used with the Common UNIX Printing System (CUPS) under Linux. It supplies high quality printing with @@ -60,7 +76,10 @@ in stdenv.mkDerivation { drivers = [ pkgs.epson-201401w ]; }; ''; - license = with licenses; [ lgpl21 epson ]; + license = with licenses; [ + lgpl21 + epson + ]; platforms = platforms.linux; maintainers = [ maintainers.lunarequest ]; }; diff --git a/pkgs/by-name/ep/epson-alc1100/package.nix b/pkgs/by-name/ep/epson-alc1100/package.nix index f39fb0ad17045d..3008665ce6833c 100644 --- a/pkgs/by-name/ep/epson-alc1100/package.nix +++ b/pkgs/by-name/ep/epson-alc1100/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, cups, pkgsi686Linux, dpkg, psutils, makeWrapper, ghostscript, bash }: +{ + lib, + stdenv, + fetchurl, + cups, + pkgsi686Linux, + dpkg, + psutils, + makeWrapper, + ghostscript, + bash, +}: let version = "1.2-0"; @@ -8,65 +19,84 @@ let sha256 = "10f8zcmqaa7skvg2bz94mnlgqpan4iscvi8913r6iawjh7hiisjy"; }; in - stdenv.mkDerivation { - pname = "epson-alc1100"; - inherit version; +stdenv.mkDerivation { + pname = "epson-alc1100"; + inherit version; - src = fetchurl { - url = "https://download3.ebz.epson.net/dsc/f/03/00/11/33/07/4027e99517b5c388d444b8444d719b4b77f7e9db/Epson-ALC1100-filter-1.2.tar.gz"; - sha256 = "1dfw75a3kj2aa4iicvlk9kz3jarrsikpnpd4cdpw79scfc5mwm2p"; - }; + src = fetchurl { + url = "https://download3.ebz.epson.net/dsc/f/03/00/11/33/07/4027e99517b5c388d444b8444d719b4b77f7e9db/Epson-ALC1100-filter-1.2.tar.gz"; + sha256 = "1dfw75a3kj2aa4iicvlk9kz3jarrsikpnpd4cdpw79scfc5mwm2p"; + }; - patches = [ ./cups-data-dir.patch ./ppd.patch ]; + patches = [ + ./cups-data-dir.patch + ./ppd.patch + ]; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; - buildInputs = [ cups pkgsi686Linux.glibc psutils ghostscript bash ]; + buildInputs = [ + cups + pkgsi686Linux.glibc + psutils + ghostscript + bash + ]; - postUnpack = '' - dpkg -x ${libstdcpp5} libstdcpp5_i386; + postUnpack = '' + dpkg -x ${libstdcpp5} libstdcpp5_i386; - mkdir -p $out/lib; + mkdir -p $out/lib; - mv libstdcpp5_i386/usr/lib/* $out/lib; - ''; + mv libstdcpp5_i386/usr/lib/* $out/lib; + ''; - postFixup = '' - patchelf --set-interpreter ${pkgsi686Linux.glibc}/lib/ld-linux.so.2 \ - --set-rpath "${lib.makeLibraryPath [ + postFixup = '' + patchelf --set-interpreter ${pkgsi686Linux.glibc}/lib/ld-linux.so.2 \ + --set-rpath "${ + lib.makeLibraryPath [ pkgsi686Linux.glibc "$out" - ]}" $out/bin/alc1100 - - patchelf --set-rpath "${lib.makeLibraryPath [ - pkgsi686Linux.glibc - ]}" $out/lib/libstdc++.so.5.0.7 - - wrapProgram $out/bin/alc1100_lprwrapper.sh \ - --suffix PATH : "\$PATH:${psutils}/bin:/var/lib/cups/path/bin" - - wrapProgram $out/bin/pstoalc1100.sh \ - --suffix PATH : "\$PATH:${psutils}/bin:${ghostscript}/bin:${bash}/bin:/var/lib/cups/path/bin" + ] + }" $out/bin/alc1100 + + patchelf --set-rpath "${ + lib.makeLibraryPath [ + pkgsi686Linux.glibc + ] + }" $out/lib/libstdc++.so.5.0.7 + + wrapProgram $out/bin/alc1100_lprwrapper.sh \ + --suffix PATH : "\$PATH:${psutils}/bin:/var/lib/cups/path/bin" + + wrapProgram $out/bin/pstoalc1100.sh \ + --suffix PATH : "\$PATH:${psutils}/bin:${ghostscript}/bin:${bash}/bin:/var/lib/cups/path/bin" + ''; + + meta = with lib; { + homepage = "http://download.ebz.epson.net/dsc/search/01/search/"; + description = "Epson AcuLaser C1100 Driver"; + longDescription = '' + This package provides a print filter for printing to EPSON AL-C1100 + printers on Linux systems. + + To use the driver adjust your configuration.nix file: + services.printing = { + enable = true; + drivers = [ pkgs.epson-alc1100 ]; + }; ''; - meta = with lib; { - homepage = "http://download.ebz.epson.net/dsc/search/01/search/"; - description = "Epson AcuLaser C1100 Driver"; - longDescription = '' - This package provides a print filter for printing to EPSON AL-C1100 - printers on Linux systems. - - To use the driver adjust your configuration.nix file: - services.printing = { - enable = true; - drivers = [ pkgs.epson-alc1100 ]; - }; - ''; - - sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = with licenses; [ mit eapl ]; - maintainers = [ maintainers.eperuffo ]; - platforms = platforms.linux; - }; - - } + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; + license = with licenses; [ + mit + eapl + ]; + maintainers = [ maintainers.eperuffo ]; + platforms = platforms.linux; + }; + +} diff --git a/pkgs/by-name/ep/epson-workforce-635-nx625-series/package.nix b/pkgs/by-name/ep/epson-workforce-635-nx625-series/package.nix index 7a467ac1ad393f..9825300d813f08 100644 --- a/pkgs/by-name/ep/epson-workforce-635-nx625-series/package.nix +++ b/pkgs/by-name/ep/epson-workforce-635-nx625-series/package.nix @@ -1,6 +1,11 @@ { - autoreconfHook, cups, libjpeg, rpmextract, - fetchurl, lib, stdenv + autoreconfHook, + cups, + libjpeg, + rpmextract, + fetchurl, + lib, + stdenv, }: let @@ -8,7 +13,8 @@ let filter = "epson-inkjet-printer-filter-1.0.0"; driver = "epson-inkjet-printer-workforce-635-nx625-series-1.0.1"; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "epson-inkjet-printer-workforce-635-nx625-series"; version = "1.0.1"; @@ -22,8 +28,14 @@ in stdenv.mkDerivation rec { }; sourceRoot = srcdirs.filter; - nativeBuildInputs = [ autoreconfHook rpmextract ]; - buildInputs = [ cups libjpeg ]; + nativeBuildInputs = [ + autoreconfHook + rpmextract + ]; + buildInputs = [ + cups + libjpeg + ]; unpackPhase = '' rpmextract "$src" @@ -39,13 +51,17 @@ in stdenv.mkDerivation rec { installPhase = let filterdir = "$out/cups/lib/filter"; - docdir = "$out/share/doc"; - ppddir = "$out/share/cups/model/${pname}"; + docdir = "$out/share/doc"; + ppddir = "$out/share/cups/model/${pname}"; libdir = - if stdenv.system == "x86_64-linux" then "lib64" - else if stdenv.system == "i686_linux" then "lib" - else throw "other platforms than i686_linux and x86_64-linux are not yet supported"; - in '' + if stdenv.system == "x86_64-linux" then + "lib64" + else if stdenv.system == "i686_linux" then + "lib" + else + throw "other platforms than i686_linux and x86_64-linux are not yet supported"; + in + '' mkdir -p "$out" "${docdir}" "${filterdir}" "${ppddir}" cp src/epson_inkjet_printer_filter "${filterdir}" @@ -95,8 +111,14 @@ in stdenv.mkDerivation rec { }; ''; downloadPage = "https://download.ebz.epson.net/dsc/du/02/DriverDownloadInfo.do?LG2=EN&CN2=&DSCMI=16857&DSCCHK=4334d3487503d7f916ccf5d58071b05b7687294f"; - license = with lib.licenses; [ lgpl21 epson ]; + license = with lib.licenses; [ + lgpl21 + epson + ]; maintainers = [ lib.maintainers.jorsn ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/by-name/ep/epson_201207w/package.nix b/pkgs/by-name/ep/epson_201207w/package.nix index d5c57b35c32e83..c5fac4e37bf859 100644 --- a/pkgs/by-name/ep/epson_201207w/package.nix +++ b/pkgs/by-name/ep/epson_201207w/package.nix @@ -1,77 +1,96 @@ -{ lib, stdenv, fetchurl, rpmextract, autoreconfHook, file, libjpeg, cups }: +{ + lib, + stdenv, + fetchurl, + rpmextract, + autoreconfHook, + file, + libjpeg, + cups, +}: let version = "1.0.0"; in - stdenv.mkDerivation { +stdenv.mkDerivation { - pname = "epson_201207w"; - inherit version; + pname = "epson_201207w"; + inherit version; - src = fetchurl { - # NOTE: Don't forget to update the webarchive link too! - urls = [ - "https://download.ebz.epson.net/dsc/op/stable/SRPMS/epson-inkjet-printer-201207w-${version}-1lsb3.2.src.rpm" - "https://web.archive.org/web/https://download.ebz.epson.net/dsc/op/stable/SRPMS/epson-inkjet-printer-201207w-${version}-1lsb3.2.src.rpm" - ]; - sha256 = "1ixnhn2dk83nh9v8sdivzgc2bm9z2phvsbx8bc6ainbjq6vn7lns"; - }; + src = fetchurl { + # NOTE: Don't forget to update the webarchive link too! + urls = [ + "https://download.ebz.epson.net/dsc/op/stable/SRPMS/epson-inkjet-printer-201207w-${version}-1lsb3.2.src.rpm" + "https://web.archive.org/web/https://download.ebz.epson.net/dsc/op/stable/SRPMS/epson-inkjet-printer-201207w-${version}-1lsb3.2.src.rpm" + ]; + sha256 = "1ixnhn2dk83nh9v8sdivzgc2bm9z2phvsbx8bc6ainbjq6vn7lns"; + }; - nativeBuildInputs = [ rpmextract autoreconfHook file ]; + nativeBuildInputs = [ + rpmextract + autoreconfHook + file + ]; - buildInputs = [ libjpeg cups ]; + buildInputs = [ + libjpeg + cups + ]; - unpackPhase = '' - rpmextract $src - tar -zxf epson-inkjet-printer-201207w-${version}.tar.gz - tar -zxf epson-inkjet-printer-filter-${version}.tar.gz - for ppd in epson-inkjet-printer-201207w-${version}/ppds/*; do - substituteInPlace $ppd --replace "/opt/epson-inkjet-printer-201207w" "$out" - substituteInPlace $ppd --replace "/cups/lib" "/lib/cups" - done - cd epson-inkjet-printer-filter-${version} - ''; + unpackPhase = '' + rpmextract $src + tar -zxf epson-inkjet-printer-201207w-${version}.tar.gz + tar -zxf epson-inkjet-printer-filter-${version}.tar.gz + for ppd in epson-inkjet-printer-201207w-${version}/ppds/*; do + substituteInPlace $ppd --replace "/opt/epson-inkjet-printer-201207w" "$out" + substituteInPlace $ppd --replace "/cups/lib" "/lib/cups" + done + cd epson-inkjet-printer-filter-${version} + ''; - preConfigure = '' - chmod +x configure - export LDFLAGS="$LDFLAGS -Wl,--no-as-needed" - ''; + preConfigure = '' + chmod +x configure + export LDFLAGS="$LDFLAGS -Wl,--no-as-needed" + ''; - postInstall = '' - cd ../epson-inkjet-printer-201207w-${version} - cp -a lib64 resource watermark $out - mkdir -p $out/share/cups/model/epson-inkjet-printer-201207w - cp -a ppds $out/share/cups/model/epson-inkjet-printer-201207w/ - cp -a Manual.txt $out/doc/ - cp -a README $out/doc/README.driver - ''; + postInstall = '' + cd ../epson-inkjet-printer-201207w-${version} + cp -a lib64 resource watermark $out + mkdir -p $out/share/cups/model/epson-inkjet-printer-201207w + cp -a ppds $out/share/cups/model/epson-inkjet-printer-201207w/ + cp -a Manual.txt $out/doc/ + cp -a README $out/doc/README.driver + ''; - meta = with lib; { - homepage = "https://www.openprinting.org/driver/epson-201207w"; - description = "Epson printer driver (L110, L210, L300, L350, L355, L550, L555)"; - longDescription = '' - This software is a filter program used with the Common UNIX Printing - System (CUPS) under Linux. It supplies high quality printing with - Seiko Epson Color Ink Jet Printers. + meta = with lib; { + homepage = "https://www.openprinting.org/driver/epson-201207w"; + description = "Epson printer driver (L110, L210, L300, L350, L355, L550, L555)"; + longDescription = '' + This software is a filter program used with the Common UNIX Printing + System (CUPS) under Linux. It supplies high quality printing with + Seiko Epson Color Ink Jet Printers. - List of printers supported by this package: - Epson L110 Series - Epson L210 Series - Epson L300 Series - Epson L350 Series - Epson L355 Series - Epson L550 Series - Epson L555 Series + List of printers supported by this package: + Epson L110 Series + Epson L210 Series + Epson L300 Series + Epson L350 Series + Epson L355 Series + Epson L550 Series + Epson L555 Series - To use the driver adjust your configuration.nix file: - services.printing = { - enable = true; - drivers = [ pkgs.epson_201207w ]; - }; - ''; - license = with licenses; [ lgpl21 epson ]; - maintainers = [ maintainers.romildo ]; - platforms = [ "x86_64-linux" ]; - }; + To use the driver adjust your configuration.nix file: + services.printing = { + enable = true; + drivers = [ pkgs.epson_201207w ]; + }; + ''; + license = with licenses; [ + lgpl21 + epson + ]; + maintainers = [ maintainers.romildo ]; + platforms = [ "x86_64-linux" ]; + }; - } +} diff --git a/pkgs/by-name/ep/epstool/package.nix b/pkgs/by-name/ep/epstool/package.nix index fadc5e62e2481a..56b38c0e37e092 100644 --- a/pkgs/by-name/ep/epstool/package.nix +++ b/pkgs/by-name/ep/epstool/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "3.09"; diff --git a/pkgs/by-name/ep/epub-thumbnailer/package.nix b/pkgs/by-name/ep/epub-thumbnailer/package.nix index 4338e037f65ec2..353f8a775bb53f 100644 --- a/pkgs/by-name/ep/epub-thumbnailer/package.nix +++ b/pkgs/by-name/ep/epub-thumbnailer/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, unstableGitUpdater +{ + lib, + python3, + fetchFromGitHub, + unstableGitUpdater, }: python3.pkgs.buildPythonApplication { diff --git a/pkgs/by-name/ep/epub2txt2/package.nix b/pkgs/by-name/ep/epub2txt2/package.nix index 586079473d5ebe..ebf3f7af15437a 100644 --- a/pkgs/by-name/ep/epub2txt2/package.nix +++ b/pkgs/by-name/ep/epub2txt2/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "epub2txt2"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-YFaXkcIdat2cn1ITYFyG1hxbbepqcxvyJ6ZzDo4dVYI="; }; - makeFlags = [ "CC:=$(CC)" "PREFIX:=$(out)" ]; + makeFlags = [ + "CC:=$(CC)" + "PREFIX:=$(out)" + ]; meta = { description = "Simple command-line utility for Linux, for extracting text from EPUB documents"; diff --git a/pkgs/by-name/ep/epubcheck/package.nix b/pkgs/by-name/ep/epubcheck/package.nix index abd2803508bb11..d3426983efa1d0 100644 --- a/pkgs/by-name/ep/epubcheck/package.nix +++ b/pkgs/by-name/ep/epubcheck/package.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchzip -, jre, makeWrapper }: +{ + lib, + stdenv, + fetchzip, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "epubcheck"; @@ -36,7 +41,12 @@ stdenv.mkDerivation rec { description = "Validation tool for EPUB"; mainProgram = "epubcheck"; sourceProvenance = with sourceTypes; [ binaryBytecode ]; - license = with licenses; [ asl20 bsd3 mpl10 w3c ]; + license = with licenses; [ + asl20 + bsd3 + mpl10 + w3c + ]; platforms = platforms.all; maintainers = with maintainers; [ eadwu ]; }; diff --git a/pkgs/by-name/ep/epy/package.nix b/pkgs/by-name/ep/epy/package.nix index 5bf3455bc48a26..3b54ee697aca21 100644 --- a/pkgs/by-name/ep/epy/package.nix +++ b/pkgs/by-name/ep/epy/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "epy"; diff --git a/pkgs/by-name/eq/eq10q/package.nix b/pkgs/by-name/eq/eq10q/package.nix index 5be1594343545b..5a6de756f6f9a8 100644 --- a/pkgs/by-name/eq/eq10q/package.nix +++ b/pkgs/by-name/eq/eq10q/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchurl, fetchpatch, cmake, fftw, gtkmm2, libxcb, lv2, pkg-config -, xorg }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + cmake, + fftw, + gtkmm2, + libxcb, + lv2, + pkg-config, + xorg, +}: stdenv.mkDerivation rec { pname = "eq10q"; version = "2.2"; @@ -8,8 +19,19 @@ stdenv.mkDerivation rec { sha256 = "16mhcav8gwkp29k9ki4dlkajlcgh1i2wvldabxb046d37dq4qzrk"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ fftw gtkmm2 libxcb lv2 xorg.libpthreadstubs xorg.libXdmcp xorg.libxshmfence ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + fftw + gtkmm2 + libxcb + lv2 + xorg.libpthreadstubs + xorg.libXdmcp + xorg.libxshmfence + ]; patches = [ (fetchpatch { @@ -20,10 +42,10 @@ stdenv.mkDerivation rec { ]; postPatch = '' - # Fix build with lv2 1.18: https://sourceforge.net/p/eq10q/bugs/23/ - find . -type f -exec fgrep -q LV2UI_Descriptor {} \; \ - -exec sed -i {} -e 's/const _\?LV2UI_Descriptor/const LV2UI_Descriptor/' \; - ''; + # Fix build with lv2 1.18: https://sourceforge.net/p/eq10q/bugs/23/ + find . -type f -exec fgrep -q LV2UI_Descriptor {} \; \ + -exec sed -i {} -e 's/const _\?LV2UI_Descriptor/const LV2UI_Descriptor/' \; + ''; installFlags = [ "DESTDIR=$(out)" ]; diff --git a/pkgs/by-name/eq/equilux-theme/package.nix b/pkgs/by-name/eq/equilux-theme/package.nix index 53e45328a8e6ae..785c3e0f68bdcb 100644 --- a/pkgs/by-name/eq/equilux-theme/package.nix +++ b/pkgs/by-name/eq/equilux-theme/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, gnome-shell, gnome-themes-extra, glib, libxml2, gtk-engine-murrine, gdk-pixbuf, librsvg, bc }: +{ + lib, + stdenv, + fetchFromGitHub, + gnome-shell, + gnome-themes-extra, + glib, + libxml2, + gtk-engine-murrine, + gdk-pixbuf, + librsvg, + bc, +}: stdenv.mkDerivation rec { pname = "equilux-theme"; @@ -11,9 +23,17 @@ stdenv.mkDerivation rec { sha256 = "0lv2yyxhnmnkwxp576wnb01id4fp734b5z5n0l67sg5z7vc2h8fc"; }; - nativeBuildInputs = [ glib libxml2 bc ]; - - buildInputs = [ gnome-themes-extra gdk-pixbuf librsvg ]; + nativeBuildInputs = [ + glib + libxml2 + bc + ]; + + buildInputs = [ + gnome-themes-extra + gdk-pixbuf + librsvg + ]; propagatedUserEnvPkgs = [ gtk-engine-murrine ]; diff --git a/pkgs/by-name/er/er-patcher/package.nix b/pkgs/by-name/er/er-patcher/package.nix index d3a02fac46b1ae..e9d3c56a1c0485 100644 --- a/pkgs/by-name/er/er-patcher/package.nix +++ b/pkgs/by-name/er/er-patcher/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, python3 +{ + lib, + stdenvNoCC, + fetchFromGitHub, + python3, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/er/erdtree/package.nix b/pkgs/by-name/er/erdtree/package.nix index 8a761416c94db7..bb9844855c7b90 100644 --- a/pkgs/by-name/er/erdtree/package.nix +++ b/pkgs/by-name/er/erdtree/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/solidiquis/erdtree"; changelog = "https://github.com/solidiquis/erdtree/releases/tag/${src.rev}"; license = licenses.mit; - maintainers = with maintainers; [ figsoda zendo ]; + maintainers = with maintainers; [ + figsoda + zendo + ]; mainProgram = "erd"; }; } diff --git a/pkgs/by-name/er/eresi/package.nix b/pkgs/by-name/er/eresi/package.nix index 192d85c5a2e990..1fa56cc97bcd97 100644 --- a/pkgs/by-name/er/eresi/package.nix +++ b/pkgs/by-name/er/eresi/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, which, openssl, readline, fetchpatch }: +{ + stdenv, + lib, + fetchFromGitHub, + which, + openssl, + readline, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "eresi"; @@ -58,14 +66,16 @@ stdenv.mkDerivation rec { dontDisableStatic = true; nativeBuildInputs = [ which ]; - buildInputs = [ openssl readline ]; + buildInputs = [ + openssl + readline + ]; enableParallelBuilding = true; # ln: failed to create symbolic link '...-eresi-0.83-a3-phoenix//bin/elfsh': No such file or directory # make: *** [Makefile:108: install64] Error 1 enableParallelInstalling = false; - installTargets = lib.singleton "install" - ++ lib.optional stdenv.hostPlatform.is64bit "install64"; + installTargets = lib.singleton "install" ++ lib.optional stdenv.hostPlatform.is64bit "install64"; meta = { description = "ERESI Reverse Engineering Software Interface"; diff --git a/pkgs/by-name/er/ergo/package.nix b/pkgs/by-name/er/ergo/package.nix index 075d4febe95a92..6eb6c6f574c103 100644 --- a/pkgs/by-name/er/ergo/package.nix +++ b/pkgs/by-name/er/ergo/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre, nixosTests }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, + nixosTests, +}: stdenv.mkDerivation rec { pname = "ergo"; diff --git a/pkgs/by-name/er/ergochat/package.nix b/pkgs/by-name/er/ergochat/package.nix index 1744361f8412d4..9f2a004d650394 100644 --- a/pkgs/by-name/er/ergochat/package.nix +++ b/pkgs/by-name/er/ergochat/package.nix @@ -1,4 +1,9 @@ -{ buildGoModule, fetchFromGitHub, lib, nixosTests }: +{ + buildGoModule, + fetchFromGitHub, + lib, + nixosTests, +}: buildGoModule rec { pname = "ergo"; @@ -21,7 +26,10 @@ buildGoModule rec { mainProgram = "ergo"; homepage = "https://github.com/ergochat/ergo"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ lassulus tv ]; + maintainers = with lib.maintainers; [ + lassulus + tv + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/er/ergoscf/package.nix b/pkgs/by-name/er/ergoscf/package.nix index ceaeb3336427de..a9afc38fc97154 100644 --- a/pkgs/by-name/er/ergoscf/package.nix +++ b/pkgs/by-name/er/ergoscf/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, blas, lapack } : +{ + lib, + stdenv, + fetchurl, + blas, + lapack, +}: stdenv.mkDerivation rec { pname = "ergoscf"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-U0NVREEZ8HI0Q0ZcbwvZsYA76PWMh7bqgDG1uaUc01c="; }; - buildInputs = [ blas lapack ]; + buildInputs = [ + blas + lapack + ]; patches = [ ./math-constants.patch ]; diff --git a/pkgs/by-name/er/ericw-tools/package.nix b/pkgs/by-name/er/ericw-tools/package.nix index 9e833eafa77059..dba4b02f9de76f 100644 --- a/pkgs/by-name/er/ericw-tools/package.nix +++ b/pkgs/by-name/er/ericw-tools/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, gtest, fmt -, cmake, ninja, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + gtest, + fmt, + cmake, + ninja, + installShellFiles, }: stdenv.mkDerivation rec { @@ -27,9 +34,17 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake ninja installShellFiles ]; + nativeBuildInputs = [ + cmake + ninja + installShellFiles + ]; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/er/erigon/package.nix b/pkgs/by-name/er/erigon/package.nix index bf65a3dce21bf9..810255b8c033b5 100644 --- a/pkgs/by-name/er/erigon/package.nix +++ b/pkgs/by-name/er/erigon/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nix-update-script }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, +}: let pname = "erigon"; @@ -40,14 +45,24 @@ buildGoModule { # Enabling silkworm also breaks the build as it requires dynamically linked libraries. # If we need it in the future, we should consider packaging silkworm and silkworm-go # as depenedencies explicitly. - tags = [ "nosqlite" "noboltdb" "nosilkworm" ]; + tags = [ + "nosqlite" + "noboltdb" + "nosilkworm" + ]; passthru.updateScript = nix-update-script { }; meta = with lib; { homepage = "https://github.com/ledgerwatch/erigon/"; description = "Ethereum node implementation focused on scalability and modularity"; - license = with licenses; [ lgpl3Plus gpl3Plus ]; - maintainers = with maintainers; [ d-xo happysalada ]; + license = with licenses; [ + lgpl3Plus + gpl3Plus + ]; + maintainers = with maintainers; [ + d-xo + happysalada + ]; }; } diff --git a/pkgs/by-name/er/eris-go/package.nix b/pkgs/by-name/er/eris-go/package.nix index 496572f9d7aac3..10c1444b79ae0f 100644 --- a/pkgs/by-name/er/eris-go/package.nix +++ b/pkgs/by-name/er/eris-go/package.nix @@ -1,9 +1,19 @@ -{ lib, stdenv, buildGoModule, fetchFromGitea, nixosTests, installShellFiles }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitea, + nixosTests, + installShellFiles, +}: buildGoModule rec { pname = "eris-go"; version = "20241028"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchFromGitea { domain = "codeberg.org"; diff --git a/pkgs/by-name/er/eriscmd/package.nix b/pkgs/by-name/er/eriscmd/package.nix index dcad67e2a8a4c8..570260dcbd6bd8 100644 --- a/pkgs/by-name/er/eriscmd/package.nix +++ b/pkgs/by-name/er/eriscmd/package.nix @@ -1,34 +1,43 @@ -{ lib, buildNimPackage, fetchFromGitea }: +{ + lib, + buildNimPackage, + fetchFromGitea, +}: -buildNimPackage (final: prev: { - pname = "eris"; - version = "20230722"; - outputs = [ "bin" "out" ]; - requiredNimVersion = 1; - src = fetchFromGitea { - domain = "codeberg.org"; - owner = "eris"; - repo = "nim-eris"; - rev = final.version; - hash = "sha256-JVl2/PmFVYuD4s9hKoQwVDKUa3PBWK5SBDEmVHVSuig="; - }; - lockFile = ./lock.json; - postInstall = '' - mkdir -p "$bin/share/recoll/filters" - mv "$bin/bin/rclerislink" "$bin/share/recoll/filters/" +buildNimPackage ( + final: prev: { + pname = "eris"; + version = "20230722"; + outputs = [ + "bin" + "out" + ]; + requiredNimVersion = 1; + src = fetchFromGitea { + domain = "codeberg.org"; + owner = "eris"; + repo = "nim-eris"; + rev = final.version; + hash = "sha256-JVl2/PmFVYuD4s9hKoQwVDKUa3PBWK5SBDEmVHVSuig="; + }; + lockFile = ./lock.json; + postInstall = '' + mkdir -p "$bin/share/recoll/filters" + mv "$bin/bin/rclerislink" "$bin/share/recoll/filters/" - mkdir -p "$bin/share/applications" - substitute "eris-open.desktop" "$bin/share/applications/eris-open.desktop"\ - --replace "Exec=eriscmd " "Exec=$bin/bin/eriscmd " + mkdir -p "$bin/share/applications" + substitute "eris-open.desktop" "$bin/share/applications/eris-open.desktop"\ + --replace "Exec=eriscmd " "Exec=$bin/bin/eriscmd " - install -D "eris-link.xml" -t "$bin/share/mime/packages" - install -D "eris48.png" "$bin/share/icons/hicolor/48x48/apps/eris.png" - ''; - meta = final.src.meta // { - homepage = "https://codeberg.org/eris/nim-eris"; - license = lib.licenses.unlicense; - maintainers = with lib.maintainers; [ ehmry ]; - mainProgram = "eriscmd"; - badPlatforms = lib.platforms.darwin; - }; -}) + install -D "eris-link.xml" -t "$bin/share/mime/packages" + install -D "eris48.png" "$bin/share/icons/hicolor/48x48/apps/eris.png" + ''; + meta = final.src.meta // { + homepage = "https://codeberg.org/eris/nim-eris"; + license = lib.licenses.unlicense; + maintainers = with lib.maintainers; [ ehmry ]; + mainProgram = "eriscmd"; + badPlatforms = lib.platforms.darwin; + }; + } +) diff --git a/pkgs/by-name/er/erosmb/package.nix b/pkgs/by-name/er/erosmb/package.nix index f03e9a958de206..abb3f08474baf2 100644 --- a/pkgs/by-name/er/erosmb/package.nix +++ b/pkgs/by-name/er/erosmb/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/er/errbot/package.nix b/pkgs/by-name/er/errbot/package.nix index cf8897b444f2fd..8ff4c4cf431a57 100644 --- a/pkgs/by-name/er/errbot/package.nix +++ b/pkgs/by-name/er/errbot/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/er/errcheck/package.nix b/pkgs/by-name/er/errcheck/package.nix index fe33dff0379614..7ec574b4b4cedf 100644 --- a/pkgs/by-name/er/errcheck/package.nix +++ b/pkgs/by-name/er/errcheck/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "errcheck"; diff --git a/pkgs/by-name/es/es/package.nix b/pkgs/by-name/es/es/package.nix index 698cfc0c62a864..78bfa8981cf5ea 100644 --- a/pkgs/by-name/es/es/package.nix +++ b/pkgs/by-name/es/es/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchpatch, fetchurl, readline, bison }: +{ + lib, + stdenv, + fetchpatch, + fetchurl, + readline, + bison, +}: stdenv.mkDerivation rec { @@ -35,16 +42,18 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Extensible shell with higher order functions"; mainProgram = "es"; - longDescription = - '' - Es is an extensible shell. The language was derived - from the Plan 9 shell, rc, and was influenced by - functional programming languages, such as Scheme, - and the Tcl embeddable programming language. - ''; + longDescription = '' + Es is an extensible shell. The language was derived + from the Plan 9 shell, rc, and was influenced by + functional programming languages, such as Scheme, + and the Tcl embeddable programming language. + ''; homepage = "http://wryun.github.io/es-shell/"; license = licenses.publicDomain; - maintainers = with maintainers; [ sjmackenzie ttuegel ]; + maintainers = with maintainers; [ + sjmackenzie + ttuegel + ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/es/esbuild-config/package.nix b/pkgs/by-name/es/esbuild-config/package.nix index 6324add2b9343b..1944523f81879f 100644 --- a/pkgs/by-name/es/esbuild-config/package.nix +++ b/pkgs/by-name/es/esbuild-config/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/es/eschalot/package.nix b/pkgs/by-name/es/eschalot/package.nix index 0c984c5d35e553..28ee6a9ee29a2c 100644 --- a/pkgs/by-name/es/eschalot/package.nix +++ b/pkgs/by-name/es/eschalot/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + openssl, +}: stdenv.mkDerivation rec { pname = "eschalot"; diff --git a/pkgs/by-name/es/escrotum/package.nix b/pkgs/by-name/es/escrotum/package.nix index 6cbd793daf2ed3..6d4f80521596f0 100644 --- a/pkgs/by-name/es/escrotum/package.nix +++ b/pkgs/by-name/es/escrotum/package.nix @@ -1,19 +1,23 @@ -{ lib, python3Packages, fetchFromGitHub -, ffmpeg-full -, gtk3 -, pango -, gobject-introspection -, wrapGAppsHook3 +{ + lib, + python3Packages, + fetchFromGitHub, + ffmpeg-full, + gtk3, + pango, + gobject-introspection, + wrapGAppsHook3, }: -with python3Packages; buildPythonApplication { +with python3Packages; +buildPythonApplication { pname = "escrotum"; version = "unstable-2020-12-07"; src = fetchFromGitHub { - owner = "Roger"; - repo = "escrotum"; - rev = "a41d0f11bb6af4f08e724b8ccddf8513d905c0d1"; + owner = "Roger"; + repo = "escrotum"; + rev = "a41d0f11bb6af4f08e724b8ccddf8513d905c0d1"; sha256 = "sha256-z0AyTbOEE60j/883X17mxgoaVlryNtn0dfEB0C18G2s="; }; @@ -27,14 +31,22 @@ with python3Packages; buildPythonApplication { wrapGAppsHook3 ]; - propagatedBuildInputs = [ pygobject3 xcffib pycairo numpy ]; + propagatedBuildInputs = [ + pygobject3 + xcffib + pycairo + numpy + ]; # Cannot find pango without strictDeps = false strictDeps = false; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - makeWrapperArgs = ["--prefix PATH : ${lib.makeBinPath [ ffmpeg-full ]}"]; + makeWrapperArgs = [ "--prefix PATH : ${lib.makeBinPath [ ffmpeg-full ]}" ]; postInstall = '' mkdir -p $man/share/man/man1 diff --git a/pkgs/by-name/es/esdm/package.nix b/pkgs/by-name/es/esdm/package.nix index e11310da72552a..f99227535c5182 100644 --- a/pkgs/by-name/es/esdm/package.nix +++ b/pkgs/by-name/es/esdm/package.nix @@ -1,61 +1,65 @@ -{ lib -, stdenv -, fetchFromGitHub -, protobufc -, pkg-config -, fuse3 -, meson -, ninja -, libselinux -, jitterentropy -, botan3 -, openssl -, libkcapi +{ + lib, + stdenv, + fetchFromGitHub, + protobufc, + pkg-config, + fuse3, + meson, + ninja, + libselinux, + jitterentropy, + botan3, + openssl, + libkcapi, -# A more detailed explaination of the following meson build options can be found -# in the source code of esdm. -# A brief explanation is given. + # A more detailed explaination of the following meson build options can be found + # in the source code of esdm. + # A brief explanation is given. -# general options -, selinux ? false # enable selinux support -, drngHashDrbg ? true # set the default drng callback -, drngChaCha20 ? false # set the default drng callback -, ais2031 ? false # set the seeding strategy to be compliant with AIS 20/31 -, sp80090c ? false # set compliance with NIST SP800-90C -, cryptoBackend ? "botan" # set backend for hash and drbg operations -, linuxDevFiles ? true # enable linux /dev/random and /dev/urandom support -, linuxGetRandom ? true # enable linux getrandom support -, hashSha512 ? false # set the conditioning hash: SHA2-512 -, hashSha3_512 ? true # set the conditioning hash: SHA3-512 -, openSSLRandProvider ? true # build ESDM provider for OpenSSL 3.x -, botanRng ? true # build ESDM class for Botan 3.x + # general options + selinux ? false, # enable selinux support + drngHashDrbg ? true, # set the default drng callback + drngChaCha20 ? false, # set the default drng callback + ais2031 ? false, # set the seeding strategy to be compliant with AIS 20/31 + sp80090c ? false, # set compliance with NIST SP800-90C + cryptoBackend ? "botan", # set backend for hash and drbg operations + linuxDevFiles ? true, # enable linux /dev/random and /dev/urandom support + linuxGetRandom ? true, # enable linux getrandom support + hashSha512 ? false, # set the conditioning hash: SHA2-512 + hashSha3_512 ? true, # set the conditioning hash: SHA3-512 + openSSLRandProvider ? true, # build ESDM provider for OpenSSL 3.x + botanRng ? true, # build ESDM class for Botan 3.x -# client-related options (handle with care, consult source code and meson options) -# leave as is if in doubt -, connectTimeoutExponent ? 28 # (1 << EXPONENT nanoseconds) -, rxTxTimeoutExponent ? 28 # (1 << EXPONENT nanoseconds) -, reconnectAttempts ? 10 # how often to attempt unix socket connection before giving up + # client-related options (handle with care, consult source code and meson options) + # leave as is if in doubt + connectTimeoutExponent ? 28, # (1 << EXPONENT nanoseconds) + rxTxTimeoutExponent ? 28, # (1 << EXPONENT nanoseconds) + reconnectAttempts ? 10, # how often to attempt unix socket connection before giving up -# entropy sources -, esJitterRng ? true # enable support for the entropy source: jitter rng (running in user space) -, esJitterRngEntropyRate ? 256 # amount of entropy to account for jitter rng source -, esJitterRngKernel ? true # enable support for the entropy source: jitter rng (running in kernel space) -, esJitterRngKernelEntropyRate ? 256 # amount of entropy to account for kernel jitter rng source -, esCPU ? true # enable support for the entropy source: cpu-based entropy -, esCPUEntropyRate ? 8 # amount of entropy to account for cpu rng source -, esKernel ? true # enable support for the entropy source: kernel-based entropy -, esKernelEntropyRate ? 128 # amount of entropy to account for kernel-based source -, esIRQ ? false # enable support for the entropy source: interrupt-based entropy -, esIRQEntropyRate ? 256 # amount of entropy to account for interrupt-based source (only set irq XOR sched != 0) -, esSched ? false # enable support for the entropy source: scheduler-based entropy -, esSchedEntropyRate ? 0 # amount of entropy to account for interrupt-based source (only set irq XOR sched != 0) -, esHwrand ? true # enable support for the entropy source: /dev/hwrng -, esHwrandEntropyRate ? 128 # amount of entropy to account for /dev/hwrng-based sources + # entropy sources + esJitterRng ? true, # enable support for the entropy source: jitter rng (running in user space) + esJitterRngEntropyRate ? 256, # amount of entropy to account for jitter rng source + esJitterRngKernel ? true, # enable support for the entropy source: jitter rng (running in kernel space) + esJitterRngKernelEntropyRate ? 256, # amount of entropy to account for kernel jitter rng source + esCPU ? true, # enable support for the entropy source: cpu-based entropy + esCPUEntropyRate ? 8, # amount of entropy to account for cpu rng source + esKernel ? true, # enable support for the entropy source: kernel-based entropy + esKernelEntropyRate ? 128, # amount of entropy to account for kernel-based source + esIRQ ? false, # enable support for the entropy source: interrupt-based entropy + esIRQEntropyRate ? 256, # amount of entropy to account for interrupt-based source (only set irq XOR sched != 0) + esSched ? false, # enable support for the entropy source: scheduler-based entropy + esSchedEntropyRate ? 0, # amount of entropy to account for interrupt-based source (only set irq XOR sched != 0) + esHwrand ? true, # enable support for the entropy source: /dev/hwrng + esHwrandEntropyRate ? 128, # amount of entropy to account for /dev/hwrng-based sources }: assert drngHashDrbg != drngChaCha20; assert hashSha512 != hashSha3_512; -assert cryptoBackend == "openssl" || cryptoBackend == "botan" || cryptoBackend == "builtin" "Unsupported ESDM crypto backend"; +assert + cryptoBackend == "openssl" + || cryptoBackend == "botan" + || cryptoBackend == "builtin" "Unsupported ESDM crypto backend"; stdenv.mkDerivation rec { pname = "esdm"; @@ -68,9 +72,14 @@ stdenv.mkDerivation rec { hash = "sha256-5XctrI02pfCgK1P76AaSkMjiQqav6LX3SMjKr4F44sw="; }; - nativeBuildInputs = [ meson pkg-config ninja ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + ]; - buildInputs = lib.optional (cryptoBackend == "botan" || botanRng) botan3 + buildInputs = + lib.optional (cryptoBackend == "botan" || botanRng) botan3 ++ lib.optional (cryptoBackend == "openssl" || openSSLRandProvider) openssl ++ lib.optional selinux libselinux ++ lib.optional esJitterRng jitterentropy @@ -123,8 +132,14 @@ stdenv.mkDerivation rec { meta = { homepage = "https://www.chronox.de/esdm.html"; description = "Entropy Source and DRNG Manager in user space"; - license = with lib.licenses; [ gpl2Only bsd3 ]; + license = with lib.licenses; [ + gpl2Only + bsd3 + ]; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ orichter thillux ]; + maintainers = with lib.maintainers; [ + orichter + thillux + ]; }; } diff --git a/pkgs/by-name/es/esh/package.nix b/pkgs/by-name/es/esh/package.nix index 2b7b2a427f6b4a..1dbd3ea54e27fa 100644 --- a/pkgs/by-name/es/esh/package.nix +++ b/pkgs/by-name/es/esh/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, asciidoctor, gawk, gnused, runtimeShell, binlore, esh }: +{ + lib, + stdenv, + fetchFromGitHub, + asciidoctor, + gawk, + gnused, + runtimeShell, + binlore, + esh, +}: stdenv.mkDerivation rec { pname = "esh"; @@ -13,9 +23,15 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ asciidoctor ]; - buildInputs = [ gawk gnused ]; + buildInputs = [ + gawk + gnused + ]; - makeFlags = [ "prefix=$(out)" "DESTDIR=" ]; + makeFlags = [ + "prefix=$(out)" + "DESTDIR=" + ]; postPatch = '' patchShebangs . diff --git a/pkgs/by-name/es/eslint_d/package.nix b/pkgs/by-name/es/eslint_d/package.nix index 1a4a71d43fefe0..d36a4eed20a17f 100644 --- a/pkgs/by-name/es/eslint_d/package.nix +++ b/pkgs/by-name/es/eslint_d/package.nix @@ -1,4 +1,10 @@ -{ lib, buildNpmPackage, fetchFromGitHub, eslint_d, testers }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, + eslint_d, + testers, +}: buildNpmPackage rec { pname = "eslint_d"; @@ -15,7 +21,10 @@ buildNpmPackage rec { dontNpmBuild = true; - passthru.tests.version = testers.testVersion { package = eslint_d; version = src.rev; }; + passthru.tests.version = testers.testVersion { + package = eslint_d; + version = src.rev; + }; meta = with lib; { description = "Makes eslint the fastest linter on the planet"; diff --git a/pkgs/by-name/es/espanso/package.nix b/pkgs/by-name/es/espanso/package.nix index 4e4e27f749fcf7..636bec07ee1ec6 100644 --- a/pkgs/by-name/es/espanso/package.nix +++ b/pkgs/by-name/es/espanso/package.nix @@ -1,29 +1,30 @@ -{ lib -, coreutils -, fetchFromGitHub -, rustPlatform -, pkg-config -, extra-cmake-modules -, dbus -, libX11 -, libXi -, libXtst -, libnotify -, libxkbcommon -, openssl -, xclip -, xdotool -, setxkbmap -, wl-clipboard -, wxGTK32 -, makeWrapper -, stdenv -, apple-sdk_11 -, darwinMinVersionHook -, waylandSupport ? false -, x11Support ? stdenv.hostPlatform.isLinux -, testers -, espanso +{ + lib, + coreutils, + fetchFromGitHub, + rustPlatform, + pkg-config, + extra-cmake-modules, + dbus, + libX11, + libXi, + libXtst, + libnotify, + libxkbcommon, + openssl, + xclip, + xdotool, + setxkbmap, + wl-clipboard, + wxGTK32, + makeWrapper, + stdenv, + apple-sdk_11, + darwinMinVersionHook, + waylandSupport ? false, + x11Support ? stdenv.hostPlatform.isLinux, + testers, + espanso, }: # espanso does not support building with both X11 and Wayland support at the same time assert stdenv.hostPlatform.isLinux -> x11Support != waylandSupport; @@ -56,35 +57,44 @@ rustPlatform.buildRustPackage rec { # Ref: https://github.com/espanso/espanso/blob/78df1b704fe2cc5ea26f88fdc443b6ae1df8a989/scripts/build_binary.rs#LL49C3-L62C4 buildNoDefaultFeatures = true; - buildFeatures = [ - "modulo" - ] ++ lib.optionals waylandSupport [ - "wayland" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "vendored-tls" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "native-tls" - ]; + buildFeatures = + [ + "modulo" + ] + ++ lib.optionals waylandSupport [ + "wayland" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "vendored-tls" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "native-tls" + ]; - buildInputs = [ - wxGTK32 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - openssl - dbus - libnotify - libxkbcommon - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - apple-sdk_11 - (darwinMinVersionHook "10.13") - ] ++ lib.optionals waylandSupport [ - wl-clipboard - ] ++ lib.optionals x11Support [ - libXi - libXtst - libX11 - xclip - xdotool - ]; + buildInputs = + [ + wxGTK32 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + openssl + dbus + libnotify + libxkbcommon + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + apple-sdk_11 + (darwinMinVersionHook "10.13") + ] + ++ lib.optionals waylandSupport [ + wl-clipboard + ] + ++ lib.optionals x11Support [ + libXi + libXtst + libX11 + xclip + xdotool + ]; postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' substituteInPlace scripts/create_bundle.sh \ @@ -101,21 +111,28 @@ rustPlatform.buildRustPackage rec { doCheck = false; postInstall = - if stdenv.hostPlatform.isDarwin then '' - EXEC_PATH=$out/bin/espanso BUILD_ARCH=current ${stdenv.shell} ./scripts/create_bundle.sh - '' else '' - wrapProgram $out/bin/espanso \ - --prefix PATH : ${lib.makeBinPath ( - lib.optionals stdenv.hostPlatform.isLinux [ - libnotify - setxkbmap - ] ++ lib.optionals waylandSupport [ - wl-clipboard - ] ++ lib.optionals x11Support [ - xclip - ] - )} - ''; + if stdenv.hostPlatform.isDarwin then + '' + EXEC_PATH=$out/bin/espanso BUILD_ARCH=current ${stdenv.shell} ./scripts/create_bundle.sh + '' + else + '' + wrapProgram $out/bin/espanso \ + --prefix PATH : ${ + lib.makeBinPath ( + lib.optionals stdenv.hostPlatform.isLinux [ + libnotify + setxkbmap + ] + ++ lib.optionals waylandSupport [ + wl-clipboard + ] + ++ lib.optionals x11Support [ + xclip + ] + ) + } + ''; passthru.tests.version = testers.testVersion { package = espanso; @@ -128,7 +145,11 @@ rustPlatform.buildRustPackage rec { mainProgram = "espanso"; homepage = "https://espanso.org"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ kimat pyrox0 n8henrie ]; + maintainers = with maintainers; [ + kimat + pyrox0 + n8henrie + ]; platforms = platforms.unix; longDescription = '' diff --git a/pkgs/by-name/es/espeakup/package.nix b/pkgs/by-name/es/espeakup/package.nix index c35cc483ea99c0..cf440d4b6d80ca 100644 --- a/pkgs/by-name/es/espeakup/package.nix +++ b/pkgs/by-name/es/espeakup/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, meson -, ninja -, espeak-ng -, fetchFromGitHub -, pkg-config -, ronn -, alsa-lib -, systemd +{ + stdenv, + lib, + meson, + ninja, + espeak-ng, + fetchFromGitHub, + pkg-config, + ronn, + alsa-lib, + systemd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/es/espflash/package.nix b/pkgs/by-name/es/espflash/package.nix index 94fa9f5ca41f6e..cd636ba7721013 100644 --- a/pkgs/by-name/es/espflash/package.nix +++ b/pkgs/by-name/es/espflash/package.nix @@ -1,16 +1,16 @@ { - lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, installShellFiles -, udev -, stdenv -, CoreServices -, Security -, nix-update-script -, openssl -, SystemConfiguration + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + installShellFiles, + udev, + stdenv, + CoreServices, + Security, + nix-update-script, + openssl, + SystemConfiguration, }: rustPlatform.buildRustPackage rec { @@ -32,13 +32,16 @@ rustPlatform.buildRustPackage rec { # Needed to get openssl-sys to use pkg-config. OPENSSL_NO_VENDOR = 1; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - udev - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreServices - Security - SystemConfiguration - ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + udev + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + Security + SystemConfiguration + ]; cargoHash = "sha256-3xUDsznzIRlfGwVuIH1+Ub5tE/ST981KZS/2TAKaBAE="; @@ -56,7 +59,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/esp-rs/espflash"; changelog = "https://github.com/esp-rs/espflash/blob/v${version}/CHANGELOG.md"; mainProgram = "espflash"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ matthiasbeyer ]; }; } diff --git a/pkgs/by-name/es/espresso/package.nix b/pkgs/by-name/es/espresso/package.nix index 8939bec8ecccc9..9e44a32cf0de6b 100644 --- a/pkgs/by-name/es/espresso/package.nix +++ b/pkgs/by-name/es/espresso/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, cmake, stdenv, nix-update-script }: +{ + lib, + fetchFromGitHub, + cmake, + stdenv, + nix-update-script, +}: stdenv.mkDerivation rec { pname = "espresso"; version = "2.4"; @@ -13,11 +19,14 @@ stdenv.mkDerivation rec { doCheck = true; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; passthru.updateScript = nix-update-script { }; - meta = with lib;{ + meta = with lib; { description = "Multi-valued PLA minimization"; # from manual longDescription = '' @@ -28,7 +37,7 @@ stdenv.mkDerivation rec { heuristic Boolean minimization. ''; homepage = "https://github.com/chipsalliance/espresso"; - maintainers = with maintainers;[ pineapplehunter ]; + maintainers = with maintainers; [ pineapplehunter ]; mainProgram = "espresso"; platforms = lib.platforms.all; diff --git a/pkgs/by-name/es/esptool-ck/package.nix b/pkgs/by-name/es/esptool-ck/package.nix index 58f84c9b063060..4f7ce1504e0d6f 100644 --- a/pkgs/by-name/es/esptool-ck/package.nix +++ b/pkgs/by-name/es/esptool-ck/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "esptool-ck"; diff --git a/pkgs/by-name/es/esptool/package.nix b/pkgs/by-name/es/esptool/package.nix index 1a61e8ae351f73..8f4b6482d9a648 100644 --- a/pkgs/by-name/es/esptool/package.nix +++ b/pkgs/by-name/es/esptool/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3Packages -, softhsm +{ + lib, + fetchFromGitHub, + python3Packages, + softhsm, }: python3Packages.buildPythonApplication rec { @@ -42,11 +43,14 @@ python3Packages.buildPythonApplication rec { hsm = [ python-pkcs11 ]; }; - nativeCheckInputs = with python3Packages; [ - pyelftools - pytestCheckHook - softhsm - ] ++ lib.flatten (lib.attrValues optional-dependencies); + nativeCheckInputs = + with python3Packages; + [ + pyelftools + pytestCheckHook + softhsm + ] + ++ lib.flatten (lib.attrValues optional-dependencies); # tests mentioned in `.github/workflows/test_esptool.yml` checkPhase = '' @@ -71,7 +75,13 @@ python3Packages.buildPythonApplication rec { description = "ESP8266 and ESP32 serial bootloader utility"; homepage = "https://github.com/espressif/esptool"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ dezgeg dotlambda ] ++ teams.lumiguide.members; + maintainers = + with maintainers; + [ + dezgeg + dotlambda + ] + ++ teams.lumiguide.members; platforms = with platforms; linux ++ darwin; mainProgram = "esptool.py"; }; diff --git a/pkgs/by-name/es/espup/package.nix b/pkgs/by-name/es/espup/package.nix index f584e3486e4f45..83710c80facfc3 100644 --- a/pkgs/by-name/es/espup/package.nix +++ b/pkgs/by-name/es/espup/package.nix @@ -1,16 +1,17 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, installShellFiles -, bzip2 -, openssl -, xz -, zstd -, stdenv -, darwin -, testers -, espup +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + installShellFiles, + bzip2, + openssl, + xz, + zstd, + stdenv, + darwin, + testers, + espup, }: rustPlatform.buildRustPackage rec { @@ -31,16 +32,18 @@ rustPlatform.buildRustPackage rec { installShellFiles ]; - buildInputs = [ - bzip2 - openssl - xz - zstd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreFoundation - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + bzip2 + openssl + xz + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreFoundation + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; env = { OPENSSL_NO_VENDOR = true; @@ -70,8 +73,14 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Tool for installing and maintaining Espressif Rust ecosystem"; homepage = "https://github.com/esp-rs/espup/"; - license = with licenses; [ mit asl20 ]; - maintainers = with maintainers; [ knightpp beeb ]; + license = with licenses; [ + mit + asl20 + ]; + maintainers = with maintainers; [ + knightpp + beeb + ]; mainProgram = "espup"; }; } diff --git a/pkgs/by-name/es/essentia-extractor/package.nix b/pkgs/by-name/es/essentia-extractor/package.nix index de3bf45d10c58a..e99bbb20a3eb80 100644 --- a/pkgs/by-name/es/essentia-extractor/package.nix +++ b/pkgs/by-name/es/essentia-extractor/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let arch_table = { "x86_64-linux" = "linux-x86_64"; @@ -34,7 +38,10 @@ stdenv.mkDerivation rec { description = "AcousticBrainz audio feature extractor"; license = licenses.agpl3Plus; maintainers = with maintainers; [ lovesegfault ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; mainProgram = "streaming_extractor_music"; }; } diff --git a/pkgs/by-name/es/esshader/package.nix b/pkgs/by-name/es/esshader/package.nix index b425ce5721ce07..83a3c20708d25b 100644 --- a/pkgs/by-name/es/esshader/package.nix +++ b/pkgs/by-name/es/esshader/package.nix @@ -1,4 +1,12 @@ -{ stdenv, fetchFromGitHub, pkg-config, libGL, glfw, soil, lib }: +{ + stdenv, + fetchFromGitHub, + pkg-config, + libGL, + glfw, + soil, + lib, +}: stdenv.mkDerivation { pname = "esshader"; @@ -20,7 +28,9 @@ stdenv.mkDerivation { pkg-config ]; buildInputs = [ - libGL glfw soil + libGL + glfw + soil ]; installPhase = '' diff --git a/pkgs/by-name/es/est-sfs/package.nix b/pkgs/by-name/es/est-sfs/package.nix index c306cfd71c3929..a88578d992487d 100644 --- a/pkgs/by-name/es/est-sfs/package.nix +++ b/pkgs/by-name/es/est-sfs/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gsl }: +{ + lib, + stdenv, + fetchurl, + gsl, +}: stdenv.mkDerivation rec { pname = "est-sfs"; diff --git a/pkgs/by-name/et/et/package.nix b/pkgs/by-name/et/et/package.nix index de47efc07ef51c..cc73253dd6ea24 100644 --- a/pkgs/by-name/et/et/package.nix +++ b/pkgs/by-name/et/et/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, libnotify, gdk-pixbuf }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libnotify, + gdk-pixbuf, +}: stdenv.mkDerivation rec { pname = "et"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "0i0lgmnly8n7y4y6pb10pxgxyz8s5zk26k8z1g1578v1wan01lnq"; }; - buildInputs = [ libnotify gdk-pixbuf ]; + buildInputs = [ + libnotify + gdk-pixbuf + ]; nativeBuildInputs = [ pkg-config ]; installPhase = '' diff --git a/pkgs/by-name/et/etBook/package.nix b/pkgs/by-name/et/etBook/package.nix index 6dfa369d606df8..2d4bfb5317fb64 100644 --- a/pkgs/by-name/et/etBook/package.nix +++ b/pkgs/by-name/et/etBook/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "et-book"; diff --git a/pkgs/by-name/et/etebase-server/package.nix b/pkgs/by-name/et/etebase-server/package.nix index e9503ecfe16778..b5f350b850d316 100644 --- a/pkgs/by-name/et/etebase-server/package.nix +++ b/pkgs/by-name/et/etebase-server/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, python3 -, withLdap ? false -, withPostgres ? true -, nix-update-script -, nixosTests +{ + lib, + fetchFromGitHub, + python3, + withLdap ? false, + withPostgres ? true, + nix-update-script, + nixosTests, }: python3.pkgs.buildPythonApplication rec { @@ -22,22 +23,25 @@ python3.pkgs.buildPythonApplication rec { doCheck = false; - propagatedBuildInputs = with python3.pkgs; [ - aiofiles - django_4 - fastapi - msgpack - pynacl - redis - uvicorn - websockets - watchfiles - uvloop - pyyaml - python-dotenv - httptools - typing-extensions - ] ++ lib.optional withLdap python-ldap + propagatedBuildInputs = + with python3.pkgs; + [ + aiofiles + django_4 + fastapi + msgpack + pynacl + redis + uvicorn + websockets + watchfiles + uvloop + pyyaml + python-dotenv + httptools + typing-extensions + ] + ++ lib.optional withLdap python-ldap ++ lib.optional withPostgres psycopg2; postInstall = '' @@ -47,7 +51,7 @@ python3.pkgs.buildPythonApplication rec { chmod +x $out/bin/etebase-server ''; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; passthru.python = python3; # PYTHONPATH of all dependencies used by the package passthru.pythonPath = python3.pkgs.makePythonPath propagatedBuildInputs; @@ -61,6 +65,9 @@ python3.pkgs.buildPythonApplication rec { mainProgram = "etebase-server"; changelog = "https://github.com/etesync/server/blob/${version}/ChangeLog.md"; license = licenses.agpl3Only; - maintainers = with maintainers; [ felschr phaer ]; + maintainers = with maintainers; [ + felschr + phaer + ]; }; } diff --git a/pkgs/by-name/et/eternal-terminal/package.nix b/pkgs/by-name/et/eternal-terminal/package.nix index 3096ea67840f7b..7f4ce3143be544 100644 --- a/pkgs/by-name/et/eternal-terminal/package.nix +++ b/pkgs/by-name/et/eternal-terminal/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gflags -, libsodium -, openssl -, protobuf -, zlib -, catch2 -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gflags, + libsodium, + openssl, + protobuf, + zlib, + catch2, + darwin, }: stdenv.mkDerivation rec { @@ -56,7 +57,10 @@ stdenv.mkDerivation rec { homepage = "https://eternalterminal.dev/"; changelog = "https://github.com/MisterTea/EternalTerminal/releases/tag/et-v${version}"; license = licenses.asl20; - maintainers = with maintainers; [ dezgeg jshort ]; + maintainers = with maintainers; [ + dezgeg + jshort + ]; platforms = platforms.linux ++ platforms.darwin; }; } diff --git a/pkgs/by-name/et/eternity/package.nix b/pkgs/by-name/et/eternity/package.nix index 92ae7ea0c9e9f8..0e04df9a5a7e7f 100644 --- a/pkgs/by-name/et/eternity/package.nix +++ b/pkgs/by-name/et/eternity/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, cmake, libGL, SDL2, SDL2_mixer, SDL2_net, fetchFromGitHub, makeWrapper }: +{ + lib, + stdenv, + cmake, + libGL, + SDL2, + SDL2_mixer, + SDL2_net, + fetchFromGitHub, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "eternity-engine"; @@ -11,8 +21,16 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake makeWrapper ]; - buildInputs = [ libGL SDL2 SDL2_mixer SDL2_net ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; + buildInputs = [ + libGL + SDL2 + SDL2_mixer + SDL2_net + ]; installPhase = '' install -Dm755 eternity/eternity $out/lib/eternity/eternity diff --git a/pkgs/by-name/et/ethash/package.nix b/pkgs/by-name/et/ethash/package.nix index adc9649b4d90a9..6abff5b969df36 100644 --- a/pkgs/by-name/et/ethash/package.nix +++ b/pkgs/by-name/et/ethash/package.nix @@ -1,16 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, cmake, gbenchmark, gtest }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gbenchmark, + gtest, +}: stdenv.mkDerivation rec { pname = "ethash"; version = "1.0.1"; - src = - fetchFromGitHub { - owner = "chfast"; - repo = "ethash"; - rev = "v${version}"; - sha256 = "sha256-BjgfWDn72P4NJhzq0ySW8bvZI3AQB9jOaRqFIeCfJ8k="; - }; + src = fetchFromGitHub { + owner = "chfast"; + repo = "ethash"; + rev = "v${version}"; + sha256 = "sha256-BjgfWDn72P4NJhzq0ySW8bvZI3AQB9jOaRqFIeCfJ8k="; + }; nativeBuildInputs = [ cmake diff --git a/pkgs/by-name/et/etherape/package.nix b/pkgs/by-name/et/etherape/package.nix index 067175bdb4803e..b2193446fcf30b 100644 --- a/pkgs/by-name/et/etherape/package.nix +++ b/pkgs/by-name/et/etherape/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchurl, pkg-config, libtool, gtk3, libpcap, goocanvas2, -popt, itstool, libxml2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libtool, + gtk3, + libpcap, + goocanvas2, + popt, + itstool, + libxml2, +}: stdenv.mkDerivation rec { pname = "etherape"; @@ -9,9 +20,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-9UsQtWOXB1yYofGS4rMIF+ISWBsJKd0DBOFfqOr1n5Y="; }; - nativeBuildInputs = [ itstool pkg-config (lib.getBin libxml2) ]; + nativeBuildInputs = [ + itstool + pkg-config + (lib.getBin libxml2) + ]; buildInputs = [ - libtool gtk3 libpcap goocanvas2 popt + libtool + gtk3 + libpcap + goocanvas2 + popt ]; meta = with lib; { diff --git a/pkgs/by-name/et/ethercat/package.nix b/pkgs/by-name/et/ethercat/package.nix index 7fa1316b147fe6..0ecf0501001391 100644 --- a/pkgs/by-name/et/ethercat/package.nix +++ b/pkgs/by-name/et/ethercat/package.nix @@ -1,9 +1,10 @@ -{ autoreconfHook -, lib -, pkg-config -, stdenv -, fetchFromGitLab -, gitUpdater +{ + autoreconfHook, + lib, + pkg-config, + stdenv, + fetchFromGitLab, + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { pname = "ethercat"; @@ -18,7 +19,10 @@ stdenv.mkDerivation (finalAttrs: { separateDebugInfo = true; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; configureFlags = [ "--enable-userlib=yes" diff --git a/pkgs/by-name/et/ethq/package.nix b/pkgs/by-name/et/ethq/package.nix index 37d0767834dbc3..9e817fe78fd3c1 100644 --- a/pkgs/by-name/et/ethq/package.nix +++ b/pkgs/by-name/et/ethq/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, ncurses }: +{ + stdenv, + lib, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { pname = "ethq"; @@ -7,7 +12,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "isc-projects"; repo = "ethq"; - rev = "refs/tags/v${builtins.replaceStrings ["."] ["_"] version}"; + rev = "refs/tags/v${builtins.replaceStrings [ "." ] [ "_" ] version}"; hash = "sha256-ye5ep9EM9Sq/NqNZHENPmFZefVBx1BGrPm3YEG1NcSc="; }; diff --git a/pkgs/by-name/et/ethtool/package.nix b/pkgs/by-name/et/ethtool/package.nix index ebd26985f7f4da..9362d2d4007e93 100644 --- a/pkgs/by-name/et/ethtool/package.nix +++ b/pkgs/by-name/et/ethtool/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, libmnl -, pkg-config -, writeScript +{ + lib, + stdenv, + fetchurl, + libmnl, + pkg-config, + writeScript, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/et/etlegacy-assets/package.nix b/pkgs/by-name/et/etlegacy-assets/package.nix index 1b42de998e0051..fbdb9fabd615f6 100644 --- a/pkgs/by-name/et/etlegacy-assets/package.nix +++ b/pkgs/by-name/et/etlegacy-assets/package.nix @@ -1,31 +1,36 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation { pname = "etlegacy-assets"; version = "2.83.1"; - srcs = let - fetchAsset = { asset, hash }: fetchurl { - url = "https://mirror.etlegacy.com/etmain/${asset}"; - inherit hash; - }; - in [ - (fetchAsset { - asset = "pak0.pk3"; - hash = "sha256-cSlmsg4GUj/oFBlRZQDkmchrK0/sgjhW3b0zP8s9JuU="; - }) - (fetchAsset { - asset = "pak1.pk3"; - hash = "sha256-VhD9dJAkQFtEJafOY5flgYe5QdIgku8R1IRLQn31Pl0="; - }) - (fetchAsset { - asset = "pak2.pk3"; - hash = "sha256-pIq3SaGhKrTZE3KGsfI9ZCwp2lmEWyuvyPZOBSzwbz4="; - }) - ]; + srcs = + let + fetchAsset = + { asset, hash }: + fetchurl { + url = "https://mirror.etlegacy.com/etmain/${asset}"; + inherit hash; + }; + in + [ + (fetchAsset { + asset = "pak0.pk3"; + hash = "sha256-cSlmsg4GUj/oFBlRZQDkmchrK0/sgjhW3b0zP8s9JuU="; + }) + (fetchAsset { + asset = "pak1.pk3"; + hash = "sha256-VhD9dJAkQFtEJafOY5flgYe5QdIgku8R1IRLQn31Pl0="; + }) + (fetchAsset { + asset = "pak2.pk3"; + hash = "sha256-pIq3SaGhKrTZE3KGsfI9ZCwp2lmEWyuvyPZOBSzwbz4="; + }) + ]; sourceRoot = "."; unpackCmd = "cp -r $curSrc \${curSrc##*-}"; diff --git a/pkgs/by-name/et/etlegacy/package.nix b/pkgs/by-name/et/etlegacy/package.nix index c59adc74e119ea..e708de08c34c2b 100644 --- a/pkgs/by-name/et/etlegacy/package.nix +++ b/pkgs/by-name/et/etlegacy/package.nix @@ -1,8 +1,9 @@ -{ lib -, symlinkJoin -, etlegacy-assets -, etlegacy-unwrapped -, makeBinaryWrapper +{ + lib, + symlinkJoin, + etlegacy-assets, + etlegacy-unwrapped, + makeBinaryWrapper, }: symlinkJoin { @@ -29,14 +30,20 @@ symlinkJoin { meta = { description = "ET: Legacy is an open source project based on the code of Wolfenstein: Enemy Territory which was released in 2010 under the terms of the GPLv3 license"; homepage = "https://etlegacy.com"; - license = with lib.licenses; [ gpl3Plus cc-by-nc-sa-30 ]; + license = with lib.licenses; [ + gpl3Plus + cc-by-nc-sa-30 + ]; longDescription = '' ET: Legacy, an open source project fully compatible client and server for the popular online FPS game Wolfenstein: Enemy Territory - whose gameplay is still considered unmatched by many, despite its great age. ''; mainProgram = "etl"; - maintainers = with lib.maintainers; [ ashleyghooper drupol ]; + maintainers = with lib.maintainers; [ + ashleyghooper + drupol + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/et/ets/package.nix b/pkgs/by-name/et/ets/package.nix index ad81513a89a985..d2ae7d35c34084 100644 --- a/pkgs/by-name/et/ets/package.nix +++ b/pkgs/by-name/et/ets/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "ets"; @@ -13,7 +18,11 @@ buildGoModule rec { vendorHash = "sha256-XHgdiXdp9aNEAc/Apvb64ExnpywjddWOw1scNKy+ico="; - ldflags = [ "-s" "-w" "-X main.version=v${version}-nixpkgs" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=v${version}-nixpkgs" + ]; nativeBuildInputs = [ installShellFiles ]; diff --git a/pkgs/by-name/et/ettercap/package.nix b/pkgs/by-name/et/ettercap/package.nix index 3554592fbe12ee..29d558b35896a2 100644 --- a/pkgs/by-name/et/ettercap/package.nix +++ b/pkgs/by-name/et/ettercap/package.nix @@ -1,6 +1,26 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch2, cmake, libpcap, libnet, zlib, curl, pcre -, openssl, ncurses, glib, gtk3, atk, pango, flex, bison, geoip, harfbuzz -, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch2, + cmake, + libpcap, + libnet, + zlib, + curl, + pcre, + openssl, + ncurses, + glib, + gtk3, + atk, + pango, + flex, + bison, + geoip, + harfbuzz, + pkg-config, +}: stdenv.mkDerivation rec { pname = "ettercap"; @@ -22,10 +42,26 @@ stdenv.mkDerivation rec { ]; strictDeps = true; - nativeBuildInputs = [ cmake flex bison pkg-config ]; + nativeBuildInputs = [ + cmake + flex + bison + pkg-config + ]; buildInputs = [ - libpcap libnet zlib curl pcre openssl ncurses - glib gtk3 atk pango geoip harfbuzz + libpcap + libnet + zlib + curl + pcre + openssl + ncurses + glib + gtk3 + atk + pango + geoip + harfbuzz ]; preConfigure = '' diff --git a/pkgs/by-name/eu/eudev/package.nix b/pkgs/by-name/eu/eudev/package.nix index 089e811ad8a503..713394d345eda6 100644 --- a/pkgs/by-name/eu/eudev/package.nix +++ b/pkgs/by-name/eu/eudev/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, gperf -, kmod -, pkg-config -, util-linux -, testers +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gperf, + kmod, + pkg-config, + util-linux, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -84,8 +85,14 @@ stdenv.mkDerivation (finalAttrs: { ''; changelog = "https://github.com/eudev-project/eudev/releases/tag/${finalAttrs.src.rev}"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ raskin AndersonTorres ]; - pkgConfigModules = [ "libudev" "udev" ]; + maintainers = with lib.maintainers; [ + raskin + AndersonTorres + ]; + pkgConfigModules = [ + "libudev" + "udev" + ]; inherit (kmod.meta) platforms; }; }) diff --git a/pkgs/by-name/eu/eudic/package.nix b/pkgs/by-name/eu/eudic/package.nix index 5b2f144e2c0d6c..b72556d3badb95 100644 --- a/pkgs/by-name/eu/eudic/package.nix +++ b/pkgs/by-name/eu/eudic/package.nix @@ -1,27 +1,28 @@ -{ fetchurl -, stdenv -, autoPatchelfHook -, makeWrapper -, lib -, copyDesktopItems -, libnotify -, libX11 -, libXScrnSaver -, libXext -, libXtst -, libuuid -, libsecret -, xdg-utils -, xdg-utils-cxx -, at-spi2-atk -# additional dependencies autoPatchelfHook discovered -, gtk3 -, alsa-lib -, e2fsprogs -, nss -, libgpg-error -, libjack2 -, mesa +{ + fetchurl, + stdenv, + autoPatchelfHook, + makeWrapper, + lib, + copyDesktopItems, + libnotify, + libX11, + libXScrnSaver, + libXext, + libXtst, + libuuid, + libsecret, + xdg-utils, + xdg-utils-cxx, + at-spi2-atk, + # additional dependencies autoPatchelfHook discovered + gtk3, + alsa-lib, + e2fsprogs, + nss, + libgpg-error, + libjack2, + mesa, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/eu/eukleides/package.nix b/pkgs/by-name/eu/eukleides/package.nix index f682a57ec9516e..fed332af099938 100644 --- a/pkgs/by-name/eu/eukleides/package.nix +++ b/pkgs/by-name/eu/eukleides/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, bison, flex, makeWrapper, texinfo4, getopt, readline, texlive }: +{ + lib, + stdenv, + fetchurl, + bison, + flex, + makeWrapper, + texinfo4, + getopt, + readline, + texlive, +}: stdenv.mkDerivation (finalAttrs: rec { pname = "eukleides"; @@ -16,9 +27,17 @@ stdenv.mkDerivation (finalAttrs: rec { ./gs-allowpstransparency.patch ]; - nativeBuildInputs = [ bison flex texinfo4 makeWrapper ]; + nativeBuildInputs = [ + bison + flex + texinfo4 + makeWrapper + ]; - buildInputs = [ getopt readline ]; + buildInputs = [ + getopt + readline + ]; preConfigure = '' substituteInPlace Makefile \ @@ -47,12 +66,21 @@ stdenv.mkDerivation (finalAttrs: rec { --prefix PATH : ${lib.makeBinPath [ getopt ]} ''; - outputs = [ "out" "doc" "tex" ]; + outputs = [ + "out" + "doc" + "tex" + ]; passthru = { tlType = "run"; # packages needed by euktoeps, euktopdf and eukleides.sty - tlDeps = with texlive; [ collection-pstricks epstopdf iftex moreverb ]; + tlDeps = with texlive; [ + collection-pstricks + epstopdf + iftex + moreverb + ]; pkgs = [ finalAttrs.finalPackage.tex ]; }; diff --git a/pkgs/by-name/eu/eunomia/package.nix b/pkgs/by-name/eu/eunomia/package.nix index ebb27be44cfbe4..c995d10cbe7da0 100644 --- a/pkgs/by-name/eu/eunomia/package.nix +++ b/pkgs/by-name/eu/eunomia/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "0"; @@ -26,7 +30,10 @@ stdenvNoCC.mkDerivation { homepage = "http://dotcolon.net/font/eunomia/"; description = "Futuristic decorative font"; platforms = platforms.all; - maintainers = with maintainers; [ leenaars minijackson ]; + maintainers = with maintainers; [ + leenaars + minijackson + ]; license = licenses.ofl; }; } diff --git a/pkgs/by-name/eu/eureka-editor/package.nix b/pkgs/by-name/eu/eureka-editor/package.nix index 6f1752d109740b..d098577c7f1d5b 100644 --- a/pkgs/by-name/eu/eureka-editor/package.nix +++ b/pkgs/by-name/eu/eureka-editor/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchzip, fltk, zlib, xdg-utils, xorg, libjpeg, libGLU }: +{ + lib, + stdenv, + fetchzip, + fltk, + zlib, + xdg-utils, + xorg, + libjpeg, + libGLU, +}: stdenv.mkDerivation rec { pname = "eureka-editor"; @@ -9,7 +19,14 @@ stdenv.mkDerivation rec { sha256 = "075w7xxsgbgh6dhndc1pfxb2h1s5fhsw28yl1c025gmx9bb4v3bf"; }; - buildInputs = [ fltk zlib xdg-utils libjpeg xorg.libXinerama libGLU ]; + buildInputs = [ + fltk + zlib + xdg-utils + libjpeg + xorg.libXinerama + libGLU + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/eu/eurofurence/package.nix b/pkgs/by-name/eu/eurofurence/package.nix index 132c13cee75513..94e21df43a6211 100644 --- a/pkgs/by-name/eu/eurofurence/package.nix +++ b/pkgs/by-name/eu/eurofurence/package.nix @@ -1,41 +1,45 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { pname = "eurofurence"; version = "2000-04-21"; - srcs = map ({ url, hash }: - fetchzip { - name = builtins.baseNameOf url; - stripRoot = false; - inherit url hash; - }) [ - { - url = - "https://web.archive.org/web/20200131023120/http://eurofurence.net/eurof_tt.zip"; - hash = "sha256-Al4tT2/qV9/K5le/OctybxgPcNMVDJi0OPr2EUBk8cE="; - } - { - url = - "https://web.archive.org/web/20200130083325/http://eurofurence.net/eurofctt.zip"; - hash = "sha256-ZF0Neysp0+TQgNAN+2IrfR/7dn043rSq6S3NHJ3gLUI="; - } - { - url = - "https://web.archive.org/web/20200206093756/http://eurofurence.net/monof_tt.zip"; - hash = "sha256-Kvcsp/0LzHhwPudP1qWLxhaiJ5/su1k7FBuV9XPKIGs="; - } - { - url = - "https://web.archive.org/web/20200206171841/http://eurofurence.net/pagebxtt.zip"; - hash = "sha256-CvKhzvxSQqdEHihQBfCSu1QgjzKn38DWaONdz5BpM4M="; - } - { - url = - "https://web.archive.org/web/20190812003003/http://eurofurence.net/unifurtt.zip"; - hash = "sha256-n9xnzJi8wvK6oCVQUQnQ1X9jW6WgyMKKIiDsT4j2Aas="; - } - ]; + srcs = + map + ( + { url, hash }: + fetchzip { + name = builtins.baseNameOf url; + stripRoot = false; + inherit url hash; + } + ) + [ + { + url = "https://web.archive.org/web/20200131023120/http://eurofurence.net/eurof_tt.zip"; + hash = "sha256-Al4tT2/qV9/K5le/OctybxgPcNMVDJi0OPr2EUBk8cE="; + } + { + url = "https://web.archive.org/web/20200130083325/http://eurofurence.net/eurofctt.zip"; + hash = "sha256-ZF0Neysp0+TQgNAN+2IrfR/7dn043rSq6S3NHJ3gLUI="; + } + { + url = "https://web.archive.org/web/20200206093756/http://eurofurence.net/monof_tt.zip"; + hash = "sha256-Kvcsp/0LzHhwPudP1qWLxhaiJ5/su1k7FBuV9XPKIGs="; + } + { + url = "https://web.archive.org/web/20200206171841/http://eurofurence.net/pagebxtt.zip"; + hash = "sha256-CvKhzvxSQqdEHihQBfCSu1QgjzKn38DWaONdz5BpM4M="; + } + { + url = "https://web.archive.org/web/20190812003003/http://eurofurence.net/unifurtt.zip"; + hash = "sha256-n9xnzJi8wvK6oCVQUQnQ1X9jW6WgyMKKIiDsT4j2Aas="; + } + ]; dontUnpack = true; @@ -49,8 +53,7 @@ stdenvNoCC.mkDerivation { ''; meta = { - homepage = - "https://web.archive.org/web/20200131023120/http://eurofurence.net/eurofurence.html"; + homepage = "https://web.archive.org/web/20200131023120/http://eurofurence.net/eurofurence.html"; description = "Family of geometric rounded sans serif fonts"; maintainers = with lib.maintainers; [ ehmry ]; license = lib.licenses.free; diff --git a/pkgs/by-name/ev/eva/package.nix b/pkgs/by-name/ev/eva/package.nix index 93645a92203c26..7509a4e9ff69ee 100644 --- a/pkgs/by-name/ev/eva/package.nix +++ b/pkgs/by-name/ev/eva/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "eva"; @@ -15,7 +19,11 @@ rustPlatform.buildRustPackage rec { description = "Calculator REPL, similar to bc"; homepage = "https://github.com/NerdyPepper/eva"; license = licenses.mit; - maintainers = with maintainers; [ nrdxp ma27 figsoda ]; + maintainers = with maintainers; [ + nrdxp + ma27 + figsoda + ]; mainProgram = "eva"; }; } diff --git a/pkgs/by-name/ev/evans/package.nix b/pkgs/by-name/ev/evans/package.nix index 89ed0fbfb17375..8deac905eff6a7 100644 --- a/pkgs/by-name/ev/evans/package.nix +++ b/pkgs/by-name/ev/evans/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "evans"; diff --git a/pkgs/by-name/ev/evcc/package.nix b/pkgs/by-name/ev/evcc/package.nix index 6848e68576ba5e..f45281b1cc2614 100644 --- a/pkgs/by-name/ev/evcc/package.nix +++ b/pkgs/by-name/ev/evcc/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, fetchNpmDeps -, cacert -, git -, go -, enumer -, mockgen -, nodejs -, npmHooks -, nix-update-script -, nixosTests +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + fetchNpmDeps, + cacert, + git, + go, + enumer, + mockgen, + nodejs, + npmHooks, + nix-update-script, + nixosTests, }: buildGoModule rec { @@ -69,15 +70,16 @@ buildGoModule rec { doCheck = !stdenv.hostPlatform.isDarwin; # darwin sandbox limitations around network access, access to /etc/protocols and likely more - checkFlags = let - skippedTests = [ - # network access - "TestOctopusConfigParse" - "TestTemplates" - "TestOcpp" - ]; - in - [ "-skip=^${lib.concatStringsSep "$|^" skippedTests}$" ]; + checkFlags = + let + skippedTests = [ + # network access + "TestOctopusConfigParse" + "TestTemplates" + "TestOcpp" + ]; + in + [ "-skip=^${lib.concatStringsSep "$|^" skippedTests}$" ]; passthru = { tests = { diff --git a/pkgs/by-name/ev/evdevremapkeys/package.nix b/pkgs/by-name/ev/evdevremapkeys/package.nix index 2dcc169c644497..cd4ec0cd98b4b0 100644 --- a/pkgs/by-name/ev/evdevremapkeys/package.nix +++ b/pkgs/by-name/ev/evdevremapkeys/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonPackage rec { pname = "evdevremapkeys"; diff --git a/pkgs/by-name/ev/evebox/package.nix b/pkgs/by-name/ev/evebox/package.nix index 4b09fba8675b99..399db1accb2933 100644 --- a/pkgs/by-name/ev/evebox/package.nix +++ b/pkgs/by-name/ev/evebox/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ev/evemu/package.nix b/pkgs/by-name/ev/evemu/package.nix index 6cb349c546b9b6..06df7e1471a0c8 100644 --- a/pkgs/by-name/ev/evemu/package.nix +++ b/pkgs/by-name/ev/evemu/package.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchgit, autoreconfHook, pkg-config, python3Packages -, libevdev +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + pkg-config, + python3Packages, + libevdev, }: stdenv.mkDerivation rec { @@ -14,16 +20,26 @@ stdenv.mkDerivation rec { sha256 = "sha256-SQDaARuqBMBVlUz+Nw6mjdxaZfVOukmzTlIqy8U2rus="; }; - nativeBuildInputs = [ pkg-config autoreconfHook python3Packages.python ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + python3Packages.python + ]; - buildInputs = [ python3Packages.evdev libevdev ]; + buildInputs = [ + python3Packages.evdev + libevdev + ]; strictDeps = true; meta = with lib; { description = "Records and replays device descriptions and events to emulate input devices through the kernel's input system"; homepage = "https://www.freedesktop.org/wiki/Evemu/"; - license = with licenses; [ lgpl3Only gpl3Only ]; + license = with licenses; [ + lgpl3Only + gpl3Only + ]; maintainers = [ maintainers.amorsillo ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/ev/eventlog/package.nix b/pkgs/by-name/ev/eventlog/package.nix index b5b4bc556f693a..ee503578ec3e35 100644 --- a/pkgs/by-name/ev/eventlog/package.nix +++ b/pkgs/by-name/ev/eventlog/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "eventlog"; diff --git a/pkgs/by-name/ev/eventstat/package.nix b/pkgs/by-name/ev/eventstat/package.nix index e54135f3e72eda..6c40ce6f009c60 100644 --- a/pkgs/by-name/ev/eventstat/package.nix +++ b/pkgs/by-name/ev/eventstat/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, ncurses }: +{ + stdenv, + lib, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { pname = "eventstat"; diff --git a/pkgs/by-name/ev/everdo/package.nix b/pkgs/by-name/ev/everdo/package.nix index 97934fb9c21a93..9c9170360bc21c 100644 --- a/pkgs/by-name/ev/everdo/package.nix +++ b/pkgs/by-name/ev/everdo/package.nix @@ -2,7 +2,8 @@ appimageTools, lib, fetchurl, -}: let +}: +let pname = "everdo"; version = "1.9.0"; @@ -11,24 +12,24 @@ hash = "sha256-0yxAzM+qmgm4E726QDYS9QwMdp6dUcuvjZzWYEZx7kU="; }; - appimageContents = appimageTools.extractType2 {inherit pname version src;}; + appimageContents = appimageTools.extractType2 { inherit pname version src; }; in - appimageTools.wrapType2 { - inherit pname version src; +appimageTools.wrapType2 { + inherit pname version src; - extraInstallCommands = '' - install -Dm444 ${appimageContents}/everdo.desktop -t $out/share/applications - substituteInPlace $out/share/applications/everdo.desktop \ - --replace-fail 'Exec=AppRun --no-sandbox %U' 'Exec=everdo %u' - cp -r ${appimageContents}/usr/share/icons $out/share - ''; + extraInstallCommands = '' + install -Dm444 ${appimageContents}/everdo.desktop -t $out/share/applications + substituteInPlace $out/share/applications/everdo.desktop \ + --replace-fail 'Exec=AppRun --no-sandbox %U' 'Exec=everdo %u' + cp -r ${appimageContents}/usr/share/icons $out/share + ''; - meta = { - description = "Cross-platform GTD app with focus on privacy"; - homepage = "https://everdo.net/"; - license = lib.licenses.unfree; - maintainers = [lib.maintainers.luftmensch-luftmensch]; - mainProgram = "everdo"; - platforms = ["x86_64-linux"]; - }; - } + meta = { + description = "Cross-platform GTD app with focus on privacy"; + homepage = "https://everdo.net/"; + license = lib.licenses.unfree; + maintainers = [ lib.maintainers.luftmensch-luftmensch ]; + mainProgram = "everdo"; + platforms = [ "x86_64-linux" ]; + }; +} diff --git a/pkgs/by-name/ev/everest-mons/package.nix b/pkgs/by-name/ev/everest-mons/package.nix index 82054c21cb2c4a..40867013870d21 100644 --- a/pkgs/by-name/ev/everest-mons/package.nix +++ b/pkgs/by-name/ev/everest-mons/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchPypi -, python3Packages -} : +{ + lib, + fetchPypi, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "everest-mons"; diff --git a/pkgs/by-name/ev/everforest-gtk-theme/package.nix b/pkgs/by-name/ev/everforest-gtk-theme/package.nix index b20e4505a5c6b2..5b39290296eec1 100644 --- a/pkgs/by-name/ev/everforest-gtk-theme/package.nix +++ b/pkgs/by-name/ev/everforest-gtk-theme/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gnome-themes-extra -, gtk-engine-murrine +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gnome-themes-extra, + gtk-engine-murrine, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/ev/everspace/package.nix b/pkgs/by-name/ev/everspace/package.nix index 482ebfa98a763b..f3657f1189c76b 100644 --- a/pkgs/by-name/ev/everspace/package.nix +++ b/pkgs/by-name/ev/everspace/package.nix @@ -1,12 +1,23 @@ { # Packaging Dependencies - lib, stdenv, requireFile, autoPatchelfHook, unzip, copyDesktopItems, makeDesktopItem, + lib, + stdenv, + requireFile, + autoPatchelfHook, + unzip, + copyDesktopItems, + makeDesktopItem, # Everspace Dependencies - cairo, gdk-pixbuf, pango, gtk2-x11, libGL, openal, + cairo, + gdk-pixbuf, + pango, + gtk2-x11, + libGL, + openal, # Unreal Engine 4 Dependencies - xorg + xorg, }: # Known issues: diff --git a/pkgs/by-name/ev/evhz/package.nix b/pkgs/by-name/ev/evhz/package.nix index 712606c6913a17..c13147c3caad02 100644 --- a/pkgs/by-name/ev/evhz/package.nix +++ b/pkgs/by-name/ev/evhz/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromSourcehut +{ + lib, + stdenv, + fetchFromSourcehut, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ev/evil-helix/package.nix b/pkgs/by-name/ev/evil-helix/package.nix index e53faa61d6d947..151aa1a278f83c 100644 --- a/pkgs/by-name/ev/evil-helix/package.nix +++ b/pkgs/by-name/ev/evil-helix/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, helix -, installShellFiles -, rustPlatform +{ + lib, + fetchFromGitHub, + helix, + installShellFiles, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ev/evil-winrm/gemset.nix b/pkgs/by-name/ev/evil-winrm/gemset.nix index 6c468c2c59fbb5..e8323a6341e7e1 100644 --- a/pkgs/by-name/ev/evil-winrm/gemset.nix +++ b/pkgs/by-name/ev/evil-winrm/gemset.nix @@ -1,206 +1,227 @@ { base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; builder = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pw3r2lyagsxkm71bf44v5b74f7l9r7di22brbyji9fwz791hya9"; type = "gem"; }; version = "3.3.0"; }; erubi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qnd6ff4az22ysnmni3730c41b979xinilahzg86bn7gv93ip9pw"; type = "gem"; }; version = "1.13.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; fileutils = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0c86k3027r896wsgvjgdx27kg5d2x4479bc6ni93w9hq88rgp81n"; type = "gem"; }; version = "1.7.2"; }; gssapi = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qdfhj12aq8v0y961v4xv96a1y2z80h3xhvzrs9vsfgf884g6765"; type = "gem"; }; version = "1.3.1"; }; gyoku = { - dependencies = ["builder" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "builder" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kd2q59xpm39hpvmmvyi6g3f1fr05xjbnxwkrdqz4xy7hirqi79q"; type = "gem"; }; version = "1.4.0"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; little-plugger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1frilv82dyxnlg8k1jhrvyd73l6k17mxc5vwxx080r4x1p04gwym"; type = "gem"; }; version = "1.1.4"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; logging = { - dependencies = ["little-plugger" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "little-plugger" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1jqcq2yxh973f3aw63nd3wxhqyhkncz3pf8v2gs3df0iqair725s"; type = "gem"; }; version = "2.4.0"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; nori = { - dependencies = ["bigdecimal"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bigdecimal" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qb84bbi74q0zgs09sdkq750jf2ri3lblbry0xi4g1ard4rwsrk1"; type = "gem"; }; version = "2.7.1"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rr145mvjgc4n28lfy0gw87aw3ab680h83bdi5i102ik8mixk3zn"; type = "gem"; }; version = "3.3.8"; }; rubyntlm = { - dependencies = ["base64"]; - groups = ["default"]; - platforms = []; + dependencies = [ "base64" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x8l0d1v88m40mby4jvgal46137cv8gga2lk7zlrxqlsp41380a7"; type = "gem"; }; version = "0.6.5"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; stringio = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07mfqb40b2wh53k33h91zva78f9zwcdnl85jiq74wnaw2wa6wiak"; type = "gem"; }; version = "3.1.1"; }; winrm = { - dependencies = ["builder" "erubi" "gssapi" "gyoku" "httpclient" "logging" "nori" "rexml" "rubyntlm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "builder" + "erubi" + "gssapi" + "gyoku" + "httpclient" + "logging" + "nori" + "rexml" + "rubyntlm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "01jxpshw5kx5ha21ymaaj14vibv5bvm0dd80ccc6xl3jaxy7cszg"; type = "gem"; }; version = "2.3.9"; }; winrm-fs = { - dependencies = ["erubi" "logging" "rubyzip" "winrm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "erubi" + "logging" + "rubyzip" + "winrm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gb91k6s1yjqw387x4w1nkpnxblq3pjdqckayl0qvz5n3ygdsb0d"; type = "gem"; }; diff --git a/pkgs/by-name/ev/evillimiter/package.nix b/pkgs/by-name/ev/evillimiter/package.nix index 9f4fb0bfc2f413..d96b54a9538ca6 100644 --- a/pkgs/by-name/ev/evillimiter/package.nix +++ b/pkgs/by-name/ev/evillimiter/package.nix @@ -34,7 +34,7 @@ python3Packages.buildPythonApplication rec { # Project has no tests doCheck = false; - meta = with lib; { + meta = with lib; { description = "Tool that monitors, analyzes and limits the bandwidth"; longDescription = '' A tool to monitor, analyze and limit the bandwidth (upload/download) of diff --git a/pkgs/by-name/ev/evince/package.nix b/pkgs/by-name/ev/evince/package.nix index 065613a6d7af77..a8837ff202457c 100644 --- a/pkgs/by-name/ev/evince/package.nix +++ b/pkgs/by-name/ev/evince/package.nix @@ -1,49 +1,54 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, gettext -, libxml2 -, appstream -, desktop-file-utils -, glib -, gtk3 -, pango -, atk -, gdk-pixbuf -, shared-mime-info -, itstool -, gnome -, poppler -, ghostscriptX -, djvulibre -, libspectre -, libarchive -, libgxps -, libhandy -, libsecret -, wrapGAppsHook3 -, librsvg -, gobject-introspection -, yelp-tools -, gspell -, gsettings-desktop-schemas -, gnome-desktop -, dbus -, texlive -, gst_all_1 -, gi-docgen -, supportMultimedia ? true # PDF multimedia -, withLibsecret ? true +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + gettext, + libxml2, + appstream, + desktop-file-utils, + glib, + gtk3, + pango, + atk, + gdk-pixbuf, + shared-mime-info, + itstool, + gnome, + poppler, + ghostscriptX, + djvulibre, + libspectre, + libarchive, + libgxps, + libhandy, + libsecret, + wrapGAppsHook3, + librsvg, + gobject-introspection, + yelp-tools, + gspell, + gsettings-desktop-schemas, + gnome-desktop, + dbus, + texlive, + gst_all_1, + gi-docgen, + supportMultimedia ? true, # PDF multimedia + withLibsecret ? true, }: stdenv.mkDerivation (finalAttrs: { pname = "evince"; version = "46.3.1"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/evince/${lib.versions.major finalAttrs.version}/evince-${finalAttrs.version}.tar.xz"; @@ -68,45 +73,54 @@ stdenv.mkDerivation (finalAttrs: { yelp-tools ]; - buildInputs = [ - atk - dbus # only needed to find the service directory - djvulibre - gdk-pixbuf - ghostscriptX - glib - gnome-desktop - gsettings-desktop-schemas - gspell - gtk3 - libarchive - libgxps - libhandy - librsvg - libspectre - libxml2 - pango - poppler - texlive.bin.core # kpathsea for DVI support - ] ++ lib.optionals withLibsecret [ - libsecret - ] ++ lib.optionals supportMultimedia (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-good - gst-plugins-bad - gst-plugins-ugly - gst-libav - ]); + buildInputs = + [ + atk + dbus # only needed to find the service directory + djvulibre + gdk-pixbuf + ghostscriptX + glib + gnome-desktop + gsettings-desktop-schemas + gspell + gtk3 + libarchive + libgxps + libhandy + librsvg + libspectre + libxml2 + pango + poppler + texlive.bin.core # kpathsea for DVI support + ] + ++ lib.optionals withLibsecret [ + libsecret + ] + ++ lib.optionals supportMultimedia ( + with gst_all_1; + [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + gst-plugins-ugly + gst-libav + ] + ); - mesonFlags = [ - "-Dnautilus=false" - "-Dps=enabled" - ] ++ lib.optionals (!withLibsecret) [ - "-Dkeyring=disabled" - ] ++ lib.optionals (!supportMultimedia) [ - "-Dmultimedia=disabled" - ]; + mesonFlags = + [ + "-Dnautilus=false" + "-Dps=enabled" + ] + ++ lib.optionals (!withLibsecret) [ + "-Dkeyring=disabled" + ] + ++ lib.optionals (!supportMultimedia) [ + "-Dmultimedia=disabled" + ]; preFixup = '' gappsWrapperArgs+=(--prefix XDG_DATA_DIRS : "${shared-mime-info}/share") diff --git a/pkgs/by-name/ev/evolution-data-server/package.nix b/pkgs/by-name/ev/evolution-data-server/package.nix index 07d16d22110c4a..d596e3f0ddb658 100644 --- a/pkgs/by-name/ev/evolution-data-server/package.nix +++ b/pkgs/by-name/ev/evolution-data-server/package.nix @@ -1,57 +1,61 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, gnome -, _experimental-update-script-combinators -, python3 -, gobject-introspection -, gettext -, libsoup_3 -, libxml2 -, libsecret -, icu -, sqlite -, libcanberra-gtk3 -, p11-kit -, db -, nspr -, nss -, libical -, gperf -, wrapGAppsHook3 -, glib-networking -, gsettings-desktop-schemas -, pcre -, vala -, cmake -, ninja -, libkrb5 -, openldap -, enableOAuth2 ? stdenv.hostPlatform.isLinux -, webkitgtk_4_1 -, webkitgtk_6_0 -, json-glib -, glib -, gtk3 -, gtk4 -, withGtk3 ? true -, withGtk4 ? false -, libphonenumber -, libuuid -, gnome-online-accounts -, libgweather -, boost -, protobuf -, libiconv -, makeHardcodeGsettingsPatch +{ + stdenv, + lib, + fetchurl, + pkg-config, + gnome, + _experimental-update-script-combinators, + python3, + gobject-introspection, + gettext, + libsoup_3, + libxml2, + libsecret, + icu, + sqlite, + libcanberra-gtk3, + p11-kit, + db, + nspr, + nss, + libical, + gperf, + wrapGAppsHook3, + glib-networking, + gsettings-desktop-schemas, + pcre, + vala, + cmake, + ninja, + libkrb5, + openldap, + enableOAuth2 ? stdenv.hostPlatform.isLinux, + webkitgtk_4_1, + webkitgtk_6_0, + json-glib, + glib, + gtk3, + gtk4, + withGtk3 ? true, + withGtk4 ? false, + libphonenumber, + libuuid, + gnome-online-accounts, + libgweather, + boost, + protobuf, + libiconv, + makeHardcodeGsettingsPatch, }: stdenv.mkDerivation rec { pname = "evolution-data-server"; version = "3.54.2"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/evolution-data-server/${lib.versions.majorMinor version}/evolution-data-server-${version}.tar.xz"; @@ -83,35 +87,41 @@ stdenv.mkDerivation rec { vala ]; - buildInputs = [ - glib - libsecret - libsoup_3 - gnome-online-accounts - p11-kit - libgweather - icu - sqlite - libkrb5 - openldap - glib-networking - libcanberra-gtk3 - pcre - libphonenumber - libuuid - boost - protobuf - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - ] ++ lib.optionals withGtk3 [ - gtk3 - ] ++ lib.optionals (withGtk3 && enableOAuth2) [ - webkitgtk_4_1 - ] ++ lib.optionals withGtk4 [ - gtk4 - ] ++ lib.optionals (withGtk4 && enableOAuth2) [ - webkitgtk_6_0 - ]; + buildInputs = + [ + glib + libsecret + libsoup_3 + gnome-online-accounts + p11-kit + libgweather + icu + sqlite + libkrb5 + openldap + glib-networking + libcanberra-gtk3 + pcre + libphonenumber + libuuid + boost + protobuf + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + ] + ++ lib.optionals withGtk3 [ + gtk3 + ] + ++ lib.optionals (withGtk3 && enableOAuth2) [ + webkitgtk_4_1 + ] + ++ lib.optionals withGtk4 [ + gtk4 + ] + ++ lib.optionals (withGtk4 && enableOAuth2) [ + webkitgtk_6_0 + ]; propagatedBuildInputs = [ db diff --git a/pkgs/by-name/ev/evscript/package.nix b/pkgs/by-name/ev/evscript/package.nix index dfd170a9a33b05..803e2e06585fbc 100644 --- a/pkgs/by-name/ev/evscript/package.nix +++ b/pkgs/by-name/ev/evscript/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitea }: +{ + lib, + rustPlatform, + fetchFromGitea, +}: rustPlatform.buildRustPackage rec { pname = "evscript"; diff --git a/pkgs/by-name/ev/evsieve/package.nix b/pkgs/by-name/ev/evsieve/package.nix index b900b136974e28..a727b941b6b573 100644 --- a/pkgs/by-name/ev/evsieve/package.nix +++ b/pkgs/by-name/ev/evsieve/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, libevdev +{ + lib, + fetchFromGitHub, + rustPlatform, + libevdev, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ev/evtest/package.nix b/pkgs/by-name/ev/evtest/package.nix index 39f8ea8c0f837e..13a497058048d6 100644 --- a/pkgs/by-name/ev/evtest/package.nix +++ b/pkgs/by-name/ev/evtest/package.nix @@ -1,10 +1,20 @@ -{ lib, stdenv, fetchgit, autoreconfHook, pkg-config, libxml2 }: +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + pkg-config, + libxml2, +}: stdenv.mkDerivation rec { pname = "evtest"; version = "1.35"; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libxml2 ]; src = fetchgit { diff --git a/pkgs/by-name/ew/eweb/package.nix b/pkgs/by-name/ew/eweb/package.nix index 1a885af12187df..ccd36c838a2d06 100644 --- a/pkgs/by-name/ew/eweb/package.nix +++ b/pkgs/by-name/ew/eweb/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, python3, asciidoc }: +{ + lib, + stdenv, + fetchurl, + python3, + asciidoc, +}: stdenv.mkDerivation rec { pname = "eweb"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1xy7vm2sj5q6s620fm25klmnwnz9xkrxmx4q2f8h6c85ydisayd5"; }; - buildInputs = [ python3 asciidoc ]; + buildInputs = [ + python3 + asciidoc + ]; installPhase = '' install -d $out/bin $out/share/doc/${pname}-${version} diff --git a/pkgs/by-name/ex/exabgp/package.nix b/pkgs/by-name/ex/exabgp/package.nix index f00b427b15a2a9..7d8f4917a711f7 100644 --- a/pkgs/by-name/ex/exabgp/package.nix +++ b/pkgs/by-name/ex/exabgp/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3 -, fetchFromGitHub -, exabgp -, testers +{ + lib, + python3, + fetchFromGitHub, + exabgp, + testers, }: python3.pkgs.buildPythonApplication rec { @@ -40,6 +41,9 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://github.com/Exa-Networks/exabgp"; changelog = "https://github.com/Exa-Networks/exabgp/blob/${src.rev}/CHANGELOG.rst"; license = licenses.bsd3; - maintainers = with maintainers; [ hexa raitobezarius ]; + maintainers = with maintainers; [ + hexa + raitobezarius + ]; }; } diff --git a/pkgs/by-name/ex/exactaudiocopy/package.nix b/pkgs/by-name/ex/exactaudiocopy/package.nix index ec7dad91a80843..b173675d9672d3 100644 --- a/pkgs/by-name/ex/exactaudiocopy/package.nix +++ b/pkgs/by-name/ex/exactaudiocopy/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, makeDesktopItem -, imagemagick -, p7zip -, wine -, writeShellScriptBin -, symlinkJoin -, use64 ? false +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + imagemagick, + p7zip, + wine, + writeShellScriptBin, + symlinkJoin, + use64 ? false, }: let @@ -66,14 +67,20 @@ let exec = pname; comment = "Audio Grabber for CDs"; desktopName = "Exact Audio Copy"; - categories = [ "Audio" "AudioVideo" ]; + categories = [ + "Audio" + "AudioVideo" + ]; icon = "${patched_eac}/eac.ico.128.png"; }; in symlinkJoin { name = "${pname}-${version}"; - paths = [ wrapper desktopItem ]; + paths = [ + wrapper + desktopItem + ]; meta = with lib; { description = "Precise CD audio grabber for creating perfect quality rips using CD and DVD drives"; diff --git a/pkgs/by-name/ex/exaile/package.nix b/pkgs/by-name/ex/exaile/package.nix index 5387069072f5f6..4d207db06959e6 100644 --- a/pkgs/by-name/ex/exaile/package.nix +++ b/pkgs/by-name/ex/exaile/package.nix @@ -1,22 +1,37 @@ -{ stdenv, lib, fetchFromGitHub -, gobject-introspection, makeWrapper, wrapGAppsHook3 -, gtk3, gst_all_1, python3 -, gettext, adwaita-icon-theme, help2man, keybinder3, libnotify, librsvg, streamripper, udisks, webkitgtk_4_0 -, iconTheme ? adwaita-icon-theme -, deviceDetectionSupport ? true -, documentationSupport ? true -, notificationSupport ? true -, scalableIconSupport ? true -, translationSupport ? true -, ipythonSupport ? false -, cdMetadataSupport ? false -, lastfmSupport ? false -, lyricsManiaSupport ? false -, multimediaKeySupport ? false -, musicBrainzSupport ? false -, podcastSupport ? false -, streamripperSupport ? false -, wikipediaSupport ? false +{ + stdenv, + lib, + fetchFromGitHub, + gobject-introspection, + makeWrapper, + wrapGAppsHook3, + gtk3, + gst_all_1, + python3, + gettext, + adwaita-icon-theme, + help2man, + keybinder3, + libnotify, + librsvg, + streamripper, + udisks, + webkitgtk_4_0, + iconTheme ? adwaita-icon-theme, + deviceDetectionSupport ? true, + documentationSupport ? true, + notificationSupport ? true, + scalableIconSupport ? true, + translationSupport ? true, + ipythonSupport ? false, + cdMetadataSupport ? false, + lastfmSupport ? false, + lyricsManiaSupport ? false, + multimediaKeySupport ? false, + musicBrainzSupport ? false, + podcastSupport ? false, + streamripperSupport ? false, + wikipediaSupport ? false, }: stdenv.mkDerivation rec { @@ -30,44 +45,51 @@ stdenv.mkDerivation rec { sha256 = "sha256-9SK0nvGdz2j6qp1JTmSuLezxX/kB93CZReSfAnfKZzg="; }; - nativeBuildInputs = [ - gobject-introspection - makeWrapper - wrapGAppsHook3 - ] ++ lib.optionals documentationSupport [ - help2man - python3.pkgs.sphinx - python3.pkgs.sphinx-rtd-theme - ] ++ lib.optional translationSupport gettext; + nativeBuildInputs = + [ + gobject-introspection + makeWrapper + wrapGAppsHook3 + ] + ++ lib.optionals documentationSupport [ + help2man + python3.pkgs.sphinx + python3.pkgs.sphinx-rtd-theme + ] + ++ lib.optional translationSupport gettext; - buildInputs = [ - iconTheme - gtk3 - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-good - gst-plugins-bad - gst-plugins-ugly - gst-libav - ]) ++ (with python3.pkgs; [ - berkeleydb - dbus-python - mutagen - pygobject3 - pycairo - gst-python - ]) ++ lib.optional deviceDetectionSupport udisks - ++ lib.optional notificationSupport libnotify - ++ lib.optional scalableIconSupport librsvg - ++ lib.optional ipythonSupport python3.pkgs.ipython - ++ lib.optional cdMetadataSupport python3.pkgs.discid - ++ lib.optional lastfmSupport python3.pkgs.pylast - ++ lib.optional lyricsManiaSupport python3.pkgs.lxml - ++ lib.optional multimediaKeySupport keybinder3 - ++ lib.optional (musicBrainzSupport || cdMetadataSupport) python3.pkgs.musicbrainzngs - ++ lib.optional podcastSupport python3.pkgs.feedparser - ++ lib.optional wikipediaSupport webkitgtk_4_0; + buildInputs = + [ + iconTheme + gtk3 + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + gst-plugins-ugly + gst-libav + ]) + ++ (with python3.pkgs; [ + berkeleydb + dbus-python + mutagen + pygobject3 + pycairo + gst-python + ]) + ++ lib.optional deviceDetectionSupport udisks + ++ lib.optional notificationSupport libnotify + ++ lib.optional scalableIconSupport librsvg + ++ lib.optional ipythonSupport python3.pkgs.ipython + ++ lib.optional cdMetadataSupport python3.pkgs.discid + ++ lib.optional lastfmSupport python3.pkgs.pylast + ++ lib.optional lyricsManiaSupport python3.pkgs.lxml + ++ lib.optional multimediaKeySupport keybinder3 + ++ lib.optional (musicBrainzSupport || cdMetadataSupport) python3.pkgs.musicbrainzngs + ++ lib.optional podcastSupport python3.pkgs.feedparser + ++ lib.optional wikipediaSupport webkitgtk_4_0; nativeCheckInputs = with python3.pkgs; [ pytest @@ -87,7 +109,9 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/exaile \ --set PYTHONPATH $PYTHONPATH \ - --prefix PATH : ${lib.makeBinPath ([ python3 ] ++ lib.optionals streamripperSupport [ streamripper ]) } + --prefix PATH : ${ + lib.makeBinPath ([ python3 ] ++ lib.optionals streamripperSupport [ streamripper ]) + } ''; meta = with lib; { diff --git a/pkgs/by-name/ex/exe2hex/package.nix b/pkgs/by-name/ex/exe2hex/package.nix index 485e0104cba24e..0c603eb6c3fa19 100644 --- a/pkgs/by-name/ex/exe2hex/package.nix +++ b/pkgs/by-name/ex/exe2hex/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3Packages -, expect +{ + lib, + fetchFromGitHub, + python3Packages, + expect, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ex/exempi/package.nix b/pkgs/by-name/ex/exempi/package.nix index ccdd0048e2aaa3..26b57d89e758be 100644 --- a/pkgs/by-name/ex/exempi/package.nix +++ b/pkgs/by-name/ex/exempi/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, expat, zlib, boost, libiconv, darwin }: +{ + lib, + stdenv, + fetchurl, + expat, + zlib, + boost, + libiconv, + darwin, +}: stdenv.mkDerivation rec { pname = "exempi"; @@ -9,14 +18,24 @@ stdenv.mkDerivation rec { sha256 = "sha256-6fmj1Cv/c7XrD3fsIs0BY8PiGUnMQUrR8ZoEZd3kH/4="; }; - configureFlags = [ - "--with-boost=${boost.dev}" - ] ++ lib.optionals (!doCheck) [ - "--enable-unittest=no" - ]; + configureFlags = + [ + "--with-boost=${boost.dev}" + ] + ++ lib.optionals (!doCheck) [ + "--enable-unittest=no" + ]; - buildInputs = [ expat zlib boost ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv darwin.apple_sdk.frameworks.CoreServices ]; + buildInputs = + [ + expat + zlib + boost + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + darwin.apple_sdk.frameworks.CoreServices + ]; doCheck = stdenv.hostPlatform.isLinux && stdenv.hostPlatform.is64bit; dontDisableStatic = doCheck; diff --git a/pkgs/by-name/ex/exercism/package.nix b/pkgs/by-name/ex/exercism/package.nix index b50ce09f98009b..2dc94860e8ea2d 100644 --- a/pkgs/by-name/ex/exercism/package.nix +++ b/pkgs/by-name/ex/exercism/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nix-update-script }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, +}: buildGoModule rec { pname = "exercism"; @@ -6,9 +11,9 @@ buildGoModule rec { src = fetchFromGitHub { owner = "exercism"; - repo = "cli"; - rev = "refs/tags/v${version}"; - hash = "sha256-7euitdo/rdeopnP7hHHxQ5lPh8wJVDaTneckeR5BEGo="; + repo = "cli"; + rev = "refs/tags/v${version}"; + hash = "sha256-7euitdo/rdeopnP7hHHxQ5lPh8wJVDaTneckeR5BEGo="; }; vendorHash = "sha256-xY3C3emqtPIKyxIN9aEkrLXhTxWNmo0EJXNZVtbtIvs="; @@ -20,10 +25,13 @@ buildGoModule rec { passthru.updateScript = nix-update-script { }; meta = with lib; { - inherit (src.meta) homepage; - description = "Go based command line tool for exercism.io"; - license = licenses.mit; - maintainers = [ maintainers.rbasso maintainers.nobbz ]; - mainProgram = "exercism"; + inherit (src.meta) homepage; + description = "Go based command line tool for exercism.io"; + license = licenses.mit; + maintainers = [ + maintainers.rbasso + maintainers.nobbz + ]; + mainProgram = "exercism"; }; } diff --git a/pkgs/by-name/ex/exfat/package.nix b/pkgs/by-name/ex/exfat/package.nix index 831f19c68f68b4..3d7d66648a401a 100644 --- a/pkgs/by-name/ex/exfat/package.nix +++ b/pkgs/by-name/ex/exfat/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, fuse }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + fuse, +}: stdenv.mkDerivation rec { pname = "exfat"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-5m8fiItEOO6piR132Gxq6SHOPN1rAFTuTVE+UI0V00k="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ fuse ]; meta = with lib; { diff --git a/pkgs/by-name/ex/exfatprogs/package.nix b/pkgs/by-name/ex/exfatprogs/package.nix index aef76521b9f51e..ef23f869cee014 100644 --- a/pkgs/by-name/ex/exfatprogs/package.nix +++ b/pkgs/by-name/ex/exfatprogs/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, autoreconfHook, file }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + file, +}: stdenv.mkDerivation rec { pname = "exfatprogs"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-VUvVPABgQ7EUQu90DbWU7a+YThrWhusTk/YreKSqU/M="; }; - nativeBuildInputs = [ pkg-config autoreconfHook file ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + file + ]; meta = with lib; { description = "exFAT filesystem userspace utilities"; diff --git a/pkgs/by-name/ex/exhaustive/package.nix b/pkgs/by-name/ex/exhaustive/package.nix index 0356306bc0c22a..d322c54b1f8e9c 100644 --- a/pkgs/by-name/ex/exhaustive/package.nix +++ b/pkgs/by-name/ex/exhaustive/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, }: buildGoModule rec { @@ -17,7 +18,10 @@ buildGoModule rec { vendorHash = "sha256-DyN2z6+lA/163k6TTQZ+ypm9s2EV93zvSo/yKQZXvCg="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru = { updateScript = nix-update-script { }; diff --git a/pkgs/by-name/ex/exif/package.nix b/pkgs/by-name/ex/exif/package.nix index 30b0d6c10eee9d..dd5737c069737b 100644 --- a/pkgs/by-name/ex/exif/package.nix +++ b/pkgs/by-name/ex/exif/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, pkg-config -, libexif -, popt -, libintl +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + libexif, + popt, + libintl, }: stdenv.mkDerivation rec { @@ -16,7 +17,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "libexif"; repo = pname; - rev = "${pname}-${builtins.replaceStrings ["."] ["_"] version}-release"; + rev = "${pname}-${builtins.replaceStrings [ "." ] [ "_" ] version}-release"; sha256 = "1xlb1gdwxm3rmw7vlrynhvjp9dkwmvw23mxisdbdmma7ah2nda3i"; }; @@ -33,8 +34,15 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libexif popt libintl ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libexif + popt + libintl + ]; meta = with lib; { homepage = "https://libexif.github.io"; diff --git a/pkgs/by-name/ex/exiflooter/package.nix b/pkgs/by-name/ex/exiflooter/package.nix index 9e23cf5b1c866d..68eb8d9cab4fb0 100644 --- a/pkgs/by-name/ex/exiflooter/package.nix +++ b/pkgs/by-name/ex/exiflooter/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-uV7O2H3gPQ+kFdEHLgM+v+TXn+87QfFwOAEQpnKQIQk="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Finds geolocation on all image urls and directories"; diff --git a/pkgs/by-name/ex/exifprobe/package.nix b/pkgs/by-name/ex/exifprobe/package.nix index 7331ac69185ae1..859232ebc08c9e 100644 --- a/pkgs/by-name/ex/exifprobe/package.nix +++ b/pkgs/by-name/ex/exifprobe/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "exifprobe"; diff --git a/pkgs/by-name/ex/exiftags/package.nix b/pkgs/by-name/ex/exiftags/package.nix index 5bd736911c7392..6479cfd3356f61 100644 --- a/pkgs/by-name/ex/exiftags/package.nix +++ b/pkgs/by-name/ex/exiftags/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "exiftags"; diff --git a/pkgs/by-name/ex/exim/package.nix b/pkgs/by-name/ex/exim/package.nix index bf593354da92f5..4c6c8a7154782a 100644 --- a/pkgs/by-name/ex/exim/package.nix +++ b/pkgs/by-name/ex/exim/package.nix @@ -1,21 +1,43 @@ -{ coreutils, db, fetchurl, openssl, pcre2, perl, pkg-config, lib, stdenv -, libxcrypt -, procps, killall -, enableLDAP ? false, openldap -, enableMySQL ? false, libmysqlclient, zlib -, enablePgSQL ? false, postgresql -, enableSqlite ? false, sqlite -, enableAuthDovecot ? false, dovecot -, enablePAM ? false, pam -, enableSPF ? true, libspf2 -, enableDMARC ? true, opendmarc -, enableRedis ? false, hiredis -, enableJSON ? false, jansson -, enableSRS ? false, +{ + coreutils, + db, + fetchurl, + openssl, + pcre2, + perl, + pkg-config, + lib, + stdenv, + libxcrypt, + procps, + killall, + enableLDAP ? false, + openldap, + enableMySQL ? false, + libmysqlclient, + zlib, + enablePgSQL ? false, + postgresql, + enableSqlite ? false, + sqlite, + enableAuthDovecot ? false, + dovecot, + enablePAM ? false, + pam, + enableSPF ? true, + libspf2, + enableDMARC ? true, + opendmarc, + enableRedis ? false, + hiredis, + enableJSON ? false, + jansson, + enableSRS ? false, }: let perl' = perl.withPackages (p: with p; [ FileFcntlLock ]); -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "exim"; version = "4.98"; @@ -27,11 +49,26 @@ in stdenv.mkDerivation rec { enableParallelBuilding = true; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ coreutils db openssl perl' pcre2 libxcrypt ] + buildInputs = + [ + coreutils + db + openssl + perl' + pcre2 + libxcrypt + ] ++ lib.optional enableLDAP openldap - ++ lib.optionals enableMySQL [ libmysqlclient zlib ] + ++ lib.optionals enableMySQL [ + libmysqlclient + zlib + ] ++ lib.optional enablePgSQL postgresql - ++ lib.optionals enableSqlite [ sqlite sqlite.dev zlib ] + ++ lib.optionals enableSqlite [ + sqlite + sqlite.dev + zlib + ] ++ lib.optional enableAuthDovecot dovecot ++ lib.optional enablePAM pam ++ lib.optional enableSPF libspf2 @@ -158,7 +195,10 @@ in stdenv.mkDerivation rec { meta = with lib; { homepage = "https://exim.org/"; description = "Mail transfer agent (MTA)"; - license = with licenses; [ gpl2Plus bsd3 ]; + license = with licenses; [ + gpl2Plus + bsd3 + ]; mainProgram = "exim"; platforms = platforms.linux; maintainers = with maintainers; [ tv ] ++ teams.helsinki-systems.members; diff --git a/pkgs/by-name/ex/exiv2/package.nix b/pkgs/by-name/ex/exiv2/package.nix index 56edbdab5d535c..a702df62ea0e9c 100644 --- a/pkgs/by-name/ex/exiv2/package.nix +++ b/pkgs/by-name/ex/exiv2/package.nix @@ -1,27 +1,34 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, doxygen -, gettext -, graphviz -, libxslt -, removeReferencesTo -, libiconv -, brotli -, expat -, inih -, zlib -, libxml2 -, python3 -, which +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + doxygen, + gettext, + graphviz, + libxslt, + removeReferencesTo, + libiconv, + brotli, + expat, + inih, + zlib, + libxml2, + python3, + which, }: stdenv.mkDerivation rec { pname = "exiv2"; version = "0.28.3"; - outputs = [ "out" "lib" "dev" "doc" "man" ]; + outputs = [ + "out" + "lib" + "dev" + "doc" + "man" + ]; src = fetchFromGitHub { owner = "exiv2"; @@ -69,21 +76,24 @@ stdenv.mkDerivation rec { doCheck = true; - preCheck = '' - patchShebangs ../test/ - mkdir ../test/tmp - '' + lib.optionalString stdenv.hostPlatform.isAarch32 '' - # Fix tests on arm - # https://github.com/Exiv2/exiv2/issues/933 - rm -f ../tests/bugfixes/github/test_CVE_2018_12265.py - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - export DYLD_LIBRARY_PATH=$DYLD_LIBRARY_PATH''${DYLD_LIBRARY_PATH:+:}$PWD/lib - export LC_ALL=C - - # disable tests that requires loopback networking - substituteInPlace ../tests/bash_tests/testcases.py \ - --replace "def io_test(self):" "def io_disabled(self):" - ''; + preCheck = + '' + patchShebangs ../test/ + mkdir ../test/tmp + '' + + lib.optionalString stdenv.hostPlatform.isAarch32 '' + # Fix tests on arm + # https://github.com/Exiv2/exiv2/issues/933 + rm -f ../tests/bugfixes/github/test_CVE_2018_12265.py + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + export DYLD_LIBRARY_PATH=$DYLD_LIBRARY_PATH''${DYLD_LIBRARY_PATH:+:}$PWD/lib + export LC_ALL=C + + # disable tests that requires loopback networking + substituteInPlace ../tests/bash_tests/testcases.py \ + --replace "def io_test(self):" "def io_disabled(self):" + ''; preFixup = '' remove-references-to -t ${stdenv.cc.cc} $lib/lib/*.so.*.*.* $out/bin/exiv2 diff --git a/pkgs/by-name/ex/exonerate/package.nix b/pkgs/by-name/ex/exonerate/package.nix index f7b6bf6c14cee6..a0bff5fa0e6ec9 100644 --- a/pkgs/by-name/ex/exonerate/package.nix +++ b/pkgs/by-name/ex/exonerate/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, glib, pkg-config }: +{ + lib, + stdenv, + fetchurl, + glib, + pkg-config, +}: stdenv.mkDerivation rec { version = "2.4.0"; @@ -20,6 +26,6 @@ stdenv.mkDerivation rec { homepage = "https://www.ebi.ac.uk/about/vertebrate-genomics/software/exonerate"; license = licenses.gpl3; maintainers = [ maintainers.bzizou ]; - platforms = platforms.unix ; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ex/exoscale-cli/package.nix b/pkgs/by-name/ex/exoscale-cli/package.nix index 53c45858e4fe23..1e9c164751fd35 100644 --- a/pkgs/by-name/ex/exoscale-cli/package.nix +++ b/pkgs/by-name/ex/exoscale-cli/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "exoscale-cli"; @@ -15,7 +20,12 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - ldflags = [ "-s" "-w" "-X main.version=${version}" "-X main.commit=${src.rev}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + "-X main.commit=${src.rev}" + ]; # we need to rename the resulting binary but can't use buildFlags with -o here # because these are passed to "go install" which does not recognize -o diff --git a/pkgs/by-name/ex/expat/package.nix b/pkgs/by-name/ex/expat/package.nix index 7d49962cbdb7d0..c58856b24772ea 100644 --- a/pkgs/by-name/ex/expat/package.nix +++ b/pkgs/by-name/ex/expat/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, updateAutotoolsGnuConfigScriptsHook -# for passthru.tests -, python3 -, perlPackages -, haskellPackages -, luaPackages -, ocamlPackages -, testers +{ + lib, + stdenv, + fetchurl, + updateAutotoolsGnuConfigScriptsHook, + # for passthru.tests + python3, + perlPackages, + haskellPackages, + luaPackages, + ocamlPackages, + testers, }: # Note: this package is used for bootstrapping fetchurl, and thus @@ -18,21 +19,26 @@ let version = "2.6.4"; - tag = "R_${lib.replaceStrings ["."] ["_"] version}"; + tag = "R_${lib.replaceStrings [ "." ] [ "_" ] version}"; in stdenv.mkDerivation (finalAttrs: { pname = "expat"; inherit version; src = fetchurl { - url = with finalAttrs; "https://github.com/libexpat/libexpat/releases/download/${tag}/${pname}-${version}.tar.xz"; + url = + with finalAttrs; + "https://github.com/libexpat/libexpat/releases/download/${tag}/${pname}-${version}.tar.xz"; hash = "sha256-ppVina4EcFWzfVCg/0d20dRdCkyELPTM7hWEQfVf9+4="; }; strictDeps = true; nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook ]; - outputs = [ "out" "dev" ]; # TODO: fix referrers + outputs = [ + "out" + "dev" + ]; # TODO: fix referrers outputBin = "dev"; enableParallelBuilding = true; diff --git a/pkgs/by-name/ex/expected-lite/package.nix b/pkgs/by-name/ex/expected-lite/package.nix index a0d5d1a509b9be..80e94ff8815d7c 100644 --- a/pkgs/by-name/ex/expected-lite/package.nix +++ b/pkgs/by-name/ex/expected-lite/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, }: stdenv.mkDerivation rec { @@ -16,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-8Lf+R7wC7f2YliXqhR6pwVVSLZ6qheu7YOV5jHc0Cjc="; }; - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; doCheck = true; diff --git a/pkgs/by-name/ex/expenses/package.nix b/pkgs/by-name/ex/expenses/package.nix index 6d66ab12c3dba6..a2a71735ed0319 100644 --- a/pkgs/by-name/ex/expenses/package.nix +++ b/pkgs/by-name/ex/expenses/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, sqlite -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + sqlite, + installShellFiles, }: buildGoModule rec { @@ -26,7 +27,9 @@ buildGoModule rec { buildInputs = [ sqlite ]; ldflags = [ - "-s" "-w" "-X github.com/manojkarthick/expenses/cmd.Version=${version}" + "-s" + "-w" + "-X github.com/manojkarthick/expenses/cmd.Version=${version}" ]; postInstall = '' @@ -37,9 +40,9 @@ buildGoModule rec { ''; meta = with lib; { - description = "Interactive command line expense logger"; - license = licenses.mit; - maintainers = [ maintainers.manojkarthick ]; - mainProgram = "expenses"; + description = "Interactive command line expense logger"; + license = licenses.mit; + maintainers = [ maintainers.manojkarthick ]; + mainProgram = "expenses"; }; } diff --git a/pkgs/by-name/ex/explain/package.nix b/pkgs/by-name/ex/explain/package.nix index fb25deacb46c10..80cc946b2e6868 100644 --- a/pkgs/by-name/ex/explain/package.nix +++ b/pkgs/by-name/ex/explain/package.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, fetchurl, fetchpatch -, libtool, bison, groff, ghostscript, gettext -, acl, libcap, lsof }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libtool, + bison, + groff, + ghostscript, + gettext, + acl, + libcap, + lsof, +}: stdenv.mkDerivation rec { pname = "explain"; version = "1.4"; @@ -10,31 +21,46 @@ stdenv.mkDerivation rec { hash = "sha256-KIY7ZezMdJNOI3ysQTZMs8GALDbJ4jGO0EF0YP7oP4A="; }; - patches = let - debian-src = "https://sources.debian.org/data/main"; - debian-ver = "${version}.D001-12"; - debian-patch = fname: hash: fetchpatch { - name = fname; - url = "${debian-src}/libe/libexplain/${debian-ver}/debian/patches/${fname}"; - hash = hash; - }; - in [ - (debian-patch "sanitize-bison.patch" - "sha256-gU6JG32j2yIOwehZTUSvIr4TSDdlg+p1U3bhfZHMEDY=") - (debian-patch "03_fsflags-4.5.patch" - "sha256-ML7Qvf85vEBp+iwm6PSosMAn/frYdEOSHRToEggmR8M=") - (debian-patch "linux5.11.patch" - "sha256-N7WwnTfwOxBfIiKntcFOqHTH9r2gd7NMEzic7szzR+Y=") - (debian-patch "termiox-no-more-exists-since-kernel-5.12.patch" - "sha256-cocgEYKoDMDnGk9VNQDtgoVxMGnnNpdae0hzgUlacOw=") - (debian-patch "gcc-10.patch" - "sha256-YNcYGyOOqPUuwpUpXGcR7zsWbepVg8SAqcVKlxENSQk=") - ]; + patches = + let + debian-src = "https://sources.debian.org/data/main"; + debian-ver = "${version}.D001-12"; + debian-patch = + fname: hash: + fetchpatch { + name = fname; + url = "${debian-src}/libe/libexplain/${debian-ver}/debian/patches/${fname}"; + hash = hash; + }; + in + [ + (debian-patch "sanitize-bison.patch" "sha256-gU6JG32j2yIOwehZTUSvIr4TSDdlg+p1U3bhfZHMEDY=") + (debian-patch "03_fsflags-4.5.patch" "sha256-ML7Qvf85vEBp+iwm6PSosMAn/frYdEOSHRToEggmR8M=") + (debian-patch "linux5.11.patch" "sha256-N7WwnTfwOxBfIiKntcFOqHTH9r2gd7NMEzic7szzR+Y=") + (debian-patch "termiox-no-more-exists-since-kernel-5.12.patch" "sha256-cocgEYKoDMDnGk9VNQDtgoVxMGnnNpdae0hzgUlacOw=") + (debian-patch "gcc-10.patch" "sha256-YNcYGyOOqPUuwpUpXGcR7zsWbepVg8SAqcVKlxENSQk=") + ]; - nativeBuildInputs = [ libtool bison groff ghostscript gettext ]; - buildInputs = [ acl libcap lsof ]; + nativeBuildInputs = [ + libtool + bison + groff + ghostscript + gettext + ]; + buildInputs = [ + acl + libcap + lsof + ]; - outputs = [ "bin" "dev" "out" "man" "doc" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + "doc" + ]; meta = with lib; { description = "Library and utility to explain system call errors"; diff --git a/pkgs/by-name/ex/expliot/package.nix b/pkgs/by-name/ex/expliot/package.nix index b94356d9746670..68f335f23ef097 100644 --- a/pkgs/by-name/ex/expliot/package.nix +++ b/pkgs/by-name/ex/expliot/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitLab -, python3 +{ + lib, + fetchFromGitLab, + python3, }: let py = python3.override { diff --git a/pkgs/by-name/ex/exportarr/package.nix b/pkgs/by-name/ex/exportarr/package.nix index d23cc62c80ffca..275285041b3b39 100644 --- a/pkgs/by-name/ex/exportarr/package.nix +++ b/pkgs/by-name/ex/exportarr/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -21,7 +22,10 @@ buildGoModule rec { CGO_ENABLE = 0; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; tags = lib.optionals stdenv.hostPlatform.isLinux [ "netgo" ]; diff --git a/pkgs/by-name/ex/expr/package.nix b/pkgs/by-name/ex/expr/package.nix index 3fa6182c6f8871..03033aab37884e 100644 --- a/pkgs/by-name/ex/expr/package.nix +++ b/pkgs/by-name/ex/expr/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -18,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-FiXxplt4w7M0cZz46kdjYuKHailW2cnLOj0jkA9w1RM="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' mv $out/bin/{repl,expr} diff --git a/pkgs/by-name/ex/expressvpn/package.nix b/pkgs/by-name/ex/expressvpn/package.nix index d7f561525b0cce..f97ec3967ee2d0 100644 --- a/pkgs/by-name/ex/expressvpn/package.nix +++ b/pkgs/by-name/ex/expressvpn/package.nix @@ -1,19 +1,23 @@ -{ autoPatchelfHook -, buildFHSEnv -, dpkg -, fetchurl -, inotify-tools -, lib -, stdenvNoCC -, sysctl -, writeScript +{ + autoPatchelfHook, + buildFHSEnv, + dpkg, + fetchurl, + inotify-tools, + lib, + stdenvNoCC, + sysctl, + writeScript, }: let pname = "expressvpn"; clientVersion = "3.52.0"; clientBuild = "2"; - version = lib.strings.concatStringsSep "." [ clientVersion clientBuild ]; + version = lib.strings.concatStringsSep "." [ + clientVersion + clientBuild + ]; expressvpnBase = stdenvNoCC.mkDerivation { inherit pname version; @@ -23,7 +27,10 @@ let hash = "sha256-cDZ9R+MA3FXEto518bH4/c1X4W9XxgTvXns7zisylew="; }; - nativeBuildInputs = [ dpkg autoPatchelfHook ]; + nativeBuildInputs = [ + dpkg + autoPatchelfHook + ]; dontConfigure = true; dontBuild = true; @@ -66,11 +73,12 @@ let # The expressvpnd binary also uses hard-coded paths to the other binaries and files # it ships with, hence the FHS environment. - targetPkgs = pkgs: with pkgs; [ - expressvpnBase - inotify-tools - iproute2 - ]; + targetPkgs = + pkgs: with pkgs; [ + expressvpnBase + inotify-tools + iproute2 + ]; }; in stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/ex/exprtk/package.nix b/pkgs/by-name/ex/exprtk/package.nix index 2aaa803431c614..984a47047bed17 100644 --- a/pkgs/by-name/ex/exprtk/package.nix +++ b/pkgs/by-name/ex/exprtk/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "exprtk"; diff --git a/pkgs/by-name/ex/exrtools/package.nix b/pkgs/by-name/ex/exrtools/package.nix index b29d1d58690090..c86cccd3074c16 100644 --- a/pkgs/by-name/ex/exrtools/package.nix +++ b/pkgs/by-name/ex/exrtools/package.nix @@ -1,16 +1,28 @@ -{ lib, stdenv, fetchurl, pkg-config, openexr, libpng12, libjpeg }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + openexr, + libpng12, + libjpeg, +}: stdenv.mkDerivation rec { pname = "exrtools"; version = "0.4"; src = fetchurl { - url = "http://scanline.ca/exrtools/${pname}-${version}.tar.gz"; + url = "http://scanline.ca/exrtools/${pname}-${version}.tar.gz"; sha256 = "0jpkskqs1yjiighab4s91jy0c0qxcscwadfn94xy2mm2bx2qwp4z"; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openexr libpng12 libjpeg ]; + buildInputs = [ + openexr + libpng12 + libjpeg + ]; meta = with lib; { description = "Collection of utilities for manipulating OpenEXR images"; @@ -20,4 +32,3 @@ stdenv.mkDerivation rec { maintainers = [ maintainers.juliendehos ]; }; } - diff --git a/pkgs/by-name/ex/ext3grep/package.nix b/pkgs/by-name/ex/ext3grep/package.nix index bb91a683ba2e75..5c5b9b0b5dc427 100644 --- a/pkgs/by-name/ex/ext3grep/package.nix +++ b/pkgs/by-name/ex/ext3grep/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, e2fsprogs +{ + lib, + stdenv, + fetchurl, + fetchpatch, + e2fsprogs, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ex/ext4magic/package.nix b/pkgs/by-name/ex/ext4magic/package.nix index 2af139c619d6a1..0822231ffc3699 100644 --- a/pkgs/by-name/ex/ext4magic/package.nix +++ b/pkgs/by-name/ex/ext4magic/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, fetchpatch, file, libuuid, e2fsprogs, zlib, bzip2 }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + file, + libuuid, + e2fsprogs, + zlib, + bzip2, +}: stdenv.mkDerivation rec { version = "0.3.2"; @@ -11,13 +21,19 @@ stdenv.mkDerivation rec { patches = [ (fetchpatch { - url = "https://sourceforge.net/p/ext4magic/tickets/10/attachment/ext4magic-0.3.2-i_dir_acl.patch"; - sha256 = "1accydd8kigid68yir2fbihm3r3x8ws3iyznp25snkx41w6y6x8c"; + url = "https://sourceforge.net/p/ext4magic/tickets/10/attachment/ext4magic-0.3.2-i_dir_acl.patch"; + sha256 = "1accydd8kigid68yir2fbihm3r3x8ws3iyznp25snkx41w6y6x8c"; }) ./glibc-fix.patch ]; - buildInputs = [ file libuuid e2fsprogs zlib bzip2 ]; + buildInputs = [ + file + libuuid + e2fsprogs + zlib + bzip2 + ]; installFlags = [ "PREFIX=$(out)" ]; meta = with lib; { diff --git a/pkgs/by-name/ex/extest/package.nix b/pkgs/by-name/ex/extest/package.nix index a0df42265da58e..f6c2699282fdfb 100644 --- a/pkgs/by-name/ex/extest/package.nix +++ b/pkgs/by-name/ex/extest/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ex/extism-cli/package.nix b/pkgs/by-name/ex/extism-cli/package.nix index 933fdeaa8b5435..ef165ac07df5d2 100644 --- a/pkgs/by-name/ex/extism-cli/package.nix +++ b/pkgs/by-name/ex/extism-cli/package.nix @@ -1,8 +1,8 @@ { - lib -, buildGoModule -, fetchFromGitHub -, installShellFiles + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/ex/extra-container/package.nix b/pkgs/by-name/ex/extra-container/package.nix index 71ba276f4bd420..84a5367b449a20 100644 --- a/pkgs/by-name/ex/extra-container/package.nix +++ b/pkgs/by-name/ex/extra-container/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, nixos-container, openssh, glibcLocales, fetchFromGitHub }: +{ + stdenv, + lib, + nixos-container, + openssh, + glibcLocales, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "extra-container"; diff --git a/pkgs/by-name/ex/extrace/package.nix b/pkgs/by-name/ex/extrace/package.nix index e4afe6f8503996..6d2491acfa85dc 100644 --- a/pkgs/by-name/ex/extrace/package.nix +++ b/pkgs/by-name/ex/extrace/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "extrace"; @@ -21,7 +25,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/leahneukirchen/extrace"; description = "Trace exec() calls system-wide"; - license = with licenses; [ gpl2Plus bsd2 ]; + license = with licenses; [ + gpl2Plus + bsd2 + ]; platforms = platforms.linux; maintainers = [ maintainers.leahneukirchen ]; }; diff --git a/pkgs/by-name/ex/extract_url/package.nix b/pkgs/by-name/ex/extract_url/package.nix index b47fca90b9f68b..b7b8e4824f75bc 100644 --- a/pkgs/by-name/ex/extract_url/package.nix +++ b/pkgs/by-name/ex/extract_url/package.nix @@ -1,15 +1,24 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper, perlPackages -, cursesSupport ? true -, uriFindSupport ? true +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + perlPackages, + cursesSupport ? true, + uriFindSupport ? true, }: let perlDeps = - [ perlPackages.MIMETools perlPackages.HTMLParser ] + [ + perlPackages.MIMETools + perlPackages.HTMLParser + ] ++ lib.optional cursesSupport perlPackages.CursesUI ++ lib.optional uriFindSupport perlPackages.URIFind; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "extract_url"; version = "1.6.2"; diff --git a/pkgs/by-name/ex/extractpdfmark/package.nix b/pkgs/by-name/ex/extractpdfmark/package.nix index 9b95e6e101edbd..8594820134f380 100644 --- a/pkgs/by-name/ex/extractpdfmark/package.nix +++ b/pkgs/by-name/ex/extractpdfmark/package.nix @@ -1,11 +1,12 @@ -{ autoreconfHook -, fetchFromGitHub -, ghostscript -, lib -, pkg-config -, poppler -, stdenv -, texlive +{ + autoreconfHook, + fetchFromGitHub, + ghostscript, + lib, + pkg-config, + poppler, + stdenv, + texlive, }: stdenv.mkDerivation rec { @@ -19,8 +20,15 @@ stdenv.mkDerivation rec { hash = "sha256-pNc/SWAtQWMbB2+lIQkJdBYSZ97iJXK71mS59qQa7Hs="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ ghostscript poppler texlive.combined.scheme-minimal ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + ghostscript + poppler + texlive.combined.scheme-minimal + ]; postPatch = '' touch config.rpath diff --git a/pkgs/by-name/ex/extremetuxracer/package.nix b/pkgs/by-name/ex/extremetuxracer/package.nix index b794543ff4ee9b..0b64b85637d561 100644 --- a/pkgs/by-name/ex/extremetuxracer/package.nix +++ b/pkgs/by-name/ex/extremetuxracer/package.nix @@ -1,7 +1,25 @@ -{ lib, stdenv, fetchurl, libGLU, libGL, libX11, xorgproto, tcl, libglut, freetype -, sfml, libXi -, libXmu, libXext, libXt, libSM, libICE -, libpng, pkg-config, gettext, intltool +{ + lib, + stdenv, + fetchurl, + libGLU, + libGL, + libX11, + xorgproto, + tcl, + libglut, + freetype, + sfml, + libXi, + libXmu, + libXext, + libXt, + libSM, + libICE, + libpng, + pkg-config, + gettext, + intltool, }: stdenv.mkDerivation rec { @@ -13,12 +31,27 @@ stdenv.mkDerivation rec { sha256 = "sha256-+jKFzAx1Wlr/Up8/LOo1FkgRFMa0uOHsB2n+7/BHc+U="; }; - nativeBuildInputs = [ pkg-config intltool ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; buildInputs = [ - libGLU libGL libX11 xorgproto tcl libglut freetype - sfml libXi - libXmu libXext libXt libSM libICE - libpng gettext + libGLU + libGL + libX11 + xorgproto + tcl + libglut + freetype + sfml + libXi + libXmu + libXext + libXt + libSM + libICE + libpng + gettext ]; configureFlags = [ "--with-tcl=${tcl}/lib" ]; diff --git a/pkgs/by-name/ex/extrude/package.nix b/pkgs/by-name/ex/extrude/package.nix index 8a9710582913dd..469678b7ec5503 100644 --- a/pkgs/by-name/ex/extrude/package.nix +++ b/pkgs/by-name/ex/extrude/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ex/extundelete/package.nix b/pkgs/by-name/ex/extundelete/package.nix index d1529565938513..41872f86642111 100644 --- a/pkgs/by-name/ex/extundelete/package.nix +++ b/pkgs/by-name/ex/extundelete/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, e2fsprogs }: +{ + lib, + stdenv, + fetchurl, + e2fsprogs, +}: stdenv.mkDerivation { version = "0.2.4"; diff --git a/pkgs/by-name/ey/eyewitness/package.nix b/pkgs/by-name/ey/eyewitness/package.nix index cc13cb0e13a918..1daaa89dc0c643 100644 --- a/pkgs/by-name/ey/eyewitness/package.nix +++ b/pkgs/by-name/ey/eyewitness/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, python3Packages -, xvfb-run -, firefox-esr -, geckodriver -, makeWrapper +{ + lib, + fetchFromGitHub, + python3Packages, + xvfb-run, + firefox-esr, + geckodriver, + makeWrapper, }: python3Packages.buildPythonApplication rec { @@ -19,24 +20,30 @@ python3Packages.buildPythonApplication rec { hash = "sha256-nSPpPbwqagc5EadQ4AHgLhjQ0kDjmbdcwE/PL5FDL4I="; }; - build-system = with python3Packages; [ - setuptools - ] ++ [ - makeWrapper - ]; + build-system = + with python3Packages; + [ + setuptools + ] + ++ [ + makeWrapper + ]; - dependencies = with python3Packages; [ - selenium - fuzzywuzzy - pyvirtualdisplay - pylev - netaddr - pydevtool - ] ++ [ - firefox-esr - xvfb-run - geckodriver - ]; + dependencies = + with python3Packages; + [ + selenium + fuzzywuzzy + pyvirtualdisplay + pylev + netaddr + pydevtool + ] + ++ [ + firefox-esr + xvfb-run + geckodriver + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/ez/eza/package.nix b/pkgs/by-name/ez/eza/package.nix index 1cd13c801ca41b..6bb16065bc4909 100644 --- a/pkgs/by-name/ez/eza/package.nix +++ b/pkgs/by-name/ez/eza/package.nix @@ -1,15 +1,16 @@ -{ lib -, gitSupport ? true -, fetchFromGitHub -, rustPlatform -, cmake -, pandoc -, pkg-config -, zlib -, installShellFiles +{ + lib, + gitSupport ? true, + fetchFromGitHub, + rustPlatform, + cmake, + pandoc, + pkg-config, + zlib, + installShellFiles, # once eza upstream gets support for setting up a compatibility symlink for exa, we should change # the handling here from postInstall to passing the required argument to the builder. -, exaAlias ? true + exaAlias ? true, }: rustPlatform.buildRustPackage rec { @@ -25,27 +26,37 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-5KVLxIYmWIcFcGNZUvNOrHrKTy0UD9LQvPn3IGpV6B0="; - nativeBuildInputs = [ cmake pkg-config installShellFiles pandoc ]; + nativeBuildInputs = [ + cmake + pkg-config + installShellFiles + pandoc + ]; buildInputs = [ zlib ]; buildNoDefaultFeatures = true; buildFeatures = lib.optional gitSupport "git"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - postInstall = '' - for page in eza.1 eza_colors.5 eza_colors-explanation.5; do - sed "s/\$version/v${version}/g" "man/$page.md" | - pandoc --standalone -f markdown -t man >"man/$page" - done - installManPage man/eza.1 man/eza_colors.5 man/eza_colors-explanation.5 - installShellCompletion \ - --bash completions/bash/eza \ - --fish completions/fish/eza.fish \ - --zsh completions/zsh/_eza - '' + lib.optionalString exaAlias '' - ln -s eza $out/bin/exa - ''; + postInstall = + '' + for page in eza.1 eza_colors.5 eza_colors-explanation.5; do + sed "s/\$version/v${version}/g" "man/$page.md" | + pandoc --standalone -f markdown -t man >"man/$page" + done + installManPage man/eza.1 man/eza_colors.5 man/eza_colors-explanation.5 + installShellCompletion \ + --bash completions/bash/eza \ + --fish completions/fish/eza.fish \ + --zsh completions/zsh/_eza + '' + + lib.optionalString exaAlias '' + ln -s eza $out/bin/exa + ''; meta = with lib; { description = "Modern, maintained replacement for ls"; @@ -61,7 +72,11 @@ rustPlatform.buildRustPackage rec { changelog = "https://github.com/eza-community/eza/releases/tag/v${version}"; license = licenses.eupl12; mainProgram = "eza"; - maintainers = with maintainers; [ cafkafk _9glenda sigmasquadron ]; + maintainers = with maintainers; [ + cafkafk + _9glenda + sigmasquadron + ]; platforms = platforms.unix ++ platforms.windows; }; } diff --git a/pkgs/by-name/ez/ezno/package.nix b/pkgs/by-name/ez/ezno/package.nix index af035e7565ec7f..5ee1c9f44e9753 100644 --- a/pkgs/by-name/ez/ezno/package.nix +++ b/pkgs/by-name/ez/ezno/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -22,7 +23,10 @@ rustPlatform.buildRustPackage rec { darwin.apple_sdk.frameworks.CoreServices ]; - cargoBuildFlags = [ "--bin" "ezno" ]; + cargoBuildFlags = [ + "--bin" + "ezno" + ]; meta = with lib; { description = "JavaScript compiler and TypeScript checker with a focus on static analysis and runtime performance"; diff --git a/pkgs/by-name/ez/ezquake/package.nix b/pkgs/by-name/ez/ezquake/package.nix index 579783af2ef8e8..8e09f58bf6323c 100644 --- a/pkgs/by-name/ez/ezquake/package.nix +++ b/pkgs/by-name/ez/ezquake/package.nix @@ -1,7 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, curl, expat -, jansson, libpng, libjpeg, libGLU, libGL -, libsndfile, libXxf86vm, pcre, pkg-config, SDL2 -, vim, speex }: +{ + lib, + stdenv, + fetchFromGitHub, + curl, + expat, + jansson, + libpng, + libjpeg, + libGLU, + libGL, + libsndfile, + libXxf86vm, + pcre, + pkg-config, + SDL2, + vim, + speex, +}: stdenv.mkDerivation rec { pname = "ezquake"; @@ -17,17 +32,31 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - expat curl jansson libpng libjpeg libGLU libGL libsndfile libXxf86vm pcre SDL2 vim speex + expat + curl + jansson + libpng + libjpeg + libGLU + libGL + libsndfile + libXxf86vm + pcre + SDL2 + vim + speex ]; - installPhase = let - sys = lib.last (lib.splitString "-" stdenv.hostPlatform.system); - arch = lib.head (lib.splitString "-" stdenv.hostPlatform.system); - in '' - mkdir -p $out/bin - find . - mv ezquake-${sys}-${arch} $out/bin/ezquake - ''; + installPhase = + let + sys = lib.last (lib.splitString "-" stdenv.hostPlatform.system); + arch = lib.head (lib.splitString "-" stdenv.hostPlatform.system); + in + '' + mkdir -p $out/bin + find . + mv ezquake-${sys}-${arch} $out/bin/ezquake + ''; enableParallelBuilding = true; diff --git a/pkgs/by-name/ez/ezra-sil/package.nix b/pkgs/by-name/ez/ezra-sil/package.nix index 7b628bd4bbc00c..83409b24277534 100644 --- a/pkgs/by-name/ez/ezra-sil/package.nix +++ b/pkgs/by-name/ez/ezra-sil/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "ezra-sil"; diff --git a/pkgs/by-name/ez/ezstream/package.nix b/pkgs/by-name/ez/ezstream/package.nix index 5e1be5f3f7e15c..49fa6efb868d86 100644 --- a/pkgs/by-name/ez/ezstream/package.nix +++ b/pkgs/by-name/ez/ezstream/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, libiconv, libshout, taglib, libxml2, pkg-config }: +{ + lib, + stdenv, + fetchurl, + libiconv, + libshout, + taglib, + libxml2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "ezstream"; @@ -9,7 +18,12 @@ stdenv.mkDerivation rec { sha256 = "f86eb8163b470c3acbc182b42406f08313f85187bd9017afb8b79b02f03635c9"; }; - buildInputs = [ libiconv libshout taglib libxml2 ]; + buildInputs = [ + libiconv + libshout + taglib + libxml2 + ]; nativeBuildInputs = [ pkg-config ]; doCheck = true; diff --git a/pkgs/by-name/ez/eztrace/package.nix b/pkgs/by-name/ez/eztrace/package.nix index fdd665bbae22c7..8a5b3dbeb91c7c 100644 --- a/pkgs/by-name/ez/eztrace/package.nix +++ b/pkgs/by-name/ez/eztrace/package.nix @@ -1,4 +1,5 @@ -{ lib, +{ + lib, stdenv, fetchFromGitLab, gfortran, @@ -9,7 +10,7 @@ # is released we can switch to latest binutils. libbfd_2_38, libopcodes_2_38, - autoreconfHook + autoreconfHook, }: stdenv.mkDerivation rec { @@ -23,8 +24,17 @@ stdenv.mkDerivation rec { hash = "sha256-A6HMr4ib5Ka1lTbbTQOdq3kIdCoN/CwAKRdXdv9wpfU="; }; - nativeBuildInputs = [ gfortran autoreconfHook ]; - buildInputs = [ libelf libiberty zlib libbfd_2_38 libopcodes_2_38 ]; + nativeBuildInputs = [ + gfortran + autoreconfHook + ]; + buildInputs = [ + libelf + libiberty + zlib + libbfd_2_38 + libopcodes_2_38 + ]; meta = with lib; { description = "Tool that aims at generating automatically execution trace from HPC programs"; diff --git a/pkgs/by-name/f1/f1_8/package.nix b/pkgs/by-name/f1/f1_8/package.nix index 187fd517c1f244..c82e08c7ec0dde 100644 --- a/pkgs/by-name/f1/f1_8/package.nix +++ b/pkgs/by-name/f1/f1_8/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "1"; diff --git a/pkgs/by-name/f1/f1viewer/package.nix b/pkgs/by-name/f1/f1viewer/package.nix index 5d89a8df657c1e..363d914548effb 100644 --- a/pkgs/by-name/f1/f1viewer/package.nix +++ b/pkgs/by-name/f1/f1viewer/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "f1viewer"; @@ -14,8 +18,7 @@ buildGoModule rec { vendorHash = "sha256-UNeH3zxgssXxFpJws6nAL8EgXt0DRyAQfmlJWz/qyDg="; meta = with lib; { - description = - "A TUI to view Formula 1 footage using VLC or another media player"; + description = "A TUI to view Formula 1 footage using VLC or another media player"; homepage = "https://github.com/SoMuchForSubtlety/f1viewer"; license = licenses.gpl3Only; maintainers = with maintainers; [ michzappa ]; diff --git a/pkgs/by-name/f2/f2c/package.nix b/pkgs/by-name/f2/f2c/package.nix index 4b263a907b0526..acc430409f1ff5 100644 --- a/pkgs/by-name/f2/f2c/package.nix +++ b/pkgs/by-name/f2/f2c/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "f2c"; @@ -9,7 +13,10 @@ stdenv.mkDerivation { sha256 = "sha256-TTPve2fe31/Ad+xFAWy6NUIes2QyUi6NjFucN0pdb5k="; }; - makeFlags = [ "-f" "makefile.u" ]; + makeFlags = [ + "-f" + "makefile.u" + ]; # Ensure xsum binary is built from scratch preBuild = "rm xsum"; diff --git a/pkgs/by-name/f3/f3/package.nix b/pkgs/by-name/f3/f3/package.nix index 04430fc23ee41e..cff9ebc4458c19 100644 --- a/pkgs/by-name/f3/f3/package.nix +++ b/pkgs/by-name/f3/f3/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, parted -, systemd -, argp-standalone +{ + stdenv, + lib, + fetchFromGitHub, + parted, + systemd, + argp-standalone, }: stdenv.mkDerivation rec { @@ -26,13 +27,16 @@ stdenv.mkDerivation rec { done ''; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ systemd parted ] + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + systemd + parted + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ argp-standalone ]; buildFlags = [ "all" # f3read, f3write - ] - ++ lib.optional stdenv.hostPlatform.isLinux "extra"; # f3brew, f3fix, f3probe + ] ++ lib.optional stdenv.hostPlatform.isLinux "extra"; # f3brew, f3fix, f3probe installFlags = [ "PREFIX=${placeholder "out"}" @@ -40,8 +44,7 @@ stdenv.mkDerivation rec { installTargets = [ "install" - ] - ++ lib.optional stdenv.hostPlatform.isLinux "install-extra"; + ] ++ lib.optional stdenv.hostPlatform.isLinux "install-extra"; postInstall = '' install -Dm555 -t $out/bin f3write.h2w log-f3wr @@ -52,6 +55,9 @@ stdenv.mkDerivation rec { description = "Fight Flash Fraud"; homepage = "https://fight-flash-fraud.readthedocs.io/en/stable/"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ makefu evils ]; + maintainers = with maintainers; [ + makefu + evils + ]; }; } diff --git a/pkgs/by-name/f5/f5_6/package.nix b/pkgs/by-name/f5/f5_6/package.nix index bf0b6de36b64e2..2671eaede6276d 100644 --- a/pkgs/by-name/f5/f5_6/package.nix +++ b/pkgs/by-name/f5/f5_6/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "0"; @@ -26,7 +30,10 @@ stdenvNoCC.mkDerivation { homepage = "http://dotcolon.net/font/f5_6/"; description = "Weighted decorative font"; platforms = platforms.all; - maintainers = with maintainers; [ leenaars minijackson ]; + maintainers = with maintainers; [ + leenaars + minijackson + ]; license = licenses.ofl; }; } diff --git a/pkgs/by-name/fa/fa_1/package.nix b/pkgs/by-name/fa/fa_1/package.nix index d3eb8e73faead0..165abcfdba7aa6 100644 --- a/pkgs/by-name/fa/fa_1/package.nix +++ b/pkgs/by-name/fa/fa_1/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "0"; diff --git a/pkgs/by-name/fa/faac/package.nix b/pkgs/by-name/fa/faac/package.nix index c1dba7c34bda3c..6caf048cee50b5 100644 --- a/pkgs/by-name/fa/faac/package.nix +++ b/pkgs/by-name/fa/faac/package.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, fetchurl, autoreconfHook -, mp4v2Support ? true, mp4v2 -, drmSupport ? false # Digital Radio Mondiale +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + mp4v2Support ? true, + mp4v2, + drmSupport ? false, # Digital Radio Mondiale }: stdenv.mkDerivation rec { @@ -8,11 +13,14 @@ stdenv.mkDerivation rec { version = "1.30"; src = fetchurl { - url = "mirror://sourceforge/faac/${pname}-${builtins.replaceStrings ["."] ["_"] version}.tar.gz"; + url = "mirror://sourceforge/faac/${pname}-${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.tar.gz"; sha256 = "1lmj0dib3mjp84jhxc5ddvydkzzhb0gfrdh3ikcidjlcb378ghxd"; }; - configureFlags = lib.optional mp4v2Support "--with-external-mp4v2" + configureFlags = + lib.optional mp4v2Support "--with-external-mp4v2" ++ lib.optional drmSupport "--enable-drm"; hardeningDisable = [ "format" ]; @@ -26,8 +34,8 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Open source MPEG-4 and MPEG-2 AAC encoder"; homepage = "https://github.com/knik0/faac"; - license = licenses.unfreeRedistributable; + license = licenses.unfreeRedistributable; maintainers = with maintainers; [ codyopel ]; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/fa/faad2/package.nix b/pkgs/by-name/fa/faad2/package.nix index c4b236786057d3..328e06960eb5a9 100644 --- a/pkgs/by-name/fa/faad2/package.nix +++ b/pkgs/by-name/fa/faad2/package.nix @@ -1,13 +1,14 @@ -{lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, -# for passthru.tests -, gst_all_1 -, mpd -, ocamlPackages -, vlc + # for passthru.tests + gst_all_1, + mpd, + ocamlPackages, + vlc, }: stdenv.mkDerivation rec { @@ -21,7 +22,11 @@ stdenv.mkDerivation rec { hash = "sha256-E6oe7yjYy1SJo8xQkyUk1sSucKDMPxwUFVSAyrf4Pd8="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; nativeBuildInputs = [ cmake ]; @@ -34,9 +39,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Open source MPEG-4 and MPEG-2 AAC decoder"; homepage = "https://sourceforge.net/projects/faac/"; - license = licenses.gpl2Plus; + license = licenses.gpl2Plus; maintainers = with maintainers; [ codyopel ]; mainProgram = "faad"; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/fa/faba-icon-theme/package.nix b/pkgs/by-name/fa/faba-icon-theme/package.nix index 4fc2068f870cc9..e110514e72f94c 100644 --- a/pkgs/by-name/fa/faba-icon-theme/package.nix +++ b/pkgs/by-name/fa/faba-icon-theme/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenvNoCC, fetchFromGitHub, meson, ninja, python3, gtk3, pantheon, gnome-icon-theme, hicolor-icon-theme }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + meson, + ninja, + python3, + gtk3, + pantheon, + gnome-icon-theme, + hicolor-icon-theme, +}: stdenvNoCC.mkDerivation rec { pname = "faba-icon-theme"; @@ -33,7 +44,10 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { description = "Sexy and modern icon theme with Tango influences"; homepage = "https://snwh.org/moka"; - license = with licenses; [ cc-by-sa-40 gpl3 ]; + license = with licenses; [ + cc-by-sa-40 + gpl3 + ]; platforms = platforms.all; maintainers = with maintainers; [ romildo ]; }; diff --git a/pkgs/by-name/fa/faba-mono-icons/package.nix b/pkgs/by-name/fa/faba-mono-icons/package.nix index efd91a5f53fdaa..290aa6ce903d4f 100644 --- a/pkgs/by-name/fa/faba-mono-icons/package.nix +++ b/pkgs/by-name/fa/faba-mono-icons/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenvNoCC, fetchFromGitHub, autoreconfHook, gtk3, moka-icon-theme, faba-icon-theme, gnome-icon-theme, hicolor-icon-theme }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + autoreconfHook, + gtk3, + moka-icon-theme, + faba-icon-theme, + gnome-icon-theme, + hicolor-icon-theme, +}: stdenvNoCC.mkDerivation rec { pname = "faba-mono-icons"; diff --git a/pkgs/by-name/fa/fabric-installer/package.nix b/pkgs/by-name/fa/fabric-installer/package.nix index 5667a55fd609e6..21fdd394531627 100644 --- a/pkgs/by-name/fa/fabric-installer/package.nix +++ b/pkgs/by-name/fa/fabric-installer/package.nix @@ -1,8 +1,10 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "fabric-installer"; @@ -15,7 +17,10 @@ stdenv.mkDerivation rec { dontUnpack = true; - nativeBuildInputs = [ jre makeWrapper ]; + nativeBuildInputs = [ + jre + makeWrapper + ]; installPhase = '' mkdir -p $out/{bin,lib/fabric} diff --git a/pkgs/by-name/fa/fabs/package.nix b/pkgs/by-name/fa/fabs/package.nix index f6e9ec29158552..69bcd4c13797a5 100644 --- a/pkgs/by-name/fa/fabs/package.nix +++ b/pkgs/by-name/fa/fabs/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, perl -, python3 -, sqlite +{ + lib, + fetchFromGitHub, + perl, + python3, + sqlite, }: python3.pkgs.buildPythonApplication rec { @@ -29,7 +30,10 @@ python3.pkgs.buildPythonApplication rec { sqlalchemy ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; preBuild = '' export PREFIX=$out @@ -52,7 +56,10 @@ python3.pkgs.buildPythonApplication rec { ]; meta = with lib; { - outputsToInstall = [ "out" "man" ]; + outputsToInstall = [ + "out" + "man" + ]; mainProgram = "fabsys"; description = "Flexible AFS Backup System for the OpenAFS distributed file system"; homepage = "https://github.com/openafs-contrib/fabs"; diff --git a/pkgs/by-name/fa/fac/package.nix b/pkgs/by-name/fa/fac/package.nix index ad26888ad5336b..fa11dfb4a50f7f 100644 --- a/pkgs/by-name/fa/fac/package.nix +++ b/pkgs/by-name/fa/fac/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeBinaryWrapper -, installShellFiles -, git +{ + lib, + buildGoModule, + fetchFromGitHub, + makeBinaryWrapper, + installShellFiles, + git, }: buildGoModule rec { diff --git a/pkgs/by-name/fa/facedetect/package.nix b/pkgs/by-name/fa/facedetect/package.nix index 623f9e249ff8ba..ecb532bb710f11 100644 --- a/pkgs/by-name/fa/facedetect/package.nix +++ b/pkgs/by-name/fa/facedetect/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, python3Packages }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + python3Packages, +}: stdenv.mkDerivation rec { pname = "facedetect"; @@ -19,8 +25,14 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ python3Packages.python python3Packages.wrapPython ]; - pythonPath = [ python3Packages.numpy python3Packages.opencv4 ]; + buildInputs = [ + python3Packages.python + python3Packages.wrapPython + ]; + pythonPath = [ + python3Packages.numpy + python3Packages.opencv4 + ]; dontConfigure = true; diff --git a/pkgs/by-name/fa/facetimehd-calibration/package.nix b/pkgs/by-name/fa/facetimehd-calibration/package.nix index ca678268872890..8c843f5f564f88 100644 --- a/pkgs/by-name/fa/facetimehd-calibration/package.nix +++ b/pkgs/by-name/fa/facetimehd-calibration/package.nix @@ -1,10 +1,15 @@ -{ lib, stdenvNoCC, fetchurl, unrar-wrapper, pkgs }: +{ + lib, + stdenvNoCC, + fetchurl, + unrar-wrapper, + pkgs, +}: let version = "5.1.5769"; - # Described on https://github.com/patjak/facetimehd/wiki/Extracting-the-sensor-calibration-files # From the wiki page, range extracted with binwalk: @@ -16,10 +21,26 @@ let # Also from the wiki page: calibrationFiles = [ - { file = "1771_01XX.dat"; offset = "1644880"; size = "19040"; } - { file = "1871_01XX.dat"; offset = "1606800"; size = "19040"; } - { file = "1874_01XX.dat"; offset = "1625840"; size = "19040"; } - { file = "9112_01XX.dat"; offset = "1663920"; size = "33060"; } + { + file = "1771_01XX.dat"; + offset = "1644880"; + size = "19040"; + } + { + file = "1871_01XX.dat"; + offset = "1606800"; + size = "19040"; + } + { + file = "1874_01XX.dat"; + offset = "1625840"; + size = "19040"; + } + { + file = "9112_01XX.dat"; + offset = "1663920"; + size = "33060"; + } ]; in @@ -39,24 +60,40 @@ stdenvNoCC.mkDerivation { buildInputs = [ unrar-wrapper ]; - buildPhase = '' - { printf '\x1f\x8b\x08\x00\x00\x00\x00\x00\x00\x00' - cat $src - printf '${gzFooter}' - } | zcat > AppleCamera64.exe - unrar x AppleCamera64.exe AppleCamera.sys - - mkdir -p $out/lib/firmware/facetimehd - '' + lib.concatMapStrings ({file, offset, size}: '' - dd bs=1 skip=${offset} count=${size} if=AppleCamera.sys of=$out/lib/firmware/facetimehd/${file} - '') calibrationFiles; + buildPhase = + '' + { printf '\x1f\x8b\x08\x00\x00\x00\x00\x00\x00\x00' + cat $src + printf '${gzFooter}' + } | zcat > AppleCamera64.exe + unrar x AppleCamera64.exe AppleCamera.sys + + mkdir -p $out/lib/firmware/facetimehd + '' + + lib.concatMapStrings ( + { + file, + offset, + size, + }: + '' + dd bs=1 skip=${offset} count=${size} if=AppleCamera.sys of=$out/lib/firmware/facetimehd/${file} + '' + ) calibrationFiles; meta = with lib; { description = "facetimehd calibration"; homepage = "https://support.apple.com/kb/DL1837"; license = licenses.unfree; - maintainers = with maintainers; [ alexshpilkin womfoo grahamc ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + maintainers = with maintainers; [ + alexshpilkin + womfoo + grahamc + ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/fa/facetimehd-firmware/package.nix b/pkgs/by-name/fa/facetimehd-firmware/package.nix index 6679f1f19e7522..9e0a9e04e69f9e 100644 --- a/pkgs/by-name/fa/facetimehd-firmware/package.nix +++ b/pkgs/by-name/fa/facetimehd-firmware/package.nix @@ -1,10 +1,16 @@ -{ lib, stdenvNoCC, fetchurl, cpio, xz, pkgs }: +{ + lib, + stdenvNoCC, + fetchurl, + cpio, + xz, + pkgs, +}: let version = "1.43_5"; - # Updated according to https://github.com/patjak/bcwc_pcie/pull/81/files # and https://github.com/patjak/bcwc_pcie/blob/5a7083bd98b38ef3bd223f7ee531d58f4fb0fe7c/firmware/Makefile#L3-L9 # and https://github.com/patjak/bcwc_pcie/blob/5a7083bd98b38ef3bd223f7ee531d58f4fb0fe7c/firmware/extract-firmware.sh @@ -24,7 +30,6 @@ let firmwareOffset = "81920"; # Variable: firmw_offsets firmwareSize = "603715"; # Variable: firmw_sizes - # separated this here as the script will fail without the 'exit 0' unpack = pkgs.writeScriptBin "unpack" '' xzcat -Q $src | cpio --format odc -i -d ${firmwareIn} @@ -46,7 +51,10 @@ stdenvNoCC.mkDerivation { dontUnpack = true; dontInstall = true; - buildInputs = [ cpio xz ]; + buildInputs = [ + cpio + xz + ]; buildPhase = '' ${unpack}/bin/unpack @@ -59,8 +67,14 @@ stdenvNoCC.mkDerivation { description = "facetimehd firmware"; homepage = "https://support.apple.com/kb/DL1877"; license = licenses.unfree; - maintainers = with maintainers; [ womfoo grahamc ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + maintainers = with maintainers; [ + womfoo + grahamc + ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/fa/facter/gemset.nix b/pkgs/by-name/fa/facter/gemset.nix index 92a024a62211b1..82645059d61dfe 100644 --- a/pkgs/by-name/fa/facter/gemset.nix +++ b/pkgs/by-name/fa/facter/gemset.nix @@ -1,30 +1,33 @@ { facter = { - dependencies = ["hocon" "thor"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "hocon" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17d561xf4s5016fm9jkfkkafn6660g04fz1yp5xfvkb0j4xj32mp"; type = "gem"; }; version = "4.10.0"; }; hocon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "106dmzsl1bxkqw5xaif012nwwfr3k9wff32cqc77ibjngknj6477"; type = "gem"; }; version = "1.4.0"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k7j2wn14h1pl4smibasw0bp66kg626drxb59z7rzflch99cd4rg"; type = "gem"; }; diff --git a/pkgs/by-name/fa/facter/package.nix b/pkgs/by-name/fa/facter/package.nix index 8d5f3bc03addc8..864efc67eac1f9 100644 --- a/pkgs/by-name/fa/facter/package.nix +++ b/pkgs/by-name/fa/facter/package.nix @@ -60,7 +60,10 @@ bundlerApp { homepage = "https://github.com/puppetlabs/facter"; license = lib.licenses.asl20; mainProgram = "facter"; - maintainers = with lib.maintainers; [ womfoo anthonyroussel ]; + maintainers = with lib.maintainers; [ + womfoo + anthonyroussel + ]; platforms = lib.platforms.unix; }; } diff --git a/pkgs/by-name/fa/fail2ban/package.nix b/pkgs/by-name/fa/fail2ban/package.nix index 6943ccc447a0e9..720ff17dac1a92 100644 --- a/pkgs/by-name/fa/fail2ban/package.nix +++ b/pkgs/by-name/fa/fail2ban/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, python3 -, installShellFiles -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + python3, + installShellFiles, + nixosTests, }: python3.pkgs.buildPythonApplication rec { @@ -18,11 +19,15 @@ python3.pkgs.buildPythonApplication rec { hash = "sha256-0xPNhbu6/p/cbHOr5Y+PXbMbt5q/S13S5100ZZSdylE="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; nativeBuildInputs = [ installShellFiles ]; - pythonPath = with python3.pkgs; + pythonPath = + with python3.pkgs; lib.optionals stdenv.hostPlatform.isLinux [ systemd pyinotify @@ -83,7 +88,8 @@ python3.pkgs.buildPythonApplication rec { rm $out/bin/fail2ban-python ln -s ${python3.interpreter} $out/bin/fail2ban-python - '' + lib.optionalString stdenv.hostPlatform.isLinux '' + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' # see https://github.com/NixOS/nixpkgs/issues/4968 rm -r "${sitePackages}/usr" ''; diff --git a/pkgs/by-name/fa/faircamp/package.nix b/pkgs/by-name/fa/faircamp/package.nix index 3ff332f68ff9e2..81684a7c5f9ec0 100644 --- a/pkgs/by-name/fa/faircamp/package.nix +++ b/pkgs/by-name/fa/faircamp/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitea -, makeWrapper -, pkg-config -, glib -, libopus -, vips -, ffmpeg -, callPackage -, darwin -, testers -, faircamp +{ + lib, + stdenv, + rustPlatform, + fetchFromGitea, + makeWrapper, + pkg-config, + glib, + libopus, + vips, + ffmpeg, + callPackage, + darwin, + testers, + faircamp, }: rustPlatform.buildRustPackage rec { @@ -40,13 +41,15 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - glib - libopus - vips - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreServices - ]; + buildInputs = + [ + glib + libopus + vips + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreServices + ]; postInstall = '' wrapProgram $out/bin/faircamp \ diff --git a/pkgs/by-name/fa/faircamp/test-wav.nix b/pkgs/by-name/fa/faircamp/test-wav.nix index 8a9d2eaa2f35a3..272bb1b71d20e0 100644 --- a/pkgs/by-name/fa/faircamp/test-wav.nix +++ b/pkgs/by-name/fa/faircamp/test-wav.nix @@ -1,6 +1,7 @@ -{ stdenv -, faircamp -, ffmpeg +{ + stdenv, + faircamp, + ffmpeg, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/fa/fairymax/package.nix b/pkgs/by-name/fa/fairymax/package.nix index 9ea9d7df974ddd..5950e0b3591f1b 100644 --- a/pkgs/by-name/fa/fairymax/package.nix +++ b/pkgs/by-name/fa/fairymax/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { @@ -39,9 +40,9 @@ stdenv.mkDerivation rec { description = "Small chess engine supporting fairy pieces"; mainProgram = "fairymax"; longDescription = '' - A version of micro-Max that reads the piece description from a file - fmax.ini, so that arbitrary fairy pieces can be implemented. This version - (4.8J) supports up to 15 piece types, and board sizes up to 12x8. + A version of micro-Max that reads the piece description from a file + fmax.ini, so that arbitrary fairy pieces can be implemented. This version + (4.8J) supports up to 15 piece types, and board sizes up to 12x8. ''; license = licenses.free; maintainers = [ maintainers.raskin ]; diff --git a/pkgs/by-name/fa/fairywren/package.nix b/pkgs/by-name/fa/fairywren/package.nix index f28ec94a37198f..088f1137045784 100644 --- a/pkgs/by-name/fa/fairywren/package.nix +++ b/pkgs/by-name/fa/fairywren/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchFromGitLab -, colorVariants ? [] # default: install all icons +{ + lib, + stdenvNoCC, + fetchFromGitLab, + colorVariants ? [ ], # default: install all icons }: let @@ -14,31 +15,34 @@ let in lib.checkListOfEnum "${pname}: colorVariants" colorVariantList colorVariants -stdenvNoCC.mkDerivation { - inherit pname; - version = "0-unstable-2024-06-10"; + stdenvNoCC.mkDerivation + { + inherit pname; + version = "0-unstable-2024-06-10"; - src = fetchFromGitLab{ - owner = "aiyahm"; - repo = "FairyWren-Icons"; - rev = "a86736cc9ff50af0ca59ef31c464da2f9e9da103"; - hash = "sha256-IzTq45lMdlAt+mEb7gpp1hWKBUSeLWINK53Sv4RithI="; - }; + src = fetchFromGitLab { + owner = "aiyahm"; + repo = "FairyWren-Icons"; + rev = "a86736cc9ff50af0ca59ef31c464da2f9e9da103"; + hash = "sha256-IzTq45lMdlAt+mEb7gpp1hWKBUSeLWINK53Sv4RithI="; + }; - installPhase = '' - runHook preInstall - mkdir -p $out/share/icons - cp -r ${lib.concatStringsSep " " (if colorVariants != [] then colorVariants else colorVariantList)} $out/share/icons/ - runHook postInstall - ''; + installPhase = '' + runHook preInstall + mkdir -p $out/share/icons + cp -r ${ + lib.concatStringsSep " " (if colorVariants != [ ] then colorVariants else colorVariantList) + } $out/share/icons/ + runHook postInstall + ''; - dontFixup = true; + dontFixup = true; - meta = with lib; { - description = "FairyWren Icon Set"; - homepage = "https://gitlab.com/aiyahm/FairyWren-Icons"; - maintainers = with maintainers; [ d3vil0p3r ]; - platforms = platforms.all; - license = with licenses; [ gpl3Plus ]; - }; -} + meta = with lib; { + description = "FairyWren Icon Set"; + homepage = "https://gitlab.com/aiyahm/FairyWren-Icons"; + maintainers = with maintainers; [ d3vil0p3r ]; + platforms = platforms.all; + license = with licenses; [ gpl3Plus ]; + }; + } diff --git a/pkgs/by-name/fa/fakeNss/package.nix b/pkgs/by-name/fa/fakeNss/package.nix index 7d85ec5fc0a5f4..346f683c72738c 100644 --- a/pkgs/by-name/fa/fakeNss/package.nix +++ b/pkgs/by-name/fa/fakeNss/package.nix @@ -2,13 +2,22 @@ # Useful when packaging binaries that insist on using nss to look up # username/groups (like nginx). # /bin/sh is fine to not exist, and provided by another shim. -{ lib, symlinkJoin, writeTextDir, runCommand, extraPasswdLines ? [], extraGroupLines ? [] }: +{ + lib, + symlinkJoin, + writeTextDir, + runCommand, + extraPasswdLines ? [ ], + extraGroupLines ? [ ], +}: symlinkJoin { name = "fake-nss"; paths = [ (writeTextDir "etc/passwd" '' root:x:0:0:root user:/var/empty:/bin/sh - ${lib.concatStrings (map (line: line + "\n") extraPasswdLines)}nobody:x:65534:65534:nobody:/var/empty:/bin/sh + ${ + lib.concatStrings (map (line: line + "\n") extraPasswdLines) + }nobody:x:65534:65534:nobody:/var/empty:/bin/sh '') (writeTextDir "etc/group" '' root:x:0: diff --git a/pkgs/by-name/fa/fakechroot/package.nix b/pkgs/by-name/fa/fakechroot/package.nix index 2357d87cc15382..cb24c0c7816fde 100644 --- a/pkgs/by-name/fa/fakechroot/package.nix +++ b/pkgs/by-name/fa/fakechroot/package.nix @@ -1,13 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, nixosTests, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + nixosTests, + perl, +}: stdenv.mkDerivation rec { pname = "fakechroot"; version = "2.20.1"; src = fetchFromGitHub { - owner = "dex4er"; - repo = pname; - rev = version; + owner = "dex4er"; + repo = pname; + rev = version; sha256 = "0xgnwazrmrg4gm30xjxdn6sx3lhqvxahrh6gmy3yfswxc30pmg86"; }; @@ -60,7 +68,7 @@ stdenv.mkDerivation rec { homepage = "https://github.com/dex4er/fakechroot"; description = "Give a fake chroot environment through LD_PRELOAD"; license = licenses.lgpl21; - maintainers = with maintainers; [offline]; + maintainers = with maintainers; [ offline ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/fa/fakeroot/package.nix b/pkgs/by-name/fa/fakeroot/package.nix index 3e805834bd35af..5ca98bcecec822 100644 --- a/pkgs/by-name/fa/fakeroot/package.nix +++ b/pkgs/by-name/fa/fakeroot/package.nix @@ -1,15 +1,16 @@ -{ lib -, coreutils -, stdenv -, fetchFromGitLab -, fetchpatch -, getopt -, libcap -, gnused -, nixosTests -, testers -, autoreconfHook -, po4a +{ + lib, + coreutils, + stdenv, + fetchFromGitLab, + fetchpatch, + getopt, + libcap, + gnused, + nixosTests, + testers, + autoreconfHook, + po4a, }: stdenv.mkDerivation (finalAttrs: { @@ -36,7 +37,10 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - nativeBuildInputs = [ autoreconfHook po4a ]; + nativeBuildInputs = [ + autoreconfHook + po4a + ]; buildInputs = lib.optional (!stdenv.hostPlatform.isDarwin) libcap; postUnpack = '' diff --git a/pkgs/by-name/fa/fakeroute/package.nix b/pkgs/by-name/fa/fakeroute/package.nix index 797a347bb45f5f..491d3677338899 100644 --- a/pkgs/by-name/fa/fakeroute/package.nix +++ b/pkgs/by-name/fa/fakeroute/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, nixosTests }: +{ + lib, + stdenv, + fetchurl, + nixosTests, +}: stdenv.mkDerivation rec { pname = "fakeroute"; diff --git a/pkgs/by-name/fa/faketty/package.nix b/pkgs/by-name/fa/faketty/package.nix index a1ec209498c0f8..c9a816ee7980f0 100644 --- a/pkgs/by-name/fa/faketty/package.nix +++ b/pkgs/by-name/fa/faketty/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "faketty"; @@ -19,7 +23,10 @@ rustPlatform.buildRustPackage rec { description = "Wrapper to execute a command in a pty, even if redirecting the output"; homepage = "https://github.com/dtolnay/faketty"; changelog = "https://github.com/dtolnay/faketty/releases/tag/${version}"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "faketty"; }; diff --git a/pkgs/by-name/fa/falcoctl/package.nix b/pkgs/by-name/fa/falcoctl/package.nix index 7a73cc8cea29b4..0734f0a91b6b21 100644 --- a/pkgs/by-name/fa/falcoctl/package.nix +++ b/pkgs/by-name/fa/falcoctl/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "falcoctl"; @@ -13,7 +17,6 @@ buildGoModule rec { vendorHash = "sha256-26EXoXMWK/zPX4M7kG3QRAb4aqtIWgSnSgXcxKUwfZk="; - ldflags = [ "-s" "-w" @@ -25,6 +28,10 @@ buildGoModule rec { mainProgram = "falcoctl"; homepage = "https://github.com/falcosecurity/falcoctl"; license = licenses.asl20; - maintainers = with maintainers; [ developer-guy kranurag7 LucaGuerra ]; + maintainers = with maintainers; [ + developer-guy + kranurag7 + LucaGuerra + ]; }; } diff --git a/pkgs/by-name/fa/fan2go/package.nix b/pkgs/by-name/fa/fan2go/package.nix index 296bfea580696a..4bdb61f9fb8c21 100644 --- a/pkgs/by-name/fa/fan2go/package.nix +++ b/pkgs/by-name/fa/fan2go/package.nix @@ -1,4 +1,9 @@ -{ buildGo123Module, fetchFromGitHub, lib, lm_sensors }: +{ + buildGo123Module, + fetchFromGitHub, + lib, + lm_sensors, +}: buildGo123Module rec { pname = "fan2go"; diff --git a/pkgs/by-name/fa/fanbox-dl/package.nix b/pkgs/by-name/fa/fanbox-dl/package.nix index f4677c9e3800aa..f2c942757e4bbc 100644 --- a/pkgs/by-name/fa/fanbox-dl/package.nix +++ b/pkgs/by-name/fa/fanbox-dl/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "fanbox-dl"; diff --git a/pkgs/by-name/fa/fanctl/package.nix b/pkgs/by-name/fa/fanctl/package.nix index 072ecda1e38fa3..e7d622abd8bf2b 100644 --- a/pkgs/by-name/fa/fanctl/package.nix +++ b/pkgs/by-name/fa/fanctl/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitLab, rustPlatform }: +{ + lib, + fetchFromGitLab, + rustPlatform, +}: rustPlatform.buildRustPackage rec { version = "0.6.4"; diff --git a/pkgs/by-name/fa/fancy-motd/package.nix b/pkgs/by-name/fa/fancy-motd/package.nix index f05ea8adceb90b..4be50c7822515b 100644 --- a/pkgs/by-name/fa/fancy-motd/package.nix +++ b/pkgs/by-name/fa/fancy-motd/package.nix @@ -1,4 +1,15 @@ -{ stdenv, lib, fetchFromGitHub, bc, curl, figlet, fortune, gawk, iproute2, procps }: +{ + stdenv, + lib, + fetchFromGitHub, + bc, + curl, + figlet, + fortune, + gawk, + iproute2, + procps, +}: stdenv.mkDerivation rec { pname = "fancy-motd"; @@ -11,7 +22,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-O/euB63Dyj+NyfZK42egSEYwZhL8B0jCxSSDYoT4cpo="; }; - buildInputs = [ bc curl figlet fortune gawk iproute2 ]; + buildInputs = [ + bc + curl + figlet + fortune + gawk + iproute2 + ]; postPatch = '' substituteInPlace motd.sh \ diff --git a/pkgs/by-name/fa/fanficfare/package.nix b/pkgs/by-name/fa/fanficfare/package.nix index 9b28551ac01145..dad31cb8506e75 100644 --- a/pkgs/by-name/fa/fanficfare/package.nix +++ b/pkgs/by-name/fa/fanficfare/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "fanficfare"; diff --git a/pkgs/by-name/fa/fangfrisch/package.nix b/pkgs/by-name/fa/fangfrisch/package.nix index 9ee1161338734a..8b99fda48ae49b 100644 --- a/pkgs/by-name/fa/fangfrisch/package.nix +++ b/pkgs/by-name/fa/fangfrisch/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: let version = "1.9.0"; diff --git a/pkgs/by-name/fa/fantasque-sans-mono/package.nix b/pkgs/by-name/fa/fantasque-sans-mono/package.nix index 9d594a7f7580cd..bcde2ee4085b53 100644 --- a/pkgs/by-name/fa/fantasque-sans-mono/package.nix +++ b/pkgs/by-name/fa/fantasque-sans-mono/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "fantasque-sans-mono"; diff --git a/pkgs/by-name/fa/fanwood/package.nix b/pkgs/by-name/fa/fanwood/package.nix index 789aee6922d146..0b0c7274148bf5 100644 --- a/pkgs/by-name/fa/fanwood/package.nix +++ b/pkgs/by-name/fa/fanwood/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, +}: stdenvNoCC.mkDerivation { pname = "fanwood"; diff --git a/pkgs/by-name/fa/faq/package.nix b/pkgs/by-name/fa/faq/package.nix index c955174a4affa4..d78758e0777cee 100644 --- a/pkgs/by-name/fa/faq/package.nix +++ b/pkgs/by-name/fa/faq/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, jq -, oniguruma +{ + lib, + buildGoModule, + fetchFromGitHub, + jq, + oniguruma, }: buildGoModule rec { diff --git a/pkgs/by-name/fa/faraday-agent-dispatcher/package.nix b/pkgs/by-name/fa/faraday-agent-dispatcher/package.nix index 6c883e2436984d..5b6a3420c2b624 100644 --- a/pkgs/by-name/fa/faraday-agent-dispatcher/package.nix +++ b/pkgs/by-name/fa/faraday-agent-dispatcher/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/fa/faraday-cli/package.nix b/pkgs/by-name/fa/faraday-cli/package.nix index 7e6ac5315e7db5..814572c2b8e19a 100644 --- a/pkgs/by-name/fa/faraday-cli/package.nix +++ b/pkgs/by-name/fa/faraday-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/fa/faraday/package.nix b/pkgs/by-name/fa/faraday/package.nix index 14b065329bb1b9..3aa54ddbcd2ef4 100644 --- a/pkgs/by-name/fa/faraday/package.nix +++ b/pkgs/by-name/fa/faraday/package.nix @@ -1,8 +1,9 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, testers -, faraday +{ + buildGoModule, + fetchFromGitHub, + lib, + testers, + faraday, }: buildGoModule rec { @@ -18,9 +19,15 @@ buildGoModule rec { vendorHash = "sha256-ku/4VE1Gj62vuJLh9J6vKlxpyI7S0RsMDozV7U5YDe4="; - subPackages = [ "cmd/frcli" "cmd/faraday" ]; + subPackages = [ + "cmd/frcli" + "cmd/faraday" + ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests.version = testers.testVersion { package = faraday; @@ -30,6 +37,9 @@ buildGoModule rec { description = "LND Channel Management Tools"; homepage = "https://github.com/lightninglabs/faraday"; license = licenses.mit; - maintainers = with maintainers; [ proofofkeags prusnak ]; + maintainers = with maintainers; [ + proofofkeags + prusnak + ]; }; } diff --git a/pkgs/by-name/fa/farbfeld/package.nix b/pkgs/by-name/fa/farbfeld/package.nix index 3e1045ab852bfb..d99e3554fe40be 100644 --- a/pkgs/by-name/fa/farbfeld/package.nix +++ b/pkgs/by-name/fa/farbfeld/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeWrapper, file, libpng, libjpeg }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + file, + libpng, + libjpeg, +}: stdenv.mkDerivation rec { pname = "farbfeld"; @@ -9,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "0ap7rcngffhdd57jw9j22arzkbrhwh0zpxhwbdfwl8fixlhmkpy7"; }; - buildInputs = [ libpng libjpeg ]; + buildInputs = [ + libpng + libjpeg + ]; nativeBuildInputs = [ makeWrapper ]; makeFlags = [ "CC:=$(CC)" ]; diff --git a/pkgs/by-name/fa/farge/package.nix b/pkgs/by-name/fa/farge/package.nix index 64ab2b084e4c1f..fbef65d5b0e5ad 100644 --- a/pkgs/by-name/fa/farge/package.nix +++ b/pkgs/by-name/fa/farge/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, makeBinaryWrapper -, bc -, libnotify -, feh -, grim -, imagemagick -, slurp -, wl-clipboard -, xcolor +{ + lib, + stdenvNoCC, + fetchFromGitHub, + makeBinaryWrapper, + bc, + libnotify, + feh, + grim, + imagemagick, + slurp, + wl-clipboard, + xcolor, -, waylandSupport ? true -, x11Support ? true + waylandSupport ? true, + x11Support ? true, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -29,17 +30,21 @@ stdenvNoCC.mkDerivation (finalAttrs: { nativeBuildInputs = [ makeBinaryWrapper ]; # Ensure the following programs are found within $PATH - wrapperPath = lib.makeBinPath ([ - bc - feh - libnotify # notify-send - # Needed to fix font rendering issue in imagemagick - (imagemagick.override { ghostscriptSupport = true; }) - ] ++ lib.optionals waylandSupport [ - grim - slurp - wl-clipboard - ] ++ lib.optional x11Support xcolor); + wrapperPath = lib.makeBinPath ( + [ + bc + feh + libnotify # notify-send + # Needed to fix font rendering issue in imagemagick + (imagemagick.override { ghostscriptSupport = true; }) + ] + ++ lib.optionals waylandSupport [ + grim + slurp + wl-clipboard + ] + ++ lib.optional x11Support xcolor + ); installPhase = '' runHook preInstall @@ -54,7 +59,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { homepage = "https://github.com/sdushantha/farge"; license = licenses.mit; platforms = platforms.unix; - maintainers = with maintainers; [ jtbx justinlime ]; + maintainers = with maintainers; [ + jtbx + justinlime + ]; mainProgram = "farge"; }; }) diff --git a/pkgs/by-name/fa/fasd/package.nix b/pkgs/by-name/fa/fasd/package.nix index 45ec3d6ddfdd99..02fd107c170b7e 100644 --- a/pkgs/by-name/fa/fasd/package.nix +++ b/pkgs/by-name/fa/fasd/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub } : +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "fasd"; diff --git a/pkgs/by-name/fa/fasmg/package.nix b/pkgs/by-name/fa/fasmg/package.nix index 8f3b51b42d65c4..56ba608f391eeb 100644 --- a/pkgs/by-name/fa/fasmg/package.nix +++ b/pkgs/by-name/fa/fasmg/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchzip +{ + lib, + stdenv, + fetchzip, -# update script -, writeScript -, coreutils -, curl -, gnugrep -, htmlq -, nix-update + # update script + writeScript, + coreutils, + curl, + gnugrep, + htmlq, + nix-update, }: stdenv.mkDerivation rec { @@ -20,34 +22,41 @@ stdenv.mkDerivation rec { stripRoot = false; }; - buildPhase = let - inherit (stdenv.hostPlatform) system; + buildPhase = + let + inherit (stdenv.hostPlatform) system; - path = { - x86_64-linux = { - bin = "fasmg.x64"; - asm = "source/linux/x64/fasmg.asm"; - }; - x86_64-darwin = { - bin = "source/macos/x64/fasmg"; - asm = "source/macos/x64/fasmg.asm"; - }; - x86-linux = { - bin = "fasmg"; - asm = "source/linux/fasmg.asm"; - }; - x86-darwin = { - bin = "source/macos/fasmg"; - asm = "source/macos/fasmg.asm"; - }; - }.${system} or (throw "Unsupported system: ${system}"); + path = + { + x86_64-linux = { + bin = "fasmg.x64"; + asm = "source/linux/x64/fasmg.asm"; + }; + x86_64-darwin = { + bin = "source/macos/x64/fasmg"; + asm = "source/macos/x64/fasmg.asm"; + }; + x86-linux = { + bin = "fasmg"; + asm = "source/linux/fasmg.asm"; + }; + x86-darwin = { + bin = "source/macos/fasmg"; + asm = "source/macos/fasmg.asm"; + }; + } + .${system} or (throw "Unsupported system: ${system}"); - in '' - chmod +x ${path.bin} - ./${path.bin} ${path.asm} fasmg - ''; + in + '' + chmod +x ${path.bin} + ./${path.bin} ${path.asm} fasmg + ''; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; installPhase = '' install -Dm755 fasmg $out/bin/fasmg @@ -57,7 +66,15 @@ stdenv.mkDerivation rec { ''; passthru.updateScript = writeScript "update-fasmg.sh" '' - export PATH="${lib.makeBinPath [ coreutils curl gnugrep htmlq nix-update ]}:$PATH" + export PATH="${ + lib.makeBinPath [ + coreutils + curl + gnugrep + htmlq + nix-update + ] + }:$PATH" version=$( curl 'https://flatassembler.net/download.php' \ | htmlq .links a.boldlink -a href \ @@ -73,7 +90,10 @@ stdenv.mkDerivation rec { mainProgram = "fasmg"; homepage = "https://flatassembler.net"; license = licenses.bsd3; - maintainers = with maintainers; [ orivej clevor ]; + maintainers = with maintainers; [ + orivej + clevor + ]; platforms = with platforms; intersectLists (linux ++ darwin) x86; }; } diff --git a/pkgs/by-name/fa/fasole/package.nix b/pkgs/by-name/fa/fasole/package.nix index 81df4e88d424ae..48c59b4c667fae 100644 --- a/pkgs/by-name/fa/fasole/package.nix +++ b/pkgs/by-name/fa/fasole/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "fasole"; diff --git a/pkgs/by-name/fa/fast-cpp-csv-parser/package.nix b/pkgs/by-name/fa/fast-cpp-csv-parser/package.nix index a30aacee26e5d4..13a2e2dbc5a3d8 100644 --- a/pkgs/by-name/fa/fast-cpp-csv-parser/package.nix +++ b/pkgs/by-name/fa/fast-cpp-csv-parser/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "fast-cpp-csv-parser"; diff --git a/pkgs/by-name/fa/fast-downward/package.nix b/pkgs/by-name/fa/fast-downward/package.nix index 790f619c6faf3c..e74ef6423e8690 100644 --- a/pkgs/by-name/fa/fast-downward/package.nix +++ b/pkgs/by-name/fa/fast-downward/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, python3 -, osi -, cplex +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + python3, + osi, + cplex, }: stdenv.mkDerivation rec { @@ -18,8 +19,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-iIBoJZCFd05bKUeftvl2YBTmSQuFvATIQAYMITDywWA="; }; - nativeBuildInputs = [ cmake python3.pkgs.wrapPython ]; - buildInputs = [ python3 osi ]; + nativeBuildInputs = [ + cmake + python3.pkgs.wrapPython + ]; + buildInputs = [ + python3 + osi + ]; cmakeFlags = lib.optionals osi.withCplex [ "-DDOWNWARD_CPLEX_ROOT=${cplex}/cplex" ]; diff --git a/pkgs/by-name/fa/fastJson/package.nix b/pkgs/by-name/fa/fastJson/package.nix index 1e8791f10419b8..131baa6fe346f7 100644 --- a/pkgs/by-name/fa/fastJson/package.nix +++ b/pkgs/by-name/fa/fastJson/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fa/fastcap/package.nix b/pkgs/by-name/fa/fastcap/package.nix index f809b1094ff428..2dda691dbeba4d 100644 --- a/pkgs/by-name/fa/fastcap/package.nix +++ b/pkgs/by-name/fa/fastcap/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, fetchzip -, ghostscript -, lib -, texliveMedium +{ + stdenv, + fetchzip, + ghostscript, + lib, + texliveMedium, }: stdenv.mkDerivation rec { @@ -53,7 +54,10 @@ stdenv.mkDerivation rec { "all" ]; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; postBuild = '' make manual @@ -84,7 +88,7 @@ stdenv.mkDerivation rec { Fastcap is a three dimensional capacitance extraction program that compute self and mutual capacitances between conductors of arbitrary shapes, sizes and orientations. - ''; + ''; homepage = "https://www.rle.mit.edu/cpg/research_codes.htm"; license = licenses.mit; maintainers = with maintainers; [ fbeffa ]; diff --git a/pkgs/by-name/fa/fastcdr/package.nix b/pkgs/by-name/fa/fastcdr/package.nix index 3e8678a8a76c3c..559f6fdcff2570 100644 --- a/pkgs/by-name/fa/fastcdr/package.nix +++ b/pkgs/by-name/fa/fastcdr/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, gtest -, withDocs ? true -, doxygen -, graphviz-nox +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + gtest, + withDocs ? true, + doxygen, + graphviz-nox, }: stdenv.mkDerivation (finalAttrs: { @@ -23,19 +24,22 @@ stdenv.mkDerivation (finalAttrs: { ./0001-Do-not-require-wget-and-unzip.patch ]; - cmakeFlags = lib.optional (stdenv.hostPlatform.isStatic) "-DBUILD_SHARED_LIBS=OFF" - # upstream turns BUILD_TESTING=OFF by default and doesn't honor cmake's default (=ON) - ++ lib.optional (finalAttrs.finalPackage.doCheck) "-DBUILD_TESTING=ON" - ++ lib.optional withDocs "-DBUILD_DOCUMENTATION=ON"; + cmakeFlags = + lib.optional (stdenv.hostPlatform.isStatic) "-DBUILD_SHARED_LIBS=OFF" + # upstream turns BUILD_TESTING=OFF by default and doesn't honor cmake's default (=ON) + ++ lib.optional (finalAttrs.finalPackage.doCheck) "-DBUILD_TESTING=ON" + ++ lib.optional withDocs "-DBUILD_DOCUMENTATION=ON"; outputs = [ "out" ] ++ lib.optional withDocs "doc"; - nativeBuildInputs = [ - cmake - ] ++ lib.optionals withDocs [ - doxygen - graphviz-nox - ]; + nativeBuildInputs = + [ + cmake + ] + ++ lib.optionals withDocs [ + doxygen + graphviz-nox + ]; doCheck = true; diff --git a/pkgs/by-name/fa/fastd/package.nix b/pkgs/by-name/fa/fastd/package.nix index cafcf4bdaf5067..d49bdb7e5da388 100644 --- a/pkgs/by-name/fa/fastd/package.nix +++ b/pkgs/by-name/fa/fastd/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, bison -, meson -, ninja -, pkg-config -, libmnl -, libuecc -, libsodium -, libcap -, json_c -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + bison, + meson, + ninja, + pkg-config, + libmnl, + libuecc, + libsodium, + libcap, + json_c, + openssl, }: stdenv.mkDerivation rec { @@ -18,7 +19,7 @@ stdenv.mkDerivation rec { version = "22"; src = fetchFromGitHub { - owner = "Neoraider"; + owner = "Neoraider"; repo = "fastd"; rev = "v${version}"; sha256 = "0qni32j7d3za9f87m68wq8zgalvfxdrx1zxi6l4x7vvmpcw5nhpq"; @@ -31,15 +32,17 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - json_c - libcap - libsodium - libuecc - openssl - ] ++ lib.optionals (stdenv.hostPlatform.isLinux) [ - libmnl - ]; + buildInputs = + [ + json_c + libcap + libsodium + libuecc + openssl + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux) [ + libmnl + ]; # some options are only available on x86 mesonFlags = lib.optionals (!stdenv.hostPlatform.isx86) [ @@ -51,7 +54,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Fast and Secure Tunneling Daemon"; homepage = "https://projects.universe-factory.net/projects/fastd/wiki"; - license = with licenses; [ bsd2 bsd3 ]; + license = with licenses; [ + bsd2 + bsd3 + ]; platforms = platforms.linux; maintainers = with maintainers; [ fpletz ]; mainProgram = "fastd"; diff --git a/pkgs/by-name/fa/fastddsgen/package.nix b/pkgs/by-name/fa/fastddsgen/package.nix index dbabe8cb40fadb..28bc6633f6027d 100644 --- a/pkgs/by-name/fa/fastddsgen/package.nix +++ b/pkgs/by-name/fa/fastddsgen/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, makeWrapper -, fetchFromGitHub -, gradle_7 -, openjdk17 +{ + lib, + stdenv, + makeWrapper, + fetchFromGitHub, + gradle_7, + openjdk17, }: let @@ -37,7 +38,10 @@ stdenv.mkDerivation { __darwinAllowLocalNetworking = true; - gradleFlags = [ "-x" "submodulesUpdate" ]; + gradleFlags = [ + "-x" + "submodulesUpdate" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/fa/fastgron/package.nix b/pkgs/by-name/fa/fastgron/package.nix index 5b5796cc7014c6..59a994953d0fb0 100644 --- a/pkgs/by-name/fa/fastgron/package.nix +++ b/pkgs/by-name/fa/fastgron/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, curl, testers }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + curl, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "fastgron"; diff --git a/pkgs/by-name/fa/fasthenry/package.nix b/pkgs/by-name/fa/fasthenry/package.nix index 963828e18edc4b..a48cc020e71acd 100644 --- a/pkgs/by-name/fa/fasthenry/package.nix +++ b/pkgs/by-name/fa/fasthenry/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, fetchFromGitHub -, lib +{ + stdenv, + fetchFromGitHub, + lib, }: stdenv.mkDerivation rec { @@ -22,22 +23,29 @@ stdenv.mkDerivation rec { dontConfigure = true; - preBuild = '' - makeFlagsArray=( - CC="gcc" - RM="rm" - SHELL="sh" - "all" - ) - '' + (if stdenv.hostPlatform.isx86_64 then '' - makeFlagsArray+=( - CFLAGS="-fcommon -O -DFOUR -m64" + preBuild = + '' + makeFlagsArray=( + CC="gcc" + RM="rm" + SHELL="sh" + "all" + ) + '' + + ( + if stdenv.hostPlatform.isx86_64 then + '' + makeFlagsArray+=( + CFLAGS="-fcommon -O -DFOUR -m64" + ); + '' + else + '' + makeFlagsArray+=( + CFLAGS="-fcommon -O -DFOUR" + ); + '' ); - '' else '' - makeFlagsArray+=( - CFLAGS="-fcommon -O -DFOUR" - ); - ''); installPhase = '' mkdir -p $out/bin @@ -51,8 +59,8 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Multipole-accelerated inductance analysis program"; longDescription = '' - Fasthenry is an inductance extraction program based on a - multipole-accelerated algorithm.''; + Fasthenry is an inductance extraction program based on a + multipole-accelerated algorithm.''; homepage = "https://www.fastfieldsolvers.com/fasthenry2.htm"; license = licenses.lgpl2Only; maintainers = with maintainers; [ fbeffa ]; diff --git a/pkgs/by-name/fa/fastjet-contrib/package.nix b/pkgs/by-name/fa/fastjet-contrib/package.nix index e4cf47683ec841..4bb49c711d5848 100644 --- a/pkgs/by-name/fa/fastjet-contrib/package.nix +++ b/pkgs/by-name/fa/fastjet-contrib/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fastjet }: +{ + lib, + stdenv, + fetchurl, + fastjet, +}: stdenv.mkDerivation rec { pname = "fastjet-contrib"; diff --git a/pkgs/by-name/fa/fastjet/package.nix b/pkgs/by-name/fa/fastjet/package.nix index 19c48c1fa11780..cdb7394c9688f0 100644 --- a/pkgs/by-name/fa/fastjet/package.nix +++ b/pkgs/by-name/fa/fastjet/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, python ? null -, withPython ? false +{ + lib, + stdenv, + fetchurl, + python ? null, + withPython ? false, }: stdenv.mkDerivation rec { @@ -25,9 +26,9 @@ stdenv.mkDerivation rec { meta = { description = "Software package for jet finding in pp and e+e− collisions"; mainProgram = "fastjet-config"; - license = lib.licenses.gpl2Plus; - homepage = "http://fastjet.fr/"; - platforms = lib.platforms.unix; + license = lib.licenses.gpl2Plus; + homepage = "http://fastjet.fr/"; + platforms = lib.platforms.unix; maintainers = with lib.maintainers; [ veprbl ]; }; } diff --git a/pkgs/by-name/fa/fastnetmon-advanced/package.nix b/pkgs/by-name/fa/fastnetmon-advanced/package.nix index a20a14bed3b5b0..6d131ee3ce5b12 100644 --- a/pkgs/by-name/fa/fastnetmon-advanced/package.nix +++ b/pkgs/by-name/fa/fastnetmon-advanced/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, bzip2 -, nixosTests +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + bzip2, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fa/fastnlo-toolkit/package.nix b/pkgs/by-name/fa/fastnlo-toolkit/package.nix index 3b1a011e10ff50..d43cc2698c1bbc 100644 --- a/pkgs/by-name/fa/fastnlo-toolkit/package.nix +++ b/pkgs/by-name/fa/fastnlo-toolkit/package.nix @@ -35,13 +35,16 @@ stdenv.mkDerivation rec { ./yoda2_support.patch ]; - buildInputs = [ - boost - gfortran - gfortran.cc.lib - lhapdf - yoda - ] ++ lib.optional withPython python ++ lib.optional (withPython && python.isPy3k) ncurses; + buildInputs = + [ + boost + gfortran + gfortran.cc.lib + lhapdf + yoda + ] + ++ lib.optional withPython python + ++ lib.optional (withPython && python.isPy3k) ncurses; propagatedBuildInputs = [ diff --git a/pkgs/by-name/fa/fastp/package.nix b/pkgs/by-name/fa/fastp/package.nix index 91f6c9d22047fc..89ae4a59486d21 100644 --- a/pkgs/by-name/fa/fastp/package.nix +++ b/pkgs/by-name/fa/fastp/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, zlib -, libdeflate -, isa-l +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + libdeflate, + isa-l, }: stdenv.mkDerivation rec { @@ -17,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-Jl2Os/6yLWXTDv6irInYlUHpz6QTw8CEMVGFXblAay0="; }; - buildInputs = [ zlib libdeflate isa-l ]; + buildInputs = [ + zlib + libdeflate + isa-l + ]; installPhase = '' install -D fastp $out/bin/fastp diff --git a/pkgs/by-name/fa/fastpbkdf2/package.nix b/pkgs/by-name/fa/fastpbkdf2/package.nix index 226d4d1a9e11a3..7ce1605a5f1bbf 100644 --- a/pkgs/by-name/fa/fastpbkdf2/package.nix +++ b/pkgs/by-name/fa/fastpbkdf2/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + openssl, +}: stdenv.mkDerivation rec { pname = "fastpbkdf2"; diff --git a/pkgs/by-name/fa/fastqc/package.nix b/pkgs/by-name/fa/fastqc/package.nix index 9c63a98e771138..13c76f5b3bfef7 100644 --- a/pkgs/by-name/fa/fastqc/package.nix +++ b/pkgs/by-name/fa/fastqc/package.nix @@ -1,4 +1,5 @@ -{ lib, +{ + lib, stdenv, fetchzip, jre, @@ -8,7 +9,7 @@ makeDesktopItem, copyDesktopItems, desktopToDarwinBundle, - testers + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -22,19 +23,28 @@ stdenv.mkDerivation (finalAttrs: { dontBuild = true; - nativeBuildInputs = [ makeWrapper imagemagick ] - ++ lib.optional stdenv.hostPlatform.isLinux copyDesktopItems # postInstallHook - ++ lib.optional stdenv.hostPlatform.isDarwin desktopToDarwinBundle; #fixupOutputHook - buildInputs = [ jre perl]; + nativeBuildInputs = + [ + makeWrapper + imagemagick + ] + ++ lib.optional stdenv.hostPlatform.isLinux copyDesktopItems # postInstallHook + ++ lib.optional stdenv.hostPlatform.isDarwin desktopToDarwinBundle; # fixupOutputHook + buildInputs = [ + jre + perl + ]; - desktopItem = (makeDesktopItem { - name = "FastQC"; - exec = "fastqc"; - icon = "fastqc"; - desktopName = "FastQC"; - comment = finalAttrs.meta.description; - categories = [ "Science" ]; - }); + desktopItem = ( + makeDesktopItem { + name = "FastQC"; + exec = "fastqc"; + icon = "fastqc"; + desktopName = "FastQC"; + comment = finalAttrs.meta.description; + categories = [ "Science" ]; + } + ); desktopItems = [ finalAttrs.desktopItem ]; installPhase = '' @@ -63,19 +73,22 @@ stdenv.mkDerivation (finalAttrs: { meta = { description = "A quality control application for high throughput sequence data"; longDescription = '' - FastQC aims to provide a simple way to do some quality control checks on raw sequence data coming from high throughput sequencing pipelines. It provides a modular set of analyses which you can use to give a quick impression of whether your data has any problems of which you should be aware before doing any further analysis. + FastQC aims to provide a simple way to do some quality control checks on raw sequence data coming from high throughput sequencing pipelines. It provides a modular set of analyses which you can use to give a quick impression of whether your data has any problems of which you should be aware before doing any further analysis. - The main functions of FastQC are + The main functions of FastQC are - - Import of data from BAM, SAM or FastQ files (any variant) - - Providing a quick overview to tell you in which areas there may be problems - - Summary graphs and tables to quickly assess your data - - Export of results to an HTML based permanent report - - Offline operation to allow automated generation of reports without running the interactive application + - Import of data from BAM, SAM or FastQ files (any variant) + - Providing a quick overview to tell you in which areas there may be problems + - Summary graphs and tables to quickly assess your data + - Export of results to an HTML based permanent report + - Offline operation to allow automated generation of reports without running the interactive application ''; homepage = "https://www.bioinformatics.babraham.ac.uk/projects/fastqc/"; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; - license = with lib.licenses; [ gpl3Plus asl20 ]; + license = with lib.licenses; [ + gpl3Plus + asl20 + ]; maintainers = [ lib.maintainers.dflores ]; mainProgram = "fastqc"; platforms = lib.platforms.unix; diff --git a/pkgs/by-name/fa/fasttext/package.nix b/pkgs/by-name/fa/fasttext/package.nix index b0a36bedc536e9..1d102d9065e067 100644 --- a/pkgs/by-name/fa/fasttext/package.nix +++ b/pkgs/by-name/fa/fasttext/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchFromGitHub, cmake}: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "fasttext"; diff --git a/pkgs/by-name/fa/fatcat/package.nix b/pkgs/by-name/fa/fatcat/package.nix index fe333dc9e10dc0..aa75ed92f1c5c0 100644 --- a/pkgs/by-name/fa/fatcat/package.nix +++ b/pkgs/by-name/fa/fatcat/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fa/fatrace/package.nix b/pkgs/by-name/fa/fatrace/package.nix index 487ad533668faf..0b56836230e741 100644 --- a/pkgs/by-name/fa/fatrace/package.nix +++ b/pkgs/by-name/fa/fatrace/package.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchFromGitHub -, python3 -, which +{ + lib, + stdenv, + fetchFromGitHub, + python3, + which, }: stdenv.mkDerivation rec { @@ -15,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-MRHM+hyuRevK4L3u6dGw1S3O7w+BJBsprJVcSz6Q9xg="; }; - buildInputs = [ python3 which ]; + buildInputs = [ + python3 + which + ]; postPatch = '' substituteInPlace power-usage-report \ diff --git a/pkgs/by-name/fa/fatresize/package.nix b/pkgs/by-name/fa/fatresize/package.nix index cd4cc131eeb86c..e6ac6c06236e45 100644 --- a/pkgs/by-name/fa/fatresize/package.nix +++ b/pkgs/by-name/fa/fatresize/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, parted, util-linux, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + parted, + util-linux, + pkg-config, +}: stdenv.mkDerivation rec { @@ -12,10 +19,16 @@ stdenv.mkDerivation rec { sha256 = "1vhz84kxfyl0q7mkqn68nvzzly0a4xgzv76m6db0bk7xyczv1qr2"; }; - buildInputs = [ parted util-linux ]; + buildInputs = [ + parted + util-linux + ]; nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ parted util-linux ]; + propagatedBuildInputs = [ + parted + util-linux + ]; meta = with lib; { description = "FAT16/FAT32 non-destructive resizer"; diff --git a/pkgs/by-name/fa/fatsort/package.nix b/pkgs/by-name/fa/fatsort/package.nix index d1604e49a32e05..4ddefc9a9ebcc0 100644 --- a/pkgs/by-name/fa/fatsort/package.nix +++ b/pkgs/by-name/fa/fatsort/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, help2man -, libiconv +{ + lib, + stdenv, + fetchurl, + help2man, + libiconv, }: stdenv.mkDerivation rec { @@ -14,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-Yw7OVtnrOlVSSvCuw6reeFQ2DrqUkXKmz7R2jLj75C4="; }; - buildInputs = [ help2man libiconv ]; + buildInputs = [ + help2man + libiconv + ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" diff --git a/pkgs/by-name/fa/faudio/package.nix b/pkgs/by-name/fa/faudio/package.nix index ab6d96e3327b5e..8e827d30f46731 100644 --- a/pkgs/by-name/fa/faudio/package.nix +++ b/pkgs/by-name/fa/faudio/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, SDL2}: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + SDL2, +}: #TODO: tests @@ -13,7 +19,7 @@ stdenv.mkDerivation rec { sha256 = "sha256-hzU4MabTzpbyMMoUQ3tSwjulm6jJSxQUvVXOY3Y84yI="; }; - nativeBuildInputs = [cmake]; + nativeBuildInputs = [ cmake ]; buildInputs = [ SDL2 ]; diff --git a/pkgs/by-name/fa/faustPhysicalModeling/package.nix b/pkgs/by-name/fa/faustPhysicalModeling/package.nix index 1b7372d5d904ca..09ce68b451c93e 100644 --- a/pkgs/by-name/fa/faustPhysicalModeling/package.nix +++ b/pkgs/by-name/fa/faustPhysicalModeling/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, faust2jaqt, faust2lv2 }: +{ + stdenv, + lib, + fetchFromGitHub, + faust2jaqt, + faust2lv2, +}: stdenv.mkDerivation rec { pname = "faustPhysicalModeling"; version = "2.75.7"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-j5Qg/H7aMBZ6A8gh6v6+ICxmCZ7ya2tVF2FjueVtvHo="; }; - buildInputs = [ faust2jaqt faust2lv2 ]; + buildInputs = [ + faust2jaqt + faust2lv2 + ]; dontWrapQtApps = true; diff --git a/pkgs/by-name/fb/fbcat/package.nix b/pkgs/by-name/fb/fbcat/package.nix index d90ec77b6d5e4c..fa2ff57dd20da2 100644 --- a/pkgs/by-name/fb/fbcat/package.nix +++ b/pkgs/by-name/fb/fbcat/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, netpbm +{ + lib, + stdenv, + fetchFromGitHub, + netpbm, }: stdenv.mkDerivation rec { @@ -33,4 +34,3 @@ stdenv.mkDerivation rec { platforms = platforms.linux; }; } - diff --git a/pkgs/by-name/fb/fbida/package.nix b/pkgs/by-name/fb/fbida/package.nix index 79e66d8ed98802..e5a142d9130b27 100644 --- a/pkgs/by-name/fb/fbida/package.nix +++ b/pkgs/by-name/fb/fbida/package.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, fetchurl -, libGL -, libjpeg -, libexif -, giflib -, libtiff -, libpng -, libwebp -, libdrm -, pkg-config -, freetype -, fontconfig -, which -, imagemagick -, curl -, sane-backends -, libXpm -, libepoxy -, pixman -, poppler -, mesa -, lirc +{ + lib, + stdenv, + fetchurl, + libGL, + libjpeg, + libexif, + giflib, + libtiff, + libpng, + libwebp, + libdrm, + pkg-config, + freetype, + fontconfig, + which, + imagemagick, + curl, + sane-backends, + libXpm, + libepoxy, + pixman, + poppler, + mesa, + lirc, }: stdenv.mkDerivation rec { @@ -42,7 +43,10 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config which ]; + nativeBuildInputs = [ + pkg-config + which + ]; buildInputs = [ libGL libexif @@ -65,7 +69,12 @@ stdenv.mkDerivation rec { mesa ]; - makeFlags = [ "prefix=$(out)" "verbose=yes" "STRIP=" "JPEG_VER=62" ]; + makeFlags = [ + "prefix=$(out)" + "verbose=yes" + "STRIP=" + "JPEG_VER=62" + ]; postPatch = '' sed -e 's@ cpp\>@ gcc -E -@' -i GNUmakefile diff --git a/pkgs/by-name/fb/fbjni/package.nix b/pkgs/by-name/fb/fbjni/package.nix index aaab456ab6a583..ed6f63016de1c2 100644 --- a/pkgs/by-name/fb/fbjni/package.nix +++ b/pkgs/by-name/fb/fbjni/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, fetchpatch -, jdk_headless -, gtest +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fetchpatch, + jdk_headless, + gtest, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fb/fblog/package.nix b/pkgs/by-name/fb/fblog/package.nix index 17e27488d0e6ca..b7210b0d33dc3f 100644 --- a/pkgs/by-name/fb/fblog/package.nix +++ b/pkgs/by-name/fb/fblog/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "fblog"; diff --git a/pkgs/by-name/fb/fbmark/package.nix b/pkgs/by-name/fb/fbmark/package.nix index fe8bca0e224095..69c1d2b4cc81ac 100644 --- a/pkgs/by-name/fb/fbmark/package.nix +++ b/pkgs/by-name/fb/fbmark/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "fbmark"; diff --git a/pkgs/by-name/fb/fbmenugen/package.nix b/pkgs/by-name/fb/fbmenugen/package.nix index 56a3ce5f28dd15..1b6d303f07dd71 100644 --- a/pkgs/by-name/fb/fbmenugen/package.nix +++ b/pkgs/by-name/fb/fbmenugen/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, fluxbox -, gnused -, makeWrapper -, perlPackages -, substituteAll -, xorg -, wrapGAppsHook3 -, gitUpdater +{ + lib, + fetchFromGitHub, + fluxbox, + gnused, + makeWrapper, + perlPackages, + substituteAll, + xorg, + wrapGAppsHook3, + gitUpdater, }: perlPackages.buildPerlPackage rec { diff --git a/pkgs/by-name/fb/fbpanel/package.nix b/pkgs/by-name/fb/fbpanel/package.nix index 69391589f8c5cd..eb9f16a0d87e60 100644 --- a/pkgs/by-name/fb/fbpanel/package.nix +++ b/pkgs/by-name/fb/fbpanel/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, libX11 -, libXmu -, libXpm -, gtk2 -, libpng -, libjpeg -, libtiff -, librsvg -, gdk-pixbuf -, gdk-pixbuf-xlib -, pypy2 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libX11, + libXmu, + libXpm, + gtk2, + libpng, + libjpeg, + libtiff, + librsvg, + gdk-pixbuf, + gdk-pixbuf-xlib, + pypy2, }: stdenv.mkDerivation rec { @@ -24,7 +25,10 @@ stdenv.mkDerivation rec { rev = "478754b687e2b48b111507ea22e8e2a001be5199"; hash = "sha256-+KcVcrh1aV6kjLGyiDnRHXSzJfelXWrhJS0DitG4yPA="; }; - nativeBuildInputs = [ pkg-config pypy2 ]; + nativeBuildInputs = [ + pkg-config + pypy2 + ]; buildInputs = [ libX11 libXmu @@ -44,8 +48,11 @@ stdenv.mkDerivation rec { sed -i 's/struct\ \_plugin_instance \*stam\;//' panel/plugin.h ''; - makeFlags = ["V=1"]; - NIX_CFLAGS_COMPILE = ["-Wno-error" "-I${gdk-pixbuf-xlib.dev}/include/gdk-pixbuf-2.0"]; + makeFlags = [ "V=1" ]; + NIX_CFLAGS_COMPILE = [ + "-Wno-error" + "-I${gdk-pixbuf-xlib.dev}/include/gdk-pixbuf-2.0" + ]; meta = with lib; { description = "Stand-alone panel"; diff --git a/pkgs/by-name/fb/fbset/package.nix b/pkgs/by-name/fb/fbset/package.nix index 7c05e4741d81a2..c081c56f3a3bd0 100644 --- a/pkgs/by-name/fb/fbset/package.nix +++ b/pkgs/by-name/fb/fbset/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, unstableGitUpdater -, bison -, flex +{ + lib, + stdenv, + fetchFromGitHub, + unstableGitUpdater, + bison, + flex, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/fb/fbterm/package.nix b/pkgs/by-name/fb/fbterm/package.nix index f472ce23aa2f7e..e8ce6e4243a611 100644 --- a/pkgs/by-name/fb/fbterm/package.nix +++ b/pkgs/by-name/fb/fbterm/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, autoreconfHook -, fetchFromGitLab -, fetchpatch -, fetchurl -, fontconfig -, freetype -, gpm -, lib -, ncurses -, pkg-config +{ + stdenv, + autoreconfHook, + fetchFromGitLab, + fetchpatch, + fetchurl, + fontconfig, + freetype, + gpm, + lib, + ncurses, + pkg-config, }: stdenv.mkDerivation rec { @@ -52,19 +53,19 @@ stdenv.mkDerivation rec { ''; postInstall = - let - fbtermrc = fetchurl { - url = "https://aur.archlinux.org/cgit/aur.git/plain/fbtermrc?h=fbterm"; - hash = "sha256-zNIfi2ZjEGc5PLdOIirKGTXESb5Wm5XBAI1sfHa31LY="; - }; - in - '' - mkdir -p "$out/share/terminfo" - tic -a -v2 -o"$out/share/terminfo" terminfo/fbterm + let + fbtermrc = fetchurl { + url = "https://aur.archlinux.org/cgit/aur.git/plain/fbtermrc?h=fbterm"; + hash = "sha256-zNIfi2ZjEGc5PLdOIirKGTXESb5Wm5XBAI1sfHa31LY="; + }; + in + '' + mkdir -p "$out/share/terminfo" + tic -a -v2 -o"$out/share/terminfo" terminfo/fbterm - mkdir -p "$out/etc/fbterm" - cp "${fbtermrc}" "$out/etc/fbterm" - ''; + mkdir -p "$out/etc/fbterm" + cp "${fbtermrc}" "$out/etc/fbterm" + ''; # Patches from https://aur.archlinux.org/cgit/aur.git/tree/PKGBUILD?h=fbterm patches = [ @@ -98,7 +99,10 @@ stdenv.mkDerivation rec { description = "Framebuffer terminal emulator"; mainProgram = "fbterm"; homepage = "https://salsa.debian.org/debian/fbterm"; - maintainers = with maintainers; [ lovesegfault raskin ]; + maintainers = with maintainers; [ + lovesegfault + raskin + ]; license = licenses.gpl2Plus; platforms = platforms.linux; }; diff --git a/pkgs/by-name/fb/fbv/package.nix b/pkgs/by-name/fb/fbv/package.nix index 659a661fded8a3..16b813a2c1de55 100644 --- a/pkgs/by-name/fb/fbv/package.nix +++ b/pkgs/by-name/fb/fbv/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, fetchpatch, getopt, libjpeg, libpng12, giflib }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + getopt, + libjpeg, + libpng12, + giflib, +}: stdenv.mkDerivation rec { pname = "fbv"; @@ -18,7 +27,12 @@ stdenv.mkDerivation rec { patchFlags = [ "-p0" ]; - buildInputs = [ getopt libjpeg libpng12 giflib ]; + buildInputs = [ + getopt + libjpeg + libpng12 + giflib + ]; makeFlags = [ "LDFLAGS=-lgif" ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/fb/fbvnc/package.nix b/pkgs/by-name/fb/fbvnc/package.nix index 0157f391d66bb5..74934166b9d93c 100644 --- a/pkgs/by-name/fb/fbvnc/package.nix +++ b/pkgs/by-name/fb/fbvnc/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fc/fcast-receiver/package.nix b/pkgs/by-name/fc/fcast-receiver/package.nix index 9aa649d34f8ca1..ae1a093fe21435 100644 --- a/pkgs/by-name/fc/fcast-receiver/package.nix +++ b/pkgs/by-name/fc/fcast-receiver/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildNpmPackage -, fetchFromGitLab -, makeDesktopItem -, copyDesktopItems -, makeWrapper -, electron +{ + lib, + buildNpmPackage, + fetchFromGitLab, + makeDesktopItem, + copyDesktopItems, + makeWrapper, + electron, }: buildNpmPackage rec { diff --git a/pkgs/by-name/fc/fcft/package.nix b/pkgs/by-name/fc/fcft/package.nix index 2a36329b386fa8..5809b417aa226f 100644 --- a/pkgs/by-name/fc/fcft/package.nix +++ b/pkgs/by-name/fc/fcft/package.nix @@ -1,10 +1,27 @@ -{ stdenv, lib, fetchFromGitea, fetchpatch, pkg-config, meson, ninja, scdoc -, freetype, fontconfig, nanosvg, pixman, tllist, check -# Text shaping methods to enable, empty list disables all text shaping. -# See `availableShapingTypes` or upstream meson_options.txt for available types. -, withShapingTypes ? [ "grapheme" "run" ] -, harfbuzz, utf8proc -, fcft # for passthru.tests +{ + stdenv, + lib, + fetchFromGitea, + fetchpatch, + pkg-config, + meson, + ninja, + scdoc, + freetype, + fontconfig, + nanosvg, + pixman, + tllist, + check, + # Text shaping methods to enable, empty list disables all text shaping. + # See `availableShapingTypes` or upstream meson_options.txt for available types. + withShapingTypes ? [ + "grapheme" + "run" + ], + harfbuzz, + utf8proc, + fcft, # for passthru.tests }: let @@ -28,25 +45,43 @@ stdenv.mkDerivation rec { }; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ pkg-config meson ninja scdoc ]; - buildInputs = [ freetype fontconfig nanosvg pixman tllist ] - ++ lib.optionals (withShapingTypes != []) [ harfbuzz ] + nativeBuildInputs = [ + pkg-config + meson + ninja + scdoc + ]; + buildInputs = + [ + freetype + fontconfig + nanosvg + pixman + tllist + ] + ++ lib.optionals (withShapingTypes != [ ]) [ harfbuzz ] ++ lib.optionals (builtins.elem "run" withShapingTypes) [ utf8proc ]; nativeCheckInputs = [ check ]; mesonBuildType = "release"; - mesonFlags = [ - (lib.mesonEnable "system-nanosvg" true) - ] ++ builtins.map (t: - lib.mesonEnable "${t}-shaping" (lib.elem t withShapingTypes) - ) availableShapingTypes; + mesonFlags = + [ + (lib.mesonEnable "system-nanosvg" true) + ] + ++ builtins.map ( + t: lib.mesonEnable "${t}-shaping" (lib.elem t withShapingTypes) + ) availableShapingTypes; doCheck = true; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; passthru.tests = { - noShaping = fcft.override { withShapingTypes = []; }; + noShaping = fcft.override { withShapingTypes = [ ]; }; onlyGraphemeShaping = fcft.override { withShapingTypes = [ "grapheme" ]; }; }; @@ -58,7 +93,10 @@ stdenv.mkDerivation rec { fionera sternenseemann ]; - license = with licenses; [ mit zlib ]; + license = with licenses; [ + mit + zlib + ]; platforms = with platforms; linux; }; } diff --git a/pkgs/by-name/fc/fcgi/package.nix b/pkgs/by-name/fc/fcgi/package.nix index 62c463b2d2f544..95ab22961ce474 100644 --- a/pkgs/by-name/fc/fcgi/package.nix +++ b/pkgs/by-name/fc/fcgi/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation (finalAttrs: { pname = "fcgi"; diff --git a/pkgs/by-name/fc/fcgiwrap/package.nix b/pkgs/by-name/fc/fcgiwrap/package.nix index 4271ed91ecd074..a40a60ca472352 100644 --- a/pkgs/by-name/fc/fcgiwrap/package.nix +++ b/pkgs/by-name/fc/fcgiwrap/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, systemd, fcgi, autoreconfHook, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + systemd, + fcgi, + autoreconfHook, + pkg-config, +}: stdenv.mkDerivation rec { pname = "fcgiwrap"; @@ -12,10 +20,19 @@ stdenv.mkDerivation rec { }; env.NIX_CFLAGS_COMPILE = "-Wno-error=implicit-fallthrough"; - configureFlags = [ "--with-systemd" "--with-systemdsystemunitdir=$(out)/etc/systemd/system" ]; + configureFlags = [ + "--with-systemd" + "--with-systemdsystemunitdir=$(out)/etc/systemd/system" + ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ systemd fcgi ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + systemd + fcgi + ]; # systemd 230 no longer has libsystemd-daemon as a separate entity from libsystemd postPatch = '' diff --git a/pkgs/by-name/fc/fcitx5-material-color/package.nix b/pkgs/by-name/fc/fcitx5-material-color/package.nix index 0385c33e7045d0..8b5147df9b828c 100644 --- a/pkgs/by-name/fc/fcitx5-material-color/package.nix +++ b/pkgs/by-name/fc/fcitx5-material-color/package.nix @@ -1,6 +1,7 @@ -{ stdenvNoCC -, fetchFromGitHub -, lib +{ + stdenvNoCC, + fetchFromGitHub, + lib, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -35,7 +36,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { description = "Fcitx5 themes based on Material color"; homepage = "https://github.com/hosxy/Fcitx5-Material-Color"; license = licenses.asl20; - maintainers = with maintainers; [ Cryolitia h7x4 ]; + maintainers = with maintainers; [ + Cryolitia + h7x4 + ]; platforms = platforms.all; }; }) diff --git a/pkgs/by-name/fc/fcitx5-nord/package.nix b/pkgs/by-name/fc/fcitx5-nord/package.nix index 6ab7fc15f0a20d..cec74a607153c5 100644 --- a/pkgs/by-name/fc/fcitx5-nord/package.nix +++ b/pkgs/by-name/fc/fcitx5-nord/package.nix @@ -1,6 +1,7 @@ -{ stdenvNoCC -, fetchFromGitHub -, lib +{ + stdenvNoCC, + fetchFromGitHub, + lib, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/fc/fcitx5-pinyin-minecraft/package.nix b/pkgs/by-name/fc/fcitx5-pinyin-minecraft/package.nix index dba53dbe887fc5..3abca1915695c8 100644 --- a/pkgs/by-name/fc/fcitx5-pinyin-minecraft/package.nix +++ b/pkgs/by-name/fc/fcitx5-pinyin-minecraft/package.nix @@ -28,7 +28,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { meta = { description = "Fcitx 5 pinyin dictionary from zh.minecraft.wiki"; homepage = "https://github.com/oldherl/fcitx5-pinyin-minecraft"; - license = with lib.licenses; [ unlicense cc-by-nc-sa-30 ]; + license = with lib.licenses; [ + unlicense + cc-by-nc-sa-30 + ]; maintainers = with lib.maintainers; [ Guanran928 ]; platforms = lib.platforms.all; }; diff --git a/pkgs/by-name/fc/fcitx5-pinyin-moegirl/package.nix b/pkgs/by-name/fc/fcitx5-pinyin-moegirl/package.nix index fe6b89e33dc106..0371e22fe9427b 100644 --- a/pkgs/by-name/fc/fcitx5-pinyin-moegirl/package.nix +++ b/pkgs/by-name/fc/fcitx5-pinyin-moegirl/package.nix @@ -28,7 +28,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { meta = { description = "Fcitx 5 pinyin dictionary from zh.moegirl.org.cn"; homepage = "https://github.com/outloudvi/mw2fcitx"; - license = with lib.licenses; [ unlicense cc-by-nc-sa-30 ]; + license = with lib.licenses; [ + unlicense + cc-by-nc-sa-30 + ]; maintainers = with lib.maintainers; [ Guanran928 ]; platforms = lib.platforms.all; }; diff --git a/pkgs/by-name/fc/fcitx5-pinyin-zhwiki/package.nix b/pkgs/by-name/fc/fcitx5-pinyin-zhwiki/package.nix index 347d70e480f598..7c82ebddaa9dd7 100644 --- a/pkgs/by-name/fc/fcitx5-pinyin-zhwiki/package.nix +++ b/pkgs/by-name/fc/fcitx5-pinyin-zhwiki/package.nix @@ -26,7 +26,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { meta = { description = "Fcitx 5 pinyin dictionary from zh.wikipedia.org"; homepage = "https://github.com/felixonmars/fcitx5-pinyin-zhwiki"; - license = with lib.licenses; [ unlicense cc-by-sa-40 ]; + license = with lib.licenses; [ + unlicense + cc-by-sa-40 + ]; maintainers = with lib.maintainers; [ Guanran928 ]; platforms = lib.platforms.all; }; diff --git a/pkgs/by-name/fc/fcitx5-rose-pine/package.nix b/pkgs/by-name/fc/fcitx5-rose-pine/package.nix index b1f11a1784a98d..eede613baa7ba5 100644 --- a/pkgs/by-name/fc/fcitx5-rose-pine/package.nix +++ b/pkgs/by-name/fc/fcitx5-rose-pine/package.nix @@ -1,6 +1,7 @@ -{ stdenvNoCC -, fetchFromGitHub -, lib +{ + stdenvNoCC, + fetchFromGitHub, + lib, }: stdenvNoCC.mkDerivation { @@ -23,7 +24,6 @@ stdenvNoCC.mkDerivation { runHook postInstall ''; - meta = { description = "Fcitx5 themes based on Rosé Pine"; homepage = "https://github.com/rose-pine/fcitx5"; diff --git a/pkgs/by-name/fc/fcl/package.nix b/pkgs/by-name/fc/fcl/package.nix index 0c6790db9f7025..6568e355dd2613 100644 --- a/pkgs/by-name/fc/fcl/package.nix +++ b/pkgs/by-name/fc/fcl/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, eigen, libccd, octomap }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + eigen, + libccd, + octomap, +}: stdenv.mkDerivation rec { pname = "fcl"; @@ -12,9 +20,16 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - propagatedBuildInputs = [ eigen libccd octomap ]; + propagatedBuildInputs = [ + eigen + libccd + octomap + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = with lib; { description = "Flexible Collision Library"; diff --git a/pkgs/by-name/fc/fcppt/package.nix b/pkgs/by-name/fc/fcppt/package.nix index 1a82a9289a6162..ac0fd75829009e 100644 --- a/pkgs/by-name/fc/fcppt/package.nix +++ b/pkgs/by-name/fc/fcppt/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, boost, catch2 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + catch2, +}: stdenv.mkDerivation rec { pname = "fcppt"; version = "4.2.1"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ boost catch2 ]; + buildInputs = [ + boost + catch2 + ]; cmakeFlags = [ "-DENABLE_BOOST=true" @@ -32,6 +42,9 @@ stdenv.mkDerivation rec { homepage = "https://fcppt.org"; license = licenses.boost; maintainers = with maintainers; [ pmiddend ]; - platforms = [ "x86_64-linux" "x86_64-windows" ]; + platforms = [ + "x86_64-linux" + "x86_64-windows" + ]; }; } diff --git a/pkgs/by-name/fc/fcrackzip/package.nix b/pkgs/by-name/fc/fcrackzip/package.nix index 6a60878c88d768..6c495702ba8df2 100644 --- a/pkgs/by-name/fc/fcrackzip/package.nix +++ b/pkgs/by-name/fc/fcrackzip/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "fcrackzip"; @@ -25,4 +29,3 @@ stdenv.mkDerivation rec { platforms = with platforms; unix; }; } - diff --git a/pkgs/by-name/fc/fcron/package.nix b/pkgs/by-name/fc/fcron/package.nix index c9ffa027445758..40d47f912bd356 100644 --- a/pkgs/by-name/fc/fcron/package.nix +++ b/pkgs/by-name/fc/fcron/package.nix @@ -1,7 +1,14 @@ # restart using 'killall -TERM fcron; fcron -b # use convert-fcrontab to update fcrontab files -{ lib, stdenv, fetchurl, perl, busybox, vim }: +{ + lib, + stdenv, + fetchurl, + perl, + busybox, + vim, +}: stdenv.mkDerivation rec { pname = "fcron"; @@ -16,16 +23,16 @@ stdenv.mkDerivation rec { patches = [ ./relative-fcronsighup.patch ]; - configureFlags = - [ "--with-sendmail=${busybox}/sbin/sendmail" - "--with-editor=${vim}/bin/vi" # TODO customizable - "--with-bootinstall=no" - "--localstatedir=/var" - "--sysconfdir=/etc" - "--with-rootname=root" - "--with-rootgroup=root" - "--disable-checks" - ]; + configureFlags = [ + "--with-sendmail=${busybox}/sbin/sendmail" + "--with-editor=${vim}/bin/vi" # TODO customizable + "--with-bootinstall=no" + "--localstatedir=/var" + "--sysconfdir=/etc" + "--with-rootname=root" + "--with-rootgroup=root" + "--disable-checks" + ]; installTargets = [ "install-staged" ]; # install does also try to change permissions of /etc/* files @@ -53,7 +60,7 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description="Command scheduler with extended capabilities over cron and anacron"; + description = "Command scheduler with extended capabilities over cron and anacron"; homepage = "http://fcron.free.fr"; license = licenses.gpl2Plus; platforms = lib.platforms.all; diff --git a/pkgs/by-name/fd/fd/package.nix b/pkgs/by-name/fd/fd/package.nix index 4e2529ee44afe8..9984e327439211 100644 --- a/pkgs/by-name/fd/fd/package.nix +++ b/pkgs/by-name/fd/fd/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, rustPlatform, fetchFromGitHub, installShellFiles, rust-jemalloc-sys, testers, fd }: +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + rust-jemalloc-sys, + testers, + fd, +}: rustPlatform.buildRustPackage rec { pname = "fd"; @@ -25,14 +34,16 @@ rustPlatform.buildRustPackage rec { "--skip=test_invalid_utf8" ]; - postInstall = '' - installManPage doc/fd.1 - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - installShellCompletion --cmd fd \ - --bash <($out/bin/fd --gen-completions bash) \ - --fish <($out/bin/fd --gen-completions fish) - installShellCompletion --zsh contrib/completion/_fd - ''; + postInstall = + '' + installManPage doc/fd.1 + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + installShellCompletion --cmd fd \ + --bash <($out/bin/fd --gen-completions bash) \ + --fish <($out/bin/fd --gen-completions fish) + installShellCompletion --zsh contrib/completion/_fd + ''; passthru.tests.version = testers.testVersion { package = fd; @@ -48,8 +59,17 @@ rustPlatform.buildRustPackage rec { ''; homepage = "https://github.com/sharkdp/fd"; changelog = "https://github.com/sharkdp/fd/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ dywedir figsoda globin ma27 zowoq ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + dywedir + figsoda + globin + ma27 + zowoq + ]; mainProgram = "fd"; }; } diff --git a/pkgs/by-name/fd/fdk-aac-encoder/package.nix b/pkgs/by-name/fd/fdk-aac-encoder/package.nix index fffa6faf1006dd..3d8735b4adc5be 100644 --- a/pkgs/by-name/fd/fdk-aac-encoder/package.nix +++ b/pkgs/by-name/fd/fdk-aac-encoder/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, autoreconfHook, fetchFromGitHub, pkg-config, fdk_aac }: +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + pkg-config, + fdk_aac, +}: stdenv.mkDerivation rec { pname = "fdkaac"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-nVVeYk7t4+n/BsOKs744stsvgJd+zNnbASk3bAgFTpk="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ fdk_aac ]; diff --git a/pkgs/by-name/fd/fdk_aac/package.nix b/pkgs/by-name/fd/fdk_aac/package.nix index 8f8611ccf6a111..e3e310363aedd4 100644 --- a/pkgs/by-name/fd/fdk_aac/package.nix +++ b/pkgs/by-name/fd/fdk_aac/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, exampleSupport ? false # Example encoding program +{ + lib, + stdenv, + fetchurl, + exampleSupport ? false, # Example encoding program }: stdenv.mkDerivation rec { @@ -13,7 +14,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-gptrie7zgkCc2mhX/YKvhPq7Y0F7CO3p6npVP4Ect54="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/fd/fdm/package.nix b/pkgs/by-name/fd/fdm/package.nix index f0d65a03d89511..6d5737c85bc6bd 100644 --- a/pkgs/by-name/fd/fdm/package.nix +++ b/pkgs/by-name/fd/fdm/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, openssl, tdb, zlib, flex, bison }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + openssl, + tdb, + zlib, + flex, + bison, +}: stdenv.mkDerivation rec { pname = "fdm"; @@ -12,7 +22,13 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ openssl tdb zlib flex bison ]; + buildInputs = [ + openssl + tdb + zlib + flex + bison + ]; postInstall = '' install fdm-sanitize $out/bin diff --git a/pkgs/by-name/fd/fdtools/package.nix b/pkgs/by-name/fd/fdtools/package.nix index 6f0d205203df8a..e7cfff46f620c3 100644 --- a/pkgs/by-name/fd/fdtools/package.nix +++ b/pkgs/by-name/fd/fdtools/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchurl, skawarePackages }: +{ + stdenv, + lib, + fetchurl, + skawarePackages, +}: let pname = "fdtools"; @@ -7,7 +12,8 @@ let sha256 = "0lnafcp4yipi0dl8gh33zjs8wlpz0mim8mwmiz9s49id0b0fmlla"; skalibs = skawarePackages.skalibs_2_10; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname version; src = fetchurl { @@ -16,7 +22,13 @@ in stdenv.mkDerivation { }; patches = [ ./new-skalibs.patch ]; - outputs = [ "bin" "lib" "dev" "doc" "out" ]; + outputs = [ + "bin" + "lib" + "dev" + "doc" + "out" + ]; buildInputs = [ # temporary, until fdtools catches up to skalibs @@ -56,20 +68,22 @@ in stdenv.mkDerivation { mv library/fdtools.a $lib/lib/fdtools.a mv include/fdtools.h $dev/include/fdtools.h - ${skawarePackages.cleanPackaging.commonFileActions { - noiseFiles = [ - "conf-compile/**/*" - "src/**/*" - "src/.**/*" - "compile/**/*" - "package/{build,check,compile,elsewhere,install,install_commands,own,run,sharing,upgrade,upgrade_version,url_src,url_src_latest,versions}" - ]; - docFiles = [ - "package/INSTALL" - "package/LICENSE" - "package/README" - ]; - }} $docdir + ${ + skawarePackages.cleanPackaging.commonFileActions { + noiseFiles = [ + "conf-compile/**/*" + "src/**/*" + "src/.**/*" + "compile/**/*" + "package/{build,check,compile,elsewhere,install,install_commands,own,run,sharing,upgrade,upgrade_version,url_src,url_src_latest,versions}" + ]; + docFiles = [ + "package/INSTALL" + "package/LICENSE" + "package/README" + ]; + } + } $docdir ${skawarePackages.cleanPackaging.checkForRemainingFiles} diff --git a/pkgs/by-name/fd/fdupes/package.nix b/pkgs/by-name/fd/fdupes/package.nix index 834f35aa530af9..c0052c2889d883 100644 --- a/pkgs/by-name/fd/fdupes/package.nix +++ b/pkgs/by-name/fd/fdupes/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, ncurses -, pcre2 -, sqlite +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + ncurses, + pcre2, + sqlite, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fe/fead/package.nix b/pkgs/by-name/fe/fead/package.nix index d18ff21801d77e..254638e9125d83 100644 --- a/pkgs/by-name/fe/fead/package.nix +++ b/pkgs/by-name/fe/fead/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchzip, python3, help2man }: +{ + lib, + stdenv, + fetchzip, + python3, + help2man, +}: stdenv.mkDerivation rec { pname = "fead"; diff --git a/pkgs/by-name/fe/feather/package.nix b/pkgs/by-name/fe/feather/package.nix index ea4c5cfb74c5ab..ae567d8ffa1841 100644 --- a/pkgs/by-name/fe/feather/package.nix +++ b/pkgs/by-name/fe/feather/package.nix @@ -1,23 +1,24 @@ -{ bc-ur -, boost -, cmake -, fetchFromGitHub -, hidapi -, lib -, libsodium -, libusb1 -, openssl -, pkg-config -, protobuf -, python3 -, qrencode -, qt6 -, readline -, stdenv -, testers -, tor -, unbound -, zxing-cpp +{ + bc-ur, + boost, + cmake, + fetchFromGitHub, + hidapi, + lib, + libsodium, + libusb1, + openssl, + pkg-config, + protobuf, + python3, + qrencode, + qt6, + readline, + stdenv, + testers, + tor, + unbound, + zxing-cpp, }: stdenv.mkDerivation (finalAttrs: { @@ -39,25 +40,27 @@ stdenv.mkDerivation (finalAttrs: { qt6.wrapQtAppsHook ]; - buildInputs = [ - bc-ur - boost - hidapi - libsodium - libusb1 - openssl - protobuf - qrencode - unbound - zxing-cpp - ] ++ (with qt6; [ - qtbase - qtmultimedia - qtsvg - qttools - qtwayland - qtwebsockets - ]); + buildInputs = + [ + bc-ur + boost + hidapi + libsodium + libusb1 + openssl + protobuf + qrencode + unbound + zxing-cpp + ] + ++ (with qt6; [ + qtbase + qtmultimedia + qtsvg + qttools + qtwayland + qtwebsockets + ]); cmakeFlags = [ "-DProtobuf_INCLUDE_DIR=${lib.getDev protobuf}/include" diff --git a/pkgs/by-name/fe/fedifetcher/package.nix b/pkgs/by-name/fe/fedifetcher/package.nix index 9ef45d07a39f34..297e4ffa9a4450 100644 --- a/pkgs/by-name/fe/fedifetcher/package.nix +++ b/pkgs/by-name/fe/fedifetcher/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, python3, stdenv }: +{ + lib, + fetchFromGitHub, + python3, + stdenv, +}: python3.pkgs.buildPythonApplication rec { pname = "fedifetcher"; diff --git a/pkgs/by-name/fe/fedimint/package.nix b/pkgs/by-name/fe/fedimint/package.nix index 246375fff66aaa..0260bb78d289d5 100644 --- a/pkgs/by-name/fe/fedimint/package.nix +++ b/pkgs/by-name/fe/fedimint/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildPackages -, fetchFromGitHub -, openssl -, pkg-config -, protobuf -, rustPlatform +{ + lib, + buildPackages, + fetchFromGitHub, + openssl, + pkg-config, + protobuf, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -30,7 +31,14 @@ rustPlatform.buildRustPackage rec { openssl ]; - outputs = [ "out" "fedimintCli" "fedimint" "gateway" "gatewayCli" "devimint" ]; + outputs = [ + "out" + "fedimintCli" + "fedimint" + "gateway" + "gatewayCli" + "devimint" + ]; postInstall = '' mkdir -p $fedimint/bin $fedimintCli/bin $gateway/bin $gatewayCli/bin $devimint/bin diff --git a/pkgs/by-name/fe/feed2imap-go/package.nix b/pkgs/by-name/fe/feed2imap-go/package.nix index d34eecd9e2d308..f2696e33799bd6 100644 --- a/pkgs/by-name/fe/feed2imap-go/package.nix +++ b/pkgs/by-name/fe/feed2imap-go/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "feed2imap-go"; @@ -12,7 +16,8 @@ buildGoModule rec { }; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/Necoro/feed2imap-go/pkg/version.version=${version}" "-X github.com/Necoro/feed2imap-go/pkg/version.commit=nixpkgs" ]; diff --git a/pkgs/by-name/fe/feedbackd/package.nix b/pkgs/by-name/fe/feedbackd/package.nix index 256892aa0c9942..5c0ab1d284985b 100644 --- a/pkgs/by-name/fe/feedbackd/package.nix +++ b/pkgs/by-name/fe/feedbackd/package.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchFromGitLab -, docbook-xsl-nons -, docutils -, gi-docgen -, gobject-introspection -, gtk-doc -, libxslt -, meson -, ninja -, pkg-config -, vala -, wrapGAppsHook3 -, glib -, gsound -, json-glib -, libgudev -, dbus -, gmobile -, umockdev +{ + lib, + stdenv, + fetchFromGitLab, + docbook-xsl-nons, + docutils, + gi-docgen, + gobject-introspection, + gtk-doc, + libxslt, + meson, + ninja, + pkg-config, + vala, + wrapGAppsHook3, + glib, + gsound, + json-glib, + libgudev, + dbus, + gmobile, + umockdev, }: let @@ -34,7 +35,11 @@ stdenv.mkDerivation (finalAttrs: { pname = "feedbackd"; version = "0.4.1"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitLab { domain = "source.puri.sm"; diff --git a/pkgs/by-name/fe/feedgnuplot/package.nix b/pkgs/by-name/fe/feedgnuplot/package.nix index 423d8d8d92f3ee..9d1590ba947b2d 100644 --- a/pkgs/by-name/fe/feedgnuplot/package.nix +++ b/pkgs/by-name/fe/feedgnuplot/package.nix @@ -1,14 +1,15 @@ -{ lib -, fetchFromGitHub -, makeWrapper -, makeFontsConf -, freefont_ttf -, gnuplot -, perl -, perlPackages -, stdenv -, shortenPerlShebang -, installShellFiles +{ + lib, + fetchFromGitHub, + makeWrapper, + makeFontsConf, + freefont_ttf, + gnuplot, + perl, + perlPackages, + stdenv, + shortenPerlShebang, + installShellFiles, }: let @@ -30,10 +31,21 @@ perlPackages.buildPerlPackage rec { outputs = [ "out" ]; - nativeBuildInputs = [ makeWrapper installShellFiles ] ++ lib.optional stdenv.hostPlatform.isDarwin shortenPerlShebang; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ] ++ lib.optional stdenv.hostPlatform.isDarwin shortenPerlShebang; - buildInputs = [ gnuplot perl ] - ++ (with perlPackages; [ ListMoreUtils IPCRun StringShellQuote ]); + buildInputs = + [ + gnuplot + perl + ] + ++ (with perlPackages; [ + ListMoreUtils + IPCRun + StringShellQuote + ]); # Fontconfig error: Cannot load default config file FONTCONFIG_FILE = fontsConf; @@ -45,21 +57,26 @@ perlPackages.buildPerlPackage rec { # Tests require gnuplot 4.6.4 and are completely skipped with gnuplot 5. doCheck = false; - postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' - shortenPerlShebang $out/bin/feedgnuplot - '' + '' - wrapProgram $out/bin/feedgnuplot \ - --prefix "PATH" ":" "$PATH" \ - --prefix "PERL5LIB" ":" "$PERL5LIB" + postInstall = + lib.optionalString stdenv.hostPlatform.isDarwin '' + shortenPerlShebang $out/bin/feedgnuplot + '' + + '' + wrapProgram $out/bin/feedgnuplot \ + --prefix "PATH" ":" "$PATH" \ + --prefix "PERL5LIB" ":" "$PERL5LIB" - installShellCompletion --bash --name feedgnuplot.bash completions/bash/feedgnuplot - installShellCompletion --zsh completions/zsh/_feedgnuplot - ''; + installShellCompletion --bash --name feedgnuplot.bash completions/bash/feedgnuplot + installShellCompletion --zsh completions/zsh/_feedgnuplot + ''; meta = with lib; { description = "General purpose pipe-oriented plotting tool"; homepage = "https://github.com/dkogan/feedgnuplot/"; - license = with licenses; [ artistic1 gpl1Plus ]; + license = with licenses; [ + artistic1 + gpl1Plus + ]; platforms = platforms.unix; maintainers = with maintainers; [ mnacamura ]; mainProgram = "feedgnuplot"; diff --git a/pkgs/by-name/fe/fehlstart/package.nix b/pkgs/by-name/fe/fehlstart/package.nix index 4d3903bbb6ec45..7c289e51688e09 100644 --- a/pkgs/by-name/fe/fehlstart/package.nix +++ b/pkgs/by-name/fe/fehlstart/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, pkg-config, gtk2, keybinder, fetchFromGitLab }: +{ + lib, + stdenv, + pkg-config, + gtk2, + keybinder, + fetchFromGitLab, +}: stdenv.mkDerivation { pname = "fehlstart"; @@ -13,7 +20,10 @@ stdenv.mkDerivation { patches = [ ./use-nix-profiles.patch ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk2 keybinder ]; + buildInputs = [ + gtk2 + keybinder + ]; preConfigure = '' export PREFIX=$out diff --git a/pkgs/by-name/fe/feishu/package.nix b/pkgs/by-name/fe/feishu/package.nix index 8a0dc4256a031b..7281893b41e9fa 100644 --- a/pkgs/by-name/fe/feishu/package.nix +++ b/pkgs/by-name/fe/feishu/package.nix @@ -1,65 +1,66 @@ -{ addDriverRunpath -, alsa-lib -, at-spi2-atk -, at-spi2-core -, atk -, autoPatchelfHook -, cairo -, cups -, curl -, dbus -, dpkg -, expat -, fetchurl -, fontconfig -, freetype -, gdk-pixbuf -, glib -, glibc -, gnutls -, gtk3 -, lib -, libGL -, libX11 -, libXScrnSaver -, libXcomposite -, libXcursor -, libXdamage -, libXext -, libXfixes -, libXi -, libXrandr -, libXrender -, libXtst -, libappindicator-gtk3 -, libcxx -, libdbusmenu -, libdrm -, libgcrypt -, libglvnd -, libnotify -, libpulseaudio -, libuuid -, libxcb -, libxkbcommon -, libxkbfile -, libxshmfence -, makeShellWrapper -, mesa -, nspr -, nss -, pango -, pciutils -, pipewire -, pixman -, stdenv -, systemd -, wayland -, xdg-utils -, writeScript +{ + addDriverRunpath, + alsa-lib, + at-spi2-atk, + at-spi2-core, + atk, + autoPatchelfHook, + cairo, + cups, + curl, + dbus, + dpkg, + expat, + fetchurl, + fontconfig, + freetype, + gdk-pixbuf, + glib, + glibc, + gnutls, + gtk3, + lib, + libGL, + libX11, + libXScrnSaver, + libXcomposite, + libXcursor, + libXdamage, + libXext, + libXfixes, + libXi, + libXrandr, + libXrender, + libXtst, + libappindicator-gtk3, + libcxx, + libdbusmenu, + libdrm, + libgcrypt, + libglvnd, + libnotify, + libpulseaudio, + libuuid, + libxcb, + libxkbcommon, + libxkbfile, + libxshmfence, + makeShellWrapper, + mesa, + nspr, + nss, + pango, + pciutils, + pipewire, + pixman, + stdenv, + systemd, + wayland, + xdg-utils, + writeScript, # for custom command line arguments, e.g. "--use-gl=desktop" -, commandLineArgs ? "" + commandLineArgs ? "", }: let @@ -74,7 +75,10 @@ let }; }; - supportedPlatforms = [ "x86_64-linux" "aarch64-linux" ]; + supportedPlatforms = [ + "x86_64-linux" + "aarch64-linux" + ]; rpath = lib.makeLibraryPath [ alsa-lib @@ -134,7 +138,9 @@ stdenv.mkDerivation { version = "7.22.9"; pname = "feishu"; - src = sources.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + sources.${stdenv.hostPlatform.system} + or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); nativeBuildInputs = [ autoPatchelfHook @@ -179,7 +185,9 @@ stdenv.mkDerivation { wrapProgram $executable \ --prefix XDG_DATA_DIRS : "$XDG_ICON_DIRS:$GSETTINGS_SCHEMAS_PATH" \ --prefix LD_LIBRARY_PATH : ${rpath}:$out/opt/bytedance/feishu:${addDriverRunpath.driverLink}/share \ - ${lib.optionalString (commandLineArgs!="") "--add-flags ${lib.escapeShellArg commandLineArgs}"} + ${lib.optionalString ( + commandLineArgs != "" + ) "--add-flags ${lib.escapeShellArg commandLineArgs}"} done mkdir -p $out/share/icons/hicolor diff --git a/pkgs/by-name/fe/femtolisp/package.nix b/pkgs/by-name/fe/femtolisp/package.nix index 3e35f7edc65700..a565921eeb9585 100644 --- a/pkgs/by-name/fe/femtolisp/package.nix +++ b/pkgs/by-name/fe/femtolisp/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromSourcehut -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromSourcehut, + unstableGitUpdater, }: stdenv.mkDerivation { @@ -32,7 +33,10 @@ stdenv.mkDerivation { meta = { description = "Compact interpreter for a minimal lisp/scheme dialect"; homepage = "https://git.sr.ht/~ft/femtolisp"; - license = with lib.licenses; [ mit bsd3 ]; + license = with lib.licenses; [ + mit + bsd3 + ]; maintainers = with lib.maintainers; [ moody ]; broken = stdenv.hostPlatform.isDarwin; platforms = lib.platforms.unix; diff --git a/pkgs/by-name/fe/ferm/package.nix b/pkgs/by-name/fe/ferm/package.nix index e14b3f8572b839..1d7da4ea13ca52 100644 --- a/pkgs/by-name/fe/ferm/package.nix +++ b/pkgs/by-name/fe/ferm/package.nix @@ -1,8 +1,17 @@ -{ lib, stdenv, fetchurl, makeWrapper, perl, iptables, nixosTests }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + perl, + iptables, + nixosTests, +}: let inherit (lib.versions) majorMinor; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { version = "2.7"; pname = "ferm"; @@ -16,7 +25,10 @@ in stdenv.mkDerivation rec { ]; # perl is used at build time to gather the ferm version. - nativeBuildInputs = [ makeWrapper perl ]; + nativeBuildInputs = [ + makeWrapper + perl + ]; buildInputs = [ perl ]; makeFlags = [ @@ -44,7 +56,7 @@ in stdenv.mkDerivation rec { language, which can contain levels and lists. ''; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [mic92]; + maintainers = with lib.maintainers; [ mic92 ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/fe/fermyon-spin/package.nix b/pkgs/by-name/fe/fermyon-spin/package.nix index 7f447db6babcb5..396f348e213317 100644 --- a/pkgs/by-name/fe/fermyon-spin/package.nix +++ b/pkgs/by-name/fe/fermyon-spin/package.nix @@ -1,31 +1,37 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, gcc-unwrapped -, zlib +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + gcc-unwrapped, + zlib, }: let system = stdenv.hostPlatform.system; - platform = { - x86_64-linux = "linux-amd64"; - aarch64-linux = "linux-aarch64"; - x86_64-darwin = "macos-amd64"; - aarch64-darwin = "macos-aarch64"; - }.${system} or (throw "Unsupported system: ${system}"); + platform = + { + x86_64-linux = "linux-amd64"; + aarch64-linux = "linux-aarch64"; + x86_64-darwin = "macos-amd64"; + aarch64-darwin = "macos-aarch64"; + } + .${system} or (throw "Unsupported system: ${system}"); # TODO: It'd be nice to write an update script that would update all of these # hashes together. - packageHash = { - x86_64-linux = "sha256-r/F3Tj3WeeL2R27ussX+ebFWpW+8z2e7tdBK4MHFMpk="; - aarch64-linux = "sha256-BSFxDJeY7fOOxDqAV+6FJf0hup1Y5IJ/czqwc4W7qSA="; - x86_64-darwin = "sha256-T6J9IjfXdt9DnZksndAmZRkYyH/5H60J7V6xU0ltD2A="; - aarch64-darwin = "sha256-6x+0PB5/2oqYDVNiNhc0xcs/ESCLvvSsWtm2KlTIeBo="; - }.${system} or (throw "Unsupported system: ${system}"); + packageHash = + { + x86_64-linux = "sha256-r/F3Tj3WeeL2R27ussX+ebFWpW+8z2e7tdBK4MHFMpk="; + aarch64-linux = "sha256-BSFxDJeY7fOOxDqAV+6FJf0hup1Y5IJ/czqwc4W7qSA="; + x86_64-darwin = "sha256-T6J9IjfXdt9DnZksndAmZRkYyH/5H60J7V6xU0ltD2A="; + aarch64-darwin = "sha256-6x+0PB5/2oqYDVNiNhc0xcs/ESCLvvSsWtm2KlTIeBo="; + } + .${system} or (throw "Unsupported system: ${system}"); -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "fermyon-spin"; version = "3.0.0"; diff --git a/pkgs/by-name/fe/fernglas/package.nix b/pkgs/by-name/fe/fernglas/package.nix index de0c7706af6f73..62854f49e2d23e 100644 --- a/pkgs/by-name/fe/fernglas/package.nix +++ b/pkgs/by-name/fe/fernglas/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, fetchYarnDeps -, fixup-yarn-lock -, python3 -, jq -, yarn -, nodejs-slim +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + fetchYarnDeps, + fixup-yarn-lock, + python3, + jq, + yarn, + nodejs-slim, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,13 @@ rustPlatform.buildRustPackage rec { hash = "sha256-0wj5AS8RLVr+S/QWWxCsMvmVjmXUWGfR9kPaZimJEss="; }; - nativeBuildInputs = [ yarn nodejs-slim fixup-yarn-lock python3 jq ]; + nativeBuildInputs = [ + yarn + nodejs-slim + fixup-yarn-lock + python3 + jq + ]; nlnog_communities = fetchFromGitHub { owner = "NLNOG"; @@ -37,11 +44,15 @@ rustPlatform.buildRustPackage rec { hash = "sha256-/ubCAs4C5nG8xNC77jTH+cJVNgddSxqGGPEVLDH/Cdo="; }; - cargoBuildFlags = lib.optionals (stdenv.hostPlatform.isMusl && stdenv.hostPlatform.isStatic) [ - "--features" "mimalloc" - ] ++ [ - "--features" "embed-static" - ]; + cargoBuildFlags = + lib.optionals (stdenv.hostPlatform.isMusl && stdenv.hostPlatform.isStatic) [ + "--features" + "mimalloc" + ] + ++ [ + "--features" + "embed-static" + ]; preBuild = '' python3 contrib/print_communities.py $nlnog_communities/communities | jq . > src/communities.json diff --git a/pkgs/by-name/fe/ferrum/package.nix b/pkgs/by-name/fe/ferrum/package.nix index 4f10d8e6451908..3841a4abf595ec 100644 --- a/pkgs/by-name/fe/ferrum/package.nix +++ b/pkgs/by-name/fe/ferrum/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "0"; @@ -26,7 +30,10 @@ stdenvNoCC.mkDerivation { homepage = "http://dotcolon.net/font/ferrum/"; description = "Decorative font"; platforms = platforms.all; - maintainers = with maintainers; [ leenaars minijackson ]; + maintainers = with maintainers; [ + leenaars + minijackson + ]; license = licenses.cc0; }; } diff --git a/pkgs/by-name/fe/fet-sh/package.nix b/pkgs/by-name/fe/fet-sh/package.nix index 3a95451d00162e..d0fd407cf57ed1 100644 --- a/pkgs/by-name/fe/fet-sh/package.nix +++ b/pkgs/by-name/fe/fet-sh/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchFromGitHub }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "fet-sh"; diff --git a/pkgs/by-name/fe/fetch-scm/package.nix b/pkgs/by-name/fe/fetch-scm/package.nix index a5bc1f65a90413..9ea2f12fa2087d 100644 --- a/pkgs/by-name/fe/fetch-scm/package.nix +++ b/pkgs/by-name/fe/fetch-scm/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, guile }: +{ + lib, + stdenv, + fetchFromGitHub, + guile, +}: stdenv.mkDerivation rec { pname = "fetch-scm"; diff --git a/pkgs/by-name/fe/fetchit/package.nix b/pkgs/by-name/fe/fetchit/package.nix index d772ba5f5ad685..9269a39bce4a97 100644 --- a/pkgs/by-name/fe/fetchit/package.nix +++ b/pkgs/by-name/fe/fetchit/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, lvm2 -, pkg-config +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + lvm2, + pkg-config, }: buildGoModule rec { @@ -21,7 +22,10 @@ buildGoModule rec { subPackages = [ "cmd/fetchit" ]; - nativeBuildInputs = [ pkg-config installShellFiles ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; buildInputs = [ lvm2 ]; # Flags are derived from diff --git a/pkgs/by-name/fe/fetchutils/package.nix b/pkgs/by-name/fe/fetchutils/package.nix index b4ab650ecaafb0..f9b5954488b185 100644 --- a/pkgs/by-name/fe/fetchutils/package.nix +++ b/pkgs/by-name/fe/fetchutils/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenvNoCC, fetchFromGitHub, bash, scdoc }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + bash, + scdoc, +}: stdenvNoCC.mkDerivation rec { pname = "fetchutils"; @@ -11,7 +17,10 @@ stdenvNoCC.mkDerivation rec { sha256 = "sha256-ONrVZC6GBV5v3TeBekW9ybZjDHF3FNyXw1rYknqKRbk="; }; - buildInputs = [ bash scdoc ]; + buildInputs = [ + bash + scdoc + ]; installFlags = [ "PREFIX=$(out)/" ]; diff --git a/pkgs/by-name/ff/ff2mpv-go/package.nix b/pkgs/by-name/ff/ff2mpv-go/package.nix index 7fa747b8839d26..195d4f3db9c420 100644 --- a/pkgs/by-name/ff/ff2mpv-go/package.nix +++ b/pkgs/by-name/ff/ff2mpv-go/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchgit -, makeWrapper -, mpv +{ + lib, + buildGoModule, + fetchgit, + makeWrapper, + mpv, }: buildGoModule rec { pname = "ff2mpv-go"; diff --git a/pkgs/by-name/ff/ff2mpv-rust/package.nix b/pkgs/by-name/ff/ff2mpv-rust/package.nix index c6db7961d0ed88..a5848b4ef93cd4 100644 --- a/pkgs/by-name/ff/ff2mpv-rust/package.nix +++ b/pkgs/by-name/ff/ff2mpv-rust/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: let diff --git a/pkgs/by-name/ff/ff2mpv/package.nix b/pkgs/by-name/ff/ff2mpv/package.nix index 27fd0ce892f7e1..f362ef29eaba15 100644 --- a/pkgs/by-name/ff/ff2mpv/package.nix +++ b/pkgs/by-name/ff/ff2mpv/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, python3, mpv }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + mpv, +}: stdenv.mkDerivation rec { pname = "ff2mpv"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-Xx18EX/MxLrnwZGwMFZJxJURUpjU2P01CQue5XbZ3fw="; }; - buildInputs = [ python3 mpv ]; + buildInputs = [ + python3 + mpv + ]; postPatch = '' patchShebangs . diff --git a/pkgs/by-name/ff/ffcast/package.nix b/pkgs/by-name/ff/ffcast/package.nix index cdf94928033b81..68aab967e3c40c 100644 --- a/pkgs/by-name/ff/ffcast/package.nix +++ b/pkgs/by-name/ff/ffcast/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, makeWrapper, perl -, ffmpeg-full, gawk, imagemagick, xdpyinfo, xprop, xrectsel, xwininfo +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + makeWrapper, + perl, + ffmpeg-full, + gawk, + imagemagick, + xdpyinfo, + xprop, + xrectsel, + xwininfo, }: stdenv.mkDerivation rec { @@ -13,23 +25,29 @@ stdenv.mkDerivation rec { sha256 = "sha256-kxqwDGEguFTFHkQzXctXqxslt0+bYnfUdQ8C/8+eTXo="; }; - nativeBuildInputs = [ autoreconfHook makeWrapper perl /*for pod2man*/ ]; + nativeBuildInputs = [ + autoreconfHook + makeWrapper + perl # for pod2man + ]; configureFlags = [ "--disable-xrectsel" ]; - postInstall = let - binPath = lib.makeBinPath [ - ffmpeg-full - gawk - imagemagick - xdpyinfo - xprop - xrectsel - xwininfo - ]; - in '' - wrapProgram $out/bin/ffcast --prefix PATH : ${binPath} - ''; + postInstall = + let + binPath = lib.makeBinPath [ + ffmpeg-full + gawk + imagemagick + xdpyinfo + xprop + xrectsel + xwininfo + ]; + in + '' + wrapProgram $out/bin/ffcast --prefix PATH : ${binPath} + ''; meta = { description = "Run commands on rectangular screen regions"; diff --git a/pkgs/by-name/ff/fff/package.nix b/pkgs/by-name/ff/fff/package.nix index d7bb50f59e43f6..cd6ffddfce5ec1 100644 --- a/pkgs/by-name/ff/fff/package.nix +++ b/pkgs/by-name/ff/fff/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, bashInteractive, xdg-utils, file, coreutils, w3m, xdotool }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + bashInteractive, + xdg-utils, + file, + coreutils, + w3m, + xdotool, +}: stdenv.mkDerivation rec { pname = "fff"; @@ -11,7 +22,13 @@ stdenv.mkDerivation rec { sha256 = "14ymdw6l6phnil0xf1frd5kgznaiwppcic0v4hb61s1zpf4wrshg"; }; - pathAdd = lib.makeSearchPath "bin" ([ xdg-utils file coreutils w3m xdotool ]); + pathAdd = lib.makeSearchPath "bin" ([ + xdg-utils + file + coreutils + w3m + xdotool + ]); nativeBuildInputs = [ makeWrapper ]; buildInputs = [ bashInteractive ]; diff --git a/pkgs/by-name/ff/fflas-ffpack/package.nix b/pkgs/by-name/ff/fflas-ffpack/package.nix index 1d8c87ba45d1a0..a3af3b49af93d9 100644 --- a/pkgs/by-name/ff/fflas-ffpack/package.nix +++ b/pkgs/by-name/ff/fflas-ffpack/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, givaro, pkg-config, blas, lapack -, gmpxx +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + givaro, + pkg-config, + blas, + lapack, + gmpxx, }: assert (!blas.isILP64) && (!lapack.isILP64); @@ -26,27 +34,33 @@ stdenv.mkDerivation rec { pkg-config ] ++ lib.optionals doCheck nativeCheckInputs; - buildInputs = [ givaro blas lapack ]; - - configureFlags = [ - "--with-blas-libs=-lcblas" - "--with-lapack-libs=-llapacke" - "--without-archnative" - ] ++ lib.optionals stdenv.hostPlatform.isx86_64 [ - # disable SIMD instructions (which are enabled *when available* by default) - # for now we need to be careful to disable *all* relevant versions of an instruction set explicitly (https://github.com/linbox-team/fflas-ffpack/issues/284) - "--${if stdenv.hostPlatform.sse3Support then "enable" else "disable"}-sse3" - "--${if stdenv.hostPlatform.ssse3Support then "enable" else "disable"}-ssse3" - "--${if stdenv.hostPlatform.sse4_1Support then "enable" else "disable"}-sse41" - "--${if stdenv.hostPlatform.sse4_2Support then "enable" else "disable"}-sse42" - "--${if stdenv.hostPlatform.avxSupport then "enable" else "disable"}-avx" - "--${if stdenv.hostPlatform.avx2Support then "enable" else "disable"}-avx2" - "--${if stdenv.hostPlatform.avx512Support then "enable" else "disable"}-avx512f" - "--${if stdenv.hostPlatform.avx512Support then "enable" else "disable"}-avx512dq" - "--${if stdenv.hostPlatform.avx512Support then "enable" else "disable"}-avx512vl" - "--${if stdenv.hostPlatform.fmaSupport then "enable" else "disable"}-fma" - "--${if stdenv.hostPlatform.fma4Support then "enable" else "disable"}-fma4" + buildInputs = [ + givaro + blas + lapack ]; + + configureFlags = + [ + "--with-blas-libs=-lcblas" + "--with-lapack-libs=-llapacke" + "--without-archnative" + ] + ++ lib.optionals stdenv.hostPlatform.isx86_64 [ + # disable SIMD instructions (which are enabled *when available* by default) + # for now we need to be careful to disable *all* relevant versions of an instruction set explicitly (https://github.com/linbox-team/fflas-ffpack/issues/284) + "--${if stdenv.hostPlatform.sse3Support then "enable" else "disable"}-sse3" + "--${if stdenv.hostPlatform.ssse3Support then "enable" else "disable"}-ssse3" + "--${if stdenv.hostPlatform.sse4_1Support then "enable" else "disable"}-sse41" + "--${if stdenv.hostPlatform.sse4_2Support then "enable" else "disable"}-sse42" + "--${if stdenv.hostPlatform.avxSupport then "enable" else "disable"}-avx" + "--${if stdenv.hostPlatform.avx2Support then "enable" else "disable"}-avx2" + "--${if stdenv.hostPlatform.avx512Support then "enable" else "disable"}-avx512f" + "--${if stdenv.hostPlatform.avx512Support then "enable" else "disable"}-avx512dq" + "--${if stdenv.hostPlatform.avx512Support then "enable" else "disable"}-avx512vl" + "--${if stdenv.hostPlatform.fmaSupport then "enable" else "disable"}-fma" + "--${if stdenv.hostPlatform.fma4Support then "enable" else "disable"}-fma4" + ]; doCheck = true; meta = with lib; { diff --git a/pkgs/by-name/ff/fflinuxprint/package.nix b/pkgs/by-name/ff/fflinuxprint/package.nix index 83a4d223b970e5..c0781e71a90947 100644 --- a/pkgs/by-name/ff/fflinuxprint/package.nix +++ b/pkgs/by-name/ff/fflinuxprint/package.nix @@ -1,9 +1,10 @@ -{ autoPatchelfHook -, cups -, dpkg -, fetchurl -, lib -, stdenv +{ + autoPatchelfHook, + cups, + dpkg, + fetchurl, + lib, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ff/fflogs/package.nix b/pkgs/by-name/ff/fflogs/package.nix index 5ff45e5c2199ba..1fa42f43a3d95f 100644 --- a/pkgs/by-name/ff/fflogs/package.nix +++ b/pkgs/by-name/ff/fflogs/package.nix @@ -1,6 +1,7 @@ -{ lib -, appimageTools -, fetchurl +{ + lib, + appimageTools, + fetchurl, }: let diff --git a/pkgs/by-name/ff/fftw/package.nix b/pkgs/by-name/ff/fftw/package.nix index 2cc3a85adb9c25..f41573a3dc5593 100644 --- a/pkgs/by-name/ff/fftw/package.nix +++ b/pkgs/by-name/ff/fftw/package.nix @@ -1,18 +1,24 @@ -{ fetchurl -, fetchpatch -, stdenv -, lib -, gfortran -, perl -, llvmPackages -, precision ? "double" -, enableMpi ? false -, mpi -, withDoc ? stdenv.cc.isGNU -, testers +{ + fetchurl, + fetchpatch, + stdenv, + lib, + gfortran, + perl, + llvmPackages, + precision ? "double", + enableMpi ? false, + mpi, + withDoc ? stdenv.cc.isGNU, + testers, }: -assert lib.elem precision [ "single" "double" "long-double" "quad-precision" ]; +assert lib.elem precision [ + "single" + "double" + "long-double" + "quad-precision" +]; stdenv.mkDerivation (finalAttrs: { pname = "fftw-${precision}"; @@ -34,31 +40,38 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - outputs = [ "out" "dev" "man" ] - ++ lib.optional withDoc "info"; # it's dev-doc only + outputs = [ + "out" + "dev" + "man" + ] ++ lib.optional withDoc "info"; # it's dev-doc only outputBin = "dev"; # fftw-wisdom nativeBuildInputs = [ gfortran ]; - buildInputs = lib.optionals stdenv.cc.isClang [ - # TODO: This may mismatch the LLVM version sin the stdenv, see #79818. - llvmPackages.openmp - ] ++ lib.optional enableMpi mpi; + buildInputs = + lib.optionals stdenv.cc.isClang [ + # TODO: This may mismatch the LLVM version sin the stdenv, see #79818. + llvmPackages.openmp + ] + ++ lib.optional enableMpi mpi; - configureFlags = [ - "--enable-shared" - "--enable-threads" - "--enable-openmp" - ] + configureFlags = + [ + "--enable-shared" + "--enable-threads" + "--enable-openmp" + ] - ++ lib.optional (precision != "double") "--enable-${precision}" - # https://www.fftw.org/fftw3_doc/SIMD-alignment-and-fftw_005fmalloc.html - # FFTW will try to detect at runtime whether the CPU supports these extensions - ++ lib.optional (stdenv.hostPlatform.isx86_64 && (precision == "single" || precision == "double")) - "--enable-sse2 --enable-avx --enable-avx2 --enable-avx512 --enable-avx128-fma" - ++ lib.optional enableMpi "--enable-mpi" - # doc generation causes Fortran wrapper generation which hard-codes gcc - ++ lib.optional (!withDoc) "--disable-doc"; + ++ lib.optional (precision != "double") "--enable-${precision}" + # https://www.fftw.org/fftw3_doc/SIMD-alignment-and-fftw_005fmalloc.html + # FFTW will try to detect at runtime whether the CPU supports these extensions + ++ lib.optional ( + stdenv.hostPlatform.isx86_64 && (precision == "single" || precision == "double") + ) "--enable-sse2 --enable-avx --enable-avx2 --enable-avx512 --enable-avx128-fma" + ++ lib.optional enableMpi "--enable-mpi" + # doc generation causes Fortran wrapper generation which hard-codes gcc + ++ lib.optional (!withDoc) "--disable-doc"; # fftw builds with -mtune=native by default postPatch = '' @@ -82,7 +95,8 @@ stdenv.mkDerivation (finalAttrs: { "double" = "fftw3"; "long-double" = "fftw3l"; "quad-precision" = "fftw3q"; - }.${precision} + } + .${precision} ]; platforms = platforms.unix; # quad-precision requires libquadmath from gfortran, but libquadmath is not supported on aarch64 diff --git a/pkgs/by-name/ff/ffuf/package.nix b/pkgs/by-name/ff/ffuf/package.nix index ae0a19bff0226e..3b576a117f3612 100644 --- a/pkgs/by-name/ff/ffuf/package.nix +++ b/pkgs/by-name/ff/ffuf/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, }: buildGoModule rec { diff --git a/pkgs/by-name/fg/fg-virgil/package.nix b/pkgs/by-name/fg/fg-virgil/package.nix index d7c04d9b9e883b..9f3e4b5fb10776 100644 --- a/pkgs/by-name/fg/fg-virgil/package.nix +++ b/pkgs/by-name/fg/fg-virgil/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "fg-virgil"; diff --git a/pkgs/by-name/fg/fgallery/package.nix b/pkgs/by-name/fg/fgallery/package.nix index 8e2e636d90f7ef..3d60062a4c2136 100644 --- a/pkgs/by-name/fg/fgallery/package.nix +++ b/pkgs/by-name/fg/fgallery/package.nix @@ -1,6 +1,18 @@ -{ lib, stdenv, fetchurl, unzip, makeWrapper, perlPackages -, coreutils, zip, imagemagick, pngcrush, lcms2 -, facedetect, fbida }: +{ + lib, + stdenv, + fetchurl, + unzip, + makeWrapper, + perlPackages, + coreutils, + zip, + imagemagick, + pngcrush, + lcms2, + facedetect, + fbida, +}: # TODO: add optional dependencies (snippet from fgallery source): # @@ -17,8 +29,18 @@ stdenv.mkDerivation rec { hash = "sha256-FvF0wkRe3wTPUG9/GEBxkaxvZ1B4wEd9kI9rURHKxn0="; }; - nativeBuildInputs = [ makeWrapper unzip ]; - buildInputs = (with perlPackages; [ perl ImageExifTool CpanelJSONXS ]); + nativeBuildInputs = [ + makeWrapper + unzip + ]; + buildInputs = ( + with perlPackages; + [ + perl + ImageExifTool + CpanelJSONXS + ] + ); postPatch = '' substituteInPlace Makefile \ @@ -39,8 +61,17 @@ stdenv.mkDerivation rec { wrapProgram "$out/share/fgallery/fgallery" \ --set PERL5LIB "$PERL5LIB" \ - --set PATH "${lib.makeBinPath - [ coreutils zip imagemagick pngcrush lcms2 facedetect fbida ]}" + --set PATH "${ + lib.makeBinPath [ + coreutils + zip + imagemagick + pngcrush + lcms2 + facedetect + fbida + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/fg/fgqcanvas/package.nix b/pkgs/by-name/fg/fgqcanvas/package.nix index e7d0352a0fbaf1..33edfdf380f32a 100644 --- a/pkgs/by-name/fg/fgqcanvas/package.nix +++ b/pkgs/by-name/fg/fgqcanvas/package.nix @@ -1,9 +1,10 @@ -{ fetchgit -, pkg-config -, stdenv -, lib -# Package dependencies -, qt5 +{ + fetchgit, + pkg-config, + stdenv, + lib, + # Package dependencies + qt5, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fh/fh/package.nix b/pkgs/by-name/fh/fh/package.nix index ba363960cf96fb..cf37e8bceaac7e 100644 --- a/pkgs/by-name/fh/fh/package.nix +++ b/pkgs/by-name/fh/fh/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv -, darwin -, gcc -, libcxx -, cacert +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + darwin, + gcc, + libcxx, + cacert, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/fh/fheroes2/package.nix b/pkgs/by-name/fh/fheroes2/package.nix index cffc2de3041416..18ba08a60e569a 100644 --- a/pkgs/by-name/fh/fheroes2/package.nix +++ b/pkgs/by-name/fh/fheroes2/package.nix @@ -1,8 +1,19 @@ -{ stdenv, lib, fetchFromGitHub, imagemagick -, gettext, glibcLocalesUtf8, libpng, SDL2, SDL2_image, SDL2_mixer, SDL2_ttf, zlib -, libiconv - -, gitUpdater +{ + stdenv, + lib, + fetchFromGitHub, + imagemagick, + gettext, + glibcLocalesUtf8, + libpng, + SDL2, + SDL2_image, + SDL2_mixer, + SDL2_ttf, + zlib, + libiconv, + + gitUpdater, }: stdenv.mkDerivation rec { @@ -18,8 +29,16 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ imagemagick ]; - buildInputs = [ gettext glibcLocalesUtf8 libpng SDL2 SDL2_image SDL2_mixer SDL2_ttf zlib ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; + buildInputs = [ + gettext + glibcLocalesUtf8 + libpng + SDL2 + SDL2_image + SDL2_mixer + SDL2_ttf + zlib + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; makeFlags = [ "FHEROES2_STRICT_COMPILATION=1" @@ -63,9 +82,9 @@ stdenv.mkDerivation rec { description = "Free implementation of Heroes of Might and Magic II game engine"; mainProgram = "fheroes2"; longDescription = '' - In order to play this game, an original game data is required. - Please refer to README of the project for instructions. - On linux, the data can be placed in ~/.local/share/fheroes2 folder. + In order to play this game, an original game data is required. + Please refer to README of the project for instructions. + On linux, the data can be placed in ~/.local/share/fheroes2 folder. ''; license = licenses.gpl2Plus; maintainers = [ maintainers.karolchmist ]; diff --git a/pkgs/by-name/fi/fiano/package.nix b/pkgs/by-name/fi/fiano/package.nix index ba4b415b283e8d..3f09e5af9c40ff 100644 --- a/pkgs/by-name/fi/fiano/package.nix +++ b/pkgs/by-name/fi/fiano/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -28,7 +29,10 @@ buildGoModule rec { vendorHash = "sha256-00ZSAVEmk2pNjv6fo++gnpIheK8lo4AVWf+ghXappnI="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Go-based tools for modifying UEFI firmware"; diff --git a/pkgs/by-name/fi/fiche/package.nix b/pkgs/by-name/fi/fiche/package.nix index 375733d272ccba..4361019d55f70b 100644 --- a/pkgs/by-name/fi/fiche/package.nix +++ b/pkgs/by-name/fi/fiche/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "fiche"; diff --git a/pkgs/by-name/fi/fichub-cli/package.nix b/pkgs/by-name/fi/fichub-cli/package.nix index f694a9b9930749..50f8b8373e6866 100644 --- a/pkgs/by-name/fi/fichub-cli/package.nix +++ b/pkgs/by-name/fi/fichub-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "fichub-cli"; diff --git a/pkgs/by-name/fi/fig2dev/package.nix b/pkgs/by-name/fi/fig2dev/package.nix index 1a2175294981c1..1a02390498df0a 100644 --- a/pkgs/by-name/fi/fig2dev/package.nix +++ b/pkgs/by-name/fi/fig2dev/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, ghostscript -, libpng -, makeWrapper -, coreutils -, bc -, gnugrep -, gawk -, gnused +{ + lib, + stdenv, + fetchurl, + ghostscript, + libpng, + makeWrapper, + coreutils, + bc, + gnugrep, + gawk, + gnused, }: stdenv.mkDerivation rec { @@ -23,13 +24,20 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; buildInputs = [ libpng ]; - GSEXE="${ghostscript}/bin/gs"; + GSEXE = "${ghostscript}/bin/gs"; configureFlags = [ "--enable-transfig" ]; postInstall = '' wrapProgram $out/bin/fig2ps2tex \ - --set PATH ${lib.makeBinPath [ coreutils bc gnugrep gawk ]} + --set PATH ${ + lib.makeBinPath [ + coreutils + bc + gnugrep + gawk + ] + } wrapProgram $out/bin/pic2tpic \ --set PATH ${lib.makeBinPath [ gnused ]} ''; diff --git a/pkgs/by-name/fi/figlet/package.nix b/pkgs/by-name/fi/figlet/package.nix index 746def80c6d9c4..5b13d3631fc1c2 100644 --- a/pkgs/by-name/fi/figlet/package.nix +++ b/pkgs/by-name/fi/figlet/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fetchpatch, fetchzip }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + fetchzip, +}: stdenv.mkDerivation rec { pname = "figlet"; @@ -28,7 +34,11 @@ stdenv.mkDerivation rec { }) ]; - makeFlags = [ "prefix=$(out)" "CC:=$(CC)" "LD:=$(CC)" ]; + makeFlags = [ + "prefix=$(out)" + "CC:=$(CC)" + "LD:=$(CC)" + ]; postInstall = "cp -ar ${contributed}/* $out/share/figlet/"; diff --git a/pkgs/by-name/fi/figma-linux/package.nix b/pkgs/by-name/fi/figma-linux/package.nix index 2b11d16803985f..5e9ced617e1447 100644 --- a/pkgs/by-name/fi/figma-linux/package.nix +++ b/pkgs/by-name/fi/figma-linux/package.nix @@ -1,12 +1,13 @@ -{ pkgs -, lib -, stdenv -, fetchurl -, autoPatchelfHook -, dpkg -, makeWrapper -, wrapGAppsHook3 -, ... +{ + pkgs, + lib, + stdenv, + fetchurl, + autoPatchelfHook, + dpkg, + makeWrapper, + wrapGAppsHook3, + ... }: stdenv.mkDerivation (finalAttrs: { pname = "figma-linux"; @@ -24,32 +25,35 @@ stdenv.mkDerivation (finalAttrs: { wrapGAppsHook3 ]; - buildInputs = with pkgs;[ - alsa-lib - at-spi2-atk - cairo - cups.lib - dbus.lib - expat - gdk-pixbuf - glib - gtk3 - libdrm - libxkbcommon - mesa - nspr - nss - pango - ] ++ (with pkgs.xorg; [ - libX11 - libXcomposite - libXdamage - libXext - libXfixes - libXrandr - libxcb - libxshmfence - ]); + buildInputs = + with pkgs; + [ + alsa-lib + at-spi2-atk + cairo + cups.lib + dbus.lib + expat + gdk-pixbuf + glib + gtk3 + libdrm + libxkbcommon + mesa + nspr + nss + pango + ] + ++ (with pkgs.xorg; [ + libX11 + libXcomposite + libXdamage + libXext + libXfixes + libXrandr + libxcb + libxshmfence + ]); runtimeDependencies = with pkgs; [ eudev ]; @@ -86,7 +90,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/Figma-Linux/figma-linux"; platforms = [ "x86_64-linux" ]; license = licenses.gpl2Plus; - maintainers = with maintainers; [ ercao kashw2 ]; + maintainers = with maintainers; [ + ercao + kashw2 + ]; mainProgram = "figma-linux"; }; }) diff --git a/pkgs/by-name/fi/figurine/package.nix b/pkgs/by-name/fi/figurine/package.nix index 5c1fa255565b42..88bb4ff21b8f18 100644 --- a/pkgs/by-name/fi/figurine/package.nix +++ b/pkgs/by-name/fi/figurine/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { diff --git a/pkgs/by-name/fi/fil-plugins/package.nix b/pkgs/by-name/fi/fil-plugins/package.nix index 1d819fd8b7639f..73d3ff0c0b33fc 100644 --- a/pkgs/by-name/fi/fil-plugins/package.nix +++ b/pkgs/by-name/fi/fil-plugins/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, ladspaH +{ + lib, + stdenv, + fetchurl, + ladspaH, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/fi/file-rename/package.nix b/pkgs/by-name/fi/file-rename/package.nix index e2e1eccae216bb..8e37bb454ba1f9 100644 --- a/pkgs/by-name/fi/file-rename/package.nix +++ b/pkgs/by-name/fi/file-rename/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, perl, perlPackages }: +{ + lib, + stdenv, + fetchurl, + perl, + perlPackages, +}: perlPackages.buildPerlPackage { pname = "File-Rename"; diff --git a/pkgs/by-name/fi/file-roller/package.nix b/pkgs/by-name/fi/file-roller/package.nix index 5de8f9f14f468a..6cb2c17477c091 100644 --- a/pkgs/by-name/fi/file-roller/package.nix +++ b/pkgs/by-name/fi/file-roller/package.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchurl -, desktop-file-utils -, gettext -, glibcLocales -, itstool -, libxml2 -, meson -, ninja -, pkg-config -, python3 -, wrapGAppsHook4 -, cpio -, glib -, gnome -, gtk4 -, libadwaita -, json-glib -, libarchive -, nautilus +{ + lib, + stdenv, + fetchurl, + desktop-file-utils, + gettext, + glibcLocales, + itstool, + libxml2, + meson, + ninja, + pkg-config, + python3, + wrapGAppsHook4, + cpio, + glib, + gnome, + gtk4, + libadwaita, + json-glib, + libarchive, + nautilus, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/fi/filebench/package.nix b/pkgs/by-name/fi/filebench/package.nix index 7cbb5f15936a66..a288ca5734d3e5 100644 --- a/pkgs/by-name/fi/filebench/package.nix +++ b/pkgs/by-name/fi/filebench/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, autoreconfHook, bison, flex }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + bison, + flex, +}: stdenv.mkDerivation rec { pname = "filebench"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "13hmx67lsz367sn8lrvz1780mfczlbiz8v80gig9kpkpf009yksc"; }; - nativeBuildInputs = [ autoreconfHook bison flex ]; + nativeBuildInputs = [ + autoreconfHook + bison + flex + ]; meta = with lib; { description = "File system and storage benchmark that can generate both micro and macro workloads"; diff --git a/pkgs/by-name/fi/filebrowser/package.nix b/pkgs/by-name/fi/filebrowser/package.nix index 7adede3e32997e..af275fdd75312c 100644 --- a/pkgs/by-name/fi/filebrowser/package.nix +++ b/pkgs/by-name/fi/filebrowser/package.nix @@ -59,4 +59,3 @@ buildGo123Module { mainProgram = "filebrowser"; }; } - diff --git a/pkgs/by-name/fi/filegive/package.nix b/pkgs/by-name/fi/filegive/package.nix index 6933404567a02e..5ea5558b92133d 100644 --- a/pkgs/by-name/fi/filegive/package.nix +++ b/pkgs/by-name/fi/filegive/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, lib, fetchurl }: +{ + buildGoModule, + lib, + fetchurl, +}: buildGoModule rec { pname = "filegive"; @@ -12,7 +16,10 @@ buildGoModule rec { vendorHash = "sha256-l7FRl58NWGBynMlGu1SCxeVBEzTdxREvUWzmJDiliZM="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://viric.name/cgi-bin/filegive"; diff --git a/pkgs/by-name/fi/fileinfo/package.nix b/pkgs/by-name/fi/fileinfo/package.nix index 08a85eaa3efefc..c0dbafd2b00f3e 100644 --- a/pkgs/by-name/fi/fileinfo/package.nix +++ b/pkgs/by-name/fi/fileinfo/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication { pname = "fileinfo"; diff --git a/pkgs/by-name/fi/files-cli/package.nix b/pkgs/by-name/fi/files-cli/package.nix index e28177c485526b..6526a677f714a9 100644 --- a/pkgs/by-name/fi/files-cli/package.nix +++ b/pkgs/by-name/fi/files-cli/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, testers -, files-cli +{ + lib, + fetchFromGitHub, + buildGoModule, + testers, + files-cli, }: buildGoModule rec { diff --git a/pkgs/by-name/fi/fileshare/package.nix b/pkgs/by-name/fi/fileshare/package.nix index e7c0bc6ad26024..0389ebd0c54ffc 100644 --- a/pkgs/by-name/fi/fileshare/package.nix +++ b/pkgs/by-name/fi/fileshare/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchgit, pkg-config, git, libmicrohttpd }: +{ + stdenv, + lib, + fetchgit, + pkg-config, + git, + libmicrohttpd, +}: stdenv.mkDerivation rec { pname = "fileshare"; @@ -14,7 +21,10 @@ stdenv.mkDerivation rec { sed -i 's,$(shell git rev-parse --short HEAD),/${version},g' Makefile ''; - nativeBuildInputs = [ pkg-config git ]; + nativeBuildInputs = [ + pkg-config + git + ]; buildInputs = [ libmicrohttpd ]; makeFlags = [ "BUILD=release" ]; diff --git a/pkgs/by-name/fi/fileshelter/package.nix b/pkgs/by-name/fi/fileshelter/package.nix index 337f178a1c507a..093348d39de22d 100644 --- a/pkgs/by-name/fi/fileshelter/package.nix +++ b/pkgs/by-name/fi/fileshelter/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libzip, boost, wt4, libconfig, pkg-config } : +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libzip, + boost, + wt4, + libconfig, + pkg-config, +}: stdenv.mkDerivation rec { pname = "fileshelter"; @@ -13,8 +23,16 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libzip boost wt4 libconfig ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libzip + boost + wt4 + libconfig + ]; NIX_LDFLAGS = "-lpthread"; diff --git a/pkgs/by-name/fi/filet/package.nix b/pkgs/by-name/fi/filet/package.nix index 4ced9fc7b00dda..94d43744245cfa 100644 --- a/pkgs/by-name/fi/filet/package.nix +++ b/pkgs/by-name/fi/filet/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "filet"; diff --git a/pkgs/by-name/fi/filter-audio/package.nix b/pkgs/by-name/fi/filter-audio/package.nix index 8b76c151b4728b..ae1d63a1e1deea 100644 --- a/pkgs/by-name/fi/filter-audio/package.nix +++ b/pkgs/by-name/fi/filter-audio/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "filter-audio"; @@ -6,7 +10,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "irungentoo"; - repo ="filter_audio"; + repo = "filter_audio"; rev = "v${version}"; sha256 = "1dv4pram317c1w97cjsv9f6r8cdxhgri7ib0v364z08pk7r2avfn"; }; diff --git a/pkgs/by-name/fi/filtron/package.nix b/pkgs/by-name/fi/filtron/package.nix index 2f6a95367e97d4..f4083022478a3a 100644 --- a/pkgs/by-name/fi/filtron/package.nix +++ b/pkgs/by-name/fi/filtron/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "filtron"; @@ -26,7 +31,10 @@ buildGoModule rec { }) ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Reverse HTTP proxy to filter requests by different rules"; diff --git a/pkgs/by-name/fi/fim-rs/package.nix b/pkgs/by-name/fi/fim-rs/package.nix index 2b1cdc313ce396..c10cc2b50a6889 100644 --- a/pkgs/by-name/fi/fim-rs/package.nix +++ b/pkgs/by-name/fi/fim-rs/package.nix @@ -1,11 +1,12 @@ -{ lib -, bzip2 -, darwin -, fetchFromGitHub -, pkg-config -, rustPlatform -, stdenv -, zstd +{ + lib, + bzip2, + darwin, + fetchFromGitHub, + pkg-config, + rustPlatform, + stdenv, + zstd, }: rustPlatform.buildRustPackage rec { @@ -31,15 +32,17 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - bzip2 - zstd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreFoundation - darwin.apple_sdk.frameworks.CoreServices - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + bzip2 + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreFoundation + darwin.apple_sdk.frameworks.CoreServices + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; env = { ZSTD_SYS_USE_PKG_CONFIG = true; diff --git a/pkgs/by-name/fi/fim/package.nix b/pkgs/by-name/fi/fim/package.nix index 79d3052a84a107..8e8954f52d5098 100644 --- a/pkgs/by-name/fi/fim/package.nix +++ b/pkgs/by-name/fi/fim/package.nix @@ -1,12 +1,29 @@ -{ stdenv, fetchurl, autoconf, automake, pkg-config, lib -, perl, flex, bison, readline, libexif -, x11Support ? true, SDL -, svgSupport ? true, inkscape -, asciiArtSupport ? true, aalib -, gifSupport ? true, giflib -, tiffSupport ? true, libtiff -, jpegSupport ? true, libjpeg -, pngSupport ? true, libpng +{ + stdenv, + fetchurl, + autoconf, + automake, + pkg-config, + lib, + perl, + flex, + bison, + readline, + libexif, + x11Support ? true, + SDL, + svgSupport ? true, + inkscape, + asciiArtSupport ? true, + aalib, + gifSupport ? true, + giflib, + tiffSupport ? true, + libtiff, + jpegSupport ? true, + libjpeg, + pngSupport ? true, + libpng, }: stdenv.mkDerivation rec { @@ -19,14 +36,24 @@ stdenv.mkDerivation rec { }; postPatch = '' - substituteInPlace doc/vim2html.pl \ - --replace /usr/bin/perl ${perl}/bin/perl + substituteInPlace doc/vim2html.pl \ + --replace /usr/bin/perl ${perl}/bin/perl ''; - nativeBuildInputs = [ autoconf automake pkg-config ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + ]; buildInputs = - [ perl flex bison readline libexif ] + [ + perl + flex + bison + readline + libexif + ] ++ lib.optional x11Support SDL ++ lib.optional svgSupport inkscape ++ lib.optional asciiArtSupport aalib diff --git a/pkgs/by-name/fi/finamp/package.nix b/pkgs/by-name/fi/finamp/package.nix index 80567e7e2f865c..6e5e298e0cc664 100644 --- a/pkgs/by-name/fi/finamp/package.nix +++ b/pkgs/by-name/fi/finamp/package.nix @@ -1,10 +1,11 @@ -{ lib -, flutter327 -, mpv-unwrapped -, patchelf -, fetchFromGitHub -, copyDesktopItems -, makeDesktopItem +{ + lib, + flutter327, + mpv-unwrapped, + patchelf, + fetchFromGitHub, + copyDesktopItems, + makeDesktopItem, }: let version = "0.9.12-beta"; @@ -20,7 +21,10 @@ flutter327.buildFlutterApplication { }; pubspecLock = lib.importJSON ./pubspec.lock.json; - nativeBuildInputs = [ patchelf copyDesktopItems ]; + nativeBuildInputs = [ + patchelf + copyDesktopItems + ]; buildInputs = [ mpv-unwrapped ]; gitHashes = { @@ -32,28 +36,32 @@ flutter327.buildFlutterApplication { }; postFixup = '' - patchelf $out/app/$pname/finamp --add-needed libisar.so --add-needed libmpv.so --add-rpath ${lib.makeLibraryPath [ mpv-unwrapped ]} + patchelf $out/app/$pname/finamp --add-needed libisar.so --add-needed libmpv.so --add-rpath ${ + lib.makeLibraryPath [ mpv-unwrapped ] + } ''; postInstall = '' install -Dm644 $src/assets/icon/icon_foreground.svg $out/share/icons/hicolor/scalable/apps/finamp.svg ''; - desktopItems = [(makeDesktopItem { - name = "Finamp"; - desktopName = "Finamp"; - genericName = "Music Player"; - exec = "finamp"; - icon = "finamp"; - startupWMClass = "finamp"; - comment = "An open source Jellyfin music player"; - categories = [ - "AudioVideo" - "Audio" - "Player" - "Music" - ]; - })]; + desktopItems = [ + (makeDesktopItem { + name = "Finamp"; + desktopName = "Finamp"; + genericName = "Music Player"; + exec = "finamp"; + icon = "finamp"; + startupWMClass = "finamp"; + comment = "An open source Jellyfin music player"; + categories = [ + "AudioVideo" + "Audio" + "Player" + "Music" + ]; + }) + ]; meta = { description = "Open source Jellyfin music player"; diff --git a/pkgs/by-name/fi/find-billy/package.nix b/pkgs/by-name/fi/find-billy/package.nix index 6ff964c684e9d5..94ca57036c3681 100644 --- a/pkgs/by-name/fi/find-billy/package.nix +++ b/pkgs/by-name/fi/find-billy/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitea -, godot3-headless -, godot3-export-templates -, godot3 -, makeWrapper -, just -, inkscape -, imagemagick +{ + stdenv, + lib, + fetchFromGitea, + godot3-headless, + godot3-export-templates, + godot3, + makeWrapper, + just, + inkscape, + imagemagick, }: stdenv.mkDerivation rec { @@ -24,7 +25,13 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ godot3-headless makeWrapper just inkscape imagemagick ]; + nativeBuildInputs = [ + godot3-headless + makeWrapper + just + inkscape + imagemagick + ]; postPatch = '' substituteInPlace export_presets.cfg --replace 'res://build/icons/usr/share/icons/hicolor' $out/share/icons/hicolor diff --git a/pkgs/by-name/fi/find-cursor/package.nix b/pkgs/by-name/fi/find-cursor/package.nix index 3b9862a47dea2b..5e385d8fd94b74 100644 --- a/pkgs/by-name/fi/find-cursor/package.nix +++ b/pkgs/by-name/fi/find-cursor/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, libX11, libXdamage, libXrender, libXcomposite, libXext, installShellFiles, git }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + libXdamage, + libXrender, + libXcomposite, + libXext, + installShellFiles, + git, +}: stdenv.mkDerivation rec { pname = "find-cursor"; @@ -11,8 +22,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-/Dw4bOTCnpCbeI0YJ5DJ9Q2AGBognylUk7xYGn0KIA8="; }; - nativeBuildInputs = [ installShellFiles git ]; - buildInputs = [ libX11 libXdamage libXrender libXcomposite libXext ]; + nativeBuildInputs = [ + installShellFiles + git + ]; + buildInputs = [ + libX11 + libXdamage + libXrender + libXcomposite + libXext + ]; preInstall = "mkdir -p $out/share/man/man1"; installFlags = [ "PREFIX=${placeholder "out"}" ]; diff --git a/pkgs/by-name/fi/findbugs/package.nix b/pkgs/by-name/fi/findbugs/package.nix index a3f52f8da092ed..ebe78c3360d669 100644 --- a/pkgs/by-name/fi/findbugs/package.nix +++ b/pkgs/by-name/fi/findbugs/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "findbugs"; diff --git a/pkgs/by-name/fi/findex/package.nix b/pkgs/by-name/fi/findex/package.nix index 20187d526337b0..3823e28c302ee2 100644 --- a/pkgs/by-name/fi/findex/package.nix +++ b/pkgs/by-name/fi/findex/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, wrapGAppsHook3 -, keybinder3 +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + wrapGAppsHook3, + keybinder3, }: rustPlatform.buildRustPackage rec { @@ -26,7 +27,10 @@ rustPlatform.buildRustPackage rec { --replace-fail '/opt/findex/style.css' "$out/share/findex/style.css" ''; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; buildInputs = [ keybinder3 ]; diff --git a/pkgs/by-name/fi/findnewest/package.nix b/pkgs/by-name/fi/findnewest/package.nix index adf791cf603021..da66750e3e7507 100644 --- a/pkgs/by-name/fi/findnewest/package.nix +++ b/pkgs/by-name/fi/findnewest/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "findnewest"; diff --git a/pkgs/by-name/fi/findomain/package.nix b/pkgs/by-name/fi/findomain/package.nix index 7fed4c99daae22..09e666128b6e9f 100644 --- a/pkgs/by-name/fi/findomain/package.nix +++ b/pkgs/by-name/fi/findomain/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -34,11 +35,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; env = { OPENSSL_NO_VENDOR = true; @@ -53,7 +56,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/Findomain/Findomain"; changelog = "https://github.com/Findomain/Findomain/releases/tag/${version}"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ Br1ght0ne figsoda ]; + maintainers = with maintainers; [ + Br1ght0ne + figsoda + ]; mainProgram = "findomain"; }; } diff --git a/pkgs/by-name/fi/findup/package.nix b/pkgs/by-name/fi/findup/package.nix index eaba884d79d9d7..77db64a887cded 100644 --- a/pkgs/by-name/fi/findup/package.nix +++ b/pkgs/by-name/fi/findup/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, testers -, zig_0_10 +{ + lib, + stdenv, + fetchFromGitHub, + testers, + zig_0_10, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/fi/fingerprintx/package.nix b/pkgs/by-name/fi/fingerprintx/package.nix index b081d82dfd70e3..087d587a0f5ddd 100644 --- a/pkgs/by-name/fi/fingerprintx/package.nix +++ b/pkgs/by-name/fi/fingerprintx/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/fi/fio/package.nix b/pkgs/by-name/fi/fio/package.nix index 1f3ea68c2c8a05..f6bb6cf6ef9bc0 100644 --- a/pkgs/by-name/fi/fio/package.nix +++ b/pkgs/by-name/fi/fio/package.nix @@ -1,26 +1,39 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper -, libaio, python3, zlib -, withGnuplot ? false, gnuplot ? null }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + libaio, + python3, + zlib, + withGnuplot ? false, + gnuplot ? null, +}: stdenv.mkDerivation rec { pname = "fio"; version = "3.38"; src = fetchFromGitHub { - owner = "axboe"; - repo = "fio"; - rev = "fio-${version}"; + owner = "axboe"; + repo = "fio"; + rev = "fio-${version}"; sha256 = "sha256-hjU6be1+x4YsY9hztqSD5zIxojs6qRZH7GwEkxPwdus="; }; - buildInputs = [ python3 zlib ] - ++ lib.optional (!stdenv.hostPlatform.isDarwin) libaio; + buildInputs = [ + python3 + zlib + ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) libaio; # ./configure does not support autoconf-style --build=/--host=. # We use $CC instead. configurePlatforms = [ ]; - nativeBuildInputs = [ makeWrapper python3.pkgs.wrapPython ]; + nativeBuildInputs = [ + makeWrapper + python3.pkgs.wrapPython + ]; strictDeps = true; diff --git a/pkgs/by-name/fi/fioctl/package.nix b/pkgs/by-name/fi/fioctl/package.nix index b930e65cbbe870..26d5ba7b9f89e1 100644 --- a/pkgs/by-name/fi/fioctl/package.nix +++ b/pkgs/by-name/fi/fioctl/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, testers, fioctl }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + fioctl, +}: buildGoModule rec { pname = "fioctl"; @@ -14,7 +21,8 @@ buildGoModule rec { vendorHash = "sha256-SUjHHsZGi5C5juYdJJ0Z7i6P6gySQOdn1VaReCIwfzU="; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/foundriesio/fioctl/subcommands/version.Commit=${src.rev}" ]; @@ -37,7 +45,10 @@ buildGoModule rec { description = "Simple CLI to manage your Foundries Factory"; homepage = "https://github.com/foundriesio/fioctl"; license = licenses.asl20; - maintainers = with maintainers; [ nixinator matthewcroughan ]; + maintainers = with maintainers; [ + nixinator + matthewcroughan + ]; mainProgram = "fioctl"; }; } diff --git a/pkgs/by-name/fi/fira-go/package.nix b/pkgs/by-name/fi/fira-go/package.nix index a850d7d2e97c87..1f5d3edd706df5 100644 --- a/pkgs/by-name/fi/fira-go/package.nix +++ b/pkgs/by-name/fi/fira-go/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { pname = "fira-go"; diff --git a/pkgs/by-name/fi/fira-math/package.nix b/pkgs/by-name/fi/fira-math/package.nix index 58b72f6b740ec7..b9eb000366f48d 100644 --- a/pkgs/by-name/fi/fira-math/package.nix +++ b/pkgs/by-name/fi/fira-math/package.nix @@ -1,10 +1,16 @@ -{ lib, fetchFromGitHub, python3, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + python3, + stdenvNoCC, +}: let pname = "fira-math"; date = "2023-10-09"; version = "0.3.4-unstable-${date}"; -in stdenvNoCC.mkDerivation { +in +stdenvNoCC.mkDerivation { inherit pname version; src = fetchFromGitHub { @@ -15,12 +21,14 @@ in stdenvNoCC.mkDerivation { }; nativeBuildInputs = [ - (python3.withPackages (ps: with ps; [ - fontmake - fonttools - glyphslib - toml - ])) + (python3.withPackages ( + ps: with ps; [ + fontmake + fonttools + glyphslib + toml + ] + )) ]; buildPhase = '' diff --git a/pkgs/by-name/fi/fira-mono/package.nix b/pkgs/by-name/fi/fira-mono/package.nix index 5925b665eb81ce..40f2f158434435 100644 --- a/pkgs/by-name/fi/fira-mono/package.nix +++ b/pkgs/by-name/fi/fira-mono/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchzip +{ + lib, + stdenvNoCC, + fetchzip, }: stdenvNoCC.mkDerivation rec { @@ -8,7 +9,9 @@ stdenvNoCC.mkDerivation rec { version = "3.2"; src = fetchzip { - url = "https://bboxtype.com/downloads/Fira/Fira_Mono_${lib.replaceStrings ["."] ["_"] version}.zip"; + url = "https://bboxtype.com/downloads/Fira/Fira_Mono_${ + lib.replaceStrings [ "." ] [ "_" ] version + }.zip"; hash = "sha256-Ukc+K2sdSz+vUQFD8mmwJHZQ3N68oM4fk6YzGLwzAfQ="; }; diff --git a/pkgs/by-name/fi/fira-sans/package.nix b/pkgs/by-name/fi/fira-sans/package.nix index 0a2bc0e0f6284b..00618336cf26a2 100644 --- a/pkgs/by-name/fi/fira-sans/package.nix +++ b/pkgs/by-name/fi/fira-sans/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchzip +{ + lib, + stdenvNoCC, + fetchzip, }: stdenvNoCC.mkDerivation rec { @@ -8,7 +9,9 @@ stdenvNoCC.mkDerivation rec { version = "4.301"; src = fetchzip { - url = "https://bboxtype.com/downloads/Fira/Download_Folder_FiraSans_${lib.replaceStrings ["."] [""] version}.zip"; + url = "https://bboxtype.com/downloads/Fira/Download_Folder_FiraSans_${ + lib.replaceStrings [ "." ] [ "" ] version + }.zip"; hash = "sha256-WBt3oqPK7ACqMhilYkyFx9Ek2ugwdCDFZN+8HLRnGRs"; stripRoot = false; }; diff --git a/pkgs/by-name/fi/fira/package.nix b/pkgs/by-name/fi/fira/package.nix index 9d2869ac53570c..b2aa6c6acd0fd8 100644 --- a/pkgs/by-name/fi/fira/package.nix +++ b/pkgs/by-name/fi/fira/package.nix @@ -1,7 +1,8 @@ -{ lib -, symlinkJoin -, fira-mono -, fira-sans +{ + lib, + symlinkJoin, + fira-mono, + fira-sans, }: symlinkJoin rec { diff --git a/pkgs/by-name/fi/firectl/package.nix b/pkgs/by-name/fi/firectl/package.nix index 9f8da61d3e486c..ec6e30949ae95c 100644 --- a/pkgs/by-name/fi/firectl/package.nix +++ b/pkgs/by-name/fi/firectl/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/fi/firefly-desktop/package.nix b/pkgs/by-name/fi/firefly-desktop/package.nix index 6e32f7431b642c..11a86b93cc061c 100644 --- a/pkgs/by-name/fi/firefly-desktop/package.nix +++ b/pkgs/by-name/fi/firefly-desktop/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools }: +{ + lib, + fetchurl, + appimageTools, +}: let pname = "firefly-desktop"; @@ -9,7 +13,8 @@ let }; appimageContents = appimageTools.extractType2 { inherit pname version src; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; extraPkgs = pkgs: [ pkgs.libsecret ]; diff --git a/pkgs/by-name/fi/firefly-iii/package.nix b/pkgs/by-name/fi/firefly-iii/package.nix index c6ad0f9bb0e337..70b8da259218a5 100644 --- a/pkgs/by-name/fi/firefly-iii/package.nix +++ b/pkgs/by-name/fi/firefly-iii/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, stdenvNoCC -, nodejs -, fetchNpmDeps -, buildPackages -, php83 -, nixosTests -, nix-update-script -, dataDir ? "/var/lib/firefly-iii" +{ + lib, + fetchFromGitHub, + stdenvNoCC, + nodejs, + fetchNpmDeps, + buildPackages, + php83, + nixosTests, + nix-update-script, + dataDir ? "/var/lib/firefly-iii", }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -81,7 +82,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { description = "Firefly III: a personal finances manager"; homepage = "https://github.com/firefly-iii/firefly-iii"; license = lib.licenses.agpl3Only; - maintainers = [ lib.maintainers.savyajha lib.maintainers.patrickdag ]; + maintainers = [ + lib.maintainers.savyajha + lib.maintainers.patrickdag + ]; hydraPlatforms = lib.platforms.linux; # build hangs on both Darwin platforms, needs investigation }; }) diff --git a/pkgs/by-name/fi/firejail/package.nix b/pkgs/by-name/fi/firejail/package.nix index 768d07dab900f5..b998bf6f583a39 100644 --- a/pkgs/by-name/fi/firejail/package.nix +++ b/pkgs/by-name/fi/firejail/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, libapparmor -, which -, xdg-dbus-proxy -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libapparmor, + which, + xdg-dbus-proxy, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fi/firestarter/package.nix b/pkgs/by-name/fi/firestarter/package.nix index 55e1700c5c858e..748f2b44e726f2 100644 --- a/pkgs/by-name/fi/firestarter/package.nix +++ b/pkgs/by-name/fi/firestarter/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchzip -, addDriverRunpath -, cmake -, glibc_multi -, glibc -, git -, pkg-config -, cudaPackages ? {} -, withCuda ? false +{ + stdenv, + lib, + fetchFromGitHub, + fetchzip, + addDriverRunpath, + cmake, + glibc_multi, + glibc, + git, + pkg-config, + cudaPackages ? { }, + withCuda ? false, }: let @@ -46,7 +47,13 @@ let enableParallelBuilding = true; - outputs = [ "out" "lib" "dev" "doc" "man" ]; + outputs = [ + "out" + "lib" + "dev" + "doc" + "man" + ]; }; in @@ -62,30 +69,41 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ - cmake - git - pkg-config - ] ++ lib.optionals withCuda [ - addDriverRunpath - ]; + nativeBuildInputs = + [ + cmake + git + pkg-config + ] + ++ lib.optionals withCuda [ + addDriverRunpath + ]; - buildInputs = [ hwloc ] ++ (if withCuda then - [ glibc_multi cudatoolkit ] - else - [ glibc.static ]); + buildInputs = + [ hwloc ] + ++ ( + if withCuda then + [ + glibc_multi + cudatoolkit + ] + else + [ glibc.static ] + ); NIX_LDFLAGS = lib.optionals withCuda [ "-L${cudatoolkit}/lib/stubs" ]; - cmakeFlags = [ - "-DFIRESTARTER_BUILD_HWLOC=OFF" - "-DCMAKE_C_COMPILER_WORKS=1" - "-DCMAKE_CXX_COMPILER_WORKS=1" - ] ++ lib.optionals withCuda [ - "-DFIRESTARTER_BUILD_TYPE=FIRESTARTER_CUDA" - ]; + cmakeFlags = + [ + "-DFIRESTARTER_BUILD_HWLOC=OFF" + "-DCMAKE_C_COMPILER_WORKS=1" + "-DCMAKE_CXX_COMPILER_WORKS=1" + ] + ++ lib.optionals withCuda [ + "-DFIRESTARTER_BUILD_TYPE=FIRESTARTER_CUDA" + ]; installPhase = '' runHook preInstall @@ -103,7 +121,10 @@ stdenv.mkDerivation rec { homepage = "https://tu-dresden.de/zih/forschung/projekte/firestarter"; description = "Processor Stress Test Utility"; platforms = platforms.linux; - maintainers = with maintainers; [ astro marenz ]; + maintainers = with maintainers; [ + astro + marenz + ]; license = licenses.gpl3; mainProgram = "FIRESTARTER"; }; diff --git a/pkgs/by-name/fi/firewalk/package.nix b/pkgs/by-name/fi/firewalk/package.nix index 13497d99c44391..4f1c365d6088b4 100644 --- a/pkgs/by-name/fi/firewalk/package.nix +++ b/pkgs/by-name/fi/firewalk/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, libnet -, libpcap -, libdnet +{ + lib, + stdenv, + fetchurl, + libnet, + libpcap, + libdnet, }: stdenv.mkDerivation (finalAttrs: { @@ -15,7 +16,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-f0sHzcH3faeg7epfpWXbgaHrRWaWBKMEqLdy38+svGo="; }; - buildInputs = [ libnet libpcap libdnet ]; + buildInputs = [ + libnet + libpcap + libdnet + ]; meta = with lib; { description = "Gateway ACL scanner"; diff --git a/pkgs/by-name/fi/firmware-manager/package.nix b/pkgs/by-name/fi/firmware-manager/package.nix index 1682f16c390350..1364c58e039069 100644 --- a/pkgs/by-name/fi/firmware-manager/package.nix +++ b/pkgs/by-name/fi/firmware-manager/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, cargo -, pkg-config -, rustc -, openssl -, udev -, gtk3 -, wrapGAppsHook3 +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + cargo, + pkg-config, + rustc, + openssl, + udev, + gtk3, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -53,7 +54,10 @@ stdenv.mkDerivation rec { meta = { description = "Graphical frontend for firmware management"; homepage = "https://github.com/pop-os/firmware-manager"; - license = with lib.licenses; [ gpl3Plus cc0 ]; + license = with lib.licenses; [ + gpl3Plus + cc0 + ]; mainProgram = "com.system76.FirmwareManager"; maintainers = [ lib.maintainers.shlevy ]; platforms = lib.platforms.linux; diff --git a/pkgs/by-name/fi/firmware-updater/package.nix b/pkgs/by-name/fi/firmware-updater/package.nix index 626f0502c48a27..28feae86242213 100644 --- a/pkgs/by-name/fi/firmware-updater/package.nix +++ b/pkgs/by-name/fi/firmware-updater/package.nix @@ -1,7 +1,8 @@ -{ lib -, writeText -, flutter -, fetchFromGitHub +{ + lib, + writeText, + flutter, + fetchFromGitHub, }: flutter.buildFlutterApplication rec { diff --git a/pkgs/by-name/fi/firrtl/package.nix b/pkgs/by-name/fi/firrtl/package.nix index 3f005243d60740..a3718753af6576 100644 --- a/pkgs/by-name/fi/firrtl/package.nix +++ b/pkgs/by-name/fi/firrtl/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, jre, setJavaClassPath, coursier, makeWrapper }: +{ + lib, + stdenv, + jre, + setJavaClassPath, + coursier, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "firrtl"; @@ -19,7 +26,10 @@ stdenv.mkDerivation rec { outputHash = "sha256-xy3zdJZk6Q2HbEn5tRQ9Z0AjyXEteXepoWDaATjiUUw="; }; - nativeBuildInputs = [ makeWrapper setJavaClassPath ]; + nativeBuildInputs = [ + makeWrapper + setJavaClassPath + ]; buildInputs = [ deps ]; dontUnpack = true; @@ -36,13 +46,13 @@ stdenv.mkDerivation rec { doInstallCheck = true; installCheckPhase = '' $out/bin/firrtl --firrtl-source "${'' - circuit test: - module test: - input a: UInt<8> - input b: UInt<8> - output o: UInt - o <= add(a, not(b)) - ''}" -o test.v + circuit test: + module test: + input a: UInt<8> + input b: UInt<8> + output o: UInt + o <= add(a, not(b)) + ''}" -o test.v cat test.v grep -qFe "module test" -e "endmodule" test.v ''; @@ -56,6 +66,6 @@ stdenv.mkDerivation rec { ''; homepage = "https://www.chisel-lang.org/firrtl/"; license = licenses.asl20; - maintainers = [ ]; + maintainers = [ ]; }; } diff --git a/pkgs/by-name/fi/fish-fillets-ng/package.nix b/pkgs/by-name/fi/fish-fillets-ng/package.nix index dc2d01ec9e94ae..7a0a88f9739d97 100644 --- a/pkgs/by-name/fi/fish-fillets-ng/package.nix +++ b/pkgs/by-name/fi/fish-fillets-ng/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, makeDesktopItem, copyDesktopItems, SDL, lua5_1, pkg-config, SDL_mixer, SDL_image, SDL_ttf }: +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + copyDesktopItems, + SDL, + lua5_1, + pkg-config, + SDL_mixer, + SDL_image, + SDL_ttf, +}: stdenv.mkDerivation rec { pname = "fish-fillets-ng"; @@ -13,17 +25,31 @@ stdenv.mkDerivation rec { sha256 = "169p0yqh2gxvhdilvjc2ld8aap7lv2nhkhkg4i1hlmgc6pxpkjgh"; }; - nativeBuildInputs = [ pkg-config copyDesktopItems ]; - buildInputs = [ SDL lua5_1 SDL_mixer SDL_image SDL_ttf ]; + nativeBuildInputs = [ + pkg-config + copyDesktopItems + ]; + buildInputs = [ + SDL + lua5_1 + SDL_mixer + SDL_image + SDL_ttf + ]; - desktopItems = [ (makeDesktopItem { - name = "fish-fillets-ng"; - exec = "fillets"; - icon = "fish-fillets-ng"; - desktopName = "Fish Fillets"; - comment = "Puzzle game about witty fish saving the world sokoban-style"; - categories = [ "Game" "LogicGame" ]; - }) ]; + desktopItems = [ + (makeDesktopItem { + name = "fish-fillets-ng"; + exec = "fillets"; + icon = "fish-fillets-ng"; + desktopName = "Fish Fillets"; + comment = "Puzzle game about witty fish saving the world sokoban-style"; + categories = [ + "Game" + "LogicGame" + ]; + }) + ]; postInstall = '' mkdir -p $out/share/games/fillets-ng diff --git a/pkgs/by-name/fi/fish-irssi/package.nix b/pkgs/by-name/fi/fish-irssi/package.nix index a5ee8b7cef628b..2421017aab0ca5 100644 --- a/pkgs/by-name/fi/fish-irssi/package.nix +++ b/pkgs/by-name/fi/fish-irssi/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, glib, openssl, irssi }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + glib, + openssl, + irssi, +}: stdenv.mkDerivation rec { pname = "fish-irssi"; @@ -13,9 +22,15 @@ stdenv.mkDerivation rec { patches = [ ./irssi-include-dir.patch ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ glib openssl ]; + buildInputs = [ + glib + openssl + ]; cmakeFlags = [ "-DIRSSI_INCLUDE_PATH:PATH=${irssi}/include" ]; diff --git a/pkgs/by-name/fi/fits-cloudctl/package.nix b/pkgs/by-name/fi/fits-cloudctl/package.nix index e4c56659c73324..95a0461cdcc847 100644 --- a/pkgs/by-name/fi/fits-cloudctl/package.nix +++ b/pkgs/by-name/fi/fits-cloudctl/package.nix @@ -1,14 +1,15 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "fits-cloudctl"; version = "0.12.21"; # also update these 3 vars: gitversion = "tags/v0.12.21-0-g0a0d89a"; # git describe --long --all - gitsha = "0a0d89a8"; # git rev-parse --short=8 HEAD - gittime = "2024-05-15T17:34:46+02:00"; # date --iso-8601=seconds + gitsha = "0a0d89a8"; # git rev-parse --short=8 HEAD + gittime = "2024-05-15T17:34:46+02:00"; # date --iso-8601=seconds src = fetchFromGitHub { owner = "fi-ts"; diff --git a/pkgs/by-name/fi/fitsverify/package.nix b/pkgs/by-name/fi/fitsverify/package.nix index b755e71616f801..c0cd705be1fc3b 100644 --- a/pkgs/by-name/fi/fitsverify/package.nix +++ b/pkgs/by-name/fi/fitsverify/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, cfitsio +{ + lib, + stdenv, + fetchurl, + cfitsio, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/fi/fityk/package.nix b/pkgs/by-name/fi/fityk/package.nix index ed906e7d4c3df6..581b717c0be84a 100644 --- a/pkgs/by-name/fi/fityk/package.nix +++ b/pkgs/by-name/fi/fityk/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, wxGTK32 -, boost -, lua -, zlib -, bzip2 -, xylib -, readline -, gnuplot -, swig +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + wxGTK32, + boost, + lua, + zlib, + bzip2, + xylib, + readline, + gnuplot, + swig, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fi/fixedsys-excelsior/package.nix b/pkgs/by-name/fi/fixedsys-excelsior/package.nix index dec1ea062bbc4a..f0d4154b98fdd9 100644 --- a/pkgs/by-name/fi/fixedsys-excelsior/package.nix +++ b/pkgs/by-name/fi/fixedsys-excelsior/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "fixedsys-excelsior"; diff --git a/pkgs/by-name/fi/fixjson/package.nix b/pkgs/by-name/fi/fixjson/package.nix index 52ed03c690f5f0..37623c8bcc4f85 100644 --- a/pkgs/by-name/fi/fixjson/package.nix +++ b/pkgs/by-name/fi/fixjson/package.nix @@ -1,7 +1,7 @@ { lib, buildNpmPackage, - fetchFromGitHub + fetchFromGitHub, }: buildNpmPackage { diff --git a/pkgs/by-name/fj/fjo/package.nix b/pkgs/by-name/fj/fjo/package.nix index 7671073cd3eeb0..d843a8947a43fb 100644 --- a/pkgs/by-name/fj/fjo/package.nix +++ b/pkgs/by-name/fj/fjo/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitea, rustPlatform, openssl, pkg-config }: +{ + lib, + stdenv, + fetchFromGitea, + rustPlatform, + openssl, + pkg-config, +}: rustPlatform.buildRustPackage rec { pname = "fjo"; diff --git a/pkgs/by-name/fl/flac/package.nix b/pkgs/by-name/fl/flac/package.nix index 09ce3341aa5471..aea4cc4378e2eb 100644 --- a/pkgs/by-name/fl/flac/package.nix +++ b/pkgs/by-name/fl/flac/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, cmake -, pkg-config -, doxygen -, graphviz -, libogg +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + doxygen, + graphviz, + libogg, }: stdenv.mkDerivation rec { @@ -33,12 +34,21 @@ stdenv.mkDerivation rec { "-DBUILD_SHARED_LIBS=ON" ]; - CFLAGS = [ "-O3" "-funroll-loops" ]; + CFLAGS = [ + "-O3" + "-funroll-loops" + ]; CXXFLAGS = [ "-O3" ]; # doCheck = true; # takes lots of time - outputs = [ "bin" "dev" "out" "man" "doc" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + "doc" + ]; meta = with lib; { homepage = "https://xiph.org/flac/"; diff --git a/pkgs/by-name/fl/flac2all/package.nix b/pkgs/by-name/fl/flac2all/package.nix index 7020879eae9bfd..fb9a420a1aa547 100644 --- a/pkgs/by-name/fl/flac2all/package.nix +++ b/pkgs/by-name/fl/flac2all/package.nix @@ -1,4 +1,13 @@ -{ python3Packages, fetchPypi, lib, flac, lame, opusTools, vorbis-tools, ffmpeg }: +{ + python3Packages, + fetchPypi, + lib, + flac, + lame, + opusTools, + vorbis-tools, + ffmpeg, +}: python3Packages.buildPythonApplication rec { pname = "flac2all"; @@ -20,20 +29,25 @@ python3Packages.buildPythonApplication rec { postInstall = '' wrapProgram $out/bin/flac2all \ - --set PATH ${lib.makeBinPath [ - # Hard requirements - flac - lame - # Optional deps depending on encoding types - opusTools - vorbis-tools - ffmpeg - ]} + --set PATH ${ + lib.makeBinPath [ + # Hard requirements + flac + lame + # Optional deps depending on encoding types + opusTools + vorbis-tools + ffmpeg + ] + } ''; # Has no standard tests, so we verify a few imports instead. doCheck = false; - pythonImportsCheck = [ "flac2all_pkg.vorbis" "flac2all_pkg.mp3" ]; + pythonImportsCheck = [ + "flac2all_pkg.vorbis" + "flac2all_pkg.mp3" + ]; meta = with lib; { description = "Multi process, clustered, FLAC to multi codec audio converter with tagging support"; diff --git a/pkgs/by-name/fl/flam3/package.nix b/pkgs/by-name/fl/flam3/package.nix index 121485b081e87b..6e32ccc5a79725 100644 --- a/pkgs/by-name/fl/flam3/package.nix +++ b/pkgs/by-name/fl/flam3/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, libjpeg -, libpng -, libxml2 -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + libjpeg, + libpng, + libxml2, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fl/flamegraph/package.nix b/pkgs/by-name/fl/flamegraph/package.nix index d80354b68c7abb..968c3efa6e82e2 100644 --- a/pkgs/by-name/fl/flamegraph/package.nix +++ b/pkgs/by-name/fl/flamegraph/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation rec { pname = "FlameGraph"; @@ -32,7 +37,11 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - license = with licenses; [ asl20 cddl gpl2Plus ]; + license = with licenses; [ + asl20 + cddl + gpl2Plus + ]; homepage = "http://www.brendangregg.com/flamegraphs.html"; description = "Visualization for profiled code"; mainProgram = "flamegraph.pl"; diff --git a/pkgs/by-name/fl/flamerobin/package.nix b/pkgs/by-name/fl/flamerobin/package.nix index de0f06fa5a0081..a49ed58d385929 100644 --- a/pkgs/by-name/fl/flamerobin/package.nix +++ b/pkgs/by-name/fl/flamerobin/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, wxGTK32 -, boost -, firebird +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + wxGTK32, + boost, + firebird, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fl/flamp/package.nix b/pkgs/by-name/fl/flamp/package.nix index 6dc8c81c1f9528..27e6797ea2be6a 100644 --- a/pkgs/by-name/fl/flamp/package.nix +++ b/pkgs/by-name/fl/flamp/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchgit -, autoreconfHook -, pkg-config -, fltk13 -, gettext +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + pkg-config, + fltk13, + gettext, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/fl/flann/package.nix b/pkgs/by-name/fl/flann/package.nix index 52d64f18e8e50c..d68def287d012b 100644 --- a/pkgs/by-name/fl/flann/package.nix +++ b/pkgs/by-name/fl/flann/package.nix @@ -1,13 +1,14 @@ -{ lib -, cmake -, fetchFromGitHub -, fetchpatch -, lz4 -, pkg-config -, python3 -, stdenv -, unzip -, enablePython ? false +{ + lib, + cmake, + fetchFromGitHub, + fetchpatch, + lz4, + pkg-config, + python3, + stdenv, + unzip, + enablePython ? false, }: stdenv.mkDerivation rec { @@ -21,35 +22,38 @@ stdenv.mkDerivation rec { sha256 = "13lg9nazj5s9a41j61vbijy04v6839i67lqd925xmxsbybf36gjc"; }; - patches = [ - # Patch HDF5_INCLUDE_DIR -> HDF_INCLUDE_DIRS. - (fetchpatch { - url = "https://salsa.debian.org/science-team/flann/-/raw/debian/1.9.1+dfsg-9/debian/patches/0001-Updated-fix-cmake-hdf5.patch"; - sha256 = "yM1ONU4mu6lctttM5YcSTg8F344TNUJXwjxXLqzr5Pk="; - }) - # Patch no-source library workaround that breaks on CMake > 3.11. - (fetchpatch { - url = "https://salsa.debian.org/science-team/flann/-/raw/debian/1.9.1+dfsg-9/debian/patches/0001-src-cpp-fix-cmake-3.11-build.patch"; - sha256 = "REsBnbe6vlrZ+iCcw43kR5wy2o6q10RM73xjW5kBsr4="; - }) - ] ++ lib.optionals (!stdenv.cc.isClang) [ - # Avoid the bundled version of LZ4 and instead use the system one. - (fetchpatch { - url = "https://salsa.debian.org/science-team/flann/-/raw/debian/1.9.1+dfsg-9/debian/patches/0003-Use-system-version-of-liblz4.patch"; - sha256 = "xi+GyFn9PEjLgbJeAIEmsbp7ut9G9KIBkVulyT3nfsg="; - }) - # Fix LZ4 string separator issue, see: https://github.com/flann-lib/flann/pull/480 - (fetchpatch { - url = "https://github.com/flann-lib/flann/commit/25eb56ec78472bd419a121c6905095a793cf8992.patch"; - sha256 = "qt8h576Gn8uR7+T9u9bEBIRz6e6AoTKpa1JfdZVvW9s="; - }) - ] ++ lib.optionals stdenv.cc.isClang [ - # Fix build with Clang 16. - (fetchpatch { - url = "https://github.com/flann-lib/flann/commit/be80cefa69b314a3d9e1ab971715e84145863ebb.patch"; - hash = "sha256-4SUKzQCm0Sx8N43Z6ShuMbgbbe7q8b2Ibk3WgkB0qa4="; - }) - ]; + patches = + [ + # Patch HDF5_INCLUDE_DIR -> HDF_INCLUDE_DIRS. + (fetchpatch { + url = "https://salsa.debian.org/science-team/flann/-/raw/debian/1.9.1+dfsg-9/debian/patches/0001-Updated-fix-cmake-hdf5.patch"; + sha256 = "yM1ONU4mu6lctttM5YcSTg8F344TNUJXwjxXLqzr5Pk="; + }) + # Patch no-source library workaround that breaks on CMake > 3.11. + (fetchpatch { + url = "https://salsa.debian.org/science-team/flann/-/raw/debian/1.9.1+dfsg-9/debian/patches/0001-src-cpp-fix-cmake-3.11-build.patch"; + sha256 = "REsBnbe6vlrZ+iCcw43kR5wy2o6q10RM73xjW5kBsr4="; + }) + ] + ++ lib.optionals (!stdenv.cc.isClang) [ + # Avoid the bundled version of LZ4 and instead use the system one. + (fetchpatch { + url = "https://salsa.debian.org/science-team/flann/-/raw/debian/1.9.1+dfsg-9/debian/patches/0003-Use-system-version-of-liblz4.patch"; + sha256 = "xi+GyFn9PEjLgbJeAIEmsbp7ut9G9KIBkVulyT3nfsg="; + }) + # Fix LZ4 string separator issue, see: https://github.com/flann-lib/flann/pull/480 + (fetchpatch { + url = "https://github.com/flann-lib/flann/commit/25eb56ec78472bd419a121c6905095a793cf8992.patch"; + sha256 = "qt8h576Gn8uR7+T9u9bEBIRz6e6AoTKpa1JfdZVvW9s="; + }) + ] + ++ lib.optionals stdenv.cc.isClang [ + # Fix build with Clang 16. + (fetchpatch { + url = "https://github.com/flann-lib/flann/commit/be80cefa69b314a3d9e1ab971715e84145863ebb.patch"; + hash = "sha256-4SUKzQCm0Sx8N43Z6ShuMbgbbe7q8b2Ibk3WgkB0qa4="; + }) + ]; cmakeFlags = [ "-DBUILD_EXAMPLES:BOOL=OFF" diff --git a/pkgs/by-name/fl/flare-signal/package.nix b/pkgs/by-name/fl/flare-signal/package.nix index 80cb2dc8948e57..f501c4891ac41f 100644 --- a/pkgs/by-name/fl/flare-signal/package.nix +++ b/pkgs/by-name/fl/flare-signal/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitLab -, cargo -, meson -, ninja -, pkg-config -, gst_all_1 -, protobuf -, libspelling -, libsecret -, libadwaita -, gtksourceview5 -, rustPlatform -, rustc -, appstream-glib -, blueprint-compiler -, desktop-file-utils -, wrapGAppsHook4 +{ + lib, + stdenv, + fetchFromGitLab, + cargo, + meson, + ninja, + pkg-config, + gst_all_1, + protobuf, + libspelling, + libsecret, + libadwaita, + gtksourceview5, + rustPlatform, + rustc, + appstream-glib, + blueprint-compiler, + desktop-file-utils, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/fl/flarectl/package.nix b/pkgs/by-name/fl/flarectl/package.nix index deec18b18a510c..93c80ff7a457c1 100644 --- a/pkgs/by-name/fl/flarectl/package.nix +++ b/pkgs/by-name/fl/flarectl/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -18,7 +19,10 @@ buildGoModule rec { subPackages = [ "cmd/flarectl" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "CLI application for interacting with a Cloudflare account"; diff --git a/pkgs/by-name/fl/flashbench/package.nix b/pkgs/by-name/fl/flashbench/package.nix index 619aea69aa64ae..c04a2a2ff1e84e 100644 --- a/pkgs/by-name/fl/flashbench/package.nix +++ b/pkgs/by-name/fl/flashbench/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "flashbench-unstable"; diff --git a/pkgs/by-name/fl/flashfocus/package.nix b/pkgs/by-name/fl/flashfocus/package.nix index f49c7936f60e78..1668b2611fb59a 100644 --- a/pkgs/by-name/fl/flashfocus/package.nix +++ b/pkgs/by-name/fl/flashfocus/package.nix @@ -1,4 +1,12 @@ -{ lib, python3Packages, fetchPypi, netcat-openbsd, procps, bash, nix-update-script }: +{ + lib, + python3Packages, + fetchPypi, + netcat-openbsd, + procps, + bash, + nix-update-script, +}: python3Packages.buildPythonApplication rec { pname = "flashfocus"; diff --git a/pkgs/by-name/fl/flashgbx/package.nix b/pkgs/by-name/fl/flashgbx/package.nix index cb5f803c63b3c9..c38f37464777ec 100644 --- a/pkgs/by-name/fl/flashgbx/package.nix +++ b/pkgs/by-name/fl/flashgbx/package.nix @@ -1,9 +1,10 @@ -{ lib -, python3Packages -, fetchFromGitHub -, makeDesktopItem -, copyDesktopItems -, qt6 +{ + lib, + python3Packages, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + qt6, }: python3Packages.buildPythonApplication rec { @@ -28,9 +29,8 @@ python3Packages.buildPythonApplication rec { }) ]; - postInstall = - '' - install -D FlashGBX/res/icon.png $out/share/icons/hicolor/256x256/apps/flashgbx.png + postInstall = '' + install -D FlashGBX/res/icon.png $out/share/icons/hicolor/256x256/apps/flashgbx.png ''; pyproject = true; @@ -41,17 +41,20 @@ python3Packages.buildPythonApplication rec { qt6.wrapQtAppsHook ]; - propagatedBuildInputs = with python3Packages; [ - pillow - pyserial - pyside6 - python-dateutil - requests - setuptools - qt6.qtbase - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qt6.qtwayland - ]; + propagatedBuildInputs = + with python3Packages; + [ + pillow + pyserial + pyside6 + python-dateutil + requests + setuptools + qt6.qtbase + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qt6.qtwayland + ]; meta = with lib; { description = "GUI for reading and writing GB and GBA cartridges with the GBxCart RW"; diff --git a/pkgs/by-name/fl/flashmq/package.nix b/pkgs/by-name/fl/flashmq/package.nix index c37fdb1f179efe..8100c6ae91489f 100644 --- a/pkgs/by-name/fl/flashmq/package.nix +++ b/pkgs/by-name/fl/flashmq/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, installShellFiles, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + installShellFiles, + openssl, +}: stdenv.mkDerivation rec { pname = "flashmq"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-sr3gKCovw5bhX9WsuiHQxwq/SaoLHOPCoNjtSop8ka8="; }; - nativeBuildInputs = [ cmake installShellFiles ]; + nativeBuildInputs = [ + cmake + installShellFiles + ]; buildInputs = [ openssl ]; diff --git a/pkgs/by-name/fl/flashprog/package.nix b/pkgs/by-name/fl/flashprog/package.nix index 30c9346903d78a..2839811d1ed704 100644 --- a/pkgs/by-name/fl/flashprog/package.nix +++ b/pkgs/by-name/fl/flashprog/package.nix @@ -1,15 +1,16 @@ -{ fetchgit -, installShellFiles -, lib -, libftdi1 -, libgpiod -, libjaylink -, libusb1 -, pciutils -, pkg-config -, stdenv -, withJlink ? true -, withGpio ? stdenv.hostPlatform.isLinux +{ + fetchgit, + installShellFiles, + lib, + libftdi1, + libgpiod, + libjaylink, + libusb1, + pciutils, + pkg-config, + stdenv, + withJlink ? true, + withGpio ? stdenv.hostPlatform.isLinux, }: stdenv.mkDerivation (finalAttrs: { @@ -26,16 +27,20 @@ stdenv.mkDerivation (finalAttrs: { installShellFiles pkg-config ]; - buildInputs = [ - libftdi1 - libusb1 - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - pciutils - ] ++ lib.optionals (withJlink) [ - libjaylink - ] ++ lib.optionals (withGpio) [ - libgpiod - ]; + buildInputs = + [ + libftdi1 + libusb1 + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + pciutils + ] + ++ lib.optionals (withJlink) [ + libjaylink + ] + ++ lib.optionals (withGpio) [ + libgpiod + ]; makeFlags = let @@ -56,7 +61,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://flashprog.org"; description = "Utility for reading, writing, erasing and verifying flash ROM chips"; license = with licenses; [ gpl2Plus ]; - maintainers = with maintainers; [ felixsinger funkeleinhorn ]; + maintainers = with maintainers; [ + felixsinger + funkeleinhorn + ]; platforms = platforms.all; mainProgram = "flashprog"; }; diff --git a/pkgs/by-name/fl/flashrom/package.nix b/pkgs/by-name/fl/flashrom/package.nix index 4eb39970e84fa2..0b1af9f9f89b98 100644 --- a/pkgs/by-name/fl/flashrom/package.nix +++ b/pkgs/by-name/fl/flashrom/package.nix @@ -1,13 +1,14 @@ -{ fetchurl -, stdenv -, installShellFiles -, lib -, libftdi1 -, libjaylink -, libusb1 -, pciutils -, pkg-config -, jlinkSupport ? false +{ + fetchurl, + stdenv, + installShellFiles, + lib, + libftdi1, + libjaylink, + libusb1, + pciutils, + pkg-config, + jlinkSupport ? false, }: stdenv.mkDerivation rec { @@ -19,8 +20,15 @@ stdenv.mkDerivation rec { hash = "sha256-oFMjRFPM0BLnnzRDvcxhYlz5e3/Xy0zdi/v/vosUliM="; }; - nativeBuildInputs = [ pkg-config installShellFiles ]; - buildInputs = [ libftdi1 libusb1 ] + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; + buildInputs = + [ + libftdi1 + libusb1 + ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ pciutils ] ++ lib.optional jlinkSupport libjaylink; @@ -29,9 +37,17 @@ stdenv.mkDerivation rec { --replace 'GROUP="plugdev"' 'TAG+="uaccess", TAG+="udev-acl"' ''; - makeFlags = [ "PREFIX=$(out)" "libinstall" ] + makeFlags = + [ + "PREFIX=$(out)" + "libinstall" + ] ++ lib.optional jlinkSupport "CONFIG_JLINK_SPI=yes" - ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ "CONFIG_INTERNAL_X86=no" "CONFIG_INTERNAL_DMI=no" "CONFIG_RAYER_SPI=no" ]; + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + "CONFIG_INTERNAL_X86=no" + "CONFIG_INTERNAL_DMI=no" + "CONFIG_RAYER_SPI=no" + ]; postInstall = '' install -Dm644 util/flashrom_udev.rules $out/lib/udev/rules.d/flashrom.rules diff --git a/pkgs/by-name/fl/flasm/package.nix b/pkgs/by-name/fl/flasm/package.nix index e1da977b0039cc..c9bd4e432ec4df 100644 --- a/pkgs/by-name/fl/flasm/package.nix +++ b/pkgs/by-name/fl/flasm/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchzip, unzip, fetchpatch, bison, flex, gperf, zlib }: +{ + lib, + stdenv, + fetchzip, + unzip, + fetchpatch, + bison, + flex, + gperf, + zlib, +}: stdenv.mkDerivation rec { pname = "flasm"; @@ -22,7 +32,12 @@ stdenv.mkDerivation rec { makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; - nativeBuildInputs = [ unzip bison flex gperf ]; + nativeBuildInputs = [ + unzip + bison + flex + gperf + ]; buildInputs = [ zlib ]; diff --git a/pkgs/by-name/fl/flat-remix-gtk/package.nix b/pkgs/by-name/fl/flat-remix-gtk/package.nix index 4fb37d2cba869e..184fe6c6c389a3 100644 --- a/pkgs/by-name/fl/flat-remix-gtk/package.nix +++ b/pkgs/by-name/fl/flat-remix-gtk/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, gtk-engine-murrine +{ + stdenv, + lib, + fetchFromGitHub, + gtk-engine-murrine, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fl/flatcc/package.nix b/pkgs/by-name/fl/flatcc/package.nix index 888fd9f61288d5..7c13f453f4232d 100644 --- a/pkgs/by-name/fl/flatcc/package.nix +++ b/pkgs/by-name/fl/flatcc/package.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fl/flatito/gemset.nix b/pkgs/by-name/fl/flatito/gemset.nix index d2164479531992..aba899a598eaff 100644 --- a/pkgs/by-name/fl/flatito/gemset.nix +++ b/pkgs/by-name/fl/flatito/gemset.nix @@ -70,7 +70,10 @@ version = "1.24.0"; }; parser = { - dependencies = [ "ast" "racc" ]; + dependencies = [ + "ast" + "racc" + ]; groups = [ "default" ]; platforms = [ ]; source = { @@ -131,7 +134,18 @@ version = "3.2.6"; }; rubocop = { - dependencies = [ "json" "language_server-protocol" "parallel" "parser" "rainbow" "regexp_parser" "rexml" "rubocop-ast" "ruby-progressbar" "unicode-display_width" ]; + dependencies = [ + "json" + "language_server-protocol" + "parallel" + "parser" + "rainbow" + "regexp_parser" + "rexml" + "rubocop-ast" + "ruby-progressbar" + "unicode-display_width" + ]; groups = [ "default" ]; platforms = [ ]; source = { @@ -153,7 +167,10 @@ version = "1.31.2"; }; rubocop-minitest = { - dependencies = [ "rubocop" "rubocop-ast" ]; + dependencies = [ + "rubocop" + "rubocop-ast" + ]; groups = [ "default" ]; platforms = [ ]; source = { @@ -164,7 +181,10 @@ version = "0.35.0"; }; rubocop-performance = { - dependencies = [ "rubocop" "rubocop-ast" ]; + dependencies = [ + "rubocop" + "rubocop-ast" + ]; groups = [ "default" ]; platforms = [ ]; source = { diff --git a/pkgs/by-name/fl/flatito/package.nix b/pkgs/by-name/fl/flatito/package.nix index 5b41e53478c28b..d650b44da0f823 100644 --- a/pkgs/by-name/fl/flatito/package.nix +++ b/pkgs/by-name/fl/flatito/package.nix @@ -1,4 +1,9 @@ -{ lib, ruby, buildRubyGem, bundlerEnv }: +{ + lib, + ruby, + buildRubyGem, + bundlerEnv, +}: let deps = bundlerEnv rec { inherit ruby; diff --git a/pkgs/by-name/fl/flatter/package.nix b/pkgs/by-name/fl/flatter/package.nix index 5ef1b6a01444a1..6eea1b44d7a3f5 100644 --- a/pkgs/by-name/fl/flatter/package.nix +++ b/pkgs/by-name/fl/flatter/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, unstableGitUpdater -, cmake -, blas -, gmp -, mpfr -, fplll -, eigen -, llvmPackages +{ + lib, + stdenv, + fetchFromGitHub, + unstableGitUpdater, + cmake, + blas, + gmp, + mpfr, + fplll, + eigen, + llvmPackages, }: stdenv.mkDerivation { @@ -28,15 +29,17 @@ stdenv.mkDerivation { cmake ]; - buildInputs = [ - blas - gmp - mpfr - fplll - eigen - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - llvmPackages.openmp - ]; + buildInputs = + [ + blas + gmp + mpfr + fplll + eigen + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + llvmPackages.openmp + ]; passthru.updateScript = unstableGitUpdater { }; diff --git a/pkgs/by-name/fl/flavours/package.nix b/pkgs/by-name/fl/flavours/package.nix index c2cb20ef5b7465..3ec6115596c0ba 100644 --- a/pkgs/by-name/fl/flavours/package.nix +++ b/pkgs/by-name/fl/flavours/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, libiconv, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + libiconv, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "flavours"; @@ -29,7 +36,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/Misterio77/flavours"; changelog = "https://github.com/Misterio77/flavours/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ moni misterio77 ]; + maintainers = with maintainers; [ + moni + misterio77 + ]; mainProgram = "flavours"; }; } diff --git a/pkgs/by-name/fl/flawfinder/package.nix b/pkgs/by-name/fl/flawfinder/package.nix index 09560acc1d21ea..acd4809a5aad63 100644 --- a/pkgs/by-name/fl/flawfinder/package.nix +++ b/pkgs/by-name/fl/flawfinder/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchurl -, python3 +{ + lib, + fetchurl, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/fl/fleng/package.nix b/pkgs/by-name/fl/fleng/package.nix index 38cb24d4ea7ce1..0257e6636ae40b 100644 --- a/pkgs/by-name/fl/fleng/package.nix +++ b/pkgs/by-name/fl/fleng/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/fl/flex-ncat/package.nix b/pkgs/by-name/fl/flex-ncat/package.nix index 185f830aa6c699..b68933b6c027d5 100644 --- a/pkgs/by-name/fl/flex-ncat/package.nix +++ b/pkgs/by-name/fl/flex-ncat/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "flex-ncat"; diff --git a/pkgs/by-name/fl/flex-ndax/package.nix b/pkgs/by-name/fl/flex-ndax/package.nix index e45604856a59e4..cc75ff1d7751ac 100644 --- a/pkgs/by-name/fl/flex-ndax/package.nix +++ b/pkgs/by-name/fl/flex-ndax/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, buildGoModule, fetchFromGitHub, libpulseaudio }: +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, + libpulseaudio, +}: buildGoModule rec { pname = "flex-ndax"; diff --git a/pkgs/by-name/fl/flexcpp/package.nix b/pkgs/by-name/fl/flexcpp/package.nix index 1a56818b4d65b6..fe1938d6cd0d9f 100644 --- a/pkgs/by-name/fl/flexcpp/package.nix +++ b/pkgs/by-name/fl/flexcpp/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, bobcat, icmake, yodl }: +{ + lib, + stdenv, + fetchFromGitHub, + bobcat, + icmake, + yodl, +}: stdenv.mkDerivation rec { pname = "flexc++"; @@ -16,7 +23,10 @@ stdenv.mkDerivation rec { ''; buildInputs = [ bobcat ]; - nativeBuildInputs = [ icmake yodl ]; + nativeBuildInputs = [ + icmake + yodl + ]; postPatch = '' substituteInPlace INSTALL.im --replace /usr $out diff --git a/pkgs/by-name/fl/flexget/package.nix b/pkgs/by-name/fl/flexget/package.nix index 853e3565abbccb..80ee7a88fb0257 100644 --- a/pkgs/by-name/fl/flexget/package.nix +++ b/pkgs/by-name/fl/flexget/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/fl/flexibee/package.nix b/pkgs/by-name/fl/flexibee/package.nix index 97edd9e1fa2eb4..a593132020aaa3 100644 --- a/pkgs/by-name/fl/flexibee/package.nix +++ b/pkgs/by-name/fl/flexibee/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: let version = "2021.2.1"; @@ -22,7 +28,6 @@ stdenv.mkDerivation rec { --replace "/var/run" "/run" ''; - installPhase = '' runHook preInstall cp -R usr/share/flexibee/ $out/ diff --git a/pkgs/by-name/fl/flexoptix-app/package.nix b/pkgs/by-name/fl/flexoptix-app/package.nix index fa2004ce40ca04..930be1b6d497a0 100644 --- a/pkgs/by-name/fl/flexoptix-app/package.nix +++ b/pkgs/by-name/fl/flexoptix-app/package.nix @@ -1,4 +1,10 @@ -{ lib, appimageTools, fetchurl, asar }: let +{ + lib, + appimageTools, + fetchurl, + asar, +}: +let pname = "flexoptix-app"; version = "5.21.2-latest"; @@ -24,7 +30,8 @@ ''; }); -in appimageTools.wrapAppImage { +in +appimageTools.wrapAppImage { inherit pname version; src = appimageContents; diff --git a/pkgs/by-name/fl/flink/package.nix b/pkgs/by-name/fl/flink/package.nix index 43cf4d047b4503..db5c8ffd53d5f2 100644 --- a/pkgs/by-name/fl/flink/package.nix +++ b/pkgs/by-name/fl/flink/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "flink"; @@ -35,6 +41,9 @@ stdenv.mkDerivation rec { license = licenses.asl20; sourceProvenance = with sourceTypes; [ binaryBytecode ]; platforms = platforms.all; - maintainers = with maintainers; [ mbode autophagy ]; + maintainers = with maintainers; [ + mbode + autophagy + ]; }; } diff --git a/pkgs/by-name/fl/flintlock/package.nix b/pkgs/by-name/fl/flintlock/package.nix index 21413fde6e1b8a..fa9314e8cccce3 100644 --- a/pkgs/by-name/fl/flintlock/package.nix +++ b/pkgs/by-name/fl/flintlock/package.nix @@ -1,14 +1,15 @@ -{ lib -, cni-plugins -, buildGoModule -, firecracker -, containerd -, runc -, makeWrapper -, fetchFromGitHub +{ + lib, + cni-plugins, + buildGoModule, + firecracker, + containerd, + runc, + makeWrapper, + fetchFromGitHub, }: -buildGoModule rec{ +buildGoModule rec { pname = "flintlock"; version = "0.6.0"; @@ -21,9 +22,16 @@ buildGoModule rec{ vendorHash = "sha256-IGfNMe1fQfAGAOVsxmn/oxleHfniqL1TJKllCwpuWOU="; - subPackages = [ "cmd/flintlock-metrics" "cmd/flintlockd" ]; + subPackages = [ + "cmd/flintlock-metrics" + "cmd/flintlockd" + ]; - ldflags = [ "-s" "-w" "-X github.com/weaveworks/flintlock/internal/version.Version=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/weaveworks/flintlock/internal/version.Version=v${version}" + ]; nativeBuildInputs = [ makeWrapper @@ -35,7 +43,14 @@ buildGoModule rec{ postInstall = '' for prog in flintlockd flintlock-metrics; do - wrapProgram "$out/bin/$prog" --prefix PATH : ${lib.makeBinPath [ cni-plugins firecracker containerd runc ]} + wrapProgram "$out/bin/$prog" --prefix PATH : ${ + lib.makeBinPath [ + cni-plugins + firecracker + containerd + runc + ] + } done ''; @@ -43,7 +58,10 @@ buildGoModule rec{ description = "Create and manage the lifecycle of MicroVMs backed by containerd"; homepage = "https://github.com/weaveworks-liquidmetal/flintlock"; license = licenses.mpl20; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; maintainers = with maintainers; [ techknowlogick ]; }; } diff --git a/pkgs/by-name/fl/flip-link/package.nix b/pkgs/by-name/fl/flip-link/package.nix index f652cb11ccac2e..e4db9c90971212 100644 --- a/pkgs/by-name/fl/flip-link/package.nix +++ b/pkgs/by-name/fl/flip-link/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, libiconv }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + libiconv, +}: rustPlatform.buildRustPackage rec { pname = "flip-link"; @@ -27,7 +33,13 @@ rustPlatform.buildRustPackage rec { mainProgram = "flip-link"; homepage = "https://github.com/knurling-rs/flip-link"; changelog = "https://github.com/knurling-rs/flip-link/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ FlorianFranzen newam ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + FlorianFranzen + newam + ]; }; } diff --git a/pkgs/by-name/fl/flip/package.nix b/pkgs/by-name/fl/flip/package.nix index 23e352a090319e..32bb4464cc4b65 100644 --- a/pkgs/by-name/fl/flip/package.nix +++ b/pkgs/by-name/fl/flip/package.nix @@ -2,7 +2,7 @@ stdenv, lib, fetchFromGitHub, - cmake + cmake, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/fl/flips/package.nix b/pkgs/by-name/fl/flips/package.nix index 29edcf254e07a1..d6a7a808243dcd 100644 --- a/pkgs/by-name/fl/flips/package.nix +++ b/pkgs/by-name/fl/flips/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, gtk3, libdivsufsort, pkg-config, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + gtk3, + libdivsufsort, + pkg-config, + wrapGAppsHook3, +}: stdenv.mkDerivation { pname = "flips"; @@ -11,8 +19,14 @@ stdenv.mkDerivation { hash = "sha256-uuHgpt7aWqiMTUILm5tAEGGeZrls3g/DdylYQgsfpTw="; }; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; - buildInputs = [ gtk3 libdivsufsort ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; + buildInputs = [ + gtk3 + libdivsufsort + ]; patches = [ ./use-system-libdivsufsort.patch ]; makeFlags = [ "PREFIX=${placeholder "out"}" ]; buildPhase = '' diff --git a/pkgs/by-name/fl/flitter/package.nix b/pkgs/by-name/fl/flitter/package.nix index cf399ba9ebb9eb..19efe2c399fc21 100644 --- a/pkgs/by-name/fl/flitter/package.nix +++ b/pkgs/by-name/fl/flitter/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, xorg +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + xorg, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/fl/flix/package.nix b/pkgs/by-name/fl/flix/package.nix index 554263db083c58..4aa796ff8b95ec 100644 --- a/pkgs/by-name/fl/flix/package.nix +++ b/pkgs/by-name/fl/flix/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, stdenvNoCC, makeWrapper, jre }: +{ + lib, + fetchurl, + stdenvNoCC, + makeWrapper, + jre, +}: stdenvNoCC.mkDerivation rec { pname = "flix"; diff --git a/pkgs/by-name/fl/fllog/package.nix b/pkgs/by-name/fl/fllog/package.nix index 46b99349be4f74..00d3de60d783ec 100644 --- a/pkgs/by-name/fl/fllog/package.nix +++ b/pkgs/by-name/fl/fllog/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, fltk13 -, libjpeg -, pkg-config +{ + lib, + stdenv, + fetchurl, + fltk13, + libjpeg, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fl/flmsg/package.nix b/pkgs/by-name/fl/flmsg/package.nix index 510c6e4b3323cd..4dd5825472ce9a 100644 --- a/pkgs/by-name/fl/flmsg/package.nix +++ b/pkgs/by-name/fl/flmsg/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, fltk13 -, libjpeg -, pkg-config +{ + lib, + stdenv, + fetchurl, + fltk13, + libjpeg, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fl/flock/package.nix b/pkgs/by-name/fl/flock/package.nix index b427a179dc80b6..135ec03888b46e 100644 --- a/pkgs/by-name/fl/flock/package.nix +++ b/pkgs/by-name/fl/flock/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, autoreconfHook, ronn }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + ronn, +}: stdenv.mkDerivation rec { pname = "flock"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-cCpckORtogs6Nt7c5q2+z0acXAnALdLV6uzxa5ng3s4="; }; - nativeBuildInputs = [ autoreconfHook ronn ]; + nativeBuildInputs = [ + autoreconfHook + ronn + ]; patches = [ (fetchpatch { diff --git a/pkgs/by-name/fl/flockit/package.nix b/pkgs/by-name/fl/flockit/package.nix index c1df7f368043eb..9990cb899b320f 100644 --- a/pkgs/by-name/fl/flockit/package.nix +++ b/pkgs/by-name/fl/flockit/package.nix @@ -1,13 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, runtimeShell }: +{ + lib, + stdenv, + fetchFromGitHub, + runtimeShell, +}: stdenv.mkDerivation { pname = "flockit"; version = "2012-08-11"; src = fetchFromGitHub { - owner = "smerritt"; - repo = "flockit"; - rev = "5c2b2092f8edcc8e3e2eb6ef66c968675dbfa686"; + owner = "smerritt"; + repo = "flockit"; + rev = "5c2b2092f8edcc8e3e2eb6ef66c968675dbfa686"; sha256 = "0vajck9q2677gpn9a4flkyz7mw69ql1647cjwqh834nrcr2b5164"; }; diff --git a/pkgs/by-name/fl/flood/package.nix b/pkgs/by-name/fl/flood/package.nix index ada2a69e69472e..bd0529ae9cf79f 100644 --- a/pkgs/by-name/fl/flood/package.nix +++ b/pkgs/by-name/fl/flood/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, nixosTests +{ + lib, + buildNpmPackage, + fetchFromGitHub, + nixosTests, }: buildNpmPackage rec { @@ -25,7 +26,10 @@ buildNpmPackage rec { description = "Modern web UI for various torrent clients with a Node.js backend and React frontend"; homepage = "https://flood.js.org"; license = licenses.gpl3Only; - maintainers = with maintainers; [ thiagokokada winter ]; + maintainers = with maintainers; [ + thiagokokada + winter + ]; mainProgram = "flood"; }; } diff --git a/pkgs/by-name/fl/flootty/package.nix b/pkgs/by-name/fl/flootty/package.nix index 2c090556b76006..085de183216482 100644 --- a/pkgs/by-name/fl/flootty/package.nix +++ b/pkgs/by-name/fl/flootty/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "Flootty"; diff --git a/pkgs/by-name/fl/flopoco/package.nix b/pkgs/by-name/fl/flopoco/package.nix index ef6f297c63ccc0..6a12d8e1f357e5 100644 --- a/pkgs/by-name/fl/flopoco/package.nix +++ b/pkgs/by-name/fl/flopoco/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, cmake -, installShellFiles -, bison -, boost -, flex -, gmp -, libxml2 -, mpfi -, mpfr -, scalp -, sollya -, wcpg +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + cmake, + installShellFiles, + bison, + boost, + flex, + gmp, + libxml2, + mpfi, + mpfr, + scalp, + sollya, + wcpg, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fl/flottbot/package.nix b/pkgs/by-name/fl/flottbot/package.nix index 73dfe4f78a12de..0242d8f144823a 100644 --- a/pkgs/by-name/fl/flottbot/package.nix +++ b/pkgs/by-name/fl/flottbot/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script -, substituteAll +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + substituteAll, }: buildGoModule rec { pname = "flottbot"; diff --git a/pkgs/by-name/fl/flowblade/package.nix b/pkgs/by-name/fl/flowblade/package.nix index 92f035ca9018d5..7d8d724580726b 100644 --- a/pkgs/by-name/fl/flowblade/package.nix +++ b/pkgs/by-name/fl/flowblade/package.nix @@ -1,6 +1,16 @@ -{ lib, fetchFromGitHub, stdenv -, ffmpeg, frei0r, sox, gtk3, python3, ladspaPlugins -, gobject-introspection, makeWrapper, wrapGAppsHook3 +{ + lib, + fetchFromGitHub, + stdenv, + ffmpeg, + frei0r, + sox, + gtk3, + python3, + ladspaPlugins, + gobject-introspection, + makeWrapper, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -15,11 +25,28 @@ stdenv.mkDerivation rec { }; buildInputs = [ - ffmpeg frei0r sox gtk3 ladspaPlugins - (python3.withPackages (ps: with ps; [ mlt pygobject3 dbus-python numpy pillow libusb1 ])) + ffmpeg + frei0r + sox + gtk3 + ladspaPlugins + (python3.withPackages ( + ps: with ps; [ + mlt + pygobject3 + dbus-python + numpy + pillow + libusb1 + ] + )) ]; - nativeBuildInputs = [ gobject-introspection makeWrapper wrapGAppsHook3 ]; + nativeBuildInputs = [ + gobject-introspection + makeWrapper + wrapGAppsHook3 + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/fl/flowtime/package.nix b/pkgs/by-name/fl/flowtime/package.nix index d372d1d45379dd..534c57904241be 100644 --- a/pkgs/by-name/fl/flowtime/package.nix +++ b/pkgs/by-name/fl/flowtime/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, vala -, meson -, ninja -, wrapGAppsHook4 -, gst_all_1 -, libadwaita -, libxml2 -, desktop-file-utils -, pkg-config -, libportal-gtk4 -, blueprint-compiler -, appstream-glib +{ + stdenv, + lib, + fetchFromGitHub, + vala, + meson, + ninja, + wrapGAppsHook4, + gst_all_1, + libadwaita, + libxml2, + desktop-file-utils, + pkg-config, + libportal-gtk4, + blueprint-compiler, + appstream-glib, }: stdenv.mkDerivation rec { @@ -37,21 +38,26 @@ stdenv.mkDerivation rec { appstream-glib ]; - buildInputs = [ - libadwaita - libxml2 - libportal-gtk4 - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - ]); + buildInputs = + [ + libadwaita + libxml2 + libportal-gtk4 + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + ]); meta = with lib; { description = "Get what motivates you done, without losing concentration"; mainProgram = "flowtime"; homepage = "https://github.com/Diego-Ivan/Flowtime"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ foo-dogsquared pokon548 ]; + maintainers = with maintainers; [ + foo-dogsquared + pokon548 + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/fl/flpsed/package.nix b/pkgs/by-name/fl/flpsed/package.nix index 09caf3a271f3fc..479c2902902a3e 100644 --- a/pkgs/by-name/fl/flpsed/package.nix +++ b/pkgs/by-name/fl/flpsed/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fltk13, ghostscript }: +{ + lib, + stdenv, + fetchurl, + fltk13, + ghostscript, +}: stdenv.mkDerivation rec { pname = "flpsed"; diff --git a/pkgs/by-name/fl/flrig/package.nix b/pkgs/by-name/fl/flrig/package.nix index 18c4ab1c205265..7e7b9f02366712 100644 --- a/pkgs/by-name/fl/flrig/package.nix +++ b/pkgs/by-name/fl/flrig/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, fltk13 -, libjpeg -, eudev -, pkg-config +{ + lib, + stdenv, + fetchurl, + fltk13, + libjpeg, + eudev, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fl/fluent-icon-theme/package.nix b/pkgs/by-name/fl/fluent-icon-theme/package.nix index cc3253e3b1fb92..e21d608496b858 100644 --- a/pkgs/by-name/fl/fluent-icon-theme/package.nix +++ b/pkgs/by-name/fl/fluent-icon-theme/package.nix @@ -1,63 +1,80 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gtk3 -, hicolor-icon-theme -, jdupes -, roundedIcons ? false -, blackPanelIcons ? false -, allColorVariants ? false -, colorVariants ? [ ] -, +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + hicolor-icon-theme, + jdupes, + roundedIcons ? false, + blackPanelIcons ? false, + allColorVariants ? false, + colorVariants ? [ ], }: -let pname = "Fluent-icon-theme"; +let + pname = "Fluent-icon-theme"; in -lib.checkListOfEnum "${pname}: available color variants" [ "standard" "green" "grey" "orange" "pink" "purple" "red" "yellow" "teal" ] colorVariants - -stdenvNoCC.mkDerivation rec { - inherit pname; - version = "2024-02-25"; - - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = version; - hash = "sha256-Cadp2+4kBZ74kdD5x0O85FszxvN6/sg6yccxughyX1Q"; - }; - - nativeBuildInputs = [ gtk3 jdupes ]; - - buildInputs = [ hicolor-icon-theme ]; - - # Unnecessary & slow fixup's - dontPatchELF = true; - dontRewriteSymlinks = true; - dontDropIconThemeCache = true; - - postPatch = '' - patchShebangs install.sh - ''; - - installPhase = '' - runHook preInstall - - ./install.sh --dest $out/share/icons \ - --name Fluent \ - ${builtins.toString colorVariants} \ - ${lib.optionalString allColorVariants "--all"} \ - ${lib.optionalString roundedIcons "--round"} \ - ${lib.optionalString blackPanelIcons "--black"} - - jdupes --quiet --link-soft --recurse $out/share - - runHook postInstall - ''; - - meta = with lib; { - description = "Fluent icon theme for linux desktops"; - homepage = "https://github.com/vinceliuice/Fluent-icon-theme"; - license = licenses.gpl3Plus; - platforms = platforms.linux; - maintainers = with maintainers; [ icy-thought ]; - }; -} +lib.checkListOfEnum "${pname}: available color variants" + [ + "standard" + "green" + "grey" + "orange" + "pink" + "purple" + "red" + "yellow" + "teal" + ] + colorVariants + + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "2024-02-25"; + + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = version; + hash = "sha256-Cadp2+4kBZ74kdD5x0O85FszxvN6/sg6yccxughyX1Q"; + }; + + nativeBuildInputs = [ + gtk3 + jdupes + ]; + + buildInputs = [ hicolor-icon-theme ]; + + # Unnecessary & slow fixup's + dontPatchELF = true; + dontRewriteSymlinks = true; + dontDropIconThemeCache = true; + + postPatch = '' + patchShebangs install.sh + ''; + + installPhase = '' + runHook preInstall + + ./install.sh --dest $out/share/icons \ + --name Fluent \ + ${builtins.toString colorVariants} \ + ${lib.optionalString allColorVariants "--all"} \ + ${lib.optionalString roundedIcons "--round"} \ + ${lib.optionalString blackPanelIcons "--black"} + + jdupes --quiet --link-soft --recurse $out/share + + runHook postInstall + ''; + + meta = with lib; { + description = "Fluent icon theme for linux desktops"; + homepage = "https://github.com/vinceliuice/Fluent-icon-theme"; + license = licenses.gpl3Plus; + platforms = platforms.linux; + maintainers = with maintainers; [ icy-thought ]; + }; + } diff --git a/pkgs/by-name/fl/fluent-reader/package.nix b/pkgs/by-name/fl/fluent-reader/package.nix index 7be8375cecc7c7..4fc85cc3c1affa 100644 --- a/pkgs/by-name/fl/fluent-reader/package.nix +++ b/pkgs/by-name/fl/fluent-reader/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools }: +{ + lib, + fetchurl, + appimageTools, +}: let pname = "fluent-reader"; @@ -10,7 +14,8 @@ let }; appimageContents = appimageTools.extractType2 { inherit pname version src; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; extraInstallCommands = '' diff --git a/pkgs/by-name/fl/fluffychat/package.nix b/pkgs/by-name/fl/fluffychat/package.nix index fdf26abced8555..f3e0e4a0cfdcce 100644 --- a/pkgs/by-name/fl/fluffychat/package.nix +++ b/pkgs/by-name/fl/fluffychat/package.nix @@ -1,99 +1,117 @@ -{ lib -, fetchzip -, fetchFromGitHub -, imagemagick -, mesa -, libdrm -, flutter324 -, pulseaudio -, makeDesktopItem -, zenity -, olm +{ + lib, + fetchzip, + fetchFromGitHub, + imagemagick, + mesa, + libdrm, + flutter324, + pulseaudio, + makeDesktopItem, + zenity, + olm, -, targetFlutterPlatform ? "linux" + targetFlutterPlatform ? "linux", }: let - libwebrtcRpath = lib.makeLibraryPath [ mesa libdrm ]; + libwebrtcRpath = lib.makeLibraryPath [ + mesa + libdrm + ]; pubspecLock = lib.importJSON ./pubspec.lock.json; in -flutter324.buildFlutterApplication (rec { - pname = "fluffychat-${targetFlutterPlatform}"; - version = "1.22.1"; +flutter324.buildFlutterApplication ( + rec { + pname = "fluffychat-${targetFlutterPlatform}"; + version = "1.22.1"; - src = fetchFromGitHub { - owner = "krille-chan"; - repo = "fluffychat"; - rev = "refs/tags/v${version}"; - hash = "sha256-biFoRcMss3JVrMoilc8BzJ+R6f+e4RYpZ5dbxDpnfTk="; - }; + src = fetchFromGitHub { + owner = "krille-chan"; + repo = "fluffychat"; + rev = "refs/tags/v${version}"; + hash = "sha256-biFoRcMss3JVrMoilc8BzJ+R6f+e4RYpZ5dbxDpnfTk="; + }; - inherit pubspecLock; + inherit pubspecLock; - gitHashes = { - flutter_shortcuts = "sha256-4nptZ7/tM2W/zylk3rfQzxXgQ6AipFH36gcIb/0RbHo="; - keyboard_shortcuts = "sha256-U74kRujftHPvpMOIqVT0Ph+wi1ocnxNxIFA1krft4Os="; - }; + gitHashes = { + flutter_shortcuts = "sha256-4nptZ7/tM2W/zylk3rfQzxXgQ6AipFH36gcIb/0RbHo="; + keyboard_shortcuts = "sha256-U74kRujftHPvpMOIqVT0Ph+wi1ocnxNxIFA1krft4Os="; + }; - inherit targetFlutterPlatform; + inherit targetFlutterPlatform; - meta = with lib; { - description = "Chat with your friends (matrix client)"; - homepage = "https://fluffychat.im/"; - license = licenses.agpl3Plus; - mainProgram = "fluffychat"; - maintainers = with maintainers; [ mkg20001 gilice ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; - sourceProvenance = [ sourceTypes.fromSource ]; - inherit (olm.meta) knownVulnerabilities; - }; -} // lib.optionalAttrs (targetFlutterPlatform == "linux") { - nativeBuildInputs = [ imagemagick ]; + meta = with lib; { + description = "Chat with your friends (matrix client)"; + homepage = "https://fluffychat.im/"; + license = licenses.agpl3Plus; + mainProgram = "fluffychat"; + maintainers = with maintainers; [ + mkg20001 + gilice + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; + sourceProvenance = [ sourceTypes.fromSource ]; + inherit (olm.meta) knownVulnerabilities; + }; + } + // lib.optionalAttrs (targetFlutterPlatform == "linux") { + nativeBuildInputs = [ imagemagick ]; - runtimeDependencies = [ pulseaudio ]; + runtimeDependencies = [ pulseaudio ]; - extraWrapProgramArgs = "--prefix PATH : ${zenity}/bin"; + extraWrapProgramArgs = "--prefix PATH : ${zenity}/bin"; - env.NIX_LDFLAGS = "-rpath-link ${libwebrtcRpath}"; + env.NIX_LDFLAGS = "-rpath-link ${libwebrtcRpath}"; - desktopItem = makeDesktopItem { - name = "Fluffychat"; - exec = "fluffychat"; - icon = "fluffychat"; - desktopName = "Fluffychat"; - genericName = "Chat with your friends (matrix client)"; - categories = [ "Chat" "Network" "InstantMessaging" ]; - }; + desktopItem = makeDesktopItem { + name = "Fluffychat"; + exec = "fluffychat"; + icon = "fluffychat"; + desktopName = "Fluffychat"; + genericName = "Chat with your friends (matrix client)"; + categories = [ + "Chat" + "Network" + "InstantMessaging" + ]; + }; - postInstall = '' - FAV=$out/app/fluffychat-linux/data/flutter_assets/assets/favicon.png - ICO=$out/share/icons + postInstall = '' + FAV=$out/app/fluffychat-linux/data/flutter_assets/assets/favicon.png + ICO=$out/share/icons - install -D $FAV $ICO/fluffychat.png - mkdir $out/share/applications - cp $desktopItem/share/applications/*.desktop $out/share/applications - for size in 24 32 42 64 128 256 512; do - D=$ICO/hicolor/''${s}x''${s}/apps - mkdir -p $D - convert $FAV -resize ''${size}x''${size} $D/fluffychat.png - done + install -D $FAV $ICO/fluffychat.png + mkdir $out/share/applications + cp $desktopItem/share/applications/*.desktop $out/share/applications + for size in 24 32 42 64 128 256 512; do + D=$ICO/hicolor/''${s}x''${s}/apps + mkdir -p $D + convert $FAV -resize ''${size}x''${size} $D/fluffychat.png + done - patchelf --add-rpath ${libwebrtcRpath} $out/app/fluffychat-linux/lib/libwebrtc.so - ''; -} // lib.optionalAttrs (targetFlutterPlatform == "web") { - prePatch = - # https://github.com/krille-chan/fluffychat/blob/v1.17.1/scripts/prepare-web.sh - let - # Use Olm 1.3.2, the oldest version, for FluffyChat 1.14.1 which depends on olm_flutter 1.2.0. - olmVersion = pubspecLock.packages.flutter_olm.version; - olmJs = fetchzip { - url = "https://github.com/famedly/olm/releases/download/v${olmVersion}/olm.zip"; - stripRoot = false; - hash = "sha256-Vl3Cp2OaYzM5CPOOtTHtUb1W48VXePzOV6FeiIzyD1Y="; - }; - in - '' - rm -r assets/js/package - cp -r '${olmJs}/javascript' assets/js/package + patchelf --add-rpath ${libwebrtcRpath} $out/app/fluffychat-linux/lib/libwebrtc.so ''; -}) + } + // lib.optionalAttrs (targetFlutterPlatform == "web") { + prePatch = + # https://github.com/krille-chan/fluffychat/blob/v1.17.1/scripts/prepare-web.sh + let + # Use Olm 1.3.2, the oldest version, for FluffyChat 1.14.1 which depends on olm_flutter 1.2.0. + olmVersion = pubspecLock.packages.flutter_olm.version; + olmJs = fetchzip { + url = "https://github.com/famedly/olm/releases/download/v${olmVersion}/olm.zip"; + stripRoot = false; + hash = "sha256-Vl3Cp2OaYzM5CPOOtTHtUb1W48VXePzOV6FeiIzyD1Y="; + }; + in + '' + rm -r assets/js/package + cp -r '${olmJs}/javascript' assets/js/package + ''; + } +) diff --git a/pkgs/by-name/fl/flux/package.nix b/pkgs/by-name/fl/flux/package.nix index 6b5620774d3b88..2a4246b2569c0d 100644 --- a/pkgs/by-name/fl/flux/package.nix +++ b/pkgs/by-name/fl/flux/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, autoreconfHook, pkg-config }: +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + pkg-config, +}: stdenv.mkDerivation rec { pname = "flux"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "11f3ypg0sdq5kj69zgz6kih1yrzgm48r16spyvzwvlswng147410"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; meta = with lib; { description = "Interface description language used by DirectFB"; diff --git a/pkgs/by-name/fl/fluxbox/package.nix b/pkgs/by-name/fl/fluxbox/package.nix index 80c5c7a216be92..65bc41d35f15ad 100644 --- a/pkgs/by-name/fl/fluxbox/package.nix +++ b/pkgs/by-name/fl/fluxbox/package.nix @@ -1,8 +1,19 @@ -{ lib, stdenv, fetchurl, pkg-config -, freetype, fribidi -, libXext, libXft, libXpm, libXrandr, libXrender, xorgproto -, libXinerama -, imlib2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + freetype, + fribidi, + libXext, + libXft, + libXpm, + libXrandr, + libXrender, + xorgproto, + libXinerama, + imlib2, +}: stdenv.mkDerivation rec { @@ -25,7 +36,18 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ freetype fribidi libXext libXft libXpm libXrandr libXrender xorgproto libXinerama imlib2 ]; + buildInputs = [ + freetype + fribidi + libXext + libXft + libXpm + libXrandr + libXrender + xorgproto + libXinerama + imlib2 + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/fl/fluxboxlauncher/package.nix b/pkgs/by-name/fl/fluxboxlauncher/package.nix index d42179aa0a959e..511def3f70084d 100644 --- a/pkgs/by-name/fl/fluxboxlauncher/package.nix +++ b/pkgs/by-name/fl/fluxboxlauncher/package.nix @@ -1,15 +1,16 @@ -{ lib -, fetchFromGitHub -, python3 -, gtk3 -, wrapGAppsHook3 -, glibcLocales -, gobject-introspection -, gettext -, pango -, gdk-pixbuf -, atk -, fluxbox +{ + lib, + fetchFromGitHub, + python3, + gtk3, + wrapGAppsHook3, + glibcLocales, + gobject-introspection, + gettext, + pango, + gdk-pixbuf, + atk, + fluxbox, }: python3.pkgs.buildPythonApplication rec { @@ -39,8 +40,10 @@ python3.pkgs.buildPythonApplication rec { fluxbox ]; - makeWrapperArgs = [ "--set LOCALE_ARCHIVE ${glibcLocales}/lib/locale/locale-archive" - "--set CHARSET en_us.UTF-8" ]; + makeWrapperArgs = [ + "--set LOCALE_ARCHIVE ${glibcLocales}/lib/locale/locale-archive" + "--set CHARSET en_us.UTF-8" + ]; propagatedBuildInputs = with python3.pkgs; [ pygobject3 diff --git a/pkgs/by-name/fl/fluxctl/package.nix b/pkgs/by-name/fl/fluxctl/package.nix index 099ef434023548..5e2ed5b0f53e87 100644 --- a/pkgs/by-name/fl/fluxctl/package.nix +++ b/pkgs/by-name/fl/fluxctl/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "fluxctl"; @@ -19,7 +24,11 @@ buildGoModule rec { subPackages = [ "cmd/fluxctl" ]; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; postInstall = '' for shell in bash fish zsh; do @@ -33,6 +42,9 @@ buildGoModule rec { mainProgram = "fluxctl"; homepage = "https://github.com/fluxcd/flux"; license = licenses.asl20; - maintainers = with maintainers; [ Gonzih Br1ght0ne ]; + maintainers = with maintainers; [ + Gonzih + Br1ght0ne + ]; }; } diff --git a/pkgs/by-name/fl/flvstreamer/package.nix b/pkgs/by-name/fl/flvstreamer/package.nix index 64915135dd8b86..d16f0ea2395172 100644 --- a/pkgs/by-name/fl/flvstreamer/package.nix +++ b/pkgs/by-name/fl/flvstreamer/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "flvstreamer"; @@ -25,9 +29,9 @@ stdenv.mkDerivation rec { description = "Command-line RTMP client"; longDescription = '' - flvstreamer is an open source command-line RTMP client intended to - stream audio or video content from all types of flash or rtmp servers. - ''; + flvstreamer is an open source command-line RTMP client intended to + stream audio or video content from all types of flash or rtmp servers. + ''; license = lib.licenses.gpl2Plus; diff --git a/pkgs/by-name/fl/flwrap/package.nix b/pkgs/by-name/fl/flwrap/package.nix index 96c3125552d604..e1a4f93a179f17 100644 --- a/pkgs/by-name/fl/flwrap/package.nix +++ b/pkgs/by-name/fl/flwrap/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, fltk13 -, libjpeg -, pkg-config +{ + lib, + stdenv, + fetchurl, + fltk13, + libjpeg, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fl/fly/package.nix b/pkgs/by-name/fl/fly/package.nix index 792e71dd7fb8f4..67e3f25c2e01bc 100644 --- a/pkgs/by-name/fl/fly/package.nix +++ b/pkgs/by-name/fl/fly/package.nix @@ -1,4 +1,10 @@ -{ buildGoModule, fetchFromGitHub, stdenv, lib, installShellFiles }: +{ + buildGoModule, + fetchFromGitHub, + stdenv, + lib, + installShellFiles, +}: buildGoModule rec { pname = "fly"; @@ -16,7 +22,9 @@ buildGoModule rec { subPackages = [ "fly" ]; ldflags = [ - "-s" "-w" "-X github.com/concourse/concourse.Version=${version}" + "-s" + "-w" + "-X github.com/concourse/concourse.Version=${version}" ]; nativeBuildInputs = [ installShellFiles ]; @@ -35,6 +43,9 @@ buildGoModule rec { mainProgram = "fly"; homepage = "https://concourse-ci.org"; license = licenses.asl20; - maintainers = with maintainers; [ ivanbrennan SuperSandro2000 ]; + maintainers = with maintainers; [ + ivanbrennan + SuperSandro2000 + ]; }; } diff --git a/pkgs/by-name/fl/flycast/package.nix b/pkgs/by-name/fl/flycast/package.nix index 5792c3a97c3e3f..9654efa2591d53 100644 --- a/pkgs/by-name/fl/flycast/package.nix +++ b/pkgs/by-name/fl/flycast/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch2 -, cmake -, pkg-config -, makeWrapper -, alsa-lib -, curl -, libao -, libpulseaudio -, libzip -, lua -, miniupnpc -, SDL2 -, vulkan-loader +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch2, + cmake, + pkg-config, + makeWrapper, + alsa-lib, + curl, + libao, + libpulseaudio, + libzip, + lua, + miniupnpc, + SDL2, + vulkan-loader, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fl/flye/package.nix b/pkgs/by-name/fl/flye/package.nix index 95899f6a3e6e9b..c81469ea257172 100644 --- a/pkgs/by-name/fl/flye/package.nix +++ b/pkgs/by-name/fl/flye/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, python3Packages -, zlib -, curl -, libdeflate -, bash -, coreutils +{ + lib, + fetchFromGitHub, + fetchpatch, + python3Packages, + zlib, + curl, + libdeflate, + bash, + coreutils, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/fl/flywheel-cli/package.nix b/pkgs/by-name/fl/flywheel-cli/package.nix index 51600d31c51302..604d962528eb40 100644 --- a/pkgs/by-name/fl/flywheel-cli/package.nix +++ b/pkgs/by-name/fl/flywheel-cli/package.nix @@ -1,22 +1,27 @@ -{ lib -, stdenv -, fetchurl -, unzip +{ + lib, + stdenv, + fetchurl, + unzip, }: let inherit (stdenv.hostPlatform) system; throwSystem = throw "Unsupported system: ${system}"; - os = { - x86_64-darwin = "darwin"; - x86_64-linux = "linux"; - }.${system} or throwSystem; - - sha256 = { - x86_64-darwin = "sha256-OIyEu3Hsobui9s5+T9nC10SxMw0MhgmTA4SN9Ridyzo="; - x86_64-linux = "sha256-SxBjRd95hoh2zwX6IDnkZnTWVduQafPHvnWw8qTuM78="; - }.${system} or throwSystem; + os = + { + x86_64-darwin = "darwin"; + x86_64-linux = "linux"; + } + .${system} or throwSystem; + + sha256 = + { + x86_64-darwin = "sha256-OIyEu3Hsobui9s5+T9nC10SxMw0MhgmTA4SN9Ridyzo="; + x86_64-linux = "sha256-SxBjRd95hoh2zwX6IDnkZnTWVduQafPHvnWw8qTuM78="; + } + .${system} or throwSystem; in stdenv.mkDerivation rec { pname = "flywheel-cli"; @@ -46,6 +51,9 @@ stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.mit; maintainers = with maintainers; [ rbreslow ]; - platforms = [ "x86_64-darwin" "x86_64-linux" ]; + platforms = [ + "x86_64-darwin" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/fm/fm-go/package.nix b/pkgs/by-name/fm/fm-go/package.nix index 27c4867426fb3f..0983402fafb104 100644 --- a/pkgs/by-name/fm/fm-go/package.nix +++ b/pkgs/by-name/fm/fm-go/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: let diff --git a/pkgs/by-name/fm/fm-tune/package.nix b/pkgs/by-name/fm/fm-tune/package.nix index e5711af1a0a829..8240b2d652f1a1 100644 --- a/pkgs/by-name/fm/fm-tune/package.nix +++ b/pkgs/by-name/fm/fm-tune/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, liquid-dsp, soapysdr }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + liquid-dsp, + soapysdr, +}: stdenv.mkDerivation rec { pname = "fm-tune"; @@ -13,7 +20,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ liquid-dsp soapysdr ]; + buildInputs = [ + liquid-dsp + soapysdr + ]; meta = with lib; { description = "Find initial calibration offset for SDR devices"; diff --git a/pkgs/by-name/fm/fm/package.nix b/pkgs/by-name/fm/fm/package.nix index 148d949794f65d..7ec86ea86cc95f 100644 --- a/pkgs/by-name/fm/fm/package.nix +++ b/pkgs/by-name/fm/fm/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, wrapGAppsHook4 -, libadwaita -, libpanel -, gtksourceview5 -, poppler +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + wrapGAppsHook4, + libadwaita, + libpanel, + gtksourceview5, + poppler, }: rustPlatform.buildRustPackage { diff --git a/pkgs/by-name/fm/fmsynth/package.nix b/pkgs/by-name/fm/fmsynth/package.nix index 72dbd50b51b428..982504c84410c7 100644 --- a/pkgs/by-name/fm/fmsynth/package.nix +++ b/pkgs/by-name/fm/fmsynth/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, gtkmm2, lv2, lvtk, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + gtkmm2, + lv2, + lvtk, + pkg-config, +}: stdenv.mkDerivation { pname = "fmsynth-unstable"; version = "2015-02-07"; @@ -10,7 +18,11 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtkmm2 lv2 lvtk ]; + buildInputs = [ + gtkmm2 + lv2 + lvtk + ]; buildPhase = '' cd lv2 diff --git a/pkgs/by-name/fn/fn-cli/package.nix b/pkgs/by-name/fn/fn-cli/package.nix index 3b40b6b8f72531..01be247931a630 100644 --- a/pkgs/by-name/fn/fn-cli/package.nix +++ b/pkgs/by-name/fn/fn-cli/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, docker }: +{ + lib, + buildGoModule, + fetchFromGitHub, + docker, +}: buildGoModule rec { pname = "fn"; @@ -13,7 +18,7 @@ buildGoModule rec { vendorHash = null; - subPackages = ["."]; + subPackages = [ "." ]; buildInputs = [ docker diff --git a/pkgs/by-name/fn/fnotifystat/package.nix b/pkgs/by-name/fn/fnotifystat/package.nix index 28fde2629f69d4..72c1edde96c9ea 100644 --- a/pkgs/by-name/fn/fnotifystat/package.nix +++ b/pkgs/by-name/fn/fnotifystat/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fn/fnott/package.nix b/pkgs/by-name/fn/fnott/package.nix index e0069e18c8f058..40328fadb6258e 100644 --- a/pkgs/by-name/fn/fnott/package.nix +++ b/pkgs/by-name/fn/fnott/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, gitUpdater -, fetchFromGitea -, pkg-config -, meson -, ninja -, scdoc -, wayland-scanner -, fontconfig -, freetype -, pixman -, libpng -, tllist -, wayland -, wayland-protocols -, dbus -, fcft +{ + stdenv, + lib, + gitUpdater, + fetchFromGitea, + pkg-config, + meson, + ninja, + scdoc, + wayland-scanner, + fontconfig, + freetype, + pixman, + libpng, + tllist, + wayland, + wayland-protocols, + dbus, + fcft, }: stdenv.mkDerivation (finalAttrs: { @@ -61,7 +62,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://codeberg.org/dnkl/fnott"; changelog = "https://codeberg.org/dnkl/fnott/src/tag/${finalAttrs.src.rev}/CHANGELOG.md"; description = "Keyboard driven and lightweight Wayland notification daemon for wlroots-based compositors"; - license = with lib.licenses; [ mit zlib ]; + license = with lib.licenses; [ + mit + zlib + ]; maintainers = with lib.maintainers; [ jmbaur ]; diff --git a/pkgs/by-name/fn/fntsample/package.nix b/pkgs/by-name/fn/fntsample/package.nix index 6ddbace3c0b7b0..817acb4273a3cb 100644 --- a/pkgs/by-name/fn/fntsample/package.nix +++ b/pkgs/by-name/fn/fntsample/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitHub -, cmake -, pkg-config -, cairo -, fontconfig -, freetype -, glib -, libXdmcp -, makeWrapper -, pango -, pcre -, perlPackages +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + cmake, + pkg-config, + cairo, + fontconfig, + freetype, + glib, + libXdmcp, + makeWrapper, + pango, + pcre, + perlPackages, }: let @@ -36,7 +37,10 @@ stdenv.mkDerivation rec { "-DUNICODE_BLOCKS=${ucd-blocks.outPath}" ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; nativeBuildInputs = [ cmake @@ -57,17 +61,20 @@ stdenv.mkDerivation rec { postFixup = let - perlPath = with perlPackages; makePerlPath [ - ExporterTiny - ListMoreUtils - PDFAPI2 - libintl-perl - ]; - in '' - for cmd in pdfoutline pdf-extract-outline; do - wrapProgram "$out/bin/$cmd" --prefix PERL5LIB : "${perlPath}" - done - ''; + perlPath = + with perlPackages; + makePerlPath [ + ExporterTiny + ListMoreUtils + PDFAPI2 + libintl-perl + ]; + in + '' + for cmd in pdfoutline pdf-extract-outline; do + wrapProgram "$out/bin/$cmd" --prefix PERL5LIB : "${perlPath}" + done + ''; meta = with lib; { homepage = "https://github.com/eugmes/fntsample"; diff --git a/pkgs/by-name/fo/focus-stack/package.nix b/pkgs/by-name/fo/focus-stack/package.nix index 6025aa9b7a1bea..683a42192274f8 100644 --- a/pkgs/by-name/fo/focus-stack/package.nix +++ b/pkgs/by-name/fo/focus-stack/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, which -, ronn -, opencv +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + which, + ronn, + opencv, }: stdenv.mkDerivation rec { @@ -18,7 +19,11 @@ stdenv.mkDerivation rec { hash = "sha256-SoECgBMjWI+n7H6p3hf8J5E9UCLHGiiz5WAsEEioJsU="; }; - nativeBuildInputs = [ pkg-config which ronn ]; + nativeBuildInputs = [ + pkg-config + which + ronn + ]; buildInputs = [ opencv ]; makeFlags = [ "prefix=$(out)" ]; diff --git a/pkgs/by-name/fo/focus/package.nix b/pkgs/by-name/fo/focus/package.nix index 20c7e2e25d90a5..016c253eec33c0 100644 --- a/pkgs/by-name/fo/focus/package.nix +++ b/pkgs/by-name/fo/focus/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, libX11 -, libXinerama +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + libXinerama, }: stdenv.mkDerivation rec { @@ -16,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-IDiUXindzv5Ng5oCTyUlj2il/2kLvXG4YhgiYp7ZebQ="; }; - buildInputs = [ libX11 libXinerama ]; + buildInputs = [ + libX11 + libXinerama + ]; makeFlags = [ "PREFIX=\${out}" ]; diff --git a/pkgs/by-name/fo/folder-color-switcher/package.nix b/pkgs/by-name/fo/folder-color-switcher/package.nix index aa3bfe245317b7..288c6a15f80fa9 100644 --- a/pkgs/by-name/fo/folder-color-switcher/package.nix +++ b/pkgs/by-name/fo/folder-color-switcher/package.nix @@ -1,8 +1,9 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, gettext -, python3 +{ + stdenvNoCC, + lib, + fetchFromGitHub, + gettext, + python3, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/fo/foliate/package.nix b/pkgs/by-name/fo/foliate/package.nix index 956f576809a01d..ec32c78ff9ef7d 100644 --- a/pkgs/by-name/fo/foliate/package.nix +++ b/pkgs/by-name/fo/foliate/package.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, gettext -, glib -, gjs -, ninja -, gtk4 -, webkitgtk_6_0 -, gsettings-desktop-schemas -, wrapGAppsHook4 -, desktop-file-utils -, gobject-introspection -, glib-networking -, pkg-config -, libadwaita +{ + stdenv, + lib, + fetchFromGitHub, + meson, + gettext, + glib, + gjs, + ninja, + gtk4, + webkitgtk_6_0, + gsettings-desktop-schemas, + wrapGAppsHook4, + desktop-file-utils, + gobject-introspection, + glib-networking, + pkg-config, + libadwaita, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fo/folks/package.nix b/pkgs/by-name/fo/folks/package.nix index 777bef9246623e..941db4dfc8e975 100644 --- a/pkgs/by-name/fo/folks/package.nix +++ b/pkgs/by-name/fo/folks/package.nix @@ -1,26 +1,27 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, meson -, ninja -, glib -, gnome -, gettext -, gobject-introspection -, vala -, sqlite -, dbus-glib -, dbus -, libgee -, evolution-data-server-gtk4 -, python3 -, readline -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_43 -, telepathy-glib -, telepathySupport ? false +{ + stdenv, + lib, + fetchurl, + pkg-config, + meson, + ninja, + glib, + gnome, + gettext, + gobject-introspection, + vala, + sqlite, + dbus-glib, + dbus, + libgee, + evolution-data-server-gtk4, + python3, + readline, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_43, + telepathy-glib, + telepathySupport ? false, }: # TODO: enable more folks backends @@ -29,34 +30,42 @@ stdenv.mkDerivation (finalAttrs: { pname = "folks"; version = "0.15.9"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/folks/${lib.versions.majorMinor finalAttrs.version}/folks-${finalAttrs.version}.tar.xz"; hash = "sha256-IxGzc1XDUfM/Fj/cOUh0oioKBoLDGUk9bYpuQgcRQV8="; }; - nativeBuildInputs = [ - gettext - gobject-introspection - gtk-doc - docbook-xsl-nons - docbook_xml_dtd_43 - meson - ninja - pkg-config - vala - ] ++ lib.optionals telepathySupport [ - python3 - ]; + nativeBuildInputs = + [ + gettext + gobject-introspection + gtk-doc + docbook-xsl-nons + docbook_xml_dtd_43 + meson + ninja + pkg-config + vala + ] + ++ lib.optionals telepathySupport [ + python3 + ]; - buildInputs = [ - dbus-glib - evolution-data-server-gtk4 # UI part not needed, using gtk4 version to reduce system closure. - readline - ] ++ lib.optionals telepathySupport [ - telepathy-glib - ]; + buildInputs = + [ + dbus-glib + evolution-data-server-gtk4 # UI part not needed, using gtk4 version to reduce system closure. + readline + ] + ++ lib.optionals telepathySupport [ + telepathy-glib + ]; propagatedBuildInputs = [ glib @@ -66,13 +75,15 @@ stdenv.mkDerivation (finalAttrs: { nativeCheckInputs = [ dbus - (python3.withPackages (pp: with pp; [ - python-dbusmock - # The following possibly need to be propagated by dbusmock - # if they are not optional - dbus-python - pygobject3 - ])) + (python3.withPackages ( + pp: with pp; [ + python-dbusmock + # The following possibly need to be propagated by dbusmock + # if they are not optional + dbus-python + pygobject3 + ] + )) ]; mesonFlags = [ @@ -92,7 +103,8 @@ stdenv.mkDerivation (finalAttrs: { mesonCheckFlags = [ # Prevents e-d-s add-contacts-stress-test from timing out - "--timeout-multiplier" "4" + "--timeout-multiplier" + "4" ]; postPatch = lib.optionalString telepathySupport '' diff --git a/pkgs/by-name/fo/foma/package.nix b/pkgs/by-name/fo/foma/package.nix index 8c83d33ee359c1..3110f745672e75 100644 --- a/pkgs/by-name/fo/foma/package.nix +++ b/pkgs/by-name/fo/foma/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, bison, cmake, flex, pkg-config, readline, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + bison, + cmake, + flex, + pkg-config, + readline, + zlib, +}: stdenv.mkDerivation rec { pname = "foma"; @@ -13,10 +23,21 @@ stdenv.mkDerivation rec { sourceRoot = "${src.name}/foma"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ bison cmake flex pkg-config ]; - buildInputs = [ readline zlib ]; + nativeBuildInputs = [ + bison + cmake + flex + pkg-config + ]; + buildInputs = [ + readline + zlib + ]; cmakeFlags = [ # the cmake package does not handle absolute CMAKE_INSTALL_XXXDIR diff --git a/pkgs/by-name/fo/fomp/package.nix b/pkgs/by-name/fo/fomp/package.nix index 1b99041af286da..ca56e9b2502af0 100644 --- a/pkgs/by-name/fo/fomp/package.nix +++ b/pkgs/by-name/fo/fomp/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, lv2, pkg-config, python3, wafHook }: +{ + lib, + stdenv, + fetchurl, + lv2, + pkg-config, + python3, + wafHook, +}: stdenv.mkDerivation rec { pname = "fomp"; @@ -9,8 +17,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-xnGijydiO3B7BjSlryFuH1j/OPio9hCYbniq2IXp2W8="; }; - nativeBuildInputs = [ pkg-config wafHook ]; - buildInputs = [ lv2 python3 ]; + nativeBuildInputs = [ + pkg-config + wafHook + ]; + buildInputs = [ + lv2 + python3 + ]; meta = with lib; { homepage = "https://drobilla.net/software/fomp.html"; diff --git a/pkgs/by-name/fo/fondo/package.nix b/pkgs/by-name/fo/fondo/package.nix index daaeb2b74f9bc5..decb67206f7fb8 100644 --- a/pkgs/by-name/fo/fondo/package.nix +++ b/pkgs/by-name/fo/fondo/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pantheon -, vala -, pkg-config -, meson -, ninja -, python3 -, glib -, gsettings-desktop-schemas -, gtk3 -, libgee -, libhandy -, libsoup_2_4 -, json-glib -, glib-networking -, desktop-file-utils -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pantheon, + vala, + pkg-config, + meson, + ninja, + python3, + glib, + gsettings-desktop-schemas, + gtk3, + libgee, + libhandy, + libsoup_2_4, + json-glib, + glib-networking, + desktop-file-utils, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fo/font-config-info/package.nix b/pkgs/by-name/fo/font-config-info/package.nix index 20133eb0df7757..4d45eab2cf8ea0 100644 --- a/pkgs/by-name/fo/font-config-info/package.nix +++ b/pkgs/by-name/fo/font-config-info/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, gtk3 -, xsettingsd +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + gtk3, + xsettingsd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fo/font-manager/package.nix b/pkgs/by-name/fo/font-manager/package.nix index dc9b27fdd3af54..c86340595dc400 100644 --- a/pkgs/by-name/fo/font-manager/package.nix +++ b/pkgs/by-name/fo/font-manager/package.nix @@ -1,26 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, gettext -, python3 -, pkg-config -, libxml2 -, json-glib -, sqlite -, itstool -, yelp-tools -, vala -, gsettings-desktop-schemas -, gtk4 -, adwaita-icon-theme -, desktop-file-utils -, nix-update-script -, wrapGAppsHook4 -, gobject-introspection -# withWebkit enables the "webkit" feature, also known as Google Fonts -, withWebkit ? true, glib-networking, libsoup_3, webkitgtk_6_0 +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + gettext, + python3, + pkg-config, + libxml2, + json-glib, + sqlite, + itstool, + yelp-tools, + vala, + gsettings-desktop-schemas, + gtk4, + adwaita-icon-theme, + desktop-file-utils, + nix-update-script, + wrapGAppsHook4, + gobject-introspection, + # withWebkit enables the "webkit" feature, also known as Google Fonts + withWebkit ? true, + glib-networking, + libsoup_3, + webkitgtk_6_0, }: stdenv.mkDerivation rec { @@ -49,18 +53,20 @@ stdenv.mkDerivation rec { gobject-introspection ]; - buildInputs = [ - libxml2 - json-glib - sqlite - gsettings-desktop-schemas # for font settings - gtk4 - adwaita-icon-theme - ] ++ lib.optionals withWebkit [ - glib-networking # for SSL so that Google Fonts can load - libsoup_3 - webkitgtk_6_0 - ]; + buildInputs = + [ + libxml2 + json-glib + sqlite + gsettings-desktop-schemas # for font settings + gtk4 + adwaita-icon-theme + ] + ++ lib.optionals withWebkit [ + glib-networking # for SSL so that Google Fonts can load + libsoup_3 + webkitgtk_6_0 + ]; mesonFlags = [ "-Dreproducible=true" # Do not hardcode build directory… diff --git a/pkgs/by-name/fo/fontfinder/package.nix b/pkgs/by-name/fo/fontfinder/package.nix index db55b020652657..b421bf00876d1b 100644 --- a/pkgs/by-name/fo/fontfinder/package.nix +++ b/pkgs/by-name/fo/fontfinder/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cargo -, pkg-config -, rustPlatform -, rustc -, wrapGAppsHook3 -, gdk-pixbuf -, gtk3 -, libsoup_3 -, webkitgtk_4_1 +{ + lib, + stdenv, + fetchFromGitHub, + cargo, + pkg-config, + rustPlatform, + rustc, + wrapGAppsHook3, + gdk-pixbuf, + gtk3, + libsoup_3, + webkitgtk_4_1, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fo/fontpreview/package.nix b/pkgs/by-name/fo/fontpreview/package.nix index 0f02eeed17697c..b80cfd9791bc5e 100644 --- a/pkgs/by-name/fo/fontpreview/package.nix +++ b/pkgs/by-name/fo/fontpreview/package.nix @@ -1,4 +1,14 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper, xdotool, fzf, imagemagick, sxiv, getopt }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + xdotool, + fzf, + imagemagick, + sxiv, + getopt, +}: stdenv.mkDerivation rec { pname = "fontpreview"; @@ -19,7 +29,15 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/fontpreview \ - --prefix PATH : ${lib.makeBinPath [ xdotool fzf imagemagick sxiv getopt ]} + --prefix PATH : ${ + lib.makeBinPath [ + xdotool + fzf + imagemagick + sxiv + getopt + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/fo/foo2zjs/package.nix b/pkgs/by-name/fo/foo2zjs/package.nix index 91f6d98e9d559f..f1c186529c0d71 100644 --- a/pkgs/by-name/fo/foo2zjs/package.nix +++ b/pkgs/by-name/fo/foo2zjs/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, foomatic-filters, bc, ghostscript, systemd, vim, time }: +{ + lib, + stdenv, + fetchurl, + foomatic-filters, + bc, + ghostscript, + systemd, + vim, + time, +}: stdenv.mkDerivation rec { pname = "foo2zjs"; @@ -9,7 +19,13 @@ stdenv.mkDerivation rec { sha256 = "14x3wizvncdy0xgvmcx541qanwb7bg76abygqy17bxycn1zh5r1x"; }; - buildInputs = [ foomatic-filters bc ghostscript systemd vim ]; + buildInputs = [ + foomatic-filters + bc + ghostscript + systemd + vim + ]; patches = [ ./no-hardcode-fw.diff @@ -66,8 +82,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "ZjStream printer drivers"; - maintainers = with maintainers; - [ + maintainers = with maintainers; [ raskin ]; platforms = platforms.linux; diff --git a/pkgs/by-name/fo/foomatic-db-engine/package.nix b/pkgs/by-name/fo/foomatic-db-engine/package.nix index d9ae78139192ec..32ceaf6bf8fbe7 100644 --- a/pkgs/by-name/fo/foomatic-db-engine/package.nix +++ b/pkgs/by-name/fo/foomatic-db-engine/package.nix @@ -1,18 +1,19 @@ -{ lib -, perlPackages -, fetchFromGitHub -, withCupsAccess ? false # needed to access local cups server -, cups -, cups-filters -, curl -, withSocketAccess ? false # needed to access network printers -, netcat-gnu -, withSMBAccess ? false # needed to access SMB-connected printers -, samba -, autoconf -, automake -, file -, makeWrapper +{ + lib, + perlPackages, + fetchFromGitHub, + withCupsAccess ? false, # needed to access local cups server + cups, + cups-filters, + curl, + withSocketAccess ? false, # needed to access network printers + netcat-gnu, + withSMBAccess ? false, # needed to access SMB-connected printers + samba, + autoconf, + automake, + file, + makeWrapper, }: perlPackages.buildPerlPackage rec { @@ -37,20 +38,27 @@ perlPackages.buildPerlPackage rec { ]; buildInputs = - [ curl ] - # provide some "cups-*" commands to `foomatic-{configure,printjob}` - # so that they can manage a local cups server (add queues, add jobs...) - ++ lib.optionals withCupsAccess [ cups cups-filters ] - # the commands `foomatic-{configure,getpjloptions}` need - # netcat if they are used to query or alter a network - # printer via AppSocket/HP JetDirect protocol + [ curl ] + # provide some "cups-*" commands to `foomatic-{configure,printjob}` + # so that they can manage a local cups server (add queues, add jobs...) + ++ lib.optionals withCupsAccess [ + cups + cups-filters + ] + # the commands `foomatic-{configure,getpjloptions}` need + # netcat if they are used to query or alter a network + # printer via AppSocket/HP JetDirect protocol ++ lib.optional withSocketAccess netcat-gnu - # `foomatic-configure` can be used to access printers that are - # shared via the SMB protocol, but it needs the `smbclient` binary - ++ lib.optional withSMBAccess samba - ; + # `foomatic-configure` can be used to access printers that are + # shared via the SMB protocol, but it needs the `smbclient` binary + ++ lib.optional withSMBAccess samba; - nativeBuildInputs = [ autoconf automake file makeWrapper ]; + nativeBuildInputs = [ + autoconf + automake + file + makeWrapper + ]; # sed-substitute indirection is more robust against # characters in paths that might need escaping @@ -77,7 +85,7 @@ perlPackages.buildPerlPackage rec { done ''; - doCheck = false; # no tests, would fail + doCheck = false; # no tests, would fail meta = { changelog = "https://github.com/OpenPrinting/foomatic-db-engine/blob/${src.rev}/ChangeLog"; diff --git a/pkgs/by-name/fo/foomatic-db-nonfree/package.nix b/pkgs/by-name/fo/foomatic-db-nonfree/package.nix index c67362a49dee6c..6d52b503b501ba 100644 --- a/pkgs/by-name/fo/foomatic-db-nonfree/package.nix +++ b/pkgs/by-name/fo/foomatic-db-nonfree/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, perl +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + perl, }: stdenv.mkDerivation (finalAttrs: { @@ -19,7 +20,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-cRZH0CXg03FEqUJdxaNnPVXjf8+ct86PjhL59WQbw60="; }; - nativeBuildInputs = [ autoconf automake perl ]; + nativeBuildInputs = [ + autoconf + automake + perl + ]; # sed-substitute indirection is more robust against # characters in paths that might need escaping diff --git a/pkgs/by-name/fo/foomatic-db-ppds/package.nix b/pkgs/by-name/fo/foomatic-db-ppds/package.nix index bdc1e0a9b5feb3..95f0721fe6a6c0 100644 --- a/pkgs/by-name/fo/foomatic-db-ppds/package.nix +++ b/pkgs/by-name/fo/foomatic-db-ppds/package.nix @@ -1,21 +1,21 @@ -{ lib -, foomatic-db -, foomatic-db-nonfree -, buildEnv -, foomatic-db-engine -, stdenv -, cups-filters -, ghostscript -, netpbm -, perl -, psutils -, patchPpdFilesHook -, withNonfreeDb ? false # include foomatic-db-nonfree ppd files +{ + lib, + foomatic-db, + foomatic-db-nonfree, + buildEnv, + foomatic-db-engine, + stdenv, + cups-filters, + ghostscript, + netpbm, + perl, + psutils, + patchPpdFilesHook, + withNonfreeDb ? false, # include foomatic-db-nonfree ppd files }: let - foomatic-db-packages = [ foomatic-db ] ++ - lib.lists.optional withNonfreeDb foomatic-db-nonfree; + foomatic-db-packages = [ foomatic-db ] ++ lib.lists.optional withNonfreeDb foomatic-db-nonfree; foomatic-db-combined = buildEnv { name = "foomatic-db-combined"; @@ -77,12 +77,15 @@ stdenv.mkDerivation { # Comments indicate the respective # package the command is contained in. ppdFileCommands = [ - "cat" "echo" # coreutils - "foomatic-rip" # cups-filters or foomatic-filters - "gs" # ghostscript - "pnmflip" "pnmgamma" "pnmnoraw" # netpbm - "perl" # perl - "psresize" # psutils + "cat" + "echo" # coreutils + "foomatic-rip" # cups-filters or foomatic-filters + "gs" # ghostscript + "pnmflip" + "pnmgamma" + "pnmnoraw" # netpbm + "perl" # perl + "psresize" # psutils # These commands aren't packaged yet. # ppd files using these likely won't work. #"c2050" "c2070" "cjet" "lm1100" diff --git a/pkgs/by-name/fo/foomatic-db/package.nix b/pkgs/by-name/fo/foomatic-db/package.nix index d35d3915eb33f5..0c676350841179 100644 --- a/pkgs/by-name/fo/foomatic-db/package.nix +++ b/pkgs/by-name/fo/foomatic-db/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, cups -, cups-filters -, ghostscript -, gnused -, perl -, autoconf -, automake -, patchPpdFilesHook +{ + lib, + stdenv, + fetchFromGitHub, + cups, + cups-filters, + ghostscript, + gnused, + perl, + autoconf, + automake, + patchPpdFilesHook, }: stdenv.mkDerivation (finalAttrs: { @@ -24,9 +25,20 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-7vvJPhUa4oDe101Iv897LoChNIcdTa4LviLUndHxWtw="; }; - buildInputs = [ cups cups-filters ghostscript gnused perl ]; + buildInputs = [ + cups + cups-filters + ghostscript + gnused + perl + ]; - nativeBuildInputs = [ autoconf automake patchPpdFilesHook perl ]; + nativeBuildInputs = [ + autoconf + automake + patchPpdFilesHook + perl + ]; # sed-substitute indirection is more robust # against characters in paths that might need escaping @@ -63,12 +75,14 @@ stdenv.mkDerivation (finalAttrs: { # Comments indicate the respective # package the command is contained in. ppdFileCommands = [ - "cat" "date" "printf" # coreutils - "rastertohp" # cups - "foomatic-rip" # cups-filters or foomatic-filters - "gs" # ghostscript - "sed" # gnused - "perl" # perl + "cat" + "date" + "printf" # coreutils + "rastertohp" # cups + "foomatic-rip" # cups-filters or foomatic-filters + "gs" # ghostscript + "sed" # gnused + "perl" # perl ]; # compress ppd files @@ -83,7 +97,7 @@ stdenv.mkDerivation (finalAttrs: { description = "OpenPrinting printer support database (free content)"; downloadPage = "https://www.openprinting.org/download/foomatic/"; homepage = "https://openprinting.github.io/projects/02-foomatic/"; - license = lib.licenses.free; # mostly GPL and MIT, see README in source dir + license = lib.licenses.free; # mostly GPL and MIT, see README in source dir maintainers = [ lib.maintainers.yarny ]; # list printer manufacturers here so people # searching for ppd files can find this package diff --git a/pkgs/by-name/fo/foomatic-filters/package.nix b/pkgs/by-name/fo/foomatic-filters/package.nix index 600ab615d89cfd..5f69ec334aa218 100644 --- a/pkgs/by-name/fo/foomatic-filters/package.nix +++ b/pkgs/by-name/fo/foomatic-filters/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchpatch, fetchurl, pkg-config, perl, cups, dbus, enscript }: +{ + lib, + stdenv, + fetchpatch, + fetchurl, + pkg-config, + perl, + cups, + dbus, + enscript, +}: stdenv.mkDerivation rec { pname = "foomatic-filters"; @@ -10,7 +20,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ perl cups dbus enscript ]; + buildInputs = [ + perl + cups + dbus + enscript + ]; patches = [ (fetchpatch { @@ -20,10 +35,9 @@ stdenv.mkDerivation rec { }) ]; - preConfigure = - '' - substituteInPlace foomaticrip.c --replace /bin/bash ${stdenv.shell} - ''; + preConfigure = '' + substituteInPlace foomaticrip.c --replace /bin/bash ${stdenv.shell} + ''; # Workaround build failure on -fno-common toolchains like upstream # gcc-10. Otherwise build fails as: diff --git a/pkgs/by-name/fo/foonathan-memory/package.nix b/pkgs/by-name/fo/foonathan-memory/package.nix index 7e2141ef042ce8..ecfd1a226b8b4b 100644 --- a/pkgs/by-name/fo/foonathan-memory/package.nix +++ b/pkgs/by-name/fo/foonathan-memory/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, cmake -, doctest +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, + doctest, }: stdenv.mkDerivation (finalAttrs: { @@ -25,7 +26,10 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; cmakeFlags = [ (lib.cmakeBool "FOONATHAN_MEMORY_BUILD_TESTS" finalAttrs.finalPackage.doCheck) diff --git a/pkgs/by-name/fo/foot/package.nix b/pkgs/by-name/fo/foot/package.nix index d84858ad07f806..d11b75ad2d34fd 100644 --- a/pkgs/by-name/fo/foot/package.nix +++ b/pkgs/by-name/fo/foot/package.nix @@ -1,28 +1,29 @@ -{ stdenv -, lib -, fetchFromGitea -, fetchurl -, runCommand -, fcft -, freetype -, pixman -, libxkbcommon -, fontconfig -, wayland -, meson -, ninja -, ncurses -, scdoc -, tllist -, wayland-protocols -, wayland-scanner -, pkg-config -, utf8proc -, allowPgo ? !stdenv.hostPlatform.isMusl -, python3 # for PGO -# for clang stdenv check -, foot -, llvmPackages +{ + stdenv, + lib, + fetchFromGitea, + fetchurl, + runCommand, + fcft, + freetype, + pixman, + libxkbcommon, + fontconfig, + wayland, + meson, + ninja, + ncurses, + scdoc, + tllist, + wayland-protocols, + wayland-scanner, + pkg-config, + utf8proc, + allowPgo ? !stdenv.hostPlatform.isMusl, + python3, # for PGO + # for clang stdenv check + foot, + llvmPackages, }: let @@ -63,29 +64,34 @@ let ''; compilerName = - if stdenv.cc.isClang - then "clang" - else if stdenv.cc.isGNU - then "gcc" - else "unknown"; + if stdenv.cc.isClang then + "clang" + else if stdenv.cc.isGNU then + "gcc" + else + "unknown"; # https://codeberg.org/dnkl/foot/src/branch/master/INSTALL.md#performance-optimized-pgo - pgoCflags = { - "clang" = "-O3 -Wno-ignored-optimization-argument"; - "gcc" = "-O3"; - }."${compilerName}"; + pgoCflags = + { + "clang" = "-O3 -Wno-ignored-optimization-argument"; + "gcc" = "-O3"; + } + ."${compilerName}"; # ar with lto support - ar = stdenv.cc.bintools.targetPrefix + { - "clang" = "llvm-ar"; - "gcc" = "gcc-ar"; - "unknown" = "ar"; - }."${compilerName}"; + ar = + stdenv.cc.bintools.targetPrefix + + { + "clang" = "llvm-ar"; + "gcc" = "gcc-ar"; + "unknown" = "ar"; + } + ."${compilerName}"; # PGO only makes sense if we are not cross compiling and # using a compiler which foot's PGO build supports (clang or gcc) - doPgo = allowPgo && (stdenv.hostPlatform == stdenv.buildPlatform) - && compilerName != "unknown"; + doPgo = allowPgo && (stdenv.hostPlatform == stdenv.buildPlatform) && compilerName != "unknown"; terminfoDir = "${placeholder "terminfo"}/share/terminfo"; in @@ -107,16 +113,18 @@ stdenv.mkDerivation { pkg-config ]; - nativeBuildInputs = [ - wayland-scanner - meson - ninja - ncurses - scdoc - pkg-config - ] ++ lib.optionals (compilerName == "clang") [ - stdenv.cc.cc.libllvm.out - ]; + nativeBuildInputs = + [ + wayland-scanner + meson + ninja + ncurses + scdoc + pkg-config + ] + ++ lib.optionals (compilerName == "clang") [ + stdenv.cc.cc.libllvm.out + ]; buildInputs = [ tllist @@ -132,10 +140,7 @@ stdenv.mkDerivation { # recommended build flags for performance optimized foot builds # https://codeberg.org/dnkl/foot/src/branch/master/INSTALL.md#release-build - CFLAGS = - if !doPgo - then "-O3" - else pgoCflags; + CFLAGS = if !doPgo then "-O3" else pgoCflags; # ar with gcc plugins for lto objects preConfigure = '' @@ -162,20 +167,22 @@ stdenv.mkDerivation { # build and run binary generating PGO profiles, # then reconfigure to build the normal foot binary utilizing PGO - preBuild = lib.optionalString doPgo '' - meson configure -Db_pgo=generate - ninja - # make sure there is _some_ profiling data on all binaries - meson test - ./footclient --version - ./foot --version - ./utils/xtgettcap - # generate pgo data of wayland independent code - ./pgo ${stimuliFile} ${stimuliFile} ${stimuliFile} - meson configure -Db_pgo=use - '' + lib.optionalString (doPgo && compilerName == "clang") '' - llvm-profdata merge default_*profraw --output=default.profdata - ''; + preBuild = + lib.optionalString doPgo '' + meson configure -Db_pgo=generate + ninja + # make sure there is _some_ profiling data on all binaries + meson test + ./footclient --version + ./foot --version + ./utils/xtgettcap + # generate pgo data of wayland independent code + ./pgo ${stimuliFile} ${stimuliFile} ${stimuliFile} + meson configure -Db_pgo=use + '' + + lib.optionalString (doPgo && compilerName == "clang") '' + llvm-profdata merge default_*profraw --output=default.profdata + ''; # Install example themes which can be added to foot.ini via the include # directive to a separate output to save a bit of space @@ -187,7 +194,11 @@ stdenv.mkDerivation { strictDeps = true; - outputs = [ "out" "terminfo" "themes" ]; + outputs = [ + "out" + "terminfo" + "themes" + ]; passthru.tests = { clang-default-compilation = foot.override { @@ -211,7 +222,10 @@ stdenv.mkDerivation { changelog = "https://codeberg.org/dnkl/foot/releases/tag/${version}"; description = "Fast, lightweight and minimalistic Wayland terminal emulator"; license = licenses.mit; - maintainers = [ maintainers.sternenseemann maintainers.abbe ]; + maintainers = [ + maintainers.sternenseemann + maintainers.abbe + ]; platforms = platforms.linux; mainProgram = "foot"; }; diff --git a/pkgs/by-name/fo/footswitch/package.nix b/pkgs/by-name/fo/footswitch/package.nix index 5df62b1c8aae64..61d33b71761daa 100644 --- a/pkgs/by-name/fo/footswitch/package.nix +++ b/pkgs/by-name/fo/footswitch/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, hidapi }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + hidapi, +}: stdenv.mkDerivation { pname = "footswitch"; diff --git a/pkgs/by-name/fo/forbidden/package.nix b/pkgs/by-name/fo/forbidden/package.nix index 691b38291da497..783f6a3737a044 100644 --- a/pkgs/by-name/fo/forbidden/package.nix +++ b/pkgs/by-name/fo/forbidden/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/fo/foreman/gemset.nix b/pkgs/by-name/fo/foreman/gemset.nix index d5b053daf4c02c..591cc3f454b6f6 100644 --- a/pkgs/by-name/fo/foreman/gemset.nix +++ b/pkgs/by-name/fo/foreman/gemset.nix @@ -1,9 +1,9 @@ { foreman = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0szgxvnzwkzrfbq5dkwa98mig78aqglfy6irdsvq1gq045pbq9r7"; type = "gem"; }; diff --git a/pkgs/by-name/fo/foreman/package.nix b/pkgs/by-name/fo/foreman/package.nix index 8a7cfde32ee059..06cb2a3d4e9667 100644 --- a/pkgs/by-name/fo/foreman/package.nix +++ b/pkgs/by-name/fo/foreman/package.nix @@ -1,4 +1,8 @@ -{ bundlerEnv, lib, ruby }: +{ + bundlerEnv, + lib, + ruby, +}: bundlerEnv { inherit ruby; diff --git a/pkgs/by-name/fo/foremost/package.nix b/pkgs/by-name/fo/foremost/package.nix index bdf846e029d3dc..c63afde7ced92d 100644 --- a/pkgs/by-name/fo/foremost/package.nix +++ b/pkgs/by-name/fo/foremost/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "foremost"; diff --git a/pkgs/by-name/fo/forge-sparks/package.nix b/pkgs/by-name/fo/forge-sparks/package.nix index ca7c38d343f60e..b7e3180a02a355 100644 --- a/pkgs/by-name/fo/forge-sparks/package.nix +++ b/pkgs/by-name/fo/forge-sparks/package.nix @@ -1,20 +1,21 @@ -{ lib -, blueprint-compiler -, desktop-file-utils -, fetchFromGitHub -, gjs -, glib -, glib-networking -, gtk4 -, libadwaita -, libportal -, libsecret -, libsoup_3 -, meson -, ninja -, pkg-config -, stdenv -, wrapGAppsHook4 +{ + lib, + blueprint-compiler, + desktop-file-utils, + fetchFromGitHub, + gjs, + glib, + glib-networking, + gtk4, + libadwaita, + libportal, + libsecret, + libsoup_3, + meson, + ninja, + pkg-config, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/fo/forge/package.nix b/pkgs/by-name/fo/forge/package.nix index 051038c747875c..da70604c2f7592 100644 --- a/pkgs/by-name/fo/forge/package.nix +++ b/pkgs/by-name/fo/forge/package.nix @@ -1,20 +1,21 @@ -{ boost -, cmake -, expat -, fetchFromGitHub -, fontconfig -, freeimage -, freetype -, glfw3 -, glm -, lib -, libGLU -, libGL -, mesa -, opencl-clhpp -, pkg-config -, stdenv -, SDL2 +{ + boost, + cmake, + expat, + fetchFromGitHub, + fontconfig, + freeimage, + freetype, + glfw3, + glm, + lib, + libGLU, + libGL, + mesa, + opencl-clhpp, + pkg-config, + stdenv, + SDL2, }: stdenv.mkDerivation rec { @@ -77,6 +78,9 @@ stdenv.mkDerivation rec { license = licenses.bsd3; homepage = "https://arrayfire.com/"; platforms = platforms.linux; - maintainers = with maintainers; [ chessai twesterhout ]; + maintainers = with maintainers; [ + chessai + twesterhout + ]; }; } diff --git a/pkgs/by-name/fo/forgejo/generic.nix b/pkgs/by-name/fo/forgejo/generic.nix index 18bc5790cb4ba8..3ca4393aace9b4 100644 --- a/pkgs/by-name/fo/forgejo/generic.nix +++ b/pkgs/by-name/fo/forgejo/generic.nix @@ -1,29 +1,31 @@ -{ lts ? false -, version -, rev ? "refs/tags/v${version}" -, hash -, npmDepsHash -, vendorHash -, nixUpdateExtraArgs ? [ ] +{ + lts ? false, + version, + rev ? "refs/tags/v${version}", + hash, + npmDepsHash, + vendorHash, + nixUpdateExtraArgs ? [ ], }: -{ bash -, brotli -, buildGoModule -, forgejo -, git -, gzip -, lib -, makeWrapper -, nix-update-script -, nixosTests -, openssh -, sqliteSupport ? true -, xorg -, runCommand -, stdenv -, fetchFromGitea -, buildNpmPackage +{ + bash, + brotli, + buildGoModule, + forgejo, + git, + gzip, + lib, + makeWrapper, + nix-update-script, + nixosTests, + openssh, + sqliteSupport ? true, + xorg, + runCommand, + stdenv, + fetchFromGitea, + buildNpmPackage, }: let @@ -56,11 +58,17 @@ buildGoModule rec { version src vendorHash - ; + ; - subPackages = [ "." "contrib/environment-to-ini" ]; + subPackages = [ + "." + "contrib/environment-to-ini" + ]; - outputs = [ "out" "data" ]; + outputs = [ + "out" + "data" + ]; nativeBuildInputs = [ makeWrapper @@ -79,7 +87,10 @@ buildGoModule rec { substituteInPlace modules/setting/server.go --subst-var data ''; - tags = lib.optionals sqliteSupport [ "sqlite" "sqlite_unlock_notify" ]; + tags = lib.optionals sqliteSupport [ + "sqlite" + "sqlite_unlock_notify" + ]; ldflags = [ "-s" @@ -124,29 +135,44 @@ buildGoModule rec { mkdir -p $out cp -R ./options/locale $out/locale wrapProgram $out/bin/gitea \ - --prefix PATH : ${lib.makeBinPath [ bash git gzip openssh ]} + --prefix PATH : ${ + lib.makeBinPath [ + bash + git + gzip + openssh + ] + } ''; # $data is not available in goModules.drv - overrideModAttrs = (_: { - postPatch = null; - }); + overrideModAttrs = ( + _: { + postPatch = null; + } + ); passthru = { # allow nix-update to handle npmDepsHash inherit (frontend) npmDeps; - data-compressed = runCommand "forgejo-data-compressed" { - nativeBuildInputs = [ brotli xorg.lndir ]; - } '' - mkdir $out - lndir ${forgejo.data}/ $out/ - - # Create static gzip and brotli files - find -L $out -type f -regextype posix-extended -iregex '.*\.(css|html|js|svg|ttf|txt)' \ - -exec gzip --best --keep --force {} ';' \ - -exec brotli --best --keep --no-copy-stat {} ';' - ''; + data-compressed = + runCommand "forgejo-data-compressed" + { + nativeBuildInputs = [ + brotli + xorg.lndir + ]; + } + '' + mkdir $out + lndir ${forgejo.data}/ $out/ + + # Create static gzip and brotli files + find -L $out -type f -regextype posix-extended -iregex '.*\.(css|html|js|svg|ttf|txt)' \ + -exec gzip --best --keep --force {} ';' \ + -exec brotli --best --keep --no-copy-stat {} ';' + ''; tests = if lts then nixosTests.forgejo-lts else nixosTests.forgejo; @@ -163,7 +189,13 @@ buildGoModule rec { homepage = "https://forgejo.org"; changelog = "https://codeberg.org/forgejo/forgejo/releases/tag/v${version}"; license = if lib.versionAtLeast version "9.0.0" then lib.licenses.gpl3Plus else lib.licenses.mit; - maintainers = with lib.maintainers; [ emilylange urandom bendlas adamcstephens marie ]; + maintainers = with lib.maintainers; [ + emilylange + urandom + bendlas + adamcstephens + marie + ]; broken = stdenv.hostPlatform.isDarwin; mainProgram = "gitea"; }; diff --git a/pkgs/by-name/fo/forkstat/package.nix b/pkgs/by-name/fo/forkstat/package.nix index 8454987343b0fd..f1a4305e306bde 100644 --- a/pkgs/by-name/fo/forkstat/package.nix +++ b/pkgs/by-name/fo/forkstat/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "forkstat"; diff --git a/pkgs/by-name/fo/forktty/package.nix b/pkgs/by-name/fo/forktty/package.nix index 72403688613801..0e6d763dd963ec 100644 --- a/pkgs/by-name/fo/forktty/package.nix +++ b/pkgs/by-name/fo/forktty/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "forktty"; @@ -18,7 +22,10 @@ stdenv.mkDerivation rec { mkdir -p "$out/share/man/man8" ''; - makeFlags = [ "prefix=$(out)" "manprefix=$(out)/share/" ]; + makeFlags = [ + "prefix=$(out)" + "manprefix=$(out)/share/" + ]; meta = with lib; { description = "Tool to detach from controlling TTY and attach to another"; diff --git a/pkgs/by-name/fo/form/package.nix b/pkgs/by-name/fo/form/package.nix index 3c5569f116d81f..b8a55c074cc69a 100644 --- a/pkgs/by-name/fo/form/package.nix +++ b/pkgs/by-name/fo/form/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, gmp, zlib }: +{ + lib, + stdenv, + fetchurl, + gmp, + zlib, +}: stdenv.mkDerivation { version = "4.3.1"; @@ -10,7 +16,10 @@ stdenv.mkDerivation { sha256 = "sha256-8fUS3DT+m71rGfLf7wX8uZEt+0PINop1t5bsRy7ou84="; }; - buildInputs = [ gmp zlib ]; + buildInputs = [ + gmp + zlib + ]; meta = with lib; { description = "FORM project for symbolic manipulation of very big expressions"; diff --git a/pkgs/by-name/fo/formatter/package.nix b/pkgs/by-name/fo/formatter/package.nix index e56ee22c506e8c..744a0499707a45 100644 --- a/pkgs/by-name/fo/formatter/package.nix +++ b/pkgs/by-name/fo/formatter/package.nix @@ -1,22 +1,24 @@ -{ lib, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, vala -, pkg-config -, pantheon -, python3 -, substituteAll -, glib -, gtk3 -, dosfstools -, e2fsprogs -, exfat -, hfsprogs -, ntfs3g -, libgee -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + vala, + pkg-config, + pantheon, + python3, + substituteAll, + glib, + gtk3, + dosfstools, + e2fsprogs, + exfat, + hfsprogs, + ntfs3g, + libgee, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fo/fornalder/package.nix b/pkgs/by-name/fo/fornalder/package.nix index c7774a60cf2b9e..84b88da240fe97 100644 --- a/pkgs/by-name/fo/fornalder/package.nix +++ b/pkgs/by-name/fo/fornalder/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, makeWrapper, gnuplot }: +{ + lib, + rustPlatform, + fetchFromGitHub, + makeWrapper, + gnuplot, +}: rustPlatform.buildRustPackage rec { pname = "fornalder"; @@ -24,7 +30,10 @@ rustPlatform.buildRustPackage rec { description = "Visualize long-term trends in collections of Git repositories"; homepage = "https://github.com/hpjansson/fornalder"; license = licenses.gpl3Only; - maintainers = with maintainers; [ astro figsoda ]; + maintainers = with maintainers; [ + astro + figsoda + ]; mainProgram = "fornalder"; }; } diff --git a/pkgs/by-name/fo/fortify-headers/package.nix b/pkgs/by-name/fo/fortify-headers/package.nix index 1f418af7ae9628..bb3c55484444c1 100644 --- a/pkgs/by-name/fo/fortify-headers/package.nix +++ b/pkgs/by-name/fo/fortify-headers/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation { @@ -11,7 +12,7 @@ stdenv.mkDerivation { # extract from the alpine package src = fetchurl { url = "https://dl-cdn.alpinelinux.org/alpine/v3.18/main/x86_64/fortify-headers-1.1-r3.apk"; - name = "fortify-headers.tar.gz"; # ensure it's extracted as a .tar.gz + name = "fortify-headers.tar.gz"; # ensure it's extracted as a .tar.gz hash = "sha256-8A8JcKHIBgXpUuIP4zs3Q1yBs5jCGd5F3H2E8UN/S2g="; }; diff --git a/pkgs/by-name/fo/fortran-fpm/package.nix b/pkgs/by-name/fo/fortran-fpm/package.nix index 40e92dd68e84a2..157306707812ab 100644 --- a/pkgs/by-name/fo/fortran-fpm/package.nix +++ b/pkgs/by-name/fo/fortran-fpm/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchurl -, pkgs -, stdenv +{ + lib, + fetchurl, + pkgs, + stdenv, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fo/fortune-kind/package.nix b/pkgs/by-name/fo/fortune-kind/package.nix index bea0bec5c4035f..295dde7c680596 100644 --- a/pkgs/by-name/fo/fortune-kind/package.nix +++ b/pkgs/by-name/fo/fortune-kind/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, darwin -, libiconv -, makeBinaryWrapper -, installShellFiles -, fortuneAlias ? true +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, + libiconv, + makeBinaryWrapper, + installShellFiles, + fortuneAlias ? true, }: rustPlatform.buildRustPackage rec { @@ -22,8 +23,14 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-hxbvsAQsZWUAgj8QAlcxqBA5YagLO3/vz9lQGJMHUjw="; - nativeBuildInputs = [ makeBinaryWrapper installShellFiles ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv darwin.apple_sdk.frameworks.Security ]; + nativeBuildInputs = [ + makeBinaryWrapper + installShellFiles + ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + darwin.apple_sdk.frameworks.Security + ]; buildNoDefaultFeatures = true; @@ -43,12 +50,14 @@ rustPlatform.buildRustPackage rec { cp -r $src/fortunes $out/fortunes; ''; - postInstall = '' - wrapProgram $out/bin/fortune-kind \ - --prefix FORTUNE_DIR : "$out/fortunes" - ''+ lib.optionalString fortuneAlias '' - ln -s fortune-kind $out/bin/fortune - ''; + postInstall = + '' + wrapProgram $out/bin/fortune-kind \ + --prefix FORTUNE_DIR : "$out/fortunes" + '' + + lib.optionalString fortuneAlias '' + ln -s fortune-kind $out/bin/fortune + ''; meta = with lib; { description = "Kinder, curated fortune, written in rust"; diff --git a/pkgs/by-name/fo/fortune/package.nix b/pkgs/by-name/fo/fortune/package.nix index 4df5e1fd1aae31..b71940e5e8666f 100644 --- a/pkgs/by-name/fo/fortune/package.nix +++ b/pkgs/by-name/fo/fortune/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, cmake, recode, perl, rinutils, withOffensive ? false }: +{ + lib, + stdenv, + fetchurl, + cmake, + recode, + perl, + rinutils, + withOffensive ? false, +}: stdenv.mkDerivation rec { pname = "fortune-mod"; @@ -11,7 +20,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-BpMhu01K46v1VJPQQ86gZTTck/Giwp6GaU2e2xOAoOM="; }; - nativeBuildInputs = [ cmake perl rinutils ]; + nativeBuildInputs = [ + cmake + perl + rinutils + ]; buildInputs = [ recode ]; @@ -19,22 +32,24 @@ stdenv.mkDerivation rec { "-DLOCALDIR=${placeholder "out"}/share/fortunes" ] ++ lib.optional (!withOffensive) "-DNO_OFFENSIVE=true"; - patches = [ (builtins.toFile "not-a-game.patch" '' - diff --git a/CMakeLists.txt b/CMakeLists.txt - index 865e855..5a59370 100644 - --- a/CMakeLists.txt - +++ b/CMakeLists.txt - @@ -154,7 +154,7 @@ ENDMACRO() - my_exe( - "fortune" - "fortune/fortune.c" - - "games" - + "bin" - ) - - my_exe( - -- - '') ]; + patches = [ + (builtins.toFile "not-a-game.patch" '' + diff --git a/CMakeLists.txt b/CMakeLists.txt + index 865e855..5a59370 100644 + --- a/CMakeLists.txt + +++ b/CMakeLists.txt + @@ -154,7 +154,7 @@ ENDMACRO() + my_exe( + "fortune" + "fortune/fortune.c" + - "games" + + "bin" + ) + + my_exe( + -- + '') + ]; postFixup = lib.optionalString (!withOffensive) '' rm $out/share/games/fortunes/men-women* diff --git a/pkgs/by-name/fo/foxtrotgps/package.nix b/pkgs/by-name/fo/foxtrotgps/package.nix index bb9049dde79190..43e176471a5c64 100644 --- a/pkgs/by-name/fo/foxtrotgps/package.nix +++ b/pkgs/by-name/fo/foxtrotgps/package.nix @@ -1,6 +1,22 @@ -{ lib, stdenv, fetchbzr, autoreconfHook, texinfo, help2man, imagemagick, pkg-config -, curl, gnome2, gpsd, gtk2, wrapGAppsHook3 -, intltool, libexif, python3Packages, sqlite }: +{ + lib, + stdenv, + fetchbzr, + autoreconfHook, + texinfo, + help2man, + imagemagick, + pkg-config, + curl, + gnome2, + gpsd, + gtk2, + wrapGAppsHook3, + intltool, + libexif, + python3Packages, + sqlite, +}: let srcs = { @@ -15,7 +31,8 @@ let sha256 = "1sgysn3dhfhrv7rj7wf8f2119vmhc1s1zzsp4r3nlrr45d20wmsv"; }; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "foxtrotgps"; version = "1.2.2+331"; @@ -23,8 +40,13 @@ in stdenv.mkDerivation rec { src = srcs.foxtrot; nativeBuildInputs = [ - pkg-config autoreconfHook texinfo help2man - imagemagick wrapGAppsHook3 intltool + pkg-config + autoreconfHook + texinfo + help2man + imagemagick + wrapGAppsHook3 + intltool ]; buildInputs = [ @@ -34,8 +56,13 @@ in stdenv.mkDerivation rec { gtk2.dev libexif sqlite.dev - (python3Packages.python.withPackages (pythonPackages: with python3Packages; - [ beautifulsoup4 feedparser sqlalchemy ])) + (python3Packages.python.withPackages ( + pythonPackages: with python3Packages; [ + beautifulsoup4 + feedparser + sqlalchemy + ] + )) ]; postUnpack = '' diff --git a/pkgs/by-name/fp/fparser/package.nix b/pkgs/by-name/fp/fparser/package.nix index 73db0575d0b1b6..389b0e5b88eb48 100644 --- a/pkgs/by-name/fp/fparser/package.nix +++ b/pkgs/by-name/fp/fparser/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fp/fpart/package.nix b/pkgs/by-name/fp/fpart/package.nix index fe58413443f262..e026291b47b497 100644 --- a/pkgs/by-name/fp/fpart/package.nix +++ b/pkgs/by-name/fp/fpart/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, fts }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + fts, +}: stdenv.mkDerivation rec { pname = "fpart"; diff --git a/pkgs/by-name/fp/fpattern/package.nix b/pkgs/by-name/fp/fpattern/package.nix index e1b75f025c89f7..9ece75ba435cfe 100644 --- a/pkgs/by-name/fp/fpattern/package.nix +++ b/pkgs/by-name/fp/fpattern/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation (finalAttrs: { version = "1.9"; diff --git a/pkgs/by-name/fp/fped/package.nix b/pkgs/by-name/fp/fped/package.nix index dbfeb69c6bfaee..b227dd8bb428b3 100644 --- a/pkgs/by-name/fp/fped/package.nix +++ b/pkgs/by-name/fp/fped/package.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchgit -, flex, bison, fig2dev, imagemagick, netpbm, gtk2 -, pkg-config +{ + lib, + stdenv, + fetchgit, + flex, + bison, + fig2dev, + imagemagick, + netpbm, + gtk2, + pkg-config, }: stdenv.mkDerivation { @@ -43,7 +51,7 @@ stdenv.mkDerivation { mainProgram = "fped"; homepage = "http://projects.qi-hardware.com/index.php/p/fped/"; license = licenses.gpl2; - maintainers = []; + maintainers = [ ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/fp/fpm2/package.nix b/pkgs/by-name/fp/fpm2/package.nix index e59322a51c9d61..c3106ef1bdfc6f 100644 --- a/pkgs/by-name/fp/fpm2/package.nix +++ b/pkgs/by-name/fp/fpm2/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, gnupg, gtk3 -, libxml2, intltool, nettle +{ + lib, + stdenv, + fetchurl, + pkg-config, + gnupg, + gtk3, + libxml2, + intltool, + nettle, }: stdenv.mkDerivation rec { @@ -11,15 +19,23 @@ stdenv.mkDerivation rec { sha256 = "1lfzja3vzd6l6hfvw8gvg4qkl5iy6gra5pa8gjlps9l63k2bjfhz"; }; - nativeBuildInputs = [ pkg-config intltool ]; - buildInputs = [ gnupg gtk3 libxml2 nettle ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; + buildInputs = [ + gnupg + gtk3 + libxml2 + nettle + ]; meta = with lib; { description = "GTK2 port from Figaro's Password Manager originally developed by John Conneely, with some new enhancements"; mainProgram = "fpm2"; - homepage = "https://als.regnet.cz/fpm2/"; - license = licenses.gpl2Plus; - platforms = platforms.linux; + homepage = "https://als.regnet.cz/fpm2/"; + license = licenses.gpl2Plus; + platforms = platforms.linux; maintainers = with maintainers; [ hce ]; }; } diff --git a/pkgs/by-name/fp/fpp/package.nix b/pkgs/by-name/fp/fpp/package.nix index d8f575b1363b1d..c065782c33eab4 100644 --- a/pkgs/by-name/fp/fpp/package.nix +++ b/pkgs/by-name/fp/fpp/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, python3, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "fpp"; diff --git a/pkgs/by-name/fp/fprettify/package.nix b/pkgs/by-name/fp/fprettify/package.nix index 1a424c5f57c1e9..5443dcf9647f12 100644 --- a/pkgs/by-name/fp/fprettify/package.nix +++ b/pkgs/by-name/fp/fprettify/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "fprettify"; diff --git a/pkgs/by-name/fq/fq/package.nix b/pkgs/by-name/fq/fq/package.nix index 4b9560f72e5ccf..b870fe1f41d47f 100644 --- a/pkgs/by-name/fq/fq/package.nix +++ b/pkgs/by-name/fq/fq/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fq -, testers +{ + lib, + buildGoModule, + fetchFromGitHub, + fq, + testers, }: buildGoModule rec { diff --git a/pkgs/by-name/fr/fractal/package.nix b/pkgs/by-name/fr/fractal/package.nix index ba81763a8e476c..2f4de32f470c10 100644 --- a/pkgs/by-name/fr/fractal/package.nix +++ b/pkgs/by-name/fr/fractal/package.nix @@ -1,28 +1,29 @@ -{ stdenv -, lib -, fetchFromGitLab -, nix-update-script -, cargo -, meson -, ninja -, rustPlatform -, rustc -, pkg-config -, glib -, gtk4 -, gtksourceview5 -, libadwaita -, gst_all_1 -, desktop-file-utils -, appstream-glib -, openssl -, pipewire -, libshumate -, wrapGAppsHook4 -, sqlite -, xdg-desktop-portal -, libseccomp -, glycin-loaders +{ + stdenv, + lib, + fetchFromGitLab, + nix-update-script, + cargo, + meson, + ninja, + rustPlatform, + rustc, + pkg-config, + glib, + gtk4, + gtksourceview5, + libadwaita, + gst_all_1, + desktop-file-utils, + appstream-glib, + openssl, + pipewire, + libshumate, + wrapGAppsHook4, + sqlite, + xdg-desktop-portal, + libseccomp, + glycin-loaders, }: stdenv.mkDerivation rec { @@ -68,23 +69,25 @@ stdenv.mkDerivation rec { wrapGAppsHook4 ]; - buildInputs = [ - glib - gtk4 - gtksourceview5 - libadwaita - openssl - pipewire - libshumate - sqlite - xdg-desktop-portal - libseccomp - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-bad - gst-plugins-good - ]); + buildInputs = + [ + glib + gtk4 + gtksourceview5 + libadwaita + openssl + pipewire + libshumate + sqlite + xdg-desktop-portal + libseccomp + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-bad + gst-plugins-good + ]); preFixup = '' gappsWrapperArgs+=( diff --git a/pkgs/by-name/fr/framac/package.nix b/pkgs/by-name/fr/framac/package.nix index f682196a458f0b..f145ecf985881c 100644 --- a/pkgs/by-name/fr/framac/package.nix +++ b/pkgs/by-name/fr/framac/package.nix @@ -1,7 +1,16 @@ -{ lib, stdenv, fetchurl, writeText -, graphviz, doxygen -, ocamlPackages, ltl2ba, coq, why3 -, gdk-pixbuf, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + writeText, + graphviz, + doxygen, + ocamlPackages, + ltl2ba, + coq, + why3, + gdk-pixbuf, + wrapGAppsHook3, }: let @@ -38,10 +47,10 @@ in stdenv.mkDerivation rec { pname = "frama-c"; version = "29.0"; - slang = "Copper"; + slang = "Copper"; src = fetchurl { - url = "https://frama-c.com/download/frama-c-${version}-${slang}.tar.gz"; + url = "https://frama-c.com/download/frama-c-${version}-${slang}.tar.gz"; hash = "sha256-0vuzuND/g5RYcunm+iWOk0pwY2DmmNrjtNX5ca3fdJM="; }; @@ -53,13 +62,36 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ wrapGAppsHook3 ] ++ (with ocamlPackages; [ ocaml findlib dune_3 menhir ]); + nativeBuildInputs = + [ wrapGAppsHook3 ] + ++ (with ocamlPackages; [ + ocaml + findlib + dune_3 + menhir + ]); buildInputs = with ocamlPackages; [ - dune-site dune-configurator - ltl2ba ocamlgraph yojson menhirLib camlzip - lablgtk3 lablgtk3-sourceview3 coq graphviz zarith apron why3 mlgmpidl doxygen - ppx_deriving ppx_import ppx_deriving_yaml ppx_deriving_yojson + dune-site + dune-configurator + ltl2ba + ocamlgraph + yojson + menhirLib + camlzip + lablgtk3 + lablgtk3-sourceview3 + coq + graphviz + zarith + apron + why3 + mlgmpidl + doxygen + ppx_deriving + ppx_import + ppx_deriving_yaml + ppx_deriving_yojson gdk-pixbuf unionFind ]; @@ -73,7 +105,7 @@ stdenv.mkDerivation rec { installFlags = [ "PREFIX=$(out)" ]; preFixup = '' - gappsWrapperArgs+=(--prefix OCAMLPATH ':' ${ocamlpath}:$out/lib/) + gappsWrapperArgs+=(--prefix OCAMLPATH ':' ${ocamlpath}:$out/lib/) ''; # Allow loading of external Frama-C plugins @@ -97,12 +129,14 @@ stdenv.mkDerivation rec { addEnvHooks "$targetOffset" addFramaCPath ''; - meta = { description = "Extensible and collaborative platform dedicated to source-code analysis of C software"; - homepage = "http://frama-c.com/"; - license = lib.licenses.lgpl21; - maintainers = with lib.maintainers; [ thoughtpolice amiddelk ]; - platforms = lib.platforms.unix; + homepage = "http://frama-c.com/"; + license = lib.licenses.lgpl21; + maintainers = with lib.maintainers; [ + thoughtpolice + amiddelk + ]; + platforms = lib.platforms.unix; }; } diff --git a/pkgs/by-name/fr/frame/package.nix b/pkgs/by-name/fr/frame/package.nix index e56ce1e684169d..e7c06a2d34e51c 100644 --- a/pkgs/by-name/fr/frame/package.nix +++ b/pkgs/by-name/fr/frame/package.nix @@ -1,5 +1,11 @@ -{ enableX11 ? true -, lib, stdenv, fetchurl, pkg-config, xorg }: +{ + enableX11 ? true, + lib, + stdenv, + fetchurl, + pkg-config, + xorg, +}: stdenv.mkDerivation rec { pname = "frame"; @@ -10,9 +16,16 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - stdenv - ] ++ lib.optionals enableX11 [xorg.xorgserver xorg.libX11 xorg.libXext xorg.libXi]; + buildInputs = + [ + stdenv + ] + ++ lib.optionals enableX11 [ + xorg.xorgserver + xorg.libX11 + xorg.libXext + xorg.libXi + ]; configureFlags = lib.optional enableX11 "--with-x11"; diff --git a/pkgs/by-name/fr/framesh/package.nix b/pkgs/by-name/fr/framesh/package.nix index 2ec358bc06e570..5cc572eeac8271 100644 --- a/pkgs/by-name/fr/framesh/package.nix +++ b/pkgs/by-name/fr/framesh/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, appimageTools, makeWrapper }: +{ + lib, + fetchurl, + appimageTools, + makeWrapper, +}: let pname = "framesh"; diff --git a/pkgs/by-name/fr/framework-tool/package.nix b/pkgs/by-name/fr/framework-tool/package.nix index b3797ff56293f4..743b0ad84ae59c 100644 --- a/pkgs/by-name/fr/framework-tool/package.nix +++ b/pkgs/by-name/fr/framework-tool/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, pkg-config, udev }: +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + udev, +}: rustPlatform.buildRustPackage { pname = "framework-tool"; @@ -17,8 +23,7 @@ rustPlatform.buildRustPackage { cargoLock = { lockFile = ./Cargo.lock; outputHashes = { - "smbios-lib-0.9.1" = - "sha256-3L8JaA75j9Aaqg1z9lVs61m6CvXDeQprEFRq+UDCHQo="; + "smbios-lib-0.9.1" = "sha256-3L8JaA75j9Aaqg1z9lVs61m6CvXDeQprEFRq+UDCHQo="; "uefi-0.20.0" = "sha256-/3WNHuc27N89M7s+WT64SHyFOp7YRyzz6B+neh1vejY="; }; }; @@ -31,7 +36,11 @@ rustPlatform.buildRustPackage { homepage = "https://github.com/FrameworkComputer/framework-system"; license = licenses.bsd3; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ nickcao leona kloenk ]; + maintainers = with maintainers; [ + nickcao + leona + kloenk + ]; mainProgram = "framework_tool"; }; } diff --git a/pkgs/by-name/fr/frangipanni/package.nix b/pkgs/by-name/fr/frangipanni/package.nix index f95c6b4f16369f..1a0711f1bf6c41 100644 --- a/pkgs/by-name/fr/frangipanni/package.nix +++ b/pkgs/by-name/fr/frangipanni/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "frangipanni"; diff --git a/pkgs/by-name/fr/frankenphp/package.nix b/pkgs/by-name/fr/frankenphp/package.nix index 9cae030df83917..d4ad0287e797e9 100644 --- a/pkgs/by-name/fr/frankenphp/package.nix +++ b/pkgs/by-name/fr/frankenphp/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, php -, brotli -, testers -, frankenphp -, cctools -, darwin -, libiconv -, pkg-config -, makeBinaryWrapper -, runCommand -, writeText +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + php, + brotli, + testers, + frankenphp, + cctools, + darwin, + libiconv, + pkg-config, + makeBinaryWrapper, + runCommand, + writeText, }: let @@ -26,7 +27,8 @@ let phpUnwrapped = phpEmbedWithZts.unwrapped; phpConfig = "${phpUnwrapped.dev}/bin/php-config"; pieBuild = stdenv.hostPlatform.isMusl; -in buildGoModule rec { +in +buildGoModule rec { pname = "frankenphp"; version = "1.2.5"; @@ -44,30 +46,46 @@ in buildGoModule rec { proxyVendor = true; vendorHash = "sha256-U2B0ok6TgqUPMwlnkzpPkJLG22S3VpoU80bWwZAeaJo="; - buildInputs = [ phpUnwrapped brotli ] ++ phpUnwrapped.buildInputs; - nativeBuildInputs = [ makeBinaryWrapper ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ pkg-config cctools darwin.autoSignDarwinBinariesHook ]; + buildInputs = [ + phpUnwrapped + brotli + ] ++ phpUnwrapped.buildInputs; + nativeBuildInputs = + [ makeBinaryWrapper ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + pkg-config + cctools + darwin.autoSignDarwinBinariesHook + ]; subPackages = [ "frankenphp" ]; - tags = [ "cgo" "netgo" "ousergo" "static_build" ]; + tags = [ + "cgo" + "netgo" + "ousergo" + "static_build" + ]; ldflags = [ "-s" "-w" "-X 'github.com/caddyserver/caddy/v2.CustomVersion=FrankenPHP ${version} PHP ${phpUnwrapped.version} Caddy'" # pie mode is only available with pkgsMusl, it also automatically add -buildmode=pie to $GOFLAGS - ] ++ (lib.optional pieBuild [ "-static-pie" ]); + ] ++ (lib.optional pieBuild [ "-static-pie" ]); - preBuild = '' - export CGO_CFLAGS="$(${phpConfig} --includes)" - export CGO_LDFLAGS="-DFRANKENPHP_VERSION=${version} \ - $(${phpConfig} --ldflags) \ - $(${phpConfig} --libs)" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # replace hard-code homebrew path - substituteInPlace ../frankenphp.go \ - --replace "-L/opt/homebrew/opt/libiconv/lib" "-L${libiconv}/lib" - ''; + preBuild = + '' + export CGO_CFLAGS="$(${phpConfig} --includes)" + export CGO_LDFLAGS="-DFRANKENPHP_VERSION=${version} \ + $(${phpConfig} --ldflags) \ + $(${phpConfig} --libs)" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # replace hard-code homebrew path + substituteInPlace ../frankenphp.go \ + --replace "-L/opt/homebrew/opt/libiconv/lib" "-L${libiconv}/lib" + ''; preFixup = '' mkdir -p $out/lib @@ -87,13 +105,16 @@ in buildGoModule rec { package = frankenphp; command = "frankenphp version"; }; - phpinfo = runCommand "php-cli-phpinfo" { - phpScript = writeText "phpinfo.php" '' - $out - ''; + phpinfo = + runCommand "php-cli-phpinfo" + { + phpScript = writeText "phpinfo.php" '' + $out + ''; }; }; @@ -103,7 +124,10 @@ in buildGoModule rec { homepage = "https://github.com/dunglas/frankenphp"; license = lib.licenses.mit; mainProgram = "frankenphp"; - maintainers = with lib.maintainers; [ gaelreyrol shyim ]; + maintainers = with lib.maintainers; [ + gaelreyrol + shyim + ]; platforms = lib.platforms.linux ++ lib.platforms.darwin; }; } diff --git a/pkgs/by-name/fr/fraunces/package.nix b/pkgs/by-name/fr/fraunces/package.nix index d74e84a570d339..b7a7fb225f30cc 100644 --- a/pkgs/by-name/fr/fraunces/package.nix +++ b/pkgs/by-name/fr/fraunces/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "fraunces"; diff --git a/pkgs/by-name/fr/frawk/package.nix b/pkgs/by-name/fr/frawk/package.nix index bec04f7db3d566..57f3a44fbfd923 100644 --- a/pkgs/by-name/fr/frawk/package.nix +++ b/pkgs/by-name/fr/frawk/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchCrate -, libxml2 -, ncurses -, zlib -, features ? [ "default" ] -, llvmPackages_12 +{ + lib, + rustPlatform, + fetchCrate, + libxml2, + ncurses, + zlib, + features ? [ "default" ], + llvmPackages_12, }: rustPlatform.buildRustPackage rec { @@ -19,16 +20,22 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Xk+iH90Nb2koCdGmVSiRl8Nq26LlFdJBuKmvcbgnkgs="; - buildInputs = [ libxml2 ncurses zlib ]; + buildInputs = [ + libxml2 + ncurses + zlib + ]; buildNoDefaultFeatures = true; buildFeatures = features; - preBuild = lib.optionalString (lib.elem "default" features || lib.elem "llvm_backend" features) '' - export LLVM_SYS_120_PREFIX=${llvmPackages_12.llvm.dev} - '' + lib.optionalString (lib.elem "default" features || lib.elem "unstable" features) '' - export RUSTC_BOOTSTRAP=1 - ''; + preBuild = + lib.optionalString (lib.elem "default" features || lib.elem "llvm_backend" features) '' + export LLVM_SYS_120_PREFIX=${llvmPackages_12.llvm.dev} + '' + + lib.optionalString (lib.elem "default" features || lib.elem "unstable" features) '' + export RUSTC_BOOTSTRAP=1 + ''; # depends on cpu instructions that may not be available on builders doCheck = false; @@ -38,7 +45,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "frawk"; homepage = "https://github.com/ezrosent/frawk"; changelog = "https://github.com/ezrosent/frawk/releases/tag/v${version}"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/fr/fre/package.nix b/pkgs/by-name/fr/fre/package.nix index 6953a630eb4e32..b2679d2a536230 100644 --- a/pkgs/by-name/fr/fre/package.nix +++ b/pkgs/by-name/fr/fre/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "fre"; diff --git a/pkgs/by-name/fr/freac/package.nix b/pkgs/by-name/fr/freac/package.nix index 6f4df5a433aaea..15f374baf8bb2b 100644 --- a/pkgs/by-name/fr/freac/package.nix +++ b/pkgs/by-name/fr/freac/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, -, boca -, smooth -, systemd + boca, + smooth, + systemd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fr/frece/package.nix b/pkgs/by-name/fr/frece/package.nix index c8bc63e3dcb725..dc1e97dd756d9e 100644 --- a/pkgs/by-name/fr/frece/package.nix +++ b/pkgs/by-name/fr/frece/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "frece"; diff --git a/pkgs/by-name/fr/free42/package.nix b/pkgs/by-name/fr/free42/package.nix index d9197e9d667e94..ee1be3804755c7 100644 --- a/pkgs/by-name/fr/free42/package.nix +++ b/pkgs/by-name/fr/free42/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, alsa-lib -, copyDesktopItems -, gtk3 -, makeDesktopItem -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + alsa-lib, + copyDesktopItems, + gtk3, + makeDesktopItem, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { @@ -43,7 +44,10 @@ stdenv.mkDerivation (finalAttrs: { exec = "free42bin"; type = "Application"; comment = "A software clone of HP-42S Calculator"; - categories = [ "Utility" "Calculator" ]; + categories = [ + "Utility" + "Calculator" + ]; }) (makeDesktopItem { name = "com.thomasokken.free42dec"; @@ -52,7 +56,10 @@ stdenv.mkDerivation (finalAttrs: { exec = "free42dec"; type = "Application"; comment = "A software clone of HP-42S Calculator"; - categories = [ "Utility" "Calculator" ]; + categories = [ + "Utility" + "Calculator" + ]; }) ]; diff --git a/pkgs/by-name/fr/freealut/package.nix b/pkgs/by-name/fr/freealut/package.nix index 2f98b1c8e7a279..cdf35d400a18ba 100644 --- a/pkgs/by-name/fr/freealut/package.nix +++ b/pkgs/by-name/fr/freealut/package.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, darwin, fetchurl, openal -, testers +{ + lib, + stdenv, + darwin, + fetchurl, + openal, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -11,10 +16,9 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "0kzlil6112x2429nw6mycmif8y6bxr2cwjcvp18vh6s7g63ymlb0"; }; - buildInputs = [ openal - ] ++ lib.optional stdenv.hostPlatform.isDarwin - darwin.apple_sdk.frameworks.OpenAL - ; + buildInputs = [ + openal + ] ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.OpenAL; passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; diff --git a/pkgs/by-name/fr/freebayes/package.nix b/pkgs/by-name/fr/freebayes/package.nix index 0ceaab4ab46bed..8d8b832d5a4716 100644 --- a/pkgs/by-name/fr/freebayes/package.nix +++ b/pkgs/by-name/fr/freebayes/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, zlib, bzip2, xz }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + bzip2, + xz, +}: stdenv.mkDerivation rec { pname = "freebayes"; @@ -6,14 +13,18 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { name = "freebayes-${version}-src"; - owner = "ekg"; - repo = "freebayes"; - rev = "v${version}"; + owner = "ekg"; + repo = "freebayes"; + rev = "v${version}"; sha256 = "035nriknjqq8gvil81vvsmvqwi35v80q8h1cw24vd1gdyn1x7bys"; fetchSubmodules = true; }; - buildInputs = [ zlib bzip2 xz ]; + buildInputs = [ + zlib + bzip2 + xz + ]; # Workaround build failure on -fno-common toolchains like upstream # gcc-10. Otherwise build fails as: @@ -27,8 +38,8 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Bayesian haplotype-based polymorphism discovery and genotyping"; - license = licenses.mit; - homepage = "https://github.com/ekg/freebayes"; + license = licenses.mit; + homepage = "https://github.com/ekg/freebayes"; maintainers = with maintainers; [ jdagilliland ]; platforms = [ "x86_64-linux" ]; }; diff --git a/pkgs/by-name/fr/freebind/package.nix b/pkgs/by-name/fr/freebind/package.nix index 661bfd8e2664ad..9a52b8180c7aa5 100644 --- a/pkgs/by-name/fr/freebind/package.nix +++ b/pkgs/by-name/fr/freebind/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, libnetfilter_queue, libnfnetlink }: +{ + lib, + stdenv, + fetchFromGitHub, + libnetfilter_queue, + libnfnetlink, +}: stdenv.mkDerivation { pname = "freebind"; @@ -11,7 +17,10 @@ stdenv.mkDerivation { sha256 = "1iv2xiz9w8hbz684caw50fn4a9vc8ninfgaqafkh9sa8mzpfzcqr"; }; - buildInputs = [ libnetfilter_queue libnfnetlink ]; + buildInputs = [ + libnetfilter_queue + libnfnetlink + ]; postPatch = '' substituteInPlace preloader.c --replace /usr/local/ $out/ diff --git a/pkgs/by-name/fr/freecell-solver/package.nix b/pkgs/by-name/fr/freecell-solver/package.nix index c7a1dc5f2a4aad..22d87b53fd05ee 100644 --- a/pkgs/by-name/fr/freecell-solver/package.nix +++ b/pkgs/by-name/fr/freecell-solver/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, cmake -, cmocka -, gmp -, gperf -, libtap -, ninja -, perl -, pkg-config -, python3 -, rinutils +{ + lib, + stdenv, + fetchurl, + cmake, + cmocka, + gmp, + gperf, + libtap, + ninja, + perl, + pkg-config, + python3, + rinutils, }: stdenv.mkDerivation (finalAttrs: { @@ -22,7 +23,12 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-oriegEzkuRjvdJAxZ2IQ8glf6jqMsSmAVgKEPHxIhKA="; }; - outputs = [ "out" "dev" "doc" "man" ]; + outputs = [ + "out" + "dev" + "doc" + "man" + ]; pythonPath = with python3.pkgs; [ cffi @@ -31,27 +37,32 @@ stdenv.mkDerivation (finalAttrs: { six ]; - nativeBuildInputs = [ - cmake - cmocka - gperf - ninja - perl - pkg-config - python3 - ] - ++ (with perl.pkgs; TaskFreecellSolverTesting.buildInputs ++ [ - GamesSolitaireVerify - HTMLTemplate - Moo - PathTiny - StringShellQuote - TaskFreecellSolverTesting - TemplateToolkit - TextTemplate - ]) - ++ [ python3.pkgs.wrapPython ] - ++ finalAttrs.pythonPath; + nativeBuildInputs = + [ + cmake + cmocka + gperf + ninja + perl + pkg-config + python3 + ] + ++ ( + with perl.pkgs; + TaskFreecellSolverTesting.buildInputs + ++ [ + GamesSolitaireVerify + HTMLTemplate + Moo + PathTiny + StringShellQuote + TaskFreecellSolverTesting + TemplateToolkit + TextTemplate + ] + ) + ++ [ python3.pkgs.wrapPython ] + ++ finalAttrs.pythonPath; buildInputs = [ gmp diff --git a/pkgs/by-name/fr/freedink/package.nix b/pkgs/by-name/fr/freedink/package.nix index 5f03f084dd77f9..9513a1dee521ce 100644 --- a/pkgs/by-name/fr/freedink/package.nix +++ b/pkgs/by-name/fr/freedink/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchurl, SDL, SDL_mixer, SDL_image, SDL_ttf, SDL_gfx -, pkg-config, intltool, fontconfig, libzip, zip, zlib }: +{ + lib, + stdenv, + fetchurl, + SDL, + SDL_mixer, + SDL_image, + SDL_ttf, + SDL_gfx, + pkg-config, + intltool, + fontconfig, + libzip, + zip, + zlib, +}: let version = "1.08.20121209"; @@ -16,7 +30,8 @@ let prePatch = "substituteInPlace Makefile --replace /usr/local $out"; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "freedink"; inherit version; @@ -25,11 +40,21 @@ in stdenv.mkDerivation rec { sha256 = "19xximbcm6506kvpf3s0q96697kmzca3yrjdr6dgphklp33zqsqr"; }; - nativeBuildInputs = [ pkg-config intltool ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; buildInputs = [ - SDL SDL_mixer SDL_image SDL_ttf SDL_gfx - fontconfig libzip zip zlib + SDL + SDL_mixer + SDL_image + SDL_ttf + SDL_gfx + fontconfig + libzip + zip + zlib ]; preConfigure = '' diff --git a/pkgs/by-name/fr/freedroid/package.nix b/pkgs/by-name/fr/freedroid/package.nix index 130b02997b59a6..cb32804c2fc50b 100644 --- a/pkgs/by-name/fr/freedroid/package.nix +++ b/pkgs/by-name/fr/freedroid/package.nix @@ -1,27 +1,47 @@ -{ lib, stdenv -, fetchFromGitHub -, makeDesktopItem, copyDesktopItems -, imagemagick -, autoreconfHook -, SDL, SDL_mixer, SDL_image, SDL_gfx -, libvorbis -, libjpeg, libpng -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + imagemagick, + autoreconfHook, + SDL, + SDL_mixer, + SDL_image, + SDL_gfx, + libvorbis, + libjpeg, + libpng, + zlib, }: stdenv.mkDerivation rec { - pname = "freedroid"; + pname = "freedroid"; version = "1.2.1"; src = fetchFromGitHub { - owner = "ReinhardPrix"; - repo = "FreedroidClassic"; - rev = "release-${version}"; + owner = "ReinhardPrix"; + repo = "FreedroidClassic"; + rev = "release-${version}"; sha256 = "027wns25nyyc8afyhyp5a8wn13x9nlzmnqzqyyma1055xjy5imis"; }; - nativeBuildInputs = [ copyDesktopItems imagemagick autoreconfHook ]; - buildInputs = [ SDL SDL_image SDL_gfx SDL_mixer libjpeg libpng libvorbis zlib ]; + nativeBuildInputs = [ + copyDesktopItems + imagemagick + autoreconfHook + ]; + buildInputs = [ + SDL + SDL_image + SDL_gfx + SDL_mixer + libjpeg + libpng + libvorbis + zlib + ]; postPatch = '' touch NEWS @@ -32,23 +52,28 @@ stdenv.mkDerivation rec { convert graphics/paraicon.bmp $out/share/icons/hicolor/32x32/apps/freedroid.png ''; - desktopItems = [ (makeDesktopItem { - name = pname; - exec = pname; - icon = pname; - desktopName = "Freedroid Classic"; - comment = "A clone of the classic game 'Paradroid' on Commodore 64"; - categories = [ "Game" "ArcadeGame" ]; - }) ]; + desktopItems = [ + (makeDesktopItem { + name = pname; + exec = pname; + icon = pname; + desktopName = "Freedroid Classic"; + comment = "A clone of the classic game 'Paradroid' on Commodore 64"; + categories = [ + "Game" + "ArcadeGame" + ]; + }) + ]; meta = with lib; { description = "Clone of the classic game 'Paradroid' on Commodore 64"; mainProgram = "freedroid"; - homepage = "https://github.com/ReinhardPrix/FreedroidClassic"; - license = licenses.gpl2Only; + homepage = "https://github.com/ReinhardPrix/FreedroidClassic"; + license = licenses.gpl2Only; maintainers = with maintainers; [ iblech ]; - platforms = platforms.unix; + platforms = platforms.unix; # Builds but fails to render to the screen at runtime. - broken = stdenv.hostPlatform.isDarwin; + broken = stdenv.hostPlatform.isDarwin; }; } diff --git a/pkgs/by-name/fr/freedroidrpg/package.nix b/pkgs/by-name/fr/freedroidrpg/package.nix index 8c9b3e0cbf0d75..9be15316e687c7 100644 --- a/pkgs/by-name/fr/freedroidrpg/package.nix +++ b/pkgs/by-name/fr/freedroidrpg/package.nix @@ -1,8 +1,28 @@ -{ fetchurl, lib, stdenv, pkg-config, gettext, glew, python3, SDL, SDL_image, SDL_gfx, SDL_mixer, libogg, libvorbis, lua5_3, libjpeg, libpng, zlib, libiconv }: +{ + fetchurl, + lib, + stdenv, + pkg-config, + gettext, + glew, + python3, + SDL, + SDL_image, + SDL_gfx, + SDL_mixer, + libogg, + libvorbis, + lua5_3, + libjpeg, + libpng, + zlib, + libiconv, +}: let version = "1.0"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "freedroidrpg"; inherit version; @@ -16,10 +36,24 @@ in stdenv.mkDerivation { ./drop-build-deps.patch ]; - nativeBuildInputs = [ pkg-config gettext python3 ]; + nativeBuildInputs = [ + pkg-config + gettext + python3 + ]; buildInputs = [ - glew SDL SDL_image SDL_gfx SDL_mixer libogg libvorbis lua5_3 libjpeg libpng zlib + glew + SDL + SDL_image + SDL_gfx + SDL_mixer + libogg + libvorbis + lua5_3 + libjpeg + libpng + zlib ] ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; enableParallelBuilding = true; diff --git a/pkgs/by-name/fr/freefont_ttf/package.nix b/pkgs/by-name/fr/freefont_ttf/package.nix index 4bf50d33858798..b1c2494dd70f88 100644 --- a/pkgs/by-name/fr/freefont_ttf/package.nix +++ b/pkgs/by-name/fr/freefont_ttf/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "freefont-ttf"; diff --git a/pkgs/by-name/fr/freeglut/package.nix b/pkgs/by-name/fr/freeglut/package.nix index 590167fc70361a..ca0f1923098f21 100644 --- a/pkgs/by-name/fr/freeglut/package.nix +++ b/pkgs/by-name/fr/freeglut/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchurl, libICE, libXext, libXi, libXrandr, libXxf86vm, libGLX, libGLU, cmake -, testers +{ + lib, + stdenv, + fetchurl, + libICE, + libXext, + libXi, + libXrandr, + libXxf86vm, + libGLX, + libGLU, + cmake, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -11,18 +22,28 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-nD1NZRb7+gKA7ck8d2mPtzA+RDwaqvN9Jp4yiKbD6lI="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ libICE libXext libXi libXrandr libXxf86vm libGLU ]; + buildInputs = [ + libICE + libXext + libXi + libXrandr + libXxf86vm + libGLU + ]; cmakeFlags = lib.optionals stdenv.hostPlatform.isDarwin [ - "-DOPENGL_INCLUDE_DIR=${libGLX.dev}/include" - "-DOPENGL_gl_LIBRARY:FILEPATH=${libGLX}/lib/libGL.dylib" - "-DOPENGL_glu_LIBRARY:FILEPATH=${libGLU}/lib/libGLU.dylib" - "-DFREEGLUT_BUILD_DEMOS:BOOL=OFF" - "-DFREEGLUT_BUILD_STATIC:BOOL=OFF" - ]; + "-DOPENGL_INCLUDE_DIR=${libGLX.dev}/include" + "-DOPENGL_gl_LIBRARY:FILEPATH=${libGLX}/lib/libGL.dylib" + "-DOPENGL_glu_LIBRARY:FILEPATH=${libGLU}/lib/libGLU.dylib" + "-DFREEGLUT_BUILD_DEMOS:BOOL=OFF" + "-DFREEGLUT_BUILD_STATIC:BOOL=OFF" + ]; passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; diff --git a/pkgs/by-name/fr/freeipmi/package.nix b/pkgs/by-name/fr/freeipmi/package.nix index 4c3a0db590ac9c..d1a4a16c53663d 100644 --- a/pkgs/by-name/fr/freeipmi/package.nix +++ b/pkgs/by-name/fr/freeipmi/package.nix @@ -1,4 +1,12 @@ -{ buildPackages, fetchurl, lib, stdenv, libgcrypt, readline, libgpg-error }: +{ + buildPackages, + fetchurl, + lib, + stdenv, + libgcrypt, + readline, + libgpg-error, +}: stdenv.mkDerivation rec { version = "1.6.14"; @@ -11,10 +19,16 @@ stdenv.mkDerivation rec { depsBuildBuild = [ buildPackages.stdenv.cc ]; - buildInputs = [ libgcrypt readline libgpg-error ]; + buildInputs = [ + libgcrypt + readline + libgpg-error + ]; - configureFlags = lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) - [ "ac_cv_file__dev_urandom=true" "ac_cv_file__dev_random=true" ]; + configureFlags = lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "ac_cv_file__dev_urandom=true" + "ac_cv_file__dev_random=true" + ]; doCheck = true; @@ -41,6 +55,6 @@ stdenv.mkDerivation rec { license = lib.licenses.gpl3Plus; maintainers = with lib.maintainers; [ raskin ]; - platforms = lib.platforms.gnu ++ lib.platforms.linux; # arbitrary choice + platforms = lib.platforms.gnu ++ lib.platforms.linux; # arbitrary choice }; } diff --git a/pkgs/by-name/fr/freenukum/package.nix b/pkgs/by-name/fr/freenukum/package.nix index e0f90773810e6c..19a787fe4fcf4b 100644 --- a/pkgs/by-name/fr/freenukum/package.nix +++ b/pkgs/by-name/fr/freenukum/package.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, rustPlatform -, fetchFromGitLab -, makeDesktopItem -, installShellFiles -, dejavu_fonts -, SDL2 -, SDL2_ttf -, SDL2_image +{ + lib, + stdenv, + rustPlatform, + fetchFromGitLab, + makeDesktopItem, + installShellFiles, + dejavu_fonts, + SDL2, + SDL2_ttf, + SDL2_image, }: let pname = "freenukum"; @@ -18,7 +20,11 @@ let exec = pname; icon = pname; comment = description; - categories = [ "Game" "ArcadeGame" "ActionGame" ]; + categories = [ + "Game" + "ArcadeGame" + "ActionGame" + ]; genericName = pname; }; diff --git a/pkgs/by-name/fr/freepats/package.nix b/pkgs/by-name/fr/freepats/package.nix index bb8dae0cf6a5b5..fd39872ea1c525 100644 --- a/pkgs/by-name/fr/freepats/package.nix +++ b/pkgs/by-name/fr/freepats/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "freepats"; diff --git a/pkgs/by-name/fr/freepv/package.nix b/pkgs/by-name/fr/freepv/package.nix index 1ff0fd5146df0d..82132fc3f677ea 100644 --- a/pkgs/by-name/fr/freepv/package.nix +++ b/pkgs/by-name/fr/freepv/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, libjpeg -, libGLU -, libGL -, libglut -, zlib -, cmake -, libX11 -, libxml2 -, libpng -, libXxf86vm +{ + lib, + stdenv, + fetchurl, + libjpeg, + libGLU, + libGL, + libglut, + zlib, + cmake, + libX11, + libxml2, + libpng, + libXxf86vm, }: stdenv.mkDerivation rec { @@ -23,7 +24,17 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libjpeg libGLU libGL libglut zlib libX11 libxml2 libpng libXxf86vm ]; + buildInputs = [ + libjpeg + libGLU + libGL + libglut + zlib + libX11 + libxml2 + libpng + libXxf86vm + ]; postPatch = '' sed -i -e '/GECKO/d' CMakeLists.txt diff --git a/pkgs/by-name/fr/freeradius/package.nix b/pkgs/by-name/fr/freeradius/package.nix index c8464086902162..d24c66fe1be905 100644 --- a/pkgs/by-name/fr/freeradius/package.nix +++ b/pkgs/by-name/fr/freeradius/package.nix @@ -1,23 +1,37 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, bsd-finger -, perl -, talloc -, linkOpenssl ? true, openssl -, withCap ? true, libcap -, withCollectd ? false, collectd -, withJson ? false, json_c -, withLdap ? true, openldap -, withMemcached ? false, libmemcached -, withMysql ? false, libmysqlclient -, withPostgresql ? false, postgresql -, withPcap ? true, libpcap -, withRedis ? false, hiredis -, withRest ? false, curl -, withSqlite ? true, sqlite -, withYubikey ? false, libyubikey +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + bsd-finger, + perl, + talloc, + linkOpenssl ? true, + openssl, + withCap ? true, + libcap, + withCollectd ? false, + collectd, + withJson ? false, + json_c, + withLdap ? true, + openldap, + withMemcached ? false, + libmemcached, + withMysql ? false, + libmysqlclient, + withPostgresql ? false, + postgresql, + withPcap ? true, + libpcap, + withRedis ? false, + hiredis, + withRest ? false, + curl, + withSqlite ? true, + sqlite, + withYubikey ? false, + libyubikey, }: assert withRest -> withJson; @@ -35,7 +49,13 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ openssl talloc bsd-finger perl ] + buildInputs = + [ + openssl + talloc + bsd-finger + perl + ] ++ lib.optional withCap libcap ++ lib.optional withCollectd collectd ++ lib.optional withJson json_c @@ -74,13 +94,21 @@ stdenv.mkDerivation rec { "INSTALL_CERT_FILES=" # see comment at makeFlags ]; - outputs = [ "out" "dev" "man" "doc" ]; + outputs = [ + "out" + "dev" + "man" + "doc" + ]; meta = with lib; { homepage = "https://freeradius.org/"; description = "Modular, high performance free RADIUS suite"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ sheenobu willibutz ]; + maintainers = with maintainers; [ + sheenobu + willibutz + ]; platforms = with platforms; linux; }; } diff --git a/pkgs/by-name/fr/freesweep/package.nix b/pkgs/by-name/fr/freesweep/package.nix index 5e658947e80398..7ade52101f7cd6 100644 --- a/pkgs/by-name/fr/freesweep/package.nix +++ b/pkgs/by-name/fr/freesweep/package.nix @@ -1,5 +1,11 @@ -{ fetchFromGitHub, ncurses, lib, stdenv -, updateAutotoolsGnuConfigScriptsHook, installShellFiles }: +{ + fetchFromGitHub, + ncurses, + lib, + stdenv, + updateAutotoolsGnuConfigScriptsHook, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "freesweep"; @@ -12,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-iuu81yHbNrjdPsimBrPK58PJ0d8i3ySM7rFUG/d8NJM"; }; - nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook installShellFiles ]; + nativeBuildInputs = [ + updateAutotoolsGnuConfigScriptsHook + installShellFiles + ]; buildInputs = [ ncurses ]; configureFlags = [ "--with-prefsdir=$out/share" ]; diff --git a/pkgs/by-name/fr/freetalk/package.nix b/pkgs/by-name/fr/freetalk/package.nix index b71395ad93bb02..7c1f9c00c5d4b8 100644 --- a/pkgs/by-name/fr/freetalk/package.nix +++ b/pkgs/by-name/fr/freetalk/package.nix @@ -1,7 +1,22 @@ -{ lib, stdenv, fetchurl -, guile, pkg-config, glib, loudmouth, gmp, libidn, readline, libtool -, libunwind, ncurses, curl, jansson, texinfo -, argp-standalone }: +{ + lib, + stdenv, + fetchurl, + guile, + pkg-config, + glib, + loudmouth, + gmp, + libidn, + readline, + libtool, + libunwind, + ncurses, + curl, + jansson, + texinfo, + argp-standalone, +}: stdenv.mkDerivation rec { pname = "freetalk"; version = "4.2"; @@ -11,20 +26,34 @@ stdenv.mkDerivation rec { hash = "sha256-u1tPKacGry+JGYeAIgDia3N7zs5EM4FyQZdV8e7htYA="; }; - nativeBuildInputs = [ pkg-config texinfo ]; - buildInputs = [ - guile glib loudmouth gmp libidn readline libtool - libunwind ncurses curl jansson - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - argp-standalone + nativeBuildInputs = [ + pkg-config + texinfo ]; + buildInputs = + [ + guile + glib + loudmouth + gmp + libidn + readline + libtool + libunwind + ncurses + curl + jansson + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + argp-standalone + ]; env.NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin "-largp"; meta = with lib; { - description = "Console XMPP client"; + description = "Console XMPP client"; mainProgram = "freetalk"; - license = licenses.gpl3Plus ; + license = licenses.gpl3Plus; maintainers = with maintainers; [ raskin ]; platforms = platforms.unix; downloadPage = "https://www.gnu.org/software/freetalk/"; diff --git a/pkgs/by-name/fr/freetds/package.nix b/pkgs/by-name/fr/freetds/package.nix index c1d8fd62497ffb..2038fd47d78c32 100644 --- a/pkgs/by-name/fr/freetds/package.nix +++ b/pkgs/by-name/fr/freetds/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pkg-config -, openssl -, odbcSupport ? true, unixODBC ? null }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + openssl, + odbcSupport ? true, + unixODBC ? null, +}: assert odbcSupport -> unixODBC != null; @@ -11,22 +18,25 @@ stdenv.mkDerivation rec { version = "1.4.23"; src = fetchurl { - url = "https://www.freetds.org/files/stable/${pname}-${version}.tar.bz2"; - hash = "sha256-k6PxhrgsYEKmahlwvUeNeRTtscVmm2QtgLTqrPKi0X4="; + url = "https://www.freetds.org/files/stable/${pname}-${version}.tar.bz2"; + hash = "sha256-k6PxhrgsYEKmahlwvUeNeRTtscVmm2QtgLTqrPKi0X4="; }; buildInputs = [ openssl ] ++ lib.optional odbcSupport unixODBC; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; meta = with lib; { description = "Libraries to natively talk to Microsoft SQL Server and Sybase databases"; - homepage = "https://www.freetds.org"; - changelog = "https://github.com/FreeTDS/freetds/releases/tag/v${version}"; - license = licenses.lgpl2; + homepage = "https://www.freetds.org"; + changelog = "https://github.com/FreeTDS/freetds/releases/tag/v${version}"; + license = licenses.lgpl2; maintainers = with maintainers; [ peterhoeg ]; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/fr/freetts/package.nix b/pkgs/by-name/fr/freetts/package.nix index 8f6fbad6d4d648..3d7c810ad7abcf 100644 --- a/pkgs/by-name/fr/freetts/package.nix +++ b/pkgs/by-name/fr/freetts/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchzip -, ant -, jdk8 -, sharutils -, stripJavaArchivesHook +{ + lib, + stdenv, + fetchzip, + ant, + jdk8, + sharutils, + stripJavaArchivesHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/fr/freetype/package.nix b/pkgs/by-name/fr/freetype/package.nix index 034ba4c3383955..a1644a35a3fb64 100644 --- a/pkgs/by-name/fr/freetype/package.nix +++ b/pkgs/by-name/fr/freetype/package.nix @@ -1,55 +1,69 @@ -{ lib -, stdenv -, fetchurl -, buildPackages -, pkgsHostHost -, pkg-config -, which -, makeWrapper -, zlib -, bzip2 -, brotli -, libpng -, gnumake -, glib - -, # FreeType supports LCD filtering (colloquially referred to as sub-pixel rendering). +{ + lib, + stdenv, + fetchurl, + buildPackages, + pkgsHostHost, + pkg-config, + which, + makeWrapper, + zlib, + bzip2, + brotli, + libpng, + gnumake, + glib, + + # FreeType supports LCD filtering (colloquially referred to as sub-pixel rendering). # LCD filtering is also known as ClearType and covered by several Microsoft patents. # This option allows it to be disabled. See http://www.freetype.org/patents.html. - useEncumberedCode ? true + useEncumberedCode ? true, # for passthru.tests -, cairo -, fontforge -, ghostscript -, graphicsmagick -, gtk3 -, harfbuzz -, imagemagick -, pango -, poppler -, python3 -, qt5 -, texmacs -, ttfautohint -, testers -, __flattenIncludeHackHook + cairo, + fontforge, + ghostscript, + graphicsmagick, + gtk3, + harfbuzz, + imagemagick, + pango, + poppler, + python3, + qt5, + texmacs, + ttfautohint, + testers, + __flattenIncludeHackHook, }: - stdenv.mkDerivation (finalAttrs: { pname = "freetype"; version = "2.13.3"; - src = let inherit (finalAttrs) pname version; in fetchurl { - url = "mirror://savannah/${pname}/${pname}-${version}.tar.xz"; - sha256 = "sha256-BVA1BmbUJ8dNrrhdWse7NTrLpfdpVjlZlTEanG8GMok="; - }; - - propagatedBuildInputs = [ zlib bzip2 brotli libpng ]; # needed when linking against freetype + src = + let + inherit (finalAttrs) pname version; + in + fetchurl { + url = "mirror://savannah/${pname}/${pname}-${version}.tar.xz"; + sha256 = "sha256-BVA1BmbUJ8dNrrhdWse7NTrLpfdpVjlZlTEanG8GMok="; + }; + + propagatedBuildInputs = [ + zlib + bzip2 + brotli + libpng + ]; # needed when linking against freetype # dependence on harfbuzz is looser than the reverse dependence - nativeBuildInputs = [ pkg-config which __flattenIncludeHackHook ] + nativeBuildInputs = + [ + pkg-config + which + __flattenIncludeHackHook + ] ++ lib.optional (!stdenv.hostPlatform.isWindows) makeWrapper # FreeType requires GNU Make, which is not part of stdenv on FreeBSD. ++ lib.optional (!stdenv.hostPlatform.isLinux) gnumake; @@ -58,15 +72,22 @@ stdenv.mkDerivation (finalAttrs: { ./enable-table-validation.patch ] ++ lib.optional useEncumberedCode ./enable-subpixel-rendering.patch; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - configureFlags = [ "--bindir=$(dev)/bin" "--enable-freetype-config" ]; + configureFlags = [ + "--bindir=$(dev)/bin" + "--enable-freetype-config" + ]; # native compiler to generate building tool CC_BUILD = "${buildPackages.stdenv.cc}/bin/cc"; # The asm for armel is written with the 'asm' keyword. - CFLAGS = lib.optionalString stdenv.hostPlatform.isAarch32 "-std=gnu99" + CFLAGS = + lib.optionalString stdenv.hostPlatform.isAarch32 "-std=gnu99" + lib.optionalString stdenv.hostPlatform.is32bit " -D_FILE_OFFSET_BITS=64"; enableParallelBuilding = true; @@ -75,14 +96,16 @@ stdenv.mkDerivation (finalAttrs: { # pkgsCross.mingwW64.pkg-config doesn't build # makeWrapper doesn't cross-compile to windows #120726 - postInstall = '' - substituteInPlace $dev/bin/freetype-config \ - --replace ${buildPackages.pkg-config} ${pkgsHostHost.pkg-config} - '' + lib.optionalString (!stdenv.hostPlatform.isMinGW) '' - - wrapProgram "$dev/bin/freetype-config" \ - --set PKG_CONFIG_PATH "$PKG_CONFIG_PATH:$dev/lib/pkgconfig" - ''; + postInstall = + '' + substituteInPlace $dev/bin/freetype-config \ + --replace ${buildPackages.pkg-config} ${pkgsHostHost.pkg-config} + '' + + lib.optionalString (!stdenv.hostPlatform.isMinGW) '' + + wrapProgram "$dev/bin/freetype-config" \ + --set PKG_CONFIG_PATH "$PKG_CONFIG_PATH:$dev/lib/pkgconfig" + ''; passthru.tests = { inherit @@ -96,7 +119,8 @@ stdenv.mkDerivation (finalAttrs: { pango poppler texmacs - ttfautohint; + ttfautohint + ; inherit (python3.pkgs) freetype-py; inherit (qt5) qtbase; pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; @@ -113,7 +137,9 @@ stdenv.mkDerivation (finalAttrs: { fonts. ''; homepage = "https://www.freetype.org/"; - changelog = "https://gitlab.freedesktop.org/freetype/freetype/-/raw/VER-${builtins.replaceStrings ["."] ["-"] finalAttrs.version}/docs/CHANGES"; + changelog = "https://gitlab.freedesktop.org/freetype/freetype/-/raw/VER-${ + builtins.replaceStrings [ "." ] [ "-" ] finalAttrs.version + }/docs/CHANGES"; license = licenses.gpl2Plus; # or the FreeType License (BSD + advertising clause) platforms = platforms.all; pkgConfigModules = [ "freetype2" ]; diff --git a/pkgs/by-name/fr/freewheeling/package.nix b/pkgs/by-name/fr/freewheeling/package.nix index 2da35c3adec859..039604733b5635 100644 --- a/pkgs/by-name/fr/freewheeling/package.nix +++ b/pkgs/by-name/fr/freewheeling/package.nix @@ -1,6 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, autoreconfHook, gnutls, freetype, fluidsynth -, SDL, SDL_gfx, SDL_ttf, liblo, libxml2, alsa-lib, libjack2, libvorbis -, libSM, libsndfile, libogg, libtool +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + gnutls, + freetype, + fluidsynth, + SDL, + SDL_gfx, + SDL_ttf, + liblo, + libxml2, + alsa-lib, + libjack2, + libvorbis, + libSM, + libsndfile, + libogg, + libtool, }: let makeSDLFlags = map (p: "-I${lib.getDev p}/include/SDL"); @@ -17,32 +35,53 @@ stdenv.mkDerivation rec { sha256 = "1xff5whr02cixihgd257dc70hnyf22j3zamvhsvg4lp7zq9l2in4"; }; - nativeBuildInputs = [ pkg-config autoreconfHook libtool ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + libtool + ]; buildInputs = [ - freetype fluidsynth SDL SDL_gfx SDL_ttf - liblo libxml2 libjack2 alsa-lib libvorbis libsndfile libogg libSM + freetype + fluidsynth + SDL + SDL_gfx + SDL_ttf + liblo + libxml2 + libjack2 + alsa-lib + libvorbis + libsndfile + libogg + libSM (gnutls.overrideAttrs (oldAttrs: { configureFlags = oldAttrs.configureFlags ++ [ "--enable-openssl-compatibility" ]; })) ]; - env.NIX_CFLAGS_COMPILE = toString - (makeSDLFlags [ SDL SDL_ttf SDL_gfx ] ++ [ "-I${libxml2.dev}/include/libxml2" ]); + env.NIX_CFLAGS_COMPILE = toString ( + makeSDLFlags [ + SDL + SDL_ttf + SDL_gfx + ] + ++ [ "-I${libxml2.dev}/include/libxml2" ] + ); hardeningDisable = [ "format" ]; meta = { description = "Live looping instrument with JACK and MIDI support"; longDescription = '' - Freewheeling allows us to build repetitive grooves - by sampling and directing loops from within spirited improvisation. + Freewheeling allows us to build repetitive grooves + by sampling and directing loops from within spirited improvisation. - It works because, down to the core, it's built around - improv. We leave mice and menus, and dive into our own process - of making sound. + It works because, down to the core, it's built around + improv. We leave mice and menus, and dive into our own process + of making sound. - Freewheeling runs under macOS and Linux, and is open source - software, released under the GNU GPL license. - '' ; + Freewheeling runs under macOS and Linux, and is open source + software, released under the GNU GPL license. + ''; homepage = "https://freewheeling.sourceforge.net"; license = lib.licenses.gpl2; diff --git a/pkgs/by-name/fr/freexl/package.nix b/pkgs/by-name/fr/freexl/package.nix index ffcf81e92f58c7..1509121ee4d04e 100644 --- a/pkgs/by-name/fr/freexl/package.nix +++ b/pkgs/by-name/fr/freexl/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, validatePkgConfig -, expat -, minizip -, zlib -, libiconv +{ + lib, + stdenv, + fetchurl, + validatePkgConfig, + expat, + minizip, + zlib, + libiconv, }: stdenv.mkDerivation rec { @@ -33,7 +34,11 @@ stdenv.mkDerivation rec { description = "Library to extract valid data from within an Excel (.xls) spreadsheet"; homepage = "https://www.gaia-gis.it/fossil/freexl"; # They allow any of these - license = with licenses; [ gpl2Plus lgpl21Plus mpl11 ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + mpl11 + ]; platforms = platforms.unix; maintainers = with maintainers; [ sikmir ]; }; diff --git a/pkgs/by-name/fr/freeze/package.nix b/pkgs/by-name/fr/freeze/package.nix index e828ed79bf4c3d..38846028c086fc 100644 --- a/pkgs/by-name/fr/freeze/package.nix +++ b/pkgs/by-name/fr/freeze/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/fr/frei/package.nix b/pkgs/by-name/fr/frei/package.nix index 6e8a2181abb170..b5db9f95635ceb 100644 --- a/pkgs/by-name/fr/frei/package.nix +++ b/pkgs/by-name/fr/frei/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/fr/frei0r/package.nix b/pkgs/by-name/fr/frei0r/package.nix index d05d8ddd5f4aed..b8afe3eca36b94 100644 --- a/pkgs/by-name/fr/frei0r/package.nix +++ b/pkgs/by-name/fr/frei0r/package.nix @@ -1,14 +1,15 @@ -{ lib -, config -, stdenv -, fetchFromGitHub -, cairo -, cmake -, opencv -, pcre -, pkg-config -, cudaSupport ? config.cudaSupport -, cudaPackages +{ + lib, + config, + stdenv, + fetchFromGitHub, + cairo, + cmake, + opencv, + pcre, + pkg-config, + cudaSupport ? config.cudaSupport, + cudaPackages, }: stdenv.mkDerivation rec { @@ -22,15 +23,20 @@ stdenv.mkDerivation rec { hash = "sha256-uKYCJD88TnrJTTnzCCietNt01QPeFW+hhnjcBNKUWsY="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ - cairo - opencv - pcre - ] ++ lib.optionals cudaSupport [ - cudaPackages.cuda_cudart - cudaPackages.cuda_nvcc + nativeBuildInputs = [ + cmake + pkg-config ]; + buildInputs = + [ + cairo + opencv + pcre + ] + ++ lib.optionals cudaSupport [ + cudaPackages.cuda_cudart + cudaPackages.cuda_nvcc + ]; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' for f in $out/lib/frei0r-1/*.so* ; do diff --git a/pkgs/by-name/fr/french-numbers/package.nix b/pkgs/by-name/fr/french-numbers/package.nix index f1efc35ea2e62a..48649d4e57a409 100644 --- a/pkgs/by-name/fr/french-numbers/package.nix +++ b/pkgs/by-name/fr/french-numbers/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Represent numbers in French language"; homepage = "https://github.com/evenfurther/french-numbers"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; mainProgram = "french-numbers"; maintainers = with maintainers; [ samueltardieu ]; }; diff --git a/pkgs/by-name/fr/frequest/package.nix b/pkgs/by-name/fr/frequest/package.nix index 85bb97f9c6fd50..b643360df0f225 100644 --- a/pkgs/by-name/fr/frequest/package.nix +++ b/pkgs/by-name/fr/frequest/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, qt5 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + qt5, +}: stdenv.mkDerivation (finalAttrs: { pname = "frequest"; diff --git a/pkgs/by-name/fr/frescobaldi/package.nix b/pkgs/by-name/fr/frescobaldi/package.nix index 653c4747c9336e..ae51e88588ab7f 100644 --- a/pkgs/by-name/fr/frescobaldi/package.nix +++ b/pkgs/by-name/fr/frescobaldi/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, python311Packages, lilypond }: +{ + lib, + stdenv, + fetchFromGitHub, + python311Packages, + lilypond, +}: python311Packages.buildPythonApplication rec { pname = "frescobaldi"; diff --git a/pkgs/by-name/fr/fretboard/package.nix b/pkgs/by-name/fr/fretboard/package.nix index 8cd365e463a8f7..5ede24ae27729a 100644 --- a/pkgs/by-name/fr/fretboard/package.nix +++ b/pkgs/by-name/fr/fretboard/package.nix @@ -1,19 +1,20 @@ -{ lib -, blueprint-compiler -, cargo -, darwin -, desktop-file-utils -, fetchFromGitHub -, glib -, gtk4 -, libadwaita -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, stdenv -, wrapGAppsHook4 +{ + lib, + blueprint-compiler, + cargo, + darwin, + desktop-file-utils, + fetchFromGitHub, + glib, + gtk4, + libadwaita, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { @@ -45,17 +46,21 @@ stdenv.mkDerivation (finalAttrs: { wrapGAppsHook4 ]; - buildInputs = [ - glib - gtk4 - libadwaita - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + glib + gtk4 + libadwaita + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-error=incompatible-function-pointer-types" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-error=incompatible-function-pointer-types" + ] + ); meta = with lib; { changelog = "https://github.com/bragefuglseth/fretboard/releases/tag/v${finalAttrs.version}"; diff --git a/pkgs/by-name/fr/fribidi/package.nix b/pkgs/by-name/fr/fribidi/package.nix index fe122067464ec0..5fedf8f1d39618 100644 --- a/pkgs/by-name/fr/fribidi/package.nix +++ b/pkgs/by-name/fr/fribidi/package.nix @@ -1,23 +1,31 @@ -{ lib, stdenv -, buildPackages -, fetchurl -, meson -, ninja -, pkg-config -, fixDarwinDylibNames -, python3 -, testers +{ + lib, + stdenv, + buildPackages, + fetchurl, + meson, + ninja, + pkg-config, + fixDarwinDylibNames, + python3, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "fribidi"; version = "1.0.16"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; # NOTE: Only URL tarball has "Have pre-generated man pages: true", which works-around upstream usage of some rare ancient `c2man` fossil application. src = fetchurl { - url = with finalAttrs; "https://github.com/fribidi/fribidi/releases/download/v${version}/${pname}-${version}.tar.xz"; + url = + with finalAttrs; + "https://github.com/fribidi/fribidi/releases/download/v${version}/${pname}-${version}.tar.xz"; sha256 = "sha256-GxzeWyNdQEeekb4vDoijCeMhTIq0cOyKJ0TYKlqeoFw="; }; @@ -25,8 +33,11 @@ stdenv.mkDerivation (finalAttrs: { patchShebangs test ''; - nativeBuildInputs = [ meson ninja pkg-config ] - ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; + nativeBuildInputs = [ + meson + ninja + pkg-config + ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; depsBuildBuild = [ buildPackages.stdenv.cc ]; diff --git a/pkgs/by-name/fr/fricas/package.nix b/pkgs/by-name/fr/fricas/package.nix index 43a00a5e1fbac3..126e6526f6a18b 100644 --- a/pkgs/by-name/fr/fricas/package.nix +++ b/pkgs/by-name/fr/fricas/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, sbcl, libX11, libXpm, libICE, libSM, libXt, libXau, libXdmcp }: +{ + lib, + stdenv, + fetchFromGitHub, + sbcl, + libX11, + libXpm, + libICE, + libSM, + libXt, + libXau, + libXdmcp, +}: stdenv.mkDerivation rec { pname = "fricas"; @@ -11,7 +23,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-EX/boSs6rK4RrJ5W6Rd0TSHsbQsNiFI1evFuNPBMeu8="; }; - buildInputs = [ sbcl libX11 libXpm libICE libSM libXt libXau libXdmcp ]; + buildInputs = [ + sbcl + libX11 + libXpm + libICE + libSM + libXt + libXau + libXdmcp + ]; # Remove when updating to next version configurePhase = '' diff --git a/pkgs/by-name/fr/frigate/package.nix b/pkgs/by-name/fr/frigate/package.nix index 4578d709a0acae..924efe720d28c2 100644 --- a/pkgs/by-name/fr/frigate/package.nix +++ b/pkgs/by-name/fr/frigate/package.nix @@ -1,10 +1,11 @@ -{ lib -, callPackage -, python312 -, fetchFromGitHub -, fetchurl -, frigate -, nixosTests +{ + lib, + callPackage, + python312, + fetchFromGitHub, + fetchurl, + frigate, + nixosTests, }: let @@ -168,7 +169,8 @@ python.pkgs.buildPythonApplication rec { passthru = { web = frigate-web; inherit python; - pythonPath =(python.pkgs.makePythonPath propagatedBuildInputs) + ":${frigate}/${python.sitePackages}"; + pythonPath = + (python.pkgs.makePythonPath propagatedBuildInputs) + ":${frigate}/${python.sitePackages}"; tests = { inherit (nixosTests) frigate; }; diff --git a/pkgs/by-name/fr/frigate/web.nix b/pkgs/by-name/fr/frigate/web.nix index cea410849ec8df..959157df670372 100644 --- a/pkgs/by-name/fr/frigate/web.nix +++ b/pkgs/by-name/fr/frigate/web.nix @@ -1,6 +1,7 @@ -{ buildNpmPackage -, src -, version +{ + buildNpmPackage, + src, + version, }: buildNpmPackage { diff --git a/pkgs/by-name/fr/fritz-exporter/package.nix b/pkgs/by-name/fr/fritz-exporter/package.nix index 85469631a08a74..e2230ff9197784 100644 --- a/pkgs/by-name/fr/fritz-exporter/package.nix +++ b/pkgs/by-name/fr/fritz-exporter/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/fr/frogatto/data.nix b/pkgs/by-name/fr/frogatto/data.nix index a61bddf94bfb52..15751c71302a06 100644 --- a/pkgs/by-name/fr/frogatto/data.nix +++ b/pkgs/by-name/fr/frogatto/data.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "frogatto-data"; @@ -19,7 +23,10 @@ stdenv.mkDerivation { meta = with lib; { homepage = "https://github.com/frogatto/frogatto"; description = "Data files to the frogatto game"; - license = with licenses; [ cc-by-30 unfree ]; + license = with licenses; [ + cc-by-30 + unfree + ]; maintainers = with maintainers; [ astro ]; }; } diff --git a/pkgs/by-name/fr/frogatto/engine.nix b/pkgs/by-name/fr/frogatto/engine.nix index d5e380588176c6..ded9db8efb346d 100644 --- a/pkgs/by-name/fr/frogatto/engine.nix +++ b/pkgs/by-name/fr/frogatto/engine.nix @@ -1,6 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, which -, boost, SDL2, SDL2_image, SDL2_mixer, SDL2_ttf -, glew, zlib, icu, pkg-config, cairo, libvpx, glm +{ + lib, + stdenv, + fetchFromGitHub, + which, + boost, + SDL2, + SDL2_image, + SDL2_mixer, + SDL2_ttf, + glew, + zlib, + icu, + pkg-config, + cairo, + libvpx, + glm, }: stdenv.mkDerivation { @@ -16,7 +30,8 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ - which pkg-config + which + pkg-config ]; buildInputs = [ diff --git a/pkgs/by-name/fr/frogatto/package.nix b/pkgs/by-name/fr/frogatto/package.nix index 036b2abec19ca0..ca17b4547957e8 100644 --- a/pkgs/by-name/fr/frogatto/package.nix +++ b/pkgs/by-name/fr/frogatto/package.nix @@ -1,4 +1,10 @@ -{ buildEnv, lib, callPackage, makeWrapper, makeDesktopItem }: +{ + buildEnv, + lib, + callPackage, + makeWrapper, + makeDesktopItem, +}: let description = "Action-adventure game, starring a certain quixotic frog"; @@ -12,14 +18,22 @@ let comment = description; desktopName = "Frogatto"; genericName = "frogatto"; - categories = [ "Game" "ArcadeGame" ]; + categories = [ + "Game" + "ArcadeGame" + ]; }; inherit (data) version; -in buildEnv { +in +buildEnv { name = "frogatto-${version}"; nativeBuildInputs = [ makeWrapper ]; - paths = [ engine data desktopItem ]; + paths = [ + engine + data + desktopItem + ]; pathsToLink = [ "/bin" "/share/frogatto/data" @@ -36,7 +50,10 @@ in buildEnv { meta = with lib; { homepage = "https://frogatto.com"; description = description; - license = with licenses; [ cc-by-30 unfree ]; + license = with licenses; [ + cc-by-30 + unfree + ]; platforms = platforms.linux; maintainers = with maintainers; [ astro ]; }; diff --git a/pkgs/by-name/fr/frogmouth/package.nix b/pkgs/by-name/fr/frogmouth/package.nix index 8a93e86be66ca9..29680ad507a506 100644 --- a/pkgs/by-name/fr/frogmouth/package.nix +++ b/pkgs/by-name/fr/frogmouth/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/fr/frotz/package.nix b/pkgs/by-name/fr/frotz/package.nix index 36ca5c2b3cae04..e90f43beca2a46 100644 --- a/pkgs/by-name/fr/frotz/package.nix +++ b/pkgs/by-name/fr/frotz/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, libao -, libmodplug -, libsamplerate -, libsndfile -, libvorbis -, ncurses -, which -, pkg-config +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + libao, + libmodplug, + libsamplerate, + libsndfile, + libvorbis, + ncurses, + which, + pkg-config, }: stdenv.mkDerivation rec { @@ -32,8 +33,18 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ which pkg-config ]; - buildInputs = [ libao libmodplug libsamplerate libsndfile libvorbis ncurses ]; + nativeBuildInputs = [ + which + pkg-config + ]; + buildInputs = [ + libao + libmodplug + libsamplerate + libsndfile + libvorbis + ncurses + ]; installFlags = [ "PREFIX=$(out)" ]; @@ -43,7 +54,10 @@ stdenv.mkDerivation rec { description = "Z-machine interpreter for Infocom games and other interactive fiction"; mainProgram = "frotz"; platforms = platforms.unix; - maintainers = with maintainers; [ nicknovitski ddelabru ]; + maintainers = with maintainers; [ + nicknovitski + ddelabru + ]; license = licenses.gpl2Plus; }; } diff --git a/pkgs/by-name/fr/frozen/package.nix b/pkgs/by-name/fr/frozen/package.nix index 26c47617c1f60d..9ea5d64ed289b1 100644 --- a/pkgs/by-name/fr/frozen/package.nix +++ b/pkgs/by-name/fr/frozen/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, }: stdenv.mkDerivation rec { @@ -17,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-BpuYK9fbWSpeF8iPT8ImrV3CKKaA5RQ2W0ZQ03TciR0="; }; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; # frozen has a simple Makefile and a GN BUILD file as building scripts. # Since it has only two source files, the best course of action to support diff --git a/pkgs/by-name/fr/frp/package.nix b/pkgs/by-name/fr/frp/package.nix index f68a4e5e74d085..419cf6e76f8115 100644 --- a/pkgs/by-name/fr/frp/package.nix +++ b/pkgs/by-name/fr/frp/package.nix @@ -1,4 +1,9 @@ -{ buildGoModule, lib, fetchFromGitHub, nixosTests }: +{ + buildGoModule, + lib, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "frp"; @@ -15,7 +20,10 @@ buildGoModule rec { doCheck = false; - subPackages = [ "cmd/frpc" "cmd/frps" ]; + subPackages = [ + "cmd/frpc" + "cmd/frps" + ]; passthru.tests = { frp = nixosTests.frp; diff --git a/pkgs/by-name/fr/frr/clippy-helper.nix b/pkgs/by-name/fr/frr/clippy-helper.nix index c2b4b918ceca53..608716b45f6b45 100644 --- a/pkgs/by-name/fr/frr/clippy-helper.nix +++ b/pkgs/by-name/fr/frr/clippy-helper.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, frrSource -, frrVersion +{ + lib, + stdenv, + frrSource, + frrVersion, # build time -, autoreconfHook -, flex -, bison -, pkg-config -, elfutils -, perl -, python3 + autoreconfHook, + flex, + bison, + pkg-config, + elfutils, + perl, + python3, }: @@ -28,11 +29,13 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - python3 - ] ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform elfutils) [ - elfutils - ]; + buildInputs = + [ + python3 + ] + ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform elfutils) [ + elfutils + ]; configureFlags = [ "--enable-clippy-only" @@ -53,7 +56,10 @@ stdenv.mkDerivation rec { to support cross-compiling, because it needs to be compiled with the build system toolchain and not the target host one. ''; - license = with licenses; [ gpl2Plus lgpl21Plus ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + ]; maintainers = with maintainers; [ thillux ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/fr/frugal/package.nix b/pkgs/by-name/fr/frugal/package.nix index bf83ec753d5008..2380581c5e7a45 100644 --- a/pkgs/by-name/fr/frugal/package.nix +++ b/pkgs/by-name/fr/frugal/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "frugal"; diff --git a/pkgs/by-name/fr/frugally-deep/package.nix b/pkgs/by-name/fr/frugally-deep/package.nix index f275ec5f02bacb..baa42437f5f083 100644 --- a/pkgs/by-name/fr/frugally-deep/package.nix +++ b/pkgs/by-name/fr/frugally-deep/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, gitUpdater -, cmake -, functionalplus -, eigen -, nlohmann_json -, doctest -, python3Packages -, buildTests ? false # Needs tensorflow +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + cmake, + functionalplus, + eigen, + nlohmann_json, + doctest, + python3Packages, + buildTests ? false, # Needs tensorflow }: stdenv.mkDerivation (finalAttrs: { @@ -22,12 +23,14 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-yg2SMsYOOSOgsdwIH1bU3iPM45z6c7WeIrgOddt3um4="; }; - nativeBuildInputs = [ - cmake - ] ++ lib.optionals buildTests [ - python3Packages.python - python3Packages.numpy - ]; + nativeBuildInputs = + [ + cmake + ] + ++ lib.optionals buildTests [ + python3Packages.python + python3Packages.numpy + ]; buildInputs = lib.optionals buildTests [ doctest diff --git a/pkgs/by-name/fs/fsarchiver/package.nix b/pkgs/by-name/fs/fsarchiver/package.nix index 6835a5dbb94bfb..7fb6b0537539f2 100644 --- a/pkgs/by-name/fs/fsarchiver/package.nix +++ b/pkgs/by-name/fs/fsarchiver/package.nix @@ -1,11 +1,26 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config -, zlib, bzip2, lzo, lz4, zstd, xz -, libgcrypt, e2fsprogs, util-linux, libgpg-error }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + zlib, + bzip2, + lzo, + lz4, + zstd, + xz, + libgcrypt, + e2fsprogs, + util-linux, + libgpg-error, +}: let version = "0.8.7"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "fsarchiver"; inherit version; @@ -17,12 +32,22 @@ in stdenv.mkDerivation { }; nativeBuildInputs = [ - autoreconfHook pkg-config + autoreconfHook + pkg-config ]; buildInputs = [ - zlib bzip2 xz lzo lz4 zstd xz - libgcrypt e2fsprogs util-linux libgpg-error + zlib + bzip2 + xz + lzo + lz4 + zstd + xz + libgcrypt + e2fsprogs + util-linux + libgpg-error ]; meta = with lib; { diff --git a/pkgs/by-name/fs/fsatrace/package.nix b/pkgs/by-name/fs/fsatrace/package.nix index d99374ac537349..5faa6748686132 100644 --- a/pkgs/by-name/fs/fsatrace/package.nix +++ b/pkgs/by-name/fs/fsatrace/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "fsatrace"; diff --git a/pkgs/by-name/fs/fscan/package.nix b/pkgs/by-name/fs/fscan/package.nix index 37886995b36146..58c348bd765efe 100644 --- a/pkgs/by-name/fs/fscan/package.nix +++ b/pkgs/by-name/fs/fscan/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "fscan"; diff --git a/pkgs/by-name/fs/fscrypt-experimental/package.nix b/pkgs/by-name/fs/fscrypt-experimental/package.nix index 2cf5243422e150..71f1f63a077382 100644 --- a/pkgs/by-name/fs/fscrypt-experimental/package.nix +++ b/pkgs/by-name/fs/fscrypt-experimental/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, gnum4, pam, fscrypt-experimental }: +{ + lib, + buildGoModule, + fetchFromGitHub, + gnum4, + pam, + fscrypt-experimental, +}: # Don't use this for anything important yet! @@ -39,8 +46,7 @@ buildGoModule rec { ''; meta = with lib; { - description = - "A high-level tool for the management of Linux filesystem encryption"; + description = "A high-level tool for the management of Linux filesystem encryption"; mainProgram = "fscrypt"; longDescription = '' This tool manages metadata, key generation, key wrapping, PAM integration, diff --git a/pkgs/by-name/fs/fsearch/package.nix b/pkgs/by-name/fs/fsearch/package.nix index 453e200ea60917..5bc77590432050 100644 --- a/pkgs/by-name/fs/fsearch/package.nix +++ b/pkgs/by-name/fs/fsearch/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, gtk3 -, pcre2 -, glib -, desktop-file-utils -, meson -, ninja -, pkg-config -, wrapGAppsHook3 -, gettext -, icu +{ + lib, + stdenv, + fetchFromGitHub, + gtk3, + pcre2, + glib, + desktop-file-utils, + meson, + ninja, + pkg-config, + wrapGAppsHook3, + gettext, + icu, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fs/fselect/package.nix b/pkgs/by-name/fs/fselect/package.nix index 95c5b4af05207e..283f6a192066c4 100644 --- a/pkgs/by-name/fs/fselect/package.nix +++ b/pkgs/by-name/fs/fselect/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, installShellFiles, libiconv }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + installShellFiles, + libiconv, +}: rustPlatform.buildRustPackage rec { pname = "fselect"; @@ -23,7 +30,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Find files with SQL-like queries"; homepage = "https://github.com/jhspetersson/fselect"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ Br1ght0ne ]; mainProgram = "fselect"; }; diff --git a/pkgs/by-name/fs/fsg/package.nix b/pkgs/by-name/fs/fsg/package.nix index d5680669df9e99..5f7340f9f03989 100644 --- a/pkgs/by-name/fs/fsg/package.nix +++ b/pkgs/by-name/fs/fsg/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, gtk2, glib, pkg-config, libGLU, libGL, wxGTK32, libX11, xorgproto, runtimeShell }: +{ + lib, + stdenv, + fetchurl, + gtk2, + glib, + pkg-config, + libGLU, + libGL, + wxGTK32, + libX11, + xorgproto, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "fsg"; @@ -16,7 +29,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib libGLU libGL wxGTK32 libX11 xorgproto ]; + buildInputs = [ + glib + libGLU + libGL + wxGTK32 + libX11 + xorgproto + ]; preBuild = '' sed -e ' diff --git a/pkgs/by-name/fs/fsharp/package.nix b/pkgs/by-name/fs/fsharp/package.nix index d141c6f5d4c5b6..716d637a84e812 100644 --- a/pkgs/by-name/fs/fsharp/package.nix +++ b/pkgs/by-name/fs/fsharp/package.nix @@ -1,6 +1,16 @@ # Temporarily avoid dependency on dotnetbuildhelpers to avoid rebuilding many times while working on it -{ lib, stdenv, fetchFromGitHub, mono, pkg-config, dotnetbuildhelpers, autoconf, automake, which }: +{ + lib, + stdenv, + fetchFromGitHub, + mono, + pkg-config, + dotnetbuildhelpers, + autoconf, + automake, + which, +}: stdenv.mkDerivation rec { pname = "fsharp"; @@ -13,8 +23,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-dgTEM2aL8lVjVMuW0+HLc+TUA39IiuBv/RfHYNURh5s="; }; - nativeBuildInputs = [ pkg-config autoconf automake ]; - buildInputs = [ mono dotnetbuildhelpers which ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; + buildInputs = [ + mono + dotnetbuildhelpers + which + ]; configurePhase = '' sed -i '988d' src/FSharpSource.targets @@ -44,7 +62,10 @@ stdenv.mkDerivation rec { description = "Functional CLI language"; homepage = "https://fsharp.org/"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ thoughtpolice raskin ]; + maintainers = with lib.maintainers; [ + thoughtpolice + raskin + ]; platforms = with lib.platforms; unix; }; } diff --git a/pkgs/by-name/fs/fsmark/package.nix b/pkgs/by-name/fs/fsmark/package.nix index 340be1a56c2ed5..9d442aba7b0a1d 100644 --- a/pkgs/by-name/fs/fsmark/package.nix +++ b/pkgs/by-name/fs/fsmark/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "fsmark"; diff --git a/pkgs/by-name/fs/fsmon/package.nix b/pkgs/by-name/fs/fsmon/package.nix index 5e38561078017d..bbdf9cad5e2f32 100644 --- a/pkgs/by-name/fs/fsmon/package.nix +++ b/pkgs/by-name/fs/fsmon/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fs/fsnotifier/package.nix b/pkgs/by-name/fs/fsnotifier/package.nix index 3c214795089749..bb9215713d61d6 100644 --- a/pkgs/by-name/fs/fsnotifier/package.nix +++ b/pkgs/by-name/fs/fsnotifier/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { @@ -35,5 +36,5 @@ stdenv.mkDerivation rec { mainProgram = "fsnotifier"; maintainers = with lib.maintainers; [ shyim ]; platforms = lib.platforms.linux; - }; + }; } diff --git a/pkgs/by-name/fs/fspy/package.nix b/pkgs/by-name/fs/fspy/package.nix index 0227e889fd6b91..211c991408e1f4 100644 --- a/pkgs/by-name/fs/fspy/package.nix +++ b/pkgs/by-name/fs/fspy/package.nix @@ -1,4 +1,8 @@ -{ appimageTools, lib, fetchurl }: +{ + appimageTools, + lib, + fetchurl, +}: let pname = "fspy"; version = "1.0.3"; @@ -8,7 +12,8 @@ let sha256 = "sha256-L+qsSExuEkzZkjnV/J6rrZ3BXqWQd+IfsN6a3kvQF3A="; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; meta = with lib; { diff --git a/pkgs/by-name/fs/fsql/package.nix b/pkgs/by-name/fs/fsql/package.nix index d9f3b3ae8f90ec..56b9215027f645 100644 --- a/pkgs/by-name/fs/fsql/package.nix +++ b/pkgs/by-name/fs/fsql/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "fsql"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-+laTnx6Xkrv3QQel5opqYQSuFmo54UMI2A653xbBWzQ="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Search through your filesystem with SQL-esque queries"; diff --git a/pkgs/by-name/fs/fsrx/package.nix b/pkgs/by-name/fs/fsrx/package.nix index c1a1fa9ecc90a4..fb2e67ef7115d7 100644 --- a/pkgs/by-name/fs/fsrx/package.nix +++ b/pkgs/by-name/fs/fsrx/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, rustPlatform, testers, fsrx }: +{ + lib, + fetchFromGitHub, + rustPlatform, + testers, + fsrx, +}: rustPlatform.buildRustPackage rec { pname = "fsrx"; diff --git a/pkgs/by-name/fs/fst/package.nix b/pkgs/by-name/fs/fst/package.nix index c43a781cf6e14d..33c819f881c110 100644 --- a/pkgs/by-name/fs/fst/package.nix +++ b/pkgs/by-name/fs/fst/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchCrate -, stdenv -, libiconv +{ + lib, + rustPlatform, + fetchCrate, + stdenv, + libiconv, }: rustPlatform.buildRustPackage rec { @@ -33,7 +34,10 @@ rustPlatform.buildRustPackage rec { description = "Represent large sets and maps compactly with finite state transducers"; mainProgram = "fst"; homepage = "https://github.com/BurntSushi/fst"; - license = with licenses; [ unlicense /* or */ mit ]; + license = with licenses; [ + unlicense # or + mit + ]; maintainers = with maintainers; [ rmcgibbo ]; }; } diff --git a/pkgs/by-name/fs/fstrcmp/package.nix b/pkgs/by-name/fs/fstrcmp/package.nix index ab7f410eddf29c..59d9cf3dfe6441 100644 --- a/pkgs/by-name/fs/fstrcmp/package.nix +++ b/pkgs/by-name/fs/fstrcmp/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchzip, libtool, ghostscript, groff, autoreconfHook }: +{ + lib, + stdenv, + fetchzip, + libtool, + ghostscript, + groff, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "fstrcmp"; @@ -11,9 +19,20 @@ stdenv.mkDerivation rec { patches = [ ./cross.patch ]; - outputs = [ "out" "dev" "doc" "man" "devman" ]; + outputs = [ + "out" + "dev" + "doc" + "man" + "devman" + ]; - nativeBuildInputs = [ libtool ghostscript groff autoreconfHook ]; + nativeBuildInputs = [ + libtool + ghostscript + groff + autoreconfHook + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/fs/fstrm/package.nix b/pkgs/by-name/fs/fstrm/package.nix index 15daa7e5a95921..899ee38533a003 100644 --- a/pkgs/by-name/fs/fstrm/package.nix +++ b/pkgs/by-name/fs/fstrm/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, libevent, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libevent, + openssl, +}: stdenv.mkDerivation rec { pname = "fstrm"; @@ -11,10 +19,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-/WFP2g3Vuf/qaY8pprY8XFAlpEE+0SJUlFNWfa+7ZlE="; }; - outputs = [ "bin" "out" "dev" ]; - - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libevent openssl ]; + outputs = [ + "bin" + "out" + "dev" + ]; + + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libevent + openssl + ]; preBuild = '' NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -L${openssl}/lib" @@ -29,4 +47,3 @@ stdenv.mkDerivation rec { platforms = platforms.unix; }; } - diff --git a/pkgs/by-name/fs/fsuae-launcher/package.nix b/pkgs/by-name/fs/fsuae-launcher/package.nix index af08047ed81dc4..8c587ca300f8a3 100644 --- a/pkgs/by-name/fs/fsuae-launcher/package.nix +++ b/pkgs/by-name/fs/fsuae-launcher/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchurl -, fsuae -, gettext -, python3Packages -, stdenv -, libsForQt5 +{ + lib, + fetchurl, + fsuae, + gettext, + python3Packages, + stdenv, + libsForQt5, }: stdenv.mkDerivation (finalAttrs: { @@ -55,8 +56,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Graphical front-end for the FS-UAE emulator"; license = lib.licenses.gpl2Plus; mainProgram = "fs-uae-launcher"; - maintainers = with lib.maintainers; [ sander AndersonTorres ]; - platforms = with lib.systems.inspect; - patternLogicalAnd patterns.isx86 patterns.isLinux; + maintainers = with lib.maintainers; [ + sander + AndersonTorres + ]; + platforms = with lib.systems.inspect; patternLogicalAnd patterns.isx86 patterns.isLinux; }; }) diff --git a/pkgs/by-name/fs/fsuae/package.nix b/pkgs/by-name/fs/fsuae/package.nix index 7ec1d656a90ad0..854538295ba14a 100644 --- a/pkgs/by-name/fs/fsuae/package.nix +++ b/pkgs/by-name/fs/fsuae/package.nix @@ -1,24 +1,25 @@ -{ lib -, SDL2 -, autoreconfHook -, fetchFromGitHub -, freetype -, gettext -, glib -, gtk2 -, libGL -, libGLU -, libmpeg2 -, lua -, openal -, pkg-config -, strip-nondeterminism -, stdenv -, zip -, zlib +{ + lib, + SDL2, + autoreconfHook, + fetchFromGitHub, + freetype, + gettext, + glib, + gtk2, + libGL, + libGLU, + libmpeg2, + lua, + openal, + pkg-config, + strip-nondeterminism, + stdenv, + zip, + zlib, }: -stdenv.mkDerivation (finalAttrs:{ +stdenv.mkDerivation (finalAttrs: { pname = "fs-uae"; version = "3.1.66"; @@ -69,7 +70,6 @@ stdenv.mkDerivation (finalAttrs:{ license = lib.licenses.gpl2Plus; mainProgram = "fs-uae"; maintainers = with lib.maintainers; [ AndersonTorres ]; - platforms = with lib.systems.inspect; - patternLogicalAnd patterns.isx86 patterns.isLinux; + platforms = with lib.systems.inspect; patternLogicalAnd patterns.isx86 patterns.isLinux; }; }) diff --git a/pkgs/by-name/fs/fsv/package.nix b/pkgs/by-name/fs/fsv/package.nix index e49610116f71d2..a9c34d2d1bc655 100644 --- a/pkgs/by-name/fs/fsv/package.nix +++ b/pkgs/by-name/fs/fsv/package.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, cglm -, gtk3 -, libepoxy -, libGLU +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + cglm, + gtk3, + libepoxy, + libGLU, }: stdenv.mkDerivation rec { - pname = "fsv"; + pname = "fsv"; version = "3.0"; src = fetchFromGitHub { owner = "jabl"; - repo = "fsv"; - rev = "${pname}-${version}"; - hash = "sha256-fxsA3qcBPvK4H5P4juGTe6eg1lkygvzFpNW36B9lsE4="; + repo = "fsv"; + rev = "${pname}-${version}"; + hash = "sha256-fxsA3qcBPvK4H5P4juGTe6eg1lkygvzFpNW36B9lsE4="; }; nativeBuildInputs = [ @@ -44,7 +45,7 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = "File system visualizer in cyberspace"; + description = "File system visualizer in cyberspace"; longDescription = '' fsv (pronounced eff-ess-vee) is a file system visualizer in cyberspace. It lays out files and directories in three dimensions, geometrically @@ -53,9 +54,9 @@ stdenv.mkDerivation rec { hard drive, or any arbitrarily large collection of files, limited only by the host computer's memory and graphics hardware. ''; - homepage = "https://github.com/jabl/fsv"; - license = licenses.lgpl2; - platforms = platforms.linux; + homepage = "https://github.com/jabl/fsv"; + license = licenses.lgpl2; + platforms = platforms.linux; maintainers = with maintainers; [ rnhmjoj ]; mainProgram = "fsv"; }; diff --git a/pkgs/by-name/fs/fsverity-utils/package.nix b/pkgs/by-name/fs/fsverity-utils/package.nix index 911b1f1fa1953e..4ef7a2357b83ca 100644 --- a/pkgs/by-name/fs/fsverity-utils/package.nix +++ b/pkgs/by-name/fs/fsverity-utils/package.nix @@ -1,17 +1,22 @@ -{ stdenv -, lib -, fetchzip -, openssl -, enableShared ? !stdenv.hostPlatform.isStatic -, enableManpages ? false -, pandoc +{ + stdenv, + lib, + fetchzip, + openssl, + enableShared ? !stdenv.hostPlatform.isStatic, + enableManpages ? false, + pandoc, }: stdenv.mkDerivation rec { pname = "fsverity-utils"; version = "1.6"; - outputs = [ "out" "lib" "dev" ] ++ lib.optional enableManpages "man"; + outputs = [ + "out" + "lib" + "dev" + ] ++ lib.optional enableManpages "man"; src = fetchzip { url = "https://git.kernel.org/pub/scm/fs/fsverity/fsverity-utils.git/snapshot/fsverity-utils-v${version}.tar.gz"; @@ -28,7 +33,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = lib.optional enableManpages pandoc; buildInputs = [ openssl ]; - makeFlags = [ "DESTDIR=$(out)" "PREFIX=" ] ++ lib.optional enableShared "USE_SHARED_LIB=1"; + makeFlags = [ + "DESTDIR=$(out)" + "PREFIX=" + ] ++ lib.optional enableShared "USE_SHARED_LIB=1"; doCheck = true; diff --git a/pkgs/by-name/fs/fswebcam/package.nix b/pkgs/by-name/fs/fswebcam/package.nix index 08b1b9935291e7..131e256f0eef7b 100644 --- a/pkgs/by-name/fs/fswebcam/package.nix +++ b/pkgs/by-name/fs/fswebcam/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libv4l, gd }: +{ + lib, + stdenv, + fetchurl, + libv4l, + gd, +}: stdenv.mkDerivation rec { pname = "fswebcam"; @@ -9,8 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1dazsrcaw9s30zz3jpxamk9lkff5dkmflp1s0jjjvdbwa0k6k6ii"; }; - buildInputs = - [ libv4l gd ]; + buildInputs = [ + libv4l + gd + ]; meta = { description = "Neat and simple webcam app"; diff --git a/pkgs/by-name/ft/ftgl/package.nix b/pkgs/by-name/ft/ftgl/package.nix index 506a756ba2e704..2c05f30f3d7293 100644 --- a/pkgs/by-name/ft/ftgl/package.nix +++ b/pkgs/by-name/ft/ftgl/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, doxygen -, libglut -, freetype -, libGL -, libGLU -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + doxygen, + libglut, + freetype, + libGL, + libGLU, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ft/ftop/package.nix b/pkgs/by-name/ft/ftop/package.nix index b199c84b9fb521..f507e3cfb61bb6 100644 --- a/pkgs/by-name/ft/ftop/package.nix +++ b/pkgs/by-name/ft/ftop/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "ftop"; diff --git a/pkgs/by-name/ft/ftxui/package.nix b/pkgs/by-name/ft/ftxui/package.nix index a911e5ba373690..40d31ec7d6a041 100644 --- a/pkgs/by-name/ft/ftxui/package.nix +++ b/pkgs/by-name/ft/ftxui/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, doxygen -, gbenchmark -, graphviz -, gtest +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + doxygen, + gbenchmark, + graphviz, + gtest, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fu/fuc/package.nix b/pkgs/by-name/fu/fuc/package.nix index 5a2f88fcb8f769..771e7e861fed09 100644 --- a/pkgs/by-name/fu/fuc/package.nix +++ b/pkgs/by-name/fu/fuc/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, clippy -, rustfmt +{ + lib, + rustPlatform, + fetchFromGitHub, + clippy, + rustfmt, }: rustPlatform.buildRustPackage rec { @@ -20,9 +21,16 @@ rustPlatform.buildRustPackage rec { RUSTC_BOOTSTRAP = 1; - cargoBuildFlags = [ "--workspace" "--bin cpz" "--bin rmz" ]; + cargoBuildFlags = [ + "--workspace" + "--bin cpz" + "--bin rmz" + ]; - nativeCheckInputs = [ clippy rustfmt ]; + nativeCheckInputs = [ + clippy + rustfmt + ]; meta = with lib; { description = "Modern, performance focused unix commands"; diff --git a/pkgs/by-name/fu/fuchsia-cursor/package.nix b/pkgs/by-name/fu/fuchsia-cursor/package.nix index 990414e219c9e4..2d567fd3341076 100644 --- a/pkgs/by-name/fu/fuchsia-cursor/package.nix +++ b/pkgs/by-name/fu/fuchsia-cursor/package.nix @@ -1,60 +1,79 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, clickgen -, python3 -, themeVariants ? [] -, sizeVariants ? [] -, platformVariants ? [] +{ + lib, + stdenvNoCC, + fetchFromGitHub, + clickgen, + python3, + themeVariants ? [ ], + sizeVariants ? [ ], + platformVariants ? [ ], }: let pname = "fuchsia-cursor"; in -lib.checkListOfEnum "${pname}: theme variants" [ "Fuchsia" "Fuchsia-Pop" "Fuchsia-Red" ] themeVariants -lib.checkListOfEnum "${pname}: size variants" [ "16" "24" "32" "48" ] sizeVariants -lib.checkListOfEnum "${pname}: platform variants" [ "x11" "windows" ] platformVariants - -stdenvNoCC.mkDerivation rec { - inherit pname; - version = "2.0.0"; - - src = fetchFromGitHub { - owner = "ful1e5"; - repo = "fuchsia-cursor"; - rev = "v${version}"; - hash = "sha256-WnDtUsjRXT7bMppgwU5BIDqphP69DmPzQM/0qXES5tM="; - }; - - nativeBuildInputs = [ - clickgen - python3.pkgs.attrs - ]; - - installPhase = '' - runHook preInstall - - ${if themeVariants != [] then '' - name= ctgen build.toml \ - ${lib.optionalString (themeVariants != []) "-d bitmaps/" + toString themeVariants + " -n " + toString themeVariants} \ - ${lib.optionalString (sizeVariants != []) "-s " + toString sizeVariants} \ - ${lib.optionalString (platformVariants != []) "-p " + toString platformVariants} \ - -o $out/share/icons - '' else '' - name= ctgen build.toml -d bitmaps/Fuchsia -n Fuchsia \ - ${lib.optionalString (sizeVariants != []) "-s " + toString sizeVariants} \ - ${lib.optionalString (platformVariants != []) "-p " + toString platformVariants} \ - -o $out/share/icons - ''} - - runHook postInstall - ''; - - meta = with lib; { - description = "First OpenSource port of FuchsiaOS's cursors for Linux and Windows"; - homepage = "https://github.com/ful1e5/fuchsia-cursor"; - maintainers = with maintainers; [ d3vil0p3r ]; - platforms = platforms.all; - license = licenses.gpl3Plus; - }; -} +lib.checkListOfEnum "${pname}: theme variants" [ "Fuchsia" "Fuchsia-Pop" "Fuchsia-Red" ] + themeVariants + lib.checkListOfEnum + "${pname}: size variants" + [ "16" "24" "32" "48" ] + sizeVariants + lib.checkListOfEnum + "${pname}: platform variants" + [ "x11" "windows" ] + platformVariants + + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "2.0.0"; + + src = fetchFromGitHub { + owner = "ful1e5"; + repo = "fuchsia-cursor"; + rev = "v${version}"; + hash = "sha256-WnDtUsjRXT7bMppgwU5BIDqphP69DmPzQM/0qXES5tM="; + }; + + nativeBuildInputs = [ + clickgen + python3.pkgs.attrs + ]; + + installPhase = '' + runHook preInstall + + ${ + if themeVariants != [ ] then + '' + name= ctgen build.toml \ + ${ + lib.optionalString (themeVariants != [ ]) "-d bitmaps/" + + toString themeVariants + + " -n " + + toString themeVariants + } \ + ${lib.optionalString (sizeVariants != [ ]) "-s " + toString sizeVariants} \ + ${lib.optionalString (platformVariants != [ ]) "-p " + toString platformVariants} \ + -o $out/share/icons + '' + else + '' + name= ctgen build.toml -d bitmaps/Fuchsia -n Fuchsia \ + ${lib.optionalString (sizeVariants != [ ]) "-s " + toString sizeVariants} \ + ${lib.optionalString (platformVariants != [ ]) "-p " + toString platformVariants} \ + -o $out/share/icons + '' + } + + runHook postInstall + ''; + + meta = with lib; { + description = "First OpenSource port of FuchsiaOS's cursors for Linux and Windows"; + homepage = "https://github.com/ful1e5/fuchsia-cursor"; + maintainers = with maintainers; [ d3vil0p3r ]; + platforms = platforms.all; + license = licenses.gpl3Plus; + }; + } diff --git a/pkgs/by-name/fu/funambol/package.nix b/pkgs/by-name/fu/funambol/package.nix index 1ee66e008fefe4..ae746d0be3ba0f 100644 --- a/pkgs/by-name/fu/funambol/package.nix +++ b/pkgs/by-name/fu/funambol/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, zlib, curl, autoreconfHook, unzip }: +{ + lib, + stdenv, + fetchurl, + zlib, + curl, + autoreconfHook, + unzip, +}: stdenv.mkDerivation rec { pname = "funambol-client-cpp"; @@ -11,9 +19,15 @@ stdenv.mkDerivation rec { postUnpack = ''sourceRoot+="/sdk/cpp/build/autotools"''; - propagatedBuildInputs = [ zlib curl ]; + propagatedBuildInputs = [ + zlib + curl + ]; - nativeBuildInputs = [ autoreconfHook unzip ]; + nativeBuildInputs = [ + autoreconfHook + unzip + ]; meta = with lib; { description = "SyncML client sdk by Funambol project"; diff --git a/pkgs/by-name/fu/func/package.nix b/pkgs/by-name/fu/func/package.nix index c31f5c9b06e1c7..0d6f02a6954895 100644 --- a/pkgs/by-name/fu/func/package.nix +++ b/pkgs/by-name/fu/func/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, testers, func }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + func, +}: buildGoModule rec { pname = "func"; @@ -23,7 +30,6 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - postInstall = '' installShellCompletion --cmd func \ --bash <($out/bin/func completion bash) \ diff --git a/pkgs/by-name/fu/functionalplus/package.nix b/pkgs/by-name/fu/functionalplus/package.nix index e07fa8fec5f262..e86e15666de881 100644 --- a/pkgs/by-name/fu/functionalplus/package.nix +++ b/pkgs/by-name/fu/functionalplus/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "functionalplus"; diff --git a/pkgs/by-name/fu/functiontrace-server/package.nix b/pkgs/by-name/fu/functiontrace-server/package.nix index efb5026e069e33..2a3a889ee6e8d2 100644 --- a/pkgs/by-name/fu/functiontrace-server/package.nix +++ b/pkgs/by-name/fu/functiontrace-server/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchCrate, stdenv, darwin }: +{ + lib, + rustPlatform, + fetchCrate, + stdenv, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "functiontrace-server"; @@ -11,8 +17,9 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-3tLjW7yiS1dNsV81KUZbfN2pvYT9kqiC62nWFid2NH8="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin - [ darwin.apple_sdk.frameworks.CoreFoundation ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreFoundation + ]; meta = with lib; { description = "Server for FunctionTrace, a graphical Python profiler"; diff --git a/pkgs/by-name/fu/fundoc/package.nix b/pkgs/by-name/fu/fundoc/package.nix index 72c572e3e4f191..8b789368157928 100644 --- a/pkgs/by-name/fu/fundoc/package.nix +++ b/pkgs/by-name/fu/fundoc/package.nix @@ -1,4 +1,9 @@ -{ lib, rustPlatform, fetchFromGitHub, fetchpatch }: +{ + lib, + rustPlatform, + fetchFromGitHub, + fetchpatch, +}: rustPlatform.buildRustPackage rec { pname = "fundoc"; diff --git a/pkgs/by-name/fu/funnelweb/package.nix b/pkgs/by-name/fu/funnelweb/package.nix index 10b4880df7cd21..14e52ff56b25c8 100644 --- a/pkgs/by-name/fu/funnelweb/package.nix +++ b/pkgs/by-name/fu/funnelweb/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "funnelweb"; diff --git a/pkgs/by-name/fu/funzzy/package.nix b/pkgs/by-name/fu/funzzy/package.nix index a5b830a8747805..26b56805aa6641 100644 --- a/pkgs/by-name/fu/funzzy/package.nix +++ b/pkgs/by-name/fu/funzzy/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/fu/furnace/package.nix b/pkgs/by-name/fu/furnace/package.nix index 8b9428c6b23920..62d60e8abbcd4e 100644 --- a/pkgs/by-name/fu/furnace/package.nix +++ b/pkgs/by-name/fu/furnace/package.nix @@ -1,29 +1,30 @@ -{ stdenv -, lib -, testers -, furnace -, fetchFromGitHub -, cmake -, pkg-config -, makeWrapper -, fftw -, fmt -, freetype -, libsndfile -, libX11 -, rtmidi -, SDL2 -, zlib -, withJACK ? stdenv.hostPlatform.isUnix -, libjack2 -, withGUI ? true -, darwin -, portaudio -, alsa-lib -# Enable GL/GLES rendering -, withGL ? !stdenv.hostPlatform.isDarwin -# Use GLES instead of GL, some platforms have better support for one than the other -, preferGLES ? stdenv.hostPlatform.isAarch +{ + stdenv, + lib, + testers, + furnace, + fetchFromGitHub, + cmake, + pkg-config, + makeWrapper, + fftw, + fmt, + freetype, + libsndfile, + libX11, + rtmidi, + SDL2, + zlib, + withJACK ? stdenv.hostPlatform.isUnix, + libjack2, + withGUI ? true, + darwin, + portaudio, + alsa-lib, + # Enable GL/GLES rendering + withGL ? !stdenv.hostPlatform.isDarwin, + # Use GLES instead of GL, some platforms have better support for one than the other + preferGLES ? stdenv.hostPlatform.isAarch, }: stdenv.mkDerivation (finalAttrs: { @@ -45,30 +46,39 @@ stdenv.mkDerivation (finalAttrs: { --replace-fail 'libX11.so' '${lib.getLib libX11}/lib/libX11.so' ''; - nativeBuildInputs = [ - cmake - pkg-config - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - makeWrapper - ]; + nativeBuildInputs = + [ + cmake + pkg-config + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + makeWrapper + ]; - buildInputs = [ - fftw - fmt - freetype - libsndfile - rtmidi - SDL2 - zlib - portaudio - ] ++ lib.optionals withJACK [ - libjack2 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - # portaudio pkg-config is pulling this in as a link dependency, not set in propagatedBuildInputs - alsa-lib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - Cocoa - ]); + buildInputs = + [ + fftw + fmt + freetype + libsndfile + rtmidi + SDL2 + zlib + portaudio + ] + ++ lib.optionals withJACK [ + libjack2 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + # portaudio pkg-config is pulling this in as a link dependency, not set in propagatedBuildInputs + alsa-lib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Cocoa + ] + ); cmakeFlags = [ (lib.cmakeBool "BUILD_GUI" withGUI) diff --git a/pkgs/by-name/fu/furtherance/package.nix b/pkgs/by-name/fu/furtherance/package.nix index 15616f32bebd9a..a983b914cae695 100644 --- a/pkgs/by-name/fu/furtherance/package.nix +++ b/pkgs/by-name/fu/furtherance/package.nix @@ -1,7 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform -, appstream-glib, cargo, desktop-file-utils, glib, libadwaita, meson, ninja -, pkg-config, rustc, wrapGAppsHook4 -, dbus, gtk4, sqlite +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + appstream-glib, + cargo, + desktop-file-utils, + glib, + libadwaita, + meson, + ninja, + pkg-config, + rustc, + wrapGAppsHook4, + dbus, + gtk4, + sqlite, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/fu/fuse-7z-ng/package.nix b/pkgs/by-name/fu/fuse-7z-ng/package.nix index 1c5b7b1d038f8b..f24d5b76ed9290 100644 --- a/pkgs/by-name/fu/fuse-7z-ng/package.nix +++ b/pkgs/by-name/fu/fuse-7z-ng/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fuse, p7zip, autoconf, automake, pkg-config, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + fuse, + p7zip, + autoconf, + automake, + pkg-config, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "fuse-7z-ng"; @@ -20,7 +30,12 @@ stdenv.mkDerivation rec { ./zero-init-fuse-operations.patch ]; - nativeBuildInputs = [ pkg-config makeWrapper autoconf automake ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + autoconf + automake + ]; buildInputs = [ fuse ]; preConfigure = "./autogen.sh"; diff --git a/pkgs/by-name/fu/fuse-archive/package.nix b/pkgs/by-name/fu/fuse-archive/package.nix index 58f48a26449835..3313de11477dab 100644 --- a/pkgs/by-name/fu/fuse-archive/package.nix +++ b/pkgs/by-name/fu/fuse-archive/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, fuse -, libarchive -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + fuse, + libarchive, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fu/fuse-emulator/package.nix b/pkgs/by-name/fu/fuse-emulator/package.nix index 3ed4ffc9c0731d..e23b1a1e64ce23 100644 --- a/pkgs/by-name/fu/fuse-emulator/package.nix +++ b/pkgs/by-name/fu/fuse-emulator/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchurl, perl, pkg-config, wrapGAppsHook3 -, SDL, bzip2, glib, gtk3, libgcrypt, libpng, libspectrum, libxml2, zlib +{ + lib, + stdenv, + fetchurl, + perl, + pkg-config, + wrapGAppsHook3, + SDL, + bzip2, + glib, + gtk3, + libgcrypt, + libpng, + libspectrum, + libxml2, + zlib, }: stdenv.mkDerivation rec { @@ -11,9 +25,23 @@ stdenv.mkDerivation rec { sha256 = "sha256-Oo/t8v/pR8VxVhusVaWa2tTFkzj3TkSbfnpn2coEcJY="; }; - nativeBuildInputs = [ perl pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + perl + pkg-config + wrapGAppsHook3 + ]; - buildInputs = [ SDL bzip2 glib gtk3 libgcrypt libpng libspectrum libxml2 zlib ]; + buildInputs = [ + SDL + bzip2 + glib + gtk3 + libgcrypt + libpng + libspectrum + libxml2 + zlib + ]; configureFlags = [ "--enable-desktop-integration" ]; diff --git a/pkgs/by-name/fu/fuse-overlayfs/package.nix b/pkgs/by-name/fu/fuse-overlayfs/package.nix index def4a793896290..1bc41f1e0624f6 100644 --- a/pkgs/by-name/fu/fuse-overlayfs/package.nix +++ b/pkgs/by-name/fu/fuse-overlayfs/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, fuse3, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + fuse3, + nixosTests, +}: stdenv.mkDerivation rec { pname = "fuse-overlayfs"; @@ -11,7 +19,10 @@ stdenv.mkDerivation rec { hash = "sha256-A70AxYPKph/5zRNFRDWrwl8Csc8Vf1gmOLJ39ixJgL0="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ fuse3 ]; diff --git a/pkgs/by-name/fu/fusee-interfacee-tk/package.nix b/pkgs/by-name/fu/fusee-interfacee-tk/package.nix index a7e19ed8af5726..39766ddb4e5ab7 100644 --- a/pkgs/by-name/fu/fusee-interfacee-tk/package.nix +++ b/pkgs/by-name/fu/fusee-interfacee-tk/package.nix @@ -1,7 +1,18 @@ -{ lib, stdenv , fetchFromGitHub , python3 , makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + makeWrapper, +}: -let pythonEnv = python3.withPackages(ps: [ ps.tkinter ps.pyusb ]); -in stdenv.mkDerivation rec { +let + pythonEnv = python3.withPackages (ps: [ + ps.tkinter + ps.pyusb + ]); +in +stdenv.mkDerivation rec { pname = "fusee-interfacee-tk"; version = "1.0.1"; diff --git a/pkgs/by-name/fu/fusee-launcher/package.nix b/pkgs/by-name/fu/fusee-launcher/package.nix index 776f5c064aefb2..917d6fd4aa7e8e 100644 --- a/pkgs/by-name/fu/fusee-launcher/package.nix +++ b/pkgs/by-name/fu/fusee-launcher/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, python3Packages -, python3 -, fetchFromGitHub -, pkgsCross -, makeWrapper -} : +{ + lib, + stdenv, + python3Packages, + python3, + fetchFromGitHub, + pkgsCross, + makeWrapper, +}: let arm-embedded-cc = pkgsCross.arm-embedded.buildPackages.gcc; @@ -36,8 +38,15 @@ stdenv.mkDerivation { --prefix PYTHONPATH : "$PYTHONPATH:$(toPythonPath $out)" ''; - nativeBuildInputs = [ arm-embedded-cc makeWrapper python3Packages.wrapPython ]; - buildInputs = [ python3 python3Packages.pyusb ]; + nativeBuildInputs = [ + arm-embedded-cc + makeWrapper + python3Packages.wrapPython + ]; + buildInputs = [ + python3 + python3Packages.pyusb + ]; pythonPath = with python3Packages; [ pyusb ]; meta = with lib; { diff --git a/pkgs/by-name/fu/fusee-nano/package.nix b/pkgs/by-name/fu/fusee-nano/package.nix index fc06232770741d..ca75ded59699e2 100644 --- a/pkgs/by-name/fu/fusee-nano/package.nix +++ b/pkgs/by-name/fu/fusee-nano/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, unixtools }: +{ + lib, + stdenv, + fetchFromGitHub, + unixtools, +}: stdenv.mkDerivation { pname = "fusee-nano"; diff --git a/pkgs/by-name/fu/fuseiso/package.nix b/pkgs/by-name/fu/fuseiso/package.nix index a2d42bb5a2a7d6..413a58e6fcdfee 100644 --- a/pkgs/by-name/fu/fuseiso/package.nix +++ b/pkgs/by-name/fu/fuseiso/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, fetchpatch, autoreconfHook, pkg-config, fuse, glib, zlib }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + pkg-config, + fuse, + glib, + zlib, +}: stdenv.mkDerivation rec { pname = "fuseiso"; @@ -32,9 +42,16 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ fuse glib zlib ]; + buildInputs = [ + fuse + glib + zlib + ]; # after autoreconfHook, glib and zlib are not found, so force link against # them diff --git a/pkgs/by-name/fu/fusionInventory/package.nix b/pkgs/by-name/fu/fusionInventory/package.nix index b4535c80877de3..4c73b269217c6d 100644 --- a/pkgs/by-name/fu/fusionInventory/package.nix +++ b/pkgs/by-name/fu/fusionInventory/package.nix @@ -1,5 +1,14 @@ -{ lib, perlPackages, nix, dmidecode, pciutils, usbutils, iproute2, nettools -, fetchFromGitHub, makeWrapper +{ + lib, + perlPackages, + nix, + dmidecode, + pciutils, + usbutils, + iproute2, + nettools, + fetchFromGitHub, + makeWrapper, }: perlPackages.buildPerlPackage rec { @@ -23,29 +32,32 @@ perlPackages.buildPerlPackage rec { --replace /sbin/ip ${iproute2}/sbin/ip ''; - buildTools = []; + buildTools = [ ]; nativeBuildInputs = [ makeWrapper ]; - buildInputs = (with perlPackages; [ - CGI - DataStructureUtil - FileCopyRecursive - HTTPProxy - HTTPServerSimple - HTTPServerSimpleAuthen - IOCapture - IOSocketSSL - IPCRun - JSON - LWPProtocolHttps - ModuleInstall - NetSNMP - TestCompile - TestDeep - TestException - TestMockModule - TestMockObject - TestNoWarnings - ]); + buildInputs = ( + with perlPackages; + [ + CGI + DataStructureUtil + FileCopyRecursive + HTTPProxy + HTTPServerSimple + HTTPServerSimpleAuthen + IOCapture + IOSocketSSL + IPCRun + JSON + LWPProtocolHttps + ModuleInstall + NetSNMP + TestCompile + TestDeep + TestException + TestMockModule + TestMockObject + TestNoWarnings + ] + ); propagatedBuildInputs = with perlPackages; [ FileWhich LWP @@ -68,7 +80,16 @@ perlPackages.buildPerlPackage rec { for cur in $out/bin/*; do if [ -x "$cur" ]; then sed -e "s|./lib|$out/lib|" -i "$cur" - wrapProgram "$cur" --prefix PATH : ${lib.makeBinPath [nix dmidecode pciutils usbutils nettools iproute2]} + wrapProgram "$cur" --prefix PATH : ${ + lib.makeBinPath [ + nix + dmidecode + pciutils + usbutils + nettools + iproute2 + ] + } fi done ''; diff --git a/pkgs/by-name/fu/fusuma/gemset.nix b/pkgs/by-name/fu/fusuma/gemset.nix index e5f895c4b74c4f..f1664a2149cc31 100644 --- a/pkgs/by-name/fu/fusuma/gemset.nix +++ b/pkgs/by-name/fu/fusuma/gemset.nix @@ -1,95 +1,102 @@ { fusuma = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vxlfda4mgff9kindrmr47xvn6b591hzvzzsx2y88zq20sn340vy"; type = "gem"; }; version = "3.5.0"; }; fusuma-plugin-appmatcher = { - dependencies = ["fusuma" "rexml" "ruby-dbus"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "fusuma" + "rexml" + "ruby-dbus" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cj3d1yz3jdxmapgk8wv5ra57nyb278x2fjxdllc0gqdfih6pxhq"; type = "gem"; }; version = "0.7.1"; }; fusuma-plugin-keypress = { - dependencies = ["fusuma"]; - groups = ["default"]; - platforms = []; + dependencies = [ "fusuma" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16csdj695y9b8bvl65cby57fsyfr30pb9qq6h0wyqrxily6cn6il"; type = "gem"; }; version = "0.11.0"; }; fusuma-plugin-sendkey = { - dependencies = ["fusuma" "revdev"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "fusuma" + "revdev" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rdpxq4nanw85x1djdanwnz46b19fr46kdlkkgbxa4dnjk0zx4pp"; type = "gem"; }; version = "0.10.1"; }; fusuma-plugin-wmctrl = { - dependencies = ["fusuma"]; - groups = ["default"]; - platforms = []; + dependencies = [ "fusuma" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rgz1d6ahg5i9sr4z2kab5qk7pm3rm0h7r1vwkygi75rv2r3jy86"; type = "gem"; }; version = "1.3.1"; }; revdev = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1b6zg6vqlaik13fqxxcxhd4qnkfgdjnl4wy3a1q67281bl0qpsz9"; type = "gem"; }; version = "0.2.1"; }; rexml = { - dependencies = ["strscan"]; - groups = ["default"]; - platforms = []; + dependencies = [ "strscan" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0d8ivcirrrxpkpjc1c835wknc9s2fl54xpw08s177yfrh5ish209"; type = "gem"; }; version = "3.2.8"; }; ruby-dbus = { - dependencies = ["rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rexml" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hf9y5lbi1xcadc2fw87wlif75s1359c2wwlvvd0gag7cq5dm0pm"; type = "gem"; }; version = "0.23.1"; }; strscan = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mamrl7pxacbc79ny5hzmakc9grbjysm3yy6119ppgsg44fsif01"; type = "gem"; }; diff --git a/pkgs/by-name/fu/fusuma/package.nix b/pkgs/by-name/fu/fusuma/package.nix index 0622ce699f8c29..e43f5b7f0ca049 100644 --- a/pkgs/by-name/fu/fusuma/package.nix +++ b/pkgs/by-name/fu/fusuma/package.nix @@ -1,4 +1,11 @@ -{ lib, bundlerApp, bundlerUpdateScript, makeWrapper, gnugrep, libinput }: +{ + lib, + bundlerApp, + bundlerUpdateScript, + makeWrapper, + gnugrep, + libinput, +}: bundlerApp { pname = "fusuma"; @@ -9,7 +16,12 @@ bundlerApp { postBuild = '' wrapProgram "$out/bin/fusuma" \ - --prefix PATH : ${lib.makeBinPath [ gnugrep libinput ]} + --prefix PATH : ${ + lib.makeBinPath [ + gnugrep + libinput + ] + } ''; passthru.updateScript = bundlerUpdateScript "fusuma"; @@ -18,7 +30,10 @@ bundlerApp { description = "Multitouch gestures with libinput driver on X11, Linux"; homepage = "https://github.com/iberianpig/fusuma"; license = licenses.mit; - maintainers = with maintainers; [ nicknovitski Br1ght0ne ]; + maintainers = with maintainers; [ + nicknovitski + Br1ght0ne + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/fu/fuzzel/package.nix b/pkgs/by-name/fu/fuzzel/package.nix index 1944c91ba064b7..beb5d346dbcb96 100644 --- a/pkgs/by-name/fu/fuzzel/package.nix +++ b/pkgs/by-name/fu/fuzzel/package.nix @@ -1,25 +1,26 @@ -{ stdenv -, lib -, fetchFromGitea -, pkg-config -, meson -, ninja -, wayland-scanner -, wayland -, pixman -, wayland-protocols -, libxkbcommon -, scdoc -, tllist -, fcft -, enableCairo ? true -, pngSupport ? true -, svgSupport ? true -, svgBackend ? "nanosvg" # alternative: "librsvg" +{ + stdenv, + lib, + fetchFromGitea, + pkg-config, + meson, + ninja, + wayland-scanner, + wayland, + pixman, + wayland-protocols, + libxkbcommon, + scdoc, + tllist, + fcft, + enableCairo ? true, + pngSupport ? true, + svgSupport ? true, + svgBackend ? "nanosvg", # alternative: "librsvg" # Optional dependencies -, cairo -, libpng -, librsvg + cairo, + libpng, + librsvg, }: assert (svgSupport && svgBackend == "nanosvg") -> enableCairo; @@ -48,16 +49,18 @@ stdenv.mkDerivation (finalAttrs: { scdoc ]; - buildInputs = [ - wayland - pixman - wayland-protocols - libxkbcommon - tllist - fcft - ] ++ lib.optional enableCairo cairo - ++ lib.optional pngSupport libpng - ++ lib.optional (svgSupport && svgBackend == "librsvg") librsvg; + buildInputs = + [ + wayland + pixman + wayland-protocols + libxkbcommon + tllist + fcft + ] + ++ lib.optional enableCairo cairo + ++ lib.optional pngSupport libpng + ++ lib.optional (svgSupport && svgBackend == "librsvg") librsvg; mesonBuildType = "release"; @@ -71,9 +74,15 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://codeberg.org/dnkl/fuzzel/releases/tag/${finalAttrs.version}"; description = "Wayland-native application launcher, similar to rofi’s drun mode"; homepage = "https://codeberg.org/dnkl/fuzzel"; - license = with licenses; [ mit zlib ]; + license = with licenses; [ + mit + zlib + ]; mainProgram = "fuzzel"; - maintainers = with maintainers; [ fionera rodrgz ]; + maintainers = with maintainers; [ + fionera + rodrgz + ]; platforms = with platforms; linux; }; }) diff --git a/pkgs/by-name/fu/fuzzylite/package.nix b/pkgs/by-name/fu/fuzzylite/package.nix index 82f11abe88e63a..3bdc571d12c501 100644 --- a/pkgs/by-name/fu/fuzzylite/package.nix +++ b/pkgs/by-name/fu/fuzzylite/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -, useFloat ? false +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + useFloat ? false, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { }; sourceRoot = "${src.name}/fuzzylite"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postPatch = '' substituteInPlace CMakeLists.txt \ diff --git a/pkgs/by-name/fv/fverb/package.nix b/pkgs/by-name/fv/fverb/package.nix index 6d28b8e88bf9c0..0c81aeff3df05c 100644 --- a/pkgs/by-name/fv/fverb/package.nix +++ b/pkgs/by-name/fv/fverb/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, }: stdenv.mkDerivation rec { @@ -29,6 +31,6 @@ stdenv.mkDerivation rec { homepage = "https://github.com/jpcima/fverb"; license = licenses.bsd2; maintainers = [ maintainers.magnetophon ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/fv/fvwm2/package.nix b/pkgs/by-name/fv/fvwm2/package.nix index 5a645c835c01be..2a7919004d5d68 100644 --- a/pkgs/by-name/fv/fvwm2/package.nix +++ b/pkgs/by-name/fv/fvwm2/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, cairo -, fontconfig -, freetype -, fribidi -, libXcursor -, libXft -, libXinerama -, libXpm -, libXt -, libpng -, librsvg -, libstroke -, libxslt -, perl -, pkg-config -, python3Packages -, readline -, enableGestures ? false +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + cairo, + fontconfig, + freetype, + fribidi, + libXcursor, + libXft, + libXinerama, + libXpm, + libXt, + libpng, + librsvg, + libstroke, + libxslt, + perl, + pkg-config, + python3Packages, + readline, + enableGestures ? false, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fv/fvwm3/package.nix b/pkgs/by-name/fv/fvwm3/package.nix index 613334610316b6..93d2fbb32ae08b 100644 --- a/pkgs/by-name/fv/fvwm3/package.nix +++ b/pkgs/by-name/fv/fvwm3/package.nix @@ -1,31 +1,32 @@ -{ lib -, asciidoctor -, autoreconfHook -, cairo -, fetchFromGitHub -, fontconfig -, freetype -, fribidi -, libSM -, libX11 -, libXcursor -, libXft -, libXi -, libXinerama -, libXpm -, libXrandr -, libXt -, libevent -, libintl -, libpng -, librsvg -, libxslt -, perl -, pkg-config -, python3Packages -, readline -, sharutils -, stdenv +{ + lib, + asciidoctor, + autoreconfHook, + cairo, + fetchFromGitHub, + fontconfig, + freetype, + fribidi, + libSM, + libX11, + libXcursor, + libXft, + libXi, + libXinerama, + libXpm, + libXrandr, + libXt, + libevent, + libintl, + libpng, + librsvg, + libxslt, + perl, + pkg-config, + python3Packages, + readline, + sharutils, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/fw/fw-ectool/package.nix b/pkgs/by-name/fw/fw-ectool/package.nix index dd24730104f36f..bd1bc0bfea98a4 100644 --- a/pkgs/by-name/fw/fw-ectool/package.nix +++ b/pkgs/by-name/fw/fw-ectool/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitLab -, cmake -, pkg-config -, libusb1 -, libftdi1 +{ + stdenv, + lib, + fetchFromGitLab, + cmake, + pkg-config, + libusb1, + libftdi1, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/fw/fw/package.nix b/pkgs/by-name/fw/fw/package.nix index 7855747c59996a..ddc3b28bf6555b 100644 --- a/pkgs/by-name/fw/fw/package.nix +++ b/pkgs/by-name/fw/fw/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libgit2 -, openssl -, zlib -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libgit2, + openssl, + zlib, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -26,13 +27,15 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - libgit2 - openssl - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + libgit2 + openssl + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; env = { OPENSSL_NO_VENDOR = true; diff --git a/pkgs/by-name/fw/fwanalyzer/package.nix b/pkgs/by-name/fw/fwanalyzer/package.nix index 26fd45fa90eaae..667c558f9693a4 100644 --- a/pkgs/by-name/fw/fwanalyzer/package.nix +++ b/pkgs/by-name/fw/fwanalyzer/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, e2tools -, makeWrapper -, mtools +{ + lib, + buildGoModule, + fetchFromGitHub, + e2tools, + makeWrapper, + mtools, }: buildGoModule rec { @@ -24,7 +25,12 @@ buildGoModule rec { nativeBuildInputs = [ makeWrapper ]; postInstall = '' - wrapProgram "$out/bin/fwanalyzer" --prefix PATH : "${lib.makeBinPath [ e2tools mtools ]}" + wrapProgram "$out/bin/fwanalyzer" --prefix PATH : "${ + lib.makeBinPath [ + e2tools + mtools + ] + }" ''; # The tests requires an additional setup (unpacking images, etc.) diff --git a/pkgs/by-name/fw/fwupd-efi/package.nix b/pkgs/by-name/fw/fwupd-efi/package.nix index 972f8a9764b58b..f1a125ede9db94 100644 --- a/pkgs/by-name/fw/fwupd-efi/package.nix +++ b/pkgs/by-name/fw/fwupd-efi/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, pkg-config -, meson -, ninja -, gnu-efi -, python3 -, python3Packages +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + meson, + ninja, + gnu-efi, + python3, + python3Packages, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fx/fx/package.nix b/pkgs/by-name/fx/fx/package.nix index cdd3f7a8f7fb34..85130c463ffaf4 100644 --- a/pkgs/by-name/fx/fx/package.nix +++ b/pkgs/by-name/fx/fx/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "fx"; diff --git a/pkgs/by-name/fx/fxlinuxprint/package.nix b/pkgs/by-name/fx/fxlinuxprint/package.nix index 4c64152e6c9290..705a4beeba237d 100644 --- a/pkgs/by-name/fx/fxlinuxprint/package.nix +++ b/pkgs/by-name/fx/fxlinuxprint/package.nix @@ -1,9 +1,19 @@ -{ stdenv, lib, fetchzip, dpkg, autoPatchelfHook, cups }: +{ + stdenv, + lib, + fetchzip, + dpkg, + autoPatchelfHook, + cups, +}: let debPlatform = - if stdenv.hostPlatform.system == "x86_64-linux" then "amd64" - else if stdenv.hostPlatform.system == "i686-linux" then "i386" - else throw "Unsupported system: ${stdenv.hostPlatform.system}"; + if stdenv.hostPlatform.system == "x86_64-linux" then + "amd64" + else if stdenv.hostPlatform.system == "i686-linux" then + "i386" + else + throw "Unsupported system: ${stdenv.hostPlatform.system}"; in stdenv.mkDerivation rec { pname = "fxlinuxprint"; @@ -15,7 +25,10 @@ stdenv.mkDerivation rec { sha256 = "1mv07ch6ysk9bknfmjqsgxb803sj6vfin29s9knaqv17jvgyh0n3"; }; - nativeBuildInputs = [ dpkg autoPatchelfHook ]; + nativeBuildInputs = [ + dpkg + autoPatchelfHook + ]; buildInputs = [ cups ]; sourceRoot = "."; diff --git a/pkgs/by-name/fx/fxlinuxprintutil/package.nix b/pkgs/by-name/fx/fxlinuxprintutil/package.nix index edb2ca73737d85..7d3ddd08ac6e88 100644 --- a/pkgs/by-name/fx/fxlinuxprintutil/package.nix +++ b/pkgs/by-name/fx/fxlinuxprintutil/package.nix @@ -1,9 +1,24 @@ -{ stdenv, lib, fetchzip, substituteAll, dpkg, autoPatchelfHook, cups, tcl, tk, xorg, makeWrapper }: +{ + stdenv, + lib, + fetchzip, + substituteAll, + dpkg, + autoPatchelfHook, + cups, + tcl, + tk, + xorg, + makeWrapper, +}: let debPlatform = - if stdenv.hostPlatform.system == "x86_64-linux" then "amd64" - else if stdenv.hostPlatform.system == "i686-linux" then "i386" - else throw "Unsupported system: ${stdenv.hostPlatform.system}"; + if stdenv.hostPlatform.system == "x86_64-linux" then + "amd64" + else if stdenv.hostPlatform.system == "i686-linux" then + "i386" + else + throw "Unsupported system: ${stdenv.hostPlatform.system}"; in stdenv.mkDerivation rec { pname = "fxlinuxprintutil"; @@ -32,8 +47,16 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ dpkg autoPatchelfHook makeWrapper ]; - buildInputs = [ cups tcl tk ]; + nativeBuildInputs = [ + dpkg + autoPatchelfHook + makeWrapper + ]; + buildInputs = [ + cups + tcl + tk + ]; sourceRoot = "."; unpackCmd = "dpkg-deb -x $curSrc/fxlinuxprintutil_${version}_${debPlatform}.deb ."; @@ -46,7 +69,12 @@ stdenv.mkDerivation rec { mv usr/bin $out mv usr/lib $out - wrapProgram $out/bin/fxlputil --prefix PATH : ${lib.makeBinPath [ tcl tk ]} + wrapProgram $out/bin/fxlputil --prefix PATH : ${ + lib.makeBinPath [ + tcl + tk + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/fx/fxload/package.nix b/pkgs/by-name/fx/fxload/package.nix index a4b204b571d451..ec4b890563ab21 100644 --- a/pkgs/by-name/fx/fxload/package.nix +++ b/pkgs/by-name/fx/fxload/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, libusb1 +{ + lib, + stdenv, + libusb1, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fy/fypp/package.nix b/pkgs/by-name/fy/fypp/package.nix index fe6cd3267bbbba..391b1f4db6ead0 100644 --- a/pkgs/by-name/fy/fypp/package.nix +++ b/pkgs/by-name/fy/fypp/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3 }: +{ + lib, + fetchFromGitHub, + python3, +}: python3.pkgs.buildPythonApplication rec { pname = "fypp"; diff --git a/pkgs/by-name/fz/fzf-git-sh/package.nix b/pkgs/by-name/fz/fzf-git-sh/package.nix index e9cda521fb1db3..1494216f03e4bd 100644 --- a/pkgs/by-name/fz/fzf-git-sh/package.nix +++ b/pkgs/by-name/fz/fzf-git-sh/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, bash -, bat -, coreutils -, fetchFromGitHub -, findutils -, fzf -, gawk -, git -, gnugrep -, gnused -, tmux -, util-linux -, xdg-utils +{ + stdenv, + lib, + bash, + bat, + coreutils, + fetchFromGitHub, + findutils, + fzf, + gawk, + git, + gnugrep, + gnused, + tmux, + util-linux, + xdg-utils, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/fz/fzf-obc/package.nix b/pkgs/by-name/fz/fzf-obc/package.nix index 7621ae8c73c0aa..549b0d752c2f5a 100644 --- a/pkgs/by-name/fz/fzf-obc/package.nix +++ b/pkgs/by-name/fz/fzf-obc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "fzf-obc"; diff --git a/pkgs/by-name/fz/fzf-zsh/package.nix b/pkgs/by-name/fz/fzf-zsh/package.nix index 089a443a8237bc..1e8dc13d1e2593 100644 --- a/pkgs/by-name/fz/fzf-zsh/package.nix +++ b/pkgs/by-name/fz/fzf-zsh/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fzf }: +{ + lib, + stdenv, + fetchFromGitHub, + fzf, +}: stdenv.mkDerivation rec { pname = "fzf-zsh-unstable"; diff --git a/pkgs/by-name/fz/fzy/package.nix b/pkgs/by-name/fz/fzy/package.nix index ea78b6c963d4d8..98842aa0cb9774 100644 --- a/pkgs/by-name/fz/fzy/package.nix +++ b/pkgs/by-name/fz/fzy/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "fzy"; diff --git a/pkgs/by-name/g-/g-wrap/package.nix b/pkgs/by-name/g-/g-wrap/package.nix index 83028d8fb2e248..4648d800fecb80 100644 --- a/pkgs/by-name/g-/g-wrap/package.nix +++ b/pkgs/by-name/g-/g-wrap/package.nix @@ -1,4 +1,13 @@ -{ fetchurl, lib, stdenv, guile, guile-lib, libffi, pkg-config, glib }: +{ + fetchurl, + lib, + stdenv, + guile, + guile-lib, + libffi, + pkg-config, + glib, +}: stdenv.mkDerivation rec { pname = "g-wrap"; @@ -13,7 +22,11 @@ stdenv.mkDerivation rec { # Note: Glib support is optional, but it's quite useful (e.g., it's used by # Guile-GNOME). - buildInputs = [ guile glib guile-lib ]; + buildInputs = [ + guile + glib + guile-lib + ]; propagatedBuildInputs = [ libffi ]; diff --git a/pkgs/by-name/g1/g15daemon/package.nix b/pkgs/by-name/g1/g15daemon/package.nix index 528b5e0993f54c..cb415da29743f9 100644 --- a/pkgs/by-name/g1/g15daemon/package.nix +++ b/pkgs/by-name/g1/g15daemon/package.nix @@ -1,16 +1,23 @@ -{ stdenv -, lib -, fetchurl -, libusb-compat-0_1 +{ + stdenv, + lib, + fetchurl, + libusb-compat-0_1, }: let license = lib.licenses.gpl2Plus; maintainers = with lib.maintainers; [ peterhoeg ]; - g15src = { pname, version, sha256 }: fetchurl { - url = "mirror://sourceforge/g15tools/${pname}/${version}/${pname}-${version}.tar.bz2"; - inherit sha256; - }; + g15src = + { + pname, + version, + sha256, + }: + fetchurl { + url = "mirror://sourceforge/g15tools/${pname}/${version}/${pname}-${version}.tar.bz2"; + inherit sha256; + }; libg15 = stdenv.mkDerivation rec { pname = "libg15"; @@ -59,13 +66,16 @@ stdenv.mkDerivation rec { sha256 = "1613gsp5dgilwbshqxxhiyw73ksngnam7n1iw6yxdjkp9fyd2a3d"; }; - patches = let - patch = fname: sha256: fetchurl rec { - url = "https://raw.githubusercontent.com/archlinux/svntogit-community/c0b0b6d4d6d7b79eca68123b20e0c9fb82e1c6e1/g15daemon/trunk/${pname}-${version}-${fname}.patch"; - name = "${fname}.patch"; - inherit sha256; - }; - in + patches = + let + patch = + fname: sha256: + fetchurl rec { + url = "https://raw.githubusercontent.com/archlinux/svntogit-community/c0b0b6d4d6d7b79eca68123b20e0c9fb82e1c6e1/g15daemon/trunk/${pname}-${version}-${fname}.patch"; + name = "${fname}.patch"; + inherit sha256; + }; + in [ (patch "uinput" "1misfff7a1vg0qgfk3n25y7drnm86a4gq96iflpcwr5x3lw7q0h7") (patch "config-write" "0jkrbqvzqrvxr14h5qi17cb4d32caq7vw9kzlz3qwpxdgxjrjvy2") @@ -73,7 +83,10 @@ stdenv.mkDerivation rec { ./pid_location.patch ]; - buildInputs = [ libg15 libg15render ]; + buildInputs = [ + libg15 + libg15render + ]; # Workaround build failure on -fno-common toolchains like upstream gcc-10: # ld: g15_plugins.o:/build/g15daemon-1.9.5.3/g15daemon/./g15daemon.h:218: diff --git a/pkgs/by-name/g2/g203-led/package.nix b/pkgs/by-name/g2/g203-led/package.nix index f2db4f58d59182..9cc6a5f9adc922 100644 --- a/pkgs/by-name/g2/g203-led/package.nix +++ b/pkgs/by-name/g2/g203-led/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + python3, }: stdenv.mkDerivation rec { pname = "g203-led"; @@ -13,9 +15,11 @@ stdenv.mkDerivation rec { }; buildInputs = [ - (python3.withPackages (ps: with ps; [ - pyusb - ])) + (python3.withPackages ( + ps: with ps; [ + pyusb + ] + )) ]; postPatch = '' diff --git a/pkgs/by-name/g3/g3kb-switch/package.nix b/pkgs/by-name/g3/g3kb-switch/package.nix index 49ccd04573dadd..d6851ceb9004ff 100644 --- a/pkgs/by-name/g3/g3kb-switch/package.nix +++ b/pkgs/by-name/g3/g3kb-switch/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, cmake -, pkg-config -, glib -, fetchFromGitHub +{ + lib, + stdenv, + cmake, + pkg-config, + glib, + fetchFromGitHub, }: stdenv.mkDerivation rec { pname = "g3kb-switch"; diff --git a/pkgs/by-name/g8/g810-led/package.nix b/pkgs/by-name/g8/g810-led/package.nix index 5f1c7e1fdae1d8..94bf6df4bd9371 100644 --- a/pkgs/by-name/g8/g810-led/package.nix +++ b/pkgs/by-name/g8/g810-led/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, hidapi -, profile ? "/etc/g810-led/profile" +{ + lib, + stdenv, + fetchFromGitHub, + hidapi, + profile ? "/etc/g810-led/profile", }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/g9/g933-utils/package.nix b/pkgs/by-name/g9/g933-utils/package.nix index 7817f0b41695cc..0d19b3b3382c5d 100644 --- a/pkgs/by-name/g9/g933-utils/package.nix +++ b/pkgs/by-name/g9/g933-utils/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, rustPlatform, udev, pkg-config }: +{ + lib, + fetchFromGitHub, + rustPlatform, + udev, + pkg-config, +}: rustPlatform.buildRustPackage rec { pname = "g933-utils"; diff --git a/pkgs/by-name/ga/gabutdm/package.nix b/pkgs/by-name/ga/gabutdm/package.nix index 9c2e57eb119eb6..1744c4f01aa517 100644 --- a/pkgs/by-name/ga/gabutdm/package.nix +++ b/pkgs/by-name/ga/gabutdm/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, pkg-config -, ninja -, vala -, wrapGAppsHook4 -, desktop-file-utils -, sqlite -, libcanberra -, libsoup_3 -, libgee -, json-glib -, qrencode -, curl -, libadwaita -, aria2 +{ + lib, + stdenv, + fetchFromGitHub, + meson, + pkg-config, + ninja, + vala, + wrapGAppsHook4, + desktop-file-utils, + sqlite, + libcanberra, + libsoup_3, + libgee, + json-glib, + qrencode, + curl, + libadwaita, + aria2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ga/galario/package.nix b/pkgs/by-name/ga/galario/package.nix index d601722efab4ef..6abfa0fe519efa 100644 --- a/pkgs/by-name/ga/galario/package.nix +++ b/pkgs/by-name/ga/galario/package.nix @@ -19,7 +19,7 @@ let hash = "sha256-ggMcgKfpYHWWgyYY84u4Q79IGCVTVkmIMw+N/soapfk="; }; in -stdenv.mkDerivation (finalAttrs:{ +stdenv.mkDerivation (finalAttrs: { pname = "galario"; version = "1.2.2"; diff --git a/pkgs/by-name/ga/galatia-sil/package.nix b/pkgs/by-name/ga/galatia-sil/package.nix index 70881399d593ef..f686c6023b1a35 100644 --- a/pkgs/by-name/ga/galatia-sil/package.nix +++ b/pkgs/by-name/ga/galatia-sil/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "galatia-sil"; diff --git a/pkgs/by-name/ga/galaxis/package.nix b/pkgs/by-name/ga/galaxis/package.nix index 788a7453e20ffb..6ec0c87fe81490 100644 --- a/pkgs/by-name/ga/galaxis/package.nix +++ b/pkgs/by-name/ga/galaxis/package.nix @@ -1,8 +1,9 @@ -{ lib -, asciidoctor -, fetchFromGitLab -, ncurses -, stdenv +{ + lib, + asciidoctor, + fetchFromGitLab, + ncurses, + stdenv, }: stdenv.mkDerivation (finalAttrs: { @@ -16,7 +17,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-fSzifGoSdWyFGt99slzAsqCMDoeLbBqQGXujX8QAfGc="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; nativeBuildInputs = [ asciidoctor diff --git a/pkgs/by-name/ga/galen/package.nix b/pkgs/by-name/ga/galen/package.nix index 581a6f99374e04..863f8a77636dbe 100644 --- a/pkgs/by-name/ga/galen/package.nix +++ b/pkgs/by-name/ga/galen/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre8, unzip }: +{ + lib, + stdenv, + fetchurl, + jre8, + unzip, +}: stdenv.mkDerivation rec { pname = "galen"; @@ -14,13 +20,13 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ unzip ]; buildPhase = '' - mkdir -p $out/bin + mkdir -p $out/bin ''; installPhase = '' - cat galen | sed -e "s,java,$jre8/bin/java," > $out/bin/galen - chmod +x $out/bin/galen - cp galen.jar $out/bin + cat galen | sed -e "s,java,$jre8/bin/java," > $out/bin/galen + chmod +x $out/bin/galen + cp galen.jar $out/bin ''; meta = with lib; { diff --git a/pkgs/by-name/ga/galer/package.nix b/pkgs/by-name/ga/galer/package.nix index 69012a2519a416..e433793a657d54 100644 --- a/pkgs/by-name/ga/galer/package.nix +++ b/pkgs/by-name/ga/galer/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ga/galerio/package.nix b/pkgs/by-name/ga/galerio/package.nix index aa1075f81a7586..1801ebd412b518 100644 --- a/pkgs/by-name/ga/galerio/package.nix +++ b/pkgs/by-name/ga/galerio/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "galerio"; @@ -17,7 +21,10 @@ rustPlatform.buildRustPackage rec { description = " A simple generator for self-contained HTML flexbox galleries"; homepage = "https://github.com/dbrgn/galerio"; maintainers = with maintainers; [ dbrgn ]; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; mainProgram = "galerio"; }; } diff --git a/pkgs/by-name/ga/galleta/package.nix b/pkgs/by-name/ga/galleta/package.nix index 651a8eafa32661..88d584b5d101c2 100644 --- a/pkgs/by-name/ga/galleta/package.nix +++ b/pkgs/by-name/ga/galleta/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchzip -, fetchpatch +{ + lib, + stdenv, + fetchzip, + fetchpatch, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ga/gam/package.nix b/pkgs/by-name/ga/gam/package.nix index 795256d2189018..f34e21d313f76c 100644 --- a/pkgs/by-name/ga/gam/package.nix +++ b/pkgs/by-name/ga/gam/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -40,7 +41,7 @@ python3.pkgs.buildPythonApplication rec { # at build time and then single quotes the vars in the wrapper, thus they # wouldn't get expanded. But using --run allows setting default vars that are # evaluated on run and not during build time. - makeWrapperArgs = [ + makeWrapperArgs = [ ''--run 'export GAMUSERCONFIGDIR="''${XDG_CONFIG_HOME:-$HOME/.config}/gam"' '' ''--run 'export GAMSITECONFIGDIR="''${XDG_CONFIG_HOME:-$HOME/.config}/gam"' '' ''--run 'export GAMCACHEDIR="''${XDG_CACHE_HOME:-$HOME/.cache}/gam"' '' diff --git a/pkgs/by-name/ga/gama/package.nix b/pkgs/by-name/ga/gama/package.nix index a27978052a0933..8c98729e5065a4 100644 --- a/pkgs/by-name/ga/gama/package.nix +++ b/pkgs/by-name/ga/gama/package.nix @@ -1,4 +1,13 @@ -{ stdenv, fetchurl, lib, expat, octave, libxml2, texinfo, zip }: +{ + stdenv, + fetchurl, + lib, + expat, + octave, + libxml2, + texinfo, + zip, +}: stdenv.mkDerivation rec { pname = "gama"; version = "2.28"; @@ -10,14 +19,20 @@ stdenv.mkDerivation rec { buildInputs = [ expat ]; - nativeBuildInputs = [ texinfo zip ]; + nativeBuildInputs = [ + texinfo + zip + ]; env.CXXFLAGS = lib.optionalString stdenv.cc.isClang "-include sstream"; - nativeCheckInputs = [ octave libxml2 ]; + nativeCheckInputs = [ + octave + libxml2 + ]; doCheck = true; - meta = with lib ; { + meta = with lib; { description = "Tools for adjustment of geodetic networks"; homepage = "https://www.gnu.org/software/gama/"; license = licenses.gpl3Plus; diff --git a/pkgs/by-name/ga/gambit-chess/package.nix b/pkgs/by-name/ga/gambit-chess/package.nix index 90e23e9820c68a..8a348527662539 100644 --- a/pkgs/by-name/ga/gambit-chess/package.nix +++ b/pkgs/by-name/ga/gambit-chess/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, testers -, gambit-chess +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + gambit-chess, }: buildGoModule rec { diff --git a/pkgs/by-name/ga/gambit-project/package.nix b/pkgs/by-name/ga/gambit-project/package.nix index 1c254e02519063..d917feaa72f5b8 100644 --- a/pkgs/by-name/ga/gambit-project/package.nix +++ b/pkgs/by-name/ga/gambit-project/package.nix @@ -1,10 +1,11 @@ -{ lib -, autoreconfHook -, fetchFromGitHub -, stdenv -, wxGTK31 -, darwin -, withGui ? true +{ + lib, + autoreconfHook, + fetchFromGitHub, + stdenv, + wxGTK31, + darwin, + withGui ? true, }: stdenv.mkDerivation (finalAttrs: { @@ -18,9 +19,7 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-OuI2DA/5CLgHqcHwOGUE9IdrnyjlGKy8B7tWueUfUtg="; }; - nativeBuildInputs = - [ autoreconfHook ] - ++ lib.optional withGui wxGTK31; + nativeBuildInputs = [ autoreconfHook ] ++ lib.optional withGui wxGTK31; buildInputs = lib.optional withGui wxGTK31 diff --git a/pkgs/by-name/ga/game-devices-udev-rules/package.nix b/pkgs/by-name/ga/game-devices-udev-rules/package.nix index ca2ef7a4498e51..f4b50120ef2088 100644 --- a/pkgs/by-name/ga/game-devices-udev-rules/package.nix +++ b/pkgs/by-name/ga/game-devices-udev-rules/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitea -, bash +{ + lib, + stdenv, + fetchFromGitea, + bash, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ga/game-music-emu/package.nix b/pkgs/by-name/ga/game-music-emu/package.nix index 4935381713b730..ee1f18715f39b6 100644 --- a/pkgs/by-name/ga/game-music-emu/package.nix +++ b/pkgs/by-name/ga/game-music-emu/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, cmake, removeReferencesTo, zlib }: +{ + lib, + stdenv, + fetchurl, + cmake, + removeReferencesTo, + zlib, +}: stdenv.mkDerivation rec { version = "0.6.3"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "07857vdkak306d9s5g6fhmjyxk7vijzjhkmqb15s7ihfxx9lx8xb"; }; cmakeFlags = [ "-DENABLE_UBSAN=OFF" ]; - nativeBuildInputs = [ cmake removeReferencesTo ]; + nativeBuildInputs = [ + cmake + removeReferencesTo + ]; buildInputs = [ zlib ]; # It used to reference it, in the past, but thanks to the postFixup hook, now diff --git a/pkgs/by-name/ga/game-rs/package.nix b/pkgs/by-name/ga/game-rs/package.nix index 40c66d6f8c71f9..d4cc3b2aa8eb85 100644 --- a/pkgs/by-name/ga/game-rs/package.nix +++ b/pkgs/by-name/ga/game-rs/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, steam-run +{ + lib, + rustPlatform, + fetchFromGitHub, + steam-run, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ga/gamecube-tools/package.nix b/pkgs/by-name/ga/gamecube-tools/package.nix index 9b854d3671e5b2..edf3e5b21684d1 100644 --- a/pkgs/by-name/ga/gamecube-tools/package.nix +++ b/pkgs/by-name/ga/gamecube-tools/package.nix @@ -1,16 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook -, freeimage, libGL }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + freeimage, + libGL, +}: stdenv.mkDerivation rec { version = "1.0.6"; pname = "gamecube-tools"; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ freeimage libGL ]; + buildInputs = [ + freeimage + libGL + ]; src = fetchFromGitHub { owner = "devkitPro"; - repo = "gamecube-tools"; + repo = "gamecube-tools"; rev = "v${version}"; sha256 = "sha256-GsTmwyxBc36Qg+UGy+cRAjGW1eh1XxV0s94B14ZJAjU="; }; diff --git a/pkgs/by-name/ga/gamehub/package.nix b/pkgs/by-name/ga/gamehub/package.nix index 731a8678f2cf9e..4581585e4173ff 100644 --- a/pkgs/by-name/ga/gamehub/package.nix +++ b/pkgs/by-name/ga/gamehub/package.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, vala -, pkg-config -, desktop-file-utils -, glib -, gtk3 -, glib-networking -, libgee -, libsoup_2_4 -, json-glib -, sqlite -, webkitgtk_4_0 -, libmanette -, libXtst -, wrapGAppsHook3 +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + vala, + pkg-config, + desktop-file-utils, + glib, + gtk3, + glib-networking, + libgee, + libsoup_2_4, + json-glib, + sqlite, + webkitgtk_4_0, + libmanette, + libXtst, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ga/gamepad-tool/package.nix b/pkgs/by-name/ga/gamepad-tool/package.nix index f01951c4b7cbd8..c436f9e79a4cfc 100644 --- a/pkgs/by-name/ga/gamepad-tool/package.nix +++ b/pkgs/by-name/ga/gamepad-tool/package.nix @@ -1,4 +1,12 @@ -{ stdenvNoCC, fetchurl, dpkg, lib, qt5, autoPatchelfHook, SDL2 }: +{ + stdenvNoCC, + fetchurl, + dpkg, + lib, + qt5, + autoPatchelfHook, + SDL2, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "gamepad-tool"; @@ -9,7 +17,11 @@ stdenvNoCC.mkDerivation (finalAttrs: { hash = "sha256-ZuB0TOyT2B5QkU1o5h3/8PL85tBq06hlz5YclRanD88="; }; - nativeBuildInputs = [ dpkg qt5.wrapQtAppsHook autoPatchelfHook ]; + nativeBuildInputs = [ + dpkg + qt5.wrapQtAppsHook + autoPatchelfHook + ]; dontBuild = true; diff --git a/pkgs/by-name/ga/gamescope/package.nix b/pkgs/by-name/ga/gamescope/package.nix index 7f57c8ba62102b..f03a165109d042 100644 --- a/pkgs/by-name/ga/gamescope/package.nix +++ b/pkgs/by-name/ga/gamescope/package.nix @@ -1,40 +1,41 @@ -{ stdenv -, buildPackages -, edid-decode -, fetchFromGitHub -, meson -, pkg-config -, ninja -, cmake -, xorg -, libdrm -, libei -, vulkan-loader -, vulkan-headers -, wayland -, wayland-protocols -, wayland-scanner -, libxkbcommon -, glm -, gbenchmark -, libcap -, libavif -, SDL2 -, pipewire -, pixman -, python3 -, libinput -, glslang -, hwdata -, stb -, wlroots -, libdecor -, lcms -, lib -, makeBinaryWrapper -, nix-update-script -, enableExecutable ? true -, enableWsi ? true +{ + stdenv, + buildPackages, + edid-decode, + fetchFromGitHub, + meson, + pkg-config, + ninja, + cmake, + xorg, + libdrm, + libei, + vulkan-loader, + vulkan-headers, + wayland, + wayland-protocols, + wayland-scanner, + libxkbcommon, + glm, + gbenchmark, + libcap, + libavif, + SDL2, + pipewire, + pixman, + python3, + libinput, + glslang, + hwdata, + stb, + wlroots, + libdecor, + lcms, + lib, + makeBinaryWrapper, + nix-update-script, + enableExecutable ? true, + enableWsi ? true, }: let joshShaders = fetchFromGitHub { @@ -79,7 +80,7 @@ stdenv.mkDerivation (finalAttrs: { ]; # don't install vendored vkroots etc - mesonInstallFlags = ["--skip-subprojects"]; + mesonInstallFlags = [ "--skip-subprojects" ]; strictDeps = true; @@ -87,59 +88,68 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - nativeBuildInputs = [ - meson - pkg-config - ninja - wayland-scanner - # For `libdisplay-info` - python3 - hwdata - edid-decode - # For OpenVR - cmake + nativeBuildInputs = + [ + meson + pkg-config + ninja + wayland-scanner + # For `libdisplay-info` + python3 + hwdata + edid-decode + # For OpenVR + cmake - # calls git describe to encode its own version into the build - (buildPackages.writeShellScriptBin "git" "echo ${finalAttrs.version}") - ] ++ lib.optionals enableExecutable [ - makeBinaryWrapper - glslang - ]; + # calls git describe to encode its own version into the build + (buildPackages.writeShellScriptBin "git" "echo ${finalAttrs.version}") + ] + ++ lib.optionals enableExecutable [ + makeBinaryWrapper + glslang + ]; - buildInputs = [ - pipewire - hwdata - xorg.libX11 - wayland - wayland-protocols - vulkan-loader - glm - ] ++ lib.optionals enableWsi [ - vulkan-headers - ] ++ lib.optionals enableExecutable (wlroots.buildInputs ++ [ # gamescope uses a custom wlroots branch - xorg.libXcomposite - xorg.libXcursor - xorg.libXdamage - xorg.libXext - xorg.libXi - xorg.libXmu - xorg.libXrender - xorg.libXres - xorg.libXtst - xorg.libXxf86vm - libavif - libdrm - libei - SDL2 - libdecor - libinput - libxkbcommon - gbenchmark - pixman - libcap - stb - lcms - ]); + buildInputs = + [ + pipewire + hwdata + xorg.libX11 + wayland + wayland-protocols + vulkan-loader + glm + ] + ++ lib.optionals enableWsi [ + vulkan-headers + ] + ++ lib.optionals enableExecutable ( + wlroots.buildInputs + ++ [ + # gamescope uses a custom wlroots branch + xorg.libXcomposite + xorg.libXcursor + xorg.libXdamage + xorg.libXext + xorg.libXi + xorg.libXmu + xorg.libXrender + xorg.libXres + xorg.libXtst + xorg.libXxf86vm + libavif + libdrm + libei + SDL2 + libdecor + libinput + libxkbcommon + gbenchmark + pixman + libcap + stb + lcms + ] + ); postInstall = lib.optionalString enableExecutable '' # using patchelf unstable because the stable version corrupts the binary @@ -148,20 +158,32 @@ stdenv.mkDerivation (finalAttrs: { # --debug-layers flag expects these in the path wrapProgram "$out/bin/gamescope" \ - --prefix PATH : ${with xorg; lib.makeBinPath [xprop xwininfo]} + --prefix PATH : ${ + with xorg; + lib.makeBinPath [ + xprop + xwininfo + ] + } # Install ReShade shaders mkdir -p $out/share/gamescope/reshade cp -r ${joshShaders}/* $out/share/gamescope/reshade/ ''; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = with lib; { description = "SteamOS session compositing window manager"; homepage = "https://github.com/ValveSoftware/gamescope"; license = licenses.bsd2; - maintainers = with maintainers; [ nrdxp pedrohlc Scrumplex zhaofengli k900 ]; + maintainers = with maintainers; [ + nrdxp + pedrohlc + Scrumplex + zhaofengli + k900 + ]; platforms = platforms.linux; mainProgram = "gamescope"; }; diff --git a/pkgs/by-name/ga/gamja/package.nix b/pkgs/by-name/ga/gamja/package.nix index eab836a6756ea8..e9b9fae017ebfa 100644 --- a/pkgs/by-name/ga/gamja/package.nix +++ b/pkgs/by-name/ga/gamja/package.nix @@ -23,7 +23,9 @@ buildNpmPackage rec { runHook preInstall cp -r dist $out - ${lib.optionalString (gamjaConfig != null) "cp ${writeText "gamja-config" (builtins.toJSON gamjaConfig)} $out/config.json"} + ${lib.optionalString ( + gamjaConfig != null + ) "cp ${writeText "gamja-config" (builtins.toJSON gamjaConfig)} $out/config.json"} runHook postInstall ''; @@ -32,6 +34,9 @@ buildNpmPackage rec { description = "Simple IRC web client"; homepage = "https://git.sr.ht/~emersion/gamja"; license = licenses.agpl3Only; - maintainers = with maintainers; [motiejus apfelkuchen6]; + maintainers = with maintainers; [ + motiejus + apfelkuchen6 + ]; }; } diff --git a/pkgs/by-name/ga/gammu/package.nix b/pkgs/by-name/ga/gammu/package.nix index 78d5e010213cff..95e28f821cd977 100644 --- a/pkgs/by-name/ga/gammu/package.nix +++ b/pkgs/by-name/ga/gammu/package.nix @@ -1,7 +1,23 @@ -{ lib, stdenv, fetchFromGitHub, substituteAll, pkg-config, cmake, bluez, libusb1, curl -, libiconv, gettext, sqlite, bash, dialog -, dbiSupport ? false, libdbi ? null, libdbiDrivers ? null -, postgresSupport ? false, postgresql ? null +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + pkg-config, + cmake, + bluez, + libusb1, + curl, + libiconv, + gettext, + sqlite, + bash, + dialog, + dbiSupport ? false, + libdbi ? null, + libdbiDrivers ? null, + postgresSupport ? false, + postgresql ? null, }: stdenv.mkDerivation rec { @@ -24,13 +40,28 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; strictDeps = true; - buildInputs = [ bash bluez libusb1 curl gettext sqlite libiconv ] - ++ lib.optionals dbiSupport [ libdbi libdbiDrivers ] - ++ lib.optionals postgresSupport [ postgresql ]; + buildInputs = + [ + bash + bluez + libusb1 + curl + gettext + sqlite + libiconv + ] + ++ lib.optionals dbiSupport [ + libdbi + libdbiDrivers + ] + ++ lib.optionals postgresSupport [ postgresql ]; meta = with lib; { homepage = "https://wammu.eu/gammu/"; diff --git a/pkgs/by-name/ga/gandom-fonts/package.nix b/pkgs/by-name/ga/gandom-fonts/package.nix index 5d128448f1c799..13c9fe1b40abfb 100644 --- a/pkgs/by-name/ga/gandom-fonts/package.nix +++ b/pkgs/by-name/ga/gandom-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "gandom-fonts"; diff --git a/pkgs/by-name/ga/gapless/package.nix b/pkgs/by-name/ga/gapless/package.nix index c9b0c0e587383d..f1b52de083f93c 100644 --- a/pkgs/by-name/ga/gapless/package.nix +++ b/pkgs/by-name/ga/gapless/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitLab -, desktop-file-utils -, gitUpdater -, gobject-introspection -, gst_all_1 -, gtk4 -, libadwaita -, meson -, ninja -, pkg-config -, vala -, wrapGAppsHook4 +{ + lib, + stdenv, + fetchFromGitLab, + desktop-file-utils, + gitUpdater, + gobject-introspection, + gst_all_1, + gtk4, + libadwaita, + meson, + ninja, + pkg-config, + vala, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { pname = "gapless"; @@ -35,15 +36,17 @@ stdenv.mkDerivation (finalAttrs: { wrapGAppsHook4 ]; - buildInputs = [ - gtk4 - libadwaita - ] ++ (with gst_all_1; [ - gst-plugins-bad - gst-plugins-base - gst-plugins-good - gstreamer - ]); + buildInputs = + [ + gtk4 + libadwaita + ] + ++ (with gst_all_1; [ + gst-plugins-bad + gst-plugins-base + gst-plugins-good + gstreamer + ]); passthru.updateScript = gitUpdater { rev-prefix = "v"; diff --git a/pkgs/by-name/ga/gappa/package.nix b/pkgs/by-name/ga/gappa/package.nix index 2eb8567aaa4ced..b13011605e507b 100644 --- a/pkgs/by-name/ga/gappa/package.nix +++ b/pkgs/by-name/ga/gappa/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, gmp, mpfr, boost }: +{ + lib, + stdenv, + fetchurl, + gmp, + mpfr, + boost, +}: stdenv.mkDerivation rec { pname = "gappa"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "12x42z901pr05ldmparqdi8sq9s7fxbavhzk2dbq3l6hy247dwbb"; }; - buildInputs = [ gmp mpfr boost.dev ]; + buildInputs = [ + gmp + mpfr + boost.dev + ]; buildPhase = "./remake"; installPhase = "./remake install"; @@ -18,7 +29,10 @@ stdenv.mkDerivation rec { homepage = "http://gappa.gforge.inria.fr/"; description = "Verifying and formally proving properties on numerical programs dealing with floating-point or fixed-point arithmetic"; mainProgram = "gappa"; - license = with lib.licenses; [ cecill20 gpl2 ]; + license = with lib.licenses; [ + cecill20 + gpl2 + ]; maintainers = with lib.maintainers; [ vbgl ]; platforms = lib.platforms.all; }; diff --git a/pkgs/by-name/ga/garamond-libre/package.nix b/pkgs/by-name/ga/garamond-libre/package.nix index bd16afaf1895b6..68b66f90fee2eb 100644 --- a/pkgs/by-name/ga/garamond-libre/package.nix +++ b/pkgs/by-name/ga/garamond-libre/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "garamond-libre"; diff --git a/pkgs/by-name/ga/gargoyle/package.nix b/pkgs/by-name/ga/gargoyle/package.nix index d7863361b84615..f4bc572b513dbb 100644 --- a/pkgs/by-name/ga/gargoyle/package.nix +++ b/pkgs/by-name/ga/gargoyle/package.nix @@ -1,21 +1,41 @@ -{ lib, stdenv, fetchFromGitHub, substituteAll, jam, cctools, pkg-config -, SDL, SDL_mixer, SDL_sound, gtk2, libvorbis, smpeg }: +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + jam, + cctools, + pkg-config, + SDL, + SDL_mixer, + SDL_sound, + gtk2, + libvorbis, + smpeg, +}: let - jamenv = '' - unset AR - '' + (if stdenv.hostPlatform.isDarwin then '' - export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -I${lib.getDev SDL}/include/SDL" - export GARGLKINI="$out/Applications/Gargoyle.app/Contents/Resources/garglk.ini" - '' else '' - export NIX_LDFLAGS="$NIX_LDFLAGS -rpath $out/libexec/gargoyle" - export DESTDIR="$out" - export _BINDIR=libexec/gargoyle - export _APPDIR=libexec/gargoyle - export _LIBDIR=libexec/gargoyle - export GARGLKINI="$out/etc/garglk.ini" - ''); + jamenv = + '' + unset AR + '' + + ( + if stdenv.hostPlatform.isDarwin then + '' + export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -I${lib.getDev SDL}/include/SDL" + export GARGLKINI="$out/Applications/Gargoyle.app/Contents/Resources/garglk.ini" + '' + else + '' + export NIX_LDFLAGS="$NIX_LDFLAGS -rpath $out/libexec/gargoyle" + export DESTDIR="$out" + export _BINDIR=libexec/gargoyle + export _APPDIR=libexec/gargoyle + export _LIBDIR=libexec/gargoyle + export GARGLKINI="$out/etc/garglk.ini" + '' + ); in @@ -30,10 +50,22 @@ stdenv.mkDerivation rec { sha256 = "0w54avmbp4i4zps2rb4acmpa641s6wvwbrln4vbdhcz97fx48nzz"; }; - nativeBuildInputs = [ jam pkg-config ] ++ lib.optional stdenv.hostPlatform.isDarwin cctools; + nativeBuildInputs = [ + jam + pkg-config + ] ++ lib.optional stdenv.hostPlatform.isDarwin cctools; - buildInputs = [ SDL SDL_mixer SDL_sound gtk2 ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ smpeg libvorbis ]; + buildInputs = + [ + SDL + SDL_mixer + SDL_sound + gtk2 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + smpeg + libvorbis + ]; # Workaround build failure on -fno-common toolchains: # ld: build/linux.release/alan3/Location.o:(.bss+0x0): multiple definition of @@ -44,23 +76,25 @@ stdenv.mkDerivation rec { buildPhase = jamenv + "jam -j$NIX_BUILD_CORES"; installPhase = - if stdenv.hostPlatform.isDarwin then - (substituteAll { - inherit (stdenv) shell; - isExecutable = true; - src = ./darwin.sh; - }) - else jamenv + '' - jam -j$NIX_BUILD_CORES install - mkdir -p "$out/bin" - ln -s ../libexec/gargoyle/gargoyle "$out/bin" - mkdir -p "$out/etc" - cp garglk/garglk.ini "$out/etc" - mkdir -p "$out/share/applications" - cp garglk/gargoyle.desktop "$out/share/applications" - mkdir -p "$out/share/icons/hicolor/32x32/apps" - cp garglk/gargoyle-house.png "$out/share/icons/hicolor/32x32/apps" - ''; + if stdenv.hostPlatform.isDarwin then + (substituteAll { + inherit (stdenv) shell; + isExecutable = true; + src = ./darwin.sh; + }) + else + jamenv + + '' + jam -j$NIX_BUILD_CORES install + mkdir -p "$out/bin" + ln -s ../libexec/gargoyle/gargoyle "$out/bin" + mkdir -p "$out/etc" + cp garglk/garglk.ini "$out/etc" + mkdir -p "$out/share/applications" + cp garglk/gargoyle.desktop "$out/share/applications" + mkdir -p "$out/share/icons/hicolor/32x32/apps" + cp garglk/gargoyle-house.png "$out/share/icons/hicolor/32x32/apps" + ''; enableParallelBuilding = true; diff --git a/pkgs/by-name/ga/garmintools/package.nix b/pkgs/by-name/ga/garmintools/package.nix index 2c5740692f4b87..34dddd4a60c33e 100644 --- a/pkgs/by-name/ga/garmintools/package.nix +++ b/pkgs/by-name/ga/garmintools/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libusb-compat-0_1 }: +{ + lib, + stdenv, + fetchurl, + libusb-compat-0_1, +}: stdenv.mkDerivation rec { pname = "garmintools"; version = "0.10"; diff --git a/pkgs/by-name/ga/gash-utils/package.nix b/pkgs/by-name/ga/gash-utils/package.nix index bea8d6730e77e0..0719eb8aa68225 100644 --- a/pkgs/by-name/ga/gash-utils/package.nix +++ b/pkgs/by-name/ga/gash-utils/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, guile -, makeWrapper -, pkg-config -, gash +{ + lib, + stdenv, + fetchurl, + guile, + makeWrapper, + pkg-config, + gash, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ga/gash/package.nix b/pkgs/by-name/ga/gash/package.nix index cd6136dbc90f4a..199c9f1a024345 100644 --- a/pkgs/by-name/ga/gash/package.nix +++ b/pkgs/by-name/ga/gash/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, guile -, pkg-config +{ + lib, + stdenv, + fetchurl, + guile, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ga/gate/package.nix b/pkgs/by-name/ga/gate/package.nix index bd91e2bf7864fb..29b116c4a4bc57 100644 --- a/pkgs/by-name/ga/gate/package.nix +++ b/pkgs/by-name/ga/gate/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: let @@ -19,7 +20,10 @@ buildGoModule { vendorHash = "sha256-5s96L9KWeiS//21mQMn8ka82Uk4rMbq/8I+l67HTSA8="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = { description = "High-Performance, Low-Memory, Lightweight, Extensible Minecraft Reverse Proxy"; @@ -34,4 +38,3 @@ buildGoModule { mainProgram = "gate"; }; } - diff --git a/pkgs/by-name/ga/gatekeeper/package.nix b/pkgs/by-name/ga/gatekeeper/package.nix index 2b8ef8c1f1766d..2653cb2cd747bf 100644 --- a/pkgs/by-name/ga/gatekeeper/package.nix +++ b/pkgs/by-name/ga/gatekeeper/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/ga/gatk/package.nix b/pkgs/by-name/ga/gatk/package.nix index 711e9e94010a76..b130f3c84a39ab 100644 --- a/pkgs/by-name/ga/gatk/package.nix +++ b/pkgs/by-name/ga/gatk/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchzip, jre, makeWrapper, python3 }: +{ + lib, + stdenv, + fetchzip, + jre, + makeWrapper, + python3, +}: stdenv.mkDerivation rec { pname = "gatk"; @@ -25,9 +32,9 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://gatk.broadinstitute.org/hc/en-us"; - description = "Wide variety of tools with a primary focus on variant discovery and genotyping." ; + description = "Wide variety of tools with a primary focus on variant discovery and genotyping."; license = licenses.asl20; - sourceProvenance = with lib.sourceTypes; [ binaryBytecode ] ; + sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; maintainers = with maintainers; [ apraga ]; longDescription = '' The GATK is the industry standard for identifying SNPs and indels in germline diff --git a/pkgs/by-name/ga/gatling/package.nix b/pkgs/by-name/ga/gatling/package.nix index 5255010177af56..1a3e2a2e4f29d6 100644 --- a/pkgs/by-name/ga/gatling/package.nix +++ b/pkgs/by-name/ga/gatling/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, libowfat, libcap, zlib, openssl, libxcrypt }: +{ + lib, + stdenv, + fetchurl, + libowfat, + libcap, + zlib, + openssl, + libxcrypt, +}: let version = "0.16"; @@ -12,7 +21,13 @@ stdenv.mkDerivation rec { sha256 = "0nrnws5qrl4frqcsfa9z973vv5mifgr9z170qbvg3mq1wa7475jz"; }; - buildInputs = [ libowfat libcap zlib openssl libxcrypt ]; + buildInputs = [ + libowfat + libcap + zlib + openssl + libxcrypt + ]; configurePhase = '' substituteInPlace Makefile --replace "/usr/local" "$out" diff --git a/pkgs/by-name/ga/gato/package.nix b/pkgs/by-name/ga/gato/package.nix index 56fb02908f667b..ec74ec1672ff6e 100644 --- a/pkgs/by-name/ga/gato/package.nix +++ b/pkgs/by-name/ga/gato/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, git -, fetchFromGitHub +{ + lib, + python3, + git, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ga/gav/package.nix b/pkgs/by-name/ga/gav/package.nix index 23f1fe7854b457..00793115b78644 100644 --- a/pkgs/by-name/ga/gav/package.nix +++ b/pkgs/by-name/ga/gav/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchurl, SDL, SDL_image, SDL_mixer, SDL_net} : +{ + lib, + stdenv, + fetchurl, + SDL, + SDL_image, + SDL_mixer, + SDL_net, +}: stdenv.mkDerivation rec { pname = "gav"; @@ -16,7 +24,12 @@ stdenv.mkDerivation rec { ''; patches = [ ./gcc.patch ]; - buildInputs = [SDL SDL_image SDL_mixer SDL_net]; + buildInputs = [ + SDL + SDL_image + SDL_mixer + SDL_net + ]; meta = { description = "Remake of AV Arcade Volleyball"; diff --git a/pkgs/by-name/ga/gavin-bc/package.nix b/pkgs/by-name/ga/gavin-bc/package.nix index 58c9ce61033d2b..5dba74350bf892 100644 --- a/pkgs/by-name/ga/gavin-bc/package.nix +++ b/pkgs/by-name/ga/gavin-bc/package.nix @@ -1,14 +1,25 @@ -{ lib -, stdenv -, fetchFromGitea -, editline -, readline -, historyType ? "internal" -, predefinedBuildType ? "BSD" +{ + lib, + stdenv, + fetchFromGitea, + editline, + readline, + historyType ? "internal", + predefinedBuildType ? "BSD", }: -assert lib.elem historyType [ "editline" "readline" "internal" ]; -assert lib.elem predefinedBuildType [ "BSD" "GNU" "GDH" "DBG" "" ]; +assert lib.elem historyType [ + "editline" + "readline" + "internal" +]; +assert lib.elem predefinedBuildType [ + "BSD" + "GNU" + "GDH" + "DBG" + "" +]; stdenv.mkDerivation (finalAttrs: { pname = "gavin-bc"; version = "6.5.0"; @@ -25,13 +36,14 @@ stdenv.mkDerivation (finalAttrs: { (lib.optional (historyType == "editline") editline) ++ (lib.optional (historyType == "readline") readline); - configureFlags = [ - "--disable-nls" - ] - ++ (lib.optional (predefinedBuildType != "") "--predefined-build-type=${predefinedBuildType}") - ++ (lib.optional (historyType == "editline") "--enable-editline") - ++ (lib.optional (historyType == "readline") "--enable-readline") - ++ (lib.optional (historyType == "internal") "--enable-internal-history"); + configureFlags = + [ + "--disable-nls" + ] + ++ (lib.optional (predefinedBuildType != "") "--predefined-build-type=${predefinedBuildType}") + ++ (lib.optional (historyType == "editline") "--enable-editline") + ++ (lib.optional (historyType == "readline") "--enable-readline") + ++ (lib.optional (historyType == "internal") "--enable-internal-history"); meta = { homepage = "https://git.gavinhoward.com/gavin/bc"; diff --git a/pkgs/by-name/ga/gavrasm/package.nix b/pkgs/by-name/ga/gavrasm/package.nix index d77ff0b8e6aa8f..1894273f7a93f4 100644 --- a/pkgs/by-name/ga/gavrasm/package.nix +++ b/pkgs/by-name/ga/gavrasm/package.nix @@ -1,16 +1,28 @@ -{ lib, stdenv, fetchzip, fpc , lang ? "en" } : - -assert lib.assertOneOf "lang" lang ["cn" "de" "en" "fr" "tr"]; +{ + lib, + stdenv, + fetchzip, + fpc, + lang ? "en", +}: + +assert lib.assertOneOf "lang" lang [ + "cn" + "de" + "en" + "fr" + "tr" +]; stdenv.mkDerivation rec { pname = "gavrasm"; version = "5.4"; - flatVersion = lib.strings.replaceStrings ["."] [""] version; + flatVersion = lib.strings.replaceStrings [ "." ] [ "" ] version; src = fetchzip { url = "http://www.avr-asm-tutorial.net/gavrasm/v${flatVersion}/gavrasm_sources_lin_${flatVersion}.zip"; sha256 = "sha256-uTalb8Wzn2RAoUKZx9RZFCX+V9HUEtUnJ4eSltFumh0="; - stripRoot=false; + stripRoot = false; }; nativeBuildInputs = [ fpc ]; diff --git a/pkgs/by-name/ga/gaw/package.nix b/pkgs/by-name/ga/gaw/package.nix index 5dec368f454c5f..d65c354f633f58 100644 --- a/pkgs/by-name/ga/gaw/package.nix +++ b/pkgs/by-name/ga/gaw/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, fetchurl -, lib -, gtk3 -, pkg-config +{ + stdenv, + fetchurl, + lib, + gtk3, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ga/gay/package.nix b/pkgs/by-name/ga/gay/package.nix index 341c620af4ffa8..6afab31a77b8c8 100644 --- a/pkgs/by-name/ga/gay/package.nix +++ b/pkgs/by-name/ga/gay/package.nix @@ -1,4 +1,5 @@ -{ lib, +{ + lib, python3, fetchPypi, }: diff --git a/pkgs/by-name/gb/gb-backup/package.nix b/pkgs/by-name/gb/gb-backup/package.nix index 856da421c55bd1..60cf4f402937e7 100644 --- a/pkgs/by-name/gb/gb-backup/package.nix +++ b/pkgs/by-name/gb/gb-backup/package.nix @@ -1,4 +1,10 @@ -{ lib, makeWrapper, buildGoModule, fetchFromGitHub, lepton }: +{ + lib, + makeWrapper, + buildGoModule, + fetchFromGitHub, + lepton, +}: buildGoModule { pname = "gb-backup"; diff --git a/pkgs/by-name/gb/gbar/package.nix b/pkgs/by-name/gb/gbar/package.nix index faa930e9aee81c..3da83248407467 100644 --- a/pkgs/by-name/gb/gbar/package.nix +++ b/pkgs/by-name/gb/gbar/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, cmake -, pkg-config -, libdbusmenu-gtk3 -, gtk-layer-shell -, stb -, wayland-protocols -, wayland-scanner -, bluez -, gtk3 -, libpulseaudio -, wayland +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + cmake, + pkg-config, + libdbusmenu-gtk3, + gtk-layer-shell, + stb, + wayland-protocols, + wayland-scanner, + bluez, + gtk3, + libpulseaudio, + wayland, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/gb/gbforth/package.nix b/pkgs/by-name/gb/gbforth/package.nix index 22c559a97350ab..0d0f4261672598 100644 --- a/pkgs/by-name/gb/gbforth/package.nix +++ b/pkgs/by-name/gb/gbforth/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, gforth +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + gforth, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/gc/gcab/package.nix b/pkgs/by-name/gc/gcab/package.nix index 6136564e5412bd..552de1b2055002 100644 --- a/pkgs/by-name/gc/gcab/package.nix +++ b/pkgs/by-name/gc/gcab/package.nix @@ -1,25 +1,33 @@ -{ lib, stdenv -, fetchurl -, gettext -, gobject-introspection -, gtk-doc -, docbook_xsl -, docbook_xml_dtd_43 -, pkg-config -, meson -, ninja -, vala -, glib -, zlib -, gnome -, nixosTests +{ + lib, + stdenv, + fetchurl, + gettext, + gobject-introspection, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_43, + pkg-config, + meson, + ninja, + vala, + glib, + zlib, + gnome, + nixosTests, }: stdenv.mkDerivation rec { pname = "gcab"; version = "1.6"; - outputs = [ "bin" "out" "dev" "devdoc" "installedTests" ]; + outputs = [ + "bin" + "out" + "dev" + "devdoc" + "installedTests" + ]; src = fetchurl { url = "mirror://gnome/sources/gcab/${lib.versions.majorMinor version}/gcab-${version}.tar.xz"; diff --git a/pkgs/by-name/gc/gcal/package.nix b/pkgs/by-name/gc/gcal/package.nix index f07a18c0edae47..808f513c72eb25 100644 --- a/pkgs/by-name/gc/gcal/package.nix +++ b/pkgs/by-name/gc/gcal/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, ncurses, gettext, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + ncurses, + gettext, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "gcal"; diff --git a/pkgs/by-name/gc/gcc-arm-embedded-10/package.nix b/pkgs/by-name/gc/gcc-arm-embedded-10/package.nix index ad690cb26fa26f..7c7ff8a24b4770 100644 --- a/pkgs/by-name/gc/gcc-arm-embedded-10/package.nix +++ b/pkgs/by-name/gc/gcc-arm-embedded-10/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, ncurses5 +{ + lib, + stdenv, + fetchurl, + ncurses5, }: stdenv.mkDerivation rec { @@ -9,19 +10,23 @@ stdenv.mkDerivation rec { version = "10.3.1"; release = "10.3-2021.10"; - suffix = { - aarch64-linux = "aarch64-linux"; - x86_64-darwin = "mac"; - x86_64-linux = "x86_64-linux"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + suffix = + { + aarch64-linux = "aarch64-linux"; + x86_64-darwin = "mac"; + x86_64-linux = "x86_64-linux"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); src = fetchurl { url = "https://developer.arm.com/-/media/Files/downloads/gnu-rm/${release}/gcc-arm-none-eabi-${release}-${suffix}.tar.bz2"; - sha256 = { - aarch64-linux = "020j8gkzc0i0b74vz98gvngnwjm5222j1gk5nswfk6587krba1gn"; - x86_64-darwin = "0fr8pki2g4bfk1rk90dzwql37d0b71ngzs9zyx0g2jainan3sqgv"; - x86_64-linux = "18y92vpl22hf74yqdvmpw8adrkl92s4crzzs6avm05md37qb9nwp"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + sha256 = + { + aarch64-linux = "020j8gkzc0i0b74vz98gvngnwjm5222j1gk5nswfk6587krba1gn"; + x86_64-darwin = "0fr8pki2g4bfk1rk90dzwql37d0b71ngzs9zyx0g2jainan3sqgv"; + x86_64-linux = "18y92vpl22hf74yqdvmpw8adrkl92s4crzzs6avm05md37qb9nwp"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); }; dontConfigure = true; @@ -39,16 +44,36 @@ stdenv.mkDerivation rec { find $out -type f | while read f; do patchelf "$f" > /dev/null 2>&1 || continue patchelf --set-interpreter $(cat ${stdenv.cc}/nix-support/dynamic-linker) "$f" || true - patchelf --set-rpath ${lib.makeLibraryPath [ "$out" stdenv.cc.cc ncurses5 ]} "$f" || true + patchelf --set-rpath ${ + lib.makeLibraryPath [ + "$out" + stdenv.cc.cc + ncurses5 + ] + } "$f" || true done ''; meta = with lib; { description = "Pre-built GNU toolchain from ARM Cortex-M & Cortex-R processors"; homepage = "https://developer.arm.com/open-source/gnu-toolchain/gnu-rm"; - license = with licenses; [ bsd2 gpl2 gpl3 lgpl21 lgpl3 mit ]; - maintainers = with maintainers; [ prusnak prtzl ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" ]; + license = with licenses; [ + bsd2 + gpl2 + gpl3 + lgpl21 + lgpl3 + mit + ]; + maintainers = with maintainers; [ + prusnak + prtzl + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; } diff --git a/pkgs/by-name/gc/gcc-arm-embedded-11/package.nix b/pkgs/by-name/gc/gcc-arm-embedded-11/package.nix index 4ed1ac9b99b010..8cbc326a3f48fb 100644 --- a/pkgs/by-name/gc/gcc-arm-embedded-11/package.nix +++ b/pkgs/by-name/gc/gcc-arm-embedded-11/package.nix @@ -1,29 +1,34 @@ -{ lib -, stdenv -, fetchurl -, ncurses5 -, python39 -, libxcrypt-legacy -, runtimeShell +{ + lib, + stdenv, + fetchurl, + ncurses5, + python39, + libxcrypt-legacy, + runtimeShell, }: stdenv.mkDerivation rec { pname = "gcc-arm-embedded"; version = "11.3.rel1"; - platform = { - aarch64-linux = "aarch64"; - x86_64-darwin = "darwin-x86_64"; - x86_64-linux = "x86_64"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + platform = + { + aarch64-linux = "aarch64"; + x86_64-darwin = "darwin-x86_64"; + x86_64-linux = "x86_64"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); src = fetchurl { url = "https://developer.arm.com/-/media/Files/downloads/gnu/${version}/binrel/arm-gnu-toolchain-${version}-${platform}-arm-none-eabi.tar.xz"; - sha256 = { - aarch64-linux = "0pmm5r0k5mxd5drbn2s8a7qkm8c4fi8j5y31c70yrp0qs08kqwbc"; - x86_64-darwin = "1kr9kd9p2xk84fa99zf3gz5lkww2i9spqkjigjwakfkzbva56qw2"; - x86_64-linux = "08b1w1zmj4z80k59zmlc1bf34lg8d7z65fwvp5ir2pb1d1zxh86l"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + sha256 = + { + aarch64-linux = "0pmm5r0k5mxd5drbn2s8a7qkm8c4fi8j5y31c70yrp0qs08kqwbc"; + x86_64-darwin = "1kr9kd9p2xk84fa99zf3gz5lkww2i9spqkjigjwakfkzbva56qw2"; + x86_64-linux = "08b1w1zmj4z80k59zmlc1bf34lg8d7z65fwvp5ir2pb1d1zxh86l"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); }; dontConfigure = true; @@ -40,7 +45,15 @@ stdenv.mkDerivation rec { find $out -type f | while read f; do patchelf "$f" > /dev/null 2>&1 || continue patchelf --set-interpreter $(cat ${stdenv.cc}/nix-support/dynamic-linker) "$f" || true - patchelf --set-rpath ${lib.makeLibraryPath [ "$out" stdenv.cc.cc ncurses5 python39 libxcrypt-legacy ]} "$f" || true + patchelf --set-rpath ${ + lib.makeLibraryPath [ + "$out" + stdenv.cc.cc + ncurses5 + python39 + libxcrypt-legacy + ] + } "$f" || true done ''; @@ -58,9 +71,20 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Pre-built GNU toolchain from ARM Cortex-M & Cortex-R processors"; homepage = "https://developer.arm.com/open-source/gnu-toolchain/gnu-rm"; - license = with licenses; [ bsd2 gpl2 gpl3 lgpl21 lgpl3 mit ]; + license = with licenses; [ + bsd2 + gpl2 + gpl3 + lgpl21 + lgpl3 + mit + ]; maintainers = with maintainers; [ prusnak ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; } diff --git a/pkgs/by-name/gc/gcc-arm-embedded-12/package.nix b/pkgs/by-name/gc/gcc-arm-embedded-12/package.nix index 0407cfa71e09c2..97a122f3034ef4 100644 --- a/pkgs/by-name/gc/gcc-arm-embedded-12/package.nix +++ b/pkgs/by-name/gc/gcc-arm-embedded-12/package.nix @@ -1,31 +1,36 @@ -{ lib -, stdenv -, fetchurl -, ncurses5 -, python39 -, libxcrypt-legacy -, runtimeShell +{ + lib, + stdenv, + fetchurl, + ncurses5, + python39, + libxcrypt-legacy, + runtimeShell, }: stdenv.mkDerivation rec { pname = "gcc-arm-embedded"; version = "12.3.rel1"; - platform = { - aarch64-darwin = "darwin-arm64"; - aarch64-linux = "aarch64"; - x86_64-darwin = "darwin-x86_64"; - x86_64-linux = "x86_64"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + platform = + { + aarch64-darwin = "darwin-arm64"; + aarch64-linux = "aarch64"; + x86_64-darwin = "darwin-x86_64"; + x86_64-linux = "x86_64"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); src = fetchurl { url = "https://developer.arm.com/-/media/Files/downloads/gnu/${version}/binrel/arm-gnu-toolchain-${version}-${platform}-arm-none-eabi.tar.xz"; - sha256 = { - aarch64-darwin = "sha256-Oy7uC99xwbvrPDt0JPv3vZ1cPw9aOkp4FZyeOtIZ570="; - aarch64-linux = "sha256-FMBIfVdT9gcdJOVoiB98fmf4DdgxZd7FFks3MTlK9DE="; - x86_64-darwin = "sha256-5u2L+TD62c4z4SCrkLNpV7H3efzKpt5snKmliYLAQpE="; - x86_64-linux = "sha256-EqKBVkQxjrzOr4S+q7Zl0JJLbnniEEhFLFMxpWMyswk="; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + sha256 = + { + aarch64-darwin = "sha256-Oy7uC99xwbvrPDt0JPv3vZ1cPw9aOkp4FZyeOtIZ570="; + aarch64-linux = "sha256-FMBIfVdT9gcdJOVoiB98fmf4DdgxZd7FFks3MTlK9DE="; + x86_64-darwin = "sha256-5u2L+TD62c4z4SCrkLNpV7H3efzKpt5snKmliYLAQpE="; + x86_64-linux = "sha256-EqKBVkQxjrzOr4S+q7Zl0JJLbnniEEhFLFMxpWMyswk="; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); }; dontConfigure = true; @@ -42,7 +47,15 @@ stdenv.mkDerivation rec { find $out -type f | while read f; do patchelf "$f" > /dev/null 2>&1 || continue patchelf --set-interpreter $(cat ${stdenv.cc}/nix-support/dynamic-linker) "$f" || true - patchelf --set-rpath ${lib.makeLibraryPath [ "$out" stdenv.cc.cc ncurses5 python39 libxcrypt-legacy ]} "$f" || true + patchelf --set-rpath ${ + lib.makeLibraryPath [ + "$out" + stdenv.cc.cc + ncurses5 + python39 + libxcrypt-legacy + ] + } "$f" || true done ''; @@ -60,9 +73,24 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Pre-built GNU toolchain from ARM Cortex-M & Cortex-R processors"; homepage = "https://developer.arm.com/open-source/gnu-toolchain/gnu-rm"; - license = with licenses; [ bsd2 gpl2 gpl3 lgpl21 lgpl3 mit ]; - maintainers = with maintainers; [ prusnak prtzl ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + license = with licenses; [ + bsd2 + gpl2 + gpl3 + lgpl21 + lgpl3 + mit + ]; + maintainers = with maintainers; [ + prusnak + prtzl + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; } diff --git a/pkgs/by-name/gc/gcc-arm-embedded-13/package.nix b/pkgs/by-name/gc/gcc-arm-embedded-13/package.nix index f3870205a66f0a..6eac3bc060ca68 100644 --- a/pkgs/by-name/gc/gcc-arm-embedded-13/package.nix +++ b/pkgs/by-name/gc/gcc-arm-embedded-13/package.nix @@ -1,32 +1,37 @@ -{ lib -, stdenv -, fetchurl -, ncurses5 -, python39 -, libxcrypt-legacy -, runtimeShell +{ + lib, + stdenv, + fetchurl, + ncurses5, + python39, + libxcrypt-legacy, + runtimeShell, }: stdenv.mkDerivation rec { pname = "gcc-arm-embedded"; version = "13.3.rel1"; - platform = { - aarch64-darwin = "darwin-arm64"; - aarch64-linux = "aarch64"; - x86_64-darwin = "darwin-x86_64"; - x86_64-linux = "x86_64"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + platform = + { + aarch64-darwin = "darwin-arm64"; + aarch64-linux = "aarch64"; + x86_64-darwin = "darwin-x86_64"; + x86_64-linux = "x86_64"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); src = fetchurl { url = "https://developer.arm.com/-/media/Files/downloads/gnu/${version}/binrel/arm-gnu-toolchain-${version}-${platform}-arm-none-eabi.tar.xz"; # hashes obtained from location ${url}.sha256asc - sha256 = { - aarch64-darwin = "fb6921db95d345dc7e5e487dd43b745e3a5b4d5c0c7ca4f707347148760317b4"; - aarch64-linux = "c8824bffd057afce2259f7618254e840715f33523a3d4e4294f471208f976764"; - x86_64-darwin = "1ab00742d1ed0926e6f227df39d767f8efab46f5250505c29cb81f548222d794"; - x86_64-linux = "95c011cee430e64dd6087c75c800f04b9c49832cc1000127a92a97f9c8d83af4"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + sha256 = + { + aarch64-darwin = "fb6921db95d345dc7e5e487dd43b745e3a5b4d5c0c7ca4f707347148760317b4"; + aarch64-linux = "c8824bffd057afce2259f7618254e840715f33523a3d4e4294f471208f976764"; + x86_64-darwin = "1ab00742d1ed0926e6f227df39d767f8efab46f5250505c29cb81f548222d794"; + x86_64-linux = "95c011cee430e64dd6087c75c800f04b9c49832cc1000127a92a97f9c8d83af4"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); }; dontConfigure = true; @@ -43,7 +48,15 @@ stdenv.mkDerivation rec { find $out -type f | while read f; do patchelf "$f" > /dev/null 2>&1 || continue patchelf --set-interpreter $(cat ${stdenv.cc}/nix-support/dynamic-linker) "$f" || true - patchelf --set-rpath ${lib.makeLibraryPath [ "$out" stdenv.cc.cc ncurses5 python39 libxcrypt-legacy ]} "$f" || true + patchelf --set-rpath ${ + lib.makeLibraryPath [ + "$out" + stdenv.cc.cc + ncurses5 + python39 + libxcrypt-legacy + ] + } "$f" || true done ''; @@ -61,9 +74,24 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Pre-built GNU toolchain from ARM Cortex-M & Cortex-R processors"; homepage = "https://developer.arm.com/open-source/gnu-toolchain/gnu-rm"; - license = with licenses; [ bsd2 gpl2 gpl3 lgpl21 lgpl3 mit ]; - maintainers = with maintainers; [ prusnak prtzl ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + license = with licenses; [ + bsd2 + gpl2 + gpl3 + lgpl21 + lgpl3 + mit + ]; + maintainers = with maintainers; [ + prusnak + prtzl + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; } diff --git a/pkgs/by-name/gc/gcc-arm-embedded-6/package.nix b/pkgs/by-name/gc/gcc-arm-embedded-6/package.nix index d805c24e002c2a..70e1481e2dd499 100644 --- a/pkgs/by-name/gc/gcc-arm-embedded-6/package.nix +++ b/pkgs/by-name/gc/gcc-arm-embedded-6/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, ncurses5 +{ + lib, + stdenv, + fetchurl, + ncurses5, }: stdenv.mkDerivation rec { @@ -10,17 +11,21 @@ stdenv.mkDerivation rec { release = "6-2017-q2-update"; subdir = "6-2017q2"; - suffix = { - x86_64-darwin = "mac"; - x86_64-linux = "linux"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + suffix = + { + x86_64-darwin = "mac"; + x86_64-linux = "linux"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); src = fetchurl { url = "https://developer.arm.com/-/media/Files/downloads/gnu-rm/${subdir}/gcc-arm-none-eabi-${release}-${suffix}.tar.bz2"; - sha256 = { - x86_64-darwin = "0019ylpq4inq7p5gydpmc9m8ni72fz2csrjlqmgx1698998q0c3x"; - x86_64-linux = "1hvwi02mx34al525sngnl0cm7dkmzxfkb1brq9kvbv28wcplp3p6"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + sha256 = + { + x86_64-darwin = "0019ylpq4inq7p5gydpmc9m8ni72fz2csrjlqmgx1698998q0c3x"; + x86_64-linux = "1hvwi02mx34al525sngnl0cm7dkmzxfkb1brq9kvbv28wcplp3p6"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); }; dontConfigure = true; @@ -38,16 +43,32 @@ stdenv.mkDerivation rec { find $out -type f | while read f; do patchelf "$f" > /dev/null 2>&1 || continue patchelf --set-interpreter $(cat ${stdenv.cc}/nix-support/dynamic-linker) "$f" || true - patchelf --set-rpath ${lib.makeLibraryPath [ "$out" stdenv.cc.cc ncurses5 ]} "$f" || true + patchelf --set-rpath ${ + lib.makeLibraryPath [ + "$out" + stdenv.cc.cc + ncurses5 + ] + } "$f" || true done ''; meta = with lib; { description = "Pre-built GNU toolchain from ARM Cortex-M & Cortex-R processors"; homepage = "https://developer.arm.com/open-source/gnu-toolchain/gnu-rm"; - license = with licenses; [ bsd2 gpl2 gpl3 lgpl21 lgpl3 mit ]; + license = with licenses; [ + bsd2 + gpl2 + gpl3 + lgpl21 + lgpl3 + mit + ]; maintainers = with maintainers; [ prusnak ]; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; } diff --git a/pkgs/by-name/gc/gcc-arm-embedded-7/package.nix b/pkgs/by-name/gc/gcc-arm-embedded-7/package.nix index 13d8c12f52ce33..10fdd294649cc0 100644 --- a/pkgs/by-name/gc/gcc-arm-embedded-7/package.nix +++ b/pkgs/by-name/gc/gcc-arm-embedded-7/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, ncurses5 +{ + lib, + stdenv, + fetchurl, + ncurses5, }: stdenv.mkDerivation rec { @@ -10,17 +11,21 @@ stdenv.mkDerivation rec { release = "7-2018-q2-update"; subdir = "7-2018q2"; - suffix = { - x86_64-darwin = "mac"; - x86_64-linux = "linux"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + suffix = + { + x86_64-darwin = "mac"; + x86_64-linux = "linux"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); src = fetchurl { url = "https://developer.arm.com/-/media/Files/downloads/gnu-rm/${subdir}/gcc-arm-none-eabi-${release}-${suffix}.tar.bz2"; - sha256 = { - x86_64-darwin = "0nc7m0mpa39qyhfyydxkkyqm7spfc27xf6ygi2vd2aym4r9azi61"; - x86_64-linux = "0sgysp3hfpgrkcbfiwkp0a7ymqs02khfbrjabm52b5z61sgi05xv"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + sha256 = + { + x86_64-darwin = "0nc7m0mpa39qyhfyydxkkyqm7spfc27xf6ygi2vd2aym4r9azi61"; + x86_64-linux = "0sgysp3hfpgrkcbfiwkp0a7ymqs02khfbrjabm52b5z61sgi05xv"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); }; dontConfigure = true; @@ -38,16 +43,32 @@ stdenv.mkDerivation rec { find $out -type f | while read f; do patchelf "$f" > /dev/null 2>&1 || continue patchelf --set-interpreter $(cat ${stdenv.cc}/nix-support/dynamic-linker) "$f" || true - patchelf --set-rpath ${lib.makeLibraryPath [ "$out" stdenv.cc.cc ncurses5 ]} "$f" || true + patchelf --set-rpath ${ + lib.makeLibraryPath [ + "$out" + stdenv.cc.cc + ncurses5 + ] + } "$f" || true done ''; meta = with lib; { description = "Pre-built GNU toolchain from ARM Cortex-M & Cortex-R processors"; homepage = "https://developer.arm.com/open-source/gnu-toolchain/gnu-rm"; - license = with licenses; [ bsd2 gpl2 gpl3 lgpl21 lgpl3 mit ]; + license = with licenses; [ + bsd2 + gpl2 + gpl3 + lgpl21 + lgpl3 + mit + ]; maintainers = with maintainers; [ prusnak ]; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; } diff --git a/pkgs/by-name/gc/gcc-arm-embedded-8/package.nix b/pkgs/by-name/gc/gcc-arm-embedded-8/package.nix index a6448baa7919fd..ff63cb58bd99bb 100644 --- a/pkgs/by-name/gc/gcc-arm-embedded-8/package.nix +++ b/pkgs/by-name/gc/gcc-arm-embedded-8/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, ncurses5 +{ + lib, + stdenv, + fetchurl, + ncurses5, }: stdenv.mkDerivation rec { @@ -10,17 +11,21 @@ stdenv.mkDerivation rec { release = "8-2019-q3-update"; subdir = "8-2019q3/RC1.1"; - suffix = { - x86_64-darwin = "mac"; - x86_64-linux = "linux"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + suffix = + { + x86_64-darwin = "mac"; + x86_64-linux = "linux"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); src = fetchurl { url = "https://developer.arm.com/-/media/Files/downloads/gnu-rm/${subdir}/gcc-arm-none-eabi-${release}-${suffix}.tar.bz2"; - sha256 = { - x86_64-darwin = "fc235ce853bf3bceba46eff4b95764c5935ca07fc4998762ef5e5b7d05f37085"; - x86_64-linux = "b50b02b0a16e5aad8620e9d7c31110ef285c1dde28980b1a9448b764d77d8f92"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + sha256 = + { + x86_64-darwin = "fc235ce853bf3bceba46eff4b95764c5935ca07fc4998762ef5e5b7d05f37085"; + x86_64-linux = "b50b02b0a16e5aad8620e9d7c31110ef285c1dde28980b1a9448b764d77d8f92"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); }; dontConfigure = true; @@ -38,16 +43,32 @@ stdenv.mkDerivation rec { find $out -type f | while read f; do patchelf "$f" > /dev/null 2>&1 || continue patchelf --set-interpreter $(cat ${stdenv.cc}/nix-support/dynamic-linker) "$f" || true - patchelf --set-rpath ${lib.makeLibraryPath [ "$out" stdenv.cc.cc ncurses5 ]} "$f" || true + patchelf --set-rpath ${ + lib.makeLibraryPath [ + "$out" + stdenv.cc.cc + ncurses5 + ] + } "$f" || true done ''; meta = with lib; { description = "Pre-built GNU toolchain from ARM Cortex-M & Cortex-R processors"; homepage = "https://developer.arm.com/open-source/gnu-toolchain/gnu-rm"; - license = with licenses; [ bsd2 gpl2 gpl3 lgpl21 lgpl3 mit ]; + license = with licenses; [ + bsd2 + gpl2 + gpl3 + lgpl21 + lgpl3 + mit + ]; maintainers = with maintainers; [ prusnak ]; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; } diff --git a/pkgs/by-name/gc/gcc-arm-embedded-9/package.nix b/pkgs/by-name/gc/gcc-arm-embedded-9/package.nix index 4c2b34b0c5b713..3dda27e3b853da 100644 --- a/pkgs/by-name/gc/gcc-arm-embedded-9/package.nix +++ b/pkgs/by-name/gc/gcc-arm-embedded-9/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, ncurses5 +{ + lib, + stdenv, + fetchurl, + ncurses5, }: stdenv.mkDerivation rec { @@ -10,19 +11,23 @@ stdenv.mkDerivation rec { release = "9-2020-q2-update"; subdir = "9-2020q2"; - suffix = { - aarch64-linux = "aarch64-linux"; - x86_64-darwin = "mac"; - x86_64-linux = "x86_64-linux"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + suffix = + { + aarch64-linux = "aarch64-linux"; + x86_64-darwin = "mac"; + x86_64-linux = "x86_64-linux"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); src = fetchurl { url = "https://developer.arm.com/-/media/Files/downloads/gnu-rm/${subdir}/gcc-arm-none-eabi-${release}-${suffix}.tar.bz2"; - sha256 = { - aarch64-linux = "1b5q2y710hy7lddj8vj3zl54gfl74j30kx3hk3i81zrcbv16ah8z"; - x86_64-darwin = "1ils9z16wrvglh72m428y5irmd36biq79yj86756whib8izbifdv"; - x86_64-linux = "07zi2yr5gvhpbij5pnj49zswb9g2gw7zqp4xwwniqmq477h2xp2s"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + sha256 = + { + aarch64-linux = "1b5q2y710hy7lddj8vj3zl54gfl74j30kx3hk3i81zrcbv16ah8z"; + x86_64-darwin = "1ils9z16wrvglh72m428y5irmd36biq79yj86756whib8izbifdv"; + x86_64-linux = "07zi2yr5gvhpbij5pnj49zswb9g2gw7zqp4xwwniqmq477h2xp2s"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); }; dontConfigure = true; @@ -40,16 +45,33 @@ stdenv.mkDerivation rec { find $out -type f | while read f; do patchelf "$f" > /dev/null 2>&1 || continue patchelf --set-interpreter $(cat ${stdenv.cc}/nix-support/dynamic-linker) "$f" || true - patchelf --set-rpath ${lib.makeLibraryPath [ "$out" stdenv.cc.cc ncurses5 ]} "$f" || true + patchelf --set-rpath ${ + lib.makeLibraryPath [ + "$out" + stdenv.cc.cc + ncurses5 + ] + } "$f" || true done ''; meta = with lib; { description = "Pre-built GNU toolchain from ARM Cortex-M & Cortex-R processors"; homepage = "https://developer.arm.com/open-source/gnu-toolchain/gnu-rm"; - license = with licenses; [ bsd2 gpl2 gpl3 lgpl21 lgpl3 mit ]; + license = with licenses; [ + bsd2 + gpl2 + gpl3 + lgpl21 + lgpl3 + mit + ]; maintainers = with maintainers; [ prusnak ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; } diff --git a/pkgs/by-name/gc/gcfflasher/package.nix b/pkgs/by-name/gc/gcfflasher/package.nix index 6bcb45fec941de..2a82d2530b9fd5 100644 --- a/pkgs/by-name/gc/gcfflasher/package.nix +++ b/pkgs/by-name/gc/gcfflasher/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, libgpiod -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libgpiod, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gc/gci/package.nix b/pkgs/by-name/gc/gci/package.nix index fcf1abe23fc2a9..28eeee22e6cf0a 100644 --- a/pkgs/by-name/gc/gci/package.nix +++ b/pkgs/by-name/gc/gci/package.nix @@ -20,6 +20,6 @@ buildGoModule rec { description = "Controls golang package import order and makes it always deterministic"; homepage = "https://github.com/daixiang0/gci"; license = licenses.bsd3; - maintainers = with maintainers; [krostar]; + maintainers = with maintainers; [ krostar ]; }; } diff --git a/pkgs/by-name/gc/gcli/package.nix b/pkgs/by-name/gc/gcli/package.nix index e4300b2b931387..d6a69fa6da01ef 100644 --- a/pkgs/by-name/gc/gcli/package.nix +++ b/pkgs/by-name/gc/gcli/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, stdenv -, curl -, autoreconfHook -, pkg-config -, byacc -, flex +{ + lib, + fetchFromGitHub, + stdenv, + curl, + autoreconfHook, + pkg-config, + byacc, + flex, }: stdenv.mkDerivation rec { @@ -19,7 +20,12 @@ stdenv.mkDerivation rec { hash = "sha256-extVTaTWVFXSTiXlZ/MtiiFdc/KZEDkc+A7xxylJaM4="; }; - nativeBuildInputs = [ autoreconfHook pkg-config byacc flex ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + byacc + flex + ]; buildInputs = [ curl ]; meta = with lib; { diff --git a/pkgs/by-name/gc/gcolor3/package.nix b/pkgs/by-name/gc/gcolor3/package.nix index cf823398a446fc..848fc9784b5107 100644 --- a/pkgs/by-name/gc/gcolor3/package.nix +++ b/pkgs/by-name/gc/gcolor3/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitLab -, meson -, ninja -, gettext -, pkg-config -, libxml2 -, gtk3 -, libportal-gtk3 -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + gettext, + pkg-config, + libxml2, + gtk3, + libportal-gtk3, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gc/gcov2lcov/package.nix b/pkgs/by-name/gc/gcov2lcov/package.nix index 712a65506214aa..63c98769567b8f 100644 --- a/pkgs/by-name/gc/gcov2lcov/package.nix +++ b/pkgs/by-name/gc/gcov2lcov/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-/2OIBWXbNch6lmw0C1jkyJfNefJXOVG9/jNW8CYHTsc="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; # Some checks depend on looking up vcs root checkPhase = false; diff --git a/pkgs/by-name/gc/gcp-scanner/package.nix b/pkgs/by-name/gc/gcp-scanner/package.nix index 0e16965f63f019..f16d3254028fa3 100644 --- a/pkgs/by-name/gc/gcp-scanner/package.nix +++ b/pkgs/by-name/gc/gcp-scanner/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/gc/gcsfuse/package.nix b/pkgs/by-name/gc/gcsfuse/package.nix index 315fc51a7a1b61..63f67ff3427145 100644 --- a/pkgs/by-name/gc/gcsfuse/package.nix +++ b/pkgs/by-name/gc/gcsfuse/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, stdenv +{ + lib, + buildGoModule, + fetchFromGitHub, + stdenv, }: buildGoModule rec { @@ -17,9 +18,16 @@ buildGoModule rec { vendorHash = "sha256-QrpILFzgUQwmrvjCdtrlgq1zSW7f82qMHsifI39WaB0="; - subPackages = [ "." "tools/mount_gcsfuse" ]; + subPackages = [ + "." + "tools/mount_gcsfuse" + ]; - ldflags = [ "-s" "-w" "-X main.gcsfuseVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.gcsfuseVersion=${version}" + ]; checkFlags = let diff --git a/pkgs/by-name/gc/gcstar/package.nix b/pkgs/by-name/gc/gcstar/package.nix index fbc730121f021f..b9638506c33cf4 100644 --- a/pkgs/by-name/gc/gcstar/package.nix +++ b/pkgs/by-name/gc/gcstar/package.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchFromGitLab -, perlPackages -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitLab, + perlPackages, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gd/gdl/package.nix b/pkgs/by-name/gd/gdl/package.nix index 6e7e1e39b38df9..8107fec39bdb2d 100644 --- a/pkgs/by-name/gd/gdl/package.nix +++ b/pkgs/by-name/gd/gdl/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, libxml2, gtk3, gnome, intltool }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libxml2, + gtk3, + gnome, + intltool, +}: stdenv.mkDerivation rec { pname = "gdl"; @@ -9,8 +18,14 @@ stdenv.mkDerivation rec { sha256 = "NkHU/WadHhgYrv88+f+3iH/Fw2eFC3jCjHdeukq2pVU="; }; - nativeBuildInputs = [ pkg-config intltool ]; - buildInputs = [ libxml2 gtk3 ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; + buildInputs = [ + libxml2 + gtk3 + ]; passthru = { updateScript = gnome.updateScript { diff --git a/pkgs/by-name/gd/gdmap/package.nix b/pkgs/by-name/gd/gdmap/package.nix index b2844c9502009b..63b0d18e23e796 100644 --- a/pkgs/by-name/gd/gdmap/package.nix +++ b/pkgs/by-name/gd/gdmap/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, gtk2, pkg-config, libxml2, intltool, gettext }: +{ + lib, + stdenv, + fetchurl, + gtk2, + pkg-config, + libxml2, + intltool, + gettext, +}: stdenv.mkDerivation rec { pname = "gdmap"; @@ -9,10 +18,20 @@ stdenv.mkDerivation rec { sha256 = "0nr8l88cg19zj585hczj8v73yh21k7j13xivhlzl8jdk0j0cj052"; }; - nativeBuildInputs = [ pkg-config intltool ]; - buildInputs = [ gtk2 libxml2 gettext ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; + buildInputs = [ + gtk2 + libxml2 + gettext + ]; - patches = [ ./get_sensitive.patch ./set_flags.patch ]; + patches = [ + ./get_sensitive.patch + ./set_flags.patch + ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/gd/gdome2/package.nix b/pkgs/by-name/gd/gdome2/package.nix index f71753b479d79e..463e87073f85c6 100644 --- a/pkgs/by-name/gd/gdome2/package.nix +++ b/pkgs/by-name/gd/gdome2/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchurl, pkg-config, glib, libxml2, gtk-doc}: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + libxml2, + gtk-doc, +}: let pname = "gdome2"; @@ -16,8 +24,15 @@ stdenv.mkDerivation { hardeningDisable = [ "format" ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib libxml2 gtk-doc ]; - propagatedBuildInputs = [glib libxml2]; + buildInputs = [ + glib + libxml2 + gtk-doc + ]; + propagatedBuildInputs = [ + glib + libxml2 + ]; patches = [ ./xml-document.patch ./fno-common.patch @@ -28,7 +43,10 @@ stdenv.mkDerivation { description = "DOM C library developed for the Gnome project"; mainProgram = "gdome-config"; license = licenses.lgpl21Plus; - maintainers = with maintainers; [ prikhi roconnor ]; + maintainers = with maintainers; [ + prikhi + roconnor + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/gd/gdrive/package.nix b/pkgs/by-name/gd/gdrive/package.nix index a07f25775ff449..79da48c59a9ca7 100644 --- a/pkgs/by-name/gd/gdrive/package.nix +++ b/pkgs/by-name/gd/gdrive/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "gdrive"; @@ -22,7 +27,10 @@ buildGoModule rec { }) ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/prasmussen/gdrive"; diff --git a/pkgs/by-name/gd/gdrive3/package.nix b/pkgs/by-name/gd/gdrive3/package.nix index 3fc7af9b14177c..c646cc574e37fc 100644 --- a/pkgs/by-name/gd/gdrive3/package.nix +++ b/pkgs/by-name/gd/gdrive3/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/gd/gdtoolkit_3/package.nix b/pkgs/by-name/gd/gdtoolkit_3/package.nix index 01b6a15e0e100e..a25eddbcac1bb5 100644 --- a/pkgs/by-name/gd/gdtoolkit_3/package.nix +++ b/pkgs/by-name/gd/gdtoolkit_3/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: let @@ -59,14 +60,25 @@ python.pkgs.buildPythonApplication rec { ''; # The tests are not working on NixOS - disabledTests = [ "test_cc_on_empty_file_succeeds" "test_cc_on_file_with_single_function_succeeds" ]; + disabledTests = [ + "test_cc_on_empty_file_succeeds" + "test_cc_on_file_with_single_function_succeeds" + ]; - pythonImportsCheck = [ "gdtoolkit" "gdtoolkit.formatter" "gdtoolkit.linter" "gdtoolkit.parser" ]; + pythonImportsCheck = [ + "gdtoolkit" + "gdtoolkit.formatter" + "gdtoolkit.linter" + "gdtoolkit.parser" + ]; meta = with lib; { description = "Independent set of tools for working with Godot's GDScript - parser, linter and formatter"; homepage = "https://github.com/Scony/godot-gdscript-toolkit"; license = licenses.mit; - maintainers = with maintainers; [ shiryel tmarkus ]; + maintainers = with maintainers; [ + shiryel + tmarkus + ]; }; } diff --git a/pkgs/by-name/gd/gdtoolkit_4/package.nix b/pkgs/by-name/gd/gdtoolkit_4/package.nix index 13735386293b4d..301f9013409eab 100644 --- a/pkgs/by-name/gd/gdtoolkit_4/package.nix +++ b/pkgs/by-name/gd/gdtoolkit_4/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: let @@ -63,7 +64,12 @@ python.pkgs.buildPythonApplication rec { "tests/gdradon/test_executable.py" ]; - pythonImportsCheck = [ "gdtoolkit" "gdtoolkit.formatter" "gdtoolkit.linter" "gdtoolkit.parser" ]; + pythonImportsCheck = [ + "gdtoolkit" + "gdtoolkit.formatter" + "gdtoolkit.linter" + "gdtoolkit.parser" + ]; meta = with lib; { description = "Independent set of tools for working with Godot's GDScript - parser, linter and formatter"; diff --git a/pkgs/by-name/ge/geary/package.nix b/pkgs/by-name/ge/geary/package.nix index 0b85d3af0776fa..824105f773ca3f 100644 --- a/pkgs/by-name/ge/geary/package.nix +++ b/pkgs/by-name/ge/geary/package.nix @@ -1,48 +1,49 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gtk3 -, vala -, enchant2 -, wrapGAppsHook3 -, meson -, ninja -, desktop-file-utils -, gnome-online-accounts -, gsettings-desktop-schemas -, adwaita-icon-theme -, libpeas -, libsecret -, gmime3 -, isocodes -, icu -, libxml2 -, gettext -, sqlite -, gcr -, json-glib -, itstool -, libgee -, gnome -, webkitgtk_4_1 -, python3 -, gnutls -, cacert -, xvfb-run -, glibcLocales -, dbus -, shared-mime-info -, libunwind -, folks -, glib-networking -, gobject-introspection -, gspell -, appstream-glib -, libstemmer -, libytnef -, libhandy -, gsound +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk3, + vala, + enchant2, + wrapGAppsHook3, + meson, + ninja, + desktop-file-utils, + gnome-online-accounts, + gsettings-desktop-schemas, + adwaita-icon-theme, + libpeas, + libsecret, + gmime3, + isocodes, + icu, + libxml2, + gettext, + sqlite, + gcr, + json-glib, + itstool, + libgee, + gnome, + webkitgtk_4_1, + python3, + gnutls, + cacert, + xvfb-run, + glibcLocales, + dbus, + shared-mime-info, + libunwind, + folks, + glib-networking, + gobject-introspection, + gspell, + appstream-glib, + libstemmer, + libytnef, + libhandy, + gsound, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ge/gebaar-libinput/package.nix b/pkgs/by-name/ge/gebaar-libinput/package.nix index 533d4ddc8ee725..810a9fb8c65951 100644 --- a/pkgs/by-name/ge/gebaar-libinput/package.nix +++ b/pkgs/by-name/ge/gebaar-libinput/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, pkg-config, cmake, libinput, zlib }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + pkg-config, + cmake, + libinput, + zlib, +}: stdenv.mkDerivation rec { pname = "gebaar-libinput"; @@ -20,8 +29,14 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config cmake ]; - buildInputs = [ libinput zlib ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; + buildInputs = [ + libinput + zlib + ]; meta = with lib; { description = "Gebaar, A Super Simple WM Independent Touchpad Gesture Daemon for libinput"; @@ -29,6 +44,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/Coffee2CodeNL/gebaar-libinput"; license = licenses.gpl3; platforms = platforms.linux; - maintainers = with maintainers; [ colemickens lovesegfault ]; + maintainers = with maintainers; [ + colemickens + lovesegfault + ]; }; } diff --git a/pkgs/by-name/ge/geek-life/package.nix b/pkgs/by-name/ge/geek-life/package.nix index 4ab016067f478a..b84c87fe18e0ac 100644 --- a/pkgs/by-name/ge/geek-life/package.nix +++ b/pkgs/by-name/ge/geek-life/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "geek-life"; diff --git a/pkgs/by-name/ge/geeqie/package.nix b/pkgs/by-name/ge/geeqie/package.nix index 2d07fbb8633d71..34acd23d3e58f7 100644 --- a/pkgs/by-name/ge/geeqie/package.nix +++ b/pkgs/by-name/ge/geeqie/package.nix @@ -1,10 +1,41 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, meson, ninja, xxd, gettext, intltool -, gtk3, lcms2, exiv2, libchamplain, clutter-gtk, ffmpegthumbnailer, fbida -, libarchive, djvulibre, libheif, openjpeg, libjxl, libraw, lua5_3, poppler -, gspell, libtiff, libwebp -, gphoto2, imagemagick, yad, exiftool, zenity, libnotify -, wrapGAppsHook3, fetchpatch, doxygen -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + meson, + ninja, + xxd, + gettext, + intltool, + gtk3, + lcms2, + exiv2, + libchamplain, + clutter-gtk, + ffmpegthumbnailer, + fbida, + libarchive, + djvulibre, + libheif, + openjpeg, + libjxl, + libraw, + lua5_3, + poppler, + gspell, + libtiff, + libwebp, + gphoto2, + imagemagick, + yad, + exiftool, + zenity, + libnotify, + wrapGAppsHook3, + fetchpatch, + doxygen, + nix-update-script, }: stdenv.mkDerivation rec { @@ -30,16 +61,36 @@ stdenv.mkDerivation rec { patchShebangs . ''; - nativeBuildInputs = - [ pkg-config gettext intltool - wrapGAppsHook3 doxygen - meson ninja xxd - ]; + nativeBuildInputs = [ + pkg-config + gettext + intltool + wrapGAppsHook3 + doxygen + meson + ninja + xxd + ]; buildInputs = [ - gtk3 lcms2 exiv2 libchamplain clutter-gtk ffmpegthumbnailer fbida - libarchive djvulibre libheif openjpeg libjxl libraw lua5_3 poppler - gspell libtiff libwebp + gtk3 + lcms2 + exiv2 + libchamplain + clutter-gtk + ffmpegthumbnailer + fbida + libarchive + djvulibre + libheif + openjpeg + libjxl + libraw + lua5_3 + poppler + gspell + libtiff + libwebp ]; postInstall = '' @@ -47,27 +98,62 @@ stdenv.mkDerivation rec { # losslessly rotate JPEG images. # Requires exiftran (fbida package) and exiv2. sed -i $out/lib/geeqie/geeqie-rotate \ - -e '1 a export PATH=${lib.makeBinPath [ exiv2 fbida ]}:$PATH' + -e '1 a export PATH=${ + lib.makeBinPath [ + exiv2 + fbida + ] + }:$PATH' # Zenity and yad are used in some scripts for reporting errors. # Allow change quality of image. # Requires imagemagick and yad. sed -i $out/lib/geeqie/geeqie-resize-image \ - -e '1 a export PATH=${lib.makeBinPath [ imagemagick yad ]}:$PATH' + -e '1 a export PATH=${ + lib.makeBinPath [ + imagemagick + yad + ] + }:$PATH' # Allow to crop image. # Requires imagemagick, exiv2 and exiftool. sed -i $out/lib/geeqie/geeqie-image-crop \ - -e '1 a export PATH=${lib.makeBinPath [ imagemagick exiv2 exiftool zenity ]}:$PATH' + -e '1 a export PATH=${ + lib.makeBinPath [ + imagemagick + exiv2 + exiftool + zenity + ] + }:$PATH' # Requires gphoto2 and libnotify sed -i $out/lib/geeqie/geeqie-tethered-photography \ - -e '1 a export PATH=${lib.makeBinPath [ gphoto2 zenity libnotify ]}:$PATH' + -e '1 a export PATH=${ + lib.makeBinPath [ + gphoto2 + zenity + libnotify + ] + }:$PATH' # Import images from camera. # Requires gphoto2. sed -i $out/lib/geeqie/geeqie-camera-import \ - -e '1 a export PATH=${lib.makeBinPath [ gphoto2 zenity ]}:$PATH' + -e '1 a export PATH=${ + lib.makeBinPath [ + gphoto2 + zenity + ] + }:$PATH' # Export jpeg from raw file. # Requires exiv2, exiftool and lcms2. sed -i $out/lib/geeqie/geeqie-export-jpeg \ - -e '1 a export PATH=${lib.makeBinPath [ zenity exiv2 exiftool lcms2 ]}:$PATH' + -e '1 a export PATH=${ + lib.makeBinPath [ + zenity + exiv2 + exiftool + lcms2 + ] + }:$PATH' ''; enableParallelBuilding = true; @@ -80,22 +166,24 @@ stdenv.mkDerivation rec { description = "Lightweight GTK based image viewer"; mainProgram = "geeqie"; - longDescription = - '' - Geeqie is a lightweight GTK based image viewer for Unix like - operating systems. It features: EXIF, IPTC and XMP metadata - browsing and editing interoperability; easy integration with other - software; geeqie works on files and directories, there is no need to - import images; fast preview for many raw image formats; tools for - image comparison, sorting and managing photo collection. Geeqie was - initially based on GQview. - ''; + longDescription = '' + Geeqie is a lightweight GTK based image viewer for Unix like + operating systems. It features: EXIF, IPTC and XMP metadata + browsing and editing interoperability; easy integration with other + software; geeqie works on files and directories, there is no need to + import images; fast preview for many raw image formats; tools for + image comparison, sorting and managing photo collection. Geeqie was + initially based on GQview. + ''; license = licenses.gpl2Plus; homepage = "https://www.geeqie.org/"; - maintainers = with maintainers; [ pSub markus1189 ]; + maintainers = with maintainers; [ + pSub + markus1189 + ]; platforms = platforms.gnu ++ platforms.linux; }; } diff --git a/pkgs/by-name/ge/geesefs/package.nix b/pkgs/by-name/ge/geesefs/package.nix index 8ac28ab7d38f18..3ca92cd8be1f63 100644 --- a/pkgs/by-name/ge/geesefs/package.nix +++ b/pkgs/by-name/ge/geesefs/package.nix @@ -1,10 +1,13 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: -let version = "0.42.3"; -in buildGoModule { +let + version = "0.42.3"; +in +buildGoModule { pname = "geesefs"; inherit version; diff --git a/pkgs/by-name/ge/gef/package.nix b/pkgs/by-name/ge/gef/package.nix index fd3071a081759e..9d95573a14d1ba 100644 --- a/pkgs/by-name/ge/gef/package.nix +++ b/pkgs/by-name/ge/gef/package.nix @@ -1,25 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, gdb -, python3 -, bintools-unwrapped -, file -, ps -, git -, coreutils +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + gdb, + python3, + bintools-unwrapped, + file, + ps, + git, + coreutils, }: let - pythonPath = with python3.pkgs; makePythonPath [ - keystone-engine - unicorn - capstone - ropper - ]; + pythonPath = + with python3.pkgs; + makePythonPath [ + keystone-engine + unicorn + capstone + ropper + ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "gef"; version = "2024.06"; @@ -40,12 +44,14 @@ in stdenv.mkDerivation rec { makeWrapper ${gdb}/bin/gdb $out/bin/gef \ --add-flags "-q -x $out/share/gef/gef.py" \ --set NIX_PYTHONPATH ${pythonPath} \ - --prefix PATH : ${lib.makeBinPath [ - python3 - bintools-unwrapped # for readelf - file - ps - ]} + --prefix PATH : ${ + lib.makeBinPath [ + python3 + bintools-unwrapped # for readelf + file + ps + ] + } ''; nativeCheckInputs = [ diff --git a/pkgs/by-name/ge/geist-font/package.nix b/pkgs/by-name/ge/geist-font/package.nix index 12ba112d04a91d..787974748772a7 100644 --- a/pkgs/by-name/ge/geist-font/package.nix +++ b/pkgs/by-name/ge/geist-font/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchzip +{ + lib, + stdenvNoCC, + fetchzip, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/ge/gelasio/package.nix b/pkgs/by-name/ge/gelasio/package.nix index 9f62d7464185ce..c08c1e34b5d50d 100644 --- a/pkgs/by-name/ge/gelasio/package.nix +++ b/pkgs/by-name/ge/gelasio/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "gelasio"; @@ -35,4 +39,3 @@ stdenvNoCC.mkDerivation { maintainers = with maintainers; [ colemickens ]; }; } - diff --git a/pkgs/by-name/ge/gem/package.nix b/pkgs/by-name/ge/gem/package.nix index 5cb308988a4f7b..5b5b70b763c680 100644 --- a/pkgs/by-name/ge/gem/package.nix +++ b/pkgs/by-name/ge/gem/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, puredata -, libGL -, libGLU -, glew -, libglut -, libv4l -, libX11 -, file +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + puredata, + libGL, + libGLU, + glew, + libglut, + libv4l, + libX11, + file, }: stdenv.mkDerivation rec { @@ -45,7 +46,10 @@ stdenv.mkDerivation rec { description = "Graphics Environment for Multimedia"; homepage = "http://puredata.info/downloads/gem"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ raboof carlthome ]; + maintainers = with maintainers; [ + raboof + carlthome + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/ge/gema/package.nix b/pkgs/by-name/ge/gema/package.nix index 4e16d4de72acdf..6966e27731c7f2 100644 --- a/pkgs/by-name/ge/gema/package.nix +++ b/pkgs/by-name/ge/gema/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, installShellFiles +{ + lib, + stdenv, + fetchurl, + installShellFiles, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ge/gemget/package.nix b/pkgs/by-name/ge/gemget/package.nix index b31d4491b59945..96326b5fdbb179 100644 --- a/pkgs/by-name/ge/gemget/package.nix +++ b/pkgs/by-name/ge/gemget/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gemget"; diff --git a/pkgs/by-name/ge/gemrb/package.nix b/pkgs/by-name/ge/gemrb/package.nix index 85ea2954309e79..f4bf90f780efb5 100644 --- a/pkgs/by-name/ge/gemrb/package.nix +++ b/pkgs/by-name/ge/gemrb/package.nix @@ -1,24 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, SDL2 -, SDL2_mixer -, freetype -, libGL -, libiconv -, libpng -, libvlc -, libvorbis -, openal -, python3 -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + SDL2, + SDL2_mixer, + freetype, + libGL, + libiconv, + libpng, + libvlc, + libvorbis, + openal, + python3, + zlib, }: let # the GLES backend on rpi is untested as I don't have the hardware - backend = - if stdenv.hostPlatform.isx86 then "OpenGL" else "GLES"; + backend = if stdenv.hostPlatform.isx86 then "OpenGL" else "GLES"; withVLC = stdenv.hostPlatform.isDarwin; @@ -47,8 +47,7 @@ stdenv.mkDerivation rec { openal python3 zlib - ] - ++ optional withVLC libvlc; + ] ++ optional withVLC libvlc; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/by-name/ge/gen-license/package.nix b/pkgs/by-name/ge/gen-license/package.nix index a69b44d7847389..86ded78e03091d 100644 --- a/pkgs/by-name/ge/gen-license/package.nix +++ b/pkgs/by-name/ge/gen-license/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, darwin +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ge/gen-oath-safe/package.nix b/pkgs/by-name/ge/gen-oath-safe/package.nix index 9ce87ac3bdd133..170f154959bd0b 100644 --- a/pkgs/by-name/ge/gen-oath-safe/package.nix +++ b/pkgs/by-name/ge/gen-oath-safe/package.nix @@ -1,4 +1,16 @@ -{ coreutils, fetchFromGitHub, file, libcaca, makeWrapper, python3, openssl, qrencode, lib, stdenv, yubikey-manager }: +{ + coreutils, + fetchFromGitHub, + file, + libcaca, + makeWrapper, + python3, + openssl, + qrencode, + lib, + stdenv, + yubikey-manager, +}: stdenv.mkDerivation rec { pname = "gen-oath-safe"; @@ -35,7 +47,7 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/mcepl/gen-oath-safe"; description = "Script for generating HOTP/TOTP keys (and QR code)"; - platforms = platforms.unix; + platforms = platforms.unix; license = licenses.mit; maintainers = [ maintainers.makefu ]; mainProgram = "gen-oath-safe"; diff --git a/pkgs/by-name/ge/gen6dns/package.nix b/pkgs/by-name/ge/gen6dns/package.nix index 92d33d55da98b0..fc77acc5650b82 100644 --- a/pkgs/by-name/ge/gen6dns/package.nix +++ b/pkgs/by-name/ge/gen6dns/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, installShellFiles }: +{ + lib, + stdenv, + fetchurl, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "gen6dns"; diff --git a/pkgs/by-name/ge/genact/package.nix b/pkgs/by-name/ge/genact/package.nix index d2abfc02ba7706..e7763ee219c4e4 100644 --- a/pkgs/by-name/ge/genact/package.nix +++ b/pkgs/by-name/ge/genact/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, installShellFiles, stdenv }: +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, +}: rustPlatform.buildRustPackage rec { pname = "genact"; diff --git a/pkgs/by-name/ge/genann/package.nix b/pkgs/by-name/ge/genann/package.nix index 3f79b7ecfc2b01..ccccceee85ff07 100644 --- a/pkgs/by-name/ge/genann/package.nix +++ b/pkgs/by-name/ge/genann/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "genann"; diff --git a/pkgs/by-name/ge/gencfsm/package.nix b/pkgs/by-name/ge/gencfsm/package.nix index 42a0b3d9188d67..b1c2ae57305cee 100644 --- a/pkgs/by-name/ge/gencfsm/package.nix +++ b/pkgs/by-name/ge/gencfsm/package.nix @@ -1,6 +1,21 @@ -{ lib, stdenv, fetchurl, autoconf, automake, intltool, libtool, pkg-config -, encfs, libsecret , glib , libgee, gtk3, vala, wrapGAppsHook3, xorg -, gobject-introspection +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + intltool, + libtool, + pkg-config, + encfs, + libsecret, + glib, + libgee, + gtk3, + vala, + wrapGAppsHook3, + xorg, + gobject-introspection, }: stdenv.mkDerivation rec { @@ -8,7 +23,8 @@ stdenv.mkDerivation rec { pname = "gnome-encfs-manager"; src = fetchurl { - url = with lib.versions; + url = + with lib.versions; "https://launchpad.net/gencfsm/trunk/${major version}.${minor version}/+download/gnome-encfs-manager_${version}.tar.xz"; sha256 = "RXVwg/xhfAQv3pWp3UylOhMKDh9ZACTuKM4lPrn1dk8="; }; diff --git a/pkgs/by-name/ge/gendef/package.nix b/pkgs/by-name/ge/gendef/package.nix index 6f637b01144d53..93144d850708d0 100644 --- a/pkgs/by-name/ge/gendef/package.nix +++ b/pkgs/by-name/ge/gendef/package.nix @@ -1,4 +1,8 @@ -{ fetchgit, lib, stdenv }: +{ + fetchgit, + lib, + stdenv, +}: stdenv.mkDerivation (finalAttrs: { pname = "gendef"; diff --git a/pkgs/by-name/ge/genesys/package.nix b/pkgs/by-name/ge/genesys/package.nix index 69fb2630e9da26..117b986c4f7543 100644 --- a/pkgs/by-name/ge/genesys/package.nix +++ b/pkgs/by-name/ge/genesys/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, jre, graphviz, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + graphviz, + makeWrapper, +}: stdenv.mkDerivation (finalAttrs: { pname = "genesys"; @@ -35,4 +42,3 @@ stdenv.mkDerivation (finalAttrs: { platforms = lib.platforms.all; }; }) - diff --git a/pkgs/by-name/ge/genext2fs/package.nix b/pkgs/by-name/ge/genext2fs/package.nix index 1a225b8ed4a30e..a5926fa3cd0fcc 100644 --- a/pkgs/by-name/ge/genext2fs/package.nix +++ b/pkgs/by-name/ge/genext2fs/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libarchive }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libarchive, +}: stdenv.mkDerivation rec { pname = "genext2fs"; diff --git a/pkgs/by-name/ge/gengetopt/package.nix b/pkgs/by-name/ge/gengetopt/package.nix index b0492665de1bf1..2543147fa32c9e 100644 --- a/pkgs/by-name/ge/gengetopt/package.nix +++ b/pkgs/by-name/ge/gengetopt/package.nix @@ -1,4 +1,10 @@ -{ fetchurl, lib, stdenv, texinfo, help2man }: +{ + fetchurl, + lib, + stdenv, + texinfo, + help2man, +}: stdenv.mkDerivation rec { pname = "gengetopt"; @@ -18,7 +24,10 @@ stdenv.mkDerivation rec { # test suite is not thread safe enableParallelBuilding = false; - nativeBuildInputs = [ texinfo help2man ]; + nativeBuildInputs = [ + texinfo + help2man + ]; #Fix, see #28255 postPatch = '' diff --git a/pkgs/by-name/ge/genimage/package.nix b/pkgs/by-name/ge/genimage/package.nix index 3e6ae58049bdae..6725fa71abf35b 100644 --- a/pkgs/by-name/ge/genimage/package.nix +++ b/pkgs/by-name/ge/genimage/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pkg-config, libconfuse, gettext }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + libconfuse, + gettext, +}: stdenv.mkDerivation rec { pname = "genimage"; @@ -9,8 +17,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-68P4hsTYAGTdbG1ePC6Y5aZwB4JkEIzi+Jraii4T/t0="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libconfuse gettext ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libconfuse + gettext + ]; postInstall = '' # As there is no manpage or built-in --help, add the README file for diff --git a/pkgs/by-name/ge/genmap/package.nix b/pkgs/by-name/ge/genmap/package.nix index 772975fc6450b9..10b4a96589b76e 100644 --- a/pkgs/by-name/ge/genmap/package.nix +++ b/pkgs/by-name/ge/genmap/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gtest -, which +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gtest, + which, }: stdenv.mkDerivation rec { @@ -22,7 +23,10 @@ stdenv.mkDerivation rec { doCheck = true; patches = [ ./gtest.patch ]; - nativeCheckInputs = [ gtest which ]; + nativeCheckInputs = [ + gtest + which + ]; preCheck = "make genmap_algo_test"; # disable benchmarks diff --git a/pkgs/by-name/ge/genromfs/package.nix b/pkgs/by-name/ge/genromfs/package.nix index 05b556019dacb0..ea6b0abcca9bf7 100644 --- a/pkgs/by-name/ge/genromfs/package.nix +++ b/pkgs/by-name/ge/genromfs/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "0.5.2"; diff --git a/pkgs/by-name/ge/gentium-book-basic/package.nix b/pkgs/by-name/ge/gentium-book-basic/package.nix index 5247e9e6d88237..c16887b53f3170 100644 --- a/pkgs/by-name/ge/gentium-book-basic/package.nix +++ b/pkgs/by-name/ge/gentium-book-basic/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "gentium-book-basic"; diff --git a/pkgs/by-name/ge/gentium/package.nix b/pkgs/by-name/ge/gentium/package.nix index e9d8435db26df3..1a1260657dfda0 100644 --- a/pkgs/by-name/ge/gentium/package.nix +++ b/pkgs/by-name/ge/gentium/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "gentium"; @@ -38,7 +42,10 @@ stdenvNoCC.mkDerivation rec { font family, along with documentation. ''; downloadPage = "https://software.sil.org/gentium/download/"; - maintainers = with maintainers; [ raskin rycee ]; + maintainers = with maintainers; [ + raskin + rycee + ]; license = licenses.ofl; platforms = platforms.all; }; diff --git a/pkgs/by-name/ge/genxword/package.nix b/pkgs/by-name/ge/genxword/package.nix index 199a63f9671982..a71628c4214632 100644 --- a/pkgs/by-name/ge/genxword/package.nix +++ b/pkgs/by-name/ge/genxword/package.nix @@ -1,11 +1,12 @@ -{ lib -, python3 -, fetchFromGitHub -, gettext -, gobject-introspection -, wrapGAppsHook3 -, pango -, gtksourceview3 +{ + lib, + python3, + fetchFromGitHub, + gettext, + gobject-introspection, + wrapGAppsHook3, + pango, + gtksourceview3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ge/genymotion/package.nix b/pkgs/by-name/ge/genymotion/package.nix index 3bc6f93158fceb..9c852df1843696 100644 --- a/pkgs/by-name/ge/genymotion/package.nix +++ b/pkgs/by-name/ge/genymotion/package.nix @@ -1,8 +1,29 @@ -{ stdenv, lib, fetchurl, makeWrapper, which, zlib, libGL, glib, xorg, libxkbcommon -, xdg-utils, libXrender, fontconfig, freetype, systemd, libpulseaudio -, cairo, gdk-pixbuf, gtk3, pixman -# For glewinfo -, libXmu, libXi, libXext }: +{ + stdenv, + lib, + fetchurl, + makeWrapper, + which, + zlib, + libGL, + glib, + xorg, + libxkbcommon, + xdg-utils, + libXrender, + fontconfig, + freetype, + systemd, + libpulseaudio, + cairo, + gdk-pixbuf, + gtk3, + pixman, + # For glewinfo + libXmu, + libXi, + libXext, +}: let packages = [ @@ -36,7 +57,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-Tgp9ud/Tq0K9ADf/POr+luuFm+QBWMucjKTbELbIveo="; }; - nativeBuildInputs = [ makeWrapper which xdg-utils ]; + nativeBuildInputs = [ + makeWrapper + which + xdg-utils + ]; unpackPhase = '' mkdir -p phony-home $out/share/applications @@ -94,11 +119,11 @@ stdenv.mkDerivation rec { Genymotion is a relatively fast Android emulator which comes with pre-configured Android (x86 with OpenGL hardware acceleration) images, suitable for application testing. - ''; + ''; homepage = "https://www.genymotion.com/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - platforms = ["x86_64-linux"]; + platforms = [ "x86_64-linux" ]; maintainers = [ maintainers.puffnfresh ]; }; } diff --git a/pkgs/by-name/ge/geoclue2/package.nix b/pkgs/by-name/ge/geoclue2/package.nix index 2b1e203c780890..cb6e524a9cb8e7 100644 --- a/pkgs/by-name/ge/geoclue2/package.nix +++ b/pkgs/by-name/ge/geoclue2/package.nix @@ -1,35 +1,40 @@ -{ lib -, stdenv -, fetchFromGitLab -, intltool -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_412 -, glib -, json-glib -, libsoup_3 -, libnotify -, gdk-pixbuf -, modemmanager -, avahi -, glib-networking -, python3 -, wrapGAppsHook3 -, gobject-introspection -, vala -, withDemoAgent ? false -, nix-update-script +{ + lib, + stdenv, + fetchFromGitLab, + intltool, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_412, + glib, + json-glib, + libsoup_3, + libnotify, + gdk-pixbuf, + modemmanager, + avahi, + glib-networking, + python3, + wrapGAppsHook3, + gobject-introspection, + vala, + withDemoAgent ? false, + nix-update-script, }: stdenv.mkDerivation (finalAttrs: { pname = "geoclue"; version = "2.7.2"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitLab { domain = "gitlab.freedesktop.org"; @@ -43,65 +48,76 @@ stdenv.mkDerivation (finalAttrs: { ./add-option-for-installation-sysconfdir.patch ]; - nativeBuildInputs = [ - pkg-config - intltool - meson - ninja - wrapGAppsHook3 - python3 - vala - gobject-introspection - # devdoc - gtk-doc - docbook-xsl-nons - docbook_xml_dtd_412 - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + pkg-config + intltool + meson + ninja + wrapGAppsHook3 + python3 + vala + gobject-introspection + # devdoc + gtk-doc + docbook-xsl-nons + docbook_xml_dtd_412 + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; - buildInputs = [ - glib - json-glib - libsoup_3 - avahi - ] ++ lib.optionals withDemoAgent [ - libnotify gdk-pixbuf - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - modemmanager - ]; + buildInputs = + [ + glib + json-glib + libsoup_3 + avahi + ] + ++ lib.optionals withDemoAgent [ + libnotify + gdk-pixbuf + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + modemmanager + ]; propagatedBuildInputs = [ glib glib-networking ]; - mesonFlags = [ - "-Dsystemd-system-unit-dir=${placeholder "out"}/lib/systemd/system" - "-Ddemo-agent=${lib.boolToString withDemoAgent}" - "--sysconfdir=/etc" - "-Dsysconfdir_install=${placeholder "out"}/etc" - "-Ddbus-srv-user=geoclue" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-D3g-source=false" - "-Dcdma-source=false" - "-Dmodem-gps-source=false" - "-Dnmea-source=false" - ]; + mesonFlags = + [ + "-Dsystemd-system-unit-dir=${placeholder "out"}/lib/systemd/system" + "-Ddemo-agent=${lib.boolToString withDemoAgent}" + "--sysconfdir=/etc" + "-Dsysconfdir_install=${placeholder "out"}/etc" + "-Ddbus-srv-user=geoclue" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-D3g-source=false" + "-Dcdma-source=false" + "-Dmodem-gps-source=false" + "-Dnmea-source=false" + ]; postPatch = '' chmod +x demo/install-file.py patchShebangs demo/install-file.py ''; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = with lib; { broken = stdenv.hostPlatform.isDarwin && withDemoAgent; description = "Geolocation framework and some data providers"; homepage = "https://gitlab.freedesktop.org/geoclue/geoclue/wikis/home"; changelog = "https://gitlab.freedesktop.org/geoclue/geoclue/-/blob/${finalAttrs.version}/NEWS"; - maintainers = with maintainers; [ raskin mimame ]; + maintainers = with maintainers; [ + raskin + mimame + ]; platforms = with platforms; linux ++ darwin; license = licenses.lgpl2Plus; }; diff --git a/pkgs/by-name/ge/geocode-glib/package.nix b/pkgs/by-name/ge/geocode-glib/package.nix index b459ad08f66246..9461c9fcb41242 100644 --- a/pkgs/by-name/ge/geocode-glib/package.nix +++ b/pkgs/by-name/ge/geocode-glib/package.nix @@ -1,26 +1,32 @@ -{ stdenv -, lib -, fetchurl -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, gettext -, gtk-doc -, docbook-xsl-nons -, gobject-introspection -, gnome -, libsoup_2_4 -, json-glib -, glib -, nixosTests +{ + stdenv, + lib, + fetchurl, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + gettext, + gtk-doc, + docbook-xsl-nons, + gobject-introspection, + gnome, + libsoup_2_4, + json-glib, + glib, + nixosTests, }: stdenv.mkDerivation rec { pname = "geocode-glib"; version = "3.26.4"; - outputs = [ "out" "dev" "devdoc" "installedTests" ]; + outputs = [ + "out" + "dev" + "devdoc" + "installedTests" + ]; src = fetchurl { url = "mirror://gnome/sources/geocode-glib/${lib.versions.majorMinor version}/geocode-glib-${version}.tar.xz"; @@ -31,17 +37,19 @@ stdenv.mkDerivation rec { ./installed-tests-path.patch ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - gettext - gtk-doc - docbook-xsl-nons - gobject-introspection - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gettext + gtk-doc + docbook-xsl-nons + gobject-introspection + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ glib diff --git a/pkgs/by-name/ge/geogram/package.nix b/pkgs/by-name/ge/geogram/package.nix index 444975de853c61..8dfff7a3d24a2b 100644 --- a/pkgs/by-name/ge/geogram/package.nix +++ b/pkgs/by-name/ge/geogram/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitHub - -, cmake -, doxygen -, zlib -, python3Packages +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + + cmake, + doxygen, + zlib, + python3Packages, }: let @@ -26,7 +27,13 @@ stdenv.mkDerivation rec { hash = "sha256-Xqha5HVqD2Ao0z++RKcQdMZUmtMb5eZ1DMJEVrfNUzE="; }; - outputs = [ "bin" "lib" "dev" "doc" "out" ]; + outputs = [ + "bin" + "lib" + "dev" + "doc" + "out" + ]; cmakeFlags = [ # Triangle is unfree @@ -122,7 +129,12 @@ stdenv.mkDerivation rec { # See https://github.com/BrunoLevy/geogram/issues/74 broken = stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; maintainers = with maintainers; [ tmarkus ]; }; } diff --git a/pkgs/by-name/ge/geographiclib/package.nix b/pkgs/by-name/ge/geographiclib/package.nix index cb733559ccb717..e0068ab3fe1fd8 100644 --- a/pkgs/by-name/ge/geographiclib/package.nix +++ b/pkgs/by-name/ge/geographiclib/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, doxygen }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + doxygen, +}: stdenv.mkDerivation rec { pname = "geographiclib"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-1CuB3H4KFFRo8wdFaa9NQLBdT8HxK2AdiVkEhbeYagM="; }; - nativeBuildInputs = [ cmake doxygen ]; + nativeBuildInputs = [ + cmake + doxygen + ]; cmakeFlags = [ "-DBUILD_DOCUMENTATION=ON" diff --git a/pkgs/by-name/ge/geoipjava/package.nix b/pkgs/by-name/ge/geoipjava/package.nix index cbb6b35a65c928..63759827a4f559 100644 --- a/pkgs/by-name/ge/geoipjava/package.nix +++ b/pkgs/by-name/ge/geoipjava/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, jdk, unzip}: +{ + lib, + stdenv, + fetchurl, + jdk, + unzip, +}: stdenv.mkDerivation rec { pname = "GeoIPJava"; @@ -10,17 +16,15 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ unzip ]; buildInputs = [ jdk ]; - buildPhase = - '' - cd source - javac $(find . -name \*.java) - jar cfv maxmindgeoip.jar $(find . -name \*.class) - ''; - installPhase = - '' - mkdir -p $out/share/java - cp maxmindgeoip.jar $out/share/java - ''; + buildPhase = '' + cd source + javac $(find . -name \*.java) + jar cfv maxmindgeoip.jar $(find . -name \*.class) + ''; + installPhase = '' + mkdir -p $out/share/java + cp maxmindgeoip.jar $out/share/java + ''; meta = { description = "GeoIP Java API"; license = lib.licenses.lgpl21Plus; diff --git a/pkgs/by-name/ge/geoipupdate/package.nix b/pkgs/by-name/ge/geoipupdate/package.nix index 7610050a429b31..45a37d824c2183 100644 --- a/pkgs/by-name/ge/geoipupdate/package.nix +++ b/pkgs/by-name/ge/geoipupdate/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "geoipupdate"; diff --git a/pkgs/by-name/ge/geonkick/package.nix b/pkgs/by-name/ge/geonkick/package.nix index c3c1fbcc47c9f2..5142d83ed671f0 100644 --- a/pkgs/by-name/ge/geonkick/package.nix +++ b/pkgs/by-name/ge/geonkick/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitLab, cmake, pkg-config, libsndfile, rapidjson -, libjack2, lv2, libX11, cairo, openssl }: +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + pkg-config, + libsndfile, + rapidjson, + libjack2, + lv2, + libX11, + cairo, + openssl, +}: stdenv.mkDerivation rec { pname = "geonkick"; @@ -12,9 +24,20 @@ stdenv.mkDerivation rec { hash = "sha256-bqdqAr4NX5WZ6zp0Kq7GFHiy/JkBvDvzuZz7jxtru0Q="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ libsndfile rapidjson libjack2 lv2 libX11 cairo openssl ]; + buildInputs = [ + libsndfile + rapidjson + libjack2 + lv2 + libX11 + cairo + openssl + ]; # Without this, the lv2 ends up in # /nix/store/$HASH/nix/store/$HASH/lib/lv2 diff --git a/pkgs/by-name/ge/geopard/package.nix b/pkgs/by-name/ge/geopard/package.nix index 348bd10500428d..a844858f50783e 100644 --- a/pkgs/by-name/ge/geopard/package.nix +++ b/pkgs/by-name/ge/geopard/package.nix @@ -1,17 +1,18 @@ -{ stdenv -, cargo -, rustc -, fetchFromGitHub -, libadwaita -, rustPlatform -, pkg-config -, lib -, wrapGAppsHook4 -, meson -, ninja -, desktop-file-utils -, blueprint-compiler -, glib-networking +{ + stdenv, + cargo, + rustc, + fetchFromGitHub, + libadwaita, + rustPlatform, + pkg-config, + lib, + wrapGAppsHook4, + meson, + ninja, + desktop-file-utils, + blueprint-compiler, + glib-networking, }: stdenv.mkDerivation (finalAttrs: { @@ -50,7 +51,10 @@ stdenv.mkDerivation (finalAttrs: { meta = { homepage = "https://github.com/ranfdev/Geopard"; description = "Colorful, adaptive gemini browser"; - maintainers = with lib.maintainers; [ jfvillablanca aleksana ]; + maintainers = with lib.maintainers; [ + jfvillablanca + aleksana + ]; license = lib.licenses.gpl3Plus; platforms = lib.platforms.linux; mainProgram = "geopard"; diff --git a/pkgs/by-name/ge/geoserver/extensions.nix b/pkgs/by-name/ge/geoserver/extensions.nix index bbb4af84c44798..9d3d4e63e31e1e 100644 --- a/pkgs/by-name/ge/geoserver/extensions.nix +++ b/pkgs/by-name/ge/geoserver/extensions.nix @@ -1,29 +1,42 @@ # DO *NOT* MODIFY THE LINES CONTAINING "hash = ..." OR "version = ...". # THEY ARE GENERATED. SEE ./update.sh. -{ fetchzip, libjpeg, netcdf, pkgs, stdenv }: +{ + fetchzip, + libjpeg, + netcdf, + pkgs, + stdenv, +}: let - mkGeoserverExtension = { name, version, hash, buildInputs ? [ ] }: stdenv.mkDerivation { - pname = "geoserver-${name}-extension"; - inherit buildInputs version; - - src = fetchzip { - url = "mirror://sourceforge/geoserver/GeoServer/${version}/extensions/geoserver-${version}-${name}-plugin.zip"; - inherit hash; - # We expect several files. - stripRoot = false; + mkGeoserverExtension = + { + name, + version, + hash, + buildInputs ? [ ], + }: + stdenv.mkDerivation { + pname = "geoserver-${name}-extension"; + inherit buildInputs version; + + src = fetchzip { + url = "mirror://sourceforge/geoserver/GeoServer/${version}/extensions/geoserver-${version}-${name}-plugin.zip"; + inherit hash; + # We expect several files. + stripRoot = false; + }; + + installPhase = '' + runHook preInstall + + DIR=$out/share/geoserver/webapps/geoserver/WEB-INF/lib + mkdir -p $DIR + cp -r $src/* $DIR + + runHook postInstall + ''; }; - - installPhase = '' - runHook preInstall - - DIR=$out/share/geoserver/webapps/geoserver/WEB-INF/lib - mkdir -p $DIR - cp -r $src/* $DIR - - runHook postInstall - ''; - }; in { diff --git a/pkgs/by-name/ge/geoserver/package.nix b/pkgs/by-name/ge/geoserver/package.nix index d5549b03e9247b..a228335d3e686b 100644 --- a/pkgs/by-name/ge/geoserver/package.nix +++ b/pkgs/by-name/ge/geoserver/package.nix @@ -1,11 +1,12 @@ -{ lib -, callPackage -, fetchurl -, makeWrapper -, nixosTests -, stdenv -, jre -, unzip +{ + lib, + callPackage, + fetchurl, + makeWrapper, + nixosTests, + stdenv, + jre, + unzip, }: stdenv.mkDerivation (finalAttrs: rec { pname = "geoserver"; @@ -22,12 +23,16 @@ stdenv.mkDerivation (finalAttrs: rec { ]; sourceRoot = "."; - nativeBuildInputs = [ unzip makeWrapper ]; + nativeBuildInputs = [ + unzip + makeWrapper + ]; installPhase = let inputs = finalAttrs.buildInputs or [ ]; - ldLibraryPathEnvName = if stdenv.hostPlatform.isDarwin then "DYLD_LIBRARY_PATH" else "LD_LIBRARY_PATH"; + ldLibraryPathEnvName = + if stdenv.hostPlatform.isDarwin then "DYLD_LIBRARY_PATH" else "LD_LIBRARY_PATH"; in '' runHook preInstall @@ -48,28 +53,34 @@ stdenv.mkDerivation (finalAttrs: rec { runHook postInstall ''; - passthru = let geoserver = finalAttrs.finalPackage; extensions = lib.attrsets.filterAttrs (n: v: lib.isDerivation v) (callPackage ./extensions.nix { }); in { - withExtensions = selector: + withExtensions = + selector: let selectedExtensions = selector extensions; in - geoserver.overrideAttrs (finalAttrs: previousAttrs: { - pname = previousAttrs.pname + "-with-extensions"; - buildInputs = lib.lists.unique ((previousAttrs.buildInputs or [ ]) ++ lib.lists.concatMap (drv: drv.buildInputs) selectedExtensions); - postInstall = (previousAttrs.postInstall or "") + '' - for extension in ${builtins.toString selectedExtensions} ; do - cp -r $extension/* $out - # Some files are the same for all/several extensions. We allow overwriting them again. - chmod -R +w $out - done - ''; - }); + geoserver.overrideAttrs ( + finalAttrs: previousAttrs: { + pname = previousAttrs.pname + "-with-extensions"; + buildInputs = lib.lists.unique ( + (previousAttrs.buildInputs or [ ]) ++ lib.lists.concatMap (drv: drv.buildInputs) selectedExtensions + ); + postInstall = + (previousAttrs.postInstall or "") + + '' + for extension in ${builtins.toString selectedExtensions} ; do + cp -r $extension/* $out + # Some files are the same for all/several extensions. We allow overwriting them again. + chmod -R +w $out + done + ''; + } + ); tests.geoserver = nixosTests.geoserver; updateScript = ./update.sh; }; diff --git a/pkgs/by-name/ge/gephi/package.nix b/pkgs/by-name/ge/gephi/package.nix index fe638bde1ba462..731177a07cac25 100644 --- a/pkgs/by-name/ge/gephi/package.nix +++ b/pkgs/by-name/ge/gephi/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, jdk11, maven, jogl }: +{ + lib, + fetchFromGitHub, + jdk11, + maven, + jogl, +}: maven.buildMavenPackage rec { pname = "gephi"; @@ -37,7 +43,7 @@ maven.buildMavenPackage rec { homepage = "https://gephi.org"; sourceProvenance = with sourceTypes; [ fromSource - binaryBytecode # deps + binaryBytecode # deps ]; license = licenses.gpl3; maintainers = [ maintainers.taeer ]; diff --git a/pkgs/by-name/ge/gerbera/package.nix b/pkgs/by-name/ge/gerbera/package.nix index dcd78acb26318f..6f8a3686801bed 100644 --- a/pkgs/by-name/ge/gerbera/package.nix +++ b/pkgs/by-name/ge/gerbera/package.nix @@ -1,42 +1,43 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + nixosTests, # required -, libiconv -, libupnp -, libuuid -, pugixml -, spdlog -, sqlite -, zlib + libiconv, + libupnp, + libuuid, + pugixml, + spdlog, + sqlite, + zlib, # options -, enableMysql ? false -, libmysqlclient -, enableDuktape ? true -, duktape -, enableCurl ? true -, curl -, enableTaglib ? true -, taglib -, enableLibmagic ? true -, file -, enableLibmatroska ? true -, libmatroska -, libebml -, enableAvcodec ? false -, ffmpeg -, enableLibexif ? true -, libexif -, enableExiv2 ? false -, exiv2 -, enableFFmpegThumbnailer ? false -, ffmpegthumbnailer -, enableInotifyTools ? true -, inotify-tools + enableMysql ? false, + libmysqlclient, + enableDuktape ? true, + duktape, + enableCurl ? true, + curl, + enableTaglib ? true, + taglib, + enableLibmagic ? true, + file, + enableLibmatroska ? true, + libmatroska, + libebml, + enableAvcodec ? false, + ffmpeg, + enableLibexif ? true, + libexif, + enableExiv2 ? false, + exiv2, + enableFFmpegThumbnailer ? false, + ffmpegthumbnailer, + enableInotifyTools ? true, + inotify-tools, }: let @@ -48,17 +49,64 @@ let }); options = [ - { name = "AVCODEC"; enable = enableAvcodec; packages = [ ffmpeg ]; } - { name = "CURL"; enable = enableCurl; packages = [ curl ]; } - { name = "EXIF"; enable = enableLibexif; packages = [ libexif ]; } - { name = "EXIV2"; enable = enableExiv2; packages = [ exiv2 ]; } - { name = "FFMPEGTHUMBNAILER"; enable = enableFFmpegThumbnailer; packages = [ ffmpegthumbnailer ]; } - { name = "INOTIFY"; enable = enableInotifyTools; packages = [ inotify-tools ]; } - { name = "JS"; enable = enableDuktape; packages = [ duktape ]; } - { name = "MAGIC"; enable = enableLibmagic; packages = [ file ]; } - { name = "MATROSKA"; enable = enableLibmatroska; packages = [ libmatroska libebml ]; } - { name = "MYSQL"; enable = enableMysql; packages = [ libmysqlclient ]; } - { name = "TAGLIB"; enable = enableTaglib; packages = [ taglib ]; } + { + name = "AVCODEC"; + enable = enableAvcodec; + packages = [ ffmpeg ]; + } + { + name = "CURL"; + enable = enableCurl; + packages = [ curl ]; + } + { + name = "EXIF"; + enable = enableLibexif; + packages = [ libexif ]; + } + { + name = "EXIV2"; + enable = enableExiv2; + packages = [ exiv2 ]; + } + { + name = "FFMPEGTHUMBNAILER"; + enable = enableFFmpegThumbnailer; + packages = [ ffmpegthumbnailer ]; + } + { + name = "INOTIFY"; + enable = enableInotifyTools; + packages = [ inotify-tools ]; + } + { + name = "JS"; + enable = enableDuktape; + packages = [ duktape ]; + } + { + name = "MAGIC"; + enable = enableLibmagic; + packages = [ file ]; + } + { + name = "MATROSKA"; + enable = enableLibmatroska; + packages = [ + libmatroska + libebml + ]; + } + { + name = "MYSQL"; + enable = enableMysql; + packages = [ libmysqlclient ]; + } + { + name = "TAGLIB"; + enable = enableTaglib; + packages = [ taglib ]; + } ]; inherit (lib) flatten optionals; @@ -96,7 +144,10 @@ stdenv.mkDerivation rec { "-DWITH_SYSTEMD=OFF" ] ++ map (e: "-DWITH_${e.name}=${if e.enable then "ON" else "OFF"}") options; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libiconv diff --git a/pkgs/by-name/ge/gerbolyze/package.nix b/pkgs/by-name/ge/gerbolyze/package.nix index 963f578dfe51e1..d8910592aed6be 100644 --- a/pkgs/by-name/ge/gerbolyze/package.nix +++ b/pkgs/by-name/ge/gerbolyze/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, python3Packages -, fetchFromGitHub -, gitUpdater -, resvg +{ + lib, + stdenv, + python3Packages, + fetchFromGitHub, + gitUpdater, + resvg, }: let @@ -44,7 +45,8 @@ let platforms = platforms.linux; }; }; -in python3Packages.buildPythonApplication rec { +in +python3Packages.buildPythonApplication rec { inherit version src; pname = "gerbolyze"; @@ -80,7 +82,11 @@ in python3Packages.buildPythonApplication rec { pythonImportsCheck = [ "gerbolyze" ]; - nativeCheckInputs = [ python3Packages.pytestCheckHook resvg svg-flatten ]; + nativeCheckInputs = [ + python3Packages.pytestCheckHook + resvg + svg-flatten + ]; passthru.updateScript = gitUpdater { rev-prefix = "v"; diff --git a/pkgs/by-name/ge/germinal/package.nix b/pkgs/by-name/ge/germinal/package.nix index cf9727e119926d..83c0b977b08125 100644 --- a/pkgs/by-name/ge/germinal/package.nix +++ b/pkgs/by-name/ge/germinal/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, appstream-glib -, autoreconfHook -, dbus -, pango -, pcre2 -, pkg-config -, tmux -, vte -, wrapGAppsHook3 -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + appstream-glib, + autoreconfHook, + dbus, + pango, + pcre2, + pkg-config, + tmux, + vte, + wrapGAppsHook3, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ge/gerrit-queue/package.nix b/pkgs/by-name/ge/gerrit-queue/package.nix index e9369e8f0232f3..f0558a1b55a53f 100644 --- a/pkgs/by-name/ge/gerrit-queue/package.nix +++ b/pkgs/by-name/ge/gerrit-queue/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, lib -, fetchFromGitHub +{ + buildGoModule, + lib, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ge/get-google-fonts/package.nix b/pkgs/by-name/ge/get-google-fonts/package.nix index 0939c43443e3f8..ec4bb400ec920b 100644 --- a/pkgs/by-name/ge/get-google-fonts/package.nix +++ b/pkgs/by-name/ge/get-google-fonts/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, fetchpatch +{ + lib, + buildNpmPackage, + fetchFromGitHub, + fetchpatch, }: buildNpmPackage { diff --git a/pkgs/by-name/ge/get_iplayer/package.nix b/pkgs/by-name/ge/get_iplayer/package.nix index c807438aaa43d3..649acec9aa3465 100644 --- a/pkgs/by-name/ge/get_iplayer/package.nix +++ b/pkgs/by-name/ge/get_iplayer/package.nix @@ -1,12 +1,13 @@ -{ lib -, perlPackages -, fetchFromGitHub -, makeWrapper -, stdenv -, shortenPerlShebang -, perl -, atomicparsley -, ffmpeg +{ + lib, + perlPackages, + fetchFromGitHub, + makeWrapper, + stdenv, + shortenPerlShebang, + perl, + atomicparsley, + ffmpeg, }: perlPackages.buildPerlPackage rec { @@ -23,18 +24,29 @@ perlPackages.buildPerlPackage rec { nativeBuildInputs = [ makeWrapper ] ++ lib.optional stdenv.hostPlatform.isDarwin shortenPerlShebang; buildInputs = [ perl ]; propagatedBuildInputs = with perlPackages; [ - LWP LWPProtocolHttps XMLLibXML Mojolicious + LWP + LWPProtocolHttps + XMLLibXML + Mojolicious ]; preConfigure = "touch Makefile.PL"; doCheck = false; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; installPhase = '' runHook preInstall install -D get_iplayer -t $out/bin - wrapProgram $out/bin/get_iplayer --suffix PATH : ${lib.makeBinPath [ atomicparsley ffmpeg ]} --prefix PERL5LIB : $PERL5LIB + wrapProgram $out/bin/get_iplayer --suffix PATH : ${ + lib.makeBinPath [ + atomicparsley + ffmpeg + ] + } --prefix PERL5LIB : $PERL5LIB install -Dm444 get_iplayer.1 -t $out/share/man/man1 runHook postInstall @@ -50,7 +62,10 @@ perlPackages.buildPerlPackage rec { license = licenses.gpl3Plus; homepage = "https://github.com/get-iplayer/get_iplayer"; platforms = platforms.all; - maintainers = with maintainers; [ rika chewblacka ]; + maintainers = with maintainers; [ + rika + chewblacka + ]; }; } diff --git a/pkgs/by-name/ge/getdata/package.nix b/pkgs/by-name/ge/getdata/package.nix index 8617d7ddd2f254..6443f016d8bd2e 100644 --- a/pkgs/by-name/ge/getdata/package.nix +++ b/pkgs/by-name/ge/getdata/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libtool }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libtool, +}: stdenv.mkDerivation rec { pname = "getdata"; version = "0.11.0"; diff --git a/pkgs/by-name/ge/getdp/package.nix b/pkgs/by-name/ge/getdp/package.nix index 30a5837c3111d6..99127704968e1a 100644 --- a/pkgs/by-name/ge/getdp/package.nix +++ b/pkgs/by-name/ge/getdp/package.nix @@ -1,8 +1,20 @@ -{ lib, stdenv, fetchurl, cmake, gfortran, blas, lapack, mpi, petsc, python3 }: +{ + lib, + stdenv, + fetchurl, + cmake, + gfortran, + blas, + lapack, + mpi, + petsc, + python3, +}: let mpiSupport = petsc.passthru.mpiSupport; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "getdp"; version = "3.6.0"; src = fetchurl { @@ -10,10 +22,16 @@ in stdenv.mkDerivation rec { hash = "sha256-nzefwCV+Z9BHDofuTfhR+vhqm3cCSiUT+7cbtn601N8="; }; - nativeBuildInputs = [ cmake python3 ]; - buildInputs = [ gfortran blas lapack petsc ] - ++ lib.optional mpiSupport mpi - ; + nativeBuildInputs = [ + cmake + python3 + ]; + buildInputs = [ + gfortran + blas + lapack + petsc + ] ++ lib.optional mpiSupport mpi; cmakeFlags = lib.optional mpiSupport "-DENABLE_MPI=1"; meta = with lib; { diff --git a/pkgs/by-name/ge/geteltorito/package.nix b/pkgs/by-name/ge/geteltorito/package.nix index 7bbedde4dac6b2..d0f2520d36048e 100644 --- a/pkgs/by-name/ge/geteltorito/package.nix +++ b/pkgs/by-name/ge/geteltorito/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, perl, ronn, fetchurl }: +{ + lib, + stdenv, + perl, + ronn, + fetchurl, +}: stdenv.mkDerivation rec { pname = "geteltorito"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1gkbm9ahj2mgqrkrfpibzclsriqgsbsvjh19fr815vpd9f6snkxv"; }; - buildInputs = [ perl ronn ]; + buildInputs = [ + perl + ronn + ]; unpackCmd = ""; dontBuild = true; diff --git a/pkgs/by-name/ge/geticons/package.nix b/pkgs/by-name/ge/geticons/package.nix index 5d8d7d2d1df88c..59dbc347087214 100644 --- a/pkgs/by-name/ge/geticons/package.nix +++ b/pkgs/by-name/ge/geticons/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromSourcehut -, gitUpdater +{ + lib, + rustPlatform, + fetchFromSourcehut, + gitUpdater, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ge/getmail6/package.nix b/pkgs/by-name/ge/getmail6/package.nix index 3ba6da5b42c6af..2513718cf40b77 100644 --- a/pkgs/by-name/ge/getmail6/package.nix +++ b/pkgs/by-name/ge/getmail6/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { @@ -36,6 +37,9 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://getmail6.org"; changelog = "https://github.com/getmail6/getmail6/blob/${src.rev}/docs/CHANGELOG"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ abbe dotlambda ]; + maintainers = with maintainers; [ + abbe + dotlambda + ]; }; } diff --git a/pkgs/by-name/ge/getopt/package.nix b/pkgs/by-name/ge/getopt/package.nix index 51ab637c6ba1d8..4eee5368c2b9da 100644 --- a/pkgs/by-name/ge/getopt/package.nix +++ b/pkgs/by-name/ge/getopt/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "getopt"; diff --git a/pkgs/by-name/ge/getoptions/package.nix b/pkgs/by-name/ge/getoptions/package.nix index d3dcde29dcd66c..344658b1962aa1 100644 --- a/pkgs/by-name/ge/getoptions/package.nix +++ b/pkgs/by-name/ge/getoptions/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenvNoCC, fetchFromGitHub, shellspec, busybox-sandbox-shell, ksh, mksh, yash, zsh }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + shellspec, + busybox-sandbox-shell, + ksh, + mksh, + yash, + zsh, +}: stdenvNoCC.mkDerivation rec { pname = "getoptions"; @@ -15,17 +25,24 @@ stdenvNoCC.mkDerivation rec { doCheck = true; - nativeCheckInputs = [ shellspec ksh mksh yash zsh ] - ++ lib.lists.optional (!stdenvNoCC.hostPlatform.isDarwin) busybox-sandbox-shell; + nativeCheckInputs = [ + shellspec + ksh + mksh + yash + zsh + ] ++ lib.lists.optional (!stdenvNoCC.hostPlatform.isDarwin) busybox-sandbox-shell; # Disable checks against yash, since shellspec seems to be broken for yash>=2.54 # (see: https://github.com/NixOS/nixpkgs/pull/218264#pullrequestreview-1434402054) - preCheck = '' - sed -i '/shellspec -s posh/d' Makefile - sed -i '/shellspec -s yash/d' Makefile - '' + lib.strings.optionalString stdenvNoCC.hostPlatform.isDarwin '' - sed -i "/shellspec -s 'busybox ash'/d" Makefile - ''; + preCheck = + '' + sed -i '/shellspec -s posh/d' Makefile + sed -i '/shellspec -s yash/d' Makefile + '' + + lib.strings.optionalString stdenvNoCC.hostPlatform.isDarwin '' + sed -i "/shellspec -s 'busybox ash'/d" Makefile + ''; checkTarget = "test_in_various_shells"; diff --git a/pkgs/by-name/ge/getxbook/package.nix b/pkgs/by-name/ge/getxbook/package.nix index 40e8db2a086c7a..e30d863f46fb71 100644 --- a/pkgs/by-name/ge/getxbook/package.nix +++ b/pkgs/by-name/ge/getxbook/package.nix @@ -1,20 +1,25 @@ -{ lib, stdenv, fetchurl, openssl }: +{ + lib, + stdenv, + fetchurl, + openssl, +}: stdenv.mkDerivation rec { pname = "getxbook"; version = "1.2"; src = fetchurl { - url = "https://njw.me.uk/getxbook/${pname}-${version}.tar.xz"; + url = "https://njw.me.uk/getxbook/${pname}-${version}.tar.xz"; sha256 = "0ihwrx4gspj8l7fc8vxch6dpjrw1lvv9z3c19f0wxnmnxhv1cjvs"; }; env.NIX_CFLAGS_COMPILE = builtins.toString ( [ "-Wno-error=deprecated-declarations" ] - ++ lib.optionals (!stdenv.cc.isClang) [ - "-Wno-error=format-truncation" - "-Wno-error=stringop-overflow" - ] + ++ lib.optionals (!stdenv.cc.isClang) [ + "-Wno-error=format-truncation" + "-Wno-error=stringop-overflow" + ] ); buildInputs = [ openssl ]; @@ -23,9 +28,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Collection of tools to download books from Google Books"; - homepage = "https://njw.me.uk/getxbook/"; - license = licenses.isc; + homepage = "https://njw.me.uk/getxbook/"; + license = licenses.isc; maintainers = with maintainers; [ obadz ]; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/ge/gexiv2/package.nix b/pkgs/by-name/ge/gexiv2/package.nix index 7a0e61cbf2b05e..54b173d08aca51 100644 --- a/pkgs/by-name/ge/gexiv2/package.nix +++ b/pkgs/by-name/ge/gexiv2/package.nix @@ -1,45 +1,52 @@ -{ stdenv -, lib -, fetchurl -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, exiv2 -, glib -, gnome -, gobject-introspection -, vala -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_43 -, python3 +{ + stdenv, + lib, + fetchurl, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + exiv2, + glib, + gnome, + gobject-introspection, + vala, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_43, + python3, }: stdenv.mkDerivation rec { pname = "gexiv2"; version = "0.14.3"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; sha256 = "IeZNLFbpszPUT+8/KkslZT2SLEGazZcvqW+raVIX4sg="; }; - nativeBuildInputs = [ - meson - ninja - pkg-config - gobject-introspection - vala - gtk-doc - docbook-xsl-nons - docbook_xml_dtd_43 - (python3.pythonOnBuildForHost.withPackages (ps: [ ps.pygobject3 ])) - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gobject-introspection + vala + gtk-doc + docbook-xsl-nons + docbook_xml_dtd_43 + (python3.pythonOnBuildForHost.withPackages (ps: [ ps.pygobject3 ])) + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ glib @@ -56,16 +63,18 @@ stdenv.mkDerivation rec { doCheck = true; - preCheck = let - libSuffix = if stdenv.hostPlatform.isDarwin then "2.dylib" else "so.2"; - in '' - # Our gobject-introspection patches make the shared library paths absolute - # in the GIR files. When running unit tests, the library is not yet installed, - # though, so we need to replace the absolute path with a local one during build. - # We are using a symlink that will be overridden during installation. - mkdir -p $out/lib - ln -s $PWD/gexiv2/libgexiv2.${libSuffix} $out/lib/libgexiv2.${libSuffix} - ''; + preCheck = + let + libSuffix = if stdenv.hostPlatform.isDarwin then "2.dylib" else "so.2"; + in + '' + # Our gobject-introspection patches make the shared library paths absolute + # in the GIR files. When running unit tests, the library is not yet installed, + # though, so we need to replace the absolute path with a local one during build. + # We are using a symlink that will be overridden during installation. + mkdir -p $out/lib + ln -s $PWD/gexiv2/libgexiv2.${libSuffix} $out/lib/libgexiv2.${libSuffix} + ''; passthru = { updateScript = gnome.updateScript { diff --git a/pkgs/by-name/gf/gf2x/package.nix b/pkgs/by-name/gf/gf2x/package.nix index 1b45be6112812f..4b469c91cd56f8 100644 --- a/pkgs/by-name/gf/gf2x/package.nix +++ b/pkgs/by-name/gf/gf2x/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, autoreconfHook -, buildPackages -, optimize ? false # impure hardware optimizations +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + autoreconfHook, + buildPackages, + optimize ? false, # impure hardware optimizations }: stdenv.mkDerivation rec { pname = "gf2x"; diff --git a/pkgs/by-name/gf/gfal2-util/package.nix b/pkgs/by-name/gf/gfal2-util/package.nix index 8af9899455af22..e99adedfa76090 100644 --- a/pkgs/by-name/gf/gfal2-util/package.nix +++ b/pkgs/by-name/gf/gfal2-util/package.nix @@ -1,2 +1 @@ -{ python3Packages }: -with python3Packages; toPythonApplication gfal2-util +{ python3Packages }: with python3Packages; toPythonApplication gfal2-util diff --git a/pkgs/by-name/gf/gfal2/package.nix b/pkgs/by-name/gf/gfal2/package.nix index 205f6e192bc444..273c0411f02df8 100644 --- a/pkgs/by-name/gf/gfal2/package.nix +++ b/pkgs/by-name/gf/gfal2/package.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, # Native build inputs -, cmake -, pkg-config + cmake, + pkg-config, # General build inputs -, glib -, gtest -, json_c -, openldap + glib, + gtest, + json_c, + openldap, # Plugin build inputs -, cryptopp -, davix-copy -, dcap -, libssh2 -, libuuid -, pugixml -, xrootd + cryptopp, + davix-copy, + dcap, + libssh2, + libuuid, + pugixml, + xrootd, # For enablePluginStatus.https only -, gsoap + gsoap, }: stdenv.mkDerivation (finalAttrs: { pname = "gfal2"; @@ -49,26 +50,35 @@ stdenv.mkDerivation (finalAttrs: { xrootd = true; }; - passthru.tests = ( - # Enable only one plugin in each test case, - # to ensure that they gets their dependency when invoked separately. - lib.listToAttrs - (map - (pluginName: lib.nameValuePair - "gfal2-${pluginName}" - (finalAttrs.finalPackage.overrideAttrs (previousAttrs: { - passthru = previousAttrs.passthru // { - enablePluginStatus = lib.mapAttrs (n: v: n == pluginName) previousAttrs.passthru.enablePluginStatus; - }; - }))) - (lib.filter (lib.flip lib.getAttr finalAttrs.passthru.enablePluginStatus) (lib.attrNames finalAttrs.passthru.enablePluginStatus)) + passthru.tests = + ( + # Enable only one plugin in each test case, + # to ensure that they gets their dependency when invoked separately. + lib.listToAttrs ( + map + ( + pluginName: + lib.nameValuePair "gfal2-${pluginName}" ( + finalAttrs.finalPackage.overrideAttrs (previousAttrs: { + passthru = previousAttrs.passthru // { + enablePluginStatus = lib.mapAttrs (n: v: n == pluginName) previousAttrs.passthru.enablePluginStatus; + }; + }) + ) + ) + ( + lib.filter (lib.flip lib.getAttr finalAttrs.passthru.enablePluginStatus) ( + lib.attrNames finalAttrs.passthru.enablePluginStatus + ) + ) ) - ) // { - # Disable all plugins in this test case. - gfal2-minimal = finalAttrs.finalPackage.overrideAttrs (previousAttrs: { - passthru.enablePluginStatus = lib.mapAttrs (n: v: false) previousAttrs.passthru.enablePluginStatus; - }); - }; + ) + // { + # Disable all plugins in this test case. + gfal2-minimal = finalAttrs.finalPackage.overrideAttrs (previousAttrs: { + passthru.enablePluginStatus = lib.mapAttrs (n: v: false) previousAttrs.passthru.enablePluginStatus; + }); + }; nativeBuildInputs = [ cmake @@ -87,22 +97,33 @@ stdenv.mkDerivation (finalAttrs: { pugixml # Optional, for MDS Cache. ] ++ lib.optionals finalAttrs.passthru.enablePluginStatus.dcap [ dcap ] - ++ lib.optionals finalAttrs.passthru.enablePluginStatus.http [ cryptopp davix-copy ] + ++ lib.optionals finalAttrs.passthru.enablePluginStatus.http [ + cryptopp + davix-copy + ] ++ lib.optionals finalAttrs.passthru.enablePluginStatus.mock [ libuuid ] ++ lib.optionals finalAttrs.passthru.enablePluginStatus.sftp [ libssh2 ] - ++ lib.optionals finalAttrs.passthru.enablePluginStatus.xrootd [ xrootd libuuid ] + ++ lib.optionals finalAttrs.passthru.enablePluginStatus.xrootd [ + xrootd + libuuid + ] ); - cmakeFlags = ( - map - (pluginName: "-DPLUGIN_${lib.toUpper pluginName}=${lib.toUpper (lib.boolToString finalAttrs.passthru.enablePluginStatus.${pluginName})}") - (lib.attrNames finalAttrs.passthru.enablePluginStatus) - ) - ++ [ "-DSKIP_TESTS=${lib.toUpper (lib.boolToString (!finalAttrs.finalPackage.doCheck))}" ] - ++ lib.optionals finalAttrs.finalPackage.doCheck [ "-DGTEST_INCLUDE_DIR=${gtest.dev}/include" ] - ++ lib.optionals finalAttrs.passthru.enablePluginStatus.http [ "-DCRYPTOPP_INCLUDE_DIRS=${cryptopp.dev}/include/cryptopp" ] - ++ lib.optionals finalAttrs.passthru.enablePluginStatus.xrootd [ "-DXROOTD_INCLUDE_DIR=${xrootd.dev}/include/xrootd" ] - ; + cmakeFlags = + (map ( + pluginName: + "-DPLUGIN_${lib.toUpper pluginName}=${ + lib.toUpper (lib.boolToString finalAttrs.passthru.enablePluginStatus.${pluginName}) + }" + ) (lib.attrNames finalAttrs.passthru.enablePluginStatus)) + ++ [ "-DSKIP_TESTS=${lib.toUpper (lib.boolToString (!finalAttrs.finalPackage.doCheck))}" ] + ++ lib.optionals finalAttrs.finalPackage.doCheck [ "-DGTEST_INCLUDE_DIR=${gtest.dev}/include" ] + ++ lib.optionals finalAttrs.passthru.enablePluginStatus.http [ + "-DCRYPTOPP_INCLUDE_DIRS=${cryptopp.dev}/include/cryptopp" + ] + ++ lib.optionals finalAttrs.passthru.enablePluginStatus.xrootd [ + "-DXROOTD_INCLUDE_DIR=${xrootd.dev}/include/xrootd" + ]; doCheck = stdenv.hostPlatform.isLinux; diff --git a/pkgs/by-name/gf/gfan/package.nix b/pkgs/by-name/gf/gfan/package.nix index 531a30e3f857fc..9410d7d2e49168 100644 --- a/pkgs/by-name/gf/gfan/package.nix +++ b/pkgs/by-name/gf/gfan/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchpatch, fetchurl, gmp, mpir, cddlib}: +{ + lib, + stdenv, + fetchpatch, + fetchurl, + gmp, + mpir, + cddlib, +}: stdenv.mkDerivation rec { pname = "gfan"; version = "0.6.2"; @@ -8,15 +16,17 @@ stdenv.mkDerivation rec { sha256 = "02pihqb1lb76a0xbfwjzs1cd6ay3ldfxsm8dvsbl6qs3vkjxax56"; }; - patches = [ - ./gfan-0.6.2-cddlib-prefix.patch - ] ++ lib.optionals (stdenv.cc.isClang) [ - (fetchpatch { - name = "clang-fix-miscompilation.patch"; - url = "https://raw.githubusercontent.com/sagemath/sage/eea1f59394a5066e9acd8ae39a90302820914ee3/build/pkgs/gfan/patches/nodel.patch"; - sha256 = "sha256-RrncSgFyrBIk/Bwe3accxiJ2rpOSJKQ84cV/uBvQsDc="; - }) - ]; + patches = + [ + ./gfan-0.6.2-cddlib-prefix.patch + ] + ++ lib.optionals (stdenv.cc.isClang) [ + (fetchpatch { + name = "clang-fix-miscompilation.patch"; + url = "https://raw.githubusercontent.com/sagemath/sage/eea1f59394a5066e9acd8ae39a90302820914ee3/build/pkgs/gfan/patches/nodel.patch"; + sha256 = "sha256-RrncSgFyrBIk/Bwe3accxiJ2rpOSJKQ84cV/uBvQsDc="; + }) + ]; postPatch = lib.optionalString stdenv.cc.isClang '' substituteInPlace Makefile --replace "-fno-guess-branch-probability" "" @@ -26,14 +36,21 @@ stdenv.mkDerivation rec { done ''; - buildFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "CXX=${stdenv.cc.targetPrefix}c++" ]; + buildFlags = [ + "CC=${stdenv.cc.targetPrefix}cc" + "CXX=${stdenv.cc.targetPrefix}c++" + ]; installFlags = [ "PREFIX=$(out)" ]; - buildInputs = [ gmp mpir cddlib ]; + buildInputs = [ + gmp + mpir + cddlib + ]; meta = { description = "Software package for computing Gröbner fans and tropical varieties"; - license = lib.licenses.gpl2 ; - maintainers = [lib.maintainers.raskin]; + license = lib.licenses.gpl2; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.unix; homepage = "http://home.math.au.dk/jensen/software/gfan/gfan.html"; }; diff --git a/pkgs/by-name/gf/gfbgraph/package.nix b/pkgs/by-name/gf/gfbgraph/package.nix index 2affe005284c30..bc283264de3a0e 100644 --- a/pkgs/by-name/gf/gfbgraph/package.nix +++ b/pkgs/by-name/gf/gfbgraph/package.nix @@ -1,23 +1,28 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, glib -, librest -, gnome-online-accounts -, gnome -, libsoup_2_4 -, json-glib -, gobject-introspection -, gtk-doc -, docbook-xsl-nons +{ + stdenv, + lib, + fetchurl, + pkg-config, + glib, + librest, + gnome-online-accounts, + gnome, + libsoup_2_4, + json-glib, + gobject-introspection, + gtk-doc, + docbook-xsl-nons, }: stdenv.mkDerivation rec { pname = "gfbgraph"; version = "0.2.5"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/gf/gflags/package.nix b/pkgs/by-name/gf/gflags/package.nix index 19926fb1d6ffee..b01b862804e3f4 100644 --- a/pkgs/by-name/gf/gflags/package.nix +++ b/pkgs/by-name/gf/gflags/package.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, enableShared ? !stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + enableShared ? !stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gf/gforth/boot-forth.nix b/pkgs/by-name/gf/gforth/boot-forth.nix index 9a4d676f513024..977e7ab5988cd9 100644 --- a/pkgs/by-name/gf/gforth/boot-forth.nix +++ b/pkgs/by-name/gf/gforth/boot-forth.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, m4 }: +{ + lib, + stdenv, + fetchurl, + m4, +}: let version = "0.7.3"; diff --git a/pkgs/by-name/gf/gforth/package.nix b/pkgs/by-name/gf/gforth/package.nix index 6b68f7b47c5c91..ac3834f5ad3fe8 100644 --- a/pkgs/by-name/gf/gforth/package.nix +++ b/pkgs/by-name/gf/gforth/package.nix @@ -1,12 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, callPackage -, autoreconfHook, texinfo, libffi +{ + lib, + stdenv, + fetchFromGitHub, + callPackage, + autoreconfHook, + texinfo, + libffi, }: let swig = callPackage ./swig.nix { }; bootForth = callPackage ./boot-forth.nix { }; lispDir = "${placeholder "out"}/share/emacs/site-lisp"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "gforth"; version = "0.7.9_20230518"; @@ -19,7 +26,10 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ - autoreconfHook texinfo bootForth swig + autoreconfHook + texinfo + bootForth + swig ]; buildInputs = [ libffi @@ -27,11 +37,13 @@ in stdenv.mkDerivation rec { passthru = { inherit bootForth; }; - configureFlags = [ - "--with-lispdir=${lispDir}" - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ - "--build=x86_64-apple-darwin" - ]; + configureFlags = + [ + "--with-lispdir=${lispDir}" + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + "--build=x86_64-apple-darwin" + ]; preConfigure = '' mkdir -p ${lispDir} diff --git a/pkgs/by-name/gf/gfs2-utils/package.nix b/pkgs/by-name/gf/gfs2-utils/package.nix index 00c73ce3e603d4..6c3634fe48d366 100644 --- a/pkgs/by-name/gf/gfs2-utils/package.nix +++ b/pkgs/by-name/gf/gfs2-utils/package.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchurl -, autoreconfHook, bison, flex, pkg-config -, bzip2, check, ncurses, util-linux, zlib +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + bison, + flex, + pkg-config, + bzip2, + check, + ncurses, + util-linux, + zlib, }: stdenv.mkDerivation rec { @@ -12,10 +22,25 @@ stdenv.mkDerivation rec { hash = "sha256-ZWzNfYuhIxGmSAe454vRjAKp9Lq7EBBSY36P7qVgZnw="; }; - outputs = [ "bin" "doc" "out" "man" ]; + outputs = [ + "bin" + "doc" + "out" + "man" + ]; - nativeBuildInputs = [ autoreconfHook bison flex pkg-config ]; - buildInputs = [ bzip2 ncurses util-linux zlib ]; + nativeBuildInputs = [ + autoreconfHook + bison + flex + pkg-config + ]; + buildInputs = [ + bzip2 + ncurses + util-linux + zlib + ]; nativeCheckInputs = [ check ]; doCheck = true; @@ -26,7 +51,10 @@ stdenv.mkDerivation rec { homepage = "https://pagure.io/gfs2-utils"; description = "Tools for creating, checking and working with gfs2 filesystems"; maintainers = with maintainers; [ qyliss ]; - license = [ licenses.gpl2Plus licenses.lgpl2Plus ]; + license = [ + licenses.gpl2Plus + licenses.lgpl2Plus + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/gf/gfshare/package.nix b/pkgs/by-name/gf/gfshare/package.nix index caf04cee0d5c05..98f402081649cc 100644 --- a/pkgs/by-name/gf/gfshare/package.nix +++ b/pkgs/by-name/gf/gfshare/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchgit, autoreconfHook }: +{ + lib, + stdenv, + fetchgit, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "gfshare"; @@ -13,7 +18,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; doCheck = true; - outputs = [ "bin" "lib" "dev" "out" ]; + outputs = [ + "bin" + "lib" + "dev" + "out" + ]; meta = with lib; { # Not the most descriptive homepage but it's what Debian and Ubuntu use diff --git a/pkgs/by-name/gf/gfxreconstruct/package.nix b/pkgs/by-name/gf/gfxreconstruct/package.nix index 78dabc68a61b04..5c52ad7f60e4a6 100644 --- a/pkgs/by-name/gf/gfxreconstruct/package.nix +++ b/pkgs/by-name/gf/gfxreconstruct/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, fetchFromGitHub -, lib -, cmake -, makeWrapper -, pkg-config -, python3 -, wayland -, libX11 -, libxcb -, lz4 -, vulkan-loader -, xcbutilkeysyms -, zlib -, zstd +{ + stdenv, + fetchFromGitHub, + lib, + cmake, + makeWrapper, + pkg-config, + python3, + wayland, + libX11, + libxcb, + lz4, + vulkan-loader, + xcbutilkeysyms, + zlib, + zstd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gf/gfxstream/package.nix b/pkgs/by-name/gf/gfxstream/package.nix index 6dd5a11e841fef..ccae47da4d4853 100644 --- a/pkgs/by-name/gf/gfxstream/package.nix +++ b/pkgs/by-name/gf/gfxstream/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchFromGitiles, fetchpatch, meson, ninja, pkg-config, python3 -, aemu, darwin, libdrm, libglvnd, vulkan-headers, vulkan-loader, xorg +{ + lib, + stdenv, + fetchFromGitiles, + fetchpatch, + meson, + ninja, + pkg-config, + python3, + aemu, + darwin, + libdrm, + libglvnd, + vulkan-headers, + vulkan-loader, + xorg, }: stdenv.mkDerivation { @@ -27,8 +41,20 @@ stdenv.mkDerivation { --replace-fail "project('gfxstream_backend', 'cpp', 'c'" "project('gfxstream_backend', 'cpp', 'c', 'objc'" ''; - nativeBuildInputs = [ meson ninja pkg-config python3 ]; - buildInputs = [ aemu libglvnd vulkan-headers vulkan-loader xorg.libX11 ] + nativeBuildInputs = [ + meson + ninja + pkg-config + python3 + ]; + buildInputs = + [ + aemu + libglvnd + vulkan-headers + vulkan-loader + xorg.libX11 + ] ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform libdrm) [ libdrm ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Cocoa diff --git a/pkgs/by-name/gf/gfxtablet/package.nix b/pkgs/by-name/gf/gfxtablet/package.nix index 3ee35844f99955..d569803a5b8ef4 100644 --- a/pkgs/by-name/gf/gfxtablet/package.nix +++ b/pkgs/by-name/gf/gfxtablet/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchFromGitHub, linuxHeaders}: +{ + lib, + stdenv, + fetchFromGitHub, + linuxHeaders, +}: stdenv.mkDerivation rec { version = "1.4"; @@ -27,8 +32,8 @@ stdenv.mkDerivation rec { meta = { description = "Uinput driver for Android GfxTablet tablet-as-input-device app"; mainProgram = "networktablet"; - license = lib.licenses.mit ; - maintainers = [lib.maintainers.raskin]; + license = lib.licenses.mit; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/gg/gg-scm/package.nix b/pkgs/by-name/gg/gg-scm/package.nix index 89fd45e45f0dc7..e3794f8bd258cb 100644 --- a/pkgs/by-name/gg/gg-scm/package.nix +++ b/pkgs/by-name/gg/gg-scm/package.nix @@ -1,18 +1,20 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, makeWrapper -, bash -, coreutils -, git -, pandoc +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + makeWrapper, + bash, + coreutils, + git, + pandoc, }: let version = "1.3.1"; commit = "b6be8bac78605c21a9670db0e44faf5e1eafe0d4"; -in buildGoModule { +in +buildGoModule { pname = "gg-scm"; inherit version; @@ -28,16 +30,30 @@ in buildGoModule { ''; subPackages = [ "cmd/gg" ]; ldflags = [ - "-s" "-w" - "-X" "main.versionInfo=${version}" - "-X" "main.buildCommit=${commit}" + "-s" + "-w" + "-X" + "main.versionInfo=${version}" + "-X" + "main.buildCommit=${commit}" ]; vendorHash = "sha256-56Sah030xbWsoOu8r3c3nN2UGHvQORheavebP+Z1Wc8="; - nativeBuildInputs = [ pandoc installShellFiles makeWrapper ]; - nativeCheckInputs = [ bash coreutils git ]; - buildInputs = [ bash git ]; + nativeBuildInputs = [ + pandoc + installShellFiles + makeWrapper + ]; + nativeCheckInputs = [ + bash + coreutils + git + ]; + buildInputs = [ + bash + git + ]; postInstall = '' wrapProgram $out/bin/gg --suffix PATH : ${git}/bin diff --git a/pkgs/by-name/gg/gg/package.nix b/pkgs/by-name/gg/gg/package.nix index 9a5d381a4e1d06..f1a08af09d3848 100644 --- a/pkgs/by-name/gg/gg/package.nix +++ b/pkgs/by-name/gg/gg/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: -buildGoModule rec{ +buildGoModule rec { pname = "gg"; version = "0.2.19"; diff --git a/pkgs/by-name/gg/ggobi/package.nix b/pkgs/by-name/gg/ggobi/package.nix index 2bd5abf0066632..14c7748c3b5b53 100644 --- a/pkgs/by-name/gg/ggobi/package.nix +++ b/pkgs/by-name/gg/ggobi/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, libxml2, gtk2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libxml2, + gtk2, +}: stdenv.mkDerivation rec { version = "2.1.11"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libxml2 gtk2 ]; + buildInputs = [ + libxml2 + gtk2 + ]; configureFlags = [ "--with-all-plugins" ]; diff --git a/pkgs/by-name/gg/ggz_base_libs/package.nix b/pkgs/by-name/gg/ggz_base_libs/package.nix index 878f6bf97cffbd..ce7dc4372a2374 100644 --- a/pkgs/by-name/gg/ggz_base_libs/package.nix +++ b/pkgs/by-name/gg/ggz_base_libs/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, intltool, openssl, expat, libgcrypt }: +{ + lib, + stdenv, + fetchurl, + intltool, + openssl, + expat, + libgcrypt, +}: stdenv.mkDerivation rec { pname = "ggz-base-libs"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ intltool ]; - buildInputs = [ openssl expat libgcrypt ]; + buildInputs = [ + openssl + expat + libgcrypt + ]; patchPhase = '' substituteInPlace configure \ @@ -25,8 +37,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "GGZ Gaming zone libraries"; mainProgram = "ggz-config"; - maintainers = with maintainers; - [ + maintainers = with maintainers; [ raskin ]; platforms = platforms.linux; diff --git a/pkgs/by-name/gh/gh-actions-cache/package.nix b/pkgs/by-name/gh/gh-actions-cache/package.nix index 2575beabf82a27..0d48923a2874b5 100644 --- a/pkgs/by-name/gh/gh-actions-cache/package.nix +++ b/pkgs/by-name/gh/gh-actions-cache/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { diff --git a/pkgs/by-name/gh/gh-copilot/package.nix b/pkgs/by-name/gh/gh-copilot/package.nix index 7865ab095842bb..31a730b97f9259 100644 --- a/pkgs/by-name/gh/gh-copilot/package.nix +++ b/pkgs/by-name/gh/gh-copilot/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, lib -, fetchurl +{ + stdenv, + lib, + fetchurl, }: let inherit (stdenv.hostPlatform) system; diff --git a/pkgs/by-name/gh/gh-dash/package.nix b/pkgs/by-name/gh/gh-dash/package.nix index c02f3b12741419..2e90cb5657315b 100644 --- a/pkgs/by-name/gh/gh-dash/package.nix +++ b/pkgs/by-name/gh/gh-dash/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, testers -, gh-dash +{ + lib, + fetchFromGitHub, + buildGoModule, + testers, + gh-dash, }: buildGoModule rec { diff --git a/pkgs/by-name/gh/gh-f/package.nix b/pkgs/by-name/gh/gh-f/package.nix index 45279ed3528d2e..33db1b6a6fa8a2 100644 --- a/pkgs/by-name/gh/gh-f/package.nix +++ b/pkgs/by-name/gh/gh-f/package.nix @@ -1,24 +1,27 @@ -{ lib -, fetchFromGitHub -, stdenvNoCC -, makeWrapper -, gh -, fzf -, coreutils -, gawk -, gnused -, withBat ? false -, bat +{ + lib, + fetchFromGitHub, + stdenvNoCC, + makeWrapper, + gh, + fzf, + coreutils, + gawk, + gnused, + withBat ? false, + bat, }: let - binPath = lib.makeBinPath ([ - gh - fzf - coreutils - gawk - gnused - ] - ++ lib.optional withBat bat); + binPath = lib.makeBinPath ( + [ + gh + fzf + coreutils + gawk + gnused + ] + ++ lib.optional withBat bat + ); in stdenvNoCC.mkDerivation rec { pname = "gh-f"; diff --git a/pkgs/by-name/gh/gh-markdown-preview/package.nix b/pkgs/by-name/gh/gh-markdown-preview/package.nix index 7e829bd19f89a4..1c39eb2d3ce6e7 100644 --- a/pkgs/by-name/gh/gh-markdown-preview/package.nix +++ b/pkgs/by-name/gh/gh-markdown-preview/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, gh-markdown-preview -, testers +{ + lib, + fetchFromGitHub, + buildGoModule, + gh-markdown-preview, + testers, }: buildGoModule rec { diff --git a/pkgs/by-name/gh/gh-notify/package.nix b/pkgs/by-name/gh/gh-notify/package.nix index 891b8843c92613..e53dcc0952eb41 100644 --- a/pkgs/by-name/gh/gh-notify/package.nix +++ b/pkgs/by-name/gh/gh-notify/package.nix @@ -1,25 +1,28 @@ -{ lib -, fetchFromGitHub -, stdenvNoCC -, makeWrapper -, gh -, gnugrep -, fzf -, python3 -, withDelta ? false -, delta -, withBat ? false -, bat +{ + lib, + fetchFromGitHub, + stdenvNoCC, + makeWrapper, + gh, + gnugrep, + fzf, + python3, + withDelta ? false, + delta, + withBat ? false, + bat, }: let - binPath = lib.makeBinPath ([ - gh - gnugrep - fzf - python3 - ] - ++ lib.optional withBat bat - ++ lib.optional withDelta delta); + binPath = lib.makeBinPath ( + [ + gh + gnugrep + fzf + python3 + ] + ++ lib.optional withBat bat + ++ lib.optional withDelta delta + ); in stdenvNoCC.mkDerivation { pname = "gh-notify"; diff --git a/pkgs/by-name/gh/gh-ost/package.nix b/pkgs/by-name/gh/gh-ost/package.nix index 91798cfae8c9cd..1cd7fb9dd20bdf 100644 --- a/pkgs/by-name/gh/gh-ost/package.nix +++ b/pkgs/by-name/gh/gh-ost/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, gh-ost }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + gh-ost, +}: buildGoModule rec { pname = "gh-ost"; diff --git a/pkgs/by-name/gh/gh-poi/package.nix b/pkgs/by-name/gh/gh-poi/package.nix index 203258c6803fe6..522d3431280fee 100644 --- a/pkgs/by-name/gh/gh-poi/package.nix +++ b/pkgs/by-name/gh/gh-poi/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { @@ -14,7 +15,10 @@ buildGoModule rec { hash = "sha256-GRTBYwphw5rpwFzLrBRpzz6z6udNCdPn3vanfMvBtGI="; }; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; vendorHash = "sha256-D/YZLwwGJWCekq9mpfCECzJyJ/xSlg7fC6leJh+e8i0="; diff --git a/pkgs/by-name/gh/gh-screensaver/package.nix b/pkgs/by-name/gh/gh-screensaver/package.nix index b5466c791333d5..2481b2688281cd 100644 --- a/pkgs/by-name/gh/gh-screensaver/package.nix +++ b/pkgs/by-name/gh/gh-screensaver/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-o9B6Q07GP/CFekG3av01boZA7FdZg4x8CsLC3lwhn2A="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "gh extension with animated terminal screensavers"; diff --git a/pkgs/by-name/gh/gh2md/package.nix b/pkgs/by-name/gh/gh2md/package.nix index a56bd53c6f4a23..87b8648bc5a7f2 100644 --- a/pkgs/by-name/gh/gh2md/package.nix +++ b/pkgs/by-name/gh/gh2md/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchPypi +{ + lib, + python3Packages, + fetchPypi, }: python3Packages.buildPythonApplication rec { @@ -12,7 +13,11 @@ python3Packages.buildPythonApplication rec { hash = "sha256-B7IB1TWfZ0StH2zo/tXfDAaPlgLvr4ciIv7B8EQyp8w="; }; - propagatedBuildInputs = with python3Packages; [ six requests python-dateutil ]; + propagatedBuildInputs = with python3Packages; [ + six + requests + python-dateutil + ]; # uses network doCheck = false; diff --git a/pkgs/by-name/gh/ghauri/package.nix b/pkgs/by-name/gh/ghauri/package.nix index 4141690085e7ea..41f75ccbe23334 100644 --- a/pkgs/by-name/gh/ghauri/package.nix +++ b/pkgs/by-name/gh/ghauri/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/gh/ghciwatch/package.nix b/pkgs/by-name/gh/ghciwatch/package.nix index e791d61862e689..35744412edddca 100644 --- a/pkgs/by-name/gh/ghciwatch/package.nix +++ b/pkgs/by-name/gh/ghciwatch/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, nix-update-script -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + nix-update-script, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -32,7 +33,10 @@ rustPlatform.buildRustPackage rec { description = "Ghci-based file watching recompiler for Haskell development"; homepage = "https://github.com/MercuryTechnologies/ghciwatch"; license = licenses.mit; - maintainers = with maintainers; [ mangoiv _9999years ]; + maintainers = with maintainers; [ + mangoiv + _9999years + ]; mainProgram = "ghciwatch"; }; diff --git a/pkgs/by-name/gh/ghdl/package.nix b/pkgs/by-name/gh/ghdl/package.nix index 181647ca4e2e40..32bed81d06bbb4 100644 --- a/pkgs/by-name/gh/ghdl/package.nix +++ b/pkgs/by-name/gh/ghdl/package.nix @@ -1,19 +1,20 @@ -{ stdenv -, fetchFromGitHub -, callPackage -, gnat -, zlib -, llvm -, lib -, gcc-unwrapped -, texinfo -, gmp -, mpfr -, libmpc -, gnutar -, glibc -, makeWrapper -, backend ? "mcode" +{ + stdenv, + fetchFromGitHub, + callPackage, + gnat, + zlib, + llvm, + lib, + gcc-unwrapped, + texinfo, + gmp, + mpfr, + libmpc, + gnutar, + glibc, + makeWrapper, + backend ? "mcode", }: assert backend == "mcode" || backend == "llvm" || backend == "gcc"; @@ -23,50 +24,62 @@ stdenv.mkDerivation (finalAttrs: { version = "4.1.0"; src = fetchFromGitHub { - owner = "ghdl"; - repo = "ghdl"; - rev = "v${finalAttrs.version}"; - hash = "sha256-tPSHer3qdtEZoPh9BsEyuTOrXgyENFUyJqnUS3UYAvM="; + owner = "ghdl"; + repo = "ghdl"; + rev = "v${finalAttrs.version}"; + hash = "sha256-tPSHer3qdtEZoPh9BsEyuTOrXgyENFUyJqnUS3UYAvM="; }; LIBRARY_PATH = "${stdenv.cc.libc}/lib"; - nativeBuildInputs = [ - gnat - ] ++ lib.optionals (backend == "gcc") [ - texinfo - makeWrapper - ]; - buildInputs = [ - zlib - ] ++ lib.optionals (backend == "llvm") [ - llvm - ] ++ lib.optionals (backend == "gcc") [ - gmp - mpfr - libmpc - ]; - propagatedBuildInputs = [ - ] ++ lib.optionals (backend == "llvm" || backend == "gcc") [ - zlib - ]; + nativeBuildInputs = + [ + gnat + ] + ++ lib.optionals (backend == "gcc") [ + texinfo + makeWrapper + ]; + buildInputs = + [ + zlib + ] + ++ lib.optionals (backend == "llvm") [ + llvm + ] + ++ lib.optionals (backend == "gcc") [ + gmp + mpfr + libmpc + ]; + propagatedBuildInputs = + [ + ] + ++ lib.optionals (backend == "llvm" || backend == "gcc") [ + zlib + ]; - preConfigure = '' - # If llvm 7.0 works, 7.x releases should work too. - sed -i 's/check_version 7.0/check_version 7/g' configure - '' + lib.optionalString (backend == "gcc") '' - ${gnutar}/bin/tar -xf ${gcc-unwrapped.src} - ''; + preConfigure = + '' + # If llvm 7.0 works, 7.x releases should work too. + sed -i 's/check_version 7.0/check_version 7/g' configure + '' + + lib.optionalString (backend == "gcc") '' + ${gnutar}/bin/tar -xf ${gcc-unwrapped.src} + ''; - configureFlags = [ - # See https://github.com/ghdl/ghdl/pull/2058 - "--disable-werror" - "--enable-synth" - ] ++ lib.optionals (backend == "llvm") [ - "--with-llvm-config=${llvm.dev}/bin/llvm-config" - ] ++ lib.optionals (backend == "gcc") [ - "--with-gcc=gcc-${gcc-unwrapped.version}" - ]; + configureFlags = + [ + # See https://github.com/ghdl/ghdl/pull/2058 + "--disable-werror" + "--enable-synth" + ] + ++ lib.optionals (backend == "llvm") [ + "--with-llvm-config=${llvm.dev}/bin/llvm-config" + ] + ++ lib.optionals (backend == "gcc") [ + "--with-gcc=gcc-${gcc-unwrapped.version}" + ]; buildPhase = lib.optionalString (backend == "gcc") '' make copy-sources @@ -91,16 +104,20 @@ stdenv.mkDerivation (finalAttrs: { postFixup = lib.optionalString (backend == "gcc") '' wrapProgram $out/bin/ghdl \ - --set LIBRARY_PATH ${lib.makeLibraryPath [ - glibc - ]} + --set LIBRARY_PATH ${ + lib.makeLibraryPath [ + glibc + ] + } ''; - hardeningDisable = [ - ] ++ lib.optionals (backend == "gcc") [ - # GCC compilation fails with format errors - "format" - ]; + hardeningDisable = + [ + ] + ++ lib.optionals (backend == "gcc") [ + # GCC compilation fails with format errors + "format" + ]; enableParallelBuilding = true; @@ -119,7 +136,10 @@ stdenv.mkDerivation (finalAttrs: { description = "VHDL 2008/93/87 simulator"; license = lib.licenses.gpl2Plus; mainProgram = "ghdl"; - maintainers = with lib.maintainers; [ lucus16 thoughtpolice ]; + maintainers = with lib.maintainers; [ + lucus16 + thoughtpolice + ]; platforms = lib.platforms.linux ++ lib.optionals (backend == "mcode" || backend == "llvm") [ "x86_64-darwin" ]; diff --git a/pkgs/by-name/gh/ghdl/test-simple.nix b/pkgs/by-name/gh/ghdl/test-simple.nix index bf034441be25a8..66c81977bf77c7 100644 --- a/pkgs/by-name/gh/ghdl/test-simple.nix +++ b/pkgs/by-name/gh/ghdl/test-simple.nix @@ -1,23 +1,43 @@ -{ stdenv, ghdl-llvm, ghdl-mcode, ghdl-gcc, backend }: +{ + stdenv, + ghdl-llvm, + ghdl-mcode, + ghdl-gcc, + backend, +}: let - ghdl = if backend == "llvm" then ghdl-llvm else if backend == "gcc" then ghdl-gcc else ghdl-mcode; + ghdl = + if backend == "llvm" then + ghdl-llvm + else if backend == "gcc" then + ghdl-gcc + else + ghdl-mcode; in stdenv.mkDerivation { name = "ghdl-test-simple"; meta.timeout = 300; nativeBuildInputs = [ ghdl ]; - buildCommand = '' - cp ${./simple.vhd} simple.vhd - cp ${./simple-tb.vhd} simple-tb.vhd - mkdir -p ghdlwork - ghdl -a --workdir=ghdlwork --ieee=synopsys simple.vhd simple-tb.vhd - ghdl -e --workdir=ghdlwork --ieee=synopsys -o sim-simple tb - '' + (if backend == "llvm" || backend == "gcc" then '' - ./sim-simple --assert-level=warning > output.txt - '' else '' - ghdl -r --workdir=ghdlwork --ieee=synopsys tb > output.txt - '') + '' - diff output.txt ${./expected-output.txt} && touch $out - ''; + buildCommand = + '' + cp ${./simple.vhd} simple.vhd + cp ${./simple-tb.vhd} simple-tb.vhd + mkdir -p ghdlwork + ghdl -a --workdir=ghdlwork --ieee=synopsys simple.vhd simple-tb.vhd + ghdl -e --workdir=ghdlwork --ieee=synopsys -o sim-simple tb + '' + + ( + if backend == "llvm" || backend == "gcc" then + '' + ./sim-simple --assert-level=warning > output.txt + '' + else + '' + ghdl -r --workdir=ghdlwork --ieee=synopsys tb > output.txt + '' + ) + + '' + diff output.txt ${./expected-output.txt} && touch $out + ''; } diff --git a/pkgs/by-name/gh/ghdorker/package.nix b/pkgs/by-name/gh/ghdorker/package.nix index 61ac1f2cc852bc..be12f9e18ed61a 100644 --- a/pkgs/by-name/gh/ghdorker/package.nix +++ b/pkgs/by-name/gh/ghdorker/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/gh/ghex/package.nix b/pkgs/by-name/gh/ghex/package.nix index b4fd1da04ff0c5..8db8840c4ea182 100644 --- a/pkgs/by-name/gh/ghex/package.nix +++ b/pkgs/by-name/gh/ghex/package.nix @@ -1,29 +1,34 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, gi-docgen -, meson -, ninja -, gnome -, desktop-file-utils -, appstream-glib -, gettext -, itstool -, gtk4 -, libadwaita -, glib -, atk -, gobject-introspection -, vala -, wrapGAppsHook4 +{ + stdenv, + lib, + fetchurl, + pkg-config, + gi-docgen, + meson, + ninja, + gnome, + desktop-file-utils, + appstream-glib, + gettext, + itstool, + gtk4, + libadwaita, + glib, + atk, + gobject-introspection, + vala, + wrapGAppsHook4, }: stdenv.mkDerivation rec { pname = "ghex"; version = "46.1"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/ghex/${lib.versions.major version}/ghex-${version}.tar.xz"; @@ -55,13 +60,15 @@ stdenv.mkDerivation rec { desktop-file-utils ]; - mesonFlags = [ - "-Dgtk_doc=true" - "-Dvapi=true" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # mremap does not exist on darwin - "-Dmmap-buffer-backend=false" - ]; + mesonFlags = + [ + "-Dgtk_doc=true" + "-Dvapi=true" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # mremap does not exist on darwin + "-Dmmap-buffer-backend=false" + ]; postFixup = '' # Cannot be in postInstall, otherwise _multioutDocs hook in preFixup will move right back. diff --git a/pkgs/by-name/gh/ghfetch/package.nix b/pkgs/by-name/gh/ghfetch/package.nix index 79a4c187dc0aba..86784b083ea6a7 100644 --- a/pkgs/by-name/gh/ghfetch/package.nix +++ b/pkgs/by-name/gh/ghfetch/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/gh/ghi/gemset.nix b/pkgs/by-name/gh/ghi/gemset.nix index 7f03d5a41e4b41..fe1a9a5143e8e9 100644 --- a/pkgs/by-name/gh/ghi/gemset.nix +++ b/pkgs/by-name/gh/ghi/gemset.nix @@ -1,28 +1,34 @@ { diff-lcs = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rwvjahnp7cpmracd8x732rjgnilqv2sx7d1gfrysslc3h039fa9"; type = "gem"; }; version = "1.5.0"; }; docile = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1lxqxgq71rqwj1lpl9q1mbhhhhhhdkkj7my341f2889pwayk85sz"; type = "gem"; }; version = "1.4.0"; }; ghi = { - dependencies = ["pygments.rb"]; - groups = ["default"]; - platforms = []; + dependencies = [ "pygments.rb" ]; + groups = [ "default" ]; + platforms = [ ]; source = { path = ./.; type = "path"; @@ -30,167 +36,212 @@ version = "1.2.0"; }; hpricot = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jn8x9ch79gqmnzgyz78kppavjh5lqx0y0r6frykga2b86rz9s6z"; type = "gem"; }; version = "0.8.6"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nrmw2r4nfxlfgprfgki3hjifgrcrs3l5zvm3ca3gb4743yr25mn"; type = "gem"; }; version = "2.3.0"; }; mustache = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l0p4wx15mi3wnamfv92ipkia4nsx8qi132c6g51jfdma3fiz2ch"; type = "gem"; }; version = "1.1.1"; }; "pygments.rb" = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "047mjyzz8v4kkgi1ap6fsjf7kcp6dwirpnigif00ss0hxsxchhac"; type = "gem"; }; version = "2.3.0"; }; rake = { - groups = ["development"]; - platforms = []; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15whn7p9nrkxangbs9hh75q585yfn66lv0v2mhj6q6dl6x8bzr2w"; type = "gem"; }; version = "13.0.6"; }; rdiscount = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16srf8cr8ynlafyh6ls654b9a3bqgai8n3y86zzv9mcpvlk6k27g"; type = "gem"; }; version = "2.2.0.2"; }; ronn = { - dependencies = ["hpricot" "mustache" "rdiscount"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "hpricot" + "mustache" + "rdiscount" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07plsxxfx5bxdk72ii9za6km0ziqlq8jh3bicr4774dalga6zpw2"; type = "gem"; }; version = "0.7.3"; }; rspec = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "19dyb6rcvgi9j2mksd29wfdhfdyzqk7yjhy1ai77559hbhpg61w9"; type = "gem"; }; version = "3.11.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rspec-support" ]; + groups = [ + "default" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "118hkfw9b11hvvalr7qlylwal5h8dihagm9xg7k4gskg7587hca6"; type = "gem"; }; version = "3.11.0"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "001ihayil7jpfxdlxlhakvz02kx0nk5m1w0bz6z8izdx0nc8bh53"; type = "gem"; }; version = "3.11.0"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0y38dc66yhnfcf4ky3k47c20xak1rax940s4a96qkjxqrniy5ys3"; type = "gem"; }; version = "3.11.0"; }; rspec-support = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xfk4pla77251n39zf4n792m1rhg5sn1kp63yvpvvysany34la03"; type = "gem"; }; version = "3.11.0"; }; rspec_junit_formatter = { - dependencies = ["rspec-core"]; - groups = ["test"]; - platforms = []; + dependencies = [ "rspec-core" ]; + groups = [ "test" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sm4yj6149v4pisnizplh58ahaqri2v6p7gyzybqy1ql0zwignxy"; type = "gem"; }; version = "0.3.0"; }; simplecov = { - dependencies = ["docile" "simplecov-html" "simplecov_json_formatter"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "docile" + "simplecov-html" + "simplecov_json_formatter" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1hrv046jll6ad1s964gsmcq4hvkr3zzr6jc7z1mns22mvfpbc3cr"; type = "gem"; }; version = "0.21.2"; }; simplecov-html = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yx01bxa8pbf9ip4hagqkp5m0mqfnwnw2xk8kjraiywz4lrss6jb"; type = "gem"; }; version = "0.12.3"; }; simplecov_json_formatter = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a5l0733hj7sk51j81ykfmlk2vd5vaijlq9d5fn165yyx3xii52j"; type = "gem"; }; diff --git a/pkgs/by-name/gh/ghi/package.nix b/pkgs/by-name/gh/ghi/package.nix index 5c17846aab7546..5fd5c6b860c864 100644 --- a/pkgs/by-name/gh/ghi/package.nix +++ b/pkgs/by-name/gh/ghi/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, bundlerEnv -, tree +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + bundlerEnv, + tree, }: stdenv.mkDerivation (finalAttrs: { @@ -40,6 +41,6 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "ghi"; homepage = "https://github.com/drazisil/ghi"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ sigmanificient]; + maintainers = with lib.maintainers; [ sigmanificient ]; }; }) diff --git a/pkgs/by-name/gh/ghorg/package.nix b/pkgs/by-name/gh/ghorg/package.nix index 001743d4fc96d0..ad35083adb0dbd 100644 --- a/pkgs/by-name/gh/ghorg/package.nix +++ b/pkgs/by-name/gh/ghorg/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "ghorg"; @@ -16,7 +21,11 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; nativeBuildInputs = [ installShellFiles ]; postInstall = '' diff --git a/pkgs/by-name/gh/ghost/package.nix b/pkgs/by-name/gh/ghost/package.nix index d645556c87be0f..9750eb5f94a198 100644 --- a/pkgs/by-name/gh/ghost/package.nix +++ b/pkgs/by-name/gh/ghost/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/gh/ghostie/package.nix b/pkgs/by-name/gh/ghostie/package.nix index e6a47a55773801..a6733b629090e3 100644 --- a/pkgs/by-name/gh/ghostie/package.nix +++ b/pkgs/by-name/gh/ghostie/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, sqlite -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + sqlite, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -30,12 +31,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - sqlite - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Cocoa - ]; + buildInputs = + [ + openssl + sqlite + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Cocoa + ]; # 4 out of 5 tests are notification tests which do not work in nix builds doCheck = false; diff --git a/pkgs/by-name/gh/ghostscript/test-corpus-render.nix b/pkgs/by-name/gh/ghostscript/test-corpus-render.nix index 089661293c25d9..c232ee49550d29 100644 --- a/pkgs/by-name/gh/ghostscript/test-corpus-render.nix +++ b/pkgs/by-name/gh/ghostscript/test-corpus-render.nix @@ -1,6 +1,7 @@ -{ stdenv -, fetchgit -, ghostscript +{ + stdenv, + fetchgit, + ghostscript, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/gh/ghosttohugo/package.nix b/pkgs/by-name/gh/ghosttohugo/package.nix index 5ec5cc6870cae6..58cde575b477c3 100644 --- a/pkgs/by-name/gh/ghosttohugo/package.nix +++ b/pkgs/by-name/gh/ghosttohugo/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/gh/ghostunnel/package.nix b/pkgs/by-name/gh/ghostunnel/package.nix index 6732c75e3c0015..2edd0471f85cae 100644 --- a/pkgs/by-name/gh/ghostunnel/package.nix +++ b/pkgs/by-name/gh/ghostunnel/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, buildGoModule -, fetchFromGitHub -, lib -, nixosTests +{ + stdenv, + buildGoModule, + fetchFromGitHub, + lib, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/by-name/gh/ghr/package.nix b/pkgs/by-name/gh/ghr/package.nix index 23db007dc26398..389df793a4912f 100644 --- a/pkgs/by-name/gh/ghr/package.nix +++ b/pkgs/by-name/gh/ghr/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, ghr +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + ghr, }: buildGoModule rec { diff --git a/pkgs/by-name/gh/ghunt/package.nix b/pkgs/by-name/gh/ghunt/package.nix index 580f3a5e28470d..719da1f897602a 100644 --- a/pkgs/by-name/gh/ghunt/package.nix +++ b/pkgs/by-name/gh/ghunt/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -21,24 +22,27 @@ python3.pkgs.buildPythonApplication rec { setuptools ]; - propagatedBuildInputs = with python3.pkgs; [ - alive-progress - autoslot - beautifulsoup4 - beautifultable - geopy - httpx - humanize - imagehash - inflection - jsonpickle - pillow - protobuf - python-dateutil - rich - trio - packaging - ] ++ httpx.optional-dependencies.http2; + propagatedBuildInputs = + with python3.pkgs; + [ + alive-progress + autoslot + beautifulsoup4 + beautifultable + geopy + httpx + humanize + imagehash + inflection + jsonpickle + pillow + protobuf + python-dateutil + rich + trio + packaging + ] + ++ httpx.optional-dependencies.http2; # Project has no tests doCheck = false; diff --git a/pkgs/by-name/gh/ghz/package.nix b/pkgs/by-name/gh/ghz/package.nix index 05b5f0e9b035f2..a5d37a552d22c3 100644 --- a/pkgs/by-name/gh/ghz/package.nix +++ b/pkgs/by-name/gh/ghz/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, ghz }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + ghz, +}: buildGoModule rec { pname = "ghz"; @@ -13,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-7TrYWmVKxHKVTyiIak7tRYKE4hgG/4zfsM76bJRxnAk="; - subPackages = [ "cmd/ghz" "cmd/ghz-web" ]; + subPackages = [ + "cmd/ghz" + "cmd/ghz-web" + ]; ldflags = [ "-s" diff --git a/pkgs/by-name/gi/gi-crystal/package.nix b/pkgs/by-name/gi/gi-crystal/package.nix index d5c19a21662ab3..0b17b733833bd5 100644 --- a/pkgs/by-name/gi/gi-crystal/package.nix +++ b/pkgs/by-name/gi/gi-crystal/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, crystal -, gobject-introspection -, gitUpdater +{ + lib, + fetchFromGitHub, + crystal, + gobject-introspection, + gitUpdater, }: crystal.buildCrystalPackage rec { pname = "gi-crystal"; @@ -17,7 +18,10 @@ crystal.buildCrystalPackage rec { # Make sure gi-crystal picks up the name of the so or dylib and not the leading nix store path # when the package name happens to start with “lib”. - patches = [ ./src.patch ./store-friendly-library-name.patch ]; + patches = [ + ./src.patch + ./store-friendly-library-name.patch + ]; nativeBuildInputs = [ gobject-introspection ]; buildTargets = [ "generator" ]; @@ -38,7 +42,6 @@ crystal.buildCrystalPackage rec { updateScript = gitUpdater { rev-prefix = "v"; }; }; - meta = with lib; { description = "GI Crystal is a binding generator used to generate Crystal bindings for GObject based libraries using GObject Introspection"; homepage = "https://github.com/hugopl/gi-crystal"; diff --git a/pkgs/by-name/gi/gi-docgen/package.nix b/pkgs/by-name/gi/gi-docgen/package.nix index 9d5da739745f5c..0f350cdbbd6231 100644 --- a/pkgs/by-name/gi/gi-docgen/package.nix +++ b/pkgs/by-name/gi/gi-docgen/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchurl -, meson -, ninja -, python3 -, gnome +{ + lib, + fetchurl, + meson, + ninja, + python3, + gnome, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/gi/giac/package.nix b/pkgs/by-name/gi/giac/package.nix index ce009975c1ba18..454c85eb418c01 100644 --- a/pkgs/by-name/gi/giac/package.nix +++ b/pkgs/by-name/gi/giac/package.nix @@ -1,8 +1,37 @@ -{ stdenv, lib, fetchurl, fetchpatch, texliveSmall, bison, flex, lapack, blas -, autoreconfHook, gmp, mpfr, pari, ntl, gsl, mpfi, ecm, glpk, nauty -, buildPackages, readline, gettext, libpng, libao, gfortran, perl -, enableGUI ? false, libGL, libGLU, xorg, fltk -, enableMicroPy ? false, python3 +{ + stdenv, + lib, + fetchurl, + fetchpatch, + texliveSmall, + bison, + flex, + lapack, + blas, + autoreconfHook, + gmp, + mpfr, + pari, + ntl, + gsl, + mpfi, + ecm, + glpk, + nauty, + buildPackages, + readline, + gettext, + libpng, + libao, + gfortran, + perl, + enableGUI ? false, + libGL, + libGLU, + xorg, + fltk, + enableMicroPy ? false, + python3, }: assert (!blas.isILP64) && (!lapack.isILP64); @@ -16,48 +45,50 @@ stdenv.mkDerivation rec { sha256 = "sha256-pqytFWrSWfEwQqRdRbaigGCq68s8mdgj2j8M+kclslE="; }; - patches = [ - ./remove-old-functional-patterns.patch - ./fix-fltk-guard.patch - - (fetchpatch { - name = "pari_2_15.patch"; - url = "https://raw.githubusercontent.com/sagemath/sage/07a2afd65fb4b0a1c9cbc43ede7d4a18c921a000/build/pkgs/giac/patches/pari_2_15.patch"; - sha256 = "sha256-Q3xBFED7XEAyNz6AHjzt63XtospmdGAIdS6iPq1C2UE="; - }) - - (fetchpatch { - name = "infinity.patch"; - url = "https://github.com/geogebra/giac/commit/851c2cd91e879c79d6652f8a5d5bed03b65c6d39.patch"; - sha256 = "sha256-WJRT2b8I9kgAkRuIugMiXoF4hT7yR7qyad8A6IspNTM="; - stripLen = 5; - extraPrefix = "/src/"; - excludes = [ "src/kdisplay.cc" ]; - }) - - # giac calls scanf/printf with non-constant first arguments, which - # the compiler rightfully warns about (with an error nowadays). - (fetchpatch { - name = "fix-string-compiler-error.patch"; - url = "https://salsa.debian.org/science-team/giac/-/raw/9ca8dbf4bb16d9d96948aa4024326d32485d7917/debian/patches/fix-string-compiler-error.patch"; - sha256 = "sha256-r+M+9MRPRqhHcdhYWI6inxyNvWbXUbBcPCeDY7aulvk="; - }) - - # issue with include path precedence - (fetchpatch { - name = "fix_implicit_declaration.patch"; - url = "https://salsa.debian.org/science-team/giac/-/raw/c05ae9b9e74d3c6ee6411d391071989426a76201/debian/patches/fix_implicit_declaration.patch"; - sha256 = "sha256-ompUceYJLiL0ftfjBkIMcYvX1YqG2/XA7e1yDyFY0IY="; - }) - ] ++ lib.optionals (!enableGUI) [ - # when enableGui is false, giac is compiled without fltk. That - # means some outputs differ in the make check. Patch around this: - (fetchpatch { - name = "nofltk-check.patch"; - url = "https://raw.githubusercontent.com/sagemath/sage/7553a3c8dfa7bcec07241a07e6a4e7dcf5bb4f26/build/pkgs/giac/patches/nofltk-check.patch"; - sha256 = "sha256-nAl5q3ufLjK3X9s0qMlGNowdRRf3EaC24eVtJABzdXY="; - }) - ]; + patches = + [ + ./remove-old-functional-patterns.patch + ./fix-fltk-guard.patch + + (fetchpatch { + name = "pari_2_15.patch"; + url = "https://raw.githubusercontent.com/sagemath/sage/07a2afd65fb4b0a1c9cbc43ede7d4a18c921a000/build/pkgs/giac/patches/pari_2_15.patch"; + sha256 = "sha256-Q3xBFED7XEAyNz6AHjzt63XtospmdGAIdS6iPq1C2UE="; + }) + + (fetchpatch { + name = "infinity.patch"; + url = "https://github.com/geogebra/giac/commit/851c2cd91e879c79d6652f8a5d5bed03b65c6d39.patch"; + sha256 = "sha256-WJRT2b8I9kgAkRuIugMiXoF4hT7yR7qyad8A6IspNTM="; + stripLen = 5; + extraPrefix = "/src/"; + excludes = [ "src/kdisplay.cc" ]; + }) + + # giac calls scanf/printf with non-constant first arguments, which + # the compiler rightfully warns about (with an error nowadays). + (fetchpatch { + name = "fix-string-compiler-error.patch"; + url = "https://salsa.debian.org/science-team/giac/-/raw/9ca8dbf4bb16d9d96948aa4024326d32485d7917/debian/patches/fix-string-compiler-error.patch"; + sha256 = "sha256-r+M+9MRPRqhHcdhYWI6inxyNvWbXUbBcPCeDY7aulvk="; + }) + + # issue with include path precedence + (fetchpatch { + name = "fix_implicit_declaration.patch"; + url = "https://salsa.debian.org/science-team/giac/-/raw/c05ae9b9e74d3c6ee6411d391071989426a76201/debian/patches/fix_implicit_declaration.patch"; + sha256 = "sha256-ompUceYJLiL0ftfjBkIMcYvX1YqG2/XA7e1yDyFY0IY="; + }) + ] + ++ lib.optionals (!enableGUI) [ + # when enableGui is false, giac is compiled without fltk. That + # means some outputs differ in the make check. Patch around this: + (fetchpatch { + name = "nofltk-check.patch"; + url = "https://raw.githubusercontent.com/sagemath/sage/7553a3c8dfa7bcec07241a07e6a4e7dcf5bb4f26/build/pkgs/giac/patches/nofltk-check.patch"; + sha256 = "sha256-nAl5q3ufLjK3X9s0qMlGNowdRRf3EaC24eVtJABzdXY="; + }) + ]; # 1.9.0-5's tarball contains a binary (src/mkjs) which is executed # at build time. we will delete and rebuild it. @@ -76,77 +107,117 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ - autoreconfHook texliveSmall bison flex + autoreconfHook + texliveSmall + bison + flex ]; # perl is only needed for patchShebangs fixup. - buildInputs = [ - gmp mpfr pari ntl gsl blas mpfi glpk nauty - readline gettext libpng libao perl ecm - # gfortran.cc default output contains static libraries compiled without -fPIC - # we want libgfortran.so.3 instead - (lib.getLib gfortran.cc) - lapack blas - ] ++ lib.optionals enableGUI [ - libGL libGLU fltk xorg.libX11 - ] ++ lib.optional enableMicroPy python3; + buildInputs = + [ + gmp + mpfr + pari + ntl + gsl + blas + mpfi + glpk + nauty + readline + gettext + libpng + libao + perl + ecm + # gfortran.cc default output contains static libraries compiled without -fPIC + # we want libgfortran.so.3 instead + (lib.getLib gfortran.cc) + lapack + blas + ] + ++ lib.optionals enableGUI [ + libGL + libGLU + fltk + xorg.libX11 + ] + ++ lib.optional enableMicroPy python3; # xcas Phys and Turtle menus are broken with split outputs # and interactive use is likely to need docs outputs = [ "out" ] ++ lib.optional (!enableGUI) "doc"; doCheck = true; - preCheck = lib.optionalString (!enableGUI) '' - # even with the nofltk patch, some changes in src/misc.cc (grep - # for HAVE_LIBFLTK) made it so that giac behaves differently - # when fltk is disabled. disable these tests for now. - echo > check/chk_fhan2 - echo > check/chk_fhan9 - '' + lib.optionalString (stdenv.hostPlatform.isDarwin) '' - # these cover a known regression in giac, likely due to how pari state - # is shared between multiple giac instances (see pari.cc.old). - # see https://github.com/NixOS/nixpkgs/pull/264126 for more information - echo > check/chk_fhan4 - echo > check/chk_fhan6 - ''; + preCheck = + lib.optionalString (!enableGUI) '' + # even with the nofltk patch, some changes in src/misc.cc (grep + # for HAVE_LIBFLTK) made it so that giac behaves differently + # when fltk is disabled. disable these tests for now. + echo > check/chk_fhan2 + echo > check/chk_fhan9 + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin) '' + # these cover a known regression in giac, likely due to how pari state + # is shared between multiple giac instances (see pari.cc.old). + # see https://github.com/NixOS/nixpkgs/pull/264126 for more information + echo > check/chk_fhan4 + echo > check/chk_fhan6 + ''; enableParallelBuilding = true; - configureFlags = [ - "--enable-gc" "--enable-png" "--enable-gsl" "--enable-lapack" - "--enable-pari" "--enable-ntl" "--enable-gmpxx" # "--enable-cocoa" - "--enable-ao" "--enable-ecm" "--enable-glpk" - ] ++ lib.optionals enableGUI [ - "--enable-gui" "--with-x" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "--disable-nls" - ] ++ lib.optionals (!enableGUI) [ - "--disable-fltk" - ] ++ lib.optionals (!enableMicroPy) [ - "--disable-micropy" - ]; - - postInstall = '' - # example Makefiles contain the full path to some commands - # notably texlive, and we don't want texlive to become a runtime - # dependency - for file in $(find $out -name Makefile) ; do - sed -i "s@${builtins.storeDir}/[^/]*/bin/@@" "$file" ; - done; - - # reference cycle - rm "$out/share/giac/doc/el/"{casinter,tutoriel}/Makefile - - if [ -n "$doc" ]; then - mkdir -p "$doc/share/giac" - mv "$out/share/giac/doc" "$doc/share/giac" - mv "$out/share/giac/examples" "$doc/share/giac" - fi - '' + lib.optionalString (!enableGUI) '' - for i in pixmaps application-registry applications icons; do - rm -r "$out/share/$i"; - done; - ''; + configureFlags = + [ + "--enable-gc" + "--enable-png" + "--enable-gsl" + "--enable-lapack" + "--enable-pari" + "--enable-ntl" + "--enable-gmpxx" # "--enable-cocoa" + "--enable-ao" + "--enable-ecm" + "--enable-glpk" + ] + ++ lib.optionals enableGUI [ + "--enable-gui" + "--with-x" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "--disable-nls" + ] + ++ lib.optionals (!enableGUI) [ + "--disable-fltk" + ] + ++ lib.optionals (!enableMicroPy) [ + "--disable-micropy" + ]; + + postInstall = + '' + # example Makefiles contain the full path to some commands + # notably texlive, and we don't want texlive to become a runtime + # dependency + for file in $(find $out -name Makefile) ; do + sed -i "s@${builtins.storeDir}/[^/]*/bin/@@" "$file" ; + done; + + # reference cycle + rm "$out/share/giac/doc/el/"{casinter,tutoriel}/Makefile + + if [ -n "$doc" ]; then + mkdir -p "$doc/share/giac" + mv "$out/share/giac/doc" "$doc/share/giac" + mv "$out/share/giac/examples" "$doc/share/giac" + fi + '' + + lib.optionalString (!enableGUI) '' + for i in pixmaps application-registry applications icons; do + rm -r "$out/share/$i"; + done; + ''; meta = with lib; { description = "Free computer algebra system (CAS)"; diff --git a/pkgs/by-name/gi/giara/package.nix b/pkgs/by-name/gi/giara/package.nix index 110d5c04767a3a..6c1aab02df9b9a 100644 --- a/pkgs/by-name/gi/giara/package.nix +++ b/pkgs/by-name/gi/giara/package.nix @@ -1,19 +1,20 @@ -{ lib -, fetchFromGitLab -, meson -, gobject-introspection -, pkg-config -, ninja -, python3 -, wrapGAppsHook4 -, gtk4 -, gdk-pixbuf -, webkitgtk_4_0 -, gtksourceview5 -, glib-networking -, libadwaita -, appstream -, blueprint-compiler +{ + lib, + fetchFromGitLab, + meson, + gobject-introspection, + pkg-config, + ninja, + python3, + wrapGAppsHook4, + gtk4, + gdk-pixbuf, + webkitgtk_4_0, + gtksourceview5, + glib-networking, + libadwaita, + appstream, + blueprint-compiler, }: python3.pkgs.buildPythonApplication rec { pname = "giara"; diff --git a/pkgs/by-name/gi/gibo/package.nix b/pkgs/by-name/gi/gibo/package.nix index d037059fd4e3ba..9663311e681212 100644 --- a/pkgs/by-name/gi/gibo/package.nix +++ b/pkgs/by-name/gi/gibo/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, coreutils, findutils, git }: +{ + lib, + stdenv, + fetchFromGitHub, + coreutils, + findutils, + git, +}: stdenv.mkDerivation rec { pname = "gibo"; diff --git a/pkgs/by-name/gi/gif-for-cli/package.nix b/pkgs/by-name/gi/gif-for-cli/package.nix index 3a2ad84a443001..5bdb18fa733d4e 100644 --- a/pkgs/by-name/gi/gif-for-cli/package.nix +++ b/pkgs/by-name/gi/gif-for-cli/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, python3Packages -, ffmpeg -, zlib -, libjpeg +{ + lib, + fetchFromGitHub, + fetchpatch, + python3Packages, + ffmpeg, + zlib, + libjpeg, }: python3Packages.buildPythonApplication { diff --git a/pkgs/by-name/gi/gif2apng/package.nix b/pkgs/by-name/gi/gif2apng/package.nix index 1a824e14a5a3e3..5b720ee4239998 100644 --- a/pkgs/by-name/gi/gif2apng/package.nix +++ b/pkgs/by-name/gi/gif2apng/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchzip -, fetchpatch -, zlib -, zopfli +{ + lib, + stdenv, + fetchzip, + fetchpatch, + zlib, + zopfli, }: stdenv.mkDerivation rec { @@ -51,7 +52,7 @@ stdenv.mkDerivation rec { makeFlags = [ "CC=${stdenv.cc.targetPrefix}c++" ]; - NIX_CFLAGS_COMPILE="-DENABLE_LOCAL_ZOPFLI"; + NIX_CFLAGS_COMPILE = "-DENABLE_LOCAL_ZOPFLI"; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/gi/gifgen/package.nix b/pkgs/by-name/gi/gifgen/package.nix index 49c87eda795de6..896d1a71a5432e 100644 --- a/pkgs/by-name/gi/gifgen/package.nix +++ b/pkgs/by-name/gi/gifgen/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, ffmpeg -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + ffmpeg, + makeWrapper, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gi/giflib/package.nix b/pkgs/by-name/gi/giflib/package.nix index c6dd7c81833f62..534ff1a7ca8165 100644 --- a/pkgs/by-name/gi/giflib/package.nix +++ b/pkgs/by-name/gi/giflib/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchurl -, fixDarwinDylibNames -, pkgsStatic +{ + stdenv, + lib, + fetchurl, + fixDarwinDylibNames, + pkgsStatic, }: stdenv.mkDerivation rec { @@ -14,18 +15,20 @@ stdenv.mkDerivation rec { hash = "sha256-vn/70FfK3r4qoURUL9kMaDjGoIO16KkEi47jtmsp1fs="; }; - patches = [ - ./CVE-2021-40633.patch - ] ++ lib.optionals stdenv.hostPlatform.isMinGW [ - # Build dll libraries. - (fetchurl { - url = "https://aur.archlinux.org/cgit/aur.git/plain/001-mingw-build.patch?h=mingw-w64-giflib&id=b7311edf54824ac797c7916cd3ddc3a4b2368a19"; - hash = "sha256-bBx7lw7FWtxZJ+E9AAbKIpCGcJnS5lrGpjYcv/zBtKk="; - }) - - # Install executables. - ./mingw-install-exes.patch - ]; + patches = + [ + ./CVE-2021-40633.patch + ] + ++ lib.optionals stdenv.hostPlatform.isMinGW [ + # Build dll libraries. + (fetchurl { + url = "https://aur.archlinux.org/cgit/aur.git/plain/001-mingw-build.patch?h=mingw-w64-giflib&id=b7311edf54824ac797c7916cd3ddc3a4b2368a19"; + hash = "sha256-bBx7lw7FWtxZJ+E9AAbKIpCGcJnS5lrGpjYcv/zBtKk="; + }) + + # Install executables. + ./mingw-install-exes.patch + ]; nativeBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ fixDarwinDylibNames @@ -35,18 +38,20 @@ stdenv.mkDerivation rec { "PREFIX=${builtins.placeholder "out"}" ]; - postPatch = '' - # we don't want to build HTML documentation - substituteInPlace doc/Makefile \ - --replace-fail "all: allhtml manpages" "all: manpages" - '' + lib.optionalString stdenv.hostPlatform.isStatic '' - # Upstream build system does not support NOT building shared libraries. - sed -i '/all:/ s/$(LIBGIFSO)//' Makefile - sed -i '/all:/ s/$(LIBUTILSO)//' Makefile - sed -i '/-m 755 $(LIBGIFSO)/ d' Makefile - sed -i '/ln -sf $(LIBGIFSOVER)/ d' Makefile - sed -i '/ln -sf $(LIBGIFSOMAJOR)/ d' Makefile - ''; + postPatch = + '' + # we don't want to build HTML documentation + substituteInPlace doc/Makefile \ + --replace-fail "all: allhtml manpages" "all: manpages" + '' + + lib.optionalString stdenv.hostPlatform.isStatic '' + # Upstream build system does not support NOT building shared libraries. + sed -i '/all:/ s/$(LIBGIFSO)//' Makefile + sed -i '/all:/ s/$(LIBUTILSO)//' Makefile + sed -i '/-m 755 $(LIBGIFSO)/ d' Makefile + sed -i '/ln -sf $(LIBGIFSOVER)/ d' Makefile + sed -i '/ln -sf $(LIBGIFSOMAJOR)/ d' Makefile + ''; passthru.tests = { static = pkgsStatic.giflib; diff --git a/pkgs/by-name/gi/gifsicle/package.nix b/pkgs/by-name/gi/gifsicle/package.nix index 974d7f3ed7dac6..60f352844e5ec3 100644 --- a/pkgs/by-name/gi/gifsicle/package.nix +++ b/pkgs/by-name/gi/gifsicle/package.nix @@ -1,6 +1,12 @@ -{ lib, stdenv, fetchurl, xorgproto, libXt, libX11 -, gifview ? false -, static ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchurl, + xorgproto, + libXt, + libX11, + gifview ? false, + static ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { @@ -12,7 +18,11 @@ stdenv.mkDerivation rec { hash = "sha256-snEWRwCf0qExMPO+FgUy7UZTjnYr/A8CDepQYYp9yVA="; }; - buildInputs = lib.optionals gifview [ xorgproto libXt libX11 ]; + buildInputs = lib.optionals gifview [ + xorgproto + libXt + libX11 + ]; configureFlags = lib.optional (!gifview) "--disable-gifview"; diff --git a/pkgs/by-name/gi/gifticlib/package.nix b/pkgs/by-name/gi/gifticlib/package.nix index b305df08860b67..ecfe3f32819caf 100644 --- a/pkgs/by-name/gi/gifticlib/package.nix +++ b/pkgs/by-name/gi/gifticlib/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, expat, nifticlib, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + expat, + nifticlib, + zlib, +}: stdenv.mkDerivation rec { pname = "gifticlib"; @@ -11,10 +19,17 @@ stdenv.mkDerivation rec { sha256 = "0gcab06gm0irjnlrkpszzd4wr8z0fi7gx8f7966gywdp2jlxzw19"; }; - cmakeFlags = [ "-DUSE_SYSTEM_NIFTI=ON" "-DDOWNLOAD_TEST_DATA=OFF" ]; + cmakeFlags = [ + "-DUSE_SYSTEM_NIFTI=ON" + "-DDOWNLOAD_TEST_DATA=OFF" + ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ expat nifticlib zlib ]; + buildInputs = [ + expat + nifticlib + zlib + ]; # without the test data, this is only a few basic tests doCheck = !stdenv.hostPlatform.isDarwin; diff --git a/pkgs/by-name/gi/gigedit/package.nix b/pkgs/by-name/gi/gigedit/package.nix index d53aa51d9b569f..47b756b6d72bf0 100644 --- a/pkgs/by-name/gi/gigedit/package.nix +++ b/pkgs/by-name/gi/gigedit/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, autoconf -, automake -, intltool -, libtool -, pkg-config -, which -, docbook_xml_dtd_45 -, docbook_xsl -, gtkmm2 -, pangomm_2_42 -, libgig -, libsndfile -, libxslt +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + intltool, + libtool, + pkg-config, + which, + docbook_xml_dtd_45, + docbook_xsl, + gtkmm2, + pangomm_2_42, + libgig, + libsndfile, + libxslt, }: let @@ -30,9 +31,23 @@ stdenv.mkDerivation rec { preConfigure = "make -f Makefile.svn"; - nativeBuildInputs = [ autoconf automake intltool libtool pkg-config which ]; + nativeBuildInputs = [ + autoconf + automake + intltool + libtool + pkg-config + which + ]; - buildInputs = [ docbook_xml_dtd_45 docbook_xsl gtkmm2_with_pango242 libgig libsndfile libxslt ]; + buildInputs = [ + docbook_xml_dtd_45 + docbook_xsl + gtkmm2_with_pango242 + libgig + libsndfile + libxslt + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/gi/gildas/package.nix b/pkgs/by-name/gi/gildas/package.nix index eafc631ef92c12..2e0a781a343dfa 100644 --- a/pkgs/by-name/gi/gildas/package.nix +++ b/pkgs/by-name/gi/gildas/package.nix @@ -1,9 +1,28 @@ -{ lib, stdenv, fetchurl, gtk2-x11 , pkg-config , python3 , gfortran , lesstif -, cfitsio , getopt , perl , groff , which, darwin, ncurses +{ + lib, + stdenv, + fetchurl, + gtk2-x11, + pkg-config, + python3, + gfortran, + lesstif, + cfitsio, + getopt, + perl, + groff, + which, + darwin, + ncurses, }: let - python3Env = python3.withPackages(ps: with ps; [ numpy setuptools ]); + python3Env = python3.withPackages ( + ps: with ps; [ + numpy + setuptools + ] + ); in stdenv.mkDerivation rec { @@ -14,27 +33,51 @@ stdenv.mkDerivation rec { src = fetchurl { # For each new release, the upstream developers of Gildas move the # source code of the previous release to a different directory - urls = [ "http://www.iram.fr/~gildas/dist/gildas-src-${srcVersion}.tar.xz" - "http://www.iram.fr/~gildas/dist/archive/gildas/gildas-src-${srcVersion}.tar.xz" ]; + urls = [ + "http://www.iram.fr/~gildas/dist/gildas-src-${srcVersion}.tar.xz" + "http://www.iram.fr/~gildas/dist/archive/gildas/gildas-src-${srcVersion}.tar.xz" + ]; sha256 = "sha256-dZ03J3I1dgoSgSc9yGfO13ZvNawCSYKN3+SGvp1eyGA="; }; - nativeBuildInputs = [ pkg-config groff perl getopt gfortran which ]; + nativeBuildInputs = [ + pkg-config + groff + perl + getopt + gfortran + which + ]; - buildInputs = [ gtk2-x11 lesstif cfitsio python3Env ncurses ] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ CoreFoundation ]); + buildInputs = + [ + gtk2-x11 + lesstif + cfitsio + python3Env + ncurses + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; [ CoreFoundation ] + ); - patches = [ ./wrapper.patch ] - ++ lib.optionals stdenv.hostPlatform.isDarwin ([ ./clang.patch ./cpp-darwin.patch ]); + patches = + [ ./wrapper.patch ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ([ + ./clang.patch + ./cpp-darwin.patch + ]); env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-unused-command-line-argument"; # Workaround for https://github.com/NixOS/nixpkgs/issues/304528 env.GAG_CPP = lib.optionalString stdenv.hostPlatform.isDarwin "${gfortran.outPath}/bin/cpp"; - NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; "-F${CoreFoundation}/Library/Frameworks"); + NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; "-F${CoreFoundation}/Library/Frameworks" + ); - configurePhase='' + configurePhase = '' substituteInPlace admin/wrapper.sh --replace '%%OUT%%' $out substituteInPlace admin/wrapper.sh --replace '%%PYTHONHOME%%' ${python3Env} substituteInPlace utilities/main/gag-makedepend.pl --replace '/usr/bin/perl' ${perl}/bin/perl @@ -44,7 +87,7 @@ stdenv.mkDerivation rec { userExec = "astro class greg imager mapping sic"; - postInstall='' + postInstall = '' mkdir -p $out/bin cp -a ../gildas-exe-${srcVersion}/* $out mv $out/$GAG_EXEC_SYSTEM $out/libexec @@ -68,7 +111,10 @@ stdenv.mkDerivation rec { plotting, widgets).''; homepage = "http://www.iram.fr/IRAMFR/GILDAS/gildas.html"; license = lib.licenses.free; - maintainers = [ lib.maintainers.bzizou lib.maintainers.smaret ]; + maintainers = [ + lib.maintainers.bzizou + lib.maintainers.smaret + ]; platforms = lib.platforms.all; }; diff --git a/pkgs/by-name/gi/gimme-aws-creds/package.nix b/pkgs/by-name/gi/gimme-aws-creds/package.nix index 69db86d4591d93..986f8d693fc376 100644 --- a/pkgs/by-name/gi/gimme-aws-creds/package.nix +++ b/pkgs/by-name/gi/gimme-aws-creds/package.nix @@ -1,11 +1,12 @@ -{ lib -, installShellFiles -, python3 -, fetchPypi -, fetchFromGitHub -, nix-update-script -, testers -, gimme-aws-creds +{ + lib, + installShellFiles, + python3, + fetchPypi, + fetchFromGitHub, + nix-update-script, + testers, + gimme-aws-creds, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/gi/gimoji/package.nix b/pkgs/by-name/gi/gimoji/package.nix index 02fe472ab39e52..5d070b9fb9ab09 100644 --- a/pkgs/by-name/gi/gimoji/package.nix +++ b/pkgs/by-name/gi/gimoji/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/gi/gimx/package.nix b/pkgs/by-name/gi/gimx/package.nix index 8f81ab09357ded..b2e1372fc35f02 100644 --- a/pkgs/by-name/gi/gimx/package.nix +++ b/pkgs/by-name/gi/gimx/package.nix @@ -1,4 +1,16 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper, curl, libusb1, bluez, libxml2, ncurses5, libmhash, xorg }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + curl, + libusb1, + bluez, + libxml2, + ncurses5, + libmhash, + xorg, +}: let gimx-config = fetchFromGitHub { @@ -8,7 +20,8 @@ let hash = "sha256-t/Ttlvc9LCRW624oSsFaP8EmswJ3OAn86QgF1dCUjAs="; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "gimx"; version = "8.0"; @@ -21,10 +34,22 @@ in stdenv.mkDerivation rec { }; env.NIX_CFLAGS_COMPILE = "-Wno-error"; - patches = [ ./conf.patch ./gcc14.patch ]; + patches = [ + ./conf.patch + ./gcc14.patch + ]; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ curl libusb1 bluez libxml2 ncurses5 libmhash xorg.libX11 xorg.libXi ]; + buildInputs = [ + curl + libusb1 + bluez + libxml2 + ncurses5 + libmhash + xorg.libX11 + xorg.libXi + ]; makeFlags = [ "build-core" ]; installPhase = '' diff --git a/pkgs/by-name/gi/ginac/package.nix b/pkgs/by-name/gi/ginac/package.nix index d2713befed3826..1f65047da6d717 100644 --- a/pkgs/by-name/gi/ginac/package.nix +++ b/pkgs/by-name/gi/ginac/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, cln, pkg-config, readline, gmp, python3 }: +{ + lib, + stdenv, + fetchurl, + cln, + pkg-config, + readline, + gmp, + python3, +}: stdenv.mkDerivation rec { pname = "ginac"; @@ -11,10 +20,12 @@ stdenv.mkDerivation rec { propagatedBuildInputs = [ cln ]; - buildInputs = [ readline ] - ++ lib.optional stdenv.hostPlatform.isDarwin gmp; + buildInputs = [ readline ] ++ lib.optional stdenv.hostPlatform.isDarwin gmp; - nativeBuildInputs = [ pkg-config python3 ]; + nativeBuildInputs = [ + pkg-config + python3 + ]; strictDeps = true; diff --git a/pkgs/by-name/gi/ginkgo/package.nix b/pkgs/by-name/gi/ginkgo/package.nix index f4174272e40e4c..e80d7d013673ed 100644 --- a/pkgs/by-name/gi/ginkgo/package.nix +++ b/pkgs/by-name/gi/ginkgo/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, ginkgo }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + ginkgo, +}: buildGoModule rec { pname = "ginkgo"; @@ -14,7 +20,10 @@ buildGoModule rec { # integration tests expect more file changes # types tests are missing CodeLocation - excludedPackages = [ "integration" "types" ]; + excludedPackages = [ + "integration" + "types" + ]; __darwinAllowLocalNetworking = true; @@ -40,6 +49,9 @@ buildGoModule rec { integration tests, acceptance test, performance tests, etc. ''; license = licenses.mit; - maintainers = with maintainers; [ saschagrunert jk ]; + maintainers = with maintainers; [ + saschagrunert + jk + ]; }; } diff --git a/pkgs/by-name/gi/gio-sharp/package.nix b/pkgs/by-name/gi/gio-sharp/package.nix index 91fbb86bd669a7..67047b2e4fedf5 100644 --- a/pkgs/by-name/gi/gio-sharp/package.nix +++ b/pkgs/by-name/gi/gio-sharp/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, which, pkg-config, mono, glib, gtk-sharp-2_0 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + which, + pkg-config, + mono, + glib, + gtk-sharp-2_0, +}: stdenv.mkDerivation rec { pname = "gio-sharp"; @@ -12,8 +23,17 @@ stdenv.mkDerivation rec { sha256 = "13pc529pjabj7lq23dbndc26ssmg5wkhc7lfvwapm87j711m0zig"; }; - nativeBuildInputs = [ pkg-config autoconf automake which ]; - buildInputs = [ mono glib gtk-sharp-2_0 ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + which + ]; + buildInputs = [ + mono + glib + gtk-sharp-2_0 + ]; dontStrip = true; diff --git a/pkgs/by-name/gi/giph/package.nix b/pkgs/by-name/gi/giph/package.nix index 9d0175911d6902..88bc15b67a9282 100644 --- a/pkgs/by-name/gi/giph/package.nix +++ b/pkgs/by-name/gi/giph/package.nix @@ -1,12 +1,13 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, ffmpeg -, xdotool -, slop -, libnotify -, procps -, makeWrapper +{ + stdenvNoCC, + lib, + fetchFromGitHub, + ffmpeg, + xdotool, + slop, + libnotify, + procps, + makeWrapper, }: stdenvNoCC.mkDerivation rec { @@ -30,7 +31,15 @@ stdenvNoCC.mkDerivation rec { postInstall = '' wrapProgram $out/bin/giph \ - --prefix PATH : ${lib.makeBinPath [ ffmpeg xdotool libnotify slop procps ]} + --prefix PATH : ${ + lib.makeBinPath [ + ffmpeg + xdotool + libnotify + slop + procps + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/gi/gir-rs/package.nix b/pkgs/by-name/gi/gir-rs/package.nix index afdfbda2c54e9d..d0dde89104160f 100644 --- a/pkgs/by-name/gi/gir-rs/package.nix +++ b/pkgs/by-name/gi/gir-rs/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: let version = "0.17.1"; diff --git a/pkgs/by-name/gi/girouette/package.nix b/pkgs/by-name/gi/girouette/package.nix index 09b0d61fccc93e..26b926f381af95 100644 --- a/pkgs/by-name/gi/girouette/package.nix +++ b/pkgs/by-name/gi/girouette/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, dbus -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + dbus, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -25,19 +26,27 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - dbus - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + dbus + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; meta = with lib; { description = "Show the weather in the terminal, in style"; homepage = "https://github.com/gourlaysama/girouette"; changelog = "https://github.com/gourlaysama/girouette/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; - maintainers = with maintainers; [ linuxissuper cafkafk ]; + license = with licenses; [ + asl20 + mit + ]; + maintainers = with maintainers; [ + linuxissuper + cafkafk + ]; mainProgram = "girouette"; }; } diff --git a/pkgs/by-name/gi/girsh/package.nix b/pkgs/by-name/gi/girsh/package.nix index ebec6f968df8c4..710abe7b0ab2c1 100644 --- a/pkgs/by-name/gi/girsh/package.nix +++ b/pkgs/by-name/gi/girsh/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/gi/gist/package.nix b/pkgs/by-name/gi/gist/package.nix index d2676b379970e6..153582afc71e85 100644 --- a/pkgs/by-name/gi/gist/package.nix +++ b/pkgs/by-name/gi/gist/package.nix @@ -1,4 +1,8 @@ -{ buildRubyGem, lib, ruby }: +{ + buildRubyGem, + lib, + ruby, +}: buildRubyGem rec { inherit ruby; diff --git a/pkgs/by-name/gi/git-agecrypt/package.nix b/pkgs/by-name/gi/git-agecrypt/package.nix index bdd9beba175dbc..e2a2c502031e00 100644 --- a/pkgs/by-name/gi/git-agecrypt/package.nix +++ b/pkgs/by-name/gi/git-agecrypt/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, darwin -, libgit2 -, git -, pkg-config -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, + libgit2, + git, + pkg-config, + zlib, }: rustPlatform.buildRustPackage { @@ -22,11 +23,15 @@ rustPlatform.buildRustPackage { cargoHash = "sha256-FmlJeWMIIyTsg3TTLUia14et+aTgFCTkOr1J5dp0SGY="; - nativeBuildInputs = [ pkg-config git ]; - - buildInputs = [ libgit2 zlib ] - ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.Security; + nativeBuildInputs = [ + pkg-config + git + ]; + buildInputs = [ + libgit2 + zlib + ] ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.Security; meta = with lib; { description = "Alternative to git-crypt using age instead of GPG"; diff --git a/pkgs/by-name/gi/git-aggregator/package.nix b/pkgs/by-name/gi/git-aggregator/package.nix index 740f805d12c580..5c95e7debed40c 100644 --- a/pkgs/by-name/gi/git-aggregator/package.nix +++ b/pkgs/by-name/gi/git-aggregator/package.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, git }: +{ + lib, + python3Packages, + fetchPypi, + git, +}: python3Packages.buildPythonApplication rec { pname = "git-aggregator"; diff --git a/pkgs/by-name/gi/git-annex-remote-rclone/package.nix b/pkgs/by-name/gi/git-annex-remote-rclone/package.nix index 4d1a7b2ade1d8e..903c0286020b53 100644 --- a/pkgs/by-name/gi/git-annex-remote-rclone/package.nix +++ b/pkgs/by-name/gi/git-annex-remote-rclone/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenvNoCC, fetchFromGitHub, rclone, makeWrapper }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + rclone, + makeWrapper, +}: stdenvNoCC.mkDerivation rec { pname = "git-annex-remote-rclone"; diff --git a/pkgs/by-name/gi/git-annex-utils/package.nix b/pkgs/by-name/gi/git-annex-utils/package.nix index 2b63192ea3b08a..bf9fd8d708983e 100644 --- a/pkgs/by-name/gi/git-annex-utils/package.nix +++ b/pkgs/by-name/gi/git-annex-utils/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchgit, autoconf, automake, libtool, gmp }: +{ + lib, + stdenv, + fetchgit, + autoconf, + automake, + libtool, + gmp, +}: stdenv.mkDerivation rec { pname = "git-annex-utils"; @@ -8,8 +16,14 @@ stdenv.mkDerivation rec { rev = "531bb33"; sha256 = "1sv7s2ykc840cjwbfn7ayy743643x9i1lvk4cd55w9l052xvzj65"; }; - nativeBuildInputs = [ autoconf automake ]; - buildInputs = [ libtool gmp ]; + nativeBuildInputs = [ + autoconf + automake + ]; + buildInputs = [ + libtool + gmp + ]; preConfigure = "./autogen.sh"; meta = { diff --git a/pkgs/by-name/gi/git-appraise/package.nix b/pkgs/by-name/gi/git-appraise/package.nix index cc77bf5aca65c4..f1b682f24574a3 100644 --- a/pkgs/by-name/gi/git-appraise/package.nix +++ b/pkgs/by-name/gi/git-appraise/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "git-appraise"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-Lzq4qpDAUjKFA2T685eW9NCfzEhDsn5UR1A1cIaZadE="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Distributed code review system for Git repos"; diff --git a/pkgs/by-name/gi/git-backdate/package.nix b/pkgs/by-name/gi/git-backdate/package.nix index 0d7d5810b9a87a..7e4c29834edbc3 100644 --- a/pkgs/by-name/gi/git-backdate/package.nix +++ b/pkgs/by-name/gi/git-backdate/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation rec { pname = "git-backdate"; @@ -29,4 +34,3 @@ stdenv.mkDerivation rec { mainProgram = "git-backdate"; }; } - diff --git a/pkgs/by-name/gi/git-bars/package.nix b/pkgs/by-name/gi/git-bars/package.nix index 66ae9bf2987bc9..31dd185e2ca747 100644 --- a/pkgs/by-name/gi/git-bars/package.nix +++ b/pkgs/by-name/gi/git-bars/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, python3Packages, git }: +{ + lib, + fetchFromGitHub, + python3Packages, + git, +}: python3Packages.buildPythonApplication { pname = "git-bars"; diff --git a/pkgs/by-name/gi/git-big-picture/package.nix b/pkgs/by-name/gi/git-big-picture/package.nix index a3ac58c04be8e9..43d127a2aae7d0 100644 --- a/pkgs/by-name/gi/git-big-picture/package.nix +++ b/pkgs/by-name/gi/git-big-picture/package.nix @@ -1,4 +1,10 @@ -{ lib, python3Packages, fetchPypi, git, graphviz }: +{ + lib, + python3Packages, + fetchPypi, + git, + graphviz, +}: python3Packages.buildPythonApplication rec { pname = "git-big-picture"; @@ -14,7 +20,12 @@ python3Packages.buildPythonApplication rec { postFixup = '' wrapProgram $out/bin/git-big-picture \ - --prefix PATH ":" ${ lib.makeBinPath [ git graphviz ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + git + graphviz + ] + } ''; meta = { diff --git a/pkgs/by-name/gi/git-bug-migration/package.nix b/pkgs/by-name/gi/git-bug-migration/package.nix index 45e90c521f104c..df18c4fe853635 100644 --- a/pkgs/by-name/gi/git-bug-migration/package.nix +++ b/pkgs/by-name/gi/git-bug-migration/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, git }: +{ + lib, + buildGoModule, + fetchFromGitHub, + git, +}: buildGoModule rec { pname = "git-bug-migration"; version = "0.3.4"; @@ -25,7 +30,7 @@ buildGoModule rec { git config --global user.email 'nobody@localhost' ''; - meta = with lib; { + meta = with lib; { description = "Tool for upgrading repositories using git-bug to new versions"; homepage = "https://github.com/MichaelMure/git-bug-migration"; license = licenses.gpl3Plus; diff --git a/pkgs/by-name/gi/git-bug/package.nix b/pkgs/by-name/gi/git-bug/package.nix index 7db43130ab4c64..5423593e92deb8 100644 --- a/pkgs/by-name/gi/git-bug/package.nix +++ b/pkgs/by-name/gi/git-bug/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "git-bug"; @@ -17,7 +22,10 @@ buildGoModule rec { doCheck = false; - excludedPackages = [ "doc" "misc" ]; + excludedPackages = [ + "doc" + "misc" + ]; ldflags = [ "-X github.com/MichaelMure/git-bug/commands.GitCommit=v${version}" @@ -38,7 +46,11 @@ buildGoModule rec { description = "Distributed bug tracker embedded in Git"; homepage = "https://github.com/git-bug/git-bug"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ royneary DeeUnderscore sudoforge ]; + maintainers = with maintainers; [ + royneary + DeeUnderscore + sudoforge + ]; mainProgram = "git-bug"; }; } diff --git a/pkgs/by-name/gi/git-cache/package.nix b/pkgs/by-name/gi/git-cache/package.nix index a099f92f504db7..8cf12ec7ca2beb 100644 --- a/pkgs/by-name/gi/git-cache/package.nix +++ b/pkgs/by-name/gi/git-cache/package.nix @@ -1,4 +1,8 @@ -{fetchFromGitHub, lib, stdenv}: +{ + fetchFromGitHub, + lib, + stdenv, +}: stdenv.mkDerivation { pname = "git-cache"; diff --git a/pkgs/by-name/gi/git-chglog/package.nix b/pkgs/by-name/gi/git-chglog/package.nix index eccc508fc257a5..26b05361c7fc81 100644 --- a/pkgs/by-name/gi/git-chglog/package.nix +++ b/pkgs/by-name/gi/git-chglog/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "git-chglog"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-skhEHpSnxOTZrL8XLlQZL3s224mg8XRINKJnatYCQko="; - ldflags = [ "-s" "-w" "-X=main.Version=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=v${version}" + ]; subPackages = [ "cmd/git-chglog" ]; diff --git a/pkgs/by-name/gi/git-codeowners/package.nix b/pkgs/by-name/gi/git-codeowners/package.nix index aff55a0a897737..b206a4312c800a 100644 --- a/pkgs/by-name/gi/git-codeowners/package.nix +++ b/pkgs/by-name/gi/git-codeowners/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "git-codeowners"; version = "0.1.2"; diff --git a/pkgs/by-name/gi/git-codereview/package.nix b/pkgs/by-name/gi/git-codereview/package.nix index aa847461d390e7..fca3b46ffa63d8 100644 --- a/pkgs/by-name/gi/git-codereview/package.nix +++ b/pkgs/by-name/gi/git-codereview/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, git }: +{ + lib, + buildGoModule, + fetchFromGitHub, + git, +}: buildGoModule rec { pname = "git-codereview"; @@ -13,7 +18,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeCheckInputs = [ git ]; diff --git a/pkgs/by-name/gi/git-cola/package.nix b/pkgs/by-name/gi/git-cola/package.nix index 7baf0662465af7..aef8a4604e6106 100644 --- a/pkgs/by-name/gi/git-cola/package.nix +++ b/pkgs/by-name/gi/git-cola/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, python3Packages -, gettext -, git -, qt5 -, gitUpdater +{ + stdenv, + lib, + fetchFromGitHub, + python3Packages, + gettext, + git, + qt5, + gitUpdater, }: python3Packages.buildPythonApplication rec { @@ -44,12 +45,14 @@ python3Packages.buildPythonApplication rec { pytestCheckHook ]; - disabledTestPaths = [ - "qtpy/" - "contrib/win32" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "cola/inotify.py" - ]; + disabledTestPaths = + [ + "qtpy/" + "contrib/win32" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "cola/inotify.py" + ]; preFixup = '' makeWrapperArgs+=("''${qtWrapperArgs[@]}") diff --git a/pkgs/by-name/gi/git-crecord/package.nix b/pkgs/by-name/gi/git-crecord/package.nix index 5365dc4e43aeb2..b5eec22bedc278 100644 --- a/pkgs/by-name/gi/git-crecord/package.nix +++ b/pkgs/by-name/gi/git-crecord/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3 }: +{ + lib, + fetchFromGitHub, + python3, +}: python3.pkgs.buildPythonApplication rec { pname = "git-crecord"; diff --git a/pkgs/by-name/gi/git-credential-oauth/package.nix b/pkgs/by-name/gi/git-credential-oauth/package.nix index 56c554da544643..9e095b2279d74b 100644 --- a/pkgs/by-name/gi/git-credential-oauth/package.nix +++ b/pkgs/by-name/gi/git-credential-oauth/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "git-credential-oauth"; diff --git a/pkgs/by-name/gi/git-crypt/package.nix b/pkgs/by-name/gi/git-crypt/package.nix index 2355f48bcb7791..367338d6019478 100644 --- a/pkgs/by-name/gi/git-crypt/package.nix +++ b/pkgs/by-name/gi/git-crypt/package.nix @@ -1,12 +1,13 @@ -{ fetchFromGitHub -, git -, gnupg -, makeWrapper -, openssl -, lib -, stdenv -, libxslt -, docbook_xsl +{ + fetchFromGitHub, + git, + gnupg, + makeWrapper, + openssl, + lib, + stdenv, + libxslt, + docbook_xsl, }: stdenv.mkDerivation rec { @@ -22,7 +23,10 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ libxslt makeWrapper ]; + nativeBuildInputs = [ + libxslt + makeWrapper + ]; buildInputs = [ openssl ]; @@ -44,7 +48,12 @@ stdenv.mkDerivation rec { postFixup = '' wrapProgram $out/bin/git-crypt \ - --suffix PATH : ${lib.makeBinPath [ git gnupg ]} + --suffix PATH : ${ + lib.makeBinPath [ + git + gnupg + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/gi/git-delete-merged-branches/package.nix b/pkgs/by-name/gi/git-delete-merged-branches/package.nix index 423dc72d24ffdc..0287e5ed590300 100644 --- a/pkgs/by-name/gi/git-delete-merged-branches/package.nix +++ b/pkgs/by-name/gi/git-delete-merged-branches/package.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchFromGitHub, git }: +{ + lib, + python3Packages, + fetchFromGitHub, + git, +}: python3Packages.buildPythonApplication rec { pname = "git-delete-merged-branches"; @@ -16,8 +21,7 @@ python3Packages.buildPythonApplication rec { prompt-toolkit ]; - nativeCheckInputs = [ git ] - ++ (with python3Packages; [ parameterized ]); + nativeCheckInputs = [ git ] ++ (with python3Packages; [ parameterized ]); meta = with lib; { description = "Command-line tool to delete merged Git branches"; diff --git a/pkgs/by-name/gi/git-dive/package.nix b/pkgs/by-name/gi/git-dive/package.nix index b80397e142bf4e..1f0c479abb4ce0 100644 --- a/pkgs/by-name/gi/git-dive/package.nix +++ b/pkgs/by-name/gi/git-dive/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libgit2 -, oniguruma -, zlib -, stdenv -, darwin -, git +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libgit2, + oniguruma, + zlib, + stdenv, + darwin, + git, }: rustPlatform.buildRustPackage rec { @@ -27,13 +28,15 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - libgit2 - oniguruma - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + libgit2 + oniguruma + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; nativeCheckInputs = [ git @@ -62,7 +65,10 @@ rustPlatform.buildRustPackage rec { description = "Dive into a file's history to find root cause"; homepage = "https://github.com/gitext-rs/git-dive"; changelog = "https://github.com/gitext-rs/git-dive/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "git-dive"; }; diff --git a/pkgs/by-name/gi/git-extras/package.nix b/pkgs/by-name/gi/git-extras/package.nix index 53382b2c24034b..630542f0e4e002 100644 --- a/pkgs/by-name/gi/git-extras/package.nix +++ b/pkgs/by-name/gi/git-extras/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, unixtools -, which +{ + lib, + stdenv, + fetchFromGitHub, + unixtools, + which, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gi/git-fire/package.nix b/pkgs/by-name/gi/git-fire/package.nix index bc7e9f4840b714..5916ed953d7eb3 100644 --- a/pkgs/by-name/gi/git-fire/package.nix +++ b/pkgs/by-name/gi/git-fire/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "git-fire"; diff --git a/pkgs/by-name/gi/git-ftp/package.nix b/pkgs/by-name/gi/git-ftp/package.nix index a3087249caddbe..85e56bb310ba9c 100644 --- a/pkgs/by-name/gi/git-ftp/package.nix +++ b/pkgs/by-name/gi/git-ftp/package.nix @@ -1,19 +1,20 @@ -{ lib -, resholve -, fetchFromGitHub -, fetchpatch -, bash -, coreutils -, git -, gnugrep -, gawk -, curl -, hostname -, gnused -, findutils -, lftp -, pandoc -, man +{ + lib, + resholve, + fetchFromGitHub, + fetchpatch, + bash, + coreutils, + git, + gnugrep, + gawk, + curl, + hostname, + gnused, + findutils, + lftp, + pandoc, + man, }: resholve.mkDerivation rec { @@ -42,7 +43,10 @@ resholve.mkDerivation rec { make install-all prefix=$out ''; - nativeBuildInputs = [ pandoc man ]; + nativeBuildInputs = [ + pandoc + man + ]; solutions = { git-ftp = { @@ -76,13 +80,13 @@ resholve.mkDerivation rec { # checked and see no obvious subexec for now "cannot:${git}/bin/git" /* - Mild uncertainty here. There *are* commandlikes in - the arguments (especially wait & cd), but I think they are - fine as-is, because I'm reading them as: - 1. ftp commands - 2. running on the remote anyways + Mild uncertainty here. There *are* commandlikes in + the arguments (especially wait & cd), but I think they are + fine as-is, because I'm reading them as: + 1. ftp commands + 2. running on the remote anyways - See https://github.com/git-ftp/git-ftp/blob/057f7d8e9f00ffc5a8c6ceaa4be30af2939df41a/git-ftp#L1214-L1221 + See https://github.com/git-ftp/git-ftp/blob/057f7d8e9f00ffc5a8c6ceaa4be30af2939df41a/git-ftp#L1214-L1221 */ "cannot:${lftp}/bin/lftp" ]; diff --git a/pkgs/by-name/gi/git-get/package.nix b/pkgs/by-name/gi/git-get/package.nix index 8e6bea06ab7f28..ccdfbf5e67f2e0 100644 --- a/pkgs/by-name/gi/git-get/package.nix +++ b/pkgs/by-name/gi/git-get/package.nix @@ -1,6 +1,11 @@ -{ lib, fetchFromGitHub, buildGoModule }: - -let config-module = "git-get/pkg/cfg"; +{ + lib, + fetchFromGitHub, + buildGoModule, +}: + +let + config-module = "git-get/pkg/cfg"; in buildGoModule rec { pname = "git-get"; diff --git a/pkgs/by-name/gi/git-gr/package.nix b/pkgs/by-name/gi/git-gr/package.nix index a50d389c04d05e..60f61e430cd453 100644 --- a/pkgs/by-name/gi/git-gr/package.nix +++ b/pkgs/by-name/gi/git-gr/package.nix @@ -33,9 +33,7 @@ rustPlatform.buildRustPackage { OPENSSL_NO_VENDOR = true; - nativeBuildInputs = - [installShellFiles] - ++ lib.optional stdenv.hostPlatform.isLinux pkg-config; + nativeBuildInputs = [ installShellFiles ] ++ lib.optional stdenv.hostPlatform.isLinux pkg-config; buildInputs = lib.optional stdenv.hostPlatform.isLinux openssl diff --git a/pkgs/by-name/gi/git-graph/package.nix b/pkgs/by-name/gi/git-graph/package.nix index 3cfda78c3af183..9c5902319aa51a 100644 --- a/pkgs/by-name/gi/git-graph/package.nix +++ b/pkgs/by-name/gi/git-graph/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -22,7 +23,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/mlange-42/git-graph"; license = licenses.mit; broken = stdenv.hostPlatform.isDarwin; - maintainers = with maintainers; [ cafkafk matthiasbeyer ]; + maintainers = with maintainers; [ + cafkafk + matthiasbeyer + ]; mainProgram = "git-graph"; }; } diff --git a/pkgs/by-name/gi/git-hound/package.nix b/pkgs/by-name/gi/git-hound/package.nix index 86efeef1c44453..67431b03b74748 100644 --- a/pkgs/by-name/gi/git-hound/package.nix +++ b/pkgs/by-name/gi/git-hound/package.nix @@ -1,7 +1,8 @@ -{ buildGoModule -, fetchFromGitHub -, fetchpatch -, lib +{ + buildGoModule, + fetchFromGitHub, + fetchpatch, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/gi/git-hub/package.nix b/pkgs/by-name/gi/git-hub/package.nix index 907721f882b3bd..33f3ea47d452c7 100644 --- a/pkgs/by-name/gi/git-hub/package.nix +++ b/pkgs/by-name/gi/git-hub/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, gitMinimal, docutils }: +{ + lib, + stdenv, + fetchFromGitHub, + gitMinimal, + docutils, +}: stdenv.mkDerivation rec { pname = "git-hub"; @@ -12,7 +18,7 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - gitMinimal # Used during build to generate Bash completion. + gitMinimal # Used during build to generate Bash completion. docutils ]; @@ -22,7 +28,10 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - installFlags = [ "prefix=$(out)" "sysconfdir=$(out)/etc" ]; + installFlags = [ + "prefix=$(out)" + "sysconfdir=$(out)/etc" + ]; postInstall = '' # Remove inert ftdetect vim plugin and a README that's a man page subset: diff --git a/pkgs/by-name/gi/git-ignore/package.nix b/pkgs/by-name/gi/git-ignore/package.nix index 12f4f02fd0a202..b418e4ded43d29 100644 --- a/pkgs/by-name/gi/git-ignore/package.nix +++ b/pkgs/by-name/gi/git-ignore/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/gi/git-instafix/package.nix b/pkgs/by-name/gi/git-instafix/package.nix index 18ab6f5fa0bd85..90abdb11e819b2 100644 --- a/pkgs/by-name/gi/git-instafix/package.nix +++ b/pkgs/by-name/gi/git-instafix/package.nix @@ -1,13 +1,13 @@ -{ git -, lib -, libgit2 -, rustPlatform -, stdenv -, fetchFromGitHub +{ + git, + lib, + libgit2, + rustPlatform, + stdenv, + fetchFromGitHub, }: let - inherit - (lib) + inherit (lib) licenses maintainers ; @@ -34,8 +34,14 @@ rustPlatform.buildRustPackage { description = "Quickly fix up an old commit using your currently-staged changes"; mainProgram = "git-instafix"; homepage = "https://github.com/quodlibetor/git-instafix"; - license = with licenses; [ mit asl20 ]; - maintainers = with maintainers; [ mightyiam quodlibetor ]; + license = with licenses; [ + mit + asl20 + ]; + maintainers = with maintainers; [ + mightyiam + quodlibetor + ]; changelog = "https://github.com/quodlibetor/git-instafix/releases/tag/v${version}"; broken = stdenv.hostPlatform.isDarwin; }; diff --git a/pkgs/by-name/gi/git-interactive-rebase-tool/package.nix b/pkgs/by-name/gi/git-interactive-rebase-tool/package.nix index fef465d9446e6f..534db5bfb1b565 100644 --- a/pkgs/by-name/gi/git-interactive-rebase-tool/package.nix +++ b/pkgs/by-name/gi/git-interactive-rebase-tool/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, libiconv, apple-sdk_11 }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + libiconv, + apple-sdk_11, +}: rustPlatform.buildRustPackage rec { pname = "git-interactive-rebase-tool"; @@ -13,7 +20,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-9pUUKxPpyoX9f10ZiLWsol2rv66WzQqwa6VubRTrT9Y="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv apple-sdk_11 ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + apple-sdk_11 + ]; # Compilation during tests fails if this env var is not set. preCheck = "export GIRT_BUILD_GIT_HASH=${version}"; @@ -24,7 +34,11 @@ rustPlatform.buildRustPackage rec { description = "Native cross platform full feature terminal based sequence editor for git interactive rebase"; changelog = "https://github.com/MitMaro/git-interactive-rebase-tool/releases/tag/${version}"; license = licenses.mit; - maintainers = with maintainers; [ SuperSandro2000 zowoq ma27 ]; + maintainers = with maintainers; [ + SuperSandro2000 + zowoq + ma27 + ]; mainProgram = "interactive-rebase-tool"; }; } diff --git a/pkgs/by-name/gi/git-latexdiff/package.nix b/pkgs/by-name/gi/git-latexdiff/package.nix index e7e4351a2088b3..c7de4b41438086 100644 --- a/pkgs/by-name/gi/git-latexdiff/package.nix +++ b/pkgs/by-name/gi/git-latexdiff/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitLab, git, bash }: +{ + lib, + stdenv, + fetchFromGitLab, + git, + bash, +}: stdenv.mkDerivation rec { version = "1.6.0"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { owner = "git-latexdiff"; }; - buildInputs = [ git bash ]; + buildInputs = [ + git + bash + ]; dontBuild = true; diff --git a/pkgs/by-name/gi/git-octopus/package.nix b/pkgs/by-name/gi/git-octopus/package.nix index 3865c9ac83b88b..3fae553d19e6bf 100644 --- a/pkgs/by-name/gi/git-octopus/package.nix +++ b/pkgs/by-name/gi/git-octopus/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, git, perl, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + git, + perl, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "git-octopus"; @@ -11,7 +18,12 @@ stdenv.mkDerivation rec { # perl provides shasum postInstall = '' for f in $out/bin/*; do - wrapProgram $f --prefix PATH : ${lib.makeBinPath [ git perl ]} + wrapProgram $f --prefix PATH : ${ + lib.makeBinPath [ + git + perl + ] + } done ''; @@ -27,6 +39,6 @@ stdenv.mkDerivation rec { description = "Continuous merge workflow"; license = licenses.lgpl3; platforms = platforms.unix; - maintainers = [maintainers.mic92]; + maintainers = [ maintainers.mic92 ]; }; } diff --git a/pkgs/by-name/gi/git-open/package.nix b/pkgs/by-name/gi/git-open/package.nix index 01d03dfef78454..61dbfbd172d4e9 100644 --- a/pkgs/by-name/gi/git-open/package.nix +++ b/pkgs/by-name/gi/git-open/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, xdg-utils, gnugrep, fetchFromGitHub, installShellFiles, makeWrapper, pandoc }: +{ + lib, + stdenv, + xdg-utils, + gnugrep, + fetchFromGitHub, + installShellFiles, + makeWrapper, + pandoc, +}: stdenv.mkDerivation rec { pname = "git-open"; @@ -11,7 +20,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-bZOknoRMkPqm1pFFFbvrHrSi90ANLEE5fLcABYHov6Q="; }; - nativeBuildInputs = [ installShellFiles makeWrapper pandoc ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + pandoc + ]; buildPhase = '' # marked-man is broken and severly outdated. diff --git a/pkgs/by-name/gi/git-privacy/package.nix b/pkgs/by-name/gi/git-privacy/package.nix index 3d3d7521f28dc9..e058e8d5ced30d 100644 --- a/pkgs/by-name/gi/git-privacy/package.nix +++ b/pkgs/by-name/gi/git-privacy/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, git -, python3 +{ + lib, + fetchFromGitHub, + git, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/gi/git-pw/package.nix b/pkgs/by-name/gi/git-pw/package.nix index e5e7bfb2113a26..24961845d1e991 100644 --- a/pkgs/by-name/gi/git-pw/package.nix +++ b/pkgs/by-name/gi/git-pw/package.nix @@ -1,9 +1,10 @@ -{ lib -, git -, python3 -, fetchFromGitHub -, testers -, git-pw +{ + lib, + git, + python3, + fetchFromGitHub, + testers, + git-pw, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/gi/git-quick-stats/package.nix b/pkgs/by-name/gi/git-quick-stats/package.nix index 113388c48cd30c..cf7bd82b0c0215 100644 --- a/pkgs/by-name/gi/git-quick-stats/package.nix +++ b/pkgs/by-name/gi/git-quick-stats/package.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, fetchFromGitHub -, makeWrapper -, coreutils -, gawk -, git -, gnugrep -, ncurses -, util-linux +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + coreutils, + gawk, + git, + gnugrep, + ncurses, + util-linux, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gi/git-radar/package.nix b/pkgs/by-name/gi/git-radar/package.nix index 59ec4b61d85c2b..6b53ea4e067bdc 100644 --- a/pkgs/by-name/gi/git-radar/package.nix +++ b/pkgs/by-name/gi/git-radar/package.nix @@ -1,4 +1,10 @@ -{ coreutils-prefixed, lib, makeWrapper, stdenv, fetchFromGitHub }: +{ + coreutils-prefixed, + lib, + makeWrapper, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "git-radar"; diff --git a/pkgs/by-name/gi/git-releaser/package.nix b/pkgs/by-name/gi/git-releaser/package.nix index 10cf95a2ec7e4e..0a46e3e98cd425 100644 --- a/pkgs/by-name/gi/git-releaser/package.nix +++ b/pkgs/by-name/gi/git-releaser/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, }: buildGoModule rec { diff --git a/pkgs/by-name/gi/git-relevant-history/package.nix b/pkgs/by-name/gi/git-relevant-history/package.nix index 063aa3215705b6..98dd80e3aa0921 100644 --- a/pkgs/by-name/gi/git-relevant-history/package.nix +++ b/pkgs/by-name/gi/git-relevant-history/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, python3, git, git-filter-repo }: +{ + lib, + fetchFromGitHub, + python3, + git, + git-filter-repo, +}: python3.pkgs.buildPythonApplication rec { pname = "git-relevant-history"; @@ -10,7 +16,8 @@ python3.pkgs.buildPythonApplication rec { hash = "sha256-46a6TR1Hi3Lg2DTmOp1aV5Uhd4IukTojZkA3TVbTnRY="; }; propagatedBuildInputs = [ - git git-filter-repo + git + git-filter-repo python3.pkgs.docopt ]; diff --git a/pkgs/by-name/gi/git-remote-gcrypt/package.nix b/pkgs/by-name/gi/git-remote-gcrypt/package.nix index d3f53b704eeb05..fc1b830ada7196 100644 --- a/pkgs/by-name/gi/git-remote-gcrypt/package.nix +++ b/pkgs/by-name/gi/git-remote-gcrypt/package.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, docutils, makeWrapper -, gnupg, curl, rsync, coreutils -, gawk, gnused, gnugrep +{ + lib, + stdenv, + fetchFromGitHub, + docutils, + makeWrapper, + gnupg, + curl, + rsync, + coreutils, + gawk, + gnused, + gnugrep, }: stdenv.mkDerivation rec { @@ -15,22 +25,40 @@ stdenv.mkDerivation rec { sha256 = "sha256-uy6s3YQwY/aZmQoW/qe1YrSlfNHyDTXBFxB6fPGiPNQ="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - nativeBuildInputs = [ docutils makeWrapper ]; + nativeBuildInputs = [ + docutils + makeWrapper + ]; installPhase = '' prefix="$out" ./install.sh wrapProgram "$out/bin/git-remote-gcrypt" \ - --prefix PATH ":" "${lib.makeBinPath [ gnupg curl rsync coreutils - gawk gnused gnugrep ]}" + --prefix PATH ":" "${ + lib.makeBinPath [ + gnupg + curl + rsync + coreutils + gawk + gnused + gnugrep + ] + }" ''; meta = with lib; { homepage = "https://spwhitton.name/tech/code/git-remote-gcrypt"; description = "Git remote helper for GPG-encrypted remotes"; license = licenses.gpl3; - maintainers = with maintainers; [ ellis montag451 ]; + maintainers = with maintainers; [ + ellis + montag451 + ]; platforms = platforms.unix; mainProgram = "git-remote-gcrypt"; }; diff --git a/pkgs/by-name/gi/git-remote-hg/package.nix b/pkgs/by-name/gi/git-remote-hg/package.nix index 76f40911f0763d..4a7435d7c2947c 100644 --- a/pkgs/by-name/gi/git-remote-hg/package.nix +++ b/pkgs/by-name/gi/git-remote-hg/package.nix @@ -1,5 +1,13 @@ -{ lib, fetchFromGitHub, python3Packages -, asciidoc, xmlto, docbook_xsl, docbook_xml_dtd_45, libxslt, libxml2 +{ + lib, + fetchFromGitHub, + python3Packages, + asciidoc, + xmlto, + docbook_xsl, + docbook_xml_dtd_45, + libxslt, + libxml2, }: python3Packages.buildPythonApplication rec { @@ -14,7 +22,12 @@ python3Packages.buildPythonApplication rec { }; nativeBuildInputs = [ - asciidoc xmlto docbook_xsl docbook_xml_dtd_45 libxslt libxml2 + asciidoc + xmlto + docbook_xsl + docbook_xml_dtd_45 + libxslt + libxml2 ]; propagatedBuildInputs = with python3Packages; [ mercurial ]; diff --git a/pkgs/by-name/gi/git-reparent/package.nix b/pkgs/by-name/gi/git-reparent/package.nix index 38a66d6db1db6c..dfe77ba1c09cde 100644 --- a/pkgs/by-name/gi/git-reparent/package.nix +++ b/pkgs/by-name/gi/git-reparent/package.nix @@ -1,13 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, git, gnused }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + git, + gnused, +}: stdenv.mkDerivation rec { pname = "git-reparent"; version = "unstable-2017-09-03"; src = fetchFromGitHub { - owner = "MarkLodato"; - repo = "git-reparent"; - rev = "a99554a32524a86421659d0f61af2a6c784b7715"; + owner = "MarkLodato"; + repo = "git-reparent"; + rev = "a99554a32524a86421659d0f61af2a6c784b7715"; sha256 = "0v0yxydpw6r4awy0hb7sbnh520zsk86ibzh1xjf3983yhsvkfk5v"; }; @@ -20,7 +27,12 @@ stdenv.mkDerivation rec { ''; postFixup = '' - wrapProgram $out/bin/git-reparent --prefix PATH : "${lib.makeBinPath [ git gnused ]}" + wrapProgram $out/bin/git-reparent --prefix PATH : "${ + lib.makeBinPath [ + git + gnused + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/gi/git-repo/package.nix b/pkgs/by-name/gi/git-repo/package.nix index 6d22522f82d52e..620d5e562ee9b9 100644 --- a/pkgs/by-name/gi/git-repo/package.nix +++ b/pkgs/by-name/gi/git-repo/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, nix-update-script -, python3, git, gnupg, less, openssh +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + nix-update-script, + python3, + git, + gnupg, + less, + openssh, }: stdenv.mkDerivation rec { @@ -37,7 +46,14 @@ stdenv.mkDerivation rec { # Important runtime dependencies postFixup = '' wrapProgram $out/bin/repo --prefix PATH ":" \ - "${lib.makeBinPath [ git gnupg less openssh ]}" + "${ + lib.makeBinPath [ + git + gnupg + less + openssh + ] + }" ''; passthru = { diff --git a/pkgs/by-name/gi/git-run/package.nix b/pkgs/by-name/gi/git-run/package.nix index a9f257b24bc665..a50242ccef3a20 100644 --- a/pkgs/by-name/gi/git-run/package.nix +++ b/pkgs/by-name/gi/git-run/package.nix @@ -1,7 +1,7 @@ { lib, buildNpmPackage, - fetchFromGitHub + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/gi/git-secret/package.nix b/pkgs/by-name/gi/git-secret/package.nix index 6c0613a28df7a3..774eb3f825ba90 100644 --- a/pkgs/by-name/gi/git-secret/package.nix +++ b/pkgs/by-name/gi/git-secret/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper, git, gnupg, gawk }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + git, + gnupg, + gawk, +}: stdenv.mkDerivation rec { pname = "git-secret"; @@ -17,7 +25,13 @@ stdenv.mkDerivation rec { install -D git-secret $out/bin/git-secret wrapProgram $out/bin/git-secret \ - --prefix PATH : "${lib.makeBinPath [ git gnupg gawk ]}" + --prefix PATH : "${ + lib.makeBinPath [ + git + gnupg + gawk + ] + }" mkdir $out/share cp -r man $out/share diff --git a/pkgs/by-name/gi/git-secrets/package.nix b/pkgs/by-name/gi/git-secrets/package.nix index a2f2045a3ddcfd..314bdecb74d7bc 100644 --- a/pkgs/by-name/gi/git-secrets/package.nix +++ b/pkgs/by-name/gi/git-secrets/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, git, coreutils }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + git, + coreutils, +}: stdenv.mkDerivation rec { pname = "git-secrets"; @@ -20,7 +27,12 @@ stdenv.mkDerivation rec { install -m444 -Dt $out/share/man/man1 git-secrets.1 wrapProgram $out/bin/git-secrets \ - --prefix PATH : "${lib.makeBinPath [ git coreutils ]}" + --prefix PATH : "${ + lib.makeBinPath [ + git + coreutils + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/gi/git-sizer/package.nix b/pkgs/by-name/gi/git-sizer/package.nix index b3d7f7a3a432e2..df6e00c22da596 100644 --- a/pkgs/by-name/gi/git-sizer/package.nix +++ b/pkgs/by-name/gi/git-sizer/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, git-sizer }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + git-sizer, +}: buildGoModule rec { pname = "git-sizer"; @@ -13,7 +19,11 @@ buildGoModule rec { vendorHash = "sha256-oRlsD99XiI/0ZWibjyRcycmGab+vMbXrV5hIdIyUDYg="; - ldflags = [ "-s" "-w" "-X main.BuildVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.BuildVersion=${version}" + ]; doCheck = false; diff --git a/pkgs/by-name/gi/git-standup/package.nix b/pkgs/by-name/gi/git-standup/package.nix index bd85ca57229fd7..ce0acd7f4f4078 100644 --- a/pkgs/by-name/gi/git-standup/package.nix +++ b/pkgs/by-name/gi/git-standup/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, git }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + git, +}: stdenv.mkDerivation (finalAttrs: { pname = "git-standup"; diff --git a/pkgs/by-name/gi/git-stree/package.nix b/pkgs/by-name/gi/git-stree/package.nix index d15db48902fa16..3c8d83d6e1c17f 100644 --- a/pkgs/by-name/gi/git-stree/package.nix +++ b/pkgs/by-name/gi/git-stree/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, ... }: +{ + stdenv, + lib, + fetchFromGitHub, + ... +}: stdenv.mkDerivation { pname = "git-stree"; diff --git a/pkgs/by-name/gi/git-subrepo/package.nix b/pkgs/by-name/gi/git-subrepo/package.nix index 29da4ee6be8b49..1d3a84f1243662 100644 --- a/pkgs/by-name/gi/git-subrepo/package.nix +++ b/pkgs/by-name/gi/git-subrepo/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, git, makeWrapper, which, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + git, + makeWrapper, + which, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "git-subrepo"; diff --git a/pkgs/by-name/gi/git-subtrac/package.nix b/pkgs/by-name/gi/git-subtrac/package.nix index 43fb89661735f3..9a454cad5af61d 100644 --- a/pkgs/by-name/gi/git-subtrac/package.nix +++ b/pkgs/by-name/gi/git-subtrac/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "git-subtrac"; diff --git a/pkgs/by-name/gi/git-team/package.nix b/pkgs/by-name/gi/git-team/package.nix index 19556366b1eb7d..081c8dc5e71dc5 100644 --- a/pkgs/by-name/gi/git-team/package.nix +++ b/pkgs/by-name/gi/git-team/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, go-mockery -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + go-mockery, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/gi/git-test/package.nix b/pkgs/by-name/gi/git-test/package.nix index fb8619249b55ff..388be610c0844c 100644 --- a/pkgs/by-name/gi/git-test/package.nix +++ b/pkgs/by-name/gi/git-test/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, git }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + git, +}: stdenv.mkDerivation rec { pname = "git-test"; diff --git a/pkgs/by-name/gi/git-together/package.nix b/pkgs/by-name/gi/git-together/package.nix index 44ae1249a59c3b..ce1532cd61aa54 100644 --- a/pkgs/by-name/gi/git-together/package.nix +++ b/pkgs/by-name/gi/git-together/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, openssl -, pkg-config -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + openssl, + pkg-config, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/gi/git-town/package.nix b/pkgs/by-name/gi/git-town/package.nix index 1fbbd4ca12e0a9..95dfc087042242 100644 --- a/pkgs/by-name/gi/git-town/package.nix +++ b/pkgs/by-name/gi/git-town/package.nix @@ -1,4 +1,13 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, git, testers, git-town, makeWrapper }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + git, + testers, + git-town, + makeWrapper, +}: buildGoModule rec { pname = "git-town"; @@ -13,7 +22,10 @@ buildGoModule rec { vendorHash = null; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; buildInputs = [ git ]; @@ -68,7 +80,11 @@ buildGoModule rec { description = "Generic, high-level git support for git-flow workflows"; homepage = "https://www.git-town.com/"; license = licenses.mit; - maintainers = with maintainers; [ allonsy blaggacao gabyx ]; + maintainers = with maintainers; [ + allonsy + blaggacao + gabyx + ]; mainProgram = "git-town"; }; } diff --git a/pkgs/by-name/gi/git-upstream/package.nix b/pkgs/by-name/gi/git-upstream/package.nix index d94ca080b630e1..3c5ef78d4585fb 100644 --- a/pkgs/by-name/gi/git-upstream/package.nix +++ b/pkgs/by-name/gi/git-upstream/package.nix @@ -3,30 +3,31 @@ fetchFromGitHub, rustPlatform, nix-update-script, -}: let +}: +let pname = "git-upstream"; version = "1.2.0"; in - rustPlatform.buildRustPackage { - inherit pname version; +rustPlatform.buildRustPackage { + inherit pname version; - src = fetchFromGitHub { - owner = "9999years"; - repo = pname; - rev = "refs/tags/v${version}"; - hash = "sha256-GnsqZSztDLXMO4T16nfcOKMKXap88CJzJ5nObzGwhMA="; - }; + src = fetchFromGitHub { + owner = "9999years"; + repo = pname; + rev = "refs/tags/v${version}"; + hash = "sha256-GnsqZSztDLXMO4T16nfcOKMKXap88CJzJ5nObzGwhMA="; + }; - cargoHash = "sha256-a12C/fpeo0ZJ0MFQlKHVZER9dVrXF95YI1i8MwCTCJo="; + cargoHash = "sha256-a12C/fpeo0ZJ0MFQlKHVZER9dVrXF95YI1i8MwCTCJo="; - meta = { - homepage = "https://github.com/9999years/git-upstream"; - changelog = "https://github.com/9999years/git-upstream/releases/tag/v${version}"; - description = "Shortcut for `git push --set-upstream`"; - license = [lib.licenses.mit]; - maintainers = [lib.maintainers._9999years]; - mainProgram = "git-upstream"; - }; + meta = { + homepage = "https://github.com/9999years/git-upstream"; + changelog = "https://github.com/9999years/git-upstream/releases/tag/v${version}"; + description = "Shortcut for `git push --set-upstream`"; + license = [ lib.licenses.mit ]; + maintainers = [ lib.maintainers._9999years ]; + mainProgram = "git-upstream"; + }; - passthru.updateScript = nix-update-script {}; - } + passthru.updateScript = nix-update-script { }; +} diff --git a/pkgs/by-name/gi/git-vendor/package.nix b/pkgs/by-name/gi/git-vendor/package.nix index a0f3e26b2e4f1d..b8132fc6cdb265 100644 --- a/pkgs/by-name/gi/git-vendor/package.nix +++ b/pkgs/by-name/gi/git-vendor/package.nix @@ -1,11 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, writeShellScriptBin, skawarePackages +{ + lib, + stdenv, + fetchFromGitHub, + writeShellScriptBin, + skawarePackages, }: let version = "1.3.0"; sha256 = "sha256-CFv9gZQHeEiZctJFyB6PJ1dVNkrQ7PlVtgZuteQQTJ0="; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "git-vendor"; inherit version; @@ -16,7 +22,12 @@ in stdenv.mkDerivation { inherit sha256; }; - outputs = [ "bin" "man" "doc" "out" ]; + outputs = [ + "bin" + "man" + "doc" + "out" + ]; PREFIX = (placeholder "out"); BINPREFIX = "${placeholder "bin"}/bin"; @@ -28,7 +39,8 @@ in stdenv.mkDerivation { ]; postInstall = '' - ${skawarePackages.cleanPackaging.commonFileActions { + ${ + skawarePackages.cleanPackaging.commonFileActions { docFiles = [ "LICENSE" "README.md" @@ -40,7 +52,8 @@ in stdenv.mkDerivation { "man" "install.sh" ]; - }} $doc/share/doc/git-vendor + } + } $doc/share/doc/git-vendor ''; postFixup = '' diff --git a/pkgs/by-name/gi/git-when-merged/package.nix b/pkgs/by-name/gi/git-when-merged/package.nix index 36336d964cc356..593f31e6a63414 100644 --- a/pkgs/by-name/gi/git-when-merged/package.nix +++ b/pkgs/by-name/gi/git-when-merged/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation rec { pname = "git-when-merged"; @@ -18,8 +23,7 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = - "Helps you figure out when and why a commit was merged into a branch"; + description = "Helps you figure out when and why a commit was merged into a branch"; longDescription = '' If you use standard Git workflows, then you create a feature branch for each feature that you are working on. When the feature diff --git a/pkgs/by-name/gi/git2-cpp/package.nix b/pkgs/by-name/gi/git2-cpp/package.nix index 45750d0b24d47c..18d50cc242a81d 100644 --- a/pkgs/by-name/gi/git2-cpp/package.nix +++ b/pkgs/by-name/gi/git2-cpp/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gi/git2cl/package.nix b/pkgs/by-name/gi/git2cl/package.nix index cddc6eb7e2fe9a..e9074f3dd41903 100644 --- a/pkgs/by-name/gi/git2cl/package.nix +++ b/pkgs/by-name/gi/git2cl/package.nix @@ -1,4 +1,9 @@ -{ fetchgit, lib, stdenv, perl }: +{ + fetchgit, + lib, + stdenv, + perl, +}: stdenv.mkDerivation rec { pname = "git2cl"; diff --git a/pkgs/by-name/gi/gitaly/git.nix b/pkgs/by-name/gi/gitaly/git.nix index a4da27381df089..5277209ef35d4c 100644 --- a/pkgs/by-name/gi/gitaly/git.nix +++ b/pkgs/by-name/gi/gitaly/git.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, gitaly -, fetchFromGitLab -, curl -, pcre2 -, zlib +{ + stdenv, + lib, + gitaly, + fetchFromGitLab, + curl, + pcre2, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gi/gitaly/package.nix b/pkgs/by-name/gi/gitaly/package.nix index 3cf0ec3e0f5abd..ca320beb14c4b0 100644 --- a/pkgs/by-name/gi/gitaly/package.nix +++ b/pkgs/by-name/gi/gitaly/package.nix @@ -1,8 +1,9 @@ -{ lib -, callPackage -, fetchFromGitLab -, buildGoModule -, pkg-config +{ + lib, + callPackage, + fetchFromGitLab, + buildGoModule, + pkg-config, }: let @@ -25,43 +26,60 @@ let vendorHash = "sha256-AxuAEiYV3jwWxcuTLc1i4/6sG957YIA+Fmky5Dkdzu8="; - ldflags = [ "-X ${gitaly_package}/internal/version.version=${version}" "-X ${gitaly_package}/internal/version.moduleVersion=${version}" ]; + ldflags = [ + "-X ${gitaly_package}/internal/version.version=${version}" + "-X ${gitaly_package}/internal/version.moduleVersion=${version}" + ]; tags = [ "static" ]; doCheck = false; }; - auxBins = buildGoModule ({ - pname = "gitaly-aux"; + auxBins = buildGoModule ( + { + pname = "gitaly-aux"; - subPackages = [ "cmd/gitaly-hooks" "cmd/gitaly-ssh" "cmd/gitaly-lfs-smudge" "cmd/gitaly-gpg" ]; - } // commonOpts); + subPackages = [ + "cmd/gitaly-hooks" + "cmd/gitaly-ssh" + "cmd/gitaly-lfs-smudge" + "cmd/gitaly-gpg" + ]; + } + // commonOpts + ); in -buildGoModule ({ - pname = "gitaly"; +buildGoModule ( + { + pname = "gitaly"; - subPackages = [ "cmd/gitaly" "cmd/gitaly-backup" ]; + subPackages = [ + "cmd/gitaly" + "cmd/gitaly-backup" + ]; - preConfigure = '' - mkdir -p _build/bin - cp -r ${auxBins}/bin/* _build/bin - for f in ${git}/bin/git-*; do - cp "$f" "_build/bin/gitaly-$(basename $f)"; - done - ''; + preConfigure = '' + mkdir -p _build/bin + cp -r ${auxBins}/bin/* _build/bin + for f in ${git}/bin/git-*; do + cp "$f" "_build/bin/gitaly-$(basename $f)"; + done + ''; - outputs = [ "out" ]; + outputs = [ "out" ]; - passthru = { - inherit git; - }; + passthru = { + inherit git; + }; - meta = with lib; { - homepage = "https://gitlab.com/gitlab-org/gitaly"; - description = "Git RPC service for handling all the git calls made by GitLab"; - platforms = platforms.linux ++ [ "x86_64-darwin" ]; - maintainers = teams.gitlab.members; - license = licenses.mit; - }; -} // commonOpts) + meta = with lib; { + homepage = "https://gitlab.com/gitlab-org/gitaly"; + description = "Git RPC service for handling all the git calls made by GitLab"; + platforms = platforms.linux ++ [ "x86_64-darwin" ]; + maintainers = teams.gitlab.members; + license = licenses.mit; + }; + } + // commonOpts +) diff --git a/pkgs/by-name/gi/gitbatch/package.nix b/pkgs/by-name/gi/gitbatch/package.nix index 7f7c6c64891a8a..f00fc4d95be15b 100644 --- a/pkgs/by-name/gi/gitbatch/package.nix +++ b/pkgs/by-name/gi/gitbatch/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, git }: +{ + lib, + buildGoModule, + fetchFromGitHub, + git, +}: buildGoModule rec { pname = "gitbatch"; @@ -13,7 +18,10 @@ buildGoModule rec { vendorHash = "sha256-wwpaJO5cXMsvqFXj+qGiIm4zg/SL4YCm2mNnG/qdilw="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeCheckInputs = [ git # required by unit tests diff --git a/pkgs/by-name/gi/gitea/package.nix b/pkgs/by-name/gi/gitea/package.nix index bb4b94c5cecf7c..8119a71f4c9dc9 100644 --- a/pkgs/by-name/gi/gitea/package.nix +++ b/pkgs/by-name/gi/gitea/package.nix @@ -1,17 +1,18 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, git -, bash -, coreutils -, compressDrvWeb -, gitea -, gzip -, openssh -, sqliteSupport ? true -, nixosTests -, buildNpmPackage +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + git, + bash, + coreutils, + compressDrvWeb, + gitea, + gzip, + openssh, + sqliteSupport ? true, + nixosTests, + buildNpmPackage, }: let @@ -31,7 +32,8 @@ let cp -R public $out/ ''; }; -in buildGoModule rec { +in +buildGoModule rec { pname = "gitea"; version = "1.22.4"; @@ -46,7 +48,10 @@ in buildGoModule rec { vendorHash = "sha256-72Q5XBb7RwfX3eekt8dsaS1doDhLCO0MFPHzJvlzxUo="; - outputs = [ "out" "data" ]; + outputs = [ + "out" + "data" + ]; patches = [ ./static-root-path.patch ]; @@ -63,7 +68,10 @@ in buildGoModule rec { nativeBuildInputs = [ makeWrapper ]; - tags = lib.optionals sqliteSupport [ "sqlite" "sqlite_unlock_notify" ]; + tags = lib.optionals sqliteSupport [ + "sqlite" + "sqlite_unlock_notify" + ]; ldflags = [ "-s" @@ -80,11 +88,21 @@ in buildGoModule rec { cp -R ./options/locale $out/locale wrapProgram $out/bin/gitea \ - --prefix PATH : ${lib.makeBinPath [ bash coreutils git gzip openssh ]} + --prefix PATH : ${ + lib.makeBinPath [ + bash + coreutils + git + gzip + openssh + ] + } ''; passthru = { - data-compressed = lib.warn "gitea.passthru.data-compressed is deprecated. Use \"compressDrvWeb gitea.data\"." (compressDrvWeb gitea.data {}); + data-compressed = + lib.warn "gitea.passthru.data-compressed is deprecated. Use \"compressDrvWeb gitea.data\"." + (compressDrvWeb gitea.data { }); tests = nixosTests.gitea; }; @@ -93,7 +111,11 @@ in buildGoModule rec { description = "Git with a cup of tea"; homepage = "https://about.gitea.com"; license = licenses.mit; - maintainers = with maintainers; [ ma27 techknowlogick SuperSandro2000 ]; + maintainers = with maintainers; [ + ma27 + techknowlogick + SuperSandro2000 + ]; mainProgram = "gitea"; }; } diff --git a/pkgs/by-name/gi/gitflow/package.nix b/pkgs/by-name/gi/gitflow/package.nix index de291113daeac4..70e6a159c29c8a 100644 --- a/pkgs/by-name/gi/gitflow/package.nix +++ b/pkgs/by-name/gi/gitflow/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, getopt, git, coreutils }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + getopt, + git, + coreutils, +}: stdenv.mkDerivation rec { pname = "gitflow"; diff --git a/pkgs/by-name/gi/gitfs/package.nix b/pkgs/by-name/gi/gitfs/package.nix index c99455cdb99731..3b9cf7cfe17b59 100644 --- a/pkgs/by-name/gi/gitfs/package.nix +++ b/pkgs/by-name/gi/gitfs/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "gitfs"; @@ -22,8 +26,17 @@ python3Packages.buildPythonApplication rec { 'from pygit2 import RemoteCallbacks' ''; - nativeCheckInputs = with python3Packages; [ pytest pytest-cov mock ]; - propagatedBuildInputs = with python3Packages; [ atomiclong fusepy pygit2 six ]; + nativeCheckInputs = with python3Packages; [ + pytest + pytest-cov + mock + ]; + propagatedBuildInputs = with python3Packages; [ + atomiclong + fusepy + pygit2 + six + ]; checkPhase = "py.test"; doCheck = false; diff --git a/pkgs/by-name/gi/gitg/package.nix b/pkgs/by-name/gi/gitg/package.nix index c5071267ae8cf7..7208eaed291c73 100644 --- a/pkgs/by-name/gi/gitg/package.nix +++ b/pkgs/by-name/gi/gitg/package.nix @@ -1,31 +1,32 @@ -{ lib -, stdenv -, fetchurl -, vala -, pkg-config -, gtk3 -, glib -, gpgme -, json-glib -, wrapGAppsHook3 -, libpeas -, bash -, gobject-introspection -, gtksourceview4 -, gsettings-desktop-schemas -, gnome -, gspell -, gvfs -, shared-mime-info -, libgee -, libgit2-glib -, libhandy -, libsecret -, libxml2 -, meson -, ninja -, python3 -, libdazzle +{ + lib, + stdenv, + fetchurl, + vala, + pkg-config, + gtk3, + glib, + gpgme, + json-glib, + wrapGAppsHook3, + libpeas, + bash, + gobject-introspection, + gtksourceview4, + gsettings-desktop-schemas, + gnome, + gspell, + gvfs, + shared-mime-info, + libgee, + libgit2-glib, + libhandy, + libsecret, + libxml2, + meson, + ninja, + python3, + libdazzle, }: stdenv.mkDerivation rec { @@ -93,7 +94,10 @@ stdenv.mkDerivation rec { changelog = "https://gitlab.gnome.org/GNOME/gitg/-/blob/v${version}/NEWS?ref_type=tags"; description = "GNOME GUI client to view git repositories"; mainProgram = "gitg"; - maintainers = with maintainers; [ domenkozar Luflosi ]; + maintainers = with maintainers; [ + domenkozar + Luflosi + ]; license = licenses.gpl2Plus; platforms = platforms.linux; }; diff --git a/pkgs/by-name/gi/githooks/package.nix b/pkgs/by-name/gi/githooks/package.nix index 54acd52929234a..262c17e334f6e0 100644 --- a/pkgs/by-name/gi/githooks/package.nix +++ b/pkgs/by-name/gi/githooks/package.nix @@ -5,7 +5,7 @@ git, testers, makeWrapper, - githooks + githooks, }: buildGoModule rec { pname = "githooks"; diff --git a/pkgs/by-name/gi/github-backup/package.nix b/pkgs/by-name/gi/github-backup/package.nix index 298b27c1b2e1ad..f067d3b94be48e 100644 --- a/pkgs/by-name/gi/github-backup/package.nix +++ b/pkgs/by-name/gi/github-backup/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3Packages -, fetchFromGitHub -, git -, git-lfs +{ + lib, + python3Packages, + fetchFromGitHub, + git, + git-lfs, }: python3Packages.buildPythonApplication rec { @@ -22,7 +23,13 @@ python3Packages.buildPythonApplication rec { ]; makeWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath [ git git-lfs ]) + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ + git + git-lfs + ]) ]; # has no unit tests diff --git a/pkgs/by-name/gi/github-commenter/package.nix b/pkgs/by-name/gi/github-commenter/package.nix index 50a12e0eb0a80a..1bf88c51cebdd9 100644 --- a/pkgs/by-name/gi/github-commenter/package.nix +++ b/pkgs/by-name/gi/github-commenter/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "github-commenter"; diff --git a/pkgs/by-name/gi/github-copilot-cli/package.nix b/pkgs/by-name/gi/github-copilot-cli/package.nix index 8bed7df94084c2..d93eb31f860981 100644 --- a/pkgs/by-name/gi/github-copilot-cli/package.nix +++ b/pkgs/by-name/gi/github-copilot-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, buildNpmPackage, fetchzip }: +{ + lib, + buildNpmPackage, + fetchzip, +}: buildNpmPackage rec { pname = "github-copilot-cli"; @@ -26,4 +30,3 @@ buildNpmPackage rec { mainProgram = "github-copilot-cli"; }; } - diff --git a/pkgs/by-name/gi/github-copilot-intellij-agent/package.nix b/pkgs/by-name/gi/github-copilot-intellij-agent/package.nix index 13c28ca5b71ab0..626d1836645da0 100644 --- a/pkgs/by-name/gi/github-copilot-intellij-agent/package.nix +++ b/pkgs/by-name/gi/github-copilot-intellij-agent/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchurl, unzip }: +{ + stdenv, + lib, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "github-copilot-intellij-agent"; @@ -19,7 +24,10 @@ stdenv.mkDerivation rec { mkdir -p $out/bin unzip -p $src github-copilot-intellij/copilot-agent/bin/copilot-agent-${ - if stdenv.hostPlatform.isDarwin then (if stdenv.hostPlatform.isAarch64 then "macos-arm64" else "macos") else "linux" + if stdenv.hostPlatform.isDarwin then + (if stdenv.hostPlatform.isAarch64 then "macos-arm64" else "macos") + else + "linux" } | install -m755 /dev/stdin $out/bin/copilot-agent runHook postInstall @@ -27,34 +35,36 @@ stdenv.mkDerivation rec { # https://discourse.nixos.org/t/unrelatable-error-when-working-with-patchelf/12043 # https://github.com/NixOS/nixpkgs/blob/db0d8e10fc1dec84f1ccb111851a82645aa6a7d3/pkgs/development/web/now-cli/default.nix - preFixup = let - binaryLocation = "$out/bin/copilot-agent"; - libPath = lib.makeLibraryPath [ stdenv.cc.cc ]; - in '' - orig_size=$(stat --printf=%s ${binaryLocation}) - - patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" ${binaryLocation} - patchelf --set-rpath ${libPath} ${binaryLocation} - chmod +x ${binaryLocation} - - new_size=$(stat --printf=%s ${binaryLocation}) - - var_skip=20 - var_select=22 - shift_by=$(expr $new_size - $orig_size) - - function fix_offset { - location=$(grep -obUam1 "$1" ${binaryLocation} | cut -d: -f1) - location=$(expr $location + $var_skip) - value=$(dd if=${binaryLocation} iflag=count_bytes,skip_bytes skip=$location \ - bs=1 count=$var_select status=none) - value=$(expr $shift_by + $value) - echo -n $value | dd of=${binaryLocation} bs=1 seek=$location conv=notrunc - } - - fix_offset PAYLOAD_POSITION - fix_offset PRELUDE_POSITION - ''; + preFixup = + let + binaryLocation = "$out/bin/copilot-agent"; + libPath = lib.makeLibraryPath [ stdenv.cc.cc ]; + in + '' + orig_size=$(stat --printf=%s ${binaryLocation}) + + patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" ${binaryLocation} + patchelf --set-rpath ${libPath} ${binaryLocation} + chmod +x ${binaryLocation} + + new_size=$(stat --printf=%s ${binaryLocation}) + + var_skip=20 + var_select=22 + shift_by=$(expr $new_size - $orig_size) + + function fix_offset { + location=$(grep -obUam1 "$1" ${binaryLocation} | cut -d: -f1) + location=$(expr $location + $var_skip) + value=$(dd if=${binaryLocation} iflag=count_bytes,skip_bytes skip=$location \ + bs=1 count=$var_select status=none) + value=$(expr $shift_by + $value) + echo -n $value | dd of=${binaryLocation} bs=1 seek=$location conv=notrunc + } + + fix_offset PAYLOAD_POSITION + fix_offset PRELUDE_POSITION + ''; dontStrip = true; @@ -76,7 +86,11 @@ stdenv.mkDerivation rec { license = lib.licenses.unfree; maintainers = with lib.maintainers; [ hacker1024 ]; mainProgram = "copilot-agent"; - platforms = [ "x86_64-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; }; } diff --git a/pkgs/by-name/gi/github-desktop/package.nix b/pkgs/by-name/gi/github-desktop/package.nix index 4551473984297d..22a01f07eb38ad 100644 --- a/pkgs/by-name/gi/github-desktop/package.nix +++ b/pkgs/by-name/gi/github-desktop/package.nix @@ -1,22 +1,23 @@ -{ stdenvNoCC -, lib -, fetchurl -, autoPatchelfHook -, buildPackages -, gnome-keyring -, libsecret -, git -, curl -, nss -, nspr -, xorg -, libdrm -, alsa-lib -, cups -, mesa -, systemd -, openssl -, libglvnd +{ + stdenvNoCC, + lib, + fetchurl, + autoPatchelfHook, + buildPackages, + gnome-keyring, + libsecret, + git, + curl, + nss, + nspr, + xorg, + libdrm, + alsa-lib, + cups, + mesa, + systemd, + openssl, + libglvnd, }: let @@ -39,7 +40,9 @@ stdenvNoCC.mkDerivation (finalAttrs: { }; }; in - fetchurl urls."${stdenvNoCC.hostPlatform.system}" or (throw "Unsupported system: ${stdenvNoCC.hostPlatform.system}"); + fetchurl + urls."${stdenvNoCC.hostPlatform.system}" + or (throw "Unsupported system: ${stdenvNoCC.hostPlatform.system}"); nativeBuildInputs = [ autoPatchelfHook diff --git a/pkgs/by-name/gi/github-markdown-toc-go/package.nix b/pkgs/by-name/gi/github-markdown-toc-go/package.nix index 809664c90d1db8..a80ac4af93b6be 100644 --- a/pkgs/by-name/gi/github-markdown-toc-go/package.nix +++ b/pkgs/by-name/gi/github-markdown-toc-go/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "github-markdown-toc-go"; diff --git a/pkgs/by-name/gi/github-release/package.nix b/pkgs/by-name/gi/github-release/package.nix index e2480451e98d1a..840ef1a579c998 100644 --- a/pkgs/by-name/gi/github-release/package.nix +++ b/pkgs/by-name/gi/github-release/package.nix @@ -1,4 +1,10 @@ -{ buildGoModule, fetchFromGitHub, lib, testers, github-release }: +{ + buildGoModule, + fetchFromGitHub, + lib, + testers, + github-release, +}: buildGoModule rec { pname = "github-release"; @@ -31,7 +37,10 @@ buildGoModule rec { license = licenses.mit; homepage = "https://github.com/github-release/github-release"; - maintainers = with maintainers; [ ardumont j03 ]; + maintainers = with maintainers; [ + ardumont + j03 + ]; platforms = with platforms; unix; }; } diff --git a/pkgs/by-name/gi/gitit/package.nix b/pkgs/by-name/gi/gitit/package.nix index 6958e1e6c59c2c..9d874e817483ba 100644 --- a/pkgs/by-name/gi/gitit/package.nix +++ b/pkgs/by-name/gi/gitit/package.nix @@ -1,10 +1,14 @@ -{ lib, stdenv, haskellPackages, haskell -# “Plugins” are a fancy way of saying gitit will invoke -# GHC at *runtime*, which in turn makes it pull GHC -# into its runtime closure. Only enable if you really need -# that feature. But if you do you’ll want to use gitit -# as a library anyway. -, pluginSupport ? false +{ + lib, + stdenv, + haskellPackages, + haskell, + # “Plugins” are a fancy way of saying gitit will invoke + # GHC at *runtime*, which in turn makes it pull GHC + # into its runtime closure. Only enable if you really need + # that feature. But if you do you’ll want to use gitit + # as a library anyway. + pluginSupport ? false, }: let @@ -13,14 +17,15 @@ let disableCabalFlag justStaticExecutables overrideCabal - ; + ; - base = (if pluginSupport then enableCabalFlag else disableCabalFlag) - "plugins" - haskellPackages.gitit; + base = + (if pluginSupport then enableCabalFlag else disableCabalFlag) "plugins" + haskellPackages.gitit; # Removes erroneous references from dead code that GHC can't eliminate - aarch64DarwinFix = overrideCabal (drv: + aarch64DarwinFix = overrideCabal ( + drv: lib.optionalAttrs (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) { postInstall = '' ${drv.postInstall or ""} @@ -31,12 +36,14 @@ let remove-references-to -t ${haskellPackages.pandoc} "$out/bin/gitit" remove-references-to -t ${haskellPackages.pandoc-types} "$out/bin/gitit" ''; - }); + } + ); in -if pluginSupport -then base -else lib.pipe (base.override { ghc-paths = null; }) [ - justStaticExecutables - aarch64DarwinFix -] +if pluginSupport then + base +else + lib.pipe (base.override { ghc-paths = null; }) [ + justStaticExecutables + aarch64DarwinFix + ] diff --git a/pkgs/by-name/gi/gitjacker/package.nix b/pkgs/by-name/gi/gitjacker/package.nix index 83e8b91f8b28e7..a438550c4a5ce3 100644 --- a/pkgs/by-name/gi/gitjacker/package.nix +++ b/pkgs/by-name/gi/gitjacker/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, git -, stdenv +{ + lib, + buildGoModule, + fetchFromGitHub, + git, + stdenv, }: buildGoModule rec { diff --git a/pkgs/by-name/gi/gitlab-ci-local/package.nix b/pkgs/by-name/gi/gitlab-ci-local/package.nix index 9eedc4178114a0..a495b9e278d88d 100644 --- a/pkgs/by-name/gi/gitlab-ci-local/package.nix +++ b/pkgs/by-name/gi/gitlab-ci-local/package.nix @@ -1,9 +1,10 @@ -{ buildNpmPackage -, fetchFromGitHub -, lib -, nix-update-script -, gitlab-ci-local -, testers +{ + buildNpmPackage, + fetchFromGitHub, + lib, + nix-update-script, + gitlab-ci-local, + testers, }: buildNpmPackage rec { @@ -32,7 +33,7 @@ buildNpmPackage rec { }; }; - meta = with lib;{ + meta = with lib; { description = "Run gitlab pipelines locally as shell executor or docker executor"; mainProgram = "gitlab-ci-local"; longDescription = '' diff --git a/pkgs/by-name/gi/gitlab-clippy/package.nix b/pkgs/by-name/gi/gitlab-clippy/package.nix index 8bdd529bb447d6..37aa54ff81eb37 100644 --- a/pkgs/by-name/gi/gitlab-clippy/package.nix +++ b/pkgs/by-name/gi/gitlab-clippy/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitLab -, rustPlatform +{ + lib, + fetchFromGitLab, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/gi/gitlab-container-registry/package.nix b/pkgs/by-name/gi/gitlab-container-registry/package.nix index 09c6477f52e151..fe3f825dbc7079 100644 --- a/pkgs/by-name/gi/gitlab-container-registry/package.nix +++ b/pkgs/by-name/gi/gitlab-container-registry/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitLab }: +{ + lib, + buildGoModule, + fetchFromGitLab, +}: buildGoModule rec { pname = "gitlab-container-registry"; diff --git a/pkgs/by-name/gi/gitlab-elasticsearch-indexer/package.nix b/pkgs/by-name/gi/gitlab-elasticsearch-indexer/package.nix index 43b5220fc15cf3..744fc4dd536168 100644 --- a/pkgs/by-name/gi/gitlab-elasticsearch-indexer/package.nix +++ b/pkgs/by-name/gi/gitlab-elasticsearch-indexer/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitLab, pkg-config, icu }: +{ + lib, + buildGoModule, + fetchFromGitLab, + pkg-config, + icu, +}: buildGoModule rec { pname = "gitlab-elasticsearch-indexer"; diff --git a/pkgs/by-name/gi/gitlab-pages/package.nix b/pkgs/by-name/gi/gitlab-pages/package.nix index e74f39a09e9e23..ab5d8a01659c04 100644 --- a/pkgs/by-name/gi/gitlab-pages/package.nix +++ b/pkgs/by-name/gi/gitlab-pages/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, lib, fetchFromGitLab }: +{ + buildGoModule, + lib, + fetchFromGitLab, +}: buildGoModule rec { pname = "gitlab-pages"; diff --git a/pkgs/by-name/gi/gitlab-shell/package.nix b/pkgs/by-name/gi/gitlab-shell/package.nix index 88e7eeaf71ded7..54492ae3306c8b 100644 --- a/pkgs/by-name/gi/gitlab-shell/package.nix +++ b/pkgs/by-name/gi/gitlab-shell/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitLab, buildGoModule, ruby, libkrb5 }: +{ + lib, + fetchFromGitLab, + buildGoModule, + ruby, + libkrb5, +}: buildGoModule rec { pname = "gitlab-shell"; @@ -12,7 +18,10 @@ buildGoModule rec { hash = "sha256-HSieVAYuqv5zYN6CMAo86s/Df17PdIXzDIZ2pM4Sqlw="; }; - buildInputs = [ ruby libkrb5 ]; + buildInputs = [ + ruby + libkrb5 + ]; patches = [ ./remove-hardcoded-locations.patch diff --git a/pkgs/by-name/gi/gitless/package.nix b/pkgs/by-name/gi/gitless/package.nix index 93014402a2ebd6..3a571c13da3f17 100644 --- a/pkgs/by-name/gi/gitless/package.nix +++ b/pkgs/by-name/gi/gitless/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -15,7 +16,6 @@ python3.pkgs.buildPythonApplication rec { hash = "sha256-XDB1i2b1reMCM6i1uK3IzTnsoLXO7jldYtNlYUo1AoQ="; }; - propagatedBuildInputs = with python3.pkgs; [ pygit2 argcomplete diff --git a/pkgs/by-name/gi/gitls/package.nix b/pkgs/by-name/gi/gitls/package.nix index 16ae8c9e6a8bcc..e03454b74a14fc 100644 --- a/pkgs/by-name/gi/gitls/package.nix +++ b/pkgs/by-name/gi/gitls/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, gitls -, fetchFromGitHub -, testers +{ + lib, + buildGoModule, + gitls, + fetchFromGitHub, + testers, }: buildGoModule rec { diff --git a/pkgs/by-name/gi/gitmoji-cli/package.nix b/pkgs/by-name/gi/gitmoji-cli/package.nix index 2534fa745cd777..d464640123310f 100644 --- a/pkgs/by-name/gi/gitmoji-cli/package.nix +++ b/pkgs/by-name/gi/gitmoji-cli/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, makeWrapper -, nodejs -, fixup-yarn-lock -, yarn -, testers +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + makeWrapper, + nodejs, + fixup-yarn-lock, + yarn, + testers, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gi/gitnr/package.nix b/pkgs/by-name/gi/gitnr/package.nix index 5d281385098346..312810b72a1ce9 100644 --- a/pkgs/by-name/gi/gitnr/package.nix +++ b/pkgs/by-name/gi/gitnr/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libxkbcommon -, openssl -, stdenv -, darwin -, wayland +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libxkbcommon, + openssl, + stdenv, + darwin, + wayland, }: rustPlatform.buildRustPackage rec { @@ -26,14 +27,17 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AppKit - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libxkbcommon - wayland - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AppKit + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libxkbcommon + wayland + ]; # requires internet access doCheck = false; @@ -43,7 +47,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/reemus-dev/gitnr"; changelog = "https://github.com/reemus-dev/gitnr/blob/${src.rev}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; mainProgram = "gitnr"; }; } diff --git a/pkgs/by-name/gi/gitnuro/package.nix b/pkgs/by-name/gi/gitnuro/package.nix index f1e6f8e2cb4aae..fcdee63e3fdc38 100644 --- a/pkgs/by-name/gi/gitnuro/package.nix +++ b/pkgs/by-name/gi/gitnuro/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, copyDesktopItems -, makeDesktopItem -, jre -, libGL +{ + lib, + stdenv, + fetchurl, + makeWrapper, + copyDesktopItems, + makeDesktopItem, + jre, + libGL, }: stdenv.mkDerivation rec { @@ -14,16 +15,17 @@ stdenv.mkDerivation rec { src = fetchurl ( if stdenv.hostPlatform.system == "x86_64-linux" then - { - url = "https://github.com/JetpackDuba/Gitnuro/releases/download/v${version}/Gitnuro-linux-x86_64-${version}.jar"; - hash = "sha256-1lwuLPR6b1+I2SWaYaVrZkMcYVRAf1R7j/AwjQf03UM="; - } + { + url = "https://github.com/JetpackDuba/Gitnuro/releases/download/v${version}/Gitnuro-linux-x86_64-${version}.jar"; + hash = "sha256-1lwuLPR6b1+I2SWaYaVrZkMcYVRAf1R7j/AwjQf03UM="; + } else if stdenv.hostPlatform.system == "aarch64-linux" then - { - url = "https://github.com/JetpackDuba/Gitnuro/releases/download/v${version}/Gitnuro-linux-arm_aarch64-${version}.jar"; - hash = "sha256-wnHW1YK4FKi5EDF/E0S+yr0tugtv3qVlCbT3+x9bM8s="; - } - else throw "Unsupported architecture: ${stdenv.hostPlatform.system}" + { + url = "https://github.com/JetpackDuba/Gitnuro/releases/download/v${version}/Gitnuro-linux-arm_aarch64-${version}.jar"; + hash = "sha256-wnHW1YK4FKi5EDF/E0S+yr0tugtv3qVlCbT3+x9bM8s="; + } + else + throw "Unsupported architecture: ${stdenv.hostPlatform.system}" ); icon = fetchurl { @@ -65,7 +67,10 @@ stdenv.mkDerivation rec { description = "A FOSS Git multiplatform client based on Compose and JGit"; homepage = "https://gitnuro.com/"; license = licenses.gpl3Plus; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; sourceProvenance = with sourceTypes; [ binaryBytecode ]; maintainers = with maintainers; [ zendo ]; mainProgram = "gitnuro"; diff --git a/pkgs/by-name/gi/gitolite/package.nix b/pkgs/by-name/gi/gitolite/package.nix index df0c7597603211..0a4b4b9a2df652 100644 --- a/pkgs/by-name/gi/gitolite/package.nix +++ b/pkgs/by-name/gi/gitolite/package.nix @@ -1,4 +1,14 @@ -{ stdenv, coreutils, fetchFromGitHub, git, lib, makeWrapper, nettools, perl, nixosTests }: +{ + stdenv, + coreutils, + fetchFromGitHub, + git, + lib, + makeWrapper, + nettools, + perl, + nixosTests, +}: stdenv.mkDerivation rec { pname = "gitolite"; @@ -11,7 +21,10 @@ stdenv.mkDerivation rec { hash = "sha256-/VBu+aepIrxWc2padPa/WoXbIdKfIwqmA/M8d1GE5FI="; }; - buildInputs = [ nettools perl ]; + buildInputs = [ + nettools + perl + ]; nativeBuildInputs = [ makeWrapper ]; propagatedBuildInputs = [ git ]; @@ -31,7 +44,12 @@ stdenv.mkDerivation rec { postFixup = '' wrapProgram $out/bin/gitolite-shell \ - --prefix PATH : ${lib.makeBinPath [ git (perl.withPackages (p: [ p.JSON ])) ]} + --prefix PATH : ${ + lib.makeBinPath [ + git + (perl.withPackages (p: [ p.JSON ])) + ] + } ''; installPhase = '' @@ -46,9 +64,13 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Finely-grained git repository hosting"; - homepage = "https://gitolite.com/gitolite/index.html"; - license = licenses.gpl2; - platforms = platforms.unix; - maintainers = [ maintainers.thoughtpolice maintainers.lassulus maintainers.tomberek ]; + homepage = "https://gitolite.com/gitolite/index.html"; + license = licenses.gpl2; + platforms = platforms.unix; + maintainers = [ + maintainers.thoughtpolice + maintainers.lassulus + maintainers.tomberek + ]; }; } diff --git a/pkgs/by-name/gi/gitrs/package.nix b/pkgs/by-name/gi/gitrs/package.nix index 99139437b4a7ce..bec55dbbca680b 100644 --- a/pkgs/by-name/gi/gitrs/package.nix +++ b/pkgs/by-name/gi/gitrs/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, openssl -, pkg-config -, libiconv -, darwin -, rustPlatform +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + pkg-config, + libiconv, + darwin, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -25,12 +26,13 @@ rustPlatform.buildRustPackage rec { pkg-config # for openssl ]; - buildInputs = [ openssl.dev ] + buildInputs = + [ openssl.dev ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + libiconv + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; meta = with lib; { description = "Simple, opinionated, tool, written in Rust, for declaratively managing Git repos on your machine"; diff --git a/pkgs/by-name/gi/gitsign/package.nix b/pkgs/by-name/gi/gitsign/package.nix index 3ff679c9ae370d..9bf36e61a665d6 100644 --- a/pkgs/by-name/gi/gitsign/package.nix +++ b/pkgs/by-name/gi/gitsign/package.nix @@ -1,4 +1,12 @@ -{ lib, buildGoModule, fetchFromGitHub, makeWrapper, gitMinimal, testers, gitsign }: +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + gitMinimal, + testers, + gitsign, +}: buildGoModule rec { pname = "gitsign"; @@ -20,7 +28,11 @@ buildGoModule rec { nativeBuildInputs = [ makeWrapper ]; nativeCheckInputs = [ gitMinimal ]; - ldflags = [ "-s" "-w" "-X github.com/sigstore/gitsign/pkg/version.gitVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/sigstore/gitsign/pkg/version.gitVersion=${version}" + ]; preCheck = '' # test all paths @@ -40,7 +52,10 @@ buildGoModule rec { changelog = "https://github.com/sigstore/gitsign/releases/tag/v${version}"; description = "Keyless Git signing using Sigstore"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ lesuisse developer-guy ]; + maintainers = with lib.maintainers; [ + lesuisse + developer-guy + ]; mainProgram = "gitsign"; }; } diff --git a/pkgs/by-name/gi/gitstats/package.nix b/pkgs/by-name/gi/gitstats/package.nix index 25fcd7247c2202..499338076df8f4 100644 --- a/pkgs/by-name/gi/gitstats/package.nix +++ b/pkgs/by-name/gi/gitstats/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, installShellFiles -, perl -, python3 -, gnuplot -, coreutils -, gnugrep +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + installShellFiles, + perl, + python3, + gnuplot, + coreutils, + gnugrep, }: stdenv.mkDerivation rec { @@ -32,7 +33,10 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ installShellFiles perl ]; + nativeBuildInputs = [ + installShellFiles + perl + ]; buildInputs = [ python3 ]; diff --git a/pkgs/by-name/gi/gittuf/package.nix b/pkgs/by-name/gi/gittuf/package.nix index a8035b0e7e373b..b842bf7bd9bcf6 100644 --- a/pkgs/by-name/gi/gittuf/package.nix +++ b/pkgs/by-name/gi/gittuf/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildGoModule, git, openssh }: +{ + lib, + fetchFromGitHub, + buildGoModule, + git, + openssh, +}: buildGoModule rec { pname = "gittuf"; @@ -15,8 +21,14 @@ buildGoModule rec { ldflags = [ "-X github.com/gittuf/gittuf/internal/version.gitVersion=${version}" ]; - nativeCheckInputs = [ git openssh ]; - checkFlags = [ "-skip=TestLoadRepository" "-skip=TestSSH" ]; + nativeCheckInputs = [ + git + openssh + ]; + checkFlags = [ + "-skip=TestLoadRepository" + "-skip=TestSSH" + ]; postInstall = "rm $out/bin/cli"; # remove gendoc cli binary diff --git a/pkgs/by-name/gi/gitty/package.nix b/pkgs/by-name/gi/gitty/package.nix index ba677b2ba8e54b..f077396684d6df 100644 --- a/pkgs/by-name/gi/gitty/package.nix +++ b/pkgs/by-name/gi/gitty/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "gitty"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-qrLECQkjXH0aTHmysq64jnXj9jgbunpVtBAIXJOEYIY="; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; meta = with lib; { homepage = "https://github.com/muesli/gitty/"; diff --git a/pkgs/by-name/gi/gitu/package.nix b/pkgs/by-name/gi/gitu/package.nix index 8985cd349fd5b7..ab321069916176 100644 --- a/pkgs/by-name/gi/gitu/package.nix +++ b/pkgs/by-name/gi/gitu/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libgit2 -, openssl -, zlib -, stdenv -, darwin -, git +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libgit2, + openssl, + zlib, + stdenv, + darwin, + git, }: rustPlatform.buildRustPackage rec { @@ -27,14 +28,16 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - libgit2 - openssl - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AppKit - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + libgit2 + openssl + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AppKit + darwin.apple_sdk.frameworks.Security + ]; nativeCheckInputs = [ git diff --git a/pkgs/by-name/gi/gitui/package.nix b/pkgs/by-name/gi/gitui/package.nix index df3adcb0e39f64..4eaa81d68fa87c 100644 --- a/pkgs/by-name/gi/gitui/package.nix +++ b/pkgs/by-name/gi/gitui/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, libiconv -, openssl -, pkg-config -, xclip -, darwin +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + libiconv, + openssl, + pkg-config, + xclip, + darwin, }: rustPlatform.buildRustPackage rec { @@ -24,13 +25,14 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] + buildInputs = + [ openssl ] ++ lib.optional stdenv.hostPlatform.isLinux xclip ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.AppKit - ]; + libiconv + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.AppKit + ]; postPatch = '' # The cargo config overrides linkers for some targets, breaking the build @@ -58,6 +60,10 @@ rustPlatform.buildRustPackage rec { changelog = "https://github.com/extrawurst/gitui/blob/v${version}/CHANGELOG.md"; mainProgram = "gitui"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ Br1ght0ne yanganto mfrw ]; + maintainers = with lib.maintainers; [ + Br1ght0ne + yanganto + mfrw + ]; }; } diff --git a/pkgs/by-name/gi/gitversion/package.nix b/pkgs/by-name/gi/gitversion/package.nix index 3c59f26860e7dc..90a184cc8be90b 100644 --- a/pkgs/by-name/gi/gitversion/package.nix +++ b/pkgs/by-name/gi/gitversion/package.nix @@ -1,5 +1,6 @@ -{ lib -, buildDotnetGlobalTool +{ + lib, + buildDotnetGlobalTool, }: buildDotnetGlobalTool rec { diff --git a/pkgs/by-name/gi/gitweb/package.nix b/pkgs/by-name/gi/gitweb/package.nix index f2cb91ac4f838e..03faec14bb63eb 100644 --- a/pkgs/by-name/gi/gitweb/package.nix +++ b/pkgs/by-name/gi/gitweb/package.nix @@ -1,5 +1,10 @@ -{ lib, buildEnv, git, fetchFromGitHub -, gitwebTheme ? false }: +{ + lib, + buildEnv, + git, + fetchFromGitHub, + gitwebTheme ? false, +}: let gitwebThemeSrc = fetchFromGitHub { @@ -14,12 +19,12 @@ let ''; sha256 = "17hypq6jvhy6zhh26lp3nyi52npfd5wy5752k6sq0shk4na2acqi"; }; -in buildEnv { +in +buildEnv { name = "gitweb-${lib.getVersion git}"; ignoreCollisions = true; - paths = lib.optional gitwebTheme gitwebThemeSrc - ++ [ "${git}/share/gitweb" ]; + paths = lib.optional gitwebTheme gitwebThemeSrc ++ [ "${git}/share/gitweb" ]; meta = git.meta // { maintainers = [ ]; diff --git a/pkgs/by-name/gj/gjay/package.nix b/pkgs/by-name/gj/gjay/package.nix index 514db23fdb4e9a..b58e8ba492e8a5 100644 --- a/pkgs/by-name/gj/gjay/package.nix +++ b/pkgs/by-name/gj/gjay/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, dbus-glib -, audacious -, gtk2 -, gsl -, libaudclient -, libmpdclient +{ + lib, + stdenv, + fetchurl, + pkg-config, + dbus-glib, + audacious, + gtk2, + gsl, + libaudclient, + libmpdclient, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gj/gjo/package.nix b/pkgs/by-name/gj/gjo/package.nix index d7fcd3a0845a69..cdb84410bf1882 100644 --- a/pkgs/by-name/gj/gjo/package.nix +++ b/pkgs/by-name/gj/gjo/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/gj/gjs/package.nix b/pkgs/by-name/gj/gjs/package.nix index d2c90bcff1a525..55342995339ddd 100644 --- a/pkgs/by-name/gj/gjs/package.nix +++ b/pkgs/by-name/gj/gjs/package.nix @@ -1,40 +1,51 @@ -{ fetchurl -, lib -, stdenv -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, gnome -, gtk3 -, atk -, gobject-introspection -, spidermonkey_128 -, pango -, cairo -, readline -, libsysprof-capture -, glib -, libxml2 -, dbus -, gdk-pixbuf -, harfbuzz -, makeWrapper -, which -, xvfb-run -, nixosTests -, installTests ? true +{ + fetchurl, + lib, + stdenv, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + gnome, + gtk3, + atk, + gobject-introspection, + spidermonkey_128, + pango, + cairo, + readline, + libsysprof-capture, + glib, + libxml2, + dbus, + gdk-pixbuf, + harfbuzz, + makeWrapper, + which, + xvfb-run, + nixosTests, + installTests ? true, }: let testDeps = [ - gtk3 atk pango.out gdk-pixbuf harfbuzz glib.out + gtk3 + atk + pango.out + gdk-pixbuf + harfbuzz + glib.out ]; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "gjs"; version = "1.82.1"; - outputs = [ "out" "dev" "installedTests" ]; + outputs = [ + "out" + "dev" + "installedTests" + ]; src = fetchurl { url = "mirror://gnome/sources/gjs/${lib.versions.majorMinor finalAttrs.version}/gjs-${finalAttrs.version}.tar.xz"; @@ -53,18 +64,20 @@ in stdenv.mkDerivation (finalAttrs: { ./disable-introspection-test.patch ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - makeWrapper - which # for locale detection - libxml2 # for xml-stripblanks - dbus # for dbus-run-session - gobject-introspection - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + makeWrapper + which # for locale detection + libxml2 # for xml-stripblanks + dbus # for dbus-run-session + gobject-introspection + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ cairo @@ -81,21 +94,25 @@ in stdenv.mkDerivation (finalAttrs: { glib ]; - mesonFlags = [ - "-Dinstalled_test_prefix=${placeholder "installedTests"}" - ] ++ lib.optionals (!stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isMusl) [ - "-Dprofiler=disabled" - ]; + mesonFlags = + [ + "-Dinstalled_test_prefix=${placeholder "installedTests"}" + ] + ++ lib.optionals (!stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isMusl) [ + "-Dprofiler=disabled" + ]; doCheck = !stdenv.hostPlatform.isDarwin; - postPatch = '' - patchShebangs build/choose-tests-locale.sh - substituteInPlace installed-tests/debugger-test.sh --subst-var-by gjsConsole $out/bin/gjs-console - '' + lib.optionalString stdenv.hostPlatform.isMusl '' - substituteInPlace installed-tests/js/meson.build \ - --replace "'Encoding'," "#'Encoding'," - ''; + postPatch = + '' + patchShebangs build/choose-tests-locale.sh + substituteInPlace installed-tests/debugger-test.sh --subst-var-by gjsConsole $out/bin/gjs-console + '' + + lib.optionalString stdenv.hostPlatform.isMusl '' + substituteInPlace installed-tests/js/meson.build \ + --replace "'Encoding'," "#'Encoding'," + ''; preCheck = '' # Our gobject-introspection patches make the shared library paths absolute diff --git a/pkgs/by-name/gl/gl117/package.nix b/pkgs/by-name/gl/gl117/package.nix index 5ba29fa49af3e6..ca1990d21b2e5a 100644 --- a/pkgs/by-name/gl/gl117/package.nix +++ b/pkgs/by-name/gl/gl117/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchurl -, libGLU, libGL, SDL, libglut, SDL_mixer, autoconf, automake, libtool +{ + lib, + stdenv, + fetchurl, + libGLU, + libGL, + SDL, + libglut, + SDL_mixer, + autoconf, + automake, + libtool, }: stdenv.mkDerivation rec { @@ -11,8 +21,18 @@ stdenv.mkDerivation rec { sha256 = "1yvg1rp1yijv0b45cz085b29x5x0g5fkm654xdv5qwh2l6803gb4"; }; - nativeBuildInputs = [ automake autoconf ]; - buildInputs = [ libGLU libGL SDL libglut SDL_mixer libtool ]; + nativeBuildInputs = [ + automake + autoconf + ]; + buildInputs = [ + libGLU + libGL + SDL + libglut + SDL_mixer + libtool + ]; meta = with lib; { description = "Air combat simulator"; diff --git a/pkgs/by-name/gl/gl2ps/package.nix b/pkgs/by-name/gl/gl2ps/package.nix index eec23cef70bce4..6838bccacc0a98 100644 --- a/pkgs/by-name/gl/gl2ps/package.nix +++ b/pkgs/by-name/gl/gl2ps/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, cmake -, zlib -, libpng -, libGL -, libGLU -, libglut -, darwin +{ + lib, + stdenv, + fetchurl, + cmake, + zlib, + libpng, + libGL, + libGLU, + libglut, + darwin, }: stdenv.mkDerivation rec { @@ -23,22 +24,28 @@ stdenv.mkDerivation rec { cmake ]; - buildInputs = [ - zlib - libpng - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - libGL - libGLU - libglut - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.OpenGL - ]; + buildInputs = + [ + zlib + libpng + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libGL + libGLU + libglut + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.OpenGL + ]; meta = with lib; { homepage = "http://geuz.org/gl2ps"; description = "OpenGL to PostScript printing library"; platforms = platforms.all; license = licenses.lgpl2; - maintainers = with maintainers; [ raskin twhitehead ]; + maintainers = with maintainers; [ + raskin + twhitehead + ]; }; } diff --git a/pkgs/by-name/gl/gl3w/package.nix b/pkgs/by-name/gl/gl3w/package.nix index c12ab1f22a8f62..eb4a0be8d4f3d8 100644 --- a/pkgs/by-name/gl/gl3w/package.nix +++ b/pkgs/by-name/gl/gl3w/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, python3, cmake, libglvnd, libGLU, unstableGitUpdater }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + cmake, + libglvnd, + libGLU, + unstableGitUpdater, +}: stdenv.mkDerivation rec { pname = "gl3w"; @@ -11,11 +20,17 @@ stdenv.mkDerivation rec { hash = "sha256-kEm5QItpasSFJQ32YBHPpc+itz/nQ8bQMCavbOTGT/w="; }; - nativeBuildInputs = [ python3 cmake ]; + nativeBuildInputs = [ + python3 + cmake + ]; # gl3w installs a CMake config that when included expects to be able to # build and link against both of these libraries # (the gl3w generated C file gets compiled into the downstream target) - propagatedBuildInputs = [ libglvnd libGLU ]; + propagatedBuildInputs = [ + libglvnd + libGLU + ]; dontUseCmakeBuildDir = true; diff --git a/pkgs/by-name/gl/glabels/package.nix b/pkgs/by-name/gl/glabels/package.nix index f5e026c75b7115..04453acfb02850 100644 --- a/pkgs/by-name/gl/glabels/package.nix +++ b/pkgs/by-name/gl/glabels/package.nix @@ -1,6 +1,25 @@ -{ lib, stdenv, fetchurl, fetchpatch, barcode, gnome, gnome-common, autoreconfHook -, gtk3, gtk-doc, libxml2, librsvg , libtool, libe-book, gsettings-desktop-schemas -, intltool, itstool, makeWrapper, pkg-config, yelp-tools, qrencode +{ + lib, + stdenv, + fetchurl, + fetchpatch, + barcode, + gnome, + gnome-common, + autoreconfHook, + gtk3, + gtk-doc, + libxml2, + librsvg, + libtool, + libe-book, + gsettings-desktop-schemas, + intltool, + itstool, + makeWrapper, + pkg-config, + yelp-tools, + qrencode, }: stdenv.mkDerivation rec { @@ -22,11 +41,25 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config makeWrapper intltool ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + makeWrapper + intltool + ]; buildInputs = [ - barcode gtk3 gtk-doc yelp-tools - gnome-common gsettings-desktop-schemas - itstool libxml2 librsvg libe-book libtool qrencode + barcode + gtk3 + gtk-doc + yelp-tools + gnome-common + gsettings-desktop-schemas + itstool + libxml2 + librsvg + libe-book + libtool + qrencode ]; preFixup = '' @@ -44,7 +77,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Create labels and business cards"; homepage = "https://github.com/jimevins/glabels"; - license = with licenses; [ gpl3Plus lgpl3Plus ]; + license = with licenses; [ + gpl3Plus + lgpl3Plus + ]; platforms = platforms.unix; maintainers = [ maintainers.nico202 ]; }; diff --git a/pkgs/by-name/gl/glade/package.nix b/pkgs/by-name/gl/glade/package.nix index 2658cbe241fe62..e0332d691ca284 100644 --- a/pkgs/by-name/gl/glade/package.nix +++ b/pkgs/by-name/gl/glade/package.nix @@ -1,27 +1,28 @@ -{ stdenv -, lib -, gettext -, fetchurl -, python3 -, meson -, ninja -, pkg-config -, gtk3 -, glib -, gjs -, enableWebkit2gtk ? stdenv.hostPlatform.isLinux -, webkitgtk_4_1 -, gobject-introspection -, wrapGAppsHook3 -, itstool -, libxml2 -, docbook-xsl-nons -, docbook_xml_dtd_42 -, gnome -, adwaita-icon-theme -, gdk-pixbuf -, libxslt -, gsettings-desktop-schemas +{ + stdenv, + lib, + gettext, + fetchurl, + python3, + meson, + ninja, + pkg-config, + gtk3, + glib, + gjs, + enableWebkit2gtk ? stdenv.hostPlatform.isLinux, + webkitgtk_4_1, + gobject-introspection, + wrapGAppsHook3, + itstool, + libxml2, + docbook-xsl-nons, + docbook_xml_dtd_42, + gnome, + adwaita-icon-theme, + gdk-pixbuf, + libxslt, + gsettings-desktop-schemas, }: stdenv.mkDerivation rec { @@ -47,19 +48,21 @@ stdenv.mkDerivation rec { gobject-introspection ]; - buildInputs = [ - gtk3 - glib - gjs - libxml2 - python3 - python3.pkgs.pygobject3 - gsettings-desktop-schemas - gdk-pixbuf - adwaita-icon-theme - ] ++ lib.optionals enableWebkit2gtk [ - webkitgtk_4_1 - ]; + buildInputs = + [ + gtk3 + glib + gjs + libxml2 + python3 + python3.pkgs.pygobject3 + gsettings-desktop-schemas + gdk-pixbuf + adwaita-icon-theme + ] + ++ lib.optionals enableWebkit2gtk [ + webkitgtk_4_1 + ]; mesonFlags = [ (lib.mesonEnable "webkit2gtk" enableWebkit2gtk) diff --git a/pkgs/by-name/gl/gladtex/package.nix b/pkgs/by-name/gl/gladtex/package.nix index bf64f400d2b8de..06827fb8a5b28a 100644 --- a/pkgs/by-name/gl/gladtex/package.nix +++ b/pkgs/by-name/gl/gladtex/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3Packages +{ + lib, + fetchFromGitHub, + python3Packages, }: python3Packages.buildPythonPackage rec { diff --git a/pkgs/by-name/gl/glamoroustoolkit/package.nix b/pkgs/by-name/gl/glamoroustoolkit/package.nix index f28c8228372299..345ebe83d10e24 100644 --- a/pkgs/by-name/gl/glamoroustoolkit/package.nix +++ b/pkgs/by-name/gl/glamoroustoolkit/package.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, fetchzip -, fetchurl -, patchelf -, wrapGAppsHook3 -, cairo -, dbus -, fontconfig -, freetype -, glib -, gtk3 -, libX11 -, libXcursor -, libXext -, libXi -, libXrandr -, libXrender -, libgit2 -, libglvnd -, libuuid -, libxcb -, harfbuzz -, libsoup_3 -, webkitgtk_4_1 -, zenity +{ + lib, + stdenv, + fetchzip, + fetchurl, + patchelf, + wrapGAppsHook3, + cairo, + dbus, + fontconfig, + freetype, + glib, + gtk3, + libX11, + libXcursor, + libXext, + libXi, + libXrandr, + libXrender, + libgit2, + libglvnd, + libuuid, + libxcb, + harfbuzz, + libsoup_3, + webkitgtk_4_1, + zenity, }: stdenv.mkDerivation (finalAttrs: { @@ -57,63 +58,65 @@ stdenv.mkDerivation (finalAttrs: { runHook postInstall ''; - preFixup = let - libPath = lib.makeLibraryPath [ - cairo - dbus - fontconfig - freetype - glib - gtk3 - libX11 - libXcursor - libXext - libXi - libXrandr - libXrender - libglvnd - libuuid - libxcb - harfbuzz # libWebView.so - libsoup_3 # libWebView.so - webkitgtk_4_1 # libWebView.so - (lib.getLib stdenv.cc.cc) - ]; - binPath = lib.makeBinPath [ - zenity # File selection dialog - ]; - in '' - chmod +x $out/lib/*.so - patchelf \ - --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath "${libPath}:$out/lib" \ - $out/bin/GlamorousToolkit $out/bin/GlamorousToolkit-cli - patchelf --shrink-rpath \ - $out/bin/GlamorousToolkit $out/bin/GlamorousToolkit-cli - patchelf \ - --set-rpath "${libPath}:$out/lib" \ - $out/lib/*.so - patchelf --shrink-rpath $out/lib/*.so - # - # shrink-rpath gets it wrong for the following libraries, - # restore the full rpath. - # - patchelf \ - --set-rpath "${libPath}:$out/lib" \ - $out/lib/libPharoVMCore.so \ - $out/lib/libWinit.so \ - $out/lib/libPixels.so - patchelf --set-rpath $out/lib $out/lib/libssl.so + preFixup = + let + libPath = lib.makeLibraryPath [ + cairo + dbus + fontconfig + freetype + glib + gtk3 + libX11 + libXcursor + libXext + libXi + libXrandr + libXrender + libglvnd + libuuid + libxcb + harfbuzz # libWebView.so + libsoup_3 # libWebView.so + webkitgtk_4_1 # libWebView.so + (lib.getLib stdenv.cc.cc) + ]; + binPath = lib.makeBinPath [ + zenity # File selection dialog + ]; + in + '' + chmod +x $out/lib/*.so + patchelf \ + --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ + --set-rpath "${libPath}:$out/lib" \ + $out/bin/GlamorousToolkit $out/bin/GlamorousToolkit-cli + patchelf --shrink-rpath \ + $out/bin/GlamorousToolkit $out/bin/GlamorousToolkit-cli + patchelf \ + --set-rpath "${libPath}:$out/lib" \ + $out/lib/*.so + patchelf --shrink-rpath $out/lib/*.so + # + # shrink-rpath gets it wrong for the following libraries, + # restore the full rpath. + # + patchelf \ + --set-rpath "${libPath}:$out/lib" \ + $out/lib/libPharoVMCore.so \ + $out/lib/libWinit.so \ + $out/lib/libPixels.so + patchelf --set-rpath $out/lib $out/lib/libssl.so - ln -s $out/lib/libcrypto.so $out/lib/libcrypto.so.1.1 - ln -s $out/lib/libcairo.so $out/lib/libcairo.so.2 - rm $out/lib/libgit2.so - ln -s "${libgit2}/lib/libgit2.so" $out/lib/libgit2.so.1.1 + ln -s $out/lib/libcrypto.so $out/lib/libcrypto.so.1.1 + ln -s $out/lib/libcairo.so $out/lib/libcairo.so.2 + rm $out/lib/libgit2.so + ln -s "${libgit2}/lib/libgit2.so" $out/lib/libgit2.so.1.1 - gappsWrapperArgs+=( - --prefix PATH : ${binPath} - ) - ''; + gappsWrapperArgs+=( + --prefix PATH : ${binPath} + ) + ''; meta = { homepage = "https://gtoolkit.com"; diff --git a/pkgs/by-name/gl/glasstty-ttf/package.nix b/pkgs/by-name/gl/glasstty-ttf/package.nix index 1c64c3227c5199..a0d6ddeddb2066 100644 --- a/pkgs/by-name/gl/glasstty-ttf/package.nix +++ b/pkgs/by-name/gl/glasstty-ttf/package.nix @@ -1,18 +1,23 @@ -{ runCommand, fetchurl, lib }: -runCommand "glasstty-ttf" { - src = fetchurl { - url = "https://github.com/svofski/glasstty/raw/2c47ac1a0065f8b12d9732257993833d8227e3e5/Glass_TTY_VT220.ttf"; - sha256 = "sha256-2NYJaSWNr1Seuqdd7nLjA7tAMs/SAvl3uAe3uDoLLO4="; - }; - meta = with lib; { - maintainers = [ maintainers.pkharvey ]; - homepage = "https://github.com/svofski/glasstty"; - license = licenses.unlicense; - platforms = platforms.all; - description = "TrueType VT220 font"; - }; -} -'' - mkdir -p $out/share/fonts/truetype - cp $src $out/share/fonts/truetype/Glass_TTY_VT220.ttf -'' +{ + runCommand, + fetchurl, + lib, +}: +runCommand "glasstty-ttf" + { + src = fetchurl { + url = "https://github.com/svofski/glasstty/raw/2c47ac1a0065f8b12d9732257993833d8227e3e5/Glass_TTY_VT220.ttf"; + sha256 = "sha256-2NYJaSWNr1Seuqdd7nLjA7tAMs/SAvl3uAe3uDoLLO4="; + }; + meta = with lib; { + maintainers = [ maintainers.pkharvey ]; + homepage = "https://github.com/svofski/glasstty"; + license = licenses.unlicense; + platforms = platforms.all; + description = "TrueType VT220 font"; + }; + } + '' + mkdir -p $out/share/fonts/truetype + cp $src $out/share/fonts/truetype/Glass_TTY_VT220.ttf + '' diff --git a/pkgs/by-name/gl/glauth/package.nix b/pkgs/by-name/gl/glauth/package.nix index 00a4bbee1f1e15..8450801806565e 100644 --- a/pkgs/by-name/gl/glauth/package.nix +++ b/pkgs/by-name/gl/glauth/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, oath-toolkit -, openldap +{ + lib, + fetchFromGitHub, + buildGoModule, + oath-toolkit, + openldap, }: buildGoModule rec { @@ -44,7 +45,10 @@ buildGoModule rec { description = "Lightweight LDAP server for development, home use, or CI"; homepage = "https://github.com/glauth/glauth"; license = licenses.mit; - maintainers = with maintainers; [ bjornfor christoph-heiss ]; + maintainers = with maintainers; [ + bjornfor + christoph-heiss + ]; mainProgram = "glauth"; }; } diff --git a/pkgs/by-name/gl/glava/package.nix b/pkgs/by-name/gl/glava/package.nix index df5d6138d35f67..742fbe2a72d048 100644 --- a/pkgs/by-name/gl/glava/package.nix +++ b/pkgs/by-name/gl/glava/package.nix @@ -1,6 +1,20 @@ -{ lib, stdenv, writeScript, fetchFromGitHub -, libGL, libX11, libXext, python3, libXrandr, libXrender, libpulseaudio, libXcomposite -, enableGlfw ? false, glfw, runtimeShell }: +{ + lib, + stdenv, + writeScript, + fetchFromGitHub, + libGL, + libX11, + libXext, + python3, + libXrandr, + libXrender, + libpulseaudio, + libXcomposite, + enableGlfw ? false, + glfw, + runtimeShell, +}: let inherit (lib) optional makeLibraryPath; @@ -20,72 +34,72 @@ let esac ''; in - stdenv.mkDerivation rec { - pname = "glava"; - version = "1.6.3"; +stdenv.mkDerivation rec { + pname = "glava"; + version = "1.6.3"; - src = fetchFromGitHub { - owner = "wacossusca34"; - repo = "glava"; - rev = "v${version}"; - sha256 = "0kqkjxmpqkmgby05lsf6c6iwm45n33jk5qy6gi3zvjx4q4yzal1i"; - }; + src = fetchFromGitHub { + owner = "wacossusca34"; + repo = "glava"; + rev = "v${version}"; + sha256 = "0kqkjxmpqkmgby05lsf6c6iwm45n33jk5qy6gi3zvjx4q4yzal1i"; + }; - buildInputs = [ - libX11 - libXext - libXrandr - libXrender - libpulseaudio - libXcomposite - ] ++ optional enableGlfw glfw; + buildInputs = [ + libX11 + libXext + libXrandr + libXrender + libpulseaudio + libXcomposite + ] ++ optional enableGlfw glfw; - nativeBuildInputs = [ - python3 - ]; + nativeBuildInputs = [ + python3 + ]; - preConfigure = '' - for f in $(find -type f);do - substituteInPlace $f \ - --replace /etc/xdg $out/etc/xdg - done + preConfigure = '' + for f in $(find -type f);do + substituteInPlace $f \ + --replace /etc/xdg $out/etc/xdg + done - substituteInPlace Makefile \ - --replace '$(DESTDIR)$(SHADERDIR)' '$(SHADERDIR)' + substituteInPlace Makefile \ + --replace '$(DESTDIR)$(SHADERDIR)' '$(SHADERDIR)' - substituteInPlace Makefile \ - --replace 'unknown' 'v${version}' - ''; + substituteInPlace Makefile \ + --replace 'unknown' 'v${version}' + ''; - makeFlags = optional (!enableGlfw) "DISABLE_GLFW=1"; + makeFlags = optional (!enableGlfw) "DISABLE_GLFW=1"; - installFlags = [ - "DESTDIR=$(out)" - ]; + installFlags = [ + "DESTDIR=$(out)" + ]; - fixupPhase = '' - mkdir -p $out/bin - mv $out/usr/bin/glava $out/bin/.glava-unwrapped - rm -rf $out/usr + fixupPhase = '' + mkdir -p $out/bin + mv $out/usr/bin/glava $out/bin/.glava-unwrapped + rm -rf $out/usr - patchelf \ - --set-rpath "$(patchelf --print-rpath $out/bin/.glava-unwrapped):${makeLibraryPath [ libGL ]}" \ - $out/bin/.glava-unwrapped + patchelf \ + --set-rpath "$(patchelf --print-rpath $out/bin/.glava-unwrapped):${makeLibraryPath [ libGL ]}" \ + $out/bin/.glava-unwrapped - substitute ${wrapperScript} $out/bin/glava --subst-var out - chmod +x $out/bin/glava - ''; + substitute ${wrapperScript} $out/bin/glava --subst-var out + chmod +x $out/bin/glava + ''; - meta = with lib; { - description = '' - OpenGL audio spectrum visualizer - ''; - mainProgram = "glava"; - homepage = "https://github.com/wacossusca34/glava"; - platforms = platforms.linux; - license = licenses.gpl3; - maintainers = with maintainers; [ - eadwu - ]; - }; - } + meta = with lib; { + description = '' + OpenGL audio spectrum visualizer + ''; + mainProgram = "glava"; + homepage = "https://github.com/wacossusca34/glava"; + platforms = platforms.linux; + license = licenses.gpl3; + maintainers = with maintainers; [ + eadwu + ]; + }; +} diff --git a/pkgs/by-name/gl/glbinding/package.nix b/pkgs/by-name/gl/glbinding/package.nix index b19a890a254504..076a5f06683d56 100644 --- a/pkgs/by-name/gl/glbinding/package.nix +++ b/pkgs/by-name/gl/glbinding/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libGLU }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libGLU, +}: stdenv.mkDerivation rec { pname = "glbinding"; diff --git a/pkgs/by-name/gl/glee/package.nix b/pkgs/by-name/gl/glee/package.nix index ec0b4ffdf79419..184d793042bfaf 100644 --- a/pkgs/by-name/gl/glee/package.nix +++ b/pkgs/by-name/gl/glee/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchgit, cmake, libGLU, libGL, xorg }: +{ + lib, + stdenv, + fetchgit, + cmake, + libGLU, + libGL, + xorg, +}: stdenv.mkDerivation rec { pname = "glee"; @@ -13,7 +21,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ libGLU libGL xorg.libX11 ]; + buildInputs = [ + libGLU + libGL + xorg.libX11 + ]; configureScript = '' cmake diff --git a/pkgs/by-name/gl/glib-networking/package.nix b/pkgs/by-name/gl/glib-networking/package.nix index d74acc063e5c0e..9bdaac3c3b4c8f 100644 --- a/pkgs/by-name/gl/glib-networking/package.nix +++ b/pkgs/by-name/gl/glib-networking/package.nix @@ -1,27 +1,31 @@ -{ stdenv -, lib -, fetchurl -, substituteAll -, meson -, ninja -, nixosTests -, pkg-config -, glib -, gettext -, makeWrapper -, gnutls -, p11-kit -, libproxy -, gnome -, gsettings-desktop-schemas -, bash +{ + stdenv, + lib, + fetchurl, + substituteAll, + meson, + ninja, + nixosTests, + pkg-config, + glib, + gettext, + makeWrapper, + gnutls, + p11-kit, + libproxy, + gnome, + gsettings-desktop-schemas, + bash, }: stdenv.mkDerivation rec { pname = "glib-networking"; version = "2.80.0"; - outputs = [ "out" "installedTests" ]; + outputs = [ + "out" + "installedTests" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/gl/glib-testing/package.nix b/pkgs/by-name/gl/glib-testing/package.nix index d77a5418a13e1d..63fa21fe38b5df 100644 --- a/pkgs/by-name/gl/glib-testing/package.nix +++ b/pkgs/by-name/gl/glib-testing/package.nix @@ -1,20 +1,27 @@ -{ lib, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_43 -, glib -, nixosTests +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_43, + glib, + nixosTests, }: stdenv.mkDerivation rec { pname = "glib-testing"; version = "0.1.1"; - outputs = [ "out" "dev" "devdoc" "installedTests" ]; + outputs = [ + "out" + "dev" + "devdoc" + "installedTests" + ]; src = fetchFromGitLab { domain = "gitlab.gnome.org"; diff --git a/pkgs/by-name/gl/glicol-cli/package.nix b/pkgs/by-name/gl/glicol-cli/package.nix index 8279bfc6b30db2..09eb57499dc6da 100644 --- a/pkgs/by-name/gl/glicol-cli/package.nix +++ b/pkgs/by-name/gl/glicol-cli/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, stdenv -, darwin -, alsa-lib +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + stdenv, + darwin, + alsa-lib, }: rustPlatform.buildRustPackage rec { @@ -25,11 +26,13 @@ rustPlatform.buildRustPackage rec { rustPlatform.bindgenHook ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AudioUnit - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AudioUnit + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + ]; meta = with lib; { description = "Cross-platform music live coding in terminal"; diff --git a/pkgs/by-name/gl/glide-media-player/package.nix b/pkgs/by-name/gl/glide-media-player/package.nix index eca436d6859138..41125d042729be 100644 --- a/pkgs/by-name/gl/glide-media-player/package.nix +++ b/pkgs/by-name/gl/glide-media-player/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, pkg-config -, meson -, ninja -, rustc -, cargo -, wrapGAppsHook4 -, python3 -, libadwaita -, graphene -, gst_all_1 -, glib-networking +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + meson, + ninja, + rustc, + cargo, + wrapGAppsHook4, + python3, + libadwaita, + graphene, + gst_all_1, + glib-networking, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gl/glider/package.nix b/pkgs/by-name/gl/glider/package.nix index 67eecb21c7b8fa..86d33e60302193 100644 --- a/pkgs/by-name/gl/glider/package.nix +++ b/pkgs/by-name/gl/glider/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "glider"; diff --git a/pkgs/by-name/gl/glitter/package.nix b/pkgs/by-name/gl/glitter/package.nix index be21abd9effb74..14e783a00be96b 100644 --- a/pkgs/by-name/gl/glitter/package.nix +++ b/pkgs/by-name/gl/glitter/package.nix @@ -1,4 +1,9 @@ -{ lib, rustPlatform, fetchFromGitHub, git }: +{ + lib, + rustPlatform, + fetchFromGitHub, + git, +}: rustPlatform.buildRustPackage rec { pname = "glitter"; @@ -23,7 +28,10 @@ rustPlatform.buildRustPackage rec { ''; # error: Found argument '--test-threads' which wasn't expected, or isn't valid in this context - checkFlags = [ "--skip" "runs_correctly" ]; + checkFlags = [ + "--skip" + "runs_correctly" + ]; meta = with lib; { description = "Git wrapper that allows you to compress multiple commands into one"; diff --git a/pkgs/by-name/gl/gllvm/package.nix b/pkgs/by-name/gl/gllvm/package.nix index 26b820f2642555..6b983cd21ef319 100644 --- a/pkgs/by-name/gl/gllvm/package.nix +++ b/pkgs/by-name/gl/gllvm/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, llvmPackages, getconf }: +{ + lib, + buildGoModule, + fetchFromGitHub, + llvmPackages, + getconf, +}: buildGoModule { pname = "gllvm"; @@ -13,10 +19,13 @@ buildGoModule { vendorHash = null; - nativeCheckInputs = with llvmPackages; [ - clang - llvm - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ getconf ]; + nativeCheckInputs = + with llvmPackages; + [ + clang + llvm + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ getconf ]; meta = with lib; { homepage = "https://github.com/SRI-CSL/gllvm"; diff --git a/pkgs/by-name/gl/glm/package.nix b/pkgs/by-name/gl/glm/package.nix index 3894db5ab9c813..675d215cb8633f 100644 --- a/pkgs/by-name/gl/glm/package.nix +++ b/pkgs/by-name/gl/glm/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { @@ -15,16 +16,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-GnGyzNRpzuguc3yYbEFtYLvG+KiCtRAktiN+NvbOICE="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; nativeBuildInputs = [ cmake ]; env.NIX_CFLAGS_COMPILE = # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=102823 - if (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "11") then "-fno-ipa-modref" + if (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "11") then + "-fno-ipa-modref" # Fix compilation errors on darwin - else if (stdenv.cc.isClang) then "-Wno-error" - else ""; + else if (stdenv.cc.isClang) then + "-Wno-error" + else + ""; cmakeFlags = [ (lib.cmakeBool "BUILD_SHARED_LIBS" false) @@ -58,4 +65,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ smancill ]; }; } - diff --git a/pkgs/by-name/gl/glmark2/package.nix b/pkgs/by-name/gl/glmark2/package.nix index cbfdeb22fbcc3d..607a7e3a9a6db3 100644 --- a/pkgs/by-name/gl/glmark2/package.nix +++ b/pkgs/by-name/gl/glmark2/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, makeWrapper -, meson -, ninja -, wayland-scanner -, libjpeg -, libpng -, libX11 -, libGL -, libdrm -, udev -, wayland -, wayland-protocols -, mesa +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + makeWrapper, + meson, + ninja, + wayland-scanner, + libjpeg, + libpng, + libX11, + libGL, + libdrm, + udev, + wayland, + wayland-protocols, + mesa, }: stdenv.mkDerivation rec { @@ -29,7 +30,13 @@ stdenv.mkDerivation rec { }; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ pkg-config makeWrapper meson ninja wayland-scanner ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + meson + ninja + wayland-scanner + ]; buildInputs = [ libjpeg libpng @@ -41,7 +48,9 @@ stdenv.mkDerivation rec { mesa ]; - mesonFlags = [ "-Dflavors=drm-gl,drm-glesv2,gbm-gl,gbm-glesv2,wayland-gl,wayland-glesv2,x11-gl,x11-gl-egl,x11-glesv2" ]; + mesonFlags = [ + "-Dflavors=drm-gl,drm-glesv2,gbm-gl,gbm-glesv2,wayland-gl,wayland-glesv2,x11-gl,x11-gl-egl,x11-glesv2" + ]; postInstall = '' for binary in $out/bin/glmark2*; do diff --git a/pkgs/by-name/gl/global-platform-pro/package.nix b/pkgs/by-name/gl/global-platform-pro/package.nix index 4a55908214c6f4..4c16e4a67f3e65 100644 --- a/pkgs/by-name/gl/global-platform-pro/package.nix +++ b/pkgs/by-name/gl/global-platform-pro/package.nix @@ -1,11 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, jdk11, maven, makeWrapper, jre_headless, pcsclite, proot, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + jdk11, + maven, + makeWrapper, + jre_headless, + pcsclite, + proot, + zlib, +}: let defineMvnWrapper = '' mvn() { # One of the deps that are downloaded and run needs zlib. - export LD_LIBRARY_PATH="${lib.makeLibraryPath [zlib]}" + export LD_LIBRARY_PATH="${lib.makeLibraryPath [ zlib ]}" # Give access to ELF interpreter under FHS path, to be able to run # prebuilt binaries. "${lib.getExe proot}" -b "${stdenv.cc.libc}/lib:/lib64" mvn "$@" @@ -27,7 +38,10 @@ maven.buildMavenPackage rec { mvnJdk = jdk11; mvnHash = "sha256-vTlOxFBjEZRD23ldMF+VRKZx6jyZ6YvgvZM353FWrWQ="; - nativeBuildInputs = [ jdk11 makeWrapper ]; + nativeBuildInputs = [ + jdk11 + makeWrapper + ]; # Fix build error due to missing .git directory: # Failed to execute goal pl.project13.maven:git-commit-id-plugin:4.0.0:revision (retrieve-git-info) on project gppro: .git directory is not found! Please specify a valid [dotGitDirectory] in your pom.xml -> [Help 1] diff --git a/pkgs/by-name/gl/global/package.nix b/pkgs/by-name/gl/global/package.nix index 7f3d79f6a3d78c..a5b84aa3a5bdb6 100644 --- a/pkgs/by-name/gl/global/package.nix +++ b/pkgs/by-name/gl/global/package.nix @@ -1,10 +1,21 @@ -{ fetchurl, lib, stdenv, libtool, makeWrapper -, coreutils, ctags, ncurses, python3Packages, sqlite, universal-ctags +{ + fetchurl, + lib, + stdenv, + libtool, + makeWrapper, + coreutils, + ctags, + ncurses, + python3Packages, + sqlite, + universal-ctags, }: let pygments = python3Packages.pygments; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "global"; version = "6.6.13"; @@ -13,9 +24,15 @@ in stdenv.mkDerivation rec { hash = "sha256-lF80lzDaAfd4VNmBHKj4AWaclGE5WimWbY2Iy2cDNHs="; }; - nativeBuildInputs = [ libtool makeWrapper ]; + nativeBuildInputs = [ + libtool + makeWrapper + ]; - buildInputs = [ ncurses sqlite ]; + buildInputs = [ + ncurses + sqlite + ]; propagatedBuildInputs = [ pygments ]; @@ -55,8 +72,13 @@ in stdenv.mkDerivation rec { ''; homepage = "https://www.gnu.org/software/global/"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ pSub peterhoeg ]; + maintainers = with maintainers; [ + pSub + peterhoeg + ]; platforms = platforms.unix; - changelog = "https://cvs.savannah.gnu.org/viewvc/global/global/NEWS?view=markup&pathrev=VERSION-${lib.replaceStrings [ "." ] [ "_" ] version}"; + changelog = "https://cvs.savannah.gnu.org/viewvc/global/global/NEWS?view=markup&pathrev=VERSION-${ + lib.replaceStrings [ "." ] [ "_" ] version + }"; }; } diff --git a/pkgs/by-name/gl/globalarrays/package.nix b/pkgs/by-name/gl/globalarrays/package.nix index ee7876e548d404..8ebc40a02561a8 100644 --- a/pkgs/by-name/gl/globalarrays/package.nix +++ b/pkgs/by-name/gl/globalarrays/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook -, blas, gfortran, openssh, mpi -} : +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + blas, + gfortran, + openssh, + mpi, +}: stdenv.mkDerivation rec { pname = "globalarrays"; @@ -13,8 +20,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-2ffQIg9topqKX7ygnWaa/UunL9d0Lj9qr9xucsjLuoY="; }; - nativeBuildInputs = [ autoreconfHook gfortran ]; - buildInputs = [ mpi blas openssh ]; + nativeBuildInputs = [ + autoreconfHook + gfortran + ]; + buildInputs = [ + mpi + blas + openssh + ]; preConfigure = '' configureFlagsArray+=( "--enable-i8" \ diff --git a/pkgs/by-name/gl/globe-cli/package.nix b/pkgs/by-name/gl/globe-cli/package.nix index fdc53e74b07838..db414184d7161f 100644 --- a/pkgs/by-name/gl/globe-cli/package.nix +++ b/pkgs/by-name/gl/globe-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "globe-cli"; diff --git a/pkgs/by-name/gl/globulation2/package.nix b/pkgs/by-name/gl/globulation2/package.nix index a444f18335fc4b..20621238c27960 100644 --- a/pkgs/by-name/gl/globulation2/package.nix +++ b/pkgs/by-name/gl/globulation2/package.nix @@ -1,6 +1,22 @@ -{ lib, stdenv, fetchurl, libGLU, libGL, SDL, scons, SDL_ttf, SDL_image, zlib, SDL_net -, speex, libvorbis, libogg, boost, fribidi, bsdiff -, fetchpatch +{ + lib, + stdenv, + fetchurl, + libGLU, + libGL, + SDL, + scons, + SDL_ttf, + SDL_image, + zlib, + SDL_net, + speex, + libvorbis, + libogg, + boost, + fribidi, + bsdiff, + fetchpatch, }: let version = "0.9.4"; @@ -19,7 +35,9 @@ stdenv.mkDerivation rec { sha256 = "1f0l2cqp2g3llhr9jl6jj15k0wb5q8n29vqj99xy4p5hqs78jk8g"; }; - patches = [ ./header-order.patch ./public-buildproject.patch + patches = [ + ./header-order.patch + ./public-buildproject.patch (fetchpatch { url = "https://bitbucket.org/giszmo/glob2/commits/c9dc715624318e4fea4abb24e04f0ebdd9cd8d2a/raw"; sha256 = "0017xg5agj3dy0hx71ijdcrxb72bjqv7x6aq7c9zxzyyw0mkxj0k"; @@ -49,7 +67,21 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ scons ]; - buildInputs = [ libGLU libGL SDL SDL_ttf SDL_image zlib SDL_net speex libvorbis libogg boost fribidi bsdiff ]; + buildInputs = [ + libGLU + libGL + SDL + SDL_ttf + SDL_image + zlib + SDL_net + speex + libvorbis + libogg + boost + fribidi + bsdiff + ]; postConfigure = '' sconsFlags+=" BINDIR=$out/bin" diff --git a/pkgs/by-name/gl/glock/package.nix b/pkgs/by-name/gl/glock/package.nix index c573d06af7d003..b116db1966e40f 100644 --- a/pkgs/by-name/gl/glock/package.nix +++ b/pkgs/by-name/gl/glock/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, }: buildGoModule { diff --git a/pkgs/by-name/gl/glog/package.nix b/pkgs/by-name/gl/glog/package.nix index ac425092128c61..762b49a68e952d 100644 --- a/pkgs/by-name/gl/glog/package.nix +++ b/pkgs/by-name/gl/glog/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, cmake, gflags, gtest, perl }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + gflags, + gtest, + perl, +}: stdenv.mkDerivation rec { pname = "glog"; @@ -34,29 +42,37 @@ stdenv.mkDerivation rec { env.GTEST_FILTER = let - filteredTests = lib.optionals stdenv.hostPlatform.isMusl [ - "Symbolize.SymbolizeStackConsumption" - "Symbolize.SymbolizeWithDemanglingStackConsumption" - ] ++ lib.optionals stdenv.hostPlatform.isStatic [ - "LogBacktraceAt.DoesBacktraceAtRightLineWhenEnabled" - ] ++ lib.optionals stdenv.cc.isClang [ - # Clang optimizes an expected allocation away. - # See https://github.com/google/glog/issues/937 - "DeathNoAllocNewHook.logging" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "LogBacktraceAt.DoesBacktraceAtRightLineWhenEnabled" - ]; + filteredTests = + lib.optionals stdenv.hostPlatform.isMusl [ + "Symbolize.SymbolizeStackConsumption" + "Symbolize.SymbolizeWithDemanglingStackConsumption" + ] + ++ lib.optionals stdenv.hostPlatform.isStatic [ + "LogBacktraceAt.DoesBacktraceAtRightLineWhenEnabled" + ] + ++ lib.optionals stdenv.cc.isClang [ + # Clang optimizes an expected allocation away. + # See https://github.com/google/glog/issues/937 + "DeathNoAllocNewHook.logging" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "LogBacktraceAt.DoesBacktraceAtRightLineWhenEnabled" + ]; in "-${builtins.concatStringsSep ":" filteredTests}"; checkPhase = let - excludedTests = lib.optionals stdenv.hostPlatform.isDarwin [ - "mock-log" - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - "logging" # works around segfaults on aarch64-darwin for now - ]; - excludedTestsRegex = lib.optionalString (excludedTests != [ ]) "(${lib.concatStringsSep "|" excludedTests})"; + excludedTests = + lib.optionals stdenv.hostPlatform.isDarwin [ + "mock-log" + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + "logging" # works around segfaults on aarch64-darwin for now + ]; + excludedTestsRegex = lib.optionalString ( + excludedTests != [ ] + ) "(${lib.concatStringsSep "|" excludedTests})"; in '' runHook preCheck @@ -69,6 +85,9 @@ stdenv.mkDerivation rec { license = licenses.bsd3; description = "Library for application-level logging"; platforms = platforms.unix; - maintainers = with maintainers; [ nh2 r-burns ]; + maintainers = with maintainers; [ + nh2 + r-burns + ]; }; } diff --git a/pkgs/by-name/gl/gloox/package.nix b/pkgs/by-name/gl/gloox/package.nix index ed5e4ec9b06fce..71fe57dbeafea9 100644 --- a/pkgs/by-name/gl/gloox/package.nix +++ b/pkgs/by-name/gl/gloox/package.nix @@ -1,11 +1,16 @@ -{ lib, stdenv, fetchurl -, zlibSupport ? true, zlib -, sslSupport ? true, openssl -, idnSupport ? true, libidn +{ + lib, + stdenv, + fetchurl, + zlibSupport ? true, + zlib, + sslSupport ? true, + openssl, + idnSupport ? true, + libidn, }: - -stdenv.mkDerivation rec{ +stdenv.mkDerivation rec { pname = "gloox"; version = "1.0.28"; @@ -21,7 +26,8 @@ stdenv.mkDerivation rec{ src/examples/*.cpp ''; - buildInputs = [ ] + buildInputs = + [ ] ++ lib.optional zlibSupport zlib ++ lib.optional sslSupport openssl ++ lib.optional idnSupport libidn; diff --git a/pkgs/by-name/gl/glow/package.nix b/pkgs/by-name/gl/glow/package.nix index 5da1e6e2f07a82..0066754cc8789e 100644 --- a/pkgs/by-name/gl/glow/package.nix +++ b/pkgs/by-name/gl/glow/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, stdenv +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + stdenv, }: buildGoModule rec { @@ -20,7 +21,11 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; doCheck = false; @@ -36,7 +41,10 @@ buildGoModule rec { homepage = "https://github.com/charmbracelet/glow"; changelog = "https://github.com/charmbracelet/glow/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ Br1ght0ne penguwin ]; + maintainers = with maintainers; [ + Br1ght0ne + penguwin + ]; mainProgram = "glow"; }; } diff --git a/pkgs/by-name/gl/glowing-bear/package.nix b/pkgs/by-name/gl/glowing-bear/package.nix index c493cae6d4637f..f1a352c8e77376 100644 --- a/pkgs/by-name/gl/glowing-bear/package.nix +++ b/pkgs/by-name/gl/glowing-bear/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, lib, stdenv }: +{ + fetchFromGitHub, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "glowing-bear"; diff --git a/pkgs/by-name/gl/glpaper/package.nix b/pkgs/by-name/gl/glpaper/package.nix index f6f285d45a0bd3..c1ccb5759d74ef 100644 --- a/pkgs/by-name/gl/glpaper/package.nix +++ b/pkgs/by-name/gl/glpaper/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromSourcehut, meson, ninja, pkg-config, wayland -, libX11, libGL }: +{ + lib, + stdenv, + fetchFromSourcehut, + meson, + ninja, + pkg-config, + wayland, + libX11, + libGL, +}: stdenv.mkDerivation rec { pname = "glpaper"; @@ -13,7 +22,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-E7FKjt3NL0aAEibfaq+YS2IVvpjNjInA+Rs8SU63/3M="; }; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; buildInputs = [ wayland libX11 # required by libglvnd @@ -21,8 +34,7 @@ stdenv.mkDerivation rec { ]; meta = with lib; { - description = - "Wallpaper program for wlroots based Wayland compositors such as sway that allows you to render glsl shaders as your wallpaper"; + description = "Wallpaper program for wlroots based Wayland compositors such as sway that allows you to render glsl shaders as your wallpaper"; mainProgram = "glpaper"; homepage = "https://hg.sr.ht/~scoopta/glpaper"; license = licenses.gpl3Plus; diff --git a/pkgs/by-name/gl/glpk/package.nix b/pkgs/by-name/gl/glpk/package.nix index 1f7974476b0276..bc7ae7c9e57565 100644 --- a/pkgs/by-name/gl/glpk/package.nix +++ b/pkgs/by-name/gl/glpk/package.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, fetchurl -, fetchpatch -, libmysqlclient -# Excerpt from glpk's INSTALL file: -# This feature allows the exact simplex solver to use the GNU MP -# bignum library. If it is disabled, the exact simplex solver uses the -# GLPK bignum module, which provides the same functionality as GNU MP, -# however, it is much less efficient. -, withGmp ? true -, gmp +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libmysqlclient, + # Excerpt from glpk's INSTALL file: + # This feature allows the exact simplex solver to use the GNU MP + # bignum library. If it is disabled, the exact simplex solver uses the + # GLPK bignum module, which provides the same functionality as GNU MP, + # however, it is much less efficient. + withGmp ? true, + gmp, }: assert withGmp -> gmp != null; @@ -23,8 +25,10 @@ stdenv.mkDerivation rec { }; buildInputs = - [ libmysqlclient - ] ++ lib.optionals withGmp [ + [ + libmysqlclient + ] + ++ lib.optionals withGmp [ gmp ]; @@ -63,11 +67,11 @@ stdenv.mkDerivation rec { description = "GNU Linear Programming Kit"; longDescription = '' - The GNU Linear Programming Kit is intended for solving large - scale linear programming problems by means of the revised - simplex method. It is a set of routines written in the ANSI C - programming language and organized in the form of a library. - ''; + The GNU Linear Programming Kit is intended for solving large + scale linear programming problems by means of the revised + simplex method. It is a set of routines written in the ANSI C + programming language and organized in the form of a library. + ''; homepage = "https://www.gnu.org/software/glpk/"; license = licenses.gpl3Plus; diff --git a/pkgs/by-name/gl/glpng/package.nix b/pkgs/by-name/gl/glpng/package.nix index 34c58774fb2419..4a98163a2a4c70 100644 --- a/pkgs/by-name/gl/glpng/package.nix +++ b/pkgs/by-name/gl/glpng/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromRepoOrCz -, cmake -, libGL -, libpng -, pkg-config -, zlib +{ + lib, + stdenv, + fetchFromRepoOrCz, + cmake, + libGL, + libpng, + pkg-config, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gl/glrnvim/package.nix b/pkgs/by-name/gl/glrnvim/package.nix index af11d0a6666564..44d73439fe3bda 100644 --- a/pkgs/by-name/gl/glrnvim/package.nix +++ b/pkgs/by-name/gl/glrnvim/package.nix @@ -19,10 +19,13 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-cHEse+pXwgPTL8GJyY4s1mhWXGTY8Fnn2rFpA5SNerY="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - DiskArbitration - Foundation - ]); + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + DiskArbitration + Foundation + ] + ); postInstall = '' install -Dm644 glrnvim.desktop -t $out/share/applications diff --git a/pkgs/by-name/gl/glsl_analyzer/package.nix b/pkgs/by-name/gl/glsl_analyzer/package.nix index 868ff99d388893..f7a71c4398a4c4 100644 --- a/pkgs/by-name/gl/glsl_analyzer/package.nix +++ b/pkgs/by-name/gl/glsl_analyzer/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, zig_0_13 -, apple-sdk_11 +{ + lib, + stdenv, + fetchFromGitHub, + zig_0_13, + apple-sdk_11, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gl/glslang/package.nix b/pkgs/by-name/gl/glslang/package.nix index e54d8711e65b74..bc57fca1a9eccd 100644 --- a/pkgs/by-name/gl/glslang/package.nix +++ b/pkgs/by-name/gl/glslang/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, bison -, cmake -, jq -, python3 -, spirv-headers -, spirv-tools +{ + lib, + stdenv, + fetchFromGitHub, + bison, + cmake, + jq, + python3, + spirv-headers, + spirv-tools, }: stdenv.mkDerivation rec { pname = "glslang"; @@ -18,7 +20,11 @@ stdenv.mkDerivation rec { hash = "sha256-QXNecJ6SDeWpRjzHRTdPJHob1H3q2HZmWuL2zBt2Tlw="; }; - outputs = [ "bin" "out" "dev" ]; + outputs = [ + "bin" + "out" + "dev" + ]; # These get set at all-packages, keep onto them for child drvs passthru = { @@ -26,7 +32,12 @@ stdenv.mkDerivation rec { spirv-headers = spirv-headers; }; - nativeBuildInputs = [ cmake python3 bison jq ]; + nativeBuildInputs = [ + cmake + python3 + bison + jq + ]; cmakeFlags = [ "-DBUILD_SHARED_LIBS=ON" ]; diff --git a/pkgs/by-name/gl/glslls/package.nix b/pkgs/by-name/gl/glslls/package.nix index 0e78dd8502f75b..c23047cf027dfe 100644 --- a/pkgs/by-name/gl/glslls/package.nix +++ b/pkgs/by-name/gl/glslls/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + python3, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gl/gltron/package.nix b/pkgs/by-name/gl/gltron/package.nix index 819914dec8b504..c09c8d7e460cc6 100644 --- a/pkgs/by-name/gl/gltron/package.nix +++ b/pkgs/by-name/gl/gltron/package.nix @@ -1,4 +1,16 @@ -{lib, stdenv, fetchurl, SDL, libGLU, libGL, zlib, libpng, libvorbis, libmikmod, SDL_sound } : +{ + lib, + stdenv, + fetchurl, + SDL, + libGLU, + libGL, + zlib, + libpng, + libvorbis, + libmikmod, + SDL_sound, +}: stdenv.mkDerivation rec { pname = "gltron"; @@ -11,14 +23,23 @@ stdenv.mkDerivation rec { patches = [ ./gentoo-prototypes.patch ]; postPatch = '' - # Fix https://sourceforge.net/p/gltron/bugs/15 - sed -i /__USE_MISC/d lua/src/lib/liolib.c + # Fix https://sourceforge.net/p/gltron/bugs/15 + sed -i /__USE_MISC/d lua/src/lib/liolib.c ''; # The build fails, unless we disable the default -Wall -Werror configureFlags = [ "--disable-warn" ]; - buildInputs = [ SDL libGLU libGL zlib libpng libvorbis libmikmod SDL_sound ]; + buildInputs = [ + SDL + libGLU + libGL + zlib + libpng + libvorbis + libmikmod + SDL_sound + ]; meta = { homepage = "http://www.gltron.org/"; diff --git a/pkgs/by-name/gl/gluesql/package.nix b/pkgs/by-name/gl/gluesql/package.nix index 7d49107de2235b..66f7297d5b87fd 100644 --- a/pkgs/by-name/gl/gluesql/package.nix +++ b/pkgs/by-name/gl/gluesql/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, nix-update-script +{ + lib, + fetchFromGitHub, + rustPlatform, + nix-update-script, }: let diff --git a/pkgs/by-name/gl/glui/package.nix b/pkgs/by-name/gl/glui/package.nix index f3999bfb439b7b..a703550a7dedf6 100644 --- a/pkgs/by-name/gl/glui/package.nix +++ b/pkgs/by-name/gl/glui/package.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, fetchFromGitHub -, libglut -, libGL -, libGLU -, libX11 -, libXext -, libXi -, libXmu +{ + lib, + stdenv, + fetchFromGitHub, + libglut, + libGL, + libGLU, + libX11, + libXext, + libXi, + libXmu, }: stdenv.mkDerivation rec { @@ -20,7 +22,15 @@ stdenv.mkDerivation rec { sha256 = "0qg2y8w95s03zay1qsqs8pqxxlg6l9kwm7rrs1qmx0h22sxb360i"; }; - buildInputs = [ libglut libGLU libGL libXmu libXext libX11 libXi ]; + buildInputs = [ + libglut + libGLU + libGL + libXmu + libXext + libX11 + libXi + ]; installPhase = '' mkdir -p "$out"/{bin,lib,share/glui/doc,include} @@ -33,7 +43,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "User interface library using OpenGL"; - license = licenses.zlib ; + license = licenses.zlib; maintainers = [ maintainers.raskin ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/gl/glusterfs/package.nix b/pkgs/by-name/gl/glusterfs/package.nix index 636a4520ea56f2..7c367cd2ad09de 100644 --- a/pkgs/by-name/gl/glusterfs/package.nix +++ b/pkgs/by-name/gl/glusterfs/package.nix @@ -1,8 +1,46 @@ -{lib, stdenv, fetchFromGitHub, fuse, bison, flex, openssl, python3, ncurses, readline, - autoconf, automake, libtool, pkg-config, zlib, libaio, libxml2, acl, sqlite, - liburcu, liburing, attr, makeWrapper, coreutils, gnused, gnugrep, which, - openssh, gawk, findutils, util-linux, lvm2, btrfs-progs, e2fsprogs, xfsprogs, systemd, - rsync, getent, rpcsvc-proto, libtirpc, gperftools, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + fuse, + bison, + flex, + openssl, + python3, + ncurses, + readline, + autoconf, + automake, + libtool, + pkg-config, + zlib, + libaio, + libxml2, + acl, + sqlite, + liburcu, + liburing, + attr, + makeWrapper, + coreutils, + gnused, + gnugrep, + which, + openssh, + gawk, + findutils, + util-linux, + lvm2, + btrfs-progs, + e2fsprogs, + xfsprogs, + systemd, + rsync, + getent, + rpcsvc-proto, + libtirpc, + gperftools, + nixosTests, }: let # NOTE: On each glusterfs release, it should be checked if gluster added @@ -14,9 +52,20 @@ let # can help with finding new Python scripts. buildInputs = [ - fuse openssl ncurses readline - zlib libaio libxml2 - acl sqlite liburcu attr util-linux libtirpc gperftools + fuse + openssl + ncurses + readline + zlib + libaio + libxml2 + acl + sqlite + liburcu + attr + util-linux + libtirpc + gperftools liburing (python3.withPackages (pkgs: [ pkgs.flask @@ -53,7 +102,8 @@ let which # which xfsprogs # xfs_info ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "glusterfs"; version = "11.1"; @@ -109,7 +159,16 @@ in stdenv.mkDerivation rec { "--localstatedir=/var" ]; - nativeBuildInputs = [ autoconf automake libtool pkg-config bison flex makeWrapper rpcsvc-proto ]; + nativeBuildInputs = [ + autoconf + automake + libtool + pkg-config + bison + flex + makeWrapper + rpcsvc-proto + ]; makeFlags = [ "DESTDIR=$(out)" ]; diff --git a/pkgs/by-name/gl/glycin-loaders/package.nix b/pkgs/by-name/gl/glycin-loaders/package.nix index dae6bc3fa810d9..76a9800952c683 100644 --- a/pkgs/by-name/gl/glycin-loaders/package.nix +++ b/pkgs/by-name/gl/glycin-loaders/package.nix @@ -1,23 +1,24 @@ -{ stdenv -, lib -, fetchurl -, substituteAll -, bubblewrap -, cairo -, cargo -, git -, gnome -, gtk4 -, lcms2 -, libheif -, libjxl -, librsvg -, libseccomp -, libxml2 -, meson -, ninja -, pkg-config -, rustc +{ + stdenv, + lib, + fetchurl, + substituteAll, + bubblewrap, + cairo, + cargo, + git, + gnome, + gtk4, + lcms2, + libheif, + libjxl, + librsvg, + libseccomp, + libxml2, + meson, + ninja, + pkg-config, + rustc, }: stdenv.mkDerivation (finalAttrs: { @@ -79,7 +80,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Glycin loaders for several formats"; homepage = "https://gitlab.gnome.org/sophie-h/glycin"; maintainers = teams.gnome.members; - license = with licenses; [ mpl20 /* or */ lgpl21Plus ]; + license = with licenses; [ + mpl20 # or + lgpl21Plus + ]; platforms = platforms.linux; }; }) diff --git a/pkgs/by-name/gl/glyr/package.nix b/pkgs/by-name/gl/glyr/package.nix index c1499a376f1560..9303d4c9e7d53e 100644 --- a/pkgs/by-name/gl/glyr/package.nix +++ b/pkgs/by-name/gl/glyr/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, curl, glib, sqlite, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + curl, + glib, + sqlite, + pkg-config, +}: stdenv.mkDerivation rec { version = "1.0.10"; @@ -12,8 +20,15 @@ stdenv.mkDerivation rec { sha256 = "1miwbqzkhg0v3zysrwh60pj9sv6ci4lzq2vq2hhc6pc6hdyh8xyr"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ sqlite glib curl ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + sqlite + glib + curl + ]; meta = with lib; { description = "Music related metadata searchengine"; @@ -24,5 +39,3 @@ stdenv.mkDerivation rec { platforms = platforms.unix; }; } - - diff --git a/pkgs/by-name/gm/gmad/package.nix b/pkgs/by-name/gm/gmad/package.nix index 799609856137b0..3ea8e2ae99f514 100644 --- a/pkgs/by-name/gm/gmad/package.nix +++ b/pkgs/by-name/gm/gmad/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, premake4, bootil }: +{ + lib, + stdenv, + fetchFromGitHub, + premake4, + bootil, +}: stdenv.mkDerivation rec { pname = "gmad"; @@ -16,17 +22,26 @@ stdenv.mkDerivation rec { owner = "Facepunch"; repo = "gmad"; rev = "5236973a2fcbb3043bdd3d4529ce68b6d938ad93"; - sha256="04an17nvnj38mpi0w005v41ib8ynb5qhgrdkmsda4hq7l1gn276s"; + sha256 = "04an17nvnj38mpi0w005v41ib8ynb5qhgrdkmsda4hq7l1gn276s"; }; - buildInputs = [ premake4 bootil ]; + buildInputs = [ + premake4 + bootil + ]; targetName = - if stdenv.hostPlatform.isLinux then "gmad_linux" - else if stdenv.hostPlatform.isDarwin then "gmad_osx" - else "gmad"; + if stdenv.hostPlatform.isLinux then + "gmad_linux" + else if stdenv.hostPlatform.isDarwin then + "gmad_osx" + else + "gmad"; - premakeFlags = [ "--bootil_lib=${bootil}/lib" "--bootil_inc=${bootil}/include" ]; + premakeFlags = [ + "--bootil_lib=${bootil}/lib" + "--bootil_inc=${bootil}/include" + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/gm/gmailctl/package.nix b/pkgs/by-name/gm/gmailctl/package.nix index b10dac2262abe2..b701b17923a032 100644 --- a/pkgs/by-name/gm/gmailctl/package.nix +++ b/pkgs/by-name/gm/gmailctl/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -34,6 +35,9 @@ buildGoModule rec { description = "Declarative configuration for Gmail filters"; homepage = "https://github.com/mbrt/gmailctl"; license = licenses.mit; - maintainers = with maintainers; [ doronbehar SuperSandro2000 ]; + maintainers = with maintainers; [ + doronbehar + SuperSandro2000 + ]; }; } diff --git a/pkgs/by-name/gm/gmetronome/package.nix b/pkgs/by-name/gm/gmetronome/package.nix index 7dcd816c31b414..eec5e5bbeda708 100644 --- a/pkgs/by-name/gm/gmetronome/package.nix +++ b/pkgs/by-name/gm/gmetronome/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitLab -, pkg-config -, autoreconfHook -, wrapGAppsHook3 -, gtkmm3 -, libpulseaudio +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + autoreconfHook, + wrapGAppsHook3, + gtkmm3, + libpulseaudio, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gm/gmic-qt/package.nix b/pkgs/by-name/gm/gmic-qt/package.nix index 539b766464e6d3..ad7ec1323da153 100644 --- a/pkgs/by-name/gm/gmic-qt/package.nix +++ b/pkgs/by-name/gm/gmic-qt/package.nix @@ -1,25 +1,26 @@ -{ lib -, cimg -, cmake -, curl -, fetchFromGitHub -, fftw -, gimp -, gimpPlugins -, gmic -, graphicsmagick -, libjpeg -, libpng -, libsForQt5 -, libtiff -, llvmPackages -, ninja -, nix-update-script -, openexr -, pkg-config -, stdenv -, zlib -, variant ? "standalone" +{ + lib, + cimg, + cmake, + curl, + fetchFromGitHub, + fftw, + gimp, + gimpPlugins, + gmic, + graphicsmagick, + libjpeg, + libpng, + libsForQt5, + libtiff, + llvmPackages, + ninja, + nix-update-script, + openexr, + pkg-config, + stdenv, + zlib, + variant ? "standalone", }: let @@ -33,20 +34,19 @@ let }; standalone = { - extraDeps = []; # Just to keep uniformity and avoid test-for-null + extraDeps = [ ]; # Just to keep uniformity and avoid test-for-null description = "Versatile front-end to the image processing framework G'MIC"; }; }; in -assert lib.assertMsg - (builtins.hasAttr variant variants) +assert lib.assertMsg (builtins.hasAttr variant variants) "gmic-qt variant \"${variant}\" is not supported. Please use one of ${lib.concatStringsSep ", " (builtins.attrNames variants)}."; -assert lib.assertMsg - (builtins.all (d: d != null) variants.${variant}.extraDeps) - "gmic-qt variant \"${variant}\" is missing one of its dependencies."; +assert lib.assertMsg (builtins.all (d: d != null) + variants.${variant}.extraDeps +) "gmic-qt variant \"${variant}\" is missing one of its dependencies."; stdenv.mkDerivation (finalAttrs: { pname = "gmic-qt${lib.optionalString (variant != "standalone") "-${variant}"}"; @@ -66,23 +66,27 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - cimg - curl - fftw - gmic - graphicsmagick - libjpeg - libpng - libtiff - openexr - zlib - ] ++ (with libsForQt5; [ - qtbase - qttools - ]) ++ lib.optionals stdenv.cc.isClang [ - llvmPackages.openmp - ] ++ variants.${variant}.extraDeps; + buildInputs = + [ + cimg + curl + fftw + gmic + graphicsmagick + libjpeg + libpng + libtiff + openexr + zlib + ] + ++ (with libsForQt5; [ + qtbase + qttools + ]) + ++ lib.optionals stdenv.cc.isClang [ + llvmPackages.openmp + ] + ++ variants.${variant}.extraDeps; postPatch = '' patchShebangs \ @@ -112,7 +116,10 @@ stdenv.mkDerivation (finalAttrs: { }; updateScript = nix-update-script { - extraArgs = [ "--version-regex" "^v\\.(.*)" ]; + extraArgs = [ + "--version-regex" + "^v\\.(.*)" + ]; }; }; diff --git a/pkgs/by-name/gm/gmic/package.nix b/pkgs/by-name/gm/gmic/package.nix index 21ebebd8f67720..89f3e13b3919a9 100644 --- a/pkgs/by-name/gm/gmic/package.nix +++ b/pkgs/by-name/gm/gmic/package.nix @@ -1,37 +1,43 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchurl -, cimg -, cmake -, common-updater-scripts -, coreutils -, curl -, fftw -, gmic-qt -, gnugrep -, gnused -, graphicsmagick -, jq -, libX11 -, libXext -, libjpeg -, libpng -, libtiff -, llvmPackages -, ninja -, opencv -, openexr -, pkg-config -, writeShellScript -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + cimg, + cmake, + common-updater-scripts, + coreutils, + curl, + fftw, + gmic-qt, + gnugrep, + gnused, + graphicsmagick, + jq, + libX11, + libXext, + libjpeg, + libpng, + libtiff, + llvmPackages, + ninja, + opencv, + openexr, + pkg-config, + writeShellScript, + zlib, }: stdenv.mkDerivation (finalAttrs: { pname = "gmic"; version = "3.4.3"; - outputs = [ "out" "lib" "dev" "man" ]; + outputs = [ + "out" + "lib" + "dev" + "man" + ]; src = fetchFromGitHub { owner = "GreycLab"; @@ -44,7 +50,9 @@ stdenv.mkDerivation (finalAttrs: { # Reference: src/Makefile, directive gmic_stdlib_community.h gmic_stdlib = fetchurl { name = "gmic_stdlib_community.h"; - url = "https://gmic.eu/gmic_stdlib_community${lib.replaceStrings ["."] [""] finalAttrs.version}.h"; + url = "https://gmic.eu/gmic_stdlib_community${ + lib.replaceStrings [ "." ] [ "" ] finalAttrs.version + }.h"; hash = "sha256-M/AL1w9KGi+dIGVQ+vdWY8PSCHi+s/aZef08AxeQMJE="; }; @@ -54,21 +62,23 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - cimg - fftw - graphicsmagick - libX11 - libXext - libjpeg - libpng - libtiff - opencv - openexr - zlib - ] ++ lib.optionals stdenv.cc.isClang [ - llvmPackages.openmp - ]; + buildInputs = + [ + cimg + fftw + graphicsmagick + libX11 + libXext + libjpeg + libpng + libtiff + opencv + openexr + zlib + ] + ++ lib.optionals stdenv.cc.isClang [ + llvmPackages.openmp + ]; cmakeFlags = [ (lib.cmakeBool "BUILD_LIB_STATIC" false) @@ -79,13 +89,14 @@ stdenv.mkDerivation (finalAttrs: { (lib.cmakeBool "USE_SYSTEM_CIMG" true) ]; - postPatch = '' - cp -r ${finalAttrs.gmic_stdlib} src/gmic_stdlib_community.h - '' - + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace CMakeLists.txt \ - --replace "LD_LIBRARY_PATH" "DYLD_LIBRARY_PATH" - ''; + postPatch = + '' + cp -r ${finalAttrs.gmic_stdlib} src/gmic_stdlib_community.h + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace CMakeLists.txt \ + --replace "LD_LIBRARY_PATH" "DYLD_LIBRARY_PATH" + ''; passthru = { tests = { @@ -95,7 +106,16 @@ stdenv.mkDerivation (finalAttrs: { updateScript = writeShellScript "gmic-update-script" '' set -o errexit - PATH=${lib.makeBinPath [ common-updater-scripts coreutils curl gnugrep gnused jq ]} + PATH=${ + lib.makeBinPath [ + common-updater-scripts + coreutils + curl + gnugrep + gnused + jq + ] + } latestVersion=$(curl 'https://gmic.eu/files/source/' \ | grep -E 'gmic_[^"]+\.tar\.gz' \ diff --git a/pkgs/by-name/gm/gmid/package.nix b/pkgs/by-name/gm/gmid/package.nix index 8efb061cd6d7f8..f630bfc954acbd 100644 --- a/pkgs/by-name/gm/gmid/package.nix +++ b/pkgs/by-name/gm/gmid/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, bison, libressl, libevent }: +{ + lib, + stdenv, + fetchFromGitHub, + bison, + libressl, + libevent, +}: stdenv.mkDerivation rec { pname = "gmid"; @@ -13,7 +20,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ bison ]; - buildInputs = [ libressl libevent ]; + buildInputs = [ + libressl + libevent + ]; configureFlags = [ "PREFIX=${placeholder "out"}" diff --git a/pkgs/by-name/gm/gmm/package.nix b/pkgs/by-name/gm/gmm/package.nix index fb44222e75f536..051c413fced8ec 100644 --- a/pkgs/by-name/gm/gmm/package.nix +++ b/pkgs/by-name/gm/gmm/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "gmm"; diff --git a/pkgs/by-name/gm/gmni/package.nix b/pkgs/by-name/gm/gmni/package.nix index a17cdab086651f..47d3487767ae7b 100644 --- a/pkgs/by-name/gm/gmni/package.nix +++ b/pkgs/by-name/gm/gmni/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromSourcehut, bearssl, scdoc }: +{ + stdenv, + lib, + fetchFromSourcehut, + bearssl, + scdoc, +}: stdenv.mkDerivation rec { pname = "gmni"; @@ -26,7 +32,10 @@ stdenv.mkDerivation rec { description = "Gemini client"; homepage = "https://git.sr.ht/~sircmpwn/gmni"; license = licenses.gpl3Only; - maintainers = with maintainers; [ bsima jb55 ]; + maintainers = with maintainers; [ + bsima + jb55 + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/gm/gmnisrv/package.nix b/pkgs/by-name/gm/gmnisrv/package.nix index bb9d7cdf59657f..52e3feb60491d4 100644 --- a/pkgs/by-name/gm/gmnisrv/package.nix +++ b/pkgs/by-name/gm/gmnisrv/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromSourcehut, pkg-config, openssl, mailcap, scdoc }: +{ + stdenv, + lib, + fetchFromSourcehut, + pkg-config, + openssl, + mailcap, + scdoc, +}: stdenv.mkDerivation rec { pname = "gmnisrv"; @@ -21,15 +29,24 @@ stdenv.mkDerivation rec { ''; MIMEDB = "${mailcap}/etc/mime.types"; - nativeBuildInputs = [ pkg-config scdoc ]; - buildInputs = [ openssl mailcap ]; + nativeBuildInputs = [ + pkg-config + scdoc + ]; + buildInputs = [ + openssl + mailcap + ]; meta = with lib; { description = "Simple Gemini protocol server"; mainProgram = "gmnisrv"; homepage = "https://git.sr.ht/~sircmpwn/gmnisrv"; license = licenses.gpl3Only; - maintainers = with maintainers; [ bsima jb55 ]; + maintainers = with maintainers; [ + bsima + jb55 + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/gm/gmnitohtml/package.nix b/pkgs/by-name/gm/gmnitohtml/package.nix index a1a080ac029ecb..a57c108bd9f82b 100644 --- a/pkgs/by-name/gm/gmnitohtml/package.nix +++ b/pkgs/by-name/gm/gmnitohtml/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromSourcehut, scdoc, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromSourcehut, + scdoc, + installShellFiles, +}: buildGoModule rec { pname = "gmnitohtml"; @@ -12,10 +18,16 @@ buildGoModule rec { }; vendorHash = "sha256-ppplXXqb2DM/AU+B+LefndrBiiTgCRNw6hEupfeWr+o="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; # Build and install the man pages - nativeBuildInputs = [ scdoc installShellFiles ]; + nativeBuildInputs = [ + scdoc + installShellFiles + ]; postBuild = '' make docs @@ -41,7 +53,10 @@ buildGoModule rec { HTML to the standard output. ''; license = licenses.mit; - maintainers = with maintainers; [ jk sikmir ]; + maintainers = with maintainers; [ + jk + sikmir + ]; mainProgram = "gmnitohtml"; }; } diff --git a/pkgs/by-name/gm/gmqcc/package.nix b/pkgs/by-name/gm/gmqcc/package.nix index ec39f8744f5832..a91b8784400bf2 100644 --- a/pkgs/by-name/gm/gmqcc/package.nix +++ b/pkgs/by-name/gm/gmqcc/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gm/gmsh/package.nix b/pkgs/by-name/gm/gmsh/package.nix index 2219815824e7c6..7187d7299d1da7 100644 --- a/pkgs/by-name/gm/gmsh/package.nix +++ b/pkgs/by-name/gm/gmsh/package.nix @@ -1,6 +1,22 @@ -{ lib, stdenv, fetchurl, cmake, blas, lapack, gfortran, gmm, fltk, libjpeg -, zlib, libGL, libGLU, xorg, opencascade-occt -, python ? null, enablePython ? false }: +{ + lib, + stdenv, + fetchurl, + cmake, + blas, + lapack, + gfortran, + gmm, + fltk, + libjpeg, + zlib, + libGL, + libGLU, + xorg, + opencascade-occt, + python ? null, + enablePython ? false, +}: assert (!blas.isILP64) && (!lapack.isILP64); assert enablePython -> (python != null); @@ -14,13 +30,30 @@ stdenv.mkDerivation rec { hash = "sha256-d5chRfQxcmAm1QWWpqRPs8HJXCElUhjWaVWAa4btvo0="; }; - buildInputs = [ - blas lapack gmm fltk libjpeg zlib opencascade-occt - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - libGL libGLU xorg.libXrender xorg.libXcursor xorg.libXfixes - xorg.libXext xorg.libXft xorg.libXinerama xorg.libX11 xorg.libSM - xorg.libICE - ] ++ lib.optional enablePython python; + buildInputs = + [ + blas + lapack + gmm + fltk + libjpeg + zlib + opencascade-occt + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libGL + libGLU + xorg.libXrender + xorg.libXcursor + xorg.libXfixes + xorg.libXext + xorg.libXft + xorg.libXinerama + xorg.libX11 + xorg.libSM + xorg.libICE + ] + ++ lib.optional enablePython python; enableParallelBuilding = true; @@ -39,7 +72,10 @@ stdenv.mkDerivation rec { "-DENABLE_OPENMP=ON" ]; - nativeBuildInputs = [ cmake gfortran ]; + nativeBuildInputs = [ + cmake + gfortran + ]; postFixup = lib.optionalString enablePython '' mkdir -p $out/lib/python${python.pythonVersion}/site-packages diff --git a/pkgs/by-name/gm/gmu/package.nix b/pkgs/by-name/gm/gmu/package.nix index cc2b46cd6ace62..8e8e26d70af429 100644 --- a/pkgs/by-name/gm/gmu/package.nix +++ b/pkgs/by-name/gm/gmu/package.nix @@ -1,7 +1,19 @@ -{lib, stdenv, fetchurl, fetchpatch, SDL, SDL_gfx, SDL_image, tremor, flac, mpg123, libmikmod -, speex, ncurses -, keymap ? "default" -, conf ? "unknown" +{ + lib, + stdenv, + fetchurl, + fetchpatch, + SDL, + SDL_gfx, + SDL_image, + tremor, + flac, + mpg123, + libmikmod, + speex, + ncurses, + keymap ? "default", + conf ? "unknown", }: stdenv.mkDerivation rec { @@ -14,24 +26,34 @@ stdenv.mkDerivation rec { }; patches = [ - # pull pending upstream inclusion fix for ncurses-6.3: - # https://github.com/jhe2/gmu/pull/7 - (fetchpatch { - name = "ncurses-6.3.patch"; - url = "https://github.com/jhe2/gmu/commit/c8b3a10afee136feb333754ef6ec26383b11072f.patch"; - sha256 = "0xp2j3jp8pkmv6yvnzi378m2dylbfsaqrsrkw7hbxw6kglzj399r"; - }) - - # pull upstream fix for -fno-common toolchains like - # upstream gcc-10 of clang-13. - (fetchpatch { - name = "fno-common.patch"; - url = "https://github.com/jhe2/gmu/commit/b705209f08ddfda141ad358ccd0c3d2d099be5e6.patch"; - sha256 = "1ci2b8kz3r58rzmivlfhqjmcgqwlkwlzzhnyxlk36vmk240a3gqq"; - }) + # pull pending upstream inclusion fix for ncurses-6.3: + # https://github.com/jhe2/gmu/pull/7 + (fetchpatch { + name = "ncurses-6.3.patch"; + url = "https://github.com/jhe2/gmu/commit/c8b3a10afee136feb333754ef6ec26383b11072f.patch"; + sha256 = "0xp2j3jp8pkmv6yvnzi378m2dylbfsaqrsrkw7hbxw6kglzj399r"; + }) + + # pull upstream fix for -fno-common toolchains like + # upstream gcc-10 of clang-13. + (fetchpatch { + name = "fno-common.patch"; + url = "https://github.com/jhe2/gmu/commit/b705209f08ddfda141ad358ccd0c3d2d099be5e6.patch"; + sha256 = "1ci2b8kz3r58rzmivlfhqjmcgqwlkwlzzhnyxlk36vmk240a3gqq"; + }) ]; - buildInputs = [ SDL SDL_gfx SDL_image tremor flac mpg123 libmikmod speex ncurses ]; + buildInputs = [ + SDL + SDL_gfx + SDL_image + tremor + flac + mpg123 + libmikmod + speex + ncurses + ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/gn/gnaural/package.nix b/pkgs/by-name/gn/gnaural/package.nix index 75f163ba1e79ba..1463ff0b9576e8 100644 --- a/pkgs/by-name/gn/gnaural/package.nix +++ b/pkgs/by-name/gn/gnaural/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, libsndfile, portaudio, gtk2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libsndfile, + portaudio, + gtk2, +}: stdenv.mkDerivation rec { pname = "gnaural"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk2 libsndfile portaudio ]; + buildInputs = [ + gtk2 + libsndfile + portaudio + ]; # Workaround build failure on -fno-common toolchains: # ld: src/net/../gnauralnet.h:233: multiple definition of `GN_ScheduleFingerprint'; diff --git a/pkgs/by-name/gn/gnet/package.nix b/pkgs/by-name/gn/gnet/package.nix index 558d8c0b112a48..ab68ef5f2ef367 100644 --- a/pkgs/by-name/gn/gnet/package.nix +++ b/pkgs/by-name/gn/gnet/package.nix @@ -1,4 +1,13 @@ -{lib, stdenv, fetchFromGitHub, pkg-config, autoconf, automake, glib, libtool }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoconf, + automake, + glib, + libtool, +}: stdenv.mkDerivation rec { pname = "gnet"; @@ -6,12 +15,19 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "GNOME"; repo = "gnet"; - rev = "GNET_${lib.replaceStrings ["."] ["_"] version}"; + rev = "GNET_${lib.replaceStrings [ "." ] [ "_" ] version}"; sha256 = "1cy78kglzi235md964ikvm0rg801bx0yk9ya8zavndjnaarzqq87"; }; - nativeBuildInputs = [ pkg-config autoconf automake ]; - buildInputs = [ glib libtool ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; + buildInputs = [ + glib + libtool + ]; preConfigure = "./autogen.sh"; diff --git a/pkgs/by-name/gn/gnirehtet/package.nix b/pkgs/by-name/gn/gnirehtet/package.nix index 95ef1c7402d913..ca194413ef0a6d 100644 --- a/pkgs/by-name/gn/gnirehtet/package.nix +++ b/pkgs/by-name/gn/gnirehtet/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, fetchzip -, androidenv -, makeWrapper +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + fetchzip, + androidenv, + makeWrapper, }: let -version = "2.5.1"; -apk = stdenv.mkDerivation { - pname = "gnirehtet.apk"; - inherit version; - src = fetchzip { - url = "https://github.com/Genymobile/gnirehtet/releases/download/v${version}/gnirehtet-rust-linux64-v${version}.zip"; - hash = "sha256-e1wwMhcco9VNoBUzbEq1ESbkX2bqTOkCbPmnV9CpvGo="; + version = "2.5.1"; + apk = stdenv.mkDerivation { + pname = "gnirehtet.apk"; + inherit version; + src = fetchzip { + url = "https://github.com/Genymobile/gnirehtet/releases/download/v${version}/gnirehtet-rust-linux64-v${version}.zip"; + hash = "sha256-e1wwMhcco9VNoBUzbEq1ESbkX2bqTOkCbPmnV9CpvGo="; + }; + installPhase = '' + mkdir $out + mv gnirehtet.apk $out + ''; }; - installPhase = '' - mkdir $out - mv gnirehtet.apk $out - ''; -}; in rustPlatform.buildRustPackage rec { pname = "gnirehtet"; @@ -58,11 +59,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/Genymobile/gnirehtet"; sourceProvenance = with sourceTypes; [ fromSource - binaryBytecode # gnirehtet.apk + binaryBytecode # gnirehtet.apk ]; license = licenses.asl20; maintainers = with maintainers; [ symphorien ]; platforms = platforms.unix; }; } - diff --git a/pkgs/by-name/gn/gnmic/package.nix b/pkgs/by-name/gn/gnmic/package.nix index 0cd567968a78d4..527cb55f29bc2d 100644 --- a/pkgs/by-name/gn/gnmic/package.nix +++ b/pkgs/by-name/gn/gnmic/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, buildPackages +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + buildPackages, }: buildGoModule rec { @@ -20,20 +21,28 @@ buildGoModule rec { vendorHash = "sha256-9A/ZcamCMUpNxG3taHrqI4JChjpSjSuwx0ZUyGAuGXo="; ldflags = [ - "-s" "-w" - "-X" "github.com/openconfig/gnmic/pkg/app.version=${version}" - "-X" "github.com/openconfig/gnmic/pkg/app.commit=${src.rev}" - "-X" "github.com/openconfig/gnmic/pkg/app.date=1970-01-01T00:00:00Z" + "-s" + "-w" + "-X" + "github.com/openconfig/gnmic/pkg/app.version=${version}" + "-X" + "github.com/openconfig/gnmic/pkg/app.commit=${src.rev}" + "-X" + "github.com/openconfig/gnmic/pkg/app.date=1970-01-01T00:00:00Z" ]; subPackages = [ "." ]; nativeBuildInputs = [ installShellFiles ]; - postInstall = let emulator = stdenv.hostPlatform.emulator buildPackages; in '' - installShellCompletion --cmd gnmic \ - --bash <(${emulator} $out/bin/gnmic completion bash) \ - --fish <(${emulator} $out/bin/gnmic completion fish) \ - --zsh <(${emulator} $out/bin/gnmic completion zsh) - ''; + postInstall = + let + emulator = stdenv.hostPlatform.emulator buildPackages; + in + '' + installShellCompletion --cmd gnmic \ + --bash <(${emulator} $out/bin/gnmic completion bash) \ + --fish <(${emulator} $out/bin/gnmic completion fish) \ + --zsh <(${emulator} $out/bin/gnmic completion zsh) + ''; meta = with lib; { description = "gNMI CLI client and collector"; diff --git a/pkgs/by-name/gn/gnome-autoar/package.nix b/pkgs/by-name/gn/gnome-autoar/package.nix index 94c69fcf03d633..aefc9e0c1fe5b8 100644 --- a/pkgs/by-name/gn/gnome-autoar/package.nix +++ b/pkgs/by-name/gn/gnome-autoar/package.nix @@ -1,22 +1,26 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, gnome -, gtk3 -, glib -, gobject-introspection -, libarchive -, vala +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + gnome, + gtk3, + glib, + gobject-introspection, + libarchive, + vala, }: stdenv.mkDerivation rec { pname = "gnome-autoar"; version = "0.4.5"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/gnome-autoar/${lib.versions.majorMinor version}/gnome-autoar-${version}.tar.xz"; diff --git a/pkgs/by-name/gn/gnome-browser-connector/package.nix b/pkgs/by-name/gn/gnome-browser-connector/package.nix index 0eeaea47befdef..05fbfd79784998 100644 --- a/pkgs/by-name/gn/gnome-browser-connector/package.nix +++ b/pkgs/by-name/gn/gnome-browser-connector/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchurl -, meson -, ninja -, python3 -, gnome -, gnome-shell -, wrapGAppsNoGuiHook -, gobject-introspection +{ + lib, + fetchurl, + meson, + ninja, + python3, + gnome, + gnome-shell, + wrapGAppsNoGuiHook, + gobject-introspection, }: let diff --git a/pkgs/by-name/gn/gnome-builder/package.nix b/pkgs/by-name/gn/gnome-builder/package.nix index 8a3c7ac09d7af5..c36d51d1f996d7 100644 --- a/pkgs/by-name/gn/gnome-builder/package.nix +++ b/pkgs/by-name/gn/gnome-builder/package.nix @@ -1,49 +1,53 @@ -{ stdenv -, lib -, ctags -, cmark -, desktop-file-utils -, editorconfig-core-c -, fetchurl -, flatpak -, gnome -, libgit2-glib -, gi-docgen -, gobject-introspection -, gom -, gtk4 -, gtksourceview5 -, json-glib -, jsonrpc-glib -, libadwaita -, libdex -, libpanel -, libpeas2 -, libportal-gtk4 -, libspelling -, libsysprof-capture -, libxml2 -, meson -, ninja -, ostree -, pcre2 -, pkg-config -, python3 -, sysprof -, template-glib -, vala -, vte-gtk4 -, webkitgtk_6_0 -, wrapGAppsHook4 -, dbus -, xvfb-run +{ + stdenv, + lib, + ctags, + cmark, + desktop-file-utils, + editorconfig-core-c, + fetchurl, + flatpak, + gnome, + libgit2-glib, + gi-docgen, + gobject-introspection, + gom, + gtk4, + gtksourceview5, + json-glib, + jsonrpc-glib, + libadwaita, + libdex, + libpanel, + libpeas2, + libportal-gtk4, + libspelling, + libsysprof-capture, + libxml2, + meson, + ninja, + ostree, + pcre2, + pkg-config, + python3, + sysprof, + template-glib, + vala, + vte-gtk4, + webkitgtk_6_0, + wrapGAppsHook4, + dbus, + xvfb-run, }: stdenv.mkDerivation (finalAttrs: { pname = "gnome-builder"; version = "47.2"; - outputs = [ "out" "devdoc" ]; + outputs = [ + "out" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/gnome-builder/${lib.versions.major finalAttrs.version}/gnome-builder-${finalAttrs.version}.tar.xz"; diff --git a/pkgs/by-name/gn/gnome-calculator/package.nix b/pkgs/by-name/gn/gnome-calculator/package.nix index 2f2d5ff94e7a03..157ea3b2b3bfeb 100644 --- a/pkgs/by-name/gn/gnome-calculator/package.nix +++ b/pkgs/by-name/gn/gnome-calculator/package.nix @@ -1,26 +1,27 @@ -{ stdenv -, lib -, appstream -, meson -, ninja -, vala -, gettext -, itstool -, fetchurl -, pkg-config -, libxml2 -, gtk4 -, glib -, gtksourceview5 -, wrapGAppsHook4 -, gnome -, mpfr -, gmp -, libsoup_3 -, libmpc -, libadwaita -, gsettings-desktop-schemas -, libgee +{ + stdenv, + lib, + appstream, + meson, + ninja, + vala, + gettext, + itstool, + fetchurl, + pkg-config, + libxml2, + gtk4, + glib, + gtksourceview5, + wrapGAppsHook4, + gnome, + mpfr, + gmp, + libsoup_3, + libmpc, + libadwaita, + gsettings-desktop-schemas, + libgee, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-calendar/package.nix b/pkgs/by-name/gn/gnome-calendar/package.nix index d3cbf403df2831..f49b00e5e3070e 100644 --- a/pkgs/by-name/gn/gnome-calendar/package.nix +++ b/pkgs/by-name/gn/gnome-calendar/package.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, libgweather -, geoclue2 -, gettext -, libxml2 -, gnome -, gtk4 -, evolution-data-server-gtk4 -, libical -, libsoup_3 -, glib -, gsettings-desktop-schemas -, libadwaita +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + libgweather, + geoclue2, + gettext, + libxml2, + gnome, + gtk4, + evolution-data-server-gtk4, + libical, + libsoup_3, + glib, + gsettings-desktop-schemas, + libadwaita, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-common/package.nix b/pkgs/by-name/gn/gnome-common/package.nix index df7eede7fa51df..9a5393a27a8a6a 100644 --- a/pkgs/by-name/gn/gnome-common/package.nix +++ b/pkgs/by-name/gn/gnome-common/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, which, gnome, autoconf, automake }: +{ + lib, + stdenv, + fetchurl, + which, + gnome, + autoconf, + automake, +}: stdenv.mkDerivation rec { pname = "gnome-common"; @@ -13,7 +21,11 @@ stdenv.mkDerivation rec { updateScript = gnome.updateScript { packageName = "gnome-common"; }; }; - propagatedBuildInputs = [ which autoconf automake ]; # autogen.sh which is using gnome-common tends to require which + propagatedBuildInputs = [ + which + autoconf + automake + ]; # autogen.sh which is using gnome-common tends to require which meta = with lib; { maintainers = teams.gnome.members; diff --git a/pkgs/by-name/gn/gnome-console/package.nix b/pkgs/by-name/gn/gnome-console/package.nix index 5cf70be5355b3e..fbe20611fdf2cc 100644 --- a/pkgs/by-name/gn/gnome-console/package.nix +++ b/pkgs/by-name/gn/gnome-console/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchurl -, gettext -, gnome -, libgtop -, gtk4 -, libadwaita -, pango -, pcre2 -, vte-gtk4 -, desktop-file-utils -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, nixosTests +{ + lib, + stdenv, + fetchurl, + gettext, + gnome, + libgtop, + gtk4, + libadwaita, + pango, + pcre2, + vte-gtk4, + desktop-file-utils, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-desktop-testing/package.nix b/pkgs/by-name/gn/gnome-desktop-testing/package.nix index 1ff42a6f6241b0..4f707c18c7f55a 100644 --- a/pkgs/by-name/gn/gnome-desktop-testing/package.nix +++ b/pkgs/by-name/gn/gnome-desktop-testing/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, glib -, autoreconfHook -, pkg-config -, systemd -, fetchFromGitLab -, nix-update-script +{ + stdenv, + lib, + glib, + autoreconfHook, + pkg-config, + systemd, + fetchFromGitLab, + nix-update-script, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-desktop/package.nix b/pkgs/by-name/gn/gnome-desktop/package.nix index eb6dbbf1384384..2d533759f60ee7 100644 --- a/pkgs/by-name/gn/gnome-desktop/package.nix +++ b/pkgs/by-name/gn/gnome-desktop/package.nix @@ -1,37 +1,42 @@ -{ lib -, stdenv -, fetchurl -, substituteAll -, pkg-config -, libxslt -, ninja -, gnome -, gtk3 -, gtk4 -, glib -, gettext -, libxml2 -, xkeyboard_config -, libxkbcommon -, isocodes -, meson -, wayland -, libseccomp -, systemd -, udev -, bubblewrap -, gobject-introspection -, gtk-doc -, docbook-xsl-nons -, gsettings-desktop-schemas -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd +{ + lib, + stdenv, + fetchurl, + substituteAll, + pkg-config, + libxslt, + ninja, + gnome, + gtk3, + gtk4, + glib, + gettext, + libxml2, + xkeyboard_config, + libxkbcommon, + isocodes, + meson, + wayland, + libseccomp, + systemd, + udev, + bubblewrap, + gobject-introspection, + gtk-doc, + docbook-xsl-nons, + gsettings-desktop-schemas, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, }: stdenv.mkDerivation rec { pname = "gnome-desktop"; version = "44.1"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/gnome-desktop/${lib.versions.major version}/${pname}-${version}.tar.xz"; @@ -59,33 +64,38 @@ stdenv.mkDerivation rec { glib ]; - buildInputs = [ - xkeyboard_config - libxkbcommon # for xkbregistry - isocodes - gtk3 - gtk4 - glib - ] ++ lib.optionals withSystemd [ - systemd - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - bubblewrap - wayland - libseccomp - udev - ]; + buildInputs = + [ + xkeyboard_config + libxkbcommon # for xkbregistry + isocodes + gtk3 + gtk4 + glib + ] + ++ lib.optionals withSystemd [ + systemd + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + bubblewrap + wayland + libseccomp + udev + ]; propagatedBuildInputs = [ gsettings-desktop-schemas ]; - mesonFlags = [ - "-Dgtk_doc=true" - "-Ddesktop_docs=false" - (lib.mesonEnable "systemd" withSystemd) - ] ++ lib.optionals (!stdenv.hostPlatform.isLinux) [ - "-Dudev=disabled" - ]; + mesonFlags = + [ + "-Dgtk_doc=true" + "-Ddesktop_docs=false" + (lib.mesonEnable "systemd" withSystemd) + ] + ++ lib.optionals (!stdenv.hostPlatform.isLinux) [ + "-Dudev=disabled" + ]; separateDebugInfo = stdenv.hostPlatform.isLinux; @@ -98,7 +108,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Library with common API for various GNOME modules"; homepage = "https://gitlab.gnome.org/GNOME/gnome-desktop"; - license = with licenses; [ gpl2Plus lgpl2Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + ]; platforms = platforms.unix; maintainers = teams.gnome.members; }; diff --git a/pkgs/by-name/gn/gnome-disk-utility/package.nix b/pkgs/by-name/gn/gnome-disk-utility/package.nix index 5a61d18f1e20f3..70cc891e75a2ed 100644 --- a/pkgs/by-name/gn/gnome-disk-utility/package.nix +++ b/pkgs/by-name/gn/gnome-disk-utility/package.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, gettext -, fetchurl -, pkg-config -, udisks2 -, libhandy -, libsecret -, libdvdread -, meson -, ninja -, gtk3 -, glib -, wrapGAppsHook3 -, libnotify -, itstool -, gnome -, gnome-settings-daemon -, adwaita-icon-theme -, libxml2 -, gsettings-desktop-schemas -, libcanberra-gtk3 -, libxslt -, docbook-xsl-nons -, desktop-file-utils -, libpwquality -, systemd +{ + lib, + stdenv, + gettext, + fetchurl, + pkg-config, + udisks2, + libhandy, + libsecret, + libdvdread, + meson, + ninja, + gtk3, + glib, + wrapGAppsHook3, + libnotify, + itstool, + gnome, + gnome-settings-daemon, + adwaita-icon-theme, + libxml2, + gsettings-desktop-schemas, + libcanberra-gtk3, + libxslt, + docbook-xsl-nons, + desktop-file-utils, + libpwquality, + systemd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-doc-utils/package.nix b/pkgs/by-name/gn/gnome-doc-utils/package.nix index 5586ed5c2301bc..8b30095d119e6d 100644 --- a/pkgs/by-name/gn/gnome-doc-utils/package.nix +++ b/pkgs/by-name/gn/gnome-doc-utils/package.nix @@ -1,5 +1,15 @@ -{ lib, fetchurl, pkg-config, libxml2, libxslt, intltool, gnome -, python3Packages, fetchpatch, bash }: +{ + lib, + fetchurl, + pkg-config, + libxml2, + libxslt, + intltool, + gnome, + python3Packages, + fetchpatch, + bash, +}: python3Packages.buildPythonApplication rec { pname = "gnome-doc-utils"; @@ -25,8 +35,16 @@ python3Packages.buildPythonApplication rec { }) ]; - nativeBuildInputs = [ intltool pkg-config libxslt.dev ]; - buildInputs = [ libxml2 libxslt bash ]; + nativeBuildInputs = [ + intltool + pkg-config + libxslt.dev + ]; + buildInputs = [ + libxml2 + libxslt + bash + ]; propagatedBuildInputs = [ python3Packages.libxml2 ]; configureFlags = [ "--disable-scrollkeeper" ]; @@ -40,7 +58,10 @@ python3Packages.buildPythonApplication rec { meta = with lib; { description = "Collection of documentation utilities for the GNOME project"; homepage = "https://gitlab.gnome.org/GNOME/gnome-doc-utils"; - license = with licenses; [ gpl2Plus lgpl2Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/gn/gnome-epub-thumbnailer/package.nix b/pkgs/by-name/gn/gnome-epub-thumbnailer/package.nix index 3e0a8978b5e5cc..f8ed99ececdad3 100644 --- a/pkgs/by-name/gn/gnome-epub-thumbnailer/package.nix +++ b/pkgs/by-name/gn/gnome-epub-thumbnailer/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchurl -, wrapGAppsNoGuiHook -, meson -, ninja -, pkg-config -, gnome -, gdk-pixbuf -, glib -, libarchive -, librsvg -, libxml2 +{ + stdenv, + lib, + fetchurl, + wrapGAppsNoGuiHook, + meson, + ninja, + pkg-config, + gnome, + gdk-pixbuf, + glib, + libarchive, + librsvg, + libxml2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-extension-manager/package.nix b/pkgs/by-name/gn/gnome-extension-manager/package.nix index 02eb300c59ef0b..46ba29a2c73d63 100644 --- a/pkgs/by-name/gn/gnome-extension-manager/package.nix +++ b/pkgs/by-name/gn/gnome-extension-manager/package.nix @@ -1,24 +1,25 @@ -{ stdenv -, lib -, fetchFromGitHub -, wrapGAppsHook4 -, libadwaita -, meson -, ninja -, gettext -, gtk4 -, appstream -, appstream-glib -, desktop-file-utils -, gobject-introspection -, blueprint-compiler -, pkg-config -, json-glib -, libsoup_3 -, glib -, libbacktrace -, text-engine -, fetchpatch +{ + stdenv, + lib, + fetchFromGitHub, + wrapGAppsHook4, + libadwaita, + meson, + ninja, + gettext, + gtk4, + appstream, + appstream-glib, + desktop-file-utils, + gobject-introspection, + blueprint-compiler, + pkg-config, + json-glib, + libsoup_3, + glib, + libbacktrace, + text-engine, + fetchpatch, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-font-viewer/package.nix b/pkgs/by-name/gn/gnome-font-viewer/package.nix index a55cc20e32b670..02e80ca2ceec11 100644 --- a/pkgs/by-name/gn/gnome-font-viewer/package.nix +++ b/pkgs/by-name/gn/gnome-font-viewer/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, meson -, ninja -, gettext -, fetchurl -, pkg-config -, gtk4 -, glib -, libxml2 -, libadwaita -, fribidi -, wrapGAppsHook4 -, gnome -, harfbuzz +{ + lib, + stdenv, + meson, + ninja, + gettext, + fetchurl, + pkg-config, + gtk4, + glib, + libxml2, + libadwaita, + fribidi, + wrapGAppsHook4, + gnome, + harfbuzz, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-frog/package.nix b/pkgs/by-name/gn/gnome-frog/package.nix index 0facc24ce44cc3..b63c65f817953c 100644 --- a/pkgs/by-name/gn/gnome-frog/package.nix +++ b/pkgs/by-name/gn/gnome-frog/package.nix @@ -1,24 +1,25 @@ -{ lib -, fetchFromGitHub -, python3Packages -, wrapGAppsHook4 -, meson -, ninja -, pkg-config -, appstream-glib -, desktop-file-utils -, glib -, gobject-introspection -, blueprint-compiler -, libxml2 -, libnotify -, libadwaita -, libportal -, gettext -, librsvg -, tesseract5 -, zbar -, gst_all_1 +{ + lib, + fetchFromGitHub, + python3Packages, + wrapGAppsHook4, + meson, + ninja, + pkg-config, + appstream-glib, + desktop-file-utils, + glib, + gobject-introspection, + blueprint-compiler, + libxml2, + libnotify, + libadwaita, + libportal, + gettext, + librsvg, + tesseract5, + zbar, + gst_all_1, }: python3Packages.buildPythonApplication rec { @@ -89,8 +90,7 @@ python3Packages.buildPythonApplication rec { meta = with lib; { homepage = "https://getfrog.app/"; - description = - "Intuitive text extraction tool (OCR) for GNOME desktop"; + description = "Intuitive text extraction tool (OCR) for GNOME desktop"; license = licenses.mit; mainProgram = "frog"; maintainers = with maintainers; [ foo-dogsquared ]; diff --git a/pkgs/by-name/gn/gnome-graphs/package.nix b/pkgs/by-name/gn/gnome-graphs/package.nix index 3a635d515d791e..a0fe96ddfa9227 100644 --- a/pkgs/by-name/gn/gnome-graphs/package.nix +++ b/pkgs/by-name/gn/gnome-graphs/package.nix @@ -1,18 +1,19 @@ -{ lib -, python3Packages -, fetchFromGitLab -, meson -, ninja -, vala -, pkg-config -, gobject-introspection -, blueprint-compiler -, itstool -, wrapGAppsHook4 -, desktop-file-utils -, shared-mime-info -, libadwaita -, libgee +{ + lib, + python3Packages, + fetchFromGitLab, + meson, + ninja, + vala, + pkg-config, + gobject-introspection, + blueprint-compiler, + itstool, + wrapGAppsHook4, + desktop-file-utils, + shared-mime-info, + libadwaita, + libgee, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/gn/gnome-icon-theme/package.nix b/pkgs/by-name/gn/gnome-icon-theme/package.nix index 22289b73c466cf..f245d806342ce0 100644 --- a/pkgs/by-name/gn/gnome-icon-theme/package.nix +++ b/pkgs/by-name/gn/gnome-icon-theme/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, intltool, iconnamingutils, gtk2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + iconnamingutils, + gtk2, +}: stdenv.mkDerivation rec { pname = "gnome-icon-theme"; diff --git a/pkgs/by-name/gn/gnome-inform7/package.nix b/pkgs/by-name/gn/gnome-inform7/package.nix index e4cc850579285a..0c2aacc1a5bb1f 100644 --- a/pkgs/by-name/gn/gnome-inform7/package.nix +++ b/pkgs/by-name/gn/gnome-inform7/package.nix @@ -1,73 +1,105 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, pkg-config, python3, perl, bison -, texinfo, desktop-file-utils, wrapGAppsHook3, docbook2x, docbook-xsl-nons -, inform7, gettext, libossp_uuid, gtk3, gobject-introspection, vala, gtk-doc -, webkitgtk_4_0, gtksourceview3, gspell, libxml2, goocanvas2, libplist, glib -, gst_all_1 }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + python3, + perl, + bison, + texinfo, + desktop-file-utils, + wrapGAppsHook3, + docbook2x, + docbook-xsl-nons, + inform7, + gettext, + libossp_uuid, + gtk3, + gobject-introspection, + vala, + gtk-doc, + webkitgtk_4_0, + gtksourceview3, + gspell, + libxml2, + goocanvas2, + libplist, + glib, + gst_all_1, +}: # Neither gnome-inform7 nor its dependencies ratify and chimara have tagged releases in the GTK3 branch yet. let - ratify = (stdenv.mkDerivation { - pname = "ratify"; - version = "unstable-2021-02-21"; - src = fetchFromGitHub { - owner = "ptomato"; - repo = "ratify"; - rev = "f4d2d60ec73d5588e953650b3879e69a727f30ca"; - sha256 = "eRh/9pYvdfbdbdJQ7pYMLq5p91I+rtyb/AqEGfakjKs="; - }; - nativeBuildInputs = [ - meson - ninja - pkg-config - docbook2x - docbook-xsl-nons - wrapGAppsHook3 - gobject-introspection - ]; - buildInputs = [ - gtk3 - vala gtk-doc - ]; - }); + ratify = ( + stdenv.mkDerivation { + pname = "ratify"; + version = "unstable-2021-02-21"; + src = fetchFromGitHub { + owner = "ptomato"; + repo = "ratify"; + rev = "f4d2d60ec73d5588e953650b3879e69a727f30ca"; + sha256 = "eRh/9pYvdfbdbdJQ7pYMLq5p91I+rtyb/AqEGfakjKs="; + }; + nativeBuildInputs = [ + meson + ninja + pkg-config + docbook2x + docbook-xsl-nons + wrapGAppsHook3 + gobject-introspection + ]; + buildInputs = [ + gtk3 + vala + gtk-doc + ]; + } + ); - chimara = (stdenv.mkDerivation { - pname = "chimara"; - version = "unstable-2021-04-06"; - src = fetchFromGitHub { - owner = "chimara"; - repo = "Chimara"; - rev = "9934b142af508c75c0f1eed597990f39495b1af4"; - sha256 = "aRz1XX8XaSLTBIrMIIMS3QNMm6Msi+slrZ6+KYlyRMo="; - }; - nativeBuildInputs = [ - meson - ninja - pkg-config - perl - bison - texinfo - python3 - glib - wrapGAppsHook3 - gobject-introspection - ]; - buildInputs = [ - gtk3 - vala - gtk-doc - gst_all_1.gstreamer - gst_all_1.gst-plugins-base - gst_all_1.gst-plugins-good - gst_all_1.gst-plugins-bad - glib - ]; - preConfigure = '' - patchShebangs build-aux/meson_post_install.py - ''; - }); + chimara = ( + stdenv.mkDerivation { + pname = "chimara"; + version = "unstable-2021-04-06"; + src = fetchFromGitHub { + owner = "chimara"; + repo = "Chimara"; + rev = "9934b142af508c75c0f1eed597990f39495b1af4"; + sha256 = "aRz1XX8XaSLTBIrMIIMS3QNMm6Msi+slrZ6+KYlyRMo="; + }; + nativeBuildInputs = [ + meson + ninja + pkg-config + perl + bison + texinfo + python3 + glib + wrapGAppsHook3 + gobject-introspection + ]; + buildInputs = [ + gtk3 + vala + gtk-doc + gst_all_1.gstreamer + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-good + gst_all_1.gst-plugins-bad + glib + ]; + preConfigure = '' + patchShebangs build-aux/meson_post_install.py + ''; + } + ); -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "gnome-inform7"; version = "unstable-2021-04-06"; src = fetchFromGitHub { diff --git a/pkgs/by-name/gn/gnome-keyring/package.nix b/pkgs/by-name/gn/gnome-keyring/package.nix index 959a3de5890f43..199bbd40b1c3a4 100644 --- a/pkgs/by-name/gn/gnome-keyring/package.nix +++ b/pkgs/by-name/gn/gnome-keyring/package.nix @@ -1,31 +1,35 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, dbus -, libgcrypt -, pam -, python3 -, glib -, libxslt -, gettext -, gcr -, libcap_ng -, libselinux -, p11-kit -, openssh -, wrapGAppsHook3 -, docbook-xsl-nons -, docbook_xml_dtd_43 -, gnome -, useWrappedDaemon ? true +{ + lib, + stdenv, + fetchurl, + pkg-config, + dbus, + libgcrypt, + pam, + python3, + glib, + libxslt, + gettext, + gcr, + libcap_ng, + libselinux, + p11-kit, + openssh, + wrapGAppsHook3, + docbook-xsl-nons, + docbook_xml_dtd_43, + gnome, + useWrappedDaemon ? true, }: stdenv.mkDerivation rec { pname = "gnome-keyring"; version = "46.2"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/gnome-keyring/${lib.versions.major version}/gnome-keyring-${version}.tar.xz"; @@ -52,7 +56,10 @@ stdenv.mkDerivation rec { p11-kit ]; - nativeCheckInputs = [ dbus python3 ]; + nativeCheckInputs = [ + dbus + python3 + ]; configureFlags = [ "--with-pkcs11-config=${placeholder "out"}/etc/pkcs11/" # installation directories diff --git a/pkgs/by-name/gn/gnome-keysign/package.nix b/pkgs/by-name/gn/gnome-keysign/package.nix index af794097cf5524..ac9aaa330a2346 100644 --- a/pkgs/by-name/gn/gnome-keysign/package.nix +++ b/pkgs/by-name/gn/gnome-keysign/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitLab -, python3 -, wrapGAppsHook3 -, gobject-introspection -, gtk3 -, glib -, gst_all_1 +{ + lib, + fetchFromGitLab, + python3, + wrapGAppsHook3, + gobject-introspection, + gtk3, + glib, + gst_all_1, }: python3.pkgs.buildPythonApplication rec { @@ -20,13 +21,15 @@ python3.pkgs.buildPythonApplication rec { hash = "sha256-k77z8Yligzs4rHpPckRGcC5qnCHynHQRjdDkzxwt1Ss="; }; - nativeBuildInputs = [ - wrapGAppsHook3 - gobject-introspection - ] ++ (with python3.pkgs; [ - babel - babelgladeextractor - ]); + nativeBuildInputs = + [ + wrapGAppsHook3 + gobject-introspection + ] + ++ (with python3.pkgs; [ + babel + babelgladeextractor + ]); buildInputs = [ # TODO: add avahi support diff --git a/pkgs/by-name/gn/gnome-menus/package.nix b/pkgs/by-name/gn/gnome-menus/package.nix index 498641bbdc3070..247f7a529214e1 100644 --- a/pkgs/by-name/gn/gnome-menus/package.nix +++ b/pkgs/by-name/gn/gnome-menus/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, gettext, glib, gobject-introspection, gnome }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + glib, + gobject-introspection, + gnome, +}: stdenv.mkDerivation rec { pname = "gnome-menus"; @@ -14,7 +23,11 @@ stdenv.mkDerivation rec { "INTROSPECTION_TYPELIBDIR=${placeholder "out"}/lib/girepository-1.0" ]; - nativeBuildInputs = [ pkg-config gettext gobject-introspection ]; + nativeBuildInputs = [ + pkg-config + gettext + gobject-introspection + ]; buildInputs = [ glib ]; passthru = { @@ -27,7 +40,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://gitlab.gnome.org/GNOME/gnome-menus"; description = "Library that implements freedesktops's Desktop Menu Specification in GNOME"; - license = with licenses; [ gpl2 lgpl2 ]; + license = with licenses; [ + gpl2 + lgpl2 + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/gn/gnome-multi-writer/package.nix b/pkgs/by-name/gn/gnome-multi-writer/package.nix index f73016681c0eea..2f77f53d45d965 100644 --- a/pkgs/by-name/gn/gnome-multi-writer/package.nix +++ b/pkgs/by-name/gn/gnome-multi-writer/package.nix @@ -1,20 +1,22 @@ -{ lib, stdenv -, fetchurl -, appstream-glib -, desktop-file-utils -, gettext -, glib -, gnome -, gtk3 -, gusb -, libcanberra-gtk3 -, libgudev -, meson -, ninja -, pkg-config -, wrapGAppsHook3 -, polkit -, udisks +{ + lib, + stdenv, + fetchurl, + appstream-glib, + desktop-file-utils, + gettext, + glib, + gnome, + gtk3, + gusb, + libcanberra-gtk3, + libgudev, + meson, + ninja, + pkg-config, + wrapGAppsHook3, + polkit, + udisks, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-network-displays/package.nix b/pkgs/by-name/gn/gnome-network-displays/package.nix index 01c82aacd20980..849c4ab8becee1 100644 --- a/pkgs/by-name/gn/gnome-network-displays/package.nix +++ b/pkgs/by-name/gn/gnome-network-displays/package.nix @@ -1,28 +1,30 @@ -{ lib, stdenv -, fetchurl -# native -, meson -, ninja -, pkg-config -, gettext -, desktop-file-utils -, appstream-glib -, wrapGAppsHook4 -, python3 -# Not native -, gst_all_1 -, gsettings-desktop-schemas -, gtk4 -, avahi -, glib -, networkmanager -, json-glib -, libadwaita -, libportal-gtk4 -, libpulseaudio -, libsoup_3 -, pipewire -, protobufc +{ + lib, + stdenv, + fetchurl, + # native + meson, + ninja, + pkg-config, + gettext, + desktop-file-utils, + appstream-glib, + wrapGAppsHook4, + python3, + # Not native + gst_all_1, + gsettings-desktop-schemas, + gtk4, + avahi, + glib, + networkmanager, + json-glib, + libadwaita, + libportal-gtk4, + libpulseaudio, + libsoup_3, + pipewire, + protobufc, }: stdenv.mkDerivation (finalAttrs: { @@ -67,13 +69,14 @@ stdenv.mkDerivation (finalAttrs: { protobufc ]; - /* Without this flag, we get this include error: + /* + Without this flag, we get this include error: - /nix/store/...-gst-rtsp-server-1.22.8-dev/include/gstreamer-1.0/gst/rtsp-server/rtsp-media-factory.h:21:10: fatal error: gst/rtsp/gstrtspurl.h: No such file or directory - 21 | #include + /nix/store/...-gst-rtsp-server-1.22.8-dev/include/gstreamer-1.0/gst/rtsp-server/rtsp-media-factory.h:21:10: fatal error: gst/rtsp/gstrtspurl.h: No such file or directory + 21 | #include - Hence, this is not necessarily an upstream issue, but could be something - wrong with how our gst_all_1 depend on each other. + Hence, this is not necessarily an upstream issue, but could be something + wrong with how our gst_all_1 depend on each other. */ CFLAGS = "-I${gst_all_1.gst-plugins-base.dev}/include/gstreamer-1.0"; diff --git a/pkgs/by-name/gn/gnome-online-accounts-gtk/package.nix b/pkgs/by-name/gn/gnome-online-accounts-gtk/package.nix index 12e7dd52defedf..7dc2539d4b26ab 100644 --- a/pkgs/by-name/gn/gnome-online-accounts-gtk/package.nix +++ b/pkgs/by-name/gn/gnome-online-accounts-gtk/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, glib -, glib-networking -, gnome-online-accounts -, gtk4 -, libadwaita +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + glib, + glib-networking, + gnome-online-accounts, + gtk4, + libadwaita, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gn/gnome-online-accounts/package.nix b/pkgs/by-name/gn/gnome-online-accounts/package.nix index 61ca498ec1e3c4..49c2042498dd94 100644 --- a/pkgs/by-name/gn/gnome-online-accounts/package.nix +++ b/pkgs/by-name/gn/gnome-online-accounts/package.nix @@ -1,39 +1,48 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, vala -, glib -, meson -, ninja -, libxslt -, gtk4 -, enableBackend ? stdenv.hostPlatform.isLinux -, json-glib -, keyutils -, libadwaita -, librest_1_0 -, libxml2 -, libsecret -, gobject-introspection -, gettext -, gi-docgen -, glib-networking -, libsoup_3 -, docbook-xsl-nons -, gnome -, gcr_4 -, libkrb5 -, gvfs -, dbus -, wrapGAppsHook4 +{ + stdenv, + lib, + fetchurl, + pkg-config, + vala, + glib, + meson, + ninja, + libxslt, + gtk4, + enableBackend ? stdenv.hostPlatform.isLinux, + json-glib, + keyutils, + libadwaita, + librest_1_0, + libxml2, + libsecret, + gobject-introspection, + gettext, + gi-docgen, + glib-networking, + libsoup_3, + docbook-xsl-nons, + gnome, + gcr_4, + libkrb5, + gvfs, + dbus, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { pname = "gnome-online-accounts"; version = "3.52.2"; - outputs = [ "out" "dev" ] ++ lib.optionals enableBackend [ "man" "devdoc" ]; + outputs = + [ + "out" + "dev" + ] + ++ lib.optionals enableBackend [ + "man" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/gnome-online-accounts/${lib.versions.majorMinor finalAttrs.version}/gnome-online-accounts-${finalAttrs.version}.tar.xz"; @@ -62,22 +71,24 @@ stdenv.mkDerivation (finalAttrs: { wrapGAppsHook4 ]; - buildInputs = [ - gcr_4 - glib - glib-networking - gtk4 - libadwaita - gvfs # OwnCloud, Google Drive - json-glib - libkrb5 - librest_1_0 - libxml2 - libsecret - libsoup_3 - ] ++ lib.optionals enableBackend [ - keyutils - ]; + buildInputs = + [ + gcr_4 + glib + glib-networking + gtk4 + libadwaita + gvfs # OwnCloud, Google Drive + json-glib + libkrb5 + librest_1_0 + libxml2 + libsecret + libsoup_3 + ] + ++ lib.optionals enableBackend [ + keyutils + ]; postFixup = '' # Cannot be in postInstall, otherwise _multioutDocs hook in preFixup will move right back. diff --git a/pkgs/by-name/gn/gnome-packagekit/package.nix b/pkgs/by-name/gn/gnome-packagekit/package.nix index 173d6d4bd7c516..6ab6363dc50dbd 100644 --- a/pkgs/by-name/gn/gnome-packagekit/package.nix +++ b/pkgs/by-name/gn/gnome-packagekit/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, meson -, ninja -, gettext -, gnome -, packagekit -, polkit -, gtk3 -, systemd -, wrapGAppsHook3 -, desktop-file-utils +{ + lib, + stdenv, + fetchurl, + pkg-config, + meson, + ninja, + gettext, + gnome, + packagekit, + polkit, + gtk3, + systemd, + wrapGAppsHook3, + desktop-file-utils, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-photos/package.nix b/pkgs/by-name/gn/gnome-photos/package.nix index 6aad3a4b51ff63..199fa1f212463b 100644 --- a/pkgs/by-name/gn/gnome-photos/package.nix +++ b/pkgs/by-name/gn/gnome-photos/package.nix @@ -1,42 +1,46 @@ -{ stdenv -, lib -, fetchurl -, at-spi2-core -, babl -, dbus -, desktop-file-utils -, dleyna-renderer -, gdk-pixbuf -, gegl -, geocode-glib_2 -, gettext -, gexiv2 -, glib -, gnome-online-accounts -, gnome -, gobject-introspection -, gsettings-desktop-schemas -, gtk3 -, itstool -, libdazzle -, libportal-gtk3 -, libhandy -, libxml2 -, meson -, ninja -, nixosTests -, pkg-config -, python3 -, tinysparql -, localsearch -, wrapGAppsHook3 +{ + stdenv, + lib, + fetchurl, + at-spi2-core, + babl, + dbus, + desktop-file-utils, + dleyna-renderer, + gdk-pixbuf, + gegl, + geocode-glib_2, + gettext, + gexiv2, + glib, + gnome-online-accounts, + gnome, + gobject-introspection, + gsettings-desktop-schemas, + gtk3, + itstool, + libdazzle, + libportal-gtk3, + libhandy, + libxml2, + meson, + ninja, + nixosTests, + pkg-config, + python3, + tinysparql, + localsearch, + wrapGAppsHook3, }: stdenv.mkDerivation rec { pname = "gnome-photos"; version = "44.0"; - outputs = [ "out" "installedTests" ]; + outputs = [ + "out" + "installedTests" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.major version}/${pname}-${version}.tar.xz"; @@ -57,11 +61,13 @@ stdenv.mkDerivation rec { meson ninja pkg-config - (python3.withPackages (pkgs: with pkgs; [ - dogtail - pygobject3 - pyatspi - ])) + (python3.withPackages ( + pkgs: with pkgs; [ + dogtail + pygobject3 + pyatspi + ] + )) wrapGAppsHook3 ]; diff --git a/pkgs/by-name/gn/gnome-podcasts/package.nix b/pkgs/by-name/gn/gnome-podcasts/package.nix index 5625f15e3a2321..0cc31075ec52ca 100644 --- a/pkgs/by-name/gn/gnome-podcasts/package.nix +++ b/pkgs/by-name/gn/gnome-podcasts/package.nix @@ -1,24 +1,25 @@ -{ stdenv -, lib -, rustPlatform -, fetchFromGitLab -, cargo -, meson -, ninja -, gettext -, pkg-config -, rustc -, glib -, gtk4 -, libadwaita -, appstream-glib -, desktop-file-utils -, dbus -, openssl -, glib-networking -, sqlite -, gst_all_1 -, wrapGAppsHook4 +{ + stdenv, + lib, + rustPlatform, + fetchFromGitLab, + cargo, + meson, + ninja, + gettext, + pkg-config, + rustc, + glib, + gtk4, + libadwaita, + appstream-glib, + desktop-file-utils, + dbus, + openssl, + glib-networking, + sqlite, + gst_all_1, + wrapGAppsHook4, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-randr/package.nix b/pkgs/by-name/gn/gnome-randr/package.nix index ca136adb24a41c..4cd09ee2bcea54 100644 --- a/pkgs/by-name/gn/gnome-randr/package.nix +++ b/pkgs/by-name/gn/gnome-randr/package.nix @@ -1,8 +1,9 @@ -{ dbus -, fetchFromGitHub -, lib -, pkg-config -, rustPlatform +{ + dbus, + fetchFromGitHub, + lib, + pkg-config, + rustPlatform, }: let version = "0.1.1"; diff --git a/pkgs/by-name/gn/gnome-recipes/package.nix b/pkgs/by-name/gn/gnome-recipes/package.nix index 09a38f2cc506d6..c2eac8eb8baaf7 100644 --- a/pkgs/by-name/gn/gnome-recipes/package.nix +++ b/pkgs/by-name/gn/gnome-recipes/package.nix @@ -1,24 +1,25 @@ -{ stdenv -, lib -, fetchFromGitLab -, meson -, ninja -, pkg-config -, desktop-file-utils -, gettext -, itstool -, python3 -, wrapGAppsHook3 -, gtk3 -, glib -, libsoup_2_4 -, gnome-online-accounts -, librest -, json-glib -, gnome-autoar -, gspell -, libcanberra -, nix-update-script +{ + stdenv, + lib, + fetchFromGitLab, + meson, + ninja, + pkg-config, + desktop-file-utils, + gettext, + itstool, + python3, + wrapGAppsHook3, + gtk3, + glib, + libsoup_2_4, + gnome-online-accounts, + librest, + json-glib, + gnome-autoar, + gspell, + libcanberra, + nix-update-script, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-screenshot/package.nix b/pkgs/by-name/gn/gnome-screenshot/package.nix index ec62a734686ee6..1509e559ac3f44 100644 --- a/pkgs/by-name/gn/gnome-screenshot/package.nix +++ b/pkgs/by-name/gn/gnome-screenshot/package.nix @@ -1,23 +1,24 @@ -{ stdenv -, lib -, gettext -, libxml2 -, libhandy -, fetchurl -, fetchpatch -, pkg-config -, libcanberra-gtk3 -, gtk3 -, glib -, meson -, ninja -, python3 -, wrapGAppsHook3 -, appstream-glib -, desktop-file-utils -, gnome -, adwaita-icon-theme -, gsettings-desktop-schemas +{ + stdenv, + lib, + gettext, + libxml2, + libhandy, + fetchurl, + fetchpatch, + pkg-config, + libcanberra-gtk3, + gtk3, + glib, + meson, + ninja, + python3, + wrapGAppsHook3, + appstream-glib, + desktop-file-utils, + gnome, + adwaita-icon-theme, + gsettings-desktop-schemas, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-secrets/package.nix b/pkgs/by-name/gn/gnome-secrets/package.nix index 62f8fdf6f2c216..26bee490ac4acc 100644 --- a/pkgs/by-name/gn/gnome-secrets/package.nix +++ b/pkgs/by-name/gn/gnome-secrets/package.nix @@ -1,18 +1,19 @@ -{ lib -, meson -, ninja -, pkg-config -, gettext -, fetchFromGitLab -, python3Packages -, wrapGAppsHook4 -, gtk4 -, glib -, gdk-pixbuf -, gobject-introspection -, desktop-file-utils -, appstream-glib -, libadwaita +{ + lib, + meson, + ninja, + pkg-config, + gettext, + fetchFromGitLab, + python3Packages, + wrapGAppsHook4, + gtk4, + glib, + gdk-pixbuf, + gobject-introspection, + desktop-file-utils, + appstream-glib, + libadwaita, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/gn/gnome-solanum/package.nix b/pkgs/by-name/gn/gnome-solanum/package.nix index 07dd24a6169506..4b90c5f74cb0c6 100644 --- a/pkgs/by-name/gn/gnome-solanum/package.nix +++ b/pkgs/by-name/gn/gnome-solanum/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitLab -, rustPlatform -, cargo -, desktop-file-utils -, appstream-glib -, blueprint-compiler -, meson -, ninja -, pkg-config -, rustc -, wrapGAppsHook4 -, python3 -, git -, glib -, gtk4 -, gst_all_1 -, libadwaita +{ + lib, + stdenv, + fetchFromGitLab, + rustPlatform, + cargo, + desktop-file-utils, + appstream-glib, + blueprint-compiler, + meson, + ninja, + pkg-config, + rustc, + wrapGAppsHook4, + python3, + git, + glib, + gtk4, + gst_all_1, + libadwaita, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-system-monitor/package.nix b/pkgs/by-name/gn/gnome-system-monitor/package.nix index 8d04c0e1c8b884..394a5104488bc4 100644 --- a/pkgs/by-name/gn/gnome-system-monitor/package.nix +++ b/pkgs/by-name/gn/gnome-system-monitor/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, gettext -, fetchurl -, pkg-config -, gtkmm4 -, libxml2 -, bash -, gtk4 -, libadwaita -, glib -, wrapGAppsHook4 -, meson -, ninja -, gsettings-desktop-schemas -, itstool -, gnome -, adwaita-icon-theme -, librsvg -, gdk-pixbuf -, libgtop -, systemd +{ + lib, + stdenv, + gettext, + fetchurl, + pkg-config, + gtkmm4, + libxml2, + bash, + gtk4, + libadwaita, + glib, + wrapGAppsHook4, + meson, + ninja, + gsettings-desktop-schemas, + itstool, + gnome, + adwaita-icon-theme, + librsvg, + gdk-pixbuf, + libgtop, + systemd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-tecla/package.nix b/pkgs/by-name/gn/gnome-tecla/package.nix index 467956204a54a7..d26e2ce841d52b 100644 --- a/pkgs/by-name/gn/gnome-tecla/package.nix +++ b/pkgs/by-name/gn/gnome-tecla/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, glib -, gtk4 -, libadwaita -, libxkbcommon -, wayland -, gnome +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + glib, + gtk4, + libadwaita, + libxkbcommon, + wayland, + gnome, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gn/gnome-terminal/package.nix b/pkgs/by-name/gn/gnome-terminal/package.nix index 755df84ffd30db..d5d0c055c05948 100644 --- a/pkgs/by-name/gn/gnome-terminal/package.nix +++ b/pkgs/by-name/gn/gnome-terminal/package.nix @@ -1,30 +1,31 @@ -{ stdenv -, lib -, fetchFromGitLab -, meson -, ninja -, pkg-config -, python3 -, libxml2 -, gitUpdater -, nautilus -, glib -, gtk4 -, gtk3 -, libhandy -, gsettings-desktop-schemas -, vte -, gettext -, which -, libuuid -, vala -, desktop-file-utils -, itstool -, wrapGAppsHook3 -, pcre2 -, libxslt -, docbook-xsl-nons -, nixosTests +{ + stdenv, + lib, + fetchFromGitLab, + meson, + ninja, + pkg-config, + python3, + libxml2, + gitUpdater, + nautilus, + glib, + gtk4, + gtk3, + libhandy, + gsettings-desktop-schemas, + vte, + gettext, + which, + libuuid, + vala, + desktop-file-utils, + itstool, + wrapGAppsHook3, + pcre2, + libxslt, + docbook-xsl-nons, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gn/gnome-themes-extra/package.nix b/pkgs/by-name/gn/gnome-themes-extra/package.nix index 64d3d4c1a0fe31..2809c19928e8d7 100644 --- a/pkgs/by-name/gn/gnome-themes-extra/package.nix +++ b/pkgs/by-name/gn/gnome-themes-extra/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchurl, intltool, gtk3, gnome, adwaita-icon-theme, librsvg, pkg-config, pango, atk, gtk2 -, gdk-pixbuf, hicolor-icon-theme }: +{ + lib, + stdenv, + fetchurl, + intltool, + gtk3, + gnome, + adwaita-icon-theme, + librsvg, + pkg-config, + pango, + atk, + gtk2, + gdk-pixbuf, + hicolor-icon-theme, +}: stdenv.mkDerivation rec { pname = "gnome-themes-extra"; @@ -16,9 +30,23 @@ stdenv.mkDerivation rec { }; }; - nativeBuildInputs = [ pkg-config intltool gtk3 ]; - buildInputs = [ gtk3 librsvg pango atk gtk2 gdk-pixbuf ]; - propagatedBuildInputs = [ adwaita-icon-theme hicolor-icon-theme ]; + nativeBuildInputs = [ + pkg-config + intltool + gtk3 + ]; + buildInputs = [ + gtk3 + librsvg + pango + atk + gtk2 + gdk-pixbuf + ]; + propagatedBuildInputs = [ + adwaita-icon-theme + hicolor-icon-theme + ]; dontDropIconThemeCache = true; diff --git a/pkgs/by-name/gn/gnome-tweaks/package.nix b/pkgs/by-name/gn/gnome-tweaks/package.nix index 075b2d777ec3f2..3235ea91d606eb 100644 --- a/pkgs/by-name/gn/gnome-tweaks/package.nix +++ b/pkgs/by-name/gn/gnome-tweaks/package.nix @@ -1,28 +1,29 @@ -{ lib -, meson -, ninja -, fetchurl -, desktop-file-utils -, gdk-pixbuf -, gettext -, glib -, gnome -, gnome-desktop -, gnome-settings-daemon -, gnome-shell -, gnome-shell-extensions -, gobject-introspection -, gsettings-desktop-schemas -, gtk4 -, itstool -, libadwaita -, libgudev -, libnotify -, libxml2 -, mutter -, pkg-config -, python3Packages -, wrapGAppsHook4 +{ + lib, + meson, + ninja, + fetchurl, + desktop-file-utils, + gdk-pixbuf, + gettext, + glib, + gnome, + gnome-desktop, + gnome-settings-daemon, + gnome-shell, + gnome-shell-extensions, + gobject-introspection, + gsettings-desktop-schemas, + gtk4, + itstool, + libadwaita, + libgudev, + libnotify, + libxml2, + mutter, + pkg-config, + python3Packages, + wrapGAppsHook4, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/gn/gnome-usage/package.nix b/pkgs/by-name/gn/gnome-usage/package.nix index 3b4f550c64ba8d..311470c94e1360 100644 --- a/pkgs/by-name/gn/gnome-usage/package.nix +++ b/pkgs/by-name/gn/gnome-usage/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, vala -, gettext -, libxml2 -, desktop-file-utils -, wrapGAppsHook4 -, glib -, gtk4 -, libadwaita -, libgee -, libgtop -, gnome -, tinysparql +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + vala, + gettext, + libxml2, + desktop-file-utils, + wrapGAppsHook4, + glib, + gtk4, + libadwaita, + libgee, + libgtop, + gnome, + tinysparql, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-user-docs/package.nix b/pkgs/by-name/gn/gnome-user-docs/package.nix index 7ced971bcbbc2c..460e342adef11c 100644 --- a/pkgs/by-name/gn/gnome-user-docs/package.nix +++ b/pkgs/by-name/gn/gnome-user-docs/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchurl -, gettext -, gnome -, itstool -, libxml2 -, yelp-tools +{ + lib, + stdenv, + fetchurl, + gettext, + gnome, + itstool, + libxml2, + yelp-tools, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnome-user-share/package.nix b/pkgs/by-name/gn/gnome-user-share/package.nix index f63afe6c5ac836..5a281dbe782864 100644 --- a/pkgs/by-name/gn/gnome-user-share/package.nix +++ b/pkgs/by-name/gn/gnome-user-share/package.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, gettext -, meson -, ninja -, fetchurl -, apacheHttpdPackages -, pkg-config -, glib -, libxml2 -, systemd -, wrapGAppsNoGuiHook -, itstool -, gnome +{ + stdenv, + lib, + gettext, + meson, + ninja, + fetchurl, + apacheHttpdPackages, + pkg-config, + glib, + libxml2, + systemd, + wrapGAppsNoGuiHook, + itstool, + gnome, }: let diff --git a/pkgs/by-name/gn/gnome-video-effects/package.nix b/pkgs/by-name/gn/gnome-video-effects/package.nix index a4cedd6c918738..cbf601a2d39a98 100644 --- a/pkgs/by-name/gn/gnome-video-effects/package.nix +++ b/pkgs/by-name/gn/gnome-video-effects/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchurl -, pkg-config -, meson -, ninja -, gettext -, gnome +{ + lib, + stdenv, + fetchurl, + pkg-config, + meson, + ninja, + gettext, + gnome, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnomecast/package.nix b/pkgs/by-name/gn/gnomecast/package.nix index bea389ccc53420..6c6c741a964287 100644 --- a/pkgs/by-name/gn/gnomecast/package.nix +++ b/pkgs/by-name/gn/gnomecast/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, python3Packages, fetchFromGitHub, gtk3, gobject-introspection, ffmpeg, wrapGAppsHook3 }: +{ + stdenv, + lib, + python3Packages, + fetchFromGitHub, + gtk3, + gobject-introspection, + ffmpeg, + wrapGAppsHook3, +}: with python3Packages; buildPythonApplication rec { diff --git a/pkgs/by-name/gn/gnonograms/package.nix b/pkgs/by-name/gn/gnonograms/package.nix index 57f38d61bbb5a4..02ee9be1acd46e 100644 --- a/pkgs/by-name/gn/gnonograms/package.nix +++ b/pkgs/by-name/gn/gnonograms/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, vala -, meson -, ninja -, pkg-config -, desktop-file-utils -, appstream -, python3 -, shared-mime-info -, wrapGAppsHook3 -, gtk3 -, pantheon -, libgee -, libhandy +{ + lib, + stdenv, + fetchFromGitHub, + vala, + meson, + ninja, + pkg-config, + desktop-file-utils, + appstream, + python3, + shared-mime-info, + wrapGAppsHook3, + gtk3, + pantheon, + libgee, + libhandy, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gn/gnostic/package.nix b/pkgs/by-name/gn/gnostic/package.nix index e6c2b665c215af..44ea7bf06a62ef 100644 --- a/pkgs/by-name/gn/gnostic/package.nix +++ b/pkgs/by-name/gn/gnostic/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gnostic"; diff --git a/pkgs/by-name/gn/gnote/package.nix b/pkgs/by-name/gn/gnote/package.nix index 935645a05f2dc7..b197c07bcc9bb4 100644 --- a/pkgs/by-name/gn/gnote/package.nix +++ b/pkgs/by-name/gn/gnote/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchurl -, desktop-file-utils -, gettext -, gtkmm4 -, itstool -, libadwaita -, libsecret -, libuuid -, libxml2 -, libxslt -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, gnome +{ + lib, + stdenv, + fetchurl, + desktop-file-utils, + gettext, + gtkmm4, + itstool, + libadwaita, + libsecret, + libuuid, + libxml2, + libxslt, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + gnome, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnss-sdr/package.nix b/pkgs/by-name/gn/gnss-sdr/package.nix index 948acd2f19c0e0..e3a242b42d5320 100644 --- a/pkgs/by-name/gn/gnss-sdr/package.nix +++ b/pkgs/by-name/gn/gnss-sdr/package.nix @@ -1,21 +1,24 @@ -{ lib -, fetchFromGitHub -, armadillo -, cmake -, gmp -, glog -, gtest -, openssl -, gflags -, gnuradio -, thrift -, enableRawUdp ? true, libpcap -, orc -, pkg-config -, blas, lapack -, matio -, pugixml -, protobuf +{ + lib, + fetchFromGitHub, + armadillo, + cmake, + gmp, + glog, + gtest, + openssl, + gflags, + gnuradio, + thrift, + enableRawUdp ? true, + libpcap, + orc, + pkg-config, + blas, + lapack, + matio, + pugixml, + protobuf, }: gnuradio.pkgs.mkDerivation rec { @@ -47,31 +50,38 @@ gnuradio.pkgs.mkDerivation rec { gtest ]; - buildInputs = [ - gmp - armadillo - glog - gflags - openssl - orc - blas lapack - matio - pugixml - protobuf - gnuradio.unwrapped.boost - gnuradio.unwrapped.logLib - ] ++ lib.optionals (gnuradio.hasFeature "gr-uhd") [ - gnuradio.unwrapped.uhd - ] ++ lib.optionals (enableRawUdp) [ - libpcap - ] ++ lib.optionals (gnuradio.hasFeature "gr-ctrlport") [ - thrift - gnuradio.unwrapped.python.pkgs.thrift - ] ++ lib.optionals (gnuradio.hasFeature "gr-pdu" || gnuradio.hasFeature "gr-iio") [ - gnuradio.unwrapped.libiio - ] ++ lib.optionals (gnuradio.hasFeature "gr-pdu") [ - gnuradio.unwrapped.libad9361 - ]; + buildInputs = + [ + gmp + armadillo + glog + gflags + openssl + orc + blas + lapack + matio + pugixml + protobuf + gnuradio.unwrapped.boost + gnuradio.unwrapped.logLib + ] + ++ lib.optionals (gnuradio.hasFeature "gr-uhd") [ + gnuradio.unwrapped.uhd + ] + ++ lib.optionals (enableRawUdp) [ + libpcap + ] + ++ lib.optionals (gnuradio.hasFeature "gr-ctrlport") [ + thrift + gnuradio.unwrapped.python.pkgs.thrift + ] + ++ lib.optionals (gnuradio.hasFeature "gr-pdu" || gnuradio.hasFeature "gr-iio") [ + gnuradio.unwrapped.libiio + ] + ++ lib.optionals (gnuradio.hasFeature "gr-pdu") [ + gnuradio.unwrapped.libad9361 + ]; cmakeFlags = [ (lib.cmakeFeature "GFlags_INCLUDE_DIRS" "${gflags}/include") diff --git a/pkgs/by-name/gn/gnss-share/package.nix b/pkgs/by-name/gn/gnss-share/package.nix index 391234103078d1..4c99144b05ffa4 100644 --- a/pkgs/by-name/gn/gnss-share/package.nix +++ b/pkgs/by-name/gn/gnss-share/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitLab, lib }: +{ + buildGoModule, + fetchFromGitLab, + lib, +}: buildGoModule rec { pname = "gnss-share"; version = "0.8.1"; diff --git a/pkgs/by-name/gn/gnu-cim/package.nix b/pkgs/by-name/gn/gnu-cim/package.nix index bf5b93c712fc5d..bf2835959ff112 100644 --- a/pkgs/by-name/gn/gnu-cim/package.nix +++ b/pkgs/by-name/gn/gnu-cim/package.nix @@ -1,13 +1,19 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { pname = "gnu-cim"; version = "5.1"; - outputs = ["out" "lib" "man" "info"]; + outputs = [ + "out" + "lib" + "man" + "info" + ]; src = fetchurl { url = "mirror://gnu/cim/cim-${version}.tar.gz"; diff --git a/pkgs/by-name/gn/gnu-config/package.nix b/pkgs/by-name/gn/gnu-config/package.nix index 9fa5247cb489be..0c4d6c16a870b6 100644 --- a/pkgs/by-name/gn/gnu-config/package.nix +++ b/pkgs/by-name/gn/gnu-config/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: # Note: this package is used for bootstrapping fetchurl, and thus # cannot use fetchpatch! All mutable patches (generated by GitHub or @@ -19,7 +23,8 @@ let url = "https://git.savannah.gnu.org/cgit/config.git/plain/config.sub?id=${rev}"; hash = "sha256-/jovMvuv9XhIcyVJ9I2YP9ZSYCTsLw9ancdcL0NZo6Y="; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "gnu-config"; version = "2024-01-01"; @@ -58,7 +63,10 @@ in stdenv.mkDerivation { # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that # program. - maintainers = with maintainers; [ dezgeg emilytrau ]; + maintainers = with maintainers; [ + dezgeg + emilytrau + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/gn/gnu-pw-mgr/package.nix b/pkgs/by-name/gn/gnu-pw-mgr/package.nix index 0e1c8c0f589ebd..3b49797654b19c 100644 --- a/pkgs/by-name/gn/gnu-pw-mgr/package.nix +++ b/pkgs/by-name/gn/gnu-pw-mgr/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchurl, gnulib }: +{ + stdenv, + lib, + fetchurl, + gnulib, +}: stdenv.mkDerivation rec { pname = "gnu-pw-mgr"; @@ -13,7 +18,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://www.gnu.org/software/gnu-pw-mgr/"; description = "Password manager designed to make it easy to reconstruct difficult passwords"; - license = with licenses; [ gpl3Plus lgpl3Plus ]; + license = with licenses; [ + gpl3Plus + lgpl3Plus + ]; platforms = lib.platforms.linux; maintainers = with maintainers; [ qoelet ]; }; diff --git a/pkgs/by-name/gn/gnu-smalltalk/package.nix b/pkgs/by-name/gn/gnu-smalltalk/package.nix index 68ebbad63ca2b7..678aa56b0562ee 100644 --- a/pkgs/by-name/gn/gnu-smalltalk/package.nix +++ b/pkgs/by-name/gn/gnu-smalltalk/package.nix @@ -1,21 +1,39 @@ -{ config, lib, stdenv, fetchurl, pkg-config, libtool -, zip, libffi, libsigsegv, readline, gmp -, gnutls, gtk2, cairo, SDL, sqlite -, emacsSupport ? config.emacsSupport or false, emacs ? null }: +{ + config, + lib, + stdenv, + fetchurl, + pkg-config, + libtool, + zip, + libffi, + libsigsegv, + readline, + gmp, + gnutls, + gtk2, + cairo, + SDL, + sqlite, + emacsSupport ? config.emacsSupport or false, + emacs ? null, +}: assert emacsSupport -> (emacs != null); -let # The gnu-smalltalk project has a dependency to the libsigsegv library. - # The project ships with sources for this library, but deprecated this option. - # Using the vanilla libsigsegv library results in error: "cannot relocate [...]" - # Adding --enable-static=libsigsegv to the gnu-smalltalk configuration flags - # does not help, the error still occurs. The only solution is to build a - # shared version of libsigsegv. - libsigsegv-shared = lib.overrideDerivation libsigsegv (oldAttrs: { - configureFlags = [ "--enable-shared" ]; - }); +let + # The gnu-smalltalk project has a dependency to the libsigsegv library. + # The project ships with sources for this library, but deprecated this option. + # Using the vanilla libsigsegv library results in error: "cannot relocate [...]" + # Adding --enable-static=libsigsegv to the gnu-smalltalk configuration flags + # does not help, the error still occurs. The only solution is to build a + # shared version of libsigsegv. + libsigsegv-shared = lib.overrideDerivation libsigsegv (oldAttrs: { + configureFlags = [ "--enable-shared" ]; + }); -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { version = "3.2.5"; pname = "gnu-smalltalk"; @@ -35,10 +53,18 @@ in stdenv.mkDerivation rec { # http://smalltalk.gnu.org/download nativeBuildInputs = [ pkg-config ]; buildInputs = [ - libtool zip libffi libsigsegv-shared readline gmp gnutls gtk2 - cairo SDL sqlite - ] - ++ lib.optional emacsSupport emacs; + libtool + zip + libffi + libsigsegv-shared + readline + gmp + gnutls + gtk2 + cairo + SDL + sqlite + ] ++ lib.optional emacsSupport emacs; configureFlags = lib.optional (!emacsSupport) "--without-emacs"; @@ -59,7 +85,10 @@ in stdenv.mkDerivation rec { language, well-versed to scripting tasks. ''; homepage = "http://smalltalk.gnu.org/"; - license = with licenses; [ gpl2 lgpl2 ]; + license = with licenses; [ + gpl2 + lgpl2 + ]; platforms = platforms.linux; maintainers = with maintainers; [ AndersonTorres ]; }; diff --git a/pkgs/by-name/gn/gnuapl/package.nix b/pkgs/by-name/gn/gnuapl/package.nix index ee4d8482cd41a8..de762f653ffa4f 100644 --- a/pkgs/by-name/gn/gnuapl/package.nix +++ b/pkgs/by-name/gn/gnuapl/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, readline, gettext, ncurses }: +{ + lib, + stdenv, + fetchurl, + readline, + gettext, + ncurses, +}: stdenv.mkDerivation rec { pname = "gnu-apl"; @@ -9,23 +16,30 @@ stdenv.mkDerivation rec { sha256 = "sha256-KRhn8bGTdpOrtXvn2aN2GLA3bj4nCVdIVKe75Suyjrg="; }; - buildInputs = [ readline gettext ncurses ]; - - env.NIX_CFLAGS_COMPILE = toString ((lib.optionals stdenv.cc.isGNU [ - # Needed with GCC 8 - "-Wno-error=int-in-bool-context" - "-Wno-error=class-memaccess" - "-Wno-error=restrict" - "-Wno-error=format-truncation" - # Needed with GCC 10 - "-Wno-error=maybe-uninitialized" - # Needed with GCC 11 - "-Wno-error=misleading-indentation" - # Needed with GCC 12 - "-Wno-error=nonnull" - "-Wno-error=stringop-overflow" - "-Wno-error=use-after-free" - ]) ++ lib.optional stdenv.cc.isClang "-Wno-error=null-dereference"); + buildInputs = [ + readline + gettext + ncurses + ]; + + env.NIX_CFLAGS_COMPILE = toString ( + (lib.optionals stdenv.cc.isGNU [ + # Needed with GCC 8 + "-Wno-error=int-in-bool-context" + "-Wno-error=class-memaccess" + "-Wno-error=restrict" + "-Wno-error=format-truncation" + # Needed with GCC 10 + "-Wno-error=maybe-uninitialized" + # Needed with GCC 11 + "-Wno-error=misleading-indentation" + # Needed with GCC 12 + "-Wno-error=nonnull" + "-Wno-error=stringop-overflow" + "-Wno-error=use-after-free" + ]) + ++ lib.optional stdenv.cc.isClang "-Wno-error=null-dereference" + ); patchPhase = lib.optionalString stdenv.hostPlatform.isDarwin '' substituteInPlace src/LApack.cc --replace "malloc.h" "malloc/malloc.h" @@ -39,10 +53,10 @@ stdenv.mkDerivation rec { meta = with lib; { broken = stdenv.hostPlatform.isDarwin; description = "Free interpreter for the APL programming language"; - homepage = "https://www.gnu.org/software/apl/"; - license = licenses.gpl3Plus; + homepage = "https://www.gnu.org/software/apl/"; + license = licenses.gpl3Plus; maintainers = [ maintainers.kovirobi ]; - platforms = with platforms; linux ++ darwin; + platforms = with platforms; linux ++ darwin; mainProgram = "apl"; longDescription = '' diff --git a/pkgs/by-name/gn/gnuastro/package.nix b/pkgs/by-name/gn/gnuastro/package.nix index 3d38dbcfd4c87f..50215965fe1ebf 100644 --- a/pkgs/by-name/gn/gnuastro/package.nix +++ b/pkgs/by-name/gn/gnuastro/package.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchurl, libtool -, cfitsio, curl, ghostscript, gsl, libgit2, libjpeg, libtiff, lzlib, wcslib }: +{ + lib, + stdenv, + fetchurl, + libtool, + cfitsio, + curl, + ghostscript, + gsl, + libgit2, + libjpeg, + libtiff, + lzlib, + wcslib, +}: stdenv.mkDerivation rec { pname = "gnuastro"; diff --git a/pkgs/by-name/gn/gnubg/package.nix b/pkgs/by-name/gn/gnubg/package.nix index 18d5698fd23e76..020f042546f1c2 100644 --- a/pkgs/by-name/gn/gnubg/package.nix +++ b/pkgs/by-name/gn/gnubg/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, python3, gtk2, readline, - copyDesktopItems, makeDesktopItem }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + python3, + gtk2, + readline, + copyDesktopItems, + makeDesktopItem, +}: stdenv.mkDerivation rec { pname = "gnubg"; @@ -10,13 +20,24 @@ stdenv.mkDerivation rec { hash = "sha256-cjmXKUGcrZ8RLDBmoS0AANpFCkVq3XsJTYkVUGnWgh4="; }; - nativeBuildInputs = [ copyDesktopItems pkg-config python3 glib ]; + nativeBuildInputs = [ + copyDesktopItems + pkg-config + python3 + glib + ]; - buildInputs = [ gtk2 readline ]; + buildInputs = [ + gtk2 + readline + ]; strictDeps = true; - configureFlags = [ "--with-gtk" "--with--board3d" ]; + configureFlags = [ + "--with-gtk" + "--with--board3d" + ]; desktopItems = [ (makeDesktopItem { @@ -26,15 +47,19 @@ stdenv.mkDerivation rec { comment = meta.description; exec = pname; icon = pname; - categories = [ "Game" "GTK" "StrategyGame" ]; + categories = [ + "Game" + "GTK" + "StrategyGame" + ]; }) ]; - meta = with lib; - { description = "World class backgammon application"; - homepage = "https://www.gnu.org/software/gnubg/"; - license = licenses.gpl3; - maintainers = [ maintainers.ehmry ]; - platforms = platforms.linux; - }; + meta = with lib; { + description = "World class backgammon application"; + homepage = "https://www.gnu.org/software/gnubg/"; + license = licenses.gpl3; + maintainers = [ maintainers.ehmry ]; + platforms = platforms.linux; + }; } diff --git a/pkgs/by-name/gn/gnucap/modelgen-verilog.nix b/pkgs/by-name/gn/gnucap/modelgen-verilog.nix index d6d6902f54a93f..6a29673563d2bc 100644 --- a/pkgs/by-name/gn/gnucap/modelgen-verilog.nix +++ b/pkgs/by-name/gn/gnucap/modelgen-verilog.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, gnucap +{ + lib, + stdenv, + fetchurl, + gnucap, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnucap/package.nix b/pkgs/by-name/gn/gnucap/package.nix index 2713a2283de6d6..56a4a67ca7e663 100644 --- a/pkgs/by-name/gn/gnucap/package.nix +++ b/pkgs/by-name/gn/gnucap/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, readline -, termcap -, gnucap -, callPackage -, writeScript +{ + lib, + stdenv, + fetchurl, + readline, + termcap, + gnucap, + callPackage, + writeScript, }: let @@ -13,8 +14,8 @@ let meta = with lib; { description = "Gnu Circuit Analysis Package"; longDescription = '' -Gnucap is a modern general purpose circuit simulator with several advantages over Spice derivatives. -It performs nonlinear dc and transient analyses, fourier analysis, and ac analysis. + Gnucap is a modern general purpose circuit simulator with several advantages over Spice derivatives. + It performs nonlinear dc and transient analyses, fourier analysis, and ac analysis. ''; homepage = "http://www.gnucap.org/"; changelog = "https://git.savannah.gnu.org/cgit/gnucap.git/plain/NEWS?h=v${version}"; @@ -42,9 +43,11 @@ stdenv.mkDerivation rec { doCheck = true; inherit meta; -} // { - plugins = callPackage ./plugins.nix {}; - withPlugins = p: +} +// { + plugins = callPackage ./plugins.nix { }; + withPlugins = + p: let selectedPlugins = p gnucap.plugins; wrapper = writeScript "gnucap" '' @@ -55,19 +58,19 @@ stdenv.mkDerivation rec { ${lib.getExe gnucap} ''; in - stdenv.mkDerivation { - pname = "gnucap-with-plugins"; - inherit version; + stdenv.mkDerivation { + pname = "gnucap-with-plugins"; + inherit version; - propagatedBuildInputs = selectedPlugins; + propagatedBuildInputs = selectedPlugins; - dontUnpack = true; + dontUnpack = true; - installPhase = '' - mkdir -p $out/bin - cp ${wrapper} $out/bin/gnucap - ''; + installPhase = '' + mkdir -p $out/bin + cp ${wrapper} $out/bin/gnucap + ''; - inherit meta; - }; + inherit meta; + }; } diff --git a/pkgs/by-name/gn/gnucap/plugins.nix b/pkgs/by-name/gn/gnucap/plugins.nix index fbdcd9548b3348..b1125310d71643 100644 --- a/pkgs/by-name/gn/gnucap/plugins.nix +++ b/pkgs/by-name/gn/gnucap/plugins.nix @@ -1,6 +1,7 @@ -{ callPackage +{ + callPackage, }: { - verilog = callPackage ./modelgen-verilog.nix {}; + verilog = callPackage ./modelgen-verilog.nix { }; } diff --git a/pkgs/by-name/gn/gnucash/package.nix b/pkgs/by-name/gn/gnucash/package.nix index a966522b9825ce..1fabe4ffbf0461 100644 --- a/pkgs/by-name/gn/gnucash/package.nix +++ b/pkgs/by-name/gn/gnucash/package.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchurl -, fetchpatch2 -, aqbanking -, boost -, cmake -, gettext -, glib -, glibcLocales -, gtest -, guile -, gwenhywfar -, icu -, libdbi -, libdbiDrivers -, libofx -, libxml2 -, libxslt -, makeWrapper -, perlPackages -, pkg-config -, swig -, webkitgtk_4_0 -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + fetchpatch2, + aqbanking, + boost, + cmake, + gettext, + glib, + glibcLocales, + gtest, + guile, + gwenhywfar, + icu, + libdbi, + libdbiDrivers, + libofx, + libxml2, + libxslt, + makeWrapper, + perlPackages, + pkg-config, + swig, + webkitgtk_4_0, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -44,28 +45,29 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - aqbanking - boost - glib - glibcLocales - gtest - guile - gwenhywfar - icu - libdbi - libdbiDrivers - libofx - libxml2 - libxslt - swig - webkitgtk_4_0 - ] - ++ (with perlPackages; [ - JSONParse - FinanceQuote - perl - ]); + buildInputs = + [ + aqbanking + boost + glib + glibcLocales + gtest + guile + gwenhywfar + icu + libdbi + libdbiDrivers + libofx + libxml2 + libxslt + swig + webkitgtk_4_0 + ] + ++ (with perlPackages; [ + JSONParse + FinanceQuote + perl + ]); patches = [ # this patch disables test-gnc-timezone and test-gnc-datetime which fail due to nix datetime challenges @@ -88,10 +90,12 @@ stdenv.mkDerivation rec { # guile warning env.GUILE_AUTO_COMPILE = "0"; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ - # Needed with GCC 12 but breaks on darwin (with clang) or older gcc - "-Wno-error=use-after-free" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ + # Needed with GCC 12 but breaks on darwin (with clang) or older gcc + "-Wno-error=use-after-free" + ] + ); doCheck = true; enableParallelChecking = true; @@ -109,7 +113,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libxml2 libxslt ]; + buildInputs = [ + libxml2 + libxslt + ]; }; preFixup = '' @@ -134,7 +141,13 @@ stdenv.mkDerivation rec { wrapProgram $out/bin/gnucash-cli "''${gappsWrapperArgs[@]}" wrapProgram $out/bin/finance-quote-wrapper \ - --prefix PERL5LIB : "${with perlPackages; makeFullPerlPath [ JSONParse FinanceQuote ]}" + --prefix PERL5LIB : "${ + with perlPackages; + makeFullPerlPath [ + JSONParse + FinanceQuote + ] + }" ''; passthru.updateScript = ./update.sh; @@ -163,7 +176,11 @@ stdenv.mkDerivation rec { - Financial Calculations ''; license = licenses.gpl2Plus; - maintainers = with maintainers; [ domenkozar rski nevivurn ]; + maintainers = with maintainers; [ + domenkozar + rski + nevivurn + ]; platforms = platforms.unix; mainProgram = "gnucash"; }; diff --git a/pkgs/by-name/gn/gnuchess/package.nix b/pkgs/by-name/gn/gnuchess/package.nix index 7e1bdd1d48cee2..8c140d6fc48ea7 100644 --- a/pkgs/by-name/gn/gnuchess/package.nix +++ b/pkgs/by-name/gn/gnuchess/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, flex, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + flex, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "gnuchess"; diff --git a/pkgs/by-name/gn/gnuclad/package.nix b/pkgs/by-name/gn/gnuclad/package.nix index a263746ef9acb1..8c86be58e15437 100644 --- a/pkgs/by-name/gn/gnuclad/package.nix +++ b/pkgs/by-name/gn/gnuclad/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchurl, pkg-config +{ + stdenv, + lib, + fetchurl, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gn/gnugo/package.nix b/pkgs/by-name/gn/gnugo/package.nix index 82848ab008052b..b6c994ec4613af 100644 --- a/pkgs/by-name/gn/gnugo/package.nix +++ b/pkgs/by-name/gn/gnugo/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "gnugo"; diff --git a/pkgs/by-name/gn/gnujump/package.nix b/pkgs/by-name/gn/gnujump/package.nix index a9806cf81f8d4e..d490033e08ace2 100644 --- a/pkgs/by-name/gn/gnujump/package.nix +++ b/pkgs/by-name/gn/gnujump/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, makeDesktopItem, copyDesktopItems, fetchurl, SDL, SDL_image, SDL_mixer }: +{ + lib, + stdenv, + makeDesktopItem, + copyDesktopItems, + fetchurl, + SDL, + SDL_image, + SDL_mixer, +}: stdenv.mkDerivation (finalAttrs: { pname = "gnujump"; @@ -9,18 +18,27 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ copyDesktopItems ]; - buildInputs = [ SDL SDL_image SDL_mixer ]; + buildInputs = [ + SDL + SDL_image + SDL_mixer + ]; NIX_LDFLAGS = "-lm"; - desktopItems = [ (makeDesktopItem { - name = "gnujump"; - exec = "gnujump"; - icon = "gnujump"; - desktopName = "GNUjump"; - comment = "Jump up the tower to survive"; - categories = [ "Game" "ArcadeGame" ]; - }) ]; + desktopItems = [ + (makeDesktopItem { + name = "gnujump"; + exec = "gnujump"; + icon = "gnujump"; + desktopName = "GNUjump"; + comment = "Jump up the tower to survive"; + categories = [ + "Game" + "ArcadeGame" + ]; + }) + ]; postInstall = '' install -Dm644 ${./gnujump.xpm} $out/share/pixmaps/gnujump.xpm diff --git a/pkgs/by-name/gn/gnulib/package.nix b/pkgs/by-name/gn/gnulib/package.nix index 42159a21cd91cc..6a9d2fe5894bab 100644 --- a/pkgs/by-name/gn/gnulib/package.nix +++ b/pkgs/by-name/gn/gnulib/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchgit, python3, perl }: +{ + lib, + stdenv, + fetchgit, + python3, + perl, +}: stdenv.mkDerivation rec { pname = "gnulib"; diff --git a/pkgs/by-name/gn/gnum4/package.nix b/pkgs/by-name/gn/gnum4/package.nix index 5dea7f0595574e..1b264ffc1290fa 100644 --- a/pkgs/by-name/gn/gnum4/package.nix +++ b/pkgs/by-name/gn/gnum4/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: # Note: this package is used for bootstrapping fetchurl, and thus # cannot use fetchpatch! All mutable patches (generated by GitHub or @@ -18,12 +22,14 @@ stdenv.mkDerivation rec { patches = lib.optional stdenv.hostPlatform.isLoongArch64 ./loong-fix-build.patch; # this could be accomplished by updateAutotoolsGnuConfigScriptsHook, but that causes infinite recursion # necessary for FreeBSD code path in configure - postPatch = '' - substituteInPlace ./build-aux/config.guess --replace-fail /usr/bin/uname uname - '' + lib.optionalString stdenv.hostPlatform.isLoongArch64 '' - touch ./aclocal.m4 ./lib/config.hin ./configure ./doc/stamp-vti || die - find . -name Makefile.in -exec touch {} + || die - ''; + postPatch = + '' + substituteInPlace ./build-aux/config.guess --replace-fail /usr/bin/uname uname + '' + + lib.optionalString stdenv.hostPlatform.isLoongArch64 '' + touch ./aclocal.m4 ./lib/config.hin ./configure ./doc/stamp-vti || die + find . -name Makefile.in -exec touch {} + || die + ''; strictDeps = true; @@ -31,8 +37,9 @@ stdenv.mkDerivation rec { doCheck = false; - configureFlags = [ "--with-syscmd-shell=${stdenv.shell}" ] - ++ lib.optional stdenv.hostPlatform.isMinGW "CFLAGS=-fno-stack-protector"; + configureFlags = [ + "--with-syscmd-shell=${stdenv.shell}" + ] ++ lib.optional stdenv.hostPlatform.isMinGW "CFLAGS=-fno-stack-protector"; meta = { description = "GNU M4, a macro processor"; diff --git a/pkgs/by-name/gn/gnumake42/package.nix b/pkgs/by-name/gn/gnumake42/package.nix index 1afadceb9b7709..dc323447af9b03 100644 --- a/pkgs/by-name/gn/gnumake42/package.nix +++ b/pkgs/by-name/gn/gnumake42/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchurl, guileSupport ? false, pkg-config ? null , guile ? null }: +{ + lib, + stdenv, + fetchurl, + guileSupport ? false, + pkg-config ? null, + guile ? null, +}: -assert guileSupport -> ( pkg-config != null && guile != null ); +assert guileSupport -> (pkg-config != null && guile != null); stdenv.mkDerivation rec { pname = "gnumake"; @@ -26,7 +33,8 @@ stdenv.mkDerivation rec { nativeBuildInputs = lib.optionals guileSupport [ pkg-config ]; buildInputs = lib.optionals guileSupport [ guile ]; - configureFlags = lib.optional guileSupport "--with-guile" + configureFlags = + lib.optional guileSupport "--with-guile" # Make uses this test to decide whether it should keep track of # subseconds. Apple made this possible with APFS and macOS 10.13. @@ -37,7 +45,11 @@ stdenv.mkDerivation rec { # See https://github.com/NixOS/nixpkgs/issues/51221 for discussion. ++ lib.optional stdenv.hostPlatform.isDarwin "ac_cv_struct_st_mtim_nsec=no"; - outputs = [ "out" "man" "info" ]; + outputs = [ + "out" + "man" + "info" + ]; meta = with lib; { description = "Tool to control the generation of non-source files from sources"; diff --git a/pkgs/by-name/gn/gnumeric/package.nix b/pkgs/by-name/gn/gnumeric/package.nix index 04588486de4edb..f67aeb28724110 100644 --- a/pkgs/by-name/gn/gnumeric/package.nix +++ b/pkgs/by-name/gn/gnumeric/package.nix @@ -1,11 +1,24 @@ -{ lib, stdenv, fetchurl, pkg-config, intltool, perlPackages -, goffice, gnome, adwaita-icon-theme, wrapGAppsHook3, gtk3, bison, python3Packages -, itstool +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + perlPackages, + goffice, + gnome, + adwaita-icon-theme, + wrapGAppsHook3, + gtk3, + bison, + python3Packages, + itstool, }: let inherit (python3Packages) python pygobject3; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "gnumeric"; version = "1.12.57"; @@ -16,13 +29,27 @@ in stdenv.mkDerivation rec { configureFlags = [ "--disable-component" ]; - nativeBuildInputs = [ pkg-config intltool bison itstool wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + intltool + bison + itstool + wrapGAppsHook3 + ]; # ToDo: optional libgda, introspection? - buildInputs = [ - goffice gtk3 adwaita-icon-theme - python pygobject3 - ] ++ (with perlPackages; [ perl XMLParser ]); + buildInputs = + [ + goffice + gtk3 + adwaita-icon-theme + python + pygobject3 + ] + ++ (with perlPackages; [ + perl + XMLParser + ]); enableParallelBuilding = true; diff --git a/pkgs/by-name/gn/gnupg-pkcs11-scd/package.nix b/pkgs/by-name/gn/gnupg-pkcs11-scd/package.nix index e594fde69dac2c..750efe12ff778f 100644 --- a/pkgs/by-name/gn/gnupg-pkcs11-scd/package.nix +++ b/pkgs/by-name/gn/gnupg-pkcs11-scd/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchurl, libgpg-error, libassuan, libgcrypt, pkcs11helper, - pkg-config, openssl }: +{ + lib, + stdenv, + fetchurl, + libgpg-error, + libassuan, + libgcrypt, + pkcs11helper, + pkg-config, + openssl, +}: stdenv.mkDerivation rec { pname = "gnupg-pkcs11-scd"; @@ -11,7 +20,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ pkcs11helper openssl ]; + buildInputs = [ + pkcs11helper + openssl + ]; configureFlags = [ "--with-libgpg-error-prefix=${libgpg-error.dev}" @@ -23,13 +35,15 @@ stdenv.mkDerivation rec { description = "Smart-card daemon to enable the use of PKCS#11 tokens with GnuPG"; mainProgram = "gnupg-pkcs11-scd"; longDescription = '' - gnupg-pkcs11 is a project to implement a BSD-licensed smart-card - daemon to enable the use of PKCS#11 tokens with GnuPG. + gnupg-pkcs11 is a project to implement a BSD-licensed smart-card + daemon to enable the use of PKCS#11 tokens with GnuPG. ''; homepage = "https://gnupg-pkcs11.sourceforge.net/"; license = licenses.bsd3; - maintainers = with maintainers; [ matthiasbeyer philandstuff ]; + maintainers = with maintainers; [ + matthiasbeyer + philandstuff + ]; platforms = platforms.unix; }; } - diff --git a/pkgs/by-name/gn/gnupth/package.nix b/pkgs/by-name/gn/gnupth/package.nix index 3d4c056b71dd53..0f105195f057d2 100644 --- a/pkgs/by-name/gn/gnupth/package.nix +++ b/pkgs/by-name/gn/gnupth/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "pth"; @@ -9,11 +13,13 @@ stdenv.mkDerivation rec { sha256 = "0ckjqw5kz5m30srqi87idj7xhpw6bpki43mj07bazjm2qmh3cdbj"; }; - preConfigure = lib.optionalString stdenv.hostPlatform.isAarch32 '' - configureFlagsArray=("CFLAGS=-DJB_SP=8 -DJB_PC=9") - '' + lib.optionalString (stdenv.hostPlatform.libc == "glibc") '' - configureFlagsArray+=("ac_cv_check_sjlj=ssjlj") - ''; + preConfigure = + lib.optionalString stdenv.hostPlatform.isAarch32 '' + configureFlagsArray=("CFLAGS=-DJB_SP=8 -DJB_PC=9") + '' + + lib.optionalString (stdenv.hostPlatform.libc == "glibc") '' + configureFlagsArray+=("ac_cv_check_sjlj=ssjlj") + ''; # Fails parallel build due to missing dependency on autogenrated # 'pth_p.h' file: diff --git a/pkgs/by-name/gn/gnushogi/package.nix b/pkgs/by-name/gn/gnushogi/package.nix index 38f76de1e7a0e1..56d063b50bce90 100644 --- a/pkgs/by-name/gn/gnushogi/package.nix +++ b/pkgs/by-name/gn/gnushogi/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, zlib +{ + lib, + stdenv, + fetchurl, + fetchpatch, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/go/go-2fa/package.nix b/pkgs/by-name/go/go-2fa/package.nix index 7261eb605c088b..55d777523dd2a0 100644 --- a/pkgs/by-name/go/go-2fa/package.nix +++ b/pkgs/by-name/go/go-2fa/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "2fa"; @@ -14,7 +18,10 @@ buildGoModule rec { deleteVendor = true; vendorHash = "sha256-4h/+ZNxlJPYY0Kyu2vDE1pDXxC/kGE5JdnagWVOGzAE="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://rsc.io/2fa"; diff --git a/pkgs/by-name/go/go-audit/package.nix b/pkgs/by-name/go/go-audit/package.nix index 722fdad702c536..f562f8fb8c516a 100644 --- a/pkgs/by-name/go/go-audit/package.nix +++ b/pkgs/by-name/go/go-audit/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/go/go-autoconfig/package.nix b/pkgs/by-name/go/go-autoconfig/package.nix index 1fe09a03a0dd64..b5af6a7f3f89e9 100644 --- a/pkgs/by-name/go/go-autoconfig/package.nix +++ b/pkgs/by-name/go/go-autoconfig/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/go/go-bare/package.nix b/pkgs/by-name/go/go-bare/package.nix index 5a9b024e337c1d..7b739d210bff9a 100644 --- a/pkgs/by-name/go/go-bare/package.nix +++ b/pkgs/by-name/go/go-bare/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromSourcehut, lib }: +{ + buildGoModule, + fetchFromSourcehut, + lib, +}: buildGoModule rec { pname = "go-bare"; diff --git a/pkgs/by-name/go/go-bindata-assetfs/package.nix b/pkgs/by-name/go/go-bindata-assetfs/package.nix index 02188707760214..0d6e3eb7a6a6aa 100644 --- a/pkgs/by-name/go/go-bindata-assetfs/package.nix +++ b/pkgs/by-name/go/go-bindata-assetfs/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-bindata-assetfs"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Serve embedded files from jteeuwen/go-bindata"; diff --git a/pkgs/by-name/go/go-bindata/package.nix b/pkgs/by-name/go/go-bindata/package.nix index 7877313b9d50c8..d3f48c5bdd348c 100644 --- a/pkgs/by-name/go/go-bindata/package.nix +++ b/pkgs/by-name/go/go-bindata/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-bindata"; @@ -15,7 +19,10 @@ buildGoModule rec { subPackages = [ "go-bindata" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/kevinburke/go-bindata"; diff --git a/pkgs/by-name/go/go-callvis/package.nix b/pkgs/by-name/go/go-callvis/package.nix index a954781fb28f9c..47834b5e8d68f0 100644 --- a/pkgs/by-name/go/go-callvis/package.nix +++ b/pkgs/by-name/go/go-callvis/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-AfbUxA5C5dH70+vqC+1RGaTt7S0FL9CBcxel0ifmHKs="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; # Build errors in github.com/goccy/go-graphviz/internal/ccall when format hardening is enabled: # cc1: error: '-Wformat-security' ignored without '-Wformat' [-Werror=format-security] diff --git a/pkgs/by-name/go/go-camo/package.nix b/pkgs/by-name/go/go-camo/package.nix index 20172d75473eba..7c9c331ccbdc57 100644 --- a/pkgs/by-name/go/go-camo/package.nix +++ b/pkgs/by-name/go/go-camo/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-camo"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-GbBFGbNxsijcUIogjSv8RcIQn6VQ+j21Qlm9eQWzTtc="; - ldflags = [ "-s" "-w" "-X=main.ServerVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.ServerVersion=${version}" + ]; preCheck = '' # requires network access diff --git a/pkgs/by-name/go/go-check/package.nix b/pkgs/by-name/go/go-check/package.nix index 1de7a49f3180e5..4e32ea4d7109d5 100644 --- a/pkgs/by-name/go/go-check/package.nix +++ b/pkgs/by-name/go/go-check/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitLab +{ + lib, + buildGoModule, + fetchFromGitLab, }: buildGoModule rec { diff --git a/pkgs/by-name/go/go-containerregistry/package.nix b/pkgs/by-name/go/go-containerregistry/package.nix index 6e3a68bf232381..2b1a28f408ad47 100644 --- a/pkgs/by-name/go/go-containerregistry/package.nix +++ b/pkgs/by-name/go/go-containerregistry/package.nix @@ -1,6 +1,16 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: -let bins = [ "crane" "gcrane" ]; in +let + bins = [ + "crane" + "gcrane" + ]; +in buildGoModule rec { pname = "go-containerregistry"; @@ -16,13 +26,23 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - subPackages = [ "cmd/crane" "cmd/gcrane" ]; + subPackages = [ + "cmd/crane" + "cmd/gcrane" + ]; outputs = [ "out" ] ++ bins; ldflags = - let t = "github.com/google/go-containerregistry"; in - [ "-s" "-w" "-X ${t}/cmd/crane/cmd.Version=v${version}" "-X ${t}/pkg/v1/remote/transport.Version=${version}" ]; + let + t = "github.com/google/go-containerregistry"; + in + [ + "-s" + "-w" + "-X ${t}/cmd/crane/cmd.Version=v${version}" + "-X ${t}/pkg/v1/remote/transport.Version=${version}" + ]; postInstall = lib.concatStringsSep "\n" ( @@ -31,7 +51,8 @@ buildGoModule rec { mv $out/bin/${bin} ''$${bin}/bin/ && ln -s ''$${bin}/bin/${bin} $out/bin/ '') bins - ) + '' + ) + + '' for cmd in crane gcrane; do installShellCompletion --cmd "$cmd" \ --bash <($GOPATH/bin/$cmd completion bash) \ diff --git a/pkgs/by-name/go/go-cover-treemap/package.nix b/pkgs/by-name/go/go-cover-treemap/package.nix index 1afb9191607a24..de358e4c8428db 100644 --- a/pkgs/by-name/go/go-cover-treemap/package.nix +++ b/pkgs/by-name/go/go-cover-treemap/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-k/k+EGkuBnZFHrcWxnzLG8efWgb2i35Agf/sWbgTc4g="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Go code coverage to SVG treemap"; diff --git a/pkgs/by-name/go/go-cqhttp/package.nix b/pkgs/by-name/go/go-cqhttp/package.nix index 87347f0e26d4b3..5fb59710c74e32 100644 --- a/pkgs/by-name/go/go-cqhttp/package.nix +++ b/pkgs/by-name/go/go-cqhttp/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/go/go-critic/package.nix b/pkgs/by-name/go/go-critic/package.nix index a3515da9ed4384..90924172f49a7f 100644 --- a/pkgs/by-name/go/go-critic/package.nix +++ b/pkgs/by-name/go/go-critic/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, nix-update-script -, go-critic +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + nix-update-script, + go-critic, }: buildGoModule rec { diff --git a/pkgs/by-name/go/go-cve-search/package.nix b/pkgs/by-name/go/go-cve-search/package.nix index e7eb19729ffb86..80e8a4e580c2d0 100644 --- a/pkgs/by-name/go/go-cve-search/package.nix +++ b/pkgs/by-name/go/go-cve-search/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/go-dork/package.nix b/pkgs/by-name/go/go-dork/package.nix index a92f8957e3ad22..5afffba56e3cda 100644 --- a/pkgs/by-name/go/go-dork/package.nix +++ b/pkgs/by-name/go/go-dork/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/go-errorlint/package.nix b/pkgs/by-name/go/go-errorlint/package.nix index 6c7252d04274cc..d0bfac3a4cefdb 100644 --- a/pkgs/by-name/go/go-errorlint/package.nix +++ b/pkgs/by-name/go/go-errorlint/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-pSajd2wyefHgxMvhDKs+qwre4BMRBv97v/tZOjiT3LE="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Source code linter that can be used to find code that will cause problems with Go's error wrapping scheme"; diff --git a/pkgs/by-name/go/go-ethereum/package.nix b/pkgs/by-name/go/go-ethereum/package.nix index db9e37156cd47e..2f54653f4a5d01 100644 --- a/pkgs/by-name/go/go-ethereum/package.nix +++ b/pkgs/by-name/go/go-ethereum/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, libobjc, IOKit, nixosTests }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + libobjc, + IOKit, + nixosTests, +}: let # A list of binaries to put into separate outputs @@ -7,7 +15,8 @@ let "clef" ]; -in buildGoModule rec { +in +buildGoModule rec { pname = "go-ethereum"; version = "1.14.12"; @@ -27,7 +36,10 @@ in buildGoModule rec { # Move binaries to separate outputs and symlink them back to $out postInstall = lib.concatStringsSep "\n" ( - builtins.map (bin: "mkdir -p \$${bin}/bin && mv $out/bin/${bin} \$${bin}/bin/ && ln -s \$${bin}/bin/${bin} $out/bin/") bins + builtins.map ( + bin: + "mkdir -p \$${bin}/bin && mv $out/bin/${bin} \$${bin}/bin/ && ln -s \$${bin}/bin/${bin} $out/bin/" + ) bins ); subPackages = [ @@ -49,15 +61,20 @@ in buildGoModule rec { tags = [ "urfave_cli_no_docs" ]; # Fix for usb-related segmentation faults on darwin - propagatedBuildInputs = - lib.optionals stdenv.hostPlatform.isDarwin [ libobjc IOKit ]; + propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + IOKit + ]; passthru.tests = { inherit (nixosTests) geth; }; meta = with lib; { homepage = "https://geth.ethereum.org/"; description = "Official golang implementation of the Ethereum protocol"; - license = with licenses; [ lgpl3Plus gpl3Plus ]; + license = with licenses; [ + lgpl3Plus + gpl3Plus + ]; maintainers = with maintainers; [ RaghavSood ]; mainProgram = "geth"; }; diff --git a/pkgs/by-name/go/go-exploitdb/package.nix b/pkgs/by-name/go/go-exploitdb/package.nix index de2fd3426fe3f7..d5e75b85cb359c 100644 --- a/pkgs/by-name/go/go-exploitdb/package.nix +++ b/pkgs/by-name/go/go-exploitdb/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/go-font/package.nix b/pkgs/by-name/go/go-font/package.nix index db96e3183e2620..436647f5906231 100644 --- a/pkgs/by-name/go/go-font/package.nix +++ b/pkgs/by-name/go/go-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "go-font"; diff --git a/pkgs/by-name/go/go-jet/package.nix b/pkgs/by-name/go/go-jet/package.nix index b2a2aec97a9c67..4519fa55af6315 100644 --- a/pkgs/by-name/go/go-jet/package.nix +++ b/pkgs/by-name/go/go-jet/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-jet"; diff --git a/pkgs/by-name/go/go-jira/package.nix b/pkgs/by-name/go/go-jira/package.nix index a3d31d034ee5ea..35ad7824760088 100644 --- a/pkgs/by-name/go/go-jira/package.nix +++ b/pkgs/by-name/go/go-jira/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-jira"; @@ -19,6 +23,9 @@ buildGoModule rec { description = "Simple command line client for Atlassian's Jira service written in Go"; homepage = "https://github.com/go-jira/jira"; license = licenses.asl20; - maintainers = with maintainers; [ carlosdagos timstott ]; + maintainers = with maintainers; [ + carlosdagos + timstott + ]; }; } diff --git a/pkgs/by-name/go/go-jsonnet/package.nix b/pkgs/by-name/go/go-jsonnet/package.nix index 8f419a189e82e4..8e531e01a1d2a0 100644 --- a/pkgs/by-name/go/go-jsonnet/package.nix +++ b/pkgs/by-name/go/go-jsonnet/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, go-jsonnet }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + go-jsonnet, +}: buildGoModule rec { pname = "go-jsonnet"; @@ -24,7 +30,10 @@ buildGoModule rec { description = "Implementation of Jsonnet in pure Go"; homepage = "https://github.com/google/go-jsonnet"; license = licenses.asl20; - maintainers = with maintainers; [ nshalman aaronjheng ]; + maintainers = with maintainers; [ + nshalman + aaronjheng + ]; mainProgram = "jsonnet"; }; } diff --git a/pkgs/by-name/go/go-junit-report/package.nix b/pkgs/by-name/go/go-junit-report/package.nix index c8a7322b42c530..a6eabc0b573f55 100644 --- a/pkgs/by-name/go/go-junit-report/package.nix +++ b/pkgs/by-name/go/go-junit-report/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-junit-report"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-+KmC7m6xdkWTT/8MkGaW9gqkzeZ6LWL0DXbt+12iTHY="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Convert go test output to junit xml"; diff --git a/pkgs/by-name/go/go-landlock/package.nix b/pkgs/by-name/go/go-landlock/package.nix index 91ed7c1ff2bdcd..52c1e7890a368a 100644 --- a/pkgs/by-name/go/go-landlock/package.nix +++ b/pkgs/by-name/go/go-landlock/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/go-libp2p-daemon/package.nix b/pkgs/by-name/go/go-libp2p-daemon/package.nix index 8e046826832838..0f9c7e06dc5a2c 100644 --- a/pkgs/by-name/go/go-libp2p-daemon/package.nix +++ b/pkgs/by-name/go/go-libp2p-daemon/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-libp2p-daemon"; diff --git a/pkgs/by-name/go/go-license-detector/package.nix b/pkgs/by-name/go/go-license-detector/package.nix index a59b55be975d8b..2b5be457f2525c 100644 --- a/pkgs/by-name/go/go-license-detector/package.nix +++ b/pkgs/by-name/go/go-license-detector/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, git }: +{ + lib, + buildGoModule, + fetchFromGitHub, + git, +}: buildGoModule rec { pname = "go-license-detector"; diff --git a/pkgs/by-name/go/go-licenses/package.nix b/pkgs/by-name/go/go-licenses/package.nix index 6d1e6dce160903..b63583d49298cc 100644 --- a/pkgs/by-name/go/go-licenses/package.nix +++ b/pkgs/by-name/go/go-licenses/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, go -, installShellFiles -, makeWrapper +{ + lib, + buildGoModule, + fetchFromGitHub, + go, + installShellFiles, + makeWrapper, }: buildGoModule rec { diff --git a/pkgs/by-name/go/go-md2man/package.nix b/pkgs/by-name/go/go-md2man/package.nix index b66584b90a9317..bd2c19f824d2de 100644 --- a/pkgs/by-name/go/go-md2man/package.nix +++ b/pkgs/by-name/go/go-md2man/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-md2man"; @@ -18,6 +22,6 @@ buildGoModule rec { mainProgram = "go-md2man"; license = licenses.mit; homepage = "https://github.com/cpuguy83/go-md2man"; - maintainers = with maintainers; [offline]; + maintainers = with maintainers; [ offline ]; }; } diff --git a/pkgs/by-name/go/go-migrate/package.nix b/pkgs/by-name/go/go-migrate/package.nix index 35c8c320cf2158..a78acdc7941da5 100644 --- a/pkgs/by-name/go/go-migrate/package.nix +++ b/pkgs/by-name/go/go-migrate/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-migrate"; @@ -16,7 +20,31 @@ buildGoModule rec { subPackages = [ "cmd/migrate" ]; - tags = [ "cassandra" "clickhouse" "cockroachdb" "crate" "firebird" "mongodb" "multistmt" "mysql" "neo4j" "pgx" "pgx5" "postgres" "ql" "redshift" "rqlite" "shell" "snowflake" "spanner" "sqlite3" "sqlserver" "stub" "testing" "yugabytedb" ]; + tags = [ + "cassandra" + "clickhouse" + "cockroachdb" + "crate" + "firebird" + "mongodb" + "multistmt" + "mysql" + "neo4j" + "pgx" + "pgx5" + "postgres" + "ql" + "redshift" + "rqlite" + "shell" + "snowflake" + "spanner" + "sqlite3" + "sqlserver" + "stub" + "testing" + "yugabytedb" + ]; meta = with lib; { homepage = "https://github.com/golang-migrate/migrate"; diff --git a/pkgs/by-name/go/go-minimock/package.nix b/pkgs/by-name/go/go-minimock/package.nix index 4b82975d5bc6f1..1db5ad7e457cd9 100644 --- a/pkgs/by-name/go/go-minimock/package.nix +++ b/pkgs/by-name/go/go-minimock/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-minimock"; @@ -12,14 +16,19 @@ buildGoModule rec { }; ldflags = [ - "-s" "-w" "-X main.version=${version}" + "-s" + "-w" + "-X main.version=${version}" ]; vendorHash = "sha256-zk5ulVxn7qAsU5i5z6eG0OMN5ExSu/ceBKu8UMwoiPo="; doCheck = true; - subPackages = [ "cmd/minimock" "." ]; + subPackages = [ + "cmd/minimock" + "." + ]; meta = with lib; { homepage = "https://github.com/gojuno/minimock"; diff --git a/pkgs/by-name/go/go-mod-graph-chart/package.nix b/pkgs/by-name/go/go-mod-graph-chart/package.nix index 8540e014839458..9a435833bba9e3 100644 --- a/pkgs/by-name/go/go-mod-graph-chart/package.nix +++ b/pkgs/by-name/go/go-mod-graph-chart/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/go-motion/package.nix b/pkgs/by-name/go/go-motion/package.nix index 3db974affe13de..9a950ac864076d 100644 --- a/pkgs/by-name/go/go-motion/package.nix +++ b/pkgs/by-name/go/go-motion/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "motion"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Navigation and insight in Go"; diff --git a/pkgs/by-name/go/go-mtpfs/package.nix b/pkgs/by-name/go/go-mtpfs/package.nix index 26655053574e5d..f6e6e667cc5972 100644 --- a/pkgs/by-name/go/go-mtpfs/package.nix +++ b/pkgs/by-name/go/go-mtpfs/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, pkg-config, libusb1 }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + pkg-config, + libusb1, +}: buildGoModule rec { pname = "go-mtpfs"; @@ -13,7 +20,10 @@ buildGoModule rec { vendorHash = "sha256-OrAEvD2rF0Y0bvCD9TUv/E429lASsvC3uK3qNvbg734="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeBuildInputs = [ pkg-config ]; buildInputs = [ libusb1 ]; diff --git a/pkgs/by-name/go/go-neb/package.nix b/pkgs/by-name/go/go-neb/package.nix index 6b4528dfe289c5..c6ad42add09172 100644 --- a/pkgs/by-name/go/go-neb/package.nix +++ b/pkgs/by-name/go/go-neb/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, nixosTests, olm }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + nixosTests, + olm, +}: buildGoModule { pname = "go-neb"; @@ -26,6 +33,9 @@ buildGoModule { mainProgram = "go-neb"; homepage = "https://github.com/matrix-org/go-neb"; license = licenses.asl20; - maintainers = with maintainers; [ hexa maralorn ]; + maintainers = with maintainers; [ + hexa + maralorn + ]; }; } diff --git a/pkgs/by-name/go/go-org/package.nix b/pkgs/by-name/go/go-org/package.nix index 4b0a2a9c41a7b1..dabed8503e2571 100644 --- a/pkgs/by-name/go/go-org/package.nix +++ b/pkgs/by-name/go/go-org/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "go-org"; diff --git a/pkgs/by-name/go/go-outline/package.nix b/pkgs/by-name/go/go-outline/package.nix index c8f7f4efa5020f..25ce29dd69deec 100644 --- a/pkgs/by-name/go/go-outline/package.nix +++ b/pkgs/by-name/go/go-outline/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-outline"; diff --git a/pkgs/by-name/go/go-passbolt-cli/package.nix b/pkgs/by-name/go/go-passbolt-cli/package.nix index e774769ae45e0f..fcf19ff37cda2a 100644 --- a/pkgs/by-name/go/go-passbolt-cli/package.nix +++ b/pkgs/by-name/go/go-passbolt-cli/package.nix @@ -1,4 +1,10 @@ -{ buildGoModule, fetchFromGitHub, installShellFiles, lib, stdenv }: +{ + buildGoModule, + fetchFromGitHub, + installShellFiles, + lib, + stdenv, +}: buildGoModule rec { pname = "go-passbolt-cli"; diff --git a/pkgs/by-name/go/go-protobuf/package.nix b/pkgs/by-name/go/go-protobuf/package.nix index aa8c8df12e8693..b55e3b15a3ebe7 100644 --- a/pkgs/by-name/go/go-protobuf/package.nix +++ b/pkgs/by-name/go/go-protobuf/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-protobuf"; @@ -14,9 +18,9 @@ buildGoModule rec { vendorHash = "sha256-jGAWUgW0DA7EwmlzVxnBmtbf2dp+P4Qwcb8mTAEhUi4="; meta = with lib; { - homepage = "https://github.com/golang/protobuf"; + homepage = "https://github.com/golang/protobuf"; description = " Go bindings for protocol buffer"; maintainers = with maintainers; [ lewo ]; - license = licenses.bsd3; + license = licenses.bsd3; }; } diff --git a/pkgs/by-name/go/go-rice/package.nix b/pkgs/by-name/go/go-rice/package.nix index 4c3fd6ef4c0683..f98384bd270f7a 100644 --- a/pkgs/by-name/go/go-rice/package.nix +++ b/pkgs/by-name/go/go-rice/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-rice"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-VlpdZcqg7yWUADN8oD/IAgAXVdzJeIeymx2Pu/7E21o="; - subPackages = [ "." "rice" ]; + subPackages = [ + "." + "rice" + ]; meta = with lib; { description = "Go package that makes working with resources such as html, js, css, images, templates very easy"; diff --git a/pkgs/by-name/go/go-sct/package.nix b/pkgs/by-name/go/go-sct/package.nix index 71c1c77fd9d3f6..80d244d136c2b0 100644 --- a/pkgs/by-name/go/go-sct/package.nix +++ b/pkgs/by-name/go/go-sct/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, xorg, wayland }: +{ + lib, + buildGoModule, + fetchFromGitHub, + xorg, + wayland, +}: buildGoModule rec { pname = "go-sct"; @@ -18,9 +24,16 @@ buildGoModule rec { vendorHash = "sha256-Rx5/oORink2QtRcD+JqbyFroWYhuYmuYDzZ391R4Jsw="; - buildInputs = [ xorg.libX11 xorg.libXrandr wayland.dev ]; + buildInputs = [ + xorg.libX11 + xorg.libXrandr + wayland.dev + ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Color temperature setting library and CLI that operates in a similar way to f.lux and Redshift"; diff --git a/pkgs/by-name/go/go-shadowsocks2/package.nix b/pkgs/by-name/go/go-shadowsocks2/package.nix index ac6bbc1663aaa4..d3398e2d7c7c34 100644 --- a/pkgs/by-name/go/go-shadowsocks2/package.nix +++ b/pkgs/by-name/go/go-shadowsocks2/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "go-shadowsocks2"; diff --git a/pkgs/by-name/go/go-swag/package.nix b/pkgs/by-name/go/go-swag/package.nix index 1903ff57ef33e6..7193d56ba31209 100644 --- a/pkgs/by-name/go/go-swag/package.nix +++ b/pkgs/by-name/go/go-swag/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "go-swag"; diff --git a/pkgs/by-name/go/go-swagger/package.nix b/pkgs/by-name/go/go-swagger/package.nix index 9319bd499758c0..0133af94d9c2f2 100644 --- a/pkgs/by-name/go/go-swagger/package.nix +++ b/pkgs/by-name/go/go-swagger/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/go-tools/package.nix b/pkgs/by-name/go/go-tools/package.nix index dd4f60f16b744e..18496f2252542c 100644 --- a/pkgs/by-name/go/go-tools/package.nix +++ b/pkgs/by-name/go/go-tools/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, lib -, fetchFromGitHub +{ + buildGoModule, + lib, + fetchFromGitHub, }: buildGoModule rec { @@ -24,6 +25,10 @@ buildGoModule rec { description = "Collection of tools and libraries for working with Go code, including linters and static analysis"; homepage = "https://staticcheck.io"; license = licenses.mit; - maintainers = with maintainers; [ rvolosatovs kalbasit smasher164 ]; + maintainers = with maintainers; [ + rvolosatovs + kalbasit + smasher164 + ]; }; } diff --git a/pkgs/by-name/go/go365/package.nix b/pkgs/by-name/go/go365/package.nix index 12fad051584d2e..297e6f04f53b55 100644 --- a/pkgs/by-name/go/go365/package.nix +++ b/pkgs/by-name/go/go365/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/goa/package.nix b/pkgs/by-name/go/goa/package.nix index 33a52e62642889..0feb0d3e3fc054 100644 --- a/pkgs/by-name/go/goa/package.nix +++ b/pkgs/by-name/go/goa/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/goawk/package.nix b/pkgs/by-name/go/goawk/package.nix index 7830258e137790..36f1382ce6db40 100644 --- a/pkgs/by-name/go/goawk/package.nix +++ b/pkgs/by-name/go/goawk/package.nix @@ -1,4 +1,10 @@ -{ buildGoModule, fetchFromGitHub, lib, stdenv, gawk }: +{ + buildGoModule, + fetchFromGitHub, + lib, + stdenv, + gawk, +}: buildGoModule rec { pname = "goawk"; diff --git a/pkgs/by-name/go/gob2/package.nix b/pkgs/by-name/go/gob2/package.nix index deef55569e9047..8e603c4bcb06da 100644 --- a/pkgs/by-name/go/gob2/package.nix +++ b/pkgs/by-name/go/gob2/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, bison, flex, gnome }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + bison, + flex, + gnome, +}: stdenv.mkDerivation rec { pname = "gob2"; @@ -11,7 +20,11 @@ stdenv.mkDerivation rec { # configure script looks for d-bus but it is only needed for tests nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib bison flex ]; + buildInputs = [ + glib + bison + flex + ]; passthru = { updateScript = gnome.updateScript { diff --git a/pkgs/by-name/go/gobble/package.nix b/pkgs/by-name/go/gobble/package.nix index b61cf78f992120..856971174890d9 100644 --- a/pkgs/by-name/go/gobble/package.nix +++ b/pkgs/by-name/go/gobble/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, xorg -, installShellFiles -, pandoc +{ + lib, + rustPlatform, + fetchFromGitHub, + xorg, + installShellFiles, + pandoc, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-5xsMLOYTKQc1bHHQsk9L4rHMVNBFOzIMxD+1qaMaNbQ="; buildInputs = [ xorg.libxcb ]; - nativeBuildInputs = [ pandoc installShellFiles ]; + nativeBuildInputs = [ + pandoc + installShellFiles + ]; postInstall = '' pandoc gobble.1.md -s -t man -o gobble.1 diff --git a/pkgs/by-name/go/gobby/package.nix b/pkgs/by-name/go/gobby/package.nix index 489a790e9e2377..18f48b758d68e5 100644 --- a/pkgs/by-name/go/gobby/package.nix +++ b/pkgs/by-name/go/gobby/package.nix @@ -1,10 +1,29 @@ -{ avahiSupport ? false # build support for Avahi in libinfinity -, lib, stdenv, fetchFromGitHub, autoconf, automake, pkg-config, wrapGAppsHook3, yelp-tools -, gtkmm3, gsasl, gtksourceview3, libxmlxx, libinfinity, intltool, itstool }: +{ + avahiSupport ? false, # build support for Avahi in libinfinity + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + pkg-config, + wrapGAppsHook3, + yelp-tools, + gtkmm3, + gsasl, + gtksourceview3, + libxmlxx, + libinfinity, + intltool, + itstool, +}: let - libinf = libinfinity.override { gtkWidgets = true; inherit avahiSupport; }; -in stdenv.mkDerivation rec { + libinf = libinfinity.override { + gtkWidgets = true; + inherit avahiSupport; + }; +in +stdenv.mkDerivation rec { pname = "gobby"; version = "0.6.0"; @@ -15,8 +34,22 @@ in stdenv.mkDerivation rec { sha256 = "06cbc2y4xkw89jaa0ayhgh7fxr5p2nv3jjs8h2xcbbbgwaw08lk0"; }; - nativeBuildInputs = [ autoconf automake pkg-config intltool itstool yelp-tools wrapGAppsHook3 ]; - buildInputs = [ gtkmm3 gsasl gtksourceview3 libxmlxx libinf ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + intltool + itstool + yelp-tools + wrapGAppsHook3 + ]; + buildInputs = [ + gtkmm3 + gsasl + gtksourceview3 + libxmlxx + libinf + ]; preConfigure = "./autogen.sh"; diff --git a/pkgs/by-name/go/gobetween/package.nix b/pkgs/by-name/go/gobetween/package.nix index db201e5ba48a9c..ca795661eeee17 100644 --- a/pkgs/by-name/go/gobetween/package.nix +++ b/pkgs/by-name/go/gobetween/package.nix @@ -1,5 +1,9 @@ -{ stdenv, buildGoModule, fetchFromGitHub, lib -, enableStatic ? stdenv.hostPlatform.isStatic +{ + stdenv, + buildGoModule, + fetchFromGitHub, + lib, + enableStatic ? stdenv.hostPlatform.isStatic, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gobgp/package.nix b/pkgs/by-name/go/gobgp/package.nix index e72bdb874ca551..a3d1f3bcb0f2cb 100644 --- a/pkgs/by-name/go/gobgp/package.nix +++ b/pkgs/by-name/go/gobgp/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "gobgp"; @@ -18,7 +22,9 @@ buildGoModule rec { ''; ldflags = [ - "-s" "-w" "-extldflags '-static'" + "-s" + "-w" + "-extldflags '-static'" ]; subPackages = [ "cmd/gobgp" ]; diff --git a/pkgs/by-name/go/gobgpd/package.nix b/pkgs/by-name/go/gobgpd/package.nix index 9754397e086aa5..bc5162675d382b 100644 --- a/pkgs/by-name/go/gobgpd/package.nix +++ b/pkgs/by-name/go/gobgpd/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gobi_loader/package.nix b/pkgs/by-name/go/gobi_loader/package.nix index 2783e9f559b82c..d878df522d7580 100644 --- a/pkgs/by-name/go/gobi_loader/package.nix +++ b/pkgs/by-name/go/gobi_loader/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/go/goblob/package.nix b/pkgs/by-name/go/goblob/package.nix index a1ffe5b4a9c817..1665cf1617ba8f 100644 --- a/pkgs/by-name/go/goblob/package.nix +++ b/pkgs/by-name/go/goblob/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gobuster/package.nix b/pkgs/by-name/go/gobuster/package.nix index bbc4b02c2b1688..832f69b3b6d8ef 100644 --- a/pkgs/by-name/go/gobuster/package.nix +++ b/pkgs/by-name/go/gobuster/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -27,6 +28,9 @@ buildGoModule rec { homepage = "https://github.com/OJ/gobuster"; changelog = "https://github.com/OJ/gobuster/releases/tag/v${version}"; license = licenses.asl20; - maintainers = with maintainers; [ fab pamplemousse ]; + maintainers = with maintainers; [ + fab + pamplemousse + ]; }; } diff --git a/pkgs/by-name/go/gocd-agent/package.nix b/pkgs/by-name/go/gocd-agent/package.nix index adb2839de1d8e2..c54dca292c627e 100644 --- a/pkgs/by-name/go/gocd-agent/package.nix +++ b/pkgs/by-name/go/gocd-agent/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, unzip, nixosTests }: +{ + lib, + stdenv, + fetchurl, + unzip, + nixosTests, +}: stdenv.mkDerivation rec { pname = "gocd-agent"; @@ -21,7 +27,10 @@ stdenv.mkDerivation rec { binaryBytecode binaryNativeCode ]; - maintainers = with maintainers; [ grahamc swarren83 ]; + maintainers = with maintainers; [ + grahamc + swarren83 + ]; }; nativeBuildInputs = [ unzip ]; diff --git a/pkgs/by-name/go/gocd-server/package.nix b/pkgs/by-name/go/gocd-server/package.nix index ce01ff95cc5a36..3197d6e05fb0cf 100644 --- a/pkgs/by-name/go/gocd-server/package.nix +++ b/pkgs/by-name/go/gocd-server/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, unzip -, nixosTests +{ + lib, + stdenv, + fetchurl, + unzip, + nixosTests, }: stdenv.mkDerivation rec { @@ -24,7 +25,10 @@ stdenv.mkDerivation rec { binaryBytecode binaryNativeCode ]; - maintainers = with maintainers; [ grahamc swarren83 ]; + maintainers = with maintainers; [ + grahamc + swarren83 + ]; }; nativeBuildInputs = [ unzip ]; diff --git a/pkgs/by-name/go/gocode-gomod/package.nix b/pkgs/by-name/go/gocode-gomod/package.nix index 6d1ef96f77a886..9aec956c578e90 100644 --- a/pkgs/by-name/go/gocode-gomod/package.nix +++ b/pkgs/by-name/go/gocode-gomod/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gocode-gomod"; @@ -41,6 +45,9 @@ buildGoModule rec { ''; homepage = "https://github.com/stamblerre/gocode"; license = licenses.mit; - maintainers = with maintainers; [ kalbasit rvolosatovs ]; + maintainers = with maintainers; [ + kalbasit + rvolosatovs + ]; }; } diff --git a/pkgs/by-name/go/goconst/package.nix b/pkgs/by-name/go/goconst/package.nix index d080a4fe375497..6d1546d69f428d 100644 --- a/pkgs/by-name/go/goconst/package.nix +++ b/pkgs/by-name/go/goconst/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "goconst"; @@ -15,7 +19,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Find in Go repeated strings that could be replaced by a constant"; diff --git a/pkgs/by-name/go/goconvey/package.nix b/pkgs/by-name/go/goconvey/package.nix index 6717ff777be6f5..ce8323ab027f86 100644 --- a/pkgs/by-name/go/goconvey/package.nix +++ b/pkgs/by-name/go/goconvey/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "goconvey"; @@ -15,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-P4J/CZY95ks08DC+gSqG+eanL3zoiaoz1d9/ZvBoc9Q="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; checkFlags = [ "-short" diff --git a/pkgs/by-name/go/gocr/package.nix b/pkgs/by-name/go/gocr/package.nix index 36bba9eaa4a18b..5f808d3ae67073 100644 --- a/pkgs/by-name/go/gocr/package.nix +++ b/pkgs/by-name/go/gocr/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, tk }: +{ + lib, + stdenv, + fetchurl, + tk, +}: stdenv.mkDerivation rec { pname = "gocr"; @@ -9,7 +14,10 @@ stdenv.mkDerivation rec { sha256 = "11l6gds1lrm8lwrrsxnm5fjlwz8q1xbh896cprrl4psz21in946z"; }; - buildFlags = [ "all" "libs" ]; + buildFlags = [ + "all" + "libs" + ]; installFlags = [ "libdir=/lib/" ]; # Specify libdir so Makefile will also install library. preInstall = "mkdir -p $out/lib"; diff --git a/pkgs/by-name/go/gocryptfs/package.nix b/pkgs/by-name/go/gocryptfs/package.nix index a1f424915f30b3..1567b10e354951 100644 --- a/pkgs/by-name/go/gocryptfs/package.nix +++ b/pkgs/by-name/go/gocryptfs/package.nix @@ -1,12 +1,13 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fuse -, makeWrapper -, openssl -, pandoc -, pkg-config -, libfido2 +{ + lib, + buildGoModule, + fetchFromGitHub, + fuse, + makeWrapper, + openssl, + pandoc, + pkg-config, + libfido2, }: buildGoModule rec { @@ -38,7 +39,11 @@ buildGoModule rec { "-X main.BuildDate=unknown" ]; - subPackages = [ "." "gocryptfs-xray" "contrib/statfs" ]; + subPackages = [ + "." + "gocryptfs-xray" + "contrib/statfs" + ]; postBuild = '' pushd Documentation/ @@ -62,7 +67,11 @@ buildGoModule rec { description = "Encrypted overlay filesystem written in Go"; license = licenses.mit; homepage = "https://nuetzlich.net/gocryptfs/"; - maintainers = with maintainers; [ flokli offline prusnak ]; + maintainers = with maintainers; [ + flokli + offline + prusnak + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/go/gocyclo/package.nix b/pkgs/by-name/go/gocyclo/package.nix index 49aa20f2be7059..cd5447ef9c8e58 100644 --- a/pkgs/by-name/go/gocyclo/package.nix +++ b/pkgs/by-name/go/gocyclo/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, lib -, fetchFromGitHub +{ + buildGoModule, + lib, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/godef/package.nix b/pkgs/by-name/go/godef/package.nix index d79406a2ac43eb..deb60e509ac37c 100644 --- a/pkgs/by-name/go/godef/package.nix +++ b/pkgs/by-name/go/godef/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "godef"; @@ -22,7 +26,10 @@ buildGoModule rec { description = "Print where symbols are defined in Go source code"; mainProgram = "godef"; homepage = "https://github.com/rogpeppe/godef/"; - maintainers = with lib.maintainers; [ vdemeester rvolosatovs ]; + maintainers = with lib.maintainers; [ + vdemeester + rvolosatovs + ]; license = lib.licenses.bsd3; }; } diff --git a/pkgs/by-name/go/godns/package.nix b/pkgs/by-name/go/godns/package.nix index dfce9e6965f085..ea2aae6b38dea1 100644 --- a/pkgs/by-name/go/godns/package.nix +++ b/pkgs/by-name/go/godns/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nodejs -, npmHooks -, fetchNpmDeps -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + nodejs, + npmHooks, + fetchNpmDeps, + nix-update-script, }: buildGoModule rec { diff --git a/pkgs/by-name/go/godu/package.nix b/pkgs/by-name/go/godu/package.nix index 1f310b2f688176..e034badc0ae735 100644 --- a/pkgs/by-name/go/godu/package.nix +++ b/pkgs/by-name/go/godu/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "godu"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-8cZCeZ0gqxqbwB0WuEOFmEUNQd3/KcLeN0eLGfWG8BY="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Utility helping to discover large files/folders"; diff --git a/pkgs/by-name/go/goeland/package.nix b/pkgs/by-name/go/goeland/package.nix index 337b09cff3362b..e3f3f337892dbd 100644 --- a/pkgs/by-name/go/goeland/package.nix +++ b/pkgs/by-name/go/goeland/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gof5/package.nix b/pkgs/by-name/go/gof5/package.nix index ead38427816c64..82047971cd3bc4 100644 --- a/pkgs/by-name/go/gof5/package.nix +++ b/pkgs/by-name/go/gof5/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { diff --git a/pkgs/by-name/go/goffice/package.nix b/pkgs/by-name/go/goffice/package.nix index a0be4727293bd3..b578372332e629 100644 --- a/pkgs/by-name/go/goffice/package.nix +++ b/pkgs/by-name/go/goffice/package.nix @@ -1,14 +1,32 @@ -{ fetchurl, lib, stdenv, pkg-config, intltool, glib, gtk3, lasem -, libgsf, libxml2, libxslt, cairo, pango, librsvg, gnome -, autoreconfHook -, gtk-doc +{ + fetchurl, + lib, + stdenv, + pkg-config, + intltool, + glib, + gtk3, + lasem, + libgsf, + libxml2, + libxslt, + cairo, + pango, + librsvg, + gnome, + autoreconfHook, + gtk-doc, }: stdenv.mkDerivation rec { pname = "goffice"; version = "0.10.57"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -16,15 +34,27 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - pkg-config intltool autoreconfHook gtk-doc - glib # for glib-genmarshal + pkg-config + intltool + autoreconfHook + gtk-doc + glib # for glib-genmarshal ]; propagatedBuildInputs = [ - glib gtk3 libxml2 cairo pango libgsf lasem + glib + gtk3 + libxml2 + cairo + pango + libgsf + lasem ]; - buildInputs = [ libxslt librsvg ]; + buildInputs = [ + libxslt + librsvg + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/go/gofish/package.nix b/pkgs/by-name/go/gofish/package.nix index dabfafc468786a..b5a28b02142625 100644 --- a/pkgs/by-name/go/gofish/package.nix +++ b/pkgs/by-name/go/gofish/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/go/goflow/package.nix b/pkgs/by-name/go/goflow/package.nix index 5ec54a85ee25b6..04937583cc3076 100644 --- a/pkgs/by-name/go/goflow/package.nix +++ b/pkgs/by-name/go/goflow/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gofu/package.nix b/pkgs/by-name/go/gofu/package.nix index abe811d74858e6..012d20bc8e642a 100644 --- a/pkgs/by-name/go/gofu/package.nix +++ b/pkgs/by-name/go/gofu/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gofu"; diff --git a/pkgs/by-name/go/gogetdoc/package.nix b/pkgs/by-name/go/gogetdoc/package.nix index ed6f586a01ba18..592b92f145adf5 100644 --- a/pkgs/by-name/go/gogetdoc/package.nix +++ b/pkgs/by-name/go/gogetdoc/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, lib -, fetchFromGitHub +{ + buildGoModule, + lib, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gogui/package.nix b/pkgs/by-name/go/gogui/package.nix index e83516d1c7d0e4..ebcaac4910c3d0 100644 --- a/pkgs/by-name/go/gogui/package.nix +++ b/pkgs/by-name/go/gogui/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, ant -, jdk -, jre -, docbook-xsl-ns -, docbook_xml_dtd_42 -, imagemagick -, libxslt -, stripJavaArchivesHook -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + ant, + jdk, + jre, + docbook-xsl-ns, + docbook_xml_dtd_42, + imagemagick, + libxslt, + stripJavaArchivesHook, + makeWrapper, }: stdenv.mkDerivation (finalAttrs: { @@ -90,7 +91,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/Remi-Coulom/gogui"; license = lib.licenses.gpl3Plus; mainProgram = "gogui"; - maintainers = with lib.maintainers; [ cleverca22 omnipotententity ]; + maintainers = with lib.maintainers; [ + cleverca22 + omnipotententity + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/by-name/go/gohai/package.nix b/pkgs/by-name/go/gohai/package.nix index 5fa84e873ba3fc..8ce3dffd99fdbe 100644 --- a/pkgs/by-name/go/gohai/package.nix +++ b/pkgs/by-name/go/gohai/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gohai"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-aN1fwGbBm45e6qdRu+4wnv2ZI7SOsIPONB4vF9o2vlI="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; doCheck = false; diff --git a/pkgs/by-name/go/gohufont/package.nix b/pkgs/by-name/go/gohufont/package.nix index 6892742de7999b..6310db9daf9398 100644 --- a/pkgs/by-name/go/gohufont/package.nix +++ b/pkgs/by-name/go/gohufont/package.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, fetchFromGitHub -, xorg, bdf2psf, bdftopcf -, libfaketime +{ + lib, + stdenv, + fetchFromGitHub, + xorg, + bdf2psf, + bdftopcf, + libfaketime, }: stdenv.mkDerivation rec { @@ -8,16 +13,19 @@ stdenv.mkDerivation rec { version = "2.1"; src = fetchFromGitHub { - owner = "hchargois"; - repo = "gohufont"; - rev = "cc36b8c9fed7141763e55dcee0a97abffcf08224"; + owner = "hchargois"; + repo = "gohufont"; + rev = "cc36b8c9fed7141763e55dcee0a97abffcf08224"; sha256 = "1hmp11mrr01b29phw0xyj4h9b92qz19cf56ssf6c47c5j2c4xmbv"; }; - nativeBuildInputs = - [ xorg.mkfontscale bdf2psf bdftopcf - xorg.fonttosfnt libfaketime - ]; + nativeBuildInputs = [ + xorg.mkfontscale + bdf2psf + bdftopcf + xorg.fonttosfnt + libfaketime + ]; buildPhase = '' # convert bdf fonts to psf @@ -62,8 +70,8 @@ stdenv.mkDerivation rec { description = '' A monospace bitmap font well suited for programming and terminal use ''; - homepage = "https://font.gohu.org/"; - license = licenses.wtfpl; + homepage = "https://font.gohu.org/"; + license = licenses.wtfpl; maintainers = with maintainers; [ rnhmjoj ]; }; } diff --git a/pkgs/by-name/go/goimapnotify/package.nix b/pkgs/by-name/go/goimapnotify/package.nix index ced815142e7372..44ab2078d5835d 100644 --- a/pkgs/by-name/go/goimapnotify/package.nix +++ b/pkgs/by-name/go/goimapnotify/package.nix @@ -1,4 +1,9 @@ -{ buildGoModule, fetchFromGitLab, lib, runtimeShell }: +{ + buildGoModule, + fetchFromGitLab, + lib, + runtimeShell, +}: buildGoModule rec { pname = "goimapnotify"; @@ -20,11 +25,13 @@ buildGoModule rec { ''; meta = with lib; { - description = - "Execute scripts on IMAP mailbox changes (new/deleted/updated messages) using IDLE"; + description = "Execute scripts on IMAP mailbox changes (new/deleted/updated messages) using IDLE"; homepage = "https://gitlab.com/shackra/goimapnotify"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ wohanley rafaelrc ]; + maintainers = with maintainers; [ + wohanley + rafaelrc + ]; mainProgram = "goimapnotify"; }; } diff --git a/pkgs/by-name/go/gojq/package.nix b/pkgs/by-name/go/gojq/package.nix index f022ccc881a91f..d8a14137603846 100644 --- a/pkgs/by-name/go/gojq/package.nix +++ b/pkgs/by-name/go/gojq/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, gojq }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + gojq, +}: buildGoModule rec { pname = "gojq"; @@ -13,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-ZC0byawZLBwId5GcAgHXRdEOMUSAv4wDNHFHLrbhB+I="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests.version = testers.testVersion { package = gojq; diff --git a/pkgs/by-name/go/gojsontoyaml/package.nix b/pkgs/by-name/go/gojsontoyaml/package.nix index f05d0405aebf11..3057639d858d4a 100644 --- a/pkgs/by-name/go/gojsontoyaml/package.nix +++ b/pkgs/by-name/go/gojsontoyaml/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gojsontoyaml"; diff --git a/pkgs/by-name/go/gokart/package.nix b/pkgs/by-name/go/gokart/package.nix index 11e68b9bede177..aa3b53fb0e3b11 100644 --- a/pkgs/by-name/go/gokart/package.nix +++ b/pkgs/by-name/go/gokart/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gokey/package.nix b/pkgs/by-name/go/gokey/package.nix index 7d60299db2392a..2b5a6f89ac06a9 100644 --- a/pkgs/by-name/go/gokey/package.nix +++ b/pkgs/by-name/go/gokey/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gokey"; version = "0.1.3"; diff --git a/pkgs/by-name/go/gol/package.nix b/pkgs/by-name/go/gol/package.nix index 7096d7b854b4ab..f1d8eafc1debaa 100644 --- a/pkgs/by-name/go/gol/package.nix +++ b/pkgs/by-name/go/gol/package.nix @@ -1,4 +1,10 @@ -{ lib, maven, fetchFromGitHub, makeWrapper, jre }: +{ + lib, + maven, + fetchFromGitHub, + makeWrapper, + jre, +}: maven.buildMavenPackage rec { pname = "gol"; diff --git a/pkgs/by-name/go/golangci-lint-langserver/package.nix b/pkgs/by-name/go/golangci-lint-langserver/package.nix index ce43f3ed50b8a0..515ed00b4eecba 100644 --- a/pkgs/by-name/go/golangci-lint-langserver/package.nix +++ b/pkgs/by-name/go/golangci-lint-langserver/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/goldwarden/package.nix b/pkgs/by-name/go/goldwarden/package.nix index f4769f3dd3084f..eddf57bfbbfa70 100644 --- a/pkgs/by-name/go/goldwarden/package.nix +++ b/pkgs/by-name/go/goldwarden/package.nix @@ -1,14 +1,15 @@ -{ lib -, blueprint-compiler -, buildGoModule -, fetchFromGitHub -, gobject-introspection -, gtk4 -, libadwaita -, libfido2 -, libnotify -, python3 -, wrapGAppsHook4 +{ + lib, + blueprint-compiler, + buildGoModule, + fetchFromGitHub, + gobject-introspection, + gtk4, + libadwaita, + libfido2, + libnotify, + python3, + wrapGAppsHook4, }: buildGoModule rec { @@ -40,7 +41,10 @@ buildGoModule rec { vendorHash = "sha256-zWACjW/WZC0ZLmRV1VwcRROG218PCZ6aCPOreCG/5sE="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeBuildInputs = [ blueprint-compiler @@ -92,7 +96,10 @@ buildGoModule rec { description = "Feature-packed Bitwarden compatible desktop integration"; homepage = "https://github.com/quexten/goldwarden"; license = licenses.mit; - maintainers = with maintainers; [ arthsmn justanotherariel ]; + maintainers = with maintainers; [ + arthsmn + justanotherariel + ]; mainProgram = "goldwarden"; platforms = platforms.linux; # Support for other platforms is not yet ready, see https://github.com/quexten/goldwarden/issues/4 }; diff --git a/pkgs/by-name/go/golines/package.nix b/pkgs/by-name/go/golines/package.nix index da6c887d43bb25..1d30cf3b148a97 100644 --- a/pkgs/by-name/go/golines/package.nix +++ b/pkgs/by-name/go/golines/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "golines"; diff --git a/pkgs/by-name/go/golink/package.nix b/pkgs/by-name/go/golink/package.nix index f48b80aeb5392e..5c10bbdcfebed8 100644 --- a/pkgs/by-name/go/golink/package.nix +++ b/pkgs/by-name/go/golink/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/golint/package.nix b/pkgs/by-name/go/golint/package.nix index 47e1ee0a54556f..d1a29e512cc324 100644 --- a/pkgs/by-name/go/golint/package.nix +++ b/pkgs/by-name/go/golint/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchgit }: +{ + lib, + buildGoModule, + fetchgit, +}: buildGoModule rec { pname = "golint"; @@ -27,6 +31,9 @@ buildGoModule rec { description = "Linter for Go source code"; mainProgram = "golint"; license = licenses.bsd3; - maintainers = with maintainers; [ jhillyerd tomberek ]; + maintainers = with maintainers; [ + jhillyerd + tomberek + ]; }; } diff --git a/pkgs/by-name/go/gollum/gemset.nix b/pkgs/by-name/go/gollum/gemset.nix index c45f4c36725198..8ee71b2e826d01 100644 --- a/pkgs/by-name/go/gollum/gemset.nix +++ b/pkgs/by-name/go/gollum/gemset.nix @@ -1,596 +1,662 @@ { asciidoctor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wyxgwmnz9bw377r3lba26b090hbsq9qnbw8575a1prpy83qh82j"; type = "gem"; }; version = "2.0.23"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; builder = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pw3r2lyagsxkm71bf44v5b74f7l9r7di22brbyji9fwz791hya9"; type = "gem"; }; version = "3.3.0"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; crass = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pfl5c0pyqaparxaqxi6s4gfl21bdldwiawrc0aknyvflli60lfw"; type = "gem"; }; version = "1.0.6"; }; creole = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00rcscz16idp6dx0dk5yi5i0fz593i3r6anbn5bg2q07v3i025wm"; type = "gem"; }; version = "0.5.0"; }; expression_parser = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1938z3wmmdabqxlh5d5c56xfg1jc6z15p7zjyhvk7364zwydnmib"; type = "gem"; }; version = "0.9.0"; }; gemojione = { - dependencies = ["json"]; - groups = ["default"]; - platforms = []; + dependencies = [ "json" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fwd523pgr72w3w6jwpz9i6sggvz52d7831a1s4y3lv8m50j6ima"; type = "gem"; }; version = "4.3.3"; }; github-markup = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mv2l0h3v5g4cwqh2lgb3braafh8n3v2s84i573wi5m79f4qhw1z"; type = "gem"; }; version = "4.0.2"; }; gollum = { - dependencies = ["gemojione" "gollum-lib" "i18n" "kramdown" "kramdown-parser-gfm" "mustache-sinatra" "octicons" "rack" "rackup" "rdoc" "rss" "sinatra" "sinatra-contrib" "sprockets" "sprockets-helpers" "therubyrhino" "useragent" "webrick"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "gemojione" + "gollum-lib" + "i18n" + "kramdown" + "kramdown-parser-gfm" + "mustache-sinatra" + "octicons" + "rack" + "rackup" + "rdoc" + "rss" + "sinatra" + "sinatra-contrib" + "sprockets" + "sprockets-helpers" + "therubyrhino" + "useragent" + "webrick" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "01gk8zb1mfr7ypspbg765fn3m6rdh0b6jpyxfninabl9dzazyvpi"; type = "gem"; }; version = "6.0.1"; }; gollum-lib = { - dependencies = ["gemojione" "github-markup" "gollum-rugged_adapter" "loofah" "nokogiri" "rouge" "twitter-text"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "gemojione" + "github-markup" + "gollum-rugged_adapter" + "loofah" + "nokogiri" + "rouge" + "twitter-text" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vgvdmz5rh3ciww95llwax7pz93n4iljsz2q5f2hhynx6csvhriw"; type = "gem"; }; version = "6.0"; }; gollum-rugged_adapter = { - dependencies = ["mime-types" "rugged"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mime-types" + "rugged" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00l1fmgjv3sq97c5lw7qcrf37v970yz89dm6b73ah2y4qn8zd7qk"; type = "gem"; }; version = "3.0"; }; htmlentities = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nkklqsn8ir8wizzlakncfv42i32wc0w9hxp00hvdlgjr7376nhj"; type = "gem"; }; version = "4.3.4"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k31wcgnvcvd14snz0pfqj976zv6drfsnq6x8acz10fiyms9l8nw"; type = "gem"; }; version = "1.14.6"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1klf2mnfilzjqwcjdi5qb1zl3ghrifz1amcnvwjvsfnx9a5jb9ly"; type = "gem"; }; version = "2.7.4"; }; kramdown = { - dependencies = ["rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rexml" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ic14hdcqxn821dvzki99zhmcy130yhv5fqfffkcf87asv5mnbmn"; type = "gem"; }; version = "2.4.0"; }; kramdown-parser-gfm = { - dependencies = ["kramdown"]; - groups = ["default"]; - platforms = []; + dependencies = [ "kramdown" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a8pb3v951f4x7h968rqfsa19c8arz21zw1vaj42jza22rap8fgv"; type = "gem"; }; version = "1.1.0"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; loofah = { - dependencies = ["crass" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "crass" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ppp2cgli5avzk0z3dwnah6y65ymyr793yja28p2fs9vrci7986h"; type = "gem"; }; version = "2.23.1"; }; mime-types = { - dependencies = ["logger" "mime-types-data"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "logger" + "mime-types-data" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0r34mc3n7sxsbm9mzyzy8m3dvq7pwbryyc8m452axkj0g2axnwbg"; type = "gem"; }; version = "3.6.0"; }; mime-types-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06dbn0j13jwdrmlvrjd50mxqrjlkh3lvxp0afh4glyzbliqvqpsd"; type = "gem"; }; version = "3.2024.1001"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q1f2sdw3y3y9mnym9dhjgsjr72sq975cfg5c4yx7gwv8nmzbvhk"; type = "gem"; }; version = "2.8.7"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; mustache = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l0p4wx15mi3wnamfv92ipkia4nsx8qi132c6g51jfdma3fiz2ch"; type = "gem"; }; version = "1.1.1"; }; mustache-sinatra = { - dependencies = ["mustache"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mustache" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03f2wdih6hnnm9iclfwi53dx56knpshv8wnf4cglp7kjx358036i"; type = "gem"; }; version = "2.0.0"; }; mustermann = { - dependencies = ["ruby2_keywords"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ruby2_keywords" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "123ycmq6pkivv29bqbv79jv2cs04xakzd0fz1lalgvfs5nxfky6i"; type = "gem"; }; version = "3.0.3"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15gysw8rassqgdq3kwgl4mhqmrgh7nk2qvrcqp4ijyqazgywn6gq"; type = "gem"; }; version = "1.16.7"; }; octicons = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00ld13van1xiayr24gwpbxfb63zbw44fx25xs9cp29g6cdzi5hrp"; type = "gem"; }; version = "19.12.0"; }; org-ruby = { - dependencies = ["rubypants"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rubypants" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0x69s7aysfiwlcpd9hkvksfyld34d8kxr62adb59vjvh8hxfrjwk"; type = "gem"; }; version = "0.9.12"; }; psych = { - dependencies = ["stringio"]; - groups = ["default"]; - platforms = []; + dependencies = [ "stringio" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0s5383m6004q76xm3lb732bp4sjzb6mxb6rbgn129gy2izsj4wrk"; type = "gem"; }; version = "5.1.2"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0byn0c9nkahsl93y9ln5bysq4j31q8xkf2ws42swighxd4lnjzsa"; type = "gem"; }; version = "1.8.1"; }; rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cd13019gnnh2c0a3kj27ij5ibk72v0bmpypqv4l6ayw8g5cpyyk"; type = "gem"; }; version = "3.1.8"; }; rack-protection = { - dependencies = ["base64" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1xmvcxgm1jq92hqxm119gfk95wzl0d46nb2c2c6qqsm4ra2n3nyh"; type = "gem"; }; version = "4.0.0"; }; rack-session = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10afdpmy9kh0qva96slcyc59j4gkk9av8ilh58cnj0qq7q3b416v"; type = "gem"; }; version = "2.0.0"; }; rackup = { - dependencies = ["rack" "webrick"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rack" + "webrick" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0kbcka30g681cqasw47pq93fxjscq7yvs5zf8lp3740rb158ijvf"; type = "gem"; }; version = "2.1.0"; }; rdoc = { - dependencies = ["psych"]; - groups = ["default"]; - platforms = []; + dependencies = [ "psych" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ygk2zk0ky3d88v3ll7qh6xqvbvw5jin0hqdi1xkv1dhaw7myzdi"; type = "gem"; }; version = "6.7.0"; }; RedCloth = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15r2h7rfp4bi9i0bfmvgnmvmw0kl3byyac53rcakk4qsv7yv4caj"; type = "gem"; }; version = "4.3.4"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j9p66pmfgxnzp76ksssyfyqqrg7281dyi3xyknl3wwraaw7a66p"; type = "gem"; }; version = "3.3.9"; }; rouge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dnfkrk8xx2m8r3r9m2p5xcq57viznyc09k7r3i4jbm758i57lx3"; type = "gem"; }; version = "3.30.0"; }; rss = { - dependencies = ["rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rexml" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dv74a07j3ih5ykyszs1k2cjvgs5c1pzrvcb1wc2bfai8p038qml"; type = "gem"; }; version = "0.3.1"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; rubypants = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kv2way45d2dz3h5b7wxyw36clvlwrz7ydf6699d0za5vm56gsrh"; type = "gem"; }; version = "0.7.1"; }; rugged = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sccng15h8h3mcjxfgvxy85lfpswbj0nhmzwwsqdffbzqgsb2jch"; type = "gem"; }; version = "1.7.2"; }; sinatra = { - dependencies = ["mustermann" "rack" "rack-protection" "rack-session" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mustermann" + "rack" + "rack-protection" + "rack-session" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0za92lv4s7xhgkkm6xxf7ib0b3bsyj8drxgkrskgsb5g3mxnixjl"; type = "gem"; }; version = "4.0.0"; }; sinatra-contrib = { - dependencies = ["multi_json" "mustermann" "rack-protection" "sinatra" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "multi_json" + "mustermann" + "rack-protection" + "sinatra" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0r9khg85m60w0i77jpnm2irh9m4k0ia4mlicapj8dr7s6ykqd9dh"; type = "gem"; }; version = "4.0.0"; }; sprockets = { - dependencies = ["concurrent-ruby" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15rzfzd9dca4v0mr0bbhsbwhygl0k9l24iqqlx0fijig5zfi66wm"; type = "gem"; }; version = "4.2.1"; }; sprockets-helpers = { - dependencies = ["sprockets"]; - groups = ["default"]; - platforms = []; + dependencies = [ "sprockets" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0513ma356g05lsskhsb363263177h6ccmp475il0p69y18his2ij"; type = "gem"; }; version = "1.4.0"; }; stringio = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07mfqb40b2wh53k33h91zva78f9zwcdnl85jiq74wnaw2wa6wiak"; type = "gem"; }; version = "3.1.1"; }; therubyrhino = { - dependencies = ["therubyrhino_jar"]; - groups = ["default"]; - platforms = []; + dependencies = [ "therubyrhino_jar" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "034mzpkxm3zjsi4rwa45dhhgq2b9vkabs5bnzbl1d3ka7210b3fc"; type = "gem"; }; version = "2.1.2"; }; therubyrhino_jar = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "149a5lsvn2n7k7vcfs77n836q1alv8yjh0503sf9cs65p974ah25"; type = "gem"; }; version = "1.7.8"; }; tilt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kds7wkxmb038cwp6ravnwn8k65ixc68wpm8j5jx5bhx8ndg4x6z"; type = "gem"; }; version = "2.4.0"; }; twitter-text = { - dependencies = ["unf"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unf" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1732h7hy1k152w8wfvjsx7b79alk45i5imwd37ia4qcx8hfm3gvg"; type = "gem"; }; version = "1.14.7"; }; unf = { - dependencies = ["unf_ext"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unf_ext" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bh2cf73i2ffh4fcpdn9ir4mhq8zi50ik0zqa1braahzadx536a9"; type = "gem"; }; version = "0.1.4"; }; unf_ext = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sf6bxvf6x8gihv6j63iakixmdddgls58cpxpg32chckb2l18qcj"; type = "gem"; }; version = "0.0.9.1"; }; useragent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fv5kvq494swy0p17h9qya9r50w15xsi9zmvhzb8gh55kq6ki50p"; type = "gem"; }; version = "0.16.10"; }; webrick = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "089gy5494j560b242vi173wnbj2913hwlwnjkpzld58r96ilc5s3"; type = "gem"; }; version = "1.8.2"; }; wikicloth = { - dependencies = ["builder" "expression_parser" "htmlentities" "nokogiri" "twitter-text"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "builder" + "expression_parser" + "htmlentities" + "nokogiri" + "twitter-text" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0c78r1rg93mb5rcrfxl01b162ma9sh46dhjksc4c9dngg62nhbjh"; type = "gem"; }; diff --git a/pkgs/by-name/go/gollum/package.nix b/pkgs/by-name/go/gollum/package.nix index 9625236193616f..b9b1395fae6fed 100644 --- a/pkgs/by-name/go/gollum/package.nix +++ b/pkgs/by-name/go/gollum/package.nix @@ -1,4 +1,11 @@ -{ lib, bundlerApp, bundlerUpdateScript, ruby, makeWrapper, nixosTests }: +{ + lib, + bundlerApp, + bundlerUpdateScript, + ruby, + makeWrapper, + nixosTests, +}: bundlerApp rec { pname = "gollum"; @@ -17,7 +24,12 @@ bundlerApp rec { homepage = "https://github.com/gollum/gollum"; changelog = "https://github.com/gollum/gollum/blob/HEAD/HISTORY.md"; license = licenses.mit; - maintainers = with maintainers; [ erictapen jgillich nicknovitski bbenno ]; + maintainers = with maintainers; [ + erictapen + jgillich + nicknovitski + bbenno + ]; platforms = platforms.unix; mainProgram = "gollum"; }; diff --git a/pkgs/by-name/go/gom/package.nix b/pkgs/by-name/go/gom/package.nix index 0df28ac88dfde4..7d902ec5ee241c 100644 --- a/pkgs/by-name/go/gom/package.nix +++ b/pkgs/by-name/go/gom/package.nix @@ -1,21 +1,26 @@ -{ lib, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, glib -, python3 -, sqlite -, gdk-pixbuf -, gnome -, gobject-introspection +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + glib, + python3, + sqlite, + gdk-pixbuf, + gnome, + gobject-introspection, }: stdenv.mkDerivation rec { pname = "gom"; version = "0.4"; - outputs = [ "out" "py" ]; + outputs = [ + "out" + "py" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/go/gomacro/package.nix b/pkgs/by-name/go/gomacro/package.nix index 1b2a45da7a4209..237070036b04e7 100644 --- a/pkgs/by-name/go/gomacro/package.nix +++ b/pkgs/by-name/go/gomacro/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gomacro"; diff --git a/pkgs/by-name/go/gomapenum/package.nix b/pkgs/by-name/go/gomapenum/package.nix index 8171d5ef57e835..5153e358cf37f8 100644 --- a/pkgs/by-name/go/gomapenum/package.nix +++ b/pkgs/by-name/go/gomapenum/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gomarkdoc/package.nix b/pkgs/by-name/go/gomarkdoc/package.nix index cea73b16081d4e..f4c7bb49a5fd11 100644 --- a/pkgs/by-name/go/gomarkdoc/package.nix +++ b/pkgs/by-name/go/gomarkdoc/package.nix @@ -3,7 +3,7 @@ buildGoModule, fetchFromGitHub, testers, - gomarkdoc + gomarkdoc, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gomatrix/package.nix b/pkgs/by-name/go/gomatrix/package.nix index 001b57d06eec3e..387b0ed1063a15 100644 --- a/pkgs/by-name/go/gomatrix/package.nix +++ b/pkgs/by-name/go/gomatrix/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gomatrix"; diff --git a/pkgs/by-name/go/gomi/package.nix b/pkgs/by-name/go/gomi/package.nix index 76ef724332e5f7..8bcab4cd2d1bac 100644 --- a/pkgs/by-name/go/gomi/package.nix +++ b/pkgs/by-name/go/gomi/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gomodifytags/package.nix b/pkgs/by-name/go/gomodifytags/package.nix index c66137a82899cb..567499f9e6d31a 100644 --- a/pkgs/by-name/go/gomodifytags/package.nix +++ b/pkgs/by-name/go/gomodifytags/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gomodifytags"; diff --git a/pkgs/by-name/go/gomp/package.nix b/pkgs/by-name/go/gomp/package.nix index 4cac73ebe866db..ee9b5ce7eb0c62 100644 --- a/pkgs/by-name/go/gomp/package.nix +++ b/pkgs/by-name/go/gomp/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchPypi +{ + lib, + python3Packages, + fetchPypi, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/go/gomplate/package.nix b/pkgs/by-name/go/gomplate/package.nix index ef2296e889de64..15127156114aeb 100644 --- a/pkgs/by-name/go/gomplate/package.nix +++ b/pkgs/by-name/go/gomplate/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -42,6 +43,9 @@ buildGoModule rec { homepage = "https://gomplate.ca/"; changelog = "https://github.com/hairyhenderson/gomplate/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ ris jlesquembre ]; + maintainers = with maintainers; [ + ris + jlesquembre + ]; }; } diff --git a/pkgs/by-name/go/gomuks/package.nix b/pkgs/by-name/go/gomuks/package.nix index 510f577a50e938..3dc22caaa00a73 100644 --- a/pkgs/by-name/go/gomuks/package.nix +++ b/pkgs/by-name/go/gomuks/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, makeDesktopItem -, makeWrapper -, libnotify -, olm -, pulseaudio -, sound-theme-freedesktop +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + makeDesktopItem, + makeWrapper, + libnotify, + olm, + pulseaudio, + sound-theme-freedesktop, }: buildGoModule rec { @@ -36,13 +37,23 @@ buildGoModule rec { terminal = true; desktopName = "Gomuks"; genericName = "Matrix client"; - categories = [ "Network" "Chat" ]; + categories = [ + "Network" + "Chat" + ]; comment = meta.description; } }/* $out/ substituteAllInPlace $out/share/applications/* wrapProgram $out/bin/gomuks \ - --prefix PATH : "${lib.makeBinPath (lib.optionals stdenv.hostPlatform.isLinux [ libnotify pulseaudio ])}" \ + --prefix PATH : "${ + lib.makeBinPath ( + lib.optionals stdenv.hostPlatform.isLinux [ + libnotify + pulseaudio + ] + ) + }" \ --set-default GOMUKS_SOUND_NORMAL "${sound-theme-freedesktop}/share/sounds/freedesktop/stereo/message-new-instant.oga" \ --set-default GOMUKS_SOUND_CRITICAL "${sound-theme-freedesktop}/share/sounds/freedesktop/stereo/complete.oga" ''; diff --git a/pkgs/by-name/go/gonic/package.nix b/pkgs/by-name/go/gonic/package.nix index c09c58f0b269d9..d8b28ba5619498 100644 --- a/pkgs/by-name/go/gonic/package.nix +++ b/pkgs/by-name/go/gonic/package.nix @@ -1,15 +1,22 @@ -{ lib, buildGoModule, fetchFromGitHub -, nixosTests -, pkg-config, taglib, zlib +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, + pkg-config, + taglib, + zlib, -# Disable on-the-fly transcoding, -# removing the dependency on ffmpeg. -# The server will (as of 0.11.0) gracefully fall back -# to the original file, but if transcoding is configured -# that takes a while. So best to disable all transcoding -# in the configuration if you disable transcodingSupport. -, transcodingSupport ? true, ffmpeg -, mpv }: + # Disable on-the-fly transcoding, + # removing the dependency on ffmpeg. + # The server will (as of 0.11.0) gracefully fall back + # to the original file, but if transcoding is configured + # that takes a while. So best to disable all transcoding + # in the configuration if you disable transcodingSupport. + transcodingSupport ? true, + ffmpeg, + mpv, +}: buildGoModule rec { pname = "gonic"; @@ -22,29 +29,35 @@ buildGoModule rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ taglib zlib ]; + buildInputs = [ + taglib + zlib + ]; vendorHash = "sha256-6JkaiaAgtXYAZqVSRZJFObZvhEsHsbPaO9pwmKqIhYI="; # TODO(Profpatsch): write a test for transcoding support, # since it is prone to break - postPatch = lib.optionalString transcodingSupport '' - substituteInPlace \ - transcode/transcode.go \ - --replace-fail \ - '`ffmpeg' \ - '`${lib.getBin ffmpeg}/bin/ffmpeg' - '' + '' - substituteInPlace \ - jukebox/jukebox.go \ - --replace-fail \ - '"mpv"' \ - '"${lib.getBin mpv}/bin/mpv"' - '' + '' - substituteInPlace server/ctrlsubsonic/testdata/test* \ - --replace-quiet \ - '"audio/flac"' \ - '"audio/x-flac"' - ''; + postPatch = + lib.optionalString transcodingSupport '' + substituteInPlace \ + transcode/transcode.go \ + --replace-fail \ + '`ffmpeg' \ + '`${lib.getBin ffmpeg}/bin/ffmpeg' + '' + + '' + substituteInPlace \ + jukebox/jukebox.go \ + --replace-fail \ + '"mpv"' \ + '"${lib.getBin mpv}/bin/mpv"' + '' + + '' + substituteInPlace server/ctrlsubsonic/testdata/test* \ + --replace-quiet \ + '"audio/flac"' \ + '"audio/x-flac"' + ''; passthru = { tests.gonic = nixosTests.gonic; diff --git a/pkgs/by-name/go/goocanvasmm2/package.nix b/pkgs/by-name/go/goocanvasmm2/package.nix index ca6951c30e4d71..ae2c4688b8c043 100644 --- a/pkgs/by-name/go/goocanvasmm2/package.nix +++ b/pkgs/by-name/go/goocanvasmm2/package.nix @@ -1,17 +1,31 @@ -{ lib, stdenv, fetchurl, pkg-config, goocanvas2, gtkmm3, gnome }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + goocanvas2, + gtkmm3, + gnome, +}: stdenv.mkDerivation rec { pname = "goocanvasmm"; version = "1.90.11"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; sha256 = "0vpdfrj59nwzwj8bk4s0h05iyql62pxjzsxh72g3vry07s3i3zw0"; }; nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ gtkmm3 goocanvas2 ]; + propagatedBuildInputs = [ + gtkmm3 + goocanvas2 + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/go/goodhosts/package.nix b/pkgs/by-name/go/goodhosts/package.nix index 9f61465b41ff07..dfb80b8a902a6a 100644 --- a/pkgs/by-name/go/goodhosts/package.nix +++ b/pkgs/by-name/go/goodhosts/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, }: buildGoModule rec { diff --git a/pkgs/by-name/go/goodvibes/package.nix b/pkgs/by-name/go/goodvibes/package.nix index 005198ae57bf19..36bdb92052ec40 100644 --- a/pkgs/by-name/go/goodvibes/package.nix +++ b/pkgs/by-name/go/goodvibes/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, glib -, glib-networking -, gtk3 -, libsoup_3 -, keybinder3 -, gst_all_1 -, wrapGAppsHook3 -, appstream-glib -, desktop-file-utils +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + glib, + glib-networking, + gtk3, + libsoup_3, + keybinder3, + gst_all_1, + wrapGAppsHook3, + appstream-glib, + desktop-file-utils, }: stdenv.mkDerivation rec { @@ -35,20 +36,22 @@ stdenv.mkDerivation rec { desktop-file-utils ]; - buildInputs = [ - glib - # for libsoup TLS support - glib-networking - gtk3 - libsoup_3 - keybinder3 - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-good - gst-plugins-bad - gst-plugins-ugly - ]); + buildInputs = + [ + glib + # for libsoup TLS support + glib-networking + gtk3 + libsoup_3 + keybinder3 + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + gst-plugins-ugly + ]); postPatch = '' patchShebangs scripts diff --git a/pkgs/by-name/go/goofys/package.nix b/pkgs/by-name/go/goofys/package.nix index bf4deb7c5c9cab..0a678d455e2d04 100644 --- a/pkgs/by-name/go/goofys/package.nix +++ b/pkgs/by-name/go/goofys/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, }: buildGoModule { diff --git a/pkgs/by-name/go/google-amber/package.nix b/pkgs/by-name/go/google-amber/package.nix index 12ff88d1340e8c..9cc066bb09c3d9 100644 --- a/pkgs/by-name/go/google-amber/package.nix +++ b/pkgs/by-name/go/google-amber/package.nix @@ -1,15 +1,17 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, cctools -, makeWrapper -, mesa -, python3 -, runCommand -, vulkan-headers -, vulkan-loader -, vulkan-validation-layers +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + cctools, + makeWrapper, + mesa, + python3, + runCommand, + vulkan-headers, + vulkan-loader, + vulkan-validation-layers, }: let # From https://github.com/google/amber/blob/main/DEPS @@ -65,17 +67,22 @@ stdenv.mkDerivation (finalAttrs: { vulkan-loader ]; - nativeBuildInputs = [ - cmake - makeWrapper - pkg-config - python3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - cctools - ]; + nativeBuildInputs = + [ + cmake + makeWrapper + pkg-config + python3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + cctools + ]; # Tests are disabled so we do not have to pull in googletest and more dependencies - cmakeFlags = [ "-DAMBER_SKIP_TESTS=ON" "-DAMBER_DISABLE_WERROR=ON" ]; + cmakeFlags = [ + "-DAMBER_SKIP_TESTS=ON" + "-DAMBER_DISABLE_WERROR=ON" + ]; prePatch = '' cp -r ${glslang}/ third_party/glslang @@ -95,48 +102,54 @@ stdenv.mkDerivation (finalAttrs: { --suffix VK_LAYER_PATH : ${vulkan-validation-layers}/share/vulkan/explicit_layer.d ''; - passthru.tests.lavapipe = runCommand "vulkan-cts-tests-lavapipe" { - nativeBuildInputs = [ finalAttrs.finalPackage mesa.llvmpipeHook ]; - } '' - cat > test.amber < SIZE 524288 FILL 0 - - PIPELINE compute kComputePipeline - ATTACH kComputeShader - BIND BUFFER kComputeBuffer AS storage DESCRIPTOR_SET 0 BINDING 3 - END # pipeline - - RUN kComputePipeline 256 256 1 - - # Four corners - EXPECT kComputeBuffer IDX 0 EQ 0 0 - EXPECT kComputeBuffer IDX 2040 EQ 255 0 - EXPECT kComputeBuffer IDX 522240 EQ 0 255 - EXPECT kComputeBuffer IDX 524280 EQ 255 255 - - # Center - EXPECT kComputeBuffer IDX 263168 EQ 128 128 - EOF - - amber test.amber - touch $out - ''; + passthru.tests.lavapipe = + runCommand "vulkan-cts-tests-lavapipe" + { + nativeBuildInputs = [ + finalAttrs.finalPackage + mesa.llvmpipeHook + ]; + } + '' + cat > test.amber < SIZE 524288 FILL 0 + + PIPELINE compute kComputePipeline + ATTACH kComputeShader + BIND BUFFER kComputeBuffer AS storage DESCRIPTOR_SET 0 BINDING 3 + END # pipeline + + RUN kComputePipeline 256 256 1 + + # Four corners + EXPECT kComputeBuffer IDX 0 EQ 0 0 + EXPECT kComputeBuffer IDX 2040 EQ 255 0 + EXPECT kComputeBuffer IDX 522240 EQ 0 255 + EXPECT kComputeBuffer IDX 524280 EQ 255 255 + + # Center + EXPECT kComputeBuffer IDX 263168 EQ 128 128 + EOF + + amber test.amber + touch $out + ''; meta = with lib; { description = "Multi-API shader test framework"; diff --git a/pkgs/by-name/go/google-app-engine-go-sdk/package.nix b/pkgs/by-name/go/google-app-engine-go-sdk/package.nix index 1230ac606ecf6b..ab1a486c274428 100644 --- a/pkgs/by-name/go/google-app-engine-go-sdk/package.nix +++ b/pkgs/by-name/go/google-app-engine-go-sdk/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchzip, python3Packages, makeWrapper }: +{ + lib, + stdenv, + fetchzip, + python3Packages, + makeWrapper, +}: with python3Packages; @@ -38,10 +44,13 @@ stdenv.mkDerivation rec { homepage = "https://cloud.google.com/appengine/docs/go/"; sourceProvenance = with sourceTypes; [ fromSource - binaryNativeCode # includes golang toolchain binaries + binaryNativeCode # includes golang toolchain binaries ]; license = licenses.asl20; - platforms = ["x86_64-linux" "x86_64-darwin"]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; maintainers = with maintainers; [ lufia ]; }; } diff --git a/pkgs/by-name/go/google-authenticator/package.nix b/pkgs/by-name/go/google-authenticator/package.nix index 11791a664c8bb0..0334a252510f26 100644 --- a/pkgs/by-name/go/google-authenticator/package.nix +++ b/pkgs/by-name/go/google-authenticator/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, autoreconfHook, pam, qrencode }: +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + pam, + qrencode, +}: stdenv.mkDerivation rec { pname = "google-authenticator-libpam"; diff --git a/pkgs/by-name/go/google-clasp/package.nix b/pkgs/by-name/go/google-clasp/package.nix index 2b2d6758410bf4..abf89139867dcf 100644 --- a/pkgs/by-name/go/google-clasp/package.nix +++ b/pkgs/by-name/go/google-clasp/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/go/google-cloud-bigtable-tool/package.nix b/pkgs/by-name/go/google-cloud-bigtable-tool/package.nix index 6e26aac5284dfa..889a98208f666c 100644 --- a/pkgs/by-name/go/google-cloud-bigtable-tool/package.nix +++ b/pkgs/by-name/go/google-cloud-bigtable-tool/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/google-cloud-cpp/package.nix b/pkgs/by-name/go/google-cloud-cpp/package.nix index af00bc1690f73a..83f55078d6a635 100644 --- a/pkgs/by-name/go/google-cloud-cpp/package.nix +++ b/pkgs/by-name/go/google-cloud-cpp/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, substituteAll -, c-ares -, cmake -, crc32c -, curl -, gbenchmark -, grpc -, gtest -, ninja -, nlohmann_json -, openssl -, pkg-config -, protobuf -, pkgsBuildHost +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + c-ares, + cmake, + crc32c, + curl, + gbenchmark, + grpc, + gtest, + ninja, + nlohmann_json, + openssl, + pkg-config, + protobuf, + pkgsBuildHost, # default list of APIs: https://github.com/googleapis/google-cloud-cpp/blob/v1.32.1/CMakeLists.txt#L173 -, apis ? [ "*" ] -, staticOnly ? stdenv.hostPlatform.isStatic + apis ? [ "*" ], + staticOnly ? stdenv.hostPlatform.isStatic, }: let # defined in cmake/GoogleapisConfig.cmake @@ -48,18 +49,20 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ - cmake - ninja - pkg-config - ] ++ lib.optionals (!doInstallCheck) [ - # enable these dependencies when doInstallCheck is false because we're - # unconditionally building tests and benchmarks - # - # when doInstallCheck is true, these deps are added to nativeInstallCheckInputs - gbenchmark - gtest - ]; + nativeBuildInputs = + [ + cmake + ninja + pkg-config + ] + ++ lib.optionals (!doInstallCheck) [ + # enable these dependencies when doInstallCheck is false because we're + # unconditionally building tests and benchmarks + # + # when doInstallCheck is true, these deps are added to nativeInstallCheckInputs + gbenchmark + gtest + ]; buildInputs = [ c-ares @@ -98,41 +101,46 @@ stdenv.mkDerivation rec { '' ); - installCheckPhase = let - disabledTests = lib.optionalString stdenv.hostPlatform.isDarwin '' - common_internal_async_connection_ready_test - bigtable_async_read_stream_test - bigtable_metadata_update_policy_test - bigtable_bigtable_benchmark_test - bigtable_embedded_server_test - ''; - in '' - runHook preInstallCheck + installCheckPhase = + let + disabledTests = lib.optionalString stdenv.hostPlatform.isDarwin '' + common_internal_async_connection_ready_test + bigtable_async_read_stream_test + bigtable_metadata_update_policy_test + bigtable_bigtable_benchmark_test + bigtable_embedded_server_test + ''; + in + '' + runHook preInstallCheck - # Disable any integration tests, which need to contact the internet. - ctest \ - --label-exclude integration-test \ - --exclude-from-file <(echo '${disabledTests}') + # Disable any integration tests, which need to contact the internet. + ctest \ + --label-exclude integration-test \ + --exclude-from-file <(echo '${disabledTests}') - runHook postInstallCheck - ''; + runHook postInstallCheck + ''; nativeInstallCheckInputs = lib.optionals doInstallCheck [ gbenchmark gtest ]; - cmakeFlags = [ - "-DBUILD_SHARED_LIBS:BOOL=${if staticOnly then "OFF" else "ON"}" - # unconditionally build tests to catch linker errors as early as possible - # this adds a good chunk of time to the build - "-DBUILD_TESTING:BOOL=ON" - "-DGOOGLE_CLOUD_CPP_ENABLE_EXAMPLES:BOOL=OFF" - ] ++ lib.optionals (apis != [ "*" ]) [ - "-DGOOGLE_CLOUD_CPP_ENABLE=${lib.concatStringsSep ";" apis}" - ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ - "-DGOOGLE_CLOUD_CPP_GRPC_PLUGIN_EXECUTABLE=${lib.getBin pkgsBuildHost.grpc}/bin/grpc_cpp_plugin" - ]; + cmakeFlags = + [ + "-DBUILD_SHARED_LIBS:BOOL=${if staticOnly then "OFF" else "ON"}" + # unconditionally build tests to catch linker errors as early as possible + # this adds a good chunk of time to the build + "-DBUILD_TESTING:BOOL=ON" + "-DGOOGLE_CLOUD_CPP_ENABLE_EXAMPLES:BOOL=OFF" + ] + ++ lib.optionals (apis != [ "*" ]) [ + "-DGOOGLE_CLOUD_CPP_ENABLE=${lib.concatStringsSep ";" apis}" + ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "-DGOOGLE_CLOUD_CPP_GRPC_PLUGIN_EXECUTABLE=${lib.getBin pkgsBuildHost.grpc}/bin/grpc_cpp_plugin" + ]; requiredSystemFeatures = [ "big-parallel" ]; diff --git a/pkgs/by-name/go/google-cloud-sql-proxy/package.nix b/pkgs/by-name/go/google-cloud-sql-proxy/package.nix index 3778d911c53f5c..f1042fd50a4a15 100644 --- a/pkgs/by-name/go/google-cloud-sql-proxy/package.nix +++ b/pkgs/by-name/go/google-cloud-sql-proxy/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, }: buildGoModule rec { @@ -37,7 +38,10 @@ buildGoModule rec { ''; homepage = "https://github.com/GoogleCloudPlatform/cloud-sql-proxy"; license = licenses.asl20; - maintainers = with maintainers; [ nicknovitski totoroot ]; + maintainers = with maintainers; [ + nicknovitski + totoroot + ]; mainProgram = "cloud-sql-proxy"; }; } diff --git a/pkgs/by-name/go/google-cursor/package.nix b/pkgs/by-name/go/google-cursor/package.nix index 0000d55ab0b513..ab341044e22136 100644 --- a/pkgs/by-name/go/google-cursor/package.nix +++ b/pkgs/by-name/go/google-cursor/package.nix @@ -1,6 +1,7 @@ -{ stdenvNoCC -, fetchzip -, lib +{ + stdenvNoCC, + fetchzip, + lib, }: let @@ -28,13 +29,14 @@ stdenvNoCC.mkDerivation (finalAttrs: { version = "2.0.0"; sourceRoot = "."; - srcs = map - (color: (fetchzip { + srcs = map ( + color: + (fetchzip { url = "https://github.com/ful1e5/Google_Cursor/releases/download/v${finalAttrs.version}/GoogleDot-${color.name}.tar.gz"; name = "GoogleDot-${color.name}"; hash = color.hash; - })) - colors; + }) + ) colors; postInstall = '' mkdir -p $out/share/icons diff --git a/pkgs/by-name/go/google-fonts/package.nix b/pkgs/by-name/go/google-fonts/package.nix index 04236ac505a94c..8e1338bbd88013 100644 --- a/pkgs/by-name/go/google-fonts/package.nix +++ b/pkgs/by-name/go/google-fonts/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, fonts ? [] +{ + lib, + stdenvNoCC, + fetchFromGitHub, + fonts ? [ ], }: stdenvNoCC.mkDerivation { @@ -11,7 +12,10 @@ stdenvNoCC.mkDerivation { # Adobe Blank is split out in a separate output, # because it causes crashes with `libfontconfig`. # It has an absurd number of symbols - outputs = [ "out" "adobeBlank" ]; + outputs = [ + "out" + "adobeBlank" + ]; src = fetchFromGitHub { owner = "google"; @@ -44,26 +48,37 @@ stdenvNoCC.mkDerivation { # FamilyName-StyleName.ttf, FamilyName[param1,param2,...].ttf, and # FamilyName.ttf. This installs all fonts if fonts is empty and otherwise # only the specified fonts by FamilyName. - fonts = map (font: builtins.replaceStrings [" "] [""] font) fonts; - installPhase = '' - adobeBlankDest=$adobeBlank/share/fonts/truetype - install -m 444 -Dt $adobeBlankDest ofl/adobeblank/AdobeBlank-Regular.ttf - rm -r ofl/adobeblank - dest=$out/share/fonts/truetype - '' + (if fonts == [] then '' - find . -name '*.ttf' -exec install -m 444 -Dt $dest '{}' + - '' else '' - for font in $fonts; do - find . \( -name "$font-*.ttf" -o -name "$font[*.ttf" -o -name "$font.ttf" \) -exec install -m 444 -Dt $dest '{}' + - done - ''); + fonts = map (font: builtins.replaceStrings [ " " ] [ "" ] font) fonts; + installPhase = + '' + adobeBlankDest=$adobeBlank/share/fonts/truetype + install -m 444 -Dt $adobeBlankDest ofl/adobeblank/AdobeBlank-Regular.ttf + rm -r ofl/adobeblank + dest=$out/share/fonts/truetype + '' + + ( + if fonts == [ ] then + '' + find . -name '*.ttf' -exec install -m 444 -Dt $dest '{}' + + '' + else + '' + for font in $fonts; do + find . \( -name "$font-*.ttf" -o -name "$font[*.ttf" -o -name "$font.ttf" \) -exec install -m 444 -Dt $dest '{}' + + done + '' + ); meta = with lib; { homepage = "https://fonts.google.com"; description = "Font files available from Google Fonts"; - license = with licenses; [ asl20 ofl ufl ]; + license = with licenses; [ + asl20 + ofl + ufl + ]; platforms = platforms.all; - hydraPlatforms = []; + hydraPlatforms = [ ]; maintainers = with maintainers; [ manveru ]; sourceProvenance = [ sourceTypes.binaryBytecode ]; }; diff --git a/pkgs/by-name/go/google-guest-agent/package.nix b/pkgs/by-name/go/google-guest-agent/package.nix index 423f43a02de03f..6f545c73764d5d 100644 --- a/pkgs/by-name/go/google-guest-agent/package.nix +++ b/pkgs/by-name/go/google-guest-agent/package.nix @@ -1,12 +1,13 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, coreutils -, makeWrapper -, google-guest-configs -, google-guest-oslogin -, iproute2 -, procps +{ + lib, + buildGoModule, + fetchFromGitHub, + coreutils, + makeWrapper, + google-guest-configs, + google-guest-oslogin, + iproute2, + procps, }: buildGoModule rec { diff --git a/pkgs/by-name/go/google-guest-configs/package.nix b/pkgs/by-name/go/google-guest-configs/package.nix index 73dd3c93d2558b..5a3bf68579a926 100644 --- a/pkgs/by-name/go/google-guest-configs/package.nix +++ b/pkgs/by-name/go/google-guest-configs/package.nix @@ -1,5 +1,17 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper -, ipcalc, iproute2, util-linux, coreutils, ethtool, gnugrep, gnused, nvme-cli }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + ipcalc, + iproute2, + util-linux, + coreutils, + ethtool, + gnugrep, + gnused, + nvme-cli, +}: stdenv.mkDerivation rec { pname = "google-guest-configs"; @@ -12,7 +24,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-0SRu6p/DsHNNI20mkXJitt/Ee5S2ooiy5hNmD+ndecM="; }; - binDeps = lib.makeBinPath [ coreutils util-linux gnugrep gnused ethtool ipcalc iproute2 ]; + binDeps = lib.makeBinPath [ + coreutils + util-linux + gnugrep + gnused + ethtool + ipcalc + iproute2 + ]; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/by-name/go/google-java-format/package.nix b/pkgs/by-name/go/google-java-format/package.nix index f54434fad949c0..a88b7c11726d63 100644 --- a/pkgs/by-name/go/google-java-format/package.nix +++ b/pkgs/by-name/go/google-java-format/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "google-java-format"; diff --git a/pkgs/by-name/go/goose/package.nix b/pkgs/by-name/go/goose/package.nix index 2dca37b2259d5e..a572100fa73054 100644 --- a/pkgs/by-name/go/goose/package.nix +++ b/pkgs/by-name/go/goose/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, stdenv +{ + lib, + buildGoModule, + fetchFromGitHub, + stdenv, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gopacked/package.nix b/pkgs/by-name/go/gopacked/package.nix index 1ce8d1cb4e1787..9c482c172bc6c4 100644 --- a/pkgs/by-name/go/gopacked/package.nix +++ b/pkgs/by-name/go/gopacked/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gopacked"; diff --git a/pkgs/by-name/go/gopatch/package.nix b/pkgs/by-name/go/gopatch/package.nix index 276176c2d65a29..ad7a50f3d82e1a 100644 --- a/pkgs/by-name/go/gopatch/package.nix +++ b/pkgs/by-name/go/gopatch/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, gopatch +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + gopatch, }: buildGoModule rec { diff --git a/pkgs/by-name/go/goperf/package.nix b/pkgs/by-name/go/goperf/package.nix index 1f64a4db4824ce..5fc39adb7f46a4 100644 --- a/pkgs/by-name/go/goperf/package.nix +++ b/pkgs/by-name/go/goperf/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchgit -, writeShellScript -, unstableGitUpdater -, sd +{ + lib, + buildGoModule, + fetchgit, + writeShellScript, + unstableGitUpdater, + sd, }: buildGoModule rec { @@ -20,7 +21,9 @@ buildGoModule rec { passthru.updateScript = writeShellScript "update-goperf" '' export UPDATE_NIX_ATTR_PATH=goperf - ${lib.escapeShellArgs (unstableGitUpdater { inherit (src) url; })} + ${lib.escapeShellArgs (unstableGitUpdater { + inherit (src) url; + })} set -x oldhash="$(nix-instantiate . --eval --strict -A "goperf.goModules.drvAttrs.outputHash" | cut -d'"' -f2)" newhash="$(nix-build -A goperf.goModules --no-out-link 2>&1 | tail -n3 | grep 'got:' | cut -d: -f2- | xargs echo || true)" diff --git a/pkgs/by-name/go/gopher/package.nix b/pkgs/by-name/go/gopher/package.nix index 822acd530749d1..1bab4c4abcb97c 100644 --- a/pkgs/by-name/go/gopher/package.nix +++ b/pkgs/by-name/go/gopher/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { pname = "gopher"; diff --git a/pkgs/by-name/go/gophernotes/package.nix b/pkgs/by-name/go/gophernotes/package.nix index 9e6ebb47f96685..f4829ba509a370 100644 --- a/pkgs/by-name/go/gophernotes/package.nix +++ b/pkgs/by-name/go/gophernotes/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gophish/package.nix b/pkgs/by-name/go/gophish/package.nix index a319b2bd97e875..04c4e53425cf74 100644 --- a/pkgs/by-name/go/gophish/package.nix +++ b/pkgs/by-name/go/gophish/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gopkgs/package.nix b/pkgs/by-name/go/gopkgs/package.nix index ba7d9ffccde3f5..f4b8c3a86cb278 100644 --- a/pkgs/by-name/go/gopkgs/package.nix +++ b/pkgs/by-name/go/gopkgs/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gopkgs"; diff --git a/pkgs/by-name/go/gopls/package.nix b/pkgs/by-name/go/gopls/package.nix index b9f44017da96ae..aa03f4ac73c762 100644 --- a/pkgs/by-name/go/gopls/package.nix +++ b/pkgs/by-name/go/gopls/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gopls"; @@ -27,7 +31,12 @@ buildGoModule rec { homepage = "https://github.com/golang/tools/tree/master/gopls"; changelog = "https://github.com/golang/tools/releases/tag/${src.rev}"; license = licenses.bsd3; - maintainers = with maintainers; [ mic92 rski SuperSandro2000 zimbatm ]; + maintainers = with maintainers; [ + mic92 + rski + SuperSandro2000 + zimbatm + ]; mainProgram = "gopls"; }; } diff --git a/pkgs/by-name/go/gopro/package.nix b/pkgs/by-name/go/gopro/package.nix index 2876e9aa18426a..296a25f045ff06 100644 --- a/pkgs/by-name/go/gopro/package.nix +++ b/pkgs/by-name/go/gopro/package.nix @@ -1,8 +1,11 @@ -{ lib, stdenv, fetchFromGitHub -, ffmpeg -, imagemagick -, makeWrapper -, mplayer +{ + lib, + stdenv, + fetchFromGitHub, + ffmpeg, + imagemagick, + makeWrapper, + mplayer, }: stdenv.mkDerivation rec { @@ -23,7 +26,13 @@ stdenv.mkDerivation rec { install -Dm755 gopro -t $out/bin wrapProgram $out/bin/gopro \ - --prefix PATH ":" "${lib.makeBinPath [ ffmpeg imagemagick mplayer ]}" + --prefix PATH ":" "${ + lib.makeBinPath [ + ffmpeg + imagemagick + mplayer + ] + }" runHook postInstall ''; diff --git a/pkgs/by-name/go/gops/package.nix b/pkgs/by-name/go/gops/package.nix index 3c1f5e2ac5ccb1..2aeb490fa3f6b8 100644 --- a/pkgs/by-name/go/gops/package.nix +++ b/pkgs/by-name/go/gops/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gops"; diff --git a/pkgs/by-name/go/gopsuinfo/package.nix b/pkgs/by-name/go/gopsuinfo/package.nix index fcb84cfde87042..37b1d4123c2201 100644 --- a/pkgs/by-name/go/gopsuinfo/package.nix +++ b/pkgs/by-name/go/gopsuinfo/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gordonflashtool/package.nix b/pkgs/by-name/go/gordonflashtool/package.nix index 7f49895739a26d..b6548d02234789 100644 --- a/pkgs/by-name/go/gordonflashtool/package.nix +++ b/pkgs/by-name/go/gordonflashtool/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, nasm, unixtools }: +{ + lib, + stdenv, + fetchFromGitHub, + nasm, + unixtools, +}: let version = "10"; @@ -15,7 +21,10 @@ stdenv.mkDerivation { hash = "sha256-/zpw7kVdQeR7QcRsP1+qcu8+hlEQTGwOKClJkwVcBPg="; }; - nativeBuildInputs = [ nasm unixtools.xxd ]; + nativeBuildInputs = [ + nasm + unixtools.xxd + ]; buildPhase = '' runHook preBuild diff --git a/pkgs/by-name/go/gore/package.nix b/pkgs/by-name/go/gore/package.nix index af9b48e85a382b..33e54e64766517 100644 --- a/pkgs/by-name/go/gore/package.nix +++ b/pkgs/by-name/go/gore/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gore"; diff --git a/pkgs/by-name/go/goread/package.nix b/pkgs/by-name/go/goread/package.nix index c25575dcfeef6c..a6220e172f6002 100644 --- a/pkgs/by-name/go/goread/package.nix +++ b/pkgs/by-name/go/goread/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "goread"; diff --git a/pkgs/by-name/go/goredo/package.nix b/pkgs/by-name/go/goredo/package.nix index 57835efc4acc91..145ea72af6f6a6 100644 --- a/pkgs/by-name/go/goredo/package.nix +++ b/pkgs/by-name/go/goredo/package.nix @@ -1,10 +1,11 @@ -{ buildGoModule -, fetchurl -, lib -, zstd -, sharness -, python3 -, perl +{ + buildGoModule, + fetchurl, + lib, + zstd, + sharness, + python3, + perl, }: buildGoModule rec { @@ -23,7 +24,10 @@ buildGoModule rec { nativeBuildInputs = [ zstd ]; - nativeCheckInputs = lib.optionals doCheck [ python3 perl ]; + nativeCheckInputs = lib.optionals doCheck [ + python3 + perl + ]; inherit (sharness) SHARNESS_TEST_SRCDIR; @@ -50,7 +54,10 @@ buildGoModule rec { cp goredo.info "$out/share/info" ''; - outputs = [ "out" "info" ]; + outputs = [ + "out" + "info" + ]; meta = with lib; { outputsToInstall = [ "out" ]; diff --git a/pkgs/by-name/go/goreman/package.nix b/pkgs/by-name/go/goreman/package.nix index c5154bfbbad515..9a572a8a41b89a 100644 --- a/pkgs/by-name/go/goreman/package.nix +++ b/pkgs/by-name/go/goreman/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, goreman }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + goreman, +}: buildGoModule rec { pname = "goreman"; @@ -13,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-Udm0xdrW8Aky26oxUhdbpsNTWziZxkM0G1ZRKLwyl1Q="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests.version = testers.testVersion { package = goreman; diff --git a/pkgs/by-name/go/goreplay/package.nix b/pkgs/by-name/go/goreplay/package.nix index 71081713c70d2b..bea28693a6df53 100644 --- a/pkgs/by-name/go/goreplay/package.nix +++ b/pkgs/by-name/go/goreplay/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch, libpcap }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + libpcap, +}: buildGoModule rec { pname = "goreplay"; @@ -21,7 +27,10 @@ buildGoModule rec { vendorHash = "sha256-jDMAtcq3ZowFdky5BdTkVNxq4ltkhklr76nXYJgGALg="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; buildInputs = [ libpcap ]; diff --git a/pkgs/by-name/go/goresym/package.nix b/pkgs/by-name/go/goresym/package.nix index d20a9a6c809a83..80ed06fd0fb8d9 100644 --- a/pkgs/by-name/go/goresym/package.nix +++ b/pkgs/by-name/go/goresym/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, unzip +{ + lib, + fetchFromGitHub, + buildGoModule, + unzip, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gorilla-bin/package.nix b/pkgs/by-name/go/gorilla-bin/package.nix index 95ca0b08bf8ef1..14a6a5ed14f5a3 100644 --- a/pkgs/by-name/go/gorilla-bin/package.nix +++ b/pkgs/by-name/go/gorilla-bin/package.nix @@ -1,4 +1,17 @@ -{ fetchurl, makeWrapper, patchelf, lib, stdenv, libXft, libX11, freetype, fontconfig, libXrender, libXScrnSaver, libXext }: +{ + fetchurl, + makeWrapper, + patchelf, + lib, + stdenv, + libXft, + libX11, + freetype, + fontconfig, + libXrender, + libXScrnSaver, + libXext, +}: stdenv.mkDerivation rec { pname = "gorilla-bin"; @@ -10,25 +23,38 @@ stdenv.mkDerivation rec { sha256 = "19ir6x4c01825hpx2wbbcxkk70ymwbw4j03v8b2xc13ayylwzx0r"; }; - nativeBuildInputs = [ patchelf makeWrapper ]; + nativeBuildInputs = [ + patchelf + makeWrapper + ]; unpackCmd = '' mkdir gorilla; cp $curSrc gorilla/gorilla-${version}; ''; - installPhase = let - interpreter = "$(< \"$NIX_CC/nix-support/dynamic-linker\")"; - libPath = lib.makeLibraryPath [ libXft libX11 freetype fontconfig libXrender libXScrnSaver libXext ]; - in '' - mkdir -p $out/opt/password-gorilla - mkdir -p $out/bin - cp gorilla-${version} $out/opt/password-gorilla - chmod ugo+x $out/opt/password-gorilla/gorilla-${version} - patchelf --set-interpreter "${interpreter}" "$out/opt/password-gorilla/gorilla-${version}" - makeWrapper "$out/opt/password-gorilla/gorilla-${version}" "$out/bin/gorilla" \ - --prefix LD_LIBRARY_PATH : "${libPath}" - ''; + installPhase = + let + interpreter = "$(< \"$NIX_CC/nix-support/dynamic-linker\")"; + libPath = lib.makeLibraryPath [ + libXft + libX11 + freetype + fontconfig + libXrender + libXScrnSaver + libXext + ]; + in + '' + mkdir -p $out/opt/password-gorilla + mkdir -p $out/bin + cp gorilla-${version} $out/opt/password-gorilla + chmod ugo+x $out/opt/password-gorilla/gorilla-${version} + patchelf --set-interpreter "${interpreter}" "$out/opt/password-gorilla/gorilla-${version}" + makeWrapper "$out/opt/password-gorilla/gorilla-${version}" "$out/bin/gorilla" \ + --prefix LD_LIBRARY_PATH : "${libPath}" + ''; meta = { description = "Password Gorilla is a Tk based password manager"; diff --git a/pkgs/by-name/go/gorilla-cli/package.nix b/pkgs/by-name/go/gorilla-cli/package.nix index b3e5a0fde509bc..58d362fe9351a4 100644 --- a/pkgs/by-name/go/gorilla-cli/package.nix +++ b/pkgs/by-name/go/gorilla-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, nix-update-script +{ + lib, + python3, + fetchFromGitHub, + nix-update-script, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/go/gorm-gentool/package.nix b/pkgs/by-name/go/gorm-gentool/package.nix index b4982427c90067..684196730602c0 100644 --- a/pkgs/by-name/go/gorm-gentool/package.nix +++ b/pkgs/by-name/go/gorm-gentool/package.nix @@ -24,6 +24,6 @@ buildGoModule rec { description = "Gen: Friendly & Safer GORM powered by Code Generation"; license = licenses.mit; mainProgram = "gentool"; - maintainers = with maintainers; [tembleking]; + maintainers = with maintainers; [ tembleking ]; }; } diff --git a/pkgs/by-name/go/gosec/package.nix b/pkgs/by-name/go/gosec/package.nix index be4d2d39dc5ff7..1f315ef6c3f06d 100644 --- a/pkgs/by-name/go/gosec/package.nix +++ b/pkgs/by-name/go/gosec/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -33,6 +34,9 @@ buildGoModule rec { description = "Golang security checker"; mainProgram = "gosec"; license = licenses.asl20; - maintainers = with maintainers; [ kalbasit nilp0inter ]; + maintainers = with maintainers; [ + kalbasit + nilp0inter + ]; }; } diff --git a/pkgs/by-name/go/gosh/package.nix b/pkgs/by-name/go/gosh/package.nix index 41ef9fa1f540e4..eb72987300d0ca 100644 --- a/pkgs/by-name/go/gosh/package.nix +++ b/pkgs/by-name/go/gosh/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gosimports/package.nix b/pkgs/by-name/go/gosimports/package.nix index c47446d1a7a6f6..72826ccc9da8ab 100644 --- a/pkgs/by-name/go/gosimports/package.nix +++ b/pkgs/by-name/go/gosimports/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gosmee/package.nix b/pkgs/by-name/go/gosmee/package.nix index bfa2fba409a9a8..73f7ab8fc3e716 100644 --- a/pkgs/by-name/go/gosmee/package.nix +++ b/pkgs/by-name/go/gosmee/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -33,6 +34,9 @@ buildGoModule rec { description = "Command line server and client for webhooks deliveries (and https://smee.io)"; homepage = "https://github.com/chmouel/gosmee"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ vdemeester chmouel ]; + maintainers = with lib.maintainers; [ + vdemeester + chmouel + ]; }; } diff --git a/pkgs/by-name/go/gosmore/package.nix b/pkgs/by-name/go/gosmore/package.nix index daa5553d0c0aef..7fba8cee89f995 100644 --- a/pkgs/by-name/go/gosmore/package.nix +++ b/pkgs/by-name/go/gosmore/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libxml2, gtk2, curl, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + libxml2, + gtk2, + curl, + pkg-config, +}: stdenv.mkDerivation rec { pname = "gosmore"; @@ -14,7 +22,11 @@ stdenv.mkDerivation rec { sourceRoot = "${src.name}/applications/rendering/gosmore"; - buildInputs = [ libxml2 gtk2 curl ]; + buildInputs = [ + libxml2 + gtk2 + curl + ]; nativeBuildInputs = [ pkg-config ]; @@ -24,7 +36,10 @@ stdenv.mkDerivation rec { ''; patches = [ ./pointer_int_comparison.patch ]; - patchFlags = [ "-p1" "--binary" ]; # patch has dos style eol + patchFlags = [ + "-p1" + "--binary" + ]; # patch has dos style eol meta = with lib; { description = "Open Street Map viewer"; diff --git a/pkgs/by-name/go/gospider/package.nix b/pkgs/by-name/go/gospider/package.nix index d78089f6072ecf..6b3f226106c226 100644 --- a/pkgs/by-name/go/gospider/package.nix +++ b/pkgs/by-name/go/gospider/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gossa/package.nix b/pkgs/by-name/go/gossa/package.nix index a19ae4672f9b3e..bce4c6bf057716 100644 --- a/pkgs/by-name/go/gossa/package.nix +++ b/pkgs/by-name/go/gossa/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { @@ -17,7 +18,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; # Tests require a socket connection to be created. doCheck = false; diff --git a/pkgs/by-name/go/gost/package.nix b/pkgs/by-name/go/gost/package.nix index 311aa1de3bbf41..5a515427bd126e 100644 --- a/pkgs/by-name/go/gost/package.nix +++ b/pkgs/by-name/go/gost/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, fetchpatch }: +{ + lib, + fetchFromGitHub, + buildGoModule, + fetchpatch, +}: buildGoModule rec { pname = "gost"; diff --git a/pkgs/by-name/go/gostatic/package.nix b/pkgs/by-name/go/gostatic/package.nix index b7967f6f4e4ffb..6b0ce598ca8848 100644 --- a/pkgs/by-name/go/gostatic/package.nix +++ b/pkgs/by-name/go/gostatic/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gosu/package.nix b/pkgs/by-name/go/gosu/package.nix index 0768b551fe10db..d2213d926c5e42 100644 --- a/pkgs/by-name/go/gosu/package.nix +++ b/pkgs/by-name/go/gosu/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, gosu }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + gosu, +}: buildGoModule rec { pname = "gosu"; @@ -13,7 +19,11 @@ buildGoModule rec { vendorHash = "sha256-fygLYSO0kpMFJd6WQp/uLYkELkyaOPZ9V8BrJcIcMuU="; - ldflags = [ "-d" "-s" "-w" ]; + ldflags = [ + "-d" + "-s" + "-w" + ]; passthru.tests.version = testers.testVersion { package = gosu; diff --git a/pkgs/by-name/go/gotags/package.nix b/pkgs/by-name/go/gotags/package.nix index f73bfa69693dcb..3b46a4cf9c6888 100644 --- a/pkgs/by-name/go/gotags/package.nix +++ b/pkgs/by-name/go/gotags/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "gotags"; @@ -21,7 +26,10 @@ buildGoModule rec { }) ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "ctags-compatible tag generator for Go"; diff --git a/pkgs/by-name/go/gotest/package.nix b/pkgs/by-name/go/gotest/package.nix index 2f54241d651d3a..4c565840fee6d6 100644 --- a/pkgs/by-name/go/gotest/package.nix +++ b/pkgs/by-name/go/gotest/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gotest"; diff --git a/pkgs/by-name/go/gotestfmt/package.nix b/pkgs/by-name/go/gotestfmt/package.nix index 0bd71fd5ea5885..f0b7babdde9ca4 100644 --- a/pkgs/by-name/go/gotestfmt/package.nix +++ b/pkgs/by-name/go/gotestfmt/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "gotestfmt"; diff --git a/pkgs/by-name/go/gotests/package.nix b/pkgs/by-name/go/gotests/package.nix index 2086df1051bae2..d0ad80fbb9daa8 100644 --- a/pkgs/by-name/go/gotests/package.nix +++ b/pkgs/by-name/go/gotests/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gotests"; diff --git a/pkgs/by-name/go/gotify-cli/package.nix b/pkgs/by-name/go/gotify-cli/package.nix index 94a7c8c82eeee6..9dc87997cc3727 100644 --- a/pkgs/by-name/go/gotify-cli/package.nix +++ b/pkgs/by-name/go/gotify-cli/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "gotify-cli"; @@ -18,7 +22,9 @@ buildGoModule rec { ''; ldflags = [ - "-X main.Version=${version}" "-X main.Commit=${version}" "-X main.BuildDate=1970-01-01" + "-X main.Version=${version}" + "-X main.Commit=${version}" + "-X main.BuildDate=1970-01-01" ]; meta = with lib; { diff --git a/pkgs/by-name/go/gotify-desktop/package.nix b/pkgs/by-name/go/gotify-desktop/package.nix index e184c38d5eb7c0..9abc5bc183f779 100644 --- a/pkgs/by-name/go/gotify-desktop/package.nix +++ b/pkgs/by-name/go/gotify-desktop/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, rustPlatform, openssl, pkg-config, stdenv}: +{ + lib, + fetchFromGitHub, + rustPlatform, + openssl, + pkg-config, + stdenv, +}: rustPlatform.buildRustPackage rec { pname = "gotify-desktop"; @@ -21,7 +28,10 @@ rustPlatform.buildRustPackage rec { description = "Small Gotify daemon to send messages as desktop notifications"; homepage = "https://github.com/desbma/gotify-desktop"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ bryanasdev000 genofire ]; + maintainers = with maintainers; [ + bryanasdev000 + genofire + ]; broken = stdenv.hostPlatform.isDarwin; mainProgram = "gotify-desktop"; }; diff --git a/pkgs/by-name/go/gotify-server/package.nix b/pkgs/by-name/go/gotify-server/package.nix index b4ee796dc0b740..3946198e2fbcf8 100644 --- a/pkgs/by-name/go/gotify-server/package.nix +++ b/pkgs/by-name/go/gotify-server/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, sqlite -, callPackage -, nixosTests -, nix-update-script +{ + lib, + fetchFromGitHub, + buildGoModule, + sqlite, + callPackage, + nixosTests, + nix-update-script, }: buildGoModule rec { @@ -56,7 +57,8 @@ buildGoModule rec { subPackages = [ "." ]; ldflags = [ - "-X main.Version=${version}" "-X main.Mode=prod" + "-X main.Version=${version}" + "-X main.Mode=prod" ]; meta = with lib; { diff --git a/pkgs/by-name/go/gotify-server/ui.nix b/pkgs/by-name/go/gotify-server/ui.nix index 7d43e219ccf12c..104b5670b9943e 100644 --- a/pkgs/by-name/go/gotify-server/ui.nix +++ b/pkgs/by-name/go/gotify-server/ui.nix @@ -1,9 +1,10 @@ -{ stdenv -, yarn -, fixup-yarn-lock -, nodejs-slim -, fetchYarnDeps -, gotify-server +{ + stdenv, + yarn, + fixup-yarn-lock, + nodejs-slim, + fetchYarnDeps, + gotify-server, }: stdenv.mkDerivation rec { @@ -17,7 +18,11 @@ stdenv.mkDerivation rec { hash = "sha256-ejHzo6NHCMlNiYePWvfMY9Blb58pj3UQ5PFI0V84flI="; }; - nativeBuildInputs = [ yarn fixup-yarn-lock nodejs-slim ]; + nativeBuildInputs = [ + yarn + fixup-yarn-lock + nodejs-slim + ]; postPatch = '' export HOME=$NIX_BUILD_TOP/fake_home diff --git a/pkgs/by-name/go/gotraceui/package.nix b/pkgs/by-name/go/gotraceui/package.nix index 3f162f24628817..9730a2e6df911a 100644 --- a/pkgs/by-name/go/gotraceui/package.nix +++ b/pkgs/by-name/go/gotraceui/package.nix @@ -1,6 +1,15 @@ { - lib, fetchFromGitHub, pkg-config, buildGoModule, - libGL, libX11, libXcursor, libXfixes, libxkbcommon, vulkan-headers, wayland, + lib, + fetchFromGitHub, + pkg-config, + buildGoModule, + libGL, + libX11, + libXcursor, + libXfixes, + libxkbcommon, + vulkan-headers, + wayland, }: buildGoModule rec { @@ -15,7 +24,7 @@ buildGoModule rec { }; vendorHash = "sha256-dNV5u6BG+2Nzci6dX/4/4WAeM/zXE5+Ix0HqIsNnm0E="; - subPackages = ["cmd/gotraceui"]; + subPackages = [ "cmd/gotraceui" ]; nativeBuildInputs = [ pkg-config ]; @@ -29,7 +38,7 @@ buildGoModule rec { libGL ]; - ldflags = ["-X gioui.org/app.ID=co.honnef.Gotraceui"]; + ldflags = [ "-X gioui.org/app.ID=co.honnef.Gotraceui" ]; postInstall = '' cp -r share $out/ diff --git a/pkgs/by-name/go/gotty/package.nix b/pkgs/by-name/go/gotty/package.nix index 9e5e95315f621c..38f040f0bb5244 100644 --- a/pkgs/by-name/go/gotty/package.nix +++ b/pkgs/by-name/go/gotty/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/go/gotypist/package.nix b/pkgs/by-name/go/gotypist/package.nix index b60fe896392d04..5806a6cded23d3 100644 --- a/pkgs/by-name/go/gotypist/package.nix +++ b/pkgs/by-name/go/gotypist/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gotypist"; diff --git a/pkgs/by-name/go/goudy-bookletter-1911/package.nix b/pkgs/by-name/go/goudy-bookletter-1911/package.nix index 8e5d9c95e1dce4..34428e7e360e1c 100644 --- a/pkgs/by-name/go/goudy-bookletter-1911/package.nix +++ b/pkgs/by-name/go/goudy-bookletter-1911/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, +}: stdenvNoCC.mkDerivation { pname = "goudy-bookletter-1911"; diff --git a/pkgs/by-name/go/gource/package.nix b/pkgs/by-name/go/gource/package.nix index 60f11d5168b192..41ee7d59812fe1 100644 --- a/pkgs/by-name/go/gource/package.nix +++ b/pkgs/by-name/go/gource/package.nix @@ -1,5 +1,21 @@ -{ lib, stdenv, fetchurl, SDL2, ftgl, pkg-config, libpng, libjpeg, pcre2 -, SDL2_image, freetype, glew, libGLU, libGL, boost, glm, tinyxml +{ + lib, + stdenv, + fetchurl, + SDL2, + ftgl, + pkg-config, + libpng, + libjpeg, + pcre2, + SDL2_image, + freetype, + glew, + libGLU, + libGL, + boost, + glm, + tinyxml, }: stdenv.mkDerivation rec { @@ -18,8 +34,19 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - glew SDL2 ftgl libpng libjpeg pcre2 SDL2_image libGLU libGL - boost glm freetype tinyxml + glew + SDL2 + ftgl + libpng + libjpeg + pcre2 + SDL2_image + libGLU + libGL + boost + glm + freetype + tinyxml ]; configureFlags = [ diff --git a/pkgs/by-name/go/govc/package.nix b/pkgs/by-name/go/govc/package.nix index 41ca788a31c38e..acbebda2cb01e6 100644 --- a/pkgs/by-name/go/govc/package.nix +++ b/pkgs/by-name/go/govc/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "govc"; diff --git a/pkgs/by-name/go/govee2mqtt/package.nix b/pkgs/by-name/go/govee2mqtt/package.nix index 41392d0022c13f..1f4ef40510be13 100644 --- a/pkgs/by-name/go/govee2mqtt/package.nix +++ b/pkgs/by-name/go/govee2mqtt/package.nix @@ -1,9 +1,10 @@ -{ rustPlatform -, lib -, fetchFromGitHub -, fetchpatch -, openssl -, pkg-config +{ + rustPlatform, + lib, + fetchFromGitHub, + fetchpatch, + openssl, + pkg-config, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/go/goverview/package.nix b/pkgs/by-name/go/goverview/package.nix index 6c55f069d25892..a5093faa0f2a09 100644 --- a/pkgs/by-name/go/goverview/package.nix +++ b/pkgs/by-name/go/goverview/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/go/govulncheck/package.nix b/pkgs/by-name/go/govulncheck/package.nix index 71d03d916e53e6..a7d0b88eca40a6 100644 --- a/pkgs/by-name/go/govulncheck/package.nix +++ b/pkgs/by-name/go/govulncheck/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, substituteAll +{ + lib, + buildGoModule, + fetchFromGitHub, + substituteAll, }: buildGoModule rec { @@ -65,6 +66,9 @@ buildGoModule rec { reported for a Linux build. ''; license = with licenses; [ bsd3 ]; - maintainers = with maintainers; [ jk SuperSandro2000 ]; + maintainers = with maintainers; [ + jk + SuperSandro2000 + ]; }; } diff --git a/pkgs/by-name/go/gox/package.nix b/pkgs/by-name/go/gox/package.nix index e1ba5d9bb743f9..d78d74191fee50 100644 --- a/pkgs/by-name/go/gox/package.nix +++ b/pkgs/by-name/go/gox/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, go +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + go, }: buildGoModule rec { diff --git a/pkgs/by-name/go/goxel/package.nix b/pkgs/by-name/go/goxel/package.nix index 404a42959038f3..918a34a883c3a5 100644 --- a/pkgs/by-name/go/goxel/package.nix +++ b/pkgs/by-name/go/goxel/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, scons, pkg-config, wrapGAppsHook3 -, glfw3, gtk3, libpng }: +{ + lib, + stdenv, + fetchFromGitHub, + scons, + pkg-config, + wrapGAppsHook3, + glfw3, + gtk3, + libpng, +}: stdenv.mkDerivation (finalAttrs: { pname = "goxel"; @@ -12,8 +21,16 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-mNSkQisWL3wXb+IsClWFTMbpeiRC4xteePXNP+GkUnU="; }; - nativeBuildInputs = [ scons pkg-config wrapGAppsHook3 ]; - buildInputs = [ glfw3 gtk3 libpng ]; + nativeBuildInputs = [ + scons + pkg-config + wrapGAppsHook3 + ]; + buildInputs = [ + glfw3 + gtk3 + libpng + ]; dontUseSconsBuild = true; dontUseSconsInstall = true; @@ -28,6 +45,9 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://guillaumechereau.github.io/goxel/"; license = licenses.gpl3; platforms = platforms.linux; - maintainers = with maintainers; [ tilpner fgaz ]; + maintainers = with maintainers; [ + tilpner + fgaz + ]; }; }) diff --git a/pkgs/by-name/gp/gpa/package.nix b/pkgs/by-name/gp/gpa/package.nix index cf6a915e29c187..79b92688428836 100644 --- a/pkgs/by-name/gp/gpa/package.nix +++ b/pkgs/by-name/gp/gpa/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, intltool, pkg-config, gtk2, gpgme, libgpg-error, libassuan }: +{ + lib, + stdenv, + fetchurl, + intltool, + pkg-config, + gtk2, + gpgme, + libgpg-error, + libassuan, +}: stdenv.mkDerivation rec { pname = "gpa"; @@ -9,8 +19,16 @@ stdenv.mkDerivation rec { sha256 = "1cbpc45f8qbdkd62p12s3q2rdq6fa5xdzwmcwd3xrj55bzkspnwm"; }; - nativeBuildInputs = [ intltool pkg-config ]; - buildInputs = [ gtk2 gpgme libgpg-error libassuan ]; + nativeBuildInputs = [ + intltool + pkg-config + ]; + buildInputs = [ + gtk2 + gpgme + libgpg-error + libassuan + ]; meta = with lib; { description = "Graphical user interface for the GnuPG"; diff --git a/pkgs/by-name/gp/gpart/package.nix b/pkgs/by-name/gp/gpart/package.nix index a8466d3462e8f8..7fa84d64e956f7 100644 --- a/pkgs/by-name/gp/gpart/package.nix +++ b/pkgs/by-name/gp/gpart/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "gpart"; diff --git a/pkgs/by-name/gp/gparted/package.nix b/pkgs/by-name/gp/gparted/package.nix index c91ed7a5a30666..d5e5ffcc0ed7c2 100644 --- a/pkgs/by-name/gp/gparted/package.nix +++ b/pkgs/by-name/gp/gparted/package.nix @@ -1,8 +1,29 @@ -{ lib, stdenv, fetchurl, gettext, coreutils, gnused, gnome -, adwaita-icon-theme -, gnugrep, parted, glib, libuuid, pkg-config, gtkmm3, libxml2 -, gpart, hdparm, procps, util-linux, polkit, wrapGAppsHook3, substituteAll -, mtools, dosfstools, xhost +{ + lib, + stdenv, + fetchurl, + gettext, + coreutils, + gnused, + gnome, + adwaita-icon-theme, + gnugrep, + parted, + glib, + libuuid, + pkg-config, + gtkmm3, + libxml2, + gpart, + hdparm, + procps, + util-linux, + polkit, + wrapGAppsHook3, + substituteAll, + mtools, + dosfstools, + xhost, }: stdenv.mkDerivation rec { @@ -26,10 +47,25 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - configureFlags = [ "--disable-doc" "--enable-xhost-root" ]; + configureFlags = [ + "--disable-doc" + "--enable-xhost-root" + ]; - buildInputs = [ parted glib libuuid gtkmm3 libxml2 polkit.bin adwaita-icon-theme ]; - nativeBuildInputs = [ gettext pkg-config wrapGAppsHook3 ]; + buildInputs = [ + parted + glib + libuuid + gtkmm3 + libxml2 + polkit.bin + adwaita-icon-theme + ]; + nativeBuildInputs = [ + gettext + pkg-config + wrapGAppsHook3 + ]; preConfigure = '' # For ITS rules @@ -38,7 +74,20 @@ stdenv.mkDerivation rec { preFixup = '' gappsWrapperArgs+=( - --prefix PATH : "${lib.makeBinPath [ gpart hdparm util-linux procps coreutils gnused gnugrep mtools dosfstools xhost ]}" + --prefix PATH : "${ + lib.makeBinPath [ + gpart + hdparm + util-linux + procps + coreutils + gnused + gnugrep + mtools + dosfstools + xhost + ] + }" ) ''; diff --git a/pkgs/by-name/gp/gpaste/package.nix b/pkgs/by-name/gp/gpaste/package.nix index 7911b5ffc6c0ee..1322bae6269b39 100644 --- a/pkgs/by-name/gp/gpaste/package.nix +++ b/pkgs/by-name/gp/gpaste/package.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, fetchurl -, gjs -, glib -, gobject-introspection -, gtk3 -, gtk4 -, gcr_4 -, libadwaita -, meson -, ninja -, pango -, pkg-config -, vala -, desktop-file-utils -, wrapGAppsHook3 +{ + stdenv, + lib, + fetchurl, + gjs, + glib, + gobject-introspection, + gtk3, + gtk4, + gcr_4, + libadwaita, + meson, + ninja, + pango, + pkg-config, + vala, + desktop-file-utils, + wrapGAppsHook3, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gp/gperftools/package.nix b/pkgs/by-name/gp/gperftools/package.nix index 62e7ecbb0e9554..7936b80808e5cd 100644 --- a/pkgs/by-name/gp/gperftools/package.nix +++ b/pkgs/by-name/gp/gperftools/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, libunwind -, perl +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + libunwind, + perl, }: stdenv.mkDerivation rec { @@ -30,20 +31,21 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; # tcmalloc uses libunwind in a way that works correctly only on non-ARM dynamically linked linux - buildInputs = [ perl ] - ++ lib.optional (stdenv.hostPlatform.isLinux && !(stdenv.hostPlatform.isAarch || stdenv.hostPlatform.isStatic )) libunwind; + buildInputs = + [ perl ] + ++ lib.optional ( + stdenv.hostPlatform.isLinux && !(stdenv.hostPlatform.isAarch || stdenv.hostPlatform.isStatic) + ) libunwind; # Disable general dynamic TLS on AArch to support dlopen()'ing the library: # https://bugzilla.redhat.com/show_bug.cgi?id=1483558 - configureFlags = lib.optional stdenv.hostPlatform.isAarch - "--disable-general-dynamic-tls"; + configureFlags = lib.optional stdenv.hostPlatform.isAarch "--disable-general-dynamic-tls"; prePatch = lib.optionalString stdenv.hostPlatform.isDarwin '' substituteInPlace Makefile.am --replace stdc++ c++ ''; - env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin - "-D_XOPEN_SOURCE"; + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-D_XOPEN_SOURCE"; # some packages want to link to the static tcmalloc_minimal # to drop the runtime dependency on gperftools diff --git a/pkgs/by-name/gp/gpg-mdp/package.nix b/pkgs/by-name/gp/gpg-mdp/package.nix index 08ab2a5b7d9f60..9e145a5fe2b13b 100644 --- a/pkgs/by-name/gp/gpg-mdp/package.nix +++ b/pkgs/by-name/gp/gpg-mdp/package.nix @@ -1,13 +1,22 @@ -{ fetchurl, fetchpatch, lib, stdenv, ncurses, gnupg }: +{ + fetchurl, + fetchpatch, + lib, + stdenv, + ncurses, + gnupg, +}: -let version = "0.7.4"; -in stdenv.mkDerivation { +let + version = "0.7.4"; +in +stdenv.mkDerivation { # mdp renamed to gpg-mdp because there is a mdp package already. pname = "gpg-mdp"; inherit version; meta = { homepage = "https://tamentis.com/projects/mdp/"; - license = [lib.licenses.isc]; + license = [ lib.licenses.isc ]; description = "Manage your passwords with GnuPG and a text editor"; }; src = fetchurl { diff --git a/pkgs/by-name/gp/gphotos-sync/package.nix b/pkgs/by-name/gp/gphotos-sync/package.nix index 461931b1b991f1..9b89e9c53b5ead 100644 --- a/pkgs/by-name/gp/gphotos-sync/package.nix +++ b/pkgs/by-name/gp/gphotos-sync/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3 -, ffmpeg +{ + lib, + fetchFromGitHub, + python3, + ffmpeg, }: python3.pkgs.buildPythonApplication rec { pname = "gphotos-sync"; diff --git a/pkgs/by-name/gp/gpick/package.nix b/pkgs/by-name/gp/gpick/package.nix index c21759b00fea26..7c0502ea32321a 100644 --- a/pkgs/by-name/gp/gpick/package.nix +++ b/pkgs/by-name/gp/gpick/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, fetchFromGitHub -, cmake -, wrapGAppsHook3 -, boost -, pkg-config -, gtk3 -, ragel -, lua -, fetchpatch -, lib +{ + stdenv, + fetchFromGitHub, + cmake, + wrapGAppsHook3, + boost, + pkg-config, + gtk3, + ragel, + lua, + fetchpatch, + lib, }: stdenv.mkDerivation rec { @@ -32,8 +33,17 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config wrapGAppsHook3 ]; - buildInputs = [ boost gtk3 ragel lua ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapGAppsHook3 + ]; + buildInputs = [ + boost + gtk3 + ragel + lua + ]; meta = with lib; { description = "Advanced color picker written in C++ using GTK+ toolkit"; diff --git a/pkgs/by-name/gp/gpodder/package.nix b/pkgs/by-name/gp/gpodder/package.nix index 9a62fab2850c90..678e119a8bb2bd 100644 --- a/pkgs/by-name/gp/gpodder/package.nix +++ b/pkgs/by-name/gp/gpodder/package.nix @@ -1,14 +1,15 @@ -{ lib -, fetchFromGitHub -, gitUpdater -, glibcLocales -, adwaita-icon-theme -, gobject-introspection -, gtk3 -, intltool -, python311Packages -, wrapGAppsHook3 -, xdg-utils +{ + lib, + fetchFromGitHub, + gitUpdater, + glibcLocales, + adwaita-icon-theme, + gobject-introspection, + gtk3, + intltool, + python311Packages, + wrapGAppsHook3, + xdg-utils, }: python311Packages.buildPythonApplication rec { @@ -82,7 +83,7 @@ python311Packages.buildPythonApplication rec { makeWrapperArgs = [ "--suffix PATH : ${lib.makeBinPath [ xdg-utils ]}" ]; - passthru.updateScript = gitUpdater {}; + passthru.updateScript = gitUpdater { }; meta = with lib; { description = "Podcatcher written in python"; diff --git a/pkgs/by-name/gp/gpp/package.nix b/pkgs/by-name/gp/gpp/package.nix index 902c0bbf02b539..dea4eecdc444cb 100644 --- a/pkgs/by-name/gp/gpp/package.nix +++ b/pkgs/by-name/gp/gpp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation { pname = "gpp"; diff --git a/pkgs/by-name/gp/gprename/package.nix b/pkgs/by-name/gp/gprename/package.nix index 6ae3b792ccfde6..a821e772e9df81 100644 --- a/pkgs/by-name/gp/gprename/package.nix +++ b/pkgs/by-name/gp/gprename/package.nix @@ -45,7 +45,8 @@ stdenv.mkDerivation (finalAttrs: { wrapProgram $out/bin/gprename \ --set PERL5LIB ${ perlPackages.makeFullPerlPath ( - with perlPackages; [ + with perlPackages; + [ Pango Glib Gtk3 diff --git a/pkgs/by-name/gp/gprojector/package.nix b/pkgs/by-name/gp/gprojector/package.nix index ec05733374e0a2..6d51e5b7a77098 100644 --- a/pkgs/by-name/gp/gprojector/package.nix +++ b/pkgs/by-name/gp/gprojector/package.nix @@ -1,11 +1,12 @@ -{ stdenvNoCC -, lib -, fetchzip -, jre -, makeDesktopItem -, copyDesktopItems -, makeWrapper -, extraJavaArgs ? "-Xms512M -Xmx2000M" +{ + stdenvNoCC, + lib, + fetchzip, + jre, + makeDesktopItem, + copyDesktopItems, + makeWrapper, + extraJavaArgs ? "-Xms512M -Xmx2000M", }: stdenvNoCC.mkDerivation rec { @@ -17,17 +18,22 @@ stdenvNoCC.mkDerivation rec { sha256 = "sha256-cMmjyitetXxQzfSBh5ry5tIsLWOnBaaYOD1eQg1IX+w="; }; - desktopItems = [ (makeDesktopItem { - name = "gprojector"; - exec = "gprojector"; - desktopName = "G.Projector"; - comment = meta.description; - categories = [ "Science" ]; - startupWMClass = "gov-nasa-giss-projector-GProjector"; - }) ]; + desktopItems = [ + (makeDesktopItem { + name = "gprojector"; + exec = "gprojector"; + desktopName = "G.Projector"; + comment = meta.description; + categories = [ "Science" ]; + startupWMClass = "gov-nasa-giss-projector-GProjector"; + }) + ]; buildInputs = [ jre ]; - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; dontConfigure = true; dontBuild = true; diff --git a/pkgs/by-name/gp/gprolog/package.nix b/pkgs/by-name/gp/gprolog/package.nix index 3cd5c1bcfa4cbc..f1bd79a2d17fda 100644 --- a/pkgs/by-name/gp/gprolog/package.nix +++ b/pkgs/by-name/gp/gprolog/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "gprolog"; diff --git a/pkgs/by-name/gp/gpscorrelate/package.nix b/pkgs/by-name/gp/gpscorrelate/package.nix index d9801f5d704cc7..c03d9204a76541 100644 --- a/pkgs/by-name/gp/gpscorrelate/package.nix +++ b/pkgs/by-name/gp/gpscorrelate/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, exiv2 -, libxml2 -, gtk3 -, libxslt -, docbook_xsl -, docbook_xml_dtd_42 -, desktop-file-utils -, wrapGAppsHook3 -, desktopToDarwinBundle +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + exiv2, + libxml2, + gtk3, + libxslt, + docbook_xsl, + docbook_xml_dtd_42, + desktop-file-utils, + wrapGAppsHook3, + desktopToDarwinBundle, }: stdenv.mkDerivation rec { @@ -48,7 +49,11 @@ stdenv.mkDerivation rec { doCheck = true; - installTargets = [ "install" "install-po" "install-desktop-file" ]; + installTargets = [ + "install" + "install-po" + "install-desktop-file" + ]; meta = with lib; { description = "GPS photo correlation tool, to add EXIF geotags"; diff --git a/pkgs/by-name/gp/gpsd/package.nix b/pkgs/by-name/gp/gpsd/package.nix index 4b9269ab669278..182fba46f2f55e 100644 --- a/pkgs/by-name/gp/gpsd/package.nix +++ b/pkgs/by-name/gp/gpsd/package.nix @@ -1,34 +1,37 @@ -{ stdenv -, lib -, fetchurl -, fetchpatch - -# nativeBuildInputs -, scons -, pkg-config - -# buildInputs -, dbus -, libusb1 -, ncurses -, kppsSupport ? stdenv.hostPlatform.isLinux, pps-tools -, python3Packages - -# optional deps for GUI packages -, guiSupport ? true -, dbus-glib -, libX11 -, libXt -, libXpm -, libXaw -, libXext -, gobject-introspection -, pango -, gdk-pixbuf -, atk -, wrapGAppsHook3 - -, gpsdUser ? "gpsd", gpsdGroup ? "dialout" +{ + stdenv, + lib, + fetchurl, + fetchpatch, + + # nativeBuildInputs + scons, + pkg-config, + + # buildInputs + dbus, + libusb1, + ncurses, + kppsSupport ? stdenv.hostPlatform.isLinux, + pps-tools, + python3Packages, + + # optional deps for GUI packages + guiSupport ? true, + dbus-glib, + libX11, + libXt, + libXpm, + libXaw, + libXext, + gobject-introspection, + pango, + gdk-pixbuf, + atk, + wrapGAppsHook3, + + gpsdUser ? "gpsd", + gpsdGroup ? "dialout", }: stdenv.mkDerivation rec { @@ -41,33 +44,38 @@ stdenv.mkDerivation rec { }; # TODO: render & install HTML documentation using asciidoctor - nativeBuildInputs = [ - pkg-config - python3Packages.wrapPython - scons - ] ++ lib.optionals guiSupport [ - gobject-introspection - wrapGAppsHook3 - ]; - - buildInputs = [ - dbus - libusb1 - ncurses - python3Packages.python - ] ++ lib.optionals kppsSupport [ - pps-tools - ] ++ lib.optionals guiSupport [ - atk - dbus-glib - gdk-pixbuf - libX11 - libXaw - libXext - libXpm - libXt - pango - ]; + nativeBuildInputs = + [ + pkg-config + python3Packages.wrapPython + scons + ] + ++ lib.optionals guiSupport [ + gobject-introspection + wrapGAppsHook3 + ]; + + buildInputs = + [ + dbus + libusb1 + ncurses + python3Packages.python + ] + ++ lib.optionals kppsSupport [ + pps-tools + ] + ++ lib.optionals guiSupport [ + atk + dbus-glib + gdk-pixbuf + libX11 + libXaw + libXext + libXpm + libXt + pango + ]; pythonPath = lib.optionals guiSupport [ python3Packages.pygobject3 @@ -113,7 +121,10 @@ stdenv.mkDerivation rec { mkdir -p "$out/lib/udev/rules.d" ''; - installTargets = [ "install" "udev-install" ]; + installTargets = [ + "install" + "udev-install" + ]; # remove binaries for x-less install because xgps sconsflag is partially broken postFixup = '' @@ -144,6 +155,9 @@ stdenv.mkDerivation rec { changelog = "https://gitlab.com/gpsd/gpsd/-/blob/release-${version}/NEWS"; license = licenses.bsd2; platforms = platforms.unix; - maintainers = with maintainers; [ bjornfor rasendubi ]; + maintainers = with maintainers; [ + bjornfor + rasendubi + ]; }; } diff --git a/pkgs/by-name/gp/gpsprune/package.nix b/pkgs/by-name/gp/gpsprune/package.nix index e33f340a1bd587..333092fdba0e7b 100644 --- a/pkgs/by-name/gp/gpsprune/package.nix +++ b/pkgs/by-name/gp/gpsprune/package.nix @@ -1,4 +1,13 @@ -{ fetchurl, lib, stdenv, makeDesktopItem, makeWrapper, unzip, jre, copyDesktopItems }: +{ + fetchurl, + lib, + stdenv, + makeDesktopItem, + makeWrapper, + unzip, + jre, + copyDesktopItems, +}: stdenv.mkDerivation rec { pname = "gpsprune"; @@ -11,7 +20,10 @@ stdenv.mkDerivation rec { dontUnpack = true; - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; buildInputs = [ jre ]; desktopItems = [ @@ -22,7 +34,10 @@ stdenv.mkDerivation rec { desktopName = "GpsPrune"; genericName = "GPS Data Editor"; comment = meta.description; - categories = [ "Education" "Geoscience" ]; + categories = [ + "Education" + "Geoscience" + ]; mimeTypes = [ "application/gpx+xml" "application/vnd.google-earth.kml+xml" diff --git a/pkgs/by-name/gp/gpt4all/package.nix b/pkgs/by-name/gp/gpt4all/package.nix index 125a3f4d46b726..118df97d6797b4 100644 --- a/pkgs/by-name/gp/gpt4all/package.nix +++ b/pkgs/by-name/gp/gpt4all/package.nix @@ -1,18 +1,19 @@ -{ lib -, config -, stdenv -, fetchFromGitHub -, fetchurl -, fetchpatch -, cmake -, qt6 -, fmt -, shaderc -, vulkan-headers -, wayland -, cudaSupport ? config.cudaSupport -, cudaPackages ? { } -, autoAddDriverRunpath +{ + lib, + config, + stdenv, + fetchFromGitHub, + fetchurl, + fetchpatch, + cmake, + qt6, + fmt, + shaderc, + vulkan-headers, + wayland, + cudaSupport ? config.cudaSupport, + cudaPackages ? { }, + autoAddDriverRunpath, }: stdenv.mkDerivation (finalAttrs: { @@ -44,44 +45,50 @@ stdenv.mkDerivation (finalAttrs: { sourceRoot = "${finalAttrs.src.name}/gpt4all-chat"; - nativeBuildInputs = [ - cmake - qt6.wrapQtAppsHook - ] ++ lib.optionals cudaSupport [ - cudaPackages.cuda_nvcc - autoAddDriverRunpath - ]; + nativeBuildInputs = + [ + cmake + qt6.wrapQtAppsHook + ] + ++ lib.optionals cudaSupport [ + cudaPackages.cuda_nvcc + autoAddDriverRunpath + ]; - buildInputs = [ - fmt - qt6.qtwayland - qt6.qtquicktimeline - qt6.qtsvg - qt6.qthttpserver - qt6.qtwebengine - qt6.qt5compat - qt6.qttools - shaderc - vulkan-headers - wayland - ] ++ lib.optionals cudaSupport ( - with cudaPackages; + buildInputs = [ - cuda_cccl - cuda_cudart - libcublas + fmt + qt6.qtwayland + qt6.qtquicktimeline + qt6.qtsvg + qt6.qthttpserver + qt6.qtwebengine + qt6.qt5compat + qt6.qttools + shaderc + vulkan-headers + wayland ] - ); + ++ lib.optionals cudaSupport ( + with cudaPackages; + [ + cuda_cccl + cuda_cudart + libcublas + ] + ); - cmakeFlags = [ - "-DKOMPUTE_OPT_USE_BUILT_IN_VULKAN_HEADER=OFF" - "-DKOMPUTE_OPT_DISABLE_VULKAN_VERSION_CHECK=ON" - "-DKOMPUTE_OPT_USE_BUILT_IN_FMT=OFF" - "-DGGML_VULKAN=ON" - "-DGGML_KOMPUTE=ON" - ] ++ lib.optionals (!cudaSupport) [ - "-DLLMODEL_CUDA=OFF" - ]; + cmakeFlags = + [ + "-DKOMPUTE_OPT_USE_BUILT_IN_VULKAN_HEADER=OFF" + "-DKOMPUTE_OPT_DISABLE_VULKAN_VERSION_CHECK=ON" + "-DKOMPUTE_OPT_USE_BUILT_IN_FMT=OFF" + "-DGGML_VULKAN=ON" + "-DGGML_KOMPUTE=ON" + ] + ++ lib.optionals (!cudaSupport) [ + "-DLLMODEL_CUDA=OFF" + ]; postInstall = '' rm -rf $out/include @@ -100,6 +107,9 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/nomic-ai/gpt4all"; license = lib.licenses.mit; mainProgram = "gpt4all"; - maintainers = with lib.maintainers; [ polygon titaniumtown ]; + maintainers = with lib.maintainers; [ + polygon + titaniumtown + ]; }; }) diff --git a/pkgs/by-name/gp/gptfdisk/package.nix b/pkgs/by-name/gp/gptfdisk/package.nix index 798d1b223e5c35..4965084857a6a1 100644 --- a/pkgs/by-name/gp/gptfdisk/package.nix +++ b/pkgs/by-name/gp/gptfdisk/package.nix @@ -1,4 +1,13 @@ -{ fetchurl, lib, stdenv, libuuid, popt, icu, ncurses, nixosTests }: +{ + fetchurl, + lib, + stdenv, + libuuid, + popt, + icu, + ncurses, + nixosTests, +}: stdenv.mkDerivation rec { pname = "gptfdisk"; @@ -11,25 +20,32 @@ stdenv.mkDerivation rec { sha256 = "sha256-Kr7WG8bSuexJiXPARAuLgEt6ctcUQGm1qSCbKtaTooI="; }; - postPatch = '' - patchShebangs gdisk_test.sh - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace Makefile.mac --replace \ - "-mmacosx-version-min=10.4" "-mmacosx-version-min=10.6" - substituteInPlace Makefile.mac --replace \ - " -arch i386" "" - substituteInPlace Makefile.mac --replace \ - "-arch x86_64" "" - substituteInPlace Makefile.mac --replace \ - "-arch arm64" "" - substituteInPlace Makefile.mac --replace \ - " -I/opt/local/include -I /usr/local/include -I/opt/local/include" "" - substituteInPlace Makefile.mac --replace \ - "/usr/local/Cellar/ncurses/6.2/lib/libncurses.dylib" "${ncurses.out}/lib/libncurses.dylib" - ''; + postPatch = + '' + patchShebangs gdisk_test.sh + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace Makefile.mac --replace \ + "-mmacosx-version-min=10.4" "-mmacosx-version-min=10.6" + substituteInPlace Makefile.mac --replace \ + " -arch i386" "" + substituteInPlace Makefile.mac --replace \ + "-arch x86_64" "" + substituteInPlace Makefile.mac --replace \ + "-arch arm64" "" + substituteInPlace Makefile.mac --replace \ + " -I/opt/local/include -I /usr/local/include -I/opt/local/include" "" + substituteInPlace Makefile.mac --replace \ + "/usr/local/Cellar/ncurses/6.2/lib/libncurses.dylib" "${ncurses.out}/lib/libncurses.dylib" + ''; buildPhase = lib.optionalString stdenv.hostPlatform.isDarwin "make -f Makefile.mac"; - buildInputs = [ libuuid popt icu ncurses ]; + buildInputs = [ + libuuid + popt + icu + ncurses + ]; installPhase = '' mkdir -p $out/sbin diff --git a/pkgs/by-name/gp/gptman/package.nix b/pkgs/by-name/gp/gptman/package.nix index 484ab05a85f2f4..5e227166226ec8 100644 --- a/pkgs/by-name/gp/gptman/package.nix +++ b/pkgs/by-name/gp/gptman/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, libiconv, testers, gptman }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + libiconv, + testers, + gptman, +}: rustPlatform.buildRustPackage rec { pname = "gptman"; @@ -24,7 +32,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "GPT manager that allows you to copy partitions from one disk to another and more"; homepage = "https://github.com/rust-disk-partition-management/gptman"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ akshgpt7 ]; mainProgram = "gptman"; }; diff --git a/pkgs/by-name/gp/gptscript/package.nix b/pkgs/by-name/gp/gptscript/package.nix index 81fc45b2bf90ae..4394e97bec6160 100644 --- a/pkgs/by-name/gp/gptscript/package.nix +++ b/pkgs/by-name/gp/gptscript/package.nix @@ -18,8 +18,7 @@ buildGoModule rec { vendorHash = "sha256-ajglXWGJhSJtcrbSBmxmriXFTT+Vb4xYq0Ec9SYRlQk="; - propagatedBuildInputs = with darwin; - lib.optionals stdenv.hostPlatform.isDarwin [Security]; + propagatedBuildInputs = with darwin; lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; ldflags = [ "-s" diff --git a/pkgs/by-name/gp/gpu-switch/package.nix b/pkgs/by-name/gp/gpu-switch/package.nix index d6f749aa8f1e3d..fc2b8b0eb322b5 100644 --- a/pkgs/by-name/gp/gpu-switch/package.nix +++ b/pkgs/by-name/gp/gpu-switch/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "gpu-switch-unstable"; diff --git a/pkgs/by-name/gp/gpustat/package.nix b/pkgs/by-name/gp/gpustat/package.nix index 38e513bd806737..8942b854d26dff 100644 --- a/pkgs/by-name/gp/gpustat/package.nix +++ b/pkgs/by-name/gp/gpustat/package.nix @@ -1,17 +1,18 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, fontconfig -, libGL -, libX11 -, libXcursor -, libXi -, libXrandr -, cmake -, libxkbcommon -, wayland -, makeWrapper +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + fontconfig, + libGL, + libX11, + libXcursor, + libXi, + libXrandr, + cmake, + libxkbcommon, + wayland, + makeWrapper, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/gp/gputils/package.nix b/pkgs/by-name/gp/gputils/package.nix index 8050368e0a95ac..1fad477342018e 100644 --- a/pkgs/by-name/gp/gputils/package.nix +++ b/pkgs/by-name/gp/gputils/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "gputils"; diff --git a/pkgs/by-name/gp/gpuvis/package.nix b/pkgs/by-name/gp/gpuvis/package.nix index ad2d36e2502149..d6d27ba8944f8d 100644 --- a/pkgs/by-name/gp/gpuvis/package.nix +++ b/pkgs/by-name/gp/gpuvis/package.nix @@ -1,13 +1,14 @@ -{ fetchFromGitHub -, freetype -, gtk3 -, lib -, meson -, ninja -, pkg-config -, SDL2 -, stdenv -, wrapGAppsHook3 +{ + fetchFromGitHub, + freetype, + gtk3, + lib, + meson, + ninja, + pkg-config, + SDL2, + stdenv, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -27,9 +28,18 @@ stdenv.mkDerivation rec { --replace "libgtk-3.so" "${lib.getLib gtk3}/lib/libgtk-3.so" ''; - nativeBuildInputs = [ pkg-config meson ninja wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + wrapGAppsHook3 + ]; - buildInputs = [ SDL2 gtk3 freetype ]; + buildInputs = [ + SDL2 + gtk3 + freetype + ]; CXXFLAGS = [ # GCC 13: error: 'uint32_t' has not been declared diff --git a/pkgs/by-name/gp/gpx-viewer/package.nix b/pkgs/by-name/gp/gpx-viewer/package.nix index a04cf4ec7c7730..12a2d49c10ba7a 100644 --- a/pkgs/by-name/gp/gpx-viewer/package.nix +++ b/pkgs/by-name/gp/gpx-viewer/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, libxml2 -, meson -, ninja -, vala -, pkg-config -, adwaita-icon-theme -, libchamplain -, gdl -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + libxml2, + meson, + ninja, + vala, + pkg-config, + adwaita-icon-theme, + libchamplain, + gdl, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gp/gpx/package.nix b/pkgs/by-name/gp/gpx/package.nix index 04ebd491c28d9a..bc1113b99b20d9 100644 --- a/pkgs/by-name/gp/gpx/package.nix +++ b/pkgs/by-name/gp/gpx/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "gpx"; diff --git a/pkgs/by-name/gp/gpython/package.nix b/pkgs/by-name/gp/gpython/package.nix index 731c40a32d17e3..2891dd308d863c 100644 --- a/pkgs/by-name/gp/gpython/package.nix +++ b/pkgs/by-name/gp/gpython/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, gpython +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + gpython, }: buildGoModule rec { diff --git a/pkgs/by-name/gq/gql/package.nix b/pkgs/by-name/gq/gql/package.nix index 903d53dcee8fdb..12d24d88ca725c 100644 --- a/pkgs/by-name/gq/gql/package.nix +++ b/pkgs/by-name/gq/gql/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libgit2 -, zlib -, cmake +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libgit2, + zlib, + cmake, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/gq/gqlgenc/package.nix b/pkgs/by-name/gq/gqlgenc/package.nix index 334eb2a178e317..e64a4d70ba8eef 100644 --- a/pkgs/by-name/gq/gqlgenc/package.nix +++ b/pkgs/by-name/gq/gqlgenc/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "gqlgenc"; diff --git a/pkgs/by-name/gq/gqlint/package.nix b/pkgs/by-name/gq/gqlint/package.nix index 18fc0cc624b76f..c0d955d7d07240 100644 --- a/pkgs/by-name/gq/gqlint/package.nix +++ b/pkgs/by-name/gq/gqlint/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/gr/grabserial/package.nix b/pkgs/by-name/gr/grabserial/package.nix index e26dcf63f77b78..72ccf1499dbbd1 100644 --- a/pkgs/by-name/gr/grabserial/package.nix +++ b/pkgs/by-name/gr/grabserial/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "grabserial"; diff --git a/pkgs/by-name/gr/gradescope-submit/package.nix b/pkgs/by-name/gr/gradescope-submit/package.nix index 54ae4b45838221..8cd424e93907b2 100644 --- a/pkgs/by-name/gr/gradescope-submit/package.nix +++ b/pkgs/by-name/gr/gradescope-submit/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, ocamlPackages +{ + lib, + fetchFromGitHub, + ocamlPackages, }: ocamlPackages.buildDunePackage rec { diff --git a/pkgs/by-name/gr/gradience/package.nix b/pkgs/by-name/gr/gradience/package.nix index d4b4965aea87b1..ebde30fff678e1 100644 --- a/pkgs/by-name/gr/gradience/package.nix +++ b/pkgs/by-name/gr/gradience/package.nix @@ -1,23 +1,24 @@ -{ lib -, fetchFromGitHub -, wrapGAppsHook4 -, meson -, ninja -, pkg-config -, glib -, glib-networking -, desktop-file-utils -, gettext -, librsvg -, blueprint-compiler -, python3Packages -, sassc -, appstream-glib -, libadwaita -, libportal -, libportal-gtk4 -, libsoup_3 -, gobject-introspection +{ + lib, + fetchFromGitHub, + wrapGAppsHook4, + meson, + ninja, + pkg-config, + glib, + glib-networking, + desktop-file-utils, + gettext, + librsvg, + blueprint-compiler, + python3Packages, + sassc, + appstream-glib, + libadwaita, + libportal, + libportal-gtk4, + libsoup_3, + gobject-introspection, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/gr/gradm/package.nix b/pkgs/by-name/gr/gradm/package.nix index cd99dfa5db8dc0..0197e3ded81c6e 100644 --- a/pkgs/by-name/gr/gradm/package.nix +++ b/pkgs/by-name/gr/gradm/package.nix @@ -1,18 +1,25 @@ -{ lib, stdenv, fetchurl -, bison, flex -, pam +{ + lib, + stdenv, + fetchurl, + bison, + flex, + pam, }: stdenv.mkDerivation rec { pname = "gradm"; version = "3.1-202102241600"; - src = fetchurl { - url = "https://grsecurity.net/stable/${pname}-${version}.tar.gz"; + src = fetchurl { + url = "https://grsecurity.net/stable/${pname}-${version}.tar.gz"; sha256 = "02ni34hpggv00140p9gvh0lqi173zdddd2qhfi96hyr1axd5pl50"; }; - nativeBuildInputs = [ bison flex ]; + nativeBuildInputs = [ + bison + flex + ]; buildInputs = [ pam ]; enableParallelBuilding = true; @@ -43,9 +50,12 @@ stdenv.mkDerivation rec { meta = with lib; { description = "grsecurity RBAC administration and policy analysis utility"; - homepage = "https://grsecurity.net"; - license = licenses.gpl2Only; - platforms = platforms.linux; - maintainers = with maintainers; [ thoughtpolice joachifm ]; + homepage = "https://grsecurity.net"; + license = licenses.gpl2Only; + platforms = platforms.linux; + maintainers = with maintainers; [ + thoughtpolice + joachifm + ]; }; } diff --git a/pkgs/by-name/gr/grafana-alloy/package.nix b/pkgs/by-name/gr/grafana-alloy/package.nix index 81c59954c8de9d..16a21ba11e058a 100644 --- a/pkgs/by-name/gr/grafana-alloy/package.nix +++ b/pkgs/by-name/gr/grafana-alloy/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, buildGoModule -, systemd -, yarn -, fixup-yarn-lock -, nodejs -, grafana-alloy -, nixosTests -, nix-update-script -, installShellFiles -, testers +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + buildGoModule, + systemd, + yarn, + fixup-yarn-lock, + nodejs, + grafana-alloy, + nixosTests, + nix-update-script, + installShellFiles, + testers, }: buildGoModule rec { @@ -28,7 +29,12 @@ buildGoModule rec { proxyVendor = true; vendorHash = "sha256-mh51vVHWq14UgfB45/HTE8Z/9t41atgoSJRPUb4jZd4="; - nativeBuildInputs = [ fixup-yarn-lock yarn nodejs installShellFiles ]; + nativeBuildInputs = [ + fixup-yarn-lock + yarn + nodejs + installShellFiles + ]; ldflags = let @@ -56,9 +62,11 @@ buildGoModule rec { ]; # Skip building the frontend in the goModules FOD - overrideModAttrs = (_: { - preBuild = null; - }); + overrideModAttrs = ( + _: { + preBuild = null; + } + ); yarnOfflineCache = fetchYarnDeps { yarnLock = "${src}/internal/web/ui/yarn.lock"; @@ -84,7 +92,9 @@ buildGoModule rec { # uses go-systemd, which uses libsystemd headers # https://github.com/coreos/go-systemd/issues/351 - NIX_CFLAGS_COMPILE = lib.optionals stdenv.hostPlatform.isLinux [ "-I${lib.getDev systemd}/include" ]; + NIX_CFLAGS_COMPILE = lib.optionals stdenv.hostPlatform.isLinux [ + "-I${lib.getDev systemd}/include" + ]; checkFlags = [ "-tags nonetwork" # disable network tests @@ -96,7 +106,9 @@ buildGoModule rec { # Add to RUNPATH so it can be found. postFixup = lib.optionalString stdenv.hostPlatform.isLinux '' patchelf \ - --set-rpath "${lib.makeLibraryPath [ (lib.getLib systemd) ]}:$(patchelf --print-rpath $out/bin/alloy)" \ + --set-rpath "${ + lib.makeLibraryPath [ (lib.getLib systemd) ] + }:$(patchelf --print-rpath $out/bin/alloy)" \ $out/bin/alloy ''; @@ -126,7 +138,12 @@ buildGoModule rec { license = licenses.asl20; homepage = "https://grafana.com/oss/alloy"; changelog = "https://github.com/grafana/alloy/blob/${src.rev}/CHANGELOG.md"; - maintainers = with maintainers; [ azahi flokli emilylange hbjydev ]; + maintainers = with maintainers; [ + azahi + flokli + emilylange + hbjydev + ]; platforms = lib.platforms.unix; }; } diff --git a/pkgs/by-name/gr/grafana-dash-n-grab/package.nix b/pkgs/by-name/gr/grafana-dash-n-grab/package.nix index c97036f71bc851..a7a2c108a56f66 100644 --- a/pkgs/by-name/gr/grafana-dash-n-grab/package.nix +++ b/pkgs/by-name/gr/grafana-dash-n-grab/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "grafana-dash-n-grab"; @@ -30,7 +34,6 @@ buildGoModule rec { homepage = "https://github.com/esnet/gdg"; maintainers = with maintainers; teams.bitnomial.members; mainProgram = "gdg"; - changelog = - "https://github.com/esnet/gdg/releases/tag/v${version}"; + changelog = "https://github.com/esnet/gdg/releases/tag/v${version}"; }; } diff --git a/pkgs/by-name/gr/grafana-image-renderer/package.nix b/pkgs/by-name/gr/grafana-image-renderer/package.nix index 833553b24e2083..03baafa0a9756d 100644 --- a/pkgs/by-name/gr/grafana-image-renderer/package.nix +++ b/pkgs/by-name/gr/grafana-image-renderer/package.nix @@ -1,4 +1,11 @@ -{ lib, mkYarnPackage, fetchFromGitHub, fetchYarnDeps, nodejs, runtimeShell }: +{ + lib, + mkYarnPackage, + fetchFromGitHub, + fetchYarnDeps, + nodejs, + runtimeShell, +}: # Notes for the upgrade: # * Download the tarball of the new version to use. diff --git a/pkgs/by-name/gr/grafana-kiosk/package.nix b/pkgs/by-name/gr/grafana-kiosk/package.nix index 39a26d95056a76..57913244e940b7 100644 --- a/pkgs/by-name/gr/grafana-kiosk/package.nix +++ b/pkgs/by-name/gr/grafana-kiosk/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, chromium, makeWrapper }: +{ + lib, + buildGoModule, + fetchFromGitHub, + chromium, + makeWrapper, +}: buildGoModule rec { pname = "grafana-kiosk"; diff --git a/pkgs/by-name/gr/grafterm/package.nix b/pkgs/by-name/gr/grafterm/package.nix index a15ab6e5ed0ff3..f0b698397e95ea 100644 --- a/pkgs/by-name/gr/grafterm/package.nix +++ b/pkgs/by-name/gr/grafterm/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-veg5B68AQhkSZg8YA/e4FbqJNG0YGwnUQFsAdscz0QI="; - ldflags = [ "-s" "-w" "-X main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.Version=${version}" + ]; meta = with lib; { description = "Command-line tool for rendering metrics dashboards inspired by Grafana"; diff --git a/pkgs/by-name/gr/grafx2/package.nix b/pkgs/by-name/gr/grafx2/package.nix index fa80fe718ce4f2..a36fe379bfa42c 100644 --- a/pkgs/by-name/gr/grafx2/package.nix +++ b/pkgs/by-name/gr/grafx2/package.nix @@ -1,23 +1,27 @@ -{ lib -, stdenv -, fetchurl -, SDL -, SDL_image -, SDL_ttf -, installShellFiles -, fontconfig -, libpng -, libtiff -, lua5 -, pkg-config -, zlib +{ + lib, + stdenv, + fetchurl, + SDL, + SDL_image, + SDL_ttf, + installShellFiles, + fontconfig, + libpng, + libtiff, + lua5, + pkg-config, + zlib, }: stdenv.mkDerivation (finalAttrs: { pname = "grafx2"; version = "2.8.3091"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchurl { name = "grafx2-${finalAttrs.version}.tar.gz"; @@ -49,7 +53,10 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = false; # Why?? makeFlags = [ "-C src" ]; - installFlags = [ "-C src" "PREFIX=$(out)" ]; + installFlags = [ + "-C src" + "PREFIX=$(out)" + ]; postInstall = '' installManPage misc/unix/grafx2.1 diff --git a/pkgs/by-name/gr/grail/package.nix b/pkgs/by-name/gr/grail/package.nix index b11ec3a9f5c3d4..85e61cbc703134 100644 --- a/pkgs/by-name/gr/grail/package.nix +++ b/pkgs/by-name/gr/grail/package.nix @@ -1,5 +1,13 @@ -{ enableX11 ? true, - lib, stdenv, fetchurl, pkg-config, xorg, python3, frame }: +{ + enableX11 ? true, + lib, + stdenv, + fetchurl, + pkg-config, + xorg, + python3, + frame, +}: stdenv.mkDerivation rec { pname = "grail"; @@ -11,8 +19,18 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ python3 frame ] - ++ lib.optionals enableX11 [xorg.libX11 xorg.libXtst xorg.libXext xorg.libXi xorg.libXfixes]; + buildInputs = + [ + python3 + frame + ] + ++ lib.optionals enableX11 [ + xorg.libX11 + xorg.libXtst + xorg.libXext + xorg.libXi + xorg.libXfixes + ]; configureFlags = lib.optional enableX11 "--with-x11"; diff --git a/pkgs/by-name/gr/grandperspective/package.nix b/pkgs/by-name/gr/grandperspective/package.nix index 816440ec1155ec..3c56cfb8bb291d 100644 --- a/pkgs/by-name/gr/grandperspective/package.nix +++ b/pkgs/by-name/gr/grandperspective/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, undmg, makeWrapper }: +{ + stdenv, + lib, + fetchurl, + undmg, + makeWrapper, +}: stdenv.mkDerivation (finalAttrs: { version = "3.4.2"; @@ -6,7 +12,9 @@ stdenv.mkDerivation (finalAttrs: { src = fetchurl { inherit (finalAttrs) version; - url = "mirror://sourceforge/grandperspectiv/GrandPerspective-${lib.replaceStrings [ "." ] [ "_" ] finalAttrs.version}.dmg"; + url = "mirror://sourceforge/grandperspectiv/GrandPerspective-${ + lib.replaceStrings [ "." ] [ "_" ] finalAttrs.version + }.dmg"; hash = "sha256-ZgyBeQCoixLGCFS8+UFoMilvtswplEC8MzK3BE4ocDg="; }; diff --git a/pkgs/by-name/gr/graph-cli/package.nix b/pkgs/by-name/gr/graph-cli/package.nix index ebddd548bed0e7..e7f722b59052df 100644 --- a/pkgs/by-name/gr/graph-cli/package.nix +++ b/pkgs/by-name/gr/graph-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3Packages -, fetchPypi -, qt5 +{ + lib, + python3Packages, + fetchPypi, + qt5, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/gr/graph-easy/package.nix b/pkgs/by-name/gr/graph-easy/package.nix index 668c7527e9e4f6..b9545c8ecd2fe8 100644 --- a/pkgs/by-name/gr/graph-easy/package.nix +++ b/pkgs/by-name/gr/graph-easy/package.nix @@ -1,4 +1,8 @@ -{ lib, perlPackages, fetchurl }: +{ + lib, + perlPackages, + fetchurl, +}: perlPackages.buildPerlPackage { pname = "graph-easy"; diff --git a/pkgs/by-name/gr/graphene-hardened-malloc/package.nix b/pkgs/by-name/gr/graphene-hardened-malloc/package.nix index 5759f7ef209440..f44cc7f4485e0d 100644 --- a/pkgs/by-name/gr/graphene-hardened-malloc/package.nix +++ b/pkgs/by-name/gr/graphene-hardened-malloc/package.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, lib -, makeWrapper -, python3 -, runCommand -, stdenv -, stress-ng +{ + fetchFromGitHub, + lib, + makeWrapper, + python3, + runCommand, + stdenv, + stress-ng, }: stdenv.mkDerivation (finalAttrs: { @@ -104,6 +105,9 @@ stdenv.mkDerivation (finalAttrs: { ''; license = licenses.mit; maintainers = with maintainers; [ ris ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; }; }) diff --git a/pkgs/by-name/gr/graphene/package.nix b/pkgs/by-name/gr/graphene/package.nix index 803f31efa47a0e..20ad68fb42b3aa 100644 --- a/pkgs/by-name/gr/graphene/package.nix +++ b/pkgs/by-name/gr/graphene/package.nix @@ -1,32 +1,41 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, nix-update-script -, pkg-config -, meson -, mesonEmulatorHook -, ninja -, python3 -, mutest -, nixosTests -, glib -, withDocumentation ? stdenv.buildPlatform.canExecute stdenv.hostPlatform || stdenv.hostPlatform.emulatorAvailable buildPackages -, gtk-doc -, docbook_xsl -, docbook_xml_dtd_43 -, buildPackages -, gobject-introspection -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, makeWrapper -, testers +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + nix-update-script, + pkg-config, + meson, + mesonEmulatorHook, + ninja, + python3, + mutest, + nixosTests, + glib, + withDocumentation ? + stdenv.buildPlatform.canExecute stdenv.hostPlatform + || stdenv.hostPlatform.emulatorAvailable buildPackages, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_43, + buildPackages, + gobject-introspection, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + makeWrapper, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "graphene"; version = "1.10.8"; - outputs = [ "out" "dev" ] + outputs = + [ + "out" + "dev" + ] ++ lib.optionals withDocumentation [ "devdoc" ] ++ lib.optionals (stdenv.hostPlatform == stdenv.buildPlatform) [ "installedTests" ]; @@ -55,21 +64,25 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - python3 - makeWrapper - ] ++ lib.optionals withDocumentation [ - docbook_xml_dtd_43 - docbook_xsl - gtk-doc - ] ++ lib.optionals (withDocumentation && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ] ++ lib.optionals withIntrospection [ - gobject-introspection - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + python3 + makeWrapper + ] + ++ lib.optionals withDocumentation [ + docbook_xml_dtd_43 + docbook_xsl + gtk-doc + ] + ++ lib.optionals (withDocumentation && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + ]; buildInputs = [ glib @@ -79,33 +92,49 @@ stdenv.mkDerivation (finalAttrs: { mutest ]; - mesonFlags = [ - (lib.mesonBool "gtk_doc" withDocumentation) - (lib.mesonEnable "introspection" withIntrospection) - "-Dinstalled_test_datadir=${placeholder "installedTests"}/share" - "-Dinstalled_test_bindir=${placeholder "installedTests"}/libexec" - ] ++ lib.optionals stdenv.hostPlatform.isAarch32 [ - # the box test is failing with SIGBUS on armv7l-linux - # https://github.com/ebassi/graphene/issues/215 - "-Darm_neon=false" - ]; + mesonFlags = + [ + (lib.mesonBool "gtk_doc" withDocumentation) + (lib.mesonEnable "introspection" withIntrospection) + "-Dinstalled_test_datadir=${placeholder "installedTests"}/share" + "-Dinstalled_test_bindir=${placeholder "installedTests"}/libexec" + ] + ++ lib.optionals stdenv.hostPlatform.isAarch32 [ + # the box test is failing with SIGBUS on armv7l-linux + # https://github.com/ebassi/graphene/issues/215 + "-Darm_neon=false" + ]; doCheck = true; - postPatch = '' - patchShebangs tests/gen-installed-test.py - '' + lib.optionalString withIntrospection '' - PATH=${python3.withPackages (pp: [ pp.pygobject3 pp.tappy ])}/bin:$PATH patchShebangs tests/introspection.py - ''; - - postFixup = let - introspectionPy = "${placeholder "installedTests"}/libexec/installed-tests/graphene-1.0/introspection.py"; - in lib.optionalString withIntrospection '' - if [ -x '${introspectionPy}' ] ; then - wrapProgram '${introspectionPy}' \ - --prefix GI_TYPELIB_PATH : "${lib.makeSearchPath "lib/girepository-1.0" [ glib.out (placeholder "out") ]}" - fi - ''; + postPatch = + '' + patchShebangs tests/gen-installed-test.py + '' + + lib.optionalString withIntrospection '' + PATH=${ + python3.withPackages (pp: [ + pp.pygobject3 + pp.tappy + ]) + }/bin:$PATH patchShebangs tests/introspection.py + ''; + + postFixup = + let + introspectionPy = "${placeholder "installedTests"}/libexec/installed-tests/graphene-1.0/introspection.py"; + in + lib.optionalString withIntrospection '' + if [ -x '${introspectionPy}' ] ; then + wrapProgram '${introspectionPy}' \ + --prefix GI_TYPELIB_PATH : "${ + lib.makeSearchPath "lib/girepository-1.0" [ + glib.out + (placeholder "out") + ] + }" + fi + ''; passthru = { tests = { @@ -124,6 +153,9 @@ stdenv.mkDerivation (finalAttrs: { license = licenses.mit; maintainers = teams.gnome.members ++ (with maintainers; [ ]); platforms = platforms.unix; - pkgConfigModules = [ "graphene-1.0" "graphene-gobject-1.0" ]; + pkgConfigModules = [ + "graphene-1.0" + "graphene-gobject-1.0" + ]; }; }) diff --git a/pkgs/by-name/gr/graphicsmagick/imagemagick-compat.nix b/pkgs/by-name/gr/graphicsmagick/imagemagick-compat.nix index 4d25a2aa0e1122..7683397b36920f 100644 --- a/pkgs/by-name/gr/graphicsmagick/imagemagick-compat.nix +++ b/pkgs/by-name/gr/graphicsmagick/imagemagick-compat.nix @@ -1,46 +1,52 @@ -{ lib -, graphicsmagick -, stdenvNoCC +{ + lib, + graphicsmagick, + stdenvNoCC, }: stdenvNoCC.mkDerivation { pname = "graphicsmagick-imagemagick-compat"; inherit (graphicsmagick) version; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; dontUnpack = true; dontBuild = true; # TODO: symlink libraries? - installPhase = let - utilities = [ - "animate" - "composite" - "conjure" - "convert" - "display" - "identify" - "import" - "mogrify" - "montage" - ]; - linkUtilityBin = utility: '' - ln -s ${lib.getExe graphicsmagick} "$out/bin/${utility}" - ''; - linkUtilityMan = utility: '' - ln -s ${lib.getMan graphicsmagick}/share/man/man1/gm.1.gz "$man/share/man/man1/${utility}.1.gz" - ''; - in '' - runHook preInstall + installPhase = + let + utilities = [ + "animate" + "composite" + "conjure" + "convert" + "display" + "identify" + "import" + "mogrify" + "montage" + ]; + linkUtilityBin = utility: '' + ln -s ${lib.getExe graphicsmagick} "$out/bin/${utility}" + ''; + linkUtilityMan = utility: '' + ln -s ${lib.getMan graphicsmagick}/share/man/man1/gm.1.gz "$man/share/man/man1/${utility}.1.gz" + ''; + in + '' + runHook preInstall - mkdir -p "$out"/bin - ${lib.concatStringsSep "\n" (map linkUtilityBin utilities)} - mkdir -p "$man"/share/man/man1 - ${lib.concatStringsSep "\n" (map linkUtilityMan utilities)} + mkdir -p "$out"/bin + ${lib.concatStringsSep "\n" (map linkUtilityBin utilities)} + mkdir -p "$man"/share/man/man1 + ${lib.concatStringsSep "\n" (map linkUtilityMan utilities)} - runHook postInstall - ''; + runHook postInstall + ''; meta = graphicsmagick.meta // { description = "Repack of GraphicsMagick that provides compatibility with ImageMagick interfaces"; diff --git a/pkgs/by-name/gr/graphicsmagick/package.nix b/pkgs/by-name/gr/graphicsmagick/package.nix index e0da1257fe14af..ffde1a95274517 100644 --- a/pkgs/by-name/gr/graphicsmagick/package.nix +++ b/pkgs/by-name/gr/graphicsmagick/package.nix @@ -1,27 +1,29 @@ -{ lib -, bzip2 -, callPackage -, coreutils -, fetchurl -, fixDarwinDylibNames -, freetype -, ghostscript -, graphviz -, libX11 -, libjpeg -, libpng -, libtiff -, libtool -, libwebp -, libxml2 -, libheifSupport ? true, libheif -, nukeReferences -, pkg-config -, quantumdepth ? 8 -, runCommand -, stdenv -, xz -, zlib +{ + lib, + bzip2, + callPackage, + coreutils, + fetchurl, + fixDarwinDylibNames, + freetype, + ghostscript, + graphviz, + libX11, + libjpeg, + libpng, + libtiff, + libtool, + libwebp, + libxml2, + libheifSupport ? true, + libheif, + nukeReferences, + pkg-config, + quantumdepth ? 8, + runCommand, + stdenv, + xz, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -33,7 +35,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-3OpRZ0FPfIBVV94tekepsxR7y/YXuR9fD0r+XmVDAms="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; buildInputs = [ bzip2 @@ -82,11 +87,14 @@ stdenv.mkDerivation (finalAttrs: { graphicsmagick = finalAttrs.finalPackage; }; tests = { - issue-157920 = runCommand "issue-157920-regression-test" { - buildInputs = [ finalAttrs.finalPackage ]; - } '' - gm convert ${graphviz}/share/doc/graphviz/neatoguide.pdf jpg:$out - ''; + issue-157920 = + runCommand "issue-157920-regression-test" + { + buildInputs = [ finalAttrs.finalPackage ]; + } + '' + gm convert ${graphviz}/share/doc/graphviz/neatoguide.pdf jpg:$out + ''; }; }; diff --git a/pkgs/by-name/gr/graphinder/package.nix b/pkgs/by-name/gr/graphinder/package.nix index 541e7ab3189d77..2aed25920bd459 100644 --- a/pkgs/by-name/gr/graphinder/package.nix +++ b/pkgs/by-name/gr/graphinder/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/gr/graphite-cli/package.nix b/pkgs/by-name/gr/graphite-cli/package.nix index 242a8b2b47778e..8066ec5321edfa 100644 --- a/pkgs/by-name/gr/graphite-cli/package.nix +++ b/pkgs/by-name/gr/graphite-cli/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildNpmPackage -, fetchurl -, git -, installShellFiles +{ + lib, + buildNpmPackage, + fetchurl, + git, + installShellFiles, }: buildNpmPackage rec { diff --git a/pkgs/by-name/gr/graphite-cursors/package.nix b/pkgs/by-name/gr/graphite-cursors/package.nix index b64e7567b25f12..f0dac31689d4e6 100644 --- a/pkgs/by-name/gr/graphite-cursors/package.nix +++ b/pkgs/by-name/gr/graphite-cursors/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gr/graphite-gtk-theme/package.nix b/pkgs/by-name/gr/graphite-gtk-theme/package.nix index e0edd1f76d928a..1cfef4fcfaaf19 100644 --- a/pkgs/by-name/gr/graphite-gtk-theme/package.nix +++ b/pkgs/by-name/gr/graphite-gtk-theme/package.nix @@ -1,98 +1,133 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gitUpdater -, gnome-themes-extra -, gtk-engine-murrine -, jdupes -, sassc -, themeVariants ? [] # default: blue -, colorVariants ? [] # default: all -, sizeVariants ? [] # default: standard -, tweaks ? [] -, wallpapers ? false -, withGrub ? false -, grubScreens ? [] # default: 1080p +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gitUpdater, + gnome-themes-extra, + gtk-engine-murrine, + jdupes, + sassc, + themeVariants ? [ ], # default: blue + colorVariants ? [ ], # default: all + sizeVariants ? [ ], # default: standard + tweaks ? [ ], + wallpapers ? false, + withGrub ? false, + grubScreens ? [ ], # default: 1080p }: let pname = "graphite-gtk-theme"; in -lib.checkListOfEnum "${pname}: theme variants" [ "default" "purple" "pink" "red" "orange" "yellow" "green" "teal" "blue" "all" ] themeVariants -lib.checkListOfEnum "${pname}: color variants" [ "standard" "light" "dark" ] colorVariants -lib.checkListOfEnum "${pname}: size variants" [ "standard" "compact" ] sizeVariants -lib.checkListOfEnum "${pname}: tweaks" [ "nord" "black" "darker" "rimless" "normal" "float" "colorful" ] tweaks -lib.checkListOfEnum "${pname}: grub screens" [ "1080p" "2k" "4k" ] grubScreens - -stdenvNoCC.mkDerivation rec { - inherit pname; - version = "2024-07-15"; - - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = version; - hash = "sha256-k93l/7DF0HSKPfiIxzBLz0mBflgbdYJyGLEmWZx3q7o="; - }; - - nativeBuildInputs = [ - jdupes - sassc - ]; - - buildInputs = [ - gnome-themes-extra - ]; - - propagatedUserEnvPkgs = [ - gtk-engine-murrine - ]; - - installPhase = '' - runHook preInstall - - patchShebangs install.sh - - name= ./install.sh \ - ${lib.optionalString (themeVariants != []) "--theme " + builtins.toString themeVariants} \ - ${lib.optionalString (colorVariants != []) "--color " + builtins.toString colorVariants} \ - ${lib.optionalString (sizeVariants != []) "--size " + builtins.toString sizeVariants} \ - ${lib.optionalString (tweaks != []) "--tweaks " + builtins.toString tweaks} \ - --dest $out/share/themes - - ${lib.optionalString wallpapers '' - mkdir -p $out/share/backgrounds - cp -a wallpaper/Graphite/*.png $out/share/backgrounds/ - ${lib.optionalString (builtins.elem "nord" tweaks) '' - cp -a wallpaper/Graphite-nord/*.png $out/share/backgrounds/ +lib.checkListOfEnum "${pname}: theme variants" + [ + "default" + "purple" + "pink" + "red" + "orange" + "yellow" + "green" + "teal" + "blue" + "all" + ] + themeVariants + lib.checkListOfEnum + "${pname}: color variants" + [ "standard" "light" "dark" ] + colorVariants + lib.checkListOfEnum + "${pname}: size variants" + [ "standard" "compact" ] + sizeVariants + lib.checkListOfEnum + "${pname}: tweaks" + [ + "nord" + "black" + "darker" + "rimless" + "normal" + "float" + "colorful" + ] + tweaks + lib.checkListOfEnum + "${pname}: grub screens" + [ "1080p" "2k" "4k" ] + grubScreens + + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "2024-07-15"; + + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = version; + hash = "sha256-k93l/7DF0HSKPfiIxzBLz0mBflgbdYJyGLEmWZx3q7o="; + }; + + nativeBuildInputs = [ + jdupes + sassc + ]; + + buildInputs = [ + gnome-themes-extra + ]; + + propagatedUserEnvPkgs = [ + gtk-engine-murrine + ]; + + installPhase = '' + runHook preInstall + + patchShebangs install.sh + + name= ./install.sh \ + ${lib.optionalString (themeVariants != [ ]) "--theme " + builtins.toString themeVariants} \ + ${lib.optionalString (colorVariants != [ ]) "--color " + builtins.toString colorVariants} \ + ${lib.optionalString (sizeVariants != [ ]) "--size " + builtins.toString sizeVariants} \ + ${lib.optionalString (tweaks != [ ]) "--tweaks " + builtins.toString tweaks} \ + --dest $out/share/themes + + ${lib.optionalString wallpapers '' + mkdir -p $out/share/backgrounds + cp -a wallpaper/Graphite/*.png $out/share/backgrounds/ + ${lib.optionalString (builtins.elem "nord" tweaks) '' + cp -a wallpaper/Graphite-nord/*.png $out/share/backgrounds/ + ''} ''} - ''} - ${lib.optionalString withGrub '' - ( - cd other/grub2 + ${lib.optionalString withGrub '' + ( + cd other/grub2 - patchShebangs install.sh + patchShebangs install.sh - ./install.sh --justcopy --dest $out/share/grub/themes \ - ${lib.optionalString (builtins.elem "nord" tweaks) "--theme nord"} \ - ${lib.optionalString (grubScreens != []) "--screen " + builtins.toString grubScreens} - ) - ''} + ./install.sh --justcopy --dest $out/share/grub/themes \ + ${lib.optionalString (builtins.elem "nord" tweaks) "--theme nord"} \ + ${lib.optionalString (grubScreens != [ ]) "--screen " + builtins.toString grubScreens} + ) + ''} - jdupes --quiet --link-soft --recurse $out/share + jdupes --quiet --link-soft --recurse $out/share - runHook postInstall - ''; + runHook postInstall + ''; - passthru.updateScript = gitUpdater { }; + passthru.updateScript = gitUpdater { }; - meta = with lib; { - description = "Flat Gtk+ theme based on Elegant Design"; - homepage = "https://github.com/vinceliuice/Graphite-gtk-theme"; - license = licenses.gpl3Only; - platforms = platforms.unix; - maintainers = [ maintainers.romildo ]; - }; -} + meta = with lib; { + description = "Flat Gtk+ theme based on Elegant Design"; + homepage = "https://github.com/vinceliuice/Graphite-gtk-theme"; + license = licenses.gpl3Only; + platforms = platforms.unix; + maintainers = [ maintainers.romildo ]; + }; + } diff --git a/pkgs/by-name/gr/graphqlmap/package.nix b/pkgs/by-name/gr/graphqlmap/package.nix index a2c0904b4a9830..28362e2daacc25 100644 --- a/pkgs/by-name/gr/graphqlmap/package.nix +++ b/pkgs/by-name/gr/graphqlmap/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/gr/graphs/package.nix b/pkgs/by-name/gr/graphs/package.nix index 3244e46d580eaf..2d2d5cc69d8984 100644 --- a/pkgs/by-name/gr/graphs/package.nix +++ b/pkgs/by-name/gr/graphs/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gr/graphwar/package.nix b/pkgs/by-name/gr/graphwar/package.nix index ac177281fa07bf..69df9ab0655bf5 100644 --- a/pkgs/by-name/gr/graphwar/package.nix +++ b/pkgs/by-name/gr/graphwar/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, copyDesktopItems -, jdk -, makeDesktopItem -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + copyDesktopItems, + jdk, + makeDesktopItem, + makeWrapper, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-t3Y576dXWp2Mj6OSQN5cm9FuNBWNqKq6xxkVRbjIBgE="; }; - nativeBuildInputs = [ copyDesktopItems makeWrapper ]; + nativeBuildInputs = [ + copyDesktopItems + makeWrapper + ]; buildInputs = [ jdk ]; buildPhase = '' diff --git a/pkgs/by-name/gr/graplang/package.nix b/pkgs/by-name/gr/graplang/package.nix index aa0a74da382f33..af6dc1a030ad2a 100644 --- a/pkgs/by-name/gr/graplang/package.nix +++ b/pkgs/by-name/gr/graplang/package.nix @@ -1,22 +1,29 @@ -{ lib -, stdenv -, fetchurl -, flex -, bison +{ + lib, + stdenv, + fetchurl, + flex, + bison, }: stdenv.mkDerivation (finalAttrs: { pname = "graplang"; version = "1.46"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchurl { url = "https://www.lunabase.org/~faber/Vault/software/grap/grap-${finalAttrs.version}.tar.gz"; hash = "sha512-7n+jLANU/x+wGrpjwYAnf45fQ5M91SwraiCbvUKe6XhWtilhGoT2yTlLkPlTihETTkizLyssW5gj5gbwNHaooA=="; }; - nativeBuildInputs = [ flex bison ]; + nativeBuildInputs = [ + flex + bison + ]; meta = with lib; { description = "Language for typesetting graphs"; diff --git a/pkgs/by-name/gr/grass-sass/package.nix b/pkgs/by-name/gr/grass-sass/package.nix index eae322e03f857d..058afa2d1130c9 100644 --- a/pkgs/by-name/gr/grass-sass/package.nix +++ b/pkgs/by-name/gr/grass-sass/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,9 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Sass compiler written purely in Rust"; homepage = "https://github.com/connorskees/grass"; - changelog = "https://github.com/connorskees/grass/blob/master/CHANGELOG.md#${replaceStrings [ "." ] [ "" ] version}"; + changelog = "https://github.com/connorskees/grass/blob/master/CHANGELOG.md#${ + replaceStrings [ "." ] [ "" ] version + }"; license = licenses.mit; maintainers = with maintainers; [ figsoda ]; mainProgram = "grass"; diff --git a/pkgs/by-name/gr/gravit/package.nix b/pkgs/by-name/gr/gravit/package.nix index b734ea9750dcc6..3a2ce481753009 100644 --- a/pkgs/by-name/gr/gravit/package.nix +++ b/pkgs/by-name/gr/gravit/package.nix @@ -1,4 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, SDL, SDL_ttf, SDL_image, libSM, libICE, libGLU, libGL, libpng, lua5, autoconf, automake, mesa }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + SDL, + SDL_ttf, + SDL_image, + libSM, + libICE, + libGLU, + libGL, + libpng, + lua5, + autoconf, + automake, + mesa, +}: stdenv.mkDerivation rec { pname = "gravit"; @@ -21,9 +38,22 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ libGLU libGL SDL SDL_ttf SDL_image lua5 libpng libSM libICE ]; + buildInputs = [ + libGLU + libGL + SDL + SDL_ttf + SDL_image + lua5 + libpng + libSM + libICE + ]; - nativeBuildInputs = [ autoconf automake ]; + nativeBuildInputs = [ + autoconf + automake + ]; preConfigure = '' ./autogen.sh diff --git a/pkgs/by-name/gr/grb/package.nix b/pkgs/by-name/gr/grb/package.nix index 48caa482bb753a..ab55e98dff5e2c 100644 --- a/pkgs/by-name/gr/grb/package.nix +++ b/pkgs/by-name/gr/grb/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "grb"; diff --git a/pkgs/by-name/gr/grepcidr/package.nix b/pkgs/by-name/gr/grepcidr/package.nix index 231718c810eef2..a5083c41419467 100644 --- a/pkgs/by-name/gr/grepcidr/package.nix +++ b/pkgs/by-name/gr/grepcidr/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "grepcidr"; diff --git a/pkgs/by-name/gr/grepm/package.nix b/pkgs/by-name/gr/grepm/package.nix index c3adbb2ab8b05c..6c6ed863cce6d7 100644 --- a/pkgs/by-name/gr/grepm/package.nix +++ b/pkgs/by-name/gr/grepm/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, perlPackages, mutt }: +{ + lib, + stdenv, + fetchurl, + perlPackages, + mutt, +}: stdenv.mkDerivation { pname = "grepm"; @@ -11,7 +17,10 @@ stdenv.mkDerivation { dontUnpack = true; - buildInputs = [ perlPackages.grepmail mutt ]; + buildInputs = [ + perlPackages.grepmail + mutt + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/gr/gridlock/package.nix b/pkgs/by-name/gr/gridlock/package.nix index ddfa9ee9831f0b..78a1c4877f97ce 100644 --- a/pkgs/by-name/gr/gridlock/package.nix +++ b/pkgs/by-name/gr/gridlock/package.nix @@ -1,17 +1,21 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage { pname = "gridlock"; version = "unstable-2023-08-29"; - outputs = [ "out" "nyarr" ]; + outputs = [ + "out" + "nyarr" + ]; src = fetchFromGitHub { owner = "lf-"; @@ -26,11 +30,13 @@ rustPlatform.buildRustPackage { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; postInstall = '' moveToOutput bin/nyarr $nyarr diff --git a/pkgs/by-name/gr/gridtracker/package.nix b/pkgs/by-name/gr/gridtracker/package.nix index 688db3fee1d92e..dff08d4d8767e9 100644 --- a/pkgs/by-name/gr/gridtracker/package.nix +++ b/pkgs/by-name/gr/gridtracker/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitLab, nix-update-script, nwjs, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitLab, + nix-update-script, + nwjs, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "gridtracker"; @@ -23,7 +30,10 @@ stdenv.mkDerivation rec { --replace "/usr/share/gridtracker/gridview.png" "$out/share/gridtracker/gridview.png" ''; - makeFlags = [ "DESTDIR=$(out)" "NO_DIST_INSTALL=1" ]; + makeFlags = [ + "DESTDIR=$(out)" + "NO_DIST_INSTALL=1" + ]; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/by-name/gr/grig/package.nix b/pkgs/by-name/gr/grig/package.nix index fa3e915ba3acfa..189eaeaa363900 100644 --- a/pkgs/by-name/gr/grig/package.nix +++ b/pkgs/by-name/gr/grig/package.nix @@ -1,11 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, wrapGAppsHook3 -, gtk2 -, hamlib_4 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + wrapGAppsHook3, + gtk2, + hamlib_4, +}: stdenv.mkDerivation rec { pname = "grig"; @@ -14,12 +16,19 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "fillods"; repo = "grig"; - rev = "GRIG-${lib.replaceStrings ["."] ["_"] version}"; + rev = "GRIG-${lib.replaceStrings [ "." ] [ "_" ] version}"; sha256 = "sha256-OgIgHW9NMW/xSSti3naIR8AQWUtNSv5bYdOcObStBlM="; }; - nativeBuildInputs = [ autoreconfHook pkg-config wrapGAppsHook3 ]; - buildInputs = [ hamlib_4 gtk2 ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + wrapGAppsHook3 + ]; + buildInputs = [ + hamlib_4 + gtk2 + ]; meta = with lib; { description = "Simple Ham Radio control (CAT) program based on Hamlib"; diff --git a/pkgs/by-name/gr/grilo-plugins/package.nix b/pkgs/by-name/gr/grilo-plugins/package.nix index 4f3560fbd1c29e..d2837d186a0526 100644 --- a/pkgs/by-name/gr/grilo-plugins/package.nix +++ b/pkgs/by-name/gr/grilo-plugins/package.nix @@ -1,32 +1,34 @@ -{ lib, stdenv -, fetchurl -, substituteAll -, meson -, ninja -, pkg-config -, gettext -, gperf -, glib -, sqlite -, libarchive -, libdmapsharing -, libsoup_3 -, gnome -, libxml2 -, lua5_4 -, liboauth -, libmediaart -, grilo -, gst_all_1 -, gnome-online-accounts -, gmime -, gom -, json-glib -, avahi -, tinysparql -, dleyna-server -, itstool -, totem-pl-parser +{ + lib, + stdenv, + fetchurl, + substituteAll, + meson, + ninja, + pkg-config, + gettext, + gperf, + glib, + sqlite, + libarchive, + libdmapsharing, + libsoup_3, + gnome, + libxml2, + lua5_4, + liboauth, + libmediaart, + grilo, + gst_all_1, + gnome-online-accounts, + gmime, + gom, + json-glib, + avahi, + tinysparql, + dleyna-server, + itstool, + totem-pl-parser, }: stdenv.mkDerivation rec { @@ -45,11 +47,17 @@ stdenv.mkDerivation rec { # * chromaprint (gst-plugins-bad) (substituteAll { src = ./chromaprint-gst-plugins.patch; - load_plugins = lib.concatMapStrings (plugin: ''gst_registry_scan_path(gst_registry_get(), "${lib.getLib plugin}/lib/gstreamer-1.0");'') (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-bad - ]); + load_plugins = + lib.concatMapStrings + (plugin: ''gst_registry_scan_path(gst_registry_get(), "${lib.getLib plugin}/lib/gstreamer-1.0");'') + ( + with gst_all_1; + [ + gstreamer + gst-plugins-base + gst-plugins-bad + ] + ); }) ]; diff --git a/pkgs/by-name/gr/grilo/package.nix b/pkgs/by-name/gr/grilo/package.nix index 06b524579ac42f..44e42f772c717d 100644 --- a/pkgs/by-name/gr/grilo/package.nix +++ b/pkgs/by-name/gr/grilo/package.nix @@ -1,31 +1,37 @@ -{ stdenv -, lib -, fetchurl -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, python3 -, gettext -, vala -, glib -, liboauth -, gtk3 -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_43 -, libxml2 -, gnome -, gobject-introspection -, libsoup_3 -, totem-pl-parser +{ + stdenv, + lib, + fetchurl, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + python3, + gettext, + vala, + glib, + liboauth, + gtk3, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_43, + libxml2, + gnome, + gobject-introspection, + libsoup_3, + totem-pl-parser, }: stdenv.mkDerivation rec { pname = "grilo"; version = "0.3.16"; # if you change minor, also change ./setup-hook.sh - outputs = [ "out" "dev" "man" "devdoc" ]; + outputs = [ + "out" + "dev" + "man" + "devdoc" + ]; outputBin = "dev"; setupHook = ./setup-hook.sh; @@ -39,20 +45,22 @@ stdenv.mkDerivation rec { "-Denable-gtk-doc=true" ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - python3 - gettext - gobject-introspection - vala - gtk-doc - docbook-xsl-nons - docbook_xml_dtd_43 - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + python3 + gettext + gobject-introspection + vala + gtk-doc + docbook-xsl-nons + docbook_xml_dtd_43 + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ glib diff --git a/pkgs/by-name/gr/grimblast/package.nix b/pkgs/by-name/gr/grimblast/package.nix index dce239d1cb59f7..9c2250042009f4 100644 --- a/pkgs/by-name/gr/grimblast/package.nix +++ b/pkgs/by-name/gr/grimblast/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, makeWrapper -, scdoc -, coreutils -, grim -, hyprland -, hyprpicker -, jq -, libnotify -, slurp -, wl-clipboard -, bash +{ + lib, + stdenvNoCC, + fetchFromGitHub, + makeWrapper, + scdoc, + coreutils, + grim, + hyprland, + hyprpicker, + jq, + libnotify, + slurp, + wl-clipboard, + bash, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -42,16 +43,18 @@ stdenvNoCC.mkDerivation (finalAttrs: { postInstall = '' wrapProgram $out/bin/grimblast --prefix PATH ':' \ - "${lib.makeBinPath [ - coreutils - grim - hyprland - hyprpicker - jq - libnotify - slurp - wl-clipboard - ]}" + "${ + lib.makeBinPath [ + coreutils + grim + hyprland + hyprpicker + jq + libnotify + slurp + wl-clipboard + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/gr/grip-search/package.nix b/pkgs/by-name/gr/grip-search/package.nix index dd272af06bf3a0..5b9b622d929ad6 100644 --- a/pkgs/by-name/gr/grip-search/package.nix +++ b/pkgs/by-name/gr/grip-search/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, boost, pkg-config, cmake, catch2 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + boost, + pkg-config, + cmake, + catch2, +}: stdenv.mkDerivation rec { pname = "grip-search"; @@ -11,7 +20,11 @@ stdenv.mkDerivation rec { sha256 = "0bkqarylgzhis6fpj48qbifcd6a26cgnq8784hgnm707rq9kb0rx"; }; - nativeBuildInputs = [ pkg-config cmake catch2 ]; + nativeBuildInputs = [ + pkg-config + cmake + catch2 + ]; doCheck = true; diff --git a/pkgs/by-name/gr/grip/package.nix b/pkgs/by-name/gr/grip/package.nix index f993cb387b74a8..eb11b33b668ee0 100644 --- a/pkgs/by-name/gr/grip/package.nix +++ b/pkgs/by-name/gr/grip/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, gtk2 -, pkg-config -, curl -, cdparanoia -, libid3tag -, libtool +{ + lib, + stdenv, + fetchurl, + gtk2, + pkg-config, + curl, + cdparanoia, + libid3tag, + libtool, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-lXu0mLLfcX8K1EmoFH0vp2cHluyRwhTL0/bW5Ax36mI="; }; - nativeBuildInputs = [ pkg-config libtool ]; + nativeBuildInputs = [ + pkg-config + libtool + ]; buildInputs = [ gtk2 curl diff --git a/pkgs/by-name/gr/grit/package.nix b/pkgs/by-name/gr/grit/package.nix index d9cffca07f0cfd..cdf1aca545f191 100644 --- a/pkgs/by-name/gr/grit/package.nix +++ b/pkgs/by-name/gr/grit/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, buildGoModule, fetchFromGitHub }: +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "grit"; diff --git a/pkgs/by-name/gr/grive2/package.nix b/pkgs/by-name/gr/grive2/package.nix index 9f6ea5acea1522..c5e2b90c439061 100644 --- a/pkgs/by-name/gr/grive2/package.nix +++ b/pkgs/by-name/gr/grive2/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, pkg-config -, yajl -, cmake -, libgcrypt -, curl -, expat -, boost -, libiberty +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + yajl, + cmake, + libgcrypt, + curl, + expat, + boost, + libiberty, }: stdenv.mkDerivation rec { @@ -19,7 +20,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "vitalif"; repo = "grive2"; - rev = "v${version}"; + rev = "v${version}"; sha256 = "sha256-P6gitA5cXfNbNDy4ohRLyXj/5dUXkCkOdE/9rJPzNCg="; }; @@ -33,9 +34,19 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ libgcrypt yajl curl expat boost libiberty ]; + buildInputs = [ + libgcrypt + yajl + curl + expat + boost + libiberty + ]; meta = with lib; { description = "Console Google Drive client"; diff --git a/pkgs/by-name/gr/grobi/package.nix b/pkgs/by-name/gr/grobi/package.nix index cea5fad51e5552..5841700709ad08 100644 --- a/pkgs/by-name/gr/grobi/package.nix +++ b/pkgs/by-name/gr/grobi/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, fetchpatch }: +{ + lib, + fetchFromGitHub, + buildGoModule, + fetchpatch, +}: buildGoModule rec { version = "0.6.0"; @@ -25,7 +30,7 @@ buildGoModule rec { homepage = "https://github.com/fd0/grobi"; description = "Automatically configure monitors/outputs for Xorg via RANDR"; license = with licenses; [ bsd2 ]; - platforms = platforms.linux; + platforms = platforms.linux; mainProgram = "grobi"; }; } diff --git a/pkgs/by-name/gr/grocy/package.nix b/pkgs/by-name/gr/grocy/package.nix index dbca9773ab6534..a7473e1c0986e4 100644 --- a/pkgs/by-name/gr/grocy/package.nix +++ b/pkgs/by-name/gr/grocy/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, fetchYarnDeps -, php -, yarn -, fixup-yarn-lock -, nixosTests +{ + lib, + fetchFromGitHub, + fetchYarnDeps, + php, + yarn, + fixup-yarn-lock, + nixosTests, }: php.buildComposerProject (finalAttrs: { diff --git a/pkgs/by-name/gr/groff/package.nix b/pkgs/by-name/gr/groff/package.nix index 6e10144bb587cf..bcc71885fd87a0 100644 --- a/pkgs/by-name/gr/groff/package.nix +++ b/pkgs/by-name/gr/groff/package.nix @@ -1,15 +1,28 @@ -{ lib, stdenv, fetchurl, perl -, enableGhostscript ? false -, ghostscript, gawk, libX11, libXaw, libXt, libXmu # for postscript and html output -, enableHtml ? false, psutils, netpbm # for html output -, enableIconv ? false, iconv -, enableLibuchardet ? false, libuchardet # for detecting input file encoding in preconv(1) -, buildPackages -, autoreconfHook -, pkg-config -, texinfo -, bison -, bash +{ + lib, + stdenv, + fetchurl, + perl, + enableGhostscript ? false, + ghostscript, + gawk, + libX11, + libXaw, + libXt, + libXmu, # for postscript and html output + enableHtml ? false, + psutils, + netpbm, # for html output + enableIconv ? false, + iconv, + enableLibuchardet ? false, + libuchardet, # for detecting input file encoding in preconv(1) + buildPackages, + autoreconfHook, + pkg-config, + texinfo, + bison, + bash, }: stdenv.mkDerivation rec { @@ -21,54 +34,86 @@ stdenv.mkDerivation rec { hash = "sha256-a5dX9ZK3UYtJAutq9+VFcL3Mujeocf3bLTCuOGNRHBM="; }; - outputs = [ "out" "man" "doc" "info" "perl" ]; + outputs = [ + "out" + "man" + "doc" + "info" + "perl" + ]; enableParallelBuilding = true; - postPatch = '' - # BASH_PROG gets replaced with a path to the build bash which doesn't get automatically patched by patchShebangs - substituteInPlace contrib/gdiffmk/gdiffmk.sh \ - --replace "@BASH_PROG@" "/bin/sh" - '' + lib.optionalString enableHtml '' - substituteInPlace src/preproc/html/pre-html.cpp \ - --replace "psselect" "${psutils}/bin/psselect" \ - --replace "pnmcut" "${lib.getBin netpbm}/bin/pnmcut" \ - --replace "pnmcrop" "${lib.getBin netpbm}/bin/pnmcrop" \ - --replace "pnmtopng" "${lib.getBin netpbm}/bin/pnmtopng" - substituteInPlace tmac/www.tmac.in \ - --replace "pnmcrop" "${lib.getBin netpbm}/bin/pnmcrop" \ - --replace "pngtopnm" "${lib.getBin netpbm}/bin/pngtopnm" \ - --replace "@PNMTOPS_NOSETPAGE@" "${lib.getBin netpbm}/bin/pnmtops -nosetpage" - '' + lib.optionalString (enableGhostscript || enableHtml) '' - substituteInPlace contrib/pdfmark/pdfroff.sh \ - --replace '$GROFF_GHOSTSCRIPT_INTERPRETER' "${lib.getBin ghostscript}/bin/gs" \ - --replace '$GROFF_AWK_INTERPRETER' "${lib.getBin gawk}/bin/gawk" - ''; + postPatch = + '' + # BASH_PROG gets replaced with a path to the build bash which doesn't get automatically patched by patchShebangs + substituteInPlace contrib/gdiffmk/gdiffmk.sh \ + --replace "@BASH_PROG@" "/bin/sh" + '' + + lib.optionalString enableHtml '' + substituteInPlace src/preproc/html/pre-html.cpp \ + --replace "psselect" "${psutils}/bin/psselect" \ + --replace "pnmcut" "${lib.getBin netpbm}/bin/pnmcut" \ + --replace "pnmcrop" "${lib.getBin netpbm}/bin/pnmcrop" \ + --replace "pnmtopng" "${lib.getBin netpbm}/bin/pnmtopng" + substituteInPlace tmac/www.tmac.in \ + --replace "pnmcrop" "${lib.getBin netpbm}/bin/pnmcrop" \ + --replace "pngtopnm" "${lib.getBin netpbm}/bin/pngtopnm" \ + --replace "@PNMTOPS_NOSETPAGE@" "${lib.getBin netpbm}/bin/pnmtops -nosetpage" + '' + + lib.optionalString (enableGhostscript || enableHtml) '' + substituteInPlace contrib/pdfmark/pdfroff.sh \ + --replace '$GROFF_GHOSTSCRIPT_INTERPRETER' "${lib.getBin ghostscript}/bin/gs" \ + --replace '$GROFF_AWK_INTERPRETER' "${lib.getBin gawk}/bin/gawk" + ''; strictDeps = true; - nativeBuildInputs = [ autoreconfHook pkg-config texinfo ] + nativeBuildInputs = + [ + autoreconfHook + pkg-config + texinfo + ] # Required due to the patch that changes .ypp files. ++ lib.optional (stdenv.cc.isClang && lib.versionAtLeast stdenv.cc.version "9") bison; - buildInputs = [ perl bash ] - ++ lib.optionals enableGhostscript [ ghostscript gawk libX11 libXaw libXt libXmu ] - ++ lib.optionals enableHtml [ psutils netpbm ] + buildInputs = + [ + perl + bash + ] + ++ lib.optionals enableGhostscript [ + ghostscript + gawk + libX11 + libXaw + libXt + libXmu + ] + ++ lib.optionals enableHtml [ + psutils + netpbm + ] ++ lib.optionals enableIconv [ iconv ] ++ lib.optionals enableLibuchardet [ libuchardet ]; # Builds running without a chroot environment may detect the presence # of /usr/X11 in the host system, leading to an impure build of the # package. To avoid this issue, X11 support is explicitly disabled. - configureFlags = lib.optionals (!enableGhostscript) [ - "--without-x" - ] ++ [ - "ac_cv_path_PERL=${buildPackages.perl}/bin/perl" - ] ++ lib.optionals enableGhostscript [ - "--with-gs=${lib.getBin ghostscript}/bin/gs" - "--with-awk=${lib.getBin gawk}/bin/gawk" - "--with-appresdir=${placeholder "out"}/lib/X11/app-defaults" - ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ - "gl_cv_func_signbit=yes" - ]; + configureFlags = + lib.optionals (!enableGhostscript) [ + "--without-x" + ] + ++ [ + "ac_cv_path_PERL=${buildPackages.perl}/bin/perl" + ] + ++ lib.optionals enableGhostscript [ + "--with-gs=${lib.getBin ghostscript}/bin/gs" + "--with-awk=${lib.getBin gawk}/bin/gawk" + "--with-appresdir=${placeholder "out"}/lib/X11/app-defaults" + ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "gl_cv_func_signbit=yes" + ]; makeFlags = lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ # Trick to get the build system find the proper 'native' groff @@ -131,6 +176,9 @@ stdenv.mkDerivation rec { implementation of the -mm macros. ''; - outputsToInstall = [ "out" "perl" ]; + outputsToInstall = [ + "out" + "perl" + ]; }; } diff --git a/pkgs/by-name/gr/gron/package.nix b/pkgs/by-name/gr/gron/package.nix index 4ef6216c370b93..8290fd91eb4f2e 100644 --- a/pkgs/by-name/gr/gron/package.nix +++ b/pkgs/by-name/gr/gron/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gron"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-K/QAG9mCIHe7PQhex3TntlGYAK9l0bESWk616N97dBs="; - ldflags = [ "-s" "-w" "-X main.gronVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.gronVersion=${version}" + ]; meta = with lib; { description = "Make JSON greppable!"; @@ -26,6 +34,9 @@ buildGoModule rec { ''; homepage = "https://github.com/tomnomnom/gron"; license = licenses.mit; - maintainers = with maintainers; [ fgaz SuperSandro2000 ]; + maintainers = with maintainers; [ + fgaz + SuperSandro2000 + ]; }; } diff --git a/pkgs/by-name/gr/groonga/package.nix b/pkgs/by-name/gr/groonga/package.nix index adcd4df02c3de3..8b985dbeee430d 100644 --- a/pkgs/by-name/gr/groonga/package.nix +++ b/pkgs/by-name/gr/groonga/package.nix @@ -1,7 +1,25 @@ -{ lib, stdenv, cmake, fetchurl, kytea, msgpack-c, mecab, pkg-config, rapidjson, testers, xxHash, zstd, postgresqlPackages -, suggestSupport ? false, zeromq, libevent, openssl -, lz4Support ? false, lz4 -, zlibSupport ? true, zlib +{ + lib, + stdenv, + cmake, + fetchurl, + kytea, + msgpack-c, + mecab, + pkg-config, + rapidjson, + testers, + xxHash, + zstd, + postgresqlPackages, + suggestSupport ? false, + zeromq, + libevent, + openssl, + lz4Support ? false, + lz4, + zlibSupport ? true, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -23,21 +41,25 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - rapidjson - xxHash - zstd - mecab - kytea - msgpack-c - ] ++ lib.optionals lz4Support [ - lz4 - ] ++ lib.optional zlibSupport [ - zlib - ] ++ lib.optionals suggestSupport [ - zeromq - libevent - ]; + buildInputs = + [ + rapidjson + xxHash + zstd + mecab + kytea + msgpack-c + ] + ++ lib.optionals lz4Support [ + lz4 + ] + ++ lib.optional zlibSupport [ + zlib + ] + ++ lib.optionals suggestSupport [ + zeromq + libevent + ]; env.NIX_CFLAGS_COMPILE = lib.optionalString zlibSupport "-I${zlib.dev}/include"; diff --git a/pkgs/by-name/gr/groove/package.nix b/pkgs/by-name/gr/groove/package.nix index 6350d0badee9f7..487a4eed497c2b 100644 --- a/pkgs/by-name/gr/groove/package.nix +++ b/pkgs/by-name/gr/groove/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, unzip, makeWrapper, makeDesktopItem, icoutils, jre8 }: +{ + lib, + stdenv, + fetchurl, + unzip, + makeWrapper, + makeDesktopItem, + icoutils, + jre8, +}: let desktopItem = makeDesktopItem { @@ -7,19 +16,29 @@ let icon = "groove"; desktopName = "GROOVE Simulator"; comment = "GRaphs for Object-Oriented VErification"; - categories = [ "Science" "ComputerScience" ]; + categories = [ + "Science" + "ComputerScience" + ]; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "groove"; version = "5.8.1"; src = fetchurl { - url = "mirror://sourceforge/groove/groove/${version}/${pname}-${builtins.replaceStrings ["."] ["_"] version}-bin.zip"; + url = "mirror://sourceforge/groove/groove/${version}/${pname}-${ + builtins.replaceStrings [ "." ] [ "_" ] version + }-bin.zip"; sha256 = "sha256-JwoUlO6F2+8NtCnLC+xm5q0Jm8RIyU1rnuKGmjgJhFU="; }; - nativeBuildInputs = [ unzip makeWrapper icoutils ]; + nativeBuildInputs = [ + unzip + makeWrapper + icoutils + ]; dontBuild = true; diff --git a/pkgs/by-name/gr/grpc-client-cli/package.nix b/pkgs/by-name/gr/grpc-client-cli/package.nix index 7e2332c52d4d53..4925c0aa3a7ed3 100644 --- a/pkgs/by-name/gr/grpc-client-cli/package.nix +++ b/pkgs/by-name/gr/grpc-client-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "grpc-client-cli"; diff --git a/pkgs/by-name/gr/grpc-health-check/package.nix b/pkgs/by-name/gr/grpc-health-check/package.nix index 5ef0efc6301a2d..1d2f915c553aa6 100644 --- a/pkgs/by-name/gr/grpc-health-check/package.nix +++ b/pkgs/by-name/gr/grpc-health-check/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, fetchFromGitHub -, rustPlatform -, protobuf -, lib +{ + stdenv, + fetchFromGitHub, + rustPlatform, + protobuf, + lib, }: rustPlatform.buildRustPackage { diff --git a/pkgs/by-name/gr/grpc-tools/package.nix b/pkgs/by-name/gr/grpc-tools/package.nix index 5c21f8a0f415dd..5bf09b7f0b940a 100644 --- a/pkgs/by-name/gr/grpc-tools/package.nix +++ b/pkgs/by-name/gr/grpc-tools/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, gitUpdater +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gr/grpc_cli/package.nix b/pkgs/by-name/gr/grpc_cli/package.nix index 58915a3509e212..d56351c484a1fc 100644 --- a/pkgs/by-name/gr/grpc_cli/package.nix +++ b/pkgs/by-name/gr/grpc_cli/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, automake, cmake, autoconf, curl, numactl }: +{ + lib, + stdenv, + fetchFromGitHub, + automake, + cmake, + autoconf, + curl, + numactl, +}: stdenv.mkDerivation rec { pname = "grpc_cli"; @@ -10,8 +19,15 @@ stdenv.mkDerivation rec { hash = "sha256-x49mh7gLliAiFjOZM5U/CnMQqs7fAhoipo18OBoeD0w="; fetchSubmodules = true; }; - nativeBuildInputs = [ automake cmake autoconf ]; - buildInputs = [ curl numactl ]; + nativeBuildInputs = [ + automake + cmake + autoconf + ]; + buildInputs = [ + curl + numactl + ]; cmakeFlags = [ "-DgRPC_BUILD_TESTS=ON" ]; makeFlags = [ "grpc_cli" ]; env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isAarch64 "-Wno-error=format-security"; diff --git a/pkgs/by-name/gr/grpcui/package.nix b/pkgs/by-name/gr/grpcui/package.nix index 3691a3ab8eb872..0a3e3588203593 100644 --- a/pkgs/by-name/gr/grpcui/package.nix +++ b/pkgs/by-name/gr/grpcui/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "grpcui"; @@ -17,7 +21,11 @@ buildGoModule rec { subPackages = [ "cmd/grpcui" ]; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; meta = with lib; { description = "Interactive web UI for gRPC, along the lines of postman"; diff --git a/pkgs/by-name/gr/grpcurl/package.nix b/pkgs/by-name/gr/grpcurl/package.nix index e445d5828b0093..8630ad61ca2a20 100644 --- a/pkgs/by-name/gr/grpcurl/package.nix +++ b/pkgs/by-name/gr/grpcurl/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "grpcurl"; @@ -15,7 +19,11 @@ buildGoModule rec { vendorHash = "sha256-e/V6MMYGqhZ2Ei7+2XhSsCXJNiwsTPa2Q43rdkns45o="; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; meta = with lib; { description = "Like cURL, but for gRPC: Command-line tool for interacting with gRPC servers"; diff --git a/pkgs/by-name/gr/grsync/package.nix b/pkgs/by-name/gr/grsync/package.nix index 0e0a6cb87eebcc..edc7d9751ecb90 100644 --- a/pkgs/by-name/gr/grsync/package.nix +++ b/pkgs/by-name/gr/grsync/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, dee, gtk3, intltool, libdbusmenu-gtk3, libunity, pkg-config, rsync, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchurl, + dee, + gtk3, + intltool, + libdbusmenu-gtk3, + libunity, + pkg-config, + rsync, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { version = "1.3.1"; diff --git a/pkgs/by-name/gr/grub2_pvgrub_image/package.nix b/pkgs/by-name/gr/grub2_pvgrub_image/package.nix index 20c54ec2cb966c..3aa240ed9feefb 100644 --- a/pkgs/by-name/gr/grub2_pvgrub_image/package.nix +++ b/pkgs/by-name/gr/grub2_pvgrub_image/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, grub2_xen }: +{ + lib, + stdenv, + grub2_xen, +}: let efiSystemsBuild = { @@ -10,35 +14,41 @@ let riscv64-linux.target = "riscv64"; }; -in ( - -stdenv.mkDerivation rec { - name = "pvgrub-image"; - - configs = ./configs; - - buildInputs = [ grub2_xen ]; - - buildCommand = '' - cp "${configs}"/* . - tar -cf memdisk.tar grub.cfg - # We include all modules except all_video.mod as otherwise grub will fail printing "no symbol table" - # if we include it. - grub-mkimage -O "${efiSystemsBuild.${stdenv.hostPlatform.system}.target}-xen" -c grub-bootstrap.cfg \ - -m memdisk.tar -o "grub-${efiSystemsBuild.${stdenv.hostPlatform.system}.target}-xen.bin" \ - $(ls "${grub2_xen}/lib/grub/${efiSystemsBuild.${stdenv.hostPlatform.system}.target}-xen/" |grep 'mod''$'|grep -v '^all_video\.mod''$') - mkdir -p "$out/lib/grub-xen" - cp "grub-${efiSystemsBuild.${stdenv.hostPlatform.system}.target}-xen.bin" $out/lib/grub-xen/ - ''; - - meta = with lib; { - description = "PvGrub image for use for booting PV Xen guests"; - - longDescription = '' - This package provides a PvGrub image for booting Para-Virtualized (PV) - Xen guests +in +( + + stdenv.mkDerivation rec { + name = "pvgrub-image"; + + configs = ./configs; + + buildInputs = [ grub2_xen ]; + + buildCommand = '' + cp "${configs}"/* . + tar -cf memdisk.tar grub.cfg + # We include all modules except all_video.mod as otherwise grub will fail printing "no symbol table" + # if we include it. + grub-mkimage -O "${ + efiSystemsBuild.${stdenv.hostPlatform.system}.target + }-xen" -c grub-bootstrap.cfg \ + -m memdisk.tar -o "grub-${efiSystemsBuild.${stdenv.hostPlatform.system}.target}-xen.bin" \ + $(ls "${grub2_xen}/lib/grub/${ + efiSystemsBuild.${stdenv.hostPlatform.system}.target + }-xen/" |grep 'mod''$'|grep -v '^all_video\.mod''$') + mkdir -p "$out/lib/grub-xen" + cp "grub-${efiSystemsBuild.${stdenv.hostPlatform.system}.target}-xen.bin" $out/lib/grub-xen/ + ''; + + meta = with lib; { + description = "PvGrub image for use for booting PV Xen guests"; + + longDescription = '' + This package provides a PvGrub image for booting Para-Virtualized (PV) + Xen guests ''; - platforms = platforms.gnu ++ platforms.linux; - }; -}) + platforms = platforms.gnu ++ platforms.linux; + }; + } +) diff --git a/pkgs/by-name/gr/grun/package.nix b/pkgs/by-name/gr/grun/package.nix index 145eba0a6539f6..0401b6d3a3328e 100644 --- a/pkgs/by-name/gr/grun/package.nix +++ b/pkgs/by-name/gr/grun/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, gtk2 -, pkg-config -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + gtk2, + pkg-config, + autoreconfHook, }: stdenv.mkDerivation { @@ -39,4 +40,3 @@ stdenv.mkDerivation { maintainers = with lib.maintainers; [ _3JlOy-PYCCKUi ]; }; } - diff --git a/pkgs/by-name/gr/gruvbox-dark-gtk/package.nix b/pkgs/by-name/gr/gruvbox-dark-gtk/package.nix index 28b55074afbb3f..e79cd65ee3849a 100644 --- a/pkgs/by-name/gr/gruvbox-dark-gtk/package.nix +++ b/pkgs/by-name/gr/gruvbox-dark-gtk/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "gruvbox-dark-gtk"; diff --git a/pkgs/by-name/gs/gsasl/package.nix b/pkgs/by-name/gs/gsasl/package.nix index 735a1a58fad6cb..714423ee273883 100644 --- a/pkgs/by-name/gs/gsasl/package.nix +++ b/pkgs/by-name/gs/gsasl/package.nix @@ -1,5 +1,10 @@ -{ fetchurl, lib, stdenv, libidn, libkrb5 -, testers +{ + fetchurl, + lib, + stdenv, + libidn, + libkrb5, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -11,7 +16,10 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-1FtWLhO9E7n8ILNy9LUyaXQM9iefg28JzhG50yvO4HU="; }; - buildInputs = [ libidn libkrb5 ]; + buildInputs = [ + libidn + libkrb5 + ]; configureFlags = [ "--with-gssapi-impl=mit" ]; diff --git a/pkgs/by-name/gs/gscan2pdf/package.nix b/pkgs/by-name/gs/gscan2pdf/package.nix index 68af433f672cb2..c1f780ae2cbc7f 100644 --- a/pkgs/by-name/gs/gscan2pdf/package.nix +++ b/pkgs/by-name/gs/gscan2pdf/package.nix @@ -1,10 +1,26 @@ -{ lib, fetchurl, perlPackages, wrapGAppsHook3, +{ + lib, + fetchurl, + perlPackages, + wrapGAppsHook3, # libs - librsvg, sane-backends, sane-frontends, + librsvg, + sane-backends, + sane-frontends, # runtime dependencies - imagemagick, libtiff, djvulibre, poppler_utils, ghostscript, unpaper, pdftk, + imagemagick, + libtiff, + djvulibre, + poppler_utils, + ghostscript, + unpaper, + pdftk, # test dependencies - xvfb-run, liberation_ttf, file, tesseract3 }: + xvfb-run, + liberation_ttf, + file, + tesseract3, +}: perlPackages.buildPerlPackage rec { pname = "gscan2pdf"; @@ -23,8 +39,12 @@ perlPackages.buildPerlPackage rec { nativeBuildInputs = [ wrapGAppsHook3 ]; buildInputs = - [ librsvg sane-backends sane-frontends ] ++ - (with perlPackages; [ + [ + librsvg + sane-backends + sane-frontends + ] + ++ (with perlPackages; [ Gtk3 Gtk3ImageView Gtk3SimpleList @@ -55,16 +75,18 @@ perlPackages.buildPerlPackage rec { SubOverride ]); - postPatch = let - fontSubstitute = "${liberation_ttf}/share/fonts/truetype/LiberationSans-Regular.ttf"; - in '' - # Required for the program to properly load its SVG assets - substituteInPlace bin/gscan2pdf \ - --replace "/usr/share" "$out/share" + postPatch = + let + fontSubstitute = "${liberation_ttf}/share/fonts/truetype/LiberationSans-Regular.ttf"; + in + '' + # Required for the program to properly load its SVG assets + substituteInPlace bin/gscan2pdf \ + --replace "/usr/share" "$out/share" - # Substitute the non-free Helvetica font in the tests - sed -i 's|-pointsize|-font ${fontSubstitute} -pointsize|g' t/*.t - ''; + # Substitute the non-free Helvetica font in the tests + sed -i 's|-pointsize|-font ${fontSubstitute} -pointsize|g' t/*.t + ''; postInstall = '' # Remove impurity @@ -86,23 +108,28 @@ perlPackages.buildPerlPackage rec { installTargets = [ "install" ]; - outputs = [ "out" "man" ]; - - nativeCheckInputs = [ - imagemagick - libtiff - djvulibre - poppler_utils - ghostscript - unpaper - pdftk - - xvfb-run - file - tesseract3 # tests are expecting tesseract 3.x precisely - ] ++ (with perlPackages; [ - TestPod - ]); + outputs = [ + "out" + "man" + ]; + + nativeCheckInputs = + [ + imagemagick + libtiff + djvulibre + poppler_utils + ghostscript + unpaper + pdftk + + xvfb-run + file + tesseract3 # tests are expecting tesseract 3.x precisely + ] + ++ (with perlPackages; [ + TestPod + ]); checkPhase = '' # Temporarily disable a dubiously failing test: diff --git a/pkgs/by-name/gs/gscreenshot/package.nix b/pkgs/by-name/gs/gscreenshot/package.nix index a686017da2489b..0a4a6f473bedb7 100644 --- a/pkgs/by-name/gs/gscreenshot/package.nix +++ b/pkgs/by-name/gs/gscreenshot/package.nix @@ -1,19 +1,20 @@ -{ lib -, fetchFromGitHub -, python3Packages -, gettext -, gobject-introspection -, gtk3 -, wrapGAppsHook3 -, xdg-utils -, scrot -, slop -, xclip -, grim -, slurp -, wl-clipboard -, waylandSupport ? true -, x11Support ? true +{ + lib, + fetchFromGitHub, + python3Packages, + gettext, + gobject-introspection, + gtk3, + wrapGAppsHook3, + xdg-utils, + scrot, + slop, + xclip, + grim, + slurp, + wl-clipboard, + waylandSupport ? true, + x11Support ? true, }: python3Packages.buildPythonApplication rec { @@ -33,27 +34,31 @@ python3Packages.buildPythonApplication rec { doCheck = false; nativeBuildInputs = [ wrapGAppsHook3 ]; - propagatedBuildInputs = [ - gettext - gobject-introspection - gtk3 - xdg-utils - ] ++ lib.optionals waylandSupport [ - # wayland deps - grim - slurp - wl-clipboard - ] ++ lib.optionals x11Support [ - # X11 deps - scrot - slop - xclip - python3Packages.xlib - ] ++ (with python3Packages; [ - pillow - pygobject3 - setuptools - ]); + propagatedBuildInputs = + [ + gettext + gobject-introspection + gtk3 + xdg-utils + ] + ++ lib.optionals waylandSupport [ + # wayland deps + grim + slurp + wl-clipboard + ] + ++ lib.optionals x11Support [ + # X11 deps + scrot + slop + xclip + python3Packages.xlib + ] + ++ (with python3Packages; [ + pillow + pygobject3 + setuptools + ]); patches = [ ./0001-Changing-paths-to-be-nix-compatible.patch ]; diff --git a/pkgs/by-name/gs/gsctl/package.nix b/pkgs/by-name/gs/gsctl/package.nix index bb30f7d1b63204..bdab9d5b6cbc0a 100644 --- a/pkgs/by-name/gs/gsctl/package.nix +++ b/pkgs/by-name/gs/gsctl/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, kubectl, stdenv }: +{ + lib, + buildGoModule, + fetchFromGitHub, + kubectl, + stdenv, +}: buildGoModule rec { pname = "gsctl"; @@ -23,7 +29,8 @@ buildGoModule rec { ''; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/giantswarm/gsctl/buildinfo.Version=${version}" ]; diff --git a/pkgs/by-name/gs/gsettings-desktop-schemas/package.nix b/pkgs/by-name/gs/gsettings-desktop-schemas/package.nix index eae3d40569a93c..7e7d51cffdf3e6 100644 --- a/pkgs/by-name/gs/gsettings-desktop-schemas/package.nix +++ b/pkgs/by-name/gs/gsettings-desktop-schemas/package.nix @@ -1,14 +1,18 @@ -{ lib, stdenv -, fetchurl -, pkg-config -, glib -, gobject-introspection -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, meson -, ninja +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + gobject-introspection, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + meson, + ninja, # just for passthru -, gnome + gnome, }: stdenv.mkDerivation rec { @@ -22,14 +26,16 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ - glib - meson - ninja - pkg-config - ] ++ lib.optionals withIntrospection [ - gobject-introspection - ]; + nativeBuildInputs = + [ + glib + meson + ninja + pkg-config + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + ]; mesonFlags = [ (lib.mesonBool "introspection" withIntrospection) diff --git a/pkgs/by-name/gs/gsimplecal/package.nix b/pkgs/by-name/gs/gsimplecal/package.nix index 224f2f359d779f..152585734f8ccd 100644 --- a/pkgs/by-name/gs/gsimplecal/package.nix +++ b/pkgs/by-name/gs/gsimplecal/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, automake, autoconf, pkg-config, gtk3 }: +{ + lib, + stdenv, + fetchFromGitHub, + automake, + autoconf, + pkg-config, + gtk3, +}: stdenv.mkDerivation rec { pname = "gsimplecal"; @@ -17,7 +25,11 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - nativeBuildInputs = [ pkg-config automake autoconf ]; + nativeBuildInputs = [ + pkg-config + automake + autoconf + ]; buildInputs = [ gtk3 ]; preConfigure = "./autogen.sh"; diff --git a/pkgs/by-name/gs/gsl-lite/package.nix b/pkgs/by-name/gs/gsl-lite/package.nix index 03fc5587f80a9b..dba428c51a0e89 100644 --- a/pkgs/by-name/gs/gsl-lite/package.nix +++ b/pkgs/by-name/gs/gsl-lite/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, ninja -, installCompatHeader ? false -, installLegacyHeaders ? false +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + ninja, + installCompatHeader ? false, + installLegacyHeaders ? false, }: stdenv.mkDerivation rec { @@ -27,15 +28,18 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; - cmakeFlags = lib.mapAttrsToList - (name: value: ''-DGSL_LITE_OPT_${name}:BOOL=${if value then "ON" else "OFF"}'') - { - INSTALL_COMPAT_HEADER = installCompatHeader; - INSTALL_LEGACY_HEADERS = installLegacyHeaders; - BUILD_TESTS = doCheck; - }; + cmakeFlags = + lib.mapAttrsToList (name: value: ''-DGSL_LITE_OPT_${name}:BOOL=${if value then "ON" else "OFF"}'') + { + INSTALL_COMPAT_HEADER = installCompatHeader; + INSTALL_LEGACY_HEADERS = installLegacyHeaders; + BUILD_TESTS = doCheck; + }; # Building tests is broken on Darwin. doCheck = !stdenv.hostPlatform.isDarwin; diff --git a/pkgs/by-name/gs/gsl/package.nix b/pkgs/by-name/gs/gsl/package.nix index aeb95476b2b65a..2a13306c6ee893 100644 --- a/pkgs/by-name/gs/gsl/package.nix +++ b/pkgs/by-name/gs/gsl/package.nix @@ -1,10 +1,18 @@ -{ fetchurl, fetchpatch, lib, stdenv }: +{ + fetchurl, + fetchpatch, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "gsl"; version = "2.8"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnu/gsl/${pname}-${version}.tar.gz"; @@ -19,9 +27,15 @@ stdenv.mkDerivation rec { }) ]; - preConfigure = if (lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11" && stdenv.hostPlatform.isDarwin) then '' - MACOSX_DEPLOYMENT_TARGET=10.16 - '' else null; + preConfigure = + if + (lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11" && stdenv.hostPlatform.isDarwin) + then + '' + MACOSX_DEPLOYMENT_TARGET=10.16 + '' + else + null; postInstall = '' moveToOutput bin/gsl-config "$dev" diff --git a/pkgs/by-name/gs/gsm/package.nix b/pkgs/by-name/gs/gsm/package.nix index a964c4e4bcb63e..44beb9398df12c 100644 --- a/pkgs/by-name/gs/gsm/package.nix +++ b/pkgs/by-name/gs/gsm/package.nix @@ -1,6 +1,9 @@ -{ lib, stdenv, fetchurl -, # Compile statically (support for packages that look for the static object) - staticSupport ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchurl, + # Compile statically (support for packages that look for the static object) + staticSupport ? stdenv.hostPlatform.isStatic, }: let @@ -17,23 +20,31 @@ stdenv.mkDerivation rec { sha256 = "sha256-8Acukfa7hah4svbb9KC3yFDE3rgEnVVMZTQLO/ad8Kw="; }; - patchPhase = '' - # Fix include directory - sed -e 's,$(GSM_INSTALL_ROOT)/inc,$(GSM_INSTALL_ROOT)/include/gsm,' -i Makefile - '' + optionalString (!staticSupport) ( - (if isDarwin then '' - # Build dylib on Darwin - sed -e 's,libgsm.a,libgsm.dylib,' -i Makefile - sed -e 's,$(AR) $(ARFLAGS) $(LIBGSM) $(GSM_OBJECTS),$(LD) -o $(LIBGSM) -dynamiclib -install_name $(GSM_INSTALL_ROOT)/$(LIBGSM) $(GSM_OBJECTS) -lc,' -i Makefile - '' else '' - # Build ELF shared object by default - sed -e 's,libgsm.a,libgsm.so,' -i Makefile - sed -e 's/$(AR) $(ARFLAGS) $(LIBGSM) $(GSM_OBJECTS)/$(LD) -shared -Wl,-soname,libgsm.so -o $(LIBGSM) $(GSM_OBJECTS) -lc/' -i Makefile - '') + '' - # Remove line that is unused when building shared libraries - sed -e 's,$(RANLIB) $(LIBGSM),,' -i Makefile + patchPhase = '' - ); + # Fix include directory + sed -e 's,$(GSM_INSTALL_ROOT)/inc,$(GSM_INSTALL_ROOT)/include/gsm,' -i Makefile + '' + + optionalString (!staticSupport) ( + ( + if isDarwin then + '' + # Build dylib on Darwin + sed -e 's,libgsm.a,libgsm.dylib,' -i Makefile + sed -e 's,$(AR) $(ARFLAGS) $(LIBGSM) $(GSM_OBJECTS),$(LD) -o $(LIBGSM) -dynamiclib -install_name $(GSM_INSTALL_ROOT)/$(LIBGSM) $(GSM_OBJECTS) -lc,' -i Makefile + '' + else + '' + # Build ELF shared object by default + sed -e 's,libgsm.a,libgsm.so,' -i Makefile + sed -e 's/$(AR) $(ARFLAGS) $(LIBGSM) $(GSM_OBJECTS)/$(LD) -shared -Wl,-soname,libgsm.so -o $(LIBGSM) $(GSM_OBJECTS) -lc/' -i Makefile + '' + ) + + '' + # Remove line that is unused when building shared libraries + sed -e 's,$(RANLIB) $(LIBGSM),,' -i Makefile + '' + ); preBuild = '' makeFlagsArray+=(CC="$CC") @@ -50,9 +61,12 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Lossy speech compression codec"; - homepage = "https://www.quut.com/gsm/"; - license = licenses.bsd2; - maintainers = with maintainers; [ codyopel raskin ]; - platforms = platforms.unix; + homepage = "https://www.quut.com/gsm/"; + license = licenses.bsd2; + maintainers = with maintainers; [ + codyopel + raskin + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/gs/gsmartcontrol/package.nix b/pkgs/by-name/gs/gsmartcontrol/package.nix index c405f7a90751a0..36f616d94cc125 100644 --- a/pkgs/by-name/gs/gsmartcontrol/package.nix +++ b/pkgs/by-name/gs/gsmartcontrol/package.nix @@ -1,4 +1,16 @@ -{ fetchurl, lib, stdenv, smartmontools, autoreconfHook, gettext, gtkmm3, pkg-config, wrapGAppsHook3, pcre-cpp, adwaita-icon-theme }: +{ + fetchurl, + lib, + stdenv, + smartmontools, + autoreconfHook, + gettext, + gtkmm3, + pkg-config, + wrapGAppsHook3, + pcre-cpp, + adwaita-icon-theme, +}: stdenv.mkDerivation rec { pname = "gsmartcontrol"; @@ -17,8 +29,17 @@ stdenv.mkDerivation rec { substituteInPlace data/org.gsmartcontrol.policy --replace "/usr/sbin" $out/bin ''; - nativeBuildInputs = [ autoreconfHook gettext pkg-config wrapGAppsHook3 ]; - buildInputs = [ gtkmm3 pcre-cpp adwaita-icon-theme ]; + nativeBuildInputs = [ + autoreconfHook + gettext + pkg-config + wrapGAppsHook3 + ]; + buildInputs = [ + gtkmm3 + pcre-cpp + adwaita-icon-theme + ]; enableParallelBuilding = true; @@ -41,7 +62,7 @@ stdenv.mkDerivation rec { ''; homepage = "https://gsmartcontrol.shaduri.dev/"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [qknight]; + maintainers = with lib.maintainers; [ qknight ]; platforms = with lib.platforms; linux; }; } diff --git a/pkgs/by-name/gs/gsoap/package.nix b/pkgs/by-name/gs/gsoap/package.nix index 1a40b87c01aafa..27bdec91f2905b 100644 --- a/pkgs/by-name/gs/gsoap/package.nix +++ b/pkgs/by-name/gs/gsoap/package.nix @@ -1,10 +1,23 @@ -{ lib, stdenv, fetchurl, autoreconfHook, unzip, m4, bison, flex, openssl, zlib, buildPackages }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + unzip, + m4, + bison, + flex, + openssl, + zlib, + buildPackages, +}: let majorVersion = "2.8"; isCross = stdenv.hostPlatform != stdenv.buildPlatform; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "gsoap"; version = "${majorVersion}.108"; @@ -13,8 +26,17 @@ in stdenv.mkDerivation rec { sha256 = "0x58bwlclk7frv03kg8bp0pm7zl784samvbzskrnr7dl5v866nvl"; }; - buildInputs = [ openssl zlib ]; - nativeBuildInputs = [ autoreconfHook bison flex m4 unzip ]; + buildInputs = [ + openssl + zlib + ]; + nativeBuildInputs = [ + autoreconfHook + bison + flex + m4 + unzip + ]; # Parallel building doesn't work as of 2.8.49 enableParallelBuilding = false; diff --git a/pkgs/by-name/gs/gsocket/package.nix b/pkgs/by-name/gs/gsocket/package.nix index a25a8345086b35..02f50b5c024cf3 100644 --- a/pkgs/by-name/gs/gsocket/package.nix +++ b/pkgs/by-name/gs/gsocket/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + openssl, +}: stdenv.mkDerivation rec { pname = "gsocket"; diff --git a/pkgs/by-name/gs/gsound/package.nix b/pkgs/by-name/gs/gsound/package.nix index e588a7adca624c..96eb2b0454ecda 100644 --- a/pkgs/by-name/gs/gsound/package.nix +++ b/pkgs/by-name/gs/gsound/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, vala, libcanberra, gobject-introspection, libtool, gnome, meson, ninja }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + vala, + libcanberra, + gobject-introspection, + libtool, + gnome, + meson, + ninja, +}: stdenv.mkDerivation rec { pname = "gsound"; @@ -11,8 +24,18 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ pkg-config meson ninja gobject-introspection libtool vala ]; - buildInputs = [ glib libcanberra ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + gobject-introspection + libtool + vala + ]; + buildInputs = [ + glib + libcanberra + ]; passthru = { updateScript = gnome.updateScript { diff --git a/pkgs/by-name/gs/gspeech/package.nix b/pkgs/by-name/gs/gspeech/package.nix index 2a253c735e37e7..f4e133064e796f 100644 --- a/pkgs/by-name/gs/gspeech/package.nix +++ b/pkgs/by-name/gs/gspeech/package.nix @@ -1,21 +1,22 @@ -{ lib -, fetchFromGitHub -, python3 -, gtk3 -, wrapGAppsHook3 -, glibcLocales -, gobject-introspection -, gettext -, pango -, gdk-pixbuf -, librsvg -, atk -, libnotify -, libappindicator-gtk3 -, gst_all_1 -, makeWrapper -, picotts -, sox +{ + lib, + fetchFromGitHub, + python3, + gtk3, + wrapGAppsHook3, + glibcLocales, + gobject-introspection, + gettext, + pango, + gdk-pixbuf, + librsvg, + atk, + libnotify, + libappindicator-gtk3, + gst_all_1, + makeWrapper, + picotts, + sox, }: python3.pkgs.buildPythonApplication rec { @@ -61,8 +62,18 @@ python3.pkgs.buildPythonApplication rec { ''; postFixup = '' - wrapProgram $out/bin/gspeech --prefix PATH : ${lib.makeBinPath [ picotts sox ]} - wrapProgram $out/bin/gspeech-cli --prefix PATH : ${lib.makeBinPath [ picotts sox ]} + wrapProgram $out/bin/gspeech --prefix PATH : ${ + lib.makeBinPath [ + picotts + sox + ] + } + wrapProgram $out/bin/gspeech-cli --prefix PATH : ${ + lib.makeBinPath [ + picotts + sox + ] + } ''; strictDeps = false; @@ -75,4 +86,3 @@ python3.pkgs.buildPythonApplication rec { platforms = platforms.unix; }; } - diff --git a/pkgs/by-name/gs/gspell/package.nix b/pkgs/by-name/gs/gspell/package.nix index d8725ed90bdc2c..6f318a9f790d38 100644 --- a/pkgs/by-name/gs/gspell/package.nix +++ b/pkgs/by-name/gs/gspell/package.nix @@ -34,18 +34,20 @@ stdenv.mkDerivation rec { sha256 = "ZOodjp7cHCW0WpIOgNr2dVnRhm/81/hDL+z+ptD+iJc="; }; - nativeBuildInputs = [ - docbook-xsl-nons - glib # glib-mkenums - gobject-introspection - gtk-doc - meson - ninja - pkg-config - vala - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + docbook-xsl-nons + glib # glib-mkenums + gobject-introspection + gtk-doc + meson + ninja + pkg-config + vala + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ gtk3 diff --git a/pkgs/by-name/gs/gss/package.nix b/pkgs/by-name/gs/gss/package.nix index 1271c52a4a8cb0..d111ded3286610 100644 --- a/pkgs/by-name/gs/gss/package.nix +++ b/pkgs/by-name/gs/gss/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, withShishi ? !stdenv.hostPlatform.isDarwin -, shishi +{ + lib, + stdenv, + fetchurl, + withShishi ? !stdenv.hostPlatform.isDarwin, + shishi, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gs/gst/package.nix b/pkgs/by-name/gs/gst/package.nix index c282da41c1ebc9..ac906d3003f9af 100644 --- a/pkgs/by-name/gs/gst/package.nix +++ b/pkgs/by-name/gs/gst/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, git -, ghq +{ + lib, + buildGoModule, + fetchFromGitHub, + git, + ghq, }: buildGoModule rec { @@ -26,7 +27,9 @@ buildGoModule rec { ]; ldflags = [ - "-s" "-w" "-X=main.Version=${version}" + "-s" + "-w" + "-X=main.Version=${version}" ]; doInstallCheck = true; diff --git a/pkgs/by-name/gs/gst123/package.nix b/pkgs/by-name/gs/gst123/package.nix index d988983dcae5f6..46b2fa3008f78b 100644 --- a/pkgs/by-name/gs/gst123/package.nix +++ b/pkgs/by-name/gs/gst123/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, wrapGAppsHook3 -, gst_all_1 -, gtk3 -, ncurses +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + wrapGAppsHook3, + gst_all_1, + gtk3, + ncurses, }: stdenv.mkDerivation (finalAttrs: { @@ -26,17 +27,19 @@ stdenv.mkDerivation (finalAttrs: { wrapGAppsHook3 ]; - buildInputs = [ - gtk3 - ncurses - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-good - gst-plugins-bad - gst-plugins-ugly - gst-libav - ]); + buildInputs = + [ + gtk3 + ncurses + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + gst-plugins-ugly + gst-libav + ]); enableParallelBuilding = true; diff --git a/pkgs/by-name/gt/gt/package.nix b/pkgs/by-name/gt/gt/package.nix index 964566b57d06c0..c5cb602f414f4f 100644 --- a/pkgs/by-name/gt/gt/package.nix +++ b/pkgs/by-name/gt/gt/package.nix @@ -1,6 +1,13 @@ -{ stdenv, lib, fetchFromGitHub, cmake, bash-completion, pkg-config, libconfig -, asciidoc -, libusbgx +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + bash-completion, + pkg-config, + libconfig, + asciidoc, + libusbgx, }: stdenv.mkDerivation (finalAttrs: { pname = "gt"; @@ -19,9 +26,17 @@ stdenv.mkDerivation (finalAttrs: { cmakeFlagsArray+=("-DBASH_COMPLETION_COMPLETIONSDIR=$out/share/bash-completions/completions") ''; - nativeBuildInputs = [ cmake pkg-config asciidoc ]; + nativeBuildInputs = [ + cmake + pkg-config + asciidoc + ]; - buildInputs = [ bash-completion libconfig libusbgx]; + buildInputs = [ + bash-completion + libconfig + libusbgx + ]; meta = { description = "Linux command line tool for setting up USB gadgets using configfs"; diff --git a/pkgs/by-name/gt/gt5/package.nix b/pkgs/by-name/gt/gt5/package.nix index 68b0e319716212..3c2121a304a686 100644 --- a/pkgs/by-name/gt/gt5/package.nix +++ b/pkgs/by-name/gt/gt5/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "gt5"; diff --git a/pkgs/by-name/gt/gtdialog/package.nix b/pkgs/by-name/gt/gtdialog/package.nix index 6a09d8cbe9e266..ef32b2bde612c9 100644 --- a/pkgs/by-name/gt/gtdialog/package.nix +++ b/pkgs/by-name/gt/gtdialog/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, cdk, unzip, gtk2, glib, ncurses, pkg-config }: +{ + lib, + stdenv, + fetchurl, + cdk, + unzip, + gtk2, + glib, + ncurses, + pkg-config, +}: stdenv.mkDerivation rec { pname = "gtdialog"; @@ -9,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-0+WBr1IZIhQjxOsKO/yuXjaTRWPObhMdGqgibcpXGtI="; }; - nativeBuildInputs = [ pkg-config unzip ]; + nativeBuildInputs = [ + pkg-config + unzip + ]; buildInputs = [ cdk gtk2 diff --git a/pkgs/by-name/gt/gtest/package.nix b/pkgs/by-name/gt/gtest/package.nix index f9465c4e356e21..db81b1f9579233 100644 --- a/pkgs/by-name/gt/gtest/package.nix +++ b/pkgs/by-name/gt/gtest/package.nix @@ -1,31 +1,37 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -# Enable C++17 support -# https://github.com/google/googletest/issues/3081 -# Projects that require a higher standard can override this package. -# For an example why that may be necessary, see: -# https://github.com/mhx/dwarfs/issues/188#issuecomment-1907574427 -# Setting this to `null` does not pass any flags to set this. -, cxx_standard ? ( - if ( - (stdenv.cc.isGNU && (lib.versionOlder stdenv.cc.version "11.0")) - || - (stdenv.cc.isClang && (lib.versionOlder stdenv.cc.version "16.0")) - ) - then "17" - else null - ) -, static ? stdenv.hostPlatform.isStatic, +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + # Enable C++17 support + # https://github.com/google/googletest/issues/3081 + # Projects that require a higher standard can override this package. + # For an example why that may be necessary, see: + # https://github.com/mhx/dwarfs/issues/188#issuecomment-1907574427 + # Setting this to `null` does not pass any flags to set this. + cxx_standard ? ( + if + ( + (stdenv.cc.isGNU && (lib.versionOlder stdenv.cc.version "11.0")) + || (stdenv.cc.isClang && (lib.versionOlder stdenv.cc.version "16.0")) + ) + then + "17" + else + null + ), + static ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { pname = "gtest"; version = "1.15.2"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "google"; @@ -38,14 +44,19 @@ stdenv.mkDerivation rec { ./fix-cmake-config-includedir.patch ]; - nativeBuildInputs = [ cmake ninja ]; - - cmakeFlags = [ - "-DBUILD_SHARED_LIBS=${if static then "OFF" else "ON"}" - ] ++ lib.optionals (cxx_standard != null) [ - "-DCMAKE_CXX_STANDARD=${cxx_standard}" + nativeBuildInputs = [ + cmake + ninja ]; + cmakeFlags = + [ + "-DBUILD_SHARED_LIBS=${if static then "OFF" else "ON"}" + ] + ++ lib.optionals (cxx_standard != null) [ + "-DCMAKE_CXX_STANDARD=${cxx_standard}" + ]; + meta = with lib; { description = "Google's framework for writing C++ tests"; homepage = "https://github.com/google/googletest"; diff --git a/pkgs/by-name/gt/gtg/package.nix b/pkgs/by-name/gt/gtg/package.nix index d990a2004a2dc4..ea9a67cfd2844a 100644 --- a/pkgs/by-name/gt/gtg/package.nix +++ b/pkgs/by-name/gt/gtg/package.nix @@ -1,19 +1,20 @@ -{ lib -, fetchFromGitHub -, meson -, python3Packages -, ninja -, gtk3 -, wrapGAppsHook3 -, glib -, gtksourceview4 -, itstool -, gettext -, pango -, gdk-pixbuf -, libsecret -, gobject-introspection -, xvfb-run +{ + lib, + fetchFromGitHub, + meson, + python3Packages, + ninja, + gtk3, + wrapGAppsHook3, + glib, + gtksourceview4, + itstool, + gettext, + pango, + gdk-pixbuf, + libsecret, + gobject-introspection, + xvfb-run, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/gt/gthree/package.nix b/pkgs/by-name/gt/gthree/package.nix index c94a3ae15d1586..f4fb6033ddd4ba 100644 --- a/pkgs/by-name/gt/gthree/package.nix +++ b/pkgs/by-name/gt/gthree/package.nix @@ -1,25 +1,31 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, ninja -, meson -, pkg-config -, gobject-introspection -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_43 -, glib -, gtk3 -, graphene -, libepoxy -, json-glib +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + ninja, + meson, + pkg-config, + gobject-introspection, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_43, + glib, + gtk3, + graphene, + libepoxy, + json-glib, }: stdenv.mkDerivation rec { pname = "gthree"; version = "0.9.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitHub { owner = "alexlarsson"; diff --git a/pkgs/by-name/gt/gthumb/package.nix b/pkgs/by-name/gt/gthumb/package.nix index 4424c109711ba0..5cc49bec9d2bb1 100644 --- a/pkgs/by-name/gt/gthumb/package.nix +++ b/pkgs/by-name/gt/gthumb/package.nix @@ -1,37 +1,39 @@ -{ stdenv -, lib -, fetchurl -, gnome -, pkg-config -, meson -, ninja -, adwaita-icon-theme -, exiv2 -, libheif -, libjpeg -, libtiff -, gst_all_1 -, libraw -, libsoup_2_4 -, libsecret -, glib -, gtk3 -, gsettings-desktop-schemas -, libchamplain -, librsvg -, libwebp -, libX11 -, json-glib -, lcms2 -, bison -, flex -, clutter-gtk -, wrapGAppsHook3 -, shared-mime-info -, python3 -, desktop-file-utils -, itstool -, withWebservices ? true, webkitgtk_4_0 +{ + stdenv, + lib, + fetchurl, + gnome, + pkg-config, + meson, + ninja, + adwaita-icon-theme, + exiv2, + libheif, + libjpeg, + libtiff, + gst_all_1, + libraw, + libsoup_2_4, + libsecret, + glib, + gtk3, + gsettings-desktop-schemas, + libchamplain, + librsvg, + libwebp, + libX11, + json-glib, + lcms2, + bison, + flex, + clutter-gtk, + wrapGAppsHook3, + shared-mime-info, + python3, + desktop-file-utils, + itstool, + withWebservices ? true, + webkitgtk_4_0, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gt/gti/package.nix b/pkgs/by-name/gt/gti/package.nix index 9e396f33e6a1e8..faf0dcfc846801 100644 --- a/pkgs/by-name/gt/gti/package.nix +++ b/pkgs/by-name/gt/gti/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gt/gtimelog/package.nix b/pkgs/by-name/gt/gtimelog/package.nix index f2abb96e3fea96..bc63fab151933a 100644 --- a/pkgs/by-name/gt/gtimelog/package.nix +++ b/pkgs/by-name/gt/gtimelog/package.nix @@ -1,5 +1,13 @@ -{ lib, fetchFromGitHub, python3Packages, wrapGAppsHook3 -, glibcLocales, gobject-introspection, gtk3, libsoup_3, libsecret +{ + lib, + fetchFromGitHub, + python3Packages, + wrapGAppsHook3, + glibcLocales, + gobject-introspection, + gtk3, + libsoup_3, + libsecret, }: python3Packages.buildPythonApplication rec { @@ -18,8 +26,16 @@ python3Packages.buildPythonApplication rec { setuptools-scm ]; - nativeBuildInputs = [ wrapGAppsHook3 gobject-introspection ]; - buildInputs = [ glibcLocales gtk3 libsoup_3 libsecret ]; + nativeBuildInputs = [ + wrapGAppsHook3 + gobject-introspection + ]; + buildInputs = [ + glibcLocales + gtk3 + libsoup_3 + libsecret + ]; propagatedBuildInputs = with python3Packages; [ pygobject3 ]; diff --git a/pkgs/by-name/gt/gtk-doc/package.nix b/pkgs/by-name/gt/gtk-doc/package.nix index b21bdfc500daaf..ad8c58cc3de171 100644 --- a/pkgs/by-name/gt/gtk-doc/package.nix +++ b/pkgs/by-name/gt/gtk-doc/package.nix @@ -1,15 +1,17 @@ -{ lib -, fetchFromGitLab -, meson -, ninja -, pkg-config -, python3 -, docbook_xml_dtd_43 -, docbook-xsl-nons -, libxslt -, gettext -, gnome -, withDblatex ? false, dblatex +{ + lib, + fetchFromGitLab, + meson, + ninja, + pkg-config, + python3, + docbook_xml_dtd_43, + docbook-xsl-nons, + libxslt, + gettext, + gnome, + withDblatex ? false, + dblatex, }: python3.pkgs.buildPythonApplication rec { @@ -52,13 +54,15 @@ python3.pkgs.buildPythonApplication rec { libxslt # for xsltproc ]; - buildInputs = [ - docbook_xml_dtd_43 - docbook-xsl-nons - libxslt - ] ++ lib.optionals withDblatex [ - dblatex - ]; + buildInputs = + [ + docbook_xml_dtd_43 + docbook-xsl-nons + libxslt + ] + ++ lib.optionals withDblatex [ + dblatex + ]; pythonPath = with python3.pkgs; [ pygments # Needed for https://gitlab.gnome.org/GNOME/gtk-doc/blob/GTK_DOC_1_32/meson.build#L42 diff --git a/pkgs/by-name/gt/gtk-frdp/package.nix b/pkgs/by-name/gt/gtk-frdp/package.nix index 22524445cf08d8..94d558c9ff7b37 100644 --- a/pkgs/by-name/gt/gtk-frdp/package.nix +++ b/pkgs/by-name/gt/gtk-frdp/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, vala -, gobject-introspection -, glib -, gtk3 -, freerdp3 -, fuse3 -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + vala, + gobject-introspection, + glib, + gtk3, + freerdp3, + fuse3, + unstableGitUpdater, }: stdenv.mkDerivation rec { @@ -47,10 +48,12 @@ stdenv.mkDerivation rec { }; }; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-DTARGET_OS_IPHONE=0" - "-DTARGET_OS_WATCH=0" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-DTARGET_OS_IPHONE=0" + "-DTARGET_OS_WATCH=0" + ] + ); meta = with lib; { homepage = "https://gitlab.gnome.org/GNOME/gtk-frdp"; diff --git a/pkgs/by-name/gt/gtk-layer-shell/package.nix b/pkgs/by-name/gt/gtk-layer-shell/package.nix index c977de1942789a..079f525bd7127c 100644 --- a/pkgs/by-name/gt/gtk-layer-shell/package.nix +++ b/pkgs/by-name/gt/gtk-layer-shell/package.nix @@ -1,24 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_43 -, wayland-scanner -, wayland -, gtk3 -, gobject-introspection -, vala +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_43, + wayland-scanner, + wayland, + gtk3, + gobject-introspection, + vala, }: stdenv.mkDerivation (finalAttrs: { pname = "gtk-layer-shell"; version = "0.9.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "devdoc"; # for demo src = fetchFromGitHub { @@ -62,7 +67,10 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "gtk-layer-demo"; homepage = "https://github.com/wmww/gtk-layer-shell"; license = licenses.lgpl3Plus; - maintainers = with maintainers; [ eonpatapon donovanglover ]; + maintainers = with maintainers; [ + eonpatapon + donovanglover + ]; platforms = platforms.linux; }; }) diff --git a/pkgs/by-name/gt/gtk-mac-bundler/package.nix b/pkgs/by-name/gt/gtk-mac-bundler/package.nix index a94534a9cb32f3..e0abdfd6fb6cdc 100644 --- a/pkgs/by-name/gt/gtk-mac-bundler/package.nix +++ b/pkgs/by-name/gt/gtk-mac-bundler/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "gtk-mac-bundler"; diff --git a/pkgs/by-name/gt/gtk-server/package.nix b/pkgs/by-name/gt/gtk-server/package.nix index d97c94fbd885ae..01535ac8810339 100644 --- a/pkgs/by-name/gt/gtk-server/package.nix +++ b/pkgs/by-name/gt/gtk-server/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, glib -, gtk3 -, libffcall -, pkg-config -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + glib, + gtk3, + libffcall, + pkg-config, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -21,8 +22,15 @@ stdenv.mkDerivation rec { cd src ''; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; - buildInputs = [ libffcall glib gtk3 ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; + buildInputs = [ + libffcall + glib + gtk3 + ]; configureOptions = [ "--with-gtk3" ]; diff --git a/pkgs/by-name/gt/gtk-session-lock/package.nix b/pkgs/by-name/gt/gtk-session-lock/package.nix index e8bafe1a06df77..f84b82e5bf28cf 100644 --- a/pkgs/by-name/gt/gtk-session-lock/package.nix +++ b/pkgs/by-name/gt/gtk-session-lock/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, gobject-introspection -, vala -, gtk3 -, wayland-scanner -, wayland +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + gobject-introspection, + vala, + gtk3, + wayland-scanner, + wayland, }: stdenv.mkDerivation (finalAttrs: { @@ -22,7 +23,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-SHKAYmdev08oRB/V6UpfSFqYwplF59IaNSOoWcACPig="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ meson diff --git a/pkgs/by-name/gt/gtk-sharp-beans/package.nix b/pkgs/by-name/gt/gtk-sharp-beans/package.nix index 69ef71f1506fda..c01f39ef028ca7 100644 --- a/pkgs/by-name/gt/gtk-sharp-beans/package.nix +++ b/pkgs/by-name/gt/gtk-sharp-beans/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, which, pkg-config, mono, gtk-sharp-2_0, gio-sharp }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + which, + pkg-config, + mono, + gtk-sharp-2_0, + gio-sharp, +}: stdenv.mkDerivation rec { pname = "gtk-sharp-beans"; @@ -12,8 +22,16 @@ stdenv.mkDerivation rec { sha256 = "04sylwdllb6gazzs2m4jjfn14mil9l3cny2q0xf0zkhczzih6ah1"; }; - nativeBuildInputs = [ pkg-config autoreconfHook which ]; - buildInputs = [ mono gtk-sharp-2_0 gio-sharp ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + which + ]; + buildInputs = [ + mono + gtk-sharp-2_0 + gio-sharp + ]; dontStrip = true; diff --git a/pkgs/by-name/gt/gtk-vnc/package.nix b/pkgs/by-name/gt/gtk-vnc/package.nix index 6ffed3604c6429..c459a6b4030ebd 100644 --- a/pkgs/by-name/gt/gtk-vnc/package.nix +++ b/pkgs/by-name/gt/gtk-vnc/package.nix @@ -1,32 +1,38 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, gobject-introspection -, gnutls -, cairo -, glib -, pkg-config -, cyrus_sasl -, pulseaudioSupport ? stdenv.hostPlatform.isLinux -, libpulseaudio -, libgcrypt -, gtk3 -, vala -, gettext -, perl -, python3 -, gnome -, gdk-pixbuf -, zlib +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + gobject-introspection, + gnutls, + cairo, + glib, + pkg-config, + cyrus_sasl, + pulseaudioSupport ? stdenv.hostPlatform.isLinux, + libpulseaudio, + libgcrypt, + gtk3, + vala, + gettext, + perl, + python3, + gnome, + gdk-pixbuf, + zlib, }: stdenv.mkDerivation rec { pname = "gtk-vnc"; version = "1.3.1"; - outputs = [ "out" "bin" "man" "dev" ]; + outputs = [ + "out" + "bin" + "man" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -44,18 +50,20 @@ stdenv.mkDerivation rec { python3 ]; - buildInputs = [ - gnutls - cairo - gdk-pixbuf - zlib - glib - libgcrypt - cyrus_sasl - gtk3 - ] ++ lib.optionals pulseaudioSupport [ - libpulseaudio - ]; + buildInputs = + [ + gnutls + cairo + gdk-pixbuf + zlib + glib + libgcrypt + cyrus_sasl + gtk3 + ] + ++ lib.optionals pulseaudioSupport [ + libpulseaudio + ]; mesonFlags = lib.optionals (!pulseaudioSupport) [ "-Dpulseaudio=disabled" @@ -72,7 +80,10 @@ stdenv.mkDerivation rec { description = "GTK VNC widget"; homepage = "https://gitlab.gnome.org/GNOME/gtk-vnc"; license = licenses.lgpl2Plus; - maintainers = with maintainers; [ raskin offline ]; + maintainers = with maintainers; [ + raskin + offline + ]; platforms = platforms.unix; mainProgram = "gvnccapture"; }; diff --git a/pkgs/by-name/gt/gtk4-layer-shell/package.nix b/pkgs/by-name/gt/gtk4-layer-shell/package.nix index f4024eafcaf75d..c98a8dc764cb08 100644 --- a/pkgs/by-name/gt/gtk4-layer-shell/package.nix +++ b/pkgs/by-name/gt/gtk4-layer-shell/package.nix @@ -1,25 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_43 -, wayland-protocols -, wayland-scanner -, wayland -, gtk4 -, gobject-introspection -, vala +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_43, + wayland-protocols, + wayland-scanner, + wayland, + gtk4, + gobject-introspection, + vala, }: stdenv.mkDerivation (finalAttrs: { pname = "gtk4-layer-shell"; version = "1.0.4"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "devdoc"; src = fetchFromGitHub { diff --git a/pkgs/by-name/gt/gtk_engines/package.nix b/pkgs/by-name/gt/gtk_engines/package.nix index d722143b210e71..a4d9e10bc48638 100644 --- a/pkgs/by-name/gt/gtk_engines/package.nix +++ b/pkgs/by-name/gt/gtk_engines/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, intltool, gtk2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + gtk2, +}: stdenv.mkDerivation rec { pname = "gtk-engines"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "1db65pb0j0mijmswrvpgkdabilqd23x22d95hp5kwxvcramq1dhm"; }; - nativeBuildInputs = [ pkg-config intltool ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; buildInputs = [ gtk2 ]; meta = { diff --git a/pkgs/by-name/gt/gtkclipblock/package.nix b/pkgs/by-name/gt/gtkclipblock/package.nix index a2489aed3990bf..c6cce92c1fa38b 100644 --- a/pkgs/by-name/gt/gtkclipblock/package.nix +++ b/pkgs/by-name/gt/gtkclipblock/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, cmake -, ninja -, pkg-config -, gtk2 -, gtk3 -, gtk4 +{ + lib, + stdenv, + fetchFromGitHub, + meson, + cmake, + ninja, + pkg-config, + gtk2, + gtk3, + gtk4, }: let @@ -31,9 +32,18 @@ in stdenv.mkDerivation { inherit pname version src; - nativeBuildInputs = [ meson cmake ninja pkg-config ]; + nativeBuildInputs = [ + meson + cmake + ninja + pkg-config + ]; - buildInputs = [ gtk2 gtk3 gtk4 ]; + buildInputs = [ + gtk2 + gtk3 + gtk4 + ]; postPatch = '' substituteInPlace subprojects/funchook-helper/subprojects/funchook/CMakeLists.txt \ diff --git a/pkgs/by-name/gt/gtkdatabox/package.nix b/pkgs/by-name/gt/gtkdatabox/package.nix index 0cc510ce7313e6..b34788dc889fa7 100644 --- a/pkgs/by-name/gt/gtkdatabox/package.nix +++ b/pkgs/by-name/gt/gtkdatabox/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gtk3 -, pango -, cairo +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk3, + pango, + cairo, }: stdenv.mkDerivation rec { @@ -18,7 +19,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ gtk3 pango cairo ]; + propagatedBuildInputs = [ + gtk3 + pango + cairo + ]; meta = { description = "GTK widget for displaying large amounts of numerical data"; diff --git a/pkgs/by-name/gt/gtkdialog/package.nix b/pkgs/by-name/gt/gtkdialog/package.nix index 378cdb5705d249..4de4f9929fb922 100644 --- a/pkgs/by-name/gt/gtkdialog/package.nix +++ b/pkgs/by-name/gt/gtkdialog/package.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchurl, fetchpatch, gtk2, pkg-config }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + gtk2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "gtkdialog"; diff --git a/pkgs/by-name/gt/gtkextra/package.nix b/pkgs/by-name/gt/gtkextra/package.nix index 66516add6d9cfe..cdaa88e9816185 100644 --- a/pkgs/by-name/gt/gtkextra/package.nix +++ b/pkgs/by-name/gt/gtkextra/package.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, gobject-introspection -, file -, gtk2 -, glib -, cairo -, atk -, pango -, libtiff -, libpng -, libjpeg +{ + stdenv, + lib, + fetchurl, + pkg-config, + gobject-introspection, + file, + gtk2, + glib, + cairo, + atk, + pango, + libtiff, + libpng, + libjpeg, }: stdenv.mkDerivation rec { @@ -28,9 +29,21 @@ stdenv.mkDerivation rec { --replace "/usr/bin/file" "${file}/bin/file" ''; - nativeBuildInputs = [ gobject-introspection pkg-config ]; + nativeBuildInputs = [ + gobject-introspection + pkg-config + ]; - buildInputs = [ gtk2 glib cairo atk pango libtiff libpng libjpeg ]; + buildInputs = [ + gtk2 + glib + cairo + atk + pango + libtiff + libpng + libjpeg + ]; meta = with lib; { homepage = "https://gtkextra.sourceforge.net/"; diff --git a/pkgs/by-name/gt/gtkgnutella/package.nix b/pkgs/by-name/gt/gtkgnutella/package.nix index 5fe7834e2d3294..5cd2eeb1680a62 100644 --- a/pkgs/by-name/gt/gtkgnutella/package.nix +++ b/pkgs/by-name/gt/gtkgnutella/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, bison -, desktop-file-utils -, gettext -, pkg-config -, glib -, gtk2 -, libxml2 -, libbfd -, zlib -, gnutls -, enableGui ? true +{ + lib, + stdenv, + fetchFromGitHub, + bison, + desktop-file-utils, + gettext, + pkg-config, + glib, + gtk2, + libxml2, + libbfd, + zlib, + gnutls, + enableGui ? true, }: stdenv.mkDerivation (finalAttrs: { @@ -31,24 +32,28 @@ stdenv.mkDerivation (finalAttrs: { gettext pkg-config ]; - buildInputs = [ - glib - gnutls - libbfd - libxml2 - zlib - ] ++ lib.optionals enableGui [ - gtk2 - ]; + buildInputs = + [ + glib + gnutls + libbfd + libxml2 + zlib + ] + ++ lib.optionals enableGui [ + gtk2 + ]; configureScript = "./build.sh"; - configureFlags = [ - "--configure-only" - # See https://sourceforge.net/p/gtk-gnutella/bugs/555/ - "--disable-malloc" - ] ++ lib.optionals (!enableGui) [ - "--topless" - ]; + configureFlags = + [ + "--configure-only" + # See https://sourceforge.net/p/gtk-gnutella/bugs/555/ + "--disable-malloc" + ] + ++ lib.optionals (!enableGui) [ + "--topless" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/gt/gtkhash/package.nix b/pkgs/by-name/gt/gtkhash/package.nix index 1b14cf302da9f8..e28674b5cd70d3 100644 --- a/pkgs/by-name/gt/gtkhash/package.nix +++ b/pkgs/by-name/gt/gtkhash/package.nix @@ -1,17 +1,18 @@ -{ lib -, fetchFromGitHub -, stdenv -, meson -, ninja -, cmake -, pkg-config -, wrapGAppsHook3 -, gtk3 -, glib -, openssl -, nettle -, libb2 -, libgcrypt +{ + lib, + fetchFromGitHub, + stdenv, + meson, + ninja, + cmake, + pkg-config, + wrapGAppsHook3, + gtk3, + glib, + openssl, + nettle, + libb2, + libgcrypt, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gt/gtkimageview/package.nix b/pkgs/by-name/gt/gtkimageview/package.nix index d3a79cf0e9d4c2..1399a6201b8552 100644 --- a/pkgs/by-name/gt/gtkimageview/package.nix +++ b/pkgs/by-name/gt/gtkimageview/package.nix @@ -1,4 +1,10 @@ -{ fetchurl, lib, stdenv, pkg-config, gtk2 }: +{ + fetchurl, + lib, + stdenv, + pkg-config, + gtk2, +}: stdenv.mkDerivation rec { pname = "gtkimageview"; diff --git a/pkgs/by-name/gt/gtklp/package.nix b/pkgs/by-name/gt/gtklp/package.nix index 29b019292e6229..f77150eb5c5c5f 100644 --- a/pkgs/by-name/gt/gtklp/package.nix +++ b/pkgs/by-name/gt/gtklp/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, autoreconfHook -, cups -, fetchurl -, gettext -, glib -, gtk2 -, libtool -, openssl -, pkg-config +{ + lib, + stdenv, + autoreconfHook, + cups, + fetchurl, + gettext, + glib, + gtk2, + libtool, + openssl, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { @@ -35,7 +36,11 @@ stdenv.mkDerivation (finalAttrs: { openssl ]; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; strictDeps = true; diff --git a/pkgs/by-name/gt/gtkradiant/package.nix b/pkgs/by-name/gt/gtkradiant/package.nix index 7c91181e06fac0..009c9c416e934e 100644 --- a/pkgs/by-name/gt/gtkradiant/package.nix +++ b/pkgs/by-name/gt/gtkradiant/package.nix @@ -1,8 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, fetchsvn -, scons, pkg-config, python3 -, glib, libxml2, gtk2, libGLU, gnome2 -, runCommand, writeScriptBin, runtimeShell -, makeDesktopItem, copyDesktopItems +{ + lib, + stdenv, + fetchFromGitHub, + fetchsvn, + scons, + pkg-config, + python3, + glib, + libxml2, + gtk2, + libGLU, + gnome2, + runCommand, + writeScriptBin, + runtimeShell, + makeDesktopItem, + copyDesktopItems, }: let @@ -136,7 +149,7 @@ let rev = 53; sha256 = "sha256-IQ12fEKnq0cJxef+ddvTXcwM8lQ8nlUoMJy81XJ7ANY="; }; - packs = runCommand "gtkradiant-packs" {} '' + packs = runCommand "gtkradiant-packs" { } '' mkdir -p $out ln -s ${q3Pack} $out/Q3Pack ln -s ${urtPack} $out/UrTPack @@ -181,9 +194,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = let - python = python3.withPackages (ps: with ps; [ - urllib3 - ]); + python = python3.withPackages ( + ps: with ps; [ + urllib3 + ] + ); svn = writeScriptBin "svn" '' #!${runtimeShell} -e if [ "$1" = checkout ]; then @@ -200,7 +215,8 @@ stdenv.mkDerivation rec { exit 1 fi ''; - in [ + in + [ scons pkg-config python @@ -208,20 +224,28 @@ stdenv.mkDerivation rec { copyDesktopItems ]; - buildInputs = [ glib libxml2 gtk2 libGLU gnome2.gtkglext ]; + buildInputs = [ + glib + libxml2 + gtk2 + libGLU + gnome2.gtkglext + ]; enableParallelBuilding = true; - desktopItems = [ (makeDesktopItem { - name = "gtkradiant"; - exec = "gtkradiant"; - desktopName = "GtkRadiant"; - comment = meta.description; - categories = [ "Development" ]; - icon = "gtkradiant"; - # includes its own splash screen - startupNotify = false; - }) ]; + desktopItems = [ + (makeDesktopItem { + name = "gtkradiant"; + exec = "gtkradiant"; + desktopName = "GtkRadiant"; + comment = meta.description; + categories = [ "Development" ]; + icon = "gtkradiant"; + # includes its own splash screen + startupNotify = false; + }) + ]; postInstall = '' mkdir -p $out/{bin,lib} @@ -248,7 +272,11 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Level editor for idTech games"; homepage = "https://icculus.org/gtkradiant/"; - license = with licenses; [ gpl2Only bsdOriginal lgpl21Only ]; + license = with licenses; [ + gpl2Only + bsdOriginal + lgpl21Only + ]; maintainers = with maintainers; [ astro ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/gt/gtksheet/package.nix b/pkgs/by-name/gt/gtksheet/package.nix index 25f5a370693d7b..cf325855cdc647 100644 --- a/pkgs/by-name/gt/gtksheet/package.nix +++ b/pkgs/by-name/gt/gtksheet/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, gobject-introspection -, gtk-doc -, pkg-config -, atk -, cairo -, glade -, gtk3 -, pango +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gobject-introspection, + gtk-doc, + pkg-config, + atk, + cairo, + glade, + gtk3, + pango, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gt/gtkspellmm/package.nix b/pkgs/by-name/gt/gtkspellmm/package.nix index 641ebbf9f08db6..80b65a5d70656f 100644 --- a/pkgs/by-name/gt/gtkspellmm/package.nix +++ b/pkgs/by-name/gt/gtkspellmm/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchurl -, pkg-config -, gtk3, glib, glibmm, gtkmm3, gtkspell3 +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk3, + glib, + glibmm, + gtkmm3, + gtkspell3, }: stdenv.mkDerivation rec { @@ -8,8 +15,7 @@ stdenv.mkDerivation rec { version = "3.0.5"; src = fetchurl { - url = "mirror://sourceforge/project/gtkspell/gtkspellmm/" + - "${pname}-${version}.tar.xz"; + url = "mirror://sourceforge/project/gtkspell/gtkspellmm/" + "${pname}-${version}.tar.xz"; sha256 = "0i8mxwyfv5mskachafa4qlh315q0cfph7s66s1s34nffadbmm1sv"; }; @@ -19,7 +25,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - gtk3 glib glibmm gtkmm3 + gtk3 + glib + glibmm + gtkmm3 ]; meta = with lib; { diff --git a/pkgs/by-name/gt/gtkterm/package.nix b/pkgs/by-name/gt/gtkterm/package.nix index 5ec61bb70f5032..0b11db2e5566b3 100644 --- a/pkgs/by-name/gt/gtkterm/package.nix +++ b/pkgs/by-name/gt/gtkterm/package.nix @@ -1,4 +1,16 @@ -{ stdenv, lib, fetchFromGitHub, meson, ninja, pkg-config, gtk3, vte, libgudev, wrapGAppsHook3, pcre2 }: +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + gtk3, + vte, + libgudev, + wrapGAppsHook3, + pcre2, +}: stdenv.mkDerivation rec { pname = "gtkterm"; diff --git a/pkgs/by-name/gt/gtkwave/package.nix b/pkgs/by-name/gt/gtkwave/package.nix index 9028d3a802887a..791c20365117e7 100644 --- a/pkgs/by-name/gt/gtkwave/package.nix +++ b/pkgs/by-name/gt/gtkwave/package.nix @@ -1,18 +1,19 @@ -{ bzip2 -, fetchurl -, glib -, gperf -, gtk3 -, gtk-mac-integration -, judy -, lib -, pkg-config -, stdenv -, tcl -, tk -, wrapGAppsHook3 -, xz -, desktopToDarwinBundle +{ + bzip2, + fetchurl, + glib, + gperf, + gtk3, + gtk-mac-integration, + judy, + lib, + pkg-config, + stdenv, + tcl, + tk, + wrapGAppsHook3, + xz, + desktopToDarwinBundle, }: stdenv.mkDerivation rec { @@ -24,13 +25,24 @@ stdenv.mkDerivation rec { sha256 = "sha256-VKpFeI1tUq+2WcOu8zWq/eDvLImQp3cPjqpk5X8ic0Y="; }; - nativeBuildInputs = [ - pkg-config wrapGAppsHook3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - desktopToDarwinBundle - ]; - buildInputs = [ bzip2 glib gperf gtk3 judy tcl tk xz ] - ++ lib.optional stdenv.hostPlatform.isDarwin gtk-mac-integration; + nativeBuildInputs = + [ + pkg-config + wrapGAppsHook3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + desktopToDarwinBundle + ]; + buildInputs = [ + bzip2 + glib + gperf + gtk3 + judy + tcl + tk + xz + ] ++ lib.optional stdenv.hostPlatform.isDarwin gtk-mac-integration; # fix compilation under Darwin # remove these patches upon next release @@ -59,7 +71,11 @@ stdenv.mkDerivation rec { description = "VCD/Waveform viewer for Unix and Win32"; homepage = "https://gtkwave.sourceforge.net"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ thoughtpolice jiegec jleightcap ]; + maintainers = with lib.maintainers; [ + thoughtpolice + jiegec + jleightcap + ]; platforms = lib.platforms.linux ++ lib.platforms.darwin; }; } diff --git a/pkgs/by-name/gt/gtop/package.nix b/pkgs/by-name/gt/gtop/package.nix index 5d882740e1a0ec..331c95b9b98fba 100644 --- a/pkgs/by-name/gt/gtop/package.nix +++ b/pkgs/by-name/gt/gtop/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/gt/gtranslator/package.nix b/pkgs/by-name/gt/gtranslator/package.nix index 7ba08063c9b6d5..60e5fa4a32f0f2 100644 --- a/pkgs/by-name/gt/gtranslator/package.nix +++ b/pkgs/by-name/gt/gtranslator/package.nix @@ -1,24 +1,25 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, itstool -, gettext -, desktop-file-utils -, wrapGAppsHook4 -, libxml2 -, libadwaita -, libgda6 -, libsoup_3 -, libspelling -, json-glib -, glib -, gtk4 -, gtksourceview5 -, gnome -, gsettings-desktop-schemas +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + itstool, + gettext, + desktop-file-utils, + wrapGAppsHook4, + libxml2, + libadwaita, + libgda6, + libsoup_3, + libspelling, + json-glib, + glib, + gtk4, + gtksourceview5, + gnome, + gsettings-desktop-schemas, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gt/gtree/package.nix b/pkgs/by-name/gt/gtree/package.nix index 4c862d2184fcef..5f50a00132ad27 100644 --- a/pkgs/by-name/gt/gtree/package.nix +++ b/pkgs/by-name/gt/gtree/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, gtree +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + gtree, }: buildGoModule rec { diff --git a/pkgs/by-name/gt/gts/package.nix b/pkgs/by-name/gt/gts/package.nix index 9586c3be7b784e..db962cb7fab305 100644 --- a/pkgs/by-name/gt/gts/package.nix +++ b/pkgs/by-name/gt/gts/package.nix @@ -1,11 +1,23 @@ -{ fetchurl, lib, stdenv, pkg-config, autoreconfHook, gettext, glib, buildPackages }: - +{ + fetchurl, + lib, + stdenv, + pkg-config, + autoreconfHook, + gettext, + glib, + buildPackages, +}: stdenv.mkDerivation rec { pname = "gts"; version = "0.7.6"; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; src = fetchurl { url = "mirror://sourceforge/gts/${pname}-${version}.tar.gz"; @@ -15,7 +27,7 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config autoreconfHook - glib # required to satisfy AM_PATH_GLIB_2_0 + glib # required to satisfy AM_PATH_GLIB_2_0 ]; buildInputs = [ gettext ]; propagatedBuildInputs = [ glib ]; diff --git a/pkgs/by-name/gt/gtt/package.nix b/pkgs/by-name/gt/gtt/package.nix index 8f3e116b532425..fb52b0b94ae180 100644 --- a/pkgs/by-name/gt/gtt/package.nix +++ b/pkgs/by-name/gt/gtt/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, pkg-config -, alsa-lib -, wl-clipboard -, xclip +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + alsa-lib, + wl-clipboard, + xclip, }: buildGoModule rec { @@ -30,7 +31,10 @@ buildGoModule rec { wl-clipboard ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Google Translate TUI (Originally). Now support Apertium, Argos, Bing, ChatGPT, DeepL, Google, Reverso"; diff --git a/pkgs/by-name/gt/gtypist/package.nix b/pkgs/by-name/gt/gtypist/package.nix index 4d9fe630ca42d2..59628e7a64d542 100644 --- a/pkgs/by-name/gt/gtypist/package.nix +++ b/pkgs/by-name/gt/gtypist/package.nix @@ -1,4 +1,13 @@ -{lib, stdenv, fetchurl, makeWrapper, libiconv, ncurses, perl, fortune}: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + libiconv, + ncurses, + perl, + fortune, +}: stdenv.mkDerivation rec { pname = "gtypist"; @@ -12,12 +21,15 @@ stdenv.mkDerivation rec { CFLAGS = "-std=gnu89"; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ ncurses perl fortune ] - ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; + buildInputs = [ + ncurses + perl + fortune + ] ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; preFixup = '' - wrapProgram "$out/bin/typefortune" \ - --prefix PATH : "${fortune}/bin" \ + wrapProgram "$out/bin/typefortune" \ + --prefix PATH : "${fortune}/bin" \ ''; meta = with lib; { diff --git a/pkgs/by-name/gu/guacamole-client/package.nix b/pkgs/by-name/gu/guacamole-client/package.nix index cc02021804366d..41af451583b31d 100644 --- a/pkgs/by-name/gu/guacamole-client/package.nix +++ b/pkgs/by-name/gu/guacamole-client/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchurl +{ + lib, + stdenvNoCC, + fetchurl, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -29,7 +30,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { homepage = "https://guacamole.apache.org/"; license = lib.licenses.asl20; maintainers = [ lib.maintainers.drupol ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; sourceProvenance = [ lib.sourceTypes.binaryBytecode ]; diff --git a/pkgs/by-name/gu/guacamole-server/package.nix b/pkgs/by-name/gu/guacamole-server/package.nix index 42bf481e252aca..a146225be312d6 100644 --- a/pkgs/by-name/gu/guacamole-server/package.nix +++ b/pkgs/by-name/gu/guacamole-server/package.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch2 -, pkg-config -, autoPatchelfHook -, autoreconfHook -, cairo -, ffmpeg-headless -, freerdp -, libjpeg_turbo -, libpng -, libossp_uuid -, libpulseaudio -, libssh2 -, libtelnet -, libvncserver -, libvorbis -, libwebp -, libwebsockets -, makeBinaryWrapper -, openssl -, pango -, perl -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch2, + pkg-config, + autoPatchelfHook, + autoreconfHook, + cairo, + ffmpeg-headless, + freerdp, + libjpeg_turbo, + libpng, + libossp_uuid, + libpulseaudio, + libssh2, + libtelnet, + libvncserver, + libvorbis, + libwebp, + libwebsockets, + makeBinaryWrapper, + openssl, + pango, + perl, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { @@ -100,6 +101,9 @@ stdenv.mkDerivation (finalAttrs: { license = lib.licenses.asl20; mainProgram = "guacd"; maintainers = [ lib.maintainers.drupol ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; }) diff --git a/pkgs/by-name/gu/guake/package.nix b/pkgs/by-name/gu/guake/package.nix index 44131d3c87b5b0..f31b1a143441ec 100644 --- a/pkgs/by-name/gu/guake/package.nix +++ b/pkgs/by-name/gu/guake/package.nix @@ -1,19 +1,20 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, python311 -, python311Packages -, glibcLocales -, gobject-introspection -, wrapGAppsHook3 -, gtk3 -, keybinder3 -, libnotify -, libutempter -, vte -, libwnck -, dconf -, nixosTests +{ + lib, + fetchFromGitHub, + fetchpatch, + python311, + python311Packages, + glibcLocales, + gobject-introspection, + wrapGAppsHook3, + gtk3, + keybinder3, + libnotify, + libutempter, + vte, + libwnck, + dconf, + nixosTests, }: python311Packages.buildPythonApplication rec { @@ -97,7 +98,10 @@ python311Packages.buildPythonApplication rec { description = "Drop-down terminal for GNOME"; homepage = "http://guake-project.org"; license = licenses.gpl2Plus; - maintainers = [ maintainers.msteen maintainers.heywoodlh ]; + maintainers = [ + maintainers.msteen + maintainers.heywoodlh + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/gu/gubbi-font/package.nix b/pkgs/by-name/gu/gubbi-font/package.nix index 0b6b42493fe35f..dbc5109a318e27 100644 --- a/pkgs/by-name/gu/gubbi-font/package.nix +++ b/pkgs/by-name/gu/gubbi-font/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fontforge }: +{ + lib, + stdenv, + fetchFromGitHub, + fontforge, +}: stdenv.mkDerivation rec { pname = "gubbi-font"; diff --git a/pkgs/by-name/gu/gucci/package.nix b/pkgs/by-name/gu/gucci/package.nix index c4e0ef81503dad..82cc016de143ff 100644 --- a/pkgs/by-name/gu/gucci/package.nix +++ b/pkgs/by-name/gu/gucci/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, gucci }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + gucci, +}: buildGoModule rec { pname = "gucci"; @@ -13,7 +19,11 @@ buildGoModule rec { vendorHash = "sha256-/4OnbtxxhXQnmSV6UbjgzXdL7szhL9rKiG5BR8FsyqI="; - ldflags = [ "-s" "-w" "-X main.AppVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.AppVersion=${version}" + ]; passthru.tests.version = testers.testVersion { package = gucci; diff --git a/pkgs/by-name/gu/gucharmap/package.nix b/pkgs/by-name/gu/gucharmap/package.nix index f6fd425d434bd5..38e2cd6f86b11e 100644 --- a/pkgs/by-name/gu/gucharmap/package.nix +++ b/pkgs/by-name/gu/gucharmap/package.nix @@ -1,38 +1,39 @@ -{ stdenv -, lib -, intltool -, fetchFromGitLab -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, python3 -, gtk3 -, pcre2 -, glib -, desktop-file-utils -, gtk-doc -, wrapGAppsHook3 -, itstool -, libxml2 -, yelp-tools -, docbook_xsl -, docbook_xml_dtd_412 -, gsettings-desktop-schemas -, unzip -, unicode-character-database -, unihan-database -, runCommand -, symlinkJoin -, gobject-introspection -, gitUpdater +{ + stdenv, + lib, + intltool, + fetchFromGitLab, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + python3, + gtk3, + pcre2, + glib, + desktop-file-utils, + gtk-doc, + wrapGAppsHook3, + itstool, + libxml2, + yelp-tools, + docbook_xsl, + docbook_xml_dtd_412, + gsettings-desktop-schemas, + unzip, + unicode-character-database, + unihan-database, + runCommand, + symlinkJoin, + gobject-introspection, + gitUpdater, }: let # TODO: make upstream patch allowing to use the uncompressed file, # preferably from XDG_DATA_DIRS. # https://gitlab.gnome.org/GNOME/gucharmap/issues/13 - unihanZip = runCommand "unihan" {} '' + unihanZip = runCommand "unihan" { } '' mkdir -p $out/share/unicode ln -s ${unihan-database.src} $out/share/unicode/Unihan.zip ''; @@ -43,11 +44,17 @@ let unicode-character-database ]; }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "gucharmap"; version = "16.0.1"; - outputs = [ "out" "lib" "dev" "devdoc" ]; + outputs = [ + "out" + "lib" + "dev" + "devdoc" + ]; src = fetchFromGitLab { domain = "gitlab.gnome.org"; @@ -58,25 +65,27 @@ in stdenv.mkDerivation (finalAttrs: { }; strictDeps = true; - nativeBuildInputs = [ - meson - ninja - pkg-config - python3 - wrapGAppsHook3 - unzip - intltool - itstool - gtk-doc - docbook_xsl - docbook_xml_dtd_412 - yelp-tools - libxml2 - desktop-file-utils - gobject-introspection - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + python3 + wrapGAppsHook3 + unzip + intltool + itstool + gtk-doc + docbook_xsl + docbook_xml_dtd_412 + yelp-tools + libxml2 + desktop-file-utils + gobject-introspection + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ gtk3 diff --git a/pkgs/by-name/gu/guetzli/package.nix b/pkgs/by-name/gu/guetzli/package.nix index 945416e3f03d98..2ecb32068b3e45 100644 --- a/pkgs/by-name/gu/guetzli/package.nix +++ b/pkgs/by-name/gu/guetzli/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, libpng, fetchFromGitHub, pkg-config }: +{ + lib, + stdenv, + libpng, + fetchFromGitHub, + pkg-config, +}: let version = "1.0.1"; in diff --git a/pkgs/by-name/gu/guff/package.nix b/pkgs/by-name/gu/guff/package.nix index c9043bcf827227..17be43aba7bde4 100644 --- a/pkgs/by-name/gu/guff/package.nix +++ b/pkgs/by-name/gu/guff/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "guff"; @@ -15,7 +19,7 @@ stdenv.mkDerivation rec { doCheck = true; - meta = with lib; { + meta = with lib; { description = "Plot device"; homepage = "https://github.com/silentbicycle/guff"; license = licenses.isc; diff --git a/pkgs/by-name/gu/guile-aspell/package.nix b/pkgs/by-name/gu/guile-aspell/package.nix index cf5e51e2540b77..dbb87edb5d037c 100644 --- a/pkgs/by-name/gu/guile-aspell/package.nix +++ b/pkgs/by-name/gu/guile-aspell/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, guile -, autoreconfHook -, pkg-config -, aspell -, texinfo +{ + lib, + stdenv, + fetchFromGitHub, + guile, + autoreconfHook, + pkg-config, + aspell, + texinfo, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gu/guile-avahi/package.nix b/pkgs/by-name/gu/guile-avahi/package.nix index 3a8c9be42998f7..0a305451958e20 100644 --- a/pkgs/by-name/gu/guile-avahi/package.nix +++ b/pkgs/by-name/gu/guile-avahi/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchgit -, avahi -, gmp -, buildPackages -, autoreconfHook -, pkg-config -, texinfo -, guile +{ + stdenv, + lib, + fetchgit, + avahi, + gmp, + buildPackages, + autoreconfHook, + pkg-config, + texinfo, + guile, }: stdenv.mkDerivation rec { @@ -22,9 +23,17 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ autoreconfHook guile pkg-config texinfo ]; + nativeBuildInputs = [ + autoreconfHook + guile + pkg-config + texinfo + ]; buildInputs = [ guile ]; - propagatedBuildInputs = [ avahi gmp ]; + propagatedBuildInputs = [ + avahi + gmp + ]; doCheck = true; makeFlags = [ "GUILE_AUTO_COMPILE=0" ]; @@ -38,4 +47,3 @@ stdenv.mkDerivation rec { platforms = guile.meta.platforms; }; } - diff --git a/pkgs/by-name/gu/guile-cairo/package.nix b/pkgs/by-name/gu/guile-cairo/package.nix index 3ed308de46b1e1..de1c3da398d455 100644 --- a/pkgs/by-name/gu/guile-cairo/package.nix +++ b/pkgs/by-name/gu/guile-cairo/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, cairo -, expat -, guile -, guile-lib -, pkg-config +{ + lib, + stdenv, + fetchurl, + cairo, + expat, + guile, + guile-lib, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gu/guile-chickadee/package.nix b/pkgs/by-name/gu/guile-chickadee/package.nix index aa34a0d36df9b4..f7a59f14b798a8 100644 --- a/pkgs/by-name/gu/guile-chickadee/package.nix +++ b/pkgs/by-name/gu/guile-chickadee/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, makeWrapper -, testers -, guile -, pkg-config -, texinfo -, freetype -, libjpeg_turbo -, libpng -, libvorbis -, mpg123 -, openal -, readline -, guile-opengl -, guile-sdl2 -, guile-chickadee +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + makeWrapper, + testers, + guile, + pkg-config, + texinfo, + freetype, + libjpeg_turbo, + libpng, + libvorbis, + mpg123, + openal, + readline, + guile-opengl, + guile-sdl2, + guile-chickadee, }: stdenv.mkDerivation (finalAttrs: { pname = "guile-chickadee"; diff --git a/pkgs/by-name/gu/guile-commonmark/package.nix b/pkgs/by-name/gu/guile-commonmark/package.nix index aa5b2ee5ce7fe1..24be48cb091072 100644 --- a/pkgs/by-name/gu/guile-commonmark/package.nix +++ b/pkgs/by-name/gu/guile-commonmark/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, guile -, pkg-config -, texinfo +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + guile, + pkg-config, + texinfo, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/gu/guile-config/package.nix b/pkgs/by-name/gu/guile-config/package.nix index d0fe7be0c87ed9..7881a5edf88131 100644 --- a/pkgs/by-name/gu/guile-config/package.nix +++ b/pkgs/by-name/gu/guile-config/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitLab, autoreconfHook, pkg-config, texinfo, guile }: +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + texinfo, + guile, +}: stdenv.mkDerivation rec { pname = "guile-config"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { hash = "sha256-n4ukGCyIx5G1ITfKSqS6FGJ6dnDBsyxXKSFNi81E4Gg="; }; - nativeBuildInputs = [ autoreconfHook pkg-config texinfo ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + texinfo + ]; buildInputs = [ guile ]; diff --git a/pkgs/by-name/gu/guile-fibers/package.nix b/pkgs/by-name/gu/guile-fibers/package.nix index c5b9b07a61244a..a2a6468941ddb7 100644 --- a/pkgs/by-name/gu/guile-fibers/package.nix +++ b/pkgs/by-name/gu/guile-fibers/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, guile -, libevent -, pkg-config -, texinfo +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + guile, + libevent, + pkg-config, + texinfo, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gu/guile-gcrypt/package.nix b/pkgs/by-name/gu/guile-gcrypt/package.nix index 3b6aa220ae923f..8c461558ed5559 100644 --- a/pkgs/by-name/gu/guile-gcrypt/package.nix +++ b/pkgs/by-name/gu/guile-gcrypt/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitea -, guile -, libgcrypt -, autoreconfHook -, pkg-config -, texinfo +{ + lib, + stdenv, + fetchFromGitea, + guile, + libgcrypt, + autoreconfHook, + pkg-config, + texinfo, }: stdenv.mkDerivation rec { @@ -22,7 +23,11 @@ stdenv.mkDerivation rec { strictDeps = true; nativeBuildInputs = [ - autoreconfHook guile libgcrypt pkg-config texinfo + autoreconfHook + guile + libgcrypt + pkg-config + texinfo ]; buildInputs = [ guile diff --git a/pkgs/by-name/gu/guile-goblins/package.nix b/pkgs/by-name/gu/guile-goblins/package.nix index f34d5878f8ab8f..50168628b89500 100644 --- a/pkgs/by-name/gu/guile-goblins/package.nix +++ b/pkgs/by-name/gu/guile-goblins/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, guile -, guile-fibers -, guile-gcrypt -, guile-gnutls -, texinfo -, pkg-config +{ + lib, + stdenv, + fetchurl, + guile, + guile-fibers, + guile-gcrypt, + guile-gnutls, + texinfo, + pkg-config, }: stdenv.mkDerivation rec { pname = "guile-goblins"; @@ -18,8 +19,17 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ guile pkg-config texinfo ]; - buildInputs = [ guile guile-fibers guile-gcrypt guile-gnutls ]; + nativeBuildInputs = [ + guile + pkg-config + texinfo + ]; + buildInputs = [ + guile + guile-fibers + guile-gcrypt + guile-gnutls + ]; makeFlags = [ "GUILE_AUTO_COMPILE=0" ]; # tests hang on darwin, and fail randomly on aarch64-linux on ofborg diff --git a/pkgs/by-name/gu/guile-hall/package.nix b/pkgs/by-name/gu/guile-hall/package.nix index 3c57fb4da8ce03..4a7ae9bef5d6f5 100644 --- a/pkgs/by-name/gu/guile-hall/package.nix +++ b/pkgs/by-name/gu/guile-hall/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitLab, autoreconfHook, pkg-config -, texinfo, makeWrapper, guile, guile-config }: +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + texinfo, + makeWrapper, + guile, + guile-config, +}: stdenv.mkDerivation rec { pname = "guile-hall"; @@ -12,9 +21,17 @@ stdenv.mkDerivation rec { hash = "sha256-TUCN8kW44X6iGbSJURurcz/Tc2eCH1xgmXH1sMOMOXs="; }; - nativeBuildInputs = [ autoreconfHook pkg-config texinfo makeWrapper ]; - - buildInputs = [ guile guile-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + texinfo + makeWrapper + ]; + + buildInputs = [ + guile + guile-config + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/gu/guile-json/package.nix b/pkgs/by-name/gu/guile-json/package.nix index cb34e22e62379e..2955c87522b640 100644 --- a/pkgs/by-name/gu/guile-json/package.nix +++ b/pkgs/by-name/gu/guile-json/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, guile -, texinfo -, pkg-config +{ + lib, + stdenv, + fetchurl, + guile, + texinfo, + pkg-config, }: stdenv.mkDerivation rec { @@ -17,7 +18,9 @@ stdenv.mkDerivation rec { strictDeps = true; nativeBuildInputs = [ - guile pkg-config texinfo + guile + pkg-config + texinfo ]; buildInputs = [ guile diff --git a/pkgs/by-name/gu/guile-lib/package.nix b/pkgs/by-name/gu/guile-lib/package.nix index 4d32bbb0461424..d6d51c9878a886 100644 --- a/pkgs/by-name/gu/guile-lib/package.nix +++ b/pkgs/by-name/gu/guile-lib/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, guile -, pkg-config -, texinfo +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + guile, + pkg-config, + texinfo, }: stdenv.mkDerivation rec { @@ -53,7 +54,10 @@ stdenv.mkDerivation rec { for Guile". ''; license = licenses.gpl3Plus; - maintainers = with maintainers; [ vyp foo-dogsquared ]; + maintainers = with maintainers; [ + vyp + foo-dogsquared + ]; platforms = guile.meta.platforms; }; } diff --git a/pkgs/by-name/gu/guile-lzlib/package.nix b/pkgs/by-name/gu/guile-lzlib/package.nix index a465849470b04d..faefb69bc26519 100644 --- a/pkgs/by-name/gu/guile-lzlib/package.nix +++ b/pkgs/by-name/gu/guile-lzlib/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, guile -, pkg-config -, texinfo -, lzlib +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + guile, + pkg-config, + texinfo, + lzlib, }: stdenv.mkDerivation rec { @@ -19,8 +20,16 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ autoreconfHook guile pkg-config texinfo ]; - propagatedBuildInputs = [ guile lzlib ]; + nativeBuildInputs = [ + autoreconfHook + guile + pkg-config + texinfo + ]; + propagatedBuildInputs = [ + guile + lzlib + ]; makeFlags = [ "GUILE_AUTO_COMPILE=0" ]; diff --git a/pkgs/by-name/gu/guile-lzma/package.nix b/pkgs/by-name/gu/guile-lzma/package.nix index 9f7b941f068f8e..2149ed42275937 100644 --- a/pkgs/by-name/gu/guile-lzma/package.nix +++ b/pkgs/by-name/gu/guile-lzma/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchurl -, xz -, pkg-config -, guile -, scheme-bytestructures +{ + stdenv, + lib, + fetchurl, + xz, + pkg-config, + guile, + scheme-bytestructures, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gu/guile-ncurses/package.nix b/pkgs/by-name/gu/guile-ncurses/package.nix index e20da1d9f98c7e..16272d27580560 100644 --- a/pkgs/by-name/gu/guile-ncurses/package.nix +++ b/pkgs/by-name/gu/guile-ncurses/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, guile -, libffi -, ncurses +{ + lib, + stdenv, + fetchurl, + pkg-config, + guile, + libffi, + ncurses, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gu/guile-opengl/package.nix b/pkgs/by-name/gu/guile-opengl/package.nix index efbb23cf71f5fe..f0ffc658634699 100644 --- a/pkgs/by-name/gu/guile-opengl/package.nix +++ b/pkgs/by-name/gu/guile-opengl/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, guile -, pkg-config +{ + lib, + stdenv, + fetchurl, + guile, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gu/guile-quickcheck/package.nix b/pkgs/by-name/gu/guile-quickcheck/package.nix index 2c3c0f9c4b9bf3..2c77b99ca18dd2 100644 --- a/pkgs/by-name/gu/guile-quickcheck/package.nix +++ b/pkgs/by-name/gu/guile-quickcheck/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, guile +{ + stdenv, + lib, + fetchurl, + pkg-config, + guile, }: stdenv.mkDerivation rec { @@ -15,7 +16,10 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ guile pkg-config ]; + nativeBuildInputs = [ + guile + pkg-config + ]; buildInputs = [ guile ]; doCheck = !stdenv.hostPlatform.isDarwin; diff --git a/pkgs/by-name/gu/guile-reader/package.nix b/pkgs/by-name/gu/guile-reader/package.nix index 17c9cfe9da8c86..1f2dae51f886c1 100644 --- a/pkgs/by-name/gu/guile-reader/package.nix +++ b/pkgs/by-name/gu/guile-reader/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, gperf -, guile -, guile-lib -, libffi -, pkg-config +{ + lib, + stdenv, + fetchurl, + gperf, + guile, + guile-lib, + libffi, + pkg-config, }: stdenv.mkDerivation rec { @@ -27,11 +28,13 @@ stdenv.mkDerivation rec { libffi ]; - env = { - GUILE_SITE = "${guile-lib}/${guile.siteDir}"; - } // lib.optionalAttrs stdenv.cc.isClang { - NIX_CFLAGS_COMPILE = "-Wno-error=implicit-function-declaration"; - }; + env = + { + GUILE_SITE = "${guile-lib}/${guile.siteDir}"; + } + // lib.optionalAttrs stdenv.cc.isClang { + NIX_CFLAGS_COMPILE = "-Wno-error=implicit-function-declaration"; + }; configureFlags = [ "--with-guilemoduledir=$(out)/${guile.siteDir}" ]; @@ -39,13 +42,13 @@ stdenv.mkDerivation rec { homepage = "https://www.nongnu.org/guile-reader/"; description = "Simple framework for building readers for GNU Guile"; longDescription = '' - Guile-Reader is a simple framework for building readers for GNU Guile. + Guile-Reader is a simple framework for building readers for GNU Guile. - The idea is to make it easy to build procedures that extend Guile's read - procedure. Readers supporting various syntax variants can easily be - written, possibly by re-using existing "token readers" of a standard - Scheme readers. For example, it is used to implement Skribilo's - R5RS-derived document syntax. + The idea is to make it easy to build procedures that extend Guile's read + procedure. Readers supporting various syntax variants can easily be + written, possibly by re-using existing "token readers" of a standard + Scheme readers. For example, it is used to implement Skribilo's + R5RS-derived document syntax. ''; license = licenses.lgpl3Plus; maintainers = with maintainers; [ ]; diff --git a/pkgs/by-name/gu/guile-sdl/package.nix b/pkgs/by-name/gu/guile-sdl/package.nix index b996e6d84b4733..e0dd9a28bb0d45 100644 --- a/pkgs/by-name/gu/guile-sdl/package.nix +++ b/pkgs/by-name/gu/guile-sdl/package.nix @@ -59,8 +59,7 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.gnu.org/software/guile-sdl/"; description = "Guile bindings for SDL"; license = lib.licenses.gpl3Plus; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ ]); inherit (guile.meta) platforms; }; }) diff --git a/pkgs/by-name/gu/guile-sdl2/package.nix b/pkgs/by-name/gu/guile-sdl2/package.nix index 0ae8424b597dcf..cc39d0fe299ec7 100644 --- a/pkgs/by-name/gu/guile-sdl2/package.nix +++ b/pkgs/by-name/gu/guile-sdl2/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, SDL2 -, SDL2_image -, SDL2_mixer -, SDL2_ttf -, guile -, libtool -, pkg-config +{ + lib, + stdenv, + fetchurl, + SDL2, + SDL2_image, + SDL2_mixer, + SDL2_ttf, + guile, + libtool, + pkg-config, }: stdenv.mkDerivation rec { @@ -46,7 +47,10 @@ stdenv.mkDerivation rec { homepage = "https://dthompson.us/projects/guile-sdl2.html"; description = "Bindings to SDL2 for GNU Guile"; license = licenses.lgpl3Plus; - maintainers = with maintainers; [ seppeljordan vyp ]; + maintainers = with maintainers; [ + seppeljordan + vyp + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/gu/guile-semver/package.nix b/pkgs/by-name/gu/guile-semver/package.nix index 3d4713f709666c..aad799d81798e8 100644 --- a/pkgs/by-name/gu/guile-semver/package.nix +++ b/pkgs/by-name/gu/guile-semver/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, pkg-config -, texinfo -, guile +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + texinfo, + guile, }: stdenv.mkDerivation rec { @@ -17,14 +18,18 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ autoreconfHook guile pkg-config texinfo ]; + nativeBuildInputs = [ + autoreconfHook + guile + pkg-config + texinfo + ]; buildInputs = [ guile ]; doCheck = true; meta = with lib; { - description = - "A GNU Guile library implementing Semantic Versioning 2.0.0"; + description = "A GNU Guile library implementing Semantic Versioning 2.0.0"; homepage = "https://ngyro.com/software/guile-semver.html"; license = licenses.gpl3Plus; maintainers = with maintainers; [ foo-dogsquared ]; diff --git a/pkgs/by-name/gu/guile-sjson/package.nix b/pkgs/by-name/gu/guile-sjson/package.nix index 8f9b49f95e0620..27ca1cf25668d9 100644 --- a/pkgs/by-name/gu/guile-sjson/package.nix +++ b/pkgs/by-name/gu/guile-sjson/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitLab -, autoreconfHook -, guile -, pkg-config +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + guile, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gu/guile-ssh/package.nix b/pkgs/by-name/gu/guile-ssh/package.nix index 5fca74a79462a3..c77ee9df5cb49c 100644 --- a/pkgs/by-name/gu/guile-ssh/package.nix +++ b/pkgs/by-name/gu/guile-ssh/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, guile -, libssh -, autoreconfHook -, pkg-config -, texinfo -, which +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + guile, + libssh, + autoreconfHook, + pkg-config, + texinfo, + which, }: stdenv.mkDerivation (finalAttrs: { @@ -61,7 +62,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Bindings to Libssh for GNU Guile"; homepage = "https://github.com/artyom-poptsov/guile-ssh"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ ethancedwards8 foo-dogsquared ]; + maintainers = with maintainers; [ + ethancedwards8 + foo-dogsquared + ]; platforms = guile.meta.platforms; }; }) diff --git a/pkgs/by-name/gu/guile-xcb/package.nix b/pkgs/by-name/gu/guile-xcb/package.nix index 2102e395d0b303..f288f6299bf405 100644 --- a/pkgs/by-name/gu/guile-xcb/package.nix +++ b/pkgs/by-name/gu/guile-xcb/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, guile -, pkg-config -, texinfo +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + guile, + pkg-config, + texinfo, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gu/guile-zstd/package.nix b/pkgs/by-name/gu/guile-zstd/package.nix index 2c0f9b8d0425bd..4b35092837633c 100644 --- a/pkgs/by-name/gu/guile-zstd/package.nix +++ b/pkgs/by-name/gu/guile-zstd/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitea -, autoreconfHook -, pkg-config -, guile -, texinfo -, zstd +{ + stdenv, + lib, + fetchFromGitea, + autoreconfHook, + pkg-config, + guile, + texinfo, + zstd, }: stdenv.mkDerivation rec { @@ -21,7 +22,12 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ autoreconfHook guile pkg-config texinfo ]; + nativeBuildInputs = [ + autoreconfHook + guile + pkg-config + texinfo + ]; buildInputs = [ guile ]; propagatedBuildInputs = [ zstd ]; makeFlags = [ "GUILE_AUTO_COMPILE=0" ]; diff --git a/pkgs/by-name/gu/guilt/package.nix b/pkgs/by-name/gu/guilt/package.nix index bca572b28bcac1..77152b5930bc2e 100644 --- a/pkgs/by-name/gu/guilt/package.nix +++ b/pkgs/by-name/gu/guilt/package.nix @@ -1,16 +1,17 @@ -{ asciidoc -, docbook_xml_dtd_45 -, docbook_xsl -, fetchFromGitHub -, gawk -, git -, gnused -, lib -, makeWrapper -, openssl -, perl -, stdenv -, xmlto +{ + asciidoc, + docbook_xml_dtd_45, + docbook_xsl, + fetchFromGitHub, + gawk, + git, + gnused, + lib, + makeWrapper, + openssl, + perl, + stdenv, + xmlto, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gu/gum/package.nix b/pkgs/by-name/gu/gum/package.nix index 3870851655038c..0bb5894cb3ef0f 100644 --- a/pkgs/by-name/gu/gum/package.nix +++ b/pkgs/by-name/gu/gum/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, buildGoModule, installShellFiles, fetchFromGitHub }: +{ + lib, + stdenv, + buildGoModule, + installShellFiles, + fetchFromGitHub, +}: buildGoModule rec { pname = "gum"; @@ -17,17 +23,23 @@ buildGoModule rec { installShellFiles ]; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; - postInstall = '' - $out/bin/gum man > gum.1 - installManPage gum.1 - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - installShellCompletion --cmd gum \ - --bash <($out/bin/gum completion bash) \ - --fish <($out/bin/gum completion fish) \ - --zsh <($out/bin/gum completion zsh) - ''; + postInstall = + '' + $out/bin/gum man > gum.1 + installManPage gum.1 + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + installShellCompletion --cmd gum \ + --bash <($out/bin/gum completion bash) \ + --fish <($out/bin/gum completion fish) \ + --zsh <($out/bin/gum completion zsh) + ''; meta = with lib; { description = "Tasty Bubble Gum for your shell"; diff --git a/pkgs/by-name/gu/gummi/package.nix b/pkgs/by-name/gu/gummi/package.nix index 857db4fd95bfdf..8c7af62fde9fc5 100644 --- a/pkgs/by-name/gu/gummi/package.nix +++ b/pkgs/by-name/gu/gummi/package.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, pkgs -, glib, gtk3, gtksourceview3, gtkspell3, poppler, texlive -, pkg-config, intltool, autoreconfHook, wrapGAppsHook3 +{ + lib, + stdenv, + pkgs, + glib, + gtk3, + gtksourceview3, + gtkspell3, + poppler, + texlive, + pkg-config, + intltool, + autoreconfHook, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -15,10 +26,17 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - pkg-config intltool autoreconfHook wrapGAppsHook3 + pkg-config + intltool + autoreconfHook + wrapGAppsHook3 ]; buildInputs = [ - glib gtksourceview3 gtk3 gtkspell3 poppler + glib + gtksourceview3 + gtk3 + gtkspell3 + poppler texlive.bin.core # needed for synctex ]; diff --git a/pkgs/by-name/gu/gummy/package.nix b/pkgs/by-name/gu/gummy/package.nix index 2b34d02d5b0a7e..e43ac701772aae 100644 --- a/pkgs/by-name/gu/gummy/package.nix +++ b/pkgs/by-name/gu/gummy/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitea -, testers -, cmake -, libX11 -, libXext -, sdbus-cpp -, udev -, xcbutilimage -, coreutils -, cli11 -, ddcutil -, fmt -, nlohmann_json -, spdlog -, nix-update-script +{ + lib, + stdenv, + fetchFromGitea, + testers, + cmake, + libX11, + libXext, + sdbus-cpp, + udev, + xcbutilimage, + coreutils, + cli11, + ddcutil, + fmt, + nlohmann_json, + spdlog, + nix-update-script, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/gu/gungnir/package.nix b/pkgs/by-name/gu/gungnir/package.nix index 5ca7388338efee..5b60b62ac05698 100644 --- a/pkgs/by-name/gu/gungnir/package.nix +++ b/pkgs/by-name/gu/gungnir/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-2RCIZS8oawaXtAYZDiLgNsco9llWCxNwQcA67F51rag="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Command-line tool that continuously monitors certificate transparency (CT) logs for newly issued SSL/TLS certificates"; @@ -26,4 +30,3 @@ buildGoModule rec { mainProgram = "gungnir"; }; } - diff --git a/pkgs/by-name/gu/gupnp-av/package.nix b/pkgs/by-name/gu/gupnp-av/package.nix index 97c7ed790ac42b..59145c2c421a04 100644 --- a/pkgs/by-name/gu/gupnp-av/package.nix +++ b/pkgs/by-name/gu/gupnp-av/package.nix @@ -1,24 +1,29 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, gobject-introspection -, vala -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_412 -, glib -, libxml2 -, gnome +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + gobject-introspection, + vala, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_412, + glib, + libxml2, + gnome, }: stdenv.mkDerivation rec { pname = "gupnp-av"; version = "0.14.1"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/gu/gupnp-dlna/package.nix b/pkgs/by-name/gu/gupnp-dlna/package.nix index 44e7c5b5f47c5e..848303ff58ed8e 100644 --- a/pkgs/by-name/gu/gupnp-dlna/package.nix +++ b/pkgs/by-name/gu/gupnp-dlna/package.nix @@ -1,24 +1,29 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, gobject-introspection -, vala -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_412 -, libxml2 -, gst_all_1 -, gnome +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + gobject-introspection, + vala, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_412, + libxml2, + gst_all_1, + gnome, }: stdenv.mkDerivation rec { pname = "gupnp-dlna"; version = "0.12.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/gu/gupnp-igd/package.nix b/pkgs/by-name/gu/gupnp-igd/package.nix index 60a3bfe911170c..7d26c68a68bc91 100644 --- a/pkgs/by-name/gu/gupnp-igd/package.nix +++ b/pkgs/by-name/gu/gupnp-igd/package.nix @@ -1,24 +1,28 @@ -{ lib, stdenv -, fetchurl -, pkg-config -, meson -, ninja -, gettext -, gobject-introspection -, gtk-doc -, docbook_xsl -, docbook_xml_dtd_412 -, glib -, gupnp -, gnome +{ + lib, + stdenv, + fetchurl, + pkg-config, + meson, + ninja, + gettext, + gobject-introspection, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_412, + glib, + gupnp, + gnome, }: stdenv.mkDerivation rec { pname = "gupnp-igd"; version = "1.2.0"; - outputs = [ "out" "dev" ] - ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ "devdoc" ]; + outputs = [ + "out" + "dev" + ] ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ "devdoc" ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/gu/gupnp-tools/package.nix b/pkgs/by-name/gu/gupnp-tools/package.nix index 254201e28962ed..e40546c094c7cf 100644 --- a/pkgs/by-name/gu/gupnp-tools/package.nix +++ b/pkgs/by-name/gu/gupnp-tools/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, gupnp_1_6 -, libsoup_3 -, gssdp_1_6 -, pkg-config -, gtk3 -, gettext -, gupnp-av -, gtksourceview4 -, gnome -, wrapGAppsHook3 +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + gupnp_1_6, + libsoup_3, + gssdp_1_6, + pkg-config, + gtk3, + gettext, + gupnp-av, + gtksourceview4, + gnome, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gu/gusb/package.nix b/pkgs/by-name/gu/gusb/package.nix index c49df7fd75fe9a..75ba45988acb4f 100644 --- a/pkgs/by-name/gu/gusb/package.nix +++ b/pkgs/by-name/gu/gusb/package.nix @@ -1,34 +1,42 @@ -{ lib -, stdenv -, fetchFromGitHub -, substituteAll -, meson -, ninja -, pkg-config -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, gobject-introspection -, gi-docgen -, python3 -, glib -, libusb1 -, json-glib -, vala -, hwdata -, umockdev +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + meson, + ninja, + pkg-config, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + gobject-introspection, + gi-docgen, + python3, + glib, + libusb1, + json-glib, + vala, + hwdata, + umockdev, }: let - pythonEnv = python3.pythonOnBuildForHost.withPackages (ps: with ps; [ - setuptools - ]); + pythonEnv = python3.pythonOnBuildForHost.withPackages ( + ps: with ps; [ + setuptools + ] + ); in stdenv.mkDerivation rec { pname = "gusb"; version = "0.4.9"; - outputs = [ "bin" "out" "dev" ] - ++ lib.optionals withIntrospection [ "devdoc" ]; + outputs = [ + "bin" + "out" + "dev" + ] ++ lib.optionals withIntrospection [ "devdoc" ]; src = fetchFromGitHub { owner = "hughsie"; @@ -50,15 +58,17 @@ stdenv.mkDerivation rec { pkg-config ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - ] ++ lib.optionals withIntrospection [ - gobject-introspection - gi-docgen - vala - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + gi-docgen + vala + ]; # all required in gusb.pc propagatedBuildInputs = [ diff --git a/pkgs/by-name/gu/gut/package.nix b/pkgs/by-name/gu/gut/package.nix index 9874a9447780dd..c49ba59dfd819c 100644 --- a/pkgs/by-name/gu/gut/package.nix +++ b/pkgs/by-name/gu/gut/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, }: buildGoModule rec { @@ -17,7 +18,11 @@ buildGoModule rec { vendorHash = "sha256-G9oDMHLmdv/vQfofTqKAf21xaGp+lvW+sedLmaj+A5A="; - ldflags = [ "-s" "-w" "-X github.com/julien040/gut/src/telemetry.gutVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/julien040/gut/src/telemetry.gutVersion=${version}" + ]; # Depends on `/home` existing doCheck = false; diff --git a/pkgs/by-name/gv/gv/package.nix b/pkgs/by-name/gv/gv/package.nix index b812e560738048..a35771ed0be3f3 100644 --- a/pkgs/by-name/gv/gv/package.nix +++ b/pkgs/by-name/gv/gv/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, libXext, Xaw3d, ghostscriptX, perl, pkg-config, libiconv }: +{ + lib, + stdenv, + fetchurl, + libXext, + Xaw3d, + ghostscriptX, + perl, + pkg-config, + libiconv, +}: stdenv.mkDerivation rec { pname = "gv"; @@ -14,14 +24,16 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - libXext - Xaw3d - ghostscriptX - perl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - ]; + buildInputs = + [ + libXext + Xaw3d + ghostscriptX + perl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + ]; patchPhase = '' sed 's|\|${ghostscriptX}/bin/gs|g' -i "src/"*.in diff --git a/pkgs/by-name/gv/gvfs/package.nix b/pkgs/by-name/gv/gvfs/package.nix index 046c1a59c99989..e70cccc2568b00 100644 --- a/pkgs/by-name/gv/gvfs/package.nix +++ b/pkgs/by-name/gv/gvfs/package.nix @@ -1,47 +1,48 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, substituteAll -, gettext -, dbus -, glib -, udevSupport ? stdenv.hostPlatform.isLinux -, libgudev -, udisks2 -, libgcrypt -, libcap -, polkit -, libgphoto2 -, avahi -, libarchive -, fuse3 -, libcdio -, libxml2 -, libsoup_3 -, libxslt -, docbook_xsl -, docbook_xml_dtd_42 -, samba -, libmtp -, gnomeSupport ? false -, gnome -, gcr_4 -, glib-networking -, gnome-online-accounts -, wrapGAppsHook3 -, libimobiledevice -, libbluray -, libcdio-paranoia -, libnfs -, openssh -, libsecret -, libgdata -, libmsgraph -, python3 -, gsettings-desktop-schemas +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + substituteAll, + gettext, + dbus, + glib, + udevSupport ? stdenv.hostPlatform.isLinux, + libgudev, + udisks2, + libgcrypt, + libcap, + polkit, + libgphoto2, + avahi, + libarchive, + fuse3, + libcdio, + libxml2, + libsoup_3, + libxslt, + docbook_xsl, + docbook_xml_dtd_42, + samba, + libmtp, + gnomeSupport ? false, + gnome, + gcr_4, + glib-networking, + gnome-online-accounts, + wrapGAppsHook3, + libimobiledevice, + libbluray, + libcdio-paranoia, + libnfs, + openssh, + libsecret, + libgdata, + libmsgraph, + python3, + gsettings-desktop-schemas, }: stdenv.mkDerivation (finalAttrs: { @@ -76,64 +77,72 @@ stdenv.mkDerivation (finalAttrs: { docbook_xml_dtd_42 ]; - buildInputs = [ - glib - libgcrypt - dbus - libgphoto2 - avahi - libarchive - libimobiledevice - libbluray - libnfs - libxml2 - gsettings-desktop-schemas - libsoup_3 - ] ++ lib.optionals udevSupport [ - libgudev - udisks2 - fuse3 - libcdio - samba - libmtp - libcap - polkit - libcdio-paranoia - ] ++ lib.optionals gnomeSupport [ - gcr_4 - glib-networking # TLS support - gnome-online-accounts - libsecret - libgdata - libmsgraph - ]; + buildInputs = + [ + glib + libgcrypt + dbus + libgphoto2 + avahi + libarchive + libimobiledevice + libbluray + libnfs + libxml2 + gsettings-desktop-schemas + libsoup_3 + ] + ++ lib.optionals udevSupport [ + libgudev + udisks2 + fuse3 + libcdio + samba + libmtp + libcap + polkit + libcdio-paranoia + ] + ++ lib.optionals gnomeSupport [ + gcr_4 + glib-networking # TLS support + gnome-online-accounts + libsecret + libgdata + libmsgraph + ]; - mesonFlags = [ - "-Dsystemduserunitdir=${placeholder "out"}/lib/systemd/user" - "-Dtmpfilesdir=no" - ] ++ lib.optionals (!udevSupport) [ - "-Dgudev=false" - "-Dudisks2=false" - "-Dfuse=false" - "-Dcdda=false" - "-Dsmb=false" - "-Dmtp=false" - "-Dadmin=false" - "-Dgphoto2=false" - "-Dlibusb=false" - "-Dlogind=false" - ] ++ lib.optionals (!gnomeSupport) [ - "-Dgcr=false" - "-Dgoa=false" - "-Dkeyring=false" - "-Dgoogle=false" - "-Donedrive=false" - ] ++ lib.optionals (avahi == null) [ - "-Ddnssd=false" - ] ++ lib.optionals (samba == null) [ - # Xfce don't want samba - "-Dsmb=false" - ]; + mesonFlags = + [ + "-Dsystemduserunitdir=${placeholder "out"}/lib/systemd/user" + "-Dtmpfilesdir=no" + ] + ++ lib.optionals (!udevSupport) [ + "-Dgudev=false" + "-Dudisks2=false" + "-Dfuse=false" + "-Dcdda=false" + "-Dsmb=false" + "-Dmtp=false" + "-Dadmin=false" + "-Dgphoto2=false" + "-Dlibusb=false" + "-Dlogind=false" + ] + ++ lib.optionals (!gnomeSupport) [ + "-Dgcr=false" + "-Dgoa=false" + "-Dkeyring=false" + "-Dgoogle=false" + "-Donedrive=false" + ] + ++ lib.optionals (avahi == null) [ + "-Ddnssd=false" + ] + ++ lib.optionals (samba == null) [ + # Xfce don't want samba + "-Dsmb=false" + ]; doCheck = false; # fails with "ModuleNotFoundError: No module named 'gi'" doInstallCheck = finalAttrs.finalPackage.doCheck; @@ -148,7 +157,8 @@ stdenv.mkDerivation (finalAttrs: { }; meta = with lib; { - description = "Virtual Filesystem support library" + optionalString gnomeSupport " (full GNOME support)"; + description = + "Virtual Filesystem support library" + optionalString gnomeSupport " (full GNOME support)"; license = licenses.lgpl2Plus; platforms = platforms.unix; maintainers = teams.gnome.members; diff --git a/pkgs/by-name/gv/gvolicon/package.nix b/pkgs/by-name/gv/gvolicon/package.nix index 9f7237dd497b04..b275fdaaa1cfdc 100644 --- a/pkgs/by-name/gv/gvolicon/package.nix +++ b/pkgs/by-name/gv/gvolicon/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, makeWrapper, alsa-lib, pkg-config, fetchFromGitHub, gtk3, adwaita-icon-theme, gdk-pixbuf, librsvg, wrapGAppsHook3 }: +{ + lib, + stdenv, + makeWrapper, + alsa-lib, + pkg-config, + fetchFromGitHub, + gtk3, + adwaita-icon-theme, + gdk-pixbuf, + librsvg, + wrapGAppsHook3, +}: stdenv.mkDerivation { pname = "gvolicon"; @@ -11,10 +23,17 @@ stdenv.mkDerivation { sha256 = "sha256-lm5OfryV1/1T1RgsVDdp0Jg5rh8AND8M3ighfrznKes="; }; - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; buildInputs = [ - alsa-lib gtk3 gdk-pixbuf adwaita-icon-theme - librsvg wrapGAppsHook3 + alsa-lib + gtk3 + gdk-pixbuf + adwaita-icon-theme + librsvg + wrapGAppsHook3 ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/gv/gvpe/package.nix b/pkgs/by-name/gv/gvpe/package.nix index 13e61e59d3dc1d..cca9f556a2d5ed 100644 --- a/pkgs/by-name/gv/gvpe/package.nix +++ b/pkgs/by-name/gv/gvpe/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, openssl, gmp, zlib, iproute2, nettools, pkg-config }: +{ + lib, + stdenv, + fetchurl, + openssl, + gmp, + zlib, + iproute2, + nettools, + pkg-config, +}: stdenv.mkDerivation rec { pname = "gvpe"; @@ -10,7 +20,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl gmp zlib ]; + buildInputs = [ + openssl + gmp + zlib + ]; configureFlags = [ "--enable-tcp" diff --git a/pkgs/by-name/gv/gvproxy/package.nix b/pkgs/by-name/gv/gvproxy/package.nix index 4a886c4b50bd9b..c02926b9c8eb62 100644 --- a/pkgs/by-name/gv/gvproxy/package.nix +++ b/pkgs/by-name/gv/gvproxy/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "gvproxy"; diff --git a/pkgs/by-name/gw/gwc/package.nix b/pkgs/by-name/gw/gwc/package.nix index 29bfc047e19934..5cced6ce7fdca1 100644 --- a/pkgs/by-name/gw/gwc/package.nix +++ b/pkgs/by-name/gw/gwc/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, alsa-lib -, libpulseaudio -, gtk2 -, hicolor-icon-theme -, libsndfile -, fftw +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + alsa-lib, + libpulseaudio, + gtk2, + hicolor-icon-theme, + libsndfile, + fftw, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gw/gwyddion/package.nix b/pkgs/by-name/gw/gwyddion/package.nix index ff656a6ce5605f..69a3ddaf11dd9e 100644 --- a/pkgs/by-name/gw/gwyddion/package.nix +++ b/pkgs/by-name/gw/gwyddion/package.nix @@ -1,41 +1,69 @@ -{ lib, stdenv, fetchurl, gtk2, pkg-config, fftw, file, +{ + lib, + stdenv, + fetchurl, + gtk2, + pkg-config, + fftw, + file, gnome2, - openexrSupport ? true, openexr, - libzipSupport ? true, libzip, - libxml2Support ? true, libxml2, - libwebpSupport ? true, libwebp, + openexrSupport ? true, + openexr, + libzipSupport ? true, + libzip, + libxml2Support ? true, + libxml2, + libwebpSupport ? true, + libwebp, # libXmu is not used if libunique is. - libXmuSupport ? false, xorg, - libxsltSupport ? true, libxslt, - fitsSupport ? true, cfitsio, - zlibSupport ? true, zlib, - libuniqueSupport ? true, libunique, - libpngSupport ? true, libpng, - openglSupport ? !stdenv.hostPlatform.isDarwin, libGL + libXmuSupport ? false, + xorg, + libxsltSupport ? true, + libxslt, + fitsSupport ? true, + cfitsio, + zlibSupport ? true, + zlib, + libuniqueSupport ? true, + libunique, + libpngSupport ? true, + libpng, + openglSupport ? !stdenv.hostPlatform.isDarwin, + libGL, }: stdenv.mkDerivation rec { pname = "gwyddion"; - version = "2.67"; + version = "2.67"; src = fetchurl { url = "mirror://sourceforge/gwyddion/gwyddion-${version}.tar.xz"; sha256 = "sha256-kK6vTeADc2lrC+9KgqxFtih62ce3rKYkkGjU0qT8jWE="; }; - nativeBuildInputs = [ pkg-config file ]; + nativeBuildInputs = [ + pkg-config + file + ]; - buildInputs = [ gtk2 fftw ] ++ - lib.optionals openglSupport [ gnome2.gtkglext libGL ] ++ - lib.optional openexrSupport openexr ++ - lib.optional libXmuSupport xorg.libXmu ++ - lib.optional fitsSupport cfitsio ++ - lib.optional libpngSupport libpng ++ - lib.optional libxsltSupport libxslt ++ - lib.optional libxml2Support libxml2 ++ - lib.optional libwebpSupport libwebp ++ - lib.optional zlibSupport zlib ++ - lib.optional libuniqueSupport libunique ++ - lib.optional libzipSupport libzip; + buildInputs = + [ + gtk2 + fftw + ] + ++ lib.optionals openglSupport [ + gnome2.gtkglext + libGL + ] + ++ lib.optional openexrSupport openexr + ++ lib.optional libXmuSupport xorg.libXmu + ++ lib.optional fitsSupport cfitsio + ++ lib.optional libpngSupport libpng + ++ lib.optional libxsltSupport libxslt + ++ lib.optional libxml2Support libxml2 + ++ lib.optional libwebpSupport libwebp + ++ lib.optional zlibSupport zlib + ++ lib.optional libuniqueSupport libunique + ++ lib.optional libzipSupport libzip; # This patch corrects problems with python support, but should apply cleanly # regardless of whether python support is enabled, and have no effects if diff --git a/pkgs/by-name/gx/gx-go/package.nix b/pkgs/by-name/gx/gx-go/package.nix index 8f8053c99591aa..1bb74d913bd2ba 100644 --- a/pkgs/by-name/gx/gx-go/package.nix +++ b/pkgs/by-name/gx/gx-go/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gx-go"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-A3jZYu7+LGCukzlrxgIPmnkcxSoWm5YJZmFG3hliMm4="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Tool for importing go packages into gx"; diff --git a/pkgs/by-name/gx/gxemul/package.nix b/pkgs/by-name/gx/gxemul/package.nix index 88ea01f9d76ef9..1825a36e05a1fa 100644 --- a/pkgs/by-name/gx/gxemul/package.nix +++ b/pkgs/by-name/gx/gxemul/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, libX11 +{ + lib, + stdenv, + fetchurl, + libX11, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/gx/gxkb/package.nix b/pkgs/by-name/gx/gxkb/package.nix index f64982ed717f7d..2692a65239266a 100644 --- a/pkgs/by-name/gx/gxkb/package.nix +++ b/pkgs/by-name/gx/gxkb/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl, git, autoreconfHook, pkg-config, gtk3, libwnck, libxklavier -, appindicatorSupport ? true, libayatana-appindicator +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + git, + autoreconfHook, + pkg-config, + gtk3, + libwnck, + libxklavier, + appindicatorSupport ? true, + libayatana-appindicator, }: stdenv.mkDerivation rec { @@ -13,18 +24,28 @@ stdenv.mkDerivation rec { sha256 = "sha256-oBIBIkj4p6HlF0PRQtI/K5dhLs7pbPxN7Cgr/YZaI1s="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ gtk3 libwnck libxklavier ] ++ lib.optional appindicatorSupport libayatana-appindicator; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + gtk3 + libwnck + libxklavier + ] ++ lib.optional appindicatorSupport libayatana-appindicator; configureFlags = lib.optional appindicatorSupport "--enable-appindicator=yes"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; # This patch restore data which was wiped by upstream without any technical reasons # https://github.com/omgbebebe/gxkb/commit/727ec8b595a91dbb540e6087750f43b85d0dfbc0 # NOTE: the `patch` hook cannot be used here due to lack of support for git binary patches p1 = fetchurl { - url = "https://github.com/omgbebebe/gxkb/commit/727ec8b595a91dbb540e6087750f43b85d0dfbc0.patch"; - hash = "sha256-x7x3MHHrOnPivvlzOFqgFAA5BDB2LOXMlalPYbwM/1Q="; + url = "https://github.com/omgbebebe/gxkb/commit/727ec8b595a91dbb540e6087750f43b85d0dfbc0.patch"; + hash = "sha256-x7x3MHHrOnPivvlzOFqgFAA5BDB2LOXMlalPYbwM/1Q="; }; postPatch = '' diff --git a/pkgs/by-name/gx/gxmatcheq-lv2/package.nix b/pkgs/by-name/gx/gxmatcheq-lv2/package.nix index 246b034400d430..e49f561fb3310b 100644 --- a/pkgs/by-name/gx/gxmatcheq-lv2/package.nix +++ b/pkgs/by-name/gx/gxmatcheq-lv2/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, xorg, xorgproto, cairo, lv2, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + xorg, + xorgproto, + cairo, + lv2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "GxMatchEQ.lv2"; @@ -13,7 +22,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - xorg.libX11 xorgproto cairo lv2 + xorg.libX11 + xorgproto + cairo + lv2 ]; # error: format not a string literal and no format arguments [-Werror=format-security] diff --git a/pkgs/by-name/gx/gxmessage/package.nix b/pkgs/by-name/gx/gxmessage/package.nix index 642cc57eb80981..ff139bcee3b7ff 100644 --- a/pkgs/by-name/gx/gxmessage/package.nix +++ b/pkgs/by-name/gx/gxmessage/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, gtk3, intltool, pkg-config, texinfo }: +{ + lib, + stdenv, + fetchurl, + gtk3, + intltool, + pkg-config, + texinfo, +}: stdenv.mkDerivation rec { pname = "gxmessage"; @@ -9,14 +17,20 @@ stdenv.mkDerivation rec { sha256 = "db4e1655fc58f31e5770a17dfca4e6c89028ad8b2c8e043febc87a0beedeef05"; }; - nativeBuildInputs = [ pkg-config intltool ]; - buildInputs = [ gtk3 texinfo ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; + buildInputs = [ + gtk3 + texinfo + ]; meta = { description = "GTK enabled dropin replacement for xmessage"; homepage = "https://trmusson.dreamhosters.com/programs.html#gxmessage"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [jfb]; + maintainers = with lib.maintainers; [ jfb ]; platforms = with lib.platforms; linux; mainProgram = "gxmessage"; }; diff --git a/pkgs/by-name/gx/gxml/package.nix b/pkgs/by-name/gx/gxml/package.nix index 3540336c81787e..dc9a8b2f53b9d3 100644 --- a/pkgs/by-name/gx/gxml/package.nix +++ b/pkgs/by-name/gx/gxml/package.nix @@ -1,22 +1,27 @@ -{ stdenv -, lib -, fetchFromGitLab -, gobject-introspection -, meson -, ninja -, pkg-config -, vala -, glib -, libgee -, libxml2 -, gitUpdater +{ + stdenv, + lib, + fetchFromGitLab, + gobject-introspection, + meson, + ninja, + pkg-config, + vala, + glib, + libgee, + libxml2, + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { pname = "gxml"; version = "0.20.3"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitLab { domain = "gitlab.gnome.org"; diff --git a/pkgs/by-name/gx/gxplugins-lv2/package.nix b/pkgs/by-name/gx/gxplugins-lv2/package.nix index 8d3fb0046eed85..2ea21f9a155c41 100644 --- a/pkgs/by-name/gx/gxplugins-lv2/package.nix +++ b/pkgs/by-name/gx/gxplugins-lv2/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, xorg, xorgproto, cairo, lv2, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + xorg, + xorgproto, + cairo, + lv2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "GxPlugins.lv2"; @@ -14,7 +23,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - xorg.libX11 xorgproto cairo lv2 + xorg.libX11 + xorgproto + cairo + lv2 ]; installFlags = [ "INSTALL_DIR=$(out)/lib/lv2" ]; diff --git a/pkgs/by-name/gy/gyb/package.nix b/pkgs/by-name/gy/gyb/package.nix index 4bbc668eb4306a..9cf2323ac833c9 100644 --- a/pkgs/by-name/gy/gyb/package.nix +++ b/pkgs/by-name/gy/gyb/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/gy/gyre-fonts/package.nix b/pkgs/by-name/gy/gyre-fonts/package.nix index 254766d1de289c..33a4bcd308e6e1 100644 --- a/pkgs/by-name/gy/gyre-fonts/package.nix +++ b/pkgs/by-name/gy/gyre-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "gyre-fonts"; diff --git a/pkgs/by-name/gz/gzrt/package.nix b/pkgs/by-name/gz/gzrt/package.nix index d28b5af803efc6..6800a5aa9445d0 100644 --- a/pkgs/by-name/gz/gzrt/package.nix +++ b/pkgs/by-name/gz/gzrt/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, zlib }: +{ + lib, + stdenv, + fetchurl, + zlib, +}: stdenv.mkDerivation rec { pname = "gzrt"; diff --git a/pkgs/by-name/h2/h2o/package.nix b/pkgs/by-name/h2/h2o/package.nix index b533a908ef988c..9f0100b8de9d52 100644 --- a/pkgs/by-name/h2/h2o/package.nix +++ b/pkgs/by-name/h2/h2o/package.nix @@ -1,29 +1,49 @@ -{ lib, stdenv, fetchFromGitHub -, pkg-config, cmake, ninja -, openssl, libuv, zlib +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + ninja, + openssl, + libuv, + zlib, }: stdenv.mkDerivation rec { - pname = "h2o"; + pname = "h2o"; version = "2.3.0-beta2"; src = fetchFromGitHub { - owner = "h2o"; - repo = "h2o"; - rev = "refs/tags/v${version}"; + owner = "h2o"; + repo = "h2o"; + rev = "refs/tags/v${version}"; sha256 = "0lwg5sfsr7fw7cfy0hrhadgixm35b5cgcvlhwhbk89j72y1bqi6n"; }; - outputs = [ "out" "man" "dev" "lib" ]; + outputs = [ + "out" + "man" + "dev" + "lib" + ]; - nativeBuildInputs = [ pkg-config cmake ninja ]; - buildInputs = [ openssl libuv zlib ]; + nativeBuildInputs = [ + pkg-config + cmake + ninja + ]; + buildInputs = [ + openssl + libuv + zlib + ]; meta = with lib; { description = "Optimized HTTP/1 and HTTP/2 server"; - homepage = "https://h2o.examp1e.net"; - license = licenses.mit; + homepage = "https://h2o.examp1e.net"; + license = licenses.mit; maintainers = with maintainers; [ thoughtpolice ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/h8/h8mail/package.nix b/pkgs/by-name/h8/h8mail/package.nix index 59da7610d690c6..bff26f3d8c2f0b 100644 --- a/pkgs/by-name/h8/h8mail/package.nix +++ b/pkgs/by-name/h8/h8mail/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ha/ha-mqtt-discoverable-cli/package.nix b/pkgs/by-name/ha/ha-mqtt-discoverable-cli/package.nix index d9ea3eeb4787f5..cf5d6c14112dd3 100644 --- a/pkgs/by-name/ha/ha-mqtt-discoverable-cli/package.nix +++ b/pkgs/by-name/ha/ha-mqtt-discoverable-cli/package.nix @@ -20,7 +20,6 @@ python3.pkgs.buildPythonApplication rec { build-system = with python3.pkgs; [ poetry-core ]; - dependencies = with python3.pkgs; [ ha-mqtt-discoverable ]; # Project has no real tests diff --git a/pkgs/by-name/ha/habitat/package.nix b/pkgs/by-name/ha/habitat/package.nix index 6830836a7318e9..cfc5e8361f3296 100644 --- a/pkgs/by-name/ha/habitat/package.nix +++ b/pkgs/by-name/ha/habitat/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, protobuf -, libsodium -, openssl -, xz -, zeromq -, cacert +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + protobuf, + libsodium, + openssl, + xz, + zeromq, + cacert, }: rustPlatform.buildRustPackage rec { @@ -45,7 +46,10 @@ rustPlatform.buildRustPackage rec { zeromq ]; - cargoBuildFlags = [ "-p" "hab" ]; + cargoBuildFlags = [ + "-p" + "hab" + ]; cargoTestFlags = cargoBuildFlags; env = { @@ -59,7 +63,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://www.habitat.sh"; changelog = "https://github.com/habitat-sh/habitat/blob/${src.rev}/CHANGELOG.md"; license = licenses.asl20; - maintainers = with maintainers; [ rushmorem qjoly ]; + maintainers = with maintainers; [ + rushmorem + qjoly + ]; mainProgram = "hab"; platforms = [ "x86_64-linux" ]; }; diff --git a/pkgs/by-name/ha/hachimarupop/package.nix b/pkgs/by-name/ha/hachimarupop/package.nix index 1097bc43862053..4bcf78fe7ed774 100644 --- a/pkgs/by-name/ha/hachimarupop/package.nix +++ b/pkgs/by-name/ha/hachimarupop/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/ha/hack-font/package.nix b/pkgs/by-name/ha/hack-font/package.nix index a503ade5d2395a..1fbe9ef59498ff 100644 --- a/pkgs/by-name/ha/hack-font/package.nix +++ b/pkgs/by-name/ha/hack-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "hack-font"; diff --git a/pkgs/by-name/ha/hackedbox/package.nix b/pkgs/by-name/ha/hackedbox/package.nix index e5812c4c63fa42..023ff246ef56ec 100644 --- a/pkgs/by-name/ha/hackedbox/package.nix +++ b/pkgs/by-name/ha/hackedbox/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, freetype -, fribidi -, imlib2 -, libX11 -, libXext -, libXft -, libXinerama -, libXpm -, libXrandr -, libXrender -, pkg-config -, xorgproto +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + freetype, + fribidi, + imlib2, + libX11, + libXext, + libXft, + libXinerama, + libXpm, + libXrandr, + libXrender, + pkg-config, + xorgproto, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ha/hackertyper/package.nix b/pkgs/by-name/ha/hackertyper/package.nix index 0428a38cfeb5c2..f482c3a6815a4b 100644 --- a/pkgs/by-name/ha/hackertyper/package.nix +++ b/pkgs/by-name/ha/hackertyper/package.nix @@ -1,13 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation { pname = "hackertyper"; version = "2.1"; src = fetchFromGitHub { - owner = "Hurricane996"; - repo = "Hackertyper"; - rev = "8d08e3200c65817bd8c5bd0baa5032919315853b"; + owner = "Hurricane996"; + repo = "Hackertyper"; + rev = "8d08e3200c65817bd8c5bd0baa5032919315853b"; sha256 = "0shri0srihw9fk027k61qkxr9ikwkn28aaamrhps6lg0vpbqpx2w"; }; diff --git a/pkgs/by-name/ha/hackneyed/package.nix b/pkgs/by-name/ha/hackneyed/package.nix index e1934337e0a347..6e63869b6077db 100644 --- a/pkgs/by-name/ha/hackneyed/package.nix +++ b/pkgs/by-name/ha/hackneyed/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenvNoCC, fetchFromGitLab, imagemagick, inkscape, xcursorgen }: +{ + lib, + stdenvNoCC, + fetchFromGitLab, + imagemagick, + inkscape, + xcursorgen, +}: stdenvNoCC.mkDerivation rec { pname = "hackneyed"; @@ -11,7 +18,11 @@ stdenvNoCC.mkDerivation rec { hash = "sha256-+7QtHgBuhJtQejiHeZ+QoedJo24LqSY51XRVLv9Ho2g="; }; - nativeBuildInputs = [ imagemagick inkscape xcursorgen ]; + nativeBuildInputs = [ + imagemagick + inkscape + xcursorgen + ]; postPatch = '' patchShebangs *.sh @@ -27,7 +38,10 @@ stdenvNoCC.mkDerivation rec { "XCURSORGEN=xcursorgen" ]; - buildFlags = [ "theme" "theme.left" ]; + buildFlags = [ + "theme" + "theme.left" + ]; # The Makefile declares a dependency on the value of $(INKSCAPE) for some reason; # it's unnecessary for building though. diff --git a/pkgs/by-name/ha/hackrf/package.nix b/pkgs/by-name/ha/hackrf/package.nix index 3cbb80393c9793..999353e527bd1c 100644 --- a/pkgs/by-name/ha/hackrf/package.nix +++ b/pkgs/by-name/ha/hackrf/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, libusb1, fftwSinglePrec }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libusb1, + fftwSinglePrec, +}: stdenv.mkDerivation rec { pname = "hackrf"; @@ -21,7 +29,10 @@ stdenv.mkDerivation rec { fftwSinglePrec ]; - cmakeFlags = [ "-DUDEV_RULES_GROUP=plugdev" "-DUDEV_RULES_PATH=lib/udev/rules.d" ]; + cmakeFlags = [ + "-DUDEV_RULES_GROUP=plugdev" + "-DUDEV_RULES_PATH=lib/udev/rules.d" + ]; preConfigure = '' cd host diff --git a/pkgs/by-name/ha/hacksaw/package.nix b/pkgs/by-name/ha/hacksaw/package.nix index 1f98355a6412db..ddf703433b116e 100644 --- a/pkgs/by-name/ha/hacksaw/package.nix +++ b/pkgs/by-name/ha/hacksaw/package.nix @@ -1,12 +1,26 @@ -{ lib, fetchCrate, rustPlatform, pkg-config, libXrandr, libX11, python3 }: +{ + lib, + fetchCrate, + rustPlatform, + pkg-config, + libXrandr, + libX11, + python3, +}: rustPlatform.buildRustPackage rec { pname = "hacksaw"; version = "1.0.4"; - nativeBuildInputs = [ pkg-config python3 ]; + nativeBuildInputs = [ + pkg-config + python3 + ]; - buildInputs = [ libXrandr libX11 ]; + buildInputs = [ + libXrandr + libX11 + ]; src = fetchCrate { inherit pname version; diff --git a/pkgs/by-name/ha/hacompanion/package.nix b/pkgs/by-name/ha/hacompanion/package.nix index d9ad59aeabe79e..d9dcc554151eea 100644 --- a/pkgs/by-name/ha/hacompanion/package.nix +++ b/pkgs/by-name/ha/hacompanion/package.nix @@ -1,6 +1,7 @@ -{ lib, +{ + lib, fetchFromGitHub, - buildGoModule + buildGoModule, }: buildGoModule rec { diff --git a/pkgs/by-name/ha/hacpack/package.nix b/pkgs/by-name/ha/hacpack/package.nix index 8bab34043c47c2..d6d4ea59a104fd 100644 --- a/pkgs/by-name/ha/hacpack/package.nix +++ b/pkgs/by-name/ha/hacpack/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "hacpack"; diff --git a/pkgs/by-name/ha/hactool/package.nix b/pkgs/by-name/ha/hactool/package.nix index 9cc3a26f6f5e47..815fdfb87c5866 100644 --- a/pkgs/by-name/ha/hactool/package.nix +++ b/pkgs/by-name/ha/hactool/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "hactool"; diff --git a/pkgs/by-name/ha/haka/package.nix b/pkgs/by-name/ha/haka/package.nix index c51d582f4c0d5c..837d8e7be28710 100644 --- a/pkgs/by-name/ha/haka/package.nix +++ b/pkgs/by-name/ha/haka/package.nix @@ -1,6 +1,22 @@ -{ lib, stdenv, fetchurl, cmake, swig, wireshark, check, rsync, libpcap, gawk, libedit, pcre, nixosTests }: +{ + lib, + stdenv, + fetchurl, + cmake, + swig, + wireshark, + check, + rsync, + libpcap, + gawk, + libedit, + pcre, + nixosTests, +}: -let version = "0.3.0"; in +let + version = "0.3.0"; +in stdenv.mkDerivation { pname = "haka"; @@ -22,7 +38,16 @@ stdenv.mkDerivation { ''; nativeBuildInputs = [ cmake ]; - buildInputs = [ swig wireshark check rsync libpcap gawk libedit pcre ]; + buildInputs = [ + swig + wireshark + check + rsync + libpcap + gawk + libedit + pcre + ]; passthru.tests = { inherit (nixosTests) haka; }; @@ -31,6 +56,9 @@ stdenv.mkDerivation { homepage = "http://www.haka-security.org/"; license = lib.licenses.mpl20; maintainers = [ lib.maintainers.tvestelind ]; - platforms = [ "x86_64-linux" "i686-linux" ]; # fails on aarch64 + platforms = [ + "x86_64-linux" + "i686-linux" + ]; # fails on aarch64 }; } diff --git a/pkgs/by-name/ha/hakrawler/package.nix b/pkgs/by-name/ha/hakrawler/package.nix index 58481390f2cc84..61ba00d2c06bd9 100644 --- a/pkgs/by-name/ha/hakrawler/package.nix +++ b/pkgs/by-name/ha/hakrawler/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -20,7 +21,7 @@ buildGoModule rec { description = "Web crawler for the discovery of endpoints and assets"; mainProgram = "hakrawler"; homepage = "https://github.com/hakluke/hakrawler"; - longDescription = '' + longDescription = '' Simple, fast web crawler designed for easy, quick discovery of endpoints and assets within a web application. ''; diff --git a/pkgs/by-name/ha/hakuneko/package.nix b/pkgs/by-name/ha/hakuneko/package.nix index fbc76aa1eb90b6..70a33c50a27b1d 100644 --- a/pkgs/by-name/ha/hakuneko/package.nix +++ b/pkgs/by-name/ha/hakuneko/package.nix @@ -1,23 +1,27 @@ -{ autoPatchelfHook -, dpkg -, fetchurl -, makeDesktopItem -, makeWrapper -, udev -, stdenv -, lib -, wrapGAppsHook3 -, alsa-lib -, nss -, nspr -, systemd -, xorg +{ + autoPatchelfHook, + dpkg, + fetchurl, + makeDesktopItem, + makeWrapper, + udev, + stdenv, + lib, + wrapGAppsHook3, + alsa-lib, + nss, + nspr, + systemd, + xorg, }: let desktopItem = makeDesktopItem { desktopName = "HakuNeko Desktop"; genericName = "Manga & Anime Downloader"; - categories = [ "Network" "FileTransfer" ]; + categories = [ + "Network" + "FileTransfer" + ]; exec = "hakuneko"; icon = "hakuneko-desktop"; name = "hakuneko-desktop"; @@ -27,16 +31,18 @@ stdenv.mkDerivation rec { pname = "hakuneko"; version = "6.1.7"; - src = { - "x86_64-linux" = fetchurl { - url = "https://github.com/manga-download/hakuneko/releases/download/v${version}/hakuneko-desktop_${version}_linux_amd64.deb"; - sha256 = "06bb17d7a06bb0601053eaaf423f9176f06ff3636cc43ffc024438e1962dcd02"; - }; - "i686-linux" = fetchurl { - url = "https://github.com/manga-download/hakuneko/releases/download/v${version}/hakuneko-desktop_${version}_linux_i386.deb"; - sha256 = "32017d26bafffaaf0a83dd6954d3926557014af4022a972371169c56c0e3d98b"; - }; - }."${stdenv.hostPlatform.system}" or (throw "unsupported system ${stdenv.hostPlatform.system}"); + src = + { + "x86_64-linux" = fetchurl { + url = "https://github.com/manga-download/hakuneko/releases/download/v${version}/hakuneko-desktop_${version}_linux_amd64.deb"; + sha256 = "06bb17d7a06bb0601053eaaf423f9176f06ff3636cc43ffc024438e1962dcd02"; + }; + "i686-linux" = fetchurl { + url = "https://github.com/manga-download/hakuneko/releases/download/v${version}/hakuneko-desktop_${version}_linux_i386.deb"; + sha256 = "32017d26bafffaaf0a83dd6954d3926557014af4022a972371169c56c0e3d98b"; + }; + } + ."${stdenv.hostPlatform.system}" or (throw "unsupported system ${stdenv.hostPlatform.system}"); dontBuild = true; dontConfigure = true; diff --git a/pkgs/by-name/ha/half/package.nix b/pkgs/by-name/ha/half/package.nix index 557ed1ffe90e69..c5ab04a67972ed 100644 --- a/pkgs/by-name/ha/half/package.nix +++ b/pkgs/by-name/ha/half/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { version = "2.2.0"; diff --git a/pkgs/by-name/ha/halfempty/package.nix b/pkgs/by-name/ha/halfempty/package.nix index 62b0d161b4123f..f52e2df14414b5 100644 --- a/pkgs/by-name/ha/halfempty/package.nix +++ b/pkgs/by-name/ha/halfempty/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, pkg-config, glib, hexdump, scowl }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + glib, + hexdump, + scowl, +}: stdenv.mkDerivation rec { pname = "halfempty"; @@ -11,7 +20,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-YGq6fneAMo2jCpLPrjzRJ0eeOsStKaK5L+lwQfqcfpY="; }; - nativeBuildInputs = [ pkg-config hexdump ]; + nativeBuildInputs = [ + pkg-config + hexdump + ]; buildInputs = [ glib ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; diff --git a/pkgs/by-name/ha/halftone/package.nix b/pkgs/by-name/ha/halftone/package.nix index c29bcb8ccd1d4e..aa7a4f7f4c29b3 100644 --- a/pkgs/by-name/ha/halftone/package.nix +++ b/pkgs/by-name/ha/halftone/package.nix @@ -1,16 +1,17 @@ -{ lib -, fetchFromGitHub -, wrapGAppsHook4 -, meson -, ninja -, pkg-config -, appstream-glib -, desktop-file-utils -, gobject-introspection -, glib -, blueprint-compiler -, libadwaita -, python3Packages +{ + lib, + fetchFromGitHub, + wrapGAppsHook4, + meson, + ninja, + pkg-config, + appstream-glib, + desktop-file-utils, + gobject-introspection, + glib, + blueprint-compiler, + libadwaita, + python3Packages, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ha/halibut/package.nix b/pkgs/by-name/ha/halibut/package.nix index 3429df706d2f4a..730fc63aa74859 100644 --- a/pkgs/by-name/ha/halibut/package.nix +++ b/pkgs/by-name/ha/halibut/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, cmake, perl}: +{ + lib, + stdenv, + fetchurl, + cmake, + perl, +}: stdenv.mkDerivation rec { pname = "halibut"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "0ciikn878vivs4ayvwvr63nnhpcg12m8023xv514zxqpdxlzg85a"; }; - nativeBuildInputs = [ cmake perl ]; + nativeBuildInputs = [ + cmake + perl + ]; meta = with lib; { description = "Documentation production system for software manuals"; diff --git a/pkgs/by-name/ha/halo/package.nix b/pkgs/by-name/ha/halo/package.nix index cc817536cdb1bf..4e7185858ae68e 100644 --- a/pkgs/by-name/ha/halo/package.nix +++ b/pkgs/by-name/ha/halo/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper +{ + lib, + stdenv, + fetchurl, + makeWrapper, # official jre size is 500MB, but temurin-jre-bin is 100MB. -, temurin-jre-bin + temurin-jre-bin, }: stdenv.mkDerivation rec { pname = "halo"; @@ -65,7 +66,10 @@ stdenv.mkDerivation rec { description = "Self-hosted dynamic blogging program"; maintainers = with lib.maintainers; [ yah ]; license = lib.licenses.gpl3Only; - platforms = [ "aarch64-linux" "x86_64-linux" ]; + platforms = [ + "aarch64-linux" + "x86_64-linux" + ]; mainProgram = "halo"; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; }; diff --git a/pkgs/by-name/ha/halp/package.nix b/pkgs/by-name/ha/halp/package.nix index 2a8b869861cdec..e45c82332060f2 100644 --- a/pkgs/by-name/ha/halp/package.nix +++ b/pkgs/by-name/ha/halp/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv -, darwin -, unixtools +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + darwin, + unixtools, }: rustPlatform.buildRustPackage rec { @@ -73,7 +74,10 @@ rustPlatform.buildRustPackage rec { description = "CLI tool to get help with CLI tools"; homepage = "https://github.com/orhun/halp"; changelog = "https://github.com/orhun/halp/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "halp"; }; diff --git a/pkgs/by-name/ha/hammer/package.nix b/pkgs/by-name/ha/hammer/package.nix index d47c62cf9d8534..20f8f0580ef5d8 100644 --- a/pkgs/by-name/ha/hammer/package.nix +++ b/pkgs/by-name/ha/hammer/package.nix @@ -1,9 +1,10 @@ -{ fetchFromGitLab -, glib -, lib -, pkg-config -, scons -, stdenv +{ + fetchFromGitLab, + glib, + lib, + pkg-config, + scons, + stdenv, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-xMZhUnycGeHkNZfHQ2d9mETti8HwGHZNskFqh9f0810="; }; - nativeBuildInputs = [ pkg-config scons ]; + nativeBuildInputs = [ + pkg-config + scons + ]; buildInputs = [ glib ]; meta = with lib; { diff --git a/pkgs/by-name/ha/hamsket/package.nix b/pkgs/by-name/ha/hamsket/package.nix index 7501bfda3ec5f3..94320d1c30d104 100644 --- a/pkgs/by-name/ha/hamsket/package.nix +++ b/pkgs/by-name/ha/hamsket/package.nix @@ -1,7 +1,8 @@ -{ lib -, appimageTools -, fetchurl -, makeDesktopItem +{ + lib, + appimageTools, + fetchurl, + makeDesktopItem, }: let @@ -13,13 +14,15 @@ let sha256 = "sha256-r85ZwcalBd/nCIBxOaQk7XClxj7VZtxwky4eWWm2tZ8="; }; - desktopItem = (makeDesktopItem { - desktopName = "Hamsket"; - name = pname; - exec = pname; - icon = pname; - categories = [ "Network" ]; - }); + desktopItem = ( + makeDesktopItem { + desktopName = "Hamsket"; + name = pname; + exec = pname; + icon = pname; + categories = [ "Network" ]; + } + ); appimageContents = appimageTools.extract { inherit pname version src; diff --git a/pkgs/by-name/ha/hamster/package.nix b/pkgs/by-name/ha/hamster/package.nix index e6e9fbea7722d1..a72f6ddbd7e51f 100644 --- a/pkgs/by-name/ha/hamster/package.nix +++ b/pkgs/by-name/ha/hamster/package.nix @@ -1,5 +1,18 @@ -{ lib, fetchFromGitHub, python3Packages, intltool, glib, itstool, gtk3 -, wrapGAppsHook3, gobject-introspection, pango, gdk-pixbuf, atk, wafHook }: +{ + lib, + fetchFromGitHub, + python3Packages, + intltool, + glib, + itstool, + gtk3, + wrapGAppsHook3, + gobject-introspection, + pango, + gdk-pixbuf, + atk, + wafHook, +}: python3Packages.buildPythonApplication rec { pname = "hamster"; diff --git a/pkgs/by-name/ha/hamtransfer/package.nix b/pkgs/by-name/ha/hamtransfer/package.nix index 49dbe40cd988b3..dc284589c6107b 100644 --- a/pkgs/by-name/ha/hamtransfer/package.nix +++ b/pkgs/by-name/ha/hamtransfer/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, protobuf -, sqlite +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + protobuf, + sqlite, }: rustPlatform.buildRustPackage { @@ -37,6 +38,10 @@ rustPlatform.buildRustPackage { description = "Tool for transferring files over amateur radio using modern techniques"; homepage = "https://github.com/ThomasHabets/hamtransfer"; license = licenses.gpl2Only; - maintainers = with maintainers; [ matthewcroughan sarcasticadmin pkharvey ]; + maintainers = with maintainers; [ + matthewcroughan + sarcasticadmin + pkharvey + ]; }; } diff --git a/pkgs/by-name/ha/hanazono/package.nix b/pkgs/by-name/ha/hanazono/package.nix index f6dd5baa60c2d5..a3e5cc7a1b5a53 100644 --- a/pkgs/by-name/ha/hanazono/package.nix +++ b/pkgs/by-name/ha/hanazono/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "hanazono"; @@ -35,7 +39,10 @@ stdenvNoCC.mkDerivation rec { # Unlimited permission is granted to use, copy, and distribute it, with # or without modification, either commercially and noncommercially. # THIS FONT IS PROVIDED "AS IS" WITHOUT WARRANTY. - license = [ licenses.ofl licenses.free ]; + license = [ + licenses.ofl + licenses.free + ]; maintainers = with maintainers; [ mathnerd314 ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/ha/handlr/package.nix b/pkgs/by-name/ha/handlr/package.nix index 612331138572f2..5b69d273faa9de 100644 --- a/pkgs/by-name/ha/handlr/package.nix +++ b/pkgs/by-name/ha/handlr/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, shared-mime-info, libiconv, installShellFiles }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + shared-mime-info, + libiconv, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "handlr"; @@ -13,7 +21,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-30fSOzWq1CoIabPWGWndi/SaCN/ckxjlbtzuwV8rk6M="; - nativeBuildInputs = [ installShellFiles shared-mime-info ]; + nativeBuildInputs = [ + installShellFiles + shared-mime-info + ]; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; preCheck = '' diff --git a/pkgs/by-name/ha/hannom/package.nix b/pkgs/by-name/ha/hannom/package.nix index d91de86c532be7..3495969e6abcb6 100644 --- a/pkgs/by-name/ha/hannom/package.nix +++ b/pkgs/by-name/ha/hannom/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "hannom"; diff --git a/pkgs/by-name/ha/hans/package.nix b/pkgs/by-name/ha/hans/package.nix index ac591c200fe22a..8314ef012ef20a 100644 --- a/pkgs/by-name/ha/hans/package.nix +++ b/pkgs/by-name/ha/hans/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, nettools }: +{ + lib, + stdenv, + fetchFromGitHub, + nettools, +}: stdenv.mkDerivation rec { pname = "hans"; diff --git a/pkgs/by-name/ha/hap-py/package.nix b/pkgs/by-name/ha/hap-py/package.nix index 9f06c822ae96f5..d953de197b31f2 100644 --- a/pkgs/by-name/ha/hap-py/package.nix +++ b/pkgs/by-name/ha/hap-py/package.nix @@ -20,7 +20,7 @@ let # Bcftools needs perl - runtime = [ + runtime = [ bcftools htslib my-python diff --git a/pkgs/by-name/ha/haproxy/package.nix b/pkgs/by-name/ha/haproxy/package.nix index cfb6ef7da7c16d..317097b28b5020 100644 --- a/pkgs/by-name/ha/haproxy/package.nix +++ b/pkgs/by-name/ha/haproxy/package.nix @@ -1,22 +1,28 @@ -{ useLua ? true -, usePcre ? true -, withPrometheusExporter ? true -, sslLibrary ? "quictls" -, stdenv -, lib -, fetchurl -, nixosTests -, zlib -, libxcrypt -, wolfssl -, libressl -, quictls -, openssl -, lua5_4 -, pcre2 +{ + useLua ? true, + usePcre ? true, + withPrometheusExporter ? true, + sslLibrary ? "quictls", + stdenv, + lib, + fetchurl, + nixosTests, + zlib, + libxcrypt, + wolfssl, + libressl, + quictls, + openssl, + lua5_4, + pcre2, }: -assert lib.assertOneOf "sslLibrary" sslLibrary [ "quictls" "openssl" "libressl" "wolfssl" ]; +assert lib.assertOneOf "sslLibrary" sslLibrary [ + "quictls" + "openssl" + "libressl" + "wolfssl" +]; let sslPkgs = { inherit quictls openssl libressl; @@ -26,7 +32,8 @@ let }; }; sslPkg = sslPkgs.${sslLibrary}; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "haproxy"; version = "3.1.0"; @@ -35,43 +42,65 @@ in stdenv.mkDerivation (finalAttrs: { hash = "sha256-VqFGhXSrQR3Kveg3+WvqbPPC65DieUafde0dzccPzhE="; }; - buildInputs = [ sslPkg zlib libxcrypt ] + buildInputs = + [ + sslPkg + zlib + libxcrypt + ] ++ lib.optional useLua lua5_4 ++ lib.optional usePcre pcre2; # TODO: make it work on bsd as well makeFlags = [ "PREFIX=${placeholder "out"}" - ("TARGET=" + (if stdenv.hostPlatform.isSunOS then "solaris" - else if stdenv.hostPlatform.isLinux then "linux-glibc" - else if stdenv.hostPlatform.isDarwin then "osx" - else "generic")) + ( + "TARGET=" + + ( + if stdenv.hostPlatform.isSunOS then + "solaris" + else if stdenv.hostPlatform.isLinux then + "linux-glibc" + else if stdenv.hostPlatform.isDarwin then + "osx" + else + "generic" + ) + ) ]; - buildFlags = [ - "USE_ZLIB=yes" - "USE_OPENSSL=yes" - "SSL_INC=${lib.getDev sslPkg}/include" - "SSL_LIB=${lib.getDev sslPkg}/lib" - "USE_QUIC=yes" - ] ++ lib.optionals (sslLibrary == "openssl") [ - "USE_QUIC_OPENSSL_COMPAT=yes" - ] ++ lib.optionals (sslLibrary == "wolfssl") [ - "USE_OPENSSL_WOLFSSL=yes" - ] ++ lib.optionals usePcre [ - "USE_PCRE2=yes" - "USE_PCRE2_JIT=yes" - ] ++ lib.optionals useLua [ - "USE_LUA=yes" - "LUA_LIB_NAME=lua" - "LUA_LIB=${lua5_4}/lib" - "LUA_INC=${lua5_4}/include" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "USE_SYSTEMD=yes" - "USE_GETADDRINFO=1" - ] ++ lib.optionals withPrometheusExporter [ - "USE_PROMEX=yes" - ] ++ [ "CC=${stdenv.cc.targetPrefix}cc" ]; + buildFlags = + [ + "USE_ZLIB=yes" + "USE_OPENSSL=yes" + "SSL_INC=${lib.getDev sslPkg}/include" + "SSL_LIB=${lib.getDev sslPkg}/lib" + "USE_QUIC=yes" + ] + ++ lib.optionals (sslLibrary == "openssl") [ + "USE_QUIC_OPENSSL_COMPAT=yes" + ] + ++ lib.optionals (sslLibrary == "wolfssl") [ + "USE_OPENSSL_WOLFSSL=yes" + ] + ++ lib.optionals usePcre [ + "USE_PCRE2=yes" + "USE_PCRE2_JIT=yes" + ] + ++ lib.optionals useLua [ + "USE_LUA=yes" + "LUA_LIB_NAME=lua" + "LUA_LIB=${lua5_4}/lib" + "LUA_INC=${lua5_4}/include" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "USE_SYSTEMD=yes" + "USE_GETADDRINFO=1" + ] + ++ lib.optionals withPrometheusExporter [ + "USE_PROMEX=yes" + ] + ++ [ "CC=${stdenv.cc.targetPrefix}cc" ]; enableParallelBuilding = true; @@ -81,7 +110,10 @@ in stdenv.mkDerivation (finalAttrs: { changelog = "https://www.haproxy.org/download/${lib.versions.majorMinor finalAttrs.version}/src/CHANGELOG"; description = "Reliable, high performance TCP/HTTP load balancer"; homepage = "https://haproxy.org"; - license = with lib.licenses; [ gpl2Plus lgpl21Only ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Only + ]; longDescription = '' HAProxy is a free, very fast and reliable solution offering high availability, load balancing, and proxying for TCP and HTTP-based diff --git a/pkgs/by-name/ha/hardinfo/package.nix b/pkgs/by-name/ha/hardinfo/package.nix index 808a36a015ec66..c7cb86f6d6ef03 100644 --- a/pkgs/by-name/ha/hardinfo/package.nix +++ b/pkgs/by-name/ha/hardinfo/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchurl, which, pkg-config, gtk2, pcre, glib, libxml2 -, libsoup_2_4 ? null +{ + lib, + stdenv, + fetchurl, + which, + pkg-config, + gtk2, + pcre, + glib, + libxml2, + libsoup_2_4 ? null, }: stdenv.mkDerivation rec { @@ -14,7 +23,14 @@ stdenv.mkDerivation rec { # Not adding 'hostname' command, the build shouldn't depend on what the build # host is called. nativeBuildInputs = [ pkg-config ]; - buildInputs = [ which gtk2 pcre glib libxml2 libsoup_2_4 ]; + buildInputs = [ + which + gtk2 + pcre + glib + libxml2 + libsoup_2_4 + ]; # Fixes '#error You must compile this program without "-O"' hardeningDisable = [ "all" ]; @@ -45,7 +61,10 @@ stdenv.mkDerivation rec { description = "Display information about your hardware and operating system"; license = licenses.gpl2Only; maintainers = with maintainers; [ bjornfor ]; - platforms = [ "x86_64-linux" "i686-linux" ]; # ARMv7 and AArch64 are unsupported + platforms = [ + "x86_64-linux" + "i686-linux" + ]; # ARMv7 and AArch64 are unsupported mainProgram = "hardinfo"; }; } diff --git a/pkgs/by-name/ha/harminv/package.nix b/pkgs/by-name/ha/harminv/package.nix index f9d8573ca6d5f8..f76504b64ba079 100644 --- a/pkgs/by-name/ha/harminv/package.nix +++ b/pkgs/by-name/ha/harminv/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, gfortran -, blas -, lapack +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gfortran, + blas, + lapack, }: assert !blas.isILP64; @@ -26,9 +27,15 @@ stdenv.mkDerivation rec { touch ChangeLog ''; - nativeBuildInputs = [ autoreconfHook gfortran ]; + nativeBuildInputs = [ + autoreconfHook + gfortran + ]; - buildInputs = [ blas lapack ]; + buildInputs = [ + blas + lapack + ]; configureFlags = [ "--enable-shared" @@ -39,7 +46,10 @@ stdenv.mkDerivation rec { description = "Harmonic inversion algorithm of Mandelshtam: decompose signal into sum of decaying sinusoids"; homepage = "https://github.com/NanoComp/harminv"; license = with licenses; [ gpl2Only ]; - maintainers = with maintainers; [ sheepforce markuskowa ]; + maintainers = with maintainers; [ + sheepforce + markuskowa + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/ha/harmonia/package.nix b/pkgs/by-name/ha/harmonia/package.nix index 2dad6fc1693f62..0d737c0efdca44 100644 --- a/pkgs/by-name/ha/harmonia/package.nix +++ b/pkgs/by-name/ha/harmonia/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, libsodium -, openssl -, pkg-config -, rustPlatform -, nix-update-script -, nixosTests +{ + lib, + fetchFromGitHub, + libsodium, + openssl, + pkg-config, + rustPlatform, + nix-update-script, + nixosTests, }: rustPlatform.buildRustPackage rec { @@ -24,11 +25,17 @@ rustPlatform.buildRustPackage rec { doCheck = false; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libsodium openssl ]; + buildInputs = [ + libsodium + openssl + ]; passthru = { updateScript = nix-update-script { - extraArgs = [ "--version-regex" "harmonia-v(.*)" ]; + extraArgs = [ + "--version-regex" + "harmonia-v(.*)" + ]; }; tests = { inherit (nixosTests) harmonia; }; }; diff --git a/pkgs/by-name/ha/harmonist/package.nix b/pkgs/by-name/ha/harmonist/package.nix index 34e996f499b97d..2e0ba2c05963fe 100644 --- a/pkgs/by-name/ha/harmonist/package.nix +++ b/pkgs/by-name/ha/harmonist/package.nix @@ -1,4 +1,8 @@ -{lib, fetchurl, buildGoModule}: +{ + lib, + fetchurl, + buildGoModule, +}: buildGoModule rec { pname = "harmonist"; @@ -11,7 +15,10 @@ buildGoModule rec { vendorHash = "sha256-0DV32a2LYnfYzg/tqwear9uaaahNUIi0M8uWlXOQ5Ic="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Stealth coffee-break roguelike game"; diff --git a/pkgs/by-name/ha/harsh/package.nix b/pkgs/by-name/ha/harsh/package.nix index be74f531d6a6c7..d9f1cd0d83f303 100644 --- a/pkgs/by-name/ha/harsh/package.nix +++ b/pkgs/by-name/ha/harsh/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ha/has/package.nix b/pkgs/by-name/ha/has/package.nix index 6fa84195a2f067..8f629a440a72a3 100644 --- a/pkgs/by-name/ha/has/package.nix +++ b/pkgs/by-name/ha/has/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation (finalAttrs: rec { pname = "has"; diff --git a/pkgs/by-name/ha/hase/package.nix b/pkgs/by-name/ha/hase/package.nix index 20e1afa56d39bd..715856d7ee6d02 100644 --- a/pkgs/by-name/ha/hase/package.nix +++ b/pkgs/by-name/ha/hase/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, sparrow3d -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + sparrow3d, + zlib, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ha/hash-identifier/package.nix b/pkgs/by-name/ha/hash-identifier/package.nix index 0fe78a4a0db519..48106b2eecf782 100644 --- a/pkgs/by-name/ha/hash-identifier/package.nix +++ b/pkgs/by-name/ha/hash-identifier/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitLab, python3Packages }: +{ + lib, + fetchFromGitLab, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "hash-identifier"; diff --git a/pkgs/by-name/ha/hash-slinger/package.nix b/pkgs/by-name/ha/hash-slinger/package.nix index cb02b806a986c1..2915b24014b601 100644 --- a/pkgs/by-name/ha/hash-slinger/package.nix +++ b/pkgs/by-name/ha/hash-slinger/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 -, unbound -, libreswan +{ + lib, + stdenv, + fetchFromGitHub, + python3, + unbound, + libreswan, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ha/hash_extender/package.nix b/pkgs/by-name/ha/hash_extender/package.nix index 10f82ca77e71be..0c24640efe0a44 100644 --- a/pkgs/by-name/ha/hash_extender/package.nix +++ b/pkgs/by-name/ha/hash_extender/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + openssl, +}: stdenv.mkDerivation { pname = "hash_extender"; diff --git a/pkgs/by-name/ha/hashcash/package.nix b/pkgs/by-name/ha/hashcash/package.nix index 8b1fdea1c935cb..db70ed37b1dc99 100644 --- a/pkgs/by-name/ha/hashcash/package.nix +++ b/pkgs/by-name/ha/hashcash/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, openssl }: +{ + lib, + stdenv, + fetchurl, + openssl, +}: stdenv.mkDerivation rec { pname = "hashcash"; diff --git a/pkgs/by-name/ha/hashcat-utils/package.nix b/pkgs/by-name/ha/hashcat-utils/package.nix index f252c7eedce763..63f99e2baf8628 100644 --- a/pkgs/by-name/ha/hashcat-utils/package.nix +++ b/pkgs/by-name/ha/hashcat-utils/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "hashcat-utils"; diff --git a/pkgs/by-name/ha/hashdeep/package.nix b/pkgs/by-name/ha/hashdeep/package.nix index c870353d75b5a1..0b6fe047cecd61 100644 --- a/pkgs/by-name/ha/hashdeep/package.nix +++ b/pkgs/by-name/ha/hashdeep/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "hashdeep"; diff --git a/pkgs/by-name/ha/hashi-ui/package.nix b/pkgs/by-name/ha/hashi-ui/package.nix index db4f6fc00091dc..104b2ca0e6f367 100644 --- a/pkgs/by-name/ha/hashi-ui/package.nix +++ b/pkgs/by-name/ha/hashi-ui/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "hashi-ui"; diff --git a/pkgs/by-name/ha/hashi-up/package.nix b/pkgs/by-name/ha/hashi-up/package.nix index 60284c1fec2863..29f0e3875c7be1 100644 --- a/pkgs/by-name/ha/hashi-up/package.nix +++ b/pkgs/by-name/ha/hashi-up/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ha/hashid/package.nix b/pkgs/by-name/ha/hashid/package.nix index 5da915380ff1e5..986e694a884c63 100644 --- a/pkgs/by-name/ha/hashid/package.nix +++ b/pkgs/by-name/ha/hashid/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3Packages +{ + lib, + fetchFromGitHub, + python3Packages, }: python3Packages.buildPythonApplication { diff --git a/pkgs/by-name/ha/hashit/package.nix b/pkgs/by-name/ha/hashit/package.nix index 5e9f07700dc28e..57a7d39612e66f 100644 --- a/pkgs/by-name/ha/hashit/package.nix +++ b/pkgs/by-name/ha/hashit/package.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, nix-update-script, meson, ninja, pkg-config, vala, pantheon, python3, libgee, gtk3, desktop-file-utils, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + pantheon, + python3, + libgee, + gtk3, + desktop-file-utils, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "hashit"; diff --git a/pkgs/by-name/ha/hashpump/package.nix b/pkgs/by-name/ha/hashpump/package.nix index cdb153f2c08029..e894380898b9f4 100644 --- a/pkgs/by-name/ha/hashpump/package.nix +++ b/pkgs/by-name/ha/hashpump/package.nix @@ -1,4 +1,9 @@ -{ stdenv, fetchFromGitHub, openssl, lib }: +{ + stdenv, + fetchFromGitHub, + openssl, + lib, +}: stdenv.mkDerivation (finalAttrs: { pname = "hashpump"; diff --git a/pkgs/by-name/ha/hashrat/package.nix b/pkgs/by-name/ha/hashrat/package.nix index f7ebc1179093fe..e63122a05ef7c2 100644 --- a/pkgs/by-name/ha/hashrat/package.nix +++ b/pkgs/by-name/ha/hashrat/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ha/hasklig/package.nix b/pkgs/by-name/ha/hasklig/package.nix index 5868452c5793ba..3b83b91576b3f7 100644 --- a/pkgs/by-name/ha/hasklig/package.nix +++ b/pkgs/by-name/ha/hasklig/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "hasklig"; diff --git a/pkgs/by-name/ha/hasmail/package.nix b/pkgs/by-name/ha/hasmail/package.nix index 9f148618b254f2..8c4317b13eb887 100644 --- a/pkgs/by-name/ha/hasmail/package.nix +++ b/pkgs/by-name/ha/hasmail/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, pkg-config -, pango -, cairo -, gtk2 +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + pango, + cairo, + gtk2, }: buildGoModule rec { diff --git a/pkgs/by-name/ha/haste-server/package.nix b/pkgs/by-name/ha/haste-server/package.nix index 30c98f298d41f0..289449cf7b39a6 100644 --- a/pkgs/by-name/ha/haste-server/package.nix +++ b/pkgs/by-name/ha/haste-server/package.nix @@ -1,7 +1,8 @@ -{ lib -, nixosTests -, buildNpmPackage -, fetchFromGitHub +{ + lib, + nixosTests, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ha/hatari/package.nix b/pkgs/by-name/ha/hatari/package.nix index a7519eb49ecf13..5b654b3ab0d465 100644 --- a/pkgs/by-name/ha/hatari/package.nix +++ b/pkgs/by-name/ha/hatari/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, zlib, SDL, cmake }: +{ + lib, + stdenv, + fetchurl, + zlib, + SDL, + cmake, +}: stdenv.mkDerivation rec { pname = "hatari"; @@ -13,7 +20,10 @@ stdenv.mkDerivation rec { cmakeFlags = [ "-DCMAKE_EXE_LINKER_FLAGS=-lgcc_s" ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ zlib SDL ]; + buildInputs = [ + zlib + SDL + ]; meta = { homepage = "http://hatari.tuxfamily.org/"; diff --git a/pkgs/by-name/ha/haunt/tests/001-test-version.nix b/pkgs/by-name/ha/haunt/tests/001-test-version.nix index 026d580c1965f0..09ef5b32947d31 100644 --- a/pkgs/by-name/ha/haunt/tests/001-test-version.nix +++ b/pkgs/by-name/ha/haunt/tests/001-test-version.nix @@ -1,5 +1,6 @@ -{ stdenv -, haunt +{ + stdenv, + haunt, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ha/haveged/package.nix b/pkgs/by-name/ha/haveged/package.nix index ef7702559d6d4a..266c31d2fe4f46 100644 --- a/pkgs/by-name/ha/haveged/package.nix +++ b/pkgs/by-name/ha/haveged/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ha/havoc/package.nix b/pkgs/by-name/ha/havoc/package.nix index 81b8177c4ec890..7dc9af73d5e311 100644 --- a/pkgs/by-name/ha/havoc/package.nix +++ b/pkgs/by-name/ha/havoc/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, libxkbcommon -, pkg-config -, wayland -, wayland-protocols -, wayland-scanner +{ + lib, + stdenv, + fetchFromGitHub, + libxkbcommon, + pkg-config, + wayland, + wayland-protocols, + wayland-scanner, }: stdenv.mkDerivation (finalAttrs: { @@ -47,7 +48,10 @@ stdenv.mkDerivation (finalAttrs: { meta = { homepage = "https://github.com/ii8/havoc"; description = "Minimal terminal emulator for Wayland"; - license = with lib.licenses; [ mit publicDomain ]; + license = with lib.licenses; [ + mit + publicDomain + ]; mainProgram = "havoc"; maintainers = with lib.maintainers; [ AndersonTorres ]; inherit (wayland.meta) platforms; diff --git a/pkgs/by-name/ha/hawknl/package.nix b/pkgs/by-name/ha/hawknl/package.nix index 6d60d62fcce766..b13b4567860bff 100644 --- a/pkgs/by-name/ha/hawknl/package.nix +++ b/pkgs/by-name/ha/hawknl/package.nix @@ -1,11 +1,18 @@ -{lib, stdenv, fetchurl, unzip}: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "hawknl"; version = "1.68"; src = fetchurl { - url = "http://urchlay.naptime.net/~urchlay/src/HawkNL${lib.replaceStrings ["."] [""] version}src.zip"; + url = "http://urchlay.naptime.net/~urchlay/src/HawkNL${ + lib.replaceStrings [ "." ] [ "" ] version + }src.zip"; sha256 = "11shn2fbxj3w0j77w0234pqyj1368x686kkgv09q5yqhi1cdp028"; }; diff --git a/pkgs/by-name/ha/hax11/package.nix b/pkgs/by-name/ha/hax11/package.nix index ee90eb0e727f14..5384bf28ee3ae9 100644 --- a/pkgs/by-name/ha/hax11/package.nix +++ b/pkgs/by-name/ha/hax11/package.nix @@ -1,10 +1,11 @@ -{ lib -, multiStdenv -, fetchFromGitHub -, libX11 -, libXxf86vm -, xorgproto -, unstableGitUpdater +{ + lib, + multiStdenv, + fetchFromGitHub, + libX11, + libXxf86vm, + xorgproto, + unstableGitUpdater, }: multiStdenv.mkDerivation (finalAttrs: { @@ -18,7 +19,10 @@ multiStdenv.mkDerivation (finalAttrs: { hash = "sha256-ND3N1oMUjmDkF7btcFucDxKxxANL9IKf08/6Kt6LX9o="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; buildInputs = [ libX11 diff --git a/pkgs/by-name/ha/haxor-news/package.nix b/pkgs/by-name/ha/haxor-news/package.nix index 8eedf7bc47b532..0ec51f9fb35561 100644 --- a/pkgs/by-name/ha/haxor-news/package.nix +++ b/pkgs/by-name/ha/haxor-news/package.nix @@ -1,5 +1,9 @@ -{ lib, fetchFromGitHub, fetchPypi, python3 }: - +{ + lib, + fetchFromGitHub, + fetchPypi, + python3, +}: let py = python3.override { @@ -53,9 +57,16 @@ buildPythonApplication rec { # will fail without pre-seeded config files doCheck = false; - nativeCheckInputs = [ unittestCheckHook mock ]; + nativeCheckInputs = [ + unittestCheckHook + mock + ]; - unittestFlagsArray = [ "-s" "tests" "-v" ]; + unittestFlagsArray = [ + "-s" + "tests" + "-v" + ]; meta = with lib; { homepage = "https://github.com/donnemartin/haxor-news"; diff --git a/pkgs/by-name/ha/hayabusa/package.nix b/pkgs/by-name/ha/hayabusa/package.nix index 4c30a16cd468fb..830cb388e9aeb2 100644 --- a/pkgs/by-name/ha/hayabusa/package.nix +++ b/pkgs/by-name/ha/hayabusa/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, vulkan-loader +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + vulkan-loader, }: rustPlatform.buildRustPackage { diff --git a/pkgs/by-name/ha/hayagriva/package.nix b/pkgs/by-name/ha/hayagriva/package.nix index c668cd8bb259b0..cb89cc09a5bffd 100644 --- a/pkgs/by-name/ha/hayagriva/package.nix +++ b/pkgs/by-name/ha/hayagriva/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -29,7 +30,10 @@ rustPlatform.buildRustPackage rec { description = "Work with references: Literature database management, storage, and citation formatting"; homepage = "https://github.com/typst/hayagriva"; changelog = "https://github.com/typst/hayagriva/releases/tag/v${version}"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "hayagriva"; }; diff --git a/pkgs/by-name/hb/hb-honeypot/package.nix b/pkgs/by-name/hb/hb-honeypot/package.nix index 9af60395731e0a..45ec85a3e8cf2f 100644 --- a/pkgs/by-name/hb/hb-honeypot/package.nix +++ b/pkgs/by-name/hb/hb-honeypot/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, perl +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + perl, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/hb/hblock/package.nix b/pkgs/by-name/hb/hblock/package.nix index 329dadedbad29f..67294d37ff9d16 100644 --- a/pkgs/by-name/hb/hblock/package.nix +++ b/pkgs/by-name/hb/hblock/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, coreutils -, gawk -, curl -, gnugrep +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + coreutils, + gawk, + curl, + gnugrep, }: stdenv.mkDerivation rec { @@ -19,7 +20,12 @@ stdenv.mkDerivation rec { hash = "sha256-XnBmKOZBHWyjNlv+L24LYns05oGTOJnNNzM0jCwZMuI="; }; - buildInputs = [ coreutils curl gnugrep gawk ]; + buildInputs = [ + coreutils + curl + gnugrep + gawk + ]; nativeBuildInputs = [ makeWrapper ]; installFlags = [ @@ -27,7 +33,14 @@ stdenv.mkDerivation rec { ]; postInstall = '' wrapProgram "$out/bin/hblock" \ - --prefix PATH : ${lib.makeBinPath [ coreutils curl gnugrep gawk ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + curl + gnugrep + gawk + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/hc/hck/package.nix b/pkgs/by-name/hc/hck/package.nix index bf3c023c786517..335fa9ab113800 100644 --- a/pkgs/by-name/hc/hck/package.nix +++ b/pkgs/by-name/hc/hck/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, cmake +{ + lib, + rustPlatform, + fetchFromGitHub, + cmake, }: rustPlatform.buildRustPackage rec { @@ -23,8 +24,14 @@ rustPlatform.buildRustPackage rec { description = "Close to drop in replacement for cut that can use a regex delimiter instead of a fixed string"; homepage = "https://github.com/sstadick/hck"; changelog = "https://github.com/sstadick/hck/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ mit /* or */ unlicense ]; - maintainers = with maintainers; [ figsoda gepbird ]; + license = with licenses; [ + mit # or + unlicense + ]; + maintainers = with maintainers; [ + figsoda + gepbird + ]; mainProgram = "hck"; }; } diff --git a/pkgs/by-name/hc/hcl2json/package.nix b/pkgs/by-name/hc/hcl2json/package.nix index 08dfd67d251162..fc7860f354c255 100644 --- a/pkgs/by-name/hc/hcl2json/package.nix +++ b/pkgs/by-name/hc/hcl2json/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/hc/hcledit/package.nix b/pkgs/by-name/hc/hcledit/package.nix index 2328840648c131..671dfb4ed38319 100644 --- a/pkgs/by-name/hc/hcledit/package.nix +++ b/pkgs/by-name/hc/hcledit/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/hc/hclfmt/package.nix b/pkgs/by-name/hc/hclfmt/package.nix index 1ed93c4b69d758..a5770aef2aeab6 100644 --- a/pkgs/by-name/hc/hclfmt/package.nix +++ b/pkgs/by-name/hc/hclfmt/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "hclfmt"; diff --git a/pkgs/by-name/hc/hcloud/package.nix b/pkgs/by-name/hc/hcloud/package.nix index c9549ba22951c8..483268680e0629 100644 --- a/pkgs/by-name/hc/hcloud/package.nix +++ b/pkgs/by-name/hc/hcloud/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -40,6 +41,9 @@ buildGoModule rec { mainProgram = "hcloud"; homepage = "https://github.com/hetznercloud/cli"; license = licenses.mit; - maintainers = with maintainers; [ zauberpony techknowlogick ]; + maintainers = with maintainers; [ + zauberpony + techknowlogick + ]; }; } diff --git a/pkgs/by-name/hc/hcxdumptool/package.nix b/pkgs/by-name/hc/hcxdumptool/package.nix index c718ec0b5a0f1b..9072ec49a6c72d 100644 --- a/pkgs/by-name/hc/hcxdumptool/package.nix +++ b/pkgs/by-name/hc/hcxdumptool/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, openssl }: +{ + stdenv, + lib, + fetchFromGitHub, + openssl, +}: stdenv.mkDerivation rec { pname = "hcxdumptool"; diff --git a/pkgs/by-name/hc/hcxtools/package.nix b/pkgs/by-name/hc/hcxtools/package.nix index bde3dc8adec99a..05f18f23b421a7 100644 --- a/pkgs/by-name/hc/hcxtools/package.nix +++ b/pkgs/by-name/hc/hcxtools/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, curl, openssl, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + curl, + openssl, + zlib, +}: stdenv.mkDerivation rec { pname = "hcxtools"; @@ -12,7 +20,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ curl openssl zlib ]; + buildInputs = [ + curl + openssl + zlib + ]; makeFlags = [ "PREFIX=${placeholder "out"}" diff --git a/pkgs/by-name/hd/hd-idle/package.nix b/pkgs/by-name/hd/hd-idle/package.nix index 7c2ac2894a55b1..c87179f74c1aa6 100644 --- a/pkgs/by-name/hd/hd-idle/package.nix +++ b/pkgs/by-name/hd/hd-idle/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "hd-idle"; diff --git a/pkgs/by-name/hd/hdaps-gl/package.nix b/pkgs/by-name/hd/hdaps-gl/package.nix index d472727ce3acc9..0152919e9b1784 100644 --- a/pkgs/by-name/hd/hdaps-gl/package.nix +++ b/pkgs/by-name/hd/hdaps-gl/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libglut, libGL, libGLU }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libglut, + libGL, + libGLU, +}: stdenv.mkDerivation rec { pname = "hdaps-gl"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ libglut libGL libGLU ]; + buildInputs = [ + libglut + libGL + libGLU + ]; meta = with lib; { description = "GL-based laptop model that rotates in real-time via hdaps"; diff --git a/pkgs/by-name/hd/hdapsd/package.nix b/pkgs/by-name/hd/hdapsd/package.nix index 43700d20aa9aa6..76e2dc4c4fc439 100644 --- a/pkgs/by-name/hd/hdapsd/package.nix +++ b/pkgs/by-name/hd/hdapsd/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "hdapsd"; @@ -11,12 +15,12 @@ stdenv.mkDerivation rec { postInstall = builtins.readFile ./postInstall.sh; - meta = with lib; - { description = "Hard Drive Active Protection System Daemon"; - mainProgram = "hdapsd"; - homepage = "http://hdaps.sf.net/"; - license = licenses.gpl2Plus; - platforms = platforms.linux; - maintainers = [ maintainers.ehmry ]; - }; + meta = with lib; { + description = "Hard Drive Active Protection System Daemon"; + mainProgram = "hdapsd"; + homepage = "http://hdaps.sf.net/"; + license = licenses.gpl2Plus; + platforms = platforms.linux; + maintainers = [ maintainers.ehmry ]; + }; } diff --git a/pkgs/by-name/hd/hdate/package.nix b/pkgs/by-name/hd/hdate/package.nix index 899630b6909909..cb7b8fcf4ada91 100644 --- a/pkgs/by-name/hd/hdate/package.nix +++ b/pkgs/by-name/hd/hdate/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "1.6.02"; diff --git a/pkgs/by-name/hd/hddfancontrol/package.nix b/pkgs/by-name/hd/hddfancontrol/package.nix index 7af08d9108bfd3..1f6770731f0f91 100644 --- a/pkgs/by-name/hd/hddfancontrol/package.nix +++ b/pkgs/by-name/hd/hddfancontrol/package.nix @@ -1,4 +1,12 @@ -{ lib, python3Packages, fetchFromGitHub, hddtemp, hdparm, smartmontools, nixosTests }: +{ + lib, + python3Packages, + fetchFromGitHub, + hddtemp, + hdparm, + smartmontools, + nixosTests, +}: python3Packages.buildPythonPackage rec { pname = "hddfancontrol"; diff --git a/pkgs/by-name/hd/hddtemp/package.nix b/pkgs/by-name/hd/hddtemp/package.nix index 17313e8d17ab6b..ab315202405ec1 100644 --- a/pkgs/by-name/hd/hddtemp/package.nix +++ b/pkgs/by-name/hd/hddtemp/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let db = fetchurl { url = "mirror://savannah/hddtemp/hddtemp.db"; @@ -16,7 +20,12 @@ stdenv.mkDerivation rec { }; # from Gentoo - patches = [ ./byteswap.patch ./dontwake.patch ./execinfo.patch ./satacmds.patch ]; + patches = [ + ./byteswap.patch + ./dontwake.patch + ./execinfo.patch + ./satacmds.patch + ]; configureFlags = [ "--with-db-path=${placeholder "out"}/share/hddtemp/hddtemp.db" diff --git a/pkgs/by-name/hd/hdf5-blosc/package.nix b/pkgs/by-name/hd/hdf5-blosc/package.nix index 985660ff9073d8..02682cd81f04c1 100644 --- a/pkgs/by-name/hd/hdf5-blosc/package.nix +++ b/pkgs/by-name/hd/hdf5-blosc/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, c-blosc, cmake, hdf5, fetchFromGitHub }: +{ + lib, + stdenv, + c-blosc, + cmake, + hdf5, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "hdf5-blosc"; @@ -7,16 +14,23 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "Blosc"; repo = pname; - rev = "v${version}"; + rev = "v${version}"; sha256 = "1nj2bm1v6ymm3fmyvhbn6ih5fgdiapavlfghh1pvbmhw71cysyqs"; }; patches = [ ./no-external-blosc.patch ]; - outputs = [ "out" "dev" "plugin" ]; + outputs = [ + "out" + "dev" + "plugin" + ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ c-blosc hdf5 ]; + buildInputs = [ + c-blosc + hdf5 + ]; preConfigure = '' substituteInPlace CMakeLists.txt --replace 'set(BLOSC_INSTALL_DIR "''${CMAKE_CURRENT_BINARY_DIR}/blosc")' 'set(BLOSC_INSTALL_DIR "${c-blosc}")' diff --git a/pkgs/by-name/hd/hdhomerun-config-gui/package.nix b/pkgs/by-name/hd/hdhomerun-config-gui/package.nix index c5ed409117e3fe..4256102988f9b8 100644 --- a/pkgs/by-name/hd/hdhomerun-config-gui/package.nix +++ b/pkgs/by-name/hd/hdhomerun-config-gui/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, libhdhomerun, pkg-config, gtk2 }: +{ + lib, + stdenv, + fetchurl, + libhdhomerun, + pkg-config, + gtk2, +}: stdenv.mkDerivation rec { pname = "hdhomerun-config-gui"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk2 libhdhomerun ]; + buildInputs = [ + gtk2 + libhdhomerun + ]; configureFlags = [ "CPPFLAGS=-I${libhdhomerun}/include/hdhomerun" ]; makeFlags = [ "SUBDIRS=src" ]; diff --git a/pkgs/by-name/hd/hdl-dump/package.nix b/pkgs/by-name/hd/hdl-dump/package.nix index 8990a447dc0ced..9f8d6dff3249da 100644 --- a/pkgs/by-name/hd/hdl-dump/package.nix +++ b/pkgs/by-name/hd/hdl-dump/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/hd/hdparm/package.nix b/pkgs/by-name/hd/hdparm/package.nix index 156901d3643d72..0ca1d37c4888c7 100644 --- a/pkgs/by-name/hd/hdparm/package.nix +++ b/pkgs/by-name/hd/hdparm/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation (finalAttrs: { pname = "hdparm"; diff --git a/pkgs/by-name/hd/hdt/package.nix b/pkgs/by-name/hd/hdt/package.nix index e7c46d78588dd6..179054dcab06c4 100644 --- a/pkgs/by-name/hd/hdt/package.nix +++ b/pkgs/by-name/hd/hdt/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, libtool, pkg-config, zlib, serd }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + libtool, + pkg-config, + zlib, + serd, +}: stdenv.mkDerivation rec { pname = "hdt"; @@ -21,9 +31,16 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ zlib serd ]; + buildInputs = [ + zlib + serd + ]; - nativeBuildInputs = [ autoreconfHook libtool pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + libtool + pkg-config + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/he/headache/package.nix b/pkgs/by-name/he/headache/package.nix index 93077f31104db8..bb4747960b8335 100644 --- a/pkgs/by-name/he/headache/package.nix +++ b/pkgs/by-name/he/headache/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, nix-update-script, ocamlPackages, darwin }: +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + ocamlPackages, + darwin, +}: let inherit (ocamlPackages) buildDunePackage camomile; diff --git a/pkgs/by-name/he/headlines/package.nix b/pkgs/by-name/he/headlines/package.nix index 0ab9b639769bbb..74b01862ad1904 100644 --- a/pkgs/by-name/he/headlines/package.nix +++ b/pkgs/by-name/he/headlines/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, cmake -, pkg-config -, libmicrohttpd -, curl -, openssl -, jsoncpp -, libxml2 -, gst_all_1 -, boost -, websocketpp -, libadwaita -, gtkmm4 -, libsecret -, fetchFromGitLab -, wrapGAppsHook4 -, xdg-utils -, youtube-dl -, ffmpeg +{ + lib, + stdenv, + cmake, + pkg-config, + libmicrohttpd, + curl, + openssl, + jsoncpp, + libxml2, + gst_all_1, + boost, + websocketpp, + libadwaita, + gtkmm4, + libsecret, + fetchFromGitLab, + wrapGAppsHook4, + xdg-utils, + youtube-dl, + ffmpeg, }: stdenv.mkDerivation rec { @@ -37,28 +38,36 @@ stdenv.mkDerivation rec { wrapGAppsHook4 ]; - buildInputs = [ - libmicrohttpd - curl - openssl - jsoncpp - libxml2 - boost - websocketpp - libadwaita - gtkmm4 - libsecret - ] ++ (with gst_all_1; [ - gstreamer - gst-libav - gst-plugins-base - (gst-plugins-good.override { gtkSupport = true; }) - gst-plugins-bad - ]); + buildInputs = + [ + libmicrohttpd + curl + openssl + jsoncpp + libxml2 + boost + websocketpp + libadwaita + gtkmm4 + libsecret + ] + ++ (with gst_all_1; [ + gstreamer + gst-libav + gst-plugins-base + (gst-plugins-good.override { gtkSupport = true; }) + gst-plugins-bad + ]); preFixup = '' gappsWrapperArgs+=( - --prefix PATH : "${lib.makeBinPath [ xdg-utils youtube-dl ffmpeg ]}" + --prefix PATH : "${ + lib.makeBinPath [ + xdg-utils + youtube-dl + ffmpeg + ] + }" ) ''; diff --git a/pkgs/by-name/he/headphones-toolbox/package.nix b/pkgs/by-name/he/headphones-toolbox/package.nix index 2eb5257fee2505..550fe4e55f4267 100644 --- a/pkgs/by-name/he/headphones-toolbox/package.nix +++ b/pkgs/by-name/he/headphones-toolbox/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, dpkg -, fetchurl -, autoPatchelfHook -, webkitgtk_4_0 +{ + lib, + stdenv, + dpkg, + fetchurl, + autoPatchelfHook, + webkitgtk_4_0, }: stdenv.mkDerivation (finalAttrs: { @@ -38,7 +39,10 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "UI for configuring Ploopy Headphones"; homepage = "https://github.com/ploopyco/headphones-toolbox/"; - maintainers = with maintainers; [ knarkzel nyabinary ]; + maintainers = with maintainers; [ + knarkzel + nyabinary + ]; license = licenses.gpl3Only; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; platforms = [ "x86_64-linux" ]; diff --git a/pkgs/by-name/he/headphones/package.nix b/pkgs/by-name/he/headphones/package.nix index fa33d16961fe27..816dee0e0d1a45 100644 --- a/pkgs/by-name/he/headphones/package.nix +++ b/pkgs/by-name/he/headphones/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, python3, makeWrapper }: +{ + lib, + fetchFromGitHub, + python3, + makeWrapper, +}: python3.pkgs.buildPythonApplication rec { pname = "headphones"; @@ -32,8 +37,8 @@ python3.pkgs.buildPythonApplication rec { meta = with lib; { description = "Automatic music downloader for SABnzbd"; - license = licenses.gpl3Plus; - homepage = "https://github.com/rembo10/headphones"; + license = licenses.gpl3Plus; + homepage = "https://github.com/rembo10/headphones"; maintainers = with lib.maintainers; [ rembo10 ]; mainProgram = "headphones"; }; diff --git a/pkgs/by-name/he/headset-charge-indicator/package.nix b/pkgs/by-name/he/headset-charge-indicator/package.nix index d365b4a5c67370..f5df4146a645d0 100644 --- a/pkgs/by-name/he/headset-charge-indicator/package.nix +++ b/pkgs/by-name/he/headset-charge-indicator/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, headsetcontrol, wrapGAppsHook3, python3, gtk3 -, gobject-introspection, libayatana-appindicator }: +{ + lib, + stdenv, + fetchFromGitHub, + headsetcontrol, + wrapGAppsHook3, + python3, + gtk3, + gobject-introspection, + libayatana-appindicator, +}: stdenv.mkDerivation rec { # The last versioned release is 1.0.0.0 from 2020, since then there were updates but no versioned release. @@ -14,7 +23,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-eaAbqeFY+B3CcKJywC3vaRsWZNQENTbALc7L7uW0W6U="; }; - nativeBuildInputs = [ wrapGAppsHook3 gobject-introspection ]; + nativeBuildInputs = [ + wrapGAppsHook3 + gobject-introspection + ]; buildInputs = [ (python3.withPackages (ps: with ps; [ pygobject3 ])) @@ -51,10 +63,8 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/centic9/headset-charge-indicator"; - description = - "A app-indicator for GNOME desktops for controlling some features of various wireless headsets"; - longDescription = - "A simple app-indicator for GNOME desktops to display the battery charge of some wireless headsets which also allows to control some functions like LEDs, sidetone and others."; + description = "A app-indicator for GNOME desktops for controlling some features of various wireless headsets"; + longDescription = "A simple app-indicator for GNOME desktops to display the battery charge of some wireless headsets which also allows to control some functions like LEDs, sidetone and others."; platforms = platforms.linux; maintainers = with maintainers; [ zebreus ]; license = licenses.bsd2; diff --git a/pkgs/by-name/he/headset/package.nix b/pkgs/by-name/he/headset/package.nix index 4d9ca19f50e130..d0288b78f1baa9 100644 --- a/pkgs/by-name/he/headset/package.nix +++ b/pkgs/by-name/he/headset/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, dpkg -, makeWrapper -, electron +{ + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + electron, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { dontConfigure = true; dontBuild = true; - nativeBuildInputs = [ makeWrapper dpkg ]; + nativeBuildInputs = [ + makeWrapper + dpkg + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/he/headsetcontrol/package.nix b/pkgs/by-name/he/headsetcontrol/package.nix index d1d7a754169068..4ca12f94739dbc 100644 --- a/pkgs/by-name/he/headsetcontrol/package.nix +++ b/pkgs/by-name/he/headsetcontrol/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, cmake -, hidapi +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, + hidapi, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/he/health-check/package.nix b/pkgs/by-name/he/health-check/package.nix index e55433c0a70bd5..9c1ab924fec9f8 100644 --- a/pkgs/by-name/he/health-check/package.nix +++ b/pkgs/by-name/he/health-check/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, json_c, libbsd }: +{ + stdenv, + lib, + fetchFromGitHub, + json_c, + libbsd, +}: stdenv.mkDerivation rec { pname = "health-check"; @@ -11,9 +17,15 @@ stdenv.mkDerivation rec { hash = "sha256-CPKXpPpdagq3UnTk8Z58WtSPek8L79totKX+Uh6foVg="; }; - buildInputs = [ json_c libbsd ]; + buildInputs = [ + json_c + libbsd + ]; - makeFlags = [ "JSON_OUTPUT=y" "FNOTIFY=y" ]; + makeFlags = [ + "JSON_OUTPUT=y" + "FNOTIFY=y" + ]; installFlags = [ "BINDIR=${placeholder "out"}/bin" diff --git a/pkgs/by-name/he/health/package.nix b/pkgs/by-name/he/health/package.nix index 499a190dd3550a..67ef4fb49a43c9 100644 --- a/pkgs/by-name/he/health/package.nix +++ b/pkgs/by-name/he/health/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, cargo -, wrapGAppsHook4 -, blueprint-compiler -, libadwaita -, libsecret -, tinysparql -, darwin +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + cargo, + wrapGAppsHook4, + blueprint-compiler, + libadwaita, + libsecret, + tinysparql, + darwin, }: stdenv.mkDerivation rec { @@ -44,18 +45,22 @@ stdenv.mkDerivation rec { blueprint-compiler ]; - buildInputs = [ - libadwaita - libsecret - tinysparql - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + libadwaita + libsecret + tinysparql + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.Foundation + ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-error=incompatible-function-pointer-types" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-error=incompatible-function-pointer-types" + ] + ); meta = with lib; { description = "Health tracking app for the GNOME desktop"; diff --git a/pkgs/by-name/he/healthchecks/package.nix b/pkgs/by-name/he/healthchecks/package.nix index 1f359ead81f158..043431c53a3bb7 100644 --- a/pkgs/by-name/he/healthchecks/package.nix +++ b/pkgs/by-name/he/healthchecks/package.nix @@ -1,8 +1,9 @@ -{ lib -, writeText -, fetchFromGitHub -, nixosTests -, python3 +{ + lib, + writeText, + fetchFromGitHub, + nixosTests, + python3, }: let py = python3.override { @@ -65,14 +66,14 @@ py.pkgs.buildPythonApplication rec { STATIC_ROOT = os.getenv("STATIC_ROOT") - ${lib.concatLines (map - (secret: '' + ${lib.concatLines ( + map (secret: '' ${secret}_FILE = os.getenv("${secret}_FILE") if ${secret}_FILE: with open(${secret}_FILE, "r") as file: ${secret} = file.readline() - '') - secrets)} + '') secrets + )} ''; installPhase = '' diff --git a/pkgs/by-name/he/heatseeker/package.nix b/pkgs/by-name/he/heatseeker/package.nix index 79377f0f22ac75..10d1772dad59a4 100644 --- a/pkgs/by-name/he/heatseeker/package.nix +++ b/pkgs/by-name/he/heatseeker/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, rustPlatform, coreutils }: +{ + lib, + fetchFromGitHub, + rustPlatform, + coreutils, +}: rustPlatform.buildRustPackage rec { pname = "heatseeker"; diff --git a/pkgs/by-name/he/heatshrink/package.nix b/pkgs/by-name/he/heatshrink/package.nix index b7508030f9cc45..ec5a15b23a7956 100644 --- a/pkgs/by-name/he/heatshrink/package.nix +++ b/pkgs/by-name/he/heatshrink/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fetchpatch, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/he/hebcal/package.nix b/pkgs/by-name/he/hebcal/package.nix index d8a2b3b7295b84..c21900545a890a 100644 --- a/pkgs/by-name/he/hebcal/package.nix +++ b/pkgs/by-name/he/hebcal/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { version = "4.24"; diff --git a/pkgs/by-name/he/hecate/package.nix b/pkgs/by-name/he/hecate/package.nix index a3e8726b13ecb1..62265a84c201f3 100644 --- a/pkgs/by-name/he/hecate/package.nix +++ b/pkgs/by-name/he/hecate/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "hecate"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-eyMrTrNarNCB3w8EOeJBmCbVxpMZy25sQ19icVARU1M="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { inherit (src.meta) homepage; diff --git a/pkgs/by-name/he/hedgedoc-cli/package.nix b/pkgs/by-name/he/hedgedoc-cli/package.nix index ce1497b62c7ce1..78eb00563a88f1 100644 --- a/pkgs/by-name/he/hedgedoc-cli/package.nix +++ b/pkgs/by-name/he/hedgedoc-cli/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, wget, jq, curl }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + wget, + jq, + curl, +}: let version = "1.0"; @@ -23,7 +31,13 @@ stdenv.mkDerivation { mkdir -p $out/bin cp $src/bin/codimd $out/bin wrapProgram $out/bin/codimd \ - --prefix PATH : ${lib.makeBinPath [ jq wget curl ]} + --prefix PATH : ${ + lib.makeBinPath [ + jq + wget + curl + ] + } ln -s $out/bin/codimd $out/bin/hedgedoc-cli runHook postInstall ''; diff --git a/pkgs/by-name/he/hedgedoc/package.nix b/pkgs/by-name/he/hedgedoc/package.nix index 1db614f03acb4a..01b4b38e9b8ddc 100644 --- a/pkgs/by-name/he/hedgedoc/package.nix +++ b/pkgs/by-name/he/hedgedoc/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, gitMinimal -, cacert -, yarn -, makeBinaryWrapper -, nodejs -, python3 -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + gitMinimal, + cacert, + yarn, + makeBinaryWrapper, + nodejs, + python3, + nixosTests, }: let @@ -45,7 +46,8 @@ let outputHash = "sha256-RV9xzNVE4//tPVWVaET78ML3ah+hkZ8x6mTAxe5/pdE="; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "hedgedoc"; inherit version src; diff --git a/pkgs/by-name/he/heisenbridge/package.nix b/pkgs/by-name/he/heisenbridge/package.nix index 59969aa4b901b1..e68d7451afe11c 100644 --- a/pkgs/by-name/he/heisenbridge/package.nix +++ b/pkgs/by-name/he/heisenbridge/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3 }: +{ + lib, + fetchFromGitHub, + python3, +}: python3.pkgs.buildPythonApplication rec { pname = "heisenbridge"; diff --git a/pkgs/by-name/he/hekatomb/package.nix b/pkgs/by-name/he/hekatomb/package.nix index 0b6e708f65b2d7..5fdd1e39c4c051 100644 --- a/pkgs/by-name/he/hekatomb/package.nix +++ b/pkgs/by-name/he/hekatomb/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/he/helio-workstation/package.nix b/pkgs/by-name/he/helio-workstation/package.nix index 70a1ffe91b0f10..3a54a6faa0fc8d 100644 --- a/pkgs/by-name/he/helio-workstation/package.nix +++ b/pkgs/by-name/he/helio-workstation/package.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchFromGitHub -, alsa-lib, freetype, xorg, curl, libGL, libjack2, zenity -, pkg-config, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + alsa-lib, + freetype, + xorg, + curl, + libGL, + libjack2, + zenity, + pkg-config, + makeWrapper, }: stdenv.mkDerivation rec { @@ -16,11 +26,24 @@ stdenv.mkDerivation rec { }; buildInputs = [ - alsa-lib freetype xorg.libX11 xorg.libXext xorg.libXinerama xorg.libXrandr - xorg.libXcursor xorg.libXcomposite curl libGL libjack2 zenity + alsa-lib + freetype + xorg.libX11 + xorg.libXext + xorg.libXinerama + xorg.libXrandr + xorg.libXcursor + xorg.libXcomposite + curl + libGL + libjack2 + zenity ]; - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; preBuild = '' cd Projects/LinuxMakefile diff --git a/pkgs/by-name/he/helix-gpt/package.nix b/pkgs/by-name/he/helix-gpt/package.nix index 6b6f7a8955bb6d..311e674d59a0b6 100644 --- a/pkgs/by-name/he/helix-gpt/package.nix +++ b/pkgs/by-name/he/helix-gpt/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, bun, makeBinaryWrapper }: +{ + stdenv, + lib, + fetchFromGitHub, + bun, + makeBinaryWrapper, +}: let pin = lib.importJSON ./pin.json; src = fetchFromGitHub { @@ -11,8 +17,10 @@ let pname = "helix-gpt-node_modules"; inherit src; version = pin.version; - impureEnvVars = lib.fetchers.proxyImpureEnvVars - ++ [ "GIT_PROXY_COMMAND" "SOCKS_SERVER" ]; + impureEnvVars = lib.fetchers.proxyImpureEnvVars ++ [ + "GIT_PROXY_COMMAND" + "SOCKS_SERVER" + ]; nativeBuildInputs = [ bun ]; dontConfigure = true; buildPhase = '' @@ -60,6 +68,11 @@ stdenv.mkDerivation { mainProgram = "helix-gpt"; maintainers = with maintainers; [ happysalada ]; license = with licenses; [ mit ]; - platforms = [ "x86_64-linux" "x86_64-darwin" "aarch64-darwin" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + "aarch64-darwin" + "aarch64-linux" + ]; }; } diff --git a/pkgs/by-name/he/helix/package.nix b/pkgs/by-name/he/helix/package.nix index 28c8cfe3dfa0f6..1a918acf6e31ab 100644 --- a/pkgs/by-name/he/helix/package.nix +++ b/pkgs/by-name/he/helix/package.nix @@ -1,4 +1,10 @@ -{ fetchzip, lib, rustPlatform, git, installShellFiles }: +{ + fetchzip, + lib, + rustPlatform, + git, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "helix"; @@ -14,7 +20,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Y8zqdS8vl2koXmgFY0hZWWP1ZAO8JgwkoPTYPVpkWsA="; - nativeBuildInputs = [ git installShellFiles ]; + nativeBuildInputs = [ + git + installShellFiles + ]; env.HELIX_DEFAULT_RUNTIME = "${placeholder "out"}/lib/runtime"; @@ -35,6 +44,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://helix-editor.com"; license = licenses.mpl20; mainProgram = "hx"; - maintainers = with maintainers; [ danth yusdacra zowoq ]; + maintainers = with maintainers; [ + danth + yusdacra + zowoq + ]; }; } diff --git a/pkgs/by-name/he/hellmaker/package.nix b/pkgs/by-name/he/hellmaker/package.nix index d05e612dbc80fe..4977b1a5610b10 100644 --- a/pkgs/by-name/he/hellmaker/package.nix +++ b/pkgs/by-name/he/hellmaker/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + python3, + makeWrapper, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/he/hello-cpp/package.nix b/pkgs/by-name/he/hello-cpp/package.nix index a8313a66cc770f..e8391645f93425 100644 --- a/pkgs/by-name/he/hello-cpp/package.nix +++ b/pkgs/by-name/he/hello-cpp/package.nix @@ -8,11 +8,14 @@ stdenv.mkDerivation { name = "hello-cpp"; src = ./src; - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; meta = { description = "Basic sanity check that C++ and cmake infrastructure are working"; platforms = lib.platforms.all; - maintainers = stdenv.meta.maintainers or []; + maintainers = stdenv.meta.maintainers or [ ]; mainProgram = "hello-cpp"; }; } diff --git a/pkgs/by-name/he/hello-unfree/package.nix b/pkgs/by-name/he/hello-unfree/package.nix index 7ff71814fb5ebd..4f8d2187f8a99e 100644 --- a/pkgs/by-name/he/hello-unfree/package.nix +++ b/pkgs/by-name/he/hello-unfree/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, runtimeShell }: +{ + lib, + stdenv, + runtimeShell, +}: stdenv.mkDerivation { pname = "example-unfree-package"; diff --git a/pkgs/by-name/he/hello-wayland/package.nix b/pkgs/by-name/he/hello-wayland/package.nix index 97b7da3e0f0925..d4f98aee64654d 100644 --- a/pkgs/by-name/he/hello-wayland/package.nix +++ b/pkgs/by-name/he/hello-wayland/package.nix @@ -1,6 +1,13 @@ -{ stdenv, lib, fetchFromGitHub -, imagemagick, pkg-config, wayland-scanner, wayland, wayland-protocols -, unstableGitUpdater +{ + stdenv, + lib, + fetchFromGitHub, + imagemagick, + pkg-config, + wayland-scanner, + wayland, + wayland-protocols, + unstableGitUpdater, }: stdenv.mkDerivation { @@ -16,8 +23,15 @@ stdenv.mkDerivation { separateDebugInfo = true; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ imagemagick pkg-config wayland-scanner ]; - buildInputs = [ wayland wayland-protocols ]; + nativeBuildInputs = [ + imagemagick + pkg-config + wayland-scanner + ]; + buildInputs = [ + wayland + wayland-protocols + ]; installPhase = '' runHook preBuild diff --git a/pkgs/by-name/he/hello/test.nix b/pkgs/by-name/he/hello/test.nix index 7acded2a16f2d5..44b5d25c94c3de 100644 --- a/pkgs/by-name/he/hello/test.nix +++ b/pkgs/by-name/he/hello/test.nix @@ -1,8 +1,10 @@ { runCommand, hello }: -runCommand "hello-test-run" { - nativeBuildInputs = [ hello ]; -} '' - diff -U3 --color=auto <(hello) <(echo 'Hello, world!') - touch $out -'' +runCommand "hello-test-run" + { + nativeBuildInputs = [ hello ]; + } + '' + diff -U3 --color=auto <(hello) <(echo 'Hello, world!') + touch $out + '' diff --git a/pkgs/by-name/he/helm-dashboard/package.nix b/pkgs/by-name/he/helm-dashboard/package.nix index 1d7a5447f4cd7c..e3ebea92a4cef6 100644 --- a/pkgs/by-name/he/helm-dashboard/package.nix +++ b/pkgs/by-name/he/helm-dashboard/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "helm-dashboard"; @@ -16,7 +20,11 @@ buildGoModule rec { # tests require internet access doCheck = false; - ldflags = [ "-s" "-w" "-X main.version=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=v${version}" + ]; meta = { description = "Simplified way of working with Helm"; diff --git a/pkgs/by-name/he/helm-docs/package.nix b/pkgs/by-name/he/helm-docs/package.nix index e60d34669b91f9..bcc89207c39497 100644 --- a/pkgs/by-name/he/helm-docs/package.nix +++ b/pkgs/by-name/he/helm-docs/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "helm-docs"; diff --git a/pkgs/by-name/he/helm-ls/package.nix b/pkgs/by-name/he/helm-ls/package.nix index df72b7dfb615e7..3a0ccda3db2928 100644 --- a/pkgs/by-name/he/helm-ls/package.nix +++ b/pkgs/by-name/he/helm-ls/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, testers -, helm-ls +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + helm-ls, }: buildGoModule rec { diff --git a/pkgs/by-name/he/helmholtz/package.nix b/pkgs/by-name/he/helmholtz/package.nix index a82007c375bd90..ea90db2b4cffc7 100644 --- a/pkgs/by-name/he/helmholtz/package.nix +++ b/pkgs/by-name/he/helmholtz/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, unzip, puredata }: +{ + lib, + stdenv, + fetchurl, + unzip, + puredata, +}: stdenv.mkDerivation { name = "helmholtz"; diff --git a/pkgs/by-name/he/help2man/package.nix b/pkgs/by-name/he/help2man/package.nix index 9fd35a094db8a5..6d44830a98ac8f 100644 --- a/pkgs/by-name/he/help2man/package.nix +++ b/pkgs/by-name/he/help2man/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, perlPackages, gettext, libintl }: +{ + lib, + stdenv, + fetchurl, + perlPackages, + gettext, + libintl, +}: # Note: this package is used for bootstrapping fetchurl, and thus # cannot use fetchpatch! All mutable patches (generated by GitHub or @@ -18,8 +25,15 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - nativeBuildInputs = [ gettext perlPackages.perl perlPackages.LocaleGettext ]; - buildInputs = [ perlPackages.LocaleGettext libintl ]; + nativeBuildInputs = [ + gettext + perlPackages.perl + perlPackages.LocaleGettext + ]; + buildInputs = [ + perlPackages.LocaleGettext + libintl + ]; configureFlags = [ "--enable-nls" diff --git a/pkgs/by-name/he/helvetica-neue-lt-std/package.nix b/pkgs/by-name/he/helvetica-neue-lt-std/package.nix index 61dc6ba14e293c..1b4d9eb4c993f6 100644 --- a/pkgs/by-name/he/helvetica-neue-lt-std/package.nix +++ b/pkgs/by-name/he/helvetica-neue-lt-std/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { name = "helvetica-neue-lt-std"; diff --git a/pkgs/by-name/he/helvum/package.nix b/pkgs/by-name/he/helvum/package.nix index f75db713f3d8ab..9ba438c3df1f1b 100644 --- a/pkgs/by-name/he/helvum/package.nix +++ b/pkgs/by-name/he/helvum/package.nix @@ -1,18 +1,19 @@ -{ lib -, cargo -, desktop-file-utils -, fetchFromGitLab -, glib -, gtk4 -, libadwaita -, meson -, ninja -, pipewire -, pkg-config -, rustPlatform -, rustc -, stdenv -, wrapGAppsHook4 +{ + lib, + cargo, + desktop-file-utils, + fetchFromGitLab, + glib, + gtk4, + libadwaita, + meson, + ninja, + pipewire, + pkg-config, + rustPlatform, + rustc, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/he/hepmc2/package.nix b/pkgs/by-name/he/hepmc2/package.nix index 870114ffcba481..6944031910ed01 100644 --- a/pkgs/by-name/he/hepmc2/package.nix +++ b/pkgs/by-name/he/hepmc2/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, cmake }: +{ + lib, + stdenv, + fetchurl, + cmake, +}: stdenv.mkDerivation rec { pname = "hepmc"; @@ -18,9 +23,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "HepMC package is an object oriented event record written in C++ for High Energy Physics Monte Carlo Generators"; - license = licenses.lgpl21; - homepage = "http://hepmc.web.cern.ch/hepmc/"; - platforms = platforms.unix; + license = licenses.lgpl21; + homepage = "http://hepmc.web.cern.ch/hepmc/"; + platforms = platforms.unix; maintainers = with maintainers; [ veprbl ]; }; } diff --git a/pkgs/by-name/he/herbe/package.nix b/pkgs/by-name/he/herbe/package.nix index 9ea08f0dc83cd0..dedc2e4c290e92 100644 --- a/pkgs/by-name/he/herbe/package.nix +++ b/pkgs/by-name/he/herbe/package.nix @@ -1,5 +1,13 @@ -{ stdenv, lib, fetchFromGitHub, libX11, libXft, freetype, patches ? [ ], - extraLibs ? [ ] }: +{ + stdenv, + lib, + fetchFromGitHub, + libX11, + libXft, + freetype, + patches ? [ ], + extraLibs ? [ ], +}: stdenv.mkDerivation rec { pname = "herbe"; @@ -18,7 +26,11 @@ stdenv.mkDerivation rec { sed -i 's_/usr/include/freetype2_${freetype.dev}/include/freetype2_' Makefile ''; - buildInputs = [ libX11 libXft freetype ] ++ extraLibs; + buildInputs = [ + libX11 + libXft + freetype + ] ++ extraLibs; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/he/herbstluftwm/package.nix b/pkgs/by-name/he/herbstluftwm/package.nix index 825ae0de85e422..64ecfeefe2ae87 100644 --- a/pkgs/by-name/he/herbstluftwm/package.nix +++ b/pkgs/by-name/he/herbstluftwm/package.nix @@ -1,7 +1,28 @@ -{ lib, stdenv, fetchurl, cmake, pkg-config, python3, libX11, libXext, libXinerama, libXrandr, libXft, libXrender, libXdmcp, libXfixes, freetype, asciidoc -, xdotool, xorgserver, xsetroot, xterm, runtimeShell -, fetchpatch -, nixosTests }: +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + python3, + libX11, + libXext, + libXinerama, + libXrandr, + libXft, + libXrender, + libXdmcp, + libXfixes, + freetype, + asciidoc, + xdotool, + xorgserver, + xsetroot, + xterm, + runtimeShell, + fetchpatch, + nixosTests, +}: stdenv.mkDerivation rec { pname = "herbstluftwm"; @@ -76,7 +97,13 @@ stdenv.mkDerivation rec { doCheck = true; nativeCheckInputs = [ - (python3.withPackages (ps: with ps; [ ewmh pytest xlib ])) + (python3.withPackages ( + ps: with ps; [ + ewmh + pytest + xlib + ] + )) xdotool xorgserver xsetroot diff --git a/pkgs/by-name/he/hercules/package.nix b/pkgs/by-name/he/hercules/package.nix index c5635d960fbb08..6ae12bfda411ec 100644 --- a/pkgs/by-name/he/hercules/package.nix +++ b/pkgs/by-name/he/hercules/package.nix @@ -1,57 +1,60 @@ -{ lib -, stdenv -, fetchFromGitHub -, runCommand -, libtool -, cmake -, zlib -, bzip2 -, enableRexx ? stdenv.hostPlatform.isLinux, regina +{ + lib, + stdenv, + fetchFromGitHub, + runCommand, + libtool, + cmake, + zlib, + bzip2, + enableRexx ? stdenv.hostPlatform.isLinux, + regina, }: let - herculesCpu = - if stdenv.hostPlatform.isx86 then "x86" - else stdenv.hostPlatform.qemuArch; + herculesCpu = if stdenv.hostPlatform.isx86 then "x86" else stdenv.hostPlatform.qemuArch; herculesBits = if stdenv.hostPlatform.is32bit then "32" else "64"; - herculesLibDir = - if stdenv.hostPlatform.isx86 then "lib" - else "lib/${herculesCpu}"; - - mkExtPkg = depName: attrFn: (stdenv.mkDerivation { - pname = "hercules-${depName}"; - - postPatch = '' - patchShebangs build - sed -i build \ - -e "s%_tool=.*$%_tool=${cmake}/bin/cmake%" \ - -e "s/CPUS=.*$/CPUS=$NIX_BUILD_CORES/" - ''; - - dontUseCmakeConfigure = true; - - buildPhase = '' - mkdir ../build $out - # In source builds are not allowed. - cd ../build - ../source/build \ - --pkgname ${depName} \ - --cpu ${herculesCpu} \ - --arch ${herculesBits} \ - --install "$out" - ''; - - nativeBuildInputs = [ cmake ]; - - enableParallelBuilding = true; - - meta = with lib; { - description = "Hercules ${depName} library"; - license = lib.licenses.free; # Mixture of Public Domain, ICU (MIT compatible) and others - maintainers = with maintainers; [ anna328p vifino ]; - }; - }).overrideAttrs (default: attrFn default); - + herculesLibDir = if stdenv.hostPlatform.isx86 then "lib" else "lib/${herculesCpu}"; + + mkExtPkg = + depName: attrFn: + (stdenv.mkDerivation { + pname = "hercules-${depName}"; + + postPatch = '' + patchShebangs build + sed -i build \ + -e "s%_tool=.*$%_tool=${cmake}/bin/cmake%" \ + -e "s/CPUS=.*$/CPUS=$NIX_BUILD_CORES/" + ''; + + dontUseCmakeConfigure = true; + + buildPhase = '' + mkdir ../build $out + # In source builds are not allowed. + cd ../build + ../source/build \ + --pkgname ${depName} \ + --cpu ${herculesCpu} \ + --arch ${herculesBits} \ + --install "$out" + ''; + + nativeBuildInputs = [ cmake ]; + + enableParallelBuilding = true; + + meta = with lib; { + description = "Hercules ${depName} library"; + license = lib.licenses.free; # Mixture of Public Domain, ICU (MIT compatible) and others + maintainers = with maintainers; [ + anna328p + vifino + ]; + }; + }).overrideAttrs + (default: attrFn default); crypto = mkExtPkg "crypto" (default: { version = "1.0.0"; @@ -93,7 +96,7 @@ let }; }); - extpkgs = runCommand "hercules-extpkgs" {} '' + extpkgs = runCommand "hercules-extpkgs" { } '' OUTINC="$out/include" OUTLIB="$out/${herculesLibDir}" mkdir -p "$OUTINC" "$OUTLIB" @@ -119,24 +122,28 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ libtool ]; - buildInputs = [ - (lib.getOutput "lib" libtool) - zlib - bzip2 - extpkgs - ] ++ lib.optionals enableRexx [ - regina - ]; - - configureFlags = [ - "--enable-extpkgs=${extpkgs}" - "--without-included-ltdl" - "--enable-ipv6" - "--enable-cckd-bzip2" - "--enable-het-bzip2" - ] ++ lib.optionals enableRexx [ - "--enable-regina-rexx" - ]; + buildInputs = + [ + (lib.getOutput "lib" libtool) + zlib + bzip2 + extpkgs + ] + ++ lib.optionals enableRexx [ + regina + ]; + + configureFlags = + [ + "--enable-extpkgs=${extpkgs}" + "--without-included-ltdl" + "--enable-ipv6" + "--enable-cckd-bzip2" + "--enable-het-bzip2" + ] + ++ lib.optionals enableRexx [ + "--enable-regina-rexx" + ]; meta = with lib; { homepage = "https://sdl-hercules-390.github.io/html/"; @@ -148,6 +155,9 @@ stdenv.mkDerivation rec { Mac OS X. ''; license = licenses.qpl; - maintainers = with maintainers; [ anna328p vifino ]; + maintainers = with maintainers; [ + anna328p + vifino + ]; }; } diff --git a/pkgs/by-name/he/hermit/package.nix b/pkgs/by-name/he/hermit/package.nix index 8a0e5479f188be..56d37f33a9f768 100644 --- a/pkgs/by-name/he/hermit/package.nix +++ b/pkgs/by-name/he/hermit/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "hermit"; diff --git a/pkgs/by-name/he/hermitcli/package.nix b/pkgs/by-name/he/hermitcli/package.nix index 5a7f0155dde812..7a9c0dc2ac28bd 100644 --- a/pkgs/by-name/he/hermitcli/package.nix +++ b/pkgs/by-name/he/hermitcli/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/he/heroku/package.nix b/pkgs/by-name/he/heroku/package.nix index 540035fb38093a..354f1ffbdecc8d 100644 --- a/pkgs/by-name/he/heroku/package.nix +++ b/pkgs/by-name/he/heroku/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchzip, makeWrapper, nodejs, writeScript }: +{ + stdenv, + lib, + fetchzip, + makeWrapper, + nodejs, + writeScript, +}: stdenv.mkDerivation { pname = "heroku"; @@ -39,7 +46,10 @@ stdenv.mkDerivation { homepage = "https://devcenter.heroku.com/articles/heroku-cli"; description = "Everything you need to get started using Heroku"; mainProgram = "heroku"; - maintainers = with lib.maintainers; [ aflatter mirdhyn ]; + maintainers = with lib.maintainers; [ + aflatter + mirdhyn + ]; license = lib.licenses.mit; platforms = with lib.platforms; unix; }; diff --git a/pkgs/by-name/he/herwig/package.nix b/pkgs/by-name/he/herwig/package.nix index c18ff9bef84dc6..9e6ea0e4586aad 100644 --- a/pkgs/by-name/he/herwig/package.nix +++ b/pkgs/by-name/he/herwig/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchurl, boost, fastjet, gfortran, gsl, lhapdf, thepeg, zlib, autoconf, automake, libtool }: +{ + lib, + stdenv, + fetchurl, + boost, + fastjet, + gfortran, + gsl, + lhapdf, + thepeg, + zlib, + autoconf, + automake, + libtool, +}: stdenv.mkDerivation rec { pname = "herwig"; @@ -9,11 +23,26 @@ stdenv.mkDerivation rec { hash = "sha256-JiSBnS3/EFupUuobXPEutvSSbUlRd0pBkHaZ4vVnaGw="; }; - nativeBuildInputs = [ autoconf automake libtool gfortran ]; + nativeBuildInputs = [ + autoconf + automake + libtool + gfortran + ]; - buildInputs = [ boost fastjet gsl thepeg zlib ] + buildInputs = + [ + boost + fastjet + gsl + thepeg + zlib + ] # There is a bug that requires for default PDF's to be present during the build - ++ (with lhapdf.pdf_sets; [ CT14lo CT14nlo ]); + ++ (with lhapdf.pdf_sets; [ + CT14lo + CT14nlo + ]); postPatch = '' patchShebangs ./ diff --git a/pkgs/by-name/he/hetzner-kube/package.nix b/pkgs/by-name/he/hetzner-kube/package.nix index 40a0a2a363dbf4..beb912964904dd 100644 --- a/pkgs/by-name/he/hetzner-kube/package.nix +++ b/pkgs/by-name/he/hetzner-kube/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "hetzner-kube"; diff --git a/pkgs/by-name/he/hevea/package.nix b/pkgs/by-name/he/hevea/package.nix index 85317b7d7ecd8b..eb01837e6803f7 100644 --- a/pkgs/by-name/he/hevea/package.nix +++ b/pkgs/by-name/he/hevea/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ocamlPackages }: +{ + lib, + stdenv, + fetchurl, + ocamlPackages, +}: stdenv.mkDerivation rec { pname = "hevea"; @@ -11,7 +16,10 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = with ocamlPackages; [ ocaml ocamlbuild ]; + nativeBuildInputs = with ocamlPackages; [ + ocaml + ocamlbuild + ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/he/hex-a-hop/package.nix b/pkgs/by-name/he/hex-a-hop/package.nix index ea2df3360796ad..8cb03266da08f9 100644 --- a/pkgs/by-name/he/hex-a-hop/package.nix +++ b/pkgs/by-name/he/hex-a-hop/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchzip, SDL, SDL_mixer, SDL_ttf }: +{ + lib, + stdenv, + fetchurl, + fetchzip, + SDL, + SDL_mixer, + SDL_ttf, +}: stdenv.mkDerivation rec { pname = "hex-a-hop"; @@ -21,7 +29,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-j6gKRq+8b1NDwP1WcCaScfmwNxAl78CfK6pemROrRak="; }; - buildInputs = [ SDL SDL_mixer SDL_ttf ]; + buildInputs = [ + SDL + SDL_mixer + SDL_ttf + ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/he/hex/package.nix b/pkgs/by-name/he/hex/package.nix index f7f8300807829e..202ea5c3dee97f 100644 --- a/pkgs/by-name/he/hex/package.nix +++ b/pkgs/by-name/he/hex/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, testers -, hex +{ + lib, + rustPlatform, + fetchFromGitHub, + testers, + hex, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/he/hexbinhex/package.nix b/pkgs/by-name/he/hexbinhex/package.nix index 7c0a417a84fc92..a4a012bdad7434 100644 --- a/pkgs/by-name/he/hexbinhex/package.nix +++ b/pkgs/by-name/he/hexbinhex/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { @@ -14,14 +15,14 @@ stdenv.mkDerivation rec { hash = "sha256-nfOmiF+t5QtAl1I7CSz26C9SGo7ZkdSziO2eiHbk6pA="; }; - preBuild = '' - substituteInPlace Makefile --replace '/usr/local' $out - mkdir -p $out/bin - '' - + - lib.optionalString (!stdenv.hostPlatform.isx86_64) '' - sed -i s/-m64//g Makefile - ''; + preBuild = + '' + substituteInPlace Makefile --replace '/usr/local' $out + mkdir -p $out/bin + '' + + lib.optionalString (!stdenv.hostPlatform.isx86_64) '' + sed -i s/-m64//g Makefile + ''; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; @@ -36,6 +37,9 @@ stdenv.mkDerivation rec { ''; license = lib.licenses.gpl2Only; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ orichter thillux ]; + maintainers = with lib.maintainers; [ + orichter + thillux + ]; }; } diff --git a/pkgs/by-name/he/hexcurse/package.nix b/pkgs/by-name/he/hexcurse/package.nix index a4d9905d6fa7aa..f5f7350792e2d0 100644 --- a/pkgs/by-name/he/hexcurse/package.nix +++ b/pkgs/by-name/he/hexcurse/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, ncurses }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + ncurses, +}: stdenv.mkDerivation rec { pname = "hexcurse"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "17ckkxfzbqvvfdnh10if4aqdcq98q3vl6dn1v6f4lhr4ifnyjdlk"; }; buildInputs = [ ncurses ]; - env.NIX_CFLAGS_COMPILE = toString [ "-Wno-error=stringop-overflow" "-Wno-error=stringop-truncation" ]; + env.NIX_CFLAGS_COMPILE = toString [ + "-Wno-error=stringop-overflow" + "-Wno-error=stringop-truncation" + ]; patches = [ # gcc7 compat (fetchpatch { diff --git a/pkgs/by-name/he/hexd/package.nix b/pkgs/by-name/he/hexd/package.nix index 140db343508371..5893d1cf9ed038 100644 --- a/pkgs/by-name/he/hexd/package.nix +++ b/pkgs/by-name/he/hexd/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "hexd"; diff --git a/pkgs/by-name/he/hexdiff/package.nix b/pkgs/by-name/he/hexdiff/package.nix index 9ee711e7457ea3..3b22afda3f198f 100644 --- a/pkgs/by-name/he/hexdiff/package.nix +++ b/pkgs/by-name/he/hexdiff/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "hexdiff"; diff --git a/pkgs/by-name/he/hexdino/package.nix b/pkgs/by-name/he/hexdino/package.nix index 1fb74497915128..0db1b3aa6eb30f 100644 --- a/pkgs/by-name/he/hexdino/package.nix +++ b/pkgs/by-name/he/hexdino/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "hexdino"; diff --git a/pkgs/by-name/he/hexfiend/package.nix b/pkgs/by-name/he/hexfiend/package.nix index 2a5ec7a461c5fc..2de0a4aa3dbd53 100644 --- a/pkgs/by-name/he/hexfiend/package.nix +++ b/pkgs/by-name/he/hexfiend/package.nix @@ -1,11 +1,13 @@ -{ stdenv, lib, fetchurl, undmg, nix-update-script }: +{ + stdenv, + lib, + fetchurl, + undmg, + nix-update-script, +}: let - urlSuffix = version: if lib.versions.patch == 0 then - lib.versions.majorMinor version - else - version - ; + urlSuffix = version: if lib.versions.patch == 0 then lib.versions.majorMinor version else version; in stdenv.mkDerivation rec { pname = "hexfiend"; diff --git a/pkgs/by-name/he/hexgui/package.nix b/pkgs/by-name/he/hexgui/package.nix index 8265cacc34001e..69278690de2a7b 100644 --- a/pkgs/by-name/he/hexgui/package.nix +++ b/pkgs/by-name/he/hexgui/package.nix @@ -1,9 +1,10 @@ -{ ant -, fetchFromGitHub -, jdk -, lib -, makeWrapper -, stdenv +{ + ant, + fetchFromGitHub, + jdk, + lib, + makeWrapper, + stdenv, }: stdenv.mkDerivation { pname = "hexgui"; @@ -16,7 +17,11 @@ stdenv.mkDerivation { hash = "sha256-W5klRwVsSlrSp3Pw5D4uknIRjaNMv+OTUtXXTmd6P3I="; }; - nativeBuildInputs = [ ant jdk makeWrapper ]; + nativeBuildInputs = [ + ant + jdk + makeWrapper + ]; buildPhase = '' ant ''; diff --git a/pkgs/by-name/he/hexio/package.nix b/pkgs/by-name/he/hexio/package.nix index 0b4e474515ab7c..da8bb23251ce03 100644 --- a/pkgs/by-name/he/hexio/package.nix +++ b/pkgs/by-name/he/hexio/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pcsclite, pth, python2 }: +{ + lib, + stdenv, + fetchFromGitHub, + pcsclite, + pth, + python2, +}: stdenv.mkDerivation rec { pname = "hexio"; @@ -13,19 +20,23 @@ stdenv.mkDerivation rec { strictDeps = true; - buildInputs = [ pcsclite pth python2 ]; + buildInputs = [ + pcsclite + pth + python2 + ]; patchPhase = '' substituteInPlace Makefile \ --replace '-I/usr/local/include/PCSC/' '-I${lib.getDev pcsclite}/include/PCSC/' \ --replace '-L/usr/local/lib/pth' '-I${pth}/lib/' - ''; + ''; installPhase = '' mkdir -p $out/bin $out/lib $out/sbin $out/man make DESTDIR=$out PREFIX=/ all make DESTDIR=$out PREFIX=/ install - ''; + ''; meta = with lib; { description = "Low-level I/O helpers for hexadecimal, tty/serial devices and so on"; diff --git a/pkgs/by-name/he/hexo-cli/package.nix b/pkgs/by-name/he/hexo-cli/package.nix index be5764c9f0c301..fcce2db7eacfcf 100644 --- a/pkgs/by-name/he/hexo-cli/package.nix +++ b/pkgs/by-name/he/hexo-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/he/hey/package.nix b/pkgs/by-name/he/hey/package.nix index b5d565d84743c2..08735573fb5a46 100644 --- a/pkgs/by-name/he/hey/package.nix +++ b/pkgs/by-name/he/hey/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, lib, fetchFromGitHub }: +{ + buildGoModule, + lib, + fetchFromGitHub, +}: buildGoModule rec { pname = "hey"; diff --git a/pkgs/by-name/he/heygpt/package.nix b/pkgs/by-name/he/heygpt/package.nix index 71ad738b8b921f..8bd481458f3015 100644 --- a/pkgs/by-name/he/heygpt/package.nix +++ b/pkgs/by-name/he/heygpt/package.nix @@ -17,7 +17,7 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-yKHAZpELuUD7wlM3Mi7XvxbKgdU1QxD9hsvIFcj3twE="; - nativeBuildInputs = [openssl]; + nativeBuildInputs = [ openssl ]; # Needed to get openssl-sys to use pkg-config. OPENSSL_NO_VENDOR = 1; @@ -30,6 +30,6 @@ rustPlatform.buildRustPackage rec { changelog = "https://github.com/fuyufjh/heygpt/releases/tag/v${version}"; license = licenses.mit; mainProgram = "heygpt"; - maintainers = with maintainers; [aldoborrero]; + maintainers = with maintainers; [ aldoborrero ]; }; } diff --git a/pkgs/by-name/hf/hfinger/package.nix b/pkgs/by-name/hf/hfinger/package.nix index baca9ed5ddd27a..85da3d54c445d2 100644 --- a/pkgs/by-name/hf/hfinger/package.nix +++ b/pkgs/by-name/hf/hfinger/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3 -, wireshark-cli +{ + lib, + fetchFromGitHub, + python3, + wireshark-cli, }: python3.pkgs.buildPythonApplication rec { @@ -20,12 +21,15 @@ python3.pkgs.buildPythonApplication rec { setuptools ]; - propagatedBuildInputs = with python3.pkgs; [ - fnvhash - python-magic - ] ++ [ - wireshark-cli - ]; + propagatedBuildInputs = + with python3.pkgs; + [ + fnvhash + python-magic + ] + ++ [ + wireshark-cli + ]; # Project has no tests doCheck = false; diff --git a/pkgs/by-name/hf/hfst-ospell/package.nix b/pkgs/by-name/hf/hfst-ospell/package.nix index eda613aede61d7..a76e57a240ba98 100644 --- a/pkgs/by-name/hf/hfst-ospell/package.nix +++ b/pkgs/by-name/hf/hfst-ospell/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, icu -, libarchive -, pkg-config +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + icu, + libarchive, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/hf/hfst/package.nix b/pkgs/by-name/hf/hfst/package.nix index 41707bbd4986f8..afae2ce01bd839 100644 --- a/pkgs/by-name/hf/hfst/package.nix +++ b/pkgs/by-name/hf/hfst/package.nix @@ -1,15 +1,16 @@ -{ lib -, autoreconfHook -, bison -, flex -, foma -, fetchFromGitHub -, gettext -, icu -, stdenv -, swig -, pkg-config -, zlib +{ + lib, + autoreconfHook, + bison, + flex, + foma, + fetchFromGitHub, + gettext, + icu, + stdenv, + swig, + pkg-config, + zlib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/hh/hheretic/package.nix b/pkgs/by-name/hh/hheretic/package.nix index 83b0ccb620cf59..86f9b33e8e108f 100644 --- a/pkgs/by-name/hh/hheretic/package.nix +++ b/pkgs/by-name/hh/hheretic/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL -, SDL_mixer -, autoreconfHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + SDL, + SDL_mixer, + autoreconfHook, + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/hh/hhexen/package.nix b/pkgs/by-name/hh/hhexen/package.nix index c73040a30f7e31..dbb4278fa9bd8b 100644 --- a/pkgs/by-name/hh/hhexen/package.nix +++ b/pkgs/by-name/hh/hhexen/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL -, SDL_mixer -, autoreconfHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + SDL, + SDL_mixer, + autoreconfHook, + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { @@ -49,7 +50,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Linux port of Raven Game's Hexen"; homepage = "https://hhexen.sourceforge.net/hhexen.html"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ moody djanatyn ]; + maintainers = with lib.maintainers; [ + moody + djanatyn + ]; mainProgram = "hhexen-gl"; inherit (SDL.meta) platforms; broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/by-name/hh/hhpc/package.nix b/pkgs/by-name/hh/hhpc/package.nix index 71c39c68accec6..048490fbe9c2ff 100644 --- a/pkgs/by-name/hh/hhpc/package.nix +++ b/pkgs/by-name/hh/hhpc/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchFromGitHub, xorg, pkg-config}: +{ + lib, + stdenv, + fetchFromGitHub, + xorg, + pkg-config, +}: stdenv.mkDerivation rec { pname = "hhpc"; @@ -15,8 +21,8 @@ stdenv.mkDerivation rec { buildInputs = [ xorg.libX11 ]; installPhase = '' - mkdir -p $out/bin - cp hhpc $out/bin/ + mkdir -p $out/bin + cp hhpc $out/bin/ ''; meta = with lib; { diff --git a/pkgs/by-name/hi/hiawatha/package.nix b/pkgs/by-name/hi/hiawatha/package.nix index 7d62dc27e8229a..9ff18400619a62 100644 --- a/pkgs/by-name/hi/hiawatha/package.nix +++ b/pkgs/by-name/hi/hiawatha/package.nix @@ -1,21 +1,25 @@ -{ lib, stdenv -, fetchFromGitLab -, callPackage +{ + lib, + stdenv, + fetchFromGitLab, + callPackage, -, cmake -, ninja -, mbedtls -, libxcrypt -, zlib + cmake, + ninja, + mbedtls, + libxcrypt, + zlib, -, enableCache ? true # Internal cache support. -, enableIpV6 ? true -, enableTls ? true -, enableMonitor ? false # Support for the Hiawatha Monitor. -, enableRproxy ? true # Reverse proxy support. -, enableTomahawk ? false # Tomahawk, the Hiawatha command shell. -, enableXslt ? true, libxml2 ? null, libxslt ? null -, enableToolkit ? true # The URL Toolkit. + enableCache ? true, # Internal cache support. + enableIpV6 ? true, + enableTls ? true, + enableMonitor ? false, # Support for the Hiawatha Monitor. + enableRproxy ? true, # Reverse proxy support. + enableTomahawk ? false, # Tomahawk, the Hiawatha command shell. + enableXslt ? true, + libxml2 ? null, + libxslt ? null, + enableToolkit ? true, # The URL Toolkit. }: stdenv.mkDerivation (finalAttrs: { @@ -29,8 +33,20 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-YsZdVqanVNibA4KnAknLh61hVo7x5uu67lb+RX2N7c8="; }; - nativeBuildInputs = [ cmake ninja ]; - buildInputs = [ mbedtls libxcrypt zlib ] ++ lib.optionals enableXslt [ libxslt libxml2 ]; + nativeBuildInputs = [ + cmake + ninja + ]; + buildInputs = + [ + mbedtls + libxcrypt + zlib + ] + ++ lib.optionals enableXslt [ + libxslt + libxml2 + ]; prePatch = '' substituteInPlace CMakeLists.txt --replace SETUID "" @@ -38,14 +54,14 @@ stdenv.mkDerivation (finalAttrs: { cmakeFlags = [ "-DUSE_SYSTEM_MBEDTLS=on" # Policy to use Nix deps, and Nix uses up to date deps - ( if enableCache then "-DENABLE_CACHE=on" else "-DENABLE_CACHE=off" ) - ( if enableIpV6 then "-DENABLE_IPV6=on" else "-DENABLE_IPV6=off" ) - ( if enableTls then "-DENABLE_TLS=on" else "-DENABLE_TLS=off" ) - ( if enableMonitor then "-DENABLE_MONITOR=on" else "-DENABLE_MONITOR=off" ) - ( if enableRproxy then "-DENABLE_RPROXY=on" else "-DENABLE_RPROXY=off" ) - ( if enableTomahawk then "-DENABLE_TOMAHAWK=on" else "-DENABLE_TOMAHAWK=off" ) - ( if enableXslt then "-DENABLE_XSLT=on" else "-DENABLE_XSLT=off" ) - ( if enableToolkit then "-DENABLE_TOOLKIT=on" else "-DENABLE_TOOLKIT=off" ) + (if enableCache then "-DENABLE_CACHE=on" else "-DENABLE_CACHE=off") + (if enableIpV6 then "-DENABLE_IPV6=on" else "-DENABLE_IPV6=off") + (if enableTls then "-DENABLE_TLS=on" else "-DENABLE_TLS=off") + (if enableMonitor then "-DENABLE_MONITOR=on" else "-DENABLE_MONITOR=off") + (if enableRproxy then "-DENABLE_RPROXY=on" else "-DENABLE_RPROXY=off") + (if enableTomahawk then "-DENABLE_TOMAHAWK=on" else "-DENABLE_TOMAHAWK=off") + (if enableXslt then "-DENABLE_XSLT=on" else "-DENABLE_XSLT=off") + (if enableToolkit then "-DENABLE_TOOLKIT=on" else "-DENABLE_TOOLKIT=off") ]; passthru.tests.serve-static-files = callPackage ./test.nix { @@ -57,7 +73,7 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://hiawatha.leisink.net/"; description = "Advanced and secure webserver"; license = licenses.gpl2Only; - platforms = platforms.unix; # "Hiawatha runs perfectly on Linux, BSD and MacOS X" + platforms = platforms.unix; # "Hiawatha runs perfectly on Linux, BSD and MacOS X" mainProgram = "hiawatha"; maintainers = [ ]; }; diff --git a/pkgs/by-name/hi/hiawatha/test.nix b/pkgs/by-name/hi/hiawatha/test.nix index 157d0ee79644d1..3287a626612715 100644 --- a/pkgs/by-name/hi/hiawatha/test.nix +++ b/pkgs/by-name/hi/hiawatha/test.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, hiawatha -, curl -, mbedtls -, enableTls +{ + lib, + stdenvNoCC, + hiawatha, + curl, + mbedtls, + enableTls, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/hi/hibernate/package.nix b/pkgs/by-name/hi/hibernate/package.nix index dfd3407f2a03dd..d870047c7cd88a 100644 --- a/pkgs/by-name/hi/hibernate/package.nix +++ b/pkgs/by-name/hi/hibernate/package.nix @@ -1,47 +1,57 @@ -{ lib, stdenv, fetchurl, gawk }: - -let version = "2.0"; +{ + lib, + stdenv, + fetchurl, + gawk, +}: + +let + version = "2.0"; in - stdenv.mkDerivation { - pname = "hibernate"; - inherit version; - src = fetchurl { - url = "http://tuxonice.nigelcunningham.com.au/files/hibernate-script-${version}.tar.gz"; - sha256 = "0ib5bac3spbcwmhf8f9apjbll8x7fgqj4k1s5q3srijh793rfifh"; - }; - - patches = [ ./install.patch ./gen-manpages.patch ./hibernate.patch ]; - - buildInputs = [ gawk ]; - - installPhase = '' - # FIXME: Storing config files under `$out/etc' is not very useful. - - substituteInPlace "hibernate.sh" --replace \ - 'SWSUSP_D="/etc/hibernate"' "SWSUSP_D=\"$out/etc/hibernate\"" - - # Remove all references to `/bin' and `/sbin'. - for i in scriptlets.d/* - do - substituteInPlace "$i" --replace "/bin/" "" --replace "/sbin/" "" - done - - PREFIX="$out" CONFIG_PREFIX="$out" ./install.sh - - ln -s "$out/share/hibernate/scriptlets.d" "$out/etc/hibernate" +stdenv.mkDerivation { + pname = "hibernate"; + inherit version; + src = fetchurl { + url = "http://tuxonice.nigelcunningham.com.au/files/hibernate-script-${version}.tar.gz"; + sha256 = "0ib5bac3spbcwmhf8f9apjbll8x7fgqj4k1s5q3srijh793rfifh"; + }; + + patches = [ + ./install.patch + ./gen-manpages.patch + ./hibernate.patch + ]; + + buildInputs = [ gawk ]; + + installPhase = '' + # FIXME: Storing config files under `$out/etc' is not very useful. + + substituteInPlace "hibernate.sh" --replace \ + 'SWSUSP_D="/etc/hibernate"' "SWSUSP_D=\"$out/etc/hibernate\"" + + # Remove all references to `/bin' and `/sbin'. + for i in scriptlets.d/* + do + substituteInPlace "$i" --replace "/bin/" "" --replace "/sbin/" "" + done + + PREFIX="$out" CONFIG_PREFIX="$out" ./install.sh + + ln -s "$out/share/hibernate/scriptlets.d" "$out/etc/hibernate" + ''; + + meta = { + description = "`hibernate' script for swsusp and Tux-on-Ice"; + mainProgram = "hibernate"; + longDescription = '' + This package provides the `hibernate' script, a command-line utility + that saves the computer's state to disk and switches it off, turning + it into "hibernation". It works both with Linux swsusp and Tux-on-Ice. ''; - meta = { - description = "`hibernate' script for swsusp and Tux-on-Ice"; - mainProgram = "hibernate"; - longDescription = '' - This package provides the `hibernate' script, a command-line utility - that saves the computer's state to disk and switches it off, turning - it into "hibernation". It works both with Linux swsusp and Tux-on-Ice. - ''; - - license = lib.licenses.gpl2Plus; - homepage = "http://www.tuxonice.net/"; - platforms = lib.platforms.linux; - }; - } + license = lib.licenses.gpl2Plus; + homepage = "http://www.tuxonice.net/"; + platforms = lib.platforms.linux; + }; +} diff --git a/pkgs/by-name/hi/hid-listen/package.nix b/pkgs/by-name/hi/hid-listen/package.nix index d126bb9e850fb2..b6dd65004943b2 100644 --- a/pkgs/by-name/hi/hid-listen/package.nix +++ b/pkgs/by-name/hi/hid-listen/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { pname = "hid-listen"; version = "1.01"; diff --git a/pkgs/by-name/hi/hid-tools/package.nix b/pkgs/by-name/hi/hid-tools/package.nix index 82c61caf020a07..6b90d588848a31 100644 --- a/pkgs/by-name/hi/hid-tools/package.nix +++ b/pkgs/by-name/hi/hid-tools/package.nix @@ -1,6 +1,7 @@ -{ python3 -, lib -, fetchFromGitLab +{ + python3, + lib, + fetchFromGitLab, }: python3.pkgs.buildPythonPackage rec { diff --git a/pkgs/by-name/hi/hidden-bar/package.nix b/pkgs/by-name/hi/hidden-bar/package.nix index e35e2a83f492bd..aaccb68fdf9218 100644 --- a/pkgs/by-name/hi/hidden-bar/package.nix +++ b/pkgs/by-name/hi/hidden-bar/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, undmg +{ + lib, + stdenvNoCC, + fetchurl, + undmg, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/hi/hidrd/package.nix b/pkgs/by-name/hi/hidrd/package.nix index d3a8a401243302..53f4f2a6a3fd86 100644 --- a/pkgs/by-name/hi/hidrd/package.nix +++ b/pkgs/by-name/hi/hidrd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation { pname = "hidrd"; diff --git a/pkgs/by-name/hi/hidviz/package.nix b/pkgs/by-name/hi/hidviz/package.nix index 14c40f30054d76..e3f154965be87e 100644 --- a/pkgs/by-name/hi/hidviz/package.nix +++ b/pkgs/by-name/hi/hidviz/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, cmake -, pkg-config -, stdenv -# Package dependencies -, qt6 -, libusb1 -, protobuf -, asio +{ + lib, + fetchFromGitHub, + cmake, + pkg-config, + stdenv, + # Package dependencies + qt6, + libusb1, + protobuf, + asio, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/hi/hifiscan/package.nix b/pkgs/by-name/hi/hifiscan/package.nix index fbaea667f9aeff..deedff446c16e2 100644 --- a/pkgs/by-name/hi/hifiscan/package.nix +++ b/pkgs/by-name/hi/hifiscan/package.nix @@ -1,28 +1,36 @@ -{ lib -, python3Packages -, fetchPypi +{ + lib, + python3Packages, + fetchPypi, }: let pname = "hifiscan"; version = "1.5.2"; hash = "sha256-8eystqjNdDP2X9beogRcsa+Wqu50uMHZv59jdc5GjUc="; in - python3Packages.buildPythonApplication { - inherit pname version; +python3Packages.buildPythonApplication { + inherit pname version; - pythonPath = with python3Packages; [ eventkit numpy sounddevice pyqt6 pyqt6-sip pyqtgraph ]; + pythonPath = with python3Packages; [ + eventkit + numpy + sounddevice + pyqt6 + pyqt6-sip + pyqtgraph + ]; - dontUseSetuptoolsCheck = true; + dontUseSetuptoolsCheck = true; - src = fetchPypi { - inherit pname version hash; - }; + src = fetchPypi { + inherit pname version hash; + }; - meta = with lib; { - homepage = "https://github.com/erdewit/HiFiScan"; - description = "Optimize the audio quality of your loudspeakers"; - license = licenses.bsd2; - maintainers = with maintainers; [ cab404 ]; - mainProgram = "hifiscan"; - }; - } + meta = with lib; { + homepage = "https://github.com/erdewit/HiFiScan"; + description = "Optimize the audio quality of your loudspeakers"; + license = licenses.bsd2; + maintainers = with maintainers; [ cab404 ]; + mainProgram = "hifiscan"; + }; +} diff --git a/pkgs/by-name/hi/highfive/package.nix b/pkgs/by-name/hi/highfive/package.nix index 3af2fc92cc108a..db3e6a19f6c8e7 100644 --- a/pkgs/by-name/hi/highfive/package.nix +++ b/pkgs/by-name/hi/highfive/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, boost -, eigen -, hdf5 -, mpiSupport ? hdf5.mpiSupport -, mpi ? hdf5.mpi +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + eigen, + hdf5, + mpiSupport ? hdf5.mpiSupport, + mpi ? hdf5.mpi, }: assert mpiSupport -> mpi != null; @@ -23,7 +25,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ boost eigen hdf5 ]; + buildInputs = [ + boost + eigen + hdf5 + ]; passthru = { inherit mpiSupport mpi; @@ -35,8 +41,7 @@ stdenv.mkDerivation rec { "-DHIGHFIVE_EXAMPLES=OFF" "-DHIGHFIVE_UNIT_TESTS=OFF" "-DHIGHFIVE_USE_INSTALL_DEPS=ON" - ] - ++ (lib.optionals mpiSupport [ "-DHIGHFIVE_PARALLEL_HDF5=ON" ]); + ] ++ (lib.optionals mpiSupport [ "-DHIGHFIVE_PARALLEL_HDF5=ON" ]); meta = with lib; { description = "Header-only C++ HDF5 interface"; diff --git a/pkgs/by-name/hi/highlight-assertions/package.nix b/pkgs/by-name/hi/highlight-assertions/package.nix index b2f595cb01ba0d..d8a0ca72988be4 100644 --- a/pkgs/by-name/hi/highlight-assertions/package.nix +++ b/pkgs/by-name/hi/highlight-assertions/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "highlight-assertions"; diff --git a/pkgs/by-name/hi/highs/package.nix b/pkgs/by-name/hi/highs/package.nix index 73460ab54164d7..bd3dff2f56fece 100644 --- a/pkgs/by-name/hi/highs/package.nix +++ b/pkgs/by-name/hi/highs/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, clang -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + clang, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -26,7 +27,10 @@ stdenv.mkDerivation (finalAttrs: { "$out/bin/highs" --version ''; - nativeBuildInputs = [ clang cmake ]; + nativeBuildInputs = [ + clang + cmake + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/hi/hikounomizu/package.nix b/pkgs/by-name/hi/hikounomizu/package.nix index f618d6680529b7..bbf8bfa29ce7e2 100644 --- a/pkgs/by-name/hi/hikounomizu/package.nix +++ b/pkgs/by-name/hi/hikounomizu/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchurl -, cmake -, pkg-config -, util-linux -, libGL -, freetype -, pugixml -, SDL2 -, SDL2_image -, openal -, libogg -, libvorbis -, libGLU -, enet -, synfigstudio -, inkscape -, imagemagick -, pngquant -, xz -, bc +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + util-linux, + libGL, + freetype, + pugixml, + SDL2, + SDL2_image, + openal, + libogg, + libvorbis, + libGLU, + enet, + synfigstudio, + inkscape, + imagemagick, + pngquant, + xz, + bc, }: stdenv.mkDerivation (finalAttrs: { @@ -75,7 +76,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://hikounomizu.org/"; downloadPage = "https://hikounomizu.org/download.html"; maintainers = with maintainers; [ fgaz ]; - license = [ licenses.gpl3Plus licenses.lal13 ]; + license = [ + licenses.gpl3Plus + licenses.lal13 + ]; platforms = platforms.all; }; }) diff --git a/pkgs/by-name/hi/hilbish/package.nix b/pkgs/by-name/hi/hilbish/package.nix index 138a750c6745d2..109b102966b078 100644 --- a/pkgs/by-name/hi/hilbish/package.nix +++ b/pkgs/by-name/hi/hilbish/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "hilbish"; diff --git a/pkgs/by-name/hi/hime/package.nix b/pkgs/by-name/hi/hime/package.nix index e0efa104840cd2..93c36cbf9f4502 100644 --- a/pkgs/by-name/hi/hime/package.nix +++ b/pkgs/by-name/hi/hime/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, fetchFromGitHub -, pkg-config -, which -, gtk2 -, gtk3 -, qt5 -, libXtst -, lib -, libchewing -, unixtools -, anthy +{ + stdenv, + fetchFromGitHub, + pkg-config, + which, + gtk2, + gtk3, + qt5, + libXtst, + lib, + libchewing, + unixtools, + anthy, }: stdenv.mkDerivation rec { @@ -23,18 +24,31 @@ stdenv.mkDerivation rec { sha256 = "sha256-fCqet+foQjI+LpTQ/6Egup1GzXELlL2hgbh0dCKLwPI="; }; - nativeBuildInputs = [ which pkg-config unixtools.whereis ]; - buildInputs = [ libXtst gtk2 gtk3 qt5.qtbase libchewing anthy ]; + nativeBuildInputs = [ + which + pkg-config + unixtools.whereis + ]; + buildInputs = [ + libXtst + gtk2 + gtk3 + qt5.qtbase + libchewing + anthy + ]; preConfigure = "patchShebangs configure"; - configureFlags = [ "--disable-lib64" "--disable-qt5-immodule" ]; + configureFlags = [ + "--disable-lib64" + "--disable-qt5-immodule" + ]; dontWrapQtApps = true; postFixup = '' hime_rpath=$(patchelf --print-rpath $out/bin/hime) patchelf --set-rpath $out/lib/hime:$hime_rpath $out/bin/hime ''; - meta = with lib; { homepage = "http://hime-ime.github.io/"; downloadPage = "https://github.com/hime-ime/hime/downloads"; diff --git a/pkgs/by-name/hi/himitsu-firefox/package.nix b/pkgs/by-name/hi/himitsu-firefox/package.nix index 46a014ce405352..fb7d5c098f145d 100644 --- a/pkgs/by-name/hi/himitsu-firefox/package.nix +++ b/pkgs/by-name/hi/himitsu-firefox/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromSourcehut -, hare -, himitsu -, zip +{ + lib, + stdenv, + fetchFromSourcehut, + hare, + himitsu, + zip, }: stdenv.mkDerivation rec { @@ -38,7 +39,10 @@ stdenv.mkDerivation rec { # > that this will probably not work. The recommended installation procedure # > for the native extension is to install it from addons.mozilla.org instead. installTargets = [ "install-native" ]; - installFlags = [ "PREFIX=" "DESTDIR=$(out)" ]; + installFlags = [ + "PREFIX=" + "DESTDIR=$(out)" + ]; meta = with lib; { homepage = "https://git.sr.ht/~sircmpwn/himitsu-firefox"; diff --git a/pkgs/by-name/hi/hiredis-vip/package.nix b/pkgs/by-name/hi/hiredis-vip/package.nix index 32fd7d0db751f5..727f8ca3beb67a 100644 --- a/pkgs/by-name/hi/hiredis-vip/package.nix +++ b/pkgs/by-name/hi/hiredis-vip/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, lib -, fetchFromGitHub +{ + stdenv, + lib, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/hi/hiredis/package.nix b/pkgs/by-name/hi/hiredis/package.nix index 68c2dc209514e9..b4b2304da600a4 100644 --- a/pkgs/by-name/hi/hiredis/package.nix +++ b/pkgs/by-name/hi/hiredis/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + openssl, +}: stdenv.mkDerivation rec { pname = "hiredis"; diff --git a/pkgs/by-name/hi/hisat2/package.nix b/pkgs/by-name/hi/hisat2/package.nix index 67c39031b773a2..3feeb435579df9 100644 --- a/pkgs/by-name/hi/hisat2/package.nix +++ b/pkgs/by-name/hi/hisat2/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchFromGitHub, unzip, which, python3, perl}: +{ + lib, + stdenv, + fetchFromGitHub, + unzip, + which, + python3, + perl, +}: stdenv.mkDerivation rec { pname = "hisat2"; @@ -11,8 +19,14 @@ stdenv.mkDerivation rec { sha256 = "0lmzdhzjkvxw7n5w40pbv5fgzd4cz0f9pxczswn3d4cr0k10k754"; }; - nativeBuildInputs = [ unzip which ]; - buildInputs = [ python3 perl ]; + nativeBuildInputs = [ + unzip + which + ]; + buildInputs = [ + python3 + perl + ]; installPhase = '' mkdir -p $out/bin @@ -40,7 +54,10 @@ stdenv.mkDerivation rec { license = licenses.gpl3Plus; homepage = "https://daehwankimlab.github.io/hisat2/"; maintainers = with maintainers; [ jbedo ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/by-name/hi/hishtory/package.nix b/pkgs/by-name/hi/hishtory/package.nix index 863afa75e9b36d..0c6e0a05d99a46 100644 --- a/pkgs/by-name/hi/hishtory/package.nix +++ b/pkgs/by-name/hi/hishtory/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { @@ -37,4 +38,3 @@ buildGoModule rec { mainProgram = "hishtory"; }; } - diff --git a/pkgs/by-name/hi/hitch/package.nix b/pkgs/by-name/hi/hitch/package.nix index bed9f77908a1fa..6b6faeab53c7c9 100644 --- a/pkgs/by-name/hi/hitch/package.nix +++ b/pkgs/by-name/hi/hitch/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, docutils, libev, openssl, pkg-config, nixosTests }: +{ + lib, + stdenv, + fetchurl, + docutils, + libev, + openssl, + pkg-config, + nixosTests, +}: stdenv.mkDerivation rec { version = "1.8.0"; pname = "hitch"; @@ -9,9 +18,17 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ docutils libev openssl ]; + buildInputs = [ + docutils + libev + openssl + ]; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; passthru.tests.hitch = nixosTests.hitch; diff --git a/pkgs/by-name/hi/hivelytracker/package.nix b/pkgs/by-name/hi/hivelytracker/package.nix index 49cd0a78ed7517..a6b687b2088026 100644 --- a/pkgs/by-name/hi/hivelytracker/package.nix +++ b/pkgs/by-name/hi/hivelytracker/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, SDL -, SDL_image -, SDL_ttf -, gtk3 -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + SDL, + SDL_image, + SDL_ttf, + gtk3, + wrapGAppsHook3, }: stdenv.mkDerivation (finalAttrs: { @@ -16,7 +17,7 @@ stdenv.mkDerivation (finalAttrs: { src = fetchFromGitHub { owner = "pete-gordon"; repo = "hivelytracker"; - rev = "V${lib.replaceStrings ["."] ["_"] finalAttrs.version}"; + rev = "V${lib.replaceStrings [ "." ] [ "_" ] finalAttrs.version}"; sha256 = "148p320sd8phcpmj4m85ns5zly2dawbp8kgx9ryjfdk24pa88xg6"; }; diff --git a/pkgs/by-name/hi/hivemind/package.nix b/pkgs/by-name/hi/hivemind/package.nix index 589c6fa8073679..0e01aa8aa42b54 100644 --- a/pkgs/by-name/hi/hivemind/package.nix +++ b/pkgs/by-name/hi/hivemind/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, runtimeShell }: +{ + lib, + buildGoModule, + fetchFromGitHub, + runtimeShell, +}: buildGoModule rec { pname = "hivemind"; diff --git a/pkgs/by-name/hj/hjson-go/package.nix b/pkgs/by-name/hj/hjson-go/package.nix index 0e625e2985b63e..f0b906ad0808db 100644 --- a/pkgs/by-name/hj/hjson-go/package.nix +++ b/pkgs/by-name/hj/hjson-go/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/hl/hledger-check-fancyassertions/package.nix b/pkgs/by-name/hl/hledger-check-fancyassertions/package.nix index 366f4fb2ae97e4..94ce06940e98f4 100644 --- a/pkgs/by-name/hl/hledger-check-fancyassertions/package.nix +++ b/pkgs/by-name/hl/hledger-check-fancyassertions/package.nix @@ -1,4 +1,10 @@ -{lib, stdenvNoCC, haskellPackages, fetchurl, writers}: +{ + lib, + stdenvNoCC, + haskellPackages, + fetchurl, + writers, +}: stdenvNoCC.mkDerivation rec { pname = "hledger-check-fancyassertions"; @@ -13,18 +19,23 @@ stdenvNoCC.mkDerivation rec { dontUnpack = true; dontBuild = true; - executable = writers.writeHaskell - "hledger-check-fancyassertions" - { - libraries = with haskellPackages; [ - hledger-lib - base base-compat base-compat-batteries filepath - megaparsec microlens optparse-applicative string-qq text time - transformers - ]; - inherit (haskellPackages) ghc; - } - src; + executable = writers.writeHaskell "hledger-check-fancyassertions" { + libraries = with haskellPackages; [ + hledger-lib + base + base-compat + base-compat-batteries + filepath + megaparsec + microlens + optparse-applicative + string-qq + text + time + transformers + ]; + inherit (haskellPackages) ghc; + } src; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/hm/hmat-oss/package.nix b/pkgs/by-name/hm/hmat-oss/package.nix index 0981ff2f821402..41ac38f06901e0 100644 --- a/pkgs/by-name/hm/hmat-oss/package.nix +++ b/pkgs/by-name/hm/hmat-oss/package.nix @@ -1,12 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, blas -, lapack +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + blas, + lapack, }: - stdenv.mkDerivation rec { pname = "hmat-oss"; version = "1.10.0"; @@ -23,7 +23,10 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ blas lapack ]; + buildInputs = [ + blas + lapack + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/hm/hmm/package.nix b/pkgs/by-name/hm/hmm/package.nix index c20f3a9626f51b..da9fd42f19e29c 100644 --- a/pkgs/by-name/hm/hmm/package.nix +++ b/pkgs/by-name/hm/hmm/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchCrate -, perl +{ + lib, + rustPlatform, + fetchCrate, + perl, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/hm/hmmer/package.nix b/pkgs/by-name/hm/hmmer/package.nix index 243e067ddec30e..81d0cdb1ec814a 100644 --- a/pkgs/by-name/hm/hmmer/package.nix +++ b/pkgs/by-name/hm/hmmer/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "3.4"; diff --git a/pkgs/by-name/hn/hnswlib/package.nix b/pkgs/by-name/hn/hnswlib/package.nix index 59cd69f9629e4e..9d8c7c5cf22557 100644 --- a/pkgs/by-name/hn/hnswlib/package.nix +++ b/pkgs/by-name/hn/hnswlib/package.nix @@ -1,13 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, }: let - python = python3.withPackages(ps: with ps; [ - numpy - ]); + python = python3.withPackages ( + ps: with ps; [ + numpy + ] + ); in stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ho/hoard/package.nix b/pkgs/by-name/ho/hoard/package.nix index 1972c9c793862c..b84f583f5d47b0 100644 --- a/pkgs/by-name/ho/hoard/package.nix +++ b/pkgs/by-name/ho/hoard/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -22,18 +23,23 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; meta = with lib; { description = "CLI command organizer written in rust"; homepage = "https://github.com/hyde46/hoard"; changelog = "https://github.com/Hyde46/hoard/blob/${src.rev}/CHANGES.md"; license = licenses.mit; - maintainers = with maintainers; [ builditluc figsoda ]; + maintainers = with maintainers; [ + builditluc + figsoda + ]; mainProgram = "hoard"; }; } diff --git a/pkgs/by-name/ho/hobbes/package.nix b/pkgs/by-name/ho/hobbes/package.nix index f6d8c0fb8624a5..7e62d9e026865f 100644 --- a/pkgs/by-name/ho/hobbes/package.nix +++ b/pkgs/by-name/ho/hobbes/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, llvmPackages -, fetchFromGitHub -, fetchpatch -, cmake -, llvm_12 -, ncurses -, readline -, zlib -, libxml2 -, python3 +{ + lib, + stdenv, + llvmPackages, + fetchFromGitHub, + fetchpatch, + cmake, + llvm_12, + ncurses, + readline, + zlib, + libxml2, + python3, }: llvmPackages.stdenv.mkDerivation { pname = "hobbes"; @@ -66,7 +67,13 @@ llvmPackages.stdenv.mkDerivation { ''; homepage = "https://github.com/morganstanley/hobbes"; license = licenses.asl20; - maintainers = with maintainers; [ kthielen thmzlt ]; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + maintainers = with maintainers; [ + kthielen + thmzlt + ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; }; } diff --git a/pkgs/by-name/ho/hol/package.nix b/pkgs/by-name/ho/hol/package.nix index 883eb4331c9fad..8e482bfb3fb03d 100644 --- a/pkgs/by-name/ho/hol/package.nix +++ b/pkgs/by-name/ho/hol/package.nix @@ -1,5 +1,13 @@ -{lib, stdenv, pkgs, fetchurl, graphviz, fontconfig, liberation_ttf, - experimentalKernel ? true}: +{ + lib, + stdenv, + pkgs, + fetchurl, + graphviz, + fontconfig, + liberation_ttf, + experimentalKernel ? true, +}: let pname = "hol4"; @@ -10,9 +18,11 @@ let holsubdir = "hol-${longVersion}"; kernelFlag = if experimentalKernel then "--expk" else "--stdknl"; - polymlEnableShared = with pkgs; lib.overrideDerivation polyml (attrs: { - configureFlags = [ "--enable-shared" ]; - }); + polymlEnableShared = + with pkgs; + lib.overrideDerivation polyml (attrs: { + configureFlags = [ "--enable-shared" ]; + }); in stdenv.mkDerivation { @@ -23,7 +33,12 @@ stdenv.mkDerivation { sha256 = "6Mc/qsEjzxGqzt6yP6x/1Tmqpwc1UDGlwV1Gl+4pMsY="; }; - buildInputs = [polymlEnableShared graphviz fontconfig liberation_ttf]; + buildInputs = [ + polymlEnableShared + graphviz + fontconfig + liberation_ttf + ]; buildCommand = '' diff --git a/pkgs/by-name/ho/holehe/package.nix b/pkgs/by-name/ho/holehe/package.nix index 872cde1f8f875c..531ca97a2ffe32 100644 --- a/pkgs/by-name/ho/holehe/package.nix +++ b/pkgs/by-name/ho/holehe/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ho/holo-build/package.nix b/pkgs/by-name/ho/holo-build/package.nix index cef9c6c5fb175e..0ed9d9232b56fd 100644 --- a/pkgs/by-name/ho/holo-build/package.nix +++ b/pkgs/by-name/ho/holo-build/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, perl, file }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + perl, + file, +}: buildGoModule rec { pname = "holo-build"; @@ -20,11 +27,18 @@ buildGoModule rec { vendorHash = null; - nativeBuildInputs = [ installShellFiles perl ]; + nativeBuildInputs = [ + installShellFiles + perl + ]; subPackages = [ "src/holo-build" ]; - ldflags = [ "-s" "-w" "-X github.com/holocm/holo-build/src/holo-build/common.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/holocm/holo-build/src/holo-build/common.version=${version}" + ]; postBuild = '' make build/man/holo-build.8 VERSION=${version} diff --git a/pkgs/by-name/ho/holochain-launcher/package.nix b/pkgs/by-name/ho/holochain-launcher/package.nix index 7ae6626d9662c3..8e3b718f069243 100644 --- a/pkgs/by-name/ho/holochain-launcher/package.nix +++ b/pkgs/by-name/ho/holochain-launcher/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchurl -, autoPatchelfHook -, dpkg -, openssl -, webkitgtk_4_0 -, libappindicator -, wrapGAppsHook3 -, shared-mime-info -, glib-networking +{ + stdenv, + lib, + fetchurl, + autoPatchelfHook, + dpkg, + openssl, + webkitgtk_4_0, + libappindicator, + wrapGAppsHook3, + shared-mime-info, + glib-networking, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ho/hologram/package.nix b/pkgs/by-name/ho/hologram/package.nix index 139f8fa18b59de..705e6d87af6c10 100644 --- a/pkgs/by-name/ho/hologram/package.nix +++ b/pkgs/by-name/ho/hologram/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "hologram"; @@ -19,7 +23,10 @@ buildGoModule rec { vendorHash = "sha256-HI5+02qSQVLy6ZKaFjy1bWtvVk5bqMBg1umu2ic5HuY="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/AdRoll/hologram/"; diff --git a/pkgs/by-name/ho/home-manager/package.nix b/pkgs/by-name/ho/home-manager/package.nix index 95705fae3a8b0f..fa2fb7e40cd3c0 100644 --- a/pkgs/by-name/ho/home-manager/package.nix +++ b/pkgs/by-name/ho/home-manager/package.nix @@ -1,19 +1,20 @@ -{ lib -, bash -, coreutils -, fetchFromGitHub -, findutils -, gettext -, gnused -, inetutils -, installShellFiles -, jq -, less -, ncurses -, nixos-option -, stdenvNoCC -, unixtools -, unstableGitUpdater +{ + lib, + bash, + coreutils, + fetchFromGitHub, + findutils, + gettext, + gnused, + inetutils, + installShellFiles, + jq, + less, + ncurses, + nixos-option, + stdenvNoCC, + unixtools, + unstableGitUpdater, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ho/homeassistant-satellite/package.nix b/pkgs/by-name/ho/homeassistant-satellite/package.nix index 40a489aa68de03..8a07c104c8f5f8 100644 --- a/pkgs/by-name/ho/homeassistant-satellite/package.nix +++ b/pkgs/by-name/ho/homeassistant-satellite/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ho/homebank/package.nix b/pkgs/by-name/ho/homebank/package.nix index 74eafcc0ac37ca..3ea15a1d5d13d0 100644 --- a/pkgs/by-name/ho/homebank/package.nix +++ b/pkgs/by-name/ho/homebank/package.nix @@ -1,24 +1,45 @@ -{ fetchurl, lib, stdenv, gtk3, pkg-config, libofx, intltool, wrapGAppsHook3 -, libsoup_3, adwaita-icon-theme }: +{ + fetchurl, + lib, + stdenv, + gtk3, + pkg-config, + libofx, + intltool, + wrapGAppsHook3, + libsoup_3, + adwaita-icon-theme, +}: stdenv.mkDerivation rec { pname = "homebank"; version = "5.8.5"; src = fetchurl { - url = - "https://www.gethomebank.org/public/sources/homebank-${version}.tar.gz"; + url = "https://www.gethomebank.org/public/sources/homebank-${version}.tar.gz"; hash = "sha256-TrRFHleEA5VGjC1qP+TQFq2gun1Hyn8c7AQYwKEznpc="; }; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 intltool ]; - buildInputs = [ gtk3 libofx libsoup_3 adwaita-icon-theme ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + intltool + ]; + buildInputs = [ + gtk3 + libofx + libsoup_3 + adwaita-icon-theme + ]; meta = with lib; { description = "Free, easy, personal accounting for everyone"; mainProgram = "homebank"; homepage = "https://www.gethomebank.org"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ pSub frlan ]; + maintainers = with maintainers; [ + pSub + frlan + ]; platforms = platforms.linux ++ platforms.darwin; }; } diff --git a/pkgs/by-name/ho/honcho/package.nix b/pkgs/by-name/ho/honcho/package.nix index 1540d227dffe3e..d6020118788357 100644 --- a/pkgs/by-name/ho/honcho/package.nix +++ b/pkgs/by-name/ho/honcho/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: let pname = "honcho"; @@ -17,7 +21,12 @@ python3Packages.buildPythonApplication rec { propagatedBuildInputs = [ python3Packages.setuptools ]; - nativeCheckInputs = with python3Packages; [ jinja2 pytest mock coverage ]; + nativeCheckInputs = with python3Packages; [ + jinja2 + pytest + mock + coverage + ]; # missing plugins doCheck = false; diff --git a/pkgs/by-name/ho/honeycomb-refinery/package.nix b/pkgs/by-name/ho/honeycomb-refinery/package.nix index 364115b6bfee09..690636870e80a2 100644 --- a/pkgs/by-name/ho/honeycomb-refinery/package.nix +++ b/pkgs/by-name/ho/honeycomb-refinery/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "honeycomb-refinery"; @@ -22,7 +26,11 @@ buildGoModule rec { excludedPackages = [ "cmd/test_redimem" ]; - ldflags = [ "-s" "-w" "-X main.BuildID=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.BuildID=${version}" + ]; vendorHash = "sha256-0M05JGLdmKivRTN8ZdhAm+JtXTlYAC31wFS82g3NenI="; diff --git a/pkgs/by-name/ho/honeytrap/package.nix b/pkgs/by-name/ho/honeytrap/package.nix index 8f83e120fdd9ee..ecdf20d5f88b35 100644 --- a/pkgs/by-name/ho/honeytrap/package.nix +++ b/pkgs/by-name/ho/honeytrap/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGo122Module -, fetchFromGitHub +{ + lib, + buildGo122Module, + fetchFromGitHub, }: buildGo122Module { pname = "honeytrap"; diff --git a/pkgs/by-name/ho/honk/package.nix b/pkgs/by-name/ho/honk/package.nix index a5a494298a0349..d0bb6450f01fb8 100644 --- a/pkgs/by-name/ho/honk/package.nix +++ b/pkgs/by-name/ho/honk/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchurl -, sqlite -, installShellFiles -, nixosTests +{ + lib, + buildGoModule, + fetchurl, + sqlite, + installShellFiles, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/by-name/ho/hop/package.nix b/pkgs/by-name/ho/hop/package.nix index 0c1f2a09e1238c..cdf9785287e77d 100644 --- a/pkgs/by-name/ho/hop/package.nix +++ b/pkgs/by-name/ho/hop/package.nix @@ -1,10 +1,18 @@ -{ lib, stdenv, fetchurl, bigloo }: +{ + lib, + stdenv, + fetchurl, + bigloo, +}: # Compute the “release” version of bigloo (before the first dash, if any) -let bigloo-release = - let inherit (lib) head splitString; in - head (splitString "-" (builtins.parseDrvName bigloo.name).version) -; in +let + bigloo-release = + let + inherit (lib) head splitString; + in + head (splitString "-" (builtins.parseDrvName bigloo.name).version); +in stdenv.mkDerivation rec { pname = "hop"; diff --git a/pkgs/by-name/ho/hoppet/package.nix b/pkgs/by-name/ho/hoppet/package.nix index af6200b9c57848..90a501d04e223b 100644 --- a/pkgs/by-name/ho/hoppet/package.nix +++ b/pkgs/by-name/ho/hoppet/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, gfortran, perl }: +{ + lib, + stdenv, + fetchurl, + gfortran, + perl, +}: stdenv.mkDerivation rec { pname = "hoppet"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "0j7437rh4xxbfzmkjr22ry34xm266gijzj6mvrq193fcsfzipzdz"; }; - nativeBuildInputs = [ perl gfortran ]; + nativeBuildInputs = [ + perl + gfortran + ]; enableParallelBuilding = true; @@ -20,9 +29,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Higher Order Perturbative Parton Evolution Toolkit"; mainProgram = "hoppet-config"; - license = licenses.gpl2; - homepage = "https://hoppet.hepforge.org"; - platforms = platforms.unix; + license = licenses.gpl2; + homepage = "https://hoppet.hepforge.org"; + platforms = platforms.unix; maintainers = with maintainers; [ veprbl ]; }; } diff --git a/pkgs/by-name/ho/horst/package.nix b/pkgs/by-name/ho/horst/package.nix index 2e220a171cc27f..cb9d6492ad61e9 100644 --- a/pkgs/by-name/ho/horst/package.nix +++ b/pkgs/by-name/ho/horst/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchFromGitHub, fetchpatch, pkg-config, ncurses, libnl }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + ncurses, + libnl, +}: stdenv.mkDerivation rec { pname = "horst"; @@ -28,7 +36,10 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ ncurses libnl ]; + buildInputs = [ + ncurses + libnl + ]; installFlags = [ "DESTDIR=${placeholder "out"}" ]; diff --git a/pkgs/by-name/ho/hostapd-mana/package.nix b/pkgs/by-name/ho/hostapd-mana/package.nix index b32fe76b022358..73d17245e42587 100644 --- a/pkgs/by-name/ho/hostapd-mana/package.nix +++ b/pkgs/by-name/ho/hostapd-mana/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, pkg-config -, libnl -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + libnl, + openssl, }: stdenv.mkDerivation rec { @@ -27,7 +28,10 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libnl openssl ]; + buildInputs = [ + libnl + openssl + ]; extraConfig = '' CONFIG_DRIVER_WIRED=y diff --git a/pkgs/by-name/ho/hostapd/package.nix b/pkgs/by-name/ho/hostapd/package.nix index 10abb04f776fc0..30eba3baca9138 100644 --- a/pkgs/by-name/ho/hostapd/package.nix +++ b/pkgs/by-name/ho/hostapd/package.nix @@ -19,7 +19,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libnl openssl sqlite ]; + buildInputs = [ + libnl + openssl + sqlite + ]; patches = [ (fetchurl { @@ -30,69 +34,74 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; # Based on hostapd's defconfig. Only differences are tracked. - extraConfig = '' - # Use epoll(7) instead of select(2) on linux - CONFIG_ELOOP_EPOLL=y - - # Drivers - CONFIG_DRIVER_WIRED=y - CONFIG_DRIVER_NONE=y - - # Integrated EAP server - CONFIG_EAP_SIM=y - CONFIG_EAP_AKA=y - CONFIG_EAP_AKA_PRIME=y - CONFIG_EAP_PAX=y - CONFIG_EAP_PSK=y - CONFIG_EAP_PWD=y - CONFIG_EAP_SAKE=y - CONFIG_EAP_GPSK=y - CONFIG_EAP_GPSK_SHA256=y - CONFIG_EAP_FAST=y - CONFIG_EAP_IKEV2=y - CONFIG_EAP_TNC=y - CONFIG_EAP_EKE=y - - CONFIG_TLS=openssl - CONFIG_TLSV11=y - CONFIG_TLSV12=y - - CONFIG_SAE=y - CONFIG_SAE_PK=y - - CONFIG_OWE=y - CONFIG_OCV=y - - # TKIP is considered insecure and upstream support will be removed in the future - CONFIG_NO_TKIP=y - - # Misc - CONFIG_RADIUS_SERVER=y - CONFIG_MACSEC=y - CONFIG_DRIVER_MACSEC_LINUX=y - CONFIG_FULL_DYNAMIC_VLAN=y - CONFIG_VLAN_NETLINK=y - CONFIG_GETRANDOM=y - CONFIG_INTERWORKING=y - CONFIG_HS20=y - CONFIG_FST=y - CONFIG_FST_TEST=y - CONFIG_ACS=y - CONFIG_WNM=y - CONFIG_MBO=y - - CONFIG_IEEE80211R=y - CONFIG_IEEE80211W=y - CONFIG_IEEE80211N=y - CONFIG_IEEE80211AC=y - CONFIG_IEEE80211AX=y - CONFIG_IEEE80211BE=y - '' + lib.optionalString (sqlite != null) '' - CONFIG_SQLITE=y - ''; + extraConfig = + '' + # Use epoll(7) instead of select(2) on linux + CONFIG_ELOOP_EPOLL=y + + # Drivers + CONFIG_DRIVER_WIRED=y + CONFIG_DRIVER_NONE=y + + # Integrated EAP server + CONFIG_EAP_SIM=y + CONFIG_EAP_AKA=y + CONFIG_EAP_AKA_PRIME=y + CONFIG_EAP_PAX=y + CONFIG_EAP_PSK=y + CONFIG_EAP_PWD=y + CONFIG_EAP_SAKE=y + CONFIG_EAP_GPSK=y + CONFIG_EAP_GPSK_SHA256=y + CONFIG_EAP_FAST=y + CONFIG_EAP_IKEV2=y + CONFIG_EAP_TNC=y + CONFIG_EAP_EKE=y + + CONFIG_TLS=openssl + CONFIG_TLSV11=y + CONFIG_TLSV12=y + + CONFIG_SAE=y + CONFIG_SAE_PK=y + + CONFIG_OWE=y + CONFIG_OCV=y + + # TKIP is considered insecure and upstream support will be removed in the future + CONFIG_NO_TKIP=y + + # Misc + CONFIG_RADIUS_SERVER=y + CONFIG_MACSEC=y + CONFIG_DRIVER_MACSEC_LINUX=y + CONFIG_FULL_DYNAMIC_VLAN=y + CONFIG_VLAN_NETLINK=y + CONFIG_GETRANDOM=y + CONFIG_INTERWORKING=y + CONFIG_HS20=y + CONFIG_FST=y + CONFIG_FST_TEST=y + CONFIG_ACS=y + CONFIG_WNM=y + CONFIG_MBO=y + + CONFIG_IEEE80211R=y + CONFIG_IEEE80211W=y + CONFIG_IEEE80211N=y + CONFIG_IEEE80211AC=y + CONFIG_IEEE80211AX=y + CONFIG_IEEE80211BE=y + '' + + lib.optionalString (sqlite != null) '' + CONFIG_SQLITE=y + ''; passAsFile = [ "extraConfig" ]; diff --git a/pkgs/by-name/ho/hostctl/package.nix b/pkgs/by-name/ho/hostctl/package.nix index 76c41d85ecdfd7..6cc9412266e9c8 100644 --- a/pkgs/by-name/ho/hostctl/package.nix +++ b/pkgs/by-name/ho/hostctl/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/ho/hostess/package.nix b/pkgs/by-name/ho/hostess/package.nix index efc849f0651d99..28ab7185d9dfe3 100644 --- a/pkgs/by-name/ho/hostess/package.nix +++ b/pkgs/by-name/ho/hostess/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "hostess"; diff --git a/pkgs/by-name/ho/hostmux/package.nix b/pkgs/by-name/ho/hostmux/package.nix index 405383d648becd..cc3dcf8339bbd4 100644 --- a/pkgs/by-name/ho/hostmux/package.nix +++ b/pkgs/by-name/ho/hostmux/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles -, openssh -, tmux -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + openssh, + tmux, + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ho/hostname-debian/package.nix b/pkgs/by-name/ho/hostname-debian/package.nix index 07135b35cc535f..ca2c7866ef4b16 100644 --- a/pkgs/by-name/ho/hostname-debian/package.nix +++ b/pkgs/by-name/ho/hostname-debian/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchurl }: +{ + stdenv, + lib, + fetchurl, +}: stdenv.mkDerivation rec { pname = "hostname-debian"; @@ -12,7 +16,10 @@ stdenv.mkDerivation rec { postPatch = '' substituteInPlace Makefile --replace 'install -o root -g root' 'install' ''; - makeFlags = [ "BINDIR=$(out)/bin" "MANDIR=$(out)/share/man" ]; + makeFlags = [ + "BINDIR=$(out)/bin" + "MANDIR=$(out)/share/man" + ]; meta = with lib; { description = "Utility to set/show the host name or domain name"; diff --git a/pkgs/by-name/ho/hostsblock/package.nix b/pkgs/by-name/ho/hostsblock/package.nix index 96eac13b76a482..491447311b3929 100644 --- a/pkgs/by-name/ho/hostsblock/package.nix +++ b/pkgs/by-name/ho/hostsblock/package.nix @@ -1,23 +1,33 @@ -{ lib, coreutils, curl, fetchFromGitHub, unzip, p7zip, gnused, gnugrep, stdenv -, blacklist ? [ "adwords.google.com" ] -, whitelist ? [ - ".dropbox.com" - " www.malwaredomainlists.com" - " www.arcamax.com" - " www.instructables.com" - " goo.gl" - " www.reddit.com" - " t.co" - " bit.ly" - " www.viddler.com" - " viddler.com" - " tinyurl.com" - " ompldr.org" - " www.ompldr.org" - "login.yahoo.com" - " l.yimg.com" - ".bp.blogspot.com" -] }: +{ + lib, + coreutils, + curl, + fetchFromGitHub, + unzip, + p7zip, + gnused, + gnugrep, + stdenv, + blacklist ? [ "adwords.google.com" ], + whitelist ? [ + ".dropbox.com" + " www.malwaredomainlists.com" + " www.arcamax.com" + " www.instructables.com" + " goo.gl" + " www.reddit.com" + " t.co" + " bit.ly" + " www.viddler.com" + " viddler.com" + " tinyurl.com" + " ompldr.org" + " www.ompldr.org" + "login.yahoo.com" + " l.yimg.com" + ".bp.blogspot.com" + ], +}: stdenv.mkDerivation { pname = "hostsblock"; diff --git a/pkgs/by-name/ho/hotpatch/package.nix b/pkgs/by-name/ho/hotpatch/package.nix index 7dcf09c5c5b2b2..b1b2ae54371663 100644 --- a/pkgs/by-name/ho/hotpatch/package.nix +++ b/pkgs/by-name/ho/hotpatch/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "hotpatch"; @@ -35,6 +40,9 @@ stdenv.mkDerivation rec { homepage = src.meta.homepage; license = licenses.bsd3; maintainers = [ ]; - platforms = ["i686-linux" "x86_64-linux"]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/ho/hottext/package.nix b/pkgs/by-name/ho/hottext/package.nix index 021e44f3c093fc..7269f16a5ac213 100644 --- a/pkgs/by-name/ho/hottext/package.nix +++ b/pkgs/by-name/ho/hottext/package.nix @@ -1,4 +1,10 @@ -{ lib, buildNimPackage, fetchFromSourcehut, gentium, makeDesktopItem }: +{ + lib, + buildNimPackage, + fetchFromSourcehut, + gentium, + makeDesktopItem, +}: buildNimPackage (finalAttrs: { pname = "hottext"; diff --git a/pkgs/by-name/ho/hound/package.nix b/pkgs/by-name/ho/hound/package.nix index 6e3124556f547a..2c3b996339328a 100644 --- a/pkgs/by-name/ho/hound/package.nix +++ b/pkgs/by-name/ho/hound/package.nix @@ -1,12 +1,13 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, mercurial -, git -, openssh -, nixosTests -, fetchpatch +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + mercurial, + git, + openssh, + nixosTests, + fetchpatch, }: buildGoModule rec { @@ -41,7 +42,13 @@ buildGoModule rec { doCheck = false; postInstall = '' - wrapProgram $out/bin/houndd --prefix PATH : ${lib.makeBinPath [ mercurial git openssh ]} + wrapProgram $out/bin/houndd --prefix PATH : ${ + lib.makeBinPath [ + mercurial + git + openssh + ] + } ''; passthru.tests = { inherit (nixosTests) hound; }; @@ -50,6 +57,9 @@ buildGoModule rec { description = "Lightning fast code searching made easy"; homepage = "https://github.com/hound-search/hound"; license = licenses.mit; - maintainers = with maintainers; [ grahamc SuperSandro2000 ]; + maintainers = with maintainers; [ + grahamc + SuperSandro2000 + ]; }; } diff --git a/pkgs/by-name/ho/hover/package.nix b/pkgs/by-name/ho/hover/package.nix index b661adaac136b1..04e4ce63dab057 100644 --- a/pkgs/by-name/ho/hover/package.nix +++ b/pkgs/by-name/ho/hover/package.nix @@ -1,18 +1,19 @@ -{ lib -, buildGoModule -, buildFHSEnv -, binutils -, dejavu_fonts -, pkg-config -, fetchFromGitHub -, roboto -, xorg -, libglvnd -, addDriverRunpath -, makeWrapper -, gcc -, go -, flutter +{ + lib, + buildGoModule, + buildFHSEnv, + binutils, + dejavu_fonts, + pkg-config, + fetchFromGitHub, + roboto, + xorg, + libglvnd, + addDriverRunpath, + makeWrapper, + gcc, + go, + flutter, }: let @@ -54,7 +55,10 @@ let sha256 = "sha256-ch59Wx4g72u7x99807ppURI4I+5aJ/W8Zr35q8X68v4="; }; - nativeBuildInputs = [ addDriverRunpath makeWrapper ]; + nativeBuildInputs = [ + addDriverRunpath + makeWrapper + ]; buildInputs = libs; @@ -85,16 +89,19 @@ let in buildFHSEnv rec { inherit pname version; - targetPkgs = pkgs: [ - binutils - dejavu_fonts - flutter - gcc - go - hover - pkg-config - roboto - ] ++ libs; + targetPkgs = + pkgs: + [ + binutils + dejavu_fonts + flutter + gcc + go + hover + pkg-config + roboto + ] + ++ libs; runScript = "hover"; } diff --git a/pkgs/by-name/ho/howl/package.nix b/pkgs/by-name/ho/howl/package.nix index 3a261f3e8714cd..7456ac9582eae0 100644 --- a/pkgs/by-name/ho/howl/package.nix +++ b/pkgs/by-name/ho/howl/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeWrapper, pkg-config, gtk3, librsvg }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + pkg-config, + gtk3, + librsvg, +}: stdenv.mkDerivation rec { pname = "howl"; @@ -15,8 +23,14 @@ stdenv.mkDerivation rec { # The Makefile uses "/usr/local" if not explicitly overridden installFlags = [ "PREFIX=$(out)" ]; - nativeBuildInputs = [ makeWrapper pkg-config ]; - buildInputs = [ gtk3 librsvg ]; + nativeBuildInputs = [ + makeWrapper + pkg-config + ]; + buildInputs = [ + gtk3 + librsvg + ]; enableParallelBuilding = true; # Required for the program to properly load its SVG assets @@ -33,7 +47,9 @@ stdenv.mkDerivation rec { mainProgram = "howl"; # LuaJIT and Howl builds fail for x86_64-darwin and aarch64-linux respectively - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } - diff --git a/pkgs/by-name/hp/hp2p/package.nix b/pkgs/by-name/hp/hp2p/package.nix index cd6d6e8b9dd94e..1d1bd5d80ae27f 100644 --- a/pkgs/by-name/hp/hp2p/package.nix +++ b/pkgs/by-name/hp/hp2p/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, mpi, python3Packages, autoconf, automake } : +{ + lib, + stdenv, + fetchFromGitHub, + mpi, + python3Packages, + autoconf, + automake, +}: stdenv.mkDerivation rec { pname = "hp2p"; @@ -12,9 +20,18 @@ stdenv.mkDerivation rec { }; enableParallelBuilding = true; - nativeBuildInputs = [ autoconf automake python3Packages.wrapPython ]; - buildInputs = [ mpi ] ++ (with python3Packages; [ python plotly ]) ; - pythonPath = (with python3Packages; [ plotly ]) ; + nativeBuildInputs = [ + autoconf + automake + python3Packages.wrapPython + ]; + buildInputs = + [ mpi ] + ++ (with python3Packages; [ + python + plotly + ]); + pythonPath = (with python3Packages; [ plotly ]); preConfigure = '' patchShebangs autogen.sh diff --git a/pkgs/by-name/hp/hpe-ltfs/package.nix b/pkgs/by-name/hp/hpe-ltfs/package.nix index 017df9a800739c..b17c45e8c56fa2 100644 --- a/pkgs/by-name/hp/hpe-ltfs/package.nix +++ b/pkgs/by-name/hp/hpe-ltfs/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fuse, icu66, pkg-config, libxml2, libuuid }: +{ + lib, + stdenv, + fetchFromGitHub, + fuse, + icu66, + pkg-config, + libxml2, + libuuid, +}: stdenv.mkDerivation rec { version = "3.4.2_Z7550-02501"; @@ -21,7 +30,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - fuse icu66 libxml2 libuuid + fuse + icu66 + libxml2 + libuuid ]; meta = with lib; { diff --git a/pkgs/by-name/hp/hping/package.nix b/pkgs/by-name/hp/hping/package.nix index 10bd63d489271d..e09d835cb70fa4 100644 --- a/pkgs/by-name/hp/hping/package.nix +++ b/pkgs/by-name/hp/hping/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, libpcap, withTcl ? true, tcl }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + libpcap, + withTcl ? true, + tcl, +}: stdenv.mkDerivation rec { pname = "hping"; @@ -22,20 +30,25 @@ stdenv.mkDerivation rec { buildInputs = [ libpcap ] ++ lib.optional withTcl tcl; - postPatch = '' - substituteInPlace Makefile.in --replace "gcc" "$CC" - substituteInPlace version.c --replace "RELEASE_DATE" "\"$version\"" - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - sed -i -e 's|#include |#include |' \ - libpcap_stuff.c script.c - '' + lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' - substituteInPlace configure --replace 'BYTEORDER=`./byteorder -m`' BYTEORDER=${ - { - littleEndian = "__LITTLE_ENDIAN_BITFIELD"; - bigEndian = "__BIG_ENDIAN_BITFIELD"; - }.${stdenv.hostPlatform.parsed.cpu.significantByte.name}} - substituteInPlace Makefile.in --replace './hping3 -v' "" - ''; + postPatch = + '' + substituteInPlace Makefile.in --replace "gcc" "$CC" + substituteInPlace version.c --replace "RELEASE_DATE" "\"$version\"" + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + sed -i -e 's|#include |#include |' \ + libpcap_stuff.c script.c + '' + + lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' + substituteInPlace configure --replace 'BYTEORDER=`./byteorder -m`' BYTEORDER=${ + { + littleEndian = "__LITTLE_ENDIAN_BITFIELD"; + bigEndian = "__BIG_ENDIAN_BITFIELD"; + } + .${stdenv.hostPlatform.parsed.cpu.significantByte.name} + } + substituteInPlace Makefile.in --replace './hping3 -v' "" + ''; configureFlags = [ (if withTcl then "TCLSH=${tcl}/bin/tclsh" else "--no-tcl") ]; diff --git a/pkgs/by-name/hp/hpl/package.nix b/pkgs/by-name/hp/hpl/package.nix index 0abd8edd527b88..694f8aec1b8c00 100644 --- a/pkgs/by-name/hp/hpl/package.nix +++ b/pkgs/by-name/hp/hpl/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, blas, lapack, mpi } : +{ + lib, + stdenv, + fetchurl, + blas, + lapack, + mpi, +}: assert (!blas.isILP64) && (!lapack.isILP64); @@ -20,7 +27,11 @@ stdenv.mkDerivation rec { install -D testing/ptest/HPL.dat $out/share/hpl/HPL.dat ''; - buildInputs = [ blas lapack mpi ]; + buildInputs = [ + blas + lapack + mpi + ]; meta = with lib; { description = "Portable Implementation of the Linpack Benchmark for Distributed-Memory Computers"; diff --git a/pkgs/by-name/hp/hplip/package.nix b/pkgs/by-name/hp/hplip/package.nix index cba838569ffa66..d5d7e1cc99b30c 100644 --- a/pkgs/by-name/hp/hplip/package.nix +++ b/pkgs/by-name/hp/hplip/package.nix @@ -1,14 +1,35 @@ -{ lib, stdenv, fetchurl, substituteAll -, pkg-config, autoreconfHook, gobject-introspection, wrapGAppsHook3 -, cups, zlib, libjpeg, libusb1, python311Packages, sane-backends -, dbus, file, ghostscript, usbutils -, net-snmp, openssl, perl, nettools, avahi -, bash, util-linux -# To remove references to gcc-unwrapped -, removeReferencesTo, qt5 -, withQt5 ? true -, withPlugin ? false -, withStaticPPDInstall ? false +{ + lib, + stdenv, + fetchurl, + substituteAll, + pkg-config, + autoreconfHook, + gobject-introspection, + wrapGAppsHook3, + cups, + zlib, + libjpeg, + libusb1, + python311Packages, + sane-backends, + dbus, + file, + ghostscript, + usbutils, + net-snmp, + openssl, + perl, + nettools, + avahi, + bash, + util-linux, + # To remove references to gcc-unwrapped + removeReferencesTo, + qt5, + withQt5 ? true, + withPlugin ? false, + withStaticPPDInstall ? false, }: let @@ -32,43 +53,54 @@ let }; hplipPlatforms = { - i686-linux = "x86_32"; + i686-linux = "x86_32"; x86_64-linux = "x86_64"; armv6l-linux = "arm32"; armv7l-linux = "arm32"; aarch64-linux = "arm64"; }; - hplipArch = hplipPlatforms.${stdenv.hostPlatform.system} - or (throw "HPLIP not supported on ${stdenv.hostPlatform.system}"); + hplipArch = + hplipPlatforms.${stdenv.hostPlatform.system} + or (throw "HPLIP not supported on ${stdenv.hostPlatform.system}"); - pluginArches = [ "x86_32" "x86_64" "arm32" "arm64" ]; + pluginArches = [ + "x86_32" + "x86_64" + "arm32" + "arm64" + ]; in -assert withPlugin -> builtins.elem hplipArch pluginArches - || throw "HPLIP plugin not supported on ${stdenv.hostPlatform.system}"; +assert + withPlugin + -> + builtins.elem hplipArch pluginArches + || throw "HPLIP plugin not supported on ${stdenv.hostPlatform.system}"; python311Packages.buildPythonApplication { inherit pname version src; format = "other"; - buildInputs = [ - libjpeg - cups - libusb1 - sane-backends - dbus - file - ghostscript - net-snmp - openssl - perl - zlib - avahi - ] ++ lib.optionals withQt5 [ - qt5.qtwayland - ]; + buildInputs = + [ + libjpeg + cups + libusb1 + sane-backends + dbus + file + ghostscript + net-snmp + openssl + perl + zlib + avahi + ] + ++ lib.optionals withQt5 [ + qt5.qtwayland + ]; nativeBuildInputs = [ pkg-config @@ -78,21 +110,29 @@ python311Packages.buildPythonApplication { wrapGAppsHook3 ] ++ lib.optional withQt5 qt5.wrapQtAppsHook; - pythonPath = with python311Packages; [ - dbus - pillow - pygobject3 - reportlab - usbutils - dbus-python - distro - ] ++ lib.optionals withQt5 [ - pyqt5 - pyqt5-sip + pythonPath = + with python311Packages; + [ + dbus + pillow + pygobject3 + reportlab + usbutils + dbus-python + distro + ] + ++ lib.optionals withQt5 [ + pyqt5 + pyqt5-sip + ]; + + makeWrapperArgs = [ + "--prefix" + "PATH" + ":" + "${nettools}/bin" ]; - makeWrapperArgs = [ "--prefix" "PATH" ":" "${nettools}/bin" ]; - patches = [ # HPLIP's getSystemPPDs() function relies on searching for PPDs below common FHS # paths, and hp-setup crashes if none of these paths actually exist (which they @@ -134,7 +174,10 @@ python311Packages.buildPythonApplication { echo 'AUTOMAKE_OPTIONS = foreign' >> Makefile.am ''; - configureFlags = let out = placeholder "out"; in + configureFlags = + let + out = placeholder "out"; + in [ "--with-hpppddir=${out}/share/cups/model/HP" "--with-cupsfilterdir=${out}/lib/cups/filter" @@ -151,8 +194,7 @@ python311Packages.buildPythonApplication { "--disable-imageProcessor-build" ] ++ lib.optional withStaticPPDInstall "--enable-cups-ppd-install" - ++ lib.optional withQt5 "--enable-qt5" - ; + ++ lib.optional withQt5 "--enable-qt5"; # Prevent 'ppdc: Unable to find include file ""' which prevent # generation of '*.ppd' files. @@ -160,15 +202,19 @@ python311Packages.buildPythonApplication { # Could not find how to fix the problem in 'ppdc' so this is a workaround. CUPS_DATADIR = "${cups}/share/cups"; - makeFlags = let out = placeholder "out"; in [ - "halpredir=${out}/share/hal/fdi/preprobe/10osvendor" - "rulesdir=${out}/etc/udev/rules.d" - "policykit_dir=${out}/share/polkit-1/actions" - "policykit_dbus_etcdir=${out}/etc/dbus-1/system.d" - "policykit_dbus_sharedir=${out}/share/dbus-1/system-services" - "hplip_confdir=${out}/etc/hp" - "hplip_statedir=${out}/var/lib/hp" - ]; + makeFlags = + let + out = placeholder "out"; + in + [ + "halpredir=${out}/share/hal/fdi/preprobe/10osvendor" + "rulesdir=${out}/etc/udev/rules.d" + "policykit_dir=${out}/share/polkit-1/actions" + "policykit_dbus_etcdir=${out}/etc/dbus-1/system.d" + "policykit_dbus_sharedir=${out}/share/dbus-1/system-services" + "hplip_confdir=${out}/etc/hp" + "hplip_statedir=${out}/var/lib/hp" + ]; postConfigure = '' # don't save timestamp, in order to improve reproducibility @@ -183,51 +229,53 @@ python311Packages.buildPythonApplication { # Running `hp-diagnose_plugin -g` can be used to diagnose # issues with plugins. # - postInstall = '' - for resolution in 16x16 32x32 64x64 128x128 256x256; do - mkdir -p $out/share/icons/hicolor/$resolution/apps - ln -s $out/share/hplip/data/images/$resolution/hp_logo.png \ - $out/share/icons/hicolor/$resolution/apps/hp_logo.png - done - '' + lib.optionalString withPlugin '' - sh ${plugin} --noexec --keep - cd plugin_tmp - - cp plugin.spec $out/share/hplip/ - - mkdir -p $out/share/hplip/data/firmware - cp *.fw.gz $out/share/hplip/data/firmware - - mkdir -p $out/share/hplip/data/plugins - cp license.txt $out/share/hplip/data/plugins - - mkdir -p $out/share/hplip/prnt/plugins - for plugin in lj hbpl1; do - cp $plugin-${hplipArch}.so $out/share/hplip/prnt/plugins - chmod 0755 $out/share/hplip/prnt/plugins/$plugin-${hplipArch}.so - ln -s $out/share/hplip/prnt/plugins/$plugin-${hplipArch}.so \ - $out/share/hplip/prnt/plugins/$plugin.so - done - - mkdir -p $out/share/hplip/scan/plugins - for plugin in bb_soap bb_marvell bb_soapht bb_escl; do - cp $plugin-${hplipArch}.so $out/share/hplip/scan/plugins - chmod 0755 $out/share/hplip/scan/plugins/$plugin-${hplipArch}.so - ln -s $out/share/hplip/scan/plugins/$plugin-${hplipArch}.so \ - $out/share/hplip/scan/plugins/$plugin.so - done - - mkdir -p $out/share/hplip/fax/plugins - for plugin in fax_marvell; do - cp $plugin-${hplipArch}.so $out/share/hplip/fax/plugins - chmod 0755 $out/share/hplip/fax/plugins/$plugin-${hplipArch}.so - ln -s $out/share/hplip/fax/plugins/$plugin-${hplipArch}.so \ - $out/share/hplip/fax/plugins/$plugin.so - done - - mkdir -p $out/var/lib/hp - cp ${hplipState} $out/var/lib/hp/hplip.state - ''; + postInstall = + '' + for resolution in 16x16 32x32 64x64 128x128 256x256; do + mkdir -p $out/share/icons/hicolor/$resolution/apps + ln -s $out/share/hplip/data/images/$resolution/hp_logo.png \ + $out/share/icons/hicolor/$resolution/apps/hp_logo.png + done + '' + + lib.optionalString withPlugin '' + sh ${plugin} --noexec --keep + cd plugin_tmp + + cp plugin.spec $out/share/hplip/ + + mkdir -p $out/share/hplip/data/firmware + cp *.fw.gz $out/share/hplip/data/firmware + + mkdir -p $out/share/hplip/data/plugins + cp license.txt $out/share/hplip/data/plugins + + mkdir -p $out/share/hplip/prnt/plugins + for plugin in lj hbpl1; do + cp $plugin-${hplipArch}.so $out/share/hplip/prnt/plugins + chmod 0755 $out/share/hplip/prnt/plugins/$plugin-${hplipArch}.so + ln -s $out/share/hplip/prnt/plugins/$plugin-${hplipArch}.so \ + $out/share/hplip/prnt/plugins/$plugin.so + done + + mkdir -p $out/share/hplip/scan/plugins + for plugin in bb_soap bb_marvell bb_soapht bb_escl; do + cp $plugin-${hplipArch}.so $out/share/hplip/scan/plugins + chmod 0755 $out/share/hplip/scan/plugins/$plugin-${hplipArch}.so + ln -s $out/share/hplip/scan/plugins/$plugin-${hplipArch}.so \ + $out/share/hplip/scan/plugins/$plugin.so + done + + mkdir -p $out/share/hplip/fax/plugins + for plugin in fax_marvell; do + cp $plugin-${hplipArch}.so $out/share/hplip/fax/plugins + chmod 0755 $out/share/hplip/fax/plugins/$plugin-${hplipArch}.so + ln -s $out/share/hplip/fax/plugins/$plugin-${hplipArch}.so \ + $out/share/hplip/fax/plugins/$plugin.so + done + + mkdir -p $out/var/lib/hp + cp ${hplipState} $out/var/lib/hp/hplip.state + ''; # The installed executables are just symlinks into $out/share/hplip, # but wrapPythonPrograms ignores symlinks. We cannot replace the Python @@ -270,17 +318,34 @@ python311Packages.buildPythonApplication { # There are some binaries there, which reference gcc-unwrapped otherwise. stripDebugList = [ - "share/hplip" "lib/cups/backend" "lib/cups/filter" python311Packages.python.sitePackages "lib/sane" + "share/hplip" + "lib/cups/backend" + "lib/cups/filter" + python311Packages.python.sitePackages + "lib/sane" ]; meta = with lib; { description = "Print, scan and fax HP drivers for Linux"; homepage = "https://developers.hp.com/hp-linux-imaging-and-printing"; downloadPage = "https://sourceforge.net/projects/hplip/files/hplip/"; - license = if withPlugin - then licenses.unfree - else with licenses; [ mit bsd2 gpl2Plus ]; - platforms = [ "i686-linux" "x86_64-linux" "armv6l-linux" "armv7l-linux" "aarch64-linux" ]; + license = + if withPlugin then + licenses.unfree + else + with licenses; + [ + mit + bsd2 + gpl2Plus + ]; + platforms = [ + "i686-linux" + "x86_64-linux" + "armv6l-linux" + "armv7l-linux" + "aarch64-linux" + ]; maintainers = with maintainers; [ ttuegel ]; }; } diff --git a/pkgs/by-name/hq/hqplayerd/package.nix b/pkgs/by-name/hq/hqplayerd/package.nix index 3cbec0b64818fd..cd5d540f61141b 100644 --- a/pkgs/by-name/hq/hqplayerd/package.nix +++ b/pkgs/by-name/hq/hqplayerd/package.nix @@ -1,24 +1,26 @@ -{ stdenv, lib -, addDriverRunpath -, alsa-lib -, autoPatchelfHook -, cairo -, fetchurl -, flac -, gcc12 -, gssdp -, gupnp -, gupnp-av -, lame -, libgmpris -, libusb-compat-0_1 -, llvmPackages_14 -, mpg123 -, rpmextract -, wavpack - -, callPackage -, rygel ? null +{ + stdenv, + lib, + addDriverRunpath, + alsa-lib, + autoPatchelfHook, + cairo, + fetchurl, + flac, + gcc12, + gssdp, + gupnp, + gupnp-av, + lame, + libgmpris, + libusb-compat-0_1, + llvmPackages_14, + mpg123, + rpmextract, + wavpack, + + callPackage, + rygel ? null, }@inputs: let # FIXME: Replace with gnome.rygel once hqplayerd releases a new version. @@ -37,7 +39,11 @@ stdenv.mkDerivation rec { ${rpmextract}/bin/rpmextract $src ''; - nativeBuildInputs = [ addDriverRunpath autoPatchelfHook rpmextract ]; + nativeBuildInputs = [ + addDriverRunpath + autoPatchelfHook + rpmextract + ]; buildInputs = [ alsa-lib diff --git a/pkgs/by-name/hq/hqplayerd/rygel.nix b/pkgs/by-name/hq/hqplayerd/rygel.nix index bf360c3f8cc1cc..23c4d6dd5a7052 100644 --- a/pkgs/by-name/hq/hqplayerd/rygel.nix +++ b/pkgs/by-name/hq/hqplayerd/rygel.nix @@ -1,29 +1,31 @@ -{ lib, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, vala -, gettext -, libxml2 -, gobject-introspection -, wrapGAppsHook3 -, python3 -, glib -, gssdp -, gupnp -, gupnp-av -, gupnp-dlna -, gst_all_1 -, libgee -, libsoup_2_4 -, gtk3 -, libmediaart -, sqlite -, systemd -, tinysparql -, shared-mime-info -, gnome +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + vala, + gettext, + libxml2, + gobject-introspection, + wrapGAppsHook3, + python3, + glib, + gssdp, + gupnp, + gupnp-av, + gupnp-dlna, + gst_all_1, + libgee, + libsoup_2_4, + gtk3, + libmediaart, + sqlite, + systemd, + tinysparql, + shared-mime-info, + gnome, }: stdenv.mkDerivation rec { @@ -31,7 +33,10 @@ stdenv.mkDerivation rec { version = "0.40.4"; # TODO: split out lib - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -54,28 +59,30 @@ stdenv.mkDerivation rec { python3 ]; - buildInputs = [ - glib - gssdp - gupnp - gupnp-av - gupnp-dlna - libgee - libsoup_2_4 - gtk3 - libmediaart - sqlite - systemd - tinysparql - shared-mime-info - ] ++ (with gst_all_1; [ - gstreamer - gst-editing-services - gst-plugins-base - gst-plugins-good - gst-plugins-bad - gst-plugins-ugly - ]); + buildInputs = + [ + glib + gssdp + gupnp + gupnp-av + gupnp-dlna + libgee + libsoup_2_4 + gtk3 + libmediaart + sqlite + systemd + tinysparql + shared-mime-info + ] + ++ (with gst_all_1; [ + gstreamer + gst-editing-services + gst-plugins-base + gst-plugins-good + gst-plugins-bad + gst-plugins-ugly + ]); mesonFlags = [ "-Dsystemd-user-units-dir=${placeholder "out"}/lib/systemd/user" diff --git a/pkgs/by-name/hr/hr/package.nix b/pkgs/by-name/hr/hr/package.nix index 51a2a14be9cc1c..b5f52e9a6a57a7 100644 --- a/pkgs/by-name/hr/hr/package.nix +++ b/pkgs/by-name/hr/hr/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "hr"; @@ -12,7 +16,10 @@ stdenv.mkDerivation rec { }; dontBuild = true; - installFlags = [ "PREFIX=$(out)" "MANPREFIX=$(out)/share" ]; + installFlags = [ + "PREFIX=$(out)" + "MANPREFIX=$(out)/share" + ]; preInstall = '' mkdir -p $out/{bin,share} diff --git a/pkgs/by-name/hr/hred/package.nix b/pkgs/by-name/hr/hred/package.nix index b7c77d3ecdda92..d946f8665b07e4 100644 --- a/pkgs/by-name/hr/hred/package.nix +++ b/pkgs/by-name/hr/hred/package.nix @@ -1,4 +1,11 @@ -{ lib, buildNpmPackage, fetchFromGitHub, runCommand, hred, jq }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, + runCommand, + hred, + jq, +}: buildNpmPackage rec { pname = "hred"; @@ -16,7 +23,7 @@ buildNpmPackage rec { dontNpmBuild = true; passthru.tests = { - simple = runCommand "${pname}-test" {} '' + simple = runCommand "${pname}-test" { } '' set -e -o pipefail echo 'bar' | ${hred}/bin/hred 'i#foo { @id => id, @.textContent => text }' -c | ${jq}/bin/jq -c > $out [ "$(cat $out)" = '{"id":"foo","text":"bar"}' ] diff --git a/pkgs/by-name/hs/hsetroot/package.nix b/pkgs/by-name/hs/hsetroot/package.nix index a3ebc33f56ba40..48a281f3bc9083 100644 --- a/pkgs/by-name/hs/hsetroot/package.nix +++ b/pkgs/by-name/hs/hsetroot/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config -, imlib2 -, libX11 -, libXinerama +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + imlib2, + libX11, + libXinerama, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/hs/hsqldb/package.nix b/pkgs/by-name/hs/hsqldb/package.nix index 3cf749b68c73b2..02fec4a73ee598 100644 --- a/pkgs/by-name/hs/hsqldb/package.nix +++ b/pkgs/by-name/hs/hsqldb/package.nix @@ -1,32 +1,42 @@ -{ lib, stdenv, fetchurl, unzip, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + unzip, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "hsqldb"; version = "2.7.4"; - underscoreMajMin = lib.replaceStrings ["."] ["_"] (lib.versions.majorMinor version); + underscoreMajMin = lib.replaceStrings [ "." ] [ "_" ] (lib.versions.majorMinor version); src = fetchurl { url = "mirror://sourceforge/project/hsqldb/hsqldb/hsqldb_${underscoreMajMin}/hsqldb-${version}.zip"; sha256 = "sha256-k4ih0VHD+RV1+kyrx/kiWUqm7P0gEpV66FPoKjpQCNU="; }; - nativeBuildInputs = [ unzip makeWrapper ]; + nativeBuildInputs = [ + unzip + makeWrapper + ]; buildInputs = [ jre ]; installPhase = '' - runHook preInstall + runHook preInstall - mkdir -p $out/lib $out/bin - cp -R hsqldb/lib/*.jar $out/lib + mkdir -p $out/lib $out/bin + cp -R hsqldb/lib/*.jar $out/lib - makeWrapper ${jre}/bin/java $out/bin/hsqldb --add-flags "-classpath $out/lib/hsqldb.jar org.hsqldb.server.Server" - makeWrapper ${jre}/bin/java $out/bin/runServer --add-flags "-classpath $out/lib/hsqldb.jar org.hsqldb.server.Server" - makeWrapper ${jre}/bin/java $out/bin/runManagerSwing --add-flags "-classpath $out/lib/hsqldb.jar org.hsqldb.util.DatabaseManagerSwing" - makeWrapper ${jre}/bin/java $out/bin/runWebServer --add-flags "-classpath $out/lib/hsqldb.jar org.hsqldb.server.WebServer" - makeWrapper ${jre}/bin/java $out/bin/runManager --add-flags "-classpath $out/lib/hsqldb.jar org.hsqldb.util.DatabaseManager" - makeWrapper ${jre}/bin/java $out/bin/sqltool --add-flags "-jar $out/lib/sqltool.jar" + makeWrapper ${jre}/bin/java $out/bin/hsqldb --add-flags "-classpath $out/lib/hsqldb.jar org.hsqldb.server.Server" + makeWrapper ${jre}/bin/java $out/bin/runServer --add-flags "-classpath $out/lib/hsqldb.jar org.hsqldb.server.Server" + makeWrapper ${jre}/bin/java $out/bin/runManagerSwing --add-flags "-classpath $out/lib/hsqldb.jar org.hsqldb.util.DatabaseManagerSwing" + makeWrapper ${jre}/bin/java $out/bin/runWebServer --add-flags "-classpath $out/lib/hsqldb.jar org.hsqldb.server.WebServer" + makeWrapper ${jre}/bin/java $out/bin/runManager --add-flags "-classpath $out/lib/hsqldb.jar org.hsqldb.util.DatabaseManager" + makeWrapper ${jre}/bin/java $out/bin/sqltool --add-flags "-jar $out/lib/sqltool.jar" - runHook postInstall + runHook postInstall ''; meta = with lib; { diff --git a/pkgs/by-name/hs/hss/package.nix b/pkgs/by-name/hs/hss/package.nix index e2535395971a77..dc2b1cc2abacd8 100644 --- a/pkgs/by-name/hs/hss/package.nix +++ b/pkgs/by-name/hs/hss/package.nix @@ -1,4 +1,9 @@ -{ lib, buildRubyGem, ruby, openssh }: +{ + lib, + buildRubyGem, + ruby, + openssh, +}: # Example ~/.hss.yml #--- @@ -16,20 +21,20 @@ buildRubyGem rec { source.sha256 = "0hdfpxxqsh6gisn8mm0knsl1aig9fir0h2x9sirk3gr36qbz5xa4"; postInstall = '' - substituteInPlace $GEM_HOME/gems/${gemName}-${version}/bin/hss \ - --replace \ - "'ssh'" \ - "'${openssh}/bin/ssh'" + substituteInPlace $GEM_HOME/gems/${gemName}-${version}/bin/hss \ + --replace \ + "'ssh'" \ + "'${openssh}/bin/ssh'" ''; meta = with lib; { description = '' A SSH helper that uses regex and fancy expansion to dynamically manage SSH shortcuts. ''; - homepage = "https://github.com/akerl/hss"; - license = licenses.mit; + homepage = "https://github.com/akerl/hss"; + license = licenses.mit; maintainers = with maintainers; [ nixy ]; - platforms = platforms.unix; + platforms = platforms.unix; mainProgram = "hss"; }; } diff --git a/pkgs/by-name/hs/hstr/package.nix b/pkgs/by-name/hs/hstr/package.nix index 2963ba732f059c..a92128622780c3 100644 --- a/pkgs/by-name/hs/hstr/package.nix +++ b/pkgs/by-name/hs/hstr/package.nix @@ -1,19 +1,34 @@ -{ lib, stdenv, fetchFromGitHub, readline, ncurses -, autoreconfHook, pkg-config, gettext }: +{ + lib, + stdenv, + fetchFromGitHub, + readline, + ncurses, + autoreconfHook, + pkg-config, + gettext, +}: stdenv.mkDerivation rec { pname = "hstr"; version = "3.1"; src = fetchFromGitHub { - owner = "dvorka"; - repo = "hstr"; - rev = version; - hash = "sha256-OuLy1aiEwUJDGy3+UXYF1Vx1nNXic46WIZEM1xrIPfA="; + owner = "dvorka"; + repo = "hstr"; + rev = version; + hash = "sha256-OuLy1aiEwUJDGy3+UXYF1Vx1nNXic46WIZEM1xrIPfA="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ readline ncurses gettext ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + readline + ncurses + gettext + ]; configureFlags = [ "--prefix=$(out)" ]; diff --git a/pkgs/by-name/hs/hstsparser/package.nix b/pkgs/by-name/hs/hstsparser/package.nix index 6c301905071995..b956845048b5c3 100644 --- a/pkgs/by-name/hs/hstsparser/package.nix +++ b/pkgs/by-name/hs/hstsparser/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ht/ht/package.nix b/pkgs/by-name/ht/ht/package.nix index a72bac0c27c2df..657110cc2f18f9 100644 --- a/pkgs/by-name/ht/ht/package.nix +++ b/pkgs/by-name/ht/ht/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchurl, ncurses }: +{ + stdenv, + lib, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "ht"; diff --git a/pkgs/by-name/ht/htb-toolkit/package.nix b/pkgs/by-name/ht/htb-toolkit/package.nix index df3c8cde12751a..a7955e3963fb81 100644 --- a/pkgs/by-name/ht/htb-toolkit/package.nix +++ b/pkgs/by-name/ht/htb-toolkit/package.nix @@ -1,16 +1,17 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin -, coreutils -, gnome-keyring -, libsecret -, openvpn -, gzip -, killall +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, + coreutils, + gnome-keyring, + libsecret, + openvpn, + gzip, + killall, }: rustPlatform.buildRustPackage { @@ -36,14 +37,17 @@ rustPlatform.buildRustPackage { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - gnome-keyring - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + gnome-keyring + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; postPatch = '' substituteInPlace src/manage.rs \ diff --git a/pkgs/by-name/ht/html-minifier/package.nix b/pkgs/by-name/ht/html-minifier/package.nix index 6fd239fa816cfe..81bf3e65fdf8aa 100644 --- a/pkgs/by-name/ht/html-minifier/package.nix +++ b/pkgs/by-name/ht/html-minifier/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ht/html-tidy/package.nix b/pkgs/by-name/ht/html-tidy/package.nix index 16e6035cef89ef..00fa778dd53a7c 100644 --- a/pkgs/by-name/ht/html-tidy/package.nix +++ b/pkgs/by-name/ht/html-tidy/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, libxslt, html-tidy }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + libxslt, + html-tidy, +}: stdenv.mkDerivation rec { pname = "html-tidy"; @@ -12,13 +20,17 @@ stdenv.mkDerivation rec { }; # https://github.com/htacg/tidy-html5/pull/1036 - patches = (fetchpatch { - url = "https://github.com/htacg/tidy-html5/commit/e9aa038bd06bd8197a0dc049380bc2945ff55b29.diff"; - sha256 = "sha256-Q2GjinNBWLL+HXUtslzDJ7CJSTflckbjweiSMCnIVwg="; - }); + patches = ( + fetchpatch { + url = "https://github.com/htacg/tidy-html5/commit/e9aa038bd06bd8197a0dc049380bc2945ff55b29.diff"; + sha256 = "sha256-Q2GjinNBWLL+HXUtslzDJ7CJSTflckbjweiSMCnIVwg="; + } + ); - nativeBuildInputs = [ cmake libxslt/*manpage*/ ] - ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) html-tidy; + nativeBuildInputs = [ + cmake + libxslt # manpage + ] ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) html-tidy; cmakeFlags = lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ "-DHOST_TIDY=tidy" diff --git a/pkgs/by-name/ht/html-xml-utils/package.nix b/pkgs/by-name/ht/html-xml-utils/package.nix index df91cbcea56632..acbbd0c8112373 100644 --- a/pkgs/by-name/ht/html-xml-utils/package.nix +++ b/pkgs/by-name/ht/html-xml-utils/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, curl, libiconv }: +{ + lib, + stdenv, + fetchurl, + curl, + libiconv, +}: stdenv.mkDerivation rec { pname = "html-xml-utils"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-XoRynvNszTkk0ocu1O5pVMYzMtylQAuo606u8fLbT7I="; }; - buildInputs = [curl libiconv]; + buildInputs = [ + curl + libiconv + ]; meta = with lib; { description = "Utilities for manipulating HTML and XML files"; diff --git a/pkgs/by-name/ht/html2text/package.nix b/pkgs/by-name/ht/html2text/package.nix index afa4bb11403797..7e6e46d6033f0c 100644 --- a/pkgs/by-name/ht/html2text/package.nix +++ b/pkgs/by-name/ht/html2text/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitLab, autoreconfHook, libiconv }: +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + libiconv, +}: stdenv.mkDerivation rec { pname = "html2text"; diff --git a/pkgs/by-name/ht/htmlcxx/package.nix b/pkgs/by-name/ht/htmlcxx/package.nix index 4b01162bf25bc0..ab349979d3f1e8 100644 --- a/pkgs/by-name/ht/htmlcxx/package.nix +++ b/pkgs/by-name/ht/htmlcxx/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, autoreconfHook, libiconv }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + libiconv, +}: stdenv.mkDerivation rec { pname = "htmlcxx"; diff --git a/pkgs/by-name/ht/htmlhint/package.nix b/pkgs/by-name/ht/htmlhint/package.nix index 6d70819515d14b..2c7f09ee60db6d 100644 --- a/pkgs/by-name/ht/htmlhint/package.nix +++ b/pkgs/by-name/ht/htmlhint/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ht/htmltest/package.nix b/pkgs/by-name/ht/htmltest/package.nix index cbb82695a46e12..9eed514e874dc9 100644 --- a/pkgs/by-name/ht/htmltest/package.nix +++ b/pkgs/by-name/ht/htmltest/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/ht/htmlunit-driver/package.nix b/pkgs/by-name/ht/htmlunit-driver/package.nix index 788a28a87f22ba..6c24a21316ce9c 100644 --- a/pkgs/by-name/ht/htmlunit-driver/package.nix +++ b/pkgs/by-name/ht/htmlunit-driver/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "htmlunit-driver-standalone"; @@ -16,7 +20,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/SeleniumHQ/htmlunit-driver"; description = "WebDriver server for running Selenium tests on the HtmlUnit headless browser"; - maintainers = with maintainers; [ coconnor offline ]; + maintainers = with maintainers; [ + coconnor + offline + ]; platforms = platforms.all; sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.asl20; diff --git a/pkgs/by-name/ht/htmx-lsp/package.nix b/pkgs/by-name/ht/htmx-lsp/package.nix index 4116d168f7ead6..49835f6a679c8c 100644 --- a/pkgs/by-name/ht/htmx-lsp/package.nix +++ b/pkgs/by-name/ht/htmx-lsp/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ht/htpdate/package.nix b/pkgs/by-name/ht/htpdate/package.nix index 0f906b4586a0cc..d8de2a8ff77b27 100644 --- a/pkgs/by-name/ht/htpdate/package.nix +++ b/pkgs/by-name/ht/htpdate/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { version = "2.0.0"; diff --git a/pkgs/by-name/ht/htslib/package.nix b/pkgs/by-name/ht/htslib/package.nix index 8e1c0a939daf3b..c7e14e03ca000e 100644 --- a/pkgs/by-name/ht/htslib/package.nix +++ b/pkgs/by-name/ht/htslib/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, zlib, bzip2, xz, curl, perl }: +{ + lib, + stdenv, + fetchurl, + zlib, + bzip2, + xz, + curl, + perl, +}: stdenv.mkDerivation rec { pname = "htslib"; @@ -12,12 +21,21 @@ stdenv.mkDerivation rec { # perl is only used during the check phase. nativeBuildInputs = [ perl ]; - buildInputs = [ zlib bzip2 xz curl ]; - - configureFlags = if ! stdenv.hostPlatform.isStatic - then [ "--enable-libcurl" ] # optional but strongly recommended - else [ "--disable-libcurl" "--disable-plugins" ]; + buildInputs = [ + zlib + bzip2 + xz + curl + ]; + configureFlags = + if !stdenv.hostPlatform.isStatic then + [ "--enable-libcurl" ] # optional but strongly recommended + else + [ + "--disable-libcurl" + "--disable-plugins" + ]; # In the case of static builds, we need to replace the build and install phases buildPhase = lib.optional stdenv.hostPlatform.isStatic '' diff --git a/pkgs/by-name/ht/http-parser/package.nix b/pkgs/by-name/ht/http-parser/package.nix index 69cf2ab210dd48..30e33e13130a6e 100644 --- a/pkgs/by-name/ht/http-parser/package.nix +++ b/pkgs/by-name/ht/http-parser/package.nix @@ -1,6 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, enableShared ? !stdenv.hostPlatform.isStatic -, enableStatic ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + enableShared ? !stdenv.hostPlatform.isStatic, + enableStatic ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { @@ -16,36 +20,41 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = "-Wno-error"; - patches = [ - ./enable-static-shared.patch - ] ++ lib.optionals stdenv.hostPlatform.isAarch32 [ - # https://github.com/nodejs/http-parser/pull/510 - (fetchpatch { - url = "https://github.com/nodejs/http-parser/commit/4f15b7d510dc7c6361a26a7c6d2f7c3a17f8d878.patch"; - sha256 = "sha256-rZZMJeow3V1fTnjadRaRa+xTq3pdhZn/eJ4xjxEDoU4="; - }) - ]; + patches = + [ + ./enable-static-shared.patch + ] + ++ lib.optionals stdenv.hostPlatform.isAarch32 [ + # https://github.com/nodejs/http-parser/pull/510 + (fetchpatch { + url = "https://github.com/nodejs/http-parser/commit/4f15b7d510dc7c6361a26a7c6d2f7c3a17f8d878.patch"; + sha256 = "sha256-rZZMJeow3V1fTnjadRaRa+xTq3pdhZn/eJ4xjxEDoU4="; + }) + ]; - makeFlags = [ - "DESTDIR=" - "PREFIX=$(out)" - "BINEXT=${stdenv.hostPlatform.extensions.executable}" - "Platform=${lib.toLower stdenv.hostPlatform.uname.system}" - "AEXT=${lib.strings.removePrefix "." stdenv.hostPlatform.extensions.staticLibrary}" - "ENABLE_SHARED=${if enableShared then "1" else "0"}" - "ENABLE_STATIC=${if enableStatic then "1" else "0"}" - ] ++ lib.optionals enableShared [ - "SOEXT=${lib.strings.removePrefix "." stdenv.hostPlatform.extensions.sharedLibrary}" - ] ++ lib.optionals enableStatic [ - "AEXT=${lib.strings.removePrefix "." stdenv.hostPlatform.extensions.staticLibrary}" - ] ++ lib.optionals (enableShared && stdenv.hostPlatform.isWindows) [ - "SONAME=$(SOLIBNAME).$(SOMAJOR).$(SOMINOR).$(SOEXT)" - "LIBNAME=$(SOLIBNAME).$(SOMAJOR).$(SOMINOR).$(SOREV).$(SOEXT)" - "LDFLAGS=-Wl,--out-implib=$(LIBNAME).a" - ]; + makeFlags = + [ + "DESTDIR=" + "PREFIX=$(out)" + "BINEXT=${stdenv.hostPlatform.extensions.executable}" + "Platform=${lib.toLower stdenv.hostPlatform.uname.system}" + "AEXT=${lib.strings.removePrefix "." stdenv.hostPlatform.extensions.staticLibrary}" + "ENABLE_SHARED=${if enableShared then "1" else "0"}" + "ENABLE_STATIC=${if enableStatic then "1" else "0"}" + ] + ++ lib.optionals enableShared [ + "SOEXT=${lib.strings.removePrefix "." stdenv.hostPlatform.extensions.sharedLibrary}" + ] + ++ lib.optionals enableStatic [ + "AEXT=${lib.strings.removePrefix "." stdenv.hostPlatform.extensions.staticLibrary}" + ] + ++ lib.optionals (enableShared && stdenv.hostPlatform.isWindows) [ + "SONAME=$(SOLIBNAME).$(SOMAJOR).$(SOMINOR).$(SOEXT)" + "LIBNAME=$(SOLIBNAME).$(SOMAJOR).$(SOMINOR).$(SOREV).$(SOEXT)" + "LDFLAGS=-Wl,--out-implib=$(LIBNAME).a" + ]; - buildFlags = lib.optional enableShared "library" - ++ lib.optional enableStatic "package"; + buildFlags = lib.optional enableShared "library" ++ lib.optional enableStatic "package"; doCheck = true; checkTarget = "test"; diff --git a/pkgs/by-name/ht/http-server/package.nix b/pkgs/by-name/ht/http-server/package.nix index 7c66a03e27279c..015a50bcbd6244 100644 --- a/pkgs/by-name/ht/http-server/package.nix +++ b/pkgs/by-name/ht/http-server/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, fetchpatch2 +{ + lib, + buildNpmPackage, + fetchFromGitHub, + fetchpatch2, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ht/http2tcp/package.nix b/pkgs/by-name/ht/http2tcp/package.nix index c1ee7bf45bb6b6..39a55907f5f54c 100644 --- a/pkgs/by-name/ht/http2tcp/package.nix +++ b/pkgs/by-name/ht/http2tcp/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, stdenv -, fetchurl +{ + lib, + python3, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ht/http3-ytproxy/package.nix b/pkgs/by-name/ht/http3-ytproxy/package.nix index 04e6965012937c..49de0c2fe4c15e 100644 --- a/pkgs/by-name/ht/http3-ytproxy/package.nix +++ b/pkgs/by-name/ht/http3-ytproxy/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, libwebp +{ + lib, + fetchFromGitHub, + buildGoModule, + libwebp, }: buildGoModule rec { pname = "http3-ytproxy"; @@ -24,7 +25,10 @@ buildGoModule rec { buildInputs = [ libwebp ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "YouTube traffic proxy for video playback and images"; diff --git a/pkgs/by-name/ht/httpdirfs/package.nix b/pkgs/by-name/ht/httpdirfs/package.nix index bf7c8ced260618..fda57e5c35030d 100644 --- a/pkgs/by-name/ht/httpdirfs/package.nix +++ b/pkgs/by-name/ht/httpdirfs/package.nix @@ -55,7 +55,11 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/fangfufu/httpdirfs"; license = lib.licenses.gpl3Only; mainProgram = "httpdirfs"; - maintainers = with lib.maintainers; [ sbruder schnusch anthonyroussel ]; + maintainers = with lib.maintainers; [ + sbruder + schnusch + anthonyroussel + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/by-name/ht/httpdump/package.nix b/pkgs/by-name/ht/httpdump/package.nix index 2a8e754977824c..7e062dd294fe2d 100644 --- a/pkgs/by-name/ht/httpdump/package.nix +++ b/pkgs/by-name/ht/httpdump/package.nix @@ -1,7 +1,8 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, libpcap +{ + buildGoModule, + fetchFromGitHub, + lib, + libpcap, }: buildGoModule rec { @@ -19,7 +20,10 @@ buildGoModule rec { propagatedBuildInputs = [ libpcap ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Parse and display HTTP traffic from network device or pcap file"; diff --git a/pkgs/by-name/ht/httperf/package.nix b/pkgs/by-name/ht/httperf/package.nix index 90cda6d78a4008..9a5f595043f3d0 100644 --- a/pkgs/by-name/ht/httperf/package.nix +++ b/pkgs/by-name/ht/httperf/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + openssl, +}: stdenv.mkDerivation rec { pname = "httperf"; diff --git a/pkgs/by-name/ht/httpfs2/package.nix b/pkgs/by-name/ht/httpfs2/package.nix index 0926461974d7a5..c4c0bbf04be0b2 100644 --- a/pkgs/by-name/ht/httpfs2/package.nix +++ b/pkgs/by-name/ht/httpfs2/package.nix @@ -1,5 +1,16 @@ -{ fetchurl, lib, stdenv, pkg-config, fuse, openssl, asciidoc -, docbook_xml_dtd_45, docbook_xsl , libxml2, libxslt }: +{ + fetchurl, + lib, + stdenv, + pkg-config, + fuse, + openssl, + asciidoc, + docbook_xml_dtd_45, + docbook_xsl, + libxml2, + libxslt, +}: stdenv.mkDerivation rec { pname = "httpfs2"; @@ -11,10 +22,15 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = - [ fuse openssl - asciidoc docbook_xml_dtd_45 docbook_xsl libxml2 libxslt - ]; + buildInputs = [ + fuse + openssl + asciidoc + docbook_xml_dtd_45 + docbook_xsl + libxml2 + libxslt + ]; installPhase = '' mkdir -p "$out/bin" diff --git a/pkgs/by-name/ht/httplab/package.nix b/pkgs/by-name/ht/httplab/package.nix index c78f32d0565005..fd2257ef8f90ff 100644 --- a/pkgs/by-name/ht/httplab/package.nix +++ b/pkgs/by-name/ht/httplab/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "httplab"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-vL3a9eO5G0WqnqcIjA9D2XM7iQ87JH0q+an2nLcG28A="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/qustavo/httplab"; diff --git a/pkgs/by-name/ht/httplz/package.nix b/pkgs/by-name/ht/httplz/package.nix index cb0e51632784a2..25296b51cc5ae5 100644 --- a/pkgs/by-name/ht/httplz/package.nix +++ b/pkgs/by-name/ht/httplz/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchCrate -, installShellFiles -, makeWrapper -, pkg-config -, ronn -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + installShellFiles, + makeWrapper, + pkg-config, + ronn, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -29,11 +30,16 @@ rustPlatform.buildRustPackage rec { ronn ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; - cargoBuildFlags = [ "--bin" "httplz" ]; + cargoBuildFlags = [ + "--bin" + "httplz" + ]; postInstall = '' sed -E 's/http(`| |\(|$)/httplz\1/g' http.md > httplz.1.ronn diff --git a/pkgs/by-name/ht/httpref/package.nix b/pkgs/by-name/ht/httpref/package.nix index f2c0f58a309444..fb04d45c3d516b 100644 --- a/pkgs/by-name/ht/httpref/package.nix +++ b/pkgs/by-name/ht/httpref/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-9Ei4Lfll79f/+iuO5KesUMaTgkS9nq+1tma/dhOZ7Qw="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Command line, offline, access to HTTP status code, common header, and port references"; diff --git a/pkgs/by-name/ht/httprobe/package.nix b/pkgs/by-name/ht/httprobe/package.nix index b1a03ed6b488a4..a1c2b4da34dc67 100644 --- a/pkgs/by-name/ht/httprobe/package.nix +++ b/pkgs/by-name/ht/httprobe/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Take a list of domains and probe for working HTTP and HTTPS servers"; diff --git a/pkgs/by-name/ht/https-dns-proxy/package.nix b/pkgs/by-name/ht/https-dns-proxy/package.nix index 12793747e86109..e4fc762bd82db9 100644 --- a/pkgs/by-name/ht/https-dns-proxy/package.nix +++ b/pkgs/by-name/ht/https-dns-proxy/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, gtest, c-ares, curl, libev }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gtest, + c-ares, + curl, + libev, +}: let # https-dns-proxy supports HTTP3 if curl has support, but as of 2022-08 curl doesn't work with that enabled @@ -25,9 +34,16 @@ stdenv.mkDerivation rec { --replace '--unit https_dns_proxy.service' '--unit https-dns-proxy.service' ''; - nativeBuildInputs = [ cmake gtest ]; + nativeBuildInputs = [ + cmake + gtest + ]; - buildInputs = [ c-ares curl' libev ]; + buildInputs = [ + c-ares + curl' + libev + ]; postInstall = '' install -Dm444 -t $out/share/doc/${pname} ../{LICENSE,*.md} diff --git a/pkgs/by-name/ht/httpstat/package.nix b/pkgs/by-name/ht/httpstat/package.nix index 971c973ada21a5..a267bbaf4d5b45 100644 --- a/pkgs/by-name/ht/httpstat/package.nix +++ b/pkgs/by-name/ht/httpstat/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, curl, python3Packages, glibcLocales }: +{ + lib, + fetchFromGitHub, + curl, + python3Packages, + glibcLocales, +}: python3Packages.buildPythonApplication rec { pname = "httpstat"; diff --git a/pkgs/by-name/ht/httptunnel/package.nix b/pkgs/by-name/ht/httptunnel/package.nix index 9a8a9ee11db5a7..e45744a9997e8d 100644 --- a/pkgs/by-name/ht/httptunnel/package.nix +++ b/pkgs/by-name/ht/httptunnel/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { @@ -21,9 +22,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Creates a bidirectional virtual data connection tunnelled in HTTP requests"; - homepage = "http://www.gnu.org/software/httptunnel/httptunnel.html"; - license = licenses.gpl2Only; + homepage = "http://www.gnu.org/software/httptunnel/httptunnel.html"; + license = licenses.gpl2Only; maintainers = with maintainers; [ koral ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ht/httpunit/package.nix b/pkgs/by-name/ht/httpunit/package.nix index 07afdabd89b28c..ffc175b2105912 100644 --- a/pkgs/by-name/ht/httpunit/package.nix +++ b/pkgs/by-name/ht/httpunit/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "httpunit"; diff --git a/pkgs/by-name/ht/httpy-cli/package.nix b/pkgs/by-name/ht/httpy-cli/package.nix index 2b59b54ef21361..80cb10863219df 100644 --- a/pkgs/by-name/ht/httpy-cli/package.nix +++ b/pkgs/by-name/ht/httpy-cli/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3Packages -, fetchPypi -, curl - }: +{ + lib, + python3Packages, + fetchPypi, + curl, +}: python3Packages.buildPythonPackage rec { pname = "httpy-cli"; @@ -23,7 +24,7 @@ python3Packages.buildPythonPackage rec { ]; build-system = with python3Packages; [ - setuptools + setuptools ]; pythonImportsCheck = [ @@ -31,9 +32,9 @@ python3Packages.buildPythonPackage rec { ]; nativeCheckInputs = [ - python3Packages.pytest - curl - ]; + python3Packages.pytest + curl + ]; checkPhase = '' runHook preCheck diff --git a/pkgs/by-name/hu/hub/package.nix b/pkgs/by-name/hu/hub/package.nix index 4486c71605da39..71c302369fb425 100644 --- a/pkgs/by-name/hu/hub/package.nix +++ b/pkgs/by-name/hu/hub/package.nix @@ -1,13 +1,14 @@ -{ lib -, buildGoModule -, fetchpatch -, fetchFromGitHub -, git -, groff -, installShellFiles -, makeWrapper -, unixtools -, nixosTests +{ + lib, + buildGoModule, + fetchpatch, + fetchFromGitHub, + git, + groff, + installShellFiles, + makeWrapper, + unixtools, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/by-name/hu/hubble/package.nix b/pkgs/by-name/hu/hubble/package.nix index eba04544258123..a841d66b74c242 100644 --- a/pkgs/by-name/hu/hubble/package.nix +++ b/pkgs/by-name/hu/hubble/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "hubble"; @@ -14,7 +19,8 @@ buildGoModule rec { vendorHash = null; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/cilium/hubble/pkg.GitBranch=none" "-X github.com/cilium/hubble/pkg.GitHash=none" "-X github.com/cilium/hubble/pkg.Version=${version}" @@ -43,6 +49,9 @@ buildGoModule rec { mainProgram = "hubble"; license = licenses.asl20; homepage = "https://github.com/cilium/hubble/"; - maintainers = with maintainers; [ humancalico bryanasdev000 ]; + maintainers = with maintainers; [ + humancalico + bryanasdev000 + ]; }; } diff --git a/pkgs/by-name/hu/hubicfuse/package.nix b/pkgs/by-name/hu/hubicfuse/package.nix index 95dabe2f97b624..1cf774bc0b9bb6 100644 --- a/pkgs/by-name/hu/hubicfuse/package.nix +++ b/pkgs/by-name/hu/hubicfuse/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, pkg-config, curl, openssl, fuse, libxml2, json_c, file }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + curl, + openssl, + fuse, + libxml2, + json_c, + file, +}: stdenv.mkDerivation rec { pname = "hubicfuse"; @@ -27,7 +39,14 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ curl openssl fuse libxml2 json_c file ]; + buildInputs = [ + curl + openssl + fuse + libxml2 + json_c + file + ]; postInstall = '' install hubic_token $out/bin mkdir -p $out/sbin diff --git a/pkgs/by-name/hu/hubot-sans/package.nix b/pkgs/by-name/hu/hubot-sans/package.nix index 3711aeb028d17d..de93d39b075ee3 100644 --- a/pkgs/by-name/hu/hubot-sans/package.nix +++ b/pkgs/by-name/hu/hubot-sans/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchzip -, stdenvNoCC +{ + lib, + fetchzip, + stdenvNoCC, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/hu/hueadm/package.nix b/pkgs/by-name/hu/hueadm/package.nix index 30cbaa591cc567..51986732b1d555 100644 --- a/pkgs/by-name/hu/hueadm/package.nix +++ b/pkgs/by-name/hu/hueadm/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/hu/hugs/package.nix b/pkgs/by-name/hu/hugs/package.nix index ab48ef91b362e0..4bc39894a6fb65 100644 --- a/pkgs/by-name/hu/hugs/package.nix +++ b/pkgs/by-name/hu/hugs/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, bison }: +{ + lib, + stdenv, + fetchurl, + bison, +}: stdenv.mkDerivation rec { pname = "hugs98"; @@ -9,13 +14,13 @@ stdenv.mkDerivation rec { sha256 = "1dj65c39zpy6qqvvrwns2hzj6ipnd4ih655xj7kgyk2nfdvd5x1w"; }; - patches = - [ (fetchurl { - url = "https://aur.archlinux.org/cgit/aur.git/plain/hsbase_inline.patch?h=hugs"; - name = "hsbase_inline.patch"; - sha256 = "1h0sp16d17hlm6gj7zdbgwrjwi2l4q02m8p0wd60dp4gn9i9js0v"; - }) - ]; + patches = [ + (fetchurl { + url = "https://aur.archlinux.org/cgit/aur.git/plain/hsbase_inline.patch?h=hugs"; + name = "hsbase_inline.patch"; + sha256 = "1h0sp16d17hlm6gj7zdbgwrjwi2l4q02m8p0wd60dp4gn9i9js0v"; + }) + ]; nativeBuildInputs = [ bison ]; @@ -24,19 +29,19 @@ stdenv.mkDerivation rec { preConfigure = "unset STRIP"; configureFlags = [ - "--enable-char-encoding=utf8" # require that the UTF-8 encoding is always used + "--enable-char-encoding=utf8" # require that the UTF-8 encoding is always used "--disable-path-canonicalization" - "--disable-timer" # evaluation timing (for benchmarking Hugs) - "--disable-profiling" # heap profiler - "--disable-stack-dumps" # stack dump on stack overflow - "--enable-large-banner" # multiline startup banner - "--disable-internal-prims" # experimental primitives to access Hugs's innards - "--disable-debug" # include C debugging information (for debugging Hugs) - "--disable-tag" # runtime tag checking (for debugging Hugs) - "--disable-lint" # "lint" flags (for debugging Hugs) - "--disable-only98" # build Hugs to understand Haskell 98 only + "--disable-timer" # evaluation timing (for benchmarking Hugs) + "--disable-profiling" # heap profiler + "--disable-stack-dumps" # stack dump on stack overflow + "--enable-large-banner" # multiline startup banner + "--disable-internal-prims" # experimental primitives to access Hugs's innards + "--disable-debug" # include C debugging information (for debugging Hugs) + "--disable-tag" # runtime tag checking (for debugging Hugs) + "--disable-lint" # "lint" flags (for debugging Hugs) + "--disable-only98" # build Hugs to understand Haskell 98 only "--enable-ffi" - "--enable-pthreads" # build Hugs using POSIX threads C library + "--enable-pthreads" # build Hugs using POSIX threads C library ]; meta = with lib; { diff --git a/pkgs/by-name/hu/hujsonfmt/package.nix b/pkgs/by-name/hu/hujsonfmt/package.nix index 9c1884feb60e05..ca4b54453e3856 100644 --- a/pkgs/by-name/hu/hujsonfmt/package.nix +++ b/pkgs/by-name/hu/hujsonfmt/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: let inherit (lib) licenses maintainers; diff --git a/pkgs/by-name/hu/humanity-icon-theme/package.nix b/pkgs/by-name/hu/humanity-icon-theme/package.nix index dd52c984b1b565..31a5bd22892637 100644 --- a/pkgs/by-name/hu/humanity-icon-theme/package.nix +++ b/pkgs/by-name/hu/humanity-icon-theme/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenvNoCC, fetchurl, gtk3, adwaita-icon-theme, hicolor-icon-theme }: +{ + lib, + stdenvNoCC, + fetchurl, + gtk3, + adwaita-icon-theme, + hicolor-icon-theme, +}: stdenvNoCC.mkDerivation rec { pname = "humanity-icon-theme"; diff --git a/pkgs/by-name/hu/humioctl/package.nix b/pkgs/by-name/hu/humioctl/package.nix index 018448d431b0ee..34fc374f4f5419 100644 --- a/pkgs/by-name/hu/humioctl/package.nix +++ b/pkgs/by-name/hu/humioctl/package.nix @@ -1,4 +1,9 @@ -{ buildGoModule, fetchFromGitHub, installShellFiles, lib }: +{ + buildGoModule, + fetchFromGitHub, + installShellFiles, + lib, +}: buildGoModule rec { pname = "humioctl"; @@ -13,7 +18,11 @@ buildGoModule rec { vendorHash = "sha256-vGX77+I/zdTBhVSywd7msjrJ0KtcdZRgvWZWQC9M9og="; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; nativeBuildInputs = [ installShellFiles ]; diff --git a/pkgs/by-name/hu/huniq/package.nix b/pkgs/by-name/hu/huniq/package.nix index 857bbb77e3d4d0..6118aae67e0976 100644 --- a/pkgs/by-name/hu/huniq/package.nix +++ b/pkgs/by-name/hu/huniq/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "huniq"; diff --git a/pkgs/by-name/hu/hunt/package.nix b/pkgs/by-name/hu/hunt/package.nix index b0e3cb6de0a59a..bebad941e1324f 100644 --- a/pkgs/by-name/hu/hunt/package.nix +++ b/pkgs/by-name/hu/hunt/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/hu/hurl/package.nix b/pkgs/by-name/hu/hurl/package.nix index 335ba94b012038..e6907aae8d94e6 100644 --- a/pkgs/by-name/hu/hurl/package.nix +++ b/pkgs/by-name/hu/hurl/package.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, fetchpatch -, pkg-config -, installShellFiles -, libxml2 -, openssl -, stdenv -, curl -, versionCheckHook +{ + lib, + rustPlatform, + fetchFromGitHub, + fetchpatch, + pkg-config, + installShellFiles, + libxml2, + openssl, + stdenv, + curl, + versionCheckHook, }: rustPlatform.buildRustPackage rec { @@ -29,12 +30,14 @@ rustPlatform.buildRustPackage rec { installShellFiles ]; - buildInputs = [ - libxml2 - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - curl - ]; + buildInputs = + [ + libxml2 + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + curl + ]; nativeInstallCheckInputs = [ versionCheckHook ]; @@ -57,7 +60,10 @@ rustPlatform.buildRustPackage rec { description = "Command line tool that performs HTTP requests defined in a simple plain text format"; homepage = "https://hurl.dev/"; changelog = "https://github.com/Orange-OpenSource/hurl/blob/${version}/CHANGELOG.md"; - maintainers = with maintainers; [ eonpatapon figsoda ]; + maintainers = with maintainers; [ + eonpatapon + figsoda + ]; license = licenses.asl20; mainProgram = "hurl"; }; diff --git a/pkgs/by-name/hu/husky/package.nix b/pkgs/by-name/hu/husky/package.nix index cd613b925b2d44..e749644bc33c00 100644 --- a/pkgs/by-name/hu/husky/package.nix +++ b/pkgs/by-name/hu/husky/package.nix @@ -1,4 +1,8 @@ -{ lib, buildNpmPackage, fetchFromGitHub }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, +}: buildNpmPackage rec { pname = "husky"; diff --git a/pkgs/by-name/hu/hut/package.nix b/pkgs/by-name/hu/hut/package.nix index f53ef737de3c10..232964381647a8 100644 --- a/pkgs/by-name/hu/hut/package.nix +++ b/pkgs/by-name/hu/hut/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromSourcehut -, scdoc +{ + lib, + buildGoModule, + fetchFromSourcehut, + scdoc, }: buildGoModule rec { diff --git a/pkgs/by-name/hv/hvm/package.nix b/pkgs/by-name/hv/hvm/package.nix index b5f1725d71137b..bdbdbc74c34275 100644 --- a/pkgs/by-name/hv/hvm/package.nix +++ b/pkgs/by-name/hv/hvm/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/hw/hwdata/package.nix b/pkgs/by-name/hw/hwdata/package.nix index b03448f7628846..2eefae34d4fcdc 100644 --- a/pkgs/by-name/hw/hwdata/package.nix +++ b/pkgs/by-name/hw/hwdata/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "hwdata"; diff --git a/pkgs/by-name/hy/hybridreverb2/package.nix b/pkgs/by-name/hy/hybridreverb2/package.nix index 5a677b9cc8809e..c9a3a0acce8371 100644 --- a/pkgs/by-name/hy/hybridreverb2/package.nix +++ b/pkgs/by-name/hy/hybridreverb2/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, lv2 -, alsa-lib -, libjack2 -, freetype -, libX11 -, gtk3 -, pcre -, libpthreadstubs -, libXdmcp -, libxkbcommon -, libepoxy -, at-spi2-core -, dbus -, curl -, fftwFloat +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + lv2, + alsa-lib, + libjack2, + freetype, + libX11, + gtk3, + pcre, + libpthreadstubs, + libXdmcp, + libxkbcommon, + libepoxy, + at-spi2-core, + dbus, + curl, + fftwFloat, }: let @@ -46,7 +47,10 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; buildInputs = [ lv2 alsa-lib diff --git a/pkgs/by-name/hy/hydrapaper/package.nix b/pkgs/by-name/hy/hydrapaper/package.nix index ca638091fb3c4f..6935eece8a3d41 100644 --- a/pkgs/by-name/hy/hydrapaper/package.nix +++ b/pkgs/by-name/hy/hydrapaper/package.nix @@ -1,18 +1,19 @@ -{ lib -, python3Packages -, fetchFromGitLab -, meson -, ninja -, glib -, pkg-config -, pandoc -, appstream -, blueprint-compiler -, gobject-introspection -, wrapGAppsHook4 -, dbus -, libadwaita -, xdg-user-dirs +{ + lib, + python3Packages, + fetchFromGitLab, + meson, + ninja, + glib, + pkg-config, + pandoc, + appstream, + blueprint-compiler, + gobject-introspection, + wrapGAppsHook4, + dbus, + libadwaita, + xdg-user-dirs, }: python3Packages.buildPythonApplication rec { @@ -61,7 +62,12 @@ python3Packages.buildPythonApplication rec { preFixup = '' gappsWrapperArgs+=( - --prefix PATH : ${lib.makeBinPath [ glib xdg-user-dirs ]} + --prefix PATH : ${ + lib.makeBinPath [ + glib + xdg-user-dirs + ] + } ) makeWrapperArgs+=("''${gappsWrapperArgs[@]}") ''; diff --git a/pkgs/by-name/hy/hydroxide/package.nix b/pkgs/by-name/hy/hydroxide/package.nix index ce49d6b1501618..34decc37b13419 100644 --- a/pkgs/by-name/hy/hydroxide/package.nix +++ b/pkgs/by-name/hy/hydroxide/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "hydroxide"; diff --git a/pkgs/by-name/hy/hyena/package.nix b/pkgs/by-name/hy/hyena/package.nix index cb962212ffea67..e165255847e0f9 100644 --- a/pkgs/by-name/hy/hyena/package.nix +++ b/pkgs/by-name/hy/hyena/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, mono, gtk-sharp-2_0, monoDLLFixer }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + mono, + gtk-sharp-2_0, + monoDLLFixer, +}: stdenv.mkDerivation rec { pname = "hyena"; @@ -11,7 +19,8 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - mono gtk-sharp-2_0 + mono + gtk-sharp-2_0 ]; postPatch = '' diff --git a/pkgs/by-name/hy/hyenae/package.nix b/pkgs/by-name/hy/hyenae/package.nix index b0e579de220946..f4f3152338e8be 100644 --- a/pkgs/by-name/hy/hyenae/package.nix +++ b/pkgs/by-name/hy/hyenae/package.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchurl, libdnet, pkg-config, libpcap}: +{ + lib, + stdenv, + fetchurl, + libdnet, + pkg-config, + libpcap, +}: stdenv.mkDerivation rec { pname = "hyenae"; @@ -12,13 +19,16 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [libdnet libpcap]; + buildInputs = [ + libdnet + libpcap + ]; meta = { description = ""; homepage = "https://sourceforge.net/projects/hyenae/"; license = lib.licenses.gpl3; - maintainers = [lib.maintainers.marcweber]; + maintainers = [ lib.maintainers.marcweber ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/hy/hylafaxplus/package.nix b/pkgs/by-name/hy/hylafaxplus/package.nix index 3c66ce8129f34e..cab83cf408b06f 100644 --- a/pkgs/by-name/hy/hylafaxplus/package.nix +++ b/pkgs/by-name/hy/hylafaxplus/package.nix @@ -1,32 +1,33 @@ -{ stdenv -, lib -, fakeroot -, fetchurl -, libfaketime -, substituteAll -## runtime dependencies -, coreutils -, file -, findutils -, gawk -, ghostscript -, gnugrep -, gnused -, libtiff -, libxcrypt -, openssl -, psmisc -, sharutils -, util-linux -, zlib -## optional packages (using `null` disables some functionality) -, jbigkit ? null -, lcms2 ? null # for colored faxes -, openldap ? null -, pam ? null -## system-dependent settings that have to be hardcoded -, maxgid ? 65534 # null -> try to auto-detect (bad on linux) -, maxuid ? 65534 # null -> hardcoded value 60002 +{ + stdenv, + lib, + fakeroot, + fetchurl, + libfaketime, + substituteAll, + ## runtime dependencies + coreutils, + file, + findutils, + gawk, + ghostscript, + gnugrep, + gnused, + libtiff, + libxcrypt, + openssl, + psmisc, + sharutils, + util-linux, + zlib, + ## optional packages (using `null` disables some functionality) + jbigkit ? null, + lcms2 ? null, # for colored faxes + openldap ? null, + pam ? null, + ## system-dependent settings that have to be hardcoded + maxgid ? 65534, # null -> try to auto-detect (bad on linux) + maxuid ? 65534, # null -> hardcoded value 60002 }: let @@ -38,9 +39,9 @@ let configSite = substituteAll { name = "${pname}-config.site"; src = ./config.site; - config_maxgid = lib.optionalString (maxgid!=null) ''CONFIG_MAXGID=${builtins.toString maxgid}''; + config_maxgid = lib.optionalString (maxgid != null) ''CONFIG_MAXGID=${builtins.toString maxgid}''; ghostscript_version = ghostscript.version; - out_ = "@out@"; # "out" will be resolved in post-install.sh + out_ = "@out@"; # "out" will be resolved in post-install.sh inherit coreutils ghostscript libtiff; }; @@ -48,11 +49,19 @@ let name = "${pname}-post-patch.sh"; src = ./post-patch.sh; inherit configSite; - maxuid = lib.optionalString (maxuid!=null) (builtins.toString maxuid); - faxcover_binpath = lib.makeBinPath - [stdenv.shellPackage coreutils]; - faxsetup_binpath = lib.makeBinPath - [stdenv.shellPackage coreutils findutils gnused gnugrep gawk]; + maxuid = lib.optionalString (maxuid != null) (builtins.toString maxuid); + faxcover_binpath = lib.makeBinPath [ + stdenv.shellPackage + coreutils + ]; + faxsetup_binpath = lib.makeBinPath [ + stdenv.shellPackage + coreutils + findutils + gnused + gnugrep + gawk + ]; }; postInstall = substituteAll { @@ -77,19 +86,19 @@ stdenv.mkDerivation { # for a couple of standard binaries in the `PATH` and # hardcode their absolute paths in the new package. buildInputs = [ - file # for `file` command + file # for `file` command ghostscript libtiff libxcrypt openssl - psmisc # for `fuser` command - sharutils # for `uuencode` command - util-linux # for `agetty` command + psmisc # for `fuser` command + sharutils # for `uuencode` command + util-linux # for `agetty` command zlib - jbigkit # optional - lcms2 # optional - openldap # optional - pam # optional + jbigkit # optional + lcms2 # optional + openldap # optional + pam # optional ]; # Disable parallel build, errors: # *** No rule to make target '../util/libfaxutil.so.7.0.4', needed by 'faxmsg'. Stop. diff --git a/pkgs/by-name/hy/hyp/package.nix b/pkgs/by-name/hy/hyp/package.nix index 76562311ac648d..dae4619da82f92 100644 --- a/pkgs/by-name/hy/hyp/package.nix +++ b/pkgs/by-name/hy/hyp/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonPackage rec { pname = "hyp-server"; @@ -12,9 +16,12 @@ python3Packages.buildPythonPackage rec { meta = with lib; { description = "Hyperminimal https server"; mainProgram = "hyp"; - homepage = "https://github.com/rnhmjoj/hyp"; - license = with licenses; [gpl3Plus mit]; + homepage = "https://github.com/rnhmjoj/hyp"; + license = with licenses; [ + gpl3Plus + mit + ]; maintainers = with maintainers; [ rnhmjoj ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/hy/hyp2mat/package.nix b/pkgs/by-name/hy/hyp2mat/package.nix index 71da4a259d54ce..a09766c38a1d29 100644 --- a/pkgs/by-name/hy/hyp2mat/package.nix +++ b/pkgs/by-name/hy/hyp2mat/package.nix @@ -1,15 +1,17 @@ -{ lib, stdenv -, fetchFromGitHub -, bison -, flex -, gengetopt -, help2man -, groff -, libharu -, autoreconfHook -, pkg-config -, libpng -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + bison, + flex, + gengetopt, + help2man, + groff, + libharu, + autoreconfHook, + pkg-config, + libpng, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/hy/hyper/package.nix b/pkgs/by-name/hy/hyper/package.nix index 9f46b59d6a5378..4f2fc478b1e635 100644 --- a/pkgs/by-name/hy/hyper/package.nix +++ b/pkgs/by-name/hy/hyper/package.nix @@ -1,15 +1,82 @@ -{ stdenv, lib, fetchurl, dpkg, atk, glib, pango, gdk-pixbuf, gtk3, cairo -, freetype, fontconfig, dbus, libXi, libXcursor, libXdamage, libXrandr, libXcomposite -, libXext, libXfixes, libXrender, libX11, libXtst, libXScrnSaver, libxcb, nss, nspr -, alsa-lib, cups, expat, udev, libpulseaudio, at-spi2-atk, at-spi2-core, libxshmfence -, libdrm, libxkbcommon, mesa, nixosTests}: +{ + stdenv, + lib, + fetchurl, + dpkg, + atk, + glib, + pango, + gdk-pixbuf, + gtk3, + cairo, + freetype, + fontconfig, + dbus, + libXi, + libXcursor, + libXdamage, + libXrandr, + libXcomposite, + libXext, + libXfixes, + libXrender, + libX11, + libXtst, + libXScrnSaver, + libxcb, + nss, + nspr, + alsa-lib, + cups, + expat, + udev, + libpulseaudio, + at-spi2-atk, + at-spi2-core, + libxshmfence, + libdrm, + libxkbcommon, + mesa, + nixosTests, +}: let libPath = lib.makeLibraryPath [ - stdenv.cc.cc gtk3 atk glib pango gdk-pixbuf cairo freetype fontconfig dbus - libXi libXcursor libXdamage libXrandr libXcomposite libXext libXfixes libxcb - libXrender libX11 libXtst libXScrnSaver nss nspr alsa-lib cups expat udev libpulseaudio - at-spi2-atk at-spi2-core libxshmfence libdrm libxkbcommon mesa + stdenv.cc.cc + gtk3 + atk + glib + pango + gdk-pixbuf + cairo + freetype + fontconfig + dbus + libXi + libXcursor + libXdamage + libXrandr + libXcomposite + libXext + libXfixes + libxcb + libXrender + libX11 + libXtst + libXScrnSaver + nss + nspr + alsa-lib + cups + expat + udev + libpulseaudio + at-spi2-atk + at-spi2-core + libxshmfence + libdrm + libxkbcommon + mesa ]; in @@ -42,11 +109,14 @@ stdenv.mkDerivation rec { dontPatchELF = true; meta = with lib; { description = "Terminal built on web technologies"; - homepage = "https://hyper.is/"; - maintainers = with maintainers; [ puffnfresh fabiangd ]; + homepage = "https://hyper.is/"; + maintainers = with maintainers; [ + puffnfresh + fabiangd + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.mit; - platforms = [ "x86_64-linux" ]; + license = licenses.mit; + platforms = [ "x86_64-linux" ]; mainProgram = "hyper"; broken = true; # Error: 'node-pty' failed to load }; diff --git a/pkgs/by-name/hy/hyperhdr/package.nix b/pkgs/by-name/hy/hyperhdr/package.nix index 1866e7212e1f1f..8eec9ef219ee4f 100644 --- a/pkgs/by-name/hy/hyperhdr/package.nix +++ b/pkgs/by-name/hy/hyperhdr/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, alsa-lib -, flatbuffers -, libjpeg_turbo -, mbedtls -, mdns -, pipewire -, qt6Packages -, qmqtt -, xz +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + alsa-lib, + flatbuffers, + libjpeg_turbo, + mbedtls, + mdns, + pipewire, + qt6Packages, + qmqtt, + xz, }: let inherit (lib) cmakeBool - ; + ; in stdenv.mkDerivation rec { diff --git a/pkgs/by-name/hy/hyperledger-fabric/package.nix b/pkgs/by-name/hy/hyperledger-fabric/package.nix index 2647b656877226..f86e6e83012c51 100644 --- a/pkgs/by-name/hy/hyperledger-fabric/package.nix +++ b/pkgs/by-name/hy/hyperledger-fabric/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/hy/hyperlink/package.nix b/pkgs/by-name/hy/hyperlink/package.nix index 0edd68e6a82e03..04e699a6f3d3a3 100644 --- a/pkgs/by-name/hy/hyperlink/package.nix +++ b/pkgs/by-name/hy/hyperlink/package.nix @@ -1,6 +1,7 @@ -{ rustPlatform -, lib -, fetchFromGitHub +{ + rustPlatform, + lib, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/hy/hyperpotamus/package.nix b/pkgs/by-name/hy/hyperpotamus/package.nix index 869b8aea9143a0..d0c293fff008b9 100644 --- a/pkgs/by-name/hy/hyperpotamus/package.nix +++ b/pkgs/by-name/hy/hyperpotamus/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/hy/hyperrogue/package.nix b/pkgs/by-name/hy/hyperrogue/package.nix index 750496186ffbe8..a0db518f4a3a2f 100644 --- a/pkgs/by-name/hy/hyperrogue/package.nix +++ b/pkgs/by-name/hy/hyperrogue/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, SDL, SDL_ttf, SDL_gfx, SDL_mixer, libpng -, glew, dejavu_fonts, makeDesktopItem }: +{ + lib, + stdenv, + fetchFromGitHub, + SDL, + SDL_ttf, + SDL_gfx, + SDL_mixer, + libpng, + glew, + dejavu_fonts, + makeDesktopItem, +}: stdenv.mkDerivation rec { pname = "hyperrogue"; @@ -21,7 +32,14 @@ stdenv.mkDerivation rec { HYPERROGUE_USE_GLEW = 1; HYPERROGUE_USE_PNG = 1; - buildInputs = [ SDL SDL_ttf SDL_gfx SDL_mixer libpng glew ]; + buildInputs = [ + SDL + SDL_ttf + SDL_gfx + SDL_mixer + libpng + glew + ]; desktopItem = makeDesktopItem { name = "hyperrogue"; @@ -30,7 +48,10 @@ stdenv.mkDerivation rec { comment = meta.description; icon = "hyperrogue"; exec = "hyperrogue"; - categories = [ "Game" "AdventureGame" ]; + categories = [ + "Game" + "AdventureGame" + ]; }; installPhase = '' diff --git a/pkgs/by-name/hy/hyperscan/package.nix b/pkgs/by-name/hy/hyperscan/package.nix index cdb578ba08d557..b9ba8e7b8ddaac 100644 --- a/pkgs/by-name/hy/hyperscan/package.nix +++ b/pkgs/by-name/hy/hyperscan/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ragel -, python3 -, util-linux -, pkg-config -, boost -, pcre -, withStatic ? false # build only shared libs by default, build static+shared if true +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ragel, + python3, + util-linux, + pkg-config, + boost, + pcre, + withStatic ? false, # build only shared libs by default, build static+shared if true }: stdenv.mkDerivation (finalAttrs: { @@ -22,19 +23,27 @@ stdenv.mkDerivation (finalAttrs: { rev = "v${finalAttrs.version}"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; buildInputs = [ boost ]; nativeBuildInputs = [ - cmake ragel python3 util-linux pkg-config + cmake + ragel + python3 + util-linux + pkg-config ]; - cmakeFlags = [ - "-DBUILD_AVX512=ON" - ] - ++ lib.optional (!stdenv.hostPlatform.isDarwin) "-DFAT_RUNTIME=ON" - ++ lib.optional (withStatic) "-DBUILD_STATIC_AND_SHARED=ON" - ++ lib.optional (!withStatic) "-DBUILD_SHARED_LIBS=ON"; + cmakeFlags = + [ + "-DBUILD_AVX512=ON" + ] + ++ lib.optional (!stdenv.hostPlatform.isDarwin) "-DFAT_RUNTIME=ON" + ++ lib.optional (withStatic) "-DBUILD_STATIC_AND_SHARED=ON" + ++ lib.optional (!withStatic) "-DBUILD_SHARED_LIBS=ON"; # hyperscan CMake is completely broken for chimera builds when pcre is compiled # the only option to make it build - building from source @@ -78,7 +87,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.hyperscan.io/"; maintainers = with maintainers; [ avnik ]; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; license = licenses.bsd3; }; }) diff --git a/pkgs/by-name/hy/hyperscrypt-font/package.nix b/pkgs/by-name/hy/hyperscrypt-font/package.nix index a55702fbf2e5b2..51517cf1b3edb8 100644 --- a/pkgs/by-name/hy/hyperscrypt-font/package.nix +++ b/pkgs/by-name/hy/hyperscrypt-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "hyperscrypt"; diff --git a/pkgs/by-name/hy/hyperspeedcube/package.nix b/pkgs/by-name/hy/hyperspeedcube/package.nix index 79616e0a676287..870ad595038d60 100644 --- a/pkgs/by-name/hy/hyperspeedcube/package.nix +++ b/pkgs/by-name/hy/hyperspeedcube/package.nix @@ -1,41 +1,42 @@ -{ cmake -, alsa-lib -, atk -, cairo -, directx-shader-compiler -, expat -, fetchFromGitHub -, fontconfig -, freetype -, gdk-pixbuf -, glib -, gtk3 -, harfbuzz -, lib -, libGL -, libX11 -, libxcb -, libXcursor -, libXi -, libxkbcommon -, libXrandr -, makeWrapper -, mold -, pango -, pkg-config -, python3 -, rustPlatform -, shaderc -, vulkan-extension-layer -, vulkan-headers -, vulkan-loader -, vulkan-tools -, vulkan-tools-lunarg -, vulkan-validation-layers -, wayland -, wrapGAppsHook3 -, yq -, zlib +{ + cmake, + alsa-lib, + atk, + cairo, + directx-shader-compiler, + expat, + fetchFromGitHub, + fontconfig, + freetype, + gdk-pixbuf, + glib, + gtk3, + harfbuzz, + lib, + libGL, + libX11, + libxcb, + libXcursor, + libXi, + libxkbcommon, + libXrandr, + makeWrapper, + mold, + pango, + pkg-config, + python3, + rustPlatform, + shaderc, + vulkan-extension-layer, + vulkan-headers, + vulkan-loader, + vulkan-tools, + vulkan-tools-lunarg, + vulkan-validation-layers, + wayland, + wrapGAppsHook3, + yq, + zlib, }: rustPlatform.buildRustPackage rec { @@ -52,7 +53,7 @@ rustPlatform.buildRustPackage rec { cargoLock = { lockFile = ./Cargo.lock; outputHashes = { - "key-names-1.5.1" = "sha256-ZO3mlCoUHCaMnxD2vQno6GNx0+JmwZ8OiqpyveiVfvc="; + "key-names-1.5.1" = "sha256-ZO3mlCoUHCaMnxD2vQno6GNx0+JmwZ8OiqpyveiVfvc="; }; }; diff --git a/pkgs/by-name/hy/hypnotix/package.nix b/pkgs/by-name/hy/hypnotix/package.nix index 7b616ff539812c..3e6169da35cfba 100644 --- a/pkgs/by-name/hy/hypnotix/package.nix +++ b/pkgs/by-name/hy/hypnotix/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, substituteAll -, xapp -, circle-flags -, gettext -, gobject-introspection -, mpv -, python3 -, wrapGAppsHook3 -, yt-dlp +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + xapp, + circle-flags, + gettext, + gobject-introspection, + mpv, + python3, + wrapGAppsHook3, + yt-dlp, }: stdenv.mkDerivation rec { @@ -90,7 +91,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/linuxmint/hypnotix"; changelog = "https://github.com/linuxmint/hypnotix/blob/${src.rev}/debian/changelog"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ dotlambda bobby285271 ]; + maintainers = with lib.maintainers; [ + dotlambda + bobby285271 + ]; platforms = lib.platforms.linux; mainProgram = "hypnotix"; }; diff --git a/pkgs/by-name/hy/hyprkeys/package.nix b/pkgs/by-name/hy/hyprkeys/package.nix index ae13dadb1401ef..672f98e764c73b 100644 --- a/pkgs/by-name/hy/hyprkeys/package.nix +++ b/pkgs/by-name/hy/hyprkeys/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -38,7 +39,10 @@ buildGoModule rec { description = "Simple, scriptable keybind retrieval utility for Hyprland"; homepage = "https://github.com/hyprland-community/Hyprkeys"; license = licenses.gpl3Only; - maintainers = with maintainers; [ NotAShelf donovanglover ]; + maintainers = with maintainers; [ + NotAShelf + donovanglover + ]; mainProgram = "hyprkeys"; }; } diff --git a/pkgs/by-name/hy/hyprland-activewindow/package.nix b/pkgs/by-name/hy/hyprland-activewindow/package.nix index 522c451fd676df..8086a4a132d30a 100644 --- a/pkgs/by-name/hy/hyprland-activewindow/package.nix +++ b/pkgs/by-name/hy/hyprland-activewindow/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "hyprland-activewindow"; @@ -18,7 +22,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/FieldofClay/hyprland-activewindow"; license = licenses.mit; platforms = platforms.linux; - maintainers = with maintainers; [ kiike donovanglover ]; + maintainers = with maintainers; [ + kiike + donovanglover + ]; mainProgram = "hyprland-activewindow"; }; } diff --git a/pkgs/by-name/hy/hyprland-autoname-workspaces/package.nix b/pkgs/by-name/hy/hyprland-autoname-workspaces/package.nix index 9655ad5c230872..78ee30be586279 100644 --- a/pkgs/by-name/hy/hyprland-autoname-workspaces/package.nix +++ b/pkgs/by-name/hy/hyprland-autoname-workspaces/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/hy/hyprland-monitor-attached/package.nix b/pkgs/by-name/hy/hyprland-monitor-attached/package.nix index 291b1f5a249df0..faea98dbef693a 100644 --- a/pkgs/by-name/hy/hyprland-monitor-attached/package.nix +++ b/pkgs/by-name/hy/hyprland-monitor-attached/package.nix @@ -1,4 +1,8 @@ -{ rustPlatform, fetchFromGitHub, lib }: +{ + rustPlatform, + fetchFromGitHub, + lib, +}: rustPlatform.buildRustPackage rec { pname = "hyprland-monitor-attached"; diff --git a/pkgs/by-name/hy/hyprland-per-window-layout/package.nix b/pkgs/by-name/hy/hyprland-per-window-layout/package.nix index a8ad214bc087bc..f9c12a0c4926f0 100644 --- a/pkgs/by-name/hy/hyprland-per-window-layout/package.nix +++ b/pkgs/by-name/hy/hyprland-per-window-layout/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "hyprland-per-window-layout"; diff --git a/pkgs/by-name/hy/hyprland-protocols/package.nix b/pkgs/by-name/hy/hyprland-protocols/package.nix index 99c07db13cc9d5..4f36ec9d56255b 100644 --- a/pkgs/by-name/hy/hyprland-protocols/package.nix +++ b/pkgs/by-name/hy/hyprland-protocols/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, }: stdenv.mkDerivation (finalAttrs: { pname = "hyprland-protocols"; diff --git a/pkgs/by-name/hy/hyprland-workspaces/package.nix b/pkgs/by-name/hy/hyprland-workspaces/package.nix index 8457b620140086..3ec41e8b9c48ff 100644 --- a/pkgs/by-name/hy/hyprland-workspaces/package.nix +++ b/pkgs/by-name/hy/hyprland-workspaces/package.nix @@ -22,7 +22,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/FieldofClay/hyprland-workspaces"; license = licenses.mit; platforms = platforms.linux; - maintainers = with maintainers; [ kiike donovanglover ]; + maintainers = with maintainers; [ + kiike + donovanglover + ]; mainProgram = "hyprland-workspaces"; }; } diff --git a/pkgs/by-name/hy/hyprlang/package.nix b/pkgs/by-name/hy/hyprlang/package.nix index 3b88af7833039f..946d553240a999 100644 --- a/pkgs/by-name/hy/hyprlang/package.nix +++ b/pkgs/by-name/hy/hyprlang/package.nix @@ -32,6 +32,9 @@ stdenv.mkDerivation (finalAttrs: { description = "Official implementation library for the hypr config language"; license = lib.licenses.lgpl3Only; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ iogamaster fufexan ]; + maintainers = with lib.maintainers; [ + iogamaster + fufexan + ]; }; }) diff --git a/pkgs/by-name/hy/hyprls/package.nix b/pkgs/by-name/hy/hyprls/package.nix index 57c732d70b4c8d..e415846dcd332a 100644 --- a/pkgs/by-name/hy/hyprls/package.nix +++ b/pkgs/by-name/hy/hyprls/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, }: buildGoModule rec { pname = "hyprls"; diff --git a/pkgs/by-name/hy/hyprnotify/package.nix b/pkgs/by-name/hy/hyprnotify/package.nix index 1be9b8b114cf7c..d89277c5cda19e 100644 --- a/pkgs/by-name/hy/hyprnotify/package.nix +++ b/pkgs/by-name/hy/hyprnotify/package.nix @@ -3,7 +3,7 @@ buildGoModule, fetchFromGitHub, pkg-config, - alsa-lib + alsa-lib, }: buildGoModule rec { diff --git a/pkgs/by-name/hy/hyprpaper/package.nix b/pkgs/by-name/hy/hyprpaper/package.nix index db4af50f496690..a1633a6d3ed675 100644 --- a/pkgs/by-name/hy/hyprpaper/package.nix +++ b/pkgs/by-name/hy/hyprpaper/package.nix @@ -1,31 +1,32 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, cairo -, expat -, file -, fribidi -, hyprlang -, libdatrie -, libGL -, libjpeg -, libselinux -, libsepol -, libthai -, libwebp -, libXdmcp -, pango -, pcre -, pcre2 -, pkg-config -, util-linux -, wayland -, wayland-protocols -, wayland-scanner -, hyprwayland-scanner -, hyprutils +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + cairo, + expat, + file, + fribidi, + hyprlang, + libdatrie, + libGL, + libjpeg, + libselinux, + libsepol, + libthai, + libwebp, + libXdmcp, + pango, + pcre, + pcre2, + pkg-config, + util-linux, + wayland, + wayland-protocols, + wayland-scanner, + hyprwayland-scanner, + hyprutils, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/hy/hyprshot/package.nix b/pkgs/by-name/hy/hyprshot/package.nix index 17be2088c727b1..98666e17b84e7f 100644 --- a/pkgs/by-name/hy/hyprshot/package.nix +++ b/pkgs/by-name/hy/hyprshot/package.nix @@ -1,15 +1,16 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, hyprland -, jq -, grim -, slurp -, wl-clipboard -, libnotify -, withFreeze ? true -, hyprpicker -, makeWrapper +{ + stdenvNoCC, + lib, + fetchFromGitHub, + hyprland, + jq, + grim, + slurp, + wl-clipboard, + libnotify, + withFreeze ? true, + hyprpicker, + makeWrapper, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -30,9 +31,19 @@ stdenvNoCC.mkDerivation (finalAttrs: { install -Dm755 hyprshot -t "$out/bin" wrapProgram "$out/bin/hyprshot" \ - --prefix PATH ":" ${lib.makeBinPath ([ - hyprland jq grim slurp wl-clipboard libnotify - ] ++ lib.optionals withFreeze [ hyprpicker ])} + --prefix PATH ":" ${ + lib.makeBinPath ( + [ + hyprland + jq + grim + slurp + wl-clipboard + libnotify + ] + ++ lib.optionals withFreeze [ hyprpicker ] + ) + } runHook postInstall ''; diff --git a/pkgs/by-name/hy/hyprutils/package.nix b/pkgs/by-name/hy/hyprutils/package.nix index 527dcafd566955..de29c5adcf522f 100644 --- a/pkgs/by-name/hy/hyprutils/package.nix +++ b/pkgs/by-name/hy/hyprutils/package.nix @@ -28,7 +28,10 @@ stdenv.mkDerivation (finalAttrs: { pixman ]; - outputs = ["out" "dev"]; + outputs = [ + "out" + "dev" + ]; cmakeBuildType = "RelWithDebInfo"; @@ -39,7 +42,7 @@ stdenv.mkDerivation (finalAttrs: { description = "Small C++ library for utilities used across the Hypr* ecosystem"; license = lib.licenses.bsd3; platforms = lib.platforms.linux ++ lib.platforms.freebsd; - maintainers = with lib.maintainers; [ + maintainers = with lib.maintainers; [ donovanglover johnrtitor ]; diff --git a/pkgs/by-name/hy/hyprwayland-scanner/package.nix b/pkgs/by-name/hy/hyprwayland-scanner/package.nix index c6c46e9fb15e96..35650330b65578 100644 --- a/pkgs/by-name/hy/hyprwayland-scanner/package.nix +++ b/pkgs/by-name/hy/hyprwayland-scanner/package.nix @@ -1,11 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, pugixml -, nix-update-script -, +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + pugixml, + nix-update-script, }: stdenv.mkDerivation (finalAttrs: { pname = "hyprwayland-scanner"; diff --git a/pkgs/by-name/hy/hyx/package.nix b/pkgs/by-name/hy/hyx/package.nix index e41f9bbfceb297..0b8f48dc06433d 100644 --- a/pkgs/by-name/hy/hyx/package.nix +++ b/pkgs/by-name/hy/hyx/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, memstreamHook }: +{ + lib, + stdenv, + fetchurl, + memstreamHook, +}: stdenv.mkDerivation rec { pname = "hyx"; diff --git a/pkgs/by-name/i-/i-dot-ming/package.nix b/pkgs/by-name/i-/i-dot-ming/package.nix index 2941a0030c533e..3254482681ba6f 100644 --- a/pkgs/by-name/i-/i-dot-ming/package.nix +++ b/pkgs/by-name/i-/i-dot-ming/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchurl, writeScript }: +{ + lib, + stdenvNoCC, + fetchurl, + writeScript, +}: stdenvNoCC.mkDerivation rec { pname = "i.ming"; diff --git a/pkgs/by-name/i2/i2c-tools/package.nix b/pkgs/by-name/i2/i2c-tools/package.nix index de94d317a55bc4..b6e7e8be46ee39 100644 --- a/pkgs/by-name/i2/i2c-tools/package.nix +++ b/pkgs/by-name/i2/i2c-tools/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchzip -, perl -, read-edid +{ + lib, + stdenv, + fetchzip, + perl, + read-edid, }: stdenv.mkDerivation rec { @@ -26,7 +27,10 @@ stdenv.mkDerivation rec { makeFlags = [ "PREFIX=${placeholder "out"}" ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; postInstall = '' rm -rf $out/include/linux/i2c-dev.h # conflics with kernel headers @@ -36,7 +40,10 @@ stdenv.mkDerivation rec { description = "Set of I2C tools for Linux"; homepage = "https://i2c.wiki.kernel.org/index.php/I2C_Tools"; # library is LGPL 2.1 or later; "most tools" GPL 2 or later - license = with licenses; [ lgpl21Plus gpl2Plus ]; + license = with licenses; [ + lgpl21Plus + gpl2Plus + ]; maintainers = [ maintainers.dezgeg ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/i2/i2p/package.nix b/pkgs/by-name/i2/i2p/package.nix index d8b2e8ca7207c0..9c0dc3bf83447a 100644 --- a/pkgs/by-name/i2/i2p/package.nix +++ b/pkgs/by-name/i2/i2p/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchzip -, jdk -, ant -, gettext -, which -, dbip-country-lite -, java-service-wrapper -, makeWrapper -, gmp +{ + lib, + stdenv, + fetchzip, + jdk, + ant, + gettext, + which, + dbip-country-lite, + java-service-wrapper, + makeWrapper, + gmp, }: stdenv.mkDerivation (finalAttrs: { @@ -16,13 +17,15 @@ stdenv.mkDerivation (finalAttrs: { version = "2.7.0"; src = fetchzip { - urls = [ - "https://github.com/i2p/i2p.i2p/archive/i2p-${finalAttrs.version}.tar.gz" - ] ++ (map (mirror: "${mirror}${finalAttrs.version}/i2psource_${finalAttrs.version}.tar.bz2") [ - "https://download.i2p2.de/releases/" - "https://files.i2p-projekt.de/" - "https://download.i2p2.no/releases/" - ]); + urls = + [ + "https://github.com/i2p/i2p.i2p/archive/i2p-${finalAttrs.version}.tar.gz" + ] + ++ (map (mirror: "${mirror}${finalAttrs.version}/i2psource_${finalAttrs.version}.tar.bz2") [ + "https://download.i2p2.de/releases/" + "https://files.i2p-projekt.de/" + "https://download.i2p2.no/releases/" + ]); hash = "sha256-gw1i6jrmTfz9CZlCjtOUdH5R4vD57ysDeQxyyWifieg="; }; @@ -117,7 +120,11 @@ stdenv.mkDerivation (finalAttrs: { mit publicDomain ]; - platforms = [ "x86_64-linux" "i686-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + "aarch64-linux" + ]; maintainers = with maintainers; [ linsui ]; mainProgram = "i2prouter-plain"; }; diff --git a/pkgs/by-name/i2/i2pd/package.nix b/pkgs/by-name/i2/i2pd/package.nix index 260ce8a79b1425..c24325c31ba164 100644 --- a/pkgs/by-name/i2/i2pd/package.nix +++ b/pkgs/by-name/i2/i2pd/package.nix @@ -1,8 +1,14 @@ -{ lib, stdenv, fetchFromGitHub -, installShellFiles -, boost, zlib, openssl -, upnpSupport ? true, miniupnpc -, aesniSupport ? stdenv.hostPlatform.aesSupport +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + boost, + zlib, + openssl, + upnpSupport ? true, + miniupnpc, + aesniSupport ? stdenv.hostPlatform.aesSupport, }: stdenv.mkDerivation rec { @@ -16,17 +22,23 @@ stdenv.mkDerivation rec { sha256 = "sha256-neoIDZNBBDq3tqz1ET3/CS/zb0Lret9niyuU7iWoNIE="; }; - buildInputs = [ boost zlib openssl ] - ++ lib.optional upnpSupport miniupnpc; + buildInputs = [ + boost + zlib + openssl + ] ++ lib.optional upnpSupport miniupnpc; nativeBuildInputs = [ installShellFiles ]; makeFlags = - let ynf = a: b: a + "=" + (if b then "yes" else "no"); in - [ (ynf "USE_AESNI" aesniSupport) - (ynf "USE_UPNP" upnpSupport) + let + ynf = a: b: a + "=" + (if b then "yes" else "no"); + in + [ + (ynf "USE_AESNI" aesniSupport) + (ynf "USE_UPNP" upnpSupport) ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/i3/i3-open-next-ws/package.nix b/pkgs/by-name/i3/i3-open-next-ws/package.nix index a28f9a56666c9b..aa4e601596e1fc 100644 --- a/pkgs/by-name/i3/i3-open-next-ws/package.nix +++ b/pkgs/by-name/i3/i3-open-next-ws/package.nix @@ -18,7 +18,7 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/JohnDowson/i3-open-next-ws"; license = lib.licenses.mit; mainProgram = "i3-open-next-ws"; - maintainers = with lib.maintainers; [quantenzitrone]; + maintainers = with lib.maintainers; [ quantenzitrone ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/i3/i3a/package.nix b/pkgs/by-name/i3/i3a/package.nix index 853b758793c1b7..578b109a2508c9 100644 --- a/pkgs/by-name/i3/i3a/package.nix +++ b/pkgs/by-name/i3/i3a/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "i3a"; diff --git a/pkgs/by-name/i3/i3bar-river/package.nix b/pkgs/by-name/i3/i3bar-river/package.nix index 5e63d8344179ca..533ef5638d3d9b 100644 --- a/pkgs/by-name/i3/i3bar-river/package.nix +++ b/pkgs/by-name/i3/i3bar-river/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, pango +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + pango, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/i3/i3lock-pixeled/package.nix b/pkgs/by-name/i3/i3lock-pixeled/package.nix index ce7eab2b1daecc..c28a1f8a4290f6 100644 --- a/pkgs/by-name/i3/i3lock-pixeled/package.nix +++ b/pkgs/by-name/i3/i3lock-pixeled/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, i3lock, imagemagick, scrot, playerctl, fetchFromGitLab }: +{ + lib, + stdenv, + i3lock, + imagemagick, + scrot, + playerctl, + fetchFromGitLab, +}: stdenv.mkDerivation rec { pname = "i3lock-pixeled"; diff --git a/pkgs/by-name/i3/i3minator/package.nix b/pkgs/by-name/i3/i3minator/package.nix index d56ee6eadc7ad8..2c56f1d521f274 100644 --- a/pkgs/by-name/i3/i3minator/package.nix +++ b/pkgs/by-name/i3/i3minator/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, python3Packages, glibcLocales }: +{ + lib, + fetchFromGitHub, + python3Packages, + glibcLocales, +}: python3Packages.buildPythonApplication rec { pname = "i3minator"; @@ -13,7 +18,10 @@ python3Packages.buildPythonApplication rec { LC_ALL = "en_US.UTF-8"; buildInputs = [ glibcLocales ]; - propagatedBuildInputs = [ python3Packages.pyyaml python3Packages.i3-py ]; + propagatedBuildInputs = [ + python3Packages.pyyaml + python3Packages.i3-py + ]; # No tests doCheck = false; diff --git a/pkgs/by-name/i3/i3nator/package.nix b/pkgs/by-name/i3/i3nator/package.nix index ede71688175e18..3736bff99dda33 100644 --- a/pkgs/by-name/i3/i3nator/package.nix +++ b/pkgs/by-name/i3/i3nator/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "i3nator"; diff --git a/pkgs/by-name/i8/i810switch/package.nix b/pkgs/by-name/i8/i810switch/package.nix index 68ce1add6a4efb..0291c249274b2e 100644 --- a/pkgs/by-name/i8/i810switch/package.nix +++ b/pkgs/by-name/i8/i810switch/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, pciutils }: +{ + lib, + stdenv, + fetchurl, + pciutils, +}: stdenv.mkDerivation { pname = "i810switch"; diff --git a/pkgs/by-name/ia/ia-writer-duospace/package.nix b/pkgs/by-name/ia/ia-writer-duospace/package.nix index dc0471b65fb894..4b2126c9ad69f7 100644 --- a/pkgs/by-name/ia/ia-writer-duospace/package.nix +++ b/pkgs/by-name/ia/ia-writer-duospace/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "ia-writer-duospace"; diff --git a/pkgs/by-name/ia/ia-writer-quattro/package.nix b/pkgs/by-name/ia/ia-writer-quattro/package.nix index 2a3cdd5feccdf9..ba6a1dbc68b23e 100644 --- a/pkgs/by-name/ia/ia-writer-quattro/package.nix +++ b/pkgs/by-name/ia/ia-writer-quattro/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub, }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "ia-writer-quattro"; diff --git a/pkgs/by-name/ia/iam-policy-json-to-terraform/package.nix b/pkgs/by-name/ia/iam-policy-json-to-terraform/package.nix index 1c83bb6e3d99fc..d8bca4f7d1ea6d 100644 --- a/pkgs/by-name/ia/iam-policy-json-to-terraform/package.nix +++ b/pkgs/by-name/ia/iam-policy-json-to-terraform/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "iam-policy-json-to-terraform"; diff --git a/pkgs/by-name/ia/iamb/package.nix b/pkgs/by-name/ia/iamb/package.nix index 02a632a9f4b1ff..02d51b9b3089e4 100644 --- a/pkgs/by-name/ia/iamb/package.nix +++ b/pkgs/by-name/ia/iamb/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, darwin -, stdenv +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + darwin, + stdenv, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ia/iamy/package.nix b/pkgs/by-name/ia/iamy/package.nix index 935cc3fee763bb..5d8e7afa92f2b4 100644 --- a/pkgs/by-name/ia/iamy/package.nix +++ b/pkgs/by-name/ia/iamy/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "iamy"; @@ -14,7 +18,9 @@ buildGoModule rec { vendorHash = "sha256-/IUYM3pTvcHXw8t5MW6JUEWdxegFuQC8zkiySp8VEgE="; ldflags = [ - "-X main.Version=v${version}" "-s" "-w" + "-X main.Version=v${version}" + "-s" + "-w" ]; meta = with lib; { diff --git a/pkgs/by-name/ia/iana-etc/package.nix b/pkgs/by-name/ia/iana-etc/package.nix index 2f60c1367f2cec..0cfaee22c6e4ca 100644 --- a/pkgs/by-name/ia/iana-etc/package.nix +++ b/pkgs/by-name/ia/iana-etc/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchzip, stdenvNoCC, writeText }: +{ + lib, + fetchzip, + stdenvNoCC, + writeText, +}: stdenvNoCC.mkDerivation rec { pname = "iana-etc"; diff --git a/pkgs/by-name/ia/ianny/package.nix b/pkgs/by-name/ia/ianny/package.nix index f6ccb9db544f89..a417b2dcc5944b 100644 --- a/pkgs/by-name/ia/ianny/package.nix +++ b/pkgs/by-name/ia/ianny/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, dbus -, pkg-config +{ + lib, + fetchFromGitHub, + rustPlatform, + dbus, + pkg-config, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ia/iat/package.nix b/pkgs/by-name/ia/iat/package.nix index 67726ebf64e01a..e91b7fd917dea2 100644 --- a/pkgs/by-name/ia/iat/package.nix +++ b/pkgs/by-name/ia/iat/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttr: { diff --git a/pkgs/by-name/ib/ibm-sw-tpm2/package.nix b/pkgs/by-name/ib/ibm-sw-tpm2/package.nix index 7c4e03ba0600a3..f5f83f4736eb9b 100644 --- a/pkgs/by-name/ib/ibm-sw-tpm2/package.nix +++ b/pkgs/by-name/ib/ibm-sw-tpm2/package.nix @@ -1,13 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + openssl, }: let - makefile = - if stdenv.hostPlatform.isDarwin - then "makefile.mac" - else "makefile"; + makefile = if stdenv.hostPlatform.isDarwin then "makefile.mac" else "makefile"; in stdenv.mkDerivation rec { pname = "ibm-sw-tpm2"; diff --git a/pkgs/by-name/ib/ibniz/package.nix b/pkgs/by-name/ib/ibniz/package.nix index 04aadf911e1e18..c8dc3636ef615a 100644 --- a/pkgs/by-name/ib/ibniz/package.nix +++ b/pkgs/by-name/ib/ibniz/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, SDL }: +{ + lib, + stdenv, + fetchurl, + SDL, +}: stdenv.mkDerivation rec { pname = "ibniz"; diff --git a/pkgs/by-name/ib/ibus-theme-tools/package.nix b/pkgs/by-name/ib/ibus-theme-tools/package.nix index 05c56edd369780..414f5d134c2c02 100644 --- a/pkgs/by-name/ib/ibus-theme-tools/package.nix +++ b/pkgs/by-name/ib/ibus-theme-tools/package.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchFromGitHub, gettext }: +{ + lib, + python3Packages, + fetchFromGitHub, + gettext, +}: python3Packages.buildPythonApplication rec { pname = "ibus-theme-tools"; @@ -13,7 +18,10 @@ python3Packages.buildPythonApplication rec { buildInputs = [ gettext ]; - propagatedBuildInputs = with python3Packages; [ tinycss2 pygobject3 ]; + propagatedBuildInputs = with python3Packages; [ + tinycss2 + pygobject3 + ]; # No test. doCheck = false; diff --git a/pkgs/by-name/ic/ic-keysmith/package.nix b/pkgs/by-name/ic/ic-keysmith/package.nix index 30ca2a467576ea..560e36b32e09a9 100644 --- a/pkgs/by-name/ic/ic-keysmith/package.nix +++ b/pkgs/by-name/ic/ic-keysmith/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "keysmith"; diff --git a/pkgs/by-name/ic/ical2orgpy/package.nix b/pkgs/by-name/ic/ical2orgpy/package.nix index ac5607b4a819fe..0ca92ac2441387 100644 --- a/pkgs/by-name/ic/ical2orgpy/package.nix +++ b/pkgs/by-name/ic/ical2orgpy/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ic/icbm3d/package.nix b/pkgs/by-name/ic/icbm3d/package.nix index 6f531f42422817..27c398dc641c82 100644 --- a/pkgs/by-name/ic/icbm3d/package.nix +++ b/pkgs/by-name/ic/icbm3d/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, libX11}: +{ + lib, + stdenv, + fetchurl, + libX11, +}: stdenv.mkDerivation rec { pname = "icbm3d"; diff --git a/pkgs/by-name/ic/icdiff/package.nix b/pkgs/by-name/ic/icdiff/package.nix index 0b35b5779a3b55..dff381e00e5049 100644 --- a/pkgs/by-name/ic/icdiff/package.nix +++ b/pkgs/by-name/ic/icdiff/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, python3Packages, bash, git, less }: +{ + lib, + fetchFromGitHub, + python3Packages, + bash, + git, + less, +}: python3Packages.buildPythonApplication rec { pname = "icdiff"; diff --git a/pkgs/by-name/ic/icebreaker/package.nix b/pkgs/by-name/ic/icebreaker/package.nix index 0624a97be5e0ad..21c1594493bba2 100644 --- a/pkgs/by-name/ic/icebreaker/package.nix +++ b/pkgs/by-name/ic/icebreaker/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeBinaryWrapper +{ + lib, + buildGoModule, + fetchFromGitHub, + makeBinaryWrapper, }: buildGoModule { @@ -22,7 +23,10 @@ buildGoModule { makeBinaryWrapper ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' mkdir -p $out/share diff --git a/pkgs/by-name/ic/icecast/package.nix b/pkgs/by-name/ic/icecast/package.nix index 488c96a52123fa..5affabed1b5208 100644 --- a/pkgs/by-name/ic/icecast/package.nix +++ b/pkgs/by-name/ic/icecast/package.nix @@ -1,6 +1,16 @@ -{lib, stdenv, fetchurl -, libxml2, libxslt, curl -, libvorbis, libtheora, speex, libkate, libopus }: +{ + lib, + stdenv, + fetchurl, + libxml2, + libxslt, + curl, + libvorbis, + libtheora, + speex, + libkate, + libopus, +}: stdenv.mkDerivation rec { pname = "icecast"; @@ -11,7 +21,16 @@ stdenv.mkDerivation rec { sha256 = "0i2d9rhav0x6js2qhjf5iy6j2a7f0d11ail0lfv40hb1kygrgda9"; }; - buildInputs = [ libxml2 libxslt curl libvorbis libtheora speex libkate libopus ]; + buildInputs = [ + libxml2 + libxslt + curl + libvorbis + libtheora + speex + libkate + libopus + ]; hardeningEnable = [ "pie" ]; @@ -34,4 +53,3 @@ stdenv.mkDerivation rec { platforms = with lib.platforms; unix; }; } - diff --git a/pkgs/by-name/ic/icecream/package.nix b/pkgs/by-name/ic/icecream/package.nix index 20c782e7023822..5e1775302876ee 100644 --- a/pkgs/by-name/ic/icecream/package.nix +++ b/pkgs/by-name/ic/icecream/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, docbook2x, libarchive, libcap_ng, lzo, pkg-config, zstd, docbook_xml_dtd_45 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + docbook2x, + libarchive, + libcap_ng, + lzo, + pkg-config, + zstd, + docbook_xml_dtd_45, +}: stdenv.mkDerivation rec { pname = "icecream"; @@ -12,8 +24,18 @@ stdenv.mkDerivation rec { }; enableParallelBuilding = true; - nativeBuildInputs = [ autoreconfHook docbook2x pkg-config ]; - buildInputs = [ libarchive libcap_ng lzo zstd docbook_xml_dtd_45 ]; + nativeBuildInputs = [ + autoreconfHook + docbook2x + pkg-config + ]; + buildInputs = [ + libarchive + libcap_ng + lzo + zstd + docbook_xml_dtd_45 + ]; meta = with lib; { description = "Distributed compiler with a central scheduler to share build load"; diff --git a/pkgs/by-name/ic/iceshelf/package.nix b/pkgs/by-name/ic/iceshelf/package.nix index 631f82f350107d..deb1a888f00a06 100644 --- a/pkgs/by-name/ic/iceshelf/package.nix +++ b/pkgs/by-name/ic/iceshelf/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, git, awscli, python3 }: +{ + lib, + fetchFromGitHub, + git, + awscli, + python3, +}: python3.pkgs.buildPythonApplication rec { pname = "iceshelf"; diff --git a/pkgs/by-name/ic/icesl/package.nix b/pkgs/by-name/ic/icesl/package.nix index aeeb82ba581fb4..cf0494f76f6e1d 100644 --- a/pkgs/by-name/ic/icesl/package.nix +++ b/pkgs/by-name/ic/icesl/package.nix @@ -1,22 +1,61 @@ -{ stdenv, lib, fetchzip, libglut, libXmu, libXi, libX11, libICE, libGLU, libGL, libSM -, libXext, glibc, lua, luabind, glfw, libgccjit, dialog, makeWrapper +{ + stdenv, + lib, + fetchzip, + libglut, + libXmu, + libXi, + libX11, + libICE, + libGLU, + libGL, + libSM, + libXext, + glibc, + lua, + luabind, + glfw, + libgccjit, + dialog, + makeWrapper, }: let - lpath = lib.makeLibraryPath [ libXmu libXi libX11 libglut libICE libGLU libGL libSM libXext glibc lua glfw luabind libgccjit ]; + lpath = lib.makeLibraryPath [ + libXmu + libXi + libX11 + libglut + libICE + libGLU + libGL + libSM + libXext + glibc + lua + glfw + luabind + libgccjit + ]; in stdenv.mkDerivation rec { pname = "iceSL"; version = "2.4.1"; - src = if stdenv.hostPlatform.system == "x86_64-linux" then fetchzip { - url = "https://icesl.loria.fr/assets/other/download.php?build=${version}&os=amd64"; - extension = "zip"; - sha256 = "0rrnkqkhlsjclif5cjbf17qz64vs95ja49xarxjvq54wb4jhbs4l"; - } else if stdenv.hostPlatform.system == "i686-linux" then fetchzip { - url = "https://icesl.loria.fr/assets/other/download.php?build=${version}&os=i386"; - extension = "zip"; - sha256 = "0n2yyxzw0arkc70f0qli4n5chdlh9vc7aqizk4v7825mcglhwlyh"; - } else throw "Unsupported architecture"; + src = + if stdenv.hostPlatform.system == "x86_64-linux" then + fetchzip { + url = "https://icesl.loria.fr/assets/other/download.php?build=${version}&os=amd64"; + extension = "zip"; + sha256 = "0rrnkqkhlsjclif5cjbf17qz64vs95ja49xarxjvq54wb4jhbs4l"; + } + else if stdenv.hostPlatform.system == "i686-linux" then + fetchzip { + url = "https://icesl.loria.fr/assets/other/download.php?build=${version}&os=i386"; + extension = "zip"; + sha256 = "0n2yyxzw0arkc70f0qli4n5chdlh9vc7aqizk4v7825mcglhwlyh"; + } + else + throw "Unsupported architecture"; nativeBuildInputs = [ makeWrapper ]; installPhase = '' @@ -39,7 +78,10 @@ stdenv.mkDerivation rec { homepage = "https://icesl.loria.fr/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.inria-icesl; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; maintainers = with maintainers; [ mgttlinger ]; }; } diff --git a/pkgs/by-name/ic/icestorm/package.nix b/pkgs/by-name/ic/icestorm/package.nix index f6f7e46db56c06..2e443636247e61 100644 --- a/pkgs/by-name/ic/icestorm/package.nix +++ b/pkgs/by-name/ic/icestorm/package.nix @@ -1,16 +1,21 @@ -{ lib, stdenv, fetchFromGitHub -, pkg-config, libftdi1 -, python3, pypy3 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libftdi1, + python3, + pypy3, -# PyPy yields large improvements in build time and runtime performance, and -# IceStorm isn't intended to be used as a library other than by the nextpnr -# build process (which is also sped up by using PyPy), so we use it by default. -# See 18839e1 for more details. -# -# FIXME(aseipp, 3/1/2021): pypy seems a bit busted since stdenv upgrade to gcc -# 10/binutils 2.34, so short-circuit this for now in passthru below (done so -# that downstream overrides can't re-enable pypy and break their build somehow) -, usePyPy ? stdenv.hostPlatform.system == "x86_64-linux" + # PyPy yields large improvements in build time and runtime performance, and + # IceStorm isn't intended to be used as a library other than by the nextpnr + # build process (which is also sped up by using PyPy), so we use it by default. + # See 18839e1 for more details. + # + # FIXME(aseipp, 3/1/2021): pypy seems a bit busted since stdenv upgrade to gcc + # 10/binutils 2.34, so short-circuit this for now in passthru below (done so + # that downstream overrides can't re-enable pypy and break their build somehow) + usePyPy ? stdenv.hostPlatform.system == "x86_64-linux", }: stdenv.mkDerivation rec { @@ -23,14 +28,17 @@ stdenv.mkDerivation rec { }; src = fetchFromGitHub { - owner = "YosysHQ"; - repo = "icestorm"; - rev = "7afc64b480212c9ac2ce7cb1622731a69a7d212c"; + owner = "YosysHQ"; + repo = "icestorm"; + rev = "7afc64b480212c9ac2ce7cb1622731a69a7d212c"; sha256 = "0vxhqs2fampglg3xlfwb35229iv96kvlwp1gyxrdrmlpznhkqdrk"; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ passthru.pythonPkg libftdi1 ]; + buildInputs = [ + passthru.pythonPkg + libftdi1 + ]; makeFlags = [ "PREFIX=$(out)" ]; enableParallelBuilding = true; @@ -62,9 +70,12 @@ stdenv.mkDerivation rec { FPGAs and providing simple tools for analyzing and creating bitstream files. ''; - homepage = "https://github.com/YosysHQ/icestorm/"; - license = lib.licenses.isc; - maintainers = with lib.maintainers; [ shell thoughtpolice ]; - platforms = lib.platforms.all; + homepage = "https://github.com/YosysHQ/icestorm/"; + license = lib.licenses.isc; + maintainers = with lib.maintainers; [ + shell + thoughtpolice + ]; + platforms = lib.platforms.all; }; } diff --git a/pkgs/by-name/ic/icewm/package.nix b/pkgs/by-name/ic/icewm/package.nix index cf39b6613f068b..50f8565a4fe6de 100644 --- a/pkgs/by-name/ic/icewm/package.nix +++ b/pkgs/by-name/ic/icewm/package.nix @@ -1,41 +1,42 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, expat -, flac -, fontconfig -, freetype -, fribidi -, gdk-pixbuf -, gdk-pixbuf-xlib -, gettext -, giflib -, glib -, imlib2 -, libICE -, libSM -, libX11 -, libXcomposite -, libXdamage -, libXdmcp -, libXext -, libXfixes -, libXft -, libXinerama -, libXpm -, libXrandr -, libjpeg -, libogg -, libpng -, libpthreadstubs -, libsndfile -, libtiff -, libxcb -, mkfontdir -, pcre2 -, perl -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + expat, + flac, + fontconfig, + freetype, + fribidi, + gdk-pixbuf, + gdk-pixbuf-xlib, + gettext, + giflib, + glib, + imlib2, + libICE, + libSM, + libX11, + libXcomposite, + libXdamage, + libXdmcp, + libXext, + libXfixes, + libXft, + libXinerama, + libXpm, + libXrandr, + libjpeg, + libogg, + libpng, + libpthreadstubs, + libsndfile, + libtiff, + libxcb, + mkfontdir, + pcre2, + perl, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ic/icmake/package.nix b/pkgs/by-name/ic/icmake/package.nix index 039d4ee6970c13..1da38266e691b5 100644 --- a/pkgs/by-name/ic/icmake/package.nix +++ b/pkgs/by-name/ic/icmake/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitLab, makeWrapper, gcc, ncurses }: +{ + lib, + stdenv, + fetchFromGitLab, + makeWrapper, + gcc, + ncurses, +}: stdenv.mkDerivation rec { pname = "icmake"; @@ -11,7 +18,6 @@ stdenv.mkDerivation rec { owner = "fbb-git"; }; - setSourceRoot = '' sourceRoot=$(echo */icmake) ''; diff --git a/pkgs/by-name/ic/icon-lang/package.nix b/pkgs/by-name/ic/icon-lang/package.nix index 2ea8a20d4f6c38..c637f84894411a 100644 --- a/pkgs/by-name/ic/icon-lang/package.nix +++ b/pkgs/by-name/ic/icon-lang/package.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, libX11 -, libXt -, withGraphics ? true +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + libXt, + withGraphics ? true, }: stdenv.mkDerivation rec { @@ -15,18 +17,27 @@ stdenv.mkDerivation rec { sha256 = "1lj2f13pbaajcy4v3744bz46rghhw5sv4dwwfnzhsllbj5gnjsv2"; }; - buildInputs = lib.optionals withGraphics [ libX11 libXt ]; + buildInputs = lib.optionals withGraphics [ + libX11 + libXt + ]; configurePhase = let target = if withGraphics then "X-Configure" else "Configure"; platform = - if stdenv.hostPlatform.isLinux then "linux" - else if stdenv.hostPlatform.isDarwin then "macintosh" - else if stdenv.hostPlatform.isBSD then "bsd" - else if stdenv.hostPlatform.isCygwin then "cygwin" - else if stdenv.hostPlatform.isSunOS then "solaris" - else throw "unsupported system"; + if stdenv.hostPlatform.isLinux then + "linux" + else if stdenv.hostPlatform.isDarwin then + "macintosh" + else if stdenv.hostPlatform.isBSD then + "bsd" + else if stdenv.hostPlatform.isCygwin then + "cygwin" + else if stdenv.hostPlatform.isSunOS then + "solaris" + else + throw "unsupported system"; in "make ${target} name=${platform}"; diff --git a/pkgs/by-name/ic/icon-library/package.nix b/pkgs/by-name/ic/icon-library/package.nix index 2b2c3e19825ab5..7c3185aedc8766 100644 --- a/pkgs/by-name/ic/icon-library/package.nix +++ b/pkgs/by-name/ic/icon-library/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchurl -, wrapGAppsHook4 -, buildPackages -, cargo -, desktop-file-utils -, meson -, ninja -, pkg-config -, rustc -, gettext -, gdk-pixbuf -, glib -, gtk4 -, gtksourceview5 -, libadwaita -, darwin +{ + lib, + stdenv, + fetchurl, + wrapGAppsHook4, + buildPackages, + cargo, + desktop-file-utils, + meson, + ninja, + pkg-config, + rustc, + gettext, + gdk-pixbuf, + glib, + gtk4, + gtksourceview5, + libadwaita, + darwin, }: stdenv.mkDerivation rec { @@ -44,15 +45,17 @@ stdenv.mkDerivation rec { rustc wrapGAppsHook4 ]; - buildInputs = [ - gdk-pixbuf - glib - gtk4 - gtksourceview5 - libadwaita - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + gdk-pixbuf + glib + gtk4 + gtksourceview5 + libadwaita + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ]; meta = with lib; { homepage = "https://gitlab.gnome.org/World/design/icon-library"; diff --git a/pkgs/by-name/ic/icon-slicer/package.nix b/pkgs/by-name/ic/icon-slicer/package.nix index 514b39496ffa4c..476bc2de17db2d 100644 --- a/pkgs/by-name/ic/icon-slicer/package.nix +++ b/pkgs/by-name/ic/icon-slicer/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, gdk-pixbuf, popt }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gdk-pixbuf, + popt, +}: stdenv.mkDerivation rec { pname = "icon-slicer"; version = "0.3"; @@ -16,7 +23,10 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ popt pkg-config ]; + nativeBuildInputs = [ + popt + pkg-config + ]; buildInputs = [ gdk-pixbuf ]; meta = with lib; { diff --git a/pkgs/by-name/ic/iconConvTools/package.nix b/pkgs/by-name/ic/iconConvTools/package.nix index 442f1f2235fa60..7abd16326da4be 100644 --- a/pkgs/by-name/ic/iconConvTools/package.nix +++ b/pkgs/by-name/ic/iconConvTools/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, icoutils }: +{ + lib, + stdenv, + icoutils, +}: stdenv.mkDerivation { pname = "icon-conv-tools"; diff --git a/pkgs/by-name/ic/iconnamingutils/package.nix b/pkgs/by-name/ic/iconnamingutils/package.nix index 930327a880db17..f75fc1e49419cf 100644 --- a/pkgs/by-name/ic/iconnamingutils/package.nix +++ b/pkgs/by-name/ic/iconnamingutils/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, perl, librsvg}: +{ + lib, + stdenv, + fetchurl, + perl, + librsvg, +}: stdenv.mkDerivation rec { pname = "icon-naming-utils"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "071fj2jm5kydlz02ic5sylhmw6h2p3cgrm3gwdfabinqkqcv4jh4"; }; - buildInputs = [ librsvg (perl.withPackages (p: [ p.XMLSimple ])) ]; + buildInputs = [ + librsvg + (perl.withPackages (p: [ p.XMLSimple ])) + ]; meta = with lib; { homepage = "http://tango.freedesktop.org/Standard_Icon_Naming_Specification"; diff --git a/pkgs/by-name/ic/iconpack-jade/package.nix b/pkgs/by-name/ic/iconpack-jade/package.nix index d68e02b838d6a3..902ba2ef716623 100644 --- a/pkgs/by-name/ic/iconpack-jade/package.nix +++ b/pkgs/by-name/ic/iconpack-jade/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenvNoCC, fetchFromGitHub, gtk3, gnome-icon-theme, hicolor-icon-theme }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + gnome-icon-theme, + hicolor-icon-theme, +}: stdenvNoCC.mkDerivation rec { pname = "iconpack-jade"; @@ -13,7 +20,10 @@ stdenvNoCC.mkDerivation rec { nativeBuildInputs = [ gtk3 ]; - propagatedBuildInputs = [ gnome-icon-theme hicolor-icon-theme ]; + propagatedBuildInputs = [ + gnome-icon-theme + hicolor-icon-theme + ]; dontDropIconThemeCache = true; diff --git a/pkgs/by-name/ic/iconpack-obsidian/package.nix b/pkgs/by-name/ic/iconpack-obsidian/package.nix index 40d4d451f3f1d9..86ff31786e0467 100644 --- a/pkgs/by-name/ic/iconpack-obsidian/package.nix +++ b/pkgs/by-name/ic/iconpack-obsidian/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenvNoCC, fetchFromGitHub, gtk3, gnome-icon-theme, mint-x-icons, hicolor-icon-theme }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + gnome-icon-theme, + mint-x-icons, + hicolor-icon-theme, +}: stdenvNoCC.mkDerivation rec { pname = "iconpack-obsidian"; @@ -13,7 +21,11 @@ stdenvNoCC.mkDerivation rec { nativeBuildInputs = [ gtk3 ]; - propagatedBuildInputs = [ gnome-icon-theme mint-x-icons hicolor-icon-theme ]; + propagatedBuildInputs = [ + gnome-icon-theme + mint-x-icons + hicolor-icon-theme + ]; # still missing parent themes: Ambiant-MATE, Faenza-Dark, KFaenza dontDropIconThemeCache = true; diff --git a/pkgs/by-name/ic/icoutils/package.nix b/pkgs/by-name/ic/icoutils/package.nix index 1806699b1c23bb..399ff1cc6234ab 100644 --- a/pkgs/by-name/ic/icoutils/package.nix +++ b/pkgs/by-name/ic/icoutils/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, fetchpatch, autoreconfHook, libpng, perl, perlPackages, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + libpng, + perl, + perlPackages, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "icoutils"; @@ -17,8 +27,14 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook makeWrapper ]; - buildInputs = [ libpng perl ]; + nativeBuildInputs = [ + autoreconfHook + makeWrapper + ]; + buildInputs = [ + libpng + perl + ]; propagatedBuildInputs = [ perlPackages.LWP ]; # Fixes build failures on Darwin. These should be defined in `TargetConditional.h`, but it’s failing anyway. diff --git a/pkgs/by-name/ic/icr/package.nix b/pkgs/by-name/ic/icr/package.nix index 21c1b532445954..22468e862816cc 100644 --- a/pkgs/by-name/ic/icr/package.nix +++ b/pkgs/by-name/ic/icr/package.nix @@ -1,14 +1,15 @@ -{ lib -, fetchFromGitHub -, crystal -, shards -, makeWrapper -, pkg-config -, which -, openssl -, readline -, libyaml -, zlib +{ + lib, + fetchFromGitHub, + crystal, + shards, + makeWrapper, + pkg-config, + which, + openssl, + readline, + libyaml, + zlib, }: crystal.buildCrystalPackage rec { @@ -24,16 +25,31 @@ crystal.buildCrystalPackage rec { shardsFile = ./shards.nix; - buildInputs = [ libyaml openssl readline zlib ]; + buildInputs = [ + libyaml + openssl + readline + zlib + ]; - nativeBuildInputs = [ makeWrapper pkg-config which ]; + nativeBuildInputs = [ + makeWrapper + pkg-config + which + ]; # tests are failing due to our sandbox doCheck = false; postFixup = '' wrapProgram $out/bin/icr \ - --prefix PATH : ${lib.makeBinPath [ crystal shards which ]} + --prefix PATH : ${ + lib.makeBinPath [ + crystal + shards + which + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/ic/ictree/package.nix b/pkgs/by-name/ic/ictree/package.nix index c8ffdc090c20c2..68a0f4d32effb3 100644 --- a/pkgs/by-name/ic/ictree/package.nix +++ b/pkgs/by-name/ic/ictree/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "ictree"; diff --git a/pkgs/by-name/id/id3lib/package.nix b/pkgs/by-name/id/id3lib/package.nix index e95f5e3cab2d6a..00a22e8c048eec 100644 --- a/pkgs/by-name/id/id3lib/package.nix +++ b/pkgs/by-name/id/id3lib/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libiconv, zlib }: +{ + lib, + stdenv, + fetchurl, + libiconv, + zlib, +}: stdenv.mkDerivation rec { pname = "id3lib"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { ./patch_id3lib_3.8.3_UTF16_writing_bug.diff ]; - buildInputs = [ libiconv zlib ]; + buildInputs = [ + libiconv + zlib + ]; src = fetchurl { url = "mirror://sourceforge/id3lib/${pname}-${version}.tar.gz"; diff --git a/pkgs/by-name/id/id3v2/package.nix b/pkgs/by-name/id/id3v2/package.nix index b50affb2a95ea3..29b02629b6e42e 100644 --- a/pkgs/by-name/id/id3v2/package.nix +++ b/pkgs/by-name/id/id3v2/package.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchurl, id3lib, groff, zlib}: +{ + lib, + stdenv, + fetchurl, + id3lib, + groff, + zlib, +}: stdenv.mkDerivation rec { pname = "id3v2"; @@ -10,10 +17,16 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ groff ]; - buildInputs = [ id3lib zlib ]; + buildInputs = [ + id3lib + zlib + ]; makeFlags = [ "PREFIX=$(out)" ]; - buildFlags = [ "clean" "all" ]; + buildFlags = [ + "clean" + "all" + ]; preInstall = '' mkdir -p $out/{bin,share/man/man1} diff --git a/pkgs/by-name/id/ida-free/package.nix b/pkgs/by-name/id/ida-free/package.nix index d825ade468d90c..81078c2929a428 100644 --- a/pkgs/by-name/id/ida-free/package.nix +++ b/pkgs/by-name/id/ida-free/package.nix @@ -1,26 +1,27 @@ -{ autoPatchelfHook -, cairo -, copyDesktopItems -, dbus -, fetchurl -, fontconfig -, freetype -, glib -, gtk3 -, lib -, libdrm -, libGL -, libkrb5 -, libsecret -, libsForQt5 -, libunwind -, libxkbcommon -, makeDesktopItem -, makeWrapper -, openssl -, stdenv -, xorg -, zlib +{ + autoPatchelfHook, + cairo, + copyDesktopItems, + dbus, + fetchurl, + fontconfig, + freetype, + glib, + gtk3, + lib, + libdrm, + libGL, + libkrb5, + libsecret, + libsForQt5, + libunwind, + libxkbcommon, + makeDesktopItem, + makeWrapper, + openssl, + stdenv, + xorg, + zlib, }: let @@ -31,7 +32,10 @@ stdenv.mkDerivation rec { version = "8.4.240320"; src = fetchurl { - inherit (srcs.${stdenv.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}")) urls sha256; + inherit (srcs.${stdenv.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}")) + urls + sha256 + ; }; icon = fetchurl { @@ -54,7 +58,12 @@ stdenv.mkDerivation rec { desktopItems = [ desktopItem ]; - nativeBuildInputs = [ makeWrapper copyDesktopItems autoPatchelfHook libsForQt5.wrapQtAppsHook ]; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + autoPatchelfHook + libsForQt5.wrapQtAppsHook + ]; # We just get a runfile in $src, so no need to unpack it. dontUnpack = true; diff --git a/pkgs/by-name/id/idb-companion/package.nix b/pkgs/by-name/id/idb-companion/package.nix index 28bc9580dd2c4d..38b0944dc7ff20 100644 --- a/pkgs/by-name/id/idb-companion/package.nix +++ b/pkgs/by-name/id/idb-companion/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/id/ideogram/package.nix b/pkgs/by-name/id/ideogram/package.nix index 721bc1c7f9ad10..bbc34d59d88faa 100644 --- a/pkgs/by-name/id/ideogram/package.nix +++ b/pkgs/by-name/id/ideogram/package.nix @@ -1,18 +1,20 @@ -{ lib, stdenv -, fetchFromGitHub -, nix-update-script -, vala -, pkg-config -, python3 -, glib -, gtk3 -, meson -, ninja -, libgee -, pantheon -, desktop-file-utils -, xorg -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + vala, + pkg-config, + python3, + glib, + gtk3, + meson, + ninja, + libgee, + pantheon, + desktop-file-utils, + xorg, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/id/ideviceinstaller/package.nix b/pkgs/by-name/id/ideviceinstaller/package.nix index 3071aab6d1011f..1bf6d11cb26b93 100644 --- a/pkgs/by-name/id/ideviceinstaller/package.nix +++ b/pkgs/by-name/id/ideviceinstaller/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, usbmuxd -, libimobiledevice -, libzip +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + usbmuxd, + libimobiledevice, + libzip, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/id/idevicerestore/package.nix b/pkgs/by-name/id/idevicerestore/package.nix index 55fa9fcda8ba69..892792bd665aef 100644 --- a/pkgs/by-name/id/idevicerestore/package.nix +++ b/pkgs/by-name/id/idevicerestore/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, curl -, libimobiledevice -, libirecovery -, libzip -, libusbmuxd +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + curl, + libimobiledevice, + libirecovery, + libzip, + libusbmuxd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/id/idle3tools/package.nix b/pkgs/by-name/id/idle3tools/package.nix index 9c87450e31e4c1..141da480488e2a 100644 --- a/pkgs/by-name/id/idle3tools/package.nix +++ b/pkgs/by-name/id/idle3tools/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "idle3-tools"; diff --git a/pkgs/by-name/id/idnkit/package.nix b/pkgs/by-name/id/idnkit/package.nix index 37354f8be489d2..d8fcc48acc6ada 100644 --- a/pkgs/by-name/id/idnkit/package.nix +++ b/pkgs/by-name/id/idnkit/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libiconv }: +{ + lib, + stdenv, + fetchurl, + libiconv, +}: stdenv.mkDerivation rec { pname = "idnkit"; diff --git a/pkgs/by-name/id/idsk/package.nix b/pkgs/by-name/id/idsk/package.nix index c053f3aa0c16c3..22e69135e55e26 100644 --- a/pkgs/by-name/id/idsk/package.nix +++ b/pkgs/by-name/id/idsk/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/id/idutils/package.nix b/pkgs/by-name/id/idutils/package.nix index d065800b458fca..f7640baffc8d5f 100644 --- a/pkgs/by-name/id/idutils/package.nix +++ b/pkgs/by-name/id/idutils/package.nix @@ -1,4 +1,19 @@ -{ fetchurl, lib, stdenv, emacs, gnulib, autoconf, bison, automake, gettext, gperf, texinfo, perl, rsync, darwin }: +{ + fetchurl, + lib, + stdenv, + emacs, + gnulib, + autoconf, + bison, + automake, + gettext, + gperf, + texinfo, + perl, + rsync, + darwin, +}: stdenv.mkDerivation rec { pname = "idutils"; @@ -14,15 +29,27 @@ stdenv.mkDerivation rec { bash -O extglob -c "cd gnulib-tests; rm -r !(Makefile.am)" substituteInPlace ./configure.ac --replace "AC_PREREQ(2.61)" "AC_PREREQ(2.64)" ./bootstrap --force --gnulib-srcdir=${gnulib} --skip-po --bootstrap-sync --no-git - ''; + ''; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - emacs - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreServices - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + emacs + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreServices + ]; - nativeBuildInputs = [ gnulib autoconf bison automake gettext gperf texinfo perl rsync ]; + nativeBuildInputs = [ + gnulib + autoconf + bison + automake + gettext + gperf + texinfo + perl + rsync + ]; doCheck = !stdenv.hostPlatform.isDarwin; diff --git a/pkgs/by-name/if/ifdnfc/package.nix b/pkgs/by-name/if/ifdnfc/package.nix index 341e87173bf128..e8e6ab3cffd110 100644 --- a/pkgs/by-name/if/ifdnfc/package.nix +++ b/pkgs/by-name/if/ifdnfc/package.nix @@ -1,7 +1,11 @@ -{ lib, stdenv, fetchFromGitHub , pkg-config -, pcsclite -, autoreconfHook -, libnfc +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + pcsclite, + autoreconfHook, + libnfc, }: stdenv.mkDerivation { @@ -14,28 +18,37 @@ stdenv.mkDerivation { rev = "0e48e8e"; sha256 = "1cxnvhhlcbm8h49rlw5racspb85fmwqqhd3gzzpzy68vrs0b37vg"; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ pcsclite libnfc ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + pcsclite + libnfc + ]; configureFlags = [ "--prefix=$(out)" ]; - makeFlags = [ "DESTDIR=/" "usbdropdir=$(out)/pcsc/drivers" ]; + makeFlags = [ + "DESTDIR=/" + "usbdropdir=$(out)/pcsc/drivers" + ]; meta = with lib; { description = "PC/SC IFD Handler based on libnfc"; mainProgram = "ifdnfc-activate"; longDescription = '' - libnfc Interface Plugin to be used in services.pcscd.plugins. - It provides support for all readers which are not supported by ccid but by libnfc. + libnfc Interface Plugin to be used in services.pcscd.plugins. + It provides support for all readers which are not supported by ccid but by libnfc. - For activating your reader you need to run - ifdnfc-activate yes with this package in your - environment.systemPackages + For activating your reader you need to run + ifdnfc-activate yes with this package in your + environment.systemPackages - To use your reader you may need to blacklist your reader kernel modules: - boot.blacklistedKernelModules = [ "pn533" "pn533_usb" "nfc" ]; + To use your reader you may need to blacklist your reader kernel modules: + boot.blacklistedKernelModules = [ "pn533" "pn533_usb" "nfc" ]; - Supports the pn533 smart-card reader chip which is for example used in - the SCM SCL3711. + Supports the pn533 smart-card reader chip which is for example used in + the SCM SCL3711. ''; homepage = "https://github.com/nfc-tools/ifdnfc"; license = licenses.gpl3; @@ -43,4 +56,3 @@ stdenv.mkDerivation { maintainers = with maintainers; [ makefu ]; }; } - diff --git a/pkgs/by-name/if/ifenslave/package.nix b/pkgs/by-name/if/ifenslave/package.nix index 8aeeff77ecbb74..1d37842df6377b 100644 --- a/pkgs/by-name/if/ifenslave/package.nix +++ b/pkgs/by-name/if/ifenslave/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ifenslave"; diff --git a/pkgs/by-name/if/iferr/package.nix b/pkgs/by-name/if/iferr/package.nix index bf970ce1e9de5e..13395db61c8d7b 100644 --- a/pkgs/by-name/if/iferr/package.nix +++ b/pkgs/by-name/if/iferr/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, lib -, fetchFromGitHub +{ + buildGoModule, + lib, + fetchFromGitHub, }: buildGoModule { @@ -16,7 +17,10 @@ buildGoModule { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = ''Generate "if err != nil {" block''; diff --git a/pkgs/by-name/if/ifm/package.nix b/pkgs/by-name/if/ifm/package.nix index abefdc1c4783bb..2d723a74dd4c01 100644 --- a/pkgs/by-name/if/ifm/package.nix +++ b/pkgs/by-name/if/ifm/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchzip, autoreconfHook, bison, flex, help2man, perl, tk }: +{ + lib, + stdenv, + fetchzip, + autoreconfHook, + bison, + flex, + help2man, + perl, + tk, +}: stdenv.mkDerivation rec { pname = "ifm"; @@ -9,9 +19,17 @@ stdenv.mkDerivation rec { sha256 = "14af21qjd5jvsscm6vxpsdrnipdr33g6niagzmykrhyfhwcbjahi"; }; - nativeBuildInputs = [ autoreconfHook bison flex help2man ]; + nativeBuildInputs = [ + autoreconfHook + bison + flex + help2man + ]; - buildInputs = [ perl tk ]; # perl and wish are not run but written as shebangs. + buildInputs = [ + perl + tk + ]; # perl and wish are not run but written as shebangs. # Workaround build failure on -fno-common toolchains: # ld: libvars.a(vars-freeze-lex.o):src/libvars/vars-freeze-lex.l:23: diff --git a/pkgs/by-name/if/ifmetric/package.nix b/pkgs/by-name/if/ifmetric/package.nix index d4672b9be21b86..f6039f1f603e7b 100644 --- a/pkgs/by-name/if/ifmetric/package.nix +++ b/pkgs/by-name/if/ifmetric/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, lynx }: +{ + lib, + stdenv, + fetchurl, + lynx, +}: stdenv.mkDerivation rec { pname = "ifmetric"; diff --git a/pkgs/by-name/if/ifrextractor-rs/package.nix b/pkgs/by-name/if/ifrextractor-rs/package.nix index 2d525771d85fa4..ebcc6bdcad1bf8 100644 --- a/pkgs/by-name/if/ifrextractor-rs/package.nix +++ b/pkgs/by-name/if/ifrextractor-rs/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/if/ifstat-legacy/package.nix b/pkgs/by-name/if/ifstat-legacy/package.nix index f37f33a23f4bd4..6c7642ed2b143b 100644 --- a/pkgs/by-name/if/ifstat-legacy/package.nix +++ b/pkgs/by-name/if/ifstat-legacy/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, autoreconfHook, net-snmp }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + net-snmp, +}: stdenv.mkDerivation rec { pname = "ifstat-legacy"; @@ -22,10 +28,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Report network interfaces bandwith just like vmstat/iostat do for other system counters - legacy version"; - homepage = "http://gael.roualland.free.fr/ifstat/"; + homepage = "http://gael.roualland.free.fr/ifstat/"; maintainers = with maintainers; [ peterhoeg ]; - platforms = platforms.unix; - license = licenses.gpl2Plus; + platforms = platforms.unix; + license = licenses.gpl2Plus; mainProgram = "ifstat-legacy"; }; } diff --git a/pkgs/by-name/if/iftop/package.nix b/pkgs/by-name/if/iftop/package.nix index fdda3245b8b1e4..ea33e56f5b3569 100644 --- a/pkgs/by-name/if/iftop/package.nix +++ b/pkgs/by-name/if/iftop/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, ncurses, libpcap, automake, nixosTests }: +{ + lib, + stdenv, + fetchurl, + ncurses, + libpcap, + automake, + nixosTests, +}: stdenv.mkDerivation rec { pname = "iftop"; @@ -17,7 +25,10 @@ stdenv.mkDerivation rec { cp ${automake}/share/automake*/config.{sub,guess} config ''; - buildInputs = [ncurses libpcap]; + buildInputs = [ + ncurses + libpcap + ]; # Workaround build failure on -fno-common toolchains like upstream # gcc-10. Otherwise build fails as: diff --git a/pkgs/by-name/if/ifuse/package.nix b/pkgs/by-name/if/ifuse/package.nix index d8751f7b4eaf36..38c1a78a9b91e5 100644 --- a/pkgs/by-name/if/ifuse/package.nix +++ b/pkgs/by-name/if/ifuse/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, fuse -, usbmuxd -, libimobiledevice +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + fuse, + usbmuxd, + libimobiledevice, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ig/igir/package.nix b/pkgs/by-name/ig/igir/package.nix index 25d968c19975f7..38bf62bf443c4e 100644 --- a/pkgs/by-name/ig/igir/package.nix +++ b/pkgs/by-name/ig/igir/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub - -# for patching bundled 7z binary from the 7zip-bin node module -# at lib/node_modules/igir/node_modules/7zip-bin/linux/x64/7za -, autoPatchelfHook -, stdenv +{ + lib, + buildNpmPackage, + fetchFromGitHub, + + # for patching bundled 7z binary from the 7zip-bin node module + # at lib/node_modules/igir/node_modules/7zip-bin/linux/x64/7za + autoPatchelfHook, + stdenv, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ig/igmpproxy/package.nix b/pkgs/by-name/ig/igmpproxy/package.nix index 0632b1f48cea43..b3c6b196f617ec 100644 --- a/pkgs/by-name/ig/igmpproxy/package.nix +++ b/pkgs/by-name/ig/igmpproxy/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "igmpproxy"; diff --git a/pkgs/by-name/ig/ignite-cli/package.nix b/pkgs/by-name/ig/ignite-cli/package.nix index dc4298bb94ad28..65a97033f37cf1 100644 --- a/pkgs/by-name/ig/ignite-cli/package.nix +++ b/pkgs/by-name/ig/ignite-cli/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, makeWrapper -, go -, buf +{ + lib, + fetchFromGitHub, + buildGoModule, + makeWrapper, + go, + buf, }: buildGoModule rec { @@ -29,7 +30,12 @@ buildGoModule rec { # Required for commands like `ignite version`, `ignite network` and others postFixup = '' - wrapProgram $out/bin/ignite --prefix PATH : ${lib.makeBinPath [ go buf ]} + wrapProgram $out/bin/ignite --prefix PATH : ${ + lib.makeBinPath [ + go + buf + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/ig/igprof/package.nix b/pkgs/by-name/ig/igprof/package.nix index 229532c755e10d..2b5d3cf946a04f 100644 --- a/pkgs/by-name/ig/igprof/package.nix +++ b/pkgs/by-name/ig/igprof/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchFromGitHub, libunwind, cmake, pcre, gdb}: +{ + lib, + stdenv, + fetchFromGitHub, + libunwind, + cmake, + pcre, + gdb, +}: stdenv.mkDerivation rec { version = "5.9.18"; @@ -13,11 +21,20 @@ stdenv.mkDerivation rec { postPatch = '' substituteInPlace src/igprof --replace libigprof.so $out/lib/libigprof.so - ''; - - buildInputs = [libunwind gdb pcre]; - nativeBuildInputs = [cmake]; - CXXFLAGS = ["-fPIC" "-O2" "-w" "-fpermissive"]; + ''; + + buildInputs = [ + libunwind + gdb + pcre + ]; + nativeBuildInputs = [ cmake ]; + CXXFLAGS = [ + "-fPIC" + "-O2" + "-w" + "-fpermissive" + ]; meta = { broken = (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64); diff --git a/pkgs/by-name/ig/igraph/package.nix b/pkgs/by-name/ig/igraph/package.nix index fecc942e02e6ad..de3fc033f9470e 100644 --- a/pkgs/by-name/ig/igraph/package.nix +++ b/pkgs/by-name/ig/igraph/package.nix @@ -1,28 +1,27 @@ -{ stdenv -, lib -, fetchFromGitHub -, arpack -, bison -, blas -, cmake -, flex -, fop -, glpk -, gmp -, lapack -, libxml2 -, libxslt -, llvmPackages -, pkg-config -, plfit -, python3 -, sourceHighlight -, xmlto +{ + stdenv, + lib, + fetchFromGitHub, + arpack, + bison, + blas, + cmake, + flex, + fop, + glpk, + gmp, + lapack, + libxml2, + libxslt, + llvmPackages, + pkg-config, + plfit, + python3, + sourceHighlight, + xmlto, }: -assert (blas.isILP64 == lapack.isILP64 && - blas.isILP64 == arpack.isILP64 && - !blas.isILP64); +assert (blas.isILP64 == lapack.isILP64 && blas.isILP64 == arpack.isILP64 && !blas.isILP64); stdenv.mkDerivation (finalAttrs: { pname = "igraph"; @@ -39,7 +38,11 @@ stdenv.mkDerivation (finalAttrs: { echo "${finalAttrs.version}" > IGRAPH_VERSION ''; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; nativeBuildInputs = [ bison @@ -54,17 +57,19 @@ stdenv.mkDerivation (finalAttrs: { xmlto ]; - buildInputs = [ - arpack - blas - glpk - gmp - lapack - libxml2 - plfit - ] ++ lib.optionals stdenv.cc.isClang [ - llvmPackages.openmp - ]; + buildInputs = + [ + arpack + blas + glpk + gmp + lapack + libxml2 + plfit + ] + ++ lib.optionals stdenv.cc.isClang [ + llvmPackages.openmp + ]; cmakeFlags = [ "-DIGRAPH_USE_INTERNAL_BLAS=OFF" @@ -88,12 +93,14 @@ stdenv.mkDerivation (finalAttrs: { cp -r doc "$out/share" ''; - postFixup = '' - substituteInPlace $dev/lib/cmake/igraph/igraph-targets.cmake \ - --replace-fail "_IMPORT_PREFIX \"$out\"" "_IMPORT_PREFIX \"$dev\"" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install_name_tool -change libblas.dylib ${blas}/lib/libblas.dylib $out/lib/libigraph.dylib - ''; + postFixup = + '' + substituteInPlace $dev/lib/cmake/igraph/igraph-targets.cmake \ + --replace-fail "_IMPORT_PREFIX \"$out\"" "_IMPORT_PREFIX \"$dev\"" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install_name_tool -change libblas.dylib ${blas}/lib/libblas.dylib $out/lib/libigraph.dylib + ''; passthru.tests = { python = python3.pkgs.igraph; @@ -105,6 +112,9 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://github.com/igraph/igraph/blob/${finalAttrs.src.rev}/CHANGELOG.md"; license = licenses.gpl2Plus; platforms = platforms.all; - maintainers = with maintainers; [ MostAwesomeDude dotlambda ]; + maintainers = with maintainers; [ + MostAwesomeDude + dotlambda + ]; }; }) diff --git a/pkgs/by-name/ig/igv/package.nix b/pkgs/by-name/ig/igv/package.nix index e2502248a50ae8..a6ea26e64824e8 100644 --- a/pkgs/by-name/ig/igv/package.nix +++ b/pkgs/by-name/ig/igv/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchzip, jdk17, testers, wrapGAppsHook3, igv }: +{ + lib, + stdenv, + fetchzip, + jdk17, + testers, + wrapGAppsHook3, + igv, +}: stdenv.mkDerivation rec { pname = "igv"; @@ -30,7 +38,6 @@ stdenv.mkDerivation rec { package = igv; }; - meta = with lib; { homepage = "https://www.broadinstitute.org/igv/"; description = "Visualization tool for interactive exploration of genomic datasets"; diff --git a/pkgs/by-name/ih/ihp-new/package.nix b/pkgs/by-name/ih/ihp-new/package.nix index 76e66a7ae45430..1d2914f4af7dbc 100644 --- a/pkgs/by-name/ih/ihp-new/package.nix +++ b/pkgs/by-name/ih/ihp-new/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, git, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + git, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "ihp-new"; diff --git a/pkgs/by-name/ii/iio-sensor-proxy/package.nix b/pkgs/by-name/ii/iio-sensor-proxy/package.nix index 38c30dc436874a..3ffca17df48f4c 100644 --- a/pkgs/by-name/ii/iio-sensor-proxy/package.nix +++ b/pkgs/by-name/ii/iio-sensor-proxy/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitLab -, glib -, cmake -, libxml2 -, meson -, ninja -, pkg-config -, libgudev -, systemd -, polkit +{ + lib, + stdenv, + fetchFromGitLab, + glib, + cmake, + libxml2, + meson, + ninja, + pkg-config, + libgudev, + systemd, + polkit, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ii/iir1/package.nix b/pkgs/by-name/ii/iir1/package.nix index 3b9b37eb344bc0..326357c9e7f239 100644 --- a/pkgs/by-name/ii/iir1/package.nix +++ b/pkgs/by-name/ii/iir1/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ij/ijs/package.nix b/pkgs/by-name/ij/ijs/package.nix index ad13daef788d16..d8f363082df4ee 100644 --- a/pkgs/by-name/ij/ijs/package.nix +++ b/pkgs/by-name/ij/ijs/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, autoreconfHook, ghostscript }: +{ + lib, + stdenv, + autoreconfHook, + ghostscript, +}: stdenv.mkDerivation { pname = "ijs"; diff --git a/pkgs/by-name/ik/ike-scan/package.nix b/pkgs/by-name/ik/ike-scan/package.nix index 3c6374cab9a389..01b7ac5ecdc396 100644 --- a/pkgs/by-name/ik/ike-scan/package.nix +++ b/pkgs/by-name/ik/ike-scan/package.nix @@ -1,9 +1,10 @@ -{ lib -, autoreconfHook -, fetchFromGitHub -, fetchpatch -, openssl -, stdenv +{ + lib, + autoreconfHook, + fetchFromGitHub, + fetchpatch, + openssl, + stdenv, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ik/ikill/package.nix b/pkgs/by-name/ik/ikill/package.nix index 7b6ac685c50eea..602aa141527eed 100644 --- a/pkgs/by-name/ik/ikill/package.nix +++ b/pkgs/by-name/ik/ikill/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "ikill"; diff --git a/pkgs/by-name/il/ilbc/package.nix b/pkgs/by-name/il/ilbc/package.nix index 39d7b7b61b049b..e529e9b4c6d813 100644 --- a/pkgs/by-name/il/ilbc/package.nix +++ b/pkgs/by-name/il/ilbc/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, gawk, cmake }: +{ + lib, + stdenv, + fetchurl, + gawk, + cmake, +}: stdenv.mkDerivation rec { name = "ilbc-rfc3951"; @@ -17,7 +23,7 @@ stdenv.mkDerivation rec { cd ${name} ${gawk}/bin/gawk -f ${script} ${rfc3951} cp -v ${./CMakeLists.txt} CMakeLists.txt - ''; + ''; meta = { platforms = lib.platforms.unix; diff --git a/pkgs/by-name/il/ili2c/package.nix b/pkgs/by-name/il/ili2c/package.nix index 1d6f373db83a38..89ad4a19ee2352 100644 --- a/pkgs/by-name/il/ili2c/package.nix +++ b/pkgs/by-name/il/ili2c/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, ant -, jdk8 -, jre8 -, makeWrapper -, stripJavaArchivesHook +{ + lib, + stdenv, + fetchFromGitHub, + ant, + jdk8, + jre8, + makeWrapper, + stripJavaArchivesHook, }: let diff --git a/pkgs/by-name/il/illum/package.nix b/pkgs/by-name/il/illum/package.nix index 81d8bbee7b8d7d..57e0d2568a1746 100644 --- a/pkgs/by-name/il/illum/package.nix +++ b/pkgs/by-name/il/illum/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, pkg-config, ninja, libevdev, libev, udev }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + ninja, + libevdev, + libev, + udev, +}: stdenv.mkDerivation rec { pname = "illum"; @@ -21,7 +31,12 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ ninja libevdev libev udev ]; + buildInputs = [ + ninja + libevdev + libev + udev + ]; configurePhase = '' bash ./configure diff --git a/pkgs/by-name/il/ilmbase/package.nix b/pkgs/by-name/il/ilmbase/package.nix index dc075e43563d88..747d8c451b9e90 100644 --- a/pkgs/by-name/il/ilmbase/package.nix +++ b/pkgs/by-name/il/ilmbase/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, buildPackages -, cmake -, openexr +{ + stdenv, + lib, + buildPackages, + cmake, + openexr, }: stdenv.mkDerivation rec { @@ -13,7 +14,10 @@ stdenv.mkDerivation rec { # the ilmbase package into openexr in the future. inherit (openexr) src patches; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake ]; depsBuildBuild = [ buildPackages.stdenv.cc ]; diff --git a/pkgs/by-name/im/image-roll/package.nix b/pkgs/by-name/im/image-roll/package.nix index 2c1e86f22c7cd6..747f1cbd8cd872 100644 --- a/pkgs/by-name/im/image-roll/package.nix +++ b/pkgs/by-name/im/image-roll/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, glib -, pkg-config -, wrapGAppsHook4 -, gtk4 +{ + lib, + rustPlatform, + fetchFromGitHub, + glib, + pkg-config, + wrapGAppsHook4, + gtk4, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,11 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-cUE2IZOunR/NIo/qytORRfNqCsf87LfpKA8o/v4Nkhk="; - nativeBuildInputs = [ glib pkg-config wrapGAppsHook4 ]; + nativeBuildInputs = [ + glib + pkg-config + wrapGAppsHook4 + ]; buildInputs = [ gtk4 ]; diff --git a/pkgs/by-name/im/imagej/package.nix b/pkgs/by-name/im/imagej/package.nix index 53c984c961325c..5a49b4d540fada 100644 --- a/pkgs/by-name/im/imagej/package.nix +++ b/pkgs/by-name/im/imagej/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, glib -, jre -, unzip -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + glib, + jre, + unzip, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + wrapGAppsHook3, }: let @@ -15,7 +16,8 @@ let url = "https://imagej.net/media/icons/imagej.png"; sha256 = "sha256-nU2nWI1wxZB/xlOKsZzdUjj+qiCTjO6GwEKYgZ5Risg="; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "imagej"; version = "153"; @@ -23,7 +25,12 @@ in stdenv.mkDerivation rec { url = "https://wsr.imagej.net/distros/cross-platform/ij${version}.zip"; sha256 = "sha256-MGuUdUDuW3s/yGC68rHr6xxzmYScUjdXRawDpc1UQqw="; }; - nativeBuildInputs = [ copyDesktopItems makeWrapper unzip wrapGAppsHook3 ]; + nativeBuildInputs = [ + copyDesktopItems + makeWrapper + unzip + wrapGAppsHook3 + ]; buildInputs = [ glib ]; dontWrapGApps = true; @@ -32,7 +39,11 @@ in stdenv.mkDerivation rec { name = "ImageJ"; desktopName = "ImageJ"; icon = "imagej"; - categories = [ "Science" "Utility" "Graphics" ]; + categories = [ + "Science" + "Utility" + "Graphics" + ]; exec = "imagej"; }) ]; diff --git a/pkgs/by-name/im/imagelol/package.nix b/pkgs/by-name/im/imagelol/package.nix index 9d5cc34b38275c..7e663db77ee9ff 100644 --- a/pkgs/by-name/im/imagelol/package.nix +++ b/pkgs/by-name/im/imagelol/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, }: stdenv.mkDerivation rec { @@ -45,7 +46,11 @@ stdenv.mkDerivation rec { cp ./ImageLOL $out/bin ''; - cmakeFlags = [ (lib.cmakeFeature "CMAKE_C_FLAGS" "-std=gnu90") ] ++ lib.optional (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) "-DPNG_ARM_NEON=off"; + cmakeFlags = + [ (lib.cmakeFeature "CMAKE_C_FLAGS" "-std=gnu90") ] + ++ lib.optional ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 + ) "-DPNG_ARM_NEON=off"; meta = with lib; { homepage = "https://github.com/MCredstoner2004/ImageLOL"; diff --git a/pkgs/by-name/im/imaginary/package.nix b/pkgs/by-name/im/imaginary/package.nix index 4632647ed93e2e..dfe07024292e02 100644 --- a/pkgs/by-name/im/imaginary/package.nix +++ b/pkgs/by-name/im/imaginary/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch -, pkg-config -, vips +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + pkg-config, + vips, }: buildGoModule rec { @@ -46,7 +47,10 @@ buildGoModule rec { changelog = "https://github.com/h2non/${pname}/releases/tag/v${version}"; description = "Fast, simple, scalable, Docker-ready HTTP microservice for high-level image processing"; license = licenses.mit; - maintainers = with maintainers; [ dotlambda urandom ]; + maintainers = with maintainers; [ + dotlambda + urandom + ]; mainProgram = "imaginary"; }; } diff --git a/pkgs/by-name/im/imagination/package.nix b/pkgs/by-name/im/imagination/package.nix index 6dd9793b8b9773..ecf5c4c6859502 100644 --- a/pkgs/by-name/im/imagination/package.nix +++ b/pkgs/by-name/im/imagination/package.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchurl, autoreconfHook, docbook_xsl, ffmpeg-full, glib, gtk3 -, intltool, libxslt, pkg-config, sox, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + docbook_xsl, + ffmpeg-full, + glib, + gtk3, + intltool, + libxslt, + pkg-config, + sox, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "imagination"; @@ -19,7 +32,12 @@ stdenv.mkDerivation rec { wrapGAppsHook3 ]; - buildInputs = [ ffmpeg-full glib gtk3 sox ]; + buildInputs = [ + ffmpeg-full + glib + gtk3 + sox + ]; preBuild = '' substituteInPlace src/main-window.c \ @@ -31,7 +49,12 @@ stdenv.mkDerivation rec { preFixup = '' gappsWrapperArgs+=( - --prefix PATH : "${lib.makeBinPath [ ffmpeg-full sox ]}" + --prefix PATH : "${ + lib.makeBinPath [ + ffmpeg-full + sox + ] + }" ) ''; diff --git a/pkgs/by-name/im/imaginer/package.nix b/pkgs/by-name/im/imaginer/package.nix index 374815cd4279c3..598d6fb2b93ce2 100644 --- a/pkgs/by-name/im/imaginer/package.nix +++ b/pkgs/by-name/im/imaginer/package.nix @@ -1,18 +1,19 @@ -{ lib -, appstream-glib -, blueprint-compiler -, desktop-file-utils -, fetchFromGitHub -, gettext -, glib -, gobject-introspection -, libadwaita -, libsoup_3 -, meson -, ninja -, pkg-config -, python3Packages -, wrapGAppsHook4 +{ + lib, + appstream-glib, + blueprint-compiler, + desktop-file-utils, + fetchFromGitHub, + gettext, + glib, + gobject-introspection, + libadwaita, + libsoup_3, + meson, + ninja, + pkg-config, + python3Packages, + wrapGAppsHook4, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/im/imath/package.nix b/pkgs/by-name/im/imath/package.nix index a8e1ed336bcd10..9a3ddc0a1a5b9e 100644 --- a/pkgs/by-name/im/imath/package.nix +++ b/pkgs/by-name/im/imath/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/im/imdshift/package.nix b/pkgs/by-name/im/imdshift/package.nix index a4d7e46e7c280c..0d0bff509cf865 100644 --- a/pkgs/by-name/im/imdshift/package.nix +++ b/pkgs/by-name/im/imdshift/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/im/img-cat/package.nix b/pkgs/by-name/im/img-cat/package.nix index d148320b869861..ef8493e757405f 100644 --- a/pkgs/by-name/im/img-cat/package.nix +++ b/pkgs/by-name/im/img-cat/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "imgcat"; diff --git a/pkgs/by-name/im/img/package.nix b/pkgs/by-name/im/img/package.nix index f7c751cf0ea3ff..71fd68fb0fae62 100644 --- a/pkgs/by-name/im/img/package.nix +++ b/pkgs/by-name/im/img/package.nix @@ -1,9 +1,10 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, makeWrapper -, runc -, wrapperDir ? "/run/wrappers/bin" # Default for NixOS, other systems might need customization. +{ + buildGoModule, + fetchFromGitHub, + lib, + makeWrapper, + runc, + wrapperDir ? "/run/wrappers/bin", # Default for NixOS, other systems might need customization. }: buildGoModule rec { diff --git a/pkgs/by-name/im/imgcat/package.nix b/pkgs/by-name/im/imgcat/package.nix index ab3d22531589c2..aaaa5b0bc0656d 100644 --- a/pkgs/by-name/im/imgcat/package.nix +++ b/pkgs/by-name/im/imgcat/package.nix @@ -1,10 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, cimg, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + cimg, + ncurses, +}: stdenv.mkDerivation rec { pname = "imgcat"; version = "2.6.0"; - buildInputs = [ ncurses cimg ]; + buildInputs = [ + ncurses + cimg + ]; preConfigure = '' sed -i -e "s|-ltermcap|-L ${ncurses}/lib -lncurses|" Makefile @@ -30,4 +39,3 @@ stdenv.mkDerivation rec { mainProgram = "imgcat"; }; } - diff --git a/pkgs/by-name/im/imgcrypt/package.nix b/pkgs/by-name/im/imgcrypt/package.nix index bb703e3a0ac607..6b30c5b5d2b422 100644 --- a/pkgs/by-name/im/imgcrypt/package.nix +++ b/pkgs/by-name/im/imgcrypt/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "imgcrypt"; @@ -17,7 +21,10 @@ buildGoModule rec { "-X github.com/containerd/containerd/version.Version=${version}" ]; - subPackages = [ "cmd/ctd-decoder" "cmd/ctr" ]; + subPackages = [ + "cmd/ctd-decoder" + "cmd/ctr" + ]; postFixup = '' mv $out/bin/ctr $out/bin/ctr-enc diff --git a/pkgs/by-name/im/imgpatchtools/package.nix b/pkgs/by-name/im/imgpatchtools/package.nix index 737457a6465086..ddb57ba74c8f28 100644 --- a/pkgs/by-name/im/imgpatchtools/package.nix +++ b/pkgs/by-name/im/imgpatchtools/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, bzip2, openssl, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + bzip2, + openssl, + zlib, +}: stdenv.mkDerivation rec { pname = "imgpatchtools"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-7TOkqaXPui14VcSmMmYJ1Wg+s85wrgp+E0XcCB0Ml7M="; }; - buildInputs = [ bzip2 openssl zlib ]; + buildInputs = [ + bzip2 + openssl + zlib + ]; installPhase = "install -Dt $out/bin bin/*"; diff --git a/pkgs/by-name/im/imgproxy/package.nix b/pkgs/by-name/im/imgproxy/package.nix index 160185c5f3dd1f..d6c2af61ff9844 100644 --- a/pkgs/by-name/im/imgproxy/package.nix +++ b/pkgs/by-name/im/imgproxy/package.nix @@ -1,5 +1,13 @@ -{ lib, buildGoModule, fetchFromGitHub, pkg-config, vips, gobject-introspection -, stdenv, libunwind }: +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + vips, + gobject-introspection, + stdenv, + libunwind, +}: buildGoModule rec { pname = "imgproxy"; @@ -14,10 +22,12 @@ buildGoModule rec { vendorHash = "sha256-LGQ+JJ3OqDisT+CsnseVO54wyRTOkGpG9/zzpJw9P1I="; - nativeBuildInputs = [ pkg-config gobject-introspection ]; + nativeBuildInputs = [ + pkg-config + gobject-introspection + ]; - buildInputs = [ vips ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libunwind ]; + buildInputs = [ vips ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libunwind ]; preBuild = '' export CGO_LDFLAGS_ALLOW='-(s|w)' diff --git a/pkgs/by-name/im/imgur-screenshot/package.nix b/pkgs/by-name/im/imgur-screenshot/package.nix index a557657143f9ca..c9d29bfe92c600 100644 --- a/pkgs/by-name/im/imgur-screenshot/package.nix +++ b/pkgs/by-name/im/imgur-screenshot/package.nix @@ -1,7 +1,29 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, curl, jq, gnugrep, libnotify, scrot, which, xclip }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + curl, + jq, + gnugrep, + libnotify, + scrot, + which, + xclip, +}: -let deps = lib.makeBinPath [ curl jq gnugrep libnotify scrot which xclip ]; -in stdenv.mkDerivation rec { +let + deps = lib.makeBinPath [ + curl + jq + gnugrep + libnotify + scrot + which + xclip + ]; +in +stdenv.mkDerivation rec { version = "2.0.0"; pname = "imgur-screenshot"; diff --git a/pkgs/by-name/im/imgurbash2/package.nix b/pkgs/by-name/im/imgurbash2/package.nix index aff33f6d7dc800..10bb01e7690f94 100644 --- a/pkgs/by-name/im/imgurbash2/package.nix +++ b/pkgs/by-name/im/imgurbash2/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, bash, curl, xsel }: +{ + lib, + stdenv, + fetchFromGitHub, + bash, + curl, + xsel, +}: stdenv.mkDerivation rec { pname = "imgurbash2"; @@ -15,7 +22,12 @@ stdenv.mkDerivation rec { mkdir -p $out/bin cat <$out/bin/imgurbash2 #!${bash}/bin/bash - PATH=${lib.makeBinPath [curl xsel]}:\$PATH + PATH=${ + lib.makeBinPath [ + curl + xsel + ] + }:\$PATH EOF cat imgurbash2 >> $out/bin/imgurbash2 chmod +x $out/bin/imgurbash2 diff --git a/pkgs/by-name/im/iml/package.nix b/pkgs/by-name/im/iml/package.nix index 884cebab2e3008..ebcbc34ebee534 100644 --- a/pkgs/by-name/im/iml/package.nix +++ b/pkgs/by-name/im/iml/package.nix @@ -1,4 +1,11 @@ -{lib, stdenv, autoreconfHook, fetchurl, gmp, blas}: +{ + lib, + stdenv, + autoreconfHook, + fetchurl, + gmp, + blas, +}: stdenv.mkDerivation rec { pname = "iml"; version = "1.0.5"; @@ -21,7 +28,7 @@ stdenv.mkDerivation rec { meta = { description = "Algorithms for computing exact solutions to dense systems of linear equations over the integers"; license = lib.licenses.gpl2Plus; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.unix; homepage = "https://cs.uwaterloo.ca/~astorjoh/iml.html"; }; diff --git a/pkgs/by-name/im/imlib2/package.nix b/pkgs/by-name/im/imlib2/package.nix index cea3f45f9ff69e..ddffcf4d52dbdd 100644 --- a/pkgs/by-name/im/imlib2/package.nix +++ b/pkgs/by-name/im/imlib2/package.nix @@ -1,29 +1,41 @@ -{ lib, stdenv, fetchurl -# Image file formats -, libjpeg, libtiff, giflib, libpng, libwebp, libjxl -, libspectre -# imlib2 can load images from ID3 tags. -, libid3tag, librsvg, libheif -, freetype , bzip2, pkg-config -, x11Support ? true -, webpSupport ? true -, svgSupport ? false -, heifSupport ? false -, jxlSupport ? false -, psSupport ? false +{ + lib, + stdenv, + fetchurl, + # Image file formats + libjpeg, + libtiff, + giflib, + libpng, + libwebp, + libjxl, + libspectre, + # imlib2 can load images from ID3 tags. + libid3tag, + librsvg, + libheif, + freetype, + bzip2, + pkg-config, + x11Support ? true, + webpSupport ? true, + svgSupport ? false, + heifSupport ? false, + jxlSupport ? false, + psSupport ? false, -# for passthru.tests -, libcaca -, diffoscopeMinimal -, feh -, icewm -, openbox -, fluxbox -, enlightenment -, xorg -, testers + # for passthru.tests + libcaca, + diffoscopeMinimal, + feh, + icewm, + openbox, + fluxbox, + enlightenment, + xorg, + testers, -, gitUpdater + gitUpdater, }: let @@ -38,10 +50,20 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-liRGVldqPgpvWLeOUU3ckZYirGgGcRvCMYN+7mLB3jQ="; }; - buildInputs = [ - libjpeg libtiff giflib libpng - bzip2 freetype libid3tag - ] ++ optionals x11Support [ xorg.libXft xorg.libXext ] + buildInputs = + [ + libjpeg + libtiff + giflib + libpng + bzip2 + freetype + libid3tag + ] + ++ optionals x11Support [ + xorg.libXft + xorg.libXext + ] ++ optional heifSupport libheif ++ optional svgSupport librsvg ++ optional webpSupport libwebp @@ -54,12 +76,17 @@ stdenv.mkDerivation (finalAttrs: { # Do not build amd64 assembly code on Darwin, because it fails to compile # with unknow directive errors - configureFlags = optional stdenv.hostPlatform.isDarwin "--enable-amd64=no" + configureFlags = + optional stdenv.hostPlatform.isDarwin "--enable-amd64=no" ++ optional (!svgSupport) "--without-svg" ++ optional (!heifSupport) "--without-heif" ++ optional (!x11Support) "--without-x"; - outputs = [ "bin" "out" "dev" ]; + outputs = [ + "bin" + "out" + "dev" + ]; passthru = { tests = { @@ -70,7 +97,8 @@ stdenv.mkDerivation (finalAttrs: { icewm openbox fluxbox - enlightenment; + enlightenment + ; pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; }; updateScript = gitUpdater { diff --git a/pkgs/by-name/im/immer/package.nix b/pkgs/by-name/im/immer/package.nix index 1e82c6ad1d5dc0..9cc4aa2afd3714 100644 --- a/pkgs/by-name/im/immer/package.nix +++ b/pkgs/by-name/im/immer/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/im/immich-go/package.nix b/pkgs/by-name/im/immich-go/package.nix index 9e996b621a7807..22337bcf166b14 100644 --- a/pkgs/by-name/im/immich-go/package.nix +++ b/pkgs/by-name/im/immich-go/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, nix-update-script, testers, immich-go }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + testers, + immich-go, +}: buildGoModule rec { pname = "immich-go"; version = "0.22.1"; diff --git a/pkgs/by-name/im/immudb/package.nix b/pkgs/by-name/im/immudb/package.nix index 2ebe92995bd9d4..76224b1f175883 100644 --- a/pkgs/by-name/im/immudb/package.nix +++ b/pkgs/by-name/im/immudb/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchzip -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchzip, + installShellFiles, }: let diff --git a/pkgs/by-name/im/impl/package.nix b/pkgs/by-name/im/impl/package.nix index c33389af05e527..7f44746a6767dd 100644 --- a/pkgs/by-name/im/impl/package.nix +++ b/pkgs/by-name/im/impl/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, lib, fetchFromGitHub }: +{ + buildGoModule, + lib, + fetchFromGitHub, +}: buildGoModule rec { pname = "impl"; diff --git a/pkgs/by-name/im/imposm/package.nix b/pkgs/by-name/im/imposm/package.nix index 76d543b3d469aa..b662dcaae8933e 100644 --- a/pkgs/by-name/im/imposm/package.nix +++ b/pkgs/by-name/im/imposm/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, leveldb, geos }: +{ + lib, + buildGoModule, + fetchFromGitHub, + leveldb, + geos, +}: buildGoModule rec { pname = "imposm"; @@ -13,7 +19,10 @@ buildGoModule rec { vendorHash = null; - buildInputs = [ leveldb geos ]; + buildInputs = [ + leveldb + geos + ]; ldflags = [ "-s -w" diff --git a/pkgs/by-name/im/impression/package.nix b/pkgs/by-name/im/impression/package.nix index 18440fed40589d..62fffcbd3afe8d 100644 --- a/pkgs/by-name/im/impression/package.nix +++ b/pkgs/by-name/im/impression/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitLab -, blueprint-compiler -, cargo -, desktop-file-utils -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, wrapGAppsHook4 -, cairo -, dbus -, gdk-pixbuf -, glib -, gtk4 -, libadwaita -, openssl -, pango +{ + lib, + stdenv, + fetchFromGitLab, + blueprint-compiler, + cargo, + desktop-file-utils, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + wrapGAppsHook4, + cairo, + dbus, + gdk-pixbuf, + glib, + gtk4, + libadwaita, + openssl, + pango, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/im/impy/package.nix b/pkgs/by-name/im/impy/package.nix index 5be23b0a96f4c7..8efe8f259ceb67 100644 --- a/pkgs/by-name/im/impy/package.nix +++ b/pkgs/by-name/im/impy/package.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, libpng -, zlib -, giflib -, libjpeg +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + libpng, + zlib, + giflib, + libjpeg, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/im/imsprog/package.nix b/pkgs/by-name/im/imsprog/package.nix index 113281f5702e10..6d65ea47093577 100644 --- a/pkgs/by-name/im/imsprog/package.nix +++ b/pkgs/by-name/im/imsprog/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, cmake, makeWrapper, pkg-config, bash, libusb1, qt5, wget, zenity }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + makeWrapper, + pkg-config, + bash, + libusb1, + qt5, + wget, + zenity, +}: stdenv.mkDerivation (finalAttrs: { pname = "imsprog"; @@ -40,14 +52,23 @@ stdenv.mkDerivation (finalAttrs: { postFixup = '' wrapProgram $out/bin/IMSProg_database_update \ - --prefix PATH : "${lib.makeBinPath [ wget zenity ]}" + --prefix PATH : "${ + lib.makeBinPath [ + wget + zenity + ] + }" ''; meta = { changelog = "https://github.com/bigbigmdm/IMSProg/releases/tag/v${finalAttrs.version}"; description = "A free I2C EEPROM programmer tool for CH341A device"; homepage = "https://github.com/bigbigmdm/IMSProg"; - license = with lib.licenses; [ gpl3Plus gpl2Plus lgpl21Only ]; + license = with lib.licenses; [ + gpl3Plus + gpl2Plus + lgpl21Only + ]; mainProgram = "IMSProg"; maintainers = with lib.maintainers; [ wucke13 ]; platforms = lib.platforms.unix; diff --git a/pkgs/by-name/im/imtui/package.nix b/pkgs/by-name/im/imtui/package.nix index ac1791126bfde3..6d949c9856fbc7 100644 --- a/pkgs/by-name/im/imtui/package.nix +++ b/pkgs/by-name/im/imtui/package.nix @@ -1,14 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, imgui -, ninja -, withEmscripten ? false, emscripten -, withCurl ? (!withEmscripten), curl -, withNcurses ? (!withEmscripten), ncurses -, static ? withEmscripten -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + imgui, + ninja, + withEmscripten ? false, + emscripten, + withCurl ? (!withEmscripten), + curl, + withNcurses ? (!withEmscripten), + ncurses, + static ? withEmscripten, + darwin, }: stdenv.mkDerivation rec { @@ -22,20 +26,26 @@ stdenv.mkDerivation rec { hash = "sha256-eHQPDEfxKGLdiOi0lUUgqJcmme1XJLSPAafT223YK+U="; }; - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; - buildInputs = lib.optional withEmscripten emscripten + buildInputs = + lib.optional withEmscripten emscripten ++ lib.optional withCurl curl ++ lib.optional withNcurses ncurses ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.Cocoa; - postPatch = '' - cp -r ${imgui.src}/* third-party/imgui/imgui - chmod -R u+w third-party/imgui - '' + lib.optionalString (lib.versionAtLeast imgui.version "1.90.1") '' - substituteInPlace src/imtui-impl-{emscripten,ncurses}.cpp \ - --replace "ImGuiKey_KeyPadEnter" "ImGuiKey_KeypadEnter" - ''; + postPatch = + '' + cp -r ${imgui.src}/* third-party/imgui/imgui + chmod -R u+w third-party/imgui + '' + + lib.optionalString (lib.versionAtLeast imgui.version "1.90.1") '' + substituteInPlace src/imtui-impl-{emscripten,ncurses}.cpp \ + --replace "ImGuiKey_KeyPadEnter" "ImGuiKey_KeypadEnter" + ''; cmakeFlags = [ "-DEMSCRIPTEN:BOOL=${if withEmscripten then "ON" else "OFF"}" diff --git a/pkgs/by-name/im/imv/package.nix b/pkgs/by-name/im/imv/package.nix index 8908a987da4db3..775c82585cc40c 100644 --- a/pkgs/by-name/im/imv/package.nix +++ b/pkgs/by-name/im/imv/package.nix @@ -1,71 +1,93 @@ -{ stdenv -, lib -, fetchFromSourcehut -, asciidoc -, cmocka -, docbook_xsl -, libxslt -, meson -, ninja -, pkg-config -, icu -, pango -, inih -, withWindowSystem ? null -, xorg -, libxkbcommon -, libGLU -, wayland -# "libnsgif" is disabled until https://todo.sr.ht/~exec64/imv/55 is solved -, withBackends ? [ "libjxl" "libtiff" "libjpeg" "libpng" "librsvg" "libheif" ] -, freeimage -, libtiff -, libjpeg_turbo -, libjxl -, libpng -, librsvg -, netsurf -, libheif +{ + stdenv, + lib, + fetchFromSourcehut, + asciidoc, + cmocka, + docbook_xsl, + libxslt, + meson, + ninja, + pkg-config, + icu, + pango, + inih, + withWindowSystem ? null, + xorg, + libxkbcommon, + libGLU, + wayland, + # "libnsgif" is disabled until https://todo.sr.ht/~exec64/imv/55 is solved + withBackends ? [ + "libjxl" + "libtiff" + "libjpeg" + "libpng" + "librsvg" + "libheif" + ], + freeimage, + libtiff, + libjpeg_turbo, + libjxl, + libpng, + librsvg, + netsurf, + libheif, }: let # default value of withWindowSystem withWindowSystem' = - if withWindowSystem != null then withWindowSystem - else if stdenv.hostPlatform.isLinux then "all" - else "x11"; + if withWindowSystem != null then + withWindowSystem + else if stdenv.hostPlatform.isLinux then + "all" + else + "x11"; windowSystems = { all = windowSystems.x11 ++ windowSystems.wayland; - x11 = [ libGLU xorg.libxcb xorg.libX11 ]; + x11 = [ + libGLU + xorg.libxcb + xorg.libX11 + ]; wayland = [ wayland ]; }; backends = { - inherit freeimage libtiff libpng librsvg libheif libjxl; + inherit + freeimage + libtiff + libpng + librsvg + libheif + libjxl + ; libjpeg = libjpeg_turbo; inherit (netsurf) libnsgif; }; - backendFlags = builtins.map - (b: if builtins.elem b withBackends - then "-D${b}=enabled" - else "-D${b}=disabled") - (builtins.attrNames backends); + backendFlags = builtins.map ( + b: if builtins.elem b withBackends then "-D${b}=enabled" else "-D${b}=disabled" + ) (builtins.attrNames backends); in # check that given window system is valid -assert lib.assertOneOf "withWindowSystem" withWindowSystem' - (builtins.attrNames windowSystems); +assert lib.assertOneOf "withWindowSystem" withWindowSystem' (builtins.attrNames windowSystems); # check that every given backend is valid -assert builtins.all - (b: lib.assertOneOf "each backend" b (builtins.attrNames backends)) - withBackends; +assert builtins.all ( + b: lib.assertOneOf "each backend" b (builtins.attrNames backends) +) withBackends; stdenv.mkDerivation rec { pname = "imv"; version = "4.5.0"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchFromSourcehut { owner = "~exec64"; @@ -91,13 +113,15 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - cmocka - icu - libxkbcommon - pango - inih - ] ++ windowSystems."${withWindowSystem'}" + buildInputs = + [ + cmocka + icu + libxkbcommon + pango + inih + ] + ++ windowSystems."${withWindowSystem'}" ++ builtins.map (b: backends."${b}") withBackends; postInstall = '' @@ -119,7 +143,10 @@ stdenv.mkDerivation rec { description = "Command line image viewer for tiling window managers"; homepage = "https://sr.ht/~exec64/imv/"; license = licenses.mit; - maintainers = with maintainers; [ rnhmjoj markus1189 ]; + maintainers = with maintainers; [ + rnhmjoj + markus1189 + ]; platforms = platforms.all; badPlatforms = platforms.darwin; mainProgram = "imv"; diff --git a/pkgs/by-name/im/imwheel/package.nix b/pkgs/by-name/im/imwheel/package.nix index 9e3afb37d4f9ab..3a3dfb0135726d 100644 --- a/pkgs/by-name/im/imwheel/package.nix +++ b/pkgs/by-name/im/imwheel/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, libX11, libXext, libXi, libXmu, libXt, libXtst }: +{ + lib, + stdenv, + fetchurl, + libX11, + libXext, + libXi, + libXmu, + libXt, + libXtst, +}: stdenv.mkDerivation rec { pname = "imwheel"; @@ -9,7 +19,14 @@ stdenv.mkDerivation rec { sha256 = "2320ed019c95ca4d922968e1e1cbf0c075a914e865e3965d2bd694ca3d57cfe3"; }; - buildInputs = [ libX11 libXext libXi libXmu libXt libXtst ]; + buildInputs = [ + libX11 + libXext + libXi + libXmu + libXt + libXtst + ]; makeFlags = [ "sysconfdir=/etc" diff --git a/pkgs/by-name/in/inadyn/package.nix b/pkgs/by-name/in/inadyn/package.nix index fa064fbd1664c6..09963d89646e71 100644 --- a/pkgs/by-name/in/inadyn/package.nix +++ b/pkgs/by-name/in/inadyn/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config -, gnutls, libite, libconfuse }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + gnutls, + libite, + libconfuse, +}: stdenv.mkDerivation rec { pname = "inadyn"; @@ -12,9 +20,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-aQHJtnMDaHF1XY9lwQVR6f78Zk2UI7OC3Oxt1r1KMak="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ gnutls libite libconfuse ]; + buildInputs = [ + gnutls + libite + libconfuse + ]; configureFlags = [ "--sysconfdir=/etc" diff --git a/pkgs/by-name/in/inav-blackbox-tools/package.nix b/pkgs/by-name/in/inav-blackbox-tools/package.nix index 4acfc4d4890eff..a9e042b0186a0f 100644 --- a/pkgs/by-name/in/inav-blackbox-tools/package.nix +++ b/pkgs/by-name/in/inav-blackbox-tools/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, cairo }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cairo, +}: stdenv.mkDerivation rec { pname = "inav-blackbox-tools"; @@ -28,7 +34,7 @@ stdenv.mkDerivation rec { description = "Tools for working with blackbox flight logs"; homepage = "https://github.com/inavflight/blackbox-tools"; license = licenses.gpl3Only; - maintainers = []; + maintainers = [ ]; platforms = platforms.all; broken = stdenv.hostPlatform.isDarwin; # never built on Hydra https://hydra.nixos.org/job/nixpkgs/trunk/inav-blackbox-tools.x86_64-darwin }; diff --git a/pkgs/by-name/in/inchi/package.nix b/pkgs/by-name/in/inchi/package.nix index 1c8cca6af715fa..d738d62e1cd6c5 100644 --- a/pkgs/by-name/in/inchi/package.nix +++ b/pkgs/by-name/in/inchi/package.nix @@ -1,8 +1,9 @@ -{ fetchurl -, lib -, stdenv -, unzip -, fixDarwinDylibNames +{ + fetchurl, + lib, + stdenv, + unzip, + fixDarwinDylibNames, }: let @@ -13,34 +14,41 @@ let src-doc = fetchurl { url = "http://www.inchi-trust.org/download/${removeDots version}/INCHI-1-DOC.zip"; sha256 = "1kyda09i9p89xfq90ninwi7w13k1w3ljpl4gqdhpfhi5g8fgxx7f"; - }; + }; in - stdenv.mkDerivation rec { - pname = "inchi"; - inherit version; +stdenv.mkDerivation rec { + pname = "inchi"; + inherit version; - src = fetchurl { - url = "http://www.inchi-trust.org/download/${removeDots version}/INCHI-1-SRC.zip"; - sha256 = "1zbygqn0443p0gxwr4kx3m1bkqaj8x9hrpch3s41py7jq08f6x28"; - }; + src = fetchurl { + url = "http://www.inchi-trust.org/download/${removeDots version}/INCHI-1-SRC.zip"; + sha256 = "1zbygqn0443p0gxwr4kx3m1bkqaj8x9hrpch3s41py7jq08f6x28"; + }; - nativeBuildInputs = [ unzip ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; - outputs = [ "out" "doc" ]; + nativeBuildInputs = [ unzip ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; + outputs = [ + "out" + "doc" + ]; - enableParallelBuilding = true; + enableParallelBuilding = true; - preConfigure = '' + preConfigure = + '' cd ./INCHI_API/libinchi/gcc - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' substituteInPlace makefile \ --replace ",--version-script=libinchi.map" "" \ --replace "LINUX_Z_RELRO = ,-z,relro" "" \ --replace "-soname" "-install_name" \ --replace "gcc" $CC ''; - installPhase = let + installPhase = + let versionOneDot = versionMajor + "." + removeDots versionMinor; - in '' + in + '' runHook preInstall cd ../../.. @@ -56,19 +64,19 @@ in runHook postInstall ''; - preFixup = lib.optionalString stdenv.hostPlatform.isDarwin '' - fixDarwinDylibNames $(find "$out" -name "*.so.*") - ''; + preFixup = lib.optionalString stdenv.hostPlatform.isDarwin '' + fixDarwinDylibNames $(find "$out" -name "*.so.*") + ''; - postInstall = '' - unzip '${src-doc}' - install -m 644 INCHI-1-DOC/*.pdf $doc/share - ''; + postInstall = '' + unzip '${src-doc}' + install -m 644 INCHI-1-DOC/*.pdf $doc/share + ''; - meta = with lib; { - homepage = "https://www.inchi-trust.org/"; - description = "IUPAC International Chemical Identifier library"; - license = licenses.lgpl2Plus; - maintainers = with maintainers; [ rmcgibbo ]; - }; - } + meta = with lib; { + homepage = "https://www.inchi-trust.org/"; + description = "IUPAC International Chemical Identifier library"; + license = licenses.lgpl2Plus; + maintainers = with maintainers; [ rmcgibbo ]; + }; +} diff --git a/pkgs/by-name/in/incron/package.nix b/pkgs/by-name/in/incron/package.nix index bf0299de20300a..9c1a1a5f4c60dd 100644 --- a/pkgs/by-name/in/incron/package.nix +++ b/pkgs/by-name/in/incron/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, bash, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + bash, + nixosTests, +}: stdenv.mkDerivation rec { pname = "incron"; diff --git a/pkgs/by-name/in/indent/package.nix b/pkgs/by-name/in/indent/package.nix index 8a371a56a3ff3c..9d5647d8790c98 100644 --- a/pkgs/by-name/in/indent/package.nix +++ b/pkgs/by-name/in/indent/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, libintl -, texinfo -, buildPackages -, pkgsStatic +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libintl, + texinfo, + buildPackages, + pkgsStatic, }: stdenv.mkDerivation rec { @@ -45,7 +46,9 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = toString ( lib.optional stdenv.cc.isClang "-Wno-implicit-function-declaration" - ++ lib.optional (stdenv.cc.isClang && lib.versionAtLeast (lib.getVersion stdenv.cc) "13") "-Wno-unused-but-set-variable" + ++ lib.optional ( + stdenv.cc.isClang && lib.versionAtLeast (lib.getVersion stdenv.cc) "13" + ) "-Wno-unused-but-set-variable" ); hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/in/indicator-sound-switcher/package.nix b/pkgs/by-name/in/indicator-sound-switcher/package.nix index cb8439305c681f..c362607311078f 100644 --- a/pkgs/by-name/in/indicator-sound-switcher/package.nix +++ b/pkgs/by-name/in/indicator-sound-switcher/package.nix @@ -1,15 +1,18 @@ -{ python3Packages -, lib -, fetchFromGitHub -, gettext -, gtk3 -, gobject-introspection -, intltool, wrapGAppsHook3, glib -, librsvg -, libayatana-appindicator -, libpulseaudio -, keybinder3 -, gdk-pixbuf +{ + python3Packages, + lib, + fetchFromGitHub, + gettext, + gtk3, + gobject-introspection, + intltool, + wrapGAppsHook3, + glib, + librsvg, + libayatana-appindicator, + libpulseaudio, + keybinder3, + gdk-pixbuf, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/in/industrializer/package.nix b/pkgs/by-name/in/industrializer/package.nix index ba7099a0d603dc..a17f3c44896460 100644 --- a/pkgs/by-name/in/industrializer/package.nix +++ b/pkgs/by-name/in/industrializer/package.nix @@ -1,16 +1,18 @@ -{ lib, stdenv -, fetchurl -, alsa-lib -, audiofile -, autoconf -, automake -, gnome2 -, gtk2 -, libGL -, libjack2 -, libtool -, libxml2 -, pkg-config +{ + lib, + stdenv, + fetchurl, + alsa-lib, + audiofile, + autoconf, + automake, + gnome2, + gtk2, + libGL, + libjack2, + libtool, + libxml2, + pkg-config, }: stdenv.mkDerivation rec { @@ -21,7 +23,11 @@ stdenv.mkDerivation rec { sha256 = "0k688k2wppam351by7cp9m7an09yligzd89padr8viqy63gkdk6v"; }; - nativeBuildInputs = [ pkg-config autoconf automake ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; buildInputs = [ alsa-lib diff --git a/pkgs/by-name/in/inetutils/package.nix b/pkgs/by-name/in/inetutils/package.nix index a8638df3914ad1..53c8a2de9bc456 100644 --- a/pkgs/by-name/in/inetutils/package.nix +++ b/pkgs/by-name/in/inetutils/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchurl -, ncurses -, perl -, help2man -, apparmorRulesFromClosure -, libxcrypt -, util-linux +{ + stdenv, + lib, + fetchurl, + ncurses, + perl, + help2man, + apparmorRulesFromClosure, + libxcrypt, + util-linux, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { hash = "sha256-h2l9YKMeELXLhqnwZR4ex77pgyDQSMBzlDGqw9V2T7Y="; }; - outputs = ["out" "apparmor"]; + outputs = [ + "out" + "apparmor" + ]; patches = [ # https://git.congatec.com/yocto/meta-openembedded/commit/3402bfac6b595c622e4590a8ff5eaaa854e2a2a3 @@ -26,8 +30,14 @@ stdenv.mkDerivation rec { ]; strictDeps = true; - nativeBuildInputs = [ help2man perl /* for `whois' */ ]; - buildInputs = [ ncurses /* for `talk' */ libxcrypt ]; + nativeBuildInputs = [ + help2man + perl # for `whois' + ]; + buildInputs = [ + ncurses # for `talk' + libxcrypt + ]; env = lib.optionalAttrs stdenv.hostPlatform.isDarwin { # This is a temporary workaround for missing headers in the 10.12 SDK to avoid a mass rebuild. @@ -38,19 +48,24 @@ stdenv.mkDerivation rec { # Don't use help2man if cross-compiling # https://lists.gnu.org/archive/html/bug-sed/2017-01/msg00001.html # https://git.congatec.com/yocto/meta-openembedded/blob/3402bfac6b595c622e4590a8ff5eaaa854e2a2a3/meta-networking/recipes-connectivity/inetutils/inetutils_1.9.1.bb#L44 - preConfigure = let - isCross = stdenv.hostPlatform != stdenv.buildPlatform; - in lib.optionalString isCross '' - export HELP2MAN=true - ''; + preConfigure = + let + isCross = stdenv.hostPlatform != stdenv.buildPlatform; + in + lib.optionalString isCross '' + export HELP2MAN=true + ''; - configureFlags = [ "--with-ncurses-include-dir=${ncurses.dev}/include" ] - ++ lib.optionals stdenv.hostPlatform.isMusl [ # Musl doesn't define rcmd - "--disable-rcp" - "--disable-rsh" - "--disable-rlogin" - "--disable-rexec" - ] ++ lib.optional stdenv.hostPlatform.isDarwin "--disable-servers"; + configureFlags = + [ "--with-ncurses-include-dir=${ncurses.dev}/include" ] + ++ lib.optionals stdenv.hostPlatform.isMusl [ + # Musl doesn't define rcmd + "--disable-rcp" + "--disable-rsh" + "--disable-rlogin" + "--disable-rexec" + ] + ++ lib.optional stdenv.hostPlatform.isDarwin "--disable-servers"; doCheck = true; @@ -63,7 +78,7 @@ stdenv.mkDerivation rec { include include include - include "${apparmorRulesFromClosure { name = "ping"; } [stdenv.cc.libc]}" + include "${apparmorRulesFromClosure { name = "ping"; } [ stdenv.cc.libc ]}" include capability net_raw, network inet raw, diff --git a/pkgs/by-name/in/infamousPlugins/package.nix b/pkgs/by-name/in/infamousPlugins/package.nix index 062431bd4080a8..29df008ab9da85 100644 --- a/pkgs/by-name/in/infamousPlugins/package.nix +++ b/pkgs/by-name/in/infamousPlugins/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, cairomm -, cmake -, lv2 -, libpthreadstubs -, libXdmcp -, libXft -, ntk -, pcre -, fftwFloat -, zita-resampler +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cairomm, + cmake, + lv2, + libpthreadstubs, + libXdmcp, + libXft, + ntk, + pcre, + fftwFloat, + zita-resampler, }: stdenv.mkDerivation rec { @@ -25,8 +26,21 @@ stdenv.mkDerivation rec { sha256 = "sha256-AhW4hLmCxz7yHMdxM6kOvtCXk1jEg/XtyPgt4yk1xqs="; }; - nativeBuildInputs = [ pkg-config cmake ]; - buildInputs = [ cairomm lv2 libpthreadstubs libXdmcp libXft ntk pcre fftwFloat zita-resampler ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; + buildInputs = [ + cairomm + lv2 + libpthreadstubs + libXdmcp + libXft + ntk + pcre + fftwFloat + zita-resampler + ]; meta = with lib; { homepage = "https://ssj71.github.io/infamousPlugins"; diff --git a/pkgs/by-name/in/inflow/package.nix b/pkgs/by-name/in/inflow/package.nix index 8545c48071b894..32416963105d55 100644 --- a/pkgs/by-name/in/inflow/package.nix +++ b/pkgs/by-name/in/inflow/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, runCommand, inflow, diffutils }: +{ + lib, + stdenv, + fetchFromGitHub, + runCommand, + inflow, + diffutils, +}: stdenv.mkDerivation rec { pname = "inflow"; @@ -28,41 +35,43 @@ stdenv.mkDerivation rec { ''; passthru.tests = { - reflowWithLineLength = runCommand "${pname}-test" - { - nativeBuildInputs = [ inflow ]; - buildInputs = [ diffutils ]; - } '' - cat < input.txt - xxxxx xxx xxx xxxx xxxxxxxxx xx x xxxxxxxxx x xxxx xxxx xxxxxxx xxxxxxxx xxx - xxxxxxxxx xxxxxxxx xx xx xxxxx xxxxx xxxx xx x xxxx xx xxxxxxxx xxxxxxxx xxxx - xxx xxxx xxxx xxx xxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxx xxx xxxxx xx xxxx x xxxx - xxxxxxxx xxxx xxxx xx xxxxx xxxx xxxxx xxxx xxxxxxxxx xxx xxxxxxxxxxx xxxxxx - xxx xxxxxxxxx xxxx xxxx xx x xx xxxx xxx xxxx xx xxx xxx xxxxxxxxxxx xxxx xxxxx - x xxxxx xxxxxxx xxxxxxx xx xx xxxxxx xx xxxxx - EOF + reflowWithLineLength = + runCommand "${pname}-test" + { + nativeBuildInputs = [ inflow ]; + buildInputs = [ diffutils ]; + } + '' + cat < input.txt + xxxxx xxx xxx xxxx xxxxxxxxx xx x xxxxxxxxx x xxxx xxxx xxxxxxx xxxxxxxx xxx + xxxxxxxxx xxxxxxxx xx xx xxxxx xxxxx xxxx xx x xxxx xx xxxxxxxx xxxxxxxx xxxx + xxx xxxx xxxx xxx xxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxx xxx xxxxx xx xxxx x xxxx + xxxxxxxx xxxx xxxx xx xxxxx xxxx xxxxx xxxx xxxxxxxxx xxx xxxxxxxxxxx xxxxxx + xxx xxxxxxxxx xxxx xxxx xx x xx xxxx xxx xxxx xx xxx xxx xxxxxxxxxxx xxxx xxxxx + x xxxxx xxxxxxx xxxxxxx xx xx xxxxxx xx xxxxx + EOF - inflow 72 < input.txt > actual.txt + inflow 72 < input.txt > actual.txt - cat < expected.txt - xxxxx xxx xxx xxxx xxxxxxxxx xx x xxxxxxxxx x xxxx xxxx xxxxxxx - xxxxxxxx xxx xxxxxxxxx xxxxxxxx xx xx xxxxx xxxxx xxxx xx x xxxx - xx xxxxxxxx xxxxxxxx xxxx xxx xxxx xxxx xxx xxxxxxxxxxxxxxxxxxx - xxxxxxxxxxxxx xxx xxxxx xx xxxx x xxxx xxxxxxxx xxxx xxxx xx xxxxx - xxxx xxxxx xxxx xxxxxxxxx xxx xxxxxxxxxxx xxxxxx xxx xxxxxxxxx - xxxx xxxx xx x xx xxxx xxx xxxx xx xxx xxx xxxxxxxxxxx xxxx xxxxx - x xxxxx xxxxxxx xxxxxxx xx xx xxxxxx xx xxxxx - EOF + cat < expected.txt + xxxxx xxx xxx xxxx xxxxxxxxx xx x xxxxxxxxx x xxxx xxxx xxxxxxx + xxxxxxxx xxx xxxxxxxxx xxxxxxxx xx xx xxxxx xxxxx xxxx xx x xxxx + xx xxxxxxxx xxxxxxxx xxxx xxx xxxx xxxx xxx xxxxxxxxxxxxxxxxxxx + xxxxxxxxxxxxx xxx xxxxx xx xxxx x xxxx xxxxxxxx xxxx xxxx xx xxxxx + xxxx xxxxx xxxx xxxxxxxxx xxx xxxxxxxxxxx xxxxxx xxx xxxxxxxxx + xxxx xxxx xx x xx xxxx xxx xxxx xx xxx xxx xxxxxxxxxxx xxxx xxxxx + x xxxxx xxxxxxx xxxxxxx xx xx xxxxxx xx xxxxx + EOF - if ! cmp --silent expected.txt actual.txt - then - echo "Error: actual.txt and expected.txt are different" - diff actual.txt expected.txt - exit 1 - fi + if ! cmp --silent expected.txt actual.txt + then + echo "Error: actual.txt and expected.txt are different" + diff actual.txt expected.txt + exit 1 + fi - touch $out - ''; + touch $out + ''; }; meta = with lib; { diff --git a/pkgs/by-name/in/influxdb-cxx/package.nix b/pkgs/by-name/in/influxdb-cxx/package.nix index 4859df6adf7993..de1ae626c49b3f 100644 --- a/pkgs/by-name/in/influxdb-cxx/package.nix +++ b/pkgs/by-name/in/influxdb-cxx/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, boost, catch2_3, libcpr_1_10_5, trompeloeil }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + boost, + catch2_3, + libcpr_1_10_5, + trompeloeil, +}: stdenv.mkDerivation (finalAttrs: { pname = "influxdb-cxx"; @@ -17,8 +27,15 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ cmake ]; - buildInputs = [ boost libcpr_1_10_5 ] - ++ lib.optionals finalAttrs.finalPackage.doCheck [ catch2_3 trompeloeil ]; + buildInputs = + [ + boost + libcpr_1_10_5 + ] + ++ lib.optionals finalAttrs.finalPackage.doCheck [ + catch2_3 + trompeloeil + ]; cmakeFlags = [ (lib.cmakeBool "INFLUXCXX_TESTING" finalAttrs.finalPackage.doCheck) diff --git a/pkgs/by-name/in/infnoise/package.nix b/pkgs/by-name/in/infnoise/package.nix index e2f117e1e8c499..c596f9e76c7966 100644 --- a/pkgs/by-name/in/infnoise/package.nix +++ b/pkgs/by-name/in/infnoise/package.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, libftdi -, testers }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + libftdi, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "infnoise"; @@ -54,7 +60,10 @@ stdenv.mkDerivation (finalAttrs: { It can either provide rng for userland applications, or provide rng for the OS entropy. ''; license = licenses.cc0; - maintainers = with maintainers; [ StijnDW zhaofengli ]; + maintainers = with maintainers; [ + StijnDW + zhaofengli + ]; platforms = platforms.linux; }; }) diff --git a/pkgs/by-name/in/inform7/package.nix b/pkgs/by-name/in/inform7/package.nix index b4b97af5241720..2ba67a1f6ed333 100644 --- a/pkgs/by-name/in/inform7/package.nix +++ b/pkgs/by-name/in/inform7/package.nix @@ -1,10 +1,24 @@ -{ lib, stdenv, fetchzip, coreutils, perl, gnutar, gzip }: +{ + lib, + stdenv, + fetchzip, + coreutils, + perl, + gnutar, + gzip, +}: let version = "6M62"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "inform7"; inherit version; - buildInputs = [ perl coreutils gnutar gzip ]; + buildInputs = [ + perl + coreutils + gnutar + gzip + ]; src = fetchzip { url = "http://inform7.com/download/content/6M62/I7_6M62_Linux_all.tar.gz"; sha256 = "0bk0pfymvsn1g8ci0pfdw7dgrlzb232a8pc67y2xk6zgpf3m41vj"; @@ -29,6 +43,8 @@ in stdenv.mkDerivation { maintainers = with maintainers; [ mbbx6spp ]; platforms = platforms.unix; # never built on aarch64-darwin since first introduction in nixpkgs - broken = (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) || (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64); + broken = + (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) + || (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64); }; } diff --git a/pkgs/by-name/in/infra-arcana/package.nix b/pkgs/by-name/in/infra-arcana/package.nix index 609bb192c28a44..bbe5e0f262b959 100644 --- a/pkgs/by-name/in/infra-arcana/package.nix +++ b/pkgs/by-name/in/infra-arcana/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitLab, cmake, makeWrapper, SDL2, SDL2_image, SDL2_mixer +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + makeWrapper, + SDL2, + SDL2_image, + SDL2_mixer, }: stdenv.mkDerivation rec { @@ -12,8 +20,15 @@ stdenv.mkDerivation rec { hash = "sha256-MI+wH0+1f41JYXT2hzDs3RrrR3eTfOzgtCa5T6m8oQc="; }; - nativeBuildInputs = [ cmake makeWrapper ]; - buildInputs = [ SDL2 SDL2_image SDL2_mixer ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; + buildInputs = [ + SDL2 + SDL2_image + SDL2_mixer + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/in/infra/package.nix b/pkgs/by-name/in/infra/package.nix index 996bb80d98c961..e42727704b2d17 100644 --- a/pkgs/by-name/in/infra/package.nix +++ b/pkgs/by-name/in/infra/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "infra"; @@ -15,7 +19,10 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Infra manages access to infrastructure such as Kubernetes"; diff --git a/pkgs/by-name/in/infracost/package.nix b/pkgs/by-name/in/infracost/package.nix index 58842ba6b55d8c..ab848711f600b0 100644 --- a/pkgs/by-name/in/infracost/package.nix +++ b/pkgs/by-name/in/infracost/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "infracost"; @@ -12,7 +17,11 @@ buildGoModule rec { }; vendorHash = "sha256-bLSj4/+7h0uHdR956VL4iLqRddKV5Ac+FIL1zJxPCW8="; - ldflags = [ "-s" "-w" "-X github.com/infracost/infracost/internal/version.Version=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/infracost/infracost/internal/version.Version=v${version}" + ]; subPackages = [ "cmd/infracost" ]; @@ -62,7 +71,11 @@ buildGoModule rec { compare different deployment options upfront. ''; license = licenses.asl20; - maintainers = with maintainers; [ davegallant jk kashw2 ]; + maintainers = with maintainers; [ + davegallant + jk + kashw2 + ]; mainProgram = "infracost"; }; } diff --git a/pkgs/by-name/in/inframap/package.nix b/pkgs/by-name/in/inframap/package.nix index e1aca0a9301b5c..ddfe0ce63dcd56 100644 --- a/pkgs/by-name/in/inframap/package.nix +++ b/pkgs/by-name/in/inframap/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { pname = "inframap"; diff --git a/pkgs/by-name/in/ingress2gateway/package.nix b/pkgs/by-name/in/ingress2gateway/package.nix index 66200676793b8d..03799ae2faf5ac 100644 --- a/pkgs/by-name/in/ingress2gateway/package.nix +++ b/pkgs/by-name/in/ingress2gateway/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-T6I8uYUaubcc1dfDu6PbQ9bDDLqGuLGXWnCZhdvkycE="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Convert Ingress resources to Gateway API resources"; diff --git a/pkgs/by-name/in/inhibridge/package.nix b/pkgs/by-name/in/inhibridge/package.nix index 4340d4a3e8696f..2f9c47f7e5c8e9 100644 --- a/pkgs/by-name/in/inhibridge/package.nix +++ b/pkgs/by-name/in/inhibridge/package.nix @@ -22,8 +22,7 @@ rustPlatform.buildRustPackage rec { description = "Simple daemon that bridges freedesktop.org ScreenSaver inhibitions to systemd-inhibit"; platforms = platforms.linux; license = licenses.agpl3Plus; - maintainers = with maintainers; [Scrumplex]; + maintainers = with maintainers; [ Scrumplex ]; mainProgram = "inhibridge"; }; } - diff --git a/pkgs/by-name/in/inih/package.nix b/pkgs/by-name/in/inih/package.nix index 91d27fbc675c49..6aa6cb2a340d01 100644 --- a/pkgs/by-name/in/inih/package.nix +++ b/pkgs/by-name/in/inih/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, +}: stdenv.mkDerivation rec { pname = "inih"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-b2f6hQvkmWgni/zdfv3I1b9ypd7zSyEBv/JVBA6K7/w="; }; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; meta = with lib; { description = "Simple .INI file parser in C, good for embedded systems"; diff --git a/pkgs/by-name/in/initool/package.nix b/pkgs/by-name/in/initool/package.nix index ea4659a5e663b4..3700790a8ddaa3 100644 --- a/pkgs/by-name/in/initool/package.nix +++ b/pkgs/by-name/in/initool/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, mlton -, lib -, fetchFromGitHub +{ + stdenv, + mlton, + lib, + fetchFromGitHub, }: stdenv.mkDerivation rec { @@ -39,4 +40,3 @@ stdenv.mkDerivation rec { changelog = "https://github.com/dbohdan/initool/releases/tag/v${version}"; }; } - diff --git a/pkgs/by-name/in/ink/package.nix b/pkgs/by-name/in/ink/package.nix index d8f13d795c8260..958d3296ad73ef 100644 --- a/pkgs/by-name/in/ink/package.nix +++ b/pkgs/by-name/in/ink/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libinklevel }: +{ + lib, + stdenv, + fetchurl, + libinklevel, +}: stdenv.mkDerivation rec { pname = "ink"; @@ -13,7 +18,10 @@ stdenv.mkDerivation rec { libinklevel ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; meta = with lib; { description = "Command line tool for checking the ink level of your locally connected printer"; diff --git a/pkgs/by-name/in/inklecate/deps.nix b/pkgs/by-name/in/inklecate/deps.nix index f3a17967e25c81..dbfecc1b26058f 100644 --- a/pkgs/by-name/in/inklecate/deps.nix +++ b/pkgs/by-name/in/inklecate/deps.nix @@ -1,5 +1,6 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ +{ fetchNuGet }: +[ ] diff --git a/pkgs/by-name/in/inklingreader/package.nix b/pkgs/by-name/in/inklingreader/package.nix index 55596ba4899920..e4ba8a252cdeca 100644 --- a/pkgs/by-name/in/inklingreader/package.nix +++ b/pkgs/by-name/in/inklingreader/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, gtk3 -, librsvg -, libusb1 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + gtk3, + librsvg, + libusb1, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/in/inko/package.nix b/pkgs/by-name/in/inko/package.nix index a623379d09152f..4cc7902c4bdc40 100644 --- a/pkgs/by-name/in/inko/package.nix +++ b/pkgs/by-name/in/inko/package.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, llvm_16 -, libffi -, libz -, libxml2 -, ncurses -, stdenv -, makeWrapper -, callPackage +{ + lib, + rustPlatform, + fetchFromGitHub, + llvm_16, + libffi, + libz, + libxml2, + ncurses, + stdenv, + makeWrapper, + callPackage, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/in/inko/test.nix b/pkgs/by-name/in/inko/test.nix index 8d63dd07ccac68..4b6d637de3fff6 100644 --- a/pkgs/by-name/in/inko/test.nix +++ b/pkgs/by-name/in/inko/test.nix @@ -1,35 +1,38 @@ -{ inko -, writeText -, runCommand -, ... +{ + inko, + writeText, + runCommand, + ... }: let - source = writeText "hello.inko" /* inko */ '' - import std.process (sleep) - import std.stdio (STDOUT) - import std.time (Duration) + source = + writeText "hello.inko" # inko + '' + import std.process (sleep) + import std.stdio (STDOUT) + import std.time (Duration) - class async Printer { - fn async print(message: String, channel: Channel[Nil]) { - let _ = STDOUT.new.print(message) + class async Printer { + fn async print(message: String, channel: Channel[Nil]) { + let _ = STDOUT.new.print(message) - channel.send(nil) - } - } + channel.send(nil) + } + } - class async Main { - fn async main { - let channel = Channel.new(size: 2) + class async Main { + fn async main { + let channel = Channel.new(size: 2) - Printer().print('Hello', channel) - Printer().print('world', channel) + Printer().print('Hello', channel) + Printer().print('world', channel) - channel.receive - channel.receive - } - } - ''; + channel.receive + channel.receive + } + } + ''; in runCommand "inko-test" { } '' diff --git a/pkgs/by-name/in/innoextract/package.nix b/pkgs/by-name/in/innoextract/package.nix index e2e3ddcdc3e73c..34bd0f083c9fc1 100644 --- a/pkgs/by-name/in/innoextract/package.nix +++ b/pkgs/by-name/in/innoextract/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, cmake -, makeWrapper -, boost -, xz -, libiconv -, withGog ? false -, unar ? null +{ + lib, + stdenv, + fetchurl, + cmake, + makeWrapper, + boost, + xz, + libiconv, + withGog ? false, + unar ? null, }: stdenv.mkDerivation rec { @@ -19,13 +20,18 @@ stdenv.mkDerivation rec { sha256 = "09l1z1nbl6ijqqwszdwch9mqr54qb7df0wp2sd77v17dq6gsci33"; }; - buildInputs = [ xz boost ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; + buildInputs = [ + xz + boost + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; # Python is reported as missing during the build, however # including Python does not change the output. - nativeBuildInputs = [ cmake makeWrapper ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; strictDeps = true; diff --git a/pkgs/by-name/in/inormalize/package.nix b/pkgs/by-name/in/inormalize/package.nix index bf24f0ce19bf94..a39d8868fe025e 100644 --- a/pkgs/by-name/in/inormalize/package.nix +++ b/pkgs/by-name/in/inormalize/package.nix @@ -1,30 +1,53 @@ -{ lib, stdenv, fetchFromGitHub, cmake, makeWrapper, +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + makeWrapper, perlPackages, - libminc, ebtks }: + libminc, + ebtks, +}: stdenv.mkDerivation rec { pname = "inormalize"; - version = "unstable-2014-10-21"; + version = "unstable-2014-10-21"; src = fetchFromGitHub { - owner = "BIC-MNI"; - repo = pname; - rev = "79cea9cdfe7b99abfd40afda89ab2253b596ad2f"; + owner = "BIC-MNI"; + repo = pname; + rev = "79cea9cdfe7b99abfd40afda89ab2253b596ad2f"; sha256 = "1ahqv5q0ljvji99a5q8azjkdf6bgp6nr8lwivkqwqs3jm0k5clq7"; }; - patches = [ ./lgmask-interp.patch ./nu_correct_norm-interp.patch ]; + patches = [ + ./lgmask-interp.patch + ./nu_correct_norm-interp.patch + ]; postPatch = '' substituteInPlace inormalize.cc \ --replace "clamp" "::clamp" ''; - nativeBuildInputs = [ cmake makeWrapper ]; - buildInputs = [ libminc ebtks ]; - propagatedBuildInputs = with perlPackages; [ perl GetoptTabular MNI-Perllib ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; + buildInputs = [ + libminc + ebtks + ]; + propagatedBuildInputs = with perlPackages; [ + perl + GetoptTabular + MNI-Perllib + ]; - cmakeFlags = [ "-DLIBMINC_DIR=${libminc}/lib/cmake" "-DEBTKS_DIR=${ebtks}/lib/" ]; + cmakeFlags = [ + "-DLIBMINC_DIR=${libminc}/lib/cmake" + "-DEBTKS_DIR=${ebtks}/lib/" + ]; postFixup = '' for p in $out/bin/*; do @@ -37,6 +60,6 @@ stdenv.mkDerivation rec { description = "Program to normalize intensity of MINC files"; maintainers = with maintainers; [ bcdarwin ]; platforms = platforms.unix; - license = licenses.free; + license = licenses.free; }; } diff --git a/pkgs/by-name/in/inotify-info/package.nix b/pkgs/by-name/in/inotify-info/package.nix index 21de48577df68e..feae128221705b 100644 --- a/pkgs/by-name/in/inotify-info/package.nix +++ b/pkgs/by-name/in/inotify-info/package.nix @@ -14,9 +14,9 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-mxZpJMmSCgm5uV5/wknVb1PdxRIF/b2k+6rdOh4b8zA="; }; - buildFlags = ["INOTIFYINFO_VERSION=v${finalAttrs.version}"]; + buildFlags = [ "INOTIFYINFO_VERSION=v${finalAttrs.version}" ]; - installFlags = ["PREFIX=$$out"]; + installFlags = [ "PREFIX=$$out" ]; meta = with lib; { description = "Easily track down the number of inotify watches, instances, and which files are being watched"; diff --git a/pkgs/by-name/in/inotify-tools/package.nix b/pkgs/by-name/in/inotify-tools/package.nix index e8536ea784f36b..10c48bffe7c056 100644 --- a/pkgs/by-name/in/inotify-tools/package.nix +++ b/pkgs/by-name/in/inotify-tools/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, autoreconfHook, fetchFromGitHub, nix-update-script, fanotifySupport ? true }: +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + nix-update-script, + fanotifySupport ? true, +}: stdenv.mkDerivation (finalAttrs: { pname = "inotify-tools"; @@ -24,7 +31,11 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { homepage = "https://github.com/inotify-tools/inotify-tools/wiki"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ marcweber pSub shamilton ]; + maintainers = with maintainers; [ + marcweber + pSub + shamilton + ]; platforms = platforms.linux; }; }) diff --git a/pkgs/by-name/in/inputplug/package.nix b/pkgs/by-name/in/inputplug/package.nix index c14ff710d4a7ff..d2441969cc62dc 100644 --- a/pkgs/by-name/in/inputplug/package.nix +++ b/pkgs/by-name/in/inputplug/package.nix @@ -1,10 +1,11 @@ -{ fetchCrate -, installShellFiles -, lib -, libbsd -, pkg-config -, rustPlatform -, stdenv +{ + fetchCrate, + installShellFiles, + lib, + libbsd, + pkg-config, + rustPlatform, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -16,7 +17,10 @@ rustPlatform.buildRustPackage rec { hash = "sha256-8Gy0h0QMcittnjuKm+atIJNsY2d6Ua29oab4fkUU+wE="; }; - nativeBuildInputs = [ installShellFiles pkg-config ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + ]; buildInputs = [ libbsd ]; @@ -37,4 +41,3 @@ rustPlatform.buildRustPackage rec { mainProgram = "inputplug"; }; } - diff --git a/pkgs/by-name/in/inql/package.nix b/pkgs/by-name/in/inql/package.nix index 6f9a6e29f2e0ec..4854dd1d72e005 100644 --- a/pkgs/by-name/in/inql/package.nix +++ b/pkgs/by-name/in/inql/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/in/inriafonts/package.nix b/pkgs/by-name/in/inriafonts/package.nix index 1ca1ce2f909881..4504c41967b606 100644 --- a/pkgs/by-name/in/inriafonts/package.nix +++ b/pkgs/by-name/in/inriafonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "inriafonts"; diff --git a/pkgs/by-name/in/inshellisense/package.nix b/pkgs/by-name/in/inshellisense/package.nix index 115639aba3d322..9c013a592bcaeb 100644 --- a/pkgs/by-name/in/inshellisense/package.nix +++ b/pkgs/by-name/in/inshellisense/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, buildNpmPackage, fetchFromGitHub, cacert }: +{ + lib, + stdenv, + buildNpmPackage, + fetchFromGitHub, + cacert, +}: buildNpmPackage rec { pname = "inshellisense"; @@ -30,4 +36,3 @@ buildNpmPackage rec { maintainers = [ maintainers.malo ]; }; } - diff --git a/pkgs/by-name/in/insomnia/package.nix b/pkgs/by-name/in/insomnia/package.nix index 2e886e195c497b..80458fc41d0af8 100644 --- a/pkgs/by-name/in/insomnia/package.nix +++ b/pkgs/by-name/in/insomnia/package.nix @@ -2,22 +2,25 @@ lib, stdenv, fetchurl, - appimageTools + appimageTools, }: let pname = "insomnia"; version = "10.0.0"; - src = fetchurl { - x86_64-darwin = { - url = "https://github.com/Kong/insomnia/releases/download/core%40${version}/Insomnia.Core-${version}.dmg"; - hash = "sha256-HYEZzLDV2T4ugCjIeskS5SkrQlu5nQt1S0RG9R/rlcs="; - }; - x86_64-linux = { - url = "https://github.com/Kong/insomnia/releases/download/core%40${version}/Insomnia.Core-${version}.AppImage"; - hash = "sha256-hElisKB1C1By8lCCgNqNr6bIOMKqMG3UyBQ6jYu8yNg="; - }; - }.${stdenv.system} or (throw "Unsupported system: ${stdenv.system}"); + src = + fetchurl + { + x86_64-darwin = { + url = "https://github.com/Kong/insomnia/releases/download/core%40${version}/Insomnia.Core-${version}.dmg"; + hash = "sha256-HYEZzLDV2T4ugCjIeskS5SkrQlu5nQt1S0RG9R/rlcs="; + }; + x86_64-linux = { + url = "https://github.com/Kong/insomnia/releases/download/core%40${version}/Insomnia.Core-${version}.AppImage"; + hash = "sha256-hElisKB1C1By8lCCgNqNr6bIOMKqMG3UyBQ6jYu8yNg="; + }; + } + .${stdenv.system} or (throw "Unsupported system: ${stdenv.system}"); meta = with lib; { homepage = "https://insomnia.rest"; @@ -25,51 +28,73 @@ let mainProgram = "insomnia"; changelog = "https://github.com/Kong/insomnia/releases/tag/core@${version}"; license = licenses.asl20; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; - maintainers = with maintainers; [ markus1189 kashw2 DataHearth ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; + maintainers = with maintainers; [ + markus1189 + kashw2 + DataHearth + ]; }; in -if stdenv.hostPlatform.isDarwin then stdenv.mkDerivation { - inherit pname version src meta; +if stdenv.hostPlatform.isDarwin then + stdenv.mkDerivation { + inherit + pname + version + src + meta + ; sourceRoot = "."; unpackCmd = '' - echo "Creating temp directory" - mnt=$(TMPDIR=/tmp mktemp -d -t nix-XXXXXXXXXX) - function finish { - echo "Ejecting temp directory" - /usr/bin/hdiutil detach $mnt -force - rm -rf $mnt - } - # Detach volume when receiving SIG "0" - trap finish EXIT - # Mount DMG file - echo "Mounting DMG file into \"$mnt\"" - /usr/bin/hdiutil attach -nobrowse -mountpoint $mnt $curSrc - # Copy content to local dir for later use - echo 'Copying extracted content into "sourceRoot"' - cp -a $mnt/Insomnia.app $PWD/ - ''; + echo "Creating temp directory" + mnt=$(TMPDIR=/tmp mktemp -d -t nix-XXXXXXXXXX) + function finish { + echo "Ejecting temp directory" + /usr/bin/hdiutil detach $mnt -force + rm -rf $mnt + } + # Detach volume when receiving SIG "0" + trap finish EXIT + # Mount DMG file + echo "Mounting DMG file into \"$mnt\"" + /usr/bin/hdiutil attach -nobrowse -mountpoint $mnt $curSrc + # Copy content to local dir for later use + echo 'Copying extracted content into "sourceRoot"' + cp -a $mnt/Insomnia.app $PWD/ + ''; - installPhase = '' - runHook preInstall - mkdir -p "$out/Applications" - mv Insomnia.app $out/Applications/ - runHook postInstall - ''; -} else appimageTools.wrapType2 { - inherit pname version src meta; + installPhase = '' + runHook preInstall + mkdir -p "$out/Applications" + mv Insomnia.app $out/Applications/ + runHook postInstall + ''; + } +else + appimageTools.wrapType2 { + inherit + pname + version + src + meta + ; - extraInstallCommands = let - appimageContents = appimageTools.extract { - inherit pname version src; - }; - in '' - # Install XDG Desktop file and its icon - install -Dm444 ${appimageContents}/insomnia.desktop -t $out/share/applications - install -Dm444 ${appimageContents}/insomnia.png -t $out/share/pixmaps - # Replace wrong exec statement in XDG Desktop file - substituteInPlace $out/share/applications/insomnia.desktop \ - --replace-fail 'Exec=AppRun --no-sandbox %U' 'Exec=insomnia' - ''; -} + extraInstallCommands = + let + appimageContents = appimageTools.extract { + inherit pname version src; + }; + in + '' + # Install XDG Desktop file and its icon + install -Dm444 ${appimageContents}/insomnia.desktop -t $out/share/applications + install -Dm444 ${appimageContents}/insomnia.png -t $out/share/pixmaps + # Replace wrong exec statement in XDG Desktop file + substituteInPlace $out/share/applications/insomnia.desktop \ + --replace-fail 'Exec=AppRun --no-sandbox %U' 'Exec=insomnia' + ''; + } diff --git a/pkgs/by-name/in/instead/package.nix b/pkgs/by-name/in/instead/package.nix index 9a68983dc2041e..d5dd0588c01728 100644 --- a/pkgs/by-name/in/instead/package.nix +++ b/pkgs/by-name/in/instead/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, SDL2, SDL2_ttf, SDL2_image, SDL2_mixer, pkg-config, lua, zlib, unzip }: +{ + lib, + stdenv, + fetchurl, + SDL2, + SDL2_ttf, + SDL2_image, + SDL2_mixer, + pkg-config, + lua, + zlib, + unzip, +}: let # I took several games at random from https://instead.syscall.ru/games/ @@ -37,8 +49,18 @@ stdenv.mkDerivation rec { NIX_LDFLAGS = "-llua -lgcc_s"; - nativeBuildInputs = [ pkg-config unzip ]; - buildInputs = [ SDL2 SDL2_ttf SDL2_image SDL2_mixer lua zlib ]; + nativeBuildInputs = [ + pkg-config + unzip + ]; + buildInputs = [ + SDL2 + SDL2_ttf + SDL2_image + SDL2_mixer + lua + zlib + ]; postPatch = '' substituteInPlace configure.sh \ diff --git a/pkgs/by-name/in/insulator2/package.nix b/pkgs/by-name/in/insulator2/package.nix index ad02d51aecdfc9..a3000e0fc5baa6 100644 --- a/pkgs/by-name/in/insulator2/package.nix +++ b/pkgs/by-name/in/insulator2/package.nix @@ -1,26 +1,27 @@ -{ lib -, cmake -, dbus -, fetchFromGitHub -, fetchYarnDeps -, openssl -, pkg-config -, freetype -, libsoup_2_4 -, gtk3 -, webkitgtk_4_0 -, perl -, cyrus_sasl -, stdenv -, yarnConfigHook -, nodejs-slim -, cargo-tauri_1 -, cargo -, rustPlatform -, rustc -, jq -, moreutils -, fetchpatch +{ + lib, + cmake, + dbus, + fetchFromGitHub, + fetchYarnDeps, + openssl, + pkg-config, + freetype, + libsoup_2_4, + gtk3, + webkitgtk_4_0, + perl, + cyrus_sasl, + stdenv, + yarnConfigHook, + nodejs-slim, + cargo-tauri_1, + cargo, + rustPlatform, + rustc, + jq, + moreutils, + fetchpatch, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/in/integresql/package.nix b/pkgs/by-name/in/integresql/package.nix index 409ef736d9e464..da724b573cdd47 100644 --- a/pkgs/by-name/in/integresql/package.nix +++ b/pkgs/by-name/in/integresql/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "integresql"; diff --git a/pkgs/by-name/in/intel-cmt-cat/package.nix b/pkgs/by-name/in/intel-cmt-cat/package.nix index 5e1302dedd92b0..0b356aa6d4c780 100644 --- a/pkgs/by-name/in/intel-cmt-cat/package.nix +++ b/pkgs/by-name/in/intel-cmt-cat/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { version = "24.05"; @@ -13,7 +17,10 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - makeFlags = [ "PREFIX=$(out)" "NOLDCONFIG=y" ]; + makeFlags = [ + "PREFIX=$(out)" + "NOLDCONFIG=y" + ]; meta = with lib; { description = "User space software for Intel(R) Resource Director Technology"; diff --git a/pkgs/by-name/in/intel-compute-runtime/package.nix b/pkgs/by-name/in/intel-compute-runtime/package.nix index 0eb33e124569e2..fdd669ad983eec 100644 --- a/pkgs/by-name/in/intel-compute-runtime/package.nix +++ b/pkgs/by-name/in/intel-compute-runtime/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, intel-gmmlib -, intel-graphics-compiler -, level-zero -, libva +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + intel-gmmlib, + intel-graphics-compiler, + level-zero, + libva, }: stdenv.mkDerivation rec { @@ -20,9 +21,17 @@ stdenv.mkDerivation rec { hash = "sha256-b7mHIet+zgbS0JfJLKvt9+xILWeuA2rvTAeXetlFz/w="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ intel-gmmlib intel-graphics-compiler libva level-zero ]; + buildInputs = [ + intel-gmmlib + intel-graphics-compiler + libva + level-zero + ]; cmakeFlags = [ "-DSKIP_UNIT_TESTS=1" @@ -32,7 +41,10 @@ stdenv.mkDerivation rec { "-DCMAKE_INSTALL_LIBDIR=lib" ]; - outputs = [ "out" "drivers" ]; + outputs = [ + "out" + "drivers" + ]; # causes redefinition of _FORTIFY_SOURCE hardeningDisable = [ "fortify3" ]; @@ -46,7 +58,14 @@ stdenv.mkDerivation rec { ''; postFixup = '' - patchelf --set-rpath ${lib.makeLibraryPath [ intel-gmmlib intel-graphics-compiler libva stdenv.cc.cc ]} \ + patchelf --set-rpath ${ + lib.makeLibraryPath [ + intel-gmmlib + intel-graphics-compiler + libva + stdenv.cc.cc + ] + } \ $out/lib/intel-opencl/libigdrcl.so ''; @@ -56,7 +75,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/intel/compute-runtime"; changelog = "https://github.com/intel/compute-runtime/releases/tag/${version}"; license = licenses.mit; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; maintainers = with maintainers; [ SuperSandro2000 ]; }; } diff --git a/pkgs/by-name/in/intel-gmmlib/package.nix b/pkgs/by-name/in/intel-gmmlib/package.nix index 6a475711bd7a17..e9ded9eeec1f9b 100644 --- a/pkgs/by-name/in/intel-gmmlib/package.nix +++ b/pkgs/by-name/in/intel-gmmlib/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -# for passthru.tests -, intel-compute-runtime -, intel-media-driver +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + # for passthru.tests + intel-compute-runtime, + intel-media-driver, }: stdenv.mkDerivation rec { @@ -33,7 +34,10 @@ stdenv.mkDerivation rec { and buffer management for the Intel(R) Graphics Compute Runtime for OpenCL(TM) and the Intel(R) Media Driver for VAAPI. ''; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = with maintainers; [ SuperSandro2000 ]; }; } diff --git a/pkgs/by-name/in/intel-gpu-tools/package.nix b/pkgs/by-name/in/intel-gpu-tools/package.nix index 7c26da46b20315..5bcc2385682dce 100644 --- a/pkgs/by-name/in/intel-gpu-tools/package.nix +++ b/pkgs/by-name/in/intel-gpu-tools/package.nix @@ -1,44 +1,45 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, -# build time -, bison -, docbook_xsl -, docutils -, flex -, gtk-doc -, meson -, ninja -, pkg-config -, utilmacros + # build time + bison, + docbook_xsl, + docutils, + flex, + gtk-doc, + meson, + ninja, + pkg-config, + utilmacros, -# runtime -, alsa-lib -, cairo -, curl -, elfutils -, glib -, gsl -, json_c -, kmod -, libdrm -, liboping -, libpciaccess -, libunwind -, libX11 -, libXext -, libXrandr -, libXv -, openssl -, peg -, procps -, python3 -, udev -, valgrind -, xmlrpc_c -, xorgproto + # runtime + alsa-lib, + cairo, + curl, + elfutils, + glib, + gsl, + json_c, + kmod, + libdrm, + liboping, + libpciaccess, + libunwind, + libX11, + libXext, + libXrandr, + libXv, + openssl, + peg, + procps, + python3, + udev, + valgrind, + xmlrpc_c, + xorgproto, }: stdenv.mkDerivation rec { @@ -111,7 +112,10 @@ stdenv.mkDerivation rec { homepage = "https://drm.pages.freedesktop.org/igt-gpu-tools/"; description = "Tools for development and testing of the Intel DRM driver"; license = licenses.mit; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = with maintainers; [ pSub ]; }; } diff --git a/pkgs/by-name/in/intel-graphics-compiler/package.nix b/pkgs/by-name/in/intel-graphics-compiler/package.nix index ef3ff5ff4565bc..851e5bac3bb504 100644 --- a/pkgs/by-name/in/intel-graphics-compiler/package.nix +++ b/pkgs/by-name/in/intel-graphics-compiler/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, bash -, cmake -, runCommandLocal -, bison -, flex -, intel-compute-runtime -, llvmPackages_14 -, opencl-clang -, python3 -, spirv-tools -, spirv-headers -, spirv-llvm-translator +{ + lib, + stdenv, + fetchFromGitHub, + bash, + cmake, + runCommandLocal, + bison, + flex, + intel-compute-runtime, + llvmPackages_14, + opencl-clang, + python3, + spirv-tools, + spirv-headers, + spirv-llvm-translator, -, buildWithPatches ? true + buildWithPatches ? true, }: let @@ -50,9 +51,26 @@ stdenv.mkDerivation rec { patchShebangs --build IGC/Scripts/igc_create_linker_script.sh ''; - nativeBuildInputs = [ bash bison cmake flex (python3.withPackages (ps : with ps; [ mako pyyaml ])) ]; + nativeBuildInputs = [ + bash + bison + cmake + flex + (python3.withPackages ( + ps: with ps; [ + mako + pyyaml + ] + )) + ]; - buildInputs = [ lld llvm spirv-headers spirv-llvm-translator' spirv-tools ]; + buildInputs = [ + lld + llvm + spirv-headers + spirv-llvm-translator' + spirv-tools + ]; strictDeps = true; diff --git a/pkgs/by-name/in/intel-media-driver/package.nix b/pkgs/by-name/in/intel-media-driver/package.nix index ded8e57cf16563..fc415cd682f0f8 100644 --- a/pkgs/by-name/in/intel-media-driver/package.nix +++ b/pkgs/by-name/in/intel-media-driver/package.nix @@ -1,24 +1,28 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, libva -, libpciaccess -, intel-gmmlib -, libdrm -, enableX11 ? stdenv.hostPlatform.isLinux -, libX11 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + libva, + libpciaccess, + intel-gmmlib, + libdrm, + enableX11 ? stdenv.hostPlatform.isLinux, + libX11, # for passhtru.tests -, pkgsi686Linux + pkgsi686Linux, }: stdenv.mkDerivation rec { pname = "intel-media-driver"; version = "24.3.4"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "intel"; @@ -43,12 +47,21 @@ stdenv.mkDerivation rec { "-DMEDIA_BUILD_FATAL_WARNINGS=OFF" ]; - env.NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.hostPlatform.system == "i686-linux") "-D_FILE_OFFSET_BITS=64"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.hostPlatform.system == "i686-linux" + ) "-D_FILE_OFFSET_BITS=64"; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ libva libpciaccess intel-gmmlib libdrm ] - ++ lib.optional enableX11 libX11; + buildInputs = [ + libva + libpciaccess + intel-gmmlib + libdrm + ] ++ lib.optional enableX11 libX11; postFixup = lib.optionalString enableX11 '' patchelf --set-rpath "$(patchelf --print-rpath $out/lib/dri/iHD_drv_video.so):${lib.makeLibraryPath [ libX11 ]}" \ @@ -68,7 +81,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://github.com/intel/media-driver"; changelog = "https://github.com/intel/media-driver/releases/tag/intel-media-${version}"; - license = with licenses; [ bsd3 mit ]; + license = with licenses; [ + bsd3 + mit + ]; platforms = platforms.linux; maintainers = with maintainers; [ SuperSandro2000 ]; }; diff --git a/pkgs/by-name/in/intel-media-sdk/package.nix b/pkgs/by-name/in/intel-media-sdk/package.nix index 37c0e7253ad1fe..26a77a7ed94e3b 100644 --- a/pkgs/by-name/in/intel-media-sdk/package.nix +++ b/pkgs/by-name/in/intel-media-sdk/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, gtest, libdrm, libpciaccess, libva, libX11 -, libXau, libXdmcp, libpthreadstubs, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + gtest, + libdrm, + libpciaccess, + libva, + libX11, + libXau, + libXdmcp, + libpthreadstubs, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "intel-media-sdk"; @@ -24,9 +38,18 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ - libdrm libva libpciaccess libX11 libXau libXdmcp libpthreadstubs + libdrm + libva + libpciaccess + libX11 + libXau + libXdmcp + libpthreadstubs ]; nativeCheckInputs = [ gtest ]; @@ -42,7 +65,10 @@ stdenv.mkDerivation rec { description = "Intel Media SDK"; mainProgram = "mfx-tracer-config"; license = licenses.mit; - maintainers = with maintainers; [ midchildan pjungkamp ]; + maintainers = with maintainers; [ + midchildan + pjungkamp + ]; platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/by-name/in/intel-ocl/package.nix b/pkgs/by-name/in/intel-ocl/package.nix index 1732fd76a735db..c98613b672cdac 100644 --- a/pkgs/by-name/in/intel-ocl/package.nix +++ b/pkgs/by-name/in/intel-ocl/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchzip, rpmextract, ncurses5, numactl, zlib }: +{ + lib, + stdenv, + fetchzip, + rpmextract, + ncurses5, + numactl, + zlib, +}: stdenv.mkDerivation rec { pname = "intel-ocl"; diff --git a/pkgs/by-name/in/intel2200BGFirmware/package.nix b/pkgs/by-name/in/intel2200BGFirmware/package.nix index af9a44b92f469d..f419d57819ea15 100644 --- a/pkgs/by-name/in/intel2200BGFirmware/package.nix +++ b/pkgs/by-name/in/intel2200BGFirmware/package.nix @@ -1,6 +1,8 @@ -{ stdenvNoCC -, lib -, fetchurl }: +{ + stdenvNoCC, + lib, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "intel2200BGFirmware"; diff --git a/pkgs/by-name/in/intelli-shell/package.nix b/pkgs/by-name/in/intelli-shell/package.nix index 5bd7f2e9794c8f..c700d066e61be4 100644 --- a/pkgs/by-name/in/intelli-shell/package.nix +++ b/pkgs/by-name/in/intelli-shell/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libgit2 -, openssl -, sqlite -, zlib -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libgit2, + openssl, + sqlite, + zlib, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -27,14 +28,16 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - libgit2 - openssl - sqlite - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + libgit2 + openssl + sqlite + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; env = { OPENSSL_NO_VENDOR = true; diff --git a/pkgs/by-name/in/inter/package.nix b/pkgs/by-name/in/inter/package.nix index 67a696f59f1d53..7af136f8c1bcab 100644 --- a/pkgs/by-name/in/inter/package.nix +++ b/pkgs/by-name/in/inter/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "inter"; diff --git a/pkgs/by-name/in/interactsh/package.nix b/pkgs/by-name/in/interactsh/package.nix index c3c719a0710b91..824e1197d93cc9 100644 --- a/pkgs/by-name/in/interactsh/package.nix +++ b/pkgs/by-name/in/interactsh/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/in/intercal/package.nix b/pkgs/by-name/in/intercal/package.nix index 6e6fd63fa5b2d2..9d5120c87e2960 100644 --- a/pkgs/by-name/in/intercal/package.nix +++ b/pkgs/by-name/in/intercal/package.nix @@ -1,7 +1,13 @@ -{ lib, stdenv, fetchurl, fetchpatch -, pkg-config -, bison, flex -, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + bison, + flex, + makeWrapper, +}: stdenv.mkDerivation rec { @@ -23,7 +29,12 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config bison flex makeWrapper ]; + nativeBuildInputs = [ + pkg-config + bison + flex + makeWrapper + ]; # Intercal invokes gcc, so we need an explicit PATH postInstall = '' diff --git a/pkgs/by-name/in/interlock/package.nix b/pkgs/by-name/in/interlock/package.nix index 4b53b2de067f75..be844503163c79 100644 --- a/pkgs/by-name/in/interlock/package.nix +++ b/pkgs/by-name/in/interlock/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, coreutils -, cryptsetup -, mount -, systemd -, umount +{ + lib, + buildGoModule, + fetchFromGitHub, + coreutils, + cryptsetup, + mount, + systemd, + umount, }: buildGoModule rec { @@ -21,7 +22,10 @@ buildGoModule rec { vendorHash = "sha256-OL6I95IpyTIc8wCwD9nWxVUTrmZH6COhsd/YwNTyvN0="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postPatch = '' grep -lr '/s\?bin/' | xargs sed -i \ diff --git a/pkgs/by-name/in/intermodal/package.nix b/pkgs/by-name/in/intermodal/package.nix index b4b7d7807cb4fd..569300715afda7 100644 --- a/pkgs/by-name/in/intermodal/package.nix +++ b/pkgs/by-name/in/intermodal/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, installShellFiles }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "intermodal"; @@ -14,7 +20,9 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-k34psGOs6G+B/msmLSDHLNxnjO1yyE4OY6aQU8bt+is="; # include_hidden test tries to use `chflags` on darwin - checkFlags = lib.optionals stdenv.hostPlatform.isDarwin [ "--skip=subcommand::torrent::create::tests::include_hidden" ]; + checkFlags = lib.optionals stdenv.hostPlatform.isDarwin [ + "--skip=subcommand::torrent::create::tests::include_hidden" + ]; nativeBuildInputs = [ installShellFiles ]; @@ -30,7 +38,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/casey/intermodal"; changelog = "https://github.com/casey/intermodal/releases/tag/v${version}"; license = licenses.cc0; - maintainers = with maintainers; [ Br1ght0ne xrelkd ]; + maintainers = with maintainers; [ + Br1ght0ne + xrelkd + ]; mainProgram = "imdl"; }; } diff --git a/pkgs/by-name/in/intiface-central/package.nix b/pkgs/by-name/in/intiface-central/package.nix index fad8b190b18620..26da97f6c643df 100644 --- a/pkgs/by-name/in/intiface-central/package.nix +++ b/pkgs/by-name/in/intiface-central/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, flutterPackages -, corrosion -, rustPlatform -, cargo -, rustc -, udev -, copyDesktopItems -, makeDesktopItem +{ + lib, + fetchFromGitHub, + flutterPackages, + corrosion, + rustPlatform, + cargo, + rustc, + udev, + copyDesktopItems, + makeDesktopItem, }: flutterPackages.stable.buildFlutterApplication rec { pname = "intiface-central"; diff --git a/pkgs/by-name/in/intltool/package.nix b/pkgs/by-name/in/intltool/package.nix index 967fc442a73d2e..e972dc7d5a1eee 100644 --- a/pkgs/by-name/in/intltool/package.nix +++ b/pkgs/by-name/in/intltool/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchpatch, gettext, perlPackages, buildPackages }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + gettext, + perlPackages, + buildPackages, +}: stdenv.mkDerivation rec { pname = "intltool"; @@ -10,17 +18,27 @@ stdenv.mkDerivation rec { }; # fix "unescaped left brace" errors when using intltool in some cases - patches = [(fetchpatch { - name = "perl5.26-regex-fixes.patch"; - urls = [ - "https://sources.debian.org/data/main/i/intltool/0.51.0-5/debian/patches/perl5.26-regex-fixes.patch" - "https://src.fedoraproject.org/rpms/intltool/raw/d8d2ef29fb122a42a6b6678eb1ec97ae56902af2/f/intltool-perl5.26-regex-fixes.patch" - ]; - sha256 = "12q2140867r5d0dysly72khi7b0mm2gd7nlm1k81iyg7fxgnyz45"; - })]; + patches = [ + (fetchpatch { + name = "perl5.26-regex-fixes.patch"; + urls = [ + "https://sources.debian.org/data/main/i/intltool/0.51.0-5/debian/patches/perl5.26-regex-fixes.patch" + "https://src.fedoraproject.org/rpms/intltool/raw/d8d2ef29fb122a42a6b6678eb1ec97ae56902af2/f/intltool-perl5.26-regex-fixes.patch" + ]; + sha256 = "12q2140867r5d0dysly72khi7b0mm2gd7nlm1k81iyg7fxgnyz45"; + }) + ]; - nativeBuildInputs = with perlPackages; [ perl XMLParser ]; - propagatedBuildInputs = [ gettext ] ++ (with perlPackages; [ perl XMLParser ]); + nativeBuildInputs = with perlPackages; [ + perl + XMLParser + ]; + propagatedBuildInputs = + [ gettext ] + ++ (with perlPackages; [ + perl + XMLParser + ]); postInstall = lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' for f in $out/bin/*; do diff --git a/pkgs/by-name/in/intune-portal/package.nix b/pkgs/by-name/in/intune-portal/package.nix index 009be9ce46debb..f5342ec6aedc8c 100644 --- a/pkgs/by-name/in/intune-portal/package.nix +++ b/pkgs/by-name/in/intune-portal/package.nix @@ -1,25 +1,26 @@ -{ stdenv -, lib -, fetchurl -, dpkg -, libuuid -, xorg -, curlMinimal -, openssl -, libsecret -, webkitgtk_4_0 -, libsoup_2_4 -, gtk3 -, atk -, pango -, glib -, sqlite -, zlib -, systemd -, msalsdk-dbusclient -, pam -, dbus -, nixosTests +{ + stdenv, + lib, + fetchurl, + dpkg, + libuuid, + xorg, + curlMinimal, + openssl, + libsecret, + webkitgtk_4_0, + libsoup_2_4, + gtk3, + atk, + pango, + glib, + sqlite, + zlib, + systemd, + msalsdk-dbusclient, + pam, + dbus, + nixosTests, }: stdenv.mkDerivation rec { pname = "intune-portal"; diff --git a/pkgs/by-name/in/invidious/videojs.nix b/pkgs/by-name/in/invidious/videojs.nix index dcd6e9e97cbf36..302415dc900031 100644 --- a/pkgs/by-name/in/invidious/videojs.nix +++ b/pkgs/by-name/in/invidious/videojs.nix @@ -1,10 +1,11 @@ -{ stdenvNoCC -, cacert -, crystal -, openssl -, pkg-config -, invidious -, versions +{ + stdenvNoCC, + cacert, + crystal, + openssl, + pkg-config, + invidious, + versions, }: stdenvNoCC.mkDerivation { @@ -14,7 +15,12 @@ stdenvNoCC.mkDerivation { builder = ./videojs.sh; - nativeBuildInputs = [ cacert crystal openssl pkg-config ]; + nativeBuildInputs = [ + cacert + crystal + openssl + pkg-config + ]; outputHashAlgo = "sha256"; outputHashMode = "recursive"; diff --git a/pkgs/by-name/in/invidtui/package.nix b/pkgs/by-name/in/invidtui/package.nix index 4ca39a938ae936..81ce6d058a766b 100644 --- a/pkgs/by-name/in/invidtui/package.nix +++ b/pkgs/by-name/in/invidtui/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, yt-dlp, ffmpeg, mpv }: +{ + lib, + buildGoModule, + fetchFromGitHub, + yt-dlp, + ffmpeg, + mpv, +}: buildGoModule rec { pname = "invidtui"; @@ -16,10 +23,10 @@ buildGoModule rec { doCheck = true; postPatch = '' - substituteInPlace cmd/flags.go \ - --replace "\"ffmpeg\"" "\"${lib.getBin ffmpeg}/bin/ffmpeg\"" \ - --replace "\"mpv\"" "\"${lib.getBin mpv}/bin/mpv\"" \ - --replace "\"yt-dlp\"" "\"${lib.getBin yt-dlp}/bin/yt-dlp\"" + substituteInPlace cmd/flags.go \ + --replace "\"ffmpeg\"" "\"${lib.getBin ffmpeg}/bin/ffmpeg\"" \ + --replace "\"mpv\"" "\"${lib.getBin mpv}/bin/mpv\"" \ + --replace "\"yt-dlp\"" "\"${lib.getBin yt-dlp}/bin/yt-dlp\"" ''; meta = with lib; { diff --git a/pkgs/by-name/in/invoice/package.nix b/pkgs/by-name/in/invoice/package.nix index ea7ce5c2205a72..fa1851636dc162 100644 --- a/pkgs/by-name/in/invoice/package.nix +++ b/pkgs/by-name/in/invoice/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "invoice"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-8VhBflnpsJ5h8S6meDFZKCcS2nz5u4kPE9W710gJG4U="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Command line invoice generator"; diff --git a/pkgs/by-name/in/invoice2data/package.nix b/pkgs/by-name/in/invoice2data/package.nix index b2179d3f63b244..3280b1fab23638 100644 --- a/pkgs/by-name/in/invoice2data/package.nix +++ b/pkgs/by-name/in/invoice2data/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, ghostscript -, imagemagick -, poppler_utils -, python3 -, tesseract5 +{ + lib, + fetchFromGitHub, + fetchpatch, + ghostscript, + imagemagick, + poppler_utils, + python3, + tesseract5, }: python3.pkgs.buildPythonApplication rec { @@ -41,12 +42,17 @@ python3.pkgs.buildPythonApplication rec { setuptools ]; - makeWrapperArgs = ["--prefix" "PATH" ":" (lib.makeBinPath [ - ghostscript - imagemagick - tesseract5 - poppler_utils - ])]; + makeWrapperArgs = [ + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ + ghostscript + imagemagick + tesseract5 + poppler_utils + ]) + ]; # Tests fails even when ran manually on my ubuntu machine !! doCheck = false; diff --git a/pkgs/by-name/in/inxi/package.nix b/pkgs/by-name/in/inxi/package.nix index 563ff69b4929b6..d4c6bdbf960b99 100644 --- a/pkgs/by-name/in/inxi/package.nix +++ b/pkgs/by-name/in/inxi/package.nix @@ -1,26 +1,68 @@ -{ lib, stdenv, fetchFromGitea, perl, perlPackages, makeWrapper -, ps, dnsutils # dig is recommended for multiple categories -, withRecommends ? false # Install (almost) all recommended tools (see --recommends) -, withRecommendedSystemPrograms ? withRecommends, util-linuxMinimal, dmidecode -, file, hddtemp, iproute2, ipmitool, usbutils, kmod, lm_sensors, smartmontools -, binutils, tree, upower, pciutils -, withRecommendedDisplayInformationPrograms ? withRecommends, mesa-demos, xorg +{ + lib, + stdenv, + fetchFromGitea, + perl, + perlPackages, + makeWrapper, + ps, + dnsutils, # dig is recommended for multiple categories + withRecommends ? false, # Install (almost) all recommended tools (see --recommends) + withRecommendedSystemPrograms ? withRecommends, + util-linuxMinimal, + dmidecode, + file, + hddtemp, + iproute2, + ipmitool, + usbutils, + kmod, + lm_sensors, + smartmontools, + binutils, + tree, + upower, + pciutils, + withRecommendedDisplayInformationPrograms ? withRecommends, + mesa-demos, + xorg, }: let - prefixPath = programs: - "--prefix PATH ':' '${lib.makeBinPath programs}'"; + prefixPath = programs: "--prefix PATH ':' '${lib.makeBinPath programs}'"; recommendedSystemPrograms = lib.optionals withRecommendedSystemPrograms [ - util-linuxMinimal dmidecode file hddtemp iproute2 ipmitool usbutils kmod - lm_sensors smartmontools binutils tree upower pciutils + util-linuxMinimal + dmidecode + file + hddtemp + iproute2 + ipmitool + usbutils + kmod + lm_sensors + smartmontools + binutils + tree + upower + pciutils ]; - recommendedDisplayInformationPrograms = lib.optionals - withRecommendedDisplayInformationPrograms - ([ mesa-demos ] ++ (with xorg; [ xdpyinfo xprop xrandr ])); - programs = [ ps dnsutils ] # Core programs + recommendedDisplayInformationPrograms = lib.optionals withRecommendedDisplayInformationPrograms ( + [ mesa-demos ] + ++ (with xorg; [ + xdpyinfo + xprop + xrandr + ]) + ); + programs = + [ + ps + dnsutils + ] # Core programs ++ recommendedSystemPrograms ++ recommendedDisplayInformationPrograms; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "inxi"; version = "3.3.35-1"; diff --git a/pkgs/by-name/io/io/package.nix b/pkgs/by-name/io/io/package.nix index 0d522055d9adfb..11d07c6a13a174 100644 --- a/pkgs/by-name/io/io/package.nix +++ b/pkgs/by-name/io/io/package.nix @@ -1,7 +1,37 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, zlib, sqlite, gmp, libffi, cairo, - ncurses, freetype, libGLU, libGL, libpng, libtiff, libjpeg, readline, libsndfile, - libxml2, libglut, libsamplerate, pcre, libevent, libedit, yajl, - python3, openssl, glfw, pkg-config, libpthreadstubs, libXdmcp, libmemcached +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + zlib, + sqlite, + gmp, + libffi, + cairo, + ncurses, + freetype, + libGLU, + libGL, + libpng, + libtiff, + libjpeg, + readline, + libsndfile, + libxml2, + libglut, + libsamplerate, + pcre, + libevent, + libedit, + yajl, + python3, + openssl, + glfw, + pkg-config, + libpthreadstubs, + libXdmcp, + libmemcached, }: stdenv.mkDerivation { @@ -28,11 +58,33 @@ stdenv.mkDerivation { ]; buildInputs = [ - zlib sqlite gmp libffi cairo ncurses freetype - libGLU libGL libpng libtiff libjpeg readline libsndfile libxml2 - libglut libsamplerate pcre libevent libedit yajl - glfw openssl libpthreadstubs libXdmcp - libmemcached python3 + zlib + sqlite + gmp + libffi + cairo + ncurses + freetype + libGLU + libGL + libpng + libtiff + libjpeg + readline + libsndfile + libxml2 + libglut + libsamplerate + pcre + libevent + libedit + yajl + glfw + openssl + libpthreadstubs + libXdmcp + libmemcached + python3 ]; preConfigure = '' diff --git a/pkgs/by-name/io/ioc-scan/package.nix b/pkgs/by-name/io/ioc-scan/package.nix index 4b7c81119c5d42..4495906ba926a6 100644 --- a/pkgs/by-name/io/ioc-scan/package.nix +++ b/pkgs/by-name/io/ioc-scan/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -17,7 +18,7 @@ python3.pkgs.buildPythonApplication rec { build-system = with python3.pkgs; [ setuptools ]; - propagatedBuildInputs = with python3.pkgs; [ docopt]; + propagatedBuildInputs = with python3.pkgs; [ docopt ]; nativeCheckInputs = with python3.pkgs; [ pyfakefs diff --git a/pkgs/by-name/io/ioccheck/package.nix b/pkgs/by-name/io/ioccheck/package.nix index 2f054c6dc6a6a3..220710d0155952 100644 --- a/pkgs/by-name/io/ioccheck/package.nix +++ b/pkgs/by-name/io/ioccheck/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: let @@ -33,7 +34,8 @@ let }; }; }; -in py.pkgs.buildPythonApplication rec { +in +py.pkgs.buildPythonApplication rec { pname = "ioccheck"; version = "unstable-2021-09-29"; pyproject = true; diff --git a/pkgs/by-name/io/iodash/package.nix b/pkgs/by-name/io/iodash/package.nix index d8982f0f8c0466..cc17be915bc811 100644 --- a/pkgs/by-name/io/iodash/package.nix +++ b/pkgs/by-name/io/iodash/package.nix @@ -1,21 +1,30 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "iodash"; version = "0.1.7"; - src = fetchFromGitHub { - owner = "YukiWorkshop"; - repo = "IODash"; - rev = "9dcb26621a9c17dbab704b5bab0c3a5fc72624cb"; + src = fetchFromGitHub { + owner = "YukiWorkshop"; + repo = "IODash"; + rev = "9dcb26621a9c17dbab704b5bab0c3a5fc72624cb"; sha256 = "0db5y2206fwh3h1pzjm9hy3m76inm0xpm1c5gvrladz6hiqfp7bx"; fetchSubmodules = true; }; # adds missing cmake install directives # https://github.com/YukiWorkshop/IODash/pull/2 - patches = [ ./0001-Add-cmake-install-directives.patch]; + patches = [ ./0001-Add-cmake-install-directives.patch ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; meta = with lib; { homepage = "https://github.com/YukiWorkshop/IODash"; diff --git a/pkgs/by-name/io/iodine/package.nix b/pkgs/by-name/io/iodine/package.nix index 328d1354ede3c4..3d993b3f1662f2 100644 --- a/pkgs/by-name/io/iodine/package.nix +++ b/pkgs/by-name/io/iodine/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, zlib -, nettools -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + nettools, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/io/iomelt/package.nix b/pkgs/by-name/io/iomelt/package.nix index 8796b740c3473e..c5abb0922e78af 100644 --- a/pkgs/by-name/io/iomelt/package.nix +++ b/pkgs/by-name/io/iomelt/package.nix @@ -1,10 +1,13 @@ -{ fetchurl -, lib -, stdenv +{ + fetchurl, + lib, + stdenv, }: -let version = "0.7"; -in stdenv.mkDerivation { +let + version = "0.7"; +in +stdenv.mkDerivation { inherit version; pname = "iomelt"; src = fetchurl { diff --git a/pkgs/by-name/io/ion/package.nix b/pkgs/by-name/io/ion/package.nix index 22fef6ee4f7481..57af77aa3a6020 100644 --- a/pkgs/by-name/io/ion/package.nix +++ b/pkgs/by-name/io/ion/package.nix @@ -1,7 +1,7 @@ { lib, rustPlatform, - fetchFromGitLab + fetchFromGitLab, }: rustPlatform.buildRustPackage { @@ -40,7 +40,10 @@ rustPlatform.buildRustPackage { description = "Modern system shell with simple (and powerful) syntax"; homepage = "https://gitlab.redox-os.org/redox-os/ion"; license = licenses.mit; - maintainers = with maintainers; [dywedir arthsmn]; + maintainers = with maintainers; [ + dywedir + arthsmn + ]; mainProgram = "ion"; platforms = platforms.unix; }; diff --git a/pkgs/by-name/io/ioping/package.nix b/pkgs/by-name/io/ioping/package.nix index f610258cf503e4..a228153ae4ef6c 100644 --- a/pkgs/by-name/io/ioping/package.nix +++ b/pkgs/by-name/io/ioping/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "ioping"; diff --git a/pkgs/by-name/io/ioport/package.nix b/pkgs/by-name/io/ioport/package.nix index 6da154648fc2ec..25f0f42108c19b 100644 --- a/pkgs/by-name/io/ioport/package.nix +++ b/pkgs/by-name/io/ioport/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, perl, fetchurl }: +{ + lib, + stdenv, + perl, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ioport"; @@ -15,7 +20,10 @@ stdenv.mkDerivation rec { description = "Direct access to I/O ports from the command line"; homepage = "https://people.redhat.com/rjones/ioport/"; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ maintainers.cleverca22 ]; }; } diff --git a/pkgs/by-name/io/ioq3-scion/package.nix b/pkgs/by-name/io/ioq3-scion/package.nix index bb28ff1989035b..b78ef09367ee0f 100644 --- a/pkgs/by-name/io/ioq3-scion/package.nix +++ b/pkgs/by-name/io/ioq3-scion/package.nix @@ -1,4 +1,10 @@ -{ ioquake3, fetchFromGitHub, pan-bindings, libsodium, lib }: +{ + ioquake3, + fetchFromGitHub, + pan-bindings, + libsodium, + lib, +}: ioquake3.overrideAttrs (old: { pname = "ioq3-scion"; version = "unstable-2024-03-03"; diff --git a/pkgs/by-name/io/ioquake3/package.nix b/pkgs/by-name/io/ioquake3/package.nix index b21a65f3933ee8..80afd46bc92b56 100644 --- a/pkgs/by-name/io/ioquake3/package.nix +++ b/pkgs/by-name/io/ioquake3/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, which -, copyDesktopItems -, makeBinaryWrapper -, SDL2 -, libGL -, openal -, curl -, speex -, opusfile -, libogg -, libvorbis -, libjpeg -, makeDesktopItem -, freetype -, mumble +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + which, + copyDesktopItems, + makeBinaryWrapper, + SDL2, + libGL, + openal, + curl, + speex, + opusfile, + libogg, + libvorbis, + libjpeg, + makeDesktopItem, + freetype, + mumble, }: stdenv.mkDerivation { @@ -75,7 +76,10 @@ stdenv.mkDerivation { icon = "ioquake3"; comment = "A fast-paced 3D first-person shooter, a community effort to continue supporting/developing id's Quake III Arena"; desktopName = "ioquake3"; - categories = [ "Game" "ActionGame" ]; + categories = [ + "Game" + "ActionGame" + ]; }) ]; @@ -84,7 +88,11 @@ stdenv.mkDerivation { description = "Fast-paced 3D first-person shooter, a community effort to continue supporting/developing id's Quake III Arena"; license = lib.licenses.gpl2Plus; mainProgram = "ioquake3"; - maintainers = with lib.maintainers; [ abbradar drupol rvolosatovs ]; + maintainers = with lib.maintainers; [ + abbradar + drupol + rvolosatovs + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/io/ior/package.nix b/pkgs/by-name/io/ior/package.nix index ba3e5f1c7ffaa7..3b33d1607b83a3 100644 --- a/pkgs/by-name/io/ior/package.nix +++ b/pkgs/by-name/io/ior/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, mpi, perl, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + mpi, + perl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "ior"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ mpi perl ]; + buildInputs = [ + mpi + perl + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/io/iotop-c/package.nix b/pkgs/by-name/io/iotop-c/package.nix index 57254f30c3c91d..62c37c4a2e6b63 100644 --- a/pkgs/by-name/io/iotop-c/package.nix +++ b/pkgs/by-name/io/iotop-c/package.nix @@ -1,4 +1,10 @@ -{stdenv, fetchFromGitHub, lib, ncurses, pkg-config }: +{ + stdenv, + fetchFromGitHub, + lib, + ncurses, + pkg-config, +}: stdenv.mkDerivation rec { pname = "iotop-c"; @@ -13,7 +19,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ ncurses ]; - makeFlags = [ "DESTDIR=$(out)" "TARGET=iotop-c" ]; + makeFlags = [ + "DESTDIR=$(out)" + "TARGET=iotop-c" + ]; postInstall = '' mv $out/usr/share/man/man8/{iotop,iotop-c}.8 diff --git a/pkgs/by-name/io/iotop/package.nix b/pkgs/by-name/io/iotop/package.nix index 767bf4a2915ced..6f420219118e01 100644 --- a/pkgs/by-name/io/iotop/package.nix +++ b/pkgs/by-name/io/iotop/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, python3Packages, fetchpatch }: +{ + lib, + fetchurl, + python3Packages, + fetchpatch, +}: python3Packages.buildPythonApplication rec { pname = "iotop"; diff --git a/pkgs/by-name/io/iozone/package.nix b/pkgs/by-name/io/iozone/package.nix index a724d67a1a0475..9820881d4c4672 100644 --- a/pkgs/by-name/io/iozone/package.nix +++ b/pkgs/by-name/io/iozone/package.nix @@ -1,15 +1,22 @@ -{ stdenv, lib, fetchurl, gnuplot }: +{ + stdenv, + lib, + fetchurl, + gnuplot, +}: let - target = if stdenv.hostPlatform.system == "i686-linux" then - "linux" - else if stdenv.hostPlatform.system == "x86_64-linux" then - "linux-AMD64" - else if stdenv.hostPlatform.system == "x86_64-darwin" then - "macosx" - else if stdenv.hostPlatform.system == "aarch64-linux" then - "linux-arm" - else throw "Platform ${stdenv.hostPlatform.system} not yet supported."; + target = + if stdenv.hostPlatform.system == "i686-linux" then + "linux" + else if stdenv.hostPlatform.system == "x86_64-linux" then + "linux-AMD64" + else if stdenv.hostPlatform.system == "x86_64-darwin" then + "macosx" + else if stdenv.hostPlatform.system == "aarch64-linux" then + "linux-arm" + else + throw "Platform ${stdenv.hostPlatform.system} not yet supported."; in stdenv.mkDerivation rec { @@ -17,7 +24,7 @@ stdenv.mkDerivation rec { version = "3.506"; src = fetchurl { - url = "http://www.iozone.org/src/current/iozone${lib.replaceStrings ["."] ["_"] version}.tar"; + url = "http://www.iozone.org/src/current/iozone${lib.replaceStrings [ "." ] [ "_" ] version}.tar"; hash = "sha256-EUzlwHGHO5ose6bnPQXV735mVkOSrL/NwLMmHbEPy+c="; }; @@ -54,9 +61,17 @@ stdenv.mkDerivation rec { meta = { description = "IOzone Filesystem Benchmark"; - homepage = "http://www.iozone.org/"; - license = lib.licenses.unfreeRedistributable; - platforms = ["i686-linux" "x86_64-linux" "x86_64-darwin" "aarch64-linux" ]; - maintainers = with lib.maintainers; [ Baughn makefu ]; + homepage = "http://www.iozone.org/"; + license = lib.licenses.unfreeRedistributable; + platforms = [ + "i686-linux" + "x86_64-linux" + "x86_64-darwin" + "aarch64-linux" + ]; + maintainers = with lib.maintainers; [ + Baughn + makefu + ]; }; } diff --git a/pkgs/by-name/io/ioztat/package.nix b/pkgs/by-name/io/ioztat/package.nix index 1763ae93c2c61d..7d1b1dd4a62398 100644 --- a/pkgs/by-name/io/ioztat/package.nix +++ b/pkgs/by-name/io/ioztat/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + python3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ip/ip2location-c/package.nix b/pkgs/by-name/ip/ip2location-c/package.nix index bc1c3736f730b6..929e5772b57273 100644 --- a/pkgs/by-name/ip/ip2location-c/package.nix +++ b/pkgs/by-name/ip/ip2location-c/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { @@ -35,7 +36,10 @@ stdenv.mkDerivation rec { any IP address or host name in the IP2Location databases. ''; homepage = "https://www.ip2location.com/developers/c"; - license = with licenses; [ gpl3Plus lgpl3Plus ]; + license = with licenses; [ + gpl3Plus + lgpl3Plus + ]; maintainers = [ ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/ip/ip2location/package.nix b/pkgs/by-name/ip/ip2location/package.nix index 6fa9345b3f01f9..ba59cc9bc3d624 100644 --- a/pkgs/by-name/ip/ip2location/package.nix +++ b/pkgs/by-name/ip/ip2location/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ip2location"; @@ -22,7 +26,10 @@ stdenv.mkDerivation rec { any IP address or host name in the IP2Location databases. ''; homepage = "https://www.ip2location.com/free/applications"; - license = with licenses; [ gpl3Plus lgpl3Plus ]; + license = with licenses; [ + gpl3Plus + lgpl3Plus + ]; platforms = platforms.linux; mainProgram = "ip2location"; }; diff --git a/pkgs/by-name/ip/ip2unix/package.nix b/pkgs/by-name/ip/ip2unix/package.nix index 9c34c859185fbd..c134eedcdeda2e 100644 --- a/pkgs/by-name/ip/ip2unix/package.nix +++ b/pkgs/by-name/ip/ip2unix/package.nix @@ -1,6 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, meson, ninja, pkg-config, yaml-cpp, systemd -, python3Packages, asciidoc, libxslt, docbook_xml_dtd_45, docbook_xsl -, libxml2, docbook5, mesonEmulatorHook +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + meson, + ninja, + pkg-config, + yaml-cpp, + systemd, + python3Packages, + asciidoc, + libxslt, + docbook_xml_dtd_45, + docbook_xsl, + libxml2, + docbook5, + mesonEmulatorHook, }: stdenv.mkDerivation rec { @@ -24,8 +39,17 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ - meson ninja pkg-config asciidoc libxslt.bin docbook_xml_dtd_45 docbook_xsl - libxml2.bin docbook5 python3Packages.pytest python3Packages.pytest-timeout + meson + ninja + pkg-config + asciidoc + libxslt.bin + docbook_xml_dtd_45 + docbook_xsl + libxml2.bin + docbook5 + python3Packages.pytest + python3Packages.pytest-timeout systemd ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ mesonEmulatorHook ]; diff --git a/pkgs/by-name/ip/ipad_charge/package.nix b/pkgs/by-name/ip/ipad_charge/package.nix index fdbab82aabcdc5..aeb4fc2ea222a8 100644 --- a/pkgs/by-name/ip/ipad_charge/package.nix +++ b/pkgs/by-name/ip/ipad_charge/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libusb1 }: +{ + lib, + stdenv, + fetchFromGitHub, + libusb1, +}: stdenv.mkDerivation rec { pname = "ipad_charge"; diff --git a/pkgs/by-name/ip/ipaexfont/package.nix b/pkgs/by-name/ip/ipaexfont/package.nix index 986eab13a2577a..e2af2c9906bc08 100644 --- a/pkgs/by-name/ip/ipaexfont/package.nix +++ b/pkgs/by-name/ip/ipaexfont/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { pname = "ipaexfont"; diff --git a/pkgs/by-name/ip/ipafont/package.nix b/pkgs/by-name/ip/ipafont/package.nix index 8a1f91da34fb3e..98bffe658ea984 100644 --- a/pkgs/by-name/ip/ipafont/package.nix +++ b/pkgs/by-name/ip/ipafont/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { pname = "ipafont"; diff --git a/pkgs/by-name/ip/ipam/package.nix b/pkgs/by-name/ip/ipam/package.nix index 3a5b7b8492e15d..1d9223ecb78dc6 100644 --- a/pkgs/by-name/ip/ipam/package.nix +++ b/pkgs/by-name/ip/ipam/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitea -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitea, + installShellFiles, }: buildGoModule rec { @@ -22,7 +23,10 @@ buildGoModule rec { vendorHash = "sha256-l8eeeYv41yUPQ1dyJY4Jo3uvULrc1B/buGlMxYSdhCA="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' installShellCompletion --cmd ipam \ diff --git a/pkgs/by-name/ip/ipatool/package.nix b/pkgs/by-name/ip/ipatool/package.nix index 0b9e7f8a941589..ea9bf1fdd9ea29 100644 --- a/pkgs/by-name/ip/ipatool/package.nix +++ b/pkgs/by-name/ip/ipatool/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script -, testers -, ipatool +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + testers, + ipatool, }: buildGoModule rec { diff --git a/pkgs/by-name/ip/ipbt/package.nix b/pkgs/by-name/ip/ipbt/package.nix index 66369d9833948f..70629038d08f71 100644 --- a/pkgs/by-name/ip/ipbt/package.nix +++ b/pkgs/by-name/ip/ipbt/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, perl, ncurses }: +{ + lib, + stdenv, + fetchurl, + perl, + ncurses, +}: stdenv.mkDerivation rec { version = "20210215.5a9cb02"; diff --git a/pkgs/by-name/ip/ipcalc/package.nix b/pkgs/by-name/ip/ipcalc/package.nix index e45a2162dd3af1..2e08354371da79 100644 --- a/pkgs/by-name/ip/ipcalc/package.nix +++ b/pkgs/by-name/ip/ipcalc/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, ronn -, withGeo ? true -, geoip +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + ronn, + withGeo ? true, + geoip, }: # In order for the geoip part to work, you need to set up a link from @@ -37,7 +38,12 @@ stdenv.mkDerivation rec { --replace /usr/share/GeoIP /var/lib/GeoIP ''; - nativeBuildInputs = [ meson ninja pkg-config ronn ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ronn + ]; buildInputs = [ geoip ]; diff --git a/pkgs/by-name/ip/iperf3d/package.nix b/pkgs/by-name/ip/iperf3d/package.nix index 93490be8e1532c..53e343c6d4b742 100644 --- a/pkgs/by-name/ip/iperf3d/package.nix +++ b/pkgs/by-name/ip/iperf3d/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, rustPlatform, makeWrapper, iperf3 }: +{ + lib, + fetchFromGitHub, + rustPlatform, + makeWrapper, + iperf3, +}: rustPlatform.buildRustPackage rec { pname = "iperf3d"; diff --git a/pkgs/by-name/ip/ipfetch/package.nix b/pkgs/by-name/ip/ipfetch/package.nix index 7f86c8a246faf6..7f1e0fea425c13 100644 --- a/pkgs/by-name/ip/ipfetch/package.nix +++ b/pkgs/by-name/ip/ipfetch/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, bash, wget, makeWrapper }: +{ + stdenv, + lib, + fetchFromGitHub, + bash, + wget, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "ipfetch"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; strictDeps = true; - buildInputs = [ bash wget ]; + buildInputs = [ + bash + wget + ]; nativeBuildInputs = [ makeWrapper ]; postPatch = '' patchShebangs --host ipfetch @@ -25,7 +35,10 @@ stdenv.mkDerivation rec { cp -r flags $out/usr/share/ipfetch/ cp ipfetch $out/bin/ipfetch wrapProgram $out/bin/ipfetch --prefix PATH : ${ - lib.makeBinPath [ bash wget ] + lib.makeBinPath [ + bash + wget + ] } ''; diff --git a/pkgs/by-name/ip/ipfs-cluster/package.nix b/pkgs/by-name/ip/ipfs-cluster/package.nix index c31e5603841231..813f40030fa42e 100644 --- a/pkgs/by-name/ip/ipfs-cluster/package.nix +++ b/pkgs/by-name/ip/ipfs-cluster/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ipfs-cluster"; @@ -17,6 +21,9 @@ buildGoModule rec { description = "Allocate, replicate, and track Pins across a cluster of IPFS daemons"; homepage = "https://ipfscluster.io"; license = licenses.mit; - maintainers = with maintainers; [ Luflosi jglukasik ]; + maintainers = with maintainers; [ + Luflosi + jglukasik + ]; }; } diff --git a/pkgs/by-name/ip/ipfs-upload-client/package.nix b/pkgs/by-name/ip/ipfs-upload-client/package.nix index a3d02d00c41871..cde82f861487c5 100644 --- a/pkgs/by-name/ip/ipfs-upload-client/package.nix +++ b/pkgs/by-name/ip/ipfs-upload-client/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ipfs-upload-client"; diff --git a/pkgs/by-name/ip/ipget/package.nix b/pkgs/by-name/ip/ipget/package.nix index 2b402130dc1664..93af9fef9526e9 100644 --- a/pkgs/by-name/ip/ipget/package.nix +++ b/pkgs/by-name/ip/ipget/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ipget"; diff --git a/pkgs/by-name/ip/ipgrep/package.nix b/pkgs/by-name/ip/ipgrep/package.nix index 04f39f8d28fb43..42e8a9305614cf 100644 --- a/pkgs/by-name/ip/ipgrep/package.nix +++ b/pkgs/by-name/ip/ipgrep/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { version = "1.0.1"; diff --git a/pkgs/by-name/ip/ipinfo/package.nix b/pkgs/by-name/ip/ipinfo/package.nix index 500b40120fc544..4adcd6b5e7f769 100644 --- a/pkgs/by-name/ip/ipinfo/package.nix +++ b/pkgs/by-name/ip/ipinfo/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ip/iplan/package.nix b/pkgs/by-name/ip/iplan/package.nix index c58a23d88ec1df..018ba38d80ee07 100644 --- a/pkgs/by-name/ip/iplan/package.nix +++ b/pkgs/by-name/ip/iplan/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cargo -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, wrapGAppsHook4 -, desktop-file-utils -, libadwaita +{ + lib, + stdenv, + fetchFromGitHub, + cargo, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + wrapGAppsHook4, + desktop-file-utils, + libadwaita, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ip/ipmicfg/package.nix b/pkgs/by-name/ip/ipmicfg/package.nix index 91dc01060099ca..cc8540c27163ef 100644 --- a/pkgs/by-name/ip/ipmicfg/package.nix +++ b/pkgs/by-name/ip/ipmicfg/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { pname = "ipmicfg"; @@ -22,14 +26,14 @@ stdenv.mkDerivation rec { ln -s "$out/opt/ipmicfg/IPMICFG-Linux.x86_64" "$out/bin/ipmicfg" ''; - dontPatchShebangs = true; # There are no scripts and it complains about null bytes. + dontPatchShebangs = true; # There are no scripts and it complains about null bytes. - meta = with lib; { - description = "Supermicro IPMI configuration tool"; - homepage = "http://www.supermicro.com/products/nfo/ipmi.cfm"; - sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.unfree; - platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ sorki ]; - }; + meta = with lib; { + description = "Supermicro IPMI configuration tool"; + homepage = "http://www.supermicro.com/products/nfo/ipmi.cfm"; + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; + license = licenses.unfree; + platforms = [ "x86_64-linux" ]; + maintainers = with maintainers; [ sorki ]; + }; } diff --git a/pkgs/by-name/ip/ipmiutil/package.nix b/pkgs/by-name/ip/ipmiutil/package.nix index cbc239b8c13a86..8d1aaec06331a3 100644 --- a/pkgs/by-name/ip/ipmiutil/package.nix +++ b/pkgs/by-name/ip/ipmiutil/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, openssl }: +{ + lib, + stdenv, + fetchurl, + openssl, +}: stdenv.mkDerivation rec { pname = "ipmiutil"; diff --git a/pkgs/by-name/ip/ipmiview/package.nix b/pkgs/by-name/ip/ipmiview/package.nix index ff8db5339f65f6..82c1de7528b86d 100644 --- a/pkgs/by-name/ip/ipmiview/package.nix +++ b/pkgs/by-name/ip/ipmiview/package.nix @@ -1,15 +1,18 @@ -{ lib, stdenv -, fetchurl -, makeDesktopItem -, makeWrapper -, patchelf -, fontconfig -, freetype -, gcc -, gcc-unwrapped -, iputils -, psmisc -, xorg }: +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + makeWrapper, + patchelf, + fontconfig, + freetype, + gcc, + gcc-unwrapped, + iputils, + psmisc, + xorg, +}: stdenv.mkDerivation rec { pname = "IPMIView"; @@ -21,23 +24,39 @@ stdenv.mkDerivation rec { hash = "sha256-ZN0vadGbjGj9U2wPqvHLjS9fsk3DNCbXoNvzUfnn8IM="; }; - nativeBuildInputs = [ patchelf makeWrapper ]; - buildPhase = with xorg; + nativeBuildInputs = [ + patchelf + makeWrapper + ]; + buildPhase = + with xorg; let - stunnelBinary = if stdenv.hostPlatform.system == "x86_64-linux" then "linux/stunnel64" - else if stdenv.hostPlatform.system == "i686-linux" then "linux/stunnel32" - else throw "IPMIView is not supported on this platform"; + stunnelBinary = + if stdenv.hostPlatform.system == "x86_64-linux" then + "linux/stunnel64" + else if stdenv.hostPlatform.system == "i686-linux" then + "linux/stunnel32" + else + throw "IPMIView is not supported on this platform"; in - '' - runHook preBuild + '' + runHook preBuild - patchelf --set-rpath "${lib.makeLibraryPath [ libX11 libXext libXrender libXtst libXi ]}" ./jre/lib/libawt_xawt.so - patchelf --set-rpath "${lib.makeLibraryPath [ freetype ]}" ./jre/lib/libfontmanager.so - patchelf --set-rpath "${gcc.cc}/lib:$out/jre/lib/jli" --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" ./jre/bin/java - patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" ./BMCSecurity/${stunnelBinary} + patchelf --set-rpath "${ + lib.makeLibraryPath [ + libX11 + libXext + libXrender + libXtst + libXi + ] + }" ./jre/lib/libawt_xawt.so + patchelf --set-rpath "${lib.makeLibraryPath [ freetype ]}" ./jre/lib/libfontmanager.so + patchelf --set-rpath "${gcc.cc}/lib:$out/jre/lib/jli" --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" ./jre/bin/java + patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" ./BMCSecurity/${stunnelBinary} - runHook postBuild - ''; + runHook postBuild + ''; desktopItem = makeDesktopItem rec { name = "IPMIView"; @@ -60,7 +79,12 @@ stdenv.mkDerivation rec { # WORK_DIR: unfortunately the ikvm related binaries are loaded from # and user configuration is written to files in the CWD makeWrapper $out/jre/bin/java $out/bin/IPMIView \ - --set LD_LIBRARY_PATH "${lib.makeLibraryPath [ fontconfig gcc-unwrapped.lib ]}" \ + --set LD_LIBRARY_PATH "${ + lib.makeLibraryPath [ + fontconfig + gcc-unwrapped.lib + ] + }" \ --prefix PATH : "$out/jre/bin:${iputils}/bin:${psmisc}/bin" \ --add-flags "-jar $out/IPMIView20.jar" \ --run 'WORK_DIR=''${XDG_DATA_HOME:-~/.local/share}/ipmiview @@ -78,7 +102,10 @@ stdenv.mkDerivation rec { ]; license = licenses.unfree; maintainers = with maintainers; [ vlaci ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; mainProgram = "IPMIView"; }; } diff --git a/pkgs/by-name/ip/ipopt/package.nix b/pkgs/by-name/ip/ipopt/package.nix index a3c61816d25c72..c020598544a5b7 100644 --- a/pkgs/by-name/ip/ipopt/package.nix +++ b/pkgs/by-name/ip/ipopt/package.nix @@ -1,13 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, blas -, lapack -, gfortran -, enableAMPL ? true, libamplsolver -, enableMUMPS ? true, mumps, mpi -, enableSPRAL ? true, spral +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + blas, + lapack, + gfortran, + enableAMPL ? true, + libamplsolver, + enableMUMPS ? true, + mumps, + mpi, + enableSPRAL ? true, + spral, }: assert (!blas.isILP64) && (!lapack.isILP64); @@ -23,23 +28,40 @@ stdenv.mkDerivation rec { sha256 = "sha256-ZuiZZMq7NzOm6CCJgMBgEWs8PEfM3pVr2yOWbS42l8U="; }; - CXXDEFS = [ "-DHAVE_RAND" "-DHAVE_CSTRING" "-DHAVE_CSTDIO" ]; - - configureFlags = lib.optionals enableAMPL [ - "--with-asl-cflags=-I${libamplsolver}/include" - "--with-asl-lflags=-lamplsolver" - ] ++ lib.optionals enableMUMPS [ - "--with-mumps-cflags=-I${mumps}/include" - "--with-mumps-lflags=-ldmumps" - ] ++ lib.optionals enableSPRAL [ - "--with-spral-cflags=-I${spral}/include" - "--with-spral-lflags=-lspral" + CXXDEFS = [ + "-DHAVE_RAND" + "-DHAVE_CSTRING" + "-DHAVE_CSTDIO" ]; - nativeBuildInputs = [ pkg-config gfortran ]; - buildInputs = [ blas lapack ] + configureFlags = + lib.optionals enableAMPL [ + "--with-asl-cflags=-I${libamplsolver}/include" + "--with-asl-lflags=-lamplsolver" + ] + ++ lib.optionals enableMUMPS [ + "--with-mumps-cflags=-I${mumps}/include" + "--with-mumps-lflags=-ldmumps" + ] + ++ lib.optionals enableSPRAL [ + "--with-spral-cflags=-I${spral}/include" + "--with-spral-lflags=-lspral" + ]; + + nativeBuildInputs = [ + pkg-config + gfortran + ]; + buildInputs = + [ + blas + lapack + ] ++ lib.optionals enableAMPL [ libamplsolver ] - ++ lib.optionals enableMUMPS [ mumps mpi ] + ++ lib.optionals enableMUMPS [ + mumps + mpi + ] ++ lib.optionals enableSPRAL [ spral ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/ip/ipp-usb/package.nix b/pkgs/by-name/ip/ipp-usb/package.nix index 0675f45aa0e46b..3de9d3454e284e 100644 --- a/pkgs/by-name/ip/ipp-usb/package.nix +++ b/pkgs/by-name/ip/ipp-usb/package.nix @@ -1,4 +1,12 @@ -{ buildGoModule, avahi, libusb1, pkg-config, lib, fetchFromGitHub, ronn }: +{ + buildGoModule, + avahi, + libusb1, + pkg-config, + lib, + fetchFromGitHub, + ronn, +}: buildGoModule rec { pname = "ipp-usb"; version = "0.9.28"; @@ -21,8 +29,14 @@ buildGoModule rec { done ''; - nativeBuildInputs = [ pkg-config ronn ]; - buildInputs = [ libusb1 avahi ]; + nativeBuildInputs = [ + pkg-config + ronn + ]; + buildInputs = [ + libusb1 + avahi + ]; vendorHash = null; diff --git a/pkgs/by-name/ip/iproute2/package.nix b/pkgs/by-name/ip/iproute2/package.nix index 923a5cc8b309be..1f33a1a5453892 100644 --- a/pkgs/by-name/ip/iproute2/package.nix +++ b/pkgs/by-name/ip/iproute2/package.nix @@ -1,7 +1,19 @@ -{ lib, stdenv, fetchurl, fetchpatch -, buildPackages, bison, flex, pkg-config -, db, iptables, elfutils, libmnl ,libbpf -, gitUpdater, pkgsStatic +{ + lib, + stdenv, + fetchurl, + fetchpatch, + buildPackages, + bison, + flex, + pkg-config, + db, + iptables, + elfutils, + libmnl, + libbpf, + gitUpdater, + pkgsStatic, }: stdenv.mkDerivation rec { @@ -41,24 +53,31 @@ stdenv.mkDerivation rec { --replace "CC := gcc" "CC ?= $CC" ''; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; configureFlags = [ - "--color" "auto" + "--color" + "auto" ]; - makeFlags = [ - "PREFIX=$(out)" - "SBINDIR=$(out)/sbin" - "DOCDIR=$(TMPDIR)/share/doc/${pname}" # Don't install docs - "HDRDIR=$(dev)/include/iproute2" - ] ++ lib.optionals stdenv.hostPlatform.isStatic [ - "SHARED_LIBS=n" - # all build .so plugins: - "TC_CONFIG_NO_XT=y" - ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ - "HOSTCC=$(CC_FOR_BUILD)" - ]; + makeFlags = + [ + "PREFIX=$(out)" + "SBINDIR=$(out)/sbin" + "DOCDIR=$(TMPDIR)/share/doc/${pname}" # Don't install docs + "HDRDIR=$(dev)/include/iproute2" + ] + ++ lib.optionals stdenv.hostPlatform.isStatic [ + "SHARED_LIBS=n" + # all build .so plugins: + "TC_CONFIG_NO_XT=y" + ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "HOSTCC=$(CC_FOR_BUILD)" + ]; buildFlags = [ "CONFDIR=/etc/iproute2" @@ -69,12 +88,22 @@ stdenv.mkDerivation rec { ]; depsBuildBuild = [ buildPackages.stdenv.cc ]; # netem requires $HOSTCC - nativeBuildInputs = [ bison flex pkg-config ]; - buildInputs = [ db iptables libmnl ] + nativeBuildInputs = [ + bison + flex + pkg-config + ]; + buildInputs = + [ + db + iptables + libmnl + ] # needed to uploaded bpf programs ++ lib.optionals (!stdenv.hostPlatform.isStatic) [ - elfutils libbpf - ]; + elfutils + libbpf + ]; enableParallelBuilding = true; @@ -91,6 +120,10 @@ stdenv.mkDerivation rec { description = "Collection of utilities for controlling TCP/IP networking and traffic control in Linux"; platforms = platforms.linux; license = licenses.gpl2Only; - maintainers = with maintainers; [ primeos fpletz globin ]; + maintainers = with maintainers; [ + primeos + fpletz + globin + ]; }; } diff --git a/pkgs/by-name/ip/iprover/package.nix b/pkgs/by-name/ip/iprover/package.nix index ad21323ec3e130..afcbae040bcccb 100644 --- a/pkgs/by-name/ip/iprover/package.nix +++ b/pkgs/by-name/ip/iprover/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitLab, ocamlPackages, eprover, z3, zlib }: +{ + lib, + stdenv, + fetchFromGitLab, + ocamlPackages, + eprover, + z3, + zlib, +}: stdenv.mkDerivation rec { pname = "iprover"; @@ -17,12 +25,23 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ eprover ] ++ (with ocamlPackages; [ - ocaml findlib - ]); - buildInputs = [ zlib ocamlPackages.z3 z3 ] ++ (with ocamlPackages; [ - ocamlgraph yojson zarith - ]); + nativeBuildInputs = + [ eprover ] + ++ (with ocamlPackages; [ + ocaml + findlib + ]); + buildInputs = + [ + zlib + ocamlPackages.z3 + z3 + ] + ++ (with ocamlPackages; [ + ocamlgraph + yojson + zarith + ]); preConfigure = "patchShebangs ."; @@ -39,7 +58,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Automated first-order logic theorem prover"; homepage = "http://www.cs.man.ac.uk/~korovink/iprover/"; - maintainers = with maintainers; [ raskin gebner ]; + maintainers = with maintainers; [ + raskin + gebner + ]; platforms = platforms.linux; license = licenses.gpl3; }; diff --git a/pkgs/by-name/ip/ipscan/package.nix b/pkgs/by-name/ip/ipscan/package.nix index 350f2525ffb691..47dd511afca937 100644 --- a/pkgs/by-name/ip/ipscan/package.nix +++ b/pkgs/by-name/ip/ipscan/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, jdk -, jre -, swt -, makeWrapper -, xorg -, dpkg -, gtk3 -, glib +{ + lib, + stdenv, + fetchurl, + jdk, + jre, + swt, + makeWrapper, + xorg, + dpkg, + gtk3, + glib, }: stdenv.mkDerivation rec { @@ -32,7 +33,14 @@ stdenv.mkDerivation rec { cp usr/lib/ipscan/ipscan-linux64-${version}.jar $out/share/${pname}-${version}.jar makeWrapper ${jre}/bin/java $out/bin/ipscan \ - --prefix LD_LIBRARY_PATH : "$out/lib/:${lib.makeLibraryPath [ swt xorg.libXtst gtk3 glib ]}" \ + --prefix LD_LIBRARY_PATH : "$out/lib/:${ + lib.makeLibraryPath [ + swt + xorg.libXtst + gtk3 + glib + ] + }" \ --add-flags "-Xmx256m -cp $out/share/${pname}-${version}.jar:${swt}/jars/swt.jar net.azib.ipscan.Main" mkdir -p $out/share/applications @@ -52,6 +60,9 @@ stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.gpl2Only; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ kylesferrazza totoroot ]; + maintainers = with maintainers; [ + kylesferrazza + totoroot + ]; }; } diff --git a/pkgs/by-name/ip/ipset/package.nix b/pkgs/by-name/ip/ipset/package.nix index 20a2b43143de51..4f1f4678863f50 100644 --- a/pkgs/by-name/ip/ipset/package.nix +++ b/pkgs/by-name/ip/ipset/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libmnl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libmnl, +}: stdenv.mkDerivation rec { pname = "ipset"; diff --git a/pkgs/by-name/ip/iptraf-ng/package.nix b/pkgs/by-name/ip/iptraf-ng/package.nix index 33f9a83dcded42..9984136a0676d4 100644 --- a/pkgs/by-name/ip/iptraf-ng/package.nix +++ b/pkgs/by-name/ip/iptraf-ng/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { version = "1.2.2"; diff --git a/pkgs/by-name/ip/iptsd/package.nix b/pkgs/by-name/ip/iptsd/package.nix index 98c901da126589..850fc4a0377872 100644 --- a/pkgs/by-name/ip/iptsd/package.nix +++ b/pkgs/by-name/ip/iptsd/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, meson -, ninja -, pkg-config -, cli11 -, eigen -, hidrd -, inih -, microsoft-gsl -, spdlog -, systemd +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + meson, + ninja, + pkg-config, + cli11, + eigen, + hidrd, + inih, + microsoft-gsl, + spdlog, + systemd, }: stdenv.mkDerivation rec { @@ -59,7 +60,7 @@ stdenv.mkDerivation rec { "-Dservice_manager=systemd" "-Dsample_config=false" "-Ddebug_tools=" - "-Db_lto=false" # plugin needed to handle lto object -> undefined reference to ... + "-Db_lto=false" # plugin needed to handle lto object -> undefined reference to ... ]; meta = with lib; { @@ -68,7 +69,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/linux-surface/iptsd"; license = licenses.gpl2Plus; mainProgram = "iptsd"; - maintainers = with maintainers; [ tomberek dotlambda ]; + maintainers = with maintainers; [ + tomberek + dotlambda + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/ip/iptstate/package.nix b/pkgs/by-name/ip/iptstate/package.nix index d1e193f831ca97..32352002aa8f78 100644 --- a/pkgs/by-name/ip/iptstate/package.nix +++ b/pkgs/by-name/ip/iptstate/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libnetfilter_conntrack, ncurses }: +{ + lib, + stdenv, + fetchurl, + libnetfilter_conntrack, + ncurses, +}: stdenv.mkDerivation rec { pname = "iptstate"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-iW3wYCiFRWomMfeV1jT8ITEeUF+MkQNI5jEoYPIJeVU="; }; - buildInputs = [ libnetfilter_conntrack ncurses ]; + buildInputs = [ + libnetfilter_conntrack + ncurses + ]; meta = with lib; { description = "Conntrack top like tool"; @@ -25,4 +34,3 @@ stdenv.mkDerivation rec { install -m755 -D iptstate $out/bin/iptstate ''; } - diff --git a/pkgs/by-name/ip/ipu6-camera-bins/package.nix b/pkgs/by-name/ip/ipu6-camera-bins/package.nix index 8ea3d96157a4d3..e7ad1ff71a15a1 100644 --- a/pkgs/by-name/ip/ipu6-camera-bins/package.nix +++ b/pkgs/by-name/ip/ipu6-camera-bins/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoPatchelfHook -, expat -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + autoPatchelfHook, + expat, + zlib, }: stdenv.mkDerivation (finalAttrs: rec { diff --git a/pkgs/by-name/ip/ipv6calc/package.nix b/pkgs/by-name/ip/ipv6calc/package.nix index 38bcd47f90f3ca..23ea837c1f48e2 100644 --- a/pkgs/by-name/ip/ipv6calc/package.nix +++ b/pkgs/by-name/ip/ipv6calc/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, getopt -, ip2location-c -, openssl -, perl -, libmaxminddb ? null -, geolite-legacy ? null +{ + lib, + stdenv, + fetchFromGitHub, + getopt, + ip2location-c, + openssl, + perl, + libmaxminddb ? null, + geolite-legacy ? null, }: stdenv.mkDerivation rec { @@ -36,21 +37,25 @@ stdenv.mkDerivation rec { done ''; - configureFlags = [ - "--prefix=${placeholder "out"}" - "--libdir=${placeholder "out"}/lib" - "--datadir=${placeholder "out"}/share" - "--disable-bundled-getopt" - "--disable-bundled-md5" - "--disable-dynamic-load" - "--enable-shared" - ] ++ lib.optionals (libmaxminddb != null) [ - "--enable-mmdb" - ] ++ lib.optionals (geolite-legacy != null) [ - "--with-geoip-db=${geolite-legacy}/share/GeoIP" - ] ++ lib.optionals (ip2location-c != null) [ - "--enable-ip2location" - ]; + configureFlags = + [ + "--prefix=${placeholder "out"}" + "--libdir=${placeholder "out"}/lib" + "--datadir=${placeholder "out"}/share" + "--disable-bundled-getopt" + "--disable-bundled-md5" + "--disable-dynamic-load" + "--enable-shared" + ] + ++ lib.optionals (libmaxminddb != null) [ + "--enable-mmdb" + ] + ++ lib.optionals (geolite-legacy != null) [ + "--with-geoip-db=${geolite-legacy}/share/GeoIP" + ] + ++ lib.optionals (ip2location-c != null) [ + "--enable-ip2location" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/ip/ipvsadm/package.nix b/pkgs/by-name/ip/ipvsadm/package.nix index c6447e9a9b5781..e73ecb554a2376 100644 --- a/pkgs/by-name/ip/ipvsadm/package.nix +++ b/pkgs/by-name/ip/ipvsadm/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, libnl, popt, gnugrep }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libnl, + popt, + gnugrep, +}: stdenv.mkDerivation rec { pname = "ipvsadm"; @@ -14,7 +22,10 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libnl popt ]; + buildInputs = [ + libnl + popt + ]; # Disable parallel build, errors: # *** No rule to make target 'libipvs/libipvs.a', needed by 'ipvsadm'. Stop. diff --git a/pkgs/by-name/iq/iqtree/package.nix b/pkgs/by-name/iq/iqtree/package.nix index ce6218449a7e86..67fb7b145025f8 100644 --- a/pkgs/by-name/iq/iqtree/package.nix +++ b/pkgs/by-name/iq/iqtree/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, boost -, eigen -, zlib -, llvmPackages +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + eigen, + zlib, + llvmPackages, }: stdenv.mkDerivation rec { @@ -22,13 +23,15 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ - boost - eigen - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - llvmPackages.openmp - ]; + buildInputs = + [ + boost + eigen + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + llvmPackages.openmp + ]; meta = with lib; { homepage = "http://www.iqtree.org/"; @@ -36,6 +39,9 @@ stdenv.mkDerivation rec { mainProgram = "iqtree2"; license = licenses.lgpl2; maintainers = with maintainers; [ bzizou ]; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; }; } diff --git a/pkgs/by-name/iq/iqueue/package.nix b/pkgs/by-name/iq/iqueue/package.nix index 7f5d5c4c069c59..4fa72e8eb80435 100644 --- a/pkgs/by-name/iq/iqueue/package.nix +++ b/pkgs/by-name/iq/iqueue/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, libbsd, microsoft-gsl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libbsd, + microsoft-gsl, +}: stdenv.mkDerivation rec { pname = "iqueue"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { doCheck = true; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libbsd microsoft-gsl ]; + buildInputs = [ + libbsd + microsoft-gsl + ]; env.NIX_CFLAGS_COMPILE = toString [ # Needed with GCC 12 diff --git a/pkgs/by-name/ir/ir-standard-fonts/package.nix b/pkgs/by-name/ir/ir-standard-fonts/package.nix index d59c111c96b739..884d875c9ce6b6 100644 --- a/pkgs/by-name/ir/ir-standard-fonts/package.nix +++ b/pkgs/by-name/ir/ir-standard-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "ir-standard-fonts"; diff --git a/pkgs/by-name/ir/irccat/package.nix b/pkgs/by-name/ir/irccat/package.nix index ce0ba4785ca701..e1851f473d1846 100644 --- a/pkgs/by-name/ir/irccat/package.nix +++ b/pkgs/by-name/ir/irccat/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "irccat"; diff --git a/pkgs/by-name/ir/irccloud/package.nix b/pkgs/by-name/ir/irccloud/package.nix index 4e41e1f865ecf5..0d0fc8598b2903 100644 --- a/pkgs/by-name/ir/irccloud/package.nix +++ b/pkgs/by-name/ir/irccloud/package.nix @@ -1,4 +1,8 @@ -{ appimageTools, fetchurl, lib }: +{ + appimageTools, + fetchurl, + lib, +}: let pname = "irccloud"; @@ -13,7 +17,8 @@ let inherit pname version src; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; extraPkgs = pkgs: [ pkgs.at-spi2-core ]; diff --git a/pkgs/by-name/ir/ircdHybrid/package.nix b/pkgs/by-name/ir/ircdHybrid/package.nix index c94dd2b9ff69ff..2b06203956f402 100644 --- a/pkgs/by-name/ir/ircdHybrid/package.nix +++ b/pkgs/by-name/ir/ircdHybrid/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, openssl, zlib, libxcrypt }: +{ + lib, + stdenv, + fetchurl, + openssl, + zlib, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "ircd-hybrid"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-lRrgMqsEqHtH5gIzngfg0Gtuh71aTrM087OVvhT3XkQ="; }; - buildInputs = [ openssl zlib libxcrypt ]; + buildInputs = [ + openssl + zlib + libxcrypt + ]; configureFlags = [ "--with-nicklen=100" diff --git a/pkgs/by-name/ir/ircdog/package.nix b/pkgs/by-name/ir/ircdog/package.nix index c2b1d5b2ee535d..6e01484a01e571 100644 --- a/pkgs/by-name/ir/ircdog/package.nix +++ b/pkgs/by-name/ir/ircdog/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -25,5 +26,3 @@ buildGoModule rec { maintainers = with maintainers; [ hexa ]; }; } - - diff --git a/pkgs/by-name/ir/iredis/package.nix b/pkgs/by-name/ir/iredis/package.nix index 7521bab9d9a8cd..ee9636a700e1fe 100644 --- a/pkgs/by-name/ir/iredis/package.nix +++ b/pkgs/by-name/ir/iredis/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, python3 -, fetchFromGitHub +{ + lib, + stdenv, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { @@ -44,18 +45,20 @@ python3.pkgs.buildPythonApplication rec { pytestCheckHook ]; - pytestFlagsArray = [ - # Fails on sandbox - "--ignore=tests/unittests/test_client.py" - "--deselect=tests/unittests/test_render_functions.py::test_render_unixtime_config_raw" - "--deselect=tests/unittests/test_render_functions.py::test_render_time" - # Only execute unittests, because cli tests require a running Redis - "tests/unittests/" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # Flaky tests - "--deselect=tests/unittests/test_entry.py::test_command_shell_options_higher_priority" - "--deselect=tests/unittests/test_utils.py::test_timer" - ]; + pytestFlagsArray = + [ + # Fails on sandbox + "--ignore=tests/unittests/test_client.py" + "--deselect=tests/unittests/test_render_functions.py::test_render_unixtime_config_raw" + "--deselect=tests/unittests/test_render_functions.py::test_render_time" + # Only execute unittests, because cli tests require a running Redis + "tests/unittests/" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # Flaky tests + "--deselect=tests/unittests/test_entry.py::test_command_shell_options_higher_priority" + "--deselect=tests/unittests/test_utils.py::test_timer" + ]; pythonImportsCheck = [ "iredis" ]; diff --git a/pkgs/by-name/ir/irker/package.nix b/pkgs/by-name/ir/irker/package.nix index a3b6874ef18141..3db135fe21ad54 100644 --- a/pkgs/by-name/ir/irker/package.nix +++ b/pkgs/by-name/ir/irker/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitLab, python3, pkg-config -, xmlto, docbook2x, docbook_xsl, docbook_xml_dtd_412 }: +{ + lib, + stdenv, + fetchFromGitLab, + python3, + pkg-config, + xmlto, + docbook2x, + docbook_xsl, + docbook_xml_dtd_412, +}: stdenv.mkDerivation { pname = "irker"; @@ -12,7 +21,13 @@ stdenv.mkDerivation { sha256 = "1hslwqa0gqsnl3l6hd5hxpn0wlachxd51infifhlwhyhd6iwgx8p"; }; - nativeBuildInputs = [ pkg-config xmlto docbook2x docbook_xsl docbook_xml_dtd_412 ]; + nativeBuildInputs = [ + pkg-config + xmlto + docbook2x + docbook_xsl + docbook_xml_dtd_412 + ]; buildInputs = [ python3 diff --git a/pkgs/by-name/ir/ironwail/package.nix b/pkgs/by-name/ir/ironwail/package.nix index 6d7ab328155aea..f9a6a13e8e6256 100644 --- a/pkgs/by-name/ir/ironwail/package.nix +++ b/pkgs/by-name/ir/ironwail/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, SDL2 -, fetchurl -, gzip -, libvorbis -, libmad -, flac -, libopus -, opusfile -, libogg -, curl -, libxmp -, mpg123 -, vulkan-headers -, vulkan-loader -, copyDesktopItems -, makeDesktopItem -, pkg-config +{ + lib, + stdenv, + SDL2, + fetchurl, + gzip, + libvorbis, + libmad, + flac, + libopus, + opusfile, + libogg, + curl, + libxmp, + mpg123, + vulkan-headers, + vulkan-loader, + copyDesktopItems, + makeDesktopItem, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ir/irpf/package.nix b/pkgs/by-name/ir/irpf/package.nix index c40ac4401ee6f8..e947cbb2739f22 100644 --- a/pkgs/by-name/ir/irpf/package.nix +++ b/pkgs/by-name/ir/irpf/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenvNoCC -, fetchzip -, copyDesktopItems -, jdk11 -, makeDesktopItem -, makeWrapper -, unzip -, xdg-utils -, writeScript +{ + lib, + stdenvNoCC, + fetchzip, + copyDesktopItems, + jdk11, + makeDesktopItem, + makeWrapper, + unzip, + xdg-utils, + writeScript, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -16,12 +17,14 @@ stdenvNoCC.mkDerivation (finalAttrs: { # https://www.gov.br/receitafederal/pt-br/centrais-de-conteudo/download/pgd/dirpf # Para outros sistemas operacionais -> Multi - src = let - year = lib.head (lib.splitVersion finalAttrs.version); - in fetchzip { - url = "https://downloadirpf.receita.fazenda.gov.br/irpf/${year}/irpf/arquivos/IRPF${finalAttrs.version}.zip"; - hash = "sha256-Pz8oI96GpLcHFEtnKUHnUHtZL3/QGhtG93ab5Au/tw0="; - }; + src = + let + year = lib.head (lib.splitVersion finalAttrs.version); + in + fetchzip { + url = "https://downloadirpf.receita.fazenda.gov.br/irpf/${year}/irpf/arquivos/IRPF${finalAttrs.version}.zip"; + hash = "sha256-Pz8oI96GpLcHFEtnKUHnUHtZL3/QGhtG93ab5Au/tw0="; + }; passthru.updateScript = writeScript "update-irpf" '' #!/usr/bin/env nix-shell @@ -33,7 +36,11 @@ stdenvNoCC.mkDerivation (finalAttrs: { update-source-version irpf "$version" ''; - nativeBuildInputs = [ unzip makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + unzip + makeWrapper + copyDesktopItems + ]; desktopItems = [ (makeDesktopItem { @@ -82,7 +89,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { license = licenses.unfree; platforms = platforms.all; sourceProvenance = with sourceTypes; [ binaryBytecode ]; - maintainers = with maintainers; [ atila bryanasdev000 ]; + maintainers = with maintainers; [ + atila + bryanasdev000 + ]; mainProgram = "irpf"; }; }) diff --git a/pkgs/by-name/ir/irqbalance/package.nix b/pkgs/by-name/ir/irqbalance/package.nix index 48e2774aaa96b0..5b97c722529031 100644 --- a/pkgs/by-name/ir/irqbalance/package.nix +++ b/pkgs/by-name/ir/irqbalance/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, glib, ncurses, libcap_ng }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + glib, + ncurses, + libcap_ng, +}: stdenv.mkDerivation rec { pname = "irqbalance"; @@ -11,20 +20,26 @@ stdenv.mkDerivation rec { sha256 = "sha256-7es7wwsPnDSF37uL5SCgAQB+u+qGWmWDHOh3JkHuXMs="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ glib ncurses libcap_ng ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + glib + ncurses + libcap_ng + ]; LDFLAGS = "-lncurses"; - postInstall = - '' - # Systemd service - mkdir -p $out/lib/systemd/system - grep -vi "EnvironmentFile" misc/irqbalance.service >$out/lib/systemd/system/irqbalance.service - substituteInPlace $out/lib/systemd/system/irqbalance.service \ - --replace /usr/sbin/irqbalance $out/bin/irqbalance \ - --replace ' $IRQBALANCE_ARGS' "" - ''; + postInstall = '' + # Systemd service + mkdir -p $out/lib/systemd/system + grep -vi "EnvironmentFile" misc/irqbalance.service >$out/lib/systemd/system/irqbalance.service + substituteInPlace $out/lib/systemd/system/irqbalance.service \ + --replace /usr/sbin/irqbalance $out/bin/irqbalance \ + --replace ' $IRQBALANCE_ARGS' "" + ''; meta = with lib; { homepage = "https://github.com/Irqbalance/irqbalance"; diff --git a/pkgs/by-name/is/isabelle/components/default.nix b/pkgs/by-name/is/isabelle/components/default.nix index dd7b605f56af0e..4bd6ff6c47dae2 100644 --- a/pkgs/by-name/is/isabelle/components/default.nix +++ b/pkgs/by-name/is/isabelle/components/default.nix @@ -1,5 +1,5 @@ { callPackage }: { - isabelle-linter = callPackage ./isabelle-linter.nix {}; + isabelle-linter = callPackage ./isabelle-linter.nix { }; } diff --git a/pkgs/by-name/is/isabelle/components/isabelle-linter.nix b/pkgs/by-name/is/isabelle/components/isabelle-linter.nix index bcf02c1489307a..61a484a7f54b54 100644 --- a/pkgs/by-name/is/isabelle/components/isabelle-linter.nix +++ b/pkgs/by-name/is/isabelle/components/isabelle-linter.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, isabelle }: +{ + stdenv, + lib, + fetchFromGitHub, + isabelle, +}: stdenv.mkDerivation rec { pname = "isabelle-linter"; diff --git a/pkgs/by-name/is/iscc/package.nix b/pkgs/by-name/is/iscc/package.nix index 03f231ca365c9b..cc402d9cbd4643 100644 --- a/pkgs/by-name/is/iscc/package.nix +++ b/pkgs/by-name/is/iscc/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, fetchurl -, innoextract -, runtimeShell -, wineWow64Packages -, lib +{ + stdenv, + fetchurl, + innoextract, + runtimeShell, + wineWow64Packages, + lib, }: let @@ -52,7 +53,6 @@ stdenv.mkDerivation rec { runHook postInstall ''; - meta = with lib; { description = "Compiler for Inno Setup, a tool for creating Windows installers"; homepage = "https://jrsoftware.org/isinfo.php"; diff --git a/pkgs/by-name/is/ised/package.nix b/pkgs/by-name/is/ised/package.nix index ae3308013c7b60..df8953f42f4663 100644 --- a/pkgs/by-name/is/ised/package.nix +++ b/pkgs/by-name/is/ised/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ised"; diff --git a/pkgs/by-name/is/iso-flags/package.nix b/pkgs/by-name/is/iso-flags/package.nix index 9deff6bcc77ec2..adb215e1e103ca 100644 --- a/pkgs/by-name/is/iso-flags/package.nix +++ b/pkgs/by-name/is/iso-flags/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenvNoCC -, fetchFromGitHub -, perl -, inkscape -, librsvg -, targets ? [ "all" ] +{ + lib, + stdenvNoCC, + fetchFromGitHub, + perl, + inkscape, + librsvg, + targets ? [ "all" ], }: stdenvNoCC.mkDerivation { @@ -21,7 +23,12 @@ stdenvNoCC.mkDerivation { perl inkscape librsvg - (perl.withPackages(pp: with pp; [ JSON XMLLibXML ])) + (perl.withPackages ( + pp: with pp; [ + JSON + XMLLibXML + ] + )) ]; postPatch = '' diff --git a/pkgs/by-name/is/isocodes/package.nix b/pkgs/by-name/is/isocodes/package.nix index 29b0bff5e0ad78..297f40d1b70c59 100644 --- a/pkgs/by-name/is/isocodes/package.nix +++ b/pkgs/by-name/is/isocodes/package.nix @@ -1,15 +1,27 @@ -{ lib, stdenv, fetchurl, gettext, python3, testers }: +{ + lib, + stdenv, + fetchurl, + gettext, + python3, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "iso-codes"; version = "4.17.0"; src = fetchurl { - url = with finalAttrs; "https://salsa.debian.org/iso-codes-team/iso-codes/-/archive/v${version}/${pname}-v${version}.tar.gz"; + url = + with finalAttrs; + "https://salsa.debian.org/iso-codes-team/iso-codes/-/archive/v${version}/${pname}-v${version}.tar.gz"; hash = "sha256-3VyhPbd+xt0cwl9cAYQpCocOwf7SRdjjmgT/NPWQdsM="; }; - nativeBuildInputs = [ gettext python3 ]; + nativeBuildInputs = [ + gettext + python3 + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/is/isolate/package.nix b/pkgs/by-name/is/isolate/package.nix index a1d67c49d531d6..18eef4c57a746a 100644 --- a/pkgs/by-name/is/isolate/package.nix +++ b/pkgs/by-name/is/isolate/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, asciidoc -, libcap -, pkg-config -, systemdLibs -, installShellFiles -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + asciidoc, + libcap, + pkg-config, + systemdLibs, + installShellFiles, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/is/isolyzer/package.nix b/pkgs/by-name/is/isolyzer/package.nix index 6f231430fa86fe..26b8ded3ca5f46 100644 --- a/pkgs/by-name/is/isolyzer/package.nix +++ b/pkgs/by-name/is/isolyzer/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { @@ -14,7 +15,10 @@ python3.pkgs.buildPythonApplication rec { sha256 = "sha256-NqkjnEwpaoyguG5GLscKS9UQGtF9N4jUL5JhrMtKCFE="; }; - propagatedBuildInputs = with python3.pkgs; [ setuptools six ]; + propagatedBuildInputs = with python3.pkgs; [ + setuptools + six + ]; meta = with lib; { homepage = "https://github.com/KBNLresearch/isolyzer"; diff --git a/pkgs/by-name/is/isomd5sum/package.nix b/pkgs/by-name/is/isomd5sum/package.nix index 62022066a6661c..3f7c2b28b9d6a0 100644 --- a/pkgs/by-name/is/isomd5sum/package.nix +++ b/pkgs/by-name/is/isomd5sum/package.nix @@ -1,6 +1,9 @@ -{ lib, stdenv, fetchFromGitHub -, python3 -, popt +{ + lib, + stdenv, + fetchFromGitHub, + python3, + popt, }: stdenv.mkDerivation rec { @@ -16,7 +19,7 @@ stdenv.mkDerivation rec { strictDeps = true; nativeBuildInputs = [ python3 ]; - buildInputs = [ popt ] ; + buildInputs = [ popt ]; postPatch = '' substituteInPlace Makefile --replace "#/usr/" "#" @@ -28,7 +31,10 @@ stdenv.mkDerivation rec { makeFlags = [ "DESTDIR=${placeholder "out"}" ]; # we don't install python stuff as it borks up directories - installTargets = [ "install-bin" "install-devel" ]; + installTargets = [ + "install-bin" + "install-devel" + ]; meta = with lib; { homepage = "https://github.com/rhinstaller/isomd5sum"; diff --git a/pkgs/by-name/is/ispell/package.nix b/pkgs/by-name/is/ispell/package.nix index 844f35612ff446..7826fc92929762 100644 --- a/pkgs/by-name/is/ispell/package.nix +++ b/pkgs/by-name/is/ispell/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, bison, ncurses }: +{ + lib, + stdenv, + fetchurl, + bison, + ncurses, +}: stdenv.mkDerivation rec { pname = "ispell"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-F8kWM9TIB1rMUDFjoWRj/FSrHHRTKArTnNPbdceD66Y="; }; - buildInputs = [ bison ncurses ]; + buildInputs = [ + bison + ncurses + ]; postPatch = '' cat >> local.h <=2.28 (fetchpatch { - name = "add_sysmacros.patch"; - url = "https://sources.debian.org/data/main/j/jfsutils/1.1.15-4/debian/patches/add_sysmacros.patch"; + name = "add_sysmacros.patch"; + url = "https://sources.debian.org/data/main/j/jfsutils/1.1.15-4/debian/patches/add_sysmacros.patch"; sha256 = "1qcwvxs4d0d24w5x98z59arqfx2n7f0d9xaqhjcg6w8n34vkhnyc"; }) # fix for musl diff --git a/pkgs/by-name/jf/jftui/package.nix b/pkgs/by-name/jf/jftui/package.nix index e30ba77dd87387..7dc6ae4690bc1a 100644 --- a/pkgs/by-name/jf/jftui/package.nix +++ b/pkgs/by-name/jf/jftui/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config -, curl -, mpv -, yajl +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + curl, + mpv, + yajl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/jg/jgmenu/package.nix b/pkgs/by-name/jg/jgmenu/package.nix index 55617ed4f651fa..cfb7dfa241ef6e 100644 --- a/pkgs/by-name/jg/jgmenu/package.nix +++ b/pkgs/by-name/jg/jgmenu/package.nix @@ -1,17 +1,19 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config -, python3Packages -, pango -, librsvg -, libxml2 -, menu-cache -, xorg -, makeWrapper -, enableXfcePanelApplet ? false -, xfce -, gtk3 -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + python3Packages, + pango, + librsvg, + libxml2, + menu-cache, + xorg, + makeWrapper, + enableXfcePanelApplet ? false, + xfce, + gtk3, + gitUpdater, }: stdenv.mkDerivation rec { @@ -31,25 +33,28 @@ stdenv.mkDerivation rec { python3Packages.wrapPython ]; - buildInputs = [ - pango - librsvg - libxml2 - menu-cache - xorg.libXinerama - xorg.libXrandr - python3Packages.python - ] ++ lib.optionals enableXfcePanelApplet [ - gtk3 - xfce.libxfce4util - xfce.xfce4-panel - ]; + buildInputs = + [ + pango + librsvg + libxml2 + menu-cache + xorg.libXinerama + xorg.libXrandr + python3Packages.python + ] + ++ lib.optionals enableXfcePanelApplet [ + gtk3 + xfce.libxfce4util + xfce.xfce4-panel + ]; - configureFlags = [ - ] - ++ lib.optionals enableXfcePanelApplet [ - "--with-xfce4-panel-applet" - ]; + configureFlags = + [ + ] + ++ lib.optionals enableXfcePanelApplet [ + "--with-xfce4-panel-applet" + ]; postFixup = '' wrapPythonProgramsIn "$out/lib/jgmenu" diff --git a/pkgs/by-name/jh/jhead/package.nix b/pkgs/by-name/jh/jhead/package.nix index 391780a4df350b..7e85789f4f210d 100644 --- a/pkgs/by-name/jh/jhead/package.nix +++ b/pkgs/by-name/jh/jhead/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libjpeg }: +{ + lib, + stdenv, + fetchFromGitHub, + libjpeg, +}: stdenv.mkDerivation rec { pname = "jhead"; @@ -13,7 +18,11 @@ stdenv.mkDerivation rec { buildInputs = [ libjpeg ]; - makeFlags = [ "CPPFLAGS=" "CFLAGS=-O3" "LDFLAGS=" ]; + makeFlags = [ + "CPPFLAGS=" + "CFLAGS=-O3" + "LDFLAGS=" + ]; doCheck = true; checkPhase = '' diff --git a/pkgs/by-name/jh/jhiccup/package.nix b/pkgs/by-name/jh/jhiccup/package.nix index 453455dcd118cf..82fed9e5d46de3 100644 --- a/pkgs/by-name/jh/jhiccup/package.nix +++ b/pkgs/by-name/jh/jhiccup/package.nix @@ -1,16 +1,20 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { pname = "jhiccup"; version = "2.0.10"; src = fetchzip { - url = "https://www.azul.com/files/jHiccup-${version}-dist.zip"; + url = "https://www.azul.com/files/jHiccup-${version}-dist.zip"; sha256 = "1hsvi8wjh615fnjf75h7b5afp04chqcgvini30vfcn3m9a5icbgy"; }; dontConfigure = true; - buildPhase = ":"; + buildPhase = ":"; installPhase = '' mkdir -p $out/bin $out/share/java cp *.jar $out/share/java @@ -28,10 +32,10 @@ stdenv.mkDerivation rec { meta = { description = "Measure JVM application stalls and GC pauses"; - homepage = "https://www.azul.com/jhiccup/"; + homepage = "https://www.azul.com/jhiccup/"; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; - license = lib.licenses.cc0; - platforms = lib.platforms.linux; + license = lib.licenses.cc0; + platforms = lib.platforms.linux; maintainers = with lib.maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/ji/jid/package.nix b/pkgs/by-name/ji/jid/package.nix index 036224f86dd0ee..f7af65b01f4201 100644 --- a/pkgs/by-name/ji/jid/package.nix +++ b/pkgs/by-name/ji/jid/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, jid }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + jid, +}: buildGoModule rec { pname = "jid"; @@ -18,7 +24,10 @@ buildGoModule rec { ./go-mod.patch ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests.version = testers.testVersion { package = jid; diff --git a/pkgs/by-name/ji/jigasi/package.nix b/pkgs/by-name/ji/jigasi/package.nix index cccf7c70ab3216..a0a0ca2b2fa75b 100644 --- a/pkgs/by-name/ji/jigasi/package.nix +++ b/pkgs/by-name/ji/jigasi/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, dpkg, jdk11, nixosTests }: +{ + lib, + stdenv, + fetchurl, + dpkg, + jdk11, + nixosTests, +}: let pname = "jigasi"; diff --git a/pkgs/by-name/ji/jigdo/package.nix b/pkgs/by-name/ji/jigdo/package.nix index 2bf1e193e5de67..aa0db0209160e6 100644 --- a/pkgs/by-name/ji/jigdo/package.nix +++ b/pkgs/by-name/ji/jigdo/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, gettext -, bzip2 -, db -, zlib +{ + lib, + stdenv, + fetchurl, + gettext, + bzip2, + db, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ji/jigmo/package.nix b/pkgs/by-name/ji/jigmo/package.nix index ef70e0d5d7bc14..000d0388a5b38f 100644 --- a/pkgs/by-name/ji/jigmo/package.nix +++ b/pkgs/by-name/ji/jigmo/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "jigmo"; diff --git a/pkgs/by-name/ji/jikespg/package.nix b/pkgs/by-name/ji/jikespg/package.nix index a6b64efb7fcf35..3651ebe3156790 100644 --- a/pkgs/by-name/ji/jikespg/package.nix +++ b/pkgs/by-name/ji/jikespg/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "jikespg"; diff --git a/pkgs/by-name/ji/jimtcl/package.nix b/pkgs/by-name/ji/jimtcl/package.nix index 2215fcaa06f379..13181a2c0e5c9b 100644 --- a/pkgs/by-name/ji/jimtcl/package.nix +++ b/pkgs/by-name/ji/jimtcl/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, -, asciidoc -, pkg-config -, inetutils -, tcl + asciidoc, + pkg-config, + inetutils, + tcl, -, sqlite -, readline -, SDL -, SDL_gfx -, openssl + sqlite, + readline, + SDL, + SDL_gfx, + openssl, -, SDLSupport ? true + SDLSupport ? true, }: stdenv.mkDerivation (finalAttrs: { @@ -33,14 +34,16 @@ stdenv.mkDerivation (finalAttrs: { tcl ]; - buildInputs = [ - sqlite - readline - openssl - ] ++ (lib.optionals SDLSupport [ - SDL - SDL_gfx - ]); + buildInputs = + [ + sqlite + readline + openssl + ] + ++ (lib.optionals SDLSupport [ + SDL + SDL_gfx + ]); configureFlags = [ "--shared" @@ -75,6 +78,9 @@ stdenv.mkDerivation (finalAttrs: { homepage = "http://jim.tcl.tk/"; license = lib.licenses.bsd2; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ dbohdan fgaz ]; + maintainers = with lib.maintainers; [ + dbohdan + fgaz + ]; }; }) diff --git a/pkgs/by-name/ji/jinja2-cli/package.nix b/pkgs/by-name/ji/jinja2-cli/package.nix index fb322d161e0038..2b1392b4ecde37 100644 --- a/pkgs/by-name/ji/jinja2-cli/package.nix +++ b/pkgs/by-name/ji/jinja2-cli/package.nix @@ -1,7 +1,14 @@ -{ lib -, python3 -, fetchFromGitHub -, extras ? [ "hjson" "json5" "toml" "xml" "yaml" ] +{ + lib, + python3, + fetchFromGitHub, + extras ? [ + "hjson" + "json5" + "toml" + "xml" + "yaml" + ], }: python3.pkgs.buildPythonApplication rec { @@ -25,9 +32,12 @@ python3.pkgs.buildPythonApplication rec { python3.pkgs.pytestCheckHook ]; - propagatedBuildInputs = with python3.pkgs; [ - jinja2 - ] ++ lib.attrVals extras optional-dependencies; + propagatedBuildInputs = + with python3.pkgs; + [ + jinja2 + ] + ++ lib.attrVals extras optional-dependencies; pythonImportsCheck = [ "jinja2cli" ]; diff --git a/pkgs/by-name/ji/jiq/package.nix b/pkgs/by-name/ji/jiq/package.nix index ed07a8d3c34472..4123eed5921262 100644 --- a/pkgs/by-name/ji/jiq/package.nix +++ b/pkgs/by-name/ji/jiq/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, jq, makeWrapper }: +{ + lib, + buildGoModule, + fetchFromGitHub, + jq, + makeWrapper, +}: buildGoModule rec { pname = "jiq"; diff --git a/pkgs/by-name/ji/jirafeau/package.nix b/pkgs/by-name/ji/jirafeau/package.nix index 96496ee83a641a..8b38fb6061894a 100644 --- a/pkgs/by-name/ji/jirafeau/package.nix +++ b/pkgs/by-name/ji/jirafeau/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitLab, writeText, nixosTests }: +{ + lib, + stdenv, + fetchFromGitLab, + writeText, + nixosTests, +}: let localConfig = writeText "config.local.php" '' = 8 (latest version by default) -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, stripJavaArchivesHook +{ + lib, + stdenv, + fetchFromGitHub, + ant, + jdk8, # the build script wants JAVA 8 for compilation + jre, # version can be >= 8 (latest version by default) + makeWrapper, + makeDesktopItem, + copyDesktopItems, + stripJavaArchivesHook, }: stdenv.mkDerivation (finalAttrs: { @@ -57,7 +58,10 @@ stdenv.mkDerivation (finalAttrs: { icon = "jpsxdec"; desktopName = "jPSXdec"; comment = finalAttrs.meta.description; - categories = [ "AudioVideo" "Utility" ]; + categories = [ + "AudioVideo" + "Utility" + ]; }) ]; diff --git a/pkgs/by-name/jq/jq/package.nix b/pkgs/by-name/jq/jq/package.nix index 515923f78421c3..900ba869f3525b 100644 --- a/pkgs/by-name/jq/jq/package.nix +++ b/pkgs/by-name/jq/jq/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, removeReferencesTo -, autoreconfHook -, bison -, onigurumaSupport ? true -, oniguruma +{ + lib, + stdenv, + fetchurl, + removeReferencesTo, + autoreconfHook, + bison, + onigurumaSupport ? true, + oniguruma, }: stdenv.mkDerivation rec { @@ -18,7 +19,13 @@ stdenv.mkDerivation rec { hash = "sha256-R4ycoSn9LjRD/icxS0VeIR4NjGC8j/ffcDhz3u7lgMI="; }; - outputs = [ "bin" "doc" "man" "dev" "out" ]; + outputs = [ + "bin" + "doc" + "man" + "dev" + "out" + ]; # https://github.com/jqlang/jq/issues/2871 postPatch = lib.optionalString stdenv.hostPlatform.isFreeBSD '' @@ -41,7 +48,11 @@ stdenv.mkDerivation rec { ''; buildInputs = lib.optionals onigurumaSupport [ oniguruma ]; - nativeBuildInputs = [ removeReferencesTo autoreconfHook bison ]; + nativeBuildInputs = [ + removeReferencesTo + autoreconfHook + bison + ]; # Darwin requires _REENTRANT be defined to use functions like `lgamma_r`. # Otherwise, configure will detect that they’re in libm, but the build will fail @@ -52,14 +63,16 @@ stdenv.mkDerivation rec { "-D_DARWIN_C_SOURCE=1" ]); - configureFlags = [ - "--bindir=\${bin}/bin" - "--sbindir=\${bin}/bin" - "--datadir=\${doc}/share" - "--mandir=\${man}/share/man" - ] ++ lib.optional (!onigurumaSupport) "--with-oniguruma=no" - # jq is linked to libjq: - ++ lib.optional (!stdenv.hostPlatform.isDarwin) "LDFLAGS=-Wl,-rpath,\\\${libdir}"; + configureFlags = + [ + "--bindir=\${bin}/bin" + "--sbindir=\${bin}/bin" + "--datadir=\${doc}/share" + "--mandir=\${man}/share/man" + ] + ++ lib.optional (!onigurumaSupport) "--with-oniguruma=no" + # jq is linked to libjq: + ++ lib.optional (!stdenv.hostPlatform.isDarwin) "LDFLAGS=-Wl,-rpath,\\\${libdir}"; # jq binary includes the whole `configureFlags` in: # https://github.com/jqlang/jq/commit/583e4a27188a2db097dd043dd203b9c106bba100 @@ -87,7 +100,11 @@ stdenv.mkDerivation rec { description = "Lightweight and flexible command-line JSON processor"; homepage = "https://jqlang.github.io/jq/"; license = licenses.mit; - maintainers = with maintainers; [ raskin artturin ncfavier ]; + maintainers = with maintainers; [ + raskin + artturin + ncfavier + ]; platforms = platforms.unix; downloadPage = "https://jqlang.github.io/jq/download/"; mainProgram = "jq"; diff --git a/pkgs/by-name/jq/jqp/package.nix b/pkgs/by-name/jq/jqp/package.nix index 22fee1b4ee98f9..eb4fe385a9cbfc 100644 --- a/pkgs/by-name/jq/jqp/package.nix +++ b/pkgs/by-name/jq/jqp/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/jq/jquake/package.nix b/pkgs/by-name/jq/jquake/package.nix index 916a12db315079..98058134a059f7 100644 --- a/pkgs/by-name/jq/jquake/package.nix +++ b/pkgs/by-name/jq/jquake/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchurl, copyDesktopItems, makeDesktopItem, unzip, jre8 -, logOutput ? false +{ + lib, + stdenv, + fetchurl, + copyDesktopItems, + makeDesktopItem, + unzip, + jre8, + logOutput ? false, }: stdenv.mkDerivation rec { @@ -11,14 +18,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-Q9R5Qhk8Qodw2d99nL2aG5WGpIyvKmjzfkRK7xJzoc0="; }; - nativeBuildInputs = [ unzip copyDesktopItems ]; + nativeBuildInputs = [ + unzip + copyDesktopItems + ]; sourceRoot = "."; postPatch = '' # JQuake emits a lot of debug-like messages on stdout. Either drop the output # stream entirely or log them at 'user.debug' level. - sed -i "/^java/ s/$/ ${if logOutput then "| logger -p user.debug" else "> \\/dev\\/null"}/" JQuake.sh + sed -i "/^java/ s/$/ ${ + if logOutput then "| logger -p user.debug" else "> \\/dev\\/null" + }/" JQuake.sh # By default, an 'errors.log' file is created in the current directory. # cd into a temporary directory and let it be created there. diff --git a/pkgs/by-name/jr/jrsonnet/package.nix b/pkgs/by-name/jr/jrsonnet/package.nix index 2031c006de6f98..a2db13c9b42fd8 100644 --- a/pkgs/by-name/jr/jrsonnet/package.nix +++ b/pkgs/by-name/jr/jrsonnet/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, installShellFiles, stdenv }: +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, +}: rustPlatform.buildRustPackage rec { pname = "jrsonnet"; @@ -25,22 +31,27 @@ rustPlatform.buildRustPackage rec { "--skip=tests::native_ext" ]; - postInstall = '' - ln -s $out/bin/jrsonnet $out/bin/jsonnet + postInstall = + '' + ln -s $out/bin/jrsonnet $out/bin/jsonnet - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - for shell in bash zsh fish; do - installShellCompletion --cmd jrsonnet \ - --$shell <($out/bin/jrsonnet --generate $shell /dev/null) - installShellCompletion --cmd jsonnet \ - --$shell <($out/bin/jrsonnet --generate $shell /dev/null | sed s/jrsonnet/jsonnet/g) - done - ''; + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + for shell in bash zsh fish; do + installShellCompletion --cmd jrsonnet \ + --$shell <($out/bin/jrsonnet --generate $shell /dev/null) + installShellCompletion --cmd jsonnet \ + --$shell <($out/bin/jrsonnet --generate $shell /dev/null | sed s/jrsonnet/jsonnet/g) + done + ''; meta = with lib; { description = "Purely-functional configuration language that helps you define JSON data"; homepage = "https://github.com/CertainLach/jrsonnet"; license = licenses.mit; - maintainers = with maintainers; [ figsoda lach ]; + maintainers = with maintainers; [ + figsoda + lach + ]; }; } diff --git a/pkgs/by-name/js/jscoverage/package.nix b/pkgs/by-name/js/jscoverage/package.nix index a082614aece365..6b0044a6ef8628 100644 --- a/pkgs/by-name/js/jscoverage/package.nix +++ b/pkgs/by-name/js/jscoverage/package.nix @@ -1,4 +1,11 @@ -{ fetchurl, perl, python3, lib, stdenv, zip }: +{ + fetchurl, + perl, + python3, + lib, + stdenv, + zip, +}: stdenv.mkDerivation rec { pname = "jscoverage"; @@ -13,7 +20,11 @@ stdenv.mkDerivation rec { ./jsfalse_to_null.patch ]; - nativeBuildInputs = [ perl python3 zip ]; + nativeBuildInputs = [ + perl + python3 + zip + ]; strictDeps = true; @@ -21,31 +32,31 @@ stdenv.mkDerivation rec { # issue. Maybe we could kick js/ (spidermonkey) completely and # instead use our spidermonkey via nix. preConfigure = '' - sed -i 's/^MOZ_FIX_LINK_PATHS=.*$/MOZ_FIX_LINK_PATHS=""/' ./js/configure + sed -i 's/^MOZ_FIX_LINK_PATHS=.*$/MOZ_FIX_LINK_PATHS=""/' ./js/configure ''; meta = { description = "Code coverage for JavaScript"; longDescription = '' - JSCoverage is a tool that measures code coverage for JavaScript - programs. - - Code coverage statistics show which lines of a program have been - executed (and which have been missed). This information is useful - for constructing comprehensive test suites (hence, it is often - called test coverage). - - JSCoverage works by instrumenting the JavaScript code used in web - pages. Code coverage statistics are collected while the - instrumented JavaScript code is executed in a web browser. - - JSCoverage supports the complete language syntax described in the - ECMAScript Language Specification (ECMA-262, 3rd - edition). JSCoverage works with any modern standards-compliant web - browser - including Internet Explorer (IE 6, 7, and 8), Firefox, - Opera, Safari, and Google Chrome - on Microsoft Windows and - GNU/Linux. + JSCoverage is a tool that measures code coverage for JavaScript + programs. + + Code coverage statistics show which lines of a program have been + executed (and which have been missed). This information is useful + for constructing comprehensive test suites (hence, it is often + called test coverage). + + JSCoverage works by instrumenting the JavaScript code used in web + pages. Code coverage statistics are collected while the + instrumented JavaScript code is executed in a web browser. + + JSCoverage supports the complete language syntax described in the + ECMAScript Language Specification (ECMA-262, 3rd + edition). JSCoverage works with any modern standards-compliant web + browser - including Internet Explorer (IE 6, 7, and 8), Firefox, + Opera, Safari, and Google Chrome - on Microsoft Windows and + GNU/Linux. ''; homepage = "http://siliconforks.com/jscoverage/"; diff --git a/pkgs/by-name/js/jsduck/gemset.nix b/pkgs/by-name/js/jsduck/gemset.nix index 493cc42f4f4e23..25a0fdf7289fd3 100644 --- a/pkgs/by-name/js/jsduck/gemset.nix +++ b/pkgs/by-name/js/jsduck/gemset.nix @@ -1,16 +1,22 @@ { dimensions = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pqb7yzjcpbgbyi196ifqbd1wy570cn12bkzcvpcha4xilhajja0"; type = "gem"; }; version = "1.2.0"; }; jsduck = { - dependencies = ["dimensions" "json" "parallel" "rdiscount" "rkelly-remix"]; + dependencies = [ + "dimensions" + "json" + "parallel" + "rdiscount" + "rkelly-remix" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hac7g9g6gg10bigbm8dskwwbv1dfch8ca353gh2bkwf244qq2xr"; type = "gem"; }; @@ -18,7 +24,7 @@ }; json = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qmj7fypgb9vag723w1a49qihxrcf5shzars106ynw2zk352gbv5"; type = "gem"; }; @@ -26,7 +32,7 @@ }; parallel = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kzz6ydg7r23ks2b7zbpx4vz3h186n19vhgnjcwi7xwd6h2f1fsq"; type = "gem"; }; @@ -34,7 +40,7 @@ }; rdiscount = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vcyy90r6wfg0b0y5wqp3d25bdyqjbwjhkm1xy9jkz9a7j72n70v"; type = "gem"; }; @@ -42,7 +48,7 @@ }; rkelly-remix = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g7hjl9nx7f953y7lncmfgp0xgxfxvgfm367q6da9niik6rp1y3j"; type = "gem"; }; diff --git a/pkgs/by-name/js/jsduck/package.nix b/pkgs/by-name/js/jsduck/package.nix index debd33c8074579..cbfba38ed8c961 100644 --- a/pkgs/by-name/js/jsduck/package.nix +++ b/pkgs/by-name/js/jsduck/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, bundlerEnv, makeWrapper, bundlerUpdateScript }: +{ + stdenv, + lib, + bundlerEnv, + makeWrapper, + bundlerUpdateScript, +}: stdenv.mkDerivation rec { pname = "jsduck"; @@ -26,9 +32,12 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Simple JavaScript Duckumentation generator"; mainProgram = "jsduck"; - homepage = "https://github.com/senchalabs/jsduck"; - license = with licenses; gpl3; - maintainers = with maintainers; [ periklis nicknovitski ]; - platforms = platforms.unix; + homepage = "https://github.com/senchalabs/jsduck"; + license = with licenses; gpl3; + maintainers = with maintainers; [ + periklis + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/js/jshon/package.nix b/pkgs/by-name/js/jshon/package.nix index 7e167aa729d273..db2b8c6574ab4d 100644 --- a/pkgs/by-name/js/jshon/package.nix +++ b/pkgs/by-name/js/jshon/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, jansson }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + jansson, +}: stdenv.mkDerivation rec { pname = "jshon"; @@ -23,15 +29,13 @@ stdenv.mkDerivation rec { }) ]; - postPatch = - '' - substituteInPlace Makefile --replace "/usr/" "/" - ''; + postPatch = '' + substituteInPlace Makefile --replace "/usr/" "/" + ''; - preInstall = - '' - export DESTDIR=$out - ''; + preInstall = '' + export DESTDIR=$out + ''; meta = with lib; { homepage = "http://kmkeen.com/jshon"; diff --git a/pkgs/by-name/js/jsluice/package.nix b/pkgs/by-name/js/jsluice/package.nix index 18a386c94b0d15..635004f8640e4d 100644 --- a/pkgs/by-name/js/jsluice/package.nix +++ b/pkgs/by-name/js/jsluice/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/js/json-fortran/package.nix b/pkgs/by-name/js/json-fortran/package.nix index c54965b386d98c..e9ee0cda1c667e 100644 --- a/pkgs/by-name/js/json-fortran/package.nix +++ b/pkgs/by-name/js/json-fortran/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, gfortran, cmake }: +{ + stdenv, + lib, + fetchFromGitHub, + gfortran, + cmake, +}: stdenv.mkDerivation rec { pname = "json-fortran"; diff --git a/pkgs/by-name/js/json-glib/package.nix b/pkgs/by-name/js/json-glib/package.nix index e3db856c23cdb8..ba38e333430d39 100644 --- a/pkgs/by-name/js/json-glib/package.nix +++ b/pkgs/by-name/js/json-glib/package.nix @@ -1,30 +1,36 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, docutils -, glib -, meson -, mesonEmulatorHook -, ninja -, nixosTests -, pkg-config -, gettext -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, buildPackages -, gobject-introspection -, gi-docgen -, libxslt -, fixDarwinDylibNames -, gnome +{ + lib, + stdenv, + fetchurl, + fetchpatch, + docutils, + glib, + meson, + mesonEmulatorHook, + ninja, + nixosTests, + pkg-config, + gettext, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + buildPackages, + gobject-introspection, + gi-docgen, + libxslt, + fixDarwinDylibNames, + gnome, }: stdenv.mkDerivation rec { pname = "json-glib"; version = "1.10.0"; - outputs = [ "out" "dev" "installedTests" ] - ++ lib.optional withIntrospection "devdoc"; + outputs = [ + "out" + "dev" + "installedTests" + ] ++ lib.optional withIntrospection "devdoc"; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -49,22 +55,26 @@ stdenv.mkDerivation rec { pkg-config ]; - nativeBuildInputs = [ - docutils # for rst2man, rst2html5 - meson - ninja - pkg-config - gettext - glib - libxslt - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ] ++ lib.optionals withIntrospection [ - gobject-introspection - gi-docgen - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + docutils # for rst2man, rst2html5 + meson + ninja + pkg-config + gettext + glib + libxslt + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + gi-docgen + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; propagatedBuildInputs = [ glib diff --git a/pkgs/by-name/js/json-plot/package.nix b/pkgs/by-name/js/json-plot/package.nix index b7d880ce42f22e..7b0f08c523adcf 100644 --- a/pkgs/by-name/js/json-plot/package.nix +++ b/pkgs/by-name/js/json-plot/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, buildGoModule +{ + lib, + fetchFromGitHub, + fetchpatch, + buildGoModule, }: buildGoModule rec { pname = "json-plot"; @@ -24,7 +25,10 @@ buildGoModule rec { }) ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Dead simple terminal plots from JSON (or CSV) data. Bar charts, line charts, scatter plots, histograms and heatmaps are supported"; diff --git a/pkgs/by-name/js/json2hcl/package.nix b/pkgs/by-name/js/json2hcl/package.nix index 7255736cd500c1..8c4883faa1ef14 100644 --- a/pkgs/by-name/js/json2hcl/package.nix +++ b/pkgs/by-name/js/json2hcl/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "json2hcl"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-GxYuFak+5CJyHgC1/RsS0ub84bgmgL+bI4YKFTb+vIY="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Convert JSON to HCL, and vice versa"; diff --git a/pkgs/by-name/js/json2tsv/package.nix b/pkgs/by-name/js/json2tsv/package.nix index 36d9d6edfa7509..9b49c3fd927c5c 100644 --- a/pkgs/by-name/js/json2tsv/package.nix +++ b/pkgs/by-name/js/json2tsv/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "json2tsv"; diff --git a/pkgs/by-name/js/json_c/package.nix b/pkgs/by-name/js/json_c/package.nix index 943712e2b8dbae..099231be501777 100644 --- a/pkgs/by-name/js/json_c/package.nix +++ b/pkgs/by-name/js/json_c/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -15,7 +16,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-R5KIJ0xVgGqffjzJaZvvvhAneJ+ZBuanyF6KYTTxb58="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/by-name/js/jsoncpp/package.nix b/pkgs/by-name/js/jsoncpp/package.nix index 4999fce4fdeaeb..0ca65befe5f892 100644 --- a/pkgs/by-name/js/jsoncpp/package.nix +++ b/pkgs/by-name/js/jsoncpp/package.nix @@ -1,18 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, python3 -, validatePkgConfig -, secureMemory ? false -, enableStatic ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, + validatePkgConfig, + secureMemory ? false, + enableStatic ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { pname = "jsoncpp"; version = "1.9.6"; - outputs = ["out" "dev"]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "open-source-parsers"; @@ -21,9 +25,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-3msc3B8NyF8PUlNaAHdUDfCpcUmz8JVW2X58USJ5HRw="; }; - /* During darwin bootstrap, we have a cp that doesn't understand the - * --reflink=auto flag, which is used in the default unpackPhase for dirs - */ + /* + During darwin bootstrap, we have a cp that doesn't understand the + --reflink=auto flag, which is used in the default unpackPhase for dirs + */ unpackPhase = '' cp -a ${src} ${src.name} chmod -R +w ${src.name} @@ -34,19 +39,26 @@ stdenv.mkDerivation rec { sed -i 's/#define JSONCPP_USING_SECURE_MEMORY 0/#define JSONCPP_USING_SECURE_MEMORY 1/' include/json/version.h ''; - nativeBuildInputs = [ cmake python3 validatePkgConfig ]; + nativeBuildInputs = [ + cmake + python3 + validatePkgConfig + ]; - cmakeFlags = [ - "-DBUILD_SHARED_LIBS=ON" - "-DBUILD_OBJECT_LIBS=OFF" - "-DJSONCPP_WITH_CMAKE_PACKAGE=ON" - "-DBUILD_STATIC_LIBS=${if enableStatic then "ON" else "OFF"}" - ] + cmakeFlags = + [ + "-DBUILD_SHARED_LIBS=ON" + "-DBUILD_OBJECT_LIBS=OFF" + "-DJSONCPP_WITH_CMAKE_PACKAGE=ON" + "-DBUILD_STATIC_LIBS=${if enableStatic then "ON" else "OFF"}" + ] # the test's won't compile if secureMemory is used because there is no # comparison operators and conversion functions between # std::basic_string<..., Json::SecureAllocator> vs. # std::basic_string<..., [default allocator]> - ++ lib.optional ((stdenv.buildPlatform != stdenv.hostPlatform) || secureMemory) "-DJSONCPP_WITH_TESTS=OFF"; + ++ lib.optional ( + (stdenv.buildPlatform != stdenv.hostPlatform) || secureMemory + ) "-DJSONCPP_WITH_TESTS=OFF"; meta = with lib; { homepage = "https://github.com/open-source-parsers/jsoncpp"; diff --git a/pkgs/by-name/js/jsonfmt/package.nix b/pkgs/by-name/js/jsonfmt/package.nix index e098c8feea8fae..79b34ac1dbd6bc 100644 --- a/pkgs/by-name/js/jsonfmt/package.nix +++ b/pkgs/by-name/js/jsonfmt/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, jsonfmt +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + jsonfmt, }: buildGoModule rec { diff --git a/pkgs/by-name/js/jsonnet-bundler/package.nix b/pkgs/by-name/js/jsonnet-bundler/package.nix index 3dedb2a41ac365..4750a17cd0cf13 100644 --- a/pkgs/by-name/js/jsonnet-bundler/package.nix +++ b/pkgs/by-name/js/jsonnet-bundler/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "jsonnet-bundler"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" "-X main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.Version=${version}" + ]; meta = with lib; { description = "Jsonnet package manager"; diff --git a/pkgs/by-name/js/jsonnet-language-server/package.nix b/pkgs/by-name/js/jsonnet-language-server/package.nix index 3e348c342ae4b9..f0408348426953 100644 --- a/pkgs/by-name/js/jsonnet-language-server/package.nix +++ b/pkgs/by-name/js/jsonnet-language-server/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/js/jsonnet/package.nix b/pkgs/by-name/js/jsonnet/package.nix index 4dc7557d137987..498cf26dadf296 100644 --- a/pkgs/by-name/js/jsonnet/package.nix +++ b/pkgs/by-name/js/jsonnet/package.nix @@ -1,9 +1,19 @@ -{ stdenv, lib, jekyll, cmake, fetchFromGitHub, gtest }: +{ + stdenv, + lib, + jekyll, + cmake, + fetchFromGitHub, + gtest, +}: stdenv.mkDerivation rec { pname = "jsonnet"; version = "0.20.0"; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; src = fetchFromGitHub { rev = "v${version}"; @@ -12,15 +22,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-FtVJE9alEl56Uik+nCpJMV5DMVVmRCnE1xMAiWdK39Y="; }; - nativeBuildInputs = [ jekyll cmake ]; + nativeBuildInputs = [ + jekyll + cmake + ]; buildInputs = [ gtest ]; - cmakeFlags = [ - "-DUSE_SYSTEM_GTEST=ON" - "-DBUILD_STATIC_LIBS=${if stdenv.hostPlatform.isStatic then "ON" else "OFF"}" - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - "-DBUILD_SHARED_BINARIES=${if stdenv.hostPlatform.isStatic then "OFF" else "ON"}" - ]; + cmakeFlags = + [ + "-DUSE_SYSTEM_GTEST=ON" + "-DBUILD_STATIC_LIBS=${if stdenv.hostPlatform.isStatic then "ON" else "OFF"}" + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + "-DBUILD_SHARED_BINARIES=${if stdenv.hostPlatform.isStatic then "OFF" else "ON"}" + ]; # https://github.com/google/jsonnet/issues/778 patches = [ @@ -42,7 +57,10 @@ stdenv.mkDerivation rec { meta = { description = "Purely-functional configuration language that helps you define JSON data"; - maintainers = with lib.maintainers; [ benley copumpkin ]; + maintainers = with lib.maintainers; [ + benley + copumpkin + ]; license = lib.licenses.asl20; homepage = "https://github.com/google/jsonnet"; platforms = lib.platforms.unix; diff --git a/pkgs/by-name/js/jsonrpc-glib/package.nix b/pkgs/by-name/js/jsonrpc-glib/package.nix index 8071fce57ef92d..19035f75f9aff7 100644 --- a/pkgs/by-name/js/jsonrpc-glib/package.nix +++ b/pkgs/by-name/js/jsonrpc-glib/package.nix @@ -1,22 +1,27 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, glib -, json-glib -, pkg-config -, gobject-introspection -, vala -, gi-docgen -, gnome +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + glib, + json-glib, + pkg-config, + gobject-introspection, + vala, + gi-docgen, + gnome, }: stdenv.mkDerivation rec { pname = "jsonrpc-glib"; version = "3.44.1"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/js/jsonschema/package.nix b/pkgs/by-name/js/jsonschema/package.nix index f962c14776b24f..3740cc4bccd684 100644 --- a/pkgs/by-name/js/jsonschema/package.nix +++ b/pkgs/by-name/js/jsonschema/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, }: buildGoModule rec { diff --git a/pkgs/by-name/js/jstest-gtk/package.nix b/pkgs/by-name/js/jstest-gtk/package.nix index 8fb45330e124de..5108dd18c834df 100644 --- a/pkgs/by-name/js/jstest-gtk/package.nix +++ b/pkgs/by-name/js/jstest-gtk/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchFromGitLab, cmake, pkg-config, gtkmm3, libsigcxx, xorg }: +{ + stdenv, + lib, + fetchFromGitLab, + cmake, + pkg-config, + gtkmm3, + libsigcxx, + xorg, +}: stdenv.mkDerivation rec { pname = "jstest-gtk"; @@ -11,8 +20,15 @@ stdenv.mkDerivation rec { sha256 = "0icbbhrj5aqljhiavdy3hic60vp0zzfzyg0d6vpjaqkbzd5pv9d8"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ gtkmm3 libsigcxx xorg.libX11 ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + gtkmm3 + libsigcxx + xorg.libX11 + ]; meta = with lib; { description = "Simple joystick tester based on Gtk+"; diff --git a/pkgs/by-name/js/jsubfinder/package.nix b/pkgs/by-name/js/jsubfinder/package.nix index c989c352ea053a..e4664bd4b0a535 100644 --- a/pkgs/by-name/js/jsubfinder/package.nix +++ b/pkgs/by-name/js/jsubfinder/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/js/jsvc/package.nix b/pkgs/by-name/js/jsvc/package.nix index 2d01daabd01b3c..5bc6ae6335b978 100644 --- a/pkgs/by-name/js/jsvc/package.nix +++ b/pkgs/by-name/js/jsvc/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, commonsDaemon, jdk, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + commonsDaemon, + jdk, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "jsvc"; @@ -10,7 +18,10 @@ stdenv.mkDerivation rec { }; buildInputs = [ commonsDaemon ]; - nativeBuildInputs = [ jdk makeWrapper ]; + nativeBuildInputs = [ + jdk + makeWrapper + ]; preConfigure = '' cd ./src/native/unix/ @@ -31,10 +42,10 @@ stdenv.mkDerivation rec { ''; meta = { - homepage = "https://commons.apache.org/proper/commons-daemon"; + homepage = "https://commons.apache.org/proper/commons-daemon"; description = "Part of the Apache Commons Daemon software, a set of utilities and Java support classes for running Java applications as server processes"; maintainers = with lib.maintainers; [ rsynnest ]; - license = lib.licenses.asl20; + license = lib.licenses.asl20; platforms = with lib.platforms; unix; mainProgram = "jsvc"; }; diff --git a/pkgs/by-name/jt/jtag-remote-server/package.nix b/pkgs/by-name/jt/jtag-remote-server/package.nix index 7f29d1bfbeb92d..62ec3bea30334b 100644 --- a/pkgs/by-name/jt/jtag-remote-server/package.nix +++ b/pkgs/by-name/jt/jtag-remote-server/package.nix @@ -1,4 +1,11 @@ -{ stdenv, fetchFromGitHub, lib, cmake, pkg-config, libftdi1 }: +{ + stdenv, + fetchFromGitHub, + lib, + cmake, + pkg-config, + libftdi1, +}: stdenv.mkDerivation rec { pname = "jtag-remote-server"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-qtgO0BO2hvWi/E2RzGTTuQynKbh7/OLeoLcm60dqro8="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libftdi1 ]; meta = with lib; { diff --git a/pkgs/by-name/jt/jtc/package.nix b/pkgs/by-name/jt/jtc/package.nix index f368a460463d7b..5820a21e5e93ae 100644 --- a/pkgs/by-name/jt/jtc/package.nix +++ b/pkgs/by-name/jt/jtc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "jtc"; diff --git a/pkgs/by-name/jt/jtdx/package.nix b/pkgs/by-name/jt/jtdx/package.nix index 09f88ddf0f5c46..018ed5d53c057e 100644 --- a/pkgs/by-name/jt/jtdx/package.nix +++ b/pkgs/by-name/jt/jtdx/package.nix @@ -1,4 +1,9 @@ -{ wsjtx, fetchgit, qt5, lib }: +{ + wsjtx, + fetchgit, + qt5, + lib, +}: wsjtx.overrideAttrs (old: { pname = "jtdx"; version = "unstable-2022-03-01"; @@ -10,7 +15,11 @@ wsjtx.overrideAttrs (old: { buildInputs = old.buildInputs ++ [ qt5.qtwebsockets ]; meta = { description = "wsjtx fork with some extra features"; - maintainers = with lib.maintainers; [ matthewcroughan sarcasticadmin pkharvey ]; + maintainers = with lib.maintainers; [ + matthewcroughan + sarcasticadmin + pkharvey + ]; homepage = "https://github.com/jtdx-project/jtdx"; }; }) diff --git a/pkgs/by-name/ju/judy/package.nix b/pkgs/by-name/ju/judy/package.nix index 618aee4984669c..8d2918cc5a539f 100644 --- a/pkgs/by-name/ju/judy/package.nix +++ b/pkgs/by-name/ju/judy/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkgsBuildBuild, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + pkgsBuildBuild, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "judy"; diff --git a/pkgs/by-name/ju/jugglinglab/package.nix b/pkgs/by-name/ju/jugglinglab/package.nix index f8f7a3fb37fdf5..a391cac9205b88 100644 --- a/pkgs/by-name/ju/jugglinglab/package.nix +++ b/pkgs/by-name/ju/jugglinglab/package.nix @@ -1,19 +1,22 @@ -{ lib -, stdenv -, maven -, fetchFromGitHub -, makeWrapper -, wrapGAppsHook3 -, jre +{ + lib, + stdenv, + maven, + fetchFromGitHub, + makeWrapper, + wrapGAppsHook3, + jre, }: let - platformName = { - "x86_64-linux" = "linux-x86-64"; - "aarch64-linux" = "linux-aarch64"; - "x86_64-darwin" = "darwin-x86-64"; - "aarch64-darwin" = "darwin-aarch64"; - }.${stdenv.system} or null; + platformName = + { + "x86_64-linux" = "linux-x86-64"; + "aarch64-linux" = "linux-aarch64"; + "x86_64-darwin" = "darwin-x86-64"; + "aarch64-darwin" = "darwin-aarch64"; + } + .${stdenv.system} or null; in maven.buildMavenPackage rec { pname = "jugglinglab"; @@ -67,7 +70,10 @@ maven.buildMavenPackage rec { homepage = "https://jugglinglab.org/"; license = licenses.gpl2Only; mainProgram = "jugglinglab"; - maintainers = with maintainers; [ wnklmnn tomasajt ]; + maintainers = with maintainers; [ + wnklmnn + tomasajt + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/ju/juju/package.nix b/pkgs/by-name/ju/juju/package.nix index e570976e5c0c9e..5a0981cbd09b26 100644 --- a/pkgs/by-name/ju/juju/package.nix +++ b/pkgs/by-name/ju/juju/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, buildGoModule, installShellFiles, testers, juju }: +{ + lib, + fetchFromGitHub, + buildGoModule, + installShellFiles, + testers, + juju, +}: buildGoModule rec { pname = "juju"; diff --git a/pkgs/by-name/ju/jujuutils/package.nix b/pkgs/by-name/ju/jujuutils/package.nix index 8c5dabf66a900c..7cfb5340415d3c 100644 --- a/pkgs/by-name/ju/jujuutils/package.nix +++ b/pkgs/by-name/ju/jujuutils/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, linuxHeaders }: +{ + lib, + stdenv, + fetchurl, + linuxHeaders, +}: stdenv.mkDerivation rec { pname = "jujuutils"; diff --git a/pkgs/by-name/ju/julia-mono/package.nix b/pkgs/by-name/ju/julia-mono/package.nix index 132d0b87a24796..c465e2a48ea4ff 100644 --- a/pkgs/by-name/ju/julia-mono/package.nix +++ b/pkgs/by-name/ju/julia-mono/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "JuliaMono-ttf"; diff --git a/pkgs/by-name/ju/julius/package.nix b/pkgs/by-name/ju/julius/package.nix index 6c85b45b0e102f..429d34420baad2 100644 --- a/pkgs/by-name/ju/julius/package.nix +++ b/pkgs/by-name/ju/julius/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL2 -, SDL2_mixer -, cmake -, libpng -, darwin -, apple-sdk_11 -, libicns -, imagemagick +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + SDL2_mixer, + cmake, + libpng, + darwin, + apple-sdk_11, + libicns, + imagemagick, }: stdenv.mkDerivation rec { pname = "julius"; @@ -27,13 +28,15 @@ stdenv.mkDerivation rec { ./darwin-fixes.patch ]; - nativeBuildInputs = [ - cmake - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.sigtool - libicns - imagemagick - ]; + nativeBuildInputs = + [ + cmake + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.sigtool + libicns + imagemagick + ]; buildInputs = [ SDL2 @@ -53,7 +56,10 @@ stdenv.mkDerivation rec { description = "Open source re-implementation of Caesar III"; mainProgram = "julius"; license = licenses.agpl3Only; - maintainers = with maintainers; [ Thra11 matteopacini ]; + maintainers = with maintainers; [ + Thra11 + matteopacini + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/ju/jumanpp/package.nix b/pkgs/by-name/ju/jumanpp/package.nix index 5dff6f6f48afa5..6f0ca2599757a2 100644 --- a/pkgs/by-name/ju/jumanpp/package.nix +++ b/pkgs/by-name/ju/jumanpp/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchpatch, cmake, protobuf, libiconv }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + cmake, + protobuf, + libiconv, +}: stdenv.mkDerivation rec { pname = "jumanpp"; @@ -31,8 +39,7 @@ stdenv.mkDerivation rec { cmakeFlags = [ "-DJPP_ENABLE_TESTS=OFF" ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ protobuf ] - ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; + buildInputs = [ protobuf ] ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; meta = with lib; { description = "Japanese morphological analyser using a recurrent neural network language model (RNNLM)"; diff --git a/pkgs/by-name/ju/jump/package.nix b/pkgs/by-name/ju/jump/package.nix index c16d1e738226f2..02b97d03a839e7 100644 --- a/pkgs/by-name/ju/jump/package.nix +++ b/pkgs/by-name/ju/jump/package.nix @@ -1,4 +1,9 @@ -{ buildGoModule, fetchFromGitHub, lib, installShellFiles }: +{ + buildGoModule, + fetchFromGitHub, + lib, + installShellFiles, +}: buildGoModule rec { pname = "jump"; @@ -15,7 +20,10 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' installManPage man/j.1 man/jump.1 diff --git a/pkgs/by-name/ju/jumpapp/package.nix b/pkgs/by-name/ju/jumpapp/package.nix index 5d7bfb635ef589..fd6a3b8c727674 100644 --- a/pkgs/by-name/ju/jumpapp/package.nix +++ b/pkgs/by-name/ju/jumpapp/package.nix @@ -1,4 +1,14 @@ -{ stdenv, lib, perl, pandoc, fetchFromGitHub, xdotool, wmctrl, xprop, nettools }: +{ + stdenv, + lib, + perl, + pandoc, + fetchFromGitHub, + xdotool, + wmctrl, + xprop, + nettools, +}: stdenv.mkDerivation rec { pname = "jumpapp"; @@ -12,15 +22,25 @@ stdenv.mkDerivation rec { }; makeFlags = [ "PREFIX=$(out)" ]; - nativeBuildInputs = [ pandoc perl ]; - buildInputs = [ xdotool wmctrl xprop nettools perl ]; - postFixup = let - runtimePath = lib.makeBinPath buildInputs; - in - '' - sed -i "2 i export PATH=${runtimePath}:\$PATH" $out/bin/jumpapp - sed -i "2 i export PATH=${perl}/bin:\$PATH" $out/bin/jumpappify-desktop-entry - ''; + nativeBuildInputs = [ + pandoc + perl + ]; + buildInputs = [ + xdotool + wmctrl + xprop + nettools + perl + ]; + postFixup = + let + runtimePath = lib.makeBinPath buildInputs; + in + '' + sed -i "2 i export PATH=${runtimePath}:\$PATH" $out/bin/jumpapp + sed -i "2 i export PATH=${perl}/bin:\$PATH" $out/bin/jumpappify-desktop-entry + ''; meta = { homepage = "https://github.com/mkropat/jumpapp"; diff --git a/pkgs/by-name/ju/jumpnbump/package.nix b/pkgs/by-name/ju/jumpnbump/package.nix index b2f6a646c65f35..9272fe41c5e8fc 100644 --- a/pkgs/by-name/ju/jumpnbump/package.nix +++ b/pkgs/by-name/ju/jumpnbump/package.nix @@ -1,16 +1,23 @@ -{ lib, stdenv -, fetchFromGitLab -, fetchzip -, SDL2, SDL2_mixer, SDL2_net -, gtk3, gobject-introspection -, python3Packages -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitLab, + fetchzip, + SDL2, + SDL2_mixer, + SDL2_net, + gtk3, + gobject-introspection, + python3Packages, + wrapGAppsHook3, }: -let data = fetchzip { - url = "https://mirandir.pagesperso-orange.fr/files/additional-levels.tar.xz"; - sha256 = "167hisscsbldrwrs54gq6446shl8h26qdqigmfg0lq3daynqycg2"; -}; in +let + data = fetchzip { + url = "https://mirandir.pagesperso-orange.fr/files/additional-levels.tar.xz"; + sha256 = "167hisscsbldrwrs54gq6446shl8h26qdqigmfg0lq3daynqycg2"; + }; +in stdenv.mkDerivation rec { pname = "jumpnbump"; @@ -27,8 +34,17 @@ stdenv.mkDerivation rec { makeFlags = [ "PREFIX=$(out)" ]; - nativeBuildInputs = [ python3Packages.wrapPython wrapGAppsHook3 gobject-introspection ]; - buildInputs = [ SDL2 SDL2_mixer SDL2_net gtk3 ]; + nativeBuildInputs = [ + python3Packages.wrapPython + wrapGAppsHook3 + gobject-introspection + ]; + buildInputs = [ + SDL2 + SDL2_mixer + SDL2_net + gtk3 + ]; postInstall = '' make -C menu PREFIX=$out all install @@ -37,7 +53,10 @@ stdenv.mkDerivation rec { sed -ie 's+Exec=jumpnbump+Exec=jumpnbump-menu+' $out/share/applications/jumpnbump.desktop ''; - pythonPath = with python3Packages; [ pygobject3 pillow ]; + pythonPath = with python3Packages; [ + pygobject3 + pillow + ]; preFixup = '' buildPythonPath "$out $pythonPath" ''; @@ -47,9 +66,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "cute, true multiplayer platform game with bunnies"; - homepage = "https://libregames.gitlab.io/jumpnbump/"; - license = licenses.gpl2Plus; + homepage = "https://libregames.gitlab.io/jumpnbump/"; + license = licenses.gpl2Plus; maintainers = with maintainers; [ iblech ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ju/jumppad/package.nix b/pkgs/by-name/ju/jumppad/package.nix index 837d0156018eab..40eb38f2fa470d 100644 --- a/pkgs/by-name/ju/jumppad/package.nix +++ b/pkgs/by-name/ju/jumppad/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "jumppad"; diff --git a/pkgs/by-name/ju/jumpy/package.nix b/pkgs/by-name/ju/jumpy/package.nix index 7040aa4e34019c..cabd27fddbca0e 100644 --- a/pkgs/by-name/ju/jumpy/package.nix +++ b/pkgs/by-name/ju/jumpy/package.nix @@ -1,17 +1,18 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, makeWrapper -, pkg-config -, zstd -, stdenv -, alsa-lib -, libxkbcommon -, udev -, vulkan-loader -, wayland -, xorg -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + makeWrapper, + pkg-config, + zstd, + stdenv, + alsa-lib, + libxkbcommon, + udev, + vulkan-loader, + wayland, + xorg, + darwin, }: rustPlatform.buildRustPackage rec { @@ -39,24 +40,30 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - zstd - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - libxkbcommon - udev - vulkan-loader - wayland - xorg.libX11 - xorg.libXcursor - xorg.libXi - xorg.libXrandr - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk_11_0.frameworks.Cocoa - rustPlatform.bindgenHook - ]; + buildInputs = + [ + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + libxkbcommon + udev + vulkan-loader + wayland + xorg.libX11 + xorg.libXcursor + xorg.libXi + xorg.libXrandr + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk_11_0.frameworks.Cocoa + rustPlatform.bindgenHook + ]; - cargoBuildFlags = [ "--bin" "jumpy" ]; + cargoBuildFlags = [ + "--bin" + "jumpy" + ]; env = { ZSTD_SYS_USE_PKG_CONFIG = true; @@ -80,7 +87,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "jumpy"; homepage = "https://fishfight.org/"; changelog = "https://github.com/fishfolk/jumpy/releases/tag/v${version}"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ju/junction-font/package.nix b/pkgs/by-name/ju/junction-font/package.nix index ea6d8b4576594a..33932a2a180e4e 100644 --- a/pkgs/by-name/ju/junction-font/package.nix +++ b/pkgs/by-name/ju/junction-font/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, +}: stdenvNoCC.mkDerivation { pname = "junction"; diff --git a/pkgs/by-name/ju/junction/package.nix b/pkgs/by-name/ju/junction/package.nix index cf03a315b2cfa2..98afa534c6a65b 100644 --- a/pkgs/by-name/ju/junction/package.nix +++ b/pkgs/by-name/ju/junction/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, appstream-glib -, blueprint-compiler -, desktop-file-utils -, gobject-introspection -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, gjs -, gtk4 -, libadwaita -, libportal-gtk4 +{ + lib, + stdenv, + fetchFromGitHub, + appstream-glib, + blueprint-compiler, + desktop-file-utils, + gobject-introspection, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + gjs, + gtk4, + libadwaita, + libportal-gtk4, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ju/junest/package.nix b/pkgs/by-name/ju/junest/package.nix index 4f2d89f9f6a00d..60f25062bf7144 100644 --- a/pkgs/by-name/ju/junest/package.nix +++ b/pkgs/by-name/ju/junest/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, stdenvNoCC, wget }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, + wget, +}: stdenvNoCC.mkDerivation rec { pname = "junest"; @@ -36,4 +41,3 @@ stdenvNoCC.mkDerivation rec { platforms = lib.platforms.linux; }; } - diff --git a/pkgs/by-name/ju/junicode/package.nix b/pkgs/by-name/ju/junicode/package.nix index 5d88b2c0aed6da..77ef17a6fcdcaf 100644 --- a/pkgs/by-name/ju/junicode/package.nix +++ b/pkgs/by-name/ju/junicode/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenvNoCC, fetchzip, texlive, callPackage }: +{ + lib, + stdenvNoCC, + fetchzip, + texlive, + callPackage, +}: stdenvNoCC.mkDerivation rec { pname = "junicode"; @@ -9,7 +15,11 @@ stdenvNoCC.mkDerivation rec { hash = "sha256-hdCDLwTiyE2ZpFgmYAX7YWCujUwozIozD+k/lCStJUg="; }; - outputs = [ "out" "doc" "tex" ]; + outputs = [ + "out" + "doc" + "tex" + ]; patches = [ ./tex-font-path.patch ]; @@ -37,7 +47,10 @@ stdenvNoCC.mkDerivation rec { ''; passthru = { - tlDeps = with texlive; [ xkeyval fontspec ]; + tlDeps = with texlive; [ + xkeyval + fontspec + ]; tests = callPackage ./tests.nix { }; }; diff --git a/pkgs/by-name/ju/junicode/tests.nix b/pkgs/by-name/ju/junicode/tests.nix index 831e60796d12fe..80cd28ec99d5a0 100644 --- a/pkgs/by-name/ju/junicode/tests.nix +++ b/pkgs/by-name/ju/junicode/tests.nix @@ -1,29 +1,49 @@ -{ lib, runCommand, junicode, texliveBasic }: +{ + lib, + runCommand, + junicode, + texliveBasic, +}: let - texliveWithJunicode = texliveBasic.withPackages (p: [ p.xetex junicode ]); + texliveWithJunicode = texliveBasic.withPackages (p: [ + p.xetex + junicode + ]); - texTest = { package, tex, fonttype, file }: + texTest = + { + package, + tex, + fonttype, + file, + }: lib.attrsets.nameValuePair "${package}-${tex}-${fonttype}" ( runCommand "${package}-test-${tex}-${fonttype}.pdf" { nativeBuildInputs = [ texliveWithJunicode ]; inherit tex fonttype file; - } '' - substituteAll $file test.tex - HOME=$PWD $tex test.tex - cp test.pdf $out - ''); + } + '' + substituteAll $file test.tex + HOME=$PWD $tex test.tex + cp test.pdf $out + '' + ); in builtins.listToAttrs ( - lib.mapCartesianProduct texTest - { - tex = [ "xelatex" "lualatex" ]; - fonttype = [ "ttf" "otf" ]; - package = [ "junicode" ]; - file = [ ./test.tex ]; - } - ++ - [ + lib.mapCartesianProduct texTest { + tex = [ + "xelatex" + "lualatex" + ]; + fonttype = [ + "ttf" + "otf" + ]; + package = [ "junicode" ]; + file = [ ./test.tex ]; + } + ++ [ (texTest { package = "junicodevf"; fonttype = "ttf"; diff --git a/pkgs/by-name/ju/junkie/package.nix b/pkgs/by-name/ju/junkie/package.nix index ac20577b5f358a..40a80f4dad30de 100644 --- a/pkgs/by-name/ju/junkie/package.nix +++ b/pkgs/by-name/ju/junkie/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, pkg-config, libpcap, guile_2_2, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + libpcap, + guile_2_2, + openssl, +}: stdenv.mkDerivation rec { pname = "junkie"; @@ -25,8 +35,15 @@ stdenv.mkDerivation rec { sed -i '10i#undef IP_DONTFRAG' include/junkie/proto/ip.h ''; - buildInputs = [ libpcap guile_2_2 openssl ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + buildInputs = [ + libpcap + guile_2_2 + openssl + ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; configureFlags = [ "GUILELIBDIR=\${out}/${guile_2_2.siteDir}" "GUILECACHEDIR=\${out}/${guile_2_2.siteCcacheDir}" diff --git a/pkgs/by-name/ju/juno-theme/package.nix b/pkgs/by-name/ju/juno-theme/package.nix index 9e1580a6a14df6..ffbb0524b92105 100644 --- a/pkgs/by-name/ju/juno-theme/package.nix +++ b/pkgs/by-name/ju/juno-theme/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchurl, + gtk-engine-murrine, +}: stdenv.mkDerivation rec { pname = "juno"; diff --git a/pkgs/by-name/ju/jupp/package.nix b/pkgs/by-name/ju/jupp/package.nix index 72e82da61ddadd..7ef4c878658eb9 100644 --- a/pkgs/by-name/ju/jupp/package.nix +++ b/pkgs/by-name/ju/jupp/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, ncurses -, gpm +{ + lib, + stdenv, + fetchurl, + ncurses, + gpm, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ju/just/package.nix b/pkgs/by-name/ju/just/package.nix index 8a501f1e6c6093..bd2ab0edcc81ca 100644 --- a/pkgs/by-name/ju/just/package.nix +++ b/pkgs/by-name/ju/just/package.nix @@ -1,19 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, bashInteractive -, coreutils -, installShellFiles -, libiconv -, mdbook -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + bashInteractive, + coreutils, + installShellFiles, + libiconv, + mdbook, + nix-update-script, }: rustPlatform.buildRustPackage rec { pname = "just"; version = "1.37.0"; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; src = fetchFromGitHub { owner = "casey"; @@ -24,7 +29,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-/uWxYxczTOlUs2wOCCn5wwbGETHwIqdDI2mb/h4xVxQ="; - nativeBuildInputs = [ installShellFiles mdbook ]; + nativeBuildInputs = [ + installShellFiles + mdbook + ]; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; preCheck = '' @@ -99,7 +107,10 @@ rustPlatform.buildRustPackage rec { changelog = "https://github.com/casey/just/blob/${version}/CHANGELOG.md"; description = "Handy way to save and run project-specific commands"; license = licenses.cc0; - maintainers = with maintainers; [ xrelkd jk ]; + maintainers = with maintainers; [ + xrelkd + jk + ]; mainProgram = "just"; }; } diff --git a/pkgs/by-name/ju/justify/package.nix b/pkgs/by-name/ju/justify/package.nix index 86de7365663e14..9e2aea2025e652 100644 --- a/pkgs/by-name/ju/justify/package.nix +++ b/pkgs/by-name/ju/justify/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitea -, cmake +{ + lib, + stdenv, + fetchFromGitea, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/jw/jwasm/package.nix b/pkgs/by-name/jw/jwasm/package.nix index eaf30e58356e04..a069cbda51d6cd 100644 --- a/pkgs/by-name/jw/jwasm/package.nix +++ b/pkgs/by-name/jw/jwasm/package.nix @@ -10,12 +10,15 @@ stdenv.mkDerivation (finalAttrs: { src = fetchFromGitHub { owner = "Baron-von-Riedesel"; - repo = "JWasm"; + repo = "JWasm"; rev = "v${finalAttrs.version}"; hash = "sha256-xbiyGBTzIkAfUy45JdAl77gbvArzVUQNPOxa+H2uGFo="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; dontConfigure = true; diff --git a/pkgs/by-name/jw/jwx/package.nix b/pkgs/by-name/jw/jwx/package.nix index 411256dec35ba1..4f3b16cdebd7da 100644 --- a/pkgs/by-name/jw/jwx/package.nix +++ b/pkgs/by-name/jw/jwx/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -23,6 +24,9 @@ buildGoModule rec { mainProgram = "jwx"; homepage = "https://github.com/lestrrat-go/jwx"; license = licenses.mit; - maintainers = with maintainers; [ arianvp flokli ]; + maintainers = with maintainers; [ + arianvp + flokli + ]; }; } diff --git a/pkgs/by-name/jx/jxplorer/package.nix b/pkgs/by-name/jx/jxplorer/package.nix index e7bd11e5f1d05a..eea1c6a6a7de13 100644 --- a/pkgs/by-name/jx/jxplorer/package.nix +++ b/pkgs/by-name/jx/jxplorer/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeDesktopItem, jdk8, copyDesktopItems, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + jdk8, + copyDesktopItems, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "jxplorer"; @@ -42,10 +50,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Java Ldap Browser"; - homepage = "https://sourceforge.net/projects/jxplorer/"; - license = lib.licenses.caossl; + homepage = "https://sourceforge.net/projects/jxplorer/"; + license = lib.licenses.caossl; maintainers = with maintainers; [ benwbooth ]; - platforms = platforms.linux; + platforms = platforms.linux; mainProgram = "jxplorer"; }; } diff --git a/pkgs/by-name/jy/jython/package.nix b/pkgs/by-name/jy/jython/package.nix index 83852d91760bfe..d3a6bd32af5d16 100644 --- a/pkgs/by-name/jy/jython/package.nix +++ b/pkgs/by-name/jy/jython/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "jython"; @@ -15,9 +21,9 @@ stdenv.mkDerivation rec { dontUnpack = true; installPhase = '' - mkdir -pv $out/bin - cp $src $out/jython.jar - makeWrapper ${jre}/bin/java $out/bin/jython --add-flags "-jar $out/jython.jar" + mkdir -pv $out/bin + cp $src $out/jython.jar + makeWrapper ${jre}/bin/java $out/bin/jython --add-flags "-jar $out/jython.jar" ''; meta = { diff --git a/pkgs/by-name/k0/k0sctl/package.nix b/pkgs/by-name/k0/k0sctl/package.nix index 8ce83a38f217d0..4714882bd2feb4 100644 --- a/pkgs/by-name/k0/k0sctl/package.nix +++ b/pkgs/by-name/k0/k0sctl/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, testers -, k0sctl +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + k0sctl, }: buildGoModule rec { @@ -49,6 +50,9 @@ buildGoModule rec { changelog = "https://github.com/k0sproject/k0sctl/releases/tag/v${version}"; license = licenses.asl20; mainProgram = "k0sctl"; - maintainers = with maintainers; [ nickcao qjoly ]; + maintainers = with maintainers; [ + nickcao + qjoly + ]; }; } diff --git a/pkgs/by-name/k2/k2tf/package.nix b/pkgs/by-name/k2/k2tf/package.nix index 0da0d51f3bc45e..1bf631353dcbb8 100644 --- a/pkgs/by-name/k2/k2tf/package.nix +++ b/pkgs/by-name/k2/k2tf/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "k2tf"; @@ -22,7 +27,12 @@ buildGoModule rec { vendorHash = "sha256-yGuoE1bgwVHk3ym382OC93me9HPlVoNgGo/3JROVC2E="; - ldflags = [ "-s" "-w" "-X main.version=${version}" "-X main.commit=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + "-X main.commit=v${version}" + ]; meta = with lib; { description = "Kubernetes YAML to Terraform HCL converter"; diff --git a/pkgs/by-name/k4/k40-whisperer/package.nix b/pkgs/by-name/k4/k40-whisperer/package.nix index 5893ceb920f5ba..fe659cbe19c62b 100644 --- a/pkgs/by-name/k4/k40-whisperer/package.nix +++ b/pkgs/by-name/k4/k40-whisperer/package.nix @@ -1,27 +1,31 @@ -{ stdenv -, makeWrapper -, writeText -, python3 -, fetchzip -, inkscape -, lib -, udevGroup ? "k40" +{ + stdenv, + makeWrapper, + writeText, + python3, + fetchzip, + inkscape, + lib, + udevGroup ? "k40", }: let - pythonEnv = python3.withPackages (ps: with ps; [ - lxml - pyusb - pillow - pyclipper - tkinter - ]); + pythonEnv = python3.withPackages ( + ps: with ps; [ + lxml + pyusb + pillow + pyclipper + tkinter + ] + ); udevRule = writeText "k40-whisperer.rules" '' SUBSYSTEM=="usb", ATTRS{idVendor}=="1a86", ATTRS{idProduct}=="5512", ENV{DEVTYPE}=="usb_device", MODE="0664", GROUP="${udevGroup}" ''; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "k40-whisperer"; version = "0.68"; @@ -71,4 +75,3 @@ in stdenv.mkDerivation rec { platforms = platforms.all; }; } - diff --git a/pkgs/by-name/k6/k6/package.nix b/pkgs/by-name/k6/k6/package.nix index 3f47e50b6c9d89..12057e640e3548 100644 --- a/pkgs/by-name/k6/k6/package.nix +++ b/pkgs/by-name/k6/k6/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "k6"; @@ -35,6 +41,10 @@ buildGoModule rec { homepage = "https://k6.io/"; changelog = "https://github.com/grafana/k6/releases/tag/v${version}"; license = licenses.agpl3Plus; - maintainers = with maintainers; [ offline bryanasdev000 kashw2 ]; + maintainers = with maintainers; [ + offline + bryanasdev000 + kashw2 + ]; }; } diff --git a/pkgs/by-name/ka/kabeljau/package.nix b/pkgs/by-name/ka/kabeljau/package.nix index 58d35ddecb0f3e..0c43141bb7c892 100644 --- a/pkgs/by-name/ka/kabeljau/package.nix +++ b/pkgs/by-name/ka/kabeljau/package.nix @@ -1,4 +1,13 @@ -{ stdenvNoCC, lib, fetchFromGitea, just, imagemagick, makeWrapper, bash, dialog }: +{ + stdenvNoCC, + lib, + fetchFromGitea, + just, + imagemagick, + makeWrapper, + bash, + dialog, +}: stdenvNoCC.mkDerivation rec { pname = "kabeljau"; @@ -13,7 +22,11 @@ stdenvNoCC.mkDerivation rec { }; # Inkscape is needed in a just recipe where it is used to export the SVG icon to several different sized PNGs. - nativeBuildInputs = [ just imagemagick makeWrapper ]; + nativeBuildInputs = [ + just + imagemagick + makeWrapper + ]; postPatch = '' patchShebangs --host ${pname} ''; @@ -21,9 +34,7 @@ stdenvNoCC.mkDerivation rec { runHook preInstall just --set bin-path $out/bin --set share-path $out/share linux-install - wrapProgram $out/bin/${pname} --suffix PATH : ${ - lib.makeBinPath [ dialog ] - } + wrapProgram $out/bin/${pname} --suffix PATH : ${lib.makeBinPath [ dialog ]} runHook postInstall ''; diff --git a/pkgs/by-name/ka/kacst/package.nix b/pkgs/by-name/ka/kacst/package.nix index aa5ed8b547da81..28f364021b6043 100644 --- a/pkgs/by-name/ka/kacst/package.nix +++ b/pkgs/by-name/ka/kacst/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "kacst"; diff --git a/pkgs/by-name/ka/kaf/package.nix b/pkgs/by-name/ka/kaf/package.nix index eb098c27287347..06a37660017d43 100644 --- a/pkgs/by-name/ka/kaf/package.nix +++ b/pkgs/by-name/ka/kaf/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "kaf"; diff --git a/pkgs/by-name/ka/kafka-cmak/package.nix b/pkgs/by-name/ka/kafka-cmak/package.nix index ee77800e3f88c9..d2913e230a8843 100644 --- a/pkgs/by-name/ka/kafka-cmak/package.nix +++ b/pkgs/by-name/ka/kafka-cmak/package.nix @@ -42,7 +42,7 @@ stdenvNoCC.mkDerivation (finalAttrs: { meta = with lib; { description = "Cluster Manager for Apache Kafka, previously known as Kafka Manager"; license = licenses.apsl20; - maintainers = with maintainers; [cafkafk]; + maintainers = with maintainers; [ cafkafk ]; platforms = lib.platforms.unix; mainProgram = "cmak"; }; diff --git a/pkgs/by-name/ka/kafka-delta-ingest/package.nix b/pkgs/by-name/ka/kafka-delta-ingest/package.nix index 3cd2cc59036354..2ae7edfb8bd97a 100644 --- a/pkgs/by-name/ka/kafka-delta-ingest/package.nix +++ b/pkgs/by-name/ka/kafka-delta-ingest/package.nix @@ -29,9 +29,12 @@ rustPlatform.buildRustPackage { perl ]; - buildFeatures = [ - "dynamic-linking" - ] ++ lib.optional enableS3 "s3" ++ lib.optional enableAzure "azure"; + buildFeatures = + [ + "dynamic-linking" + ] + ++ lib.optional enableS3 "s3" + ++ lib.optional enableAzure "azure"; buildInputs = [ openssl diff --git a/pkgs/by-name/ka/kafkactl/package.nix b/pkgs/by-name/ka/kafkactl/package.nix index 808060f41f54e2..673cbdd137395c 100644 --- a/pkgs/by-name/ka/kafkactl/package.nix +++ b/pkgs/by-name/ka/kafkactl/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ka/kail/package.nix b/pkgs/by-name/ka/kail/package.nix index 809aa6a757b5b6..c252233957636d 100644 --- a/pkgs/by-name/ka/kail/package.nix +++ b/pkgs/by-name/ka/kail/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "kail"; @@ -23,7 +27,10 @@ buildGoModule rec { description = "Kubernetes log viewer"; homepage = "https://github.com/boz/kail"; license = licenses.mit; - maintainers = with maintainers; [ offline vdemeester ]; + maintainers = with maintainers; [ + offline + vdemeester + ]; mainProgram = "kail"; }; } diff --git a/pkgs/by-name/ka/kaitai-struct-compiler/package.nix b/pkgs/by-name/ka/kaitai-struct-compiler/package.nix index 2fd4fba11e3b0b..7dcb250f2b40ab 100644 --- a/pkgs/by-name/ka/kaitai-struct-compiler/package.nix +++ b/pkgs/by-name/ka/kaitai-struct-compiler/package.nix @@ -1,11 +1,11 @@ -{ lib -, stdenv -, fetchzip -, openjdk8 -, makeWrapper +{ + lib, + stdenv, + fetchzip, + openjdk8, + makeWrapper, }: - stdenv.mkDerivation rec { pname = "kaitai-struct-compiler"; version = "0.10"; @@ -21,16 +21,14 @@ stdenv.mkDerivation rec { install -D $src/bin/kaitai-struct-compiler $out/bin/kaitai-struct-compiler ln -s $out/bin/kaitai-struct-compiler $out/bin/ksc cp -R $src/lib $out/lib - wrapProgram $out/bin/kaitai-struct-compiler --prefix PATH : ${lib.makeBinPath [ openjdk8 ] } + wrapProgram $out/bin/kaitai-struct-compiler --prefix PATH : ${lib.makeBinPath [ openjdk8 ]} ''; meta = with lib; { homepage = "https://github.com/kaitai-io/kaitai_struct_compiler"; - description = - "Compiler to generate binary data parsers in C++ / C# / Go / Java / JavaScript / Lua / Perl / PHP / Python / Ruby "; + description = "Compiler to generate binary data parsers in C++ / C# / Go / Java / JavaScript / Lua / Perl / PHP / Python / Ruby "; license = licenses.gpl3Only; maintainers = with maintainers; [ qubasa ]; platforms = platforms.unix; }; } - diff --git a/pkgs/by-name/ka/kakasi/package.nix b/pkgs/by-name/ka/kakasi/package.nix index 9e0cc95bff4ffd..af749f436f29b9 100644 --- a/pkgs/by-name/ka/kakasi/package.nix +++ b/pkgs/by-name/ka/kakasi/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libiconv }: +{ + lib, + stdenv, + fetchurl, + libiconv, +}: stdenv.mkDerivation rec { pname = "kakasi"; @@ -13,9 +18,9 @@ stdenv.mkDerivation rec { characters to Hiragana, Katakana or Romaji and may be helpful to read Japanese documents. ''; - homepage = "http://kakasi.namazu.org/"; - license = licenses.gpl2Plus; - platforms = platforms.unix; + homepage = "http://kakasi.namazu.org/"; + license = licenses.gpl2Plus; + platforms = platforms.unix; }; src = fetchurl { diff --git a/pkgs/by-name/ka/kalamine/package.nix b/pkgs/by-name/ka/kalamine/package.nix index 6f7ae19795aa78..adfdc494077b27 100644 --- a/pkgs/by-name/ka/kalamine/package.nix +++ b/pkgs/by-name/ka/kalamine/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ka/kalibrate-hackrf/package.nix b/pkgs/by-name/ka/kalibrate-hackrf/package.nix index 1d821bba4adfcb..268e1721544d2b 100644 --- a/pkgs/by-name/ka/kalibrate-hackrf/package.nix +++ b/pkgs/by-name/ka/kalibrate-hackrf/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, fftw, hackrf, libusb1 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + fftw, + hackrf, + libusb1, +}: stdenv.mkDerivation { pname = "kalibrate-hackrf"; @@ -13,9 +22,16 @@ stdenv.mkDerivation { sha256 = "1jvn1qx7csgycxpx1k804sm9gk5a0c65z9gh8ybp9awq3pziv0nx"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ fftw hackrf libusb1 ]; + buildInputs = [ + fftw + hackrf + libusb1 + ]; postInstall = '' mv $out/bin/kal $out/bin/kal-hackrf diff --git a/pkgs/by-name/ka/kalibrate-rtl/package.nix b/pkgs/by-name/ka/kalibrate-rtl/package.nix index b463faa4a255db..b47098890156df 100644 --- a/pkgs/by-name/ka/kalibrate-rtl/package.nix +++ b/pkgs/by-name/ka/kalibrate-rtl/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, fftw, rtl-sdr, libusb1 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + fftw, + rtl-sdr, + libusb1, +}: stdenv.mkDerivation { pname = "kalibrate-rtl"; @@ -11,9 +20,16 @@ stdenv.mkDerivation { sha256 = "n9mfu8H2OS8dKPNhtJxBfMDp8aHEIcxg/R+kcRNOBpk="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ fftw rtl-sdr libusb1 ]; + buildInputs = [ + fftw + rtl-sdr + libusb1 + ]; meta = with lib; { description = "Calculate local oscillator frequency offset in RTL-SDR devices"; @@ -26,7 +42,10 @@ stdenv.mkDerivation { ''; homepage = "https://github.com/steve-m/kalibrate-rtl"; license = licenses.bsd2; - maintainers = with maintainers; [ bjornfor viraptor ]; + maintainers = with maintainers; [ + bjornfor + viraptor + ]; mainProgram = "kal"; platforms = platforms.linux ++ platforms.darwin; }; diff --git a/pkgs/by-name/ka/kalign/package.nix b/pkgs/by-name/ka/kalign/package.nix index 4dc720290adce3..d33398fc668fe4 100644 --- a/pkgs/by-name/ka/kalign/package.nix +++ b/pkgs/by-name/ka/kalign/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, llvmPackages -, enableSse4_1 ? stdenv.hostPlatform.sse4_1Support -, enableAvx ? stdenv.hostPlatform.avxSupport -, enableAvx2 ? stdenv.hostPlatform.avx2Support +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + llvmPackages, + enableSse4_1 ? stdenv.hostPlatform.sse4_1Support, + enableAvx ? stdenv.hostPlatform.avxSupport, + enableAvx2 ? stdenv.hostPlatform.avx2Support, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ka/kalker/package.nix b/pkgs/by-name/ka/kalker/package.nix index 2d142da60bc2aa..3b6721205d4cb0 100644 --- a/pkgs/by-name/ka/kalker/package.nix +++ b/pkgs/by-name/ka/kalker/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, gmp -, mpfr -, libmpc +{ + lib, + rustPlatform, + fetchFromGitHub, + gmp, + mpfr, + libmpc, }: rustPlatform.buildRustPackage rec { @@ -19,9 +20,16 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-hgtSDPQRrqhQALqzVW8z9xXqIv+v5/Sbs6McrUCKiaU="; - buildInputs = [ gmp mpfr libmpc ]; + buildInputs = [ + gmp + mpfr + libmpc + ]; - outputs = [ "out" "lib" ]; + outputs = [ + "out" + "lib" + ]; postInstall = '' moveToOutput "lib" "$lib" @@ -38,7 +46,10 @@ rustPlatform.buildRustPackage rec { variables, functions, derivation, integration, and complex numbers ''; license = licenses.mit; - maintainers = with maintainers; [ figsoda lovesegfault ]; + maintainers = with maintainers; [ + figsoda + lovesegfault + ]; mainProgram = "kalker"; }; } diff --git a/pkgs/by-name/ka/kamailio/package.nix b/pkgs/by-name/ka/kamailio/package.nix index 8cb83c60882850..c83d81c31ed9ab 100644 --- a/pkgs/by-name/ka/kamailio/package.nix +++ b/pkgs/by-name/ka/kamailio/package.nix @@ -1,22 +1,23 @@ -{ callPackage -, fetchurl -, lib -, stdenv -, pkg-config -, which -, bison -, flex -, json_c -, libevent -, libxml2 -, mariadb-connector-c -, pcre -, gnugrep -, gawk -, coreutils -, gdb -, gnused -, openssl +{ + callPackage, + fetchurl, + lib, + stdenv, + pkg-config, + which, + bison, + flex, + json_c, + libevent, + libxml2, + mariadb-connector-c, + pcre, + gnugrep, + gawk, + coreutils, + gdb, + gnused, + openssl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ka/kamid/package.nix b/pkgs/by-name/ka/kamid/package.nix index 24060a0c1c00d7..0b8924270b0507 100644 --- a/pkgs/by-name/ka/kamid/package.nix +++ b/pkgs/by-name/ka/kamid/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, pkg-config -, libevent -, libressl -, libbsd -, fetchurl -, readline +{ + stdenv, + lib, + pkg-config, + libevent, + libressl, + libbsd, + fetchurl, + readline, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ka/kamilalisp/package.nix b/pkgs/by-name/ka/kamilalisp/package.nix index 5b4d392d62f755..ca898af8555493 100644 --- a/pkgs/by-name/ka/kamilalisp/package.nix +++ b/pkgs/by-name/ka/kamilalisp/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, jre -, makeWrapper +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ka/kana/package.nix b/pkgs/by-name/ka/kana/package.nix index e0260d1363d689..78902b4c2fca33 100644 --- a/pkgs/by-name/ka/kana/package.nix +++ b/pkgs/by-name/ka/kana/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitLab -, rustPlatform -, meson -, ninja -, pkg-config -, rustc -, cargo -, wrapGAppsHook4 -, desktop-file-utils -, libadwaita -, gst_all_1 -, darwin +{ + lib, + stdenv, + fetchFromGitLab, + rustPlatform, + meson, + ninja, + pkg-config, + rustc, + cargo, + wrapGAppsHook4, + desktop-file-utils, + libadwaita, + gst_all_1, + darwin, }: stdenv.mkDerivation rec { @@ -43,25 +44,25 @@ stdenv.mkDerivation rec { desktop-file-utils ]; - buildInputs = [ - libadwaita - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-bad - gst-plugins-good - ]) ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + libadwaita + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-bad + gst-plugins-good + ]) + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ]; # Workaround for the gettext-sys issue # https://github.com/Koka/gettext-rs/issues/114 - env.NIX_CFLAGS_COMPILE = lib.optionalString - ( - stdenv.cc.isClang && - lib.versionAtLeast stdenv.cc.version "16" - ) - "-Wno-error=incompatible-function-pointer-types"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.cc.isClang && lib.versionAtLeast stdenv.cc.version "16" + ) "-Wno-error=incompatible-function-pointer-types"; meta = with lib; { description = "Learn Japanese hiragana and katakana characters"; diff --git a/pkgs/by-name/ka/kanagawa-gtk-theme/package.nix b/pkgs/by-name/ka/kanagawa-gtk-theme/package.nix index 590994dabbffc0..4f33ec40c7979c 100644 --- a/pkgs/by-name/ka/kanagawa-gtk-theme/package.nix +++ b/pkgs/by-name/ka/kanagawa-gtk-theme/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gtk3 -, gtk-engine-murrine +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + gtk-engine-murrine, }: stdenvNoCC.mkDerivation { pname = "kanagawa-gtk-theme"; diff --git a/pkgs/by-name/ka/kanagawa-icon-theme/package.nix b/pkgs/by-name/ka/kanagawa-icon-theme/package.nix index 7761e4788a34c8..42573489d134a8 100644 --- a/pkgs/by-name/ka/kanagawa-icon-theme/package.nix +++ b/pkgs/by-name/ka/kanagawa-icon-theme/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gtk3 -, hicolor-icon-theme +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + hicolor-icon-theme, }: stdenvNoCC.mkDerivation { pname = "kanagawa-icon-theme"; diff --git a/pkgs/by-name/ka/kanata/package.nix b/pkgs/by-name/ka/kanata/package.nix index e18019c45cb010..08df492acd7219 100644 --- a/pkgs/by-name/ka/kanata/package.nix +++ b/pkgs/by-name/ka/kanata/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, darwin -, rustPlatform -, fetchFromGitHub -, jq -, moreutils -, versionCheckHook -, nix-update-script -, withCmd ? false +{ + stdenv, + lib, + darwin, + rustPlatform, + fetchFromGitHub, + jq, + moreutils, + versionCheckHook, + nix-update-script, + withCmd ? false, }: rustPlatform.buildRustPackage rec { @@ -65,7 +66,10 @@ rustPlatform.buildRustPackage rec { description = "Tool to improve keyboard comfort and usability with advanced customization"; homepage = "https://github.com/jtroo/kanata"; license = licenses.lgpl3Only; - maintainers = with maintainers; [ bmanuel linj ]; + maintainers = with maintainers; [ + bmanuel + linj + ]; platforms = platforms.unix; mainProgram = "kanata"; broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/by-name/ka/kanif/package.nix b/pkgs/by-name/ka/kanif/package.nix index b4bb69dc1f6253..5a2658c6247bc6 100644 --- a/pkgs/by-name/ka/kanif/package.nix +++ b/pkgs/by-name/ka/kanif/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, perl , taktuk}: +{ + lib, + stdenv, + fetchurl, + perl, + taktuk, +}: stdenv.mkDerivation rec { version = "1.2.2"; @@ -10,8 +16,8 @@ stdenv.mkDerivation rec { }; preBuild = '' - substituteInPlace ./kanif --replace "/usr/bin/perl" "${perl}/bin/perl" - substituteInPlace ./kanif --replace '$taktuk_command = "taktuk";' '$taktuk_command = "${taktuk}/bin/taktuk";' + substituteInPlace ./kanif --replace "/usr/bin/perl" "${perl}/bin/perl" + substituteInPlace ./kanif --replace '$taktuk_command = "taktuk";' '$taktuk_command = "${taktuk}/bin/taktuk";' ''; meta = { @@ -32,4 +38,3 @@ stdenv.mkDerivation rec { }; } - diff --git a/pkgs/by-name/ka/kaniko/package.nix b/pkgs/by-name/ka/kaniko/package.nix index 24779b60351147..901b047bf963d8 100644 --- a/pkgs/by-name/ka/kaniko/package.nix +++ b/pkgs/by-name/ka/kaniko/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, buildGoModule -, installShellFiles -, testers -, kaniko +{ + stdenv, + lib, + fetchFromGitHub, + buildGoModule, + installShellFiles, + testers, + kaniko, }: buildGoModule rec { @@ -21,7 +22,8 @@ buildGoModule rec { vendorHash = null; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/GoogleContainerTools/kaniko/pkg/version.version=${version}" ]; @@ -47,7 +49,10 @@ buildGoModule rec { homepage = "https://github.com/GoogleContainerTools/kaniko"; license = lib.licenses.asl20; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ jk qjoly ]; + maintainers = with lib.maintainers; [ + jk + qjoly + ]; mainProgram = "executor"; }; } diff --git a/pkgs/by-name/ka/kanit-font/package.nix b/pkgs/by-name/ka/kanit-font/package.nix index 88eb8740ee19e4..37d15748987e0f 100644 --- a/pkgs/by-name/ka/kanit-font/package.nix +++ b/pkgs/by-name/ka/kanit-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "kanit"; diff --git a/pkgs/by-name/ka/kanji-stroke-order-font/package.nix b/pkgs/by-name/ka/kanji-stroke-order-font/package.nix index 7d7d025bbb7696..8c731353c2b0fa 100644 --- a/pkgs/by-name/ka/kanji-stroke-order-font/package.nix +++ b/pkgs/by-name/ka/kanji-stroke-order-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: let font = "kanji-stroke-order"; @@ -30,7 +34,10 @@ stdenv.mkDerivation { homepage = "https://www.nihilist.org.uk/"; license = [ licenses.bsd3 ]; - maintainers = with maintainers; [ ptrhlm stephen-huan ]; + maintainers = with maintainers; [ + ptrhlm + stephen-huan + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/ka/kanjidraw/package.nix b/pkgs/by-name/ka/kanjidraw/package.nix index 0d5189474729ae..14a90b18723bac 100644 --- a/pkgs/by-name/ka/kanjidraw/package.nix +++ b/pkgs/by-name/ka/kanjidraw/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3 -, bash +{ + lib, + fetchFromGitHub, + python3, + bash, }: python3.pkgs.buildPythonApplication rec { @@ -40,8 +41,8 @@ python3.pkgs.buildPythonApplication rec { ''; homepage = "https://github.com/obfusk/kanjidraw"; license = with licenses; [ - agpl3Plus # code - cc-by-sa-30 # data.json + agpl3Plus # code + cc-by-sa-30 # data.json ]; maintainers = [ maintainers.obfusk ]; }; diff --git a/pkgs/by-name/ka/kanshi/package.nix b/pkgs/by-name/ka/kanshi/package.nix index 853638db6fb6a6..10a4266ecdc61c 100644 --- a/pkgs/by-name/ka/kanshi/package.nix +++ b/pkgs/by-name/ka/kanshi/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromSourcehut -, meson -, ninja -, pkg-config -, scdoc -, wayland -, wayland-scanner -, libvarlink -, libscfg +{ + lib, + stdenv, + fetchFromSourcehut, + meson, + ninja, + pkg-config, + scdoc, + wayland, + wayland-scanner, + libvarlink, + libscfg, }: stdenv.mkDerivation rec { @@ -26,8 +27,18 @@ stdenv.mkDerivation rec { depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson ninja pkg-config scdoc wayland-scanner ]; - buildInputs = [ wayland libvarlink libscfg ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + scdoc + wayland-scanner + ]; + buildInputs = [ + wayland + libvarlink + libscfg + ]; env.NIX_CFLAGS_COMPILE = toString [ "-Wno-error=maybe-uninitialized" @@ -46,7 +57,10 @@ stdenv.mkDerivation rec { ''; license = licenses.mit; mainProgram = "kanshi"; - maintainers = with maintainers; [ balsoft danielbarter ]; + maintainers = with maintainers; [ + balsoft + danielbarter + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/ka/kapitonov-plugins-pack/package.nix b/pkgs/by-name/ka/kapitonov-plugins-pack/package.nix index 032ee8ec03c6b9..ae774134acef6f 100644 --- a/pkgs/by-name/ka/kapitonov-plugins-pack/package.nix +++ b/pkgs/by-name/ka/kapitonov-plugins-pack/package.nix @@ -1,7 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, faust, meson, ninja, pkg-config -, boost, cairo, fftw, ladspa-sdk, libxcb, lv2, xcbutilwm, xorg -, zita-convolver, zita-resampler - }: +{ + lib, + stdenv, + fetchFromGitHub, + faust, + meson, + ninja, + pkg-config, + boost, + cairo, + fftw, + ladspa-sdk, + libxcb, + lv2, + xcbutilwm, + xorg, + zita-convolver, + zita-resampler, +}: stdenv.mkDerivation rec { pname = "kapitonov-plugins-pack"; diff --git a/pkgs/by-name/ka/kapowbang/package.nix b/pkgs/by-name/ka/kapowbang/package.nix index 7027d8a50c120a..d4e8e9cdd66c44 100644 --- a/pkgs/by-name/ka/kapowbang/package.nix +++ b/pkgs/by-name/ka/kapowbang/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "kapowbang"; diff --git a/pkgs/by-name/ka/kappanhang/package.nix b/pkgs/by-name/ka/kappanhang/package.nix index be8fa24a949e48..8429279cafcd7e 100644 --- a/pkgs/by-name/ka/kappanhang/package.nix +++ b/pkgs/by-name/ka/kappanhang/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, pkg-config, pulseaudio }: +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + pulseaudio, +}: buildGoModule rec { pname = "kappanhang"; diff --git a/pkgs/by-name/ka/karate/package.nix b/pkgs/by-name/ka/karate/package.nix index bc3076931d6959..ba30709a8977f1 100644 --- a/pkgs/by-name/ka/karate/package.nix +++ b/pkgs/by-name/ka/karate/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenvNoCC, fetchurl, jre, makeWrapper }: +{ + lib, + stdenvNoCC, + fetchurl, + jre, + makeWrapper, +}: stdenvNoCC.mkDerivation rec { pname = "karate"; diff --git a/pkgs/by-name/ka/karla/package.nix b/pkgs/by-name/ka/karla/package.nix index f73b2060f5437f..ea8090d36626a6 100644 --- a/pkgs/by-name/ka/karla/package.nix +++ b/pkgs/by-name/ka/karla/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "karla"; diff --git a/pkgs/by-name/ka/karma-runner/package.nix b/pkgs/by-name/ka/karma-runner/package.nix index 514d789ac67879..594267f143ca14 100644 --- a/pkgs/by-name/ka/karma-runner/package.nix +++ b/pkgs/by-name/ka/karma-runner/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ka/karma/package.nix b/pkgs/by-name/ka/karma/package.nix index 95f66e1dd7b34e..c4c6822eea05be 100644 --- a/pkgs/by-name/ka/karma/package.nix +++ b/pkgs/by-name/ka/karma/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchNpmDeps -, nixosTests -, nodejs -, npmHooks +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchNpmDeps, + nixosTests, + nodejs, + npmHooks, }: buildGoModule rec { diff --git a/pkgs/by-name/ka/karmor/package.nix b/pkgs/by-name/ka/karmor/package.nix index eb2722b34150e6..c25af90b9bccfe 100644 --- a/pkgs/by-name/ka/karmor/package.nix +++ b/pkgs/by-name/ka/karmor/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, testers -, karmor +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + karmor, }: buildGoModule rec { @@ -52,6 +53,9 @@ buildGoModule rec { homepage = "https://kubearmor.io"; changelog = "https://github.com/kubearmor/kubearmor-client/releases/v${version}"; license = licenses.asl20; - maintainers = with maintainers; [ urandom kashw2 ]; + maintainers = with maintainers; [ + urandom + kashw2 + ]; }; } diff --git a/pkgs/by-name/ka/kas/package.nix b/pkgs/by-name/ka/kas/package.nix index 51cbae22afdb02..b9708c9e789a93 100644 --- a/pkgs/by-name/ka/kas/package.nix +++ b/pkgs/by-name/ka/kas/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, python3, testers, kas }: +{ + lib, + fetchFromGitHub, + python3, + testers, + kas, +}: python3.pkgs.buildPythonApplication rec { pname = "kas"; @@ -11,7 +17,14 @@ python3.pkgs.buildPythonApplication rec { hash = "sha256-J64yy2G8+5uT31Vpwhge5R7ZqId+NzE5ykXBHjc0qgQ="; }; - propagatedBuildInputs = with python3.pkgs; [ setuptools kconfiglib jsonschema distro pyyaml gitpython ]; + propagatedBuildInputs = with python3.pkgs; [ + setuptools + kconfiglib + jsonschema + distro + pyyaml + gitpython + ]; # Tests require network as they try to clone repos doCheck = false; diff --git a/pkgs/by-name/ka/kasmweb/package.nix b/pkgs/by-name/ka/kasmweb/package.nix index 9c40fab2b95d4c..bb528e57e6646e 100644 --- a/pkgs/by-name/ka/kasmweb/package.nix +++ b/pkgs/by-name/ka/kasmweb/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, lib -, fetchzip +{ + stdenv, + lib, + fetchzip, }: stdenv.mkDerivation rec { @@ -26,7 +27,6 @@ stdenv.mkDerivation rec { runHook postInstall ''; - meta = with lib; { homepage = "https://www.kasmweb.com/"; description = "Streaming containerized apps and desktops to end-users"; diff --git a/pkgs/by-name/ka/katago/package.nix b/pkgs/by-name/ka/katago/package.nix index b6b7336845da3f..204d6777b0c4bb 100644 --- a/pkgs/by-name/ka/katago/package.nix +++ b/pkgs/by-name/ka/katago/package.nix @@ -1,18 +1,41 @@ -{ stdenv, boost, cmake, config, cudaPackages, eigen, fetchFromGitHub, gperftools -, lib, libzip, makeWrapper, ocl-icd, opencl-headers, openssl -, writeShellScriptBin, enableAVX2 ? stdenv.hostPlatform.avx2Support -, backend ? if config.cudaSupport then "cuda" else "opencl" -, enableBigBoards ? false, enableContrib ? false, enableTcmalloc ? true -, enableTrtPlanCache ? false }: +{ + stdenv, + boost, + cmake, + config, + cudaPackages, + eigen, + fetchFromGitHub, + gperftools, + lib, + libzip, + makeWrapper, + ocl-icd, + opencl-headers, + openssl, + writeShellScriptBin, + enableAVX2 ? stdenv.hostPlatform.avx2Support, + backend ? if config.cudaSupport then "cuda" else "opencl", + enableBigBoards ? false, + enableContrib ? false, + enableTcmalloc ? true, + enableTrtPlanCache ? false, +}: -assert lib.assertOneOf "backend" backend [ "opencl" "cuda" "tensorrt" "eigen" ]; +assert lib.assertOneOf "backend" backend [ + "opencl" + "cuda" + "tensorrt" + "eigen" +]; # N.b. older versions of cuda toolkit (e.g. 10) do not support newer versions # of gcc. If you need to use cuda10, please override stdenv with gcc8Stdenv let githash = "cd0ed6c0712088ddb901be68189ba7fa1439a9e7"; fakegit = writeShellScriptBin "git" "echo ${githash}"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "katago"; version = "1.15.3"; @@ -23,47 +46,67 @@ in stdenv.mkDerivation rec { sha256 = "sha256-hZc8LlOxnVqJqyqOSIWKv3550QOaGr79xgqsAQ8B8SM="; }; - nativeBuildInputs = [ cmake makeWrapper ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; - buildInputs = [ libzip boost ] ++ lib.optionals (backend == "eigen") [ eigen ] + buildInputs = + [ + libzip + boost + ] + ++ lib.optionals (backend == "eigen") [ eigen ] ++ lib.optionals (backend == "cuda") [ cudaPackages.cudnn cudaPackages.cudatoolkit - ] ++ lib.optionals (backend == "tensorrt") [ + ] + ++ lib.optionals (backend == "tensorrt") [ cudaPackages.cudatoolkit cudaPackages.tensorrt - ] ++ lib.optionals (backend == "opencl") [ opencl-headers ocl-icd ] + ] + ++ lib.optionals (backend == "opencl") [ + opencl-headers + ocl-icd + ] ++ lib.optionals enableContrib [ openssl ] ++ lib.optionals enableTcmalloc [ gperftools ]; - cmakeFlags = [ - (lib.cmakeFeature "USE_BACKEND" (lib.toUpper backend)) - (lib.cmakeBool "USE_AVX2" enableAVX2) - (lib.cmakeBool "USE_TCMALLOC" enableTcmalloc) - (lib.cmakeBool "USE_BIGGER_BOARDS_EXPENSIVE" enableBigBoards) - (lib.cmakeBool "USE_CACHE_TENSORRT_PLAN" enableTrtPlanCache) - (lib.cmakeBool "NO_GIT_REVISION" (!enableContrib)) - ] ++ lib.optionals enableContrib [ - (lib.cmakeBool "BUILD_DISTRIBUTED" true) - (lib.cmakeFeature "GIT_EXECUTABLE" "${fakegit}/bin/git") - ]; + cmakeFlags = + [ + (lib.cmakeFeature "USE_BACKEND" (lib.toUpper backend)) + (lib.cmakeBool "USE_AVX2" enableAVX2) + (lib.cmakeBool "USE_TCMALLOC" enableTcmalloc) + (lib.cmakeBool "USE_BIGGER_BOARDS_EXPENSIVE" enableBigBoards) + (lib.cmakeBool "USE_CACHE_TENSORRT_PLAN" enableTrtPlanCache) + (lib.cmakeBool "NO_GIT_REVISION" (!enableContrib)) + ] + ++ lib.optionals enableContrib [ + (lib.cmakeBool "BUILD_DISTRIBUTED" true) + (lib.cmakeFeature "GIT_EXECUTABLE" "${fakegit}/bin/git") + ]; - preConfigure = '' - cd cpp/ - '' + lib.optionalString (backend == "cuda" || backend == "tensorrt") '' - export CUDA_PATH="${cudaPackages.cudatoolkit}" - export EXTRA_LDFLAGS="-L/run/opengl-driver/lib" - ''; + preConfigure = + '' + cd cpp/ + '' + + lib.optionalString (backend == "cuda" || backend == "tensorrt") '' + export CUDA_PATH="${cudaPackages.cudatoolkit}" + export EXTRA_LDFLAGS="-L/run/opengl-driver/lib" + ''; - installPhase = '' - runHook preInstall - mkdir -p $out/bin; cp katago $out/bin; - '' + lib.optionalString (backend == "cuda" || backend == "tensorrt") '' - wrapProgram $out/bin/katago \ - --prefix LD_LIBRARY_PATH : "/run/opengl-driver/lib" - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + mkdir -p $out/bin; cp katago $out/bin; + '' + + lib.optionalString (backend == "cuda" || backend == "tensorrt") '' + wrapProgram $out/bin/katago \ + --prefix LD_LIBRARY_PATH : "/run/opengl-driver/lib" + '' + + '' + runHook postInstall + ''; meta = with lib; { description = "Go engine modeled after AlphaGo Zero"; diff --git a/pkgs/by-name/ka/katawa-shoujo-re-engineered/package.nix b/pkgs/by-name/ka/katawa-shoujo-re-engineered/package.nix index 798a1763bb7107..bfd2836a166357 100644 --- a/pkgs/by-name/ka/katawa-shoujo-re-engineered/package.nix +++ b/pkgs/by-name/ka/katawa-shoujo-re-engineered/package.nix @@ -62,7 +62,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { cc-by-nc-nd-30 ]; mainProgram = "katawa-shoujo-re-engineered"; - maintainers = with lib.maintainers; [ quantenzitrone rapiteanu ]; + maintainers = with lib.maintainers; [ + quantenzitrone + rapiteanu + ]; platforms = renpy.meta.platforms; }; }) diff --git a/pkgs/by-name/ka/katawa-shoujo/package.nix b/pkgs/by-name/ka/katawa-shoujo/package.nix index 18aa00d0e16e08..23b8d7aa503e2a 100644 --- a/pkgs/by-name/ka/katawa-shoujo/package.nix +++ b/pkgs/by-name/ka/katawa-shoujo/package.nix @@ -1,47 +1,51 @@ -{ stdenvNoCC -, lib -, fetchurl -, autoPatchelfHook -, copyDesktopItems -, freetype -, makeDesktopItem -, makeWrapper -, libGL -, libGLU -# Darwin cannot handle these when devendored: -# - DYLD_LIBRARY_PATH masks system libraries with similar, differently-cased names and cause missing symbol errors -# - symlinks cause unrelated BMP image loading to fail(?) -, devendorImageLibs ? !stdenvNoCC.hostPlatform.isDarwin -, libjpeg -, libpng12 -, libX11 -, libXext -, libXi -, libXmu -, runtimeShell -, SDL_compat -, SDL_image -, SDL_ttf -, undmg -, unrpa -, zlib +{ + stdenvNoCC, + lib, + fetchurl, + autoPatchelfHook, + copyDesktopItems, + freetype, + makeDesktopItem, + makeWrapper, + libGL, + libGLU, + # Darwin cannot handle these when devendored: + # - DYLD_LIBRARY_PATH masks system libraries with similar, differently-cased names and cause missing symbol errors + # - symlinks cause unrelated BMP image loading to fail(?) + devendorImageLibs ? !stdenvNoCC.hostPlatform.isDarwin, + libjpeg, + libpng12, + libX11, + libXext, + libXi, + libXmu, + runtimeShell, + SDL_compat, + SDL_image, + SDL_ttf, + undmg, + unrpa, + zlib, }: let stdenv = stdenvNoCC; - srcDetails = rec { - x86_64-linux = { - archiveDate = "20240825224413"; - urlSuffix = "%5blinux-x86%5d%5b18161880%5d.tar.bz2"; - hash = "sha256-7FoFz88dWYHs2/pxkEwnmiFeeb3+slayrWknEJoAB9o="; - }; - i686-linux = x86_64-linux; - x86_64-darwin = { - archiveDate = "20240825224411"; - urlSuffix = "%5bmac%5d%5b1DFC84A6%5d.dmg"; - hash = "sha256-Sc5BAlpJsffjcNrZ8+VU3n7G10DoqDKQn/leHDW32Y8="; - }; - }.${stdenv.hostPlatform.system} or (throw "Don't know how to fetch source for ${stdenv.hostPlatform.system}!"); + srcDetails = + rec { + x86_64-linux = { + archiveDate = "20240825224413"; + urlSuffix = "%5blinux-x86%5d%5b18161880%5d.tar.bz2"; + hash = "sha256-7FoFz88dWYHs2/pxkEwnmiFeeb3+slayrWknEJoAB9o="; + }; + i686-linux = x86_64-linux; + x86_64-darwin = { + archiveDate = "20240825224411"; + urlSuffix = "%5bmac%5d%5b1DFC84A6%5d.dmg"; + hash = "sha256-Sc5BAlpJsffjcNrZ8+VU3n7G10DoqDKQn/leHDW32Y8="; + }; + } + .${stdenv.hostPlatform.system} + or (throw "Don't know how to fetch source for ${stdenv.hostPlatform.system}!"); in stdenv.mkDerivation rec { pname = "katawa-shoujo"; @@ -55,103 +59,127 @@ stdenv.mkDerivation rec { # fetchzip requires a custom unpackPhase to handle dmg, fetchurl cannot handle undmg producing >1 directory without this sourceRoot = "."; - nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - autoPatchelfHook - copyDesktopItems - unrpa - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - makeWrapper - undmg + nativeBuildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + autoPatchelfHook + copyDesktopItems + unrpa + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + makeWrapper + undmg + ]; + + buildInputs = + [ + freetype + SDL_compat + zlib + ] + ++ lib.optionals devendorImageLibs [ + libjpeg + libpng12 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libX11 + libXext + libXi + libXmu + libGL + libGLU + ]; + + desktopItems = [ + (makeDesktopItem rec { + name = "katawa-shoujo"; + desktopName = "Katawa Shoujo"; + comment = meta.description; + exec = name; + icon = name; + categories = [ "Game" ]; + }) ]; - buildInputs = [ - freetype - SDL_compat - zlib - ] ++ lib.optionals devendorImageLibs [ - libjpeg - libpng12 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libX11 - libXext - libXi - libXmu - libGL - libGLU - ]; - - desktopItems = [(makeDesktopItem rec { - name = "katawa-shoujo"; - desktopName = "Katawa Shoujo"; - comment = meta.description; - exec = name; - icon = name; - categories = [ "Game" ]; - })]; - dontConfigure = true; dontBuild = true; - installPhase = let - platformDetails = with stdenv.hostPlatform; if isDarwin then rec { - arch = "darwin-x86_64"; - sourceDir = "'Katawa Shoujo'.app"; - installDir = "$out/Applications/'Katawa Shoujo'.app"; - dataDir = "${installDir}/Contents/Resources/autorun"; - bin = "${installDir}/Contents/MacOS/'Katawa Shoujo'"; - } else rec { - arch = "linux-${if isx86_64 then "x86_64" else "i686"}"; - sourceDir = "'Katawa Shoujo'-${version}-linux"; - installDir = "$out/share/katawa-shoujo"; - dataDir = installDir; - bin = "${installDir}/'Katawa Shoujo'.sh"; - }; - libDir = with platformDetails; "${dataDir}/lib/${arch}"; - in with platformDetails; '' - runHook preInstall - - mkdir -p "$(dirname ${installDir})" - cp -R ${sourceDir} ${installDir} - - # Simplify launcher script - cat <${bin} - #!${runtimeShell} - exec \$RENPY_GDB ${libDir}/'Katawa Shoujo' \$RENPY_PYARGS -EO ${dataDir}/'Katawa Shoujo'.py "\$@" - EOF - - '' + (if stdenv.hostPlatform.isDarwin then '' - # No autoPatchelfHook on Darwin - wrapProgram ${bin} \ - --prefix DYLD_LIBRARY_PATH : ${lib.makeLibraryPath buildInputs} - '' else '' - # Extract icon for xdg desktop file - unrpa ${dataDir}/game/data.rpa - install -Dm644 ui/icon.png $out/share/icons/hicolor/512x512/apps/katawa-shoujo.png - '') + '' - - # Delete binaries for wrong arch, autoPatchelfHook gets confused by them & less to keep in the store - find "$(dirname ${libDir})" -mindepth 1 -maxdepth 1 \ - -not -name 'python*' -not -name ${arch} \ - -exec rm -r {} \; - - # Replace some bundled libs so Nixpkgs' versions are used - rm ${libDir}/libz* - rm ${libDir}/libfreetype* - rm ${libDir}/libSDL-1.2* - '' + lib.optionalString devendorImageLibs '' - rm ${libDir}/libjpeg* - rm ${libDir}/libpng12* - '' + '' - - mkdir -p $out/share/{doc,licenses}/katawa-shoujo - mv ${dataDir}/'Game Manual'.pdf $out/share/doc/katawa-shoujo/ - mv ${dataDir}/LICENSE.txt $out/share/licenses/katawa-shoujo/ - - mkdir -p $out/bin - ln -s ${bin} $out/bin/katawa-shoujo - - runHook postInstall - ''; + installPhase = + let + platformDetails = + with stdenv.hostPlatform; + if isDarwin then + rec { + arch = "darwin-x86_64"; + sourceDir = "'Katawa Shoujo'.app"; + installDir = "$out/Applications/'Katawa Shoujo'.app"; + dataDir = "${installDir}/Contents/Resources/autorun"; + bin = "${installDir}/Contents/MacOS/'Katawa Shoujo'"; + } + else + rec { + arch = "linux-${if isx86_64 then "x86_64" else "i686"}"; + sourceDir = "'Katawa Shoujo'-${version}-linux"; + installDir = "$out/share/katawa-shoujo"; + dataDir = installDir; + bin = "${installDir}/'Katawa Shoujo'.sh"; + }; + libDir = with platformDetails; "${dataDir}/lib/${arch}"; + in + with platformDetails; + '' + runHook preInstall + + mkdir -p "$(dirname ${installDir})" + cp -R ${sourceDir} ${installDir} + + # Simplify launcher script + cat <${bin} + #!${runtimeShell} + exec \$RENPY_GDB ${libDir}/'Katawa Shoujo' \$RENPY_PYARGS -EO ${dataDir}/'Katawa Shoujo'.py "\$@" + EOF + + '' + + ( + if stdenv.hostPlatform.isDarwin then + '' + # No autoPatchelfHook on Darwin + wrapProgram ${bin} \ + --prefix DYLD_LIBRARY_PATH : ${lib.makeLibraryPath buildInputs} + '' + else + '' + # Extract icon for xdg desktop file + unrpa ${dataDir}/game/data.rpa + install -Dm644 ui/icon.png $out/share/icons/hicolor/512x512/apps/katawa-shoujo.png + '' + ) + + '' + + # Delete binaries for wrong arch, autoPatchelfHook gets confused by them & less to keep in the store + find "$(dirname ${libDir})" -mindepth 1 -maxdepth 1 \ + -not -name 'python*' -not -name ${arch} \ + -exec rm -r {} \; + + # Replace some bundled libs so Nixpkgs' versions are used + rm ${libDir}/libz* + rm ${libDir}/libfreetype* + rm ${libDir}/libSDL-1.2* + '' + + lib.optionalString devendorImageLibs '' + rm ${libDir}/libjpeg* + rm ${libDir}/libpng12* + '' + + '' + + mkdir -p $out/share/{doc,licenses}/katawa-shoujo + mv ${dataDir}/'Game Manual'.pdf $out/share/doc/katawa-shoujo/ + mv ${dataDir}/LICENSE.txt $out/share/licenses/katawa-shoujo/ + + mkdir -p $out/bin + ln -s ${bin} $out/bin/katawa-shoujo + + runHook postInstall + ''; meta = with lib; { description = "Bishoujo-style visual novel by Four Leaf Studios, built in Ren'Py"; diff --git a/pkgs/by-name/ka/kati/package.nix b/pkgs/by-name/ka/kati/package.nix index 9ceeb2f8c490c1..661248987aee7b 100644 --- a/pkgs/by-name/ka/kati/package.nix +++ b/pkgs/by-name/ka/kati/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "kati-unstable"; diff --git a/pkgs/by-name/ka/kawkab-mono-font/package.nix b/pkgs/by-name/ka/kawkab-mono-font/package.nix index 60e455dae6ca16..9915f0ae52b409 100644 --- a/pkgs/by-name/ka/kawkab-mono-font/package.nix +++ b/pkgs/by-name/ka/kawkab-mono-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { pname = "kawkab-mono"; diff --git a/pkgs/by-name/ka/kazam/package.nix b/pkgs/by-name/ka/kazam/package.nix index 3d3349ab1bd751..f887b39f2d2e39 100644 --- a/pkgs/by-name/ka/kazam/package.nix +++ b/pkgs/by-name/ka/kazam/package.nix @@ -1,18 +1,19 @@ -{ lib -, fetchFromGitHub -, substituteAll -, python3Packages -, gst_all_1 -, wrapGAppsHook3 -, gobject-introspection -, gtk3 -, libwnck -, keybinder3 -, intltool -, libcanberra-gtk3 -, libappindicator-gtk3 -, libpulseaudio -, libgudev +{ + lib, + fetchFromGitHub, + substituteAll, + python3Packages, + gst_all_1, + wrapGAppsHook3, + gobject-introspection, + gtk3, + libwnck, + keybinder3, + intltool, + libcanberra-gtk3, + libappindicator-gtk3, + libpulseaudio, + libgudev, }: python3Packages.buildPythonApplication rec { @@ -26,7 +27,12 @@ python3Packages.buildPythonApplication rec { sha256 = "1jk6khwgdv3nmagdgp5ivz3156pl0ljhf7b6i4b52w1h5ywsg9ah"; }; - nativeBuildInputs = [ gobject-introspection python3Packages.distutils-extra intltool wrapGAppsHook3 ]; + nativeBuildInputs = [ + gobject-introspection + python3Packages.distutils-extra + intltool + wrapGAppsHook3 + ]; buildInputs = [ gst_all_1.gstreamer gst_all_1.gst-plugins-base @@ -38,7 +44,13 @@ python3Packages.buildPythonApplication rec { libgudev ]; - propagatedBuildInputs = with python3Packages; [ pygobject3 pyxdg pycairo dbus-python xlib ]; + propagatedBuildInputs = with python3Packages; [ + pygobject3 + pyxdg + pycairo + dbus-python + xlib + ]; patches = [ # Fix paths diff --git a/pkgs/by-name/kb/kb/package.nix b/pkgs/by-name/kb/kb/package.nix index 41f5d7e55c3291..f05cf7e325b69a 100644 --- a/pkgs/by-name/kb/kb/package.nix +++ b/pkgs/by-name/kb/kb/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/kb/kbd/package.nix b/pkgs/by-name/kb/kbd/package.nix index badb02aaec5a8a..2db418ecc0a794 100644 --- a/pkgs/by-name/kb/kbd/package.nix +++ b/pkgs/by-name/kb/kbd/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, nixosTests -, autoreconfHook -, pkg-config -, flex -, check -, pam -, coreutils -, gzip -, bzip2 -, xz -, zstd -, gitUpdater +{ + lib, + stdenv, + fetchurl, + nixosTests, + autoreconfHook, + pkg-config, + flex, + check, + pam, + coreutils, + gzip, + bzip2, + xz, + zstd, + gitUpdater, }: stdenv.mkDerivation rec { @@ -26,7 +27,11 @@ stdenv.mkDerivation rec { # vlock is moved into its own output, since it depends on pam. This # reduces closure size for most use cases. - outputs = [ "out" "vlock" "dev" ]; + outputs = [ + "out" + "vlock" + "dev" + ]; configureFlags = [ "--enable-optional-progs" @@ -38,33 +43,32 @@ stdenv.mkDerivation rec { ./search-paths.patch ]; - postPatch = - '' - # Renaming keymaps with name clashes, because loadkeys just picks - # the first keymap it sees. The clashing names lead to e.g. - # "loadkeys no" defaulting to a norwegian dvorak map instead of - # the much more common qwerty one. - pushd data/keymaps/i386 - mv qwertz/cz{,-qwertz}.map - mv olpc/es{,-olpc}.map - mv olpc/pt{,-olpc}.map - mv fgGIod/trf{,-fgGIod}.map - mv colemak/{en-latin9,colemak}.map - popd + postPatch = '' + # Renaming keymaps with name clashes, because loadkeys just picks + # the first keymap it sees. The clashing names lead to e.g. + # "loadkeys no" defaulting to a norwegian dvorak map instead of + # the much more common qwerty one. + pushd data/keymaps/i386 + mv qwertz/cz{,-qwertz}.map + mv olpc/es{,-olpc}.map + mv olpc/pt{,-olpc}.map + mv fgGIod/trf{,-fgGIod}.map + mv colemak/{en-latin9,colemak}.map + popd - # Fix paths to decompressors. Trailing space to avoid replacing `xz` in `".xz"`. - substituteInPlace src/libkbdfile/kbdfile.c \ - --replace 'gzip ' '${gzip}/bin/gzip ' \ - --replace 'bzip2 ' '${bzip2.bin}/bin/bzip2 ' \ - --replace 'xz ' '${xz.bin}/bin/xz ' \ - --replace 'zstd ' '${zstd.bin}/bin/zstd ' + # Fix paths to decompressors. Trailing space to avoid replacing `xz` in `".xz"`. + substituteInPlace src/libkbdfile/kbdfile.c \ + --replace 'gzip ' '${gzip}/bin/gzip ' \ + --replace 'bzip2 ' '${bzip2.bin}/bin/bzip2 ' \ + --replace 'xz ' '${xz.bin}/bin/xz ' \ + --replace 'zstd ' '${zstd.bin}/bin/zstd ' - sed -i ' - 1i prefix:=$(vlock) - 1i bindir := $(vlock)/bin' \ - src/vlock/Makefile.in \ - src/vlock/Makefile.am - ''; + sed -i ' + 1i prefix:=$(vlock) + 1i bindir := $(vlock)/bin' \ + src/vlock/Makefile.in \ + src/vlock/Makefile.am + ''; postInstall = '' for i in $out/bin/unicode_{start,stop}; do @@ -73,9 +77,16 @@ stdenv.mkDerivation rec { done ''; - buildInputs = [ check pam ]; + buildInputs = [ + check + pam + ]; NIX_LDFLAGS = lib.optional stdenv.hostPlatform.isStatic "-laudit"; - nativeBuildInputs = [ autoreconfHook pkg-config flex ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + flex + ]; passthru.tests = { inherit (nixosTests) keymap kbd-setfont-decompress kbd-update-search-paths-patch; @@ -83,9 +94,9 @@ stdenv.mkDerivation rec { passthru = { gzip = gzip; updateScript = gitUpdater { - # No nicer place to find latest release. - url = "https://github.com/legionus/kbd.git"; - rev-prefix = "v"; + # No nicer place to find latest release. + url = "https://github.com/legionus/kbd.git"; + rev-prefix = "v"; }; }; diff --git a/pkgs/by-name/kb/kbdd/package.nix b/pkgs/by-name/kb/kbdd/package.nix index 0692780a549d43..55278a45945589 100644 --- a/pkgs/by-name/kb/kbdd/package.nix +++ b/pkgs/by-name/kb/kbdd/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, dbus-glib, autoreconfHook, xorg }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + dbus-glib, + autoreconfHook, + xorg, +}: stdenv.mkDerivation { pname = "kbdd"; @@ -11,8 +19,14 @@ stdenv.mkDerivation { sha256 = "1gzcjnflgdqnjgphiqpzwbcx60hm0h2cprncm7i8xca3ln5q6ba1"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ xorg.libX11 dbus-glib ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + xorg.libX11 + dbus-glib + ]; meta = { description = "Simple daemon and library to make per window layout using XKB"; diff --git a/pkgs/by-name/kb/kbdlight/package.nix b/pkgs/by-name/kb/kbdlight/package.nix index 4d6172fa39fe7f..efb971d634fcea 100644 --- a/pkgs/by-name/kb/kbdlight/package.nix +++ b/pkgs/by-name/kb/kbdlight/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "kbdlight"; diff --git a/pkgs/by-name/kb/kbst/package.nix b/pkgs/by-name/kb/kbst/package.nix index 566610ebc7cbce..93fa27fc26ca62 100644 --- a/pkgs/by-name/kb/kbst/package.nix +++ b/pkgs/by-name/kb/kbst/package.nix @@ -1,10 +1,14 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "kbst"; version = "0.2.1"; - src = fetchFromGitHub{ + src = fetchFromGitHub { owner = "kbst"; repo = "kbst"; rev = "v${version}"; @@ -14,9 +18,12 @@ buildGoModule rec { vendorHash = "sha256-+FY6KGX606CfTVKM1HeHxCm9PkaqfnT5XeOEXUX3Q5I="; ldflags = - let package_url = "github.com/kbst/kbst"; in + let + package_url = "github.com/kbst/kbst"; + in [ - "-s" "-w" + "-s" + "-w" "-X ${package_url}.version=${version}" "-X ${package_url}.buildDate=unknown" "-X ${package_url}.gitCommit=${src.rev}" diff --git a/pkgs/by-name/kb/kbt/package.nix b/pkgs/by-name/kb/kbt/package.nix index 8a7e91ba3c7dd4..6a7abdc808778d 100644 --- a/pkgs/by-name/kb/kbt/package.nix +++ b/pkgs/by-name/kb/kbt/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, pkg-config -, darwin -, xorg +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + pkg-config, + darwin, + xorg, }: rustPlatform.buildRustPackage rec { @@ -24,11 +25,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AppKit - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - xorg.libX11 - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AppKit + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + xorg.libX11 + ]; meta = with lib; { description = "Keyboard tester in terminal"; diff --git a/pkgs/by-name/kc/kcat/package.nix b/pkgs/by-name/kc/kcat/package.nix index f3bd6a8555b631..22d64830edb91e 100644 --- a/pkgs/by-name/kc/kcat/package.nix +++ b/pkgs/by-name/kc/kcat/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, zlib, rdkafka, yajl, avro-c, libserdes, which }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + zlib, + rdkafka, + yajl, + avro-c, + libserdes, + which, +}: stdenv.mkDerivation rec { pname = "kcat"; @@ -12,9 +23,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-pCIYNx0GYPGDYzTLq9h/LbOrJjhKWLAV4gq07Ikl5O4="; }; - nativeBuildInputs = [ pkg-config which ]; + nativeBuildInputs = [ + pkg-config + which + ]; - buildInputs = [ zlib rdkafka yajl avro-c libserdes ]; + buildInputs = [ + zlib + rdkafka + yajl + avro-c + libserdes + ]; meta = with lib; { description = "Generic non-JVM producer and consumer for Apache Kafka"; diff --git a/pkgs/by-name/kc/kcgi/package.nix b/pkgs/by-name/kc/kcgi/package.nix index 0b2f7438e69876..246cc597407f32 100644 --- a/pkgs/by-name/kc/kcgi/package.nix +++ b/pkgs/by-name/kc/kcgi/package.nix @@ -1,9 +1,15 @@ -{ lib, stdenv, pkg-config, fetchFromGitHub, libbsd }: +{ + lib, + stdenv, + pkg-config, + fetchFromGitHub, + libbsd, +}: stdenv.mkDerivation rec { pname = "kcgi"; version = "0.10.8"; - underscoreVersion = lib.replaceStrings ["."] ["_"] version; + underscoreVersion = lib.replaceStrings [ "." ] [ "_" ] version; src = fetchFromGitHub { owner = "kristapsdz"; @@ -17,7 +23,7 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libbsd ] ; + buildInputs = [ ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libbsd ]; dontAddPrefix = true; diff --git a/pkgs/by-name/kc/kchat/package.nix b/pkgs/by-name/kc/kchat/package.nix index baec68b0a5731b..c472bc2eafbe2b 100644 --- a/pkgs/by-name/kc/kchat/package.nix +++ b/pkgs/by-name/kc/kchat/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchurl -, appimageTools +{ + lib, + fetchurl, + appimageTools, }: appimageTools.wrapType2 rec { diff --git a/pkgs/by-name/kc/kcli/package.nix b/pkgs/by-name/kc/kcli/package.nix index 4047b3c296dd6e..ab609f2d87526c 100644 --- a/pkgs/by-name/kc/kcli/package.nix +++ b/pkgs/by-name/kc/kcli/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "kcli"; diff --git a/pkgs/by-name/kc/kclvm/package.nix b/pkgs/by-name/kc/kclvm/package.nix index 76774e510cadc6..00ed9e182150a5 100644 --- a/pkgs/by-name/kc/kclvm/package.nix +++ b/pkgs/by-name/kc/kclvm/package.nix @@ -1,12 +1,12 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, protobuf -, pkg-config -, darwin -, rustc -, +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + protobuf, + pkg-config, + darwin, + rustc, }: rustPlatform.buildRustPackage rec { pname = "kclvm"; @@ -28,18 +28,22 @@ rustPlatform.buildRustPackage rec { }; }; - buildInputs = [ rustc ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.CoreServices - darwin.apple_sdk.frameworks.SystemConfiguration - ]; - + buildInputs = + [ rustc ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.CoreServices + darwin.apple_sdk.frameworks.SystemConfiguration + ]; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' install_name_tool -id $out/lib/libkclvm_cli_cdylib.dylib $out/lib/libkclvm_cli_cdylib.dylib ''; - nativeBuildInputs = [ pkg-config protobuf ]; + nativeBuildInputs = [ + pkg-config + protobuf + ]; patches = [ ./enable_protoc_env.patch ]; @@ -51,6 +55,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/kcl-lang/kcl"; license = licenses.asl20; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ selfuryon peefy ]; + maintainers = with maintainers; [ + selfuryon + peefy + ]; }; } diff --git a/pkgs/by-name/kc/kclvm_cli/package.nix b/pkgs/by-name/kc/kclvm_cli/package.nix index c6793267cddbd6..ca37fc6e71fb3b 100644 --- a/pkgs/by-name/kc/kclvm_cli/package.nix +++ b/pkgs/by-name/kc/kclvm_cli/package.nix @@ -1,11 +1,11 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, kclvm -, darwin -, rustc -, +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + kclvm, + darwin, + rustc, }: rustPlatform.buildRustPackage rec { pname = "kclvm_cli"; @@ -22,20 +22,26 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-elIo986ag7x+q17HwkcoqFnD9+1+Jq66XIHYZNaBB/w="; cargoPatches = [ ./cargo_lock.patch ]; - buildInputs = [ kclvm rustc ] ++ ( - lib.optionals stdenv.hostPlatform.isDarwin [ + buildInputs = + [ + kclvm + rustc + ] + ++ (lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Security darwin.apple_sdk.frameworks.CoreServices darwin.apple_sdk.frameworks.SystemConfiguration - ] - ); + ]); meta = with lib; { description = "A high-performance implementation of KCL written in Rust that uses LLVM as the compiler backend"; homepage = "https://github.com/kcl-lang/kcl"; license = licenses.asl20; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ selfuryon peefy ]; + maintainers = with maintainers; [ + selfuryon + peefy + ]; mainProgram = "kclvm_cli"; }; } diff --git a/pkgs/by-name/kc/kconfig-frontends/package.nix b/pkgs/by-name/kc/kconfig-frontends/package.nix index b2c74e330f87d5..d7ec574a5963d4 100644 --- a/pkgs/by-name/kc/kconfig-frontends/package.nix +++ b/pkgs/by-name/kc/kconfig-frontends/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, bash -, bison -, flex -, gperf -, ncurses -, pkg-config -, python3 +{ + lib, + stdenv, + fetchurl, + bash, + bison, + flex, + gperf, + ncurses, + pkg-config, + python3, }: stdenv.mkDerivation (finalAttrs: { @@ -27,7 +28,12 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - outputs = [ "out" "lib" "dev" "doc" ]; + outputs = [ + "out" + "lib" + "dev" + "doc" + ]; nativeBuildInputs = [ bison diff --git a/pkgs/by-name/kc/kcov/package.nix b/pkgs/by-name/kc/kcov/package.nix index efb0bba4a1b2fb..cab93025030b7e 100644 --- a/pkgs/by-name/kc/kcov/package.nix +++ b/pkgs/by-name/kc/kcov/package.nix @@ -1,83 +1,96 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, zlib -, curl -, elfutils -, python3 -, libiberty -, libopcodes -, runCommandCC -, rustc +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + zlib, + curl, + elfutils, + python3, + libiberty, + libopcodes, + runCommandCC, + rustc, }: let - self = - stdenv.mkDerivation rec { - pname = "kcov"; - version = "43"; + self = stdenv.mkDerivation rec { + pname = "kcov"; + version = "43"; - src = fetchFromGitHub { - owner = "SimonKagstrom"; - repo = "kcov"; - rev = "v${version}"; - sha256 = "sha256-hRJYuHNSXyRoUDBF/yIPXPcBBxZoTO5cgoB2tBhKPwY="; - }; + src = fetchFromGitHub { + owner = "SimonKagstrom"; + repo = "kcov"; + rev = "v${version}"; + sha256 = "sha256-hRJYuHNSXyRoUDBF/yIPXPcBBxZoTO5cgoB2tBhKPwY="; + }; - preConfigure = "patchShebangs src/bin-to-c-source.py"; - nativeBuildInputs = [ cmake pkg-config python3 ]; + preConfigure = "patchShebangs src/bin-to-c-source.py"; + nativeBuildInputs = [ + cmake + pkg-config + python3 + ]; - buildInputs = [ curl zlib elfutils libiberty libopcodes ]; + buildInputs = [ + curl + zlib + elfutils + libiberty + libopcodes + ]; - strictDeps = true; + strictDeps = true; - passthru.tests = { - works-on-c = runCommandCC "works-on-c" { } '' - set -ex - cat - > a.c < a.c < a.rs < a.rs < "); - test $a == -1983393885 + a=$(echo "(* (+ 1 2 3 4 5 6 7 8 9 10) 12020569 (- 2 5))" | $out/bin/lambda-lisp-blc | tr -d "> "); + test $a == -1983393885 - runHook postInstallCheck + runHook postInstallCheck ''; meta = with lib; { diff --git a/pkgs/by-name/la/lambda-lisp/sources.nix b/pkgs/by-name/la/lambda-lisp/sources.nix index 8dbda01b4e27cd..6160eb7ad3214c 100644 --- a/pkgs/by-name/la/lambda-lisp/sources.nix +++ b/pkgs/by-name/la/lambda-lisp/sources.nix @@ -4,7 +4,8 @@ let # Archive of "https://justine.lol/lambda/"; justineLolArchive = "https://web.archive.org/web/20230614065521if_/https://justine.lol/lambda/"; in -{ fetchFromGitHub, fetchurl }: { +{ fetchFromGitHub, fetchurl }: +{ inherit blcVersion; inherit lambdaLispVersion; diff --git a/pkgs/by-name/la/lambda-mod-zsh-theme/package.nix b/pkgs/by-name/la/lambda-mod-zsh-theme/package.nix index 85bd6d5bf2e0a9..266dd9a2a4ace3 100644 --- a/pkgs/by-name/la/lambda-mod-zsh-theme/package.nix +++ b/pkgs/by-name/la/lambda-mod-zsh-theme/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "lambda-mod-zsh-theme-unstable"; diff --git a/pkgs/by-name/la/lame/package.nix b/pkgs/by-name/la/lame/package.nix index 6032e7051b990e..aa595e94efc2cb 100644 --- a/pkgs/by-name/la/lame/package.nix +++ b/pkgs/by-name/la/lame/package.nix @@ -1,14 +1,19 @@ -{ lib, stdenv, fetchurl -, nasmSupport ? true, nasm # Assembly optimizations -, cpmlSupport ? true # Compaq's fast math library -#, efenceSupport ? false, libefence # Use ElectricFence for malloc debugging -, sndfileFileIOSupport ? false, libsndfile # Use libsndfile, instead of lame's internal routines -, analyzerHooksSupport ? true # Use analyzer hooks -, decoderSupport ? true # mpg123 decoder -, frontendSupport ? true # Build the lame executable -#, mp3xSupport ? false, gtk1 # Build GTK frame analyzer -, mp3rtpSupport ? false # Build mp3rtp -, debugSupport ? false # Debugging (disables optimizations) +{ + lib, + stdenv, + fetchurl, + nasmSupport ? true, + nasm, # Assembly optimizations + cpmlSupport ? true, # Compaq's fast math library + #, efenceSupport ? false, libefence # Use ElectricFence for malloc debugging + sndfileFileIOSupport ? false, + libsndfile, # Use libsndfile, instead of lame's internal routines + analyzerHooksSupport ? true, # Use analyzer hooks + decoderSupport ? true, # mpg123 decoder + frontendSupport ? true, # Build the lame executable + #, mp3xSupport ? false, gtk1 # Build GTK frame analyzer + mp3rtpSupport ? false, # Build mp3rtp + debugSupport ? false, # Debugging (disables optimizations) }: stdenv.mkDerivation rec { @@ -20,13 +25,17 @@ stdenv.mkDerivation rec { sha256 = "07nsn5sy3a8xbmw1bidxnsj5fj6kg9ai04icmqw40ybkp353dznx"; }; - outputs = [ "out" "lib" "doc" ]; # a small single header + outputs = [ + "out" + "lib" + "doc" + ]; # a small single header outputMan = "out"; - nativeBuildInputs = [ ] - ++ lib.optional nasmSupport nasm; + nativeBuildInputs = [ ] ++ lib.optional nasmSupport nasm; - buildInputs = [ ] + buildInputs = + [ ] #++ optional efenceSupport libefence #++ optional mp3xSupport gtk1 ++ lib.optional sndfileFileIOSupport libsndfile; @@ -53,10 +62,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "High quality MPEG Audio Layer III (MP3) encoder"; - homepage = "http://lame.sourceforge.net"; - license = licenses.lgpl2; + homepage = "http://lame.sourceforge.net"; + license = licenses.lgpl2; maintainers = with maintainers; [ codyopel ]; - platforms = platforms.all; + platforms = platforms.all; mainProgram = "lame"; }; } diff --git a/pkgs/by-name/la/laminar/package.nix b/pkgs/by-name/la/laminar/package.nix index e32d3e4a970145..9d5a1d2f7e9b77 100644 --- a/pkgs/by-name/la/laminar/package.nix +++ b/pkgs/by-name/la/laminar/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchurl -, fetchFromGitHub -, cmake -, capnproto -, sqlite -, boost -, zlib -, rapidjson -, pandoc +{ + stdenv, + lib, + fetchurl, + fetchFromGitHub, + cmake, + capnproto, + sqlite, + boost, + zlib, + rapidjson, + pandoc, }: let js.vue = fetchurl { @@ -23,10 +24,14 @@ let url = "https://cdnjs.cloudflare.com/ajax/libs/Chart.js/3.9.1/chart.min.js"; hash = "sha256-+8RZJua0aEWg+QVVKg4LEzEEm/8RFez5Tb4JBNiV5xA="; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "laminar"; version = "1.3"; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; src = fetchFromGitHub { owner = "ohwgiles"; repo = "laminar"; @@ -36,8 +41,18 @@ in stdenv.mkDerivation rec { patches = [ ./patches/no-network.patch ]; # We need both binary from "capnproto" and library files. - nativeBuildInputs = [ cmake pandoc capnproto ]; - buildInputs = [ capnproto sqlite boost zlib rapidjson ]; + nativeBuildInputs = [ + cmake + pandoc + capnproto + ]; + buildInputs = [ + capnproto + sqlite + boost + zlib + rapidjson + ]; cmakeFlags = [ "-DLAMINAR_VERSION=${version}" ]; preBuild = '' @@ -62,6 +77,9 @@ in stdenv.mkDerivation rec { homepage = "https://laminar.ohwg.net"; license = licenses.gpl3Plus; platforms = platforms.linux; - maintainers = with maintainers; [ kaction maralorn ]; + maintainers = with maintainers; [ + kaction + maralorn + ]; }; } diff --git a/pkgs/by-name/la/lammps/package.nix b/pkgs/by-name/la/lammps/package.nix index 28e98e37dc380f..b6e7b89b913440 100644 --- a/pkgs/by-name/la/lammps/package.nix +++ b/pkgs/by-name/la/lammps/package.nix @@ -81,13 +81,16 @@ stdenv.mkDerivation (finalAttrs: { ++ (lib.mapAttrsToList (n: v: lib.cmakeBool "PKG_${n}" v) packages) ++ (lib.mapAttrsToList (n: v: "-D${n}=${v}") extraCmakeFlags); - buildInputs = [ - fftw - libpng - blas - lapack - gzip - ] ++ lib.optionals packages.PYTHON [ python3 ] ++ extraBuildInputs; + buildInputs = + [ + fftw + libpng + blas + lapack + gzip + ] + ++ lib.optionals packages.PYTHON [ python3 ] + ++ extraBuildInputs; postInstall = '' # For backwards compatibility diff --git a/pkgs/by-name/la/languagetool/package.nix b/pkgs/by-name/la/languagetool/package.nix index 8052dd0b83b1bb..247011629235ee 100644 --- a/pkgs/by-name/la/languagetool/package.nix +++ b/pkgs/by-name/la/languagetool/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchzip, jre, makeWrapper, nixosTests }: +{ + lib, + stdenv, + fetchzip, + jre, + makeWrapper, + nixosTests, +}: stdenv.mkDerivation rec { pname = "LanguageTool"; diff --git a/pkgs/by-name/la/lanzaboote-tool/package.nix b/pkgs/by-name/la/lanzaboote-tool/package.nix index 05ea3e4391eb70..c13a0b8974df2a 100644 --- a/pkgs/by-name/la/lanzaboote-tool/package.nix +++ b/pkgs/by-name/la/lanzaboote-tool/package.nix @@ -1,11 +1,12 @@ -{ systemd -, stdenv -, makeWrapper -, binutils-unwrapped -, sbsigntool -, rustPlatform -, fetchFromGitHub -, lib +{ + systemd, + stdenv, + makeWrapper, + binutils-unwrapped, + sbsigntool, + rustPlatform, + fetchFromGitHub, + lib, }: rustPlatform.buildRustPackage rec { pname = "lanzaboote-tool"; @@ -34,7 +35,12 @@ rustPlatform.buildRustPackage rec { # UEFI stub location. mv $out/bin/lzbt $out/bin/lzbt-unwrapped wrapProgram $out/bin/lzbt-unwrapped \ - --set PATH ${lib.makeBinPath [ binutils-unwrapped sbsigntool ]} + --set PATH ${ + lib.makeBinPath [ + binutils-unwrapped + sbsigntool + ] + } ''; nativeCheckInputs = [ @@ -47,9 +53,15 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/nix-community/lanzaboote"; license = licenses.gpl3Only; mainProgram = "lzbt"; - maintainers = with maintainers; [ raitobezarius nikstur ]; + maintainers = with maintainers; [ + raitobezarius + nikstur + ]; # Broken on aarch64-linux and any other architecture for now. # Wait for 0.4.0. - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/by-name/la/lao/package.nix b/pkgs/by-name/la/lao/package.nix index d7d5d3ddd4b159..921d9c9321714a 100644 --- a/pkgs/by-name/la/lao/package.nix +++ b/pkgs/by-name/la/lao/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "lao"; diff --git a/pkgs/by-name/la/lapack-reference/package.nix b/pkgs/by-name/la/lapack-reference/package.nix index def5379d27c8f5..ada93fccc58038 100644 --- a/pkgs/by-name/la/lapack-reference/package.nix +++ b/pkgs/by-name/la/lapack-reference/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, gfortran -, cmake -, shared ? true -# Compile with ILP64 interface -, blas64 ? false -, testers +{ + lib, + stdenv, + fetchFromGitHub, + gfortran, + cmake, + shared ? true, + # Compile with ILP64 interface + blas64 ? false, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -20,33 +21,46 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-xn9HL4YF8JPka1gwet5bGGo2k505H3RfWpxkUIYNecQ="; }; - nativeBuildInputs = [ gfortran cmake ]; + nativeBuildInputs = [ + gfortran + cmake + ]; # Configure stage fails on aarch64-darwin otherwise, due to either clang 11 or gfortran 10. - hardeningDisable = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ "stackprotector" ]; + hardeningDisable = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + "stackprotector" + ]; - cmakeFlags = [ - "-DCMAKE_Fortran_FLAGS=-fPIC" - "-DLAPACKE=ON" - "-DCBLAS=ON" - "-DBUILD_TESTING=ON" - ] ++ lib.optional shared "-DBUILD_SHARED_LIBS=ON" + cmakeFlags = + [ + "-DCMAKE_Fortran_FLAGS=-fPIC" + "-DLAPACKE=ON" + "-DCBLAS=ON" + "-DBUILD_TESTING=ON" + ] + ++ lib.optional shared "-DBUILD_SHARED_LIBS=ON" ++ lib.optional blas64 "-DBUILD_INDEX64=ON" # Tries to run host platform binaries during the build # Will likely be disabled by default in 3.12, see: # https://github.com/Reference-LAPACK/lapack/issues/757 - ++ lib.optional (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) "-DTEST_FORTRAN_COMPILER=OFF"; + ++ lib.optional ( + !stdenv.buildPlatform.canExecute stdenv.hostPlatform + ) "-DTEST_FORTRAN_COMPILER=OFF"; passthru = { inherit blas64; }; - postInstall = let - canonicalExtension = if stdenv.hostPlatform.isLinux - then "${stdenv.hostPlatform.extensions.sharedLibrary}.${lib.versions.major finalAttrs.version}" - else stdenv.hostPlatform.extensions.sharedLibrary; - in lib.optionalString blas64 '' - ln -s $out/lib/liblapack64${canonicalExtension} $out/lib/liblapack${canonicalExtension} - ln -s $out/lib/liblapacke64${canonicalExtension} $out/lib/liblapacke${canonicalExtension} - ''; + postInstall = + let + canonicalExtension = + if stdenv.hostPlatform.isLinux then + "${stdenv.hostPlatform.extensions.sharedLibrary}.${lib.versions.major finalAttrs.version}" + else + stdenv.hostPlatform.extensions.sharedLibrary; + in + lib.optionalString blas64 '' + ln -s $out/lib/liblapack64${canonicalExtension} $out/lib/liblapack${canonicalExtension} + ln -s $out/lib/liblapacke64${canonicalExtension} $out/lib/liblapacke${canonicalExtension} + ''; doCheck = true; diff --git a/pkgs/by-name/la/lapack/package.nix b/pkgs/by-name/la/lapack/package.nix index 983d59ac6f6099..017c84213760cf 100644 --- a/pkgs/by-name/la/lapack/package.nix +++ b/pkgs/by-name/la/lapack/package.nix @@ -1,19 +1,27 @@ -{ lib, stdenv -, lapack-reference, openblas -, isILP64 ? false -, lapackProvider ? openblas }: +{ + lib, + stdenv, + lapack-reference, + openblas, + isILP64 ? false, + lapackProvider ? openblas, +}: let version = "3"; - canonicalExtension = if stdenv.hostPlatform.isLinux - then "${stdenv.hostPlatform.extensions.sharedLibrary}.${version}" - else stdenv.hostPlatform.extensions.sharedLibrary; + canonicalExtension = + if stdenv.hostPlatform.isLinux then + "${stdenv.hostPlatform.extensions.sharedLibrary}.${version}" + else + stdenv.hostPlatform.extensions.sharedLibrary; lapackImplementation = lib.getName lapackProvider; - lapackProvider' = if lapackImplementation == "mkl" - then lapackProvider - else lapackProvider.override { blas64 = isILP64; }; + lapackProvider' = + if lapackImplementation == "mkl" then + lapackProvider + else + lapackProvider.override { blas64 = isILP64; }; in @@ -23,9 +31,12 @@ stdenv.mkDerivation { pname = "lapack"; inherit version; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - meta = (lapackProvider'.meta or {}) // { + meta = (lapackProvider'.meta or { }) // { description = "${lib.getName lapackProvider'} with just the LAPACK C and FORTRAN ABI"; }; @@ -36,7 +47,8 @@ stdenv.mkDerivation { }; # TODO: drop this forced rebuild, as it was needed just once. - rebuild_salt = if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64 then "J4AQ" else null; + rebuild_salt = + if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64 then "J4AQ" else null; dontBuild = true; dontConfigure = true; @@ -44,70 +56,77 @@ stdenv.mkDerivation { dontPatchELF = true; - installPhase = ('' - mkdir -p $out/lib $dev/include $dev/lib/pkgconfig - - liblapack="${lib.getLib lapackProvider'}/lib/liblapack${canonicalExtension}" - - if ! [ -e "$liblapack" ]; then - echo "$liblapack does not exist, ${lapackProvider'.name} does not provide liblapack." - exit 1 - fi - - cp -L "$liblapack" $out/lib/liblapack${canonicalExtension} - chmod +w $out/lib/liblapack${canonicalExtension} - -'' + (lib.optionalString stdenv.hostPlatform.isElf '' - patchelf --set-soname liblapack${canonicalExtension} $out/lib/liblapack${canonicalExtension} - patchelf --set-rpath "$(patchelf --print-rpath $out/lib/liblapack${canonicalExtension}):${lapackProvider'}/lib" $out/lib/liblapack${canonicalExtension} -'') + '' - - if [ "$out/lib/liblapack${canonicalExtension}" != "$out/lib/liblapack${stdenv.hostPlatform.extensions.sharedLibrary}" ]; then - ln -s $out/lib/liblapack${canonicalExtension} "$out/lib/liblapack${stdenv.hostPlatform.extensions.sharedLibrary}" - fi - - install -D ${lib.getDev lapack-reference}/include/lapack.h $dev/include/lapack.h - - cat < $dev/lib/pkgconfig/lapack.pc -Name: lapack -Version: ${version} -Description: LAPACK FORTRAN implementation -Cflags: -I$dev/include -Libs: -L$out/lib -llapack -EOF - - liblapacke="${lib.getLib lapackProvider'}/lib/liblapacke${canonicalExtension}" - - if ! [ -e "$liblapacke" ]; then - echo "$liblapacke does not exist, ${lapackProvider'.name} does not provide liblapacke." - exit 1 - fi - - cp -L "$liblapacke" $out/lib/liblapacke${canonicalExtension} - chmod +w $out/lib/liblapacke${canonicalExtension} - -'' + (lib.optionalString stdenv.hostPlatform.isElf '' - patchelf --set-soname liblapacke${canonicalExtension} $out/lib/liblapacke${canonicalExtension} - patchelf --set-rpath "$(patchelf --print-rpath $out/lib/liblapacke${canonicalExtension}):${lib.getLib lapackProvider'}/lib" $out/lib/liblapacke${canonicalExtension} -'') + '' - - if [ -f "$out/lib/liblapacke.so.3" ]; then - ln -s $out/lib/liblapacke.so.3 $out/lib/liblapacke.so - fi - - cp ${lib.getDev lapack-reference}/include/lapacke{,_mangling,_config,_utils}.h $dev/include - - cat < $dev/lib/pkgconfig/lapacke.pc -Name: lapacke -Version: ${version} -Description: LAPACK C implementation -Cflags: -I$dev/include -Libs: -L$out/lib -llapacke -EOF -'' + lib.optionalString (lapackImplementation == "mkl") '' - mkdir -p $out/nix-support - echo 'export MKL_INTERFACE_LAYER=${lib.optionalString isILP64 "I"}LP64,GNU' > $out/nix-support/setup-hook - ln -s $out/lib/liblapack${canonicalExtension} $out/lib/libmkl_rt${stdenv.hostPlatform.extensions.sharedLibrary} - ln -sf ${lapackProvider'}/include/* $dev/include -''); + installPhase = ( + '' + mkdir -p $out/lib $dev/include $dev/lib/pkgconfig + + liblapack="${lib.getLib lapackProvider'}/lib/liblapack${canonicalExtension}" + + if ! [ -e "$liblapack" ]; then + echo "$liblapack does not exist, ${lapackProvider'.name} does not provide liblapack." + exit 1 + fi + + cp -L "$liblapack" $out/lib/liblapack${canonicalExtension} + chmod +w $out/lib/liblapack${canonicalExtension} + + '' + + (lib.optionalString stdenv.hostPlatform.isElf '' + patchelf --set-soname liblapack${canonicalExtension} $out/lib/liblapack${canonicalExtension} + patchelf --set-rpath "$(patchelf --print-rpath $out/lib/liblapack${canonicalExtension}):${lapackProvider'}/lib" $out/lib/liblapack${canonicalExtension} + '') + + '' + + if [ "$out/lib/liblapack${canonicalExtension}" != "$out/lib/liblapack${stdenv.hostPlatform.extensions.sharedLibrary}" ]; then + ln -s $out/lib/liblapack${canonicalExtension} "$out/lib/liblapack${stdenv.hostPlatform.extensions.sharedLibrary}" + fi + + install -D ${lib.getDev lapack-reference}/include/lapack.h $dev/include/lapack.h + + cat < $dev/lib/pkgconfig/lapack.pc + Name: lapack + Version: ${version} + Description: LAPACK FORTRAN implementation + Cflags: -I$dev/include + Libs: -L$out/lib -llapack + EOF + + liblapacke="${lib.getLib lapackProvider'}/lib/liblapacke${canonicalExtension}" + + if ! [ -e "$liblapacke" ]; then + echo "$liblapacke does not exist, ${lapackProvider'.name} does not provide liblapacke." + exit 1 + fi + + cp -L "$liblapacke" $out/lib/liblapacke${canonicalExtension} + chmod +w $out/lib/liblapacke${canonicalExtension} + + '' + + (lib.optionalString stdenv.hostPlatform.isElf '' + patchelf --set-soname liblapacke${canonicalExtension} $out/lib/liblapacke${canonicalExtension} + patchelf --set-rpath "$(patchelf --print-rpath $out/lib/liblapacke${canonicalExtension}):${lib.getLib lapackProvider'}/lib" $out/lib/liblapacke${canonicalExtension} + '') + + '' + + if [ -f "$out/lib/liblapacke.so.3" ]; then + ln -s $out/lib/liblapacke.so.3 $out/lib/liblapacke.so + fi + + cp ${lib.getDev lapack-reference}/include/lapacke{,_mangling,_config,_utils}.h $dev/include + + cat < $dev/lib/pkgconfig/lapacke.pc + Name: lapacke + Version: ${version} + Description: LAPACK C implementation + Cflags: -I$dev/include + Libs: -L$out/lib -llapacke + EOF + '' + + lib.optionalString (lapackImplementation == "mkl") '' + mkdir -p $out/nix-support + echo 'export MKL_INTERFACE_LAYER=${lib.optionalString isILP64 "I"}LP64,GNU' > $out/nix-support/setup-hook + ln -s $out/lib/liblapack${canonicalExtension} $out/lib/libmkl_rt${stdenv.hostPlatform.extensions.sharedLibrary} + ln -sf ${lapackProvider'}/include/* $dev/include + '' + ); } diff --git a/pkgs/by-name/la/larswm/package.nix b/pkgs/by-name/la/larswm/package.nix index ce212b1c682bee..28d5fe805c5ac2 100644 --- a/pkgs/by-name/la/larswm/package.nix +++ b/pkgs/by-name/la/larswm/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, imake, gccmakedep, libX11, libXext, libXmu }: +{ + lib, + stdenv, + fetchurl, + imake, + gccmakedep, + libX11, + libXext, + libXmu, +}: stdenv.mkDerivation rec { pname = "larswm"; @@ -9,11 +18,24 @@ stdenv.mkDerivation rec { sha256 = "1xmlx9g1nhklxjrg0wvsya01s4k5b9fphnpl9zdwp29mm484ni3v"; }; - nativeBuildInputs = [ imake gccmakedep ]; - buildInputs = [ libX11 libXext libXmu ]; + nativeBuildInputs = [ + imake + gccmakedep + ]; + buildInputs = [ + libX11 + libXext + libXmu + ]; - makeFlags = [ "BINDIR=$(out)/bin" "MANPATH=$(out)/share/man" ]; - installTargets = [ "install" "install.man" ]; + makeFlags = [ + "BINDIR=$(out)/bin" + "MANPATH=$(out)/share/man" + ]; + installTargets = [ + "install" + "install.man" + ]; meta = { homepage = "http://www.fnurt.net/larswm"; diff --git a/pkgs/by-name/la/lasem/package.nix b/pkgs/by-name/la/lasem/package.nix index c76a6955625092..f7482e5dec8111 100644 --- a/pkgs/by-name/la/lasem/package.nix +++ b/pkgs/by-name/la/lasem/package.nix @@ -1,21 +1,48 @@ -{ fetchurl, lib, stdenv, pkg-config, intltool, gobject-introspection, glib, gdk-pixbuf -, libxml2, cairo, pango, gnome }: +{ + fetchurl, + lib, + stdenv, + pkg-config, + intltool, + gobject-introspection, + glib, + gdk-pixbuf, + libxml2, + cairo, + pango, + gnome, +}: stdenv.mkDerivation rec { pname = "lasem"; version = "0.4.4"; - outputs = [ "bin" "out" "dev" "man" "doc" "devdoc" ]; + outputs = [ + "bin" + "out" + "dev" + "man" + "doc" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; sha256 = "0fds3fsx84ylsfvf55zp65y8xqjj5n8gbhcsk02vqglivk7izw4v"; }; - nativeBuildInputs = [ pkg-config intltool gobject-introspection ]; + nativeBuildInputs = [ + pkg-config + intltool + gobject-introspection + ]; propagatedBuildInputs = [ - glib gdk-pixbuf libxml2 cairo pango + glib + gdk-pixbuf + libxml2 + cairo + pango ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/la/lash/package.nix b/pkgs/by-name/la/lash/package.nix index e7c5a822cd4b3c..c3ec6476b2a4e4 100644 --- a/pkgs/by-name/la/lash/package.nix +++ b/pkgs/by-name/la/lash/package.nix @@ -1,9 +1,20 @@ -{ lib, stdenv, fetchurl, alsa-lib, gtk2, libjack2, libuuid, libxml2 -, makeWrapper, pkg-config, readline }: +{ + lib, + stdenv, + fetchurl, + alsa-lib, + gtk2, + libjack2, + libuuid, + libxml2, + makeWrapper, + pkg-config, + readline, +}: assert libuuid != null; -stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "lash"; version = "0.5.4"; @@ -13,10 +24,22 @@ stdenv.mkDerivation rec { }; # http://permalink.gmane.org/gmane.linux.redhat.fedora.extras.cvs/822346 - patches = [ ./socket.patch ./gcc-47.patch ]; + patches = [ + ./socket.patch + ./gcc-47.patch + ]; - nativeBuildInputs = [ pkg-config makeWrapper ]; - buildInputs = [ alsa-lib gtk2 libjack2 libxml2 readline ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; + buildInputs = [ + alsa-lib + gtk2 + libjack2 + libxml2 + readline + ]; propagatedBuildInputs = [ libuuid ]; NIX_LDFLAGS = "-lm -lpthread -luuid"; diff --git a/pkgs/by-name/la/lasso/package.nix b/pkgs/by-name/la/lasso/package.nix index 7b2965f1f73056..88f77f42bdd512 100644 --- a/pkgs/by-name/la/lasso/package.nix +++ b/pkgs/by-name/la/lasso/package.nix @@ -1,18 +1,20 @@ -{ lib, stdenv -, autoreconfHook -, fetchurl -, fetchpatch -, glib -, gobject-introspection -, gtk-doc -, libtool -, libxml2 -, libxslt -, openssl -, pkg-config -, python3 -, xmlsec -, zlib +{ + lib, + stdenv, + autoreconfHook, + fetchurl, + fetchpatch, + glib, + gobject-introspection, + gtk-doc, + libtool, + libxml2, + libxslt, + openssl, + pkg-config, + python3, + xmlsec, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/la/last-resort/package.nix b/pkgs/by-name/la/last-resort/package.nix index 87fb95e96035f7..fb1a4e5411c53e 100644 --- a/pkgs/by-name/la/last-resort/package.nix +++ b/pkgs/by-name/la/last-resort/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "last-resort"; diff --git a/pkgs/by-name/la/lastfm/package.nix b/pkgs/by-name/la/lastfm/package.nix index 345e21b87994c4..cfd068185f4a39 100644 --- a/pkgs/by-name/la/lastfm/package.nix +++ b/pkgs/by-name/la/lastfm/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchzip -, stdenvNoCC -, writeShellApplication -, curl -, xmlstarlet -, common-updater-scripts +{ + lib, + fetchzip, + stdenvNoCC, + writeShellApplication, + curl, + xmlstarlet, + common-updater-scripts, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/la/lastpass-cli/package.nix b/pkgs/by-name/la/lastpass-cli/package.nix index c6449f8f8e6161..c4c7d48d85dbd4 100644 --- a/pkgs/by-name/la/lastpass-cli/package.nix +++ b/pkgs/by-name/la/lastpass-cli/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, asciidoc -, cmake -, docbook_xsl -, pkg-config -, bash-completion -, openssl -, curl -, libxml2 -, libxslt +{ + stdenv, + lib, + fetchFromGitHub, + asciidoc, + cmake, + docbook_xsl, + pkg-config, + bash-completion, + openssl, + curl, + libxml2, + libxslt, }: stdenv.mkDerivation rec { @@ -23,7 +24,12 @@ stdenv.mkDerivation rec { sha256 = "sha256-Q0ZG5Ehg29STLeAerMoLfzjaH9JyPk7269RgiPmDJV8="; }; - nativeBuildInputs = [ asciidoc cmake docbook_xsl pkg-config ]; + nativeBuildInputs = [ + asciidoc + cmake + docbook_xsl + pkg-config + ]; buildInputs = [ bash-completion @@ -33,7 +39,10 @@ stdenv.mkDerivation rec { libxslt ]; - installTargets = [ "install" "install-doc" ]; + installTargets = [ + "install" + "install-doc" + ]; postInstall = '' install -Dm644 -T ../contrib/lpass_zsh_completion $out/share/zsh/site-functions/_lpass diff --git a/pkgs/by-name/la/laszip/package.nix b/pkgs/by-name/la/laszip/package.nix index ded2abb03fec8d..270d715db99eae 100644 --- a/pkgs/by-name/la/laszip/package.nix +++ b/pkgs/by-name/la/laszip/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, fixDarwinDylibNames +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fixDarwinDylibNames, }: stdenv.mkDerivation (finalAttrs: { @@ -16,11 +17,13 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-9fzal54YaocONtguOCxnP7h1LejQPQ0dKFiCzfvTjCY="; }; - nativeBuildInputs = [ - cmake - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ]; + nativeBuildInputs = + [ + cmake + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ]; meta = { description = "Turn quickly bulky LAS files into compact LAZ files without information loss"; diff --git a/pkgs/by-name/la/laszip_2/package.nix b/pkgs/by-name/la/laszip_2/package.nix index e7a7bb00302d78..735e3e9c3836f0 100644 --- a/pkgs/by-name/la/laszip_2/package.nix +++ b/pkgs/by-name/la/laszip_2/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation (finalAttrs: { version = "2.2.0"; diff --git a/pkgs/by-name/la/latexminted/package.nix b/pkgs/by-name/la/latexminted/package.nix index c8947c7ce70c47..ee5409f5dadf76 100644 --- a/pkgs/by-name/la/latexminted/package.nix +++ b/pkgs/by-name/la/latexminted/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchPypi -, python3Packages -, latexminted -, testers +{ + lib, + fetchPypi, + python3Packages, + latexminted, + testers, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/la/latexrun/package.nix b/pkgs/by-name/la/latexrun/package.nix index 5cab85a1cc1ff2..464fc7dc9c0d77 100644 --- a/pkgs/by-name/la/latexrun/package.nix +++ b/pkgs/by-name/la/latexrun/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchFromGitHub, python3 }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + python3, +}: stdenvNoCC.mkDerivation { pname = "latexrun"; diff --git a/pkgs/by-name/la/lato/package.nix b/pkgs/by-name/la/lato/package.nix index ff1cc62bee0e92..de07e06369b92c 100644 --- a/pkgs/by-name/la/lato/package.nix +++ b/pkgs/by-name/la/lato/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { pname = "lato"; diff --git a/pkgs/by-name/la/latte-integrale/package.nix b/pkgs/by-name/la/latte-integrale/package.nix index 822e0f23821414..d6f9df4cc1f680 100644 --- a/pkgs/by-name/la/latte-integrale/package.nix +++ b/pkgs/by-name/la/latte-integrale/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, gmp -, ntl -, cddlib +{ + lib, + stdenv, + fetchurl, + fetchpatch, + gmp, + ntl, + cddlib, }: stdenv.mkDerivation (finalAttrs: { @@ -12,7 +13,9 @@ stdenv.mkDerivation (finalAttrs: { version = "1.7.6"; src = fetchurl { - url = "https://github.com/latte-int/latte/releases/download/version_${lib.replaceStrings ["."] ["_"] finalAttrs.version}/latte-int-${finalAttrs.version}.tar.gz"; + url = "https://github.com/latte-int/latte/releases/download/version_${ + lib.replaceStrings [ "." ] [ "_" ] finalAttrs.version + }/latte-int-${finalAttrs.version}.tar.gz"; hash = "sha256-AGwQ6+XVv9ybFZy6YmSkQyhh/nY84F/oIWJKt9P8IXA="; }; diff --git a/pkgs/by-name/la/lattice-diamond/package.nix b/pkgs/by-name/la/lattice-diamond/package.nix index f80261720cf671..462101b67a3074 100644 --- a/pkgs/by-name/la/lattice-diamond/package.nix +++ b/pkgs/by-name/la/lattice-diamond/package.nix @@ -1,11 +1,30 @@ -{ lib, stdenv, rpmextract, patchelf, makeWrapper, file, requireFile, glib, zlib, - freetype, fontconfig, xorg, libusb-compat-0_1, coreutils }: +{ + lib, + stdenv, + rpmextract, + patchelf, + makeWrapper, + file, + requireFile, + glib, + zlib, + freetype, + fontconfig, + xorg, + libusb-compat-0_1, + coreutils, +}: stdenv.mkDerivation { pname = "diamond"; version = "3.10"; - nativeBuildInputs = [ rpmextract patchelf makeWrapper file ]; + nativeBuildInputs = [ + rpmextract + patchelf + makeWrapper + file + ]; src = requireFile { name = "diamond_3_10-base_x64-111-2-x86_64-linux.rpm"; @@ -100,8 +119,16 @@ stdenv.mkDerivation { ''; libPath = lib.makeLibraryPath [ - glib zlib freetype fontconfig - xorg.libSM xorg.libICE xorg.libXrender xorg.libXext xorg.libX11 xorg.libXt + glib + zlib + freetype + fontconfig + xorg.libSM + xorg.libICE + xorg.libXrender + xorg.libXext + xorg.libX11 + xorg.libXt libusb-compat-0_1 ]; diff --git a/pkgs/by-name/la/laudanum/package.nix b/pkgs/by-name/la/laudanum/package.nix index 3a4cc8bd16a9eb..19d0122a86f553 100644 --- a/pkgs/by-name/la/laudanum/package.nix +++ b/pkgs/by-name/la/laudanum/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/la/lavat/package.nix b/pkgs/by-name/la/lavat/package.nix index 6cd38f6f34a188..12beae650e5264 100644 --- a/pkgs/by-name/la/lavat/package.nix +++ b/pkgs/by-name/la/lavat/package.nix @@ -1,7 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub -, +{ + lib, + stdenv, + fetchFromGitHub, }: let version = "2.1.0"; diff --git a/pkgs/by-name/la/layan-gtk-theme/package.nix b/pkgs/by-name/la/layan-gtk-theme/package.nix index b72f3d2ffe8d08..c159d831212fa9 100644 --- a/pkgs/by-name/la/layan-gtk-theme/package.nix +++ b/pkgs/by-name/la/layan-gtk-theme/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, fetchFromGitHub -, lib -, gtk-engine-murrine +{ + stdenv, + fetchFromGitHub, + lib, + gtk-engine-murrine, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/la/lazycli/package.nix b/pkgs/by-name/la/lazycli/package.nix index 77596b66302f13..80c8f4bbac3e87 100644 --- a/pkgs/by-name/la/lazycli/package.nix +++ b/pkgs/by-name/la/lazycli/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "lazycli"; diff --git a/pkgs/by-name/la/lazydocker/package.nix b/pkgs/by-name/la/lazydocker/package.nix index 828e6048c1d8e9..d3b35e97073115 100644 --- a/pkgs/by-name/la/lazydocker/package.nix +++ b/pkgs/by-name/la/lazydocker/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, lazydocker, testers }: +{ + lib, + buildGoModule, + fetchFromGitHub, + lazydocker, + testers, +}: buildGoModule rec { pname = "lazydocker"; @@ -17,9 +23,16 @@ buildGoModule rec { rm -f pkg/config/app_config_test.go ''; - excludedPackages = [ "scripts" "test/printrandom" ]; + excludedPackages = [ + "scripts" + "test/printrandom" + ]; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; passthru.tests.version = testers.testVersion { package = lazydocker; @@ -29,7 +42,10 @@ buildGoModule rec { description = "Simple terminal UI for both docker and docker-compose"; homepage = "https://github.com/jesseduffield/lazydocker"; license = licenses.mit; - maintainers = with maintainers; [ das-g Br1ght0ne ]; + maintainers = with maintainers; [ + das-g + Br1ght0ne + ]; mainProgram = "lazydocker"; }; } diff --git a/pkgs/by-name/la/lazymc/package.nix b/pkgs/by-name/la/lazymc/package.nix index 8df8352d8a51b1..75a6c1536c7fde 100644 --- a/pkgs/by-name/la/lazymc/package.nix +++ b/pkgs/by-name/la/lazymc/package.nix @@ -1,10 +1,10 @@ { - lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin -, nix-update-script + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, + nix-update-script, }: rustPlatform.buildRustPackage rec { @@ -35,7 +35,10 @@ rustPlatform.buildRustPackage rec { description = "Remote wake-up daemon for minecraft servers"; homepage = "https://github.com/timvisee/lazymc"; license = licenses.gpl3Only; - maintainers = with maintainers; [ h7x4 dandellion ]; + maintainers = with maintainers; [ + h7x4 + dandellion + ]; platforms = platforms.unix; mainProgram = "lazymc"; }; diff --git a/pkgs/by-name/lb/lbd/package.nix b/pkgs/by-name/lb/lbd/package.nix index f84ed553ad25b9..330d2775c03fd7 100644 --- a/pkgs/by-name/lb/lbd/package.nix +++ b/pkgs/by-name/lb/lbd/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, makeWrapper -, bash -, coreutils -, diffutils -, gawk -, gnugrep -, gnused -, host -, netcat-openbsd +{ + lib, + stdenvNoCC, + fetchFromGitHub, + makeWrapper, + bash, + coreutils, + diffutils, + gawk, + gnugrep, + gnused, + host, + netcat-openbsd, }: stdenvNoCC.mkDerivation { @@ -32,7 +33,17 @@ stdenvNoCC.mkDerivation { mkdir -p $out/{bin,share/lbd} cp lbd $out/share/lbd/ makeWrapper ${lib.getExe bash} $out/bin/lbd \ - --prefix PATH : "${lib.makeBinPath [ coreutils diffutils gawk gnugrep gnused host netcat-openbsd ]}" \ + --prefix PATH : "${ + lib.makeBinPath [ + coreutils + diffutils + gawk + gnugrep + gnused + host + netcat-openbsd + ] + }" \ --add-flags "$out/share/lbd/lbd" runHook postInstall ''; diff --git a/pkgs/by-name/lb/lbdb/package.nix b/pkgs/by-name/lb/lbdb/package.nix index cd1f8d0c486186..c0cdd532a25f58 100644 --- a/pkgs/by-name/lb/lbdb/package.nix +++ b/pkgs/by-name/lb/lbdb/package.nix @@ -1,23 +1,31 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, perl -, bsd-finger -, withAbook ? true, abook -, withGnupg ? true, gnupg -, withGoobook ? true, goobook -, withKhard ? true, khard -, withMu ? true, mu +{ + lib, + stdenv, + fetchurl, + fetchpatch, + perl, + bsd-finger, + withAbook ? true, + abook, + withGnupg ? true, + gnupg, + withGoobook ? true, + goobook, + withKhard ? true, + khard, + withMu ? true, + mu, }: let - perl' = perl.withPackages (p: with p; [ - AuthenSASL - ConvertASN1 - IOSocketSSL - perlldap - ]); + perl' = perl.withPackages ( + p: with p; [ + AuthenSASL + ConvertASN1 + IOSocketSSL + perlldap + ] + ); in stdenv.mkDerivation rec { pname = "lbdb"; @@ -28,7 +36,8 @@ stdenv.mkDerivation rec { sha256 = "1gr5l2fr9qbdccga8bhsrpvz6jxigvfkdxrln9wyf2xpps5cdjxh"; }; - buildInputs = [ perl' ] + buildInputs = + [ perl' ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) bsd-finger ++ lib.optional withAbook abook ++ lib.optional withGnupg gnupg @@ -36,7 +45,8 @@ stdenv.mkDerivation rec { ++ lib.optional withKhard khard ++ lib.optional withMu mu; - configureFlags = [ ] + configureFlags = + [ ] ++ lib.optional withAbook "--with-abook" ++ lib.optional withGnupg "--with-gpg" ++ lib.optional withGoobook "--with-goobook" @@ -57,7 +67,10 @@ stdenv.mkDerivation rec { homepage = "https://www.spinnaker.de/lbdb/"; description = "Little Brother's Database"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ kaiha bfortz ]; + maintainers = with maintainers; [ + kaiha + bfortz + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/lb/lbreakout2/package.nix b/pkgs/by-name/lb/lbreakout2/package.nix index 4853162ab111f9..fb53778a817ae9 100644 --- a/pkgs/by-name/lb/lbreakout2/package.nix +++ b/pkgs/by-name/lb/lbreakout2/package.nix @@ -1,12 +1,13 @@ -{ lib -, SDL -, SDL_mixer -, fetchpatch -, fetchurl -, libintl -, libpng -, stdenv -, zlib +{ + lib, + SDL, + SDL_mixer, + fetchpatch, + fetchurl, + libintl, + libpng, + stdenv, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -47,7 +48,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Breakout clone from the LGames series"; license = with lib.licenses; [ gpl2Plus ]; mainProgram = "lbreakout2"; - maintainers = with lib.maintainers; [ AndersonTorres ciil ]; + maintainers = with lib.maintainers; [ + AndersonTorres + ciil + ]; platforms = lib.platforms.unix; hydraPlatforms = lib.platforms.linux; # build hangs on both Darwin platforms, needs investigation }; diff --git a/pkgs/by-name/lb/lbreakouthd/package.nix b/pkgs/by-name/lb/lbreakouthd/package.nix index 2675718466930a..e694a3a8ebea38 100644 --- a/pkgs/by-name/lb/lbreakouthd/package.nix +++ b/pkgs/by-name/lb/lbreakouthd/package.nix @@ -1,11 +1,12 @@ -{ lib -, SDL2 -, SDL2_image -, SDL2_mixer -, SDL2_ttf -, directoryListingUpdater -, fetchurl -, stdenv +{ + lib, + SDL2, + SDL2_image, + SDL2_mixer, + SDL2_ttf, + directoryListingUpdater, + fetchurl, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/lb/lbry/package.nix b/pkgs/by-name/lb/lbry/package.nix index fe4100ebef57e4..8785b836f05163 100644 --- a/pkgs/by-name/lb/lbry/package.nix +++ b/pkgs/by-name/lb/lbry/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools}: +{ + lib, + fetchurl, + appimageTools, +}: appimageTools.wrapAppImage rec { pname = "lbry-desktop"; diff --git a/pkgs/by-name/lb/lbzip2/package.nix b/pkgs/by-name/lb/lbzip2/package.nix index 2e7557a310e516..b08fa3c465160a 100644 --- a/pkgs/by-name/lb/lbzip2/package.nix +++ b/pkgs/by-name/lb/lbzip2/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, gnulib, perl, autoconf, automake }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + gnulib, + perl, + autoconf, + automake, +}: stdenv.mkDerivation rec { pname = "lbzip2"; @@ -22,8 +31,14 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ gnulib perl ]; - nativeBuildInputs = [ autoconf automake ]; + buildInputs = [ + gnulib + perl + ]; + nativeBuildInputs = [ + autoconf + automake + ]; preConfigure = '' substituteInPlace configure.ac --replace 'AC_PREREQ([2.63])' 'AC_PREREQ(2.64)' diff --git a/pkgs/by-name/lc/lc0/package.nix b/pkgs/by-name/lc/lc0/package.nix index 1c1099752580ca..adc46d627a3cb8 100644 --- a/pkgs/by-name/lc/lc0/package.nix +++ b/pkgs/by-name/lc/lc0/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, python3 -, zlib -, gtest -, eigen +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + python3, + zlib, + gtest, + eigen, }: stdenv.mkDerivation rec { @@ -45,15 +46,15 @@ stdenv.mkDerivation rec { zlib ]; - mesonFlags = [ - "-Dplain_cuda=false" - "-Daccelerate=false" - "-Dmetal=disabled" - "-Dembed=false" - ] - # in version 31 this option will be required - ++ lib.optionals (lib.versionAtLeast version "0.31") [ "-Dnative_cuda=false" ]; - + mesonFlags = + [ + "-Dplain_cuda=false" + "-Daccelerate=false" + "-Dmetal=disabled" + "-Dembed=false" + ] + # in version 31 this option will be required + ++ lib.optionals (lib.versionAtLeast version "0.31") [ "-Dnative_cuda=false" ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/lc/lc3tools/package.nix b/pkgs/by-name/lc/lc3tools/package.nix index c6120a227a993e..f1ea3735193983 100644 --- a/pkgs/by-name/lc/lc3tools/package.nix +++ b/pkgs/by-name/lc/lc3tools/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, unzip, flex, tk, ncurses, readline }: +{ + lib, + stdenv, + fetchurl, + unzip, + flex, + tk, + ncurses, + readline, +}: stdenv.mkDerivation { pname = "lc3tools"; @@ -25,7 +34,12 @@ stdenv.mkDerivation { ]; nativeBuildInputs = [ unzip ]; - buildInputs = [ flex tk ncurses readline ]; + buildInputs = [ + flex + tk + ncurses + readline + ]; # lumetta published this a while ago but handrolled his configure # jank in the original packaging makes this necessary: diff --git a/pkgs/by-name/lc/lcab/package.nix b/pkgs/by-name/lc/lcab/package.nix index 54f6159ab15dbb..dc7d018f239839 100644 --- a/pkgs/by-name/lc/lcab/package.nix +++ b/pkgs/by-name/lc/lcab/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/lc/lcalc/package.nix b/pkgs/by-name/lc/lcalc/package.nix index 6ea1ca8f8e6c09..f81ea501270fc4 100644 --- a/pkgs/by-name/lc/lcalc/package.nix +++ b/pkgs/by-name/lc/lcalc/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, autoreconfHook -, gengetopt -, pkg-config -, fetchFromGitLab -, pari +{ + lib, + stdenv, + autoreconfHook, + gengetopt, + pkg-config, + fetchFromGitLab, + pari, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/lc/lcdf-typetools/package.nix b/pkgs/by-name/lc/lcdf-typetools/package.nix index feb2563735b4bb..07fe3981db6671 100644 --- a/pkgs/by-name/lc/lcdf-typetools/package.nix +++ b/pkgs/by-name/lc/lcdf-typetools/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "lcdf-typetools"; diff --git a/pkgs/by-name/lc/lcdproc/package.nix b/pkgs/by-name/lc/lcdproc/package.nix index 7570428d7f3ec3..81c2971b91035e 100644 --- a/pkgs/by-name/lc/lcdproc/package.nix +++ b/pkgs/by-name/lc/lcdproc/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, makeWrapper -, pkg-config -, doxygen -, freetype -, libX11 -, libftdi -, libusb-compat-0_1 -, libusb1 -, ncurses -, perl +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + makeWrapper, + pkg-config, + doxygen, + freetype, + libX11, + libftdi, + libusb-compat-0_1, + libusb1, + ncurses, + perl, }: stdenv.mkDerivation rec { @@ -50,9 +51,21 @@ stdenv.mkDerivation rec { "--with-pidfile-dir=/run" ]; - buildInputs = [ freetype libX11 libftdi libusb-compat-0_1 libusb1 ncurses ]; + buildInputs = [ + freetype + libX11 + libftdi + libusb-compat-0_1 + libusb1 + ncurses + ]; - nativeBuildInputs = [ autoreconfHook doxygen makeWrapper pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + doxygen + makeWrapper + pkg-config + ]; # In 0.5.9: gcc: error: libbignum.a: No such file or directory enableParallelBuilding = false; diff --git a/pkgs/by-name/lc/lci/package.nix b/pkgs/by-name/lc/lci/package.nix index 659855c23fb2d5..11db8b1bf0c888 100644 --- a/pkgs/by-name/lc/lci/package.nix +++ b/pkgs/by-name/lc/lci/package.nix @@ -1,16 +1,21 @@ -{lib, stdenv, fetchurl, readline}: +{ + lib, + stdenv, + fetchurl, + readline, +}: stdenv.mkDerivation rec { version = "0.6"; pname = "lci"; src = fetchurl { url = "mirror://sourceforge/lci/${pname}-${version}.tar.gz"; - sha256="204f1ca5e2f56247d71ab320246811c220ed511bf08c9cb7f305cf180a93948e"; + sha256 = "204f1ca5e2f56247d71ab320246811c220ed511bf08c9cb7f305cf180a93948e"; }; - buildInputs = [readline]; + buildInputs = [ readline ]; meta = { description = "Lambda calculus interpreter"; mainProgram = "lci"; - maintainers = with lib.maintainers; [raskin]; + maintainers = with lib.maintainers; [ raskin ]; platforms = with lib.platforms; linux; license = lib.licenses.gpl3; }; diff --git a/pkgs/by-name/lc/lcm/package.nix b/pkgs/by-name/lc/lcm/package.nix index dcd50a6f4fe1d3..767d453a477643 100644 --- a/pkgs/by-name/lc/lcm/package.nix +++ b/pkgs/by-name/lc/lcm/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, glib, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + glib, + pkg-config, +}: stdenv.mkDerivation rec { pname = "lcm"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { hash = "sha256-IFHoJl5OtnUb+w3gLG5f578yAektjgrY9Uj2eUVoIrc="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; nativeBuildInputs = [ pkg-config diff --git a/pkgs/by-name/lc/lcms1/package.nix b/pkgs/by-name/lc/lcms1/package.nix index cdb994578b2966..4bf2f1e3c43489 100644 --- a/pkgs/by-name/lc/lcms1/package.nix +++ b/pkgs/by-name/lc/lcms1/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "lcms"; @@ -15,7 +19,12 @@ stdenv.mkDerivation rec { NIX_CFLAGS_COMPILE = "-Wno-error=implicit-function-declaration"; }; - outputs = [ "bin" "dev" "out" "man" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + ]; doCheck = false; # fails with "Error in Linear interpolation (2p): Must be i=8000, But is n=8001" diff --git a/pkgs/by-name/lc/lcms2/package.nix b/pkgs/by-name/lc/lcms2/package.nix index ab984884073a35..d78841ef5c859e 100644 --- a/pkgs/by-name/lc/lcms2/package.nix +++ b/pkgs/by-name/lc/lcms2/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, libtiff, libjpeg, zlib }: +{ + lib, + stdenv, + fetchurl, + libtiff, + libjpeg, + zlib, +}: stdenv.mkDerivation rec { pname = "lcms2"; @@ -9,9 +16,17 @@ stdenv.mkDerivation rec { hash = "sha256-2HPTSti5tM6gEGMfGmIo0gh0deTcXnY+uBrMI9nUWlE="; }; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; - propagatedBuildInputs = [ libtiff libjpeg zlib ]; + propagatedBuildInputs = [ + libtiff + libjpeg + zlib + ]; # See https://trac.macports.org/ticket/60656 LDFLAGS = if stdenv.hostPlatform.isDarwin then "-Wl,-w" else null; diff --git a/pkgs/by-name/lc/lcrq/package.nix b/pkgs/by-name/lc/lcrq/package.nix index 995de90a8cef52..42bdde48166c63 100644 --- a/pkgs/by-name/lc/lcrq/package.nix +++ b/pkgs/by-name/lc/lcrq/package.nix @@ -1,7 +1,7 @@ { stdenv, fetchFromGitea, - lib + lib, }: stdenv.mkDerivation (finalAttrs: { pname = "lcrq"; @@ -21,8 +21,17 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://codeberg.org/librecast/lcrq/src/tag/v${finalAttrs.version}/CHANGELOG.md"; description = "Librecast RaptorQ library"; homepage = "https://librecast.net/lcrq.html"; - license = [ lib.licenses.gpl2 lib.licenses.gpl3 ]; - maintainers = with lib.maintainers; [ albertchae aynish DMills27 jasonodoom jleightcap ]; + license = [ + lib.licenses.gpl2 + lib.licenses.gpl3 + ]; + maintainers = with lib.maintainers; [ + albertchae + aynish + DMills27 + jasonodoom + jleightcap + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/by-name/lc/lcsync/package.nix b/pkgs/by-name/lc/lcsync/package.nix index a71514516eb977..dc468fb4e397b0 100644 --- a/pkgs/by-name/lc/lcsync/package.nix +++ b/pkgs/by-name/lc/lcsync/package.nix @@ -4,7 +4,7 @@ lib, librecast, libsodium, - stdenv + stdenv, }: stdenv.mkDerivation (finalAttrs: { pname = "lcsync"; @@ -17,7 +17,11 @@ stdenv.mkDerivation (finalAttrs: { rev = "v${finalAttrs.version}"; hash = "sha256-x8KjvUtn00g+zxDfSWZq4WgALDKRgbCF9rtipdOMbpc="; }; - buildInputs = [ lcrq librecast libsodium ]; + buildInputs = [ + lcrq + librecast + libsodium + ]; configureFlags = [ "SETCAP_PROGRAM=true" ]; installFlags = [ "PREFIX=$(out)" ]; doCheck = true; @@ -27,8 +31,17 @@ stdenv.mkDerivation (finalAttrs: { description = "Librecast File and Syncing Tool"; mainProgram = "lcsync"; homepage = "https://librecast.net/lcsync.html"; - license = [ lib.licenses.gpl2 lib.licenses.gpl3 ]; - maintainers = with lib.maintainers; [ albertchae aynish DMills27 jasonodoom jleightcap ]; + license = [ + lib.licenses.gpl2 + lib.licenses.gpl3 + ]; + maintainers = with lib.maintainers; [ + albertchae + aynish + DMills27 + jasonodoom + jleightcap + ]; platforms = lib.platforms.gnu; }; }) diff --git a/pkgs/by-name/ld/ldacbt/package.nix b/pkgs/by-name/ld/ldacbt/package.nix index b11da8cb59d386..a4aa2b64519802 100644 --- a/pkgs/by-name/ld/ldacbt/package.nix +++ b/pkgs/by-name/ld/ldacbt/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { @@ -15,7 +17,10 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake @@ -28,10 +33,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "AOSP libldac dispatcher"; - homepage = "https://github.com/EHfive/ldacBT"; - license = licenses.asl20; + homepage = "https://github.com/EHfive/ldacBT"; + license = licenses.asl20; # libldac code detects & #error's out on non-LE byte order - platforms = platforms.littleEndian; + platforms = platforms.littleEndian; maintainers = [ ]; }; } diff --git a/pkgs/by-name/ld/ldapmonitor/package.nix b/pkgs/by-name/ld/ldapmonitor/package.nix index 989e1bebc15301..0587418d3e8e5a 100644 --- a/pkgs/by-name/ld/ldapmonitor/package.nix +++ b/pkgs/by-name/ld/ldapmonitor/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ld/ldapnomnom/package.nix b/pkgs/by-name/ld/ldapnomnom/package.nix index b6d14a323517e9..f761083458fe6f 100644 --- a/pkgs/by-name/ld/ldapnomnom/package.nix +++ b/pkgs/by-name/ld/ldapnomnom/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ld/ldapvi/package.nix b/pkgs/by-name/ld/ldapvi/package.nix index d30f8465ff3794..f7a5cf400f6ec1 100644 --- a/pkgs/by-name/ld/ldapvi/package.nix +++ b/pkgs/by-name/ld/ldapvi/package.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchgit, openldap, openssl, popt, glib, libxcrypt, ncurses, readline, pkg-config, cyrus_sasl, autoconf, automake }: +{ + lib, + stdenv, + fetchgit, + openldap, + openssl, + popt, + glib, + libxcrypt, + ncurses, + readline, + pkg-config, + cyrus_sasl, + autoconf, + automake, +}: stdenv.mkDerivation { pname = "ldapvi"; @@ -11,8 +26,21 @@ stdenv.mkDerivation { sha256 = "3ef3103030ecb04d7fe80180e3fd490377cf81fb2af96782323fddabc3225030"; }; - nativeBuildInputs = [ pkg-config autoconf automake ]; - buildInputs = [ openldap openssl popt glib libxcrypt ncurses readline cyrus_sasl ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; + buildInputs = [ + openldap + openssl + popt + glib + libxcrypt + ncurses + readline + cyrus_sasl + ]; preConfigure = '' cd ldapvi diff --git a/pkgs/by-name/ld/ldc/bootstrap.nix b/pkgs/by-name/ld/ldc/bootstrap.nix index 2a23e755c7cf66..fcb1f5191de9bf 100644 --- a/pkgs/by-name/ld/ldc/bootstrap.nix +++ b/pkgs/by-name/ld/ldc/bootstrap.nix @@ -1,18 +1,29 @@ -{ lib, stdenv, fetchurl, curl, tzdata, autoPatchelfHook, fixDarwinDylibNames, libxml2 }: +{ + lib, + stdenv, + fetchurl, + curl, + tzdata, + autoPatchelfHook, + fixDarwinDylibNames, + libxml2, +}: let inherit (stdenv) hostPlatform; OS = if hostPlatform.isDarwin then "osx" else hostPlatform.parsed.kernel.name; - ARCH = if hostPlatform.isDarwin && hostPlatform.isAarch64 then "arm64" else hostPlatform.parsed.cpu.name; + ARCH = + if hostPlatform.isDarwin && hostPlatform.isAarch64 then "arm64" else hostPlatform.parsed.cpu.name; version = "1.30.0"; hashes = { # Get these from `nix store prefetch-file https://github.com/ldc-developers/ldc/releases/download/v1.19.0/ldc2-1.19.0-osx-x86_64.tar.xz` etc.. osx-x86_64 = "sha256-AAWZvxuZC82xvrW6fpYm783TY+H8k3DvqE94ZF1yjmk="; linux-x86_64 = "sha256-V4TUzEfQhFrwiX07dHOgjdAoGkzausCkhnQIQNAU/eE="; - linux-aarch64 = "sha256-kTeglub75iv/jWWNPCn15aCGAbmck0RQl6L7bFOUu7Y="; - osx-arm64 = "sha256-Nb/owBdIeroB9jLMDvwjo8bvsTC9vFyJPLMTOMsSAd4="; + linux-aarch64 = "sha256-kTeglub75iv/jWWNPCn15aCGAbmck0RQl6L7bFOUu7Y="; + osx-arm64 = "sha256-Nb/owBdIeroB9jLMDvwjo8bvsTC9vFyJPLMTOMsSAd4="; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "ldc-bootstrap"; inherit version; @@ -25,13 +36,21 @@ in stdenv.mkDerivation { dontConfigure = true; dontBuild = true; - nativeBuildInputs = lib.optionals hostPlatform.isLinux [ - autoPatchelfHook - ] ++ lib.optional hostPlatform.isDarwin fixDarwinDylibNames; + nativeBuildInputs = + lib.optionals hostPlatform.isLinux [ + autoPatchelfHook + ] + ++ lib.optional hostPlatform.isDarwin fixDarwinDylibNames; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libxml2 stdenv.cc.cc ]; + buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ + libxml2 + stdenv.cc.cc + ]; - propagatedBuildInputs = [ curl tzdata ]; + propagatedBuildInputs = [ + curl + tzdata + ]; installPhase = '' mkdir -p $out @@ -43,8 +62,19 @@ in stdenv.mkDerivation { description = "LLVM-based D Compiler"; homepage = "https://github.com/ldc-developers/ldc"; # from https://github.com/ldc-developers/ldc/blob/master/LICENSE - license = with licenses; [ bsd3 boost mit ncsa gpl2Plus ]; + license = with licenses; [ + bsd3 + boost + mit + ncsa + gpl2Plus + ]; maintainers = with maintainers; [ lionello ]; - platforms = [ "x86_64-linux" "x86_64-darwin" "aarch64-linux" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + "aarch64-linux" + "aarch64-darwin" + ]; }; } diff --git a/pkgs/by-name/ld/ldc/package.nix b/pkgs/by-name/ld/ldc/package.nix index 112a9eeb1d8ed0..c8f1ba18633a0e 100644 --- a/pkgs/by-name/ld/ldc/package.nix +++ b/pkgs/by-name/ld/ldc/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -, llvm_18 -, curl -, tzdata -, lit -, gdb -, unzip -, darwin -, callPackage -, makeWrapper -, runCommand -, writeText -, targetPackages - -, ldcBootstrap ? callPackage ./bootstrap.nix { } +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + llvm_18, + curl, + tzdata, + lit, + gdb, + unzip, + darwin, + callPackage, + makeWrapper, + runCommand, + writeText, + targetPackages, + + ldcBootstrap ? callPackage ./bootstrap.nix { }, }: let - pathConfig = runCommand "ldc-lib-paths" {} '' + pathConfig = runCommand "ldc-lib-paths" { } '' mkdir $out echo ${tzdata}/share/zoneinfo/ > $out/TZDatabaseDirFile echo ${curl.out}/lib/libcurl${stdenv.hostPlatform.extensions.sharedLibrary} > $out/LibcurlPathFile @@ -43,36 +44,55 @@ stdenv.mkDerivation (finalAttrs: { # https://issues.dlang.org/show_bug.cgi?id=19553 hardeningDisable = [ "fortify" ]; - postPatch = '' - patchShebangs runtime tools tests - - rm tests/dmd/fail_compilation/mixin_gc.d - rm tests/dmd/runnable/xtest46_gc.d - rm tests/dmd/runnable/testptrref_gc.d - - # test depends on current year - rm tests/dmd/compilable/ddocYear.d - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace runtime/phobos/std/socket.d --replace-fail "assert(ih.addrList[0] == 0x7F_00_00_01);" "" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace runtime/phobos/std/socket.d --replace-fail "foreach (name; names)" "names = []; foreach (name; names)" - - # https://github.com/NixOS/nixpkgs/issues/34817 - rm -r tests/plugins/addFuncEntryCall - ''; - - nativeBuildInputs = [ - cmake ldcBootstrap lit lit.python llvm_18.dev makeWrapper ninja unzip - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - # https://github.com/NixOS/nixpkgs/pull/36378#issuecomment-385034818 - gdb + postPatch = + '' + patchShebangs runtime tools tests + + rm tests/dmd/fail_compilation/mixin_gc.d + rm tests/dmd/runnable/xtest46_gc.d + rm tests/dmd/runnable/testptrref_gc.d + + # test depends on current year + rm tests/dmd/compilable/ddocYear.d + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace runtime/phobos/std/socket.d --replace-fail "assert(ih.addrList[0] == 0x7F_00_00_01);" "" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace runtime/phobos/std/socket.d --replace-fail "foreach (name; names)" "names = []; foreach (name; names)" + + # https://github.com/NixOS/nixpkgs/issues/34817 + rm -r tests/plugins/addFuncEntryCall + ''; + + nativeBuildInputs = + [ + cmake + ldcBootstrap + lit + lit.python + llvm_18.dev + makeWrapper + ninja + unzip + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + # https://github.com/NixOS/nixpkgs/pull/36378#issuecomment-385034818 + gdb + ]; + + buildInputs = [ + curl + tzdata ]; - buildInputs = [ curl tzdata ]; - - outputs = [ "out" "include" ]; + outputs = [ + "out" + "include" + ]; outputInclude = "include"; cmakeFlags = [ @@ -106,8 +126,7 @@ stdenv.mkDerivation (finalAttrs: { ''; # https://github.com/ldc-developers/ldc/issues/2497#issuecomment-459633746 - additionalExceptions = lib.optionalString stdenv.hostPlatform.isDarwin - "|druntime-test-shared"; + additionalExceptions = lib.optionalString stdenv.hostPlatform.isDarwin "|druntime-test-shared"; checkPhase = '' # Build default lib test runners @@ -140,41 +159,58 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/ldc-developers/ldc"; changelog = "https://github.com/ldc-developers/ldc/releases/tag/v${finalAttrs.version}"; # from https://github.com/ldc-developers/ldc/blob/master/LICENSE - license = with licenses; [ bsd3 boost mit ncsa gpl2Plus ]; + license = with licenses; [ + bsd3 + boost + mit + ncsa + gpl2Plus + ]; mainProgram = "ldc2"; - maintainers = with maintainers; [ lionello jtbx ]; - platforms = [ "x86_64-linux" "i686-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + maintainers = with maintainers; [ + lionello + jtbx + ]; + platforms = [ + "x86_64-linux" + "i686-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; }; passthru.ldcBootstrap = ldcBootstrap; - passthru.tests = let - ldc = finalAttrs.finalPackage; - helloWorld = stdenv.mkDerivation (finalAttrs: { - name = "ldc-hello-world"; - src = writeText "hello_world.d" '' - module hello_world; - import std.stdio; - void main() { - writeln("Hello, world!"); - } - ''; - dontUnpack = true; - buildInputs = [ ldc ]; - dFlags = []; - buildPhase = '' - ldc2 ${lib.escapeShellArgs finalAttrs.dFlags} -of=test $src - ''; - installPhase = '' - mkdir -p $out/bin - mv test $out/bin - ''; - }); - in { - # Without -shared, built binaries should not contain - # references to the compiler binaries. - no-references-to-compiler = helloWorld.overrideAttrs { - disallowedReferences = [ ldc ]; - dFlags = ["-g"]; + passthru.tests = + let + ldc = finalAttrs.finalPackage; + helloWorld = stdenv.mkDerivation (finalAttrs: { + name = "ldc-hello-world"; + src = writeText "hello_world.d" '' + module hello_world; + import std.stdio; + void main() { + writeln("Hello, world!"); + } + ''; + dontUnpack = true; + buildInputs = [ ldc ]; + dFlags = [ ]; + buildPhase = '' + ldc2 ${lib.escapeShellArgs finalAttrs.dFlags} -of=test $src + ''; + installPhase = '' + mkdir -p $out/bin + mv test $out/bin + ''; + }); + in + { + # Without -shared, built binaries should not contain + # references to the compiler binaries. + no-references-to-compiler = helloWorld.overrideAttrs { + disallowedReferences = [ ldc ]; + dFlags = [ "-g" ]; + }; }; - }; }) diff --git a/pkgs/by-name/ld/ldm/package.nix b/pkgs/by-name/ld/ldm/package.nix index 5214f270bfb26e..c56ea0e82691ca 100644 --- a/pkgs/by-name/ld/ldm/package.nix +++ b/pkgs/by-name/ld/ldm/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchgit, udev, util-linux, mountPath ? "/media/" }: +{ + lib, + stdenv, + fetchgit, + udev, + util-linux, + mountPath ? "/media/", +}: assert mountPath != ""; @@ -17,7 +24,10 @@ stdenv.mkDerivation rec { sha256 = "0lxfypnbamfx6p9ar5k9wra20gvwn665l4pp2j4vsx4yi5q7rw2n"; }; - buildInputs = [ udev util-linux ]; + buildInputs = [ + udev + util-linux + ]; postPatch = '' substituteInPlace ldm.c \ diff --git a/pkgs/by-name/ld/ldmtool/package.nix b/pkgs/by-name/ld/ldmtool/package.nix index 6a1527ea8fe2eb..19495696c14c06 100644 --- a/pkgs/by-name/ld/ldmtool/package.nix +++ b/pkgs/by-name/ld/ldmtool/package.nix @@ -1,6 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, gtk-doc, pkg-config, libuuid, - libtool, readline, gobject-introspection, json-glib, lvm2, libxslt, docbook_xsl -, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + gtk-doc, + pkg-config, + libuuid, + libtool, + readline, + gobject-introspection, + json-glib, + lvm2, + libxslt, + docbook_xsl, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "ldmtool"; @@ -31,9 +46,20 @@ stdenv.mkDerivation rec { configureScript = "sh autogen.sh"; - nativeBuildInputs = [ pkg-config autoconf automake gobject-introspection ]; - buildInputs = [ gtk-doc lvm2 libxslt.bin - libtool readline json-glib libuuid + nativeBuildInputs = [ + pkg-config + autoconf + automake + gobject-introspection + ]; + buildInputs = [ + gtk-doc + lvm2 + libxslt.bin + libtool + readline + json-glib + libuuid ]; meta = with lib; { diff --git a/pkgs/by-name/ld/ldns/package.nix b/pkgs/by-name/ld/ldns/package.nix index 96e6b7d54db9b6..ed0a570a750385 100644 --- a/pkgs/by-name/ld/ldns/package.nix +++ b/pkgs/by-name/ld/ldns/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, openssl, perl, which, dns-root-data }: +{ + lib, + stdenv, + fetchurl, + openssl, + perl, + which, + dns-root-data, +}: stdenv.mkDerivation rec { pname = "ldns"; @@ -13,21 +21,28 @@ stdenv.mkDerivation rec { patchShebangs doc/doxyparse.pl ''; - outputs = [ "out" "dev" "man" "examples" ]; + outputs = [ + "out" + "dev" + "man" + "examples" + ]; nativeBuildInputs = [ perl ]; buildInputs = [ openssl ]; - configureFlags = [ - "--with-ssl=${openssl.dev}" - "--with-trust-anchor=${dns-root-data}/root.key" - "--with-drill" - "--disable-gost" - "--with-examples" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "ac_cv_func_malloc_0_nonnull=yes" - "ac_cv_func_realloc_0_nonnull=yes" - ]; + configureFlags = + [ + "--with-ssl=${openssl.dev}" + "--with-trust-anchor=${dns-root-data}/root.key" + "--with-drill" + "--disable-gost" + "--with-examples" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "ac_cv_func_malloc_0_nonnull=yes" + "ac_cv_func_realloc_0_nonnull=yes" + ]; nativeCheckInputs = [ which ]; doCheck = false; # fails. missing some files diff --git a/pkgs/by-name/ld/ldproxy/package.nix b/pkgs/by-name/ld/ldproxy/package.nix index 4736207cdc170e..ac1f62c4132d0a 100644 --- a/pkgs/by-name/ld/ldproxy/package.nix +++ b/pkgs/by-name/ld/ldproxy/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "ldproxy"; @@ -23,7 +27,10 @@ rustPlatform.buildRustPackage rec { description = "Linker Proxy: a simple tool to forward linker arguments to the actual linker executable"; homepage = "https://github.com/esp-rs/embuild"; changelog = "https://github.com/esp-rs/embuild/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ vpochapuis ]; }; } diff --git a/pkgs/by-name/ld/ldtk/package.nix b/pkgs/by-name/ld/ldtk/package.nix index 4e05fc2b39117d..7eba14b9494958 100644 --- a/pkgs/by-name/ld/ldtk/package.nix +++ b/pkgs/by-name/ld/ldtk/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchurl, makeWrapper, makeDesktopItem, copyDesktopItems, unzip -, appimage-run, nix-update-script }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + unzip, + appimage-run, + nix-update-script, +}: stdenv.mkDerivation (finalAttrs: { pname = "ldtk"; @@ -10,7 +19,12 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-i7HIcKs10srfvwihGdMEnnmGoqgFWNJhC6vGf81QJWY="; }; - nativeBuildInputs = [ unzip makeWrapper copyDesktopItems appimage-run ]; + nativeBuildInputs = [ + unzip + makeWrapper + copyDesktopItems + appimage-run + ]; buildInputs = [ appimage-run ]; diff --git a/pkgs/by-name/le/leaf/package.nix b/pkgs/by-name/le/leaf/package.nix index 1bd44f23d30490..a37a9b1c9c3706 100644 --- a/pkgs/by-name/le/leaf/package.nix +++ b/pkgs/by-name/le/leaf/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/le/league-gothic/package.nix b/pkgs/by-name/le/league-gothic/package.nix index c119dc3f562f7f..ca72373b1b806d 100644 --- a/pkgs/by-name/le/league-gothic/package.nix +++ b/pkgs/by-name/le/league-gothic/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchzip, stdenvNoCC }: +{ + lib, + fetchzip, + stdenvNoCC, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "league-gothic"; diff --git a/pkgs/by-name/le/league-of-moveable-type/package.nix b/pkgs/by-name/le/league-of-moveable-type/package.nix index 236a2e39ed10a0..4e0f6fbce6e4ea 100644 --- a/pkgs/by-name/le/league-of-moveable-type/package.nix +++ b/pkgs/by-name/le/league-of-moveable-type/package.nix @@ -1,22 +1,23 @@ -{ lib -, symlinkJoin -, the-neue-black -, blackout -, chunk -, fanwood -, goudy-bookletter-1911 -, junction-font -, knewave -, league-gothic -, league-script-number-one -, league-spartan -, linden-hill -, orbitron -, ostrich-sans -, prociono -, raleway -, sniglet -, sorts-mill-goudy +{ + lib, + symlinkJoin, + the-neue-black, + blackout, + chunk, + fanwood, + goudy-bookletter-1911, + junction-font, + knewave, + league-gothic, + league-script-number-one, + league-spartan, + linden-hill, + orbitron, + ostrich-sans, + prociono, + raleway, + sniglet, + sorts-mill-goudy, }: symlinkJoin { @@ -57,6 +58,9 @@ symlinkJoin { license = lib.licenses.ofl; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ bergey minijackson ]; + maintainers = with lib.maintainers; [ + bergey + minijackson + ]; }; } diff --git a/pkgs/by-name/le/league-script-number-one/package.nix b/pkgs/by-name/le/league-script-number-one/package.nix index 0ced0c8d181d67..a408f64cb589df 100644 --- a/pkgs/by-name/le/league-script-number-one/package.nix +++ b/pkgs/by-name/le/league-script-number-one/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, +}: stdenvNoCC.mkDerivation { pname = "league-script-number-one"; diff --git a/pkgs/by-name/le/league-spartan/package.nix b/pkgs/by-name/le/league-spartan/package.nix index 022346c5abca8c..35704c997a4048 100644 --- a/pkgs/by-name/le/league-spartan/package.nix +++ b/pkgs/by-name/le/league-spartan/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchzip, stdenvNoCC }: +{ + lib, + fetchzip, + stdenvNoCC, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "league-spartan"; diff --git a/pkgs/by-name/le/lean/package.nix b/pkgs/by-name/le/lean/package.nix index 4df1d6eb8aab5e..d8248af1b4096e 100644 --- a/pkgs/by-name/le/lean/package.nix +++ b/pkgs/by-name/le/lean/package.nix @@ -1,18 +1,26 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, gmp, coreutils }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + gmp, + coreutils, +}: stdenv.mkDerivation rec { pname = "lean"; version = "3.51.0"; src = fetchFromGitHub { - owner = "leanprover-community"; - repo = "lean"; + owner = "leanprover-community"; + repo = "lean"; # lean's version string contains the commit sha1 it was built # from. this is then used to check whether an olean file should be # rebuilt. don't use a tag as rev because this will get replaced into # src/githash.h.in in preConfigure. - rev = "9fc1dee97a72a3e34d658aefb4b8a95ecd3d477c"; - hash = "sha256-Vcsph4dTNLafeaTtVwJS8tWoWCgcP6pxF0ssZDE/YfM="; + rev = "9fc1dee97a72a3e34d658aefb4b8a95ecd3d477c"; + hash = "sha256-Vcsph4dTNLafeaTtVwJS8tWoWCgcP6pxF0ssZDE/YfM="; }; patches = [ @@ -33,12 +41,14 @@ stdenv.mkDerivation rec { # library. doCheck = true; - preConfigure = assert builtins.stringLength src.rev == 40; '' - substituteInPlace src/githash.h.in \ - --subst-var-by GIT_SHA1 "${src.rev}" - substituteInPlace library/init/version.lean.in \ - --subst-var-by GIT_SHA1 "${src.rev}" - ''; + preConfigure = + assert builtins.stringLength src.rev == 40; + '' + substituteInPlace src/githash.h.in \ + --subst-var-by GIT_SHA1 "${src.rev}" + substituteInPlace library/init/version.lean.in \ + --subst-var-by GIT_SHA1 "${src.rev}" + ''; postPatch = "patchShebangs ."; @@ -49,11 +59,13 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Automatic and interactive theorem prover"; - homepage = "https://leanprover.github.io/"; - changelog = "https://github.com/leanprover-community/lean/blob/v${version}/doc/changes.md"; - license = licenses.asl20; - platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice gebner ]; + homepage = "https://leanprover.github.io/"; + changelog = "https://github.com/leanprover-community/lean/blob/v${version}/doc/changes.md"; + license = licenses.asl20; + platforms = platforms.unix; + maintainers = with maintainers; [ + thoughtpolice + gebner + ]; }; } - diff --git a/pkgs/by-name/le/lean2/package.nix b/pkgs/by-name/le/lean2/package.nix index 83cada9e309abe..f4378b1620cc9d 100644 --- a/pkgs/by-name/le/lean2/package.nix +++ b/pkgs/by-name/le/lean2/package.nix @@ -1,14 +1,25 @@ -{ lib, stdenv, fetchpatch, fetchFromGitHub, cmake, gmp, mpfr, python3 -, jemalloc, ninja, makeWrapper }: +{ + lib, + stdenv, + fetchpatch, + fetchFromGitHub, + cmake, + gmp, + mpfr, + python3, + jemalloc, + ninja, + makeWrapper, +}: stdenv.mkDerivation { pname = "lean2"; version = "2018-10-01"; src = fetchFromGitHub { - owner = "leanprover"; - repo = "lean2"; - rev = "8072fdf9a0b31abb9d43ab894d7a858639e20ed7"; + owner = "leanprover"; + repo = "lean2"; + rev = "8072fdf9a0b31abb9d43ab894d7a858639e20ed7"; sha256 = "12bscgihdgvaq5xi0hqf5r4w386zxm3nkx1n150lv5smhg8ga3gg"; }; @@ -20,8 +31,17 @@ stdenv.mkDerivation { sha256 = "060mvqn9y8lsn4l20q9rhamkymzsgh0r1vzkjw78gnj8kjw67jl5"; }) ]; - nativeBuildInputs = [ cmake makeWrapper ninja ]; - buildInputs = [ gmp mpfr python3 jemalloc ]; + nativeBuildInputs = [ + cmake + makeWrapper + ninja + ]; + buildInputs = [ + gmp + mpfr + python3 + jemalloc + ]; preConfigure = '' patchShebangs bin/leantags @@ -36,11 +56,14 @@ stdenv.mkDerivation { meta = with lib; { description = "Automatic and interactive theorem prover (version with HoTT support)"; - homepage = "http://leanprover.github.io"; - license = licenses.asl20; - platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice gebner ]; - broken = stdenv.hostPlatform.isAarch64; + homepage = "http://leanprover.github.io"; + license = licenses.asl20; + platforms = platforms.unix; + maintainers = with maintainers; [ + thoughtpolice + gebner + ]; + broken = stdenv.hostPlatform.isAarch64; mainProgram = "lean"; }; } diff --git a/pkgs/by-name/le/lean4/package.nix b/pkgs/by-name/le/lean4/package.nix index fe94225e66f2f0..7d5e7ef838bf0f 100644 --- a/pkgs/by-name/le/lean4/package.nix +++ b/pkgs/by-name/le/lean4/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, git -, gmp -, perl -, testers +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + git, + gmp, + perl, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -63,7 +64,10 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://github.com/leanprover/lean4/blob/${finalAttrs.src.rev}/RELEASES.md"; license = licenses.asl20; platforms = platforms.all; - maintainers = with maintainers; [ danielbritten jthulhu ]; + maintainers = with maintainers; [ + danielbritten + jthulhu + ]; mainProgram = "lean"; }; }) diff --git a/pkgs/by-name/le/leanify/package.nix b/pkgs/by-name/le/leanify/package.nix index 81f6205986df27..ad63f4492b0e6c 100644 --- a/pkgs/by-name/le/leanify/package.nix +++ b/pkgs/by-name/le/leanify/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, libiconv +{ + lib, + stdenv, + fetchFromGitHub, + libiconv, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/le/leaps/package.nix b/pkgs/by-name/le/leaps/package.nix index c9eac1db13a8b3..6c053c8343c2a1 100644 --- a/pkgs/by-name/le/leaps/package.nix +++ b/pkgs/by-name/le/leaps/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, leaps, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + leaps, + nixosTests, +}: buildGoModule rec { pname = "leaps"; @@ -14,7 +21,11 @@ buildGoModule rec { proxyVendor = true; # darwin/linux hash mismatch vendorHash = "sha256-0dwUOoV2bxPB+B6CKxJPImPIDlBMPcm0AwEMrVUkALc="; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; passthru.tests = { version = testers.testVersion { package = leaps; }; diff --git a/pkgs/by-name/le/leatherman/package.nix b/pkgs/by-name/le/leatherman/package.nix index d3bd349cc8e01c..b73192f0b78810 100644 --- a/pkgs/by-name/le/leatherman/package.nix +++ b/pkgs/by-name/le/leatherman/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, boost, cmake, curl, ruby }: +{ + lib, + stdenv, + fetchFromGitHub, + boost, + cmake, + curl, + ruby, +}: stdenv.mkDerivation rec { pname = "leatherman"; @@ -16,7 +24,11 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = "-Wno-error"; nativeBuildInputs = [ cmake ]; - buildInputs = [ boost curl ruby ]; + buildInputs = [ + boost + curl + ruby + ]; meta = with lib; { homepage = "https://github.com/puppetlabs/leatherman/"; diff --git a/pkgs/by-name/le/ledfx/package.nix b/pkgs/by-name/le/ledfx/package.nix index b10ade8a59fe91..e9281a67f171eb 100644 --- a/pkgs/by-name/le/ledfx/package.nix +++ b/pkgs/by-name/le/ledfx/package.nix @@ -26,7 +26,6 @@ python3.pkgs.buildPythonPackage rec { poetry-core ]; - dependencies = with python3.pkgs; [ aiohttp aiohttp-cors diff --git a/pkgs/by-name/le/ledger-live-desktop/package.nix b/pkgs/by-name/le/ledger-live-desktop/package.nix index ac4e142078d45a..9a7dcd35137273 100644 --- a/pkgs/by-name/le/ledger-live-desktop/package.nix +++ b/pkgs/by-name/le/ledger-live-desktop/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, appimageTools, makeWrapper, imagemagick }: +{ + lib, + fetchurl, + appimageTools, + makeWrapper, + imagemagick, +}: let pname = "ledger-live-desktop"; @@ -35,7 +41,13 @@ appimageTools.wrapType2 rec { description = "App for Ledger hardware wallets"; homepage = "https://www.ledger.com/ledger-live/"; license = licenses.mit; - maintainers = with maintainers; [ andresilva thedavidmeister nyanloutre RaghavSood th0rgal ]; + maintainers = with maintainers; [ + andresilva + thedavidmeister + nyanloutre + RaghavSood + th0rgal + ]; platforms = [ "x86_64-linux" ]; mainProgram = "ledger-live-desktop"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; diff --git a/pkgs/by-name/le/ledger-udev-rules/package.nix b/pkgs/by-name/le/ledger-udev-rules/package.nix index 8201f12480c395..c0d7a8f183162d 100644 --- a/pkgs/by-name/le/ledger-udev-rules/package.nix +++ b/pkgs/by-name/le/ledger-udev-rules/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "ledger-udev-rules"; @@ -22,7 +26,10 @@ stdenv.mkDerivation { meta = with lib; { description = "udev rules for Ledger devices"; license = licenses.asl20; - maintainers = with maintainers; [ asymmetric toasteruwu ]; + maintainers = with maintainers; [ + asymmetric + toasteruwu + ]; platforms = platforms.linux; homepage = "https://github.com/LedgerHQ/udev-rules"; }; diff --git a/pkgs/by-name/le/ledger2beancount/package.nix b/pkgs/by-name/le/ledger2beancount/package.nix index 38522293767697..ee6c17494df053 100644 --- a/pkgs/by-name/le/ledger2beancount/package.nix +++ b/pkgs/by-name/le/ledger2beancount/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, perlPackages, beancount }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + perlPackages, + beancount, +}: let perlDeps = with perlPackages; [ @@ -13,7 +20,8 @@ let YAMLLibYAML ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "ledger2beancount"; version = "2.7"; @@ -27,7 +35,10 @@ in stdenv.mkDerivation rec { dontBuild = true; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ perlPackages.perl beancount ] ++ perlDeps; + buildInputs = [ + perlPackages.perl + beancount + ] ++ perlDeps; makeFlags = [ "prefix=$(out)" ]; installFlags = [ "INSTALL=install" ]; diff --git a/pkgs/by-name/le/ledit/package.nix b/pkgs/by-name/le/ledit/package.nix index a9ef90a48bf3b5..f905c2b2931253 100644 --- a/pkgs/by-name/le/ledit/package.nix +++ b/pkgs/by-name/le/ledit/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ocamlPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + ocamlPackages, +}: stdenv.mkDerivation { pname = "ledit"; @@ -28,7 +33,6 @@ stdenv.mkDerivation { camlp-streams ]; - meta = with lib; { homepage = "http://pauillac.inria.fr/~ddr/ledit/"; description = "Line editor, allowing to use shell commands with control characters like in emacs"; diff --git a/pkgs/by-name/le/ledmon/package.nix b/pkgs/by-name/le/ledmon/package.nix index 088f8cf281eb48..767467c7ffec16 100644 --- a/pkgs/by-name/le/ledmon/package.nix +++ b/pkgs/by-name/le/ledmon/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, perl, udev, sg3_utils }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, + udev, + sg3_utils, +}: stdenv.mkDerivation rec { pname = "ledmon"; @@ -14,9 +21,15 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ perl # for pod2man ]; - buildInputs = [ udev sg3_utils ]; + buildInputs = [ + udev + sg3_utils + ]; - installTargets = [ "install" "install-systemd" ]; + installTargets = [ + "install" + "install-systemd" + ]; makeFlags = [ "MAN_INSTDIR=${placeholder "out"}/share/man" diff --git a/pkgs/by-name/le/leela/package.nix b/pkgs/by-name/le/leela/package.nix index 7ddf02d163693a..32a25a936fceff 100644 --- a/pkgs/by-name/le/leela/package.nix +++ b/pkgs/by-name/le/leela/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, poppler }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + poppler, +}: stdenv.mkDerivation { pname = "leela"; @@ -14,7 +20,10 @@ stdenv.mkDerivation { nativeBuildInputs = [ pkg-config ]; buildInputs = [ poppler ]; - installFlags = [ "PREFIX=$(out)" "MANDIR=$(out)/share/man" ]; + installFlags = [ + "PREFIX=$(out)" + "MANDIR=$(out)/share/man" + ]; meta = { description = "CLI frontend to the poppler-glib library of PDF tools"; diff --git a/pkgs/by-name/le/leetcode-cli/package.nix b/pkgs/by-name/le/leetcode-cli/package.nix index dbad8d651247ea..d1d1442bd5b53e 100644 --- a/pkgs/by-name/le/leetcode-cli/package.nix +++ b/pkgs/by-name/le/leetcode-cli/package.nix @@ -1,15 +1,16 @@ -{ lib -, fetchCrate -, rustPlatform -, pkg-config -, installShellFiles -, openssl -, dbus -, sqlite -, stdenv -, darwin -, testers -, leetcode-cli +{ + lib, + fetchCrate, + rustPlatform, + pkg-config, + installShellFiles, + openssl, + dbus, + sqlite, + stdenv, + darwin, + testers, + leetcode-cli, }: rustPlatform.buildRustPackage rec { @@ -28,14 +29,16 @@ rustPlatform.buildRustPackage rec { installShellFiles ]; - buildInputs = [ - openssl - dbus - sqlite - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + dbus + sqlite + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' installShellCompletion --cmd leetcode \ diff --git a/pkgs/by-name/le/leetgo/package.nix b/pkgs/by-name/le/leetgo/package.nix index ff1fb0e7493bd8..93cc8cd5415169 100644 --- a/pkgs/by-name/le/leetgo/package.nix +++ b/pkgs/by-name/le/leetgo/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/le/left4gore-bin/package.nix b/pkgs/by-name/le/left4gore-bin/package.nix index 0379ce477f989c..76bd0b5b17e207 100644 --- a/pkgs/by-name/le/left4gore-bin/package.nix +++ b/pkgs/by-name/le/left4gore-bin/package.nix @@ -1,4 +1,9 @@ -{ stdenvNoCC, lib, fetchurl, buildFHSEnv }: +{ + stdenvNoCC, + lib, + fetchurl, + buildFHSEnv, +}: let version = "2.3"; @@ -27,7 +32,8 @@ let runScript = "left4gore"; }; -in stdenvNoCC.mkDerivation { +in +stdenvNoCC.mkDerivation { pname = "left4gore"; inherit version; diff --git a/pkgs/by-name/le/lefthook/package.nix b/pkgs/by-name/le/lefthook/package.nix index ae2c52ec71afe4..430db1cf1a91f6 100644 --- a/pkgs/by-name/le/lefthook/package.nix +++ b/pkgs/by-name/le/lefthook/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: let @@ -22,7 +23,10 @@ buildGoModule { nativeBuildInputs = [ installShellFiles ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; doCheck = false; diff --git a/pkgs/by-name/le/leftwm/package.nix b/pkgs/by-name/le/leftwm/package.nix index 00bfbe66f661d1..ecc8506e81898b 100644 --- a/pkgs/by-name/le/leftwm/package.nix +++ b/pkgs/by-name/le/leftwm/package.nix @@ -1,12 +1,16 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, libX11 -, libXinerama +{ + lib, + fetchFromGitHub, + rustPlatform, + libX11, + libXinerama, }: let - rpathLibs = [ libXinerama libX11 ]; + rpathLibs = [ + libXinerama + libX11 + ]; in rustPlatform.buildRustPackage rec { @@ -39,7 +43,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/leftwm/leftwm"; license = lib.licenses.mit; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ vuimuich yanganto ]; + maintainers = with lib.maintainers; [ + vuimuich + yanganto + ]; changelog = "https://github.com/leftwm/leftwm/blob/${version}/CHANGELOG.md"; mainProgram = "leftwm"; }; diff --git a/pkgs/by-name/le/legba/package.nix b/pkgs/by-name/le/legba/package.nix index efb9a351340b91..51dd7df1accbff 100644 --- a/pkgs/by-name/le/legba/package.nix +++ b/pkgs/by-name/le/legba/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, cmake -, pkg-config -, openssl -, samba -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + cmake, + pkg-config, + openssl, + samba, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -22,10 +23,18 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-viDfJ214Zf5segjrLSTbHav5T5e219NAF+MvuPow+JQ="; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ openssl.dev samba ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration + nativeBuildInputs = [ + cmake + pkg-config ]; + buildInputs = + [ + openssl.dev + samba + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; # Paho C test fails due to permission issue doCheck = false; diff --git a/pkgs/by-name/le/legcord/package.nix b/pkgs/by-name/le/legcord/package.nix index 11ff8a188488a3..df4b73bacb215a 100644 --- a/pkgs/by-name/le/legcord/package.nix +++ b/pkgs/by-name/le/legcord/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, pnpm -, nodejs -, electron_32 -, makeWrapper -, copyDesktopItems -, makeDesktopItem -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + pnpm, + nodejs, + electron_32, + makeWrapper, + copyDesktopItems, + makeDesktopItem, + nix-update-script, }: stdenv.mkDerivation rec { pname = "legcord"; @@ -20,7 +21,12 @@ stdenv.mkDerivation rec { hash = "sha256-9CicqDZDetxElD36OLizyVNxkqz3rQOjAtUNTGWVwss="; }; - nativeBuildInputs = [ pnpm.configHook nodejs makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + pnpm.configHook + nodejs + makeWrapper + copyDesktopItems + ]; pnpmDeps = pnpm.fetchDeps { inherit pname version src; @@ -80,8 +86,14 @@ stdenv.mkDerivation rec { homepage = "https://legcord.app"; downloadPage = "https://github.com/Legcord/Legcord"; license = licenses.osl3; - maintainers = with maintainers; [ wrmilling water-sucks ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + maintainers = with maintainers; [ + wrmilling + water-sucks + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; mainProgram = "legcord"; }; } diff --git a/pkgs/by-name/le/legit-web/package.nix b/pkgs/by-name/le/legit-web/package.nix index b73fa142055113..e39960f67ef2a3 100644 --- a/pkgs/by-name/le/legit-web/package.nix +++ b/pkgs/by-name/le/legit-web/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/by-name/le/legit/package.nix b/pkgs/by-name/le/legit/package.nix index d03bc426243be9..500b1b8fef6cea 100644 --- a/pkgs/by-name/le/legit/package.nix +++ b/pkgs/by-name/le/legit/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchPypi +{ + lib, + python3Packages, + fetchPypi, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/le/legitify/package.nix b/pkgs/by-name/le/legitify/package.nix index 4759f9f19967c3..7e4509af4ed4e3 100644 --- a/pkgs/by-name/le/legitify/package.nix +++ b/pkgs/by-name/le/legitify/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/le/lektor/package.nix b/pkgs/by-name/le/lektor/package.nix index cd3d639c9e2dee..86722f2dbb8880 100644 --- a/pkgs/by-name/le/lektor/package.nix +++ b/pkgs/by-name/le/lektor/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, fetchNpmDeps -, fetchPypi -, fetchpatch -, nodejs -, npmHooks -, python3 +{ + lib, + fetchFromGitHub, + fetchNpmDeps, + fetchPypi, + fetchpatch, + nodejs, + npmHooks, + python3, }: let diff --git a/pkgs/by-name/le/lemmeknow/package.nix b/pkgs/by-name/le/lemmeknow/package.nix index 8c119a350a92a7..cae3664637b293 100644 --- a/pkgs/by-name/le/lemmeknow/package.nix +++ b/pkgs/by-name/le/lemmeknow/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "lemmeknow"; @@ -16,7 +20,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/swanandx/lemmeknow"; changelog = "https://github.com/swanandx/lemmeknow/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ figsoda Br1ght0ne ]; + maintainers = with maintainers; [ + figsoda + Br1ght0ne + ]; mainProgram = "lemmeknow"; }; } diff --git a/pkgs/by-name/le/lemminx/package.nix b/pkgs/by-name/le/lemminx/package.nix index 32ecf1dc6cdabe..f8f73a67b8ed6c 100644 --- a/pkgs/by-name/le/lemminx/package.nix +++ b/pkgs/by-name/le/lemminx/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, makeWrapper -, jdk_headless -, jre_minimal -, maven -, writeScript -, lemminx +{ + lib, + fetchFromGitHub, + makeWrapper, + jdk_headless, + jre_minimal, + maven, + writeScript, + lemminx, }: let diff --git a/pkgs/by-name/le/lemmy-help/package.nix b/pkgs/by-name/le/lemmy-help/package.nix index 6138d331b02f3f..3af2ba09ccaee8 100644 --- a/pkgs/by-name/le/lemmy-help/package.nix +++ b/pkgs/by-name/le/lemmy-help/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "lemmy-help"; diff --git a/pkgs/by-name/le/lemon-graph/package.nix b/pkgs/by-name/le/lemon-graph/package.nix index 4e96e9f4c93a02..1d687d237d949e 100644 --- a/pkgs/by-name/le/lemon-graph/package.nix +++ b/pkgs/by-name/le/lemon-graph/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, cmake +{ + lib, + stdenv, + fetchurl, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/le/lemon/package.nix b/pkgs/by-name/le/lemon/package.nix index 512d3bccc97332..6535e2f1fb1d74 100644 --- a/pkgs/by-name/le/lemon/package.nix +++ b/pkgs/by-name/le/lemon/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let @@ -15,7 +19,8 @@ let }; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "lemon"; version = "1.69"; diff --git a/pkgs/by-name/le/lemonade/package.nix b/pkgs/by-name/le/lemonade/package.nix index 012020c1768e53..c402e8a7d2ae5d 100644 --- a/pkgs/by-name/le/lemonade/package.nix +++ b/pkgs/by-name/le/lemonade/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, }: buildGoModule rec { diff --git a/pkgs/by-name/le/lenpaste/package.nix b/pkgs/by-name/le/lenpaste/package.nix index c7a9e3e9234a1a..757a586b5b381e 100644 --- a/pkgs/by-name/le/lenpaste/package.nix +++ b/pkgs/by-name/le/lenpaste/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitea }: +{ + lib, + buildGoModule, + fetchFromGitea, +}: buildGoModule rec { pname = "lenpaste"; diff --git a/pkgs/by-name/le/lens/darwin.nix b/pkgs/by-name/le/lens/darwin.nix index 9b9b752b877ba8..3acc21000c5179 100644 --- a/pkgs/by-name/le/lens/darwin.nix +++ b/pkgs/by-name/le/lens/darwin.nix @@ -1,7 +1,19 @@ -{ stdenv, pname, version, src, meta, undmg }: +{ + stdenv, + pname, + version, + src, + meta, + undmg, +}: stdenv.mkDerivation { - inherit pname version src meta; + inherit + pname + version + src + meta + ; sourceRoot = "."; diff --git a/pkgs/by-name/le/lens/linux.nix b/pkgs/by-name/le/lens/linux.nix index dd50775682bd41..e101ab53556cdc 100644 --- a/pkgs/by-name/le/lens/linux.nix +++ b/pkgs/by-name/le/lens/linux.nix @@ -1,4 +1,11 @@ -{ pname, version, src, meta, appimageTools, makeWrapper }: +{ + pname, + version, + src, + meta, + appimageTools, + makeWrapper, +}: let appimageContents = appimageTools.extractType2 { inherit pname version src; @@ -7,20 +14,24 @@ let in appimageTools.wrapType2 { - inherit pname version src meta; + inherit + pname + version + src + meta + ; nativeBuildInputs = [ makeWrapper ]; - extraInstallCommands = - '' - wrapProgram $out/bin/${pname} \ - --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" - install -m 444 -D ${appimageContents}/${pname}.desktop $out/share/applications/${pname}.desktop - install -m 444 -D ${appimageContents}/usr/share/icons/hicolor/512x512/apps/${pname}.png \ - $out/share/icons/hicolor/512x512/apps/${pname}.png - substituteInPlace $out/share/applications/${pname}.desktop \ - --replace 'Exec=AppRun' 'Exec=${pname}' - ''; + extraInstallCommands = '' + wrapProgram $out/bin/${pname} \ + --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" + install -m 444 -D ${appimageContents}/${pname}.desktop $out/share/applications/${pname}.desktop + install -m 444 -D ${appimageContents}/usr/share/icons/hicolor/512x512/apps/${pname}.png \ + $out/share/icons/hicolor/512x512/apps/${pname}.png + substituteInPlace $out/share/applications/${pname}.desktop \ + --replace 'Exec=AppRun' 'Exec=${pname}' + ''; extraPkgs = pkgs: [ pkgs.nss_latest ]; } diff --git a/pkgs/by-name/le/lens/package.nix b/pkgs/by-name/le/lens/package.nix index 98c9ca2d1758d7..284b06e4762be4 100644 --- a/pkgs/by-name/le/lens/package.nix +++ b/pkgs/by-name/le/lens/package.nix @@ -1,7 +1,9 @@ -{ stdenv -, callPackage -, fetchurl -, lib }: +{ + stdenv, + callPackage, + fetchurl, + lib, +}: let @@ -31,11 +33,30 @@ let description = "Kubernetes IDE"; homepage = "https://k8slens.dev/"; license = licenses.lens; - maintainers = with maintainers; [ dbirks RossComputerGuy starkca90 ]; + maintainers = with maintainers; [ + dbirks + RossComputerGuy + starkca90 + ]; platforms = builtins.attrNames sources; }; -in if stdenv.hostPlatform.isDarwin then - callPackage ./darwin.nix { inherit pname version src meta; } +in +if stdenv.hostPlatform.isDarwin then + callPackage ./darwin.nix { + inherit + pname + version + src + meta + ; + } else - callPackage ./linux.nix { inherit pname version src meta; } + callPackage ./linux.nix { + inherit + pname + version + src + meta + ; + } diff --git a/pkgs/by-name/le/lensfun/package.nix b/pkgs/by-name/le/lensfun/package.nix index 8972485bb2824c..da8c954c44aba4 100644 --- a/pkgs/by-name/le/lensfun/package.nix +++ b/pkgs/by-name/le/lensfun/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, glib, zlib, libpng, cmake, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + glib, + zlib, + libpng, + cmake, + python3, +}: let version = "0.3.4"; @@ -44,13 +54,20 @@ stdenv.mkDerivation { python3.pkgs.lxml # For the db converison ]; - buildInputs = [ glib zlib libpng ]; + buildInputs = [ + glib + zlib + libpng + ]; cmakeFlags = [ "-DINSTALL_HELPER_SCRIPTS=OFF" ]; meta = with lib; { platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ flokli paperdigits ]; + maintainers = with maintainers; [ + flokli + paperdigits + ]; license = lib.licenses.lgpl3; description = "Opensource database of photographic lenses and their characteristics"; homepage = "https://lensfun.github.io"; diff --git a/pkgs/by-name/le/lepton-eda/package.nix b/pkgs/by-name/le/lepton-eda/package.nix index 00b0961895d317..4c8d7ccc3453bf 100644 --- a/pkgs/by-name/le/lepton-eda/package.nix +++ b/pkgs/by-name/le/lepton-eda/package.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, pkg-config -, makeWrapper -, texinfo -, fetchurl -, autoreconfHook -, guile -, flex -, gtk3 -, glib -, gtksheet -, gettext -, gawk -, shared-mime-info -, groff -, libstroke +{ + stdenv, + lib, + pkg-config, + makeWrapper, + texinfo, + fetchurl, + autoreconfHook, + guile, + flex, + gtk3, + glib, + gtksheet, + gettext, + gawk, + shared-mime-info, + groff, + libstroke, }: stdenv.mkDerivation rec { @@ -26,9 +27,25 @@ stdenv.mkDerivation rec { hash = "sha256-X9yNuosNR1Jf3gYWQZeOnKdxzJLld29Sn9XYsPGWYYI="; }; - nativeBuildInputs = [ pkg-config makeWrapper texinfo autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + texinfo + autoreconfHook + ]; - propagatedBuildInputs = [ guile flex gtk3 glib gtksheet gettext gawk shared-mime-info groff libstroke ]; + propagatedBuildInputs = [ + guile + flex + gtk3 + glib + gtksheet + gettext + gawk + shared-mime-info + groff + libstroke + ]; configureFlags = [ "--disable-update-xdg-database" diff --git a/pkgs/by-name/le/lepton/package.nix b/pkgs/by-name/le/lepton/package.nix index 980f729e9725d7..ba48910df32eed 100644 --- a/pkgs/by-name/le/lepton/package.nix +++ b/pkgs/by-name/le/lepton/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, git, glibc }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + git, + glibc, +}: stdenv.mkDerivation rec { version = "2019-08-20"; @@ -11,14 +18,20 @@ stdenv.mkDerivation rec { sha256 = "0aqs6nvcbq8cbfv8699fa634bsz7csmk0169n069yvv17d1c07fd"; }; - nativeBuildInputs = [ cmake git ]; + nativeBuildInputs = [ + cmake + git + ]; buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ glibc.static ]; meta = with lib; { homepage = "https://github.com/dropbox/lepton"; description = "Tool to losslessly compress JPEGs"; license = licenses.asl20; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; maintainers = with maintainers; [ artemist ]; knownVulnerabilities = [ "CVE-2022-4104" ]; }; diff --git a/pkgs/by-name/le/leptosfmt/package.nix b/pkgs/by-name/le/leptosfmt/package.nix index ef5324d4ba37f3..5b89af49bd71b1 100644 --- a/pkgs/by-name/le/leptosfmt/package.nix +++ b/pkgs/by-name/le/leptosfmt/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -22,7 +23,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "leptosfmt"; homepage = "https://github.com/bram209/leptosfmt"; changelog = "https://github.com/bram209/leptosfmt/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/le/lerc/package.nix b/pkgs/by-name/le/lerc/package.nix index 463344f5b7f682..08a7cb63afbfb4 100644 --- a/pkgs/by-name/le/lerc/package.nix +++ b/pkgs/by-name/le/lerc/package.nix @@ -1,16 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, testers +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "lerc"; version = "4.0.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "esri"; diff --git a/pkgs/by-name/le/lerpn/package.nix b/pkgs/by-name/le/lerpn/package.nix index fcbd6e9513cd84..ac1d3d2e49cfcd 100644 --- a/pkgs/by-name/le/lerpn/package.nix +++ b/pkgs/by-name/le/lerpn/package.nix @@ -1,6 +1,7 @@ -{ python3 -, lib -, fetchFromGitea +{ + python3, + lib, + fetchFromGitea, }: python3.pkgs.buildPythonApplication { diff --git a/pkgs/by-name/le/lesbar/package.nix b/pkgs/by-name/le/lesbar/package.nix index 5649ae27810a60..e05ad2f9a7d8a3 100644 --- a/pkgs/by-name/le/lesbar/package.nix +++ b/pkgs/by-name/le/lesbar/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromSourcehut -, pkg-config -, scdoc -, libX11 -, cairo -, pango +{ + lib, + stdenv, + fetchFromSourcehut, + pkg-config, + scdoc, + libX11, + cairo, + pango, }: stdenv.mkDerivation (finalAttrs: { @@ -19,9 +20,16 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-uggIoO6rgotkLi6lSJTR4d3NtidXsAC1Kjay9YsT9ps="; }; - nativeBuildInputs = [ pkg-config scdoc ]; + nativeBuildInputs = [ + pkg-config + scdoc + ]; - buildInputs = [ libX11 cairo pango ]; + buildInputs = [ + libX11 + cairo + pango + ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/le/lesscpy/package.nix b/pkgs/by-name/le/lesscpy/package.nix index 493fdc08f812cc..eb3e53b8081992 100644 --- a/pkgs/by-name/le/lesscpy/package.nix +++ b/pkgs/by-name/le/lesscpy/package.nix @@ -1,7 +1,11 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { - pname = "lesscpy"; + pname = "lesscpy"; version = "0.15.1"; src = fetchPypi { @@ -11,15 +15,18 @@ python3Packages.buildPythonApplication rec { checkInputs = with python3Packages; [ pytestCheckHook ]; pythonImportsCheck = [ "lesscpy" ]; - propagatedBuildInputs = with python3Packages; [ ply six ]; + propagatedBuildInputs = with python3Packages; [ + ply + six + ]; doCheck = false; # Really weird test failures (`nix-build-python2.css not found`) meta = with lib; { description = "Python LESS Compiler"; mainProgram = "lesscpy"; - homepage = "https://github.com/lesscpy/lesscpy"; - license = licenses.mit; + homepage = "https://github.com/lesscpy/lesscpy"; + license = licenses.mit; maintainers = with maintainers; [ s1341 ]; }; } diff --git a/pkgs/by-name/le/lesspass-cli/package.nix b/pkgs/by-name/le/lesspass-cli/package.nix index c568be5ebbd855..5ef005aec7e8c1 100644 --- a/pkgs/by-name/le/lesspass-cli/package.nix +++ b/pkgs/by-name/le/lesspass-cli/package.nix @@ -1,7 +1,16 @@ -{ lib, python3, fetchFromGitHub }: +{ + lib, + python3, + fetchFromGitHub, +}: let - inherit (python3.pkgs) buildPythonApplication pytest mock pexpect; + inherit (python3.pkgs) + buildPythonApplication + pytest + mock + pexpect + ; repo = "lesspass"; in buildPythonApplication rec { @@ -24,7 +33,11 @@ buildPythonApplication rec { done ''; - nativeCheckInputs = [ pytest mock pexpect ]; + nativeCheckInputs = [ + pytest + mock + pexpect + ]; checkPhase = '' mv lesspass lesspass.hidden # ensure we're testing against *installed* package pytest tests diff --git a/pkgs/by-name/le/lesspipe/package.nix b/pkgs/by-name/le/lesspipe/package.nix index 8fd4689aaeac68..f3eeed022c621d 100644 --- a/pkgs/by-name/le/lesspipe/package.nix +++ b/pkgs/by-name/le/lesspipe/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, perl -, procps -, bash +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + perl, + procps, + bash, -# shell referenced dependencies -, resholve -, binutils-unwrapped -, file -, gnugrep -, coreutils -, gnused -, gnutar -, iconv -, ncurses + # shell referenced dependencies + resholve, + binutils-unwrapped, + file, + gnugrep, + coreutils, + gnused, + gnutar, + iconv, + ncurses, }: stdenv.mkDerivation rec { @@ -29,8 +30,14 @@ stdenv.mkDerivation rec { hash = "sha256-jJrKiRdrargk0JzcPWxBZGyOpMfTIONHG8HNRecazVo="; }; - nativeBuildInputs = [ perl makeWrapper ]; - buildInputs = [ perl bash ]; + nativeBuildInputs = [ + perl + makeWrapper + ]; + buildInputs = [ + perl + bash + ]; strictDeps = true; postPatch = '' @@ -38,7 +45,10 @@ stdenv.mkDerivation rec { substituteInPlace configure --replace '/etc/bash_completion.d' '/share/bash-completion/completions' ''; - configureFlags = [ "--shell=${bash}/bin/bash" "--prefix=/" ]; + configureFlags = [ + "--shell=${bash}/bin/bash" + "--prefix=/" + ]; configurePlatforms = [ ]; dontBuild = true; @@ -62,23 +72,100 @@ stdenv.mkDerivation rec { procps ncurses ]; - keep = [ "$prog" "$c1" "$c2" "$c3" "$c4" "$c5" "$cmd" "$colorizer" "$HOME" ]; + keep = [ + "$prog" + "$c1" + "$c2" + "$c3" + "$c4" + "$c5" + "$cmd" + "$colorizer" + "$HOME" + ]; fake = { # script guards usage behind has_cmd test function, it's safe to leave these external and optional - external = [ - "cpio" "isoinfo" "cabextract" "bsdtar" "rpm2cpio" "bsdtar" "unzip" "ar" "unrar" "rar" "7zr" "7za" "isoinfo" - "gzip" "bzip2" "lzip" "lzma" "xz" "brotli" "compress" "zstd" "lz4" - "archive_color" "bat" "batcat" "pygmentize" "source-highlight" "vimcolor" "code2color" + external = + [ + "cpio" + "isoinfo" + "cabextract" + "bsdtar" + "rpm2cpio" + "bsdtar" + "unzip" + "ar" + "unrar" + "rar" + "7zr" + "7za" + "isoinfo" + "gzip" + "bzip2" + "lzip" + "lzma" + "xz" + "brotli" + "compress" + "zstd" + "lz4" + "archive_color" + "bat" + "batcat" + "pygmentize" + "source-highlight" + "vimcolor" + "code2color" - "w3m" "lynx" "elinks" "html2text" "dtc" "pdftotext" "pdftohtml" "pdfinfo" "ps2ascii" "procyon" "ccze" - "mdcat" "pandoc" "docx2txt" "libreoffice" "pptx2md" "mdcat" "xlscat" "odt2txt" "wvText" "antiword" "catdoc" - "broken_catppt" "sxw2txt" "groff" "mandoc" "unrtf" "dvi2tty" "pod2text" "perldoc" "h5dump" "ncdump" "matdump" - "djvutxt" "openssl" "gpg" "plistutil" "plutil" "id3v2" "csvlook" "jq" "zlib-flate" "lessfilter" - ] ++ lib.optional (stdenv.hostPlatform.isDarwin || stdenv.hostPlatform.isFreeBSD) [ - # resholve only identifies this on darwin/bsd - # call site is guarded by || so it's safe to leave dynamic - "locale" - ]; + "w3m" + "lynx" + "elinks" + "html2text" + "dtc" + "pdftotext" + "pdftohtml" + "pdfinfo" + "ps2ascii" + "procyon" + "ccze" + "mdcat" + "pandoc" + "docx2txt" + "libreoffice" + "pptx2md" + "mdcat" + "xlscat" + "odt2txt" + "wvText" + "antiword" + "catdoc" + "broken_catppt" + "sxw2txt" + "groff" + "mandoc" + "unrtf" + "dvi2tty" + "pod2text" + "perldoc" + "h5dump" + "ncdump" + "matdump" + "djvutxt" + "openssl" + "gpg" + "plistutil" + "plutil" + "id3v2" + "csvlook" + "jq" + "zlib-flate" + "lessfilter" + ] + ++ lib.optional (stdenv.hostPlatform.isDarwin || stdenv.hostPlatform.isFreeBSD) [ + # resholve only identifies this on darwin/bsd + # call site is guarded by || so it's safe to leave dynamic + "locale" + ]; builtin = [ "setopt" ]; }; execer = [ @@ -95,12 +182,40 @@ stdenv.mkDerivation rec { gnused gnutar ]; - keep = [ "$prog" "$c1" "$c2" "$c3" "$c4" "$c5" "$cmd" ]; + keep = [ + "$prog" + "$c1" + "$c2" + "$c3" + "$c4" + "$c5" + "$cmd" + ]; fake = { # script guards usage behind has_cmd test function, it's safe to leave these external and optional external = [ - "cpio" "isoinfo" "cabextract" "bsdtar" "rpm2cpio" "bsdtar" "unzip" "ar" "unrar" "rar" "7zr" "7za" "isoinfo" - "gzip" "bzip2" "lzip" "lzma" "xz" "brotli" "compress" "zstd" "lz4" + "cpio" + "isoinfo" + "cabextract" + "bsdtar" + "rpm2cpio" + "bsdtar" + "unzip" + "ar" + "unrar" + "rar" + "7zr" + "7za" + "isoinfo" + "gzip" + "bzip2" + "lzip" + "lzma" + "xz" + "brotli" + "compress" + "zstd" + "lz4" ]; builtin = [ "setopt" ]; }; diff --git a/pkgs/by-name/le/lesstif/package.nix b/pkgs/by-name/le/lesstif/package.nix index 33c2f220e40df8..0312e530c931c9 100644 --- a/pkgs/by-name/le/lesstif/package.nix +++ b/pkgs/by-name/le/lesstif/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, freetype -, fontconfig -, libICE -, libX11 -, libXp -, libXau -, libXext -, libXt +{ + lib, + stdenv, + fetchurl, + freetype, + fontconfig, + libICE, + libX11, + libXp, + libXau, + libXext, + libXt, }: stdenv.mkDerivation rec { @@ -39,12 +40,15 @@ stdenv.mkDerivation rec { ./c-missing_xm_h.patch ./c-render_table_crash.patch ./c-xpmpipethrough.patch - ]; + ]; meta = with lib; { description = "Open source clone of the Motif widget set"; homepage = "https://lesstif.sourceforge.net"; platforms = platforms.unix; - license = with licenses; [ gpl2 lgpl2 ]; + license = with licenses; [ + gpl2 + lgpl2 + ]; }; } diff --git a/pkgs/by-name/le/letterpress/package.nix b/pkgs/by-name/le/letterpress/package.nix index 3286633f671e39..83e3500bef5ebe 100644 --- a/pkgs/by-name/le/letterpress/package.nix +++ b/pkgs/by-name/le/letterpress/package.nix @@ -65,7 +65,7 @@ python3Packages.buildPythonApplication rec { dontWrapGApps = true; # prevent double wrapping preFixup = '' - makeWrapperArgs+=(''${gappsWrapperArgs[@]} --prefix PATH : ${ lib.makeBinPath runtimeDeps }) + makeWrapperArgs+=(''${gappsWrapperArgs[@]} --prefix PATH : ${lib.makeBinPath runtimeDeps}) ''; meta = with lib; { diff --git a/pkgs/by-name/le/levant/package.nix b/pkgs/by-name/le/levant/package.nix index cd6d25113e7280..b998742f1c454f 100644 --- a/pkgs/by-name/le/levant/package.nix +++ b/pkgs/by-name/le/levant/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "levant"; diff --git a/pkgs/by-name/le/level-zero/package.nix b/pkgs/by-name/le/level-zero/package.nix index 1be331ffa0c429..afc81c7e91cd01 100644 --- a/pkgs/by-name/le/level-zero/package.nix +++ b/pkgs/by-name/le/level-zero/package.nix @@ -1,10 +1,11 @@ -{ lib -, addDriverRunpath -, cmake -, fetchFromGitHub -, intel-compute-runtime -, openvino -, stdenv +{ + lib, + addDriverRunpath, + cmake, + fetchFromGitHub, + intel-compute-runtime, + openvino, + stdenv, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { hash = "sha256-MnTPu7jsjHR+PDHzj/zJiBKi9Ou/cjJvrf87yMdSnz0="; }; - nativeBuildInputs = [ cmake addDriverRunpath ]; + nativeBuildInputs = [ + cmake + addDriverRunpath + ]; postFixup = '' addDriverRunpath $out/lib/libze_loader.so @@ -37,4 +41,3 @@ stdenv.mkDerivation rec { maintainers = [ maintainers.ziguana ]; }; } - diff --git a/pkgs/by-name/le/leveldb/package.nix b/pkgs/by-name/le/leveldb/package.nix index 9d2dfe468029c0..899135413fbc1f 100644 --- a/pkgs/by-name/le/leveldb/package.nix +++ b/pkgs/by-name/le/leveldb/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, fixDarwinDylibNames, snappy, cmake -, static ? stdenv.hostPlatform.isStatic }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + fixDarwinDylibNames, + snappy, + cmake, + static ? stdenv.hostPlatform.isStatic, +}: stdenv.mkDerivation rec { pname = "leveldb"; @@ -23,7 +31,10 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; buildInputs = [ snappy ]; diff --git a/pkgs/by-name/le/levmar/package.nix b/pkgs/by-name/le/levmar/package.nix index f1ba199fc8e0b9..0212cae30f628c 100644 --- a/pkgs/by-name/le/levmar/package.nix +++ b/pkgs/by-name/le/levmar/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "levmar"; diff --git a/pkgs/by-name/le/lexend/package.nix b/pkgs/by-name/le/lexend/package.nix index 91eb497e901bf1..94b8cb554920eb 100644 --- a/pkgs/by-name/le/lexend/package.nix +++ b/pkgs/by-name/le/lexend/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/le/lexmark-aex/package.nix b/pkgs/by-name/le/lexmark-aex/package.nix index cfb02f70d6f3e5..8bb1c4c0bec82f 100644 --- a/pkgs/by-name/le/lexmark-aex/package.nix +++ b/pkgs/by-name/le/lexmark-aex/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, cups -, fetchurl -, patchPpdFilesHook -, autoPatchelfHook -, dpkg -, perl -, avahi +{ + lib, + stdenv, + cups, + fetchurl, + patchPpdFilesHook, + autoPatchelfHook, + dpkg, + perl, + avahi, }: stdenv.mkDerivation { @@ -40,32 +41,40 @@ stdenv.mkDerivation { # Needed for autoPatchelfHook. runtimeDependencies = [ (lib.getLib cups) ]; - ppdFileCommands = [ "CommandFileFilterG2" "rerouteprintoption" ]; + ppdFileCommands = [ + "CommandFileFilterG2" + "rerouteprintoption" + ]; - installPhase = let - libdir = - if stdenv.system == "x86_64-linux" then "lib64" - else if stdenv.system == "i686_linux" then "lib" - else throw "other platforms than i686_linux and x86_64-linux are not yet supported"; - in '' - runHook preInstall + installPhase = + let + libdir = + if stdenv.system == "x86_64-linux" then + "lib64" + else if stdenv.system == "i686_linux" then + "lib" + else + throw "other platforms than i686_linux and x86_64-linux are not yet supported"; + in + '' + runHook preInstall - prefix=usr/local/Lexmark/ppd/Lexmark-AEX-PPD-Files/GlobalPPD_1.4 + prefix=usr/local/Lexmark/ppd/Lexmark-AEX-PPD-Files/GlobalPPD_1.4 - # Install raster image filter. - install -Dm755 "$prefix/rerouteprintoption" "$out/lib/cups/filter/rerouteprintoption" - patchShebangs "$out/lib/cups/filter/rerouteprintoption" + # Install raster image filter. + install -Dm755 "$prefix/rerouteprintoption" "$out/lib/cups/filter/rerouteprintoption" + patchShebangs "$out/lib/cups/filter/rerouteprintoption" - # Install additional binary filters. - for i in CommandFileFilterG2 LexHBPFilter; do - install -Dm755 "$prefix/${libdir}/$i" "$out/lib/cups/filter/$i" - done + # Install additional binary filters. + for i in CommandFileFilterG2 LexHBPFilter; do + install -Dm755 "$prefix/${libdir}/$i" "$out/lib/cups/filter/$i" + done - # Install PPD. - install -Dm 0644 -t "$out/share/cups/model/Lexmark" "$prefix"/*.ppd + # Install PPD. + install -Dm 0644 -t "$out/share/cups/model/Lexmark" "$prefix"/*.ppd - runHook postInstall - ''; + runHook postInstall + ''; meta = with lib; { description = "CUPS drivers for Lexmark B2200 and MB2200 Series printers"; @@ -73,6 +82,9 @@ stdenv.mkDerivation { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; maintainers = [ maintainers.tobim ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/by-name/lf/lftp/package.nix b/pkgs/by-name/lf/lftp/package.nix index 1d25888f5d380b..37654dd957d96d 100644 --- a/pkgs/by-name/lf/lftp/package.nix +++ b/pkgs/by-name/lf/lftp/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, openssl, pkg-config, readline, zlib, libidn2, gmp, libiconv, libunistring, gettext }: +{ + lib, + stdenv, + fetchurl, + openssl, + pkg-config, + readline, + zlib, + libidn2, + gmp, + libiconv, + libunistring, + gettext, +}: stdenv.mkDerivation rec { pname = "lftp"; @@ -8,13 +21,22 @@ stdenv.mkDerivation rec { urls = [ "https://lftp.yar.ru/ftp/${pname}-${version}.tar.xz" "https://ftp.st.ryukoku.ac.jp/pub/network/ftp/lftp/${pname}-${version}.tar.xz" - ]; + ]; sha256 = "sha256-lucZnXk1vjPPaxFh6VWyqrQKt37N8qGc6k/BGT9Fftw="; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl readline zlib libidn2 gmp libiconv libunistring gettext ]; + buildInputs = [ + openssl + readline + zlib + libidn2 + gmp + libiconv + libunistring + gettext + ]; hardeningDisable = lib.optional stdenv.hostPlatform.isDarwin "format"; diff --git a/pkgs/by-name/lg/lguf-brightness/package.nix b/pkgs/by-name/lg/lguf-brightness/package.nix index 0bb288c217630c..f597fa1c27b1aa 100644 --- a/pkgs/by-name/lg/lguf-brightness/package.nix +++ b/pkgs/by-name/lg/lguf-brightness/package.nix @@ -1,11 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libusb1, ncurses5 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libusb1, + ncurses5, +}: stdenv.mkDerivation rec { pname = "lguf-brightness"; version = "unstable-2018-02-11"; - src = fetchFromGitHub { + src = fetchFromGitHub { owner = "periklis"; repo = pname; rev = "fcb2bc1738d55c83b6395c24edc27267a520a725"; @@ -14,7 +21,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ libusb1 ncurses5 ]; + buildInputs = [ + libusb1 + ncurses5 + ]; installPhase = '' install -D lguf_brightness $out/bin/lguf_brightness diff --git a/pkgs/by-name/lh/lha/package.nix b/pkgs/by-name/lh/lha/package.nix index b7d0ac93029030..c786bcb2861d8a 100644 --- a/pkgs/by-name/lh/lha/package.nix +++ b/pkgs/by-name/lh/lha/package.nix @@ -1,4 +1,9 @@ -{stdenv, lib, fetchFromGitHub, autoreconfHook}: +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation { pname = "lha"; diff --git a/pkgs/by-name/lh/lhasa/package.nix b/pkgs/by-name/lh/lhasa/package.nix index 9ced4a9b7bfba9..ee98f0ac5c6141 100644 --- a/pkgs/by-name/lh/lhasa/package.nix +++ b/pkgs/by-name/lh/lhasa/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "lhasa"; diff --git a/pkgs/by-name/li/liana/package.nix b/pkgs/by-name/li/liana/package.nix index 7ee6d0ccc56f0d..a1ab4a63c84a1b 100644 --- a/pkgs/by-name/li/liana/package.nix +++ b/pkgs/by-name/li/liana/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, cmake -, copyDesktopItems -, makeDesktopItem -, makeWrapper -, expat -, fontconfig -, freetype -, libGL -, udev -, libxkbcommon -, wayland -, vulkan-loader -, xorg +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + cmake, + copyDesktopItems, + makeDesktopItem, + makeWrapper, + expat, + fontconfig, + freetype, + libGL, + udev, + libxkbcommon, + wayland, + vulkan-loader, + xorg, }: let diff --git a/pkgs/by-name/li/lib3270/package.nix b/pkgs/by-name/li/lib3270/package.nix index 119f7a1d6e15ec..78d168d78a3512 100644 --- a/pkgs/by-name/li/lib3270/package.nix +++ b/pkgs/by-name/li/lib3270/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, which -, pkg-config -, autoconf -, automake -, libtool -, gettext -, openssl -, curl +{ + lib, + stdenv, + fetchFromGitHub, + which, + pkg-config, + autoconf, + automake, + libtool, + gettext, + openssl, + curl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/lib3ds/package.nix b/pkgs/by-name/li/lib3ds/package.nix index 791d2ab523d036..3764dbdd0158f5 100644 --- a/pkgs/by-name/li/lib3ds/package.nix +++ b/pkgs/by-name/li/lib3ds/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "lib3ds"; @@ -18,4 +23,3 @@ stdenv.mkDerivation rec { platforms = lib.platforms.unix; }; } - diff --git a/pkgs/by-name/li/lib3mf/package.nix b/pkgs/by-name/li/lib3mf/package.nix index df88534bc6e746..c61a747bec0eee 100644 --- a/pkgs/by-name/li/lib3mf/package.nix +++ b/pkgs/by-name/li/lib3mf/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, cmake, ninja, automaticcomponenttoolkit -, pkg-config, libzip, gtest, openssl, libuuid, libossp_uuid }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + automaticcomponenttoolkit, + pkg-config, + libzip, + gtest, + openssl, + libuuid, + libossp_uuid, +}: stdenv.mkDerivation rec { pname = "lib3mf"; @@ -14,9 +26,16 @@ stdenv.mkDerivation rec { patches = [ ./upgrade-to-cpp-14.patch ]; - nativeBuildInputs = [ cmake ninja pkg-config ]; + nativeBuildInputs = [ + cmake + ninja + pkg-config + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; cmakeFlags = [ "-DCMAKE_INSTALL_INCLUDEDIR=include/lib3mf" @@ -27,7 +46,9 @@ stdenv.mkDerivation rec { ]; buildInputs = [ - libzip gtest openssl + libzip + gtest + openssl ] ++ (if stdenv.hostPlatform.isDarwin then [ libossp_uuid ] else [ libuuid ]); postPatch = '' diff --git a/pkgs/by-name/li/libGDSII/package.nix b/pkgs/by-name/li/libGDSII/package.nix index 095e0ee182a3df..36d13c9ed8c348 100644 --- a/pkgs/by-name/li/libGDSII/package.nix +++ b/pkgs/by-name/li/libGDSII/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { @@ -27,7 +28,10 @@ stdenv.mkDerivation rec { mainProgram = "GDSIIConvert"; homepage = "https://github.com/HomerReid/libGDSII"; license = [ licenses.gpl2Only ]; - maintainers = with maintainers; [ sheepforce markuskowa ]; + maintainers = with maintainers; [ + sheepforce + markuskowa + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/li/libHX/package.nix b/pkgs/by-name/li/libHX/package.nix index 7016c5c86593b7..dda695c1f7472d 100644 --- a/pkgs/by-name/li/libHX/package.nix +++ b/pkgs/by-name/li/libHX/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, autoconf, automake, libtool }: +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + libtool, +}: stdenv.mkDerivation rec { pname = "libHX"; @@ -9,9 +16,13 @@ stdenv.mkDerivation rec { sha256 = "18w39j528lyg2026dr11f2xxxphy91cg870nx182wbd8cjlqf86c"; }; - patches = []; + patches = [ ]; - nativeBuildInputs = [ autoconf automake libtool ]; + nativeBuildInputs = [ + autoconf + automake + libtool + ]; preConfigure = '' sh autogen.sh @@ -23,9 +34,13 @@ stdenv.mkDerivation rec { libHX is a C library (with some C++ bindings available) that provides data structures and functions commonly needed, such as maps, deques, linked lists, string formatting and autoresizing, option and config file parsing, type checking casts and more. - ''; + ''; maintainers = [ ]; platforms = platforms.linux; - license = with licenses; [ gpl3 lgpl21Plus wtfpl ]; + license = with licenses; [ + gpl3 + lgpl21Plus + wtfpl + ]; }; } diff --git a/pkgs/by-name/li/libLAS/package.nix b/pkgs/by-name/li/libLAS/package.nix index f9bd013065852e..5bec9b5f2075bc 100644 --- a/pkgs/by-name/li/libLAS/package.nix +++ b/pkgs/by-name/li/libLAS/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, fetchpatch, boost, cmake, libgeotiff, libtiff, laszip_2, fixDarwinDylibNames }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + boost, + cmake, + libgeotiff, + libtiff, + laszip_2, + fixDarwinDylibNames, +}: stdenv.mkDerivation rec { pname = "libLAS"; @@ -35,7 +46,12 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ cmake ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; - buildInputs = [ boost libgeotiff libtiff laszip_2 ]; + buildInputs = [ + boost + libgeotiff + libtiff + laszip_2 + ]; cmakeFlags = [ "-DWITH_LASZIP=ON" diff --git a/pkgs/by-name/li/libaacs/package.nix b/pkgs/by-name/li/libaacs/package.nix index c0d3b91885e659..656aca8ddfa8c0 100644 --- a/pkgs/by-name/li/libaacs/package.nix +++ b/pkgs/by-name/li/libaacs/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, libgcrypt, libgpg-error, bison, flex }: +{ + lib, + stdenv, + fetchurl, + libgcrypt, + libgpg-error, + bison, + flex, +}: # library that allows libbluray to play AACS protected bluray disks # libaacs does not infringe DRM's right or copyright. See the legal page of the website for more info. @@ -9,16 +17,22 @@ stdenv.mkDerivation rec { pname = "libaacs"; - version = "0.11.1"; + version = "0.11.1"; src = fetchurl { url = "http://get.videolan.org/libaacs/${version}/${pname}-${version}.tar.bz2"; sha256 = "sha256-qIqg6+TJinf3rv/ZKrPvZKxUjGuCLoJIqLkmclvqCjk="; }; - buildInputs = [ libgcrypt libgpg-error ]; + buildInputs = [ + libgcrypt + libgpg-error + ]; - nativeBuildInputs = [ bison flex ]; + nativeBuildInputs = [ + bison + flex + ]; meta = with lib; { homepage = "https://www.videolan.org/developers/libaacs.html"; diff --git a/pkgs/by-name/li/libaal/package.nix b/pkgs/by-name/li/libaal/package.nix index d5b0b95f959925..8e3535d90f6b49 100644 --- a/pkgs/by-name/li/libaal/package.nix +++ b/pkgs/by-name/li/libaal/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "1.0.7"; diff --git a/pkgs/by-name/li/libabigail/package.nix b/pkgs/by-name/li/libabigail/package.nix index fcfc88cbb667ba..f8f2578089503e 100644 --- a/pkgs/by-name/li/libabigail/package.nix +++ b/pkgs/by-name/li/libabigail/package.nix @@ -1,18 +1,24 @@ -{ lib, stdenv -, fetchurl -, autoreconfHook -, elfutils -, libxml2 -, pkg-config -, strace -, python3 +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + elfutils, + libxml2, + pkg-config, + strace, + python3, }: stdenv.mkDerivation rec { pname = "libabigail"; version = "2.5"; - outputs = [ "bin" "out" "dev" ]; + outputs = [ + "bin" + "out" + "dev" + ]; src = fetchurl { url = "https://mirrors.kernel.org/sourceware/${pname}/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/li/libabw/package.nix b/pkgs/by-name/li/libabw/package.nix index 5476b3c7402b54..083e4ad7be0a44 100644 --- a/pkgs/by-name/li/libabw/package.nix +++ b/pkgs/by-name/li/libabw/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, boost, doxygen, gperf, pkg-config, librevenge, libxml2, perl, zlib }: +{ + lib, + stdenv, + fetchurl, + boost, + doxygen, + gperf, + pkg-config, + librevenge, + libxml2, + perl, + zlib, +}: stdenv.mkDerivation rec { pname = "libabw"; @@ -16,7 +28,15 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ boost doxygen gperf librevenge libxml2 perl zlib ]; + buildInputs = [ + boost + doxygen + gperf + librevenge + libxml2 + perl + zlib + ]; meta = with lib; { homepage = "https://wiki.documentfoundation.org/DLP/Libraries/libabw"; diff --git a/pkgs/by-name/li/libaccounts-glib/package.nix b/pkgs/by-name/li/libaccounts-glib/package.nix index 3ed46996056aec..aa4fd5f15009d8 100644 --- a/pkgs/by-name/li/libaccounts-glib/package.nix +++ b/pkgs/by-name/li/libaccounts-glib/package.nix @@ -1,11 +1,36 @@ -{ lib, stdenv, fetchFromGitLab, gitUpdater, meson, mesonEmulatorHook, ninja, glib, check, python3, vala, gtk-doc, glibcLocales -, libxml2, libxslt, pkg-config, sqlite, docbook_xsl, docbook_xml_dtd_43, gobject-introspection }: +{ + lib, + stdenv, + fetchFromGitLab, + gitUpdater, + meson, + mesonEmulatorHook, + ninja, + glib, + check, + python3, + vala, + gtk-doc, + glibcLocales, + libxml2, + libxslt, + pkg-config, + sqlite, + docbook_xsl, + docbook_xml_dtd_43, + gobject-introspection, +}: stdenv.mkDerivation rec { pname = "libaccounts-glib"; version = "1.27"; - outputs = [ "out" "dev" "devdoc" "py" ]; + outputs = [ + "out" + "dev" + "devdoc" + "py" + ]; src = fetchFromGitLab { owner = "accounts-sso"; @@ -14,20 +39,22 @@ stdenv.mkDerivation rec { hash = "sha256-mLhcwp8rhCGSB1K6rTWT0tuiINzgwULwXINfCbgPKEg="; }; - nativeBuildInputs = [ - check - docbook_xml_dtd_43 - docbook_xsl - glibcLocales - gobject-introspection - gtk-doc - meson - ninja - pkg-config - vala - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + check + docbook_xml_dtd_43 + docbook_xsl + glibcLocales + gobject-introspection + gtk-doc + meson + ninja + pkg-config + vala + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ glib diff --git a/pkgs/by-name/li/libad9361/package.nix b/pkgs/by-name/li/libad9361/package.nix index 96f1e877d52ba5..6b0e62dcd159d2 100644 --- a/pkgs/by-name/li/libad9361/package.nix +++ b/pkgs/by-name/li/libad9361/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libiio }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libiio, +}: stdenv.mkDerivation rec { pname = "libad9361"; diff --git a/pkgs/by-name/li/libaec/package.nix b/pkgs/by-name/li/libaec/package.nix index cd816329a51a36..e323b420b980c2 100644 --- a/pkgs/by-name/li/libaec/package.nix +++ b/pkgs/by-name/li/libaec/package.nix @@ -1,10 +1,13 @@ -{ lib, stdenv, fetchFromGitLab -, cmake +{ + lib, + stdenv, + fetchFromGitLab, + cmake, }: stdenv.mkDerivation rec { pname = "libaec"; - version = "1.1.3"; + version = "1.1.3"; src = fetchFromGitLab { domain = "gitlab.dkrz.de"; diff --git a/pkgs/by-name/li/libaio/package.nix b/pkgs/by-name/li/libaio/package.nix index 080571ad71d1a4..ca30fc15d6bc21 100644 --- a/pkgs/by-name/li/libaio/package.nix +++ b/pkgs/by-name/li/libaio/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "0.3.113"; diff --git a/pkgs/by-name/li/libajantv2/package.nix b/pkgs/by-name/li/libajantv2/package.nix index ed5a57ed7364ee..4b0366d20c52f5 100644 --- a/pkgs/by-name/li/libajantv2/package.nix +++ b/pkgs/by-name/li/libajantv2/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, ninja -, pkg-config +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + ninja, + pkg-config, }: # Warning: We are aware that the upstream changed and there are new releases, @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-h5PKWMwqTeI5/EaTWkjYojuvDU0FyMpzIjWB98UOJwc="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake diff --git a/pkgs/by-name/li/libamplsolver/package.nix b/pkgs/by-name/li/libamplsolver/package.nix index bfaad6cbc7674b..d6a3e0a35682a0 100644 --- a/pkgs/by-name/li/libamplsolver/package.nix +++ b/pkgs/by-name/li/libamplsolver/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, substitute, fetchurl }: +{ + lib, + stdenv, + substitute, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libamplsolver"; @@ -12,22 +17,29 @@ stdenv.mkDerivation rec { patches = [ (substitute { src = ./libamplsolver-sharedlib.patch; - substitutions = [ "--replace" "@sharedlibext@" "${stdenv.hostPlatform.extensions.sharedLibrary}" ]; + substitutions = [ + "--replace" + "@sharedlibext@" + "${stdenv.hostPlatform.extensions.sharedLibrary}" + ]; }) ]; - installPhase = '' - runHook preInstall - pushd sys.$(uname -m).$(uname -s) - install -D -m 0644 *.h -t $out/include - install -D -m 0644 *${stdenv.hostPlatform.extensions.sharedLibrary}* -t $out/lib - install -D -m 0644 *.a -t $out/lib - popd - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install_name_tool -id $out/lib/libamplsolver.dylib $out/lib/libamplsolver.dylib - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + pushd sys.$(uname -m).$(uname -s) + install -D -m 0644 *.h -t $out/include + install -D -m 0644 *${stdenv.hostPlatform.extensions.sharedLibrary}* -t $out/lib + install -D -m 0644 *.a -t $out/lib + popd + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install_name_tool -id $out/lib/libamplsolver.dylib $out/lib/libamplsolver.dylib + '' + + '' + runHook postInstall + ''; meta = with lib; { description = "Library of routines that help solvers work with AMPL"; diff --git a/pkgs/by-name/li/libantlr3c/package.nix b/pkgs/by-name/li/libantlr3c/package.nix index 622dabd82394fe..76ad3a77342189 100644 --- a/pkgs/by-name/li/libantlr3c/package.nix +++ b/pkgs/by-name/li/libantlr3c/package.nix @@ -1,14 +1,19 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libantlr3c"; version = "3.4"; src = fetchurl { url = "https://www.antlr3.org/download/C/libantlr3c-${version}.tar.gz"; - sha256 ="0lpbnb4dq4azmsvlhp6khq1gy42kyqyjv8gww74g5lm2y6blm4fa"; + sha256 = "0lpbnb4dq4azmsvlhp6khq1gy42kyqyjv8gww74g5lm2y6blm4fa"; }; - configureFlags = lib.optional stdenv.hostPlatform.is64bit "--enable-64bit" + configureFlags = + lib.optional stdenv.hostPlatform.is64bit "--enable-64bit" # libantlr3c wrongly emits the abi flags -m64 and -m32 which imply x86 archs # https://github.com/antlr/antlr3/issues/205 ++ lib.optional (!stdenv.hostPlatform.isx86) "--disable-abiflags"; diff --git a/pkgs/by-name/li/libaom/package.nix b/pkgs/by-name/li/libaom/package.nix index 8b8362d6c19349..82650185cd818b 100644 --- a/pkgs/by-name/li/libaom/package.nix +++ b/pkgs/by-name/li/libaom/package.nix @@ -1,11 +1,21 @@ -{ lib, stdenv, fetchurl, fetchzip, yasm, perl, cmake, pkg-config, python3 -, enableVmaf ? true, libvmaf -, gitUpdater +{ + lib, + stdenv, + fetchurl, + fetchzip, + yasm, + perl, + cmake, + pkg-config, + python3, + enableVmaf ? true, + libvmaf, + gitUpdater, -# for passthru.tests -, ffmpeg -, libavif -, libheif + # for passthru.tests + ffmpeg, + libavif, + libheif, }: let @@ -21,20 +31,26 @@ stdenv.mkDerivation rec { stripRoot = false; }; - patches = [ - ./outputs.patch - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - # This patch defines `_POSIX_C_SOURCE`, which breaks system headers - # on Darwin. - (fetchurl { - name = "musl.patch"; - url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/media-libs/libaom/files/libaom-3.4.0-posix-c-source-ftello.patch?id=50c7c4021e347ee549164595280cf8a23c960959"; - hash = "sha256-6+u7GTxZcSNJgN7D+s+XAVwbMnULufkTcQ0s7l+Ydl0="; - }) - ]; + patches = + [ + ./outputs.patch + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + # This patch defines `_POSIX_C_SOURCE`, which breaks system headers + # on Darwin. + (fetchurl { + name = "musl.patch"; + url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/media-libs/libaom/files/libaom-3.4.0-posix-c-source-ftello.patch?id=50c7c4021e347ee549164595280cf8a23c960959"; + hash = "sha256-6+u7GTxZcSNJgN7D+s+XAVwbMnULufkTcQ0s7l+Ydl0="; + }) + ]; nativeBuildInputs = [ - yasm perl cmake pkg-config python3 + yasm + perl + cmake + pkg-config + python3 ]; propagatedBuildInputs = lib.optional enableVmaf libvmaf; @@ -52,26 +68,37 @@ stdenv.mkDerivation rec { # Configuration options: # https://aomedia.googlesource.com/aom/+/refs/heads/master/build/cmake/aom_config_defaults.cmake - cmakeFlags = [ - "-DBUILD_SHARED_LIBS=ON" - "-DENABLE_TESTS=OFF" - ] ++ lib.optionals enableVmaf [ - "-DCONFIG_TUNE_VMAF=1" - ] ++ lib.optionals (isCross && !stdenv.hostPlatform.isx86) [ - "-DCMAKE_ASM_COMPILER=${stdenv.cc.targetPrefix}as" - ] ++ lib.optionals stdenv.hostPlatform.isAarch32 [ - # armv7l-hf-multiplatform does not support NEON - # see lib/systems/platform.nix - "-DENABLE_NEON=0" - ]; + cmakeFlags = + [ + "-DBUILD_SHARED_LIBS=ON" + "-DENABLE_TESTS=OFF" + ] + ++ lib.optionals enableVmaf [ + "-DCONFIG_TUNE_VMAF=1" + ] + ++ lib.optionals (isCross && !stdenv.hostPlatform.isx86) [ + "-DCMAKE_ASM_COMPILER=${stdenv.cc.targetPrefix}as" + ] + ++ lib.optionals stdenv.hostPlatform.isAarch32 [ + # armv7l-hf-multiplatform does not support NEON + # see lib/systems/platform.nix + "-DENABLE_NEON=0" + ]; - postFixup = '' - moveToOutput lib/libaom.a "$static" - '' + lib.optionalString stdenv.hostPlatform.isStatic '' - ln -s $static $out - ''; + postFixup = + '' + moveToOutput lib/libaom.a "$static" + '' + + lib.optionalString stdenv.hostPlatform.isStatic '' + ln -s $static $out + ''; - outputs = [ "out" "bin" "dev" "static" ]; + outputs = [ + "out" + "bin" + "dev" + "static" + ]; passthru = { updateScript = gitUpdater { @@ -92,10 +119,14 @@ stdenv.mkDerivation rec { for Open Media. It contains an AV1 library as well as applications like an encoder (aomenc) and a decoder (aomdec). ''; - homepage = "https://aomedia.org/av1-features/get-started/"; - changelog = "https://aomedia.googlesource.com/aom/+/refs/tags/v${version}/CHANGELOG"; - maintainers = with maintainers; [ primeos kiloreux dandellion ]; - platforms = platforms.all; + homepage = "https://aomedia.org/av1-features/get-started/"; + changelog = "https://aomedia.googlesource.com/aom/+/refs/tags/v${version}/CHANGELOG"; + maintainers = with maintainers; [ + primeos + kiloreux + dandellion + ]; + platforms = platforms.all; outputsToInstall = [ "bin" ]; license = licenses.bsd2; }; diff --git a/pkgs/by-name/li/libaosd/package.nix b/pkgs/by-name/li/libaosd/package.nix index 8068ae3edd9d92..bc6aa9c97dd791 100644 --- a/pkgs/by-name/li/libaosd/package.nix +++ b/pkgs/by-name/li/libaosd/package.nix @@ -1,19 +1,38 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, cairo, pango, - libX11, libXcomposite, autoconf, automake }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cairo, + pango, + libX11, + libXcomposite, + autoconf, + automake, +}: stdenv.mkDerivation rec { version = "0.2.7-9-g177589f"; pname = "libaosd"; src = fetchFromGitHub { - owner = "atheme-legacy"; - repo = "libaosd"; - rev = version; + owner = "atheme-legacy"; + repo = "libaosd"; + rev = version; sha256 = "1cn7k0n74p6jp25kxwcyblhmbdvgw3mikvj0m2jh4c6xccfrgb9a"; }; - nativeBuildInputs = [ autoconf automake pkg-config ]; - buildInputs = [ cairo pango libX11 libXcomposite ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + ]; + buildInputs = [ + cairo + pango + libX11 + libXcomposite + ]; enableParallelBuilding = true; preConfigure = '' diff --git a/pkgs/by-name/li/libappindicator/package.nix b/pkgs/by-name/li/libappindicator/package.nix index e2cd9624bc40fc..8de5d08ed94179 100644 --- a/pkgs/by-name/li/libappindicator/package.nix +++ b/pkgs/by-name/li/libappindicator/package.nix @@ -1,12 +1,26 @@ -{ stdenv, fetchgit, lib -, pkg-config, autoreconfHook -, glib, dbus-glib -, gtkVersion ? "3" -, gtk2, libindicator-gtk2, libdbusmenu-gtk2 -, gtk3, libindicator-gtk3, libdbusmenu-gtk3 -, gtk-doc, vala, gobject-introspection -, monoSupport ? false, mono, gtk-sharp-2_0, gtk-sharp-3_0 -, testers +{ + stdenv, + fetchgit, + lib, + pkg-config, + autoreconfHook, + glib, + dbus-glib, + gtkVersion ? "3", + gtk2, + libindicator-gtk2, + libdbusmenu-gtk2, + gtk3, + libindicator-gtk3, + libdbusmenu-gtk3, + gtk-doc, + vala, + gobject-introspection, + monoSupport ? false, + mono, + gtk-sharp-2_0, + gtk-sharp-3_0, + testers, }: let @@ -14,11 +28,17 @@ let in stdenv.mkDerivation (finalAttrs: { - pname = let postfix = if monoSupport then "sharp" else "gtk${gtkVersion}"; - in "libappindicator-${postfix}"; + pname = + let + postfix = if monoSupport then "sharp" else "gtk${gtkVersion}"; + in + "libappindicator-${postfix}"; version = "12.10.1+20.10.20200706.1"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchgit { url = "https://git.launchpad.net/ubuntu/+source/libappindicator"; @@ -26,26 +46,45 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "0xjvbl4gn7ra2fs6gn2g9s787kzb5cg9hv79iqsz949rxh4iw32d"; }; - nativeBuildInputs = [ pkg-config autoreconfHook vala gobject-introspection gtk-doc ]; - - propagatedBuildInputs = { - "2" = [ gtk2 libdbusmenu-gtk2 ]; - "3" = [ gtk3 libdbusmenu-gtk3 ]; - }.${gtkVersion} or throwBadGtkVersion; + nativeBuildInputs = [ + pkg-config + autoreconfHook + vala + gobject-introspection + gtk-doc + ]; - buildInputs = [ - glib dbus-glib + propagatedBuildInputs = { - "2" = libindicator-gtk2; - "3" = libindicator-gtk3; - }.${gtkVersion} or throwBadGtkVersion - ] ++ lib.optionals monoSupport [ - mono - { - "2" = gtk-sharp-2_0; - "3" = gtk-sharp-3_0; - }.${gtkVersion} or throwBadGtkVersion - ]; + "2" = [ + gtk2 + libdbusmenu-gtk2 + ]; + "3" = [ + gtk3 + libdbusmenu-gtk3 + ]; + } + .${gtkVersion} or throwBadGtkVersion; + + buildInputs = + [ + glib + dbus-glib + { + "2" = libindicator-gtk2; + "3" = libindicator-gtk3; + } + .${gtkVersion} or throwBadGtkVersion + ] + ++ lib.optionals monoSupport [ + mono + { + "2" = gtk-sharp-2_0; + "3" = gtk-sharp-3_0; + } + .${gtkVersion} or throwBadGtkVersion + ]; preAutoreconf = '' gtkdocize @@ -70,11 +109,16 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Library to allow applications to export a menu into the Unity Menu bar"; homepage = "https://launchpad.net/libappindicator"; - license = with licenses; [ lgpl21 lgpl3 ]; - pkgConfigModules = { - "2" = [ "appindicator-0.1" ]; - "3" = [ "appindicator3-0.1" ]; - }.${gtkVersion} or throwBadGtkVersion; + license = with licenses; [ + lgpl21 + lgpl3 + ]; + pkgConfigModules = + { + "2" = [ "appindicator-0.1" ]; + "3" = [ "appindicator3-0.1" ]; + } + .${gtkVersion} or throwBadGtkVersion; platforms = platforms.linux; maintainers = [ maintainers.msteen ]; # TODO: Resolve the issues with the Mono bindings. diff --git a/pkgs/by-name/li/libarchive/package.nix b/pkgs/by-name/li/libarchive/package.nix index 6ffa2b53144161..6b6c8771b1673e 100644 --- a/pkgs/by-name/li/libarchive/package.nix +++ b/pkgs/by-name/li/libarchive/package.nix @@ -1,31 +1,33 @@ -{ lib -, stdenv -, fetchFromGitHub -, acl -, attr -, autoreconfHook -, bzip2 -, e2fsprogs -, glibcLocalesUtf8 -, lzo -, openssl -, pkg-config -, sharutils -, xz -, zlib -, zstd -# Optional but increases closure only negligibly. Also, while libxml2 builds -# fine on windows, libarchive has trouble linking windows things it depends on -# for some reason. -, xarSupport ? stdenv.hostPlatform.isUnix, libxml2 - -# for passthru.tests -, cmake -, nix -, samba - -# for passthru.lore -, binlore +{ + lib, + stdenv, + fetchFromGitHub, + acl, + attr, + autoreconfHook, + bzip2, + e2fsprogs, + glibcLocalesUtf8, + lzo, + openssl, + pkg-config, + sharutils, + xz, + zlib, + zstd, + # Optional but increases closure only negligibly. Also, while libxml2 builds + # fine on windows, libarchive has trouble linking windows things it depends on + # for some reason. + xarSupport ? stdenv.hostPlatform.isUnix, + libxml2, + + # for passthru.tests + cmake, + nix, + samba, + + # for passthru.lore + binlore, }: assert xarSupport -> libxml2 != null; @@ -56,33 +58,41 @@ stdenv.mkDerivation (finalAttrs: { ./fix-pkg-config-iconv.patch ]; - outputs = [ "out" "lib" "dev" ]; - - postPatch = let - skipTestPaths = [ - # test won't work in nix sandbox - "libarchive/test/test_write_disk_perms.c" - # the filesystem does not necessarily have sparse capabilities - "libarchive/test/test_sparse_basic.c" - # the filesystem does not necessarily have hardlink capabilities - "libarchive/test/test_write_disk_hardlink.c" - # access-time-related tests flakey on some systems - "cpio/test/test_option_a.c" - "cpio/test/test_option_t.c" - ] ++ lib.optionals (stdenv.hostPlatform.isAarch64 && stdenv.hostPlatform.isLinux) [ - # only on some aarch64-linux systems? - "cpio/test/test_basic.c" - "cpio/test/test_format_newc.c" - ]; - removeTest = testPath: '' - substituteInPlace Makefile.am --replace-fail "${testPath}" "" - rm "${testPath}" - ''; - in '' - substituteInPlace Makefile.am --replace-fail '/bin/pwd' "$(type -P pwd)" + outputs = [ + "out" + "lib" + "dev" + ]; - ${lib.concatStringsSep "\n" (map removeTest skipTestPaths)} - ''; + postPatch = + let + skipTestPaths = + [ + # test won't work in nix sandbox + "libarchive/test/test_write_disk_perms.c" + # the filesystem does not necessarily have sparse capabilities + "libarchive/test/test_sparse_basic.c" + # the filesystem does not necessarily have hardlink capabilities + "libarchive/test/test_write_disk_hardlink.c" + # access-time-related tests flakey on some systems + "cpio/test/test_option_a.c" + "cpio/test/test_option_t.c" + ] + ++ lib.optionals (stdenv.hostPlatform.isAarch64 && stdenv.hostPlatform.isLinux) [ + # only on some aarch64-linux systems? + "cpio/test/test_basic.c" + "cpio/test/test_format_newc.c" + ]; + removeTest = testPath: '' + substituteInPlace Makefile.am --replace-fail "${testPath}" "" + rm "${testPath}" + ''; + in + '' + substituteInPlace Makefile.am --replace-fail '/bin/pwd' "$(type -P pwd)" + + ${lib.concatStringsSep "\n" (map removeTest skipTestPaths)} + ''; nativeBuildInputs = [ autoreconfHook @@ -90,19 +100,28 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - bzip2 - lzo - openssl - xz - zlib - zstd - ] ++ lib.optional stdenv.hostPlatform.isUnix sharutils - ++ lib.optionals stdenv.hostPlatform.isLinux [ acl attr e2fsprogs ] + buildInputs = + [ + bzip2 + lzo + openssl + xz + zlib + zstd + ] + ++ lib.optional stdenv.hostPlatform.isUnix sharutils + ++ lib.optionals stdenv.hostPlatform.isLinux [ + acl + attr + e2fsprogs + ] ++ lib.optional xarSupport libxml2; # Without this, pkg-config-based dependencies are unhappy - propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ attr acl ]; + propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ + attr + acl + ]; configureFlags = lib.optional (!xarSupport) "--without-xml2"; diff --git a/pkgs/by-name/li/libargon2/package.nix b/pkgs/by-name/li/libargon2/package.nix index ccd8166ca4f0d1..ca9049503dc7d2 100644 --- a/pkgs/by-name/li/libargon2/package.nix +++ b/pkgs/by-name/li/libargon2/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, fixDarwinDylibNames }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + fixDarwinDylibNames, +}: stdenv.mkDerivation rec { pname = "libargon2"; @@ -23,15 +29,17 @@ stdenv.mkDerivation rec { }) ]; - makeFlags = [ - "AR=${stdenv.cc.targetPrefix}ar" # Fix cross-compilation - "PREFIX=${placeholder "out"}" - "ARGON2_VERSION=${version}" - "LIBRARY_REL=lib" - "PKGCONFIG_REL=lib" - ] ++ lib.optionals stdenv.hostPlatform.isStatic [ - "LIBRARIES=$(LIB_ST)" - ]; + makeFlags = + [ + "AR=${stdenv.cc.targetPrefix}ar" # Fix cross-compilation + "PREFIX=${placeholder "out"}" + "ARGON2_VERSION=${version}" + "LIBRARY_REL=lib" + "PKGCONFIG_REL=lib" + ] + ++ lib.optionals stdenv.hostPlatform.isStatic [ + "LIBRARIES=$(LIB_ST)" + ]; meta = with lib; { description = "Key derivation function that was selected as the winner of the Password Hashing Competition in July 2015"; @@ -43,8 +51,14 @@ stdenv.mkDerivation rec { recommends using Argon2 rather than legacy algorithms. ''; homepage = "https://www.argon2.com/"; - license = with licenses; [ asl20 cc0 ]; - maintainers = with maintainers; [ taeer olynch ]; + license = with licenses; [ + asl20 + cc0 + ]; + maintainers = with maintainers; [ + taeer + olynch + ]; mainProgram = "argon2"; platforms = platforms.all; }; diff --git a/pkgs/by-name/li/libargs/package.nix b/pkgs/by-name/li/libargs/package.nix index 227afc0eb1f836..e9900a4e4114e8 100644 --- a/pkgs/by-name/li/libargs/package.nix +++ b/pkgs/by-name/li/libargs/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "args"; diff --git a/pkgs/by-name/li/libaribcaption/package.nix b/pkgs/by-name/li/libaribcaption/package.nix index 936991ef6a875a..353f31c0e12845 100644 --- a/pkgs/by-name/li/libaribcaption/package.nix +++ b/pkgs/by-name/li/libaribcaption/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake - -, fontconfig -, freetype - -, ApplicationServices -, CoreFoundation -, CoreGraphics -, CoreText +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + + fontconfig, + freetype, + + ApplicationServices, + CoreFoundation, + CoreGraphics, + CoreText, }: stdenv.mkDerivation rec { @@ -27,15 +28,17 @@ stdenv.mkDerivation rec { cmakeFlags = [ "-DBUILD_SHARED_LIBS=ON" ]; - buildInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ - fontconfig - freetype - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ApplicationServices - CoreFoundation - CoreGraphics - CoreText - ]; + buildInputs = + lib.optionals (!stdenv.hostPlatform.isDarwin) [ + fontconfig + freetype + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ApplicationServices + CoreFoundation + CoreGraphics + CoreText + ]; meta = with lib; { description = "Portable ARIB STD-B24 Caption Decoder/Renderer"; diff --git a/pkgs/by-name/li/libasr/package.nix b/pkgs/by-name/li/libasr/package.nix index 8d5b6d128ddf36..7dccc5058e28e4 100644 --- a/pkgs/by-name/li/libasr/package.nix +++ b/pkgs/by-name/li/libasr/package.nix @@ -1,15 +1,24 @@ -{ lib, stdenv, fetchurl, libevent, openssl }: +{ + lib, + stdenv, + fetchurl, + libevent, + openssl, +}: stdenv.mkDerivation rec { pname = "libasr"; - version= "1.0.4"; + version = "1.0.4"; src = fetchurl { url = "https://www.opensmtpd.org/archives/${pname}-${version}.tar.gz"; sha256 = "1d6s8njqhvayx2gp47409sp1fn8m608ws26hr1srfp6i23nnpyqr"; }; - buildInputs = [ libevent openssl ]; + buildInputs = [ + libevent + openssl + ]; meta = with lib; { homepage = "https://github.com/OpenSMTPD/libasr"; diff --git a/pkgs/by-name/li/libassuan/package.nix b/pkgs/by-name/li/libassuan/package.nix index 9998bfdceb7bfc..25cd5a2ed485c0 100644 --- a/pkgs/by-name/li/libassuan/package.nix +++ b/pkgs/by-name/li/libassuan/package.nix @@ -1,4 +1,13 @@ -{ fetchurl, lib, stdenv, gettext, npth, libgpg-error, buildPackages, gitUpdater }: +{ + fetchurl, + lib, + stdenv, + gettext, + npth, + libgpg-error, + buildPackages, + gitUpdater, +}: stdenv.mkDerivation rec { pname = "libassuan"; @@ -9,11 +18,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-AQMIH/wng4ouUEeRU8oQXoc9PWXYqVkygunJTH5q+3Y="; }; - outputs = [ "out" "dev" "info" ]; + outputs = [ + "out" + "dev" + "info" + ]; outputBin = "dev"; # libassuan-config depsBuildBuild = [ buildPackages.stdenv.cc ]; - buildInputs = [ npth gettext ]; + buildInputs = [ + npth + gettext + ]; configureFlags = [ # Required for cross-compilation. diff --git a/pkgs/by-name/li/libast/package.nix b/pkgs/by-name/li/libast/package.nix index ae6f6e17445f50..c7bbce07f11983 100644 --- a/pkgs/by-name/li/libast/package.nix +++ b/pkgs/by-name/li/libast/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libasyncns/package.nix b/pkgs/by-name/li/libasyncns/package.nix index 77c998f4216b7b..a13e3733ff96b5 100644 --- a/pkgs/by-name/li/libasyncns/package.nix +++ b/pkgs/by-name/li/libasyncns/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libasyncns"; diff --git a/pkgs/by-name/li/libatasmart/package.nix b/pkgs/by-name/li/libatasmart/package.nix index d5be78e913b7a0..c3e5c301b37c05 100644 --- a/pkgs/by-name/li/libatasmart/package.nix +++ b/pkgs/by-name/li/libatasmart/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, udev, buildPackages }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + udev, + buildPackages, +}: stdenv.mkDerivation rec { pname = "libatasmart"; diff --git a/pkgs/by-name/li/libation/deps.nix b/pkgs/by-name/li/libation/deps.nix index 998aaa73b9ae27..8be16ac27ce00a 100644 --- a/pkgs/by-name/li/libation/deps.nix +++ b/pkgs/by-name/li/libation/deps.nix @@ -1,224 +1,1101 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "AAXClean"; version = "1.1.2"; hash = "sha256-Abgf22iixOsF1VnVfbutYPtPuUonq0G+aSynhOMLtkM="; }) - (fetchNuGet { pname = "AAXClean.Codecs"; version = "1.1.3"; hash = "sha256-SPbynIf6vtDfnfTWcfpn7WiwKHD15CogCIEyTTVMEkM="; }) - (fetchNuGet { pname = "AudibleApi"; version = "9.2.0.1"; hash = "sha256-2NcRx+2sBLQDmXA+lLFnpGj9/IzyxYnvE5doQP9oCQ8="; }) - (fetchNuGet { pname = "Avalonia"; version = "11.0.5"; hash = "sha256-BqpHqQIObTb7DHTyZAgCD9A5I0pZkHhSoPTN2g6/G9E="; }) - (fetchNuGet { pname = "Avalonia.Angle.Windows.Natives"; version = "2.1.0.2023020321"; hash = "sha256-TWop9cvak6cMv2vrA/GlpuYBxS8Fuj5UmupGIV7Q5Ks="; }) - (fetchNuGet { pname = "Avalonia.BuildServices"; version = "0.0.29"; hash = "sha256-WPHRMNowRnYSCh88DWNBCltWsLPyOfzXGzBqLYE7tRY="; }) - (fetchNuGet { pname = "Avalonia.Controls.ColorPicker"; version = "11.0.5"; hash = "sha256-Iob8OyWhwXhmHKCdnea7dtL9VQvcrf6/gUGHJ30CKXA="; }) - (fetchNuGet { pname = "Avalonia.Controls.DataGrid"; version = "11.0.5"; hash = "sha256-2iVuMPRw7sbsYPGSG4XjQFGFky5WB5B05Jh1+I852ZI="; }) - (fetchNuGet { pname = "Avalonia.Controls.ItemsRepeater"; version = "11.0.5"; hash = "sha256-e/PyjYtJx0TFPSYS/jLBG7HC2x7o4qJ3NR2T+xchV0w="; }) - (fetchNuGet { pname = "Avalonia.Desktop"; version = "11.0.5"; hash = "sha256-UKVibxhJoGNvEGh8J/Z0sq8J81FT8yth/yXVPSFHF/8="; }) - (fetchNuGet { pname = "Avalonia.Diagnostics"; version = "11.0.5"; hash = "sha256-0cUxPYJP2W11wnM6j4qNB3IvHlsUp9EZlY8I/NoAmd4="; }) - (fetchNuGet { pname = "Avalonia.FreeDesktop"; version = "11.0.5"; hash = "sha256-O20fC/9YXO3/MZNlh1EgWLHFSyi/ao083MKwjetgxmo="; }) - (fetchNuGet { pname = "Avalonia.Native"; version = "11.0.5"; hash = "sha256-KVUAXXT+f4VrtJ8widfEIzN25GBbtXWog/tpM354gdg="; }) - (fetchNuGet { pname = "Avalonia.ReactiveUI"; version = "11.0.5"; hash = "sha256-8tGLyA0PRKt1REb9YeCtEDz5oB886PRG35aO0uZm/jU="; }) - (fetchNuGet { pname = "Avalonia.Remote.Protocol"; version = "11.0.5"; hash = "sha256-wTqdxPU3Ql7jC4JFkChbUfaRR0nqUKrYKn8oexdFyig="; }) - (fetchNuGet { pname = "Avalonia.Skia"; version = "11.0.5"; hash = "sha256-rKOgkNLCwEVVcyLCimvhDUDKXnrDOguUryaGVOPFFwE="; }) - (fetchNuGet { pname = "Avalonia.Themes.Fluent"; version = "11.0.5"; hash = "sha256-ETOaNvRzTAC0uEVVB3noiyYM9N9nPrPnMwCqiFgID/4="; }) - (fetchNuGet { pname = "Avalonia.Themes.Simple"; version = "11.0.5"; hash = "sha256-27evmgSrIx+EopF6E3N1cT7BvAUc/s99TVEMfmG83cQ="; }) - (fetchNuGet { pname = "Avalonia.Win32"; version = "11.0.5"; hash = "sha256-ncZLGKhpfjuuVPz4Fs+P6L3dM0KRnwAC3xJRqyvpKw8="; }) - (fetchNuGet { pname = "Avalonia.X11"; version = "11.0.5"; hash = "sha256-rvs3hwRh3F5E1j3JqcodWJTHV3BTWMKkvzq170tuPa4="; }) - (fetchNuGet { pname = "BouncyCastle.Cryptography"; version = "2.3.0"; hash = "sha256-TIBOegJAEfFRyvtwuPakvKsQbqoPHj1RSTmK7SKYsf0="; }) - (fetchNuGet { pname = "CommandLineParser"; version = "2.9.1"; hash = "sha256-ApU9y1yX60daSjPk3KYDBeJ7XZByKW8hse9NRZGcjeo="; }) - (fetchNuGet { pname = "CsvHelper"; version = "33.0.1"; hash = "sha256-4MwA/WerpI0VYWiaEudNCNnE1v6/k2tPmLbRjmgijV4="; }) - (fetchNuGet { pname = "Dinah.Core"; version = "8.0.0.1"; hash = "sha256-jYAaIqv67DOl+l+i92QmV7TM3YXL250D8XUZ7dZh1s0="; }) - (fetchNuGet { pname = "Dinah.EntityFrameworkCore"; version = "8.0.0.1"; hash = "sha256-xTKKCBE2KfXqUaRMZqgohQmUi51GrWvaIWTW66nRRYQ="; }) - (fetchNuGet { pname = "DynamicData"; version = "7.9.5"; hash = "sha256-3XjOMuFathku9oWyss360+Ze5UMP7tSmUbMoax7qONU="; }) - (fetchNuGet { pname = "Enums.NET"; version = "4.0.1"; hash = "sha256-ZTWgmbLlOvF9rKQAa4cwPBA0NLZhZ0rwrgZtg/RuJY8="; }) - (fetchNuGet { pname = "ExtendedNumerics.BigDecimal"; version = "2023.1000.0.230"; hash = "sha256-THVfKgtJoier9RfJamO1a+F1ufVRSWoMw+0lerxxdC8="; }) - (fetchNuGet { pname = "HarfBuzzSharp"; version = "2.8.2.3"; hash = "sha256-4tbdgUabPjlkBm3aUFeocj4Fdslmms2olDFpzOLyqoQ="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Linux"; version = "2.8.2.3"; hash = "sha256-3xwVfNfKTkuLdnT+e3bfG9tNTdEmar7ByzY+NTlUKLg="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.macOS"; version = "2.8.2.3"; hash = "sha256-ZohUEaovj/sRB4rjuJIOq6S9eim3m+qMlpHIebNDTRQ="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; version = "2.8.2.3"; hash = "sha256-ZsiBGpXfODHUHPgU/50k9QR/j6Klo7rsB0SUt8zYcBA="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Win32"; version = "2.8.2.3"; hash = "sha256-5GSzM5IUoOwK+zJg0d74WlT3n1VZly8pKlyjiqVocCI="; }) - (fetchNuGet { pname = "HtmlAgilityPack"; version = "1.11.54"; hash = "sha256-Cl3l5H5qYOn6fEzX9cl1eMn43l7C13a+tBOAVD1oGp0="; }) - (fetchNuGet { pname = "Humanizer.Core"; version = "2.14.1"; hash = "sha256-EXvojddPu+9JKgOG9NSQgUTfWq1RpOYw7adxDPKDJ6o="; }) - (fetchNuGet { pname = "LuceneNet303r2"; version = "3.0.3.8"; hash = "sha256-mHfa5OzVff2q5MIgefih9Y269qQKe7It/6G4IwT2Meg="; }) - (fetchNuGet { pname = "MathNet.Numerics.Signed"; version = "5.0.0"; hash = "sha256-76y1jaL+abqoyP3K4n9phF1S1hTpylkw//vTHukROUc="; }) - (fetchNuGet { pname = "MicroCom.Runtime"; version = "0.11.0"; hash = "sha256-VdwpP5fsclvNqJuppaOvwEwv2ofnAI5ZSz2V+UEdLF0="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "6.0.0"; hash = "sha256-49+H/iFwp+AfCICvWcqo9us4CzxApPKC37Q5Eqrw+JU="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.0.0"; hash = "sha256-KDbCfsBWSJ5ohEXUKp1s1LX9xA2NPvXE/xVzj68EdC0="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.3.3"; hash = "sha256-pkZiggwLw8k+CVSXKTzsVGsT+K49LxXUS3VH5PNlpCY="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "3.8.0"; hash = "sha256-3G9vSc/gHH7FWgOySLTut1+eEaf3H66qcPOvNPLOx4o="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "4.5.0"; hash = "sha256-qo1oVNTB9JIMEPoiIZ+02qvF/O8PshQ/5gTjsY9iX0I="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "3.8.0"; hash = "sha256-i/r3V/No/VzqmJlWxpGoirvlbJDbBPa/ONZtzYrxuc4="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "4.5.0"; hash = "sha256-5dZTS9PYtY83vyVa5bdNG3XKV5EjcnmddfUqWmIE29A="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.Scripting"; version = "3.8.0"; hash = "sha256-fA9Qu+vTyMZ9REzxJ4aMg/SHCDRk4q9k4ZGUdynoHnA="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.Workspaces"; version = "4.5.0"; hash = "sha256-Kmyt1Xfcs0rSZHvN9PH94CKAooqMS9abZQY7EpEqb2o="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Scripting.Common"; version = "3.8.0"; hash = "sha256-866jMHp8kbc1FYpKuUWnd7ViU6kGJTAxPcL/IjXrT0I="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Workspaces.Common"; version = "4.5.0"; hash = "sha256-WM7AXJYHagaPx2waj2E32gG0qXq6Kx4Zhiq7Ym3WXPI="; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.3.0"; hash = "sha256-a3dAiPaVuky0wpcHmpTVtAQJNGZ2v91/oArA+dpJgj8="; }) - (fetchNuGet { pname = "Microsoft.Data.Sqlite.Core"; version = "8.0.5"; hash = "sha256-PH+ZS45SGfWSFcYZA+V3m0k1r3kxaDzD3DutVVRyqfQ="; }) - (fetchNuGet { pname = "Microsoft.EntityFrameworkCore"; version = "8.0.0"; hash = "sha256-Z6dlgOQrYcSCcRaXPNnYLC87sg4OGRS+p4Tv3EFXFfY="; }) - (fetchNuGet { pname = "Microsoft.EntityFrameworkCore"; version = "8.0.5"; hash = "sha256-qR7Z+AQXzwejgYUKhoZIfYTWPOLNpOD6DBJ80xEfLaE="; }) - (fetchNuGet { pname = "Microsoft.EntityFrameworkCore.Abstractions"; version = "8.0.0"; hash = "sha256-QxPc73WzjE63Pzuxc/xr/uQc0C+v6xVd2N0iIUJKOQU="; }) - (fetchNuGet { pname = "Microsoft.EntityFrameworkCore.Abstractions"; version = "8.0.5"; hash = "sha256-2RyxdXMIc2Gzbc5ouEdbbrVDfTrCU8PP9zPYxlcQXpw="; }) - (fetchNuGet { pname = "Microsoft.EntityFrameworkCore.Analyzers"; version = "8.0.0"; hash = "sha256-SidpTl9AveYiXHa+TtvyHnRTOn02lmab4qXPf0FTi+0="; }) - (fetchNuGet { pname = "Microsoft.EntityFrameworkCore.Analyzers"; version = "8.0.5"; hash = "sha256-tvLA2TZouZC8pgxS8YikG2ui4Znaj6bNrVGAVy7t9rk="; }) - (fetchNuGet { pname = "Microsoft.EntityFrameworkCore.Design"; version = "8.0.5"; hash = "sha256-zwDnWBGVf6O+L2iqcwJ/e+gbg5A+hVLf8Tc3vIbl+cA="; }) - (fetchNuGet { pname = "Microsoft.EntityFrameworkCore.Relational"; version = "8.0.0"; hash = "sha256-ga+Qp4dZpmxVEmIIn8AcC92HrhVQBaDICyHqE87s+lk="; }) - (fetchNuGet { pname = "Microsoft.EntityFrameworkCore.Relational"; version = "8.0.5"; hash = "sha256-peIG9ZgXvvEB2wJ2QFxC3u+H8LnZ9xL/HIegw4R00Do="; }) - (fetchNuGet { pname = "Microsoft.EntityFrameworkCore.Sqlite"; version = "8.0.5"; hash = "sha256-lED2YXKz6PzYAC5iIXW957N74KUuYtJ9cKvoPFiebpk="; }) - (fetchNuGet { pname = "Microsoft.EntityFrameworkCore.Sqlite.Core"; version = "8.0.5"; hash = "sha256-+6AvDE+Fj0Oc7EfA4SXwFUdkOSvvX6jC5HPtbUhYQwE="; }) - (fetchNuGet { pname = "Microsoft.EntityFrameworkCore.Tools"; version = "8.0.5"; hash = "sha256-tHtuHXdI4d3CdL+2as595sys0phrBeZtWEof2Gd/A3I="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Caching.Abstractions"; version = "8.0.0"; hash = "sha256-xGpKrywQvU1Wm/WolYIxgHYEFfgkNGeJ+GGc5DT3phI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Caching.Memory"; version = "8.0.0"; hash = "sha256-RUQe2VgOATM9JkZ/wGm9mreKoCmOS4pPyvyJWBqMaC8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "8.0.0"; hash = "sha256-9BPsASlxrV8ilmMCjdb3TiUcm5vFZxkBnAI/fNBSEyA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "8.0.0"; hash = "sha256-4eBpDkf7MJozTZnOwQvwcfgRKQGcNXe0K/kF+h5Rl8o="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "8.0.0"; hash = "sha256-GanfInGzzoN2bKeNwON8/Hnamr6l7RTpYLA49CNXD9Q="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.FileExtensions"; version = "8.0.0"; hash = "sha256-BCxcjVP+kvrDDB0nzsFCJfU74UK4VBvct2JA4r+jNcs="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Json"; version = "8.0.0"; hash = "sha256-Fi/ijcG5l0BOu7i96xHu96aN5/g7zO6SWQbTsI3Qetg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "8.0.0"; hash = "sha256-+qIDR8hRzreCHNEDtUcPfVHQdurzWPo/mqviCH78+EQ="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.0"; hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyModel"; version = "8.0.0"; hash = "sha256-qkCdwemqdZY/yIW5Xmh7Exv74XuE39T8aHGHCofoVgo="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "8.0.0"; hash = "sha256-uQSXmt47X2HGoVniavjLICbPtD2ReQOYQMgy3l0xuMU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Physical"; version = "8.0.0"; hash = "sha256-29y5ZRQ1ZgzVOxHktYxyiH40kVgm5un2yTGdvuSWnRc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileSystemGlobbing"; version = "8.0.0"; hash = "sha256-+Oz41JR5jdcJlCJOSpQIL5OMBNi+1Hl2d0JUHfES7sU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "8.0.0"; hash = "sha256-Meh0Z0X7KyOEG4l0RWBcuHHihcABcvCyfUXgasmQ91o="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "8.0.0"; hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "8.0.0"; hash = "sha256-n2m4JSegQKUTlOsKLZUUHHKMq926eJ0w9N9G+I3FoFw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "8.0.0"; hash = "sha256-FU8qj3DR8bDdc1c+WeGZx/PCZeqqndweZM9epcpXjSo="; }) - (fetchNuGet { pname = "Microsoft.IO.RecyclableMemoryStream"; version = "3.0.0"; hash = "sha256-WBXkqxC5g4tJ481sa1uft39LqA/5hx5yOfiTfMRMg/4="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "2.1.2"; hash = "sha256-gYQQO7zsqG+OtN4ywYQyfsiggS2zmxw4+cPXlK+FB5Q="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "5.0.0"; hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; }) - (fetchNuGet { pname = "Microsoft.Win32.SystemEvents"; version = "6.0.0"; hash = "sha256-N9EVZbl5w1VnMywGXyaVWzT9lh84iaJ3aD48hIBk1zA="; }) - (fetchNuGet { pname = "Mono.TextTemplating"; version = "2.2.1"; hash = "sha256-4TYsfc8q74P8FuDwkIWPO+VYY0mh4Hs4ZL8v0lMaBsY="; }) - (fetchNuGet { pname = "NameParserSharp"; version = "1.5.0"; hash = "sha256-I0xUWObpeR9r867ef3SskvdyIWB7kpNI+Xy7X4l05eE="; }) - (fetchNuGet { pname = "NAudio.Core"; version = "2.2.1"; hash = "sha256-eUZF2/0w5IgGY9UtnZIk1VwwH6VCKP9iPJXVcseIc0c="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.3"; hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; }) - (fetchNuGet { pname = "NPOI"; version = "2.7.0"; hash = "sha256-zqns3HwLv8OQMyvw+LUtwqPbkAEIrVJU589AMNhnM4s="; }) - (fetchNuGet { pname = "Octokit"; version = "11.0.1"; hash = "sha256-24Ym/CXgU3LCFQcMHdFfWp8vUjLfwRcRIyW9fvr4i1s="; }) - (fetchNuGet { pname = "Pluralize.NET"; version = "1.0.2"; hash = "sha256-u/WHYDpSvGs6SkgPREm1RID4po6h8/fj2QgJal1TBwU="; }) - (fetchNuGet { pname = "Polly"; version = "8.4.1"; hash = "sha256-CPFw0j6f2P5LfcoFAHo1RRDnCx6SXnp8gzHnwYDnYhY="; }) - (fetchNuGet { pname = "Polly.Core"; version = "8.4.1"; hash = "sha256-EksA3U5cmsri2joM+SMtbdwOUMUVxIXT8DnH4DSAIpA="; }) - (fetchNuGet { pname = "ReactiveUI"; version = "18.3.1"; hash = "sha256-1rf4icGRKTR3XIWJpkQJCG7ObRM+72ITB5K+ND1is9M="; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; }) - (fetchNuGet { pname = "Serilog"; version = "2.10.0"; hash = "sha256-+8wilkt+VVvW+KFWuLryj7cSFpz9D+sz92KYWICAcSE="; }) - (fetchNuGet { pname = "Serilog"; version = "2.8.0"; hash = "sha256-MBL9AWGV8UthhiHXnqH3EsfIyXnxdLWqAdFa6QvQ2To="; }) - (fetchNuGet { pname = "Serilog"; version = "3.1.0"; hash = "sha256-1CDAp+AjfFjQqoLvKYp/j6pKTUfNOGfKVlWyqCGHo7k="; }) - (fetchNuGet { pname = "Serilog"; version = "3.1.1"; hash = "sha256-L263y8jkn7dNFD2jAUK6mgvyRTqFe39i1tRhVZsNZTI="; }) - (fetchNuGet { pname = "Serilog"; version = "4.0.0"; hash = "sha256-j8hQ5TdL1TjfdGiBO9PyHJFMMPvATHWN1dtrrUZZlNw="; }) - (fetchNuGet { pname = "Serilog.Exceptions"; version = "8.4.0"; hash = "sha256-2We6ZVAcFsEYVV7vVM+F1+4phHRqc7NeQZKbYDK0Gew="; }) - (fetchNuGet { pname = "Serilog.Settings.Configuration"; version = "8.0.0"; hash = "sha256-JQ39fvhOFSUHE6r9DXJvLaZI+Lk7AYzuskQu3ux+hQg="; }) - (fetchNuGet { pname = "Serilog.Sinks.Console"; version = "5.0.0"; hash = "sha256-UOVlegJLhs0vK1ml2DZCjFE5roDRZsGCAqD/53ZaZWI="; }) - (fetchNuGet { pname = "Serilog.Sinks.Console"; version = "6.0.0"; hash = "sha256-QH8ykDkLssJ99Fgl+ZBFBr+RQRl0wRTkeccQuuGLyro="; }) - (fetchNuGet { pname = "Serilog.Sinks.File"; version = "5.0.0"; hash = "sha256-GKy9hwOdlu2W0Rw8LiPyEwus+sDtSOTl8a5l9uqz+SQ="; }) - (fetchNuGet { pname = "Serilog.Sinks.File"; version = "6.0.0"; hash = "sha256-KQmlUpG9ovRpNqKhKe6rz3XMLUjkBqjyQhEm2hV5Sow="; }) - (fetchNuGet { pname = "Serilog.Sinks.ZipFile"; version = "3.1.1"; hash = "sha256-W4oXuOZF+Ic6rKma2PkmKW5O7GvuzooNsiB17p5H6lQ="; }) - (fetchNuGet { pname = "SharpZipLib"; version = "1.3.3"; hash = "sha256-HWEQTKh9Ktwg/zIl079dAiH+ob2ShWFAqLgG6XgIMr4="; }) - (fetchNuGet { pname = "SixLabors.Fonts"; version = "1.0.1"; hash = "sha256-fox6f9Z5xunVXiy71KTSkb0DirMN00tuUlChyp96kiI="; }) - (fetchNuGet { pname = "SixLabors.ImageSharp"; version = "2.1.7"; hash = "sha256-CPC3x2vPfjv8ZLyxnQ8uuNhlsUMrIE/+hdYP0dZGLR8="; }) - (fetchNuGet { pname = "SixLabors.ImageSharp"; version = "3.1.5"; hash = "sha256-3UehX9T+I81nfgv2dTHlpoPgYzXFk7kHr1mmlQOCBfw="; }) - (fetchNuGet { pname = "SkiaSharp"; version = "2.88.6"; hash = "sha256-y0wzgwdQXtgl5boCz/EgLWbK3SwC0cFVRUbBxOUPQXc="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Linux"; version = "2.88.6"; hash = "sha256-VjgGoi73tVvqO/UXmQb1w9ioAbFu2dxH8oHz1l5H4zE="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.macOS"; version = "2.88.6"; hash = "sha256-7hOMjlYTOiNPLNwfLFUjTcdgiGEtmYUI1EubiRiC6bo="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.WebAssembly"; version = "2.88.6"; hash = "sha256-CIb9fHVgHwIa0R1WafKJ3+GqtDHHRgDohA3ayTHvlws="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Win32"; version = "2.88.6"; hash = "sha256-ljD4QmAO2/vwA6I8GIUNkONpOzmGsOVJJy9vPDnjVfA="; }) - (fetchNuGet { pname = "Splat"; version = "14.4.1"; hash = "sha256-i1yzIVpKdFjZMI4J8H970nZCxszklgDitYTEKKz0zA8="; }) - (fetchNuGet { pname = "SQLitePCLRaw.bundle_e_sqlite3"; version = "2.1.6"; hash = "sha256-dZD/bZsYXjOu46ZH5Y/wgh0uhHOqIxC+S+0ecKhr718="; }) - (fetchNuGet { pname = "SQLitePCLRaw.core"; version = "2.1.6"; hash = "sha256-RxWjm52PdmMV98dgDy0BCpF988+BssRZUgALLv7TH/E="; }) - (fetchNuGet { pname = "SQLitePCLRaw.lib.e_sqlite3"; version = "2.1.6"; hash = "sha256-uHt5d+SFUkSd6WD7Tg0J3e8eVoxy/FM/t4PAkc9PJT0="; }) - (fetchNuGet { pname = "SQLitePCLRaw.provider.e_sqlite3"; version = "2.1.6"; hash = "sha256-zHc/YZsd72eXlI8ba1tv58HZWUIiyjJaxq2CCP1hQe8="; }) - (fetchNuGet { pname = "System.CodeDom"; version = "4.4.0"; hash = "sha256-L1xyspJ8pDJNVPYKl+FMGf4Zwm0tlqtAyQCNW6pT6/0="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "5.0.0"; hash = "sha256-GdwSIjLMM0uVfE56VUSLVNgpW0B//oCeSFj8/hSlbM8="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "6.0.0"; hash = "sha256-DKEbpFqXCIEfqp9p3ezqadn5b/S1YTk32/EQK+tEScs="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "8.0.0"; hash = "sha256-F7OVjKNwpqbUh8lTidbqJWYi476nsq9n+6k0+QVRo3w="; }) - (fetchNuGet { pname = "System.Collections.NonGeneric"; version = "4.3.0"; hash = "sha256-8/yZmD4jjvq7m68SPkJZLBQ79jOTOyT5lyzX4SCYAx8="; }) - (fetchNuGet { pname = "System.ComponentModel.Annotations"; version = "4.5.0"; hash = "sha256-15yE2NoT9vmL9oGCaxHClQR1jLW1j1ef5hHMg55xRso="; }) - (fetchNuGet { pname = "System.Composition"; version = "6.0.0"; hash = "sha256-H5TnnxOwihI0VyRuykbOWuKFSCWNN+MUEYyloa328Nw="; }) - (fetchNuGet { pname = "System.Composition.AttributedModel"; version = "6.0.0"; hash = "sha256-03DR8ecEHSKfgzwuTuxtsRW0Gb7aQtDS4LAYChZdGdc="; }) - (fetchNuGet { pname = "System.Composition.Convention"; version = "6.0.0"; hash = "sha256-a3DZS8CT2kV8dVpGxHKoP5wHVKsT+kiPJixckpYfdQo="; }) - (fetchNuGet { pname = "System.Composition.Hosting"; version = "6.0.0"; hash = "sha256-fpoh6WBNmaHEHszwlBR/TNjd85lwesfM7ZkQhqYtLy4="; }) - (fetchNuGet { pname = "System.Composition.Runtime"; version = "6.0.0"; hash = "sha256-nGZvg2xYhhazAjOjhWqltBue+hROKP0IOiFGP8yMBW8="; }) - (fetchNuGet { pname = "System.Composition.TypedParts"; version = "6.0.0"; hash = "sha256-4uAETfmL1CvGjHajzWowsEmJgTKnuFC8u9lbYPzAN3k="; }) - (fetchNuGet { pname = "System.Configuration.ConfigurationManager"; version = "6.0.0"; hash = "sha256-fPV668Cfi+8pNWrvGAarF4fewdPVEDwlJWvJk0y+Cms="; }) - (fetchNuGet { pname = "System.Configuration.ConfigurationManager"; version = "8.0.0"; hash = "sha256-xhljqSkNQk8DMkEOBSYnn9lzCSEDDq4yO910itptqiE="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; }) - (fetchNuGet { pname = "System.Diagnostics.EventLog"; version = "8.0.0"; hash = "sha256-rt8xc3kddpQY4HEdghlBeOK4gdw5yIj4mcZhAVtk2/Y="; }) - (fetchNuGet { pname = "System.Drawing.Common"; version = "6.0.0"; hash = "sha256-/9EaAbEeOjELRSMZaImS1O8FmUe8j4WuFUw1VOrPyAo="; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.3.0"; hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; }) - (fetchNuGet { pname = "System.Formats.Asn1"; version = "6.0.0"; hash = "sha256-KaMHgIRBF7Nf3VwOo+gJS1DcD+41cJDPWFh+TDQ8ee8="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "6.0.0"; hash = "sha256-xfjF4UqTMJpf8KsBWUyJlJkzPTOO/H5MW023yTYNQSA="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "6.0.3"; hash = "sha256-v+FOmjRRKlDtDW6+TfmyMiiki010YGVTa0EwXu9X7ck="; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.3.0"; hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.3"; hash = "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.3.0"; hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; }) - (fetchNuGet { pname = "System.Reactive"; version = "5.0.0"; hash = "sha256-M5Z8pw8rVb8ilbnTdaOptzk5VFd5DlKa7zzCpuytTtE="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.3.0"; hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.3.0"; hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.3.0"; hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "5.0.0"; hash = "sha256-Wo+MiqhcP9dQ6NuFGrQTw6hpbJORFwp+TBNTq2yhGp8="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "6.0.1"; hash = "sha256-id27sU4qIEIpgKenO5b4IHt6L1XuNsVe4TR9TKaLWDo="; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.3.0"; hash = "sha256-4U4/XNQAnddgQIHIJq3P2T80hN0oPdU2uCeghsDTWng="; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.7.0"; hash = "sha256-GEtCGXwtOnkYejSV+Tfl+DqyGq5jTUaVyL9eMupMHBM="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.7.1"; hash = "sha256-UvyoDV8O0oY3HPG1GbA56YVdvwTGEfjYR5gW1O7IK4U="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "5.0.0"; hash = "sha256-neARSpLPUzPxEKhJRwoBzhPxK+cKIitLx7WBYncsYgo="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "6.0.0"; hash = "sha256-qOyWEBbNr3EjyS+etFG8/zMbuPjA+O+di717JP9Cxyg="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Pkcs"; version = "6.0.3"; hash = "sha256-p5xbSMTjndPCht9HRbDp5fr1osUOaXunjDZUatualgs="; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "6.0.0"; hash = "sha256-Wi9I9NbZlpQDXgS7Kl06RIFxY/9674S7hKiYw5EabRY="; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "8.0.0"; hash = "sha256-fb0pa9sQxN+mr0vnXg1Igbx49CaOqS+GDkTfWNboUvs="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Xml"; version = "6.0.1"; hash = "sha256-spXV8cWZu0V3liek1936REtdpvS4fQwc98JvacO1oJU="; }) - (fetchNuGet { pname = "System.Security.Permissions"; version = "6.0.0"; hash = "sha256-/MMvtFWGN/vOQfjXdOhet1gsnMgh6lh5DCHimVsnVEs="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; }) - (fetchNuGet { pname = "System.ServiceProcess.ServiceController"; version = "8.0.0"; hash = "sha256-mq/Qm8JeMUvitHf32/F8uvw1YJGx4prGnEI/VzdaFAI="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "4.5.1"; hash = "sha256-PIhkv59IXjyiuefdhKxS9hQfEwO9YWRuNudpo53HQfw="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "5.0.0"; hash = "sha256-YJ5jJqkVPp+6fEzSXOmw1sNSdygB5Rx7TJ0TrNS/wq4="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "6.0.0"; hash = "sha256-nGc2A6XYnwqGcq8rfgTRjGr+voISxNe/76k2K36coj4="; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "8.0.0"; hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; }) - (fetchNuGet { pname = "System.Text.Json"; version = "8.0.0"; hash = "sha256-XFcCHMW1u2/WujlWNHaIWkbW1wn8W4kI0QdrwPtWmow="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; }) - (fetchNuGet { pname = "System.Threading.Channels"; version = "6.0.0"; hash = "sha256-klGYnsyrjvXaGeqgfnMf/dTAMNtcHY+zM4Xh6v2JfuE="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; }) - (fetchNuGet { pname = "System.Windows.Extensions"; version = "6.0.0"; hash = "sha256-N+qg1E6FDJ9A9L50wmVt3xPQV8ZxlG1xeXgFuxO+yfM="; }) - (fetchNuGet { pname = "Tmds.DBus.Protocol"; version = "0.15.0"; hash = "sha256-4gk2vXDjKFaBh82gTkwg3c/5GRjiH+bvM5elfDSbKTU="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "AAXClean"; + version = "1.1.2"; + hash = "sha256-Abgf22iixOsF1VnVfbutYPtPuUonq0G+aSynhOMLtkM="; + }) + (fetchNuGet { + pname = "AAXClean.Codecs"; + version = "1.1.3"; + hash = "sha256-SPbynIf6vtDfnfTWcfpn7WiwKHD15CogCIEyTTVMEkM="; + }) + (fetchNuGet { + pname = "AudibleApi"; + version = "9.2.0.1"; + hash = "sha256-2NcRx+2sBLQDmXA+lLFnpGj9/IzyxYnvE5doQP9oCQ8="; + }) + (fetchNuGet { + pname = "Avalonia"; + version = "11.0.5"; + hash = "sha256-BqpHqQIObTb7DHTyZAgCD9A5I0pZkHhSoPTN2g6/G9E="; + }) + (fetchNuGet { + pname = "Avalonia.Angle.Windows.Natives"; + version = "2.1.0.2023020321"; + hash = "sha256-TWop9cvak6cMv2vrA/GlpuYBxS8Fuj5UmupGIV7Q5Ks="; + }) + (fetchNuGet { + pname = "Avalonia.BuildServices"; + version = "0.0.29"; + hash = "sha256-WPHRMNowRnYSCh88DWNBCltWsLPyOfzXGzBqLYE7tRY="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.ColorPicker"; + version = "11.0.5"; + hash = "sha256-Iob8OyWhwXhmHKCdnea7dtL9VQvcrf6/gUGHJ30CKXA="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.DataGrid"; + version = "11.0.5"; + hash = "sha256-2iVuMPRw7sbsYPGSG4XjQFGFky5WB5B05Jh1+I852ZI="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.ItemsRepeater"; + version = "11.0.5"; + hash = "sha256-e/PyjYtJx0TFPSYS/jLBG7HC2x7o4qJ3NR2T+xchV0w="; + }) + (fetchNuGet { + pname = "Avalonia.Desktop"; + version = "11.0.5"; + hash = "sha256-UKVibxhJoGNvEGh8J/Z0sq8J81FT8yth/yXVPSFHF/8="; + }) + (fetchNuGet { + pname = "Avalonia.Diagnostics"; + version = "11.0.5"; + hash = "sha256-0cUxPYJP2W11wnM6j4qNB3IvHlsUp9EZlY8I/NoAmd4="; + }) + (fetchNuGet { + pname = "Avalonia.FreeDesktop"; + version = "11.0.5"; + hash = "sha256-O20fC/9YXO3/MZNlh1EgWLHFSyi/ao083MKwjetgxmo="; + }) + (fetchNuGet { + pname = "Avalonia.Native"; + version = "11.0.5"; + hash = "sha256-KVUAXXT+f4VrtJ8widfEIzN25GBbtXWog/tpM354gdg="; + }) + (fetchNuGet { + pname = "Avalonia.ReactiveUI"; + version = "11.0.5"; + hash = "sha256-8tGLyA0PRKt1REb9YeCtEDz5oB886PRG35aO0uZm/jU="; + }) + (fetchNuGet { + pname = "Avalonia.Remote.Protocol"; + version = "11.0.5"; + hash = "sha256-wTqdxPU3Ql7jC4JFkChbUfaRR0nqUKrYKn8oexdFyig="; + }) + (fetchNuGet { + pname = "Avalonia.Skia"; + version = "11.0.5"; + hash = "sha256-rKOgkNLCwEVVcyLCimvhDUDKXnrDOguUryaGVOPFFwE="; + }) + (fetchNuGet { + pname = "Avalonia.Themes.Fluent"; + version = "11.0.5"; + hash = "sha256-ETOaNvRzTAC0uEVVB3noiyYM9N9nPrPnMwCqiFgID/4="; + }) + (fetchNuGet { + pname = "Avalonia.Themes.Simple"; + version = "11.0.5"; + hash = "sha256-27evmgSrIx+EopF6E3N1cT7BvAUc/s99TVEMfmG83cQ="; + }) + (fetchNuGet { + pname = "Avalonia.Win32"; + version = "11.0.5"; + hash = "sha256-ncZLGKhpfjuuVPz4Fs+P6L3dM0KRnwAC3xJRqyvpKw8="; + }) + (fetchNuGet { + pname = "Avalonia.X11"; + version = "11.0.5"; + hash = "sha256-rvs3hwRh3F5E1j3JqcodWJTHV3BTWMKkvzq170tuPa4="; + }) + (fetchNuGet { + pname = "BouncyCastle.Cryptography"; + version = "2.3.0"; + hash = "sha256-TIBOegJAEfFRyvtwuPakvKsQbqoPHj1RSTmK7SKYsf0="; + }) + (fetchNuGet { + pname = "CommandLineParser"; + version = "2.9.1"; + hash = "sha256-ApU9y1yX60daSjPk3KYDBeJ7XZByKW8hse9NRZGcjeo="; + }) + (fetchNuGet { + pname = "CsvHelper"; + version = "33.0.1"; + hash = "sha256-4MwA/WerpI0VYWiaEudNCNnE1v6/k2tPmLbRjmgijV4="; + }) + (fetchNuGet { + pname = "Dinah.Core"; + version = "8.0.0.1"; + hash = "sha256-jYAaIqv67DOl+l+i92QmV7TM3YXL250D8XUZ7dZh1s0="; + }) + (fetchNuGet { + pname = "Dinah.EntityFrameworkCore"; + version = "8.0.0.1"; + hash = "sha256-xTKKCBE2KfXqUaRMZqgohQmUi51GrWvaIWTW66nRRYQ="; + }) + (fetchNuGet { + pname = "DynamicData"; + version = "7.9.5"; + hash = "sha256-3XjOMuFathku9oWyss360+Ze5UMP7tSmUbMoax7qONU="; + }) + (fetchNuGet { + pname = "Enums.NET"; + version = "4.0.1"; + hash = "sha256-ZTWgmbLlOvF9rKQAa4cwPBA0NLZhZ0rwrgZtg/RuJY8="; + }) + (fetchNuGet { + pname = "ExtendedNumerics.BigDecimal"; + version = "2023.1000.0.230"; + hash = "sha256-THVfKgtJoier9RfJamO1a+F1ufVRSWoMw+0lerxxdC8="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp"; + version = "2.8.2.3"; + hash = "sha256-4tbdgUabPjlkBm3aUFeocj4Fdslmms2olDFpzOLyqoQ="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Linux"; + version = "2.8.2.3"; + hash = "sha256-3xwVfNfKTkuLdnT+e3bfG9tNTdEmar7ByzY+NTlUKLg="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.macOS"; + version = "2.8.2.3"; + hash = "sha256-ZohUEaovj/sRB4rjuJIOq6S9eim3m+qMlpHIebNDTRQ="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; + version = "2.8.2.3"; + hash = "sha256-ZsiBGpXfODHUHPgU/50k9QR/j6Klo7rsB0SUt8zYcBA="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Win32"; + version = "2.8.2.3"; + hash = "sha256-5GSzM5IUoOwK+zJg0d74WlT3n1VZly8pKlyjiqVocCI="; + }) + (fetchNuGet { + pname = "HtmlAgilityPack"; + version = "1.11.54"; + hash = "sha256-Cl3l5H5qYOn6fEzX9cl1eMn43l7C13a+tBOAVD1oGp0="; + }) + (fetchNuGet { + pname = "Humanizer.Core"; + version = "2.14.1"; + hash = "sha256-EXvojddPu+9JKgOG9NSQgUTfWq1RpOYw7adxDPKDJ6o="; + }) + (fetchNuGet { + pname = "LuceneNet303r2"; + version = "3.0.3.8"; + hash = "sha256-mHfa5OzVff2q5MIgefih9Y269qQKe7It/6G4IwT2Meg="; + }) + (fetchNuGet { + pname = "MathNet.Numerics.Signed"; + version = "5.0.0"; + hash = "sha256-76y1jaL+abqoyP3K4n9phF1S1hTpylkw//vTHukROUc="; + }) + (fetchNuGet { + pname = "MicroCom.Runtime"; + version = "0.11.0"; + hash = "sha256-VdwpP5fsclvNqJuppaOvwEwv2ofnAI5ZSz2V+UEdLF0="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "6.0.0"; + hash = "sha256-49+H/iFwp+AfCICvWcqo9us4CzxApPKC37Q5Eqrw+JU="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.0.0"; + hash = "sha256-KDbCfsBWSJ5ohEXUKp1s1LX9xA2NPvXE/xVzj68EdC0="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.3.3"; + hash = "sha256-pkZiggwLw8k+CVSXKTzsVGsT+K49LxXUS3VH5PNlpCY="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "3.8.0"; + hash = "sha256-3G9vSc/gHH7FWgOySLTut1+eEaf3H66qcPOvNPLOx4o="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "4.5.0"; + hash = "sha256-qo1oVNTB9JIMEPoiIZ+02qvF/O8PshQ/5gTjsY9iX0I="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "3.8.0"; + hash = "sha256-i/r3V/No/VzqmJlWxpGoirvlbJDbBPa/ONZtzYrxuc4="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "4.5.0"; + hash = "sha256-5dZTS9PYtY83vyVa5bdNG3XKV5EjcnmddfUqWmIE29A="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.Scripting"; + version = "3.8.0"; + hash = "sha256-fA9Qu+vTyMZ9REzxJ4aMg/SHCDRk4q9k4ZGUdynoHnA="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.Workspaces"; + version = "4.5.0"; + hash = "sha256-Kmyt1Xfcs0rSZHvN9PH94CKAooqMS9abZQY7EpEqb2o="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Scripting.Common"; + version = "3.8.0"; + hash = "sha256-866jMHp8kbc1FYpKuUWnd7ViU6kGJTAxPcL/IjXrT0I="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Workspaces.Common"; + version = "4.5.0"; + hash = "sha256-WM7AXJYHagaPx2waj2E32gG0qXq6Kx4Zhiq7Ym3WXPI="; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.3.0"; + hash = "sha256-a3dAiPaVuky0wpcHmpTVtAQJNGZ2v91/oArA+dpJgj8="; + }) + (fetchNuGet { + pname = "Microsoft.Data.Sqlite.Core"; + version = "8.0.5"; + hash = "sha256-PH+ZS45SGfWSFcYZA+V3m0k1r3kxaDzD3DutVVRyqfQ="; + }) + (fetchNuGet { + pname = "Microsoft.EntityFrameworkCore"; + version = "8.0.0"; + hash = "sha256-Z6dlgOQrYcSCcRaXPNnYLC87sg4OGRS+p4Tv3EFXFfY="; + }) + (fetchNuGet { + pname = "Microsoft.EntityFrameworkCore"; + version = "8.0.5"; + hash = "sha256-qR7Z+AQXzwejgYUKhoZIfYTWPOLNpOD6DBJ80xEfLaE="; + }) + (fetchNuGet { + pname = "Microsoft.EntityFrameworkCore.Abstractions"; + version = "8.0.0"; + hash = "sha256-QxPc73WzjE63Pzuxc/xr/uQc0C+v6xVd2N0iIUJKOQU="; + }) + (fetchNuGet { + pname = "Microsoft.EntityFrameworkCore.Abstractions"; + version = "8.0.5"; + hash = "sha256-2RyxdXMIc2Gzbc5ouEdbbrVDfTrCU8PP9zPYxlcQXpw="; + }) + (fetchNuGet { + pname = "Microsoft.EntityFrameworkCore.Analyzers"; + version = "8.0.0"; + hash = "sha256-SidpTl9AveYiXHa+TtvyHnRTOn02lmab4qXPf0FTi+0="; + }) + (fetchNuGet { + pname = "Microsoft.EntityFrameworkCore.Analyzers"; + version = "8.0.5"; + hash = "sha256-tvLA2TZouZC8pgxS8YikG2ui4Znaj6bNrVGAVy7t9rk="; + }) + (fetchNuGet { + pname = "Microsoft.EntityFrameworkCore.Design"; + version = "8.0.5"; + hash = "sha256-zwDnWBGVf6O+L2iqcwJ/e+gbg5A+hVLf8Tc3vIbl+cA="; + }) + (fetchNuGet { + pname = "Microsoft.EntityFrameworkCore.Relational"; + version = "8.0.0"; + hash = "sha256-ga+Qp4dZpmxVEmIIn8AcC92HrhVQBaDICyHqE87s+lk="; + }) + (fetchNuGet { + pname = "Microsoft.EntityFrameworkCore.Relational"; + version = "8.0.5"; + hash = "sha256-peIG9ZgXvvEB2wJ2QFxC3u+H8LnZ9xL/HIegw4R00Do="; + }) + (fetchNuGet { + pname = "Microsoft.EntityFrameworkCore.Sqlite"; + version = "8.0.5"; + hash = "sha256-lED2YXKz6PzYAC5iIXW957N74KUuYtJ9cKvoPFiebpk="; + }) + (fetchNuGet { + pname = "Microsoft.EntityFrameworkCore.Sqlite.Core"; + version = "8.0.5"; + hash = "sha256-+6AvDE+Fj0Oc7EfA4SXwFUdkOSvvX6jC5HPtbUhYQwE="; + }) + (fetchNuGet { + pname = "Microsoft.EntityFrameworkCore.Tools"; + version = "8.0.5"; + hash = "sha256-tHtuHXdI4d3CdL+2as595sys0phrBeZtWEof2Gd/A3I="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Caching.Abstractions"; + version = "8.0.0"; + hash = "sha256-xGpKrywQvU1Wm/WolYIxgHYEFfgkNGeJ+GGc5DT3phI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Caching.Memory"; + version = "8.0.0"; + hash = "sha256-RUQe2VgOATM9JkZ/wGm9mreKoCmOS4pPyvyJWBqMaC8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "8.0.0"; + hash = "sha256-9BPsASlxrV8ilmMCjdb3TiUcm5vFZxkBnAI/fNBSEyA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "8.0.0"; + hash = "sha256-4eBpDkf7MJozTZnOwQvwcfgRKQGcNXe0K/kF+h5Rl8o="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "8.0.0"; + hash = "sha256-GanfInGzzoN2bKeNwON8/Hnamr6l7RTpYLA49CNXD9Q="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.FileExtensions"; + version = "8.0.0"; + hash = "sha256-BCxcjVP+kvrDDB0nzsFCJfU74UK4VBvct2JA4r+jNcs="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Json"; + version = "8.0.0"; + hash = "sha256-Fi/ijcG5l0BOu7i96xHu96aN5/g7zO6SWQbTsI3Qetg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "8.0.0"; + hash = "sha256-+qIDR8hRzreCHNEDtUcPfVHQdurzWPo/mqviCH78+EQ="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.0"; + hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyModel"; + version = "8.0.0"; + hash = "sha256-qkCdwemqdZY/yIW5Xmh7Exv74XuE39T8aHGHCofoVgo="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "8.0.0"; + hash = "sha256-uQSXmt47X2HGoVniavjLICbPtD2ReQOYQMgy3l0xuMU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Physical"; + version = "8.0.0"; + hash = "sha256-29y5ZRQ1ZgzVOxHktYxyiH40kVgm5un2yTGdvuSWnRc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileSystemGlobbing"; + version = "8.0.0"; + hash = "sha256-+Oz41JR5jdcJlCJOSpQIL5OMBNi+1Hl2d0JUHfES7sU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "8.0.0"; + hash = "sha256-Meh0Z0X7KyOEG4l0RWBcuHHihcABcvCyfUXgasmQ91o="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "8.0.0"; + hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "8.0.0"; + hash = "sha256-n2m4JSegQKUTlOsKLZUUHHKMq926eJ0w9N9G+I3FoFw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "8.0.0"; + hash = "sha256-FU8qj3DR8bDdc1c+WeGZx/PCZeqqndweZM9epcpXjSo="; + }) + (fetchNuGet { + pname = "Microsoft.IO.RecyclableMemoryStream"; + version = "3.0.0"; + hash = "sha256-WBXkqxC5g4tJ481sa1uft39LqA/5hx5yOfiTfMRMg/4="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "2.1.2"; + hash = "sha256-gYQQO7zsqG+OtN4ywYQyfsiggS2zmxw4+cPXlK+FB5Q="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "5.0.0"; + hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.SystemEvents"; + version = "6.0.0"; + hash = "sha256-N9EVZbl5w1VnMywGXyaVWzT9lh84iaJ3aD48hIBk1zA="; + }) + (fetchNuGet { + pname = "Mono.TextTemplating"; + version = "2.2.1"; + hash = "sha256-4TYsfc8q74P8FuDwkIWPO+VYY0mh4Hs4ZL8v0lMaBsY="; + }) + (fetchNuGet { + pname = "NameParserSharp"; + version = "1.5.0"; + hash = "sha256-I0xUWObpeR9r867ef3SskvdyIWB7kpNI+Xy7X4l05eE="; + }) + (fetchNuGet { + pname = "NAudio.Core"; + version = "2.2.1"; + hash = "sha256-eUZF2/0w5IgGY9UtnZIk1VwwH6VCKP9iPJXVcseIc0c="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.3"; + hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; + }) + (fetchNuGet { + pname = "NPOI"; + version = "2.7.0"; + hash = "sha256-zqns3HwLv8OQMyvw+LUtwqPbkAEIrVJU589AMNhnM4s="; + }) + (fetchNuGet { + pname = "Octokit"; + version = "11.0.1"; + hash = "sha256-24Ym/CXgU3LCFQcMHdFfWp8vUjLfwRcRIyW9fvr4i1s="; + }) + (fetchNuGet { + pname = "Pluralize.NET"; + version = "1.0.2"; + hash = "sha256-u/WHYDpSvGs6SkgPREm1RID4po6h8/fj2QgJal1TBwU="; + }) + (fetchNuGet { + pname = "Polly"; + version = "8.4.1"; + hash = "sha256-CPFw0j6f2P5LfcoFAHo1RRDnCx6SXnp8gzHnwYDnYhY="; + }) + (fetchNuGet { + pname = "Polly.Core"; + version = "8.4.1"; + hash = "sha256-EksA3U5cmsri2joM+SMtbdwOUMUVxIXT8DnH4DSAIpA="; + }) + (fetchNuGet { + pname = "ReactiveUI"; + version = "18.3.1"; + hash = "sha256-1rf4icGRKTR3XIWJpkQJCG7ObRM+72ITB5K+ND1is9M="; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; + }) + (fetchNuGet { + pname = "Serilog"; + version = "2.10.0"; + hash = "sha256-+8wilkt+VVvW+KFWuLryj7cSFpz9D+sz92KYWICAcSE="; + }) + (fetchNuGet { + pname = "Serilog"; + version = "2.8.0"; + hash = "sha256-MBL9AWGV8UthhiHXnqH3EsfIyXnxdLWqAdFa6QvQ2To="; + }) + (fetchNuGet { + pname = "Serilog"; + version = "3.1.0"; + hash = "sha256-1CDAp+AjfFjQqoLvKYp/j6pKTUfNOGfKVlWyqCGHo7k="; + }) + (fetchNuGet { + pname = "Serilog"; + version = "3.1.1"; + hash = "sha256-L263y8jkn7dNFD2jAUK6mgvyRTqFe39i1tRhVZsNZTI="; + }) + (fetchNuGet { + pname = "Serilog"; + version = "4.0.0"; + hash = "sha256-j8hQ5TdL1TjfdGiBO9PyHJFMMPvATHWN1dtrrUZZlNw="; + }) + (fetchNuGet { + pname = "Serilog.Exceptions"; + version = "8.4.0"; + hash = "sha256-2We6ZVAcFsEYVV7vVM+F1+4phHRqc7NeQZKbYDK0Gew="; + }) + (fetchNuGet { + pname = "Serilog.Settings.Configuration"; + version = "8.0.0"; + hash = "sha256-JQ39fvhOFSUHE6r9DXJvLaZI+Lk7AYzuskQu3ux+hQg="; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Console"; + version = "5.0.0"; + hash = "sha256-UOVlegJLhs0vK1ml2DZCjFE5roDRZsGCAqD/53ZaZWI="; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Console"; + version = "6.0.0"; + hash = "sha256-QH8ykDkLssJ99Fgl+ZBFBr+RQRl0wRTkeccQuuGLyro="; + }) + (fetchNuGet { + pname = "Serilog.Sinks.File"; + version = "5.0.0"; + hash = "sha256-GKy9hwOdlu2W0Rw8LiPyEwus+sDtSOTl8a5l9uqz+SQ="; + }) + (fetchNuGet { + pname = "Serilog.Sinks.File"; + version = "6.0.0"; + hash = "sha256-KQmlUpG9ovRpNqKhKe6rz3XMLUjkBqjyQhEm2hV5Sow="; + }) + (fetchNuGet { + pname = "Serilog.Sinks.ZipFile"; + version = "3.1.1"; + hash = "sha256-W4oXuOZF+Ic6rKma2PkmKW5O7GvuzooNsiB17p5H6lQ="; + }) + (fetchNuGet { + pname = "SharpZipLib"; + version = "1.3.3"; + hash = "sha256-HWEQTKh9Ktwg/zIl079dAiH+ob2ShWFAqLgG6XgIMr4="; + }) + (fetchNuGet { + pname = "SixLabors.Fonts"; + version = "1.0.1"; + hash = "sha256-fox6f9Z5xunVXiy71KTSkb0DirMN00tuUlChyp96kiI="; + }) + (fetchNuGet { + pname = "SixLabors.ImageSharp"; + version = "2.1.7"; + hash = "sha256-CPC3x2vPfjv8ZLyxnQ8uuNhlsUMrIE/+hdYP0dZGLR8="; + }) + (fetchNuGet { + pname = "SixLabors.ImageSharp"; + version = "3.1.5"; + hash = "sha256-3UehX9T+I81nfgv2dTHlpoPgYzXFk7kHr1mmlQOCBfw="; + }) + (fetchNuGet { + pname = "SkiaSharp"; + version = "2.88.6"; + hash = "sha256-y0wzgwdQXtgl5boCz/EgLWbK3SwC0cFVRUbBxOUPQXc="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Linux"; + version = "2.88.6"; + hash = "sha256-VjgGoi73tVvqO/UXmQb1w9ioAbFu2dxH8oHz1l5H4zE="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.macOS"; + version = "2.88.6"; + hash = "sha256-7hOMjlYTOiNPLNwfLFUjTcdgiGEtmYUI1EubiRiC6bo="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.WebAssembly"; + version = "2.88.6"; + hash = "sha256-CIb9fHVgHwIa0R1WafKJ3+GqtDHHRgDohA3ayTHvlws="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Win32"; + version = "2.88.6"; + hash = "sha256-ljD4QmAO2/vwA6I8GIUNkONpOzmGsOVJJy9vPDnjVfA="; + }) + (fetchNuGet { + pname = "Splat"; + version = "14.4.1"; + hash = "sha256-i1yzIVpKdFjZMI4J8H970nZCxszklgDitYTEKKz0zA8="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.bundle_e_sqlite3"; + version = "2.1.6"; + hash = "sha256-dZD/bZsYXjOu46ZH5Y/wgh0uhHOqIxC+S+0ecKhr718="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.core"; + version = "2.1.6"; + hash = "sha256-RxWjm52PdmMV98dgDy0BCpF988+BssRZUgALLv7TH/E="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.lib.e_sqlite3"; + version = "2.1.6"; + hash = "sha256-uHt5d+SFUkSd6WD7Tg0J3e8eVoxy/FM/t4PAkc9PJT0="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.provider.e_sqlite3"; + version = "2.1.6"; + hash = "sha256-zHc/YZsd72eXlI8ba1tv58HZWUIiyjJaxq2CCP1hQe8="; + }) + (fetchNuGet { + pname = "System.CodeDom"; + version = "4.4.0"; + hash = "sha256-L1xyspJ8pDJNVPYKl+FMGf4Zwm0tlqtAyQCNW6pT6/0="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "5.0.0"; + hash = "sha256-GdwSIjLMM0uVfE56VUSLVNgpW0B//oCeSFj8/hSlbM8="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "6.0.0"; + hash = "sha256-DKEbpFqXCIEfqp9p3ezqadn5b/S1YTk32/EQK+tEScs="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "8.0.0"; + hash = "sha256-F7OVjKNwpqbUh8lTidbqJWYi476nsq9n+6k0+QVRo3w="; + }) + (fetchNuGet { + pname = "System.Collections.NonGeneric"; + version = "4.3.0"; + hash = "sha256-8/yZmD4jjvq7m68SPkJZLBQ79jOTOyT5lyzX4SCYAx8="; + }) + (fetchNuGet { + pname = "System.ComponentModel.Annotations"; + version = "4.5.0"; + hash = "sha256-15yE2NoT9vmL9oGCaxHClQR1jLW1j1ef5hHMg55xRso="; + }) + (fetchNuGet { + pname = "System.Composition"; + version = "6.0.0"; + hash = "sha256-H5TnnxOwihI0VyRuykbOWuKFSCWNN+MUEYyloa328Nw="; + }) + (fetchNuGet { + pname = "System.Composition.AttributedModel"; + version = "6.0.0"; + hash = "sha256-03DR8ecEHSKfgzwuTuxtsRW0Gb7aQtDS4LAYChZdGdc="; + }) + (fetchNuGet { + pname = "System.Composition.Convention"; + version = "6.0.0"; + hash = "sha256-a3DZS8CT2kV8dVpGxHKoP5wHVKsT+kiPJixckpYfdQo="; + }) + (fetchNuGet { + pname = "System.Composition.Hosting"; + version = "6.0.0"; + hash = "sha256-fpoh6WBNmaHEHszwlBR/TNjd85lwesfM7ZkQhqYtLy4="; + }) + (fetchNuGet { + pname = "System.Composition.Runtime"; + version = "6.0.0"; + hash = "sha256-nGZvg2xYhhazAjOjhWqltBue+hROKP0IOiFGP8yMBW8="; + }) + (fetchNuGet { + pname = "System.Composition.TypedParts"; + version = "6.0.0"; + hash = "sha256-4uAETfmL1CvGjHajzWowsEmJgTKnuFC8u9lbYPzAN3k="; + }) + (fetchNuGet { + pname = "System.Configuration.ConfigurationManager"; + version = "6.0.0"; + hash = "sha256-fPV668Cfi+8pNWrvGAarF4fewdPVEDwlJWvJk0y+Cms="; + }) + (fetchNuGet { + pname = "System.Configuration.ConfigurationManager"; + version = "8.0.0"; + hash = "sha256-xhljqSkNQk8DMkEOBSYnn9lzCSEDDq4yO910itptqiE="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; + }) + (fetchNuGet { + pname = "System.Diagnostics.EventLog"; + version = "8.0.0"; + hash = "sha256-rt8xc3kddpQY4HEdghlBeOK4gdw5yIj4mcZhAVtk2/Y="; + }) + (fetchNuGet { + pname = "System.Drawing.Common"; + version = "6.0.0"; + hash = "sha256-/9EaAbEeOjELRSMZaImS1O8FmUe8j4WuFUw1VOrPyAo="; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.3.0"; + hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; + }) + (fetchNuGet { + pname = "System.Formats.Asn1"; + version = "6.0.0"; + hash = "sha256-KaMHgIRBF7Nf3VwOo+gJS1DcD+41cJDPWFh+TDQ8ee8="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "6.0.0"; + hash = "sha256-xfjF4UqTMJpf8KsBWUyJlJkzPTOO/H5MW023yTYNQSA="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "6.0.3"; + hash = "sha256-v+FOmjRRKlDtDW6+TfmyMiiki010YGVTa0EwXu9X7ck="; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.3.0"; + hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.3"; + hash = "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.3.0"; + hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; + }) + (fetchNuGet { + pname = "System.Reactive"; + version = "5.0.0"; + hash = "sha256-M5Z8pw8rVb8ilbnTdaOptzk5VFd5DlKa7zzCpuytTtE="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.3.0"; + hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.3.0"; + hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.3.0"; + hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "5.0.0"; + hash = "sha256-Wo+MiqhcP9dQ6NuFGrQTw6hpbJORFwp+TBNTq2yhGp8="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "6.0.1"; + hash = "sha256-id27sU4qIEIpgKenO5b4IHt6L1XuNsVe4TR9TKaLWDo="; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.3.0"; + hash = "sha256-4U4/XNQAnddgQIHIJq3P2T80hN0oPdU2uCeghsDTWng="; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.7.0"; + hash = "sha256-GEtCGXwtOnkYejSV+Tfl+DqyGq5jTUaVyL9eMupMHBM="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.7.1"; + hash = "sha256-UvyoDV8O0oY3HPG1GbA56YVdvwTGEfjYR5gW1O7IK4U="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "5.0.0"; + hash = "sha256-neARSpLPUzPxEKhJRwoBzhPxK+cKIitLx7WBYncsYgo="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "6.0.0"; + hash = "sha256-qOyWEBbNr3EjyS+etFG8/zMbuPjA+O+di717JP9Cxyg="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Pkcs"; + version = "6.0.3"; + hash = "sha256-p5xbSMTjndPCht9HRbDp5fr1osUOaXunjDZUatualgs="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "6.0.0"; + hash = "sha256-Wi9I9NbZlpQDXgS7Kl06RIFxY/9674S7hKiYw5EabRY="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "8.0.0"; + hash = "sha256-fb0pa9sQxN+mr0vnXg1Igbx49CaOqS+GDkTfWNboUvs="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Xml"; + version = "6.0.1"; + hash = "sha256-spXV8cWZu0V3liek1936REtdpvS4fQwc98JvacO1oJU="; + }) + (fetchNuGet { + pname = "System.Security.Permissions"; + version = "6.0.0"; + hash = "sha256-/MMvtFWGN/vOQfjXdOhet1gsnMgh6lh5DCHimVsnVEs="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; + }) + (fetchNuGet { + pname = "System.ServiceProcess.ServiceController"; + version = "8.0.0"; + hash = "sha256-mq/Qm8JeMUvitHf32/F8uvw1YJGx4prGnEI/VzdaFAI="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "4.5.1"; + hash = "sha256-PIhkv59IXjyiuefdhKxS9hQfEwO9YWRuNudpo53HQfw="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "5.0.0"; + hash = "sha256-YJ5jJqkVPp+6fEzSXOmw1sNSdygB5Rx7TJ0TrNS/wq4="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "6.0.0"; + hash = "sha256-nGc2A6XYnwqGcq8rfgTRjGr+voISxNe/76k2K36coj4="; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "8.0.0"; + hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "8.0.0"; + hash = "sha256-XFcCHMW1u2/WujlWNHaIWkbW1wn8W4kI0QdrwPtWmow="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; + }) + (fetchNuGet { + pname = "System.Threading.Channels"; + version = "6.0.0"; + hash = "sha256-klGYnsyrjvXaGeqgfnMf/dTAMNtcHY+zM4Xh6v2JfuE="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; + }) + (fetchNuGet { + pname = "System.Windows.Extensions"; + version = "6.0.0"; + hash = "sha256-N+qg1E6FDJ9A9L50wmVt3xPQV8ZxlG1xeXgFuxO+yfM="; + }) + (fetchNuGet { + pname = "Tmds.DBus.Protocol"; + version = "0.15.0"; + hash = "sha256-4gk2vXDjKFaBh82gTkwg3c/5GRjiH+bvM5elfDSbKTU="; + }) ] diff --git a/pkgs/by-name/li/libatomic_ops/package.nix b/pkgs/by-name/li/libatomic_ops/package.nix index a9fc75558e9bd6..b971e23e1acd21 100644 --- a/pkgs/by-name/li/libatomic_ops/package.nix +++ b/pkgs/by-name/li/libatomic_ops/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, autoconf, automake, libtool }: +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + libtool, +}: stdenv.mkDerivation rec { pname = "libatomic_ops"; @@ -12,9 +19,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-0wUgf+IH8rP7XLTAGdoStEzj/LxZPf1QgNhnsaJBm1E="; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; - nativeBuildInputs = lib.optionals stdenv.hostPlatform.isCygwin [ autoconf automake libtool ]; + nativeBuildInputs = lib.optionals stdenv.hostPlatform.isCygwin [ + autoconf + automake + libtool + ]; preConfigure = lib.optionalString stdenv.hostPlatform.isCygwin '' sed -i -e "/libatomic_ops_gpl_la_SOURCES/a libatomic_ops_gpl_la_LIBADD = libatomic_ops.la" src/Makefile.am @@ -23,8 +38,8 @@ stdenv.mkDerivation rec { meta = { description = "Library for semi-portable access to hardware-provided atomic memory update operations"; - license = lib.licenses.gpl2Plus ; - maintainers = [lib.maintainers.raskin]; + license = lib.licenses.gpl2Plus; + maintainers = [ lib.maintainers.raskin ]; platforms = with lib.platforms; unix ++ windows; }; } diff --git a/pkgs/by-name/li/libaudclient/package.nix b/pkgs/by-name/li/libaudclient/package.nix index 9c790172039bc3..a8245cb0fadf6f 100644 --- a/pkgs/by-name/li/libaudclient/package.nix +++ b/pkgs/by-name/li/libaudclient/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, dbus-glib }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + dbus-glib, +}: stdenv.mkDerivation rec { pname = "libaudclient"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib dbus-glib ]; + buildInputs = [ + glib + dbus-glib + ]; meta = with lib; { description = "Legacy D-Bus client library for Audacious"; diff --git a/pkgs/by-name/li/libaudec/package.nix b/pkgs/by-name/li/libaudec/package.nix index ffe5f785acd5d5..073191c7a9d32b 100644 --- a/pkgs/by-name/li/libaudec/package.nix +++ b/pkgs/by-name/li/libaudec/package.nix @@ -1,6 +1,12 @@ -{ lib, stdenv, fetchFromGitHub -, libsndfile, libsamplerate -, meson, ninja, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + libsndfile, + libsamplerate, + meson, + ninja, + pkg-config, }: stdenv.mkDerivation rec { @@ -14,8 +20,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-8morbrq8zG+2N3ruMeJa85ci9P0wPQOfZ5H56diFEAo="; }; - buildInputs = [ libsndfile libsamplerate ]; - nativeBuildInputs = [ meson ninja pkg-config ]; + buildInputs = [ + libsndfile + libsamplerate + ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; meta = with lib; { description = "Library for reading and resampling audio files"; diff --git a/pkgs/by-name/li/libavc1394/package.nix b/pkgs/by-name/li/libavc1394/package.nix index 4dfc5713af7e24..7a58f151c9273d 100644 --- a/pkgs/by-name/li/libavc1394/package.nix +++ b/pkgs/by-name/li/libavc1394/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, libraw1394, argp-standalone }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libraw1394, + argp-standalone, +}: stdenv.mkDerivation rec { pname = "libavc1394"; diff --git a/pkgs/by-name/li/libavif/package.nix b/pkgs/by-name/li/libavif/package.nix index 060d653bdb6eee..00273ae753f12e 100644 --- a/pkgs/by-name/li/libavif/package.nix +++ b/pkgs/by-name/li/libavif/package.nix @@ -1,15 +1,17 @@ -{ lib, stdenv -, fetchFromGitHub -, libaom -, cmake -, pkg-config -, zlib -, libpng -, libjpeg -, dav1d -, libyuv -, gdk-pixbuf -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + libaom, + cmake, + pkg-config, + zlib, + libpng, + libjpeg, + dav1d, + libyuv, + gdk-pixbuf, + makeWrapper, }: let @@ -66,21 +68,22 @@ stdenv.mkDerivation rec { env.PKG_CONFIG_GDK_PIXBUF_2_0_GDK_PIXBUF_MODULEDIR = gdkPixbufModuleDir; - postInstall = '' - GDK_PIXBUF_MODULEDIR=${gdkPixbufModuleDir} \ - GDK_PIXBUF_MODULE_FILE=${gdkPixbufModuleFile} \ - gdk-pixbuf-query-loaders --update-cache + postInstall = + '' + GDK_PIXBUF_MODULEDIR=${gdkPixbufModuleDir} \ + GDK_PIXBUF_MODULE_FILE=${gdkPixbufModuleFile} \ + gdk-pixbuf-query-loaders --update-cache - '' - # Cross-compiled gdk-pixbuf doesn't support thumbnailers - + lib.optionalString (stdenv.hostPlatform == stdenv.buildPlatform) '' - mkdir -p "$out/bin" - makeWrapper ${gdk-pixbuf}/bin/gdk-pixbuf-thumbnailer "$out/libexec/gdk-pixbuf-thumbnailer-avif" \ - --set GDK_PIXBUF_MODULE_FILE ${gdkPixbufModuleFile} - ''; + '' + # Cross-compiled gdk-pixbuf doesn't support thumbnailers + + lib.optionalString (stdenv.hostPlatform == stdenv.buildPlatform) '' + mkdir -p "$out/bin" + makeWrapper ${gdk-pixbuf}/bin/gdk-pixbuf-thumbnailer "$out/libexec/gdk-pixbuf-thumbnailer-avif" \ + --set GDK_PIXBUF_MODULE_FILE ${gdkPixbufModuleFile} + ''; meta = with lib; { - description = "C implementation of the AV1 Image File Format"; + description = "C implementation of the AV1 Image File Format"; longDescription = '' Libavif aims to be a friendly, portable C implementation of the AV1 Image File Format. It is a work-in-progress, but can already @@ -88,10 +91,10 @@ stdenv.mkDerivation rec { (with alpha). It also features an encoder and a decoder (avifenc/avifdec). ''; - homepage = "https://github.com/AOMediaCodec/libavif"; - changelog = "https://github.com/AOMediaCodec/libavif/blob/v${version}/CHANGELOG.md"; + homepage = "https://github.com/AOMediaCodec/libavif"; + changelog = "https://github.com/AOMediaCodec/libavif/blob/v${version}/CHANGELOG.md"; maintainers = with maintainers; [ mkg20001 ]; - platforms = platforms.all; - license = licenses.bsd2; + platforms = platforms.all; + license = licenses.bsd2; }; } diff --git a/pkgs/by-name/li/libax25/package.nix b/pkgs/by-name/li/libax25/package.nix index 27f51909900628..15a9d11f33b1bc 100644 --- a/pkgs/by-name/li/libax25/package.nix +++ b/pkgs/by-name/li/libax25/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, glibc +{ + lib, + stdenv, + fetchurl, + glibc, }: stdenv.mkDerivation rec { @@ -19,7 +20,10 @@ stdenv.mkDerivation rec { configureFlags = [ "--sysconfdir=/etc" ]; - LDFLAGS = lib.optionals stdenv.hostPlatform.isStatic [ "-static-libgcc" "-static" ]; + LDFLAGS = lib.optionals stdenv.hostPlatform.isStatic [ + "-static-libgcc" + "-static" + ]; meta = with lib; { description = "AX.25 library for hamradio applications"; diff --git a/pkgs/by-name/li/libayatana-appindicator/package.nix b/pkgs/by-name/li/libayatana-appindicator/package.nix index 719f1b3e4275a7..86eb9214c197b1 100644 --- a/pkgs/by-name/li/libayatana-appindicator/package.nix +++ b/pkgs/by-name/li/libayatana-appindicator/package.nix @@ -1,16 +1,25 @@ -{ stdenv, fetchFromGitHub, lib -, pkg-config, cmake -, gtk-doc -, gtk3, libayatana-indicator, libdbusmenu-gtk3 -, vala -, gobject-introspection +{ + stdenv, + fetchFromGitHub, + lib, + pkg-config, + cmake, + gtk-doc, + gtk3, + libayatana-indicator, + libdbusmenu-gtk3, + vala, + gobject-introspection, }: stdenv.mkDerivation rec { pname = "libayatana-appindicator"; version = "0.5.92"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "AyatanaIndicators"; @@ -19,11 +28,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-NzaWQBb2Ez1ik23wCgW1ZQh1/rY7GcPlLvaSgV7uXrA="; }; - nativeBuildInputs = [ pkg-config cmake gtk-doc vala gobject-introspection ]; + nativeBuildInputs = [ + pkg-config + cmake + gtk-doc + vala + gobject-introspection + ]; buildInputs = [ gtk3 ]; - propagatedBuildInputs = [ libayatana-indicator libdbusmenu-gtk3 ]; + propagatedBuildInputs = [ + libayatana-indicator + libdbusmenu-gtk3 + ]; cmakeFlags = [ "-DENABLE_BINDINGS_MONO=False" @@ -33,7 +51,10 @@ stdenv.mkDerivation rec { description = "Ayatana Application Indicators Shared Library"; homepage = "https://github.com/AyatanaIndicators/libayatana-appindicator"; changelog = "https://github.com/AyatanaIndicators/libayatana-appindicator/blob/${version}/ChangeLog"; - license = [ licenses.lgpl3Plus licenses.lgpl21Plus ]; + license = [ + licenses.lgpl3Plus + licenses.lgpl21Plus + ]; maintainers = [ maintainers.nickhu ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/li/libayatana-common/package.nix b/pkgs/by-name/li/libayatana-common/package.nix index 439cc45031f95d..687917e1bdd3c1 100644 --- a/pkgs/by-name/li/libayatana-common/package.nix +++ b/pkgs/by-name/li/libayatana-common/package.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchFromGitHub -, gitUpdater -, testers -, cmake -, glib -, gobject-introspection -, gtest -, intltool -, lomiri -, pkg-config -, systemd -, vala +{ + stdenv, + lib, + fetchFromGitHub, + gitUpdater, + testers, + cmake, + glib, + gobject-introspection, + gtest, + intltool, + lomiri, + pkg-config, + systemd, + vala, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/libb2/package.nix b/pkgs/by-name/li/libb2/package.nix index 39697b4af521a1..5a44f2f2a72d82 100644 --- a/pkgs/by-name/li/libb2/package.nix +++ b/pkgs/by-name/li/libb2/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, libtool -, pkg-config -, testers +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libtool, + pkg-config, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -37,7 +38,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://blake2.net/"; pkgConfigModules = [ "libb2" ]; platforms = platforms.all; - maintainers = with maintainers; [ dfoxfranke dotlambda ]; + maintainers = with maintainers; [ + dfoxfranke + dotlambda + ]; license = licenses.cc0; }; }) diff --git a/pkgs/by-name/li/libb64/package.nix b/pkgs/by-name/li/libb64/package.nix index 3b24089e53c636..2f73c45d0d9ed6 100644 --- a/pkgs/by-name/li/libb64/package.nix +++ b/pkgs/by-name/li/libb64/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "libb64"; @@ -11,37 +16,39 @@ stdenv.mkDerivation rec { sha256 = "sha256-9loDftr769qnIi00MueO86kjha2EiG9pnCLogp0Iq3c="; }; - patches = [ - # Fix parallel build failure: https://github.com/libb64/libb64/pull/9 - # make[1]: *** No rule to make target 'libb64.a', needed by 'c-example1'. Stop. - (fetchpatch { - name = "parallel-make.patch"; - url = "https://github.com/libb64/libb64/commit/4fe47c052e9123da8f751545deb48be08c3411f6.patch"; - sha256 = "18b3np3gpyzimqmk6001riqv5n70wfbclky6zzsrvj5zl1dj4ljf"; - }) - # Fix i686-linux build failure. - (fetchpatch { - name = "elif.patch"; - url = "https://github.com/libb64/libb64/commit/819e43c8b34261ea3ee694bdc27865a033966083.patch"; - hash = "sha256-r2jI6Q3rWDtArLlkAuyy7vcjsuRvX+2fBd5yk8XOMcc"; - }) - (fetchpatch { - name = "size_t.patch"; - url = "https://github.com/libb64/libb64/commit/b5edeafc89853c48fa41a4c16393a1fdc8638ab6.patch"; - hash = "sha256-+bqfOOlT/t0FLQEMHuxW1BxJcx9rk0yYM3wD43mcymo"; - }) - # Fix build with Clang 16. - # https://github.com/libb64/libb64/pull/10 - (fetchpatch { - name = "use-proper-function-prototype-for-main.patch"; - url = "https://github.com/libb64/libb64/commit/98eaf510f40e384b32c01ad4bd5c3a697fdd8560.patch"; - hash = "sha256-CGslJUw0og/bBBirLm0J5Q7cf2WW/vniVAkXHlb6lbQ="; - }) - ] ++ lib.optional (stdenv.buildPlatform != stdenv.hostPlatform) (fetchpatch { - name = "0001-example-Do-not-run-the-tests.patch"; - url = "https://cgit.openembedded.org/meta-openembedded/plain/meta-oe/recipes-support/libb64/libb64/0001-example-Do-not-run-the-tests.patch?id=484e0de1e4ee107f21ae2a5c5f976ed987978baf"; - sha256 = "sha256-KTsiIWJe66BKlu/A43FWfW0XAu4E7lWX/RY4NITRrm4="; - }); + patches = + [ + # Fix parallel build failure: https://github.com/libb64/libb64/pull/9 + # make[1]: *** No rule to make target 'libb64.a', needed by 'c-example1'. Stop. + (fetchpatch { + name = "parallel-make.patch"; + url = "https://github.com/libb64/libb64/commit/4fe47c052e9123da8f751545deb48be08c3411f6.patch"; + sha256 = "18b3np3gpyzimqmk6001riqv5n70wfbclky6zzsrvj5zl1dj4ljf"; + }) + # Fix i686-linux build failure. + (fetchpatch { + name = "elif.patch"; + url = "https://github.com/libb64/libb64/commit/819e43c8b34261ea3ee694bdc27865a033966083.patch"; + hash = "sha256-r2jI6Q3rWDtArLlkAuyy7vcjsuRvX+2fBd5yk8XOMcc"; + }) + (fetchpatch { + name = "size_t.patch"; + url = "https://github.com/libb64/libb64/commit/b5edeafc89853c48fa41a4c16393a1fdc8638ab6.patch"; + hash = "sha256-+bqfOOlT/t0FLQEMHuxW1BxJcx9rk0yYM3wD43mcymo"; + }) + # Fix build with Clang 16. + # https://github.com/libb64/libb64/pull/10 + (fetchpatch { + name = "use-proper-function-prototype-for-main.patch"; + url = "https://github.com/libb64/libb64/commit/98eaf510f40e384b32c01ad4bd5c3a697fdd8560.patch"; + hash = "sha256-CGslJUw0og/bBBirLm0J5Q7cf2WW/vniVAkXHlb6lbQ="; + }) + ] + ++ lib.optional (stdenv.buildPlatform != stdenv.hostPlatform) (fetchpatch { + name = "0001-example-Do-not-run-the-tests.patch"; + url = "https://cgit.openembedded.org/meta-openembedded/plain/meta-oe/recipes-support/libb64/libb64/0001-example-Do-not-run-the-tests.patch?id=484e0de1e4ee107f21ae2a5c5f976ed987978baf"; + sha256 = "sha256-KTsiIWJe66BKlu/A43FWfW0XAu4E7lWX/RY4NITRrm4="; + }); enableParallelBuilding = true; diff --git a/pkgs/by-name/li/libbacktrace/package.nix b/pkgs/by-name/li/libbacktrace/package.nix index 60c7ede0993fb6..33ce3d6a0ebe82 100644 --- a/pkgs/by-name/li/libbacktrace/package.nix +++ b/pkgs/by-name/li/libbacktrace/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, enableStatic ? stdenv.hostPlatform.isStatic -, enableShared ? !stdenv.hostPlatform.isStatic -, unstableGitUpdater -, autoreconfHook +{ + stdenv, + lib, + fetchFromGitHub, + enableStatic ? stdenv.hostPlatform.isStatic, + enableShared ? !stdenv.hostPlatform.isStatic, + unstableGitUpdater, + autoreconfHook, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/li/libbaseencode/package.nix b/pkgs/by-name/li/libbaseencode/package.nix index 7cd4b173c9b7d4..f4a65c01e297b6 100644 --- a/pkgs/by-name/li/libbaseencode/package.nix +++ b/pkgs/by-name/li/libbaseencode/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, cmake }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "libbaseencode"; diff --git a/pkgs/by-name/li/libbdplus/package.nix b/pkgs/by-name/li/libbdplus/package.nix index d52ca4fca28428..c894a07eba1f66 100644 --- a/pkgs/by-name/li/libbdplus/package.nix +++ b/pkgs/by-name/li/libbdplus/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, libgcrypt, libgpg-error, gettext }: +{ + lib, + stdenv, + fetchurl, + libgcrypt, + libgpg-error, + gettext, +}: # library that allows libbluray to play BDplus protected bluray disks # libaacs does not infringe DRM's right or copyright. See the legal page of the website for more info. @@ -9,14 +16,18 @@ stdenv.mkDerivation rec { pname = "libbdplus"; - version = "0.2.0"; + version = "0.2.0"; src = fetchurl { url = "http://get.videolan.org/libbdplus/${version}/${pname}-${version}.tar.bz2"; sha256 = "sha256-uT7qPq7zPW6RVdLDSwaMUFSTqlpJNuYydPQ0KrD0Clg="; }; - buildInputs = [ libgcrypt libgpg-error gettext ]; + buildInputs = [ + libgcrypt + libgpg-error + gettext + ]; meta = with lib; { homepage = "http://www.videolan.org/developers/libbdplus.html"; diff --git a/pkgs/by-name/li/libbfio/package.nix b/pkgs/by-name/li/libbfio/package.nix index 1695b65272d2e4..21fad908b6f1ac 100644 --- a/pkgs/by-name/li/libbfio/package.nix +++ b/pkgs/by-name/li/libbfio/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchzip -, stdenv -, gettext -, libtool -, pkg-config +{ + lib, + fetchzip, + stdenv, + gettext, + libtool, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { @@ -16,12 +17,18 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gettext libtool ]; + buildInputs = [ + gettext + libtool + ]; meta = { description = "Library to provide basic file input/output abstraction"; homepage = "https://github.com/libyal/libbfio"; - license = with lib.licenses; [ gpl3Plus lgpl3Plus ]; + license = with lib.licenses; [ + gpl3Plus + lgpl3Plus + ]; maintainers = with lib.maintainers; [ d3vil0p3r ]; platforms = with lib.platforms; unix ++ windows; }; diff --git a/pkgs/by-name/li/libbgcode/package.nix b/pkgs/by-name/li/libbgcode/package.nix index c2ddb4f6ddf4c8..ddfd37c773e241 100644 --- a/pkgs/by-name/li/libbgcode/package.nix +++ b/pkgs/by-name/li/libbgcode/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, heatshrink -, zlib -, boost -, catch2 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + heatshrink, + zlib, + boost, + catch2, }: stdenv.mkDerivation { pname = "libbgcode"; diff --git a/pkgs/by-name/li/libbladeRF/package.nix b/pkgs/by-name/li/libbladeRF/package.nix index 77e72d22db6c7a..d615b116bb630a 100644 --- a/pkgs/by-name/li/libbladeRF/package.nix +++ b/pkgs/by-name/li/libbladeRF/package.nix @@ -1,5 +1,17 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config, cmake, git, doxygen, help2man, ncurses, tecla -, libusb1, udev }: +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + cmake, + git, + doxygen, + help2man, + ncurses, + tecla, + libusb1, + udev, +}: stdenv.mkDerivation rec { pname = "libbladeRF"; @@ -13,9 +25,19 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake pkg-config git doxygen help2man ]; + nativeBuildInputs = [ + cmake + pkg-config + git + doxygen + help2man + ]; # ncurses used due to https://github.com/Nuand/bladeRF/blob/ab4fc672c8bab4f8be34e8917d3f241b1d52d0b8/host/utilities/bladeRF-cli/CMakeLists.txt#L208 - buildInputs = [ tecla libusb1 ] + buildInputs = + [ + tecla + libusb1 + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ udev ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ ncurses ]; @@ -27,13 +49,15 @@ stdenv.mkDerivation rec { sed -i 's/$(hostname)/hostname/' host/utilities/bladeRF-cli/src/cmd/doc/generate.bash ''; - cmakeFlags = [ - "-DBUILD_DOCUMENTATION=ON" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "-DUDEV_RULES_PATH=etc/udev/rules.d" - "-DINSTALL_UDEV_RULES=ON" - "-DBLADERF_GROUP=bladerf" - ]; + cmakeFlags = + [ + "-DBUILD_DOCUMENTATION=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "-DUDEV_RULES_PATH=etc/udev/rules.d" + "-DINSTALL_UDEV_RULES=ON" + "-DBLADERF_GROUP=bladerf" + ]; env = lib.optionalAttrs stdenv.cc.isClang { NIX_CFLAGS_COMPILE = "-Wno-error=unused-but-set-variable"; diff --git a/pkgs/by-name/li/libbpkg/package.nix b/pkgs/by-name/li/libbpkg/package.nix index 969654b675a2b0..f91d2e738ceb13 100644 --- a/pkgs/by-name/li/libbpkg/package.nix +++ b/pkgs/by-name/li/libbpkg/package.nix @@ -1,15 +1,21 @@ -{ lib, stdenv -, build2 -, fetchurl -, libbutl -, enableShared ? !stdenv.hostPlatform.isStatic -, enableStatic ? !enableShared +{ + lib, + stdenv, + build2, + fetchurl, + libbutl, + enableShared ? !stdenv.hostPlatform.isStatic, + enableStatic ? !enableShared, }: stdenv.mkDerivation rec { pname = "libbpkg"; version = "0.17.0"; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; src = fetchurl { url = "https://pkg.cppget.org/1/alpha/build2/libbpkg-${version}.tar.gz"; diff --git a/pkgs/by-name/li/libbraiding/package.nix b/pkgs/by-name/li/libbraiding/package.nix index 2ee2e831f6e636..da04ca7b5eed02 100644 --- a/pkgs/by-name/li/libbraiding/package.nix +++ b/pkgs/by-name/li/libbraiding/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libbs2b/package.nix b/pkgs/by-name/li/libbs2b/package.nix index fa390eaaa58814..569b661d53c934 100644 --- a/pkgs/by-name/li/libbs2b/package.nix +++ b/pkgs/by-name/li/libbs2b/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libsndfile }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libsndfile, +}: stdenv.mkDerivation rec { pname = "libbs2b"; diff --git a/pkgs/by-name/li/libbsd/package.nix b/pkgs/by-name/li/libbsd/package.nix index 90a92f50f46345..0bc9d73d4de886 100644 --- a/pkgs/by-name/li/libbsd/package.nix +++ b/pkgs/by-name/li/libbsd/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, libmd -, gitUpdater +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + libmd, + gitUpdater, }: stdenv.mkDerivation rec { @@ -15,7 +16,11 @@ stdenv.mkDerivation rec { hash = "sha256-uIzJFj0MZSqvOamZkdl03bocOpcR248bWDivKhRzEBQ="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; enableParallelBuilding = true; @@ -36,12 +41,21 @@ stdenv.mkDerivation rec { }; # Fix undefined reference errors with version script under LLVM. - configureFlags = lib.optionals (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") [ "LDFLAGS=-Wl,--undefined-version" ]; + configureFlags = lib.optionals ( + stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17" + ) [ "LDFLAGS=-Wl,--undefined-version" ]; meta = with lib; { description = "Common functions found on BSD systems"; homepage = "https://libbsd.freedesktop.org/"; - license = with licenses; [ beerware bsd2 bsd3 bsdOriginal isc mit ]; + license = with licenses; [ + beerware + bsd2 + bsd3 + bsdOriginal + isc + mit + ]; platforms = platforms.unix; # See architectures defined in src/local-elf.h. badPlatforms = lib.platforms.microblaze; diff --git a/pkgs/by-name/li/libburn/package.nix b/pkgs/by-name/li/libburn/package.nix index 7085551c723888..4f3e60bf90ce1c 100644 --- a/pkgs/by-name/li/libburn/package.nix +++ b/pkgs/by-name/li/libburn/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitea -, autoreconfHook -, pkg-config +{ + lib, + stdenv, + fetchFromGitea, + autoreconfHook, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { @@ -22,7 +23,10 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; strictDeps = true; @@ -31,7 +35,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Library by which preformatted data get onto optical media: CD, DVD, BD (Blu-Ray)"; changelog = "https://dev.lovelyhq.com/libburnia/libburn/src/tag/${finalAttrs.src.rev}/ChangeLog"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ abbradar AndersonTorres ]; + maintainers = with lib.maintainers; [ + abbradar + AndersonTorres + ]; mainProgram = "cdrskin"; platforms = lib.platforms.unix; }; diff --git a/pkgs/by-name/li/libcaca/package.nix b/pkgs/by-name/li/libcaca/package.nix index 78b81bf49169ea..f9abf2a3970bcc 100644 --- a/pkgs/by-name/li/libcaca/package.nix +++ b/pkgs/by-name/li/libcaca/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, imlib2 -, xorg -, ncurses -, pkg-config -, zlib -, x11Support ? !stdenv.hostPlatform.isDarwin +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + imlib2, + xorg, + ncurses, + pkg-config, + zlib, + x11Support ? !stdenv.hostPlatform.isDarwin, }: stdenv.mkDerivation rec { @@ -26,25 +27,34 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - ncurses - zlib - (imlib2.override { inherit x11Support; }) - ] ++ lib.optionals x11Support [ - xorg.libX11 - xorg.libXext - ]; - - outputs = [ "bin" "dev" "out" "man" ]; + buildInputs = + [ + ncurses + zlib + (imlib2.override { inherit x11Support; }) + ] + ++ lib.optionals x11Support [ + xorg.libX11 + xorg.libXext + ]; - configureFlags = [ - (if x11Support then "--enable-x11" else "--disable-x11") - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # Suppresses a build failure building Cocoa support due to accessing private ivar `_running`, - # which no longer available. - (lib.enableFeature false "cocoa") + outputs = [ + "bin" + "dev" + "out" + "man" ]; + configureFlags = + [ + (if x11Support then "--enable-x11" else "--disable-x11") + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # Suppresses a build failure building Cocoa support due to accessing private ivar `_running`, + # which no longer available. + (lib.enableFeature false "cocoa") + ]; + env.NIX_CFLAGS_COMPILE = lib.optionalString (!x11Support) "-DX_DISPLAY_MISSING"; postInstall = '' diff --git a/pkgs/by-name/li/libcacard/package.nix b/pkgs/by-name/li/libcacard/package.nix index 1dd07a9d6ec2a1..3dfe6a7445baf9 100644 --- a/pkgs/by-name/li/libcacard/package.nix +++ b/pkgs/by-name/li/libcacard/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, nss }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + nss, +}: stdenv.mkDerivation rec { pname = "libcacard"; @@ -15,7 +22,10 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib nss ]; + buildInputs = [ + glib + nss + ]; meta = with lib; { description = "Smart card emulation library"; diff --git a/pkgs/by-name/li/libcamera/package.nix b/pkgs/by-name/li/libcamera/package.nix index cd056cbf3074af..5a20a665143126 100644 --- a/pkgs/by-name/li/libcamera/package.nix +++ b/pkgs/by-name/li/libcamera/package.nix @@ -1,26 +1,27 @@ -{ stdenv -, fetchgit -, lib -, meson -, ninja -, pkg-config -, makeFontsConf -, openssl -, libdrm -, libevent -, libyaml -, gst_all_1 -, gtest -, graphviz -, doxygen -, python3 -, python3Packages -, systemd # for libudev -, withTracing ? lib.meta.availableOn stdenv.hostPlatform lttng-ust -, lttng-ust # withTracing -, withQcam ? false -, qt6 # withQcam -, libtiff # withQcam +{ + stdenv, + fetchgit, + lib, + meson, + ninja, + pkg-config, + makeFontsConf, + openssl, + libdrm, + libevent, + libyaml, + gst_all_1, + gtest, + graphviz, + doxygen, + python3, + python3Packages, + systemd, # for libudev + withTracing ? lib.meta.availableOn stdenv.hostPlatform lttng-ust, + lttng-ust, # withTracing + withQcam ? false, + qt6, # withQcam + libtiff, # withQcam }: stdenv.mkDerivation rec { @@ -33,7 +34,10 @@ stdenv.mkDerivation rec { hash = "sha256-rW1BG5blozQKA73P5vH5dGkwQG5JJzxdOU2GCB3xIns="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postPatch = '' patchShebangs src/py/ utils/ @@ -57,30 +61,36 @@ stdenv.mkDerivation rec { strictDeps = true; - buildInputs = [ - # IPA and signing - openssl + buildInputs = + [ + # IPA and signing + openssl - # gstreamer integration - gst_all_1.gstreamer - gst_all_1.gst-plugins-base + # gstreamer integration + gst_all_1.gstreamer + gst_all_1.gst-plugins-base - # cam integration - libevent - libdrm + # cam integration + libevent + libdrm - # hotplugging - systemd + # hotplugging + systemd - # pycamera - python3Packages.pybind11 + # pycamera + python3Packages.pybind11 - # yamlparser - libyaml + # yamlparser + libyaml - gtest - ] ++ lib.optionals withTracing [ lttng-ust ] - ++ lib.optionals withQcam [ libtiff qt6.qtbase qt6.qttools ]; + gtest + ] + ++ lib.optionals withTracing [ lttng-ust ] + ++ lib.optionals withQcam [ + libtiff + qt6.qtbase + qt6.qttools + ]; nativeBuildInputs = [ meson diff --git a/pkgs/by-name/li/libcap_ng/package.nix b/pkgs/by-name/li/libcap_ng/package.nix index 478b5fa8ac2cc4..6435e5b676bfd6 100644 --- a/pkgs/by-name/li/libcap_ng/package.nix +++ b/pkgs/by-name/li/libcap_ng/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libcap-ng"; @@ -9,7 +13,11 @@ stdenv.mkDerivation rec { hash = "sha256-O6UpTRy9+pivqs+8ALavntK4PoohgXGF39hEzIx6xv8="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; configureFlags = [ "--without-python" diff --git a/pkgs/by-name/li/libcaption/package.nix b/pkgs/by-name/li/libcaption/package.nix index 0070aa3524eecd..8218389e430424 100644 --- a/pkgs/by-name/li/libcaption/package.nix +++ b/pkgs/by-name/li/libcaption/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, re2c +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + re2c, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/libcardiacarrest/package.nix b/pkgs/by-name/li/libcardiacarrest/package.nix index 4c0d0fa97ad11c..54a80da8611e5b 100644 --- a/pkgs/by-name/li/libcardiacarrest/package.nix +++ b/pkgs/by-name/li/libcardiacarrest/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, glib, libpulseaudio }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + glib, + libpulseaudio, +}: stdenv.mkDerivation rec { pname = "libcardiacarrest"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "0vrigwcw3g8zknqyznv6y3437ahn1w00gv3d303smmygr0p8bd94"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ pkg-config ]; @@ -25,22 +35,25 @@ stdenv.mkDerivation rec { moveToOutput $out/lib/cmake $dev ''; - meta = with lib; src.meta // { - description = "Trivial implementation of libpulse PulseAudio library API"; - longDescription = '' - libcardiacarrest is a trivial implementation of libpulse - PulseAudio library API that unconditionally (but gracefully) - fails to connect to the PulseAudio daemon and does nothing else. - - apulse and pressureaudio (which uses apulse internally) are an - inspiration for this but unlike those two projects - libcardiacarrest is not an emulation layer, all it does is it - gracefully fails to provide the requested PulseAudio service - hoping the application would try something else (e.g. ALSA or - JACK). - ''; - license = libpulseaudio.meta.license; # "same as PA headers" - maintainers = [ maintainers.oxij ]; # also the author - }; + meta = + with lib; + src.meta + // { + description = "Trivial implementation of libpulse PulseAudio library API"; + longDescription = '' + libcardiacarrest is a trivial implementation of libpulse + PulseAudio library API that unconditionally (but gracefully) + fails to connect to the PulseAudio daemon and does nothing else. + + apulse and pressureaudio (which uses apulse internally) are an + inspiration for this but unlike those two projects + libcardiacarrest is not an emulation layer, all it does is it + gracefully fails to provide the requested PulseAudio service + hoping the application would try something else (e.g. ALSA or + JACK). + ''; + license = libpulseaudio.meta.license; # "same as PA headers" + maintainers = [ maintainers.oxij ]; # also the author + }; } diff --git a/pkgs/by-name/li/libcbor/package.nix b/pkgs/by-name/li/libcbor/package.nix index 673885b096e452..96481722474cdb 100644 --- a/pkgs/by-name/li/libcbor/package.nix +++ b/pkgs/by-name/li/libcbor/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, cmocka - -# for passthru.tests -, libfido2 -, mysql80 -, openssh -, systemd +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + cmocka, + + # for passthru.tests + libfido2, + mysql80, + openssh, + systemd, }: stdenv.mkDerivation (finalAttrs: { @@ -22,7 +23,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-N1xYkZw/6lX/nX/TE6/pVuEFgSyDiUJ50msK42NrKwI="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; strictDeps = true; nativeBuildInputs = [ cmake ]; @@ -31,23 +35,25 @@ stdenv.mkDerivation (finalAttrs: { cmocka # cmake expects cmocka module ]; - cmakeFlags = lib.optional finalAttrs.finalPackage.doCheck "-DWITH_TESTS=ON" + cmakeFlags = + lib.optional finalAttrs.finalPackage.doCheck "-DWITH_TESTS=ON" ++ lib.optional (!stdenv.hostPlatform.isStatic) "-DBUILD_SHARED_LIBS=ON"; # Tests are restricted while pkgsStatic.cmocka is broken. Tracked at: # https://github.com/NixOS/nixpkgs/issues/213623 - doCheck = !stdenv.hostPlatform.isStatic - && stdenv.hostPlatform == stdenv.buildPlatform; + doCheck = !stdenv.hostPlatform.isStatic && stdenv.hostPlatform == stdenv.buildPlatform; nativeCheckInputs = [ cmocka ]; passthru.tests = { inherit libfido2 mysql80; openssh = (openssh.override { withFIDO = true; }); - systemd = (systemd.override { - withFido2 = true; - withCryptsetup = true; - }); + systemd = ( + systemd.override { + withFido2 = true; + withCryptsetup = true; + } + ); }; meta = with lib; { diff --git a/pkgs/by-name/li/libccd/package.nix b/pkgs/by-name/li/libccd/package.nix index c8e7c8af210486..67eaa7eba25ea2 100644 --- a/pkgs/by-name/li/libccd/package.nix +++ b/pkgs/by-name/li/libccd/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, +}: stdenv.mkDerivation rec { pname = "libccd"; diff --git a/pkgs/by-name/li/libcdada/package.nix b/pkgs/by-name/li/libcdada/package.nix index bb0593c1bf0232..e944a448710e52 100644 --- a/pkgs/by-name/li/libcdada/package.nix +++ b/pkgs/by-name/li/libcdada/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libcdaudio/package.nix b/pkgs/by-name/li/libcdaudio/package.nix index 8e7bb7e2964a9f..eb21424d349c80 100644 --- a/pkgs/by-name/li/libcdaudio/package.nix +++ b/pkgs/by-name/li/libcdaudio/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libcdaudio"; @@ -6,7 +10,7 @@ stdenv.mkDerivation rec { src = fetchurl { url = "mirror://sourceforge/libcdaudio/libcdaudio-${version}.tar.gz"; - sha256 = "1fsy6dlzxrx177qc877qhajm9l4g28mvh06h2l15rxy4bapzknjz" ; + sha256 = "1fsy6dlzxrx177qc877qhajm9l4g28mvh06h2l15rxy4bapzknjz"; }; meta = { diff --git a/pkgs/by-name/li/libcddb/package.nix b/pkgs/by-name/li/libcddb/package.nix index 56459fe07d4f54..0830491431cb87 100644 --- a/pkgs/by-name/li/libcddb/package.nix +++ b/pkgs/by-name/li/libcddb/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libiconv }: +{ + lib, + stdenv, + fetchurl, + libiconv, +}: stdenv.mkDerivation rec { pname = "libcddb"; diff --git a/pkgs/by-name/li/libcello/package.nix b/pkgs/by-name/li/libcello/package.nix index b2f3fc5fae5be0..b7167529030929 100644 --- a/pkgs/by-name/li/libcello/package.nix +++ b/pkgs/by-name/li/libcello/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libcello"; diff --git a/pkgs/by-name/li/libcerf/package.nix b/pkgs/by-name/li/libcerf/package.nix index 92fd70bb0cc634..cd02eee33e70c5 100644 --- a/pkgs/by-name/li/libcerf/package.nix +++ b/pkgs/by-name/li/libcerf/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchurl, cmake, perl, gnuplot }: +{ + stdenv, + lib, + fetchurl, + cmake, + perl, + gnuplot, +}: stdenv.mkDerivation rec { pname = "libcerf"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-CAswrlZMPavjuJJkUira9WR+x1QCFXK+5UkpaXsnbNw="; }; - nativeBuildInputs = [ cmake perl ]; + nativeBuildInputs = [ + cmake + perl + ]; passthru.tests = { inherit gnuplot; diff --git a/pkgs/by-name/li/libcgroup/package.nix b/pkgs/by-name/li/libcgroup/package.nix index e86e989ba8887b..1f286741ef0e0f 100644 --- a/pkgs/by-name/li/libcgroup/package.nix +++ b/pkgs/by-name/li/libcgroup/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, pam, bison, flex, systemdLibs, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + pam, + bison, + flex, + systemdLibs, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libcgroup"; @@ -12,8 +21,15 @@ stdenv.mkDerivation rec { hash = "sha256-CnejQcOyW3QzHuvsAdKe4M4XgmG9ufRaEBdO48+8ZqQ="; }; - nativeBuildInputs = [ autoreconfHook bison flex ]; - buildInputs = [ pam systemdLibs ]; + nativeBuildInputs = [ + autoreconfHook + bison + flex + ]; + buildInputs = [ + pam + systemdLibs + ]; postPatch = '' substituteInPlace src/tools/Makefile.am \ @@ -22,9 +38,9 @@ stdenv.mkDerivation rec { meta = { description = "Library and tools to manage Linux cgroups"; - homepage = "https://github.com/libcgroup/libcgroup"; - license = lib.licenses.lgpl2; - platforms = lib.platforms.linux; + homepage = "https://github.com/libcgroup/libcgroup"; + license = lib.licenses.lgpl2; + platforms = lib.platforms.linux; maintainers = [ lib.maintainers.thoughtpolice ]; }; } diff --git a/pkgs/by-name/li/libchamplain/package.nix b/pkgs/by-name/li/libchamplain/package.nix index fc228f4d6a9442..fee33071d43921 100644 --- a/pkgs/by-name/li/libchamplain/package.nix +++ b/pkgs/by-name/li/libchamplain/package.nix @@ -1,48 +1,53 @@ -{ fetchurl -, lib -, stdenv -, meson -, ninja -, vala -, gtk-doc -, docbook_xsl -, docbook_xml_dtd_412 -, pkg-config -, glib -, gtk3 -, cairo -, sqlite -, gnome -, clutter-gtk -, libsoup_2_4 -, libsoup_3 -, gobject-introspection /*, libmemphis */ -, withLibsoup3 ? false +{ + fetchurl, + lib, + stdenv, + meson, + ninja, + vala, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_412, + pkg-config, + glib, + gtk3, + cairo, + sqlite, + gnome, + clutter-gtk, + libsoup_2_4, + libsoup_3, + gobject-introspection, # , libmemphis + withLibsoup3 ? false, }: stdenv.mkDerivation rec { pname = "libchamplain"; version = "0.12.21"; - outputs = [ "out" "dev" ] - ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ "devdoc" ]; + outputs = [ + "out" + "dev" + ] ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ "devdoc" ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; sha256 = "qRXNFyoMUpRMVXn8tGg/ioeMVxv16SglS12v78cn5ac="; }; - nativeBuildInputs = [ - meson - ninja - pkg-config - gobject-introspection - vala - ] ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ - gtk-doc - docbook_xsl - docbook_xml_dtd_412 - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gobject-introspection + vala + ] + ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ + gtk-doc + docbook_xsl + docbook_xml_dtd_412 + ]; buildInputs = [ sqlite diff --git a/pkgs/by-name/li/libchardet/package.nix b/pkgs/by-name/li/libchardet/package.nix index 9152038e16817c..ba922c6f98cf08 100644 --- a/pkgs/by-name/li/libchardet/package.nix +++ b/pkgs/by-name/li/libchardet/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + perl, +}: stdenv.mkDerivation rec { pname = "libchardet"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-JhEiWM3q8X+eEBHxv8k9yYOaTGoJOzI+/iFYC0gZJJs="; }; - nativeBuildInputs = [ autoreconfHook perl ]; + nativeBuildInputs = [ + autoreconfHook + perl + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/li/libchop/package.nix b/pkgs/by-name/li/libchop/package.nix index 996c92ef20fcf7..83d064ef08fbae 100644 --- a/pkgs/by-name/li/libchop/package.nix +++ b/pkgs/by-name/li/libchop/package.nix @@ -1,6 +1,21 @@ -{ fetchurl, lib, stdenv, zlib, bzip2, libgcrypt -, gdbm, gperf, tdb, gnutls, db, libuuid -, lzo, pkg-config, guile, rpcsvc-proto, libtirpc +{ + fetchurl, + lib, + stdenv, + zlib, + bzip2, + libgcrypt, + gdbm, + gperf, + tdb, + gnutls, + db, + libuuid, + lzo, + pkg-config, + guile, + rpcsvc-proto, + libtirpc, }: stdenv.mkDerivation rec { @@ -12,20 +27,34 @@ stdenv.mkDerivation rec { sha256 = "0fpdyxww41ba52d98blvnf543xvirq1v9xz1i3x1gm9lzlzpmc2g"; }; - patches = [ ./gets-undeclared.patch ./size_t.patch ./0001-Fix-RPC-compilation-when-using-libtirpc-rather-than-.patch ]; + patches = [ + ./gets-undeclared.patch + ./size_t.patch + ./0001-Fix-RPC-compilation-when-using-libtirpc-rather-than-.patch + ]; - nativeBuildInputs = [ pkg-config gperf rpcsvc-proto ]; + nativeBuildInputs = [ + pkg-config + gperf + rpcsvc-proto + ]; env.NIX_CFLAGS_COMPILE = toString [ "-I${libtirpc.dev}/include/tirpc" ]; NIX_LDFLAGS = [ "-ltirpc" ]; - buildInputs = - [ zlib bzip2 lzo - libgcrypt - gdbm db tdb - gnutls libuuid - guile libtirpc - ]; + buildInputs = [ + zlib + bzip2 + lzo + libgcrypt + gdbm + db + tdb + gnutls + libuuid + guile + libtirpc + ]; doCheck = false; diff --git a/pkgs/by-name/li/libcint/package.nix b/pkgs/by-name/li/libcint/package.nix index caa7e51336a4c6..a8460668b90859 100644 --- a/pkgs/by-name/li/libcint/package.nix +++ b/pkgs/by-name/li/libcint/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, blas +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + blas, # Check Inputs -, python3 + python3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libcircle/package.nix b/pkgs/by-name/li/libcircle/package.nix index 1ff33ac1ac216d..fc59d955226cc9 100644 --- a/pkgs/by-name/li/libcircle/package.nix +++ b/pkgs/by-name/li/libcircle/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, mpi +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + mpi, }: stdenv.mkDerivation rec { @@ -17,9 +18,15 @@ stdenv.mkDerivation rec { hash = "sha256-EfnoNL6wo6qQES6XzMtpTpYcsJ8V2gy32i26wiTldH0="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; propagatedBuildInputs = [ mpi ]; diff --git a/pkgs/by-name/li/libck/package.nix b/pkgs/by-name/li/libck/package.nix index 71937b2a658ec2..68534337344127 100644 --- a/pkgs/by-name/li/libck/package.nix +++ b/pkgs/by-name/li/libck/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "ck"; @@ -19,7 +23,7 @@ stdenv.mkDerivation rec { "COMPILER=gcc" ''; - configureFlags = ["--platform=${stdenv.hostPlatform.parsed.cpu.name}}"]; + configureFlags = [ "--platform=${stdenv.hostPlatform.parsed.cpu.name}}" ]; dontDisableStatic = true; @@ -28,9 +32,15 @@ stdenv.mkDerivation rec { longDescription = '' Concurrency primitives, safe memory reclamation mechanisms and non-blocking data structures for the research, design and implementation of high performance concurrent systems. ''; - license = with licenses; [ asl20 bsd2 ]; + license = with licenses; [ + asl20 + bsd2 + ]; homepage = "http://concurrencykit.org/"; platforms = platforms.unix; - maintainers = with maintainers; [ chessai thoughtpolice ]; + maintainers = with maintainers; [ + chessai + thoughtpolice + ]; }; } diff --git a/pkgs/by-name/li/libcli/package.nix b/pkgs/by-name/li/libcli/package.nix index 982d34f1bdce4c..71aca93bf84b8b 100644 --- a/pkgs/by-name/li/libcli/package.nix +++ b/pkgs/by-name/li/libcli/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl, libxcrypt }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "libcli"; @@ -11,18 +17,22 @@ stdenv.mkDerivation rec { owner = "dparrish"; }; - patches = - [ (fetchurl { - url = "https://github.com/dparrish/libcli/commit/ebc5a09db457ee1be9996711463cbbafe5ea72d5.patch"; - sha256 = "0szjiw3gd7by1sv924shnngfxvc98xvaqvx228b575xq93xxjcwl"; - }) - ]; + patches = [ + (fetchurl { + url = "https://github.com/dparrish/libcli/commit/ebc5a09db457ee1be9996711463cbbafe5ea72d5.patch"; + sha256 = "0szjiw3gd7by1sv924shnngfxvc98xvaqvx228b575xq93xxjcwl"; + }) + ]; buildInputs = [ libxcrypt ]; enableParallelBuilding = true; - makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "AR=${stdenv.cc.targetPrefix}ar" "PREFIX=$(out)" ]; + makeFlags = [ + "CC=${stdenv.cc.targetPrefix}cc" + "AR=${stdenv.cc.targetPrefix}ar" + "PREFIX=$(out)" + ]; env.NIX_CFLAGS_COMPILE = toString [ # Needed with GCC 12 diff --git a/pkgs/by-name/li/libclipboard/package.nix b/pkgs/by-name/li/libclipboard/package.nix index eec120bcd62d57..e0eb69704199d1 100644 --- a/pkgs/by-name/li/libclipboard/package.nix +++ b/pkgs/by-name/li/libclipboard/package.nix @@ -7,7 +7,7 @@ libXau, libXdmcp, darwin, - lib + lib, }: stdenv.mkDerivation (finalAttrs: { @@ -21,12 +21,21 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-553hNG8QUlt/Aff9EKYr6w279ELr+2MX7nh1SKIklhA="; }; - buildInputs = [ libxcb libXau libXdmcp ] - ++ lib.optional stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Cocoa ]; - nativeBuildInputs = [ cmake pkg-config ]; + buildInputs = [ + libxcb + libXau + libXdmcp + ] ++ lib.optional stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Cocoa ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; cmakeFlags = [ "-DBUILD_SHARED_LIBS=ON" ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = { description = "Lightweight cross-platform clipboard library"; diff --git a/pkgs/by-name/li/libcloudproviders/package.nix b/pkgs/by-name/li/libcloudproviders/package.nix index 8b6722d9cde7d9..c69a9ecc6cee7d 100644 --- a/pkgs/by-name/li/libcloudproviders/package.nix +++ b/pkgs/by-name/li/libcloudproviders/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, gobject-introspection -, vala -, gtk-doc -, docbook_xsl -, glib -, mesonEmulatorHook -, gnome +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + gobject-introspection, + vala, + gtk-doc, + docbook_xsl, + glib, + mesonEmulatorHook, + gnome, }: # TODO: Add installed tests once https://gitlab.gnome.org/World/libcloudproviders/issues/4 is fixed @@ -24,24 +25,30 @@ stdenv.mkDerivation rec { hash = "sha256-O3URCzpP3vTFxaRA5IcB/gVNKuBh0VbIkTa7W6BedLc="; }; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; mesonFlags = [ "-Denable-gtk-doc=true" ]; strictDeps = true; - nativeBuildInputs = [ - meson - ninja - pkg-config - gobject-introspection - vala - gtk-doc - docbook_xsl - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gobject-introspection + vala + gtk-doc + docbook_xsl + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ glib ]; diff --git a/pkgs/by-name/li/libclthreads/package.nix b/pkgs/by-name/li/libclthreads/package.nix index e4548420a05762..db0183c7e21a42 100644 --- a/pkgs/by-name/li/libclthreads/package.nix +++ b/pkgs/by-name/li/libclthreads/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libclthreads"; diff --git a/pkgs/by-name/li/libclxclient/package.nix b/pkgs/by-name/li/libclxclient/package.nix index 40f259677ff4e6..1aea861ea1a92c 100644 --- a/pkgs/by-name/li/libclxclient/package.nix +++ b/pkgs/by-name/li/libclxclient/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, libclthreads, libX11, libXft, xorg, pkg-config }: +{ + lib, + stdenv, + fetchurl, + libclthreads, + libX11, + libXft, + xorg, + pkg-config, +}: stdenv.mkDerivation rec { pname = "libclxclient"; @@ -9,7 +18,12 @@ stdenv.mkDerivation rec { sha256 = "10bq6fy8d3pr1x2x3xx9qhf2hdxrwdgvg843a2y6lx70y1jfj0c5"; }; - buildInputs = [ libclthreads libX11 libXft xorg.xorgproto ]; + buildInputs = [ + libclthreads + libX11 + libXft + xorg.xorgproto + ]; nativeBuildInputs = [ pkg-config ]; diff --git a/pkgs/by-name/li/libcmis/package.nix b/pkgs/by-name/li/libcmis/package.nix index 52da3719991944..f125d1f9bb00b3 100644 --- a/pkgs/by-name/li/libcmis/package.nix +++ b/pkgs/by-name/li/libcmis/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, boost, libxml2, pkg-config, docbook2x, curl, autoreconfHook, cppunit }: +{ + lib, + stdenv, + fetchFromGitHub, + boost, + libxml2, + pkg-config, + docbook2x, + curl, + autoreconfHook, + cppunit, +}: stdenv.mkDerivation rec { pname = "libcmis"; @@ -11,8 +22,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-HXiyQKjOlQXWABY10XrOiYxPqfpmUJC3a6xD98LIHDw="; }; - nativeBuildInputs = [ autoreconfHook pkg-config docbook2x ]; - buildInputs = [ boost libxml2 curl cppunit ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + docbook2x + ]; + buildInputs = [ + boost + libxml2 + curl + cppunit + ]; configureFlags = [ "--disable-werror" diff --git a/pkgs/by-name/li/libcollectdclient/package.nix b/pkgs/by-name/li/libcollectdclient/package.nix index 41c5565482fe72..ae8b2dc671fc48 100644 --- a/pkgs/by-name/li/libcollectdclient/package.nix +++ b/pkgs/by-name/li/libcollectdclient/package.nix @@ -5,7 +5,7 @@ collectd.overrideAttrs (oldAttrs: { inherit (collectd) version; buildInputs = [ ]; - configureFlags = (oldAttrs.configureFlags or []) ++ [ + configureFlags = (oldAttrs.configureFlags or [ ]) ++ [ "--disable-daemon" "--disable-all-plugins" ]; @@ -17,6 +17,9 @@ collectd.overrideAttrs (oldAttrs: { homepage = "http://collectd.org"; license = licenses.gpl2; platforms = platforms.linux; # TODO: collectd may be linux but the C client may be more portable? - maintainers = [ maintainers.sheenobu maintainers.bjornfor ]; + maintainers = [ + maintainers.sheenobu + maintainers.bjornfor + ]; }; }) diff --git a/pkgs/by-name/li/libconfuse/package.nix b/pkgs/by-name/li/libconfuse/package.nix index 91a5a2f26f87d4..3a13c2a6778041 100644 --- a/pkgs/by-name/li/libconfuse/package.nix +++ b/pkgs/by-name/li/libconfuse/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, flex +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + flex, }: stdenv.mkDerivation rec { @@ -35,7 +36,10 @@ stdenv.mkDerivation rec { --replace 'TESTS += print_filter' "" ''; - nativeBuildInputs = [ autoreconfHook flex ]; + nativeBuildInputs = [ + autoreconfHook + flex + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/li/libcork/package.nix b/pkgs/by-name/li/libcork/package.nix index c013775fcaeb0b..e5f71c009db1f6 100644 --- a/pkgs/by-name/li/libcork/package.nix +++ b/pkgs/by-name/li/libcork/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, fetchFromGitHub -, cmake -, lib -, pkg-config -, check +{ + stdenv, + fetchFromGitHub, + cmake, + lib, + pkg-config, + check, }: stdenv.mkDerivation rec { pname = "libcork"; @@ -32,7 +33,10 @@ stdenv.mkDerivation rec { --replace '\$'{datarootdir}/'$'{base_docdir} '$'{CMAKE_INSTALL_FULL_DOCDIR} ''; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ check ]; doCheck = false; diff --git a/pkgs/by-name/li/libcotp/package.nix b/pkgs/by-name/li/libcotp/package.nix index 8b24f4250b5cb5..28f92f6b45fa6d 100644 --- a/pkgs/by-name/li/libcotp/package.nix +++ b/pkgs/by-name/li/libcotp/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, cmake, pkg-config, libgcrypt }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + libgcrypt, +}: stdenv.mkDerivation rec { pname = "libcotp"; @@ -17,7 +24,10 @@ stdenv.mkDerivation rec { ''; buildInputs = [ libgcrypt ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; meta = with lib; { description = "C library that generates TOTP and HOTP"; diff --git a/pkgs/by-name/li/libcrafter/package.nix b/pkgs/by-name/li/libcrafter/package.nix index 029bec5630bf43..d53e5e3c917c26 100644 --- a/pkgs/by-name/li/libcrafter/package.nix +++ b/pkgs/by-name/li/libcrafter/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libtool, libpcap }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + libpcap, +}: stdenv.mkDerivation rec { pname = "libcrafter"; @@ -17,7 +25,10 @@ stdenv.mkDerivation rec { configureFlags = [ "--with-libpcap=yes" ]; - nativeBuildInputs = [ autoconf automake ]; + nativeBuildInputs = [ + autoconf + automake + ]; buildInputs = [ libtool ]; propagatedBuildInputs = [ libpcap ]; diff --git a/pkgs/by-name/li/libcredis/package.nix b/pkgs/by-name/li/libcredis/package.nix index 3515bce2da207f..28103abe29e674 100644 --- a/pkgs/by-name/li/libcredis/package.nix +++ b/pkgs/by-name/li/libcredis/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libcredis"; diff --git a/pkgs/by-name/li/libcrossguid/package.nix b/pkgs/by-name/li/libcrossguid/package.nix index c81dbb86f6a05d..3a165303f5ad31 100644 --- a/pkgs/by-name/li/libcrossguid/package.nix +++ b/pkgs/by-name/li/libcrossguid/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libuuid }: +{ + lib, + stdenv, + fetchFromGitHub, + libuuid, +}: stdenv.mkDerivation rec { name = "lib" + pname + "-" + version; diff --git a/pkgs/by-name/li/libcs50/package.nix b/pkgs/by-name/li/libcs50/package.nix index a7dd7c6879b5e3..becca7221ef6ff 100644 --- a/pkgs/by-name/li/libcs50/package.nix +++ b/pkgs/by-name/li/libcs50/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation (finalAttrs: { pname = "libcs50"; diff --git a/pkgs/by-name/li/libcsptr/package.nix b/pkgs/by-name/li/libcsptr/package.nix index a8f33deda36c66..d055ec74479f7d 100644 --- a/pkgs/by-name/li/libcsptr/package.nix +++ b/pkgs/by-name/li/libcsptr/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "libcsptr"; diff --git a/pkgs/by-name/li/libctb/package.nix b/pkgs/by-name/li/libctb/package.nix index d52adac556d846..4e5ea342e3bc5d 100644 --- a/pkgs/by-name/li/libctb/package.nix +++ b/pkgs/by-name/li/libctb/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libctb"; version = "0.16"; diff --git a/pkgs/by-name/li/libctemplate/package.nix b/pkgs/by-name/li/libctemplate/package.nix index 816bbe41708a91..11c2323806d51a 100644 --- a/pkgs/by-name/li/libctemplate/package.nix +++ b/pkgs/by-name/li/libctemplate/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, python3, autoconf, automake, libtool }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + autoconf, + automake, + libtool, +}: stdenv.mkDerivation rec { pname = "ctemplate"; @@ -11,7 +19,12 @@ stdenv.mkDerivation rec { sha256 = "1x0p5yym6vvcx70pm8ihnbxxrl2wnblfp72ih5vjyg8mzkc8cxrr"; }; - nativeBuildInputs = [ python3 autoconf automake libtool ]; + nativeBuildInputs = [ + python3 + autoconf + automake + libtool + ]; postPatch = '' patchShebangs . diff --git a/pkgs/by-name/li/libctl/package.nix b/pkgs/by-name/li/libctl/package.nix index 6969f6166beb87..e9b459b8aa5374 100644 --- a/pkgs/by-name/li/libctl/package.nix +++ b/pkgs/by-name/li/libctl/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, gfortran -, guile -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gfortran, + guile, + pkg-config, }: stdenv.mkDerivation rec { @@ -18,7 +19,12 @@ stdenv.mkDerivation rec { sha256 = "uOydBWYPXSBUi+4MM6FNx6B5l2to7Ny9Uc1MMTV9bGA="; }; - nativeBuildInputs = [ autoreconfHook gfortran guile pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + gfortran + guile + pkg-config + ]; configureFlags = [ "--enable-shared" ]; diff --git a/pkgs/by-name/li/libcue/package.nix b/pkgs/by-name/li/libcue/package.nix index ec7f1ba26ab1ef..e21cbea7216170 100644 --- a/pkgs/by-name/li/libcue/package.nix +++ b/pkgs/by-name/li/libcue/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, bison, flex }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + bison, + flex, +}: stdenv.mkDerivation rec { pname = "libcue"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { hash = "sha256-ZMUUa8CmpFNparPsM/P2yvRto9E85EdTxpID5sKQbNI="; }; - nativeBuildInputs = [ cmake bison flex ]; + nativeBuildInputs = [ + cmake + bison + flex + ]; doCheck = true; diff --git a/pkgs/by-name/li/libcyaml/package.nix b/pkgs/by-name/li/libcyaml/package.nix index a1bbd17753cab9..beb458f400fc35 100644 --- a/pkgs/by-name/li/libcyaml/package.nix +++ b/pkgs/by-name/li/libcyaml/package.nix @@ -1,5 +1,8 @@ -{ stdenv, lib, fetchFromGitHub -, libyaml +{ + stdenv, + lib, + fetchFromGitHub, + libyaml, }: stdenv.mkDerivation rec { @@ -15,7 +18,10 @@ stdenv.mkDerivation rec { buildInputs = [ libyaml ]; - makeFlags = [ "VARIANT=release" "PREFIX=$(out)" ]; + makeFlags = [ + "VARIANT=release" + "PREFIX=$(out)" + ]; meta = with lib; { homepage = "https://github.com/tlsa/libcyaml"; diff --git a/pkgs/by-name/li/libdaemon/package.nix b/pkgs/by-name/li/libdaemon/package.nix index 112792454c43c7..796cb02ea03fde 100644 --- a/pkgs/by-name/li/libdaemon/package.nix +++ b/pkgs/by-name/li/libdaemon/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libdaemon"; @@ -9,13 +13,18 @@ stdenv.mkDerivation rec { sha256 = "0d5qlq5ab95wh1xc87rqrh1vx6i8lddka1w3f1zcqvcqdxgyn8zx"; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; patches = [ ./fix-includes.patch ]; - configureFlags = [ "--disable-lynx" ] - ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) - [ # Can't run this test while cross-compiling + configureFlags = + [ "--disable-lynx" ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + # Can't run this test while cross-compiling "ac_cv_func_setpgrp_void=yes" ]; diff --git a/pkgs/by-name/li/libdatovka/package.nix b/pkgs/by-name/li/libdatovka/package.nix index 9b0f4f2d59e8bd..3f7bbef3c1a8d1 100644 --- a/pkgs/by-name/li/libdatovka/package.nix +++ b/pkgs/by-name/li/libdatovka/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, autoreconfHook -, pkg-config -, fetchurl -, expat -, gpgme -, libgcrypt -, libxml2 -, libxslt -, gnutls -, curl -, docbook_xsl +{ + lib, + stdenv, + autoreconfHook, + pkg-config, + fetchurl, + expat, + gpgme, + libgcrypt, + libxml2, + libxslt, + gnutls, + curl, + docbook_xsl, }: stdenv.mkDerivation rec { @@ -30,8 +31,20 @@ stdenv.mkDerivation rec { "--with-docbook-xsl-stylesheets=${docbook_xsl}/xml/xsl/docbook" ]; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ expat gpgme libgcrypt libxml2 libxslt gnutls curl docbook_xsl ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + expat + gpgme + libgcrypt + libxml2 + libxslt + gnutls + curl + docbook_xsl + ]; meta = with lib; { description = "Client library for accessing SOAP services of Czech government-provided Databox infomation system"; diff --git a/pkgs/by-name/li/libdatrie/package.nix b/pkgs/by-name/li/libdatrie/package.nix index e810da2e96cdeb..9c22e4a46ca651 100644 --- a/pkgs/by-name/li/libdatrie/package.nix +++ b/pkgs/by-name/li/libdatrie/package.nix @@ -1,13 +1,24 @@ -{ lib, stdenv, fetchFromGitHub -, autoreconfHook, autoconf-archive -, installShellFiles, libiconv }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + autoconf-archive, + installShellFiles, + libiconv, +}: stdenv.mkDerivation rec { pname = "libdatrie"; version = "2019-12-20"; - outputs = [ "bin" "out" "lib" "dev" ]; + outputs = [ + "bin" + "out" + "lib" + "dev" + ]; src = fetchFromGitHub { owner = "tlwg"; @@ -24,13 +35,14 @@ stdenv.mkDerivation rec { buildInputs = [ libiconv ]; - preAutoreconf = let - reports = "https://github.com/tlwg/libdatrie/issues"; - in - '' - sed -i -e "/AC_INIT/,+3d" configure.ac - sed -i "5iAC_INIT(${pname},${version},[${reports}])" configure.ac - ''; + preAutoreconf = + let + reports = "https://github.com/tlwg/libdatrie/issues"; + in + '' + sed -i -e "/AC_INIT/,+3d" configure.ac + sed -i "5iAC_INIT(${pname},${version},[${reports}])" configure.ac + ''; postInstall = '' installManPage man/trietool.1 diff --git a/pkgs/by-name/li/libdazzle/package.nix b/pkgs/by-name/li/libdazzle/package.nix index 08b286c825cf64..7c54966532148e 100644 --- a/pkgs/by-name/li/libdazzle/package.nix +++ b/pkgs/by-name/li/libdazzle/package.nix @@ -1,28 +1,33 @@ -{ lib -, stdenv -, fetchurl -, ninja -, meson -, mesonEmulatorHook -, pkg-config -, vala -, gobject-introspection -, libxml2 -, gtk-doc -, docbook_xsl -, docbook_xml_dtd_43 -, dbus -, xvfb-run -, glib -, gtk3 -, gnome +{ + lib, + stdenv, + fetchurl, + ninja, + meson, + mesonEmulatorHook, + pkg-config, + vala, + gobject-introspection, + libxml2, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_43, + dbus, + xvfb-run, + glib, + gtk3, + gnome, }: stdenv.mkDerivation rec { pname = "libdazzle"; version = "3.44.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "dev"; src = fetchurl { @@ -30,23 +35,26 @@ stdenv.mkDerivation rec { sha256 = "PNPkXrbiaAywXVLh6A3Y+dWdR2UhLw4o945sF4PRjq4="; }; - nativeBuildInputs = [ - ninja - meson - pkg-config - vala - gobject-introspection - libxml2 - gtk-doc - docbook_xsl - docbook_xml_dtd_43 - dbus - glib - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - xvfb-run - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + ninja + meson + pkg-config + vala + gobject-introspection + libxml2 + gtk-doc + docbook_xsl + docbook_xml_dtd_43 + dbus + glib + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + xvfb-run + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ glib diff --git a/pkgs/by-name/li/libdbi/package.nix b/pkgs/by-name/li/libdbi/package.nix index f0cb74cb86d07c..44cd2e99f8c107 100644 --- a/pkgs/by-name/li/libdbi/package.nix +++ b/pkgs/by-name/li/libdbi/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libdbi"; diff --git a/pkgs/by-name/li/libdbiDrivers/package.nix b/pkgs/by-name/li/libdbiDrivers/package.nix index 6537e3ae2a3e8e..66edca677d6c47 100644 --- a/pkgs/by-name/li/libdbiDrivers/package.nix +++ b/pkgs/by-name/li/libdbiDrivers/package.nix @@ -1,8 +1,12 @@ -{ lib, stdenv, fetchurl, libdbi -# TODO: migrate away from overriding packages to null -, libmysqlclient ? null -, sqlite ? null -, postgresql ? null +{ + lib, + stdenv, + fetchurl, + libdbi, + # TODO: migrate away from overriding packages to null + libmysqlclient ? null, + sqlite ? null, + postgresql ? null, }: stdenv.mkDerivation rec { @@ -14,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "0m680h8cc4428xin4p733azysamzgzcmv4psjvraykrsaz6ymlj3"; }; - buildInputs = [ libdbi sqlite postgresql ] ++ lib.optional (libmysqlclient != null) libmysqlclient; + buildInputs = [ + libdbi + sqlite + postgresql + ] ++ lib.optional (libmysqlclient != null) libmysqlclient; patches = [ # https://sourceforge.net/p/libdbi-drivers/libdbi-drivers/ci/24f48b86c8988ee3aaebc5f303d71e9d789f77b6 @@ -25,29 +33,35 @@ stdenv.mkDerivation rec { sed -i '/SQLITE3_LIBS/ s/-lsqlite/-lsqlite3/' configure; ''; - configureFlags = [ - "--sysconfdir=/etc" - "--localstatedir=/var" - "--disable-docs" - "--enable-libdbi" - "--with-dbi-incdir=${libdbi}/include" - "--with-dbi-libdir=${libdbi}/lib" - ] ++ lib.optionals (libmysqlclient != null) [ - "--with-mysql" - "--with-mysql-incdir=${lib.getDev libmysqlclient}/include/mysql" - "--with-mysql-libdir=${libmysqlclient}/lib/mysql" - ] ++ lib.optionals (sqlite != null) [ - "--with-sqlite3" - "--with-sqlite3-incdir=${sqlite.dev}/include/sqlite" - "--with-sqlite3-libdir=${sqlite.out}/lib/sqlite" - ] ++ lib.optionals (postgresql != null) [ - "--with-pgsql" - ]; + configureFlags = + [ + "--sysconfdir=/etc" + "--localstatedir=/var" + "--disable-docs" + "--enable-libdbi" + "--with-dbi-incdir=${libdbi}/include" + "--with-dbi-libdir=${libdbi}/lib" + ] + ++ lib.optionals (libmysqlclient != null) [ + "--with-mysql" + "--with-mysql-incdir=${lib.getDev libmysqlclient}/include/mysql" + "--with-mysql-libdir=${libmysqlclient}/lib/mysql" + ] + ++ lib.optionals (sqlite != null) [ + "--with-sqlite3" + "--with-sqlite3-incdir=${sqlite.dev}/include/sqlite" + "--with-sqlite3-libdir=${sqlite.out}/lib/sqlite" + ] + ++ lib.optionals (postgresql != null) [ + "--with-pgsql" + ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-error=incompatible-function-pointer-types" - "-Wno-error=int-conversion" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-error=incompatible-function-pointer-types" + "-Wno-error=int-conversion" + ] + ); installFlags = [ "DESTDIR=\${out}" ]; diff --git a/pkgs/by-name/li/libdbusmenu/package.nix b/pkgs/by-name/li/libdbusmenu/package.nix index 5143372d2b0db7..504b1954d06828 100644 --- a/pkgs/by-name/li/libdbusmenu/package.nix +++ b/pkgs/by-name/li/libdbusmenu/package.nix @@ -1,31 +1,53 @@ -{ stdenv, fetchurl, lib, file -, pkg-config, intltool -, glib, dbus-glib, json-glib -, gobject-introspection, vala -, gtkVersion ? null, gtk2, gtk3 -, testers +{ + stdenv, + fetchurl, + lib, + file, + pkg-config, + intltool, + glib, + dbus-glib, + json-glib, + gobject-introspection, + vala, + gtkVersion ? null, + gtk2, + gtk3, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "libdbusmenu-${if gtkVersion == null then "glib" else "gtk${gtkVersion}"}"; version = "16.04.0"; - src = let - inherit (finalAttrs) version; - in fetchurl { - url = "https://launchpad.net/dbusmenu/${lib.versions.majorMinor version}/${version}/+download/libdbusmenu-${version}.tar.gz"; - sha256 = "12l7z8dhl917iy9h02sxmpclnhkdjryn08r8i4sr8l3lrlm4mk5r"; - }; + src = + let + inherit (finalAttrs) version; + in + fetchurl { + url = "https://launchpad.net/dbusmenu/${lib.versions.majorMinor version}/${version}/+download/libdbusmenu-${version}.tar.gz"; + sha256 = "12l7z8dhl917iy9h02sxmpclnhkdjryn08r8i4sr8l3lrlm4mk5r"; + }; - nativeBuildInputs = [ vala pkg-config intltool gobject-introspection ]; + nativeBuildInputs = [ + vala + pkg-config + intltool + gobject-introspection + ]; - buildInputs = [ - glib dbus-glib json-glib - ] ++ lib.optional (gtkVersion != null) - { - "2" = gtk2; - "3" = gtk3; - }.${gtkVersion} or (throw "unknown GTK version ${gtkVersion}"); + buildInputs = + [ + glib + dbus-glib + json-glib + ] + ++ lib.optional (gtkVersion != null) + { + "2" = gtk2; + "3" = gtk3; + } + .${gtkVersion} or (throw "unknown GTK version ${gtkVersion}"); patches = [ ./requires-glib.patch @@ -66,7 +88,11 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Library for passing menu structures across DBus"; homepage = "https://launchpad.net/dbusmenu"; - license = with licenses; [ gpl3 lgpl21 lgpl3 ]; + license = with licenses; [ + gpl3 + lgpl21 + lgpl3 + ]; pkgConfigModules = [ "dbusmenu-glib-0.4" "dbusmenu-jsonloader-0.4" diff --git a/pkgs/by-name/li/libde265/package.nix b/pkgs/by-name/li/libde265/package.nix index e4dfba60fe9998..fc441254b9b310 100644 --- a/pkgs/by-name/li/libde265/package.nix +++ b/pkgs/by-name/li/libde265/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, -, callPackage + callPackage, # for passthru.tests -, imagemagick -, libheif -, imlib2Full -, gst_all_1 + imagemagick, + libheif, + imlib2Full, + gst_all_1, }: stdenv.mkDerivation (finalAttrs: rec { @@ -24,7 +25,10 @@ stdenv.mkDerivation (finalAttrs: rec { hash = "sha256-guiLM4RNe5O0qpeCoQUbs1Z7j0wp8iK9za2+6NIB8yY="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/li/libde265/test-corpus-decode.nix b/pkgs/by-name/li/libde265/test-corpus-decode.nix index 9c184362d10bba..ac7368f27cb5b4 100644 --- a/pkgs/by-name/li/libde265/test-corpus-decode.nix +++ b/pkgs/by-name/li/libde265/test-corpus-decode.nix @@ -1,6 +1,7 @@ -{ stdenv -, fetchFromGitHub -, libde265 +{ + stdenv, + fetchFromGitHub, + libde265, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/li/libdecor/package.nix b/pkgs/by-name/li/libdecor/package.nix index f81fdc68768acd..063ad2f6059caa 100644 --- a/pkgs/by-name/li/libdecor/package.nix +++ b/pkgs/by-name/li/libdecor/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitLab -, pkg-config -, meson -, ninja -, wayland -, wayland-protocols -, wayland-scanner -, cairo -, dbus -, pango -, gtk3 +{ + stdenv, + lib, + fetchFromGitLab, + pkg-config, + meson, + ninja, + wayland, + wayland-protocols, + wayland-scanner, + cairo, + dbus, + pango, + gtk3, }: stdenv.mkDerivation rec { @@ -25,7 +26,10 @@ stdenv.mkDerivation rec { hash = "sha256-mID19uHXFKJUZtQsSOXjRdz541YVjMxmSHVa+DlkPRc="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; strictDeps = true; diff --git a/pkgs/by-name/li/libdex/package.nix b/pkgs/by-name/li/libdex/package.nix index e605ff3ea7bd8b..96387af9f9fc09 100644 --- a/pkgs/by-name/li/libdex/package.nix +++ b/pkgs/by-name/li/libdex/package.nix @@ -1,22 +1,27 @@ -{ stdenv -, lib -, fetchurl -, gi-docgen -, gobject-introspection -, meson -, ninja -, pkg-config -, vala -, glib -, liburing -, gnome +{ + stdenv, + lib, + fetchurl, + gi-docgen, + gobject-introspection, + meson, + ninja, + pkg-config, + vala, + glib, + liburing, + gnome, }: stdenv.mkDerivation (finalAttrs: { pname = "libdex"; version = "0.8.1"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/libdex/${lib.versions.majorMinor finalAttrs.version}/libdex-${finalAttrs.version}.tar.xz"; diff --git a/pkgs/by-name/li/libdicom/package.nix b/pkgs/by-name/li/libdicom/package.nix index 94dfaf81298df4..b23fc37c56f8f5 100644 --- a/pkgs/by-name/li/libdicom/package.nix +++ b/pkgs/by-name/li/libdicom/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, uthash -, meson -, ninja -, pkg-config -, check +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + uthash, + meson, + ninja, + pkg-config, + check, }: stdenv.mkDerivation (finalAttrs: { @@ -31,8 +32,11 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ uthash ]; - nativeBuildInputs = [ meson ninja pkg-config ] - ++ lib.optionals (finalAttrs.finalPackage.doCheck) [ check ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ] ++ lib.optionals (finalAttrs.finalPackage.doCheck) [ check ]; mesonBuildType = "release"; diff --git a/pkgs/by-name/li/libdigidocpp/package.nix b/pkgs/by-name/li/libdigidocpp/package.nix index 81a129587dd706..3fc8389bc35d99 100644 --- a/pkgs/by-name/li/libdigidocpp/package.nix +++ b/pkgs/by-name/li/libdigidocpp/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, cmake -, libtool -, libxml2 -, minizip -, pcsclite -, opensc -, openssl -, xercesc -, pkg-config -, xsd -, zlib -, xmlsec -, xxd +{ + lib, + stdenv, + fetchurl, + cmake, + libtool, + libxml2, + minizip, + pcsclite, + opensc, + openssl, + xercesc, + pkg-config, + xsd, + zlib, + xmlsec, + xxd, }: stdenv.mkDerivation rec { @@ -25,7 +26,11 @@ stdenv.mkDerivation rec { hash = "sha256-0G7cjJEgLJ24SwHRznKJ18cRY0m50lr6HXstfbYq9f8="; }; - nativeBuildInputs = [ cmake pkg-config xxd ]; + nativeBuildInputs = [ + cmake + pkg-config + xxd + ]; buildInputs = [ libxml2 @@ -39,7 +44,12 @@ stdenv.mkDerivation rec { xmlsec ]; - outputs = [ "out" "lib" "dev" "bin" ]; + outputs = [ + "out" + "lib" + "dev" + "bin" + ]; # This wants to link to ${CMAKE_DL_LIBS} (ltdl), and there doesn't seem to be # a way to tell CMake where this should be pulled from. diff --git a/pkgs/by-name/li/libdiscid/package.nix b/pkgs/by-name/li/libdiscid/package.nix index 2c4e7de008b6ba..e863863fe6f114 100644 --- a/pkgs/by-name/li/libdiscid/package.nix +++ b/pkgs/by-name/li/libdiscid/package.nix @@ -1,10 +1,20 @@ -{ lib, stdenv, fetchurl, cmake, pkg-config, darwin }: +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + darwin, +}: stdenv.mkDerivation rec { pname = "libdiscid"; version = "0.6.4"; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.IOKit ]; diff --git a/pkgs/by-name/li/libdisplay-info/package.nix b/pkgs/by-name/li/libdisplay-info/package.nix index 68cca4ea135584..a54ee542097ae7 100644 --- a/pkgs/by-name/li/libdisplay-info/package.nix +++ b/pkgs/by-name/li/libdisplay-info/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, pkg-config -, ninja -, python3 -, hwdata -, edid-decode +{ + lib, + stdenv, + fetchFromGitLab, + meson, + pkg-config, + ninja, + python3, + hwdata, + edid-decode, }: stdenv.mkDerivation rec { @@ -22,7 +23,14 @@ stdenv.mkDerivation rec { }; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson pkg-config ninja edid-decode hwdata python3 ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + edid-decode + hwdata + python3 + ]; postPatch = '' patchShebangs tool/gen-search-table.py diff --git a/pkgs/by-name/li/libdivecomputer/package.nix b/pkgs/by-name/li/libdivecomputer/package.nix index 8824061dee86be..e2ac2746af6a96 100644 --- a/pkgs/by-name/li/libdivecomputer/package.nix +++ b/pkgs/by-name/li/libdivecomputer/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libdivecomputer"; diff --git a/pkgs/by-name/li/libdivsufsort/package.nix b/pkgs/by-name/li/libdivsufsort/package.nix index 9cce02bc08eed8..c180b8698c5c2c 100644 --- a/pkgs/by-name/li/libdivsufsort/package.nix +++ b/pkgs/by-name/li/libdivsufsort/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchFromGitHub, cmake}: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "libdivsufsort"; diff --git a/pkgs/by-name/li/libdjinterop/package.nix b/pkgs/by-name/li/libdjinterop/package.nix index 36c971f33a27de..0b514a34a2097e 100644 --- a/pkgs/by-name/li/libdjinterop/package.nix +++ b/pkgs/by-name/li/libdjinterop/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, boost -, cmake -, ninja -, pkg-config -, sqlite -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + boost, + cmake, + ninja, + pkg-config, + sqlite, + zlib, }: stdenv.mkDerivation { @@ -27,7 +28,10 @@ stdenv.mkDerivation { pkg-config ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; buildInputs = [ boost diff --git a/pkgs/by-name/li/libdmtx/package.nix b/pkgs/by-name/li/libdmtx/package.nix index bd7eb2359ef7f7..fca4825a8b5a36 100644 --- a/pkgs/by-name/li/libdmtx/package.nix +++ b/pkgs/by-name/li/libdmtx/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, }: stdenv.mkDerivation rec { @@ -16,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-UQy8iFfl8BNT5cBUMVF1tIScFPfHekSofaebtel9JWk="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; meta = { description = "Open source software for reading and writing Data Matrix barcodes"; diff --git a/pkgs/by-name/li/libdovi/package.nix b/pkgs/by-name/li/libdovi/package.nix index 5f87567e3bc888..055c90f7d9c4d8 100644 --- a/pkgs/by-name/li/libdovi/package.nix +++ b/pkgs/by-name/li/libdovi/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchCrate -, cargo-c -, rust -, stdenv +{ + lib, + rustPlatform, + fetchCrate, + cargo-c, + rust, + stdenv, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/li/libdsk/package.nix b/pkgs/by-name/li/libdsk/package.nix index 74d87548389057..a2041ee70b7601 100644 --- a/pkgs/by-name/li/libdsk/package.nix +++ b/pkgs/by-name/li/libdsk/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libdsk"; diff --git a/pkgs/by-name/li/libdv/package.nix b/pkgs/by-name/li/libdv/package.nix index da69eedb288778..71a7e206860dc0 100644 --- a/pkgs/by-name/li/libdv/package.nix +++ b/pkgs/by-name/li/libdv/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, popt }: +{ + lib, + stdenv, + fetchurl, + popt, +}: stdenv.mkDerivation rec { pname = "libdv"; diff --git a/pkgs/by-name/li/libdvbcsa/package.nix b/pkgs/by-name/li/libdvbcsa/package.nix index f9daa860cf479c..e85f6095d28f0d 100644 --- a/pkgs/by-name/li/libdvbcsa/package.nix +++ b/pkgs/by-name/li/libdvbcsa/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libdvbcsa"; diff --git a/pkgs/by-name/li/libdvbpsi/package.nix b/pkgs/by-name/li/libdvbpsi/package.nix index 6ec8aab8943ceb..b8f6c3c15e7b4e 100644 --- a/pkgs/by-name/li/libdvbpsi/package.nix +++ b/pkgs/by-name/li/libdvbpsi/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libdvbpsi"; diff --git a/pkgs/by-name/li/libdwarf/common.nix b/pkgs/by-name/li/libdwarf/common.nix index 4cf3102bbbfce7..7206140b9db2ab 100644 --- a/pkgs/by-name/li/libdwarf/common.nix +++ b/pkgs/by-name/li/libdwarf/common.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, buildInputs, hash, version, url, knownVulnerabilities }: +{ + lib, + stdenv, + fetchurl, + buildInputs, + hash, + version, + url, + knownVulnerabilities, +}: stdenv.mkDerivation rec { pname = "libdwarf"; @@ -8,11 +17,19 @@ stdenv.mkDerivation rec { inherit url hash; }; - configureFlags = [ "--enable-shared" "--disable-nonshared" ]; + configureFlags = [ + "--enable-shared" + "--disable-nonshared" + ]; inherit buildInputs; - outputs = [ "bin" "lib" "dev" "out" ]; + outputs = [ + "bin" + "lib" + "dev" + "out" + ]; meta = { homepage = "https://github.com/davea42/libdwarf-code"; diff --git a/pkgs/by-name/li/libdwarf/package.nix b/pkgs/by-name/li/libdwarf/package.nix index b4bccdf30ef331..65820422e34799 100644 --- a/pkgs/by-name/li/libdwarf/package.nix +++ b/pkgs/by-name/li/libdwarf/package.nix @@ -1,12 +1,16 @@ -{ callPackage -, zlib -, zstd +{ + callPackage, + zlib, + zstd, }: callPackage ./common.nix rec { version = "0.9.2"; url = "https://www.prevanders.net/libdwarf-${version}.tar.xz"; hash = "sha512-9QK22kuW1ZYtoRl8SuUiv9soWElsSvGYEJ2ETgAhMYyypevJyM+fwuRDmZfKlUXGUMpPKPDZbLZrBcm4m5jy+A=="; - buildInputs = [ zlib zstd ]; - knownVulnerabilities = []; + buildInputs = [ + zlib + zstd + ]; + knownVulnerabilities = [ ]; } diff --git a/pkgs/by-name/li/libdwg/package.nix b/pkgs/by-name/li/libdwg/package.nix index 741d848c47a85a..38b4492a8867a1 100644 --- a/pkgs/by-name/li/libdwg/package.nix +++ b/pkgs/by-name/li/libdwg/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, indent}: +{ + lib, + stdenv, + fetchurl, + indent, +}: stdenv.mkDerivation rec { pname = "libdwg"; @@ -26,7 +31,7 @@ stdenv.mkDerivation rec { description = "Library reading dwg files"; homepage = "http://libdwg.sourceforge.net/en/"; license = lib.licenses.gpl3; - maintainers = [lib.maintainers.marcweber]; + maintainers = [ lib.maintainers.marcweber ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/li/libdynd/package.nix b/pkgs/by-name/li/libdynd/package.nix index 8746ea42882c69..8bfc3412e34130 100644 --- a/pkgs/by-name/li/libdynd/package.nix +++ b/pkgs/by-name/li/libdynd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "libdynd"; @@ -30,7 +35,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; outputDoc = "dev"; meta = with lib; { diff --git a/pkgs/by-name/li/libe-book/package.nix b/pkgs/by-name/li/libe-book/package.nix index f066e470568bb8..a0caf152897868 100644 --- a/pkgs/by-name/li/libe-book/package.nix +++ b/pkgs/by-name/li/libe-book/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, gperf -, pkg-config -, librevenge -, libxml2 -, boost -, icu -, cppunit -, zlib -, liblangtag +{ + lib, + stdenv, + fetchurl, + gperf, + pkg-config, + librevenge, + libxml2, + boost, + icu, + cppunit, + zlib, + liblangtag, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libe57format/package.nix b/pkgs/by-name/li/libe57format/package.nix index 7e70cb95031064..bf391abd82d83c 100644 --- a/pkgs/by-name/li/libe57format/package.nix +++ b/pkgs/by-name/li/libe57format/package.nix @@ -1,5 +1,6 @@ { - lib, stdenv, + lib, + stdenv, cmake, fetchFromGitHub, fetchpatch, @@ -51,9 +52,11 @@ stdenv.mkDerivation (finalAttrs: { cmakeFlags = [ # See https://github.com/asmaloney/libE57Format/blob/9372bdea8db2cc0c032a08f6d655a53833d484b8/test/README.md - (if finalAttrs.finalPackage.doCheck - then "-DE57_TEST_DATA_PATH=${finalAttrs.libE57Format-test-data_src}" - else "-DE57_BUILD_TEST=OFF" + ( + if finalAttrs.finalPackage.doCheck then + "-DE57_TEST_DATA_PATH=${finalAttrs.libE57Format-test-data_src}" + else + "-DE57_BUILD_TEST=OFF" ) ]; @@ -84,7 +87,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Library for reading & writing the E57 file format"; homepage = "https://github.com/asmaloney/libE57Format"; license = licenses.boost; - maintainers = with maintainers; [ chpatrick nh2 ]; + maintainers = with maintainers; [ + chpatrick + nh2 + ]; platforms = platforms.linux; # because of the .so buiding in `postInstall` above }; }) diff --git a/pkgs/by-name/li/libeatmydata/package.nix b/pkgs/by-name/li/libeatmydata/package.nix index f315e32f02d93a..d166a39299eb0c 100644 --- a/pkgs/by-name/li/libeatmydata/package.nix +++ b/pkgs/by-name/li/libeatmydata/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, strace -, which +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + strace, + which, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libeb/package.nix b/pkgs/by-name/li/libeb/package.nix index fe0011f9c99737..b21a6d405e592e 100644 --- a/pkgs/by-name/li/libeb/package.nix +++ b/pkgs/by-name/li/libeb/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, perl, zlib }: +{ + lib, + stdenv, + fetchurl, + perl, + zlib, +}: stdenv.mkDerivation rec { pname = "libeb"; version = "4.4.3"; diff --git a/pkgs/by-name/li/libebml/package.nix b/pkgs/by-name/li/libebml/package.nix index 34a45e398bcdb3..e6bd5d29bca292 100644 --- a/pkgs/by-name/li/libebml/package.nix +++ b/pkgs/by-name/li/libebml/package.nix @@ -1,17 +1,26 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "libebml"; version = "1.4.5"; src = fetchFromGitHub { - owner = "Matroska-Org"; - repo = "libebml"; - rev = "release-${version}"; + owner = "Matroska-Org"; + repo = "libebml"; + rev = "release-${version}"; sha256 = "sha256-PIVBePTWceMgiENdaL9lvXIL/RQIrtg7l0OG2tO0SU8="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; cmakeFlags = [ "-DBUILD_SHARED_LIBS=YES" diff --git a/pkgs/by-name/li/libebur128/package.nix b/pkgs/by-name/li/libebur128/package.nix index c91cb23189f706..c9925606303790 100644 --- a/pkgs/by-name/li/libebur128/package.nix +++ b/pkgs/by-name/li/libebur128/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, speexdsp, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + speexdsp, + pkg-config, +}: stdenv.mkDerivation rec { version = "1.2.6"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-UKO2k+kKH/dwt2xfaYMrH/GXjEkIrnxh1kGG/3P5d3Y="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ speexdsp ]; # https://github.com/jiixyj/libebur128/issues/121 diff --git a/pkgs/by-name/li/libedit/package.nix b/pkgs/by-name/li/libedit/package.nix index 90d69aa6db2095..92248a806d253f 100644 --- a/pkgs/by-name/li/libedit/package.nix +++ b/pkgs/by-name/li/libedit/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, ncurses +{ + lib, + stdenv, + fetchurl, + ncurses, }: stdenv.mkDerivation (finalAttrs: { @@ -13,7 +14,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-XwVzNJ13xKSJZxkc3WY03Xql9jmMalf+A3zAJpbWCZ8="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; patches = [ ./01-cygwin.patch @@ -30,9 +35,9 @@ stdenv.mkDerivation (finalAttrs: { # fine with GCC and Musl. # There is a DR to fix this issue with Clang which is not merged yet. # https://reviews.llvm.org/D137043 - env.NIX_CFLAGS_COMPILE = - lib.optionalString (stdenv.targetPlatform.isMusl && stdenv.cc.isClang) - "-D__STDC_ISO_10646__=201103L"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.targetPlatform.isMusl && stdenv.cc.isClang + ) "-D__STDC_ISO_10646__=201103L"; postFixup = '' find $out/lib -type f | \ @@ -45,10 +50,10 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://www.thrysoee.dk/editline/#changelog"; description = "Port of the NetBSD Editline library (libedit)"; longDescription = '' - This is an autotool- and libtoolized port of the NetBSD Editline library - (libedit). This Berkeley-style licensed command line editor library - provides generic line editing, history, and tokenization functions, - similar to those found in GNU Readline. + This is an autotool- and libtoolized port of the NetBSD Editline library + (libedit). This Berkeley-style licensed command line editor library + provides generic line editing, history, and tokenization functions, + similar to those found in GNU Readline. ''; license = with lib.licenses; [ bsd3 ]; maintainers = with lib.maintainers; [ AndersonTorres ]; diff --git a/pkgs/by-name/li/libeduvpn-common/package.nix b/pkgs/by-name/li/libeduvpn-common/package.nix index f9dce02b5d40ac..0b052cd5c3d4fb 100644 --- a/pkgs/by-name/li/libeduvpn-common/package.nix +++ b/pkgs/by-name/li/libeduvpn-common/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchurl +{ + lib, + buildGoModule, + fetchurl, }: buildGoModule rec { @@ -30,7 +31,10 @@ buildGoModule rec { changelog = "https://raw.githubusercontent.com/eduvpn/eduvpn-common/${version}/CHANGES.md"; description = "Code to be shared between eduVPN clients"; homepage = "https://github.com/eduvpn/eduvpn-common"; - maintainers = with maintainers; [ benneti jwijenbergh ]; + maintainers = with maintainers; [ + benneti + jwijenbergh + ]; license = licenses.mit; platforms = platforms.linux; }; diff --git a/pkgs/by-name/li/libee/package.nix b/pkgs/by-name/li/libee/package.nix index 246fb73090b9ef..d3bdd2c69bdb47 100644 --- a/pkgs/by-name/li/libee/package.nix +++ b/pkgs/by-name/li/libee/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libestr }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libestr, +}: stdenv.mkDerivation rec { pname = "libee"; version = "0.4.1"; @@ -9,7 +15,7 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libestr]; + buildInputs = [ libestr ]; meta = { description = "Event Expression Library inspired by CEE"; diff --git a/pkgs/by-name/li/libei/package.nix b/pkgs/by-name/li/libei/package.nix index c2529e66c0bb4a..654f9ba4625543 100644 --- a/pkgs/by-name/li/libei/package.nix +++ b/pkgs/by-name/li/libei/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchFromGitLab -, libevdev -, libxkbcommon -, meson -, ninja -, pkg-config -, protobuf -, protobufc -, systemd -, buildPackages +{ + lib, + stdenv, + fetchFromGitHub, + fetchFromGitLab, + libevdev, + libxkbcommon, + meson, + ninja, + pkg-config, + protobuf, + protobufc, + systemd, + buildPackages, }: let munit = fetchFromGitHub { @@ -43,14 +44,16 @@ stdenv.mkDerivation rec { meson ninja pkg-config - (buildPackages.python3.withPackages (ps: with ps; [ - attrs - jinja2 - pytest - python-dbusmock - strenum - structlog - ])) + (buildPackages.python3.withPackages ( + ps: with ps; [ + attrs + jinja2 + pytest + python-dbusmock + strenum + structlog + ] + )) ]; postPatch = '' diff --git a/pkgs/by-name/li/libelf/package.nix b/pkgs/by-name/li/libelf/package.nix index fdfa4fda0def46..d9749b431b8adf 100644 --- a/pkgs/by-name/li/libelf/package.nix +++ b/pkgs/by-name/li/libelf/package.nix @@ -1,5 +1,11 @@ -{ lib, stdenv -, fetchurl, autoreconfHook, gettext, freebsd, netbsd +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + gettext, + freebsd, + netbsd, }: stdenv.mkDerivation rec { @@ -29,27 +35,37 @@ stdenv.mkDerivation rec { doCheck = true; - preConfigure = if !stdenv.hostPlatform.useAndroidPrebuilt then null else '' - sed -i 's|DISTSUBDIRS = lib po|DISTSUBDIRS = lib|g' Makefile.in - sed -i 's|SUBDIRS = lib @POSUB@|SUBDIRS = lib|g' Makefile.in - ''; + preConfigure = + if !stdenv.hostPlatform.useAndroidPrebuilt then + null + else + '' + sed -i 's|DISTSUBDIRS = lib po|DISTSUBDIRS = lib|g' Makefile.in + sed -i 's|SUBDIRS = lib @POSUB@|SUBDIRS = lib|g' Makefile.in + ''; - configureFlags = [] - # Configure check for dynamic lib support is broken, see - # http://lists.uclibc.org/pipermail/uclibc-cvs/2005-August/019383.html + configureFlags = + [ ] + # Configure check for dynamic lib support is broken, see + # http://lists.uclibc.org/pipermail/uclibc-cvs/2005-August/019383.html ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "mr_cv_target_elf=yes" - # Libelf's custom NLS macros fail to determine the catalog file extension - # on Darwin, so disable NLS for now. + # Libelf's custom NLS macros fail to determine the catalog file extension + # on Darwin, so disable NLS for now. ++ lib.optional stdenv.hostPlatform.isDarwin "--disable-nls"; strictDeps = true; nativeBuildInputs = - (if stdenv.hostPlatform.isFreeBSD then [ freebsd.gencat ] - else if stdenv.hostPlatform.isNetBSD then [ netbsd.gencat ] - else [ gettext ]) - # The provided `configure` script fails on clang 16 because some tests have a `main` - # returning an implicit `int`, which clang 16 treats as an error. Running `autoreconf` fixes - # the test and allows `configure` to detect clang properly. + ( + if stdenv.hostPlatform.isFreeBSD then + [ freebsd.gencat ] + else if stdenv.hostPlatform.isNetBSD then + [ netbsd.gencat ] + else + [ gettext ] + ) + # The provided `configure` script fails on clang 16 because some tests have a `main` + # returning an implicit `int`, which clang 16 treats as an error. Running `autoreconf` fixes + # the test and allows `configure` to detect clang properly. ++ [ autoreconfHook ]; meta = { diff --git a/pkgs/by-name/li/libelfin/package.nix b/pkgs/by-name/li/libelfin/package.nix index 8ff7d8c9523739..663b5c3dd7f0fb 100644 --- a/pkgs/by-name/li/libelfin/package.nix +++ b/pkgs/by-name/li/libelfin/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, python3, substituteAll }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + substituteAll, +}: stdenv.mkDerivation rec { pname = "libelfin"; diff --git a/pkgs/by-name/li/libemf2svg/package.nix b/pkgs/by-name/li/libemf2svg/package.nix index 351d9345f3f78b..b1ede82417442d 100644 --- a/pkgs/by-name/li/libemf2svg/package.nix +++ b/pkgs/by-name/li/libemf2svg/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, fontconfig -, freetype -, libpng +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fontconfig, + freetype, + libpng, }: stdenv.mkDerivation rec { @@ -19,7 +20,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ fontconfig freetype libpng ]; + buildInputs = [ + fontconfig + freetype + libpng + ]; meta = with lib; { description = "Microsoft EMF to SVG conversion library"; diff --git a/pkgs/by-name/li/libepc/package.nix b/pkgs/by-name/li/libepc/package.nix index 3387e20ce69971..b9a94a544cab37 100644 --- a/pkgs/by-name/li/libepc/package.nix +++ b/pkgs/by-name/li/libepc/package.nix @@ -1,25 +1,30 @@ -{ stdenv -, lib -, fetchurl -, autoreconfHook -, gnome-common -, pkg-config -, intltool -, gtk-doc -, glib -, avahi -, gnutls -, libuuid -, libsoup_2_4 -, gtk3 -, gnome +{ + stdenv, + lib, + fetchurl, + autoreconfHook, + gnome-common, + pkg-config, + intltool, + gtk-doc, + glib, + avahi, + gnutls, + libuuid, + libsoup_2_4, + gtk3, + gnome, }: stdenv.mkDerivation (finalAttrs: { pname = "libepc"; version = "0.4.6"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/libepc/${lib.versions.majorMinor finalAttrs.version}/libepc-${finalAttrs.version}.tar.xz"; diff --git a/pkgs/by-name/li/libepubgen/package.nix b/pkgs/by-name/li/libepubgen/package.nix index ec0901ec438553..4f02f57598467d 100644 --- a/pkgs/by-name/li/libepubgen/package.nix +++ b/pkgs/by-name/li/libepubgen/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchgit -, autoreconfHook -, pkg-config -, boost -, cppunit -, librevenge -, libxml2 +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + pkg-config, + boost, + cppunit, + librevenge, + libxml2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/liberal-crime-squad/package.nix b/pkgs/by-name/li/liberal-crime-squad/package.nix index 47968c8c2ba47d..4bcbc3083f756d 100644 --- a/pkgs/by-name/li/liberal-crime-squad/package.nix +++ b/pkgs/by-name/li/liberal-crime-squad/package.nix @@ -1,4 +1,13 @@ -{ fetchFromGitHub, lib, stdenv, autoreconfHook, libiconv, ncurses, SDL2, SDL2_mixer }: +{ + fetchFromGitHub, + lib, + stdenv, + autoreconfHook, + libiconv, + ncurses, + SDL2, + SDL2_mixer, +}: stdenv.mkDerivation { version = "2016-07-06"; @@ -12,7 +21,12 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ libiconv ncurses SDL2 SDL2_mixer ]; + buildInputs = [ + libiconv + ncurses + SDL2 + SDL2_mixer + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/li/liberastika/package.nix b/pkgs/by-name/li/liberastika/package.nix index 7c716c1a354b05..85ccb3c6b9fa8e 100644 --- a/pkgs/by-name/li/liberastika/package.nix +++ b/pkgs/by-name/li/liberastika/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "liberastika"; diff --git a/pkgs/by-name/li/liberation-circuit/package.nix b/pkgs/by-name/li/liberation-circuit/package.nix index a9bceda06adb9f..55083ad46f4f7c 100644 --- a/pkgs/by-name/li/liberation-circuit/package.nix +++ b/pkgs/by-name/li/liberation-circuit/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config, allegro5, libGL, wrapGAppsHook3 }: +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + allegro5, + libGL, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "liberation-circuit"; @@ -11,8 +19,14 @@ stdenv.mkDerivation rec { hash = "sha256-zIwjh4CBSmKz7pF7GM5af+VslWho5jHOLsulbW4C8TY="; }; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; - buildInputs = [ allegro5 libGL ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; + buildInputs = [ + allegro5 + libGL + ]; dontWrapGApps = true; diff --git a/pkgs/by-name/li/liberation-sans-narrow/package.nix b/pkgs/by-name/li/liberation-sans-narrow/package.nix index 281bfa4c42b0fe..0fd45c6c500e0f 100644 --- a/pkgs/by-name/li/liberation-sans-narrow/package.nix +++ b/pkgs/by-name/li/liberation-sans-narrow/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fontforge, python3Packages, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + fontforge, + python3Packages, + python3, +}: stdenv.mkDerivation rec { pname = "liberation-sans-narrow"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "1qw554jbdnqkg6pjjl4cqkgsalq3398kzvww2naw30vykcz752bm"; }; - buildInputs = [ fontforge python3Packages.fonttools python3 ]; + buildInputs = [ + fontforge + python3Packages.fonttools + python3 + ]; installPhase = '' find . -name '*Narrow*.ttf' -exec install -m444 -Dt $out/share/fonts/truetype {} \; diff --git a/pkgs/by-name/li/liberfa/package.nix b/pkgs/by-name/li/liberfa/package.nix index 612d5ec34b7828..7a31b881b1e2a7 100644 --- a/pkgs/by-name/li/liberfa/package.nix +++ b/pkgs/by-name/li/liberfa/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "erfa"; diff --git a/pkgs/by-name/li/liberio/package.nix b/pkgs/by-name/li/liberio/package.nix index f7e4fa6e732999..b6ddf988b36e96 100644 --- a/pkgs/by-name/li/liberio/package.nix +++ b/pkgs/by-name/li/liberio/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, systemd -, pkg-config +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + systemd, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/libertine-g/package.nix b/pkgs/by-name/li/libertine-g/package.nix index 2f472e345c0fc5..1608db181d9e91 100644 --- a/pkgs/by-name/li/libertine-g/package.nix +++ b/pkgs/by-name/li/libertine-g/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation { pname = "linux-libertine-g"; diff --git a/pkgs/by-name/li/libertine/package.nix b/pkgs/by-name/li/libertine/package.nix index e24096e74f4ef9..79455a3f0dbef0 100644 --- a/pkgs/by-name/li/libertine/package.nix +++ b/pkgs/by-name/li/libertine/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fontforge }: +{ + lib, + stdenv, + fetchurl, + fontforge, +}: stdenv.mkDerivation { pname = "linux-libertine"; diff --git a/pkgs/by-name/li/libertinus/package.nix b/pkgs/by-name/li/libertinus/package.nix index a9bdb0a2654fe4..46f2f27567f864 100644 --- a/pkgs/by-name/li/libertinus/package.nix +++ b/pkgs/by-name/li/libertinus/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchurl, zstd }: +{ + lib, + stdenvNoCC, + fetchurl, + zstd, +}: stdenvNoCC.mkDerivation rec { pname = "libertinus"; diff --git a/pkgs/by-name/li/libesmtp/package.nix b/pkgs/by-name/li/libesmtp/package.nix index 0fb8890cf129db..27c53f54b478cf 100644 --- a/pkgs/by-name/li/libesmtp/package.nix +++ b/pkgs/by-name/li/libesmtp/package.nix @@ -1,10 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, pkg-config, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + openssl, +}: stdenv.mkDerivation rec { pname = "libESMTP"; version = "1.1.0"; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; buildInputs = [ openssl ]; src = fetchFromGitHub { @@ -26,4 +38,3 @@ stdenv.mkDerivation rec { license = licenses.lgpl21Plus; }; } - diff --git a/pkgs/by-name/li/libestr/package.nix b/pkgs/by-name/li/libestr/package.nix index 5630047eed7f13..4183c0e5e8154e 100644 --- a/pkgs/by-name/li/libestr/package.nix +++ b/pkgs/by-name/li/libestr/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libestr"; diff --git a/pkgs/by-name/li/libetebase/package.nix b/pkgs/by-name/li/libetebase/package.nix index c76b5a2320f718..67ec18801a0405 100644 --- a/pkgs/by-name/li/libetebase/package.nix +++ b/pkgs/by-name/li/libetebase/package.nix @@ -1,11 +1,12 @@ -{ rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, lib -, stdenv -, testers -, libetebase +{ + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + lib, + stdenv, + testers, + libetebase, }: rustPlatform.buildRustPackage rec { pname = "libetebase"; diff --git a/pkgs/by-name/li/libetpan/package.nix b/pkgs/by-name/li/libetpan/package.nix index 767b53c9d277cb..e1612b75b231bd 100644 --- a/pkgs/by-name/li/libetpan/package.nix +++ b/pkgs/by-name/li/libetpan/package.nix @@ -1,5 +1,13 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch -, autoconf, automake, libtool, openssl, pkg-config +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + autoconf, + automake, + libtool, + openssl, + pkg-config, }: stdenv.mkDerivation rec { @@ -13,7 +21,10 @@ stdenv.mkDerivation rec { hash = "sha256-lukeWURNsRPTuFk2q2XVnwkKz5Y+PRiPba5GPQCw6jw="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; patches = [ # The following patches are security and/or reliability fixes. @@ -84,7 +95,12 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoconf automake libtool pkg-config ]; + nativeBuildInputs = [ + autoconf + automake + libtool + pkg-config + ]; buildInputs = [ openssl ]; diff --git a/pkgs/by-name/li/libev/package.nix b/pkgs/by-name/li/libev/package.nix index 32960de8919d70..017d113225595e 100644 --- a/pkgs/by-name/li/libev/package.nix +++ b/pkgs/by-name/li/libev/package.nix @@ -1,6 +1,10 @@ -{ lib, stdenv, fetchurl, updateAutotoolsGnuConfigScriptsHook -, # Note: -static hasn’t work on darwin - static ? with stdenv.hostPlatform; isStatic && !isDarwin +{ + lib, + stdenv, + fetchurl, + updateAutotoolsGnuConfigScriptsHook, + # Note: -static hasn’t work on darwin + static ? with stdenv.hostPlatform; isStatic && !isDarwin, }: # Note: this package is used for bootstrapping fetchurl, and thus @@ -10,7 +14,7 @@ stdenv.mkDerivation rec { pname = "libev"; - version="4.33"; + version = "4.33"; src = fetchurl { url = "http://dist.schmorp.de/libev/Attic/${pname}-${version}.tar.gz"; diff --git a/pkgs/by-name/li/libevdev/package.nix b/pkgs/by-name/li/libevdev/package.nix index 5138eeca4dda07..5d56ee62fe64d5 100644 --- a/pkgs/by-name/li/libevdev/package.nix +++ b/pkgs/by-name/li/libevdev/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, python3 }: +{ + lib, + stdenv, + fetchurl, + python3, +}: stdenv.mkDerivation rec { pname = "libevdev"; diff --git a/pkgs/by-name/li/libevdevplus/package.nix b/pkgs/by-name/li/libevdevplus/package.nix index 11d644cd90dfde..da881c6d8bfaba 100644 --- a/pkgs/by-name/li/libevdevplus/package.nix +++ b/pkgs/by-name/li/libevdevplus/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "libevdevplus"; @@ -6,16 +12,19 @@ stdenv.mkDerivation rec { # adds missing cmake install directives # https://github.com/YukiWorkshop/libevdevPlus/pull/10 - patches = [ ./0001-Add-cmake-install-directives.patch]; + patches = [ ./0001-Add-cmake-install-directives.patch ]; - src = fetchFromGitHub { - owner = "YukiWorkshop"; - repo = "libevdevPlus"; - rev = "b4d4b3143056424a3da9f0516ca02a47209ef757"; + src = fetchFromGitHub { + owner = "YukiWorkshop"; + repo = "libevdevPlus"; + rev = "b4d4b3143056424a3da9f0516ca02a47209ef757"; sha256 = "09y65s16gch0w7fy1s9yjk9gz3bjzxix36h5wmwww6lkj2i1z3rj"; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; meta = with lib; { inherit (src.meta) homepage; diff --git a/pkgs/by-name/li/libevent/package.nix b/pkgs/by-name/li/libevent/package.nix index ab443dfac80dbb..42c2d2fe120ebe 100644 --- a/pkgs/by-name/li/libevent/package.nix +++ b/pkgs/by-name/li/libevent/package.nix @@ -1,9 +1,15 @@ -{ lib, stdenv, fetchurl, findutils, fixDarwinDylibNames -, updateAutotoolsGnuConfigScriptsHook -, sslSupport ? true, openssl -, fetchpatch +{ + lib, + stdenv, + fetchurl, + findutils, + fixDarwinDylibNames, + updateAutotoolsGnuConfigScriptsHook, + sslSupport ? true, + openssl, + fetchpatch, -, static ? stdenv.hostPlatform.isStatic + static ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { @@ -25,7 +31,10 @@ stdenv.mkDerivation rec { configureFlags = lib.flatten [ (lib.optional (!sslSupport) "--disable-openssl") - (lib.optionals static ["--disable-shared" "--with-pic"]) + (lib.optionals static [ + "--disable-shared" + "--with-pic" + ]) ]; preConfigure = lib.optionalString (lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11") '' @@ -34,18 +43,19 @@ stdenv.mkDerivation rec { # libevent_openssl is moved into its own output, so that openssl isn't present # in the default closure. - outputs = [ "out" "dev" ] - ++ lib.optional sslSupport "openssl" - ; + outputs = [ + "out" + "dev" + ] ++ lib.optional sslSupport "openssl"; outputBin = "dev"; - propagatedBuildOutputs = [ "out" ] - ++ lib.optional sslSupport "openssl" - ; + propagatedBuildOutputs = [ "out" ] ++ lib.optional sslSupport "openssl"; - nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook ] - ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; + nativeBuildInputs = [ + updateAutotoolsGnuConfigScriptsHook + ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; - buildInputs = lib.optional sslSupport openssl + buildInputs = + lib.optional sslSupport openssl ++ lib.optional stdenv.hostPlatform.isCygwin findutils; doCheck = false; # needs the net diff --git a/pkgs/by-name/li/libewf-legacy/package.nix b/pkgs/by-name/li/libewf-legacy/package.nix index fdd202f8c96db1..4cb9f3c324bfe2 100644 --- a/pkgs/by-name/li/libewf-legacy/package.nix +++ b/pkgs/by-name/li/libewf-legacy/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchurl -, stdenv -, zlib -, openssl -, libuuid -, pkg-config -, bzip2 +{ + lib, + fetchurl, + stdenv, + zlib, + openssl, + libuuid, + pkg-config, + bzip2, }: stdenv.mkDerivation (finalAttrs: { @@ -18,8 +19,11 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ zlib openssl libuuid ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ bzip2 ]; + buildInputs = [ + zlib + openssl + libuuid + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ bzip2 ]; meta = { description = "Legacy library for support of the Expert Witness Compression Format"; diff --git a/pkgs/by-name/li/libewf/package.nix b/pkgs/by-name/li/libewf/package.nix index 3bfd958bfd60e9..977365863e2fb9 100644 --- a/pkgs/by-name/li/libewf/package.nix +++ b/pkgs/by-name/li/libewf/package.nix @@ -1,4 +1,13 @@ -{ fetchurl, lib, stdenv, zlib, openssl, libuuid, pkg-config, bzip2 }: +{ + fetchurl, + lib, + stdenv, + zlib, + openssl, + libuuid, + pkg-config, + bzip2, +}: stdenv.mkDerivation rec { version = "20231119"; @@ -10,8 +19,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ zlib openssl libuuid ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ bzip2 ]; + buildInputs = [ + zlib + openssl + libuuid + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ bzip2 ]; # cannot run test program while cross compiling configureFlags = lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ @@ -22,7 +34,7 @@ stdenv.mkDerivation rec { description = "Library for support of the Expert Witness Compression Format"; homepage = "https://sourceforge.net/projects/libewf/"; license = lib.licenses.lgpl3; - maintainers = [ lib.maintainers.raskin ] ; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.unix; }; } diff --git a/pkgs/by-name/li/libexecinfo/package.nix b/pkgs/by-name/li/libexecinfo/package.nix index 24fc1e6dc74ec5..066a29a580bc2a 100644 --- a/pkgs/by-name/li/libexecinfo/package.nix +++ b/pkgs/by-name/li/libexecinfo/package.nix @@ -1,6 +1,10 @@ -{ lib, stdenv, fetchurl, fetchpatch -, enableStatic ? true -, enableShared ? !stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchurl, + fetchpatch, + enableStatic ? true, + enableShared ? !stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { @@ -26,23 +30,27 @@ stdenv.mkDerivation rec { ./30-linux-makefile.patch ]; - makeFlags = [ "CC:=$(CC)" "AR:=$(AR)" ]; + makeFlags = [ + "CC:=$(CC)" + "AR:=$(AR)" + ]; hardeningEnable = [ "stackprotector" ]; - buildFlags = - lib.optional enableStatic "static" - ++ lib.optional enableShared "dynamic"; + buildFlags = lib.optional enableStatic "static" ++ lib.optional enableShared "dynamic"; patchFlags = [ "-p0" ]; - installPhase = '' - install -Dm644 execinfo.h stacktraverse.h -t $out/include - '' + lib.optionalString enableShared '' - install -Dm755 libexecinfo.so.1 -t $out/lib - ln -s $out/lib/libexecinfo.so{.1,} - '' + lib.optionalString enableStatic '' - install -Dm755 libexecinfo.a -t $out/lib - ''; + installPhase = + '' + install -Dm644 execinfo.h stacktraverse.h -t $out/include + '' + + lib.optionalString enableShared '' + install -Dm755 libexecinfo.so.1 -t $out/lib + ln -s $out/lib/libexecinfo.so{.1,} + '' + + lib.optionalString enableStatic '' + install -Dm755 libexecinfo.a -t $out/lib + ''; meta = with lib; { description = "Quick-n-dirty BSD licensed clone of the GNU libc backtrace facility"; diff --git a/pkgs/by-name/li/libexif/package.nix b/pkgs/by-name/li/libexif/package.nix index 4130c54eba3d17..31fc243ca2dfc9 100644 --- a/pkgs/by-name/li/libexif/package.nix +++ b/pkgs/by-name/li/libexif/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, gettext }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gettext, +}: stdenv.mkDerivation rec { pname = "libexif"; @@ -7,11 +13,14 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = pname; repo = pname; - rev = "${pname}-${builtins.replaceStrings ["."] ["_"] version}-release"; + rev = "${pname}-${builtins.replaceStrings [ "." ] [ "_" ] version}-release"; sha256 = "sha256-Eqgnm31s8iPJdhTpk5HM89HSZTXTK+e7YZ/CCdbeJX4="; }; - nativeBuildInputs = [ autoreconfHook gettext ]; + nativeBuildInputs = [ + autoreconfHook + gettext + ]; meta = with lib; { homepage = "https://libexif.github.io/"; diff --git a/pkgs/by-name/li/libexosip/package.nix b/pkgs/by-name/li/libexosip/package.nix index 10d390bd678d34..5927101d0bcc41 100644 --- a/pkgs/by-name/li/libexosip/package.nix +++ b/pkgs/by-name/li/libexosip/package.nix @@ -1,16 +1,26 @@ -{ lib, stdenv, fetchurl, libosip, openssl, pkg-config }: +{ + lib, + stdenv, + fetchurl, + libosip, + openssl, + pkg-config, +}: stdenv.mkDerivation rec { - pname = "libexosip2"; - version = "5.3.0"; + pname = "libexosip2"; + version = "5.3.0"; - src = fetchurl { + src = fetchurl { url = "mirror://savannah/exosip/${pname}-${version}.tar.gz"; sha256 = "sha256-W3gjmGQx6lztyfCV1pZKzpZvCTsq59CwhAR4i/zrycI="; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libosip openssl ]; + buildInputs = [ + libosip + openssl + ]; meta = with lib; { license = licenses.gpl2Plus; diff --git a/pkgs/by-name/li/libexsid/package.nix b/pkgs/by-name/li/libexsid/package.nix index 38cdfc84d4e482..e6bd0eb7997fc4 100644 --- a/pkgs/by-name/li/libexsid/package.nix +++ b/pkgs/by-name/li/libexsid/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, pkg-config -, docSupport ? true -, doxygen -, libftdi1 +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + pkg-config, + docSupport ? true, + doxygen, + libftdi1, }: stdenv.mkDerivation rec { @@ -19,18 +20,18 @@ stdenv.mkDerivation rec { sha256 = "1qbiri549fma8c72nmj3cpz3sn1vc256kfafnygkmkzg7wdmgi7r"; }; - outputs = [ "out" ] - ++ lib.optional docSupport "doc"; + outputs = [ "out" ] ++ lib.optional docSupport "doc"; - nativeBuildInputs = [ autoreconfHook pkg-config ] - ++ lib.optional docSupport doxygen; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ] ++ lib.optional docSupport doxygen; buildInputs = [ libftdi1 ]; enableParallelBuilding = true; - installTargets = [ "install" ] - ++ lib.optional docSupport "doc"; + installTargets = [ "install" ] ++ lib.optional docSupport "doc"; postInstall = lib.optionalString docSupport '' mkdir -p $doc/share/libexsid/doc diff --git a/pkgs/by-name/li/libexttextcat/package.nix b/pkgs/by-name/li/libexttextcat/package.nix index 6ed3603dd184dd..ba7b16d087306b 100644 --- a/pkgs/by-name/li/libexttextcat/package.nix +++ b/pkgs/by-name/li/libexttextcat/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libexttextcat"; diff --git a/pkgs/by-name/li/libf2c/package.nix b/pkgs/by-name/li/libf2c/package.nix index a2cb4d2bd2460c..8ca63143545d80 100644 --- a/pkgs/by-name/li/libf2c/package.nix +++ b/pkgs/by-name/li/libf2c/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, unzip}: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "libf2c"; @@ -15,7 +20,10 @@ stdenv.mkDerivation rec { unzip ${src} ''; - makeFlags = [ "-f" "makefile.u" ]; + makeFlags = [ + "-f" + "makefile.u" + ]; installPhase = '' mkdir -p $out/include $out/lib diff --git a/pkgs/by-name/li/libfabric/package.nix b/pkgs/by-name/li/libfabric/package.nix index 6fabadf5f1291b..37dcb13d0c52da 100644 --- a/pkgs/by-name/li/libfabric/package.nix +++ b/pkgs/by-name/li/libfabric/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, autoreconfHook -, enablePsm2 ? (stdenv.hostPlatform.isx86_64 && stdenv.hostPlatform.isLinux) -, libpsm2 -, enableOpx ? (stdenv.hostPlatform.isx86_64 && stdenv.hostPlatform.isLinux) -, libuuid -, numactl +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + enablePsm2 ? (stdenv.hostPlatform.isx86_64 && stdenv.hostPlatform.isLinux), + libpsm2, + enableOpx ? (stdenv.hostPlatform.isx86_64 && stdenv.hostPlatform.isLinux), + libuuid, + numactl, }: stdenv.mkDerivation rec { @@ -23,11 +24,23 @@ stdenv.mkDerivation rec { sha256 = "sha256-s6e9UMCYqSuAvVvlF+SuduCA5UC43QEahUA8apubnOk="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; - buildInputs = lib.optionals enableOpx [ libuuid numactl ] ++ lib.optionals enablePsm2 [ libpsm2 ]; + buildInputs = + lib.optionals enableOpx [ + libuuid + numactl + ] + ++ lib.optionals enablePsm2 [ libpsm2 ]; configureFlags = [ (if enablePsm2 then "--enable-psm2=${libpsm2}" else "--disable-psm2") @@ -37,7 +50,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://ofiwg.github.io/libfabric/"; description = "Open Fabric Interfaces"; - license = with licenses; [ gpl2 bsd2 ]; + license = with licenses; [ + gpl2 + bsd2 + ]; platforms = platforms.all; maintainers = [ maintainers.bzizou ]; }; diff --git a/pkgs/by-name/li/libfaketime/package.nix b/pkgs/by-name/li/libfaketime/package.nix index 2cb94d11fd670d..9eba7b189c1f14 100644 --- a/pkgs/by-name/li/libfaketime/package.nix +++ b/pkgs/by-name/li/libfaketime/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, perl, coreutils }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + perl, + coreutils, +}: stdenv.mkDerivation rec { pname = "libfaketime"; @@ -11,22 +18,24 @@ stdenv.mkDerivation rec { sha256 = "sha256-DYRuQmIhQu0CNEboBAtHOr/NnWxoXecuPMSR/UQ/VIQ="; }; - patches = [ - ./nix-store-date.patch - (fetchpatch { - name = "0001-libfaketime.c-wrap-timespec_get-in-TIME_UTC-macro.patch"; - url = "https://github.com/wolfcw/libfaketime/commit/e0e6b79568d36a8fd2b3c41f7214769221182128.patch"; - sha256 = "sha256-KwwP76v0DXNW73p/YBvwUOPdKMAcVdbQSKexD/uFOYo="; - }) - (fetchpatch { - name = "LFS64.patch"; - url = "https://github.com/wolfcw/libfaketime/commit/f32986867addc9d22b0fab29c1c927f079d44ac1.patch"; - hash = "sha256-fIXuxxcV9J2IcgwcwSrMo4maObkH9WYv1DC/wdtbq/g="; - }) - ] ++ (lib.optionals stdenv.cc.isClang [ - # https://github.com/wolfcw/libfaketime/issues/277 - ./0001-Remove-unsupported-clang-flags.patch - ]); + patches = + [ + ./nix-store-date.patch + (fetchpatch { + name = "0001-libfaketime.c-wrap-timespec_get-in-TIME_UTC-macro.patch"; + url = "https://github.com/wolfcw/libfaketime/commit/e0e6b79568d36a8fd2b3c41f7214769221182128.patch"; + sha256 = "sha256-KwwP76v0DXNW73p/YBvwUOPdKMAcVdbQSKexD/uFOYo="; + }) + (fetchpatch { + name = "LFS64.patch"; + url = "https://github.com/wolfcw/libfaketime/commit/f32986867addc9d22b0fab29c1c927f079d44ac1.patch"; + hash = "sha256-fIXuxxcV9J2IcgwcwSrMo4maObkH9WYv1DC/wdtbq/g="; + }) + ] + ++ (lib.optionals stdenv.cc.isClang [ + # https://github.com/wolfcw/libfaketime/issues/277 + ./0001-Remove-unsupported-clang-flags.patch + ]); postPatch = '' patchShebangs test src diff --git a/pkgs/by-name/li/libfann/package.nix b/pkgs/by-name/li/libfann/package.nix index 590755c3a0fa1a..2cccdac05c1d99 100644 --- a/pkgs/by-name/li/libfann/package.nix +++ b/pkgs/by-name/li/libfann/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, cmake }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "libfann"; @@ -13,7 +18,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = { homepage = "http://leenissen.dk/fann/wp/"; diff --git a/pkgs/by-name/li/libff/package.nix b/pkgs/by-name/li/libff/package.nix index 5277337500794c..3a48a3145a44ec 100644 --- a/pkgs/by-name/li/libff/package.nix +++ b/pkgs/by-name/li/libff/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, boost, gmp, openssl, pkg-config -, enableStatic ? stdenv.hostPlatform.isStatic }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + gmp, + openssl, + pkg-config, + enableStatic ? stdenv.hostPlatform.isStatic, +}: stdenv.mkDerivation rec { pname = "libff"; @@ -13,15 +22,26 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - cmakeFlags = [ "-DWITH_PROCPS=Off" ] - ++ lib.optionals stdenv.hostPlatform.isAarch64 [ "-DCURVE=ALT_BN128" "-DUSE_ASM=OFF" ]; + cmakeFlags = + [ "-DWITH_PROCPS=Off" ] + ++ lib.optionals stdenv.hostPlatform.isAarch64 [ + "-DCURVE=ALT_BN128" + "-DUSE_ASM=OFF" + ]; postPatch = lib.optionalString (!enableStatic) '' substituteInPlace libff/CMakeLists.txt --replace "STATIC" "SHARED" ''; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ boost gmp openssl ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + boost + gmp + openssl + ]; meta = with lib; { description = "C++ library for Finite Fields and Elliptic Curves"; diff --git a/pkgs/by-name/li/libfido2/package.nix b/pkgs/by-name/li/libfido2/package.nix index 1a68b5eb6eb122..f8e75b6acb8b1a 100644 --- a/pkgs/by-name/li/libfido2/package.nix +++ b/pkgs/by-name/li/libfido2/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, cmake -, pkg-config -, hidapi -, libcbor -, openssl -, udev -, zlib -, withPcsclite ? true -, pcsclite +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + hidapi, + libcbor, + openssl, + udev, + zlib, + withPcsclite ? true, + pcsclite, }: stdenv.mkDerivation rec { @@ -22,28 +23,43 @@ stdenv.mkDerivation rec { hash = "sha256-q6qxMY0h0mLs5Bb7inEy+pN0vaifb6UrhqmKL1cSth4="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ libcbor zlib ] + buildInputs = + [ + libcbor + zlib + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ hidapi ] ++ lib.optionals stdenv.hostPlatform.isLinux [ udev ] ++ lib.optionals (stdenv.hostPlatform.isLinux && withPcsclite) [ pcsclite ]; propagatedBuildInputs = [ openssl ]; - outputs = [ "out" "dev" "man" ]; - - cmakeFlags = [ - "-DUDEV_RULES_DIR=${placeholder "out"}/etc/udev/rules.d" - "-DCMAKE_INSTALL_LIBDIR=lib" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DUSE_HIDAPI=1" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "-DNFC_LINUX=1" - ] ++ lib.optionals (stdenv.hostPlatform.isLinux && withPcsclite) [ - "-DUSE_PCSC=1" + outputs = [ + "out" + "dev" + "man" ]; + cmakeFlags = + [ + "-DUDEV_RULES_DIR=${placeholder "out"}/etc/udev/rules.d" + "-DCMAKE_INSTALL_LIBDIR=lib" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DUSE_HIDAPI=1" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "-DNFC_LINUX=1" + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && withPcsclite) [ + "-DUSE_PCSC=1" + ]; + # causes possible redefinition of _FORTIFY_SOURCE? hardeningDisable = [ "fortify3" ]; diff --git a/pkgs/by-name/li/libfishsound/package.nix b/pkgs/by-name/li/libfishsound/package.nix index 2105f2cc0f96b8..0c5ea9c4c023af 100644 --- a/pkgs/by-name/li/libfishsound/package.nix +++ b/pkgs/by-name/li/libfishsound/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, libvorbis, speex, flac, pkg-config }: +{ + lib, + stdenv, + fetchurl, + libvorbis, + speex, + flac, + pkg-config, +}: stdenv.mkDerivation rec { pname = "libfishsound"; @@ -9,7 +17,11 @@ stdenv.mkDerivation rec { sha256 = "1iz7mn6hw2wg8ljaw74f4g2zdj68ib88x4vjxxg3gjgc5z75f2rf"; }; - propagatedBuildInputs = [ libvorbis speex flac ]; + propagatedBuildInputs = [ + libvorbis + speex + flac + ]; nativeBuildInputs = [ pkg-config ]; diff --git a/pkgs/by-name/li/libfixposix/package.nix b/pkgs/by-name/li/libfixposix/package.nix index 3eb1dceffdef40..db66032af7e801 100644 --- a/pkgs/by-name/li/libfixposix/package.nix +++ b/pkgs/by-name/li/libfixposix/package.nix @@ -1,8 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, getconf }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + getconf, +}: stdenv.mkDerivation rec { pname = "libfixposix"; - version="0.5.1"; + version = "0.5.1"; src = fetchFromGitHub { owner = "sionescu"; @@ -11,13 +18,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-5qA6ytbqE+/05XQGxP9/4vEs9gFcuI3k7eJJYucW7fM="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ getconf ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ getconf ]; meta = with lib; { homepage = "https://github.com/sionescu/libfixposix"; description = "Thin wrapper over POSIX syscalls and some replacement functionality"; license = licenses.boost; - maintainers = with maintainers; [ orivej raskin ]; + maintainers = with maintainers; [ + orivej + raskin + ]; platforms = platforms.linux ++ platforms.darwin; }; } diff --git a/pkgs/by-name/li/libfm/package.nix b/pkgs/by-name/li/libfm/package.nix index ff08294bdb2950..8ce1a0b2ccfeb2 100644 --- a/pkgs/by-name/li/libfm/package.nix +++ b/pkgs/by-name/li/libfm/package.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchurl -, glib -, intltool -, menu-cache -, pango -, pkg-config -, vala -, extraOnly ? false -, withGtk3 ? false, gtk2, gtk3 +{ + lib, + stdenv, + fetchurl, + glib, + intltool, + menu-cache, + pango, + pkg-config, + vala, + extraOnly ? false, + withGtk3 ? false, + gtk2, + gtk3, }: let - gtk = if withGtk3 then gtk3 else gtk2; - inherit (lib) optional optionalString; + gtk = if withGtk3 then gtk3 else gtk2; + inherit (lib) optional optionalString; in stdenv.mkDerivation rec { - pname = if extraOnly - then "libfm-extra" - else "libfm"; + pname = if extraOnly then "libfm-extra" else "libfm"; version = "1.3.2"; src = fetchurl { @@ -26,19 +27,27 @@ stdenv.mkDerivation rec { sha256 = "sha256-pQQmMDBM+OXYz/nVZca9VG8ii0jJYBU+02ajTofK0eU="; }; - nativeBuildInputs = [ vala pkg-config intltool ]; - buildInputs = [ glib gtk pango ] - ++ optional (!extraOnly) menu-cache; - - configureFlags = [ "--sysconfdir=/etc" ] - ++ optional extraOnly "--with-extra-only" - ++ optional withGtk3 "--with-gtk=3"; + nativeBuildInputs = [ + vala + pkg-config + intltool + ]; + buildInputs = [ + glib + gtk + pango + ] ++ optional (!extraOnly) menu-cache; + + configureFlags = + [ "--sysconfdir=/etc" ] + ++ optional extraOnly "--with-extra-only" + ++ optional withGtk3 "--with-gtk=3"; installFlags = [ "sysconfdir=${placeholder "out"}/etc" ]; # libfm-extra is pulled in by menu-cache and thus leads to a collision for libfm postInstall = optionalString (!extraOnly) '' - rm $out/lib/libfm-extra.so $out/lib/libfm-extra.so.* $out/lib/libfm-extra.la $out/lib/pkgconfig/libfm-extra.pc + rm $out/lib/libfm-extra.so $out/lib/libfm-extra.so.* $out/lib/libfm-extra.la $out/lib/pkgconfig/libfm-extra.pc ''; enableParallelBuilding = true; diff --git a/pkgs/by-name/li/libfprint-2-tod1-elan/package.nix b/pkgs/by-name/li/libfprint-2-tod1-elan/package.nix index 3e7253a40175a3..30ca7275d68fcc 100644 --- a/pkgs/by-name/li/libfprint-2-tod1-elan/package.nix +++ b/pkgs/by-name/li/libfprint-2-tod1-elan/package.nix @@ -1,11 +1,12 @@ -{ stdenvNoCC -, lib -, fetchzip -, libfprint-tod -, openssl -, gusb -, glib -, autoPatchelfHook +{ + stdenvNoCC, + lib, + fetchzip, + libfprint-tod, + openssl, + gusb, + glib, + autoPatchelfHook, }: stdenvNoCC.mkDerivation { @@ -23,7 +24,7 @@ stdenvNoCC.mkDerivation { ''; }; - nativeBuildInputs = [ autoPatchelfHook]; + nativeBuildInputs = [ autoPatchelfHook ]; buildInputs = [ libfprint-tod diff --git a/pkgs/by-name/li/libfprint-2-tod1-goodix-550a/package.nix b/pkgs/by-name/li/libfprint-2-tod1-goodix-550a/package.nix index 16626fe0e227f4..f597fd7f89f2cb 100644 --- a/pkgs/by-name/li/libfprint-2-tod1-goodix-550a/package.nix +++ b/pkgs/by-name/li/libfprint-2-tod1-goodix-550a/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchzip, unzip, libfprint-tod }: +{ + stdenv, + lib, + fetchzip, + unzip, + libfprint-tod, +}: stdenv.mkDerivation { pname = "libfprint-2-tod1-goodix-550a"; diff --git a/pkgs/by-name/li/libfprint-2-tod1-goodix/package.nix b/pkgs/by-name/li/libfprint-2-tod1-goodix/package.nix index c7710ce1d1991d..f0900f7e5e3c59 100644 --- a/pkgs/by-name/li/libfprint-2-tod1-goodix/package.nix +++ b/pkgs/by-name/li/libfprint-2-tod1-goodix/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchgit, libfprint-tod }: +{ + stdenv, + lib, + fetchgit, + libfprint-tod, +}: stdenv.mkDerivation { pname = "libfprint-2-tod1-goodix"; diff --git a/pkgs/by-name/li/libfprint-2-tod1-vfs0090/package.nix b/pkgs/by-name/li/libfprint-2-tod1-vfs0090/package.nix index e40fa4c3df76fe..7d0d006dbb4c59 100644 --- a/pkgs/by-name/li/libfprint-2-tod1-vfs0090/package.nix +++ b/pkgs/by-name/li/libfprint-2-tod1-vfs0090/package.nix @@ -1,4 +1,19 @@ -{ stdenv, lib, fetchFromGitLab, pkg-config, libfprint, libfprint-tod, gusb, udev, nss, openssl, meson, pixman, ninja, glib }: +{ + stdenv, + lib, + fetchFromGitLab, + pkg-config, + libfprint, + libfprint-tod, + gusb, + udev, + nss, + openssl, + meson, + pixman, + ninja, + glib, +}: stdenv.mkDerivation { pname = "libfprint-2-tod1-vfs0090"; version = "0.8.5"; @@ -18,8 +33,21 @@ stdenv.mkDerivation { ./0002-vfs0090-add-missing-linux-limits.h-include.patch ]; - nativeBuildInputs = [ pkg-config meson ninja ]; - buildInputs = [ libfprint libfprint-tod glib gusb udev nss openssl pixman ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + ]; + buildInputs = [ + libfprint + libfprint-tod + glib + gusb + udev + nss + openssl + pixman + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/li/libfprint-tod/package.nix b/pkgs/by-name/li/libfprint-tod/package.nix index 538df33ff28143..30f2b91864d7d9 100644 --- a/pkgs/by-name/li/libfprint-tod/package.nix +++ b/pkgs/by-name/li/libfprint-tod/package.nix @@ -1,42 +1,49 @@ -{ lib -, libfprint -, fetchFromGitLab +{ + lib, + libfprint, + fetchFromGitLab, }: # for the curious, "tod" means "Touch OEM Drivers" meaning it can load # external .so's. -libfprint.overrideAttrs ({ postPatch ? "", mesonFlags ? [], ... }: let - version = "1.90.7+git20210222+tod1"; -in { - pname = "libfprint-tod"; - inherit version; +libfprint.overrideAttrs ( + { + postPatch ? "", + mesonFlags ? [ ], + ... + }: + let + version = "1.90.7+git20210222+tod1"; + in + { + pname = "libfprint-tod"; + inherit version; - src = fetchFromGitLab { - domain = "gitlab.freedesktop.org"; - owner = "3v1n0"; - repo = "libfprint"; - rev = "v${version}"; - sha256 = "0cj7iy5799pchyzqqncpkhibkq012g3bdpn18pfb19nm43svhn4j"; - }; + src = fetchFromGitLab { + domain = "gitlab.freedesktop.org"; + owner = "3v1n0"; + repo = "libfprint"; + rev = "v${version}"; + sha256 = "0cj7iy5799pchyzqqncpkhibkq012g3bdpn18pfb19nm43svhn4j"; + }; - mesonFlags = [ - # Include virtual drivers for fprintd tests - "-Ddrivers=all" - "-Dudev_hwdb_dir=${placeholder "out"}/lib/udev/hwdb.d" - ]; + mesonFlags = [ + # Include virtual drivers for fprintd tests + "-Ddrivers=all" + "-Dudev_hwdb_dir=${placeholder "out"}/lib/udev/hwdb.d" + ]; + postPatch = '' + ${postPatch} + patchShebangs ./tests/*.py ./tests/*.sh + ''; - postPatch = '' - ${postPatch} - patchShebangs ./tests/*.py ./tests/*.sh - ''; - - - meta = with lib; { - homepage = "https://gitlab.freedesktop.org/3v1n0/libfprint"; - description = "Library designed to make it easy to add support for consumer fingerprint readers, with support for loaded drivers"; - license = licenses.lgpl21; - platforms = platforms.linux; - maintainers = with maintainers; [ grahamc ]; - }; -}) + meta = with lib; { + homepage = "https://gitlab.freedesktop.org/3v1n0/libfprint"; + description = "Library designed to make it easy to add support for consumer fingerprint readers, with support for loaded drivers"; + license = licenses.lgpl21; + platforms = platforms.linux; + maintainers = with maintainers; [ grahamc ]; + }; + } +) diff --git a/pkgs/by-name/li/libfpx/package.nix b/pkgs/by-name/li/libfpx/package.nix index 82785a4d0fb8b7..08851aa477590a 100644 --- a/pkgs/by-name/li/libfpx/package.nix +++ b/pkgs/by-name/li/libfpx/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "libfpx"; diff --git a/pkgs/by-name/li/libfreeaptx/package.nix b/pkgs/by-name/li/libfreeaptx/package.nix index 7a59cde8433e78..3c7291f060e72b 100644 --- a/pkgs/by-name/li/libfreeaptx/package.nix +++ b/pkgs/by-name/li/libfreeaptx/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "libfreeaptx"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-eEUhOrKqb2hHWanY+knpY9FBEnjkkFTB+x6BZgMBpbo="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' substituteInPlace Makefile \ diff --git a/pkgs/by-name/li/libfsm/package.nix b/pkgs/by-name/li/libfsm/package.nix index 9840b875f331cf..940e6ac38ffc7a 100644 --- a/pkgs/by-name/li/libfsm/package.nix +++ b/pkgs/by-name/li/libfsm/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, bmake -, docbook_xsl -, libxslt +{ + lib, + stdenv, + fetchFromGitHub, + bmake, + docbook_xsl, + libxslt, }: stdenv.mkDerivation rec { @@ -11,10 +12,10 @@ stdenv.mkDerivation rec { version = "0.1pre2987_${builtins.substring 0 8 src.rev}"; src = fetchFromGitHub { - owner = "katef"; - repo = pname; - rev = "087e3389ad2cd5e5c40caeb40387e632567d7258"; - hash = "sha256-XWrZxnRbMB609l+sYFf8VsXy3NxqBsBPUrHgKLIyu/I="; + owner = "katef"; + repo = pname; + rev = "087e3389ad2cd5e5c40caeb40387e632567d7258"; + hash = "sha256-XWrZxnRbMB609l+sYFf8VsXy3NxqBsBPUrHgKLIyu/I="; fetchSubmodules = true; }; @@ -31,7 +32,10 @@ stdenv.mkDerivation rec { # if we use stdenv vs clangStdenv, we don't know which, and CC=cc in all # cases.) it's unclear exactly what should be done if we want those flags, # but the defaults work fine. - makeFlags = [ "-r" "PREFIX=$(out)" ]; + makeFlags = [ + "-r" + "PREFIX=$(out)" + ]; # fix up multi-output install. we also have to fix the pkg-config libdir # file; it uses prefix=$out; libdir=${prefix}/lib, which is wrong in @@ -50,13 +54,17 @@ stdenv.mkDerivation rec { done ''; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; meta = with lib; { description = "DFA regular expression library & friends"; - homepage = "https://github.com/katef/libfsm"; - license = licenses.bsd2; - platforms = platforms.unix; + homepage = "https://github.com/katef/libfsm"; + license = licenses.bsd2; + platforms = platforms.unix; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/li/libfyaml/package.nix b/pkgs/by-name/li/libfyaml/package.nix index 40e7ab53240ed5..0e9e5c665a9592 100644 --- a/pkgs/by-name/li/libfyaml/package.nix +++ b/pkgs/by-name/li/libfyaml/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, autoreconfHook, testers }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "libfyaml"; @@ -11,9 +18,17 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-Id5pdFzjA9q67okfESO3LZH8jIz93mVgIEEuBbPjuGI="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - - outputs = [ "bin" "dev" "out" "man" ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + + outputs = [ + "bin" + "dev" + "out" + "man" + ]; configureFlags = [ "--disable-network" ]; diff --git a/pkgs/by-name/li/libgadu/package.nix b/pkgs/by-name/li/libgadu/package.nix index 65f8b26c5a3783..32cb229b441b60 100644 --- a/pkgs/by-name/li/libgadu/package.nix +++ b/pkgs/by-name/li/libgadu/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, zlib, protobufc, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + protobufc, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libgadu"; diff --git a/pkgs/by-name/li/libgaminggear/package.nix b/pkgs/by-name/li/libgaminggear/package.nix index c90d47dff5024d..46daaf734fb688 100644 --- a/pkgs/by-name/li/libgaminggear/package.nix +++ b/pkgs/by-name/li/libgaminggear/package.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, fetchurl, cmake, pkg-config, gettext -, gtk2, libcanberra, libnotify, pcre, sqlite, xorg -, harfbuzz +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + gettext, + gtk2, + libcanberra, + libnotify, + pcre, + sqlite, + xorg, + harfbuzz, }: stdenv.mkDerivation rec { @@ -12,12 +23,26 @@ stdenv.mkDerivation rec { sha256 = "0jf5i1iv8j842imgiixbhwcr6qcwa93m27lzr6gb01ri5v35kggz"; }; - outputs = [ "dev" "out" "bin" ]; + outputs = [ + "dev" + "out" + "bin" + ]; - nativeBuildInputs = [ cmake pkg-config gettext ]; + nativeBuildInputs = [ + cmake + pkg-config + gettext + ]; propagatedBuildInputs = [ - gtk2 libcanberra libnotify pcre sqlite xorg.libXdmcp xorg.libpthreadstubs + gtk2 + libcanberra + libnotify + pcre + sqlite + xorg.libXdmcp + xorg.libpthreadstubs ]; cmakeFlags = [ diff --git a/pkgs/by-name/li/libgbinder/package.nix b/pkgs/by-name/li/libgbinder/package.nix index 0167dee157ae5b..dbad66ae3c2859 100644 --- a/pkgs/by-name/li/libgbinder/package.nix +++ b/pkgs/by-name/li/libgbinder/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config, glib, libglibutil }: +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + glib, + libglibutil, +}: stdenv.mkDerivation rec { pname = "libgbinder"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-CnoxWzouOX8OLzJx3nVl0u2L8fObESzj4Q0Z1KH7Tg4="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ pkg-config @@ -35,7 +45,10 @@ stdenv.mkDerivation rec { "INSTALL_PKGCONFIG_DIR=$(dev)/lib/pkgconfig" ]; - installTargets = [ "install" "install-dev" ]; + installTargets = [ + "install" + "install-dev" + ]; postInstall = '' sed -i -e "s@includedir=/usr@includedir=$dev@g" $dev/lib/pkgconfig/$pname.pc diff --git a/pkgs/by-name/li/libgdamm/package.nix b/pkgs/by-name/li/libgdamm/package.nix index 34735e644e4366..074a8167e9a070 100644 --- a/pkgs/by-name/li/libgdamm/package.nix +++ b/pkgs/by-name/li/libgdamm/package.nix @@ -1,16 +1,29 @@ -{ lib, stdenv, fetchurl, pkg-config, glibmm, libgda, libxml2, gnome -, mysqlSupport ? false -, postgresSupport ? false }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glibmm, + libgda, + libxml2, + gnome, + mysqlSupport ? false, + postgresSupport ? false, +}: let gda = libgda.override { inherit mysqlSupport postgresSupport; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "libgdamm"; version = "4.99.11"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -18,7 +31,10 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glibmm libxml2 ]; + buildInputs = [ + glibmm + libxml2 + ]; propagatedBuildInputs = [ gda ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/li/libgdata/package.nix b/pkgs/by-name/li/libgdata/package.nix index ed706ee9b78c00..b3ce0ce8aab666 100644 --- a/pkgs/by-name/li/libgdata/package.nix +++ b/pkgs/by-name/li/libgdata/package.nix @@ -1,29 +1,35 @@ -{ lib, stdenv -, fetchurl -, pkg-config -, meson -, ninja -, nixosTests -, vala -, gettext -, libxml2 -, glib -, json-glib -, gcr -, gnome-online-accounts -, gobject-introspection -, gnome -, p11-kit -, openssl -, uhttpmock -, libsoup_2_4 +{ + lib, + stdenv, + fetchurl, + pkg-config, + meson, + ninja, + nixosTests, + vala, + gettext, + libxml2, + glib, + json-glib, + gcr, + gnome-online-accounts, + gobject-introspection, + gnome, + p11-kit, + openssl, + uhttpmock, + libsoup_2_4, }: stdenv.mkDerivation rec { pname = "libgdata"; version = "0.18.1"; - outputs = [ "out" "dev" "installedTests" ]; + outputs = [ + "out" + "dev" + "installedTests" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/li/libgedit-amtk/package.nix b/pkgs/by-name/li/libgedit-amtk/package.nix index 00891ba921a59d..73d3adee7a3151 100644 --- a/pkgs/by-name/li/libgedit-amtk/package.nix +++ b/pkgs/by-name/li/libgedit-amtk/package.nix @@ -1,25 +1,30 @@ -{ stdenv -, lib -, fetchFromGitLab -, glib -, gtk3 -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, gobject-introspection -, gtk-doc -, docbook-xsl-nons -, gitUpdater -, dbus -, xvfb-run +{ + stdenv, + lib, + fetchFromGitLab, + glib, + gtk3, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + gobject-introspection, + gtk-doc, + docbook-xsl-nons, + gitUpdater, + dbus, + xvfb-run, }: stdenv.mkDerivation rec { pname = "libgedit-amtk"; version = "5.9.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitLab { domain = "gitlab.gnome.org"; @@ -31,16 +36,18 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ - meson - ninja - pkg-config - gobject-introspection - gtk-doc - docbook-xsl-nons - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gobject-introspection + gtk-doc + docbook-xsl-nons + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; propagatedBuildInputs = [ # Required by libgedit-amtk-5.pc @@ -70,7 +77,10 @@ stdenv.mkDerivation rec { homepage = "https://gitlab.gnome.org/World/gedit/libgedit-amtk"; changelog = "https://gitlab.gnome.org/World/gedit/libgedit-amtk/-/blob/${version}/NEWS?ref_type=tags"; description = "Actions, Menus and Toolbars Kit for GTK applications"; - maintainers = with maintainers; [ manveru bobby285271 ]; + maintainers = with maintainers; [ + manveru + bobby285271 + ]; license = licenses.lgpl21Plus; platforms = platforms.linux; }; diff --git a/pkgs/by-name/li/libgedit-gfls/package.nix b/pkgs/by-name/li/libgedit-gfls/package.nix index ee6ce5df0eaf6c..e1572fed66a051 100644 --- a/pkgs/by-name/li/libgedit-gfls/package.nix +++ b/pkgs/by-name/li/libgedit-gfls/package.nix @@ -1,22 +1,27 @@ -{ stdenv -, lib -, fetchFromGitLab -, docbook-xsl-nons -, gobject-introspection -, gtk-doc -, meson -, ninja -, pkg-config -, mesonEmulatorHook -, gtk3 -, glib +{ + stdenv, + lib, + fetchFromGitLab, + docbook-xsl-nons, + gobject-introspection, + gtk-doc, + meson, + ninja, + pkg-config, + mesonEmulatorHook, + gtk3, + glib, }: stdenv.mkDerivation (finalAttrs: { pname = "libgedit-gfls"; version = "0.2.1"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitLab { domain = "gitlab.gnome.org"; @@ -27,16 +32,18 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-kMkqEly8RDc5eKqUupQD4tkVIXxL1rt4e/OCAPoutIg="; }; - nativeBuildInputs = [ - docbook-xsl-nons - gobject-introspection - gtk-doc - meson - ninja - pkg-config - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + docbook-xsl-nons + gobject-introspection + gtk-doc + meson + ninja + pkg-config + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ gtk3 diff --git a/pkgs/by-name/li/libgee/package.nix b/pkgs/by-name/li/libgee/package.nix index 60696e38226700..ef7856de5efab5 100644 --- a/pkgs/by-name/li/libgee/package.nix +++ b/pkgs/by-name/li/libgee/package.nix @@ -1,19 +1,23 @@ -{ stdenv -, lib -, fetchurl -, autoconf -, vala -, pkg-config -, glib -, gobject-introspection -, gnome +{ + stdenv, + lib, + fetchurl, + autoconf, + vala, + pkg-config, + glib, + gobject-introspection, + gnome, }: stdenv.mkDerivation (finalAttrs: { pname = "libgee"; version = "0.20.6"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/libgee/${lib.versions.majorMinor finalAttrs.version}/libgee-${finalAttrs.version}.tar.xz"; @@ -33,13 +37,15 @@ stdenv.mkDerivation (finalAttrs: { doCheck = true; - env = { - NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-error=incompatible-function-pointer-types"; - PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_GIRDIR = "${placeholder "dev"}/share/gir-1.0"; - PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_TYPELIBDIR = "${placeholder "out"}/lib/girepository-1.0"; - } // lib.optionalAttrs stdenv.cc.isGNU { - NIX_CFLAGS_COMPILE = "-Wno-error=incompatible-pointer-types"; - }; + env = + { + NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-error=incompatible-function-pointer-types"; + PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_GIRDIR = "${placeholder "dev"}/share/gir-1.0"; + PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_TYPELIBDIR = "${placeholder "out"}/lib/girepository-1.0"; + } + // lib.optionalAttrs stdenv.cc.isGNU { + NIX_CFLAGS_COMPILE = "-Wno-error=incompatible-pointer-types"; + }; passthru = { updateScript = gnome.updateScript { diff --git a/pkgs/by-name/li/libgen-cli/package.nix b/pkgs/by-name/li/libgen-cli/package.nix index 45192447bdca78..b296e9e140a22f 100644 --- a/pkgs/by-name/li/libgen-cli/package.nix +++ b/pkgs/by-name/li/libgen-cli/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "libgen-cli"; @@ -19,7 +24,10 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' installShellCompletion --cmd libgen-cli \ @@ -30,8 +38,7 @@ buildGoModule rec { meta = with lib; { homepage = "https://github.com/ciehanski/libgen-cli"; - description = - "A CLI tool used to access the Library Genesis dataset; written in Go"; + description = "A CLI tool used to access the Library Genesis dataset; written in Go"; longDescription = '' libgen-cli is a command line interface application which allows users to quickly query the Library Genesis dataset and download any of its diff --git a/pkgs/by-name/li/libgeotiff/package.nix b/pkgs/by-name/li/libgeotiff/package.nix index 37e726fa23bb99..14c3204dcdf541 100644 --- a/pkgs/by-name/li/libgeotiff/package.nix +++ b/pkgs/by-name/li/libgeotiff/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libjpeg -, libtiff -, proj -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libjpeg, + libtiff, + proj, + zlib, }: stdenv.mkDerivation rec { @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { hash = "sha256-FUvWZR5BrGEMnApxCBQBwmmi9NU7Tx6Ziq3mbIxjqfc="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; sourceRoot = "${src.name}/libgeotiff"; @@ -34,7 +38,10 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ libtiff proj ]; + buildInputs = [ + libtiff + proj + ]; #hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/li/libgepub/package.nix b/pkgs/by-name/li/libgepub/package.nix index fbf9d28ce93e9d..9d4e8ef50097c8 100644 --- a/pkgs/by-name/li/libgepub/package.nix +++ b/pkgs/by-name/li/libgepub/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, glib -, gobject-introspection -, gnome -, webkitgtk_4_1 -, libsoup_3 -, libxml2 -, libarchive +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + glib, + gobject-introspection, + gnome, + webkitgtk_4_1, + libsoup_3, + libxml2, + libarchive, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libgestures/package.nix b/pkgs/by-name/li/libgestures/package.nix index 1454c0c78a5024..144a457c1987ab 100644 --- a/pkgs/by-name/li/libgestures/package.nix +++ b/pkgs/by-name/li/libgestures/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, glib, jsoncpp }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + glib, + jsoncpp, +}: stdenv.mkDerivation rec { pname = "libgestures"; @@ -18,10 +25,15 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib jsoncpp ]; + buildInputs = [ + glib + jsoncpp + ]; - - makeFlags = [ "DESTDIR=$(out)" "LIBDIR=/lib" ]; + makeFlags = [ + "DESTDIR=$(out)" + "LIBDIR=/lib" + ]; meta = with lib; { description = "ChromiumOS libgestures modified to compile for Linux"; diff --git a/pkgs/by-name/li/libgff/package.nix b/pkgs/by-name/li/libgff/package.nix index fc81cd09277768..0f0e7d808927d8 100644 --- a/pkgs/by-name/li/libgff/package.nix +++ b/pkgs/by-name/li/libgff/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -21,8 +22,7 @@ stdenv.mkDerivation (finalAttrs: { description = "Lightweight GTF/GFF parsers exposing a C++ interface"; homepage = "https://github.com/COMBINE-lab/libgff"; downloadPage = "https://github.com/COMBINE-lab/libgff/releases"; - changelog = "https://github.com/COMBINE-lab/libgff/releases/tag/" + - "v${finalAttrs.version}"; + changelog = "https://github.com/COMBINE-lab/libgff/releases/tag/" + "v${finalAttrs.version}"; license = lib.licenses.boost; platforms = lib.platforms.all; maintainers = [ lib.maintainers.kupac ]; diff --git a/pkgs/by-name/li/libgflow/package.nix b/pkgs/by-name/li/libgflow/package.nix index 007afa6ef5bf22..cc0470babd9cd5 100644 --- a/pkgs/by-name/li/libgflow/package.nix +++ b/pkgs/by-name/li/libgflow/package.nix @@ -1,10 +1,25 @@ -{stdenv, lib, vala, meson, ninja, pkg-config, fetchFromGitea, gobject-introspection, glib, gtk3}: +{ + stdenv, + lib, + vala, + meson, + ninja, + pkg-config, + fetchFromGitea, + gobject-introspection, + glib, + gtk3, +}: stdenv.mkDerivation rec { pname = "libgflow"; version = "1.0.4"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "devdoc"; # demo app src = fetchFromGitea { diff --git a/pkgs/by-name/li/libgig/package.nix b/pkgs/by-name/li/libgig/package.nix index aa710a91612531..b292d314c19543 100644 --- a/pkgs/by-name/li/libgig/package.nix +++ b/pkgs/by-name/li/libgig/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, autoconf, automake, libsndfile, libtool, pkg-config, libuuid }: +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + libsndfile, + libtool, + pkg-config, + libuuid, +}: stdenv.mkDerivation rec { pname = "libgig"; @@ -9,9 +19,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-/cie+rH5BhKObFRymWdXfo0EYgFwGLwSVRJX313+OqQ="; }; - nativeBuildInputs = [ autoconf automake libtool pkg-config ]; + nativeBuildInputs = [ + autoconf + automake + libtool + pkg-config + ]; - buildInputs = [ libsndfile libuuid ]; + buildInputs = [ + libsndfile + libuuid + ]; preConfigure = "make -f Makefile.svn"; diff --git a/pkgs/by-name/li/libgit2-glib/package.nix b/pkgs/by-name/li/libgit2-glib/package.nix index abf15fdec4d871..aad8fec365cdee 100644 --- a/pkgs/by-name/li/libgit2-glib/package.nix +++ b/pkgs/by-name/li/libgit2-glib/package.nix @@ -1,26 +1,31 @@ -{ stdenv -, lib -, fetchurl -, gnome -, meson -, ninja -, pkg-config -, vala -, libssh2 -, gtk-doc -, gobject-introspection -, gi-docgen -, libgit2 -, glib -, python3 -, fetchpatch +{ + stdenv, + lib, + fetchurl, + gnome, + meson, + ninja, + pkg-config, + vala, + libssh2, + gtk-doc, + gobject-introspection, + gi-docgen, + libgit2, + glib, + python3, + fetchpatch, }: stdenv.mkDerivation rec { pname = "libgit2-glib"; version = "1.2.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/li/libglibutil/package.nix b/pkgs/by-name/li/libglibutil/package.nix index c70dbc649c0417..132106b30250fb 100644 --- a/pkgs/by-name/li/libglibutil/package.nix +++ b/pkgs/by-name/li/libglibutil/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config, glib }: +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + glib, +}: stdenv.mkDerivation rec { pname = "libglibutil"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-UJsKjvigZuwDL4DyjUE6fXEecgoHrTE+5pO0hVyCwP4="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ pkg-config @@ -32,7 +41,10 @@ stdenv.mkDerivation rec { "INSTALL_PKGCONFIG_DIR=$(dev)/lib/pkgconfig" ]; - installTargets = [ "install" "install-dev" ]; + installTargets = [ + "install" + "install-dev" + ]; postInstall = '' sed -i -e "s@includedir=/usr@includedir=$dev@g" $dev/lib/pkgconfig/$pname.pc diff --git a/pkgs/by-name/li/libglvnd/package.nix b/pkgs/by-name/li/libglvnd/package.nix index c3667d664707ed..25e2f60d4403af 100644 --- a/pkgs/by-name/li/libglvnd/package.nix +++ b/pkgs/by-name/li/libglvnd/package.nix @@ -1,7 +1,15 @@ -{ stdenv, lib, fetchFromGitLab -, fetchpatch -, autoreconfHook, pkg-config, python3, addDriverRunpath -, libX11, libXext, xorgproto +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + autoreconfHook, + pkg-config, + python3, + addDriverRunpath, + libX11, + libXext, + xorgproto, }: stdenv.mkDerivation rec { @@ -26,8 +34,17 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config python3 addDriverRunpath ]; - buildInputs = [ libX11 libXext xorgproto ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + python3 + addDriverRunpath + ]; + buildInputs = [ + libX11 + libXext + xorgproto + ]; postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' substituteInPlace src/GLX/Makefile.am \ @@ -38,24 +55,31 @@ stdenv.mkDerivation rec { --replace "-Xlinker --version-script=$(VERSION_SCRIPT)" "-Xlinker" ''; - env.NIX_CFLAGS_COMPILE = toString ([ - "-UDEFAULT_EGL_VENDOR_CONFIG_DIRS" - # FHS paths are added so that non-NixOS applications can find vendor files. - "-DDEFAULT_EGL_VENDOR_CONFIG_DIRS=\"${addDriverRunpath.driverLink}/share/glvnd/egl_vendor.d:/etc/glvnd/egl_vendor.d:/usr/share/glvnd/egl_vendor.d\"" + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-UDEFAULT_EGL_VENDOR_CONFIG_DIRS" + # FHS paths are added so that non-NixOS applications can find vendor files. + "-DDEFAULT_EGL_VENDOR_CONFIG_DIRS=\"${addDriverRunpath.driverLink}/share/glvnd/egl_vendor.d:/etc/glvnd/egl_vendor.d:/usr/share/glvnd/egl_vendor.d\"" - "-Wno-error=array-bounds" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-error" - "-Wno-int-conversion" - ]); + "-Wno-error=array-bounds" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-error" + "-Wno-int-conversion" + ] + ); - configureFlags = [] + configureFlags = + [ ] # Indirectly: https://bugs.freedesktop.org/show_bug.cgi?id=35268 ++ lib.optional stdenv.hostPlatform.isMusl "--disable-tls" # Remove when aarch64-darwin asm support is upstream: https://gitlab.freedesktop.org/glvnd/libglvnd/-/issues/216 ++ lib.optional (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) "--disable-asm"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; # Set RUNPATH so that libGLX can find driver libraries in /run/opengl-driver(-32)/lib. # Note that libEGL does not need it because it uses driver config files which should @@ -78,7 +102,13 @@ stdenv.mkDerivation rec { inherit (src.meta) homepage; # https://gitlab.freedesktop.org/glvnd/libglvnd#libglvnd: changelog = "https://gitlab.freedesktop.org/glvnd/libglvnd/-/tags/v${version}"; - license = with licenses; [ mit bsd1 bsd3 gpl3Only asl20 ]; + license = with licenses; [ + mit + bsd1 + bsd3 + gpl3Only + asl20 + ]; platforms = platforms.unix; # https://gitlab.freedesktop.org/glvnd/libglvnd/-/issues/212 badPlatforms = [ lib.systems.inspect.platformPatterns.isStatic ]; diff --git a/pkgs/by-name/li/libgmpris/package.nix b/pkgs/by-name/li/libgmpris/package.nix index a7826fabd134b6..c1368abe6ceb83 100644 --- a/pkgs/by-name/li/libgmpris/package.nix +++ b/pkgs/by-name/li/libgmpris/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, glib -, gobject-introspection +{ + stdenv, + lib, + fetchurl, + pkg-config, + glib, + gobject-introspection, }: stdenv.mkDerivation rec { @@ -15,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-iyKNmg6sf+mxlY/4vt5lKdrKfJzkoCYU2j1O8uwk8K4="; }; - nativeBuildInputs = [ pkg-config gobject-introspection ]; + nativeBuildInputs = [ + pkg-config + gobject-introspection + ]; buildInputs = [ glib ]; diff --git a/pkgs/by-name/li/libgnome-keyring/package.nix b/pkgs/by-name/li/libgnome-keyring/package.nix index 5e6c6f0c02eaca..416d02232eda5f 100644 --- a/pkgs/by-name/li/libgnome-keyring/package.nix +++ b/pkgs/by-name/li/libgnome-keyring/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, glib, dbus, libgcrypt, pkg-config, intltool, gobject-introspection, testers +{ + lib, + stdenv, + fetchurl, + glib, + dbus, + libgcrypt, + pkg-config, + intltool, + gobject-introspection, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -10,11 +20,22 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-xMF4+7BfcqzEhNIt2wVo91MsQJsKE+BlE/9UuR6Ud4M="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; strictDeps = true; - propagatedBuildInputs = [ glib gobject-introspection dbus libgcrypt ]; - nativeBuildInputs = [ pkg-config intltool ]; + propagatedBuildInputs = [ + glib + gobject-introspection + dbus + libgcrypt + ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; configureFlags = [ # not ideal to use -config scripts but it's not possible switch it to pkg-config @@ -35,7 +56,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Framework for managing passwords and other secrets"; homepage = "https://gitlab.gnome.org/Archive/libgnome-keyring"; changelog = "https://gitlab.gnome.org/Archive/libgnome-keyring/-/blob/${finalAttrs.version}/NEWS?ref_type=tags"; - license = with lib.licenses; [ gpl2Plus lgpl2Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl2Plus + ]; pkgConfigModules = [ "gnome-keyring-1" ]; platforms = lib.platforms.unix; maintainers = [ ]; diff --git a/pkgs/by-name/li/libgnomekbd/package.nix b/pkgs/by-name/li/libgnomekbd/package.nix index a5c278956f2d7c..88db2b779ea1ec 100644 --- a/pkgs/by-name/li/libgnomekbd/package.nix +++ b/pkgs/by-name/li/libgnomekbd/package.nix @@ -1,22 +1,26 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, gobject-introspection -, glib -, gtk3 -, libxklavier -, wrapGAppsHook3 -, gnome +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + gobject-introspection, + glib, + gtk3, + libxklavier, + wrapGAppsHook3, + gnome, }: stdenv.mkDerivation rec { pname = "libgnomekbd"; version = "3.28.1"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/li/libgnurl/package.nix b/pkgs/by-name/li/libgnurl/package.nix index b3db03d0240b7d..d1f3ecf8c790ad 100644 --- a/pkgs/by-name/li/libgnurl/package.nix +++ b/pkgs/by-name/li/libgnurl/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchurl, libtool, perl, pkg-config, python3, zlib, gnutls -, libidn2, libunistring }: +{ + lib, + stdenv, + fetchurl, + libtool, + perl, + pkg-config, + python3, + zlib, + gnutls, + libidn2, + libunistring, +}: stdenv.mkDerivation rec { pname = "libgnurl"; @@ -10,9 +21,19 @@ stdenv.mkDerivation rec { sha256 = "1y4laraq37kw8hc8jlzgcw7y37bfd0n71q0sy3d3z6yg7zh2prxi"; }; - nativeBuildInputs = [ libtool perl pkg-config python3 ]; + nativeBuildInputs = [ + libtool + perl + pkg-config + python3 + ]; - buildInputs = [ gnutls zlib libidn2 libunistring ]; + buildInputs = [ + gnutls + zlib + libidn2 + libunistring + ]; configureFlags = [ "--disable-ntlm-wb" @@ -38,7 +59,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Fork of libcurl used by GNUnet"; - homepage = "https://gnunet.org/en/gnurl.html"; + homepage = "https://gnunet.org/en/gnurl.html"; maintainers = [ ]; platforms = platforms.unix; license = licenses.curl; diff --git a/pkgs/by-name/li/libgourou/package.nix b/pkgs/by-name/li/libgourou/package.nix index ba64735f873dd4..cc669b5120305c 100644 --- a/pkgs/by-name/li/libgourou/package.nix +++ b/pkgs/by-name/li/libgourou/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchzip -, pugixml -, updfparser -, curl -, openssl -, libzip -, installShellFiles +{ + lib, + stdenv, + fetchzip, + pugixml, + updfparser, + curl, + openssl, + libzip, + installShellFiles, }: stdenv.mkDerivation rec { @@ -29,9 +30,18 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ installShellFiles ]; - buildInputs = [ pugixml updfparser curl openssl libzip ]; + buildInputs = [ + pugixml + updfparser + curl + openssl + libzip + ]; - makeFlags = [ "BUILD_STATIC=1" "BUILD_SHARED=1" ]; + makeFlags = [ + "BUILD_STATIC=1" + "BUILD_SHARED=1" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/li/libgovirt/package.nix b/pkgs/by-name/li/libgovirt/package.nix index 18d88b5468524d..98aa1e319b6203 100644 --- a/pkgs/by-name/li/libgovirt/package.nix +++ b/pkgs/by-name/li/libgovirt/package.nix @@ -1,20 +1,24 @@ -{ lib -, stdenv -, fetchzip -, gnome -, meson -, pkg-config -, gobject-introspection -, ninja -, glib -, librest_1_0 +{ + lib, + stdenv, + fetchzip, + gnome, + meson, + pkg-config, + gobject-introspection, + ninja, + glib, + librest_1_0, }: stdenv.mkDerivation rec { pname = "libgovirt"; version = "0.3.9"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchzip { url = "mirror://gnome/sources/libgovirt/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -25,11 +29,13 @@ stdenv.mkDerivation rec { # https://gitlab.gnome.org/GNOME/libgovirt/-/issues/9 ./auto-disable-incompatible-compiler-warnings.patch ]; - env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang (lib.concatStringsSep " " [ - "-Wno-typedef-redefinition" - "-Wno-missing-field-initializers" - "-Wno-cast-align" - ]); + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang ( + lib.concatStringsSep " " [ + "-Wno-typedef-redefinition" + "-Wno-missing-field-initializers" + "-Wno-cast-align" + ] + ); nativeBuildInputs = [ meson @@ -53,7 +59,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://gitlab.gnome.org/GNOME/libgovirt"; description = "GObject wrapper for the oVirt REST API"; - maintainers = with maintainers; [ amarshall atemu ]; + maintainers = with maintainers; [ + amarshall + atemu + ]; platforms = with platforms; linux ++ darwin; license = licenses.lgpl21Plus; }; diff --git a/pkgs/by-name/li/libgpiod_1/package.nix b/pkgs/by-name/li/libgpiod_1/package.nix index 94644afff3fec1..444459d6601813 100644 --- a/pkgs/by-name/li/libgpiod_1/package.nix +++ b/pkgs/by-name/li/libgpiod_1/package.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchurl, autoreconfHook, autoconf-archive, pkg-config, kmod -, enable-tools ? true -, enablePython ? false, python3, ncurses }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + autoconf-archive, + pkg-config, + kmod, + enable-tools ? true, + enablePython ? false, + python3, + ncurses, +}: stdenv.mkDerivation rec { pname = "libgpiod"; @@ -17,7 +27,12 @@ stdenv.mkDerivation rec { ./0001-Drop-AC_FUNC_MALLOC-and-_REALLOC-and-check-for-them-.patch ]; - buildInputs = [ kmod ] ++ lib.optionals enablePython [ python3 ncurses ]; + buildInputs = + [ kmod ] + ++ lib.optionals enablePython [ + python3 + ncurses + ]; nativeBuildInputs = [ autoconf-archive pkg-config @@ -39,7 +54,7 @@ stdenv.mkDerivation rec { ''; homepage = "https://git.kernel.org/pub/scm/libs/libgpiod/libgpiod.git/about/"; license = licenses.lgpl2; - maintainers = []; + maintainers = [ ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/li/libgrapheme/package.nix b/pkgs/by-name/li/libgrapheme/package.nix index 44883d17d0c6ea..bde5ddc937c7b8 100644 --- a/pkgs/by-name/li/libgrapheme/package.nix +++ b/pkgs/by-name/li/libgrapheme/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, buildPackages }: +{ + lib, + stdenv, + fetchurl, + buildPackages, +}: stdenv.mkDerivation rec { pname = "libgrapheme"; @@ -16,9 +21,17 @@ stdenv.mkDerivation rec { depsBuildBuild = [ buildPackages.stdenv.cc ]; - makeFlags = [ "AR:=$(AR)" "CC:=$(CC)" "RANLIB:=$(RANLIB)" "BUILD_CC=$(CC_FOR_BUILD)" ]; + makeFlags = [ + "AR:=$(AR)" + "CC:=$(CC)" + "RANLIB:=$(RANLIB)" + "BUILD_CC=$(CC_FOR_BUILD)" + ]; - installFlags = [ "PREFIX=$(out)" "LDCONFIG=" ]; + installFlags = [ + "PREFIX=$(out)" + "LDCONFIG=" + ]; meta = with lib; { description = "Unicode string library"; diff --git a/pkgs/by-name/li/libgringotts/package.nix b/pkgs/by-name/li/libgringotts/package.nix index 268ada87ac6ea4..fb941e531bebd3 100644 --- a/pkgs/by-name/li/libgringotts/package.nix +++ b/pkgs/by-name/li/libgringotts/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, zlib, bzip2, libmcrypt, libmhash }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + zlib, + bzip2, + libmcrypt, + libmhash, +}: stdenv.mkDerivation rec { pname = "libgringotts"; @@ -10,7 +19,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ zlib bzip2 libmcrypt libmhash ]; + buildInputs = [ + zlib + bzip2 + libmcrypt + libmhash + ]; meta = with lib; { description = "Small library to encapsulate data in an encrypted structure"; diff --git a/pkgs/by-name/li/libgsf/package.nix b/pkgs/by-name/li/libgsf/package.nix index 1f93139eb02d4f..ea749cf2c63c1c 100644 --- a/pkgs/by-name/li/libgsf/package.nix +++ b/pkgs/by-name/li/libgsf/package.nix @@ -1,33 +1,37 @@ -{ fetchFromGitLab -, lib -, stdenv -, autoreconfHook -, gtk-doc -, pkg-config -, intltool -, gettext -, glib -, libxml2 -, zlib -, bzip2 -, perl -, gdk-pixbuf -, libiconv -, libintl -, gnome +{ + fetchFromGitLab, + lib, + stdenv, + autoreconfHook, + gtk-doc, + pkg-config, + intltool, + gettext, + glib, + libxml2, + zlib, + bzip2, + perl, + gdk-pixbuf, + libiconv, + libintl, + gnome, }: stdenv.mkDerivation rec { pname = "libgsf"; version = "1.14.53"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitLab { domain = "gitlab.gnome.org"; owner = "GNOME"; repo = "libgsf"; - rev = "LIBGSF_${lib.replaceStrings ["."] ["_"] version}"; + rev = "LIBGSF_${lib.replaceStrings [ "." ] [ "_" ] version}"; hash = "sha256-vC/6QEoV6FvFxQ0YlMkBbTmAtqbkvgZf+9BU8epi8yo="; }; diff --git a/pkgs/by-name/li/libgtkflow3/package.nix b/pkgs/by-name/li/libgtkflow3/package.nix index 7c85bd00b5d623..a32f890d9f5f41 100644 --- a/pkgs/by-name/li/libgtkflow3/package.nix +++ b/pkgs/by-name/li/libgtkflow3/package.nix @@ -1,10 +1,26 @@ -{stdenv, lib, vala, meson, ninja, pkg-config, fetchFromGitea, gobject-introspection, glib, gtk3, libgflow}: +{ + stdenv, + lib, + vala, + meson, + ninja, + pkg-config, + fetchFromGitea, + gobject-introspection, + glib, + gtk3, + libgflow, +}: stdenv.mkDerivation rec { pname = "libgtkflow3"; version = "1.0.6"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "devdoc"; # demo app src = fetchFromGitea { diff --git a/pkgs/by-name/li/libgtkflow4/package.nix b/pkgs/by-name/li/libgtkflow4/package.nix index 60439e7636e183..8b8a4cc41e4ddc 100644 --- a/pkgs/by-name/li/libgtkflow4/package.nix +++ b/pkgs/by-name/li/libgtkflow4/package.nix @@ -1,10 +1,26 @@ -{stdenv, lib, vala, meson, ninja, pkg-config, fetchFromGitea, gobject-introspection, glib, gtk4, libgflow}: +{ + stdenv, + lib, + vala, + meson, + ninja, + pkg-config, + fetchFromGitea, + gobject-introspection, + glib, + gtk4, + libgflow, +}: stdenv.mkDerivation rec { pname = "libgtkflow4"; version = "0.2.6"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "devdoc"; # demo app src = fetchFromGitea { diff --git a/pkgs/by-name/li/libgtop/package.nix b/pkgs/by-name/li/libgtop/package.nix index a265d366ab768f..36264b173dfb13 100644 --- a/pkgs/by-name/li/libgtop/package.nix +++ b/pkgs/by-name/li/libgtop/package.nix @@ -1,20 +1,25 @@ -{ lib, stdenv -, fetchurl -, glib -, pkg-config -, perl -, gettext -, gobject-introspection -, gnome -, gtk-doc -, deterministic-uname +{ + lib, + stdenv, + fetchurl, + glib, + pkg-config, + perl, + gettext, + gobject-introspection, + gnome, + gtk-doc, + deterministic-uname, }: stdenv.mkDerivation (finalAttrs: { pname = "libgtop"; version = "2.41.3"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/libgtop/${lib.versions.majorMinor finalAttrs.version}/libgtop-${finalAttrs.version}.tar.xz"; diff --git a/pkgs/by-name/li/libgudev/package.nix b/pkgs/by-name/li/libgudev/package.nix index dcd2015e1d156e..6e9007b90945d3 100644 --- a/pkgs/by-name/li/libgudev/package.nix +++ b/pkgs/by-name/li/libgudev/package.nix @@ -1,25 +1,31 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, meson -, ninja -, udev -, glib -, glibcLocales -, umockdev -, gnome -, vala -, gobject-introspection -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages +{ + stdenv, + lib, + fetchurl, + pkg-config, + meson, + ninja, + udev, + glib, + glibcLocales, + umockdev, + gnome, + vala, + gobject-introspection, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, }: stdenv.mkDerivation (finalAttrs: { pname = "libgudev"; version = "238"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/libgudev/${lib.versions.majorMinor finalAttrs.version}/libgudev-${finalAttrs.version}.tar.xz"; @@ -40,15 +46,17 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - nativeBuildInputs = [ - pkg-config - meson - ninja - glib # for glib-mkenums needed during the build - ] ++ lib.optionals withIntrospection [ - gobject-introspection - vala - ]; + nativeBuildInputs = + [ + pkg-config + meson + ninja + glib # for glib-mkenums needed during the build + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + vala + ]; buildInputs = [ udev diff --git a/pkgs/by-name/li/libgumath/package.nix b/pkgs/by-name/li/libgumath/package.nix index f82401f524fad6..6160e7276c2d25 100644 --- a/pkgs/by-name/li/libgumath/package.nix +++ b/pkgs/by-name/li/libgumath/package.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchFromGitHub -, libndtypes -, libxnd +{ + lib, + stdenv, + fetchFromGitHub, + libndtypes, + libxnd, }: stdenv.mkDerivation { @@ -15,7 +17,10 @@ stdenv.mkDerivation { sha256 = "1wprkxpmjrk369fpw8rbq51r7jvqkcndqs209y7p560cnagmsxc6"; }; - buildInputs = [ libndtypes libxnd ]; + buildInputs = [ + libndtypes + libxnd + ]; # Override linker with cc (symlink to either gcc or clang) # Library expects to use cc for linking diff --git a/pkgs/by-name/li/libgweather/package.nix b/pkgs/by-name/li/libgweather/package.nix index c528a2198ddcc7..a27aa76edcf929 100644 --- a/pkgs/by-name/li/libgweather/package.nix +++ b/pkgs/by-name/li/libgweather/package.nix @@ -1,31 +1,37 @@ -{ lib -, stdenv -, buildPackages -, fetchurl -, makeWrapper -, meson -, ninja -, pkg-config -, libxml2 -, json-glib -, glib -, gettext -, libsoup_3 -, gi-docgen -, gobject-introspection -, python3 -, tzdata -, geocode-glib_2 -, vala -, gnome -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages +{ + lib, + stdenv, + buildPackages, + fetchurl, + makeWrapper, + meson, + ninja, + pkg-config, + libxml2, + json-glib, + glib, + gettext, + libsoup_3, + gi-docgen, + gobject-introspection, + python3, + tzdata, + geocode-glib_2, + vala, + gnome, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, }: stdenv.mkDerivation rec { pname = "libgweather"; version = "4.4.4"; - outputs = [ "out" "dev" ] ++ lib.optional withIntrospection "devdoc"; + outputs = [ + "out" + "dev" + ] ++ lib.optional withIntrospection "devdoc"; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -44,18 +50,20 @@ stdenv.mkDerivation rec { pkg-config ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - gettext - glib - (python3.pythonOnBuildForHost.withPackages (ps: [ ps.pygobject3 ])) - ] ++ lib.optionals withIntrospection [ - gi-docgen - gobject-introspection - vala - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gettext + glib + (python3.pythonOnBuildForHost.withPackages (ps: [ ps.pygobject3 ])) + ] + ++ lib.optionals withIntrospection [ + gi-docgen + gobject-introspection + vala + ]; buildInputs = [ glib @@ -65,12 +73,14 @@ stdenv.mkDerivation rec { geocode-glib_2 ]; - mesonFlags = [ - "-Dzoneinfo_dir=${tzdata}/share/zoneinfo" - (lib.mesonBool "introspection" withIntrospection) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-Dc_args=-D_DARWIN_C_SOURCE" - ]; + mesonFlags = + [ + "-Dzoneinfo_dir=${tzdata}/share/zoneinfo" + (lib.mesonBool "introspection" withIntrospection) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-Dc_args=-D_DARWIN_C_SOURCE" + ]; postPatch = '' patchShebangs --build build-aux/meson/gen_locations_variant.py diff --git a/pkgs/by-name/li/libgxps/package.nix b/pkgs/by-name/li/libgxps/package.nix index cff74fbb474163..29f5289b5ea219 100644 --- a/pkgs/by-name/li/libgxps/package.nix +++ b/pkgs/by-name/li/libgxps/package.nix @@ -1,27 +1,58 @@ -{ lib, stdenv, fetchurl, meson, ninja, pkg-config, glib, gobject-introspection, cairo -, libarchive, freetype, libjpeg, libtiff, gnome, lcms2 +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + glib, + gobject-introspection, + cairo, + libarchive, + freetype, + libjpeg, + libtiff, + gnome, + lcms2, }: stdenv.mkDerivation rec { pname = "libgxps"; version = "0.3.2"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; sha256 = "bSeGclajXM+baSU+sqiKMrrKO5fV9O9/guNmf6Q1JRw="; }; - nativeBuildInputs = [ meson ninja pkg-config gobject-introspection ]; - buildInputs = [ glib cairo freetype libjpeg libtiff lcms2 ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + gobject-introspection + ]; + buildInputs = [ + glib + cairo + freetype + libjpeg + libtiff + lcms2 + ]; propagatedBuildInputs = [ libarchive ]; - mesonFlags = [ - "-Denable-test=false" - ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ - "-Ddisable-introspection=true" - ]; + mesonFlags = + [ + "-Denable-test=false" + ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "-Ddisable-introspection=true" + ]; passthru = { updateScript = gnome.updateScript { diff --git a/pkgs/by-name/li/libhangul/package.nix b/pkgs/by-name/li/libhangul/package.nix index 2ff18376a4610c..af66dc6c499792 100644 --- a/pkgs/by-name/li/libhangul/package.nix +++ b/pkgs/by-name/li/libhangul/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libhangul"; diff --git a/pkgs/by-name/li/libharu/package.nix b/pkgs/by-name/li/libharu/package.nix index dabd74e648c3cb..264f5a52137209 100644 --- a/pkgs/by-name/li/libharu/package.nix +++ b/pkgs/by-name/li/libharu/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, zlib, libpng }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, + libpng, +}: stdenv.mkDerivation rec { pname = "libharu"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ zlib libpng ]; + buildInputs = [ + zlib + libpng + ]; meta = { description = "Cross platform, open source library for generating PDF files"; diff --git a/pkgs/by-name/li/libhomfly/package.nix b/pkgs/by-name/li/libhomfly/package.nix index d0f09290c3c76b..9cae6196d83c0c 100644 --- a/pkgs/by-name/li/libhomfly/package.nix +++ b/pkgs/by-name/li/libhomfly/package.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, boehmgc +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + boehmgc, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libhsts/package.nix b/pkgs/by-name/li/libhsts/package.nix index 124b1fc5496c8a..697f71b732ecd9 100644 --- a/pkgs/by-name/li/libhsts/package.nix +++ b/pkgs/by-name/li/libhsts/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitLab, fetchurl, autoconf-archive, autoreconfHook, pkg-config, python3 }: +{ + lib, + stdenv, + fetchFromGitLab, + fetchurl, + autoconf-archive, + autoreconfHook, + pkg-config, + python3, +}: let chromium_version = "90.0.4417.1"; @@ -27,15 +36,26 @@ stdenv.mkDerivation rec { patchShebangs src/hsts-make-dafsa ''; - nativeBuildInputs = [ autoconf-archive autoreconfHook pkg-config python3 ]; + nativeBuildInputs = [ + autoconf-archive + autoreconfHook + pkg-config + python3 + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = with lib; { description = "Library to easily check a domain against the Chromium HSTS Preload list"; mainProgram = "hsts"; homepage = "https://gitlab.com/rockdaboot/libhsts"; - license = with licenses; [ mit bsd3 ]; + license = with licenses; [ + mit + bsd3 + ]; maintainers = [ ]; }; } diff --git a/pkgs/by-name/li/libhttpserver/package.nix b/pkgs/by-name/li/libhttpserver/package.nix index a61342b99d07eb..64077cab20d325 100644 --- a/pkgs/by-name/li/libhttpserver/package.nix +++ b/pkgs/by-name/li/libhttpserver/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoconf -, automake -, libtool -, gnutls -, libmicrohttpd +{ + stdenv, + lib, + fetchFromGitHub, + autoconf, + automake, + libtool, + gnutls, + libmicrohttpd, }: stdenv.mkDerivation rec { @@ -19,9 +20,16 @@ stdenv.mkDerivation rec { hash = "sha256-Pc3Fvd8D4Ymp7dG9YgU58mDceOqNfhWE1JtnpVaNx/Y="; }; - nativeBuildInputs = [ autoconf automake libtool ]; + nativeBuildInputs = [ + autoconf + automake + libtool + ]; - buildInputs = [ gnutls libmicrohttpd ]; + buildInputs = [ + gnutls + libmicrohttpd + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/li/libhttpseverywhere/package.nix b/pkgs/by-name/li/libhttpseverywhere/package.nix index 50072b6cbef36a..c24eb6ab778086 100644 --- a/pkgs/by-name/li/libhttpseverywhere/package.nix +++ b/pkgs/by-name/li/libhttpseverywhere/package.nix @@ -1,10 +1,27 @@ -{ lib, stdenv, fetchurl, pkg-config, meson, ninja, makeFontsConf, vala, fetchpatch -, gnome, libgee, glib, json-glib, libarchive, libsoup_2_4, gobject-introspection }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + meson, + ninja, + makeFontsConf, + vala, + fetchpatch, + gnome, + libgee, + glib, + json-glib, + libarchive, + libsoup_2_4, + gobject-introspection, +}: let pname = "libhttpseverywhere"; version = "0.8.3"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { name = "${pname}-${version}"; src = fetchurl { @@ -12,8 +29,20 @@ in stdenv.mkDerivation rec { sha256 = "1jmn6i4vsm89q1axlq4ajqkzqmlmjaml9xhw3h9jnal46db6y00w"; }; - nativeBuildInputs = [ vala gobject-introspection meson ninja pkg-config ]; - buildInputs = [ glib libgee json-glib libsoup_2_4 libarchive ]; + nativeBuildInputs = [ + vala + gobject-introspection + meson + ninja + pkg-config + ]; + buildInputs = [ + glib + libgee + json-glib + libsoup_2_4 + libarchive + ]; patches = [ # Fixes build with vala >=0.42 @@ -36,7 +65,10 @@ in stdenv.mkDerivation rec { FONTCONFIG_FILE = makeFontsConf { fontDirectories = [ ]; }; - outputs = [ "out" "devdoc" ]; + outputs = [ + "out" + "devdoc" + ]; passthru = { updateScript = gnome.updateScript { diff --git a/pkgs/by-name/li/libhugetlbfs/package.nix b/pkgs/by-name/li/libhugetlbfs/package.nix index bcc676b1b0408c..581f6abf4689fa 100644 --- a/pkgs/by-name/li/libhugetlbfs/package.nix +++ b/pkgs/by-name/li/libhugetlbfs/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchurl, autoreconfHook }: +{ + stdenv, + lib, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libhugetlbfs"; @@ -9,7 +14,14 @@ stdenv.mkDerivation rec { hash = "sha256-1QHfqRyOrREGlno9OCnyunOMP6wKZcs1jtKrOHDdxe8="; }; - outputs = [ "bin" "dev" "man" "doc" "lib" "out" ]; + outputs = [ + "bin" + "dev" + "man" + "doc" + "lib" + "out" + ]; nativeBuildInputs = [ autoreconfHook ]; @@ -18,24 +30,32 @@ stdenv.mkDerivation rec { ''; enableParallelBuilding = true; - makeFlags = [ - "BUILDTYPE=NATIVEONLY" - "PREFIX=$(out)" - "HEADERDIR=$(dev)/include" - "LIBDIR32=$(lib)/$(LIB32)" - "LIBDIR64=$(lib)/$(LIB64)" - "EXEDIR=$(bin)/bin" - "DOCDIR=$(doc)/share/doc/libhugetlbfs" - "MANDIR=$(man)/share/man" - ] ++ lib.optionals (stdenv.buildPlatform.system != stdenv.hostPlatform.system) [ - # The ARCH logic defaults to querying `uname`, which will return build platform arch - "ARCH=${stdenv.hostPlatform.uname.processor}" - ]; + makeFlags = + [ + "BUILDTYPE=NATIVEONLY" + "PREFIX=$(out)" + "HEADERDIR=$(dev)/include" + "LIBDIR32=$(lib)/$(LIB32)" + "LIBDIR64=$(lib)/$(LIB64)" + "EXEDIR=$(bin)/bin" + "DOCDIR=$(doc)/share/doc/libhugetlbfs" + "MANDIR=$(man)/share/man" + ] + ++ lib.optionals (stdenv.buildPlatform.system != stdenv.hostPlatform.system) [ + # The ARCH logic defaults to querying `uname`, which will return build platform arch + "ARCH=${stdenv.hostPlatform.uname.processor}" + ]; # Default target builds tests as well, and the tests want a static # libc. - buildFlags = [ "libs" "tools" ]; - installTargets = [ "install" "install-docs" ]; + buildFlags = [ + "libs" + "tools" + ]; + installTargets = [ + "install" + "install-docs" + ]; meta = with lib; { homepage = "https://github.com/libhugetlbfs/libhugetlbfs"; diff --git a/pkgs/by-name/li/libhwy/package.nix b/pkgs/by-name/li/libhwy/package.nix index 7bf78ec875e210..c282d8420a34e3 100644 --- a/pkgs/by-name/li/libhwy/package.nix +++ b/pkgs/by-name/li/libhwy/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, cmake -, ninja -, gtest -, fetchFromGitHub -, fetchpatch +{ + lib, + stdenv, + cmake, + ninja, + gtest, + fetchFromGitHub, + fetchpatch, }: stdenv.mkDerivation rec { @@ -18,14 +19,17 @@ stdenv.mkDerivation rec { hash = "sha256-Z+mAR9nSAbCskUvo6oK79Yd85bu0HtI2aR5THS1EozM="; }; - patches = lib.optional stdenv.hostPlatform.isRiscV - # Adds CMake option HWY_CMAKE_RVV - # https://github.com/google/highway/pull/1743 - (fetchpatch { - name = "libhwy-add-rvv-optout.patch"; - url = "https://github.com/google/highway/commit/5d58d233fbcec0c6a39df8186a877329147324b3.patch"; - hash = "sha256-ileSNYddOt1F5rooRB0fXT20WkVlnG+gP5w7qJdBuww="; - }); + patches = + lib.optional stdenv.hostPlatform.isRiscV + # Adds CMake option HWY_CMAKE_RVV + # https://github.com/google/highway/pull/1743 + ( + fetchpatch { + name = "libhwy-add-rvv-optout.patch"; + url = "https://github.com/google/highway/commit/5d58d233fbcec0c6a39df8186a877329147324b3.patch"; + hash = "sha256-ileSNYddOt1F5rooRB0fXT20WkVlnG+gP5w7qJdBuww="; + } + ); hardeningDisable = lib.optionals stdenv.hostPlatform.isAarch64 [ # aarch64-specific code gets: @@ -33,38 +37,47 @@ stdenv.mkDerivation rec { "trivialautovarinit" ]; - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; # Required for case-insensitive filesystems ("BUILD" exists) dontUseCmakeBuildDir = true; - cmakeFlags = let - libExt = stdenv.hostPlatform.extensions.library; - in [ - "-GNinja" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals doCheck [ - "-DHWY_SYSTEM_GTEST:BOOL=ON" - "-DGTEST_INCLUDE_DIR=${lib.getDev gtest}/include" - "-DGTEST_LIBRARY=${lib.getLib gtest}/lib/libgtest${libExt}" - "-DGTEST_MAIN_LIBRARY=${lib.getLib gtest}/lib/libgtest_main${libExt}" - ] ++ lib.optionals stdenv.hostPlatform.isAarch32 [ - "-DHWY_CMAKE_ARM7=ON" - ] ++ lib.optionals stdenv.hostPlatform.isx86_32 [ - # Quoting CMakelists.txt: - # This must be set on 32-bit x86 with GCC < 13.1, otherwise math_test will be - # skipped. For GCC 13.1+, you can also build with -fexcess-precision=standard. - # Fixes tests: - # HwyMathTestGroup/HwyMathTest.TestAllAtanh/EMU128 - # HwyMathTestGroup/HwyMathTest.TestAllLog1p/EMU128 - "-DHWY_CMAKE_SSE2=ON" - ] ++ lib.optionals stdenv.hostPlatform.isRiscV [ - # Runtime dispatch is not implemented https://github.com/google/highway/issues/838 - # so tests (and likely normal operation) fail with SIGILL on processors without V. - # Until the issue is resolved, we disable RVV completely. - "-DHWY_CMAKE_RVV=OFF" - ]; + cmakeFlags = + let + libExt = stdenv.hostPlatform.extensions.library; + in + [ + "-GNinja" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals doCheck [ + "-DHWY_SYSTEM_GTEST:BOOL=ON" + "-DGTEST_INCLUDE_DIR=${lib.getDev gtest}/include" + "-DGTEST_LIBRARY=${lib.getLib gtest}/lib/libgtest${libExt}" + "-DGTEST_MAIN_LIBRARY=${lib.getLib gtest}/lib/libgtest_main${libExt}" + ] + ++ lib.optionals stdenv.hostPlatform.isAarch32 [ + "-DHWY_CMAKE_ARM7=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isx86_32 [ + # Quoting CMakelists.txt: + # This must be set on 32-bit x86 with GCC < 13.1, otherwise math_test will be + # skipped. For GCC 13.1+, you can also build with -fexcess-precision=standard. + # Fixes tests: + # HwyMathTestGroup/HwyMathTest.TestAllAtanh/EMU128 + # HwyMathTestGroup/HwyMathTest.TestAllLog1p/EMU128 + "-DHWY_CMAKE_SSE2=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isRiscV [ + # Runtime dispatch is not implemented https://github.com/google/highway/issues/838 + # so tests (and likely normal operation) fail with SIGILL on processors without V. + # Until the issue is resolved, we disable RVV completely. + "-DHWY_CMAKE_RVV=OFF" + ]; # hydra's darwin machines run into https://github.com/libjxl/libjxl/issues/408 doCheck = !stdenv.hostPlatform.isDarwin; @@ -72,7 +85,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Performance-portable, length-agnostic SIMD with runtime dispatch"; homepage = "https://github.com/google/highway"; - license = with licenses; [ asl20 bsd3 ]; + license = with licenses; [ + asl20 + bsd3 + ]; platforms = platforms.unix; maintainers = with maintainers; [ zhaofengli ]; }; diff --git a/pkgs/by-name/li/libibmad/package.nix b/pkgs/by-name/li/libibmad/package.nix index 9088d9022069f2..40fea538483519 100644 --- a/pkgs/by-name/li/libibmad/package.nix +++ b/pkgs/by-name/li/libibmad/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libibumad }: +{ + lib, + stdenv, + fetchurl, + libibumad, +}: stdenv.mkDerivation rec { pname = "libibmad"; diff --git a/pkgs/by-name/li/libibumad/package.nix b/pkgs/by-name/li/libibumad/package.nix index b9ebef7d4ccbb4..1f280e4142cd36 100644 --- a/pkgs/by-name/li/libibumad/package.nix +++ b/pkgs/by-name/li/libibumad/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libibumad"; diff --git a/pkgs/by-name/li/libical/package.nix b/pkgs/by-name/li/libical/package.nix index f6a0555f341239..ef92eddd101146 100644 --- a/pkgs/by-name/li/libical/package.nix +++ b/pkgs/by-name/li/libical/package.nix @@ -1,29 +1,33 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkgsBuildBuild -, pkgsBuildHost -, cmake -, glib -, icu -, libxml2 -, ninja -, perl -, pkg-config -, libical -, python3 -, tzdata -, fixDarwinDylibNames -, withIntrospection ? stdenv.hostPlatform.emulatorAvailable pkgsBuildHost -, gobject-introspection -, vala +{ + lib, + stdenv, + fetchFromGitHub, + pkgsBuildBuild, + pkgsBuildHost, + cmake, + glib, + icu, + libxml2, + ninja, + perl, + pkg-config, + libical, + python3, + tzdata, + fixDarwinDylibNames, + withIntrospection ? stdenv.hostPlatform.emulatorAvailable pkgsBuildHost, + gobject-introspection, + vala, }: stdenv.mkDerivation rec { pname = "libical"; version = "3.0.18"; - outputs = [ "out" "dev" ]; # "devdoc" ]; + outputs = [ + "out" + "dev" + ]; # "devdoc" ]; src = fetchFromGitHub { owner = "libical"; @@ -39,27 +43,32 @@ stdenv.mkDerivation rec { libical ]; - nativeBuildInputs = [ - cmake - icu - ninja - perl - pkg-config - ] ++ lib.optionals withIntrospection [ - gobject-introspection - vala - # Docs building fails: - # https://github.com/NixOS/nixpkgs/pull/67204 - # previously with https://github.com/NixOS/nixpkgs/pull/61657#issuecomment-495579489 - # gtk-doc docbook_xsl docbook_xml_dtd_43 # for docs - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ]; + nativeBuildInputs = + [ + cmake + icu + ninja + perl + pkg-config + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + vala + # Docs building fails: + # https://github.com/NixOS/nixpkgs/pull/67204 + # previously with https://github.com/NixOS/nixpkgs/pull/61657#issuecomment-495579489 + # gtk-doc docbook_xsl docbook_xml_dtd_43 # for docs + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ]; nativeInstallCheckInputs = [ # running libical-glib tests - (python3.pythonOnBuildForHost.withPackages (pkgs: with pkgs; [ - pygobject3 - ])) + (python3.pythonOnBuildForHost.withPackages ( + pkgs: with pkgs; [ + pygobject3 + ] + )) ]; buildInputs = [ @@ -68,13 +77,15 @@ stdenv.mkDerivation rec { icu ]; - cmakeFlags = [ - "-DENABLE_GTK_DOC=False" - "-DGOBJECT_INTROSPECTION=${if withIntrospection then "True" else "False"}" - "-DICAL_GLIB_VAPI=${if withIntrospection then "True" else "False"}" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "-DIMPORT_ICAL_GLIB_SRC_GENERATOR=${lib.getDev pkgsBuildBuild.libical}/lib/cmake/LibIcal/IcalGlibSrcGenerator.cmake" - ]; + cmakeFlags = + [ + "-DENABLE_GTK_DOC=False" + "-DGOBJECT_INTROSPECTION=${if withIntrospection then "True" else "False"}" + "-DICAL_GLIB_VAPI=${if withIntrospection then "True" else "False"}" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "-DIMPORT_ICAL_GLIB_SRC_GENERATOR=${lib.getDev pkgsBuildBuild.libical}/lib/cmake/LibIcal/IcalGlibSrcGenerator.cmake" + ]; patches = [ # Will appear in 3.1.0 @@ -95,13 +106,17 @@ stdenv.mkDerivation rec { # Musl does not support TZDIR. doInstallCheck = !stdenv.hostPlatform.isMusl; enableParallelChecking = false; - preInstallCheck = if stdenv.hostPlatform.isDarwin then '' - for testexe in $(find ./src/test -maxdepth 1 -type f -executable); do - for lib in $(cd lib && ls *.3.dylib); do - install_name_tool -change $lib $out/lib/$lib $testexe - done - done - '' else null; + preInstallCheck = + if stdenv.hostPlatform.isDarwin then + '' + for testexe in $(find ./src/test -maxdepth 1 -type f -executable); do + for lib in $(cd lib && ls *.3.dylib); do + install_name_tool -change $lib $out/lib/$lib $testexe + done + done + '' + else + null; installCheckPhase = '' runHook preInstallCheck diff --git a/pkgs/by-name/li/libicns/package.nix b/pkgs/by-name/li/libicns/package.nix index fc2fa9b664879f..d0853240ec5655 100644 --- a/pkgs/by-name/li/libicns/package.nix +++ b/pkgs/by-name/li/libicns/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchgit, autoreconfHook, pkg-config, libpng, openjpeg, zlib }: +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + pkg-config, + libpng, + openjpeg, + zlib, +}: stdenv.mkDerivation { pname = "libicns"; @@ -11,13 +20,24 @@ stdenv.mkDerivation { hash = "sha256-YeO0rlTujDNmrdJ3DRyl3TORswF2KFKA+wVUxJo8Dno"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libpng openjpeg zlib ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libpng + openjpeg + zlib + ]; meta = with lib; { description = "Library for manipulation of the Mac OS icns resource format"; homepage = "https://icns.sourceforge.io"; - license = with licenses; [ gpl2 lgpl2 lgpl21 ]; + license = with licenses; [ + gpl2 + lgpl2 + lgpl21 + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/li/libidn/package.nix b/pkgs/by-name/li/libidn/package.nix index bafb2fff272fba..b591ed684689e3 100644 --- a/pkgs/by-name/li/libidn/package.nix +++ b/pkgs/by-name/li/libidn/package.nix @@ -1,5 +1,9 @@ -{ fetchurl, lib, stdenv, libiconv -, testers +{ + fetchurl, + lib, + stdenv, + libiconv, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -11,7 +15,13 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-1sGZ3NgG5P4nk2DLSwg0mg05Vg7VSP/RzK3ajN7LRyM="; }; - outputs = [ "bin" "dev" "out" "info" "devdoc" ]; + outputs = [ + "bin" + "dev" + "out" + "info" + "devdoc" + ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/li/libiec61883/package.nix b/pkgs/by-name/li/libiec61883/package.nix index 911210202fe06a..42d7254f09090f 100644 --- a/pkgs/by-name/li/libiec61883/package.nix +++ b/pkgs/by-name/li/libiec61883/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libraw1394 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libraw1394, +}: stdenv.mkDerivation rec { version = "1.2.0"; diff --git a/pkgs/by-name/li/libieee1284/package.nix b/pkgs/by-name/li/libieee1284/package.nix index 377d56957123c3..abf3b7d16979ea 100644 --- a/pkgs/by-name/li/libieee1284/package.nix +++ b/pkgs/by-name/li/libieee1284/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl -, autoconf, automake, libtool, xmlto, docbook_xml_dtd_412, docbook_xsl +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + autoconf, + automake, + libtool, + xmlto, + docbook_xml_dtd_412, + docbook_xsl, }: stdenv.mkDerivation rec { @@ -30,14 +39,16 @@ stdenv.mkDerivation rec { docbook_xsl ]; - configureFlags = [ - "--without-python" - ] ++ lib.optionals (stdenv.hostPlatform.isMusl && !stdenv.hostPlatform.isx86) [ - # musl always provides , even though the functionality - # is x86-specific. - # https://www.openwall.com/lists/musl/2024/10/25/2 - "ac_cv_header_sys_io_h=no" - ]; + configureFlags = + [ + "--without-python" + ] + ++ lib.optionals (stdenv.hostPlatform.isMusl && !stdenv.hostPlatform.isx86) [ + # musl always provides , even though the functionality + # is x86-specific. + # https://www.openwall.com/lists/musl/2024/10/25/2 + "ac_cv_header_sys_io_h=no" + ]; prePatch = '' ./bootstrap diff --git a/pkgs/by-name/li/libime/package.nix b/pkgs/by-name/li/libime/package.nix index c7bd59d016cfc0..db80dc81742f78 100644 --- a/pkgs/by-name/li/libime/package.nix +++ b/pkgs/by-name/li/libime/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitHub -, cmake -, extra-cmake-modules -, boost -, python3 -, fcitx5 -, zstd +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + cmake, + extra-cmake-modules, + boost, + python3, + fcitx5, + zstd, }: let diff --git a/pkgs/by-name/li/libimobiledevice-glue/package.nix b/pkgs/by-name/li/libimobiledevice-glue/package.nix index 99eb6c3cede04d..01a0ea4f8494df 100644 --- a/pkgs/by-name/li/libimobiledevice-glue/package.nix +++ b/pkgs/by-name/li/libimobiledevice-glue/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libplist -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libplist, + nix-update-script, }: stdenv.mkDerivation rec { @@ -31,7 +32,10 @@ stdenv.mkDerivation rec { libplist ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/by-name/li/libindicator/package.nix b/pkgs/by-name/li/libindicator/package.nix index 767b7a1d8cf247..72bd23985a3810 100644 --- a/pkgs/by-name/li/libindicator/package.nix +++ b/pkgs/by-name/li/libindicator/package.nix @@ -1,6 +1,14 @@ -{ stdenv, fetchurl, lib, file -, pkg-config, glib -, gtkVersion ? "3", gtk2, gtk3 }: +{ + stdenv, + fetchurl, + lib, + file, + pkg-config, + glib, + gtkVersion ? "3", + gtk2, + gtk3, +}: stdenv.mkDerivation rec { pname = "libindicator-gtk${gtkVersion}"; @@ -13,7 +21,10 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ pkg-config glib ]; + nativeBuildInputs = [ + pkg-config + glib + ]; buildInputs = [ (if gtkVersion == "2" then gtk2 else gtk3) ]; diff --git a/pkgs/by-name/li/libinfinity/package.nix b/pkgs/by-name/li/libinfinity/package.nix index e720ee8b072629..dd76a585a70944 100644 --- a/pkgs/by-name/li/libinfinity/package.nix +++ b/pkgs/by-name/li/libinfinity/package.nix @@ -1,9 +1,25 @@ -{ gtkWidgets ? false # build GTK widgets for libinfinity -, avahiSupport ? false # build support for Avahi in libinfinity -, lib, stdenv, fetchurl, pkg-config, glib, libxml2, gnutls, gsasl -, gobject-introspection -, gtk3 ? null, gtk-doc, docbook_xsl, docbook_xml_dtd_412, avahi ? null, libdaemon, libidn, gss -, libintl }: +{ + gtkWidgets ? false, # build GTK widgets for libinfinity + avahiSupport ? false, # build support for Avahi in libinfinity + lib, + stdenv, + fetchurl, + pkg-config, + glib, + libxml2, + gnutls, + gsasl, + gobject-introspection, + gtk3 ? null, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_412, + avahi ? null, + libdaemon, + libidn, + gss, + libintl, +}: assert avahiSupport -> avahi != null; assert gtkWidgets -> gtk3 != null; @@ -17,10 +33,31 @@ let sha256 = "17i3g61hxz9pzl3ryd1yr15142r25m06jfzjrpdy7ic1b8vjjw3f"; }; - outputs = [ "bin" "out" "dev" "man" "devdoc" ]; + outputs = [ + "bin" + "out" + "dev" + "man" + "devdoc" + ]; - nativeBuildInputs = [ pkg-config gtk-doc docbook_xsl docbook_xml_dtd_412 gobject-introspection ]; - buildInputs = [ glib libxml2 gsasl libidn gss libintl libdaemon ] + nativeBuildInputs = [ + pkg-config + gtk-doc + docbook_xsl + docbook_xml_dtd_412 + gobject-introspection + ]; + buildInputs = + [ + glib + libxml2 + gsasl + libidn + gss + libintl + libdaemon + ] ++ lib.optional gtkWidgets gtk3 ++ lib.optional avahiSupport avahi; @@ -49,4 +86,5 @@ let platforms = with lib.platforms; linux ++ darwin; }; }; -in self +in +self diff --git a/pkgs/by-name/li/libinjection/package.nix b/pkgs/by-name/li/libinjection/package.nix index d4193f32ccc084..ebecb25ece7caf 100644 --- a/pkgs/by-name/li/libinjection/package.nix +++ b/pkgs/by-name/li/libinjection/package.nix @@ -1,15 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + python3, }: stdenv.mkDerivation rec { - pname = "libinjection"; + pname = "libinjection"; version = "3.10.0"; src = fetchFromGitHub { - owner = "client9"; - repo = pname; - rev = "refs/tags/v${version}"; + owner = "client9"; + repo = pname; + rev = "refs/tags/v${version}"; sha256 = "0chsgam5dqr9vjfhdcp8cgk7la6nf3lq44zs6z6si98cq743550g"; }; @@ -35,13 +39,16 @@ stdenv.mkDerivation rec { buildPhase = "make all"; # no binaries, so out = library, dev = headers - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = with lib; { description = "SQL / SQLI tokenizer parser analyzer"; - homepage = "https://github.com/client9/libinjection"; - license = licenses.bsd3; - platforms = platforms.all; + homepage = "https://github.com/client9/libinjection"; + license = licenses.bsd3; + platforms = platforms.all; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/li/libinklevel/package.nix b/pkgs/by-name/li/libinklevel/package.nix index 945fa0df5962da..602ef0687123d1 100644 --- a/pkgs/by-name/li/libinklevel/package.nix +++ b/pkgs/by-name/li/libinklevel/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libusb1 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libusb1, +}: stdenv.mkDerivation rec { pname = "libinklevel"; @@ -14,7 +20,11 @@ stdenv.mkDerivation rec { libusb1 ]; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; meta = with lib; { description = "Library for checking the ink level of your printer"; diff --git a/pkgs/by-name/li/libinotify-kqueue/package.nix b/pkgs/by-name/li/libinotify-kqueue/package.nix index 3d73ace3c925ae..f797660b0b79a4 100644 --- a/pkgs/by-name/li/libinotify-kqueue/package.nix +++ b/pkgs/by-name/li/libinotify-kqueue/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libinotify-kqueue"; diff --git a/pkgs/by-name/li/libinsane/package.nix b/pkgs/by-name/li/libinsane/package.nix index a83268ca31ad59..c91d4b27113201 100644 --- a/pkgs/by-name/li/libinsane/package.nix +++ b/pkgs/by-name/li/libinsane/package.nix @@ -1,25 +1,30 @@ -{ stdenv -, lib -, meson -, ninja -, fetchFromGitLab -, pkg-config -, glib -, docbook_xsl -, sane-backends -, gobject-introspection -, vala -, gtk-doc -, valgrind -, doxygen -, cunit +{ + stdenv, + lib, + meson, + ninja, + fetchFromGitLab, + pkg-config, + glib, + docbook_xsl, + sane-backends, + gobject-introspection, + vala, + gtk-doc, + valgrind, + doxygen, + cunit, }: stdenv.mkDerivation rec { pname = "libinsane"; version = "1.0.10"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitLab { domain = "gitlab.gnome.org"; @@ -30,11 +35,26 @@ stdenv.mkDerivation rec { sha256 = "sha256-2BLg8zB0InPJqK9JypQIMVXIJndo9ZuNB4OeOAo/Hsc="; }; - nativeBuildInputs = [ meson pkg-config ninja doxygen gtk-doc docbook_xsl gobject-introspection vala ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + doxygen + gtk-doc + docbook_xsl + gobject-introspection + vala + ]; - buildInputs = [ sane-backends glib ]; + buildInputs = [ + sane-backends + glib + ]; - nativeCheckInputs = [ cunit valgrind ]; + nativeCheckInputs = [ + cunit + valgrind + ]; doCheck = true; diff --git a/pkgs/by-name/li/libinstpatch/package.nix b/pkgs/by-name/li/libinstpatch/package.nix index 670dee26b2bf7e..bc7f391ff1e658 100644 --- a/pkgs/by-name/li/libinstpatch/package.nix +++ b/pkgs/by-name/li/libinstpatch/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, glib, libsndfile }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + glib, + libsndfile, +}: stdenv.mkDerivation rec { pname = "libinstpatch"; @@ -11,9 +19,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-OU6/slrPDgzn9tvXZJKSWbcFbpS/EAsOi52FtjeYdvA="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - propagatedBuildInputs = [ glib libsndfile ]; # Both are needed for includes. + propagatedBuildInputs = [ + glib + libsndfile + ]; # Both are needed for includes. cmakeFlags = [ "-DLIB_SUFFIX=" # Install in $out/lib. diff --git a/pkgs/by-name/li/libipfix/package.nix b/pkgs/by-name/li/libipfix/package.nix index e6ddb9b471c7c2..70f480e0570b2d 100644 --- a/pkgs/by-name/li/libipfix/package.nix +++ b/pkgs/by-name/li/libipfix/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "libipfix"; diff --git a/pkgs/by-name/li/libipt/package.nix b/pkgs/by-name/li/libipt/package.nix index 060f6a803566a0..73f14cec3603ad 100644 --- a/pkgs/by-name/li/libipt/package.nix +++ b/pkgs/by-name/li/libipt/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, freebsd }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + freebsd, +}: stdenv.mkDerivation rec { pname = "libipt"; diff --git a/pkgs/by-name/li/libiptcdata/package.nix b/pkgs/by-name/li/libiptcdata/package.nix index 741c8d8a74a5a2..3e25f36bd6e510 100644 --- a/pkgs/by-name/li/libiptcdata/package.nix +++ b/pkgs/by-name/li/libiptcdata/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, libiconv -, libintl +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libiconv, + libintl, }: stdenv.mkDerivation rec { @@ -13,7 +14,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "ianw"; repo = pname; - rev = "release_${builtins.replaceStrings ["."] ["_"] version}"; + rev = "release_${builtins.replaceStrings [ "." ] [ "_" ] version}"; sha256 = "sha256-ZjokepDAHiSEwXrkvM9qUAPcpIiRQoOsv7REle7roPU="; }; diff --git a/pkgs/by-name/li/libipuz/package.nix b/pkgs/by-name/li/libipuz/package.nix index 5ea6b5527bb69f..38761b128834fa 100644 --- a/pkgs/by-name/li/libipuz/package.nix +++ b/pkgs/by-name/li/libipuz/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, glib -, json-glib +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + glib, + json-glib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libircclient/package.nix b/pkgs/by-name/li/libircclient/package.nix index 9d64b53c13f4ba..903dafce1b5854 100644 --- a/pkgs/by-name/li/libircclient/package.nix +++ b/pkgs/by-name/li/libircclient/package.nix @@ -1,15 +1,22 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "1.10"; - pname = "libircclient"; + pname = "libircclient"; src = fetchurl { - url = "mirror://sourceforge/${pname}/${pname}/${version}/${pname}-${version}.tar.gz"; + url = "mirror://sourceforge/${pname}/${pname}/${version}/${pname}-${version}.tar.gz"; sha256 = "0b9wa0h3xc31wpqlvgxgnvqp5wgx3kwsf5s9432m5cj8ycx6zcmv"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; configureFlags = [ "--enable-shared" ]; @@ -22,9 +29,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Small but extremely powerful library which implements the client IRC protocol"; - homepage = "http://www.ulduzsoft.com/libircclient/"; - license = licenses.lgpl3; + homepage = "http://www.ulduzsoft.com/libircclient/"; + license = licenses.lgpl3; maintainers = with maintainers; [ obadz ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/li/libirecovery/package.nix b/pkgs/by-name/li/libirecovery/package.nix index c58287aedad16d..f9be0ab0146bcd 100644 --- a/pkgs/by-name/li/libirecovery/package.nix +++ b/pkgs/by-name/li/libirecovery/package.nix @@ -1,18 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libusb1 -, readline -, libimobiledevice-glue +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libusb1, + readline, + libimobiledevice-glue, }: stdenv.mkDerivation rec { pname = "libirecovery"; version = "1.2.1"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "libimobiledevice"; diff --git a/pkgs/by-name/li/libiscsi/package.nix b/pkgs/by-name/li/libiscsi/package.nix index 2a0d722c3d0fdc..6067083ef57abf 100644 --- a/pkgs/by-name/li/libiscsi/package.nix +++ b/pkgs/by-name/li/libiscsi/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libiscsi"; diff --git a/pkgs/by-name/li/libisds/package.nix b/pkgs/by-name/li/libisds/package.nix index 4c61e3c48868d5..5ca83d7f6edd6f 100644 --- a/pkgs/by-name/li/libisds/package.nix +++ b/pkgs/by-name/li/libisds/package.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, fetchurl -, expat -, gpgme -, libgcrypt -, libxml2 -, libxslt -, curl -, docbook_xsl +{ + lib, + stdenv, + fetchurl, + expat, + gpgme, + libgcrypt, + libxml2, + libxslt, + curl, + docbook_xsl, }: stdenv.mkDerivation rec { @@ -22,7 +24,15 @@ stdenv.mkDerivation rec { "--with-docbook-xsl-stylesheets=${docbook_xsl}/xml/xsl/docbook" ]; - buildInputs = [ expat gpgme libgcrypt libxml2 libxslt curl docbook_xsl ]; + buildInputs = [ + expat + gpgme + libgcrypt + libxml2 + libxslt + curl + docbook_xsl + ]; NIX_CFLAGS_COMPILE = [ "-Wno-error=deprecated-declarations" ]; diff --git a/pkgs/by-name/li/libisoburn/package.nix b/pkgs/by-name/li/libisoburn/package.nix index 498c3394d3e1df..fec34a43457090 100644 --- a/pkgs/by-name/li/libisoburn/package.nix +++ b/pkgs/by-name/li/libisoburn/package.nix @@ -1,17 +1,18 @@ -{ lib -, acl -, attr -, autoreconfHook -, bzip2 -, fetchFromGitea -, libburn -, libcdio -, libiconv -, libisofs -, pkg-config -, readline -, stdenv -, zlib +{ + lib, + acl, + attr, + autoreconfHook, + bzip2, + fetchFromGitea, + libburn, + libcdio, + libiconv, + libisofs, + pkg-config, + readline, + stdenv, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -31,24 +32,32 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - bzip2 - libcdio - libiconv - readline - zlib - libburn - libisofs - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - acl - attr - ]; + buildInputs = + [ + bzip2 + libcdio + libiconv + readline + zlib + libburn + libisofs + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + acl + attr + ]; propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ acl ]; - outputs = [ "out" "lib" "dev" "info" "man" ]; + outputs = [ + "out" + "lib" + "dev" + "info" + "man" + ]; strictDeps = true; diff --git a/pkgs/by-name/li/libisofs/package.nix b/pkgs/by-name/li/libisofs/package.nix index 52b807c6c8d234..1d8b772eabf932 100644 --- a/pkgs/by-name/li/libisofs/package.nix +++ b/pkgs/by-name/li/libisofs/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitea -, acl -, attr -, autoreconfHook -, libiconv -, zlib +{ + lib, + stdenv, + fetchFromGitea, + acl, + attr, + autoreconfHook, + libiconv, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -24,16 +25,22 @@ stdenv.mkDerivation (finalAttrs: { autoreconfHook ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - acl - attr - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - ] ++ [ - zlib - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + acl + attr + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + ] + ++ [ + zlib + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; enableParallelBuilding = true; @@ -42,7 +49,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Library to create an ISO-9660 filesystem with extensions like RockRidge or Joliet"; changelog = "https://dev.lovelyhq.com/libburnia/libisofs/src/tag/${finalAttrs.src.rev}/ChangeLog"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ abbradar AndersonTorres ]; + maintainers = with lib.maintainers; [ + abbradar + AndersonTorres + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/by-name/li/libite/package.nix b/pkgs/by-name/li/libite/package.nix index 8b70a3b715f6c7..74dffc4d645045 100644 --- a/pkgs/by-name/li/libite/package.nix +++ b/pkgs/by-name/li/libite/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, libconfuse }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libconfuse, +}: stdenv.mkDerivation rec { pname = "libite"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-q1NoHSiPmFPwkTJqg3L5fEBXF/JjRWvA9e4d532ILE8="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libconfuse ]; meta = with lib; { @@ -31,7 +41,11 @@ stdenv.mkDerivation rec { homepage = "https://github.com/troglobit/libite"; platforms = with platforms; linux ++ netbsd; maintainers = with maintainers; [ fpletz ]; - license = with licenses; [ mit isc bsd2 bsd3 ]; + license = with licenses; [ + mit + isc + bsd2 + bsd3 + ]; }; } - diff --git a/pkgs/by-name/li/libitl/package.nix b/pkgs/by-name/li/libitl/package.nix index 8bec704064c565..ce6c87b115ee34 100644 --- a/pkgs/by-name/li/libitl/package.nix +++ b/pkgs/by-name/li/libitl/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/libivykis/package.nix b/pkgs/by-name/li/libivykis/package.nix index aebc93f7e22402..5cb6cc0fbd0b43 100644 --- a/pkgs/by-name/li/libivykis/package.nix +++ b/pkgs/by-name/li/libivykis/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pkg-config, file, protobufc }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + file, + protobufc, +}: stdenv.mkDerivation rec { pname = "libivykis"; @@ -10,8 +18,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-k+PpsjdpVDfNY9SqSKjZ39izm8KKGSpXcNETxP6Qme8="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ file protobufc ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + file + protobufc + ]; meta = with lib; { homepage = "https://libivykis.sourceforge.net/"; diff --git a/pkgs/by-name/li/libixion/package.nix b/pkgs/by-name/li/libixion/package.nix index c501442ff8be2b..79283f35fa15dd 100644 --- a/pkgs/by-name/li/libixion/package.nix +++ b/pkgs/by-name/li/libixion/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitLab -, autoreconfHook -, pkg-config -, boost -, mdds -, python3 +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + boost, + mdds, + python3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libixp/package.nix b/pkgs/by-name/li/libixp/package.nix index 7d235d7a7649dd..be0cee4aff59ae 100644 --- a/pkgs/by-name/li/libixp/package.nix +++ b/pkgs/by-name/li/libixp/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, unzip, txt2tags }: +{ + lib, + stdenv, + fetchFromGitHub, + unzip, + txt2tags, +}: stdenv.mkDerivation rec { pname = "libixp"; @@ -17,7 +23,7 @@ stdenv.mkDerivation rec { ''; postConfigure = '' - sed -i -e "s|^PREFIX.*=.*$|PREFIX = $out|" config.mk + sed -i -e "s|^PREFIX.*=.*$|PREFIX = $out|" config.mk ''; nativeBuildInputs = [ unzip ]; diff --git a/pkgs/by-name/li/libjcat/package.nix b/pkgs/by-name/li/libjcat/package.nix index fac097e0d6b0e0..8393016e39da6e 100644 --- a/pkgs/by-name/li/libjcat/package.nix +++ b/pkgs/by-name/li/libjcat/package.nix @@ -1,27 +1,35 @@ -{ stdenv -, lib -, fetchFromGitHub -, docbook_xml_dtd_43 -, docbook-xsl-nons -, glib -, json-glib -, gnutls -, gpgme -, gobject-introspection -, vala -, gtk-doc -, meson -, ninja -, pkg-config -, python3 -, nixosTests +{ + stdenv, + lib, + fetchFromGitHub, + docbook_xml_dtd_43, + docbook-xsl-nons, + glib, + json-glib, + gnutls, + gpgme, + gobject-introspection, + vala, + gtk-doc, + meson, + ninja, + pkg-config, + python3, + nixosTests, }: stdenv.mkDerivation rec { pname = "libjcat"; version = "0.2.2"; - outputs = [ "bin" "out" "dev" "devdoc" "man" "installedTests" ]; + outputs = [ + "bin" + "out" + "dev" + "devdoc" + "man" + "installedTests" + ]; src = fetchFromGitHub { owner = "hughsie"; diff --git a/pkgs/by-name/li/libjpeg_turbo/package.nix b/pkgs/by-name/li/libjpeg_turbo/package.nix index eb638d8c6e74ef..b991a63951fe71 100644 --- a/pkgs/by-name/li/libjpeg_turbo/package.nix +++ b/pkgs/by-name/li/libjpeg_turbo/package.nix @@ -1,33 +1,34 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, nasm -, openjdk -, enableJava ? false # whether to build the java wrapper -, enableJpeg7 ? false # whether to build libjpeg with v7 compatibility -, enableJpeg8 ? false # whether to build libjpeg with v8 compatibility -, enableStatic ? stdenv.hostPlatform.isStatic -, enableShared ? !stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + nasm, + openjdk, + enableJava ? false, # whether to build the java wrapper + enableJpeg7 ? false, # whether to build libjpeg with v7 compatibility + enableJpeg8 ? false, # whether to build libjpeg with v8 compatibility + enableStatic ? stdenv.hostPlatform.isStatic, + enableShared ? !stdenv.hostPlatform.isStatic, -# for passthru.tests -, dvgrab -, epeg -, freeimage -, gd -, graphicsmagick -, imagemagick -, imlib2 -, jhead -, libjxl -, mjpegtools -, opencv -, python3 -, vips -, testers + # for passthru.tests + dvgrab, + epeg, + freeimage, + gd, + graphicsmagick, + imagemagick, + imlib2, + jhead, + libjxl, + mjpegtools, + opencv, + python3, + vips, + testers, }: -assert !(enableJpeg7 && enableJpeg8); # pick only one or none, not both +assert !(enableJpeg7 && enableJpeg8); # pick only one or none, not both stdenv.mkDerivation (finalAttrs: { @@ -41,42 +42,59 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-ZNqhOfZtWcMv10VWIUxn7MSy4KhW/jBrgC1tUFKczqs="; }; - patches = [ - # This is needed by freeimage - ./0001-Compile-transupp.c-as-part-of-the-library.patch - ] ++ lib.optionals (!stdenv.hostPlatform.isMinGW) [ - ./0002-Make-exported-symbols-in-transupp.c-weak.patch - ] ++ lib.optionals stdenv.hostPlatform.isMinGW [ - ./mingw-boolean.patch - ]; + patches = + [ + # This is needed by freeimage + ./0001-Compile-transupp.c-as-part-of-the-library.patch + ] + ++ lib.optionals (!stdenv.hostPlatform.isMinGW) [ + ./0002-Make-exported-symbols-in-transupp.c-weak.patch + ] + ++ lib.optionals stdenv.hostPlatform.isMinGW [ + ./mingw-boolean.patch + ]; - outputs = [ "bin" "dev" "dev_private" "out" "man" "doc" ]; + outputs = [ + "bin" + "dev" + "dev_private" + "out" + "man" + "doc" + ]; postFixup = '' moveToOutput include/transupp.h $dev_private ''; - nativeBuildInputs = [ - cmake - nasm - ] ++ lib.optionals enableJava [ - openjdk - ]; + nativeBuildInputs = + [ + cmake + nasm + ] + ++ lib.optionals enableJava [ + openjdk + ]; - cmakeFlags = [ - "-DENABLE_STATIC=${if enableStatic then "1" else "0"}" - "-DENABLE_SHARED=${if enableShared then "1" else "0"}" - ] ++ lib.optionals enableJava [ - "-DWITH_JAVA=1" - ] ++ lib.optionals enableJpeg7 [ - "-DWITH_JPEG7=1" - ] ++ lib.optionals enableJpeg8 [ - "-DWITH_JPEG8=1" - ] ++ lib.optionals stdenv.hostPlatform.isRiscV [ - # https://github.com/libjpeg-turbo/libjpeg-turbo/issues/428 - # https://github.com/libjpeg-turbo/libjpeg-turbo/commit/88bf1d16786c74f76f2e4f6ec2873d092f577c75 - "-DFLOATTEST=fp-contract" - ]; + cmakeFlags = + [ + "-DENABLE_STATIC=${if enableStatic then "1" else "0"}" + "-DENABLE_SHARED=${if enableShared then "1" else "0"}" + ] + ++ lib.optionals enableJava [ + "-DWITH_JAVA=1" + ] + ++ lib.optionals enableJpeg7 [ + "-DWITH_JPEG7=1" + ] + ++ lib.optionals enableJpeg8 [ + "-DWITH_JPEG8=1" + ] + ++ lib.optionals stdenv.hostPlatform.isRiscV [ + # https://github.com/libjpeg-turbo/libjpeg-turbo/issues/428 + # https://github.com/libjpeg-turbo/libjpeg-turbo/commit/88bf1d16786c74f76f2e4f6ec2873d092f577c75 + "-DFLOATTEST=fp-contract" + ]; doInstallCheck = true; installCheckTarget = "test"; @@ -93,7 +111,8 @@ stdenv.mkDerivation (finalAttrs: { libjxl mjpegtools opencv - vips; + vips + ; inherit (python3.pkgs) pillow imread pyturbojpeg; pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; }; @@ -102,8 +121,15 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://libjpeg-turbo.org/"; description = "Faster (using SIMD) libjpeg implementation"; license = licenses.ijg; # and some parts under other BSD-style licenses - pkgConfigModules = [ "libjpeg" "libturbojpeg" ]; - maintainers = with maintainers; [ vcunat colemickens kamadorueda ]; + pkgConfigModules = [ + "libjpeg" + "libturbojpeg" + ]; + maintainers = with maintainers; [ + vcunat + colemickens + kamadorueda + ]; platforms = platforms.all; }; }) diff --git a/pkgs/by-name/li/libjson-rpc-cpp/package.nix b/pkgs/by-name/li/libjson-rpc-cpp/package.nix index f132a66560be43..b2e3417c092081 100644 --- a/pkgs/by-name/li/libjson-rpc-cpp/package.nix +++ b/pkgs/by-name/li/libjson-rpc-cpp/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, cmake, argtable, catch2 -, curl, doxygen, hiredis, jsoncpp, libmicrohttpd }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + argtable, + catch2, + curl, + doxygen, + hiredis, + jsoncpp, + libmicrohttpd, +}: stdenv.mkDerivation rec { pname = "libjson-rpc-cpp"; @@ -14,9 +26,20 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = "-I${catch2}/include/catch2"; - nativeBuildInputs = [ pkg-config cmake doxygen ]; + nativeBuildInputs = [ + pkg-config + cmake + doxygen + ]; - buildInputs = [ argtable catch2 curl hiredis jsoncpp libmicrohttpd ]; + buildInputs = [ + argtable + catch2 + curl + hiredis + jsoncpp + libmicrohttpd + ]; postPatch = '' for f in cmake/FindArgtable.cmake \ @@ -47,7 +70,12 @@ stdenv.mkDerivation rec { function fixRunPath { p=$(patchelf --print-rpath $1) q="$p:${ - lib.makeLibraryPath [ jsoncpp argtable libmicrohttpd curl ] + lib.makeLibraryPath [ + jsoncpp + argtable + libmicrohttpd + curl + ] }:$out/lib" patchelf --set-rpath $q $1 } diff --git a/pkgs/by-name/li/libjson/package.nix b/pkgs/by-name/li/libjson/package.nix index dd68957616b6f7..9f27a1a319adad 100644 --- a/pkgs/by-name/li/libjson/package.nix +++ b/pkgs/by-name/li/libjson/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "libjson"; diff --git a/pkgs/by-name/li/libjwt/package.nix b/pkgs/by-name/li/libjwt/package.nix index abb6f7a220d980..d4ebba5f184232 100644 --- a/pkgs/by-name/li/libjwt/package.nix +++ b/pkgs/by-name/li/libjwt/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, autoreconfHook, pkg-config, jansson, openssl }: +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + pkg-config, + jansson, + openssl, +}: stdenv.mkDerivation rec { pname = "libjwt"; @@ -11,8 +19,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-0gFMeSW4gfbI6MUctcN8UuKhMDswaT8BzHTV2VuwZzc="; }; - buildInputs = [ jansson openssl ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + buildInputs = [ + jansson + openssl + ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; meta = with lib; { homepage = "https://github.com/benmcollins/libjwt"; diff --git a/pkgs/by-name/li/libjxl/package.nix b/pkgs/by-name/li/libjxl/package.nix index 2bd30ddda8e26f..1931916121c4a5 100644 --- a/pkgs/by-name/li/libjxl/package.nix +++ b/pkgs/by-name/li/libjxl/package.nix @@ -1,24 +1,27 @@ -{ stdenv, lib, fetchFromGitHub -, brotli -, cmake -, giflib -, gperftools -, gtest -, libhwy -, libjpeg -, libpng -, libwebp -, gdk-pixbuf -, openexr_3 -, pkg-config -, makeWrapper -, zlib -, asciidoc -, graphviz -, doxygen -, python3 -, lcms2 -, enablePlugins ? true +{ + stdenv, + lib, + fetchFromGitHub, + brotli, + cmake, + giflib, + gperftools, + gtest, + libhwy, + libjpeg, + libpng, + libwebp, + gdk-pixbuf, + openexr_3, + pkg-config, + makeWrapper, + zlib, + asciidoc, + graphviz, + doxygen, + python3, + lcms2, + enablePlugins ? true, }: let @@ -29,7 +32,10 @@ stdenv.mkDerivation rec { pname = "libjxl"; version = "0.11.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "libjxl"; @@ -90,33 +96,37 @@ stdenv.mkDerivation rec { libhwy ]; - cmakeFlags = [ - # For C dependencies like brotli, which are dynamically linked, - # we want to use the system libraries, so that we don't have to care about - # installing their .so files generated by this build. - # The other C++ dependencies are statically linked in, so there - # using the vendorered ones is easier. - "-DJPEGXL_FORCE_SYSTEM_BROTLI=ON" - - # Use our version of highway, though it is still statically linked in - "-DJPEGXL_FORCE_SYSTEM_HWY=ON" - - # Use our version of gtest - "-DJPEGXL_FORCE_SYSTEM_GTEST=ON" - - # TODO: Update this package to enable this (overridably via an option): - # Viewer tools for evaluation. - # "-DJPEGXL_ENABLE_VIEWERS=ON" - ] ++ lib.optionals enablePlugins [ - # Enable plugins, such as: - # * the `gdk-pixbuf` one, which allows applications like `eog` to load jpeg-xl files - # * the `gimp` one, which allows GIMP to load jpeg-xl files - "-DJPEGXL_ENABLE_PLUGINS=ON" - ] ++ lib.optionals stdenv.hostPlatform.isStatic [ - "-DJPEGXL_STATIC=ON" - ] ++ lib.optionals stdenv.hostPlatform.isAarch32 [ - "-DJPEGXL_FORCE_NEON=ON" - ]; + cmakeFlags = + [ + # For C dependencies like brotli, which are dynamically linked, + # we want to use the system libraries, so that we don't have to care about + # installing their .so files generated by this build. + # The other C++ dependencies are statically linked in, so there + # using the vendorered ones is easier. + "-DJPEGXL_FORCE_SYSTEM_BROTLI=ON" + + # Use our version of highway, though it is still statically linked in + "-DJPEGXL_FORCE_SYSTEM_HWY=ON" + + # Use our version of gtest + "-DJPEGXL_FORCE_SYSTEM_GTEST=ON" + + # TODO: Update this package to enable this (overridably via an option): + # Viewer tools for evaluation. + # "-DJPEGXL_ENABLE_VIEWERS=ON" + ] + ++ lib.optionals enablePlugins [ + # Enable plugins, such as: + # * the `gdk-pixbuf` one, which allows applications like `eog` to load jpeg-xl files + # * the `gimp` one, which allows GIMP to load jpeg-xl files + "-DJPEGXL_ENABLE_PLUGINS=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isStatic [ + "-DJPEGXL_STATIC=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isAarch32 [ + "-DJPEGXL_FORCE_NEON=ON" + ]; # the second substitution fix regex for a2x script # https://github.com/libjxl/libjxl/pull/3842 @@ -127,17 +137,18 @@ stdenv.mkDerivation rec { --replace 'sh$' 'sh( -e$|$)' ''; - postInstall = lib.optionalString enablePlugins '' - GDK_PIXBUF_MODULEDIR="$out/${gdk-pixbuf.moduleDir}" \ - GDK_PIXBUF_MODULE_FILE="$out/${loadersPath}" \ - gdk-pixbuf-query-loaders --update-cache - '' - # Cross-compiled gdk-pixbuf doesn't support thumbnailers - + lib.optionalString (enablePlugins && stdenv.hostPlatform == stdenv.buildPlatform) '' - mkdir -p "$out/bin" - makeWrapper ${gdk-pixbuf}/bin/gdk-pixbuf-thumbnailer "$out/libexec/gdk-pixbuf-thumbnailer-jxl" \ - --set GDK_PIXBUF_MODULE_FILE "$out/${loadersPath}" - ''; + postInstall = + lib.optionalString enablePlugins '' + GDK_PIXBUF_MODULEDIR="$out/${gdk-pixbuf.moduleDir}" \ + GDK_PIXBUF_MODULE_FILE="$out/${loadersPath}" \ + gdk-pixbuf-query-loaders --update-cache + '' + # Cross-compiled gdk-pixbuf doesn't support thumbnailers + + lib.optionalString (enablePlugins && stdenv.hostPlatform == stdenv.buildPlatform) '' + mkdir -p "$out/bin" + makeWrapper ${gdk-pixbuf}/bin/gdk-pixbuf-thumbnailer "$out/libexec/gdk-pixbuf-thumbnailer-jxl" \ + --set GDK_PIXBUF_MODULE_FILE "$out/${loadersPath}" + ''; CXXFLAGS = lib.optionalString stdenv.hostPlatform.isAarch32 "-mfp16-format=ieee"; diff --git a/pkgs/by-name/li/libkate/package.nix b/pkgs/by-name/li/libkate/package.nix index d1a9711ddd891f..418e91d7ebb07c 100644 --- a/pkgs/by-name/li/libkate/package.nix +++ b/pkgs/by-name/li/libkate/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libogg, libpng }: +{ + lib, + stdenv, + fetchurl, + libogg, + libpng, +}: stdenv.mkDerivation rec { pname = "libkate"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "0s3vr2nxfxlf1k75iqpp4l78yf4gil3f0v778kvlngbchvaq23n4"; }; - buildInputs = [ libogg libpng ]; + buildInputs = [ + libogg + libpng + ]; meta = with lib; { description = "Library for encoding and decoding Kate streams"; diff --git a/pkgs/by-name/li/libkcapi/package.nix b/pkgs/by-name/li/libkcapi/package.nix index 93405b1f9e3b0c..97009bbe40f9e8 100644 --- a/pkgs/by-name/li/libkcapi/package.nix +++ b/pkgs/by-name/li/libkcapi/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, buildPackages +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + buildPackages, # libkcapi offers multiple tools. They can be disabled for minimization. -, kcapi-test ? true -, kcapi-speed ? true -, kcapi-hasher ? true -, kcapi-rngapp ? true -, kcapi-encapp ? true -, kcapi-dgstapp ? true + kcapi-test ? true, + kcapi-speed ? true, + kcapi-hasher ? true, + kcapi-rngapp ? true, + kcapi-encapp ? true, + kcapi-dgstapp ? true, }: stdenv.mkDerivation rec { @@ -35,19 +36,24 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; configureFlags = - lib.optional kcapi-test "--enable-kcapi-test" ++ - lib.optional kcapi-speed "--enable-kcapi-speed" ++ - lib.optional kcapi-hasher "--enable-kcapi-hasher" ++ - lib.optional kcapi-rngapp "--enable-kcapi-rngapp" ++ - lib.optional kcapi-encapp "--enable-kcapi-encapp" ++ - lib.optional kcapi-dgstapp "--enable-kcapi-dgstapp" - ; + lib.optional kcapi-test "--enable-kcapi-test" + ++ lib.optional kcapi-speed "--enable-kcapi-speed" + ++ lib.optional kcapi-hasher "--enable-kcapi-hasher" + ++ lib.optional kcapi-rngapp "--enable-kcapi-rngapp" + ++ lib.optional kcapi-encapp "--enable-kcapi-encapp" + ++ lib.optional kcapi-dgstapp "--enable-kcapi-dgstapp"; meta = { homepage = "http://www.chronox.de/libkcapi.html"; description = "Linux Kernel Crypto API User Space Interface Library"; - license = with lib.licenses; [ bsd3 gpl2Only ]; + license = with lib.licenses; [ + bsd3 + gpl2Only + ]; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ orichter thillux ]; + maintainers = with lib.maintainers; [ + orichter + thillux + ]; }; } diff --git a/pkgs/by-name/li/libkeyfinder/package.nix b/pkgs/by-name/li/libkeyfinder/package.nix index d6f16f65df5d8d..350f44dea29021 100644 --- a/pkgs/by-name/li/libkeyfinder/package.nix +++ b/pkgs/by-name/li/libkeyfinder/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchpatch, fetchFromGitHub, cmake, fftw, catch2_3 }: +{ + lib, + stdenv, + fetchpatch, + fetchFromGitHub, + cmake, + fftw, + catch2_3, +}: stdenv.mkDerivation rec { pname = "libkeyfinder"; diff --git a/pkgs/by-name/li/libkkc-data/package.nix b/pkgs/by-name/li/libkkc-data/package.nix index 516dd61c60f36a..dfd6d86a28998b 100644 --- a/pkgs/by-name/li/libkkc-data/package.nix +++ b/pkgs/by-name/li/libkkc-data/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, fetchpatch, python3, libkkc }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + python3, + libkkc, +}: stdenv.mkDerivation rec { pname = "libkkc-data"; @@ -24,9 +31,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Language model data package for libkkc"; - homepage = "https://github.com/ueno/libkkc"; - license = licenses.gpl3Plus; + homepage = "https://github.com/ueno/libkkc"; + license = licenses.gpl3Plus; maintainers = with maintainers; [ vanzef ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/li/libkkc/package.nix b/pkgs/by-name/li/libkkc/package.nix index 06bc775689f2df..a329b39739de8b 100644 --- a/pkgs/by-name/li/libkkc/package.nix +++ b/pkgs/by-name/li/libkkc/package.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, fetchurl, fetchpatch -, vala, gobject-introspection, intltool, python3, glib -, pkg-config -, libgee, json-glib, marisa, libkkc-data +{ + lib, + stdenv, + fetchurl, + fetchpatch, + vala, + gobject-introspection, + intltool, + python3, + glib, + pkg-config, + libgee, + json-glib, + marisa, + libkkc-data, }: stdenv.mkDerivation rec { @@ -22,15 +33,25 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ - vala gobject-introspection - python3 python3.pkgs.marisa - intltool glib pkg-config + vala + gobject-introspection + python3 + python3.pkgs.marisa + intltool + glib + pkg-config ]; - buildInputs = [ marisa libkkc-data ]; + buildInputs = [ + marisa + libkkc-data + ]; enableParallelBuilding = true; - propagatedBuildInputs = [ libgee json-glib ]; + propagatedBuildInputs = [ + libgee + json-glib + ]; postInstall = '' ln -s ${libkkc-data}/lib/libkkc/models $out/share/libkkc/models @@ -38,9 +59,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Japanese Kana Kanji conversion input method library"; - homepage = "https://github.com/ueno/libkkc"; - license = licenses.gpl3Plus; + homepage = "https://github.com/ueno/libkkc"; + license = licenses.gpl3Plus; maintainers = with maintainers; [ vanzef ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/li/libkqueue/package.nix b/pkgs/by-name/li/libkqueue/package.nix index 54b6b2beecac80..cfb21e6906b704 100644 --- a/pkgs/by-name/li/libkqueue/package.nix +++ b/pkgs/by-name/li/libkqueue/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "libkqueue"; diff --git a/pkgs/by-name/li/libkrun/package.nix b/pkgs/by-name/li/libkrun/package.nix index 92a03018ca425f..dbe52975d7fa2a 100644 --- a/pkgs/by-name/li/libkrun/package.nix +++ b/pkgs/by-name/li/libkrun/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, cargo -, pkg-config -, glibc -, openssl -, libepoxy -, libdrm -, pipewire -, virglrenderer -, libkrunfw -, rustc -, withGpu ? false -, withSound ? false -, withNet ? false -, sevVariant ? false +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + cargo, + pkg-config, + glibc, + openssl, + libepoxy, + libdrm, + pipewire, + virglrenderer, + libkrunfw, + rustc, + withGpu ? false, + withSound ? false, + withNet ? false, + sevVariant ? false, }: stdenv.mkDerivation (finalAttrs: { @@ -29,7 +30,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-a5ot5ad8boANK3achn6PJ52k/xmxawbTM0/hEEC/fss="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; cargoDeps = rustPlatform.fetchCargoTarball { inherit (finalAttrs) src; @@ -43,17 +47,25 @@ stdenv.mkDerivation (finalAttrs: { rustc ] ++ lib.optional (sevVariant || withGpu) pkg-config; - buildInputs = [ - (libkrunfw.override { inherit sevVariant; }) - glibc - glibc.static - ] ++ lib.optionals withGpu [ libepoxy libdrm virglrenderer ] + buildInputs = + [ + (libkrunfw.override { inherit sevVariant; }) + glibc + glibc.static + ] + ++ lib.optionals withGpu [ + libepoxy + libdrm + virglrenderer + ] ++ lib.optional withSound pipewire ++ lib.optional sevVariant openssl; - makeFlags = [ - "PREFIX=${placeholder "out"}" - ] ++ lib.optional withGpu "GPU=1" + makeFlags = + [ + "PREFIX=${placeholder "out"}" + ] + ++ lib.optional withGpu "GPU=1" ++ lib.optional withSound "SND=1" ++ lib.optional withNet "NET=1" ++ lib.optional sevVariant "SEV=1"; @@ -68,7 +80,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Dynamic library providing Virtualization-based process isolation capabilities"; homepage = "https://github.com/containers/libkrun"; license = licenses.asl20; - maintainers = with maintainers; [ nickcao RossComputerGuy ]; + maintainers = with maintainers; [ + nickcao + RossComputerGuy + ]; platforms = libkrunfw.meta.platforms; }; }) diff --git a/pkgs/by-name/li/libkrunfw/package.nix b/pkgs/by-name/li/libkrunfw/package.nix index 10245ed920c5ff..82f84b0b7a7ddc 100644 --- a/pkgs/by-name/li/libkrunfw/package.nix +++ b/pkgs/by-name/li/libkrunfw/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchurl -, flex -, bison -, bc -, cpio -, perl -, elfutils -, python3 -, sevVariant ? false +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + flex, + bison, + bc, + cpio, + perl, + elfutils, + python3, + sevVariant ? false, }: stdenv.mkDerivation (finalAttrs: { @@ -47,11 +48,13 @@ stdenv.mkDerivation (finalAttrs: { elfutils ]; - makeFlags = [ - "PREFIX=${placeholder "out"}" - ] ++ lib.optionals sevVariant [ - "SEV=1" - ]; + makeFlags = + [ + "PREFIX=${placeholder "out"}" + ] + ++ lib.optionals sevVariant [ + "SEV=1" + ]; # Fixes https://github.com/containers/libkrunfw/issues/55 NIX_CFLAGS_COMPILE = lib.optionalString stdenv.targetPlatform.isAarch64 "-march=armv8-a+crypto"; @@ -61,8 +64,14 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Dynamic library bundling the guest payload consumed by libkrun"; homepage = "https://github.com/containers/libkrunfw"; - license = with licenses; [ lgpl2Only lgpl21Only ]; - maintainers = with maintainers; [ nickcao RossComputerGuy ]; + license = with licenses; [ + lgpl2Only + lgpl21Only + ]; + maintainers = with maintainers; [ + nickcao + RossComputerGuy + ]; platforms = [ "x86_64-linux" ] ++ lib.optionals (!sevVariant) [ "aarch64-linux" ]; }; }) diff --git a/pkgs/by-name/li/libks/package.nix b/pkgs/by-name/li/libks/package.nix index cc6311f024ace4..80d0ce24474a8e 100644 --- a/pkgs/by-name/li/libks/package.nix +++ b/pkgs/by-name/li/libks/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, libuuid -, openssl -, libossp_uuid -, freeswitch -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + libuuid, + openssl, + libossp_uuid, + freeswitch, + nix-update-script, }: stdenv.mkDerivation rec { @@ -36,7 +37,8 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ openssl ] + buildInputs = + [ openssl ] ++ lib.optional stdenv.hostPlatform.isLinux libuuid ++ lib.optional stdenv.hostPlatform.isDarwin libossp_uuid; diff --git a/pkgs/by-name/li/libksba/package.nix b/pkgs/by-name/li/libksba/package.nix index 5eb07184c651f6..e45be78cae0a4f 100644 --- a/pkgs/by-name/li/libksba/package.nix +++ b/pkgs/by-name/li/libksba/package.nix @@ -1,4 +1,11 @@ -{ buildPackages, lib, stdenv, fetchurl, gettext, libgpg-error }: +{ + buildPackages, + lib, + stdenv, + fetchurl, + gettext, + libgpg-error, +}: stdenv.mkDerivation rec { pname = "libksba"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { hash = "sha256-z3JRC467TrZpPu92V0nYNnegPHkpGjEQQKW/15uqt2M="; }; - outputs = [ "out" "dev" "info" ]; + outputs = [ + "out" + "dev" + "info" + ]; buildInputs = [ gettext ]; propagatedBuildInputs = [ libgpg-error ]; diff --git a/pkgs/by-name/li/libksi/package.nix b/pkgs/by-name/li/libksi/package.nix index 3698be42d5f625..162167e820f73f 100644 --- a/pkgs/by-name/li/libksi/package.nix +++ b/pkgs/by-name/li/libksi/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, openssl, curl }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + openssl, + curl, +}: stdenv.mkDerivation rec { pname = "libksi"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ openssl curl ]; + buildInputs = [ + openssl + curl + ]; configureFlags = [ "--with-openssl=${openssl.dev}" diff --git a/pkgs/by-name/li/liblangtag/package.nix b/pkgs/by-name/li/liblangtag/package.nix index 38f1cc03cac482..cebc9e20f52181 100644 --- a/pkgs/by-name/li/liblangtag/package.nix +++ b/pkgs/by-name/li/liblangtag/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchurl, fetchpatch, autoreconfHook, gtk-doc, gettext -, pkg-config, glib, libxml2, gobject-introspection, gnome-common, unzip +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + gtk-doc, + gettext, + pkg-config, + glib, + libxml2, + gobject-introspection, + gnome-common, + unzip, }: stdenv.mkDerivation rec { @@ -44,13 +56,24 @@ stdenv.mkDerivation rec { cp "${language_subtag_registry}" data/language-subtag-registry ''; - configureFlags = - lib.optional - (stdenv.hostPlatform.libc == "glibc") - "--with-locale-alias=${stdenv.cc.libc}/share/locale/locale.alias"; + configureFlags = lib.optional ( + stdenv.hostPlatform.libc == "glibc" + ) "--with-locale-alias=${stdenv.cc.libc}/share/locale/locale.alias"; - buildInputs = [ gettext glib libxml2 gnome-common ]; - nativeBuildInputs = [ autoreconfHook gtk-doc gettext pkg-config unzip gobject-introspection ]; + buildInputs = [ + gettext + glib + libxml2 + gnome-common + ]; + nativeBuildInputs = [ + autoreconfHook + gtk-doc + gettext + pkg-config + unzip + gobject-introspection + ]; meta = with lib; { description = "Interface library to access tags for identifying languages"; diff --git a/pkgs/by-name/li/liblapin/package.nix b/pkgs/by-name/li/liblapin/package.nix index f736bb2d426873..5f232058a04929 100644 --- a/pkgs/by-name/li/liblapin/package.nix +++ b/pkgs/by-name/li/liblapin/package.nix @@ -47,7 +47,10 @@ stdenv.mkDerivation { libudev-zero ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = { description = "Multimedia library for rookies and prototyping"; diff --git a/pkgs/by-name/li/liblastfmSF/package.nix b/pkgs/by-name/li/liblastfmSF/package.nix index f25ee3afae4a46..8c7af49f4be051 100644 --- a/pkgs/by-name/li/liblastfmSF/package.nix +++ b/pkgs/by-name/li/liblastfmSF/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, curl, openssl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + curl, + openssl, +}: stdenv.mkDerivation rec { pname = "liblastfm-SF"; @@ -6,7 +13,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ curl openssl ]; + propagatedBuildInputs = [ + curl + openssl + ]; src = fetchurl { url = "mirror://sourceforge/liblastfm/libclastfm-${version}.tar.gz"; diff --git a/pkgs/by-name/li/liblaxjson/package.nix b/pkgs/by-name/li/liblaxjson/package.nix index 9464714d5cc906..905cc1cb9a165b 100644 --- a/pkgs/by-name/li/liblaxjson/package.nix +++ b/pkgs/by-name/li/liblaxjson/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { version = "1.0.5"; diff --git a/pkgs/by-name/li/liblbfgs/package.nix b/pkgs/by-name/li/liblbfgs/package.nix index d429c4c1f703c1..2b85c561f88a62 100644 --- a/pkgs/by-name/li/liblbfgs/package.nix +++ b/pkgs/by-name/li/liblbfgs/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "liblbfgs"; version = "1.10"; diff --git a/pkgs/by-name/li/liblc3/package.nix b/pkgs/by-name/li/liblc3/package.nix index ff04d23cb0c635..0da8995a793ff4 100644 --- a/pkgs/by-name/li/liblc3/package.nix +++ b/pkgs/by-name/li/liblc3/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, }: let @@ -20,7 +21,10 @@ stdenv.mkDerivation { sha256 = "sha256-h9qy04FqlHXp0bOUoP4+WqI0yrM78e56S+DEn3HztYo="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ meson @@ -35,4 +39,3 @@ stdenv.mkDerivation { maintainers = with maintainers; [ jansol ]; }; } - diff --git a/pkgs/by-name/li/liblcf/package.nix b/pkgs/by-name/li/liblcf/package.nix index 07f24f4d5a06aa..4721bd659ce577 100644 --- a/pkgs/by-name/li/liblcf/package.nix +++ b/pkgs/by-name/li/liblcf/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, expat -, icu +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + expat, + icu, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libleidenalg/package.nix b/pkgs/by-name/li/libleidenalg/package.nix index 75cdd34efa0f6f..13dac32268ed86 100644 --- a/pkgs/by-name/li/libleidenalg/package.nix +++ b/pkgs/by-name/li/libleidenalg/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, igraph +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + igraph, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/liblinear/package.nix b/pkgs/by-name/li/liblinear/package.nix index 31da8305be7ae4..75ff37996e75ea 100644 --- a/pkgs/by-name/li/liblinear/package.nix +++ b/pkgs/by-name/li/liblinear/package.nix @@ -1,32 +1,53 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: let soVersion = "5"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "liblinear"; version = "2.47"; src = fetchFromGitHub { owner = "cjlin1"; repo = "liblinear"; - rev = "v${builtins.replaceStrings ["."] [""] version}"; + rev = "v${builtins.replaceStrings [ "." ] [ "" ] version}"; sha256 = "sha256-so7uCc/52NdN0V2Ska8EUdw/wSegaudX5AF+c0xe5jk="; }; - makeFlags = [ "AR=${stdenv.cc.targetPrefix}ar" "RANLIB=${stdenv.cc.targetPrefix}ranlib" ]; + makeFlags = [ + "AR=${stdenv.cc.targetPrefix}ar" + "RANLIB=${stdenv.cc.targetPrefix}ranlib" + ]; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; - buildFlags = [ "lib" "predict" "train" ]; + buildFlags = [ + "lib" + "predict" + "train" + ]; installPhase = '' - ${if stdenv.hostPlatform.isDarwin then '' - install -D liblinear.so.${soVersion} $out/lib/liblinear.${soVersion}.dylib - ln -s $out/lib/liblinear.${soVersion}.dylib $out/lib/liblinear.dylib - '' else '' - install -Dt $out/lib liblinear.so.${soVersion} - ln -s $out/lib/liblinear.so.${soVersion} $out/lib/liblinear.so - ''} + ${ + if stdenv.hostPlatform.isDarwin then + '' + install -D liblinear.so.${soVersion} $out/lib/liblinear.${soVersion}.dylib + ln -s $out/lib/liblinear.${soVersion}.dylib $out/lib/liblinear.dylib + '' + else + '' + install -Dt $out/lib liblinear.so.${soVersion} + ln -s $out/lib/liblinear.so.${soVersion} $out/lib/liblinear.so + '' + } install -D train $bin/bin/liblinear-train install -D predict $bin/bin/liblinear-predict install -Dm444 -t $dev/include linear.h diff --git a/pkgs/by-name/li/liblinphone/package.nix b/pkgs/by-name/li/liblinphone/package.nix index a4a1e03e93ef01..f22403a79cb35f 100644 --- a/pkgs/by-name/li/liblinphone/package.nix +++ b/pkgs/by-name/li/liblinphone/package.nix @@ -1,19 +1,20 @@ -{ lib -, bc-soci -, belcard -, belle-sip -, cmake -, doxygen -, fetchFromGitLab -, jsoncpp -, libxml2 -, lime -, mediastreamer -, python3 -, sqlite -, stdenv -, xercesc -, zxing-cpp +{ + lib, + bc-soci, + belcard, + belle-sip, + cmake, + doxygen, + fetchFromGitLab, + jsoncpp, + libxml2, + lime, + mediastreamer, + python3, + sqlite, + stdenv, + xercesc, + zxing-cpp, }: stdenv.mkDerivation rec { @@ -67,7 +68,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake doxygen - (python3.withPackages (ps: [ ps.pystache ps.six ])) + (python3.withPackages (ps: [ + ps.pystache + ps.six + ])) ]; strictDeps = true; diff --git a/pkgs/by-name/li/liblo/package.nix b/pkgs/by-name/li/liblo/package.nix index 1a9ce7c331a034..71483dc24d42ca 100644 --- a/pkgs/by-name/li/liblo/package.nix +++ b/pkgs/by-name/li/liblo/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "liblo"; @@ -15,7 +19,7 @@ stdenv.mkDerivation rec { description = "Lightweight library to handle the sending and receiving of messages according to the Open Sound Control (OSC) protocol"; homepage = "https://sourceforge.net/projects/liblo"; license = lib.licenses.gpl2; - maintainers = [lib.maintainers.marcweber]; + maintainers = [ lib.maintainers.marcweber ]; platforms = with lib.platforms; linux ++ darwin; }; } diff --git a/pkgs/by-name/li/liblockfile/package.nix b/pkgs/by-name/li/liblockfile/package.nix index 17fc086704ec1d..7d1d1b5769334e 100644 --- a/pkgs/by-name/li/liblockfile/package.nix +++ b/pkgs/by-name/li/liblockfile/package.nix @@ -1,9 +1,13 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { - _name = "liblockfile"; + _name = "liblockfile"; version = "1.17"; - name = "${_name}-${version}"; + name = "${_name}-${version}"; src = fetchurl { url = "mirror://debian/pool/main/libl/${_name}/${_name}_${version}.orig.tar.gz"; diff --git a/pkgs/by-name/li/liblogging/package.nix b/pkgs/by-name/li/liblogging/package.nix index 50b850b886a5e5..40f9d0a76d7fef 100644 --- a/pkgs/by-name/li/liblogging/package.nix +++ b/pkgs/by-name/li/liblogging/package.nix @@ -1,6 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, systemd +{ + lib, + stdenv, + fetchurl, + pkg-config, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/liblognorm/package.nix b/pkgs/by-name/li/liblognorm/package.nix index 184d9932eb281f..68c757de75e8f4 100644 --- a/pkgs/by-name/li/liblognorm/package.nix +++ b/pkgs/by-name/li/liblognorm/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, libestr, json_c, pcre, fastJson }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libestr, + json_c, + pcre, + fastJson, +}: stdenv.mkDerivation rec { pname = "liblognorm"; @@ -10,7 +19,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libestr json_c pcre fastJson ]; + buildInputs = [ + libestr + json_c + pcre + fastJson + ]; configureFlags = [ "--enable-regexp" ]; diff --git a/pkgs/by-name/li/libltc/package.nix b/pkgs/by-name/li/libltc/package.nix index a290b9bce9e05f..9c07075526a88b 100644 --- a/pkgs/by-name/li/libltc/package.nix +++ b/pkgs/by-name/li/libltc/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libltc"; diff --git a/pkgs/by-name/li/libmad/package.nix b/pkgs/by-name/li/libmad/package.nix index a8c212ea846399..f6772748edb726 100644 --- a/pkgs/by-name/li/libmad/package.nix +++ b/pkgs/by-name/li/libmad/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, autoconf +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoconf, -# for passthru.tests -, audacity -, mpd -, normalize -, ocamlPackages -, streamripper -, vlc + # for passthru.tests + audacity, + mpd, + normalize, + ocamlPackages, + streamripper, + vlc, }: stdenv.mkDerivation rec { @@ -22,42 +23,46 @@ stdenv.mkDerivation rec { sha256 = "14460zhacxhswnzb36qfpd1f2wbk10qvksvm6wyq5hpvdgnw7ymv"; }; - outputs = [ "out" "dev" ]; - - patches = [ - (fetchpatch { - url = "https://github.com/openwrt/packages/raw/openwrt-19.07/libs/libmad/patches/001-mips_removal_h_constraint.patch"; - sha256 = "0layswr6qg6axf4vyz6xrv73jwga34mkma3ifk9w9vrk41454hr5"; - }) - (fetchpatch { - url = "https://github.com/KaOSx/main/raw/1270b8080f37fb6cca562829a521991800b0a497/libmad/libmad.patch"; - sha256 = "0rysq0sn3dfdz6pa6bfqkmk4ymc4rzk5ym7p16dyk37sldg1pbzs"; - }) - (fetchpatch { - url = "https://github.com/KaOSx/main/raw/1270b8080f37fb6cca562829a521991800b0a497/libmad/amd64-64bit.diff"; - sha256 = "0mx56dmkbvw3zxnqd2hjng48q0d7q7473pns4n0ksdam29b0c5ar"; - }) - (fetchpatch { - name = "CVE-2017-8372-CVE-2017-8373.patch"; - url = "https://github.com/openwrt/packages/raw/openwrt-19.07/libs/libmad/patches/102-CVE-2017-8373-CVE-2017-8372-md-size.patch"; - sha256 = "0p6mkpn66h1ds8jvww28q4vlr58jwm58m9vb7pkvvyvy764agqnk"; - }) - (fetchpatch { - name = "CVE-2017-8374.patch"; - url = "https://github.com/openwrt/packages/raw/openwrt-19.07/libs/libmad/patches/101-CVE-2017-8374-length-check.patch"; - sha256 = "1j1ssxwmx9nfahzl62frbzck93xrjc2v3w30c12vmk29iflf1890"; - }) - ] - # optimize.diff is taken from https://projects.archlinux.org/svntogit/packages.git/tree/trunk/optimize.diff?h=packages/libmad - # It is included here in order to fix a build failure in Clang - # But it may be useful to fix other, currently unknown problems as well - ++ lib.optionals stdenv.cc.isClang [ - (fetchpatch { - url = "https://github.com/KaOSx/main/raw/1270b8080f37fb6cca562829a521991800b0a497/libmad/optimize.diff"; - sha256 = "0hcxzz9ql1fizyqbsgdchdwi7bvchfr72172j43hpyj53p0yabc6"; - }) + outputs = [ + "out" + "dev" ]; + patches = + [ + (fetchpatch { + url = "https://github.com/openwrt/packages/raw/openwrt-19.07/libs/libmad/patches/001-mips_removal_h_constraint.patch"; + sha256 = "0layswr6qg6axf4vyz6xrv73jwga34mkma3ifk9w9vrk41454hr5"; + }) + (fetchpatch { + url = "https://github.com/KaOSx/main/raw/1270b8080f37fb6cca562829a521991800b0a497/libmad/libmad.patch"; + sha256 = "0rysq0sn3dfdz6pa6bfqkmk4ymc4rzk5ym7p16dyk37sldg1pbzs"; + }) + (fetchpatch { + url = "https://github.com/KaOSx/main/raw/1270b8080f37fb6cca562829a521991800b0a497/libmad/amd64-64bit.diff"; + sha256 = "0mx56dmkbvw3zxnqd2hjng48q0d7q7473pns4n0ksdam29b0c5ar"; + }) + (fetchpatch { + name = "CVE-2017-8372-CVE-2017-8373.patch"; + url = "https://github.com/openwrt/packages/raw/openwrt-19.07/libs/libmad/patches/102-CVE-2017-8373-CVE-2017-8372-md-size.patch"; + sha256 = "0p6mkpn66h1ds8jvww28q4vlr58jwm58m9vb7pkvvyvy764agqnk"; + }) + (fetchpatch { + name = "CVE-2017-8374.patch"; + url = "https://github.com/openwrt/packages/raw/openwrt-19.07/libs/libmad/patches/101-CVE-2017-8374-length-check.patch"; + sha256 = "1j1ssxwmx9nfahzl62frbzck93xrjc2v3w30c12vmk29iflf1890"; + }) + ] + # optimize.diff is taken from https://projects.archlinux.org/svntogit/packages.git/tree/trunk/optimize.diff?h=packages/libmad + # It is included here in order to fix a build failure in Clang + # But it may be useful to fix other, currently unknown problems as well + ++ lib.optionals stdenv.cc.isClang [ + (fetchpatch { + url = "https://github.com/KaOSx/main/raw/1270b8080f37fb6cca562829a521991800b0a497/libmad/optimize.diff"; + sha256 = "0hcxzz9ql1fizyqbsgdchdwi7bvchfr72172j43hpyj53p0yabc6"; + }) + ]; + # The -fforce-mem flag has been removed in GCC 4.3. postPatch = '' substituteInPlace configure.ac --replace "-fforce-mem" "" @@ -69,15 +74,21 @@ stdenv.mkDerivation rec { preConfigure = "autoconf"; passthru.tests = { - inherit audacity mpd normalize streamripper vlc; + inherit + audacity + mpd + normalize + streamripper + vlc + ; ocaml-mad = ocamlPackages.mad; }; meta = with lib; { - homepage = "https://sourceforge.net/projects/mad/"; + homepage = "https://sourceforge.net/projects/mad/"; description = "High-quality, fixed-point MPEG audio decoder supporting MPEG-1 and MPEG-2"; - license = licenses.gpl2; + license = licenses.gpl2; maintainers = with maintainers; [ lovek323 ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/li/libmanette/package.nix b/pkgs/by-name/li/libmanette/package.nix index 594ba202a6e1cc..4a0bb9f0a97dfe 100644 --- a/pkgs/by-name/li/libmanette/package.nix +++ b/pkgs/by-name/li/libmanette/package.nix @@ -1,54 +1,66 @@ -{ lib, stdenv -, fetchurl -, ninja -, meson -, mesonEmulatorHook -, pkg-config -, vala -, gobject-introspection -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_43 -, glib -, libgudev -, libevdev -, gnome +{ + lib, + stdenv, + fetchurl, + ninja, + meson, + mesonEmulatorHook, + pkg-config, + vala, + gobject-introspection, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_43, + glib, + libgudev, + libevdev, + gnome, }: stdenv.mkDerivation rec { pname = "libmanette"; version = "0.2.9"; - outputs = [ "out" "dev" ] ++ lib.optional withIntrospection "devdoc"; + outputs = [ + "out" + "dev" + ] ++ lib.optional withIntrospection "devdoc"; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; hash = "sha256-KTZr5UUvYKdMZfxk/+LXTt3U5uaCTCzvpWekO9kraI8="; }; - nativeBuildInputs = [ - meson - ninja - pkg-config - glib - ] ++ lib.optionals withIntrospection [ - vala - gobject-introspection - gtk-doc - docbook-xsl-nons - docbook_xml_dtd_43 - ] ++ lib.optionals (withIntrospection && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + glib + ] + ++ lib.optionals withIntrospection [ + vala + gobject-introspection + gtk-doc + docbook-xsl-nons + docbook_xml_dtd_43 + ] + ++ lib.optionals (withIntrospection && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; - buildInputs = [ - glib - libevdev - ] ++ lib.optionals withIntrospection [ - libgudev - ]; + buildInputs = + [ + glib + libevdev + ] + ++ lib.optionals withIntrospection [ + libgudev + ]; mesonFlags = [ (lib.mesonBool "doc" withIntrospection) diff --git a/pkgs/by-name/li/libmatchbox/package.nix b/pkgs/by-name/li/libmatchbox/package.nix index 50b66eccfb3d62..c8f757899b314b 100644 --- a/pkgs/by-name/li/libmatchbox/package.nix +++ b/pkgs/by-name/li/libmatchbox/package.nix @@ -1,11 +1,31 @@ -{ lib, stdenv, fetchurl, libX11, libXext, libpng, libXft, libICE, pango, libjpeg}: +{ + lib, + stdenv, + fetchurl, + libX11, + libXext, + libpng, + libXft, + libICE, + pango, + libjpeg, +}: stdenv.mkDerivation rec { pname = "libmatchbox"; version = "1.11"; - buildInputs = [ libXft libICE pango libjpeg ]; - propagatedBuildInputs = [ libX11 libXext libpng ]; + buildInputs = [ + libXft + libICE + pango + libjpeg + ]; + propagatedBuildInputs = [ + libX11 + libXext + libpng + ]; NIX_LDFLAGS = "-lX11"; src = fetchurl { diff --git a/pkgs/by-name/li/libmatheval/package.nix b/pkgs/by-name/li/libmatheval/package.nix index 7ee8b865664728..41f55701d1ffa3 100644 --- a/pkgs/by-name/li/libmatheval/package.nix +++ b/pkgs/by-name/li/libmatheval/package.nix @@ -1,10 +1,21 @@ -{ lib, stdenv, fetchurl, pkg-config, guile, flex, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + guile, + flex, + fetchpatch, +}: stdenv.mkDerivation rec { version = "1.1.11"; pname = "libmatheval"; - nativeBuildInputs = [ pkg-config flex ]; + nativeBuildInputs = [ + pkg-config + flex + ]; buildInputs = [ guile ]; src = fetchurl { @@ -47,4 +58,3 @@ stdenv.mkDerivation rec { platforms = lib.platforms.unix; }; } - diff --git a/pkgs/by-name/li/libmaxminddb/package.nix b/pkgs/by-name/li/libmaxminddb/package.nix index f86e7d256040f4..539fa33d2c5459 100644 --- a/pkgs/by-name/li/libmaxminddb/package.nix +++ b/pkgs/by-name/li/libmaxminddb/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libmaxminddb"; diff --git a/pkgs/by-name/li/libmbd/package.nix b/pkgs/by-name/li/libmbd/package.nix index 5322bdfa942e14..a4b9b92e98ccf3 100644 --- a/pkgs/by-name/li/libmbd/package.nix +++ b/pkgs/by-name/li/libmbd/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, fetchFromGitHub -, lib -, cmake -, mpi -, blas -, lapack -, scalapack -, gfortran -} : +{ + stdenv, + fetchFromGitHub, + lib, + cmake, + mpi, + blas, + lapack, + scalapack, + gfortran, +}: assert !blas.isILP64; assert !lapack.isILP64; @@ -29,9 +30,16 @@ stdenv.mkDerivation rec { EOF ''; - nativeBuildInputs = [ cmake gfortran ]; + nativeBuildInputs = [ + cmake + gfortran + ]; - buildInputs = [ blas lapack scalapack ]; + buildInputs = [ + blas + lapack + scalapack + ]; propagatedBuildInputs = [ mpi ]; diff --git a/pkgs/by-name/li/libmbim/package.nix b/pkgs/by-name/li/libmbim/package.nix index ee4acc094e668c..0171aea5490efb 100644 --- a/pkgs/by-name/li/libmbim/package.nix +++ b/pkgs/by-name/li/libmbim/package.nix @@ -1,26 +1,31 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, glib -, python3 -, help2man -, bash-completion -, bash -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, withDocs ? stdenv.hostPlatform == stdenv.buildPlatform -, gobject-introspection +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + glib, + python3, + help2man, + bash-completion, + bash, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + withDocs ? stdenv.hostPlatform == stdenv.buildPlatform, + gobject-introspection, }: stdenv.mkDerivation rec { pname = "libmbim"; version = "1.30.0"; - outputs = [ "out" "dev" ] - ++ lib.optionals withDocs [ "man" ]; + outputs = [ + "out" + "dev" + ] ++ lib.optionals withDocs [ "man" ]; src = fetchFromGitLab { domain = "gitlab.freedesktop.org"; @@ -38,16 +43,19 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ - meson - ninja - pkg-config - python3 - ] ++ lib.optionals withDocs [ - help2man - ] ++ lib.optionals withIntrospection [ - gobject-introspection - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + python3 + ] + ++ lib.optionals withDocs [ + help2man + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + ]; buildInputs = [ glib diff --git a/pkgs/by-name/li/libmcfp/package.nix b/pkgs/by-name/li/libmcfp/package.nix index 37d667ffee9a4b..1c993782800950 100644 --- a/pkgs/by-name/li/libmcfp/package.nix +++ b/pkgs/by-name/li/libmcfp/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub +{ + lib, + stdenv, + cmake, + fetchFromGitHub, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/libmcrypt/package.nix b/pkgs/by-name/li/libmcrypt/package.nix index 3ed85fad550d81..372c1cc87d38af 100644 --- a/pkgs/by-name/li/libmcrypt/package.nix +++ b/pkgs/by-name/li/libmcrypt/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, cctools, disablePosixThreads ? false }: +{ + lib, + stdenv, + fetchurl, + cctools, + disablePosixThreads ? false, +}: stdenv.mkDerivation rec { pname = "libmcrypt"; @@ -11,7 +17,8 @@ stdenv.mkDerivation rec { buildInputs = lib.optional stdenv.hostPlatform.isDarwin cctools; - configureFlags = lib.optionals disablePosixThreads [ "--disable-posix-threads" ] + configureFlags = + lib.optionals disablePosixThreads [ "--disable-posix-threads" ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ # AC_FUNC_MALLOC is broken on cross builds. "ac_cv_func_malloc_0_nonnull=yes" diff --git a/pkgs/by-name/li/libmd/package.nix b/pkgs/by-name/li/libmd/package.nix index 867bd5dc9ba3e0..72c8ffda720baf 100644 --- a/pkgs/by-name/li/libmd/package.nix +++ b/pkgs/by-name/li/libmd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation (finalAttrs: { pname = "libmd"; @@ -23,7 +28,13 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://archive.hadrons.org/software/libmd/libmd-${finalAttrs.version}.announce"; # Git: https://git.hadrons.org/cgit/libmd.git description = "Message Digest functions from BSD systems"; - license = with licenses; [ bsd3 bsd2 isc beerware publicDomain ]; + license = with licenses; [ + bsd3 + bsd2 + isc + beerware + publicDomain + ]; maintainers = with maintainers; [ primeos ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/li/libmediaart/package.nix b/pkgs/by-name/li/libmediaart/package.nix index a68db1389ab5fa..1e84e68401f7ae 100644 --- a/pkgs/by-name/li/libmediaart/package.nix +++ b/pkgs/by-name/li/libmediaart/package.nix @@ -1,22 +1,55 @@ -{ lib, stdenv, fetchurl, meson, mesonEmulatorHook, ninja, pkg-config, vala, gtk-doc, docbook_xsl, docbook_xml_dtd_412, glib, gdk-pixbuf, gobject-introspection, gnome }: +{ + lib, + stdenv, + fetchurl, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + vala, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_412, + glib, + gdk-pixbuf, + gobject-introspection, + gnome, +}: stdenv.mkDerivation rec { pname = "libmediaart"; version = "1.9.6"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; sha256 = "w7xQJdfbOAWH+cjrgAxhH2taFta0t4/P+T9ih2pnfxc="; }; - nativeBuildInputs = [ meson ninja pkg-config vala gtk-doc docbook_xsl docbook_xml_dtd_412 gobject-introspection ] + nativeBuildInputs = + [ + meson + ninja + pkg-config + vala + gtk-doc + docbook_xsl + docbook_xml_dtd_412 + gobject-introspection + ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + mesonEmulatorHook + ]; - buildInputs = [ glib gdk-pixbuf ]; + buildInputs = [ + glib + gdk-pixbuf + ]; mesonFlags = [ "-Dgtk_doc=true" diff --git a/pkgs/by-name/li/libmemcached/package.nix b/pkgs/by-name/li/libmemcached/package.nix index 053cd91be2d989..43f0e9880eb98d 100644 --- a/pkgs/by-name/li/libmemcached/package.nix +++ b/pkgs/by-name/li/libmemcached/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, fetchpatch, cyrus_sasl, libevent }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + cyrus_sasl, + libevent, +}: stdenv.mkDerivation rec { pname = "libmemcached"; @@ -14,7 +21,8 @@ stdenv.mkDerivation rec { # https://bugs.launchpad.net/libmemcached/+bug/1281907 # Fix building on macOS (patch from Homebrew) # https://bugs.launchpad.net/libmemcached/+bug/1245562 - patches = lib.optional stdenv.hostPlatform.isLinux ./libmemcached-fix-linking-with-libpthread.patch + patches = + lib.optional stdenv.hostPlatform.isLinux ./libmemcached-fix-linking-with-libpthread.patch ++ lib.optional stdenv.hostPlatform.isDarwin (fetchpatch { url = "https://raw.githubusercontent.com/Homebrew/homebrew/bfd4a0a4626b61c2511fdf573bcbbc6bbe86340e/Library/Formula/libmemcached.rb"; sha256 = "1gjf3vd7hiyzxjvlg2zfc3y2j0lyr6nhbws4xb5dmin3csyp8qb8"; diff --git a/pkgs/by-name/li/libmesode/package.nix b/pkgs/by-name/li/libmesode/package.nix index 6ac53d3d5d3d6f..3633b47d15932f 100644 --- a/pkgs/by-name/li/libmesode/package.nix +++ b/pkgs/by-name/li/libmesode/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, libtool -, openssl -, expat -, pkg-config -, check +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libtool, + openssl, + expat, + pkg-config, + check, }: stdenv.mkDerivation rec { @@ -19,8 +21,16 @@ stdenv.mkDerivation rec { sha256 = "1bxnkhrypgv41qyy1n545kcggmlw1hvxnhwihijhhcf2pxd2s654"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ openssl expat libtool check ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + openssl + expat + libtool + check + ]; dontDisableStatic = true; @@ -40,7 +50,10 @@ stdenv.mkDerivation rec { TLS functionality such as manual SSL certificate verification. ''; homepage = "https://github.com/profanity-im/libmesode/"; - license = with licenses; [ gpl3Only mit]; + license = with licenses; [ + gpl3Only + mit + ]; platforms = platforms.unix; broken = stdenv.hostPlatform.isDarwin; maintainers = with maintainers; [ devhell ]; diff --git a/pkgs/by-name/li/libmhash/package.nix b/pkgs/by-name/li/libmhash/package.nix index 0cccefb9998037..c13761b2c69c5e 100644 --- a/pkgs/by-name/li/libmhash/package.nix +++ b/pkgs/by-name/li/libmhash/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mhash"; diff --git a/pkgs/by-name/li/libmicrodns/package.nix b/pkgs/by-name/li/libmicrodns/package.nix index c9dd899a2b00c8..fbf36f3b181caf 100644 --- a/pkgs/by-name/li/libmicrodns/package.nix +++ b/pkgs/by-name/li/libmicrodns/package.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libmilter/package.nix b/pkgs/by-name/li/libmilter/package.nix index 10a0986936797d..c8fe5eed036230 100644 --- a/pkgs/by-name/li/libmilter/package.nix +++ b/pkgs/by-name/li/libmilter/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, m4, fixDarwinDylibNames }: +{ + lib, + stdenv, + fetchurl, + m4, + fixDarwinDylibNames, +}: stdenv.mkDerivation rec { pname = "libmilter"; @@ -32,7 +38,11 @@ stdenv.mkDerivation rec { sh Build -f ./a.m4 ''; - patches = [ ./install.patch ./sharedlib.patch ./darwin.patch ]; + patches = [ + ./install.patch + ./sharedlib.patch + ./darwin.patch + ]; nativeBuildInputs = [ m4 ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; diff --git a/pkgs/by-name/li/libminc/package.nix b/pkgs/by-name/li/libminc/package.nix index b270b8eb56689b..b747fea45483d5 100644 --- a/pkgs/by-name/li/libminc/package.nix +++ b/pkgs/by-name/li/libminc/package.nix @@ -1,7 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, cmake, zlib, netcdf, nifticlib, hdf5 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, + netcdf, + nifticlib, + hdf5, +}: stdenv.mkDerivation (finalAttrs: { - pname = "libminc"; + pname = "libminc"; version = "2.4.06"; src = fetchFromGitHub { @@ -33,7 +42,7 @@ stdenv.mkDerivation (finalAttrs: { ]; doCheck = !stdenv.hostPlatform.isDarwin; - # -j1: see https://github.com/BIC-MNI/libminc/issues/110 + # -j1: see https://github.com/BIC-MNI/libminc/issues/110 checkPhase = '' ctest -j1 --output-on-failure ''; diff --git a/pkgs/by-name/li/libmkv/package.nix b/pkgs/by-name/li/libmkv/package.nix index 584d76e1cf2b30..31c17b884ccb25 100644 --- a/pkgs/by-name/li/libmkv/package.nix +++ b/pkgs/by-name/li/libmkv/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, libtool, autoconf, automake }: +{ + lib, + stdenv, + fetchFromGitHub, + libtool, + autoconf, + automake, +}: stdenv.mkDerivation rec { pname = "libmkv"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "0pr9q7yprndl8d15ir7i7cznvmf1yqpvnsyivv763n6wryssq6dl"; }; - nativeBuildInputs = [ libtool autoconf automake ]; + nativeBuildInputs = [ + libtool + autoconf + automake + ]; preConfigure = "sh bootstrap.sh"; diff --git a/pkgs/by-name/li/libmms/package.nix b/pkgs/by-name/li/libmms/package.nix index 0d099e77b6e3c7..2d4630e698235c 100644 --- a/pkgs/by-name/li/libmms/package.nix +++ b/pkgs/by-name/li/libmms/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, glib, pkg-config }: +{ + lib, + stdenv, + fetchurl, + glib, + pkg-config, +}: stdenv.mkDerivation rec { pname = "libmms"; diff --git a/pkgs/by-name/li/libmng/package.nix b/pkgs/by-name/li/libmng/package.nix index 19896b13998d34..da928a584ce676 100644 --- a/pkgs/by-name/li/libmng/package.nix +++ b/pkgs/by-name/li/libmng/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, zlib, libpng, libjpeg, lcms2 }: +{ + lib, + stdenv, + fetchurl, + zlib, + libpng, + libjpeg, + lcms2, +}: stdenv.mkDerivation rec { pname = "libmng"; @@ -9,10 +17,19 @@ stdenv.mkDerivation rec { sha256 = "1lvxnpds0vcf0lil6ia2036ghqlbl740c4d2sz0q5g6l93fjyija"; }; - outputs = [ "out" "dev" "devdoc" ]; - outputMan= "devdoc"; + outputs = [ + "out" + "dev" + "devdoc" + ]; + outputMan = "devdoc"; - propagatedBuildInputs = [ zlib libpng libjpeg lcms2 ]; + propagatedBuildInputs = [ + zlib + libpng + libjpeg + lcms2 + ]; meta = with lib; { description = "Reference library for reading, displaying, writing and examining Multiple-Image Network Graphics"; diff --git a/pkgs/by-name/li/libmnl/package.nix b/pkgs/by-name/li/libmnl/package.nix index 9a6f6a1d14dc92..4c6502e617c0e7 100644 --- a/pkgs/by-name/li/libmnl/package.nix +++ b/pkgs/by-name/li/libmnl/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libmnl"; diff --git a/pkgs/by-name/li/libmodbus/package.nix b/pkgs/by-name/li/libmodbus/package.nix index e27e8e1c387cf3..96e7b0d2b46b55 100644 --- a/pkgs/by-name/li/libmodbus/package.nix +++ b/pkgs/by-name/li/libmodbus/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libmodbus"; diff --git a/pkgs/by-name/li/libmodplug/package.nix b/pkgs/by-name/li/libmodplug/package.nix index 334dfa9d80151e..dd5ee10ca5b30f 100644 --- a/pkgs/by-name/li/libmodplug/package.nix +++ b/pkgs/by-name/li/libmodplug/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, file }: +{ + lib, + stdenv, + fetchurl, + file, +}: stdenv.mkDerivation rec { pname = "libmodplug"; @@ -14,19 +19,22 @@ stdenv.mkDerivation rec { # not allowed in C++17 and is an error in clang 16. prePatch = "substituteInPlace src/fastmix.cpp --replace 'register ' ''"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; preConfigure = '' - substituteInPlace configure \ - --replace ' -mmacosx-version-min=10.5' "" \ - --replace /usr/bin/file ${file}/bin/file + substituteInPlace configure \ + --replace ' -mmacosx-version-min=10.5' "" \ + --replace /usr/bin/file ${file}/bin/file ''; meta = with lib; { description = "MOD playing library"; - homepage = "https://modplug-xmms.sourceforge.net/"; - license = licenses.publicDomain; - platforms = platforms.unix; + homepage = "https://modplug-xmms.sourceforge.net/"; + license = licenses.publicDomain; + platforms = platforms.unix; maintainers = with maintainers; [ raskin ]; }; } diff --git a/pkgs/by-name/li/libmodule/package.nix b/pkgs/by-name/li/libmodule/package.nix index dd98908f3111ab..dbb2505e5c1841 100644 --- a/pkgs/by-name/li/libmodule/package.nix +++ b/pkgs/by-name/li/libmodule/package.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "libmodule"; diff --git a/pkgs/by-name/li/libmodulemd/package.nix b/pkgs/by-name/li/libmodulemd/package.nix index 0769cf4b1c2ba7..8c55e61b331012 100644 --- a/pkgs/by-name/li/libmodulemd/package.nix +++ b/pkgs/by-name/li/libmodulemd/package.nix @@ -1,26 +1,34 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch2 -, pkg-config -, meson -, ninja -, gobject-introspection -, python3 -, libyaml -, rpm -, file -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_412 -, glib +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch2, + pkg-config, + meson, + ninja, + gobject-introspection, + python3, + libyaml, + rpm, + file, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_412, + glib, }: stdenv.mkDerivation rec { pname = "libmodulemd"; version = "2.15.0"; - outputs = [ "bin" "out" "dev" "devdoc" "man" "py" ]; + outputs = [ + "bin" + "out" + "dev" + "devdoc" + "man" + "py" + ]; src = fetchFromGitHub { owner = "fedora-modularity"; diff --git a/pkgs/by-name/li/libmowgli/package.nix b/pkgs/by-name/li/libmowgli/package.nix index 5c999c4c1d4848..2f2575a3a18333 100644 --- a/pkgs/by-name/li/libmowgli/package.nix +++ b/pkgs/by-name/li/libmowgli/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "libmowgli"; diff --git a/pkgs/by-name/li/libmp3splt/package.nix b/pkgs/by-name/li/libmp3splt/package.nix index 0e813375b9a251..92d9ee12483055 100644 --- a/pkgs/by-name/li/libmp3splt/package.nix +++ b/pkgs/by-name/li/libmp3splt/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, libtool, libmad, libid3tag }: +{ + lib, + stdenv, + fetchurl, + libtool, + libmad, + libid3tag, +}: stdenv.mkDerivation rec { pname = "libmp3splt"; @@ -9,17 +16,23 @@ stdenv.mkDerivation rec { sha256 = "1p1mn2hsmj5cp40fnc8g1yfvk72p8pjxi866gjdkgjsqrr7xdvih"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ libtool ]; - buildInputs = [ libmad libid3tag ]; + buildInputs = [ + libmad + libid3tag + ]; configureFlags = [ "--disable-pcre" ]; meta = with lib; { - homepage = "https://sourceforge.net/projects/mp3splt/"; + homepage = "https://sourceforge.net/projects/mp3splt/"; description = "Utility to split mp3, ogg vorbis and FLAC files without decoding"; maintainers = with maintainers; [ bosu ]; - platforms = platforms.unix; + platforms = platforms.unix; license = licenses.gpl2; }; } diff --git a/pkgs/by-name/li/libmpack/package.nix b/pkgs/by-name/li/libmpack/package.nix index edb692d512d753..00b8d72d28b620 100644 --- a/pkgs/by-name/li/libmpack/package.nix +++ b/pkgs/by-name/li/libmpack/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libtool }: +{ + lib, + stdenv, + fetchFromGitHub, + libtool, +}: stdenv.mkDerivation rec { pname = "libmpack"; diff --git a/pkgs/by-name/li/libmpcdec/package.nix b/pkgs/by-name/li/libmpcdec/package.nix index 7536872212455b..b7613dc2ab9412 100644 --- a/pkgs/by-name/li/libmpcdec/package.nix +++ b/pkgs/by-name/li/libmpcdec/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libmpcdec"; diff --git a/pkgs/by-name/li/libmpd/package.nix b/pkgs/by-name/li/libmpd/package.nix index bb6c9ed45f8cce..a509134318d45b 100644 --- a/pkgs/by-name/li/libmpd/package.nix +++ b/pkgs/by-name/li/libmpd/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, doxygen -, glib +{ + lib, + stdenv, + fetchurl, + pkg-config, + doxygen, + glib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/libmpdclient/package.nix b/pkgs/by-name/li/libmpdclient/package.nix index 297ca698b0c94c..eeed2140bf8dba 100644 --- a/pkgs/by-name/li/libmpdclient/package.nix +++ b/pkgs/by-name/li/libmpdclient/package.nix @@ -1,9 +1,10 @@ -{ fetchFromGitHub -, fixDarwinDylibNames -, lib -, meson -, ninja -, stdenv +{ + fetchFromGitHub, + fixDarwinDylibNames, + lib, + meson, + ninja, + stdenv, }: stdenv.mkDerivation (finalAttrs: { @@ -17,12 +18,14 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-KF8IR9YV6b9ro+L9m6nHs1IggakEZddfcBKm/oKCVZY="; }; - nativeBuildInputs = [ - meson - ninja - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ]; + nativeBuildInputs = + [ + meson + ninja + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ]; meta = { description = "Client library for MPD (music player daemon)"; diff --git a/pkgs/by-name/li/libmpeg2/package.nix b/pkgs/by-name/li/libmpeg2/package.nix index 13fce963738fb6..7860056707cadb 100644 --- a/pkgs/by-name/li/libmpeg2/package.nix +++ b/pkgs/by-name/li/libmpeg2/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "0.5.1"; diff --git a/pkgs/by-name/li/libmsgraph/package.nix b/pkgs/by-name/li/libmsgraph/package.nix index 21845a6b7f7e15..186bd3b735eed2 100644 --- a/pkgs/by-name/li/libmsgraph/package.nix +++ b/pkgs/by-name/li/libmsgraph/package.nix @@ -1,25 +1,30 @@ -{ stdenv -, lib -, fetchurl -, gi-docgen -, gobject-introspection -, meson -, ninja -, pkg-config -, uhttpmock_1_0 -, libxml2 -, glib -, gnome-online-accounts -, json-glib -, libsoup_3 -, gnome +{ + stdenv, + lib, + fetchurl, + gi-docgen, + gobject-introspection, + meson, + ninja, + pkg-config, + uhttpmock_1_0, + libxml2, + glib, + gnome-online-accounts, + json-glib, + libsoup_3, + gnome, }: stdenv.mkDerivation (finalAttrs: { pname = "libmsgraph"; version = "0.2.3"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/msgraph/${lib.versions.majorMinor finalAttrs.version}/msgraph-${finalAttrs.version}.tar.xz"; diff --git a/pkgs/by-name/li/libmspack/package.nix b/pkgs/by-name/li/libmspack/package.nix index 136a303109162d..2e4f7d9d38beb8 100644 --- a/pkgs/by-name/li/libmspack/package.nix +++ b/pkgs/by-name/li/libmspack/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libmspack"; diff --git a/pkgs/by-name/li/libmsym/package.nix b/pkgs/by-name/li/libmsym/package.nix index fdcf7d00e3ba70..998cee1f48be84 100644 --- a/pkgs/by-name/li/libmsym/package.nix +++ b/pkgs/by-name/li/libmsym/package.nix @@ -1,14 +1,19 @@ -{ stdenv, lib, fetchFromGitHub, cmake } : +{ + stdenv, + lib, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "libmsym"; version = "0.2.3"; - src = fetchFromGitHub { + src = fetchFromGitHub { owner = "mcodev31"; repo = pname; rev = "v${version}"; - sha256= "k+OEwrA/saupP/wX6Ii5My0vffiJ0X9xMCTrliMSMik="; + sha256 = "k+OEwrA/saupP/wX6Ii5My0vffiJ0X9xMCTrliMSMik="; }; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/by-name/li/libmtp/package.nix b/pkgs/by-name/li/libmtp/package.nix index 320873c9792ce3..d61f1936fb5278 100644 --- a/pkgs/by-name/li/libmtp/package.nix +++ b/pkgs/by-name/li/libmtp/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, autoconf -, automake -, fetchFromGitHub -, fetchpatch -, gettext -, lib -, libiconv -, libtool -, libusb1 -, pkg-config -, buildPackages +{ + stdenv, + autoconf, + automake, + fetchFromGitHub, + fetchpatch, + gettext, + lib, + libiconv, + libtool, + libusb1, + pkg-config, + buildPackages, }: stdenv.mkDerivation rec { @@ -31,7 +32,11 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; nativeBuildInputs = [ autoconf @@ -49,12 +54,17 @@ stdenv.mkDerivation rec { configureFlags = [ "--with-udev=${placeholder "out"}/lib/udev" ]; - configurePlatforms = [ "build" "host" ]; - - makeFlags = lib.optionals (stdenv.hostPlatform.isLinux && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - "MTP_HOTPLUG=${buildPackages.libmtp}/bin/mtp-hotplug" + configurePlatforms = [ + "build" + "host" ]; + makeFlags = + lib.optionals (stdenv.hostPlatform.isLinux && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) + [ + "MTP_HOTPLUG=${buildPackages.libmtp}/bin/mtp-hotplug" + ]; + enableParallelBuilding = true; meta = with lib; { diff --git a/pkgs/by-name/li/libmwaw/package.nix b/pkgs/by-name/li/libmwaw/package.nix index cc2a292a049329..732db1b4c9b26b 100644 --- a/pkgs/by-name/li/libmwaw/package.nix +++ b/pkgs/by-name/li/libmwaw/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, boost, pkg-config, cppunit, zlib, libwpg, libwpd, librevenge }: +{ + lib, + stdenv, + fetchurl, + boost, + pkg-config, + cppunit, + zlib, + libwpg, + libwpd, + librevenge, +}: stdenv.mkDerivation rec { pname = "libmwaw"; diff --git a/pkgs/by-name/li/libmypaint/package.nix b/pkgs/by-name/li/libmypaint/package.nix index 2e9f4bc2b86675..3031b38d349333 100644 --- a/pkgs/by-name/li/libmypaint/package.nix +++ b/pkgs/by-name/li/libmypaint/package.nix @@ -1,20 +1,25 @@ -{ lib, stdenv -, autoconf -, automake -, fetchFromGitHub -, glib -, intltool -, json_c -, libtool -, pkg-config -, python3 +{ + lib, + stdenv, + autoconf, + automake, + fetchFromGitHub, + glib, + intltool, + json_c, + libtool, + pkg-config, + python3, }: stdenv.mkDerivation rec { pname = "libmypaint"; version = "1.6.1"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "mypaint"; diff --git a/pkgs/by-name/li/libmysofa/package.nix b/pkgs/by-name/li/libmysofa/package.nix index 5125d4c76ebac7..8b650259094212 100644 --- a/pkgs/by-name/li/libmysofa/package.nix +++ b/pkgs/by-name/li/libmysofa/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, +}: stdenv.mkDerivation rec { pname = "libmysofa"; @@ -11,12 +17,18 @@ stdenv.mkDerivation rec { hash = "sha256-eXMGwa6lOtKoUCcHR9BM2S3NWAZkGyZzF3FAjYaWTvg="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake ]; buildInputs = [ zlib ]; - cmakeFlags = [ "-DBUILD_TESTS=OFF" "-DCODE_COVERAGE=OFF" ]; + cmakeFlags = [ + "-DBUILD_TESTS=OFF" + "-DCODE_COVERAGE=OFF" + ]; meta = with lib; { description = "Reader for AES SOFA files to get better HRTFs"; diff --git a/pkgs/by-name/li/libnabo/package.nix b/pkgs/by-name/li/libnabo/package.nix index 8be83148b51406..58bec38657e4e5 100644 --- a/pkgs/by-name/li/libnabo/package.nix +++ b/pkgs/by-name/li/libnabo/package.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchFromGitHub, cmake, eigen, boost}: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + eigen, + boost, +}: stdenv.mkDerivation rec { version = "1.1.2"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ eigen boost ]; + buildInputs = [ + eigen + boost + ]; cmakeFlags = [ "-DEIGEN_INCLUDE_DIR=${eigen}/include/eigen3" @@ -25,7 +35,7 @@ stdenv.mkDerivation rec { inherit (src.meta) homepage; description = "Fast K Nearest Neighbor library for low-dimensional spaces"; license = licenses.bsd3; - platforms = platforms.linux; + platforms = platforms.linux; maintainers = with maintainers; [ cryptix ]; }; } diff --git a/pkgs/by-name/li/libnatpmp/package.nix b/pkgs/by-name/li/libnatpmp/package.nix index 13128e81231efd..95ec99a7363012 100644 --- a/pkgs/by-name/li/libnatpmp/package.nix +++ b/pkgs/by-name/li/libnatpmp/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, fixDarwinDylibNames +{ + lib, + stdenv, + fetchurl, + fetchpatch, + fixDarwinDylibNames, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libnats-c/package.nix b/pkgs/by-name/li/libnats-c/package.nix index 5d641a386344e5..82428ee03f8224 100644 --- a/pkgs/by-name/li/libnats-c/package.nix +++ b/pkgs/by-name/li/libnats-c/package.nix @@ -1,24 +1,38 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, protobuf, protobufc -, libsodium, openssl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + protobuf, + protobufc, + libsodium, + openssl, }: stdenv.mkDerivation rec { - pname = "libnats"; + pname = "libnats"; version = "3.8.2"; src = fetchFromGitHub { - owner = "nats-io"; - repo = "nats.c"; - rev = "v${version}"; + owner = "nats-io"; + repo = "nats.c"; + rev = "v${version}"; sha256 = "sha256-Tn88RRigL6C36AcFhUlLbLyqcqbBR8z6PKAQH4w/mYY="; }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libsodium openssl protobuf protobufc ]; + buildInputs = [ + libsodium + openssl + protobuf + protobufc + ]; separateDebugInfo = true; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; # https://github.com/nats-io/nats.c/issues/542 postPatch = '' @@ -28,9 +42,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "C API for the NATS messaging system"; - homepage = "https://github.com/nats-io/nats.c"; - license = licenses.asl20; - platforms = platforms.unix; + homepage = "https://github.com/nats-io/nats.c"; + license = licenses.asl20; + platforms = platforms.unix; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/li/libnatspec/package.nix b/pkgs/by-name/li/libnatspec/package.nix index 65ea9086dce16b..0bc5de4e4f05aa 100644 --- a/pkgs/by-name/li/libnatspec/package.nix +++ b/pkgs/by-name/li/libnatspec/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, autoreconfHook, popt, libiconv }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + popt, + libiconv, +}: stdenv.mkDerivation rec { pname = "libnatspec"; diff --git a/pkgs/by-name/li/libnbd/package.nix b/pkgs/by-name/li/libnbd/package.nix index 02b3cf734daa47..59ba1c48e4f051 100644 --- a/pkgs/by-name/li/libnbd/package.nix +++ b/pkgs/by-name/li/libnbd/package.nix @@ -19,80 +19,81 @@ lib.throwIf (buildOcamlBindings && !lib.versionAtLeast ocamlPackages.ocaml.version "4.05") "OCaml binding are not available for OCaml < 4.05" -stdenv.mkDerivation rec { - pname = "libnbd"; - version = "1.20.2"; + stdenv.mkDerivation + rec { + pname = "libnbd"; + version = "1.20.2"; - src = fetchurl { - url = "https://download.libguestfs.org/libnbd/${lib.versions.majorMinor version}-stable/${pname}-${version}.tar.gz"; - hash = "sha256-7DgviwGPPLccTPvomyH+0CMknXmR2wENsxpXD97OP84="; - }; + src = fetchurl { + url = "https://download.libguestfs.org/libnbd/${lib.versions.majorMinor version}-stable/${pname}-${version}.tar.gz"; + hash = "sha256-7DgviwGPPLccTPvomyH+0CMknXmR2wENsxpXD97OP84="; + }; - nativeBuildInputs = - [ - bash-completion - pkg-config - perl - autoreconfHook - ] - ++ lib.optionals buildPythonBindings [ python3 ] - ++ lib.optionals buildOcamlBindings ( - with ocamlPackages; + nativeBuildInputs = [ - findlib - ocaml + bash-completion + pkg-config + perl + autoreconfHook ] - ); + ++ lib.optionals buildPythonBindings [ python3 ] + ++ lib.optionals buildOcamlBindings ( + with ocamlPackages; + [ + findlib + ocaml + ] + ); - buildInputs = [ - fuse - fuse3 - gnutls - libxml2 - ]; + buildInputs = [ + fuse + fuse3 + gnutls + libxml2 + ]; - postPatch = lib.optionalString buildOcamlBindings '' - substituteInPlace ocaml/Makefile.am \ - --replace-fail '$(DESTDIR)$(OCAMLLIB)' '$(out)/lib/ocaml/${ocamlPackages.ocaml.version}/site-lib' - ''; + postPatch = lib.optionalString buildOcamlBindings '' + substituteInPlace ocaml/Makefile.am \ + --replace-fail '$(DESTDIR)$(OCAMLLIB)' '$(out)/lib/ocaml/${ocamlPackages.ocaml.version}/site-lib' + ''; - configureFlags = lib.optionals buildPythonBindings [ - "--with-python-installdir=${placeholder "out"}/${python3.sitePackages}" - ]; + configureFlags = lib.optionals buildPythonBindings [ + "--with-python-installdir=${placeholder "out"}/${python3.sitePackages}" + ]; - installFlags = [ "bashcompdir=$(out)/share/bash-completion/completions" ]; + installFlags = [ "bashcompdir=$(out)/share/bash-completion/completions" ]; - postInstall = lib.optionalString buildPythonBindings '' - LIBNBD_PYTHON_METADATA='${placeholder "out"}/${python3.sitePackages}/nbd-${version}.dist-info/METADATA' - install -Dm644 -T ${./libnbd-metadata} $LIBNBD_PYTHON_METADATA - substituteAllInPlace $LIBNBD_PYTHON_METADATA - ''; + postInstall = lib.optionalString buildPythonBindings '' + LIBNBD_PYTHON_METADATA='${placeholder "out"}/${python3.sitePackages}/nbd-${version}.dist-info/METADATA' + install -Dm644 -T ${./libnbd-metadata} $LIBNBD_PYTHON_METADATA + substituteAllInPlace $LIBNBD_PYTHON_METADATA + ''; - meta = with lib; { - homepage = "https://gitlab.com/nbdkit/libnbd"; - description = "Network Block Device client library in userspace"; - longDescription = '' - NBD — Network Block Device — is a protocol for accessing Block Devices - (hard disks and disk-like things) over a Network. This is the NBD client - library in userspace, a simple library for writing NBD clients. + meta = with lib; { + homepage = "https://gitlab.com/nbdkit/libnbd"; + description = "Network Block Device client library in userspace"; + longDescription = '' + NBD — Network Block Device — is a protocol for accessing Block Devices + (hard disks and disk-like things) over a Network. This is the NBD client + library in userspace, a simple library for writing NBD clients. - The key features are: - - Synchronous API for ease of use. - - Asynchronous API for writing non-blocking, multithreaded clients. You - can mix both APIs freely. - - High performance. - - Minimal dependencies for the basic library. - - Well-documented, stable API. - - Bindings in several programming languages. - - Shell (nbdsh) for command line and scripting. - ''; - license = with licenses; lgpl21Plus; - maintainers = with maintainers; [ - humancalico - ]; - platforms = with platforms; linux; - }; -} + The key features are: + - Synchronous API for ease of use. + - Asynchronous API for writing non-blocking, multithreaded clients. You + can mix both APIs freely. + - High performance. + - Minimal dependencies for the basic library. + - Well-documented, stable API. + - Bindings in several programming languages. + - Shell (nbdsh) for command line and scripting. + ''; + license = with licenses; lgpl21Plus; + maintainers = with maintainers; [ + humancalico + ]; + platforms = with platforms; linux; + }; + } # TODO: package the 1.6-stable version too # TODO: git version needs ocaml # TODO: bindings for go diff --git a/pkgs/by-name/li/libndp/package.nix b/pkgs/by-name/li/libndp/package.nix index a8df26fbb9b8a5..933c0aaa54dd95 100644 --- a/pkgs/by-name/li/libndp/package.nix +++ b/pkgs/by-name/li/libndp/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, autoreconfHook, gitUpdater }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + gitUpdater, +}: stdenv.mkDerivation rec { pname = "libndp"; diff --git a/pkgs/by-name/li/libndtypes/package.nix b/pkgs/by-name/li/libndtypes/package.nix index 175b48f109348f..ec7fd35932df81 100644 --- a/pkgs/by-name/li/libndtypes/package.nix +++ b/pkgs/by-name/li/libndtypes/package.nix @@ -1,13 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation { pname = "libndtypes"; version = "unstable-2019-08-01"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "xnd-project"; diff --git a/pkgs/by-name/li/libnest2d/package.nix b/pkgs/by-name/li/libnest2d/package.nix index b3aba528f92431..88906caac71eb9 100644 --- a/pkgs/by-name/li/libnest2d/package.nix +++ b/pkgs/by-name/li/libnest2d/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, clipper, nlopt, boost }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + clipper, + nlopt, + boost, +}: stdenv.mkDerivation { version = "4.12.0"; @@ -19,15 +27,18 @@ stdenv.mkDerivation { --replace "set(CMAKE_CXX_STANDARD 11)" "set(CMAKE_CXX_STANDARD 14)" ''; - propagatedBuildInputs = [ clipper nlopt boost ]; + propagatedBuildInputs = [ + clipper + nlopt + boost + ]; nativeBuildInputs = [ cmake ]; CLIPPER_PATH = "${clipper.out}"; cmakeFlags = [ "-DLIBNEST2D_HEADER_ONLY=OFF" ]; meta = with lib; { - description = - "2D irregular bin packaging and nesting library written in modern C++"; + description = "2D irregular bin packaging and nesting library written in modern C++"; homepage = "https://github.com/Ultimaker/libnest2d"; license = licenses.lgpl3; platforms = platforms.all; diff --git a/pkgs/by-name/li/libnet/package.nix b/pkgs/by-name/li/libnet/package.nix index c8f38387111f8f..c8a6c712c1d6ba 100644 --- a/pkgs/by-name/li/libnet/package.nix +++ b/pkgs/by-name/li/libnet/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libtool }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, +}: stdenv.mkDerivation rec { pname = "libnet"; diff --git a/pkgs/by-name/li/libnetfilter_acct/package.nix b/pkgs/by-name/li/libnetfilter_acct/package.nix index 6c52d7f7b560f6..c12e39e9bcb5c3 100644 --- a/pkgs/by-name/li/libnetfilter_acct/package.nix +++ b/pkgs/by-name/li/libnetfilter_acct/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libmnl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libmnl, +}: stdenv.mkDerivation rec { version = "1.0.3"; diff --git a/pkgs/by-name/li/libnetfilter_conntrack/package.nix b/pkgs/by-name/li/libnetfilter_conntrack/package.nix index e056eddcb1ab0c..ff200671af0f3b 100644 --- a/pkgs/by-name/li/libnetfilter_conntrack/package.nix +++ b/pkgs/by-name/li/libnetfilter_conntrack/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, libnfnetlink, libmnl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libnfnetlink, + libmnl, +}: stdenv.mkDerivation rec { pname = "libnetfilter_conntrack"; diff --git a/pkgs/by-name/li/libnetfilter_cthelper/package.nix b/pkgs/by-name/li/libnetfilter_cthelper/package.nix index 5d221bed34a020..4a0afa76b736b7 100644 --- a/pkgs/by-name/li/libnetfilter_cthelper/package.nix +++ b/pkgs/by-name/li/libnetfilter_cthelper/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libmnl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libmnl, +}: stdenv.mkDerivation rec { pname = "libnetfilter_cthelper"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-FAc9VIcjOJc1XT/wTdwcjQPMW6jSNWI2qogWGp8tyRI="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ pkg-config ]; buildInputs = [ libmnl ]; diff --git a/pkgs/by-name/li/libnetfilter_cttimeout/package.nix b/pkgs/by-name/li/libnetfilter_cttimeout/package.nix index d4b53a1818717a..7c2c870bf36275 100644 --- a/pkgs/by-name/li/libnetfilter_cttimeout/package.nix +++ b/pkgs/by-name/li/libnetfilter_cttimeout/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libmnl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libmnl, +}: stdenv.mkDerivation rec { pname = "libnetfilter_cttimeout"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-C1naLzIE4cgMuF0fbXIoX8B7AaL1Z4q/Xcz7vv1lAyU="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ pkg-config ]; buildInputs = [ libmnl ]; diff --git a/pkgs/by-name/li/libnetfilter_log/package.nix b/pkgs/by-name/li/libnetfilter_log/package.nix index aadc3d92b597f3..93d6d4b861f11e 100644 --- a/pkgs/by-name/li/libnetfilter_log/package.nix +++ b/pkgs/by-name/li/libnetfilter_log/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, libnfnetlink, libmnl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libnfnetlink, + libmnl, +}: stdenv.mkDerivation rec { pname = "libnetfilter_log"; diff --git a/pkgs/by-name/li/libnetfilter_queue/package.nix b/pkgs/by-name/li/libnetfilter_queue/package.nix index d1783289965ee7..86a5ab16235df3 100644 --- a/pkgs/by-name/li/libnetfilter_queue/package.nix +++ b/pkgs/by-name/li/libnetfilter_queue/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, libmnl, libnfnetlink }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libmnl, + libnfnetlink, +}: stdenv.mkDerivation rec { version = "1.0.5"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libmnl libnfnetlink ]; + buildInputs = [ + libmnl + libnfnetlink + ]; meta = with lib; { homepage = "https://www.netfilter.org/projects/libnetfilter_queue/"; diff --git a/pkgs/by-name/li/libnfc/package.nix b/pkgs/by-name/li/libnfc/package.nix index 8fb983333c1cb3..1d7560d9e1c515 100644 --- a/pkgs/by-name/li/libnfc/package.nix +++ b/pkgs/by-name/li/libnfc/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, libusb-compat-0_1 -, readline -, cmake -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + libusb-compat-0_1, + readline, + cmake, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libnfnetlink/package.nix b/pkgs/by-name/li/libnfnetlink/package.nix index 3b6b804a8dc62a..897b257ab3ef6e 100644 --- a/pkgs/by-name/li/libnfnetlink/package.nix +++ b/pkgs/by-name/li/libnfnetlink/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libnfnetlink"; diff --git a/pkgs/by-name/li/libnfs/package.nix b/pkgs/by-name/li/libnfs/package.nix index d9beee7933fa9a..e1a896d031ecee 100644 --- a/pkgs/by-name/li/libnfs/package.nix +++ b/pkgs/by-name/li/libnfs/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libnfs"; @@ -34,9 +40,13 @@ stdenv.mkDerivation rec { meta = with lib; { description = "NFS client library"; - homepage = "https://github.com/sahlberg/libnfs"; - license = with licenses; [ lgpl2 bsd2 gpl3 ]; + homepage = "https://github.com/sahlberg/libnfs"; + license = with licenses; [ + lgpl2 + bsd2 + gpl3 + ]; maintainers = with maintainers; [ peterhoeg ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/li/libnftnl/package.nix b/pkgs/by-name/li/libnftnl/package.nix index bac21d63b2b697..a2536ad82ac70b 100644 --- a/pkgs/by-name/li/libnftnl/package.nix +++ b/pkgs/by-name/li/libnftnl/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, libmnl, gitUpdater }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libmnl, + gitUpdater, +}: stdenv.mkDerivation rec { version = "1.2.8"; @@ -9,7 +16,9 @@ stdenv.mkDerivation rec { hash = "sha256-N/6l1rXJsI3nkg0pjePNyULnrmSxo+i4gLLTkK5nrZU="; }; - configureFlags = lib.optional (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") "LDFLAGS=-Wl,--undefined-version"; + configureFlags = lib.optional ( + stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17" + ) "LDFLAGS=-Wl,--undefined-version"; nativeBuildInputs = [ pkg-config ]; buildInputs = [ libmnl ]; diff --git a/pkgs/by-name/li/libnghttp2_asio/package.nix b/pkgs/by-name/li/libnghttp2_asio/package.nix index 7853e89d27de84..a303b43b8438b9 100644 --- a/pkgs/by-name/li/libnghttp2_asio/package.nix +++ b/pkgs/by-name/li/libnghttp2_asio/package.nix @@ -1,17 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, nghttp2 -, openssl -, boost +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + nghttp2, + openssl, + boost, }: stdenv.mkDerivation rec { pname = "libnghttp2_asio"; version = "unstable-2022-08-11"; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; src = fetchFromGitHub { owner = "nghttp2"; diff --git a/pkgs/by-name/li/libngspice/package.nix b/pkgs/by-name/li/libngspice/package.nix index 044d1b25fafe17..18720937e01bbf 100644 --- a/pkgs/by-name/li/libngspice/package.nix +++ b/pkgs/by-name/li/libngspice/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, flex -, bison -, fftw -, withNgshared ? true -, libXaw -, libXext -, llvmPackages -, readline +{ + lib, + stdenv, + fetchurl, + flex, + bison, + fftw, + withNgshared ? true, + libXaw, + libXext, + llvmPackages, + readline, }: stdenv.mkDerivation rec { @@ -25,23 +26,28 @@ stdenv.mkDerivation rec { bison ]; - buildInputs = [ - fftw - readline - ] ++ lib.optionals (!withNgshared) [ - libXaw - libXext - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - llvmPackages.openmp - ]; + buildInputs = + [ + fftw + readline + ] + ++ lib.optionals (!withNgshared) [ + libXaw + libXext + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + llvmPackages.openmp + ]; - configureFlags = lib.optionals withNgshared [ - "--with-ngshared" - ] ++ [ - "--enable-xspice" - "--enable-cider" - "--enable-osdi" - ]; + configureFlags = + lib.optionals withNgshared [ + "--with-ngshared" + ] + ++ [ + "--enable-xspice" + "--enable-cider" + "--enable-osdi" + ]; enableParallelBuilding = true; @@ -49,7 +55,11 @@ stdenv.mkDerivation rec { description = "Next Generation Spice (Electronic Circuit Simulator)"; mainProgram = "ngspice"; homepage = "http://ngspice.sourceforge.net"; - license = with licenses; [ bsd3 gpl2Plus lgpl2Plus ]; # See https://sourceforge.net/p/ngspice/ngspice/ci/master/tree/COPYING + license = with licenses; [ + bsd3 + gpl2Plus + lgpl2Plus + ]; # See https://sourceforge.net/p/ngspice/ngspice/ci/master/tree/COPYING maintainers = with maintainers; [ bgamari ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/li/libnice/package.nix b/pkgs/by-name/li/libnice/package.nix index 72419deaccb5a8..7cc8166bf6d792 100644 --- a/pkgs/by-name/li/libnice/package.nix +++ b/pkgs/by-name/li/libnice/package.nix @@ -1,27 +1,32 @@ -{ lib, stdenv -, fetchurl -, fetchpatch -, meson -, ninja -, pkg-config -, python3 -, gobject-introspection -, gtk-doc -, docbook_xsl -, docbook_xml_dtd_412 -, glib -, gupnp-igd -, gst_all_1 -, gnutls -, graphviz +{ + lib, + stdenv, + fetchurl, + fetchpatch, + meson, + ninja, + pkg-config, + python3, + gobject-introspection, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_412, + glib, + gupnp-igd, + gst_all_1, + gnutls, + graphviz, }: stdenv.mkDerivation rec { pname = "libnice"; version = "0.1.22"; - outputs = [ "bin" "out" "dev" ] - ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ "devdoc" ]; + outputs = [ + "bin" + "out" + "dev" + ] ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ "devdoc" ]; src = fetchurl { url = "https://libnice.freedesktop.org/releases/${pname}-${version}.tar.gz"; @@ -84,6 +89,9 @@ stdenv.mkDerivation rec { libstun as well as GStreamer elements.''; homepage = "https://libnice.freedesktop.org/"; platforms = platforms.unix; - license = with licenses; [ lgpl21 mpl11 ]; + license = with licenses; [ + lgpl21 + mpl11 + ]; }; } diff --git a/pkgs/by-name/li/libnids/package.nix b/pkgs/by-name/li/libnids/package.nix index 739c8c57879ac1..93e31d8804ff76 100644 --- a/pkgs/by-name/li/libnids/package.nix +++ b/pkgs/by-name/li/libnids/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchzip, libpcap, glib, pkg-config, libnet }: +{ + lib, + stdenv, + fetchzip, + libpcap, + glib, + pkg-config, + libnet, +}: stdenv.mkDerivation { pname = "libnids"; version = "1.24"; @@ -7,16 +15,20 @@ stdenv.mkDerivation { sha256 = "1cblklfdfxcmy0an6xyyzx4l877xdawhjd28daqfsvrh81mb07k1"; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libpcap glib libnet ]; + buildInputs = [ + libpcap + glib + libnet + ]; /* - Quoting the documentation of glib: g_thread_init has been deprecated since - version 2.32 and should not be used in newly-written code. This function is - no longer necessary. The GLib threading system is automatically initialized - at the start of your program. + Quoting the documentation of glib: g_thread_init has been deprecated since + version 2.32 and should not be used in newly-written code. This function is + no longer necessary. The GLib threading system is automatically initialized + at the start of your program. - this is necessary for dsniff to compile; otherwise g_thread_init is a missing - symbol when linking (?!?) + this is necessary for dsniff to compile; otherwise g_thread_init is a missing + symbol when linking (?!?) */ env.NIX_CFLAGS_COMPILE = "-Dg_thread_init= "; diff --git a/pkgs/by-name/li/libnitrokey/package.nix b/pkgs/by-name/li/libnitrokey/package.nix index 6b847a8e742d6d..5b73a5963bb742 100644 --- a/pkgs/by-name/li/libnitrokey/package.nix +++ b/pkgs/by-name/li/libnitrokey/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, hidapi -, libusb1 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + hidapi, + libusb1, }: stdenv.mkDerivation (finalAttrs: { @@ -40,6 +41,9 @@ stdenv.mkDerivation (finalAttrs: { description = "Communicate with Nitrokey devices in a clean and easy manner"; homepage = "https://github.com/Nitrokey/libnitrokey"; license = licenses.lgpl3; - maintainers = with maintainers; [ panicgh raitobezarius ]; + maintainers = with maintainers; [ + panicgh + raitobezarius + ]; }; }) diff --git a/pkgs/by-name/li/libnixxml/package.nix b/pkgs/by-name/li/libnixxml/package.nix index fb2bfdde5c06a1..ec6baa77fcde9e 100644 --- a/pkgs/by-name/li/libnixxml/package.nix +++ b/pkgs/by-name/li/libnixxml/package.nix @@ -1,4 +1,17 @@ -{ fetchFromGitHub, lib, stdenv, autoreconfHook, pkg-config, libxml2, gd, glib, getopt, libxslt, nix, bash}: +{ + fetchFromGitHub, + lib, + stdenv, + autoreconfHook, + pkg-config, + libxml2, + gd, + glib, + getopt, + libxslt, + nix, + bash, +}: stdenv.mkDerivation { pname = "libnixxml"; @@ -28,7 +41,10 @@ stdenv.mkDerivation { mkdir -p config ''; - configureFlags = [ "--with-gd" "--with-glib" ]; + configureFlags = [ + "--with-gd" + "--with-glib" + ]; CFLAGS = [ "-Wall" "-std=c90" diff --git a/pkgs/by-name/li/libnl-tiny/package.nix b/pkgs/by-name/li/libnl-tiny/package.nix index 8a8c84513f624f..84d9210328e630 100644 --- a/pkgs/by-name/li/libnl-tiny/package.nix +++ b/pkgs/by-name/li/libnl-tiny/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchgit, cmake, pkg-config }: +{ + stdenv, + lib, + fetchgit, + cmake, + pkg-config, +}: stdenv.mkDerivation { pname = "libnl-tiny"; @@ -10,7 +16,10 @@ stdenv.mkDerivation { hash = "sha256-kegTV7FXMERW7vjRZo/Xp4cbSBZmynBgge2lK71Fx94="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; preConfigure = '' sed -e 's|''${prefix}/@CMAKE_INSTALL_LIBDIR@|@CMAKE_INSTALL_FULL_LIBDIR@|g' \ diff --git a/pkgs/by-name/li/libnotify/package.nix b/pkgs/by-name/li/libnotify/package.nix index cb8506dca6ca5d..655211524f7ee7 100644 --- a/pkgs/by-name/li/libnotify/package.nix +++ b/pkgs/by-name/li/libnotify/package.nix @@ -1,23 +1,31 @@ -{ lib, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, libxslt -, docbook-xsl-ns -, glib -, gdk-pixbuf -, gnome -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, gobject-introspection +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + libxslt, + docbook-xsl-ns, + glib, + gdk-pixbuf, + gnome, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + gobject-introspection, }: stdenv.mkDerivation rec { pname = "libnotify"; version = "0.8.3"; - outputs = [ "out" "man" "dev" ]; + outputs = [ + "out" + "man" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -34,16 +42,18 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ - meson - ninja - pkg-config - libxslt - docbook-xsl-ns - glib # for glib-mkenums needed during the build - ] ++ lib.optionals withIntrospection [ - gobject-introspection - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + libxslt + docbook-xsl-ns + glib # for glib-mkenums needed during the build + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + ]; propagatedBuildInputs = [ gdk-pixbuf diff --git a/pkgs/by-name/li/libnova/package.nix b/pkgs/by-name/li/libnova/package.nix index 2f5f6851fd8d30..3d240a60596556 100644 --- a/pkgs/by-name/li/libnova/package.nix +++ b/pkgs/by-name/li/libnova/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchgit, autoreconfHook }: +{ + lib, + stdenv, + fetchgit, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libnova"; diff --git a/pkgs/by-name/li/libnsl/package.nix b/pkgs/by-name/li/libnsl/package.nix index b199406918abd4..d03bc44888deb5 100644 --- a/pkgs/by-name/li/libnsl/package.nix +++ b/pkgs/by-name/li/libnsl/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libtirpc, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libtirpc, + pkg-config, +}: stdenv.mkDerivation rec { pname = "libnsl"; @@ -11,9 +18,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-bCToqXVE4RZcoZ2eTNZcVHyzKlWyIpSAssQCOZcfmEA="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libtirpc ]; meta = with lib; { diff --git a/pkgs/by-name/li/libnss-mysql/package.nix b/pkgs/by-name/li/libnss-mysql/package.nix index 1333128011191a..432f75bdd0a653 100644 --- a/pkgs/by-name/li/libnss-mysql/package.nix +++ b/pkgs/by-name/li/libnss-mysql/package.nix @@ -1,10 +1,11 @@ -{ lib -, nixosTests -, stdenv -, fetchFromGitHub -, autoreconfHook -, which -, libmysqlclient +{ + lib, + nixosTests, + stdenv, + fetchFromGitHub, + autoreconfHook, + which, + libmysqlclient, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "1fhsswa3h2nkhjkyjxxqnj07rlx6bmfvd8j521snimx2jba8h0d6"; }; - nativeBuildInputs = [ autoreconfHook which ]; + nativeBuildInputs = [ + autoreconfHook + which + ]; buildInputs = [ libmysqlclient ]; configureFlags = [ "--sysconfdir=/etc" ]; diff --git a/pkgs/by-name/li/libnut/package.nix b/pkgs/by-name/li/libnut/package.nix index c89206209963c8..c1d197cccedd02 100644 --- a/pkgs/by-name/li/libnut/package.nix +++ b/pkgs/by-name/li/libnut/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, lib -, fetchgit +{ + stdenv, + lib, + fetchgit, }: stdenv.mkDerivation rec { pname = "libnut"; @@ -13,7 +14,7 @@ stdenv.mkDerivation rec { }; sourceRoot = "${src.name}/src/trunk"; - makeFlags = ["prefix=$(out)"]; + makeFlags = [ "prefix=$(out)" ]; installTargets = [ "install-libnut" "install-nututils" @@ -23,7 +24,7 @@ stdenv.mkDerivation rec { description = "Library to read/write the NUT video container format"; homepage = "https://git.ffmpeg.org/gitweb/nut.git"; license = licenses.mit; - maintainers = with maintainers; [quag]; + maintainers = with maintainers; [ quag ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/li/libnvme/package.nix b/pkgs/by-name/li/libnvme/package.nix index b175a325d34a36..8fa316908454d2 100644 --- a/pkgs/by-name/li/libnvme/package.nix +++ b/pkgs/by-name/li/libnvme/package.nix @@ -1,19 +1,20 @@ -{ fetchFromGitHub -, bash -, json_c -, keyutils -, lib -, meson -, ninja -, openssl -, perl -, pkg-config -, python3 -, stdenv -, swig -, systemd -# ImportError: cannot import name 'mlog' from 'mesonbuild' -, withDocs ? stdenv.hostPlatform.canExecute stdenv.buildPlatform +{ + fetchFromGitHub, + bash, + json_c, + keyutils, + lib, + meson, + ninja, + openssl, + perl, + pkg-config, + python3, + stdenv, + swig, + systemd, + # ImportError: cannot import name 'mlog' from 'mesonbuild' + withDocs ? stdenv.hostPlatform.canExecute stdenv.buildPlatform, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/liboauth/package.nix b/pkgs/by-name/li/liboauth/package.nix index 3f2f02987fbb69..12552d6e4c033f 100644 --- a/pkgs/by-name/li/liboauth/package.nix +++ b/pkgs/by-name/li/liboauth/package.nix @@ -1,5 +1,11 @@ -{ fetchurl, lib, stdenv, nss, nspr, pkg-config }: - +{ + fetchurl, + lib, + stdenv, + nss, + nspr, + pkg-config, +}: stdenv.mkDerivation rec { pname = "liboauth"; @@ -10,11 +16,17 @@ stdenv.mkDerivation rec { sha256 = "07w1aq8y8wld43wmbk2q8134p3bfkp2vma78mmsfgw2jn1bh3xhd"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ nss nspr ]; + propagatedBuildInputs = [ + nss + nspr + ]; configureFlags = [ "--enable-nss" ]; diff --git a/pkgs/by-name/li/libodb-sqlite/package.nix b/pkgs/by-name/li/libodb-sqlite/package.nix index 547ff807d441a4..851ff3cb662981 100644 --- a/pkgs/by-name/li/libodb-sqlite/package.nix +++ b/pkgs/by-name/li/libodb-sqlite/package.nix @@ -1,16 +1,22 @@ -{ lib, stdenv -, build2 -, fetchurl -, libodb -, sqlite -, enableShared ? !stdenv.hostPlatform.isStatic -, enableStatic ? !enableShared +{ + lib, + stdenv, + build2, + fetchurl, + libodb, + sqlite, + enableShared ? !stdenv.hostPlatform.isStatic, + enableStatic ? !enableShared, }: stdenv.mkDerivation rec { pname = "libodb-sqlite"; version = "2.5.0-b.27"; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; src = fetchurl { url = "https://pkg.cppget.org/1/beta/odb/libodb-sqlite-${version}.tar.gz"; diff --git a/pkgs/by-name/li/libodb/package.nix b/pkgs/by-name/li/libodb/package.nix index b83e4d5c681627..3ec508b9d11eca 100644 --- a/pkgs/by-name/li/libodb/package.nix +++ b/pkgs/by-name/li/libodb/package.nix @@ -1,14 +1,20 @@ -{ lib, stdenv -, build2 -, fetchurl -, enableShared ? !stdenv.hostPlatform.isStatic -, enableStatic ? !enableShared +{ + lib, + stdenv, + build2, + fetchurl, + enableShared ? !stdenv.hostPlatform.isStatic, + enableStatic ? !enableShared, }: stdenv.mkDerivation rec { pname = "libodb"; version = "2.5.0-b.27"; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; src = fetchurl { url = "https://pkg.cppget.org/1/beta/odb/libodb-${version}.tar.gz"; diff --git a/pkgs/by-name/li/libodfgen/package.nix b/pkgs/by-name/li/libodfgen/package.nix index 4f9574e0790818..d48a97088281cc 100644 --- a/pkgs/by-name/li/libodfgen/package.nix +++ b/pkgs/by-name/li/libodfgen/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, boost, pkg-config, cppunit, zlib, libwpg, libwpd, librevenge }: +{ + lib, + stdenv, + fetchurl, + boost, + pkg-config, + cppunit, + zlib, + libwpg, + libwpd, + librevenge, +}: stdenv.mkDerivation rec { pname = "libodfgen"; diff --git a/pkgs/by-name/li/libofa/package.nix b/pkgs/by-name/li/libofa/package.nix index a64afbb930aef8..e1176a1ff2c680 100644 --- a/pkgs/by-name/li/libofa/package.nix +++ b/pkgs/by-name/li/libofa/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, expat, curl, fftw }: +{ + lib, + stdenv, + fetchurl, + expat, + curl, + fftw, +}: stdenv.mkDerivation rec { pname = "libofa"; @@ -15,7 +22,10 @@ stdenv.mkDerivation rec { sha256 = "1rfkyz13cm8izm90c1xflp4rvsa24aqs6qpbbbqqcbmvzsj6j9yn"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; setOutputFlags = false; @@ -23,7 +33,11 @@ stdenv.mkDerivation rec { configureFlagsArray=(--includedir=$dev/include --libdir=$out/lib) ''; - propagatedBuildInputs = [ expat curl fftw ]; + propagatedBuildInputs = [ + expat + curl + fftw + ]; meta = with lib; { homepage = "https://code.google.com/archive/p/musicip-libofa/"; diff --git a/pkgs/by-name/li/libofx/package.nix b/pkgs/by-name/li/libofx/package.nix index ec5f6d8924d71d..0c5389afcfc2eb 100644 --- a/pkgs/by-name/li/libofx/package.nix +++ b/pkgs/by-name/li/libofx/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, opensp, pkg-config, libxml2, curl -, autoconf, automake, libtool, gengetopt, libiconv }: +{ + lib, + stdenv, + fetchFromGitHub, + opensp, + pkg-config, + libxml2, + curl, + autoconf, + automake, + libtool, + gengetopt, + libiconv, +}: stdenv.mkDerivation rec { pname = "libofx"; @@ -14,8 +26,18 @@ stdenv.mkDerivation rec { preConfigure = "./autogen.sh"; configureFlags = [ "--with-opensp-includes=${opensp}/include/OpenSP" ]; - nativeBuildInputs = [ pkg-config libtool autoconf automake gengetopt ]; - buildInputs = [ opensp libxml2 curl ] ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; + nativeBuildInputs = [ + pkg-config + libtool + autoconf + automake + gengetopt + ]; + buildInputs = [ + opensp + libxml2 + curl + ] ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; meta = { description = "Opensource implementation of the Open Financial eXchange specification"; diff --git a/pkgs/by-name/li/liboggz/package.nix b/pkgs/by-name/li/liboggz/package.nix index d458590179dd22..47778a5181ff06 100644 --- a/pkgs/by-name/li/liboggz/package.nix +++ b/pkgs/by-name/li/liboggz/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libogg, pkg-config }: +{ + lib, + stdenv, + fetchurl, + libogg, + pkg-config, +}: stdenv.mkDerivation rec { pname = "liboggz"; diff --git a/pkgs/by-name/li/liboil/package.nix b/pkgs/by-name/li/liboil/package.nix index 2abbaa66f34781..f9f9cdc5ea93b7 100644 --- a/pkgs/by-name/li/liboil/package.nix +++ b/pkgs/by-name/li/liboil/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, pkg-config }: +{ + lib, + stdenv, + fetchurl, + pkg-config, +}: stdenv.mkDerivation rec { pname = "liboil"; @@ -11,14 +16,20 @@ stdenv.mkDerivation rec { patches = [ ./x86_64-cpuid.patch ]; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "dev"; # oil-bugreport nativeBuildInputs = [ pkg-config ]; # fix "argb_paint_i386.c:53:Incorrect register `%rax' used with `l' suffix" # errors - configureFlags = lib.optional (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) "--build=x86_64"; + configureFlags = lib.optional ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64 + ) "--build=x86_64"; # fixes a cast in inline asm: easier than patching buildFlags = lib.optional stdenv.hostPlatform.isDarwin "CFLAGS=-fheinous-gnu-extensions"; @@ -26,9 +37,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Library of simple functions that are optimized for various CPUs"; mainProgram = "oil-bugreport"; - homepage = "https://liboil.freedesktop.org"; - license = licenses.bsd2; + homepage = "https://liboil.freedesktop.org"; + license = licenses.bsd2; maintainers = with maintainers; [ lovek323 ]; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/li/libomemo-c/package.nix b/pkgs/by-name/li/libomemo-c/package.nix index 4b7524c59d0ca0..e1f87d39b180f9 100644 --- a/pkgs/by-name/li/libomemo-c/package.nix +++ b/pkgs/by-name/li/libomemo-c/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openssl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libomxil-bellagio/package.nix b/pkgs/by-name/li/libomxil-bellagio/package.nix index 78f37bbbb67dd4..936d70f32787db 100644 --- a/pkgs/by-name/li/libomxil-bellagio/package.nix +++ b/pkgs/by-name/li/libomxil-bellagio/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { @@ -12,8 +13,9 @@ stdenv.mkDerivation rec { sha256 = "0k6p6h4npn8p1qlgq6z3jbfld6n1bqswzvxzndki937gr0lhfg2r"; }; - configureFlags = - lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ "ac_cv_func_malloc_0_nonnull=yes" ]; + configureFlags = lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "ac_cv_func_malloc_0_nonnull=yes" + ]; patches = [ ./fedora-fixes.patch @@ -34,10 +36,13 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = # stringop-truncation: see https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=1028978 - if stdenv.cc.isGNU then "-Wno-error=array-bounds -Wno-error=stringop-overflow=8 -Wno-error=stringop-truncation" - else let - isLLVM17 = stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17"; - in "-Wno-error=absolute-value -Wno-error=enum-conversion -Wno-error=logical-not-parentheses -Wno-error=non-literal-null-conversion${lib.optionalString (isLLVM17) " -Wno-error=unused-but-set-variable"}"; + if stdenv.cc.isGNU then + "-Wno-error=array-bounds -Wno-error=stringop-overflow=8 -Wno-error=stringop-truncation" + else + let + isLLVM17 = stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17"; + in + "-Wno-error=absolute-value -Wno-error=enum-conversion -Wno-error=logical-not-parentheses -Wno-error=non-literal-null-conversion${lib.optionalString (isLLVM17) " -Wno-error=unused-but-set-variable"}"; meta = with lib; { homepage = "https://omxil.sourceforge.net/"; diff --git a/pkgs/by-name/li/libopenaptx/package.nix b/pkgs/by-name/li/libopenaptx/package.nix index 33a5cadb71ddd1..a4abae53381770 100644 --- a/pkgs/by-name/li/libopenaptx/package.nix +++ b/pkgs/by-name/li/libopenaptx/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "libopenaptx"; diff --git a/pkgs/by-name/li/libopenglrecorder/package.nix b/pkgs/by-name/li/libopenglrecorder/package.nix index 05616dd7c98426..8074cc066d741d 100644 --- a/pkgs/by-name/li/libopenglrecorder/package.nix +++ b/pkgs/by-name/li/libopenglrecorder/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, libjpeg -, libvpx -, openh264 -, withPulse ? stdenv.hostPlatform.isLinux -, libpulseaudio -, libvorbis +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + libjpeg, + libvpx, + openh264, + withPulse ? stdenv.hostPlatform.isLinux, + libpulseaudio, + libvorbis, }: stdenv.mkDerivation rec { @@ -27,14 +28,16 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - libjpeg - libvpx - openh264 - ] ++ lib.optionals withPulse [ - libpulseaudio - libvorbis - ]; + buildInputs = + [ + libjpeg + libvpx + openh264 + ] + ++ lib.optionals withPulse [ + libpulseaudio + libvorbis + ]; meta = with lib; { description = "Library allowing Optional async readback OpenGL frame buffer with optional audio recording"; diff --git a/pkgs/by-name/li/libopenmpt-modplug/package.nix b/pkgs/by-name/li/libopenmpt-modplug/package.nix index 50495d1633592d..4c7a9bf49e2198 100644 --- a/pkgs/by-name/li/libopenmpt-modplug/package.nix +++ b/pkgs/by-name/li/libopenmpt-modplug/package.nix @@ -1,16 +1,20 @@ -{ stdenv -, lib -, fetchurl -, autoreconfHook -, pkg-config -, libopenmpt +{ + stdenv, + lib, + fetchurl, + autoreconfHook, + pkg-config, + libopenmpt, }: stdenv.mkDerivation rec { pname = "libopenmpt-modplug"; version = "0.8.9.0-openmpt1"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "https://lib.openmpt.org/files/libopenmpt-modplug/libopenmpt-modplug-${version}.tar.gz"; diff --git a/pkgs/by-name/li/libopenraw/package.nix b/pkgs/by-name/li/libopenraw/package.nix index 80038929a3f1e7..bbf1bf94ef5a91 100644 --- a/pkgs/by-name/li/libopenraw/package.nix +++ b/pkgs/by-name/li/libopenraw/package.nix @@ -1,5 +1,16 @@ -{ stdenv, fetchurl, boost, gdk-pixbuf, glib, libjpeg, libxml2, lib, pkg-config -, cargo, rustc }: +{ + stdenv, + fetchurl, + boost, + gdk-pixbuf, + glib, + libjpeg, + libxml2, + lib, + pkg-config, + cargo, + rustc, +}: stdenv.mkDerivation rec { pname = "libopenraw"; @@ -10,9 +21,19 @@ stdenv.mkDerivation rec { hash = "sha256-VRWyYQNh7zRYC2uXZjURn23ttPCnnVRmL6X+YYakXtU="; }; - nativeBuildInputs = [ pkg-config cargo rustc ]; + nativeBuildInputs = [ + pkg-config + cargo + rustc + ]; - buildInputs = [ boost gdk-pixbuf glib libjpeg libxml2 ]; + buildInputs = [ + boost + gdk-pixbuf + glib + libjpeg + libxml2 + ]; postPatch = '' sed -i configure{,.ac} \ @@ -23,7 +44,10 @@ stdenv.mkDerivation rec { description = "RAW camerafile decoding library"; homepage = "https://libopenraw.freedesktop.org"; license = licenses.lgpl3Plus; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; maintainers = [ maintainers.struan ]; }; } diff --git a/pkgs/by-name/li/libopensmtpd/package.nix b/pkgs/by-name/li/libopensmtpd/package.nix index e9abdf0864f2d4..b4229e69ba91e4 100644 --- a/pkgs/by-name/li/libopensmtpd/package.nix +++ b/pkgs/by-name/li/libopensmtpd/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, libevent -, mandoc +{ + lib, + stdenv, + fetchurl, + libevent, + mandoc, }: stdenv.mkDerivation rec { pname = "libopensmtpd"; diff --git a/pkgs/by-name/li/liboping/package.nix b/pkgs/by-name/li/liboping/package.nix index 118f283a0f9f44..fefd39aee363f0 100644 --- a/pkgs/by-name/li/liboping/package.nix +++ b/pkgs/by-name/li/liboping/package.nix @@ -1,4 +1,11 @@ -{ stdenv, fetchurl, fetchpatch, ncurses ? null, perl ? null, lib }: +{ + stdenv, + fetchurl, + fetchpatch, + ncurses ? null, + perl ? null, + lib, +}: stdenv.mkDerivation rec { pname = "liboping"; @@ -23,10 +30,12 @@ stdenv.mkDerivation rec { }) ]; - env.NIX_CFLAGS_COMPILE = lib.optionalString - stdenv.cc.isGNU "-Wno-error=format-truncation"; + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isGNU "-Wno-error=format-truncation"; - buildInputs = [ ncurses perl ]; + buildInputs = [ + ncurses + perl + ]; configureFlags = lib.optional (perl == null) "--with-perl-bindings=no"; diff --git a/pkgs/by-name/li/libopus/package.nix b/pkgs/by-name/li/libopus/package.nix index f809c40000e957..ec138dc62b8109 100644 --- a/pkgs/by-name/li/libopus/package.nix +++ b/pkgs/by-name/li/libopus/package.nix @@ -78,6 +78,9 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://gitlab.xiph.org/xiph/opus/-/releases/v${finalAttrs.version}"; license = lib.licenses.bsd3; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ getchoo jopejoe1 ]; + maintainers = with lib.maintainers; [ + getchoo + jopejoe1 + ]; }; }) diff --git a/pkgs/by-name/li/libopusenc/package.nix b/pkgs/by-name/li/libopusenc/package.nix index bd749616cc477b..0c5ee795ad626b 100644 --- a/pkgs/by-name/li/libopusenc/package.nix +++ b/pkgs/by-name/li/libopusenc/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libopus }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libopus, +}: stdenv.mkDerivation rec { pname = "libopusenc"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1ffb0vhlymlsq70pxsjj0ksz77yfm2x0a1x8q50kxmnkm1hxp642"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; doCheck = true; diff --git a/pkgs/by-name/li/liboqs/package.nix b/pkgs/by-name/li/liboqs/package.nix index 5da88f18169a6d..ac45816ce2e9d6 100644 --- a/pkgs/by-name/li/liboqs/package.nix +++ b/pkgs/by-name/li/liboqs/package.nix @@ -41,7 +41,10 @@ stdenv.mkDerivation (finalAttrs: { dontFixCmake = true; # fix CMake file will give an error - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = with lib; { description = "C library for prototyping and experimenting with quantum-resistant cryptography"; diff --git a/pkgs/by-name/li/liborcus/package.nix b/pkgs/by-name/li/liborcus/package.nix index 14f2023fc1eea9..4e3a48d10b8b63 100644 --- a/pkgs/by-name/li/liborcus/package.nix +++ b/pkgs/by-name/li/liborcus/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitLab -, autoreconfHook -, pkg-config -, boost -, libixion -, mdds -, python3 -, zlib +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + boost, + libixion, + mdds, + python3, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libosinfo/package.nix b/pkgs/by-name/li/libosinfo/package.nix index 498f26a7caf09e..93cb538b59093b 100644 --- a/pkgs/by-name/li/libosinfo/package.nix +++ b/pkgs/by-name/li/libosinfo/package.nix @@ -1,24 +1,26 @@ -{ lib, stdenv -, fetchurl -, fetchpatch -, pkg-config -, meson -, ninja -, gettext -, gobject-introspection -, gtk-doc -, docbook_xsl -, glib -, libsoup_3 -, libxml2 -, libxslt -, check -, curl -, perl -, hwdata -, osinfo-db -, substituteAll -, vala ? null +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + meson, + ninja, + gettext, + gobject-introspection, + gtk-doc, + docbook_xsl, + glib, + libsoup_3, + libxml2, + libxslt, + check, + curl, + perl, + hwdata, + osinfo-db, + substituteAll, + vala ? null, }: stdenv.mkDerivation rec { @@ -30,8 +32,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-G/lu7J4UYPPRpxMWPMof8NSAo0kLUImSkvFFSLOpa2A="; }; - outputs = [ "out" "dev" ] - ++ lib.optional (stdenv.hostPlatform == stdenv.buildPlatform) "devdoc"; + outputs = [ + "out" + "dev" + ] ++ lib.optional (stdenv.hostPlatform == stdenv.buildPlatform) "devdoc"; nativeBuildInputs = [ pkg-config diff --git a/pkgs/by-name/li/libosip/package.nix b/pkgs/by-name/li/libosip/package.nix index d552bedaa4f917..a7bf8e5e0a3101 100644 --- a/pkgs/by-name/li/libosip/package.nix +++ b/pkgs/by-name/li/libosip/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "5.3.1"; src = fetchurl { diff --git a/pkgs/by-name/li/libosmium/package.nix b/pkgs/by-name/li/libosmium/package.nix index 211ca0559b9a84..77a269650c5999 100644 --- a/pkgs/by-name/li/libosmium/package.nix +++ b/pkgs/by-name/li/libosmium/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, cmake, protozero, expat, zlib, bzip2, boost, lz4 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + protozero, + expat, + zlib, + bzip2, + boost, + lz4, +}: stdenv.mkDerivation rec { pname = "libosmium"; @@ -13,7 +24,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ protozero zlib bzip2 expat boost lz4 ]; + buildInputs = [ + protozero + zlib + bzip2 + expat + boost + lz4 + ]; cmakeFlags = [ "-DINSTALL_GDALCPP:BOOL=ON" ]; diff --git a/pkgs/by-name/li/libosmo-netif/package.nix b/pkgs/by-name/li/libosmo-netif/package.nix index 5d8b0e2310f024..89505c6fec64d1 100644 --- a/pkgs/by-name/li/libosmo-netif/package.nix +++ b/pkgs/by-name/li/libosmo-netif/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, lksctp-tools -, pkg-config -, libosmocore +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + lksctp-tools, + pkg-config, + libosmocore, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libosmo-sccp/package.nix b/pkgs/by-name/li/libosmo-sccp/package.nix index 6226de5297cabb..1d11203f66520f 100644 --- a/pkgs/by-name/li/libosmo-sccp/package.nix +++ b/pkgs/by-name/li/libosmo-sccp/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, lksctp-tools -, pkg-config -, libosmocore -, libosmo-netif +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + lksctp-tools, + pkg-config, + libosmocore, + libosmo-netif, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libosmoabis/package.nix b/pkgs/by-name/li/libosmoabis/package.nix index 480eaa0cece5e0..53b4a63408ed5e 100644 --- a/pkgs/by-name/li/libosmoabis/package.nix +++ b/pkgs/by-name/li/libosmoabis/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, pkg-config -, libosmocore -, ortp -, bctoolbox +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + pkg-config, + libosmocore, + ortp, + bctoolbox, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libosmocore/package.nix b/pkgs/by-name/li/libosmocore/package.nix index b3fdd20cb77064..5085f9308f2497 100644 --- a/pkgs/by-name/li/libosmocore/package.nix +++ b/pkgs/by-name/li/libosmocore/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, gnutls -, libmnl -, liburing -, libusb1 -, lksctp-tools -, pcsclite -, pkg-config -, python3 -, talloc +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + gnutls, + libmnl, + liburing, + libusb1, + lksctp-tools, + pcsclite, + pkg-config, + python3, + talloc, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libossp_uuid/package.nix b/pkgs/by-name/li/libossp_uuid/package.nix index 267829d2aee429..a04339778f0581 100644 --- a/pkgs/by-name/li/libossp_uuid/package.nix +++ b/pkgs/by-name/li/libossp_uuid/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libossp-uuid"; @@ -6,7 +10,7 @@ stdenv.mkDerivation rec { src = fetchurl { url = "ftp://ftp.ossp.org/pkg/lib/uuid/uuid-${version}.tar.gz"; - sha256= "11a615225baa5f8bb686824423f50e4427acd3f70d394765bdff32801f0fd5b0"; + sha256 = "11a615225baa5f8bb686824423f50e4427acd3f70d394765bdff32801f0fd5b0"; }; configureFlags = [ @@ -18,28 +22,27 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "http://www.ossp.org/pkg/lib/uuid/"; description = "OSSP uuid ISO-C and C++ shared library"; - longDescription = - '' - OSSP uuid is a ISO-C:1999 application programming interface - (API) and corresponding command line interface (CLI) for the - generation of DCE 1.1, ISO/IEC 11578:1996 and RFC 4122 - compliant Universally Unique Identifier (UUID). It supports - DCE 1.1 variant UUIDs of version 1 (time and node based), - version 3 (name based, MD5), version 4 (random number based) - and version 5 (name based, SHA-1). Additional API bindings are - provided for the languages ISO-C++:1998, Perl:5 and - PHP:4/5. Optional backward compatibility exists for the ISO-C - DCE-1.1 and Perl Data::UUID APIs. + longDescription = '' + OSSP uuid is a ISO-C:1999 application programming interface + (API) and corresponding command line interface (CLI) for the + generation of DCE 1.1, ISO/IEC 11578:1996 and RFC 4122 + compliant Universally Unique Identifier (UUID). It supports + DCE 1.1 variant UUIDs of version 1 (time and node based), + version 3 (name based, MD5), version 4 (random number based) + and version 5 (name based, SHA-1). Additional API bindings are + provided for the languages ISO-C++:1998, Perl:5 and + PHP:4/5. Optional backward compatibility exists for the ISO-C + DCE-1.1 and Perl Data::UUID APIs. - UUIDs are 128 bit numbers which are intended to have a high - likelihood of uniqueness over space and time and are - computationally difficult to guess. They are globally unique - identifiers which can be locally generated without contacting - a global registration authority. UUIDs are intended as unique - identifiers for both mass tagging objects with an extremely - short lifetime and to reliably identifying very persistent - objects across a network. - ''; + UUIDs are 128 bit numbers which are intended to have a high + likelihood of uniqueness over space and time and are + computationally difficult to guess. They are globally unique + identifiers which can be locally generated without contacting + a global registration authority. UUIDs are intended as unique + identifiers for both mass tagging objects with an extremely + short lifetime and to reliably identifying very persistent + objects across a network. + ''; license = licenses.bsd2; platforms = platforms.all; }; diff --git a/pkgs/by-name/li/libotr/package.nix b/pkgs/by-name/li/libotr/package.nix index 672d298f14468b..8a668e04959601 100644 --- a/pkgs/by-name/li/libotr/package.nix +++ b/pkgs/by-name/li/libotr/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkgsHostTarget, libgcrypt, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + pkgsHostTarget, + libgcrypt, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libotr"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { patches = [ ./fix-regtest-client.patch ]; - outputs = [ "bin" "out" "dev" ]; + outputs = [ + "bin" + "out" + "dev" + ]; nativeBuildInputs = [ autoreconfHook diff --git a/pkgs/by-name/li/libow/package.nix b/pkgs/by-name/li/libow/package.nix index 5340caeff0a8eb..b8b86b0321b385 100644 --- a/pkgs/by-name/li/libow/package.nix +++ b/pkgs/by-name/li/libow/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, pkg-config, libtool }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + pkg-config, + libtool, +}: stdenv.mkDerivation rec { version = "3.2p4"; @@ -11,7 +19,12 @@ stdenv.mkDerivation rec { sha256 = "0dln1ar7bxwhpi36sccmpwapy7iz4j097rbf02mgn42lw5vrcg3s"; }; - nativeBuildInputs = [ autoconf automake libtool pkg-config ]; + nativeBuildInputs = [ + autoconf + automake + libtool + pkg-config + ]; preConfigure = '' # Tries to use glibtoolize on Darwin, but it shouldn't for Nix. diff --git a/pkgs/by-name/li/libowlevelzs/package.nix b/pkgs/by-name/li/libowlevelzs/package.nix index 6199dcca1bb843..6bc0c5fa5371e4 100644 --- a/pkgs/by-name/li/libowlevelzs/package.nix +++ b/pkgs/by-name/li/libowlevelzs/package.nix @@ -1,7 +1,8 @@ -{ cmake -, fetchFromGitHub -, lib -, stdenv +{ + cmake, + fetchFromGitHub, + lib, + stdenv, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libp11/package.nix b/pkgs/by-name/li/libp11/package.nix index 69eb2fb63394d8..5bfaffacfb10db 100644 --- a/pkgs/by-name/li/libp11/package.nix +++ b/pkgs/by-name/li/libp11/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libtool, pkg-config -, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libtool, + pkg-config, + openssl, +}: stdenv.mkDerivation rec { pname = "libp11"; @@ -16,7 +23,11 @@ stdenv.mkDerivation rec { "--with-enginesdir=${placeholder "out"}/lib/engines" ]; - nativeBuildInputs = [ autoreconfHook pkg-config libtool ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + libtool + ]; buildInputs = [ openssl ]; diff --git a/pkgs/by-name/li/libpaper/package.nix b/pkgs/by-name/li/libpaper/package.nix index 9e36812e7e8976..452d787318ce1c 100644 --- a/pkgs/by-name/li/libpaper/package.nix +++ b/pkgs/by-name/li/libpaper/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation rec { version = "1.1.29"; diff --git a/pkgs/by-name/li/libpar2/package.nix b/pkgs/by-name/li/libpar2/package.nix index 7def28b9246038..1745aae945d75c 100644 --- a/pkgs/by-name/li/libpar2/package.nix +++ b/pkgs/by-name/li/libpar2/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libsigcxx }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libsigcxx, +}: stdenv.mkDerivation rec { pname = "libpar2"; diff --git a/pkgs/by-name/li/libpcap/package.nix b/pkgs/by-name/li/libpcap/package.nix index 0825ea3681e5ed..72996ff96cef1b 100644 --- a/pkgs/by-name/li/libpcap/package.nix +++ b/pkgs/by-name/li/libpcap/package.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchurl -, flex -, bison -, bluez -, libnl -, libxcrypt -, pkg-config -, withBluez ? false -, withRemote ? false +{ + lib, + stdenv, + fetchurl, + flex, + bison, + bluez, + libnl, + libxcrypt, + pkg-config, + withBluez ? false, + withRemote ? false, -# for passthru.tests -, ettercap -, nmap -, ostinato -, tcpreplay -, vde2 -, wireshark -, python3 -, haskellPackages + # for passthru.tests + ettercap, + nmap, + ostinato, + tcpreplay, + vde2, + wireshark, + python3, + haskellPackages, }: stdenv.mkDerivation rec { @@ -30,23 +31,31 @@ stdenv.mkDerivation rec { hash = "sha256-N87ZChmjAqfzLkWCJKAMNlwReQXCzTWsVEtogKgUiPA="; }; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libnl ] + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ libnl ] ++ lib.optionals withRemote [ libxcrypt ]; - nativeBuildInputs = [ flex bison ] + nativeBuildInputs = + [ + flex + bison + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ] ++ lib.optionals withBluez [ bluez.dev ]; # We need to force the autodetection because detection doesn't # work in pure build environments. - configureFlags = [ - "--with-pcap=${if stdenv.hostPlatform.isLinux then "linux" else "bpf"}" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "--disable-universal" - ] ++ lib.optionals withRemote [ - "--enable-remote" - ] ++ lib.optionals (stdenv.hostPlatform == stdenv.buildPlatform) - [ "ac_cv_linux_vers=2" ]; + configureFlags = + [ + "--with-pcap=${if stdenv.hostPlatform.isLinux then "linux" else "bpf"}" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "--disable-universal" + ] + ++ lib.optionals withRemote [ + "--enable-remote" + ] + ++ lib.optionals (stdenv.hostPlatform == stdenv.buildPlatform) [ "ac_cv_linux_vers=2" ]; postInstall = '' if [ "$dontDisableStatic" -ne "1" ]; then @@ -57,7 +66,14 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; passthru.tests = { - inherit ettercap nmap ostinato tcpreplay vde2 wireshark; + inherit + ettercap + nmap + ostinato + tcpreplay + vde2 + wireshark + ; inherit (python3.pkgs) pcapy-ng scapy; haskell-pcap = haskellPackages.pcap; }; diff --git a/pkgs/by-name/li/libpff/package.nix b/pkgs/by-name/li/libpff/package.nix index 62ee7c8f447c8c..31071f5ac9fb7d 100644 --- a/pkgs/by-name/li/libpff/package.nix +++ b/pkgs/by-name/li/libpff/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchzip -, pkg-config -, autoreconfHook +{ + stdenv, + lib, + fetchzip, + pkg-config, + autoreconfHook, }: stdenv.mkDerivation rec { @@ -14,8 +15,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-UmGRBgi78nDSuuOXi/WmODojWU5AbQGKNQwLseoh714="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - outputs = [ "bin" "dev" "out" ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + outputs = [ + "bin" + "dev" + "out" + ]; meta = { description = "Library and tools to access the Personal Folder File (PFF) and the Offline Folder File (OFF) format"; diff --git a/pkgs/by-name/li/libpfm/package.nix b/pkgs/by-name/li/libpfm/package.nix index 0598fd6451ef58..8e6b5bc50cfeb5 100644 --- a/pkgs/by-name/li/libpfm/package.nix +++ b/pkgs/by-name/li/libpfm/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, enableShared ? !stdenv.hostPlatform.isStatic -, windows +{ + lib, + stdenv, + fetchurl, + enableShared ? !stdenv.hostPlatform.isStatic, + windows, }: stdenv.mkDerivation (finalAttrs: { @@ -46,7 +47,10 @@ stdenv.mkDerivation (finalAttrs: { (PMU) of modern processors. ''; license = licenses.gpl2; - maintainers = with maintainers; [ pierron t4ccer ]; + maintainers = with maintainers; [ + pierron + t4ccer + ]; platforms = platforms.linux ++ platforms.windows; }; }) diff --git a/pkgs/by-name/li/libpgf/package.nix b/pkgs/by-name/li/libpgf/package.nix index c0d24cb3cdf591..0a7dafddd2425c 100644 --- a/pkgs/by-name/li/libpgf/package.nix +++ b/pkgs/by-name/li/libpgf/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchzip -, autoreconfHook -, dos2unix +{ + lib, + stdenv, + fetchzip, + autoreconfHook, + dos2unix, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libpinyin/package.nix b/pkgs/by-name/li/libpinyin/package.nix index 2ae333d61ad885..9df54306930b8c 100644 --- a/pkgs/by-name/li/libpinyin/package.nix +++ b/pkgs/by-name/li/libpinyin/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitHub -, autoreconfHook -, glib -, db -, pkg-config +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + autoreconfHook, + glib, + db, + pkg-config, }: let @@ -45,7 +46,10 @@ stdenv.mkDerivation rec { description = "Library for intelligent sentence-based Chinese pinyin input method"; homepage = "https://github.com/libpinyin/libpinyin"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ linsui ericsagnes ]; + maintainers = with maintainers; [ + linsui + ericsagnes + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/li/libpipeline/package.nix b/pkgs/by-name/li/libpipeline/package.nix index 36ce1ceea9f5f1..3ae4568451f837 100644 --- a/pkgs/by-name/li/libpipeline/package.nix +++ b/pkgs/by-name/li/libpipeline/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, updateAutotoolsGnuConfigScriptsHook }: +{ + lib, + stdenv, + fetchurl, + updateAutotoolsGnuConfigScriptsHook, +}: stdenv.mkDerivation rec { pname = "libpipeline"; diff --git a/pkgs/by-name/li/libpkgconf/package.nix b/pkgs/by-name/li/libpkgconf/package.nix index 34d718762cd1f8..fb9e541fb242bc 100644 --- a/pkgs/by-name/li/libpkgconf/package.nix +++ b/pkgs/by-name/li/libpkgconf/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, removeReferencesTo -, gitUpdater +{ + lib, + stdenv, + fetchurl, + removeReferencesTo, + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { @@ -14,7 +15,13 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-OpCArFHQNhXnwZEKCiqN8IQkiStfE7BiiiBNP8zg6os="; }; - outputs = [ "out" "lib" "dev" "man" "doc" ]; + outputs = [ + "out" + "lib" + "dev" + "man" + "doc" + ]; nativeBuildInputs = [ removeReferencesTo ]; @@ -23,23 +30,24 @@ stdenv.mkDerivation (finalAttrs: { # Debian has outputs like these too # (https://packages.debian.org/source/bullseye/pkgconf), so it is safe to # remove those references - postFixup = '' - remove-references-to \ - -t "${placeholder "out"}" \ - "${placeholder "lib"}"/lib/* - remove-references-to \ - -t "${placeholder "dev"}" \ - "${placeholder "lib"}"/lib/* \ - "${placeholder "out"}"/bin/* - '' - # Move back share/aclocal. Yes, this normally goes in the dev output for good - # reason, but in this case the dev output is for the `libpkgconf` library, - # while the aclocal stuff is for the tool. The tool is already for use during - # development, so there is no reason to have separate "dev-bin" and "dev-lib" - # outputs or something. - + '' - mv ${placeholder "dev"}/share ${placeholder "out"} - ''; + postFixup = + '' + remove-references-to \ + -t "${placeholder "out"}" \ + "${placeholder "lib"}"/lib/* + remove-references-to \ + -t "${placeholder "dev"}" \ + "${placeholder "lib"}"/lib/* \ + "${placeholder "out"}"/bin/* + '' + # Move back share/aclocal. Yes, this normally goes in the dev output for good + # reason, but in this case the dev output is for the `libpkgconf` library, + # while the aclocal stuff is for the tool. The tool is already for use during + # development, so there is no reason to have separate "dev-bin" and "dev-lib" + # outputs or something. + + '' + mv ${placeholder "dev"}/share ${placeholder "out"} + ''; passthru.updateScript = gitUpdater { url = "https://gitea.treehouse.systems/ariadne/pkgconf"; @@ -61,7 +69,10 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://gitea.treehouse.systems/ariadne/pkgconf/src/tag/pkgconf-${finalAttrs.version}/NEWS"; license = lib.licenses.isc; mainProgram = "pkgconf"; - maintainers = with lib.maintainers; [ zaninime AndersonTorres ]; + maintainers = with lib.maintainers; [ + zaninime + AndersonTorres + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/by-name/li/libplacebo/package.nix b/pkgs/by-name/li/libplacebo/package.nix index 159037bec832c6..d4fd402b565852 100644 --- a/pkgs/by-name/li/libplacebo/package.nix +++ b/pkgs/by-name/li/libplacebo/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, python3Packages -, vulkan-headers -, vulkan-loader -, shaderc -, lcms2 -, libGL -, libX11 -, libunwind -, libdovi -, xxHash -, fast-float -, vulkanSupport ? true +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + python3Packages, + vulkan-headers, + vulkan-loader, + shaderc, + lcms2, + libGL, + libX11, + libunwind, + libdovi, + xxHash, + fast-float, + vulkanSupport ? true, }: stdenv.mkDerivation rec { @@ -38,30 +39,35 @@ stdenv.mkDerivation rec { python3Packages.glad2 ]; - buildInputs = [ - shaderc - lcms2 - libGL - libX11 - libunwind - libdovi - xxHash - vulkan-headers - ] ++ lib.optionals vulkanSupport [ - vulkan-loader - ] ++ lib.optionals (!stdenv.cc.isGNU) [ - fast-float - ]; + buildInputs = + [ + shaderc + lcms2 + libGL + libX11 + libunwind + libdovi + xxHash + vulkan-headers + ] + ++ lib.optionals vulkanSupport [ + vulkan-loader + ] + ++ lib.optionals (!stdenv.cc.isGNU) [ + fast-float + ]; - mesonFlags = [ - (lib.mesonBool "demos" false) # Don't build and install the demo programs - (lib.mesonEnable "d3d11" false) # Disable the Direct3D 11 based renderer - (lib.mesonEnable "glslang" false) # rely on shaderc for GLSL compilation instead - (lib.mesonEnable "vk-proc-addr" vulkanSupport) - (lib.mesonOption "vulkan-registry" "${vulkan-headers}/share/vulkan/registry/vk.xml") - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - (lib.mesonEnable "unwind" false) # libplacebo doesn’t build with `darwin.libunwind` - ]; + mesonFlags = + [ + (lib.mesonBool "demos" false) # Don't build and install the demo programs + (lib.mesonEnable "d3d11" false) # Disable the Direct3D 11 based renderer + (lib.mesonEnable "glslang" false) # rely on shaderc for GLSL compilation instead + (lib.mesonEnable "vk-proc-addr" vulkanSupport) + (lib.mesonOption "vulkan-registry" "${vulkan-headers}/share/vulkan/registry/vk.xml") + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + (lib.mesonEnable "unwind" false) # libplacebo doesn’t build with `darwin.libunwind` + ]; postPatch = '' substituteInPlace meson.build \ diff --git a/pkgs/by-name/li/libplacebo_5/package.nix b/pkgs/by-name/li/libplacebo_5/package.nix index e75d44dcdf265f..f4f9286b9fbc93 100644 --- a/pkgs/by-name/li/libplacebo_5/package.nix +++ b/pkgs/by-name/li/libplacebo_5/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, python3Packages -, vulkan-headers -, vulkan-loader -, shaderc -, lcms2 -, libGL -, libX11 -, libunwind -, libdovi +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + python3Packages, + vulkan-headers, + vulkan-loader, + shaderc, + lcms2, + libGL, + libX11, + libunwind, + libdovi, }: stdenv.mkDerivation rec { @@ -46,14 +47,16 @@ stdenv.mkDerivation rec { libdovi ]; - mesonFlags = [ - (lib.mesonOption "vulkan-registry" "${vulkan-headers}/share/vulkan/registry/vk.xml") - (lib.mesonBool "demos" false) # Don't build and install the demo programs - (lib.mesonEnable "d3d11" false) # Disable the Direct3D 11 based renderer - (lib.mesonEnable "glslang" false) # rely on shaderc for GLSL compilation instead - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - (lib.mesonEnable "unwind" false) # libplacebo doesn’t build with `darwin.libunwind` - ]; + mesonFlags = + [ + (lib.mesonOption "vulkan-registry" "${vulkan-headers}/share/vulkan/registry/vk.xml") + (lib.mesonBool "demos" false) # Don't build and install the demo programs + (lib.mesonEnable "d3d11" false) # Disable the Direct3D 11 based renderer + (lib.mesonEnable "glslang" false) # rely on shaderc for GLSL compilation instead + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + (lib.mesonEnable "unwind" false) # libplacebo doesn’t build with `darwin.libunwind` + ]; postPatch = '' substituteInPlace meson.build \ diff --git a/pkgs/by-name/li/libplctag/package.nix b/pkgs/by-name/li/libplctag/package.nix index 994cf0fef05ce9..3c6548073e0472 100644 --- a/pkgs/by-name/li/libplctag/package.nix +++ b/pkgs/by-name/li/libplctag/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub +{ + lib, + stdenv, + cmake, + fetchFromGitHub, }: stdenv.mkDerivation rec { @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/libplctag/libplctag"; description = "Library that uses EtherNet/IP or Modbus TCP to read and write tags in PLCs"; - license = with licenses; [ lgpl2Plus mpl20 ]; + license = with licenses; [ + lgpl2Plus + mpl20 + ]; maintainers = with maintainers; [ petterstorvik ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/li/libplist/package.nix b/pkgs/by-name/li/libplist/package.nix index eeabf62e1c8144..1405fc7d7f802b 100644 --- a/pkgs/by-name/li/libplist/package.nix +++ b/pkgs/by-name/li/libplist/package.nix @@ -1,18 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config - -, enablePython ? false -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + + enablePython ? false, + python3, }: stdenv.mkDerivation rec { pname = "libplist"; version = "2.6.0"; - outputs = [ "bin" "dev" "out" ] ++ lib.optional enablePython "py"; + outputs = [ + "bin" + "dev" + "out" + ] ++ lib.optional enablePython "py"; src = fetchFromGitHub { owner = "libimobiledevice"; @@ -35,11 +40,13 @@ stdenv.mkDerivation rec { export RELEASE_VERSION=${version} ''; - configureFlags = [ - "--enable-debug" - ] ++ lib.optionals (!enablePython) [ - "--without-cython" - ]; + configureFlags = + [ + "--enable-debug" + ] + ++ lib.optionals (!enablePython) [ + "--without-cython" + ]; doCheck = true; diff --git a/pkgs/by-name/li/libpointmatcher/package.nix b/pkgs/by-name/li/libpointmatcher/package.nix index 57c629783aa6fe..19ce98dec5cfd8 100644 --- a/pkgs/by-name/li/libpointmatcher/package.nix +++ b/pkgs/by-name/li/libpointmatcher/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, eigen, boost, libnabo, yaml-cpp }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + eigen, + boost, + libnabo, + yaml-cpp, +}: stdenv.mkDerivation rec { pname = "libpointmatcher"; @@ -12,7 +21,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ eigen boost libnabo yaml-cpp ]; + buildInputs = [ + eigen + boost + libnabo + yaml-cpp + ]; cmakeFlags = [ (lib.cmakeFeature "EIGEN_INCLUDE_DIR" "${eigen}/include/eigen3") diff --git a/pkgs/by-name/li/libpoly/package.nix b/pkgs/by-name/li/libpoly/package.nix index e54f822921ca0d..f11ce14ce59d79 100644 --- a/pkgs/by-name/li/libpoly/package.nix +++ b/pkgs/by-name/li/libpoly/package.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchFromGitHub, gmp, cmake, python3}: +{ + lib, + stdenv, + fetchFromGitHub, + gmp, + cmake, + python3, +}: stdenv.mkDerivation rec { pname = "libpoly"; @@ -14,7 +21,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ gmp python3 ]; + buildInputs = [ + gmp + python3 + ]; strictDeps = true; diff --git a/pkgs/by-name/li/libpseudo/package.nix b/pkgs/by-name/li/libpseudo/package.nix index 58931a8161886e..23dd33253eda8c 100644 --- a/pkgs/by-name/li/libpseudo/package.nix +++ b/pkgs/by-name/li/libpseudo/package.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchurl, pkg-config, glib, ncurses}: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + ncurses, +}: stdenv.mkDerivation rec { pname = "libpseudo"; version = "1.2.0"; @@ -18,7 +25,10 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib ncurses ]; + buildInputs = [ + glib + ncurses + ]; meta = with lib; { homepage = "http://libpseudo.sourceforge.net/"; diff --git a/pkgs/by-name/li/libpsm2/package.nix b/pkgs/by-name/li/libpsm2/package.nix index ee47968352ae4a..e7591afaf2b93b 100644 --- a/pkgs/by-name/li/libpsm2/package.nix +++ b/pkgs/by-name/li/libpsm2/package.nix @@ -1,10 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, numactl, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + numactl, + pkg-config, +}: stdenv.mkDerivation rec { pname = "libpsm2"; version = "12.0.1"; - preConfigure= '' + preConfigure = '' export UDEVDIR=$out/etc/udev substituteInPlace ./Makefile --replace "udevrulesdir}" "prefix}/etc/udev"; ''; @@ -41,7 +47,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/intel/opa-psm2"; description = "PSM2 library supports a number of fabric media and stacks"; - license = with licenses; [ gpl2Only bsd3 ]; + license = with licenses; [ + gpl2Only + bsd3 + ]; platforms = [ "x86_64-linux" ]; maintainers = [ maintainers.bzizou ]; }; diff --git a/pkgs/by-name/li/libpst/package.nix b/pkgs/by-name/li/libpst/package.nix index a608b6741b0c07..aa52e2daa378e9 100644 --- a/pkgs/by-name/li/libpst/package.nix +++ b/pkgs/by-name/li/libpst/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, bzip2 -, doxygen -, gettext -, imagemagick -, libgsf -, pkg-config -, xmlto +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + bzip2, + doxygen, + gettext, + imagemagick, + libgsf, + pkg-config, + xmlto, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/libptytty/package.nix b/pkgs/by-name/li/libptytty/package.nix index 3ed0cf6a39d0c0..e9da99ff565d56 100644 --- a/pkgs/by-name/li/libptytty/package.nix +++ b/pkgs/by-name/li/libptytty/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchurl -, cmake +{ + stdenv, + lib, + fetchurl, + cmake, }: let @@ -21,7 +22,8 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - cmakeFlags = lib.optional isStatic "-DBUILD_SHARED_LIBS=OFF" + cmakeFlags = + lib.optional isStatic "-DBUILD_SHARED_LIBS=OFF" ++ lib.optional (isCross || isStatic) "-DTTY_GID_SUPPORT=OFF" # Musl lacks UTMP/WTMP built-in support ++ lib.optionals isMusl [ diff --git a/pkgs/by-name/li/libqalculate/package.nix b/pkgs/by-name/li/libqalculate/package.nix index 6a7072f850fc8f..c3b24c9ef91a3b 100644 --- a/pkgs/by-name/li/libqalculate/package.nix +++ b/pkgs/by-name/li/libqalculate/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, intltool -, pkg-config -, doxygen -, autoreconfHook -, buildPackages -, curl -, gettext -, libiconv -, readline -, libxml2 -, mpfr -, icu -, gnuplot +{ + lib, + stdenv, + fetchFromGitHub, + intltool, + pkg-config, + doxygen, + autoreconfHook, + buildPackages, + curl, + gettext, + libiconv, + readline, + libxml2, + mpfr, + icu, + gnuplot, }: stdenv.mkDerivation (finalAttrs: { @@ -27,7 +28,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-IatxsbSKoLwG6yXCFtejUTl48gIis76rLeULc2+aktk="; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; nativeBuildInputs = [ intltool @@ -56,14 +61,16 @@ stdenv.mkDerivation (finalAttrs: { intltoolize -f ''; - patchPhase = '' - substituteInPlace libqalculate/Calculator-plot.cc \ - --replace 'commandline = "gnuplot"' 'commandline = "${gnuplot}/bin/gnuplot"' \ - --replace '"gnuplot - ' '"${gnuplot}/bin/gnuplot - ' - '' + lib.optionalString stdenv.cc.isClang '' - substituteInPlace src/qalc.cc \ - --replace 'printf(_("aborted"))' 'printf("%s", _("aborted"))' - ''; + patchPhase = + '' + substituteInPlace libqalculate/Calculator-plot.cc \ + --replace 'commandline = "gnuplot"' 'commandline = "${gnuplot}/bin/gnuplot"' \ + --replace '"gnuplot - ' '"${gnuplot}/bin/gnuplot - ' + '' + + lib.optionalString stdenv.cc.isClang '' + substituteInPlace src/qalc.cc \ + --replace 'printf(_("aborted"))' 'printf("%s", _("aborted"))' + ''; preBuild = '' pushd docs/reference @@ -75,7 +82,11 @@ stdenv.mkDerivation (finalAttrs: { description = "Advanced calculator library"; homepage = "http://qalculate.github.io"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ gebner doronbehar alyaeanyx ]; + maintainers = with maintainers; [ + gebner + doronbehar + alyaeanyx + ]; mainProgram = "qalc"; platforms = platforms.all; }; diff --git a/pkgs/by-name/li/libqb/package.nix b/pkgs/by-name/li/libqb/package.nix index 080078d2b7fac8..094a1c53790f80 100644 --- a/pkgs/by-name/li/libqb/package.nix +++ b/pkgs/by-name/li/libqb/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, pkg-config, libxml2 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + libxml2, +}: stdenv.mkDerivation rec { pname = "libqb"; @@ -19,7 +27,10 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libxml2 ]; diff --git a/pkgs/by-name/li/libqmi/package.nix b/pkgs/by-name/li/libqmi/package.nix index 58fadd30ee8d57..1bd3a50715efee 100644 --- a/pkgs/by-name/li/libqmi/package.nix +++ b/pkgs/by-name/li/libqmi/package.nix @@ -1,32 +1,37 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, gobject-introspection -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_43 -, help2man -, glib -, python3 -, mesonEmulatorHook -, libgudev -, bash-completion -, libmbim -, libqrtr-glib -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, withMan ? stdenv.buildPlatform.canExecute stdenv.hostPlatform +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + gobject-introspection, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_43, + help2man, + glib, + python3, + mesonEmulatorHook, + libgudev, + bash-completion, + libmbim, + libqrtr-glib, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + withMan ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, }: stdenv.mkDerivation rec { pname = "libqmi"; version = "1.34.0"; - outputs = [ "out" "dev" ] - ++ lib.optional withIntrospection "devdoc"; + outputs = [ + "out" + "dev" + ] ++ lib.optional withIntrospection "devdoc"; src = fetchFromGitLab { domain = "gitlab.freedesktop.org"; @@ -36,34 +41,42 @@ stdenv.mkDerivation rec { hash = "sha256-l9ev9ZOWicVNZ/Wj//KNd3NHcefIrLVriqJhEpwWvtQ="; }; - nativeBuildInputs = [ - meson - ninja - pkg-config - python3 - ] ++ lib.optionals withMan [ - help2man - ] ++ lib.optionals withIntrospection [ - gobject-introspection - gtk-doc - docbook-xsl-nons - docbook_xml_dtd_43 - ] ++ lib.optionals (withIntrospection && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + python3 + ] + ++ lib.optionals withMan [ + help2man + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + gtk-doc + docbook-xsl-nons + docbook_xml_dtd_43 + ] + ++ lib.optionals (withIntrospection && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; - buildInputs = [ - bash-completion - libmbim - ] ++ lib.optionals withIntrospection [ - libgudev - ]; + buildInputs = + [ + bash-completion + libmbim + ] + ++ lib.optionals withIntrospection [ + libgudev + ]; - propagatedBuildInputs = [ - glib - ] ++ lib.optionals withIntrospection [ - libqrtr-glib - ]; + propagatedBuildInputs = + [ + glib + ] + ++ lib.optionals withIntrospection [ + libqrtr-glib + ]; mesonFlags = [ "-Dudevdir=${placeholder "out"}/lib/udev" diff --git a/pkgs/by-name/li/libqrtr-glib/package.nix b/pkgs/by-name/li/libqrtr-glib/package.nix index 9309c48a8c6a75..852d76906a66d4 100644 --- a/pkgs/by-name/li/libqrtr-glib/package.nix +++ b/pkgs/by-name/li/libqrtr-glib/package.nix @@ -1,22 +1,27 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, gobject-introspection -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_43 -, glib +{ + lib, + stdenv, + fetchFromGitLab, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + gobject-introspection, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_43, + glib, }: stdenv.mkDerivation rec { pname = "libqrtr-glib"; version = "1.2.2"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitLab { domain = "gitlab.freedesktop.org"; @@ -32,17 +37,19 @@ stdenv.mkDerivation rec { pkg-config ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - gobject-introspection - gtk-doc - docbook-xsl-nons - docbook_xml_dtd_43 - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gobject-introspection + gtk-doc + docbook-xsl-nons + docbook_xml_dtd_43 + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ glib diff --git a/pkgs/by-name/li/libr3/package.nix b/pkgs/by-name/li/libr3/package.nix index 78934bbdcfb89c..046547fdd053b8 100644 --- a/pkgs/by-name/li/libr3/package.nix +++ b/pkgs/by-name/li/libr3/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitHub -, pcre -, pkg-config -, check -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + pcre, + pkg-config, + check, + autoreconfHook, }: stdenv.mkDerivation rec { @@ -17,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "09cixbms817p6nb77wz3rxp0znnac8ybycvsrrzgwlbfn58a3zwl"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ check ]; propagatedBuildInputs = [ pcre ]; diff --git a/pkgs/by-name/li/libraqm/package.nix b/pkgs/by-name/li/libraqm/package.nix index 9899c70b8089e6..9df38707bcb342 100644 --- a/pkgs/by-name/li/libraqm/package.nix +++ b/pkgs/by-name/li/libraqm/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, meson -, ninja -, freetype -, harfbuzz -, fribidi +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + meson, + ninja, + freetype, + harfbuzz, + fribidi, }: stdenv.mkDerivation rec { @@ -20,9 +21,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-KhGE66GS5rIieVXJUFA3jSsXEpbdnzN0VIAF/zOelU4="; }; - buildInputs = [ freetype harfbuzz fribidi ]; + buildInputs = [ + freetype + harfbuzz + fribidi + ]; - nativeBuildInputs = [ pkg-config meson ninja ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + ]; doCheck = true; diff --git a/pkgs/by-name/li/libraspberrypi/package.nix b/pkgs/by-name/li/libraspberrypi/package.nix index bb7508b1cec5f1..3d66848f17731d 100644 --- a/pkgs/by-name/li/libraspberrypi/package.nix +++ b/pkgs/by-name/li/libraspberrypi/package.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, }: stdenv.mkDerivation rec { @@ -15,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha512-f7tBgIykcIdkwcFjBKk5ooD/5Bsyrd/0OFr7LNCwWFYeE4DH3XA7UR7YjArkwqUVCVBByr82EOaacw0g1blOkw=="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; cmakeFlags = [ # -DARM64=ON disables all targets that only build on 32-bit ARM; this allows # the package to build on aarch64 and other architectures @@ -27,7 +32,15 @@ stdenv.mkDerivation rec { description = "Userland tools & libraries for interfacing with Raspberry Pi hardware"; homepage = "https://github.com/raspberrypi/userland"; license = licenses.bsd3; - platforms = [ "armv6l-linux" "armv7l-linux" "aarch64-linux" "x86_64-linux" ]; - maintainers = with maintainers; [ dezgeg tkerber ]; + platforms = [ + "armv6l-linux" + "armv7l-linux" + "aarch64-linux" + "x86_64-linux" + ]; + maintainers = with maintainers; [ + dezgeg + tkerber + ]; }; } diff --git a/pkgs/by-name/li/libraw/package.nix b/pkgs/by-name/li/libraw/package.nix index 5c40666a21155e..7b63fb45435e70 100644 --- a/pkgs/by-name/li/libraw/package.nix +++ b/pkgs/by-name/li/libraw/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, lcms2 -, pkg-config - -# for passthru.tests -, deepin -, freeimage -, hdrmerge -, imagemagick -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + lcms2, + pkg-config, + + # for passthru.tests + deepin, + freeimage, + hdrmerge, + imagemagick, + python3, }: stdenv.mkDerivation rec { @@ -24,11 +25,19 @@ stdenv.mkDerivation rec { hash = "sha256-QFyRQ0V7din/rnkRvEWf521kSzN7HwJ3kZiQ43PAmVI="; }; - outputs = [ "out" "lib" "dev" "doc" ]; + outputs = [ + "out" + "lib" + "dev" + "doc" + ]; propagatedBuildInputs = [ lcms2 ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; enableParallelBuilding = true; @@ -41,8 +50,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Library for reading RAW files obtained from digital photo cameras (CRW/CR2, NEF, RAF, DNG, and others)"; homepage = "https://www.libraw.org/"; - license = with licenses; [ cddl lgpl2Plus ]; + license = with licenses; [ + cddl + lgpl2Plus + ]; platforms = platforms.unix; }; } - diff --git a/pkgs/by-name/li/libraw1394/package.nix b/pkgs/by-name/li/libraw1394/package.nix index 184cb2e7de4adf..628d10710e0f21 100644 --- a/pkgs/by-name/li/libraw1394/package.nix +++ b/pkgs/by-name/li/libraw1394/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libraw1394"; diff --git a/pkgs/by-name/li/librclone/package.nix b/pkgs/by-name/li/librclone/package.nix index bb3053e19d53be..3a526a83cae1b5 100644 --- a/pkgs/by-name/li/librclone/package.nix +++ b/pkgs/by-name/li/librclone/package.nix @@ -1,12 +1,14 @@ -{ lib -, stdenv -, buildGoModule -, rclone +{ + lib, + stdenv, + buildGoModule, + rclone, }: let ext = stdenv.hostPlatform.extensions.sharedLibrary; -in buildGoModule rec { +in +buildGoModule rec { pname = "librclone"; inherit (rclone) version src vendorHash; diff --git a/pkgs/by-name/li/librda/package.nix b/pkgs/by-name/li/librda/package.nix index 793783a2bae9eb..bcd94265fb162a 100644 --- a/pkgs/by-name/li/librda/package.nix +++ b/pkgs/by-name/li/librda/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, testers -, autoreconfHook -, glib -, gobject-introspection -, gtk3 -, intltool -, pkg-config +{ + stdenv, + lib, + fetchFromGitHub, + testers, + autoreconfHook, + glib, + gobject-introspection, + gtk3, + intltool, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/libre-baskerville/package.nix b/pkgs/by-name/li/libre-baskerville/package.nix index 0be599e281e950..848c2c009f0502 100644 --- a/pkgs/by-name/li/libre-baskerville/package.nix +++ b/pkgs/by-name/li/libre-baskerville/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "libre-baskerville"; diff --git a/pkgs/by-name/li/libre-bodoni/package.nix b/pkgs/by-name/li/libre-bodoni/package.nix index cd55c10d2e6422..46d8510ff56dcd 100644 --- a/pkgs/by-name/li/libre-bodoni/package.nix +++ b/pkgs/by-name/li/libre-bodoni/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "libre-bodoni"; diff --git a/pkgs/by-name/li/libre-caslon/package.nix b/pkgs/by-name/li/libre-caslon/package.nix index d89d4c41c0f3b9..6f766f2df98ad1 100644 --- a/pkgs/by-name/li/libre-caslon/package.nix +++ b/pkgs/by-name/li/libre-caslon/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "libre-caslon"; diff --git a/pkgs/by-name/li/libre-franklin/package.nix b/pkgs/by-name/li/libre-franklin/package.nix index c9b00888160024..2af58d8c92f15d 100644 --- a/pkgs/by-name/li/libre-franklin/package.nix +++ b/pkgs/by-name/li/libre-franklin/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "libre-franklin"; diff --git a/pkgs/by-name/li/libre-graph-api-cpp-qt-client/package.nix b/pkgs/by-name/li/libre-graph-api-cpp-qt-client/package.nix index 5fc90574d40f77..6619689d46b0f3 100644 --- a/pkgs/by-name/li/libre-graph-api-cpp-qt-client/package.nix +++ b/pkgs/by-name/li/libre-graph-api-cpp-qt-client/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qt6 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qt6, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/librearp-lv2/package.nix b/pkgs/by-name/li/librearp-lv2/package.nix index 82c78aa76d7ecf..c5a0cd73daf04e 100644 --- a/pkgs/by-name/li/librearp-lv2/package.nix +++ b/pkgs/by-name/li/librearp-lv2/package.nix @@ -1,6 +1,23 @@ -{ stdenv, lib, fetchFromGitLab, cmake, pkg-config, cairo, libxkbcommon -, xcbutilcursor, xcbutilkeysyms, xcbutil, libXrandr, libXinerama, libXcursor -, alsa-lib, libjack2, lv2, gcc-unwrapped, curl}: +{ + stdenv, + lib, + fetchFromGitLab, + cmake, + pkg-config, + cairo, + libxkbcommon, + xcbutilcursor, + xcbutilkeysyms, + xcbutil, + libXrandr, + libXinerama, + libXcursor, + alsa-lib, + libjack2, + lv2, + gcc-unwrapped, + curl, +}: stdenv.mkDerivation (finalAttrs: { pname = "librearp-lv2"; @@ -14,7 +31,10 @@ stdenv.mkDerivation (finalAttrs: { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ cairo libxkbcommon @@ -43,8 +63,7 @@ stdenv.mkDerivation (finalAttrs: { ''; meta = with lib; { - description = - "A pattern-based arpeggio generator plugin."; + description = "A pattern-based arpeggio generator plugin."; homepage = "https://librearp.gitlab.io/"; license = licenses.gpl3Plus; platforms = [ "x86_64-linux" ]; diff --git a/pkgs/by-name/li/librearp/package.nix b/pkgs/by-name/li/librearp/package.nix index 9bd1beac345d48..eb6f10ea8a7467 100644 --- a/pkgs/by-name/li/librearp/package.nix +++ b/pkgs/by-name/li/librearp/package.nix @@ -1,6 +1,23 @@ -{ stdenv, lib, fetchFromGitLab, cmake, pkg-config, cairo, libxkbcommon -, xcbutilcursor, xcbutilkeysyms, xcbutil, libXrandr, libXinerama, libXcursor -, alsa-lib, libjack2, lv2, gcc-unwrapped, curl}: +{ + stdenv, + lib, + fetchFromGitLab, + cmake, + pkg-config, + cairo, + libxkbcommon, + xcbutilcursor, + xcbutilkeysyms, + xcbutil, + libXrandr, + libXinerama, + libXcursor, + alsa-lib, + libjack2, + lv2, + gcc-unwrapped, + curl, +}: stdenv.mkDerivation (finalAttrs: { pname = "librearp"; @@ -14,7 +31,10 @@ stdenv.mkDerivation (finalAttrs: { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ cairo libxkbcommon @@ -43,8 +63,7 @@ stdenv.mkDerivation (finalAttrs: { ''; meta = with lib; { - description = - "A pattern-based arpeggio generator plugin"; + description = "A pattern-based arpeggio generator plugin"; homepage = "https://librearp.gitlab.io/"; license = licenses.gpl3Plus; platforms = [ "x86_64-linux" ]; diff --git a/pkgs/by-name/li/librecast/package.nix b/pkgs/by-name/li/librecast/package.nix index a706b6ff14617b..950893d5d67197 100644 --- a/pkgs/by-name/li/librecast/package.nix +++ b/pkgs/by-name/li/librecast/package.nix @@ -16,15 +16,27 @@ stdenv.mkDerivation (finalAttrs: { rev = "v${finalAttrs.version}"; hash = "sha256-pW18yYKzuWNt1+fzb/Y00cBr/gTENxeh7qLFSzFsmN0="; }; - buildInputs = [ lcrq libsodium ]; + buildInputs = [ + lcrq + libsodium + ]; installFlags = [ "PREFIX=$(out)" ]; meta = { changelog = "https://codeberg.org/librecast/librecast/src/tag/v${finalAttrs.version}/CHANGELOG.md"; description = "IPv6 multicast library"; homepage = "https://librecast.net/librecast.html"; - license = [ lib.licenses.gpl2 lib.licenses.gpl3 ]; - maintainers = with lib.maintainers; [ albertchae aynish DMills27 jasonodoom jleightcap ]; + license = [ + lib.licenses.gpl2 + lib.licenses.gpl3 + ]; + maintainers = with lib.maintainers; [ + albertchae + aynish + DMills27 + jasonodoom + jleightcap + ]; platforms = lib.platforms.gnu; }; }) diff --git a/pkgs/by-name/li/libredirect/package.nix b/pkgs/by-name/li/libredirect/package.nix index 24754041a1b665..ebc52708dded3a 100644 --- a/pkgs/by-name/li/libredirect/package.nix +++ b/pkgs/by-name/li/libredirect/package.nix @@ -1,115 +1,140 @@ -{ lib, stdenv, bintools-unwrapped, llvmPackages, coreutils }: +{ + lib, + stdenv, + bintools-unwrapped, + llvmPackages, + coreutils, +}: -if stdenv.hostPlatform.isStatic -then throw '' - libredirect is not available on static builds. +if stdenv.hostPlatform.isStatic then + throw '' + libredirect is not available on static builds. - Please fix your derivation to not depend on libredirect on static - builds, using something like following: + Please fix your derivation to not depend on libredirect on static + builds, using something like following: - nativeBuildInputs = - lib.optional (!stdenv.buildPlatform.isStatic) libredirect; + nativeBuildInputs = + lib.optional (!stdenv.buildPlatform.isStatic) libredirect; - and disable tests as necessary, although fixing tests to work without - libredirect is even better. + and disable tests as necessary, although fixing tests to work without + libredirect is even better. - libredirect uses LD_PRELOAD feature of dynamic loader and does not - work on static builds where dynamic loader is not used. + libredirect uses LD_PRELOAD feature of dynamic loader and does not + work on static builds where dynamic loader is not used. '' -else stdenv.mkDerivation rec { - pname = "libredirect"; - version = "0"; - - unpackPhase = '' - cp ${./libredirect.c} libredirect.c - cp ${./test.c} test.c - ''; - - outputs = ["out" "hook"]; - - libName = "libredirect" + stdenv.hostPlatform.extensions.sharedLibrary; - - buildPhase = '' - runHook preBuild - - ${if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 then '' - # We need the unwrapped binutils and clang: - # We also want to build a fat library with x86_64, arm64, arm64e in there. - # Because we use the unwrapped tools, we need to provide -isystem for headers - # and the library search directory for libdl. - # We can't build this on x86_64, because the libSystem we point to doesn't - # like arm64(e). - PATH=${bintools-unwrapped}/bin:${llvmPackages.clang-unwrapped}/bin:$PATH \ - clang -arch x86_64 -arch arm64 -arch arm64e \ - -isystem "$SDKROOT/usr/include" \ - -isystem ${lib.getLib llvmPackages.libclang}/lib/clang/*/include \ - "-L$SDKROOT/usr/lib" \ - -Wl,-install_name,$out/lib/$libName \ - -Wall -std=c99 -O3 -fPIC libredirect.c \ - -shared -o "$libName" - '' else if stdenv.hostPlatform.isDarwin then '' - $CC -Wall -std=c99 -O3 -fPIC libredirect.c \ - -Wl,-install_name,$out/lib/$libName \ - -shared -o "$libName" - '' else '' - $CC -Wall -std=c99 -O3 -fPIC libredirect.c \ - -shared -o "$libName" - ''} - - if [ -n "$doInstallCheck" ]; then - $CC -Wall -std=c99 \ - ${lib.optionalString (!stdenv.hostPlatform.isDarwin) "-D_GNU_SOURCE"} \ - -O3 test.c -o test - fi - - runHook postBuild - ''; - - # We want to retain debugging info to be able to use GDB on libredirect.so - # to more easily investigate which function overrides are missing or why - # existing ones do not have the intended effect. - dontStrip = true; - - installPhase = '' - runHook preInstall - - install -vD "$libName" "$out/lib/$libName" - - '' + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' - # dylib will be rejected unless dylib rpath gets explictly set - install_name_tool \ - -change $libName $out/lib/$libName \ - $out/lib/$libName - '' + '' - # Provide a setup hook that injects our library into every process. - mkdir -p "$hook/nix-support" - cat < "$hook/nix-support/setup-hook" - ${if stdenv.hostPlatform.isDarwin then '' - export DYLD_INSERT_LIBRARIES="$out/lib/$libName" - '' else '' - export LD_PRELOAD="$out/lib/$libName" - ''} - SETUP_HOOK - - runHook postInstall - ''; - - doInstallCheck = true; - - installCheckPhase = '' - ( - source "$hook/nix-support/setup-hook" - NIX_REDIRECTS="/foo/bar/test=${coreutils}/bin/true:/bar/baz=$(mktemp -d)" ./test - ) - ''; - - meta = with lib; { - platforms = platforms.unix; - description = "LD_PRELOAD library to intercept and rewrite the paths in glibc calls"; - longDescription = '' - libredirect is an LD_PRELOAD library to intercept and rewrite the paths in - glibc calls based on the value of $NIX_REDIRECTS, a colon-separated list - of path prefixes to be rewritten, e.g. "/src=/dst:/usr/=/nix/store/". +else + stdenv.mkDerivation rec { + pname = "libredirect"; + version = "0"; + + unpackPhase = '' + cp ${./libredirect.c} libredirect.c + cp ${./test.c} test.c ''; - }; -} + + outputs = [ + "out" + "hook" + ]; + + libName = "libredirect" + stdenv.hostPlatform.extensions.sharedLibrary; + + buildPhase = '' + runHook preBuild + + ${ + if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 then + '' + # We need the unwrapped binutils and clang: + # We also want to build a fat library with x86_64, arm64, arm64e in there. + # Because we use the unwrapped tools, we need to provide -isystem for headers + # and the library search directory for libdl. + # We can't build this on x86_64, because the libSystem we point to doesn't + # like arm64(e). + PATH=${bintools-unwrapped}/bin:${llvmPackages.clang-unwrapped}/bin:$PATH \ + clang -arch x86_64 -arch arm64 -arch arm64e \ + -isystem "$SDKROOT/usr/include" \ + -isystem ${lib.getLib llvmPackages.libclang}/lib/clang/*/include \ + "-L$SDKROOT/usr/lib" \ + -Wl,-install_name,$out/lib/$libName \ + -Wall -std=c99 -O3 -fPIC libredirect.c \ + -shared -o "$libName" + '' + else if stdenv.hostPlatform.isDarwin then + '' + $CC -Wall -std=c99 -O3 -fPIC libredirect.c \ + -Wl,-install_name,$out/lib/$libName \ + -shared -o "$libName" + '' + else + '' + $CC -Wall -std=c99 -O3 -fPIC libredirect.c \ + -shared -o "$libName" + '' + } + + if [ -n "$doInstallCheck" ]; then + $CC -Wall -std=c99 \ + ${lib.optionalString (!stdenv.hostPlatform.isDarwin) "-D_GNU_SOURCE"} \ + -O3 test.c -o test + fi + + runHook postBuild + ''; + + # We want to retain debugging info to be able to use GDB on libredirect.so + # to more easily investigate which function overrides are missing or why + # existing ones do not have the intended effect. + dontStrip = true; + + installPhase = + '' + runHook preInstall + + install -vD "$libName" "$out/lib/$libName" + + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' + # dylib will be rejected unless dylib rpath gets explictly set + install_name_tool \ + -change $libName $out/lib/$libName \ + $out/lib/$libName + '' + + '' + # Provide a setup hook that injects our library into every process. + mkdir -p "$hook/nix-support" + cat < "$hook/nix-support/setup-hook" + ${ + if stdenv.hostPlatform.isDarwin then + '' + export DYLD_INSERT_LIBRARIES="$out/lib/$libName" + '' + else + '' + export LD_PRELOAD="$out/lib/$libName" + '' + } + SETUP_HOOK + + runHook postInstall + ''; + + doInstallCheck = true; + + installCheckPhase = '' + ( + source "$hook/nix-support/setup-hook" + NIX_REDIRECTS="/foo/bar/test=${coreutils}/bin/true:/bar/baz=$(mktemp -d)" ./test + ) + ''; + + meta = with lib; { + platforms = platforms.unix; + description = "LD_PRELOAD library to intercept and rewrite the paths in glibc calls"; + longDescription = '' + libredirect is an LD_PRELOAD library to intercept and rewrite the paths in + glibc calls based on the value of $NIX_REDIRECTS, a colon-separated list + of path prefixes to be rewritten, e.g. "/src=/dst:/usr/=/nix/store/". + ''; + }; + } diff --git a/pkgs/by-name/li/libredwg/package.nix b/pkgs/by-name/li/libredwg/package.nix index aff1fc1a1d6868..557ae44b2071aa 100644 --- a/pkgs/by-name/li/libredwg/package.nix +++ b/pkgs/by-name/li/libredwg/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, writeShellScript -, pkg-config -, texinfo -, pcre2 -, swig -, libxml2 -, ncurses -, enablePython ? false -, python ? null +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + writeShellScript, + pkg-config, + texinfo, + pcre2, + swig, + libxml2, + ncurses, + enablePython ? false, + python ? null, }: let isPython3 = enablePython && python.pythonAtLeast "3"; @@ -27,28 +28,33 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - postPatch = let - printVersion = writeShellScript "print-version" '' - echo -n ${lib.escapeShellArg version} + postPatch = + let + printVersion = writeShellScript "print-version" '' + echo -n ${lib.escapeShellArg version} + ''; + in + '' + # avoid git dependency + cp ${printVersion} build-aux/git-version-gen ''; - in '' - # avoid git dependency - cp ${printVersion} build-aux/git-version-gen - ''; preConfigure = lib.optionalString (stdenv.hostPlatform.isDarwin && enablePython) '' # prevent configure picking up stack_size from distutils.sysconfig export PYTHON_EXTRA_LDFLAGS=" " ''; - nativeBuildInputs = [ autoreconfHook pkg-config texinfo ] - ++ lib.optional enablePython swig; + nativeBuildInputs = [ + autoreconfHook + pkg-config + texinfo + ] ++ lib.optional enablePython swig; - buildInputs = [ pcre2 ] + buildInputs = + [ pcre2 ] ++ lib.optionals enablePython [ python ] # configurePhase fails with python 3 when ncurses is missing - ++ lib.optional isPython3 ncurses - ; + ++ lib.optional isPython3 ncurses; # prevent python tests from running when not building with python configureFlags = lib.optional (!enablePython) "--disable-python"; @@ -57,7 +63,10 @@ stdenv.mkDerivation rec { doCheck = !stdenv.hostPlatform.isLinux; # the "xmlsuite" test requires the libxml2 c library as well as the python module - nativeCheckInputs = lib.optionals enablePython [ libxml2 libxml2.dev ]; + nativeCheckInputs = lib.optionals enablePython [ + libxml2 + libxml2.dev + ]; meta = with lib; { description = "Free implementation of the DWG file format"; diff --git a/pkgs/by-name/li/libreelec-dvb-firmware/package.nix b/pkgs/by-name/li/libreelec-dvb-firmware/package.nix index d2e3696ea4c968..6841383511f283 100644 --- a/pkgs/by-name/li/libreelec-dvb-firmware/package.nix +++ b/pkgs/by-name/li/libreelec-dvb-firmware/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, fetchFromGitHub, lib}: +{ + stdenvNoCC, + fetchFromGitHub, + lib, +}: stdenvNoCC.mkDerivation rec { pname = "libreelec-dvb-firmware"; diff --git a/pkgs/by-name/li/librelp/package.nix b/pkgs/by-name/li/librelp/package.nix index 258067c0830027..00e8ef09be0a9e 100644 --- a/pkgs/by-name/li/librelp/package.nix +++ b/pkgs/by-name/li/librelp/package.nix @@ -1,9 +1,12 @@ -{ lib, stdenv, fetchFromGitHub -, autoreconfHook -, gnutls -, openssl -, pkg-config -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gnutls, + openssl, + pkg-config, + zlib, }: stdenv.mkDerivation rec { @@ -17,8 +20,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-VJlvFiOsIyiu0kBU8NkObtt9j2ElrSzJtvE8wtSlOus="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ gnutls zlib openssl ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + gnutls + zlib + openssl + ]; meta = with lib; { description = "Reliable logging library"; diff --git a/pkgs/by-name/li/librem/package.nix b/pkgs/by-name/li/librem/package.nix index 10dba7e7a59dd3..8d75bb11166109 100644 --- a/pkgs/by-name/li/librem/package.nix +++ b/pkgs/by-name/li/librem/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, zlib, openssl, libre -, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + openssl, + libre, + cmake, +}: stdenv.mkDerivation rec { version = "2.12.0"; @@ -11,18 +18,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-MsXSUxFH89EqxMe4285xFV1Tsqmv2l5RnEeli48O3XQ="; }; nativeBuildInputs = [ cmake ]; - buildInputs = [ zlib openssl libre ]; + buildInputs = [ + zlib + openssl + libre + ]; cmakeFlags = [ "-DRE_INCLUDE_DIR=${libre}/include/re" ]; - makeFlags = [ - "LIBRE_MK=${libre}/share/re/re.mk" - "PREFIX=$(out)" - "AR=${stdenv.cc.targetPrefix}ar" - ] - ++ lib.optional (stdenv.cc.cc != null) "SYSROOT_ALT=${lib.getDev stdenv.cc.cc}" - ++ lib.optional (stdenv.cc.libc != null) "SYSROOT=${lib.getDev stdenv.cc.libc}" - ; + makeFlags = + [ + "LIBRE_MK=${libre}/share/re/re.mk" + "PREFIX=$(out)" + "AR=${stdenv.cc.targetPrefix}ar" + ] + ++ lib.optional (stdenv.cc.cc != null) "SYSROOT_ALT=${lib.getDev stdenv.cc.cc}" + ++ lib.optional (stdenv.cc.libc != null) "SYSROOT=${lib.getDev stdenv.cc.libc}"; enableParallelBuilding = true; meta = { description = "Library for real-time audio and video processing"; diff --git a/pkgs/by-name/li/librenms/package.nix b/pkgs/by-name/li/librenms/package.nix index 0fc97f14bbb4e8..2b0efaf6cf4387 100644 --- a/pkgs/by-name/li/librenms/package.nix +++ b/pkgs/by-name/li/librenms/package.nix @@ -1,28 +1,31 @@ -{ lib -, fetchFromGitHub -, unixtools -, php82 -, python3 -, makeWrapper -, nixosTests -# run-time dependencies -, graphviz -, ipmitool -, libvirt -, monitoring-plugins -, mtr -, net-snmp -, nfdump -, nmap -, rrdtool -, system-sendmail -, whois -, dataDir ? "/var/lib/librenms", logDir ? "/var/log/librenms" }: - +{ + lib, + fetchFromGitHub, + unixtools, + php82, + python3, + makeWrapper, + nixosTests, + # run-time dependencies + graphviz, + ipmitool, + libvirt, + monitoring-plugins, + mtr, + net-snmp, + nfdump, + nmap, + rrdtool, + system-sendmail, + whois, + dataDir ? "/var/lib/librenms", + logDir ? "/var/log/librenms", +}: let phpPackage = php82.withExtensions ({ enabled, all }: enabled ++ [ all.memcached ]); -in phpPackage.buildComposerProject rec { +in +phpPackage.buildComposerProject rec { pname = "librenms"; version = "24.11.0"; @@ -50,15 +53,17 @@ in phpPackage.buildComposerProject rec { system-sendmail unixtools.whereis whois - (python3.withPackages (ps: with ps; [ - pymysql - python-dotenv - python-memcached - redis - setuptools - psutil - command-runner - ])) + (python3.withPackages ( + ps: with ps; [ + pymysql + python-dotenv + python-memcached + redis + setuptools + psutil + command-runner + ] + )) ]; nativeBuildInputs = [ makeWrapper ]; @@ -121,9 +126,9 @@ in phpPackage.buildComposerProject rec { meta = with lib; { description = "Auto-discovering PHP/MySQL/SNMP based network monitoring"; - homepage = "https://www.librenms.org/"; - license = licenses.gpl3Only; + homepage = "https://www.librenms.org/"; + license = licenses.gpl3Only; maintainers = with maintainers; [ netali ] ++ teams.wdz.members; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/li/librep/package.nix b/pkgs/by-name/li/librep/package.nix index 373f8232a85757..6258682938a5bf 100644 --- a/pkgs/by-name/li/librep/package.nix +++ b/pkgs/by-name/li/librep/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, gdbm -, gmp -, libffi -, pkg-config -, readline -, texinfo +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + gdbm, + gmp, + libffi, + pkg-config, + readline, + texinfo, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/librespeed-cli/package.nix b/pkgs/by-name/li/librespeed-cli/package.nix index 8751d9ab43d4d1..627686d58d1b6c 100644 --- a/pkgs/by-name/li/librespeed-cli/package.nix +++ b/pkgs/by-name/li/librespeed-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/li/libreswan/package.nix b/pkgs/by-name/li/libreswan/package.nix index 8484185404519b..8635ee0a208b9f 100644 --- a/pkgs/by-name/li/libreswan/package.nix +++ b/pkgs/by-name/li/libreswan/package.nix @@ -1,45 +1,51 @@ -{ lib -, stdenv -, fetchurl -, nixosTests -, pkg-config -, systemd -, gmp -, unbound -, bison -, flex -, pam -, libevent -, libcap_ng -, libxcrypt -, curl -, nspr -, bash -, runtimeShell -, iproute2 -, iptables -, procps -, coreutils -, gnused -, gawk -, nss -, which -, python3 -, libselinux -, ldns -, xmlto -, docbook_xml_dtd_45 -, docbook_xsl -, findXMLCatalogs -, dns-root-data +{ + lib, + stdenv, + fetchurl, + nixosTests, + pkg-config, + systemd, + gmp, + unbound, + bison, + flex, + pam, + libevent, + libcap_ng, + libxcrypt, + curl, + nspr, + bash, + runtimeShell, + iproute2, + iptables, + procps, + coreutils, + gnused, + gawk, + nss, + which, + python3, + libselinux, + ldns, + xmlto, + docbook_xml_dtd_45, + docbook_xsl, + findXMLCatalogs, + dns-root-data, }: let # Tools needed by ipsec scripts binPath = lib.makeBinPath [ - iproute2 iptables procps - coreutils gnused gawk - nss.tools which + iproute2 + iptables + procps + coreutils + gnused + gawk + nss.tools + which ]; in @@ -65,11 +71,23 @@ stdenv.mkDerivation rec { ]; buildInputs = [ - systemd coreutils - gnused gawk gmp unbound pam libevent - libcap_ng libxcrypt curl nspr nss ldns + systemd + coreutils + gnused + gawk + gmp + unbound + pam + libevent + libcap_ng + libxcrypt + curl + nspr + nss + ldns # needed to patch shebangs - python3 bash + python3 + bash ] ++ lib.optional stdenv.hostPlatform.isLinux libselinux; prePatch = '' @@ -110,8 +128,14 @@ stdenv.mkDerivation rec { homepage = "https://libreswan.org"; description = "Free software implementation of the VPN protocol based on IPSec and the Internet Key Exchange"; platforms = platforms.linux ++ platforms.freebsd; - license = with licenses; [ gpl2Plus mpl20 ] ; - maintainers = with maintainers; [ afranchuk rnhmjoj ]; + license = with licenses; [ + gpl2Plus + mpl20 + ]; + maintainers = with maintainers; [ + afranchuk + rnhmjoj + ]; mainProgram = "ipsec"; }; } diff --git a/pkgs/by-name/li/librevenge/package.nix b/pkgs/by-name/li/librevenge/package.nix index e8733a324cabc9..db56de87c8443e 100644 --- a/pkgs/by-name/li/librevenge/package.nix +++ b/pkgs/by-name/li/librevenge/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, boost, pkg-config, cppunit, zlib }: +{ + lib, + stdenv, + fetchurl, + boost, + pkg-config, + cppunit, + zlib, +}: stdenv.mkDerivation rec { pname = "librevenge"; diff --git a/pkgs/by-name/li/librime-lua/package.nix b/pkgs/by-name/li/librime-lua/package.nix index 3c60a41b6264c4..bca9fc2f36e5a9 100644 --- a/pkgs/by-name/li/librime-lua/package.nix +++ b/pkgs/by-name/li/librime-lua/package.nix @@ -35,6 +35,9 @@ stdenvNoCC.mkDerivation { description = "Extending RIME with Lua scripts"; homepage = "https://github.com/hchunhui/librime-lua"; license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [ linj xddxdd ]; + maintainers = with lib.maintainers; [ + linj + xddxdd + ]; }; } diff --git a/pkgs/by-name/li/librime/package.nix b/pkgs/by-name/li/librime/package.nix index 6cd7788caf9782..e998a9fd753064 100644 --- a/pkgs/by-name/li/librime/package.nix +++ b/pkgs/by-name/li/librime/package.nix @@ -1,6 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, cmake, boost, glog, leveldb, marisa, opencc, - yaml-cpp, gtest, capnproto, pkg-config, librime-lua, librime-octagram, - plugins ? [ librime-lua librime-octagram ] }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + glog, + leveldb, + marisa, + opencc, + yaml-cpp, + gtest, + capnproto, + pkg-config, + librime-lua, + librime-octagram, + plugins ? [ + librime-lua + librime-octagram + ], +}: let copySinglePlugin = plug: "cp -r ${plug} plugins/${plug.name}"; @@ -21,18 +39,29 @@ stdenv.mkDerivation rec { sha256 = "sha256-NwtWpH1FxIZP/+oOJbsaEmySLxXlxkCCIG+SEGo242Q="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ boost glog leveldb marisa opencc yaml-cpp gtest capnproto ] - ++ plugins; # for propagated build inputs + buildInputs = [ + boost + glog + leveldb + marisa + opencc + yaml-cpp + gtest + capnproto + ] ++ plugins; # for propagated build inputs preConfigure = copyPlugins; meta = with lib; { - homepage = "https://rime.im/"; + homepage = "https://rime.im/"; description = "Rime Input Method Engine, the core library"; - license = licenses.bsd3; + license = licenses.bsd3; maintainers = with maintainers; [ vonfry ]; - platforms = platforms.linux ++ platforms.darwin; + platforms = platforms.linux ++ platforms.darwin; }; } diff --git a/pkgs/by-name/li/librist/package.nix b/pkgs/by-name/li/librist/package.nix index a98400a89d356c..9de790f636b4a7 100644 --- a/pkgs/by-name/li/librist/package.nix +++ b/pkgs/by-name/li/librist/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchFromGitLab -, meson -, ninja -, pkg-config -, cjson -, cmocka -, mbedtls +{ + stdenv, + lib, + fetchFromGitLab, + meson, + ninja, + pkg-config, + cjson, + cmocka, + mbedtls, }: stdenv.mkDerivation rec { @@ -43,7 +44,11 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Library that can be used to easily add the RIST protocol to your application"; homepage = "https://code.videolan.org/rist/librist"; - license = with licenses; [ bsd2 mit isc ]; + license = with licenses; [ + bsd2 + mit + isc + ]; maintainers = with maintainers; [ raphaelr ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/li/libroxml/package.nix b/pkgs/by-name/li/libroxml/package.nix index 647e4c188a0506..68ba8f05c76715 100644 --- a/pkgs/by-name/li/libroxml/package.nix +++ b/pkgs/by-name/li/libroxml/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libroxml"; @@ -6,7 +10,7 @@ stdenv.mkDerivation rec { src = fetchurl { url = "http://download.libroxml.net/pool/v2.x/libroxml-${version}.tar.gz"; - sha256 = "0y0vc9n4rfbimjp28nx4kdfzz08j5xymh5xjy84l9fhfac5z5a0x"; + sha256 = "0y0vc9n4rfbimjp28nx4kdfzz08j5xymh5xjy84l9fhfac5z5a0x"; }; meta = with lib; { diff --git a/pkgs/by-name/li/librseq/package.nix b/pkgs/by-name/li/librseq/package.nix index 890c0dd25ff2e9..b0c6670986a154 100644 --- a/pkgs/by-name/li/librseq/package.nix +++ b/pkgs/by-name/li/librseq/package.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, fetchFromGitHub -, autoreconfHook, linuxHeaders +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + linuxHeaders, }: stdenv.mkDerivation rec { @@ -7,17 +11,24 @@ stdenv.mkDerivation rec { version = "0.1.0pre71_${builtins.substring 0 7 src.rev}"; src = fetchFromGitHub { - owner = "compudj"; - repo = "librseq"; - rev = "170f840b498e1aff068b90188727a656111bfc2f"; + owner = "compudj"; + repo = "librseq"; + rev = "170f840b498e1aff068b90188727a656111bfc2f"; sha256 = "0rdx59y8y9x8cfmmx5gl66gibkzpk3kw5lrrqhrxan8zr37a055y"; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; nativeBuildInputs = [ autoreconfHook ]; buildInputs = [ linuxHeaders ]; - installTargets = [ "install" "install-man" ]; + installTargets = [ + "install" + "install-man" + ]; doCheck = true; separateDebugInfo = true; @@ -36,9 +47,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Userspace library for the Linux Restartable Sequence API"; - homepage = "https://github.com/compudj/librseq"; - license = licenses.lgpl21Only; - platforms = platforms.linux; + homepage = "https://github.com/compudj/librseq"; + license = licenses.lgpl21Only; + platforms = platforms.linux; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/li/librsync/package.nix b/pkgs/by-name/li/librsync/package.nix index 5139c397de3a3f..02efdd531fa1d0 100644 --- a/pkgs/by-name/li/librsync/package.nix +++ b/pkgs/by-name/li/librsync/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, perl, zlib, bzip2, popt }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + perl, + zlib, + bzip2, + popt, +}: stdenv.mkDerivation rec { pname = "librsync"; @@ -12,7 +21,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ perl zlib bzip2 popt ]; + buildInputs = [ + perl + zlib + bzip2 + popt + ]; dontStrip = stdenv.hostPlatform != stdenv.buildPlatform; diff --git a/pkgs/by-name/li/librtprocess/package.nix b/pkgs/by-name/li/librtprocess/package.nix index a8366f8a92df18..8796373c6776d6 100644 --- a/pkgs/by-name/li/librtprocess/package.nix +++ b/pkgs/by-name/li/librtprocess/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, llvmPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + llvmPackages, +}: stdenv.mkDerivation rec { pname = "librtprocess"; diff --git a/pkgs/by-name/li/librttopo/package.nix b/pkgs/by-name/li/librttopo/package.nix index 5d768db366df0b..9eec8ba69bc3b1 100644 --- a/pkgs/by-name/li/librttopo/package.nix +++ b/pkgs/by-name/li/librttopo/package.nix @@ -1,16 +1,20 @@ -{ lib -, stdenv -, fetchFromGitea -, autoreconfHook -, validatePkgConfig -, geos +{ + lib, + stdenv, + fetchFromGitea, + autoreconfHook, + validatePkgConfig, + geos, }: stdenv.mkDerivation rec { pname = "librttopo"; version = "1.1.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitea { domain = "git.osgeo.org/gitea"; diff --git a/pkgs/by-name/li/librum/package.nix b/pkgs/by-name/li/librum/package.nix index 40158f72a12096..5e2844ed73cb01 100644 --- a/pkgs/by-name/li/librum/package.nix +++ b/pkgs/by-name/li/librum/package.nix @@ -1,11 +1,12 @@ -{ lib -, mupdf -, stdenv -, fetchFromGitHub -, substituteAll -, cmake -, qt6 -, desktopToDarwinBundle +{ + lib, + mupdf, + stdenv, + fetchFromGitHub, + substituteAll, + cmake, + qt6, + desktopToDarwinBundle, }: let @@ -31,20 +32,24 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ - cmake - qt6.qttools - qt6.wrapQtAppsHook - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - desktopToDarwinBundle - ]; + nativeBuildInputs = + [ + cmake + qt6.qttools + qt6.wrapQtAppsHook + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + desktopToDarwinBundle + ]; - buildInputs = [ - qt6.qtbase - qt6.qtsvg - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qt6.qtwayland - ]; + buildInputs = + [ + qt6.qtbase + qt6.qtsvg + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qt6.qtwayland + ]; meta = with lib; { description = "Application designed to make reading enjoyable and straightforward"; @@ -63,7 +68,10 @@ stdenv.mkDerivation rec { changelog = "https://github.com/Librum-Reader/Librum/releases/tag/${src.rev}"; license = licenses.gpl3Plus; mainProgram = "librum"; - maintainers = with maintainers; [ aleksana oluceps ]; + maintainers = with maintainers; [ + aleksana + oluceps + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/li/libsass/package.nix b/pkgs/by-name/li/libsass/package.nix index c63dd35097cc87..0dd16c7535ed9c 100644 --- a/pkgs/by-name/li/libsass/package.nix +++ b/pkgs/by-name/li/libsass/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, testers - -# for passthru.tests -, gtk3 -, gtk4 -, sassc +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + testers, + + # for passthru.tests + gtk3, + gtk4, + sassc, }: stdenv.mkDerivation (finalAttrs: { @@ -43,7 +44,10 @@ stdenv.mkDerivation (finalAttrs: { description = "C/C++ implementation of a Sass compiler"; homepage = "https://github.com/sass/libsass"; license = licenses.mit; - maintainers = with maintainers; [ codyopel offline ]; + maintainers = with maintainers; [ + codyopel + offline + ]; pkgConfigModules = [ "libsass" ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/li/libschrift/package.nix b/pkgs/by-name/li/libschrift/package.nix index 376c0abbcdf949..d3a9c6b98b352f 100644 --- a/pkgs/by-name/li/libschrift/package.nix +++ b/pkgs/by-name/li/libschrift/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "libschrift"; diff --git a/pkgs/by-name/li/libsciter/package.nix b/pkgs/by-name/li/libsciter/package.nix index 9e9c0aece0ba02..c920db6c1a457e 100644 --- a/pkgs/by-name/li/libsciter/package.nix +++ b/pkgs/by-name/li/libsciter/package.nix @@ -1,12 +1,13 @@ -{ lib -, glib -, cairo -, libuuid -, pango -, gtk3 -, stdenv -, fetchurl -, autoPatchelfHook +{ + lib, + glib, + cairo, + libuuid, + pango, + gtk3, + stdenv, + fetchurl, + autoPatchelfHook, }: stdenv.mkDerivation { @@ -22,7 +23,13 @@ stdenv.mkDerivation { autoPatchelfHook ]; - buildInputs = [ glib cairo libuuid pango gtk3 ]; + buildInputs = [ + glib + cairo + libuuid + pango + gtk3 + ]; dontUnpack = true; diff --git a/pkgs/by-name/li/libscrypt/package.nix b/pkgs/by-name/li/libscrypt/package.nix index 4f8f0deba9021e..33ed0870466cb0 100644 --- a/pkgs/by-name/li/libscrypt/package.nix +++ b/pkgs/by-name/li/libscrypt/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "libscrypt"; diff --git a/pkgs/by-name/li/libsearpc/package.nix b/pkgs/by-name/li/libsearpc/package.nix index 94034d6167cbfe..a16fdb584de45f 100644 --- a/pkgs/by-name/li/libsearpc/package.nix +++ b/pkgs/by-name/li/libsearpc/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, python3 -, glib -, jansson +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + python3, + glib, + jansson, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libseccomp/package.nix b/pkgs/by-name/li/libseccomp/package.nix index a8b2a98850dd9e..9ff313c84a65e7 100644 --- a/pkgs/by-name/li/libseccomp/package.nix +++ b/pkgs/by-name/li/libseccomp/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, getopt, util-linuxMinimal, which, gperf, nix-update-script }: +{ + lib, + stdenv, + fetchurl, + getopt, + util-linuxMinimal, + which, + gperf, + nix-update-script, +}: stdenv.mkDerivation rec { pname = "libseccomp"; @@ -9,7 +18,13 @@ stdenv.mkDerivation rec { hash = "sha256-JIosik2bmFiqa69ScSw0r+/PnJ6Ut23OAsHJqiX7M3U="; }; - outputs = [ "out" "lib" "dev" "man" "pythonsrc" ]; + outputs = [ + "out" + "lib" + "dev" + "man" + "pythonsrc" + ]; nativeBuildInputs = [ gperf ]; buildInputs = [ getopt ]; @@ -18,7 +33,10 @@ stdenv.mkDerivation rec { patchShebangs . ''; - nativeCheckInputs = [ util-linuxMinimal which ]; + nativeCheckInputs = [ + util-linuxMinimal + which + ]; doCheck = !(stdenv.targetPlatform.useLLVM or false); # Hack to ensure that patchelf --shrink-rpath get rids of a $TMPDIR reference. diff --git a/pkgs/by-name/li/libsecret/package.nix b/pkgs/by-name/li/libsecret/package.nix index 69eb32a8c95c21..95552812f5087a 100644 --- a/pkgs/by-name/li/libsecret/package.nix +++ b/pkgs/by-name/li/libsecret/package.nix @@ -1,34 +1,40 @@ -{ stdenv -, lib -, fetchurl -, fetchpatch2 -, glib -, meson -, ninja -, pkg-config -, gettext -, libxslt -, python3 -, python3Packages -, docbook-xsl-nons -, docbook_xml_dtd_42 -, libgcrypt -, gobject-introspection -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, vala -, gi-docgen -, gnome -, gjs -, libintl -, dbus +{ + stdenv, + lib, + fetchurl, + fetchpatch2, + glib, + meson, + ninja, + pkg-config, + gettext, + libxslt, + python3, + python3Packages, + docbook-xsl-nons, + docbook_xml_dtd_42, + libgcrypt, + gobject-introspection, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + vala, + gi-docgen, + gnome, + gjs, + libintl, + dbus, }: stdenv.mkDerivation rec { pname = "libsecret"; version = "0.21.4"; - outputs = [ "out" "dev" ] ++ lib.optional withIntrospection "devdoc"; + outputs = [ + "out" + "dev" + ] ++ lib.optional withIntrospection "devdoc"; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -47,21 +53,23 @@ stdenv.mkDerivation rec { pkg-config ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - gettext - libxslt # for xsltproc for building man pages - docbook-xsl-nons - docbook_xml_dtd_42 - libintl - vala - glib - ] ++ lib.optionals withIntrospection [ - gi-docgen - gobject-introspection - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gettext + libxslt # for xsltproc for building man pages + docbook-xsl-nons + docbook_xml_dtd_42 + libintl + vala + glib + ] + ++ lib.optionals withIntrospection [ + gi-docgen + gobject-introspection + ]; buildInputs = [ libgcrypt diff --git a/pkgs/by-name/li/libsegfault/package.nix b/pkgs/by-name/li/libsegfault/package.nix index e9f014381c5bac..89c493c5a1a373 100644 --- a/pkgs/by-name/li/libsegfault/package.nix +++ b/pkgs/by-name/li/libsegfault/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, boost -, libbacktrace -, unstableGitUpdater +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + boost, + libbacktrace, + unstableGitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libselinux/package.nix b/pkgs/by-name/li/libselinux/package.nix index e77c15e7c7ecd3..57f875fcd85589 100644 --- a/pkgs/by-name/li/libselinux/package.nix +++ b/pkgs/by-name/li/libselinux/package.nix @@ -1,94 +1,126 @@ -{ lib, stdenv, fetchurl, buildPackages, pcre2, pkg-config, libsepol -, enablePython ? !stdenv.hostPlatform.isStatic -, swig ? null, python3 ? null, python3Packages -, fts +{ + lib, + stdenv, + fetchurl, + buildPackages, + pcre2, + pkg-config, + libsepol, + enablePython ? !stdenv.hostPlatform.isStatic, + swig ? null, + python3 ? null, + python3Packages, + fts, }: assert enablePython -> swig != null && python3 != null; -stdenv.mkDerivation (rec { - pname = "libselinux"; - version = "3.7"; - inherit (libsepol) se_url; +stdenv.mkDerivation ( + rec { + pname = "libselinux"; + version = "3.7"; + inherit (libsepol) se_url; - outputs = [ "bin" "out" "dev" "man" ] ++ lib.optional enablePython "py"; + outputs = [ + "bin" + "out" + "dev" + "man" + ] ++ lib.optional enablePython "py"; - src = fetchurl { - url = "${se_url}/${version}/libselinux-${version}.tar.gz"; - hash = "sha256-6gP0LROk+VdXmX26jPCyYyH6xdLxZEGLTMhWqS0rF70="; - }; + src = fetchurl { + url = "${se_url}/${version}/libselinux-${version}.tar.gz"; + hash = "sha256-6gP0LROk+VdXmX26jPCyYyH6xdLxZEGLTMhWqS0rF70="; + }; - patches = [ - # Make it possible to disable shared builds (for pkgsStatic). - # - # We can't use fetchpatch because it processes includes/excludes - # /after/ stripping the prefix, which wouldn't work here because - # there would be no way to distinguish between - # e.g. libselinux/src/Makefile and libsepol/src/Makefile. - # - # This is a static email, so we shouldn't have to worry about - # normalizing the patch. - (fetchurl { - url = "https://lore.kernel.org/selinux/20211113141616.361640-1-hi@alyssa.is/raw"; - sha256 = "16a2s2ji9049892i15yyqgp4r20hi1hij4c1s4s8law9jsx65b3n"; - postFetch = '' - mv "$out" $TMPDIR/patch - ${buildPackages.patchutils_0_3_3}/bin/filterdiff \ - -i 'a/libselinux/*' --strip 1 <$TMPDIR/patch >"$out" - ''; - }) + patches = [ + # Make it possible to disable shared builds (for pkgsStatic). + # + # We can't use fetchpatch because it processes includes/excludes + # /after/ stripping the prefix, which wouldn't work here because + # there would be no way to distinguish between + # e.g. libselinux/src/Makefile and libsepol/src/Makefile. + # + # This is a static email, so we shouldn't have to worry about + # normalizing the patch. + (fetchurl { + url = "https://lore.kernel.org/selinux/20211113141616.361640-1-hi@alyssa.is/raw"; + sha256 = "16a2s2ji9049892i15yyqgp4r20hi1hij4c1s4s8law9jsx65b3n"; + postFetch = '' + mv "$out" $TMPDIR/patch + ${buildPackages.patchutils_0_3_3}/bin/filterdiff \ + -i 'a/libselinux/*' --strip 1 <$TMPDIR/patch >"$out" + ''; + }) - (fetchurl { - url = "https://git.yoctoproject.org/meta-selinux/plain/recipes-security/selinux/libselinux/0003-libselinux-restore-drop-the-obsolete-LSF-transitiona.patch?id=62b9c816a5000dc01b28e78213bde26b58cbca9d"; - sha256 = "sha256-RiEUibLVzfiRU6N/J187Cs1iPAih87gCZrlyRVI2abU="; - }) - ]; + (fetchurl { + url = "https://git.yoctoproject.org/meta-selinux/plain/recipes-security/selinux/libselinux/0003-libselinux-restore-drop-the-obsolete-LSF-transitiona.patch?id=62b9c816a5000dc01b28e78213bde26b58cbca9d"; + sha256 = "sha256-RiEUibLVzfiRU6N/J187Cs1iPAih87gCZrlyRVI2abU="; + }) + ]; - nativeBuildInputs = [ pkg-config python3 ] ++ lib.optionals enablePython [ - python3Packages.pip - python3Packages.setuptools - python3Packages.wheel - swig - ]; - buildInputs = [ libsepol pcre2 fts ] ++ lib.optionals enablePython [ python3 ]; + nativeBuildInputs = + [ + pkg-config + python3 + ] + ++ lib.optionals enablePython [ + python3Packages.pip + python3Packages.setuptools + python3Packages.wheel + swig + ]; + buildInputs = [ + libsepol + pcre2 + fts + ] ++ lib.optionals enablePython [ python3 ]; - # drop fortify here since package uses it by default, leading to compile error: - # command-line>:0:0: error: "_FORTIFY_SOURCE" redefined [-Werror] - hardeningDisable = [ "fortify" ]; + # drop fortify here since package uses it by default, leading to compile error: + # command-line>:0:0: error: "_FORTIFY_SOURCE" redefined [-Werror] + hardeningDisable = [ "fortify" ]; - env.NIX_CFLAGS_COMPILE = "-Wno-error -D_FILE_OFFSET_BITS=64"; + env.NIX_CFLAGS_COMPILE = "-Wno-error -D_FILE_OFFSET_BITS=64"; - makeFlags = [ - "PREFIX=$(out)" - "INCDIR=$(dev)/include/selinux" - "INCLUDEDIR=$(dev)/include" - "MAN3DIR=$(man)/share/man/man3" - "MAN5DIR=$(man)/share/man/man5" - "MAN8DIR=$(man)/share/man/man8" - "SBINDIR=$(bin)/sbin" - "SHLIBDIR=$(out)/lib" + makeFlags = + [ + "PREFIX=$(out)" + "INCDIR=$(dev)/include/selinux" + "INCLUDEDIR=$(dev)/include" + "MAN3DIR=$(man)/share/man/man3" + "MAN5DIR=$(man)/share/man/man5" + "MAN8DIR=$(man)/share/man/man8" + "SBINDIR=$(bin)/sbin" + "SHLIBDIR=$(out)/lib" - "LIBSEPOLA=${lib.getLib libsepol}/lib/libsepol.a" - "ARCH=${stdenv.hostPlatform.linuxArch}" - ] ++ lib.optionals (fts != null) [ - "FTS_LDLIBS=-lfts" - ] ++ lib.optionals stdenv.hostPlatform.isStatic [ - "DISABLE_SHARED=y" - ] ++ lib.optionals enablePython [ - "PYTHON=${python3.pythonOnBuildForHost.interpreter}" - "PYTHONLIBDIR=$(py)/${python3.sitePackages}" - "PYTHON_SETUP_ARGS=--no-build-isolation" - ]; + "LIBSEPOLA=${lib.getLib libsepol}/lib/libsepol.a" + "ARCH=${stdenv.hostPlatform.linuxArch}" + ] + ++ lib.optionals (fts != null) [ + "FTS_LDLIBS=-lfts" + ] + ++ lib.optionals stdenv.hostPlatform.isStatic [ + "DISABLE_SHARED=y" + ] + ++ lib.optionals enablePython [ + "PYTHON=${python3.pythonOnBuildForHost.interpreter}" + "PYTHONLIBDIR=$(py)/${python3.sitePackages}" + "PYTHON_SETUP_ARGS=--no-build-isolation" + ]; - preInstall = lib.optionalString enablePython '' - mkdir -p $py/${python3.sitePackages}/selinux - ''; + preInstall = lib.optionalString enablePython '' + mkdir -p $py/${python3.sitePackages}/selinux + ''; - installTargets = [ "install" ] ++ lib.optional enablePython "install-pywrap"; + installTargets = [ "install" ] ++ lib.optional enablePython "install-pywrap"; - meta = removeAttrs libsepol.meta ["outputsToInstall"] // { - description = "SELinux core library"; - }; -} // lib.optionalAttrs (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") { - NIX_LDFLAGS = "--undefined-version"; -}) + meta = removeAttrs libsepol.meta [ "outputsToInstall" ] // { + description = "SELinux core library"; + }; + } + // + lib.optionalAttrs (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") + { + NIX_LDFLAGS = "--undefined-version"; + } +) diff --git a/pkgs/by-name/li/libsepol/package.nix b/pkgs/by-name/li/libsepol/package.nix index c1224a9dd57c58..01e038d4ec0c31 100644 --- a/pkgs/by-name/li/libsepol/package.nix +++ b/pkgs/by-name/li/libsepol/package.nix @@ -1,11 +1,21 @@ -{ lib, stdenv, fetchurl, flex }: +{ + lib, + stdenv, + fetchurl, + flex, +}: stdenv.mkDerivation rec { pname = "libsepol"; version = "3.7"; se_url = "https://github.com/SELinuxProject/selinux/releases/download"; - outputs = [ "bin" "out" "dev" "man" ]; + outputs = [ + "bin" + "out" + "dev" + "man" + ]; src = fetchurl { url = "${se_url}/${version}/libsepol-${version}.tar.gz"; diff --git a/pkgs/by-name/li/libserdes/package.nix b/pkgs/by-name/li/libserdes/package.nix index 9c61d6a4079e46..27eb6c1f43ec7b 100644 --- a/pkgs/by-name/li/libserdes/package.nix +++ b/pkgs/by-name/li/libserdes/package.nix @@ -1,15 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, perl -, which -, boost -, rdkafka -, jansson -, curl -, avro-c -, avro-cpp -, nix-update-script }: +{ + stdenv, + lib, + fetchFromGitHub, + perl, + which, + boost, + rdkafka, + jansson, + curl, + avro-c, + avro-cpp, + nix-update-script, +}: stdenv.mkDerivation rec { pname = "libserdes"; @@ -22,11 +24,24 @@ stdenv.mkDerivation rec { hash = "sha256-rg4SWa9nIDT6JrnnCDwdiFE1cvpUn0HWHn+bPkXMHQ4="; }; - outputs = [ "dev" "out" ]; + outputs = [ + "dev" + "out" + ]; - nativeBuildInputs = [ perl which ]; + nativeBuildInputs = [ + perl + which + ]; - buildInputs = [ boost rdkafka jansson curl avro-c avro-cpp ]; + buildInputs = [ + boost + rdkafka + jansson + curl + avro-c + avro-cpp + ]; makeFlags = [ "GEN_PKG_CONFIG=y" ]; diff --git a/pkgs/by-name/li/libserialport/package.nix b/pkgs/by-name/li/libserialport/package.nix index 4f362674006731..11415d4fe68e21 100644 --- a/pkgs/by-name/li/libserialport/package.nix +++ b/pkgs/by-name/li/libserialport/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, udev, darwin }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + udev, + darwin, +}: stdenv.mkDerivation rec { pname = "libserialport"; @@ -10,7 +17,8 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = lib.optional stdenv.hostPlatform.isLinux udev + buildInputs = + lib.optional stdenv.hostPlatform.isLinux udev ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.IOKit; meta = with lib; { diff --git a/pkgs/by-name/li/libshout/package.nix b/pkgs/by-name/li/libshout/package.nix index 8f97b09a3138d2..3ba32d1f8e0484 100644 --- a/pkgs/by-name/li/libshout/package.nix +++ b/pkgs/by-name/li/libshout/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config -, openssl, libvorbis, libtheora, speex }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + openssl, + libvorbis, + libtheora, + speex, +}: # need pkg-config so that libshout installs ${out}/lib/pkgconfig/shout.pc @@ -25,11 +34,20 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; depsBuildBuild = [ pkg-config ]; nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ openssl libvorbis libtheora speex ]; + propagatedBuildInputs = [ + openssl + libvorbis + libtheora + speex + ]; meta = { description = "icecast 'c' language bindings"; diff --git a/pkgs/by-name/li/libshumate/package.nix b/pkgs/by-name/li/libshumate/package.nix index 98a3ea533bef4a..b0e25af9cffd00 100644 --- a/pkgs/by-name/li/libshumate/package.nix +++ b/pkgs/by-name/li/libshumate/package.nix @@ -1,30 +1,35 @@ -{ lib -, stdenv -, fetchurl -, gi-docgen -, meson -, ninja -, pkg-config -, vala -, gobject-introspection -, gperf -, glib -, cairo -, sqlite -, libsoup_3 -, gtk4 -, libsysprof-capture -, json-glib -, protobufc -, xvfb-run -, gnome +{ + lib, + stdenv, + fetchurl, + gi-docgen, + meson, + ninja, + pkg-config, + vala, + gobject-introspection, + gperf, + glib, + cairo, + sqlite, + libsoup_3, + gtk4, + libsysprof-capture, + json-glib, + protobufc, + xvfb-run, + gnome, }: stdenv.mkDerivation (finalAttrs: { pname = "libshumate"; version = "1.3.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "devdoc"; # demo app src = fetchurl { diff --git a/pkgs/by-name/li/libsieve/package.nix b/pkgs/by-name/li/libsieve/package.nix index 12838b6269f7f1..d922f0ce29a4ce 100644 --- a/pkgs/by-name/li/libsieve/package.nix +++ b/pkgs/by-name/li/libsieve/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "2.3.1"; pname = "libsieve"; diff --git a/pkgs/by-name/li/libsignal-protocol-c/package.nix b/pkgs/by-name/li/libsignal-protocol-c/package.nix index 203d3613af85a8..7cfa79b425aa98 100644 --- a/pkgs/by-name/li/libsignal-protocol-c/package.nix +++ b/pkgs/by-name/li/libsignal-protocol-c/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openssl, +}: stdenv.mkDerivation rec { pname = "libsignal-protocol-c"; @@ -17,7 +23,10 @@ stdenv.mkDerivation rec { cmakeFlags = [ "-DBUILD_SHARED_LIBS=ON" ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = with lib; { description = "Signal Protocol C Library"; diff --git a/pkgs/by-name/li/libsignon-glib/package.nix b/pkgs/by-name/li/libsignon-glib/package.nix index 95541c97eb89f0..c668b6b1a070b4 100644 --- a/pkgs/by-name/li/libsignon-glib/package.nix +++ b/pkgs/by-name/li/libsignon-glib/package.nix @@ -1,10 +1,32 @@ -{ lib, stdenv, fetchgit, nix-update-script, pkg-config, meson, ninja, vala, python3, gtk-doc, docbook_xsl, docbook_xml_dtd_43, docbook_xml_dtd_412, glib, check, gobject-introspection }: +{ + lib, + stdenv, + fetchgit, + nix-update-script, + pkg-config, + meson, + ninja, + vala, + python3, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_43, + docbook_xml_dtd_412, + glib, + check, + gobject-introspection, +}: stdenv.mkDerivation rec { pname = "libsignon-glib"; version = "2.1"; - outputs = [ "out" "dev" "devdoc" "py" ]; + outputs = [ + "out" + "dev" + "devdoc" + "py" + ]; src = fetchgit { url = "https://gitlab.com/accounts-sso/${pname}"; @@ -54,4 +76,3 @@ stdenv.mkDerivation rec { platforms = platforms.linux; }; } - diff --git a/pkgs/by-name/li/libsigrokdecode/package.nix b/pkgs/by-name/li/libsigrokdecode/package.nix index 972c413ccddd94..36eed358095b8a 100644 --- a/pkgs/by-name/li/libsigrokdecode/package.nix +++ b/pkgs/by-name/li/libsigrokdecode/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchgit, pkg-config, autoreconfHook, glib, python3, check, libxcrypt }: +{ + lib, + stdenv, + fetchgit, + pkg-config, + autoreconfHook, + glib, + python3, + check, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "libsigrokdecode"; @@ -10,8 +20,15 @@ stdenv.mkDerivation rec { hash = "sha256-1kQB7uk2c+6Uriw+1o6brThDcBLoCdPV0MVWAha7ohk="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ glib python3 libxcrypt ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + glib + python3 + libxcrypt + ]; nativeCheckInputs = [ check ]; doCheck = true; @@ -20,6 +37,9 @@ stdenv.mkDerivation rec { homepage = "https://sigrok.org/"; license = licenses.gpl3Plus; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ bjornfor vifino ]; + maintainers = with maintainers; [ + bjornfor + vifino + ]; }; } diff --git a/pkgs/by-name/li/libsigsegv/package.nix b/pkgs/by-name/li/libsigsegv/package.nix index 84c2f19e5e2969..7f64f4ba0ee222 100644 --- a/pkgs/by-name/li/libsigsegv/package.nix +++ b/pkgs/by-name/li/libsigsegv/package.nix @@ -1,5 +1,8 @@ -{ lib, stdenv, fetchurl -, enableSigbusFix ? false # required by kernels < 3.18.6 +{ + lib, + stdenv, + fetchurl, + enableSigbusFix ? false, # required by kernels < 3.18.6 }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libsixel/package.nix b/pkgs/by-name/li/libsixel/package.nix index 81f13acb340a6b..3add0a77716da4 100644 --- a/pkgs/by-name/li/libsixel/package.nix +++ b/pkgs/by-name/li/libsixel/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, gdk-pixbuf -, gd -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + gdk-pixbuf, + gd, + pkg-config, }: stdenv.mkDerivation rec { pname = "libsixel"; @@ -19,11 +20,14 @@ stdenv.mkDerivation rec { }; buildInputs = [ - gdk-pixbuf gd + gdk-pixbuf + gd ]; nativeBuildInputs = [ - meson ninja pkg-config + meson + ninja + pkg-config ]; doCheck = true; diff --git a/pkgs/by-name/li/libskk/package.nix b/pkgs/by-name/li/libskk/package.nix index 219a71447e080c..6bb44ce70d639d 100644 --- a/pkgs/by-name/li/libskk/package.nix +++ b/pkgs/by-name/li/libskk/package.nix @@ -1,7 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, - libtool, gettext, pkg-config, - vala, gnome-common, gobject-introspection, - libgee, json-glib, skkDictionaries, libxkbcommon }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + libtool, + gettext, + pkg-config, + vala, + gnome-common, + gobject-introspection, + libgee, + json-glib, + skkDictionaries, + libxkbcommon, +}: stdenv.mkDerivation rec { pname = "libskk"; @@ -24,8 +36,18 @@ stdenv.mkDerivation rec { ]; buildInputs = [ libxkbcommon ]; - nativeBuildInputs = [ vala gnome-common gobject-introspection libtool gettext pkg-config ]; - propagatedBuildInputs = [ libgee json-glib ]; + nativeBuildInputs = [ + vala + gnome-common + gobject-introspection + libtool + gettext + pkg-config + ]; + propagatedBuildInputs = [ + libgee + json-glib + ]; preConfigure = '' ./autogen.sh diff --git a/pkgs/by-name/li/libslirp/package.nix b/pkgs/by-name/li/libslirp/package.nix index a8a8c3e77e08b0..e590aa2a9ad2b8 100644 --- a/pkgs/by-name/li/libslirp/package.nix +++ b/pkgs/by-name/li/libslirp/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, glib +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + glib, }: stdenv.mkDerivation rec { @@ -21,7 +22,11 @@ stdenv.mkDerivation rec { separateDebugInfo = true; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; buildInputs = [ glib ]; diff --git a/pkgs/by-name/li/libsmartcols/package.nix b/pkgs/by-name/li/libsmartcols/package.nix index 5b4fcf875f6fba..ad6378cb1a3f82 100644 --- a/pkgs/by-name/li/libsmartcols/package.nix +++ b/pkgs/by-name/li/libsmartcols/package.nix @@ -1,10 +1,23 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, python3, gtk-doc}: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + python3, + gtk-doc, +}: stdenv.mkDerivation rec { pname = "libsmartcols"; version = "2.39.3"; - nativeBuildInputs = [ autoreconfHook pkg-config python3 gtk-doc ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + python3 + gtk-doc + ]; src = fetchFromGitHub { owner = "karelzak"; @@ -13,13 +26,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-X39os2iHqSrrYP6HVHPOkuTfc6vNB3pmsOP3VjW50fI="; }; - configureFlags = [ "--disable-all-programs" "--enable-libsmartcols" ]; + configureFlags = [ + "--disable-all-programs" + "--enable-libsmartcols" + ]; buildPhase = '' make libsmartcols.la ''; - installTargets = [ "install-am" "install-pkgconfigDATA" ]; + installTargets = [ + "install-am" + "install-pkgconfigDATA" + ]; meta = { description = "smart column output alignment library"; @@ -29,4 +48,3 @@ stdenv.mkDerivation rec { maintainers = with lib.maintainers; [ rb2k ]; }; } - diff --git a/pkgs/by-name/li/libsmbios/package.nix b/pkgs/by-name/li/libsmbios/package.nix index cf01f43ca7fc97..a878b9d154d66c 100644 --- a/pkgs/by-name/li/libsmbios/package.nix +++ b/pkgs/by-name/li/libsmbios/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl -, pkg-config, autoreconfHook, help2man, gettext, libxml2, perl, python3, doxygen +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + pkg-config, + autoreconfHook, + help2man, + gettext, + libxml2, + perl, + python3, + doxygen, }: stdenv.mkDerivation rec { @@ -21,7 +32,15 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook doxygen gettext libxml2 help2man perl pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + doxygen + gettext + libxml2 + help2man + perl + pkg-config + ]; buildInputs = [ python3 ]; @@ -43,8 +62,14 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/dell/libsmbios"; description = "Library to obtain BIOS information"; - license = with licenses; [ osl21 gpl2Plus ]; + license = with licenses; [ + osl21 + gpl2Plus + ]; maintainers = [ ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/li/libsmf/package.nix b/pkgs/by-name/li/libsmf/package.nix index c8d33508672e93..8c766a1a3eb314 100644 --- a/pkgs/by-name/li/libsmf/package.nix +++ b/pkgs/by-name/li/libsmf/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, glib, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + glib, + pkg-config, +}: stdenv.mkDerivation rec { version = "1.3"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-OJXJkXvbM2GQNInZXU2ldObquKHhqkdu1zqUDnVZN0Y="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ glib ]; meta = with lib; { diff --git a/pkgs/by-name/li/libsmi/package.nix b/pkgs/by-name/li/libsmi/package.nix index 5750e6677b347a..1e578eed35a0e1 100644 --- a/pkgs/by-name/li/libsmi/package.nix +++ b/pkgs/by-name/li/libsmi/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv , fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libsmi"; diff --git a/pkgs/by-name/li/libsodium/package.nix b/pkgs/by-name/li/libsodium/package.nix index a9de633d46d7ed..3a594b8609ab88 100644 --- a/pkgs/by-name/li/libsodium/package.nix +++ b/pkgs/by-name/li/libsodium/package.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, fetchurl, autoreconfHook -, testers +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -11,18 +15,25 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-67Ze9spDkzPCu0GgwZkFhyiNoH9sf9B8s6GMwY0wzhk="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ autoreconfHook ]; separateDebugInfo = stdenv.hostPlatform.isLinux && stdenv.hostPlatform.libc != "musl"; enableParallelBuilding = true; - hardeningDisable = lib.optional (stdenv.hostPlatform.isMusl && stdenv.hostPlatform.isx86_32) "stackprotector"; + hardeningDisable = lib.optional ( + stdenv.hostPlatform.isMusl && stdenv.hostPlatform.isx86_32 + ) "stackprotector"; # FIXME: the hardeingDisable attr above does not seems effective, so # the need to disable stackprotector via configureFlags - configureFlags = lib.optional (stdenv.hostPlatform.isMusl && stdenv.hostPlatform.isx86_32) "--disable-ssp"; + configureFlags = lib.optional ( + stdenv.hostPlatform.isMusl && stdenv.hostPlatform.isx86_32 + ) "--disable-ssp"; doCheck = true; diff --git a/pkgs/by-name/li/libspatialaudio/package.nix b/pkgs/by-name/li/libspatialaudio/package.nix index a97a46f357a647..ef7275e2076e02 100644 --- a/pkgs/by-name/li/libspatialaudio/package.nix +++ b/pkgs/by-name/li/libspatialaudio/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, cmake, fetchFromGitHub, libmysofa, zlib }: +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + libmysofa, + zlib, +}: stdenv.mkDerivation rec { pname = "libspatialaudio"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libmysofa zlib ]; + buildInputs = [ + libmysofa + zlib + ]; postFixup = '' substituteInPlace "''${!outputDev}/lib/pkgconfig/spatialaudio.pc" \ @@ -20,8 +30,7 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = - "Ambisonic encoding / decoding and binauralization library in C++"; + description = "Ambisonic encoding / decoding and binauralization library in C++"; homepage = "https://github.com/videolabs/libspatialaudio"; license = licenses.lgpl21Plus; platforms = platforms.linux; diff --git a/pkgs/by-name/li/libspatialite/package.nix b/pkgs/by-name/li/libspatialite/package.nix index 8330b34f4c87b7..421d67096cf2d9 100644 --- a/pkgs/by-name/li/libspatialite/package.nix +++ b/pkgs/by-name/li/libspatialite/package.nix @@ -1,24 +1,28 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, validatePkgConfig -, freexl -, geos -, librttopo -, libxml2 -, minizip -, proj -, sqlite -, libiconv -, zlib +{ + lib, + stdenv, + fetchurl, + pkg-config, + validatePkgConfig, + freexl, + geos, + librttopo, + libxml2, + minizip, + proj, + sqlite, + libiconv, + zlib, }: stdenv.mkDerivation rec { pname = "libspatialite"; version = "5.1.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "https://www.gaia-gis.it/gaia-sins/libspatialite-sources/libspatialite-${version}.tar.gz"; @@ -38,18 +42,20 @@ stdenv.mkDerivation rec { geos # for geos-config ]; - buildInputs = [ - freexl - geos - librttopo - libxml2 - minizip - proj - sqlite - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - ]; + buildInputs = + [ + freexl + geos + librttopo + libxml2 + minizip + proj + sqlite + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + ]; enableParallelBuilding = true; @@ -71,7 +77,11 @@ stdenv.mkDerivation rec { description = "Extensible spatial index library in C++"; homepage = "https://www.gaia-gis.it/fossil/libspatialite"; # They allow any of these - license = with licenses; [ gpl2Plus lgpl21Plus mpl11 ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + mpl11 + ]; platforms = platforms.unix; maintainers = with maintainers; teams.geospatial.members ++ [ dotlambda ]; }; diff --git a/pkgs/by-name/li/libspecbleach/package.nix b/pkgs/by-name/li/libspecbleach/package.nix index b1065561e1c635..fa3823a897d783 100644 --- a/pkgs/by-name/li/libspecbleach/package.nix +++ b/pkgs/by-name/li/libspecbleach/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, pkg-config, fftwFloat}: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + fftwFloat, +}: stdenv.mkDerivation rec { pname = "libspecbleach"; @@ -11,15 +19,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-Tw5nrGVAeoiMH00efJwcU+QLmKDZZTXHQPSV9x789TM="; }; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; buildInputs = [ fftwFloat ]; meta = with lib; { description = "C library for audio noise reduction"; - homepage = "https://github.com/lucianodato/libspecbleach"; - license = licenses.lgpl2; + homepage = "https://github.com/lucianodato/libspecbleach"; + license = licenses.lgpl2; maintainers = [ maintainers.magnetophon ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/li/libspectre/package.nix b/pkgs/by-name/li/libspectre/package.nix index 9299e4dbfb1375..08f3088282ae56 100644 --- a/pkgs/by-name/li/libspectre/package.nix +++ b/pkgs/by-name/li/libspectre/package.nix @@ -1,4 +1,11 @@ -{ fetchurl, lib, stdenv, pkg-config, ghostscript, cairo }: +{ + fetchurl, + lib, + stdenv, + pkg-config, + ghostscript, + cairo, +}: stdenv.mkDerivation rec { pname = "libspectre"; diff --git a/pkgs/by-name/li/libspectrum/package.nix b/pkgs/by-name/li/libspectrum/package.nix index 3dda20ab612840..389334300593c7 100644 --- a/pkgs/by-name/li/libspectrum/package.nix +++ b/pkgs/by-name/li/libspectrum/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, perl, pkg-config, audiofile, bzip2, glib, libgcrypt, zlib }: +{ + lib, + stdenv, + fetchurl, + perl, + pkg-config, + audiofile, + bzip2, + glib, + libgcrypt, + zlib, +}: stdenv.mkDerivation rec { pname = "libspectrum"; @@ -9,9 +20,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-o1PLRumxooEGHYFjU+oBDQpv545qF6oLe3QnHKXkrPw="; }; - nativeBuildInputs = [ perl pkg-config ]; + nativeBuildInputs = [ + perl + pkg-config + ]; - buildInputs = [ audiofile bzip2 glib libgcrypt zlib ]; + buildInputs = [ + audiofile + bzip2 + glib + libgcrypt + zlib + ]; enableParallelBuilding = true; doCheck = true; diff --git a/pkgs/by-name/li/libspelling/package.nix b/pkgs/by-name/li/libspelling/package.nix index 9d0eac13bcd372..15d226079e316f 100644 --- a/pkgs/by-name/li/libspelling/package.nix +++ b/pkgs/by-name/li/libspelling/package.nix @@ -1,26 +1,31 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, gobject-introspection -, vala -, gi-docgen -, glib -, gtk4 -, gtksourceview5 -, enchant -, icu -, libsysprof-capture -, gnome +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + gobject-introspection, + vala, + gi-docgen, + glib, + gtk4, + gtksourceview5, + enchant, + icu, + libsysprof-capture, + gnome, }: stdenv.mkDerivation rec { pname = "libspelling"; version = "0.4.5"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitLab { domain = "gitlab.gnome.org"; diff --git a/pkgs/by-name/li/libspf2/package.nix b/pkgs/by-name/li/libspf2/package.nix index 9e64441af5580f..17663a5e10de10 100644 --- a/pkgs/by-name/li/libspf2/package.nix +++ b/pkgs/by-name/li/libspf2/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libspf2"; @@ -28,10 +33,13 @@ stdenv.mkDerivation rec { doCheck = true; meta = with lib; { - description = "Implementation of the Sender Policy Framework for SMTP " + - "authorization (Helsinki Systems fork)"; + description = + "Implementation of the Sender Policy Framework for SMTP " + "authorization (Helsinki Systems fork)"; homepage = "https://github.com/helsinki-systems/libspf2"; - license = with licenses; [ lgpl21Plus bsd2 ]; + license = with licenses; [ + lgpl21Plus + bsd2 + ]; maintainers = with maintainers; [ pacien ] ++ teams.helsinki-systems.members; platforms = platforms.all; }; diff --git a/pkgs/by-name/li/libspiro/package.nix b/pkgs/by-name/li/libspiro/package.nix index c14117305f04bd..9f3bf740d066bd 100644 --- a/pkgs/by-name/li/libspiro/package.nix +++ b/pkgs/by-name/li/libspiro/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, pkg-config, autoreconfHook, fetchFromGitHub }: +{ + lib, + stdenv, + pkg-config, + autoreconfHook, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "libspiro"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-psEF1SWkire6ngEUcMU0xnGYaT8ktqDCBlBckToGUMg="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; meta = with lib; { description = "Library that simplifies the drawing of beautiful curves"; diff --git a/pkgs/by-name/li/libspng/package.nix b/pkgs/by-name/li/libspng/package.nix index 98e4aa0641ce95..2ba14980ad54c7 100644 --- a/pkgs/by-name/li/libspng/package.nix +++ b/pkgs/by-name/li/libspng/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, stdenv -, zlib -, ninja -, meson -, pkg-config -, cmake -, libpng +{ + lib, + fetchFromGitHub, + stdenv, + zlib, + ninja, + meson, + pkg-config, + cmake, + libpng, }: stdenv.mkDerivation rec { @@ -30,7 +31,10 @@ stdenv.mkDerivation rec { "-Ddev_build=true" ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; strictDeps = true; diff --git a/pkgs/by-name/li/libsrs2/package.nix b/pkgs/by-name/li/libsrs2/package.nix index e6fd748362e90c..e1de774e48e8cb 100644 --- a/pkgs/by-name/li/libsrs2/package.nix +++ b/pkgs/by-name/li/libsrs2/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchurl }: +{ + stdenv, + lib, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libsrs2"; @@ -12,7 +16,10 @@ stdenv.mkDerivation rec { meta = { description = "Next generation SRS library from the original designer of SRS"; mainProgram = "srs"; - license = with lib.licenses; [ gpl2 bsd3 ]; + license = with lib.licenses; [ + gpl2 + bsd3 + ]; homepage = "https://www.libsrs2.org/"; platforms = lib.platforms.linux; }; diff --git a/pkgs/by-name/li/libssh/package.nix b/pkgs/by-name/li/libssh/package.nix index ad6a4322bc1a4d..b0f5cbc51ce313 100644 --- a/pkgs/by-name/li/libssh/package.nix +++ b/pkgs/by-name/li/libssh/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, cmake -, zlib -, openssl -, libsodium - -# for passthru.tests -, ffmpeg -, sshping -, wireshark +{ + lib, + stdenv, + fetchurl, + pkg-config, + cmake, + zlib, + openssl, + libsodium, + + # for passthru.tests + ffmpeg, + sshping, + wireshark, }: stdenv.mkDerivation rec { @@ -22,7 +23,10 @@ stdenv.mkDerivation rec { hash = "sha256-FLfcxy6R4IFRxYuYGntXCrJmP2MOfSg3ZF1anGEsG3k="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postPatch = '' # Fix headers to use libsodium instead of NaCl @@ -33,9 +37,16 @@ stdenv.mkDerivation rec { # included in `buildInputs` such as libX11. cmakeFlags = [ "-DWITH_EXAMPLES=OFF" ]; - buildInputs = [ zlib openssl libsodium ]; + buildInputs = [ + zlib + openssl + libsodium + ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; postFixup = '' substituteInPlace $dev/lib/cmake/libssh/libssh-config.cmake \ diff --git a/pkgs/by-name/li/libssh2/package.nix b/pkgs/by-name/li/libssh2/package.nix index 42f8acbc8f3f34..0239ca729c6a71 100644 --- a/pkgs/by-name/li/libssh2/package.nix +++ b/pkgs/by-name/li/libssh2/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, openssl -, zlib -, windows - -# for passthru.tests -, aria2 -, curl -, libgit2 -, mc -, vlc +{ + lib, + stdenv, + fetchurl, + openssl, + zlib, + windows, + + # for passthru.tests + aria2, + curl, + libgit2, + mc, + vlc, }: stdenv.mkDerivation rec { @@ -28,14 +29,22 @@ stdenv.mkDerivation rec { substituteInPlace ./config.guess --replace-fail /usr/bin/uname uname ''; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; propagatedBuildInputs = [ openssl ]; # see Libs: in libssh2.pc - buildInputs = [ zlib ] - ++ lib.optional stdenv.hostPlatform.isMinGW windows.mingw_w64; + buildInputs = [ zlib ] ++ lib.optional stdenv.hostPlatform.isMinGW windows.mingw_w64; passthru.tests = { - inherit aria2 libgit2 mc vlc; + inherit + aria2 + libgit2 + mc + vlc + ; curl = (curl.override { scpSupport = true; }).tests.withCheck; }; diff --git a/pkgs/by-name/li/libstaden-read/package.nix b/pkgs/by-name/li/libstaden-read/package.nix index dd2d93ae30a3ca..877c5042ff840c 100644 --- a/pkgs/by-name/li/libstaden-read/package.nix +++ b/pkgs/by-name/li/libstaden-read/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, bzip2 -, xz -, zlib +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + bzip2, + xz, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -15,7 +16,7 @@ stdenv.mkDerivation (finalAttrs: { src = fetchFromGitHub { owner = "jkbonfield"; repo = "io_lib"; - rev = "io_lib-" + builtins.replaceStrings ["."] ["-"] finalAttrs.version; + rev = "io_lib-" + builtins.replaceStrings [ "." ] [ "-" ] finalAttrs.version; fetchSubmodules = true; hash = "sha256-2Dlx+MXmqar81/Xmf0oE+6lWX461EDYijiZsZf/VD28="; }; @@ -25,7 +26,11 @@ stdenv.mkDerivation (finalAttrs: { ./libstaden-install-config-header.patch ]; - buildInputs = [ bzip2 xz zlib ]; + buildInputs = [ + bzip2 + xz + zlib + ]; nativeBuildInputs = [ autoreconfHook ]; # autoreconfHook does not descend into htscodecs folder @@ -40,7 +45,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://staden.sourceforge.net"; downloadPage = "https://github.com/jkbonfield/io_lib/releases"; changelog = "https://github.com/jkbonfield/io_lib/blob/${finalAttrs.src.rev}/CHANGES"; - license = with lib.licenses; [ bsd3 free ]; + license = with lib.licenses; [ + bsd3 + free + ]; platforms = lib.platforms.all; maintainers = [ lib.maintainers.kupac ]; }; diff --git a/pkgs/by-name/li/libstartup_notification/package.nix b/pkgs/by-name/li/libstartup_notification/package.nix index bf84345be2d110..374c92e963b35e 100644 --- a/pkgs/by-name/li/libstartup_notification/package.nix +++ b/pkgs/by-name/li/libstartup_notification/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchurl, libX11, libxcb, pkg-config, xcbutil}: +{ + lib, + stdenv, + fetchurl, + libX11, + libxcb, + pkg-config, + xcbutil, +}: stdenv.mkDerivation rec { pname = "libstartup-notification"; @@ -13,7 +21,11 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libX11 libxcb xcbutil ]; + buildInputs = [ + libX11 + libxcb + xcbutil + ]; meta = { homepage = "https://www.freedesktop.org/software/startup-notification"; diff --git a/pkgs/by-name/li/libstemmer/package.nix b/pkgs/by-name/li/libstemmer/package.nix index 3f66ee92a72e55..2df64013e2b6f0 100644 --- a/pkgs/by-name/li/libstemmer/package.nix +++ b/pkgs/by-name/li/libstemmer/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, perl, buildPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, + buildPackages, +}: stdenv.mkDerivation rec { pname = "libstemmer"; @@ -13,12 +19,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ perl ]; - prePatch = '' - patchShebangs . - '' + lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - substituteInPlace GNUmakefile \ - --replace './snowball' '${lib.getBin buildPackages.libstemmer}/bin/snowball' - ''; + prePatch = + '' + patchShebangs . + '' + + lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + substituteInPlace GNUmakefile \ + --replace './snowball' '${lib.getBin buildPackages.libstemmer}/bin/snowball' + ''; makeTarget = "libstemmer.a"; diff --git a/pkgs/by-name/li/libstroke/package.nix b/pkgs/by-name/li/libstroke/package.nix index d3f44a03810583..826dbeaa3c2970 100644 --- a/pkgs/by-name/li/libstroke/package.nix +++ b/pkgs/by-name/li/libstroke/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, automake -, autoconf -, libX11 +{ + lib, + stdenv, + fetchurl, + automake, + autoconf, + libX11, }: stdenv.mkDerivation rec { @@ -19,16 +20,19 @@ stdenv.mkDerivation rec { sed -i 1i'#include ' libstroke/stroke.c ''; - nativeBuildInputs = [ automake autoconf ]; + nativeBuildInputs = [ + automake + autoconf + ]; buildInputs = [ libX11 ]; # libstroke ships with an ancient config.sub that doesn't know about x86_64, so regenerate it. # Also, modern automake doesn't like things and returns error code 63. But it generates the file. preConfigure = '' - rm config.sub - autoconf - automake -a || true - ''; + rm config.sub + autoconf + automake -a || true + ''; meta = { description = "Library for simple gesture recognition"; diff --git a/pkgs/by-name/li/libstrophe/package.nix b/pkgs/by-name/li/libstrophe/package.nix index c78411b5c4f20f..ecb3a87c77dce4 100644 --- a/pkgs/by-name/li/libstrophe/package.nix +++ b/pkgs/by-name/li/libstrophe/package.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, libtool -, openssl -, expat -, pkg-config -, check -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libtool, + openssl, + expat, + pkg-config, + check, + zlib, }: stdenv.mkDerivation rec { @@ -20,8 +22,17 @@ stdenv.mkDerivation rec { hash = "sha256-JMuvWspgXs+1dVWoo6kJVaf6cVvYj8lhyyu4ZILKeOg="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ openssl expat libtool check zlib ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + openssl + expat + libtool + check + zlib + ]; dontDisableStatic = true; @@ -38,9 +49,14 @@ stdenv.mkDerivation rec { ''; homepage = "https://strophe.im/libstrophe/"; changelog = "https://github.com/strophe/libstrophe/blob/${src.rev}/ChangeLog"; - license = with licenses; [ gpl3Only mit ]; + license = with licenses; [ + gpl3Only + mit + ]; platforms = platforms.unix; - maintainers = with maintainers; [ devhell flosse ]; + maintainers = with maintainers; [ + devhell + flosse + ]; }; } - diff --git a/pkgs/by-name/li/libsurvive/package.nix b/pkgs/by-name/li/libsurvive/package.nix index 4e5418de689aa0..35f649b3d86d67 100644 --- a/pkgs/by-name/li/libsurvive/package.nix +++ b/pkgs/by-name/li/libsurvive/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, libglut -, lapack -, libusb1 -, blas -, zlib -, eigen +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libglut, + lapack, + libusb1, + blas, + zlib, + eigen, }: stdenv.mkDerivation rec { @@ -23,7 +25,10 @@ stdenv.mkDerivation rec { hash = "sha256-NcxdTKra+YkLt/iu9+1QCeQZLV3/qlhma2Ns/+ZYVsk="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libglut diff --git a/pkgs/by-name/li/libsvm/package.nix b/pkgs/by-name/li/libsvm/package.nix index 1fd5141c9084f1..4653352086fe35 100644 --- a/pkgs/by-name/li/libsvm/package.nix +++ b/pkgs/by-name/li/libsvm/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, fixDarwinDylibNames -, llvmPackages -, withOpenMP ? true +{ + lib, + stdenv, + fetchurl, + fixDarwinDylibNames, + llvmPackages, + withOpenMP ? true, }: stdenv.mkDerivation rec { @@ -19,9 +20,16 @@ stdenv.mkDerivation rec { buildInputs = lib.optionals (stdenv.cc.isClang && withOpenMP) [ llvmPackages.openmp ]; - buildFlags = [ "lib" "all" ]; + buildFlags = [ + "lib" + "all" + ]; - outputs = [ "out" "bin" "dev" ]; + outputs = [ + "out" + "bin" + "dev" + ]; nativeBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ fixDarwinDylibNames ]; @@ -29,7 +37,11 @@ stdenv.mkDerivation rec { let libSuff = stdenv.hostPlatform.extensions.sharedLibrary; soVersion = "3"; - libName = if stdenv.hostPlatform.isDarwin then "libsvm.${soVersion}${libSuff}" else "libsvm${libSuff}.${soVersion}"; + libName = + if stdenv.hostPlatform.isDarwin then + "libsvm.${soVersion}${libSuff}" + else + "libsvm${libSuff}.${soVersion}"; in '' runHook preInstall diff --git a/pkgs/by-name/li/libsystemtap/package.nix b/pkgs/by-name/li/libsystemtap/package.nix index c227f689074b91..9c798b956f7a7b 100644 --- a/pkgs/by-name/li/libsystemtap/package.nix +++ b/pkgs/by-name/li/libsystemtap/package.nix @@ -1,7 +1,10 @@ -{ lib, stdenv, fetchgit -, gettext -, python3 -, elfutils +{ + lib, + stdenv, + fetchgit, + gettext, + python3, + elfutils, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/li/libtap/package.nix b/pkgs/by-name/li/libtap/package.nix index 46b2e492cb3534..cda5e0d3bf5776 100644 --- a/pkgs/by-name/li/libtap/package.nix +++ b/pkgs/by-name/li/libtap/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, cmake, perl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + cmake, + perl, +}: stdenv.mkDerivation rec { @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ cmake perl ]; + propagatedBuildInputs = [ + cmake + perl + ]; meta = with lib; { description = "Library to implement a test protocol"; diff --git a/pkgs/by-name/li/libtar/package.nix b/pkgs/by-name/li/libtar/package.nix index 6a9f3d4a50a786..9c5d3dbedf0ac4 100644 --- a/pkgs/by-name/li/libtar/package.nix +++ b/pkgs/by-name/li/libtar/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchgit, fetchpatch, autoreconfHook }: +{ + lib, + stdenv, + fetchgit, + fetchpatch, + autoreconfHook, +}: stdenv.mkDerivation rec { version = "1.2.20"; @@ -11,21 +17,24 @@ stdenv.mkDerivation rec { sha256 = "1pjsqnqjaqgkzf1j8m6y5h76bwprffsjjj6gk8rh2fjsha14rqn9"; }; - patches = let - fp = name: sha256: - fetchpatch { - url = "https://sources.debian.net/data/main/libt/libtar/1.2.20-4/debian/patches/${name}.patch"; - inherit sha256; - }; - in [ + patches = + let + fp = + name: sha256: + fetchpatch { + url = "https://sources.debian.net/data/main/libt/libtar/1.2.20-4/debian/patches/${name}.patch"; + inherit sha256; + }; + in + [ (fetchpatch { name = "no_static_buffers.patch"; url = "https://src.fedoraproject.org/rpms/libtar/raw/e25b692fc7ceaa387dafb865b472510754f51bd2/f/libtar-1.2.20-no-static-buffer.patch"; sha256 = "sha256-QcWOgdkNlALb+YDVneT1zCNAMf4d8IUm2kUUUy2VvJs="; }) - (fp "no_maxpathlen" "11riv231wpbdb1cm4nbdwdsik97wny5sxcwdgknqbp61ibk572b7") - (fp "CVE-2013-4420" "0d010190bqgr2ggy02qwxvjaymy9a22jmyfwdfh4086v876cbxpq") - (fp "th_get_size-unsigned-int" "1ravbs5yrfac98mnkrzciw9hd2fxq4dc07xl3wx8y2pv1bzkwm41") + (fp "no_maxpathlen" "11riv231wpbdb1cm4nbdwdsik97wny5sxcwdgknqbp61ibk572b7") + (fp "CVE-2013-4420" "0d010190bqgr2ggy02qwxvjaymy9a22jmyfwdfh4086v876cbxpq") + (fp "th_get_size-unsigned-int" "1ravbs5yrfac98mnkrzciw9hd2fxq4dc07xl3wx8y2pv1bzkwm41") (fetchpatch { name = "CVE-2021-33643_CVE-2021-33644.patch"; url = "https://src.fedoraproject.org/rpms/libtar/raw/e25b692fc7ceaa387dafb865b472510754f51bd2/f/libtar-1.2.20-CVE-2021-33643-CVE-2021-33644.patch"; diff --git a/pkgs/by-name/li/libtasn1/package.nix b/pkgs/by-name/li/libtasn1/package.nix index 9d3e181701bde1..21986252b919f9 100644 --- a/pkgs/by-name/li/libtasn1/package.nix +++ b/pkgs/by-name/li/libtasn1/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, perl -, texinfo - -# for passthru.tests -, gnutls -, samba -, qemu +{ + lib, + stdenv, + fetchurl, + perl, + texinfo, + + # for passthru.tests + gnutls, + samba, + qemu, }: stdenv.mkDerivation rec { @@ -19,16 +20,21 @@ stdenv.mkDerivation rec { sha256 = "sha256-FhPwrBz0hNbsDOO4wG1WJjzHJC8cI7MNgtI940WmP3o="; }; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "dev"; - nativeBuildInputs = [ texinfo perl ]; + nativeBuildInputs = [ + texinfo + perl + ]; doCheck = true; - preCheck = if stdenv.hostPlatform.isDarwin then - "export DYLD_LIBRARY_PATH=`pwd`/lib/.libs" - else - null; + preCheck = + if stdenv.hostPlatform.isDarwin then "export DYLD_LIBRARY_PATH=`pwd`/lib/.libs" else null; passthru.tests = { inherit gnutls samba qemu; diff --git a/pkgs/by-name/li/libtcod/package.nix b/pkgs/by-name/li/libtcod/package.nix index 3674f25b465903..678ce9c46f5aea 100644 --- a/pkgs/by-name/li/libtcod/package.nix +++ b/pkgs/by-name/li/libtcod/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromBitbucket, cmake, SDL, libGLU, libGL, upx, zlib }: +{ + lib, + stdenv, + fetchFromBitbucket, + cmake, + SDL, + libGLU, + libGL, + upx, + zlib, +}: stdenv.mkDerivation { @@ -22,7 +32,13 @@ stdenv.mkDerivation { cmakeFlags = [ "-DLIBTCOD_SAMPLES=OFF" ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ SDL libGLU libGL upx zlib ]; + buildInputs = [ + SDL + libGLU + libGL + upx + zlib + ]; meta = { description = "API for roguelike games"; diff --git a/pkgs/by-name/li/libtelnet/package.nix b/pkgs/by-name/li/libtelnet/package.nix index eebaee394ee0ff..b2243d30113a0f 100644 --- a/pkgs/by-name/li/libtelnet/package.nix +++ b/pkgs/by-name/li/libtelnet/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, autoreconfHook, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + zlib, +}: stdenv.mkDerivation { pname = "libtelnet"; @@ -11,7 +18,10 @@ stdenv.mkDerivation { sha256 = "1lp6gdbndsp2w8mhy88c2jknxj2klvnggvq04ln7qjg8407ifpda"; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; buildInputs = [ zlib ]; meta = { diff --git a/pkgs/by-name/li/libtermkey/package.nix b/pkgs/by-name/li/libtermkey/package.nix index a96baf0d9f3e04..4fe2408d80d660 100644 --- a/pkgs/by-name/li/libtermkey/package.nix +++ b/pkgs/by-name/li/libtermkey/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchzip, libtool, pkg-config, ncurses, unibilium }: +{ + stdenv, + lib, + fetchzip, + libtool, + pkg-config, + ncurses, + unibilium, +}: stdenv.mkDerivation rec { pname = "libtermkey"; @@ -9,10 +17,19 @@ stdenv.mkDerivation rec { sha256 = "02dks6bj7n23lj005yq41azf95wh3hapmgc2lzyh12vigkjh67rg"; }; - makeFlags = [ "PREFIX=$(out)" "LIBTOOL=${libtool}/bin/libtool" ]; + makeFlags = [ + "PREFIX=$(out)" + "LIBTOOL=${libtool}/bin/libtool" + ]; - nativeBuildInputs = [ libtool pkg-config ]; - buildInputs = [ ncurses unibilium ]; + nativeBuildInputs = [ + libtool + pkg-config + ]; + buildInputs = [ + ncurses + unibilium + ]; strictDeps = true; diff --git a/pkgs/by-name/li/libthai/package.nix b/pkgs/by-name/li/libthai/package.nix index a72bfc6f25d598..bde18a05198558 100644 --- a/pkgs/by-name/li/libthai/package.nix +++ b/pkgs/by-name/li/libthai/package.nix @@ -1,10 +1,20 @@ -{ lib, stdenv, fetchurl, installShellFiles, pkg-config, libdatrie }: +{ + lib, + stdenv, + fetchurl, + installShellFiles, + pkg-config, + libdatrie, +}: stdenv.mkDerivation rec { pname = "libthai"; version = "0.1.29"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "https://github.com/tlwg/libthai/releases/download/v${version}/libthai-${version}.tar.xz"; @@ -13,7 +23,11 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ installShellFiles (lib.getBin libdatrie) pkg-config ]; + nativeBuildInputs = [ + installShellFiles + (lib.getBin libdatrie) + pkg-config + ]; buildInputs = [ libdatrie ]; diff --git a/pkgs/by-name/li/libthreadar/package.nix b/pkgs/by-name/li/libthreadar/package.nix index bd6a7b1a49b5fe..549142ad0d5277 100644 --- a/pkgs/by-name/li/libthreadar/package.nix +++ b/pkgs/by-name/li/libthreadar/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gcc-unwrapped }: +{ + lib, + stdenv, + fetchurl, + gcc-unwrapped, +}: stdenv.mkDerivation rec { version = "1.5.0"; @@ -9,7 +14,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-wJAkIUGK7Ud6n2p1275vNkSx/W7LlgKWXQaDevetPko="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; buildInputs = [ gcc-unwrapped ]; diff --git a/pkgs/by-name/li/libticables2/package.nix b/pkgs/by-name/li/libticables2/package.nix index 5beab9b14c1e1f..162b8332c7f5fc 100644 --- a/pkgs/by-name/li/libticables2/package.nix +++ b/pkgs/by-name/li/libticables2/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchurl -, fetchpatch -, pkg-config -, autoreconfHook -, glib -, libusb1 +{ + stdenv, + lib, + fetchurl, + fetchpatch, + pkg-config, + autoreconfHook, + glib, + libusb1, }: stdenv.mkDerivation rec { @@ -68,7 +69,10 @@ stdenv.mkDerivation rec { description = "This library is part of the TiLP framework"; homepage = "http://lpg.ticalc.org/prj_tilp/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ siraben clevor ]; + maintainers = with maintainers; [ + siraben + clevor + ]; platforms = with platforms; linux ++ darwin; }; } diff --git a/pkgs/by-name/li/libtickit/package.nix b/pkgs/by-name/li/libtickit/package.nix index eaecc2d6d8bdd4..c67745e3e771de 100644 --- a/pkgs/by-name/li/libtickit/package.nix +++ b/pkgs/by-name/li/libtickit/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, libtool -, perl -, libtermkey -, unibilium +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libtool, + perl, + libtermkey, + unibilium, }: let version = "0.4.3"; diff --git a/pkgs/by-name/li/libticonv/package.nix b/pkgs/by-name/li/libticonv/package.nix index 1fb708823a3fe8..5ef5348b794744 100644 --- a/pkgs/by-name/li/libticonv/package.nix +++ b/pkgs/by-name/li/libticonv/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, autoreconfHook -, glib +{ + stdenv, + lib, + fetchurl, + pkg-config, + autoreconfHook, + glib, }: stdenv.mkDerivation rec { @@ -32,7 +33,10 @@ stdenv.mkDerivation rec { description = "This library is part of the TiLP framework"; homepage = "http://lpg.ticalc.org/prj_tilp/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ siraben clevor ]; + maintainers = with maintainers; [ + siraben + clevor + ]; platforms = with platforms; linux ++ darwin; }; } diff --git a/pkgs/by-name/li/libtiff/package.nix b/pkgs/by-name/li/libtiff/package.nix index 7ad8f84fc2a12c..674369df1cd07b 100644 --- a/pkgs/by-name/li/libtiff/package.nix +++ b/pkgs/by-name/li/libtiff/package.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, nix-update-script - -, autoreconfHook -, pkg-config -, sphinx - -, lerc -, libdeflate -, libjpeg -, libwebp -, xz -, zlib -, zstd +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + nix-update-script, + + autoreconfHook, + pkg-config, + sphinx, + + lerc, + libdeflate, + libjpeg, + libwebp, + xz, + zlib, + zstd, # for passthru.tests -, libgeotiff -, python3Packages -, imagemagick -, graphicsmagick -, gdal -, openimageio -, freeimage -, testers + libgeotiff, + python3Packages, + imagemagick, + graphicsmagick, + gdal, + openimageio, + freeimage, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -50,7 +51,14 @@ stdenv.mkDerivation (finalAttrs: { mv VERSION VERSION.txt ''; - outputs = [ "bin" "dev" "dev_private" "out" "man" "doc" ]; + outputs = [ + "bin" + "dev" + "dev_private" + "out" + "man" + "doc" + ]; postFixup = '' moveToOutput include/tif_config.h $dev_private @@ -61,7 +69,11 @@ stdenv.mkDerivation (finalAttrs: { # If you want to change to a different build system, please make # sure cross-compilation works first! - nativeBuildInputs = [ autoreconfHook pkg-config sphinx ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + sphinx + ]; buildInputs = [ lerc @@ -88,7 +100,14 @@ stdenv.mkDerivation (finalAttrs: { passthru = { tests = { - inherit libgeotiff imagemagick graphicsmagick gdal openimageio freeimage; + inherit + libgeotiff + imagemagick + graphicsmagick + gdal + openimageio + freeimage + ; inherit (python3Packages) pillow imread; pkg-config = testers.hasPkgConfigModules { package = finalAttrs.finalPackage; diff --git a/pkgs/by-name/li/libtifiles2/package.nix b/pkgs/by-name/li/libtifiles2/package.nix index 3ff14e69a0c14d..6e253660440703 100644 --- a/pkgs/by-name/li/libtifiles2/package.nix +++ b/pkgs/by-name/li/libtifiles2/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, autoreconfHook -, glib -, libarchive -, libticonv +{ + stdenv, + lib, + fetchurl, + pkg-config, + autoreconfHook, + glib, + libarchive, + libticonv, }: stdenv.mkDerivation rec { @@ -32,7 +33,10 @@ stdenv.mkDerivation rec { description = "This library is part of the TiLP framework"; homepage = "http://lpg.ticalc.org/prj_tilp/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ siraben clevor ]; + maintainers = with maintainers; [ + siraben + clevor + ]; platforms = with platforms; linux ++ darwin; }; } diff --git a/pkgs/by-name/li/libtiger/package.nix b/pkgs/by-name/li/libtiger/package.nix index 149f5e65fc418f..09211b89c89b39 100644 --- a/pkgs/by-name/li/libtiger/package.nix +++ b/pkgs/by-name/li/libtiger/package.nix @@ -1,5 +1,13 @@ -{ stdenv, lib, fetchurl, autoreconfHook, pkg-config -, libkate, pango, cairo, darwin +{ + stdenv, + lib, + fetchurl, + autoreconfHook, + pkg-config, + libkate, + pango, + cairo, + darwin, }: stdenv.mkDerivation rec { @@ -19,9 +27,15 @@ stdenv.mkDerivation rec { substituteInPlace configure.ac --replace "-Werror" "-Wno-error" ''; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libkate pango cairo ] - ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.ApplicationServices; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libkate + pango + cairo + ] ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.ApplicationServices; meta = { homepage = "https://code.google.com/archive/p/libtiger/"; diff --git a/pkgs/by-name/li/libtins/package.nix b/pkgs/by-name/li/libtins/package.nix index 6f195615551fbf..c433d5dbb37a75 100644 --- a/pkgs/by-name/li/libtins/package.nix +++ b/pkgs/by-name/li/libtins/package.nix @@ -1,4 +1,13 @@ -{ boost, cmake, fetchFromGitHub, gtest, libpcap, openssl, lib, stdenv }: +{ + boost, + cmake, + fetchFromGitHub, + gtest, + libpcap, + openssl, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "libtins"; @@ -23,7 +32,10 @@ stdenv.mkDerivation rec { chmod -R a+w googletest ''; - nativeBuildInputs = [ cmake gtest ]; + nativeBuildInputs = [ + cmake + gtest + ]; buildInputs = [ openssl libpcap diff --git a/pkgs/by-name/li/libtirpc/package.nix b/pkgs/by-name/li/libtirpc/package.nix index 1a1cf14c9ea883..caf70fbe096717 100644 --- a/pkgs/by-name/li/libtirpc/package.nix +++ b/pkgs/by-name/li/libtirpc/package.nix @@ -1,16 +1,27 @@ -{ fetchurl, lib, stdenv, autoreconfHook, libkrb5 }: +{ + fetchurl, + lib, + stdenv, + autoreconfHook, + libkrb5, +}: stdenv.mkDerivation rec { pname = "libtirpc"; version = "1.3.5"; src = fetchurl { - url = "http://git.linux-nfs.org/?p=steved/libtirpc.git;a=snapshot;h=refs/tags/libtirpc-${lib.replaceStrings ["."] ["-"] version};sf=tgz"; + url = "http://git.linux-nfs.org/?p=steved/libtirpc.git;a=snapshot;h=refs/tags/libtirpc-${ + lib.replaceStrings [ "." ] [ "-" ] version + };sf=tgz"; hash = "sha256-bq2zfqfMJsJ6gezLCUTlNiRXJhFxFslY4iW+4kpOPVE="; name = "${pname}-${version}.tar.gz"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; KRB5_CONFIG = "${libkrb5.dev}/bin/krb5-config"; nativeBuildInputs = [ autoreconfHook ]; @@ -36,17 +47,17 @@ stdenv.mkDerivation rec { platforms = platforms.linux; maintainers = with maintainers; [ abbradar ]; longDescription = '' - Currently, NFS commands use the SunRPC routines provided by the - glibc. These routines do not support IPv6 addresses. Ulrich - Drepper, who is the maintainer of the glibc, refuses any change in - the glibc concerning the RPC. He wants the RPC to become a separate - library. Other OS (NetBSD, FreeBSD, Solarix, HP-UX, AIX) have - migrated their SunRPC library to a TI-RPC (Transport Independent - RPC) implementation. This implementation allows the support of - other transports than UDP and TCP over IPv4. FreeBSD provides a - TI-RPC library ported from NetBSD with improvements. This library - already supports IPv6. So, the FreeBSD release 5.2.1 TI-RPC has - been ported to replace the SunRPC of the glibc. + Currently, NFS commands use the SunRPC routines provided by the + glibc. These routines do not support IPv6 addresses. Ulrich + Drepper, who is the maintainer of the glibc, refuses any change in + the glibc concerning the RPC. He wants the RPC to become a separate + library. Other OS (NetBSD, FreeBSD, Solarix, HP-UX, AIX) have + migrated their SunRPC library to a TI-RPC (Transport Independent + RPC) implementation. This implementation allows the support of + other transports than UDP and TCP over IPv4. FreeBSD provides a + TI-RPC library ported from NetBSD with improvements. This library + already supports IPv6. So, the FreeBSD release 5.2.1 TI-RPC has + been ported to replace the SunRPC of the glibc. ''; }; } diff --git a/pkgs/by-name/li/libtomcrypt/package.nix b/pkgs/by-name/li/libtomcrypt/package.nix index 568d1a22c6a808..b44b19cc53cf86 100644 --- a/pkgs/by-name/li/libtomcrypt/package.nix +++ b/pkgs/by-name/li/libtomcrypt/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, fetchpatch, libtool, libtommath }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libtool, + libtommath, +}: stdenv.mkDerivation rec { pname = "libtomcrypt"; @@ -21,7 +28,10 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ libtool libtommath ]; + nativeBuildInputs = [ + libtool + libtommath + ]; postPatch = '' substituteInPlace makefile.shared --replace "LIBTOOL:=glibtool" "LIBTOOL:=libtool" @@ -43,7 +53,10 @@ stdenv.mkDerivation rec { description = "Fairly comprehensive, modular and portable cryptographic toolkit"; homepage = "https://www.libtom.net/LibTomCrypt/"; changelog = "https://github.com/libtom/libtomcrypt/raw/v${version}/changes"; - license = with licenses; [ publicDomain wtfpl ]; + license = with licenses; [ + publicDomain + wtfpl + ]; maintainers = [ ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/li/libtommath/package.nix b/pkgs/by-name/li/libtommath/package.nix index 56225f96de8c4b..cfc07912e46d86 100644 --- a/pkgs/by-name/li/libtommath/package.nix +++ b/pkgs/by-name/li/libtommath/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libtool }: +{ + lib, + stdenv, + fetchurl, + libtool, +}: stdenv.mkDerivation rec { pname = "libtommath"; @@ -24,14 +29,19 @@ stdenv.mkDerivation rec { makefile = "makefile.shared"; - env.NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) "-DTARGET_OS_IPHONE=0"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 + ) "-DTARGET_OS_IPHONE=0"; enableParallelBuilding = true; meta = with lib; { homepage = "https://www.libtom.net/LibTomMath/"; description = "Library for integer-based number-theoretic applications"; - license = with licenses; [ publicDomain wtfpl ]; + license = with licenses; [ + publicDomain + wtfpl + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/li/libtorrent-rasterbar-2_0_x/package.nix b/pkgs/by-name/li/libtorrent-rasterbar-2_0_x/package.nix index 3f85048e4eb715..236b930a994dbf 100644 --- a/pkgs/by-name/li/libtorrent-rasterbar-2_0_x/package.nix +++ b/pkgs/by-name/li/libtorrent-rasterbar-2_0_x/package.nix @@ -1,14 +1,27 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, zlib, boost, openssl, python3, ncurses, darwin +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, + boost, + openssl, + python3, + ncurses, + darwin, }: let version = "2.0.10"; # Make sure we override python, so the correct version is chosen - boostPython = boost.override { enablePython = true; python = python3; }; + boostPython = boost.override { + enablePython = true; + python = python3; + }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "libtorrent-rasterbar"; inherit version; @@ -22,8 +35,13 @@ in stdenv.mkDerivation { nativeBuildInputs = [ cmake ]; - buildInputs = [ boostPython openssl zlib python3 ncurses ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; + buildInputs = [ + boostPython + openssl + zlib + python3 + ncurses + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; patches = [ # provide distutils alternative for python 3.12 @@ -50,7 +68,11 @@ in stdenv.mkDerivation { --replace "\''${_IMPORT_PREFIX}/lib" "$out/lib" ''; - outputs = [ "out" "dev" "python" ]; + outputs = [ + "out" + "dev" + "python" + ]; cmakeFlags = [ "-Dpython-bindings=on" diff --git a/pkgs/by-name/li/libtoxcore/package.nix b/pkgs/by-name/li/libtoxcore/package.nix index 7e7619b1a2fbff..41d60e68363f6e 100644 --- a/pkgs/by-name/li/libtoxcore/package.nix +++ b/pkgs/by-name/li/libtoxcore/package.nix @@ -1,26 +1,28 @@ -{ lib -, stdenv -, fetchurl -, cmake -, libsodium -, ncurses -, libopus -, libvpx -, check -, libconfig -, pkg-config +{ + lib, + stdenv, + fetchurl, + cmake, + libsodium, + ncurses, + libopus, + libvpx, + check, + libconfig, + pkg-config, }: -let buildToxAV = !stdenv.hostPlatform.isAarch32; -in stdenv.mkDerivation rec { +let + buildToxAV = !stdenv.hostPlatform.isAarch32; +in +stdenv.mkDerivation rec { pname = "libtoxcore"; version = "0.2.20"; src = # We need the prepared sources tarball. fetchurl { - url = - "https://github.com/TokTok/c-toxcore/releases/download/v${version}/c-toxcore-${version}.tar.gz"; + url = "https://github.com/TokTok/c-toxcore/releases/download/v${version}/c-toxcore-${version}.tar.gz"; hash = "sha256-qciaja6nRdU+XXjnqsuZx7R5LEQApaaccSOPRdYWT0w="; }; @@ -29,16 +31,21 @@ in stdenv.mkDerivation rec { "-DBOOTSTRAP_DAEMON=ON" ] ++ lib.optional buildToxAV "-DMUST_BUILD_TOXAV=ON"; - buildInputs = [ - libsodium - ncurses - libconfig - ] ++ lib.optionals buildToxAV [ - libopus - libvpx - ]; + buildInputs = + [ + libsodium + ncurses + libconfig + ] + ++ lib.optionals buildToxAV [ + libopus + libvpx + ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; doCheck = true; nativeCheckInputs = [ check ]; @@ -55,7 +62,10 @@ in stdenv.mkDerivation rec { description = "P2P FOSS instant messaging application aimed to replace Skype"; homepage = "https://tox.chat"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ peterhoeg ehmry ]; + maintainers = with lib.maintainers; [ + peterhoeg + ehmry + ]; platforms = lib.platforms.all; }; } diff --git a/pkgs/by-name/li/libtpms/package.nix b/pkgs/by-name/li/libtpms/package.nix index 5ac368eea9f061..7f8d15a798429b 100644 --- a/pkgs/by-name/li/libtpms/package.nix +++ b/pkgs/by-name/li/libtpms/package.nix @@ -1,8 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config, autoreconfHook -, openssl, perl +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + openssl, + perl, }: stdenv.mkDerivation rec { @@ -23,7 +26,11 @@ stdenv.mkDerivation rec { ]; buildInputs = [ openssl ]; - outputs = [ "out" "man" "dev" ]; + outputs = [ + "out" + "man" + "dev" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/li/libtraceevent/package.nix b/pkgs/by-name/li/libtraceevent/package.nix index 0b9843cc4a5370..ec5cc5fcb3c126 100644 --- a/pkgs/by-name/li/libtraceevent/package.nix +++ b/pkgs/by-name/li/libtraceevent/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchgit, pkg-config, asciidoc, xmlto, docbook_xml_dtd_45, docbook_xsl, meson, ninja, cunit, gitUpdater }: +{ + lib, + stdenv, + fetchgit, + pkg-config, + asciidoc, + xmlto, + docbook_xml_dtd_45, + docbook_xsl, + meson, + ninja, + cunit, + gitUpdater, +}: stdenv.mkDerivation rec { pname = "libtraceevent"; @@ -15,10 +28,26 @@ stdenv.mkDerivation rec { patchShebangs --build check-manpages.sh Documentation/install-docs.sh.in ''; - outputs = [ "out" "dev" "devman" "doc" ]; - nativeBuildInputs = [ meson ninja pkg-config asciidoc xmlto docbook_xml_dtd_45 docbook_xsl ]; + outputs = [ + "out" + "dev" + "devman" + "doc" + ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + asciidoc + xmlto + docbook_xml_dtd_45 + docbook_xsl + ]; - ninjaFlags = [ "all" "docs" ]; + ninjaFlags = [ + "all" + "docs" + ]; doCheck = true; checkInputs = [ cunit ]; @@ -31,9 +60,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Linux kernel trace event library"; - homepage = "https://git.kernel.org/pub/scm/libs/libtrace/libtraceevent.git/"; - license = licenses.lgpl21Only; - platforms = platforms.linux; + homepage = "https://git.kernel.org/pub/scm/libs/libtrace/libtraceevent.git/"; + license = licenses.lgpl21Only; + platforms = platforms.linux; maintainers = with maintainers; [ wentasah ]; }; } diff --git a/pkgs/by-name/li/libtracefs/package.nix b/pkgs/by-name/li/libtracefs/package.nix index d35b9e709626f2..d60221e81afdbd 100644 --- a/pkgs/by-name/li/libtracefs/package.nix +++ b/pkgs/by-name/li/libtracefs/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchzip -, pkg-config -, libtraceevent -, asciidoc -, xmlto -, docbook_xml_dtd_45 -, docbook_xsl -, valgrind -, sourceHighlight -, meson -, flex -, bison -, ninja -, cunit -, gitUpdater -, fetchpatch +{ + lib, + stdenv, + fetchzip, + pkg-config, + libtraceevent, + asciidoc, + xmlto, + docbook_xml_dtd_45, + docbook_xsl, + valgrind, + sourceHighlight, + meson, + flex, + bison, + ninja, + cunit, + gitUpdater, + fetchpatch, }: stdenv.mkDerivation rec { @@ -40,7 +41,12 @@ stdenv.mkDerivation rec { patchShebangs --build check-manpages.sh samples/extract-example.sh Documentation/install-docs.sh.in ''; - outputs = [ "out" "dev" "devman" "doc" ]; + outputs = [ + "out" + "dev" + "devman" + "doc" + ]; nativeBuildInputs = [ meson ninja @@ -56,7 +62,10 @@ stdenv.mkDerivation rec { ]; buildInputs = [ libtraceevent ]; - ninjaFlags = [ "all" "docs" ]; + ninjaFlags = [ + "all" + "docs" + ]; doCheck = true; checkInputs = [ cunit ]; @@ -70,9 +79,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Linux kernel trace file system library"; mainProgram = "sqlhist"; - homepage = "https://git.kernel.org/pub/scm/libs/libtrace/libtracefs.git/"; - license = licenses.lgpl21Only; - platforms = platforms.linux; + homepage = "https://git.kernel.org/pub/scm/libs/libtrace/libtracefs.git/"; + license = licenses.lgpl21Only; + platforms = platforms.linux; maintainers = with maintainers; [ wentasah ]; }; } diff --git a/pkgs/by-name/li/libtree/package.nix b/pkgs/by-name/li/libtree/package.nix index 621ab218669ec8..423280978086ec 100644 --- a/pkgs/by-name/li/libtree/package.nix +++ b/pkgs/by-name/li/libtree/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, testers -, libtree -, runCommand -, coreutils -, dieHook +{ + lib, + stdenv, + fetchFromGitHub, + testers, + libtree, + runCommand, + coreutils, + dieHook, }: stdenv.mkDerivation (finalAttrs: { @@ -30,12 +31,18 @@ stdenv.mkDerivation (finalAttrs: { command = "libtree --version"; version = finalAttrs.version; }; - checkCoreUtils = runCommand "${finalAttrs.pname}-ls-test" { - nativeBuildInputs = [ finalAttrs.finalPackage dieHook ]; - } '' - libtree ${coreutils}/bin/ls > $out || die "libtree failed to show dependencies." - [ -s $out ] - ''; + checkCoreUtils = + runCommand "${finalAttrs.pname}-ls-test" + { + nativeBuildInputs = [ + finalAttrs.finalPackage + dieHook + ]; + } + '' + libtree ${coreutils}/bin/ls > $out || die "libtree failed to show dependencies." + [ -s $out ] + ''; }; meta = with lib; { @@ -44,6 +51,9 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/haampie/libtree"; license = licenses.mit; platforms = platforms.linux; - maintainers = with maintainers; [ prusnak rardiol ]; + maintainers = with maintainers; [ + prusnak + rardiol + ]; }; }) diff --git a/pkgs/by-name/li/libtsm/package.nix b/pkgs/by-name/li/libtsm/package.nix index bcf9270a7158e2..9de5e44acad6ef 100644 --- a/pkgs/by-name/li/libtsm/package.nix +++ b/pkgs/by-name/li/libtsm/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, libxkbcommon, pkg-config, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + libxkbcommon, + pkg-config, + cmake, +}: stdenv.mkDerivation rec { pname = "libtsm"; @@ -13,7 +20,10 @@ stdenv.mkDerivation rec { buildInputs = [ libxkbcommon ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; # https://github.com/Aetf/libtsm/issues/20 postPatch = '' diff --git a/pkgs/by-name/li/libu2f-host/package.nix b/pkgs/by-name/li/libu2f-host/package.nix index 724a3b6b3118bc..dcf975eeb93512 100644 --- a/pkgs/by-name/li/libu2f-host/package.nix +++ b/pkgs/by-name/li/libu2f-host/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, json_c, hidapi }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + json_c, + hidapi, +}: stdenv.mkDerivation rec { pname = "libu2f-host"; @@ -19,14 +27,20 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ json_c hidapi ]; + buildInputs = [ + json_c + hidapi + ]; doCheck = true; meta = with lib; { description = "C library and command-line tool that implements the host-side of the U2F protocol"; homepage = "https://developers.yubico.com/libu2f-host"; - license = with licenses; [ gpl3Plus lgpl21Plus ]; + license = with licenses; [ + gpl3Plus + lgpl21Plus + ]; mainProgram = "u2f-host"; platforms = platforms.unix; }; diff --git a/pkgs/by-name/li/libu2f-server/package.nix b/pkgs/by-name/li/libu2f-server/package.nix index 86f0245b2ed741..ae8a05ea00b600 100644 --- a/pkgs/by-name/li/libu2f-server/package.nix +++ b/pkgs/by-name/li/libu2f-server/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, json_c, openssl, check, file, help2man, which, gengetopt }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + json_c, + openssl, + check, + file, + help2man, + which, + gengetopt, +}: stdenv.mkDerivation rec { pname = "libu2f-server"; @@ -18,7 +31,15 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ json_c openssl check file help2man which gengetopt ]; + buildInputs = [ + json_c + openssl + check + file + help2man + which + gengetopt + ]; meta = with lib; { homepage = "https://developers.yubico.com/libu2f-server/"; diff --git a/pkgs/by-name/li/libuchardet/package.nix b/pkgs/by-name/li/libuchardet/package.nix index 12f210593107e4..321a1d04257639 100644 --- a/pkgs/by-name/li/libuchardet/package.nix +++ b/pkgs/by-name/li/libuchardet/package.nix @@ -1,10 +1,20 @@ -{ lib, stdenv, fetchurl, cmake }: +{ + lib, + stdenv, + fetchurl, + cmake, +}: stdenv.mkDerivation rec { pname = "uchardet"; version = "0.0.8"; - outputs = [ "bin" "out" "man" "dev" ]; + outputs = [ + "bin" + "out" + "man" + "dev" + ]; src = fetchurl { url = "https://www.freedesktop.org/software/${pname}/releases/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/li/libucl/package.nix b/pkgs/by-name/li/libucl/package.nix index 0adb3a66465efb..8919d545fa5c91 100644 --- a/pkgs/by-name/li/libucl/package.nix +++ b/pkgs/by-name/li/libucl/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config -, autoreconfHook -, curl -, lua -, openssl -, features ? { +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + curl, + lua, + openssl, + features ? { urls = false; # Upstream enables regex by default regex = true; @@ -13,7 +15,7 @@ signatures = false; lua = false; utils = false; - } + }, }: let @@ -34,17 +36,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-esNEVBa660rl3Oo2SLaLrFThFkjbqtZ1r0tjMq3h6cM="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; buildInputs = lib.concatLists ( - lib.mapAttrsToList (feat: enabled: - lib.optionals enabled (featureDeps."${feat}" or []) - ) features - ); + lib.mapAttrsToList (feat: enabled: lib.optionals enabled (featureDeps."${feat}" or [ ])) features + ); enableParallelBuilding = true; - configureFlags = lib.mapAttrsToList (feat: enabled: lib.strings.enableFeature enabled feat) features; + configureFlags = lib.mapAttrsToList ( + feat: enabled: lib.strings.enableFeature enabled feat + ) features; meta = with lib; { description = "Universal configuration library parser"; diff --git a/pkgs/by-name/li/libucontext/package.nix b/pkgs/by-name/li/libucontext/package.nix index 23301648bdf948..375fc20164ac9f 100644 --- a/pkgs/by-name/li/libucontext/package.nix +++ b/pkgs/by-name/li/libucontext/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "libucontext"; diff --git a/pkgs/by-name/li/libudev-zero/package.nix b/pkgs/by-name/li/libudev-zero/package.nix index 82bc25cca57a97..104c80c498f956 100644 --- a/pkgs/by-name/li/libudev-zero/package.nix +++ b/pkgs/by-name/li/libudev-zero/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, testers }: +{ + lib, + stdenv, + fetchFromGitHub, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "libudev-zero"; @@ -11,7 +16,10 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-NXDof1tfr66ywYhCBDlPa+8DUfFj6YH0dvSaxHFqsXI="; }; - makeFlags = [ "PREFIX=$(out)" "AR=${stdenv.cc.targetPrefix}ar" ]; + makeFlags = [ + "PREFIX=$(out)" + "AR=${stdenv.cc.targetPrefix}ar" + ]; # Just let the installPhase build stuff, because there's no # non-install target that builds everything anyway. @@ -27,7 +35,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/illiliti/libudev-zero"; description = "Daemonless replacement for libudev"; changelog = "https://github.com/illiliti/libudev-zero/releases/tag/${version}"; - maintainers = with maintainers; [ qyliss shamilton ]; + maintainers = with maintainers; [ + qyliss + shamilton + ]; license = licenses.isc; pkgConfigModules = [ "libudev" ]; platforms = platforms.linux; diff --git a/pkgs/by-name/li/libudev0-shim/package.nix b/pkgs/by-name/li/libudev0-shim/package.nix index 642dd534232baf..55f51b8b412df0 100644 --- a/pkgs/by-name/li/libudev0-shim/package.nix +++ b/pkgs/by-name/li/libudev0-shim/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, udev }: +{ + lib, + stdenv, + fetchFromGitHub, + udev, +}: stdenv.mkDerivation rec { pname = "libudev0-shim"; diff --git a/pkgs/by-name/li/libudfread/package.nix b/pkgs/by-name/li/libudfread/package.nix index d4f9a0d06b462e..cb42d737210883 100644 --- a/pkgs/by-name/li/libudfread/package.nix +++ b/pkgs/by-name/li/libudfread/package.nix @@ -1,12 +1,16 @@ -{ lib, stdenv, fetchurl, autoreconfHook, }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libudfread"; version = "1.1.2"; src = fetchurl { - url = - "https://code.videolan.org/videolan/${pname}/-/archive/${version}/${pname}-${version}.tar.gz"; + url = "https://code.videolan.org/videolan/${pname}/-/archive/${version}/${pname}-${version}.tar.gz"; sha256 = "1idsfxff1x264n8jd7077qrd61rycsd09fwmc4ar7l4qmhk6gw9b"; }; diff --git a/pkgs/by-name/li/libuecc/package.nix b/pkgs/by-name/li/libuecc/package.nix index 1cc3ac8ebea1a9..da7cb93ab8423f 100644 --- a/pkgs/by-name/li/libuecc/package.nix +++ b/pkgs/by-name/li/libuecc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchgit, cmake }: +{ + lib, + stdenv, + fetchgit, + cmake, +}: stdenv.mkDerivation rec { version = "7"; diff --git a/pkgs/by-name/li/libuev/package.nix b/pkgs/by-name/li/libuev/package.nix index a124c25a20404f..430eb6a0fc21c2 100644 --- a/pkgs/by-name/li/libuev/package.nix +++ b/pkgs/by-name/li/libuev/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libuev"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-x1Sk7IuhlBQPFL7Rq4tmEanBxI/WaQ2L5fpUyEWOoi8="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; meta = with lib; { description = "Lightweight event loop library for Linux epoll() family APIs"; diff --git a/pkgs/by-name/li/libui-ng/package.nix b/pkgs/by-name/li/libui-ng/package.nix index cc308d86c842fe..8bed051db0bf34 100644 --- a/pkgs/by-name/li/libui-ng/package.nix +++ b/pkgs/by-name/li/libui-ng/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, cmocka -, darwin -, fetchFromGitHub -, gtk3 -, meson -, ninja -, pkg-config -, unstableGitUpdater +{ + lib, + stdenv, + cmocka, + darwin, + fetchFromGitHub, + gtk3, + meson, + ninja, + pkg-config, + unstableGitUpdater, }: stdenv.mkDerivation rec { @@ -33,15 +34,18 @@ stdenv.mkDerivation rec { ]; buildInputs = - if stdenv.hostPlatform.isDarwin then [ - darwin.libobjc - darwin.apple_sdk_11_0.Libsystem - darwin.apple_sdk_11_0.frameworks.Cocoa - darwin.apple_sdk_11_0.frameworks.AppKit - darwin.apple_sdk_11_0.frameworks.CoreFoundation - ] else [ - gtk3 - ]; + if stdenv.hostPlatform.isDarwin then + [ + darwin.libobjc + darwin.apple_sdk_11_0.Libsystem + darwin.apple_sdk_11_0.frameworks.Cocoa + darwin.apple_sdk_11_0.frameworks.AppKit + darwin.apple_sdk_11_0.frameworks.CoreFoundation + ] + else + [ + gtk3 + ]; mesonFlags = [ (lib.mesonBool "examples" (!stdenv.hostPlatform.isDarwin)) diff --git a/pkgs/by-name/li/libuinputplus/package.nix b/pkgs/by-name/li/libuinputplus/package.nix index 28110b577047d9..8d1ed42b6ca6a5 100644 --- a/pkgs/by-name/li/libuinputplus/package.nix +++ b/pkgs/by-name/li/libuinputplus/package.nix @@ -1,20 +1,29 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "libuinputplus"; version = "2021-04-02"; # adds missing cmake install directives # https://github.com/YukiWorkshop/libuInputPlus/pull/7 - patches = [ ./0001-Add-cmake-install-directives.patch]; + patches = [ ./0001-Add-cmake-install-directives.patch ]; - src = fetchFromGitHub { - owner = "YukiWorkshop"; - repo = "libuInputPlus"; - rev = "f7f18eb339bba61a43f2cad481a9b1a453a66957"; + src = fetchFromGitHub { + owner = "YukiWorkshop"; + repo = "libuInputPlus"; + rev = "f7f18eb339bba61a43f2cad481a9b1a453a66957"; sha256 = "0sind2ghhy4h9kfkr5hsmhcq0di4ifwqyv4gac96rgj5mwvs33lp"; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; meta = with lib; { inherit (src.meta) homepage; diff --git a/pkgs/by-name/li/libuldaq/package.nix b/pkgs/by-name/li/libuldaq/package.nix index fb234ef60d14c4..cb5adc4c456033 100644 --- a/pkgs/by-name/li/libuldaq/package.nix +++ b/pkgs/by-name/li/libuldaq/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libusb1, ...}: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libusb1, + ... +}: stdenv.mkDerivation rec { pname = "libuldaq"; diff --git a/pkgs/by-name/li/libunarr/package.nix b/pkgs/by-name/li/libunarr/package.nix index c53196afe42010..2ea5d3025a24b0 100644 --- a/pkgs/by-name/li/libunarr/package.nix +++ b/pkgs/by-name/li/libunarr/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, cmake +{ + lib, + stdenv, + fetchurl, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libunibreak/package.nix b/pkgs/by-name/li/libunibreak/package.nix index 557ad37f23d27b..66601e4725743c 100644 --- a/pkgs/by-name/li/libunibreak/package.nix +++ b/pkgs/by-name/li/libunibreak/package.nix @@ -1,17 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libunibreak"; version = "6.1"; - src = let - rev_version = lib.replaceStrings ["."] ["_"] version; - in fetchFromGitHub { - owner = "adah1972"; - repo = pname; - rev = "libunibreak_${rev_version}"; - sha256 = "sha256-8yheb+XSvc1AqITjSutF+/4OWb4+7hweedKzhKJcE1Y="; - }; + src = + let + rev_version = lib.replaceStrings [ "." ] [ "_" ] version; + in + fetchFromGitHub { + owner = "adah1972"; + repo = pname; + rev = "libunibreak_${rev_version}"; + sha256 = "sha256-8yheb+XSvc1AqITjSutF+/4OWb4+7hweedKzhKJcE1Y="; + }; nativeBuildInputs = [ autoreconfHook ]; diff --git a/pkgs/by-name/li/libuninameslist/package.nix b/pkgs/by-name/li/libuninameslist/package.nix index ff438f749fd8aa..a1df422c7183c1 100644 --- a/pkgs/by-name/li/libuninameslist/package.nix +++ b/pkgs/by-name/li/libuninameslist/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libunity/package.nix b/pkgs/by-name/li/libunity/package.nix index 5905798ee88086..f705ca9f56c01d 100644 --- a/pkgs/by-name/li/libunity/package.nix +++ b/pkgs/by-name/li/libunity/package.nix @@ -1,23 +1,28 @@ -{ lib -, stdenv -, fetchgit -, pkg-config -, glib -, vala -, dee -, gobject-introspection -, libdbusmenu -, gtk3 -, intltool -, python3 -, autoreconfHook +{ + lib, + stdenv, + fetchgit, + pkg-config, + glib, + vala, + dee, + gobject-introspection, + libdbusmenu, + gtk3, + intltool, + python3, + autoreconfHook, }: stdenv.mkDerivation { pname = "libunity"; version = "unstable-2021-02-01"; - outputs = [ "out" "dev" "py" ]; + outputs = [ + "out" + "dev" + "py" + ]; # Obtained from https://git.launchpad.net/ubuntu/+source/libunity/log/ src = fetchgit { diff --git a/pkgs/by-name/li/liburcu/package.nix b/pkgs/by-name/li/liburcu/package.nix index 1759fab7d319de..425c2969da2154 100644 --- a/pkgs/by-name/li/liburcu/package.nix +++ b/pkgs/by-name/li/liburcu/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { version = "0.14.1"; @@ -9,7 +14,11 @@ stdenv.mkDerivation rec { hash = "sha256-IxrLE9xuwCPoNqDwZm9qq0fcYh7LHSzZ2cIvkiZ4q8A="; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; nativeCheckInputs = [ perl ]; @@ -22,7 +31,16 @@ stdenv.mkDerivation rec { changelog = "https://github.com/urcu/userspace-rcu/raw/v${version}/ChangeLog"; license = licenses.lgpl21Plus; # https://git.liburcu.org/?p=userspace-rcu.git;a=blob;f=include/urcu/arch.h - platforms = intersectLists platforms.unix (platforms.x86 ++ platforms.power ++ platforms.s390 ++ platforms.arm ++ platforms.aarch64 ++ platforms.mips ++ platforms.m68k ++ platforms.riscv); + platforms = intersectLists platforms.unix ( + platforms.x86 + ++ platforms.power + ++ platforms.s390 + ++ platforms.arm + ++ platforms.aarch64 + ++ platforms.mips + ++ platforms.m68k + ++ platforms.riscv + ); maintainers = [ maintainers.bjornfor ]; }; diff --git a/pkgs/by-name/li/liburing/package.nix b/pkgs/by-name/li/liburing/package.nix index 931cbd77b041d2..ebe4d4562b2327 100644 --- a/pkgs/by-name/li/liburing/package.nix +++ b/pkgs/by-name/li/liburing/package.nix @@ -42,9 +42,7 @@ stdenv.mkDerivation rec { postInstall = '' # Always builds both static and dynamic libraries, so we need to remove the # libraries that don't match stdenv type. - rm $out/lib/liburing*${ - if stdenv.hostPlatform.isStatic then ".so*" else ".a" - } + rm $out/lib/liburing*${if stdenv.hostPlatform.isStatic then ".so*" else ".a"} # Copy the examples into $bin. Most reverse dependency of # this package should reference only the $out output diff --git a/pkgs/by-name/li/libusbgx/package.nix b/pkgs/by-name/li/libusbgx/package.nix index dacaf6d42da9eb..fa119c9477446e 100644 --- a/pkgs/by-name/li/libusbgx/package.nix +++ b/pkgs/by-name/li/libusbgx/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config, libconfig, autoreconfHook }: +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + libconfig, + autoreconfHook, +}: stdenv.mkDerivation { pname = "libusbgx"; version = "unstable-2021-10-31"; @@ -8,7 +15,10 @@ stdenv.mkDerivation { rev = "060784424609d5a4e3bce8355f788c93f09802a5"; sha256 = "172qh8gva17jr18ldhf9zi960w2bqzmp030w6apxq57c9nv6d8k7"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libconfig ]; meta = { description = "C library encapsulating the kernel USB gadget-configfs userspace API functionality"; diff --git a/pkgs/by-name/li/libusbp/package.nix b/pkgs/by-name/li/libusbp/package.nix index d1f1a2cc3b230c..7e6a921d3aea16 100644 --- a/pkgs/by-name/li/libusbp/package.nix +++ b/pkgs/by-name/li/libusbp/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, udev -, cmake -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + udev, + cmake, + pkg-config, }: -stdenv.mkDerivation(finalAttrs: { +stdenv.mkDerivation (finalAttrs: { pname = "libusbp"; version = "1.3.1"; @@ -17,7 +18,10 @@ stdenv.mkDerivation(finalAttrs: { hash = "sha256-hFvQceUapzlD021KIOJbSXX7qv1IQMuEudRHYeCkbS8="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake diff --git a/pkgs/by-name/li/libusbsio/package.nix b/pkgs/by-name/li/libusbsio/package.nix index 21c7e3f1396ec0..24a41781d447e1 100644 --- a/pkgs/by-name/li/libusbsio/package.nix +++ b/pkgs/by-name/li/libusbsio/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchzip -, pkg-config -, fixDarwinDylibNames -, libusb1 -, systemdMinimal -, darwin +{ + lib, + stdenv, + fetchzip, + pkg-config, + fixDarwinDylibNames, + libusb1, + systemdMinimal, + darwin, }: stdenv.mkDerivation rec { @@ -26,21 +27,29 @@ stdenv.mkDerivation rec { "BINDIR=" ]; - nativeBuildInputs = [ - pkg-config - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ]; + nativeBuildInputs = + [ + pkg-config + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ]; - buildInputs = [ - libusb1 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - AppKit - CoreFoundation - IOKit - ]) ++ lib.optionals stdenv.hostPlatform.isLinux [ - systemdMinimal # libudev - ]; + buildInputs = + [ + libusb1 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + AppKit + CoreFoundation + IOKit + ] + ) + ++ lib.optionals stdenv.hostPlatform.isLinux [ + systemdMinimal # libudev + ]; installPhase = '' runHook preInstall @@ -53,6 +62,9 @@ stdenv.mkDerivation rec { description = "Library for communicating with devices connected via the USB bridge on LPC-Link2 and MCU-Link debug probes on supported NXP microcontroller evaluation boards"; platforms = platforms.all; license = licenses.bsd3; - maintainers = with maintainers; [ frogamic sbruder ]; + maintainers = with maintainers; [ + frogamic + sbruder + ]; }; } diff --git a/pkgs/by-name/li/libutempter/package.nix b/pkgs/by-name/li/libutempter/package.nix index 717418e686b4f0..6506d10076423c 100644 --- a/pkgs/by-name/li/libutempter/package.nix +++ b/pkgs/by-name/li/libutempter/package.nix @@ -1,4 +1,9 @@ -{ stdenv, fetchurl, lib, glib }: +{ + stdenv, + fetchurl, + lib, + glib, +}: stdenv.mkDerivation rec { pname = "libutempter"; diff --git a/pkgs/by-name/li/libuvc/package.nix b/pkgs/by-name/li/libuvc/package.nix index e7ff4bb7f288d8..de1062a5594f26 100644 --- a/pkgs/by-name/li/libuvc/package.nix +++ b/pkgs/by-name/li/libuvc/package.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, libusb1 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libusb1, }: stdenv.mkDerivation rec { @@ -16,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "0kranb0x1k5qad8rwxnn1w9963sbfj2cfzdgpfmlivb04544m2j7"; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libusb1 ]; diff --git a/pkgs/by-name/li/libv3270/package.nix b/pkgs/by-name/li/libv3270/package.nix index 3e87f868ec1668..25f3ab61bcbcfc 100644 --- a/pkgs/by-name/li/libv3270/package.nix +++ b/pkgs/by-name/li/libv3270/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, libtool -, which -, pkg-config -, gtk3 -, lib3270 +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + which, + pkg-config, + gtk3, + lib3270, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libva-vdpau-driver/package.nix b/pkgs/by-name/li/libva-vdpau-driver/package.nix index 2e3976e3a4d234..49f3f92148c8a9 100644 --- a/pkgs/by-name/li/libva-vdpau-driver/package.nix +++ b/pkgs/by-name/li/libva-vdpau-driver/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, fetchpatch, libvdpau, libGLU, libGL, libva, pkg-config }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libvdpau, + libGLU, + libGL, + libva, + pkg-config, +}: stdenv.mkDerivation rec { pname = "libva-vdpau-driver"; @@ -10,22 +20,39 @@ stdenv.mkDerivation rec { }; patches = [ - (fetchpatch { url = "https://src.fedoraproject.org/rpms/libva-vdpau-driver/raw/0ad71107e28a60ea453ac70e895cf64342bd58d0/f/libva-vdpau-driver-0.7.4-glext-85.patch"; - sha256 = "0f0v7cl7kna3jcfnxw48b9mfl0hpacw72df9vym96sa2206vqlb0"; }) - (fetchpatch { url = "https://src.fedoraproject.org/rpms/libva-vdpau-driver/raw/0ad71107e28a60ea453ac70e895cf64342bd58d0/f/libva-vdpau-driver-0.7.4-drop-h264-api.patch"; - sha256 = "0q5w83jbf4qqmhwf54h906pzxgvhqv7g2vrkw7jzgnrxhhj9sj60"; }) - (fetchpatch { url = "https://src.fedoraproject.org/rpms/libva-vdpau-driver/raw/0ad71107e28a60ea453ac70e895cf64342bd58d0/f/libva-vdpau-driver-0.7.4-fix_type.patch"; - sha256 = "0s5dk6aa4sm0iyicnf2fwfsrqbvr58nbp77mhjg5bvwlar7znqv7"; }) - (fetchpatch { url = "https://src.fedoraproject.org/rpms/libva-vdpau-driver/raw/0ad71107e28a60ea453ac70e895cf64342bd58d0/f/sigfpe-crash.patch"; - sha256 = "15snqf60ib0xb3cnav5b2r55qv8lv2fa4p6jwxajh8wbvqpw0ibz"; }) - (fetchpatch { url = "https://src.fedoraproject.org/rpms/libva-vdpau-driver/raw/0ad71107e28a60ea453ac70e895cf64342bd58d0/f/implement-vaquerysurfaceattributes.patch"; - sha256 = "1dapx3bqqblw6l2iqqw1yff6qifam8q4m2rq343kwb3dqhy2ymy5"; }) - (fetchpatch { url = "https://github.com/gentoo/gentoo/raw/34d5cc6fcf1d76c1c2833cb534717246c221214c/x11-libs/libva-vdpau-driver/files/libva-vdpau-driver-0.7.4-include-linux-videodev2.h.patch"; - sha256 = "1m4is6lk580mppsx2mvdv1xifj6gvx724si4qynsm9qrdfdc9fby"; }) + (fetchpatch { + url = "https://src.fedoraproject.org/rpms/libva-vdpau-driver/raw/0ad71107e28a60ea453ac70e895cf64342bd58d0/f/libva-vdpau-driver-0.7.4-glext-85.patch"; + sha256 = "0f0v7cl7kna3jcfnxw48b9mfl0hpacw72df9vym96sa2206vqlb0"; + }) + (fetchpatch { + url = "https://src.fedoraproject.org/rpms/libva-vdpau-driver/raw/0ad71107e28a60ea453ac70e895cf64342bd58d0/f/libva-vdpau-driver-0.7.4-drop-h264-api.patch"; + sha256 = "0q5w83jbf4qqmhwf54h906pzxgvhqv7g2vrkw7jzgnrxhhj9sj60"; + }) + (fetchpatch { + url = "https://src.fedoraproject.org/rpms/libva-vdpau-driver/raw/0ad71107e28a60ea453ac70e895cf64342bd58d0/f/libva-vdpau-driver-0.7.4-fix_type.patch"; + sha256 = "0s5dk6aa4sm0iyicnf2fwfsrqbvr58nbp77mhjg5bvwlar7znqv7"; + }) + (fetchpatch { + url = "https://src.fedoraproject.org/rpms/libva-vdpau-driver/raw/0ad71107e28a60ea453ac70e895cf64342bd58d0/f/sigfpe-crash.patch"; + sha256 = "15snqf60ib0xb3cnav5b2r55qv8lv2fa4p6jwxajh8wbvqpw0ibz"; + }) + (fetchpatch { + url = "https://src.fedoraproject.org/rpms/libva-vdpau-driver/raw/0ad71107e28a60ea453ac70e895cf64342bd58d0/f/implement-vaquerysurfaceattributes.patch"; + sha256 = "1dapx3bqqblw6l2iqqw1yff6qifam8q4m2rq343kwb3dqhy2ymy5"; + }) + (fetchpatch { + url = "https://github.com/gentoo/gentoo/raw/34d5cc6fcf1d76c1c2833cb534717246c221214c/x11-libs/libva-vdpau-driver/files/libva-vdpau-driver-0.7.4-include-linux-videodev2.h.patch"; + sha256 = "1m4is6lk580mppsx2mvdv1xifj6gvx724si4qynsm9qrdfdc9fby"; + }) ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libvdpau libGLU libGL libva ]; + buildInputs = [ + libvdpau + libGLU + libGL + libva + ]; postPatch = '' sed -i -e "s,LIBVA_DRIVERS_PATH=.*,LIBVA_DRIVERS_PATH=$out/lib/dri," configure diff --git a/pkgs/by-name/li/libvdpau-va-gl/package.nix b/pkgs/by-name/li/libvdpau-va-gl/package.nix index 7a042a172c821a..0f035821e47675 100644 --- a/pkgs/by-name/li/libvdpau-va-gl/package.nix +++ b/pkgs/by-name/li/libvdpau-va-gl/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, libX11, libpthreadstubs, libXau, libXdmcp -, libXext, libvdpau, glib, libva, libGLU }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libX11, + libpthreadstubs, + libXau, + libXdmcp, + libXext, + libvdpau, + glib, + libva, + libGLU, +}: stdenv.mkDerivation rec { pname = "libvdpau-va-gl"; @@ -12,8 +26,21 @@ stdenv.mkDerivation rec { sha256 = "0asndybfv8xb0fx73sjjw5kydqrahqkm6n04lh589pbf18s5qlld"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libX11 libpthreadstubs libXau libXdmcp libXext libvdpau glib libva libGLU ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + libX11 + libpthreadstubs + libXau + libXdmcp + libXext + libvdpau + glib + libva + libGLU + ]; doCheck = false; # fails. needs DRI access diff --git a/pkgs/by-name/li/libvdwxc/package.nix b/pkgs/by-name/li/libvdwxc/package.nix index c843d443e81e21..20162f7e11d0b3 100644 --- a/pkgs/by-name/li/libvdwxc/package.nix +++ b/pkgs/by-name/li/libvdwxc/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitLab -, gfortran -, autoreconfHook -, fftwMpi -, mpi +{ + stdenv, + lib, + fetchFromGitLab, + gfortran, + autoreconfHook, + fftwMpi, + mpi, }: stdenv.mkDerivation rec { @@ -19,9 +20,15 @@ stdenv.mkDerivation rec { sha256 = "1c7pjrvifncbdyngs2bv185imxbcbq64nka8gshhp8n2ns6fids6"; }; - nativeBuildInputs = [ autoreconfHook gfortran ]; + nativeBuildInputs = [ + autoreconfHook + gfortran + ]; - buildInputs = [ mpi fftwMpi ]; + buildInputs = [ + mpi + fftwMpi + ]; preConfigure = '' mkdir build && cd build @@ -44,7 +51,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Portable C library of density functionals with van der Waals interactions for density functional theory"; - license = with licenses; [ lgpl3Plus bsd3 ]; + license = with licenses; [ + lgpl3Plus + bsd3 + ]; homepage = "https://libvdwxc.org/"; platforms = platforms.unix; maintainers = [ maintainers.sheepforce ]; diff --git a/pkgs/by-name/li/libversion/package.nix b/pkgs/by-name/li/libversion/package.nix index 4efe91096576c6..c1f1af764b0d9f 100644 --- a/pkgs/by-name/li/libversion/package.nix +++ b/pkgs/by-name/li/libversion/package.nix @@ -1,4 +1,9 @@ -{ stdenv, fetchFromGitHub, cmake, lib }: +{ + stdenv, + fetchFromGitHub, + cmake, + lib, +}: stdenv.mkDerivation rec { pname = "libversion"; diff --git a/pkgs/by-name/li/libverto/package.nix b/pkgs/by-name/li/libverto/package.nix index d161f2b92b2b5c..2e8bb24fb2cef4 100644 --- a/pkgs/by-name/li/libverto/package.nix +++ b/pkgs/by-name/li/libverto/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, glib -, libev -, libevent -, pkg-config -, glibSupport ? true -, libevSupport ? true -, libeventSupport ? true +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + glib, + libev, + libevent, + pkg-config, + glibSupport ? true, + libevSupport ? true, + libeventSupport ? true, }: let @@ -31,9 +32,7 @@ stdenv.mkDerivation (finalAttrs: { ]; buildInputs = - optional glibSupport glib - ++ optional libevSupport libev - ++ optional libeventSupport libevent; + optional glibSupport glib ++ optional libevSupport libev ++ optional libeventSupport libevent; meta = with lib; { homepage = "https://github.com/latchset/libverto"; diff --git a/pkgs/by-name/li/libviper/package.nix b/pkgs/by-name/li/libviper/package.nix index 4caa26aadc6a96..3966eaf40ac543 100644 --- a/pkgs/by-name/li/libviper/package.nix +++ b/pkgs/by-name/li/libviper/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchurl, pkg-config, glib, ncurses, gpm}: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + ncurses, + gpm, +}: stdenv.mkDerivation rec { pname = "libviper"; version = "1.4.6"; @@ -28,7 +36,11 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib ncurses gpm]; + buildInputs = [ + glib + ncurses + gpm + ]; meta = with lib; { homepage = "http://libviper.sourceforge.net/"; diff --git a/pkgs/by-name/li/libviperfx/package.nix b/pkgs/by-name/li/libviperfx/package.nix index 2778726a4bf7c0..a6d3b877054ec8 100644 --- a/pkgs/by-name/li/libviperfx/package.nix +++ b/pkgs/by-name/li/libviperfx/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "libviperfx"; diff --git a/pkgs/by-name/li/libvirt-glib/package.nix b/pkgs/by-name/li/libvirt-glib/package.nix index 472812e27d9eff..6d37c6df19c320 100644 --- a/pkgs/by-name/li/libvirt-glib/package.nix +++ b/pkgs/by-name/li/libvirt-glib/package.nix @@ -1,28 +1,34 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, meson -, ninja -, pkg-config -, gettext -, vala -, libcap_ng -, libvirt -, libxml2 -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, gobject-introspection -, withDocs ? stdenv.hostPlatform == stdenv.buildPlatform -, gtk-doc -, docbook-xsl-nons +{ + lib, + stdenv, + fetchurl, + fetchpatch, + meson, + ninja, + pkg-config, + gettext, + vala, + libcap_ng, + libvirt, + libxml2, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + gobject-introspection, + withDocs ? stdenv.hostPlatform == stdenv.buildPlatform, + gtk-doc, + docbook-xsl-nons, }: stdenv.mkDerivation rec { pname = "libvirt-glib"; version = "5.0.0"; - outputs = [ "out" "dev" ] ++ lib.optional withDocs "devdoc"; + outputs = [ + "out" + "dev" + ] ++ lib.optional withDocs "devdoc"; src = fetchurl { url = "https://libvirt.org/sources/glib/${pname}-${version}.tar.xz"; @@ -37,26 +43,31 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - gettext - vala - gobject-introspection - ] ++ lib.optionals withIntrospection [ - gobject-introspection - ] ++ lib.optionals withDocs [ - gtk-doc - docbook-xsl-nons - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gettext + vala + gobject-introspection + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + ] + ++ lib.optionals withDocs [ + gtk-doc + docbook-xsl-nons + ]; - buildInputs = [ - libvirt - libxml2 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libcap_ng - ]; + buildInputs = + [ + libvirt + libxml2 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libcap_ng + ]; strictDeps = true; diff --git a/pkgs/by-name/li/libvisio2svg/package.nix b/pkgs/by-name/li/libvisio2svg/package.nix index b2a68ed586808e..35452cc983145b 100644 --- a/pkgs/by-name/li/libvisio2svg/package.nix +++ b/pkgs/by-name/li/libvisio2svg/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, freetype -, libemf2svg -, librevenge -, libvisio -, libwmf -, libxml2 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + freetype, + libemf2svg, + librevenge, + libvisio, + libwmf, + libxml2, }: stdenv.mkDerivation rec { @@ -22,7 +23,14 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libxml2 freetype librevenge libvisio libwmf libemf2svg ]; + buildInputs = [ + libxml2 + freetype + librevenge + libvisio + libwmf + libemf2svg + ]; cmakeFlags = [ # file RPATH_CHANGE could not write new RPATH diff --git a/pkgs/by-name/li/libvisual/package.nix b/pkgs/by-name/li/libvisual/package.nix index 12fae974312be5..c38a649c8b8a7c 100644 --- a/pkgs/by-name/li/libvisual/package.nix +++ b/pkgs/by-name/li/libvisual/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, SDL -, autoreconfHook -, glib -, pkg-config +{ + lib, + stdenv, + fetchurl, + fetchpatch, + SDL, + autoreconfHook, + glib, + pkg-config, }: stdenv.mkDerivation rec { @@ -17,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-qhKHdBf3bTZC2fTHIzAjgNgzF1Y51jpVZB0Bkopd230="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; patches = [ # pull upstream fix for SDL1 cross-compilation. @@ -41,16 +45,24 @@ stdenv.mkDerivation rec { ]; strictDeps = true; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ SDL glib ]; - - configureFlags = lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - # Remove once "sdl-cross-prereq.patch" patch above is removed. - "--disable-lv-tool" - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - "ac_cv_func_malloc_0_nonnull=yes" - "ac_cv_func_realloc_0_nonnull=yes" + nativeBuildInputs = [ + autoreconfHook + pkg-config ]; + buildInputs = [ + SDL + glib + ]; + + configureFlags = + lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + # Remove once "sdl-cross-prereq.patch" patch above is removed. + "--disable-lv-tool" + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + "ac_cv_func_malloc_0_nonnull=yes" + "ac_cv_func_realloc_0_nonnull=yes" + ]; meta = { description = "Abstraction library for audio visualisations"; diff --git a/pkgs/by-name/li/libvmaf/package.nix b/pkgs/by-name/li/libvmaf/package.nix index 9e692fc5805eb9..00ee04515b5ceb 100644 --- a/pkgs/by-name/li/libvmaf/package.nix +++ b/pkgs/by-name/li/libvmaf/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, ffmpeg-full -, libaom -, meson -, nasm -, ninja -, testers -, xxd +{ + lib, + stdenv, + fetchFromGitHub, + ffmpeg-full, + libaom, + meson, + nasm, + ninja, + testers, + xxd, }: stdenv.mkDerivation (finalAttrs: { @@ -23,11 +24,19 @@ stdenv.mkDerivation (finalAttrs: { sourceRoot = "${finalAttrs.src.name}/libvmaf"; - nativeBuildInputs = [ meson ninja nasm xxd ]; + nativeBuildInputs = [ + meson + ninja + nasm + xxd + ]; mesonFlags = [ "-Denable_avx512=true" ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; doCheck = false; passthru.tests = { diff --git a/pkgs/by-name/li/libvoikko/package.nix b/pkgs/by-name/li/libvoikko/package.nix index 3f5f4ef5c858c4..6cdfd61353eb30 100644 --- a/pkgs/by-name/li/libvoikko/package.nix +++ b/pkgs/by-name/li/libvoikko/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, autoreconfHook -, hfst-ospell -, fetchFromGitHub -, pkg-config -, python3 +{ + stdenv, + lib, + autoreconfHook, + hfst-ospell, + fetchFromGitHub, + pkg-config, + python3, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/libvolume_id/package.nix b/pkgs/by-name/li/libvolume_id/package.nix index 718bd9cec89ca5..dbdd75e2756032 100644 --- a/pkgs/by-name/li/libvolume_id/package.nix +++ b/pkgs/by-name/li/libvolume_id/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libvolume_id"; diff --git a/pkgs/by-name/li/libvorbis/package.nix b/pkgs/by-name/li/libvorbis/package.nix index 42e7328a8ec12e..c5104cafc4335d 100644 --- a/pkgs/by-name/li/libvorbis/package.nix +++ b/pkgs/by-name/li/libvorbis/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libogg, pkg-config }: +{ + lib, + stdenv, + fetchurl, + libogg, + pkg-config, +}: stdenv.mkDerivation rec { pname = "libvorbis"; @@ -9,7 +15,11 @@ stdenv.mkDerivation rec { sha256 = "0jwmf87x5sdis64rbv0l87mdpah1rbilkkxszipbzg128f9w8g5k"; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; nativeBuildInputs = [ pkg-config ]; propagatedBuildInputs = [ libogg ]; diff --git a/pkgs/by-name/li/libvori/package.nix b/pkgs/by-name/li/libvori/package.nix index 9483c2a0bb7a8c..1d431610a006ea 100644 --- a/pkgs/by-name/li/libvori/package.nix +++ b/pkgs/by-name/li/libvori/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchurl, cmake }: +{ + stdenv, + lib, + fetchurl, + cmake, +}: stdenv.mkDerivation rec { pname = "libvori"; diff --git a/pkgs/by-name/li/libvpl/package.nix b/pkgs/by-name/li/libvpl/package.nix index c0ae60f2bb9600..61b4d79b8cfc6a 100644 --- a/pkgs/by-name/li/libvpl/package.nix +++ b/pkgs/by-name/li/libvpl/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, substituteAll -, addDriverRunpath +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + substituteAll, + addDriverRunpath, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/libvpx/package.nix b/pkgs/by-name/li/libvpx/package.nix index 4e6e6316d9adab..41cc90a1795460 100644 --- a/pkgs/by-name/li/libvpx/package.nix +++ b/pkgs/by-name/li/libvpx/package.nix @@ -1,91 +1,120 @@ -{ lib, stdenv, fetchFromGitHub, perl, yasm -, vp8DecoderSupport ? true # VP8 decoder -, vp8EncoderSupport ? true # VP8 encoder -, vp9DecoderSupport ? true # VP9 decoder -, vp9EncoderSupport ? true # VP9 encoder -, extraWarningsSupport ? false # emit non-fatal warnings -, werrorSupport ? false # treat warnings as errors (not available with all compilers) -, debugSupport ? false # debug mode -, gprofSupport ? false # gprof profiling instrumentation -, gcovSupport ? false # gcov coverage instrumentation -, sizeLimitSupport ? true # limit max size to allow in the decoder -, optimizationsSupport ? true # compiler optimization flags -, runtimeCpuDetectSupport ? true # detect cpu capabilities at runtime -, thumbSupport ? false # build arm assembly in thumb mode -, examplesSupport ? true # build examples (vpxdec & vpxenc are part of examples) -, debugLibsSupport ? false # include debug version of each library -, postprocSupport ? true # postprocessing -, multithreadSupport ? true # multithreaded decoding & encoding -, internalStatsSupport ? false # output of encoder internal stats for debug, if supported (encoders) -, spatialResamplingSupport ? true # spatial sampling (scaling) -, realtimeOnlySupport ? false # build for real-time encoding -, ontheflyBitpackingSupport ? false # on-the-fly bitpacking in real-time encoding -, errorConcealmentSupport ? false # decoder conceals losses -, smallSupport ? false # favor smaller binary over speed -, postprocVisualizerSupport ? false # macro block/block level visualizers -, unitTestsSupport ? false, curl ? null, coreutils ? null # unit tests -, webmIOSupport ? true # input from and output to webm container -, libyuvSupport ? true # libyuv -, decodePerfTestsSupport ? false # build decoder perf tests with unit tests -, encodePerfTestsSupport ? false # build encoder perf tests with unit tests -, multiResEncodingSupport ? false # multiple-resolution encoding -, temporalDenoisingSupport ? true # use temporal denoising instead of spatial denoising -, coefficientRangeCheckingSupport ? false # decoder checks if intermediate transform coefficients are in valid range -, vp9HighbitdepthSupport ? true # 10/12 bit color support in VP9 -# Experimental features -, experimentalSpatialSvcSupport ? false # Spatial scalable video coding -, experimentalFpMbStatsSupport ? false -, experimentalEmulateHardwareSupport ? false - -# for passthru.tests -, ffmpeg -, gst_all_1 +{ + lib, + stdenv, + fetchFromGitHub, + perl, + yasm, + vp8DecoderSupport ? true, # VP8 decoder + vp8EncoderSupport ? true, # VP8 encoder + vp9DecoderSupport ? true, # VP9 decoder + vp9EncoderSupport ? true, # VP9 encoder + extraWarningsSupport ? false, # emit non-fatal warnings + werrorSupport ? false, # treat warnings as errors (not available with all compilers) + debugSupport ? false, # debug mode + gprofSupport ? false, # gprof profiling instrumentation + gcovSupport ? false, # gcov coverage instrumentation + sizeLimitSupport ? true, # limit max size to allow in the decoder + optimizationsSupport ? true, # compiler optimization flags + runtimeCpuDetectSupport ? true, # detect cpu capabilities at runtime + thumbSupport ? false, # build arm assembly in thumb mode + examplesSupport ? true, # build examples (vpxdec & vpxenc are part of examples) + debugLibsSupport ? false, # include debug version of each library + postprocSupport ? true, # postprocessing + multithreadSupport ? true, # multithreaded decoding & encoding + internalStatsSupport ? false, # output of encoder internal stats for debug, if supported (encoders) + spatialResamplingSupport ? true, # spatial sampling (scaling) + realtimeOnlySupport ? false, # build for real-time encoding + ontheflyBitpackingSupport ? false, # on-the-fly bitpacking in real-time encoding + errorConcealmentSupport ? false, # decoder conceals losses + smallSupport ? false, # favor smaller binary over speed + postprocVisualizerSupport ? false, # macro block/block level visualizers + unitTestsSupport ? false, + curl ? null, + coreutils ? null, # unit tests + webmIOSupport ? true, # input from and output to webm container + libyuvSupport ? true, # libyuv + decodePerfTestsSupport ? false, # build decoder perf tests with unit tests + encodePerfTestsSupport ? false, # build encoder perf tests with unit tests + multiResEncodingSupport ? false, # multiple-resolution encoding + temporalDenoisingSupport ? true, # use temporal denoising instead of spatial denoising + coefficientRangeCheckingSupport ? false, # decoder checks if intermediate transform coefficients are in valid range + vp9HighbitdepthSupport ? true, # 10/12 bit color support in VP9 + # Experimental features + experimentalSpatialSvcSupport ? false, # Spatial scalable video coding + experimentalFpMbStatsSupport ? false, + experimentalEmulateHardwareSupport ? false, + + # for passthru.tests + ffmpeg, + gst_all_1, }: let - inherit (stdenv.hostPlatform) is64bit isMips isDarwin isCygwin; + inherit (stdenv.hostPlatform) + is64bit + isMips + isDarwin + isCygwin + ; inherit (lib) enableFeature optional optionals; # libvpx darwin targets include darwin version (ie. ARCH-darwinXX-gcc, XX being the darwin version) # See all_platforms: https://github.com/webmproject/libvpx/blob/master/configure # Darwin versions: 10.4=8, 10.5=9, 10.6=10, 10.7=11, 10.8=12, 10.9=13, 10.10=14 darwinVersion = - /**/ if stdenv.hostPlatform.osxMinVersion == "10.10" then "14" - else if stdenv.hostPlatform.osxMinVersion == "10.9" then "13" - else if stdenv.hostPlatform.osxMinVersion == "10.8" then "12" - else if stdenv.hostPlatform.osxMinVersion == "10.7" then "11" - else if stdenv.hostPlatform.osxMinVersion == "10.6" then "10" - else if stdenv.hostPlatform.osxMinVersion == "10.5" then "9" - else "8"; + if stdenv.hostPlatform.osxMinVersion == "10.10" then + "14" + else if stdenv.hostPlatform.osxMinVersion == "10.9" then + "13" + else if stdenv.hostPlatform.osxMinVersion == "10.8" then + "12" + else if stdenv.hostPlatform.osxMinVersion == "10.7" then + "11" + else if stdenv.hostPlatform.osxMinVersion == "10.6" then + "10" + else if stdenv.hostPlatform.osxMinVersion == "10.5" then + "9" + else + "8"; cpu = - /**/ if stdenv.hostPlatform.isArmv7 then "armv7" - else if stdenv.hostPlatform.isAarch64 then "arm64" - else if stdenv.hostPlatform.isx86_32 then "x86" - else stdenv.hostPlatform.parsed.cpu.name; + if stdenv.hostPlatform.isArmv7 then + "armv7" + else if stdenv.hostPlatform.isAarch64 then + "arm64" + else if stdenv.hostPlatform.isx86_32 then + "x86" + else + stdenv.hostPlatform.parsed.cpu.name; kernel = # Build system doesn't understand BSD, so pretend to be Linux. - /**/ if stdenv.hostPlatform.isBSD then "linux" - else if stdenv.hostPlatform.isDarwin then "darwin${darwinVersion}" - else stdenv.hostPlatform.parsed.kernel.name; + if stdenv.hostPlatform.isBSD then + "linux" + else if stdenv.hostPlatform.isDarwin then + "darwin${darwinVersion}" + else + stdenv.hostPlatform.parsed.kernel.name; isGeneric = - /**/ (stdenv.hostPlatform.isPower && stdenv.hostPlatform.isLittleEndian) + (stdenv.hostPlatform.isPower && stdenv.hostPlatform.isLittleEndian) || stdenv.hostPlatform.parsed.cpu.name == "armv6l" || stdenv.hostPlatform.isRiscV; target = - /**/ if (stdenv.hostPlatform.isBSD || stdenv.hostPlatform != stdenv.buildPlatform) then + if (stdenv.hostPlatform.isBSD || stdenv.hostPlatform != stdenv.buildPlatform) then (if isGeneric then "generic-gnu" else "${cpu}-${kernel}-gcc") - else null; + else + null; in assert vp8DecoderSupport || vp8EncoderSupport || vp9DecoderSupport || vp9EncoderSupport; assert internalStatsSupport && (vp9DecoderSupport || vp9EncoderSupport) -> postprocSupport; -/* If spatialResamplingSupport not enabled, build will fail with undeclared variable errors. - Variables called in vpx_scale/generic/vpx_scale.c are declared by vpx_scale/vpx_scale_rtcd.pl, - but is only executed if spatialResamplingSupport is enabled */ +/* + If spatialResamplingSupport not enabled, build will fail with undeclared variable errors. + Variables called in vpx_scale/generic/vpx_scale.c are declared by vpx_scale/vpx_scale_rtcd.pl, + but is only executed if spatialResamplingSupport is enabled +*/ assert spatialResamplingSupport; assert postprocVisualizerSupport -> postprocSupport; assert unitTestsSupport -> curl != null && coreutils != null; @@ -119,81 +148,94 @@ stdenv.mkDerivation rec { --replace "check_cflags -Wshorten-64-to-32 && add_cflags_only -Wshorten-64-to-32" "" ''; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; setOutputFlags = false; - configurePlatforms = []; - configureFlags = [ - (enableFeature (vp8EncoderSupport || vp8DecoderSupport) "vp8") - (enableFeature vp8EncoderSupport "vp8-encoder") - (enableFeature vp8DecoderSupport "vp8-decoder") - (enableFeature (vp9EncoderSupport || vp9DecoderSupport) "vp9") - (enableFeature vp9EncoderSupport "vp9-encoder") - (enableFeature vp9DecoderSupport "vp9-decoder") - (enableFeature extraWarningsSupport "extra-warnings") - (enableFeature werrorSupport "werror") - "--disable-install-docs" - (enableFeature examplesSupport "install-bins") - "--enable-install-libs" - "--disable-install-srcs" - (enableFeature debugSupport "debug") - (enableFeature gprofSupport "gprof") - (enableFeature gcovSupport "gcov") - # Required to build shared libraries - (enableFeature (!isCygwin) "pic") - (enableFeature optimizationsSupport "optimizations") - (enableFeature runtimeCpuDetectSupport "runtime-cpu-detect") - (enableFeature thumbSupport "thumb") - "--enable-libs" - (enableFeature examplesSupport "examples") - "--disable-docs" - "--as=yasm" - # Limit default decoder max to WHXGA - (if sizeLimitSupport then "--size-limit=5120x3200" else null) - "--disable-codec-srcs" - (enableFeature debugLibsSupport "debug-libs") - (enableFeature isMips "dequant-tokens") - (enableFeature isMips "dc-recon") - (enableFeature postprocSupport "postproc") - (enableFeature (postprocSupport && (vp9DecoderSupport || vp9EncoderSupport)) "vp9-postproc") - (enableFeature multithreadSupport "multithread") - (enableFeature internalStatsSupport "internal-stats") - (enableFeature spatialResamplingSupport "spatial-resampling") - (enableFeature realtimeOnlySupport "realtime-only") - (enableFeature ontheflyBitpackingSupport "onthefly-bitpacking") - (enableFeature errorConcealmentSupport "error-concealment") - # Shared libraries are only supported on ELF platforms - (if isDarwin || isCygwin then - "--enable-static --disable-shared" - else - "--enable-shared") - (enableFeature smallSupport "small") - (enableFeature postprocVisualizerSupport "postproc-visualizer") - (enableFeature unitTestsSupport "unit-tests") - (enableFeature webmIOSupport "webm-io") - (enableFeature libyuvSupport "libyuv") - (enableFeature decodePerfTestsSupport "decode-perf-tests") - (enableFeature encodePerfTestsSupport "encode-perf-tests") - (enableFeature multiResEncodingSupport "multi-res-encoding") - (enableFeature temporalDenoisingSupport "temporal-denoising") - (enableFeature (temporalDenoisingSupport && (vp9DecoderSupport || vp9EncoderSupport)) "vp9-temporal-denoising") - (enableFeature coefficientRangeCheckingSupport "coefficient-range-checking") - (enableFeature (vp9HighbitdepthSupport && is64bit) "vp9-highbitdepth") - (enableFeature (experimentalSpatialSvcSupport || - experimentalFpMbStatsSupport || - experimentalEmulateHardwareSupport) "experimental") - ] ++ optionals (target != null) [ - "--target=${target}" - (lib.optionalString stdenv.hostPlatform.isCygwin "--enable-static-msvcrt") - ] # Experimental features + configurePlatforms = [ ]; + configureFlags = + [ + (enableFeature (vp8EncoderSupport || vp8DecoderSupport) "vp8") + (enableFeature vp8EncoderSupport "vp8-encoder") + (enableFeature vp8DecoderSupport "vp8-decoder") + (enableFeature (vp9EncoderSupport || vp9DecoderSupport) "vp9") + (enableFeature vp9EncoderSupport "vp9-encoder") + (enableFeature vp9DecoderSupport "vp9-decoder") + (enableFeature extraWarningsSupport "extra-warnings") + (enableFeature werrorSupport "werror") + "--disable-install-docs" + (enableFeature examplesSupport "install-bins") + "--enable-install-libs" + "--disable-install-srcs" + (enableFeature debugSupport "debug") + (enableFeature gprofSupport "gprof") + (enableFeature gcovSupport "gcov") + # Required to build shared libraries + (enableFeature (!isCygwin) "pic") + (enableFeature optimizationsSupport "optimizations") + (enableFeature runtimeCpuDetectSupport "runtime-cpu-detect") + (enableFeature thumbSupport "thumb") + "--enable-libs" + (enableFeature examplesSupport "examples") + "--disable-docs" + "--as=yasm" + # Limit default decoder max to WHXGA + (if sizeLimitSupport then "--size-limit=5120x3200" else null) + "--disable-codec-srcs" + (enableFeature debugLibsSupport "debug-libs") + (enableFeature isMips "dequant-tokens") + (enableFeature isMips "dc-recon") + (enableFeature postprocSupport "postproc") + (enableFeature (postprocSupport && (vp9DecoderSupport || vp9EncoderSupport)) "vp9-postproc") + (enableFeature multithreadSupport "multithread") + (enableFeature internalStatsSupport "internal-stats") + (enableFeature spatialResamplingSupport "spatial-resampling") + (enableFeature realtimeOnlySupport "realtime-only") + (enableFeature ontheflyBitpackingSupport "onthefly-bitpacking") + (enableFeature errorConcealmentSupport "error-concealment") + # Shared libraries are only supported on ELF platforms + (if isDarwin || isCygwin then "--enable-static --disable-shared" else "--enable-shared") + (enableFeature smallSupport "small") + (enableFeature postprocVisualizerSupport "postproc-visualizer") + (enableFeature unitTestsSupport "unit-tests") + (enableFeature webmIOSupport "webm-io") + (enableFeature libyuvSupport "libyuv") + (enableFeature decodePerfTestsSupport "decode-perf-tests") + (enableFeature encodePerfTestsSupport "encode-perf-tests") + (enableFeature multiResEncodingSupport "multi-res-encoding") + (enableFeature temporalDenoisingSupport "temporal-denoising") + (enableFeature ( + temporalDenoisingSupport && (vp9DecoderSupport || vp9EncoderSupport) + ) "vp9-temporal-denoising") + (enableFeature coefficientRangeCheckingSupport "coefficient-range-checking") + (enableFeature (vp9HighbitdepthSupport && is64bit) "vp9-highbitdepth") + (enableFeature ( + experimentalSpatialSvcSupport || experimentalFpMbStatsSupport || experimentalEmulateHardwareSupport + ) "experimental") + ] + ++ optionals (target != null) [ + "--target=${target}" + (lib.optionalString stdenv.hostPlatform.isCygwin "--enable-static-msvcrt") + ] + # Experimental features ++ optional experimentalSpatialSvcSupport "--enable-spatial-svc" ++ optional experimentalFpMbStatsSupport "--enable-fp-mb-stats" ++ optional experimentalEmulateHardwareSupport "--enable-emulate-hardware"; - nativeBuildInputs = [ perl yasm ]; + nativeBuildInputs = [ + perl + yasm + ]; - buildInputs = [ ] - ++ optionals unitTestsSupport [ coreutils curl ]; + buildInputs = + [ ] + ++ optionals unitTestsSupport [ + coreutils + curl + ]; NIX_LDFLAGS = [ "-lpthread" # fixes linker errors @@ -210,10 +252,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "WebM VP8/VP9 codec SDK"; - homepage = "https://www.webmproject.org/"; - changelog = "https://github.com/webmproject/libvpx/raw/v${version}/CHANGELOG"; - license = licenses.bsd3; + homepage = "https://www.webmproject.org/"; + changelog = "https://github.com/webmproject/libvpx/raw/v${version}/CHANGELOG"; + license = licenses.bsd3; maintainers = with maintainers; [ codyopel ]; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/li/libvterm-neovim/package.nix b/pkgs/by-name/li/libvterm-neovim/package.nix index 0e92d28046aa3b..5f183515da9803 100644 --- a/pkgs/by-name/li/libvterm-neovim/package.nix +++ b/pkgs/by-name/li/libvterm-neovim/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, perl -, libtool +{ + lib, + stdenv, + fetchurl, + perl, + libtool, }: stdenv.mkDerivation rec { @@ -15,7 +16,10 @@ stdenv.mkDerivation rec { hash = "sha256-CRVvQ90hKL00fL7r5Q2aVx0yxk4M8Y0hEZeUav9yJuA="; }; - nativeBuildInputs = [ perl libtool ]; + nativeBuildInputs = [ + perl + libtool + ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" diff --git a/pkgs/by-name/li/libvterm/package.nix b/pkgs/by-name/li/libvterm/package.nix index f1e217f2b3e520..30980297efcdfd 100644 --- a/pkgs/by-name/li/libvterm/package.nix +++ b/pkgs/by-name/li/libvterm/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, ncurses }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + ncurses, +}: stdenv.mkDerivation rec { pname = "libvterm"; diff --git a/pkgs/by-name/li/libwbxml/package.nix b/pkgs/by-name/li/libwbxml/package.nix index 1ddc1c3534ccaf..294ef4ea3472d8 100644 --- a/pkgs/by-name/li/libwbxml/package.nix +++ b/pkgs/by-name/li/libwbxml/package.nix @@ -1,4 +1,10 @@ -{ stdenv, fetchFromGitHub, lib, cmake, expat }: +{ + stdenv, + fetchFromGitHub, + lib, + cmake, + expat, +}: stdenv.mkDerivation rec { pname = "libwbxml"; diff --git a/pkgs/by-name/li/libwebcam/package.nix b/pkgs/by-name/li/libwebcam/package.nix index 093b3dac21f20f..d2759838ac5ea2 100644 --- a/pkgs/by-name/li/libwebcam/package.nix +++ b/pkgs/by-name/li/libwebcam/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, cmake -, pkg-config -, libxml2 +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + libxml2, }: stdenv.mkDerivation rec { @@ -19,7 +20,10 @@ stdenv.mkDerivation rec { ./uvcdynctrl_symlink_support_and_take_data_dir_from_env.patch ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libxml2 ]; postPatch = '' @@ -34,7 +38,6 @@ stdenv.mkDerivation rec { --replace "/lib/udev" "$out/lib/udev" ''; - preConfigure = '' cmakeFlagsArray=( $cmakeFlagsArray diff --git a/pkgs/by-name/li/libwebsockets/package.nix b/pkgs/by-name/li/libwebsockets/package.nix index 8cdcd9d19560d0..39b4335552f956 100644 --- a/pkgs/by-name/li/libwebsockets/package.nix +++ b/pkgs/by-name/li/libwebsockets/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, openssl -, zlib -, libuv -, removeReferencesTo +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openssl, + zlib, + libuv, + removeReferencesTo, # External poll is required for e.g. mosquitto, but discouraged by the maintainer. -, withExternalPoll ? false + withExternalPoll ? false, }: stdenv.mkDerivation rec { @@ -21,26 +22,41 @@ stdenv.mkDerivation rec { hash = "sha256-IXA9NUh55GtZmn4BhCXntVdHcKZ34iZIJ/0wlySj0/M="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - buildInputs = [ openssl zlib libuv ]; + buildInputs = [ + openssl + zlib + libuv + ]; - nativeBuildInputs = [ cmake removeReferencesTo ]; + nativeBuildInputs = [ + cmake + removeReferencesTo + ]; - cmakeFlags = [ - "-DLWS_WITH_PLUGINS=ON" - "-DLWS_WITH_IPV6=ON" - "-DLWS_WITH_SOCKS5=ON" - "-DDISABLE_WERROR=ON" - "-DLWS_BUILD_HASH=no_hash" - ] ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "-DLWS_WITHOUT_TESTAPPS=ON" - ++ lib.optional withExternalPoll "-DLWS_WITH_EXTERNAL_POLL=ON" - ++ ( - if stdenv.hostPlatform.isStatic then - [ "-DLWS_WITH_SHARED=OFF" ] - else - [ "-DLWS_WITH_STATIC=OFF" "-DLWS_LINK_TESTAPPS_DYNAMIC=ON" ] - ); + cmakeFlags = + [ + "-DLWS_WITH_PLUGINS=ON" + "-DLWS_WITH_IPV6=ON" + "-DLWS_WITH_SOCKS5=ON" + "-DDISABLE_WERROR=ON" + "-DLWS_BUILD_HASH=no_hash" + ] + ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "-DLWS_WITHOUT_TESTAPPS=ON" + ++ lib.optional withExternalPoll "-DLWS_WITH_EXTERNAL_POLL=ON" + ++ ( + if stdenv.hostPlatform.isStatic then + [ "-DLWS_WITH_SHARED=OFF" ] + else + [ + "-DLWS_WITH_STATIC=OFF" + "-DLWS_LINK_TESTAPPS_DYNAMIC=ON" + ] + ); postInstall = '' find "$out" -type f -exec remove-references-to -t ${stdenv.cc.cc} '{}' + @@ -67,9 +83,13 @@ stdenv.mkDerivation rec { homepage = "https://libwebsockets.org/"; # Relicensed from LGPLv2.1+ to MIT with 4.0. Licensing situation # is tricky, see https://github.com/warmcat/libwebsockets/blob/main/LICENSE - license = with licenses; [ mit publicDomain bsd3 asl20 ]; + license = with licenses; [ + mit + publicDomain + bsd3 + asl20 + ]; maintainers = with maintainers; [ mindavi ]; platforms = platforms.all; }; } - diff --git a/pkgs/by-name/li/libwhereami/package.nix b/pkgs/by-name/li/libwhereami/package.nix index 455e59d89718cc..f21551ca02420c 100644 --- a/pkgs/by-name/li/libwhereami/package.nix +++ b/pkgs/by-name/li/libwhereami/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, boost, curl, leatherman }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + curl, + leatherman, +}: stdenv.mkDerivation rec { pname = "libwhereami"; @@ -15,14 +23,22 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ boost curl leatherman ]; + buildInputs = [ + boost + curl + leatherman + ]; meta = with lib; { inherit (src.meta) homepage; description = "Library to report hypervisor information from inside a VM"; license = licenses.asl20; maintainers = [ maintainers.womfoo ]; - platforms = [ "i686-linux" "x86_64-linux" "x86_64-darwin" ]; # fails on aarch64 + platforms = [ + "i686-linux" + "x86_64-linux" + "x86_64-darwin" + ]; # fails on aarch64 }; } diff --git a/pkgs/by-name/li/libwhich/package.nix b/pkgs/by-name/li/libwhich/package.nix index e8d919cfabe02a..d4b26174623a1d 100644 --- a/pkgs/by-name/li/libwhich/package.nix +++ b/pkgs/by-name/li/libwhich/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "libwhich"; diff --git a/pkgs/by-name/li/libwmf/package.nix b/pkgs/by-name/li/libwmf/package.nix index b42e09894db8ff..2511289349db0c 100644 --- a/pkgs/by-name/li/libwmf/package.nix +++ b/pkgs/by-name/li/libwmf/package.nix @@ -1,12 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config -, freetype, glib, imagemagick, libjpeg, libpng, libxml2, zlib +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + freetype, + glib, + imagemagick, + libjpeg, + libpng, + libxml2, + zlib, }: stdenv.mkDerivation rec { pname = "libwmf"; version = "0.2.13"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "caolanm"; @@ -16,7 +29,15 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ zlib imagemagick libpng glib freetype libjpeg libxml2 ]; + buildInputs = [ + zlib + imagemagick + libpng + glib + freetype + libjpeg + libxml2 + ]; enableParallelBuilding = true; meta = with lib; { diff --git a/pkgs/by-name/li/libwpg/package.nix b/pkgs/by-name/li/libwpg/package.nix index ada7f984a4a2d5..f0cee5d5c87a0d 100644 --- a/pkgs/by-name/li/libwpg/package.nix +++ b/pkgs/by-name/li/libwpg/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, libwpd, zlib, librevenge, boost }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libwpd, + zlib, + librevenge, + boost, +}: stdenv.mkDerivation rec { pname = "libwpg"; @@ -9,13 +18,21 @@ stdenv.mkDerivation rec { hash = "sha256-tV/alEDR4HBjDrJIfYuGl89BLCFKJ8runfac7HwATeM="; }; - buildInputs = [ libwpd zlib librevenge boost ]; + buildInputs = [ + libwpd + zlib + librevenge + boost + ]; nativeBuildInputs = [ pkg-config ]; meta = with lib; { homepage = "https://libwpg.sourceforge.net"; description = "C++ library to parse WPG"; - license = with licenses; [ lgpl21 mpl20 ]; + license = with licenses; [ + lgpl21 + mpl20 + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/li/libwps/package.nix b/pkgs/by-name/li/libwps/package.nix index f5af2e8284c863..9b2f54b9b883f2 100644 --- a/pkgs/by-name/li/libwps/package.nix +++ b/pkgs/by-name/li/libwps/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, boost, pkg-config, librevenge, zlib }: +{ + lib, + stdenv, + fetchurl, + boost, + pkg-config, + librevenge, + zlib, +}: stdenv.mkDerivation rec { pname = "libwps"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ boost librevenge zlib ]; + buildInputs = [ + boost + librevenge + zlib + ]; env.NIX_CFLAGS_COMPILE = "-Wno-error=implicit-fallthrough"; diff --git a/pkgs/by-name/li/libwtk-sdl2/package.nix b/pkgs/by-name/li/libwtk-sdl2/package.nix index 4da8873ca775cb..6415480e135fa1 100644 --- a/pkgs/by-name/li/libwtk-sdl2/package.nix +++ b/pkgs/by-name/li/libwtk-sdl2/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, boost -, SDL2 -, SDL2_ttf -, SDL2_image +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + boost, + SDL2, + SDL2_ttf, + SDL2_image, }: stdenv.mkDerivation (finalAttrs: { @@ -33,7 +34,11 @@ stdenv.mkDerivation (finalAttrs: { # From some reason, this is needed as otherwise SDL.h is not found NIX_CFLAGS_COMPILE = "-I${SDL2.dev}/include/SDL2"; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; meta = with lib; { description = "Simplistic SDL2 GUI framework in early developement"; @@ -42,10 +47,11 @@ stdenv.mkDerivation (finalAttrs: { # See: https://github.com/muesli4/mpd-touch-screen-gui/tree/master/LICENSES license = licenses.lgpl3Plus; maintainers = with maintainers; [ doronbehar ]; - /* Partial darwin build failure log (from ofborg): - geometry.cpp:95:34: error: no member named 'abs' in namespace 'std' - > return { std::abs(v.w), std::abs(v.h) }; - > ~~~~~^ + /* + Partial darwin build failure log (from ofborg): + geometry.cpp:95:34: error: no member named 'abs' in namespace 'std' + > return { std::abs(v.w), std::abs(v.h) }; + > ~~~~~^ */ platforms = platforms.linux; }; diff --git a/pkgs/by-name/li/libx86/package.nix b/pkgs/by-name/li/libx86/package.nix index 0c7c981f82214c..487c24e18cd65f 100644 --- a/pkgs/by-name/li/libx86/package.nix +++ b/pkgs/by-name/li/libx86/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libx86"; @@ -7,7 +11,10 @@ stdenv.mkDerivation rec { url = "https://www.codon.org.uk/~mjg59/libx86/downloads/${pname}-${version}.tar.gz"; sha256 = "0j6h6bc02c6qi0q7c1ncraz4d1hkm5936r35rfsp4x1jrc233wav"; }; - patches = [./constants.patch ./non-x86.patch ]; + patches = [ + ./constants.patch + ./non-x86.patch + ]; # using BACKEND=x86emu on 64bit systems fixes: # http://www.mail-archive.com/suspend-devel@lists.sourceforge.net/msg02355.html @@ -27,7 +34,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Real-mode x86 code emulator"; maintainers = with maintainers; [ raskin ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; license = licenses.mit; }; } diff --git a/pkgs/by-name/li/libx86/src-for-default.nix b/pkgs/by-name/li/libx86/src-for-default.nix index b7e432d8109cc9..6e0b75967e82f7 100644 --- a/pkgs/by-name/li/libx86/src-for-default.nix +++ b/pkgs/by-name/li/libx86/src-for-default.nix @@ -1,7 +1,7 @@ rec { - pname="libx86"; - version="1.1"; - hash="0j6h6bc02c6qi0q7c1ncraz4d1hkm5936r35rfsp4x1jrc233wav"; - url="http://www.codon.org.uk/~mjg59/libx86/downloads/libx86-${version}.tar.gz"; - advertisedUrl="http://www.codon.org.uk/~mjg59/libx86/downloads/libx86-${version}.tar.gz"; + pname = "libx86"; + version = "1.1"; + hash = "0j6h6bc02c6qi0q7c1ncraz4d1hkm5936r35rfsp4x1jrc233wav"; + url = "http://www.codon.org.uk/~mjg59/libx86/downloads/libx86-${version}.tar.gz"; + advertisedUrl = "http://www.codon.org.uk/~mjg59/libx86/downloads/libx86-${version}.tar.gz"; } diff --git a/pkgs/by-name/li/libx86emu/package.nix b/pkgs/by-name/li/libx86emu/package.nix index 4ace07d2cf0e40..caea4869f04d8e 100644 --- a/pkgs/by-name/li/libx86emu/package.nix +++ b/pkgs/by-name/li/libx86emu/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation rec { pname = "libx86emu"; @@ -20,10 +25,16 @@ stdenv.mkDerivation rec { substituteInPlace Makefile --replace "/usr" "/" ''; - buildFlags = [ "shared" "CC=${stdenv.cc.targetPrefix}cc" ]; + buildFlags = [ + "shared" + "CC=${stdenv.cc.targetPrefix}cc" + ]; enableParallelBuilding = true; - installFlags = [ "DESTDIR=$(out)" "LIBDIR=/lib" ]; + installFlags = [ + "DESTDIR=$(out)" + "LIBDIR=/lib" + ]; meta = with lib; { description = "x86 emulation library"; diff --git a/pkgs/by-name/li/libxc/package.nix b/pkgs/by-name/li/libxc/package.nix index d5e543a1b5f319..29af5687a1714e 100644 --- a/pkgs/by-name/li/libxc/package.nix +++ b/pkgs/by-name/li/libxc/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitLab, cmake, gfortran, perl }: +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + gfortran, + perl, +}: stdenv.mkDerivation rec { pname = "libxc"; @@ -18,9 +25,16 @@ stdenv.mkDerivation rec { --replace "PROPERTIES TIMEOUT 1" "PROPERTIES TIMEOUT 30" ''; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ perl cmake gfortran ]; + nativeBuildInputs = [ + perl + cmake + gfortran + ]; preConfigure = '' patchShebangs ./ diff --git a/pkgs/by-name/li/libxcomp/package.nix b/pkgs/by-name/li/libxcomp/package.nix index b66fe5c5a21a37..ba935930a20755 100644 --- a/pkgs/by-name/li/libxcomp/package.nix +++ b/pkgs/by-name/li/libxcomp/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pkg-config, libjpeg, libpng, libX11, zlib }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + libjpeg, + libpng, + libX11, + zlib, +}: stdenv.mkDerivation rec { pname = "libxcomp"; @@ -9,8 +19,16 @@ stdenv.mkDerivation rec { url = "https://code.x2go.org/releases/source/nx-libs/nx-libs-${version}-lite.tar.gz"; }; - buildInputs = [ libjpeg libpng libX11 zlib ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + buildInputs = [ + libjpeg + libpng + libX11 + zlib + ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; preAutoreconf = '' cd nxcomp/ diff --git a/pkgs/by-name/li/libxdg_basedir/package.nix b/pkgs/by-name/li/libxdg_basedir/package.nix index 7786ec7908ff38..ba1cb5fa606792 100644 --- a/pkgs/by-name/li/libxdg_basedir/package.nix +++ b/pkgs/by-name/li/libxdg_basedir/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libxisf/package.nix b/pkgs/by-name/li/libxisf/package.nix index d19dd27887455b..5087b9529840c1 100644 --- a/pkgs/by-name/li/libxisf/package.nix +++ b/pkgs/by-name/li/libxisf/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitea -, cmake -, pkg-config -, lz4 -, pugixml -, zlib -, zstd +{ + lib, + stdenv, + fetchFromGitea, + cmake, + pkg-config, + lz4, + pugixml, + zlib, + zstd, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/libxkbcommon_8/package.nix b/pkgs/by-name/li/libxkbcommon_8/package.nix index 9a0ebd6d59da1a..88e3830d150cf1 100644 --- a/pkgs/by-name/li/libxkbcommon_8/package.nix +++ b/pkgs/by-name/li/libxkbcommon_8/package.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, bison -, doxygen -, xkeyboard_config -, libxcb -, libxml2 -, python3 -, libX11 +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + bison, + doxygen, + xkeyboard_config, + libxcb, + libxml2, + python3, + libX11, # To enable the "interactive-wayland" subcommand of xkbcli. This is the # wayland equivalent of `xev` on X11. -, xorg -, withWaylandTools ? stdenv.hostPlatform.isLinux -, wayland -, wayland-protocols -, wayland-scanner -, testers + xorg, + withWaylandTools ? stdenv.hostPlatform.isLinux, + wayland, + wayland-protocols, + wayland-scanner, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -35,13 +36,31 @@ stdenv.mkDerivation (finalAttrs: { ./disable-x11com.patch ]; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson ninja pkg-config bison doxygen xorg.xvfb ] - ++ lib.optional withWaylandTools wayland-scanner; - buildInputs = [ xkeyboard_config libxcb libxml2 ] - ++ lib.optionals withWaylandTools [ wayland wayland-protocols ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + bison + doxygen + xorg.xvfb + ] ++ lib.optional withWaylandTools wayland-scanner; + buildInputs = + [ + xkeyboard_config + libxcb + libxml2 + ] + ++ lib.optionals withWaylandTools [ + wayland + wayland-protocols + ]; nativeCheckInputs = [ python3 ]; mesonFlags = [ @@ -74,7 +93,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://xkbcommon.org"; changelog = "https://github.com/xkbcommon/libxkbcommon/blob/xkbcommon-${finalAttrs.version}/NEWS"; license = licenses.mit; - maintainers = with maintainers; [ primeos ttuegel ]; + maintainers = with maintainers; [ + primeos + ttuegel + ]; mainProgram = "xkbcli"; platforms = with platforms; unix; pkgConfigModules = [ diff --git a/pkgs/by-name/li/libxklavier/package.nix b/pkgs/by-name/li/libxklavier/package.nix index b6a217d9fbf8e7..aacab4527abbbf 100644 --- a/pkgs/by-name/li/libxklavier/package.nix +++ b/pkgs/by-name/li/libxklavier/package.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchgit, fetchpatch, autoreconfHook, pkg-config, gtk-doc, xkeyboard_config, libxml2, xorg, docbook_xsl -, glib, isocodes, gobject-introspection -, withDoc ? (stdenv.buildPlatform == stdenv.hostPlatform) +{ + lib, + stdenv, + fetchgit, + fetchpatch, + autoreconfHook, + pkg-config, + gtk-doc, + xkeyboard_config, + libxml2, + xorg, + docbook_xsl, + glib, + isocodes, + gobject-introspection, + withDoc ? (stdenv.buildPlatform == stdenv.hostPlatform), }: stdenv.mkDerivation rec { @@ -13,21 +26,41 @@ stdenv.mkDerivation rec { sha256 = "1w1x5mrgly2ldiw3q2r6y620zgd89gk7n90ja46775lhaswxzv7a"; }; - patches = [ - ./honor-XKB_CONFIG_ROOT.patch - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - (fetchpatch { - url = "https://gitlab.freedesktop.org/archived-projects/libxklavier/-/commit/1387c21a788ec1ea203c8392ea1460fc29d83f70.patch"; - sha256 = "sha256-fyWu7sVfDv/ozjhLSLCVsv+iNFawWgJqHUsQHHSkQn4="; - }) - ]; + patches = + [ + ./honor-XKB_CONFIG_ROOT.patch + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + (fetchpatch { + url = "https://gitlab.freedesktop.org/archived-projects/libxklavier/-/commit/1387c21a788ec1ea203c8392ea1460fc29d83f70.patch"; + sha256 = "sha256-fyWu7sVfDv/ozjhLSLCVsv+iNFawWgJqHUsQHHSkQn4="; + }) + ]; - outputs = [ "out" "dev" ] ++ lib.optionals withDoc [ "devdoc" ]; + outputs = [ + "out" + "dev" + ] ++ lib.optionals withDoc [ "devdoc" ]; # TODO: enable xmodmap support, needs xmodmap DB - propagatedBuildInputs = with xorg; [ libX11 libXi xkeyboard_config libxml2 libICE glib libxkbfile isocodes ]; + propagatedBuildInputs = with xorg; [ + libX11 + libXi + xkeyboard_config + libxml2 + libICE + glib + libxkbfile + isocodes + ]; - nativeBuildInputs = [ autoreconfHook pkg-config gtk-doc docbook_xsl gobject-introspection ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + gtk-doc + docbook_xsl + gobject-introspection + ]; preAutoreconf = '' export NOCONFIGURE=1 diff --git a/pkgs/by-name/li/libxl/package.nix b/pkgs/by-name/li/libxl/package.nix index 3a6c0ca18edd45..a8700bc8391dcb 100644 --- a/pkgs/by-name/li/libxl/package.nix +++ b/pkgs/by-name/li/libxl/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libxl"; @@ -20,9 +24,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Library for parsing Excel files"; - homepage = "https://www.libxl.com/"; - license = licenses.unfree; - platforms = platforms.linux; + homepage = "https://www.libxl.com/"; + license = licenses.unfree; + platforms = platforms.linux; maintainers = [ ]; }; } diff --git a/pkgs/by-name/li/libxls/package.nix b/pkgs/by-name/li/libxls/package.nix index 4c9b77d7c387bd..5a5dee9255d360 100644 --- a/pkgs/by-name/li/libxls/package.nix +++ b/pkgs/by-name/li/libxls/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, autoconf-archive }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + autoconf-archive, +}: stdenv.mkDerivation rec { pname = "libxls"; @@ -19,7 +26,10 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook autoconf-archive ]; + nativeBuildInputs = [ + autoreconfHook + autoconf-archive + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/li/libxlsxwriter/package.nix b/pkgs/by-name/li/libxlsxwriter/package.nix index 6f1a43d28a11de..124e157c2c3e4e 100644 --- a/pkgs/by-name/li/libxlsxwriter/package.nix +++ b/pkgs/by-name/li/libxlsxwriter/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, minizip -, python3 -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + minizip, + python3, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libxmi/package.nix b/pkgs/by-name/li/libxmi/package.nix index 2446df52a2bc9d..aa0ec1d89c7ab0 100644 --- a/pkgs/by-name/li/libxmi/package.nix +++ b/pkgs/by-name/li/libxmi/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libtool }: +{ + lib, + stdenv, + fetchurl, + libtool, +}: stdenv.mkDerivation rec { pname = "libxmi"; diff --git a/pkgs/by-name/li/libxmlb/package.nix b/pkgs/by-name/li/libxmlb/package.nix index 28c314c12e70a6..79937718941ccc 100644 --- a/pkgs/by-name/li/libxmlb/package.nix +++ b/pkgs/by-name/li/libxmlb/package.nix @@ -1,26 +1,33 @@ -{ stdenv -, lib -, fetchFromGitHub -, docbook_xml_dtd_43 -, docbook-xsl-nons -, glib -, gobject-introspection -, gtk-doc -, meson -, ninja -, pkg-config -, python3 -, shared-mime-info -, nixosTests -, xz -, zstd +{ + stdenv, + lib, + fetchFromGitHub, + docbook_xml_dtd_43, + docbook-xsl-nons, + glib, + gobject-introspection, + gtk-doc, + meson, + ninja, + pkg-config, + python3, + shared-mime-info, + nixosTests, + xz, + zstd, }: stdenv.mkDerivation rec { pname = "libxmlb"; version = "0.3.21"; - outputs = [ "out" "lib" "dev" "devdoc" "installedTests" ]; + outputs = [ + "out" + "lib" + "dev" + "devdoc" + "installedTests" + ]; src = fetchFromGitHub { owner = "hughsie"; diff --git a/pkgs/by-name/li/libxmp/package.nix b/pkgs/by-name/li/libxmp/package.nix index 1cd4e5aa03a983..7d8fcb94a4a3dc 100644 --- a/pkgs/by-name/li/libxmp/package.nix +++ b/pkgs/by-name/li/libxmp/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libxmp"; @@ -6,14 +10,14 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Extended module player library"; - homepage = "https://xmp.sourceforge.net/"; + homepage = "https://xmp.sourceforge.net/"; longDescription = '' Libxmp is a library that renders module files to PCM data. It supports over 90 mainstream and obscure module formats including Protracker (MOD), Scream Tracker 3 (S3M), Fast Tracker II (XM), and Impulse Tracker (IT). ''; - license = licenses.lgpl21Plus; - platforms = platforms.all; + license = licenses.lgpl21Plus; + platforms = platforms.all; }; src = fetchurl { diff --git a/pkgs/by-name/li/libxplayer-plparser/package.nix b/pkgs/by-name/li/libxplayer-plparser/package.nix index 51358b45bbda01..e6c64a78d06d55 100644 --- a/pkgs/by-name/li/libxplayer-plparser/package.nix +++ b/pkgs/by-name/li/libxplayer-plparser/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, gobject-introspection -, gmime3 -, libxml2 -, libsoup_2_4 -, pkg-config +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + gobject-introspection, + gmime3, + libxml2, + libsoup_2_4, + pkg-config, }: stdenv.mkDerivation rec { @@ -37,7 +38,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Playlist parsing library for xplayer"; homepage = "https://github.com/linuxmint/xplayer-plparser"; - maintainers = with maintainers; [ tu-maurice bobby285271 ]; + maintainers = with maintainers; [ + tu-maurice + bobby285271 + ]; license = licenses.lgpl2Plus; platforms = platforms.linux; }; diff --git a/pkgs/by-name/li/libxsmm/package.nix b/pkgs/by-name/li/libxsmm/package.nix index 3276354240f4a9..fcb99e8c346cfd 100644 --- a/pkgs/by-name/li/libxsmm/package.nix +++ b/pkgs/by-name/li/libxsmm/package.nix @@ -1,7 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, gfortran -, python3, util-linux, which +{ + lib, + stdenv, + fetchFromGitHub, + gfortran, + python3, + util-linux, + which, -, enableStatic ? stdenv.hostPlatform.isStatic + enableStatic ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { @@ -18,7 +24,11 @@ stdenv.mkDerivation rec { # Fixes /build references in the rpath patches = [ ./rpath.patch ]; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; nativeBuildInputs = [ gfortran @@ -31,13 +41,15 @@ stdenv.mkDerivation rec { dontConfigure = true; - makeFlags = let - static = if enableStatic then "1" else "0"; - in [ - "OMP=1" - "PREFIX=$(out)" - "STATIC=${static}" - ]; + makeFlags = + let + static = if enableStatic then "1" else "0"; + in + [ + "OMP=1" + "PREFIX=$(out)" + "STATIC=${static}" + ]; postInstall = '' mkdir -p $dev/lib/pkgconfig diff --git a/pkgs/by-name/li/libyafaray/package.nix b/pkgs/by-name/li/libyafaray/package.nix index b5c8b45fc76e24..fbd13a7cada713 100644 --- a/pkgs/by-name/li/libyafaray/package.nix +++ b/pkgs/by-name/li/libyafaray/package.nix @@ -1,18 +1,20 @@ -{ cmake -, fetchFromGitHub -, freetype -, ilmbase -, lib -, libjpeg -, libtiff -, libxml2 -, opencv -, openexr -, pkg-config -, stdenv -, swig -, zlib -, withPython ? true, python3 +{ + cmake, + fetchFromGitHub, + freetype, + ilmbase, + lib, + libjpeg, + libtiff, + libxml2, + opencv, + openexr, + pkg-config, + stdenv, + swig, + zlib, + withPython ? true, + python3, }: stdenv.mkDerivation rec { @@ -20,9 +22,9 @@ stdenv.mkDerivation rec { version = "unstable-2022-09-17"; src = fetchFromGitHub { - owner = "YafaRay"; - repo = "libYafaRay"; - rev = "6e8c45fb150185b3356220e5f99478f20408ee49"; + owner = "YafaRay"; + repo = "libYafaRay"; + rev = "6e8c45fb150185b3356220e5f99478f20408ee49"; sha256 = "sha256-UVBA1vXOuLg4RT+BdF4rhbZ6I9ySeZX0N81gh3MH84I="; }; @@ -58,7 +60,10 @@ stdenv.mkDerivation rec { homepage = "http://www.yafaray.org"; maintainers = with maintainers; [ hodapp ]; license = licenses.lgpl21; - platforms = [ "aarch64-linux" "x86_64-linux" ]; + platforms = [ + "aarch64-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/li/libyaml/package.nix b/pkgs/by-name/li/libyaml/package.nix index dc58226edea4b1..9ab641e5543d1f 100644 --- a/pkgs/by-name/li/libyaml/package.nix +++ b/pkgs/by-name/li/libyaml/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { @@ -14,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "18zsnsxc53pans4a01cs4401a2cjk3qi098hi440pj4zijifgcsb"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ autoreconfHook ]; diff --git a/pkgs/by-name/li/libyang/package.nix b/pkgs/by-name/li/libyang/package.nix index 6e3e3d841e64f9..30b40d0a013e13 100644 --- a/pkgs/by-name/li/libyang/package.nix +++ b/pkgs/by-name/li/libyang/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub +{ + stdenv, + lib, + fetchFromGitHub, -# build time -, cmake -, pkg-config + # build time + cmake, + pkg-config, -# run time -, pcre2 + # run time + pcre2, -# update script -, gitUpdater + # update script + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/libykclient/package.nix b/pkgs/by-name/li/libykclient/package.nix index 0f99c86f939218..a35a5a92a490d2 100644 --- a/pkgs/by-name/li/libykclient/package.nix +++ b/pkgs/by-name/li/libykclient/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, help2man, curl }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + help2man, + curl, +}: stdenv.mkDerivation { pname = "libykclient"; @@ -10,7 +18,11 @@ stdenv.mkDerivation { sha256 = "01b19jgv2lypih6lhw9yjjsfl8q1ahl955vhr2ai8ccshh0050yj"; }; - nativeBuildInputs = [ autoreconfHook pkg-config help2man ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + help2man + ]; buildInputs = [ curl ]; meta = with lib; { diff --git a/pkgs/by-name/li/libykneomgr/package.nix b/pkgs/by-name/li/libykneomgr/package.nix index 8278b3d8a84187..06d8a8e87e13b4 100644 --- a/pkgs/by-name/li/libykneomgr/package.nix +++ b/pkgs/by-name/li/libykneomgr/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, pcsclite, libzip, help2man }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + pcsclite, + libzip, + help2man, +}: stdenv.mkDerivation rec { pname = "libykneomgr"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ pcsclite libzip help2man ]; + buildInputs = [ + pcsclite + libzip + help2man + ]; configureFlags = [ "--with-backend=pcsc" diff --git a/pkgs/by-name/li/libytnef/package.nix b/pkgs/by-name/li/libytnef/package.nix index 43734b19b890da..9b3bf8c5e3fe68 100644 --- a/pkgs/by-name/li/libytnef/package.nix +++ b/pkgs/by-name/li/libytnef/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, autoreconfHook }: +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "libytnef"; diff --git a/pkgs/by-name/li/libyubikey/package.nix b/pkgs/by-name/li/libyubikey/package.nix index 3b05be00d905d0..edfb08994133d8 100644 --- a/pkgs/by-name/li/libyubikey/package.nix +++ b/pkgs/by-name/li/libyubikey/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libyubikey"; diff --git a/pkgs/by-name/li/libyuv/package.nix b/pkgs/by-name/li/libyuv/package.nix index 1062d527fa2a17..67d4bd43720f85 100644 --- a/pkgs/by-name/li/libyuv/package.nix +++ b/pkgs/by-name/li/libyuv/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchgit -, cmake -, libjpeg +{ + lib, + stdenv, + fetchgit, + cmake, + libjpeg, }: stdenv.mkDerivation rec { @@ -20,7 +21,9 @@ stdenv.mkDerivation rec { ]; # NEON does not work on aarch64, we disable it - cmakeFlags = lib.optionals stdenv.hostPlatform.isAarch64 ["-DCMAKE_CXX_FLAGS=-DLIBYUV_DISABLE_NEON"]; + cmakeFlags = lib.optionals stdenv.hostPlatform.isAarch64 [ + "-DCMAKE_CXX_FLAGS=-DLIBYUV_DISABLE_NEON" + ]; buildInputs = [ libjpeg ]; diff --git a/pkgs/by-name/li/libz/package.nix b/pkgs/by-name/li/libz/package.nix index ac859e1a0bb8bc..62c579d2f20b47 100644 --- a/pkgs/by-name/li/libz/package.nix +++ b/pkgs/by-name/li/libz/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitLab -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitLab, + unstableGitUpdater, }: stdenv.mkDerivation (finalAttrs: { @@ -15,7 +16,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-AQuZ0BOl1iP5Nub+tVwctlE2tfJe4Sq/KDGkjwBbsV4="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; outputDoc = "dev"; # single tiny man3 page passthru.updateScript = unstableGitUpdater { diff --git a/pkgs/by-name/li/libzapojit/package.nix b/pkgs/by-name/li/libzapojit/package.nix index 5de315b794570c..ace4b1bbf65f4a 100644 --- a/pkgs/by-name/li/libzapojit/package.nix +++ b/pkgs/by-name/li/libzapojit/package.nix @@ -1,18 +1,44 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, intltool, json-glib, librest, libsoup_2_4, gnome, gnome-online-accounts, gobject-introspection }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + intltool, + json-glib, + librest, + libsoup_2_4, + gnome, + gnome-online-accounts, + gobject-introspection, +}: stdenv.mkDerivation rec { pname = "libzapojit"; version = "0.0.3"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; sha256 = "0zn3s7ryjc3k1abj4k55dr2na844l451nrg9s6cvnnhh569zj99x"; }; - nativeBuildInputs = [ pkg-config intltool gobject-introspection ]; - propagatedBuildInputs = [ glib json-glib librest libsoup_2_4 gnome-online-accounts ]; # zapojit-0.0.pc + nativeBuildInputs = [ + pkg-config + intltool + gobject-introspection + ]; + propagatedBuildInputs = [ + glib + json-glib + librest + libsoup_2_4 + gnome-online-accounts + ]; # zapojit-0.0.pc passthru = { updateScript = gnome.updateScript { diff --git a/pkgs/by-name/li/libzbc/package.nix b/pkgs/by-name/li/libzbc/package.nix index ebc453847a7aba..d7c00b7b296e33 100644 --- a/pkgs/by-name/li/libzbc/package.nix +++ b/pkgs/by-name/li/libzbc/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, gtk3 -, libtool -, pkg-config -, guiSupport ? false +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + gtk3, + libtool, + pkg-config, + guiSupport ? false, }: stdenv.mkDerivation rec { @@ -32,7 +33,10 @@ stdenv.mkDerivation rec { description = "ZBC device manipulation library"; homepage = "https://github.com/westerndigitalcorporation/libzbc"; maintainers = [ ]; - license = with licenses; [ bsd2 lgpl3Plus ]; + license = with licenses; [ + bsd2 + lgpl3Plus + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/li/libzbd/package.nix b/pkgs/by-name/li/libzbd/package.nix index 3bc48d0657b273..2276e1dfc4d5a2 100644 --- a/pkgs/by-name/li/libzbd/package.nix +++ b/pkgs/by-name/li/libzbd/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, autoconf-archive -, autoreconfHook -, fetchFromGitHub -, gtk3 -, libtool -, pkg-config -, guiSupport ? false +{ + lib, + stdenv, + autoconf-archive, + autoreconfHook, + fetchFromGitHub, + gtk3, + libtool, + pkg-config, + guiSupport ? false, }: stdenv.mkDerivation rec { @@ -35,7 +36,10 @@ stdenv.mkDerivation rec { mainProgram = "zbd"; homepage = "https://github.com/westerndigitalcorporation/libzbd"; maintainers = [ ]; - license = with licenses; [ lgpl3Plus gpl3Plus ]; + license = with licenses; [ + lgpl3Plus + gpl3Plus + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/li/libzdb/package.nix b/pkgs/by-name/li/libzdb/package.nix index bb40e05b9e6fb2..212515cc49c6f0 100644 --- a/pkgs/by-name/li/libzdb/package.nix +++ b/pkgs/by-name/li/libzdb/package.nix @@ -1,20 +1,22 @@ -{lib, stdenv, fetchurl, sqlite}: - -stdenv.mkDerivation rec { + lib, + stdenv, + fetchurl, + sqlite, +}: + +stdenv.mkDerivation rec { version = "3.4.0"; pname = "libzdb"; - src = fetchurl - { + src = fetchurl { url = "https://www.tildeslash.com/libzdb/dist/libzdb-${version}.tar.gz"; sha256 = "sha256-q9Z1cZvL3eQwqk7hOXW5gNVdKry1zCKAgqMDIKa7nw8="; }; buildInputs = [ sqlite ]; - meta = - { + meta = { homepage = "http://www.tildeslash.com/libzdb/"; description = "Small, easy to use Open Source Database Connection Pool Library"; license = lib.licenses.gpl3; diff --git a/pkgs/by-name/li/libzen/package.nix b/pkgs/by-name/li/libzen/package.nix index ecc3736d1fbbbd..ee01bb7a0f2247 100644 --- a/pkgs/by-name/li/libzen/package.nix +++ b/pkgs/by-name/li/libzen/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation rec { version = "0.4.41"; diff --git a/pkgs/by-name/li/libzim-glib/package.nix b/pkgs/by-name/li/libzim-glib/package.nix index 39894323c227f3..183e4d030fabc9 100644 --- a/pkgs/by-name/li/libzim-glib/package.nix +++ b/pkgs/by-name/li/libzim-glib/package.nix @@ -22,7 +22,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-C1f/ULTJIHvt/LCSRw3dsGAWUkb1i4xaCmW1+QBZd2c="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ meson diff --git a/pkgs/by-name/li/libzip/package.nix b/pkgs/by-name/li/libzip/package.nix index 759edc288e4736..d3a6598aa4c34f 100644 --- a/pkgs/by-name/li/libzip/package.nix +++ b/pkgs/by-name/li/libzip/package.nix @@ -1,18 +1,20 @@ -{ lib, stdenv -, cmake -, fetchurl -, perl -, zlib -, groff -, withBzip2 ? false -, bzip2 -, withLZMA ? false -, xz -, withOpenssl ? false -, openssl -, withZstd ? false -, zstd -, testers +{ + lib, + stdenv, + cmake, + fetchurl, + perl, + zlib, + groff, + withBzip2 ? false, + bzip2, + withLZMA ? false, + xz, + withOpenssl ? false, + openssl, + withZstd ? false, + zstd, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -24,11 +26,20 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-wOb6UqYroR79MCYikNxpcJR67zLgzClO5Q6QBc6sCSo="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; - nativeBuildInputs = [ cmake perl groff ]; + nativeBuildInputs = [ + cmake + perl + groff + ]; propagatedBuildInputs = [ zlib ]; - buildInputs = lib.optionals withLZMA [ xz ] + buildInputs = + lib.optionals withLZMA [ xz ] ++ lib.optionals withBzip2 [ bzip2 ] ++ lib.optionals withOpenssl [ openssl ] ++ lib.optionals withZstd [ zstd ]; diff --git a/pkgs/by-name/li/libzmf/package.nix b/pkgs/by-name/li/libzmf/package.nix index 0e139ad529261e..0d7071ec805907 100644 --- a/pkgs/by-name/li/libzmf/package.nix +++ b/pkgs/by-name/li/libzmf/package.nix @@ -1,4 +1,16 @@ -{lib, stdenv, fetchurl, boost, icu, libpng, librevenge, zlib, doxygen, pkg-config, cppunit}: +{ + lib, + stdenv, + fetchurl, + boost, + icu, + libpng, + librevenge, + zlib, + doxygen, + pkg-config, + cppunit, +}: stdenv.mkDerivation rec { pname = "libzmf"; @@ -9,14 +21,24 @@ stdenv.mkDerivation rec { sha256 = "08mg5kmkjrmqrd8j5rkzw9vdqlvibhb1ynp6bmfxnzq5rcq1l197"; }; - buildInputs = [ boost icu libpng librevenge zlib cppunit ]; - nativeBuildInputs = [ doxygen pkg-config ]; + buildInputs = [ + boost + icu + libpng + librevenge + zlib + cppunit + ]; + nativeBuildInputs = [ + doxygen + pkg-config + ]; configureFlags = [ "--disable-werror" ]; meta = { description = "Library that parses the file format of Zoner Callisto/Draw documents"; license = lib.licenses.mpl20; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.unix; homepage = "https://wiki.documentfoundation.org/DLP/Libraries/libzmf"; downloadPage = "http://dev-www.libreoffice.org/src/libzmf/"; diff --git a/pkgs/by-name/li/libzra/package.nix b/pkgs/by-name/li/libzra/package.nix index 163389fb11ac4c..eff23c6b539f32 100644 --- a/pkgs/by-name/li/libzra/package.nix +++ b/pkgs/by-name/li/libzra/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/license-cli/package.nix b/pkgs/by-name/li/license-cli/package.nix index bf3de443e30207..c91618db40cc39 100644 --- a/pkgs/by-name/li/license-cli/package.nix +++ b/pkgs/by-name/li/license-cli/package.nix @@ -1,14 +1,15 @@ -{ lib -, fetchFromSourcehut -, rustPlatform -, installShellFiles -, scdoc -, makeWrapper - -# Script dependencies. -, fzf -, wl-clipboard -, xclip +{ + lib, + fetchFromSourcehut, + rustPlatform, + installShellFiles, + scdoc, + makeWrapper, + + # Script dependencies. + fzf, + wl-clipboard, + xclip, }: rustPlatform.buildRustPackage rec { @@ -24,7 +25,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Zj9t/e6QhiOxU8mlVRBKEbviSTKXM4WQ3lqtoCcMbMI="; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; preInstall = '' ${scdoc}/bin/scdoc < doc/license.scd > license.1 @@ -43,7 +47,12 @@ rustPlatform.buildRustPackage rec { install -Dm0755 ./scripts/copy-header -t $out/bin wrapProgram $out/bin/copy-header \ --prefix PATH : "$out/bin" \ - --prefix PATH : ${lib.makeBinPath [ wl-clipboard xclip ]} + --prefix PATH : ${ + lib.makeBinPath [ + wl-clipboard + xclip + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/li/license-generator/package.nix b/pkgs/by-name/li/license-generator/package.nix index 47dcfc9488e672..f2f4af2b5f27c0 100644 --- a/pkgs/by-name/li/license-generator/package.nix +++ b/pkgs/by-name/li/license-generator/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchCrate, rustPlatform }: +{ + lib, + fetchCrate, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "license-generator"; diff --git a/pkgs/by-name/li/license-scanner/package.nix b/pkgs/by-name/li/license-scanner/package.nix index 6fcb17e4f4b24a..9700627303a98b 100644 --- a/pkgs/by-name/li/license-scanner/package.nix +++ b/pkgs/by-name/li/license-scanner/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/li/licenseclassifier/package.nix b/pkgs/by-name/li/licenseclassifier/package.nix index 369adafa10b4f2..ad12323a4ecc5b 100644 --- a/pkgs/by-name/li/licenseclassifier/package.nix +++ b/pkgs/by-name/li/licenseclassifier/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -19,7 +20,10 @@ buildGoModule rec { vendorHash = "sha256-u0VR8DCmbZS0MF26Y4HfqtLaGyX2n2INdAidVNbnXPE="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "License Classifier"; diff --git a/pkgs/by-name/li/licensor/package.nix b/pkgs/by-name/li/licensor/package.nix index c1716911537a69..0e69041844e111 100644 --- a/pkgs/by-name/li/licensor/package.nix +++ b/pkgs/by-name/li/licensor/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/li/licensure/package.nix b/pkgs/by-name/li/licensure/package.nix index 97db16e1fcba63..47dfc418acacf9 100644 --- a/pkgs/by-name/li/licensure/package.nix +++ b/pkgs/by-name/li/licensure/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, git -, gitls -, darwin +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + git, + gitls, + darwin, }: rustPlatform.buildRustPackage rec { pname = "licensure"; @@ -21,10 +22,15 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Ywfn+6qdKD9CG2/xdHR2XDsj5LF5XPJ2+XR5H1o2iXk="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl git gitls ] + buildInputs = + [ + openssl + git + gitls + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + darwin.apple_sdk.frameworks.SystemConfiguration + ]; checkFlags = [ # Checking for files in the git repo (git ls-files), diff --git a/pkgs/by-name/li/lie/package.nix b/pkgs/by-name/li/lie/package.nix index dbc66fe2a05fe5..e8b15560dd07e4 100644 --- a/pkgs/by-name/li/lie/package.nix +++ b/pkgs/by-name/li/lie/package.nix @@ -1,10 +1,15 @@ -{ lib, stdenv, fetchurl -, bison, readline }: +{ + lib, + stdenv, + fetchurl, + bison, + readline, +}: stdenv.mkDerivation { version = "2.2.2"; - # The current version of LiE is 2.2.2, which is more or less unchanged - # since about the year 2000. Minor bugfixes do get applied now and then. + # The current version of LiE is 2.2.2, which is more or less unchanged + # since about the year 2000. Minor bugfixes do get applied now and then. pname = "lie"; meta = { @@ -29,7 +34,10 @@ stdenv.mkDerivation { sha256 = "07lbj75qqr4pq1j1qz8fyfnmrz1gnk92lnsshxycfavxl5zzdmn4"; }; - buildInputs = [ bison readline ]; + buildInputs = [ + bison + readline + ]; patchPhase = '' substituteInPlace make_lie \ diff --git a/pkgs/by-name/li/lieer/package.nix b/pkgs/by-name/li/lieer/package.nix index 32f8d666392942..b0a564984e4bc5 100644 --- a/pkgs/by-name/li/lieer/package.nix +++ b/pkgs/by-name/li/lieer/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3Packages -, nix-update-script +{ + lib, + fetchFromGitHub, + python3Packages, + nix-update-script, }: python3Packages.buildPythonApplication rec { @@ -44,7 +45,10 @@ python3Packages.buildPythonApplication rec { ''; homepage = "https://lieer.gaute.vetsj.com/"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ archer-65 flokli ]; + maintainers = with maintainers; [ + archer-65 + flokli + ]; mainProgram = "gmi"; }; } diff --git a/pkgs/by-name/li/lifecycled/package.nix b/pkgs/by-name/li/lifecycled/package.nix index f4148b6316c283..8605f701fe1bc9 100644 --- a/pkgs/by-name/li/lifecycled/package.nix +++ b/pkgs/by-name/li/lifecycled/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "lifecycled"; @@ -25,7 +26,9 @@ buildGoModule rec { description = "Daemon for responding to AWS AutoScaling Lifecycle Hooks"; homepage = "https://github.com/buildkite/lifecycled/"; license = licenses.mit; - maintainers = with maintainers; [ cole-h grahamc ]; + maintainers = with maintainers; [ + cole-h + grahamc + ]; }; } - diff --git a/pkgs/by-name/li/lifelines/package.nix b/pkgs/by-name/li/lifelines/package.nix index f7f6c5fa2a38e0..32aecb3ca405e0 100644 --- a/pkgs/by-name/li/lifelines/package.nix +++ b/pkgs/by-name/li/lifelines/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, gettext, libiconv, bison, ncurses, perl, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + gettext, + libiconv, + bison, + ncurses, + perl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "lifelines"; @@ -27,7 +38,10 @@ stdenv.mkDerivation rec { ncurses perl ]; - nativeBuildInputs = [ autoreconfHook bison ]; + nativeBuildInputs = [ + autoreconfHook + bison + ]; meta = with lib; { description = "Genealogy tool with ncurses interface"; diff --git a/pkgs/by-name/li/lifeograph/package.nix b/pkgs/by-name/li/lifeograph/package.nix index 0501d25c51c924..c44d85c9645276 100644 --- a/pkgs/by-name/li/lifeograph/package.nix +++ b/pkgs/by-name/li/lifeograph/package.nix @@ -1,5 +1,17 @@ -{ stdenv, lib, fetchgit, pkg-config, meson, ninja, wrapGAppsHook3 -, enchant, gtkmm3, libchamplain, libgcrypt, shared-mime-info }: +{ + stdenv, + lib, + fetchgit, + pkg-config, + meson, + ninja, + wrapGAppsHook3, + enchant, + gtkmm3, + libchamplain, + libgcrypt, + shared-mime-info, +}: stdenv.mkDerivation rec { pname = "lifeograph"; diff --git a/pkgs/by-name/li/liferea/package.nix b/pkgs/by-name/li/liferea/package.nix index e117549d575631..9490f4b5f50209 100644 --- a/pkgs/by-name/li/liferea/package.nix +++ b/pkgs/by-name/li/liferea/package.nix @@ -1,25 +1,27 @@ -{ lib, stdenv -, fetchurl -, pkg-config -, intltool -, python3Packages -, wrapGAppsHook3 -, glib -, libxml2 -, libxslt -, sqlite -, libsoup_3 -, webkitgtk_4_1 -, json-glib -, gst_all_1 -, libnotify -, gtk3 -, gsettings-desktop-schemas -, libpeas -, libsecret -, gobject-introspection -, glib-networking -, gitUpdater +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + python3Packages, + wrapGAppsHook3, + glib, + libxml2, + libxslt, + sqlite, + libsoup_3, + webkitgtk_4_1, + json-glib, + gst_all_1, + libnotify, + gtk3, + gsettings-desktop-schemas, + libpeas, + libsecret, + gobject-introspection, + glib-networking, + gitUpdater, }: stdenv.mkDerivation rec { @@ -39,26 +41,28 @@ stdenv.mkDerivation rec { gobject-introspection ]; - buildInputs = [ - glib - gtk3 - webkitgtk_4_1 - libxml2 - libxslt - sqlite - libsoup_3 - libpeas - gsettings-desktop-schemas - json-glib - libsecret - glib-networking - libnotify - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-good - gst-plugins-bad - ]); + buildInputs = + [ + glib + gtk3 + webkitgtk_4_1 + libxml2 + libxslt + sqlite + libsoup_3 + libpeas + gsettings-desktop-schemas + json-glib + libsecret + glib-networking + libnotify + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + ]); enableParallelBuilding = true; @@ -76,7 +80,10 @@ stdenv.mkDerivation rec { description = "GTK-based news feed aggregator"; homepage = "http://lzone.de/liferea/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ romildo yayayayaka ]; + maintainers = with maintainers; [ + romildo + yayayayaka + ]; platforms = platforms.linux; longDescription = '' diff --git a/pkgs/by-name/li/lightdm-enso-os-greeter/package.nix b/pkgs/by-name/li/lightdm-enso-os-greeter/package.nix index b8082c4510d6ee..056ab12c8515e2 100644 --- a/pkgs/by-name/li/lightdm-enso-os-greeter/package.nix +++ b/pkgs/by-name/li/lightdm-enso-os-greeter/package.nix @@ -1,6 +1,27 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, linkFarm, lightdm-enso-os-greeter -, dbus, pcre, libepoxy, xorg, at-spi2-core, libxklavier, libxkbcommon -, gtk3, vala, cmake, libgee, lightdm, gdk-pixbuf, clutter-gtk, wrapGAppsHook3, librsvg }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + linkFarm, + lightdm-enso-os-greeter, + dbus, + pcre, + libepoxy, + xorg, + at-spi2-core, + libxklavier, + libxkbcommon, + gtk3, + vala, + cmake, + libgee, + lightdm, + gdk-pixbuf, + clutter-gtk, + wrapGAppsHook3, + librsvg, +}: stdenv.mkDerivation { pname = "lightdm-enso-os-greeter"; @@ -46,10 +67,12 @@ stdenv.mkDerivation { cd greeter ''; - passthru.xgreeters = linkFarm "enso-os-greeter-xgreeters" [{ - path = "${lightdm-enso-os-greeter}/share/xgreeters/pantheon-greeter.desktop"; - name = "pantheon-greeter.desktop"; - }]; + passthru.xgreeters = linkFarm "enso-os-greeter-xgreeters" [ + { + path = "${lightdm-enso-os-greeter}/share/xgreeters/pantheon-greeter.desktop"; + name = "pantheon-greeter.desktop"; + } + ]; postFixup = '' substituteInPlace $out/share/xgreeters/pantheon-greeter.desktop \ diff --git a/pkgs/by-name/li/lightdm-mini-greeter/package.nix b/pkgs/by-name/li/lightdm-mini-greeter/package.nix index b72b837eaf3442..632e471c92035f 100644 --- a/pkgs/by-name/li/lightdm-mini-greeter/package.nix +++ b/pkgs/by-name/li/lightdm-mini-greeter/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, linkFarm, lightdm-mini-greeter, fetchFromGitHub, autoreconfHook, pkg-config, lightdm, gtk3, glib, gdk-pixbuf, wrapGAppsHook3, librsvg }: +{ + lib, + stdenv, + linkFarm, + lightdm-mini-greeter, + fetchFromGitHub, + autoreconfHook, + pkg-config, + lightdm, + gtk3, + glib, + gdk-pixbuf, + wrapGAppsHook3, + librsvg, +}: stdenv.mkDerivation rec { pname = "lightdm-mini-greeter"; @@ -11,8 +25,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-Pm7ExfusFIPktX2C4UE07qgOVhcWhVxnaD3QARpmu7Y="; }; - nativeBuildInputs = [ autoreconfHook pkg-config wrapGAppsHook3 ]; - buildInputs = [ lightdm gtk3 glib gdk-pixbuf librsvg ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + wrapGAppsHook3 + ]; + buildInputs = [ + lightdm + gtk3 + glib + gdk-pixbuf + librsvg + ]; configureFlags = [ "--sysconfdir=/etc" ]; makeFlags = [ "configdir=${placeholder "out"}/etc" ]; @@ -22,17 +46,22 @@ stdenv.mkDerivation rec { --replace "Exec=lightdm-mini-greeter" "Exec=$out/bin/lightdm-mini-greeter" ''; - passthru.xgreeters = linkFarm "lightdm-mini-greeter-xgreeters" [{ - path = "${lightdm-mini-greeter}/share/xgreeters/lightdm-mini-greeter.desktop"; - name = "lightdm-mini-greeter.desktop"; - }]; + passthru.xgreeters = linkFarm "lightdm-mini-greeter-xgreeters" [ + { + path = "${lightdm-mini-greeter}/share/xgreeters/lightdm-mini-greeter.desktop"; + name = "lightdm-mini-greeter.desktop"; + } + ]; meta = with lib; { description = "Minimal, configurable, single-user GTK3 LightDM greeter"; mainProgram = "lightdm-mini-greeter"; homepage = "https://github.com/prikhi/lightdm-mini-greeter"; license = licenses.gpl3; - maintainers = with maintainers; [ mnacamura prikhi ]; + maintainers = with maintainers; [ + mnacamura + prikhi + ]; platforms = platforms.linux; changelog = "https://github.com/prikhi/lightdm-mini-greeter/blob/master/CHANGELOG.md"; }; diff --git a/pkgs/by-name/li/lightdm-mobile-greeter/package.nix b/pkgs/by-name/li/lightdm-mobile-greeter/package.nix index a18397262fde0a..fbac4f88c26949 100644 --- a/pkgs/by-name/li/lightdm-mobile-greeter/package.nix +++ b/pkgs/by-name/li/lightdm-mobile-greeter/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitea -, gtk3 -, libhandy_0 -, lightdm -, lightdm-mobile-greeter -, linkFarm -, pkg-config -, rustPlatform +{ + lib, + fetchFromGitea, + gtk3, + libhandy_0, + lightdm, + lightdm-mobile-greeter, + linkFarm, + pkg-config, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -43,10 +44,12 @@ rustPlatform.buildRustPackage rec { --replace lightdm-mobile-greeter $out/bin/lightdm-mobile-greeter ''; - passthru.xgreeters = linkFarm "lightdm-mobile-greeter-xgreeters" [{ - path = "${lightdm-mobile-greeter}/share/xgreeters/lightdm-mobile-greeter.desktop"; - name = "lightdm-mobile-greeter.desktop"; - }]; + passthru.xgreeters = linkFarm "lightdm-mobile-greeter-xgreeters" [ + { + path = "${lightdm-mobile-greeter}/share/xgreeters/lightdm-mobile-greeter.desktop"; + name = "lightdm-mobile-greeter.desktop"; + } + ]; meta = with lib; { description = "Simple log in screen for use on touch screens"; diff --git a/pkgs/by-name/li/lightdm-slick-greeter/package.nix b/pkgs/by-name/li/lightdm-slick-greeter/package.nix index 0b5b307625d5ad..b273fb0f0c27a4 100644 --- a/pkgs/by-name/li/lightdm-slick-greeter/package.nix +++ b/pkgs/by-name/li/lightdm-slick-greeter/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, python3 -, vala -, wrapGAppsHook3 -, xapp -, lightdm -, gtk3 -, pixman -, libcanberra -, libgnomekbd -, libX11 -, libXext -, linkFarm -, lightdm-slick-greeter -, numlockx +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + python3, + vala, + wrapGAppsHook3, + xapp, + lightdm, + gtk3, + pixman, + libcanberra, + libgnomekbd, + libX11, + libXext, + linkFarm, + lightdm-slick-greeter, + numlockx, }: stdenv.mkDerivation rec { @@ -89,16 +90,21 @@ stdenv.mkDerivation rec { ) ''; - passthru.xgreeters = linkFarm "lightdm-slick-greeter-xgreeters" [{ - path = "${lightdm-slick-greeter}/share/xgreeters/slick-greeter.desktop"; - name = "lightdm-slick-greeter.desktop"; - }]; + passthru.xgreeters = linkFarm "lightdm-slick-greeter-xgreeters" [ + { + path = "${lightdm-slick-greeter}/share/xgreeters/slick-greeter.desktop"; + name = "lightdm-slick-greeter.desktop"; + } + ]; meta = with lib; { description = "Slick-looking LightDM greeter"; homepage = "https://github.com/linuxmint/slick-greeter"; license = licenses.gpl3Only; - maintainers = with maintainers; [ water-sucks bobby285271 ]; + maintainers = with maintainers; [ + water-sucks + bobby285271 + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/li/lightdm-tiny-greeter/package.nix b/pkgs/by-name/li/lightdm-tiny-greeter/package.nix index 42e5e004a62a7b..46a5ff29365ce4 100644 --- a/pkgs/by-name/li/lightdm-tiny-greeter/package.nix +++ b/pkgs/by-name/li/lightdm-tiny-greeter/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, linkFarm, lightdm-tiny-greeter, fetchFromGitHub -, pkg-config, lightdm, gtk3, glib, wrapGAppsHook3, config, conf ? config.lightdm-tiny-greeter.conf or "" }: +{ + lib, + stdenv, + linkFarm, + lightdm-tiny-greeter, + fetchFromGitHub, + pkg-config, + lightdm, + gtk3, + glib, + wrapGAppsHook3, + config, + conf ? config.lightdm-tiny-greeter.conf or "", +}: stdenv.mkDerivation rec { pname = "lightdm-tiny-greeter"; @@ -12,8 +24,15 @@ stdenv.mkDerivation rec { sha256 = "08azpj7b5qgac9bgi1xvd6qy6x2nb7iapa0v40ggr3d1fabyhrg6"; }; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; - buildInputs = [ lightdm gtk3 glib ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; + buildInputs = [ + lightdm + gtk3 + glib + ]; postUnpack = lib.optionalString (conf != "") '' cp ${builtins.toFile "config.h" conf} source/config.h @@ -31,10 +50,12 @@ stdenv.mkDerivation rec { --replace "Exec=lightdm-tiny-greeter" "Exec=$out/bin/lightdm-tiny-greeter" ''; - passthru.xgreeters = linkFarm "lightdm-tiny-greeter-xgreeters" [{ - path = "${lightdm-tiny-greeter}/share/xgreeters/lightdm-tiny-greeter.desktop"; - name = "lightdm-tiny-greeter.desktop"; - }]; + passthru.xgreeters = linkFarm "lightdm-tiny-greeter-xgreeters" [ + { + path = "${lightdm-tiny-greeter}/share/xgreeters/lightdm-tiny-greeter.desktop"; + name = "lightdm-tiny-greeter.desktop"; + } + ]; meta = with lib; { description = "Tiny multi user lightdm greeter"; diff --git a/pkgs/by-name/li/lightgbm/package.nix b/pkgs/by-name/li/lightgbm/package.nix index 934b0cab5a3e6f..c5d0238724d522 100644 --- a/pkgs/by-name/li/lightgbm/package.nix +++ b/pkgs/by-name/li/lightgbm/package.nix @@ -1,8 +1,31 @@ -{ config, stdenv, lib, fetchFromGitHub, cmake, gtest, doCheck ? true -, cudaSupport ? config.cudaSupport or false, openclSupport ? false -, mpiSupport ? false, javaWrapper ? false, hdfsSupport ? false, pythonLibrary ? false -, rLibrary ? false, cudaPackages, opencl-headers, ocl-icd, boost -, llvmPackages, openmpi, openjdk, swig, hadoop, R, rPackages, pandoc }: +{ + config, + stdenv, + lib, + fetchFromGitHub, + cmake, + gtest, + doCheck ? true, + cudaSupport ? config.cudaSupport or false, + openclSupport ? false, + mpiSupport ? false, + javaWrapper ? false, + hdfsSupport ? false, + pythonLibrary ? false, + rLibrary ? false, + cudaPackages, + opencl-headers, + ocl-icd, + boost, + llvmPackages, + openmpi, + openjdk, + swig, + hadoop, + R, + rPackages, + pandoc, +}: assert doCheck -> !mpiSupport; assert openclSupport -> !cudaSupport; @@ -33,17 +56,24 @@ stdenv.mkDerivation rec { hash = "sha256-nST6+/c3Y4/hqwgEUhx03gWtjxhlmUu1XKDCy2pSsvU="; }; - nativeBuildInputs = [ cmake ] + nativeBuildInputs = + [ cmake ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ llvmPackages.openmp ] - ++ lib.optionals openclSupport [ opencl-headers ocl-icd boost ] + ++ lib.optionals openclSupport [ + opencl-headers + ocl-icd + boost + ] ++ lib.optionals mpiSupport [ openmpi ] ++ lib.optionals hdfsSupport [ hadoop ] ++ lib.optionals (hdfsSupport || javaWrapper) [ openjdk ] ++ lib.optionals javaWrapper [ swig ] - ++ lib.optionals rLibrary [ R pandoc ]; + ++ lib.optionals rLibrary [ + R + pandoc + ]; - buildInputs = [ gtest ] - ++ lib.optional cudaSupport cudaPackages.cudatoolkit; + buildInputs = [ gtest ] ++ lib.optional cudaSupport cudaPackages.cudatoolkit; propagatedBuildInputs = lib.optionals rLibrary [ rPackages.data_table @@ -76,18 +106,24 @@ stdenv.mkDerivation rec { rm tests/cpp_tests/test_arrow.cpp ''; - cmakeFlags = lib.optionals doCheck [ "-DBUILD_CPP_TEST=ON" ] - ++ lib.optionals cudaSupport [ "-DUSE_CUDA=1" "-DCMAKE_CXX_COMPILER=${cudaPackages.backendStdenv.cc}/bin/cc" ] + cmakeFlags = + lib.optionals doCheck [ "-DBUILD_CPP_TEST=ON" ] + ++ lib.optionals cudaSupport [ + "-DUSE_CUDA=1" + "-DCMAKE_CXX_COMPILER=${cudaPackages.backendStdenv.cc}/bin/cc" + ] ++ lib.optionals openclSupport [ "-DUSE_GPU=ON" ] ++ lib.optionals mpiSupport [ "-DUSE_MPI=ON" ] ++ lib.optionals hdfsSupport [ "-DUSE_HDFS=ON" "-DHDFS_LIB=${hadoop}/lib/hadoop-${hadoop.version}/lib/native/libhdfs.so" - "-DHDFS_INCLUDE_DIR=${hadoop}/lib/hadoop-${hadoop.version}/include" ] + "-DHDFS_INCLUDE_DIR=${hadoop}/lib/hadoop-${hadoop.version}/include" + ] ++ lib.optionals javaWrapper [ "-DUSE_SWIG=ON" # RPATH of binary /nix/store/.../bin/... contains a forbidden reference to /build/ - "-DCMAKE_SKIP_BUILD_RPATH=ON" ] + "-DCMAKE_SKIP_BUILD_RPATH=ON" + ] ++ lib.optionals rLibrary [ "-D__BUILD_FOR_R=ON" ] ++ lib.optionals pythonLibrary [ "-D__BUILD_FOR_PYTHON=ON" ]; @@ -97,43 +133,50 @@ stdenv.mkDerivation rec { # set the R package buildPhase to null because lightgbm has a # custom builder script that builds and installs in one step - buildPhase = lib.optionals rLibrary '' - ''; + buildPhase = lib.optionals rLibrary ''''; inherit doCheck; - installPhase = '' + installPhase = + '' runHook preInstall - '' + lib.optionalString (!rLibrary) '' + '' + + lib.optionalString (!rLibrary) '' mkdir -p $out mkdir -p $out/lib mkdir -p $out/bin cp -r ../include $out install -Dm755 ../lib_lightgbm${stdenv.hostPlatform.extensions.sharedLibrary} $out/lib/lib_lightgbm${stdenv.hostPlatform.extensions.sharedLibrary} - '' + lib.optionalString (!rLibrary && !pythonLibrary) '' + '' + + lib.optionalString (!rLibrary && !pythonLibrary) '' install -Dm755 ../lightgbm $out/bin/lightgbm - '' + lib.optionalString javaWrapper '' + '' + + lib.optionalString javaWrapper '' cp -r java $out cp -r com $out cp -r lightgbmlib.jar $out - '' + '' - '' + lib.optionalString rLibrary '' + '' + + '''' + + lib.optionalString rLibrary '' mkdir $out mkdir $out/tmp mkdir $out/library mkdir $out/library/lightgbm - '' + lib.optionalString (rLibrary && (!openclSupport)) '' + '' + + lib.optionalString (rLibrary && (!openclSupport)) '' Rscript build_r.R \ -j$NIX_BUILD_CORES rm -rf $out/tmp - '' + lib.optionalString (rLibrary && openclSupport) '' + '' + + lib.optionalString (rLibrary && openclSupport) '' Rscript build_r.R --use-gpu \ --opencl-library=${ocl-icd}/lib/libOpenCL.so \ --opencl-include-dir=${opencl-headers}/include \ --boost-librarydir=${boost} \ -j$NIX_BUILD_CORES rm -rf $out/tmp - '' + '' + '' + + '' runHook postInstall ''; @@ -144,8 +187,7 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = - "LightGBM is a gradient boosting framework that uses tree based learning algorithms."; + description = "LightGBM is a gradient boosting framework that uses tree based learning algorithms."; mainProgram = "lightgbm"; homepage = "https://github.com/microsoft/LightGBM"; license = licenses.mit; diff --git a/pkgs/by-name/li/lightlocker/package.nix b/pkgs/by-name/li/lightlocker/package.nix index ef141c784d8d3f..f805157c66f9b8 100644 --- a/pkgs/by-name/li/lightlocker/package.nix +++ b/pkgs/by-name/li/lightlocker/package.nix @@ -1,27 +1,32 @@ -{ lib, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, gtk3 -, glib -, intltool -, dbus-glib -, libX11 -, libXScrnSaver -, libXxf86vm -, libXext -, systemd -, pantheon -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + gtk3, + glib, + intltool, + dbus-glib, + libX11, + libXScrnSaver, + libXxf86vm, + libXext, + systemd, + pantheon, + wrapGAppsHook3, }: stdenv.mkDerivation rec { pname = "light-locker"; version = "1.9.0"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchFromGitHub { owner = "the-cavalry"; diff --git a/pkgs/by-name/li/lightning-loop/package.nix b/pkgs/by-name/li/lightning-loop/package.nix index e257c581fd5164..c68648a0ee3d51 100644 --- a/pkgs/by-name/li/lightning-loop/package.nix +++ b/pkgs/by-name/li/lightning-loop/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { @@ -16,14 +17,23 @@ buildGoModule rec { vendorHash = "sha256-v7zSvCp63z+xZIuXbqHueamEBN/jZBr2Kysvq03e8L0="; - subPackages = [ "cmd/loop" "cmd/loopd" ]; + subPackages = [ + "cmd/loop" + "cmd/loopd" + ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Lightning Loop Client"; homepage = "https://github.com/lightninglabs/loop"; license = licenses.mit; - maintainers = with maintainers; [ proofofkeags prusnak ]; + maintainers = with maintainers; [ + proofofkeags + prusnak + ]; }; } diff --git a/pkgs/by-name/li/lightning-pool/package.nix b/pkgs/by-name/li/lightning-pool/package.nix index 0846db643db803..af93ba7c1e83cd 100644 --- a/pkgs/by-name/li/lightning-pool/package.nix +++ b/pkgs/by-name/li/lightning-pool/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { @@ -16,14 +17,23 @@ buildGoModule rec { vendorHash = "sha256-DD27zUW524qe9yLaVPEzw/c4sSzlH89HMw0PdtNYEhg="; - subPackages = [ "cmd/pool" "cmd/poold" ]; + subPackages = [ + "cmd/pool" + "cmd/poold" + ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Lightning Pool Client"; homepage = "https://github.com/lightninglabs/pool"; license = licenses.mit; - maintainers = with maintainers; [ proofofkeags prusnak ]; + maintainers = with maintainers; [ + proofofkeags + prusnak + ]; }; } diff --git a/pkgs/by-name/li/lightning/package.nix b/pkgs/by-name/li/lightning/package.nix index ea99a5873dc824..1256ee1cf3b75b 100644 --- a/pkgs/by-name/li/lightning/package.nix +++ b/pkgs/by-name/li/lightning/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchurl -, libopcodes -, libiberty -, stdenv -, libbfd -, zlib +{ + lib, + fetchurl, + libopcodes, + libiberty, + stdenv, + libbfd, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -16,7 +17,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-wEXHozoAr/v+sRBm+lAsA5kuR0piupWXeq0G28FMaCk="; }; - outputs = [ "out" "dev" "info" ]; + outputs = [ + "out" + "dev" + "info" + ]; buildInputs = [ libopcodes diff --git a/pkgs/by-name/li/lightningcss/package.nix b/pkgs/by-name/li/lightningcss/package.nix index b1b6cf3afa1679..544cb9e7fa31a7 100644 --- a/pkgs/by-name/li/lightningcss/package.nix +++ b/pkgs/by-name/li/lightningcss/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, nix-update-script +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + nix-update-script, }: rustPlatform.buildRustPackage rec { @@ -38,14 +39,17 @@ rustPlatform.buildRustPackage rec { "--lib" ]; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = { description = "Extremely fast CSS parser, transformer, and minifier written in Rust"; homepage = "https://lightningcss.dev/"; changelog = "https://github.com/parcel-bundler/lightningcss/releases/tag/v${version}"; license = lib.licenses.mpl20; - maintainers = with lib.maintainers; [ johnrtitor toastal ]; + maintainers = with lib.maintainers; [ + johnrtitor + toastal + ]; mainProgram = "lightningcss"; platforms = lib.platforms.all; }; diff --git a/pkgs/by-name/li/lightspark/package.nix b/pkgs/by-name/li/lightspark/package.nix index 904028feddaaa2..4f73bf561ef21c 100644 --- a/pkgs/by-name/li/lightspark/package.nix +++ b/pkgs/by-name/li/lightspark/package.nix @@ -1,5 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, cmake, curl, zlib, ffmpeg, glew, pcre -, rtmpdump, cairo, boost, SDL2, libjpeg, pango, xz, nasm, llvm, glibmm +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + curl, + zlib, + ffmpeg, + glew, + pcre, + rtmpdump, + cairo, + boost, + SDL2, + libjpeg, + pango, + xz, + nasm, + llvm, + glibmm, }: stdenv.mkDerivation rec { @@ -17,11 +36,27 @@ stdenv.mkDerivation rec { sed -i 's/SET(ETCDIR "\/etc")/SET(ETCDIR "etc")/g' CMakeLists.txt ''; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; buildInputs = [ - curl zlib ffmpeg glew pcre rtmpdump cairo boost SDL2 libjpeg pango xz nasm - llvm glibmm + curl + zlib + ffmpeg + glew + pcre + rtmpdump + cairo + boost + SDL2 + libjpeg + pango + xz + nasm + llvm + glibmm ]; meta = with lib; { diff --git a/pkgs/by-name/li/lighttpd/package.nix b/pkgs/by-name/li/lighttpd/package.nix index b169e5a83dab22..3d7bea50a1aff5 100644 --- a/pkgs/by-name/li/lighttpd/package.nix +++ b/pkgs/by-name/li/lighttpd/package.nix @@ -1,16 +1,35 @@ -{ lib, stdenv, buildPackages, fetchurl, pkg-config, pcre2, libxml2, zlib, bzip2, which, file -, autoreconfHook -, openssl -, enableDbi ? false, libdbi -, enableMagnet ? false, lua5_1 -, enableMysql ? false, libmysqlclient -, enableLdap ? false, openldap -, enablePam ? false, linux-pam -, enableSasl ? false, cyrus_sasl -, enableWebDAV ? false, sqlite, libuuid -, enableExtendedAttrs ? false -, perl -, nixosTests +{ + lib, + stdenv, + buildPackages, + fetchurl, + pkg-config, + pcre2, + libxml2, + zlib, + bzip2, + which, + file, + autoreconfHook, + openssl, + enableDbi ? false, + libdbi, + enableMagnet ? false, + lua5_1, + enableMysql ? false, + libmysqlclient, + enableLdap ? false, + openldap, + enablePam ? false, + linux-pam, + enableSasl ? false, + cyrus_sasl, + enableWebDAV ? false, + sqlite, + libuuid, + enableExtendedAttrs ? false, + perl, + nixosTests, }: stdenv.mkDerivation rec { @@ -30,27 +49,41 @@ stdenv.mkDerivation rec { depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ pcre2 pcre2.dev libxml2 zlib bzip2 which file openssl ] - ++ lib.optional enableDbi libdbi - ++ lib.optional enableMagnet lua5_1 - ++ lib.optional enableMysql libmysqlclient - ++ lib.optional enableLdap openldap - ++ lib.optional enablePam linux-pam - ++ lib.optional enableSasl cyrus_sasl - ++ lib.optional enableWebDAV sqlite - ++ lib.optional enableWebDAV libuuid; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = + [ + pcre2 + pcre2.dev + libxml2 + zlib + bzip2 + which + file + openssl + ] + ++ lib.optional enableDbi libdbi + ++ lib.optional enableMagnet lua5_1 + ++ lib.optional enableMysql libmysqlclient + ++ lib.optional enableLdap openldap + ++ lib.optional enablePam linux-pam + ++ lib.optional enableSasl cyrus_sasl + ++ lib.optional enableWebDAV sqlite + ++ lib.optional enableWebDAV libuuid; - configureFlags = [ "--with-openssl" ] - ++ lib.optional enableDbi "--with-dbi" - ++ lib.optional enableMagnet "--with-lua" - ++ lib.optional enableMysql "--with-mysql" - ++ lib.optional enableLdap "--with-ldap" - ++ lib.optional enablePam "--with-pam" - ++ lib.optional enableSasl "--with-sasl" - ++ lib.optional enableWebDAV "--with-webdav-props" - ++ lib.optional enableWebDAV "--with-webdav-locks" - ++ lib.optional enableExtendedAttrs "--with-attr"; + configureFlags = + [ "--with-openssl" ] + ++ lib.optional enableDbi "--with-dbi" + ++ lib.optional enableMagnet "--with-lua" + ++ lib.optional enableMysql "--with-mysql" + ++ lib.optional enableLdap "--with-ldap" + ++ lib.optional enablePam "--with-pam" + ++ lib.optional enableSasl "--with-sasl" + ++ lib.optional enableWebDAV "--with-webdav-props" + ++ lib.optional enableWebDAV "--with-webdav-locks" + ++ lib.optional enableExtendedAttrs "--with-attr"; preConfigure = '' export PATH=$PATH:${pcre2.dev}/bin @@ -78,7 +111,10 @@ stdenv.mkDerivation rec { homepage = "http://www.lighttpd.net/"; license = lib.licenses.bsd3; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ bjornfor brecht ]; + maintainers = with maintainers; [ + bjornfor + brecht + ]; mainProgram = "lighttpd"; }; } diff --git a/pkgs/by-name/li/lightum/package.nix b/pkgs/by-name/li/lightum/package.nix index f1f95d5563b011..59fe1ec552a128 100644 --- a/pkgs/by-name/li/lightum/package.nix +++ b/pkgs/by-name/li/lightum/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, libX11, libXScrnSaver, libXext, glib, dbus, pkg-config, systemd }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + libXScrnSaver, + libXext, + glib, + dbus, + pkg-config, + systemd, +}: stdenv.mkDerivation { pname = "lightum"; diff --git a/pkgs/by-name/li/lightwalletd/package.nix b/pkgs/by-name/li/lightwalletd/package.nix index f66cd78adba16b..2f3779f337b9d9 100644 --- a/pkgs/by-name/li/lightwalletd/package.nix +++ b/pkgs/by-name/li/lightwalletd/package.nix @@ -1,4 +1,10 @@ -{ buildGoModule, fetchFromGitHub, lib, lightwalletd, testers }: +{ + buildGoModule, + fetchFromGitHub, + lib, + lightwalletd, + testers, +}: buildGoModule rec { pname = "lightwalletd"; @@ -6,7 +12,7 @@ buildGoModule rec { src = fetchFromGitHub { owner = "zcash"; - repo = "lightwalletd"; + repo = "lightwalletd"; rev = "v${version}"; hash = "sha256-M9xfV2T8L+nssrJj29QmPiErNMpfpT8BY/30Vj8wPjY="; }; @@ -14,7 +20,8 @@ buildGoModule rec { vendorHash = "sha256-z5Hs+CkPswWhz+Ya5MyHKA3MZzQkvS7WOxNckElkg6U="; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/zcash/lightwalletd/common.Version=v${version}" "-X github.com/zcash/lightwalletd/common.GitCommit=${src.rev}" "-X github.com/zcash/lightwalletd/common.BuildDate=1970-01-01" diff --git a/pkgs/by-name/li/lil-pwny/package.nix b/pkgs/by-name/li/lil-pwny/package.nix index 42ee72d2c204da..81b28b6c5533d9 100644 --- a/pkgs/by-name/li/lil-pwny/package.nix +++ b/pkgs/by-name/li/lil-pwny/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/li/lilo/package.nix b/pkgs/by-name/li/lilo/package.nix index 0eb8d563373aec..7a104119faa39a 100644 --- a/pkgs/by-name/li/lilo/package.nix +++ b/pkgs/by-name/li/lilo/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, dev86, sharutils }: +{ + stdenv, + lib, + fetchurl, + dev86, + sharutils, +}: stdenv.mkDerivation rec { pname = "lilo"; @@ -7,7 +13,10 @@ stdenv.mkDerivation rec { url = "https://www.joonet.de/lilo/ftp/sources/lilo-${version}.tar.gz"; hash = "sha256-4VjxneRWDJNevgUHwht5v/F2GLkjDYB2/oxf/5/b1bE="; }; - nativeBuildInputs = [ dev86 sharutils ]; + nativeBuildInputs = [ + dev86 + sharutils + ]; # Workaround build failure on -fno-common toolchains: # ld: identify.o:(.bss+0x0): multiple definition of `identify'; diff --git a/pkgs/by-name/li/lilv/package.nix b/pkgs/by-name/li/lilv/package.nix index 63c222d368c48a..32b0bb70bf366f 100644 --- a/pkgs/by-name/li/lilv/package.nix +++ b/pkgs/by-name/li/lilv/package.nix @@ -1,50 +1,69 @@ -{ lib -, stdenv -, fetchurl -, lv2 -, meson -, ninja -, pkg-config -, python3 -, libsndfile -, serd -, sord -, sratom -, gitUpdater +{ + lib, + stdenv, + fetchurl, + lv2, + meson, + ninja, + pkg-config, + python3, + libsndfile, + serd, + sord, + sratom, + gitUpdater, -# test derivations -, pipewire + # test derivations + pipewire, }: stdenv.mkDerivation rec { pname = "lilv"; version = "0.24.24"; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; src = fetchurl { url = "https://download.drobilla.net/${pname}-${version}.tar.xz"; hash = "sha256-a7a+n4hQQXbQZC8S3oCbK54txVYhporbjH7bma76u08="; }; - nativeBuildInputs = [ meson ninja pkg-config python3 ]; - buildInputs = [ libsndfile serd sord sratom ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + python3 + ]; + buildInputs = [ + libsndfile + serd + sord + sratom + ]; propagatedBuildInputs = [ lv2 ]; - mesonFlags = [ - (lib.mesonOption "docs" "disabled") - # Tests require building a shared library. - (lib.mesonEnable "tests" (!stdenv.hostPlatform.isStatic)) - ] # Add nix and NixOS specific lv2 paths + mesonFlags = + [ + (lib.mesonOption "docs" "disabled") + # Tests require building a shared library. + (lib.mesonEnable "tests" (!stdenv.hostPlatform.isStatic)) + ] + # Add nix and NixOS specific lv2 paths # The default values are from: https://github.com/lv2/lilv/blob/master/src/lilv_config.h - ++ lib.optional stdenv.hostPlatform.isDarwin (lib.mesonOption "default_lv2_path" - "~/.lv2:~/Library/Audio/Plug-Ins/LV2:" + ++ lib.optional stdenv.hostPlatform.isDarwin ( + lib.mesonOption "default_lv2_path" "~/.lv2:~/Library/Audio/Plug-Ins/LV2:" + "/usr/local/lib/lv2:/usr/lib/lv2:" + "/Library/Audio/Plug-Ins/LV2:" - + "~/.nix-profile/lib/lv2") - ++ lib.optional stdenv.hostPlatform.isLinux (lib.mesonOption "default_lv2_path" - "~/.lv2:/usr/local/lib/lv2:/usr/lib/lv2:" - + "~/.nix-profile/lib/lv2:/run/current-system/sw/lib/lv2"); + + "~/.nix-profile/lib/lv2" + ) + ++ lib.optional stdenv.hostPlatform.isLinux ( + lib.mesonOption "default_lv2_path" "~/.lv2:/usr/local/lib/lv2:/usr/lib/lv2:" + + "~/.nix-profile/lib/lv2:/run/current-system/sw/lib/lv2" + ); passthru = { tests = { diff --git a/pkgs/by-name/li/lime/package.nix b/pkgs/by-name/li/lime/package.nix index d40ac0a05c540d..69d1b391987ba5 100644 --- a/pkgs/by-name/li/lime/package.nix +++ b/pkgs/by-name/li/lime/package.nix @@ -1,11 +1,12 @@ -{ bctoolbox -, belle-sip -, cmake -, fetchFromGitLab -, lib -, bc-soci -, sqlite -, stdenv +{ + bctoolbox, + belle-sip, + cmake, + fetchFromGitLab, + lib, + bc-soci, + sqlite, + stdenv, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/limesurvey/package.nix b/pkgs/by-name/li/limesurvey/package.nix index ecffaa1fe27d6e..d9b1d6b029c9fa 100644 --- a/pkgs/by-name/li/limesurvey/package.nix +++ b/pkgs/by-name/li/limesurvey/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, writeText, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + writeText, + nixosTests, +}: stdenv.mkDerivation rec { pname = "limesurvey"; @@ -12,9 +18,9 @@ stdenv.mkDerivation rec { }; phpConfig = writeText "config.php" '' - + ''; installPhase = '' @@ -35,7 +41,7 @@ stdenv.mkDerivation rec { description = "Open source survey application"; license = licenses.gpl2Plus; homepage = "https://www.limesurvey.org"; - maintainers = with maintainers; [offline]; + maintainers = with maintainers; [ offline ]; platforms = with platforms; unix; }; } diff --git a/pkgs/by-name/li/limitcpu/package.nix b/pkgs/by-name/li/limitcpu/package.nix index 4d8b14229ac231..c3488092f72fc4 100644 --- a/pkgs/by-name/li/limitcpu/package.nix +++ b/pkgs/by-name/li/limitcpu/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "limitcpu"; @@ -9,11 +13,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-lGmU7GDznwMJW4m9dOZguJwUyCq6dUVmk5jjArx7I0w="; }; - buildFlags = with stdenv; [ ( - if isDarwin then "osx" - else if isFreeBSD then "freebsd" - else "cpulimit" - ) ]; + buildFlags = with stdenv; [ + ( + if isDarwin then + "osx" + else if isFreeBSD then + "freebsd" + else + "cpulimit" + ) + ]; installFlags = [ "PREFIX=$(out)" ]; @@ -22,7 +31,7 @@ stdenv.mkDerivation rec { description = "Tool to throttle the CPU usage of programs"; platforms = with platforms; linux ++ freebsd; license = licenses.gpl2Only; - maintainers = [maintainers.rycee]; + maintainers = [ maintainers.rycee ]; mainProgram = "cpulimit"; }; } diff --git a/pkgs/by-name/li/linbox/package.nix b/pkgs/by-name/li/linbox/package.nix index f9258f9913614d..be78cb31a31588 100644 --- a/pkgs/by-name/li/linbox/package.nix +++ b/pkgs/by-name/li/linbox/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, givaro -, pkg-config -, blas -, lapack -, fflas-ffpack -, gmpxx +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + givaro, + pkg-config, + blas, + lapack, + fflas-ffpack, + gmpxx, }: assert (!blas.isILP64) && (!lapack.isILP64); @@ -42,20 +44,22 @@ stdenv.mkDerivation rec { fflas-ffpack ]; - configureFlags = [ - "--with-blas-libs=-lblas" - "--without-archnative" - ] ++ lib.optionals stdenv.hostPlatform.isx86_64 [ - # disable SIMD instructions (which are enabled *when available* by default) - "--${if stdenv.hostPlatform.sse3Support then "enable" else "disable"}-sse3" - "--${if stdenv.hostPlatform.ssse3Support then "enable" else "disable"}-ssse3" - "--${if stdenv.hostPlatform.sse4_1Support then "enable" else "disable"}-sse41" - "--${if stdenv.hostPlatform.sse4_2Support then "enable" else "disable"}-sse42" - "--${if stdenv.hostPlatform.avxSupport then "enable" else "disable"}-avx" - "--${if stdenv.hostPlatform.avx2Support then "enable" else "disable"}-avx2" - "--${if stdenv.hostPlatform.fmaSupport then "enable" else "disable"}-fma" - "--${if stdenv.hostPlatform.fma4Support then "enable" else "disable"}-fma4" - ]; + configureFlags = + [ + "--with-blas-libs=-lblas" + "--without-archnative" + ] + ++ lib.optionals stdenv.hostPlatform.isx86_64 [ + # disable SIMD instructions (which are enabled *when available* by default) + "--${if stdenv.hostPlatform.sse3Support then "enable" else "disable"}-sse3" + "--${if stdenv.hostPlatform.ssse3Support then "enable" else "disable"}-ssse3" + "--${if stdenv.hostPlatform.sse4_1Support then "enable" else "disable"}-sse41" + "--${if stdenv.hostPlatform.sse4_2Support then "enable" else "disable"}-sse42" + "--${if stdenv.hostPlatform.avxSupport then "enable" else "disable"}-avx" + "--${if stdenv.hostPlatform.avx2Support then "enable" else "disable"}-avx2" + "--${if stdenv.hostPlatform.fmaSupport then "enable" else "disable"}-fma" + "--${if stdenv.hostPlatform.fma4Support then "enable" else "disable"}-fma4" + ]; # https://github.com/linbox-team/linbox/issues/304 hardeningDisable = [ "fortify3" ]; diff --git a/pkgs/by-name/li/linden-hill/package.nix b/pkgs/by-name/li/linden-hill/package.nix index cd543f473e205e..07d41919b2c25d 100644 --- a/pkgs/by-name/li/linden-hill/package.nix +++ b/pkgs/by-name/li/linden-hill/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, +}: stdenvNoCC.mkDerivation { pname = "linden-hill"; diff --git a/pkgs/by-name/li/line-awesome/package.nix b/pkgs/by-name/li/line-awesome/package.nix index d9f7818dd2f793..12bd35d1f31cdd 100644 --- a/pkgs/by-name/li/line-awesome/package.nix +++ b/pkgs/by-name/li/line-awesome/package.nix @@ -1,12 +1,16 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "line-awesome"; version = "1.3.0"; src = fetchurl { - url = - "https://maxst.icons8.com/vue-static/landings/line-awesome/line-awesome/${version}/line-awesome-${version}.zip"; + url = "https://maxst.icons8.com/vue-static/landings/line-awesome/line-awesome/${version}/line-awesome-${version}.zip"; sha256 = "07qkz8s1wjh5xwqlq1b4lpihr1zah3kh6bnqvfwvncld8l9wjqfk"; }; diff --git a/pkgs/by-name/li/linearicons-free/package.nix b/pkgs/by-name/li/linearicons-free/package.nix index 9b310a38d5ac65..4df1923e3b634e 100644 --- a/pkgs/by-name/li/linearicons-free/package.nix +++ b/pkgs/by-name/li/linearicons-free/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchzip, stdenvNoCC }: +{ + lib, + fetchzip, + stdenvNoCC, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "linearicons-free"; diff --git a/pkgs/by-name/li/linenoise-ng/package.nix b/pkgs/by-name/li/linenoise-ng/package.nix index c52b7085796ccc..1b9ad3f243c4bf 100644 --- a/pkgs/by-name/li/linenoise-ng/package.nix +++ b/pkgs/by-name/li/linenoise-ng/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "linenoise-ng"; diff --git a/pkgs/by-name/li/linenoise/package.nix b/pkgs/by-name/li/linenoise/package.nix index 13891d08f11337..acf8cf3e258c59 100644 --- a/pkgs/by-name/li/linenoise/package.nix +++ b/pkgs/by-name/li/linenoise/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, validatePkgConfig -, fixDarwinDylibNames +{ + lib, + stdenv, + fetchFromGitHub, + validatePkgConfig, + fixDarwinDylibNames, }: stdenv.mkDerivation { @@ -16,8 +17,9 @@ stdenv.mkDerivation { hash = "sha256-GsrYg16gpjHkkmpCU3yGzqNS/buZl+JoWALLvwzmT4A="; }; - nativeBuildInputs = [ validatePkgConfig ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ fixDarwinDylibNames ]; + nativeBuildInputs = [ + validatePkgConfig + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ fixDarwinDylibNames ]; buildPhase = '' runHook preBuild @@ -44,7 +46,10 @@ stdenv.mkDerivation { meta = { homepage = "https://github.com/antirez/linenoise"; description = "Minimal, zero-config, BSD licensed, readline replacement"; - maintainers = with lib.maintainers; [ fstamour remexre ]; + maintainers = with lib.maintainers; [ + fstamour + remexre + ]; platforms = lib.platforms.unix; license = lib.licenses.bsd2; }; diff --git a/pkgs/by-name/li/lineselect/package.nix b/pkgs/by-name/li/lineselect/package.nix index a99908b2e70efb..5386172232ea38 100644 --- a/pkgs/by-name/li/lineselect/package.nix +++ b/pkgs/by-name/li/lineselect/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, makeBinaryWrapper -, nodejs +{ + lib, + buildNpmPackage, + fetchFromGitHub, + makeBinaryWrapper, + nodejs, }: buildNpmPackage rec { diff --git a/pkgs/by-name/li/lingeling/package.nix b/pkgs/by-name/li/lingeling/package.nix index 1abf38b49cf82d..80cc5da336a05c 100644 --- a/pkgs/by-name/li/lingeling/package.nix +++ b/pkgs/by-name/li/lingeling/package.nix @@ -1,5 +1,8 @@ -{ lib, stdenv, fetchFromGitHub -, aiger +{ + lib, + stdenv, + fetchFromGitHub, + aiger, }: stdenv.mkDerivation { @@ -8,9 +11,9 @@ stdenv.mkDerivation { version = "pre1_708beb26"; src = fetchFromGitHub { - owner = "arminbiere"; - repo = "lingeling"; - rev = "708beb26a7d5b5d5e7abd88d6f552fb1946b07c1"; + owner = "arminbiere"; + repo = "lingeling"; + rev = "708beb26a7d5b5d5e7abd88d6f552fb1946b07c1"; sha256 = "1lb2g37nd8qq5hw5g6l691nx5095336yb2zlbaw43mg56hkj8357"; }; @@ -36,13 +39,17 @@ stdenv.mkDerivation { cp lingeling plingeling treengeling ilingeling blimc $out/bin ''; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; meta = with lib; { description = "Fast SAT solver"; - homepage = "http://fmv.jku.at/lingeling/"; - license = licenses.mit; - platforms = platforms.unix; + homepage = "http://fmv.jku.at/lingeling/"; + license = licenses.mit; + platforms = platforms.unix; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/li/lingot/package.nix b/pkgs/by-name/li/lingot/package.nix index b024b42a6f1af0..88df150b004eea 100644 --- a/pkgs/by-name/li/lingot/package.nix +++ b/pkgs/by-name/li/lingot/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, intltool -, wrapGAppsHook3 -, gtk3 -, alsa-lib -, libpulseaudio -, fftw -, fftwFloat -, json_c -, libjack2 -, jackSupport ? true +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + wrapGAppsHook3, + gtk3, + alsa-lib, + libpulseaudio, + fftw, + fftwFloat, + json_c, + libjack2, + jackSupport ? true, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/lingua-franca/package.nix b/pkgs/by-name/li/lingua-franca/package.nix index f989a5e9d6be1b..769c9e13d4c916 100644 --- a/pkgs/by-name/li/lingua-franca/package.nix +++ b/pkgs/by-name/li/lingua-franca/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchzip, jdk17_headless }: +{ + lib, + stdenv, + fetchzip, + jdk17_headless, +}: stdenv.mkDerivation rec { pname = "lfc"; diff --git a/pkgs/by-name/li/linien-gui/package.nix b/pkgs/by-name/li/linien-gui/package.nix index 374bb6951dc369..a62f5b269f109d 100644 --- a/pkgs/by-name/li/linien-gui/package.nix +++ b/pkgs/by-name/li/linien-gui/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, qt5 +{ + lib, + python3, + qt5, }: python3.pkgs.buildPythonApplication rec { @@ -11,11 +12,14 @@ python3.pkgs.buildPythonApplication rec { sourceRoot = "${src.name}/linien-gui"; - nativeBuildInputs = with python3.pkgs; [ - setuptools - ] ++ [ - qt5.wrapQtAppsHook - ]; + nativeBuildInputs = + with python3.pkgs; + [ + setuptools + ] + ++ [ + qt5.wrapQtAppsHook + ]; # Makes qt-wayland appear in the qt paths injected by the wrapper - helps users # with `QT_QPA_PLATFORM=wayland` in their environment. @@ -45,6 +49,9 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://github.com/linien-org/linien/tree/develop/linien-gui"; changelog = "https://github.com/linien-org/linien/blob/v${version}/CHANGELOG.md"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ fsagbuya doronbehar ]; + maintainers = with maintainers; [ + fsagbuya + doronbehar + ]; }; } diff --git a/pkgs/by-name/li/linja-pi-pu-lukin/package.nix b/pkgs/by-name/li/linja-pi-pu-lukin/package.nix index 3f320a61233545..de46fa570e527b 100644 --- a/pkgs/by-name/li/linja-pi-pu-lukin/package.nix +++ b/pkgs/by-name/li/linja-pi-pu-lukin/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation { pname = "linja-pi-pu-lukin"; diff --git a/pkgs/by-name/li/link-grammar/package.nix b/pkgs/by-name/li/link-grammar/package.nix index 68d38d7505d48e..25a97d0a6df510 100644 --- a/pkgs/by-name/li/link-grammar/package.nix +++ b/pkgs/by-name/li/link-grammar/package.nix @@ -1,67 +1,76 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, python3 -, flex -, sqlite -, libedit -, runCommand -, dieHook +{ + lib, + stdenv, + fetchurl, + pkg-config, + python3, + flex, + sqlite, + libedit, + runCommand, + dieHook, }: let -link-grammar = stdenv.mkDerivation rec { - pname = "link-grammar"; - version = "5.10.5"; + link-grammar = stdenv.mkDerivation rec { + pname = "link-grammar"; + version = "5.10.5"; - outputs = [ "bin" "out" "dev" "man" ]; + outputs = [ + "bin" + "out" + "dev" + "man" + ]; - src = fetchurl { - url = "http://www.abisource.com/downloads/${pname}/${version}/${pname}-${version}.tar.gz"; - sha256 = "sha256-MkcQzYEyl1/5zLU1CXMvdVhHOxwZ8XiSAAo97bhhiu0="; - }; + src = fetchurl { + url = "http://www.abisource.com/downloads/${pname}/${version}/${pname}-${version}.tar.gz"; + sha256 = "sha256-MkcQzYEyl1/5zLU1CXMvdVhHOxwZ8XiSAAo97bhhiu0="; + }; - nativeBuildInputs = [ - pkg-config - python3 - flex - ]; + nativeBuildInputs = [ + pkg-config + python3 + flex + ]; - buildInputs = [ - sqlite - libedit - ]; + buildInputs = [ + sqlite + libedit + ]; - configureFlags = [ - "--disable-java-bindings" - ]; + configureFlags = [ + "--disable-java-bindings" + ]; - doCheck = true; + doCheck = true; - passthru.tests = { - quick = runCommand "link-grammar-quick-test" { - buildInputs = [ - link-grammar - dieHook - ]; - } '' - echo "Furiously sleep ideas green colorless." | link-parser en | grep "No complete linkages found." || die "Grammaticaly invalid sentence was parsed." - echo "Colorless green ideas sleep furiously." | link-parser en | grep "Found .* linkages." || die "Grammaticaly valid sentence was not parsed." - touch $out - ''; - }; + passthru.tests = { + quick = + runCommand "link-grammar-quick-test" + { + buildInputs = [ + link-grammar + dieHook + ]; + } + '' + echo "Furiously sleep ideas green colorless." | link-parser en | grep "No complete linkages found." || die "Grammaticaly invalid sentence was parsed." + echo "Colorless green ideas sleep furiously." | link-parser en | grep "Found .* linkages." || die "Grammaticaly valid sentence was not parsed." + touch $out + ''; + }; - meta = with lib; { - description = "Grammar Checking library"; - homepage = "https://www.abisource.com/projects/link-grammar/"; - changelog = "https://github.com/opencog/link-grammar/blob/link-grammar-${version}/ChangeLog"; - license = licenses.lgpl21Only; - maintainers = with maintainers; [ jtojnar ]; - platforms = platforms.unix; + meta = with lib; { + description = "Grammar Checking library"; + homepage = "https://www.abisource.com/projects/link-grammar/"; + changelog = "https://github.com/opencog/link-grammar/blob/link-grammar-${version}/ChangeLog"; + license = licenses.lgpl21Only; + maintainers = with maintainers; [ jtojnar ]; + platforms = platforms.unix; + }; }; -}; in - link-grammar +link-grammar diff --git a/pkgs/by-name/li/links2/package.nix b/pkgs/by-name/li/links2/package.nix index 6680033e683153..fbeed583d48591 100644 --- a/pkgs/by-name/li/links2/package.nix +++ b/pkgs/by-name/li/links2/package.nix @@ -1,10 +1,26 @@ -{ lib, stdenv, fetchurl -, gpm, openssl, pkg-config, libev # Misc. -, libpng, libjpeg, libtiff, librsvg, libavif # graphic formats -, bzip2, zlib, xz # Transfer encodings -, enableFB ? (!stdenv.hostPlatform.isDarwin) -, enableDirectFB ? false, directfb -, enableX11 ? (!stdenv.hostPlatform.isDarwin), libX11, libXt, libXau # GUI support +{ + lib, + stdenv, + fetchurl, + gpm, + openssl, + pkg-config, + libev, # Misc. + libpng, + libjpeg, + libtiff, + librsvg, + libavif, # graphic formats + bzip2, + zlib, + xz, # Transfer encodings + enableFB ? (!stdenv.hostPlatform.isDarwin), + enableDirectFB ? false, + directfb, + enableX11 ? (!stdenv.hostPlatform.isDarwin), + libX11, + libXt, + libXau, # GUI support }: stdenv.mkDerivation (finalAttrs: { @@ -17,14 +33,33 @@ stdenv.mkDerivation (finalAttrs: { }; buildInputs = - [ libev librsvg libpng libjpeg libtiff libavif openssl xz bzip2 zlib ] + [ + libev + librsvg + libpng + libjpeg + libtiff + libavif + openssl + xz + bzip2 + zlib + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ gpm ] - ++ lib.optionals enableX11 [ libX11 libXau libXt ] + ++ lib.optionals enableX11 [ + libX11 + libXau + libXt + ] ++ lib.optionals enableDirectFB [ directfb ]; - nativeBuildInputs = [ pkg-config bzip2 ]; + nativeBuildInputs = [ + pkg-config + bzip2 + ]; - configureFlags = [ "--with-ssl" ] + configureFlags = + [ "--with-ssl" ] ++ lib.optional (enableX11 || enableFB || enableDirectFB) "--enable-graphics" ++ lib.optional enableX11 "--with-x" ++ lib.optional enableFB "--with-fb" diff --git a/pkgs/by-name/li/lint-staged/package.nix b/pkgs/by-name/li/lint-staged/package.nix index d802df0f3c6098..8987008c06f5ea 100644 --- a/pkgs/by-name/li/lint-staged/package.nix +++ b/pkgs/by-name/li/lint-staged/package.nix @@ -1,4 +1,10 @@ -{ lib, buildNpmPackage, fetchFromGitHub, testers, lint-staged }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, + testers, + lint-staged, +}: buildNpmPackage rec { pname = "lint-staged"; diff --git a/pkgs/by-name/li/linux-exploit-suggester/package.nix b/pkgs/by-name/li/linux-exploit-suggester/package.nix index ed68e8e7c7a334..e9af8bcaea366f 100644 --- a/pkgs/by-name/li/linux-exploit-suggester/package.nix +++ b/pkgs/by-name/li/linux-exploit-suggester/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "linux-exploit-suggester"; diff --git a/pkgs/by-name/li/linux-manual/package.nix b/pkgs/by-name/li/linux-manual/package.nix index e9cfe258a7fa2a..4240654d6b3434 100644 --- a/pkgs/by-name/li/linux-manual/package.nix +++ b/pkgs/by-name/li/linux-manual/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, perl, linuxPackages_latest }: +{ + lib, + stdenv, + perl, + linuxPackages_latest, +}: stdenv.mkDerivation rec { pname = "linux-manual"; diff --git a/pkgs/by-name/li/linux-pam/package.nix b/pkgs/by-name/li/linux-pam/package.nix index 9e97071bbc7c95..a1a515097307cd 100644 --- a/pkgs/by-name/li/linux-pam/package.nix +++ b/pkgs/by-name/li/linux-pam/package.nix @@ -1,7 +1,17 @@ -{ lib, stdenv, buildPackages, fetchurl -, flex, cracklib, db4, gettext, audit, libxcrypt -, nixosTests -, autoreconfHook269, pkg-config-unwrapped +{ + lib, + stdenv, + buildPackages, + fetchurl, + flex, + cracklib, + db4, + gettext, + audit, + libxcrypt, + nixosTests, + autoreconfHook269, + pkg-config-unwrapped, }: stdenv.mkDerivation rec { @@ -18,21 +28,33 @@ stdenv.mkDerivation rec { ]; # Case-insensitivity workaround for https://github.com/linux-pam/linux-pam/issues/569 - postPatch = lib.optionalString (stdenv.buildPlatform.isDarwin && stdenv.buildPlatform != stdenv.hostPlatform) '' - rm CHANGELOG - touch ChangeLog - ''; + postPatch = + lib.optionalString (stdenv.buildPlatform.isDarwin && stdenv.buildPlatform != stdenv.hostPlatform) + '' + rm CHANGELOG + touch ChangeLog + ''; - outputs = [ "out" "doc" "man" /* "modules" */ ]; + outputs = [ + "out" + "doc" + "man" # "modules" + ]; depsBuildBuild = [ buildPackages.stdenv.cc ]; # autoreconfHook269 is needed for `suid-wrapper-path.patch` above. # pkg-config-unwrapped is needed for `AC_CHECK_LIB` and `AC_SEARCH_LIBS` - nativeBuildInputs = [ flex autoreconfHook269 pkg-config-unwrapped ] - ++ lib.optional stdenv.buildPlatform.isDarwin gettext; + nativeBuildInputs = [ + flex + autoreconfHook269 + pkg-config-unwrapped + ] ++ lib.optional stdenv.buildPlatform.isDarwin gettext; - buildInputs = [ cracklib db4 libxcrypt ] - ++ lib.optional stdenv.buildPlatform.isLinux audit; + buildInputs = [ + cracklib + db4 + libxcrypt + ] ++ lib.optional stdenv.buildPlatform.isLinux audit; enableParallelBuilding = true; @@ -51,7 +73,12 @@ stdenv.mkDerivation rec { doCheck = false; # fails passthru.tests = { - inherit (nixosTests) pam-oath-login pam-u2f shadow sssd-ldap; + inherit (nixosTests) + pam-oath-login + pam-u2f + shadow + sssd-ldap + ; }; meta = with lib; { diff --git a/pkgs/by-name/li/linux-router/package.nix b/pkgs/by-name/li/linux-router/package.nix index e2620b90b22be1..4e84f419a190c0 100644 --- a/pkgs/by-name/li/linux-router/package.nix +++ b/pkgs/by-name/li/linux-router/package.nix @@ -1,41 +1,42 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, -# --- Runtime Dependencies --- -, bash -, procps -, iproute2 -, dnsmasq -, iptables -, coreutils -, flock -, gawk -, getopt -, gnugrep -, gnused -, which -# `nmcli` is not required for create_ap. -# Use NetworkManager by default because it is very likely already present -, useNetworkManager ? true -, networkmanager + # --- Runtime Dependencies --- + bash, + procps, + iproute2, + dnsmasq, + iptables, + coreutils, + flock, + gawk, + getopt, + gnugrep, + gnused, + which, + # `nmcli` is not required for create_ap. + # Use NetworkManager by default because it is very likely already present + useNetworkManager ? true, + networkmanager, -# --- WiFi Hotspot Dependencies --- -, useWifiDependencies ? true -, hostapd -, iw -# You only need this if 'iw' can not recognize your adapter. -, useWirelessTools ? true -, wirelesstools # for iwconfig -# To fall back to haveged if entropy is low. -# Defaulting to false because not having it does not break things. -# If it is really needed, warnings will be logged to journal. -, useHaveged ? false -, haveged -# You only need this if you wish to show WiFi QR codes in terminal -, useQrencode ? true -, qrencode + # --- WiFi Hotspot Dependencies --- + useWifiDependencies ? true, + hostapd, + iw, + # You only need this if 'iw' can not recognize your adapter. + useWirelessTools ? true, + wirelesstools, # for iwconfig + # To fall back to haveged if entropy is low. + # Defaulting to false because not having it does not break things. + # If it is really needed, warnings will be logged to journal. + useHaveged ? false, + haveged, + # You only need this if you wish to show WiFi QR codes in terminal + useQrencode ? true, + qrencode, }: stdenv.mkDerivation rec { @@ -55,15 +56,30 @@ stdenv.mkDerivation rec { dontBuild = true; - installPhase = let - binPath = lib.makeBinPath ([ procps iproute2 getopt bash dnsmasq - iptables coreutils which flock gnugrep gnused gawk ] - ++ lib.optional useNetworkManager networkmanager - ++ lib.optional useWifiDependencies hostapd - ++ lib.optional useWifiDependencies iw - ++ lib.optional (useWifiDependencies && useWirelessTools) wirelesstools - ++ lib.optional (useWifiDependencies && useHaveged) haveged - ++ lib.optional (useWifiDependencies && useQrencode) qrencode); + installPhase = + let + binPath = lib.makeBinPath ( + [ + procps + iproute2 + getopt + bash + dnsmasq + iptables + coreutils + which + flock + gnugrep + gnused + gawk + ] + ++ lib.optional useNetworkManager networkmanager + ++ lib.optional useWifiDependencies hostapd + ++ lib.optional useWifiDependencies iw + ++ lib.optional (useWifiDependencies && useWirelessTools) wirelesstools + ++ lib.optional (useWifiDependencies && useHaveged) haveged + ++ lib.optional (useWifiDependencies && useQrencode) qrencode + ); in '' mkdir -p $out/bin/ $out/.bin-wrapped diff --git a/pkgs/by-name/li/linux-scripts/package.nix b/pkgs/by-name/li/linux-scripts/package.nix index f317538be7e705..479fcafecfd3c0 100644 --- a/pkgs/by-name/li/linux-scripts/package.nix +++ b/pkgs/by-name/li/linux-scripts/package.nix @@ -1,19 +1,20 @@ -{ lib -, linuxHeaders # Linux source tree -, makeWrapper -, stdenvNoCC +{ + lib, + linuxHeaders, # Linux source tree + makeWrapper, + stdenvNoCC, -, binutils -, coreutils -, gnugrep + binutils, + coreutils, + gnugrep, # decompressors for possible kernel image formats -, bzip2 -, gzip -, lz4 -, lzop -, xz -, zstd + bzip2, + gzip, + lz4, + lzop, + xz, + zstd, }: let @@ -34,8 +35,7 @@ let wrapProgram $out/bin/${scriptName} --prefix PATH : ${lib.makeBinPath commonDeps} ''; in -stdenvNoCC.mkDerivation -{ +stdenvNoCC.mkDerivation { inherit (linuxHeaders) version; pname = "linux-scripts"; diff --git a/pkgs/by-name/li/linuxConsoleTools/package.nix b/pkgs/by-name/li/linuxConsoleTools/package.nix index c5138e12fe469e..323c83b9d26b42 100644 --- a/pkgs/by-name/li/linuxConsoleTools/package.nix +++ b/pkgs/by-name/li/linuxConsoleTools/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, SDL, SDL2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + SDL, + SDL2, +}: stdenv.mkDerivation rec { pname = "linuxconsoletools"; @@ -10,9 +17,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ SDL SDL2 ]; + buildInputs = [ + SDL + SDL2 + ]; - makeFlags = [ "DESTDIR=$(out)"]; + makeFlags = [ "DESTDIR=$(out)" ]; installFlags = [ "PREFIX=\"\"" ]; @@ -21,7 +31,10 @@ stdenv.mkDerivation rec { description = "Set of tools for joysticks and serial peripherals"; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ pSub ebzzry ]; + maintainers = with maintainers; [ + pSub + ebzzry + ]; longDescription = '' The included tools are: diff --git a/pkgs/by-name/li/linux_logo/package.nix b/pkgs/by-name/li/linux_logo/package.nix index 5b12f75b729736..07d3bfe9e5df36 100644 --- a/pkgs/by-name/li/linux_logo/package.nix +++ b/pkgs/by-name/li/linux_logo/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, gettext -, which +{ + lib, + stdenv, + fetchFromGitHub, + gettext, + which, }: stdenv.mkDerivation rec { @@ -16,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-yBAxPwgKyFFIX0wuG7oG+FbEDpA5cPwyyJgWrFErJ7I="; }; - nativeBuildInputs = [ gettext which ]; + nativeBuildInputs = [ + gettext + which + ]; meta = with lib; { description = "Prints an ASCII logo and some system info"; diff --git a/pkgs/by-name/li/linuxdoc-tools/package.nix b/pkgs/by-name/li/linuxdoc-tools/package.nix index 18356356cdca37..34bb2d84757513 100644 --- a/pkgs/by-name/li/linuxdoc-tools/package.nix +++ b/pkgs/by-name/li/linuxdoc-tools/package.nix @@ -1,5 +1,18 @@ -{ stdenv, lib, makeWrapper, fetchFromGitLab, perl, flex -, gnused, coreutils, which, opensp, groff, texliveMedium, texinfo, withLatex ? false +{ + stdenv, + lib, + makeWrapper, + fetchFromGitLab, + perl, + flex, + gnused, + coreutils, + which, + opensp, + groff, + texliveMedium, + texinfo, + withLatex ? false, }: stdenv.mkDerivation rec { @@ -13,18 +26,26 @@ stdenv.mkDerivation rec { hash = "sha256-8nsCfcxqVt16br6Vhk8tW3cxJMJFSZYX2g3MjO7JoT4="; }; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; configureFlags = [ - ("--enable-docs=txt info lyx html rtf" - + lib.optionalString withLatex " pdf") + ("--enable-docs=txt info lyx html rtf" + lib.optionalString withLatex " pdf") ]; LEX = "flex"; postInstall = '' wrapProgram $out/bin/linuxdoc \ - --prefix PATH : "${lib.makeBinPath [ groff opensp ]}:$out/bin" \ + --prefix PATH : "${ + lib.makeBinPath [ + groff + opensp + ] + }:$out/bin" \ --prefix PERL5LIB : "$out/share/linuxdoc-tools/" ''; @@ -39,10 +60,20 @@ stdenv.mkDerivation rec { popd ''; - nativeBuildInputs = [ flex which makeWrapper ]; + nativeBuildInputs = [ + flex + which + makeWrapper + ]; - buildInputs = [ opensp groff texinfo perl gnused coreutils ] - ++ lib.optionals withLatex [ texliveMedium ]; + buildInputs = [ + opensp + groff + texinfo + perl + gnused + coreutils + ] ++ lib.optionals withLatex [ texliveMedium ]; meta = with lib; { description = "Toolset for processing LinuxDoc DTD SGML files"; @@ -55,7 +86,11 @@ stdenv.mkDerivation rec { documents written in LinuxDoc DTD sgml source. ''; homepage = "https://gitlab.com/agmartin/linuxdoc-tools"; - license = with licenses; [ gpl3Plus mit sgmlug ]; + license = with licenses; [ + gpl3Plus + mit + sgmlug + ]; platforms = platforms.linux; maintainers = with maintainers; [ p-h ]; }; diff --git a/pkgs/by-name/li/linuxhw-edid-fetcher/package.nix b/pkgs/by-name/li/linuxhw-edid-fetcher/package.nix index 18c91f1b18cdca..dcf6c0908e71b5 100644 --- a/pkgs/by-name/li/linuxhw-edid-fetcher/package.nix +++ b/pkgs/by-name/li/linuxhw-edid-fetcher/package.nix @@ -1,14 +1,15 @@ -{ lib -, coreutils -, curl -, fetchFromGitHub -, gawk -, gnutar -, stdenv -, unixtools -, writeShellApplication -, nix-update-script -, displays ? { } +{ + lib, + coreutils, + curl, + fetchFromGitHub, + gawk, + gnutar, + stdenv, + unixtools, + writeShellApplication, + nix-update-script, + displays ? { }, }: # Usage: @@ -31,7 +32,13 @@ stdenv.mkDerivation rec { fetch = lib.getExe (writeShellApplication { name = "linuxhw-edid-fetch"; - runtimeInputs = [ gawk coreutils unixtools.xxd curl gnutar ]; + runtimeInputs = [ + gawk + coreutils + unixtools.xxd + curl + gnutar + ]; text = '' repo="''${repo:-"${src}"}" ${builtins.readFile ./linuxhw-edid-fetch.sh} @@ -39,9 +46,11 @@ stdenv.mkDerivation rec { }); configurePhase = lib.pipe displays [ - (lib.mapAttrsToList (name: patterns: '' - "$fetch" ${lib.escapeShellArgs patterns} > "${name}.bin" - '')) + (lib.mapAttrsToList ( + name: patterns: '' + "$fetch" ${lib.escapeShellArgs patterns} > "${name}.bin" + '' + )) (builtins.concatStringsSep "\n") ]; diff --git a/pkgs/by-name/li/linuxptp/package.nix b/pkgs/by-name/li/linuxptp/package.nix index 66a03a4ffa3273..3b02c68f1221b1 100644 --- a/pkgs/by-name/li/linuxptp/package.nix +++ b/pkgs/by-name/li/linuxptp/package.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, linuxHeaders } : - +{ + lib, + stdenv, + fetchFromGitHub, + linuxHeaders, +}: stdenv.mkDerivation rec { pname = "linuxptp"; @@ -12,7 +16,10 @@ stdenv.mkDerivation rec { hash = "sha256-w1buo+D8Mnd6ytMhQYhvCDqt+RejlNSN/iVjrDR+Khk="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; postPatch = '' substituteInPlace incdefs.sh --replace-fail \ diff --git a/pkgs/by-name/li/linuxquota/package.nix b/pkgs/by-name/li/linuxquota/package.nix index d9aa6492b58110..8543256ec87e64 100644 --- a/pkgs/by-name/li/linuxquota/package.nix +++ b/pkgs/by-name/li/linuxquota/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, e2fsprogs, openldap, pkg-config, binlore, linuxquota }: +{ + lib, + stdenv, + fetchurl, + e2fsprogs, + openldap, + pkg-config, + binlore, + linuxquota, +}: stdenv.mkDerivation rec { version = "4.09"; @@ -9,10 +18,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-nNrKFUvJKvwxF/Dl9bMgjdX4RYOvHPBhw5uqCiuxQvk="; }; - outputs = [ "out" "dev" "doc" "man" ]; + outputs = [ + "out" + "dev" + "doc" + "man" + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ e2fsprogs openldap ]; + buildInputs = [ + e2fsprogs + openldap + ]; passthru.binlore.out = binlore.synthesize linuxquota '' execer cannot bin/quota diff --git a/pkgs/by-name/li/linuxsampler/package.nix b/pkgs/by-name/li/linuxsampler/package.nix index 53e5b6e6e7333f..6a7fbf180120ba 100644 --- a/pkgs/by-name/li/linuxsampler/package.nix +++ b/pkgs/by-name/li/linuxsampler/package.nix @@ -1,5 +1,20 @@ -{ lib, stdenv, fetchurl, autoconf, automake, bison, libtool, pkg-config, which -, alsa-lib, asio, libjack2, libgig, libsndfile, lv2 }: +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + bison, + libtool, + pkg-config, + which, + alsa-lib, + asio, + libjack2, + libgig, + libsndfile, + lv2, +}: stdenv.mkDerivation rec { pname = "linuxsampler"; @@ -14,9 +29,23 @@ stdenv.mkDerivation rec { make -f Makefile.svn ''; - nativeBuildInputs = [ autoconf automake bison libtool pkg-config which ]; + nativeBuildInputs = [ + autoconf + automake + bison + libtool + pkg-config + which + ]; - buildInputs = [ alsa-lib asio libjack2 libgig libsndfile lv2 ]; + buildInputs = [ + alsa-lib + asio + libjack2 + libgig + libsndfile + lv2 + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/li/linuxwave/package.nix b/pkgs/by-name/li/linuxwave/package.nix index 4d86b31c854ef5..0ac17761b0fa6d 100644 --- a/pkgs/by-name/li/linuxwave/package.nix +++ b/pkgs/by-name/li/linuxwave/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles -, zig_0_10 +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + zig_0_10, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/linx-server/package.nix b/pkgs/by-name/li/linx-server/package.nix index dbd8c3f3d122f6..27bd8cbf2d539d 100644 --- a/pkgs/by-name/li/linx-server/package.nix +++ b/pkgs/by-name/li/linx-server/package.nix @@ -1,7 +1,8 @@ -{ buildGoModule -, fetchFromGitHub -, go-rice -, lib +{ + buildGoModule, + fetchFromGitHub, + go-rice, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/li/lipl/package.nix b/pkgs/by-name/li/lipl/package.nix index 8d9d294f3edd78..c039056cf4986c 100644 --- a/pkgs/by-name/li/lipl/package.nix +++ b/pkgs/by-name/li/lipl/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/li/liquibase/package.nix b/pkgs/by-name/li/liquibase/package.nix index 275ea342943213..266efd45a870a5 100644 --- a/pkgs/by-name/li/liquibase/package.nix +++ b/pkgs/by-name/li/liquibase/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, gitUpdater -, jre -, makeWrapper -, mysqlSupport ? true -, mysql_jdbc -, postgresqlSupport ? true -, postgresql_jdbc -, redshiftSupport ? true -, redshift_jdbc -, liquibase_redshift_extension +{ + lib, + stdenv, + fetchurl, + gitUpdater, + jre, + makeWrapper, + mysqlSupport ? true, + mysql_jdbc, + postgresqlSupport ? true, + postgresql_jdbc, + redshiftSupport ? true, + redshift_jdbc, + liquibase_redshift_extension, }: let @@ -38,11 +39,12 @@ stdenv.mkDerivation (finalAttrs: { sourceRoot = "."; installPhase = - let addJars = dir: '' - for jar in ${dir}/*.jar; do - CP="\$CP":"\$jar" - done - ''; + let + addJars = dir: '' + for jar in ${dir}/*.jar; do + CP="\$CP":"\$jar" + done + ''; in '' mkdir -p $out diff --git a/pkgs/by-name/li/liquibase_redshift_extension/package.nix b/pkgs/by-name/li/liquibase_redshift_extension/package.nix index ba15086ae0ab59..705dbf2b283d68 100644 --- a/pkgs/by-name/li/liquibase_redshift_extension/package.nix +++ b/pkgs/by-name/li/liquibase_redshift_extension/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchMavenArtifact }: +{ + lib, + stdenv, + fetchMavenArtifact, +}: stdenv.mkDerivation rec { pname = "liquibase-redshift-extension"; diff --git a/pkgs/by-name/li/liquidfun/package.nix b/pkgs/by-name/li/liquidfun/package.nix index 2e12f5903444c0..84974f233890d3 100644 --- a/pkgs/by-name/li/liquidfun/package.nix +++ b/pkgs/by-name/li/liquidfun/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, requireFile, cmake, libGLU, libGL, libX11, libXi }: +{ + lib, + stdenv, + requireFile, + cmake, + libGLU, + libGL, + libX11, + libXi, +}: stdenv.mkDerivation rec { pname = "liquidfun"; @@ -11,7 +20,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libGLU libGL libX11 libXi ]; + buildInputs = [ + libGLU + libGL + libX11 + libXi + ]; sourceRoot = "liquidfun/Box2D"; diff --git a/pkgs/by-name/li/liquidprompt/package.nix b/pkgs/by-name/li/liquidprompt/package.nix index 6c2cb409658dc7..aec6d5f3fd01a7 100644 --- a/pkgs/by-name/li/liquidprompt/package.nix +++ b/pkgs/by-name/li/liquidprompt/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, gitUpdater }: +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, +}: stdenv.mkDerivation rec { pname = "liquidprompt"; diff --git a/pkgs/by-name/li/lirc/package.nix b/pkgs/by-name/li/lirc/package.nix index 80c9d1f1d81024..69cc919a8d0065 100644 --- a/pkgs/by-name/li/lirc/package.nix +++ b/pkgs/by-name/li/lirc/package.nix @@ -1,25 +1,31 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, autoreconfHook -, pkg-config -, help2man -, python3 -, linuxHeaders - -, alsa-lib -, libxslt -, systemd -, libusb-compat-0_1 -, libftdi1 -, libICE -, libSM -, libX11 +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + pkg-config, + help2man, + python3, + linuxHeaders, + + alsa-lib, + libxslt, + systemd, + libusb-compat-0_1, + libftdi1, + libICE, + libSM, + libX11, }: let - pythonEnv = python3.pythonOnBuildForHost.withPackages (p: with p; [ pyyaml setuptools ]); + pythonEnv = python3.pythonOnBuildForHost.withPackages ( + p: with p; [ + pyyaml + setuptools + ] + ); in stdenv.mkDerivation rec { pname = "lirc"; @@ -66,9 +72,23 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ autoreconfHook help2man libxslt pythonEnv pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + help2man + libxslt + pythonEnv + pkg-config + ]; - buildInputs = [ alsa-lib systemd libusb-compat-0_1 libftdi1 libICE libSM libX11 ]; + buildInputs = [ + alsa-lib + systemd + libusb-compat-0_1 + libftdi1 + libICE + libSM + libX11 + ]; DEVINPUT_HEADER = "${linuxHeaders}/include/linux/input-event-codes.h"; diff --git a/pkgs/by-name/li/lisgd/package.nix b/pkgs/by-name/li/lisgd/package.nix index 23e677144945a2..7ccc9e7f9cd3dd 100644 --- a/pkgs/by-name/li/lisgd/package.nix +++ b/pkgs/by-name/li/lisgd/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromSourcehut -, writeText -, libinput -, libX11 -, wayland -, conf ? null -, patches ? [ ] +{ + lib, + stdenv, + fetchFromSourcehut, + writeText, + libinput, + libX11, + wayland, + conf ? null, + patches ? [ ], }: stdenv.mkDerivation rec { @@ -22,14 +23,14 @@ stdenv.mkDerivation rec { inherit patches; - postPatch = let - configFile = if lib.isDerivation conf || lib.isPath conf then - conf - else - writeText "config.def.h" conf; - in lib.optionalString (conf != null) '' - cp ${configFile} config.def.h - ''; + postPatch = + let + configFile = + if lib.isDerivation conf || lib.isPath conf then conf else writeText "config.def.h" conf; + in + lib.optionalString (conf != null) '' + cp ${configFile} config.def.h + ''; buildInputs = [ libinput diff --git a/pkgs/by-name/li/listadmin/package.nix b/pkgs/by-name/li/listadmin/package.nix index 6a4a2927d3ef3f..f99c749ef75d91 100644 --- a/pkgs/by-name/li/listadmin/package.nix +++ b/pkgs/by-name/li/listadmin/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenvNoCC, fetchurl, makeWrapper, perl, installShellFiles }: +{ + lib, + stdenvNoCC, + fetchurl, + makeWrapper, + perl, + installShellFiles, +}: stdenvNoCC.mkDerivation rec { pname = "listadmin"; @@ -10,7 +17,10 @@ stdenvNoCC.mkDerivation rec { }; buildInputs = [ perl ]; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; # There is a Makefile, but we don’t need it, and it prints errors dontBuild = true; @@ -21,9 +31,14 @@ stdenvNoCC.mkDerivation rec { installManPage listadmin.1 wrapProgram $out/bin/listadmin \ - --prefix PERL5LIB : "${with perl.pkgs; makeFullPerlPath [ - TextReform NetINET6Glue LWPProtocolHttps - ]}" + --prefix PERL5LIB : "${ + with perl.pkgs; + makeFullPerlPath [ + TextReform + NetINET6Glue + LWPProtocolHttps + ] + }" ''; doInstallCheck = true; @@ -34,11 +49,11 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { description = "Command line mailman moderator queue manipulation"; longDescription = '' - listadmin is a command line tool to manipulate the queues of messages - held for moderator approval by mailman. It is designed to keep user - interaction to a minimum, in theory you could run it from cron to prune - the queue. It can use the score from a header added by SpamAssassin to - filter, or it can match specific senders, subjects, or reasons. + listadmin is a command line tool to manipulate the queues of messages + held for moderator approval by mailman. It is designed to keep user + interaction to a minimum, in theory you could run it from cron to prune + the queue. It can use the score from a header added by SpamAssassin to + filter, or it can match specific senders, subjects, or reasons. ''; homepage = "https://sourceforge.net/projects/listadmin/"; license = licenses.publicDomain; diff --git a/pkgs/by-name/li/listen1/package.nix b/pkgs/by-name/li/listen1/package.nix index 97470e33c77f29..f159d5d425140c 100644 --- a/pkgs/by-name/li/listen1/package.nix +++ b/pkgs/by-name/li/listen1/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools }: +{ + lib, + fetchurl, + appimageTools, +}: let pname = "listen1"; diff --git a/pkgs/by-name/li/lite/package.nix b/pkgs/by-name/li/lite/package.nix index a58fb9756661de..fd19d3bd1f83ec 100644 --- a/pkgs/by-name/li/lite/package.nix +++ b/pkgs/by-name/li/lite/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, SDL2 -, lua52Packages -, pkg-config -, makeWrapper -, openlibm -} : +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + lua52Packages, + pkg-config, + makeWrapper, + openlibm, +}: stdenv.mkDerivation rec { pname = "lite"; @@ -18,9 +20,16 @@ stdenv.mkDerivation rec { sha256 = "0wxqfb4ly8g7w5qph76xys95b55ackkags8jgd1nasmiyi8gcd5a"; }; - nativeBuildInputs = [ makeWrapper pkg-config ]; + nativeBuildInputs = [ + makeWrapper + pkg-config + ]; - buildInputs = [ SDL2 lua52Packages.lua openlibm ]; + buildInputs = [ + SDL2 + lua52Packages.lua + openlibm + ]; postPatch = '' # use system Lua 5.2 diff --git a/pkgs/by-name/li/litebrowser/package.nix b/pkgs/by-name/li/litebrowser/package.nix index b46bde36cb9618..1dcaf8b4c436ee 100644 --- a/pkgs/by-name/li/litebrowser/package.nix +++ b/pkgs/by-name/li/litebrowser/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, gtk3 -, gtkmm3 -, curl -, poco -, gumbo # litehtml dependency +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + gtk3, + gtkmm3, + curl, + poco, + gumbo, # litehtml dependency }: stdenv.mkDerivation { @@ -46,7 +47,7 @@ stdenv.mkDerivation { ''; meta = with lib; { - broken = stdenv.cc.isClang; # https://github.com/litehtml/litebrowser-linux/issues/19 + broken = stdenv.cc.isClang; # https://github.com/litehtml/litebrowser-linux/issues/19 description = "Simple browser based on the litehtml engine"; mainProgram = "litebrowser"; homepage = "https://github.com/litehtml/litebrowser-linux"; diff --git a/pkgs/by-name/li/litefs/package.nix b/pkgs/by-name/li/litefs/package.nix index e3dbdd780cd87c..5277cda5c178f7 100644 --- a/pkgs/by-name/li/litefs/package.nix +++ b/pkgs/by-name/li/litefs/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/li/litehtml/package.nix b/pkgs/by-name/li/litehtml/package.nix index b7626733210de1..f5029dc9b27f58 100644 --- a/pkgs/by-name/li/litehtml/package.nix +++ b/pkgs/by-name/li/litehtml/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gumbo +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gumbo, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/li/litemdview/package.nix b/pkgs/by-name/li/litemdview/package.nix index e07c22165277d6..a5dfff322b109b 100644 --- a/pkgs/by-name/li/litemdview/package.nix +++ b/pkgs/by-name/li/litemdview/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitea -, gtkmm3 -, autoreconfHook -, pkg-config +{ + lib, + stdenv, + fetchFromGitea, + gtkmm3, + autoreconfHook, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/litestream/package.nix b/pkgs/by-name/li/litestream/package.nix index b09b0168b0aa35..fdb205a271ed85 100644 --- a/pkgs/by-name/li/litestream/package.nix +++ b/pkgs/by-name/li/litestream/package.nix @@ -1,7 +1,8 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, nixosTests +{ + buildGoModule, + fetchFromGitHub, + lib, + nixosTests, }: buildGoModule rec { pname = "litestream"; diff --git a/pkgs/by-name/li/litmus/package.nix b/pkgs/by-name/li/litmus/package.nix index 11068ea39fb7ce..2741576e5a0cfe 100644 --- a/pkgs/by-name/li/litmus/package.nix +++ b/pkgs/by-name/li/litmus/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, pkg-config -, expat -, libproxy -, neon -, zlib +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + pkg-config, + expat, + libproxy, + neon, + zlib, }: stdenv.mkDerivation rec { @@ -41,7 +42,10 @@ stdenv.mkDerivation rec { zlib ]; - autoreconfFlags = [ "-I" "neon/macros" ]; + autoreconfFlags = [ + "-I" + "neon/macros" + ]; meta = with lib; { description = "WebDAV server protocol compliance test suite"; @@ -52,4 +56,3 @@ stdenv.mkDerivation rec { mainProgram = "litmus"; }; } - diff --git a/pkgs/by-name/li/litmusctl/package.nix b/pkgs/by-name/li/litmusctl/package.nix index f7922663206a83..63c4151c12df58 100644 --- a/pkgs/by-name/li/litmusctl/package.nix +++ b/pkgs/by-name/li/litmusctl/package.nix @@ -1,8 +1,9 @@ -{ buildGoModule -, fetchFromGitHub -, installShellFiles -, kubectl -, lib +{ + buildGoModule, + fetchFromGitHub, + installShellFiles, + kubectl, + lib, }: buildGoModule rec { @@ -38,6 +39,9 @@ buildGoModule rec { homepage = "https://github.com/litmuschaos/litmusctl"; license = lib.licenses.asl20; mainProgram = "litmusctl"; - maintainers = with lib.maintainers; [ vinetos sailord ]; + maintainers = with lib.maintainers; [ + vinetos + sailord + ]; }; } diff --git a/pkgs/by-name/li/litterbox/package.nix b/pkgs/by-name/li/litterbox/package.nix index dcf6a3d0d12536..f5210ef13d3006 100644 --- a/pkgs/by-name/li/litterbox/package.nix +++ b/pkgs/by-name/li/litterbox/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, libressl, fetchzip, pkg-config, sqlite }: +{ + lib, + stdenv, + libressl, + fetchzip, + pkg-config, + sqlite, +}: stdenv.mkDerivation rec { pname = "litterbox"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { hash = "sha256-w4qW7J5CKm+hXHsNNbl9roBslHD14JOe0Nj5WntETqM="; }; - buildInputs = [ libressl sqlite ]; + buildInputs = [ + libressl + sqlite + ]; nativeBuildInputs = [ pkg-config ]; diff --git a/pkgs/by-name/li/little_boxes/package.nix b/pkgs/by-name/li/little_boxes/package.nix index ebc2da2e404ecb..7d9178af1469e0 100644 --- a/pkgs/by-name/li/little_boxes/package.nix +++ b/pkgs/by-name/li/little_boxes/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, testers -, little_boxes +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + testers, + little_boxes, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/li/littlefs-fuse/package.nix b/pkgs/by-name/li/littlefs-fuse/package.nix index f9a7693084917a..c54c103052bb48 100644 --- a/pkgs/by-name/li/littlefs-fuse/package.nix +++ b/pkgs/by-name/li/littlefs-fuse/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fuse }: +{ + lib, + stdenv, + fetchFromGitHub, + fuse, +}: stdenv.mkDerivation rec { pname = "littlefs-fuse"; diff --git a/pkgs/by-name/li/live555/package.nix b/pkgs/by-name/li/live555/package.nix index c558e806db9d3a..2b24804cb33a21 100644 --- a/pkgs/by-name/li/live555/package.nix +++ b/pkgs/by-name/li/live555/package.nix @@ -57,36 +57,45 @@ stdenv.mkDerivation (finalAttrs: { # required for whitespaces in makeFlags __structuredAttrs = true; - postPatch = '' - substituteInPlace config.macosx-catalina \ - --replace '/usr/lib/libssl.46.dylib' "${lib.getLib openssl}/lib/libssl.dylib" \ - --replace '/usr/lib/libcrypto.44.dylib' "${lib.getLib openssl}/lib/libcrypto.dylib" - sed -i -e 's|/bin/rm|rm|g' genMakefiles - sed -i \ - -e 's/$(INCLUDES) -I. -O2 -DSOCKLEN_T/$(INCLUDES) -I. -O2 -I. -fPIC -DRTSPCLIENT_SYNCHRONOUS_INTERFACE=1 -DSOCKLEN_T/g' \ - config.linux - '' - # condition from icu/base.nix - + lib.optionalString (lib.elem stdenv.hostPlatform.libc [ "glibc" "musl" ]) '' - substituteInPlace liveMedia/include/Locale.hh \ - --replace '' '' - ''; - - configurePhase = let - platform = - if stdenv.hostPlatform.isLinux then - "linux" - else if stdenv.hostPlatform.isDarwin then - "macosx-catalina" - else - throw "Unsupported platform: ${stdenv.hostPlatform.system}"; - in '' - runHook preConfigure - - ./genMakefiles ${platform} - - runHook postConfigure - ''; + postPatch = + '' + substituteInPlace config.macosx-catalina \ + --replace '/usr/lib/libssl.46.dylib' "${lib.getLib openssl}/lib/libssl.dylib" \ + --replace '/usr/lib/libcrypto.44.dylib' "${lib.getLib openssl}/lib/libcrypto.dylib" + sed -i -e 's|/bin/rm|rm|g' genMakefiles + sed -i \ + -e 's/$(INCLUDES) -I. -O2 -DSOCKLEN_T/$(INCLUDES) -I. -O2 -I. -fPIC -DRTSPCLIENT_SYNCHRONOUS_INTERFACE=1 -DSOCKLEN_T/g' \ + config.linux + '' + # condition from icu/base.nix + + + lib.optionalString + (lib.elem stdenv.hostPlatform.libc [ + "glibc" + "musl" + ]) + '' + substituteInPlace liveMedia/include/Locale.hh \ + --replace '' '' + ''; + + configurePhase = + let + platform = + if stdenv.hostPlatform.isLinux then + "linux" + else if stdenv.hostPlatform.isDarwin then + "macosx-catalina" + else + throw "Unsupported platform: ${stdenv.hostPlatform.system}"; + in + '' + runHook preConfigure + + ./genMakefiles ${platform} + + runHook postConfigure + ''; passthru.tests = { # Downstream dependency diff --git a/pkgs/by-name/li/livecaptions/package.nix b/pkgs/by-name/li/livecaptions/package.nix index 1dc03b3e5d85f1..f78390a8489d74 100644 --- a/pkgs/by-name/li/livecaptions/package.nix +++ b/pkgs/by-name/li/livecaptions/package.nix @@ -14,7 +14,8 @@ libadwaita, libpulseaudio, xorg, -}: let +}: +let aprilAsr = fetchFromGitHub { name = "april-asr"; owner = "abb128"; @@ -23,57 +24,57 @@ hash = "sha256-/cOZ2EcZu/Br9v0ComxnOegcEtlC9e8FYt3XHfah7mE="; }; in - stdenv.mkDerivation (finalAttrs: { - pname = "livecaptions"; - version = "0.4.2"; +stdenv.mkDerivation (finalAttrs: { + pname = "livecaptions"; + version = "0.4.2"; - src = fetchFromGitHub { - owner = "abb128"; - repo = "LiveCaptions"; - rev = "v${finalAttrs.version}"; - hash = "sha256-bLWJQgZopuQ0t2pexazUTj1+C2weRMrL3PUhIHZ0W5M="; - }; + src = fetchFromGitHub { + owner = "abb128"; + repo = "LiveCaptions"; + rev = "v${finalAttrs.version}"; + hash = "sha256-bLWJQgZopuQ0t2pexazUTj1+C2weRMrL3PUhIHZ0W5M="; + }; - model = fetchurl { - name = "april-english-dev-01110_en.april"; - url = "https://april.sapples.net/april-english-dev-01110_en.april"; - hash = "sha256-d+uV0PpPdwijfoaMImUwHubELcsl5jymPuo9nLrbwfM="; - }; + model = fetchurl { + name = "april-english-dev-01110_en.april"; + url = "https://april.sapples.net/april-english-dev-01110_en.april"; + hash = "sha256-d+uV0PpPdwijfoaMImUwHubELcsl5jymPuo9nLrbwfM="; + }; - nativeBuildInputs = [ - meson - ninja - pkg-config - cmake - appstream-glib # appstreamcli - desktop-file-utils # update-desktop-database - wrapGAppsHook4 - ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + cmake + appstream-glib # appstreamcli + desktop-file-utils # update-desktop-database + wrapGAppsHook4 + ]; - buildInputs = [ - onnxruntime - libadwaita - libpulseaudio - xorg.libX11 - ]; + buildInputs = [ + onnxruntime + libadwaita + libpulseaudio + xorg.libX11 + ]; - postUnpack = '' - rm -r source/subprojects/april-asr - ln -s ${aprilAsr} source/subprojects/april-asr - ''; + postUnpack = '' + rm -r source/subprojects/april-asr + ln -s ${aprilAsr} source/subprojects/april-asr + ''; - preFixup = '' - gappsWrapperArgs+=( - --set APRIL_MODEL_PATH ${finalAttrs.model} - ) - ''; + preFixup = '' + gappsWrapperArgs+=( + --set APRIL_MODEL_PATH ${finalAttrs.model} + ) + ''; - meta = with lib; { - description = "Linux Desktop application that provides live captioning"; - homepage = "https://github.com/abb128/LiveCaptions"; - license = licenses.gpl3Plus; - platforms = platforms.linux; - maintainers = with maintainers; [Scrumplex]; - mainProgram = "livecaptions"; - }; - }) + meta = with lib; { + description = "Linux Desktop application that provides live captioning"; + homepage = "https://github.com/abb128/LiveCaptions"; + license = licenses.gpl3Plus; + platforms = platforms.linux; + maintainers = with maintainers; [ Scrumplex ]; + mainProgram = "livecaptions"; + }; +}) diff --git a/pkgs/by-name/li/livedl/package.nix b/pkgs/by-name/li/livedl/package.nix index 9a3b4c3fd1f68d..1034cad36ede26 100644 --- a/pkgs/by-name/li/livedl/package.nix +++ b/pkgs/by-name/li/livedl/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, stdenv }: +{ + lib, + buildGoModule, + fetchFromGitHub, + stdenv, +}: buildGoModule rec { pname = "livedl"; diff --git a/pkgs/by-name/li/livekit-cli/package.nix b/pkgs/by-name/li/livekit-cli/package.nix index 777d71a987d202..ea9716c6fd7056 100644 --- a/pkgs/by-name/li/livekit-cli/package.nix +++ b/pkgs/by-name/li/livekit-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/li/livekit/package.nix b/pkgs/by-name/li/livekit/package.nix index a477069c6e3408..3bfc888390a5ec 100644 --- a/pkgs/by-name/li/livekit/package.nix +++ b/pkgs/by-name/li/livekit/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/li/livi/package.nix b/pkgs/by-name/li/livi/package.nix index daa6084989a44a..8abe03548baa60 100644 --- a/pkgs/by-name/li/livi/package.nix +++ b/pkgs/by-name/li/livi/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, gst_all_1 -, wrapGAppsHook4 -, appstream-glib -, gtk4 -, libadwaita -, desktop-file-utils -, libGL +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + gst_all_1, + wrapGAppsHook4, + appstream-glib, + gtk4, + libadwaita, + desktop-file-utils, + libGL, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/li/lizardfs/package.nix b/pkgs/by-name/li/lizardfs/package.nix index 2765da37189fb2..533ad1d0eb503c 100644 --- a/pkgs/by-name/li/lizardfs/package.nix +++ b/pkgs/by-name/li/lizardfs/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, makeWrapper -, python3 -, db -, fuse -, asciidoc -, libxml2 -, libxslt -, docbook_xml_dtd_412 -, docbook_xsl -, boost -, pkg-config -, judy -, pam -, spdlog -, systemdMinimal -, zlib # optional +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + makeWrapper, + python3, + db, + fuse, + asciidoc, + libxml2, + libxslt, + docbook_xml_dtd_412, + docbook_xsl, + boost, + pkg-config, + judy, + pam, + spdlog, + systemdMinimal, + zlib, # optional }: stdenv.mkDerivation rec { @@ -31,11 +32,27 @@ stdenv.mkDerivation rec { sha256 = "sha256-rgaFhJvmA1RVDL4+vQLMC0GrdlgUlvJeZ5/JJ67C20Q="; }; - nativeBuildInputs = [ cmake pkg-config makeWrapper ]; + nativeBuildInputs = [ + cmake + pkg-config + makeWrapper + ]; buildInputs = [ - db fuse asciidoc libxml2 libxslt docbook_xml_dtd_412 docbook_xsl - zlib boost judy pam spdlog python3 systemdMinimal + db + fuse + asciidoc + libxml2 + libxslt + docbook_xml_dtd_412 + docbook_xsl + zlib + boost + judy + pam + spdlog + python3 + systemdMinimal ]; meta = with lib; { @@ -43,7 +60,10 @@ stdenv.mkDerivation rec { description = "Highly reliable, scalable and efficient distributed file system"; platforms = platforms.linux; license = licenses.gpl3; - maintainers = with maintainers; [ rushmorem shamilton ]; + maintainers = with maintainers; [ + rushmorem + shamilton + ]; # 'fprintf' was not declared in this scope broken = true; }; diff --git a/pkgs/by-name/lk/lk-jwt-service/package.nix b/pkgs/by-name/lk/lk-jwt-service/package.nix index 42e4441c6a1177..78ea0a5d9af434 100644 --- a/pkgs/by-name/lk/lk-jwt-service/package.nix +++ b/pkgs/by-name/lk/lk-jwt-service/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/lk/lklug-sinhala/package.nix b/pkgs/by-name/lk/lklug-sinhala/package.nix index 817dbbb25312ab..de313a2ca75642 100644 --- a/pkgs/by-name/lk/lklug-sinhala/package.nix +++ b/pkgs/by-name/lk/lklug-sinhala/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "lklug-sinhala"; diff --git a/pkgs/by-name/lk/lkproof/package.nix b/pkgs/by-name/lk/lkproof/package.nix index 6b866b43d1b968..88b70bb29d6b5f 100644 --- a/pkgs/by-name/lk/lkproof/package.nix +++ b/pkgs/by-name/lk/lkproof/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, unzip}: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation { pname = "lkproof"; diff --git a/pkgs/by-name/lk/lksctp-tools/package.nix b/pkgs/by-name/lk/lksctp-tools/package.nix index de370c5b5c85ec..8958dff70378e9 100644 --- a/pkgs/by-name/lk/lksctp-tools/package.nix +++ b/pkgs/by-name/lk/lksctp-tools/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "lksctp-tools"; @@ -18,7 +23,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Linux Kernel Stream Control Transmission Protocol Tools"; homepage = "https://github.com/sctp/lksctp-tools/wiki"; - license = with licenses; [ gpl2Plus lgpl21 ]; # library is lgpl21 + license = with licenses; [ + gpl2Plus + lgpl21 + ]; # library is lgpl21 platforms = platforms.linux; }; } diff --git a/pkgs/by-name/ll/llama-cpp/package.nix b/pkgs/by-name/ll/llama-cpp/package.nix index 77c10a84637f46..4b775e8a0f2acb 100644 --- a/pkgs/by-name/ll/llama-cpp/package.nix +++ b/pkgs/by-name/ll/llama-cpp/package.nix @@ -1,33 +1,40 @@ -{ lib -, autoAddDriverRunpath -, cmake -, darwin -, fetchFromGitHub -, nix-update-script -, stdenv - -, config -, cudaSupport ? config.cudaSupport -, cudaPackages ? { } - -, rocmSupport ? config.rocmSupport -, rocmPackages ? { } - -, openclSupport ? false -, clblast - -, blasSupport ? builtins.all (x: !x) [ cudaSupport metalSupport openclSupport rocmSupport vulkanSupport ] -, blas - -, pkg-config -, metalSupport ? stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 && !openclSupport -, vulkanSupport ? false -, rpcSupport ? false -, shaderc -, vulkan-headers -, vulkan-loader -, ninja -, git +{ + lib, + autoAddDriverRunpath, + cmake, + darwin, + fetchFromGitHub, + nix-update-script, + stdenv, + + config, + cudaSupport ? config.cudaSupport, + cudaPackages ? { }, + + rocmSupport ? config.rocmSupport, + rocmPackages ? { }, + + openclSupport ? false, + clblast, + + blasSupport ? builtins.all (x: !x) [ + cudaSupport + metalSupport + openclSupport + rocmSupport + vulkanSupport + ], + blas, + + pkg-config, + metalSupport ? stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 && !openclSupport, + vulkanSupport ? false, + rpcSupport ? false, + shaderc, + vulkan-headers, + vulkan-loader, + ninja, + git, }: let @@ -35,7 +42,12 @@ let # otherwise we get libstdc++ errors downstream. # cuda imposes an upper bound on the gcc version, e.g. the latest gcc compatible with cudaPackages_11 is gcc11 effectiveStdenv = if cudaSupport then cudaPackages.backendStdenv else stdenv; - inherit (lib) cmakeBool cmakeFeature optionals optionalString; + inherit (lib) + cmakeBool + cmakeFeature + optionals + optionalString + ; darwinBuildInputs = with darwin.apple_sdk.frameworks; @@ -46,7 +58,7 @@ let ] ++ optionals metalSupport [ MetalKit ]; - cudaBuildInputs = with cudaPackages; [ + cudaBuildInputs = with cudaPackages; [ cuda_cccl # # A temporary hack for reducing the closure size, remove once cudaPackages @@ -100,67 +112,81 @@ effectiveStdenv.mkDerivation (finalAttrs: { --replace-fail 'build_commit="unknown"' "build_commit=\"$(cat COMMIT)\"" ''; - nativeBuildInputs = [ cmake ninja pkg-config git ] + nativeBuildInputs = + [ + cmake + ninja + pkg-config + git + ] ++ optionals cudaSupport [ - cudaPackages.cuda_nvcc - autoAddDriverRunpath - ]; + cudaPackages.cuda_nvcc + autoAddDriverRunpath + ]; - buildInputs = optionals effectiveStdenv.hostPlatform.isDarwin darwinBuildInputs + buildInputs = + optionals effectiveStdenv.hostPlatform.isDarwin darwinBuildInputs ++ optionals cudaSupport cudaBuildInputs ++ optionals openclSupport [ clblast ] ++ optionals rocmSupport rocmBuildInputs ++ optionals blasSupport [ blas ] ++ optionals vulkanSupport vulkanBuildInputs; - cmakeFlags = [ - # -march=native is non-deterministic; override with platform-specific flags if needed - (cmakeBool "GGML_NATIVE" false) - (cmakeBool "LLAMA_BUILD_SERVER" true) - (cmakeBool "BUILD_SHARED_LIBS" true) - (cmakeBool "GGML_BLAS" blasSupport) - (cmakeBool "GGML_CLBLAST" openclSupport) - (cmakeBool "GGML_CUDA" cudaSupport) - (cmakeBool "GGML_HIPBLAS" rocmSupport) - (cmakeBool "GGML_METAL" metalSupport) - (cmakeBool "GGML_RPC" rpcSupport) - (cmakeBool "GGML_VULKAN" vulkanSupport) - ] - ++ optionals cudaSupport [ - (cmakeFeature "CMAKE_CUDA_ARCHITECTURES" cudaPackages.flags.cmakeCudaArchitecturesString) - ] - ++ optionals rocmSupport [ - (cmakeFeature "CMAKE_C_COMPILER" "hipcc") - (cmakeFeature "CMAKE_CXX_COMPILER" "hipcc") - - # Build all targets supported by rocBLAS. When updating search for TARGET_LIST_ROCM - # in https://github.com/ROCmSoftwarePlatform/rocBLAS/blob/develop/CMakeLists.txt - # and select the line that matches the current nixpkgs version of rocBLAS. - # Should likely use `rocmPackages.clr.gpuTargets`. - "-DAMDGPU_TARGETS=gfx803;gfx900;gfx906:xnack-;gfx908:xnack-;gfx90a:xnack+;gfx90a:xnack-;gfx940;gfx941;gfx942;gfx1010;gfx1012;gfx1030;gfx1100;gfx1101;gfx1102" - ] - ++ optionals metalSupport [ - (cmakeFeature "CMAKE_C_FLAGS" "-D__ARM_FEATURE_DOTPROD=1") - (cmakeBool "LLAMA_METAL_EMBED_LIBRARY" true) - ] ++ optionals rpcSupport [ - # This is done so we can move rpc-server out of bin because llama.cpp doesn't - # install rpc-server in their install target. - "-DCMAKE_SKIP_BUILD_RPATH=ON" - ]; + cmakeFlags = + [ + # -march=native is non-deterministic; override with platform-specific flags if needed + (cmakeBool "GGML_NATIVE" false) + (cmakeBool "LLAMA_BUILD_SERVER" true) + (cmakeBool "BUILD_SHARED_LIBS" true) + (cmakeBool "GGML_BLAS" blasSupport) + (cmakeBool "GGML_CLBLAST" openclSupport) + (cmakeBool "GGML_CUDA" cudaSupport) + (cmakeBool "GGML_HIPBLAS" rocmSupport) + (cmakeBool "GGML_METAL" metalSupport) + (cmakeBool "GGML_RPC" rpcSupport) + (cmakeBool "GGML_VULKAN" vulkanSupport) + ] + ++ optionals cudaSupport [ + (cmakeFeature "CMAKE_CUDA_ARCHITECTURES" cudaPackages.flags.cmakeCudaArchitecturesString) + ] + ++ optionals rocmSupport [ + (cmakeFeature "CMAKE_C_COMPILER" "hipcc") + (cmakeFeature "CMAKE_CXX_COMPILER" "hipcc") + + # Build all targets supported by rocBLAS. When updating search for TARGET_LIST_ROCM + # in https://github.com/ROCmSoftwarePlatform/rocBLAS/blob/develop/CMakeLists.txt + # and select the line that matches the current nixpkgs version of rocBLAS. + # Should likely use `rocmPackages.clr.gpuTargets`. + "-DAMDGPU_TARGETS=gfx803;gfx900;gfx906:xnack-;gfx908:xnack-;gfx90a:xnack+;gfx90a:xnack-;gfx940;gfx941;gfx942;gfx1010;gfx1012;gfx1030;gfx1100;gfx1101;gfx1102" + ] + ++ optionals metalSupport [ + (cmakeFeature "CMAKE_C_FLAGS" "-D__ARM_FEATURE_DOTPROD=1") + (cmakeBool "LLAMA_METAL_EMBED_LIBRARY" true) + ] + ++ optionals rpcSupport [ + # This is done so we can move rpc-server out of bin because llama.cpp doesn't + # install rpc-server in their install target. + "-DCMAKE_SKIP_BUILD_RPATH=ON" + ]; # upstream plans on adding targets at the cmakelevel, remove those # additional steps after that - postInstall = '' - # Match previous binary name for this package - ln -sf $out/bin/llama-cli $out/bin/llama + postInstall = + '' + # Match previous binary name for this package + ln -sf $out/bin/llama-cli $out/bin/llama - mkdir -p $out/include - cp $src/include/llama.h $out/include/ - '' + optionalString rpcSupport "cp bin/rpc-server $out/bin/llama-rpc-server"; + mkdir -p $out/include + cp $src/include/llama.h $out/include/ + '' + + optionalString rpcSupport "cp bin/rpc-server $out/bin/llama-rpc-server"; passthru.updateScript = nix-update-script { attrPath = "llama-cpp"; - extraArgs = [ "--version-regex" "b(.*)" ]; + extraArgs = [ + "--version-regex" + "b(.*)" + ]; }; meta = with lib; { @@ -168,7 +194,12 @@ effectiveStdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/ggerganov/llama.cpp/"; license = licenses.mit; mainProgram = "llama"; - maintainers = with maintainers; [ dit7ya elohmeier philiptaron xddxdd ]; + maintainers = with maintainers; [ + dit7ya + elohmeier + philiptaron + xddxdd + ]; platforms = platforms.unix; badPlatforms = optionals (cudaSupport || openclSupport) lib.platforms.darwin; broken = (metalSupport && !effectiveStdenv.hostPlatform.isDarwin); diff --git a/pkgs/by-name/ll/lldap-cli/package.nix b/pkgs/by-name/ll/lldap-cli/package.nix index 6bec2c2426627c..737ecded6f8c60 100644 --- a/pkgs/by-name/ll/lldap-cli/package.nix +++ b/pkgs/by-name/ll/lldap-cli/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, bash -, coreutils -, gnugrep -, gnused -, jq -, curl -, makeWrapper +{ + stdenv, + lib, + fetchFromGitHub, + bash, + coreutils, + gnugrep, + gnused, + jq, + curl, + makeWrapper, }: stdenv.mkDerivation { pname = "lldap-cli"; @@ -38,7 +39,16 @@ stdenv.mkDerivation { installPhase = '' install -Dm555 lldap-cli -t $out/bin wrapProgram $out/bin/lldap-cli \ - --prefix PATH : ${lib.makeBinPath [ bash coreutils gnugrep gnused jq curl ]} + --prefix PATH : ${ + lib.makeBinPath [ + bash + coreutils + gnugrep + gnused + jq + curl + ] + } ''; meta = { diff --git a/pkgs/by-name/ll/llhttp/package.nix b/pkgs/by-name/ll/llhttp/package.nix index dfdd8200b5565c..2b2e55df913bb6 100644 --- a/pkgs/by-name/ll/llhttp/package.nix +++ b/pkgs/by-name/ll/llhttp/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, testers, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + testers, + python3, +}: stdenv.mkDerivation (finalAttrs: { pname = "llhttp"; @@ -11,7 +18,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-cnEp7Ds32bqu3jeUU/rqJOr/VW3KNmJU4pmNNaTpXRs="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake diff --git a/pkgs/by-name/ll/llm-ls/package.nix b/pkgs/by-name/ll/llm-ls/package.nix index c7a0aec58a2283..327b3ab49ada07 100644 --- a/pkgs/by-name/ll/llm-ls/package.nix +++ b/pkgs/by-name/ll/llm-ls/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, fetchpatch -, pkg-config -, libiconv -, darwin -, testers -, llm-ls +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + fetchpatch, + pkg-config, + libiconv, + darwin, + testers, + llm-ls, }: let @@ -40,11 +41,13 @@ rustPlatform.buildRustPackage { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - libiconv - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + libiconv + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; passthru.tests.version = testers.testVersion { package = llm-ls; diff --git a/pkgs/by-name/ll/llpp/package.nix b/pkgs/by-name/ll/llpp/package.nix index ff5d34e8224a1a..a377f68551e876 100644 --- a/pkgs/by-name/ll/llpp/package.nix +++ b/pkgs/by-name/ll/llpp/package.nix @@ -1,25 +1,26 @@ -{ stdenv -, lib -, makeWrapper -, fetchFromGitHub -, ocaml -, pkg-config -, mupdf -, libX11 -, jbig2dec -, openjpeg -, libjpeg -, lcms2 -, harfbuzz -, libGLU -, libGL -, gumbo -, freetype -, zlib -, xclip -, inotify-tools -, procps -, darwin +{ + stdenv, + lib, + makeWrapper, + fetchFromGitHub, + ocaml, + pkg-config, + mupdf, + libX11, + jbig2dec, + openjpeg, + libjpeg, + lcms2, + harfbuzz, + libGLU, + libGL, + gumbo, + freetype, + zlib, + xclip, + inotify-tools, + procps, + darwin, }: assert lib.versionAtLeast (lib.getVersion ocaml) "4.07"; @@ -41,10 +42,32 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ makeWrapper ocaml pkg-config ]; - buildInputs = [ mupdf libX11 freetype zlib gumbo jbig2dec openjpeg libjpeg lcms2 harfbuzz ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libGLU libGL ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.OpenGL darwin.apple_sdk.frameworks.Cocoa ]; + nativeBuildInputs = [ + makeWrapper + ocaml + pkg-config + ]; + buildInputs = + [ + mupdf + libX11 + freetype + zlib + gumbo + jbig2dec + openjpeg + libjpeg + lcms2 + harfbuzz + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libGLU + libGL + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.OpenGL + darwin.apple_sdk.frameworks.Cocoa + ]; dontStrip = true; @@ -52,26 +75,31 @@ stdenv.mkDerivation rec { bash ./build.bash build ''; - installPhase = '' - install -d $out/bin - install build/llpp $out/bin - install misc/llpp.inotify $out/bin/llpp.inotify - install -Dm444 misc/llpp.desktop -t $out/share/applications - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - wrapProgram $out/bin/llpp \ - --prefix PATH ":" "${xclip}/bin" + installPhase = + '' + install -d $out/bin + install build/llpp $out/bin + install misc/llpp.inotify $out/bin/llpp.inotify + install -Dm444 misc/llpp.desktop -t $out/share/applications + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + wrapProgram $out/bin/llpp \ + --prefix PATH ":" "${xclip}/bin" - wrapProgram $out/bin/llpp.inotify \ - --prefix PATH ":" "$out/bin" \ - --prefix PATH ":" "${inotify-tools}/bin" \ - --prefix PATH ":" "${procps}/bin" - ''; + wrapProgram $out/bin/llpp.inotify \ + --prefix PATH ":" "$out/bin" \ + --prefix PATH ":" "${inotify-tools}/bin" \ + --prefix PATH ":" "${procps}/bin" + ''; meta = with lib; { homepage = "https://github.com/criticic/llpp"; description = "MuPDF based PDF pager written in OCaml"; platforms = platforms.linux ++ platforms.darwin; maintainers = with maintainers; [ pSub ]; - license = [ licenses.publicDomain licenses.bsd3 ]; + license = [ + licenses.publicDomain + licenses.bsd3 + ]; }; } diff --git a/pkgs/by-name/lm/lm_sensors/package.nix b/pkgs/by-name/lm/lm_sensors/package.nix index 9b37b7c7e63e9f..59cb3147754654 100644 --- a/pkgs/by-name/lm/lm_sensors/package.nix +++ b/pkgs/by-name/lm/lm_sensors/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, bash -, bison -, flex -, which -, perl -, sensord ? false -, rrdtool ? null +{ + lib, + stdenv, + fetchFromGitHub, + bash, + bison, + flex, + which, + perl, + sensord ? false, + rrdtool ? null, }: assert sensord -> rrdtool != null; @@ -31,10 +32,16 @@ stdenv.mkDerivation rec { substituteInPlace prog/sensors/Module.mk --replace 'lib/$(LIBSHBASENAME)' "" ''; - nativeBuildInputs = [ bison flex which ]; + nativeBuildInputs = [ + bison + flex + which + ]; # bash is required for correctly replacing the shebangs in all tools for cross-compilation. - buildInputs = [ bash perl ] - ++ lib.optional sensord rrdtool; + buildInputs = [ + bash + perl + ] ++ lib.optional sensord rrdtool; makeFlags = [ "PREFIX=${placeholder "out"}" @@ -48,18 +55,23 @@ stdenv.mkDerivation rec { # Making regexp to patch-out installing of .so symlinks from Makefile is # complicated, it is easier to remove them post-install. - postInstall = '' - mkdir -p $out/share/doc/${pname} - cp -r configs doc/* $out/share/doc/${pname} - '' + lib.optionalString stdenv.hostPlatform.isStatic '' - rm $out/lib/*.so* - ''; + postInstall = + '' + mkdir -p $out/share/doc/${pname} + cp -r configs doc/* $out/share/doc/${pname} + '' + + lib.optionalString stdenv.hostPlatform.isStatic '' + rm $out/lib/*.so* + ''; meta = with lib; { homepage = "https://hwmon.wiki.kernel.org/lm_sensors"; changelog = "https://raw.githubusercontent.com/lm-sensors/lm-sensors/V${dashedVersion}/CHANGES"; description = "Tools for reading hardware sensors"; - license = with licenses; [ lgpl21Plus gpl2Plus ]; + license = with licenses; [ + lgpl21Plus + gpl2Plus + ]; maintainers = with maintainers; [ pmy ]; platforms = platforms.linux; mainProgram = "sensors"; diff --git a/pkgs/by-name/lm/lmdb/package.nix b/pkgs/by-name/lm/lmdb/package.nix index 69100b9dffd622..e7ec894cf95beb 100644 --- a/pkgs/by-name/lm/lmdb/package.nix +++ b/pkgs/by-name/lm/lmdb/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, windows }: +{ + lib, + stdenv, + fetchFromGitLab, + windows, +}: stdenv.mkDerivation rec { pname = "lmdb"; @@ -14,7 +19,10 @@ stdenv.mkDerivation rec { postUnpack = "sourceRoot=\${sourceRoot}/libraries/liblmdb"; - patches = [ ./hardcoded-compiler.patch ./bin-ext.patch ]; + patches = [ + ./hardcoded-compiler.patch + ./bin-ext.patch + ]; patchFlags = [ "-p3" ]; # Don't attempt the .so if static, as it would fail. @@ -22,39 +30,48 @@ stdenv.mkDerivation rec { sed 's/^ILIBS\>.*/ILIBS = liblmdb.a/' -i Makefile ''; - outputs = [ "bin" "out" "dev" ]; + outputs = [ + "bin" + "out" + "dev" + ]; buildInputs = lib.optional stdenv.hostPlatform.isWindows windows.pthreads; - makeFlags = [ - "prefix=$(out)" - "CC=${stdenv.cc.targetPrefix}cc" - "AR=${stdenv.cc.targetPrefix}ar" - ] + makeFlags = + [ + "prefix=$(out)" + "CC=${stdenv.cc.targetPrefix}cc" + "AR=${stdenv.cc.targetPrefix}ar" + ] ++ lib.optional stdenv.hostPlatform.isDarwin "LDFLAGS=-Wl,-install_name,$(out)/lib/liblmdb.so" - ++ lib.optionals stdenv.hostPlatform.isWindows [ "SOEXT=.dll" "BINEXT=.exe" ]; + ++ lib.optionals stdenv.hostPlatform.isWindows [ + "SOEXT=.dll" + "BINEXT=.exe" + ]; doCheck = true; checkTarget = "test"; - postInstall = '' - moveToOutput bin "$bin" - '' + postInstall = + '' + moveToOutput bin "$bin" + '' # add lmdb.pc (dynamic only) + '' - mkdir -p "$dev/lib/pkgconfig" - cat > "$dev/lib/pkgconfig/lmdb.pc" < "$dev/lib/pkgconfig/lmdb.pc" <> src/man_db.conf.in ''; - configureFlags = [ - "--disable-setuid" - "--disable-cache-owner" - "--localstatedir=/var" - "--with-config-file=${placeholder "out"}/etc/man_db.conf" - "--with-systemdtmpfilesdir=${placeholder "out"}/lib/tmpfiles.d" - "--with-systemdsystemunitdir=${placeholder "out"}/lib/systemd/system" - "--with-pager=less" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "ac_cv_func__set_invalid_parameter_handler=no" - "ac_cv_func_posix_fadvise=no" - "ac_cv_func_mempcpy=no" - ] ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ - "--enable-mandirs=" - ]; + configureFlags = + [ + "--disable-setuid" + "--disable-cache-owner" + "--localstatedir=/var" + "--with-config-file=${placeholder "out"}/etc/man_db.conf" + "--with-systemdtmpfilesdir=${placeholder "out"}/lib/tmpfiles.d" + "--with-systemdsystemunitdir=${placeholder "out"}/lib/systemd/system" + "--with-pager=less" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "ac_cv_func__set_invalid_parameter_handler=no" + "ac_cv_func_posix_fadvise=no" + "ac_cv_func_mempcpy=no" + ] + ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ + "--enable-mandirs=" + ]; preConfigure = '' configureFlagsArray+=("--with-sections=1 n l 8 3 0 2 5 4 9 6 7") @@ -76,7 +94,13 @@ stdenv.mkDerivation rec { # make sure that we don't wrap symlinks (since that changes argv[0] to the -wrapped name) find "$out/bin" -type f | while read file; do wrapProgram "$file" \ - --prefix PATH : "${lib.makeBinPath [ groff gzip zstd ]}" + --prefix PATH : "${ + lib.makeBinPath [ + groff + gzip + zstd + ] + }" done ''; @@ -86,7 +110,9 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - doCheck = !stdenv.hostPlatform.isMusl /* iconv binary */; + doCheck = + !stdenv.hostPlatform.isMusl # iconv binary + ; passthru.tests = { nixos = nixosTests.man; diff --git a/pkgs/by-name/ma/man-pages-posix/package.nix b/pkgs/by-name/ma/man-pages-posix/package.nix index 1d9ddda377b9af..e2ed0b4be923bc 100644 --- a/pkgs/by-name/ma/man-pages-posix/package.nix +++ b/pkgs/by-name/ma/man-pages-posix/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: let year = "2017"; diff --git a/pkgs/by-name/ma/man-pages/package.nix b/pkgs/by-name/ma/man-pages/package.nix index b6b891ac462ae5..9154a47594200a 100644 --- a/pkgs/by-name/ma/man-pages/package.nix +++ b/pkgs/by-name/ma/man-pages/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "man-pages"; diff --git a/pkgs/by-name/ma/mandoc/package.nix b/pkgs/by-name/ma/mandoc/package.nix index b61ea7f3e9f576..d084f5084eafd9 100644 --- a/pkgs/by-name/ma/mandoc/package.nix +++ b/pkgs/by-name/ma/mandoc/package.nix @@ -1,13 +1,17 @@ -{ lib, stdenv, fetchurl, zlib, perl, nixosTests }: +{ + lib, + stdenv, + fetchurl, + zlib, + perl, + nixosTests, +}: let # Name of an UTF-8 locale _always_ present at runtime, used for UTF-8 support # (locale set by the user may differ). This would usually be C.UTF-8, but # darwin has no such locale. - utf8Locale = - if stdenv.hostPlatform.isDarwin - then "en_US.UTF-8" - else "C.UTF-8"; + utf8Locale = if stdenv.hostPlatform.isDarwin then "en_US.UTF-8" else "C.UTF-8"; in stdenv.mkDerivation rec { @@ -76,7 +80,10 @@ stdenv.mkDerivation rec { downloadPage = "http://mandoc.bsd.lv/snapshots/"; license = licenses.bsd3; platforms = platforms.all; - maintainers = with maintainers; [ ramkromberg sternenseemann ]; + maintainers = with maintainers; [ + ramkromberg + sternenseemann + ]; mainProgram = "man"; }; } diff --git a/pkgs/by-name/ma/mandown/package.nix b/pkgs/by-name/ma/mandown/package.nix index 65a7cdb196598e..a007ef0dd74d45 100644 --- a/pkgs/by-name/ma/mandown/package.nix +++ b/pkgs/by-name/ma/mandown/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "mandown"; @@ -14,7 +18,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Markdown to groff (man page) converter"; homepage = "https://gitlab.com/kornelski/mandown"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = [ ]; mainProgram = "mandown"; }; diff --git a/pkgs/by-name/ma/manga-cli/package.nix b/pkgs/by-name/ma/manga-cli/package.nix index 65d45cf60e3c07..9319628ae253fc 100644 --- a/pkgs/by-name/ma/manga-cli/package.nix +++ b/pkgs/by-name/ma/manga-cli/package.nix @@ -1,9 +1,10 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, makeWrapper -, img2pdf -, zathura +{ + stdenvNoCC, + lib, + fetchFromGitHub, + makeWrapper, + img2pdf, + zathura, }: stdenvNoCC.mkDerivation { @@ -25,7 +26,12 @@ stdenvNoCC.mkDerivation { install -Dm755 manga-cli $out/bin/manga-cli wrapProgram $out/bin/manga-cli \ - --prefix PATH : ${lib.makeBinPath [ img2pdf zathura ]} + --prefix PATH : ${ + lib.makeBinPath [ + img2pdf + zathura + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/ma/mani/package.nix b/pkgs/by-name/ma/mani/package.nix index add490154d66c5..44be4bc8c34f6d 100644 --- a/pkgs/by-name/ma/mani/package.nix +++ b/pkgs/by-name/ma/mani/package.nix @@ -1,4 +1,11 @@ -{ buildGoModule, fetchFromGitHub, lib, installShellFiles, git, makeWrapper}: +{ + buildGoModule, + fetchFromGitHub, + lib, + installShellFiles, + git, + makeWrapper, +}: buildGoModule rec { pname = "mani"; @@ -13,9 +20,16 @@ buildGoModule rec { vendorHash = "sha256-mFan09oJ+BPVJHAxoROj282WJ+4e7TD0ZqeQH1kDabQ="; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; - ldflags = [ "-s" "-w" "-X github.com/alajmo/mani/cmd.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/alajmo/mani/cmd.version=${version}" + ]; postInstall = '' installShellCompletion --cmd mani \ diff --git a/pkgs/by-name/ma/manifest-tool/package.nix b/pkgs/by-name/ma/manifest-tool/package.nix index 134caea5ba464f..103f80aacbd5d1 100644 --- a/pkgs/by-name/ma/manifest-tool/package.nix +++ b/pkgs/by-name/ma/manifest-tool/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, git -, stdenv -, testers -, manifest-tool +{ + lib, + buildGoModule, + fetchFromGitHub, + git, + stdenv, + testers, + manifest-tool, }: buildGoModule rec { @@ -28,15 +29,17 @@ buildGoModule rec { nativeBuildInputs = [ git ]; - ldflags = [ - "-s" - "-w" - "-X main.version=${version}" - ] ++ lib.optionals stdenv.hostPlatform.isStatic [ - "-linkmode=external" - "-extldflags" - "-static" - ]; + ldflags = + [ + "-s" + "-w" + "-X main.version=${version}" + ] + ++ lib.optionals stdenv.hostPlatform.isStatic [ + "-linkmode=external" + "-extldflags" + "-static" + ]; preConfigure = '' export ldflags+=" -X main.gitCommit=$(cat .git-revision)" diff --git a/pkgs/by-name/ma/manix/package.nix b/pkgs/by-name/ma/manix/package.nix index bdf05833c73dfb..c3ea02a3e5b29c 100644 --- a/pkgs/by-name/ma/manix/package.nix +++ b/pkgs/by-name/ma/manix/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,10 @@ rustPlatform.buildRustPackage rec { description = "Fast CLI documentation searcher for Nix"; homepage = "https://github.com/nix-community/manix"; license = licenses.mpl20; - maintainers = with maintainers; [ iogamaster lecoqjacob ]; + maintainers = with maintainers; [ + iogamaster + lecoqjacob + ]; mainProgram = "manix"; }; } diff --git a/pkgs/by-name/ma/manrope/package.nix b/pkgs/by-name/ma/manrope/package.nix index 1bde4e869214ae..5835078e161436 100644 --- a/pkgs/by-name/ma/manrope/package.nix +++ b/pkgs/by-name/ma/manrope/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "manrope"; diff --git a/pkgs/by-name/ma/manticore/package.nix b/pkgs/by-name/ma/manticore/package.nix index d344ff4b726ee8..883acec4526a5f 100644 --- a/pkgs/by-name/ma/manticore/package.nix +++ b/pkgs/by-name/ma/manticore/package.nix @@ -1,8 +1,15 @@ -{ stdenv, fetchFromGitHub, coreutils, autoreconfHook, smlnj }: +{ + stdenv, + fetchFromGitHub, + coreutils, + autoreconfHook, + smlnj, +}: let rev = "7376cb20ba5285a6b076a73c821e4743809c1d9d"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "manticore"; version = "2019.12.03"; @@ -17,9 +24,15 @@ in stdenv.mkDerivation { nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ coreutils smlnj ]; + buildInputs = [ + coreutils + smlnj + ]; - autoreconfFlags = [ "-Iconfig" "-vfi" ]; + autoreconfFlags = [ + "-Iconfig" + "-vfi" + ]; unpackPhase = '' mkdir -p $out diff --git a/pkgs/by-name/ma/mantra/package.nix b/pkgs/by-name/ma/mantra/package.nix index 5a6b0074b46b1f..b48a36bd1b074e 100644 --- a/pkgs/by-name/ma/mantra/package.nix +++ b/pkgs/by-name/ma/mantra/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ma/map-cmd/package.nix b/pkgs/by-name/ma/map-cmd/package.nix index bd70971e0b1ec5..e11af51aa70f7f 100644 --- a/pkgs/by-name/ma/map-cmd/package.nix +++ b/pkgs/by-name/ma/map-cmd/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "map"; diff --git a/pkgs/by-name/ma/mapcidr/package.nix b/pkgs/by-name/ma/mapcidr/package.nix index 3c955c2d336b29..18378cf233d3b6 100644 --- a/pkgs/by-name/ma/mapcidr/package.nix +++ b/pkgs/by-name/ma/mapcidr/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ma/mapscii/package.nix b/pkgs/by-name/ma/mapscii/package.nix index 088e5bd4b5671c..1fb76d1b3f1c8b 100644 --- a/pkgs/by-name/ma/mapscii/package.nix +++ b/pkgs/by-name/ma/mapscii/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildNpmPackage +{ + lib, + fetchFromGitHub, + buildNpmPackage, }: buildNpmPackage rec { pname = "mapscii"; diff --git a/pkgs/by-name/ma/mar1d/package.nix b/pkgs/by-name/ma/mar1d/package.nix index 60e4d5ad355277..5494432ac91a8a 100644 --- a/pkgs/by-name/ma/mar1d/package.nix +++ b/pkgs/by-name/ma/mar1d/package.nix @@ -12,7 +12,7 @@ fetchpatch, }: -stdenv.mkDerivation (finalAttrs:{ +stdenv.mkDerivation (finalAttrs: { pname = "MAR1D"; version = "unstable-2023-02-02"; diff --git a/pkgs/by-name/ma/marathi-cursive/package.nix b/pkgs/by-name/ma/marathi-cursive/package.nix index 4da56b2251c5ad..8ab61de1f1d4f9 100644 --- a/pkgs/by-name/ma/marathi-cursive/package.nix +++ b/pkgs/by-name/ma/marathi-cursive/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "marathi-cursive"; diff --git a/pkgs/by-name/ma/marathonctl/package.nix b/pkgs/by-name/ma/marathonctl/package.nix index 85576b4f664025..3a1f344e53af8d 100644 --- a/pkgs/by-name/ma/marathonctl/package.nix +++ b/pkgs/by-name/ma/marathonctl/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "marathonctl"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-Oiol4KuPOyJq2Bfc5div+enX4kQqYn20itmwWBecuIg="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/shoenig/marathonctl"; diff --git a/pkgs/by-name/ma/marble-marcher-ce/package.nix b/pkgs/by-name/ma/marble-marcher-ce/package.nix index ee1422abc5b8e0..b1f0ffa98fd42b 100644 --- a/pkgs/by-name/ma/marble-marcher-ce/package.nix +++ b/pkgs/by-name/ma/marble-marcher-ce/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, fetchFromGitHub -, sfml -, anttweakbar -, glm -, eigen -, glew -, cmake +{ + lib, + stdenv, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + fetchFromGitHub, + sfml, + anttweakbar, + glm, + eigen, + glew, + cmake, }: stdenv.mkDerivation rec { pname = "marble-marcher-ce"; @@ -22,8 +23,18 @@ stdenv.mkDerivation rec { hash = "sha256-m5i/Q4k5S4wcojHqMYS7e1W/Ph7q/95j3oOK2xbrHSk="; }; - buildInputs = [ sfml anttweakbar glm eigen glew ]; - nativeBuildInputs = [ cmake makeWrapper copyDesktopItems ]; + buildInputs = [ + sfml + anttweakbar + glm + eigen + glew + ]; + nativeBuildInputs = [ + cmake + makeWrapper + copyDesktopItems + ]; installFlags = [ "DESTDIR=$(out)" ]; prePatch = '' diff --git a/pkgs/by-name/ma/marcel/package.nix b/pkgs/by-name/ma/marcel/package.nix index 790d38d466b1d2..1e3e1391f488c1 100644 --- a/pkgs/by-name/ma/marcel/package.nix +++ b/pkgs/by-name/ma/marcel/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3Packages -, bash +{ + lib, + fetchFromGitHub, + python3Packages, + bash, }: python3Packages.buildPythonApplication rec { @@ -36,7 +37,7 @@ python3Packages.buildPythonApplication rec { wrapProgram $out/bin/marcel \ --prefix PATH : "$program_PATH:${lib.getBin bash}/bin" \ --prefix PYTHONPATH : "$program_PYTHONPATH" - ''; + ''; meta = with lib; { description = "Modern shell"; diff --git a/pkgs/by-name/ma/marge-bot/package.nix b/pkgs/by-name/ma/marge-bot/package.nix index cdfc71bb46e4dd..e958ea990bd649 100644 --- a/pkgs/by-name/ma/marge-bot/package.nix +++ b/pkgs/by-name/ma/marge-bot/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitLab +{ + lib, + python3, + fetchFromGitLab, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ma/mari0/package.nix b/pkgs/by-name/ma/mari0/package.nix index f75fbedebd7da8..deb7d959bc1477 100644 --- a/pkgs/by-name/ma/mari0/package.nix +++ b/pkgs/by-name/ma/mari0/package.nix @@ -1,12 +1,13 @@ -{ lib -, copyDesktopItems -, fetchFromGitHub -, love -, makeDesktopItem -, makeWrapper -, stdenv -, strip-nondeterminism -, zip +{ + lib, + copyDesktopItems, + fetchFromGitHub, + love, + makeDesktopItem, + makeWrapper, + stdenv, + strip-nondeterminism, + zip, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ma/mariadb-connector-java/package.nix b/pkgs/by-name/ma/mariadb-connector-java/package.nix index 897d86d9708eca..6c9ab746309460 100644 --- a/pkgs/by-name/ma/mariadb-connector-java/package.nix +++ b/pkgs/by-name/ma/mariadb-connector-java/package.nix @@ -1,7 +1,8 @@ -{ lib -, maven -, fetchFromGitHub -, nix-update-script +{ + lib, + maven, + fetchFromGitHub, + nix-update-script, }: maven.buildMavenPackage rec { diff --git a/pkgs/by-name/ma/marisa/package.nix b/pkgs/by-name/ma/marisa/package.nix index 4a3f8be0417243..2ff016940d3051 100644 --- a/pkgs/by-name/ma/marisa/package.nix +++ b/pkgs/by-name/ma/marisa/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "marisa"; @@ -16,10 +21,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; meta = with lib; { - homepage = "https://github.com/s-yata/marisa-trie"; + homepage = "https://github.com/s-yata/marisa-trie"; description = "Static and space-efficient trie data structure library"; - license = licenses.bsd3; + license = licenses.bsd3; maintainers = with maintainers; [ sifmelcara ]; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/ma/mark/package.nix b/pkgs/by-name/ma/mark/package.nix index d274746c65320e..bff02f982b6291 100644 --- a/pkgs/by-name/ma/mark/package.nix +++ b/pkgs/by-name/ma/mark/package.nix @@ -1,19 +1,27 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "mark"; version = "11.3.0"; src = fetchFromGitHub { - owner = "kovetskiy"; - repo = "mark"; - rev = version; + owner = "kovetskiy"; + repo = "mark"; + rev = version; sha256 = "sha256-IppvQPcwix4TGxGW1iOVV60NfK4D53fZuFt5OvLrn/g="; }; vendorHash = "sha256-boXimID1tmZwa29rbTW5bqPz2KTnQAEAIG6d/6BPuWc="; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; checkFlags = let @@ -21,7 +29,8 @@ buildGoModule rec { # Expects to be able to launch google-chrome "TestExtractMermaidImage" ]; - in [ + in + [ "-skip=^${builtins.concatStringsSep "$|^" skippedTests}$" ]; diff --git a/pkgs/by-name/ma/markdown-anki-decks/package.nix b/pkgs/by-name/ma/markdown-anki-decks/package.nix index b8fbc37ae81e0b..69d53183abcec3 100644 --- a/pkgs/by-name/ma/markdown-anki-decks/package.nix +++ b/pkgs/by-name/ma/markdown-anki-decks/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ma/markdownlint-cli/package.nix b/pkgs/by-name/ma/markdownlint-cli/package.nix index 43650e583a0206..32eba5e1aa76b9 100644 --- a/pkgs/by-name/ma/markdownlint-cli/package.nix +++ b/pkgs/by-name/ma/markdownlint-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ma/marked-man/package.nix b/pkgs/by-name/ma/marked-man/package.nix index 6de1f49c4374af..ffbe51602c5a5a 100644 --- a/pkgs/by-name/ma/marked-man/package.nix +++ b/pkgs/by-name/ma/marked-man/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ma/marker/package.nix b/pkgs/by-name/ma/marker/package.nix index aea005d7d9065f..2a5165da2b3bae 100644 --- a/pkgs/by-name/ma/marker/package.nix +++ b/pkgs/by-name/ma/marker/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, itstool -, meson -, ninja -, pkg-config -, wrapGAppsHook3 -, gtk3 -, gtksourceview -, gtkspell3 -, webkitgtk_4_1 -, pandoc +{ + stdenv, + lib, + fetchFromGitHub, + itstool, + meson, + ninja, + pkg-config, + wrapGAppsHook3, + gtk3, + gtksourceview, + gtkspell3, + webkitgtk_4_1, + pandoc, }: stdenv.mkDerivation rec { @@ -48,7 +49,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://fabiocolacio.github.io/Marker/"; description = "Markdown editor for the Linux desktop made with GTK3"; - maintainers = with maintainers; [ trepetti aleksana ]; + maintainers = with maintainers; [ + trepetti + aleksana + ]; license = licenses.gpl3Plus; platforms = platforms.linux; changelog = "https://github.com/fabiocolacio/Marker/releases/tag/${version}"; diff --git a/pkgs/by-name/ma/markets/package.nix b/pkgs/by-name/ma/markets/package.nix index 5365dea34609b4..b06f5fa4fd322e 100644 --- a/pkgs/by-name/ma/markets/package.nix +++ b/pkgs/by-name/ma/markets/package.nix @@ -1,7 +1,22 @@ -{ lib, stdenv, fetchFromGitHub -, desktop-file-utils, glib, gtk3, meson, ninja, pkg-config, python3, vala -, wrapGAppsHook3 -, glib-networking, gobject-introspection, json-glib, libgee, libhandy, libsoup_2_4 +{ + lib, + stdenv, + fetchFromGitHub, + desktop-file-utils, + glib, + gtk3, + meson, + ninja, + pkg-config, + python3, + vala, + wrapGAppsHook3, + glib-networking, + gobject-introspection, + json-glib, + libgee, + libhandy, + libsoup_2_4, }: stdenv.mkDerivation rec { @@ -16,11 +31,24 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - desktop-file-utils glib gtk3 meson ninja pkg-config python3 vala - wrapGAppsHook3 gobject-introspection + desktop-file-utils + glib + gtk3 + meson + ninja + pkg-config + python3 + vala + wrapGAppsHook3 + gobject-introspection ]; buildInputs = [ - glib glib-networking gtk3 json-glib libgee libhandy + glib + glib-networking + gtk3 + json-glib + libgee + libhandy libsoup_2_4 ]; diff --git a/pkgs/by-name/ma/markscribe/package.nix b/pkgs/by-name/ma/markscribe/package.nix index c2ee3a596e9797..9dac443919f3f5 100644 --- a/pkgs/by-name/ma/markscribe/package.nix +++ b/pkgs/by-name/ma/markscribe/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-leeP2+W+bnYASls3k0l4jpz1rc1mAkMWUfrY2uBUUdQ="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Your personal markdown scribe with template-engine and Git(Hub) & RSS powers"; diff --git a/pkgs/by-name/ma/marl/package.nix b/pkgs/by-name/ma/marl/package.nix index 7ff28a9d5221f3..d4e796bc5fe686 100644 --- a/pkgs/by-name/ma/marl/package.nix +++ b/pkgs/by-name/ma/marl/package.nix @@ -1,8 +1,13 @@ -{ lib, stdenv, cmake, fetchFromGitHub }: +{ + lib, + stdenv, + cmake, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "marl"; - version = "1.0.0"; # Based on marl's CHANGES.md + version = "1.0.0"; # Based on marl's CHANGES.md src = fetchFromGitHub { owner = "google"; @@ -14,7 +19,7 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; # Turn on the flag to install after building the library. - cmakeFlags = ["-DMARL_INSTALL=ON"]; + cmakeFlags = [ "-DMARL_INSTALL=ON" ]; meta = with lib; { homepage = "https://github.com/google/marl"; diff --git a/pkgs/by-name/ma/marlin-calc/package.nix b/pkgs/by-name/ma/marlin-calc/package.nix index ec8e90631b54b7..7ad05f082d0c44 100644 --- a/pkgs/by-name/ma/marlin-calc/package.nix +++ b/pkgs/by-name/ma/marlin-calc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "marlin-calc"; diff --git a/pkgs/by-name/ma/mars-mips/package.nix b/pkgs/by-name/ma/mars-mips/package.nix index d5489e7e2537a8..3de083a98317af 100644 --- a/pkgs/by-name/ma/mars-mips/package.nix +++ b/pkgs/by-name/ma/mars-mips/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, makeBinaryWrapper -, copyDesktopItems -, makeDesktopItem -, desktopToDarwinBundle -, unzip -, imagemagick -, jre +{ + lib, + stdenv, + fetchurl, + makeBinaryWrapper, + copyDesktopItems, + makeDesktopItem, + desktopToDarwinBundle, + unzip, + imagemagick, + jre, }: stdenv.mkDerivation (finalAttrs: { @@ -15,20 +16,24 @@ stdenv.mkDerivation (finalAttrs: { version = "4.5"; src = fetchurl { - url = "https://courses.missouristate.edu/KenVollmar/MARS/MARS_${lib.replaceStrings ["."] ["_"] finalAttrs.version}_Aug2014/Mars${lib.replaceStrings ["."] ["_"] finalAttrs.version}.jar"; + url = "https://courses.missouristate.edu/KenVollmar/MARS/MARS_${ + lib.replaceStrings [ "." ] [ "_" ] finalAttrs.version + }_Aug2014/Mars${lib.replaceStrings [ "." ] [ "_" ] finalAttrs.version}.jar"; hash = "sha256-rDQLZ2uitiJGud935i+BrURHvP0ymrU5cWvNCZULcJY="; }; dontUnpack = true; - nativeBuildInputs = [ - makeBinaryWrapper - copyDesktopItems - unzip - imagemagick - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - desktopToDarwinBundle - ]; + nativeBuildInputs = + [ + makeBinaryWrapper + copyDesktopItems + unzip + imagemagick + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + desktopToDarwinBundle + ]; desktopItems = [ (makeDesktopItem { @@ -37,7 +42,10 @@ stdenv.mkDerivation (finalAttrs: { exec = "Mars"; icon = "mars"; comment = finalAttrs.meta.description; - categories = [ "Development" "IDE" ]; + categories = [ + "Development" + "IDE" + ]; }) ]; diff --git a/pkgs/by-name/ma/mars/package.nix b/pkgs/by-name/ma/mars/package.nix index c63152fb5445df..5742a01851cb75 100644 --- a/pkgs/by-name/ma/mars/package.nix +++ b/pkgs/by-name/ma/mars/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libGLU, libGL, sfml, fribidi, taglib }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libGLU, + libGL, + sfml, + fribidi, + taglib, +}: stdenv.mkDerivation rec { pname = "mars"; version = "unstable-17.10.2021"; @@ -10,7 +20,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-SWLP926SyVTjn+UT1DCaJSo4Ue0RbyzImVnlNJQksS0="; }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libGLU libGL sfml fribidi taglib ]; + buildInputs = [ + libGLU + libGL + sfml + fribidi + taglib + ]; installPhase = '' cd .. mkdir -p "$out/share/mars/" diff --git a/pkgs/by-name/ma/marst/package.nix b/pkgs/by-name/ma/marst/package.nix index f62181405b9ed5..b1f4fff0dd2aa6 100644 --- a/pkgs/by-name/ma/marst/package.nix +++ b/pkgs/by-name/ma/marst/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, texinfo +{ + lib, + stdenv, + fetchurl, + texinfo, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ma/martian-mono/package.nix b/pkgs/by-name/ma/martian-mono/package.nix index 4cfeb61cdac535..c6cf4cfb169845 100644 --- a/pkgs/by-name/ma/martian-mono/package.nix +++ b/pkgs/by-name/ma/martian-mono/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "martian-mono"; diff --git a/pkgs/by-name/ma/marwaita-icons/package.nix b/pkgs/by-name/ma/marwaita-icons/package.nix index 73c40ae4b257fb..b8cd39c7150f61 100644 --- a/pkgs/by-name/ma/marwaita-icons/package.nix +++ b/pkgs/by-name/ma/marwaita-icons/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gtk3 -, breeze-icons -, hicolor-icon-theme -, pantheon +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + breeze-icons, + hicolor-icon-theme, + pantheon, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/ma/marwaita-mint/package.nix b/pkgs/by-name/ma/marwaita-mint/package.nix index 91b4f45d82e20a..6ef068e211860f 100644 --- a/pkgs/by-name/ma/marwaita-mint/package.nix +++ b/pkgs/by-name/ma/marwaita-mint/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gitUpdater -, gdk-pixbuf -, gtk-engine-murrine -, gtk_engines -, librsvg +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gitUpdater, + gdk-pixbuf, + gtk-engine-murrine, + gtk_engines, + librsvg, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ma/marwaita-orange/package.nix b/pkgs/by-name/ma/marwaita-orange/package.nix index e12c9f501076cb..80bc17f448c7db 100644 --- a/pkgs/by-name/ma/marwaita-orange/package.nix +++ b/pkgs/by-name/ma/marwaita-orange/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, gdk-pixbuf -, gtk-engine-murrine -, gtk_engines -, librsvg -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + gdk-pixbuf, + gtk-engine-murrine, + gtk_engines, + librsvg, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ma/marwaita-red/package.nix b/pkgs/by-name/ma/marwaita-red/package.nix index bb807a534704fd..b9a805fd7d1c47 100644 --- a/pkgs/by-name/ma/marwaita-red/package.nix +++ b/pkgs/by-name/ma/marwaita-red/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, gdk-pixbuf -, gtk-engine-murrine -, gtk_engines -, librsvg -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + gdk-pixbuf, + gtk-engine-murrine, + gtk_engines, + librsvg, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ma/marwaita-teal/package.nix b/pkgs/by-name/ma/marwaita-teal/package.nix index b9d2b3f15a6b52..d587947db9a8ce 100644 --- a/pkgs/by-name/ma/marwaita-teal/package.nix +++ b/pkgs/by-name/ma/marwaita-teal/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, gdk-pixbuf -, gtk-engine-murrine -, gtk_engines -, librsvg -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + gdk-pixbuf, + gtk-engine-murrine, + gtk_engines, + librsvg, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ma/marwaita-x/package.nix b/pkgs/by-name/ma/marwaita-x/package.nix index 9c05736e84f66b..c150cfba92b362 100644 --- a/pkgs/by-name/ma/marwaita-x/package.nix +++ b/pkgs/by-name/ma/marwaita-x/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, nix-update-script -, gdk-pixbuf -, gtk-engine-murrine -, gtk_engines -, librsvg +{ + lib, + stdenvNoCC, + fetchFromGitHub, + nix-update-script, + gdk-pixbuf, + gtk-engine-murrine, + gtk_engines, + librsvg, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ma/marwaita-yellow/package.nix b/pkgs/by-name/ma/marwaita-yellow/package.nix index b363436c4b4a65..2b134621475375 100644 --- a/pkgs/by-name/ma/marwaita-yellow/package.nix +++ b/pkgs/by-name/ma/marwaita-yellow/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, gdk-pixbuf -, gtk-engine-murrine -, gtk_engines -, librsvg -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + gdk-pixbuf, + gtk-engine-murrine, + gtk_engines, + librsvg, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ma/marwaita/package.nix b/pkgs/by-name/ma/marwaita/package.nix index 48abc1573e159e..6698fe3a936269 100644 --- a/pkgs/by-name/ma/marwaita/package.nix +++ b/pkgs/by-name/ma/marwaita/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gdk-pixbuf -, gtk-engine-murrine -, gtk_engines -, librsvg -, gitUpdater +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gdk-pixbuf, + gtk-engine-murrine, + gtk_engines, + librsvg, + gitUpdater, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/ma/mas/package.nix b/pkgs/by-name/ma/mas/package.nix index 968cb10cd5a3b1..1926bf25474288 100644 --- a/pkgs/by-name/ma/mas/package.nix +++ b/pkgs/by-name/ma/mas/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, fetchurl -, installShellFiles -, testers -, mas +{ + lib, + stdenvNoCC, + fetchurl, + installShellFiles, + testers, + mas, }: stdenvNoCC.mkDerivation rec { @@ -35,7 +36,13 @@ stdenvNoCC.mkDerivation rec { description = "Mac App Store command line interface"; homepage = "https://github.com/mas-cli/mas"; license = licenses.mit; - maintainers = with maintainers; [ steinybot zachcoyle ]; - platforms = [ "x86_64-darwin" "aarch64-darwin" ]; + maintainers = with maintainers; [ + steinybot + zachcoyle + ]; + platforms = [ + "x86_64-darwin" + "aarch64-darwin" + ]; }; } diff --git a/pkgs/by-name/ma/mask/package.nix b/pkgs/by-name/ma/mask/package.nix index 78172cb932a9d0..11a7008927f872 100644 --- a/pkgs/by-name/ma/mask/package.nix +++ b/pkgs/by-name/ma/mask/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "mask"; diff --git a/pkgs/by-name/ma/masscan/package.nix b/pkgs/by-name/ma/masscan/package.nix index 9606fe0f1156ee..c067e1ac54dca9 100644 --- a/pkgs/by-name/ma/masscan/package.nix +++ b/pkgs/by-name/ma/masscan/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, installShellFiles -, makeWrapper -, libpcap +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + installShellFiles, + makeWrapper, + libpcap, }: stdenv.mkDerivation rec { @@ -32,7 +33,10 @@ stdenv.mkDerivation rec { substituteInPlace Makefile --replace "-pm755" "-pDm755" ''; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; makeFlags = [ "PREFIX=$(out)" diff --git a/pkgs/by-name/ma/massdns/package.nix b/pkgs/by-name/ma/massdns/package.nix index b47e162861ce54..1f6d19fcaeb20a 100644 --- a/pkgs/by-name/ma/massdns/package.nix +++ b/pkgs/by-name/ma/massdns/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, nix-update-script +{ + stdenv, + lib, + fetchFromGitHub, + nix-update-script, }: stdenv.mkDerivation rec { pname = "massdns"; diff --git a/pkgs/by-name/ma/massren/package.nix b/pkgs/by-name/ma/massren/package.nix index 0c33de89eecd1c..0ae0c0c332051a 100644 --- a/pkgs/by-name/ma/massren/package.nix +++ b/pkgs/by-name/ma/massren/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "massren"; @@ -21,7 +26,10 @@ buildGoModule rec { }) ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; checkFlags = let diff --git a/pkgs/by-name/ma/mastodon-archive/package.nix b/pkgs/by-name/ma/mastodon-archive/package.nix index 92498c529ca197..09bfc3c5eebdd1 100644 --- a/pkgs/by-name/ma/mastodon-archive/package.nix +++ b/pkgs/by-name/ma/mastodon-archive/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ma/mastotool/package.nix b/pkgs/by-name/ma/mastotool/package.nix index eb5e64573225ee..c14432ab819f9c 100644 --- a/pkgs/by-name/ma/mastotool/package.nix +++ b/pkgs/by-name/ma/mastotool/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-uQgLwH8Z8rBfyKHMm2JHO+H1gsHK25+c34bOnMcmquA="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Collection of command-line tools to work with your Mastodon account"; diff --git a/pkgs/by-name/ma/matcha-gtk-theme/package.nix b/pkgs/by-name/ma/matcha-gtk-theme/package.nix index f7c7960fe86e52..74d5dde06f25cb 100644 --- a/pkgs/by-name/ma/matcha-gtk-theme/package.nix +++ b/pkgs/by-name/ma/matcha-gtk-theme/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gdk-pixbuf -, gtk-engine-murrine -, jdupes -, librsvg -, gitUpdater -, colorVariants ? [] # default: all -, themeVariants ? [] # default: blue +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gdk-pixbuf, + gtk-engine-murrine, + jdupes, + librsvg, + gitUpdater, + colorVariants ? [ ], # default: all + themeVariants ? [ ], # default: blue }: let @@ -15,61 +16,65 @@ let in lib.checkListOfEnum "${pname}: color variants" [ "standard" "light" "dark" ] colorVariants -lib.checkListOfEnum "${pname}: theme variants" [ "aliz" "azul" "sea" "pueril" "all" ] themeVariants - -stdenvNoCC.mkDerivation rec { - inherit pname; - version = "2024-05-01"; - - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = version; - sha256 = "trQwRZ/JKIS8TcRIg0eL5GmB/yymDwqqNued0ddRuqU="; - }; - - nativeBuildInputs = [ - jdupes - ]; - - buildInputs = [ - gdk-pixbuf - librsvg - ]; - - propagatedUserEnvPkgs = [ - gtk-engine-murrine - ]; - - postPatch = '' - patchShebangs install.sh - ''; - - installPhase = '' - runHook preInstall - - mkdir -p $out/share/themes - - name= ./install.sh \ - ${lib.optionalString (colorVariants != []) "--color " + builtins.toString colorVariants} \ - ${lib.optionalString (themeVariants != []) "--theme " + builtins.toString themeVariants} \ - --dest $out/share/themes - - mkdir -p $out/share/doc/${pname} - cp -a src/extra/firefox $out/share/doc/${pname} - - jdupes --quiet --link-soft --recurse $out/share - - runHook postInstall - ''; - - passthru.updateScript = gitUpdater { }; - - meta = with lib; { - description = "Stylish flat Design theme for GTK based desktop environments"; - homepage = "https://vinceliuice.github.io/theme-matcha"; - license = licenses.gpl3Only; - platforms = platforms.unix; - maintainers = [ maintainers.romildo ]; - }; -} + lib.checkListOfEnum + "${pname}: theme variants" + [ "aliz" "azul" "sea" "pueril" "all" ] + themeVariants + + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "2024-05-01"; + + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = version; + sha256 = "trQwRZ/JKIS8TcRIg0eL5GmB/yymDwqqNued0ddRuqU="; + }; + + nativeBuildInputs = [ + jdupes + ]; + + buildInputs = [ + gdk-pixbuf + librsvg + ]; + + propagatedUserEnvPkgs = [ + gtk-engine-murrine + ]; + + postPatch = '' + patchShebangs install.sh + ''; + + installPhase = '' + runHook preInstall + + mkdir -p $out/share/themes + + name= ./install.sh \ + ${lib.optionalString (colorVariants != [ ]) "--color " + builtins.toString colorVariants} \ + ${lib.optionalString (themeVariants != [ ]) "--theme " + builtins.toString themeVariants} \ + --dest $out/share/themes + + mkdir -p $out/share/doc/${pname} + cp -a src/extra/firefox $out/share/doc/${pname} + + jdupes --quiet --link-soft --recurse $out/share + + runHook postInstall + ''; + + passthru.updateScript = gitUpdater { }; + + meta = with lib; { + description = "Stylish flat Design theme for GTK based desktop environments"; + homepage = "https://vinceliuice.github.io/theme-matcha"; + license = licenses.gpl3Only; + platforms = platforms.unix; + maintainers = [ maintainers.romildo ]; + }; + } diff --git a/pkgs/by-name/ma/matcha-rss-digest/package.nix b/pkgs/by-name/ma/matcha-rss-digest/package.nix index 72e599c3a699a6..be5c7f85d69762 100644 --- a/pkgs/by-name/ma/matcha-rss-digest/package.nix +++ b/pkgs/by-name/ma/matcha-rss-digest/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ma/matchbox/package.nix b/pkgs/by-name/ma/matchbox/package.nix index f12ed0ea0a7f52..bfeeeed9a6a7b1 100644 --- a/pkgs/by-name/ma/matchbox/package.nix +++ b/pkgs/by-name/ma/matchbox/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, libmatchbox, libX11, libXext }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + libmatchbox, + libX11, + libXext, +}: stdenv.mkDerivation rec { pname = "matchbox"; diff --git a/pkgs/by-name/ma/materia-kde-theme/package.nix b/pkgs/by-name/ma/materia-kde-theme/package.nix index 160c0593a07f76..990bc77b0762c0 100644 --- a/pkgs/by-name/ma/materia-kde-theme/package.nix +++ b/pkgs/by-name/ma/materia-kde-theme/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "materia-kde-theme"; diff --git a/pkgs/by-name/ma/materia-theme/package.nix b/pkgs/by-name/ma/materia-theme/package.nix index a5a574aa7927d6..24c0e7a42ebc0f 100644 --- a/pkgs/by-name/ma/materia-theme/package.nix +++ b/pkgs/by-name/ma/materia-theme/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, sassc -, gnome-shell -, gnome-themes-extra -, gtk-engine-murrine -, gdk-pixbuf -, librsvg +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + sassc, + gnome-shell, + gnome-themes-extra, + gtk-engine-murrine, + gdk-pixbuf, + librsvg, }: stdenv.mkDerivation rec { @@ -22,9 +23,17 @@ stdenv.mkDerivation rec { sha256 = "1fsicmcni70jkl4jb3fvh7yv0v9jhb8nwjzdq8vfwn256qyk0xvl"; }; - nativeBuildInputs = [ meson ninja sassc ]; + nativeBuildInputs = [ + meson + ninja + sassc + ]; - buildInputs = [ gnome-themes-extra gdk-pixbuf librsvg ]; + buildInputs = [ + gnome-themes-extra + gdk-pixbuf + librsvg + ]; propagatedUserEnvPkgs = [ gtk-engine-murrine ]; diff --git a/pkgs/by-name/ma/material-black-colors/package.nix b/pkgs/by-name/ma/material-black-colors/package.nix index 3fff194ddd9965..7f3386f70cd00d 100644 --- a/pkgs/by-name/ma/material-black-colors/package.nix +++ b/pkgs/by-name/ma/material-black-colors/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, colorVariants ? [] # default: install all icons +{ + lib, + stdenvNoCC, + fetchFromGitHub, + colorVariants ? [ ], # default: install all icons }: let @@ -36,31 +37,37 @@ let in lib.checkListOfEnum "${pname}: color variants" colorVariantList colorVariants -stdenvNoCC.mkDerivation { - inherit pname; - version = "0-unstable-2020-12-17"; + stdenvNoCC.mkDerivation + { + inherit pname; + version = "0-unstable-2020-12-17"; - src = fetchFromGitHub { - owner = "rtlewis88"; - repo = "rtl88-Themes"; - rev = "3864d851aac7f4e76cf23717aee104de234aef74"; - hash = "sha256-BUJMd6Ltq16/HqqDbB5VDGIRSzLivXxNYZPT9sd6oTI="; - }; + src = fetchFromGitHub { + owner = "rtlewis88"; + repo = "rtl88-Themes"; + rev = "3864d851aac7f4e76cf23717aee104de234aef74"; + hash = "sha256-BUJMd6Ltq16/HqqDbB5VDGIRSzLivXxNYZPT9sd6oTI="; + }; - installPhase = '' - runHook preInstall - mkdir -p $out/share/icons - cp -r ${lib.concatStringsSep " " (if colorVariants != [] then colorVariants else colorVariantList)} $out/share/icons/ - runHook postInstall - ''; + installPhase = '' + runHook preInstall + mkdir -p $out/share/icons + cp -r ${ + lib.concatStringsSep " " (if colorVariants != [ ] then colorVariants else colorVariantList) + } $out/share/icons/ + runHook postInstall + ''; - dontFixup = true; + dontFixup = true; - meta = with lib; { - description = "Material Black Colors icons"; - homepage = "https://github.com/rtlewis88/rtl88-Themes/tree/material-black-COLORS"; - maintainers = with maintainers; [ d3vil0p3r ]; - platforms = platforms.all; - license = with licenses; [ gpl3Plus mit ]; - }; -} + meta = with lib; { + description = "Material Black Colors icons"; + homepage = "https://github.com/rtlewis88/rtl88-Themes/tree/material-black-COLORS"; + maintainers = with maintainers; [ d3vil0p3r ]; + platforms = platforms.all; + license = with licenses; [ + gpl3Plus + mit + ]; + }; + } diff --git a/pkgs/by-name/ma/material-cursors/package.nix b/pkgs/by-name/ma/material-cursors/package.nix index d3d7c63672cca8..76a4746e2e7fc2 100644 --- a/pkgs/by-name/ma/material-cursors/package.nix +++ b/pkgs/by-name/ma/material-cursors/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, inkscape -, xcursorgen +{ + lib, + stdenvNoCC, + fetchFromGitHub, + inkscape, + xcursorgen, }: stdenvNoCC.mkDerivation { - pname = "material-cursors"; + pname = "material-cursors"; version = "unstable-2023-11-30"; src = fetchFromGitHub { diff --git a/pkgs/by-name/ma/material-design-icons/package.nix b/pkgs/by-name/ma/material-design-icons/package.nix index ebd33b88b65098..800a245b36f49b 100644 --- a/pkgs/by-name/ma/material-design-icons/package.nix +++ b/pkgs/by-name/ma/material-design-icons/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, stdenvNoCC -, nix-update-script +{ + lib, + fetchFromGitHub, + stdenvNoCC, + nix-update-script, }: stdenvNoCC.mkDerivation rec { @@ -40,6 +41,9 @@ stdenvNoCC.mkDerivation rec { homepage = "https://materialdesignicons.com"; license = licenses.asl20; platforms = platforms.all; - maintainers = with maintainers; [ vlaci dixslyf ]; + maintainers = with maintainers; [ + vlaci + dixslyf + ]; }; } diff --git a/pkgs/by-name/ma/material-icons/package.nix b/pkgs/by-name/ma/material-icons/package.nix index 993e25ba2cd334..a8dfb57c9cc7ea 100644 --- a/pkgs/by-name/ma/material-icons/package.nix +++ b/pkgs/by-name/ma/material-icons/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchFromGitHub, nix-update-script }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + nix-update-script, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "material-icons"; diff --git a/pkgs/by-name/ma/math-preview/package.nix b/pkgs/by-name/ma/math-preview/package.nix index 6206c67bf1c1ce..e1b0214c5c7764 100644 --- a/pkgs/by-name/ma/math-preview/package.nix +++ b/pkgs/by-name/ma/math-preview/package.nix @@ -1,8 +1,9 @@ -{ lib -, nix-update-script -, fetchFromGitLab -, buildNpmPackage -, nodejs +{ + lib, + nix-update-script, + fetchFromGitLab, + buildNpmPackage, + nodejs, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ma/mathgl/package.nix b/pkgs/by-name/ma/mathgl/package.nix index c5cddcc46c37c3..45095e7f2bf7f5 100644 --- a/pkgs/by-name/ma/mathgl/package.nix +++ b/pkgs/by-name/ma/mathgl/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, cmake -, zlib -, libpng -, libGL +{ + lib, + stdenv, + fetchurl, + cmake, + zlib, + libpng, + libGL, }: stdenv.mkDerivation rec { pname = "mathgl"; @@ -28,7 +29,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Library for scientific data visualization"; homepage = "https://mathgl.sourceforge.net/"; - license = with licenses; [ gpl3 lgpl3 ]; + license = with licenses; [ + gpl3 + lgpl3 + ]; platforms = platforms.linux; maintainers = [ maintainers.GabrielDougherty ]; }; diff --git a/pkgs/by-name/ma/mathjax-node-cli/package.nix b/pkgs/by-name/ma/mathjax-node-cli/package.nix index d15f6bf67b629f..b8c275e8c69039 100644 --- a/pkgs/by-name/ma/mathjax-node-cli/package.nix +++ b/pkgs/by-name/ma/mathjax-node-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, fetchpatch +{ + lib, + buildNpmPackage, + fetchFromGitHub, + fetchpatch, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ma/mathpix-snipping-tool/package.nix b/pkgs/by-name/ma/mathpix-snipping-tool/package.nix index 0f03913c87a846..ff4205c90d4f5b 100644 --- a/pkgs/by-name/ma/mathpix-snipping-tool/package.nix +++ b/pkgs/by-name/ma/mathpix-snipping-tool/package.nix @@ -1,4 +1,8 @@ -{ appimageTools, lib, fetchurl }: +{ + appimageTools, + lib, + fetchurl, +}: let pname = "mathpix-snipping-tool"; version = "03.00.0072"; @@ -9,7 +13,8 @@ let }; appimageContents = appimageTools.extract { inherit pname version src; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; extraInstallCommands = '' diff --git a/pkgs/by-name/ma/matlab-language-server/package.nix b/pkgs/by-name/ma/matlab-language-server/package.nix index 732d8ef9acd0f2..c6576475057349 100644 --- a/pkgs/by-name/ma/matlab-language-server/package.nix +++ b/pkgs/by-name/ma/matlab-language-server/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, fetchpatch +{ + lib, + buildNpmPackage, + fetchFromGitHub, + fetchpatch, }: buildNpmPackage { diff --git a/pkgs/by-name/ma/matrix-alertmanager/package.nix b/pkgs/by-name/ma/matrix-alertmanager/package.nix index 9e387d03285be4..ff4a27e7a07a4d 100644 --- a/pkgs/by-name/ma/matrix-alertmanager/package.nix +++ b/pkgs/by-name/ma/matrix-alertmanager/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, jq +{ + lib, + buildNpmPackage, + fetchFromGitHub, + jq, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ma/matrix-appservice-irc/package.nix b/pkgs/by-name/ma/matrix-appservice-irc/package.nix index 75ef8d6e69d23a..ab5b23f813b215 100644 --- a/pkgs/by-name/ma/matrix-appservice-irc/package.nix +++ b/pkgs/by-name/ma/matrix-appservice-irc/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, fixup-yarn-lock -, nodejs -, nodejs-slim -, matrix-sdk-crypto-nodejs -, nixosTests -, nix-update-script -, yarn +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + fixup-yarn-lock, + nodejs, + nodejs-slim, + matrix-sdk-crypto-nodejs, + nixosTests, + nix-update-script, + yarn, }: let @@ -30,7 +31,12 @@ let in stdenv.mkDerivation { - inherit pname version src yarnOfflineCache; + inherit + pname + version + src + yarnOfflineCache + ; strictDeps = true; diff --git a/pkgs/by-name/ma/matrix-brandy/package.nix b/pkgs/by-name/ma/matrix-brandy/package.nix index a51347e908b893..13088cec236f54 100644 --- a/pkgs/by-name/ma/matrix-brandy/package.nix +++ b/pkgs/by-name/ma/matrix-brandy/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL +{ + lib, + stdenv, + fetchFromGitHub, + SDL, }: stdenv.mkDerivation rec { @@ -33,4 +34,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ fiq ]; }; } - diff --git a/pkgs/by-name/ma/matrix-conduit/package.nix b/pkgs/by-name/ma/matrix-conduit/package.nix index 9f0af06125f93d..dfb7691434498b 100644 --- a/pkgs/by-name/ma/matrix-conduit/package.nix +++ b/pkgs/by-name/ma/matrix-conduit/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitLab -, pkg-config -, sqlite -, stdenv -, darwin -, nixosTests -, rocksdb -, rust-jemalloc-sys +{ + lib, + rustPlatform, + fetchFromGitLab, + pkg-config, + sqlite, + stdenv, + darwin, + nixosTests, + rocksdb, + rust-jemalloc-sys, }: rustPlatform.buildRustPackage rec { @@ -41,13 +42,15 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - sqlite - rust-jemalloc-sys - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + sqlite + rust-jemalloc-sys + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; env = { ROCKSDB_INCLUDE_DIR = "${rocksdb}/include"; @@ -65,7 +68,10 @@ rustPlatform.buildRustPackage rec { description = "Matrix homeserver written in Rust"; homepage = "https://conduit.rs/"; license = licenses.asl20; - maintainers = with maintainers; [ pstn pimeys ]; + maintainers = with maintainers; [ + pstn + pimeys + ]; mainProgram = "conduit"; }; } diff --git a/pkgs/by-name/ma/matrix-corporal/package.nix b/pkgs/by-name/ma/matrix-corporal/package.nix index 8ad2db532e7ee5..e15c4657a2fad6 100644 --- a/pkgs/by-name/ma/matrix-corporal/package.nix +++ b/pkgs/by-name/ma/matrix-corporal/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "matrix-corporal"; @@ -12,7 +16,13 @@ buildGoModule rec { }; ldflags = [ - "-s" "-w" "-X main.GitCommit=${version}" "-X main.GitBranch=${version}" "-X main.GitState=nixpkgs" "-X main.GitSummary=${version}" "-X main.Version=${version}" + "-s" + "-w" + "-X main.GitCommit=${version}" + "-X main.GitBranch=${version}" + "-X main.GitState=nixpkgs" + "-X main.GitSummary=${version}" + "-X main.Version=${version}" ]; vendorHash = "sha256-sC9JA6VRmHGuO3anaZW2Ih5QnRrUom9IIOE7yi3TTG8="; diff --git a/pkgs/by-name/ma/matrix-dl/package.nix b/pkgs/by-name/ma/matrix-dl/package.nix index b16b0bbd7c4ed5..83f61c4b92ce57 100644 --- a/pkgs/by-name/ma/matrix-dl/package.nix +++ b/pkgs/by-name/ma/matrix-dl/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ma/matrix-hook/package.nix b/pkgs/by-name/ma/matrix-hook/package.nix index 05e78621ee15d5..244ba93eec09e9 100644 --- a/pkgs/by-name/ma/matrix-hook/package.nix +++ b/pkgs/by-name/ma/matrix-hook/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "matrix-hook"; @@ -19,6 +23,10 @@ buildGoModule rec { mainProgram = "matrix-hook"; homepage = "https://github.com/pinpox/matrix-hook"; license = licenses.gpl3; - maintainers = with maintainers; [ pinpox mic92 zowoq ]; + maintainers = with maintainers; [ + pinpox + mic92 + zowoq + ]; }; } diff --git a/pkgs/by-name/ma/matrix-hookshot/package.nix b/pkgs/by-name/ma/matrix-hookshot/package.nix index 4b418ff20d1da7..0d5e0a9b0a741d 100644 --- a/pkgs/by-name/ma/matrix-hookshot/package.nix +++ b/pkgs/by-name/ma/matrix-hookshot/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, makeWrapper -, matrix-sdk-crypto-nodejs -, mkYarnPackage -, cargo -, rustPlatform -, rustc -, napi-rs-cli -, pkg-config -, nodejs -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + makeWrapper, + matrix-sdk-crypto-nodejs, + mkYarnPackage, + cargo, + rustPlatform, + rustc, + napi-rs-cli, + pkg-config, + nodejs, + openssl, }: let @@ -42,7 +43,8 @@ mkYarnPackage rec { }; packageResolutions = { - "@matrix-org/matrix-sdk-crypto-nodejs" = "${matrix-sdk-crypto-nodejs}/lib/node_modules/@matrix-org/matrix-sdk-crypto-nodejs"; + "@matrix-org/matrix-sdk-crypto-nodejs" = + "${matrix-sdk-crypto-nodejs}/lib/node_modules/@matrix-org/matrix-sdk-crypto-nodejs"; }; extraBuildInputs = [ openssl ]; diff --git a/pkgs/by-name/ma/matrix-media-repo/package.nix b/pkgs/by-name/ma/matrix-media-repo/package.nix index d6302b28967d87..f15eb89e33e85a 100644 --- a/pkgs/by-name/ma/matrix-media-repo/package.nix +++ b/pkgs/by-name/ma/matrix-media-repo/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, pkg-config -, libde265 -, libheif +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + libde265, + libheif, }: let pname = "matrix-media-repo"; @@ -29,7 +30,12 @@ let in buildGoModule { - inherit pname version src vendorHash; + inherit + pname + version + src + vendorHash + ; nativeBuildInputs = [ pkg-config @@ -48,7 +54,8 @@ buildGoModule { ldflags = [ "-s" "-w" - "-X" "github.com/t2bot/matrix-media-repo/common/version.Version=${version}" + "-X" + "github.com/t2bot/matrix-media-repo/common/version.Version=${version}" ]; doCheck = false; # requires docker diff --git a/pkgs/by-name/ma/matterircd/package.nix b/pkgs/by-name/ma/matterircd/package.nix index 11fc0080a9e0bd..68641888699228 100644 --- a/pkgs/by-name/ma/matterircd/package.nix +++ b/pkgs/by-name/ma/matterircd/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "matterircd"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Minimal IRC server bridge to Mattermost"; diff --git a/pkgs/by-name/ma/mattermost-desktop/package.nix b/pkgs/by-name/ma/mattermost-desktop/package.nix index 68ce8cfaebd70d..b6f4085a688fb3 100644 --- a/pkgs/by-name/ma/mattermost-desktop/package.nix +++ b/pkgs/by-name/ma/mattermost-desktop/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, electron -, makeWrapper +{ + lib, + stdenv, + fetchurl, + electron, + makeWrapper, }: let @@ -66,7 +67,10 @@ stdenv.mkDerivation { homepage = "https://about.mattermost.com/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.asl20; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; maintainers = [ maintainers.joko ]; }; } diff --git a/pkgs/by-name/ma/mattermost/package.nix b/pkgs/by-name/ma/mattermost/package.nix index 910d26dd9ef651..3d2ac231022fe8 100644 --- a/pkgs/by-name/ma/mattermost/package.nix +++ b/pkgs/by-name/ma/mattermost/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script -, fetchurl -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + fetchurl, + nixosTests, }: buildGoModule rec { @@ -25,12 +26,14 @@ buildGoModule rec { # We use go 1.22's workspace vendor command, which is not yet available # in the default version of go used in nixpkgs, nor is it used by upstream: # https://github.com/mattermost/mattermost/issues/26221#issuecomment-1945351597 - overrideModAttrs = (_: { - buildPhase = '' - make setup-go-work - go work vendor -e - ''; - }); + overrideModAttrs = ( + _: { + buildPhase = '' + make setup-go-work + go work vendor -e + ''; + } + ); webapp = fetchurl { url = "https://releases.mattermost.com/${version}/mattermost-${version}-linux-amd64.tar.gz"; @@ -73,7 +76,10 @@ buildGoModule rec { passthru = { updateScript = nix-update-script { - extraArgs = [ "--version-regex" "^v(9\.11\.[0-9]+)$" ]; + extraArgs = [ + "--version-regex" + "^v(9\.11\.[0-9]+)$" + ]; }; tests.mattermost = nixosTests.mattermost; }; @@ -81,8 +87,16 @@ buildGoModule rec { meta = with lib; { description = "Mattermost is an open source platform for secure collaboration across the entire software development lifecycle"; homepage = "https://www.mattermost.org"; - license = with licenses; [ agpl3Only asl20 ]; - maintainers = with maintainers; [ ryantm numinit kranzes mgdelacroix ]; + license = with licenses; [ + agpl3Only + asl20 + ]; + maintainers = with maintainers; [ + ryantm + numinit + kranzes + mgdelacroix + ]; mainProgram = "mattermost"; }; } diff --git a/pkgs/by-name/ma/maude/package.nix b/pkgs/by-name/ma/maude/package.nix index 2050760adaf686..5a08066937ae6a 100644 --- a/pkgs/by-name/ma/maude/package.nix +++ b/pkgs/by-name/ma/maude/package.nix @@ -1,7 +1,20 @@ -{ lib, stdenv, fetchurl, unzip, makeWrapper, flex, bison, ncurses, buddy, tecla -, libsigsegv, gmpxx, cln, yices -# passthru.tests -, tamarin-prover +{ + lib, + stdenv, + fetchurl, + unzip, + makeWrapper, + flex, + bison, + ncurses, + buddy, + tecla, + libsigsegv, + gmpxx, + cln, + yices, + # passthru.tests + tamarin-prover, }: let @@ -17,13 +30,28 @@ stdenv.mkDerivation { sha256 = "IXWEWAmh388NpNSt9wnOpLkzhZ09N+AStO2wn5dRT8o="; }; - nativeBuildInputs = [ flex bison unzip makeWrapper ]; + nativeBuildInputs = [ + flex + bison + unzip + makeWrapper + ]; buildInputs = [ - ncurses buddy tecla gmpxx libsigsegv cln yices + ncurses + buddy + tecla + gmpxx + libsigsegv + cln + yices ]; - hardeningDisable = [ "stackprotector" ] ++ - lib.optionals stdenv.hostPlatform.isi686 [ "pic" "fortify" ]; + hardeningDisable = + [ "stackprotector" ] + ++ lib.optionals stdenv.hostPlatform.isi686 [ + "pic" + "fortify" + ]; # Fix for glibc-2.34, see # https://gitweb.gentoo.org/repo/gentoo.git/commit/dev-lang/maude/maude-3.1-r1.ebuild?id=f021cc6cfa1e35eb9c59955830f1fd89bfcb26b4 diff --git a/pkgs/by-name/ma/mautrix-discord/package.nix b/pkgs/by-name/ma/mautrix-discord/package.nix index dc3bbcff8a0cdd..d0b469debd1bed 100644 --- a/pkgs/by-name/ma/mautrix-discord/package.nix +++ b/pkgs/by-name/ma/mautrix-discord/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, olm -, nix-update-script -, testers -, mautrix-discord +{ + lib, + buildGoModule, + fetchFromGitHub, + olm, + nix-update-script, + testers, + mautrix-discord, }: buildGoModule rec { @@ -20,13 +21,15 @@ buildGoModule rec { vendorHash = "sha256-QdH98NA5Y9YKkvL8Gq8ChgvHFOyOBFXDDulxwql6v5c="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; buildInputs = [ olm ]; doCheck = false; - passthru = { updateScript = nix-update-script { }; tests.version = testers.testVersion { diff --git a/pkgs/by-name/ma/mautrix-facebook/package.nix b/pkgs/by-name/ma/mautrix-facebook/package.nix index 3857e5abd45de0..3ae5c76fb19e71 100644 --- a/pkgs/by-name/ma/mautrix-facebook/package.nix +++ b/pkgs/by-name/ma/mautrix-facebook/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 -, enableSystemd ? lib.meta.availableOn stdenv.hostPlatform python3.pkgs.systemd +{ + lib, + stdenv, + fetchFromGitHub, + python3, + enableSystemd ? lib.meta.availableOn stdenv.hostPlatform python3.pkgs.systemd, }: python3.pkgs.buildPythonPackage rec { @@ -16,23 +17,26 @@ python3.pkgs.buildPythonPackage rec { hash = "sha256-8uleN7L3fgNqqRjva3kJU7fLPJZpO6b0J4z0RxZ9B64="; }; - propagatedBuildInputs = with python3.pkgs; [ - commonmark - aiohttp - asyncpg - commonmark - (mautrix.override { withOlm = true; }) - paho-mqtt - pillow - prometheus-client - pycryptodome - python-olm - python-magic - ruamel-yaml - unpaddedbase64 - yarl - zstandard - ] ++ lib.optional enableSystemd systemd; + propagatedBuildInputs = + with python3.pkgs; + [ + commonmark + aiohttp + asyncpg + commonmark + (mautrix.override { withOlm = true; }) + paho-mqtt + pillow + prometheus-client + pycryptodome + python-olm + python-magic + ruamel-yaml + unpaddedbase64 + yarl + zstandard + ] + ++ lib.optional enableSystemd systemd; postPatch = '' # Drop version limiting so that every dependency update doesn't break this package. diff --git a/pkgs/by-name/ma/mautrix-googlechat/package.nix b/pkgs/by-name/ma/mautrix-googlechat/package.nix index a352b5ab8e8759..d3c8bdd7ee2561 100644 --- a/pkgs/by-name/ma/mautrix-googlechat/package.nix +++ b/pkgs/by-name/ma/mautrix-googlechat/package.nix @@ -1,11 +1,13 @@ -{ fetchFromGitHub -, fetchpatch -, lib -, python3 -, enableE2be ? true -, enableMetrics ? true -, enableSqlite ? true -}: python3.pkgs.buildPythonApplication rec { +{ + fetchFromGitHub, + fetchpatch, + lib, + python3, + enableE2be ? true, + enableMetrics ? true, + enableSqlite ? true, +}: +python3.pkgs.buildPythonApplication rec { pname = "mautrix-googlechat"; version = "0.5.2"; @@ -46,19 +48,22 @@ ]; }; - propagatedBuildInputs = with python3.pkgs; [ - aiohttp - commonmark - yarl - asyncpg - ruamel-yaml - commonmark - python-magic - protobuf - (mautrix.override { withOlm = enableE2be; }) - ] ++ lib.optionals enableE2be optional-dependencies.e2be - ++ lib.optionals enableMetrics optional-dependencies.metrics - ++ lib.optionals enableSqlite optional-dependencies.sqlite; + propagatedBuildInputs = + with python3.pkgs; + [ + aiohttp + commonmark + yarl + asyncpg + ruamel-yaml + commonmark + python-magic + protobuf + (mautrix.override { withOlm = enableE2be; }) + ] + ++ lib.optionals enableE2be optional-dependencies.e2be + ++ lib.optionals enableMetrics optional-dependencies.metrics + ++ lib.optionals enableSqlite optional-dependencies.sqlite; doCheck = false; diff --git a/pkgs/by-name/ma/mautrix-meta/package.nix b/pkgs/by-name/ma/mautrix-meta/package.nix index 29ca66cdf80e05..1b5204f6d20bc7 100644 --- a/pkgs/by-name/ma/mautrix-meta/package.nix +++ b/pkgs/by-name/ma/mautrix-meta/package.nix @@ -1,15 +1,16 @@ -{ buildGoModule -, fetchFromGitHub -, nix-update-script -, lib -, nixosTests -, olm -# This option enables the use of an experimental pure-Go implementation of the -# Olm protocol instead of libolm for end-to-end encryption. Using goolm is not -# recommended by the mautrix developers, but they are interested in people -# trying it out in non-production-critical environments and reporting any -# issues they run into. -, withGoolm ? false +{ + buildGoModule, + fetchFromGitHub, + nix-update-script, + lib, + nixosTests, + olm, + # This option enables the use of an experimental pure-Go implementation of the + # Olm protocol instead of libolm for end-to-end encryption. Using goolm is not + # recommended by the mautrix developers, but they are interested in people + # trying it out in non-production-critical environments and reporting any + # issues they run into. + withGoolm ? false, }: buildGoModule rec { @@ -41,7 +42,6 @@ buildGoModule rec { updateScript = nix-update-script { }; }; - meta = { homepage = "https://github.com/mautrix/meta"; description = "Matrix <-> Facebook and Matrix <-> Instagram hybrid puppeting/relaybot bridge"; diff --git a/pkgs/by-name/ma/mautrix-whatsapp/package.nix b/pkgs/by-name/ma/mautrix-whatsapp/package.nix index 5f4e1683fa18c5..b65664d89dd301 100644 --- a/pkgs/by-name/ma/mautrix-whatsapp/package.nix +++ b/pkgs/by-name/ma/mautrix-whatsapp/package.nix @@ -33,7 +33,11 @@ buildGoModule rec { homepage = "https://github.com/tulir/mautrix-whatsapp"; description = "Matrix <-> Whatsapp hybrid puppeting/relaybot bridge"; license = licenses.agpl3Plus; - maintainers = with maintainers; [ vskilet ma27 chvp ]; + maintainers = with maintainers; [ + vskilet + ma27 + chvp + ]; mainProgram = "mautrix-whatsapp"; }; } diff --git a/pkgs/by-name/ma/maven/build-maven.nix b/pkgs/by-name/ma/maven/build-maven.nix index 7ac8afdde225a1..4dbe24c5e8b0b6 100644 --- a/pkgs/by-name/ma/maven/build-maven.nix +++ b/pkgs/by-name/ma/maven/build-maven.nix @@ -1,4 +1,13 @@ -{ stdenv, maven, runCommand, writeText, fetchurl, lib, requireFile, linkFarm }: +{ + stdenv, + maven, + runCommand, + writeText, + fetchurl, + lib, + requireFile, + linkFarm, +}: # Takes an info file generated by mvn2nix # (https://github.com/NixOS/mvn2nix-maven-plugin) and builds the maven # project with it. @@ -16,45 +25,61 @@ infoFile: let info = lib.importJSON infoFile; - dependencies = lib.flatten (map (dep: - let - inherit (dep) sha1 groupId artifactId version metadata repository-id; - versionDir = dep.unresolved-version or version; - authenticated = dep.authenticated or false; - url = dep.url or ""; + dependencies = lib.flatten ( + map ( + dep: + let + inherit (dep) + sha1 + groupId + artifactId + version + metadata + repository-id + ; + versionDir = dep.unresolved-version or version; + authenticated = dep.authenticated or false; + url = dep.url or ""; - fetch = if (url != "") then - ((if authenticated then requireFile else fetchurl) { - inherit url sha1; - }) - else - ""; + fetch = + if (url != "") then + ((if authenticated then requireFile else fetchurl) { + inherit url sha1; + }) + else + ""; - fetchMetadata = (if authenticated then requireFile else fetchurl) { - inherit (metadata) url sha1; - }; + fetchMetadata = (if authenticated then requireFile else fetchurl) { + inherit (metadata) url sha1; + }; - layout = "${ - builtins.replaceStrings [ "." ] [ "/" ] groupId - }/${artifactId}/${versionDir}"; - in lib.optional (url != "") { - layout = "${layout}/${fetch.name}"; - drv = fetch; - } ++ lib.optionals (dep ? metadata) ([{ - layout = "${layout}/maven-metadata-${repository-id}.xml"; - drv = fetchMetadata; - }] ++ lib.optional (fetch != "") { - layout = "${layout}/${ - builtins.replaceStrings [ version ] [ dep.unresolved-version ] - fetch.name - }"; - drv = fetch; - })) info.dependencies); + layout = "${builtins.replaceStrings [ "." ] [ "/" ] groupId}/${artifactId}/${versionDir}"; + in + lib.optional (url != "") { + layout = "${layout}/${fetch.name}"; + drv = fetch; + } + ++ lib.optionals (dep ? metadata) ( + [ + { + layout = "${layout}/maven-metadata-${repository-id}.xml"; + drv = fetchMetadata; + } + ] + ++ lib.optional (fetch != "") { + layout = "${layout}/${builtins.replaceStrings [ version ] [ dep.unresolved-version ] fetch.name}"; + drv = fetch; + } + ) + ) info.dependencies + ); - repo = linkFarm "maven-repository" (lib.forEach dependencies (dependency: { - name = dependency.layout; - path = dependency.drv; - })); + repo = linkFarm "maven-repository" ( + lib.forEach dependencies (dependency: { + name = dependency.layout; + path = dependency.drv; + }) + ); settings = writeText "settings.xml" '' tiffSupport; let - inherit (lib) makeBinPath optional optionals optionalString; + inherit (lib) + makeBinPath + optional + optionals + optionalString + ; runtimePath = makeBinPath ( optional tiffSupport libraw - ++ optionals jpgSupport [ graphicsmagick exiftool ] + ++ optionals jpgSupport [ + graphicsmagick + exiftool + ] ); in stdenv.mkDerivation (finalAttrs: { @@ -77,7 +86,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://gitlab.com/megapixels-org/Megapixels"; changelog = "https://gitlab.com/megapixels-org/Megapixels/-/tags/${finalAttrs.version}"; license = licenses.gpl3Only; - maintainers = with maintainers; [ dotlambda Luflosi ]; + maintainers = with maintainers; [ + dotlambda + Luflosi + ]; platforms = platforms.linux; mainProgram = "megapixels"; }; diff --git a/pkgs/by-name/me/megatools/package.nix b/pkgs/by-name/me/megatools/package.nix index 105abe64708980..0f303363ca2f9f 100644 --- a/pkgs/by-name/me/megatools/package.nix +++ b/pkgs/by-name/me/megatools/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchgit -, asciidoc -, docbook_xml_dtd_45 -, docbook2x -, libxml2 -, meson -, ninja -, pkg-config -, curl -, glib -, fuse +{ + lib, + stdenv, + fetchgit, + asciidoc, + docbook_xml_dtd_45, + docbook2x, + libxml2, + meson, + ninja, + pkg-config, + curl, + glib, + fuse, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/me/meh/package.nix b/pkgs/by-name/me/meh/package.nix index 49477277d92bdd..9c5dd2792fc0c5 100644 --- a/pkgs/by-name/me/meh/package.nix +++ b/pkgs/by-name/me/meh/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, libX11, libXext, libjpeg, libpng, giflib }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + libXext, + libjpeg, + libpng, + giflib, +}: stdenv.mkDerivation { pname = "meh"; @@ -13,9 +22,18 @@ stdenv.mkDerivation { installFlags = [ "PREFIX=${placeholder "out"}" ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - buildInputs = [ libXext libX11 libjpeg libpng giflib ]; + buildInputs = [ + libXext + libX11 + libjpeg + libpng + giflib + ]; meta = { description = "Minimal image viewer using raw XLib"; diff --git a/pkgs/by-name/me/mela/package.nix b/pkgs/by-name/me/mela/package.nix index a478a972c9566f..1bdaf081ac3ac5 100644 --- a/pkgs/by-name/me/mela/package.nix +++ b/pkgs/by-name/me/mela/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, gfortran }: +{ + lib, + stdenv, + fetchFromGitHub, + gfortran, +}: stdenv.mkDerivation rec { pname = "mela"; @@ -18,9 +23,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Mellin Evolution LibrAry"; mainProgram = "mela-config"; - license = licenses.gpl3; - homepage = "https://github.com/vbertone/MELA"; - platforms = platforms.unix; + license = licenses.gpl3; + homepage = "https://github.com/vbertone/MELA"; + platforms = platforms.unix; maintainers = with maintainers; [ veprbl ]; }; } diff --git a/pkgs/by-name/me/meld/package.nix b/pkgs/by-name/me/meld/package.nix index 1fcc3c235816a8..9312917f008cdb 100644 --- a/pkgs/by-name/me/meld/package.nix +++ b/pkgs/by-name/me/meld/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchurl -, gettext -, itstool -, python3 -, meson -, ninja -, wrapGAppsHook3 -, libxml2 -, pkg-config -, desktop-file-utils -, gobject-introspection -, gtk3 -, gtksourceview4 -, gnome -, adwaita-icon-theme -, gsettings-desktop-schemas -, desktopToDarwinBundle +{ + lib, + stdenv, + fetchurl, + gettext, + itstool, + python3, + meson, + ninja, + wrapGAppsHook3, + libxml2, + pkg-config, + desktop-file-utils, + gobject-introspection, + gtk3, + gtksourceview4, + gnome, + adwaita-icon-theme, + gsettings-desktop-schemas, + desktopToDarwinBundle, }: python3.pkgs.buildPythonApplication rec { @@ -71,7 +72,10 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://meld.app/"; license = licenses.gpl2Plus; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ jtojnar mimame ]; + maintainers = with maintainers; [ + jtojnar + mimame + ]; mainProgram = "meld"; }; } diff --git a/pkgs/by-name/me/melete/package.nix b/pkgs/by-name/me/melete/package.nix index 671f7e0cafe64e..02465f91762589 100644 --- a/pkgs/by-name/me/melete/package.nix +++ b/pkgs/by-name/me/melete/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "0"; diff --git a/pkgs/by-name/me/meletrix-udev-rules/package.nix b/pkgs/by-name/me/meletrix-udev-rules/package.nix index 43fd2b94cdd5b5..cdbce4957d98a3 100644 --- a/pkgs/by-name/me/meletrix-udev-rules/package.nix +++ b/pkgs/by-name/me/meletrix-udev-rules/package.nix @@ -6,7 +6,7 @@ stdenvNoCC.mkDerivation { pname = "meletrix-udev-rules"; version = "0-unstable-2023-10-20"; - src = [./meletrix.rules]; + src = [ ./meletrix.rules ]; dontUnpack = true; dontBuild = true; @@ -18,7 +18,7 @@ stdenvNoCC.mkDerivation { meta = with lib; { description = "udev rules to configure Meletrix keyboards"; license = licenses.cc0; - maintainers = with maintainers; [Scrumplex]; + maintainers = with maintainers; [ Scrumplex ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/me/meli/package.nix b/pkgs/by-name/me/meli/package.nix index cbdbc795f3087b..7640e4813d6c3a 100644 --- a/pkgs/by-name/me/meli/package.nix +++ b/pkgs/by-name/me/meli/package.nix @@ -1,25 +1,26 @@ -{ stdenv -, lib -, fetchzip -, fetchpatch -, rustPlatform +{ + stdenv, + lib, + fetchzip, + fetchpatch, + rustPlatform, -# native build inputs -, pkg-config -, installShellFiles -, makeWrapper -, mandoc -, rustfmt -, file + # native build inputs + pkg-config, + installShellFiles, + makeWrapper, + mandoc, + rustfmt, + file, -# build inputs -, openssl -, dbus -, sqlite + # build inputs + openssl, + dbus, + sqlite, -# runtime deps -, gpgme -, gnum4 + # runtime deps + gpgme, + gnum4, }: rustPlatform.buildRustPackage rec { @@ -38,7 +39,7 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-w0fxh3c54Hcczc9NW8heewrRFx7UZnQqAHiQWZ43wKw="; # Needed to get openssl-sys to use pkg-config - OPENSSL_NO_VENDOR=1; + OPENSSL_NO_VENDOR = 1; nativeBuildInputs = [ pkg-config @@ -81,7 +82,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "meli"; homepage = "https://meli.delivery"; license = licenses.gpl3; - maintainers = with maintainers; [ _0x4A6F matthiasbeyer ]; + maintainers = with maintainers; [ + _0x4A6F + matthiasbeyer + ]; platforms = platforms.linux ++ platforms.darwin; }; } diff --git a/pkgs/by-name/me/melody/package.nix b/pkgs/by-name/me/melody/package.nix index f7865646c89149..6d77b73350e84b 100644 --- a/pkgs/by-name/me/melody/package.nix +++ b/pkgs/by-name/me/melody/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "melody"; diff --git a/pkgs/by-name/me/melt/package.nix b/pkgs/by-name/me/melt/package.nix index 80bec168c1cc8a..39284acc152216 100644 --- a/pkgs/by-name/me/melt/package.nix +++ b/pkgs/by-name/me/melt/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "melt"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-ZCHPbLjf2rTlg+Nj3v+XRW2xDN0qqhnlrF4sXNrGH/E="; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; meta = with lib; { description = "Backup and restore Ed25519 SSH keys with seed words"; diff --git a/pkgs/by-name/me/meme-bingo-web/package.nix b/pkgs/by-name/me/meme-bingo-web/package.nix index 9c98fe5a83a200..7a8c7c945e6ffd 100644 --- a/pkgs/by-name/me/meme-bingo-web/package.nix +++ b/pkgs/by-name/me/meme-bingo-web/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitea -, rustPlatform -, makeWrapper -, nix-update-script +{ + lib, + fetchFromGitea, + rustPlatform, + makeWrapper, + nix-update-script, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/me/meme-image-generator/package.nix b/pkgs/by-name/me/meme-image-generator/package.nix index e60351bf962d61..98a643d4754afc 100644 --- a/pkgs/by-name/me/meme-image-generator/package.nix +++ b/pkgs/by-name/me/meme-image-generator/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/me/meme-suite/package.nix b/pkgs/by-name/me/meme-suite/package.nix index c0f67c314161e7..82ca6c3400579f 100644 --- a/pkgs/by-name/me/meme-suite/package.nix +++ b/pkgs/by-name/me/meme-suite/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, python3, perl, zlib }: +{ + lib, + stdenv, + fetchurl, + python3, + perl, + zlib, +}: stdenv.mkDerivation rec { pname = "meme-suite"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; buildInputs = [ zlib ]; - nativeBuildInputs = [ perl python3 ]; + nativeBuildInputs = [ + perl + python3 + ]; meta = with lib; { description = "Motif-based sequence analysis tools"; diff --git a/pkgs/by-name/me/memo/package.nix b/pkgs/by-name/me/memo/package.nix index c6d9c58b0ad627..5973477ffa2d85 100644 --- a/pkgs/by-name/me/memo/package.nix +++ b/pkgs/by-name/me/memo/package.nix @@ -1,7 +1,15 @@ -{ fetchFromGitHub, silver-searcher, tree, man, lib, stdenv, +{ + fetchFromGitHub, + silver-searcher, + tree, + man, + lib, + stdenv, git, - pandocSupport ? true, pandoc ? null - , ... }: + pandocSupport ? true, + pandoc ? null, + ... +}: assert pandocSupport -> pandoc != null; @@ -12,30 +20,30 @@ stdenv.mkDerivation rec { version = "0.8"; src = fetchFromGitHub { - owner = "mrVanDalo"; - repo = "memo"; - rev = version; + owner = "mrVanDalo"; + repo = "memo"; + rev = version; sha256 = "0azx2bx6y7j0637fg3m8zigcw09zfm2mw9wjfg218sx88cm1wdkp"; }; - installPhase = let - pandocReplacement = if pandocSupport then - "pandoc_cmd=${pandoc}/bin/pandoc" - else - "#pandoc_cmd=pandoc"; - in '' - mkdir -p $out/{bin,share/man/man1,share/bash-completion/completions,share/zsh/site-functions} - substituteInPlace memo \ - --replace "ack_cmd=ack" "ack_cmd=${silver-searcher}/bin/ag" \ - --replace "tree_cmd=tree" "tree_cmd=${tree}/bin/tree" \ - --replace "man_cmd=man" "man_cmd=${man}/bin/man" \ - --replace "git_cmd=git" "git_cmd=${git}/bin/git" \ - --replace "pandoc_cmd=pandoc" "${pandocReplacement}" - mv memo $out/bin/ - mv doc/memo.1 $out/share/man/man1/memo.1 - mv completion/bash/memo.sh $out/share/bash-completion/completions/memo.sh - mv completion/zsh/_memo $out/share/zsh/site-functions/_memo - ''; + installPhase = + let + pandocReplacement = + if pandocSupport then "pandoc_cmd=${pandoc}/bin/pandoc" else "#pandoc_cmd=pandoc"; + in + '' + mkdir -p $out/{bin,share/man/man1,share/bash-completion/completions,share/zsh/site-functions} + substituteInPlace memo \ + --replace "ack_cmd=ack" "ack_cmd=${silver-searcher}/bin/ag" \ + --replace "tree_cmd=tree" "tree_cmd=${tree}/bin/tree" \ + --replace "man_cmd=man" "man_cmd=${man}/bin/man" \ + --replace "git_cmd=git" "git_cmd=${git}/bin/git" \ + --replace "pandoc_cmd=pandoc" "${pandocReplacement}" + mv memo $out/bin/ + mv doc/memo.1 $out/share/man/man1/memo.1 + mv completion/bash/memo.sh $out/share/bash-completion/completions/memo.sh + mv completion/zsh/_memo $out/share/zsh/site-functions/_memo + ''; meta = { description = "Simple tool written in bash to memorize stuff"; diff --git a/pkgs/by-name/me/memorado/package.nix b/pkgs/by-name/me/memorado/package.nix index 924c906a5ee65f..1af6239281ae4c 100644 --- a/pkgs/by-name/me/memorado/package.nix +++ b/pkgs/by-name/me/memorado/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, gtk4 -, pkg-config -, libadwaita -, blueprint-compiler -, python3 -, desktop-file-utils -, gobject-introspection -, wrapGAppsHook4 +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + gtk4, + pkg-config, + libadwaita, + blueprint-compiler, + python3, + desktop-file-utils, + gobject-introspection, + wrapGAppsHook4, }: stdenv.mkDerivation rec { @@ -37,9 +38,11 @@ stdenv.mkDerivation rec { buildInputs = [ gtk4 libadwaita - (python3.withPackages (ps: with ps; [ - pygobject3 - ])) + (python3.withPackages ( + ps: with ps; [ + pygobject3 + ] + )) ]; meta = with lib; { diff --git a/pkgs/by-name/me/memtest86-efi/package.nix b/pkgs/by-name/me/memtest86-efi/package.nix index ead250feee6a5a..ff8704515ffae4 100644 --- a/pkgs/by-name/me/memtest86-efi/package.nix +++ b/pkgs/by-name/me/memtest86-efi/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchzip -, util-linux -, jq -, mtools +{ + stdenv, + lib, + fetchzip, + util-linux, + jq, + mtools, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/me/memtest86plus/package.nix b/pkgs/by-name/me/memtest86plus/package.nix index 10d691b5c86be6..204583493b7a1b 100644 --- a/pkgs/by-name/me/memtest86plus/package.nix +++ b/pkgs/by-name/me/memtest86plus/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation (finalAttrs: { pname = "memtest86+"; @@ -30,7 +34,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.memtest.org/"; description = "Tool to detect memory errors"; license = lib.licenses.gpl2Only; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ lib.maintainers.LunNova ]; }; }) diff --git a/pkgs/by-name/me/memtest_vulkan/package.nix b/pkgs/by-name/me/memtest_vulkan/package.nix index cdbcc7982b8393..e030646ce8b41c 100644 --- a/pkgs/by-name/me/memtest_vulkan/package.nix +++ b/pkgs/by-name/me/memtest_vulkan/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, vulkan-loader +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + vulkan-loader, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,9 @@ rustPlatform.buildRustPackage rec { # It doesn't discover this on its own :/ # https://github.com/GpuZelenograd/memtest_vulkan/issues/36 postFixup = lib.optionalString stdenv.targetPlatform.isElf '' - patchelf $out/bin/memtest_vulkan --add-needed libvulkan.so --add-rpath ${lib.makeLibraryPath [ vulkan-loader ]} + patchelf $out/bin/memtest_vulkan --add-needed libvulkan.so --add-rpath ${ + lib.makeLibraryPath [ vulkan-loader ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/me/memtier-benchmark/package.nix b/pkgs/by-name/me/memtier-benchmark/package.nix index 2850d0dfe0310a..02f67e23c9c03e 100644 --- a/pkgs/by-name/me/memtier-benchmark/package.nix +++ b/pkgs/by-name/me/memtier-benchmark/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook -, pkg-config, libevent, pcre, zlib, openssl +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libevent, + pcre, + zlib, + openssl, }: stdenv.mkDerivation rec { @@ -7,9 +15,9 @@ stdenv.mkDerivation rec { version = "2.1.2"; src = fetchFromGitHub { - owner = "redislabs"; - repo = "memtier_benchmark"; - rev = "refs/tags/${version}"; + owner = "redislabs"; + repo = "memtier_benchmark"; + rev = "refs/tags/${version}"; sha256 = "sha256-a6v+M+r2f3AZImkHmUomViQNlgTdL7JaRayoVvmaMJU="; }; @@ -18,14 +26,22 @@ stdenv.mkDerivation rec { --replace '1.2.8' '${version}' ''; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libevent pcre zlib openssl ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libevent + pcre + zlib + openssl + ]; meta = { description = "Redis and Memcached traffic generation and benchmarking tool"; - homepage = "https://github.com/redislabs/memtier_benchmark"; - license = lib.licenses.gpl2Only; - platforms = lib.platforms.linux; + homepage = "https://github.com/redislabs/memtier_benchmark"; + license = lib.licenses.gpl2Only; + platforms = lib.platforms.linux; maintainers = with lib.maintainers; [ thoughtpolice ]; mainProgram = "memtier_benchmark"; }; diff --git a/pkgs/by-name/me/memtree/package.nix b/pkgs/by-name/me/memtree/package.nix index 6c40a000d590dd..7a6ed7a323af0f 100644 --- a/pkgs/by-name/me/memtree/package.nix +++ b/pkgs/by-name/me/memtree/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, nix-update-script -, python3Packages +{ + lib, + fetchFromGitHub, + nix-update-script, + python3Packages, }: python3Packages.buildPythonApplication { diff --git a/pkgs/by-name/me/mencal/package.nix b/pkgs/by-name/me/mencal/package.nix index 011db7455fcf26..dd5ea1063b03c5 100644 --- a/pkgs/by-name/me/mencal/package.nix +++ b/pkgs/by-name/me/mencal/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "mencal"; diff --git a/pkgs/by-name/me/menu-cache/package.nix b/pkgs/by-name/me/menu-cache/package.nix index e05d387846a678..0994473826e16f 100644 --- a/pkgs/by-name/me/menu-cache/package.nix +++ b/pkgs/by-name/me/menu-cache/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchpatch, glib, pkg-config, libfm-extra }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + glib, + pkg-config, + libfm-extra, +}: stdenv.mkDerivation rec { pname = "menu-cache"; @@ -21,7 +29,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib libfm-extra ]; + buildInputs = [ + glib + libfm-extra + ]; meta = with lib; { description = "Library to read freedesktop.org menu files"; diff --git a/pkgs/by-name/me/menulibre/package.nix b/pkgs/by-name/me/menulibre/package.nix index b8ad319c895762..530d0f8f7ab6c5 100644 --- a/pkgs/by-name/me/menulibre/package.nix +++ b/pkgs/by-name/me/menulibre/package.nix @@ -1,14 +1,15 @@ -{ lib -, fetchFromGitHub -, python3Packages -, gnome-menus -, gtk3 -, intltool -, gobject-introspection -, wrapGAppsHook3 -, nix-update-script -, testers -, menulibre +{ + lib, + fetchFromGitHub, + python3Packages, + gnome-menus, + gtk3, + intltool, + gobject-introspection, + wrapGAppsHook3, + nix-update-script, + testers, + menulibre, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/me/menumaker/package.nix b/pkgs/by-name/me/menumaker/package.nix index 23ec74cd8b8d25..d4b2cef88cbdd7 100644 --- a/pkgs/by-name/me/menumaker/package.nix +++ b/pkgs/by-name/me/menumaker/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, python3Packages }: +{ + lib, + fetchurl, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "menumaker"; diff --git a/pkgs/by-name/me/mepo/package.nix b/pkgs/by-name/me/mepo/package.nix index afa5ffe3d79718..06f6b22d4ea415 100644 --- a/pkgs/by-name/me/mepo/package.nix +++ b/pkgs/by-name/me/mepo/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromSourcehut -, SDL2 -, SDL2_gfx -, SDL2_image -, SDL2_ttf -, busybox -, curl -, findutils -, geoclue2-with-demo-agent -, gpsd -, jq -, makeWrapper -, ncurses -, pkg-config -, util-linux -, xwininfo -, zenity -, zig_0_12 +{ + lib, + stdenv, + fetchFromSourcehut, + SDL2, + SDL2_gfx, + SDL2_image, + SDL2_ttf, + busybox, + curl, + findutils, + geoclue2-with-demo-agent, + gpsd, + jq, + makeWrapper, + ncurses, + pkg-config, + util-linux, + xwininfo, + zenity, + zig_0_12, }: stdenv.mkDerivation (finalAttrs: { @@ -62,17 +63,19 @@ stdenv.mkDerivation (finalAttrs: { --replace-fail " ls " " ls -a " #circumvent wrapping for script detection for program in $out/bin/* ; do wrapProgram $program \ - --suffix PATH : $out/bin:${lib.makeBinPath ([ - busybox - curl - findutils - gpsd - jq - ncurses - util-linux - xwininfo - zenity - ])} + --suffix PATH : $out/bin:${ + lib.makeBinPath ([ + busybox + curl + findutils + gpsd + jq + ncurses + util-linux + xwininfo + zenity + ]) + } done ''; @@ -92,7 +95,11 @@ stdenv.mkDerivation (finalAttrs: { more. ''; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ sikmir McSinyx laalsaas ]; + maintainers = with lib.maintainers; [ + sikmir + McSinyx + laalsaas + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/by-name/me/mercure/package.nix b/pkgs/by-name/me/mercure/package.nix index 8b96f1400a52d2..e1aebcc85a63a4 100644 --- a/pkgs/by-name/me/mercure/package.nix +++ b/pkgs/by-name/me/mercure/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script -, testers -, mercure +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + testers, + mercure, }: buildGoModule rec { diff --git a/pkgs/by-name/me/merecat/package.nix b/pkgs/by-name/me/merecat/package.nix index 344f81da2ff7aa..2a50a431bfb87e 100644 --- a/pkgs/by-name/me/merecat/package.nix +++ b/pkgs/by-name/me/merecat/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libconfuse -, libxcrypt -, testers -, merecat -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libconfuse, + libxcrypt, + testers, + merecat, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/me/meritous/package.nix b/pkgs/by-name/me/meritous/package.nix index 8b0a176938aaca..010e34bc23bb95 100644 --- a/pkgs/by-name/me/meritous/package.nix +++ b/pkgs/by-name/me/meritous/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitLab, SDL, SDL_image, SDL_mixer, zlib }: +{ + lib, + stdenv, + fetchFromGitLab, + SDL, + SDL_image, + SDL_mixer, + zlib, +}: stdenv.mkDerivation (finalAttrs: { pname = "meritous"; @@ -20,7 +28,12 @@ stdenv.mkDerivation (finalAttrs: { --replace "filename[64]" "filename[256]" ''; - buildInputs = [ SDL SDL_image SDL_mixer zlib ]; + buildInputs = [ + SDL + SDL_image + SDL_mixer + zlib + ]; installPhase = '' install -m 555 -D meritous $out/bin/meritous @@ -28,7 +41,10 @@ stdenv.mkDerivation (finalAttrs: { cp -r dat/* $out/share/meritous/ ''; - hardeningDisable = [ "stackprotector" "fortify" ]; + hardeningDisable = [ + "stackprotector" + "fortify" + ]; meta = with lib; { description = "Action-adventure dungeon crawl game"; diff --git a/pkgs/by-name/me/mermaid-cli/package.nix b/pkgs/by-name/me/mermaid-cli/package.nix index a11b5504bca5a7..1678bbd58e8538 100644 --- a/pkgs/by-name/me/mermaid-cli/package.nix +++ b/pkgs/by-name/me/mermaid-cli/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, makeWrapper -, nodejs -, fixup-yarn-lock -, yarn -, chromium +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + makeWrapper, + nodejs, + fixup-yarn-lock, + yarn, + chromium, }: stdenv.mkDerivation rec { @@ -25,7 +26,7 @@ stdenv.mkDerivation rec { hash = "sha256-SfRzn5FxO+Ls+ne7ay3tySNLr+awEJ9fo/nwcAY11qA="; }; - nativeBuildInputs = [ + nativeBuildInputs = [ makeWrapper nodejs fixup-yarn-lock @@ -52,22 +53,25 @@ stdenv.mkDerivation rec { runHook postBuild ''; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - yarn --offline --production install + yarn --offline --production install - mkdir -p "$out/lib/node_modules/@mermaid-js/mermaid-cli" - cp -r . "$out/lib/node_modules/@mermaid-js/mermaid-cli" + mkdir -p "$out/lib/node_modules/@mermaid-js/mermaid-cli" + cp -r . "$out/lib/node_modules/@mermaid-js/mermaid-cli" - makeWrapper "${nodejs}/bin/node" "$out/bin/mmdc" \ - '' + lib.optionalString (lib.meta.availableOn stdenv.hostPlatform chromium) '' + makeWrapper "${nodejs}/bin/node" "$out/bin/mmdc" \ + '' + + lib.optionalString (lib.meta.availableOn stdenv.hostPlatform chromium) '' --set PUPPETEER_EXECUTABLE_PATH '${lib.getExe chromium}' \ - '' + '' - --add-flags "$out/lib/node_modules/@mermaid-js/mermaid-cli/src/cli.js" + '' + + '' + --add-flags "$out/lib/node_modules/@mermaid-js/mermaid-cli/src/cli.js" - runHook postInstall - ''; + runHook postInstall + ''; meta = { description = "Generation of diagrams from text in a similar manner as markdown"; diff --git a/pkgs/by-name/me/mermaid-filter/package.nix b/pkgs/by-name/me/mermaid-filter/package.nix index 3ed315784569db..d34f0eb5b0b039 100644 --- a/pkgs/by-name/me/mermaid-filter/package.nix +++ b/pkgs/by-name/me/mermaid-filter/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, makeWrapper -, chromium +{ + lib, + buildNpmPackage, + fetchFromGitHub, + makeWrapper, + chromium, }: buildNpmPackage rec { diff --git a/pkgs/by-name/me/mermerd/package.nix b/pkgs/by-name/me/mermerd/package.nix index 5c85ac43ff9d00..7779d2b926f03d 100644 --- a/pkgs/by-name/me/mermerd/package.nix +++ b/pkgs/by-name/me/mermerd/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, mermerd +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + mermerd, }: buildGoModule rec { diff --git a/pkgs/by-name/me/merriweather-sans/package.nix b/pkgs/by-name/me/merriweather-sans/package.nix index 397f42236b52cd..8f1499eb2b8079 100644 --- a/pkgs/by-name/me/merriweather-sans/package.nix +++ b/pkgs/by-name/me/merriweather-sans/package.nix @@ -1,6 +1,7 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub +{ + stdenvNoCC, + lib, + fetchFromGitHub, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/me/merriweather/package.nix b/pkgs/by-name/me/merriweather/package.nix index f658f7943eb29f..a3c3066beb937b 100644 --- a/pkgs/by-name/me/merriweather/package.nix +++ b/pkgs/by-name/me/merriweather/package.nix @@ -1,6 +1,7 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub +{ + stdenvNoCC, + lib, + fetchFromGitHub, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/me/mesa-demos/package.nix b/pkgs/by-name/me/mesa-demos/package.nix index 3ac1ede77eac96..d26fbe799dd5ff 100644 --- a/pkgs/by-name/me/mesa-demos/package.nix +++ b/pkgs/by-name/me/mesa-demos/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchurl -, libglut -, libGL -, libGLU -, libX11 -, libXext -, mesa -, meson -, ninja -, pkg-config -, wayland -, wayland-scanner -, wayland-protocols -, vulkan-loader -, libxkbcommon -, libdecor -, glslang +{ + lib, + stdenv, + fetchurl, + libglut, + libGL, + libGLU, + libX11, + libXext, + mesa, + meson, + ninja, + pkg-config, + wayland, + wayland-scanner, + wayland-protocols, + vulkan-loader, + libxkbcommon, + libdecor, + glslang, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/me/mesa_glu/package.nix b/pkgs/by-name/me/mesa_glu/package.nix index bbcc0bb99a0e74..8925f15e770f48 100644 --- a/pkgs/by-name/me/mesa_glu/package.nix +++ b/pkgs/by-name/me/mesa_glu/package.nix @@ -1,25 +1,39 @@ -{ lib, stdenv, fetchurl -, meson, ninja -, pkg-config, libGLX -, testers -, gitUpdater +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + libGLX, + testers, + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { pname = "glu"; version = "9.0.3"; - src = let - inherit (finalAttrs) pname version; - in fetchurl { - url = "https://mesa.freedesktop.org/archive/${pname}/${pname}-${version}.tar.xz"; - hash = "sha256-vUP+EvN0sRkusV/iDkX/RWubwmq1fw7ukZ+Wyg+KMw8="; - }; + src = + let + inherit (finalAttrs) pname version; + in + fetchurl { + url = "https://mesa.freedesktop.org/archive/${pname}/${pname}-${version}.tar.xz"; + hash = "sha256-vUP+EvN0sRkusV/iDkX/RWubwmq1fw7ukZ+Wyg+KMw8="; + }; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; propagatedBuildInputs = [ libGLX ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; mesonFlags = lib.optionals stdenv.hostPlatform.isDarwin [ "-Dgl_provider=gl" # glvnd is default diff --git a/pkgs/by-name/me/mescc-tools-extra/package.nix b/pkgs/by-name/me/mescc-tools-extra/package.nix index 892c185060e167..b611df378103da 100644 --- a/pkgs/by-name/me/mescc-tools-extra/package.nix +++ b/pkgs/by-name/me/mescc-tools-extra/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, m2libc -, perl +{ + lib, + stdenv, + fetchFromGitHub, + m2libc, + perl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/me/mescc-tools/package.nix b/pkgs/by-name/me/mescc-tools/package.nix index 635e375aa80bd4..18562c71076b53 100644 --- a/pkgs/by-name/me/mescc-tools/package.nix +++ b/pkgs/by-name/me/mescc-tools/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromSavannah -, m2libc -, which +{ + lib, + stdenv, + fetchFromSavannah, + m2libc, + which, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/me/meshoptimizer/package.nix b/pkgs/by-name/me/meshoptimizer/package.nix index 168ee2c7299477..e50aa8eb854382 100644 --- a/pkgs/by-name/me/meshoptimizer/package.nix +++ b/pkgs/by-name/me/meshoptimizer/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, nix-update-script }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + nix-update-script, +}: let basis_universal = fetchFromGitHub { @@ -7,7 +13,8 @@ let rev = "8903f6d69849fd782b72a551a4dd04a264434e20"; hash = "sha256-o3dCxAAkpMoNkvkM7qD75cPn/obDc/fJ8u7KLPm1G6g="; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "meshoptimizer"; version = "0.22"; src = fetchFromGitHub { @@ -19,13 +26,16 @@ in stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; cmakeFlags = [ "-DMESHOPT_BUILD_GLTFPACK=ON" "-DMESHOPT_BASISU_PATH=${basis_universal}" - ] ++ lib.optional (!stdenv.hostPlatform.isStatic) - "-DMESHOPT_BUILD_SHARED_LIBS:BOOL=ON"; + ] ++ lib.optional (!stdenv.hostPlatform.isStatic) "-DMESHOPT_BUILD_SHARED_LIBS:BOOL=ON"; passthru.updateScript = nix-update-script { }; @@ -33,7 +43,10 @@ in stdenv.mkDerivation rec { description = "Mesh optimization library that makes meshes smaller and faster to render"; homepage = "https://github.com/zeux/meshoptimizer"; license = licenses.mit; - maintainers = with maintainers; [ bouk lillycham ]; + maintainers = with maintainers; [ + bouk + lillycham + ]; platforms = platforms.all; mainProgram = "gltfpack"; }; diff --git a/pkgs/by-name/me/meslo-lg/package.nix b/pkgs/by-name/me/meslo-lg/package.nix index e0dc649bc7217a..24864ed71c8620 100644 --- a/pkgs/by-name/me/meslo-lg/package.nix +++ b/pkgs/by-name/me/meslo-lg/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { version = "1.2.1"; @@ -6,15 +11,15 @@ stdenv.mkDerivation rec { pname = "meslo-lg"; meslo-lg = fetchurl { - url="https://github.com/andreberg/Meslo-Font/blob/master/dist/v${version}/Meslo%20LG%20v${version}.zip?raw=true"; - name="${pname}-${version}"; - sha256="1l08mxlzaz3i5bamnfr49s2k4k23vdm64b8nz2ha33ysimkbgg6h"; + url = "https://github.com/andreberg/Meslo-Font/blob/master/dist/v${version}/Meslo%20LG%20v${version}.zip?raw=true"; + name = "${pname}-${version}"; + sha256 = "1l08mxlzaz3i5bamnfr49s2k4k23vdm64b8nz2ha33ysimkbgg6h"; }; meslo-lg-dz = fetchurl { - url="https://github.com/andreberg/Meslo-Font/blob/master/dist/v${version}/Meslo%20LG%20DZ%20v${version}.zip?raw=true"; - name="${pname}-${version}-dz"; - sha256="0lnbkrvcpgz9chnvix79j6fiz36wj6n46brb7b1746182rl1l875"; + url = "https://github.com/andreberg/Meslo-Font/blob/master/dist/v${version}/Meslo%20LG%20DZ%20v${version}.zip?raw=true"; + name = "${pname}-${version}-dz"; + sha256 = "0lnbkrvcpgz9chnvix79j6fiz36wj6n46brb7b1746182rl1l875"; }; nativeBuildInputs = [ unzip ]; diff --git a/pkgs/by-name/me/meslo-lgs-nf/package.nix b/pkgs/by-name/me/meslo-lgs-nf/package.nix index 51dacaba366c2c..7e6b554455ee00 100644 --- a/pkgs/by-name/me/meslo-lgs-nf/package.nix +++ b/pkgs/by-name/me/meslo-lgs-nf/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "meslo-lgs-nf"; diff --git a/pkgs/by-name/me/meson-tools/package.nix b/pkgs/by-name/me/meson-tools/package.nix index 78e8549807917a..0cba7cacf63a04 100644 --- a/pkgs/by-name/me/meson-tools/package.nix +++ b/pkgs/by-name/me/meson-tools/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + openssl, +}: stdenv.mkDerivation rec { pname = "meson-tools"; diff --git a/pkgs/by-name/me/meson/package.nix b/pkgs/by-name/me/meson/package.nix index 2b68f1e5078ed8..052ebf269630c7 100644 --- a/pkgs/by-name/me/meson/package.nix +++ b/pkgs/by-name/me/meson/package.nix @@ -1,22 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles -, coreutils -, darwin -, libblocksruntime -, llvmPackages -, libxcrypt -, openldap -, ninja -, pkg-config -, python3 -, substituteAll -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + coreutils, + darwin, + libblocksruntime, + llvmPackages, + libxcrypt, + openldap, + ninja, + pkg-config, + python3, + substituteAll, + zlib, }: let - inherit (darwin.apple_sdk.frameworks) AppKit Cocoa Foundation LDAP OpenAL OpenGL; + inherit (darwin.apple_sdk.frameworks) + AppKit + Cocoa + Foundation + LDAP + OpenAL + OpenGL + ; in python3.pkgs.buildPythonApplication rec { pname = "meson"; @@ -86,56 +94,64 @@ python3.pkgs.buildPythonApplication rec { pkg-config ]; - checkInputs = [ - zlib - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - Cocoa - Foundation - LDAP - OpenAL - OpenGL - openldap - ] ++ lib.optionals (stdenv.cc.isClang && !stdenv.hostPlatform.isDarwin) [ - # https://github.com/mesonbuild/meson/blob/bd3f1b2e0e70ef16dfa4f441686003212440a09b/test%20cases/common/184%20openmp/meson.build - llvmPackages.openmp - # https://github.com/mesonbuild/meson/blob/1670fca36fcb1a4fe4780e96731e954515501a35/test%20cases/frameworks/29%20blocks/meson.build - libblocksruntime - ]; - - checkPhase = lib.concatStringsSep "\n" ([ - "runHook preCheck" - '' - patchShebangs 'test cases' - substituteInPlace \ - 'test cases/native/8 external program shebang parsing/script.int.in' \ - 'test cases/common/274 customtarget exe for test/generate.py' \ - --replace /usr/bin/env ${coreutils}/bin/env - '' - ] - # Remove problematic tests - ++ (builtins.map (f: ''rm -vr "${f}";'') ([ - # requires git, creating cyclic dependency - ''test cases/common/66 vcstag'' - # requires glib, creating cyclic dependency - ''test cases/linuxlike/6 subdir include order'' - ''test cases/linuxlike/9 compiler checks with dependencies'' - # requires static zlib, see #66461 - ''test cases/linuxlike/14 static dynamic linkage'' - # Nixpkgs cctools does not have bitcode support. - ''test cases/osx/7 bitcode'' - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # requires llvmPackages.openmp, creating cyclic dependency - ''test cases/common/184 openmp'' - ] ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ - # pch doesn't work quite right on FreeBSD, I think - ''test cases/common/13 pch'' - ])) - ++ [ - ''HOME="$TMPDIR" python ./run_project_tests.py'' - "runHook postCheck" - ]); + checkInputs = + [ + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + Cocoa + Foundation + LDAP + OpenAL + OpenGL + openldap + ] + ++ lib.optionals (stdenv.cc.isClang && !stdenv.hostPlatform.isDarwin) [ + # https://github.com/mesonbuild/meson/blob/bd3f1b2e0e70ef16dfa4f441686003212440a09b/test%20cases/common/184%20openmp/meson.build + llvmPackages.openmp + # https://github.com/mesonbuild/meson/blob/1670fca36fcb1a4fe4780e96731e954515501a35/test%20cases/frameworks/29%20blocks/meson.build + libblocksruntime + ]; + + checkPhase = lib.concatStringsSep "\n" ( + [ + "runHook preCheck" + '' + patchShebangs 'test cases' + substituteInPlace \ + 'test cases/native/8 external program shebang parsing/script.int.in' \ + 'test cases/common/274 customtarget exe for test/generate.py' \ + --replace /usr/bin/env ${coreutils}/bin/env + '' + ] + # Remove problematic tests + ++ (builtins.map (f: ''rm -vr "${f}";'') ( + [ + # requires git, creating cyclic dependency + ''test cases/common/66 vcstag'' + # requires glib, creating cyclic dependency + ''test cases/linuxlike/6 subdir include order'' + ''test cases/linuxlike/9 compiler checks with dependencies'' + # requires static zlib, see #66461 + ''test cases/linuxlike/14 static dynamic linkage'' + # Nixpkgs cctools does not have bitcode support. + ''test cases/osx/7 bitcode'' + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # requires llvmPackages.openmp, creating cyclic dependency + ''test cases/common/184 openmp'' + ] + ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ + # pch doesn't work quite right on FreeBSD, I think + ''test cases/common/13 pch'' + ] + )) + ++ [ + ''HOME="$TMPDIR" python ./run_project_tests.py'' + "runHook postCheck" + ] + ); postInstall = '' installShellCompletion --zsh data/shell-completions/zsh/_meson diff --git a/pkgs/by-name/me/mesos-dns/package.nix b/pkgs/by-name/me/mesos-dns/package.nix index 52f6ba74fd8951..080a00d41acfc3 100644 --- a/pkgs/by-name/me/mesos-dns/package.nix +++ b/pkgs/by-name/me/mesos-dns/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "mesos-dns"; @@ -15,7 +19,10 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://m3scluster.github.io/mesos-dns/"; diff --git a/pkgs/by-name/me/messer-slim/package.nix b/pkgs/by-name/me/messer-slim/package.nix index 24b9a96019da67..6c90806992edf3 100644 --- a/pkgs/by-name/me/messer-slim/package.nix +++ b/pkgs/by-name/me/messer-slim/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, gcc, gcc-unwrapped }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gcc, + gcc-unwrapped, +}: stdenv.mkDerivation rec { version = "4.3"; @@ -11,16 +18,22 @@ stdenv.mkDerivation rec { hash = "sha256-Hgh1ianEdITRUIDKLiLW32kQlPlXKIfN4PSv3cOXTGI="; }; - nativeBuildInputs = [ cmake gcc gcc-unwrapped ]; + nativeBuildInputs = [ + cmake + gcc + gcc-unwrapped + ]; - cmakeFlags = [ "-DCMAKE_AR=${gcc-unwrapped}/bin/gcc-ar" - "-DCMAKE_RANLIB=${gcc-unwrapped}/bin/gcc-ranlib" ]; + cmakeFlags = [ + "-DCMAKE_AR=${gcc-unwrapped}/bin/gcc-ar" + "-DCMAKE_RANLIB=${gcc-unwrapped}/bin/gcc-ranlib" + ]; meta = { - description = "Evolutionary simulation framework"; - homepage = "https://messerlab.org/slim/"; - license = with lib.licenses; [ gpl3 ]; - maintainers = with lib.maintainers; [ bzizou ]; - platforms = lib.platforms.all; + description = "Evolutionary simulation framework"; + homepage = "https://messerlab.org/slim/"; + license = with lib.licenses; [ gpl3 ]; + maintainers = with lib.maintainers; [ bzizou ]; + platforms = lib.platforms.all; }; } diff --git a/pkgs/by-name/me/metaBuildEnv/package.nix b/pkgs/by-name/me/metaBuildEnv/package.nix index 195f0c0e36f89c..4b23dbd32b594e 100644 --- a/pkgs/by-name/me/metaBuildEnv/package.nix +++ b/pkgs/by-name/me/metaBuildEnv/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "meta-build-env"; diff --git a/pkgs/by-name/me/metabigor/package.nix b/pkgs/by-name/me/metabigor/package.nix index 2949fb6db54145..5230006d135947 100644 --- a/pkgs/by-name/me/metabigor/package.nix +++ b/pkgs/by-name/me/metabigor/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/me/metadata-cleaner/package.nix b/pkgs/by-name/me/metadata-cleaner/package.nix index 9c596eef9cd483..30226f6bee1035 100644 --- a/pkgs/by-name/me/metadata-cleaner/package.nix +++ b/pkgs/by-name/me/metadata-cleaner/package.nix @@ -1,19 +1,20 @@ -{ lib -, python3 -, fetchFromGitLab -, appstream -, desktop-file-utils -, glib -, gobject-introspection -, gtk4 -, itstool -, libadwaita -, librsvg -, meson -, ninja -, pkg-config -, poppler_gi -, wrapGAppsHook4 +{ + lib, + python3, + fetchFromGitLab, + appstream, + desktop-file-utils, + glib, + gobject-introspection, + gtk4, + itstool, + libadwaita, + librsvg, + meson, + ninja, + pkg-config, + poppler_gi, + wrapGAppsHook4, }: python3.pkgs.buildPythonApplication rec { @@ -60,7 +61,10 @@ python3.pkgs.buildPythonApplication rec { mainProgram = "metadata-cleaner"; homepage = "https://gitlab.com/rmnvgr/metadata-cleaner"; changelog = "https://gitlab.com/rmnvgr/metadata-cleaner/-/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ gpl3Plus cc-by-sa-40 ]; + license = with licenses; [ + gpl3Plus + cc-by-sa-40 + ]; maintainers = with maintainers; [ dotlambda ]; }; } diff --git a/pkgs/by-name/me/metadata/package.nix b/pkgs/by-name/me/metadata/package.nix index d9d71da6508798..97130d30758bae 100644 --- a/pkgs/by-name/me/metadata/package.nix +++ b/pkgs/by-name/me/metadata/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, pkg-config -, ffmpeg -, rustPlatform -, glib -, installShellFiles -, asciidoc +{ + lib, + fetchFromGitHub, + fetchpatch, + pkg-config, + ffmpeg, + rustPlatform, + glib, + installShellFiles, + asciidoc, }: rustPlatform.buildRustPackage rec { pname = "metadata"; diff --git a/pkgs/by-name/me/metal-cli/package.nix b/pkgs/by-name/me/metal-cli/package.nix index 62b69b6318ff44..b13d6bb0d162ee 100644 --- a/pkgs/by-name/me/metal-cli/package.nix +++ b/pkgs/by-name/me/metal-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -39,7 +40,7 @@ buildGoModule rec { doInstallCheck = true; installCheckPhase = '' - $out/bin/metal --version | grep ${version} + $out/bin/metal --version | grep ${version} ''; meta = with lib; { @@ -47,7 +48,11 @@ buildGoModule rec { homepage = "https://github.com/equinix/metal-cli/"; changelog = "https://github.com/equinix/metal-cli/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ Br1ght0ne nshalman teutat3s ]; + maintainers = with maintainers; [ + Br1ght0ne + nshalman + teutat3s + ]; mainProgram = "metal"; }; } diff --git a/pkgs/by-name/me/metals/package.nix b/pkgs/by-name/me/metals/package.nix index 7a84f3b8c1d5e4..2dab427762640f 100644 --- a/pkgs/by-name/me/metals/package.nix +++ b/pkgs/by-name/me/metals/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, coursier, jre, makeWrapper, setJavaClassPath }: +{ + stdenv, + lib, + coursier, + jre, + makeWrapper, + setJavaClassPath, +}: stdenv.mkDerivation rec { pname = "metals"; @@ -19,7 +26,10 @@ stdenv.mkDerivation rec { outputHash = "sha256-CVAPjeTYuv0w57EK/IldJcGz8mTQnyCGAjaUf6La2rU="; }; - nativeBuildInputs = [ makeWrapper setJavaClassPath ]; + nativeBuildInputs = [ + makeWrapper + setJavaClassPath + ]; buildInputs = [ deps ]; dontUnpack = true; @@ -38,6 +48,10 @@ stdenv.mkDerivation rec { license = licenses.asl20; description = "Language server for Scala"; mainProgram = "metals"; - maintainers = with maintainers; [ fabianhjr jpaju tomahna ]; + maintainers = with maintainers; [ + fabianhjr + jpaju + tomahna + ]; }; } diff --git a/pkgs/by-name/me/metamath/package.nix b/pkgs/by-name/me/metamath/package.nix index 3d36b8501f10c5..884aa8ab48143c 100644 --- a/pkgs/by-name/me/metamath/package.nix +++ b/pkgs/by-name/me/metamath/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "metamath"; diff --git a/pkgs/by-name/me/metamorphose2/package.nix b/pkgs/by-name/me/metamorphose2/package.nix index 344376b985a6c3..6d997bc327cf0e 100644 --- a/pkgs/by-name/me/metamorphose2/package.nix +++ b/pkgs/by-name/me/metamorphose2/package.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, gettext -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + gettext, + python3, }: stdenv.mkDerivation { @@ -29,16 +34,21 @@ stdenv.mkDerivation { ''; nativeBuildInputs = [ makeWrapper ]; - propagatedBuildInputs = with python3.pkgs; [ mutagen wxpython pillow six ]; + propagatedBuildInputs = with python3.pkgs; [ + mutagen + wxpython + pillow + six + ]; makeFlags = [ "PREFIX=$(out)" ]; meta = with lib; { description = "Graphical mass renaming program for files and folders"; - homepage = "https://github.com/timinaust/metamorphose2"; - license = with licenses; gpl3Plus; + homepage = "https://github.com/timinaust/metamorphose2"; + license = with licenses; gpl3Plus; maintainers = with maintainers; [ ramkromberg ]; - platforms = with platforms; linux; + platforms = with platforms; linux; mainProgram = "metamorphose2"; }; } diff --git a/pkgs/by-name/me/metapixel/package.nix b/pkgs/by-name/me/metapixel/package.nix index 8c9fef0cd484d1..f4599e568112c4 100644 --- a/pkgs/by-name/me/metapixel/package.nix +++ b/pkgs/by-name/me/metapixel/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, libpng, libjpeg, giflib, perl, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + libpng, + libjpeg, + giflib, + perl, + pkg-config, +}: stdenv.mkDerivation rec { pname = "metapixel"; @@ -15,7 +24,12 @@ stdenv.mkDerivation rec { makeFlags = [ "metapixel" ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libpng libjpeg giflib perl ]; + buildInputs = [ + libpng + libjpeg + giflib + perl + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/me/metar/package.nix b/pkgs/by-name/me/metar/package.nix index d1edfb6a761f16..9f7defda371d23 100644 --- a/pkgs/by-name/me/metar/package.nix +++ b/pkgs/by-name/me/metar/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, curl }: +{ + lib, + stdenv, + fetchFromGitHub, + curl, +}: stdenv.mkDerivation { pname = "metar"; diff --git a/pkgs/by-name/me/metastore/package.nix b/pkgs/by-name/me/metastore/package.nix index 999c771fcfafba..32d85ff6cc4ea0 100644 --- a/pkgs/by-name/me/metastore/package.nix +++ b/pkgs/by-name/me/metastore/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, libbsd, fetchFromGitHub }: +{ + lib, + stdenv, + libbsd, + fetchFromGitHub, +}: stdenv.mkDerivation rec { version = "1.1.2"; diff --git a/pkgs/by-name/me/meteo/package.nix b/pkgs/by-name/me/meteo/package.nix index 226c8078c64e15..bc24c52e249d3f 100644 --- a/pkgs/by-name/me/meteo/package.nix +++ b/pkgs/by-name/me/meteo/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitLab -, nix-update-script -, appstream -, desktop-file-utils -, meson -, ninja -, pkg-config -, python3 -, vala -, wrapGAppsHook3 -, glib -, glib-networking -, gtk3 -, json-glib -, libappindicator -, libsoup_2_4 -, webkitgtk_4_0 +{ + lib, + stdenv, + fetchFromGitLab, + nix-update-script, + appstream, + desktop-file-utils, + meson, + ninja, + pkg-config, + python3, + vala, + wrapGAppsHook3, + glib, + glib-networking, + gtk3, + json-glib, + libappindicator, + libsoup_2_4, + webkitgtk_4_0, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/me/meterbridge/package.nix b/pkgs/by-name/me/meterbridge/package.nix index 93e2bfabd175c5..3d285d4d8bc4e0 100644 --- a/pkgs/by-name/me/meterbridge/package.nix +++ b/pkgs/by-name/me/meterbridge/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, SDL, SDL_image, libjack2 +{ + lib, + stdenv, + fetchurl, + pkg-config, + SDL, + SDL_image, + libjack2, }: stdenv.mkDerivation rec { @@ -10,12 +17,17 @@ stdenv.mkDerivation rec { sha256 = "0s7n3czfpil94vsd7iblv4xrck9c7zvsz4r3yfbkqcv85pjz1viz"; }; - patches = [ ./buf_rect.patch ./fix_build_with_gcc-5.patch]; + patches = [ + ./buf_rect.patch + ./fix_build_with_gcc-5.patch + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = - [ SDL SDL_image libjack2 - ]; + buildInputs = [ + SDL + SDL_image + libjack2 + ]; meta = with lib; { description = "Various meters (VU, PPM, DPM, JF, SCO) for Jack Audio Connection Kit"; diff --git a/pkgs/by-name/me/metersLv2/package.nix b/pkgs/by-name/me/metersLv2/package.nix index d4dbcf210ec917..beeaeb4f5ebfbe 100644 --- a/pkgs/by-name/me/metersLv2/package.nix +++ b/pkgs/by-name/me/metersLv2/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, lv2 -, libGLU -, libGL -, gtk2 -, cairo -, pango -, fftwFloat -, libjack2 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + lv2, + libGLU, + libGL, + gtk2, + cairo, + pango, + fftwFloat, + libjack2, }: stdenv.mkDerivation rec { @@ -18,7 +19,16 @@ stdenv.mkDerivation rec { robtkVersion = "0.7.5"; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ lv2 libGLU libGL gtk2 cairo pango fftwFloat libjack2 ]; + buildInputs = [ + lv2 + libGLU + libGL + gtk2 + cairo + pango + fftwFloat + libjack2 + ]; src = fetchFromGitHub { owner = "x42"; diff --git a/pkgs/by-name/me/methane/package.nix b/pkgs/by-name/me/methane/package.nix index e1590859837fbc..2840b9b048c177 100644 --- a/pkgs/by-name/me/methane/package.nix +++ b/pkgs/by-name/me/methane/package.nix @@ -22,7 +22,7 @@ libXinerama, }: -stdenv.mkDerivation (finalAttrs:{ +stdenv.mkDerivation (finalAttrs: { pname = "methane"; version = "2.1.0"; diff --git a/pkgs/by-name/me/metis-prover/package.nix b/pkgs/by-name/me/metis-prover/package.nix index bd6f71860bdb9d..a3062131c95fc9 100644 --- a/pkgs/by-name/me/metis-prover/package.nix +++ b/pkgs/by-name/me/metis-prover/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, perl, mlton }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, + mlton, +}: stdenv.mkDerivation { pname = "metis-prover"; diff --git a/pkgs/by-name/me/metis/package.nix b/pkgs/by-name/me/metis/package.nix index cd221e86b1486f..bf8a631b51777c 100644 --- a/pkgs/by-name/me/metis/package.nix +++ b/pkgs/by-name/me/metis/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, unzip, cmake }: +{ + lib, + stdenv, + fetchurl, + unzip, + cmake, +}: stdenv.mkDerivation rec { pname = "metis"; @@ -14,7 +20,10 @@ stdenv.mkDerivation rec { # remove once updated past https://github.com/KarypisLab/METIS/commit/521a2c360dc21ace5c4feb6dc0b7992433e3cb0f "-DCMAKE_SKIP_BUILD_RPATH=ON" ]; - nativeBuildInputs = [ unzip cmake ]; + nativeBuildInputs = [ + unzip + cmake + ]; meta = { description = "Serial graph partitioning and fill-reducing matrix ordering"; diff --git a/pkgs/by-name/me/metronome/package.nix b/pkgs/by-name/me/metronome/package.nix index 6c75f65dd3d7a3..9c78def4493184 100644 --- a/pkgs/by-name/me/metronome/package.nix +++ b/pkgs/by-name/me/metronome/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, cargo -, wrapGAppsHook4 -, desktop-file-utils -, libadwaita -, gst_all_1 -, darwin +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + cargo, + wrapGAppsHook4, + desktop-file-utils, + libadwaita, + gst_all_1, + darwin, }: stdenv.mkDerivation rec { @@ -43,23 +44,22 @@ stdenv.mkDerivation rec { desktop-file-utils ]; - buildInputs = [ - libadwaita - gst_all_1.gstreamer - gst_all_1.gst-plugins-base - gst_all_1.gst-plugins-bad - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + libadwaita + gst_all_1.gstreamer + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-bad + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ]; # Workaround for the gettext-sys issue # https://github.com/Koka/gettext-rs/issues/114 - env.NIX_CFLAGS_COMPILE = lib.optionalString - ( - stdenv.cc.isClang && - lib.versionAtLeast stdenv.cc.version "16" - ) - "-Wno-error=incompatible-function-pointer-types"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.cc.isClang && lib.versionAtLeast stdenv.cc.version "16" + ) "-Wno-error=incompatible-function-pointer-types"; meta = with lib; { description = "Keep the tempo"; diff --git a/pkgs/by-name/me/mev-boost/package.nix b/pkgs/by-name/me/mev-boost/package.nix index 4e66b0e49f6d4c..f99e1b0ce3fb4f 100644 --- a/pkgs/by-name/me/mev-boost/package.nix +++ b/pkgs/by-name/me/mev-boost/package.nix @@ -1,16 +1,17 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "mev-boost"; version = "1.8"; src = fetchFromGitHub { - owner = "flashbots"; - repo = "mev-boost"; - rev = "v${version}"; - hash = "sha256-EFPVBSSIef3cTrYp3X1xCEOtYcGpuW/GZXHXX+0wGd8="; + owner = "flashbots"; + repo = "mev-boost"; + rev = "v${version}"; + hash = "sha256-EFPVBSSIef3cTrYp3X1xCEOtYcGpuW/GZXHXX+0wGd8="; }; vendorHash = "sha256-xkncfaqNfgPt5LEQ3JyYXHHq6slOUchomzqwkZCgCOM="; diff --git a/pkgs/by-name/mf/mfc465cncupswrapper/package.nix b/pkgs/by-name/mf/mfc465cncupswrapper/package.nix index c64e48a86ce846..89626b1f3c2867 100644 --- a/pkgs/by-name/mf/mfc465cncupswrapper/package.nix +++ b/pkgs/by-name/mf/mfc465cncupswrapper/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, dpkg -, makeWrapper -, coreutils -, gnugrep -, gnused -, mfc465cnlpr -, pkgsi686Linux -, psutils +{ + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + coreutils, + gnugrep, + gnused, + mfc465cnlpr, + pkgsi686Linux, + psutils, }: stdenv.mkDerivation rec { @@ -67,9 +68,15 @@ stdenv.mkDerivation rec { ln $dir/cupswrapper/cupswrappermfc465cn $out/lib/cups/filter ln $dir/cupswrapper/brmfc465.ppd $out/share/cups/model sed -n '/!ENDOFWFILTER!/,/!ENDOFWFILTER!/p' "$dir/cupswrapper/cupswrappermfc465cn" | sed '1 br; b; :r s/.*/printer_model=mfc465cn; cat < $out/lib/cups/filter/brlpdwrappermfc465cn - sed -i "/#! \/bin\/sh/a PATH=${lib.makeBinPath [ coreutils gnused gnugrep ]}:\$PATH" $out/lib/cups/filter/brlpdwrappermfc465cn + sed -i "/#! \/bin\/sh/a PATH=${ + lib.makeBinPath [ + coreutils + gnused + gnugrep + ] + }:\$PATH" $out/lib/cups/filter/brlpdwrappermfc465cn chmod 755 $out/lib/cups/filter/brlpdwrappermfc465cn - ''; + ''; meta = with lib; { description = "Brother MFC-465CN CUPS wrapper driver"; diff --git a/pkgs/by-name/mf/mfc465cnlpr/package.nix b/pkgs/by-name/mf/mfc465cnlpr/package.nix index dc0be00a693281..0a86b518db4956 100644 --- a/pkgs/by-name/mf/mfc465cnlpr/package.nix +++ b/pkgs/by-name/mf/mfc465cnlpr/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchurl -, dpkg -, makeWrapper -, coreutils -, file -, gawk -, ghostscript -, gnused -, pkgsi686Linux +{ + stdenv, + lib, + fetchurl, + dpkg, + makeWrapper, + coreutils, + file, + gawk, + ghostscript, + gnused, + pkgsi686Linux, }: stdenv.mkDerivation rec { @@ -35,25 +36,31 @@ stdenv.mkDerivation rec { dir=$out/usr/local/Brother/Printer/mfc465cn patchelf --set-interpreter ${pkgsi686Linux.glibc.out}/lib/ld-linux.so.2 $dir/lpd/brmfc465cnfilter wrapProgram $dir/inf/setupPrintcapij \ - --prefix PATH : ${lib.makeBinPath [ - coreutils - ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + ] + } substituteInPlace $dir/lpd/filtermfc465cn \ --replace "BR_PRT_PATH=" "BR_PRT_PATH=\"$dir/\" #" wrapProgram $dir/lpd/filtermfc465cn \ - --prefix PATH : ${lib.makeBinPath [ - coreutils - file - ghostscript - gnused - ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + file + ghostscript + gnused + ] + } substituteInPlace $dir/lpd/psconvertij2 \ --replace '`which gs`' "${ghostscript}/bin/gs" wrapProgram $dir/lpd/psconvertij2 \ - --prefix PATH : ${lib.makeBinPath [ - gnused - gawk - ]} + --prefix PATH : ${ + lib.makeBinPath [ + gnused + gawk + ] + } chmod -R a+w $dir/inf/ ''; @@ -62,6 +69,9 @@ stdenv.mkDerivation rec { homepage = "http://www.brother.com/"; license = licenses.unfree; maintainers = with maintainers; [ phrogg ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/mf/mfc5890cncupswrapper/package.nix b/pkgs/by-name/mf/mfc5890cncupswrapper/package.nix index 2b265498ac6d02..88607d736cef97 100644 --- a/pkgs/by-name/mf/mfc5890cncupswrapper/package.nix +++ b/pkgs/by-name/mf/mfc5890cncupswrapper/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, dpkg -, makeWrapper -, coreutils -, gnugrep -, gnused -, mfc5890cnlpr -, pkgsi686Linux -, psutils +{ + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + coreutils, + gnugrep, + gnused, + mfc5890cnlpr, + pkgsi686Linux, + psutils, }: stdenv.mkDerivation rec { @@ -54,14 +55,21 @@ stdenv.mkDerivation rec { $dir/cupswrapper/cupswrappermfc5890cn chmod +x $out/usr/lib64/cups/filter/brlpdwrappermfc5890cn - wrapProgram $out/usr/lib64/cups/filter/brlpdwrappermfc5890cn --prefix PATH : ${lib.makeBinPath [coreutils psutils gnugrep gnused]} + wrapProgram $out/usr/lib64/cups/filter/brlpdwrappermfc5890cn --prefix PATH : ${ + lib.makeBinPath [ + coreutils + psutils + gnugrep + gnused + ] + } mkdir -p $out/lib/cups/filter mkdir -p $out/share/cups/model ln $out/usr/lib64/cups/filter/brlpdwrappermfc5890cn $out/lib/cups/filter ln $dir/cupswrapper/cupswrappermfc5890cn $out/lib/cups/filter ln $out/usr/share/ppd/brmfc5890cn.ppd $out/share/cups/model - ''; + ''; meta = with lib; { description = "Brother MFC-5890CN CUPS wrapper driver"; diff --git a/pkgs/by-name/mf/mfc5890cnlpr/package.nix b/pkgs/by-name/mf/mfc5890cnlpr/package.nix index 7878d77afc0438..225b04ea6e1765 100644 --- a/pkgs/by-name/mf/mfc5890cnlpr/package.nix +++ b/pkgs/by-name/mf/mfc5890cnlpr/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, a2ps -, lib -, fetchurl -, dpkg -, makeWrapper -, coreutils -, file -, gawk -, ghostscript -, gnused -, pkgsi686Linux +{ + stdenv, + a2ps, + lib, + fetchurl, + dpkg, + makeWrapper, + coreutils, + file, + gawk, + ghostscript, + gnused, + pkgsi686Linux, }: stdenv.mkDerivation rec { @@ -38,30 +39,36 @@ stdenv.mkDerivation rec { patchelf --set-interpreter ${pkgsi686Linux.glibc.out}/lib/ld-linux.so.2 $dir/lpd/brmfc5890cnfilter wrapProgram $dir/inf/setupPrintcapij \ - --prefix PATH : ${lib.makeBinPath [ - coreutils - ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + ] + } substituteInPlace $dir/lpd/filtermfc5890cn \ --replace "/usr/" "$out/usr/" wrapProgram $dir/lpd/filtermfc5890cn \ - --prefix PATH : ${lib.makeBinPath [ - a2ps - coreutils - file - ghostscript - gnused - ]} + --prefix PATH : ${ + lib.makeBinPath [ + a2ps + coreutils + file + ghostscript + gnused + ] + } substituteInPlace $dir/lpd/psconvertij2 \ --replace '`which gs`' "${ghostscript}/bin/gs" wrapProgram $dir/lpd/psconvertij2 \ - --prefix PATH : ${lib.makeBinPath [ - gnused - gawk - ]} + --prefix PATH : ${ + lib.makeBinPath [ + gnused + gawk + ] + } ''; meta = with lib; { @@ -70,6 +77,9 @@ stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; maintainers = with maintainers; [ martinramm ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/mf/mfc9140cdncupswrapper/package.nix b/pkgs/by-name/mf/mfc9140cdncupswrapper/package.nix index c38b5261865155..7534a623802458 100644 --- a/pkgs/by-name/mf/mfc9140cdncupswrapper/package.nix +++ b/pkgs/by-name/mf/mfc9140cdncupswrapper/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, dpkg -, makeWrapper -, coreutils -, gnugrep -, gnused -, mfc9140cdnlpr -, pkgsi686Linux -, psutils +{ + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + coreutils, + gnugrep, + gnused, + mfc9140cdnlpr, + pkgsi686Linux, + psutils, }: stdenv.mkDerivation rec { @@ -54,9 +55,15 @@ stdenv.mkDerivation rec { ln $dir/cupswrapper/brother_mfc9140cdn_printer_en.ppd $out/share/cups/model sed -n '/!ENDOFWFILTER!/,/!ENDOFWFILTER!/p' "$dir/cupswrapper/cupswrappermfc9140cdn" | sed '1 br; b; :r s/.*/printer_model=mfc9140cdn; cat < $out/lib/cups/filter/brother_lpdwrapper_mfc9140cdn - sed -i "/#! \/bin\/sh/a PATH=${lib.makeBinPath [ coreutils gnused gnugrep ]}:\$PATH" $out/lib/cups/filter/brother_lpdwrapper_mfc9140cdn + sed -i "/#! \/bin\/sh/a PATH=${ + lib.makeBinPath [ + coreutils + gnused + gnugrep + ] + }:\$PATH" $out/lib/cups/filter/brother_lpdwrapper_mfc9140cdn chmod +x $out/lib/cups/filter/brother_lpdwrapper_mfc9140cdn - ''; + ''; meta = with lib; { description = "Brother MFC-9140CDN CUPS wrapper driver"; diff --git a/pkgs/by-name/mf/mfc9140cdnlpr/package.nix b/pkgs/by-name/mf/mfc9140cdnlpr/package.nix index ab20016c7ff0be..9092d2073807fc 100644 --- a/pkgs/by-name/mf/mfc9140cdnlpr/package.nix +++ b/pkgs/by-name/mf/mfc9140cdnlpr/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchurl -, dpkg -, makeWrapper -, coreutils -, file -, gawk -, ghostscript -, gnused -, pkgsi686Linux +{ + stdenv, + lib, + fetchurl, + dpkg, + makeWrapper, + coreutils, + file, + gawk, + ghostscript, + gnused, + pkgsi686Linux, }: stdenv.mkDerivation rec { @@ -37,30 +38,36 @@ stdenv.mkDerivation rec { patchelf --set-interpreter ${pkgsi686Linux.glibc.out}/lib/ld-linux.so.2 $dir/lpd/brmfc9140cdnfilter wrapProgram $dir/inf/setupPrintcapij \ - --prefix PATH : ${lib.makeBinPath [ - coreutils - ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + ] + } substituteInPlace $dir/lpd/filtermfc9140cdn \ --replace "BR_CFG_PATH=" "BR_CFG_PATH=\"$dir/\" #" \ --replace "BR_LPD_PATH=" "BR_LPD_PATH=\"$dir/\" #" wrapProgram $dir/lpd/filtermfc9140cdn \ - --prefix PATH : ${lib.makeBinPath [ - coreutils - file - ghostscript - gnused - ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + file + ghostscript + gnused + ] + } substituteInPlace $dir/lpd/psconvertij2 \ --replace '`which gs`' "${ghostscript}/bin/gs" wrapProgram $dir/lpd/psconvertij2 \ - --prefix PATH : ${lib.makeBinPath [ - gnused - gawk - ]} + --prefix PATH : ${ + lib.makeBinPath [ + gnused + gawk + ] + } ''; meta = with lib; { @@ -69,6 +76,9 @@ stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; maintainers = with maintainers; [ hexa ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/mf/mfcj470dw-cupswrapper/package.nix b/pkgs/by-name/mf/mfcj470dw-cupswrapper/package.nix index c629a4918901db..393967c59acdcf 100644 --- a/pkgs/by-name/mf/mfcj470dw-cupswrapper/package.nix +++ b/pkgs/by-name/mf/mfcj470dw-cupswrapper/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, mfcj470dwlpr, makeWrapper, bash }: +{ + lib, + stdenv, + fetchurl, + mfcj470dwlpr, + makeWrapper, + bash, +}: stdenv.mkDerivation rec { pname = "mfcj470dw-cupswrapper"; @@ -14,7 +21,11 @@ stdenv.mkDerivation rec { bash # shebang ]; - makeFlags = [ "-C" "brcupsconfpt1" "all" ]; + makeFlags = [ + "-C" + "brcupsconfpt1" + "all" + ]; postPatch = '' WRAPPER=cupswrapper/cupswrappermfcj470dw diff --git a/pkgs/by-name/mf/mfcj6510dw-cupswrapper/package.nix b/pkgs/by-name/mf/mfcj6510dw-cupswrapper/package.nix index aead095635b392..eefc4294c4b764 100644 --- a/pkgs/by-name/mf/mfcj6510dw-cupswrapper/package.nix +++ b/pkgs/by-name/mf/mfcj6510dw-cupswrapper/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, mfcj6510dwlpr, makeWrapper, bash }: +{ + lib, + stdenv, + fetchurl, + mfcj6510dwlpr, + makeWrapper, + bash, +}: stdenv.mkDerivation rec { pname = "mfcj6510dw-cupswrapper"; @@ -14,7 +21,11 @@ stdenv.mkDerivation rec { bash # shebang ]; - makeFlags = [ "-C" "brcupsconfig" "all" ]; + makeFlags = [ + "-C" + "brcupsconfig" + "all" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/mf/mfcj880dwcupswrapper/package.nix b/pkgs/by-name/mf/mfcj880dwcupswrapper/package.nix index 5fbc3948f03250..46b484e657875e 100644 --- a/pkgs/by-name/mf/mfcj880dwcupswrapper/package.nix +++ b/pkgs/by-name/mf/mfcj880dwcupswrapper/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, mfcj880dwlpr, makeWrapper, bash }: +{ + lib, + stdenv, + fetchurl, + mfcj880dwlpr, + makeWrapper, + bash, +}: stdenv.mkDerivation rec { pname = "mfcj880dw-cupswrapper"; @@ -14,7 +21,11 @@ stdenv.mkDerivation rec { bash # shebang ]; - makeFlags = [ "-C" "brcupsconfig" "all" ]; + makeFlags = [ + "-C" + "brcupsconfig" + "all" + ]; installPhase = '' runHook preInstall @@ -33,7 +44,7 @@ stdenv.mkDerivation rec { ln -s ${mfcj880dwlpr}/lib/cups/filter/brother_lpdwrapper_mfcj880dw $out/lib/cups/filter/brother_lpdwrapper_mfcj880dw runHook postInstall - ''; + ''; meta = with lib; { homepage = "http://www.brother.com/"; diff --git a/pkgs/by-name/mf/mfcj880dwlpr/package.nix b/pkgs/by-name/mf/mfcj880dwlpr/package.nix index a1d0a9c44f0642..7948c720fcbd33 100644 --- a/pkgs/by-name/mf/mfcj880dwlpr/package.nix +++ b/pkgs/by-name/mf/mfcj880dwlpr/package.nix @@ -1,5 +1,21 @@ -{ lib, stdenv, fetchurl, pkgsi686Linux, dpkg, makeWrapper, coreutils, gnused, gawk, file, cups, util-linux, xxd, runtimeShell -, ghostscript, a2ps }: +{ + lib, + stdenv, + fetchurl, + pkgsi686Linux, + dpkg, + makeWrapper, + coreutils, + gnused, + gawk, + file, + cups, + util-linux, + xxd, + runtimeShell, + ghostscript, + a2ps, +}: # Why: # The executable "brprintconf_mfcj880dw" binary is looking for "/opt/brother/Printers/%s/inf/br%sfunc" and "/opt/brother/Printers/%s/inf/br%src". @@ -29,7 +45,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ cups ghostscript dpkg a2ps ]; + buildInputs = [ + cups + ghostscript + dpkg + a2ps + ]; dontUnpack = true; @@ -77,18 +98,32 @@ stdenv.mkDerivation rec { ln -s $out/opt/brother/Printers/mfcj880dw/lpd/filtermfcj880dw $out/lib/cups/filter/brother_lpdwrapper_mfcj880dw wrapProgram $out/opt/brother/Printers/mfcj880dw/lpd/psconvertij2 \ - --prefix PATH ":" ${ lib.makeBinPath [ coreutils gnused gawk ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + coreutils + gnused + gawk + ] + } wrapProgram $out/opt/brother/Printers/mfcj880dw/lpd/filtermfcj880dw \ - --prefix PATH ":" ${ lib.makeBinPath [ coreutils gnused file ghostscript a2ps ] } - ''; + --prefix PATH ":" ${ + lib.makeBinPath [ + coreutils + gnused + file + ghostscript + a2ps + ] + } + ''; meta = with lib; { - description = "Brother MFC-J880DW LPR driver"; + description = "Brother MFC-J880DW LPR driver"; downloadPage = "https://support.brother.com/g/b/downloadlist.aspx?c=us&lang=en&prod=mfcj880dw_us_eu_as&os=128"; - homepage = "http://www.brother.com/"; + homepage = "http://www.brother.com/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = with licenses; unfree; - maintainers = with maintainers; [ _6543 ]; - platforms = with platforms; linux; + license = with licenses; unfree; + maintainers = with maintainers; [ _6543 ]; + platforms = with platforms; linux; }; } diff --git a/pkgs/by-name/mf/mfcl2700dncupswrapper/package.nix b/pkgs/by-name/mf/mfcl2700dncupswrapper/package.nix index 0b145dfa38535f..1de0781cd6d0da 100644 --- a/pkgs/by-name/mf/mfcl2700dncupswrapper/package.nix +++ b/pkgs/by-name/mf/mfcl2700dncupswrapper/package.nix @@ -1,4 +1,15 @@ -{ coreutils, dpkg, fetchurl, gnugrep, gnused, makeWrapper, mfcl2700dnlpr, perl, lib, stdenv }: +{ + coreutils, + dpkg, + fetchurl, + gnugrep, + gnused, + makeWrapper, + mfcl2700dnlpr, + perl, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "mfcl2700dncupswrapper"; @@ -9,7 +20,10 @@ stdenv.mkDerivation rec { sha256 = "07w48mah0xbv4h8vsh1qd5cd4b463bx8y6gc5x9pfgsxsy6h6da1"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; dontUnpack = true; @@ -25,7 +39,13 @@ stdenv.mkDerivation rec { --replace "PRINTER =~" "PRINTER = \"MFCL2700DN\"; #" wrapProgram $dir/cupswrapper/brother_lpdwrapper_MFCL2700DN \ - --prefix PATH : ${lib.makeBinPath [ coreutils gnugrep gnused ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + gnugrep + gnused + ] + } mkdir -p $out/lib/cups/filter mkdir -p $out/share/cups/model diff --git a/pkgs/by-name/mf/mfcl2720dwcupswrapper/package.nix b/pkgs/by-name/mf/mfcl2720dwcupswrapper/package.nix index abf25ae69850e5..9538e5a4f367e3 100644 --- a/pkgs/by-name/mf/mfcl2720dwcupswrapper/package.nix +++ b/pkgs/by-name/mf/mfcl2720dwcupswrapper/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, dpkg, makeWrapper, coreutils, gnugrep, gnused, perl, mfcl2720dwlpr }: +{ + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + coreutils, + gnugrep, + gnused, + perl, + mfcl2720dwlpr, +}: stdenv.mkDerivation rec { pname = "mfcl2720dwcupswrapper"; @@ -9,7 +20,10 @@ stdenv.mkDerivation rec { sha256 = "6d131926ce22c51b1854d2b91e426cc7ecbf5d6dabd698ef51a417090e35c598"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; dontUnpack = true; @@ -28,7 +42,13 @@ stdenv.mkDerivation rec { --replace /usr/bin/perl ${perl}/bin/perl wrapProgram $dir/cupswrapper/brother_lpdwrapper_MFCL2720DW \ - --prefix PATH : ${lib.makeBinPath [ coreutils gnugrep gnused ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + gnugrep + gnused + ] + } mkdir -p $out/lib/cups/filter mkdir -p $out/share/cups/model @@ -41,7 +61,10 @@ stdenv.mkDerivation rec { description = "Brother MFC-L2720DW CUPS wrapper driver"; homepage = "http://www.brother.com/"; license = lib.licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ lib.maintainers.xeji ]; }; } diff --git a/pkgs/by-name/mf/mfcl2720dwlpr/package.nix b/pkgs/by-name/mf/mfcl2720dwlpr/package.nix index 36600a4505aafe..3c69ca44469da7 100644 --- a/pkgs/by-name/mf/mfcl2720dwlpr/package.nix +++ b/pkgs/by-name/mf/mfcl2720dwlpr/package.nix @@ -1,4 +1,17 @@ -{ pkgs, lib, stdenv, fetchurl, dpkg, makeWrapper, coreutils, ghostscript, gnugrep, gnused, which, perl }: +{ + pkgs, + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + coreutils, + ghostscript, + gnugrep, + gnused, + which, + perl, +}: stdenv.mkDerivation rec { pname = "mfcl2720dwlpr"; @@ -9,7 +22,10 @@ stdenv.mkDerivation rec { sha256 = "088217e9ad118ec1e7f3d3f8f60f3bd839fe2c7d7c1136b249e9ac648dc742af"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; dontUnpack = true; @@ -24,9 +40,15 @@ stdenv.mkDerivation rec { --replace "PRINTER =~" "PRINTER = \"MFCL2720DW\"; #" wrapProgram $dir/lpd/filter_MFCL2720DW \ - --prefix PATH : ${lib.makeBinPath [ - coreutils ghostscript gnugrep gnused which - ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + ghostscript + gnugrep + gnused + which + ] + } # need to use i686 glibc here, these are 32bit proprietary binaries interpreter=${pkgs.pkgsi686Linux.glibc}/lib/ld-linux.so.2 @@ -40,7 +62,10 @@ stdenv.mkDerivation rec { homepage = "http://www.brother.com/"; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; license = lib.licenses.unfree; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ lib.maintainers.xeji ]; }; } diff --git a/pkgs/by-name/mf/mfcl2740dwcupswrapper/package.nix b/pkgs/by-name/mf/mfcl2740dwcupswrapper/package.nix index 9b2fe4ce1736a8..b8b9ff1d099c52 100644 --- a/pkgs/by-name/mf/mfcl2740dwcupswrapper/package.nix +++ b/pkgs/by-name/mf/mfcl2740dwcupswrapper/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, dpkg, makeWrapper, coreutils, gnugrep, gnused, perl, mfcl2740dwlpr }: +{ + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + coreutils, + gnugrep, + gnused, + perl, + mfcl2740dwlpr, +}: stdenv.mkDerivation rec { pname = "mfcl2740dwcupswrapper"; @@ -9,7 +20,10 @@ stdenv.mkDerivation rec { sha256 = "078453e19f20ab6c7fc4d63c3e09f162f3d1410c04c23a294b6ffbd720b35ffb"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; unpackPhase = "dpkg-deb -x $src $out"; @@ -26,7 +40,13 @@ stdenv.mkDerivation rec { --replace /usr/bin/perl ${perl}/bin/perl wrapProgram $dir/cupswrapper/brother_lpdwrapper_MFCL2740DW \ - --prefix PATH : ${lib.makeBinPath [ coreutils gnugrep gnused ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + gnugrep + gnused + ] + } mkdir -p $out/lib/cups/filter mkdir -p $out/share/cups/model @@ -39,7 +59,10 @@ stdenv.mkDerivation rec { description = "Brother MFC-L2740DW CUPS wrapper driver"; homepage = "http://www.brother.com/"; license = lib.licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ ]; }; } diff --git a/pkgs/by-name/mf/mfcl2740dwlpr/package.nix b/pkgs/by-name/mf/mfcl2740dwlpr/package.nix index 162b019ac9b130..53ce0da9669f6b 100644 --- a/pkgs/by-name/mf/mfcl2740dwlpr/package.nix +++ b/pkgs/by-name/mf/mfcl2740dwlpr/package.nix @@ -1,4 +1,17 @@ -{ pkgsi686Linux, lib, stdenv, fetchurl, dpkg, makeWrapper, coreutils, ghostscript, gnugrep, gnused, which, perl }: +{ + pkgsi686Linux, + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + coreutils, + ghostscript, + gnugrep, + gnused, + which, + perl, +}: stdenv.mkDerivation rec { pname = "mfcl2740dwlpr"; @@ -9,7 +22,10 @@ stdenv.mkDerivation rec { sha256 = "10a2bc672bd54e718b478f3afc7e47d451557f7d5513167d3ad349a3d00bffaf"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; unpackPhase = "dpkg-deb -x $src $out"; @@ -22,9 +38,15 @@ stdenv.mkDerivation rec { --replace "PRINTER =~" "PRINTER = \"MFCL2740DW\"; #" wrapProgram $dir/lpd/filter_MFCL2740DW \ - --prefix PATH : ${lib.makeBinPath [ - coreutils ghostscript gnugrep gnused which - ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + ghostscript + gnugrep + gnused + which + ] + } # need to use i686 glibc here, these are 32bit proprietary binaries interpreter=${pkgsi686Linux.glibc}/lib/ld-linux.so.2 @@ -38,7 +60,10 @@ stdenv.mkDerivation rec { homepage = "http://www.brother.com/"; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; license = lib.licenses.unfree; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ ]; }; } diff --git a/pkgs/by-name/mf/mfcl8690cdwcupswrapper/package.nix b/pkgs/by-name/mf/mfcl8690cdwcupswrapper/package.nix index dbc6a8fc8e5ec1..f18bec338f8af6 100644 --- a/pkgs/by-name/mf/mfcl8690cdwcupswrapper/package.nix +++ b/pkgs/by-name/mf/mfcl8690cdwcupswrapper/package.nix @@ -1,5 +1,15 @@ -{ coreutils, dpkg, fetchurl, gnugrep, gnused, makeWrapper, -mfcl8690cdwlpr, perl, lib, stdenv}: +{ + coreutils, + dpkg, + fetchurl, + gnugrep, + gnused, + makeWrapper, + mfcl8690cdwlpr, + perl, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "mfcl8690cdwcupswrapper"; @@ -10,7 +20,10 @@ stdenv.mkDerivation rec { sha256 = "1bl9r8mmj4vnanwpfjqgq3c9lf2v46wp5k6r2n9iqprf7ldd1kb2"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; dontUnpack = true; @@ -26,14 +39,20 @@ stdenv.mkDerivation rec { --replace "PRINTER =~" "PRINTER = \"mfcl8690cdw\"; #" wrapProgram $dir/cupswrapper/brother_lpdwrapper_mfcl8690cdw \ - --prefix PATH : ${lib.makeBinPath [ coreutils gnugrep gnused ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + gnugrep + gnused + ] + } mkdir -p $out/lib/cups/filter mkdir -p $out/share/cups/model ln $dir/cupswrapper/brother_lpdwrapper_mfcl8690cdw $out/lib/cups/filter ln $dir/cupswrapper/brother_mfcl8690cdw_printer_en.ppd $out/share/cups/model - ''; + ''; meta = { description = "Brother MFC-L8690CDW CUPS wrapper driver"; diff --git a/pkgs/by-name/mf/mfcl8690cdwlpr/package.nix b/pkgs/by-name/mf/mfcl8690cdwlpr/package.nix index f290b9563cc75e..bcdb8a2ce67bba 100644 --- a/pkgs/by-name/mf/mfcl8690cdwlpr/package.nix +++ b/pkgs/by-name/mf/mfcl8690cdwlpr/package.nix @@ -1,5 +1,18 @@ -{ coreutils, dpkg, fetchurl, file, ghostscript, gnugrep, gnused, -makeWrapper, perl, pkgs, lib, stdenv, which }: +{ + coreutils, + dpkg, + fetchurl, + file, + ghostscript, + gnugrep, + gnused, + makeWrapper, + perl, + pkgs, + lib, + stdenv, + which, +}: stdenv.mkDerivation rec { pname = "mfcl8690cdwlpr"; @@ -10,7 +23,10 @@ stdenv.mkDerivation rec { sha256 = "0x8zd4b1psmw1znp2ibncs37xm5mljcy9yza2rx8jm8lp0a3l85v"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; dontUnpack = true; @@ -26,9 +42,16 @@ stdenv.mkDerivation rec { --replace "PRINTER =~" "PRINTER = \"mfcl8690cdw\"; #" wrapProgram $filter \ - --prefix PATH : ${lib.makeBinPath [ - coreutils file ghostscript gnugrep gnused which - ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + file + ghostscript + gnugrep + gnused + which + ] + } # need to use i686 glibc here, these are 32bit proprietary binaries interpreter=${pkgs.pkgsi686Linux.glibc}/lib/ld-linux.so.2 @@ -41,6 +64,9 @@ stdenv.mkDerivation rec { sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; license = lib.licenses.unfree; maintainers = [ ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/by-name/mf/mfcuk/package.nix b/pkgs/by-name/mf/mfcuk/package.nix index 74761dd994e891..8d10b3eb20acd6 100644 --- a/pkgs/by-name/mf/mfcuk/package.nix +++ b/pkgs/by-name/mf/mfcuk/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libnfc }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libnfc, +}: stdenv.mkDerivation { pname = "mfcuk"; diff --git a/pkgs/by-name/mf/mfoc-hardnested/package.nix b/pkgs/by-name/mf/mfoc-hardnested/package.nix index b8b46e45c7a1df..a753eec1c7abd1 100644 --- a/pkgs/by-name/mf/mfoc-hardnested/package.nix +++ b/pkgs/by-name/mf/mfoc-hardnested/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libnfc -, xz +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libnfc, + xz, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/mf/mfoc/package.nix b/pkgs/by-name/mf/mfoc/package.nix index bc85261305d3a5..fb944721503120 100644 --- a/pkgs/by-name/mf/mfoc/package.nix +++ b/pkgs/by-name/mf/mfoc/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, pkg-config, libnfc }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + libnfc, +}: stdenv.mkDerivation rec { pname = "mfoc"; @@ -22,7 +30,10 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libnfc ]; meta = with lib; { diff --git a/pkgs/by-name/mf/mftrace/package.nix b/pkgs/by-name/mf/mftrace/package.nix index 7acc7c81b28f7a..a384846e7ec1cb 100644 --- a/pkgs/by-name/mf/mftrace/package.nix +++ b/pkgs/by-name/mf/mftrace/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, fetchFromGitHub -, lib -, makeWrapper -, autoreconfHook -, python3 -, fontforge -, potrace -, texlive +{ + stdenv, + fetchFromGitHub, + lib, + makeWrapper, + autoreconfHook, + python3, + fontforge, + potrace, + texlive, }: /* @@ -33,9 +34,17 @@ stdenv.mkDerivation (finalAttrs: rec { sha256 = "02ik25aczkbi10jrjlnxby3fmixxrwm2k5r4fkfif3bjfym7nqbc"; }; - nativeBuildInputs = [ makeWrapper autoreconfHook python3 potrace ]; + nativeBuildInputs = [ + makeWrapper + autoreconfHook + python3 + potrace + ]; - buildInputs = [ fontforge potrace ]; + buildInputs = [ + fontforge + potrace + ]; postInstall = '' wrapProgram $out/bin/mftrace --prefix PATH : ${lib.makeBinPath finalAttrs.buildInputs} @@ -43,7 +52,11 @@ stdenv.mkDerivation (finalAttrs: rec { # experimental texlive.combine support # (note that only the bin/ folder will be combined into texlive) - passthru.tlDeps = with texlive; [ kpathsea t1utils metafont ]; + passthru.tlDeps = with texlive; [ + kpathsea + t1utils + metafont + ]; meta = with lib; { description = "Scalable PostScript Fonts for MetaFont"; @@ -53,7 +66,10 @@ stdenv.mkDerivation (finalAttrs: rec { TTF (TrueType) font. ''; homepage = "https://lilypond.org/mftrace/"; - license = with licenses; [ gpl2Only mit ]; + license = with licenses; [ + gpl2Only + mit + ]; maintainers = with maintainers; [ xworld21 ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/mg/mg/package.nix b/pkgs/by-name/mg/mg/package.nix index 2b69571a9109b4..b88c01f605ae85 100644 --- a/pkgs/by-name/mg/mg/package.nix +++ b/pkgs/by-name/mg/mg/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, ncurses, buildPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + ncurses, + buildPackages, +}: stdenv.mkDerivation { pname = "mg"; @@ -17,7 +24,9 @@ stdenv.mkDerivation { enableParallelBuilding = true; - makeFlags = [ "PKG_CONFIG=${buildPackages.pkg-config}/bin/${buildPackages.pkg-config.targetPrefix}pkg-config" ]; + makeFlags = [ + "PKG_CONFIG=${buildPackages.pkg-config}/bin/${buildPackages.pkg-config.targetPrefix}pkg-config" + ]; installPhase = '' install -m 555 -Dt $out/bin mg diff --git a/pkgs/by-name/mg/mgba/package.nix b/pkgs/by-name/mg/mgba/package.nix index a01507c96361c6..6ebe1ca2d6acc8 100644 --- a/pkgs/by-name/mg/mgba/package.nix +++ b/pkgs/by-name/mg/mgba/package.nix @@ -19,11 +19,12 @@ }: let - inherit (libsForQt5) - qtbase - qtmultimedia - qttools - wrapQtAppsHook; + inherit (libsForQt5) + qtbase + qtmultimedia + qttools + wrapQtAppsHook + ; in stdenv.mkDerivation (finalAttrs: { pname = "mgba"; @@ -36,7 +37,13 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-GATjKpY4EYgep4uquBuaxDsS13aIoxVicAYs/KAs1lE="; }; - outputs = [ "out" "dev" "doc" "lib" "man" ]; + outputs = [ + "out" + "dev" + "doc" + "lib" + "man" + ]; nativeBuildInputs = [ SDL2 @@ -58,8 +65,7 @@ stdenv.mkDerivation (finalAttrs: { qtbase qtmultimedia qttools - ] - ++ lib.optionals enableDiscordRpc [ discord-rpc ]; + ] ++ lib.optionals enableDiscordRpc [ discord-rpc ]; cmakeFlags = [ (lib.cmakeBool "USE_DISCORD_RPC" enableDiscordRpc) diff --git a/pkgs/by-name/mg/mgmt/package.nix b/pkgs/by-name/mg/mgmt/package.nix index bfa85ef566fdf7..c574e8f2dd6180 100644 --- a/pkgs/by-name/mg/mgmt/package.nix +++ b/pkgs/by-name/mg/mgmt/package.nix @@ -1,13 +1,14 @@ -{ augeas -, buildGoModule -, fetchFromGitHub -, gotools -, lib -, libvirt -, libxml2 -, nex -, pkg-config -, ragel +{ + augeas, + buildGoModule, + fetchFromGitHub, + gotools, + lib, + libvirt, + libxml2, + nex, + pkg-config, + ragel, }: buildGoModule rec { pname = "mgmt"; @@ -46,7 +47,6 @@ buildGoModule rec { ragel ]; - ldflags = [ "-s" "-w" diff --git a/pkgs/by-name/mh/mhddfs/package.nix b/pkgs/by-name/mh/mhddfs/package.nix index 58986c25dbf272..b970ef80a714a1 100644 --- a/pkgs/by-name/mh/mhddfs/package.nix +++ b/pkgs/by-name/mh/mhddfs/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fuse, pkg-config, attr, uthash }: +{ + lib, + stdenv, + fetchurl, + fuse, + pkg-config, + attr, + uthash, +}: stdenv.mkDerivation rec { pname = "mhddfs"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ fuse attr uthash ]; + buildInputs = [ + fuse + attr + uthash + ]; patches = [ ./fix-format-security-error.patch diff --git a/pkgs/by-name/mi/mi2ly/package.nix b/pkgs/by-name/mi/mi2ly/package.nix index 8b03f75b398d92..56fb4f5b3a8775 100644 --- a/pkgs/by-name/mi/mi2ly/package.nix +++ b/pkgs/by-name/mi/mi2ly/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mi2ly"; diff --git a/pkgs/by-name/mi/micro-httpd/package.nix b/pkgs/by-name/mi/micro-httpd/package.nix index 2ab15979026660..8a47f8eff38ee4 100644 --- a/pkgs/by-name/mi/micro-httpd/package.nix +++ b/pkgs/by-name/mi/micro-httpd/package.nix @@ -1,11 +1,15 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "micro-httpd"; version = "20140814"; src = fetchurl { - url = "https://acme.com/software/micro_httpd/micro_httpd_14Aug2014.tar.gz"; + url = "https://acme.com/software/micro_httpd/micro_httpd_14Aug2014.tar.gz"; sha256 = "0mlm24bi31s0s8w55i0sysv2nc1n2x4cfp6dm47slz49h2fz24rk"; }; @@ -16,12 +20,11 @@ stdenv.mkDerivation { ''; meta = with lib; { - homepage = "http://acme.com/software/micro_httpd/"; + homepage = "http://acme.com/software/micro_httpd/"; description = "Really small HTTP server"; - license = licenses.bsd2; - platforms = platforms.unix; + license = licenses.bsd2; + platforms = platforms.unix; maintainers = with maintainers; [ copumpkin ]; mainProgram = "micro_httpd"; }; } - diff --git a/pkgs/by-name/mi/microbin/package.nix b/pkgs/by-name/mi/microbin/package.nix index 62cb97ce1b2fb5..4a1012f0f0493c 100644 --- a/pkgs/by-name/mi/microbin/package.nix +++ b/pkgs/by-name/mi/microbin/package.nix @@ -1,12 +1,13 @@ -{ darwin -, fetchFromGitHub -, fetchpatch -, lib -, oniguruma -, openssl -, pkg-config -, rustPlatform -, stdenv +{ + darwin, + fetchFromGitHub, + fetchpatch, + lib, + oniguruma, + openssl, + pkg-config, + rustPlatform, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -64,12 +65,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - oniguruma - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + oniguruma + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; env = { OPENSSL_NO_VENDOR = true; @@ -81,7 +84,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/szabodanika/microbin"; changelog = "https://github.com/szabodanika/microbin/releases/tag/v${version}"; license = licenses.bsd3; - maintainers = with maintainers; [ dit7ya figsoda ]; + maintainers = with maintainers; [ + dit7ya + figsoda + ]; mainProgram = "microbin"; }; } diff --git a/pkgs/by-name/mi/microcom/package.nix b/pkgs/by-name/mi/microcom/package.nix index 8f9639dcfcd486..8ed6d286b2fadb 100644 --- a/pkgs/by-name/mi/microcom/package.nix +++ b/pkgs/by-name/mi/microcom/package.nix @@ -1,8 +1,10 @@ -{ stdenv, +{ + stdenv, lib, fetchFromGitHub, readline, - autoreconfHook }: + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "microcom"; diff --git a/pkgs/by-name/mi/micromamba/package.nix b/pkgs/by-name/mi/micromamba/package.nix index 8707d4099f95c6..fa003a4397634d 100644 --- a/pkgs/by-name/mi/micromamba/package.nix +++ b/pkgs/by-name/mi/micromamba/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, bzip2 -, cli11 -, cmake -, curl -, ghc_filesystem -, libarchive -, libsolv -, yaml-cpp -, nlohmann_json -, python3 -, reproc -, spdlog -, tl-expected +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + bzip2, + cli11, + cmake, + curl, + ghc_filesystem, + libarchive, + libsolv, + yaml-cpp, + nlohmann_json, + python3, + reproc, + spdlog, + tl-expected, }: let diff --git a/pkgs/by-name/mi/micronaut/package.nix b/pkgs/by-name/mi/micronaut/package.nix index 7fe24e39c02628..90e0334f2df924 100644 --- a/pkgs/by-name/mi/micronaut/package.nix +++ b/pkgs/by-name/mi/micronaut/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchzip, jdk, makeWrapper, installShellFiles }: +{ + lib, + stdenv, + fetchzip, + jdk, + makeWrapper, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "micronaut"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-h0C3mRV74tpoVoMDdl9TVAWk8/P7ngjPFM2c3qybTCE="; }; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/mi/micronucleus/package.nix b/pkgs/by-name/mi/micronucleus/package.nix index d7141324dc9714..51369ef5a70439 100644 --- a/pkgs/by-name/mi/micronucleus/package.nix +++ b/pkgs/by-name/mi/micronucleus/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, libusb-compat-0_1 -, fetchFromGitHub -, lib +{ + stdenv, + libusb-compat-0_1, + fetchFromGitHub, + lib, }: stdenv.mkDerivation rec { pname = "micronucleus"; diff --git a/pkgs/by-name/mi/microplane/package.nix b/pkgs/by-name/mi/microplane/package.nix index 1b16066b488a09..fcae4cf42b71d6 100644 --- a/pkgs/by-name/mi/microplane/package.nix +++ b/pkgs/by-name/mi/microplane/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "microplane"; @@ -14,7 +18,9 @@ buildGoModule rec { vendorHash = "sha256-DizwNph3hmSRoozvJgs3Qw/c9iMTRR1gMGC60pBCFSk="; ldflags = [ - "-s" "-w" "-X main.version=${version}" + "-s" + "-w" + "-X main.version=${version}" ]; postInstall = '' diff --git a/pkgs/by-name/mi/micropython/package.nix b/pkgs/by-name/mi/micropython/package.nix index 161d584cc00708..fb75f70d01c8a4 100644 --- a/pkgs/by-name/mi/micropython/package.nix +++ b/pkgs/by-name/mi/micropython/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, python3 -, libffi -, readline +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + python3, + libffi, + readline, }: stdenv.mkDerivation rec { @@ -29,12 +30,20 @@ stdenv.mkDerivation rec { ''; }; + nativeBuildInputs = [ + pkg-config + python3 + ]; - nativeBuildInputs = [ pkg-config python3 ]; + buildInputs = [ + libffi + readline + ]; - buildInputs = [ libffi readline ]; - - makeFlags = [ "-C" "ports/unix" ]; # also builds mpy-cross + makeFlags = [ + "-C" + "ports/unix" + ]; # also builds mpy-cross enableParallelBuilding = true; @@ -42,10 +51,14 @@ stdenv.mkDerivation rec { __darwinAllowLocalNetworking = true; # needed for select_poll_eintr test - skippedTests = " -e select_poll_fd" - + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) " -e ffi_callback -e float_parse -e float_parse_doubleproc" - + lib.optionalString (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) " -e float_parse" - ; + skippedTests = + " -e select_poll_fd" + + lib.optionalString ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 + ) " -e ffi_callback -e float_parse -e float_parse_doubleproc" + + lib.optionalString ( + stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64 + ) " -e float_parse"; checkPhase = '' runHook preCheck @@ -68,6 +81,9 @@ stdenv.mkDerivation rec { homepage = "https://micropython.org"; platforms = platforms.unix; license = licenses.mit; - maintainers = with maintainers; [ prusnak sgo ]; + maintainers = with maintainers; [ + prusnak + sgo + ]; }; } diff --git a/pkgs/by-name/mi/microscheme/package.nix b/pkgs/by-name/mi/microscheme/package.nix index d630082c76fb4b..8c78419044384a 100644 --- a/pkgs/by-name/mi/microscheme/package.nix +++ b/pkgs/by-name/mi/microscheme/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, unixtools }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + unixtools, +}: stdenv.mkDerivation rec { pname = "microscheme"; @@ -15,7 +21,10 @@ stdenv.mkDerivation rec { substituteInPlace makefile --replace gcc ${stdenv.cc.targetPrefix}cc ''; - nativeBuildInputs = [ makeWrapper unixtools.xxd ]; + nativeBuildInputs = [ + makeWrapper + unixtools.xxd + ]; makeFlags = [ "PREFIX=${placeholder "out"}" ]; diff --git a/pkgs/by-name/mi/microserver/package.nix b/pkgs/by-name/mi/microserver/package.nix index 810128a5d6eaa4..bc2c3d5b17081c 100644 --- a/pkgs/by-name/mi/microserver/package.nix +++ b/pkgs/by-name/mi/microserver/package.nix @@ -1,8 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, darwin }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, +}: rustPlatform.buildRustPackage rec { - pname = "microserver"; - version = "0.2.1"; + pname = "microserver"; + version = "0.2.1"; src = fetchFromGitHub { owner = "robertohuertasm"; @@ -13,7 +19,9 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-JGsMtlWuww1rYE4w6i2VlyD6gGHqnLehLDZmW57R+Fo="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ Security ]); + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; [ Security ] + ); meta = with lib; { homepage = "https://github.com/robertohuertasm/microserver"; diff --git a/pkgs/by-name/mi/microsocks/package.nix b/pkgs/by-name/mi/microsocks/package.nix index 8c773bc1c3fe39..e53fb2d2bc78e7 100644 --- a/pkgs/by-name/mi/microsocks/package.nix +++ b/pkgs/by-name/mi/microsocks/package.nix @@ -1,4 +1,5 @@ -{ stdenv, +{ + stdenv, fetchFromGitHub, lib, }: diff --git a/pkgs/by-name/mi/microsoft-gsl/package.nix b/pkgs/by-name/mi/microsoft-gsl/package.nix index 59df670e9ec510..1805605685117f 100644 --- a/pkgs/by-name/mi/microsoft-gsl/package.nix +++ b/pkgs/by-name/mi/microsoft-gsl/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, gtest -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + gtest, + pkg-config, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { hash = "sha256-cXDFqt2KgMFGfdh6NGE+JmP4R0Wm9LNHM0eIblYe6zU="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ gtest ]; # error: unsafe buffer access @@ -45,6 +49,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/Microsoft/GSL"; license = licenses.mit; platforms = platforms.all; - maintainers = with maintainers; [ thoughtpolice yuriaisaka ]; + maintainers = with maintainers; [ + thoughtpolice + yuriaisaka + ]; }; } diff --git a/pkgs/by-name/mi/mictray/package.nix b/pkgs/by-name/mi/mictray/package.nix index f53ae6c48d0e36..b8d1112eee2d7b 100644 --- a/pkgs/by-name/mi/mictray/package.nix +++ b/pkgs/by-name/mi/mictray/package.nix @@ -1,15 +1,16 @@ -{ fetchFromGitHub -, gtk3 -, lib -, libgee -, libnotify -, meson -, ninja -, pkg-config -, pulseaudio -, stdenv -, vala -, wrapGAppsHook3 +{ + fetchFromGitHub, + gtk3, + lib, + libgee, + libnotify, + meson, + ninja, + pkg-config, + pulseaudio, + stdenv, + vala, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mi/mid2key/package.nix b/pkgs/by-name/mi/mid2key/package.nix index 95b48779459a25..d1e3fb1c2b7226 100644 --- a/pkgs/by-name/mi/mid2key/package.nix +++ b/pkgs/by-name/mi/mid2key/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, alsa-lib, libX11, libXi, libXtst, xorgproto }: +{ + lib, + stdenv, + fetchFromGitHub, + alsa-lib, + libX11, + libXi, + libXtst, + xorgproto, +}: stdenv.mkDerivation rec { pname = "mid2key"; @@ -11,7 +20,13 @@ stdenv.mkDerivation rec { sha256 = "Zo0mqdBJ1JKD9ZCA8te3f5opyYslFncYcx9iuXq2B9g="; }; - buildInputs = [ alsa-lib libX11 libXi libXtst xorgproto ]; + buildInputs = [ + alsa-lib + libX11 + libXi + libXtst + xorgproto + ]; buildPhase = "make"; diff --git a/pkgs/by-name/mi/midi-trigger/package.nix b/pkgs/by-name/mi/midi-trigger/package.nix index 9fcf49e5ae6672..c05218a923bd19 100644 --- a/pkgs/by-name/mi/midi-trigger/package.nix +++ b/pkgs/by-name/mi/midi-trigger/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + lv2, +}: stdenv.mkDerivation rec { pname = "midi-trigger"; diff --git a/pkgs/by-name/mi/midicsv/package.nix b/pkgs/by-name/mi/midicsv/package.nix index 673503d51d7b86..5712040004b7ae 100644 --- a/pkgs/by-name/mi/midicsv/package.nix +++ b/pkgs/by-name/mi/midicsv/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "midicsv"; diff --git a/pkgs/by-name/mi/midimonster/package.nix b/pkgs/by-name/mi/midimonster/package.nix index 8ff97968b0008e..dc92d792535ab0 100644 --- a/pkgs/by-name/mi/midimonster/package.nix +++ b/pkgs/by-name/mi/midimonster/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, gnumake -, gcc -, pkg-config -, lua5_4 -, openssl -, jack1 -, python3 -, alsa-lib -, ncurses -, libevdev +{ + lib, + stdenv, + fetchFromGitHub, + gnumake, + gcc, + pkg-config, + lua5_4, + openssl, + jack1, + python3, + alsa-lib, + ncurses, + libevdev, }: stdenv.mkDerivation { @@ -18,7 +19,17 @@ stdenv.mkDerivation { version = "0.6.0"; nativeBuildInputs = [ pkg-config ]; - buildInputs = [gnumake gcc lua5_4 openssl jack1 python3 alsa-lib ncurses libevdev]; + buildInputs = [ + gnumake + gcc + lua5_4 + openssl + jack1 + python3 + alsa-lib + ncurses + libevdev + ]; src = fetchFromGitHub { repo = "midimonster"; @@ -30,7 +41,10 @@ stdenv.mkDerivation { doCheck = true; enableParallelBuilding = true; - outputs = ["out" "man"]; + outputs = [ + "out" + "man" + ]; buildPhase = '' PLUGINS=$out/lib/midimonster make all @@ -51,7 +65,7 @@ stdenv.mkDerivation { description = "Multi-protocol translation tool"; license = licenses.bsd2; platforms = platforms.unix; - maintainers = with maintainers; [keldu]; + maintainers = with maintainers; [ keldu ]; mainProgram = "midimonster"; }; } diff --git a/pkgs/by-name/mi/midisheetmusic/package.nix b/pkgs/by-name/mi/midisheetmusic/package.nix index 645c69a1c86b8b..211e012b7e8a2d 100644 --- a/pkgs/by-name/mi/midisheetmusic/package.nix +++ b/pkgs/by-name/mi/midisheetmusic/package.nix @@ -1,10 +1,19 @@ -{ lib, stdenv, fetchurl -, mono, dotnetPackages, makeWrapper -, gtk2, cups, timidity }: +{ + lib, + stdenv, + fetchurl, + mono, + dotnetPackages, + makeWrapper, + gtk2, + cups, + timidity, +}: let version = "2.6"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "midisheetmusic"; inherit version; @@ -14,7 +23,10 @@ in stdenv.mkDerivation { }; nativeCheckInputs = (with dotnetPackages; [ NUnitConsole ]); - nativeBuildInputs = [ mono makeWrapper ]; + nativeBuildInputs = [ + mono + makeWrapper + ]; buildPhase = '' for i in Classes/MidiPlayer.cs Classes/MidiSheetMusic.cs @@ -47,7 +59,12 @@ in stdenv.mkDerivation { cp bin/Debug/MidiSheetMusic.exe $out/bin/.MidiSheetMusic.exe makeWrapper ${mono}/bin/mono $out/bin/midisheetmusic.mono.exe \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ gtk2 cups ]} \ + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + gtk2 + cups + ] + } \ --prefix PATH : ${lib.makeBinPath [ timidity ]} \ --add-flags $out/bin/.MidiSheetMusic.exe ''; diff --git a/pkgs/by-name/mi/midori-unwrapped/package.nix b/pkgs/by-name/mi/midori-unwrapped/package.nix index 74f25b636df0cf..70f3d294493dde 100644 --- a/pkgs/by-name/mi/midori-unwrapped/package.nix +++ b/pkgs/by-name/mi/midori-unwrapped/package.nix @@ -1,21 +1,23 @@ -{ lib, stdenv -, fetchurl -, cmake -, ninja -, pkg-config -, intltool -, vala -, wrapGAppsHook3 -, gcr -, libpeas -, gtk3 -, webkitgtk_4_0 -, sqlite -, gsettings-desktop-schemas -, libsoup_2_4 -, glib-networking -, json-glib -, libarchive +{ + lib, + stdenv, + fetchurl, + cmake, + ninja, + pkg-config, + intltool, + vala, + wrapGAppsHook3, + gcr, + libpeas, + gtk3, + webkitgtk_4_0, + sqlite, + gsettings-desktop-schemas, + libsoup_2_4, + glib-networking, + json-glib, + libarchive, }: stdenv.mkDerivation rec { @@ -59,6 +61,9 @@ stdenv.mkDerivation rec { homepage = "https://www.midori-browser.org/"; license = with licenses; [ lgpl21Plus ]; platforms = with platforms; linux; - maintainers = with maintainers; [ raskin ramkromberg ]; + maintainers = with maintainers; [ + raskin + ramkromberg + ]; }; } diff --git a/pkgs/by-name/mi/migmix/package.nix b/pkgs/by-name/mi/migmix/package.nix index 5c5212189e207f..7e7bbbcccedfdf 100644 --- a/pkgs/by-name/mi/migmix/package.nix +++ b/pkgs/by-name/mi/migmix/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { pname = "migmix"; diff --git a/pkgs/by-name/mi/migra/package.nix b/pkgs/by-name/mi/migra/package.nix index 8fd3ef6332edc2..f911232a55d791 100644 --- a/pkgs/by-name/mi/migra/package.nix +++ b/pkgs/by-name/mi/migra/package.nix @@ -1,9 +1,9 @@ -{ lib -, python3 -, fetchFromGitHub -, postgresql -, postgresqlTestHook -, +{ + lib, + python3, + fetchFromGitHub, + postgresql, + postgresqlTestHook, }: python3.pkgs.buildPythonApplication rec { pname = "migra"; diff --git a/pkgs/by-name/mi/migu/package.nix b/pkgs/by-name/mi/migu/package.nix index 76c4afc706e666..0476bd07298779 100644 --- a/pkgs/by-name/mi/migu/package.nix +++ b/pkgs/by-name/mi/migu/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { pname = "migu"; diff --git a/pkgs/by-name/mi/mihomo/package.nix b/pkgs/by-name/mi/mihomo/package.nix index fe55472e1e523e..3544d854981961 100644 --- a/pkgs/by-name/mi/mihomo/package.nix +++ b/pkgs/by-name/mi/mihomo/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, nixosTests +{ + lib, + fetchFromGitHub, + buildGoModule, + nixosTests, }: buildGoModule rec { @@ -32,7 +33,6 @@ buildGoModule rec { # network required doCheck = false; - passthru.tests = { mihomo = nixosTests.mihomo; }; diff --git a/pkgs/by-name/mi/mikmod/package.nix b/pkgs/by-name/mi/mikmod/package.nix index 7cc6bb62275a4f..02cfba37f0ec69 100644 --- a/pkgs/by-name/mi/mikmod/package.nix +++ b/pkgs/by-name/mi/mikmod/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, fetchpatch, libmikmod, ncurses }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libmikmod, + ncurses, +}: stdenv.mkDerivation rec { pname = "mikmod"; @@ -20,7 +27,10 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ libmikmod ncurses ]; + buildInputs = [ + libmikmod + ncurses + ]; meta = { description = "Tracker music player for the terminal"; diff --git a/pkgs/by-name/mi/mill/package.nix b/pkgs/by-name/mi/mill/package.nix index c54a0fd1f76bb0..c39ccf722c9f6f 100644 --- a/pkgs/by-name/mi/mill/package.nix +++ b/pkgs/by-name/mi/mill/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation (finalAttrs: { pname = "mill"; @@ -47,7 +53,10 @@ stdenv.mkDerivation (finalAttrs: { SBT, but can also be extended to support any other language or platform via modules (written in Java or Scala) or through an external subprocesses. ''; - maintainers = with maintainers; [ scalavision zenithal ]; + maintainers = with maintainers; [ + scalavision + zenithal + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/by-name/mi/miller/package.nix b/pkgs/by-name/mi/miller/package.nix index 7947944f6489bd..9c256790645361 100644 --- a/pkgs/by-name/mi/miller/package.nix +++ b/pkgs/by-name/mi/miller/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "miller"; @@ -11,7 +15,10 @@ buildGoModule rec { sha256 = "sha256-eHiYIw/sQMXLow2Vy4zFTGeON28LmG0pK2Uca4ooInU="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; vendorHash = "sha256-oc6Lp4rQ+MLmQDVcuNJ3CqYH277Vuuwu4zSSO2ICXsw="; @@ -24,10 +31,10 @@ buildGoModule rec { meta = with lib; { description = "Like awk, sed, cut, join, and sort for data formats such as CSV, TSV, JSON, JSON Lines, and positionally-indexed"; - homepage = "https://github.com/johnkerl/miller"; - license = licenses.bsd2; + homepage = "https://github.com/johnkerl/miller"; + license = licenses.bsd2; maintainers = with maintainers; [ mstarzyk ]; mainProgram = "mlr"; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/mi/millet/package.nix b/pkgs/by-name/mi/millet/package.nix index 36e78863deb6c5..5b6ea76957fd6b 100644 --- a/pkgs/by-name/mi/millet/package.nix +++ b/pkgs/by-name/mi/millet/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "millet"; @@ -23,15 +27,24 @@ rustPlatform.buildRustPackage rec { rm .cargo/config.toml ''; - cargoBuildFlags = [ "--package" "millet-ls" ]; + cargoBuildFlags = [ + "--package" + "millet-ls" + ]; - cargoTestFlags = [ "--package" "millet-ls" ]; + cargoTestFlags = [ + "--package" + "millet-ls" + ]; meta = with lib; { description = "Language server for Standard ML"; homepage = "https://github.com/azdavis/millet"; changelog = "https://github.com/azdavis/millet/blob/v${version}/docs/CHANGELOG.md"; - license = [ licenses.mit /* or */ licenses.asl20 ]; + license = [ + licenses.mit # or + licenses.asl20 + ]; maintainers = [ ]; mainProgram = "millet-ls"; }; diff --git a/pkgs/by-name/mi/millipixels/package.nix b/pkgs/by-name/mi/millipixels/package.nix index 27c24c5e935e2d..3abe2766458f27 100644 --- a/pkgs/by-name/mi/millipixels/package.nix +++ b/pkgs/by-name/mi/millipixels/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, glib -, meson -, ninja -, pkg-config -, rustc -, libbsd -, libcamera -, gtk3 -, libtiff -, zbar -, libjpeg -, libexif -, libraw -, libpulseaudio -, ffmpeg-headless -, v4l-utils -, makeWrapper -, python3 +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + glib, + meson, + ninja, + pkg-config, + rustc, + libbsd, + libcamera, + gtk3, + libtiff, + zbar, + libjpeg, + libexif, + libraw, + libpulseaudio, + ffmpeg-headless, + v4l-utils, + makeWrapper, + python3, }: stdenv.mkDerivation rec { @@ -65,7 +66,12 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/millipixels \ - --prefix PATH : ${lib.makeBinPath [ v4l-utils ffmpeg-headless ]} + --prefix PATH : ${ + lib.makeBinPath [ + v4l-utils + ffmpeg-headless + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/mi/milu/package.nix b/pkgs/by-name/mi/milu/package.nix index 333d58d500c83d..bed794be48bc75 100644 --- a/pkgs/by-name/mi/milu/package.nix +++ b/pkgs/by-name/mi/milu/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, unzip, pkg-config, glib, llvmPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + unzip, + pkg-config, + glib, + llvmPackages, +}: stdenv.mkDerivation { pname = "milu-nightly"; @@ -22,10 +30,13 @@ stdenv.mkDerivation { cp bin/milu $out/bin ''; - nativeBuildInputs = [ pkg-config unzip ]; + nativeBuildInputs = [ + pkg-config + unzip + ]; buildInputs = [ - glib - llvmPackages.libclang + glib + llvmPackages.libclang ]; meta = { @@ -37,4 +48,3 @@ stdenv.mkDerivation { mainProgram = "milu"; }; } - diff --git a/pkgs/by-name/mi/mimalloc/package.nix b/pkgs/by-name/mi/mimalloc/package.nix index e8259541c27a68..f638d1fa36bb5b 100644 --- a/pkgs/by-name/mi/mimalloc/package.nix +++ b/pkgs/by-name/mi/mimalloc/package.nix @@ -1,59 +1,78 @@ -{ lib, stdenv, fetchFromGitHub, cmake, ninja -, secureBuild ? false +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + secureBuild ? false, }: let soext = stdenv.hostPlatform.extensions.sharedLibrary; in stdenv.mkDerivation rec { - pname = "mimalloc"; + pname = "mimalloc"; version = "2.1.7"; src = fetchFromGitHub { - owner = "microsoft"; - repo = pname; - rev = "v${version}"; + owner = "microsoft"; + repo = pname; + rev = "v${version}"; sha256 = "sha256-slAi8Ht/jwpsFy5zC3CpfTdAkxEMpHJlgmNqMgz+psU="; }; doCheck = !stdenv.hostPlatform.isStatic; - preCheck = let - ldLibraryPathEnv = if stdenv.hostPlatform.isDarwin then "DYLD_LIBRARY_PATH" else "LD_LIBRARY_PATH"; - in '' - export ${ldLibraryPathEnv}="$(pwd)/build:''${${ldLibraryPathEnv}}" - ''; - - nativeBuildInputs = [ cmake ninja ]; - cmakeFlags = [ "-DMI_INSTALL_TOPLEVEL=ON" ] + preCheck = + let + ldLibraryPathEnv = if stdenv.hostPlatform.isDarwin then "DYLD_LIBRARY_PATH" else "LD_LIBRARY_PATH"; + in + '' + export ${ldLibraryPathEnv}="$(pwd)/build:''${${ldLibraryPathEnv}}" + ''; + + nativeBuildInputs = [ + cmake + ninja + ]; + cmakeFlags = + [ "-DMI_INSTALL_TOPLEVEL=ON" ] ++ lib.optionals secureBuild [ "-DMI_SECURE=ON" ] ++ lib.optionals stdenv.hostPlatform.isStatic [ "-DMI_BUILD_SHARED=OFF" ] - ++ lib.optionals (!doCheck) [ "-DMI_BUILD_TESTS=OFF" ] - ; - - postInstall = let - rel = lib.versions.majorMinor version; - suffix = if stdenv.hostPlatform.isLinux then "${soext}.${rel}" else ".${rel}${soext}"; - in '' - # first, move headers and cmake files, that's easy - mkdir -p $dev/lib - mv $out/lib/cmake $dev/lib/ - - find $dev $out -type f - '' + (lib.optionalString secureBuild '' - # pretend we're normal mimalloc - ln -sfv $out/lib/libmimalloc-secure${suffix} $out/lib/libmimalloc${suffix} - ln -sfv $out/lib/libmimalloc-secure${suffix} $out/lib/libmimalloc${soext} - ln -sfv $out/lib/libmimalloc-secure.a $out/lib/libmimalloc.a - ln -sfv $out/lib/mimalloc-secure.o $out/lib/mimalloc.o - ''); - - outputs = [ "out" "dev" ]; + ++ lib.optionals (!doCheck) [ "-DMI_BUILD_TESTS=OFF" ]; + + postInstall = + let + rel = lib.versions.majorMinor version; + suffix = if stdenv.hostPlatform.isLinux then "${soext}.${rel}" else ".${rel}${soext}"; + in + '' + # first, move headers and cmake files, that's easy + mkdir -p $dev/lib + mv $out/lib/cmake $dev/lib/ + + find $dev $out -type f + '' + + (lib.optionalString secureBuild '' + # pretend we're normal mimalloc + ln -sfv $out/lib/libmimalloc-secure${suffix} $out/lib/libmimalloc${suffix} + ln -sfv $out/lib/libmimalloc-secure${suffix} $out/lib/libmimalloc${soext} + ln -sfv $out/lib/libmimalloc-secure.a $out/lib/libmimalloc.a + ln -sfv $out/lib/mimalloc-secure.o $out/lib/mimalloc.o + ''); + + outputs = [ + "out" + "dev" + ]; meta = with lib; { description = "Compact, fast, general-purpose memory allocator"; - homepage = "https://github.com/microsoft/mimalloc"; - license = licenses.bsd2; - platforms = platforms.unix; - maintainers = with maintainers; [ kamadorueda thoughtpolice ]; + homepage = "https://github.com/microsoft/mimalloc"; + license = licenses.bsd2; + platforms = platforms.unix; + maintainers = with maintainers; [ + kamadorueda + thoughtpolice + ]; }; } diff --git a/pkgs/by-name/mi/mimeo/package.nix b/pkgs/by-name/mi/mimeo/package.nix index 49a86807017f21..444203ba89014f 100644 --- a/pkgs/by-name/mi/mimeo/package.nix +++ b/pkgs/by-name/mi/mimeo/package.nix @@ -1,7 +1,15 @@ -{ lib, fetchurl, desktop-file-utils, file, python3Packages }: - -let version = "2023"; -in python3Packages.buildPythonApplication { +{ + lib, + fetchurl, + desktop-file-utils, + file, + python3Packages, +}: + +let + version = "2023"; +in +python3Packages.buildPythonApplication { pname = "mimeo"; inherit version; @@ -10,7 +18,10 @@ in python3Packages.buildPythonApplication { hash = "sha256-CahvSypwR1aHVDHTdtty1ZfaKBWPolxc73uZ5OyeqZA="; }; - buildInputs = [ file desktop-file-utils ]; + buildInputs = [ + file + desktop-file-utils + ]; propagatedBuildInputs = [ python3Packages.pyxdg ]; diff --git a/pkgs/by-name/mi/mimetic/package.nix b/pkgs/by-name/mi/mimetic/package.nix index 33b6e1b8cae8d1..38a843b809e519 100644 --- a/pkgs/by-name/mi/mimetic/package.nix +++ b/pkgs/by-name/mi/mimetic/package.nix @@ -1,11 +1,17 @@ -{ lib, stdenv, fetchurl, fetchpatch, cutee }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + cutee, +}: stdenv.mkDerivation rec { pname = "mimetic"; version = "0.9.8"; src = fetchurl { - url = "http://www.codesink.org/download/${pname}-${version}.tar.gz"; + url = "http://www.codesink.org/download/${pname}-${version}.tar.gz"; sha256 = "003715lvj4nx23arn1s9ss6hgc2yblkwfy5h94li6pjz2a6xc1rs"; }; @@ -21,9 +27,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "MIME handling library"; - homepage = "https://www.codesink.org/mimetic_mime_library.html"; - license = licenses.mit; - maintainers = with maintainers; [ leenaars]; + homepage = "https://www.codesink.org/mimetic_mime_library.html"; + license = licenses.mit; + maintainers = with maintainers; [ leenaars ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/mi/mimic/package.nix b/pkgs/by-name/mi/mimic/package.nix index 6baa1b5c7cb0b8..70a9b0e33a83ec 100644 --- a/pkgs/by-name/mi/mimic/package.nix +++ b/pkgs/by-name/mi/mimic/package.nix @@ -1,7 +1,20 @@ -{ config, lib, stdenv, autoreconfHook, fetchFromGitHub, fetchpatch -, pkg-config, makeWrapper -, alsa-lib, alsa-plugins, libtool, icu, pcre2 -, pulseaudioSupport ? config.pulseaudio or false, libpulseaudio }: +{ + config, + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + fetchpatch, + pkg-config, + makeWrapper, + alsa-lib, + alsa-plugins, + libtool, + icu, + pcre2, + pulseaudioSupport ? config.pulseaudio or false, + libpulseaudio, +}: stdenv.mkDerivation rec { pname = "mimic"; diff --git a/pkgs/by-name/mi/mimikatz/package.nix b/pkgs/by-name/mi/mimikatz/package.nix index becc83dc6142fa..83dcbb55207023 100644 --- a/pkgs/by-name/mi/mimikatz/package.nix +++ b/pkgs/by-name/mi/mimikatz/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchzip -, stdenvNoCC +{ + lib, + fetchzip, + stdenvNoCC, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/mi/mimir/package.nix b/pkgs/by-name/mi/mimir/package.nix index 4eba5a71c0f8ec..5e1e4deb449c0c 100644 --- a/pkgs/by-name/mi/mimir/package.nix +++ b/pkgs/by-name/mi/mimir/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests, nix-update-script }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, + nix-update-script, +}: buildGoModule rec { pname = "mimir"; version = "2.14.2"; @@ -12,23 +18,28 @@ buildGoModule rec { vendorHash = null; - subPackages = [ - "cmd/mimir" - "cmd/mimirtool" - ] ++ (map (pathName: "tools/${pathName}") [ - "compaction-planner" - "copyblocks" - "copyprefix" - "delete-objects" - "list-deduplicated-blocks" - "listblocks" - "markblocks" - "undelete-blocks" - ]); + subPackages = + [ + "cmd/mimir" + "cmd/mimirtool" + ] + ++ (map (pathName: "tools/${pathName}") [ + "compaction-planner" + "copyblocks" + "copyprefix" + "delete-objects" + "list-deduplicated-blocks" + "listblocks" + "markblocks" + "undelete-blocks" + ]); passthru = { updateScript = nix-update-script { - extraArgs = [ "--version-regex" "mimir-([0-9.]+)" ]; + extraArgs = [ + "--version-regex" + "mimir-([0-9.]+)" + ]; }; tests = { inherit (nixosTests) mimir; @@ -36,8 +47,10 @@ buildGoModule rec { }; ldflags = - let t = "github.com/grafana/mimir/pkg/util/version"; - in [ + let + t = "github.com/grafana/mimir/pkg/util/version"; + in + [ ''-extldflags "-static"'' "-s" "-w" @@ -47,10 +60,13 @@ buildGoModule rec { ]; meta = with lib; { - description = - "Grafana Mimir provides horizontally scalable, highly available, multi-tenant, long-term storage for Prometheus. "; + description = "Grafana Mimir provides horizontally scalable, highly available, multi-tenant, long-term storage for Prometheus. "; homepage = "https://github.com/grafana/mimir"; license = licenses.agpl3Only; - maintainers = with maintainers; [ happysalada bryanhonof adamcstephens ]; + maintainers = with maintainers; [ + happysalada + bryanhonof + adamcstephens + ]; }; } diff --git a/pkgs/by-name/mi/min/package.nix b/pkgs/by-name/mi/min/package.nix index 9b2bfd34a749e5..60d1b11404d134 100644 --- a/pkgs/by-name/mi/min/package.nix +++ b/pkgs/by-name/mi/min/package.nix @@ -1,4 +1,10 @@ -{ lib, buildNimPackage, fetchFromGitHub, openssl, pcre }: +{ + lib, + buildNimPackage, + fetchFromGitHub, + openssl, + pcre, +}: buildNimPackage (finalAttrs: { pname = "min"; @@ -13,7 +19,10 @@ buildNimPackage (finalAttrs: { lockFile = ./lock.json; - buildInputs = [ openssl pcre ]; + buildInputs = [ + openssl + pcre + ]; prePatch = '' # remove vendorabilities @@ -25,8 +34,7 @@ buildNimPackage (finalAttrs: { NIX_LDFLAGS = [ "-lpcre" ]; meta = { - description = - "A functional, concatenative programming language with a minimalist syntax"; + description = "A functional, concatenative programming language with a minimalist syntax"; homepage = "https://min-lang.org/"; changelog = "https://github.com/h3rald/min/releases/tag/${finalAttrs.src.rev}"; license = lib.licenses.mit; diff --git a/pkgs/by-name/mi/minc_widgets/package.nix b/pkgs/by-name/mi/minc_widgets/package.nix index 42178722b55171..054af1323a82c8 100644 --- a/pkgs/by-name/mi/minc_widgets/package.nix +++ b/pkgs/by-name/mi/minc_widgets/package.nix @@ -1,25 +1,52 @@ -{ lib, stdenv, fetchFromGitHub, cmake, makeWrapper, +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + makeWrapper, perlPackages, - libminc, octave, coreutils, minc_tools }: + libminc, + octave, + coreutils, + minc_tools, +}: stdenv.mkDerivation rec { pname = "minc-widgets"; version = "unstable-2016-04-20"; src = fetchFromGitHub { - owner = "BIC-MNI"; - repo = pname; - rev = "f08b643894c81a1a2e0fbfe595a17a42ba8906db"; + owner = "BIC-MNI"; + repo = pname; + rev = "f08b643894c81a1a2e0fbfe595a17a42ba8906db"; sha256 = "1b9g6lf37wpp211ikaji4rf74rl9xcmrlyqcw1zq3z12ji9y33bm"; }; - nativeBuildInputs = [ cmake makeWrapper ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; buildInputs = [ libminc ]; - propagatedBuildInputs = (with perlPackages; [ perl GetoptTabular MNI-Perllib ]) ++ [ octave coreutils minc_tools ]; + propagatedBuildInputs = + (with perlPackages; [ + perl + GetoptTabular + MNI-Perllib + ]) + ++ [ + octave + coreutils + minc_tools + ]; postFixup = '' for p in $out/bin/*; do - wrapProgram $p --prefix PERL5LIB : $PERL5LIB --set PATH "${lib.makeBinPath [ coreutils minc_tools ]}"; + wrapProgram $p --prefix PERL5LIB : $PERL5LIB --set PATH "${ + lib.makeBinPath [ + coreutils + minc_tools + ] + }"; done ''; diff --git a/pkgs/by-name/mi/minder/package.nix b/pkgs/by-name/mi/minder/package.nix index cb7fc6403d9793..0101fa8480072c 100644 --- a/pkgs/by-name/mi/minder/package.nix +++ b/pkgs/by-name/mi/minder/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitHub -, desktop-file-utils -, meson -, ninja -, pkg-config -, python3 -, shared-mime-info -, vala -, wrapGAppsHook3 -, cairo -, discount -, glib -, gtk3 -, gtksourceview4 -, hicolor-icon-theme # for setup-hook -, json-glib -, libarchive -, libgee -, libhandy -, libxml2 -, pantheon +{ + lib, + stdenv, + fetchFromGitHub, + desktop-file-utils, + meson, + ninja, + pkg-config, + python3, + shared-mime-info, + vala, + wrapGAppsHook3, + cairo, + discount, + glib, + gtk3, + gtksourceview4, + hicolor-icon-theme, # for setup-hook + json-glib, + libarchive, + libgee, + libhandy, + libxml2, + pantheon, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mi/minecraft-server-hibernation/package.nix b/pkgs/by-name/mi/minecraft-server-hibernation/package.nix index 3837b890632bdf..e5279d2e3bf2ba 100644 --- a/pkgs/by-name/mi/minecraft-server-hibernation/package.nix +++ b/pkgs/by-name/mi/minecraft-server-hibernation/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "minecraft-server-hibernation"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; checkFlags = let @@ -25,7 +32,10 @@ buildGoModule rec { "Test_QueryFull" ]; in - [ "-skip" "${builtins.concatStringsSep "|" skippedTests}" ]; + [ + "-skip" + "${builtins.concatStringsSep "|" skippedTests}" + ]; meta = with lib; { description = "Autostart and stop minecraft-server when players join/leave"; diff --git a/pkgs/by-name/mi/minecraftia/package.nix b/pkgs/by-name/mi/minecraftia/package.nix index 584730ea8df3bf..811b99c51045c7 100644 --- a/pkgs/by-name/mi/minecraftia/package.nix +++ b/pkgs/by-name/mi/minecraftia/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchzip, stdenvNoCC }: +{ + lib, + fetchzip, + stdenvNoCC, +}: stdenvNoCC.mkDerivation { pname = "minecraftia"; diff --git a/pkgs/by-name/mi/minesweep-rs/package.nix b/pkgs/by-name/mi/minesweep-rs/package.nix index 454be1129634d7..f4c2974862c917 100644 --- a/pkgs/by-name/mi/minesweep-rs/package.nix +++ b/pkgs/by-name/mi/minesweep-rs/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/mi/minetest-mapserver/package.nix b/pkgs/by-name/mi/minetest-mapserver/package.nix index 525918caab202b..9255d825a8bebc 100644 --- a/pkgs/by-name/mi/minetest-mapserver/package.nix +++ b/pkgs/by-name/mi/minetest-mapserver/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { @@ -21,7 +22,10 @@ buildGoModule rec { mainProgram = "mapserver"; homepage = "https://github.com/minetest-mapserver/mapserver/blob/master/readme.md"; changelog = "https://github.com/minetest-mapserver/mapserver/releases/tag/v${version}"; - license = with licenses; [ mit cc-by-sa-30 ]; + license = with licenses; [ + mit + cc-by-sa-30 + ]; platforms = platforms.all; maintainers = with maintainers; [ gm6k ]; }; diff --git a/pkgs/by-name/mi/mingetty/package.nix b/pkgs/by-name/mi/mingetty/package.nix index bbae8f73e316a1..261fcf6cbffff8 100644 --- a/pkgs/by-name/mi/mingetty/package.nix +++ b/pkgs/by-name/mi/mingetty/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mingetty"; diff --git a/pkgs/by-name/mi/miniHttpd/package.nix b/pkgs/by-name/mi/miniHttpd/package.nix index fdf5012514f6b4..2c161583cf7dee 100644 --- a/pkgs/by-name/mi/miniHttpd/package.nix +++ b/pkgs/by-name/mi/miniHttpd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, boost }: +{ + lib, + stdenv, + fetchurl, + boost, +}: stdenv.mkDerivation rec { pname = "mini-httpd"; diff --git a/pkgs/by-name/mi/minia/package.nix b/pkgs/by-name/mi/minia/package.nix index 3665639a2cd930..1e76f8a6212756 100644 --- a/pkgs/by-name/mi/minia/package.nix +++ b/pkgs/by-name/mi/minia/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, hdf5, boost }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + hdf5, + boost, +}: stdenv.mkDerivation rec { pname = "minia"; @@ -17,7 +24,10 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = toString [ "-Wformat" ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ hdf5 boost ]; + buildInputs = [ + hdf5 + boost + ]; prePatch = '' rm -rf thirdparty/gatb-core/gatb-core/thirdparty/{hdf5,boost} diff --git a/pkgs/by-name/mi/miniaudio/package.nix b/pkgs/by-name/mi/miniaudio/package.nix index d8567177be61e5..410f470fb01f76 100644 --- a/pkgs/by-name/mi/miniaudio/package.nix +++ b/pkgs/by-name/mi/miniaudio/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { pname = "miniaudio"; @@ -22,7 +23,10 @@ stdenv.mkDerivation rec { description = "Single header audio playback and capture library written in C"; homepage = "https://github.com/mackron/miniaudio"; changelog = "https://github.com/mackron/miniaudio/blob/${src.rev}/CHANGES.md"; - license = with licenses; [ unlicense /* or */ mit0 ]; + license = with licenses; [ + unlicense # or + mit0 + ]; maintainers = [ maintainers.jansol ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/mi/miniball/package.nix b/pkgs/by-name/mi/miniball/package.nix index 13a814684a4246..b6e35fa17afbad 100644 --- a/pkgs/by-name/mi/miniball/package.nix +++ b/pkgs/by-name/mi/miniball/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "miniball"; diff --git a/pkgs/by-name/mi/minica/package.nix b/pkgs/by-name/mi/minica/package.nix index 8c351e18036187..594725a773cd61 100644 --- a/pkgs/by-name/mi/minica/package.nix +++ b/pkgs/by-name/mi/minica/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Simple tool for generating self signed certificates"; diff --git a/pkgs/by-name/mi/minidjvu/package.nix b/pkgs/by-name/mi/minidjvu/package.nix index c656eb84f75c7d..fb1c5995d5db59 100644 --- a/pkgs/by-name/mi/minidjvu/package.nix +++ b/pkgs/by-name/mi/minidjvu/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libtiff, gettext }: +{ + lib, + stdenv, + fetchurl, + libtiff, + gettext, +}: stdenv.mkDerivation rec { pname = "minidjvu"; @@ -13,7 +19,10 @@ stdenv.mkDerivation rec { sed -i s,/usr/bin/gzip,gzip, Makefile.in ''; - buildInputs = [ libtiff gettext ]; + buildInputs = [ + libtiff + gettext + ]; preInstall = '' mkdir -p $out/lib diff --git a/pkgs/by-name/mi/minidlna/package.nix b/pkgs/by-name/mi/minidlna/package.nix index 78b2140b25c3c4..7f481d20e4afe3 100644 --- a/pkgs/by-name/mi/minidlna/package.nix +++ b/pkgs/by-name/mi/minidlna/package.nix @@ -1,4 +1,21 @@ -{ lib, stdenv, fetchgit, fetchpatch2, autoreconfHook, ffmpeg, flac, libvorbis, libogg, libid3tag, libexif, libjpeg, sqlite, gettext, nixosTests, zlib }: +{ + lib, + stdenv, + fetchgit, + fetchpatch2, + autoreconfHook, + ffmpeg, + flac, + libvorbis, + libogg, + libid3tag, + libexif, + libjpeg, + sqlite, + gettext, + nixosTests, + zlib, +}: let pname = "minidlna"; @@ -26,7 +43,18 @@ stdenv.mkDerivation { nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ ffmpeg flac libvorbis libogg libid3tag libexif libjpeg sqlite gettext zlib ]; + buildInputs = [ + ffmpeg + flac + libvorbis + libogg + libid3tag + libexif + libjpeg + sqlite + gettext + zlib + ]; postInstall = '' mkdir -p $out/share/man/man{5,8} diff --git a/pkgs/by-name/mi/miniflux/package.nix b/pkgs/by-name/mi/miniflux/package.nix index 09e7c4f6927d6b..b27ec71b520acf 100644 --- a/pkgs/by-name/mi/miniflux/package.nix +++ b/pkgs/by-name/mi/miniflux/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, nixosTests, nix-update-script }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + nixosTests, + nix-update-script, +}: buildGoModule rec { pname = "miniflux"; @@ -18,7 +25,9 @@ buildGoModule rec { checkFlags = [ "-skip=TestClient" ]; # skip client tests as they require network access ldflags = [ - "-s" "-w" "-X miniflux.app/v2/internal/version.Version=${version}" + "-s" + "-w" + "-X miniflux.app/v2/internal/version.Version=${version}" ]; postInstall = '' @@ -35,7 +44,12 @@ buildGoModule rec { description = "Minimalist and opinionated feed reader"; homepage = "https://miniflux.app/"; license = licenses.asl20; - maintainers = with maintainers; [ rvolosatovs benpye emilylange adamcstephens ]; + maintainers = with maintainers; [ + rvolosatovs + benpye + emilylange + adamcstephens + ]; mainProgram = "miniflux"; }; } diff --git a/pkgs/by-name/mi/minify/package.nix b/pkgs/by-name/mi/minify/package.nix index a1bc044caeae2b..ccbb8c0f90a8a8 100644 --- a/pkgs/by-name/mi/minify/package.nix +++ b/pkgs/by-name/mi/minify/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, nix-update-script -, testers -, minify +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + nix-update-script, + testers, + minify, }: buildGoModule rec { @@ -22,7 +23,11 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - ldflags = [ "-s" "-w" "-X main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.Version=${version}" + ]; subPackages = [ "cmd/minify" ]; diff --git a/pkgs/by-name/mi/minigalaxy/package.nix b/pkgs/by-name/mi/minigalaxy/package.nix index 247055d1ec1ca4..05ff14a6b82d59 100644 --- a/pkgs/by-name/mi/minigalaxy/package.nix +++ b/pkgs/by-name/mi/minigalaxy/package.nix @@ -1,16 +1,17 @@ -{ lib -, fetchFromGitHub -, glibcLocales -, glib-networking -, gobject-introspection -, gtk3 -, libnotify -, python3Packages -, steam-run -, substituteAll -, unzip -, webkitgtk_4_0 -, wrapGAppsHook3 +{ + lib, + fetchFromGitHub, + glibcLocales, + glib-networking, + gobject-introspection, + gtk3, + libnotify, + python3Packages, + steam-run, + substituteAll, + unzip, + webkitgtk_4_0, + wrapGAppsHook3, }: python3Packages.buildPythonApplication rec { @@ -28,7 +29,7 @@ python3Packages.buildPythonApplication rec { (substituteAll { src = ./inject-launcher-steam-run.diff; steamrun = lib.getExe steam-run; - }) + }) ]; postPatch = '' diff --git a/pkgs/by-name/mi/minijinja/package.nix b/pkgs/by-name/mi/minijinja/package.nix index ca9ed7870579b3..b85ddf73e3812b 100644 --- a/pkgs/by-name/mi/minijinja/package.nix +++ b/pkgs/by-name/mi/minijinja/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "minijinja"; diff --git a/pkgs/by-name/mi/minilibx/package.nix b/pkgs/by-name/mi/minilibx/package.nix index b088aed10921d8..01d50ffe3b59bc 100644 --- a/pkgs/by-name/mi/minilibx/package.nix +++ b/pkgs/by-name/mi/minilibx/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles -, libX11 -, libXext -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + libX11, + libXext, + unstableGitUpdater, }: stdenv.mkDerivation { @@ -18,7 +19,11 @@ stdenv.mkDerivation { hash = "sha256-aRYMpaPC7dC6EHmmXugvwcQnaizRCQZKFcQX0K2MLM4="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; nativeBuildInputs = [ installShellFiles diff --git a/pkgs/by-name/mi/minimacy/package.nix b/pkgs/by-name/mi/minimacy/package.nix index 6f4d14b2790156..2238c0b129b11f 100644 --- a/pkgs/by-name/mi/minimacy/package.nix +++ b/pkgs/by-name/mi/minimacy/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, alsa-lib -, fetchFromGitHub -, libGL -, libGLU -, libX11 -, libXext -, makeBinaryWrapper +{ + lib, + stdenv, + alsa-lib, + fetchFromGitHub, + libGL, + libGLU, + libX11, + libXext, + makeBinaryWrapper, }: stdenv.mkDerivation rec { @@ -16,13 +17,22 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "ambermind"; repo = pname; - rev = version; + rev = version; hash = "sha256-uA+4dnhOnv7qRE7nqew8a14DGaQblsMY2uBZ+iyLtFU="; }; nativeBuildInputs = [ makeBinaryWrapper ]; - buildInputs = [ libGL libGLU ] ++ lib.optionals stdenv.hostPlatform.isLinux [ alsa-lib libX11 libXext ]; + buildInputs = + [ + libGL + libGLU + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + libX11 + libXext + ]; enableParallelBuilding = true; @@ -33,7 +43,9 @@ stdenv.mkDerivation rec { ''; # TODO: build graphic version for darwin - buildFlags = (if stdenv.hostPlatform.isDarwin then [ "nox" ] else [ "all" ]) ++ [ "CC=${stdenv.cc.targetPrefix}cc" ]; + buildFlags = (if stdenv.hostPlatform.isDarwin then [ "nox" ] else [ "all" ]) ++ [ + "CC=${stdenv.cc.targetPrefix}cc" + ]; postBuild = '' popd @@ -44,7 +56,9 @@ stdenv.mkDerivation rec { checkPhase = '' runHook preCheck - bin/${if stdenv.hostPlatform.isDarwin then "minimacyMac" else "minimacy"} system/demo/demo.fun.mandelbrot.mcy + bin/${ + if stdenv.hostPlatform.isDarwin then "minimacyMac" else "minimacy" + } system/demo/demo.fun.mandelbrot.mcy runHook postCheck ''; @@ -73,8 +87,8 @@ stdenv.mkDerivation rec { It is designed and programmed by Sylvain Huet. ''; maintainers = with lib.maintainers; [ jboy ]; - homepage = "https://minimacy.net"; - license = lib.licenses.gpl2; - platforms = lib.platforms.linux ++ lib.platforms.darwin; + homepage = "https://minimacy.net"; + license = lib.licenses.gpl2; + platforms = lib.platforms.linux ++ lib.platforms.darwin; }; } diff --git a/pkgs/by-name/mi/minimap2/package.nix b/pkgs/by-name/mi/minimap2/package.nix index 1c523a909241a4..630fb70febf328 100644 --- a/pkgs/by-name/mi/minimap2/package.nix +++ b/pkgs/by-name/mi/minimap2/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, +}: stdenv.mkDerivation rec { pname = "minimap2"; @@ -13,7 +18,10 @@ stdenv.mkDerivation rec { buildInputs = [ zlib ]; - makeFlags = lib.optionals stdenv.hostPlatform.isAarch64 [ "arm_neon=1" "aarch64=1" ]; + makeFlags = lib.optionals stdenv.hostPlatform.isAarch64 [ + "arm_neon=1" + "aarch64=1" + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/mi/minimodem/package.nix b/pkgs/by-name/mi/minimodem/package.nix index a09e62dfd191de..ae4961f1fa6a54 100644 --- a/pkgs/by-name/mi/minimodem/package.nix +++ b/pkgs/by-name/mi/minimodem/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, autoconf, automake, libtool -, fftw, fftwSinglePrec, alsa-lib, libsndfile, libpulseaudio +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoconf, + automake, + libtool, + fftw, + fftwSinglePrec, + alsa-lib, + libsndfile, + libpulseaudio, }: stdenv.mkDerivation rec { @@ -13,8 +24,19 @@ stdenv.mkDerivation rec { sha256 = "1b5xy36fjcp7vkp115dpx4mlmqg2fc7xvxdy648fb8im953bw7ql"; }; - nativeBuildInputs = [ pkg-config autoconf automake libtool ]; - buildInputs = [ fftw fftwSinglePrec alsa-lib libsndfile libpulseaudio ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + libtool + ]; + buildInputs = [ + fftw + fftwSinglePrec + alsa-lib + libsndfile + libpulseaudio + ]; preConfigure = '' aclocal \ @@ -26,11 +48,11 @@ stdenv.mkDerivation rec { meta = { description = "General-purpose software audio FSK modem"; longDescription = '' - Minimodem is a command-line program which decodes (or generates) audio - modem tones at any specified baud rate, using various framing protocols. It - acts a general-purpose software FSK modem, and includes support for various - standard FSK protocols such as Bell103, Bell202, RTTY, NOAA SAME, and - Caller-ID. + Minimodem is a command-line program which decodes (or generates) audio + modem tones at any specified baud rate, using various framing protocols. It + acts a general-purpose software FSK modem, and includes support for various + standard FSK protocols such as Bell103, Bell202, RTTY, NOAA SAME, and + Caller-ID. ''; homepage = "http://www.whence.com/minimodem/"; license = lib.licenses.gpl3Plus; @@ -39,4 +61,3 @@ stdenv.mkDerivation rec { mainProgram = "minimodem"; }; } - diff --git a/pkgs/by-name/mi/mininet/package.nix b/pkgs/by-name/mi/mininet/package.nix index a04859cc108949..8980443d16b076 100644 --- a/pkgs/by-name/mi/mininet/package.nix +++ b/pkgs/by-name/mi/mininet/package.nix @@ -1,30 +1,31 @@ -{ stdenv, lib, fetchFromGitHub -, runCommand -, which -, python3 -, help2man -, makeWrapper -, ethtool -, inetutils -, iperf -, iproute2 -, nettools -, socat +{ + stdenv, + lib, + fetchFromGitHub, + runCommand, + which, + python3, + help2man, + makeWrapper, + ethtool, + inetutils, + iperf, + iproute2, + nettools, + socat, }: let - pyEnv = python3.withPackages(ps: [ + pyEnv = python3.withPackages (ps: [ ps.setuptools ps.packaging ps.distutils ]); - telnet = runCommand "inetutils-telnet" - { } - '' - mkdir -p "$out/bin" - ln -s "${inetutils}"/bin/telnet "$out/bin" - ''; + telnet = runCommand "inetutils-telnet" { } '' + mkdir -p "$out/bin" + ln -s "${inetutils}"/bin/telnet "$out/bin" + ''; generatedPath = lib.makeSearchPath "bin" [ iperf @@ -42,7 +43,10 @@ stdenv.mkDerivation rec { pname = "mininet"; version = "2.3.1b4"; - outputs = [ "out" "py" ]; + outputs = [ + "out" + "py" + ]; src = fetchFromGitHub { owner = "mininet"; @@ -55,11 +59,21 @@ stdenv.mkDerivation rec { makeFlags = [ "PREFIX=$(out)" ]; pythonPath = [ python3.pkgs.setuptools ]; - nativeBuildInputs = [ help2man makeWrapper python3.pkgs.wrapPython ]; + nativeBuildInputs = [ + help2man + makeWrapper + python3.pkgs.wrapPython + ]; - propagatedBuildInputs = [ pyEnv which ]; + propagatedBuildInputs = [ + pyEnv + which + ]; - installTargets = [ "install-mnexec" "install-manpages" ]; + installTargets = [ + "install-mnexec" + "install-manpages" + ]; preInstall = '' mkdir -p $out $py @@ -80,7 +94,6 @@ stdenv.mkDerivation rec { doCheck = false; - meta = with lib; { description = "Emulator for rapid prototyping of Software Defined Networks"; license = licenses.bsd3; diff --git a/pkgs/by-name/mi/minio-certgen/package.nix b/pkgs/by-name/mi/minio-certgen/package.nix index 2379de92f430c0..3ab53dbac9adf7 100644 --- a/pkgs/by-name/mi/minio-certgen/package.nix +++ b/pkgs/by-name/mi/minio-certgen/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "minio-certgen"; diff --git a/pkgs/by-name/mi/minio-client/package.nix b/pkgs/by-name/mi/minio-client/package.nix index 286f81f7cfc441..a2b23eb2479a53 100644 --- a/pkgs/by-name/mi/minio-client/package.nix +++ b/pkgs/by-name/mi/minio-client/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "minio-client"; diff --git a/pkgs/by-name/mi/miniplayer/package.nix b/pkgs/by-name/mi/miniplayer/package.nix index 2d87078b786dc5..abb54413638ad2 100644 --- a/pkgs/by-name/mi/miniplayer/package.nix +++ b/pkgs/by-name/mi/miniplayer/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchPypi +{ + lib, + python3Packages, + fetchPypi, }: with python3Packages; diff --git a/pkgs/by-name/mi/minipro/package.nix b/pkgs/by-name/mi/minipro/package.nix index d2f47e09705cdd..b48a4033690fbb 100644 --- a/pkgs/by-name/mi/minipro/package.nix +++ b/pkgs/by-name/mi/minipro/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitLab -, pkg-config -, libusb1 +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + libusb1, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mi/minisat/package.nix b/pkgs/by-name/mi/minisat/package.nix index 10d3808827441a..67f66159c19a10 100644 --- a/pkgs/by-name/mi/minisat/package.nix +++ b/pkgs/by-name/mi/minisat/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, +}: stdenv.mkDerivation rec { pname = "minisat"; @@ -16,7 +22,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Compact and readable SAT solver"; - maintainers = with maintainers; [ gebner raskin ]; + maintainers = with maintainers; [ + gebner + raskin + ]; platforms = platforms.unix; license = licenses.mit; homepage = "http://minisat.se/"; diff --git a/pkgs/by-name/mi/miniscript/package.nix b/pkgs/by-name/mi/miniscript/package.nix index 0c3ad55ab44059..5ca244c128b37f 100644 --- a/pkgs/by-name/mi/miniscript/package.nix +++ b/pkgs/by-name/mi/miniscript/package.nix @@ -15,7 +15,7 @@ stdenv.mkDerivation rec { sha256 = "sha256-qkYDzsl2Y4WEDDXs9cE/jIXm01jclkYUQbDGe1S0wYs="; }; - postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' + postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' # Replace hardcoded g++ with c++ so clang can be used # on darwin substituteInPlace Makefile \ diff --git a/pkgs/by-name/mi/miniserve/package.nix b/pkgs/by-name/mi/miniserve/package.nix index 7822fd6d8d2060..02ec7705fe66c6 100644 --- a/pkgs/by-name/mi/miniserve/package.nix +++ b/pkgs/by-name/mi/miniserve/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv -, darwin -, curl +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + darwin, + curl, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/mi/minisign/package.nix b/pkgs/by-name/mi/minisign/package.nix index 45886a3803be7e..8a5eeca9974e02 100644 --- a/pkgs/by-name/mi/minisign/package.nix +++ b/pkgs/by-name/mi/minisign/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, libsodium }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libsodium, +}: stdenv.mkDerivation rec { pname = "minisign"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-sczGs6du797WUkfr3JiTI/bUHp7vKEeZtJdCryFcYu8="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libsodium ]; meta = with lib; { diff --git a/pkgs/by-name/mi/minissdpd/package.nix b/pkgs/by-name/mi/minissdpd/package.nix index b2a95972613b5b..9b11452bdc810e 100644 --- a/pkgs/by-name/mi/minissdpd/package.nix +++ b/pkgs/by-name/mi/minissdpd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libnfnetlink }: +{ + lib, + stdenv, + fetchurl, + libnfnetlink, +}: stdenv.mkDerivation rec { pname = "minissdpd"; @@ -16,7 +21,10 @@ stdenv.mkDerivation rec { buildInputs = [ libnfnetlink ]; - installFlags = [ "PREFIX=$(out)" "INSTALLPREFIX=$(out)" ]; + installFlags = [ + "PREFIX=$(out)" + "INSTALLPREFIX=$(out)" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/mi/ministat/package.nix b/pkgs/by-name/mi/ministat/package.nix index d0f88e5d1b1cbd..eadf3342aa7a96 100644 --- a/pkgs/by-name/mi/ministat/package.nix +++ b/pkgs/by-name/mi/ministat/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchgit }: +{ + lib, + stdenv, + fetchgit, +}: stdenv.mkDerivation rec { pname = "ministat"; diff --git a/pkgs/by-name/mi/minixml/package.nix b/pkgs/by-name/mi/minixml/package.nix index 3438cb9290b68d..d978973e7e93a0 100644 --- a/pkgs/by-name/mi/minixml/package.nix +++ b/pkgs/by-name/mi/minixml/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "mxml"; diff --git a/pkgs/by-name/mi/miniz/package.nix b/pkgs/by-name/mi/miniz/package.nix index 0cb5087c4f7a03..c47b49755916fd 100644 --- a/pkgs/by-name/mi/miniz/package.nix +++ b/pkgs/by-name/mi/miniz/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, nix-update-script -, stdenv -, testers -, validatePkgConfig -, cmake +{ + lib, + fetchFromGitHub, + nix-update-script, + stdenv, + testers, + validatePkgConfig, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -17,10 +18,13 @@ stdenv.mkDerivation (finalAttrs: { rev = finalAttrs.version; hash = "sha256-3J0bkr2Yk+MJXilUqOCHsWzuykySv5B1nepmucvA4hg="; }; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; strictDeps = true; - nativeBuildInputs = [ cmake validatePkgConfig ]; + nativeBuildInputs = [ + cmake + validatePkgConfig + ]; postFixup = '' substituteInPlace "$out"/lib/pkgconfig/miniz.pc \ diff --git a/pkgs/by-name/mi/minizip-ng/package.nix b/pkgs/by-name/mi/minizip-ng/package.nix index 23de85f33a760d..79a2ce7aaf0398 100644 --- a/pkgs/by-name/mi/minizip-ng/package.nix +++ b/pkgs/by-name/mi/minizip-ng/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gtest -, pkg-config -, zlib -, bzip2 -, xz -, zstd -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gtest, + pkg-config, + zlib, + bzip2, + xz, + zstd, + openssl, }: stdenv.mkDerivation (finalAttrs: { @@ -22,20 +23,31 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-scoEqymRMBTZZVr1fxtKOyBj4VLCgI8jQpanUKrJhiQ="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ zlib bzip2 xz zstd openssl ]; - - cmakeFlags = [ - "-DBUILD_SHARED_LIBS=${if stdenv.hostPlatform.isStatic then "OFF" else "ON"}" - "-DMZ_OPENSSL=ON" - "-DMZ_BUILD_TESTS=${if finalAttrs.finalPackage.doCheck then "ON" else "OFF"}" - "-DMZ_BUILD_UNIT_TESTS=${if finalAttrs.finalPackage.doCheck then "ON" else "OFF"}" - "-DMZ_LIB_SUFFIX='-ng'" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # missing header file - "-DMZ_LIBCOMP=OFF" + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + zlib + bzip2 + xz + zstd + openssl ]; + cmakeFlags = + [ + "-DBUILD_SHARED_LIBS=${if stdenv.hostPlatform.isStatic then "OFF" else "ON"}" + "-DMZ_OPENSSL=ON" + "-DMZ_BUILD_TESTS=${if finalAttrs.finalPackage.doCheck then "ON" else "OFF"}" + "-DMZ_BUILD_UNIT_TESTS=${if finalAttrs.finalPackage.doCheck then "ON" else "OFF"}" + "-DMZ_LIB_SUFFIX='-ng'" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # missing header file + "-DMZ_LIBCOMP=OFF" + ]; + postInstall = '' # make lib findable as libminizip-ng even if compat is enabled for ext in so dylib a ; do @@ -56,7 +68,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Fork of the popular zip manipulation library found in the zlib distribution"; homepage = "https://github.com/zlib-ng/minizip-ng"; license = licenses.zlib; - maintainers = with maintainers; [ gebner ris ]; + maintainers = with maintainers; [ + gebner + ris + ]; platforms = platforms.unix; }; }) diff --git a/pkgs/by-name/mi/minizip/package.nix b/pkgs/by-name/mi/minizip/package.nix index 44cba9767b36e8..3a09845916197d 100644 --- a/pkgs/by-name/mi/minizip/package.nix +++ b/pkgs/by-name/mi/minizip/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, zlib, autoreconfHook }: +{ + lib, + stdenv, + zlib, + autoreconfHook, +}: stdenv.mkDerivation { pname = "minizip"; diff --git a/pkgs/by-name/mi/mint-artwork/package.nix b/pkgs/by-name/mi/mint-artwork/package.nix index e74c9e7dc542ad..f3d2a690f5d6d0 100644 --- a/pkgs/by-name/mi/mint-artwork/package.nix +++ b/pkgs/by-name/mi/mint-artwork/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchurl -, glib -, nixos-artwork +{ + stdenv, + lib, + fetchurl, + glib, + nixos-artwork, }: stdenv.mkDerivation rec { @@ -41,7 +42,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/linuxmint/mint-artwork"; description = "Artwork for the cinnamon desktop"; - license = with licenses; [ gpl3Plus cc-by-40 ]; # from debian/copyright + license = with licenses; [ + gpl3Plus + cc-by-40 + ]; # from debian/copyright platforms = platforms.linux; maintainers = teams.cinnamon.members; }; diff --git a/pkgs/by-name/mi/mint-cursor-themes/package.nix b/pkgs/by-name/mi/mint-cursor-themes/package.nix index e0402b2f721b78..13a908db5170a3 100644 --- a/pkgs/by-name/mi/mint-cursor-themes/package.nix +++ b/pkgs/by-name/mi/mint-cursor-themes/package.nix @@ -1,6 +1,7 @@ -{ stdenvNoCC -, fetchFromGitHub -, lib +{ + stdenvNoCC, + fetchFromGitHub, + lib, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/mi/mint-l-icons/package.nix b/pkgs/by-name/mi/mint-l-icons/package.nix index f58266a6d668d2..3a53d89ade142c 100644 --- a/pkgs/by-name/mi/mint-l-icons/package.nix +++ b/pkgs/by-name/mi/mint-l-icons/package.nix @@ -1,10 +1,11 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, adwaita-icon-theme -, gnome-icon-theme -, hicolor-icon-theme -, gtk3 +{ + stdenvNoCC, + lib, + fetchFromGitHub, + adwaita-icon-theme, + gnome-icon-theme, + hicolor-icon-theme, + gtk3, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/mi/mint-l-theme/package.nix b/pkgs/by-name/mi/mint-l-theme/package.nix index b0836d514e2efb..206d24d91c4c0e 100644 --- a/pkgs/by-name/mi/mint-l-theme/package.nix +++ b/pkgs/by-name/mi/mint-l-theme/package.nix @@ -1,9 +1,10 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, python3 -, sassc -, sass +{ + stdenvNoCC, + lib, + fetchFromGitHub, + python3, + sassc, + sass, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/mi/mint-themes/package.nix b/pkgs/by-name/mi/mint-themes/package.nix index 3336476db59562..3a8b8aac0a05b9 100644 --- a/pkgs/by-name/mi/mint-themes/package.nix +++ b/pkgs/by-name/mi/mint-themes/package.nix @@ -1,8 +1,9 @@ -{ fetchFromGitHub -, lib -, stdenvNoCC -, python3 -, python3Packages +{ + fetchFromGitHub, + lib, + stdenvNoCC, + python3, + python3Packages, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/mi/mint-x-icons/package.nix b/pkgs/by-name/mi/mint-x-icons/package.nix index 4b9b420e35f5ba..b6a63d8387fd68 100644 --- a/pkgs/by-name/mi/mint-x-icons/package.nix +++ b/pkgs/by-name/mi/mint-x-icons/package.nix @@ -1,12 +1,13 @@ -{ fetchFromGitHub -, lib -, stdenvNoCC -, adwaita-icon-theme -, gnome-icon-theme -, hicolor-icon-theme -, gtk3 -, humanity-icon-theme -, ubuntu-themes +{ + fetchFromGitHub, + lib, + stdenvNoCC, + adwaita-icon-theme, + gnome-icon-theme, + hicolor-icon-theme, + gtk3, + humanity-icon-theme, + ubuntu-themes, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/mi/mint-y-icons/package.nix b/pkgs/by-name/mi/mint-y-icons/package.nix index 0f2934646a2e1d..f67358b53b564b 100644 --- a/pkgs/by-name/mi/mint-y-icons/package.nix +++ b/pkgs/by-name/mi/mint-y-icons/package.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, lib -, stdenvNoCC -, adwaita-icon-theme -, gnome-icon-theme -, hicolor-icon-theme -, gtk3 +{ + fetchFromGitHub, + lib, + stdenvNoCC, + adwaita-icon-theme, + gnome-icon-theme, + hicolor-icon-theme, + gtk3, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/mi/miraclecast/package.nix b/pkgs/by-name/mi/miraclecast/package.nix index f781366e1945e7..74a3aff23ecbe1 100644 --- a/pkgs/by-name/mi/miraclecast/package.nix +++ b/pkgs/by-name/mi/miraclecast/package.nix @@ -1,20 +1,43 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, pkg-config -, glib, readline, pcre, systemd, udev, iproute2 }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + glib, + readline, + pcre, + systemd, + udev, + iproute2, +}: stdenv.mkDerivation { pname = "miraclecast"; version = "1.0-20231112"; src = fetchFromGitHub { - owner = "albfan"; - repo = "miraclecast"; - rev = "af6ab257eae83bb0270a776a8fe00c0148bc53c4"; - hash = "sha256-3ZIAvA3w/ZhoJtVmUD444nch0PGD58PdBRke7zd9IuQ="; + owner = "albfan"; + repo = "miraclecast"; + rev = "af6ab257eae83bb0270a776a8fe00c0148bc53c4"; + hash = "sha256-3ZIAvA3w/ZhoJtVmUD444nch0PGD58PdBRke7zd9IuQ="; }; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; - buildInputs = [ glib pcre readline systemd udev iproute2 ]; + buildInputs = [ + glib + pcre + readline + systemd + udev + iproute2 + ]; mesonFlags = [ "-Drely-udev=true" @@ -24,9 +47,9 @@ stdenv.mkDerivation { meta = with lib; { description = "Connect external monitors via Wi-Fi"; - homepage = "https://github.com/albfan/miraclecast"; - license = licenses.lgpl21Plus; + homepage = "https://github.com/albfan/miraclecast"; + license = licenses.lgpl21Plus; maintainers = [ ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/mi/miracode/package.nix b/pkgs/by-name/mi/miracode/package.nix index 0ffcc3cdbfc600..0bc5cb3bd05d7e 100644 --- a/pkgs/by-name/mi/miracode/package.nix +++ b/pkgs/by-name/mi/miracode/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchurl }: +{ + stdenvNoCC, + lib, + fetchurl, +}: let version = "1.0"; diff --git a/pkgs/by-name/mi/mirakurun/package.nix b/pkgs/by-name/mi/mirakurun/package.nix index a1d9d58403d071..c01ea18ba8c6fc 100644 --- a/pkgs/by-name/mi/mirakurun/package.nix +++ b/pkgs/by-name/mi/mirakurun/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, bash -, buildNpmPackage -, fetchFromGitHub -, installShellFiles -, makeWrapper -, nodejs -, substituteAll -, v4l-utils -, which +{ + lib, + stdenv, + bash, + buildNpmPackage, + fetchFromGitHub, + installShellFiles, + makeWrapper, + nodejs, + substituteAll, + v4l-utils, + which, }: buildNpmPackage rec { @@ -30,7 +31,10 @@ buildNpmPackage rec { npmDepsHash = "sha256-e7m7xb7p1SBzLAyQ82TTR/qLXv4lRm37x0JJPWYYGvI="; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; # workaround for https://github.com/webpack/webpack/issues/14532 NODE_OPTIONS = "--openssl-legacy-provider"; diff --git a/pkgs/by-name/mi/miranda/package.nix b/pkgs/by-name/mi/miranda/package.nix index 8385f5063db9e9..be51e320f22640 100644 --- a/pkgs/by-name/mi/miranda/package.nix +++ b/pkgs/by-name/mi/miranda/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchzip, fetchpatch }: +{ + stdenv, + lib, + fetchzip, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "miranda"; @@ -14,7 +19,9 @@ stdenv.mkDerivation rec { # Using `fetchzip` will make all the source files have `mtime=1` # from the start so this mismatch cannot occur. src = fetchzip { - url = "https://www.cs.kent.ac.uk/people/staff/dat/miranda/src/mira-${builtins.replaceStrings [ "." ] [ "" ] version}-src.tgz"; + url = "https://www.cs.kent.ac.uk/people/staff/dat/miranda/src/mira-${ + builtins.replaceStrings [ "." ] [ "" ] version + }-src.tgz"; sha256 = "KE/FTL9YW9l7VBAgkFZlqgSM1Bt/BXT6GkkONtyKJjQ="; }; @@ -55,11 +62,14 @@ stdenv.mkDerivation rec { # Workaround build failure on -fno-common toolchains like upstream # gcc-10. Otherwise build fails as: # ld: types.o:(.bss+0x11b0): multiple definition of `current_file'; y.tab.o:(.bss+0x70): first defined here - env.NIX_CFLAGS_COMPILE = toString ([ - "-fcommon" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-error=int-conversion" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-fcommon" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-error=int-conversion" + ] + ); makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" diff --git a/pkgs/by-name/mi/miredo/package.nix b/pkgs/by-name/mi/miredo/package.nix index bac427228b52fd..2ac01fede0ecad 100644 --- a/pkgs/by-name/mi/miredo/package.nix +++ b/pkgs/by-name/mi/miredo/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, nettools, iproute2, judy }: +{ + lib, + stdenv, + fetchurl, + nettools, + iproute2, + judy, +}: stdenv.mkDerivation rec { version = "1.2.6"; diff --git a/pkgs/by-name/mi/mirrorbits/package.nix b/pkgs/by-name/mi/mirrorbits/package.nix index 3bd72b0e7dad8c..a5d8bc041b7f82 100644 --- a/pkgs/by-name/mi/mirrorbits/package.nix +++ b/pkgs/by-name/mi/mirrorbits/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch -, pkg-config -, zlib -, geoip +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + pkg-config, + zlib, + geoip, }: buildGoModule rec { @@ -29,11 +30,17 @@ buildGoModule rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ zlib geoip ]; + buildInputs = [ + zlib + geoip + ]; subPackages = [ "." ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "geographical download redirector for distributing files efficiently across a set of mirrors"; diff --git a/pkgs/by-name/mi/miscfiles/package.nix b/pkgs/by-name/mi/miscfiles/package.nix index ad58e5bd7b79b9..21d538cb0b79f4 100644 --- a/pkgs/by-name/mi/miscfiles/package.nix +++ b/pkgs/by-name/mi/miscfiles/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "miscfiles"; diff --git a/pkgs/by-name/mi/missidentify/package.nix b/pkgs/by-name/mi/missidentify/package.nix index 2fbce5bf96f2ae..a99950d39541c9 100644 --- a/pkgs/by-name/mi/missidentify/package.nix +++ b/pkgs/by-name/mi/missidentify/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook +{ + lib, + stdenv, + fetchurl, + autoreconfHook, }: stdenv.mkDerivation (finalAttrs: { @@ -32,7 +33,9 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ autoreconfHook ]; - configureFlags = lib.optionals (stdenv.hostPlatform.isAarch32 || stdenv.hostPlatform.isAarch64) [ "--build=arm" ]; + configureFlags = lib.optionals (stdenv.hostPlatform.isAarch32 || stdenv.hostPlatform.isAarch64) [ + "--build=arm" + ]; meta = with lib; { description = "Find Win32 applications"; diff --git a/pkgs/by-name/mi/mission-planner/package.nix b/pkgs/by-name/mi/mission-planner/package.nix index bd8ac9ed4b973c..626f499f9e156a 100644 --- a/pkgs/by-name/mi/mission-planner/package.nix +++ b/pkgs/by-name/mi/mission-planner/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeDesktopItem, makeWrapper, unzip, mono, gitUpdater +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + makeWrapper, + unzip, + mono, + gitUpdater, }: let @@ -11,20 +19,27 @@ let desktopName = "MissionPlanner"; genericName = "Ground Control Station"; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { inherit pname; version = "1.3.82"; src = fetchurl { - url = - "https://firmware.ardupilot.org/Tools/MissionPlanner/MissionPlanner-${version}.zip"; + url = "https://firmware.ardupilot.org/Tools/MissionPlanner/MissionPlanner-${version}.zip"; sha256 = "sha256-554fFDxHMo4jV3yrPdGgDYQ6XeW+TWdVIIkGQIBdrCQ="; }; - nativeBuildInputs = [ makeWrapper mono unzip ]; + nativeBuildInputs = [ + makeWrapper + mono + unzip + ]; sourceRoot = "."; - AOT_FILES = [ "MissionPlanner.exe" "MissionPlanner.*.dll" ]; + AOT_FILES = [ + "MissionPlanner.exe" + "MissionPlanner.*.dll" + ]; buildPhase = '' runHook preBuild diff --git a/pkgs/by-name/mi/mitama-cpp-result/package.nix b/pkgs/by-name/mi/mitama-cpp-result/package.nix index 69d910e3bd9917..cda102a736ce22 100644 --- a/pkgs/by-name/mi/mitama-cpp-result/package.nix +++ b/pkgs/by-name/mi/mitama-cpp-result/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/mi/mix2nix/package.nix b/pkgs/by-name/mi/mix2nix/package.nix index a2420980d18154..a1e25f4e0a20c8 100644 --- a/pkgs/by-name/mi/mix2nix/package.nix +++ b/pkgs/by-name/mi/mix2nix/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, elixir, erlang }: +{ + stdenv, + lib, + fetchFromGitHub, + elixir, + erlang, +}: stdenv.mkDerivation rec { pname = "mix2nix"; diff --git a/pkgs/by-name/mj/mjolnir/package.nix b/pkgs/by-name/mj/mjolnir/package.nix index dd1404b4b5b4d0..098ed9bf9b3aa3 100644 --- a/pkgs/by-name/mj/mjolnir/package.nix +++ b/pkgs/by-name/mj/mjolnir/package.nix @@ -1,11 +1,12 @@ -{ lib -, mkYarnPackage -, fetchFromGitHub -, fetchYarnDeps -, matrix-sdk-crypto-nodejs -, makeWrapper -, nodejs -, nixosTests +{ + lib, + mkYarnPackage, + fetchFromGitHub, + fetchYarnDeps, + matrix-sdk-crypto-nodejs, + makeWrapper, + nodejs, + nixosTests, }: mkYarnPackage rec { @@ -32,7 +33,8 @@ mkYarnPackage rec { }; packageResolutions = { - "@matrix-org/matrix-sdk-crypto-nodejs" = "${matrix-sdk-crypto-nodejs}/lib/node_modules/@matrix-org/matrix-sdk-crypto-nodejs"; + "@matrix-org/matrix-sdk-crypto-nodejs" = + "${matrix-sdk-crypto-nodejs}/lib/node_modules/@matrix-org/matrix-sdk-crypto-nodejs"; }; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/by-name/mj/mjpegtools/package.nix b/pkgs/by-name/mj/mjpegtools/package.nix index 147c30fed4c52b..f29e3691ff3eff 100644 --- a/pkgs/by-name/mj/mjpegtools/package.nix +++ b/pkgs/by-name/mj/mjpegtools/package.nix @@ -1,5 +1,16 @@ -{ stdenv, lib, fetchurl, gtk2, libdv, libjpeg, libpng, libX11, pkg-config, SDL, SDL_gfx -, withMinimal ? true +{ + stdenv, + lib, + fetchurl, + gtk2, + libdv, + libjpeg, + libpng, + libX11, + pkg-config, + SDL, + SDL_gfx, + withMinimal ? true, }: # TODO: @@ -23,8 +34,18 @@ stdenv.mkDerivation rec { hardeningDisable = [ "format" ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libdv libjpeg libpng ] - ++ lib.optionals (!withMinimal) [ gtk2 libX11 SDL SDL_gfx ]; + buildInputs = + [ + libdv + libjpeg + libpng + ] + ++ lib.optionals (!withMinimal) [ + gtk2 + libX11 + SDL + SDL_gfx + ]; env.NIX_CFLAGS_COMPILE = lib.optionalString (!withMinimal) "-I${lib.getDev SDL}/include/SDL"; @@ -34,7 +55,10 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - outputs = [ "out" "lib" ]; + outputs = [ + "out" + "lib" + ]; meta = with lib; { description = "Suite of programs for processing MPEG or MJPEG video"; diff --git a/pkgs/by-name/mj/mjpg-streamer/package.nix b/pkgs/by-name/mj/mjpg-streamer/package.nix index f04025b37ddc41..58af533b24501a 100644 --- a/pkgs/by-name/mj/mjpg-streamer/package.nix +++ b/pkgs/by-name/mj/mjpg-streamer/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libjpeg }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libjpeg, +}: stdenv.mkDerivation { pname = "mjpg-streamer"; diff --git a/pkgs/by-name/mk/mkalias/package.nix b/pkgs/by-name/mk/mkalias/package.nix index 1989452df36eb5..38f326992f670c 100644 --- a/pkgs/by-name/mk/mkalias/package.nix +++ b/pkgs/by-name/mk/mkalias/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + darwin, }: stdenv.mkDerivation (finalAttrs: { @@ -41,7 +42,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/vs49688/mkalias"; license = lib.licenses.gpl2Only; mainProgram = "mkalias"; - maintainers = with lib.maintainers; [ zane emilytrau ]; + maintainers = with lib.maintainers; [ + zane + emilytrau + ]; platforms = lib.platforms.darwin; }; }) diff --git a/pkgs/by-name/mk/mkbootimage/package.nix b/pkgs/by-name/mk/mkbootimage/package.nix index 278162bafcd6f0..91a70173ae050d 100644 --- a/pkgs/by-name/mk/mkbootimage/package.nix +++ b/pkgs/by-name/mk/mkbootimage/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, elfutils -, pcre +{ + lib, + stdenv, + fetchFromGitHub, + elfutils, + pcre, }: stdenv.mkDerivation (finalAttrs: { @@ -18,7 +19,10 @@ stdenv.mkDerivation (finalAttrs: { # Using elfutils because libelf is being discontinued # See https://github.com/NixOS/nixpkgs/pull/271568 - buildInputs = [ elfutils pcre ]; + buildInputs = [ + elfutils + pcre + ]; postPatch = '' substituteInPlace Makefile --replace "git rev-parse --short HEAD" "echo ${finalAttrs.src.rev}" diff --git a/pkgs/by-name/mk/mkcert/package.nix b/pkgs/by-name/mk/mkcert/package.nix index 1b3355b7cc451d..b918cb4da0fd04 100644 --- a/pkgs/by-name/mk/mkcert/package.nix +++ b/pkgs/by-name/mk/mkcert/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "mkcert"; @@ -16,7 +20,9 @@ buildGoModule rec { doCheck = false; ldflags = [ - "-s" "-w" "-X main.Version=v${version}" + "-s" + "-w" + "-X main.Version=v${version}" ]; meta = with lib; { diff --git a/pkgs/by-name/mk/mkclean/package.nix b/pkgs/by-name/mk/mkclean/package.nix index 49c270c410693a..14eee4aa21e6db 100644 --- a/pkgs/by-name/mk/mkclean/package.nix +++ b/pkgs/by-name/mk/mkclean/package.nix @@ -1,4 +1,9 @@ -{ dos2unix, fetchurl, lib, stdenv }: +{ + dos2unix, + fetchurl, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "mkclean"; @@ -32,6 +37,9 @@ stdenv.mkDerivation rec { homepage = "https://www.matroska.org"; license = licenses.bsdOriginal; maintainers = with maintainers; [ cawilliamson ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/mk/mkcue/package.nix b/pkgs/by-name/mk/mkcue/package.nix index 34893b9f68a54a..d0e2baacf519af 100644 --- a/pkgs/by-name/mk/mkcue/package.nix +++ b/pkgs/by-name/mk/mkcue/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mkcue"; diff --git a/pkgs/by-name/mk/mkinitcpio-nfs-utils/package.nix b/pkgs/by-name/mk/mkinitcpio-nfs-utils/package.nix index 0e7bb127dbb9a1..f073053536ebfe 100644 --- a/pkgs/by-name/mk/mkinitcpio-nfs-utils/package.nix +++ b/pkgs/by-name/mk/mkinitcpio-nfs-utils/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mkinitcpio-nfs-utils"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { name = "mkinitcpio-nfs-utils-${version}.tar.gz"; }; - makeFlags = [ "DESTDIR=$(out)" "bindir=/bin" ]; + makeFlags = [ + "DESTDIR=$(out)" + "bindir=/bin" + ]; postInstall = '' rm -rf $out/usr @@ -21,7 +28,7 @@ stdenv.mkDerivation rec { homepage = "https://archlinux.org/"; description = "ipconfig and nfsmount tools for root on NFS, ported from klibc"; license = licenses.gpl2Only; - platforms = platforms.linux; + platforms = platforms.linux; maintainers = with maintainers; [ abbradar ]; }; } diff --git a/pkgs/by-name/mk/mkjson/generated.nix b/pkgs/by-name/mk/mkjson/generated.nix index e20313a25d4134..1fd4090b1d0f44 100644 --- a/pkgs/by-name/mk/mkjson/generated.nix +++ b/pkgs/by-name/mk/mkjson/generated.nix @@ -1,8 +1,26 @@ -{ mkDerivation, lib, fetchFromGitHub -, aeson, base, bytestring, containers, criterion -, doctest, Glob, mersenne-random-pure64, mtl -, optparse-applicative, parsec, random, regex-tdfa, scientific -, text, time, unordered-containers, uuid, vector +{ + mkDerivation, + lib, + fetchFromGitHub, + aeson, + base, + bytestring, + containers, + criterion, + doctest, + Glob, + mersenne-random-pure64, + mtl, + optparse-applicative, + parsec, + random, + regex-tdfa, + scientific, + text, + time, + unordered-containers, + uuid, + vector, }: mkDerivation rec { @@ -18,24 +36,79 @@ mkDerivation rec { isLibrary = false; isExecutable = true; libraryHaskellDepends = [ - aeson base bytestring containers mersenne-random-pure64 mtl - optparse-applicative parsec random regex-tdfa scientific text time - unordered-containers uuid vector + aeson + base + bytestring + containers + mersenne-random-pure64 + mtl + optparse-applicative + parsec + random + regex-tdfa + scientific + text + time + unordered-containers + uuid + vector ]; executableHaskellDepends = [ - aeson base bytestring containers mersenne-random-pure64 mtl - optparse-applicative parsec random regex-tdfa scientific text time - unordered-containers uuid vector + aeson + base + bytestring + containers + mersenne-random-pure64 + mtl + optparse-applicative + parsec + random + regex-tdfa + scientific + text + time + unordered-containers + uuid + vector ]; testHaskellDepends = [ - aeson base bytestring containers doctest Glob - mersenne-random-pure64 mtl optparse-applicative parsec random - regex-tdfa scientific text time unordered-containers uuid vector + aeson + base + bytestring + containers + doctest + Glob + mersenne-random-pure64 + mtl + optparse-applicative + parsec + random + regex-tdfa + scientific + text + time + unordered-containers + uuid + vector ]; benchmarkHaskellDepends = [ - aeson base bytestring containers criterion mersenne-random-pure64 - mtl optparse-applicative parsec random regex-tdfa scientific text - time unordered-containers uuid vector + aeson + base + bytestring + containers + criterion + mersenne-random-pure64 + mtl + optparse-applicative + parsec + random + regex-tdfa + scientific + text + time + unordered-containers + uuid + vector ]; description = "Commandline tool to generate static or random JSON records"; diff --git a/pkgs/by-name/mk/mkjson/package.nix b/pkgs/by-name/mk/mkjson/package.nix index dfa170a5303d25..09e4b73886a2a3 100644 --- a/pkgs/by-name/mk/mkjson/package.nix +++ b/pkgs/by-name/mk/mkjson/package.nix @@ -1 +1,2 @@ -{ haskell, haskellPackages }: haskell.lib.justStaticExecutables (haskellPackages.callPackage ./generated.nix { }) +{ haskell, haskellPackages }: +haskell.lib.justStaticExecutables (haskellPackages.callPackage ./generated.nix { }) diff --git a/pkgs/by-name/mk/mkl/package.nix b/pkgs/by-name/mk/mkl/package.nix index dc8b674f5c265c..9f223473c0971c 100644 --- a/pkgs/by-name/mk/mkl/package.nix +++ b/pkgs/by-name/mk/mkl/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, callPackage -, stdenvNoCC -, fetchurl -, rpmextract -, _7zz -, cctools -, validatePkgConfig -, enableStatic ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + callPackage, + stdenvNoCC, + fetchurl, + rpmextract, + _7zz, + cctools, + validatePkgConfig, + enableStatic ? stdenv.hostPlatform.isStatic, }: /* @@ -62,123 +63,162 @@ let hash = "sha256-pzJpQdiYVpcKDShePak2I0uEh7u08vJgX7OBF5p5yAM="; }; -in stdenvNoCC.mkDerivation ({ - pname = "mkl"; - inherit version; - - dontUnpack = stdenvNoCC.hostPlatform.isLinux; - - sourceRoot = if stdenvNoCC.hostPlatform.isDarwin then "." else null; - - nativeBuildInputs = [ validatePkgConfig ] ++ (if stdenvNoCC.hostPlatform.isDarwin - then - [ _7zz cctools ] - else - [ rpmextract ]); - - buildPhase = if stdenvNoCC.hostPlatform.isDarwin then '' - for f in bootstrapper.app/Contents/Resources/packages/*/cupPayload.cup; do - tar -xf $f - done - mkdir -p opt/intel - mv _installdir opt/intel/oneapi - '' else '' - rpmextract ${oneapi-mkl} - rpmextract ${oneapi-mkl-common} - rpmextract ${oneapi-mkl-common-devel} - rpmextract ${oneapi-mkl-devel} - rpmextract ${oneapi-openmp} - rpmextract ${oneapi-tbb} - ''; - - installPhase = '' - for f in $(find . -name 'mkl*.pc') ; do - bn=$(basename $f) - substituteInPlace $f \ - --replace $\{MKLROOT} "$out" \ - --replace "lib/intel64" "lib" - - sed -r -i "s|^prefix=.*|prefix=$out|g" $f - done - - for f in $(find opt/intel -name 'mkl*iomp.pc') ; do - substituteInPlace $f --replace "../compiler/lib" "lib" - done - - # License - install -Dm0655 -t $out/share/doc/mkl opt/intel/oneapi/mkl/${mklVersion}/licensing/license.txt - - # Dynamic libraries - mkdir -p $out/lib - cp -a opt/intel/oneapi/mkl/${mklVersion}/lib/${lib.optionalString stdenvNoCC.hostPlatform.isLinux "intel64"}/*${shlibExt}* $out/lib - cp -a opt/intel/oneapi/compiler/${mklVersion}/${if stdenvNoCC.hostPlatform.isDarwin then "mac" else "linux"}/compiler/lib/${lib.optionalString stdenvNoCC.hostPlatform.isLinux "intel64_lin"}/*${shlibExt}* $out/lib - cp -a opt/intel/oneapi/tbb/${tbbVersion}/lib/${lib.optionalString stdenvNoCC.hostPlatform.isLinux "intel64/gcc4.8"}/*${shlibExt}* $out/lib - - # Headers - cp -r opt/intel/oneapi/mkl/${mklVersion}/include $out/ - - # CMake config - cp -r opt/intel/oneapi/mkl/${mklVersion}/lib/cmake $out/lib - '' + - (if enableStatic then '' - install -Dm0644 -t $out/lib opt/intel/oneapi/mkl/${mklVersion}/lib/${lib.optionalString stdenvNoCC.hostPlatform.isLinux "intel64"}/*.a - install -Dm0644 -t $out/lib/pkgconfig opt/intel/oneapi/mkl/${mklVersion}/lib/pkgconfig/*.pc - '' else '' - cp opt/intel/oneapi/mkl/${mklVersion}/lib/${lib.optionalString stdenvNoCC.hostPlatform.isLinux "intel64"}/*${shlibExt}* $out/lib - install -Dm0644 -t $out/lib/pkgconfig opt/intel/oneapi/mkl/${mklVersion}/lib/pkgconfig/*dynamic*.pc - '') + '' - # Setup symlinks for blas / lapack - ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/libblas${shlibExt} - ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/libcblas${shlibExt} - ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/liblapack${shlibExt} - ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/liblapacke${shlibExt} - '' + lib.optionalString stdenvNoCC.hostPlatform.isLinux '' - ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/libblas${shlibExt}".3" - ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/libcblas${shlibExt}".3" - ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/liblapack${shlibExt}".3" - ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/liblapacke${shlibExt}".3" - ''; - - # fixDarwinDylibName fails for libmkl_cdft_core.dylib because the - # larger updated load commands do not fit. Use install_name_tool - # explicitly and ignore the error. - postFixup = lib.optionalString stdenvNoCC.hostPlatform.isDarwin '' - for f in $out/lib/*.dylib; do - install_name_tool -id $out/lib/$(basename $f) $f || true - done - install_name_tool -change @rpath/libiomp5.dylib $out/lib/libiomp5.dylib $out/lib/libmkl_intel_thread.dylib - install_name_tool -change @rpath/libtbb.12.dylib $out/lib/libtbb.12.dylib $out/lib/libmkl_tbb_thread.dylib - install_name_tool -change @rpath/libtbbmalloc.2.dylib $out/lib/libtbbmalloc.2.dylib $out/lib/libtbbmalloc_proxy.dylib - ''; - - # Per license agreement, do not modify the binary - dontStrip = true; - dontPatchELF = true; - - passthru.tests = { - pkg-config-dynamic-iomp = callPackage ./test { enableStatic = false; execution = "iomp"; }; - pkg-config-static-iomp = callPackage ./test { enableStatic = true; execution = "iomp"; }; - pkg-config-dynamic-seq = callPackage ./test { enableStatic = false; execution = "seq"; }; - pkg-config-static-seq = callPackage ./test { enableStatic = true; execution = "seq"; }; - }; - - meta = with lib; { - description = "Intel OneAPI Math Kernel Library"; - longDescription = '' - Intel OneAPI Math Kernel Library (Intel oneMKL) optimizes code with minimal - effort for future generations of Intel processors. It is compatible with your - choice of compilers, languages, operating systems, and linking and - threading models. +in +stdenvNoCC.mkDerivation ( + { + pname = "mkl"; + inherit version; + + dontUnpack = stdenvNoCC.hostPlatform.isLinux; + + sourceRoot = if stdenvNoCC.hostPlatform.isDarwin then "." else null; + + nativeBuildInputs = + [ validatePkgConfig ] + ++ ( + if stdenvNoCC.hostPlatform.isDarwin then + [ + _7zz + cctools + ] + else + [ rpmextract ] + ); + + buildPhase = + if stdenvNoCC.hostPlatform.isDarwin then + '' + for f in bootstrapper.app/Contents/Resources/packages/*/cupPayload.cup; do + tar -xf $f + done + mkdir -p opt/intel + mv _installdir opt/intel/oneapi + '' + else + '' + rpmextract ${oneapi-mkl} + rpmextract ${oneapi-mkl-common} + rpmextract ${oneapi-mkl-common-devel} + rpmextract ${oneapi-mkl-devel} + rpmextract ${oneapi-openmp} + rpmextract ${oneapi-tbb} + ''; + + installPhase = + '' + for f in $(find . -name 'mkl*.pc') ; do + bn=$(basename $f) + substituteInPlace $f \ + --replace $\{MKLROOT} "$out" \ + --replace "lib/intel64" "lib" + + sed -r -i "s|^prefix=.*|prefix=$out|g" $f + done + + for f in $(find opt/intel -name 'mkl*iomp.pc') ; do + substituteInPlace $f --replace "../compiler/lib" "lib" + done + + # License + install -Dm0655 -t $out/share/doc/mkl opt/intel/oneapi/mkl/${mklVersion}/licensing/license.txt + + # Dynamic libraries + mkdir -p $out/lib + cp -a opt/intel/oneapi/mkl/${mklVersion}/lib/${lib.optionalString stdenvNoCC.hostPlatform.isLinux "intel64"}/*${shlibExt}* $out/lib + cp -a opt/intel/oneapi/compiler/${mklVersion}/${ + if stdenvNoCC.hostPlatform.isDarwin then "mac" else "linux" + }/compiler/lib/${lib.optionalString stdenvNoCC.hostPlatform.isLinux "intel64_lin"}/*${shlibExt}* $out/lib + cp -a opt/intel/oneapi/tbb/${tbbVersion}/lib/${lib.optionalString stdenvNoCC.hostPlatform.isLinux "intel64/gcc4.8"}/*${shlibExt}* $out/lib + + # Headers + cp -r opt/intel/oneapi/mkl/${mklVersion}/include $out/ + + # CMake config + cp -r opt/intel/oneapi/mkl/${mklVersion}/lib/cmake $out/lib + '' + + ( + if enableStatic then + '' + install -Dm0644 -t $out/lib opt/intel/oneapi/mkl/${mklVersion}/lib/${lib.optionalString stdenvNoCC.hostPlatform.isLinux "intel64"}/*.a + install -Dm0644 -t $out/lib/pkgconfig opt/intel/oneapi/mkl/${mklVersion}/lib/pkgconfig/*.pc + '' + else + '' + cp opt/intel/oneapi/mkl/${mklVersion}/lib/${lib.optionalString stdenvNoCC.hostPlatform.isLinux "intel64"}/*${shlibExt}* $out/lib + install -Dm0644 -t $out/lib/pkgconfig opt/intel/oneapi/mkl/${mklVersion}/lib/pkgconfig/*dynamic*.pc + '' + ) + + '' + # Setup symlinks for blas / lapack + ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/libblas${shlibExt} + ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/libcblas${shlibExt} + ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/liblapack${shlibExt} + ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/liblapacke${shlibExt} + '' + + lib.optionalString stdenvNoCC.hostPlatform.isLinux '' + ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/libblas${shlibExt}".3" + ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/libcblas${shlibExt}".3" + ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/liblapack${shlibExt}".3" + ln -s $out/lib/libmkl_rt${shlibExt} $out/lib/liblapacke${shlibExt}".3" + ''; + + # fixDarwinDylibName fails for libmkl_cdft_core.dylib because the + # larger updated load commands do not fit. Use install_name_tool + # explicitly and ignore the error. + postFixup = lib.optionalString stdenvNoCC.hostPlatform.isDarwin '' + for f in $out/lib/*.dylib; do + install_name_tool -id $out/lib/$(basename $f) $f || true + done + install_name_tool -change @rpath/libiomp5.dylib $out/lib/libiomp5.dylib $out/lib/libmkl_intel_thread.dylib + install_name_tool -change @rpath/libtbb.12.dylib $out/lib/libtbb.12.dylib $out/lib/libmkl_tbb_thread.dylib + install_name_tool -change @rpath/libtbbmalloc.2.dylib $out/lib/libtbbmalloc.2.dylib $out/lib/libtbbmalloc_proxy.dylib ''; - homepage = "https://software.intel.com/en-us/mkl"; - sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.issl; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; - maintainers = with maintainers; [ bhipple ]; - }; -} // lib.optionalAttrs stdenvNoCC.hostPlatform.isDarwin { - src = fetchurl { - url = "https://registrationcenter-download.intel.com/akdlm/IRC_NAS/087a9190-9d96-4b8c-bd2f-79159572ed89/m_onemkl_p_${mklVersion}.${rel}_offline.dmg"; - hash = "sha256-bUaaJPSaLr60fw0DzDCjPvY/UucHlLbCSLyQxyiAi04="; - }; -}) + + # Per license agreement, do not modify the binary + dontStrip = true; + dontPatchELF = true; + + passthru.tests = { + pkg-config-dynamic-iomp = callPackage ./test { + enableStatic = false; + execution = "iomp"; + }; + pkg-config-static-iomp = callPackage ./test { + enableStatic = true; + execution = "iomp"; + }; + pkg-config-dynamic-seq = callPackage ./test { + enableStatic = false; + execution = "seq"; + }; + pkg-config-static-seq = callPackage ./test { + enableStatic = true; + execution = "seq"; + }; + }; + + meta = with lib; { + description = "Intel OneAPI Math Kernel Library"; + longDescription = '' + Intel OneAPI Math Kernel Library (Intel oneMKL) optimizes code with minimal + effort for future generations of Intel processors. It is compatible with your + choice of compilers, languages, operating systems, and linking and + threading models. + ''; + homepage = "https://software.intel.com/en-us/mkl"; + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; + license = licenses.issl; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; + maintainers = with maintainers; [ bhipple ]; + }; + } + // lib.optionalAttrs stdenvNoCC.hostPlatform.isDarwin { + src = fetchurl { + url = "https://registrationcenter-download.intel.com/akdlm/IRC_NAS/087a9190-9d96-4b8c-bd2f-79159572ed89/m_onemkl_p_${mklVersion}.${rel}_offline.dmg"; + hash = "sha256-bUaaJPSaLr60fw0DzDCjPvY/UucHlLbCSLyQxyiAi04="; + }; + } +) diff --git a/pkgs/by-name/mk/mkl/test/default.nix b/pkgs/by-name/mk/mkl/test/default.nix index 1717e11e43d867..848b7092abae45 100644 --- a/pkgs/by-name/mk/mkl/test/default.nix +++ b/pkgs/by-name/mk/mkl/test/default.nix @@ -1,14 +1,16 @@ -{ stdenv -, pkg-config -, mkl +{ + stdenv, + pkg-config, + mkl, -, enableStatic ? false -, execution ? "seq" + enableStatic ? false, + execution ? "seq", }: let linkType = if enableStatic then "static" else "dynamic"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "mkl-test"; version = mkl.version; diff --git a/pkgs/by-name/mk/mkp224o/package.nix b/pkgs/by-name/mk/mkp224o/package.nix index 318284a4318fde..b6d12752d9ad21 100644 --- a/pkgs/by-name/mk/mkp224o/package.nix +++ b/pkgs/by-name/mk/mkp224o/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, autoreconfHook, libsodium }: +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + libsodium, +}: stdenv.mkDerivation rec { pname = "mkp224o"; @@ -15,17 +21,37 @@ stdenv.mkDerivation rec { let # compile few variants with different implementation of crypto # the fastest depends on a particular cpu - variants = [ - { suffix = "ref10"; configureFlags = ["--enable-ref10"]; } - { suffix = "donna"; configureFlags = ["--enable-donna"]; } - ] ++ lib.optionals stdenv.hostPlatform.isx86 [ - { suffix = "donna-sse2"; configureFlags = ["--enable-donna-sse2"]; } - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ - { suffix = "amd64-51-30k"; configureFlags = ["--enable-amd64-51-30k"]; } - { suffix = "amd64-64-24k"; configureFlags = ["--enable-amd64-64-24k"]; } - ]; + variants = + [ + { + suffix = "ref10"; + configureFlags = [ "--enable-ref10" ]; + } + { + suffix = "donna"; + configureFlags = [ "--enable-donna" ]; + } + ] + ++ lib.optionals stdenv.hostPlatform.isx86 [ + { + suffix = "donna-sse2"; + configureFlags = [ "--enable-donna-sse2" ]; + } + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + { + suffix = "amd64-51-30k"; + configureFlags = [ "--enable-amd64-51-30k" ]; + } + { + suffix = "amd64-64-24k"; + configureFlags = [ "--enable-amd64-64-24k" ]; + } + ]; in - lib.concatMapStrings ({suffix, configureFlags}: '' + lib.concatMapStrings ( + { suffix, configureFlags }: + '' install -D ${ stdenv.mkDerivation { name = "mkp224o-${suffix}-${version}"; @@ -35,7 +61,8 @@ stdenv.mkDerivation rec { installPhase = "install -D mkp224o $out"; } } $out/bin/mkp224o-${suffix} - '') variants; + '' + ) variants; meta = with lib; { description = "Vanity address generator for tor onion v3 (ed25519) hidden services"; diff --git a/pkgs/by-name/mk/mkrand/package.nix b/pkgs/by-name/mk/mkrand/package.nix index 38ef22117fa33f..c919e16eb58e61 100644 --- a/pkgs/by-name/mk/mkrand/package.nix +++ b/pkgs/by-name/mk/mkrand/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mkrand"; @@ -19,4 +23,4 @@ stdenv.mkDerivation rec { license = lib.licenses.mit; platforms = lib.platforms.all; }; - } +} diff --git a/pkgs/by-name/mk/mksh/package.nix b/pkgs/by-name/mk/mksh/package.nix index f22fc93578a388..39b4e0d686eec5 100644 --- a/pkgs/by-name/mk/mksh/package.nix +++ b/pkgs/by-name/mk/mksh/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, installShellFiles +{ + lib, + stdenv, + fetchurl, + installShellFiles, }: stdenv.mkDerivation (finalAttrs: { @@ -54,8 +55,15 @@ stdenv.mkDerivation (finalAttrs: { also to be readily available under other UNIX(R)-like operating systems. ''; - license = with lib.licenses; [ miros isc unicode-dfs-2016 ]; - maintainers = with lib.maintainers; [ AndersonTorres joachifm ]; + license = with lib.licenses; [ + miros + isc + unicode-dfs-2016 + ]; + maintainers = with lib.maintainers; [ + AndersonTorres + joachifm + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/by-name/mk/mktemp/package.nix b/pkgs/by-name/mk/mktemp/package.nix index ca16611332f769..4b644672dd8e21 100644 --- a/pkgs/by-name/mk/mktemp/package.nix +++ b/pkgs/by-name/mk/mktemp/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, groff +{ + lib, + stdenv, + fetchurl, + fetchpatch, + groff, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mk/mktorrent/package.nix b/pkgs/by-name/mk/mktorrent/package.nix index 3fb3f7390fe6ce..4edbb1acab46f1 100644 --- a/pkgs/by-name/mk/mktorrent/package.nix +++ b/pkgs/by-name/mk/mktorrent/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + openssl, +}: stdenv.mkDerivation rec { pname = "mktorrent"; @@ -11,7 +16,12 @@ stdenv.mkDerivation rec { sha256 = "17pdc5mandl739f8q26n5is8ga56s83aqcrwhlnnplbxwx2inidr"; }; - makeFlags = [ "USE_PTHREADS=1" "USE_OPENSSL=1" "USE_LONG_OPTIONS=1" ] + makeFlags = + [ + "USE_PTHREADS=1" + "USE_OPENSSL=1" + "USE_LONG_OPTIONS=1" + ] ++ lib.optional stdenv.hostPlatform.isi686 "USE_LARGE_FILES=1" ++ lib.optional stdenv.hostPlatform.isLinux "CFLAGS=-lgcc_s"; @@ -23,7 +33,10 @@ stdenv.mkDerivation rec { description = "Command line utility to create BitTorrent metainfo files"; homepage = "https://github.com/pobrn/mktorrent/wiki"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ Profpatsch winter ]; + maintainers = with maintainers; [ + Profpatsch + winter + ]; platforms = platforms.all; mainProgram = "mktorrent"; }; diff --git a/pkgs/by-name/ml/mlarchive2maildir/package.nix b/pkgs/by-name/ml/mlarchive2maildir/package.nix index d381dd0b0f2713..e80d7a5d35af74 100644 --- a/pkgs/by-name/ml/mlarchive2maildir/package.nix +++ b/pkgs/by-name/ml/mlarchive2maildir/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchPypi }: +{ + lib, + python3, + fetchPypi, +}: python3.pkgs.buildPythonApplication rec { pname = "mlarchive2maildir"; diff --git a/pkgs/by-name/ml/mlc/package.nix b/pkgs/by-name/ml/mlc/package.nix index 524db47d8e3d15..ee0bf347bac64e 100644 --- a/pkgs/by-name/ml/mlc/package.nix +++ b/pkgs/by-name/ml/mlc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, patchelf }: +{ + lib, + stdenv, + fetchurl, + patchelf, +}: stdenv.mkDerivation rec { pname = "mlc"; version = "3.9a"; diff --git a/pkgs/by-name/ml/mle/package.nix b/pkgs/by-name/ml/mle/package.nix index 079c24c2e732b3..c11fc690e55b48 100644 --- a/pkgs/by-name/ml/mle/package.nix +++ b/pkgs/by-name/ml/mle/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, pcre2 -, uthash -, lua5_4 -, makeWrapper -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + pcre2, + uthash, + lua5_4, + makeWrapper, + installShellFiles, }: stdenv.mkDerivation rec { @@ -26,9 +27,16 @@ stdenv.mkDerivation rec { patchShebangs tests/* ''; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; - buildInputs = [ pcre2 uthash lua5_4 ]; + buildInputs = [ + pcre2 + uthash + lua5_4 + ]; doCheck = true; diff --git a/pkgs/by-name/ml/mlib/package.nix b/pkgs/by-name/ml/mlib/package.nix index 91e1271278333e..d91702689d07ef 100644 --- a/pkgs/by-name/ml/mlib/package.nix +++ b/pkgs/by-name/ml/mlib/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { @@ -14,7 +15,10 @@ stdenv.mkDerivation rec { hash = "sha256-r8ol923tNkZ13QXWjWpMrN6rBjjjg5XoBCho4OKdyvY="; }; - makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "PREFIX=$(out)" ]; + makeFlags = [ + "CC=${stdenv.cc.targetPrefix}cc" + "PREFIX=$(out)" + ]; doCheck = true; diff --git a/pkgs/by-name/ml/mlmmj/package.nix b/pkgs/by-name/ml/mlmmj/package.nix index 76ce2d01159986..f49a58338cbca2 100644 --- a/pkgs/by-name/ml/mlmmj/package.nix +++ b/pkgs/by-name/ml/mlmmj/package.nix @@ -15,11 +15,16 @@ stdenv.mkDerivation rec { domain = "codeberg.org"; owner = pname; repo = pname; - rev = "refs/tags/RELEASE_" + lib.replaceStrings ["."] ["_"] version; + rev = "refs/tags/RELEASE_" + lib.replaceStrings [ "." ] [ "_" ] version; hash = "sha256-QetxCxny9elPetKuAsgKF0xTov1bNIRxi7gWhv6dYyU="; }; - nativeBuildInputs = [autoreconfHook atf pkg-config kyua]; + nativeBuildInputs = [ + autoreconfHook + atf + pkg-config + kyua + ]; configureFlags = lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ # AC_FUNC_MALLOC is broken on cross builds. @@ -36,7 +41,7 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "http://mlmmj.org"; description = "Mailing List Management Made Joyful"; - maintainers = [maintainers.edwtjo]; + maintainers = [ maintainers.edwtjo ]; platforms = platforms.linux; license = licenses.mit; }; diff --git a/pkgs/by-name/ml/mloader/package.nix b/pkgs/by-name/ml/mloader/package.nix index c4fa4820321655..6691d11440fa62 100644 --- a/pkgs/by-name/ml/mloader/package.nix +++ b/pkgs/by-name/ml/mloader/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "mloader"; diff --git a/pkgs/by-name/ml/mlocate/package.nix b/pkgs/by-name/ml/mlocate/package.nix index 4ae61095fff561..3a3bd207764f96 100644 --- a/pkgs/by-name/ml/mlocate/package.nix +++ b/pkgs/by-name/ml/mlocate/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mlocate"; diff --git a/pkgs/by-name/ml/mlvwm/package.nix b/pkgs/by-name/ml/mlvwm/package.nix index e2986159b20a73..37224e21ccf3f7 100644 --- a/pkgs/by-name/ml/mlvwm/package.nix +++ b/pkgs/by-name/ml/mlvwm/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, gccmakedep, libX11, libXext, libXpm, imake, installShellFiles, ... }: +{ + lib, + stdenv, + fetchFromGitHub, + gccmakedep, + libX11, + libXext, + libXpm, + imake, + installShellFiles, + ... +}: stdenv.mkDerivation rec { pname = "mlvwm"; @@ -13,7 +24,13 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ installShellFiles ]; - buildInputs = [ gccmakedep libX11 libXext libXpm imake ]; + buildInputs = [ + gccmakedep + libX11 + libXext + libXpm + imake + ]; buildPhase = '' (cd man && xmkmf) diff --git a/pkgs/by-name/ml/mlxbf-bootctl/package.nix b/pkgs/by-name/ml/mlxbf-bootctl/package.nix index 531956dd4b1caf..1356457380a580 100644 --- a/pkgs/by-name/ml/mlxbf-bootctl/package.nix +++ b/pkgs/by-name/ml/mlxbf-bootctl/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, fetchFromGitHub -, lib +{ + stdenv, + fetchFromGitHub, + lib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ml/mlxbf-bootimages/package.nix b/pkgs/by-name/ml/mlxbf-bootimages/package.nix index 7c4291fe778e8a..46e87a88d32b5d 100644 --- a/pkgs/by-name/ml/mlxbf-bootimages/package.nix +++ b/pkgs/by-name/ml/mlxbf-bootimages/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchurl -, dpkg +{ + stdenv, + lib, + fetchurl, + dpkg, }: stdenv.mkDerivation rec { @@ -34,7 +35,9 @@ stdenv.mkDerivation rec { # they are unfree. See https://github.com/Mellanox/bootimages/issues/3 license = licenses.unfree; platforms = [ "aarch64-linux" ]; - maintainers = with maintainers; [ nikstur thillux ]; + maintainers = with maintainers; [ + nikstur + thillux + ]; }; } - diff --git a/pkgs/by-name/mm/MMA/package.nix b/pkgs/by-name/mm/MMA/package.nix index 8f54e6e2971007..b5e52bd423320a 100644 --- a/pkgs/by-name/mm/MMA/package.nix +++ b/pkgs/by-name/mm/MMA/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeWrapper, python3, alsa-utils, timidity }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + python3, + alsa-utils, + timidity, +}: stdenv.mkDerivation rec { version = "21.09"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ python3 alsa-utils timidity ]; + buildInputs = [ + python3 + alsa-utils + timidity + ]; patchPhase = '' sed -i 's@/usr/bin/aplaymidi@/${alsa-utils}/bin/aplaymidi@g' mma-splitrec @@ -60,8 +72,7 @@ stdenv.mkDerivation rec { ''; meta = { - description = - "Creates MIDI tracks for a soloist to perform over from a user supplied file containing chords"; + description = "Creates MIDI tracks for a soloist to perform over from a user supplied file containing chords"; homepage = "https://www.mellowood.ca/mma/index.html"; license = lib.licenses.gpl2; maintainers = [ lib.maintainers.magnetophon ]; diff --git a/pkgs/by-name/mm/mm-common/package.nix b/pkgs/by-name/mm/mm-common/package.nix index cbc0f86e31b120..e4d2b8b2543977 100644 --- a/pkgs/by-name/mm/mm-common/package.nix +++ b/pkgs/by-name/mm/mm-common/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, bash -, gnome -, meson -, python3 -, ninja +{ + lib, + stdenv, + fetchurl, + bash, + gnome, + meson, + python3, + ninja, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mm/mm/package.nix b/pkgs/by-name/mm/mm/package.nix index 2fa65fddfd1d04..95e4d00a2e56e1 100644 --- a/pkgs/by-name/mm/mm/package.nix +++ b/pkgs/by-name/mm/mm/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchgit }: +{ + lib, + buildGoModule, + fetchgit, +}: buildGoModule { pname = "mm"; diff --git a/pkgs/by-name/mm/mmake/package.nix b/pkgs/by-name/mm/mmake/package.nix index b0aff161ecea82..c882a4d027dd2a 100644 --- a/pkgs/by-name/mm/mmake/package.nix +++ b/pkgs/by-name/mm/mmake/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "mmake"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-0z+sujzzBl/rtzXbhL4Os+jYfLUuO9PlXshUDxAH9DU="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; # Almost all tests require non-local networking, trying to resolve githubusercontent.com. doCheck = false; diff --git a/pkgs/by-name/mm/mmark/package.nix b/pkgs/by-name/mm/mmark/package.nix index ab371104dc8689..93a86bf61f1445 100644 --- a/pkgs/by-name/mm/mmark/package.nix +++ b/pkgs/by-name/mm/mmark/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, mmark }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + mmark, +}: buildGoModule rec { pname = "mmark"; @@ -16,7 +22,10 @@ buildGoModule rec { vendorHash = "sha256-GjR9cOGLB6URHQi+qcyNbP7rm0+y4wypvgUxgJzIgGQ="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests.version = testers.testVersion { package = mmark; diff --git a/pkgs/by-name/mm/mmc-utils/package.nix b/pkgs/by-name/mm/mmc-utils/package.nix index 76b7d3ae1af19c..7e197e6bbda553 100644 --- a/pkgs/by-name/mm/mmc-utils/package.nix +++ b/pkgs/by-name/mm/mmc-utils/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchzip, unstableGitUpdater }: +{ + lib, + stdenv, + fetchzip, + unstableGitUpdater, +}: stdenv.mkDerivation { pname = "mmc-utils"; @@ -10,7 +15,10 @@ stdenv.mkDerivation { sha256 = "/lkcZ/ArdBAStV9usavrbfjULXenqb+h2rbDJzxZjJk="; }; - makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "prefix=$(out)" ]; + makeFlags = [ + "CC=${stdenv.cc.targetPrefix}cc" + "prefix=$(out)" + ]; # causes redefinition of _FORTIFY_SOURCE hardeningDisable = [ "fortify3" ]; diff --git a/pkgs/by-name/mm/mmctl/package.nix b/pkgs/by-name/mm/mmctl/package.nix index 956a12f598bdbd..f5e6c29916f64a 100644 --- a/pkgs/by-name/mm/mmctl/package.nix +++ b/pkgs/by-name/mm/mmctl/package.nix @@ -1,4 +1,5 @@ -{ mattermost +{ + mattermost, }: mattermost.overrideAttrs (o: { diff --git a/pkgs/by-name/mm/mmdoc/package.nix b/pkgs/by-name/mm/mmdoc/package.nix index e7bf45dbb4c808..ca10843f3095c0 100644 --- a/pkgs/by-name/mm/mmdoc/package.nix +++ b/pkgs/by-name/mm/mmdoc/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmark-gfm -, xxd -, fastJson -, libzip -, ninja -, meson -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + cmark-gfm, + xxd, + fastJson, + libzip, + ninja, + meson, + pkg-config, }: stdenv.mkDerivation rec { @@ -21,9 +22,18 @@ stdenv.mkDerivation rec { hash = "sha256-NS8i5xvCwq0pSdfxnaxnpuwmDAkfH6Tkc4N2F6aGvWY="; }; - nativeBuildInputs = [ ninja meson pkg-config xxd ]; + nativeBuildInputs = [ + ninja + meson + pkg-config + xxd + ]; - buildInputs = [ cmark-gfm fastJson libzip ]; + buildInputs = [ + cmark-gfm + fastJson + libzip + ]; meta = with lib; { description = "Minimal Markdown Documentation"; diff --git a/pkgs/by-name/mm/mmh/package.nix b/pkgs/by-name/mm/mmh/package.nix index edcc48386a1106..81a34a381ef03c 100644 --- a/pkgs/by-name/mm/mmh/package.nix +++ b/pkgs/by-name/mm/mmh/package.nix @@ -1,6 +1,15 @@ -{ lib, stdenv, fetchurl, ncurses, autoreconfHook, flex }: -let rev = "b17ea39dc17e5514f33b3f5c34ede92bd16e208c"; -in stdenv.mkDerivation rec { +{ + lib, + stdenv, + fetchurl, + ncurses, + autoreconfHook, + flex, +}: +let + rev = "b17ea39dc17e5514f33b3f5c34ede92bd16e208c"; +in +stdenv.mkDerivation rec { pname = "mmh"; version = "unstable-2020-08-21"; @@ -13,10 +22,13 @@ in stdenv.mkDerivation rec { postPatch = '' substituteInPlace sbr/Makefile.in \ --replace "ar " "${stdenv.cc.targetPrefix}ar " - ''; + ''; buildInputs = [ ncurses ]; - nativeBuildInputs = [ autoreconfHook flex ]; + nativeBuildInputs = [ + autoreconfHook + flex + ]; meta = with lib; { description = "Set of electronic mail handling programs"; diff --git a/pkgs/by-name/mm/mmixware/package.nix b/pkgs/by-name/mm/mmixware/package.nix index 024028fd5b69dc..3349f3fbc02a6e 100644 --- a/pkgs/by-name/mm/mmixware/package.nix +++ b/pkgs/by-name/mm/mmixware/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, tetex }: +{ + lib, + stdenv, + fetchFromGitLab, + tetex, +}: stdenv.mkDerivation { pname = "mmixware"; @@ -25,7 +30,11 @@ stdenv.mkDerivation { nativeBuildInputs = [ tetex ]; enableParallelBuilding = true; - makeFlags = [ "all" "doc" "CFLAGS=-O2" ]; + makeFlags = [ + "all" + "doc" + "CFLAGS=-O2" + ]; installPhase = '' runHook preInstall @@ -39,10 +48,10 @@ stdenv.mkDerivation { ''; meta = with lib; { - description = "MMIX simulator and assembler"; - homepage = "https://www-cs-faculty.stanford.edu/~knuth/mmix-news.html"; - maintainers = with maintainers; [ siraben ]; - platforms = platforms.unix; - license = licenses.publicDomain; + description = "MMIX simulator and assembler"; + homepage = "https://www-cs-faculty.stanford.edu/~knuth/mmix-news.html"; + maintainers = with maintainers; [ siraben ]; + platforms = platforms.unix; + license = licenses.publicDomain; }; } diff --git a/pkgs/by-name/mm/mmsd/package.nix b/pkgs/by-name/mm/mmsd/package.nix index b156b4f125f329..fe594fa6620386 100644 --- a/pkgs/by-name/mm/mmsd/package.nix +++ b/pkgs/by-name/mm/mmsd/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchzip -, autoreconfHook -, pkg-config -, glib -, dbus +{ + lib, + stdenv, + fetchzip, + autoreconfHook, + pkg-config, + glib, + dbus, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mm/mmtc/package.nix b/pkgs/by-name/mm/mmtc/package.nix index 384bd449297460..8485728b8b79f5 100644 --- a/pkgs/by-name/mm/mmtc/package.nix +++ b/pkgs/by-name/mm/mmtc/package.nix @@ -1,4 +1,9 @@ -{ lib, rustPlatform, fetchFromGitHub, installShellFiles }: +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "mmtc"; diff --git a/pkgs/by-name/mm/mmtf-cpp/package.nix b/pkgs/by-name/mm/mmtf-cpp/package.nix index ef77380396730f..99f2287a20f26a 100644 --- a/pkgs/by-name/mm/mmtf-cpp/package.nix +++ b/pkgs/by-name/mm/mmtf-cpp/package.nix @@ -1,10 +1,16 @@ -{ stdenv, lib, fetchFromGitHub, cmake, msgpack } : +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + msgpack, +}: stdenv.mkDerivation (finalAttrs: { pname = "mmtf-cpp"; version = "1.1.0"; - src = fetchFromGitHub { + src = fetchFromGitHub { owner = "rcsb"; repo = "mmtf-cpp"; rev = "v${finalAttrs.version}"; diff --git a/pkgs/by-name/mm/mmutils/package.nix b/pkgs/by-name/mm/mmutils/package.nix index 4e744e9d9571cf..7b410dc72e1790 100644 --- a/pkgs/by-name/mm/mmutils/package.nix +++ b/pkgs/by-name/mm/mmutils/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libxcb }: +{ + lib, + stdenv, + fetchFromGitHub, + libxcb, +}: stdenv.mkDerivation rec { pname = "wmutils"; diff --git a/pkgs/by-name/mm/mmv-go/package.nix b/pkgs/by-name/mm/mmv-go/package.nix index 2a4c74ddea01ec..fdc05fdbd68c8c 100644 --- a/pkgs/by-name/mm/mmv-go/package.nix +++ b/pkgs/by-name/mm/mmv-go/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "mmv-go"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-HHGiMSBu3nrIChSYaEu9i22nwhLKgVQkPvbTMHBWwAE="; - ldflags = [ "-s" "-w" "-X main.revision=${src.rev}" ]; + ldflags = [ + "-s" + "-w" + "-X main.revision=${src.rev}" + ]; meta = with lib; { homepage = "https://github.com/itchyny/mmv"; diff --git a/pkgs/by-name/mm/mmv/package.nix b/pkgs/by-name/mm/mmv/package.nix index 6fd4c59e423e94..7016a79fd0d309 100644 --- a/pkgs/by-name/mm/mmv/package.nix +++ b/pkgs/by-name/mm/mmv/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, gengetopt, m4, gnupg -, git, perl, autoconf, automake, help2man }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + gengetopt, + m4, + gnupg, + git, + perl, + autoconf, + automake, + help2man, +}: stdenv.mkDerivation rec { pname = "mmv"; @@ -17,7 +29,17 @@ stdenv.mkDerivation rec { ./bootstrap ''; - nativeBuildInputs = [ gengetopt m4 git gnupg perl autoconf automake help2man pkg-config ]; + nativeBuildInputs = [ + gengetopt + m4 + git + gnupg + perl + autoconf + automake + help2man + pkg-config + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/mn/mnc/package.nix b/pkgs/by-name/mn/mnc/package.nix index 229600132aa9ad..8186682ad96a50 100644 --- a/pkgs/by-name/mn/mnc/package.nix +++ b/pkgs/by-name/mn/mnc/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromSourcehut +{ + lib, + buildGoModule, + fetchFromSourcehut, }: buildGoModule rec { diff --git a/pkgs/by-name/mn/mnemonicode/package.nix b/pkgs/by-name/mn/mnemonicode/package.nix index 1cd78fdce093eb..bf8859933505ee 100644 --- a/pkgs/by-name/mn/mnemonicode/package.nix +++ b/pkgs/by-name/mn/mnemonicode/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation (finalAttrs: { pname = "mnemonicode"; diff --git a/pkgs/by-name/mn/mni_autoreg/package.nix b/pkgs/by-name/mn/mni_autoreg/package.nix index 29ab02ee3139dd..10bb56265f57ef 100644 --- a/pkgs/by-name/mn/mni_autoreg/package.nix +++ b/pkgs/by-name/mn/mni_autoreg/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, makeWrapper, perlPackages, libminc }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + makeWrapper, + perlPackages, + libminc, +}: stdenv.mkDerivation rec { pname = "mni_autoreg"; @@ -11,9 +19,16 @@ stdenv.mkDerivation rec { sha256 = "sGMZbCrdV6yAOgGiqvBFOUr6pGlTCqwy8yNrPxMoKco="; }; - nativeBuildInputs = [ cmake makeWrapper ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; buildInputs = [ libminc ]; - propagatedBuildInputs = with perlPackages; [ perl GetoptTabular MNI-Perllib ]; + propagatedBuildInputs = with perlPackages; [ + perl + GetoptTabular + MNI-Perllib + ]; cmakeFlags = [ "-DLIBMINC_DIR=${libminc}/lib/cmake" ]; # testing broken: './minc_wrapper: Permission denied' from Testing/ellipse0.mnc diff --git a/pkgs/by-name/mn/mnist/package.nix b/pkgs/by-name/mn/mnist/package.nix index 3df5001e70ef15..5a54f6403c6a62 100644 --- a/pkgs/by-name/mn/mnist/package.nix +++ b/pkgs/by-name/mn/mnist/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: let srcs = { train-images = fetchurl { @@ -19,27 +23,27 @@ let }; }; in - stdenvNoCC.mkDerivation rec { - pname = "mnist"; - version = "2018-11-16"; - installPhase = '' - mkdir -p $out - ln -s "${srcs.train-images}" "$out/${srcs.train-images.name}" - ln -s "${srcs.train-labels}" "$out/${srcs.train-labels.name}" - ln -s "${srcs.test-images}" "$out/${srcs.test-images.name}" - ln -s "${srcs.test-labels}" "$out/${srcs.test-labels.name}" +stdenvNoCC.mkDerivation rec { + pname = "mnist"; + version = "2018-11-16"; + installPhase = '' + mkdir -p $out + ln -s "${srcs.train-images}" "$out/${srcs.train-images.name}" + ln -s "${srcs.train-labels}" "$out/${srcs.train-labels.name}" + ln -s "${srcs.test-images}" "$out/${srcs.test-images.name}" + ln -s "${srcs.test-labels}" "$out/${srcs.test-labels.name}" + ''; + dontUnpack = true; + meta = with lib; { + description = "Large database of handwritten digits"; + longDescription = '' + The MNIST database (Modified National Institute of Standards and + Technology database) is a large database of handwritten digits that is + commonly used for training various image processing systems. ''; - dontUnpack = true; - meta = with lib; { - description = "Large database of handwritten digits"; - longDescription = '' - The MNIST database (Modified National Institute of Standards and - Technology database) is a large database of handwritten digits that is - commonly used for training various image processing systems. - ''; - homepage = "http://yann.lecun.com/exdb/mnist/index.html"; - license = licenses.cc-by-sa-30; - platforms = platforms.all; - maintainers = with maintainers; [ cmcdragonkai ]; - }; - } + homepage = "http://yann.lecun.com/exdb/mnist/index.html"; + license = licenses.cc-by-sa-30; + platforms = platforms.all; + maintainers = with maintainers; [ cmcdragonkai ]; + }; +} diff --git a/pkgs/by-name/mn/mno16/package.nix b/pkgs/by-name/mn/mno16/package.nix index 59597120c1003d..8d4b6d036eea36 100644 --- a/pkgs/by-name/mn/mno16/package.nix +++ b/pkgs/by-name/mn/mno16/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "mno16"; diff --git a/pkgs/by-name/mo/mo/package.nix b/pkgs/by-name/mo/mo/package.nix index 4ce066920b9931..8794800e5662eb 100644 --- a/pkgs/by-name/mo/mo/package.nix +++ b/pkgs/by-name/mo/mo/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, lib -, fetchFromGitHub +{ + stdenv, + lib, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mo/mob/package.nix b/pkgs/by-name/mo/mob/package.nix index 115162094a1c8d..789baeb400d1e0 100644 --- a/pkgs/by-name/mo/mob/package.nix +++ b/pkgs/by-name/mo/mob/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, stdenv -, withSpeech ? !stdenv.hostPlatform.isDarwin -, makeWrapper -, espeak-ng +{ + lib, + buildGoModule, + fetchFromGitHub, + stdenv, + withSpeech ? !stdenv.hostPlatform.isDarwin, + makeWrapper, + espeak-ng, }: buildGoModule rec { @@ -24,7 +25,10 @@ buildGoModule rec { makeWrapper ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; doCheck = false; diff --git a/pkgs/by-name/mo/mobilecoin-wallet/package.nix b/pkgs/by-name/mo/mobilecoin-wallet/package.nix index 91c59315ba6a90..1fba3f5a3f172f 100644 --- a/pkgs/by-name/mo/mobilecoin-wallet/package.nix +++ b/pkgs/by-name/mo/mobilecoin-wallet/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools }: +{ + lib, + fetchurl, + appimageTools, +}: let pname = "mobilecoin-wallet"; @@ -9,7 +13,8 @@ let }; appimageContents = appimageTools.extractType2 { inherit pname version src; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; extraPkgs = pkgs: [ pkgs.libsecret ]; diff --git a/pkgs/by-name/mo/mockobjects/package.nix b/pkgs/by-name/mo/mockobjects/package.nix index 113c377240b439..cf94033856796a 100644 --- a/pkgs/by-name/mo/mockobjects/package.nix +++ b/pkgs/by-name/mo/mockobjects/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mockobjects"; diff --git a/pkgs/by-name/mo/mockoon/package.nix b/pkgs/by-name/mo/mockoon/package.nix index 76d32bd24666fe..f0e276c0cc5fb2 100644 --- a/pkgs/by-name/mo/mockoon/package.nix +++ b/pkgs/by-name/mo/mockoon/package.nix @@ -1,6 +1,7 @@ -{ lib -, appimageTools -, fetchurl +{ + lib, + appimageTools, + fetchurl, }: let diff --git a/pkgs/by-name/mo/mod-arpeggiator-lv2/package.nix b/pkgs/by-name/mo/mod-arpeggiator-lv2/package.nix index 0f8ef18d569a59..934175349420ae 100644 --- a/pkgs/by-name/mo/mod-arpeggiator-lv2/package.nix +++ b/pkgs/by-name/mo/mod-arpeggiator-lv2/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, lv2, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + lv2, + pkg-config, +}: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mo/mod-distortion/package.nix b/pkgs/by-name/mo/mod-distortion/package.nix index 7e2b2bf6cfbda8..804dfe60befb87 100644 --- a/pkgs/by-name/mo/mod-distortion/package.nix +++ b/pkgs/by-name/mo/mod-distortion/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + lv2, +}: stdenv.mkDerivation { pname = "mod-distortion"; diff --git a/pkgs/by-name/mo/mod/package.nix b/pkgs/by-name/mo/mod/package.nix index 8e71eb969b6b84..2a866dbd54d5dd 100644 --- a/pkgs/by-name/mo/mod/package.nix +++ b/pkgs/by-name/mo/mod/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "mod"; @@ -23,7 +27,7 @@ buildGoModule rec { longDescription = '' Command line tool to upgrade/downgrade Semantic Import Versioning in Go Modules. - ''; + ''; homepage = "https://github.com/marwan-at-work/mod"; license = licenses.mit; maintainers = with maintainers; [ kalbasit ]; diff --git a/pkgs/by-name/mo/modd/package.nix b/pkgs/by-name/mo/modd/package.nix index 23116255c0de71..28c631528d7b62 100644 --- a/pkgs/by-name/mo/modd/package.nix +++ b/pkgs/by-name/mo/modd/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "modd"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-O+hJRMSwV/9NHxbaLjloCWnfPugfRYaXNve098wjbqQ="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Flexible developer tool that runs processes and responds to filesystem changes"; diff --git a/pkgs/by-name/mo/modem-manager-gui/package.nix b/pkgs/by-name/mo/modem-manager-gui/package.nix index a96031342f8ed9..9e342010356326 100644 --- a/pkgs/by-name/mo/modem-manager-gui/package.nix +++ b/pkgs/by-name/mo/modem-manager-gui/package.nix @@ -1,18 +1,20 @@ -{ lib, stdenv -, pkg-config -, python3 -, fetchFromGitLab -, fetchpatch -, gtk3 -, glib -, gdbm -, gtkspell3 -, ofono -, itstool -, libayatana-appindicator -, perlPackages -, meson -, ninja +{ + lib, + stdenv, + pkg-config, + python3, + fetchFromGitLab, + fetchpatch, + gtk3, + glib, + gdbm, + gtkspell3, + ofono, + itstool, + libayatana-appindicator, + perlPackages, + meson, + ninja, }: stdenv.mkDerivation (finalAttrs: { @@ -79,7 +81,10 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://linuxonly.ru/page/modem-manager-gui"; license = licenses.gpl3; - maintainers = with maintainers; [ ahuzik galagora ]; + maintainers = with maintainers; [ + ahuzik + galagora + ]; platforms = platforms.linux; mainProgram = "modem-manager-gui"; }; diff --git a/pkgs/by-name/mo/modemmanager/package.nix b/pkgs/by-name/mo/modemmanager/package.nix index a91854865b1b2b..0840191e498f56 100644 --- a/pkgs/by-name/mo/modemmanager/package.nix +++ b/pkgs/by-name/mo/modemmanager/package.nix @@ -1,29 +1,32 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, glib -, libgudev -, ppp -, gettext -, pkg-config -, libxslt -, python3 -, libmbim -, libqmi -, bash-completion -, meson -, ninja -, vala -, dbus -, bash -, gobject-introspection -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, polkit -, withPolkit ? lib.meta.availableOn stdenv.hostPlatform polkit -, systemd -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + glib, + libgudev, + ppp, + gettext, + pkg-config, + libxslt, + python3, + libmbim, + libqmi, + bash-completion, + meson, + ninja, + vala, + dbus, + bash, + gobject-introspection, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + polkit, + withPolkit ? lib.meta.availableOn stdenv.hostPlatform polkit, + systemd, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, }: stdenv.mkDerivation rec { @@ -52,33 +55,38 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ - meson - ninja - gettext - glib - pkg-config - libxslt - python3 - ] ++ lib.optionals withIntrospection [ - gobject-introspection - vala - ]; + nativeBuildInputs = + [ + meson + ninja + gettext + glib + pkg-config + libxslt + python3 + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + vala + ]; - buildInputs = [ - glib - libgudev - ppp - libmbim - libqmi - bash-completion - dbus - bash # shebangs in share/ModemManager/fcc-unlock.available.d/ - ] ++ lib.optionals withPolkit [ - polkit - ] ++ lib.optionals withSystemd [ - systemd - ]; + buildInputs = + [ + glib + libgudev + ppp + libmbim + libqmi + bash-completion + dbus + bash # shebangs in share/ModemManager/fcc-unlock.available.d/ + ] + ++ lib.optionals withPolkit [ + polkit + ] + ++ lib.optionals withSystemd [ + systemd + ]; nativeInstallCheckInputs = [ python3 diff --git a/pkgs/by-name/mo/modern-cpp-kafka/package.nix b/pkgs/by-name/mo/modern-cpp-kafka/package.nix index f8db36d613bf8a..3a73192a3ad44f 100644 --- a/pkgs/by-name/mo/modern-cpp-kafka/package.nix +++ b/pkgs/by-name/mo/modern-cpp-kafka/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, boost -, rdkafka -, gtest -, rapidjson +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + boost, + rdkafka, + gtest, + rapidjson, }: stdenv.mkDerivation rec { @@ -21,12 +22,14 @@ stdenv.mkDerivation rec { }; patches = [ - (fetchpatch { # https://github.com/morganstanley/modern-cpp-kafka/pull/221 + (fetchpatch { + # https://github.com/morganstanley/modern-cpp-kafka/pull/221 name = "fix-avoid-overwriting-library-paths.patch"; url = "https://github.com/morganstanley/modern-cpp-kafka/compare/a146d10bcf166f55299c7a55728abaaea52cb0e5...a0b5ec08315759097ce656813be57b2c38d79091.patch"; hash = "sha256-UsQcMvJoRTn5kgXhmXOyqfW3n59kGKO596U2WjtdqAY="; }) - (fetchpatch { # https://github.com/morganstanley/modern-cpp-kafka/pull/222 + (fetchpatch { + # https://github.com/morganstanley/modern-cpp-kafka/pull/222 name = "add-pkg-config-cmake-config.patch"; url = "https://github.com/morganstanley/modern-cpp-kafka/commit/edc576ab83710412f6201e2bb8de5cb41682ee4a.patch"; hash = "sha256-OjoSttnpgEwSZjCVKc888xJb5f1Dulu/rQqoGmqXNM4="; @@ -58,7 +61,10 @@ stdenv.mkDerivation rec { "-DCMAKE_CXX_FLAGS=-Wno-uninitialized" ]; - checkInputs = [ gtest rapidjson ]; + checkInputs = [ + gtest + rapidjson + ]; meta = with lib; { description = "C++ API for Kafka clients (i.e. KafkaProducer, KafkaConsumer, AdminClient)"; diff --git a/pkgs/by-name/mo/modprobed-db/package.nix b/pkgs/by-name/mo/modprobed-db/package.nix index c321aa6199f79c..12a799ff276be6 100644 --- a/pkgs/by-name/mo/modprobed-db/package.nix +++ b/pkgs/by-name/mo/modprobed-db/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, libevdev -, kmod -, bash -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libevdev, + kmod, + bash, + installShellFiles, }: let pname = "modprobed-db"; @@ -22,8 +23,15 @@ stdenv.mkDerivation { }; strictDeps = true; - nativeBuildInputs = [ pkg-config installShellFiles ]; - buildInputs = [ kmod libevdev bash ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; + buildInputs = [ + kmod + libevdev + bash + ]; installFlags = [ "PREFIX=$(out)" diff --git a/pkgs/by-name/mo/mods/package.nix b/pkgs/by-name/mo/mods/package.nix index 5a5bb912cb2fe3..b00f4f552865b1 100644 --- a/pkgs/by-name/mo/mods/package.nix +++ b/pkgs/by-name/mo/mods/package.nix @@ -61,7 +61,10 @@ buildGoModule rec { description = "AI on the command line"; homepage = "https://github.com/charmbracelet/mods"; license = licenses.mit; - maintainers = with maintainers; [ dit7ya caarlos0 ]; + maintainers = with maintainers; [ + dit7ya + caarlos0 + ]; mainProgram = "mods"; }; } diff --git a/pkgs/by-name/mo/modsecurity-crs/package.nix b/pkgs/by-name/mo/modsecurity-crs/package.nix index 16e21577f78ea5..f95bb592e4599f 100644 --- a/pkgs/by-name/mo/modsecurity-crs/package.nix +++ b/pkgs/by-name/mo/modsecurity-crs/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { version = "3.3.4"; diff --git a/pkgs/by-name/mo/modsecurity_standalone/package.nix b/pkgs/by-name/mo/modsecurity_standalone/package.nix index 23433ee05d93f7..599d7e1195b027 100644 --- a/pkgs/by-name/mo/modsecurity_standalone/package.nix +++ b/pkgs/by-name/mo/modsecurity_standalone/package.nix @@ -1,10 +1,23 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config, autoreconfHook -, curl, apacheHttpd, pcre, apr, aprutil, libxml2 -, luaSupport ? false, lua5, perl +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + autoreconfHook, + curl, + apacheHttpd, + pcre, + apr, + aprutil, + libxml2, + luaSupport ? false, + lua5, + perl, }: -let luaValue = if luaSupport then lua5 else "no"; - optional = lib.optional; +let + luaValue = if luaSupport then lua5 else "no"; + optional = lib.optional; in stdenv.mkDerivation rec { @@ -18,9 +31,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-hJ8wYeC83dl85bkUXGZKHpHzw9QRgtusj1/+Coxsx0k="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ curl apacheHttpd pcre apr aprutil libxml2 ] ++ - optional luaSupport lua5; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + curl + apacheHttpd + pcre + apr + aprutil + libxml2 + ] ++ optional luaSupport lua5; configureFlags = [ "--enable-standalone-module" @@ -34,7 +56,10 @@ stdenv.mkDerivation rec { "--with-lua=${luaValue}" ]; - outputs = ["out" "nginx"]; + outputs = [ + "out" + "nginx" + ]; # by default modsecurity's install script copies compiled output to httpd's modules folder # this patch removes those lines patches = [ ./Makefile.am.patch ]; @@ -51,7 +76,7 @@ stdenv.mkDerivation rec { description = "Open source, cross-platform web application firewall (WAF)"; license = licenses.asl20; homepage = "https://github.com/owasp-modsecurity/ModSecurity"; - maintainers = with maintainers; [offline]; - platforms = lib.platforms.linux ++ lib.platforms.darwin; + maintainers = with maintainers; [ offline ]; + platforms = lib.platforms.linux ++ lib.platforms.darwin; }; } diff --git a/pkgs/by-name/mo/moe/package.nix b/pkgs/by-name/mo/moe/package.nix index e60ce728a6fe6e..7d1f9a875cd597 100644 --- a/pkgs/by-name/mo/moe/package.nix +++ b/pkgs/by-name/mo/moe/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, lzip -, ncurses +{ + lib, + stdenv, + fetchurl, + lzip, + ncurses, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/mo/mojave-gtk-theme/package.nix b/pkgs/by-name/mo/mojave-gtk-theme/package.nix index dabb6e928dde71..2f8c76af7f87a0 100644 --- a/pkgs/by-name/mo/mojave-gtk-theme/package.nix +++ b/pkgs/by-name/mo/mojave-gtk-theme/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, glib -, gnome-shell -, gtk-engine-murrine -, gtk_engines -, inkscape -, jdupes -, optipng -, sassc -, which -, buttonSizeVariants ? [] # default to standard -, buttonVariants ? [] # default to all -, colorVariants ? [] # default to all -, opacityVariants ? [] # default to all -, themeVariants ? [] # default to MacOS blue -, wallpapers ? false -, gitUpdater +{ + lib, + stdenvNoCC, + fetchFromGitHub, + glib, + gnome-shell, + gtk-engine-murrine, + gtk_engines, + inkscape, + jdupes, + optipng, + sassc, + which, + buttonSizeVariants ? [ ], # default to standard + buttonVariants ? [ ], # default to all + colorVariants ? [ ], # default to all + opacityVariants ? [ ], # default to all + themeVariants ? [ ], # default to MacOS blue + wallpapers ? false, + gitUpdater, }: let @@ -42,108 +43,134 @@ let in lib.checkListOfEnum "${pname}: button size variants" [ "standard" "small" ] buttonSizeVariants -lib.checkListOfEnum "${pname}: button variants" [ "standard" "alt" ] buttonVariants -lib.checkListOfEnum "${pname}: color variants" [ "light" "dark" ] colorVariants -lib.checkListOfEnum "${pname}: opacity variants" [ "standard" "solid" ] opacityVariants -lib.checkListOfEnum "${pname}: theme variants" [ "default" "blue" "purple" "pink" "red" "orange" "yellow" "green" "grey" "all" ] themeVariants - -stdenvNoCC.mkDerivation rec { - inherit pname version; - - srcs = [ main_src ] ++ lib.optional wallpapers wallpapers_src; - - sourceRoot = main_src.name; - - nativeBuildInputs = [ - glib - gnome-shell - inkscape - jdupes - optipng - sassc - which - ]; - - buildInputs = [ - gtk_engines - ]; - - propagatedUserEnvPkgs = [ - gtk-engine-murrine - ]; - - # These fixup steps are slow and unnecessary. - dontPatchELF = true; - dontRewriteSymlinks = true; - - postPatch = '' - patchShebangs \ - install.sh \ - src/main/gtk-3.0/make_gresource_xml.sh \ - src/main/gtk-4.0/make_gresource_xml.sh - - for f in \ - render-assets.sh \ - src/assets/cinnamon/thumbnails/render-thumbnails.sh \ - src/assets/gtk-2.0/render-assets.sh \ - src/assets/gtk/common-assets/render-assets.sh \ - src/assets/gtk/thumbnails/render-thumbnails.sh \ - src/assets/gtk/windows-assets/render-alt-assets.sh \ - src/assets/gtk/windows-assets/render-alt-small-assets.sh \ - src/assets/gtk/windows-assets/render-assets.sh \ - src/assets/gtk/windows-assets/render-small-assets.sh \ - src/assets/metacity-1/render-assets.sh \ - src/assets/xfwm4/render-assets.sh - do - patchShebangs $f - substituteInPlace $f \ - --replace-fail /usr/bin/inkscape ${inkscape}/bin/inkscape \ - --replace-fail /usr/bin/optipng ${optipng}/bin/optipng - done - - ${lib.optionalString wallpapers '' - for f in ../${wallpapers_src.name}/Mojave{,-timed}.xml; do - substituteInPlace $f --replace-fail /usr $out + lib.checkListOfEnum + "${pname}: button variants" + [ "standard" "alt" ] + buttonVariants + lib.checkListOfEnum + "${pname}: color variants" + [ "light" "dark" ] + colorVariants + lib.checkListOfEnum + "${pname}: opacity variants" + [ "standard" "solid" ] + opacityVariants + lib.checkListOfEnum + "${pname}: theme variants" + [ + "default" + "blue" + "purple" + "pink" + "red" + "orange" + "yellow" + "green" + "grey" + "all" + ] + themeVariants + + stdenvNoCC.mkDerivation + rec { + inherit pname version; + + srcs = [ main_src ] ++ lib.optional wallpapers wallpapers_src; + + sourceRoot = main_src.name; + + nativeBuildInputs = [ + glib + gnome-shell + inkscape + jdupes + optipng + sassc + which + ]; + + buildInputs = [ + gtk_engines + ]; + + propagatedUserEnvPkgs = [ + gtk-engine-murrine + ]; + + # These fixup steps are slow and unnecessary. + dontPatchELF = true; + dontRewriteSymlinks = true; + + postPatch = '' + patchShebangs \ + install.sh \ + src/main/gtk-3.0/make_gresource_xml.sh \ + src/main/gtk-4.0/make_gresource_xml.sh + + for f in \ + render-assets.sh \ + src/assets/cinnamon/thumbnails/render-thumbnails.sh \ + src/assets/gtk-2.0/render-assets.sh \ + src/assets/gtk/common-assets/render-assets.sh \ + src/assets/gtk/thumbnails/render-thumbnails.sh \ + src/assets/gtk/windows-assets/render-alt-assets.sh \ + src/assets/gtk/windows-assets/render-alt-small-assets.sh \ + src/assets/gtk/windows-assets/render-assets.sh \ + src/assets/gtk/windows-assets/render-small-assets.sh \ + src/assets/metacity-1/render-assets.sh \ + src/assets/xfwm4/render-assets.sh + do + patchShebangs $f + substituteInPlace $f \ + --replace-fail /usr/bin/inkscape ${inkscape}/bin/inkscape \ + --replace-fail /usr/bin/optipng ${optipng}/bin/optipng done - ''} - ''; - - installPhase = '' - runHook preInstall - - name= ./install.sh \ - ${lib.optionalString (buttonSizeVariants != []) "--small " + builtins.toString buttonSizeVariants} \ - ${lib.optionalString (buttonVariants != []) "--alt " + builtins.toString buttonVariants} \ - ${lib.optionalString (colorVariants != []) "--color " + builtins.toString colorVariants} \ - ${lib.optionalString (opacityVariants != []) "--opacity " + builtins.toString opacityVariants} \ - ${lib.optionalString (themeVariants != []) "--theme " + builtins.toString themeVariants} \ - --icon nixos \ - --dest $out/share/themes - - rm $out/share/themes/*/COPYING - - ${lib.optionalString wallpapers '' - mkdir -p $out/share/backgrounds/Mojave - mkdir -p $out/share/gnome-background-properties - cp -a ../${wallpapers_src.name}/Mojave*.jpeg $out/share/backgrounds/Mojave/ - cp -a ../${wallpapers_src.name}/Mojave-timed.xml $out/share/backgrounds/Mojave/ - cp -a ../${wallpapers_src.name}/Mojave.xml $out/share/gnome-background-properties/ - ''} - - # Replace duplicate files with soft links to the first file in each - # set of duplicates, reducing the installed size in about 53% - jdupes --quiet --link-soft --recurse $out/share - - runHook postInstall - ''; - - passthru.updateScript = gitUpdater { }; - - meta = { - description = "Mac OSX Mojave like theme for GTK based desktop environments"; - homepage = "https://github.com/vinceliuice/Mojave-gtk-theme"; - license = lib.licenses.gpl3Only; - platforms = lib.platforms.unix; - maintainers = [ lib.maintainers.romildo ]; - }; -} + + ${lib.optionalString wallpapers '' + for f in ../${wallpapers_src.name}/Mojave{,-timed}.xml; do + substituteInPlace $f --replace-fail /usr $out + done + ''} + ''; + + installPhase = '' + runHook preInstall + + name= ./install.sh \ + ${ + lib.optionalString (buttonSizeVariants != [ ]) "--small " + builtins.toString buttonSizeVariants + } \ + ${lib.optionalString (buttonVariants != [ ]) "--alt " + builtins.toString buttonVariants} \ + ${lib.optionalString (colorVariants != [ ]) "--color " + builtins.toString colorVariants} \ + ${lib.optionalString (opacityVariants != [ ]) "--opacity " + builtins.toString opacityVariants} \ + ${lib.optionalString (themeVariants != [ ]) "--theme " + builtins.toString themeVariants} \ + --icon nixos \ + --dest $out/share/themes + + rm $out/share/themes/*/COPYING + + ${lib.optionalString wallpapers '' + mkdir -p $out/share/backgrounds/Mojave + mkdir -p $out/share/gnome-background-properties + cp -a ../${wallpapers_src.name}/Mojave*.jpeg $out/share/backgrounds/Mojave/ + cp -a ../${wallpapers_src.name}/Mojave-timed.xml $out/share/backgrounds/Mojave/ + cp -a ../${wallpapers_src.name}/Mojave.xml $out/share/gnome-background-properties/ + ''} + + # Replace duplicate files with soft links to the first file in each + # set of duplicates, reducing the installed size in about 53% + jdupes --quiet --link-soft --recurse $out/share + + runHook postInstall + ''; + + passthru.updateScript = gitUpdater { }; + + meta = { + description = "Mac OSX Mojave like theme for GTK based desktop environments"; + homepage = "https://github.com/vinceliuice/Mojave-gtk-theme"; + license = lib.licenses.gpl3Only; + platforms = lib.platforms.unix; + maintainers = [ lib.maintainers.romildo ]; + }; + } diff --git a/pkgs/by-name/mo/moka-icon-theme/package.nix b/pkgs/by-name/mo/moka-icon-theme/package.nix index d9fef47da0bb1f..9b03e14793387a 100644 --- a/pkgs/by-name/mo/moka-icon-theme/package.nix +++ b/pkgs/by-name/mo/moka-icon-theme/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenvNoCC, fetchFromGitHub, meson, ninja, gtk3, python3, faba-icon-theme, hicolor-icon-theme, jdupes }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + meson, + ninja, + gtk3, + python3, + faba-icon-theme, + hicolor-icon-theme, + jdupes, +}: stdenvNoCC.mkDerivation rec { pname = "moka-icon-theme"; @@ -42,7 +53,10 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { description = "Icon theme designed with a minimal flat style using simple geometry and bright colours"; homepage = "https://snwh.org/moka"; - license = with licenses; [ cc-by-sa-40 gpl3Only ]; + license = with licenses; [ + cc-by-sa-40 + gpl3Only + ]; # darwin cannot deal with file names differing only in case platforms = platforms.linux; maintainers = with maintainers; [ romildo ]; diff --git a/pkgs/by-name/mo/mokutil/package.nix b/pkgs/by-name/mo/mokutil/package.nix index cd36b8eaa1e9f2..c5dee7a093271e 100644 --- a/pkgs/by-name/mo/mokutil/package.nix +++ b/pkgs/by-name/mo/mokutil/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, pkg-config -, openssl -, efivar -, keyutils -, libxcrypt +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + pkg-config, + openssl, + efivar, + keyutils, + libxcrypt, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mo/molden/package.nix b/pkgs/by-name/mo/molden/package.nix index 7a15ef9363b59b..58349a76b753fd 100644 --- a/pkgs/by-name/mo/molden/package.nix +++ b/pkgs/by-name/mo/molden/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, which, gfortran, libGLU, xorg } : +{ + lib, + stdenv, + fetchurl, + which, + gfortran, + libGLU, + xorg, +}: stdenv.mkDerivation rec { version = "6.3"; @@ -10,38 +18,43 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ which ]; - buildInputs = [ gfortran libGLU xorg.libX11 xorg.libXmu ]; + buildInputs = [ + gfortran + libGLU + xorg.libX11 + xorg.libXmu + ]; patches = [ ./dont_register_file_types.patch ]; postPatch = '' - substituteInPlace ./makefile --replace '-L/usr/X11R6/lib' "" \ - --replace '-I/usr/X11R6/include' "" \ - --replace '/usr/local/' $out/ \ - --replace 'sudo' "" \ - --replace '-C surf depend' '-C surf' \ - --replace 'FFLAGS =' 'FFLAGS = -fallow-argument-mismatch' + substituteInPlace ./makefile --replace '-L/usr/X11R6/lib' "" \ + --replace '-I/usr/X11R6/include' "" \ + --replace '/usr/local/' $out/ \ + --replace 'sudo' "" \ + --replace '-C surf depend' '-C surf' \ + --replace 'FFLAGS =' 'FFLAGS = -fallow-argument-mismatch' - substituteInPlace ambfor/makefile --replace 'FFLAGS =' 'FFLAGS = -fallow-argument-mismatch' + substituteInPlace ambfor/makefile --replace 'FFLAGS =' 'FFLAGS = -fallow-argument-mismatch' - sed -in '/^# DO NOT DELETE THIS LINE/q;' surf/Makefile + sed -in '/^# DO NOT DELETE THIS LINE/q;' surf/Makefile ''; preInstall = '' - mkdir -p $out/bin + mkdir -p $out/bin ''; enableParallelBuilding = false; meta = with lib; { - description = "Display and manipulate molecular structures"; - homepage = "http://www3.cmbi.umcn.nl/molden/"; - license = { - fullName = "Free for academic/non-profit use"; - url = "http://www3.cmbi.umcn.nl/molden/CopyRight.html"; - free = false; - }; - platforms = platforms.linux; - maintainers = with maintainers; [ markuskowa ]; + description = "Display and manipulate molecular structures"; + homepage = "http://www3.cmbi.umcn.nl/molden/"; + license = { + fullName = "Free for academic/non-profit use"; + url = "http://www3.cmbi.umcn.nl/molden/CopyRight.html"; + free = false; + }; + platforms = platforms.linux; + maintainers = with maintainers; [ markuskowa ]; }; } diff --git a/pkgs/by-name/mo/mole/package.nix b/pkgs/by-name/mo/mole/package.nix index dca72a66b1f80a..0665e0951c1b83 100644 --- a/pkgs/by-name/mo/mole/package.nix +++ b/pkgs/by-name/mo/mole/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, stdenv +{ + lib, + buildGoModule, + fetchFromGitHub, + stdenv, }: buildGoModule rec { diff --git a/pkgs/by-name/mo/molly-brown/package.nix b/pkgs/by-name/mo/molly-brown/package.nix index f5529f0389967d..642d873f9c15a6 100644 --- a/pkgs/by-name/mo/molly-brown/package.nix +++ b/pkgs/by-name/mo/molly-brown/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchgit, nixosTests }: +{ + lib, + buildGoModule, + fetchgit, + nixosTests, +}: buildGoModule rec { pname = "molly-brown"; @@ -12,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-czfHnXS9tf5vQQNXhWH7DStmhsorSc4Di/yZuv4LHRk="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests.basic = nixosTests.molly-brown; diff --git a/pkgs/by-name/mo/molly-guard/package.nix b/pkgs/by-name/mo/molly-guard/package.nix index a444f5231788c6..e7feab9566e655 100644 --- a/pkgs/by-name/mo/molly-guard/package.nix +++ b/pkgs/by-name/mo/molly-guard/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, dpkg, busybox, systemd }: +{ + lib, + stdenv, + fetchurl, + dpkg, + busybox, + systemd, +}: stdenv.mkDerivation rec { pname = "molly-guard"; @@ -26,10 +33,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Attempts to prevent you from accidentally shutting down or rebooting machines"; - homepage = "https://salsa.debian.org/debian/molly-guard"; - license = licenses.artistic2; - platforms = platforms.linux; + homepage = "https://salsa.debian.org/debian/molly-guard"; + license = licenses.artistic2; + platforms = platforms.linux; maintainers = with maintainers; [ DerTim1 ]; - priority = -10; + priority = -10; }; } diff --git a/pkgs/by-name/mo/mollysocket/package.nix b/pkgs/by-name/mo/mollysocket/package.nix index 992d3bdfd93d6a..212999ae9abd0a 100644 --- a/pkgs/by-name/mo/mollysocket/package.nix +++ b/pkgs/by-name/mo/mollysocket/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, sqlite -, stdenv -, darwin -, nixosTests +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + sqlite, + stdenv, + darwin, + nixosTests, }: rustPlatform.buildRustPackage rec { @@ -26,12 +27,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - sqlite - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + openssl + sqlite + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; checkFlags = [ # tests interact with Signal servers diff --git a/pkgs/by-name/mo/molot-lite/package.nix b/pkgs/by-name/mo/molot-lite/package.nix index da1e3702bacc81..20688d604de893 100644 --- a/pkgs/by-name/mo/molot-lite/package.nix +++ b/pkgs/by-name/mo/molot-lite/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, lv2, cairo, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + lv2, + cairo, + pkg-config, +}: stdenv.mkDerivation rec { @@ -13,7 +20,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ lv2 cairo ]; + buildInputs = [ + lv2 + cairo + ]; makeFlags = [ "INSTALL_DIR=$out/lib/lv2" ]; diff --git a/pkgs/by-name/mo/molotov/package.nix b/pkgs/by-name/mo/molotov/package.nix index 58e66c8f77ae80..2ab6c0769b8e9e 100644 --- a/pkgs/by-name/mo/molotov/package.nix +++ b/pkgs/by-name/mo/molotov/package.nix @@ -1,4 +1,8 @@ -{ appimageTools, lib, fetchurl }: +{ + appimageTools, + lib, + fetchurl, +}: let pname = "molotov"; @@ -23,7 +27,10 @@ appimageTools.wrapType2 { description = "French TV service"; homepage = "https://www.molotov.tv/"; license = with licenses; [ unfree ]; - maintainers = with maintainers; [ apeyroux freezeboy ]; + maintainers = with maintainers; [ + apeyroux + freezeboy + ]; platforms = [ "x86_64-linux" ]; mainProgram = "molotov"; }; diff --git a/pkgs/by-name/mo/moltengamepad/package.nix b/pkgs/by-name/mo/moltengamepad/package.nix index 65259d73f2c734..e71f746085b315 100644 --- a/pkgs/by-name/mo/moltengamepad/package.nix +++ b/pkgs/by-name/mo/moltengamepad/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, udev }: +{ + lib, + stdenv, + fetchFromGitHub, + udev, +}: stdenv.mkDerivation { pname = "moltengamepad"; diff --git a/pkgs/by-name/mo/mommy/package.nix b/pkgs/by-name/mo/mommy/package.nix index 94eef31397547d..c38de622df239b 100644 --- a/pkgs/by-name/mo/mommy/package.nix +++ b/pkgs/by-name/mo/mommy/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, writeText -, shellspec +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + writeText, + shellspec, # usage: # pkgs.mommy.override { # mommySettings.sweetie = "catgirl"; @@ -11,13 +12,13 @@ # # $ mommy # who's my good catgirl~ -, mommySettings ? null + mommySettings ? null, }: let - variables = lib.mapAttrs' - (name: value: lib.nameValuePair "MOMMY_${lib.toUpper name}" value) - mommySettings; + variables = lib.mapAttrs' ( + name: value: lib.nameValuePair "MOMMY_${lib.toUpper name}" value + ) mommySettings; configFile = writeText "mommy-config" (lib.toShellVars variables); in stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mo/mona-sans/package.nix b/pkgs/by-name/mo/mona-sans/package.nix index c8be0b40a041fa..bc41d2d58f284e 100644 --- a/pkgs/by-name/mo/mona-sans/package.nix +++ b/pkgs/by-name/mo/mona-sans/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/mo/monaspace/package.nix b/pkgs/by-name/mo/monaspace/package.nix index bf360c0086bae1..6a5e4757defe4e 100644 --- a/pkgs/by-name/mo/monaspace/package.nix +++ b/pkgs/by-name/mo/monaspace/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchzip +{ + lib, + stdenvNoCC, + fetchzip, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -13,7 +14,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { hash = "sha256-o5s4XBuwqA4sJ5KhEn5oYttBj4ojekr/LO6Ww9oQRGw="; }; - outputs = [ "out" "woff" ]; + outputs = [ + "out" + "woff" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/mo/mongoaudit/package.nix b/pkgs/by-name/mo/mongoaudit/package.nix index 2f980be5163b01..931e6f5d1ea741 100644 --- a/pkgs/by-name/mo/mongoaudit/package.nix +++ b/pkgs/by-name/mo/mongoaudit/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/mo/mongodb-tools/package.nix b/pkgs/by-name/mo/mongodb-tools/package.nix index 2a56d72480f528..f45fbaf5569511 100644 --- a/pkgs/by-name/mo/mongodb-tools/package.nix +++ b/pkgs/by-name/mo/mongodb-tools/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, openssl, pkg-config, libpcap }: +{ + lib, + buildGoModule, + fetchFromGitHub, + openssl, + pkg-config, + libpcap, +}: buildGoModule rec { pname = "mongo-tools"; @@ -14,7 +21,10 @@ buildGoModule rec { vendorHash = null; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl libpcap ]; + buildInputs = [ + openssl + libpcap + ]; # Mongodb incorrectly names all of their binaries main # Let's work around this with our own installer @@ -29,7 +39,8 @@ buildGoModule rec { "mongorestore" "mongostat" "mongotop" - ]; in + ]; + in '' # move vendored codes so nixpkgs go builder could find it runHook preBuild diff --git a/pkgs/by-name/mo/mongoose/package.nix b/pkgs/by-name/mo/mongoose/package.nix index f1e851ef444d06..7e1068164b56cb 100644 --- a/pkgs/by-name/mo/mongoose/package.nix +++ b/pkgs/by-name/mo/mongoose/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, blas -, llvmPackages +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + blas, + llvmPackages, }: let @@ -13,7 +14,11 @@ stdenv.mkDerivation { pname = "mongoose"; version = "3.3.3"; - outputs = [ "bin" "out" "dev" ]; + outputs = [ + "bin" + "out" + "dev" + ]; src = fetchFromGitHub { owner = "DrTimothyAldenDavis"; @@ -26,11 +31,13 @@ stdenv.mkDerivation { cmake ]; - buildInputs = [ - blas - ] ++ lib.optionals stdenv.cc.isClang [ - llvmPackages.openmp - ]; + buildInputs = + [ + blas + ] + ++ lib.optionals stdenv.cc.isClang [ + llvmPackages.openmp + ]; dontUseCmakeConfigure = true; diff --git a/pkgs/by-name/mo/mongosh/package.nix b/pkgs/by-name/mo/mongosh/package.nix index 8221c89c719741..52248dc8e86e17 100644 --- a/pkgs/by-name/mo/mongosh/package.nix +++ b/pkgs/by-name/mo/mongosh/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildNpmPackage -, fetchurl -, testers -, mongosh +{ + lib, + buildNpmPackage, + fetchurl, + testers, + mongosh, }: let diff --git a/pkgs/by-name/mo/monit/package.nix b/pkgs/by-name/mo/monit/package.nix index 9838eb7c8b2d5b..a2a41ef70548bd 100644 --- a/pkgs/by-name/mo/monit/package.nix +++ b/pkgs/by-name/mo/monit/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, darwin -, bison -, flex -, zlib -, libxcrypt -, usePAM ? stdenv.hostPlatform.isLinux -, pam -, useSSL ? true -, openssl +{ + lib, + stdenv, + fetchurl, + darwin, + bison, + flex, + zlib, + libxcrypt, + usePAM ? stdenv.hostPlatform.isLinux, + pam, + useSSL ? true, + openssl, }: stdenv.mkDerivation rec { @@ -21,34 +22,54 @@ stdenv.mkDerivation rec { sha256 = "sha256-KRyj2JjptCW20MF2hyj+zWwc9MJox52xX9omKFrVuDI="; }; - nativeBuildInputs = [ bison flex ] ++ - lib.optionals stdenv.hostPlatform.isDarwin [ + nativeBuildInputs = + [ + bison + flex + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.DiskArbitration darwin.apple_sdk.frameworks.System ]; - buildInputs = [ zlib.dev libxcrypt ] ++ - lib.optionals useSSL [ openssl ] ++ - lib.optionals usePAM [ pam ]; + buildInputs = + [ + zlib.dev + libxcrypt + ] + ++ lib.optionals useSSL [ openssl ] + ++ lib.optionals usePAM [ pam ]; - configureFlags = [ - (lib.withFeature usePAM "pam") - ] ++ (if useSSL then [ - "--with-ssl-incl-dir=${openssl.dev}/include" - "--with-ssl-lib-dir=${lib.getLib openssl}/lib" - ] else [ - "--without-ssl" - ]) ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - # will need to check both these are true for musl - "libmonit_cv_setjmp_available=yes" - "libmonit_cv_vsnprintf_c99_conformant=yes" - ]; + configureFlags = + [ + (lib.withFeature usePAM "pam") + ] + ++ ( + if useSSL then + [ + "--with-ssl-incl-dir=${openssl.dev}/include" + "--with-ssl-lib-dir=${lib.getLib openssl}/lib" + ] + else + [ + "--without-ssl" + ] + ) + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + # will need to check both these are true for musl + "libmonit_cv_setjmp_available=yes" + "libmonit_cv_vsnprintf_c99_conformant=yes" + ]; meta = { homepage = "https://mmonit.com/monit/"; description = "Monitoring system"; license = lib.licenses.agpl3Plus; - maintainers = with lib.maintainers; [ raskin wmertens ryantm ]; + maintainers = with lib.maintainers; [ + raskin + wmertens + ryantm + ]; platforms = lib.platforms.linux ++ lib.platforms.darwin; mainProgram = "monit"; }; diff --git a/pkgs/by-name/mo/monitorcontrol/package.nix b/pkgs/by-name/mo/monitorcontrol/package.nix index db112415fda85d..92932d8e059acb 100644 --- a/pkgs/by-name/mo/monitorcontrol/package.nix +++ b/pkgs/by-name/mo/monitorcontrol/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, stdenv, _7zz }: +{ + lib, + fetchurl, + stdenv, + _7zz, +}: # This cannot be built from source due to the problematic nature of XCode - so # this is what it's like when doves cry? @@ -8,8 +13,7 @@ stdenv.mkDerivation rec { version = "4.2.0"; src = fetchurl { - url = - "https://github.com/MonitorControl/${pname}/releases/download/v${version}/MonitorControl.${version}.dmg"; + url = "https://github.com/MonitorControl/${pname}/releases/download/v${version}/MonitorControl.${version}.dmg"; sha256 = "Q96uK6wVe1D2uLvWL+pFR6LcmrU7cgmr2Y5tPvvTDgI="; }; @@ -28,7 +32,10 @@ stdenv.mkDerivation rec { longDescription = "Controls your external display brightness and volume and shows native OSD. Use menulet sliders or the keyboard, including native Apple keys!"; homepage = "https://github.com/MonitorControl/MonitorControl#readme"; license = licenses.mit; - maintainers = with maintainers; [ cbleslie cottand ]; + maintainers = with maintainers; [ + cbleslie + cottand + ]; platforms = platforms.darwin; }; } diff --git a/pkgs/by-name/mo/monitoring-plugins/package.nix b/pkgs/by-name/mo/monitoring-plugins/package.nix index 0993dceb935210..95abd51614f7a4 100644 --- a/pkgs/by-name/mo/monitoring-plugins/package.nix +++ b/pkgs/by-name/mo/monitoring-plugins/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, runCommand -, coreutils -, gnugrep -, gnused -, lm_sensors -, net-snmp -, openssh -, openssl -, perl -, dnsutils -, libdbi -, libmysqlclient -, uriparser -, zlib -, openldap -, procps -, runtimeShell -, unixtools +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + runCommand, + coreutils, + gnugrep, + gnused, + lm_sensors, + net-snmp, + openssh, + openssl, + perl, + dnsutils, + libdbi, + libmysqlclient, + uriparser, + zlib, + openldap, + procps, + runtimeShell, + unixtools, }: let @@ -90,7 +91,10 @@ stdenv.mkDerivation rec { zlib ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; enableParallelBuilding = true; @@ -98,7 +102,10 @@ stdenv.mkDerivation rec { description = "Official monitoring plugins for Nagios/Icinga/Sensu and others"; homepage = "https://www.monitoring-plugins.org"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ thoughtpolice relrod ]; + maintainers = with maintainers; [ + thoughtpolice + relrod + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/mo/monkeysAudio/package.nix b/pkgs/by-name/mo/monkeysAudio/package.nix index 0bda723ba18c95..642a20075f3e80 100644 --- a/pkgs/by-name/mo/monkeysAudio/package.nix +++ b/pkgs/by-name/mo/monkeysAudio/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchzip -, cmake +{ + lib, + stdenv, + fetchzip, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -9,8 +10,7 @@ stdenv.mkDerivation (finalAttrs: { pname = "monkeys-audio"; src = fetchzip { - url = "https://monkeysaudio.com/files/MAC_${ - builtins.concatStringsSep "" (lib.strings.splitString "." finalAttrs.version)}_SDK.zip"; + url = "https://monkeysaudio.com/files/MAC_${builtins.concatStringsSep "" (lib.strings.splitString "." finalAttrs.version)}_SDK.zip"; hash = "sha256-QPd3YlQ2IYAqIIau3RVb2FcdE4obQjg5bZi6CUsDyHU="; stripRoot = false; }; diff --git a/pkgs/by-name/mo/monkeysphere/package.nix b/pkgs/by-name/mo/monkeysphere/package.nix index bc267a9a7703d1..249c4b9e26a780 100644 --- a/pkgs/by-name/mo/monkeysphere/package.nix +++ b/pkgs/by-name/mo/monkeysphere/package.nix @@ -1,8 +1,23 @@ -{ lib, stdenv, fetchurl, makeWrapper -, perl, libassuan, libgcrypt -, perlPackages, lockfileProgs, gnupg, coreutils -# For the tests: -, openssh, which, socat, cpio, hexdump, procps, openssl +{ + lib, + stdenv, + fetchurl, + makeWrapper, + perl, + libassuan, + libgcrypt, + perlPackages, + lockfileProgs, + gnupg, + coreutils, + # For the tests: + openssh, + which, + socat, + cpio, + hexdump, + procps, + openssl, }: let @@ -12,7 +27,8 @@ let opensshUnsafe = openssh.overrideAttrs (oldAttrs: { patches = oldAttrs.patches ++ [ ./openssh-nixos-sandbox.patch ]; }); -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "monkeysphere"; version = "0.44"; @@ -31,10 +47,28 @@ in stdenv.mkDerivation rec { ''; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ perl libassuan libgcrypt ] - ++ lib.optional doCheck - ([ gnupg opensshUnsafe which socat cpio hexdump procps lockfileProgs ] ++ - (with perlPackages; [ CryptOpenSSLRSA CryptOpenSSLBignum ])); + buildInputs = + [ + perl + libassuan + libgcrypt + ] + ++ lib.optional doCheck ( + [ + gnupg + opensshUnsafe + which + socat + cpio + hexdump + procps + lockfileProgs + ] + ++ (with perlPackages; [ + CryptOpenSSLRSA + CryptOpenSSLBignum + ]) + ); makeFlags = [ "PREFIX=/" @@ -58,31 +92,36 @@ in stdenv.mkDerivation rec { ''; postFixup = - let wrapperArgs = runtimeDeps: - "--prefix PERL5LIB : " - + (with perlPackages; makePerlPath [ # Optional (only required for keytrans) - CryptOpenSSLRSA - CryptOpenSSLBignum - ]) - + lib.optionalString - (builtins.length runtimeDeps > 0) - " --prefix PATH : ${lib.makeBinPath runtimeDeps}"; - wrapMonkeysphere = runtimeDeps: program: - "wrapProgram $out/bin/${program} ${wrapperArgs runtimeDeps}\n"; - wrapPrograms = runtimeDeps: programs: lib.concatMapStrings - (wrapMonkeysphere runtimeDeps) - programs; - in wrapPrograms [ gnupg ] [ "monkeysphere-authentication" "monkeysphere-host" ] - + wrapPrograms [ gnupg lockfileProgs ] [ "monkeysphere" ] - + '' - # These 4 programs depend on the program name ($0): - for program in openpgp2pem openpgp2spki openpgp2ssh pem2openpgp; do - rm $out/bin/$program - ln -sf keytrans $out/share/monkeysphere/$program - makeWrapper $out/share/monkeysphere/$program $out/bin/$program \ - ${wrapperArgs [ ]} - done - ''; + let + wrapperArgs = + runtimeDeps: + "--prefix PERL5LIB : " + + ( + with perlPackages; + makePerlPath [ + # Optional (only required for keytrans) + CryptOpenSSLRSA + CryptOpenSSLBignum + ] + ) + + lib.optionalString ( + builtins.length runtimeDeps > 0 + ) " --prefix PATH : ${lib.makeBinPath runtimeDeps}"; + wrapMonkeysphere = + runtimeDeps: program: "wrapProgram $out/bin/${program} ${wrapperArgs runtimeDeps}\n"; + wrapPrograms = runtimeDeps: programs: lib.concatMapStrings (wrapMonkeysphere runtimeDeps) programs; + in + wrapPrograms [ gnupg ] [ "monkeysphere-authentication" "monkeysphere-host" ] + + wrapPrograms [ gnupg lockfileProgs ] [ "monkeysphere" ] + + '' + # These 4 programs depend on the program name ($0): + for program in openpgp2pem openpgp2spki openpgp2ssh pem2openpgp; do + rm $out/bin/$program + ln -sf keytrans $out/share/monkeysphere/$program + makeWrapper $out/share/monkeysphere/$program $out/bin/$program \ + ${wrapperArgs [ ]} + done + ''; meta = with lib; { homepage = "http://web.monkeysphere.info/"; diff --git a/pkgs/by-name/mo/mono-addins/package.nix b/pkgs/by-name/mo/mono-addins/package.nix index 23e613be08878a..e20614c683eccb 100644 --- a/pkgs/by-name/mo/mono-addins/package.nix +++ b/pkgs/by-name/mo/mono-addins/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, mono4, gtk-sharp-2_0 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + mono4, + gtk-sharp-2_0, +}: stdenv.mkDerivation rec { pname = "mono-addins"; @@ -12,10 +20,16 @@ stdenv.mkDerivation rec { sha256 = "018g3bd8afjc39h22h2j5r6ldsdn08ynx7wg889gdvnxg3hrxgl2"; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; # Use msbuild when https://github.com/NixOS/nixpkgs/pull/43680 is merged - buildInputs = [ mono4 gtk-sharp-2_0 ]; + buildInputs = [ + mono4 + gtk-sharp-2_0 + ]; dontStrip = true; diff --git a/pkgs/by-name/mo/monoDLLFixer/package.nix b/pkgs/by-name/mo/monoDLLFixer/package.nix index 09a986015eeda0..61df37e1fda87e 100644 --- a/pkgs/by-name/mo/monoDLLFixer/package.nix +++ b/pkgs/by-name/mo/monoDLLFixer/package.nix @@ -1,4 +1,4 @@ -{stdenv, perl}: +{ stdenv, perl }: stdenv.mkDerivation { name = "mono-dll-fixer"; dllFixer = ./dll-fixer.pl; diff --git a/pkgs/by-name/mo/monocraft/package.nix b/pkgs/by-name/mo/monocraft/package.nix index fe3778e6b0531a..85ff3d02f53b52 100644 --- a/pkgs/by-name/mo/monocraft/package.nix +++ b/pkgs/by-name/mo/monocraft/package.nix @@ -1,11 +1,17 @@ -{ stdenvNoCC, lib, fetchurl }: +{ + stdenvNoCC, + lib, + fetchurl, +}: let version = "4.0"; - relArtifact = name: hash: fetchurl { - inherit name hash; - url = "https://github.com/IdreesInc/Monocraft/releases/download/v${version}/${name}"; - }; + relArtifact = + name: hash: + fetchurl { + inherit name hash; + url = "https://github.com/IdreesInc/Monocraft/releases/download/v${version}/${name}"; + }; in stdenvNoCC.mkDerivation { pname = "monocraft"; diff --git a/pkgs/by-name/mo/monocypher/package.nix b/pkgs/by-name/mo/monocypher/package.nix index f5853385ba9136..f7e4eb9ff568c4 100644 --- a/pkgs/by-name/mo/monocypher/package.nix +++ b/pkgs/by-name/mo/monocypher/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "monocypher"; @@ -16,7 +20,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Boring crypto that simply works"; homepage = "https://monocypher.org"; - license = with licenses; [ bsd2 cc0 ]; + license = with licenses; [ + bsd2 + cc0 + ]; platforms = platforms.linux; maintainers = with maintainers; [ sikmir ]; }; diff --git a/pkgs/by-name/mo/monoid/package.nix b/pkgs/by-name/mo/monoid/package.nix index f6875a482d08b8..7882007dae03cb 100644 --- a/pkgs/by-name/mo/monoid/package.nix +++ b/pkgs/by-name/mo/monoid/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + python3, +}: stdenv.mkDerivation { pname = "monoid"; @@ -12,9 +18,11 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ - (python3.withPackages (pp: with pp; [ - fontforge - ])) + (python3.withPackages ( + pp: with pp; [ + fontforge + ] + )) ]; patches = [ @@ -43,9 +51,11 @@ stdenv.mkDerivation { meta = with lib; { homepage = "http://larsenwork.com/monoid"; description = "Customisable coding font with alternates, ligatures and contextual positioning"; - license = [ licenses.ofl licenses.mit ]; + license = [ + licenses.ofl + licenses.mit + ]; platforms = platforms.all; maintainers = [ maintainers.romildo ]; }; } - diff --git a/pkgs/by-name/mo/mononoki/package.nix b/pkgs/by-name/mo/mononoki/package.nix index 5c4d3c79adcbc0..5b8b33144e2f36 100644 --- a/pkgs/by-name/mo/mononoki/package.nix +++ b/pkgs/by-name/mo/mononoki/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "mononoki"; diff --git a/pkgs/by-name/mo/monophony/package.nix b/pkgs/by-name/mo/monophony/package.nix index 76f81c3b2846c1..2b13dd852402ab 100644 --- a/pkgs/by-name/mo/monophony/package.nix +++ b/pkgs/by-name/mo/monophony/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitLab -, python3Packages -, wrapGAppsHook4 -, gst_all_1 -, gobject-introspection -, yt-dlp -, libadwaita -, glib-networking -, nix-update-script +{ + lib, + fetchFromGitLab, + python3Packages, + wrapGAppsHook4, + gst_all_1, + gobject-introspection, + yt-dlp, + libadwaita, + glib-networking, + nix-update-script, }: python3Packages.buildPythonApplication rec { pname = "monophony"; @@ -39,15 +40,17 @@ python3Packages.buildPythonApplication rec { wrapGAppsHook4 ]; - buildInputs = [ - libadwaita - # needed for gstreamer https - glib-networking - ] ++ (with gst_all_1; [ - gst-plugins-base - gst-plugins-good - gstreamer - ]); + buildInputs = + [ + libadwaita + # needed for gstreamer https + glib-networking + ] + ++ (with gst_all_1; [ + gst-plugins-base + gst-plugins-good + gstreamer + ]); # Makefile only contains `install` dontBuild = true; @@ -58,7 +61,7 @@ python3Packages.buildPythonApplication rec { preFixup = '' makeWrapperArgs+=( - --prefix PATH : "${lib.makeBinPath [yt-dlp]}" + --prefix PATH : "${lib.makeBinPath [ yt-dlp ]}" "''${gappsWrapperArgs[@]}" ) ''; diff --git a/pkgs/by-name/mo/monosat/package.nix b/pkgs/by-name/mo/monosat/package.nix index 1bd2d29d450591..9fa647f2c2bd53 100644 --- a/pkgs/by-name/mo/monosat/package.nix +++ b/pkgs/by-name/mo/monosat/package.nix @@ -1,20 +1,30 @@ -{ lib, stdenv, fetchpatch, fetchFromGitHub, cmake, zlib, gmp, jdk8, +{ + lib, + stdenv, + fetchpatch, + fetchFromGitHub, + cmake, + zlib, + gmp, + jdk8, # The JDK we use on Darwin currently makes extensive use of rpaths which are # annoying and break the python library, so let's not bother for now - includeJava ? !stdenv.hostPlatform.isDarwin, includeGplCode ? true }: + includeJava ? !stdenv.hostPlatform.isDarwin, + includeGplCode ? true, +}: let boolToCmake = x: if x then "ON" else "OFF"; - rev = "1.8.0"; + rev = "1.8.0"; sha256 = "0q3a8x3iih25xkp2bm842sm2hxlb8hxlls4qmvj7vzwrh4lvsl7b"; - pname = "monosat"; + pname = "monosat"; version = rev; src = fetchFromGitHub { owner = "sambayless"; - repo = pname; + repo = pname; inherit rev sha256; }; @@ -39,7 +49,11 @@ let inherit src patches; postPatch = commonPostPatch; nativeBuildInputs = [ cmake ]; - buildInputs = [ zlib gmp jdk8 ]; + buildInputs = [ + zlib + gmp + jdk8 + ]; cmakeFlags = [ "-DBUILD_STATIC=OFF" @@ -60,39 +74,57 @@ let meta = with lib; { description = "SMT solver for Monotonic Theories"; mainProgram = "monosat"; - platforms = platforms.unix; - license = if includeGplCode then licenses.gpl2 else licenses.mit; - homepage = "https://github.com/sambayless/monosat"; + platforms = platforms.unix; + license = if includeGplCode then licenses.gpl2 else licenses.mit; + homepage = "https://github.com/sambayless/monosat"; maintainers = [ maintainers.acairncross ]; }; }; - python = { buildPythonPackage, cython, pytestCheckHook }: buildPythonPackage { - inherit pname version src patches; - - propagatedBuildInputs = [ core cython ]; - - # This tells setup.py to use cython, which should produce faster bindings - MONOSAT_CYTHON = true; - - # After patching src, move to where the actually relevant source is. This could just be made - # the sourceRoot if it weren't for the patch. - postPatch = commonPostPatch + '' - cd src/monosat/api/python - '' + - # The relative paths here don't make sense for our Nix build - # TODO: do we want to just reference the core monosat library rather than copying the - # shared lib? The current setup.py copies the .dylib/.so... - '' - substituteInPlace setup.py \ - --replace 'library_dir = "../../../../"' 'library_dir = "${core}/lib/"' - ''; - - nativeCheckInputs = [ pytestCheckHook ]; - - disabledTests = [ - "test_assertAtMostOne" - "test_assertEqual" - ]; - }; -in core + python = + { + buildPythonPackage, + cython, + pytestCheckHook, + }: + buildPythonPackage { + inherit + pname + version + src + patches + ; + + propagatedBuildInputs = [ + core + cython + ]; + + # This tells setup.py to use cython, which should produce faster bindings + MONOSAT_CYTHON = true; + + # After patching src, move to where the actually relevant source is. This could just be made + # the sourceRoot if it weren't for the patch. + postPatch = + commonPostPatch + + '' + cd src/monosat/api/python + '' + + + # The relative paths here don't make sense for our Nix build + # TODO: do we want to just reference the core monosat library rather than copying the + # shared lib? The current setup.py copies the .dylib/.so... + '' + substituteInPlace setup.py \ + --replace 'library_dir = "../../../../"' 'library_dir = "${core}/lib/"' + ''; + + nativeCheckInputs = [ pytestCheckHook ]; + + disabledTests = [ + "test_assertAtMostOne" + "test_assertEqual" + ]; + }; +in +core diff --git a/pkgs/by-name/mo/mons/package.nix b/pkgs/by-name/mo/mons/package.nix index d386c901e7c079..8be9b38aa2d2ab 100644 --- a/pkgs/by-name/mo/mons/package.nix +++ b/pkgs/by-name/mo/mons/package.nix @@ -1,13 +1,14 @@ -{ lib -, bash -, coreutils -, fetchFromGitHub -, gawk -, gnugrep -, gnused -, help2man -, resholve -, xrandr +{ + lib, + bash, + coreutils, + fetchFromGitHub, + gawk, + gnugrep, + gnused, + help2man, + resholve, + xrandr, }: resholve.mkDerivation rec { @@ -42,7 +43,10 @@ resholve.mkDerivation rec { solutions = { mons = { - scripts = [ "bin/mons" "lib/libshlist/liblist.sh" ]; + scripts = [ + "bin/mons" + "lib/libshlist/liblist.sh" + ]; interpreter = "${bash}/bin/sh"; inputs = [ bash @@ -58,8 +62,8 @@ resholve.mkDerivation rec { }; keep = { /* - has a whole slate of *flag variables that it sets to either - the true or false builtin and then executes... + has a whole slate of *flag variables that it sets to either + the true or false builtin and then executes... */ "$aFlag" = true; "$dFlag" = true; diff --git a/pkgs/by-name/mo/monsoon/package.nix b/pkgs/by-name/mo/monsoon/package.nix index 78bf95ac6c8bb6..a28a4902361538 100644 --- a/pkgs/by-name/mo/monsoon/package.nix +++ b/pkgs/by-name/mo/monsoon/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/mo/montserrat/package.nix b/pkgs/by-name/mo/montserrat/package.nix index 60ee2ee97f6753..5251367f519327 100644 --- a/pkgs/by-name/mo/montserrat/package.nix +++ b/pkgs/by-name/mo/montserrat/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "montserrat"; @@ -29,6 +33,9 @@ stdenvNoCC.mkDerivation rec { homepage = "https://www.fontspace.com/julieta-ulanovsky/montserrat"; license = licenses.ofl; platforms = platforms.all; - maintainers = with maintainers; [ scolobb jk ]; + maintainers = with maintainers; [ + scolobb + jk + ]; }; } diff --git a/pkgs/by-name/mo/mooSpace/package.nix b/pkgs/by-name/mo/mooSpace/package.nix index 6d67d83f9875ce..079c034d925299 100644 --- a/pkgs/by-name/mo/mooSpace/package.nix +++ b/pkgs/by-name/mo/mooSpace/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, faust2jaqt, faust2lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + faust2jaqt, + faust2lv2, +}: stdenv.mkDerivation rec { pname = "mooSpace"; version = "unstable-2020-06-10"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "10vsbddf6d7i06040850v8xkmqh3bqawczs29kfgakair809wqxl"; }; - buildInputs = [ faust2jaqt faust2lv2 ]; + buildInputs = [ + faust2jaqt + faust2lv2 + ]; patchPhase = "mv ${pname}_faust.dsp ${pname}.dsp"; diff --git a/pkgs/by-name/mo/moon-buggy/package.nix b/pkgs/by-name/mo/moon-buggy/package.nix index 0da9248b223766..96642b26bc1273 100644 --- a/pkgs/by-name/mo/moon-buggy/package.nix +++ b/pkgs/by-name/mo/moon-buggy/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, ncurses +{ + lib, + stdenv, + fetchurl, + ncurses, }: stdenv.mkDerivation rec { pname = "moon-buggy"; diff --git a/pkgs/by-name/mo/moon-phases/package.nix b/pkgs/by-name/mo/moon-phases/package.nix index e1c41556827c4f..77cd0a73af7c34 100644 --- a/pkgs/by-name/mo/moon-phases/package.nix +++ b/pkgs/by-name/mo/moon-phases/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchCrate, rustPlatform }: +{ + lib, + fetchCrate, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "moon-phases"; diff --git a/pkgs/by-name/mo/moonlight-embedded/package.nix b/pkgs/by-name/mo/moonlight-embedded/package.nix index e00be02e6f0676..20833864409681 100644 --- a/pkgs/by-name/mo/moonlight-embedded/package.nix +++ b/pkgs/by-name/mo/moonlight-embedded/package.nix @@ -1,7 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, cmake, perl -, alsa-lib, libevdev, libopus, udev, SDL2 -, ffmpeg, pkg-config, xorg, libvdpau, libpulseaudio, libcec -, curl, expat, avahi, libuuid, libva +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + perl, + alsa-lib, + libevdev, + libopus, + udev, + SDL2, + ffmpeg, + pkg-config, + xorg, + libvdpau, + libpulseaudio, + libcec, + curl, + expat, + avahi, + libuuid, + libva, }: stdenv.mkDerivation rec { @@ -16,13 +34,33 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - nativeBuildInputs = [ cmake perl pkg-config ]; + nativeBuildInputs = [ + cmake + perl + pkg-config + ]; buildInputs = [ - alsa-lib libevdev libopus udev SDL2 - ffmpeg xorg.libxcb libvdpau libpulseaudio libcec - xorg.libpthreadstubs curl expat avahi libuuid libva + alsa-lib + libevdev + libopus + udev + SDL2 + ffmpeg + xorg.libxcb + libvdpau + libpulseaudio + libcec + xorg.libpthreadstubs + curl + expat + avahi + libuuid + libva ]; meta = with lib; { diff --git a/pkgs/by-name/mo/moonraker/package.nix b/pkgs/by-name/mo/moonraker/package.nix index 054ba5eb452e67..7e4f3bd45acb79 100644 --- a/pkgs/by-name/mo/moonraker/package.nix +++ b/pkgs/by-name/mo/moonraker/package.nix @@ -1,8 +1,17 @@ -{ lib, stdenvNoCC, fetchFromGitHub, python3, makeWrapper, unstableGitUpdater, nixosTests, useGpiod ? false }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + python3, + makeWrapper, + unstableGitUpdater, + nixosTests, + useGpiod ? false, +}: let - pythonEnv = python3.withPackages (packages: - with packages; [ + pythonEnv = python3.withPackages ( + packages: with packages; [ tornado pyserial-asyncio pillow @@ -23,7 +32,8 @@ let importlib-metadata ] ); -in stdenvNoCC.mkDerivation rec { +in +stdenvNoCC.mkDerivation rec { pname = "moonraker"; version = "0.9.3-unstable-2024-11-17"; diff --git a/pkgs/by-name/mo/mop/package.nix b/pkgs/by-name/mo/mop/package.nix index 301b5302b022a8..245abeac0f5dba 100644 --- a/pkgs/by-name/mo/mop/package.nix +++ b/pkgs/by-name/mo/mop/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "mop"; diff --git a/pkgs/by-name/mo/mopac/package.nix b/pkgs/by-name/mo/mopac/package.nix index d0cb1e43ff457d..903b178869d6e4 100644 --- a/pkgs/by-name/mo/mopac/package.nix +++ b/pkgs/by-name/mo/mopac/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, gfortran -, fetchFromGitHub -, cmake -, blas -, lapack -, python3Packages +{ + stdenv, + lib, + gfortran, + fetchFromGitHub, + cmake, + blas, + lapack, + python3Packages, }: assert blas.isILP64 == lapack.isILP64; @@ -21,11 +22,20 @@ stdenv.mkDerivation rec { hash = "sha256-y9/b+ro9CgDo0ld9q+3xaCFE9J5ssZp6W9ct6WQgD/o="; }; - nativeBuildInputs = [ gfortran cmake ]; + nativeBuildInputs = [ + gfortran + cmake + ]; - buildInputs = [ blas lapack ]; + buildInputs = [ + blas + lapack + ]; - checkInputs = with python3Packages; [ python numpy ]; + checkInputs = with python3Packages; [ + python + numpy + ]; doCheck = true; @@ -38,6 +48,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/openmopac/mopac"; license = licenses.lgpl3Plus; platforms = platforms.linux; - maintainers = with maintainers; [ sheepforce markuskowa ]; + maintainers = with maintainers; [ + sheepforce + markuskowa + ]; }; } diff --git a/pkgs/by-name/mo/moproxy/package.nix b/pkgs/by-name/mo/moproxy/package.nix index 7c320cad4889d5..354f230ba6b2b4 100644 --- a/pkgs/by-name/mo/moproxy/package.nix +++ b/pkgs/by-name/mo/moproxy/package.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, rustPlatform -, fetchurl -, lib +{ + fetchFromGitHub, + rustPlatform, + fetchurl, + lib, }: -rustPlatform.buildRustPackage rec{ +rustPlatform.buildRustPackage rec { pname = "moproxy"; version = "0.5.1"; @@ -26,7 +27,9 @@ rustPlatform.buildRustPackage rec{ in '' # build script try to download from network - sed -i '15s/.*/let zip_path = PathBuf::from("${lib.escape ["/"] (toString webBundle)}");/' build.rs + sed -i '15s/.*/let zip_path = PathBuf::from("${ + lib.escape [ "/" ] (toString webBundle) + }");/' build.rs ''; meta = with lib; { diff --git a/pkgs/by-name/mo/morph/package.nix b/pkgs/by-name/mo/morph/package.nix index 7dc6d9f8dfa2cf..4e3d9b410c73a5 100644 --- a/pkgs/by-name/mo/morph/package.nix +++ b/pkgs/by-name/mo/morph/package.nix @@ -1,4 +1,10 @@ -{ buildGoModule, fetchFromGitHub, lib, makeWrapper, openssh }: +{ + buildGoModule, + fetchFromGitHub, + lib, + makeWrapper, + openssh, +}: buildGoModule rec { pname = "morph"; @@ -26,13 +32,19 @@ buildGoModule rec { wrapProgram $out/bin/morph --prefix PATH : ${lib.makeBinPath [ openssh ]}; ''; - outputs = [ "out" "lib" ]; + outputs = [ + "out" + "lib" + ]; meta = with lib; { description = "NixOS host manager written in Golang"; license = licenses.mit; homepage = "https://github.com/dbcdk/morph"; - maintainers = with maintainers; [adamt johanot]; + maintainers = with maintainers; [ + adamt + johanot + ]; mainProgram = "morph"; }; } diff --git a/pkgs/by-name/mo/morsel/package.nix b/pkgs/by-name/mo/morsel/package.nix index 416f2e65782f12..b4b02d686d5ba9 100644 --- a/pkgs/by-name/mo/morsel/package.nix +++ b/pkgs/by-name/mo/morsel/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "morsel"; diff --git a/pkgs/by-name/mo/morty/package.nix b/pkgs/by-name/mo/morty/package.nix index 6ee57abc028a9a..9e210f3a78c3f6 100644 --- a/pkgs/by-name/mo/morty/package.nix +++ b/pkgs/by-name/mo/morty/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule { pname = "morty"; @@ -25,7 +30,10 @@ buildGoModule { The main goal of morty is to provide a result proxy for searx, but it can be used as a standalone sanitizer service too. ''; homepage = "https://github.com/asciimoo/morty"; - maintainers = with maintainers; [ leenaars SuperSandro2000 ]; + maintainers = with maintainers; [ + leenaars + SuperSandro2000 + ]; license = licenses.agpl3Only; }; } diff --git a/pkgs/by-name/mo/mos/package.nix b/pkgs/by-name/mo/mos/package.nix index 803148c91be33f..2ed2f51c5eae6b 100644 --- a/pkgs/by-name/mo/mos/package.nix +++ b/pkgs/by-name/mo/mos/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, undmg +{ + lib, + stdenvNoCC, + fetchurl, + undmg, }: stdenvNoCC.mkDerivation (finalAttrs: { pname = "mos"; diff --git a/pkgs/by-name/mo/mosdepth/package.nix b/pkgs/by-name/mo/mosdepth/package.nix index b629f492af33ee..5c226a570d59c8 100644 --- a/pkgs/by-name/mo/mosdepth/package.nix +++ b/pkgs/by-name/mo/mosdepth/package.nix @@ -1,4 +1,10 @@ -{ lib, buildNimPackage, fetchFromGitHub, pcre, testers }: +{ + lib, + buildNimPackage, + fetchFromGitHub, + pcre, + testers, +}: buildNimPackage (finalAttrs: { pname = "mosdepth"; diff --git a/pkgs/by-name/mo/moserial/package.nix b/pkgs/by-name/mo/moserial/package.nix index 0a708681b40954..7fa80d3ce9f4ca 100644 --- a/pkgs/by-name/mo/moserial/package.nix +++ b/pkgs/by-name/mo/moserial/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitLab -, autoreconfHook -, intltool -, itstool -, pkg-config -, vala -, glib -, graphviz -, yelp-tools -, gtk3 -, lrzsz +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + intltool, + itstool, + pkg-config, + vala, + glib, + graphviz, + yelp-tools, + gtk3, + lrzsz, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mo/mosh/package.nix b/pkgs/by-name/mo/mosh/package.nix index 230122a2574bcd..4777920be44d6e 100644 --- a/pkgs/by-name/mo/mosh/package.nix +++ b/pkgs/by-name/mo/mosh/package.nix @@ -1,6 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, zlib, protobuf, ncurses, pkg-config -, makeWrapper, perl, openssl, autoreconfHook, openssh, bash-completion, fetchpatch -, withUtempter ? stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isMusl, libutempter }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + protobuf, + ncurses, + pkg-config, + makeWrapper, + perl, + openssl, + autoreconfHook, + openssh, + bash-completion, + fetchpatch, + withUtempter ? stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isMusl, + libutempter, +}: stdenv.mkDerivation rec { pname = "mosh"; @@ -13,9 +28,21 @@ stdenv.mkDerivation rec { hash = "sha256-tlSsHu7JnXO+sorVuWWubNUNdb9X0/pCaiGG5Y0X/g8="; }; - nativeBuildInputs = [ autoreconfHook pkg-config makeWrapper protobuf perl ]; - buildInputs = [ protobuf ncurses zlib openssl bash-completion perl ] - ++ lib.optional withUtempter libutempter; + nativeBuildInputs = [ + autoreconfHook + pkg-config + makeWrapper + protobuf + perl + ]; + buildInputs = [ + protobuf + ncurses + zlib + openssl + bash-completion + perl + ] ++ lib.optional withUtempter libutempter; strictDeps = true; @@ -40,11 +67,10 @@ stdenv.mkDerivation rec { --subst-var-by mosh-client "$out/bin/mosh-client" ''; - configureFlags = [ "--enable-completion" ] - ++ lib.optional withUtempter "--with-utempter"; + configureFlags = [ "--enable-completion" ] ++ lib.optional withUtempter "--with-utempter"; postInstall = '' - wrapProgram $out/bin/mosh --prefix PERL5LIB : $PERL5LIB + wrapProgram $out/bin/mosh --prefix PERL5LIB : $PERL5LIB ''; meta = with lib; { diff --git a/pkgs/by-name/mo/mosml/package.nix b/pkgs/by-name/mo/mosml/package.nix index 26ce0365a6cd4e..755a002ebff507 100644 --- a/pkgs/by-name/mo/mosml/package.nix +++ b/pkgs/by-name/mo/mosml/package.nix @@ -1,12 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, gmp, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + gmp, + perl, +}: stdenv.mkDerivation rec { pname = "mosml"; version = "2.10.1"; - buildInputs = [ gmp perl ]; + buildInputs = [ + gmp + perl + ]; - makeFlags = [ "PREFIX=$(out)" "CC=${stdenv.cc.targetPrefix}cc" ]; + makeFlags = [ + "PREFIX=$(out)" + "CC=${stdenv.cc.targetPrefix}cc" + ]; src = fetchFromGitHub { owner = "kfl"; diff --git a/pkgs/by-name/mo/mosquitto/package.nix b/pkgs/by-name/mo/mosquitto/package.nix index 99bc3be76f17a5..4792b23d15718f 100644 --- a/pkgs/by-name/mo/mosquitto/package.nix +++ b/pkgs/by-name/mo/mosquitto/package.nix @@ -1,30 +1,33 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, docbook_xsl -, libxslt -, c-ares -, cjson -, libuuid -, libuv -, libwebsockets -, openssl -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, systemd -, uthash -, nixosTests +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + docbook_xsl, + libxslt, + c-ares, + cjson, + libuuid, + libuv, + libwebsockets, + openssl, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + uthash, + nixosTests, }: let # Mosquitto needs external poll enabled in libwebsockets. - libwebsockets' = (libwebsockets.override { - withExternalPoll = true; - }).overrideAttrs (old: { - # Avoid bug in firefox preventing websockets being created over http/2 connections - # https://github.com/eclipse/mosquitto/issues/1211#issuecomment-958137569 - cmakeFlags = old.cmakeFlags ++ [ "-DLWS_WITH_HTTP2=OFF" ]; - }); + libwebsockets' = + (libwebsockets.override { + withExternalPoll = true; + }).overrideAttrs + (old: { + # Avoid bug in firefox preventing websockets being created over http/2 connections + # https://github.com/eclipse/mosquitto/issues/1211#issuecomment-958137569 + cmakeFlags = old.cmakeFlags ++ [ "-DLWS_WITH_HTTP2=OFF" ]; + }); in stdenv.mkDerivation rec { @@ -45,9 +48,17 @@ stdenv.mkDerivation rec { done ''; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; - nativeBuildInputs = [ cmake docbook_xsl libxslt ]; + nativeBuildInputs = [ + cmake + docbook_xsl + libxslt + ]; buildInputs = [ c-ares diff --git a/pkgs/by-name/mo/most/package.nix b/pkgs/by-name/mo/most/package.nix index 91af6a2d02a5fc..f7d31d4a24c6d8 100644 --- a/pkgs/by-name/mo/most/package.nix +++ b/pkgs/by-name/mo/most/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, slang, ncurses }: +{ + lib, + stdenv, + fetchurl, + slang, + ncurses, +}: stdenv.mkDerivation rec { pname = "most"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { hash = "sha256-lFWuuPgm+oOFyFDcIr8PIs+QabPDQj+6S/LG9iJtmQM="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; makeFlags = [ "DOC_DIR=${placeholder "doc"}/share/doc/most" @@ -24,7 +33,10 @@ stdenv.mkDerivation rec { configureFlags = [ "--with-slang=${slang.dev}" ]; - buildInputs = [ slang ncurses ]; + buildInputs = [ + slang + ncurses + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/mo/motif/package.nix b/pkgs/by-name/mo/motif/package.nix index d59c5894836d2a..969cd4ad5a810b 100644 --- a/pkgs/by-name/mo/motif/package.nix +++ b/pkgs/by-name/mo/motif/package.nix @@ -1,9 +1,24 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, libtool -, xbitmaps, libXext, libXft, libXrender, libXmu, libXt -, expat, libjpeg, libpng, libiconv -, flex -, libXp, libXau -, demoSupport ? false +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + libtool, + xbitmaps, + libXext, + libXft, + libXrender, + libXmu, + libXt, + expat, + libjpeg, + libpng, + libiconv, + flex, + libXp, + libXau, + demoSupport ? false, }: # refer to the gentoo package @@ -18,13 +33,27 @@ stdenv.mkDerivation rec { buildInputs = [ libtool - xbitmaps libXext libXft libXrender libXmu libXt - expat libjpeg libpng libiconv + xbitmaps + libXext + libXft + libXrender + libXmu + libXt + expat + libjpeg + libpng + libiconv ]; - nativeBuildInputs = [ pkg-config flex ]; + nativeBuildInputs = [ + pkg-config + flex + ]; - propagatedBuildInputs = [ libXp libXau ]; + propagatedBuildInputs = [ + libXp + libXau + ]; postPatch = lib.optionalString (!demoSupport) '' sed 's/\//' -i Makefile.{am,in} diff --git a/pkgs/by-name/mo/motion/package.nix b/pkgs/by-name/mo/motion/package.nix index 5e02d58977ceb7..627596911c9b18 100644 --- a/pkgs/by-name/mo/motion/package.nix +++ b/pkgs/by-name/mo/motion/package.nix @@ -1,26 +1,44 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config -, ffmpeg, libjpeg, libmicrohttpd }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + ffmpeg, + libjpeg, + libmicrohttpd, +}: stdenv.mkDerivation rec { pname = "motion"; version = "4.7.0"; src = fetchFromGitHub { - owner = "Motion-Project"; - repo = "motion"; - rev = "release-${version}"; + owner = "Motion-Project"; + repo = "motion"; + rev = "release-${version}"; sha256 = "sha256-bGjiO14a7xKRgoeo5JlexXlKggE+agRMmQViBXagmt8="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ ffmpeg libjpeg libmicrohttpd ]; + buildInputs = [ + ffmpeg + libjpeg + libmicrohttpd + ]; meta = with lib; { description = "Monitors the video signal from cameras"; homepage = "https://motion-project.github.io/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ puffnfresh veprbl ]; + maintainers = with maintainers; [ + puffnfresh + veprbl + ]; platforms = platforms.unix; # never built on aarch64-darwin since first introduction in nixpkgs broken = stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64; diff --git a/pkgs/by-name/mo/motrix/package.nix b/pkgs/by-name/mo/motrix/package.nix index 8c26a67352aaab..cbbfd061b08a67 100644 --- a/pkgs/by-name/mo/motrix/package.nix +++ b/pkgs/by-name/mo/motrix/package.nix @@ -1,6 +1,7 @@ -{ lib -, appimageTools -, fetchurl +{ + lib, + appimageTools, + fetchurl, }: let pname = "motrix"; diff --git a/pkgs/by-name/mo/mountain-duck/package.nix b/pkgs/by-name/mo/mountain-duck/package.nix index 8eef2328b0df11..c2ab2ae707ff2d 100644 --- a/pkgs/by-name/mo/mountain-duck/package.nix +++ b/pkgs/by-name/mo/mountain-duck/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, unzip +{ + lib, + stdenvNoCC, + fetchurl, + unzip, }: stdenvNoCC.mkDerivation (finalAttrs: { pname = "mountain-duck"; diff --git a/pkgs/by-name/mo/mountpoint-s3/package.nix b/pkgs/by-name/mo/mountpoint-s3/package.nix index 83144bbee56085..c442f08664bc35 100644 --- a/pkgs/by-name/mo/mountpoint-s3/package.nix +++ b/pkgs/by-name/mo/mountpoint-s3/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, cmake -, fuse3 -, pkg-config +{ + lib, + fetchFromGitHub, + rustPlatform, + cmake, + fuse3, + pkg-config, }: rustPlatform.buildRustPackage rec { @@ -24,7 +25,11 @@ rustPlatform.buildRustPackage rec { # cargo metadata failure: error: none of the selected packages contains these features: libfuse3 auditable = false; - nativeBuildInputs = [ cmake pkg-config rustPlatform.bindgenHook ]; + nativeBuildInputs = [ + cmake + pkg-config + rustPlatform.bindgenHook + ]; buildInputs = [ fuse3 ]; checkFlags = [ diff --git a/pkgs/by-name/mo/mousai/package.nix b/pkgs/by-name/mo/mousai/package.nix index 53d084c308fa53..33fb9ca23b6233 100644 --- a/pkgs/by-name/mo/mousai/package.nix +++ b/pkgs/by-name/mo/mousai/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, appstream-glib -, cargo -, dbus -, desktop-file-utils -, glib -, glib-networking -, gst_all_1 -, gtk4 -, libadwaita -, libpulseaudio -, libsoup_3 -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, wrapGAppsHook4 +{ + lib, + stdenv, + fetchFromGitHub, + appstream-glib, + cargo, + dbus, + desktop-file-utils, + glib, + glib-networking, + gst_all_1, + gtk4, + libadwaita, + libpulseaudio, + libsoup_3, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + wrapGAppsHook4, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mo/mousam/package.nix b/pkgs/by-name/mo/mousam/package.nix index 4cf91beffe49c6..7afaf9615765ba 100644 --- a/pkgs/by-name/mo/mousam/package.nix +++ b/pkgs/by-name/mo/mousam/package.nix @@ -1,13 +1,14 @@ -{ lib -, python3Packages -, fetchFromGitHub -, meson -, ninja -, pkg-config -, gobject-introspection -, wrapGAppsHook4 -, desktop-file-utils -, libadwaita +{ + lib, + python3Packages, + fetchFromGitHub, + meson, + ninja, + pkg-config, + gobject-introspection, + wrapGAppsHook4, + desktop-file-utils, + libadwaita, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/mo/mouse-actions/package.nix b/pkgs/by-name/mo/mouse-actions/package.nix index 293fb16f4383d4..fb95726bd65784 100644 --- a/pkgs/by-name/mo/mouse-actions/package.nix +++ b/pkgs/by-name/mo/mouse-actions/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, libX11 -, libXi -, libXtst -, libevdev +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + libX11, + libXi, + libXtst, + libevdev, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/mo/mouse_m908/package.nix b/pkgs/by-name/mo/mouse_m908/package.nix index f9491674659b4a..56e320c0ba04bf 100644 --- a/pkgs/by-name/mo/mouse_m908/package.nix +++ b/pkgs/by-name/mo/mouse_m908/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, libusb1 -, installShellFiles -, fetchFromGitHub -, pkg-config +{ + stdenv, + lib, + libusb1, + installShellFiles, + fetchFromGitHub, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { @@ -17,7 +18,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-sCAvjNpJYkp4G0KkDJtHOBR1vc80DZJtWR2W9gakkzQ="; }; - nativeBuildInputs = [ pkg-config installShellFiles ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; buildInputs = [ libusb1 ]; diff --git a/pkgs/by-name/mo/mousecape/package.nix b/pkgs/by-name/mo/mousecape/package.nix index 7d45953a4e4027..d7644cc6b58cf1 100644 --- a/pkgs/by-name/mo/mousecape/package.nix +++ b/pkgs/by-name/mo/mousecape/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchzip +{ + lib, + stdenvNoCC, + fetchzip, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -30,4 +31,3 @@ stdenvNoCC.mkDerivation (finalAttrs: { sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; }; }) - diff --git a/pkgs/by-name/mo/mousetweaks/package.nix b/pkgs/by-name/mo/mousetweaks/package.nix index c05c1dd8bf1d87..162f70d0b30965 100644 --- a/pkgs/by-name/mo/mousetweaks/package.nix +++ b/pkgs/by-name/mo/mousetweaks/package.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchurl, pkg-config -, glib, gtk3, gnome, gsettings-desktop-schemas, wrapGAppsHook3 -, xorg +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + gtk3, + gnome, + gsettings-desktop-schemas, + wrapGAppsHook3, + xorg, }: stdenv.mkDerivation rec { @@ -8,15 +16,23 @@ stdenv.mkDerivation rec { version = "3.32.0"; src = fetchurl { - url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; - sha256 = "005fhmvb45sa9mq17dpa23n1xnspiissx5rnpiy7hiqmy3g5rg8f"; + url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; + sha256 = "005fhmvb45sa9mq17dpa23n1xnspiissx5rnpiy7hiqmy3g5rg8f"; }; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; buildInputs = [ - glib gtk3 gsettings-desktop-schemas - xorg.libX11 xorg.libXtst xorg.libXfixes xorg.libXcursor + glib + gtk3 + gsettings-desktop-schemas + xorg.libX11 + xorg.libXtst + xorg.libXfixes + xorg.libXcursor ]; passthru = { diff --git a/pkgs/by-name/mo/mov-cli/package.nix b/pkgs/by-name/mo/mov-cli/package.nix index 21a27905a702b5..ae08bd5dd535ec 100644 --- a/pkgs/by-name/mo/mov-cli/package.nix +++ b/pkgs/by-name/mo/mov-cli/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, ffmpeg -, fzf -, mpv -, python3 +{ + lib, + fetchFromGitHub, + ffmpeg, + fzf, + mpv, + python3, }: let @@ -40,7 +41,7 @@ python3.pkgs.buildPythonPackage { toml typer unidecode - (callPackage ./mov-cli-test.nix {}) + (callPackage ./mov-cli-test.nix { }) ]; pythonRelaxDeps = [ @@ -48,15 +49,17 @@ python3.pkgs.buildPythonPackage { "tldextract" ]; - makeWrapperArgs = let - binPath = lib.makeBinPath [ - ffmpeg - fzf - mpv + makeWrapperArgs = + let + binPath = lib.makeBinPath [ + ffmpeg + fzf + mpv + ]; + in + [ + "--prefix PATH : ${binPath}" ]; - in [ - "--prefix PATH : ${binPath}" - ]; meta = with lib; { homepage = "https://github.com/mov-cli/mov-cli"; diff --git a/pkgs/by-name/mo/move-mount-beneath/package.nix b/pkgs/by-name/mo/move-mount-beneath/package.nix index 2bbde4f7d57af7..b60e7ec9011061 100644 --- a/pkgs/by-name/mo/move-mount-beneath/package.nix +++ b/pkgs/by-name/mo/move-mount-beneath/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/mo/movim/package.nix b/pkgs/by-name/mo/movim/package.nix index ef5dac3d58fed1..5aa5f4ed70ffee 100644 --- a/pkgs/by-name/mo/movim/package.nix +++ b/pkgs/by-name/mo/movim/package.nix @@ -1,16 +1,17 @@ -{ lib -, fetchFromGitHub -, writeShellScript -, dash -, php -, phpCfg ? null -, withPgsql ? true # “strongly recommended” according to docs -, withMysql ? false -, minifyStaticFiles ? false # default files are often not minified -, esbuild -, lightningcss -, scour -, nixosTests +{ + lib, + fetchFromGitHub, + writeShellScript, + dash, + php, + phpCfg ? null, + withPgsql ? true, # “strongly recommended” according to docs + withMysql ? false, + minifyStaticFiles ? false, # default files are often not minified + esbuild, + lightningcss, + scour, + nixosTests, }: let @@ -28,13 +29,18 @@ let }; }; - minify = lib.recursiveUpdate defaultMinifyOpts - (if lib.isBool minifyStaticFiles && minifyStaticFiles then - { script.enable = true; style.enable = true; svg.enable = true; } + minify = lib.recursiveUpdate defaultMinifyOpts ( + if lib.isBool minifyStaticFiles && minifyStaticFiles then + { + script.enable = true; + style.enable = true; + svg.enable = true; + } else if lib.isAttrs minifyStaticFiles then lib.filterAttrsRecursive (_: v: v != null) minifyStaticFiles else - { }); + { } + ); in php.buildComposerProject (finalAttrs: { pname = "movim"; @@ -47,16 +53,41 @@ php.buildComposerProject (finalAttrs: { hash = "sha256-mjBeBu1seH5XMls+e4ON13ayVeugKogbNTzbjp1pUjE="; }; - php = php.buildEnv ({ - extensions = ({ all, enabled }: - enabled - ++ (with all; [ curl dom gd imagick mbstring pdo simplexml ]) - ++ lib.optionals withPgsql (with all; [ pdo_pgsql pgsql ]) - ++ lib.optionals withMysql (with all; [ mysqli mysqlnd pdo_mysql ]) - ); - } // lib.optionalAttrs (phpCfg != null) { - extraConfig = phpCfg; - }); + php = php.buildEnv ( + { + extensions = ( + { all, enabled }: + enabled + ++ (with all; [ + curl + dom + gd + imagick + mbstring + pdo + simplexml + ]) + ++ lib.optionals withPgsql ( + with all; + [ + pdo_pgsql + pgsql + ] + ) + ++ lib.optionals withMysql ( + with all; + [ + mysqli + mysqlnd + pdo_mysql + ] + ) + ); + } + // lib.optionalAttrs (phpCfg != null) { + extraConfig = phpCfg; + } + ); nativeBuildInputs = lib.optional minify.script.enable esbuild @@ -91,32 +122,35 @@ php.buildComposerProject (finalAttrs: { --replace-fail "Imagick::ALPHACHANNEL_ACTIVATE" "Imagick::ALPHACHANNEL_ON" ''; - preBuild = lib.optionalString minify.script.enable '' - find ./public -type f -iname "*.js" -print0 \ - | xargs -0 -n 1 -P $NIX_BUILD_CORES ${writeShellScript "movim_script_minify" '' + preBuild = + lib.optionalString minify.script.enable '' + find ./public -type f -iname "*.js" -print0 \ + | xargs -0 -n 1 -P $NIX_BUILD_CORES ${writeShellScript "movim_script_minify" '' file="$1" tmp="$(mktemp)" esbuild $file --minify --target=${lib.escapeShellArg minify.script.target} --outfile=$tmp [[ "$(stat -c %s $tmp)" -lt "$(stat -c %s $file)" ]] && mv $tmp $file ''} - '' + lib.optionalString minify.style.enable '' - find ./public -type f -iname "*.css" -print0 \ - | xargs -0 -n 1 -P $NIX_BUILD_CORES ${writeShellScript "movim_style_minify" '' + '' + + lib.optionalString minify.style.enable '' + find ./public -type f -iname "*.css" -print0 \ + | xargs -0 -n 1 -P $NIX_BUILD_CORES ${writeShellScript "movim_style_minify" '' export BROWSERLIST="${lib.escapeShellArg minify.style.browserslist}" file="$1" tmp="$(mktemp)" lightningcss $file --minify --browserslist --output-file=$tmp [[ "$(stat -c %s $tmp)" -lt "$(stat -c %s $file)" ]] && mv $tmp $file ''} - '' + lib.optionalString minify.svg.enable '' - find ./public -type f -iname "*.svg" -a -not -path "*/emojis/*" -print0 \ - | xargs -0 -n 1 -P $NIX_BUILD_CORES ${writeShellScript "movim_svg_minify" '' + '' + + lib.optionalString minify.svg.enable '' + find ./public -type f -iname "*.svg" -a -not -path "*/emojis/*" -print0 \ + | xargs -0 -n 1 -P $NIX_BUILD_CORES ${writeShellScript "movim_svg_minify" '' file="$1" tmp="$(mktemp)" scour -i $file -o $tmp --disable-style-to-xml --enable-comment-stripping --enable-viewboxing --indent=tab [[ "$(stat -c %s $tmp)" -lt "$(stat -c %s $file)" ]] && mv $tmp $file ''} - ''; + ''; postInstall = '' mkdir -p $out/bin diff --git a/pkgs/by-name/mo/movine/package.nix b/pkgs/by-name/mo/movine/package.nix index 41ea6a42a05d3d..60e9df62baefd6 100644 --- a/pkgs/by-name/mo/movine/package.nix +++ b/pkgs/by-name/mo/movine/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -22,11 +23,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; meta = with lib; { description = "Migration manager written in Rust, that attempts to be smart yet minimal"; diff --git a/pkgs/by-name/mo/movit/package.nix b/pkgs/by-name/mo/movit/package.nix index 55a4ec26025a48..e285137e459fca 100644 --- a/pkgs/by-name/mo/movit/package.nix +++ b/pkgs/by-name/mo/movit/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, SDL2 -, fftw -, gtest -, darwin -, eigen -, libepoxy +{ + lib, + stdenv, + fetchurl, + pkg-config, + SDL2, + fftw, + gtest, + darwin, + eigen, + libepoxy, }: stdenv.mkDerivation rec { @@ -19,7 +20,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-szBztwXwzLasSULPURUVFUB7QLtOmi3QIowcLLH7wRo="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; GTEST_DIR = "${gtest.src}/googletest"; @@ -27,14 +31,16 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - SDL2 - fftw - gtest - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.OpenGL - darwin.libobjc - ]; + buildInputs = + [ + SDL2 + fftw + gtest + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.OpenGL + darwin.libobjc + ]; propagatedBuildInputs = [ eigen diff --git a/pkgs/by-name/mo/mox/package.nix b/pkgs/by-name/mo/mox/package.nix index cb266f89bc4dd2..749e4d2e4515ef 100644 --- a/pkgs/by-name/mo/mox/package.nix +++ b/pkgs/by-name/mo/mox/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/mo/mozjpeg/package.nix b/pkgs/by-name/mo/mozjpeg/package.nix index b693626fae644e..8a73827a29532d 100644 --- a/pkgs/by-name/mo/mozjpeg/package.nix +++ b/pkgs/by-name/mo/mozjpeg/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, libpng, zlib, nasm }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libpng, + zlib, + nasm, +}: stdenv.mkDerivation rec { version = "4.1.5"; @@ -11,10 +20,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-k8qWtU4j3ipIHvY60ae7kdNnPvWnUa0qgacqlSIJijo="; }; - cmakeFlags = [ "-DENABLE_STATIC=NO" "-DPNG_SUPPORTED=TRUE" ]; # See https://github.com/mozilla/mozjpeg/issues/351 + cmakeFlags = [ + "-DENABLE_STATIC=NO" + "-DPNG_SUPPORTED=TRUE" + ]; # See https://github.com/mozilla/mozjpeg/issues/351 - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libpng zlib nasm ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + libpng + zlib + nasm + ]; meta = { description = "Mozilla JPEG Encoder Project"; diff --git a/pkgs/by-name/mo/mozlz4a/package.nix b/pkgs/by-name/mo/mozlz4a/package.nix index a9ab74bc7a5923..8ef0d3ea0c08e6 100644 --- a/pkgs/by-name/mo/mozlz4a/package.nix +++ b/pkgs/by-name/mo/mozlz4a/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, python3 -, runtimeShell +{ + lib, + stdenv, + fetchurl, + python3, + runtimeShell, }: stdenv.mkDerivation rec { @@ -16,7 +17,10 @@ stdenv.mkDerivation rec { dontUnpack = true; - buildInputs = [ python3 python3.pkgs.lz4 ]; + buildInputs = [ + python3 + python3.pkgs.lz4 + ]; installPhase = '' mkdir -p "$out/bin" "$out/${python3.sitePackages}/" @@ -31,7 +35,11 @@ stdenv.mkDerivation rec { meta = with lib; { description = "MozLz4a compression/decompression utility"; license = licenses.bsd2; - maintainers = with maintainers; [ kira-bruneau pshirshov raskin ]; + maintainers = with maintainers; [ + kira-bruneau + pshirshov + raskin + ]; platforms = python3.meta.platforms; homepage = "https://gist.github.com/Tblue/62ff47bef7f894e92ed5"; mainProgram = "mozlz4a"; diff --git a/pkgs/by-name/mo/mozphab/package.nix b/pkgs/by-name/mo/mozphab/package.nix index 6a08104129821a..a9618e9d519033 100644 --- a/pkgs/by-name/mo/mozphab/package.nix +++ b/pkgs/by-name/mo/mozphab/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, -# tests -, git -, mercurial -, patch + # tests + git, + mercurial, + patch, }: python3.pkgs.buildPythonApplication rec { @@ -40,18 +41,19 @@ python3.pkgs.buildPythonApplication rec { setuptools ]; - nativeCheckInputs = [ - git - mercurial - patch - ] - ++ (with python3.pkgs; [ - callee - immutabledict - hg-evolve - mock - pytestCheckHook - ]); + nativeCheckInputs = + [ + git + mercurial + patch + ] + ++ (with python3.pkgs; [ + callee + immutabledict + hg-evolve + mock + pytestCheckHook + ]); preCheck = '' export HOME=$(mktemp -d) diff --git a/pkgs/by-name/mp/mp3blaster/package.nix b/pkgs/by-name/mp/mp3blaster/package.nix index 02711ab4e1314c..3127c53fe73ce0 100644 --- a/pkgs/by-name/mp/mp3blaster/package.nix +++ b/pkgs/by-name/mp/mp3blaster/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, ncurses, libvorbis, SDL }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + ncurses, + libvorbis, + SDL, +}: stdenv.mkDerivation rec { pname = "mp3blaster"; @@ -26,11 +34,14 @@ stdenv.mkDerivation rec { libvorbis ] ++ lib.optional stdenv.hostPlatform.isDarwin SDL; - env.NIX_CFLAGS_COMPILE = toString ([ - "-Wno-narrowing" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-reserved-user-defined-literal" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-Wno-narrowing" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-reserved-user-defined-literal" + ] + ); meta = with lib; { description = "Audio player for the text console"; diff --git a/pkgs/by-name/mp/mp3cat/package.nix b/pkgs/by-name/mp/mp3cat/package.nix index d6e76582d16744..a945e50be8d47f 100644 --- a/pkgs/by-name/mp/mp3cat/package.nix +++ b/pkgs/by-name/mp/mp3cat/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "mp3cat"; diff --git a/pkgs/by-name/mp/mp3fs/package.nix b/pkgs/by-name/mp/mp3fs/package.nix index 0412a99beee0e0..6a98b78348b86b 100644 --- a/pkgs/by-name/mp/mp3fs/package.nix +++ b/pkgs/by-name/mp/mp3fs/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, flac -, fuse -, lame -, libid3tag -, libvorbis -, autoreconfHook -, pkg-config -, pandoc +{ + lib, + stdenv, + fetchFromGitHub, + flac, + fuse, + lame, + libid3tag, + libvorbis, + autoreconfHook, + pkg-config, + pandoc, }: stdenv.mkDerivation rec { @@ -28,8 +29,18 @@ stdenv.mkDerivation rec { --replace "osxfuse_version()" "fuse_version()" ''; - buildInputs = [ flac fuse lame libid3tag libvorbis ]; - nativeBuildInputs = [ autoreconfHook pkg-config pandoc ]; + buildInputs = [ + flac + fuse + lame + libid3tag + libvorbis + ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + pandoc + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/mp/mp3gain/package.nix b/pkgs/by-name/mp/mp3gain/package.nix index a59f2e376db031..d672d58a356327 100644 --- a/pkgs/by-name/mp/mp3gain/package.nix +++ b/pkgs/by-name/mp/mp3gain/package.nix @@ -1,10 +1,19 @@ -{ lib, stdenv, fetchurl, fetchpatch, unzip, mpg123 }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + unzip, + mpg123, +}: stdenv.mkDerivation rec { pname = "mp3gain"; version = "1.6.2"; src = fetchurl { - url = "mirror://sourceforge/${pname}/${pname}-${lib.replaceStrings ["."] ["_"] version}-src.zip"; + url = "mirror://sourceforge/${pname}/${pname}-${ + lib.replaceStrings [ "." ] [ "_" ] version + }-src.zip"; sha256 = "0varr6y7k8zarr56b42r0ad9g3brhn5vv3xjg1c0v19jxwr4gh2w"; }; diff --git a/pkgs/by-name/mp/mp3splt/package.nix b/pkgs/by-name/mp/mp3splt/package.nix index 1407c153aed2d5..5721630bef2375 100644 --- a/pkgs/by-name/mp/mp3splt/package.nix +++ b/pkgs/by-name/mp/mp3splt/package.nix @@ -1,20 +1,31 @@ -{ lib, stdenv, fetchurl, pkg-config, libmp3splt }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libmp3splt, +}: stdenv.mkDerivation rec { pname = "mp3splt"; version = "2.6.2"; - src = fetchurl { url = "mirror://sourceforge/${pname}/${pname}-${version}.tar.gz"; sha256 = "1aiv20gypb6r84qabz8gblk8vi42cg3x333vk2pi3fyqvl82phry"; }; - configureFlags = [ "--enable-oggsplt-symlink" "--enable-flacsplt-symlink" ]; + configureFlags = [ + "--enable-oggsplt-symlink" + "--enable-flacsplt-symlink" + ]; nativeBuildInputs = [ pkg-config ]; buildInputs = [ libmp3splt ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; meta = with lib; { description = "Utility to split mp3, ogg vorbis and FLAC files without decoding"; diff --git a/pkgs/by-name/mp/mp3val/package.nix b/pkgs/by-name/mp/mp3val/package.nix index 506829ac3a0004..a29ebb5dcdab70 100644 --- a/pkgs/by-name/mp/mp3val/package.nix +++ b/pkgs/by-name/mp/mp3val/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mp3val"; diff --git a/pkgs/by-name/mp/mp4v2/package.nix b/pkgs/by-name/mp/mp4v2/package.nix index 1fdb48dab4c429..40a8da44fa5a41 100644 --- a/pkgs/by-name/mp/mp4v2/package.nix +++ b/pkgs/by-name/mp/mp4v2/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "mp4v2"; diff --git a/pkgs/by-name/mp/mpage/package.nix b/pkgs/by-name/mp/mpage/package.nix index e7a114ec657717..ef6cfa8e381d12 100644 --- a/pkgs/by-name/mp/mpage/package.nix +++ b/pkgs/by-name/mp/mpage/package.nix @@ -1,4 +1,8 @@ -{ fetchurl, lib, stdenv }: +{ + fetchurl, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "mpage"; @@ -26,7 +30,7 @@ stdenv.mkDerivation rec { ISO 8859.1 to print 8-bit characters. ''; - license = "liberal"; # a non-copyleft license, see `Copyright' file + license = "liberal"; # a non-copyleft license, see `Copyright' file homepage = "http://www.mesa.nl/pub/mpage/"; platforms = lib.platforms.all; }; diff --git a/pkgs/by-name/mp/mpc123/package.nix b/pkgs/by-name/mp/mpc123/package.nix index 1061705115ea58..a08d91e84b3dbd 100644 --- a/pkgs/by-name/mp/mpc123/package.nix +++ b/pkgs/by-name/mp/mpc123/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitLab -, gettext -, libao -, libmpcdec +{ + lib, + stdenv, + fetchFromGitLab, + gettext, + libao, + libmpcdec, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/mp/mpd-discord-rpc/package.nix b/pkgs/by-name/mp/mpd-discord-rpc/package.nix index 1dada2fcfc3f5e..8235b426864e9f 100644 --- a/pkgs/by-name/mp/mpd-discord-rpc/package.nix +++ b/pkgs/by-name/mp/mpd-discord-rpc/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -24,12 +25,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; meta = with lib; { description = "Rust application which displays your currently playing song / album / artist from MPD in Discord using Rich Presence"; diff --git a/pkgs/by-name/mp/mpd-mpris/package.nix b/pkgs/by-name/mp/mpd-mpris/package.nix index 9c6412de12e128..8d7096eed5038b 100644 --- a/pkgs/by-name/mp/mpd-mpris/package.nix +++ b/pkgs/by-name/mp/mpd-mpris/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, }: buildGoModule rec { diff --git a/pkgs/by-name/mp/mpd-notification/package.nix b/pkgs/by-name/mp/mpd-notification/package.nix index 277a9fcf65a20a..f488d46f4e5bce 100644 --- a/pkgs/by-name/mp/mpd-notification/package.nix +++ b/pkgs/by-name/mp/mpd-notification/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, pkg-config -, fetchFromGitHub -, file -, iniparser -, ffmpeg -, libnotify -, libmpdclient -, discount -, systemd +{ + lib, + stdenv, + pkg-config, + fetchFromGitHub, + file, + iniparser, + ffmpeg, + libnotify, + libmpdclient, + discount, + systemd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mp/mpd-touch-screen-gui/package.nix b/pkgs/by-name/mp/mpd-touch-screen-gui/package.nix index 87f2dea11f065c..31a47126dfc461 100644 --- a/pkgs/by-name/mp/mpd-touch-screen-gui/package.nix +++ b/pkgs/by-name/mp/mpd-touch-screen-gui/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, autoreconfHook -, SDL2 -, SDL2_ttf -, SDL2_image -, boost -, libmpdclient -, libwtk-sdl2 -, icu -, libconfig -, dejavu_fonts +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + SDL2, + SDL2_ttf, + SDL2_image, + boost, + libmpdclient, + libwtk-sdl2, + icu, + libconfig, + dejavu_fonts, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/mp/mpdas/package.nix b/pkgs/by-name/mp/mpdas/package.nix index 04251854d48d21..c1e9c88bdb5d57 100644 --- a/pkgs/by-name/mp/mpdas/package.nix +++ b/pkgs/by-name/mp/mpdas/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, libmpdclient -, curl +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libmpdclient, + curl, }: stdenv.mkDerivation rec { @@ -19,9 +20,16 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libmpdclient curl ]; + buildInputs = [ + libmpdclient + curl + ]; - makeFlags = [ "CONFIG=/etc" "DESTDIR=" "PREFIX=$(out)" ]; + makeFlags = [ + "CONFIG=/etc" + "DESTDIR=" + "PREFIX=$(out)" + ]; meta = with lib; { description = "Music Player Daemon AudioScrobbler"; diff --git a/pkgs/by-name/mp/mpdcron/gemset.nix b/pkgs/by-name/mp/mpdcron/gemset.nix index ee254bb6354b77..4a42bdef22c044 100644 --- a/pkgs/by-name/mp/mpdcron/gemset.nix +++ b/pkgs/by-name/mp/mpdcron/gemset.nix @@ -1,20 +1,20 @@ { mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15zplpfw3knqifj9bpf604rb3wc1vhq6363pd6lvhayng8wql5vy"; type = "gem"; }; version = "2.4.0"; }; nokogiri = { - dependencies = ["mini_portile2"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mini_portile2" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02bjydih0j515szfv9mls195cvpyidh6ixm7dwbl3s2sbaxxk5s4"; type = "gem"; }; diff --git a/pkgs/by-name/mp/mpdcron/package.nix b/pkgs/by-name/mp/mpdcron/package.nix index 3ced3d5d1382e9..b3c22a7b80ee76 100644 --- a/pkgs/by-name/mp/mpdcron/package.nix +++ b/pkgs/by-name/mp/mpdcron/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, libtool -, pkg-config -, glib -, libdaemon -, libmpdclient -, curl -, sqlite -, bundlerEnv -, libnotify -, pandoc +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + pkg-config, + glib, + libdaemon, + libmpdclient, + curl, + sqlite, + bundlerEnv, + libnotify, + pandoc, }: let @@ -20,7 +21,8 @@ let name = "mpdcron-bundle"; gemdir = ./.; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "mpdcron"; version = "20161228"; @@ -31,7 +33,11 @@ in stdenv.mkDerivation { sha256 = "0vdksf6lcgmizqr5mqp0bbci259k0dj7gpmhx32md41jlmw5skaw"; }; - nativeBuildInputs = [ autoconf automake pkg-config ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + ]; buildInputs = [ libtool glib @@ -48,15 +54,21 @@ in stdenv.mkDerivation { ./autogen.sh ''; - configureFlags = [ "--enable-gmodule" "--with-standard-modules=all" ]; + configureFlags = [ + "--enable-gmodule" + "--with-standard-modules=all" + ]; meta = with lib; { description = "Cron like daemon for mpd"; - homepage = "http://alip.github.io/mpdcron/"; - license = licenses.gpl2Plus; - platforms = platforms.unix; - maintainers = with maintainers; [ lovek323 manveru ]; - broken = stdenv.hostPlatform.isDarwin; # fails due to old nokogiri https://github.com/sparklemotion/nokogiri/discussions/3152#discussioncomment-8806607 + homepage = "http://alip.github.io/mpdcron/"; + license = licenses.gpl2Plus; + platforms = platforms.unix; + maintainers = with maintainers; [ + lovek323 + manveru + ]; + broken = stdenv.hostPlatform.isDarwin; # fails due to old nokogiri https://github.com/sparklemotion/nokogiri/discussions/3152#discussioncomment-8806607 }; } # TODO: autoreconfHook this diff --git a/pkgs/by-name/mp/mpdecimal/package.nix b/pkgs/by-name/mp/mpdecimal/package.nix index 82643b19710982..72a3ece43fbbae 100644 --- a/pkgs/by-name/mp/mpdecimal/package.nix +++ b/pkgs/by-name/mp/mpdecimal/package.nix @@ -1,9 +1,19 @@ -{ lib, stdenv, fetchurl, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "mpdecimal"; version = "4.0.0"; - outputs = [ "out" "cxx" "doc" "dev" ]; + outputs = [ + "out" + "cxx" + "doc" + "dev" + ]; src = fetchurl { url = "https://www.bytereef.org/software/mpdecimal/releases/mpdecimal-${version}.tar.gz"; @@ -31,7 +41,7 @@ stdenv.mkDerivation rec { meta = { description = "Library for arbitrary precision decimal floating point arithmetic"; - longDescription = '' + longDescription = '' libmpdec is a fast C/C++ library for correctly-rounded arbitrary precision decimal floating point arithmetic. It is a complete implementation of Mike Cowlishaw/IBM's General Decimal Arithmetic diff --git a/pkgs/by-name/mp/mpdris2/package.nix b/pkgs/by-name/mp/mpdris2/package.nix index 3fb6b46a42a81d..c9f6578efbca94 100644 --- a/pkgs/by-name/mp/mpdris2/package.nix +++ b/pkgs/by-name/mp/mpdris2/package.nix @@ -1,12 +1,13 @@ -{ lib -, autoreconfHook -, fetchFromGitHub -, glib -, gobject-introspection -, intltool -, libnotify -, python3 -, wrapGAppsHook3 +{ + lib, + autoreconfHook, + fetchFromGitHub, + glib, + gobject-introspection, + intltool, + libnotify, + python3, + wrapGAppsHook3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/mp/mpdscribble/package.nix b/pkgs/by-name/mp/mpdscribble/package.nix index c4e7ad591eb695..a6d74dabc7ebd4 100644 --- a/pkgs/by-name/mp/mpdscribble/package.nix +++ b/pkgs/by-name/mp/mpdscribble/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, pkg-config -, meson -, ninja -, boost -, curl -, libgcrypt -, libmpdclient -, systemd +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + meson, + ninja, + boost, + curl, + libgcrypt, + libmpdclient, + systemd, }: stdenv.mkDerivation rec { @@ -22,17 +23,23 @@ stdenv.mkDerivation rec { }; # Fix build issue on darwin; to be removed after the next release - patches = [(fetchpatch { - name = "remove-empty-static-lib.patch"; - url = "https://github.com/MusicPlayerDaemon/mpdscribble/commit/0dbcea25c81f3fdc608f71ef71a9784679fee17f.patch"; - sha256 = "sha256-3wLfQvbwx+OFrCl5vMV7Zps4e4iEYFhqPiVCo5hDqgw="; - })]; + patches = [ + (fetchpatch { + name = "remove-empty-static-lib.patch"; + url = "https://github.com/MusicPlayerDaemon/mpdscribble/commit/0dbcea25c81f3fdc608f71ef71a9784679fee17f.patch"; + sha256 = "sha256-3wLfQvbwx+OFrCl5vMV7Zps4e4iEYFhqPiVCo5hDqgw="; + }) + ]; postPatch = '' sed '1i#include ' -i src/Log.cxx # gcc12 ''; - nativeBuildInputs = [ pkg-config meson ninja ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + ]; buildInputs = [ libmpdclient curl diff --git a/pkgs/by-name/mp/mpfi/package.nix b/pkgs/by-name/mp/mpfi/package.nix index 802a89c4c5e4ef..a5ba01b2af848c 100644 --- a/pkgs/by-name/mp/mpfi/package.nix +++ b/pkgs/by-name/mp/mpfi/package.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchFromGitLab, autoreconfHook, texinfo, mpfr}: +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + texinfo, + mpfr, +}: stdenv.mkDerivation rec { pname = "mpfi"; version = "1.5.4"; @@ -12,23 +19,24 @@ stdenv.mkDerivation rec { # Conditional to allow auto-updaters to try new releases # TODO: remove the conditional after an upstream update # rev = version; - rev = if version == "1.5.4" then - "feab26bc54529417af983950ddbffb3a4c334d4f" - else version; + rev = if version == "1.5.4" then "feab26bc54529417af983950ddbffb3a4c334d4f" else version; sha256 = "sha256-aj/QmJ38ifsW36JFQcbp55aIQRvOpiqLHwEh/aFXsgo="; }; sourceRoot = "${src.name}/mpfi"; - nativeBuildInputs = [ autoreconfHook texinfo ]; + nativeBuildInputs = [ + autoreconfHook + texinfo + ]; buildInputs = [ mpfr ]; meta = { description = "Multiple precision interval arithmetic library based on MPFR"; homepage = "http://perso.ens-lyon.fr/nathalie.revol/software.html"; license = lib.licenses.lgpl21Plus; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.unix; }; } diff --git a/pkgs/by-name/mp/mpfr/package.nix b/pkgs/by-name/mp/mpfr/package.nix index 2ba09fc226fdaa..79de1ab9de9011 100644 --- a/pkgs/by-name/mp/mpfr/package.nix +++ b/pkgs/by-name/mp/mpfr/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, gmp -, writeScript -, updateAutotoolsGnuConfigScriptsHook +{ + lib, + stdenv, + fetchurl, + gmp, + writeScript, + updateAutotoolsGnuConfigScriptsHook, }: # Note: this package is used for bootstrapping fetchurl, and thus @@ -23,7 +24,12 @@ stdenv.mkDerivation rec { hash = "sha256-J3gHNTpnJpeJlpRa8T5Sgp46vXqaW3+yeTiU4Y8fy7I="; }; - outputs = [ "out" "dev" "doc" "info" ]; + outputs = [ + "out" + "dev" + "doc" + "info" + ]; strictDeps = true; # necessary to build on FreeBSD native pending inclusion of @@ -32,7 +38,8 @@ stdenv.mkDerivation rec { # mpfr.h requires gmp.h propagatedBuildInputs = [ gmp ]; - configureFlags = lib.optional stdenv.hostPlatform.isSunOS "--disable-thread-safe" + configureFlags = + lib.optional stdenv.hostPlatform.isSunOS "--disable-thread-safe" ++ lib.optional stdenv.hostPlatform.is64bit "--with-pic" ++ lib.optionals stdenv.hostPlatform.isPower64 [ # Without this, the `tget_set_d128` test experiences a link diff --git a/pkgs/by-name/mp/mpfshell/package.nix b/pkgs/by-name/mp/mpfshell/package.nix index 63223a54eb8e49..7e4bbdf740ab00 100644 --- a/pkgs/by-name/mp/mpfshell/package.nix +++ b/pkgs/by-name/mp/mpfshell/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonPackage rec { pname = "mpfshell-unstable"; @@ -12,7 +16,9 @@ python3Packages.buildPythonPackage rec { }; propagatedBuildInputs = with python3Packages; [ - pyserial colorama websocket-client + pyserial + colorama + websocket-client ]; doCheck = false; diff --git a/pkgs/by-name/mp/mpifileutils/package.nix b/pkgs/by-name/mp/mpifileutils/package.nix index 92300592c2fa81..e72da7d2aff44b 100644 --- a/pkgs/by-name/mp/mpifileutils/package.nix +++ b/pkgs/by-name/mp/mpifileutils/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, mpi -, attr -, dtcmp -, libarchive -, libcircle -, bzip2 -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + mpi, + attr, + dtcmp, + libarchive, + libcircle, + bzip2, + openssl, }: stdenv.mkDerivation rec { @@ -23,9 +24,16 @@ stdenv.mkDerivation rec { hash = "sha256-3nls82awMMCwlfafsOy3AY8OvT9sE+BvvsDOY14YvQc="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ attr dtcmp diff --git a/pkgs/by-name/mp/mpir/package.nix b/pkgs/by-name/mp/mpir/package.nix index 9857317ea1889e..21f9ebd36a238f 100644 --- a/pkgs/by-name/mp/mpir/package.nix +++ b/pkgs/by-name/mp/mpir/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, m4, which, yasm, autoreconfHook, fetchpatch, buildPackages }: +{ + lib, + stdenv, + fetchurl, + m4, + which, + yasm, + autoreconfHook, + fetchpatch, + buildPackages, +}: stdenv.mkDerivation rec { pname = "mpir"; @@ -6,7 +16,12 @@ stdenv.mkDerivation rec { depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ m4 which yasm autoreconfHook ]; + nativeBuildInputs = [ + m4 + which + yasm + autoreconfHook + ]; src = fetchurl { url = "https://mpir.org/mpir-${version}.tar.bz2"; @@ -22,13 +37,12 @@ stdenv.mkDerivation rec { }) ]; - configureFlags = [ "--enable-cxx" ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ "--enable-fat" ]; + configureFlags = [ "--enable-cxx" ] ++ lib.optionals stdenv.hostPlatform.isLinux [ "--enable-fat" ]; meta = { description = "Highly optimised library for bignum arithmetic forked from GMP"; license = lib.licenses.lgpl3Plus; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.unix; downloadPage = "https://mpir.org/downloads.html"; homepage = "https://mpir.org/"; diff --git a/pkgs/by-name/mp/mprime/package.nix b/pkgs/by-name/mp/mprime/package.nix index e55f8ca50fe0b8..8cdf5f1b1479fa 100644 --- a/pkgs/by-name/mp/mprime/package.nix +++ b/pkgs/by-name/mp/mprime/package.nix @@ -1,19 +1,32 @@ -{ stdenv, lib, fetchurl, unzip, boost, curl, hwloc, gmp }: +{ + stdenv, + lib, + fetchurl, + unzip, + boost, + curl, + hwloc, + gmp, +}: let throwSystem = throw "Unsupported system: ${stdenv.hostPlatform.system}"; - srcDir = { - x86_64-linux = "linux64"; - i686-linux = "linux"; - x86_64-darwin = "macosx64"; - }."${stdenv.hostPlatform.system}" or throwSystem; + srcDir = + { + x86_64-linux = "linux64"; + i686-linux = "linux"; + x86_64-darwin = "macosx64"; + } + ."${stdenv.hostPlatform.system}" or throwSystem; - gwnum = { - x86_64-linux = "make64"; - i686-linux = "makefile"; - x86_64-darwin = "makemac"; - }."${stdenv.hostPlatform.system}" or throwSystem; + gwnum = + { + x86_64-linux = "make64"; + i686-linux = "makefile"; + x86_64-darwin = "makemac"; + } + ."${stdenv.hostPlatform.system}" or throwSystem; in stdenv.mkDerivation rec { @@ -21,7 +34,9 @@ stdenv.mkDerivation rec { version = "30.8b15"; src = fetchurl { - url = "https://www.mersenne.org/ftp_root/gimps/p95v${lib.replaceStrings ["."] [""] version}.source.zip"; + url = "https://www.mersenne.org/ftp_root/gimps/p95v${ + lib.replaceStrings [ "." ] [ "" ] version + }.source.zip"; hash = "sha256-CNYorZStHV0aESGX9LfLZ4oD5PFR2UOFLN1MiLaKw58="; }; @@ -37,7 +52,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ unzip ]; - buildInputs = [ boost curl hwloc gmp ]; + buildInputs = [ + boost + curl + hwloc + gmp + ]; enableParallelBuilding = true; @@ -63,7 +83,11 @@ stdenv.mkDerivation rec { # a suitable prime. http://www.mersenne.org/legal/#EULA license = licenses.unfree; # Untested on linux-32 and osx. Works in theory. - platforms = ["i686-linux" "x86_64-linux" "x86_64-darwin"]; + platforms = [ + "i686-linux" + "x86_64-linux" + "x86_64-darwin" + ]; mainProgram = "mprime"; }; } diff --git a/pkgs/by-name/mp/mpris-notifier/package.nix b/pkgs/by-name/mp/mpris-notifier/package.nix index 3b3016a1d24816..feaca1f895b3c0 100644 --- a/pkgs/by-name/mp/mpris-notifier/package.nix +++ b/pkgs/by-name/mp/mpris-notifier/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/mp/mpris-scrobbler/package.nix b/pkgs/by-name/mp/mpris-scrobbler/package.nix index 749a90336ae45d..224108fa418a0f 100644 --- a/pkgs/by-name/mp/mpris-scrobbler/package.nix +++ b/pkgs/by-name/mp/mpris-scrobbler/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, curl -, dbus -, libevent -, m4 -, meson -, ninja -, pkg-config -, scdoc -, json_c -, xdg-utils +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + curl, + dbus, + libevent, + m4, + meson, + ninja, + pkg-config, + scdoc, + json_c, + xdg-utils, }: stdenv.mkDerivation rec { @@ -25,14 +26,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-eeOhFkLyx+smZmKPTbVB1OiYkHdWk5v2rnOb9yCIuYE="; }; - postPatch = '' - substituteInPlace src/signon.c \ - --replace "/usr/bin/xdg-open" "${xdg-utils}/bin/xdg-open" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace meson.build \ - --replace "-Werror=format-truncation=0" "" \ - --replace "-Wno-stringop-overflow" "" - ''; + postPatch = + '' + substituteInPlace src/signon.c \ + --replace "/usr/bin/xdg-open" "${xdg-utils}/bin/xdg-open" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace meson.build \ + --replace "-Werror=format-truncation=0" "" \ + --replace "-Wno-stringop-overflow" "" + ''; nativeBuildInputs = [ m4 @@ -53,17 +56,21 @@ stdenv.mkDerivation rec { "-Dversion=${version}" ]; - env.NIX_CFLAGS_COMPILE = toString ([ - # Needed with GCC 12 - "-Wno-error=address" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-Wno-sometimes-uninitialized" - "-Wno-tautological-pointer-compare" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "-Wno-array-bounds" - "-Wno-free-nonheap-object" - "-Wno-stringop-truncation" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + [ + # Needed with GCC 12 + "-Wno-error=address" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-Wno-sometimes-uninitialized" + "-Wno-tautological-pointer-compare" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "-Wno-array-bounds" + "-Wno-free-nonheap-object" + "-Wno-stringop-truncation" + ] + ); passthru = { updateScript = nix-update-script { }; diff --git a/pkgs/by-name/mp/mprocs/package.nix b/pkgs/by-name/mp/mprocs/package.nix index d7b9a44290fa9f..2dedffb92ff268 100644 --- a/pkgs/by-name/mp/mprocs/package.nix +++ b/pkgs/by-name/mp/mprocs/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, rustPlatform, nix-update-script, testers, mprocs }: +{ + lib, + fetchFromGitHub, + rustPlatform, + nix-update-script, + testers, + mprocs, +}: rustPlatform.buildRustPackage rec { pname = "mprocs"; @@ -23,7 +30,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/pvolok/mprocs"; changelog = "https://github.com/pvolok/mprocs/releases/tag/v${version}"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ GaetanLepage pyrox0 ]; + maintainers = with lib.maintainers; [ + GaetanLepage + pyrox0 + ]; platforms = lib.platforms.unix; mainProgram = "mprocs"; }; diff --git a/pkgs/by-name/mp/mps/package.nix b/pkgs/by-name/mp/mps/package.nix index 049868c9381b61..48d8bede782e00 100644 --- a/pkgs/by-name/mp/mps/package.nix +++ b/pkgs/by-name/mp/mps/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, sqlite +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + sqlite, }: stdenv.mkDerivation rec { @@ -29,9 +30,9 @@ stdenv.mkDerivation rec { meta = { description = "Flexible memory management and garbage collection library"; - homepage = "https://www.ravenbrook.com/project/mps"; - license = lib.licenses.sleepycat; - platforms = lib.platforms.linux; + homepage = "https://www.ravenbrook.com/project/mps"; + license = lib.licenses.sleepycat; + platforms = lib.platforms.linux; maintainers = [ lib.maintainers.thoughtpolice ]; }; } diff --git a/pkgs/by-name/mp/mpv-shim-default-shaders/package.nix b/pkgs/by-name/mp/mpv-shim-default-shaders/package.nix index 7e1dfbae4a4d3d..1c46eae6d6e04e 100644 --- a/pkgs/by-name/mp/mpv-shim-default-shaders/package.nix +++ b/pkgs/by-name/mp/mpv-shim-default-shaders/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "mpv-shim-default-shaders"; diff --git a/pkgs/by-name/mp/mpv-subs-popout/package.nix b/pkgs/by-name/mp/mpv-subs-popout/package.nix index 8da60cb88a2813..a3420eb2e3c9d6 100644 --- a/pkgs/by-name/mp/mpv-subs-popout/package.nix +++ b/pkgs/by-name/mp/mpv-subs-popout/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, wrapGAppsHook3 -, pkg-config -, openssl +{ + lib, + fetchFromGitHub, + rustPlatform, + wrapGAppsHook3, + pkg-config, + openssl, }: rustPlatform.buildRustPackage rec { pname = "mpv-subs-popout"; @@ -18,7 +19,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-vWDrbT1qZVU/N+V24Egq4cAoqysfX1hjQc+D9M5ViEE="; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; buildInputs = [ openssl ]; meta = { diff --git a/pkgs/by-name/mp/mpvc/package.nix b/pkgs/by-name/mp/mpvc/package.nix index 90b5c1d4b5eb8c..d6fb6a45aa3ceb 100644 --- a/pkgs/by-name/mp/mpvc/package.nix +++ b/pkgs/by-name/mp/mpvc/package.nix @@ -22,7 +22,10 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ socat ]; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/mp/mpvpaper/package.nix b/pkgs/by-name/mp/mpvpaper/package.nix index 3ae57ffdaafd67..91d6d33634bd0a 100644 --- a/pkgs/by-name/mp/mpvpaper/package.nix +++ b/pkgs/by-name/mp/mpvpaper/package.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, meson -, ninja -, wayland -, wayland-protocols -, wayland-scanner -, egl-wayland -, glew -, mpv -, pkg-config -, fetchFromGitHub -, makeWrapper -, installShellFiles +{ + stdenv, + lib, + meson, + ninja, + wayland, + wayland-protocols, + wayland-scanner, + egl-wayland, + glew, + mpv, + pkg-config, + fetchFromGitHub, + makeWrapper, + installShellFiles, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mp/mpw/package.nix b/pkgs/by-name/mp/mpw/package.nix index 5900c72bcff320..495b1384b87342 100644 --- a/pkgs/by-name/mp/mpw/package.nix +++ b/pkgs/by-name/mp/mpw/package.nix @@ -1,16 +1,25 @@ -{ lib, stdenv, cmake, fetchFromGitLab -, json_c, libsodium, libxml2, ncurses }: +{ + lib, + stdenv, + cmake, + fetchFromGitLab, + json_c, + libsodium, + libxml2, + ncurses, +}: let rev = "22796663dcad81684ab24308d9db570f6781ba2c"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { name = "mpw-${version}-${builtins.substring 0 8 rev}"; version = "2.6"; src = fetchFromGitLab { - owner = "MasterPassword"; - repo = "MasterPassword"; + owner = "MasterPassword"; + repo = "MasterPassword"; sha256 = "1f2vqacgbyam1mazawrfim8zwp38gnwf5v3xkkficsfnv789g6fw"; inherit rev; }; @@ -31,7 +40,12 @@ in stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ json_c libxml2 libsodium ncurses ]; + buildInputs = [ + json_c + libxml2 + libsodium + ncurses + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/mq/mq-cli/package.nix b/pkgs/by-name/mq/mq-cli/package.nix index 6da2fbefab4b70..1e386761650570 100644 --- a/pkgs/by-name/mq/mq-cli/package.nix +++ b/pkgs/by-name/mq/mq-cli/package.nix @@ -1,24 +1,28 @@ -{ fetchFromGitHub, lib, rustPlatform }: +{ + fetchFromGitHub, + lib, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "mq-cli"; version = "1.0.0"; src = fetchFromGitHub { - owner = "aprilabank"; - repo = "mq-cli"; - rev = "v${version}"; + owner = "aprilabank"; + repo = "mq-cli"; + rev = "v${version}"; sha256 = "02z85waj5jc312biv2qhbgplsggxgjmfmyv9v8b1ky0iq1mpxjw7"; }; cargoHash = "sha256-kZox1QhMPFC5l8mJNxh6C3tiNYMgfmLyWLhkdigEs6Y="; meta = with lib; { - description = "CLI tool to manage POSIX message queues"; - homepage = "https://github.com/aprilabank/mq-cli"; - license = licenses.mit; - maintainers = with maintainers; [ tazjin ]; - platforms = platforms.linux; - mainProgram = "mq"; + description = "CLI tool to manage POSIX message queues"; + homepage = "https://github.com/aprilabank/mq-cli"; + license = licenses.mit; + maintainers = with maintainers; [ tazjin ]; + platforms = platforms.linux; + mainProgram = "mq"; }; } diff --git a/pkgs/by-name/mq/mqtt-benchmark/package.nix b/pkgs/by-name/mq/mqtt-benchmark/package.nix index bc755247c40c0b..72ae68f33b5668 100644 --- a/pkgs/by-name/mq/mqtt-benchmark/package.nix +++ b/pkgs/by-name/mq/mqtt-benchmark/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/mq/mqtt_cpp/package.nix b/pkgs/by-name/mq/mqtt_cpp/package.nix index fca89f8d0f68a3..29e0febea0fdbb 100644 --- a/pkgs/by-name/mq/mqtt_cpp/package.nix +++ b/pkgs/by-name/mq/mqtt_cpp/package.nix @@ -16,15 +16,15 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-E5dMZ0uJ1AOwiGTxD4qhbO72blplmXHh1gTYGE34H+0="; }; - nativeBuildInputs = [cmake]; + nativeBuildInputs = [ cmake ]; - buildInputs = [boost]; + buildInputs = [ boost ]; meta = with lib; { description = "MQTT client/server for C++14 based on Boost.Asio"; homepage = "https://github.com/redboltz/mqtt_cpp"; license = licenses.boost; - maintainers = with maintainers; [spalf]; + maintainers = with maintainers; [ spalf ]; platforms = platforms.unix; }; }) diff --git a/pkgs/by-name/mq/mqttmultimeter/deps.nix b/pkgs/by-name/mq/mqttmultimeter/deps.nix index c43ceb31c3c013..1c9b5d7b5abb90 100644 --- a/pkgs/by-name/mq/mqttmultimeter/deps.nix +++ b/pkgs/by-name/mq/mqttmultimeter/deps.nix @@ -1,121 +1,586 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Avalonia"; version = "11.0.9"; sha256 = "1km9642p9qbx8i14q94h65m96ywr9d54ilv5h0rdsdfidbpbmfhf"; }) - (fetchNuGet { pname = "Avalonia.Angle.Windows.Natives"; version = "2.1.0.2023020321"; sha256 = "1az4s1g22ipak9a3xfh55z2h3rm6lpqh7svbpw6ag4ysrgsjjsjd"; }) - (fetchNuGet { pname = "Avalonia.AvaloniaEdit"; version = "11.0.6"; sha256 = "1vma45sa5falrzmw23jzr3chhi7gllvxgkks379sd48a6p6acv6q"; }) - (fetchNuGet { pname = "Avalonia.BuildServices"; version = "0.0.29"; sha256 = "05mm7f0jssih3gbzqfgjnfq5cnqa85ihsg0z1897ciihv8qd3waq"; }) - (fetchNuGet { pname = "Avalonia.Controls.ColorPicker"; version = "11.0.9"; sha256 = "1ycc7jzlhyvy3ssw8pqb9da8qrv9wxwnffk060w7wbb00m90zjh3"; }) - (fetchNuGet { pname = "Avalonia.Controls.DataGrid"; version = "11.0.9"; sha256 = "1q58z54wl9sk4j17innm885fn776j9f381mhsmd0mzw0ybya3dys"; }) - (fetchNuGet { pname = "Avalonia.Desktop"; version = "11.0.9"; sha256 = "06mcb24grrikjqbgmvrry47hjyz9qcqz6az9lpmjlf9nrsf6h1yc"; }) - (fetchNuGet { pname = "Avalonia.Diagnostics"; version = "11.0.9"; sha256 = "19j6z5zq5k4sfgkak6y0nsq3i98jzyz9y87bw5nf1jbpa4ahv2dn"; }) - (fetchNuGet { pname = "Avalonia.Fonts.Inter"; version = "11.0.9"; sha256 = "1w56gyn5pbvv1j9mm5n9ga8zlfq515nzc6hdqfnsrgaxh6xxkxyb"; }) - (fetchNuGet { pname = "Avalonia.FreeDesktop"; version = "11.0.9"; sha256 = "0ws8gk8rc1h9axn55zm222axal3pbyjmsqvpgihzwfdjafk3qy2w"; }) - (fetchNuGet { pname = "Avalonia.Native"; version = "11.0.9"; sha256 = "0hn6b2b16kiyzjmas9gx874bhn4x3ab114k2ixw32wcl3m61w749"; }) - (fetchNuGet { pname = "Avalonia.ReactiveUI"; version = "11.0.9"; sha256 = "1j6q7djp1jl2j2k6qvfik7gjqjljbkwj1y65zgh93v002xirfmja"; }) - (fetchNuGet { pname = "Avalonia.Remote.Protocol"; version = "11.0.9"; sha256 = "0vxjbrsn2r1jgm12avln2xnlqs0ya593yh341g7qrq9awmaik93h"; }) - (fetchNuGet { pname = "Avalonia.Skia"; version = "11.0.9"; sha256 = "07sjawy0zpmsx0d26kfz7zw2a23z254sdd6psscypidl92cxhy3d"; }) - (fetchNuGet { pname = "Avalonia.Themes.Fluent"; version = "11.0.9"; sha256 = "1ddsyh3bf99swsmb6m7cz1ilvlfqzqs8c1cfscpd9v8cabpgip8g"; }) - (fetchNuGet { pname = "Avalonia.Themes.Simple"; version = "11.0.9"; sha256 = "0q6kxvnrkzpcmby235h372axcy0wv3j9zlq64k1bhg92sh3za9w6"; }) - (fetchNuGet { pname = "Avalonia.Win32"; version = "11.0.9"; sha256 = "143rvsz6hw7fq5fvxflg0w8545gc20kcijd0qc3qilf0hcirn26q"; }) - (fetchNuGet { pname = "Avalonia.X11"; version = "11.0.9"; sha256 = "0yrhmjrxdjymw70dqxpaivq9vvj4lvd16bxc8wm8w3nkw82my8f7"; }) - (fetchNuGet { pname = "AvaloniaEdit.TextMate"; version = "11.0.6"; sha256 = "075qh14h3v89f6vzgjq63p8zvnazfd12p5pzv0zs1l9dm0zmc2pd"; }) - (fetchNuGet { pname = "DynamicData"; version = "7.9.5"; sha256 = "1m9qx8g6na5ka6kd9vhg8gjmxrnkzb6v5cl5yqp1kdjsw4rcwy6x"; }) - (fetchNuGet { pname = "HarfBuzzSharp"; version = "7.3.0"; sha256 = "1rqcmdyzxz9kc0k8594hbpksjc23mkakmjybi4b8702qycxx0lrf"; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Linux"; version = "7.3.0"; sha256 = "0i9gaiyjgmcpnfn1fixbxq8shqlh4ahng7j4dxlf38zlln1f6h80"; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.macOS"; version = "7.3.0"; sha256 = "1b5ng37bwk75cifw7p1hzn8z6sswi8h7h510qgwlbvgmlrs5r0ga"; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; version = "7.3.0"; sha256 = "0dcmclnyryb82wzsky1dn0gbjsvx84mfx46v984f5fmg4v238lpm"; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Win32"; version = "7.3.0"; sha256 = "1hyvmz7rfbrxbcpnwyvb64gdk1hifcpz3rln58yyb7g1pnbpnw2s"; }) - (fetchNuGet { pname = "MessagePack"; version = "2.5.129"; sha256 = "08bpg5v467zyx5ni8pj9x2nkqx3r2vbfdh7v72laii0707163fb2"; }) - (fetchNuGet { pname = "MessagePack.Annotations"; version = "2.5.129"; sha256 = "1q0pprliqr8wrn09k8sa2p9l28q30rk6sl47vlazgwc678f96vg7"; }) - (fetchNuGet { pname = "MicroCom.Runtime"; version = "0.11.0"; sha256 = "0p9c3m0zk59x9dcqw077hzd2yk60myisbacvm36mnwpcjwzjkp2m"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.0.0"; sha256 = "0bbl0jpqywqmzz2gagld1p2gvdfldjfjmm25hil9wj2nq1zc4di8"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "3.8.0"; sha256 = "12n7rvr39bzkf2maw7zplw8rwpxpxss4ich3bb2pw770rx4nyvyw"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "3.8.0"; sha256 = "1kmry65csvfn72zzc16vj1nfbfwam28wcmlrk3m5rzb8ydbzgylb"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.Scripting"; version = "3.8.0"; sha256 = "0w0yx0lpg54iw5jazqk46h48gx43ij32gwac8iywdj6kxfxm03vw"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Scripting.Common"; version = "3.8.0"; sha256 = "0hjgxcsj5zy27lqk0986m59n5dbplx2vjjla2lsvg4bwg8qa7bpk"; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.3.0"; sha256 = "0gw297dgkh0al1zxvgvncqs0j15lsna9l1wpqas4rflmys440xvb"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "7.0.0"; sha256 = "121zs4jp8iimgbpzm3wsglhjwkc06irg1pxy8c1zcdlsg34cfq1p"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "7.0.0"; sha256 = "181d7mp9307fs17lyy42f8cxnjwysddmpsalky4m0pqxcimnr6g7"; }) - (fetchNuGet { pname = "Microsoft.NET.StringTools"; version = "17.6.3"; sha256 = "0g5jdg0jp844a2ygwlm04igsxkrihqcq2rpmfx722nrv3vrk0r0z"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "2.1.2"; sha256 = "1507hnpr9my3z4w1r6xk5n0s1j3y6a2c2cnynj76za7cphxi1141"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; }) - (fetchNuGet { pname = "MQTTnet"; version = "4.3.3.952"; sha256 = "0a6g389vxia2k6lgnhk1x7vgns7da7hlqvj1z0f5av5qfk2377g3"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.3"; sha256 = "0xrwysmrn4midrjal8g2hr1bbg38iyisl0svamb11arqws4w2bw7"; }) - (fetchNuGet { pname = "ReactiveUI"; version = "18.3.1"; sha256 = "1lxkc8yk9glj0w9n5vry2dnwwvh8152ad2c5bivk8aciq64zidyn"; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Extensions"; version = "4.3.0"; sha256 = "0zyri97dfc5vyaz9ba65hjj1zbcrzaffhsdlpxc9bh09wy22fq33"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "16rnxzpk5dpbbl1x354yrlsbvwylrq456xzpsha1n9y3glnhyx9d"; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0hkg03sgm2wyq8nqk6dbm9jh5vcq57ry42lkqdmfklrw89lsmr59"; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0c2p354hjx58xhhz7wv6div8xpi90sc6ibdm40qin21bvi7ymcaa"; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "18pzfdlwsg2nb1jjjjzyb5qlgy6xjxzmhnfaijq5s2jw3cm3ab97"; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0qyynf9nz5i7pc26cwhgi8j62ps27sqmf78ijcfgzab50z9g8ay3"; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "1klrs545awhayryma6l7g2pvnp9xy4z0r1i40r80zb45q3i9nbyf"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0zcxjv5pckplvkg0r6mw3asggm7aqzbdjimhvsasb0cgm59x09l3"; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0vhynn79ih7hw7cwjazn87rm9z9fj0rvxgzlab36jybgcpcgphsn"; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "160p68l2c7cqmyqjwxydcvgw7lvl1cr0znkw8fp24d1by9mqc8p3"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "15zrc8fgd8zx28hdghcj5f5i34wf3l6bq5177075m2bc2j34jrqy"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "1p4dgxax6p7rlgj4q73k73rslcnz4wdcv8q2flg1s8ygwcm58ld5"; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; }) - (fetchNuGet { pname = "SkiaSharp"; version = "2.88.7"; sha256 = "0f6wbk9dnjiffb9ycjachy1m9zw3pai2m503nym07qgb0izxm792"; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Linux"; version = "2.88.7"; sha256 = "0p0z6nxkkmabv46wmxhs3yr0xy24i6jzn54gk0hsm3h1a8vi3m21"; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.macOS"; version = "2.88.7"; sha256 = "05xwa1izzvqz4gznvx2x31qnpvl1lc65hm5p9sscjg5afisya0ss"; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.WebAssembly"; version = "2.88.7"; sha256 = "1k2hfasgbv01navc55zzwdwzfxcw4186jni35c00zykgwhbwb250"; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Win32"; version = "2.88.7"; sha256 = "119mlbh5hmlis7vb111s95dwg5p1anm2hmv7cm6fz7gy18473d7v"; }) - (fetchNuGet { pname = "Splat"; version = "14.4.1"; sha256 = "03ycyjn2ii44npi015p4rk344xnjgdzz02cf63cmhx2ab8hv6p4b"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "5.0.0"; sha256 = "1kvcllagxz2q92g81zkz81djkn2lid25ayjfgjalncyc68i15p0r"; }) - (fetchNuGet { pname = "System.ComponentModel.Annotations"; version = "4.5.0"; sha256 = "1jj6f6g87k0iwsgmg3xmnn67a14mq88np0l1ys5zkxhkvbc8976p"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.3.0"; sha256 = "1d951hrvrpndk7insiag80qxjbf2y0y39y8h5hnq9612ws661glk"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "6.0.0"; sha256 = "08211lvckdsdbd67xz4f6cyk76cli565j0dby1grlc4k9bhwby65"; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.3.0"; sha256 = "0ky2nrcvh70rqq88m9a5yqabsl4fyd17bpr63iy2mbivjs2nyypv"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; sha256 = "1kzrj37yzawf1b19jq0253rcs8hsq1l2q8g69d7ipnhzb0h97m59"; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.3.0"; sha256 = "191p63zy5rpqx7dnrb3h7prvgixmk168fhvvkkvhlazncf8r3nc2"; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; }) - (fetchNuGet { pname = "System.Reactive"; version = "5.0.0"; sha256 = "1lafmpnadhiwxyd543kraxa3jfdpm6ipblxrjlibym9b1ykpr5ik"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.3.0"; sha256 = "11f8y3qfysfcrscjpjym9msk7lsfxkk4fmz9qq95kn3jd0769f74"; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.3.0"; sha256 = "0w1n67glpv8241vnpz1kl14sy7zlnw414aqwj4hcx5nd86f6994q"; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.3.0"; sha256 = "0ql7lcakycrvzgi9kxz1b3lljd990az1x6c4jsiwcacrvimpib5c"; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.3.0"; sha256 = "02bly8bdc98gs22lqsfx9xicblszr2yan7v2mmw3g7hy6miq5hwq"; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "5.0.0"; sha256 = "17qsl5nanlqk9iz0l5wijdn6ka632fs1m1fvx18dfgswm258r3ss"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.3.0"; sha256 = "0y2ssg08d817p0vdag98vn238gyrrynjdj4181hdg780sif3ykp1"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.7.1"; sha256 = "119br3pd85lq8zcgh4f60jzmv1g976q1kdgi3hvqdlhfbw6siz2j"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "4.5.1"; sha256 = "1z21qyfs6sg76rp68qdx0c9iy57naan89pg7p6i3qpj8kyzn921w"; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "7.0.0"; sha256 = "1151hbyrcf8kyg1jz8k9awpbic98lwz9x129rg7zk1wrs6vjlpxl"; }) - (fetchNuGet { pname = "System.Text.Json"; version = "7.0.0"; sha256 = "0scb0lp7wbgcinaa4kqiqs7b8i5nx4ppfad81138jiwd1sl37pyp"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; sha256 = "0y6ncasgfcgnjrhynaf0lwpkpkmv4a07sswwkwbwb5h7riisj153"; }) - (fetchNuGet { pname = "TextMateSharp"; version = "1.0.56"; sha256 = "1nb0rlcgrdp05h952gwbbqp2kwgdvni7jmswdh263n4xnnvhmzdr"; }) - (fetchNuGet { pname = "TextMateSharp.Grammars"; version = "1.0.56"; sha256 = "1jzvhwx13dyg7iirk2c1m8h0dca8b0pki4yh0r8r89y4c1ighx98"; }) - (fetchNuGet { pname = "Tmds.DBus.Protocol"; version = "0.15.0"; sha256 = "0d99kcs7r9cp6gpyc7z230czkkyx4164x86dhy0mca73f2ykc2g2"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Avalonia"; + version = "11.0.9"; + sha256 = "1km9642p9qbx8i14q94h65m96ywr9d54ilv5h0rdsdfidbpbmfhf"; + }) + (fetchNuGet { + pname = "Avalonia.Angle.Windows.Natives"; + version = "2.1.0.2023020321"; + sha256 = "1az4s1g22ipak9a3xfh55z2h3rm6lpqh7svbpw6ag4ysrgsjjsjd"; + }) + (fetchNuGet { + pname = "Avalonia.AvaloniaEdit"; + version = "11.0.6"; + sha256 = "1vma45sa5falrzmw23jzr3chhi7gllvxgkks379sd48a6p6acv6q"; + }) + (fetchNuGet { + pname = "Avalonia.BuildServices"; + version = "0.0.29"; + sha256 = "05mm7f0jssih3gbzqfgjnfq5cnqa85ihsg0z1897ciihv8qd3waq"; + }) + (fetchNuGet { + pname = "Avalonia.Controls.ColorPicker"; + version = "11.0.9"; + sha256 = "1ycc7jzlhyvy3ssw8pqb9da8qrv9wxwnffk060w7wbb00m90zjh3"; + }) + (fetchNuGet { + pname = "Avalonia.Controls.DataGrid"; + version = "11.0.9"; + sha256 = "1q58z54wl9sk4j17innm885fn776j9f381mhsmd0mzw0ybya3dys"; + }) + (fetchNuGet { + pname = "Avalonia.Desktop"; + version = "11.0.9"; + sha256 = "06mcb24grrikjqbgmvrry47hjyz9qcqz6az9lpmjlf9nrsf6h1yc"; + }) + (fetchNuGet { + pname = "Avalonia.Diagnostics"; + version = "11.0.9"; + sha256 = "19j6z5zq5k4sfgkak6y0nsq3i98jzyz9y87bw5nf1jbpa4ahv2dn"; + }) + (fetchNuGet { + pname = "Avalonia.Fonts.Inter"; + version = "11.0.9"; + sha256 = "1w56gyn5pbvv1j9mm5n9ga8zlfq515nzc6hdqfnsrgaxh6xxkxyb"; + }) + (fetchNuGet { + pname = "Avalonia.FreeDesktop"; + version = "11.0.9"; + sha256 = "0ws8gk8rc1h9axn55zm222axal3pbyjmsqvpgihzwfdjafk3qy2w"; + }) + (fetchNuGet { + pname = "Avalonia.Native"; + version = "11.0.9"; + sha256 = "0hn6b2b16kiyzjmas9gx874bhn4x3ab114k2ixw32wcl3m61w749"; + }) + (fetchNuGet { + pname = "Avalonia.ReactiveUI"; + version = "11.0.9"; + sha256 = "1j6q7djp1jl2j2k6qvfik7gjqjljbkwj1y65zgh93v002xirfmja"; + }) + (fetchNuGet { + pname = "Avalonia.Remote.Protocol"; + version = "11.0.9"; + sha256 = "0vxjbrsn2r1jgm12avln2xnlqs0ya593yh341g7qrq9awmaik93h"; + }) + (fetchNuGet { + pname = "Avalonia.Skia"; + version = "11.0.9"; + sha256 = "07sjawy0zpmsx0d26kfz7zw2a23z254sdd6psscypidl92cxhy3d"; + }) + (fetchNuGet { + pname = "Avalonia.Themes.Fluent"; + version = "11.0.9"; + sha256 = "1ddsyh3bf99swsmb6m7cz1ilvlfqzqs8c1cfscpd9v8cabpgip8g"; + }) + (fetchNuGet { + pname = "Avalonia.Themes.Simple"; + version = "11.0.9"; + sha256 = "0q6kxvnrkzpcmby235h372axcy0wv3j9zlq64k1bhg92sh3za9w6"; + }) + (fetchNuGet { + pname = "Avalonia.Win32"; + version = "11.0.9"; + sha256 = "143rvsz6hw7fq5fvxflg0w8545gc20kcijd0qc3qilf0hcirn26q"; + }) + (fetchNuGet { + pname = "Avalonia.X11"; + version = "11.0.9"; + sha256 = "0yrhmjrxdjymw70dqxpaivq9vvj4lvd16bxc8wm8w3nkw82my8f7"; + }) + (fetchNuGet { + pname = "AvaloniaEdit.TextMate"; + version = "11.0.6"; + sha256 = "075qh14h3v89f6vzgjq63p8zvnazfd12p5pzv0zs1l9dm0zmc2pd"; + }) + (fetchNuGet { + pname = "DynamicData"; + version = "7.9.5"; + sha256 = "1m9qx8g6na5ka6kd9vhg8gjmxrnkzb6v5cl5yqp1kdjsw4rcwy6x"; + }) + (fetchNuGet { + pname = "HarfBuzzSharp"; + version = "7.3.0"; + sha256 = "1rqcmdyzxz9kc0k8594hbpksjc23mkakmjybi4b8702qycxx0lrf"; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Linux"; + version = "7.3.0"; + sha256 = "0i9gaiyjgmcpnfn1fixbxq8shqlh4ahng7j4dxlf38zlln1f6h80"; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.macOS"; + version = "7.3.0"; + sha256 = "1b5ng37bwk75cifw7p1hzn8z6sswi8h7h510qgwlbvgmlrs5r0ga"; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; + version = "7.3.0"; + sha256 = "0dcmclnyryb82wzsky1dn0gbjsvx84mfx46v984f5fmg4v238lpm"; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Win32"; + version = "7.3.0"; + sha256 = "1hyvmz7rfbrxbcpnwyvb64gdk1hifcpz3rln58yyb7g1pnbpnw2s"; + }) + (fetchNuGet { + pname = "MessagePack"; + version = "2.5.129"; + sha256 = "08bpg5v467zyx5ni8pj9x2nkqx3r2vbfdh7v72laii0707163fb2"; + }) + (fetchNuGet { + pname = "MessagePack.Annotations"; + version = "2.5.129"; + sha256 = "1q0pprliqr8wrn09k8sa2p9l28q30rk6sl47vlazgwc678f96vg7"; + }) + (fetchNuGet { + pname = "MicroCom.Runtime"; + version = "0.11.0"; + sha256 = "0p9c3m0zk59x9dcqw077hzd2yk60myisbacvm36mnwpcjwzjkp2m"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.0.0"; + sha256 = "0bbl0jpqywqmzz2gagld1p2gvdfldjfjmm25hil9wj2nq1zc4di8"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "3.8.0"; + sha256 = "12n7rvr39bzkf2maw7zplw8rwpxpxss4ich3bb2pw770rx4nyvyw"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "3.8.0"; + sha256 = "1kmry65csvfn72zzc16vj1nfbfwam28wcmlrk3m5rzb8ydbzgylb"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.Scripting"; + version = "3.8.0"; + sha256 = "0w0yx0lpg54iw5jazqk46h48gx43ij32gwac8iywdj6kxfxm03vw"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Scripting.Common"; + version = "3.8.0"; + sha256 = "0hjgxcsj5zy27lqk0986m59n5dbplx2vjjla2lsvg4bwg8qa7bpk"; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.3.0"; + sha256 = "0gw297dgkh0al1zxvgvncqs0j15lsna9l1wpqas4rflmys440xvb"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "7.0.0"; + sha256 = "121zs4jp8iimgbpzm3wsglhjwkc06irg1pxy8c1zcdlsg34cfq1p"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "7.0.0"; + sha256 = "181d7mp9307fs17lyy42f8cxnjwysddmpsalky4m0pqxcimnr6g7"; + }) + (fetchNuGet { + pname = "Microsoft.NET.StringTools"; + version = "17.6.3"; + sha256 = "0g5jdg0jp844a2ygwlm04igsxkrihqcq2rpmfx722nrv3vrk0r0z"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "2.1.2"; + sha256 = "1507hnpr9my3z4w1r6xk5n0s1j3y6a2c2cnynj76za7cphxi1141"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; + }) + (fetchNuGet { + pname = "MQTTnet"; + version = "4.3.3.952"; + sha256 = "0a6g389vxia2k6lgnhk1x7vgns7da7hlqvj1z0f5av5qfk2377g3"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.3"; + sha256 = "0xrwysmrn4midrjal8g2hr1bbg38iyisl0svamb11arqws4w2bw7"; + }) + (fetchNuGet { + pname = "ReactiveUI"; + version = "18.3.1"; + sha256 = "1lxkc8yk9glj0w9n5vry2dnwwvh8152ad2c5bivk8aciq64zidyn"; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Extensions"; + version = "4.3.0"; + sha256 = "0zyri97dfc5vyaz9ba65hjj1zbcrzaffhsdlpxc9bh09wy22fq33"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "16rnxzpk5dpbbl1x354yrlsbvwylrq456xzpsha1n9y3glnhyx9d"; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0hkg03sgm2wyq8nqk6dbm9jh5vcq57ry42lkqdmfklrw89lsmr59"; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0c2p354hjx58xhhz7wv6div8xpi90sc6ibdm40qin21bvi7ymcaa"; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "18pzfdlwsg2nb1jjjjzyb5qlgy6xjxzmhnfaijq5s2jw3cm3ab97"; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0qyynf9nz5i7pc26cwhgi8j62ps27sqmf78ijcfgzab50z9g8ay3"; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "1klrs545awhayryma6l7g2pvnp9xy4z0r1i40r80zb45q3i9nbyf"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0zcxjv5pckplvkg0r6mw3asggm7aqzbdjimhvsasb0cgm59x09l3"; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0vhynn79ih7hw7cwjazn87rm9z9fj0rvxgzlab36jybgcpcgphsn"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "160p68l2c7cqmyqjwxydcvgw7lvl1cr0znkw8fp24d1by9mqc8p3"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "15zrc8fgd8zx28hdghcj5f5i34wf3l6bq5177075m2bc2j34jrqy"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "1p4dgxax6p7rlgj4q73k73rslcnz4wdcv8q2flg1s8ygwcm58ld5"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; + }) + (fetchNuGet { + pname = "SkiaSharp"; + version = "2.88.7"; + sha256 = "0f6wbk9dnjiffb9ycjachy1m9zw3pai2m503nym07qgb0izxm792"; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Linux"; + version = "2.88.7"; + sha256 = "0p0z6nxkkmabv46wmxhs3yr0xy24i6jzn54gk0hsm3h1a8vi3m21"; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.macOS"; + version = "2.88.7"; + sha256 = "05xwa1izzvqz4gznvx2x31qnpvl1lc65hm5p9sscjg5afisya0ss"; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.WebAssembly"; + version = "2.88.7"; + sha256 = "1k2hfasgbv01navc55zzwdwzfxcw4186jni35c00zykgwhbwb250"; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Win32"; + version = "2.88.7"; + sha256 = "119mlbh5hmlis7vb111s95dwg5p1anm2hmv7cm6fz7gy18473d7v"; + }) + (fetchNuGet { + pname = "Splat"; + version = "14.4.1"; + sha256 = "03ycyjn2ii44npi015p4rk344xnjgdzz02cf63cmhx2ab8hv6p4b"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "5.0.0"; + sha256 = "1kvcllagxz2q92g81zkz81djkn2lid25ayjfgjalncyc68i15p0r"; + }) + (fetchNuGet { + pname = "System.ComponentModel.Annotations"; + version = "4.5.0"; + sha256 = "1jj6f6g87k0iwsgmg3xmnn67a14mq88np0l1ys5zkxhkvbc8976p"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.3.0"; + sha256 = "1d951hrvrpndk7insiag80qxjbf2y0y39y8h5hnq9612ws661glk"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "6.0.0"; + sha256 = "08211lvckdsdbd67xz4f6cyk76cli565j0dby1grlc4k9bhwby65"; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.3.0"; + sha256 = "0ky2nrcvh70rqq88m9a5yqabsl4fyd17bpr63iy2mbivjs2nyypv"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + sha256 = "1kzrj37yzawf1b19jq0253rcs8hsq1l2q8g69d7ipnhzb0h97m59"; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.3.0"; + sha256 = "191p63zy5rpqx7dnrb3h7prvgixmk168fhvvkkvhlazncf8r3nc2"; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; + }) + (fetchNuGet { + pname = "System.Reactive"; + version = "5.0.0"; + sha256 = "1lafmpnadhiwxyd543kraxa3jfdpm6ipblxrjlibym9b1ykpr5ik"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.3.0"; + sha256 = "11f8y3qfysfcrscjpjym9msk7lsfxkk4fmz9qq95kn3jd0769f74"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.3.0"; + sha256 = "0w1n67glpv8241vnpz1kl14sy7zlnw414aqwj4hcx5nd86f6994q"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.3.0"; + sha256 = "0ql7lcakycrvzgi9kxz1b3lljd990az1x6c4jsiwcacrvimpib5c"; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.3.0"; + sha256 = "02bly8bdc98gs22lqsfx9xicblszr2yan7v2mmw3g7hy6miq5hwq"; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "5.0.0"; + sha256 = "17qsl5nanlqk9iz0l5wijdn6ka632fs1m1fvx18dfgswm258r3ss"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.3.0"; + sha256 = "0y2ssg08d817p0vdag98vn238gyrrynjdj4181hdg780sif3ykp1"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.7.1"; + sha256 = "119br3pd85lq8zcgh4f60jzmv1g976q1kdgi3hvqdlhfbw6siz2j"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "4.5.1"; + sha256 = "1z21qyfs6sg76rp68qdx0c9iy57naan89pg7p6i3qpj8kyzn921w"; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "7.0.0"; + sha256 = "1151hbyrcf8kyg1jz8k9awpbic98lwz9x129rg7zk1wrs6vjlpxl"; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "7.0.0"; + sha256 = "0scb0lp7wbgcinaa4kqiqs7b8i5nx4ppfad81138jiwd1sl37pyp"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + sha256 = "0y6ncasgfcgnjrhynaf0lwpkpkmv4a07sswwkwbwb5h7riisj153"; + }) + (fetchNuGet { + pname = "TextMateSharp"; + version = "1.0.56"; + sha256 = "1nb0rlcgrdp05h952gwbbqp2kwgdvni7jmswdh263n4xnnvhmzdr"; + }) + (fetchNuGet { + pname = "TextMateSharp.Grammars"; + version = "1.0.56"; + sha256 = "1jzvhwx13dyg7iirk2c1m8h0dca8b0pki4yh0r8r89y4c1ighx98"; + }) + (fetchNuGet { + pname = "Tmds.DBus.Protocol"; + version = "0.15.0"; + sha256 = "0d99kcs7r9cp6gpyc7z230czkkyx4164x86dhy0mca73f2ykc2g2"; + }) ] diff --git a/pkgs/by-name/mq/mqttmultimeter/package.nix b/pkgs/by-name/mq/mqttmultimeter/package.nix index 191bc642d7c71c..411057bfe8c0a8 100644 --- a/pkgs/by-name/mq/mqttmultimeter/package.nix +++ b/pkgs/by-name/mq/mqttmultimeter/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, dotnetCorePackages -, dotnet-runtime_8 -, buildDotnetModule -, fetchFromGitHub -, libglvnd -, makeDesktopItem -, copyDesktopItems +{ + lib, + stdenv, + dotnetCorePackages, + dotnet-runtime_8, + buildDotnetModule, + fetchFromGitHub, + libglvnd, + makeDesktopItem, + copyDesktopItems, }: buildDotnetModule rec { diff --git a/pkgs/by-name/mq/mqttx/package.nix b/pkgs/by-name/mq/mqttx/package.nix index 1e36ad57ab41e5..838d8aedf3748b 100644 --- a/pkgs/by-name/mq/mqttx/package.nix +++ b/pkgs/by-name/mq/mqttx/package.nix @@ -1,15 +1,18 @@ -{ lib -, stdenv -, fetchurl -, appimageTools -, imagemagick +{ + lib, + stdenv, + fetchurl, + appimageTools, + imagemagick, }: let pname = "mqttx"; version = "1.10.1"; - suffixedUrl = suffix: "https://github.com/emqx/MQTTX/releases/download/v${version}/MQTTX-${version}${suffix}.AppImage"; + suffixedUrl = + suffix: + "https://github.com/emqx/MQTTX/releases/download/v${version}/MQTTX-${version}${suffix}.AppImage"; sources = { "aarch64-linux" = fetchurl { url = suffixedUrl "-arm64"; @@ -21,8 +24,9 @@ let }; }; - src = sources.${stdenv.hostPlatform.system} - or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + sources.${stdenv.hostPlatform.system} + or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); appimageContents = appimageTools.extractType2 { inherit pname version src; diff --git a/pkgs/by-name/mr/mr/package.nix b/pkgs/by-name/mr/mr/package.nix index 4ff6c6733e6f26..1f053b243e8281 100644 --- a/pkgs/by-name/mr/mr/package.nix +++ b/pkgs/by-name/mr/mr/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchgit, perl }: +{ + lib, + stdenv, + fetchgit, + perl, +}: stdenv.mkDerivation { pname = "mr"; diff --git a/pkgs/by-name/mr/mrbayes/package.nix b/pkgs/by-name/mr/mrbayes/package.nix index 88b402712016bd..b8c899d0bd3efe 100644 --- a/pkgs/by-name/mr/mrbayes/package.nix +++ b/pkgs/by-name/mr/mrbayes/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "mrbayes"; diff --git a/pkgs/by-name/mr/mrkd/package.nix b/pkgs/by-name/mr/mrkd/package.nix index 1c223861b4869d..8193766f02f117 100644 --- a/pkgs/by-name/mr/mrkd/package.nix +++ b/pkgs/by-name/mr/mrkd/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: let @@ -23,7 +24,8 @@ let }); }; }; -in python.pkgs.buildPythonApplication rec { +in +python.pkgs.buildPythonApplication rec { pname = "mrkd"; version = "0.2.0"; diff --git a/pkgs/by-name/mr/mro-unicode/package.nix b/pkgs/by-name/mr/mro-unicode/package.nix index 9a522c1c2a3627..8c613e11e84c60 100644 --- a/pkgs/by-name/mr/mro-unicode/package.nix +++ b/pkgs/by-name/mr/mro-unicode/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation { pname = "mro-unicode"; diff --git a/pkgs/by-name/mr/mrpeach/package.nix b/pkgs/by-name/mr/mrpeach/package.nix index e11c5cd00a186c..2fa63b5da8ad61 100644 --- a/pkgs/by-name/mr/mrpeach/package.nix +++ b/pkgs/by-name/mr/mrpeach/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, puredata }: +{ + lib, + stdenv, + fetchurl, + puredata, +}: stdenv.mkDerivation { pname = "mrpeach"; diff --git a/pkgs/by-name/mr/mrsh/package.nix b/pkgs/by-name/mr/mrsh/package.nix index bff6956e97bd14..b8363b117b142b 100644 --- a/pkgs/by-name/mr/mrsh/package.nix +++ b/pkgs/by-name/mr/mrsh/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, pkg-config, readline }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + readline, +}: stdenv.mkDerivation rec { pname = "mrsh-unstable"; @@ -12,7 +20,11 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; buildInputs = [ readline ]; doCheck = true; diff --git a/pkgs/by-name/mr/mrtg/package.nix b/pkgs/by-name/mr/mrtg/package.nix index 69219010ac20d9..9c5e89f7bd74b2 100644 --- a/pkgs/by-name/mr/mrtg/package.nix +++ b/pkgs/by-name/mr/mrtg/package.nix @@ -1,10 +1,19 @@ -{ lib, stdenv, fetchurl, perl, gd, rrdtool }: +{ + lib, + stdenv, + fetchurl, + perl, + gd, + rrdtool, +}: let - perlWithPkgs = perl.withPackages (pp: with pp;[ - Socket6 - IOSocketINET6 - ]); + perlWithPkgs = perl.withPackages ( + pp: with pp; [ + Socket6 + IOSocketINET6 + ] + ); in stdenv.mkDerivation rec { pname = "mrtg"; diff --git a/pkgs/by-name/mr/mruby/package.nix b/pkgs/by-name/mr/mruby/package.nix index 0fc1af2d6676d7..c0d78848697a16 100644 --- a/pkgs/by-name/mr/mruby/package.nix +++ b/pkgs/by-name/mr/mruby/package.nix @@ -1,14 +1,21 @@ -{ lib, stdenv, ruby, rake, fetchFromGitHub, testers }: +{ + lib, + stdenv, + ruby, + rake, + fetchFromGitHub, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "mruby"; version = "3.3.0"; src = fetchFromGitHub { - owner = "mruby"; - repo = "mruby"; - rev = finalAttrs.version; - sha256 = "sha256-rCoEC1ioX6bOocPoPi+Lsn4PM8gY0DjKja1/MJvJ1n8="; + owner = "mruby"; + repo = "mruby"; + rev = finalAttrs.version; + sha256 = "sha256-rCoEC1ioX6bOocPoPi+Lsn4PM8gY0DjKja1/MJvJ1n8="; }; nativeBuildInputs = [ rake ]; diff --git a/pkgs/by-name/mr/mrxvt/package.nix b/pkgs/by-name/mr/mrxvt/package.nix index 83bac2343b97f0..39ee43c80f9c9e 100644 --- a/pkgs/by-name/mr/mrxvt/package.nix +++ b/pkgs/by-name/mr/mrxvt/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, libX11 -, libXft -, libXi -, xorgproto -, libSM -, libICE -, freetype -, pkg-config -, which -, nixosTests +{ + lib, + stdenv, + fetchurl, + libX11, + libXft, + libXi, + xorgproto, + libSM, + libICE, + freetype, + pkg-config, + which, + nixosTests, }: stdenv.mkDerivation rec { @@ -23,7 +24,16 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libX11 libXft libXi xorgproto libSM libICE freetype which ]; + buildInputs = [ + libX11 + libXft + libXi + xorgproto + libSM + libICE + freetype + which + ]; configureFlags = [ "--with-x" diff --git a/pkgs/by-name/ms/ms-sys/package.nix b/pkgs/by-name/ms/ms-sys/package.nix index 203654f3e6b760..482f7602a40d32 100644 --- a/pkgs/by-name/ms/ms-sys/package.nix +++ b/pkgs/by-name/ms/ms-sys/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gettext }: +{ + lib, + stdenv, + fetchurl, + gettext, +}: stdenv.mkDerivation rec { pname = "ms-sys"; diff --git a/pkgs/by-name/ms/msalsdk-dbusclient/package.nix b/pkgs/by-name/ms/msalsdk-dbusclient/package.nix index 5fd09f0035f8db..c38bbf685b4189 100644 --- a/pkgs/by-name/ms/msalsdk-dbusclient/package.nix +++ b/pkgs/by-name/ms/msalsdk-dbusclient/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchurl -, dpkg -, sdbus-cpp +{ + stdenv, + lib, + fetchurl, + dpkg, + sdbus-cpp, }: stdenv.mkDerivation rec { pname = "msalsdk-dbusclient"; @@ -20,7 +21,12 @@ stdenv.mkDerivation rec { mkdir -p $out/lib install -m 755 usr/lib/libmsal_dbus_client.so $out/lib/ - patchelf --set-rpath ${lib.makeLibraryPath [ stdenv.cc.cc sdbus-cpp ]} $out/lib/libmsal_dbus_client.so + patchelf --set-rpath ${ + lib.makeLibraryPath [ + stdenv.cc.cc + sdbus-cpp + ] + } $out/lib/libmsal_dbus_client.so runHook postInstall ''; diff --git a/pkgs/by-name/ms/msat/package.nix b/pkgs/by-name/ms/msat/package.nix index 3c27493baff874..dad2277800576a 100644 --- a/pkgs/by-name/ms/msat/package.nix +++ b/pkgs/by-name/ms/msat/package.nix @@ -1,11 +1,16 @@ { ocamlPackages }: -with ocamlPackages; buildDunePackage { +with ocamlPackages; +buildDunePackage { pname = "msat-bin"; inherit (msat) version src; - buildInputs = [ camlzip containers msat ]; + buildInputs = [ + camlzip + containers + msat + ]; meta = msat.meta // { description = "SAT solver binary based on the msat library"; diff --git a/pkgs/by-name/ms/msbuild/deps.nix b/pkgs/by-name/ms/msbuild/deps.nix index e7d1d362a1c55c..d5838fbeb4b55d 100644 --- a/pkgs/by-name/ms/msbuild/deps.nix +++ b/pkgs/by-name/ms/msbuild/deps.nix @@ -1,235 +1,1386 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "BenchmarkDotNet"; version = "0.12.1"; hash = "sha256-vISVlxTg4nhyRd1Jw+EwzGK7jabO+dQYnBScDVRAE3I="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/benchmarkdotnet/0.12.1/benchmarkdotnet.0.12.1.nupkg"; }) - (fetchNuGet { pname = "BenchmarkDotNet.Annotations"; version = "0.12.1"; hash = "sha256-g1M3JNIgAsL1g7oEISRf5mMsYkO2uJfWBkglc9tHOxg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/benchmarkdotnet.annotations/0.12.1/benchmarkdotnet.annotations.0.12.1.nupkg"; }) - (fetchNuGet { pname = "CommandLineParser"; version = "2.4.3"; hash = "sha256-pTyYP26uXXLe6ejCb/yVYpb23ad/Dkl2Ka8NWwQeiqk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/commandlineparser/2.4.3/commandlineparser.2.4.3.nupkg"; }) - (fetchNuGet { pname = "FSharp.NET.Sdk"; version = "1.0.4-bundled-0100"; hash = "sha256-6FC2zLqwF0bydu8d2uiH1McIy0af/NrZ//hf4xdvHho="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/fsharp.net.sdk/1.0.4-bundled-0100/fsharp.net.sdk.1.0.4-bundled-0100.nupkg"; }) - (fetchNuGet { pname = "Iced"; version = "1.4.0"; hash = "sha256-yQ7xTIeuZCo5WotGbkWuw7/hyAf/6sukdtuURRkQFNE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/iced/1.4.0/iced.1.4.0.nupkg"; }) - (fetchNuGet { pname = "ILLink.Tasks"; version = "0.1.6-prerelease.20175.2"; hash = "sha256-/yDCjUVz3RstltoUDOcYEwNyGeLWAviiG7YUURGZjmg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/7d9f5c21-0d79-403f-bfe3-9a4506529760/nuget/v3/flat2/illink.tasks/0.1.6-prerelease.20175.2/illink.tasks.0.1.6-prerelease.20175.2.nupkg"; }) - (fetchNuGet { pname = "jnm2.ReferenceAssemblies.net35"; version = "1.0.1"; hash = "sha256-7Kgh/lQW1wxa76vecVxmG/8JNBvMz766lxazyL+mt4E="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/jnm2.referenceassemblies.net35/1.0.1/jnm2.referenceassemblies.net35.1.0.1.nupkg"; }) - (fetchNuGet { pname = "LargeAddressAware"; version = "1.0.5"; hash = "sha256-IQnTkOHBsic3HDa7TwfQtwwbowHG/iWQd6tkPuqAUkM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/largeaddressaware/1.0.5/largeaddressaware.1.0.5.nupkg"; }) - (fetchNuGet { pname = "MicroBuild.Core"; version = "0.2.0"; hash = "sha256-JIVBO1hWtK955RmtghoXqn6S9rb2G69Id92vqWUhmmA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microbuild.core/0.2.0/microbuild.core.0.2.0.nupkg"; }) - (fetchNuGet { pname = "MicroBuild.Core.Sentinel"; version = "1.0.0"; hash = "sha256-Efk2JFokIgDHw8G3sSsBs2990adCCItAoPiq6UrHsww="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microbuild.core.sentinel/1.0.0/microbuild.core.sentinel.1.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "1.1.0"; hash = "sha256-QYVojfqSZKbF8P6D/aacfxfumMaRUD9SEEQbzw73Bbc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.bcl.asyncinterfaces/1.1.0/microsoft.bcl.asyncinterfaces.1.1.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build"; version = "14.3.0"; hash = "sha256-P4NszYl1VU6+2hWB64Y7Jy1mw/HA0kul5iD2ju6wVf0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build/14.3.0/microsoft.build.14.3.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.CentralPackageVersions"; version = "2.0.1"; hash = "sha256-sxSrG4+xzZVP2YtJYYCpHGa0pCAPmZCQRhilJaSKkp0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.centralpackageversions/2.0.1/microsoft.build.centralpackageversions.2.0.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Framework"; version = "14.3.0"; hash = "sha256-zSmVu5u/oec5XVHsbwviR5joITIC5uZGWXfk1U4M/mQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.framework/14.3.0/microsoft.build.framework.14.3.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Framework"; version = "15.5.180"; hash = "sha256-XyTJ3tn+vOc5rH4Pux1MjswRia6ei5bqTX3GEI4anhg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.framework/15.5.180/microsoft.build.framework.15.5.180.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.NuGetSdkResolver"; version = "5.9.1-rc.8"; hash = "sha256-DaH2rPBY32UWK1M2odPiRVF/NnmrrnvBtxTnI6ia/bU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.build.nugetsdkresolver/5.9.1-rc.8/microsoft.build.nugetsdkresolver.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Tasks.Git"; version = "1.1.0-beta-20206-02"; hash = "sha256-nbFnPIifuevbeOCkPuCirofjqDLi+CnxYUXvSfGGlL8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.build.tasks.git/1.1.0-beta-20206-02/microsoft.build.tasks.git.1.1.0-beta-20206-02.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Utilities.Core"; version = "14.3.0"; hash = "sha256-awZNRydsILpI8xtA/zI8WbHTDuQcq220nt+K0K22oQw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.utilities.core/14.3.0/microsoft.build.utilities.core.14.3.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Utilities.Core"; version = "15.5.180"; hash = "sha256-YJiW2bLfrkOFvQ8toWDGyPodrmjlIkshWyixhxWUizA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.utilities.core/15.5.180/microsoft.build.utilities.core.15.5.180.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "2.6.1"; hash = "sha256-1+FV3KvwerZsknecHZhdDACsPKaWrbQQeN27BAcZk94="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.analyzers/2.6.1/microsoft.codeanalysis.analyzers.2.6.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Build.Tasks"; version = "3.9.0-5.21112.8"; hash = "sha256-h1UrpcVKxFQkmX4bHrsZGlJ2wB5X+dwREtiHu++sm6M="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.build.tasks/3.9.0-5.21112.8/microsoft.codeanalysis.build.tasks.3.9.0-5.21112.8.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "2.10.0"; hash = "sha256-UikMFW/dcSiKfsUqnn2hvguLJN7gw1e01WpWmHEHydA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.common/2.10.0/microsoft.codeanalysis.common.2.10.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "2.10.0"; hash = "sha256-szdSweIavn5BBPZgM8uE4j1WrvTfMqF/4yqzgLJeSmk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.csharp/2.10.0/microsoft.codeanalysis.csharp.2.10.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeCoverage"; version = "16.6.1"; hash = "sha256-NI+9eizIs3mrCNAw058DZvRzxpCAdoL3SKth6iypzgU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codecoverage/16.6.1/microsoft.codecoverage.16.6.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.NETCore.Client"; version = "0.2.61701"; hash = "sha256-ITNO2LJYyWhYs3A/iqfoaW6ddvkuuBVXQ5YSKQ8wgcU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.diagnostics.netcore.client/0.2.61701/microsoft.diagnostics.netcore.client.0.2.61701.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.Runtime"; version = "1.1.57604"; hash = "sha256-Ubu6a+qKwstY6v7Oywg1izAwgLZOnvv5ZjcmOJ5+qb4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.diagnostics.runtime/1.1.57604/microsoft.diagnostics.runtime.1.1.57604.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.Tracing.TraceEvent"; version = "2.0.49"; hash = "sha256-SUkXJTeA+Ctk+MlxY5QAThL6d+mBIz+gKJ0RlShKnCM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.diagnostics.tracing.traceevent/2.0.49/microsoft.diagnostics.tracing.traceevent.2.0.49.nupkg"; }) - (fetchNuGet { pname = "Microsoft.DotNet.Arcade.Sdk"; version = "5.0.0-beta.21226.1"; hash = "sha256-g0R3wc9SZryUvgu5fB5WwyLEcQsPYbrqa4qylNpn97Q="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.dotnet.arcade.sdk/5.0.0-beta.21226.1/microsoft.dotnet.arcade.sdk.5.0.0-beta.21226.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.DotNet.MSBuildSdkResolver"; version = "5.0.300-servicing.21267.11"; hash = "sha256-5S7nvtosI97MPWxHaxBManc70Dp1e9Ycbta9C6cS78k="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a8a526e9-91b3-4569-ba2d-ff08dbb7c110/nuget/v3/flat2/microsoft.dotnet.msbuildsdkresolver/5.0.300-servicing.21267.11/microsoft.dotnet.msbuildsdkresolver.5.0.300-servicing.21267.11.nupkg"; }) - (fetchNuGet { pname = "Microsoft.DotNet.PlatformAbstractions"; version = "2.1.0"; hash = "sha256-vrZhYp94SjycUMGaVYCFWJ4p7KBKfqVyLWtIG73fzeM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.dotnet.platformabstractions/2.1.0/microsoft.dotnet.platformabstractions.2.1.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.DotNet.SignTool"; version = "5.0.0-beta.21226.1"; hash = "sha256-cr0QbHmpSj7zhg3y0bMudugkInppcdSlDTHFYRExo8k="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.dotnet.signtool/5.0.0-beta.21226.1/microsoft.dotnet.signtool.5.0.0-beta.21226.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NET.Build.Extensions"; version = "3.1.400-preview.20365.20"; hash = "sha256-pUGvWPLzNQEIDhdCbkv+qnU1e9QS477moiFree6RrO4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d5f6139d-6136-4228-8b2d-9676e9e4eb3d/nuget/v3/flat2/microsoft.net.build.extensions/3.1.400-preview.20365.20/microsoft.net.build.extensions.3.1.400-preview.20365.20.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Net.Compilers.Toolset"; version = "3.9.0-5.21112.8"; hash = "sha256-MDxQi3QVFfvA5bcOblCm/ypHSe6WqpGb0ZD65NXrLLc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.net.compilers.toolset/3.9.0-5.21112.8/microsoft.net.compilers.toolset.3.9.0-5.21112.8.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NET.Sdk"; version = "3.1.400-preview.20365.20"; hash = "sha256-XiBnkAuLbDXE3qNKswDW5bJ+2/lOTM0Jotwwq7OxVgk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d5f6139d-6136-4228-8b2d-9676e9e4eb3d/nuget/v3/flat2/microsoft.net.sdk/3.1.400-preview.20365.20/microsoft.net.sdk.3.1.400-preview.20365.20.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NET.Sdk.Publish"; version = "3.1.300-servicing.20216.7"; hash = "sha256-gVym+TG4pekotsouOrEup8dkYYLPFeNIqzN/cWHEO/Y="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d5f6139d-6136-4228-8b2d-9676e9e4eb3d/nuget/v3/flat2/microsoft.net.sdk.publish/3.1.300-servicing.20216.7/microsoft.net.sdk.publish.3.1.300-servicing.20216.7.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NET.Sdk.Razor"; version = "3.1.6"; hash = "sha256-KqYNpuT8B01liMwZLBLZoLucTt3uVYR3zE4UTEH8gO8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.net.sdk.razor/3.1.6/microsoft.net.sdk.razor.3.1.6.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NET.Sdk.Web"; version = "3.1.300-servicing.20216.7"; hash = "sha256-oWSmOGSjhfiRXcJYRKQK0GuBfgkpxlZ6WRtwzqNoMgA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d5f6139d-6136-4228-8b2d-9676e9e4eb3d/nuget/v3/flat2/microsoft.net.sdk.web/3.1.300-servicing.20216.7/microsoft.net.sdk.web.3.1.300-servicing.20216.7.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NET.Sdk.Web.ProjectSystem"; version = "3.1.300-servicing.20216.7"; hash = "sha256-VE0CiduLOC3KT0D4pqaWGrSSzF6rvd6dQhAFanqsARg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d5f6139d-6136-4228-8b2d-9676e9e4eb3d/nuget/v3/flat2/microsoft.net.sdk.web.projectsystem/3.1.300-servicing.20216.7/microsoft.net.sdk.web.projectsystem.3.1.300-servicing.20216.7.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NET.Test.Sdk"; version = "16.6.1"; hash = "sha256-G9Z/50Ycr4GxkyxV+a04JzOaAuvDEXO+2NcwiQx5TUo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.net.test.sdk/16.6.1/microsoft.net.test.sdk.16.6.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.0.1"; hash = "sha256-mZotlGZqtrqDSoBrZhsxFe6fuOv5/BIo0w2Z2x0zVAU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/1.0.1/microsoft.netcore.platforms.1.0.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/1.1.0/microsoft.netcore.platforms.1.1.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.0.1"; hash = "sha256-lxxw/Gy32xHi0fLgFWNj4YTFBSBkjx5l6ucmbTyf7V4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.targets/1.0.1/microsoft.netcore.targets.1.0.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.targets/1.1.0/microsoft.netcore.targets.1.1.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies"; version = "1.0.0"; hash = "sha256-6faPQ4jaFY3OGGVk3lZKW+DEZaIOBZ/wHqbiDTsRR1k="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies/1.0.0/microsoft.netframework.referenceassemblies.1.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies.net45"; version = "1.0.0"; hash = "sha256-m5521kl7/G0DKFKOtQ9fzIhqPrpPR82r099m+UF06sY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies.net45/1.0.0/microsoft.netframework.referenceassemblies.net45.1.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies.net472"; version = "1.0.0"; hash = "sha256-LI/XnqGb0Dzs5A7ZK3uv3gJPh8c6vOvj7/jabgW2Ea8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies.net472/1.0.0/microsoft.netframework.referenceassemblies.net472.1.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.SourceLink.AzureRepos.Git"; version = "1.1.0-beta-20206-02"; hash = "sha256-xbwMpGdH9cr6ssddH10lg64jCR465IdDubb80RCUDgI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.sourcelink.azurerepos.git/1.1.0-beta-20206-02/microsoft.sourcelink.azurerepos.git.1.1.0-beta-20206-02.nupkg"; }) - (fetchNuGet { pname = "Microsoft.SourceLink.Common"; version = "1.1.0-beta-20206-02"; hash = "sha256-KdM3dDkuDQNUQyaBVyEyCCwnp/pZxMnYDXLsfhWYYOM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.sourcelink.common/1.1.0-beta-20206-02/microsoft.sourcelink.common.1.1.0-beta-20206-02.nupkg"; }) - (fetchNuGet { pname = "Microsoft.SourceLink.GitHub"; version = "1.1.0-beta-20206-02"; hash = "sha256-akWBI51ohB5mUp8ADBgukUsgwfMR3yR2sX93PqV8NWA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.sourcelink.github/1.1.0-beta-20206-02/microsoft.sourcelink.github.1.1.0-beta-20206-02.nupkg"; }) - (fetchNuGet { pname = "Microsoft.SymbolUploader.Build.Task"; version = "1.1.145102"; hash = "sha256-ou58zD57BfjtpalXM8Pced3l2MF7/4VmsOLOIR8Drdo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.symboluploader.build.task/1.1.145102/microsoft.symboluploader.build.task.1.1.145102.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.SDK.EmbedInteropTypes"; version = "15.0.15"; hash = "sha256-7VYeONedZMDjHQiO9gl09WPI4iNdx9Q841ax/6keGTI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.sdk.embedinteroptypes/15.0.15/microsoft.visualstudio.sdk.embedinteroptypes.15.0.15.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Setup.Configuration.Interop"; version = "1.16.30"; hash = "sha256-5IGlN0Nmp6887dxLgV0O3eFbXtertrU2xaztAToVApA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.setup.configuration.interop/1.16.30/microsoft.visualstudio.setup.configuration.interop.1.16.30.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Web.Xdt"; version = "3.0.0"; hash = "sha256-FhFSzVbgttYCtrqUcIVFN2VKGEz1J5DI8IzRB4FzcaE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.web.xdt/3.0.0/microsoft.web.xdt.3.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.0.1"; hash = "sha256-B4t5El/ViBdxALMcpZulewc4j/3SIXf71HhJWhm4Ctk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.primitives/4.0.1/microsoft.win32.primitives.4.0.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.3.0"; hash = "sha256-mBNDmPXNTW54XLnPAUwBRvkIORFM7/j0D0I2SyQPDEg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.primitives/4.3.0/microsoft.win32.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "4.5.0"; hash = "sha256-WMBXsIb0DgPFPaFkNVxY9b9vcMxPqtgFgijKYMJfV/0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.registry/4.5.0/microsoft.win32.registry.4.5.0.nupkg"; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "1.6.1"; hash = "sha256-iNan1ix7RtncGWC9AjAZ2sk70DoxOsmEOgQ10fXm4Pw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/netstandard.library/1.6.1/netstandard.library.1.6.1.nupkg"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "11.0.1"; hash = "sha256-lbR7rpS/EXgJ8TqQspuIIqAsiorrZb1oOK4HFw+QyPw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/newtonsoft.json/11.0.1/newtonsoft.json.11.0.1.nupkg"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "9.0.1"; hash = "sha256-mYCBrgUhIJFzRuLLV9SIiIFHovzfR8Uuqfg6e08EnlU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/newtonsoft.json/9.0.1/newtonsoft.json.9.0.1.nupkg"; }) - (fetchNuGet { pname = "NuGet.Build.Tasks"; version = "5.9.1-rc.8"; hash = "sha256-5awutMHe2p6BwEFHqzA4mwK6l0y2dgkOXb/iNwpsIBg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.build.tasks/5.9.1-rc.8/nuget.build.tasks.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.Build.Tasks.Pack"; version = "5.9.1-rc.8"; hash = "sha256-kgrhybexqM5jKBY9/kKZeGWl3gsmjBzRD+fvYsJuE4M="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.build.tasks.pack/5.9.1-rc.8/nuget.build.tasks.pack.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.CommandLine"; version = "4.1.0"; hash = "sha256-QZPkNpa3+jClzVUikLkuZH2PEn2sdJdU520f2lgGMw4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/nuget.commandline/4.1.0/nuget.commandline.4.1.0.nupkg"; }) - (fetchNuGet { pname = "NuGet.Commands"; version = "5.9.1-rc.8"; hash = "sha256-mXIMDyviqUklhu+Kn3YybAJDWBKcaCy5oRzn2T6Lv2U="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.commands/5.9.1-rc.8/nuget.commands.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.Common"; version = "5.9.1-rc.8"; hash = "sha256-jCjfnYCpwZOXI8EpUNiNiymiwf/YaMGw+GbG7QgMyxQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.common/5.9.1-rc.8/nuget.common.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.Configuration"; version = "5.9.1-rc.8"; hash = "sha256-c0/Bwx37fVCbVBWa0E0qkW2CJsmsoxSDm+Y6DdyLG3U="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.configuration/5.9.1-rc.8/nuget.configuration.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.Credentials"; version = "5.9.1-rc.8"; hash = "sha256-27DsdfUd3o0FqlzXkeLc1Ubj0Uls7aP9CTe7TP7TG4k="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.credentials/5.9.1-rc.8/nuget.credentials.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.DependencyResolver.Core"; version = "5.9.1-rc.8"; hash = "sha256-7I1/82CJt8n2ohyvfEtCo9BvMRVPCXTJckaNH/RJKuE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.dependencyresolver.core/5.9.1-rc.8/nuget.dependencyresolver.core.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.Frameworks"; version = "5.9.1-rc.8"; hash = "sha256-O8JyP+V5HnLPR5JiwPX7tSCyxlYCHvl4I9ino226ddg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.frameworks/5.9.1-rc.8/nuget.frameworks.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.LibraryModel"; version = "5.9.1-rc.8"; hash = "sha256-m+yi3s1QU0K8qWlulQ7t8VYjMFeWFqQmeoyTxIQgyGs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.librarymodel/5.9.1-rc.8/nuget.librarymodel.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.PackageManagement"; version = "5.9.1-rc.8"; hash = "sha256-75IKTQQyaeBTW8wE8w2vOaPGRC+r3JuS9R06ODBunVU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.packagemanagement/5.9.1-rc.8/nuget.packagemanagement.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.Packaging"; version = "5.9.1-rc.8"; hash = "sha256-G2aab7v/ko3hOFIrs+FWRXaiHELKtvi6qMbaQM4eLHU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.packaging/5.9.1-rc.8/nuget.packaging.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.ProjectModel"; version = "5.9.1-rc.8"; hash = "sha256-+444VKy9NvmzFCV8Y7RlIu5kOOVDutkOm/YYwnU8UPY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.projectmodel/5.9.1-rc.8/nuget.projectmodel.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.Protocol"; version = "5.9.1-rc.8"; hash = "sha256-+DeBsU6oiK84o3vWvYMJMNTs9oQN+EUafxDiyNTv2eY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.protocol/5.9.1-rc.8/nuget.protocol.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.Resolver"; version = "5.9.1-rc.8"; hash = "sha256-m5hBLEceBDELGo2Bur8iySpvKP/zV8ytPz650sDDzWA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.resolver/5.9.1-rc.8/nuget.resolver.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "NuGet.Versioning"; version = "5.9.1-rc.8"; hash = "sha256-e5u1mlhopshnwPbVoDh6hSwXLxzSVLl1FlPTKET4Z+8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.versioning/5.9.1-rc.8/nuget.versioning.5.9.1-rc.8.nupkg"; }) - (fetchNuGet { pname = "Perfolizer"; version = "0.2.1"; hash = "sha256-nllshKuHU+1jSBfcTz8BTJTGr1TeCFvxjM4OPyLGSgQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/perfolizer/0.2.1/perfolizer.0.2.1.nupkg"; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.0.0"; hash = "sha256-bmaM0ovT4X4aqDJOR255Yda/u3fmHZskU++lMnsy894="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system/4.0.0/runtime.native.system.4.0.0.nupkg"; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system/4.3.0/runtime.native.system.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.native.System.IO.Compression"; version = "4.3.0"; hash = "sha256-DWnXs4vlKoU6WxxvCArTJupV6sX3iBbZh8SbqfHace8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.io.compression/4.3.0/runtime.native.system.io.compression.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.security.cryptography.openssl/4.3.0/runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "Shouldly"; version = "3.0.0"; hash = "sha256-g9MPlQooO7NsDy92Tjss25yVvliU6VN6JohOlBBH4sE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/shouldly/3.0.0/shouldly.3.0.0.nupkg"; }) - (fetchNuGet { pname = "sn"; version = "1.0.0"; hash = "sha256-GoeLcHlpQEKLuGdd1e7D1oprNBkEGrRLGQJvwxpzIoA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/sn/1.0.0/sn.1.0.0.nupkg"; }) - (fetchNuGet { pname = "System.AppContext"; version = "4.1.0"; hash = "sha256-v6YfyfrKmhww+EYHUq6cwYUMj00MQ6SOfJtcGVRlYzs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.appcontext/4.1.0/system.appcontext.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.AppContext"; version = "4.3.0"; hash = "sha256-yg95LNQOwFlA1tWxXdQkVyJqT4AnoDc+ACmrNvzGiZg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.appcontext/4.3.0/system.appcontext.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.3.0"; hash = "sha256-XqZWb4Kd04960h4U9seivjKseGA/YEIpdplfHYHQ9jk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.3.0/system.buffers.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.4.0"; hash = "sha256-KTxAhYawFG2V5VX1jw3pzx3IrQXRgn1TsvgjPgxAbqA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.4.0/system.buffers.4.4.0.nupkg"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.0"; hash = "sha256-THw2znu+KibfJRfD7cE3nRYHsm7Fyn5pjOOZVonFjvs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.5.0/system.buffers.4.5.0.nupkg"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; hash = "sha256-wws90sfi9M7kuCPWkv1CEYMJtCqx9QB/kj0ymlsNaxI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.5.1/system.buffers.4.5.1.nupkg"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.0.11"; hash = "sha256-puoFMkx4Z55C1XPxNw3np8nzNGjH+G24j43yTIsDRL0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections/4.0.11/system.collections.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections/4.3.0/system.collections.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.0.12"; hash = "sha256-zIEM7AB4SyE9u6G8+o+gCLLwkgi6+3rHQVPdn/dEwB8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.concurrent/4.0.12/system.collections.concurrent.4.0.12.nupkg"; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.3.0"; hash = "sha256-KMY5DfJnDeIsa13DpqvyN8NkReZEMAFnlmNglVoFIXI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.concurrent/4.3.0/system.collections.concurrent.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "1.2.0"; hash = "sha256-FQ3l+ulbLSPhQ0JcQCC4D4SzjTnHsRqcOj56Ywy7pMo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.immutable/1.2.0/system.collections.immutable.1.2.0.nupkg"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "1.5.0"; hash = "sha256-BliqYlL9ntbMXo5d7NUrKXwYN+PqdyqDIS5bp4qVr7Q="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.immutable/1.5.0/system.collections.immutable.1.5.0.nupkg"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "5.0.0"; hash = "sha256-GdwSIjLMM0uVfE56VUSLVNgpW0B//oCeSFj8/hSlbM8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.immutable/5.0.0/system.collections.immutable.5.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Collections.NonGeneric"; version = "4.0.1"; hash = "sha256-jdCVXmGOsJ+2F0xAagCkiMZ91SGAm9iOhO2u4ksmKaU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.nongeneric/4.0.1/system.collections.nongeneric.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Configuration.ConfigurationManager"; version = "4.7.0"; hash = "sha256-rYjp/UmagI4ZULU1ocia/AiXxLNL8uhMV8LBF4QFW10="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.configuration.configurationmanager/4.7.0/system.configuration.configurationmanager.4.7.0.nupkg"; }) - (fetchNuGet { pname = "System.Console"; version = "4.0.0"; hash = "sha256-jtZfT/TpJtLisV/y5Mk3IfCpE79zwhBYXtyGP9jC3Xo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.console/4.0.0/system.console.4.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Console"; version = "4.3.0"; hash = "sha256-Xh3PPBZr0pDbDaK8AEHbdGz7ePK6Yi1ZyRWI1JM6mbo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.console/4.3.0/system.console.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.0.11"; hash = "sha256-P+rSQJVoN6M56jQbs76kZ9G3mAWFdtF27P/RijN8sj4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.debug/4.0.11/system.diagnostics.debug.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.debug/4.3.0/system.diagnostics.debug.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "4.3.0"; hash = "sha256-OFJRb0ygep0Z3yDBLwAgM/Tkfs4JCDtsNhwDH9cd1Xw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.diagnosticsource/4.3.0/system.diagnostics.diagnosticsource.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.FileVersionInfo"; version = "4.3.0"; hash = "sha256-JyqOf5/lsUNLMpIqK8XffcFTxB6vHWzGWHssmojokCQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.fileversioninfo/4.3.0/system.diagnostics.fileversioninfo.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Process"; version = "4.1.0"; hash = "sha256-OgW6ogQ+oYADYS0PHmwXdhrOKQJpqXlwzSvmfjTLNBg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.process/4.1.0/system.diagnostics.process.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.StackTrace"; version = "4.3.0"; hash = "sha256-Tfq7F61N0VfujVyI5A9MZvyWewQ5HepB1f1UMBMkUCs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.stacktrace/4.3.0/system.diagnostics.stacktrace.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Tools"; version = "4.3.0"; hash = "sha256-gVOv1SK6Ape0FQhCVlNOd9cvQKBvMxRX9K0JPVi8w0Y="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tools/4.3.0/system.diagnostics.tools.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.TraceSource"; version = "4.0.0"; hash = "sha256-cCjdPU7ow91HGf1hBIOLJMQGO6pNmF+N+5/Z38XJh9U="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracesource/4.0.0/system.diagnostics.tracesource.4.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.1.0"; hash = "sha256-JA0jJcLbU3zh52ub3zweob2EVHvxOqiC6SCYHrY5WbQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracing/4.1.0/system.diagnostics.tracing.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracing/4.3.0/system.diagnostics.tracing.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.3.0"; hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.dynamic.runtime/4.3.0/system.dynamic.runtime.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.0.11"; hash = "sha256-rbSgc2PIEc2c2rN6LK3qCREAX3DqA2Nq1WcLrZYsDBw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization/4.0.11/system.globalization.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization/4.3.0/system.globalization.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.3.0"; hash = "sha256-uNOD0EOVFgnS2fMKvMiEtI9aOw00+Pfy/H+qucAQlPc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization.calendars/4.3.0/system.globalization.calendars.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO"; version = "4.1.0"; hash = "sha256-V6oyQFwWb8NvGxAwvzWnhPxy9dKOfj/XBM3tEC5aHrw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io/4.1.0/system.io.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io/4.3.0/system.io.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO.Compression"; version = "4.3.0"; hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.compression/4.3.0/system.io.compression.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO.Compression.ZipFile"; version = "4.3.0"; hash = "sha256-WQl+JgWs+GaRMeiahTFUbrhlXIHapzcpTFXbRvAtvvs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.compression.zipfile/4.3.0/system.io.compression.zipfile.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.0.1"; hash = "sha256-4VKXFgcGYCTWVXjAlniAVq0dO3o5s8KHylg2wg2/7k0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem/4.0.1/system.io.filesystem.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem/4.3.0/system.io.filesystem.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.0.1"; hash = "sha256-IpigKMomqb6pmYWkrlf0ZdpILtRluX2cX5sOKVW0Feg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem.primitives/4.0.1/system.io.filesystem.primitives.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem.primitives/4.3.0/system.io.filesystem.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Linq"; version = "4.1.0"; hash = "sha256-ZQpFtYw5N1F1aX0jUK3Tw+XvM5tnlnshkTCNtfVA794="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.linq/4.1.0/system.linq.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.linq/4.3.0/system.linq.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.3.0"; hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.linq.expressions/4.3.0/system.linq.expressions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Management"; version = "4.5.0"; hash = "sha256-mcsEl3a95O3oPO260hL3lpiaYaJhFPoWSbEHYYfo5ac="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.management/4.5.0/system.management.4.5.0.nupkg"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.3"; hash = "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.memory/4.5.3/system.memory.4.5.3.nupkg"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.memory/4.5.4/system.memory.4.5.4.nupkg"; }) - (fetchNuGet { pname = "System.Net.Http"; version = "4.3.0"; hash = "sha256-UoBB7WPDp2Bne/fwxKF0nE8grJ6FzTMXdT/jfsphj8Q="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.http/4.3.0/system.net.http.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.3.0"; hash = "sha256-MY7Z6vOtFMbEKaLW9nOSZeAjcWpwCtdO7/W1mkGZBzE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.primitives/4.3.0/system.net.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Net.Sockets"; version = "4.3.0"; hash = "sha256-il7dr5VT/QWDg/0cuh+4Es2u8LY//+qqiY9BZmYxSus="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.sockets/4.3.0/system.net.sockets.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.4.0"; hash = "sha256-auXQK2flL/JpnB/rEcAcUm4vYMCYMEMiWOCAlIaqu2U="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.numerics.vectors/4.4.0/system.numerics.vectors.4.4.0.nupkg"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.numerics.vectors/4.5.0/system.numerics.vectors.4.5.0.nupkg"; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.0.12"; hash = "sha256-MudZ/KYcvYsn2cST3EE049mLikrNkmE7QoUoYKKby+s="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.objectmodel/4.0.12/system.objectmodel.4.0.12.nupkg"; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.3.0"; hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.objectmodel/4.3.0/system.objectmodel.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Private.DataContractSerialization"; version = "4.1.1"; hash = "sha256-OaE+ZcEfkpIkbdMOMAMiJa9vgiVP25FGuFrf+N/mafY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.private.datacontractserialization/4.1.1/system.private.datacontractserialization.4.1.1.nupkg"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.1.0"; hash = "sha256-idZHGH2Yl/hha1CM4VzLhsaR8Ljo/rV7TYe7mwRJSMs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection/4.1.0/system.reflection.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection/4.3.0/system.reflection.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.0.1"; hash = "sha256-F1MvYoQWHCY89/O4JBwswogitqVvKuVfILFqA7dmuHk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit/4.0.1/system.reflection.emit.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.3.0"; hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit/4.3.0/system.reflection.emit.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.0.1"; hash = "sha256-YG+eJBG5P+5adsHiw/lhJwvREnvdHw6CJyS8ZV4Ujd0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit.ilgeneration/4.0.1/system.reflection.emit.ilgeneration.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.0.1"; hash = "sha256-uVvNOnL64CPqsgZP2OLqNmxdkZl6Q0fTmKmv9gcBi+g="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit.lightweight/4.0.1/system.reflection.emit.lightweight.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.3.0"; hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit.lightweight/4.3.0/system.reflection.emit.lightweight.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.0.1"; hash = "sha256-NsfmzM9G/sN3H8X2cdnheTGRsh7zbRzvegnjDzDH/FQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.extensions/4.0.1/system.reflection.extensions.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.extensions/4.3.0/system.reflection.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "1.6.0"; hash = "sha256-JJfgaPav7UfEh4yRAQdGhLZF1brr0tUWPl6qmfNWq/E="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadata/1.6.0/system.reflection.metadata.1.6.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "5.0.0"; hash = "sha256-Wo+MiqhcP9dQ6NuFGrQTw6hpbJORFwp+TBNTq2yhGp8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadata/5.0.0/system.reflection.metadata.5.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.0.1"; hash = "sha256-SFSfpWEyCBMAOerrMCOiKnpT+UAWTvRcmoRquJR6Vq0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.primitives/4.0.1/system.reflection.primitives.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.primitives/4.3.0/system.reflection.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.1.0"; hash = "sha256-R0YZowmFda+xzKNR4kKg7neFoE30KfZwp/IwfRSKVK4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.typeextensions/4.1.0/system.reflection.typeextensions.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Resources.Extensions"; version = "4.6.0"; hash = "sha256-ErAPQRTkjRsica+h1mAFxMZbE4RrR9nH0/VB9mSCzEY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.extensions/4.6.0/system.resources.extensions.4.6.0.nupkg"; }) - (fetchNuGet { pname = "System.Resources.Reader"; version = "4.0.0"; hash = "sha256-NOax26EYc/L4bfedL2a33fg4sFXVkBwzVTQ41saJTsk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.reader/4.0.0/system.resources.reader.4.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.0.1"; hash = "sha256-cZ2/3/fczLjEpn6j3xkgQV9ouOVjy4Kisgw5xWw9kSw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.resourcemanager/4.0.1/system.resources.resourcemanager.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.resourcemanager/4.3.0/system.resources.resourcemanager.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.1.0"; hash = "sha256-FViNGM/4oWtlP6w0JC0vJU+k9efLKZ+yaXrnEeabDQo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime/4.1.0/system.runtime.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime/4.3.0/system.runtime.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "5.0.0"; hash = "sha256-neARSpLPUzPxEKhJRwoBzhPxK+cKIitLx7WBYncsYgo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.compilerservices.unsafe/5.0.0/system.runtime.compilerservices.unsafe.5.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.1.0"; hash = "sha256-X7DZ5CbPY7jHs20YZ7bmcXs9B5Mxptu/HnBUvUnNhGc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.extensions/4.1.0/system.runtime.extensions.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.extensions/4.3.0/system.runtime.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.0.1"; hash = "sha256-j2QgVO9ZOjv7D1het98CoFpjoYgxjupuIhuBUmLLH7w="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.handles/4.0.1/system.runtime.handles.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.handles/4.3.0/system.runtime.handles.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.1.0"; hash = "sha256-QceAYlJvkPRJc/+5jR+wQpNNI3aqGySWWSO30e/FfQY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices/4.1.0/system.runtime.interopservices.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices/4.3.0/system.runtime.interopservices.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices.RuntimeInformation"; version = "4.0.0"; hash = "sha256-5j53amb76A3SPiE3B0llT2XPx058+CgE7OXL4bLalT4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices.runtimeinformation/4.0.0/system.runtime.interopservices.runtimeinformation.4.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices.RuntimeInformation"; version = "4.3.0"; hash = "sha256-MYpl6/ZyC6hjmzWRIe+iDoldOMW1mfbwXsduAnXIKGA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices.runtimeinformation/4.3.0/system.runtime.interopservices.runtimeinformation.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.3.0"; hash = "sha256-P5jHCgMbgFMYiONvzmaKFeOqcAIDPu/U8bOVrNPYKqc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.numerics/4.3.0/system.runtime.numerics.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Serialization.Primitives"; version = "4.1.1"; hash = "sha256-80B05oxJbPLGq2pGOSl6NlZvintX9A1CNpna2aN0WRA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.serialization.primitives/4.1.1/system.runtime.serialization.primitives.4.1.1.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Serialization.Xml"; version = "4.1.1"; hash = "sha256-Mx/8hiqvp1E4I6ysJC3U8D2B9qhRQcVvEOivV6w65IQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.serialization.xml/4.1.1/system.runtime.serialization.xml.4.1.1.nupkg"; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "4.5.0"; hash = "sha256-AFsKPb/nTk2/mqH/PYpaoI8PLsiKKimaXf+7Mb5VfPM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.accesscontrol/4.5.0/system.security.accesscontrol.4.5.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "4.7.0"; hash = "sha256-/9ZCPIHLdhzq7OW4UKqTsR0O93jjHd6BRG1SRwgHE1g="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.accesscontrol/4.7.0/system.security.accesscontrol.4.7.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.3.0"; hash = "sha256-tAJvNSlczYBJ3Ed24Ae27a55tq/n4D3fubNQdwcKWA8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.algorithms/4.3.0/system.security.cryptography.algorithms.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.3.0"; hash = "sha256-Yuge89N6M+NcblcvXMeyHZ6kZDfwBv3LPMDiF8HhJss="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.encoding/4.3.0/system.security.cryptography.encoding.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.3.0"; hash = "sha256-fnFi7B3SnVj5a+BbgXnbjnGNvWrCEU6Hp/wjsjWz318="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.primitives/4.3.0/system.security.cryptography.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.3.0"; hash = "sha256-MG3V/owDh273GCUPsGGraNwaVpcydupl3EtPXj6TVG0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.x509certificates/4.3.0/system.security.cryptography.x509certificates.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Permissions"; version = "4.7.0"; hash = "sha256-BGgXMLUi5rxVmmChjIhcXUxisJjvlNToXlyaIbUxw40="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.permissions/4.7.0/system.security.permissions.4.7.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.5.0"; hash = "sha256-BkUYNguz0e4NJp1kkW7aJBn3dyH9STwB5N8XqnlCsmY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.principal.windows/4.5.0/system.security.principal.windows.4.5.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.7.0"; hash = "sha256-rWBM2U8Kq3rEdaa1MPZSYOOkbtMGgWyB8iPrpIqmpqg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.principal.windows/4.7.0/system.security.principal.windows.4.7.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.0.11"; hash = "sha256-PEailOvG05CVgPTyKLtpAgRydlSHmtd5K0Y8GSHY2Lc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding/4.0.11/system.text.encoding.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding/4.3.0/system.text.encoding.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "4.0.1"; hash = "sha256-wxtwWQSTv5tuFP79KhUAhaL6bL4d8lSzSWkCn9aolwM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.codepages/4.0.1/system.text.encoding.codepages.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "4.3.0"; hash = "sha256-ezYVwe9atRkREc8O/HT/VfGDE2vuCpIckOfdY194/VE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.codepages/4.3.0/system.text.encoding.codepages.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.0.11"; hash = "sha256-+kf7J3dEhgCbnCM5vHYlsTm5/R/Ud0Jr6elpHm922iI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.extensions/4.0.11/system.text.encoding.extensions.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.extensions/4.3.0/system.text.encoding.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "4.7.0"; hash = "sha256-w3KhanXU1v+0uWZuLECd1oChvYeUrGhN5blk5WBco2k="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encodings.web/4.7.0/system.text.encodings.web.4.7.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Json"; version = "4.7.0"; hash = "sha256-ubmcBH9pNdILnROdpGfnfo90WijLE6bUbKUypn3u4zo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.json/4.7.0/system.text.json.4.7.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.RegularExpressions"; version = "4.1.0"; hash = "sha256-x6OQN6MCN7S0fJ6EFTfv4rczdUWjwuWE9QQ0P6fbh9c="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.regularexpressions/4.1.0/system.text.regularexpressions.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.RegularExpressions"; version = "4.3.0"; hash = "sha256-VLCk1D1kcN2wbAe3d0YQM/PqCsPHOuqlBY1yd2Yo+K0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.regularexpressions/4.3.0/system.text.regularexpressions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.0.11"; hash = "sha256-mob1Zv3qLQhQ1/xOLXZmYqpniNUMCfn02n8ZkaAhqac="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading/4.0.11/system.threading.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading/4.3.0/system.threading.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.0.11"; hash = "sha256-5SLxzFg1df6bTm2t09xeI01wa5qQglqUwwJNlQPJIVs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks/4.0.11/system.threading.tasks.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks/4.3.0/system.threading.tasks.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Dataflow"; version = "4.9.0"; hash = "sha256-ZTZBJTrP5kzO38ec9lPxuNUYgEoeGNdQ8hF98uRN2rw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.dataflow/4.9.0/system.threading.tasks.dataflow.4.9.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.0.0"; hash = "sha256-+YdcPkMhZhRbMZHnfsDwpNbUkr31X7pQFGxXYcAPZbE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.extensions/4.0.0/system.threading.tasks.extensions.4.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.3.0"; hash = "sha256-X2hQ5j+fxcmnm88Le/kSavjiGOmkcumBGTZKBLvorPc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.extensions/4.3.0/system.threading.tasks.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.2"; hash = "sha256-EqJF9TppMHTKvpR6emrdA61zalMW3HwrZ7j6Bn4bBuo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.extensions/4.5.2/system.threading.tasks.extensions.4.5.2.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Parallel"; version = "4.0.1"; hash = "sha256-5VyRZ97Fug4reK/cQ6wsCrJ5jH53aGu1a4ZkKMZrnIQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.parallel/4.0.1/system.threading.tasks.parallel.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Parallel"; version = "4.3.0"; hash = "sha256-8H2vRmsn29MNfMmCeIL5vHfbM19jWaLDKNLzDonCI+c="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.parallel/4.3.0/system.threading.tasks.parallel.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Thread"; version = "4.0.0"; hash = "sha256-7EtSJuKqcW107FYA5Ko9NFXEWUPIzNDtlfKaQV2pvb8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.thread/4.0.0/system.threading.thread.4.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Thread"; version = "4.3.0"; hash = "sha256-pMs6RNFC3nQOGz9EqIcyWmO8YLaqay+q/Qde5hqPXXg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.thread/4.3.0/system.threading.thread.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Timer"; version = "4.0.1"; hash = "sha256-5lU6zt1O9JDSPr2KAHw4BYgysHnt0yyZrMNa5IIjxZY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.timer/4.0.1/system.threading.timer.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Timer"; version = "4.3.0"; hash = "sha256-pmhslmhQhP32TWbBzoITLZ4BoORBqYk25OWbru04p9s="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.timer/4.3.0/system.threading.timer.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.ValueTuple"; version = "4.5.0"; hash = "sha256-niH6l2fU52vAzuBlwdQMw0OEoRS/7E1w5smBFoqSaAI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.valuetuple/4.5.0/system.valuetuple.4.5.0.nupkg"; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.0.11"; hash = "sha256-haZAFFQ9Sl2DhfvEbdx2YRqKEoxNMU5STaqpMmXw0zA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.readerwriter/4.0.11/system.xml.readerwriter.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.3.0"; hash = "sha256-QQ8KgU0lu4F5Unh+TbechO//zaAGZ4MfgvW72Cn1hzA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.readerwriter/4.3.0/system.xml.readerwriter.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Xml.XDocument"; version = "4.3.0"; hash = "sha256-rWtdcmcuElNOSzCehflyKwHkDRpiOhJJs8CeQ0l1CCI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.xdocument/4.3.0/system.xml.xdocument.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Xml.XmlDocument"; version = "4.0.1"; hash = "sha256-gdoFrPo54v1LjkBF79f8EvtltVVjHz9ZI9kc5ve0GkY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.xmldocument/4.0.1/system.xml.xmldocument.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Xml.XmlDocument"; version = "4.3.0"; hash = "sha256-kbuV4Y7rVJkfMp2Kgoi8Zvdatm9CZNmlKB3GZgANvy4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.xmldocument/4.3.0/system.xml.xmldocument.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Xml.XmlSerializer"; version = "4.0.11"; hash = "sha256-v6x4d6W18dijG5cDqQmVHdtWRf6Y4OkdBolT3d5g3wY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.xmlserializer/4.0.11/system.xml.xmlserializer.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Xml.XPath"; version = "4.3.0"; hash = "sha256-kd1JMqj6obhxzEPRJeYvcUyJqkOs/9A0UOQccC6oYrM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.xpath/4.3.0/system.xml.xpath.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Xml.XPath.XDocument"; version = "4.3.0"; hash = "sha256-dqk4CWuwocj5qsUAYlS+XAe6GGcY/N/HIPEGe5afrPM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.xpath.xdocument/4.3.0/system.xml.xpath.xdocument.4.3.0.nupkg"; }) - (fetchNuGet { pname = "vswhere"; version = "2.6.7"; hash = "sha256-kzMH9TNexExGSutkXHIWpydXgjlbd+L+H8Oca1Isk0A="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/vswhere/2.6.7/vswhere.2.6.7.nupkg"; }) - (fetchNuGet { pname = "XliffTasks"; version = "1.0.0-beta.20502.2"; hash = "sha256-ICnkCRBS+hsuFtwNPS7ux2ZQAttaAgCX/HTBzp5qY54="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/xlifftasks/1.0.0-beta.20502.2/xlifftasks.1.0.0-beta.20502.2.nupkg"; }) - (fetchNuGet { pname = "xunit"; version = "2.4.1"; hash = "sha256-QGDuE0ZnsxyEJONP8GcJ80PmPeb+OawwdSW8y72aw3U="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit/2.4.1/xunit.2.4.1.nupkg"; }) - (fetchNuGet { pname = "xunit.abstractions"; version = "2.0.3"; hash = "sha256-0D1y/C34iARI96gb3bAOG8tcGPMjx+fMabTPpydGlAM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.abstractions/2.0.3/xunit.abstractions.2.0.3.nupkg"; }) - (fetchNuGet { pname = "xunit.analyzers"; version = "0.10.0"; hash = "sha256-8lRZhogXHYksa9ChnkFXpBnTMlLlYIvu3Av7qQYWwJY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.analyzers/0.10.0/xunit.analyzers.0.10.0.nupkg"; }) - (fetchNuGet { pname = "xunit.assert"; version = "2.4.1"; hash = "sha256-hl1cMSakAlwkpFEchxCNMdvQie6PMJ1uFrhzgOC3vsY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.assert/2.4.1/xunit.assert.2.4.1.nupkg"; }) - (fetchNuGet { pname = "xunit.core"; version = "2.4.1"; hash = "sha256-KgUgAIJIPHQ5VQ4FiB+i5u2JXSYxmvMCV8zXP4kcy9o="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.core/2.4.1/xunit.core.2.4.1.nupkg"; }) - (fetchNuGet { pname = "xunit.extensibility.core"; version = "2.4.1"; hash = "sha256-oACVOrvF4XmKFr+8ZqPVpjbopZgeRwaXveJGW2XUeIA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.extensibility.core/2.4.1/xunit.extensibility.core.2.4.1.nupkg"; }) - (fetchNuGet { pname = "xunit.extensibility.execution"; version = "2.4.1"; hash = "sha256-KmKEdgsUq4zuQJ2saJA0YT1CIZ2AuhZL5V7cF2Cncd0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.extensibility.execution/2.4.1/xunit.extensibility.execution.2.4.1.nupkg"; }) - (fetchNuGet { pname = "xunit.runner.console"; version = "2.4.1"; hash = "sha256-I/C0ntv+W+j4VU5/QxejkJSbuWvbL4MJ6+J8aFX6048="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.runner.console/2.4.1/xunit.runner.console.2.4.1.nupkg"; }) - (fetchNuGet { pname = "xunit.runner.visualstudio"; version = "2.4.3"; hash = "sha256-42axn0yDDiJWKV8UEYzYWgiKbpc6mHh9M/eeylYGLUg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.runner.visualstudio/2.4.3/xunit.runner.visualstudio.2.4.3.nupkg"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "BenchmarkDotNet"; + version = "0.12.1"; + hash = "sha256-vISVlxTg4nhyRd1Jw+EwzGK7jabO+dQYnBScDVRAE3I="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/benchmarkdotnet/0.12.1/benchmarkdotnet.0.12.1.nupkg"; + }) + (fetchNuGet { + pname = "BenchmarkDotNet.Annotations"; + version = "0.12.1"; + hash = "sha256-g1M3JNIgAsL1g7oEISRf5mMsYkO2uJfWBkglc9tHOxg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/benchmarkdotnet.annotations/0.12.1/benchmarkdotnet.annotations.0.12.1.nupkg"; + }) + (fetchNuGet { + pname = "CommandLineParser"; + version = "2.4.3"; + hash = "sha256-pTyYP26uXXLe6ejCb/yVYpb23ad/Dkl2Ka8NWwQeiqk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/commandlineparser/2.4.3/commandlineparser.2.4.3.nupkg"; + }) + (fetchNuGet { + pname = "FSharp.NET.Sdk"; + version = "1.0.4-bundled-0100"; + hash = "sha256-6FC2zLqwF0bydu8d2uiH1McIy0af/NrZ//hf4xdvHho="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/fsharp.net.sdk/1.0.4-bundled-0100/fsharp.net.sdk.1.0.4-bundled-0100.nupkg"; + }) + (fetchNuGet { + pname = "Iced"; + version = "1.4.0"; + hash = "sha256-yQ7xTIeuZCo5WotGbkWuw7/hyAf/6sukdtuURRkQFNE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/iced/1.4.0/iced.1.4.0.nupkg"; + }) + (fetchNuGet { + pname = "ILLink.Tasks"; + version = "0.1.6-prerelease.20175.2"; + hash = "sha256-/yDCjUVz3RstltoUDOcYEwNyGeLWAviiG7YUURGZjmg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/7d9f5c21-0d79-403f-bfe3-9a4506529760/nuget/v3/flat2/illink.tasks/0.1.6-prerelease.20175.2/illink.tasks.0.1.6-prerelease.20175.2.nupkg"; + }) + (fetchNuGet { + pname = "jnm2.ReferenceAssemblies.net35"; + version = "1.0.1"; + hash = "sha256-7Kgh/lQW1wxa76vecVxmG/8JNBvMz766lxazyL+mt4E="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/jnm2.referenceassemblies.net35/1.0.1/jnm2.referenceassemblies.net35.1.0.1.nupkg"; + }) + (fetchNuGet { + pname = "LargeAddressAware"; + version = "1.0.5"; + hash = "sha256-IQnTkOHBsic3HDa7TwfQtwwbowHG/iWQd6tkPuqAUkM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/largeaddressaware/1.0.5/largeaddressaware.1.0.5.nupkg"; + }) + (fetchNuGet { + pname = "MicroBuild.Core"; + version = "0.2.0"; + hash = "sha256-JIVBO1hWtK955RmtghoXqn6S9rb2G69Id92vqWUhmmA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microbuild.core/0.2.0/microbuild.core.0.2.0.nupkg"; + }) + (fetchNuGet { + pname = "MicroBuild.Core.Sentinel"; + version = "1.0.0"; + hash = "sha256-Efk2JFokIgDHw8G3sSsBs2990adCCItAoPiq6UrHsww="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microbuild.core.sentinel/1.0.0/microbuild.core.sentinel.1.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "1.1.0"; + hash = "sha256-QYVojfqSZKbF8P6D/aacfxfumMaRUD9SEEQbzw73Bbc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.bcl.asyncinterfaces/1.1.0/microsoft.bcl.asyncinterfaces.1.1.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build"; + version = "14.3.0"; + hash = "sha256-P4NszYl1VU6+2hWB64Y7Jy1mw/HA0kul5iD2ju6wVf0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build/14.3.0/microsoft.build.14.3.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.CentralPackageVersions"; + version = "2.0.1"; + hash = "sha256-sxSrG4+xzZVP2YtJYYCpHGa0pCAPmZCQRhilJaSKkp0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.centralpackageversions/2.0.1/microsoft.build.centralpackageversions.2.0.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Framework"; + version = "14.3.0"; + hash = "sha256-zSmVu5u/oec5XVHsbwviR5joITIC5uZGWXfk1U4M/mQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.framework/14.3.0/microsoft.build.framework.14.3.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Framework"; + version = "15.5.180"; + hash = "sha256-XyTJ3tn+vOc5rH4Pux1MjswRia6ei5bqTX3GEI4anhg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.framework/15.5.180/microsoft.build.framework.15.5.180.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.NuGetSdkResolver"; + version = "5.9.1-rc.8"; + hash = "sha256-DaH2rPBY32UWK1M2odPiRVF/NnmrrnvBtxTnI6ia/bU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.build.nugetsdkresolver/5.9.1-rc.8/microsoft.build.nugetsdkresolver.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Tasks.Git"; + version = "1.1.0-beta-20206-02"; + hash = "sha256-nbFnPIifuevbeOCkPuCirofjqDLi+CnxYUXvSfGGlL8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.build.tasks.git/1.1.0-beta-20206-02/microsoft.build.tasks.git.1.1.0-beta-20206-02.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Utilities.Core"; + version = "14.3.0"; + hash = "sha256-awZNRydsILpI8xtA/zI8WbHTDuQcq220nt+K0K22oQw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.utilities.core/14.3.0/microsoft.build.utilities.core.14.3.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Utilities.Core"; + version = "15.5.180"; + hash = "sha256-YJiW2bLfrkOFvQ8toWDGyPodrmjlIkshWyixhxWUizA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.utilities.core/15.5.180/microsoft.build.utilities.core.15.5.180.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "2.6.1"; + hash = "sha256-1+FV3KvwerZsknecHZhdDACsPKaWrbQQeN27BAcZk94="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.analyzers/2.6.1/microsoft.codeanalysis.analyzers.2.6.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Build.Tasks"; + version = "3.9.0-5.21112.8"; + hash = "sha256-h1UrpcVKxFQkmX4bHrsZGlJ2wB5X+dwREtiHu++sm6M="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.build.tasks/3.9.0-5.21112.8/microsoft.codeanalysis.build.tasks.3.9.0-5.21112.8.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "2.10.0"; + hash = "sha256-UikMFW/dcSiKfsUqnn2hvguLJN7gw1e01WpWmHEHydA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.common/2.10.0/microsoft.codeanalysis.common.2.10.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "2.10.0"; + hash = "sha256-szdSweIavn5BBPZgM8uE4j1WrvTfMqF/4yqzgLJeSmk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.csharp/2.10.0/microsoft.codeanalysis.csharp.2.10.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeCoverage"; + version = "16.6.1"; + hash = "sha256-NI+9eizIs3mrCNAw058DZvRzxpCAdoL3SKth6iypzgU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codecoverage/16.6.1/microsoft.codecoverage.16.6.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.NETCore.Client"; + version = "0.2.61701"; + hash = "sha256-ITNO2LJYyWhYs3A/iqfoaW6ddvkuuBVXQ5YSKQ8wgcU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.diagnostics.netcore.client/0.2.61701/microsoft.diagnostics.netcore.client.0.2.61701.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.Runtime"; + version = "1.1.57604"; + hash = "sha256-Ubu6a+qKwstY6v7Oywg1izAwgLZOnvv5ZjcmOJ5+qb4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.diagnostics.runtime/1.1.57604/microsoft.diagnostics.runtime.1.1.57604.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.Tracing.TraceEvent"; + version = "2.0.49"; + hash = "sha256-SUkXJTeA+Ctk+MlxY5QAThL6d+mBIz+gKJ0RlShKnCM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.diagnostics.tracing.traceevent/2.0.49/microsoft.diagnostics.tracing.traceevent.2.0.49.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.Arcade.Sdk"; + version = "5.0.0-beta.21226.1"; + hash = "sha256-g0R3wc9SZryUvgu5fB5WwyLEcQsPYbrqa4qylNpn97Q="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.dotnet.arcade.sdk/5.0.0-beta.21226.1/microsoft.dotnet.arcade.sdk.5.0.0-beta.21226.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.MSBuildSdkResolver"; + version = "5.0.300-servicing.21267.11"; + hash = "sha256-5S7nvtosI97MPWxHaxBManc70Dp1e9Ycbta9C6cS78k="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a8a526e9-91b3-4569-ba2d-ff08dbb7c110/nuget/v3/flat2/microsoft.dotnet.msbuildsdkresolver/5.0.300-servicing.21267.11/microsoft.dotnet.msbuildsdkresolver.5.0.300-servicing.21267.11.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.PlatformAbstractions"; + version = "2.1.0"; + hash = "sha256-vrZhYp94SjycUMGaVYCFWJ4p7KBKfqVyLWtIG73fzeM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.dotnet.platformabstractions/2.1.0/microsoft.dotnet.platformabstractions.2.1.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.SignTool"; + version = "5.0.0-beta.21226.1"; + hash = "sha256-cr0QbHmpSj7zhg3y0bMudugkInppcdSlDTHFYRExo8k="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.dotnet.signtool/5.0.0-beta.21226.1/microsoft.dotnet.signtool.5.0.0-beta.21226.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NET.Build.Extensions"; + version = "3.1.400-preview.20365.20"; + hash = "sha256-pUGvWPLzNQEIDhdCbkv+qnU1e9QS477moiFree6RrO4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d5f6139d-6136-4228-8b2d-9676e9e4eb3d/nuget/v3/flat2/microsoft.net.build.extensions/3.1.400-preview.20365.20/microsoft.net.build.extensions.3.1.400-preview.20365.20.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Net.Compilers.Toolset"; + version = "3.9.0-5.21112.8"; + hash = "sha256-MDxQi3QVFfvA5bcOblCm/ypHSe6WqpGb0ZD65NXrLLc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.net.compilers.toolset/3.9.0-5.21112.8/microsoft.net.compilers.toolset.3.9.0-5.21112.8.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NET.Sdk"; + version = "3.1.400-preview.20365.20"; + hash = "sha256-XiBnkAuLbDXE3qNKswDW5bJ+2/lOTM0Jotwwq7OxVgk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d5f6139d-6136-4228-8b2d-9676e9e4eb3d/nuget/v3/flat2/microsoft.net.sdk/3.1.400-preview.20365.20/microsoft.net.sdk.3.1.400-preview.20365.20.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NET.Sdk.Publish"; + version = "3.1.300-servicing.20216.7"; + hash = "sha256-gVym+TG4pekotsouOrEup8dkYYLPFeNIqzN/cWHEO/Y="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d5f6139d-6136-4228-8b2d-9676e9e4eb3d/nuget/v3/flat2/microsoft.net.sdk.publish/3.1.300-servicing.20216.7/microsoft.net.sdk.publish.3.1.300-servicing.20216.7.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NET.Sdk.Razor"; + version = "3.1.6"; + hash = "sha256-KqYNpuT8B01liMwZLBLZoLucTt3uVYR3zE4UTEH8gO8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.net.sdk.razor/3.1.6/microsoft.net.sdk.razor.3.1.6.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NET.Sdk.Web"; + version = "3.1.300-servicing.20216.7"; + hash = "sha256-oWSmOGSjhfiRXcJYRKQK0GuBfgkpxlZ6WRtwzqNoMgA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d5f6139d-6136-4228-8b2d-9676e9e4eb3d/nuget/v3/flat2/microsoft.net.sdk.web/3.1.300-servicing.20216.7/microsoft.net.sdk.web.3.1.300-servicing.20216.7.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NET.Sdk.Web.ProjectSystem"; + version = "3.1.300-servicing.20216.7"; + hash = "sha256-VE0CiduLOC3KT0D4pqaWGrSSzF6rvd6dQhAFanqsARg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d5f6139d-6136-4228-8b2d-9676e9e4eb3d/nuget/v3/flat2/microsoft.net.sdk.web.projectsystem/3.1.300-servicing.20216.7/microsoft.net.sdk.web.projectsystem.3.1.300-servicing.20216.7.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NET.Test.Sdk"; + version = "16.6.1"; + hash = "sha256-G9Z/50Ycr4GxkyxV+a04JzOaAuvDEXO+2NcwiQx5TUo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.net.test.sdk/16.6.1/microsoft.net.test.sdk.16.6.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.0.1"; + hash = "sha256-mZotlGZqtrqDSoBrZhsxFe6fuOv5/BIo0w2Z2x0zVAU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/1.0.1/microsoft.netcore.platforms.1.0.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/1.1.0/microsoft.netcore.platforms.1.1.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.0.1"; + hash = "sha256-lxxw/Gy32xHi0fLgFWNj4YTFBSBkjx5l6ucmbTyf7V4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.targets/1.0.1/microsoft.netcore.targets.1.0.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.targets/1.1.0/microsoft.netcore.targets.1.1.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies"; + version = "1.0.0"; + hash = "sha256-6faPQ4jaFY3OGGVk3lZKW+DEZaIOBZ/wHqbiDTsRR1k="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies/1.0.0/microsoft.netframework.referenceassemblies.1.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies.net45"; + version = "1.0.0"; + hash = "sha256-m5521kl7/G0DKFKOtQ9fzIhqPrpPR82r099m+UF06sY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies.net45/1.0.0/microsoft.netframework.referenceassemblies.net45.1.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies.net472"; + version = "1.0.0"; + hash = "sha256-LI/XnqGb0Dzs5A7ZK3uv3gJPh8c6vOvj7/jabgW2Ea8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies.net472/1.0.0/microsoft.netframework.referenceassemblies.net472.1.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.SourceLink.AzureRepos.Git"; + version = "1.1.0-beta-20206-02"; + hash = "sha256-xbwMpGdH9cr6ssddH10lg64jCR465IdDubb80RCUDgI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.sourcelink.azurerepos.git/1.1.0-beta-20206-02/microsoft.sourcelink.azurerepos.git.1.1.0-beta-20206-02.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.SourceLink.Common"; + version = "1.1.0-beta-20206-02"; + hash = "sha256-KdM3dDkuDQNUQyaBVyEyCCwnp/pZxMnYDXLsfhWYYOM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.sourcelink.common/1.1.0-beta-20206-02/microsoft.sourcelink.common.1.1.0-beta-20206-02.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.SourceLink.GitHub"; + version = "1.1.0-beta-20206-02"; + hash = "sha256-akWBI51ohB5mUp8ADBgukUsgwfMR3yR2sX93PqV8NWA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.sourcelink.github/1.1.0-beta-20206-02/microsoft.sourcelink.github.1.1.0-beta-20206-02.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.SymbolUploader.Build.Task"; + version = "1.1.145102"; + hash = "sha256-ou58zD57BfjtpalXM8Pced3l2MF7/4VmsOLOIR8Drdo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.symboluploader.build.task/1.1.145102/microsoft.symboluploader.build.task.1.1.145102.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.SDK.EmbedInteropTypes"; + version = "15.0.15"; + hash = "sha256-7VYeONedZMDjHQiO9gl09WPI4iNdx9Q841ax/6keGTI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.sdk.embedinteroptypes/15.0.15/microsoft.visualstudio.sdk.embedinteroptypes.15.0.15.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Setup.Configuration.Interop"; + version = "1.16.30"; + hash = "sha256-5IGlN0Nmp6887dxLgV0O3eFbXtertrU2xaztAToVApA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.setup.configuration.interop/1.16.30/microsoft.visualstudio.setup.configuration.interop.1.16.30.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Web.Xdt"; + version = "3.0.0"; + hash = "sha256-FhFSzVbgttYCtrqUcIVFN2VKGEz1J5DI8IzRB4FzcaE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.web.xdt/3.0.0/microsoft.web.xdt.3.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.0.1"; + hash = "sha256-B4t5El/ViBdxALMcpZulewc4j/3SIXf71HhJWhm4Ctk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.primitives/4.0.1/microsoft.win32.primitives.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.3.0"; + hash = "sha256-mBNDmPXNTW54XLnPAUwBRvkIORFM7/j0D0I2SyQPDEg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.primitives/4.3.0/microsoft.win32.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "4.5.0"; + hash = "sha256-WMBXsIb0DgPFPaFkNVxY9b9vcMxPqtgFgijKYMJfV/0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.registry/4.5.0/microsoft.win32.registry.4.5.0.nupkg"; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "1.6.1"; + hash = "sha256-iNan1ix7RtncGWC9AjAZ2sk70DoxOsmEOgQ10fXm4Pw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/netstandard.library/1.6.1/netstandard.library.1.6.1.nupkg"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "11.0.1"; + hash = "sha256-lbR7rpS/EXgJ8TqQspuIIqAsiorrZb1oOK4HFw+QyPw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/newtonsoft.json/11.0.1/newtonsoft.json.11.0.1.nupkg"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "9.0.1"; + hash = "sha256-mYCBrgUhIJFzRuLLV9SIiIFHovzfR8Uuqfg6e08EnlU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/newtonsoft.json/9.0.1/newtonsoft.json.9.0.1.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Build.Tasks"; + version = "5.9.1-rc.8"; + hash = "sha256-5awutMHe2p6BwEFHqzA4mwK6l0y2dgkOXb/iNwpsIBg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.build.tasks/5.9.1-rc.8/nuget.build.tasks.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Build.Tasks.Pack"; + version = "5.9.1-rc.8"; + hash = "sha256-kgrhybexqM5jKBY9/kKZeGWl3gsmjBzRD+fvYsJuE4M="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.build.tasks.pack/5.9.1-rc.8/nuget.build.tasks.pack.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.CommandLine"; + version = "4.1.0"; + hash = "sha256-QZPkNpa3+jClzVUikLkuZH2PEn2sdJdU520f2lgGMw4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/nuget.commandline/4.1.0/nuget.commandline.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Commands"; + version = "5.9.1-rc.8"; + hash = "sha256-mXIMDyviqUklhu+Kn3YybAJDWBKcaCy5oRzn2T6Lv2U="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.commands/5.9.1-rc.8/nuget.commands.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Common"; + version = "5.9.1-rc.8"; + hash = "sha256-jCjfnYCpwZOXI8EpUNiNiymiwf/YaMGw+GbG7QgMyxQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.common/5.9.1-rc.8/nuget.common.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Configuration"; + version = "5.9.1-rc.8"; + hash = "sha256-c0/Bwx37fVCbVBWa0E0qkW2CJsmsoxSDm+Y6DdyLG3U="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.configuration/5.9.1-rc.8/nuget.configuration.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Credentials"; + version = "5.9.1-rc.8"; + hash = "sha256-27DsdfUd3o0FqlzXkeLc1Ubj0Uls7aP9CTe7TP7TG4k="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.credentials/5.9.1-rc.8/nuget.credentials.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.DependencyResolver.Core"; + version = "5.9.1-rc.8"; + hash = "sha256-7I1/82CJt8n2ohyvfEtCo9BvMRVPCXTJckaNH/RJKuE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.dependencyresolver.core/5.9.1-rc.8/nuget.dependencyresolver.core.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Frameworks"; + version = "5.9.1-rc.8"; + hash = "sha256-O8JyP+V5HnLPR5JiwPX7tSCyxlYCHvl4I9ino226ddg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.frameworks/5.9.1-rc.8/nuget.frameworks.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.LibraryModel"; + version = "5.9.1-rc.8"; + hash = "sha256-m+yi3s1QU0K8qWlulQ7t8VYjMFeWFqQmeoyTxIQgyGs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.librarymodel/5.9.1-rc.8/nuget.librarymodel.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.PackageManagement"; + version = "5.9.1-rc.8"; + hash = "sha256-75IKTQQyaeBTW8wE8w2vOaPGRC+r3JuS9R06ODBunVU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.packagemanagement/5.9.1-rc.8/nuget.packagemanagement.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Packaging"; + version = "5.9.1-rc.8"; + hash = "sha256-G2aab7v/ko3hOFIrs+FWRXaiHELKtvi6qMbaQM4eLHU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.packaging/5.9.1-rc.8/nuget.packaging.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.ProjectModel"; + version = "5.9.1-rc.8"; + hash = "sha256-+444VKy9NvmzFCV8Y7RlIu5kOOVDutkOm/YYwnU8UPY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.projectmodel/5.9.1-rc.8/nuget.projectmodel.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Protocol"; + version = "5.9.1-rc.8"; + hash = "sha256-+DeBsU6oiK84o3vWvYMJMNTs9oQN+EUafxDiyNTv2eY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.protocol/5.9.1-rc.8/nuget.protocol.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Resolver"; + version = "5.9.1-rc.8"; + hash = "sha256-m5hBLEceBDELGo2Bur8iySpvKP/zV8ytPz650sDDzWA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.resolver/5.9.1-rc.8/nuget.resolver.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Versioning"; + version = "5.9.1-rc.8"; + hash = "sha256-e5u1mlhopshnwPbVoDh6hSwXLxzSVLl1FlPTKET4Z+8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.versioning/5.9.1-rc.8/nuget.versioning.5.9.1-rc.8.nupkg"; + }) + (fetchNuGet { + pname = "Perfolizer"; + version = "0.2.1"; + hash = "sha256-nllshKuHU+1jSBfcTz8BTJTGr1TeCFvxjM4OPyLGSgQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/perfolizer/0.2.1/perfolizer.0.2.1.nupkg"; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.0.0"; + hash = "sha256-bmaM0ovT4X4aqDJOR255Yda/u3fmHZskU++lMnsy894="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system/4.0.0/runtime.native.system.4.0.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system/4.3.0/runtime.native.system.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.native.System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-DWnXs4vlKoU6WxxvCArTJupV6sX3iBbZh8SbqfHace8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.io.compression/4.3.0/runtime.native.system.io.compression.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.security.cryptography.openssl/4.3.0/runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "Shouldly"; + version = "3.0.0"; + hash = "sha256-g9MPlQooO7NsDy92Tjss25yVvliU6VN6JohOlBBH4sE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/shouldly/3.0.0/shouldly.3.0.0.nupkg"; + }) + (fetchNuGet { + pname = "sn"; + version = "1.0.0"; + hash = "sha256-GoeLcHlpQEKLuGdd1e7D1oprNBkEGrRLGQJvwxpzIoA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/sn/1.0.0/sn.1.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.AppContext"; + version = "4.1.0"; + hash = "sha256-v6YfyfrKmhww+EYHUq6cwYUMj00MQ6SOfJtcGVRlYzs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.appcontext/4.1.0/system.appcontext.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.AppContext"; + version = "4.3.0"; + hash = "sha256-yg95LNQOwFlA1tWxXdQkVyJqT4AnoDc+ACmrNvzGiZg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.appcontext/4.3.0/system.appcontext.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.3.0"; + hash = "sha256-XqZWb4Kd04960h4U9seivjKseGA/YEIpdplfHYHQ9jk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.3.0/system.buffers.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.4.0"; + hash = "sha256-KTxAhYawFG2V5VX1jw3pzx3IrQXRgn1TsvgjPgxAbqA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.4.0/system.buffers.4.4.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.0"; + hash = "sha256-THw2znu+KibfJRfD7cE3nRYHsm7Fyn5pjOOZVonFjvs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.5.0/system.buffers.4.5.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + hash = "sha256-wws90sfi9M7kuCPWkv1CEYMJtCqx9QB/kj0ymlsNaxI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.5.1/system.buffers.4.5.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.0.11"; + hash = "sha256-puoFMkx4Z55C1XPxNw3np8nzNGjH+G24j43yTIsDRL0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections/4.0.11/system.collections.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections/4.3.0/system.collections.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.0.12"; + hash = "sha256-zIEM7AB4SyE9u6G8+o+gCLLwkgi6+3rHQVPdn/dEwB8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.concurrent/4.0.12/system.collections.concurrent.4.0.12.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.3.0"; + hash = "sha256-KMY5DfJnDeIsa13DpqvyN8NkReZEMAFnlmNglVoFIXI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.concurrent/4.3.0/system.collections.concurrent.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "1.2.0"; + hash = "sha256-FQ3l+ulbLSPhQ0JcQCC4D4SzjTnHsRqcOj56Ywy7pMo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.immutable/1.2.0/system.collections.immutable.1.2.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "1.5.0"; + hash = "sha256-BliqYlL9ntbMXo5d7NUrKXwYN+PqdyqDIS5bp4qVr7Q="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.immutable/1.5.0/system.collections.immutable.1.5.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "5.0.0"; + hash = "sha256-GdwSIjLMM0uVfE56VUSLVNgpW0B//oCeSFj8/hSlbM8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.immutable/5.0.0/system.collections.immutable.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections.NonGeneric"; + version = "4.0.1"; + hash = "sha256-jdCVXmGOsJ+2F0xAagCkiMZ91SGAm9iOhO2u4ksmKaU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.nongeneric/4.0.1/system.collections.nongeneric.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Configuration.ConfigurationManager"; + version = "4.7.0"; + hash = "sha256-rYjp/UmagI4ZULU1ocia/AiXxLNL8uhMV8LBF4QFW10="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.configuration.configurationmanager/4.7.0/system.configuration.configurationmanager.4.7.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Console"; + version = "4.0.0"; + hash = "sha256-jtZfT/TpJtLisV/y5Mk3IfCpE79zwhBYXtyGP9jC3Xo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.console/4.0.0/system.console.4.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Console"; + version = "4.3.0"; + hash = "sha256-Xh3PPBZr0pDbDaK8AEHbdGz7ePK6Yi1ZyRWI1JM6mbo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.console/4.3.0/system.console.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.0.11"; + hash = "sha256-P+rSQJVoN6M56jQbs76kZ9G3mAWFdtF27P/RijN8sj4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.debug/4.0.11/system.diagnostics.debug.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.debug/4.3.0/system.diagnostics.debug.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "4.3.0"; + hash = "sha256-OFJRb0ygep0Z3yDBLwAgM/Tkfs4JCDtsNhwDH9cd1Xw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.diagnosticsource/4.3.0/system.diagnostics.diagnosticsource.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.FileVersionInfo"; + version = "4.3.0"; + hash = "sha256-JyqOf5/lsUNLMpIqK8XffcFTxB6vHWzGWHssmojokCQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.fileversioninfo/4.3.0/system.diagnostics.fileversioninfo.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Process"; + version = "4.1.0"; + hash = "sha256-OgW6ogQ+oYADYS0PHmwXdhrOKQJpqXlwzSvmfjTLNBg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.process/4.1.0/system.diagnostics.process.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.StackTrace"; + version = "4.3.0"; + hash = "sha256-Tfq7F61N0VfujVyI5A9MZvyWewQ5HepB1f1UMBMkUCs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.stacktrace/4.3.0/system.diagnostics.stacktrace.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tools"; + version = "4.3.0"; + hash = "sha256-gVOv1SK6Ape0FQhCVlNOd9cvQKBvMxRX9K0JPVi8w0Y="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tools/4.3.0/system.diagnostics.tools.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.TraceSource"; + version = "4.0.0"; + hash = "sha256-cCjdPU7ow91HGf1hBIOLJMQGO6pNmF+N+5/Z38XJh9U="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracesource/4.0.0/system.diagnostics.tracesource.4.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.1.0"; + hash = "sha256-JA0jJcLbU3zh52ub3zweob2EVHvxOqiC6SCYHrY5WbQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracing/4.1.0/system.diagnostics.tracing.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracing/4.3.0/system.diagnostics.tracing.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.3.0"; + hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.dynamic.runtime/4.3.0/system.dynamic.runtime.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.0.11"; + hash = "sha256-rbSgc2PIEc2c2rN6LK3qCREAX3DqA2Nq1WcLrZYsDBw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization/4.0.11/system.globalization.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization/4.3.0/system.globalization.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.3.0"; + hash = "sha256-uNOD0EOVFgnS2fMKvMiEtI9aOw00+Pfy/H+qucAQlPc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization.calendars/4.3.0/system.globalization.calendars.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.1.0"; + hash = "sha256-V6oyQFwWb8NvGxAwvzWnhPxy9dKOfj/XBM3tEC5aHrw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io/4.1.0/system.io.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io/4.3.0/system.io.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.compression/4.3.0/system.io.compression.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.Compression.ZipFile"; + version = "4.3.0"; + hash = "sha256-WQl+JgWs+GaRMeiahTFUbrhlXIHapzcpTFXbRvAtvvs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.compression.zipfile/4.3.0/system.io.compression.zipfile.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.0.1"; + hash = "sha256-4VKXFgcGYCTWVXjAlniAVq0dO3o5s8KHylg2wg2/7k0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem/4.0.1/system.io.filesystem.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem/4.3.0/system.io.filesystem.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.0.1"; + hash = "sha256-IpigKMomqb6pmYWkrlf0ZdpILtRluX2cX5sOKVW0Feg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem.primitives/4.0.1/system.io.filesystem.primitives.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem.primitives/4.3.0/system.io.filesystem.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.1.0"; + hash = "sha256-ZQpFtYw5N1F1aX0jUK3Tw+XvM5tnlnshkTCNtfVA794="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.linq/4.1.0/system.linq.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.linq/4.3.0/system.linq.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.3.0"; + hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.linq.expressions/4.3.0/system.linq.expressions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Management"; + version = "4.5.0"; + hash = "sha256-mcsEl3a95O3oPO260hL3lpiaYaJhFPoWSbEHYYfo5ac="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.management/4.5.0/system.management.4.5.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.3"; + hash = "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.memory/4.5.3/system.memory.4.5.3.nupkg"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.memory/4.5.4/system.memory.4.5.4.nupkg"; + }) + (fetchNuGet { + pname = "System.Net.Http"; + version = "4.3.0"; + hash = "sha256-UoBB7WPDp2Bne/fwxKF0nE8grJ6FzTMXdT/jfsphj8Q="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.http/4.3.0/system.net.http.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.3.0"; + hash = "sha256-MY7Z6vOtFMbEKaLW9nOSZeAjcWpwCtdO7/W1mkGZBzE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.primitives/4.3.0/system.net.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Net.Sockets"; + version = "4.3.0"; + hash = "sha256-il7dr5VT/QWDg/0cuh+4Es2u8LY//+qqiY9BZmYxSus="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.sockets/4.3.0/system.net.sockets.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.4.0"; + hash = "sha256-auXQK2flL/JpnB/rEcAcUm4vYMCYMEMiWOCAlIaqu2U="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.numerics.vectors/4.4.0/system.numerics.vectors.4.4.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.numerics.vectors/4.5.0/system.numerics.vectors.4.5.0.nupkg"; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.0.12"; + hash = "sha256-MudZ/KYcvYsn2cST3EE049mLikrNkmE7QoUoYKKby+s="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.objectmodel/4.0.12/system.objectmodel.4.0.12.nupkg"; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.3.0"; + hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.objectmodel/4.3.0/system.objectmodel.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Private.DataContractSerialization"; + version = "4.1.1"; + hash = "sha256-OaE+ZcEfkpIkbdMOMAMiJa9vgiVP25FGuFrf+N/mafY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.private.datacontractserialization/4.1.1/system.private.datacontractserialization.4.1.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.1.0"; + hash = "sha256-idZHGH2Yl/hha1CM4VzLhsaR8Ljo/rV7TYe7mwRJSMs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection/4.1.0/system.reflection.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection/4.3.0/system.reflection.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.0.1"; + hash = "sha256-F1MvYoQWHCY89/O4JBwswogitqVvKuVfILFqA7dmuHk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit/4.0.1/system.reflection.emit.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.3.0"; + hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit/4.3.0/system.reflection.emit.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.0.1"; + hash = "sha256-YG+eJBG5P+5adsHiw/lhJwvREnvdHw6CJyS8ZV4Ujd0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit.ilgeneration/4.0.1/system.reflection.emit.ilgeneration.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.0.1"; + hash = "sha256-uVvNOnL64CPqsgZP2OLqNmxdkZl6Q0fTmKmv9gcBi+g="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit.lightweight/4.0.1/system.reflection.emit.lightweight.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.3.0"; + hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit.lightweight/4.3.0/system.reflection.emit.lightweight.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.0.1"; + hash = "sha256-NsfmzM9G/sN3H8X2cdnheTGRsh7zbRzvegnjDzDH/FQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.extensions/4.0.1/system.reflection.extensions.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.extensions/4.3.0/system.reflection.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "1.6.0"; + hash = "sha256-JJfgaPav7UfEh4yRAQdGhLZF1brr0tUWPl6qmfNWq/E="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadata/1.6.0/system.reflection.metadata.1.6.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "5.0.0"; + hash = "sha256-Wo+MiqhcP9dQ6NuFGrQTw6hpbJORFwp+TBNTq2yhGp8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadata/5.0.0/system.reflection.metadata.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.0.1"; + hash = "sha256-SFSfpWEyCBMAOerrMCOiKnpT+UAWTvRcmoRquJR6Vq0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.primitives/4.0.1/system.reflection.primitives.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.primitives/4.3.0/system.reflection.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.1.0"; + hash = "sha256-R0YZowmFda+xzKNR4kKg7neFoE30KfZwp/IwfRSKVK4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.typeextensions/4.1.0/system.reflection.typeextensions.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Resources.Extensions"; + version = "4.6.0"; + hash = "sha256-ErAPQRTkjRsica+h1mAFxMZbE4RrR9nH0/VB9mSCzEY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.extensions/4.6.0/system.resources.extensions.4.6.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Resources.Reader"; + version = "4.0.0"; + hash = "sha256-NOax26EYc/L4bfedL2a33fg4sFXVkBwzVTQ41saJTsk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.reader/4.0.0/system.resources.reader.4.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.0.1"; + hash = "sha256-cZ2/3/fczLjEpn6j3xkgQV9ouOVjy4Kisgw5xWw9kSw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.resourcemanager/4.0.1/system.resources.resourcemanager.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.resourcemanager/4.3.0/system.resources.resourcemanager.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.1.0"; + hash = "sha256-FViNGM/4oWtlP6w0JC0vJU+k9efLKZ+yaXrnEeabDQo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime/4.1.0/system.runtime.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime/4.3.0/system.runtime.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "5.0.0"; + hash = "sha256-neARSpLPUzPxEKhJRwoBzhPxK+cKIitLx7WBYncsYgo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.compilerservices.unsafe/5.0.0/system.runtime.compilerservices.unsafe.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.1.0"; + hash = "sha256-X7DZ5CbPY7jHs20YZ7bmcXs9B5Mxptu/HnBUvUnNhGc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.extensions/4.1.0/system.runtime.extensions.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.extensions/4.3.0/system.runtime.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.0.1"; + hash = "sha256-j2QgVO9ZOjv7D1het98CoFpjoYgxjupuIhuBUmLLH7w="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.handles/4.0.1/system.runtime.handles.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.handles/4.3.0/system.runtime.handles.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.1.0"; + hash = "sha256-QceAYlJvkPRJc/+5jR+wQpNNI3aqGySWWSO30e/FfQY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices/4.1.0/system.runtime.interopservices.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices/4.3.0/system.runtime.interopservices.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices.RuntimeInformation"; + version = "4.0.0"; + hash = "sha256-5j53amb76A3SPiE3B0llT2XPx058+CgE7OXL4bLalT4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices.runtimeinformation/4.0.0/system.runtime.interopservices.runtimeinformation.4.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices.RuntimeInformation"; + version = "4.3.0"; + hash = "sha256-MYpl6/ZyC6hjmzWRIe+iDoldOMW1mfbwXsduAnXIKGA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices.runtimeinformation/4.3.0/system.runtime.interopservices.runtimeinformation.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.3.0"; + hash = "sha256-P5jHCgMbgFMYiONvzmaKFeOqcAIDPu/U8bOVrNPYKqc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.numerics/4.3.0/system.runtime.numerics.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Serialization.Primitives"; + version = "4.1.1"; + hash = "sha256-80B05oxJbPLGq2pGOSl6NlZvintX9A1CNpna2aN0WRA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.serialization.primitives/4.1.1/system.runtime.serialization.primitives.4.1.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Serialization.Xml"; + version = "4.1.1"; + hash = "sha256-Mx/8hiqvp1E4I6ysJC3U8D2B9qhRQcVvEOivV6w65IQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.serialization.xml/4.1.1/system.runtime.serialization.xml.4.1.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "4.5.0"; + hash = "sha256-AFsKPb/nTk2/mqH/PYpaoI8PLsiKKimaXf+7Mb5VfPM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.accesscontrol/4.5.0/system.security.accesscontrol.4.5.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "4.7.0"; + hash = "sha256-/9ZCPIHLdhzq7OW4UKqTsR0O93jjHd6BRG1SRwgHE1g="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.accesscontrol/4.7.0/system.security.accesscontrol.4.7.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.3.0"; + hash = "sha256-tAJvNSlczYBJ3Ed24Ae27a55tq/n4D3fubNQdwcKWA8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.algorithms/4.3.0/system.security.cryptography.algorithms.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.3.0"; + hash = "sha256-Yuge89N6M+NcblcvXMeyHZ6kZDfwBv3LPMDiF8HhJss="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.encoding/4.3.0/system.security.cryptography.encoding.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.3.0"; + hash = "sha256-fnFi7B3SnVj5a+BbgXnbjnGNvWrCEU6Hp/wjsjWz318="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.primitives/4.3.0/system.security.cryptography.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.3.0"; + hash = "sha256-MG3V/owDh273GCUPsGGraNwaVpcydupl3EtPXj6TVG0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.x509certificates/4.3.0/system.security.cryptography.x509certificates.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Permissions"; + version = "4.7.0"; + hash = "sha256-BGgXMLUi5rxVmmChjIhcXUxisJjvlNToXlyaIbUxw40="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.permissions/4.7.0/system.security.permissions.4.7.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.5.0"; + hash = "sha256-BkUYNguz0e4NJp1kkW7aJBn3dyH9STwB5N8XqnlCsmY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.principal.windows/4.5.0/system.security.principal.windows.4.5.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.7.0"; + hash = "sha256-rWBM2U8Kq3rEdaa1MPZSYOOkbtMGgWyB8iPrpIqmpqg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.principal.windows/4.7.0/system.security.principal.windows.4.7.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.0.11"; + hash = "sha256-PEailOvG05CVgPTyKLtpAgRydlSHmtd5K0Y8GSHY2Lc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding/4.0.11/system.text.encoding.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding/4.3.0/system.text.encoding.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "4.0.1"; + hash = "sha256-wxtwWQSTv5tuFP79KhUAhaL6bL4d8lSzSWkCn9aolwM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.codepages/4.0.1/system.text.encoding.codepages.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "4.3.0"; + hash = "sha256-ezYVwe9atRkREc8O/HT/VfGDE2vuCpIckOfdY194/VE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.codepages/4.3.0/system.text.encoding.codepages.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.0.11"; + hash = "sha256-+kf7J3dEhgCbnCM5vHYlsTm5/R/Ud0Jr6elpHm922iI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.extensions/4.0.11/system.text.encoding.extensions.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.extensions/4.3.0/system.text.encoding.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "4.7.0"; + hash = "sha256-w3KhanXU1v+0uWZuLECd1oChvYeUrGhN5blk5WBco2k="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encodings.web/4.7.0/system.text.encodings.web.4.7.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "4.7.0"; + hash = "sha256-ubmcBH9pNdILnROdpGfnfo90WijLE6bUbKUypn3u4zo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.json/4.7.0/system.text.json.4.7.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.RegularExpressions"; + version = "4.1.0"; + hash = "sha256-x6OQN6MCN7S0fJ6EFTfv4rczdUWjwuWE9QQ0P6fbh9c="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.regularexpressions/4.1.0/system.text.regularexpressions.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.RegularExpressions"; + version = "4.3.0"; + hash = "sha256-VLCk1D1kcN2wbAe3d0YQM/PqCsPHOuqlBY1yd2Yo+K0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.regularexpressions/4.3.0/system.text.regularexpressions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.0.11"; + hash = "sha256-mob1Zv3qLQhQ1/xOLXZmYqpniNUMCfn02n8ZkaAhqac="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading/4.0.11/system.threading.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading/4.3.0/system.threading.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.0.11"; + hash = "sha256-5SLxzFg1df6bTm2t09xeI01wa5qQglqUwwJNlQPJIVs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks/4.0.11/system.threading.tasks.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks/4.3.0/system.threading.tasks.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Dataflow"; + version = "4.9.0"; + hash = "sha256-ZTZBJTrP5kzO38ec9lPxuNUYgEoeGNdQ8hF98uRN2rw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.dataflow/4.9.0/system.threading.tasks.dataflow.4.9.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.0.0"; + hash = "sha256-+YdcPkMhZhRbMZHnfsDwpNbUkr31X7pQFGxXYcAPZbE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.extensions/4.0.0/system.threading.tasks.extensions.4.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.3.0"; + hash = "sha256-X2hQ5j+fxcmnm88Le/kSavjiGOmkcumBGTZKBLvorPc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.extensions/4.3.0/system.threading.tasks.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.2"; + hash = "sha256-EqJF9TppMHTKvpR6emrdA61zalMW3HwrZ7j6Bn4bBuo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.extensions/4.5.2/system.threading.tasks.extensions.4.5.2.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Parallel"; + version = "4.0.1"; + hash = "sha256-5VyRZ97Fug4reK/cQ6wsCrJ5jH53aGu1a4ZkKMZrnIQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.parallel/4.0.1/system.threading.tasks.parallel.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Parallel"; + version = "4.3.0"; + hash = "sha256-8H2vRmsn29MNfMmCeIL5vHfbM19jWaLDKNLzDonCI+c="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.parallel/4.3.0/system.threading.tasks.parallel.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Thread"; + version = "4.0.0"; + hash = "sha256-7EtSJuKqcW107FYA5Ko9NFXEWUPIzNDtlfKaQV2pvb8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.thread/4.0.0/system.threading.thread.4.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Thread"; + version = "4.3.0"; + hash = "sha256-pMs6RNFC3nQOGz9EqIcyWmO8YLaqay+q/Qde5hqPXXg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.thread/4.3.0/system.threading.thread.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Timer"; + version = "4.0.1"; + hash = "sha256-5lU6zt1O9JDSPr2KAHw4BYgysHnt0yyZrMNa5IIjxZY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.timer/4.0.1/system.threading.timer.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Timer"; + version = "4.3.0"; + hash = "sha256-pmhslmhQhP32TWbBzoITLZ4BoORBqYk25OWbru04p9s="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.timer/4.3.0/system.threading.timer.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.ValueTuple"; + version = "4.5.0"; + hash = "sha256-niH6l2fU52vAzuBlwdQMw0OEoRS/7E1w5smBFoqSaAI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.valuetuple/4.5.0/system.valuetuple.4.5.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.0.11"; + hash = "sha256-haZAFFQ9Sl2DhfvEbdx2YRqKEoxNMU5STaqpMmXw0zA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.readerwriter/4.0.11/system.xml.readerwriter.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.3.0"; + hash = "sha256-QQ8KgU0lu4F5Unh+TbechO//zaAGZ4MfgvW72Cn1hzA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.readerwriter/4.3.0/system.xml.readerwriter.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Xml.XDocument"; + version = "4.3.0"; + hash = "sha256-rWtdcmcuElNOSzCehflyKwHkDRpiOhJJs8CeQ0l1CCI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.xdocument/4.3.0/system.xml.xdocument.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Xml.XmlDocument"; + version = "4.0.1"; + hash = "sha256-gdoFrPo54v1LjkBF79f8EvtltVVjHz9ZI9kc5ve0GkY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.xmldocument/4.0.1/system.xml.xmldocument.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Xml.XmlDocument"; + version = "4.3.0"; + hash = "sha256-kbuV4Y7rVJkfMp2Kgoi8Zvdatm9CZNmlKB3GZgANvy4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.xmldocument/4.3.0/system.xml.xmldocument.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Xml.XmlSerializer"; + version = "4.0.11"; + hash = "sha256-v6x4d6W18dijG5cDqQmVHdtWRf6Y4OkdBolT3d5g3wY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.xmlserializer/4.0.11/system.xml.xmlserializer.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Xml.XPath"; + version = "4.3.0"; + hash = "sha256-kd1JMqj6obhxzEPRJeYvcUyJqkOs/9A0UOQccC6oYrM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.xpath/4.3.0/system.xml.xpath.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Xml.XPath.XDocument"; + version = "4.3.0"; + hash = "sha256-dqk4CWuwocj5qsUAYlS+XAe6GGcY/N/HIPEGe5afrPM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.xml.xpath.xdocument/4.3.0/system.xml.xpath.xdocument.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "vswhere"; + version = "2.6.7"; + hash = "sha256-kzMH9TNexExGSutkXHIWpydXgjlbd+L+H8Oca1Isk0A="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/vswhere/2.6.7/vswhere.2.6.7.nupkg"; + }) + (fetchNuGet { + pname = "XliffTasks"; + version = "1.0.0-beta.20502.2"; + hash = "sha256-ICnkCRBS+hsuFtwNPS7ux2ZQAttaAgCX/HTBzp5qY54="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/xlifftasks/1.0.0-beta.20502.2/xlifftasks.1.0.0-beta.20502.2.nupkg"; + }) + (fetchNuGet { + pname = "xunit"; + version = "2.4.1"; + hash = "sha256-QGDuE0ZnsxyEJONP8GcJ80PmPeb+OawwdSW8y72aw3U="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit/2.4.1/xunit.2.4.1.nupkg"; + }) + (fetchNuGet { + pname = "xunit.abstractions"; + version = "2.0.3"; + hash = "sha256-0D1y/C34iARI96gb3bAOG8tcGPMjx+fMabTPpydGlAM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.abstractions/2.0.3/xunit.abstractions.2.0.3.nupkg"; + }) + (fetchNuGet { + pname = "xunit.analyzers"; + version = "0.10.0"; + hash = "sha256-8lRZhogXHYksa9ChnkFXpBnTMlLlYIvu3Av7qQYWwJY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.analyzers/0.10.0/xunit.analyzers.0.10.0.nupkg"; + }) + (fetchNuGet { + pname = "xunit.assert"; + version = "2.4.1"; + hash = "sha256-hl1cMSakAlwkpFEchxCNMdvQie6PMJ1uFrhzgOC3vsY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.assert/2.4.1/xunit.assert.2.4.1.nupkg"; + }) + (fetchNuGet { + pname = "xunit.core"; + version = "2.4.1"; + hash = "sha256-KgUgAIJIPHQ5VQ4FiB+i5u2JXSYxmvMCV8zXP4kcy9o="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.core/2.4.1/xunit.core.2.4.1.nupkg"; + }) + (fetchNuGet { + pname = "xunit.extensibility.core"; + version = "2.4.1"; + hash = "sha256-oACVOrvF4XmKFr+8ZqPVpjbopZgeRwaXveJGW2XUeIA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.extensibility.core/2.4.1/xunit.extensibility.core.2.4.1.nupkg"; + }) + (fetchNuGet { + pname = "xunit.extensibility.execution"; + version = "2.4.1"; + hash = "sha256-KmKEdgsUq4zuQJ2saJA0YT1CIZ2AuhZL5V7cF2Cncd0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.extensibility.execution/2.4.1/xunit.extensibility.execution.2.4.1.nupkg"; + }) + (fetchNuGet { + pname = "xunit.runner.console"; + version = "2.4.1"; + hash = "sha256-I/C0ntv+W+j4VU5/QxejkJSbuWvbL4MJ6+J8aFX6048="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.runner.console/2.4.1/xunit.runner.console.2.4.1.nupkg"; + }) + (fetchNuGet { + pname = "xunit.runner.visualstudio"; + version = "2.4.3"; + hash = "sha256-42axn0yDDiJWKV8UEYzYWgiKbpc6mHh9M/eeylYGLUg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/xunit.runner.visualstudio/2.4.3/xunit.runner.visualstudio.2.4.3.nupkg"; + }) ] diff --git a/pkgs/by-name/ms/mscgen/package.nix b/pkgs/by-name/ms/mscgen/package.nix index 4af5c9b648e929..4bf3c3ddd1c890 100644 --- a/pkgs/by-name/ms/mscgen/package.nix +++ b/pkgs/by-name/ms/mscgen/package.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, bison -, fetchurl -, flex -, gd -, libjpeg -, libpng -, libwebp -, pkg-config -, runtimeShell -, zlib +{ + lib, + stdenv, + bison, + fetchurl, + flex, + gd, + libjpeg, + libpng, + libwebp, + pkg-config, + runtimeShell, + zlib, }: stdenv.mkDerivation rec { @@ -20,15 +22,28 @@ stdenv.mkDerivation rec { sha256 = "3c3481ae0599e1c2d30b7ed54ab45249127533ab2f20e768a0ae58d8551ddc23"; }; - nativeBuildInputs = [ bison flex pkg-config ]; - buildInputs = [ gd libjpeg libpng libwebp zlib ]; + nativeBuildInputs = [ + bison + flex + pkg-config + ]; + buildInputs = [ + gd + libjpeg + libpng + libwebp + zlib + ]; doCheck = true; preCheck = '' sed -i -e "s|#!/bin/bash|#!${runtimeShell}|" test/renderercheck.sh ''; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; meta = { homepage = "http://www.mcternan.me.uk/mscgen/"; diff --git a/pkgs/by-name/ms/mscompress/package.nix b/pkgs/by-name/ms/mscompress/package.nix index e6bc49feb18713..c6974027cafbb9 100644 --- a/pkgs/by-name/ms/mscompress/package.nix +++ b/pkgs/by-name/ms/mscompress/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ms/msfpc/package.nix b/pkgs/by-name/ms/msfpc/package.nix index afc67cc4dde37a..74d04f76e0eb48 100644 --- a/pkgs/by-name/ms/msfpc/package.nix +++ b/pkgs/by-name/ms/msfpc/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, metasploit, curl, inetutils, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + metasploit, + curl, + inetutils, + openssl, +}: stdenv.mkDerivation rec { pname = "msfpc"; @@ -25,7 +34,14 @@ stdenv.mkDerivation rec { postFixup = '' wrapProgram $out/bin/msfpc \ - --prefix PATH : "${lib.makeBinPath [ metasploit curl inetutils openssl ]}" + --prefix PATH : "${ + lib.makeBinPath [ + metasploit + curl + inetutils + openssl + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/ms/msgpack-c/package.nix b/pkgs/by-name/ms/msgpack-c/package.nix index 103831e7c06b52..f4b74a9abf9920 100644 --- a/pkgs/by-name/ms/msgpack-c/package.nix +++ b/pkgs/by-name/ms/msgpack-c/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gtest -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gtest, + zlib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ms/msgpack-tools/package.nix b/pkgs/by-name/ms/msgpack-tools/package.nix index 382dd8fd306b95..e62af58ae1c10f 100644 --- a/pkgs/by-name/ms/msgpack-tools/package.nix +++ b/pkgs/by-name/ms/msgpack-tools/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "msgpack-tools"; diff --git a/pkgs/by-name/ms/msgpack/generic.nix b/pkgs/by-name/ms/msgpack/generic.nix index a784bc0263613a..0e966b6c63ffb3 100644 --- a/pkgs/by-name/ms/msgpack/generic.nix +++ b/pkgs/by-name/ms/msgpack/generic.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, cmake -, version, src, patches ? [ ] -, ... +{ + lib, + stdenv, + cmake, + version, + src, + patches ? [ ], + ... }: stdenv.mkDerivation { @@ -11,13 +16,15 @@ stdenv.mkDerivation { nativeBuildInputs = [ cmake ]; - cmakeFlags = lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "-DMSGPACK_BUILD_EXAMPLES=OFF"; + cmakeFlags = lib.optional ( + stdenv.hostPlatform != stdenv.buildPlatform + ) "-DMSGPACK_BUILD_EXAMPLES=OFF"; meta = with lib; { description = "MessagePack implementation for C and C++"; - homepage = "https://msgpack.org"; - license = licenses.asl20; + homepage = "https://msgpack.org"; + license = licenses.asl20; maintainers = with maintainers; [ redbaron ]; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/ms/msgpack/package.nix b/pkgs/by-name/ms/msgpack/package.nix index d040eff11a322b..24ab0a74a51131 100644 --- a/pkgs/by-name/ms/msgpack/package.nix +++ b/pkgs/by-name/ms/msgpack/package.nix @@ -1,12 +1,15 @@ -{ callPackage, fetchFromGitHub, ... } @ args: +{ callPackage, fetchFromGitHub, ... }@args: -callPackage ./generic.nix (args // rec { - version = "3.3.0"; +callPackage ./generic.nix ( + args + // rec { + version = "3.3.0"; - src = fetchFromGitHub { - owner = "msgpack"; - repo = "msgpack-c"; - rev = "cpp-${version}"; - sha256 = "02dxgzxlwn8g9ca2j4m0rjvdq1k2iciy6ickj615daz5w8pcjajd"; - }; -}) + src = fetchFromGitHub { + owner = "msgpack"; + repo = "msgpack-c"; + rev = "cpp-${version}"; + sha256 = "02dxgzxlwn8g9ca2j4m0rjvdq1k2iciy6ickj615daz5w8pcjajd"; + }; + } +) diff --git a/pkgs/by-name/ms/msgpuck/package.nix b/pkgs/by-name/ms/msgpuck/package.nix index a21dd799e0fc84..41fdca7052def1 100644 --- a/pkgs/by-name/ms/msgpuck/package.nix +++ b/pkgs/by-name/ms/msgpuck/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "msgpuck"; @@ -11,15 +17,21 @@ stdenv.mkDerivation rec { sha256 = "0cjq86kncn3lv65vig9cqkqqv2p296ymcjjbviw0j1s85cfflps0"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; meta = with lib; { - description = "Simple and efficient MsgPack binary serialization library in a self-contained header file"; - homepage = "https://github.com/rtsisyk/msgpuck"; - license = licenses.bsd2; - platforms = platforms.all; - maintainers = with maintainers; [ izorkin ]; - }; + description = "Simple and efficient MsgPack binary serialization library in a self-contained header file"; + homepage = "https://github.com/rtsisyk/msgpuck"; + license = licenses.bsd2; + platforms = platforms.all; + maintainers = with maintainers; [ izorkin ]; + }; } diff --git a/pkgs/by-name/ms/msgraph-cli/deps.nix b/pkgs/by-name/ms/msgraph-cli/deps.nix index e2ad995943b43d..d446a33445778d 100644 --- a/pkgs/by-name/ms/msgraph-cli/deps.nix +++ b/pkgs/by-name/ms/msgraph-cli/deps.nix @@ -1,220 +1,1081 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Azure.Core"; version = "1.36.0"; hash = "sha256-lokfjW2wvgFu6bALLzNmDhXIz3HXoPuGX0WfGb9hmpI="; }) - (fetchNuGet { pname = "Azure.Core"; version = "1.37.0"; hash = "sha256-ETDRf0+cNgVa1udMkhjYkOLP5Hd0NtiSQqAZHCjevds="; }) - (fetchNuGet { pname = "Azure.Identity"; version = "1.10.4"; hash = "sha256-wjopxd/bq0IjdZd5C69XLITrKz8+TFxc0YsPcj8sZHA="; }) - (fetchNuGet { pname = "JmesPath.Net"; version = "1.0.330"; hash = "sha256-FfSgpXmgaFg1uNzJjyJKjU1GZQAo64Og449EByhmKsc="; }) - (fetchNuGet { pname = "JmesPath.Net.Parser"; version = "1.0.330"; hash = "sha256-xJxWkfve/tpeFmX4YRW9SK8z1cT8dMCwwqEhOudi9og="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "1.1.1"; hash = "sha256-fAcX4sxE0veWM1CZBtXR/Unky+6sE33yrV7ohrWGKig="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "8.0.0"; hash = "sha256-9BPsASlxrV8ilmMCjdb3TiUcm5vFZxkBnAI/fNBSEyA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "6.0.0"; hash = "sha256-Evg+Ynj2QUa6Gz+zqF+bUyfGD0HI5A2fHmxZEXbn3HA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "8.0.0"; hash = "sha256-4eBpDkf7MJozTZnOwQvwcfgRKQGcNXe0K/kF+h5Rl8o="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "6.0.0"; hash = "sha256-7NZcKkiXWSuhhVcA/fXHPY/62aGUyMsRdiHm91cWC5Y="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "8.0.0"; hash = "sha256-GanfInGzzoN2bKeNwON8/Hnamr6l7RTpYLA49CNXD9Q="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.CommandLine"; version = "6.0.0"; hash = "sha256-jFACPqLvGo14eg4G3hV/UYY/d9i3hNKvgL+3nnDGZME="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.CommandLine"; version = "8.0.0"; hash = "sha256-fmPC/o8S+weTtQJWykpnGHm6AKVU21xYE/CaHYU7zgg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; version = "6.0.0"; hash = "sha256-tG3DEWURVkQHm4MlmxjE/YouTp9wQKbWs6qHH2nfgqc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; version = "8.0.0"; hash = "sha256-+bjFZvqCsMf2FRM2olqx/fub+QwfM1kBhjGVOT5HC48="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.FileExtensions"; version = "6.0.0"; hash = "sha256-PLnSa0JMfDC62OTv8sL0QFJbANE7QSnJ997ySFBS1go="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.FileExtensions"; version = "8.0.0"; hash = "sha256-BCxcjVP+kvrDDB0nzsFCJfU74UK4VBvct2JA4r+jNcs="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Json"; version = "8.0.0"; hash = "sha256-Fi/ijcG5l0BOu7i96xHu96aN5/g7zO6SWQbTsI3Qetg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.UserSecrets"; version = "6.0.0"; hash = "sha256-b+y3HRjUm+CfZhChVdMoN0HTXmWxrs4yiC7yM6psGmc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.UserSecrets"; version = "8.0.0"; hash = "sha256-/yj5QaEzeRStvOFoBpPRPXlEehGtr2E6/rJb+OEPIK8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "6.0.0"; hash = "sha256-gZuMaunMJVyvvepuzNodGPRc6eqKH//bks3957dYkPI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "8.0.0"; hash = "sha256-+qIDR8hRzreCHNEDtUcPfVHQdurzWPo/mqviCH78+EQ="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "6.0.0"; hash = "sha256-SZke0jNKIqJvvukdta+MgIlGsrP2EdPkkS8lfLg7Ju4="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.0"; hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Diagnostics"; version = "8.0.0"; hash = "sha256-fBLlb9xAfTgZb1cpBxFs/9eA+BlBvF8Xg0DMkBqdHD4="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Diagnostics.Abstractions"; version = "8.0.0"; hash = "sha256-USD5uZOaahMqi6u7owNWx/LR4EDrOwqPrAAim7iRpJY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "6.0.0"; hash = "sha256-uBjWjHKEXjZ9fDfFxMjOou3lhfTNhs1yO+e3fpWreLk="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "8.0.0"; hash = "sha256-uQSXmt47X2HGoVniavjLICbPtD2ReQOYQMgy3l0xuMU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Physical"; version = "6.0.0"; hash = "sha256-5BAQOqnaEXM2YjdrmrCinXBeZ5FKxCWtebEXMdwcbMY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Physical"; version = "8.0.0"; hash = "sha256-29y5ZRQ1ZgzVOxHktYxyiH40kVgm5un2yTGdvuSWnRc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileSystemGlobbing"; version = "6.0.0"; hash = "sha256-RAWHjkkfvGpjc49Q0kJbZyXgU6UEq/EJ0j557sj2/iU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileSystemGlobbing"; version = "8.0.0"; hash = "sha256-+Oz41JR5jdcJlCJOSpQIL5OMBNi+1Hl2d0JUHfES7sU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting"; version = "6.0.0"; hash = "sha256-ux2aROPMS7aCyfDgRn7DmIrg5M2UlK00vPjfUWGC/kA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting"; version = "8.0.0"; hash = "sha256-sKHa+w4/pMeQb5RRFqLtMTUJy5H6hSIGWchbH2pxSrg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting.Abstractions"; version = "6.0.0"; hash = "sha256-ksIPO6RhfbYx/i3su4J3sDhoL+TDnITKsgIpEqnpktc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting.Abstractions"; version = "8.0.0"; hash = "sha256-0JBx+wwt5p1SPfO4m49KxNOXPAzAU0A+8tEc/itvpQE="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Http"; version = "8.0.0"; hash = "sha256-UgljypOLld1lL7k7h1noazNzvyEHIJw+r+6uGzucFSY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "6.0.0"; hash = "sha256-8WsZKRGfXW5MsXkMmNVf6slrkw+cR005czkOP2KUqTk="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "8.0.0"; hash = "sha256-Meh0Z0X7KyOEG4l0RWBcuHHihcABcvCyfUXgasmQ91o="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "6.0.0"; hash = "sha256-QNqcQ3x+MOK7lXbWkCzSOWa/2QyYNbdM/OEEbWN15Sw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "8.0.0"; hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Configuration"; version = "6.0.0"; hash = "sha256-IeMOza71UDzsEIVIlYuI0RYKk+d+VOC6zCqYCQs6nV4="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Configuration"; version = "8.0.0"; hash = "sha256-mzmstNsVjKT0EtQcdAukGRifD30T82BMGYlSu8k4K7U="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Console"; version = "8.0.0"; hash = "sha256-bdb9YWWVn//AeySp7se87/tCN2E7e8Gx2GPMw28cd9c="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Debug"; version = "6.0.0"; hash = "sha256-kweko71W7/hIAUO3ZYYbNXksVLgj8wrDN028QthMFCs="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Debug"; version = "8.0.0"; hash = "sha256-AJunzYBZM2wCg86hnPnMrBuWIIyW/4PnIVoDSU969cA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.EventLog"; version = "6.0.0"; hash = "sha256-1BXQjw/ySWmddAZ79bv3OhmC4SPTG8PHyTOlrNEUb0g="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.EventLog"; version = "8.0.0"; hash = "sha256-vXBm4yhWGP4uow0CqstuqOkxO8yeZEM15JTTenjPbhc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.EventSource"; version = "6.0.0"; hash = "sha256-j2Begn1+Xoa+9yPoQC6b6aPmUIpBrjkTGQhRhYfJaDI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.EventSource"; version = "8.0.0"; hash = "sha256-kaR7YOlq5s8W9nZDtH/lKtnfGbrgOuQY4DUPcA2lcj0="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "6.0.0"; hash = "sha256-DxnEgGiCXpkrxFkxXtOXqwaiAtoIjA8VSSWCcsW0FwE="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "8.0.0"; hash = "sha256-n2m4JSegQKUTlOsKLZUUHHKMq926eJ0w9N9G+I3FoFw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; version = "6.0.0"; hash = "sha256-au0Y13cGk/dQFKuvSA5NnP/++bErTk0oOTlgmHdI2Mw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; version = "8.0.0"; hash = "sha256-A5Bbzw1kiNkgirk5x8kyxwg9lLTcSngojeD+ocpG1RI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "6.0.0"; hash = "sha256-AgvysszpQ11AiTBJFkvSy8JnwIWTj15Pfek7T7ThUc4="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "8.0.0"; hash = "sha256-FU8qj3DR8bDdc1c+WeGZx/PCZeqqndweZM9epcpXjSo="; }) - (fetchNuGet { pname = "Microsoft.Graph.Cli.Core"; version = "1.2.1"; hash = "sha256-aS8p5p6v2BLMwYq4MsPqzPNuyvli+cck0If8zew1Tg8="; }) - (fetchNuGet { pname = "Microsoft.Graph.Core"; version = "3.1.7"; hash = "sha256-OVAc7SpKYtY9IP83TGpy7F2lLR7rTJ6XBR+2JAVPWAU="; }) - (fetchNuGet { pname = "Microsoft.Identity.Client"; version = "4.56.0"; hash = "sha256-vXd9uZ1AoThcVIBmOZbMrP2xIjpoInWM9iP1pzCSnmc="; }) - (fetchNuGet { pname = "Microsoft.Identity.Client.Extensions.Msal"; version = "4.56.0"; hash = "sha256-FQF6kIDzNLxtaVnVDBMFryfTuj6T5pCx92GN6aYhmN0="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.Abstractions"; version = "6.22.0"; hash = "sha256-P+7razdzKHXujmkfYfw7ZCK/MvhqNqCJ9kuxFEUsiRg="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.Abstractions"; version = "7.3.1"; hash = "sha256-lbZKfnulWcM4Mxbz6Hkrp/lM41hsOfCnsHLEb+u2czc="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.JsonWebTokens"; version = "7.3.1"; hash = "sha256-C7uySnKBB0e5Wf6z8YNtjbtBbhalJMdqx0EWVcYy7Q4="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.Logging"; version = "7.3.1"; hash = "sha256-6OHGsItAXicCSlW0ghCy5szNi6HwhlCmbykbN1O5yAw="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.Protocols"; version = "7.3.1"; hash = "sha256-bBEbYXtPGNqsJiSZ7Kx3kcP1ZbosqPrGyu1PIfFPIeA="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.Protocols.OpenIdConnect"; version = "7.3.1"; hash = "sha256-NWw7q26IZAKiQQILU1qLeNVkMxE9rX0NwUubWAcoBiE="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.Tokens"; version = "7.3.1"; hash = "sha256-qfTNU0g9QA8kV42VTAez1pSTmfFRJBbeTbGn/nfGFUU="; }) - (fetchNuGet { pname = "Microsoft.Kiota.Abstractions"; version = "1.7.5"; hash = "sha256-g2ShFodiwkMofAMAbuYiUTXn21yLWyaYeDzAAikTY60="; }) - (fetchNuGet { pname = "Microsoft.Kiota.Abstractions"; version = "1.7.8"; hash = "sha256-209eh7BsL2Y0SZZbj3ABZXZQeq5bFiGRA2k4Dia9nLs="; }) - (fetchNuGet { pname = "Microsoft.Kiota.Abstractions"; version = "1.7.9"; hash = "sha256-zRAtEMarPRwJY985Morh+enZXrqO+gDpLH2K9HVCIQI="; }) - (fetchNuGet { pname = "Microsoft.Kiota.Authentication.Azure"; version = "1.1.3"; hash = "sha256-eNfXJ4Ab+55c15w5QEHzUy0nkxXK5fhPSw+waiSxJ8k="; }) - (fetchNuGet { pname = "Microsoft.Kiota.Cli.Commons"; version = "1.1.0"; hash = "sha256-+ieR78qQpeCLGo7TSEzSYE52zaBC6oASvPusOf2eHaY="; }) - (fetchNuGet { pname = "Microsoft.Kiota.Http.HttpClientLibrary"; version = "1.3.6"; hash = "sha256-w79hmlcGlkky8HK8Cy24iWXhn1UdmQCpgIJ9n3Z3kHA="; }) - (fetchNuGet { pname = "Microsoft.Kiota.Serialization.Form"; version = "1.1.3"; hash = "sha256-bY9XhBO618WaP8N3WWS7lKNkzsb0UG+0vyo85/ROk2s="; }) - (fetchNuGet { pname = "Microsoft.Kiota.Serialization.Json"; version = "1.1.5"; hash = "sha256-BSWIlNwGkceO4WHFGmD0PSQhlDf0J4EAq+66LXOZkuI="; }) - (fetchNuGet { pname = "Microsoft.Kiota.Serialization.Multipart"; version = "1.1.2"; hash = "sha256-co1iP+5YB9xdsfj73pzRh9PYWP/lVDzMv64klJeVvAs="; }) - (fetchNuGet { pname = "Microsoft.Kiota.Serialization.Text"; version = "1.1.2"; hash = "sha256-TXTNr/15sJnGQ0qJuFGvu2apZHXRWtVcVjpAO2dLaEE="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "5.0.0"; hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.3.0"; hash = "sha256-mBNDmPXNTW54XLnPAUwBRvkIORFM7/j0D0I2SyQPDEg="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "1.6.1"; hash = "sha256-iNan1ix7RtncGWC9AjAZ2sk70DoxOsmEOgQ10fXm4Pw="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.1"; hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tools"; version = "4.3.0"; hash = "sha256-8yLKFt2wQxkEf7fNfzB+cPUCjYn2qbqNgQ1+EeY2h/I="; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-dsmTLGvt8HqRkDWP8iKVXJCS+akAzENGXKPV18W2RgI="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization.Calendars"; version = "4.3.0"; hash = "sha256-AYh39tgXJVFu8aLi9Y/4rK8yWMaza4S4eaxjfcuEEL4="; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-6MYj0RmLh4EVqMtO/MRqBi0HOn5iG4x9JimgCCJ+EFM="; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Timer"; version = "4.3.0"; hash = "sha256-BgHxXCIbicVZtpgMimSXixhFC3V+p5ODqeljDjO8hCs="; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; }) - (fetchNuGet { pname = "runtime.native.System.IO.Compression"; version = "4.3.0"; hash = "sha256-DWnXs4vlKoU6WxxvCArTJupV6sX3iBbZh8SbqfHace8="; }) - (fetchNuGet { pname = "runtime.native.System.Net.Http"; version = "4.3.0"; hash = "sha256-c556PyheRwpYhweBjSfIwEyZHnAUB8jWioyKEcp/2dg="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; hash = "sha256-2IhBv0i6pTcOyr8FFIyfPEaaCHUmJZ8DYwLUwJ+5waw="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; hash = "sha256-serkd4A7F6eciPiPJtUyJyxzdAtupEcWIZQ9nptEzIM="; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; }) - (fetchNuGet { pname = "runtime.unix.Microsoft.Win32.Primitives"; version = "4.3.0"; hash = "sha256-LZb23lRXzr26tRS5aA0xyB08JxiblPDoA7HBvn6awXg="; }) - (fetchNuGet { pname = "runtime.unix.System.Console"; version = "4.3.0"; hash = "sha256-AHkdKShTRHttqfMjmi+lPpTuCrM5vd/WRy6Kbtie190="; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; }) - (fetchNuGet { pname = "runtime.unix.System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-Pf4mRl6YDK2x2KMh0WdyNgv0VUNdSKVDLlHqozecy5I="; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Primitives"; version = "4.3.0"; hash = "sha256-pHJ+I6i16MV6m77uhTC6GPY6jWGReE3SSP3fVB59ti0="; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Sockets"; version = "4.3.0"; hash = "sha256-IvgOeA2JuBjKl5yAVGjPYMPDzs9phb3KANs95H9v1w4="; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; }) - (fetchNuGet { pname = "Spectre.Console"; version = "0.48.0"; hash = "sha256-hr7BkVJ5v+NOPytlINjo+yoJetRUKmBhZbTMVKOMf2w="; }) - (fetchNuGet { pname = "Springcomp.GPLEX.Runtime"; version = "1.2.4"; hash = "sha256-WrdQVnuoJMWD4q+j7qW5nKL1jjj/YKb2lafHMsKNS/Y="; }) - (fetchNuGet { pname = "Springcomp.GPPG.Runtime"; version = "1.2.4"; hash = "sha256-M6JRE/uW8WwV8UsQi8ROKII+zFW+ROpvE9b1ig+kcic="; }) - (fetchNuGet { pname = "Std.UriTemplate"; version = "0.0.50"; hash = "sha256-Wkxk3YQ3datFXVrPSuzBqtrWEmLkIQUeiBwuQb+E+aM="; }) - (fetchNuGet { pname = "System.AppContext"; version = "4.3.0"; hash = "sha256-yg95LNQOwFlA1tWxXdQkVyJqT4AnoDc+ACmrNvzGiZg="; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.3.0"; hash = "sha256-XqZWb4Kd04960h4U9seivjKseGA/YEIpdplfHYHQ9jk="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.3.0"; hash = "sha256-KMY5DfJnDeIsa13DpqvyN8NkReZEMAFnlmNglVoFIXI="; }) - (fetchNuGet { pname = "System.CommandLine"; version = "2.0.0-beta4.22272.1"; hash = "sha256-zSO+CYnMH8deBHDI9DHhCPj79Ce3GOzHCyH1/TiHxcc="; }) - (fetchNuGet { pname = "System.CommandLine.Hosting"; version = "0.4.0-alpha.22272.1"; hash = "sha256-tmzZU+FBdao8Jp2v+K+HHfc9QXpGBr5EY4X8+dNPceY="; }) - (fetchNuGet { pname = "System.CommandLine.NamingConventionBinder"; version = "2.0.0-beta4.22272.1"; hash = "sha256-Ffzs51XiFraSX1efQRO1IyiNraIgi8aOdkRRzCT6DB4="; }) - (fetchNuGet { pname = "System.Console"; version = "4.3.0"; hash = "sha256-Xh3PPBZr0pDbDaK8AEHbdGz7ePK6Yi1ZyRWI1JM6mbo="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "4.3.0"; hash = "sha256-OFJRb0ygep0Z3yDBLwAgM/Tkfs4JCDtsNhwDH9cd1Xw="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "6.0.0"; hash = "sha256-RY9uWSPdK2fgSwlj1OHBGBVo3ZvGQgBJNzAsS5OGMWc="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "6.0.1"; hash = "sha256-Xi8wrUjVlioz//TPQjFHqcV/QGhTqnTfUcltsNlcCJ4="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "8.0.0"; hash = "sha256-+aODaDEQMqla5RYZeq0Lh66j+xkPYxykrVvSCmJQ+Vs="; }) - (fetchNuGet { pname = "System.Diagnostics.EventLog"; version = "6.0.0"; hash = "sha256-zUXIQtAFKbiUMKCrXzO4mOTD5EUphZzghBYKXprowSM="; }) - (fetchNuGet { pname = "System.Diagnostics.EventLog"; version = "8.0.0"; hash = "sha256-rt8xc3kddpQY4HEdghlBeOK4gdw5yIj4mcZhAVtk2/Y="; }) - (fetchNuGet { pname = "System.Diagnostics.Tools"; version = "4.3.0"; hash = "sha256-gVOv1SK6Ape0FQhCVlNOd9cvQKBvMxRX9K0JPVi8w0Y="; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.3.0"; hash = "sha256-uNOD0EOVFgnS2fMKvMiEtI9aOw00+Pfy/H+qucAQlPc="; }) - (fetchNuGet { pname = "System.Globalization.Extensions"; version = "4.3.0"; hash = "sha256-mmJWA27T0GRVuFP9/sj+4TrR4GJWrzNIk2PDrbr7RQk="; }) - (fetchNuGet { pname = "System.IdentityModel.Tokens.Jwt"; version = "7.3.1"; hash = "sha256-Si60aDtJSjvXvY5ZkVQKF3JzxAkmkAKOw5D/q8CwuyQ="; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; }) - (fetchNuGet { pname = "System.IO.Compression"; version = "4.3.0"; hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; }) - (fetchNuGet { pname = "System.IO.Compression.ZipFile"; version = "4.3.0"; hash = "sha256-WQl+JgWs+GaRMeiahTFUbrhlXIHapzcpTFXbRvAtvvs="; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; }) - (fetchNuGet { pname = "System.IO.FileSystem.AccessControl"; version = "5.0.0"; hash = "sha256-c9MlDKJfj63YRvl7brRBNs59olrmbL+G1A6oTS8ytEc="; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.3.0"; hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.5"; hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; }) - (fetchNuGet { pname = "System.Memory.Data"; version = "1.0.2"; hash = "sha256-XiVrVQZQIz4NgjiK/wtH8iZhhOZ9MJ+X2hL2/8BrGN0="; }) - (fetchNuGet { pname = "System.Net.Http"; version = "4.3.0"; hash = "sha256-UoBB7WPDp2Bne/fwxKF0nE8grJ6FzTMXdT/jfsphj8Q="; }) - (fetchNuGet { pname = "System.Net.NameResolution"; version = "4.3.0"; hash = "sha256-eGZwCBExWsnirWBHyp2sSSSXp6g7I6v53qNmwPgtJ5c="; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.3.0"; hash = "sha256-MY7Z6vOtFMbEKaLW9nOSZeAjcWpwCtdO7/W1mkGZBzE="; }) - (fetchNuGet { pname = "System.Net.Sockets"; version = "4.3.0"; hash = "sha256-il7dr5VT/QWDg/0cuh+4Es2u8LY//+qqiY9BZmYxSus="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.3.0"; hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.3.0"; hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.3.0"; hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.3.0"; hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.7.0"; hash = "sha256-GEtCGXwtOnkYejSV+Tfl+DqyGq5jTUaVyL9eMupMHBM="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices.RuntimeInformation"; version = "4.3.0"; hash = "sha256-MYpl6/ZyC6hjmzWRIe+iDoldOMW1mfbwXsduAnXIKGA="; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.3.0"; hash = "sha256-P5jHCgMbgFMYiONvzmaKFeOqcAIDPu/U8bOVrNPYKqc="; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "5.0.0"; hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; }) - (fetchNuGet { pname = "System.Security.Claims"; version = "4.3.0"; hash = "sha256-Fua/rDwAqq4UByRVomAxMPmDBGd5eImRqHVQIeSxbks="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.3.0"; hash = "sha256-tAJvNSlczYBJ3Ed24Ae27a55tq/n4D3fubNQdwcKWA8="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.3.0"; hash = "sha256-u17vy6wNhqok91SrVLno2M1EzLHZm6VMca85xbVChsw="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Csp"; version = "4.3.0"; hash = "sha256-oefdTU/Z2PWU9nlat8uiRDGq/PGZoSPRgkML11pmvPQ="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.3.0"; hash = "sha256-Yuge89N6M+NcblcvXMeyHZ6kZDfwBv3LPMDiF8HhJss="; }) - (fetchNuGet { pname = "System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-DL+D2sc2JrQiB4oAcUggTFyD8w3aLEjJfod5JPe+Oz4="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.3.0"; hash = "sha256-fnFi7B3SnVj5a+BbgXnbjnGNvWrCEU6Hp/wjsjWz318="; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "4.7.0"; hash = "sha256-dZfs5q3Ij1W1eJCfYjxI2o+41aSiFpaAugpoECaCOug="; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.3.0"; hash = "sha256-MG3V/owDh273GCUPsGGraNwaVpcydupl3EtPXj6TVG0="; }) - (fetchNuGet { pname = "System.Security.Principal"; version = "4.3.0"; hash = "sha256-rjudVUHdo8pNJg2EVEn0XxxwNo5h2EaYo+QboPkXlYk="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.3.0"; hash = "sha256-mbdLVUcEwe78p3ZnB6jYsizNEqxMaCAWI3tEQNhRQAE="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "4.7.2"; hash = "sha256-CUZOulSeRy1CGBm7mrNrTumA9od9peKiIDR/Nb1B4io="; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "6.0.0"; hash = "sha256-UemDHGFoQIG7ObQwRluhVf6AgtQikfHEoPLC6gbFyRo="; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "8.0.0"; hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; }) - (fetchNuGet { pname = "System.Text.Json"; version = "4.7.2"; hash = "sha256-xA8PZwxX9iOJvPbfdi7LWjM2RMVJ7hmtEqS9JvgNsoM="; }) - (fetchNuGet { pname = "System.Text.Json"; version = "6.0.0"; hash = "sha256-9AE/5ds4DqEfb0l+27fCBTSeYCdRWhxh2Bhg8IKvIuo="; }) - (fetchNuGet { pname = "System.Text.Json"; version = "8.0.0"; hash = "sha256-XFcCHMW1u2/WujlWNHaIWkbW1wn8W4kI0QdrwPtWmow="; }) - (fetchNuGet { pname = "System.Text.Json"; version = "8.0.1"; hash = "sha256-Y0ba+eTXdrJZgET0xaurt1nkKbQRNBhod+KMcg9IdR4="; }) - (fetchNuGet { pname = "System.Text.RegularExpressions"; version = "4.3.0"; hash = "sha256-VLCk1D1kcN2wbAe3d0YQM/PqCsPHOuqlBY1yd2Yo+K0="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.3.0"; hash = "sha256-X2hQ5j+fxcmnm88Le/kSavjiGOmkcumBGTZKBLvorPc="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; }) - (fetchNuGet { pname = "System.Threading.ThreadPool"; version = "4.3.0"; hash = "sha256-wW0QdvssRoaOfQLazTGSnwYTurE4R8FxDx70pYkL+gg="; }) - (fetchNuGet { pname = "System.Threading.Timer"; version = "4.3.0"; hash = "sha256-pmhslmhQhP32TWbBzoITLZ4BoORBqYk25OWbru04p9s="; }) - (fetchNuGet { pname = "System.ValueTuple"; version = "4.5.0"; hash = "sha256-niH6l2fU52vAzuBlwdQMw0OEoRS/7E1w5smBFoqSaAI="; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.3.0"; hash = "sha256-QQ8KgU0lu4F5Unh+TbechO//zaAGZ4MfgvW72Cn1hzA="; }) - (fetchNuGet { pname = "System.Xml.XDocument"; version = "4.3.0"; hash = "sha256-rWtdcmcuElNOSzCehflyKwHkDRpiOhJJs8CeQ0l1CCI="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Azure.Core"; + version = "1.36.0"; + hash = "sha256-lokfjW2wvgFu6bALLzNmDhXIz3HXoPuGX0WfGb9hmpI="; + }) + (fetchNuGet { + pname = "Azure.Core"; + version = "1.37.0"; + hash = "sha256-ETDRf0+cNgVa1udMkhjYkOLP5Hd0NtiSQqAZHCjevds="; + }) + (fetchNuGet { + pname = "Azure.Identity"; + version = "1.10.4"; + hash = "sha256-wjopxd/bq0IjdZd5C69XLITrKz8+TFxc0YsPcj8sZHA="; + }) + (fetchNuGet { + pname = "JmesPath.Net"; + version = "1.0.330"; + hash = "sha256-FfSgpXmgaFg1uNzJjyJKjU1GZQAo64Og449EByhmKsc="; + }) + (fetchNuGet { + pname = "JmesPath.Net.Parser"; + version = "1.0.330"; + hash = "sha256-xJxWkfve/tpeFmX4YRW9SK8z1cT8dMCwwqEhOudi9og="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "1.1.1"; + hash = "sha256-fAcX4sxE0veWM1CZBtXR/Unky+6sE33yrV7ohrWGKig="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "8.0.0"; + hash = "sha256-9BPsASlxrV8ilmMCjdb3TiUcm5vFZxkBnAI/fNBSEyA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "6.0.0"; + hash = "sha256-Evg+Ynj2QUa6Gz+zqF+bUyfGD0HI5A2fHmxZEXbn3HA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "8.0.0"; + hash = "sha256-4eBpDkf7MJozTZnOwQvwcfgRKQGcNXe0K/kF+h5Rl8o="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "6.0.0"; + hash = "sha256-7NZcKkiXWSuhhVcA/fXHPY/62aGUyMsRdiHm91cWC5Y="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "8.0.0"; + hash = "sha256-GanfInGzzoN2bKeNwON8/Hnamr6l7RTpYLA49CNXD9Q="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.CommandLine"; + version = "6.0.0"; + hash = "sha256-jFACPqLvGo14eg4G3hV/UYY/d9i3hNKvgL+3nnDGZME="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.CommandLine"; + version = "8.0.0"; + hash = "sha256-fmPC/o8S+weTtQJWykpnGHm6AKVU21xYE/CaHYU7zgg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; + version = "6.0.0"; + hash = "sha256-tG3DEWURVkQHm4MlmxjE/YouTp9wQKbWs6qHH2nfgqc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; + version = "8.0.0"; + hash = "sha256-+bjFZvqCsMf2FRM2olqx/fub+QwfM1kBhjGVOT5HC48="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.FileExtensions"; + version = "6.0.0"; + hash = "sha256-PLnSa0JMfDC62OTv8sL0QFJbANE7QSnJ997ySFBS1go="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.FileExtensions"; + version = "8.0.0"; + hash = "sha256-BCxcjVP+kvrDDB0nzsFCJfU74UK4VBvct2JA4r+jNcs="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Json"; + version = "8.0.0"; + hash = "sha256-Fi/ijcG5l0BOu7i96xHu96aN5/g7zO6SWQbTsI3Qetg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.UserSecrets"; + version = "6.0.0"; + hash = "sha256-b+y3HRjUm+CfZhChVdMoN0HTXmWxrs4yiC7yM6psGmc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.UserSecrets"; + version = "8.0.0"; + hash = "sha256-/yj5QaEzeRStvOFoBpPRPXlEehGtr2E6/rJb+OEPIK8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "6.0.0"; + hash = "sha256-gZuMaunMJVyvvepuzNodGPRc6eqKH//bks3957dYkPI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "8.0.0"; + hash = "sha256-+qIDR8hRzreCHNEDtUcPfVHQdurzWPo/mqviCH78+EQ="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "6.0.0"; + hash = "sha256-SZke0jNKIqJvvukdta+MgIlGsrP2EdPkkS8lfLg7Ju4="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.0"; + hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Diagnostics"; + version = "8.0.0"; + hash = "sha256-fBLlb9xAfTgZb1cpBxFs/9eA+BlBvF8Xg0DMkBqdHD4="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Diagnostics.Abstractions"; + version = "8.0.0"; + hash = "sha256-USD5uZOaahMqi6u7owNWx/LR4EDrOwqPrAAim7iRpJY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "6.0.0"; + hash = "sha256-uBjWjHKEXjZ9fDfFxMjOou3lhfTNhs1yO+e3fpWreLk="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "8.0.0"; + hash = "sha256-uQSXmt47X2HGoVniavjLICbPtD2ReQOYQMgy3l0xuMU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Physical"; + version = "6.0.0"; + hash = "sha256-5BAQOqnaEXM2YjdrmrCinXBeZ5FKxCWtebEXMdwcbMY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Physical"; + version = "8.0.0"; + hash = "sha256-29y5ZRQ1ZgzVOxHktYxyiH40kVgm5un2yTGdvuSWnRc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileSystemGlobbing"; + version = "6.0.0"; + hash = "sha256-RAWHjkkfvGpjc49Q0kJbZyXgU6UEq/EJ0j557sj2/iU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileSystemGlobbing"; + version = "8.0.0"; + hash = "sha256-+Oz41JR5jdcJlCJOSpQIL5OMBNi+1Hl2d0JUHfES7sU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting"; + version = "6.0.0"; + hash = "sha256-ux2aROPMS7aCyfDgRn7DmIrg5M2UlK00vPjfUWGC/kA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting"; + version = "8.0.0"; + hash = "sha256-sKHa+w4/pMeQb5RRFqLtMTUJy5H6hSIGWchbH2pxSrg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting.Abstractions"; + version = "6.0.0"; + hash = "sha256-ksIPO6RhfbYx/i3su4J3sDhoL+TDnITKsgIpEqnpktc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting.Abstractions"; + version = "8.0.0"; + hash = "sha256-0JBx+wwt5p1SPfO4m49KxNOXPAzAU0A+8tEc/itvpQE="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Http"; + version = "8.0.0"; + hash = "sha256-UgljypOLld1lL7k7h1noazNzvyEHIJw+r+6uGzucFSY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "6.0.0"; + hash = "sha256-8WsZKRGfXW5MsXkMmNVf6slrkw+cR005czkOP2KUqTk="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "8.0.0"; + hash = "sha256-Meh0Z0X7KyOEG4l0RWBcuHHihcABcvCyfUXgasmQ91o="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "6.0.0"; + hash = "sha256-QNqcQ3x+MOK7lXbWkCzSOWa/2QyYNbdM/OEEbWN15Sw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "8.0.0"; + hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Configuration"; + version = "6.0.0"; + hash = "sha256-IeMOza71UDzsEIVIlYuI0RYKk+d+VOC6zCqYCQs6nV4="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Configuration"; + version = "8.0.0"; + hash = "sha256-mzmstNsVjKT0EtQcdAukGRifD30T82BMGYlSu8k4K7U="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Console"; + version = "8.0.0"; + hash = "sha256-bdb9YWWVn//AeySp7se87/tCN2E7e8Gx2GPMw28cd9c="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Debug"; + version = "6.0.0"; + hash = "sha256-kweko71W7/hIAUO3ZYYbNXksVLgj8wrDN028QthMFCs="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Debug"; + version = "8.0.0"; + hash = "sha256-AJunzYBZM2wCg86hnPnMrBuWIIyW/4PnIVoDSU969cA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.EventLog"; + version = "6.0.0"; + hash = "sha256-1BXQjw/ySWmddAZ79bv3OhmC4SPTG8PHyTOlrNEUb0g="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.EventLog"; + version = "8.0.0"; + hash = "sha256-vXBm4yhWGP4uow0CqstuqOkxO8yeZEM15JTTenjPbhc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.EventSource"; + version = "6.0.0"; + hash = "sha256-j2Begn1+Xoa+9yPoQC6b6aPmUIpBrjkTGQhRhYfJaDI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.EventSource"; + version = "8.0.0"; + hash = "sha256-kaR7YOlq5s8W9nZDtH/lKtnfGbrgOuQY4DUPcA2lcj0="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "6.0.0"; + hash = "sha256-DxnEgGiCXpkrxFkxXtOXqwaiAtoIjA8VSSWCcsW0FwE="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "8.0.0"; + hash = "sha256-n2m4JSegQKUTlOsKLZUUHHKMq926eJ0w9N9G+I3FoFw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; + version = "6.0.0"; + hash = "sha256-au0Y13cGk/dQFKuvSA5NnP/++bErTk0oOTlgmHdI2Mw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; + version = "8.0.0"; + hash = "sha256-A5Bbzw1kiNkgirk5x8kyxwg9lLTcSngojeD+ocpG1RI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "6.0.0"; + hash = "sha256-AgvysszpQ11AiTBJFkvSy8JnwIWTj15Pfek7T7ThUc4="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "8.0.0"; + hash = "sha256-FU8qj3DR8bDdc1c+WeGZx/PCZeqqndweZM9epcpXjSo="; + }) + (fetchNuGet { + pname = "Microsoft.Graph.Cli.Core"; + version = "1.2.1"; + hash = "sha256-aS8p5p6v2BLMwYq4MsPqzPNuyvli+cck0If8zew1Tg8="; + }) + (fetchNuGet { + pname = "Microsoft.Graph.Core"; + version = "3.1.7"; + hash = "sha256-OVAc7SpKYtY9IP83TGpy7F2lLR7rTJ6XBR+2JAVPWAU="; + }) + (fetchNuGet { + pname = "Microsoft.Identity.Client"; + version = "4.56.0"; + hash = "sha256-vXd9uZ1AoThcVIBmOZbMrP2xIjpoInWM9iP1pzCSnmc="; + }) + (fetchNuGet { + pname = "Microsoft.Identity.Client.Extensions.Msal"; + version = "4.56.0"; + hash = "sha256-FQF6kIDzNLxtaVnVDBMFryfTuj6T5pCx92GN6aYhmN0="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.Abstractions"; + version = "6.22.0"; + hash = "sha256-P+7razdzKHXujmkfYfw7ZCK/MvhqNqCJ9kuxFEUsiRg="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.Abstractions"; + version = "7.3.1"; + hash = "sha256-lbZKfnulWcM4Mxbz6Hkrp/lM41hsOfCnsHLEb+u2czc="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.JsonWebTokens"; + version = "7.3.1"; + hash = "sha256-C7uySnKBB0e5Wf6z8YNtjbtBbhalJMdqx0EWVcYy7Q4="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.Logging"; + version = "7.3.1"; + hash = "sha256-6OHGsItAXicCSlW0ghCy5szNi6HwhlCmbykbN1O5yAw="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.Protocols"; + version = "7.3.1"; + hash = "sha256-bBEbYXtPGNqsJiSZ7Kx3kcP1ZbosqPrGyu1PIfFPIeA="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.Protocols.OpenIdConnect"; + version = "7.3.1"; + hash = "sha256-NWw7q26IZAKiQQILU1qLeNVkMxE9rX0NwUubWAcoBiE="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.Tokens"; + version = "7.3.1"; + hash = "sha256-qfTNU0g9QA8kV42VTAez1pSTmfFRJBbeTbGn/nfGFUU="; + }) + (fetchNuGet { + pname = "Microsoft.Kiota.Abstractions"; + version = "1.7.5"; + hash = "sha256-g2ShFodiwkMofAMAbuYiUTXn21yLWyaYeDzAAikTY60="; + }) + (fetchNuGet { + pname = "Microsoft.Kiota.Abstractions"; + version = "1.7.8"; + hash = "sha256-209eh7BsL2Y0SZZbj3ABZXZQeq5bFiGRA2k4Dia9nLs="; + }) + (fetchNuGet { + pname = "Microsoft.Kiota.Abstractions"; + version = "1.7.9"; + hash = "sha256-zRAtEMarPRwJY985Morh+enZXrqO+gDpLH2K9HVCIQI="; + }) + (fetchNuGet { + pname = "Microsoft.Kiota.Authentication.Azure"; + version = "1.1.3"; + hash = "sha256-eNfXJ4Ab+55c15w5QEHzUy0nkxXK5fhPSw+waiSxJ8k="; + }) + (fetchNuGet { + pname = "Microsoft.Kiota.Cli.Commons"; + version = "1.1.0"; + hash = "sha256-+ieR78qQpeCLGo7TSEzSYE52zaBC6oASvPusOf2eHaY="; + }) + (fetchNuGet { + pname = "Microsoft.Kiota.Http.HttpClientLibrary"; + version = "1.3.6"; + hash = "sha256-w79hmlcGlkky8HK8Cy24iWXhn1UdmQCpgIJ9n3Z3kHA="; + }) + (fetchNuGet { + pname = "Microsoft.Kiota.Serialization.Form"; + version = "1.1.3"; + hash = "sha256-bY9XhBO618WaP8N3WWS7lKNkzsb0UG+0vyo85/ROk2s="; + }) + (fetchNuGet { + pname = "Microsoft.Kiota.Serialization.Json"; + version = "1.1.5"; + hash = "sha256-BSWIlNwGkceO4WHFGmD0PSQhlDf0J4EAq+66LXOZkuI="; + }) + (fetchNuGet { + pname = "Microsoft.Kiota.Serialization.Multipart"; + version = "1.1.2"; + hash = "sha256-co1iP+5YB9xdsfj73pzRh9PYWP/lVDzMv64klJeVvAs="; + }) + (fetchNuGet { + pname = "Microsoft.Kiota.Serialization.Text"; + version = "1.1.2"; + hash = "sha256-TXTNr/15sJnGQ0qJuFGvu2apZHXRWtVcVjpAO2dLaEE="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "5.0.0"; + hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.3.0"; + hash = "sha256-mBNDmPXNTW54XLnPAUwBRvkIORFM7/j0D0I2SyQPDEg="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "1.6.1"; + hash = "sha256-iNan1ix7RtncGWC9AjAZ2sk70DoxOsmEOgQ10fXm4Pw="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.1"; + hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tools"; + version = "4.3.0"; + hash = "sha256-8yLKFt2wQxkEf7fNfzB+cPUCjYn2qbqNgQ1+EeY2h/I="; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-dsmTLGvt8HqRkDWP8iKVXJCS+akAzENGXKPV18W2RgI="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization.Calendars"; + version = "4.3.0"; + hash = "sha256-AYh39tgXJVFu8aLi9Y/4rK8yWMaza4S4eaxjfcuEEL4="; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-6MYj0RmLh4EVqMtO/MRqBi0HOn5iG4x9JimgCCJ+EFM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Timer"; + version = "4.3.0"; + hash = "sha256-BgHxXCIbicVZtpgMimSXixhFC3V+p5ODqeljDjO8hCs="; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; + }) + (fetchNuGet { + pname = "runtime.native.System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-DWnXs4vlKoU6WxxvCArTJupV6sX3iBbZh8SbqfHace8="; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Http"; + version = "4.3.0"; + hash = "sha256-c556PyheRwpYhweBjSfIwEyZHnAUB8jWioyKEcp/2dg="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + hash = "sha256-2IhBv0i6pTcOyr8FFIyfPEaaCHUmJZ8DYwLUwJ+5waw="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + hash = "sha256-serkd4A7F6eciPiPJtUyJyxzdAtupEcWIZQ9nptEzIM="; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; + }) + (fetchNuGet { + pname = "runtime.unix.Microsoft.Win32.Primitives"; + version = "4.3.0"; + hash = "sha256-LZb23lRXzr26tRS5aA0xyB08JxiblPDoA7HBvn6awXg="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Console"; + version = "4.3.0"; + hash = "sha256-AHkdKShTRHttqfMjmi+lPpTuCrM5vd/WRy6Kbtie190="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; + }) + (fetchNuGet { + pname = "runtime.unix.System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-Pf4mRl6YDK2x2KMh0WdyNgv0VUNdSKVDLlHqozecy5I="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Primitives"; + version = "4.3.0"; + hash = "sha256-pHJ+I6i16MV6m77uhTC6GPY6jWGReE3SSP3fVB59ti0="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Sockets"; + version = "4.3.0"; + hash = "sha256-IvgOeA2JuBjKl5yAVGjPYMPDzs9phb3KANs95H9v1w4="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; + }) + (fetchNuGet { + pname = "Spectre.Console"; + version = "0.48.0"; + hash = "sha256-hr7BkVJ5v+NOPytlINjo+yoJetRUKmBhZbTMVKOMf2w="; + }) + (fetchNuGet { + pname = "Springcomp.GPLEX.Runtime"; + version = "1.2.4"; + hash = "sha256-WrdQVnuoJMWD4q+j7qW5nKL1jjj/YKb2lafHMsKNS/Y="; + }) + (fetchNuGet { + pname = "Springcomp.GPPG.Runtime"; + version = "1.2.4"; + hash = "sha256-M6JRE/uW8WwV8UsQi8ROKII+zFW+ROpvE9b1ig+kcic="; + }) + (fetchNuGet { + pname = "Std.UriTemplate"; + version = "0.0.50"; + hash = "sha256-Wkxk3YQ3datFXVrPSuzBqtrWEmLkIQUeiBwuQb+E+aM="; + }) + (fetchNuGet { + pname = "System.AppContext"; + version = "4.3.0"; + hash = "sha256-yg95LNQOwFlA1tWxXdQkVyJqT4AnoDc+ACmrNvzGiZg="; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.3.0"; + hash = "sha256-XqZWb4Kd04960h4U9seivjKseGA/YEIpdplfHYHQ9jk="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.3.0"; + hash = "sha256-KMY5DfJnDeIsa13DpqvyN8NkReZEMAFnlmNglVoFIXI="; + }) + (fetchNuGet { + pname = "System.CommandLine"; + version = "2.0.0-beta4.22272.1"; + hash = "sha256-zSO+CYnMH8deBHDI9DHhCPj79Ce3GOzHCyH1/TiHxcc="; + }) + (fetchNuGet { + pname = "System.CommandLine.Hosting"; + version = "0.4.0-alpha.22272.1"; + hash = "sha256-tmzZU+FBdao8Jp2v+K+HHfc9QXpGBr5EY4X8+dNPceY="; + }) + (fetchNuGet { + pname = "System.CommandLine.NamingConventionBinder"; + version = "2.0.0-beta4.22272.1"; + hash = "sha256-Ffzs51XiFraSX1efQRO1IyiNraIgi8aOdkRRzCT6DB4="; + }) + (fetchNuGet { + pname = "System.Console"; + version = "4.3.0"; + hash = "sha256-Xh3PPBZr0pDbDaK8AEHbdGz7ePK6Yi1ZyRWI1JM6mbo="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "4.3.0"; + hash = "sha256-OFJRb0ygep0Z3yDBLwAgM/Tkfs4JCDtsNhwDH9cd1Xw="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "6.0.0"; + hash = "sha256-RY9uWSPdK2fgSwlj1OHBGBVo3ZvGQgBJNzAsS5OGMWc="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "6.0.1"; + hash = "sha256-Xi8wrUjVlioz//TPQjFHqcV/QGhTqnTfUcltsNlcCJ4="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "8.0.0"; + hash = "sha256-+aODaDEQMqla5RYZeq0Lh66j+xkPYxykrVvSCmJQ+Vs="; + }) + (fetchNuGet { + pname = "System.Diagnostics.EventLog"; + version = "6.0.0"; + hash = "sha256-zUXIQtAFKbiUMKCrXzO4mOTD5EUphZzghBYKXprowSM="; + }) + (fetchNuGet { + pname = "System.Diagnostics.EventLog"; + version = "8.0.0"; + hash = "sha256-rt8xc3kddpQY4HEdghlBeOK4gdw5yIj4mcZhAVtk2/Y="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tools"; + version = "4.3.0"; + hash = "sha256-gVOv1SK6Ape0FQhCVlNOd9cvQKBvMxRX9K0JPVi8w0Y="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.3.0"; + hash = "sha256-uNOD0EOVFgnS2fMKvMiEtI9aOw00+Pfy/H+qucAQlPc="; + }) + (fetchNuGet { + pname = "System.Globalization.Extensions"; + version = "4.3.0"; + hash = "sha256-mmJWA27T0GRVuFP9/sj+4TrR4GJWrzNIk2PDrbr7RQk="; + }) + (fetchNuGet { + pname = "System.IdentityModel.Tokens.Jwt"; + version = "7.3.1"; + hash = "sha256-Si60aDtJSjvXvY5ZkVQKF3JzxAkmkAKOw5D/q8CwuyQ="; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; + }) + (fetchNuGet { + pname = "System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; + }) + (fetchNuGet { + pname = "System.IO.Compression.ZipFile"; + version = "4.3.0"; + hash = "sha256-WQl+JgWs+GaRMeiahTFUbrhlXIHapzcpTFXbRvAtvvs="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.AccessControl"; + version = "5.0.0"; + hash = "sha256-c9MlDKJfj63YRvl7brRBNs59olrmbL+G1A6oTS8ytEc="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.3.0"; + hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.5"; + hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; + }) + (fetchNuGet { + pname = "System.Memory.Data"; + version = "1.0.2"; + hash = "sha256-XiVrVQZQIz4NgjiK/wtH8iZhhOZ9MJ+X2hL2/8BrGN0="; + }) + (fetchNuGet { + pname = "System.Net.Http"; + version = "4.3.0"; + hash = "sha256-UoBB7WPDp2Bne/fwxKF0nE8grJ6FzTMXdT/jfsphj8Q="; + }) + (fetchNuGet { + pname = "System.Net.NameResolution"; + version = "4.3.0"; + hash = "sha256-eGZwCBExWsnirWBHyp2sSSSXp6g7I6v53qNmwPgtJ5c="; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.3.0"; + hash = "sha256-MY7Z6vOtFMbEKaLW9nOSZeAjcWpwCtdO7/W1mkGZBzE="; + }) + (fetchNuGet { + pname = "System.Net.Sockets"; + version = "4.3.0"; + hash = "sha256-il7dr5VT/QWDg/0cuh+4Es2u8LY//+qqiY9BZmYxSus="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.3.0"; + hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.3.0"; + hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.3.0"; + hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.3.0"; + hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.7.0"; + hash = "sha256-GEtCGXwtOnkYejSV+Tfl+DqyGq5jTUaVyL9eMupMHBM="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices.RuntimeInformation"; + version = "4.3.0"; + hash = "sha256-MYpl6/ZyC6hjmzWRIe+iDoldOMW1mfbwXsduAnXIKGA="; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.3.0"; + hash = "sha256-P5jHCgMbgFMYiONvzmaKFeOqcAIDPu/U8bOVrNPYKqc="; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "5.0.0"; + hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; + }) + (fetchNuGet { + pname = "System.Security.Claims"; + version = "4.3.0"; + hash = "sha256-Fua/rDwAqq4UByRVomAxMPmDBGd5eImRqHVQIeSxbks="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.3.0"; + hash = "sha256-tAJvNSlczYBJ3Ed24Ae27a55tq/n4D3fubNQdwcKWA8="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.3.0"; + hash = "sha256-u17vy6wNhqok91SrVLno2M1EzLHZm6VMca85xbVChsw="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Csp"; + version = "4.3.0"; + hash = "sha256-oefdTU/Z2PWU9nlat8uiRDGq/PGZoSPRgkML11pmvPQ="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.3.0"; + hash = "sha256-Yuge89N6M+NcblcvXMeyHZ6kZDfwBv3LPMDiF8HhJss="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-DL+D2sc2JrQiB4oAcUggTFyD8w3aLEjJfod5JPe+Oz4="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.3.0"; + hash = "sha256-fnFi7B3SnVj5a+BbgXnbjnGNvWrCEU6Hp/wjsjWz318="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "4.7.0"; + hash = "sha256-dZfs5q3Ij1W1eJCfYjxI2o+41aSiFpaAugpoECaCOug="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.3.0"; + hash = "sha256-MG3V/owDh273GCUPsGGraNwaVpcydupl3EtPXj6TVG0="; + }) + (fetchNuGet { + pname = "System.Security.Principal"; + version = "4.3.0"; + hash = "sha256-rjudVUHdo8pNJg2EVEn0XxxwNo5h2EaYo+QboPkXlYk="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.3.0"; + hash = "sha256-mbdLVUcEwe78p3ZnB6jYsizNEqxMaCAWI3tEQNhRQAE="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "4.7.2"; + hash = "sha256-CUZOulSeRy1CGBm7mrNrTumA9od9peKiIDR/Nb1B4io="; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "6.0.0"; + hash = "sha256-UemDHGFoQIG7ObQwRluhVf6AgtQikfHEoPLC6gbFyRo="; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "8.0.0"; + hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "4.7.2"; + hash = "sha256-xA8PZwxX9iOJvPbfdi7LWjM2RMVJ7hmtEqS9JvgNsoM="; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "6.0.0"; + hash = "sha256-9AE/5ds4DqEfb0l+27fCBTSeYCdRWhxh2Bhg8IKvIuo="; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "8.0.0"; + hash = "sha256-XFcCHMW1u2/WujlWNHaIWkbW1wn8W4kI0QdrwPtWmow="; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "8.0.1"; + hash = "sha256-Y0ba+eTXdrJZgET0xaurt1nkKbQRNBhod+KMcg9IdR4="; + }) + (fetchNuGet { + pname = "System.Text.RegularExpressions"; + version = "4.3.0"; + hash = "sha256-VLCk1D1kcN2wbAe3d0YQM/PqCsPHOuqlBY1yd2Yo+K0="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.3.0"; + hash = "sha256-X2hQ5j+fxcmnm88Le/kSavjiGOmkcumBGTZKBLvorPc="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; + }) + (fetchNuGet { + pname = "System.Threading.ThreadPool"; + version = "4.3.0"; + hash = "sha256-wW0QdvssRoaOfQLazTGSnwYTurE4R8FxDx70pYkL+gg="; + }) + (fetchNuGet { + pname = "System.Threading.Timer"; + version = "4.3.0"; + hash = "sha256-pmhslmhQhP32TWbBzoITLZ4BoORBqYk25OWbru04p9s="; + }) + (fetchNuGet { + pname = "System.ValueTuple"; + version = "4.5.0"; + hash = "sha256-niH6l2fU52vAzuBlwdQMw0OEoRS/7E1w5smBFoqSaAI="; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.3.0"; + hash = "sha256-QQ8KgU0lu4F5Unh+TbechO//zaAGZ4MfgvW72Cn1hzA="; + }) + (fetchNuGet { + pname = "System.Xml.XDocument"; + version = "4.3.0"; + hash = "sha256-rWtdcmcuElNOSzCehflyKwHkDRpiOhJJs8CeQ0l1CCI="; + }) ] diff --git a/pkgs/by-name/ms/msgviewer/package.nix b/pkgs/by-name/ms/msgviewer/package.nix index 14d2556616c7c1..37c1a633d24c4f 100644 --- a/pkgs/by-name/ms/msgviewer/package.nix +++ b/pkgs/by-name/ms/msgviewer/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeWrapper, unzip, jre, runtimeShell }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + unzip, + jre, + runtimeShell, +}: stdenv.mkDerivation rec { version = "1.9"; @@ -6,7 +14,7 @@ stdenv.mkDerivation rec { uname = "MSGViewer"; src = fetchurl { - url = "mirror://sourceforge/msgviewer/${uname}-${version}/${uname}-${version}.zip"; + url = "mirror://sourceforge/msgviewer/${uname}-${version}/${uname}-${version}.zip"; sha256 = "0igmr8c0757xsc94xlv2470zv2mz57zaj52dwr9wj8agmj23jbjz"; }; @@ -23,15 +31,18 @@ stdenv.mkDerivation rec { chmod 755 $out/bin/msgviewer ''; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; meta = with lib; { description = "Viewer for .msg files (MS Outlook)"; mainProgram = "msgviewer"; - homepage = "https://www.washington.edu/alpine/"; + homepage = "https://www.washington.edu/alpine/"; sourceProvenance = with sourceTypes; [ binaryBytecode ]; - license = licenses.asl20; + license = licenses.asl20; maintainers = with maintainers; [ peterhoeg ]; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/ms/msieve/package.nix b/pkgs/by-name/ms/msieve/package.nix index a5af9e844eca44..2562eea0c80ba9 100644 --- a/pkgs/by-name/ms/msieve/package.nix +++ b/pkgs/by-name/ms/msieve/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchsvn, zlib, gmp, ecm }: +{ + lib, + stdenv, + fetchsvn, + zlib, + gmp, + ecm, +}: stdenv.mkDerivation rec { pname = "msieve"; @@ -10,12 +17,19 @@ stdenv.mkDerivation rec { hash = "sha256-6ErVn4pYPMG5VFjOQURLsHNpN0pGdp55+rjY8988onU="; }; - buildInputs = [ zlib gmp ecm ]; + buildInputs = [ + zlib + gmp + ecm + ]; ECM = if ecm == null then "0" else "1"; # Doesn't hurt Linux but lets clang-based platforms like Darwin work fine too - makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "all" ]; + makeFlags = [ + "CC=${stdenv.cc.targetPrefix}cc" + "all" + ]; installPhase = '' mkdir -p $out/bin/ diff --git a/pkgs/by-name/ms/msilbc/package.nix b/pkgs/by-name/ms/msilbc/package.nix index b5eaee26aa0335..8addbb00b0266e 100644 --- a/pkgs/by-name/ms/msilbc/package.nix +++ b/pkgs/by-name/ms/msilbc/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, ilbc, mediastreamer, pkg-config }: +{ + lib, + stdenv, + fetchurl, + ilbc, + mediastreamer, + pkg-config, +}: stdenv.mkDerivation rec { pname = "msilbc"; @@ -9,12 +16,17 @@ stdenv.mkDerivation rec { sha256 = "07j02y994ybh274fp7ydjvi76h34y2c34ndwjpjfcwwr03b48cfp"; }; - propagatedBuildInputs = [ ilbc mediastreamer ]; + propagatedBuildInputs = [ + ilbc + mediastreamer + ]; nativeBuildInputs = [ pkg-config ]; configureFlags = [ - "ILBC_LIBS=ilbc" "ILBC_CFLAGS=-I${ilbc}/include" - "MEDIASTREAMER_LIBS=mediastreamer" "MEDIASTREAMER_CFLAGS=-I${mediastreamer}/include" + "ILBC_LIBS=ilbc" + "ILBC_CFLAGS=-I${ilbc}/include" + "MEDIASTREAMER_LIBS=mediastreamer" + "MEDIASTREAMER_CFLAGS=-I${mediastreamer}/include" ]; meta = with lib; { diff --git a/pkgs/by-name/ms/msitools/package.nix b/pkgs/by-name/ms/msitools/package.nix index 6b190f9c659eaf..232e071fe4dd6a 100644 --- a/pkgs/by-name/ms/msitools/package.nix +++ b/pkgs/by-name/ms/msitools/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, vala -, gobject-introspection -, perl -, bison -, gettext -, glib -, pkg-config -, libgsf -, gcab -, bzip2 -, gnome +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + vala, + gobject-introspection, + perl, + bison, + gettext, + glib, + pkg-config, + libgsf, + gcab, + bzip2, + gnome, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ms/msldapdump/package.nix b/pkgs/by-name/ms/msldapdump/package.nix index cf232c3df6970c..c038dd027ee799 100644 --- a/pkgs/by-name/ms/msldapdump/package.nix +++ b/pkgs/by-name/ms/msldapdump/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ms/mslink/package.nix b/pkgs/by-name/ms/mslink/package.nix index 82c60ab926f0ca..f52167c3162e97 100644 --- a/pkgs/by-name/ms/mslink/package.nix +++ b/pkgs/by-name/ms/mslink/package.nix @@ -1,6 +1,7 @@ -{ gccStdenv -, lib -, fetchurl +{ + gccStdenv, + lib, + fetchurl, }: gccStdenv.mkDerivation rec { diff --git a/pkgs/by-name/ms/msr-tools/package.nix b/pkgs/by-name/ms/msr-tools/package.nix index a96a74c764c4ee..e725b36f34928a 100644 --- a/pkgs/by-name/ms/msr-tools/package.nix +++ b/pkgs/by-name/ms/msr-tools/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "msr-tools"; diff --git a/pkgs/by-name/ms/msr/package.nix b/pkgs/by-name/ms/msr/package.nix index 630fc983690d2c..ba2a670356ebf6 100644 --- a/pkgs/by-name/ms/msr/package.nix +++ b/pkgs/by-name/ms/msr/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchzip -, installShellFiles +{ + lib, + stdenv, + fetchzip, + installShellFiles, }: stdenv.mkDerivation rec { @@ -36,6 +37,9 @@ stdenv.mkDerivation rec { mainProgram = "msr"; license = licenses.bsd0; maintainers = with maintainers; [ AndersonTorres ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/ms/mstore/package.nix b/pkgs/by-name/ms/mstore/package.nix index c77667a8d71ae4..642cc754631170 100644 --- a/pkgs/by-name/ms/mstore/package.nix +++ b/pkgs/by-name/ms/mstore/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchFromGitHub -, gfortran -, meson -, ninja -, pkg-config -, python3 -, mctc-lib +{ + stdenv, + lib, + fetchFromGitHub, + gfortran, + meson, + ninja, + pkg-config, + python3, + mctc-lib, }: stdenv.mkDerivation rec { @@ -20,11 +21,20 @@ stdenv.mkDerivation rec { hash = "sha256-zfrxdrZ1Um52qTRNGJoqZNQuHhK3xM/mKfk0aBLrcjw="; }; - nativeBuildInputs = [ gfortran meson ninja pkg-config python3 ]; + nativeBuildInputs = [ + gfortran + meson + ninja + pkg-config + python3 + ]; buildInputs = [ mctc-lib ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postPatch = '' patchShebangs --build config/install-mod.py diff --git a/pkgs/by-name/ms/mstpd/package.nix b/pkgs/by-name/ms/mstpd/package.nix index 0f82fb8fcbdd4e..31d289bb7bcda3 100644 --- a/pkgs/by-name/ms/mstpd/package.nix +++ b/pkgs/by-name/ms/mstpd/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "mstpd"; diff --git a/pkgs/by-name/ms/mswatch/package.nix b/pkgs/by-name/ms/mswatch/package.nix index cf14a411efe6c5..68a1f9bed8ac22 100644 --- a/pkgs/by-name/ms/mswatch/package.nix +++ b/pkgs/by-name/ms/mswatch/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchsvn -, pkg-config -, autoreconfHook -, bison -, flex -, glib +{ + lib, + stdenv, + fetchsvn, + pkg-config, + autoreconfHook, + bison, + flex, + glib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/mt/mt-st/package.nix b/pkgs/by-name/mt/mt-st/package.nix index 25ab2f5b2bb122..532598a2e28445 100644 --- a/pkgs/by-name/mt/mt-st/package.nix +++ b/pkgs/by-name/mt/mt-st/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mt-st"; @@ -9,7 +13,10 @@ stdenv.mkDerivation rec { sha256 = "b552775326a327cdcc076c431c5cbc4f4e235ac7c41aa931ad83f94cccb9f6de"; }; - installFlags = [ "PREFIX=$(out)" "EXEC_PREFIX=$(out)" ]; + installFlags = [ + "PREFIX=$(out)" + "EXEC_PREFIX=$(out)" + ]; meta = { description = "Magnetic Tape control tools for Linux"; diff --git a/pkgs/by-name/mt/mtail/package.nix b/pkgs/by-name/mt/mtail/package.nix index 96d7544da2c829..d767d7a34cd6dc 100644 --- a/pkgs/by-name/mt/mtail/package.nix +++ b/pkgs/by-name/mt/mtail/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/mt/mtdev/package.nix b/pkgs/by-name/mt/mtdev/package.nix index 334cda54d1bf49..b2f2a25641a1c4 100644 --- a/pkgs/by-name/mt/mtdev/package.nix +++ b/pkgs/by-name/mt/mtdev/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, evdev-proto -, gitUpdater +{ + lib, + stdenv, + fetchurl, + evdev-proto, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mt/mtm/package.nix b/pkgs/by-name/mt/mtm/package.nix index 8ecbc087894b1d..7f54649fb39381 100644 --- a/pkgs/by-name/mt/mtm/package.nix +++ b/pkgs/by-name/mt/mtm/package.nix @@ -1,10 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { pname = "mtm"; version = "1.2.1"; - outputs = [ "out" "terminfo" ]; + outputs = [ + "out" + "terminfo" + ]; src = fetchFromGitHub { owner = "deadpixi"; @@ -15,7 +23,10 @@ stdenv.mkDerivation rec { buildInputs = [ ncurses ]; - makeFlags = [ "DESTDIR=${placeholder "out"}" "MANDIR=${placeholder "out"}/share/man/man1" ]; + makeFlags = [ + "DESTDIR=${placeholder "out"}" + "MANDIR=${placeholder "out"}/share/man/man1" + ]; preInstall = '' mkdir -p $out/bin/ $out/share/man/man1 diff --git a/pkgs/by-name/mt/mtpaint/package.nix b/pkgs/by-name/mt/mtpaint/package.nix index 991eb8925f3793..d783ae50f120ff 100644 --- a/pkgs/by-name/mt/mtpaint/package.nix +++ b/pkgs/by-name/mt/mtpaint/package.nix @@ -1,10 +1,21 @@ -{ lib, stdenv, fetchFromGitHub -, pkg-config -, freetype, giflib, gtk3, lcms2, libjpeg, libpng, libtiff, openjpeg, gifsicle +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + freetype, + giflib, + gtk3, + lcms2, + libjpeg, + libpng, + libtiff, + openjpeg, + gifsicle, }: stdenv.mkDerivation rec { - pname = "mtPaint"; + pname = "mtPaint"; version = "3.50.01"; src = fetchFromGitHub { @@ -16,10 +27,22 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - freetype giflib gtk3 lcms2 libjpeg libpng libtiff openjpeg gifsicle + freetype + giflib + gtk3 + lcms2 + libjpeg + libpng + libtiff + openjpeg + gifsicle ]; - configureFlags = [ "gtk3" "intl" "man" ]; + configureFlags = [ + "gtk3" + "intl" + "man" + ]; meta = { description = "Simple GTK painting program"; @@ -39,4 +62,3 @@ stdenv.mkDerivation rec { mainProgram = "mtpaint"; }; } - diff --git a/pkgs/by-name/mt/mtpfs/package.nix b/pkgs/by-name/mt/mtpfs/package.nix index a0ca5e5a82aa04..707ce295796be8 100644 --- a/pkgs/by-name/mt/mtpfs/package.nix +++ b/pkgs/by-name/mt/mtpfs/package.nix @@ -1,11 +1,27 @@ -{ lib, stdenv, fetchurl, pkg-config, fuse, libmtp, glib, libmad, libid3tag }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + fuse, + libmtp, + glib, + libmad, + libid3tag, +}: stdenv.mkDerivation rec { pname = "mtpfs"; version = "1.1"; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ fuse libmtp glib libid3tag libmad ]; + buildInputs = [ + fuse + libmtp + glib + libid3tag + libmad + ]; src = fetchurl { url = "https://www.adebenham.com/files/mtp/mtpfs-${version}.tar.gz"; diff --git a/pkgs/by-name/mt/mtr-exporter/package.nix b/pkgs/by-name/mt/mtr-exporter/package.nix index cc807181d12ae5..2425226d513ac0 100644 --- a/pkgs/by-name/mt/mtr-exporter/package.nix +++ b/pkgs/by-name/mt/mtr-exporter/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "mtr-exporter"; diff --git a/pkgs/by-name/mt/mtx/package.nix b/pkgs/by-name/mt/mtx/package.nix index 11112911e648f6..92ca4d643eafa1 100644 --- a/pkgs/by-name/mt/mtx/package.nix +++ b/pkgs/by-name/mt/mtx/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mtx"; diff --git a/pkgs/by-name/mu/mu/package.nix b/pkgs/by-name/mu/mu/package.nix index b698978b2fd08d..df073991bff209 100644 --- a/pkgs/by-name/mu/mu/package.nix +++ b/pkgs/by-name/mu/mu/package.nix @@ -1,25 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, glibcLocales -, meson -, ninja -, pkg-config -, python3 -, cld2 -, coreutils -, emacs -, glib -, gmime3 -, texinfo -, xapian +{ + lib, + stdenv, + fetchFromGitHub, + glibcLocales, + meson, + ninja, + pkg-config, + python3, + cld2, + coreutils, + emacs, + glib, + gmime3, + texinfo, + xapian, }: stdenv.mkDerivation rec { pname = "mu"; version = "1.12.7"; - outputs = [ "out" "mu4e" ]; + outputs = [ + "out" + "mu4e" + ]; src = fetchFromGitHub { owner = "djcb"; @@ -57,7 +61,14 @@ stdenv.mkDerivation rec { fi ''; - buildInputs = [ cld2 emacs glib gmime3 texinfo xapian ]; + buildInputs = [ + cld2 + emacs + glib + gmime3 + texinfo + xapian + ]; mesonFlags = [ "-Dguile=disabled" @@ -65,7 +76,13 @@ stdenv.mkDerivation rec { "-Dlispdir=${placeholder "mu4e"}/share/emacs/site-lisp" ]; - nativeBuildInputs = [ pkg-config meson ninja python3 glibcLocales ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + python3 + glibcLocales + ]; doCheck = true; @@ -77,7 +94,11 @@ stdenv.mkDerivation rec { license = licenses.gpl3Plus; homepage = "https://www.djcbsoftware.nl/code/mu/"; changelog = "https://github.com/djcb/mu/releases/tag/v${version}"; - maintainers = with maintainers; [ antono chvp peterhoeg ]; + maintainers = with maintainers; [ + antono + chvp + peterhoeg + ]; mainProgram = "mu"; platforms = platforms.unix; }; diff --git a/pkgs/by-name/mu/mubeng/package.nix b/pkgs/by-name/mu/mubeng/package.nix index 66344f42f35ce7..6a5dedf8fe97f7 100644 --- a/pkgs/by-name/mu/mubeng/package.nix +++ b/pkgs/by-name/mu/mubeng/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/mu/mueval/package.nix b/pkgs/by-name/mu/mueval/package.nix index f763c69c3737bb..db216d9958a600 100644 --- a/pkgs/by-name/mu/mueval/package.nix +++ b/pkgs/by-name/mu/mueval/package.nix @@ -1,15 +1,22 @@ -{ lib, stdenv, makeWrapper, haskellPackages, packages ? (pkgs: []) +{ + lib, + stdenv, + makeWrapper, + haskellPackages, + packages ? (pkgs: [ ]), }: -let defaultPkgs = pkgs: [ pkgs.show - pkgs.simple-reflect - pkgs.QuickCheck - pkgs.mtl - ]; - env = haskellPackages.ghcWithPackages - (pkgs: defaultPkgs pkgs ++ packages pkgs); - -in stdenv.mkDerivation { +let + defaultPkgs = pkgs: [ + pkgs.show + pkgs.simple-reflect + pkgs.QuickCheck + pkgs.mtl + ]; + env = haskellPackages.ghcWithPackages (pkgs: defaultPkgs pkgs ++ packages pkgs); + +in +stdenv.mkDerivation { name = "mueval-env"; inherit (haskellPackages) mueval; diff --git a/pkgs/by-name/mu/muffet/package.nix b/pkgs/by-name/mu/muffet/package.nix index 8e750cc836e054..6ba43eb7953411 100644 --- a/pkgs/by-name/mu/muffet/package.nix +++ b/pkgs/by-name/mu/muffet/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/mu/muffin/package.nix b/pkgs/by-name/mu/muffin/package.nix index a95834b04c25b5..ae846fba95de48 100644 --- a/pkgs/by-name/mu/muffin/package.nix +++ b/pkgs/by-name/mu/muffin/package.nix @@ -1,49 +1,54 @@ -{ stdenv -, lib -, fetchFromGitHub -, substituteAll -, cairo -, cinnamon-desktop -, dbus -, desktop-file-utils -, egl-wayland -, glib -, gobject-introspection -, graphene -, gtk3 -, json-glib -, libcanberra -, libdrm -, libgnomekbd -, libgudev -, libinput -, libstartup_notification -, libwacom -, libxcvt -, libXdamage -, libxkbcommon -, libXtst -, mesa -, meson -, ninja -, pipewire -, pkg-config -, python3 -, udev -, wayland -, wayland-protocols -, wayland-scanner -, wrapGAppsHook3 -, xorgserver -, xwayland -, zenity +{ + stdenv, + lib, + fetchFromGitHub, + substituteAll, + cairo, + cinnamon-desktop, + dbus, + desktop-file-utils, + egl-wayland, + glib, + gobject-introspection, + graphene, + gtk3, + json-glib, + libcanberra, + libdrm, + libgnomekbd, + libgudev, + libinput, + libstartup_notification, + libwacom, + libxcvt, + libXdamage, + libxkbcommon, + libXtst, + mesa, + meson, + ninja, + pipewire, + pkg-config, + python3, + udev, + wayland, + wayland-protocols, + wayland-scanner, + wrapGAppsHook3, + xorgserver, + xwayland, + zenity, }: stdenv.mkDerivation rec { pname = "muffin"; version = "6.4.1"; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; src = fetchFromGitHub { owner = "linuxmint"; diff --git a/pkgs/by-name/mu/mujs/package.nix b/pkgs/by-name/mu/mujs/package.nix index 9bffafe4bd73d1..78252d6844dea2 100644 --- a/pkgs/by-name/mu/mujs/package.nix +++ b/pkgs/by-name/mu/mujs/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, fixDarwinDylibNames -, readline -, gitUpdater +{ + lib, + stdenv, + fetchurl, + fixDarwinDylibNames, + readline, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mu/mullvad-browser/package.nix b/pkgs/by-name/mu/mullvad-browser/package.nix index ceb2c869bfa9cf..67fbc6d31e2631 100644 --- a/pkgs/by-name/mu/mullvad-browser/package.nix +++ b/pkgs/by-name/mu/mullvad-browser/package.nix @@ -1,61 +1,62 @@ -{ lib -, stdenv -, fetchurl -, makeDesktopItem -, copyDesktopItems -, makeWrapper -, writeText -, wrapGAppsHook3 -, autoPatchelfHook -, patchelfUnstable # have to use patchelfUnstable to support --no-clobber-old-sections -, callPackage - -, atk -, cairo -, dbus -, dbus-glib -, fontconfig -, freetype -, gdk-pixbuf -, glib -, gtk3 -, libxcb -, libX11 -, libXext -, libXrender -, libXt -, libXtst -, mesa -, pango -, pciutils -, zlib - -, libnotifySupport ? stdenv.hostPlatform.isLinux -, libnotify - -, waylandSupport ? stdenv.hostPlatform.isLinux -, libxkbcommon -, libdrm -, libGL - -, mediaSupport ? true -, ffmpeg - -, audioSupport ? mediaSupport - -, pipewireSupport ? audioSupport -, pipewire - -, pulseaudioSupport ? audioSupport -, libpulseaudio -, apulse -, alsa-lib - -, libvaSupport ? mediaSupport -, libva - -# Extra preferences -, extraPrefs ? "" +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + copyDesktopItems, + makeWrapper, + writeText, + wrapGAppsHook3, + autoPatchelfHook, + patchelfUnstable, # have to use patchelfUnstable to support --no-clobber-old-sections + callPackage, + + atk, + cairo, + dbus, + dbus-glib, + fontconfig, + freetype, + gdk-pixbuf, + glib, + gtk3, + libxcb, + libX11, + libXext, + libXrender, + libXt, + libXtst, + mesa, + pango, + pciutils, + zlib, + + libnotifySupport ? stdenv.hostPlatform.isLinux, + libnotify, + + waylandSupport ? stdenv.hostPlatform.isLinux, + libxkbcommon, + libdrm, + libGL, + + mediaSupport ? true, + ffmpeg, + + audioSupport ? mediaSupport, + + pipewireSupport ? audioSupport, + pipewire, + + pulseaudioSupport ? audioSupport, + libpulseaudio, + apulse, + alsa-lib, + + libvaSupport ? mediaSupport, + libva, + + # Extra preferences + extraPrefs ? "", }: let @@ -83,12 +84,17 @@ let stdenv.cc.cc stdenv.cc.libc zlib - ] ++ lib.optionals libnotifySupport [ libnotify ] - ++ lib.optionals waylandSupport [ libxkbcommon libdrm libGL ] - ++ lib.optionals pipewireSupport [ pipewire ] - ++ lib.optionals pulseaudioSupport [ libpulseaudio ] - ++ lib.optionals libvaSupport [ libva ] - ++ lib.optionals mediaSupport [ ffmpeg ] + ] + ++ lib.optionals libnotifySupport [ libnotify ] + ++ lib.optionals waylandSupport [ + libxkbcommon + libdrm + libGL + ] + ++ lib.optionals pipewireSupport [ pipewire ] + ++ lib.optionals pulseaudioSupport [ libpulseaudio ] + ++ lib.optionals libvaSupport [ libva ] + ++ lib.optionals mediaSupport [ ffmpeg ] ); version = "14.0.3"; @@ -107,24 +113,30 @@ let }; }; - distributionIni = writeText "distribution.ini" (lib.generators.toINI {} { - # Some light branding indicating this build uses our distro preferences - Global = { - id = "nixos"; - version = "1.0"; - about = "Mullvad Browser for NixOS"; - }; - }); + distributionIni = writeText "distribution.ini" ( + lib.generators.toINI { } { + # Some light branding indicating this build uses our distro preferences + Global = { + id = "nixos"; + version = "1.0"; + about = "Mullvad Browser for NixOS"; + }; + } + ); - policiesJson = writeText "policies.json" (builtins.toJSON { - policies.DisableAppUpdate = true; - }); + policiesJson = writeText "policies.json" ( + builtins.toJSON { + policies.DisableAppUpdate = true; + } + ); in stdenv.mkDerivation rec { pname = "mullvad-browser"; inherit version; - src = sources.${stdenv.hostPlatform.system} or (throw "unsupported system: ${stdenv.hostPlatform.system}"); + src = + sources.${stdenv.hostPlatform.system} + or (throw "unsupported system: ${stdenv.hostPlatform.system}"); nativeBuildInputs = [ autoPatchelfHook @@ -146,23 +158,29 @@ stdenv.mkDerivation rec { preferLocalBuild = true; allowSubstitutes = false; - desktopItems = [(makeDesktopItem { - name = "mullvad-browser"; - exec = "mullvad-browser %U"; - icon = "mullvad-browser"; - desktopName = "Mullvad Browser"; - genericName = "Web Browser"; - comment = meta.description; - categories = [ "Network" "WebBrowser" "Security" ]; - mimeTypes = [ - "text/html" - "text/xml" - "application/xhtml+xml" - "application/vnd.mozilla.xul+xml" - "x-scheme-handler/http" - "x-scheme-handler/https" - ]; - })]; + desktopItems = [ + (makeDesktopItem { + name = "mullvad-browser"; + exec = "mullvad-browser %U"; + icon = "mullvad-browser"; + desktopName = "Mullvad Browser"; + genericName = "Web Browser"; + comment = meta.description; + categories = [ + "Network" + "WebBrowser" + "Security" + ]; + mimeTypes = [ + "text/html" + "text/xml" + "application/xhtml+xml" + "application/vnd.mozilla.xul+xml" + "x-scheme-handler/http" + "x-scheme-handler/https" + ]; + }) + ]; buildPhase = '' runHook preBuild @@ -212,11 +230,16 @@ stdenv.mkDerivation rec { lockPref("noscript.firstRunRedirection", false); // Allow sandbox access to sound devices if using ALSA directly - ${if (audioSupport && !pulseaudioSupport) then '' - pref("security.sandbox.content.write_path_whitelist", "/dev/snd/"); - '' else '' - clearPref("security.sandbox.content.write_path_whitelist"); - ''} + ${ + if (audioSupport && !pulseaudioSupport) then + '' + pref("security.sandbox.content.write_path_whitelist", "/dev/snd/"); + '' + else + '' + clearPref("security.sandbox.content.write_path_whitelist"); + '' + } ${lib.optionalString (extraPrefs != "") '' ${extraPrefs} @@ -278,11 +301,20 @@ stdenv.mkDerivation rec { mainProgram = "mullvad-browser"; homepage = "https://mullvad.net/en/browser"; platforms = attrNames sources; - maintainers = with maintainers; [ felschr panicgh sigmasquadron ]; + maintainers = with maintainers; [ + felschr + panicgh + sigmasquadron + ]; # MPL2.0+, GPL+, &c. While it's not entirely clear whether # the compound is "libre" in a strict sense (some components place certain # restrictions on redistribution), it's free enough for our purposes. - license = with licenses; [ mpl20 lgpl21Plus lgpl3Plus free ]; + license = with licenses; [ + mpl20 + lgpl21Plus + lgpl3Plus + free + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; } diff --git a/pkgs/by-name/mu/mullvad-browser/update.nix b/pkgs/by-name/mu/mullvad-browser/update.nix index 7faf4c31efbf0e..148a8ecc9bcd70 100644 --- a/pkgs/by-name/mu/mullvad-browser/update.nix +++ b/pkgs/by-name/mu/mullvad-browser/update.nix @@ -1,29 +1,39 @@ -{ lib -, writeShellScript -, coreutils -, gnused -, gnugrep -, curl -, gnupg -, nix -, common-updater-scripts +{ + lib, + writeShellScript, + coreutils, + gnused, + gnugrep, + curl, + gnupg, + nix, + common-updater-scripts, -# options -, pname -, version -, meta -, baseUrl ? "https://dist.torproject.org/torbrowser/" -# name used to match published archive -, name ? "tor-browser" -, prerelease ? false + # options + pname, + version, + meta, + baseUrl ? "https://dist.torproject.org/torbrowser/", + # name used to match published archive + name ? "tor-browser", + prerelease ? false, }: let - versionMatch = if prerelease - then ''[0-9]+(\.[0-9]+)*.*'' - else ''[0-9]+(\.[0-9]+)*''; -in writeShellScript "update-${pname}" '' - PATH="${lib.makeBinPath [ coreutils curl gnugrep gnused gnupg nix common-updater-scripts ]}" + versionMatch = if prerelease then ''[0-9]+(\.[0-9]+)*.*'' else ''[0-9]+(\.[0-9]+)*''; +in +writeShellScript "update-${pname}" '' + PATH="${ + lib.makeBinPath [ + coreutils + curl + gnugrep + gnused + gnupg + nix + common-updater-scripts + ] + }" set -euo pipefail trap diff --git a/pkgs/by-name/mu/multicharge/package.nix b/pkgs/by-name/mu/multicharge/package.nix index 3660705242f6d1..f731d902733844 100644 --- a/pkgs/by-name/mu/multicharge/package.nix +++ b/pkgs/by-name/mu/multicharge/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch2 -, gfortran -, meson -, ninja -, pkg-config -, python3 -, blas -, lapack -, mctc-lib -, mstore +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch2, + gfortran, + meson, + ninja, + pkg-config, + python3, + blas, + lapack, + mctc-lib, + mstore, }: assert !blas.isILP64 && !lapack.isILP64; @@ -36,11 +37,25 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ gfortran meson ninja pkg-config python3 ]; + nativeBuildInputs = [ + gfortran + meson + ninja + pkg-config + python3 + ]; - buildInputs = [ blas lapack mctc-lib mstore ]; + buildInputs = [ + blas + lapack + mctc-lib + mstore + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; doCheck = true; diff --git a/pkgs/by-name/mu/multilockscreen/package.nix b/pkgs/by-name/mu/multilockscreen/package.nix index ad8045e7052849..08fa8c8055d2a6 100644 --- a/pkgs/by-name/mu/multilockscreen/package.nix +++ b/pkgs/by-name/mu/multilockscreen/package.nix @@ -1,17 +1,39 @@ { - lib, stdenv, makeWrapper, fetchFromGitHub, writeShellScriptBin, - imagemagick, i3lock-color, xdpyinfo, xrandr, bc, feh, procps, xrdb, xset, - gnused, gnugrep, coreutils + lib, + stdenv, + makeWrapper, + fetchFromGitHub, + writeShellScriptBin, + imagemagick, + i3lock-color, + xdpyinfo, + xrandr, + bc, + feh, + procps, + xrdb, + xset, + gnused, + gnugrep, + coreutils, }: let i3lock = writeShellScriptBin "i3lock" '' ${i3lock-color}/bin/i3lock-color "$@" ''; binPath = lib.makeBinPath [ - imagemagick i3lock - xdpyinfo xrandr xset - bc feh procps xrdb - gnused gnugrep coreutils + imagemagick + i3lock + xdpyinfo + xrandr + xset + bc + feh + procps + xrdb + gnused + gnugrep + coreutils ]; in stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mu/multimarkdown/package.nix b/pkgs/by-name/mu/multimarkdown/package.nix index 91e1c9cb310961..0daf9781aca19d 100644 --- a/pkgs/by-name/mu/multimarkdown/package.nix +++ b/pkgs/by-name/mu/multimarkdown/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, perl -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + perl, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mu/multimon-ng/package.nix b/pkgs/by-name/mu/multimon-ng/package.nix index f71af7e6486252..7ccf951639a28a 100644 --- a/pkgs/by-name/mu/multimon-ng/package.nix +++ b/pkgs/by-name/mu/multimon-ng/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libpulseaudio, libX11, makeWrapper, sox }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libpulseaudio, + libX11, + makeWrapper, + sox, +}: stdenv.mkDerivation rec { pname = "multimon-ng"; @@ -11,12 +20,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-irKpVerxzjJIiLofoTdySk/PzojuVLgMq2DYF0qPaAM="; }; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libpulseaudio libX11 ]; + buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ + libpulseaudio + libX11 + ]; - nativeBuildInputs = [ cmake makeWrapper ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; postInstall = '' - wrapProgram $out/bin/multimon-ng --prefix PATH : "${lib.makeBinPath [sox]}" + wrapProgram $out/bin/multimon-ng --prefix PATH : "${lib.makeBinPath [ sox ]}" ''; meta = with lib; { diff --git a/pkgs/by-name/mu/multipart-parser-c/package.nix b/pkgs/by-name/mu/multipart-parser-c/package.nix index ef4834b8c00584..9900a01e4b8554 100644 --- a/pkgs/by-name/mu/multipart-parser-c/package.nix +++ b/pkgs/by-name/mu/multipart-parser-c/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mu/multipath-tools/package.nix b/pkgs/by-name/mu/multipath-tools/package.nix index 9fe8630e227576..536e0777898da8 100644 --- a/pkgs/by-name/mu/multipath-tools/package.nix +++ b/pkgs/by-name/mu/multipath-tools/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, coreutils +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + coreutils, -, perl -, pkg-config + perl, + pkg-config, -, json_c -, libaio -, liburcu -, linuxHeaders -, lvm2 -, readline -, systemd -, util-linuxMinimal + json_c, + libaio, + liburcu, + linuxHeaders, + lvm2, + readline, + systemd, + util-linuxMinimal, -, cmocka -, nixosTests + cmocka, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mu/multirun/package.nix b/pkgs/by-name/mu/multirun/package.nix index 2886c2ec492b63..1ecc3c8f9e9ed9 100644 --- a/pkgs/by-name/mu/multirun/package.nix +++ b/pkgs/by-name/mu/multirun/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mu/multitail/package.nix b/pkgs/by-name/mu/multitail/package.nix index 5a89b997512e12..9bca4a902a187b 100644 --- a/pkgs/by-name/mu/multitail/package.nix +++ b/pkgs/by-name/mu/multitail/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, ncurses, pkg-config, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + pkg-config, + cmake, +}: stdenv.mkDerivation rec { version = "7.1.5"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-c9NlQLgHngNBbADZ6/legWFaKHJAQR/LZIfh8bJoc4Y="; }; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; buildInputs = [ ncurses ]; diff --git a/pkgs/by-name/mu/multitime/package.nix b/pkgs/by-name/mu/multitime/package.nix index 189a49ad348ee7..378f8731eed761 100644 --- a/pkgs/by-name/mu/multitime/package.nix +++ b/pkgs/by-name/mu/multitime/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "multitime"; diff --git a/pkgs/by-name/mu/multiviewer-for-f1/package.nix b/pkgs/by-name/mu/multiviewer-for-f1/package.nix index 408dc0530e1792..a7e783972f39f2 100644 --- a/pkgs/by-name/mu/multiviewer-for-f1/package.nix +++ b/pkgs/by-name/mu/multiviewer-for-f1/package.nix @@ -1,26 +1,27 @@ -{ stdenvNoCC -, fetchurl -, lib -, makeWrapper -, autoPatchelfHook -, dpkg -, alsa-lib -, at-spi2-atk -, cairo -, cups -, dbus -, expat -, ffmpeg -, glib -, gtk3 -, libdrm -, libudev0-shim -, libxkbcommon -, mesa -, nspr -, nss -, pango -, xorg +{ + stdenvNoCC, + fetchurl, + lib, + makeWrapper, + autoPatchelfHook, + dpkg, + alsa-lib, + at-spi2-atk, + cairo, + cups, + dbus, + expat, + ffmpeg, + glib, + gtk3, + libdrm, + libudev0-shim, + libxkbcommon, + mesa, + nspr, + nss, + pango, + xorg, }: let id = "203624820"; @@ -85,7 +86,9 @@ stdenvNoCC.mkDerivation rec { makeWrapper "$out/share/multiviewer-for-f1/MultiViewer for F1" $out/bin/multiviewer-for-f1 \ --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform=wayland --enable-features=WaylandWindowDecorations --enable-wayland-ime=true}}" \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ libudev0-shim ]}:\"$out/share/Multiviewer for F1\"" + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ libudev0-shim ] + }:\"$out/share/Multiviewer for F1\"" runHook postInstall ''; diff --git a/pkgs/by-name/mu/multus-cni/package.nix b/pkgs/by-name/mu/multus-cni/package.nix index ceda5e60c4f44f..6db149fca3f7e6 100644 --- a/pkgs/by-name/mu/multus-cni/package.nix +++ b/pkgs/by-name/mu/multus-cni/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "multus-cni"; @@ -33,7 +37,10 @@ buildGoModule rec { homepage = "https://github.com/k8snetworkplumbingwg/multus-cni"; license = licenses.asl20; platforms = platforms.linux; - maintainers = with maintainers; [ onixie kashw2 ]; + maintainers = with maintainers; [ + onixie + kashw2 + ]; mainProgram = "multus"; }; } diff --git a/pkgs/by-name/mu/munin/package.nix b/pkgs/by-name/mu/munin/package.nix index 785c0fecf43f60..637d95af89f7a5 100644 --- a/pkgs/by-name/mu/munin/package.nix +++ b/pkgs/by-name/mu/munin/package.nix @@ -1,6 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, which, coreutils, rrdtool, perlPackages -, python3, ruby, jre8, nettools, bc -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + which, + coreutils, + rrdtool, + perlPackages, + python3, + ruby, + jre8, + nettools, + bc, + nixosTests, }: stdenv.mkDerivation rec { @@ -63,8 +75,8 @@ stdenv.mkDerivation rec { doCheck = false; checkPhase = '' - export PERL5LIB="$PERL5LIB:${rrdtool}/${perlPackages.perl.libPrefix}" - LC_ALL=C make -j1 test + export PERL5LIB="$PERL5LIB:${rrdtool}/${perlPackages.perl.libPrefix}" + LC_ALL=C make -j1 test ''; patches = [ @@ -126,11 +138,27 @@ stdenv.mkDerivation rec { *.jar) continue;; esac wrapProgram "$file" \ - --set PERL5LIB "$out/${perlPackages.perl.libPrefix}:${with perlPackages; makePerlPath [ - LogLog4perl IOSocketINET6 Socket6 URI DBFile TimeDate - HTMLTemplate FileCopyRecursive FCGI NetCIDR NetSNMP NetServer - ListMoreUtils DBDPg LWP rrdtool - ]}" + --set PERL5LIB "$out/${perlPackages.perl.libPrefix}:${ + with perlPackages; + makePerlPath [ + LogLog4perl + IOSocketINET6 + Socket6 + URI + DBFile + TimeDate + HTMLTemplate + FileCopyRecursive + FCGI + NetCIDR + NetSNMP + NetServer + ListMoreUtils + DBDPg + LWP + rrdtool + ] + }" done ''; diff --git a/pkgs/by-name/mu/muon/package.nix b/pkgs/by-name/mu/muon/package.nix index 0e38f4f8e99325..dc32c0114cfbe2 100644 --- a/pkgs/by-name/mu/muon/package.nix +++ b/pkgs/by-name/mu/muon/package.nix @@ -1,22 +1,22 @@ -{ lib -, stdenv -, fetchFromSourcehut -, fetchurl -, curl -, libarchive -, libpkgconf -, pkgconf -, python3 -, samurai -, scdoc -, zlib -, embedSamurai ? false -, buildDocs ? true +{ + lib, + stdenv, + fetchFromSourcehut, + fetchurl, + curl, + libarchive, + libpkgconf, + pkgconf, + python3, + samurai, + scdoc, + zlib, + embedSamurai ? false, + buildDocs ? true, }: stdenv.mkDerivation (finalAttrs: { - pname = "muon" - + lib.optionalString embedSamurai "-embedded-samurai"; + pname = "muon" + lib.optionalString embedSamurai "-embedded-samurai"; version = "0.2.0"; src = fetchFromSourcehut { @@ -29,14 +29,15 @@ stdenv.mkDerivation (finalAttrs: { outputs = [ "out" ] ++ lib.optionals buildDocs [ "man" ]; - nativeBuildInputs = [ - pkgconf - samurai - ] - ++ lib.optionals buildDocs [ - (python3.withPackages (ps: [ ps.pyyaml ])) - scdoc - ]; + nativeBuildInputs = + [ + pkgconf + samurai + ] + ++ lib.optionals buildDocs [ + (python3.withPackages (ps: [ ps.pyyaml ])) + scdoc + ]; buildInputs = [ curl @@ -48,61 +49,66 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - postUnpack = let - # URLs manually extracted from subprojects directory - meson-docs-wrap = fetchurl { - name = "meson-docs-wrap"; - url = "https://mochiro.moe/wrap/meson-docs-1.0.1-19-gdd8d4ee22.tar.gz"; - hash = "sha256-jHSPdLFR5jUeds4e+hLZ6JOblor5iuCV5cIwoc4K9gI="; - }; - - samurai-wrap = fetchurl { - name = "samurai-wrap"; - url = "https://mochiro.moe/wrap/samurai-1.2-32-g81cef5d.tar.gz"; - hash = "sha256-aPMAtScqweGljvOLaTuR6B0A0GQQQrVbRviXY4dpCoc="; - }; - in '' - pushd $sourceRoot/subprojects - ${lib.optionalString buildDocs "tar xvf ${meson-docs-wrap}"} - ${lib.optionalString embedSamurai "tar xvf ${samurai-wrap}"} - popd - ''; - - postPatch = '' - patchShebangs bootstrap.sh - '' - + lib.optionalString buildDocs '' - patchShebangs subprojects/meson-docs/docs/genrefman.py - ''; + postUnpack = + let + # URLs manually extracted from subprojects directory + meson-docs-wrap = fetchurl { + name = "meson-docs-wrap"; + url = "https://mochiro.moe/wrap/meson-docs-1.0.1-19-gdd8d4ee22.tar.gz"; + hash = "sha256-jHSPdLFR5jUeds4e+hLZ6JOblor5iuCV5cIwoc4K9gI="; + }; + + samurai-wrap = fetchurl { + name = "samurai-wrap"; + url = "https://mochiro.moe/wrap/samurai-1.2-32-g81cef5d.tar.gz"; + hash = "sha256-aPMAtScqweGljvOLaTuR6B0A0GQQQrVbRviXY4dpCoc="; + }; + in + '' + pushd $sourceRoot/subprojects + ${lib.optionalString buildDocs "tar xvf ${meson-docs-wrap}"} + ${lib.optionalString embedSamurai "tar xvf ${samurai-wrap}"} + popd + ''; + + postPatch = + '' + patchShebangs bootstrap.sh + '' + + lib.optionalString buildDocs '' + patchShebangs subprojects/meson-docs/docs/genrefman.py + ''; # tests try to access "~" postConfigure = '' export HOME=$(mktemp -d) ''; - buildPhase = let - muonBool = lib.mesonBool; - muonEnable = lib.mesonEnable; + buildPhase = + let + muonBool = lib.mesonBool; + muonEnable = lib.mesonEnable; - cmdlineForMuon = lib.concatStringsSep " " [ - (muonBool "static" stdenv.targetPlatform.isStatic) - (muonEnable "docs" buildDocs) - (muonEnable "samurai" embedSamurai) - ]; - cmdlineForSamu = "-j$NIX_BUILD_CORES"; - in '' - runHook preBuild + cmdlineForMuon = lib.concatStringsSep " " [ + (muonBool "static" stdenv.targetPlatform.isStatic) + (muonEnable "docs" buildDocs) + (muonEnable "samurai" embedSamurai) + ]; + cmdlineForSamu = "-j$NIX_BUILD_CORES"; + in + '' + runHook preBuild - ./bootstrap.sh stage-1 + ./bootstrap.sh stage-1 - ./stage-1/muon setup ${cmdlineForMuon} stage-2 - samu ${cmdlineForSamu} -C stage-2 + ./stage-1/muon setup ${cmdlineForMuon} stage-2 + samu ${cmdlineForSamu} -C stage-2 - stage-2/muon setup -Dprefix=$out ${cmdlineForMuon} stage-3 - samu ${cmdlineForSamu} -C stage-3 + stage-2/muon setup -Dprefix=$out ${cmdlineForMuon} stage-3 + samu ${cmdlineForSamu} -C stage-3 - runHook postBuild - ''; + runHook postBuild + ''; # tests are failing because they don't find Python doCheck = false; diff --git a/pkgs/by-name/mu/muonlang/package.nix b/pkgs/by-name/mu/muonlang/package.nix index aef02bca970de4..5882e2e26f0ec6 100644 --- a/pkgs/by-name/mu/muonlang/package.nix +++ b/pkgs/by-name/mu/muonlang/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "muon"; diff --git a/pkgs/by-name/mu/muparser/package.nix b/pkgs/by-name/mu/muparser/package.nix index c73273d522de5f..467b36ce950190 100644 --- a/pkgs/by-name/mu/muparser/package.nix +++ b/pkgs/by-name/mu/muparser/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, llvmPackages +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + llvmPackages, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mu/muparserx/package.nix b/pkgs/by-name/mu/muparserx/package.nix index 957e49c4d6d77c..4c1071eb2c682e 100644 --- a/pkgs/by-name/mu/muparserx/package.nix +++ b/pkgs/by-name/mu/muparserx/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mu/mupdf/package.nix b/pkgs/by-name/mu/mupdf/package.nix index 25d8686b50d9d6..40b03c5a97e082 100644 --- a/pkgs/by-name/mu/mupdf/package.nix +++ b/pkgs/by-name/mu/mupdf/package.nix @@ -1,46 +1,47 @@ -{ stdenv -, lib -, fetchurl -, fetchFromGitHub -, copyDesktopItems -, makeDesktopItem -, desktopToDarwinBundle -, buildPackages -, pkg-config -, fixDarwinDylibNames -, freetype -, harfbuzz -, openjpeg -, jbig2dec -, libjpeg -, darwin -, gumbo -, enableX11 ? (!stdenv.hostPlatform.isDarwin) -, libX11 -, libXext -, libXi -, libXrandr -, enableCurl ? true -, curl -, openssl -, enableGL ? true -, freeglut -, libGLU -, enableOcr ? false -, leptonica -, tesseract -, enableCxx ? false -, python3 -, enablePython ? false -, which -, swig -, xcbuild -, gitUpdater - -# for passthru.tests -, cups-filters -, zathura -, mupdf +{ + stdenv, + lib, + fetchurl, + fetchFromGitHub, + copyDesktopItems, + makeDesktopItem, + desktopToDarwinBundle, + buildPackages, + pkg-config, + fixDarwinDylibNames, + freetype, + harfbuzz, + openjpeg, + jbig2dec, + libjpeg, + darwin, + gumbo, + enableX11 ? (!stdenv.hostPlatform.isDarwin), + libX11, + libXext, + libXi, + libXrandr, + enableCurl ? true, + curl, + openssl, + enableGL ? true, + freeglut, + libGLU, + enableOcr ? false, + leptonica, + tesseract, + enableCxx ? false, + python3, + enablePython ? false, + which, + swig, + xcbuild, + gitUpdater, + + # for passthru.tests + cups-filters, + zathura, + mupdf, }: assert enablePython -> enableCxx; @@ -92,35 +93,80 @@ stdenv.mkDerivation rec { done ''; - makeFlags = [ - "prefix=$(out)" - "shared=yes" - "USE_SYSTEM_LIBS=yes" - "PKG_CONFIG=${buildPackages.pkg-config}/bin/${buildPackages.pkg-config.targetPrefix}pkg-config" - ] ++ lib.optionals (!enableX11) [ "HAVE_X11=no" ] + makeFlags = + [ + "prefix=$(out)" + "shared=yes" + "USE_SYSTEM_LIBS=yes" + "PKG_CONFIG=${buildPackages.pkg-config}/bin/${buildPackages.pkg-config.targetPrefix}pkg-config" + ] + ++ lib.optionals (!enableX11) [ "HAVE_X11=no" ] ++ lib.optionals (!enableGL) [ "HAVE_GLUT=no" ] ++ lib.optionals (enableOcr) [ "USE_TESSERACT=yes" ]; - nativeBuildInputs = [ pkg-config ] + nativeBuildInputs = + [ pkg-config ] ++ lib.optional (enableGL || enableX11) copyDesktopItems ++ lib.optional (stdenv.hostPlatform.isDarwin && (enableGL || enableX11)) desktopToDarwinBundle - ++ lib.optionals (enableCxx || enablePython) [ (python3.pythonOnBuildForHost.withPackages (ps: [ ps.setuptools ps.libclang ])) ] - ++ lib.optionals (enablePython) [ which swig ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ fixDarwinDylibNames xcbuild ]; + ++ lib.optionals (enableCxx || enablePython) [ + (python3.pythonOnBuildForHost.withPackages (ps: [ + ps.setuptools + ps.libclang + ])) + ] + ++ lib.optionals (enablePython) [ + which + swig + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + xcbuild + ]; - buildInputs = [ freetype harfbuzz openjpeg jbig2dec libjpeg gumbo ] - ++ lib.optionals enableX11 [ libX11 libXext libXi libXrandr ] - ++ lib.optionals enableCurl [ curl openssl ] + buildInputs = + [ + freetype + harfbuzz + openjpeg + jbig2dec + libjpeg + gumbo + ] + ++ lib.optionals enableX11 [ + libX11 + libXext + libXi + libXrandr + ] + ++ lib.optionals enableCurl [ + curl + openssl + ] ++ lib.optionals enableGL ( if stdenv.hostPlatform.isDarwin then - with darwin.apple_sdk.frameworks; [ GLUT OpenGL ] + with darwin.apple_sdk.frameworks; + [ + GLUT + OpenGL + ] else - [ freeglut-mupdf libGLU ] + [ + freeglut-mupdf + libGLU + ] ) - ++ lib.optionals enableOcr [ leptonica tesseract ] - ; + ++ lib.optionals enableOcr [ + leptonica + tesseract + ]; - outputs = [ "bin" "dev" "out" "man" "doc" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + "doc" + ]; preConfigure = '' # Don't remove mujs because upstream version is incompatible @@ -149,50 +195,75 @@ stdenv.mkDerivation rec { "application/x-cbz" "application/x-pdf" ]; - categories = [ "Graphics" "Viewer" ]; + categories = [ + "Graphics" + "Viewer" + ]; keywords = [ - "mupdf" "comic" "document" "ebook" "viewer" - "cbz" "epub" "fb2" "pdf" "xps" + "mupdf" + "comic" + "document" + "ebook" + "viewer" + "cbz" + "epub" + "fb2" + "pdf" + "xps" ]; }) ]; - postInstall = '' - mkdir -p "$out/lib/pkgconfig" - cat >"$out/lib/pkgconfig/mupdf.pc" <"$out/lib/pkgconfig/mupdf.pc" < sslSupport; assert gpgmeSupport -> sslSupport; @@ -24,73 +31,84 @@ assert gpgmeSupport -> sslSupport; stdenv.mkDerivation rec { pname = "mutt"; version = "2.2.13"; - outputs = [ "out" "doc" "info" ]; + outputs = [ + "out" + "doc" + "info" + ]; src = fetchurl { url = "http://ftp.mutt.org/pub/mutt/${pname}-${version}.tar.gz"; hash = "sha256-6yP63cHMl9hnaT86Sp8wlJrZN2WtW2/a4nl6QAHFjvs="; }; - patches = [ - # Avoid build-only references embedding into 'mutt -v' output. - ./no-build-only-refs.patch - ] ++ lib.optional smimeSupport (fetchpatch { - url = "https://salsa.debian.org/mutt-team/mutt/raw/debian/1.10.1-2/debian/patches/misc/smime.rc.patch"; - sha256 = "0b4i00chvx6zj9pcb06x2jysmrcb2znn831lcy32cgfds6gr3nsi"; - }); + patches = + [ + # Avoid build-only references embedding into 'mutt -v' output. + ./no-build-only-refs.patch + ] + ++ lib.optional smimeSupport (fetchpatch { + url = "https://salsa.debian.org/mutt-team/mutt/raw/debian/1.10.1-2/debian/patches/misc/smime.rc.patch"; + sha256 = "0b4i00chvx6zj9pcb06x2jysmrcb2znn831lcy32cgfds6gr3nsi"; + }); strictDeps = true; nativeBuildInputs = [ - perl which + perl + which ]; buildInputs = [ ncurses ] - ++ lib.optional headerCache gdbm - ++ lib.optional sslSupport openssl - ++ lib.optional gssSupport libkrb5 - ++ lib.optional saslSupport cyrus_sasl; - - configureFlags = [ - (lib.enableFeature headerCache "hcache") - (lib.enableFeature gpgmeSupport "gpgme") - (lib.enableFeature imapSupport "imap") - (lib.enableFeature smtpSupport "smtp") - (lib.enableFeature pop3Support "pop") - (lib.enableFeature withSidebar "sidebar") - "--with-mailpath=" - - # Look in $PATH at runtime, instead of hardcoding /usr/bin/sendmail - "ac_cv_path_SENDMAIL=sendmail" - - # This allows calls with "-d N", that output debug info into ~/.muttdebug* - "--enable-debug" - - # The next allows building mutt without having anything setgid - # set by the installer, and removing the need for the group 'mail' - # I set the value 'mailbox' because it is a default in the configure script - "--with-homespool=mailbox" - ] ++ lib.optional sslSupport "--with-ssl" - ++ lib.optional gssSupport "--with-gss" - ++ lib.optional saslSupport "--with-sasl" + ++ lib.optional headerCache gdbm + ++ lib.optional sslSupport openssl + ++ lib.optional gssSupport libkrb5 + ++ lib.optional saslSupport cyrus_sasl; + + configureFlags = + [ + (lib.enableFeature headerCache "hcache") + (lib.enableFeature gpgmeSupport "gpgme") + (lib.enableFeature imapSupport "imap") + (lib.enableFeature smtpSupport "smtp") + (lib.enableFeature pop3Support "pop") + (lib.enableFeature withSidebar "sidebar") + "--with-mailpath=" + + # Look in $PATH at runtime, instead of hardcoding /usr/bin/sendmail + "ac_cv_path_SENDMAIL=sendmail" + + # This allows calls with "-d N", that output debug info into ~/.muttdebug* + "--enable-debug" + + # The next allows building mutt without having anything setgid + # set by the installer, and removing the need for the group 'mail' + # I set the value 'mailbox' because it is a default in the configure script + "--with-homespool=mailbox" + ] + ++ lib.optional sslSupport "--with-ssl" + ++ lib.optional gssSupport "--with-gss" + ++ lib.optional saslSupport "--with-sasl" ++ lib.optional gpgmeSupport "--with-gpgme-prefix=${lib.getDev gpgme}"; postPatch = lib.optionalString (smimeSupport || gpgmeSupport) '' sed -i 's#/usr/bin/openssl#${openssl}/bin/openssl#' smime_keys.pl ''; - postInstall = lib.optionalString smimeSupport '' - # S/MIME setup - cp contrib/smime.rc $out/etc/smime.rc - sed -i 's#openssl#${openssl}/bin/openssl#' $out/etc/smime.rc - echo "source $out/etc/smime.rc" >> $out/etc/Muttrc - '' + lib.optionalString gpgSupport '' - # GnuPG setup - cp contrib/gpg.rc $out/etc/gpg.rc - sed -i 's#\(command="\)gpg #\1${gnupg}/bin/gpg #' $out/etc/gpg.rc - echo "source $out/etc/gpg.rc" >> $out/etc/Muttrc - ''; + postInstall = + lib.optionalString smimeSupport '' + # S/MIME setup + cp contrib/smime.rc $out/etc/smime.rc + sed -i 's#openssl#${openssl}/bin/openssl#' $out/etc/smime.rc + echo "source $out/etc/smime.rc" >> $out/etc/Muttrc + '' + + lib.optionalString gpgSupport '' + # GnuPG setup + cp contrib/gpg.rc $out/etc/gpg.rc + sed -i 's#\(command="\)gpg #\1${gnupg}/bin/gpg #' $out/etc/gpg.rc + echo "source $out/etc/gpg.rc" >> $out/etc/Muttrc + ''; passthru = { updateScript = writeScript "update-mutt" '' diff --git a/pkgs/by-name/mu/muzika/package.nix b/pkgs/by-name/mu/muzika/package.nix index d3b4e3d2745225..fd537eb1675d32 100644 --- a/pkgs/by-name/mu/muzika/package.nix +++ b/pkgs/by-name/mu/muzika/package.nix @@ -1,24 +1,25 @@ -{ lib -, desktop-file-utils -, fetchFromGitHub -, fetchYarnDeps -, fixup-yarn-lock -, gjs -, glib-networking -, gobject-introspection -, gst_all_1 -, gtk4 -, libadwaita -, libsoup_3 -, meson -, ninja -, pkg-config -, stdenv -, wrapGAppsHook4 -, yarn -, nodejs -, blueprint-compiler -, libsecret +{ + lib, + desktop-file-utils, + fetchFromGitHub, + fetchYarnDeps, + fixup-yarn-lock, + gjs, + glib-networking, + gobject-introspection, + gst_all_1, + gtk4, + libadwaita, + libsoup_3, + meson, + ninja, + pkg-config, + stdenv, + wrapGAppsHook4, + yarn, + nodejs, + blueprint-compiler, + libsecret, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mv/mvapich/package.nix b/pkgs/by-name/mv/mvapich/package.nix index 1299d06d46877e..c70fa731d003d5 100644 --- a/pkgs/by-name/mv/mvapich/package.nix +++ b/pkgs/by-name/mv/mvapich/package.nix @@ -1,16 +1,35 @@ -{ lib, stdenv, fetchurl, pkg-config, bison, numactl, libxml2 -, perl, gfortran, slurm, openssh, hwloc, zlib, makeWrapper -# InfiniBand dependencies -, opensm, rdma-core -# OmniPath dependencies -, libpsm2, libfabric -# Compile with slurm as a process manager -, useSlurm ? false -# Network type for MVAPICH2 -, network ? "ethernet" -} : +{ + lib, + stdenv, + fetchurl, + pkg-config, + bison, + numactl, + libxml2, + perl, + gfortran, + slurm, + openssh, + hwloc, + zlib, + makeWrapper, + # InfiniBand dependencies + opensm, + rdma-core, + # OmniPath dependencies + libpsm2, + libfabric, + # Compile with slurm as a process manager + useSlurm ? false, + # Network type for MVAPICH2 + network ? "ethernet", +}: -assert builtins.elem network [ "ethernet" "infiniband" "omnipath" ]; +assert builtins.elem network [ + "ethernet" + "infiniband" + "omnipath" +]; stdenv.mkDerivation rec { pname = "mvapich"; @@ -21,32 +40,63 @@ stdenv.mkDerivation rec { sha256 = "sha256-w5pEkvS+UN9hAHhXSLoolOI85FCpQSgYHVFtpXV3Ua4="; }; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; - nativeBuildInputs = [ pkg-config bison makeWrapper gfortran ]; - propagatedBuildInputs = [ numactl rdma-core zlib opensm ]; - buildInputs = [ + nativeBuildInputs = [ + pkg-config + bison + makeWrapper + gfortran + ]; + propagatedBuildInputs = [ numactl - libxml2 - perl - openssh - hwloc - ] ++ lib.optionals (network == "infiniband") [ rdma-core opensm ] - ++ lib.optionals (network == "omnipath") [ libpsm2 libfabric ] + rdma-core + zlib + opensm + ]; + buildInputs = + [ + numactl + libxml2 + perl + openssh + hwloc + ] + ++ lib.optionals (network == "infiniband") [ + rdma-core + opensm + ] + ++ lib.optionals (network == "omnipath") [ + libpsm2 + libfabric + ] ++ lib.optional useSlurm slurm; - configureFlags = [ - "--with-pm=hydra" - "--enable-fortran=all" - "--enable-cxx" - "--enable-threads=multiple" - "--enable-hybrid" - "--enable-shared" - "FFLAGS=-fallow-argument-mismatch" # fix build with gfortran 10 - ] ++ lib.optional useSlurm "--with-pm=slurm" + configureFlags = + [ + "--with-pm=hydra" + "--enable-fortran=all" + "--enable-cxx" + "--enable-threads=multiple" + "--enable-hybrid" + "--enable-shared" + "FFLAGS=-fallow-argument-mismatch" # fix build with gfortran 10 + ] + ++ lib.optional useSlurm "--with-pm=slurm" ++ lib.optional (network == "ethernet") "--with-device=ch3:sock" - ++ lib.optionals (network == "infiniband") [ "--with-device=ch3:mrail" "--with-rdma=gen2" "--disable-ibv-dlopen" ] - ++ lib.optionals (network == "omnipath") ["--with-device=ch3:psm" "--with-psm2=${libpsm2}"]; + ++ lib.optionals (network == "infiniband") [ + "--with-device=ch3:mrail" + "--with-rdma=gen2" + "--disable-ibv-dlopen" + ] + ++ lib.optionals (network == "omnipath") [ + "--with-device=ch3:psm" + "--with-psm2=${libpsm2}" + ]; doCheck = true; diff --git a/pkgs/by-name/mv/mvebu64boot/package.nix b/pkgs/by-name/mv/mvebu64boot/package.nix index 0c682cebd5e663..61fcad72b47d6f 100644 --- a/pkgs/by-name/mv/mvebu64boot/package.nix +++ b/pkgs/by-name/mv/mvebu64boot/package.nix @@ -1,7 +1,8 @@ -{ fetchFromGitHub -, stdenv -, lib -, ncurses +{ + fetchFromGitHub, + stdenv, + lib, + ncurses, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/mw/mw/package.nix b/pkgs/by-name/mw/mw/package.nix index f1b8b9dcf32161..4503f09ec54297 100644 --- a/pkgs/by-name/mw/mw/package.nix +++ b/pkgs/by-name/mw/mw/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildNpmPackage +{ + lib, + fetchFromGitHub, + buildNpmPackage, }: buildNpmPackage rec { diff --git a/pkgs/by-name/mx/mx-takeover/package.nix b/pkgs/by-name/mx/mx-takeover/package.nix index 13804b4e887227..d3799694f37c21 100644 --- a/pkgs/by-name/mx/mx-takeover/package.nix +++ b/pkgs/by-name/mx/mx-takeover/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/mx/mxt-app/package.nix b/pkgs/by-name/mx/mxt-app/package.nix index 02bd829c9431e3..7e2635278b652d 100644 --- a/pkgs/by-name/mx/mxt-app/package.nix +++ b/pkgs/by-name/mx/mxt-app/package.nix @@ -1,7 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libtool }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libtool, +}: stdenv.mkDerivation rec { - version="1.41"; + version = "1.41"; pname = "mxt-app"; src = fetchFromGitHub { diff --git a/pkgs/by-name/my/mya/package.nix b/pkgs/by-name/my/mya/package.nix index d33e6aecdf2918..073a003498d69d 100644 --- a/pkgs/by-name/my/mya/package.nix +++ b/pkgs/by-name/my/mya/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -, curl -, json_c -, libbsd -, argp-standalone +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + curl, + json_c, + libbsd, + argp-standalone, }: stdenv.mkDerivation (finalAttrs: { @@ -25,13 +26,15 @@ stdenv.mkDerivation (finalAttrs: { ninja ]; - buildInputs = [ - curl - json_c - libbsd - ] ++ lib.optionals (!stdenv.hostPlatform.isGnu) [ - argp-standalone - ]; + buildInputs = + [ + curl + json_c + libbsd + ] + ++ lib.optionals (!stdenv.hostPlatform.isGnu) [ + argp-standalone + ]; patches = [ ./argp.patch diff --git a/pkgs/by-name/my/myanon/package.nix b/pkgs/by-name/my/myanon/package.nix index 3ac096267e6d93..0123698f6e2a19 100644 --- a/pkgs/by-name/my/myanon/package.nix +++ b/pkgs/by-name/my/myanon/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, flex -, bison +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + flex, + bison, }: stdenv.mkDerivation (finalAttrs: { @@ -17,7 +18,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-sB6ykRywaoG2gfHOEQ9UoVn62nMciBWgCM9DhovBoe0="; }; - nativeBuildInputs = [ autoreconfHook flex bison ]; + nativeBuildInputs = [ + autoreconfHook + flex + bison + ]; meta = { description = "Myanon is a mysqldump anonymizer, reading a dump from stdin, and producing on the fly an anonymized version to stdout"; @@ -27,4 +32,3 @@ stdenv.mkDerivation (finalAttrs: { platforms = lib.platforms.unix; }; }) - diff --git a/pkgs/by-name/my/mycorrhiza/package.nix b/pkgs/by-name/my/mycorrhiza/package.nix index 02f19ed08b75c9..9ffd22c450e624 100644 --- a/pkgs/by-name/my/mycorrhiza/package.nix +++ b/pkgs/by-name/my/mycorrhiza/package.nix @@ -1,5 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, buildGoModule -, makeWrapper, git +{ + stdenv, + lib, + fetchFromGitHub, + buildGoModule, + makeWrapper, + git, }: buildGoModule rec { diff --git a/pkgs/by-name/my/mycrypto/package.nix b/pkgs/by-name/my/mycrypto/package.nix index 0798b888d022e3..04f713d2a30fc3 100644 --- a/pkgs/by-name/my/mycrypto/package.nix +++ b/pkgs/by-name/my/mycrypto/package.nix @@ -1,4 +1,9 @@ -{ lib, appimageTools, fetchurl, makeDesktopItem }: +{ + lib, + appimageTools, + fetchurl, + makeDesktopItem, +}: let pname = "MyCrypto"; @@ -23,7 +28,8 @@ let categories = [ "Finance" ]; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; extraInstallCommands = '' diff --git a/pkgs/by-name/my/mydumper/package.nix b/pkgs/by-name/my/mydumper/package.nix index a6a1370646ca1e..865f5f7b8c0fb1 100644 --- a/pkgs/by-name/my/mydumper/package.nix +++ b/pkgs/by-name/my/mydumper/package.nix @@ -1,10 +1,26 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, pkg-config, sphinx, python3Packages -, glib, pcre, pcre2, util-linux -, libsysprof-capture, libmysqlclient, libressl -, zlib, zstd -, libselinux, libsepol -, nix-update-script, testers, versionCheckHook, mydumper +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + sphinx, + python3Packages, + glib, + pcre, + pcre2, + util-linux, + libsysprof-capture, + libmysqlclient, + libressl, + zlib, + zstd, + libselinux, + libsepol, + nix-update-script, + testers, + versionCheckHook, + mydumper, }: stdenv.mkDerivation rec { @@ -20,18 +36,38 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; - nativeBuildInputs = [ cmake pkg-config sphinx python3Packages.furo ]; + nativeBuildInputs = [ + cmake + pkg-config + sphinx + python3Packages.furo + ]; nativeInstallCheckInputs = [ versionCheckHook ]; doInstallCheck = true; - buildInputs = [ - glib pcre pcre2 util-linux - libmysqlclient libressl libsysprof-capture - zlib zstd - ] ++ lib.optionals stdenv.isLinux [ libselinux libsepol ]; + buildInputs = + [ + glib + pcre + pcre2 + util-linux + libmysqlclient + libressl + libsysprof-capture + zlib + zstd + ] + ++ lib.optionals stdenv.isLinux [ + libselinux + libsepol + ]; cmakeFlags = [ "-DBUILD_DOCS=ON" @@ -78,6 +114,9 @@ stdenv.mkDerivation rec { changelog = "https://github.com/mydumper/mydumper/releases/tag/v${version}"; license = licenses.gpl3Plus; platforms = lib.platforms.unix; - maintainers = with maintainers; [ izorkin michaelglass ]; + maintainers = with maintainers; [ + izorkin + michaelglass + ]; }; } diff --git a/pkgs/by-name/my/mylvmbackup/package.nix b/pkgs/by-name/my/mylvmbackup/package.nix index 590a4655eb402e..b45d653fe0453a 100644 --- a/pkgs/by-name/my/mylvmbackup/package.nix +++ b/pkgs/by-name/my/mylvmbackup/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, perlPackages -, makeWrapper +{ + lib, + stdenv, + fetchurl, + perlPackages, + makeWrapper, }: stdenv.mkDerivation rec { @@ -29,15 +30,18 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram "$out/bin/mylvmbackup" \ - --prefix PERL5LIB : "${perlPackages.makePerlPath ( - with perlPackages; [ - ConfigIniFiles - DBDmysql - DBI - TimeDate - FileCopyRecursive - ] - )}" + --prefix PERL5LIB : "${ + perlPackages.makePerlPath ( + with perlPackages; + [ + ConfigIniFiles + DBDmysql + DBI + TimeDate + FileCopyRecursive + ] + ) + }" ''; meta = { diff --git a/pkgs/by-name/my/mympd/package.nix b/pkgs/by-name/my/mympd/package.nix index dd38997971d68a..c0362e214b295c 100644 --- a/pkgs/by-name/my/mympd/package.nix +++ b/pkgs/by-name/my/mympd/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, libmpdclient -, openssl -, lua5_3 -, libid3tag -, flac -, pcre2 -, gzip -, perl -, jq -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libmpdclient, + openssl, + lua5_3, + libid3tag, + flac, + pcre2, + gzip, + perl, + jq, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/my/mynewt-newtmgr/package.nix b/pkgs/by-name/my/mynewt-newtmgr/package.nix index d78c6304a1e366..bf9e547b104074 100644 --- a/pkgs/by-name/my/mynewt-newtmgr/package.nix +++ b/pkgs/by-name/my/mynewt-newtmgr/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, stdenv -, testers -, mynewt-newtmgr +{ + lib, + buildGoModule, + fetchFromGitHub, + stdenv, + testers, + mynewt-newtmgr, }: buildGoModule rec { @@ -13,7 +14,7 @@ buildGoModule rec { src = fetchFromGitHub { owner = "apache"; repo = "mynewt-newtmgr"; - rev = "mynewt_${builtins.replaceStrings ["."] ["_"] version}_tag"; + rev = "mynewt_${builtins.replaceStrings [ "." ] [ "_" ] version}_tag"; sha256 = "sha256-fobaMkYLLK5qclogtClGdOjgTbmuse/72T3APNssYa4="; }; diff --git a/pkgs/by-name/my/mypaint/package.nix b/pkgs/by-name/my/mypaint/package.nix index 10a19431dbfca8..2977a381c9f984 100644 --- a/pkgs/by-name/my/mypaint/package.nix +++ b/pkgs/by-name/my/mypaint/package.nix @@ -1,26 +1,33 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, gtk3 -, gettext -, json_c -, lcms2 -, libpng -, librsvg -, gobject-introspection -, libmypaint -, hicolor-icon-theme -, mypaint-brushes -, gdk-pixbuf -, pkg-config -, python3 -, swig -, wrapGAppsHook3 +{ + lib, + fetchFromGitHub, + fetchpatch, + gtk3, + gettext, + json_c, + lcms2, + libpng, + librsvg, + gobject-introspection, + libmypaint, + hicolor-icon-theme, + mypaint-brushes, + gdk-pixbuf, + pkg-config, + python3, + swig, + wrapGAppsHook3, }: let - inherit (python3.pkgs) pycairo pygobject3 numpy buildPythonApplication; -in buildPythonApplication rec { + inherit (python3.pkgs) + pycairo + pygobject3 + numpy + buildPythonApplication + ; +in +buildPythonApplication rec { pname = "mypaint"; version = "2.0.1"; format = "other"; diff --git a/pkgs/by-name/my/myrddin/package.nix b/pkgs/by-name/my/myrddin/package.nix index 9ce5185f41dcbb..d941dfc6dcaa56 100644 --- a/pkgs/by-name/my/myrddin/package.nix +++ b/pkgs/by-name/my/myrddin/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, bison -, binutils -, makeWrapper +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + bison, + binutils, + makeWrapper, }: stdenv.mkDerivation rec { @@ -53,6 +54,7 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ ]; platforms = platforms.all; # darwin: never built on Hydra https://hydra.nixos.org/job/nixpkgs/trunk/myrddin.x86_64-darwin - broken = (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) || stdenv.hostPlatform.isDarwin; + broken = + (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) || stdenv.hostPlatform.isDarwin; }; } diff --git a/pkgs/by-name/my/myrescue/package.nix b/pkgs/by-name/my/myrescue/package.nix index 975599c219f8ad..9a53d03970915f 100644 --- a/pkgs/by-name/my/myrescue/package.nix +++ b/pkgs/by-name/my/myrescue/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, installShellFiles +{ + lib, + stdenv, + fetchurl, + installShellFiles, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/my/myrica/package.nix b/pkgs/by-name/my/myrica/package.nix index 5d8aa43a5b21c1..bba8fde3e86712 100644 --- a/pkgs/by-name/my/myrica/package.nix +++ b/pkgs/by-name/my/myrica/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "myrica"; diff --git a/pkgs/by-name/my/mysides/package.nix b/pkgs/by-name/my/mysides/package.nix index cdbfee5046a2aa..acdd4cb5c6aaa7 100644 --- a/pkgs/by-name/my/mysides/package.nix +++ b/pkgs/by-name/my/mysides/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libarchive, p7zip }: +{ + lib, + stdenv, + fetchurl, + libarchive, + p7zip, +}: stdenv.mkDerivation rec { pname = "mysides"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { }; dontBuild = true; - nativeBuildInputs = [ libarchive p7zip ]; + nativeBuildInputs = [ + libarchive + p7zip + ]; unpackPhase = '' 7z x $src diff --git a/pkgs/by-name/my/mysql2pgsql/package.nix b/pkgs/by-name/my/mysql2pgsql/package.nix index d3e24c55984938..47c834240afd91 100644 --- a/pkgs/by-name/my/mysql2pgsql/package.nix +++ b/pkgs/by-name/my/mysql2pgsql/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: # The homepage says this script is mature.. stdenv.mkDerivation rec { diff --git a/pkgs/by-name/my/mysql84/package.nix b/pkgs/by-name/my/mysql84/package.nix index 4e2128a3ef1b3a..075c39763ae7e5 100644 --- a/pkgs/by-name/my/mysql84/package.nix +++ b/pkgs/by-name/my/mysql84/package.nix @@ -1,6 +1,28 @@ -{ lib, stdenv, fetchurl, bison, cmake, pkg-config -, icu, libedit, libevent, lz4, ncurses, openssl, protobuf_21, re2, readline, zlib, zstd, libfido2 -, cctools, darwin, numactl, libtirpc, rpcsvc-proto, curl +{ + lib, + stdenv, + fetchurl, + bison, + cmake, + pkg-config, + icu, + libedit, + libevent, + lz4, + ncurses, + openssl, + protobuf_21, + re2, + readline, + zlib, + zstd, + libfido2, + cctools, + darwin, + numactl, + libtirpc, + rpcsvc-proto, + curl, }: stdenv.mkDerivation (finalAttrs: { @@ -12,8 +34,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-eslWTEeAIvcwBf+Ju7QPZ7OB/AbVUYQWvf/sdeYluBg="; }; - nativeBuildInputs = [ bison cmake pkg-config ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ rpcsvc-proto ]; + nativeBuildInputs = [ + bison + cmake + pkg-config + ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ rpcsvc-proto ]; patches = [ ./no-force-outline-atomics.patch # Do not force compilers to turn on -moutline-atomics switch @@ -25,16 +50,37 @@ stdenv.mkDerivation (finalAttrs: { substituteInPlace cmake/os/Darwin.cmake --replace /usr/bin/libtool libtool ''; - buildInputs = [ - (curl.override { inherit openssl; }) icu libedit libevent lz4 ncurses openssl protobuf_21 re2 readline zlib - zstd libfido2 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - numactl libtirpc - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - cctools darwin.apple_sdk.frameworks.CoreServices darwin.developer_cmds darwin.DarwinTools - ]; + buildInputs = + [ + (curl.override { inherit openssl; }) + icu + libedit + libevent + lz4 + ncurses + openssl + protobuf_21 + re2 + readline + zlib + zstd + libfido2 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + numactl + libtirpc + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + cctools + darwin.apple_sdk.frameworks.CoreServices + darwin.developer_cmds + darwin.DarwinTools + ]; - outputs = [ "out" "static" ]; + outputs = [ + "out" + "static" + ]; cmakeFlags = [ "-DFORCE_UNSUPPORTED_COMPILER=1" # To configure on Darwin. @@ -72,7 +118,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.mysql.com/"; description = "World's most popular open source database"; license = licenses.gpl2; - maintainers = with maintainers; [ orivej shyim ]; + maintainers = with maintainers; [ + orivej + shyim + ]; platforms = platforms.unix; }; }) diff --git a/pkgs/by-name/my/mysql_jdbc/package.nix b/pkgs/by-name/my/mysql_jdbc/package.nix index 15c9f519be7113..bcafbc7b52f521 100644 --- a/pkgs/by-name/my/mysql_jdbc/package.nix +++ b/pkgs/by-name/my/mysql_jdbc/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, ant, unzip, gitUpdater }: +{ + lib, + stdenv, + fetchurl, + ant, + unzip, + gitUpdater, +}: stdenv.mkDerivation rec { pname = "mysql-connector-java"; diff --git a/pkgs/by-name/my/mysqltuner/package.nix b/pkgs/by-name/my/mysqltuner/package.nix index f13b455e523bf4..ebda96763c015c 100644 --- a/pkgs/by-name/my/mysqltuner/package.nix +++ b/pkgs/by-name/my/mysqltuner/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation rec { pname = "mysqltuner"; @@ -31,7 +36,10 @@ stdenv.mkDerivation rec { description = "Make recommendations for increased performance and stability of MariaDB/MySQL"; homepage = "https://github.com/major/MySQLTuner-perl"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ peterhoeg shamilton ]; + maintainers = with maintainers; [ + peterhoeg + shamilton + ]; mainProgram = "mysqltuner"; }; } diff --git a/pkgs/by-name/my/mystem/package.nix b/pkgs/by-name/my/mystem/package.nix index 50c2c35749e0c0..cd7e9bd1ad2b75 100644 --- a/pkgs/by-name/my/mystem/package.nix +++ b/pkgs/by-name/my/mystem/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mystem"; diff --git a/pkgs/by-name/my/mystmd/package.nix b/pkgs/by-name/my/mystmd/package.nix index 542ead80299163..1c3d41a8c8254f 100644 --- a/pkgs/by-name/my/mystmd/package.nix +++ b/pkgs/by-name/my/mystmd/package.nix @@ -1,4 +1,11 @@ -{ lib, buildNpmPackage, fetchFromGitHub, mystmd, testers, nix-update-script }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, + mystmd, + testers, + nix-update-script, +}: buildNpmPackage rec { pname = "mystmd"; diff --git a/pkgs/by-name/my/mythes/package.nix b/pkgs/by-name/my/mythes/package.nix index 960fefc74ac145..9fe998421a9bc9 100644 --- a/pkgs/by-name/my/mythes/package.nix +++ b/pkgs/by-name/my/mythes/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, hunspell, ncurses, pkg-config, perl }: +{ + lib, + stdenv, + fetchurl, + hunspell, + ncurses, + pkg-config, + perl, +}: stdenv.mkDerivation rec { pname = "mythes"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; buildInputs = [ hunspell ]; - nativeBuildInputs = [ ncurses pkg-config perl ]; + nativeBuildInputs = [ + ncurses + pkg-config + perl + ]; meta = { homepage = "https://hunspell.sourceforge.net/"; diff --git a/pkgs/by-name/my/myxer/package.nix b/pkgs/by-name/my/myxer/package.nix index 8b865ba475f115..73dbad4c793064 100644 --- a/pkgs/by-name/my/myxer/package.nix +++ b/pkgs/by-name/my/myxer/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, wrapGAppsHook3 -, libpulseaudio -, glib -, pango -, gtk3 +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + wrapGAppsHook3, + libpulseaudio, + glib, + pango, + gtk3, }: rustPlatform.buildRustPackage rec { @@ -22,9 +23,17 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-IH+SLIHO/wu+przH+mgOEnH9m+iAE5s/BJhh0UUHR/0="; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; - buildInputs = [ libpulseaudio glib pango gtk3 ]; + buildInputs = [ + libpulseaudio + glib + pango + gtk3 + ]; postInstall = '' install -Dm644 Myxer.desktop $out/share/applications/Myxer.desktop @@ -37,7 +46,10 @@ rustPlatform.buildRustPackage rec { description = "Modern Volume Mixer for PulseAudio"; homepage = "https://github.com/Aurailus/Myxer"; license = licenses.gpl3Only; - maintainers = with maintainers; [ erin rster2002 ]; + maintainers = with maintainers; [ + erin + rster2002 + ]; mainProgram = "myxer"; platforms = platforms.linux; }; diff --git a/pkgs/by-name/n2/n2/package.nix b/pkgs/by-name/n2/n2/package.nix index 6700cc58a777c3..c9293a57aa47fd 100644 --- a/pkgs/by-name/n2/n2/package.nix +++ b/pkgs/by-name/n2/n2/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage { diff --git a/pkgs/by-name/n2/n2048/package.nix b/pkgs/by-name/n2/n2048/package.nix index 2ae937ee6be273..7b4c570a6fb54c 100644 --- a/pkgs/by-name/n2/n2048/package.nix +++ b/pkgs/by-name/n2/n2048/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "n2048"; diff --git a/pkgs/by-name/n2/n2n/package.nix b/pkgs/by-name/n2/n2n/package.nix index cde49d1c392d98..55a7bda111b759 100644 --- a/pkgs/by-name/n2/n2n/package.nix +++ b/pkgs/by-name/n2/n2n/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, libcap }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libcap, +}: stdenv.mkDerivation rec { pname = "n2n"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-OXmcc6r+fTHs/tDNF3akSsynB/bVRKB6Fl5oYxmu+E0="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libcap diff --git a/pkgs/by-name/n3/n3/package.nix b/pkgs/by-name/n3/n3/package.nix index e7ae8fb3cea3de..81f6e74ace881e 100644 --- a/pkgs/by-name/n3/n3/package.nix +++ b/pkgs/by-name/n3/n3/package.nix @@ -1,15 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, cmake, makeWrapper, +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + makeWrapper, perlPackages, - libminc, ebtks }: + libminc, + ebtks, +}: stdenv.mkDerivation rec { pname = "N3"; version = "unstable-2018-08-09"; src = fetchFromGitHub { - owner = "BIC-MNI"; - repo = pname; - rev = "010fc2ac58ce1d67b8e6a863fac0809d3203cb9b"; + owner = "BIC-MNI"; + repo = pname; + rev = "010fc2ac58ce1d67b8e6a863fac0809d3203cb9b"; sha256 = "06hci7gzhy8p34ggvx7gah2k9yxpwhgmq1cgw8pcd1r82g4rg6kd"; }; @@ -18,11 +25,24 @@ stdenv.mkDerivation rec { --replace "register " "" ''; - nativeBuildInputs = [ cmake makeWrapper ]; - buildInputs = [ libminc ebtks ]; - propagatedBuildInputs = with perlPackages; [ perl MNI-Perllib GetoptTabular ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; + buildInputs = [ + libminc + ebtks + ]; + propagatedBuildInputs = with perlPackages; [ + perl + MNI-Perllib + GetoptTabular + ]; - cmakeFlags = [ "-DLIBMINC_DIR=${libminc}/lib/cmake" "-DEBTKS_DIR=${ebtks}/lib/" ]; + cmakeFlags = [ + "-DLIBMINC_DIR=${libminc}/lib/cmake" + "-DEBTKS_DIR=${ebtks}/lib/" + ]; postFixup = '' for p in $out/bin/*; do @@ -35,6 +55,6 @@ stdenv.mkDerivation rec { description = "MRI non-uniformity correction for MINC files"; maintainers = with maintainers; [ bcdarwin ]; platforms = platforms.unix; - license = licenses.free; + license = licenses.free; }; } diff --git a/pkgs/by-name/n9/n98-magerun/package.nix b/pkgs/by-name/n9/n98-magerun/package.nix index c52fd68473b16c..2aadbf8a837b36 100644 --- a/pkgs/by-name/n9/n98-magerun/package.nix +++ b/pkgs/by-name/n9/n98-magerun/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, php81 +{ + lib, + fetchFromGitHub, + php81, }: php81.buildComposerProject (finalAttrs: { diff --git a/pkgs/by-name/na/nabi/package.nix b/pkgs/by-name/na/nabi/package.nix index aba2d2f66c672a..dbeedd39f7a09f 100644 --- a/pkgs/by-name/na/nabi/package.nix +++ b/pkgs/by-name/na/nabi/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, gtk2, libhangul }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + libhangul, +}: stdenv.mkDerivation rec { pname = "nabi"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk2 libhangul ]; + buildInputs = [ + gtk2 + libhangul + ]; meta = with lib; { description = "Easy Hangul XIM"; diff --git a/pkgs/by-name/na/nacelle/package.nix b/pkgs/by-name/na/nacelle/package.nix index e43d0b4402ac6a..2ab17a4c87be7e 100644 --- a/pkgs/by-name/na/nacelle/package.nix +++ b/pkgs/by-name/na/nacelle/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "1"; diff --git a/pkgs/by-name/na/naev/package.nix b/pkgs/by-name/na/naev/package.nix index 24f21f4df5d814..9f52a1b623cbc6 100644 --- a/pkgs/by-name/na/naev/package.nix +++ b/pkgs/by-name/na/naev/package.nix @@ -1,27 +1,28 @@ -{ lib -, SDL2 -, SDL2_image -, enet -, fetchFromGitHub -, freetype -, glpk -, intltool -, libpng -, libunibreak -, libvorbis -, libwebp -, libxml2 -, luajit -, meson -, ninja -, openal -, openblas -, pcre2 -, physfs -, pkg-config -, python3 -, stdenv -, suitesparse +{ + lib, + SDL2, + SDL2_image, + enet, + fetchFromGitHub, + freetype, + glpk, + intltool, + libpng, + libunibreak, + libvorbis, + libwebp, + libxml2, + luajit, + meson, + ninja, + openal, + openblas, + pcre2, + physfs, + pkg-config, + python3, + stdenv, + suitesparse, }: stdenv.mkDerivation rec { @@ -56,7 +57,12 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ - (python3.withPackages (ps: with ps; [ pyyaml mutagen ])) + (python3.withPackages ( + ps: with ps; [ + pyyaml + mutagen + ] + )) meson ninja pkg-config diff --git a/pkgs/by-name/na/nafees/package.nix b/pkgs/by-name/na/nafees/package.nix index e23528aefe8057..3e5af2873cff0b 100644 --- a/pkgs/by-name/na/nafees/package.nix +++ b/pkgs/by-name/na/nafees/package.nix @@ -1,34 +1,40 @@ -{lib, stdenv, fetchurl, unzip}: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation { name = "nafees"; - srcs = [(fetchurl { - url = "http://www.cle.org.pk/Downloads/localization/fonts/NafeesNastaleeq/Nafees_Nastaleeq_v1.02.zip"; - sha256 = "1h1k5d74pg2gs782910v7i9rz2633wdacy34ds7ybxbpjiz6pqix"; - }) - - (fetchurl { - url = "http://www.cle.org.pk/Downloads/localization/fonts/NafeesRiqa/Nafees_Riqa_v1.0.zip"; - sha256 = "1liismsyaj69y40vs9a9db4l95n25n8vnjnx7sbk70nxppwngd8i"; - }) - - (fetchurl { - url = "http://www.cle.org.pk/Downloads/localization/fonts/NafeesNaskh/Nafees_Naskh_v2.01.zip"; - sha256 = "1qbbj6w6bvrlymv7z6ld609yhp0l2f27z14180w5n8kzzl720vly"; - }) - - (fetchurl { - url = "http://www.cle.org.pk/Downloads/localization/fonts/NafeesTahreerNaskh/Nafees_Tahreer_Naskh_v1.0.zip"; - sha256 = "006l87drbi4zh52kpvn8wl9wbwm9srfn406rzsnf4gv0spzhqrxl"; - }) - (fetchurl { - url = "http://www.cle.org.pk/Downloads/localization/fonts/NafeesPakistaniNaskh/Nafees_Pakistani_Naskh_v2.01.zip"; - sha256 = "1i5ip60gq1cgc9fc96kvlahdpia8dxdgcisglvbm2d212bz0s5nb"; - }) -]; - - nativeBuildInputs = [unzip]; + srcs = [ + (fetchurl { + url = "http://www.cle.org.pk/Downloads/localization/fonts/NafeesNastaleeq/Nafees_Nastaleeq_v1.02.zip"; + sha256 = "1h1k5d74pg2gs782910v7i9rz2633wdacy34ds7ybxbpjiz6pqix"; + }) + + (fetchurl { + url = "http://www.cle.org.pk/Downloads/localization/fonts/NafeesRiqa/Nafees_Riqa_v1.0.zip"; + sha256 = "1liismsyaj69y40vs9a9db4l95n25n8vnjnx7sbk70nxppwngd8i"; + }) + + (fetchurl { + url = "http://www.cle.org.pk/Downloads/localization/fonts/NafeesNaskh/Nafees_Naskh_v2.01.zip"; + sha256 = "1qbbj6w6bvrlymv7z6ld609yhp0l2f27z14180w5n8kzzl720vly"; + }) + + (fetchurl { + url = "http://www.cle.org.pk/Downloads/localization/fonts/NafeesTahreerNaskh/Nafees_Tahreer_Naskh_v1.0.zip"; + sha256 = "006l87drbi4zh52kpvn8wl9wbwm9srfn406rzsnf4gv0spzhqrxl"; + }) + (fetchurl { + url = "http://www.cle.org.pk/Downloads/localization/fonts/NafeesPakistaniNaskh/Nafees_Pakistani_Naskh_v2.01.zip"; + sha256 = "1i5ip60gq1cgc9fc96kvlahdpia8dxdgcisglvbm2d212bz0s5nb"; + }) + ]; + + nativeBuildInputs = [ unzip ]; sourceRoot = "."; diff --git a/pkgs/by-name/na/nagelfar/package.nix b/pkgs/by-name/na/nagelfar/package.nix index 3e379875c4c51f..d0e02c9ee3e18f 100644 --- a/pkgs/by-name/na/nagelfar/package.nix +++ b/pkgs/by-name/na/nagelfar/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchzip, tcl, tclPackages, tk, }: +{ + lib, + fetchzip, + tcl, + tclPackages, + tk, +}: tcl.mkTclDerivation { pname = "nagelfar"; diff --git a/pkgs/by-name/na/nahid-fonts/package.nix b/pkgs/by-name/na/nahid-fonts/package.nix index 069bf877bf742f..b36b78d752e1b4 100644 --- a/pkgs/by-name/na/nahid-fonts/package.nix +++ b/pkgs/by-name/na/nahid-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "nahid-fonts"; diff --git a/pkgs/by-name/na/nailgun/package.nix b/pkgs/by-name/na/nailgun/package.nix index 6f4e5505299eed..94541e952287c3 100644 --- a/pkgs/by-name/na/nailgun/package.nix +++ b/pkgs/by-name/na/nailgun/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, stdenvNoCC, fetchMavenArtifact, fetchFromGitHub, jre, makeWrapper, symlinkJoin }: +{ + lib, + stdenv, + stdenvNoCC, + fetchMavenArtifact, + fetchFromGitHub, + jre, + makeWrapper, + symlinkJoin, +}: let version = "1.0.0"; @@ -61,7 +70,10 @@ symlinkJoin rec { inherit client server version; name = "${pname}-${version}"; - paths = [ client server ]; + paths = [ + client + server + ]; meta = commonMeta // { description = "Client, protocol, and server for running Java programs from the command line without incurring the JVM startup overhead"; diff --git a/pkgs/by-name/na/namaka/package.nix b/pkgs/by-name/na/namaka/package.nix index 70e8abc186c689..2763791448128a 100644 --- a/pkgs/by-name/na/namaka/package.nix +++ b/pkgs/by-name/na/namaka/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, oniguruma +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + oniguruma, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/na/namazu/package.nix b/pkgs/by-name/na/namazu/package.nix index e748515b051323..9616c9332ba1ca 100644 --- a/pkgs/by-name/na/namazu/package.nix +++ b/pkgs/by-name/na/namazu/package.nix @@ -1,4 +1,11 @@ -{ fetchurl, lib, stdenv, perl, perlPackages, makeWrapper }: +{ + fetchurl, + lib, + stdenv, + perl, + perlPackages, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "namazu"; @@ -9,11 +16,16 @@ stdenv.mkDerivation rec { sha256 = "1xvi7hrprdchdpzhg3fvk4yifaakzgydza5c0m50h1yvg6vay62w"; }; - buildInputs = [ perl perlPackages.FileMMagic ]; + buildInputs = [ + perl + perlPackages.FileMMagic + ]; nativeBuildInputs = [ makeWrapper ]; postInstall = '' - wrapProgram $out/bin/mknmz --set PERL5LIB ${perlPackages.makeFullPerlPath [ perlPackages.FileMMagic ]} + wrapProgram $out/bin/mknmz --set PERL5LIB ${ + perlPackages.makeFullPerlPath [ perlPackages.FileMMagic ] + } ''; meta = { @@ -28,7 +40,7 @@ stdenv.mkDerivation rec { license = lib.licenses.gpl2Plus; homepage = "http://namazu.org/"; - platforms = lib.platforms.gnu ++ lib.platforms.linux; # arbitrary choice + platforms = lib.platforms.gnu ++ lib.platforms.linux; # arbitrary choice maintainers = [ ]; }; } diff --git a/pkgs/by-name/na/namecoind/package.nix b/pkgs/by-name/na/namecoind/package.nix index 42f4be7a227bdf..ce27b8fadde6d6 100644 --- a/pkgs/by-name/na/namecoind/package.nix +++ b/pkgs/by-name/na/namecoind/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch2, openssl, boost, libevent, autoreconfHook, db4, miniupnpc, eject, pkg-config, hexdump }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch2, + openssl, + boost, + libevent, + autoreconfHook, + db4, + miniupnpc, + eject, + pkg-config, + hexdump, +}: stdenv.mkDerivation rec { pname = "namecoind"; diff --git a/pkgs/by-name/na/namespace-cli/package.nix b/pkgs/by-name/na/namespace-cli/package.nix index 4881a247d59e7d..60fa3f562138ab 100644 --- a/pkgs/by-name/na/namespace-cli/package.nix +++ b/pkgs/by-name/na/namespace-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { @@ -16,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-E9RhELIGOjFa+gDinl4xDR3ckTtdFLqVoAT0HQoI38I="; - subPackages = ["cmd/nsc" "cmd/ns" "cmd/docker-credential-nsc"]; + subPackages = [ + "cmd/nsc" + "cmd/ns" + "cmd/docker-credential-nsc" + ]; ldflags = [ "-s" diff --git a/pkgs/by-name/na/nanoblogger/package.nix b/pkgs/by-name/na/nanoblogger/package.nix index 587bf4ac4d7c46..db9b13872a0158 100644 --- a/pkgs/by-name/na/nanoblogger/package.nix +++ b/pkgs/by-name/na/nanoblogger/package.nix @@ -1,4 +1,9 @@ -{ fetchurl, lib, stdenv, bash }: +{ + fetchurl, + lib, + stdenv, + bash, +}: stdenv.mkDerivation rec { version = "3.5-rc1"; diff --git a/pkgs/by-name/na/nanodbc/package.nix b/pkgs/by-name/na/nanodbc/package.nix index 7fca00c1d4596a..18691cb6fe3599 100644 --- a/pkgs/by-name/na/nanodbc/package.nix +++ b/pkgs/by-name/na/nanodbc/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, catch2, cmake, unixODBC }: +{ + lib, + stdenv, + fetchFromGitHub, + catch2, + cmake, + unixODBC, +}: stdenv.mkDerivation rec { pname = "nanodbc"; @@ -19,10 +26,11 @@ stdenv.mkDerivation rec { buildInputs = [ unixODBC ]; - cmakeFlags = if (stdenv.hostPlatform.isStatic) then - [ "-DBUILD_STATIC_LIBS=ON" ] - else - [ "-DBUILD_SHARED_LIBS=ON" ]; + cmakeFlags = + if (stdenv.hostPlatform.isStatic) then + [ "-DBUILD_STATIC_LIBS=ON" ] + else + [ "-DBUILD_SHARED_LIBS=ON" ]; meta = with lib; { homepage = "https://github.com/nanodbc/nanodbc"; diff --git a/pkgs/by-name/na/nanoflann/package.nix b/pkgs/by-name/na/nanoflann/package.nix index f2f883d650dc91..656ff91be8ec9e 100644 --- a/pkgs/by-name/na/nanoflann/package.nix +++ b/pkgs/by-name/na/nanoflann/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, buildExamples ? false +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + buildExamples ? false, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/na/nanomq/package.nix b/pkgs/by-name/na/nanomq/package.nix index f5ad6c1bed01ab..a67679dffd47bc 100644 --- a/pkgs/by-name/na/nanomq/package.nix +++ b/pkgs/by-name/na/nanomq/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -, pkg-config -, cyclonedds -, libmysqlclient -, mariadb -, mbedtls -, sqlite -, zeromq -, flex -, bison - -# for tests -, python3 -, mosquitto -, netcat-gnu +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + pkg-config, + cyclonedds, + libmysqlclient, + mariadb, + mbedtls, + sqlite, + zeromq, + flex, + bison, + + # for tests + python3, + mosquitto, + netcat-gnu, }: let @@ -34,13 +35,19 @@ let hash = "sha256-HM5TSMfEr4uv5BuNCQjyZganSQ/ZqT3xZQp0KLmjIEc="; }; - nativeBuildInputs = [ cmake ninja flex bison ]; + nativeBuildInputs = [ + cmake + ninja + flex + bison + ]; # https://github.com/nanomq/idl-serial/issues/36 hardeningDisable = [ "fortify3" ]; }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "nanomq"; version = "0.22.1"; @@ -57,9 +64,21 @@ in stdenv.mkDerivation (finalAttrs: { --replace "DESTINATION /etc" "DESTINATION $out/etc" ''; - nativeBuildInputs = [ cmake ninja pkg-config idl-serial ]; + nativeBuildInputs = [ + cmake + ninja + pkg-config + idl-serial + ]; - buildInputs = [ cyclonedds libmysqlclient mariadb mbedtls sqlite zeromq ]; + buildInputs = [ + cyclonedds + libmysqlclient + mariadb + mbedtls + sqlite + zeromq + ]; cmakeFlags = [ (lib.cmakeBool "BUILD_BENCH" true) @@ -79,7 +98,13 @@ in stdenv.mkDerivation (finalAttrs: { nativeInstallCheckInputs = [ mosquitto netcat-gnu - (python3.withPackages (ps: with ps; [ jinja2 requests paho-mqtt ])) + (python3.withPackages ( + ps: with ps; [ + jinja2 + requests + paho-mqtt + ] + )) ]; installCheckPhase = '' runHook preInstallCheck @@ -103,7 +128,9 @@ in stdenv.mkDerivation (finalAttrs: { ''; passthru.tests = { - withInstallChecks = finalAttrs.finalPackage.overrideAttrs (_: { doInstallCheck = true; }); + withInstallChecks = finalAttrs.finalPackage.overrideAttrs (_: { + doInstallCheck = true; + }); }; meta = with lib; { diff --git a/pkgs/by-name/na/nanomsg/package.nix b/pkgs/by-name/na/nanomsg/package.nix index d7b7409dad14e2..f1487c0c095504 100644 --- a/pkgs/by-name/na/nanomsg/package.nix +++ b/pkgs/by-name/na/nanomsg/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, cmake, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { version = "1.1.5"; @@ -28,7 +34,7 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description= "Socket library that provides several common communication patterns"; + description = "Socket library that provides several common communication patterns"; homepage = "https://nanomsg.org/"; license = licenses.mit; mainProgram = "nanocat"; diff --git a/pkgs/by-name/na/nanopb/generator.nix b/pkgs/by-name/na/nanopb/generator.nix index 15d4e0605b80e1..a79fd6fc26548c 100644 --- a/pkgs/by-name/na/nanopb/generator.nix +++ b/pkgs/by-name/na/nanopb/generator.nix @@ -1,8 +1,9 @@ -{ python3 -, stdenvNoCC -, protobuf -, version -, generator-out +{ + python3, + stdenvNoCC, + protobuf, + version, + generator-out, }: stdenvNoCC.mkDerivation { pname = "nanopb-generator"; diff --git a/pkgs/by-name/na/nanopb/package.nix b/pkgs/by-name/na/nanopb/package.nix index a2f341594f9ef3..f2e308d1b6b948 100644 --- a/pkgs/by-name/na/nanopb/package.nix +++ b/pkgs/by-name/na/nanopb/package.nix @@ -1,122 +1,134 @@ -{ stdenvNoCC -, callPackage -, fetchFromGitHub -, buildPackages -, lib -, enableMalloc ? false -, noPackedStructs ? false -, maxRequiredFields ? null -, field32bit ? false -, noErrmsg ? false -, bufferOnly ? false -, systemHeader ? null -, without64bit ? false -, encodeArraysUnpacked ? false -, convertDoubleFloat ? false -, validateUtf8 ? false -, littleEndian8bit ? false -, c99StaticAssert ? false -, noStaticAssert ? false +{ + stdenvNoCC, + callPackage, + fetchFromGitHub, + buildPackages, + lib, + enableMalloc ? false, + noPackedStructs ? false, + maxRequiredFields ? null, + field32bit ? false, + noErrmsg ? false, + bufferOnly ? false, + systemHeader ? null, + without64bit ? false, + encodeArraysUnpacked ? false, + convertDoubleFloat ? false, + validateUtf8 ? false, + littleEndian8bit ? false, + c99StaticAssert ? false, + noStaticAssert ? false, }: -stdenvNoCC.mkDerivation (self: -let - generator-out = buildPackages.callPackage ./generator-out.nix { inherit (self) src version; }; - python-module = buildPackages.callPackage ./python-module.nix { - inherit (self) version; - inherit (self.passthru) generator-out; - }; - python3 = buildPackages.python3.override { - self = python3; - packageOverrides = _: _: { - nanopb-proto = self.passthru.python-module; +stdenvNoCC.mkDerivation ( + self: + let + generator-out = buildPackages.callPackage ./generator-out.nix { inherit (self) src version; }; + python-module = buildPackages.callPackage ./python-module.nix { + inherit (self) version; + inherit (self.passthru) generator-out; }; - }; - generator = buildPackages.callPackage ./generator.nix { - inherit python3; - inherit (self) version; - inherit (self.passthru) generator-out; - }; - runtime = callPackage ./runtime.nix { - inherit python3; - inherit (self) src version; - inherit - enableMalloc - noPackedStructs - maxRequiredFields - field32bit - noErrmsg - bufferOnly - systemHeader - without64bit - encodeArraysUnpacked - convertDoubleFloat - validateUtf8 - littleEndian8bit - c99StaticAssert - noStaticAssert; - }; -in -{ - pname = "nanopb"; - version = "0.4.9.1"; + python3 = buildPackages.python3.override { + self = python3; + packageOverrides = _: _: { + nanopb-proto = self.passthru.python-module; + }; + }; + generator = buildPackages.callPackage ./generator.nix { + inherit python3; + inherit (self) version; + inherit (self.passthru) generator-out; + }; + runtime = callPackage ./runtime.nix { + inherit python3; + inherit (self) src version; + inherit + enableMalloc + noPackedStructs + maxRequiredFields + field32bit + noErrmsg + bufferOnly + systemHeader + without64bit + encodeArraysUnpacked + convertDoubleFloat + validateUtf8 + littleEndian8bit + c99StaticAssert + noStaticAssert + ; + }; + in + { + pname = "nanopb"; + version = "0.4.9.1"; - src = fetchFromGitHub { - owner = "nanopb"; - repo = "nanopb"; - rev = self.version; - hash = "sha256-bMSZZaF8egAegi3enCM+DRyxOrPoWKAKybvWsrKZEDc="; - }; + src = fetchFromGitHub { + owner = "nanopb"; + repo = "nanopb"; + rev = self.version; + hash = "sha256-bMSZZaF8egAegi3enCM+DRyxOrPoWKAKybvWsrKZEDc="; + }; - dontPatch = true; - dontUnpack = true; + dontPatch = true; + dontUnpack = true; - propagatedNativeBuildInputs = [ generator ]; + propagatedNativeBuildInputs = [ generator ]; - propagatedBuildInputs = [ runtime ]; + propagatedBuildInputs = [ runtime ]; - postInstall = '' - mkdir $out - ln -s ${generator}/bin $out/bin - ln -s ${runtime}/include $out/include - ln -s ${runtime}/lib $out/lib - mkdir -p $out/share/nanopb/generator/proto - ln -s ${self.src}/generator/proto/nanopb.proto $out/share/nanopb/generator/proto/nanopb.proto - ''; + postInstall = '' + mkdir $out + ln -s ${generator}/bin $out/bin + ln -s ${runtime}/include $out/include + ln -s ${runtime}/lib $out/lib + mkdir -p $out/share/nanopb/generator/proto + ln -s ${self.src}/generator/proto/nanopb.proto $out/share/nanopb/generator/proto/nanopb.proto + ''; - passthru = { - inherit runtime generator-out python-module generator; - tests = { - simple-proto2 = callPackage ./test-simple-proto2 { }; - simple-proto3 = callPackage ./test-simple-proto3 { }; - message-with-annotations = callPackage ./test-message-with-annotations { }; - message-with-options = callPackage ./test-message-with-options { }; + passthru = { + inherit + runtime + generator-out + python-module + generator + ; + tests = { + simple-proto2 = callPackage ./test-simple-proto2 { }; + simple-proto3 = callPackage ./test-simple-proto3 { }; + message-with-annotations = callPackage ./test-message-with-annotations { }; + message-with-options = callPackage ./test-message-with-options { }; + }; }; - }; - meta = with lib; { - platforms = platforms.all; + meta = with lib; { + platforms = platforms.all; - description = "Protocol Buffers with small code size"; - homepage = "https://jpa.kapsi.fi/nanopb/"; - license = licenses.zlib; - maintainers = with maintainers; [ kalbasit liarokapisv ]; + description = "Protocol Buffers with small code size"; + homepage = "https://jpa.kapsi.fi/nanopb/"; + license = licenses.zlib; + maintainers = with maintainers; [ + kalbasit + liarokapisv + ]; - longDescription = '' - Nanopb is a small code-size Protocol Buffers implementation in ansi C. It - is especially suitable for use in microcontrollers, but fits any memory - restricted system. + longDescription = '' + Nanopb is a small code-size Protocol Buffers implementation in ansi C. It + is especially suitable for use in microcontrollers, but fits any memory + restricted system. - - Homepage: jpa.kapsi.fi/nanopb - - Documentation: jpa.kapsi.fi/nanopb/docs - - Downloads: jpa.kapsi.fi/nanopb/download - - Forum: groups.google.com/forum/#!forum/nanopb + - Homepage: jpa.kapsi.fi/nanopb + - Documentation: jpa.kapsi.fi/nanopb/docs + - Downloads: jpa.kapsi.fi/nanopb/download + - Forum: groups.google.com/forum/#!forum/nanopb - In order to use the nanopb options in your proto files, you'll need to - tell protoc where to find the nanopb.proto file. - You can do so with the --proto_path (-I) option to add the directory - ''${nanopb}/share/nanopb/generator/proto like so: + In order to use the nanopb options in your proto files, you'll need to + tell protoc where to find the nanopb.proto file. + You can do so with the --proto_path (-I) option to add the directory + ''${nanopb}/share/nanopb/generator/proto like so: - protoc --proto_path=. --proto_path=''${nanopb}/share/nanopb/generator/proto --plugin=protoc-gen-nanopb=''${nanopb}/bin/protoc-gen-nanopb --nanopb_out=out file.proto - ''; - }; -}) + protoc --proto_path=. --proto_path=''${nanopb}/share/nanopb/generator/proto --plugin=protoc-gen-nanopb=''${nanopb}/bin/protoc-gen-nanopb --nanopb_out=out file.proto + ''; + }; + } +) diff --git a/pkgs/by-name/na/nanopb/python-module.nix b/pkgs/by-name/na/nanopb/python-module.nix index f58c955307d846..2240aaca624db0 100644 --- a/pkgs/by-name/na/nanopb/python-module.nix +++ b/pkgs/by-name/na/nanopb/python-module.nix @@ -1,6 +1,7 @@ -{ python3 -, version -, generator-out +{ + python3, + version, + generator-out, }: python3.pkgs.buildPythonPackage { pname = "nanopb-python-module"; diff --git a/pkgs/by-name/na/nanopb/runtime.nix b/pkgs/by-name/na/nanopb/runtime.nix index 2af7d2cedd5d79..fba88ee37e2cb8 100644 --- a/pkgs/by-name/na/nanopb/runtime.nix +++ b/pkgs/by-name/na/nanopb/runtime.nix @@ -1,69 +1,118 @@ -{ cmake -, lib -, stdenv -, protobuf -, python3 -, src -, version -, enableMalloc -, noPackedStructs -, maxRequiredFields -, field32bit -, noErrmsg -, bufferOnly -, systemHeader -, without64bit -, encodeArraysUnpacked -, convertDoubleFloat -, validateUtf8 -, littleEndian8bit -, c99StaticAssert -, noStaticAssert +{ + cmake, + lib, + stdenv, + protobuf, + python3, + src, + version, + enableMalloc, + noPackedStructs, + maxRequiredFields, + field32bit, + noErrmsg, + bufferOnly, + systemHeader, + without64bit, + encodeArraysUnpacked, + convertDoubleFloat, + validateUtf8, + littleEndian8bit, + c99StaticAssert, + noStaticAssert, }: -stdenv.mkDerivation - ({ - pname = "nanopb-runtime"; - inherit src version; +stdenv.mkDerivation ({ + pname = "nanopb-runtime"; + inherit src version; - nativeBuildInputs = [ cmake protobuf python3 ]; + nativeBuildInputs = [ + cmake + protobuf + python3 + ]; - patchPhase = - let - compile_definitions = target: '' - target_compile_definitions(${target} - PUBLIC - ${lib.concatStringsSep "\n\t" (map (x: "PB_${x.flag}") - (builtins.filter (x: x.cond) [ - { cond = enableMalloc; flag = "ENABLE_MALLOC=1"; } - { cond = noPackedStructs; flag = "NO_PACKED_STRUCTS=1"; } - { cond = maxRequiredFields != null; flag = "MAX_REQUIRED_FIELDS=${maxRequiredFields}"; } - { cond = field32bit; flag = "FIELD_32BIT=1"; } - { cond = noErrmsg; flag = "NO_ERRMSG=1"; } - { cond = bufferOnly; flag = "BUFFER_ONLY=1"; } - { cond = systemHeader != null; flag = "SYSTEM_HEADER=${systemHeader}"; } - { cond = without64bit; flag = "WITHOUT_64BIT=1"; } - { cond = encodeArraysUnpacked; flag = "ENCODE_ARRAYS_UNPACKED=1"; } - { cond = convertDoubleFloat; flag = "CONVERT_DOUBLE_FLOAT=1"; } - { cond = validateUtf8; flag = "VALIDATE_UTF8=1"; } - { cond = littleEndian8bit; flag = "LITTLE_ENDIAN_8BIT=1"; } - { cond = c99StaticAssert; flag = "C99_STATIC_ASSERT=1"; } - { cond = noStaticAssert; flag = "NO_STATIC_ASSERT=1"; } - ]))} - ) - ''; - in - '' - cat << EOF >> CMakeLists.txt - ${compile_definitions "protobuf-nanopb"} - ${compile_definitions "protobuf-nanopb-static"} - EOF + patchPhase = + let + compile_definitions = target: '' + target_compile_definitions(${target} + PUBLIC + ${lib.concatStringsSep "\n\t" ( + map (x: "PB_${x.flag}") ( + builtins.filter (x: x.cond) [ + { + cond = enableMalloc; + flag = "ENABLE_MALLOC=1"; + } + { + cond = noPackedStructs; + flag = "NO_PACKED_STRUCTS=1"; + } + { + cond = maxRequiredFields != null; + flag = "MAX_REQUIRED_FIELDS=${maxRequiredFields}"; + } + { + cond = field32bit; + flag = "FIELD_32BIT=1"; + } + { + cond = noErrmsg; + flag = "NO_ERRMSG=1"; + } + { + cond = bufferOnly; + flag = "BUFFER_ONLY=1"; + } + { + cond = systemHeader != null; + flag = "SYSTEM_HEADER=${systemHeader}"; + } + { + cond = without64bit; + flag = "WITHOUT_64BIT=1"; + } + { + cond = encodeArraysUnpacked; + flag = "ENCODE_ARRAYS_UNPACKED=1"; + } + { + cond = convertDoubleFloat; + flag = "CONVERT_DOUBLE_FLOAT=1"; + } + { + cond = validateUtf8; + flag = "VALIDATE_UTF8=1"; + } + { + cond = littleEndian8bit; + flag = "LITTLE_ENDIAN_8BIT=1"; + } + { + cond = c99StaticAssert; + flag = "C99_STATIC_ASSERT=1"; + } + { + cond = noStaticAssert; + flag = "NO_STATIC_ASSERT=1"; + } + ] + ) + )} + ) ''; + in + '' + cat << EOF >> CMakeLists.txt + ${compile_definitions "protobuf-nanopb"} + ${compile_definitions "protobuf-nanopb-static"} + EOF + ''; - cmakeFlags = [ - "-DBUILD_SHARED_LIBS=ON" - "-DBUILD_STATIC_LIBS=ON" - "-Dnanopb_BUILD_GENERATOR=OFF" - "-Dnanopb_BUILD_RUNTIME=ON" - ]; - }) + cmakeFlags = [ + "-DBUILD_SHARED_LIBS=ON" + "-DBUILD_STATIC_LIBS=ON" + "-Dnanopb_BUILD_GENERATOR=OFF" + "-Dnanopb_BUILD_RUNTIME=ON" + ]; +}) diff --git a/pkgs/by-name/na/nanopb/test-message-with-annotations/default.nix b/pkgs/by-name/na/nanopb/test-message-with-annotations/default.nix index 5e53e72c62e633..b8f4e84af17e3c 100644 --- a/pkgs/by-name/na/nanopb/test-message-with-annotations/default.nix +++ b/pkgs/by-name/na/nanopb/test-message-with-annotations/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, nanopb }: +{ + lib, + stdenv, + nanopb, +}: stdenv.mkDerivation { name = "nanopb-test-message-with-annotations"; diff --git a/pkgs/by-name/na/nanopb/test-message-with-options/default.nix b/pkgs/by-name/na/nanopb/test-message-with-options/default.nix index 78be532d569d76..c44041a5ac5554 100644 --- a/pkgs/by-name/na/nanopb/test-message-with-options/default.nix +++ b/pkgs/by-name/na/nanopb/test-message-with-options/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, nanopb }: +{ + lib, + stdenv, + nanopb, +}: stdenv.mkDerivation { name = "nanopb-test-message-with-options"; diff --git a/pkgs/by-name/na/nanopb/test-simple-proto2/default.nix b/pkgs/by-name/na/nanopb/test-simple-proto2/default.nix index 5896679567486a..a89a04a107402b 100644 --- a/pkgs/by-name/na/nanopb/test-simple-proto2/default.nix +++ b/pkgs/by-name/na/nanopb/test-simple-proto2/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, nanopb }: +{ + lib, + stdenv, + nanopb, +}: stdenv.mkDerivation { name = "nanopb-test-simple-proto2"; diff --git a/pkgs/by-name/na/nanopb/test-simple-proto3/default.nix b/pkgs/by-name/na/nanopb/test-simple-proto3/default.nix index 6276126131c866..eb9aba5fdf1f38 100644 --- a/pkgs/by-name/na/nanopb/test-simple-proto3/default.nix +++ b/pkgs/by-name/na/nanopb/test-simple-proto3/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, nanopb }: +{ + lib, + stdenv, + nanopb, +}: stdenv.mkDerivation { name = "nanopb-test-simple-proto3"; diff --git a/pkgs/by-name/na/nanorc/package.nix b/pkgs/by-name/na/nanorc/package.nix index 5587c2c0243c3b..ed3d734f58656b 100644 --- a/pkgs/by-name/na/nanorc/package.nix +++ b/pkgs/by-name/na/nanorc/package.nix @@ -1,10 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, writeScript, common-updater-scripts -, coreutils, git, gnused, nix }: +{ + lib, + stdenv, + fetchFromGitHub, + writeScript, + common-updater-scripts, + coreutils, + git, + gnused, + nix, +}: let owner = "scopatz"; repo = "nanorc"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "nanorc"; version = "2020-10-10"; diff --git a/pkgs/by-name/na/nanosaur/package.nix b/pkgs/by-name/na/nanosaur/package.nix index 99f609ffd509e8..9bac2d99105fae 100644 --- a/pkgs/by-name/na/nanosaur/package.nix +++ b/pkgs/by-name/na/nanosaur/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, SDL2, cmake, makeWrapper, unstableGitUpdater }: +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + cmake, + makeWrapper, + unstableGitUpdater, +}: stdenv.mkDerivation rec { pname = "nanosaur"; diff --git a/pkgs/by-name/na/nanosaur2/package.nix b/pkgs/by-name/na/nanosaur2/package.nix index 3e370d7809a97f..6d53df9b414ba3 100644 --- a/pkgs/by-name/na/nanosaur2/package.nix +++ b/pkgs/by-name/na/nanosaur2/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, SDL2, cmake, makeWrapper, unstableGitUpdater }: +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + cmake, + makeWrapper, + unstableGitUpdater, +}: stdenv.mkDerivation rec { pname = "nanosaur2"; diff --git a/pkgs/by-name/na/nanosvg/package.nix b/pkgs/by-name/na/nanosvg/package.nix index 29861777889bcc..2c0f4bbc0a66b9 100644 --- a/pkgs/by-name/na/nanosvg/package.nix +++ b/pkgs/by-name/na/nanosvg/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, unstableGitUpdater }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + unstableGitUpdater, +}: stdenv.mkDerivation { pname = "nanosvg"; diff --git a/pkgs/by-name/na/nanotts/package.nix b/pkgs/by-name/na/nanotts/package.nix index 41214ffe9206af..c1a246a67262e2 100644 --- a/pkgs/by-name/na/nanotts/package.nix +++ b/pkgs/by-name/na/nanotts/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libtool, popt, alsa-lib, alsa-plugins, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + popt, + alsa-lib, + alsa-plugins, + makeWrapper, +}: stdenv.mkDerivation { pname = "nano-tts"; @@ -12,8 +23,16 @@ stdenv.mkDerivation { }; strictDeps = true; - nativeBuildInputs = [ autoconf automake libtool makeWrapper ]; - buildInputs = [ popt alsa-lib ]; + nativeBuildInputs = [ + autoconf + automake + libtool + makeWrapper + ]; + buildInputs = [ + popt + alsa-lib + ]; patchPhase = '' substituteInPlace "src/main.cpp" --replace "/usr/share/pico/lang" "$out/share/lang" diff --git a/pkgs/by-name/na/nanum-gothic-coding/package.nix b/pkgs/by-name/na/nanum-gothic-coding/package.nix index f27f487bd6abdd..ef6c0ea107d95f 100644 --- a/pkgs/by-name/na/nanum-gothic-coding/package.nix +++ b/pkgs/by-name/na/nanum-gothic-coding/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "nanum-gothic-coding"; diff --git a/pkgs/by-name/na/nanum/package.nix b/pkgs/by-name/na/nanum/package.nix index 64575a1310290e..b8342a24c22f39 100644 --- a/pkgs/by-name/na/nanum/package.nix +++ b/pkgs/by-name/na/nanum/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "nanum"; diff --git a/pkgs/by-name/na/nap/package.nix b/pkgs/by-name/na/nap/package.nix index 784877af792f20..68d344d3a33f22 100644 --- a/pkgs/by-name/na/nap/package.nix +++ b/pkgs/by-name/na/nap/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "nap"; @@ -20,6 +24,9 @@ buildGoModule rec { mainProgram = "nap"; homepage = "https://github.com/maaslalani/nap"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ phdcybersec maaslalani ]; + maintainers = with lib.maintainers; [ + phdcybersec + maaslalani + ]; }; } diff --git a/pkgs/by-name/na/napi-rs-cli/package.nix b/pkgs/by-name/na/napi-rs-cli/package.nix index 86b714dbb0c4e8..0b482e0ea97ed9 100644 --- a/pkgs/by-name/na/napi-rs-cli/package.nix +++ b/pkgs/by-name/na/napi-rs-cli/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, nodejs }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + nodejs, +}: stdenv.mkDerivation rec { pname = "napi-rs-cli"; diff --git a/pkgs/by-name/na/naproche/package.nix b/pkgs/by-name/na/naproche/package.nix index 1843ebf1c78998..7e76fa3217ba18 100644 --- a/pkgs/by-name/na/naproche/package.nix +++ b/pkgs/by-name/na/naproche/package.nix @@ -1,6 +1,13 @@ -{ lib, fetchFromGitHub, haskellPackages, makeWrapper, eprover }: +{ + lib, + fetchFromGitHub, + haskellPackages, + makeWrapper, + eprover, +}: -with haskellPackages; mkDerivation { +with haskellPackages; +mkDerivation { pname = "Naproche-SAD"; version = "unstable-2024-05-19"; @@ -13,10 +20,27 @@ with haskellPackages; mkDerivation { isExecutable = true; - buildTools = [ hpack makeWrapper ]; + buildTools = [ + hpack + makeWrapper + ]; executableHaskellDepends = [ - base array bytestring containers ghc-prim megaparsec mtl network process - split temporary text threads time transformers uuid + base + array + bytestring + containers + ghc-prim + megaparsec + mtl + network + process + split + temporary + text + threads + time + transformers + uuid ]; prePatch = "hpack"; diff --git a/pkgs/by-name/na/naps2/deps.nix b/pkgs/by-name/na/naps2/deps.nix index 4a9c92fe836592..ae3d9d4fdcdb94 100644 --- a/pkgs/by-name/na/naps2/deps.nix +++ b/pkgs/by-name/na/naps2/deps.nix @@ -1,180 +1,881 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "AtkSharp"; version = "3.24.24.95"; sha256 = "0x4nr8rx50h87n6ijv5a4vkavs2x61bsrkxvam27h178finmc1rn"; }) - (fetchNuGet { pname = "Autofac"; version = "8.0.0"; sha256 = "0w3y76vik6rfr9am649v4w6dyyp5s25244q3il2x8si11xgl6y7d"; }) - (fetchNuGet { pname = "Ben.Demystifier"; version = "0.4.1"; sha256 = "1szlrhvwpwkjhpgvjlrpjg714bz1yhyljs72pxni3li4mgnklk1f"; }) - (fetchNuGet { pname = "CairoSharp"; version = "3.24.24.95"; sha256 = "05fq8jdlxzrrw7gh0i3w272q34wzmb3bizcghjnf9mlh1jcn1iy9"; }) - (fetchNuGet { pname = "CommandLineParser"; version = "2.9.1"; sha256 = "1sldkj8lakggn4hnyabjj1fppqh50fkdrr1k99d4gswpbk5kv582"; }) - (fetchNuGet { pname = "EmbedIO"; version = "3.5.2"; sha256 = "13saxicm07nkppzfxb60cpm1501n4ixaqhkvvqqfaqgifma9z8bv"; }) - (fetchNuGet { pname = "Eto.Forms"; version = "2.8.3"; sha256 = "00v2ffi9sl8cjllrz8rw3a5s5cgm9bfh45852znwz18zp06rh5bg"; }) - (fetchNuGet { pname = "Eto.Platform.Gtk"; version = "2.8.3"; sha256 = "0av22hyx6xf6cnm89a4jvpnm80h1p6a6301r4n2906ihai9k3gsk"; }) - (fetchNuGet { pname = "GdkSharp"; version = "3.24.24.95"; sha256 = "1wp2kgng0pwg8q5bl1zz4lzzj603qcjljql61h83bxa60q7c121m"; }) - (fetchNuGet { pname = "GioSharp"; version = "3.24.24.95"; sha256 = "121xb98hg955vwxfv1r5idr5a2zv09xpcmqckm7hhgprlzhz2cg5"; }) - (fetchNuGet { pname = "GLibSharp"; version = "3.24.24.95"; sha256 = "1l5nbg0qwjp55wfj06vnk5q5r5cnq5h064qp4k5xf8qlma8d346n"; }) - (fetchNuGet { pname = "Google.Protobuf"; version = "3.25.1"; sha256 = "0zcw9vmv2bdai3zaip86s37lj3r5z4zvcs9mf5a9nih0hy4gzwsi"; }) - (fetchNuGet { pname = "Grpc.Core.Api"; version = "2.59.0"; sha256 = "0pajrxg0dsfnyxwrd2li5nrabz0r3b3bql776l44hn5rg1s1287k"; }) - (fetchNuGet { pname = "Grpc.Tools"; version = "2.62.0"; sha256 = "1x6ydsvjckxdpnrl07h307wql5gghlb4fasf591ppr16kv5igdfp"; }) - (fetchNuGet { pname = "GrpcDotNetNamedPipes"; version = "3.0.0"; sha256 = "1sndscz12dldjfvifp04ml56fkbl1vwb9llzq0h58hwri35nnbv7"; }) - (fetchNuGet { pname = "GtkSharp"; version = "3.24.24.95"; sha256 = "0y20zn8wv72dg2bc7f95l8iz8z51ap08q5gnv6f2xnhz8zjf86xh"; }) - (fetchNuGet { pname = "IsExternalInit"; version = "1.0.3"; sha256 = "01flcxs8m7m916s5rx5iyvzh6fjdl1dvcyzl9cpzn0d17yp8dz2i"; }) - (fetchNuGet { pname = "Makaretu.Dns"; version = "2.0.1"; sha256 = "1l6ajfdcvqpz078wl6nm44bnhd8h47nssb5qgp5al9zqic50mqnd"; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "7.0.0"; sha256 = "1waiggh3g1cclc81gmjrqbh128kwfjky3z79ma4bd2ms9pa3gvfm"; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "8.0.0"; sha256 = "0z4jq5prnxyb4p3163yxx35znpd2msjd8hw8ysmv4ah90f5sd9gm"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "2.1.0"; sha256 = "04rjl38wlr1jjjpbzgf64jp0ql6sbzbil0brwq9mgr3hdgwd7vx2"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "2.1.0"; sha256 = "03gzlr3z9j1xnr1k6y91zgxpz3pj27i3zsvjwj7i8jqnlqmk7pxd"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "8.0.0"; sha256 = "1jlpa4ggl1gr5fs7fdcw04li3y3iy05w3klr9lrrlc7v8w76kq71"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "2.1.0"; sha256 = "0x1888w5ypavvszfmpja9krgc64527prs75vm8xbf9fv3rgsplql"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "8.0.0"; sha256 = "0i7qziz0iqmbk8zzln7kx9vd0lbx1x3va0yi3j1bgkjir13h78ps"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "2.1.0"; sha256 = "0c0cx8r5xkjpxmcfp51959jnp55qjvq28d9vaslk08avvi1by12s"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.0"; sha256 = "1zw0bpp5742jzx03wvqc8csnvsbgdqi0ls9jfc5i2vd3cl8b74pg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.1"; sha256 = "1wyhpamm1nqjfi3r463dhxljdlr6rm2ax4fvbgq2s0j3jhpdhd4p"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "2.1.0"; sha256 = "0dii8i7s6libfnspz2xb96ayagb4rwqj2kmr162vndivr9rmbm06"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "8.0.0"; sha256 = "0nppj34nmq25gnrg0wh1q22y4wdqbih4ax493f226azv8mkp9s1i"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "2.1.0"; sha256 = "1gvgif1wcx4k6pv7gc00qv1hid945jdywy1s50s33q0hfd91hbnj"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "8.0.0"; sha256 = "1klcqhg3hk55hb6vmjiq2wgqidsl81aldw0li2z98lrwx26msrr6"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "8.0.1"; sha256 = "0i9pgmk60b8xlws3q9z890gim1xjq42dhyh6dj4xvbycmgg1x1sd"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "2.1.0"; sha256 = "0w9644sryd1c6r3n4lq2cgd5pn6jl3k5m38a05m7vjffa4m2spd2"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "8.0.0"; sha256 = "0p50qn6zhinzyhq9sy5svnmqqwhw2jajs2pbjh9sah504wjvhscz"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "2.1.0"; sha256 = "1r9gzwdfmb8ysnc4nzmyz5cyar1lw0qmizsvrsh252nhlyg06nmb"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "8.0.0"; sha256 = "0aldaz5aapngchgdr7dax9jw5wy7k7hmjgjpfgfv1wfif27jlkqm"; }) - (fetchNuGet { pname = "Microsoft.NETCore.App"; version = "2.1.30"; sha256 = "10brwj7csacwa4ra37pjb2bqwg961lxi576330xlhhwqixkjkrqf"; }) - (fetchNuGet { pname = "Microsoft.NETCore.DotNetAppHost"; version = "2.1.30"; sha256 = "0rabvmid1n604pk9rndlq62zqhq77p7cznmq9bzr7hshvr2rszab"; }) - (fetchNuGet { pname = "Microsoft.NETCore.DotNetHostPolicy"; version = "2.1.30"; sha256 = "1zk6ajalssvpm2yv4ri3g6hbxjaj1ns0y4w3g98wss54k7v44vpw"; }) - (fetchNuGet { pname = "Microsoft.NETCore.DotNetHostResolver"; version = "2.1.30"; sha256 = "0k3k6ldi5lj9ab9bdnhzfiykr6ipwz17d9g952bcanhvmk57l376"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.1"; sha256 = "164wycgng4mi9zqi2pnsf1pq6gccbqvw6ib916mqizgjmd8f44pj"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "2.1.14"; sha256 = "0mbmcgsky65y0xai4xjfnhm07kn856y9kpn6hnm1b5m3mdsf8dkq"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "5.0.0"; sha256 = "0mwpwdflidzgzfx2dlpkvvnkgkr2ayaf0s80737h4wa35gaj11rc"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "2.0.0"; sha256 = "0nsrrhafvxqdx8gmlgsz612bmlll2w3l2qn2ygdzr92rp1nqyka2"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies"; version = "1.0.3"; sha256 = "0hc4d4d4358g5192mf8faijwk0bpf9pjwcfd3h85sr67j0zhj6hl"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies.net462"; version = "1.0.3"; sha256 = "08bfss2p262d8zj41xqndv0qgvz9lq636k2xhl80jl23ay22lsgf"; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.3.0"; sha256 = "0j0c1wj4ndj21zsgivsc24whiya605603kxrbiw6wkfdync464wq"; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "5.0.0"; sha256 = "102hvhq2gmlcbq8y2cb7hdr2dnmjzfp2k3asr1ycwrfacwyaak7n"; }) - (fetchNuGet { pname = "MimeKitLite"; version = "4.4.0"; sha256 = "1am381zbh89qa520pllsa92by92lg6wn0zxhqa26z7mlh6jwc8nz"; }) - (fetchNuGet { pname = "NAPS2.Mdns"; version = "1.0.1"; sha256 = "0xi46brppcjm8mrabnffahkmkcakhw94cnq1w2yk8y2hyq9qb4ms"; }) - (fetchNuGet { pname = "NAPS2.NTwain"; version = "1.0.0"; sha256 = "088dw31h7rlgr0s05snm382wz65wi46yaizjnjpd0wzw2mb58yld"; }) - (fetchNuGet { pname = "NAPS2.Pdfium.Binaries"; version = "1.1.0"; sha256 = "0rnqkk6y047p6a6li2dr2cygkhjn3d2a13yn3rck5gf854k3q3ws"; }) - (fetchNuGet { pname = "NAPS2.PdfSharp"; version = "1.0.1"; sha256 = "0x51whjhlqd5r0f1s5hjx41zzwwcwcdl19q6iz6k7fwx81746w0w"; }) - (fetchNuGet { pname = "NAPS2.Tesseract.Binaries"; version = "1.2.0"; sha256 = "0m1aksfjg4vfl2llvhd2in0a5i4wa72nmfw2h78y4wwxmjplbfz2"; }) - (fetchNuGet { pname = "NAPS2.Wia"; version = "2.0.3"; sha256 = "0xszkccb8fy2x60nkblpda78wx2d86fn8y49j94qmvz4rp2nw98i"; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; sha256 = "1fn9fxppfcg4jgypp2pmrpr6awl3qz1xmnri0cygpkwvyx27df1y"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.3"; sha256 = "0xrwysmrn4midrjal8g2hr1bbg38iyisl0svamb11arqws4w2bw7"; }) - (fetchNuGet { pname = "NLog"; version = "5.2.8"; sha256 = "1z3h20m5rjnizm1jbf5j0vpdc1f373rzzkg6478p1lxv5j385c12"; }) - (fetchNuGet { pname = "NLog.Extensions.Logging"; version = "5.3.8"; sha256 = "1qnz91099f51vk7f5g2ig0041maw5hcbyqllxvj5zj7zkp0qw9b8"; }) - (fetchNuGet { pname = "PangoSharp"; version = "3.24.24.95"; sha256 = "0548jrkgzia899va9smhh7if49nk6avbswb68xmc52k37lins6b2"; }) - (fetchNuGet { pname = "Polyfill"; version = "4.2.0"; sha256 = "0h25jszwrkmxlklcr6mjjmz71rn6q36pqb5jx36l94lrccy2k0a8"; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tracing"; version = "4.3.0"; sha256 = "00j6nv2xgmd3bi347k00m7wr542wjlig53rmj28pmw7ddcn97jbn"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization.Calendars"; version = "4.3.0"; sha256 = "1ghhhk5psqxcg6w88sxkqrc35bxcz27zbqm2y5p5298pv3v7g201"; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0rwpqngkqiapqc5c2cpkj7idhngrgss5qpnqg0yh40mbyflcxf8i"; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1n06gxwlinhs0w7s8a94r1q3lwqzvynxwd3mp10ws9bg6gck8n4r"; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0404wqrc7f2yc0wxv71y3nnybvqx8v4j9d47hlscxy759a525mc3"; }) - (fetchNuGet { pname = "runtime.linux-arm64.Microsoft.NETCore.App"; version = "2.1.30"; sha256 = "039r4c42mz8fg8nqn8p3v0dxnjv681xlllhrc4l91rbbwv04li6j"; }) - (fetchNuGet { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; version = "2.1.30"; sha256 = "00pm387jvv574jsdd1261mbvxd7lbjbsfx3wq0z0iqjhr31pgmw1"; }) - (fetchNuGet { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "2.1.30"; sha256 = "1gjjs4xvg9x48lg00ys6r5vc00s973aknpqp0ffa946s8m8xhlfw"; }) - (fetchNuGet { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "2.1.30"; sha256 = "0jyzw9wr9sgllgj08vdf716p27s13ad46nah2q1qmfa05cgdbikb"; }) - (fetchNuGet { pname = "runtime.linux-x64.Microsoft.NETCore.App"; version = "2.1.30"; sha256 = "1wy9kagwj6avvhpp4lrlxw5sqgh4zlmii9wvf474fx999szi5bqb"; }) - (fetchNuGet { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; version = "2.1.30"; sha256 = "0mrlvhm6yb3x40pfm4smi67p6wm3hi71jdnawqkqy73g203rjmgx"; }) - (fetchNuGet { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "2.1.30"; sha256 = "1zv9i8wqpsdr2vx35i3qzad1yvz00l6i9f00fclw02v2p92jz9c1"; }) - (fetchNuGet { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostResolver"; version = "2.1.30"; sha256 = "1s6zx2hpg60pscvz8yfdkxpdg1lhs534x5mz3yryxa91nfzhxv95"; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; }) - (fetchNuGet { pname = "runtime.native.System.Net.Http"; version = "4.3.0"; sha256 = "1n6rgz5132lcibbch1qlf0g9jk60r0kqv087hxc0lisy50zpm7kk"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; sha256 = "1b61p6gw1m02cc1ry996fl49liiwky6181dzr873g9ds92zl326q"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0zy5r25jppz48i2bkg8b9lfig24xixg6nm3xyr1379zdnqnpm8f6"; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "096ch4n4s8k82xga80lfmpimpzahd2ip1mgwdqgar0ywbbl6x438"; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1dm8fifl7rf1gy7lnwln78ch4rw54g0pl5g1c189vawavll7p6rj"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; sha256 = "10yc8jdrwgcl44b4g93f1ds76b176bajd3zqi2faf5rvh1vy9smi"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1m9z1k9kzva9n9kwinqxl97x2vgl79qhqjlv17k9s2ymcyv2bwr6"; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1cpx56mcfxz7cpn57wvj18sjisvzq8b5vd9rw16ihd2i6mcp3wa1"; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "15gsm1a8jdmgmf8j5v1slfz8ks124nfdhk2vxs2rw3asrxalg8hi"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0q0n5q1r1wnqmr5i5idsrd9ywl33k0js4pngkwq9p368mbxp8x1w"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1x0g58pbpjrmj2x2qw17rdwwnrcl0wvim2hdwz48lixvwvp22n9c"; }) - (fetchNuGet { pname = "runtime.unix.Microsoft.Win32.Primitives"; version = "4.3.0"; sha256 = "0y61k9zbxhdi0glg154v30kkq7f8646nif8lnnxbvkjpakggd5id"; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; }) - (fetchNuGet { pname = "runtime.unix.System.IO.FileSystem"; version = "4.3.0"; sha256 = "14nbkhvs7sji5r1saj2x8daz82rnf9kx28d3v2qss34qbr32dzix"; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Primitives"; version = "4.3.0"; sha256 = "0bdnglg59pzx9394sy4ic66kmxhqp8q8bvmykdxcbs5mm0ipwwm4"; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; }) - (fetchNuGet { pname = "SharpZipLib"; version = "1.4.2"; sha256 = "0ijrzz2szxjmv2cipk7rpmg14dfaigdkg7xabjvb38ih56m9a27y"; }) - (fetchNuGet { pname = "SimpleBase"; version = "1.3.1"; sha256 = "0mjvqbn3b6ai7nhzs5mssy2imn9lw10z4sj8nhgiapyqy9qlim0n"; }) - (fetchNuGet { pname = "SixLabors.Fonts"; version = "1.0.1"; sha256 = "08ljgagwm8aha9p4plqdnf507gcisajd9frcbvaykikrsrzpm33y"; }) - (fetchNuGet { pname = "StandardSocketsHttpHandler"; version = "2.2.0.8"; sha256 = "18h3rzh9pp3b6mjx1m4jvwwhv5abjqsd1nnbibc0gbkvbcrb16ni"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.3.0"; sha256 = "0fgns20ispwrfqll4q1zc1waqcmylb3zc50ys9x8zlwxh9pmd9jy"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.4.0"; sha256 = "183f8063w8zqn99pv0ni0nnwh7fgx46qzxamwnans55hhs2l0g19"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.3.0"; sha256 = "0wi10md9aq33jrkh2c24wr2n9hrpyamsdhsxdcnf43b7y86kkii8"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "5.0.0"; sha256 = "1kvcllagxz2q92g81zkz81djkn2lid25ayjfgjalncyc68i15p0r"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "8.0.0"; sha256 = "0z53a42zjd59zdkszcm7pvij4ri5xbb8jly9hzaad9khlf69bcqp"; }) - (fetchNuGet { pname = "System.ComponentModel.Annotations"; version = "5.0.0"; sha256 = "021h7x98lblq9avm1bgpa4i31c2kgsa7zn4sqhxf39g087ar756j"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "4.3.0"; sha256 = "0z6m3pbiy0qw6rn3n209rrzf9x1k4002zh90vwcrsym09ipm2liq"; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "7.0.2"; sha256 = "1h97ikph775gya93qsjjaka87qcygbyh1064rh1hnfcnp5xv0ipi"; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; sha256 = "1m3bx6c2s958qligl67q7grkwfz3w53hpy7nc97mh6f7j5k168c4"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.3.0"; sha256 = "1xwl230bkakzzkrggy1l1lxmm3xlhk4bq2pkv790j5lm8g887lxq"; }) - (fetchNuGet { pname = "System.Globalization.Extensions"; version = "4.3.0"; sha256 = "02a5zfxavhv3jd437bsncbhd2fp1zv4gxzakp1an9l6kdq1mcqls"; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; sha256 = "0z2dfrbra9i6y16mm9v1v6k47f0fm617vlb7s5iybjjsz6g1ilmw"; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.0"; sha256 = "1layqpcx1q4l805fdnj2dfqp6ncx2z42ca06rgsr6ikq4jjgbv30"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.1"; sha256 = "0f07d7hny38lq9w69wx4lxkn4wszrqf9m9js6fh9is645csm167c"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.5"; sha256 = "08jsfwimcarfzrhlyvjjid61j02irx6xsklf32rv57x2aaikvx0h"; }) - (fetchNuGet { pname = "System.Net.Http"; version = "4.3.4"; sha256 = "0kdp31b8819v88l719j6my0yas6myv9d1viql3qz5577mv819jhl"; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.3.0"; sha256 = "0c87k50rmdgmxx7df2khd9qj7q35j9rzdmm2572cc55dygmdk3ii"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.4.0"; sha256 = "0rdvma399070b0i46c4qq1h2yvjj3k013sqzkilz4bz5cwmx1rba"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; sha256 = "1kzrj37yzawf1b19jq0253rcs8hsq1l2q8g69d7ipnhzb0h97m59"; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "5.0.0"; sha256 = "17qsl5nanlqk9iz0l5wijdn6ka632fs1m1fvx18dfgswm258r3ss"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; }) - (fetchNuGet { pname = "System.Resources.Extensions"; version = "8.0.0"; sha256 = "0chqkw486pb5dg9nlj5352lsz1206xyf953nd98dglia3isxklg5"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.0"; sha256 = "17labczwqk3jng3kkky73m0jhi8wc21vbl7cz5c0hj2p1dswin43"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.2"; sha256 = "1vz4275fjij8inf31np78hw50al8nqkngk04p3xv5n4fcmf1grgi"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.3"; sha256 = "1afi6s2r1mh1kygbjmfba6l4f87pi5sg13p4a48idqafli94qxln"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.7.0"; sha256 = "16r6sn4czfjk8qhnz7bnqlyiaaszr0ihinb7mq9zzr1wba257r54"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.3.0"; sha256 = "19rav39sr5dky7afygh309qamqqmi9kcwvz3i0c5700v0c5cg61z"; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "5.0.0"; sha256 = "17n3lrrl6vahkqmhlpn3w20afgz09n7i6rv0r3qypngwi7wqdr5r"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.3.0"; sha256 = "03sq183pfl5kp7gkvq77myv7kbpdnq3y0xj7vi4q1kaw54sny0ml"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.3.0"; sha256 = "1k468aswafdgf56ab6yrn7649kfqx2wm9aslywjam1hdmk5yypmv"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Csp"; version = "4.3.0"; sha256 = "1x5wcrddf2s3hb8j78cry7yalca4lb5vfnkrysagbn6r9x6xvrx1"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.3.0"; sha256 = "1jr6w70igqn07k5zs1ph6xja97hxnb3mqbspdrff6cvssgrixs32"; }) - (fetchNuGet { pname = "System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0givpvvj8yc7gv4lhb6s1prq6p2c4147204a0wib89inqzd87gqc"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.3.0"; sha256 = "0pyzncsv48zwly3lw4f2dayqswcfvdwq2nz0dgwmi7fj3pn64wby"; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "8.0.0"; sha256 = "1ysjx3b5ips41s32zacf4vs7ig41906mxrsbmykdzi0hvdmjkgbx"; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.3.0"; sha256 = "0valjcz5wksbvijylxijjxb1mp38mdhv03r533vnx1q3ikzdav9h"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; sha256 = "1mpk7xj76lxgz97a5yg93wi8lj0l8p157a5d50mmjy3gbz1904q8"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "8.0.0"; sha256 = "1lgdd78cik4qyvp2fggaa0kzxasw6kc9a6cjqw46siagrm0qnc3y"; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Dataflow"; version = "8.0.0"; sha256 = "02mmqnbd7ybin1yiffrq3ph71rsbrnf6r6m01j98ynydqfscz9s3"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.2"; sha256 = "1sh63dz0dymqcwmprp0nadm77b83vmm7lyllpv578c397bslb8hj"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; sha256 = "0y6ncasgfcgnjrhynaf0lwpkpkmv4a07sswwkwbwb5h7riisj153"; }) - (fetchNuGet { pname = "System.ValueTuple"; version = "4.5.0"; sha256 = "00k8ja51d0f9wrq4vv5z2jhq8hy31kac2rg0rv06prylcybzl8cy"; }) - (fetchNuGet { pname = "Unosquare.Swan.Lite"; version = "3.1.0"; sha256 = "0yjbchc2rhgssfvb1qxg3kq3lzyx089r3rngpcjgrkw85bf0vgrw"; }) - (fetchNuGet { pname = "ZXing.Net"; version = "0.16.9"; sha256 = "0bpki21p2wjjjviayhza0gam7s9lm7qj6g8hdcp2csd0mv54l980"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "AtkSharp"; + version = "3.24.24.95"; + sha256 = "0x4nr8rx50h87n6ijv5a4vkavs2x61bsrkxvam27h178finmc1rn"; + }) + (fetchNuGet { + pname = "Autofac"; + version = "8.0.0"; + sha256 = "0w3y76vik6rfr9am649v4w6dyyp5s25244q3il2x8si11xgl6y7d"; + }) + (fetchNuGet { + pname = "Ben.Demystifier"; + version = "0.4.1"; + sha256 = "1szlrhvwpwkjhpgvjlrpjg714bz1yhyljs72pxni3li4mgnklk1f"; + }) + (fetchNuGet { + pname = "CairoSharp"; + version = "3.24.24.95"; + sha256 = "05fq8jdlxzrrw7gh0i3w272q34wzmb3bizcghjnf9mlh1jcn1iy9"; + }) + (fetchNuGet { + pname = "CommandLineParser"; + version = "2.9.1"; + sha256 = "1sldkj8lakggn4hnyabjj1fppqh50fkdrr1k99d4gswpbk5kv582"; + }) + (fetchNuGet { + pname = "EmbedIO"; + version = "3.5.2"; + sha256 = "13saxicm07nkppzfxb60cpm1501n4ixaqhkvvqqfaqgifma9z8bv"; + }) + (fetchNuGet { + pname = "Eto.Forms"; + version = "2.8.3"; + sha256 = "00v2ffi9sl8cjllrz8rw3a5s5cgm9bfh45852znwz18zp06rh5bg"; + }) + (fetchNuGet { + pname = "Eto.Platform.Gtk"; + version = "2.8.3"; + sha256 = "0av22hyx6xf6cnm89a4jvpnm80h1p6a6301r4n2906ihai9k3gsk"; + }) + (fetchNuGet { + pname = "GdkSharp"; + version = "3.24.24.95"; + sha256 = "1wp2kgng0pwg8q5bl1zz4lzzj603qcjljql61h83bxa60q7c121m"; + }) + (fetchNuGet { + pname = "GioSharp"; + version = "3.24.24.95"; + sha256 = "121xb98hg955vwxfv1r5idr5a2zv09xpcmqckm7hhgprlzhz2cg5"; + }) + (fetchNuGet { + pname = "GLibSharp"; + version = "3.24.24.95"; + sha256 = "1l5nbg0qwjp55wfj06vnk5q5r5cnq5h064qp4k5xf8qlma8d346n"; + }) + (fetchNuGet { + pname = "Google.Protobuf"; + version = "3.25.1"; + sha256 = "0zcw9vmv2bdai3zaip86s37lj3r5z4zvcs9mf5a9nih0hy4gzwsi"; + }) + (fetchNuGet { + pname = "Grpc.Core.Api"; + version = "2.59.0"; + sha256 = "0pajrxg0dsfnyxwrd2li5nrabz0r3b3bql776l44hn5rg1s1287k"; + }) + (fetchNuGet { + pname = "Grpc.Tools"; + version = "2.62.0"; + sha256 = "1x6ydsvjckxdpnrl07h307wql5gghlb4fasf591ppr16kv5igdfp"; + }) + (fetchNuGet { + pname = "GrpcDotNetNamedPipes"; + version = "3.0.0"; + sha256 = "1sndscz12dldjfvifp04ml56fkbl1vwb9llzq0h58hwri35nnbv7"; + }) + (fetchNuGet { + pname = "GtkSharp"; + version = "3.24.24.95"; + sha256 = "0y20zn8wv72dg2bc7f95l8iz8z51ap08q5gnv6f2xnhz8zjf86xh"; + }) + (fetchNuGet { + pname = "IsExternalInit"; + version = "1.0.3"; + sha256 = "01flcxs8m7m916s5rx5iyvzh6fjdl1dvcyzl9cpzn0d17yp8dz2i"; + }) + (fetchNuGet { + pname = "Makaretu.Dns"; + version = "2.0.1"; + sha256 = "1l6ajfdcvqpz078wl6nm44bnhd8h47nssb5qgp5al9zqic50mqnd"; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "7.0.0"; + sha256 = "1waiggh3g1cclc81gmjrqbh128kwfjky3z79ma4bd2ms9pa3gvfm"; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "8.0.0"; + sha256 = "0z4jq5prnxyb4p3163yxx35znpd2msjd8hw8ysmv4ah90f5sd9gm"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "2.1.0"; + sha256 = "04rjl38wlr1jjjpbzgf64jp0ql6sbzbil0brwq9mgr3hdgwd7vx2"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "2.1.0"; + sha256 = "03gzlr3z9j1xnr1k6y91zgxpz3pj27i3zsvjwj7i8jqnlqmk7pxd"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "8.0.0"; + sha256 = "1jlpa4ggl1gr5fs7fdcw04li3y3iy05w3klr9lrrlc7v8w76kq71"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "2.1.0"; + sha256 = "0x1888w5ypavvszfmpja9krgc64527prs75vm8xbf9fv3rgsplql"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "8.0.0"; + sha256 = "0i7qziz0iqmbk8zzln7kx9vd0lbx1x3va0yi3j1bgkjir13h78ps"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "2.1.0"; + sha256 = "0c0cx8r5xkjpxmcfp51959jnp55qjvq28d9vaslk08avvi1by12s"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.0"; + sha256 = "1zw0bpp5742jzx03wvqc8csnvsbgdqi0ls9jfc5i2vd3cl8b74pg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.1"; + sha256 = "1wyhpamm1nqjfi3r463dhxljdlr6rm2ax4fvbgq2s0j3jhpdhd4p"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "2.1.0"; + sha256 = "0dii8i7s6libfnspz2xb96ayagb4rwqj2kmr162vndivr9rmbm06"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "8.0.0"; + sha256 = "0nppj34nmq25gnrg0wh1q22y4wdqbih4ax493f226azv8mkp9s1i"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "2.1.0"; + sha256 = "1gvgif1wcx4k6pv7gc00qv1hid945jdywy1s50s33q0hfd91hbnj"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "8.0.0"; + sha256 = "1klcqhg3hk55hb6vmjiq2wgqidsl81aldw0li2z98lrwx26msrr6"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "8.0.1"; + sha256 = "0i9pgmk60b8xlws3q9z890gim1xjq42dhyh6dj4xvbycmgg1x1sd"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "2.1.0"; + sha256 = "0w9644sryd1c6r3n4lq2cgd5pn6jl3k5m38a05m7vjffa4m2spd2"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "8.0.0"; + sha256 = "0p50qn6zhinzyhq9sy5svnmqqwhw2jajs2pbjh9sah504wjvhscz"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "2.1.0"; + sha256 = "1r9gzwdfmb8ysnc4nzmyz5cyar1lw0qmizsvrsh252nhlyg06nmb"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "8.0.0"; + sha256 = "0aldaz5aapngchgdr7dax9jw5wy7k7hmjgjpfgfv1wfif27jlkqm"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App"; + version = "2.1.30"; + sha256 = "10brwj7csacwa4ra37pjb2bqwg961lxi576330xlhhwqixkjkrqf"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.DotNetAppHost"; + version = "2.1.30"; + sha256 = "0rabvmid1n604pk9rndlq62zqhq77p7cznmq9bzr7hshvr2rszab"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.DotNetHostPolicy"; + version = "2.1.30"; + sha256 = "1zk6ajalssvpm2yv4ri3g6hbxjaj1ns0y4w3g98wss54k7v44vpw"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.DotNetHostResolver"; + version = "2.1.30"; + sha256 = "0k3k6ldi5lj9ab9bdnhzfiykr6ipwz17d9g952bcanhvmk57l376"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.1"; + sha256 = "164wycgng4mi9zqi2pnsf1pq6gccbqvw6ib916mqizgjmd8f44pj"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "2.1.14"; + sha256 = "0mbmcgsky65y0xai4xjfnhm07kn856y9kpn6hnm1b5m3mdsf8dkq"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "5.0.0"; + sha256 = "0mwpwdflidzgzfx2dlpkvvnkgkr2ayaf0s80737h4wa35gaj11rc"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "2.0.0"; + sha256 = "0nsrrhafvxqdx8gmlgsz612bmlll2w3l2qn2ygdzr92rp1nqyka2"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies"; + version = "1.0.3"; + sha256 = "0hc4d4d4358g5192mf8faijwk0bpf9pjwcfd3h85sr67j0zhj6hl"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies.net462"; + version = "1.0.3"; + sha256 = "08bfss2p262d8zj41xqndv0qgvz9lq636k2xhl80jl23ay22lsgf"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.3.0"; + sha256 = "0j0c1wj4ndj21zsgivsc24whiya605603kxrbiw6wkfdync464wq"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "5.0.0"; + sha256 = "102hvhq2gmlcbq8y2cb7hdr2dnmjzfp2k3asr1ycwrfacwyaak7n"; + }) + (fetchNuGet { + pname = "MimeKitLite"; + version = "4.4.0"; + sha256 = "1am381zbh89qa520pllsa92by92lg6wn0zxhqa26z7mlh6jwc8nz"; + }) + (fetchNuGet { + pname = "NAPS2.Mdns"; + version = "1.0.1"; + sha256 = "0xi46brppcjm8mrabnffahkmkcakhw94cnq1w2yk8y2hyq9qb4ms"; + }) + (fetchNuGet { + pname = "NAPS2.NTwain"; + version = "1.0.0"; + sha256 = "088dw31h7rlgr0s05snm382wz65wi46yaizjnjpd0wzw2mb58yld"; + }) + (fetchNuGet { + pname = "NAPS2.Pdfium.Binaries"; + version = "1.1.0"; + sha256 = "0rnqkk6y047p6a6li2dr2cygkhjn3d2a13yn3rck5gf854k3q3ws"; + }) + (fetchNuGet { + pname = "NAPS2.PdfSharp"; + version = "1.0.1"; + sha256 = "0x51whjhlqd5r0f1s5hjx41zzwwcwcdl19q6iz6k7fwx81746w0w"; + }) + (fetchNuGet { + pname = "NAPS2.Tesseract.Binaries"; + version = "1.2.0"; + sha256 = "0m1aksfjg4vfl2llvhd2in0a5i4wa72nmfw2h78y4wwxmjplbfz2"; + }) + (fetchNuGet { + pname = "NAPS2.Wia"; + version = "2.0.3"; + sha256 = "0xszkccb8fy2x60nkblpda78wx2d86fn8y49j94qmvz4rp2nw98i"; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + sha256 = "1fn9fxppfcg4jgypp2pmrpr6awl3qz1xmnri0cygpkwvyx27df1y"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.3"; + sha256 = "0xrwysmrn4midrjal8g2hr1bbg38iyisl0svamb11arqws4w2bw7"; + }) + (fetchNuGet { + pname = "NLog"; + version = "5.2.8"; + sha256 = "1z3h20m5rjnizm1jbf5j0vpdc1f373rzzkg6478p1lxv5j385c12"; + }) + (fetchNuGet { + pname = "NLog.Extensions.Logging"; + version = "5.3.8"; + sha256 = "1qnz91099f51vk7f5g2ig0041maw5hcbyqllxvj5zj7zkp0qw9b8"; + }) + (fetchNuGet { + pname = "PangoSharp"; + version = "3.24.24.95"; + sha256 = "0548jrkgzia899va9smhh7if49nk6avbswb68xmc52k37lins6b2"; + }) + (fetchNuGet { + pname = "Polyfill"; + version = "4.2.0"; + sha256 = "0h25jszwrkmxlklcr6mjjmz71rn6q36pqb5jx36l94lrccy2k0a8"; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tracing"; + version = "4.3.0"; + sha256 = "00j6nv2xgmd3bi347k00m7wr542wjlig53rmj28pmw7ddcn97jbn"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization.Calendars"; + version = "4.3.0"; + sha256 = "1ghhhk5psqxcg6w88sxkqrc35bxcz27zbqm2y5p5298pv3v7g201"; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0rwpqngkqiapqc5c2cpkj7idhngrgss5qpnqg0yh40mbyflcxf8i"; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1n06gxwlinhs0w7s8a94r1q3lwqzvynxwd3mp10ws9bg6gck8n4r"; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0404wqrc7f2yc0wxv71y3nnybvqx8v4j9d47hlscxy759a525mc3"; + }) + (fetchNuGet { + pname = "runtime.linux-arm64.Microsoft.NETCore.App"; + version = "2.1.30"; + sha256 = "039r4c42mz8fg8nqn8p3v0dxnjv681xlllhrc4l91rbbwv04li6j"; + }) + (fetchNuGet { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "2.1.30"; + sha256 = "00pm387jvv574jsdd1261mbvxd7lbjbsfx3wq0z0iqjhr31pgmw1"; + }) + (fetchNuGet { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "2.1.30"; + sha256 = "1gjjs4xvg9x48lg00ys6r5vc00s973aknpqp0ffa946s8m8xhlfw"; + }) + (fetchNuGet { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "2.1.30"; + sha256 = "0jyzw9wr9sgllgj08vdf716p27s13ad46nah2q1qmfa05cgdbikb"; + }) + (fetchNuGet { + pname = "runtime.linux-x64.Microsoft.NETCore.App"; + version = "2.1.30"; + sha256 = "1wy9kagwj6avvhpp4lrlxw5sqgh4zlmii9wvf474fx999szi5bqb"; + }) + (fetchNuGet { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; + version = "2.1.30"; + sha256 = "0mrlvhm6yb3x40pfm4smi67p6wm3hi71jdnawqkqy73g203rjmgx"; + }) + (fetchNuGet { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "2.1.30"; + sha256 = "1zv9i8wqpsdr2vx35i3qzad1yvz00l6i9f00fclw02v2p92jz9c1"; + }) + (fetchNuGet { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "2.1.30"; + sha256 = "1s6zx2hpg60pscvz8yfdkxpdg1lhs534x5mz3yryxa91nfzhxv95"; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Http"; + version = "4.3.0"; + sha256 = "1n6rgz5132lcibbch1qlf0g9jk60r0kqv087hxc0lisy50zpm7kk"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + sha256 = "1b61p6gw1m02cc1ry996fl49liiwky6181dzr873g9ds92zl326q"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0zy5r25jppz48i2bkg8b9lfig24xixg6nm3xyr1379zdnqnpm8f6"; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "096ch4n4s8k82xga80lfmpimpzahd2ip1mgwdqgar0ywbbl6x438"; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1dm8fifl7rf1gy7lnwln78ch4rw54g0pl5g1c189vawavll7p6rj"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + sha256 = "10yc8jdrwgcl44b4g93f1ds76b176bajd3zqi2faf5rvh1vy9smi"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1m9z1k9kzva9n9kwinqxl97x2vgl79qhqjlv17k9s2ymcyv2bwr6"; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1cpx56mcfxz7cpn57wvj18sjisvzq8b5vd9rw16ihd2i6mcp3wa1"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "15gsm1a8jdmgmf8j5v1slfz8ks124nfdhk2vxs2rw3asrxalg8hi"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0q0n5q1r1wnqmr5i5idsrd9ywl33k0js4pngkwq9p368mbxp8x1w"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1x0g58pbpjrmj2x2qw17rdwwnrcl0wvim2hdwz48lixvwvp22n9c"; + }) + (fetchNuGet { + pname = "runtime.unix.Microsoft.Win32.Primitives"; + version = "4.3.0"; + sha256 = "0y61k9zbxhdi0glg154v30kkq7f8646nif8lnnxbvkjpakggd5id"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; + }) + (fetchNuGet { + pname = "runtime.unix.System.IO.FileSystem"; + version = "4.3.0"; + sha256 = "14nbkhvs7sji5r1saj2x8daz82rnf9kx28d3v2qss34qbr32dzix"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Primitives"; + version = "4.3.0"; + sha256 = "0bdnglg59pzx9394sy4ic66kmxhqp8q8bvmykdxcbs5mm0ipwwm4"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; + }) + (fetchNuGet { + pname = "SharpZipLib"; + version = "1.4.2"; + sha256 = "0ijrzz2szxjmv2cipk7rpmg14dfaigdkg7xabjvb38ih56m9a27y"; + }) + (fetchNuGet { + pname = "SimpleBase"; + version = "1.3.1"; + sha256 = "0mjvqbn3b6ai7nhzs5mssy2imn9lw10z4sj8nhgiapyqy9qlim0n"; + }) + (fetchNuGet { + pname = "SixLabors.Fonts"; + version = "1.0.1"; + sha256 = "08ljgagwm8aha9p4plqdnf507gcisajd9frcbvaykikrsrzpm33y"; + }) + (fetchNuGet { + pname = "StandardSocketsHttpHandler"; + version = "2.2.0.8"; + sha256 = "18h3rzh9pp3b6mjx1m4jvwwhv5abjqsd1nnbibc0gbkvbcrb16ni"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.3.0"; + sha256 = "0fgns20ispwrfqll4q1zc1waqcmylb3zc50ys9x8zlwxh9pmd9jy"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.4.0"; + sha256 = "183f8063w8zqn99pv0ni0nnwh7fgx46qzxamwnans55hhs2l0g19"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.3.0"; + sha256 = "0wi10md9aq33jrkh2c24wr2n9hrpyamsdhsxdcnf43b7y86kkii8"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "5.0.0"; + sha256 = "1kvcllagxz2q92g81zkz81djkn2lid25ayjfgjalncyc68i15p0r"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "8.0.0"; + sha256 = "0z53a42zjd59zdkszcm7pvij4ri5xbb8jly9hzaad9khlf69bcqp"; + }) + (fetchNuGet { + pname = "System.ComponentModel.Annotations"; + version = "5.0.0"; + sha256 = "021h7x98lblq9avm1bgpa4i31c2kgsa7zn4sqhxf39g087ar756j"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "4.3.0"; + sha256 = "0z6m3pbiy0qw6rn3n209rrzf9x1k4002zh90vwcrsym09ipm2liq"; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "7.0.2"; + sha256 = "1h97ikph775gya93qsjjaka87qcygbyh1064rh1hnfcnp5xv0ipi"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + sha256 = "1m3bx6c2s958qligl67q7grkwfz3w53hpy7nc97mh6f7j5k168c4"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.3.0"; + sha256 = "1xwl230bkakzzkrggy1l1lxmm3xlhk4bq2pkv790j5lm8g887lxq"; + }) + (fetchNuGet { + pname = "System.Globalization.Extensions"; + version = "4.3.0"; + sha256 = "02a5zfxavhv3jd437bsncbhd2fp1zv4gxzakp1an9l6kdq1mcqls"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + sha256 = "0z2dfrbra9i6y16mm9v1v6k47f0fm617vlb7s5iybjjsz6g1ilmw"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.0"; + sha256 = "1layqpcx1q4l805fdnj2dfqp6ncx2z42ca06rgsr6ikq4jjgbv30"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.1"; + sha256 = "0f07d7hny38lq9w69wx4lxkn4wszrqf9m9js6fh9is645csm167c"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.5"; + sha256 = "08jsfwimcarfzrhlyvjjid61j02irx6xsklf32rv57x2aaikvx0h"; + }) + (fetchNuGet { + pname = "System.Net.Http"; + version = "4.3.4"; + sha256 = "0kdp31b8819v88l719j6my0yas6myv9d1viql3qz5577mv819jhl"; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.3.0"; + sha256 = "0c87k50rmdgmxx7df2khd9qj7q35j9rzdmm2572cc55dygmdk3ii"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.4.0"; + sha256 = "0rdvma399070b0i46c4qq1h2yvjj3k013sqzkilz4bz5cwmx1rba"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + sha256 = "1kzrj37yzawf1b19jq0253rcs8hsq1l2q8g69d7ipnhzb0h97m59"; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "5.0.0"; + sha256 = "17qsl5nanlqk9iz0l5wijdn6ka632fs1m1fvx18dfgswm258r3ss"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; + }) + (fetchNuGet { + pname = "System.Resources.Extensions"; + version = "8.0.0"; + sha256 = "0chqkw486pb5dg9nlj5352lsz1206xyf953nd98dglia3isxklg5"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.0"; + sha256 = "17labczwqk3jng3kkky73m0jhi8wc21vbl7cz5c0hj2p1dswin43"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.2"; + sha256 = "1vz4275fjij8inf31np78hw50al8nqkngk04p3xv5n4fcmf1grgi"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.3"; + sha256 = "1afi6s2r1mh1kygbjmfba6l4f87pi5sg13p4a48idqafli94qxln"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.7.0"; + sha256 = "16r6sn4czfjk8qhnz7bnqlyiaaszr0ihinb7mq9zzr1wba257r54"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.3.0"; + sha256 = "19rav39sr5dky7afygh309qamqqmi9kcwvz3i0c5700v0c5cg61z"; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "5.0.0"; + sha256 = "17n3lrrl6vahkqmhlpn3w20afgz09n7i6rv0r3qypngwi7wqdr5r"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.3.0"; + sha256 = "03sq183pfl5kp7gkvq77myv7kbpdnq3y0xj7vi4q1kaw54sny0ml"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.3.0"; + sha256 = "1k468aswafdgf56ab6yrn7649kfqx2wm9aslywjam1hdmk5yypmv"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Csp"; + version = "4.3.0"; + sha256 = "1x5wcrddf2s3hb8j78cry7yalca4lb5vfnkrysagbn6r9x6xvrx1"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.3.0"; + sha256 = "1jr6w70igqn07k5zs1ph6xja97hxnb3mqbspdrff6cvssgrixs32"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0givpvvj8yc7gv4lhb6s1prq6p2c4147204a0wib89inqzd87gqc"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.3.0"; + sha256 = "0pyzncsv48zwly3lw4f2dayqswcfvdwq2nz0dgwmi7fj3pn64wby"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "8.0.0"; + sha256 = "1ysjx3b5ips41s32zacf4vs7ig41906mxrsbmykdzi0hvdmjkgbx"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.3.0"; + sha256 = "0valjcz5wksbvijylxijjxb1mp38mdhv03r533vnx1q3ikzdav9h"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + sha256 = "1mpk7xj76lxgz97a5yg93wi8lj0l8p157a5d50mmjy3gbz1904q8"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "8.0.0"; + sha256 = "1lgdd78cik4qyvp2fggaa0kzxasw6kc9a6cjqw46siagrm0qnc3y"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Dataflow"; + version = "8.0.0"; + sha256 = "02mmqnbd7ybin1yiffrq3ph71rsbrnf6r6m01j98ynydqfscz9s3"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.2"; + sha256 = "1sh63dz0dymqcwmprp0nadm77b83vmm7lyllpv578c397bslb8hj"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + sha256 = "0y6ncasgfcgnjrhynaf0lwpkpkmv4a07sswwkwbwb5h7riisj153"; + }) + (fetchNuGet { + pname = "System.ValueTuple"; + version = "4.5.0"; + sha256 = "00k8ja51d0f9wrq4vv5z2jhq8hy31kac2rg0rv06prylcybzl8cy"; + }) + (fetchNuGet { + pname = "Unosquare.Swan.Lite"; + version = "3.1.0"; + sha256 = "0yjbchc2rhgssfvb1qxg3kq3lzyx089r3rngpcjgrkw85bf0vgrw"; + }) + (fetchNuGet { + pname = "ZXing.Net"; + version = "0.16.9"; + sha256 = "0bpki21p2wjjjviayhza0gam7s9lm7qj6g8hdcp2csd0mv54l980"; + }) ] diff --git a/pkgs/by-name/na/nar-serve/package.nix b/pkgs/by-name/na/nar-serve/package.nix index 8bd274af659f08..84e91c2ae2bfcd 100644 --- a/pkgs/by-name/na/nar-serve/package.nix +++ b/pkgs/by-name/na/nar-serve/package.nix @@ -1,7 +1,8 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, nixosTests +{ + buildGoModule, + fetchFromGitHub, + lib, + nixosTests, }: buildGoModule rec { pname = "nar-serve"; @@ -25,6 +26,9 @@ buildGoModule rec { mainProgram = "nar-serve"; homepage = "https://github.com/numtide/nar-serve"; license = licenses.mit; - maintainers = with maintainers; [ rizary zimbatm ]; + maintainers = with maintainers; [ + rizary + zimbatm + ]; }; } diff --git a/pkgs/by-name/na/narrowlink/package.nix b/pkgs/by-name/na/narrowlink/package.nix index 531b0e7f60c9e1..f0e5a58b4c184c 100644 --- a/pkgs/by-name/na/narrowlink/package.nix +++ b/pkgs/by-name/na/narrowlink/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -30,7 +31,10 @@ rustPlatform.buildRustPackage rec { meta = { description = "Self-hosted solution to enable secure connectivity between devices across restricted networks like NAT or firewalls"; homepage = "https://github.com/narrowlink/narrowlink"; - license = with lib.licenses; [ agpl3Only mpl20 ]; # the gateway component is AGPLv3, the rest is MPLv2 + license = with lib.licenses; [ + agpl3Only + mpl20 + ]; # the gateway component is AGPLv3, the rest is MPLv2 maintainers = with lib.maintainers; [ dit7ya ]; mainProgram = "narrowlink"; }; diff --git a/pkgs/by-name/na/nas/package.nix b/pkgs/by-name/na/nas/package.nix index 84d8db558546c0..30e359960faeec 100644 --- a/pkgs/by-name/na/nas/package.nix +++ b/pkgs/by-name/na/nas/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, bison -, flex -, gccmakedep -, imake -, libXau -, libXaw -, libXext -, libXpm -, libXt -, xorgcffiles -, xorgproto +{ + lib, + stdenv, + fetchurl, + bison, + flex, + gccmakedep, + imake, + libXau, + libXaw, + libXext, + libXpm, + libXt, + xorgcffiles, + xorgproto, }: stdenv.mkDerivation (finalAttrs: { @@ -39,9 +40,15 @@ stdenv.mkDerivation (finalAttrs: { xorgproto ]; - buildFlags = [ "WORLDOPTS=" "World" ]; + buildFlags = [ + "WORLDOPTS=" + "World" + ]; - installFlags = [ "LDLIBS=-lfl" "DESTDIR=${placeholder "out"}" ]; + installFlags = [ + "LDLIBS=-lfl" + "DESTDIR=${placeholder "out"}" + ]; postInstall = '' mv $out/${xorgcffiles}/* $out diff --git a/pkgs/by-name/na/nasc/package.nix b/pkgs/by-name/na/nasc/package.nix index cd96b1d669a10e..57afe669e12dc8 100644 --- a/pkgs/by-name/na/nasc/package.nix +++ b/pkgs/by-name/na/nasc/package.nix @@ -1,21 +1,23 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config -, python3 -, meson -, ninja -, vala -, gtk3 -, glib -, pantheon -, gtksourceview -, libgee -, nix-update-script -, webkitgtk_4_0 -, libqalculate -, intltool -, gnuplot -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + python3, + meson, + ninja, + vala, + gtk3, + glib, + pantheon, + gtksourceview, + libgee, + nix-update-script, + webkitgtk_4_0, + libqalculate, + intltool, + gnuplot, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -42,15 +44,18 @@ stdenv.mkDerivation rec { wrapGAppsHook3 ]; - buildInputs = [ - glib - gtk3 - gtksourceview - libgee - pantheon.granite - webkitgtk_4_0 - # We add libqalculate's runtime dependencies because nasc has it as a modified subproject. - ] ++ libqalculate.buildInputs ++ libqalculate.propagatedBuildInputs; + buildInputs = + [ + glib + gtk3 + gtksourceview + libgee + pantheon.granite + webkitgtk_4_0 + # We add libqalculate's runtime dependencies because nasc has it as a modified subproject. + ] + ++ libqalculate.buildInputs + ++ libqalculate.propagatedBuildInputs; postPatch = '' chmod +x meson/post_install.py diff --git a/pkgs/by-name/na/nasin-nanpa/package.nix b/pkgs/by-name/na/nasin-nanpa/package.nix index 339c89dd9b0b4b..de98f92b4ad118 100644 --- a/pkgs/by-name/na/nasin-nanpa/package.nix +++ b/pkgs/by-name/na/nasin-nanpa/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "nasin-nanpa"; diff --git a/pkgs/by-name/na/nasty/package.nix b/pkgs/by-name/na/nasty/package.nix index 80b6a2da8e2da9..bd548a37bbd84c 100644 --- a/pkgs/by-name/na/nasty/package.nix +++ b/pkgs/by-name/na/nasty/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gpgme }: +{ + lib, + stdenv, + fetchurl, + gpgme, +}: stdenv.mkDerivation rec { pname = "nasty"; @@ -24,9 +29,9 @@ stdenv.mkDerivation rec { description = "Recover the passphrase of your PGP or GPG-key"; mainProgram = "nasty"; longDescription = '' - Nasty is a program that helps you to recover the passphrase of your PGP or GPG-key - in case you forget or lost it. It is mostly a proof-of-concept: with a different implementation - this program could be at least 100x faster. + Nasty is a program that helps you to recover the passphrase of your PGP or GPG-key + in case you forget or lost it. It is mostly a proof-of-concept: with a different implementation + this program could be at least 100x faster. ''; homepage = "http://www.vanheusden.com/nasty/"; license = licenses.gpl2Only; @@ -34,4 +39,3 @@ stdenv.mkDerivation rec { platforms = platforms.unix; }; } - diff --git a/pkgs/by-name/na/nat-traverse/package.nix b/pkgs/by-name/na/nat-traverse/package.nix index 39e74f215159b1..e955c672f38860 100644 --- a/pkgs/by-name/na/nat-traverse/package.nix +++ b/pkgs/by-name/na/nat-traverse/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "nat-traverse"; diff --git a/pkgs/by-name/na/national-park-typeface/package.nix b/pkgs/by-name/na/national-park-typeface/package.nix index 36b7e6e2ac339a..8f9bfd3ab148f0 100644 --- a/pkgs/by-name/na/national-park-typeface/package.nix +++ b/pkgs/by-name/na/national-park-typeface/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "national-park-typeface"; diff --git a/pkgs/by-name/na/natls/package.nix b/pkgs/by-name/na/natls/package.nix index 195ef7994216c4..c728826b5bc5cc 100644 --- a/pkgs/by-name/na/natls/package.nix +++ b/pkgs/by-name/na/natls/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/na/nats-kafka/package.nix b/pkgs/by-name/na/nats-kafka/package.nix index fa9b770a0a8d6a..df63a9af602c38 100644 --- a/pkgs/by-name/na/nats-kafka/package.nix +++ b/pkgs/by-name/na/nats-kafka/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, }: buildGoModule rec { diff --git a/pkgs/by-name/na/nats-server/package.nix b/pkgs/by-name/na/nats-server/package.nix index f43c3c1ea263e2..e99d1a34d3e537 100644 --- a/pkgs/by-name/na/nats-server/package.nix +++ b/pkgs/by-name/na/nats-server/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { @@ -27,6 +28,9 @@ buildGoModule rec { homepage = "https://nats.io/"; changelog = "https://github.com/nats-io/nats-server/releases/tag/v${version}"; license = licenses.asl20; - maintainers = with maintainers; [ swdunlop derekcollison ]; + maintainers = with maintainers; [ + swdunlop + derekcollison + ]; }; } diff --git a/pkgs/by-name/na/nats-streaming-server/package.nix b/pkgs/by-name/na/nats-streaming-server/package.nix index 30f7b366e579ac..7431132ae47a78 100644 --- a/pkgs/by-name/na/nats-streaming-server/package.nix +++ b/pkgs/by-name/na/nats-streaming-server/package.nix @@ -1,13 +1,17 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { - pname = "nats-streaming-server"; + pname = "nats-streaming-server"; version = "0.25.6"; src = fetchFromGitHub { - rev = "v${version}"; - owner = "nats-io"; - repo = pname; + rev = "v${version}"; + owner = "nats-io"; + repo = pname; sha256 = "sha256-i5fNxeJQXiyy+9NOGT1X68u9Pztxvnnba64rxIgjbZc="; }; diff --git a/pkgs/by-name/na/nats-top/package.nix b/pkgs/by-name/na/nats-top/package.nix index ae66e1ba1c50bf..cb24d0fe98d7fe 100644 --- a/pkgs/by-name/na/nats-top/package.nix +++ b/pkgs/by-name/na/nats-top/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, nats-top +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + nats-top, }: buildGoModule rec { diff --git a/pkgs/by-name/na/natscli/package.nix b/pkgs/by-name/na/natscli/package.nix index 68787caff7b28d..555c09689037b4 100644 --- a/pkgs/by-name/na/natscli/package.nix +++ b/pkgs/by-name/na/natscli/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, versionCheckHook +{ + lib, + buildGoModule, + fetchFromGitHub, + versionCheckHook, }: buildGoModule rec { diff --git a/pkgs/by-name/na/natural-docs/package.nix b/pkgs/by-name/na/natural-docs/package.nix index 7b614fe359dd57..fcffb10de7df6c 100644 --- a/pkgs/by-name/na/natural-docs/package.nix +++ b/pkgs/by-name/na/natural-docs/package.nix @@ -1,4 +1,10 @@ -{ stdenv, fetchzip, makeWrapper, mono, lib }: +{ + stdenv, + fetchzip, + makeWrapper, + mono, + lib, +}: stdenv.mkDerivation rec { pname = "natural-docs"; diff --git a/pkgs/by-name/na/nautilus-open-any-terminal/package.nix b/pkgs/by-name/na/nautilus-open-any-terminal/package.nix index 67f45c2eb6f26c..058e3bec6e6985 100644 --- a/pkgs/by-name/na/nautilus-open-any-terminal/package.nix +++ b/pkgs/by-name/na/nautilus-open-any-terminal/package.nix @@ -1,16 +1,17 @@ -{ lib -, pkg-config -, dbus -, dconf -, fetchFromGitHub -, glib -, nautilus -, nautilus-python -, gobject-introspection -, gsettings-desktop-schemas -, gtk3 -, python3 -, wrapGAppsHook3 +{ + lib, + pkg-config, + dbus, + dconf, + fetchFromGitHub, + glib, + nautilus, + nautilus-python, + gobject-introspection, + gsettings-desktop-schemas, + gtk3, + python3, + wrapGAppsHook3, }: python3.pkgs.buildPythonPackage rec { diff --git a/pkgs/by-name/na/nautilus-open-in-blackbox/package.nix b/pkgs/by-name/na/nautilus-open-in-blackbox/package.nix index cb8c6434e24cb3..6a68bbe7225609 100644 --- a/pkgs/by-name/na/nautilus-open-in-blackbox/package.nix +++ b/pkgs/by-name/na/nautilus-open-in-blackbox/package.nix @@ -1,13 +1,19 @@ -{ python3, fetchFromGitHub, nautilus-python, stdenv, lib }: +{ + python3, + fetchFromGitHub, + nautilus-python, + stdenv, + lib, +}: stdenv.mkDerivation rec { pname = "nautilus-open-in-blackbox"; version = "0.1.1"; src = fetchFromGitHub { - owner = "ppvan"; - repo = "nautilus-open-in-blackbox"; - rev = "refs/tags/${version}"; - hash = "sha256-5rvh3qNalpjamcBVQrnAW6GxhwPPlRxP5h045YDqvrM="; + owner = "ppvan"; + repo = "nautilus-open-in-blackbox"; + rev = "refs/tags/${version}"; + hash = "sha256-5rvh3qNalpjamcBVQrnAW6GxhwPPlRxP5h045YDqvrM="; }; # The Orignal Source code tries to execute `/usr/bin/blackbox` which is not valid in NixOS diff --git a/pkgs/by-name/na/nautilus-python/package.nix b/pkgs/by-name/na/nautilus-python/package.nix index 993d3e2933aff4..f501181da59778 100644 --- a/pkgs/by-name/na/nautilus-python/package.nix +++ b/pkgs/by-name/na/nautilus-python/package.nix @@ -14,7 +14,7 @@ gnome, }: -stdenv.mkDerivation (finalAttrs:{ +stdenv.mkDerivation (finalAttrs: { pname = "nautilus-python"; version = "4.0.1"; diff --git a/pkgs/by-name/na/nauty/package.nix b/pkgs/by-name/na/nauty/package.nix index c1feeffdcb6d92..0963586a049d65 100644 --- a/pkgs/by-name/na/nauty/package.nix +++ b/pkgs/by-name/na/nauty/package.nix @@ -1,17 +1,23 @@ -{ stdenv -, lib -, fetchurl +{ + stdenv, + lib, + fetchurl, }: stdenv.mkDerivation rec { pname = "nauty"; version = "2.8.8"; src = fetchurl { - url = "https://pallini.di.uniroma1.it/nauty${builtins.replaceStrings ["."] ["_"] version}.tar.gz"; + url = "https://pallini.di.uniroma1.it/nauty${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.tar.gz"; sha256 = "sha256-FZ0hVoEKa7JAQQzWHrZBrdhQiNnxXIiM2qN7hoH5Kc4="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; configureFlags = [ # Prevent nauty from sniffing some cpu features. While those are very diff --git a/pkgs/by-name/na/navi/package.nix b/pkgs/by-name/na/navi/package.nix index 2d634e99dd157e..78ad846cf2d64f 100644 --- a/pkgs/by-name/na/navi/package.nix +++ b/pkgs/by-name/na/navi/package.nix @@ -1,4 +1,14 @@ -{ stdenv, fetchFromGitHub, lib, makeWrapper, rustPlatform, wget, libiconv, withFzf ? true, fzf }: +{ + stdenv, + fetchFromGitHub, + lib, + makeWrapper, + rustPlatform, + wget, + libiconv, + withFzf ? true, + fzf, +}: rustPlatform.buildRustPackage rec { pname = "navi"; @@ -20,13 +30,13 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram $out/bin/navi \ --prefix PATH : "$out/bin" \ - --prefix PATH : ${lib.makeBinPath([ wget ] ++ lib.optionals withFzf [ fzf ])} + --prefix PATH : ${lib.makeBinPath ([ wget ] ++ lib.optionals withFzf [ fzf ])} ''; checkFlags = [ # error: Found argument '--test-threads' which wasn't expected, or isn't valid in this context "--skip=test_parse_variable_line" - ]; + ]; meta = with lib; { description = "Interactive cheatsheet tool for the command-line and application launchers"; diff --git a/pkgs/by-name/na/navidrome/package.nix b/pkgs/by-name/na/navidrome/package.nix index 89cfd60e3ebfb2..8925f7ba68077c 100644 --- a/pkgs/by-name/na/navidrome/package.nix +++ b/pkgs/by-name/na/navidrome/package.nix @@ -1,18 +1,19 @@ -{ buildGo123Module -, buildPackages -, fetchFromGitHub -, fetchNpmDeps -, lib -, nodejs -, npmHooks -, pkg-config -, stdenv -, ffmpeg-headless -, taglib -, zlib -, nixosTests -, nix-update-script -, ffmpegSupport ? true +{ + buildGo123Module, + buildPackages, + fetchFromGitHub, + fetchNpmDeps, + lib, + nodejs, + npmHooks, + pkg-config, + stdenv, + ffmpeg-headless, + taglib, + zlib, + nixosTests, + nix-update-script, + ffmpegSupport ? true, }: buildGo123Module rec { @@ -80,7 +81,10 @@ buildGo123Module rec { homepage = "https://www.navidrome.org/"; license = lib.licenses.gpl3Only; sourceProvenance = with lib.sourceTypes; [ fromSource ]; - maintainers = with lib.maintainers; [ aciceri squalus ]; + maintainers = with lib.maintainers; [ + aciceri + squalus + ]; # Broken on Darwin: sandbox-exec: pattern serialization length exceeds maximum (NixOS/nix#4119) broken = stdenv.hostPlatform.isDarwin; }; diff --git a/pkgs/by-name/na/nawk/package.nix b/pkgs/by-name/na/nawk/package.nix index d2132c25f27720..1e34e7f9d010b5 100644 --- a/pkgs/by-name/na/nawk/package.nix +++ b/pkgs/by-name/na/nawk/package.nix @@ -20,7 +20,10 @@ stdenv.mkDerivation (finalAttrs: { depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ bison installShellFiles ]; + nativeBuildInputs = [ + bison + installShellFiles + ]; outputs = [ "out" diff --git a/pkgs/by-name/nb/nb/package.nix b/pkgs/by-name/nb/nb/package.nix index c94a44bc7cbdef..299df3fb157c0d 100644 --- a/pkgs/by-name/nb/nb/package.nix +++ b/pkgs/by-name/nb/nb/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, installShellFiles, testers, nix-update-script, nb }: +{ + stdenv, + lib, + fetchFromGitHub, + installShellFiles, + testers, + nix-update-script, + nb, +}: stdenv.mkDerivation rec { pname = "nb"; diff --git a/pkgs/by-name/nb/nbd/package.nix b/pkgs/by-name/nb/nbd/package.nix index e2924665bd3183..9a3c6b02540a44 100644 --- a/pkgs/by-name/nb/nbd/package.nix +++ b/pkgs/by-name/nb/nbd/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, pkg-config -, glib -, which -, bison -, nixosTests -, libnl -, linuxHeaders -, gnutls +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + glib, + which, + bison, + nixosTests, + libnl, + linuxHeaders, + gnutls, }: stdenv.mkDerivation rec { @@ -36,13 +37,15 @@ stdenv.mkDerivation rec { bison ]; - buildInputs = [ - glib - gnutls - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libnl - linuxHeaders - ]; + buildInputs = + [ + glib + gnutls + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libnl + linuxHeaders + ]; configureFlags = [ "--sysconfdir=/etc" diff --git a/pkgs/by-name/nb/nbench/package.nix b/pkgs/by-name/nb/nbench/package.nix index b8fa6abfbadaa9..abb8c5a3747e93 100644 --- a/pkgs/by-name/nb/nbench/package.nix +++ b/pkgs/by-name/nb/nbench/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "nbench-byte"; @@ -9,12 +13,14 @@ stdenv.mkDerivation rec { sha256 = "1b01j7nmm3wd92ngvsmn2sbw43sl9fpx4xxmkrink68fz1rx0gbj"; }; - prePatch = '' - substituteInPlace nbench1.h --replace '"NNET.DAT"' "\"$out/NNET.DAT\"" - substituteInPlace sysspec.h --replace "malloc.h" "stdlib.h" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace Makefile --replace "-static" "" - ''; + prePatch = + '' + substituteInPlace nbench1.h --replace '"NNET.DAT"' "\"$out/NNET.DAT\"" + substituteInPlace sysspec.h --replace "malloc.h" "stdlib.h" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace Makefile --replace "-static" "" + ''; buildInputs = lib.optionals stdenv.hostPlatform.isGnu [ stdenv.cc.libc.static diff --git a/pkgs/by-name/nb/nbfc-linux/package.nix b/pkgs/by-name/nb/nbfc-linux/package.nix index 4e41574dcd1892..2ae265b615dbbc 100644 --- a/pkgs/by-name/nb/nbfc-linux/package.nix +++ b/pkgs/by-name/nb/nbfc-linux/package.nix @@ -31,7 +31,7 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://github.com/nbfc-linux/nbfc-linux"; license = lib.licenses.gpl3; - maintainers = [lib.maintainers.Celibistrial]; + maintainers = [ lib.maintainers.Celibistrial ]; mainProgram = "nbfc"; platforms = lib.platforms.linux; }; diff --git a/pkgs/by-name/nb/nbtscan/package.nix b/pkgs/by-name/nb/nbtscan/package.nix index 9d9e0b3afbe67b..a958994a4f3b3b 100644 --- a/pkgs/by-name/nb/nbtscan/package.nix +++ b/pkgs/by-name/nb/nbtscan/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/nb/nbutools/package.nix b/pkgs/by-name/nb/nbutools/package.nix index 15401e3db2588e..36ad8bd11e2f1e 100644 --- a/pkgs/by-name/nb/nbutools/package.nix +++ b/pkgs/by-name/nb/nbutools/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/nb/nbxplorer/deps.nix b/pkgs/by-name/nb/nbxplorer/deps.nix index 441a54528783fd..1b8747df04f97d 100644 --- a/pkgs/by-name/nb/nbxplorer/deps.nix +++ b/pkgs/by-name/nb/nbxplorer/deps.nix @@ -1,220 +1,1081 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Dapper"; version = "2.1.35"; hash = "sha256-zeroySx7lO1yLtbhKhFQ87diWXOq9gPnv3qFcmNcs9M="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.JsonPatch"; version = "8.0.5"; hash = "sha256-i5VzC7peTKTiwjoqzlUFysyu7oUxBtf3bG/BZ6QYs/A="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.NewtonsoftJson"; version = "8.0.5"; hash = "sha256-8GX1oDCmWiX3t/gwpn2fVl3Pw3DdXgWru5refK8w+aw="; }) - (fetchNuGet { pname = "Microsoft.Azure.Amqp"; version = "2.4.9"; hash = "sha256-qmJGqOHjn1SofqiFuQ7qUuDOaDgX2cjnCOcE6iCde5Y="; }) - (fetchNuGet { pname = "Microsoft.Azure.ServiceBus"; version = "4.2.1"; hash = "sha256-RUfwCX0NMxKMXV7guVRWjmZOYEuxpFeabOeiA3TDfSo="; }) - (fetchNuGet { pname = "Microsoft.Azure.Services.AppAuthentication"; version = "1.0.3"; hash = "sha256-KaGL7asV10S+fGp9dt1i6frelho8ns73epxGzZ4iRis="; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.3.0"; hash = "sha256-a3dAiPaVuky0wpcHmpTVtAQJNGZ2v91/oArA+dpJgj8="; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.7.0"; hash = "sha256-Enknv2RsFF68lEPdrf5M+BpV1kHoLTVRApKUwuk/pj0="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "6.0.0"; hash = "sha256-SIO/Q+OD2bG+Q0EoOXRgJYzZMhahGXDG1fXZn0VUvv0="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "6.0.0"; hash = "sha256-Evg+Ynj2QUa6Gz+zqF+bUyfGD0HI5A2fHmxZEXbn3HA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; version = "6.0.0"; hash = "sha256-tG3DEWURVkQHm4MlmxjE/YouTp9wQKbWs6qHH2nfgqc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.FileExtensions"; version = "6.0.0"; hash = "sha256-PLnSa0JMfDC62OTv8sL0QFJbANE7QSnJ997ySFBS1go="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Ini"; version = "6.0.0"; hash = "sha256-5tUoqvIsWL5hfmMCpCpBW6V1tw/sMUCwfnm/7Y8LD6M="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.0"; hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "6.0.0"; hash = "sha256-uBjWjHKEXjZ9fDfFxMjOou3lhfTNhs1yO+e3fpWreLk="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Physical"; version = "6.0.0"; hash = "sha256-5BAQOqnaEXM2YjdrmrCinXBeZ5FKxCWtebEXMdwcbMY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileSystemGlobbing"; version = "6.0.0"; hash = "sha256-RAWHjkkfvGpjc49Q0kJbZyXgU6UEq/EJ0j557sj2/iU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "1.0.0"; hash = "sha256-asIXVFsAK7ELd/f+vLwhxYDdazqRTmf+fGJ4WFtcCeo="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "6.0.0"; hash = "sha256-QNqcQ3x+MOK7lXbWkCzSOWa/2QyYNbdM/OEEbWN15Sw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "8.0.0"; hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "6.0.0"; hash = "sha256-AgvysszpQ11AiTBJFkvSy8JnwIWTj15Pfek7T7ThUc4="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.Clients.ActiveDirectory"; version = "3.14.2"; hash = "sha256-mFlsKSQ6DsKttWuFkv6eMs0uSFHgwocxDad1icMXKj0="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.JsonWebTokens"; version = "5.4.0"; hash = "sha256-yKITMgW2JEXhPlQgdmofAyt0eEcCr72P4rM2EC6wrig="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.Logging"; version = "5.4.0"; hash = "sha256-YKdSKQDO5+ssC5mqLGtBhuJ4lLbLUadMVV4PPJ6/tMU="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.Tokens"; version = "5.4.0"; hash = "sha256-gCJ+4QwhuBPSkDN+HcMCpTE2LFIQ3htI/SddoHOB7T4="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.0.1"; hash = "sha256-mZotlGZqtrqDSoBrZhsxFe6fuOv5/BIo0w2Z2x0zVAU="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.0.2"; hash = "sha256-YLJ2+BONtCWb0lY4Rttdqzbcm4z+5N5uNr3byRWQOZ8="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.0.1"; hash = "sha256-lxxw/Gy32xHi0fLgFWNj4YTFBSBkjx5l6ucmbTyf7V4="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.0.1"; hash = "sha256-B4t5El/ViBdxALMcpZulewc4j/3SIXf71HhJWhm4Ctk="; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.3.0"; hash = "sha256-mBNDmPXNTW54XLnPAUwBRvkIORFM7/j0D0I2SyQPDEg="; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "4.3.0"; hash = "sha256-50XwFbyRfZkTD/bBn76WV/NIpOy/mzXD3MMEVFX/vr8="; }) - (fetchNuGet { pname = "NBitcoin"; version = "7.0.37"; hash = "sha256-RclQZgot+Y8PZi9JEX7tgUJinkIBXs1Qgf4vGR2y4rc="; }) - (fetchNuGet { pname = "NBitcoin.Altcoins"; version = "3.0.24"; hash = "sha256-MGxIuYtWPgSYj5JCMmZfP7u04ki/UpeN1+//gU6RsdI="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "1.6.1"; hash = "sha256-iNan1ix7RtncGWC9AjAZ2sk70DoxOsmEOgQ10fXm4Pw="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "10.0.3"; hash = "sha256-WEHCjp+OMr5axXQjFsh7TMDE/ttE35nMv5RBPdcxfhs="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.1"; hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.3"; hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; }) - (fetchNuGet { pname = "Newtonsoft.Json.Bson"; version = "1.0.2"; hash = "sha256-ZUj6YFSMZp5CZtXiamw49eZmbp1iYBuNsIKNnjxcRzA="; }) - (fetchNuGet { pname = "NicolasDorier.CommandLine"; version = "2.0.0"; hash = "sha256-LizYyIMx6I17jZd52duYcGWNgcPs88c/zWxo/ADd3D8="; }) - (fetchNuGet { pname = "NicolasDorier.CommandLine.Configuration"; version = "2.0.0"; hash = "sha256-fDpDOVdt7xCDXXqaBnbaFvUOPaE0Sl4cLWjNkU0Cz7I="; }) - (fetchNuGet { pname = "NicolasDorier.StandardConfiguration"; version = "2.0.0"; hash = "sha256-mwPvVaESUnou1qd0b6oSmQfBBz28LmQIb1EoSUZvqAA="; }) - (fetchNuGet { pname = "Npgsql"; version = "8.0.3"; hash = "sha256-weBGo/IXKI5ufixBCuWG7OqDSyIqvGV07oxrG0XnQIQ="; }) - (fetchNuGet { pname = "RabbitMQ.Client"; version = "5.1.2"; hash = "sha256-reYeBKsqfrdZZ4Nq4dsqLo1GNtcT2A0VuOIHtW3ttqQ="; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tools"; version = "4.3.0"; hash = "sha256-8yLKFt2wQxkEf7fNfzB+cPUCjYn2qbqNgQ1+EeY2h/I="; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-dsmTLGvt8HqRkDWP8iKVXJCS+akAzENGXKPV18W2RgI="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization.Calendars"; version = "4.3.0"; hash = "sha256-AYh39tgXJVFu8aLi9Y/4rK8yWMaza4S4eaxjfcuEEL4="; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-6MYj0RmLh4EVqMtO/MRqBi0HOn5iG4x9JimgCCJ+EFM="; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Timer"; version = "4.3.0"; hash = "sha256-BgHxXCIbicVZtpgMimSXixhFC3V+p5ODqeljDjO8hCs="; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.0.0"; hash = "sha256-bmaM0ovT4X4aqDJOR255Yda/u3fmHZskU++lMnsy894="; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; }) - (fetchNuGet { pname = "runtime.native.System.IO.Compression"; version = "4.3.0"; hash = "sha256-DWnXs4vlKoU6WxxvCArTJupV6sX3iBbZh8SbqfHace8="; }) - (fetchNuGet { pname = "runtime.native.System.Net.Http"; version = "4.0.1"; hash = "sha256-5nWnTQrA1T6t9r8MqIiV4yTNu+IH0of2OX1qteoS+8E="; }) - (fetchNuGet { pname = "runtime.native.System.Net.Http"; version = "4.3.0"; hash = "sha256-c556PyheRwpYhweBjSfIwEyZHnAUB8jWioyKEcp/2dg="; }) - (fetchNuGet { pname = "runtime.native.System.Net.Security"; version = "4.3.0"; hash = "sha256-I8vYld/7WtU2/rrD4XfSRgpO/DY3qXghG14VQjiU2DY="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography"; version = "4.0.0"; hash = "sha256-6Q8eYzC32BbGIiTHoQaE6B3cD81vYQcH5SCswYRSp0w="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; hash = "sha256-2IhBv0i6pTcOyr8FFIyfPEaaCHUmJZ8DYwLUwJ+5waw="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; hash = "sha256-serkd4A7F6eciPiPJtUyJyxzdAtupEcWIZQ9nptEzIM="; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; }) - (fetchNuGet { pname = "runtime.unix.Microsoft.Win32.Primitives"; version = "4.3.0"; hash = "sha256-LZb23lRXzr26tRS5aA0xyB08JxiblPDoA7HBvn6awXg="; }) - (fetchNuGet { pname = "runtime.unix.System.Console"; version = "4.3.0"; hash = "sha256-AHkdKShTRHttqfMjmi+lPpTuCrM5vd/WRy6Kbtie190="; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; }) - (fetchNuGet { pname = "runtime.unix.System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-Pf4mRl6YDK2x2KMh0WdyNgv0VUNdSKVDLlHqozecy5I="; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Primitives"; version = "4.3.0"; hash = "sha256-pHJ+I6i16MV6m77uhTC6GPY6jWGReE3SSP3fVB59ti0="; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Sockets"; version = "4.3.0"; hash = "sha256-IvgOeA2JuBjKl5yAVGjPYMPDzs9phb3KANs95H9v1w4="; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; }) - (fetchNuGet { pname = "System.AppContext"; version = "4.3.0"; hash = "sha256-yg95LNQOwFlA1tWxXdQkVyJqT4AnoDc+ACmrNvzGiZg="; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.3.0"; hash = "sha256-XqZWb4Kd04960h4U9seivjKseGA/YEIpdplfHYHQ9jk="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.0.11"; hash = "sha256-puoFMkx4Z55C1XPxNw3np8nzNGjH+G24j43yTIsDRL0="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.0.12"; hash = "sha256-zIEM7AB4SyE9u6G8+o+gCLLwkgi6+3rHQVPdn/dEwB8="; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.3.0"; hash = "sha256-KMY5DfJnDeIsa13DpqvyN8NkReZEMAFnlmNglVoFIXI="; }) - (fetchNuGet { pname = "System.Collections.NonGeneric"; version = "4.3.0"; hash = "sha256-8/yZmD4jjvq7m68SPkJZLBQ79jOTOyT5lyzX4SCYAx8="; }) - (fetchNuGet { pname = "System.Collections.Specialized"; version = "4.3.0"; hash = "sha256-QNg0JJNx+zXMQ26MJRPzH7THdtqjrNtGLUgaR1SdvOk="; }) - (fetchNuGet { pname = "System.ComponentModel"; version = "4.3.0"; hash = "sha256-i00uujMO4JEDIEPKLmdLY3QJ6vdSpw6Gh9oOzkFYBiU="; }) - (fetchNuGet { pname = "System.ComponentModel.Primitives"; version = "4.3.0"; hash = "sha256-IOMJleuIBppmP4ECB3uftbdcgL7CCd56+oAD/Sqrbus="; }) - (fetchNuGet { pname = "System.ComponentModel.TypeConverter"; version = "4.3.0"; hash = "sha256-PSDiPYt8PgTdTUBz+GH6lHCaM1YgfObneHnZsc8Fz54="; }) - (fetchNuGet { pname = "System.Console"; version = "4.3.0"; hash = "sha256-Xh3PPBZr0pDbDaK8AEHbdGz7ePK6Yi1ZyRWI1JM6mbo="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.0.11"; hash = "sha256-P+rSQJVoN6M56jQbs76kZ9G3mAWFdtF27P/RijN8sj4="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "4.5.1"; hash = "sha256-gZEDRv0v0AAauQ36BWXkJk3GLW0sYH6QPxa0p2l8Dck="; }) - (fetchNuGet { pname = "System.Diagnostics.Process"; version = "4.3.0"; hash = "sha256-Rzo24qXhuJDDgrGNHr2eQRHhwLmsYmWDqAg/P5fOlzw="; }) - (fetchNuGet { pname = "System.Diagnostics.Tools"; version = "4.3.0"; hash = "sha256-gVOv1SK6Ape0FQhCVlNOd9cvQKBvMxRX9K0JPVi8w0Y="; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.1.0"; hash = "sha256-JA0jJcLbU3zh52ub3zweob2EVHvxOqiC6SCYHrY5WbQ="; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.3.0"; hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.0.11"; hash = "sha256-rbSgc2PIEc2c2rN6LK3qCREAX3DqA2Nq1WcLrZYsDBw="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.0.1"; hash = "sha256-EJN3LbN+b0O9Dr2eg7kfThCYpne0iJ/H/GIyUTNVYC8="; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.3.0"; hash = "sha256-uNOD0EOVFgnS2fMKvMiEtI9aOw00+Pfy/H+qucAQlPc="; }) - (fetchNuGet { pname = "System.Globalization.Extensions"; version = "4.3.0"; hash = "sha256-mmJWA27T0GRVuFP9/sj+4TrR4GJWrzNIk2PDrbr7RQk="; }) - (fetchNuGet { pname = "System.IdentityModel.Tokens.Jwt"; version = "5.4.0"; hash = "sha256-zLtoejPBG8yeFEPIcXZAkdAb0WDnrVXh5YsUYKULyRU="; }) - (fetchNuGet { pname = "System.IO"; version = "4.1.0"; hash = "sha256-V6oyQFwWb8NvGxAwvzWnhPxy9dKOfj/XBM3tEC5aHrw="; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; }) - (fetchNuGet { pname = "System.IO.Compression"; version = "4.3.0"; hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; }) - (fetchNuGet { pname = "System.IO.Compression.ZipFile"; version = "4.3.0"; hash = "sha256-WQl+JgWs+GaRMeiahTFUbrhlXIHapzcpTFXbRvAtvvs="; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.0.1"; hash = "sha256-4VKXFgcGYCTWVXjAlniAVq0dO3o5s8KHylg2wg2/7k0="; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.0.1"; hash = "sha256-IpigKMomqb6pmYWkrlf0ZdpILtRluX2cX5sOKVW0Feg="; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; }) - (fetchNuGet { pname = "System.Linq"; version = "4.1.0"; hash = "sha256-ZQpFtYw5N1F1aX0jUK3Tw+XvM5tnlnshkTCNtfVA794="; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.3.0"; hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; }) - (fetchNuGet { pname = "System.Net.Http"; version = "4.3.0"; hash = "sha256-UoBB7WPDp2Bne/fwxKF0nE8grJ6FzTMXdT/jfsphj8Q="; }) - (fetchNuGet { pname = "System.Net.NameResolution"; version = "4.3.0"; hash = "sha256-eGZwCBExWsnirWBHyp2sSSSXp6g7I6v53qNmwPgtJ5c="; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.0.11"; hash = "sha256-2YSijNhCdw/ZU2yfH7vE+ReA8pgxRCXPnWr+ab36v4M="; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.3.0"; hash = "sha256-MY7Z6vOtFMbEKaLW9nOSZeAjcWpwCtdO7/W1mkGZBzE="; }) - (fetchNuGet { pname = "System.Net.Security"; version = "4.3.0"; hash = "sha256-B7laE1z1+ldbo6JkjlDjZynG5JiMZ/3uNHPHMP6LRak="; }) - (fetchNuGet { pname = "System.Net.Sockets"; version = "4.3.0"; hash = "sha256-il7dr5VT/QWDg/0cuh+4Es2u8LY//+qqiY9BZmYxSus="; }) - (fetchNuGet { pname = "System.Net.WebHeaderCollection"; version = "4.0.1"; hash = "sha256-uJSV6kmL+V/9/ot1LhHXGCd8Ndcu6zk+AJ8wgGS/fYE="; }) - (fetchNuGet { pname = "System.Net.WebHeaderCollection"; version = "4.3.0"; hash = "sha256-wpRP3D/2YjpFmqU7Q42L/+/hChEVMlwU1sjysGVrQ1c="; }) - (fetchNuGet { pname = "System.Net.WebSockets"; version = "4.0.0"; hash = "sha256-YhLVuTPyEiHAjdBMHyIobGpysDbAtgZNDX2Q2xKGTRI="; }) - (fetchNuGet { pname = "System.Net.WebSockets"; version = "4.3.0"; hash = "sha256-l3h3cF1cCC9zMhWLKSDnZBZvFADUd0Afe2+iAwBA0r0="; }) - (fetchNuGet { pname = "System.Net.WebSockets.Client"; version = "4.0.2"; hash = "sha256-miyjFY0E49/rtWDOF7QR26jJlYn3WRiQQOonSBJMFV0="; }) - (fetchNuGet { pname = "System.Net.WebSockets.Client"; version = "4.3.2"; hash = "sha256-MwNKwIIpBJhC4Na6EYWMmVyPCa064Yp1aL0opx1FfoA="; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.3.0"; hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; }) - (fetchNuGet { pname = "System.Private.DataContractSerialization"; version = "4.1.1"; hash = "sha256-OaE+ZcEfkpIkbdMOMAMiJa9vgiVP25FGuFrf+N/mafY="; }) - (fetchNuGet { pname = "System.Private.DataContractSerialization"; version = "4.3.0"; hash = "sha256-vNlHUKkaFvhiVnTY0JNsNT5E6TW9CFRzTqVcufGN0hk="; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.1.0"; hash = "sha256-idZHGH2Yl/hha1CM4VzLhsaR8Ljo/rV7TYe7mwRJSMs="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.0.1"; hash = "sha256-F1MvYoQWHCY89/O4JBwswogitqVvKuVfILFqA7dmuHk="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.3.0"; hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.0.1"; hash = "sha256-YG+eJBG5P+5adsHiw/lhJwvREnvdHw6CJyS8ZV4Ujd0="; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.3.0"; hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.0.1"; hash = "sha256-uVvNOnL64CPqsgZP2OLqNmxdkZl6Q0fTmKmv9gcBi+g="; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.3.0"; hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.0.1"; hash = "sha256-NsfmzM9G/sN3H8X2cdnheTGRsh7zbRzvegnjDzDH/FQ="; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.0.1"; hash = "sha256-SFSfpWEyCBMAOerrMCOiKnpT+UAWTvRcmoRquJR6Vq0="; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.1.0"; hash = "sha256-R0YZowmFda+xzKNR4kKg7neFoE30KfZwp/IwfRSKVK4="; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.3.0"; hash = "sha256-4U4/XNQAnddgQIHIJq3P2T80hN0oPdU2uCeghsDTWng="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.0.1"; hash = "sha256-cZ2/3/fczLjEpn6j3xkgQV9ouOVjy4Kisgw5xWw9kSw="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.1.0"; hash = "sha256-FViNGM/4oWtlP6w0JC0vJU+k9efLKZ+yaXrnEeabDQo="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.1.0"; hash = "sha256-X7DZ5CbPY7jHs20YZ7bmcXs9B5Mxptu/HnBUvUnNhGc="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.0.1"; hash = "sha256-j2QgVO9ZOjv7D1het98CoFpjoYgxjupuIhuBUmLLH7w="; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.1.0"; hash = "sha256-QceAYlJvkPRJc/+5jR+wQpNNI3aqGySWWSO30e/FfQY="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices.RuntimeInformation"; version = "4.3.0"; hash = "sha256-MYpl6/ZyC6hjmzWRIe+iDoldOMW1mfbwXsduAnXIKGA="; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.0.1"; hash = "sha256-1pJt5ZGxLPTX1mjOi8qZPXyyOMkYV0NstoUCv91HYPg="; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.3.0"; hash = "sha256-P5jHCgMbgFMYiONvzmaKFeOqcAIDPu/U8bOVrNPYKqc="; }) - (fetchNuGet { pname = "System.Runtime.Serialization.Formatters"; version = "4.3.0"; hash = "sha256-Feic7MGKVG4imh7kpLkPHmApQzYjq7SxHnazh2wZkoQ="; }) - (fetchNuGet { pname = "System.Runtime.Serialization.Json"; version = "4.0.2"; hash = "sha256-thmzgYbyxoPYtkDdDwoG7wnVuVhFNwLUE2AsDfRf1yM="; }) - (fetchNuGet { pname = "System.Runtime.Serialization.Primitives"; version = "4.1.1"; hash = "sha256-80B05oxJbPLGq2pGOSl6NlZvintX9A1CNpna2aN0WRA="; }) - (fetchNuGet { pname = "System.Runtime.Serialization.Primitives"; version = "4.3.0"; hash = "sha256-zu5m1M9usend+i9sbuD6Xbizdo8Z6N5PEF9DAtEVewc="; }) - (fetchNuGet { pname = "System.Runtime.Serialization.Xml"; version = "4.3.0"; hash = "sha256-0bp8xtv2cP/IuxaBF8xkyYYD8N6w1wVX8wzpAwXtTKw="; }) - (fetchNuGet { pname = "System.Security.Claims"; version = "4.3.0"; hash = "sha256-Fua/rDwAqq4UByRVomAxMPmDBGd5eImRqHVQIeSxbks="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.2.0"; hash = "sha256-BelNIpEyToEp/VYKnje/q1P7KNEpQNtOzGPU18pLGpE="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.3.0"; hash = "sha256-tAJvNSlczYBJ3Ed24Ae27a55tq/n4D3fubNQdwcKWA8="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.2.0"; hash = "sha256-7F+m3HnmBsgE4xWF8FeCGlaEgQM3drqA6HEaQr6MEoU="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.3.0"; hash = "sha256-u17vy6wNhqok91SrVLno2M1EzLHZm6VMca85xbVChsw="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Csp"; version = "4.0.0"; hash = "sha256-WHyR6vVK3zaT4De7jgQFUar1P5fiX9ECwiVkJDFFm7M="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Csp"; version = "4.3.0"; hash = "sha256-oefdTU/Z2PWU9nlat8uiRDGq/PGZoSPRgkML11pmvPQ="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.0.0"; hash = "sha256-ZO7ha39J5uHkIF2RoEKv/bW/bLbVvYMO4+rWyYsKHik="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.3.0"; hash = "sha256-Yuge89N6M+NcblcvXMeyHZ6kZDfwBv3LPMDiF8HhJss="; }) - (fetchNuGet { pname = "System.Security.Cryptography.OpenSsl"; version = "4.0.0"; hash = "sha256-mLijAozynzjiOMyh2P5BHcfVq3Ovd0T/phG08SIbXZs="; }) - (fetchNuGet { pname = "System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-DL+D2sc2JrQiB4oAcUggTFyD8w3aLEjJfod5JPe+Oz4="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.0.0"; hash = "sha256-sEdPftfTxQd/8DpdpqUZC2XWC0SjVCPqAkEleLl17EQ="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.3.0"; hash = "sha256-fnFi7B3SnVj5a+BbgXnbjnGNvWrCEU6Hp/wjsjWz318="; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.1.0"; hash = "sha256-sBUUhJP+yYDXvcjNMKqNpn8yzGUpVABwK9vVUvYKjzI="; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.3.0"; hash = "sha256-MG3V/owDh273GCUPsGGraNwaVpcydupl3EtPXj6TVG0="; }) - (fetchNuGet { pname = "System.Security.Principal"; version = "4.3.0"; hash = "sha256-rjudVUHdo8pNJg2EVEn0XxxwNo5h2EaYo+QboPkXlYk="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.3.0"; hash = "sha256-mbdLVUcEwe78p3ZnB6jYsizNEqxMaCAWI3tEQNhRQAE="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.0.11"; hash = "sha256-PEailOvG05CVgPTyKLtpAgRydlSHmtd5K0Y8GSHY2Lc="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.0.11"; hash = "sha256-+kf7J3dEhgCbnCM5vHYlsTm5/R/Ud0Jr6elpHm922iI="; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; }) - (fetchNuGet { pname = "System.Text.RegularExpressions"; version = "4.1.0"; hash = "sha256-x6OQN6MCN7S0fJ6EFTfv4rczdUWjwuWE9QQ0P6fbh9c="; }) - (fetchNuGet { pname = "System.Text.RegularExpressions"; version = "4.3.0"; hash = "sha256-VLCk1D1kcN2wbAe3d0YQM/PqCsPHOuqlBY1yd2Yo+K0="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.0.11"; hash = "sha256-mob1Zv3qLQhQ1/xOLXZmYqpniNUMCfn02n8ZkaAhqac="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.0.11"; hash = "sha256-5SLxzFg1df6bTm2t09xeI01wa5qQglqUwwJNlQPJIVs="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.0.0"; hash = "sha256-+YdcPkMhZhRbMZHnfsDwpNbUkr31X7pQFGxXYcAPZbE="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.3.0"; hash = "sha256-X2hQ5j+fxcmnm88Le/kSavjiGOmkcumBGTZKBLvorPc="; }) - (fetchNuGet { pname = "System.Threading.Thread"; version = "4.3.0"; hash = "sha256-pMs6RNFC3nQOGz9EqIcyWmO8YLaqay+q/Qde5hqPXXg="; }) - (fetchNuGet { pname = "System.Threading.ThreadPool"; version = "4.3.0"; hash = "sha256-wW0QdvssRoaOfQLazTGSnwYTurE4R8FxDx70pYkL+gg="; }) - (fetchNuGet { pname = "System.Threading.Timer"; version = "4.3.0"; hash = "sha256-pmhslmhQhP32TWbBzoITLZ4BoORBqYk25OWbru04p9s="; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.0.11"; hash = "sha256-haZAFFQ9Sl2DhfvEbdx2YRqKEoxNMU5STaqpMmXw0zA="; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.3.0"; hash = "sha256-QQ8KgU0lu4F5Unh+TbechO//zaAGZ4MfgvW72Cn1hzA="; }) - (fetchNuGet { pname = "System.Xml.XDocument"; version = "4.3.0"; hash = "sha256-rWtdcmcuElNOSzCehflyKwHkDRpiOhJJs8CeQ0l1CCI="; }) - (fetchNuGet { pname = "System.Xml.XmlDocument"; version = "4.0.1"; hash = "sha256-gdoFrPo54v1LjkBF79f8EvtltVVjHz9ZI9kc5ve0GkY="; }) - (fetchNuGet { pname = "System.Xml.XmlDocument"; version = "4.3.0"; hash = "sha256-kbuV4Y7rVJkfMp2Kgoi8Zvdatm9CZNmlKB3GZgANvy4="; }) - (fetchNuGet { pname = "System.Xml.XmlSerializer"; version = "4.0.11"; hash = "sha256-v6x4d6W18dijG5cDqQmVHdtWRf6Y4OkdBolT3d5g3wY="; }) - (fetchNuGet { pname = "System.Xml.XmlSerializer"; version = "4.3.0"; hash = "sha256-IqTGPENWYoI06x2NHFPVtHlLEq9tazbom32bFLom6h4="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Dapper"; + version = "2.1.35"; + hash = "sha256-zeroySx7lO1yLtbhKhFQ87diWXOq9gPnv3qFcmNcs9M="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.JsonPatch"; + version = "8.0.5"; + hash = "sha256-i5VzC7peTKTiwjoqzlUFysyu7oUxBtf3bG/BZ6QYs/A="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.NewtonsoftJson"; + version = "8.0.5"; + hash = "sha256-8GX1oDCmWiX3t/gwpn2fVl3Pw3DdXgWru5refK8w+aw="; + }) + (fetchNuGet { + pname = "Microsoft.Azure.Amqp"; + version = "2.4.9"; + hash = "sha256-qmJGqOHjn1SofqiFuQ7qUuDOaDgX2cjnCOcE6iCde5Y="; + }) + (fetchNuGet { + pname = "Microsoft.Azure.ServiceBus"; + version = "4.2.1"; + hash = "sha256-RUfwCX0NMxKMXV7guVRWjmZOYEuxpFeabOeiA3TDfSo="; + }) + (fetchNuGet { + pname = "Microsoft.Azure.Services.AppAuthentication"; + version = "1.0.3"; + hash = "sha256-KaGL7asV10S+fGp9dt1i6frelho8ns73epxGzZ4iRis="; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.3.0"; + hash = "sha256-a3dAiPaVuky0wpcHmpTVtAQJNGZ2v91/oArA+dpJgj8="; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.7.0"; + hash = "sha256-Enknv2RsFF68lEPdrf5M+BpV1kHoLTVRApKUwuk/pj0="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "6.0.0"; + hash = "sha256-SIO/Q+OD2bG+Q0EoOXRgJYzZMhahGXDG1fXZn0VUvv0="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "6.0.0"; + hash = "sha256-Evg+Ynj2QUa6Gz+zqF+bUyfGD0HI5A2fHmxZEXbn3HA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; + version = "6.0.0"; + hash = "sha256-tG3DEWURVkQHm4MlmxjE/YouTp9wQKbWs6qHH2nfgqc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.FileExtensions"; + version = "6.0.0"; + hash = "sha256-PLnSa0JMfDC62OTv8sL0QFJbANE7QSnJ997ySFBS1go="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Ini"; + version = "6.0.0"; + hash = "sha256-5tUoqvIsWL5hfmMCpCpBW6V1tw/sMUCwfnm/7Y8LD6M="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.0"; + hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "6.0.0"; + hash = "sha256-uBjWjHKEXjZ9fDfFxMjOou3lhfTNhs1yO+e3fpWreLk="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Physical"; + version = "6.0.0"; + hash = "sha256-5BAQOqnaEXM2YjdrmrCinXBeZ5FKxCWtebEXMdwcbMY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileSystemGlobbing"; + version = "6.0.0"; + hash = "sha256-RAWHjkkfvGpjc49Q0kJbZyXgU6UEq/EJ0j557sj2/iU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "1.0.0"; + hash = "sha256-asIXVFsAK7ELd/f+vLwhxYDdazqRTmf+fGJ4WFtcCeo="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "6.0.0"; + hash = "sha256-QNqcQ3x+MOK7lXbWkCzSOWa/2QyYNbdM/OEEbWN15Sw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "8.0.0"; + hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "6.0.0"; + hash = "sha256-AgvysszpQ11AiTBJFkvSy8JnwIWTj15Pfek7T7ThUc4="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.Clients.ActiveDirectory"; + version = "3.14.2"; + hash = "sha256-mFlsKSQ6DsKttWuFkv6eMs0uSFHgwocxDad1icMXKj0="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.JsonWebTokens"; + version = "5.4.0"; + hash = "sha256-yKITMgW2JEXhPlQgdmofAyt0eEcCr72P4rM2EC6wrig="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.Logging"; + version = "5.4.0"; + hash = "sha256-YKdSKQDO5+ssC5mqLGtBhuJ4lLbLUadMVV4PPJ6/tMU="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.Tokens"; + version = "5.4.0"; + hash = "sha256-gCJ+4QwhuBPSkDN+HcMCpTE2LFIQ3htI/SddoHOB7T4="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.0.1"; + hash = "sha256-mZotlGZqtrqDSoBrZhsxFe6fuOv5/BIo0w2Z2x0zVAU="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.0.2"; + hash = "sha256-YLJ2+BONtCWb0lY4Rttdqzbcm4z+5N5uNr3byRWQOZ8="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.0.1"; + hash = "sha256-lxxw/Gy32xHi0fLgFWNj4YTFBSBkjx5l6ucmbTyf7V4="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.0.1"; + hash = "sha256-B4t5El/ViBdxALMcpZulewc4j/3SIXf71HhJWhm4Ctk="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.3.0"; + hash = "sha256-mBNDmPXNTW54XLnPAUwBRvkIORFM7/j0D0I2SyQPDEg="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "4.3.0"; + hash = "sha256-50XwFbyRfZkTD/bBn76WV/NIpOy/mzXD3MMEVFX/vr8="; + }) + (fetchNuGet { + pname = "NBitcoin"; + version = "7.0.37"; + hash = "sha256-RclQZgot+Y8PZi9JEX7tgUJinkIBXs1Qgf4vGR2y4rc="; + }) + (fetchNuGet { + pname = "NBitcoin.Altcoins"; + version = "3.0.24"; + hash = "sha256-MGxIuYtWPgSYj5JCMmZfP7u04ki/UpeN1+//gU6RsdI="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "1.6.1"; + hash = "sha256-iNan1ix7RtncGWC9AjAZ2sk70DoxOsmEOgQ10fXm4Pw="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "10.0.3"; + hash = "sha256-WEHCjp+OMr5axXQjFsh7TMDE/ttE35nMv5RBPdcxfhs="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.1"; + hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.3"; + hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json.Bson"; + version = "1.0.2"; + hash = "sha256-ZUj6YFSMZp5CZtXiamw49eZmbp1iYBuNsIKNnjxcRzA="; + }) + (fetchNuGet { + pname = "NicolasDorier.CommandLine"; + version = "2.0.0"; + hash = "sha256-LizYyIMx6I17jZd52duYcGWNgcPs88c/zWxo/ADd3D8="; + }) + (fetchNuGet { + pname = "NicolasDorier.CommandLine.Configuration"; + version = "2.0.0"; + hash = "sha256-fDpDOVdt7xCDXXqaBnbaFvUOPaE0Sl4cLWjNkU0Cz7I="; + }) + (fetchNuGet { + pname = "NicolasDorier.StandardConfiguration"; + version = "2.0.0"; + hash = "sha256-mwPvVaESUnou1qd0b6oSmQfBBz28LmQIb1EoSUZvqAA="; + }) + (fetchNuGet { + pname = "Npgsql"; + version = "8.0.3"; + hash = "sha256-weBGo/IXKI5ufixBCuWG7OqDSyIqvGV07oxrG0XnQIQ="; + }) + (fetchNuGet { + pname = "RabbitMQ.Client"; + version = "5.1.2"; + hash = "sha256-reYeBKsqfrdZZ4Nq4dsqLo1GNtcT2A0VuOIHtW3ttqQ="; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tools"; + version = "4.3.0"; + hash = "sha256-8yLKFt2wQxkEf7fNfzB+cPUCjYn2qbqNgQ1+EeY2h/I="; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-dsmTLGvt8HqRkDWP8iKVXJCS+akAzENGXKPV18W2RgI="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization.Calendars"; + version = "4.3.0"; + hash = "sha256-AYh39tgXJVFu8aLi9Y/4rK8yWMaza4S4eaxjfcuEEL4="; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-6MYj0RmLh4EVqMtO/MRqBi0HOn5iG4x9JimgCCJ+EFM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Timer"; + version = "4.3.0"; + hash = "sha256-BgHxXCIbicVZtpgMimSXixhFC3V+p5ODqeljDjO8hCs="; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.0.0"; + hash = "sha256-bmaM0ovT4X4aqDJOR255Yda/u3fmHZskU++lMnsy894="; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; + }) + (fetchNuGet { + pname = "runtime.native.System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-DWnXs4vlKoU6WxxvCArTJupV6sX3iBbZh8SbqfHace8="; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Http"; + version = "4.0.1"; + hash = "sha256-5nWnTQrA1T6t9r8MqIiV4yTNu+IH0of2OX1qteoS+8E="; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Http"; + version = "4.3.0"; + hash = "sha256-c556PyheRwpYhweBjSfIwEyZHnAUB8jWioyKEcp/2dg="; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Security"; + version = "4.3.0"; + hash = "sha256-I8vYld/7WtU2/rrD4XfSRgpO/DY3qXghG14VQjiU2DY="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography"; + version = "4.0.0"; + hash = "sha256-6Q8eYzC32BbGIiTHoQaE6B3cD81vYQcH5SCswYRSp0w="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + hash = "sha256-2IhBv0i6pTcOyr8FFIyfPEaaCHUmJZ8DYwLUwJ+5waw="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + hash = "sha256-serkd4A7F6eciPiPJtUyJyxzdAtupEcWIZQ9nptEzIM="; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; + }) + (fetchNuGet { + pname = "runtime.unix.Microsoft.Win32.Primitives"; + version = "4.3.0"; + hash = "sha256-LZb23lRXzr26tRS5aA0xyB08JxiblPDoA7HBvn6awXg="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Console"; + version = "4.3.0"; + hash = "sha256-AHkdKShTRHttqfMjmi+lPpTuCrM5vd/WRy6Kbtie190="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; + }) + (fetchNuGet { + pname = "runtime.unix.System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-Pf4mRl6YDK2x2KMh0WdyNgv0VUNdSKVDLlHqozecy5I="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Primitives"; + version = "4.3.0"; + hash = "sha256-pHJ+I6i16MV6m77uhTC6GPY6jWGReE3SSP3fVB59ti0="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Sockets"; + version = "4.3.0"; + hash = "sha256-IvgOeA2JuBjKl5yAVGjPYMPDzs9phb3KANs95H9v1w4="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; + }) + (fetchNuGet { + pname = "System.AppContext"; + version = "4.3.0"; + hash = "sha256-yg95LNQOwFlA1tWxXdQkVyJqT4AnoDc+ACmrNvzGiZg="; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.3.0"; + hash = "sha256-XqZWb4Kd04960h4U9seivjKseGA/YEIpdplfHYHQ9jk="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.0.11"; + hash = "sha256-puoFMkx4Z55C1XPxNw3np8nzNGjH+G24j43yTIsDRL0="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.0.12"; + hash = "sha256-zIEM7AB4SyE9u6G8+o+gCLLwkgi6+3rHQVPdn/dEwB8="; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.3.0"; + hash = "sha256-KMY5DfJnDeIsa13DpqvyN8NkReZEMAFnlmNglVoFIXI="; + }) + (fetchNuGet { + pname = "System.Collections.NonGeneric"; + version = "4.3.0"; + hash = "sha256-8/yZmD4jjvq7m68SPkJZLBQ79jOTOyT5lyzX4SCYAx8="; + }) + (fetchNuGet { + pname = "System.Collections.Specialized"; + version = "4.3.0"; + hash = "sha256-QNg0JJNx+zXMQ26MJRPzH7THdtqjrNtGLUgaR1SdvOk="; + }) + (fetchNuGet { + pname = "System.ComponentModel"; + version = "4.3.0"; + hash = "sha256-i00uujMO4JEDIEPKLmdLY3QJ6vdSpw6Gh9oOzkFYBiU="; + }) + (fetchNuGet { + pname = "System.ComponentModel.Primitives"; + version = "4.3.0"; + hash = "sha256-IOMJleuIBppmP4ECB3uftbdcgL7CCd56+oAD/Sqrbus="; + }) + (fetchNuGet { + pname = "System.ComponentModel.TypeConverter"; + version = "4.3.0"; + hash = "sha256-PSDiPYt8PgTdTUBz+GH6lHCaM1YgfObneHnZsc8Fz54="; + }) + (fetchNuGet { + pname = "System.Console"; + version = "4.3.0"; + hash = "sha256-Xh3PPBZr0pDbDaK8AEHbdGz7ePK6Yi1ZyRWI1JM6mbo="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.0.11"; + hash = "sha256-P+rSQJVoN6M56jQbs76kZ9G3mAWFdtF27P/RijN8sj4="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "4.5.1"; + hash = "sha256-gZEDRv0v0AAauQ36BWXkJk3GLW0sYH6QPxa0p2l8Dck="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Process"; + version = "4.3.0"; + hash = "sha256-Rzo24qXhuJDDgrGNHr2eQRHhwLmsYmWDqAg/P5fOlzw="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tools"; + version = "4.3.0"; + hash = "sha256-gVOv1SK6Ape0FQhCVlNOd9cvQKBvMxRX9K0JPVi8w0Y="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.1.0"; + hash = "sha256-JA0jJcLbU3zh52ub3zweob2EVHvxOqiC6SCYHrY5WbQ="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.3.0"; + hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.0.11"; + hash = "sha256-rbSgc2PIEc2c2rN6LK3qCREAX3DqA2Nq1WcLrZYsDBw="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.0.1"; + hash = "sha256-EJN3LbN+b0O9Dr2eg7kfThCYpne0iJ/H/GIyUTNVYC8="; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.3.0"; + hash = "sha256-uNOD0EOVFgnS2fMKvMiEtI9aOw00+Pfy/H+qucAQlPc="; + }) + (fetchNuGet { + pname = "System.Globalization.Extensions"; + version = "4.3.0"; + hash = "sha256-mmJWA27T0GRVuFP9/sj+4TrR4GJWrzNIk2PDrbr7RQk="; + }) + (fetchNuGet { + pname = "System.IdentityModel.Tokens.Jwt"; + version = "5.4.0"; + hash = "sha256-zLtoejPBG8yeFEPIcXZAkdAb0WDnrVXh5YsUYKULyRU="; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.1.0"; + hash = "sha256-V6oyQFwWb8NvGxAwvzWnhPxy9dKOfj/XBM3tEC5aHrw="; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; + }) + (fetchNuGet { + pname = "System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; + }) + (fetchNuGet { + pname = "System.IO.Compression.ZipFile"; + version = "4.3.0"; + hash = "sha256-WQl+JgWs+GaRMeiahTFUbrhlXIHapzcpTFXbRvAtvvs="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.0.1"; + hash = "sha256-4VKXFgcGYCTWVXjAlniAVq0dO3o5s8KHylg2wg2/7k0="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.0.1"; + hash = "sha256-IpigKMomqb6pmYWkrlf0ZdpILtRluX2cX5sOKVW0Feg="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.1.0"; + hash = "sha256-ZQpFtYw5N1F1aX0jUK3Tw+XvM5tnlnshkTCNtfVA794="; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.3.0"; + hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; + }) + (fetchNuGet { + pname = "System.Net.Http"; + version = "4.3.0"; + hash = "sha256-UoBB7WPDp2Bne/fwxKF0nE8grJ6FzTMXdT/jfsphj8Q="; + }) + (fetchNuGet { + pname = "System.Net.NameResolution"; + version = "4.3.0"; + hash = "sha256-eGZwCBExWsnirWBHyp2sSSSXp6g7I6v53qNmwPgtJ5c="; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.0.11"; + hash = "sha256-2YSijNhCdw/ZU2yfH7vE+ReA8pgxRCXPnWr+ab36v4M="; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.3.0"; + hash = "sha256-MY7Z6vOtFMbEKaLW9nOSZeAjcWpwCtdO7/W1mkGZBzE="; + }) + (fetchNuGet { + pname = "System.Net.Security"; + version = "4.3.0"; + hash = "sha256-B7laE1z1+ldbo6JkjlDjZynG5JiMZ/3uNHPHMP6LRak="; + }) + (fetchNuGet { + pname = "System.Net.Sockets"; + version = "4.3.0"; + hash = "sha256-il7dr5VT/QWDg/0cuh+4Es2u8LY//+qqiY9BZmYxSus="; + }) + (fetchNuGet { + pname = "System.Net.WebHeaderCollection"; + version = "4.0.1"; + hash = "sha256-uJSV6kmL+V/9/ot1LhHXGCd8Ndcu6zk+AJ8wgGS/fYE="; + }) + (fetchNuGet { + pname = "System.Net.WebHeaderCollection"; + version = "4.3.0"; + hash = "sha256-wpRP3D/2YjpFmqU7Q42L/+/hChEVMlwU1sjysGVrQ1c="; + }) + (fetchNuGet { + pname = "System.Net.WebSockets"; + version = "4.0.0"; + hash = "sha256-YhLVuTPyEiHAjdBMHyIobGpysDbAtgZNDX2Q2xKGTRI="; + }) + (fetchNuGet { + pname = "System.Net.WebSockets"; + version = "4.3.0"; + hash = "sha256-l3h3cF1cCC9zMhWLKSDnZBZvFADUd0Afe2+iAwBA0r0="; + }) + (fetchNuGet { + pname = "System.Net.WebSockets.Client"; + version = "4.0.2"; + hash = "sha256-miyjFY0E49/rtWDOF7QR26jJlYn3WRiQQOonSBJMFV0="; + }) + (fetchNuGet { + pname = "System.Net.WebSockets.Client"; + version = "4.3.2"; + hash = "sha256-MwNKwIIpBJhC4Na6EYWMmVyPCa064Yp1aL0opx1FfoA="; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.3.0"; + hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; + }) + (fetchNuGet { + pname = "System.Private.DataContractSerialization"; + version = "4.1.1"; + hash = "sha256-OaE+ZcEfkpIkbdMOMAMiJa9vgiVP25FGuFrf+N/mafY="; + }) + (fetchNuGet { + pname = "System.Private.DataContractSerialization"; + version = "4.3.0"; + hash = "sha256-vNlHUKkaFvhiVnTY0JNsNT5E6TW9CFRzTqVcufGN0hk="; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.1.0"; + hash = "sha256-idZHGH2Yl/hha1CM4VzLhsaR8Ljo/rV7TYe7mwRJSMs="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.0.1"; + hash = "sha256-F1MvYoQWHCY89/O4JBwswogitqVvKuVfILFqA7dmuHk="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.3.0"; + hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.0.1"; + hash = "sha256-YG+eJBG5P+5adsHiw/lhJwvREnvdHw6CJyS8ZV4Ujd0="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.3.0"; + hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.0.1"; + hash = "sha256-uVvNOnL64CPqsgZP2OLqNmxdkZl6Q0fTmKmv9gcBi+g="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.3.0"; + hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.0.1"; + hash = "sha256-NsfmzM9G/sN3H8X2cdnheTGRsh7zbRzvegnjDzDH/FQ="; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.0.1"; + hash = "sha256-SFSfpWEyCBMAOerrMCOiKnpT+UAWTvRcmoRquJR6Vq0="; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.1.0"; + hash = "sha256-R0YZowmFda+xzKNR4kKg7neFoE30KfZwp/IwfRSKVK4="; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.3.0"; + hash = "sha256-4U4/XNQAnddgQIHIJq3P2T80hN0oPdU2uCeghsDTWng="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.0.1"; + hash = "sha256-cZ2/3/fczLjEpn6j3xkgQV9ouOVjy4Kisgw5xWw9kSw="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.1.0"; + hash = "sha256-FViNGM/4oWtlP6w0JC0vJU+k9efLKZ+yaXrnEeabDQo="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.1.0"; + hash = "sha256-X7DZ5CbPY7jHs20YZ7bmcXs9B5Mxptu/HnBUvUnNhGc="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.0.1"; + hash = "sha256-j2QgVO9ZOjv7D1het98CoFpjoYgxjupuIhuBUmLLH7w="; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.1.0"; + hash = "sha256-QceAYlJvkPRJc/+5jR+wQpNNI3aqGySWWSO30e/FfQY="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices.RuntimeInformation"; + version = "4.3.0"; + hash = "sha256-MYpl6/ZyC6hjmzWRIe+iDoldOMW1mfbwXsduAnXIKGA="; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.0.1"; + hash = "sha256-1pJt5ZGxLPTX1mjOi8qZPXyyOMkYV0NstoUCv91HYPg="; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.3.0"; + hash = "sha256-P5jHCgMbgFMYiONvzmaKFeOqcAIDPu/U8bOVrNPYKqc="; + }) + (fetchNuGet { + pname = "System.Runtime.Serialization.Formatters"; + version = "4.3.0"; + hash = "sha256-Feic7MGKVG4imh7kpLkPHmApQzYjq7SxHnazh2wZkoQ="; + }) + (fetchNuGet { + pname = "System.Runtime.Serialization.Json"; + version = "4.0.2"; + hash = "sha256-thmzgYbyxoPYtkDdDwoG7wnVuVhFNwLUE2AsDfRf1yM="; + }) + (fetchNuGet { + pname = "System.Runtime.Serialization.Primitives"; + version = "4.1.1"; + hash = "sha256-80B05oxJbPLGq2pGOSl6NlZvintX9A1CNpna2aN0WRA="; + }) + (fetchNuGet { + pname = "System.Runtime.Serialization.Primitives"; + version = "4.3.0"; + hash = "sha256-zu5m1M9usend+i9sbuD6Xbizdo8Z6N5PEF9DAtEVewc="; + }) + (fetchNuGet { + pname = "System.Runtime.Serialization.Xml"; + version = "4.3.0"; + hash = "sha256-0bp8xtv2cP/IuxaBF8xkyYYD8N6w1wVX8wzpAwXtTKw="; + }) + (fetchNuGet { + pname = "System.Security.Claims"; + version = "4.3.0"; + hash = "sha256-Fua/rDwAqq4UByRVomAxMPmDBGd5eImRqHVQIeSxbks="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.2.0"; + hash = "sha256-BelNIpEyToEp/VYKnje/q1P7KNEpQNtOzGPU18pLGpE="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.3.0"; + hash = "sha256-tAJvNSlczYBJ3Ed24Ae27a55tq/n4D3fubNQdwcKWA8="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.2.0"; + hash = "sha256-7F+m3HnmBsgE4xWF8FeCGlaEgQM3drqA6HEaQr6MEoU="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.3.0"; + hash = "sha256-u17vy6wNhqok91SrVLno2M1EzLHZm6VMca85xbVChsw="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Csp"; + version = "4.0.0"; + hash = "sha256-WHyR6vVK3zaT4De7jgQFUar1P5fiX9ECwiVkJDFFm7M="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Csp"; + version = "4.3.0"; + hash = "sha256-oefdTU/Z2PWU9nlat8uiRDGq/PGZoSPRgkML11pmvPQ="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.0.0"; + hash = "sha256-ZO7ha39J5uHkIF2RoEKv/bW/bLbVvYMO4+rWyYsKHik="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.3.0"; + hash = "sha256-Yuge89N6M+NcblcvXMeyHZ6kZDfwBv3LPMDiF8HhJss="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.OpenSsl"; + version = "4.0.0"; + hash = "sha256-mLijAozynzjiOMyh2P5BHcfVq3Ovd0T/phG08SIbXZs="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-DL+D2sc2JrQiB4oAcUggTFyD8w3aLEjJfod5JPe+Oz4="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.0.0"; + hash = "sha256-sEdPftfTxQd/8DpdpqUZC2XWC0SjVCPqAkEleLl17EQ="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.3.0"; + hash = "sha256-fnFi7B3SnVj5a+BbgXnbjnGNvWrCEU6Hp/wjsjWz318="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.1.0"; + hash = "sha256-sBUUhJP+yYDXvcjNMKqNpn8yzGUpVABwK9vVUvYKjzI="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.3.0"; + hash = "sha256-MG3V/owDh273GCUPsGGraNwaVpcydupl3EtPXj6TVG0="; + }) + (fetchNuGet { + pname = "System.Security.Principal"; + version = "4.3.0"; + hash = "sha256-rjudVUHdo8pNJg2EVEn0XxxwNo5h2EaYo+QboPkXlYk="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.3.0"; + hash = "sha256-mbdLVUcEwe78p3ZnB6jYsizNEqxMaCAWI3tEQNhRQAE="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.0.11"; + hash = "sha256-PEailOvG05CVgPTyKLtpAgRydlSHmtd5K0Y8GSHY2Lc="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.0.11"; + hash = "sha256-+kf7J3dEhgCbnCM5vHYlsTm5/R/Ud0Jr6elpHm922iI="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; + }) + (fetchNuGet { + pname = "System.Text.RegularExpressions"; + version = "4.1.0"; + hash = "sha256-x6OQN6MCN7S0fJ6EFTfv4rczdUWjwuWE9QQ0P6fbh9c="; + }) + (fetchNuGet { + pname = "System.Text.RegularExpressions"; + version = "4.3.0"; + hash = "sha256-VLCk1D1kcN2wbAe3d0YQM/PqCsPHOuqlBY1yd2Yo+K0="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.0.11"; + hash = "sha256-mob1Zv3qLQhQ1/xOLXZmYqpniNUMCfn02n8ZkaAhqac="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.0.11"; + hash = "sha256-5SLxzFg1df6bTm2t09xeI01wa5qQglqUwwJNlQPJIVs="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.0.0"; + hash = "sha256-+YdcPkMhZhRbMZHnfsDwpNbUkr31X7pQFGxXYcAPZbE="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.3.0"; + hash = "sha256-X2hQ5j+fxcmnm88Le/kSavjiGOmkcumBGTZKBLvorPc="; + }) + (fetchNuGet { + pname = "System.Threading.Thread"; + version = "4.3.0"; + hash = "sha256-pMs6RNFC3nQOGz9EqIcyWmO8YLaqay+q/Qde5hqPXXg="; + }) + (fetchNuGet { + pname = "System.Threading.ThreadPool"; + version = "4.3.0"; + hash = "sha256-wW0QdvssRoaOfQLazTGSnwYTurE4R8FxDx70pYkL+gg="; + }) + (fetchNuGet { + pname = "System.Threading.Timer"; + version = "4.3.0"; + hash = "sha256-pmhslmhQhP32TWbBzoITLZ4BoORBqYk25OWbru04p9s="; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.0.11"; + hash = "sha256-haZAFFQ9Sl2DhfvEbdx2YRqKEoxNMU5STaqpMmXw0zA="; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.3.0"; + hash = "sha256-QQ8KgU0lu4F5Unh+TbechO//zaAGZ4MfgvW72Cn1hzA="; + }) + (fetchNuGet { + pname = "System.Xml.XDocument"; + version = "4.3.0"; + hash = "sha256-rWtdcmcuElNOSzCehflyKwHkDRpiOhJJs8CeQ0l1CCI="; + }) + (fetchNuGet { + pname = "System.Xml.XmlDocument"; + version = "4.0.1"; + hash = "sha256-gdoFrPo54v1LjkBF79f8EvtltVVjHz9ZI9kc5ve0GkY="; + }) + (fetchNuGet { + pname = "System.Xml.XmlDocument"; + version = "4.3.0"; + hash = "sha256-kbuV4Y7rVJkfMp2Kgoi8Zvdatm9CZNmlKB3GZgANvy4="; + }) + (fetchNuGet { + pname = "System.Xml.XmlSerializer"; + version = "4.0.11"; + hash = "sha256-v6x4d6W18dijG5cDqQmVHdtWRf6Y4OkdBolT3d5g3wY="; + }) + (fetchNuGet { + pname = "System.Xml.XmlSerializer"; + version = "4.3.0"; + hash = "sha256-IqTGPENWYoI06x2NHFPVtHlLEq9tazbom32bFLom6h4="; + }) ] diff --git a/pkgs/by-name/nb/nbxplorer/package.nix b/pkgs/by-name/nb/nbxplorer/package.nix index b7e75efea2e5be..bda82fc536378a 100644 --- a/pkgs/by-name/nb/nbxplorer/package.nix +++ b/pkgs/by-name/nb/nbxplorer/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildDotnetModule -, fetchFromGitHub -, dotnetCorePackages +{ + lib, + buildDotnetModule, + fetchFromGitHub, + dotnetCorePackages, }: buildDotnetModule rec { @@ -28,7 +29,10 @@ buildDotnetModule rec { meta = with lib; { description = "Minimalist UTXO tracker for HD Cryptocurrency Wallets"; - maintainers = with maintainers; [ kcalvinalvin erikarvstedt ]; + maintainers = with maintainers; [ + kcalvinalvin + erikarvstedt + ]; license = licenses.mit; platforms = platforms.linux ++ platforms.darwin; mainProgram = "nbxplorer"; diff --git a/pkgs/by-name/nc/ncdc/package.nix b/pkgs/by-name/nc/ncdc/package.nix index 912bd60b3b6562..b1d313868100bb 100644 --- a/pkgs/by-name/nc/ncdc/package.nix +++ b/pkgs/by-name/nc/ncdc/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, ncurses -, zlib -, bzip2 -, sqlite -, pkg-config -, glib -, gnutls -, perl -, libmaxminddb +{ + lib, + stdenv, + fetchurl, + ncurses, + zlib, + bzip2, + sqlite, + pkg-config, + glib, + gnutls, + perl, + libmaxminddb, }: stdenv.mkDerivation (finalAttrs: { @@ -21,8 +22,19 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-Koq5rX1D8Bj8c7qLq9aJ36RKuozsU7iOR3AYXLl3ePc="; }; - nativeBuildInputs = [ perl pkg-config ]; - buildInputs = [ ncurses zlib bzip2 sqlite glib gnutls libmaxminddb ]; + nativeBuildInputs = [ + perl + pkg-config + ]; + buildInputs = [ + ncurses + zlib + bzip2 + sqlite + glib + gnutls + libmaxminddb + ]; configureFlags = [ "--with-geoip" ]; diff --git a/pkgs/by-name/nc/ncdns/package.nix b/pkgs/by-name/nc/ncdns/package.nix index 1f896ec21a5c0c..a603b9674f029d 100644 --- a/pkgs/by-name/nc/ncdns/package.nix +++ b/pkgs/by-name/nc/ncdns/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchpatch -, buildGoModule -, fetchFromGitHub -, nixosTests -, libcap -, go +{ + lib, + stdenv, + fetchpatch, + buildGoModule, + fetchFromGitHub, + nixosTests, + libcap, + go, }: let @@ -83,7 +84,7 @@ buildGoModule { buildInputs = [ libcap ]; - patches = [./fix-tpl-path.patch ]; + patches = [ ./fix-tpl-path.patch ]; # Put in our own lockfiles postPatch = '' diff --git a/pkgs/by-name/nc/ncftp/package.nix b/pkgs/by-name/nc/ncftp/package.nix index 883d2e48afe39f..01eef692a2daf1 100644 --- a/pkgs/by-name/nc/ncftp/package.nix +++ b/pkgs/by-name/nc/ncftp/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, ncurses, coreutils }: +{ + lib, + stdenv, + fetchurl, + ncurses, + coreutils, +}: stdenv.mkDerivation rec { pname = "ncftp"; @@ -17,12 +23,14 @@ stdenv.mkDerivation rec { # gcc-10. Otherwise build fails as: # ld: bookmark.o: (.bss+0x20): multiple definition of `gBm'; # gpshare.o:(.bss+0x0): first defined here - env.NIX_CFLAGS_COMPILE = toString ([ "-fcommon" ] + env.NIX_CFLAGS_COMPILE = toString ( + [ "-fcommon" ] # these are required for the configure script to work with clang ++ lib.optionals stdenv.hostPlatform.isDarwin [ "-Wno-implicit-int" "-Wno-implicit-function-declaration" - ]); + ] + ); preConfigure = '' find -name Makefile.in | xargs sed -i '/^TMPDIR=/d' diff --git a/pkgs/by-name/nc/ncgopher/package.nix b/pkgs/by-name/nc/ncgopher/package.nix index 4d2f72c35439d6..95f12be4bb1ce1 100644 --- a/pkgs/by-name/nc/ncgopher/package.nix +++ b/pkgs/by-name/nc/ncgopher/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, ncurses6 -, openssl -, sqlite +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + ncurses6, + openssl, + sqlite, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/nc/ncmpcpp/package.nix b/pkgs/by-name/nc/ncmpcpp/package.nix index 3f5baff5963ebc..3d15f22943c9d1 100644 --- a/pkgs/by-name/nc/ncmpcpp/package.nix +++ b/pkgs/by-name/nc/ncmpcpp/package.nix @@ -52,15 +52,17 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - boost - libmpdclient - ncurses - readline - libiconv - icu - curl - ] ++ lib.optional visualizerSupport fftw + buildInputs = + [ + boost + libmpdclient + ncurses + readline + libiconv + icu + curl + ] + ++ lib.optional visualizerSupport fftw ++ lib.optional taglibSupport taglib; preConfigure = @@ -73,7 +75,7 @@ stdenv.mkDerivation rec { --replace-fail "std=c++20" "std=c++17" ''; - meta = { + meta = { description = "Featureful ncurses based MPD client inspired by ncmpc"; homepage = "https://rybczak.net/ncmpcpp/"; changelog = "https://github.com/ncmpcpp/ncmpcpp/blob/${version}/CHANGELOG.md"; diff --git a/pkgs/by-name/nc/ncnn/package.nix b/pkgs/by-name/nc/ncnn/package.nix index f431133c250579..b1f819cdee193d 100644 --- a/pkgs/by-name/nc/ncnn/package.nix +++ b/pkgs/by-name/nc/ncnn/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, vulkan-headers -, vulkan-loader -, glslang -, opencv -, protobuf +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + vulkan-headers, + vulkan-loader, + glslang, + opencv, + protobuf, }: stdenv.mkDerivation rec { @@ -24,21 +25,28 @@ stdenv.mkDerivation rec { ./cmakelists.patch ]; - cmakeFlags = [ - "-DNCNN_CMAKE_VERBOSE=1" # Only for debugging the build - "-DNCNN_SHARED_LIB=1" - "-DNCNN_ENABLE_LTO=1" - "-DNCNN_VULKAN=1" - "-DNCNN_BUILD_EXAMPLES=0" - "-DNCNN_BUILD_TOOLS=0" - "-DNCNN_SYSTEM_GLSLANG=1" - "-DNCNN_PYTHON=0" # Should be an attribute - ] - # Requires setting `Vulkan_LIBRARY` on Darwin. Otherwise the build fails due to missing symbols. - ++ lib.optionals stdenv.hostPlatform.isDarwin [ "-DVulkan_LIBRARY=-lvulkan" ]; + cmakeFlags = + [ + "-DNCNN_CMAKE_VERBOSE=1" # Only for debugging the build + "-DNCNN_SHARED_LIB=1" + "-DNCNN_ENABLE_LTO=1" + "-DNCNN_VULKAN=1" + "-DNCNN_BUILD_EXAMPLES=0" + "-DNCNN_BUILD_TOOLS=0" + "-DNCNN_SYSTEM_GLSLANG=1" + "-DNCNN_PYTHON=0" # Should be an attribute + ] + # Requires setting `Vulkan_LIBRARY` on Darwin. Otherwise the build fails due to missing symbols. + ++ lib.optionals stdenv.hostPlatform.isDarwin [ "-DVulkan_LIBRARY=-lvulkan" ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ vulkan-headers vulkan-loader glslang opencv protobuf ]; + buildInputs = [ + vulkan-headers + vulkan-loader + glslang + opencv + protobuf + ]; meta = with lib; { description = "ncnn is a high-performance neural network inference framework optimized for the mobile platform"; diff --git a/pkgs/by-name/nc/nco/package.nix b/pkgs/by-name/nc/nco/package.nix index 22cc45f0447f86..ab8a316c4e14ba 100644 --- a/pkgs/by-name/nc/nco/package.nix +++ b/pkgs/by-name/nc/nco/package.nix @@ -1,16 +1,17 @@ -{ antlr2 -, coreutils -, curl -, fetchFromGitHub -, flex -, gsl -, lib -, libtool -, netcdf -, netcdfcxx4 -, stdenv -, udunits -, which +{ + antlr2, + coreutils, + curl, + fetchFromGitHub, + flex, + gsl, + lib, + libtool, + netcdf, + netcdfcxx4, + stdenv, + udunits, + which, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/nc/ncompress/package.nix b/pkgs/by-name/nc/ncompress/package.nix index bb8084ac013a60..4baac00754eeb1 100644 --- a/pkgs/by-name/nc/ncompress/package.nix +++ b/pkgs/by-name/nc/ncompress/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "ncompress"; diff --git a/pkgs/by-name/nc/ncpamixer/package.nix b/pkgs/by-name/nc/ncpamixer/package.nix index 77519fde31c597..b519d5585e959f 100644 --- a/pkgs/by-name/nc/ncpamixer/package.nix +++ b/pkgs/by-name/nc/ncpamixer/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl, cmake, ncurses, libpulseaudio, pandoc, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + cmake, + ncurses, + libpulseaudio, + pandoc, + pkg-config, +}: stdenv.mkDerivation rec { pname = "ncpamixer"; @@ -15,19 +25,28 @@ stdenv.mkDerivation rec { ./remove_dynamic_download.patch ]; - postPatch = let - PandocMan = fetchurl { - url = "https://github.com/rnpgp/cmake-modules/raw/387084811ee01a69911fe86bcc644b7ed8ad6304/PandocMan.cmake"; - hash = "sha256-KI55Yc2IuQtmbptqkk6Hzr75gIE/uQdUbQsm/fDpaWg="; - }; - in '' - substituteInPlace src/CMakeLists.txt \ - --replace "include(PandocMan)" "include(${PandocMan})" - ''; - - nativeBuildInputs = [ cmake pandoc pkg-config ]; + postPatch = + let + PandocMan = fetchurl { + url = "https://github.com/rnpgp/cmake-modules/raw/387084811ee01a69911fe86bcc644b7ed8ad6304/PandocMan.cmake"; + hash = "sha256-KI55Yc2IuQtmbptqkk6Hzr75gIE/uQdUbQsm/fDpaWg="; + }; + in + '' + substituteInPlace src/CMakeLists.txt \ + --replace "include(PandocMan)" "include(${PandocMan})" + ''; + + nativeBuildInputs = [ + cmake + pandoc + pkg-config + ]; - buildInputs = [ ncurses libpulseaudio ]; + buildInputs = [ + ncurses + libpulseaudio + ]; configurePhase = '' make PREFIX=$out USE_WIDE=1 RELEASE=1 build/Makefile diff --git a/pkgs/by-name/nc/ncrack/package.nix b/pkgs/by-name/nc/ncrack/package.nix index bfce4dd3712312..2df00ec4c89422 100644 --- a/pkgs/by-name/nc/ncrack/package.nix +++ b/pkgs/by-name/nc/ncrack/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, openssl, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + openssl, + zlib, +}: stdenv.mkDerivation rec { pname = "ncrack"; @@ -24,7 +31,10 @@ stdenv.mkDerivation rec { # Our version is good; the check is bad. configureFlags = [ "--without-zlib-version-check" ]; - buildInputs = [ openssl zlib ]; + buildInputs = [ + openssl + zlib + ]; meta = with lib; { description = "Network authentication tool"; diff --git a/pkgs/by-name/nc/ncview/package.nix b/pkgs/by-name/nc/ncview/package.nix index fcfb6661f31014..7dc9288bbda658 100644 --- a/pkgs/by-name/nc/ncview/package.nix +++ b/pkgs/by-name/nc/ncview/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, expat -, libpng -, udunits -, netcdf -, xorg +{ + lib, + stdenv, + fetchurl, + expat, + libpng, + udunits, + netcdf, + xorg, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/nd/ndisc6/package.nix b/pkgs/by-name/nd/ndisc6/package.nix index e4df6551184bb2..f89a89164b8aa4 100644 --- a/pkgs/by-name/nd/ndisc6/package.nix +++ b/pkgs/by-name/nd/ndisc6/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "ndisc6"; diff --git a/pkgs/by-name/nd/ndjbdns/package.nix b/pkgs/by-name/nd/ndjbdns/package.nix index 5619c5b5c37bf3..5d330ed1ab0e36 100644 --- a/pkgs/by-name/nd/ndjbdns/package.nix +++ b/pkgs/by-name/nd/ndjbdns/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, systemd, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + systemd, + pkg-config, +}: stdenv.mkDerivation { version = "1.06"; @@ -11,9 +18,11 @@ stdenv.mkDerivation { sha256 = "0gjyvn8r66kp49gasd6sqfvg2pj0c6v67hnq7cqwl04kj69rfy86"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ ] - ++ lib.optional stdenv.hostPlatform.isLinux systemd; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ ] ++ lib.optional stdenv.hostPlatform.isLinux systemd; meta = with lib; { description = "Brand new release of the Djbdns"; diff --git a/pkgs/by-name/nd/ndpi/package.nix b/pkgs/by-name/nd/ndpi/package.nix index 7ede8a409c3b14..6bc064fafbfe3a 100644 --- a/pkgs/by-name/nd/ndpi/package.nix +++ b/pkgs/by-name/nd/ndpi/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, json_c -, libpcap -, libtool -, pkg-config -, which +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + json_c, + libpcap, + libtool, + pkg-config, + which, }: stdenv.mkDerivation (finalAttrs: { @@ -39,7 +40,10 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://www.ntop.org/products/deep-packet-inspection/ndpi/"; changelog = "https://github.com/ntop/nDPI/blob/${finalAttrs.version}/CHANGELOG.md"; - license = with licenses; [ lgpl3Plus bsd3 ]; + license = with licenses; [ + lgpl3Plus + bsd3 + ]; maintainers = with maintainers; [ takikawa ]; mainProgram = "ndpiReader"; platforms = with platforms; unix; diff --git a/pkgs/by-name/nd/ndstool/package.nix b/pkgs/by-name/nd/ndstool/package.nix index 6a61ff825ff2ef..5c3fcf4eaeb3d0 100644 --- a/pkgs/by-name/nd/ndstool/package.nix +++ b/pkgs/by-name/nd/ndstool/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, +}: stdenv.mkDerivation rec { pname = "ndstool"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-121xEmbt1WBR1wi4RLw9/iLHqkpyXImXKiCNnLCYnJs="; }; - nativeBuildInputs = [ autoconf automake ]; + nativeBuildInputs = [ + autoconf + automake + ]; preConfigure = "./autogen.sh"; diff --git a/pkgs/by-name/nd/ndstrim/package.nix b/pkgs/by-name/nd/ndstrim/package.nix index edf35039388a92..92926263622ef6 100644 --- a/pkgs/by-name/nd/ndstrim/package.nix +++ b/pkgs/by-name/nd/ndstrim/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, rustPlatform +{ + lib, + fetchFromGitHub, + fetchpatch, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ne/ne/package.nix b/pkgs/by-name/ne/ne/package.nix index 7a3244dba84ec9..83a755ad2735fd 100644 --- a/pkgs/by-name/ne/ne/package.nix +++ b/pkgs/by-name/ne/ne/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, ncurses, texinfo6, texliveMedium, perl, ghostscript }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + texinfo6, + texliveMedium, + perl, + ghostscript, +}: stdenv.mkDerivation rec { pname = "ne"; @@ -16,7 +25,12 @@ stdenv.mkDerivation rec { substituteInPlace src/makefile --replace "-lcurses" "-lncurses" ''; - nativeBuildInputs = [ texliveMedium texinfo6 perl ghostscript ]; + nativeBuildInputs = [ + texliveMedium + texinfo6 + perl + ghostscript + ]; buildInputs = [ ncurses ]; makeFlags = [ "PREFIX=${placeholder "out"}" ]; diff --git a/pkgs/by-name/ne/near-cli/package.nix b/pkgs/by-name/ne/near-cli/package.nix index 8741f694782cd0..dfce986e94ed91 100644 --- a/pkgs/by-name/ne/near-cli/package.nix +++ b/pkgs/by-name/ne/near-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, mkYarnPackage -, fetchFromGitHub -, fetchYarnDeps +{ + lib, + mkYarnPackage, + fetchFromGitHub, + fetchYarnDeps, }: mkYarnPackage rec { @@ -42,7 +43,10 @@ mkYarnPackage rec { changelog = "https://github.com/near/near-cli/blob/${src.rev}/CHANGELOG.md"; description = "General purpose command line tools for interacting with NEAR Protocol"; homepage = "https://github.com/near/near-cli"; - license = with lib.licenses; [ asl20 mit ]; + license = with lib.licenses; [ + asl20 + mit + ]; mainProgram = "near"; maintainers = with lib.maintainers; [ ekleog ]; }; diff --git a/pkgs/by-name/ne/nearcore/package.nix b/pkgs/by-name/ne/nearcore/package.nix index 46fbc289bde35e..3d3952a4d8c3d1 100644 --- a/pkgs/by-name/ne/nearcore/package.nix +++ b/pkgs/by-name/ne/nearcore/package.nix @@ -1,6 +1,11 @@ -{ rustPlatform, lib, fetchFromGitHub -, zlib, openssl -, pkg-config, protobuf +{ + rustPlatform, + lib, + fetchFromGitHub, + zlib, + openssl, + pkg-config, + protobuf, }: rustPlatform.buildRustPackage rec { pname = "nearcore"; diff --git a/pkgs/by-name/ne/neard/package.nix b/pkgs/by-name/ne/neard/package.nix index d82043f2f5e0f2..71853a3f37696f 100644 --- a/pkgs/by-name/ne/neard/package.nix +++ b/pkgs/by-name/ne/neard/package.nix @@ -1,22 +1,26 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, autoconf-archive -, gobject-introspection -, pkg-config -, wrapGAppsHook3 -, glib -, dbus -, libnl -, python3Packages +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + autoconf-archive, + gobject-introspection, + pkg-config, + wrapGAppsHook3, + glib, + dbus, + libnl, + python3Packages, }: stdenv.mkDerivation { pname = "neard"; version = "0.19-unstable-2024-07-02"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "linux-nfc"; diff --git a/pkgs/by-name/ne/neardal/package.nix b/pkgs/by-name/ne/neardal/package.nix index 243c9b81bbe119..b1aa85d1f173e5 100644 --- a/pkgs/by-name/ne/neardal/package.nix +++ b/pkgs/by-name/ne/neardal/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, pkg-config, glib, readline, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + pkg-config, + glib, + readline, + makeWrapper, +}: stdenv.mkDerivation { pname = "neardal"; @@ -11,8 +21,16 @@ stdenv.mkDerivation { sha256 = "12qwg7qiw2wfpaxfg2fjkmj5lls0g33xp6w433g8bnkvwlq4s29g"; }; - nativeBuildInputs = [ pkg-config makeWrapper autoconf automake ]; - buildInputs = [ glib readline ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + autoconf + automake + ]; + buildInputs = [ + glib + readline + ]; preConfigure = '' substituteInPlace "ncl/Makefile.am" --replace "noinst_PROGRAMS" "bin_PROGRAMS" @@ -20,7 +38,10 @@ stdenv.mkDerivation { sh autogen.sh ''; - configureFlags = [ "--disable-dependency-tracking" "--disable-traces" ]; + configureFlags = [ + "--disable-dependency-tracking" + "--disable-traces" + ]; meta = with lib; { broken = true; # 2022-11-13 diff --git a/pkgs/by-name/ne/nebula/package.nix b/pkgs/by-name/ne/nebula/package.nix index b1db2b02b8e067..4050345ea6ae3e 100644 --- a/pkgs/by-name/ne/nebula/package.nix +++ b/pkgs/by-name/ne/nebula/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { @@ -17,7 +18,10 @@ buildGoModule rec { vendorHash = "sha256-oXhq+s5gDKPVClZpOzYi7BaYwcDqbCLBEO5BNGy9LJA="; - subPackages = [ "cmd/nebula" "cmd/nebula-cert" ]; + subPackages = [ + "cmd/nebula" + "cmd/nebula-cert" + ]; ldflags = [ "-X main.Build=${version}" ]; @@ -45,6 +49,9 @@ buildGoModule rec { homepage = "https://github.com/slackhq/nebula"; changelog = "https://github.com/slackhq/nebula/blob/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ Br1ght0ne numinit ]; + maintainers = with maintainers; [ + Br1ght0ne + numinit + ]; }; } diff --git a/pkgs/by-name/ne/nedit/package.nix b/pkgs/by-name/ne/nedit/package.nix index d329220409c3e4..f3809053300fb1 100644 --- a/pkgs/by-name/ne/nedit/package.nix +++ b/pkgs/by-name/ne/nedit/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, motif, libXpm, libXt }: +{ + lib, + stdenv, + fetchurl, + motif, + libXpm, + libXt, +}: stdenv.mkDerivation rec { pname = "nedit"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { hardeningDisable = [ "format" ]; - buildInputs = [ motif libXpm libXt ]; + buildInputs = [ + motif + libXpm + libXt + ]; # the linux config works fine on darwin too! buildFlags = lib.optional (stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isDarwin) "linux"; diff --git a/pkgs/by-name/ne/neil/package.nix b/pkgs/by-name/ne/neil/package.nix index 4be548a8fec596..8aa5c7b85fea4e 100644 --- a/pkgs/by-name/ne/neil/package.nix +++ b/pkgs/by-name/ne/neil/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, babashka +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + babashka, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ne/neko/package.nix b/pkgs/by-name/ne/neko/package.nix index 7219d2b38097fa..22dc97f7d1d622 100644 --- a/pkgs/by-name/ne/neko/package.nix +++ b/pkgs/by-name/ne/neko/package.nix @@ -1,5 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, boehmgc, zlib, sqlite, pcre, cmake, pkg-config -, git, apacheHttpd, apr, aprutil, libmysqlclient, mbedtls_2, openssl, pkgs, gtk2, libpthreadstubs +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + boehmgc, + zlib, + sqlite, + pcre, + cmake, + pkg-config, + git, + apacheHttpd, + apr, + aprutil, + libmysqlclient, + mbedtls_2, + openssl, + pkgs, + gtk2, + libpthreadstubs, }: stdenv.mkDerivation rec { @@ -21,13 +40,30 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config git ]; + nativeBuildInputs = [ + cmake + pkg-config + git + ]; buildInputs = - [ boehmgc zlib sqlite pcre apacheHttpd apr aprutil - libmysqlclient mbedtls_2 openssl libpthreadstubs ] - ++ lib.optional stdenv.hostPlatform.isLinux gtk2 - ++ lib.optionals stdenv.hostPlatform.isDarwin [ pkgs.darwin.apple_sdk.frameworks.Security - pkgs.darwin.apple_sdk.frameworks.Carbon]; + [ + boehmgc + zlib + sqlite + pcre + apacheHttpd + apr + aprutil + libmysqlclient + mbedtls_2 + openssl + libpthreadstubs + ] + ++ lib.optional stdenv.hostPlatform.isLinux gtk2 + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + pkgs.darwin.apple_sdk.frameworks.Security + pkgs.darwin.apple_sdk.frameworks.Carbon + ]; cmakeFlags = [ "-DRUN_LDCONFIG=OFF" ]; env = lib.optionalAttrs stdenv.cc.isClang { NIX_CFLAGS_COMPILE = "-Wno-error=implicit-function-declaration"; @@ -48,15 +84,18 @@ stdenv.mkDerivation rec { homepage = "https://nekovm.org"; license = [ # list based on https://github.com/HaxeFoundation/neko/blob/v2-3-0/LICENSE - licenses.gpl2Plus # nekoc, nekoml - licenses.lgpl21Plus # mysql.ndll - licenses.bsd3 # regexp.ndll - licenses.zlib # zlib.ndll - licenses.asl20 # mod_neko, mod_tora, mbedTLS - licenses.mit # overall, other libs + licenses.gpl2Plus # nekoc, nekoml + licenses.lgpl21Plus # mysql.ndll + licenses.bsd3 # regexp.ndll + licenses.zlib # zlib.ndll + licenses.asl20 # mod_neko, mod_tora, mbedTLS + licenses.mit # overall, other libs "https://github.com/HaxeFoundation/neko/blob/v2-3-0/LICENSE#L24-L40" # boehm gc ]; - maintainers = [ maintainers.marcweber maintainers.locallycompact ]; + maintainers = [ + maintainers.marcweber + maintainers.locallycompact + ]; platforms = platforms.linux ++ platforms.darwin; }; } diff --git a/pkgs/by-name/ne/nemiver/package.nix b/pkgs/by-name/ne/nemiver/package.nix index c63761f23a0b97..198c5ef3fe4b72 100644 --- a/pkgs/by-name/ne/nemiver/package.nix +++ b/pkgs/by-name/ne/nemiver/package.nix @@ -1,23 +1,25 @@ -{ lib, stdenv -, fetchurl -, fetchpatch -, pkg-config -, gnome -, gtk3 -, libxml2 -, intltool -, itstool -, gdb -, boost -, sqlite -, libgtop -, glibmm -, gtkmm3 -, vte -, gtksourceview -, gsettings-desktop-schemas -, gtksourceviewmm -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + gnome, + gtk3, + libxml2, + intltool, + itstool, + gdb, + boost, + sqlite, + libgtop, + glibmm, + gtkmm3, + vte, + gtksourceview, + gsettings-desktop-schemas, + gtksourceviewmm, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ne/nemo-emblems/package.nix b/pkgs/by-name/ne/nemo-emblems/package.nix index 467211a3830a1c..faa0215419b19c 100644 --- a/pkgs/by-name/ne/nemo-emblems/package.nix +++ b/pkgs/by-name/ne/nemo-emblems/package.nix @@ -1,7 +1,8 @@ -{ python3 -, lib -, fetchFromGitHub -, cinnamon-translations +{ + python3, + lib, + fetchFromGitHub, + cinnamon-translations, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ne/nemo-fileroller/package.nix b/pkgs/by-name/ne/nemo-fileroller/package.nix index 9800fd9bb3d2c2..ae668730829e98 100644 --- a/pkgs/by-name/ne/nemo-fileroller/package.nix +++ b/pkgs/by-name/ne/nemo-fileroller/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, pkg-config -, ninja -, glib -, gtk3 -, nemo -, file-roller -, cinnamon-translations +{ + stdenv, + lib, + fetchFromGitHub, + meson, + pkg-config, + ninja, + glib, + gtk3, + nemo, + file-roller, + cinnamon-translations, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ne/nemo-python/package.nix b/pkgs/by-name/ne/nemo-python/package.nix index 9c1651d34c198f..a80cf5e60294be 100644 --- a/pkgs/by-name/ne/nemo-python/package.nix +++ b/pkgs/by-name/ne/nemo-python/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, pkg-config -, ninja -, glib -, gtk3 -, nemo -, python3 +{ + stdenv, + lib, + fetchFromGitHub, + meson, + pkg-config, + ninja, + glib, + gtk3, + nemo, + python3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ne/nemo-with-extensions/package.nix b/pkgs/by-name/ne/nemo-with-extensions/package.nix index 2c97367695eea7..52c081c774c872 100644 --- a/pkgs/by-name/ne/nemo-with-extensions/package.nix +++ b/pkgs/by-name/ne/nemo-with-extensions/package.nix @@ -1,26 +1,29 @@ -{ symlinkJoin -, lib -, makeWrapper -, folder-color-switcher -, nemo -, nemo-emblems -, nemo-fileroller -, nemo-python -, python3 -, extensions ? [ ] -, useDefaultExtensions ? true +{ + symlinkJoin, + lib, + makeWrapper, + folder-color-switcher, + nemo, + nemo-emblems, + nemo-fileroller, + nemo-python, + python3, + extensions ? [ ], + useDefaultExtensions ? true, }: let - selectedExtensions = extensions ++ lib.optionals useDefaultExtensions [ - # We keep this in sync with a default Mint installation - # Right now (only) nemo-share is missing - folder-color-switcher - nemo-emblems - nemo-fileroller - nemo-python - ]; - nemoPythonExtensionsDeps = lib.concatMap (x: x.nemoPythonExtensionDeps or []) selectedExtensions; + selectedExtensions = + extensions + ++ lib.optionals useDefaultExtensions [ + # We keep this in sync with a default Mint installation + # Right now (only) nemo-share is missing + folder-color-switcher + nemo-emblems + nemo-fileroller + nemo-python + ]; + nemoPythonExtensionsDeps = lib.concatMap (x: x.nemoPythonExtensionDeps or [ ]) selectedExtensions; in symlinkJoin { name = "nemo-with-extensions-${nemo.version}"; @@ -51,5 +54,9 @@ symlinkJoin { done ''; - meta = builtins.removeAttrs nemo.meta [ "name" "outputsToInstall" "position" ]; + meta = builtins.removeAttrs nemo.meta [ + "name" + "outputsToInstall" + "position" + ]; } diff --git a/pkgs/by-name/ne/nemo/package.nix b/pkgs/by-name/ne/nemo/package.nix index 52da8ee3e867c8..a17f28145e6c07 100644 --- a/pkgs/by-name/ne/nemo/package.nix +++ b/pkgs/by-name/ne/nemo/package.nix @@ -1,34 +1,37 @@ -{ fetchFromGitHub -, glib -, gobject-introspection -, meson -, ninja -, pkg-config -, lib -, stdenv -, wrapGAppsHook3 -, libxmlb -, gtk3 -, gvfs -, cinnamon-desktop -, xapp -, libexif -, json-glib -, exempi -, intltool -, shared-mime-info -, cinnamon-translations -, libgsf -, python3 +{ + fetchFromGitHub, + glib, + gobject-introspection, + meson, + ninja, + pkg-config, + lib, + stdenv, + wrapGAppsHook3, + libxmlb, + gtk3, + gvfs, + cinnamon-desktop, + xapp, + libexif, + json-glib, + exempi, + intltool, + shared-mime-info, + cinnamon-translations, + libgsf, + python3, }: let # For action-layout-editor. - pythonEnv = python3.withPackages (pp: with pp; [ - pycairo - pygobject3 - python-xapp - ]); + pythonEnv = python3.withPackages ( + pp: with pp; [ + pycairo + pygobject3 + python-xapp + ] + ); in stdenv.mkDerivation rec { pname = "nemo"; @@ -47,7 +50,10 @@ stdenv.mkDerivation rec { ./load-extensions-from-env.patch ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; buildInputs = [ glib @@ -98,10 +104,12 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/linuxmint/nemo"; description = "File browser for Cinnamon"; - license = [ licenses.gpl2 licenses.lgpl2 ]; + license = [ + licenses.gpl2 + licenses.lgpl2 + ]; platforms = platforms.linux; maintainers = teams.cinnamon.members; mainProgram = "nemo"; }; } - diff --git a/pkgs/by-name/ne/nemu/package.nix b/pkgs/by-name/ne/nemu/package.nix index 5f543e13cffbec..0ec873b2faac12 100644 --- a/pkgs/by-name/ne/nemu/package.nix +++ b/pkgs/by-name/ne/nemu/package.nix @@ -1,27 +1,28 @@ -{ busybox -, cmake -, coreutils -, dbus -, fetchFromGitHub -, gettext -, graphviz -, json_c -, lib -, libarchive -, libusb1 -, libxml2 -, makeWrapper -, ncurses -, ninja -, openssl -, picocom -, pkg-config -, qemu -, socat -, sqlite -, stdenv -, systemd -, tigervnc +{ + busybox, + cmake, + coreutils, + dbus, + fetchFromGitHub, + gettext, + graphviz, + json_c, + lib, + libarchive, + libusb1, + libxml2, + makeWrapper, + ncurses, + ninja, + openssl, + picocom, + pkg-config, + qemu, + socat, + sqlite, + stdenv, + systemd, + tigervnc, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ne/nengo-gui/package.nix b/pkgs/by-name/ne/nengo-gui/package.nix index 9a100c03293ea3..44e79a58552006 100644 --- a/pkgs/by-name/ne/nengo-gui/package.nix +++ b/pkgs/by-name/ne/nengo-gui/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonPackage rec { pname = "nengo-gui"; @@ -19,8 +23,8 @@ python3Packages.buildPythonPackage rec { meta = with lib; { description = "Nengo interactive visualizer"; - homepage = "https://nengo.ai/"; - license = licenses.unfreeRedistributable; + homepage = "https://nengo.ai/"; + license = licenses.unfreeRedistributable; maintainers = with maintainers; [ arjix ]; }; } diff --git a/pkgs/by-name/ne/neo-cowsay/package.nix b/pkgs/by-name/ne/neo-cowsay/package.nix index 2682658ab38d68..8f3f556c877c26 100644 --- a/pkgs/by-name/ne/neo-cowsay/package.nix +++ b/pkgs/by-name/ne/neo-cowsay/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "neo-cowsay"; @@ -17,12 +21,18 @@ buildGoModule rec { doCheck = false; - subPackages = [ "cowsay" "cowthink" ]; + subPackages = [ + "cowsay" + "cowthink" + ]; meta = with lib; { description = "Cowsay reborn, written in Go"; homepage = "https://github.com/Code-Hex/Neo-cowsay"; - license = with licenses; [ artistic1 /* or */ gpl3 ]; + license = with licenses; [ + artistic1 # or + gpl3 + ]; maintainers = with maintainers; [ Br1ght0ne ]; mainProgram = "cowsay"; }; diff --git a/pkgs/by-name/ne/neo/package.nix b/pkgs/by-name/ne/neo/package.nix index 27216c381db647..1a34e52cac4c53 100644 --- a/pkgs/by-name/ne/neo/package.nix +++ b/pkgs/by-name/ne/neo/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "neo"; diff --git a/pkgs/by-name/ne/neocities/gemset.nix b/pkgs/by-name/ne/neocities/gemset.nix index 573cee83eed2f4..206f77cb78eb0c 100644 --- a/pkgs/by-name/ne/neocities/gemset.nix +++ b/pkgs/by-name/ne/neocities/gemset.nix @@ -30,8 +30,13 @@ version = "0.4.0"; }; neocities = { - dependencies = - [ "httpclient-fixcerts" "pastel" "rake" "tty-prompt" "tty-table" ]; + dependencies = [ + "httpclient-fixcerts" + "pastel" + "rake" + "tty-prompt" + "tty-table" + ]; groups = [ "default" ]; platforms = [ ]; source = { @@ -42,7 +47,10 @@ version = "0.0.18"; }; pastel = { - dependencies = [ "equatable" "tty-color" ]; + dependencies = [ + "equatable" + "tty-color" + ]; groups = [ "default" ]; platforms = [ ]; source = { @@ -63,7 +71,11 @@ version = "12.3.3"; }; strings = { - dependencies = [ "strings-ansi" "unicode-display_width" "unicode_utils" ]; + dependencies = [ + "strings-ansi" + "unicode-display_width" + "unicode_utils" + ]; groups = [ "default" ]; platforms = [ ]; source = { @@ -104,7 +116,12 @@ version = "0.4.0"; }; tty-prompt = { - dependencies = [ "necromancer" "pastel" "tty-cursor" "wisper" ]; + dependencies = [ + "necromancer" + "pastel" + "tty-cursor" + "wisper" + ]; groups = [ "default" ]; platforms = [ ]; source = { @@ -125,8 +142,13 @@ version = "0.6.5"; }; tty-table = { - dependencies = - [ "equatable" "necromancer" "pastel" "strings" "tty-screen" ]; + dependencies = [ + "equatable" + "necromancer" + "pastel" + "strings" + "tty-screen" + ]; groups = [ "default" ]; platforms = [ ]; source = { diff --git a/pkgs/by-name/ne/neocities/package.nix b/pkgs/by-name/ne/neocities/package.nix index 0907d14a2144c7..3f324fd19d9a4d 100644 --- a/pkgs/by-name/ne/neocities/package.nix +++ b/pkgs/by-name/ne/neocities/package.nix @@ -1,6 +1,7 @@ -{ lib -, bundlerApp -, bundlerUpdateScript +{ + lib, + bundlerApp, + bundlerUpdateScript, }: bundlerApp { @@ -19,4 +20,3 @@ bundlerApp { platforms = platforms.unix; }; } - diff --git a/pkgs/by-name/ne/neocmakelsp/package.nix b/pkgs/by-name/ne/neocmakelsp/package.nix index bdc780817da3f0..a253a22f24368a 100644 --- a/pkgs/by-name/ne/neocmakelsp/package.nix +++ b/pkgs/by-name/ne/neocmakelsp/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/Decodetalkers/neocmakelsp"; license = licenses.mit; platforms = platforms.unix; - maintainers = with maintainers; [ rewine multivac61 ]; + maintainers = with maintainers; [ + rewine + multivac61 + ]; mainProgram = "neocmakelsp"; }; } diff --git a/pkgs/by-name/ne/neocomp/package.nix b/pkgs/by-name/ne/neocomp/package.nix index 8a112b0d8855f5..31e7d7de8ec947 100644 --- a/pkgs/by-name/ne/neocomp/package.nix +++ b/pkgs/by-name/ne/neocomp/package.nix @@ -1,24 +1,26 @@ -{ lib, stdenv -, fetchFromGitHub -, asciidoc -, docbook_xml_dtd_45 -, docbook_xsl -, freetype -, judy -, libGL -, libconfig -, libdrm -, libxml2 -, libxslt -, libXcomposite -, libXdamage -, libXext -, libXinerama -, libXrandr -, libXrender -, libXres -, pcre -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + asciidoc, + docbook_xml_dtd_45, + docbook_xsl, + freetype, + judy, + libGL, + libconfig, + libdrm, + libxml2, + libxslt, + libXcomposite, + libXdamage, + libXext, + libXinerama, + libXrandr, + libXrender, + libXres, + pcre, + pkg-config, }: stdenv.mkDerivation rec { @@ -74,11 +76,14 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - homepage = "https://github.com/DelusionalLogic/NeoComp"; - license = licenses.gpl3Only; - maintainers = with maintainers; [ twey moni ]; - platforms = platforms.linux; - description = "Fork of Compton, a compositor for X11"; + homepage = "https://github.com/DelusionalLogic/NeoComp"; + license = licenses.gpl3Only; + maintainers = with maintainers; [ + twey + moni + ]; + platforms = platforms.linux; + description = "Fork of Compton, a compositor for X11"; longDescription = '' NeoComp is a (hopefully) fast and (hopefully) simple compositor for X11, focused on delivering frames from the window to the diff --git a/pkgs/by-name/ne/neofetch/package.nix b/pkgs/by-name/ne/neofetch/package.nix index fc8a641bfad943..8d241b7a5531bd 100644 --- a/pkgs/by-name/ne/neofetch/package.nix +++ b/pkgs/by-name/ne/neofetch/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenvNoCC, fetchFromGitHub, bash, makeWrapper, pciutils -, x11Support ? true, ueberzug, fetchpatch +{ + lib, + stdenvNoCC, + fetchFromGitHub, + bash, + makeWrapper, + pciutils, + x11Support ? true, + ueberzug, + fetchpatch, }: stdenvNoCC.mkDerivation rec { @@ -33,7 +41,10 @@ stdenvNoCC.mkDerivation rec { }) ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; strictDeps = true; buildInputs = [ bash ]; @@ -44,7 +55,7 @@ stdenvNoCC.mkDerivation rec { postInstall = '' wrapProgram $out/bin/neofetch \ - --prefix PATH : ${lib.makeBinPath ([ pciutils ] ++ lib.optional x11Support ueberzug) } + --prefix PATH : ${lib.makeBinPath ([ pciutils ] ++ lib.optional x11Support ueberzug)} ''; makeFlags = [ diff --git a/pkgs/by-name/ne/neosay/package.nix b/pkgs/by-name/ne/neosay/package.nix index b931cdb05a9d9e..293de7c9b0dc32 100644 --- a/pkgs/by-name/ne/neosay/package.nix +++ b/pkgs/by-name/ne/neosay/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-w0aZnel5Obq73UXcG9wmO9t/7qQTE8ru656u349cvzQ="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Pipe stdin to matrix"; diff --git a/pkgs/by-name/ne/neothesia/package.nix b/pkgs/by-name/ne/neothesia/package.nix index 2b918d74cac122..4d2ab395bf044c 100644 --- a/pkgs/by-name/ne/neothesia/package.nix +++ b/pkgs/by-name/ne/neothesia/package.nix @@ -1,14 +1,15 @@ -{ rustPlatform -, fetchFromGitHub -, lib -, ffmpeg -, pkg-config -, alsa-lib -, wayland -, makeWrapper -, libxkbcommon -, vulkan-loader -, xorg +{ + rustPlatform, + fetchFromGitHub, + lib, + ffmpeg, + pkg-config, + alsa-lib, + wayland, + makeWrapper, + libxkbcommon, + vulkan-loader, + xorg, }: let version = "0.2.1"; @@ -48,7 +49,17 @@ rustPlatform.buildRustPackage { ]; postInstall = '' - wrapProgram $out/bin/neothesia --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ wayland libxkbcommon vulkan-loader xorg.libX11 xorg.libXcursor xorg.libXi xorg.libXrender ]}" + wrapProgram $out/bin/neothesia --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + wayland + libxkbcommon + vulkan-loader + xorg.libX11 + xorg.libXcursor + xorg.libXi + xorg.libXrender + ] + }" install -Dm 644 flatpak/com.github.polymeilex.neothesia.desktop $out/share/applications/com.github.polymeilex.neothesia.desktop install -Dm 644 flatpak/com.github.polymeilex.neothesia.png $out/share/icons/hicolor/256x256/apps/com.github.polymeilex.neothesia.png ''; diff --git a/pkgs/by-name/ne/neovim-gtk/package.nix b/pkgs/by-name/ne/neovim-gtk/package.nix index 7b8504ebe09a04..66257fd5949b43 100644 --- a/pkgs/by-name/ne/neovim-gtk/package.nix +++ b/pkgs/by-name/ne/neovim-gtk/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, wrapGAppsHook4 -, pkg-config -, gdk-pixbuf -, gtk4 -, pango -, vte-gtk4 +{ + lib, + rustPlatform, + fetchFromGitHub, + wrapGAppsHook4, + pkg-config, + gdk-pixbuf, + gtk4, + pango, + vte-gtk4, }: rustPlatform.buildRustPackage rec { @@ -22,9 +23,17 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-9eZwCOP4xQtFOieqVRBAdXZrXmzdnae6PexGJ/eCyYc="; - nativeBuildInputs = [ wrapGAppsHook4 pkg-config ]; - - buildInputs = [ gdk-pixbuf gtk4 pango vte-gtk4 ]; + nativeBuildInputs = [ + wrapGAppsHook4 + pkg-config + ]; + + buildInputs = [ + gdk-pixbuf + gtk4 + pango + vte-gtk4 + ]; patches = [ ./collect-box.patch ]; diff --git a/pkgs/by-name/ne/neovim-qt-unwrapped/package.nix b/pkgs/by-name/ne/neovim-qt-unwrapped/package.nix index 1e8c13ede81bcb..aa43c0fa7bd3de 100644 --- a/pkgs/by-name/ne/neovim-qt-unwrapped/package.nix +++ b/pkgs/by-name/ne/neovim-qt-unwrapped/package.nix @@ -1,30 +1,48 @@ -{ stdenv, lib, libsForQt5, fetchFromGitHub, cmake, doxygen, msgpack, neovim, python3Packages }: +{ + stdenv, + lib, + libsForQt5, + fetchFromGitHub, + cmake, + doxygen, + msgpack, + neovim, + python3Packages, +}: stdenv.mkDerivation rec { pname = "neovim-qt-unwrapped"; version = "0.2.18"; src = fetchFromGitHub { - owner = "equalsraf"; - repo = "neovim-qt"; - rev = "v${version}"; + owner = "equalsraf"; + repo = "neovim-qt"; + rev = "v${version}"; hash = "sha256-BitFHHwL2aqBUpY/8eHaZIFvnDCeABC6w33Vmbx0z2g="; }; cmakeFlags = [ "-DUSE_SYSTEM_MSGPACK=1" - "-DENABLE_TESTS=0" # tests fail because xcb platform plugin is not found + "-DENABLE_TESTS=0" # tests fail because xcb platform plugin is not found ]; - nativeBuildInputs = [ cmake doxygen libsForQt5.wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + doxygen + libsForQt5.wrapQtAppsHook + ]; - buildInputs = [ - neovim.unwrapped # only used to generate help tags at build time - libsForQt5.qtbase - libsForQt5.qtsvg - ] ++ (with python3Packages; [ - jinja2 python msgpack - ]); + buildInputs = + [ + neovim.unwrapped # only used to generate help tags at build time + libsForQt5.qtbase + libsForQt5.qtsvg + ] + ++ (with python3Packages; [ + jinja2 + python + msgpack + ]); preCheck = '' # The GUI tests require a running X server, disable them @@ -36,7 +54,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Neovim client library and GUI, in Qt5"; homepage = "https://github.com/equalsraf/neovim-qt"; - license = licenses.isc; + license = licenses.isc; mainProgram = "nvim-qt"; maintainers = with maintainers; [ peterhoeg ]; inherit (neovim.meta) platforms; diff --git a/pkgs/by-name/ne/neovim-qt/package.nix b/pkgs/by-name/ne/neovim-qt/package.nix index c94c47720106dc..1af3a94b724fbf 100644 --- a/pkgs/by-name/ne/neovim-qt/package.nix +++ b/pkgs/by-name/ne/neovim-qt/package.nix @@ -1,4 +1,9 @@ -{ stdenvNoCC, makeWrapper, neovim, neovim-qt-unwrapped }: +{ + stdenvNoCC, + makeWrapper, + neovim, + neovim-qt-unwrapped, +}: let unwrapped = neovim-qt-unwrapped; @@ -6,22 +11,26 @@ in stdenvNoCC.mkDerivation { pname = "neovim-qt"; version = unwrapped.version; - buildCommand = if stdenvNoCC.hostPlatform.isDarwin then '' - mkdir -p $out/Applications - cp -r ${unwrapped}/bin/nvim-qt.app $out/Applications + buildCommand = + if stdenvNoCC.hostPlatform.isDarwin then + '' + mkdir -p $out/Applications + cp -r ${unwrapped}/bin/nvim-qt.app $out/Applications - chmod -R a+w $out/Applications/nvim-qt.app/Contents/MacOS - wrapProgram $out/Applications/nvim-qt.app/Contents/MacOS/nvim-qt \ - --prefix PATH : ${neovim}/bin - '' else '' - makeWrapper ${unwrapped}/bin/nvim-qt $out/bin/nvim-qt \ - --prefix PATH : ${neovim}/bin + chmod -R a+w $out/Applications/nvim-qt.app/Contents/MacOS + wrapProgram $out/Applications/nvim-qt.app/Contents/MacOS/nvim-qt \ + --prefix PATH : ${neovim}/bin + '' + else + '' + makeWrapper ${unwrapped}/bin/nvim-qt $out/bin/nvim-qt \ + --prefix PATH : ${neovim}/bin - # link .desktop file - mkdir -p $out/share/pixmaps - ln -s ${unwrapped}/share/applications $out/share/applications - ln -s ${unwrapped}/share/icons $out/share/icons - ''; + # link .desktop file + mkdir -p $out/share/pixmaps + ln -s ${unwrapped}/share/applications $out/share/applications + ln -s ${unwrapped}/share/icons $out/share/icons + ''; preferLocalBuild = true; diff --git a/pkgs/by-name/ne/neovim-remote/package.nix b/pkgs/by-name/ne/neovim-remote/package.nix index e0f88180542f87..566f323ce2c61d 100644 --- a/pkgs/by-name/ne/neovim-remote/package.nix +++ b/pkgs/by-name/ne/neovim-remote/package.nix @@ -1,11 +1,13 @@ -{ lib -, fetchFromGitHub -, python3 -, neovim -, fetchpatch +{ + lib, + fetchFromGitHub, + python3, + neovim, + fetchpatch, }: -with python3.pkgs; buildPythonApplication rec { +with python3.pkgs; +buildPythonApplication rec { pname = "neovim-remote"; version = "2.5.1"; diff --git a/pkgs/by-name/ne/nerd-font-patcher/package.nix b/pkgs/by-name/ne/nerd-font-patcher/package.nix index be4321cb37e08e..83ada71e8e3526 100644 --- a/pkgs/by-name/ne/nerd-font-patcher/package.nix +++ b/pkgs/by-name/ne/nerd-font-patcher/package.nix @@ -1,4 +1,8 @@ -{ python3Packages, lib, fetchzip }: +{ + python3Packages, + lib, + fetchzip, +}: python3Packages.buildPythonApplication rec { pname = "nerd-font-patcher"; diff --git a/pkgs/by-name/ne/nerdctl/package.nix b/pkgs/by-name/ne/nerdctl/package.nix index 7d27205855c4a6..9e69d6761fb120 100644 --- a/pkgs/by-name/ne/nerdctl/package.nix +++ b/pkgs/by-name/ne/nerdctl/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, installShellFiles -, buildkit -, cni-plugins -, extraPackages ? [ ] +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + installShellFiles, + buildkit, + cni-plugins, + extraPackages ? [ ], }: buildGoModule rec { @@ -21,10 +22,21 @@ buildGoModule rec { vendorHash = "sha256-5LRsT04T/CKv+YHaiM2g6giimWWXyzPju3iZuj2DfAY="; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; - ldflags = let t = "github.com/containerd/nerdctl/pkg/version"; in - [ "-s" "-w" "-X ${t}.Version=v${version}" "-X ${t}.Revision=" ]; + ldflags = + let + t = "github.com/containerd/nerdctl/pkg/version"; + in + [ + "-s" + "-w" + "-X ${t}.Version=v${version}" + "-X ${t}.Revision=" + ]; # Many checks require a containerd socket and running nerdctl after it's built doCheck = false; @@ -54,7 +66,10 @@ buildGoModule rec { description = "Docker-compatible CLI for containerd"; mainProgram = "nerdctl"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ developer-guy jk ]; + maintainers = with lib.maintainers; [ + developer-guy + jk + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/ne/nerdfetch/package.nix b/pkgs/by-name/ne/nerdfetch/package.nix index f8480813a7dedc..276a1d9eacd5a6 100644 --- a/pkgs/by-name/ne/nerdfetch/package.nix +++ b/pkgs/by-name/ne/nerdfetch/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gitUpdater +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gitUpdater, }: stdenvNoCC.mkDerivation (finalAttrs: { pname = "nerdfetch"; @@ -26,7 +27,7 @@ stdenvNoCC.mkDerivation (finalAttrs: { rev-prefix = "v"; }; - meta = with lib;{ + meta = with lib; { description = "POSIX *nix (Linux, macOS, Android, *BSD, etc) fetch script using Nerdfonts"; homepage = "https://github.com/ThatOneCalculator/NerdFetch"; maintainers = with maintainers; [ ByteSudoer ]; diff --git a/pkgs/by-name/ne/nerdfix/package.nix b/pkgs/by-name/ne/nerdfix/package.nix index 1a57f2f7709db2..852b392c75812c 100644 --- a/pkgs/by-name/ne/nerdfix/package.nix +++ b/pkgs/by-name/ne/nerdfix/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "nerdfix"; homepage = "https://github.com/loichyan/nerdfix"; changelog = "https://github.com/loichyan/nerdfix/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ne/nestopia-ue/package.nix b/pkgs/by-name/ne/nestopia-ue/package.nix index 34ba7112e43f08..b87aedd3d64b9a 100644 --- a/pkgs/by-name/ne/nestopia-ue/package.nix +++ b/pkgs/by-name/ne/nestopia-ue/package.nix @@ -1,21 +1,22 @@ -{ lib -, SDL2 -, alsa-lib -, autoconf-archive -, autoreconfHook -, fetchFromGitHub -, fltk -, libGL -, libGLU -, libao -, libarchive -, libepoxy -, makeWrapper -, pkg-config -, stdenv -, unzip -, wrapGAppsHook3 -, xdg-utils +{ + lib, + SDL2, + alsa-lib, + autoconf-archive, + autoreconfHook, + fetchFromGitHub, + fltk, + libGL, + libGLU, + libao, + libarchive, + libepoxy, + makeWrapper, + pkg-config, + stdenv, + unzip, + wrapGAppsHook3, + xdg-utils, }: stdenv.mkDerivation (finalAttrs: { @@ -60,10 +61,10 @@ stdenv.mkDerivation (finalAttrs: { ''; preFixup = '' - for f in $out/bin/*; do - wrapProgram $f \ - --prefix XDG_DATA_DIRS : "$GSETTINGS_SCHEMAS_PATH:$out/share" - done + for f in $out/bin/*; do + wrapProgram $f \ + --prefix XDG_DATA_DIRS : "$GSETTINGS_SCHEMAS_PATH:$out/share" + done ''; meta = { diff --git a/pkgs/by-name/ne/net-cpp/package.nix b/pkgs/by-name/ne/net-cpp/package.nix index 00815ff66ca800..16fe04ccd5c280 100644 --- a/pkgs/by-name/ne/net-cpp/package.nix +++ b/pkgs/by-name/ne/net-cpp/package.nix @@ -1,28 +1,31 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, gitUpdater -, testers -, boost -, cmake -, curl -, doxygen -, graphviz -, gtest -, jsoncpp -, lomiri -, pkg-config -, process-cpp -, properties-cpp -, python3 -, validatePkgConfig +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + gitUpdater, + testers, + boost, + cmake, + curl, + doxygen, + graphviz, + gtest, + jsoncpp, + lomiri, + pkg-config, + process-cpp, + properties-cpp, + python3, + validatePkgConfig, }: let - pythonEnv = python3.withPackages (ps: with ps; [ - httpbin - ]); + pythonEnv = python3.withPackages ( + ps: with ps; [ + httpbin + ] + ); in stdenv.mkDerivation (finalAttrs: { pname = "net-cpp"; diff --git a/pkgs/by-name/ne/net-snmp/package.nix b/pkgs/by-name/ne/net-snmp/package.nix index 5aa0e8697c58b3..a8c268e2abb998 100644 --- a/pkgs/by-name/ne/net-snmp/package.nix +++ b/pkgs/by-name/ne/net-snmp/package.nix @@ -1,16 +1,28 @@ -{ lib, stdenv, fetchurl, fetchpatch -, file, openssl, perl, nettools -, autoreconfHook -, withPerlTools ? false -, darwin }: let +{ + lib, + stdenv, + fetchurl, + fetchpatch, + file, + openssl, + perl, + nettools, + autoreconfHook, + withPerlTools ? false, + darwin, +}: +let - perlWithPkgs = perl.withPackages (ps: with ps; [ - JSON - TermReadKey - Tk - ]); + perlWithPkgs = perl.withPackages ( + ps: with ps; [ + JSON + TermReadKey + Tk + ] + ); -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "net-snmp"; version = "5.9.4"; @@ -20,32 +32,41 @@ in stdenv.mkDerivation rec { }; patches = - let fetchAlpinePatch = name: sha256: fetchurl { - url = "https://git.alpinelinux.org/aports/plain/main/net-snmp/${name}?id=ebb21045c31f4d5993238bcdb654f21d8faf8123"; - inherit name sha256; - }; - in [ - (fetchAlpinePatch "fix-includes.patch" "0zpkbb6k366qpq4dax5wknwprhwnhighcp402mlm7950d39zfa3m") - (fetchAlpinePatch "netsnmp-swinst-crash.patch" "0gh164wy6zfiwiszh58fsvr25k0ns14r3099664qykgpmickkqid") - (fetchpatch { - name = "configure-musl.patch"; - url = "https://github.com/net-snmp/net-snmp/commit/a62169f1fa358be8f330ea8519ade0610fac525b.patch"; - hash = "sha256-+vWH095fFL3wE6XLsTaPXgMDya0LRWdlL6urD5AIBUs="; - }) - ]; + let + fetchAlpinePatch = + name: sha256: + fetchurl { + url = "https://git.alpinelinux.org/aports/plain/main/net-snmp/${name}?id=ebb21045c31f4d5993238bcdb654f21d8faf8123"; + inherit name sha256; + }; + in + [ + (fetchAlpinePatch "fix-includes.patch" "0zpkbb6k366qpq4dax5wknwprhwnhighcp402mlm7950d39zfa3m") + (fetchAlpinePatch "netsnmp-swinst-crash.patch" "0gh164wy6zfiwiszh58fsvr25k0ns14r3099664qykgpmickkqid") + (fetchpatch { + name = "configure-musl.patch"; + url = "https://github.com/net-snmp/net-snmp/commit/a62169f1fa358be8f330ea8519ade0610fac525b.patch"; + hash = "sha256-+vWH095fFL3wE6XLsTaPXgMDya0LRWdlL6urD5AIBUs="; + }) + ]; - outputs = [ "bin" "out" "dev" "lib" ]; + outputs = [ + "bin" + "out" + "dev" + "lib" + ]; - configureFlags = - [ "--with-default-snmp-version=3" - "--with-sys-location=Unknown" - "--with-sys-contact=root@unknown" - "--with-logfile=/var/log/net-snmpd.log" - "--with-persistent-directory=/var/lib/net-snmp" - "--with-openssl=${openssl.dev}" - "--disable-embedded-perl" - "--without-perl-modules" - ] ++ lib.optional stdenv.hostPlatform.isLinux "--with-mnttab=/proc/mounts"; + configureFlags = [ + "--with-default-snmp-version=3" + "--with-sys-location=Unknown" + "--with-sys-contact=root@unknown" + "--with-logfile=/var/log/net-snmpd.log" + "--with-persistent-directory=/var/lib/net-snmp" + "--with-openssl=${openssl.dev}" + "--disable-embedded-perl" + "--without-perl-modules" + ] ++ lib.optional stdenv.hostPlatform.isLinux "--with-mnttab=/proc/mounts"; postPatch = '' substituteInPlace testing/fulltests/support/simple_TESTCONF.sh --replace "/bin/netstat" "${nettools}/bin/netstat" @@ -58,8 +79,13 @@ in stdenv.mkDerivation rec { -e "/NETSNMP_CONFIGURE_OPTIONS/ s|$NIX_STORE/[a-z0-9]\{32\}-|$NIX_STORE/eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee-|g" ''; - nativeBuildInputs = [ nettools file autoreconfHook ]; - buildInputs = [ openssl ] + nativeBuildInputs = [ + nettools + file + autoreconfHook + ]; + buildInputs = + [ openssl ] ++ lib.optional withPerlTools perlWithPkgs ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.ApplicationServices @@ -72,7 +98,7 @@ in stdenv.mkDerivation rec { # Missing dependencies during relinking: # ./.libs/libnetsnmpagent.so: file not recognized: file format not recognized enableParallelInstalling = false; - doCheck = false; # tries to use networking + doCheck = false; # tries to use networking postInstall = '' for f in "$lib/lib/"*.la $bin/bin/net-snmp-config $bin/bin/net-snmp-create-v3-user; do diff --git a/pkgs/by-name/ne/netassert/package.nix b/pkgs/by-name/ne/netassert/package.nix index caf473ea46c261..a03870c42450ea 100644 --- a/pkgs/by-name/ne/netassert/package.nix +++ b/pkgs/by-name/ne/netassert/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ne/netatalk/package.nix b/pkgs/by-name/ne/netatalk/package.nix index 6262de5f94e8b5..b181486b9e4936 100644 --- a/pkgs/by-name/ne/netatalk/package.nix +++ b/pkgs/by-name/ne/netatalk/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, acl -, autoreconfHook -, avahi -, db -, libevent -, libgcrypt -, libiconv -, openssl -, pam -, perl -, pkg-config -, python3 +{ + lib, + stdenv, + fetchurl, + acl, + autoreconfHook, + avahi, + db, + libevent, + libgcrypt, + libiconv, + openssl, + pam, + perl, + pkg-config, + python3, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ne/netboot/package.nix b/pkgs/by-name/ne/netboot/package.nix index 30dc544fe23bd9..2041f5507472c3 100644 --- a/pkgs/by-name/ne/netboot/package.nix +++ b/pkgs/by-name/ne/netboot/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, bison, lzo, db4 }: +{ + lib, + stdenv, + fetchurl, + bison, + lzo, + db4, +}: stdenv.mkDerivation rec { pname = "netboot"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "09w09bvwgb0xzn8hjz5rhi3aibysdadbg693ahn8rylnqfq4hwg0"; }; - buildInputs = [ bison lzo db4 ]; + buildInputs = [ + bison + lzo + db4 + ]; hardeningDisable = [ "format" ]; @@ -20,7 +31,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Mini PXE server"; maintainers = [ maintainers.raskin ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; license = lib.licenses.free; }; } diff --git a/pkgs/by-name/ne/netbootxyz-efi/package.nix b/pkgs/by-name/ne/netbootxyz-efi/package.nix index 7137f22e89987a..bd2fc9fa09d151 100644 --- a/pkgs/by-name/ne/netbootxyz-efi/package.nix +++ b/pkgs/by-name/ne/netbootxyz-efi/package.nix @@ -1,11 +1,13 @@ -{ lib -, fetchurl +{ + lib, + fetchurl, }: let pname = "netboot.xyz-efi"; version = "2.0.82"; -in fetchurl { +in +fetchurl { name = "${pname}-${version}"; url = "https://github.com/netbootxyz/netboot.xyz/releases/download/${version}/netboot.xyz.efi"; diff --git a/pkgs/by-name/ne/netbox2netshot/package.nix b/pkgs/by-name/ne/netbox2netshot/package.nix index ada70c8f37ef7c..24095209c79427 100644 --- a/pkgs/by-name/ne/netbox2netshot/package.nix +++ b/pkgs/by-name/ne/netbox2netshot/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -24,12 +25,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreFoundation - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreFoundation + darwin.apple_sdk.frameworks.Security + ]; meta = with lib; { description = "Inventory synchronization tool between Netbox and Netshot"; diff --git a/pkgs/by-name/ne/netcat-gnu/package.nix b/pkgs/by-name/ne/netcat-gnu/package.nix index 8271fe9d27a52c..f072cf5d21335d 100644 --- a/pkgs/by-name/ne/netcat-gnu/package.nix +++ b/pkgs/by-name/ne/netcat-gnu/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "netcat-gnu"; diff --git a/pkgs/by-name/ne/netcat-openbsd/package.nix b/pkgs/by-name/ne/netcat-openbsd/package.nix index ec82ec16915ff4..ebb407027bd20d 100644 --- a/pkgs/by-name/ne/netcat-openbsd/package.nix +++ b/pkgs/by-name/ne/netcat-openbsd/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitLab, pkg-config, libbsd, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + libbsd, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "netcat-openbsd"; @@ -13,7 +20,10 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ pkg-config installShellFiles ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; buildInputs = [ libbsd ]; postPatch = '' diff --git a/pkgs/by-name/ne/netcdf/package.nix b/pkgs/by-name/ne/netcdf/package.nix index 4769a09630984e..1bdaf7068552c8 100644 --- a/pkgs/by-name/ne/netcdf/package.nix +++ b/pkgs/by-name/ne/netcdf/package.nix @@ -1,20 +1,24 @@ -{ lib, stdenv -, fetchurl, unzip -, hdf5 -, bzip2 -, libzip -, zstd -, szipSupport ? false -, szip -, libxml2 -, m4 -, curl # for DAP -, removeReferencesTo +{ + lib, + stdenv, + fetchurl, + unzip, + hdf5, + bzip2, + libzip, + zstd, + szipSupport ? false, + szip, + libxml2, + m4, + curl, # for DAP + removeReferencesTo, }: let inherit (hdf5) mpiSupport mpi; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "netcdf" + lib.optionalString mpiSupport "-mpi"; version = "4.9.2"; @@ -63,14 +67,18 @@ in stdenv.mkDerivation rec { # tracked upstream here: https://github.com/Unidata/netcdf-c/issues/2715 lib.optionalString stdenv.cc.isClang "-Wno-error=incompatible-function-pointer-types"; - configureFlags = [ + configureFlags = + [ "--enable-netcdf-4" "--enable-dap" "--enable-shared" "--disable-dap-remote-tests" "--with-plugin-dir=${placeholder "out"}/lib/hdf5-plugins" - ] - ++ (lib.optionals mpiSupport [ "--enable-parallel-tests" "CC=${lib.getDev mpi}/bin/mpicc" ]); + ] + ++ (lib.optionals mpiSupport [ + "--enable-parallel-tests" + "CC=${lib.getDev mpi}/bin/mpicc" + ]); enableParallelBuilding = true; diff --git a/pkgs/by-name/ne/netcdfcxx4/package.nix b/pkgs/by-name/ne/netcdfcxx4/package.nix index 606e8a86b0c341..50769879d2a365 100644 --- a/pkgs/by-name/ne/netcdfcxx4/package.nix +++ b/pkgs/by-name/ne/netcdfcxx4/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, netcdf, hdf5, curl, cmake, ninja }: +{ + lib, + stdenv, + fetchFromGitHub, + netcdf, + hdf5, + curl, + cmake, + ninja, +}: stdenv.mkDerivation rec { pname = "netcdf-cxx4"; version = "4.3.1"; @@ -19,8 +28,15 @@ stdenv.mkDerivation rec { cmakeFlags+="-Dabs_top_srcdir=$(readlink -f ./)" ''; - nativeBuildInputs = [ cmake ninja ]; - buildInputs = [ netcdf hdf5 curl ]; + nativeBuildInputs = [ + cmake + ninja + ]; + buildInputs = [ + netcdf + hdf5 + curl + ]; doCheck = true; enableParallelChecking = false; diff --git a/pkgs/by-name/ne/netclient/package.nix b/pkgs/by-name/ne/netclient/package.nix index 5351ede7bfc265..d4a301d1b9263c 100644 --- a/pkgs/by-name/ne/netclient/package.nix +++ b/pkgs/by-name/ne/netclient/package.nix @@ -1,8 +1,9 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, libX11 -, stdenv +{ + buildGoModule, + fetchFromGitHub, + lib, + libX11, + stdenv, }: buildGoModule rec { diff --git a/pkgs/by-name/ne/netcoredbg/deps.nix b/pkgs/by-name/ne/netcoredbg/deps.nix index 12e4c86a157f1b..1e7b246511f33a 100644 --- a/pkgs/by-name/ne/netcoredbg/deps.nix +++ b/pkgs/by-name/ne/netcoredbg/deps.nix @@ -1,122 +1,591 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "1.1.0"; hash = "sha256-7KrZfK3kUbmeT82eVadvHurZcaFq3FDj4qkIIeExJiM="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "2.3.0"; hash = "sha256-9/DyI5MV2+Biwg+xWNL7CBk2vIg0bHfmgf7ilAjZSdw="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "2.3.0"; hash = "sha256-pR/zH3AGkHNxZFzAUNmJwQg+KncAv9hgKq1CxHAeCb0="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.Scripting"; version = "2.3.0"; hash = "sha256-l+DaOdHrMHwXHbhwoHoCbcsyO9LpzAYCqV+WJp2FLYg="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Scripting.Common"; version = "2.3.0"; hash = "sha256-OH4yRoHHn1xhbhci4pTZ6PAYuiQgkD+9Qfq1/PYMwYU="; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.4.0"; hash = "sha256-EMIApW3Zj0V85leF7DLgFFvfqPdsIdvvJ3BD7zD+Pto="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim"; version = "8.0.532401"; hash = "sha256-rvTxIxaW6WYlbNqV0mVjX3JkjxOB2eoDtm7HD3qgKvg="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim.linux-arm"; version = "8.0.532401"; hash = "sha256-LYDAN85Qsnj3TIdH1VzzIbeQRQfo4A9kYp/da0nZMX4="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim.linux-arm64"; version = "8.0.532401"; hash = "sha256-/1eElmNjO8ug2i0hzsnX+ksaeTlSrJNxuHBZZ5Mxw7A="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim.linux-musl-arm"; version = "8.0.532401"; hash = "sha256-3FsyQbXHgUErMg4islyZ68ZOi22Dtc7bHuzV4cHTetQ="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim.linux-musl-arm64"; version = "8.0.532401"; hash = "sha256-UCGQZZ9ZQKgdvVpgJfKAUL1hDxopEOpkb71x11mZ5go="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim.linux-musl-x64"; version = "8.0.532401"; hash = "sha256-zpKJdEGHfrk/ty0s2TuPiNi/yanEk6iAVZDOgBlv20s="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim.linux-x64"; version = "8.0.532401"; hash = "sha256-maN37KzN1GxFW37E2t8suG1XHNfTIdDLTHxiaiwGfdc="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim.osx-arm64"; version = "8.0.532401"; hash = "sha256-4+hYe0f09F/seep1K1O9uF1S+g0ygyNJIcqA3b4Fhh4="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim.osx-x64"; version = "8.0.532401"; hash = "sha256-K/0i5SGl3rG8ciXbhSu2dWURlzfB2uVorv2yc7KKP4I="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim.win-arm"; version = "8.0.532401"; hash = "sha256-m/XEdwtXKGGIB1ORetiEaJ5qnQa+wz1Ou+aspxHAhe0="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim.win-arm64"; version = "8.0.532401"; hash = "sha256-QPo/eFVr7HCAeOcLlsOrukL78BWfs+nZHVr5ClZzCiQ="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim.win-x64"; version = "8.0.532401"; hash = "sha256-gxTB3KBr/ROgbBpLGQogtg2dz7a8F26UWyzsMJYMzv4="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.DbgShim.win-x86"; version = "8.0.532401"; hash = "sha256-CP1WHi8a3Xr0ml2Dnhmhc14xSGqHPnrfnrfeuhZmm6o="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tools"; version = "4.3.0"; hash = "sha256-8yLKFt2wQxkEf7fNfzB+cPUCjYn2qbqNgQ1+EeY2h/I="; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-dsmTLGvt8HqRkDWP8iKVXJCS+akAzENGXKPV18W2RgI="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization.Calendars"; version = "4.3.0"; hash = "sha256-AYh39tgXJVFu8aLi9Y/4rK8yWMaza4S4eaxjfcuEEL4="; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-6MYj0RmLh4EVqMtO/MRqBi0HOn5iG4x9JimgCCJ+EFM="; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; }) - (fetchNuGet { pname = "runtime.native.System.IO.Compression"; version = "4.3.0"; hash = "sha256-DWnXs4vlKoU6WxxvCArTJupV6sX3iBbZh8SbqfHace8="; }) - (fetchNuGet { pname = "runtime.native.System.Net.Http"; version = "4.3.0"; hash = "sha256-c556PyheRwpYhweBjSfIwEyZHnAUB8jWioyKEcp/2dg="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; hash = "sha256-2IhBv0i6pTcOyr8FFIyfPEaaCHUmJZ8DYwLUwJ+5waw="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; hash = "sha256-serkd4A7F6eciPiPJtUyJyxzdAtupEcWIZQ9nptEzIM="; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; }) - (fetchNuGet { pname = "runtime.unix.System.Console"; version = "4.3.0"; hash = "sha256-AHkdKShTRHttqfMjmi+lPpTuCrM5vd/WRy6Kbtie190="; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; }) - (fetchNuGet { pname = "runtime.unix.System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-Pf4mRl6YDK2x2KMh0WdyNgv0VUNdSKVDLlHqozecy5I="; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; }) - (fetchNuGet { pname = "System.AppContext"; version = "4.3.0"; hash = "sha256-yg95LNQOwFlA1tWxXdQkVyJqT4AnoDc+ACmrNvzGiZg="; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.3.0"; hash = "sha256-XqZWb4Kd04960h4U9seivjKseGA/YEIpdplfHYHQ9jk="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.3.0"; hash = "sha256-KMY5DfJnDeIsa13DpqvyN8NkReZEMAFnlmNglVoFIXI="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "1.3.1"; hash = "sha256-areGRq/dO08KhxiWuAK+cWAjOWYtuB1R9zGXLvIqwZw="; }) - (fetchNuGet { pname = "System.Console"; version = "4.3.0"; hash = "sha256-Xh3PPBZr0pDbDaK8AEHbdGz7ePK6Yi1ZyRWI1JM6mbo="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; }) - (fetchNuGet { pname = "System.Diagnostics.FileVersionInfo"; version = "4.3.0"; hash = "sha256-JyqOf5/lsUNLMpIqK8XffcFTxB6vHWzGWHssmojokCQ="; }) - (fetchNuGet { pname = "System.Diagnostics.StackTrace"; version = "4.3.0"; hash = "sha256-Tfq7F61N0VfujVyI5A9MZvyWewQ5HepB1f1UMBMkUCs="; }) - (fetchNuGet { pname = "System.Diagnostics.Tools"; version = "4.3.0"; hash = "sha256-gVOv1SK6Ape0FQhCVlNOd9cvQKBvMxRX9K0JPVi8w0Y="; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.3.0"; hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.3.0"; hash = "sha256-uNOD0EOVFgnS2fMKvMiEtI9aOw00+Pfy/H+qucAQlPc="; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; }) - (fetchNuGet { pname = "System.IO.Compression"; version = "4.3.0"; hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.3.0"; hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.3.0"; hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.3.0"; hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.3.0"; hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.3.0"; hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "1.4.2"; hash = "sha256-cYd2SWmnacNq14fTpyW9vGcnbZSD4DPRjpR+tgdZZyE="; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.3.0"; hash = "sha256-4U4/XNQAnddgQIHIJq3P2T80hN0oPdU2uCeghsDTWng="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.3.0"; hash = "sha256-P5jHCgMbgFMYiONvzmaKFeOqcAIDPu/U8bOVrNPYKqc="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.3.0"; hash = "sha256-tAJvNSlczYBJ3Ed24Ae27a55tq/n4D3fubNQdwcKWA8="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.3.0"; hash = "sha256-u17vy6wNhqok91SrVLno2M1EzLHZm6VMca85xbVChsw="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Csp"; version = "4.3.0"; hash = "sha256-oefdTU/Z2PWU9nlat8uiRDGq/PGZoSPRgkML11pmvPQ="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.3.0"; hash = "sha256-Yuge89N6M+NcblcvXMeyHZ6kZDfwBv3LPMDiF8HhJss="; }) - (fetchNuGet { pname = "System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-DL+D2sc2JrQiB4oAcUggTFyD8w3aLEjJfod5JPe+Oz4="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.3.0"; hash = "sha256-fnFi7B3SnVj5a+BbgXnbjnGNvWrCEU6Hp/wjsjWz318="; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.3.0"; hash = "sha256-MG3V/owDh273GCUPsGGraNwaVpcydupl3EtPXj6TVG0="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "4.3.0"; hash = "sha256-ezYVwe9atRkREc8O/HT/VfGDE2vuCpIckOfdY194/VE="; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; }) - (fetchNuGet { pname = "System.Text.RegularExpressions"; version = "4.3.0"; hash = "sha256-VLCk1D1kcN2wbAe3d0YQM/PqCsPHOuqlBY1yd2Yo+K0="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.3.0"; hash = "sha256-X2hQ5j+fxcmnm88Le/kSavjiGOmkcumBGTZKBLvorPc="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Parallel"; version = "4.3.0"; hash = "sha256-8H2vRmsn29MNfMmCeIL5vHfbM19jWaLDKNLzDonCI+c="; }) - (fetchNuGet { pname = "System.Threading.Thread"; version = "4.3.0"; hash = "sha256-pMs6RNFC3nQOGz9EqIcyWmO8YLaqay+q/Qde5hqPXXg="; }) - (fetchNuGet { pname = "System.ValueTuple"; version = "4.3.0"; hash = "sha256-tkMwiobmGQn/t8LDqpkM+Q7XJOebEl3bwVf11d2ZR4g="; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.3.0"; hash = "sha256-QQ8KgU0lu4F5Unh+TbechO//zaAGZ4MfgvW72Cn1hzA="; }) - (fetchNuGet { pname = "System.Xml.XDocument"; version = "4.3.0"; hash = "sha256-rWtdcmcuElNOSzCehflyKwHkDRpiOhJJs8CeQ0l1CCI="; }) - (fetchNuGet { pname = "System.Xml.XmlDocument"; version = "4.3.0"; hash = "sha256-kbuV4Y7rVJkfMp2Kgoi8Zvdatm9CZNmlKB3GZgANvy4="; }) - (fetchNuGet { pname = "System.Xml.XPath"; version = "4.3.0"; hash = "sha256-kd1JMqj6obhxzEPRJeYvcUyJqkOs/9A0UOQccC6oYrM="; }) - (fetchNuGet { pname = "System.Xml.XPath.XDocument"; version = "4.3.0"; hash = "sha256-dqk4CWuwocj5qsUAYlS+XAe6GGcY/N/HIPEGe5afrPM="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "1.1.0"; + hash = "sha256-7KrZfK3kUbmeT82eVadvHurZcaFq3FDj4qkIIeExJiM="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "2.3.0"; + hash = "sha256-9/DyI5MV2+Biwg+xWNL7CBk2vIg0bHfmgf7ilAjZSdw="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "2.3.0"; + hash = "sha256-pR/zH3AGkHNxZFzAUNmJwQg+KncAv9hgKq1CxHAeCb0="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.Scripting"; + version = "2.3.0"; + hash = "sha256-l+DaOdHrMHwXHbhwoHoCbcsyO9LpzAYCqV+WJp2FLYg="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Scripting.Common"; + version = "2.3.0"; + hash = "sha256-OH4yRoHHn1xhbhci4pTZ6PAYuiQgkD+9Qfq1/PYMwYU="; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.4.0"; + hash = "sha256-EMIApW3Zj0V85leF7DLgFFvfqPdsIdvvJ3BD7zD+Pto="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim"; + version = "8.0.532401"; + hash = "sha256-rvTxIxaW6WYlbNqV0mVjX3JkjxOB2eoDtm7HD3qgKvg="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim.linux-arm"; + version = "8.0.532401"; + hash = "sha256-LYDAN85Qsnj3TIdH1VzzIbeQRQfo4A9kYp/da0nZMX4="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim.linux-arm64"; + version = "8.0.532401"; + hash = "sha256-/1eElmNjO8ug2i0hzsnX+ksaeTlSrJNxuHBZZ5Mxw7A="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim.linux-musl-arm"; + version = "8.0.532401"; + hash = "sha256-3FsyQbXHgUErMg4islyZ68ZOi22Dtc7bHuzV4cHTetQ="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim.linux-musl-arm64"; + version = "8.0.532401"; + hash = "sha256-UCGQZZ9ZQKgdvVpgJfKAUL1hDxopEOpkb71x11mZ5go="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim.linux-musl-x64"; + version = "8.0.532401"; + hash = "sha256-zpKJdEGHfrk/ty0s2TuPiNi/yanEk6iAVZDOgBlv20s="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim.linux-x64"; + version = "8.0.532401"; + hash = "sha256-maN37KzN1GxFW37E2t8suG1XHNfTIdDLTHxiaiwGfdc="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim.osx-arm64"; + version = "8.0.532401"; + hash = "sha256-4+hYe0f09F/seep1K1O9uF1S+g0ygyNJIcqA3b4Fhh4="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim.osx-x64"; + version = "8.0.532401"; + hash = "sha256-K/0i5SGl3rG8ciXbhSu2dWURlzfB2uVorv2yc7KKP4I="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim.win-arm"; + version = "8.0.532401"; + hash = "sha256-m/XEdwtXKGGIB1ORetiEaJ5qnQa+wz1Ou+aspxHAhe0="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim.win-arm64"; + version = "8.0.532401"; + hash = "sha256-QPo/eFVr7HCAeOcLlsOrukL78BWfs+nZHVr5ClZzCiQ="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim.win-x64"; + version = "8.0.532401"; + hash = "sha256-gxTB3KBr/ROgbBpLGQogtg2dz7a8F26UWyzsMJYMzv4="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.DbgShim.win-x86"; + version = "8.0.532401"; + hash = "sha256-CP1WHi8a3Xr0ml2Dnhmhc14xSGqHPnrfnrfeuhZmm6o="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tools"; + version = "4.3.0"; + hash = "sha256-8yLKFt2wQxkEf7fNfzB+cPUCjYn2qbqNgQ1+EeY2h/I="; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-dsmTLGvt8HqRkDWP8iKVXJCS+akAzENGXKPV18W2RgI="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization.Calendars"; + version = "4.3.0"; + hash = "sha256-AYh39tgXJVFu8aLi9Y/4rK8yWMaza4S4eaxjfcuEEL4="; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-6MYj0RmLh4EVqMtO/MRqBi0HOn5iG4x9JimgCCJ+EFM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; + }) + (fetchNuGet { + pname = "runtime.native.System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-DWnXs4vlKoU6WxxvCArTJupV6sX3iBbZh8SbqfHace8="; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Http"; + version = "4.3.0"; + hash = "sha256-c556PyheRwpYhweBjSfIwEyZHnAUB8jWioyKEcp/2dg="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + hash = "sha256-2IhBv0i6pTcOyr8FFIyfPEaaCHUmJZ8DYwLUwJ+5waw="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + hash = "sha256-serkd4A7F6eciPiPJtUyJyxzdAtupEcWIZQ9nptEzIM="; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Console"; + version = "4.3.0"; + hash = "sha256-AHkdKShTRHttqfMjmi+lPpTuCrM5vd/WRy6Kbtie190="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; + }) + (fetchNuGet { + pname = "runtime.unix.System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-Pf4mRl6YDK2x2KMh0WdyNgv0VUNdSKVDLlHqozecy5I="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; + }) + (fetchNuGet { + pname = "System.AppContext"; + version = "4.3.0"; + hash = "sha256-yg95LNQOwFlA1tWxXdQkVyJqT4AnoDc+ACmrNvzGiZg="; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.3.0"; + hash = "sha256-XqZWb4Kd04960h4U9seivjKseGA/YEIpdplfHYHQ9jk="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.3.0"; + hash = "sha256-KMY5DfJnDeIsa13DpqvyN8NkReZEMAFnlmNglVoFIXI="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "1.3.1"; + hash = "sha256-areGRq/dO08KhxiWuAK+cWAjOWYtuB1R9zGXLvIqwZw="; + }) + (fetchNuGet { + pname = "System.Console"; + version = "4.3.0"; + hash = "sha256-Xh3PPBZr0pDbDaK8AEHbdGz7ePK6Yi1ZyRWI1JM6mbo="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; + }) + (fetchNuGet { + pname = "System.Diagnostics.FileVersionInfo"; + version = "4.3.0"; + hash = "sha256-JyqOf5/lsUNLMpIqK8XffcFTxB6vHWzGWHssmojokCQ="; + }) + (fetchNuGet { + pname = "System.Diagnostics.StackTrace"; + version = "4.3.0"; + hash = "sha256-Tfq7F61N0VfujVyI5A9MZvyWewQ5HepB1f1UMBMkUCs="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tools"; + version = "4.3.0"; + hash = "sha256-gVOv1SK6Ape0FQhCVlNOd9cvQKBvMxRX9K0JPVi8w0Y="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.3.0"; + hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.3.0"; + hash = "sha256-uNOD0EOVFgnS2fMKvMiEtI9aOw00+Pfy/H+qucAQlPc="; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; + }) + (fetchNuGet { + pname = "System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.3.0"; + hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.3.0"; + hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.3.0"; + hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.3.0"; + hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.3.0"; + hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "1.4.2"; + hash = "sha256-cYd2SWmnacNq14fTpyW9vGcnbZSD4DPRjpR+tgdZZyE="; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.3.0"; + hash = "sha256-4U4/XNQAnddgQIHIJq3P2T80hN0oPdU2uCeghsDTWng="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.3.0"; + hash = "sha256-P5jHCgMbgFMYiONvzmaKFeOqcAIDPu/U8bOVrNPYKqc="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.3.0"; + hash = "sha256-tAJvNSlczYBJ3Ed24Ae27a55tq/n4D3fubNQdwcKWA8="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.3.0"; + hash = "sha256-u17vy6wNhqok91SrVLno2M1EzLHZm6VMca85xbVChsw="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Csp"; + version = "4.3.0"; + hash = "sha256-oefdTU/Z2PWU9nlat8uiRDGq/PGZoSPRgkML11pmvPQ="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.3.0"; + hash = "sha256-Yuge89N6M+NcblcvXMeyHZ6kZDfwBv3LPMDiF8HhJss="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-DL+D2sc2JrQiB4oAcUggTFyD8w3aLEjJfod5JPe+Oz4="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.3.0"; + hash = "sha256-fnFi7B3SnVj5a+BbgXnbjnGNvWrCEU6Hp/wjsjWz318="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.3.0"; + hash = "sha256-MG3V/owDh273GCUPsGGraNwaVpcydupl3EtPXj6TVG0="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "4.3.0"; + hash = "sha256-ezYVwe9atRkREc8O/HT/VfGDE2vuCpIckOfdY194/VE="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; + }) + (fetchNuGet { + pname = "System.Text.RegularExpressions"; + version = "4.3.0"; + hash = "sha256-VLCk1D1kcN2wbAe3d0YQM/PqCsPHOuqlBY1yd2Yo+K0="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.3.0"; + hash = "sha256-X2hQ5j+fxcmnm88Le/kSavjiGOmkcumBGTZKBLvorPc="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Parallel"; + version = "4.3.0"; + hash = "sha256-8H2vRmsn29MNfMmCeIL5vHfbM19jWaLDKNLzDonCI+c="; + }) + (fetchNuGet { + pname = "System.Threading.Thread"; + version = "4.3.0"; + hash = "sha256-pMs6RNFC3nQOGz9EqIcyWmO8YLaqay+q/Qde5hqPXXg="; + }) + (fetchNuGet { + pname = "System.ValueTuple"; + version = "4.3.0"; + hash = "sha256-tkMwiobmGQn/t8LDqpkM+Q7XJOebEl3bwVf11d2ZR4g="; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.3.0"; + hash = "sha256-QQ8KgU0lu4F5Unh+TbechO//zaAGZ4MfgvW72Cn1hzA="; + }) + (fetchNuGet { + pname = "System.Xml.XDocument"; + version = "4.3.0"; + hash = "sha256-rWtdcmcuElNOSzCehflyKwHkDRpiOhJJs8CeQ0l1CCI="; + }) + (fetchNuGet { + pname = "System.Xml.XmlDocument"; + version = "4.3.0"; + hash = "sha256-kbuV4Y7rVJkfMp2Kgoi8Zvdatm9CZNmlKB3GZgANvy4="; + }) + (fetchNuGet { + pname = "System.Xml.XPath"; + version = "4.3.0"; + hash = "sha256-kd1JMqj6obhxzEPRJeYvcUyJqkOs/9A0UOQccC6oYrM="; + }) + (fetchNuGet { + pname = "System.Xml.XPath.XDocument"; + version = "4.3.0"; + hash = "sha256-dqk4CWuwocj5qsUAYlS+XAe6GGcY/N/HIPEGe5afrPM="; + }) ] diff --git a/pkgs/by-name/ne/netcoredbg/package.nix b/pkgs/by-name/ne/netcoredbg/package.nix index 6b9773cb60dbd4..24194c88062606 100644 --- a/pkgs/by-name/ne/netcoredbg/package.nix +++ b/pkgs/by-name/ne/netcoredbg/package.nix @@ -1,4 +1,15 @@ -{ lib, clangStdenv, stdenv, cmake, autoPatchelfHook, fetchFromGitHub, dotnetCorePackages, buildDotnetModule, netcoredbg, testers }: +{ + lib, + clangStdenv, + stdenv, + cmake, + autoPatchelfHook, + fetchFromGitHub, + dotnetCorePackages, + buildDotnetModule, + netcoredbg, + testers, +}: let pname = "netcoredbg"; build = "1031"; @@ -26,7 +37,10 @@ let unmanaged = clangStdenv.mkDerivation { inherit src pname version; - nativeBuildInputs = [ cmake dotnet-sdk ]; + nativeBuildInputs = [ + cmake + dotnet-sdk + ]; hardeningDisable = [ "strictoverflow" ]; @@ -42,7 +56,12 @@ let }; managed = buildDotnetModule { - inherit pname version src dotnet-sdk; + inherit + pname + version + src + dotnet-sdk + ; dotnet-runtime = null; projectFile = "src/managed/ManagedPart.csproj"; @@ -88,6 +107,9 @@ stdenv.mkDerivation { license = licenses.mit; platforms = platforms.unix; mainProgram = "netcoredbg"; - maintainers = with maintainers; [ leo60228 konradmalik ]; + maintainers = with maintainers; [ + leo60228 + konradmalik + ]; }; } diff --git a/pkgs/by-name/ne/netdiscover/package.nix b/pkgs/by-name/ne/netdiscover/package.nix index f58a6903943bc3..2f7608c36ab7b6 100644 --- a/pkgs/by-name/ne/netdiscover/package.nix +++ b/pkgs/by-name/ne/netdiscover/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, libpcap, libnet, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + libpcap, + libnet, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "netdiscover"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ libpcap libnet ]; + buildInputs = [ + libpcap + libnet + ]; # Running update-oui-database.sh would probably make the build irreproducible diff --git a/pkgs/by-name/ne/netevent/package.nix b/pkgs/by-name/ne/netevent/package.nix index 9d09d9ed2bf29c..19e87147f28d2b 100644 --- a/pkgs/by-name/ne/netevent/package.nix +++ b/pkgs/by-name/ne/netevent/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, docutils, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + docutils, + installShellFiles, +}: stdenv.mkDerivation { pname = "netevent"; @@ -14,7 +20,11 @@ stdenv.mkDerivation { buildInputs = [ docutils ]; nativeBuildInputs = [ installShellFiles ]; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; configurePhase = '' export RST2MAN=rst2man diff --git a/pkgs/by-name/ne/netflix/package.nix b/pkgs/by-name/ne/netflix/package.nix index 8c50e027c0e201..14e3a3f1a827dc 100644 --- a/pkgs/by-name/ne/netflix/package.nix +++ b/pkgs/by-name/ne/netflix/package.nix @@ -1,13 +1,14 @@ -{ fetchurl -, google-chrome -, lib -, makeDesktopItem -, runtimeShell -, symlinkJoin -, writeScriptBin +{ + fetchurl, + google-chrome, + lib, + makeDesktopItem, + runtimeShell, + symlinkJoin, + writeScriptBin, # command line arguments which are always set e.g "--disable-gpu" -, commandLineArgs ? [ ] + commandLineArgs ? [ ], }: let @@ -40,7 +41,11 @@ let }; desktopName = "Netflix via Google Chrome"; genericName = "A video streaming service providing films and exclusive TV series"; - categories = [ "TV" "AudioVideo" "Network" ]; + categories = [ + "TV" + "AudioVideo" + "Network" + ]; startupNotify = true; }; @@ -58,5 +63,8 @@ in symlinkJoin { inherit name meta; - paths = [ script desktopItem ]; + paths = [ + script + desktopItem + ]; } diff --git a/pkgs/by-name/ne/nethogs/package.nix b/pkgs/by-name/ne/nethogs/package.nix index f4d7700b9000c2..5ad1bfd5c999b1 100644 --- a/pkgs/by-name/ne/nethogs/package.nix +++ b/pkgs/by-name/ne/nethogs/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, ncurses, libpcap }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + libpcap, +}: stdenv.mkDerivation rec { pname = "nethogs"; @@ -11,11 +17,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-+yVMyGSBIBWYjA9jaGWvrcsNPbJ6S4ax9H1BhWHYUUU="; }; - buildInputs = [ ncurses libpcap ]; + buildInputs = [ + ncurses + libpcap + ]; - makeFlags = [ "VERSION=${version}" "nethogs" ]; + makeFlags = [ + "VERSION=${version}" + "nethogs" + ]; - installFlags = [ "PREFIX=$(out)" "sbin=$(out)/bin" ]; + installFlags = [ + "PREFIX=$(out)" + "sbin=$(out)/bin" + ]; meta = with lib; { description = "Small 'net top' tool, grouping bandwidth by process"; diff --git a/pkgs/by-name/ne/nethoscope/package.nix b/pkgs/by-name/ne/nethoscope/package.nix index 2b450cf7b8aa53..18d284443d7c8f 100644 --- a/pkgs/by-name/ne/nethoscope/package.nix +++ b/pkgs/by-name/ne/nethoscope/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, alsa-lib -, libpcap -, expect +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + alsa-lib, + libpcap, + expect, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ne/netifd/package.nix b/pkgs/by-name/ne/netifd/package.nix index 6fd90f6082c975..afb13762dc225f 100644 --- a/pkgs/by-name/ne/netifd/package.nix +++ b/pkgs/by-name/ne/netifd/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, cmake -, fetchgit -, libnl -, libubox -, uci -, ubus -, json_c -, pkg-config -, udebug +{ + lib, + stdenv, + cmake, + fetchgit, + libnl, + libubox, + uci, + ubus, + json_c, + pkg-config, + udebug, }: stdenv.mkDerivation { @@ -44,9 +45,11 @@ stdenv.mkDerivation { sed "s|./ethtool-modes.h|$PWD/ethtool-modes.h|g" -i CMakeLists.txt ''; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ - "-Wno-error=maybe-uninitialized" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ + "-Wno-error=maybe-uninitialized" + ] + ); meta = with lib; { description = "OpenWrt Network interface configuration daemon"; diff --git a/pkgs/by-name/ne/netkittftp/package.nix b/pkgs/by-name/ne/netkittftp/package.nix index 807aa62601fe84..077438c0e4e7e4 100644 --- a/pkgs/by-name/ne/netkittftp/package.nix +++ b/pkgs/by-name/ne/netkittftp/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "netkit-tftp"; diff --git a/pkgs/by-name/ne/netlistsvg/package.nix b/pkgs/by-name/ne/netlistsvg/package.nix index 8458d63f03bb0c..6d9ee1f4a16e6e 100644 --- a/pkgs/by-name/ne/netlistsvg/package.nix +++ b/pkgs/by-name/ne/netlistsvg/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, runCommandLocal -, netlistsvg -, yosys +{ + lib, + buildNpmPackage, + fetchFromGitHub, + runCommandLocal, + netlistsvg, + yosys, }: buildNpmPackage rec { @@ -36,14 +37,20 @@ buildNpmPackage rec { ''; # An integration test: Synthesize a circuit from hdl and generate a diagram - passthru.tests.netlistsvg-yosys-integration-test = runCommandLocal "netlistsvg-yosys-integration-test" { - nativeBuildInputs = [ netlistsvg yosys ]; - } '' - yosys -p "prep -top helloworld -flatten; aigmap; write_json circuit.json" ${./test.v} - netlistsvg circuit.json -o circuit.svg - test -s circuit.svg - touch $out - ''; + passthru.tests.netlistsvg-yosys-integration-test = + runCommandLocal "netlistsvg-yosys-integration-test" + { + nativeBuildInputs = [ + netlistsvg + yosys + ]; + } + '' + yosys -p "prep -top helloworld -flatten; aigmap; write_json circuit.json" ${./test.v} + netlistsvg circuit.json -o circuit.svg + test -s circuit.svg + touch $out + ''; meta = { description = "Draw SVG digital circuits schematics from yosys JSON netlists"; diff --git a/pkgs/by-name/ne/netlogo/package.nix b/pkgs/by-name/ne/netlogo/package.nix index 20d001d8dba23f..f7375bc7c78d47 100644 --- a/pkgs/by-name/ne/netlogo/package.nix +++ b/pkgs/by-name/ne/netlogo/package.nix @@ -1,4 +1,11 @@ -{ jre, lib, stdenv, fetchurl, makeWrapper, makeDesktopItem }: +{ + jre, + lib, + stdenv, + fetchurl, + makeWrapper, + makeDesktopItem, +}: let diff --git a/pkgs/by-name/ne/netmask/package.nix b/pkgs/by-name/ne/netmask/package.nix index c9b359cb3a2e4f..9397e44d9fd79b 100644 --- a/pkgs/by-name/ne/netmask/package.nix +++ b/pkgs/by-name/ne/netmask/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, texinfo }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + texinfo, +}: stdenv.mkDerivation rec { pname = "netmask"; diff --git a/pkgs/by-name/ne/netop/package.nix b/pkgs/by-name/ne/netop/package.nix index ac85b1e4936bd6..db2d00f6a654e6 100644 --- a/pkgs/by-name/ne/netop/package.nix +++ b/pkgs/by-name/ne/netop/package.nix @@ -1,4 +1,9 @@ -{ lib, libpcap, rustPlatform, fetchFromGitHub }: +{ + lib, + libpcap, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "netop"; diff --git a/pkgs/by-name/ne/netperf/package.nix b/pkgs/by-name/ne/netperf/package.nix index 7722ab479c5690..a1bd6255e738a1 100644 --- a/pkgs/by-name/ne/netperf/package.nix +++ b/pkgs/by-name/ne/netperf/package.nix @@ -1,4 +1,11 @@ -{ libsmbios, lib, stdenv, autoreconfHook, fetchFromGitHub, fetchpatch }: +{ + libsmbios, + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation { pname = "netperf"; diff --git a/pkgs/by-name/ne/netplan/package.nix b/pkgs/by-name/ne/netplan/package.nix index 8b6443bfd1375b..6668eeff00f514 100644 --- a/pkgs/by-name/ne/netplan/package.nix +++ b/pkgs/by-name/ne/netplan/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, fetchFromGitHub -, pkg-config -, glib -, pandoc -, systemd -, libyaml -, python3 -, libuuid -, bash-completion -, lib +{ + stdenv, + fetchFromGitHub, + pkg-config, + glib, + pandoc, + systemd, + libyaml, + python3, + libuuid, + bash-completion, + lib, }: stdenv.mkDerivation rec { @@ -32,7 +33,14 @@ stdenv.mkDerivation rec { systemd glib libyaml - (python3.withPackages (p: with p; [ pyyaml netifaces dbus-python rich ])) + (python3.withPackages ( + p: with p; [ + pyyaml + netifaces + dbus-python + rich + ] + )) libuuid bash-completion ]; diff --git a/pkgs/by-name/ne/netproc/package.nix b/pkgs/by-name/ne/netproc/package.nix index 16f8cabe5fbef6..eb49dcb019f556 100644 --- a/pkgs/by-name/ne/netproc/package.nix +++ b/pkgs/by-name/ne/netproc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation (finalAttrs: { pname = "netproc"; diff --git a/pkgs/by-name/ne/netproxrc/package.nix b/pkgs/by-name/ne/netproxrc/package.nix index 341c74d2c6646c..96eb98afd65dce 100644 --- a/pkgs/by-name/ne/netproxrc/package.nix +++ b/pkgs/by-name/ne/netproxrc/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "netproxrc"; diff --git a/pkgs/by-name/ne/netris/package.nix b/pkgs/by-name/ne/netris/package.nix index 583d6efa58fe06..ab299e8dbedba4 100644 --- a/pkgs/by-name/ne/netris/package.nix +++ b/pkgs/by-name/ne/netris/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation { pname = "netris"; diff --git a/pkgs/by-name/ne/netrw/package.nix b/pkgs/by-name/ne/netrw/package.nix index bfab84bf0221fb..4d89650f29eff6 100644 --- a/pkgs/by-name/ne/netrw/package.nix +++ b/pkgs/by-name/ne/netrw/package.nix @@ -1,7 +1,10 @@ -{ lib, stdenv, fetchurl -, checksumType ? "built-in" -, libmhash ? null -, openssl ? null +{ + lib, + stdenv, + fetchurl, + checksumType ? "built-in", + libmhash ? null, + openssl ? null, }: assert checksumType == "mhash" -> libmhash != null; @@ -15,8 +18,9 @@ stdenv.mkDerivation rec { "--with-checksum=${checksumType}" ]; - buildInputs = lib.optional (checksumType == "mhash") libmhash - ++ lib.optional (checksumType == "openssl") openssl; + buildInputs = + lib.optional (checksumType == "mhash") libmhash + ++ lib.optional (checksumType == "openssl") openssl; src = fetchurl { urls = [ diff --git a/pkgs/by-name/ne/netscanner/package.nix b/pkgs/by-name/ne/netscanner/package.nix index 32da25af82535c..7df1c4c192bc91 100644 --- a/pkgs/by-name/ne/netscanner/package.nix +++ b/pkgs/by-name/ne/netscanner/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, makeWrapper -, iw +{ + lib, + rustPlatform, + fetchFromGitHub, + makeWrapper, + iw, }: let pname = "netscanner"; @@ -24,7 +25,7 @@ rustPlatform.buildRustPackage { postFixup = '' wrapProgram $out/bin/netscanner \ - --prefix PATH : "${lib.makeBinPath [iw]}" + --prefix PATH : "${lib.makeBinPath [ iw ]}" ''; meta = { diff --git a/pkgs/by-name/ne/netselect/package.nix b/pkgs/by-name/ne/netselect/package.nix index aa8d81dc7d6813..1eaae2cf75aebc 100644 --- a/pkgs/by-name/ne/netselect/package.nix +++ b/pkgs/by-name/ne/netselect/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "netselect"; diff --git a/pkgs/by-name/ne/netsniff-ng/package.nix b/pkgs/by-name/ne/netsniff-ng/package.nix index a6bf4383b31785..98fbc042a64c47 100644 --- a/pkgs/by-name/ne/netsniff-ng/package.nix +++ b/pkgs/by-name/ne/netsniff-ng/package.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchFromGitHub -, makeWrapper -, bison -, flex -, geoip -, geolite-legacy -, libcli -, libnet -, libnetfilter_conntrack -, libnl -, libpcap -, libsodium -, liburcu -, ncurses -, pkg-config -, gnumake42 -, zlib +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + bison, + flex, + geoip, + geolite-legacy, + libcli, + libnet, + libnetfilter_conntrack, + libnl, + libpcap, + libsodium, + liburcu, + ncurses, + pkg-config, + gnumake42, + zlib, }: stdenv.mkDerivation rec { @@ -62,7 +63,10 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; # All files installed to /etc are just static data that can go in the store - makeFlags = [ "PREFIX=$(out)" "ETCDIR=$(out)/etc" ]; + makeFlags = [ + "PREFIX=$(out)" + "ETCDIR=$(out)/etc" + ]; postInstall = '' # trafgen and bpfc can call out to cpp to process config files. diff --git a/pkgs/by-name/ne/networkaudiod/package.nix b/pkgs/by-name/ne/networkaudiod/package.nix index c2566f4451eaf4..37b99d4a3546ec 100644 --- a/pkgs/by-name/ne/networkaudiod/package.nix +++ b/pkgs/by-name/ne/networkaudiod/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, autoPatchelfHook -, dpkg -, fetchurl -, lib -, alsa-lib +{ + stdenv, + autoPatchelfHook, + dpkg, + fetchurl, + lib, + alsa-lib, }: let inherit (stdenv.hostPlatform) system; @@ -13,22 +14,27 @@ stdenv.mkDerivation rec { pname = "networkaudiod"; version = "4.1.1-46"; - src = { - x86_64-linux = fetchurl { - url = "https://www.signalyst.eu/bins/naa/linux/buster/${pname}_${version}_amd64.deb"; - sha256 = "sha256-un5VcCnvCCS/KWtW991Rt9vz3flYilERmRNooEsKCkA="; - }; - aarch64-linux = fetchurl { - url = "https://www.signalyst.eu/bins/naa/linux/buster/${pname}_${version}_arm64.deb"; - sha256 = "sha256-fjSCWX9VYhVJ43N2kSqd5gfTtDJ1UiH4j5PJ9I5Skag="; - }; - }.${system} or throwSystem; + src = + { + x86_64-linux = fetchurl { + url = "https://www.signalyst.eu/bins/naa/linux/buster/${pname}_${version}_amd64.deb"; + sha256 = "sha256-un5VcCnvCCS/KWtW991Rt9vz3flYilERmRNooEsKCkA="; + }; + aarch64-linux = fetchurl { + url = "https://www.signalyst.eu/bins/naa/linux/buster/${pname}_${version}_arm64.deb"; + sha256 = "sha256-fjSCWX9VYhVJ43N2kSqd5gfTtDJ1UiH4j5PJ9I5Skag="; + }; + } + .${system} or throwSystem; unpackPhase = '' dpkg -x $src . ''; - nativeBuildInputs = [ autoPatchelfHook dpkg ]; + nativeBuildInputs = [ + autoPatchelfHook + dpkg + ]; buildInputs = [ alsa-lib diff --git a/pkgs/by-name/ne/networkd-dispatcher/package.nix b/pkgs/by-name/ne/networkd-dispatcher/package.nix index 11b0e3171916db..d2b9732f87d9ad 100644 --- a/pkgs/by-name/ne/networkd-dispatcher/package.nix +++ b/pkgs/by-name/ne/networkd-dispatcher/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, python3Packages -, asciidoc -, wrapGAppsNoGuiHook -, iw +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + python3Packages, + asciidoc, + wrapGAppsNoGuiHook, + iw, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ne/networking-ts-cxx/package.nix b/pkgs/by-name/ne/networking-ts-cxx/package.nix index 7dc6d4b11fee28..86b2b4f3e222c3 100644 --- a/pkgs/by-name/ne/networking-ts-cxx/package.nix +++ b/pkgs/by-name/ne/networking-ts-cxx/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "networking-ts-cxx"; diff --git a/pkgs/by-name/ne/networkmanager-l2tp/package.nix b/pkgs/by-name/ne/networkmanager-l2tp/package.nix index 4389b2b6209914..d44ae6a3209051 100644 --- a/pkgs/by-name/ne/networkmanager-l2tp/package.nix +++ b/pkgs/by-name/ne/networkmanager-l2tp/package.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, substituteAll -, fetchFromGitHub -, autoreconfHook -, pkg-config -, gtk3 -, gtk4 -, networkmanager -, ppp -, xl2tpd -, strongswan -, libsecret -, withGnome ? true -, libnma -, libnma-gtk4 -, glib -, openssl -, nss +{ + stdenv, + lib, + substituteAll, + fetchFromGitHub, + autoreconfHook, + pkg-config, + gtk3, + gtk4, + networkmanager, + ppp, + xl2tpd, + strongswan, + libsecret, + withGnome ? true, + libnma, + libnma-gtk4, + glib, + openssl, + nss, }: stdenv.mkDerivation rec { @@ -43,19 +44,21 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - networkmanager - ppp - glib - openssl - nss - ] ++ lib.optionals withGnome [ - gtk3 - gtk4 - libsecret - libnma - libnma-gtk4 - ]; + buildInputs = + [ + networkmanager + ppp + glib + openssl + nss + ] + ++ lib.optionals withGnome [ + gtk3 + gtk4 + libsecret + libnma + libnma-gtk4 + ]; configureFlags = [ "--with-gnome=${if withGnome then "yes" else "no"}" @@ -75,6 +78,9 @@ stdenv.mkDerivation rec { inherit (networkmanager.meta) platforms; homepage = "https://github.com/nm-l2tp/network-manager-l2tp"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ abbradar obadz ]; + maintainers = with maintainers; [ + abbradar + obadz + ]; }; } diff --git a/pkgs/by-name/ne/networkmanager-openconnect/package.nix b/pkgs/by-name/ne/networkmanager-openconnect/package.nix index 426039b19f607b..0e2a199d5c3a14 100644 --- a/pkgs/by-name/ne/networkmanager-openconnect/package.nix +++ b/pkgs/by-name/ne/networkmanager-openconnect/package.nix @@ -1,24 +1,25 @@ -{ stdenv -, lib -, fetchurl -, substituteAll -, glib -, libxml2 -, openconnect -, intltool -, pkg-config -, networkmanager -, gcr -, libsecret -, file -, gtk3 -, webkitgtk_4_1 -, libnma -, libnma-gtk4 -, gtk4 -, withGnome ? true -, gnome -, kmod +{ + stdenv, + lib, + fetchurl, + substituteAll, + glib, + libxml2, + openconnect, + intltool, + pkg-config, + networkmanager, + gcr, + libsecret, + file, + gtk3, + webkitgtk_4_1, + libnma, + libnma-gtk4, + gtk4, + withGnome ? true, + gnome, + kmod, }: stdenv.mkDerivation rec { @@ -37,20 +38,22 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ - glib - libxml2 - openconnect - networkmanager - webkitgtk_4_1 # required, for SSO - ] ++ lib.optionals withGnome [ - gtk3 - libnma - libnma-gtk4 - gtk4 - gcr - libsecret - ]; + buildInputs = + [ + glib + libxml2 + openconnect + networkmanager + webkitgtk_4_1 # required, for SSO + ] + ++ lib.optionals withGnome [ + gtk3 + libnma + libnma-gtk4 + gtk4 + gcr + libsecret + ]; nativeBuildInputs = [ intltool diff --git a/pkgs/by-name/ne/networkmanager-sstp/package.nix b/pkgs/by-name/ne/networkmanager-sstp/package.nix index 026f038ef20db9..4a8a13ac39368d 100644 --- a/pkgs/by-name/ne/networkmanager-sstp/package.nix +++ b/pkgs/by-name/ne/networkmanager-sstp/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, autoreconfHook -, fetchurl -, file -, glib -, gnome -, gtk3 -, gtk4 -, gettext -, libnma -, libnma-gtk4 -, libsecret -, networkmanager -, pkg-config -, ppp -, sstp -, withGnome ? true +{ + stdenv, + lib, + autoreconfHook, + fetchurl, + file, + glib, + gnome, + gtk3, + gtk4, + gettext, + libnma, + libnma-gtk4, + libsecret, + networkmanager, + pkg-config, + ppp, + sstp, + withGnome ? true, }: stdenv.mkDerivation rec { @@ -35,18 +36,20 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - sstp - networkmanager - glib - ppp - ] ++ lib.optionals withGnome [ - gtk3 - gtk4 - libsecret - libnma - libnma-gtk4 - ]; + buildInputs = + [ + sstp + networkmanager + glib + ppp + ] + ++ lib.optionals withGnome [ + gtk3 + gtk4 + libsecret + libnma + libnma-gtk4 + ]; postPatch = '' sed -i 's#/sbin/pppd#${ppp}/bin/pppd#' src/nm-sstp-service.c diff --git a/pkgs/by-name/ne/networkmanager_dmenu/package.nix b/pkgs/by-name/ne/networkmanager_dmenu/package.nix index a2724ed73c270d..97acb7b35c1a5f 100644 --- a/pkgs/by-name/ne/networkmanager_dmenu/package.nix +++ b/pkgs/by-name/ne/networkmanager_dmenu/package.nix @@ -1,8 +1,18 @@ -{ lib, stdenv, glib, fetchFromGitHub, networkmanager, python3Packages -, gobject-introspection, procps }: - -let inherit (python3Packages) python pygobject3; -in stdenv.mkDerivation rec { +{ + lib, + stdenv, + glib, + fetchFromGitHub, + networkmanager, + python3Packages, + gobject-introspection, + procps, +}: + +let + inherit (python3Packages) python pygobject3; +in +stdenv.mkDerivation rec { pname = "networkmanager_dmenu"; version = "2.5.0"; @@ -14,7 +24,14 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ gobject-introspection ]; - buildInputs = [ glib python pygobject3 networkmanager python3Packages.wrapPython procps ]; + buildInputs = [ + glib + python + pygobject3 + networkmanager + python3Packages.wrapPython + procps + ]; dontBuild = true; @@ -33,13 +50,12 @@ in stdenv.mkDerivation rec { wrapPythonPrograms ''; - meta = with lib; { - description = "Small script to manage NetworkManager connections with dmenu instead of nm-applet"; + description = "Small script to manage NetworkManager connections with dmenu instead of nm-applet"; mainProgram = "networkmanager_dmenu"; - homepage = "https://github.com/firecat53/networkmanager-dmenu"; - license = lib.licenses.mit; - maintainers = [ lib.maintainers.jensbin ]; - platforms = lib.platforms.all; + homepage = "https://github.com/firecat53/networkmanager-dmenu"; + license = lib.licenses.mit; + maintainers = [ lib.maintainers.jensbin ]; + platforms = lib.platforms.all; }; } diff --git a/pkgs/by-name/ne/networkmanager_strongswan/package.nix b/pkgs/by-name/ne/networkmanager_strongswan/package.nix index f46fb127208791..799c4923541051 100644 --- a/pkgs/by-name/ne/networkmanager_strongswan/package.nix +++ b/pkgs/by-name/ne/networkmanager_strongswan/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchurl -, intltool -, pkg-config -, networkmanager -, strongswanNM -, gtk3 -, gtk4 -, libsecret -, libnma -, libnma-gtk4 +{ + stdenv, + lib, + fetchurl, + intltool, + pkg-config, + networkmanager, + strongswanNM, + gtk3, + gtk4, + libsecret, + libnma, + libnma-gtk4, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ne/networkmanagerapplet/package.nix b/pkgs/by-name/ne/networkmanagerapplet/package.nix index e7234cc172fff1..252a54c71b3e55 100644 --- a/pkgs/by-name/ne/networkmanagerapplet/package.nix +++ b/pkgs/by-name/ne/networkmanagerapplet/package.nix @@ -1,26 +1,28 @@ -{ lib, stdenv -, fetchurl -, meson -, ninja -, gettext -, pkg-config -, networkmanager -, gnome -, adwaita-icon-theme -, libsecret -, polkit -, modemmanager -, libnma -, glib-networking -, gsettings-desktop-schemas -, libgudev -, jansson -, wrapGAppsHook3 -, gobject-introspection -, python3 -, gtk3 -, libayatana-appindicator -, glib +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + gettext, + pkg-config, + networkmanager, + gnome, + adwaita-icon-theme, + libsecret, + polkit, + modemmanager, + libnma, + glib-networking, + gsettings-desktop-schemas, + libgudev, + jansson, + wrapGAppsHook3, + gobject-introspection, + python3, + gtk3, + libayatana-appindicator, + glib, }: stdenv.mkDerivation rec { @@ -37,7 +39,10 @@ stdenv.mkDerivation rec { "-Dappindicator=yes" ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; buildInputs = [ libnma diff --git a/pkgs/by-name/ne/networkminer/deps.nix b/pkgs/by-name/ne/networkminer/deps.nix index 196ca32bf1ead8..db2372c61a38f4 100644 --- a/pkgs/by-name/ne/networkminer/deps.nix +++ b/pkgs/by-name/ne/networkminer/deps.nix @@ -1,8 +1,21 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies"; version = "1.0.2"; sha256 = "0i42rn8xmvhn08799manpym06kpw89qy9080myyy2ngy565pqh0a"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies.net461"; version = "1.0.2"; sha256 = "0js3dp26nszx82q0phv7hmsm5z23dva7javbmk6a91lbkm07y8p2"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies.net472"; version = "1.0.2"; sha256 = "1dny43jksy6dm9zrkdm8j80gb25w6wdvjlxnphj7ngf0fbg3dd2c"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies"; + version = "1.0.2"; + sha256 = "0i42rn8xmvhn08799manpym06kpw89qy9080myyy2ngy565pqh0a"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies.net461"; + version = "1.0.2"; + sha256 = "0js3dp26nszx82q0phv7hmsm5z23dva7javbmk6a91lbkm07y8p2"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies.net472"; + version = "1.0.2"; + sha256 = "1dny43jksy6dm9zrkdm8j80gb25w6wdvjlxnphj7ngf0fbg3dd2c"; + }) ] diff --git a/pkgs/by-name/ne/networkminer/package.nix b/pkgs/by-name/ne/networkminer/package.nix index c3be596118ff04..07e5d371547d5c 100644 --- a/pkgs/by-name/ne/networkminer/package.nix +++ b/pkgs/by-name/ne/networkminer/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildDotnetModule -, fetchurl -, unzip -, dos2unix -, msbuild -, mono -, dotnetCorePackages +{ + lib, + buildDotnetModule, + fetchurl, + unzip, + dos2unix, + msbuild, + mono, + dotnetCorePackages, }: buildDotnetModule rec { pname = "networkminer"; @@ -14,13 +15,19 @@ buildDotnetModule rec { src = fetchurl { # Upstream does not provide versioned releases, a mirror has been uploaded # to archive.org - url = "https://archive.org/download/networkminer-${lib.replaceStrings ["."] ["-"] version}/NetworkMiner_${lib.replaceStrings ["."] ["-"] version}_source.zip"; + url = "https://archive.org/download/networkminer-${ + lib.replaceStrings [ "." ] [ "-" ] version + }/NetworkMiner_${lib.replaceStrings [ "." ] [ "-" ] version}_source.zip"; sha256 = "1n2312acq5rq0jizlcfk0crslx3wgcsd836p47nk3pnapzw0cqvv"; }; dotnet-sdk = dotnetCorePackages.sdk_6_0; - nativeBuildInputs = [ unzip dos2unix msbuild ]; + nativeBuildInputs = [ + unzip + dos2unix + msbuild + ]; patches = [ # Store application data in XDG_DATA_DIRS instead of trying to write to nix store diff --git a/pkgs/by-name/ne/neural-amp-modeler-lv2/package.nix b/pkgs/by-name/ne/neural-amp-modeler-lv2/package.nix index dbf7a91789189a..4cc5b314618664 100644 --- a/pkgs/by-name/ne/neural-amp-modeler-lv2/package.nix +++ b/pkgs/by-name/ne/neural-amp-modeler-lv2/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ne/neuron/package.nix b/pkgs/by-name/ne/neuron/package.nix index fe5de3c68fab5f..d6b7098654bc30 100644 --- a/pkgs/by-name/ne/neuron/package.nix +++ b/pkgs/by-name/ne/neuron/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, readline -, xorg -, mpi -, cmake -, bison -, flex -, git -, perl -, gsl -, xcbuild -, python3 -, useMpi ? false -, useIv ? true -, useCore ? false -, useRx3d ? false +{ + lib, + stdenv, + fetchFromGitHub, + readline, + xorg, + mpi, + cmake, + bison, + flex, + git, + perl, + gsl, + xcbuild, + python3, + useMpi ? false, + useIv ? true, + useCore ? false, + useRx3d ? false, }: let inherit (lib.lists) optionals; @@ -28,13 +29,18 @@ stdenv.mkDerivation (finalAttrs: { # format is for pythonModule conversion format = "other"; - nativeBuildInputs = [ - cmake - bison - flex - git - ] ++ optionals useCore [ perl gsl ] - ++ optionals stdenv.hostPlatform.isDarwin [ xcbuild ]; + nativeBuildInputs = + [ + cmake + bison + flex + git + ] + ++ optionals useCore [ + perl + gsl + ] + ++ optionals stdenv.hostPlatform.isDarwin [ xcbuild ]; buildInputs = optionals useIv [ xorg.libX11.dev @@ -42,21 +48,25 @@ stdenv.mkDerivation (finalAttrs: { xorg.libXext.dev ]; - propagatedBuildInputs = [ - readline - python3 - python3.pkgs.wheel - python3.pkgs.setuptools - python3.pkgs.scikit-build - python3.pkgs.matplotlib - ] ++ optionals useMpi [ - mpi - ] ++ optionals useMpi [ - python3.pkgs.mpi4py - ] ++ optionals useRx3d [ - python3.pkgs.cython_0 # NOTE: cython<3 is required as of 8.2.6 - python3.pkgs.numpy - ]; + propagatedBuildInputs = + [ + readline + python3 + python3.pkgs.wheel + python3.pkgs.setuptools + python3.pkgs.scikit-build + python3.pkgs.matplotlib + ] + ++ optionals useMpi [ + mpi + ] + ++ optionals useMpi [ + python3.pkgs.mpi4py + ] + ++ optionals useRx3d [ + python3.pkgs.cython_0 # NOTE: cython<3 is required as of 8.2.6 + python3.pkgs.numpy + ]; # Patch build shells for cmake (bin, src, cmake) and submodules (external) postPatch = '' @@ -104,7 +114,10 @@ stdenv.mkDerivation (finalAttrs: { sourceProvenance = with sourceTypes; [ fromSource ]; license = licenses.bsd3; homepage = "http://www.neuron.yale.edu/neuron"; - maintainers = with maintainers; [ adev davidcromp ]; + maintainers = with maintainers; [ + adev + davidcromp + ]; platforms = platforms.all; }; }) diff --git a/pkgs/by-name/ne/neverball/package.nix b/pkgs/by-name/ne/neverball/package.nix index e0555ded7bee09..167023a22f6a9e 100644 --- a/pkgs/by-name/ne/neverball/package.nix +++ b/pkgs/by-name/ne/neverball/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchurl, fetchpatch, SDL2, libGL, libpng, libjpeg, SDL2_ttf, libvorbis, gettext -, physfs }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + SDL2, + libGL, + libpng, + libjpeg, + SDL2_ttf, + libvorbis, + gettext, + physfs, +}: stdenv.mkDerivation rec { pname = "neverball"; @@ -18,7 +30,16 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ libpng SDL2 libGL libjpeg SDL2_ttf libvorbis gettext physfs ]; + buildInputs = [ + libpng + SDL2 + libGL + libjpeg + SDL2_ttf + libvorbis + gettext + physfs + ]; dontPatchELF = true; diff --git a/pkgs/by-name/ne/neverest/package.nix b/pkgs/by-name/ne/neverest/package.nix index 5c4bd81fa83c42..10d472e8e9680c 100644 --- a/pkgs/by-name/ne/neverest/package.nix +++ b/pkgs/by-name/ne/neverest/package.nix @@ -1,15 +1,16 @@ -{ lib -, rustPlatform -, fetchFromSourcehut -, stdenv -, pkg-config -, darwin -, installShellFiles -, installShellCompletions ? stdenv.buildPlatform.canExecute stdenv.hostPlatform -, installManPages ? stdenv.buildPlatform.canExecute stdenv.hostPlatform -, notmuch -, buildNoDefaultFeatures ? false -, buildFeatures ? [] +{ + lib, + rustPlatform, + fetchFromSourcehut, + stdenv, + pkg-config, + darwin, + installShellFiles, + installShellCompletions ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, + installManPages ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, + notmuch, + buildNoDefaultFeatures ? false, + buildFeatures ? [ ], }: rustPlatform.buildRustPackage rec { @@ -30,27 +31,38 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-i5or8oBtjGqOfTfwB7dYXn/OPgr5WEWNEvC0WdCCG+c="; - nativeBuildInputs = [ pkg-config ] - ++ lib.optional (installManPages || installShellCompletions) installShellFiles; + nativeBuildInputs = [ + pkg-config + ] ++ lib.optional (installManPages || installShellCompletions) installShellFiles; - buildInputs = [ ] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ AppKit Cocoa Security ]) + buildInputs = + [ ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + AppKit + Cocoa + Security + ] + ) ++ lib.optional (builtins.elem "notmuch" buildFeatures) notmuch; # TODO: unit tests temporarily broken, remove this line for the next # beta.2 release doCheck = false; - postInstall = lib.optionalString installManPages '' - mkdir -p $out/man - $out/bin/neverest man $out/man - installManPage $out/man/* - '' + lib.optionalString installShellCompletions '' - installShellCompletion --cmd neverest \ - --bash <($out/bin/neverest completion bash) \ - --fish <($out/bin/neverest completion fish) \ - --zsh <($out/bin/neverest completion zsh) - ''; + postInstall = + lib.optionalString installManPages '' + mkdir -p $out/man + $out/bin/neverest man $out/man + installManPage $out/man/* + '' + + lib.optionalString installShellCompletions '' + installShellCompletion --cmd neverest \ + --bash <($out/bin/neverest completion bash) \ + --fish <($out/bin/neverest completion fish) \ + --zsh <($out/bin/neverest completion zsh) + ''; meta = with lib; { description = "CLI to synchronize, backup and restore emails"; diff --git a/pkgs/by-name/ne/new-session-manager/package.nix b/pkgs/by-name/ne/new-session-manager/package.nix index 6e24f0c90d292d..343c84db10d08c 100644 --- a/pkgs/by-name/ne/new-session-manager/package.nix +++ b/pkgs/by-name/ne/new-session-manager/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, meson, pkg-config, ninja, liblo, libjack2, fltk }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + pkg-config, + ninja, + liblo, + libjack2, + fltk, +}: stdenv.mkDerivation rec { pname = "new-session-manager"; @@ -11,9 +21,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-5G2GlBuKjC/r1SMm78JKia7bMA97YcvUR5l6zBucemw="; }; - nativeBuildInputs = [ meson pkg-config ninja ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + ]; - buildInputs = [ liblo libjack2 fltk ]; + buildInputs = [ + liblo + libjack2 + fltk + ]; hardeningDisable = [ "format" ]; @@ -22,6 +40,6 @@ stdenv.mkDerivation rec { description = "Session manager designed for audio applications"; maintainers = [ maintainers._6AA4FD ]; license = licenses.gpl3Plus; - platforms = ["x86_64-linux"]; + platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/by-name/ne/newcomputermodern/package.nix b/pkgs/by-name/ne/newcomputermodern/package.nix index 660230e40332ee..c35f9989e50e24 100644 --- a/pkgs/by-name/ne/newcomputermodern/package.nix +++ b/pkgs/by-name/ne/newcomputermodern/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchgit -, fontforge +{ + lib, + stdenvNoCC, + fetchgit, + fontforge, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ne/newman/package.nix b/pkgs/by-name/ne/newman/package.nix index 31805a4b33101b..002dd0ad82f50c 100644 --- a/pkgs/by-name/ne/newman/package.nix +++ b/pkgs/by-name/ne/newman/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/ne/newrelic-sysmond/package.nix b/pkgs/by-name/ne/newrelic-sysmond/package.nix index 35a6a5e828e5c2..73218723f222bc 100644 --- a/pkgs/by-name/ne/newrelic-sysmond/package.nix +++ b/pkgs/by-name/ne/newrelic-sysmond/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "newrelic-sysmond"; diff --git a/pkgs/by-name/ne/newsraft/package.nix b/pkgs/by-name/ne/newsraft/package.nix index 0f2a251df3ba16..26a1e1f041143b 100644 --- a/pkgs/by-name/ne/newsraft/package.nix +++ b/pkgs/by-name/ne/newsraft/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitea -, pkg-config -, curl -, expat -, gumbo -, ncurses -, sqlite -, yajl -, nix-update-script +{ + lib, + stdenv, + fetchFromGitea, + pkg-config, + curl, + expat, + gumbo, + ncurses, + sqlite, + yajl, + nix-update-script, }: stdenv.mkDerivation (finalAttrs: { @@ -24,11 +25,18 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ curl expat gumbo ncurses sqlite yajl ]; + buildInputs = [ + curl + expat + gumbo + ncurses + sqlite + yajl + ]; makeFlags = [ "PREFIX=$(out)" ]; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = with lib; { description = "Feed reader for terminal"; diff --git a/pkgs/by-name/ne/newtonwars/package.nix b/pkgs/by-name/ne/newtonwars/package.nix index 62d553f402f615..5d0f0ece621e02 100644 --- a/pkgs/by-name/ne/newtonwars/package.nix +++ b/pkgs/by-name/ne/newtonwars/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, libglut -, libGLU -, libGL +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + libglut, + libGLU, + libGL, }: stdenv.mkDerivation { @@ -19,7 +20,11 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ libglut libGL libGLU ]; + buildInputs = [ + libglut + libGL + libGLU + ]; patchPhase = '' sed -i "s;font24.raw;$out/share/font24.raw;g" display.c diff --git a/pkgs/by-name/ne/nex/package.nix b/pkgs/by-name/ne/nex/package.nix index 6a341566087846..e7487144b5c3ac 100644 --- a/pkgs/by-name/ne/nex/package.nix +++ b/pkgs/by-name/ne/nex/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: # upstream is pretty stale, but it still works, so until they merge module # support we have to use gopath: see blynn/nex#57 diff --git a/pkgs/by-name/ne/nextdns/package.nix b/pkgs/by-name/ne/nextdns/package.nix index 560a134a9dd460..0b901e2b41708d 100644 --- a/pkgs/by-name/ne/nextdns/package.nix +++ b/pkgs/by-name/ne/nextdns/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "nextdns"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-U5LJF1RX0ZS0PhjQTZKXrJo89WPfSZaVbgskWcYNlJY="; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; meta = with lib; { description = "NextDNS DNS/53 to DoH Proxy"; diff --git a/pkgs/by-name/ne/nextflow/package.nix b/pkgs/by-name/ne/nextflow/package.nix index 9fe2c20fae550c..612c1c2913c12d 100644 --- a/pkgs/by-name/ne/nextflow/package.nix +++ b/pkgs/by-name/ne/nextflow/package.nix @@ -60,7 +60,7 @@ stdenv.mkDerivation (finalAttrs: { # See https://github.com/NixOS/nixpkgs/pull/339197#discussion_r1747749061 gradleUpdateTask = "pack"; # The installer attempts to copy a final JAR to $HOME/.nextflow/... - gradleFlags = ["-Duser.home=\$TMPDIR"]; + gradleFlags = [ "-Duser.home=\$TMPDIR" ]; preBuild = '' # See Makefile (`make pack`) export BUILD_PACK=1 diff --git a/pkgs/by-name/ne/nextpnr/package.nix b/pkgs/by-name/ne/nextpnr/package.nix index b3dee524f7a74c..7f49f10a542709 100644 --- a/pkgs/by-name/ne/nextpnr/package.nix +++ b/pkgs/by-name/ne/nextpnr/package.nix @@ -1,58 +1,80 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, boost, python3, eigen, python3Packages -, icestorm, trellis -, llvmPackages - -, enableGui ? false -, wrapQtAppsHook ? null -, qtbase ? null -, OpenGL ? null +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + python3, + eigen, + python3Packages, + icestorm, + trellis, + llvmPackages, + + enableGui ? false, + wrapQtAppsHook ? null, + qtbase ? null, + OpenGL ? null, }: let - boostPython = boost.override { python = python3; enablePython = true; }; + boostPython = boost.override { + python = python3; + enablePython = true; + }; pname = "nextpnr"; version = "0.7"; main_src = fetchFromGitHub { owner = "YosysHQ"; - repo = "nextpnr"; - rev = "${pname}-${version}"; - hash = "sha256-YIAQcCg9RjvCys1bQ3x+sTgTmnmEeXVbt9Lr6wtg1pA="; - name = "nextpnr"; + repo = "nextpnr"; + rev = "${pname}-${version}"; + hash = "sha256-YIAQcCg9RjvCys1bQ3x+sTgTmnmEeXVbt9Lr6wtg1pA="; + name = "nextpnr"; }; test_src = fetchFromGitHub { - owner = "YosysHQ"; - repo = "nextpnr-tests"; - rev = "00c55a9eb9ea2e062b51fe0d64741412b185d95d"; + owner = "YosysHQ"; + repo = "nextpnr-tests"; + rev = "00c55a9eb9ea2e062b51fe0d64741412b185d95d"; hash = "sha256-83suMftMtnaRFq3T2/I7Uahb11WZlXhwYt6Q/rqi2Yo="; - name = "nextpnr-tests"; + name = "nextpnr-tests"; }; in stdenv.mkDerivation rec { inherit pname version; - srcs = [ main_src test_src ]; + srcs = [ + main_src + test_src + ]; sourceRoot = main_src.name; - nativeBuildInputs - = [ cmake python3 ] - ++ (lib.optional enableGui wrapQtAppsHook); - buildInputs - = [ boostPython eigen python3Packages.apycula ] + nativeBuildInputs = [ + cmake + python3 + ] ++ (lib.optional enableGui wrapQtAppsHook); + buildInputs = + [ + boostPython + eigen + python3Packages.apycula + ] ++ (lib.optional enableGui qtbase) ++ (lib.optional stdenv.cc.isClang llvmPackages.openmp); - cmakeFlags = let - # the specified version must always start with "nextpnr-", so add it if - # missing (e.g. if the user overrides with a git hash) - rev = main_src.rev; - version = if (lib.hasPrefix "nextpnr-" rev) then rev else "nextpnr-${rev}"; - in ["-DCURRENT_GIT_VERSION=${version}" + cmakeFlags = + let + # the specified version must always start with "nextpnr-", so add it if + # missing (e.g. if the user overrides with a git hash) + rev = main_src.rev; + version = if (lib.hasPrefix "nextpnr-" rev) then rev else "nextpnr-${rev}"; + in + [ + "-DCURRENT_GIT_VERSION=${version}" "-DARCH=generic;ice40;ecp5;gowin;himbaechel" "-DBUILD_TESTS=ON" "-DICESTORM_INSTALL_PREFIX=${icestorm}" @@ -65,8 +87,9 @@ stdenv.mkDerivation rec { "-DHIMBAECHEL_GOWIN_DEVICES=all" ] ++ (lib.optional enableGui "-DBUILD_GUI=ON") - ++ (lib.optional (enableGui && stdenv.hostPlatform.isDarwin) - "-DOPENGL_INCLUDE_DIR=${OpenGL}/Library/Frameworks"); + ++ (lib.optional ( + enableGui && stdenv.hostPlatform.isDarwin + ) "-DOPENGL_INCLUDE_DIR=${OpenGL}/Library/Frameworks"); patchPhase = with builtins; '' # use PyPy for icestorm if enabled @@ -92,9 +115,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Place and route tool for FPGAs"; - homepage = "https://github.com/yosyshq/nextpnr"; - license = licenses.isc; - platforms = platforms.all; + homepage = "https://github.com/yosyshq/nextpnr"; + license = licenses.isc; + platforms = platforms.all; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/ne/nexttrace/package.nix b/pkgs/by-name/ne/nexttrace/package.nix index f82444e68feb4d..42535a4edb192a 100644 --- a/pkgs/by-name/ne/nexttrace/package.nix +++ b/pkgs/by-name/ne/nexttrace/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGo122Module, fetchFromGitHub }: +{ + lib, + buildGo122Module, + fetchFromGitHub, +}: buildGo122Module rec { pname = "nexttrace"; @@ -32,4 +36,3 @@ buildGo122Module rec { mainProgram = "nexttrace"; }; } - diff --git a/pkgs/by-name/ne/nexuiz/package.nix b/pkgs/by-name/ne/nexuiz/package.nix index 8a178d475ee52f..7a608b453b8d26 100644 --- a/pkgs/by-name/ne/nexuiz/package.nix +++ b/pkgs/by-name/ne/nexuiz/package.nix @@ -1,20 +1,39 @@ -{ lib, stdenv, fetchurl -, # required for both - unzip, zlib, curl, libjpeg, libpng, libvorbis, libtheora -, libogg, libmodplug -, # glx - libX11, libGLU, libGL, libXpm, libXext, libXxf86vm, libXxf86dga, alsa-lib -, # sdl - SDL -, # icon - copyDesktopItems, makeDesktopItem +{ + lib, + stdenv, + fetchurl, + # required for both + unzip, + zlib, + curl, + libjpeg, + libpng, + libvorbis, + libtheora, + libogg, + libmodplug, + # glx + libX11, + libGLU, + libGL, + libXpm, + libXext, + libXxf86vm, + libXxf86dga, + alsa-lib, + # sdl + SDL, + # icon + copyDesktopItems, + makeDesktopItem, }: let version = "2.5.2"; version_short = lib.replaceStrings [ "." ] [ "" ] version; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "nexuiz"; inherit version; @@ -23,10 +42,20 @@ in stdenv.mkDerivation { sha256 = "0010jrxc68qqinkvdh1qn2b8z3sa5v1kcd8d1m4llp3pr6y7xqm5"; }; - nativeBuildInputs = [ unzip copyDesktopItems ]; + nativeBuildInputs = [ + unzip + copyDesktopItems + ]; buildInputs = [ # glx - libX11 libGLU libGL libXpm libXext libXxf86vm libXxf86dga alsa-lib + libX11 + libGLU + libGL + libXpm + libXext + libXxf86vm + libXxf86dga + alsa-lib # sdl SDL ]; @@ -80,7 +109,10 @@ in stdenv.mkDerivation { icon = "nexuiz"; desktopName = "Nexuiz"; comment = "A free first-person shooter video game developed and published by Alientrap"; - categories = [ "Game" "ActionGame" ]; + categories = [ + "Game" + "ActionGame" + ]; }) ]; diff --git a/pkgs/by-name/ne/nexusmods-app/deps.nix b/pkgs/by-name/ne/nexusmods-app/deps.nix index 2cc3c42480e857..4d97882c5b4ca2 100644 --- a/pkgs/by-name/ne/nexusmods-app/deps.nix +++ b/pkgs/by-name/ne/nexusmods-app/deps.nix @@ -1,639 +1,3176 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Argon"; version = "0.24.2"; hash = "sha256-QUwH6v4XKPU9T/mO/TNvMhoUv8yZHMr/Yg39NO+YV+0="; }) - (fetchNuGet { pname = "AutoFixture"; version = "4.18.1"; hash = "sha256-reP+aoYiPcIj4GbCIhjd5/OhuWVLCtD4hKuLPHe2EXI="; }) - (fetchNuGet { pname = "AutoFixture.Xunit2"; version = "4.18.1"; hash = "sha256-5hZm1Rx4n0e2JNsJ6lketE3c8z6AFdquTgKCQORqRfc="; }) - (fetchNuGet { pname = "Avalonia"; version = "11.0.0"; hash = "sha256-7QE0MtD1QDiG3gRx5xW33E33BXyEtASQSw+Wi3Lmy3E="; }) - (fetchNuGet { pname = "Avalonia"; version = "11.1.3"; hash = "sha256-kz+k/vkuWoL0XBvRT8SadMOmmRCFk9W/J4k/IM6oYX0="; }) - (fetchNuGet { pname = "Avalonia"; version = "11.2.0"; hash = "sha256-kG3tnsLdodlvIjYd5feBZ0quGd2FsvV8FIy7uD5UZ5Q="; }) - (fetchNuGet { pname = "Avalonia"; version = "11.2.1"; hash = "sha256-KdjhwDKlii12v7HNI3NsYAM1qYoXKRsVN2scQJbYMTc="; }) - (fetchNuGet { pname = "Avalonia.Angle.Windows.Natives"; version = "2.1.22045.20230930"; hash = "sha256-RxPcWUT3b/+R3Tu5E5ftpr5ppCLZrhm+OTsi0SwW3pc="; }) - (fetchNuGet { pname = "Avalonia.AvaloniaEdit"; version = "11.1.0"; hash = "sha256-K9+hK+4aK93dyuGytYvVU25daz605+KN54hmwQYXFF8="; }) - (fetchNuGet { pname = "Avalonia.BuildServices"; version = "0.0.28"; hash = "sha256-7NQWQl3xrBDOXhGihCkt5DIrws48KyDGon/7+gPzMDU="; }) - (fetchNuGet { pname = "Avalonia.BuildServices"; version = "0.0.29"; hash = "sha256-WPHRMNowRnYSCh88DWNBCltWsLPyOfzXGzBqLYE7tRY="; }) - (fetchNuGet { pname = "Avalonia.Controls.ColorPicker"; version = "11.2.1"; hash = "sha256-yhjVW5pH8Y0JF1vbfcdL5MQfx24wb+Lkp8OBo51he8U="; }) - (fetchNuGet { pname = "Avalonia.Controls.DataGrid"; version = "11.2.1"; hash = "sha256-IFzA7ztuhgddckQV9DlwkUTSk3RQqkJddCHAtu9yhbY="; }) - (fetchNuGet { pname = "Avalonia.Controls.TreeDataGrid"; version = "11.0.10"; hash = "sha256-1R2AFOKQQPemN7qXsdxCGXcfMSRztRiC86DLqiV6CpY="; }) - (fetchNuGet { pname = "Avalonia.Desktop"; version = "11.2.1"; hash = "sha256-Bu4ZEu81g6oWnxd+ew9BZ8zwYETjY8InQsaYvYnGqX4="; }) - (fetchNuGet { pname = "Avalonia.Diagnostics"; version = "11.2.1"; hash = "sha256-gJhi2clOc+a4NDRZfEoT5BwLTq8DLAWtaxo5FI/OJaY="; }) - (fetchNuGet { pname = "Avalonia.FreeDesktop"; version = "11.2.1"; hash = "sha256-2j9VfG8uD2BVF+p9REPQ4dp8E41vUh+R3Lh6v5AVmHA="; }) - (fetchNuGet { pname = "Avalonia.Headless"; version = "11.2.1"; hash = "sha256-3nPxjkPgeH1gJie7b39ezGMe12ZHc5lhuQbYDkoYxME="; }) - (fetchNuGet { pname = "Avalonia.Labs.Panels"; version = "11.2.0"; hash = "sha256-DhzjF4nhq8XXrCVHh9Eu1NTjVF2oPDNoto4BDQU7EJk="; }) - (fetchNuGet { pname = "Avalonia.Native"; version = "11.2.1"; hash = "sha256-bBJsvp6gHfBcAWPNKpAAFCk1Wi0gP3tw4qimI93px0U="; }) - (fetchNuGet { pname = "Avalonia.ReactiveUI"; version = "11.2.1"; hash = "sha256-zEO6YkOuWdSj22KgvKO54UCHnw4rn9F3cd8xXsKRe7s="; }) - (fetchNuGet { pname = "Avalonia.Remote.Protocol"; version = "11.0.0"; hash = "sha256-gkVpdbk/0RDM7Hhq0jwZwltDpTsGRmbX+ZFTjWYYoKw="; }) - (fetchNuGet { pname = "Avalonia.Remote.Protocol"; version = "11.2.1"; hash = "sha256-RlO65QbExBdjEUY66CTlHefRdTZWzZbN4ksibVXxKv4="; }) - (fetchNuGet { pname = "Avalonia.Skia"; version = "11.0.0"; hash = "sha256-A01nrs3Ij1eTo6tPmu7++T1K+Wo/H/9LvpeuOUGbQeU="; }) - (fetchNuGet { pname = "Avalonia.Skia"; version = "11.2.0"; hash = "sha256-rNR+l+vLtlzTU+F51FpOi4Ujy7nR5+lbTc3NQte8s/o="; }) - (fetchNuGet { pname = "Avalonia.Skia"; version = "11.2.1"; hash = "sha256-F8Q4q5MaeyCkAm4rc6dPG1DhH5mZMvGzzyr2Z3AUe8s="; }) - (fetchNuGet { pname = "Avalonia.Svg.Skia"; version = "11.2.0"; hash = "sha256-bbmOWYlVZyQ65BVTYW7BPr++VoM3VwqQLeMzZ6ZnI/o="; }) - (fetchNuGet { pname = "Avalonia.Themes.Fluent"; version = "11.2.1"; hash = "sha256-yDCJJ9OkL5EIEXr05pdnOK1p+Yp7YIRJn4MVjLX84kE="; }) - (fetchNuGet { pname = "Avalonia.Themes.Simple"; version = "11.2.1"; hash = "sha256-cdMQ03nOT8jL9cnZrntpzfwgMF/dctE9610eXPV60tA="; }) - (fetchNuGet { pname = "Avalonia.Win32"; version = "11.2.1"; hash = "sha256-QsQXXKz8vqKwaijR/fZINXHH7Hripwdm+92i9f1k3Xg="; }) - (fetchNuGet { pname = "Avalonia.X11"; version = "11.2.1"; hash = "sha256-Y2Zem7GhWFHHUwwDT1qUldUCRt8vWZZXi3Fxq+p/Pdg="; }) - (fetchNuGet { pname = "AvaloniaEdit.TextMate"; version = "11.1.0"; hash = "sha256-Nv52bUxA02VcsKCbMqEAkNBl46gznSivRZ3llLHrhkM="; }) - (fetchNuGet { pname = "Bannerlord.LauncherManager"; version = "1.0.138"; hash = "sha256-U954PUK8oq1mFBqNjONMXi1DYSudT7gjpueWYBIXDdo="; }) - (fetchNuGet { pname = "Bannerlord.LauncherManager.Localization"; version = "1.0.138"; hash = "sha256-i7OhCR6pceJU7xyaY1pi67PLSnyDX5YDCIrbHw1Jcuc="; }) - (fetchNuGet { pname = "Bannerlord.LauncherManager.Models"; version = "1.0.138"; hash = "sha256-mo7Xmj7Ntxgy2/aMzywuyCJ9w/Y1FzbhKOf7fR6ebjw="; }) - (fetchNuGet { pname = "Bannerlord.ModuleManager"; version = "5.0.225"; hash = "sha256-Kpc2iwgylMJ0w8aL5QkmwHnRsfRXzhV5lFxpbEv0OcU="; }) - (fetchNuGet { pname = "Bannerlord.ModuleManager"; version = "6.0.242"; hash = "sha256-nHBchr6mLQNOWEyfPGi4nzspaIviQY4j+fGJkUTN0Bs="; }) - (fetchNuGet { pname = "Bannerlord.ModuleManager.Models"; version = "5.0.221"; hash = "sha256-CWlslG730Ife/Q5ILmNE38IcFikWqlfIqRm6/UwZkzM="; }) - (fetchNuGet { pname = "Bannerlord.ModuleManager.Models"; version = "6.0.242"; hash = "sha256-iRTxQ7VhrYziaAy3jzD7qEXzq6bOM8eIrB6kyZMurkY="; }) - (fetchNuGet { pname = "BenchmarkDotNet"; version = "0.14.0"; hash = "sha256-Ynfhr0OsW0dKp81caryZXcrBJsA2YScuKQOCiLVg1rI="; }) - (fetchNuGet { pname = "BenchmarkDotNet.Annotations"; version = "0.14.0"; hash = "sha256-BKtno0khZ2jZtXF05l9/vsYjbQIqxAimoaSkxyx6L9A="; }) - (fetchNuGet { pname = "BitFaster.Caching"; version = "2.5.2"; hash = "sha256-rZz3zNPt7DB+H5VDpI3nOrh5Nl4XYvU50CJXGfl3+5A="; }) - (fetchNuGet { pname = "BsDiff"; version = "1.1.0"; hash = "sha256-JWmzAE+5k8BeGicl4rQNK3Q5F9+VnBpTtUwlKs72pmI="; }) - (fetchNuGet { pname = "Castle.Core"; version = "5.1.1"; hash = "sha256-oVkQB+ON7S6Q27OhXrTLaxTL0kWB58HZaFFuiw4iTrE="; }) - (fetchNuGet { pname = "CliWrap"; version = "3.6.7"; hash = "sha256-9j3GILP25inLJoQe0E8sF8egVt8ISqEQBGdIShev4Mk="; }) - (fetchNuGet { pname = "ColorDocument.Avalonia"; version = "11.0.3-a1"; hash = "sha256-Pkh5FX+4pBzep5oCCyhIiR559QyFCEb1vrfEgG0wREw="; }) - (fetchNuGet { pname = "ColorTextBlock.Avalonia"; version = "11.0.3-a1"; hash = "sha256-fWJuApxnJLISayQJIKEBVOt/t1Qyj+0s+RezZkMnPio="; }) - (fetchNuGet { pname = "CommandLineParser"; version = "2.9.1"; hash = "sha256-ApU9y1yX60daSjPk3KYDBeJ7XZByKW8hse9NRZGcjeo="; }) - (fetchNuGet { pname = "coverlet.collector"; version = "6.0.2"; hash = "sha256-LdSQUrOmjFug47LjtqgtN2MM6BcfG0HR5iL+prVHlDo="; }) - (fetchNuGet { pname = "DiffEngine"; version = "15.5.3"; hash = "sha256-oZG++i9oWBJhSPHERAQwVODA0GWtp//r2oHpnjgmCeA="; }) - (fetchNuGet { pname = "DiffPlex"; version = "1.7.2"; hash = "sha256-Vsn81duAmPIPkR40h5bEz7hgtF5Kt5nAAGhQZrQbqxE="; }) - (fetchNuGet { pname = "DynamicData"; version = "8.3.27"; hash = "sha256-iPZfL1x36PLf5Lq96zRFvR5OLcoRn7OdJIao98X8wac="; }) - (fetchNuGet { pname = "DynamicData"; version = "8.4.1"; hash = "sha256-r+haH5VlmZFJTEJ3UedsYybw+oddn/CSvfm6x7PrrQ4="; }) - (fetchNuGet { pname = "DynamicData"; version = "9.0.1"; hash = "sha256-dvo4eSHg8S9oS5QhvfCrbV+y7BVtlYRwH7PN7N1GubM="; }) - (fetchNuGet { pname = "DynamicData"; version = "9.0.4"; hash = "sha256-3pyiJeWRwfaT7p1ArsoR13aI78Jo13aHOEw3BelTS9g="; }) - (fetchNuGet { pname = "EmptyFiles"; version = "8.5.0"; hash = "sha256-mLraPiJa1JiXOWQ17GUp8MWuBNrIjcYYjItQRfMjP8s="; }) - (fetchNuGet { pname = "ExCSS"; version = "4.2.3"; hash = "sha256-M/H6P5p7qqdFz/fgAI2MMBWQ7neN/GIieYSSxxjsM9I="; }) - (fetchNuGet { pname = "Fare"; version = "2.1.1"; hash = "sha256-n9X3GE2qsT2wpmDymD1AyCYcOoY/c0+t+aIWLiaST70="; }) - (fetchNuGet { pname = "FetchBannerlordVersion"; version = "1.0.6.46"; hash = "sha256-NS3B8XD4Y398dOXUdjstJ8xrZ+WLGHtGBl+Ewj8agh0="; }) - (fetchNuGet { pname = "FetchBannerlordVersion.Models"; version = "1.0.6.46"; hash = "sha256-VgTNwXUHGgtoBoLCcXVGgph5Mf36oYYqhISmEgUQMk8="; }) - (fetchNuGet { pname = "FluentAssertions"; version = "5.0.0"; hash = "sha256-jmGbSHbZhonYWIxqqux8ZOBVY2GNEG9eppNsIn6wEBc="; }) - (fetchNuGet { pname = "FluentAssertions"; version = "6.12.2"; hash = "sha256-yvbnZapTF610zG8YhMOESn0iXudX4xVCdoSKVo6eu+w="; }) - (fetchNuGet { pname = "FluentAssertions.Analyzers"; version = "0.34.1"; hash = "sha256-4n26IoSLJRLxyPDyJwF7T+za5xbHO27qM7CarniTADk="; }) - (fetchNuGet { pname = "FluentAssertions.OneOf"; version = "0.0.5"; hash = "sha256-T/yzpRPwEKh0r6JUPgH2GYkSt36PqOZYr9Qi0grGczo="; }) - (fetchNuGet { pname = "FluentResults"; version = "3.15.2"; hash = "sha256-NhS7sLhgXDAI4Qwb285HWRtPfUDN6K0tTkKx2QRsI9w="; }) - (fetchNuGet { pname = "Fody"; version = "6.8.0"; hash = "sha256-2laYscz0i0LalGTAup7dsh6XlYRZSojYpp8XOwZJJfg="; }) - (fetchNuGet { pname = "FomodInstaller.Interface"; version = "1.0.0"; hash = "sha256-ChhqiNGmj+deuIIYXJWsz7Xmolv9YaeLUlwfothQyjA="; }) - (fetchNuGet { pname = "FomodInstaller.Interface"; version = "1.2.0"; hash = "sha256-sxylVEA7uiaBtxbQHAeRElsVbZPIj2nm27Ozlik8wmg="; }) - (fetchNuGet { pname = "FomodInstaller.Scripting"; version = "1.0.0"; hash = "sha256-GNqbLS+lU6aNThUUCfJpmZgP+rd4lF0fKyfMn2Y7Ckg="; }) - (fetchNuGet { pname = "FomodInstaller.Scripting.XmlScript"; version = "1.0.0"; hash = "sha256-fbekooynf0jQD0k0zbYueDvOTxPa3FIZUKjCcVMPeeY="; }) - (fetchNuGet { pname = "FomodInstaller.Utils"; version = "1.0.0"; hash = "sha256-H0Fc79msO6GhYstzqtZk9ttRcqxtXuDT9v0zQBwDRHI="; }) - (fetchNuGet { pname = "GameFinder"; version = "4.3.3"; hash = "sha256-uJzGa5CAa+6oHuG5gU0TN68biDb7ZQYGgqeW1nGLHQc="; }) - (fetchNuGet { pname = "GameFinder.Common"; version = "4.3.3"; hash = "sha256-0mITSz+9TyknYO8zzvLNB70jWPe5v2Q3sKHPupvGGBk="; }) - (fetchNuGet { pname = "GameFinder.Launcher.Heroic"; version = "4.3.3"; hash = "sha256-3DuhHRGbWeh4Smj0TXitzUsTPbCwHmtZsk3e+CVZHHA="; }) - (fetchNuGet { pname = "GameFinder.RegistryUtils"; version = "4.3.3"; hash = "sha256-bd6qpOthn4ljNpwQi7pdVe5P1EN8DnXbyKyR4PnSxJk="; }) - (fetchNuGet { pname = "GameFinder.StoreHandlers.EADesktop"; version = "4.3.3"; hash = "sha256-jvh672wPSH0T4W6dJHdvMGJi93LWDJBefcVFrkxT6hI="; }) - (fetchNuGet { pname = "GameFinder.StoreHandlers.EGS"; version = "4.3.3"; hash = "sha256-IKDDTnCor3G7HdsVjo0wYNJQjBoQjQ+a+MgjnGVOaek="; }) - (fetchNuGet { pname = "GameFinder.StoreHandlers.GOG"; version = "4.3.3"; hash = "sha256-76+W+wi33ms0Xm5OCXQBmHCAilWRaA/OMd343vkkhc0="; }) - (fetchNuGet { pname = "GameFinder.StoreHandlers.Origin"; version = "4.3.3"; hash = "sha256-Ss48fc+19RqhjkEP0tld5Eui65XwECFeAMu+126JCo4="; }) - (fetchNuGet { pname = "GameFinder.StoreHandlers.Steam"; version = "4.3.3"; hash = "sha256-EQxtM7k459MfHL0Z2Li45jWji6CgGvpJbJbJv8zXVc4="; }) - (fetchNuGet { pname = "GameFinder.StoreHandlers.Xbox"; version = "4.3.3"; hash = "sha256-uzIPKS3O/uxqXZMysZfgRlQaDUSUhj1y9hCKAwwhK0g="; }) - (fetchNuGet { pname = "GameFinder.Wine"; version = "4.3.3"; hash = "sha256-aEFkI7UVHsipCxdvHq3P+mrThgYdrFhpK6EbyFYqU6Y="; }) - (fetchNuGet { pname = "Gee.External.Capstone"; version = "2.3.0"; hash = "sha256-wdYT/F8SLL72OIVv/Q/hfLMfhlWMnhDNCTWx+wWlPoU="; }) - (fetchNuGet { pname = "GitHubActionsTestLogger"; version = "2.4.1"; hash = "sha256-bY8RXB3fIsgYIrlLeEuq8dsOfIn8zcbZ0dj2Ra1sFZg="; }) - (fetchNuGet { pname = "Google.Protobuf"; version = "3.22.5"; hash = "sha256-KuPCqobX6vE9RYElAN9vw+FPonFipms7kE/cRDCLmSQ="; }) - (fetchNuGet { pname = "Grpc.Core.Api"; version = "2.52.0"; hash = "sha256-ISgN3zWwvV8qD7JFkaYveLbke09+UtUBy3Tux+ZHLNc="; }) - (fetchNuGet { pname = "Grpc.Net.Client"; version = "2.52.0"; hash = "sha256-4Rhb8PIoV2BiohfRwzx1GYDPbcfqxGAmL2uB0atFFTk="; }) - (fetchNuGet { pname = "Grpc.Net.Common"; version = "2.52.0"; hash = "sha256-XoY+jt+JIt6SzvCjUSXKKa9Q8Bu5UrNJv2z1hCBKDrY="; }) - (fetchNuGet { pname = "HarfBuzzSharp"; version = "7.3.0.2"; hash = "sha256-ibgoqzT1NV7Qo5e7X2W6Vt7989TKrkd2M2pu+lhSDg8="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Linux"; version = "7.3.0.2"; hash = "sha256-SSfyuyBaduGobJW+reqyioWHhFWsQ+FXa2Gn7TiWxrU="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.macOS"; version = "7.3.0.2"; hash = "sha256-dmEqR9MmpCwK8AuscfC7xUlnKIY7+Nvi06V0u5Jff08="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; version = "7.3.0.3-preview.2.2"; hash = "sha256-1NlcTnXrWUYZ2r2/N3SPxNIjNcyIpiiv3g7h8XxpNkM="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Win32"; version = "7.3.0.2"; hash = "sha256-x4iM3NHs9VyweG57xA74yd4uLuXly147ooe0mvNQ8zo="; }) - (fetchNuGet { pname = "HotChocolate.Language.SyntaxTree"; version = "14.1.0"; hash = "sha256-4cRFDfLW+A0378BZ0wzPrc7FOiuTdCtlA4gyitSrhiI="; }) - (fetchNuGet { pname = "HotChocolate.Transport.Abstractions"; version = "14.1.0"; hash = "sha256-i8i4ovnxHcFRrnU/a3U01izWEa+OsOjxgLDRq7wo1vs="; }) - (fetchNuGet { pname = "HotChocolate.Transport.Http"; version = "14.1.0"; hash = "sha256-e5VoAtmieIhNvhtGMnmPXqYAZE9SrXlfyJmDKF7LBJo="; }) - (fetchNuGet { pname = "HotChocolate.Utilities"; version = "14.1.0"; hash = "sha256-KIYlc1jDG1BT6gZGZoei6ypHXZo9I3dN4zM/NpDWJuI="; }) - (fetchNuGet { pname = "HtmlAgilityPack"; version = "1.11.70"; hash = "sha256-V/SI2N1+jNkwjSQRd2Y/XVVhdOKvSNz3/NeIFE9V3wY="; }) - (fetchNuGet { pname = "Humanizer"; version = "2.14.1"; hash = "sha256-1wGwf5KAmDeiH0Dz8KcTdZw+UMkiNsjKOIOt/VJnnqE="; }) - (fetchNuGet { pname = "Humanizer.Core"; version = "2.14.1"; hash = "sha256-EXvojddPu+9JKgOG9NSQgUTfWq1RpOYw7adxDPKDJ6o="; }) - (fetchNuGet { pname = "Humanizer.Core"; version = "2.2.0"; hash = "sha256-5Q6oRaV8wHPONHreKvB74VjV2FW36mwC3n+05It5vyI="; }) - (fetchNuGet { pname = "Humanizer.Core.af"; version = "2.14.1"; hash = "sha256-8CCgI7OweSa53cZWZBXQ8a7VVt/NPP16zHVBZvzU9KQ="; }) - (fetchNuGet { pname = "Humanizer.Core.ar"; version = "2.14.1"; hash = "sha256-JRoP+brQgYBZI8OccH/jaM1Z482ZWBiqU2XL3KsIPw8="; }) - (fetchNuGet { pname = "Humanizer.Core.az"; version = "2.14.1"; hash = "sha256-ubwkbes9zrrisuXTcT4ZgOAiFsUieC6OLd4pgzxsE40="; }) - (fetchNuGet { pname = "Humanizer.Core.bg"; version = "2.14.1"; hash = "sha256-Xv6DP1xxxGVUfP44TZasWpxgQ/DkriljvmIMtHf+nGk="; }) - (fetchNuGet { pname = "Humanizer.Core.bn-BD"; version = "2.14.1"; hash = "sha256-6JpReIc3fkExvJIXzk6fUw56wJ78aTEg1dWQ6o+dQow="; }) - (fetchNuGet { pname = "Humanizer.Core.cs"; version = "2.14.1"; hash = "sha256-MGL86KxSbz0PkDo9+NRj6h1fDjPZXlxAtYNf0Zreg/4="; }) - (fetchNuGet { pname = "Humanizer.Core.da"; version = "2.14.1"; hash = "sha256-Gpw8kJbgz0KQS2mGY5tmrHqpgUO4abD7dSKIy//ONYM="; }) - (fetchNuGet { pname = "Humanizer.Core.de"; version = "2.14.1"; hash = "sha256-Eswv8aEQoxI9MZr2CvWtBUn5X9JRZTWQjRzHJkGj80g="; }) - (fetchNuGet { pname = "Humanizer.Core.el"; version = "2.14.1"; hash = "sha256-wCK2Uy/AV6FxPUSUM0NMbV14pAP+ss25AaVAHMQIeJA="; }) - (fetchNuGet { pname = "Humanizer.Core.es"; version = "2.14.1"; hash = "sha256-iEHiQXKwg0ABDxh//HSrzwaVOlilQBFI96+GYzzTMwQ="; }) - (fetchNuGet { pname = "Humanizer.Core.fa"; version = "2.14.1"; hash = "sha256-2Js7k3nvwJvxAjq3yoLn7PUY2S8+vXfgESwU4SbvjaA="; }) - (fetchNuGet { pname = "Humanizer.Core.fi-FI"; version = "2.14.1"; hash = "sha256-jOWo43r3dhiBsV9cCoDfqK/YqWj5LejZsnfkG6mlkpA="; }) - (fetchNuGet { pname = "Humanizer.Core.fr"; version = "2.14.1"; hash = "sha256-WCbA+f4B3g/ml7KrkHkzpU2Fj38HtWc/ujoVY5F3lk4="; }) - (fetchNuGet { pname = "Humanizer.Core.fr-BE"; version = "2.14.1"; hash = "sha256-GydVmoEy+lwEQ1nM39QXSRhYNchqM47p7qhUEimN4Cw="; }) - (fetchNuGet { pname = "Humanizer.Core.he"; version = "2.14.1"; hash = "sha256-MMf3qjJ+yzxjMxOR7wMWf+eErxWLqpsdWKFhjNCOsyM="; }) - (fetchNuGet { pname = "Humanizer.Core.hr"; version = "2.14.1"; hash = "sha256-kBv2I9ns6L6D4XfXfyZS1VM6+YwF4yUkCmCA5zqvsok="; }) - (fetchNuGet { pname = "Humanizer.Core.hu"; version = "2.14.1"; hash = "sha256-vRje+kxqOsl1JCXAE0yDKvauUumzuEhNcnhNsdIdgVM="; }) - (fetchNuGet { pname = "Humanizer.Core.hy"; version = "2.14.1"; hash = "sha256-UL7PsK4msT5c96lk70/bVAxN63B71l8VOFtvuJQH9a0="; }) - (fetchNuGet { pname = "Humanizer.Core.id"; version = "2.14.1"; hash = "sha256-nIl64gCuZh4D527qI2hfQRvzt1mTJUCDGMIZwpS3C/A="; }) - (fetchNuGet { pname = "Humanizer.Core.is"; version = "2.14.1"; hash = "sha256-38vUQ1aVtlhK15kP9ZlDO0Nl0DcOA5iHx6F2SPN1gYM="; }) - (fetchNuGet { pname = "Humanizer.Core.it"; version = "2.14.1"; hash = "sha256-4ne0VRNi9OAj3bGCQgCy1BNYKMizoHykJ/lchmCsWdc="; }) - (fetchNuGet { pname = "Humanizer.Core.ja"; version = "2.14.1"; hash = "sha256-oAilMM8J6LumV6qv3gSIBNTm7u2L4vV38cQXtME3PhM="; }) - (fetchNuGet { pname = "Humanizer.Core.ko-KR"; version = "2.14.1"; hash = "sha256-b70HQl2IWVPATtaYGDyJ+Z6ioPtrM53vXzfTCHYgxpQ="; }) - (fetchNuGet { pname = "Humanizer.Core.ku"; version = "2.14.1"; hash = "sha256-8LiEH7MaapMtkHFMj7Y3pG+g0QYuIa5gD3VR9nYQn+k="; }) - (fetchNuGet { pname = "Humanizer.Core.lv"; version = "2.14.1"; hash = "sha256-zyCsE5cD++u5shNIqCQUd+66FkUWOl+NfFrs2JduCaQ="; }) - (fetchNuGet { pname = "Humanizer.Core.ms-MY"; version = "2.14.1"; hash = "sha256-pSdZLUi9oWo78nBh2DJunPhDR7THdZSZP0msCVbPsrY="; }) - (fetchNuGet { pname = "Humanizer.Core.mt"; version = "2.14.1"; hash = "sha256-mkX2reEvNpx9w6gtZw+6bkrnj3Di1qgVDMr9q0IeKCw="; }) - (fetchNuGet { pname = "Humanizer.Core.nb"; version = "2.14.1"; hash = "sha256-QvYJHqjO/SrelWYgtm8Sc7axs7J8wbJE+GbTgVw5LYs="; }) - (fetchNuGet { pname = "Humanizer.Core.nb-NO"; version = "2.14.1"; hash = "sha256-YW8y2XkmHjwqf2fztNB3rsn3+CgslF1TclITwp0fA9g="; }) - (fetchNuGet { pname = "Humanizer.Core.nl"; version = "2.14.1"; hash = "sha256-bQM7aXNQMBY+65NfMVQz/xYz9Ad2JC+ryXoB4lcYgmA="; }) - (fetchNuGet { pname = "Humanizer.Core.pl"; version = "2.14.1"; hash = "sha256-IrPxHI4uQvBeMM9/8PaNueKwVkbN+1zFQlNWRjNfXEA="; }) - (fetchNuGet { pname = "Humanizer.Core.pt"; version = "2.14.1"; hash = "sha256-XrlC15HNJFmDwLpHIUHb3Bec9A79msQCRB9Dvz8w4l0="; }) - (fetchNuGet { pname = "Humanizer.Core.ro"; version = "2.14.1"; hash = "sha256-llXtfq4Tr5V2Q4dVD7J0IKITtpiWrFs50DAtJhcSuRI="; }) - (fetchNuGet { pname = "Humanizer.Core.ru"; version = "2.14.1"; hash = "sha256-lD0dB3mkbFfGExwVWZk6fv24MyQQ8Cdv5OrleuZeChg="; }) - (fetchNuGet { pname = "Humanizer.Core.sk"; version = "2.14.1"; hash = "sha256-EmyE+wssZwY6tAuEiFXGn5/yzVMZe7QEuTjOcByOXaA="; }) - (fetchNuGet { pname = "Humanizer.Core.sl"; version = "2.14.1"; hash = "sha256-sWWxh7KZ8Y3Ps6GbBOHbU2GMsNZfkM+BOnUChf3fz4s="; }) - (fetchNuGet { pname = "Humanizer.Core.sr"; version = "2.14.1"; hash = "sha256-/bA3LULRFn5WYmCscr5R5vaFRjeHC0xjNiF7PXEJ8r0="; }) - (fetchNuGet { pname = "Humanizer.Core.sr-Latn"; version = "2.14.1"; hash = "sha256-43+o6oj0UNRJKiFoh57MGPSzlsWAq0eRtzlCrewDmVM="; }) - (fetchNuGet { pname = "Humanizer.Core.sv"; version = "2.14.1"; hash = "sha256-9lXrHveKDs1y/W3Qxd+MVcohhKEU7zNPx21GBVPp/rA="; }) - (fetchNuGet { pname = "Humanizer.Core.th-TH"; version = "2.14.1"; hash = "sha256-ldCsXINSvL2xom0SCtVQy+qX1IN5//EUoyIOwXiJ3k8="; }) - (fetchNuGet { pname = "Humanizer.Core.tr"; version = "2.14.1"; hash = "sha256-VZnO1vMXiR7egKEKJ6lBsj7eNgxhFzakFWsYYRW4u2U="; }) - (fetchNuGet { pname = "Humanizer.Core.uk"; version = "2.14.1"; hash = "sha256-rdvleUrKbj3c06A0O2MkgAZLtXLro9SPB1YqAGE1Vyg="; }) - (fetchNuGet { pname = "Humanizer.Core.uz-Cyrl-UZ"; version = "2.14.1"; hash = "sha256-Qso1Iz9MTLs63x4F00kK31TZAN4AoFaFsuVzM+1z38k="; }) - (fetchNuGet { pname = "Humanizer.Core.uz-Latn-UZ"; version = "2.14.1"; hash = "sha256-sVnkZTuEaHfMJIAZmSCqsspnKkYxK9eVBQZnAAqHNW4="; }) - (fetchNuGet { pname = "Humanizer.Core.vi"; version = "2.14.1"; hash = "sha256-5wDt72+HdNN3mt/iJkxV9LaH13Jc1qr1vB4Lz8ahIPs="; }) - (fetchNuGet { pname = "Humanizer.Core.zh-CN"; version = "2.14.1"; hash = "sha256-Z3qfFWyovcVT4Hqy51lgW2xGwyfI//Yfv90E0Liy1sw="; }) - (fetchNuGet { pname = "Humanizer.Core.zh-Hans"; version = "2.14.1"; hash = "sha256-BTGkMEkQYJKRp858EU7hwNOdsHRT+w6vAMa6H8JIyX4="; }) - (fetchNuGet { pname = "Humanizer.Core.zh-Hant"; version = "2.14.1"; hash = "sha256-N3D1z5aoGwAZ6+ZxrWMtXgacvQcgDG+aLrQQI9uysmM="; }) - (fetchNuGet { pname = "Iced"; version = "1.17.0"; hash = "sha256-6/5E5v5mqSG7yiE2zHUChZZeC47NRgLzQFD4+7bqKaU="; }) - (fetchNuGet { pname = "ini-parser-netstandard"; version = "2.5.2"; hash = "sha256-idb2hvuDlxl83x0yttGHnTgEQmwLLdUT7QfMeGDXVJE="; }) - (fetchNuGet { pname = "JetBrains.Annotations"; version = "2024.3.0"; hash = "sha256-BQYhE7JDJ9Bw588KyWzOvQFvQTiRa0K9maVkI9lZgBc="; }) - (fetchNuGet { pname = "K4os.Compression.LZ4"; version = "1.3.7-beta"; hash = "sha256-mMNIMLSXnKFF3oAgX+k/n0wipxyRDGE1z2BrI2+7ALc="; }) - (fetchNuGet { pname = "K4os.Compression.LZ4"; version = "1.3.8"; hash = "sha256-OmT3JwO4qpkZDL7XqiFqZCyxySj64s9t+mXcN1T+IyA="; }) - (fetchNuGet { pname = "LinqGen"; version = "0.3.1"; hash = "sha256-Yyt1uShHigHVCIjPT8jL2Kth9L9yq1MGrCM5w2+tj9o="; }) - (fetchNuGet { pname = "LiveChartsCore"; version = "2.0.0-rc2"; hash = "sha256-JSw2bwHOvUDx+axSufcvKSD9RPmqi366tbiIcsym3As="; }) - (fetchNuGet { pname = "LiveChartsCore.SkiaSharpView"; version = "2.0.0-rc2"; hash = "sha256-tKBTT75B77po0jDqWJL0mOzXkCKmHAGPlQV3biKtZdw="; }) - (fetchNuGet { pname = "LiveChartsCore.SkiaSharpView.Avalonia"; version = "2.0.0-rc2"; hash = "sha256-pHMtCkoz4sz2MLlVGFbFwwONLC3vzy+9Cg0OmEJ+f/s="; }) - (fetchNuGet { pname = "Magick.NET-Q16-AnyCPU"; version = "14.0.0"; hash = "sha256-hsFqy7F1s9pO3SWnOuKc4AWEoG7fR8CKSkjfo7pKvzY="; }) - (fetchNuGet { pname = "Magick.NET.Core"; version = "14.0.0"; hash = "sha256-mwh8d7qmM7m6IbnLSPNq8ZMcD24/1ypM3Gdf6GZm0ao="; }) - (fetchNuGet { pname = "Markdown.Avalonia.Tight"; version = "11.0.3-a1"; hash = "sha256-KkRzr8BXmUCGCVv/64gg1aiXHUY0yGj5t12OsYAidcw="; }) - (fetchNuGet { pname = "MartinCostello.Logging.XUnit"; version = "0.3.0"; hash = "sha256-RhcRcww2ZYaB1ZZ/qRN95fMffcsfqP4EKLVeR4+5S9A="; }) - (fetchNuGet { pname = "MemoryPack"; version = "1.21.3"; hash = "sha256-x0riT7EvbuyX91wq9PIEwDQe1aiBrYD9R9Io16JvprM="; }) - (fetchNuGet { pname = "MemoryPack.Core"; version = "1.21.3"; hash = "sha256-99ys+oZfBxcmal9PE14bxmR+svGk+J3FqAzxG7qVOHg="; }) - (fetchNuGet { pname = "MemoryPack.Generator"; version = "1.21.3"; hash = "sha256-TdbsUp0jB/1T4nU1dHS25iizpXLXJ0KWzqo3skMV6KE="; }) - (fetchNuGet { pname = "MemoryPack.Streaming"; version = "1.21.3"; hash = "sha256-WWJx+aMHnjKVPrOSt0QE0iFh/rNhZCCbUrnww3HdqfI="; }) - (fetchNuGet { pname = "MicroCom.Runtime"; version = "0.11.0"; hash = "sha256-VdwpP5fsclvNqJuppaOvwEwv2ofnAI5ZSz2V+UEdLF0="; }) - (fetchNuGet { pname = "Microsoft.AspNet.WebApi.Client"; version = "6.0.0"; hash = "sha256-lNL5C4W7/p8homWooO/3ZKDZQ2M0FUTDixJwqWBPVbo="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.WebUtilities"; version = "8.0.0"; hash = "sha256-e4wqTJUgPfq6CfRwuXTw32K9vB+hOpSLxSZDpzv23Yg="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.WebUtilities"; version = "9.0.0"; hash = "sha256-LFyhPIJNZLBqOEF4uZ1SpqN/NhjpCHqhzO4R2ApXuj0="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "1.1.0"; hash = "sha256-QYVojfqSZKbF8P6D/aacfxfumMaRUD9SEEQbzw73Bbc="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "1.1.1"; hash = "sha256-fAcX4sxE0veWM1CZBtXR/Unky+6sE33yrV7ohrWGKig="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "6.0.0"; hash = "sha256-49+H/iFwp+AfCICvWcqo9us4CzxApPKC37Q5Eqrw+JU="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "7.0.0"; hash = "sha256-1e031E26iraIqun84ad0fCIR4MJZ1hcQo4yFN+B7UfE="; }) - (fetchNuGet { pname = "Microsoft.Build.Tasks.Git"; version = "8.0.0"; hash = "sha256-vX6/kPij8vNAu8f7rrvHHhPrNph20IcufmrBgZNxpQA="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzer.Testing"; version = "1.1.2"; hash = "sha256-NeOzfN/9WiX/GsZicQ+oDUuPrZgrxTcP8w7kszAKaaY="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.3.3"; hash = "sha256-pkZiggwLw8k+CVSXKTzsVGsT+K49LxXUS3VH5PNlpCY="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.3.4"; hash = "sha256-qDzTfZBSCvAUu9gzq2k+LOvh6/eRvJ9++VCNck/ZpnE="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "1.0.1"; hash = "sha256-jjWtdrHSISgBF1m94P0DsVbQa4YxKnf2CWRWYHQLTG8="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "3.8.0"; hash = "sha256-3G9vSc/gHH7FWgOySLTut1+eEaf3H66qcPOvNPLOx4o="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "4.1.0"; hash = "sha256-g3RLyeHfdOOF6H89VLJi06/k8/eJ6j2dgNYZ/MBdfNU="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "4.11.0"; hash = "sha256-cX/xgM0VmS+Bsu63KZk2ofjFOOy1mzI+CCVEY6kI+Qk="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "4.8.0"; hash = "sha256-3IEinVTZq6/aajMVA8XTRO3LTIEt0PuhGyITGJLtqz4="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "3.8.0"; hash = "sha256-i/r3V/No/VzqmJlWxpGoirvlbJDbBPa/ONZtzYrxuc4="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "4.1.0"; hash = "sha256-pM9WXvxZI3SS89CGVjxqtAyZyfyiZQzW0UnNCDiQrQA="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "4.11.0"; hash = "sha256-E9jEOjp9g/CFecsc5/QfRKOPXMRpSw0Tf79XsRgL+Mk="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "4.8.0"; hash = "sha256-MmOnXJvd/ezs5UPcqyGLnbZz5m+VedpRfB+kFZeeqkU="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.SourceGenerators.Testing"; version = "1.1.2"; hash = "sha256-WkdcHsqrFQnXEkcuyWPIPybY25QDzpMEem9KflPwFn0="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.SourceGenerators.Testing.XUnit"; version = "1.1.2"; hash = "sha256-wYCDZopLucktDQpzACb/BTj+t4arpFuqUEAKxfjLk7U="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.Workspaces"; version = "3.8.0"; hash = "sha256-i6PTXkHepgTXseFFg57iRh5thKtKYc9CH11y/qzDy8k="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.Workspaces"; version = "4.8.0"; hash = "sha256-WNzc+6mKqzPviOI0WMdhKyrWs8u32bfGj2XwmfL7bwE="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.SourceGenerators.Testing"; version = "1.1.2"; hash = "sha256-5npL4J8jxcBTmNBT9k3CNeGT0lIWfmWBVXwzEiqRypg="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Testing.Verifiers.XUnit"; version = "1.1.2"; hash = "sha256-lwRXcej7nA6sa/Ss4HwDBgiMG3NTBx9peiLxn4l0Wrk="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Workspaces.Common"; version = "1.0.1"; hash = "sha256-/SYPkq5LhOoEWi+rcBZDyQL2U0cQk2YrykNJODrRLVs="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Workspaces.Common"; version = "3.8.0"; hash = "sha256-3D7xV3V1WsUU9OMMEOj+z9GouCDKXSBC4Z/Szs/OcWE="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Workspaces.Common"; version = "4.8.0"; hash = "sha256-X8R4SpWVO/gpip5erVZf5jCCx8EX3VzIRtNrQiLDIoM="; }) - (fetchNuGet { pname = "Microsoft.CodeCoverage"; version = "17.11.1"; hash = "sha256-1dLlK3NGh88PuFYZiYpT+izA96etxhU3BSgixDgdtGA="; }) - (fetchNuGet { pname = "Microsoft.Composition"; version = "1.0.27"; hash = "sha256-G/3p3zxOWC8HqLt7Ll5cqN7507F6N/G6G/HzKazQRdE="; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.7.0"; hash = "sha256-Enknv2RsFF68lEPdrf5M+BpV1kHoLTVRApKUwuk/pj0="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.NETCore.Client"; version = "0.2.251802"; hash = "sha256-9ZH4rrfACzJP5oiarDW4cD2nczv1SNgZr4GW1J9hlUA="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.Runtime"; version = "2.2.332302"; hash = "sha256-5R9xK0owZEhXsucqPKnPaTiwhXBnLo92L2AY7IjyxNg="; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.Tracing.TraceEvent"; version = "3.1.8"; hash = "sha256-JFrNrQrXjOJI7v4MpQEDMfmfndM4ThtDZkATAGin9lE="; }) - (fetchNuGet { pname = "Microsoft.DotNet.PlatformAbstractions"; version = "3.1.6"; hash = "sha256-RfM2qXiqdiamPkXr4IDkNc0IZSF9iTZv4uou/E7zNS0="; }) - (fetchNuGet { pname = "Microsoft.Extensions.AmbientMetadata.Application"; version = "9.0.0"; hash = "sha256-1cEpOtFLK7J9Hnq28Av+pdKaYjRldWVNRD2zhBsbWps="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Compliance.Abstractions"; version = "9.0.0"; hash = "sha256-Se92b6d4EEpL9HCD0OwFRlRSGM64+U4PVEid9ncuAqk="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "8.0.0"; hash = "sha256-9BPsASlxrV8ilmMCjdb3TiUcm5vFZxkBnAI/fNBSEyA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "9.0.0"; hash = "sha256-uBLeb4z60y8z7NelHs9uT3cLD6wODkdwyfJm6/YZLDM="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "8.0.0"; hash = "sha256-4eBpDkf7MJozTZnOwQvwcfgRKQGcNXe0K/kF+h5Rl8o="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "9.0.0"; hash = "sha256-xtG2USC9Qm0f2Nn6jkcklpyEDT3hcEZOxOwTc0ep7uc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "8.0.0"; hash = "sha256-GanfInGzzoN2bKeNwON8/Hnamr6l7RTpYLA49CNXD9Q="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "9.0.0"; hash = "sha256-6ajYWcNOQX2WqftgnoUmVtyvC1kkPOtTCif4AiKEffU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.CommandLine"; version = "8.0.0"; hash = "sha256-fmPC/o8S+weTtQJWykpnGHm6AKVU21xYE/CaHYU7zgg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.CommandLine"; version = "9.0.0"; hash = "sha256-RE6DotU1FM1sy5p3hukT+WOFsDYJRsKX6jx5vhlPceM="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; version = "8.0.0"; hash = "sha256-+bjFZvqCsMf2FRM2olqx/fub+QwfM1kBhjGVOT5HC48="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; version = "9.0.0"; hash = "sha256-tDJx2prYZpr0RKSwmJfsK9FlUGwaDmyuSz2kqQxsWoI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.FileExtensions"; version = "8.0.0"; hash = "sha256-BCxcjVP+kvrDDB0nzsFCJfU74UK4VBvct2JA4r+jNcs="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.FileExtensions"; version = "9.0.0"; hash = "sha256-PsLo6mrLGYfbi96rfCG8YS1APXkUXBG4hLstpT60I4s="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Json"; version = "8.0.0"; hash = "sha256-Fi/ijcG5l0BOu7i96xHu96aN5/g7zO6SWQbTsI3Qetg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Json"; version = "9.0.0"; hash = "sha256-qQn7Ol0CvPYuyecYWYBkPpTMdocO7I6n+jXQI2udzLI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.UserSecrets"; version = "8.0.0"; hash = "sha256-/yj5QaEzeRStvOFoBpPRPXlEehGtr2E6/rJb+OEPIK8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.UserSecrets"; version = "9.0.0"; hash = "sha256-GoEk+Qq7lbiwWurHYx1LkDaUzIpOzaoTiVGDPfViGak="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "8.0.0"; hash = "sha256-+qIDR8hRzreCHNEDtUcPfVHQdurzWPo/mqviCH78+EQ="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "9.0.0"; hash = "sha256-dAH52PPlTLn7X+1aI/7npdrDzMEFPMXRv4isV1a+14k="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "2.0.0"; hash = "sha256-H1rEnq/veRWvmp8qmUsrQkQIcVlKilUNzmmKsxJ0md8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.0"; hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.1"; hash = "sha256-lzTYLpRDAi3wW9uRrkTNJtMmaYdtGJJHdBLbUKu60PM="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.2"; hash = "sha256-UfLfEQAkXxDaVPC7foE/J3FVEXd31Pu6uQIhTic3JgY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "9.0.0"; hash = "sha256-CncVwkKZ5CsIG2O0+OM9qXuYXh3p6UGyueTHSLDVL+c="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.AutoActivation"; version = "9.0.0"; hash = "sha256-45NiMtCHV4BDkwnSZmsTRJ8dHMDm5WAGhJh4x+z7TiM="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Diagnostics"; version = "8.0.0"; hash = "sha256-fBLlb9xAfTgZb1cpBxFs/9eA+BlBvF8Xg0DMkBqdHD4="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Diagnostics"; version = "9.0.0"; hash = "sha256-JMbhtjdcWRlrcrbgPlowfj26+pM+MYhnPIaYKnv9byU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Diagnostics.Abstractions"; version = "8.0.0"; hash = "sha256-USD5uZOaahMqi6u7owNWx/LR4EDrOwqPrAAim7iRpJY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Diagnostics.Abstractions"; version = "9.0.0"; hash = "sha256-wG1LcET+MPRjUdz3HIOTHVEnbG/INFJUqzPErCM79eY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Diagnostics.ExceptionSummarization"; version = "9.0.0"; hash = "sha256-Nj8l1ba5iZ5Tubu+vY3a5dgTRkYmGNP2wtXC8Re8aCg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "8.0.0"; hash = "sha256-uQSXmt47X2HGoVniavjLICbPtD2ReQOYQMgy3l0xuMU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "9.0.0"; hash = "sha256-mVfLjZ8VrnOQR/uQjv74P2uEG+rgW72jfiGdSZhIfDc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Physical"; version = "8.0.0"; hash = "sha256-29y5ZRQ1ZgzVOxHktYxyiH40kVgm5un2yTGdvuSWnRc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Physical"; version = "9.0.0"; hash = "sha256-IzFpjKHmF1L3eVbFLUZa2N5aH3oJkJ7KE1duGIS7DP8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileSystemGlobbing"; version = "8.0.0"; hash = "sha256-+Oz41JR5jdcJlCJOSpQIL5OMBNi+1Hl2d0JUHfES7sU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileSystemGlobbing"; version = "9.0.0"; hash = "sha256-eBLa8pW/y/hRj+JbEr340zbHRABIeFlcdqE0jf5/Uhc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting"; version = "8.0.0"; hash = "sha256-sKHa+w4/pMeQb5RRFqLtMTUJy5H6hSIGWchbH2pxSrg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting"; version = "9.0.0"; hash = "sha256-apIN4Cz86ujsMp/ibxcvguA9uCFaFqOsZ4kAUPX5ASI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting.Abstractions"; version = "8.0.0"; hash = "sha256-0JBx+wwt5p1SPfO4m49KxNOXPAzAU0A+8tEc/itvpQE="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting.Abstractions"; version = "9.0.0"; hash = "sha256-NhEDqZGnwCDFyK/NKn1dwLQExYE82j1YVFcrhXVczqY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Http"; version = "8.0.0"; hash = "sha256-UgljypOLld1lL7k7h1noazNzvyEHIJw+r+6uGzucFSY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Http"; version = "9.0.0"; hash = "sha256-MsStH3oUfyBbcSEoxm+rfxFBKI/rtB5PZrSGvtDjVe0="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Http.Diagnostics"; version = "9.0.0"; hash = "sha256-4XtkhRMXTFR1I85rJ73BFa01XDRW/fz4+Jig0S/Wm3M="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Http.Resilience"; version = "9.0.0"; hash = "sha256-GFGvnupmgvTgbmknxpF7H3DmxqvX9JOdxKuK2lR6bVM="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "2.0.0"; hash = "sha256-Bg3bFJPjQRJnPvlEc5v7lzwRaUTzKwXDtz81GjCTfMo="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "2.1.1"; hash = "sha256-HnEBmAhweBalCAeX+KZ4kEL3GXEVDBg6Uq4H4LJ56oo="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "8.0.0"; hash = "sha256-Meh0Z0X7KyOEG4l0RWBcuHHihcABcvCyfUXgasmQ91o="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "9.0.0"; hash = "sha256-kR16c+N8nQrWeYLajqnXPg7RiXjZMSFLnKLEs4VfjcM="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "2.0.0"; hash = "sha256-cBBNcoREIdCDnwZtnTG+BoAFmVb71P1nhFOAH07UsfQ="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "3.0.3"; hash = "sha256-UFawgCAhbN5HCtJy39XO4sz5N/P/Zyrs0uqrQHc4SPI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "6.0.1"; hash = "sha256-v3FWpuKXlBIW5NwqQx0Ffb6y58RlevIyO/byqeLphJ8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "8.0.0"; hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "9.0.0"; hash = "sha256-iBTs9twjWXFeERt4CErkIIcoJZU1jrd1RWCI8V5j7KU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Configuration"; version = "8.0.0"; hash = "sha256-mzmstNsVjKT0EtQcdAukGRifD30T82BMGYlSu8k4K7U="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Configuration"; version = "9.0.0"; hash = "sha256-ysPjBq64p6JM4EmeVndryXnhLWHYYszzlVpPxRWkUkw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Console"; version = "8.0.0"; hash = "sha256-bdb9YWWVn//AeySp7se87/tCN2E7e8Gx2GPMw28cd9c="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Console"; version = "9.0.0"; hash = "sha256-N2t9EUdlS6ippD4Z04qUUyBuQ4tKSR/8TpmKScb5zRw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Debug"; version = "8.0.0"; hash = "sha256-AJunzYBZM2wCg86hnPnMrBuWIIyW/4PnIVoDSU969cA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Debug"; version = "9.0.0"; hash = "sha256-5W6fP9Eb98U3MTWKeLzSNl2cRFpE694OOPjpWp/qTAk="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.EventLog"; version = "8.0.0"; hash = "sha256-vXBm4yhWGP4uow0CqstuqOkxO8yeZEM15JTTenjPbhc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.EventLog"; version = "9.0.0"; hash = "sha256-mIL1I85Ef5+/mXl24odoUpcXet+jCZTRtKCd5z6YUwI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.EventSource"; version = "8.0.0"; hash = "sha256-kaR7YOlq5s8W9nZDtH/lKtnfGbrgOuQY4DUPcA2lcj0="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.EventSource"; version = "9.0.0"; hash = "sha256-pplZskMsR3gGbs3I0wycGsvIMPIpfWFJpOsR9GkiYRw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.ObjectPool"; version = "8.0.0"; hash = "sha256-FxFr5GC0y6vnp5YD2A2vISXYizAz3k/QyrH7sBXP5kg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.ObjectPool"; version = "9.0.0"; hash = "sha256-mX2Y2bHwScjXh1xQOweawmwo7jYLw+MhePibk/96dMY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "2.0.0"; hash = "sha256-EMvaXxGzueI8lT97bYJQr0kAj1IK0pjnAcWN82hTnzw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "8.0.0"; hash = "sha256-n2m4JSegQKUTlOsKLZUUHHKMq926eJ0w9N9G+I3FoFw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "9.0.0"; hash = "sha256-DT5euAQY/ItB5LPI8WIp6Dnd0lSvBRP35vFkOXC68ck="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; version = "8.0.0"; hash = "sha256-A5Bbzw1kiNkgirk5x8kyxwg9lLTcSngojeD+ocpG1RI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; version = "9.0.0"; hash = "sha256-r1Z3sEVSIjeH2UKj+KMj86har68g/zybSqoSjESBcoA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "8.0.0"; hash = "sha256-FU8qj3DR8bDdc1c+WeGZx/PCZeqqndweZM9epcpXjSo="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "9.0.0"; hash = "sha256-ZNLusK1CRuq5BZYZMDqaz04PIKScE2Z7sS2tehU7EJs="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Resilience"; version = "9.0.0"; hash = "sha256-3zd2zOR8C3+VaPpUnJ+wcCaBbvzU8DjGGuaZ/dxsqQQ="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Telemetry"; version = "9.0.0"; hash = "sha256-MKltsZC6s7sE8mO1XpOOzgFbp3CJS7sHGMH92DjXSso="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Telemetry.Abstractions"; version = "9.0.0"; hash = "sha256-rGeoVSc3RJlhL8Sv8CgDh2+BOiFHllKl2K9vtXxl+Ec="; }) - (fetchNuGet { pname = "Microsoft.IO.RecyclableMemoryStream"; version = "3.0.0"; hash = "sha256-WBXkqxC5g4tJ481sa1uft39LqA/5hx5yOfiTfMRMg/4="; }) - (fetchNuGet { pname = "Microsoft.Net.Http.Headers"; version = "9.0.0"; hash = "sha256-fJ42UoMaftaGZbMA5LlGhZNns1hQY2eLkw6EEeCYcAQ="; }) - (fetchNuGet { pname = "Microsoft.NET.Test.Sdk"; version = "17.11.1"; hash = "sha256-0JUEucQ2lzaPgkrjm/NFLBTbqU1dfhvhN3Tl3moE6mI="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "2.0.0"; hash = "sha256-IEvBk6wUXSdyCnkj6tHahOJv290tVVT8tyemYcR0Yro="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "2.1.2"; hash = "sha256-gYQQO7zsqG+OtN4ywYQyfsiggS2zmxw4+cPXlK+FB5Q="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "5.0.0"; hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; }) - (fetchNuGet { pname = "Microsoft.SourceLink.Common"; version = "8.0.0"; hash = "sha256-AfUqleVEqWuHE7z2hNiwOLnquBJ3tuYtbkdGMppHOXc="; }) - (fetchNuGet { pname = "Microsoft.SourceLink.GitHub"; version = "8.0.0"; hash = "sha256-hNTkpKdCLY5kIuOmznD1mY+pRdJ0PKu2HypyXog9vb0="; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.ObjectModel"; version = "17.10.0"; hash = "sha256-3YjVGK2zEObksBGYg8b/CqoJgLQ1jUv4GCWNjDhLRh4="; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.ObjectModel"; version = "17.11.1"; hash = "sha256-5vX+vCzFY3S7xfMVIv8OlMMFtdedW9UIJzc0WEc+vm4="; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.TestHost"; version = "17.11.1"; hash = "sha256-wSkY0H1fQAq0H3LcKT4u7Y5RzhAAPa6yueVN84g8HxU="; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Composition"; version = "16.1.8"; hash = "sha256-yFT4t3Uk31R5EPdAxxsTAmRuiv58MlYoYL4JT1ywlHQ="; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Composition.NetFxAttributes"; version = "16.1.8"; hash = "sha256-FFemIG+m8RWUPo5W+kCHPh5Yn4fGS+tpjGiQTcT0sAE="; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Threading"; version = "17.10.48"; hash = "sha256-WL8c7TjDBHGjsVLMMPf9cin8rirzOdxusEBQlkUfiVU="; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Threading.Analyzers"; version = "17.10.48"; hash = "sha256-EvZGbyxtrJDvHZwsQbZDXtVfWiy0f58oCdTdSzD34wI="; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Validation"; version = "15.0.82"; hash = "sha256-7JFaA/HZHVjsEtTh/iHDRLi5RcuA39KKvvCkuI4JQFc="; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Validation"; version = "17.8.8"; hash = "sha256-sB8GLRiJHX3Py7qeBUnUANiDWhyPtISon6HQs+8wKms="; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.3.0"; hash = "sha256-mBNDmPXNTW54XLnPAUwBRvkIORFM7/j0D0I2SyQPDEg="; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "4.4.0"; hash = "sha256-ZumsykAAIYKmVtP4QI5kZ0J10n2zcOZZ69PmAK0SEiE="; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "5.0.0"; hash = "sha256-9kylPGfKZc58yFqNKa77stomcoNnMeERXozWJzDcUIA="; }) - (fetchNuGet { pname = "Nerdbank.FullDuplexStream"; version = "1.1.12"; hash = "sha256-PZwy+qQ8nOdH5gRRQ24go2yh+YmZQhziwbyWC+1qoJc="; }) - (fetchNuGet { pname = "Nerdbank.Streams"; version = "2.11.79"; hash = "sha256-1bzibVcSH8LJMR8Nb6Q0q/7fieTgxRnVY4C1RvRbrrI="; }) - (fetchNuGet { pname = "NetEscapades.EnumGenerators"; version = "1.0.0-beta07"; hash = "sha256-SYIuk1B2birutYx6d0vbCshEd8ZEH0pDVrNm9daBxwY="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "1.6.0"; hash = "sha256-ExWI1EKDCRishcfAeHVS/RoJphqSqohmJIC/wz3ZtVo="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "1.6.1"; hash = "sha256-iNan1ix7RtncGWC9AjAZ2sk70DoxOsmEOgQ10fXm4Pw="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "12.0.1"; hash = "sha256-4Xf3RZrJomAh3jaZrEAJX3oPmOowGV8yDB9Y3h0Dw4U="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.1"; hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.3"; hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; }) - (fetchNuGet { pname = "Newtonsoft.Json.Bson"; version = "1.0.2"; hash = "sha256-ZUj6YFSMZp5CZtXiamw49eZmbp1iYBuNsIKNnjxcRzA="; }) - (fetchNuGet { pname = "NexusMods.Archives.Nx"; version = "0.6.1"; hash = "sha256-NDUxypEccSlGBG9nYTJJiTqYrZWjSjV1xt/uUbtfeS8="; }) - (fetchNuGet { pname = "NexusMods.Hashing.xxHash3"; version = "3.0.3"; hash = "sha256-lhuuHZvH1klH6HE00h1On6icd6CLdFqvLLkfb3x1VVY="; }) - (fetchNuGet { pname = "NexusMods.Hashing.xxHash3.Paths"; version = "3.0.3"; hash = "sha256-UeOX3Y8MGmAgWHWH3GolsA/MyNM9iam75pxxRXhd50M="; }) - (fetchNuGet { pname = "NexusMods.MnemonicDB"; version = "0.9.97"; hash = "sha256-b0k/hM6UYvMTZN2QMk53QN9Fw/pomXJ88k9QqfrAF+s="; }) - (fetchNuGet { pname = "NexusMods.MnemonicDB.Abstractions"; version = "0.9.97"; hash = "sha256-EnWQMeXMKwziMoBXKf7t+Ru6EHZBml4Pt3h1eSP1Ud0="; }) - (fetchNuGet { pname = "NexusMods.MnemonicDB.SourceGenerator"; version = "0.9.97"; hash = "sha256-KOZVhS3H/qY6bRW9HmSF1Ud4fXv5oEWORDdYET9Ochw="; }) - (fetchNuGet { pname = "NexusMods.Paths"; version = "0.10.0"; hash = "sha256-tzUKPBrGNyZvVgScDAP0qvVF5nV6635v3NlBvzpnz1M="; }) - (fetchNuGet { pname = "NexusMods.Paths"; version = "0.15.0"; hash = "sha256-No2kbrDVmJ5ySLm7jH+gNAfNLVnsv4AtLT1phcuOFLc="; }) - (fetchNuGet { pname = "NexusMods.Paths.Extensions.Nx"; version = "0.15.0"; hash = "sha256-8QT+Iu32u4m5wqMG2bAqramnUQPLDmUB8/c+ew4fRqM="; }) - (fetchNuGet { pname = "NexusMods.Paths.TestingHelpers"; version = "0.15.0"; hash = "sha256-xUZIAND1Ob0SRuoTTuJqw7N2j/4ncIlck3lgfeWxd5M="; }) - (fetchNuGet { pname = "NLog"; version = "5.3.4"; hash = "sha256-Cwr1Wu9VbOcRz3GdVKkt7lIpNwC1E4Hdb0g+qEkEr3k="; }) - (fetchNuGet { pname = "NLog.Extensions.Logging"; version = "5.3.14"; hash = "sha256-Ckb3z1Ou5dAncADgylCu7yOGfQ7Vh47Oc48PInAi1lA="; }) - (fetchNuGet { pname = "Noggog.CSharpExt"; version = "2.67.3"; hash = "sha256-UjONR5k+miASf4OxLPF9fccYLkfRJsVnktmvvEQDzUc="; }) - (fetchNuGet { pname = "NSubstitute"; version = "5.3.0"; hash = "sha256-fa6Hn9Qmpia2labWOs1Xp2LnJBOHfrWIwxvqKRRccs0="; }) - (fetchNuGet { pname = "NSubstitute.Analyzers.CSharp"; version = "1.0.17"; hash = "sha256-HyMhNJMze3ALJbl71pprjuLCqS+KLA/bOeX4Sng/eb4="; }) - (fetchNuGet { pname = "NuGet.Common"; version = "6.3.4"; hash = "sha256-GDzEyx9/wdVOUAri94uoDjChmfDnBhI90nBfzoHarts="; }) - (fetchNuGet { pname = "NuGet.Configuration"; version = "6.3.4"; hash = "sha256-qXIONIKcCIXJUmNJQs7MINQ18qIEUByTtW5xsORoZoc="; }) - (fetchNuGet { pname = "NuGet.Frameworks"; version = "6.3.4"; hash = "sha256-zqogus3HXQYSiqfnhVH2jd2VZXa+uTsmaw/uwD8dlgY="; }) - (fetchNuGet { pname = "NuGet.Packaging"; version = "6.3.4"; hash = "sha256-1LKM5vgfNKn8v2LcqialwmcynACISR57q13n7I2lQbU="; }) - (fetchNuGet { pname = "NuGet.Protocol"; version = "6.3.4"; hash = "sha256-j3L4bDzM+0/U4dm9q914DNpOzPpOPWhaolfOFKosdAQ="; }) - (fetchNuGet { pname = "NuGet.Resolver"; version = "6.3.4"; hash = "sha256-rXYXgdJMtwne3skk4jMgqyZlwh3QCTX9hIHvvXafxUM="; }) - (fetchNuGet { pname = "NuGet.Versioning"; version = "6.3.4"; hash = "sha256-6CMYVQeGfXu+xner3T3mgl/iQfXiYixoHizmrNA6bvQ="; }) - (fetchNuGet { pname = "ObservableCollections"; version = "3.3.2"; hash = "sha256-pM/2bPf2QvgOhkqA/cSpd/0jAqhOXrtLn01WWZiuoGc="; }) - (fetchNuGet { pname = "ObservableCollections.R3"; version = "3.3.2"; hash = "sha256-q/Ch2JW4H/CvE0oFxmqQDKbgQVo1HfHmtuhMrnFQSEU="; }) - (fetchNuGet { pname = "OneOf"; version = "2.1.125"; hash = "sha256-3XkBNSEMwlNyNpY/H2gtJ47Mc7905p/CJH9d/VJyO3s="; }) - (fetchNuGet { pname = "OneOf"; version = "3.0.271"; hash = "sha256-tFWy8Jg/XVJfVOddjXeCAizq/AUljJrq6J8PF6ArYSU="; }) - (fetchNuGet { pname = "OneOf.Extended"; version = "2.1.125"; hash = "sha256-wJaz49zNFzZwSpMTeabEoJR65Kvk7NCrAqyTKxjfFkg="; }) - (fetchNuGet { pname = "Onigwrap"; version = "1.0.6"; hash = "sha256-p+dhMfIH4C6xLKRUREnUpC0DZwFazjvI+30KRT8TWnU="; }) - (fetchNuGet { pname = "OpenTelemetry"; version = "1.10.0"; hash = "sha256-ucUy3vIabYb0TGDhraqMEzT+LLPmXrO1NgAjEeyVCO8="; }) - (fetchNuGet { pname = "OpenTelemetry.Api"; version = "1.10.0"; hash = "sha256-ZSpQFnNgkk3dO8Q7yokJ/VSl4wp5PuIv9nduxgC6UxU="; }) - (fetchNuGet { pname = "OpenTelemetry.Api.ProviderBuilderExtensions"; version = "1.10.0"; hash = "sha256-hLw3Sf1fviAlVJYhaMudVJEdG5pjX5JvVrqv9DgYAk8="; }) - (fetchNuGet { pname = "OpenTelemetry.Exporter.OpenTelemetryProtocol"; version = "1.10.0"; hash = "sha256-1sKqD/DsEo1nfD4BuuIde/In7W0wAbIEWD3jvvbO8JA="; }) - (fetchNuGet { pname = "OpenTelemetry.Extensions.Hosting"; version = "1.10.0"; hash = "sha256-+O9oaAUYaKUItLAaT7yQUs2nrHVDNkj8YcFuUxiTy6M="; }) - (fetchNuGet { pname = "Pathoschild.Http.FluentClient"; version = "4.4.1"; hash = "sha256-UmMMhtOkhC3l8XHVPsI2aLg9lYgHOePSnkPcUaJumTo="; }) - (fetchNuGet { pname = "Perfolizer"; version = "0.3.17"; hash = "sha256-EfT9EabewLMOAKrxEwpj7QRzqnHODU0tZ08o1w7aV6Q="; }) - (fetchNuGet { pname = "Polly"; version = "8.5.0"; hash = "sha256-oXIqYMkFXoF/9y704LJSX5Non9mry19OSKA7JFviu5Q="; }) - (fetchNuGet { pname = "Polly.Core"; version = "8.4.2"; hash = "sha256-4fn5n6Bu29uqWg8ciii3MDsi9bO2/moPa9B3cJ9Ihe8="; }) - (fetchNuGet { pname = "Polly.Core"; version = "8.5.0"; hash = "sha256-vN/OoQi5F8+oKNO46FwjPcKrgfhGMGjAQ2yCQUlHtOc="; }) - (fetchNuGet { pname = "Polly.Extensions"; version = "8.4.2"; hash = "sha256-oyf9CNi8NXLyeMLwBBCifFvV6erIEaurs8i9BZdr0ik="; }) - (fetchNuGet { pname = "Polly.RateLimiting"; version = "8.4.2"; hash = "sha256-432TfbcJ8UUhDWKLcAFksMjbcU0PlLrK+BrrDxFw4/8="; }) - (fetchNuGet { pname = "Projektanker.Icons.Avalonia"; version = "9.4.1"; hash = "sha256-RK62Wls48/j7QZTLlzHOLCXV0jK/0WBra5367zyit7s="; }) - (fetchNuGet { pname = "Projektanker.Icons.Avalonia.MaterialDesign"; version = "9.4.1"; hash = "sha256-YfGVVfl/Yon9WgJCZscXZMbZoCNg+OvGFvdPSxe+Q1I="; }) - (fetchNuGet { pname = "QoiSharp"; version = "1.0.0"; hash = "sha256-iN/yCXVN0M5+T/Ye9KJ+EGoLsaBxFU/uCIXvX17EhkM="; }) - (fetchNuGet { pname = "R3"; version = "1.0.0"; hash = "sha256-CikGDRUi/EDN2j32cBRl0g+QtdCVYPUizBt41oSVlUA="; }) - (fetchNuGet { pname = "R3"; version = "1.2.9"; hash = "sha256-Wb3ELPbVhxEMqkrQq5vIjGC36VAzIuMdiYqSAEnVXpY="; }) - (fetchNuGet { pname = "R3Extensions.Avalonia"; version = "1.2.9"; hash = "sha256-ZNah6u4+a13E93rYGtZIyYPIb3mkopIjjCzYUgmjCxQ="; }) - (fetchNuGet { pname = "ReactiveUI"; version = "19.5.41"; hash = "sha256-FsdD1lBZyegqOVzJhZHAz1owCLh7GbVUYXiORbo5euk="; }) - (fetchNuGet { pname = "ReactiveUI"; version = "20.1.1"; hash = "sha256-p9l2GMzBRchKb4gW9pQ3DIKhs2O9fX3t/V7jDDztBqE="; }) - (fetchNuGet { pname = "ReactiveUI"; version = "20.1.63"; hash = "sha256-fcLBYRz5WFlPYtIiLA1k/6xxxWhlclVMj7li8z04g68="; }) - (fetchNuGet { pname = "ReactiveUI.Fody"; version = "19.5.41"; hash = "sha256-LfKELxAfApQLL0fDd7UJCsZML5C4MFN+Gc5ECaBXmUM="; }) - (fetchNuGet { pname = "Reloaded.Memory"; version = "9.4.1"; hash = "sha256-bXaTAUx+/SiiMLmxuPumV9z5w1HcHpzEoNuR+xNhafs="; }) - (fetchNuGet { pname = "Reloaded.Memory"; version = "9.4.2"; hash = "sha256-GGS949WoLUPwCYyfbdTOAgXgbV/N0seqL3RegwyPkls="; }) - (fetchNuGet { pname = "RocksDB"; version = "9.4.0.50294"; hash = "sha256-SHt+2Kaj2eCqoeeH28EGlyRUi+g9Y3e9OzVvp946F7I="; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tools"; version = "4.3.0"; hash = "sha256-8yLKFt2wQxkEf7fNfzB+cPUCjYn2qbqNgQ1+EeY2h/I="; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-dsmTLGvt8HqRkDWP8iKVXJCS+akAzENGXKPV18W2RgI="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization.Calendars"; version = "4.3.0"; hash = "sha256-AYh39tgXJVFu8aLi9Y/4rK8yWMaza4S4eaxjfcuEEL4="; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-6MYj0RmLh4EVqMtO/MRqBi0HOn5iG4x9JimgCCJ+EFM="; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Timer"; version = "4.3.0"; hash = "sha256-BgHxXCIbicVZtpgMimSXixhFC3V+p5ODqeljDjO8hCs="; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; }) - (fetchNuGet { pname = "runtime.native.System.IO.Compression"; version = "4.3.0"; hash = "sha256-DWnXs4vlKoU6WxxvCArTJupV6sX3iBbZh8SbqfHace8="; }) - (fetchNuGet { pname = "runtime.native.System.Net.Http"; version = "4.3.0"; hash = "sha256-c556PyheRwpYhweBjSfIwEyZHnAUB8jWioyKEcp/2dg="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; hash = "sha256-2IhBv0i6pTcOyr8FFIyfPEaaCHUmJZ8DYwLUwJ+5waw="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; hash = "sha256-serkd4A7F6eciPiPJtUyJyxzdAtupEcWIZQ9nptEzIM="; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; }) - (fetchNuGet { pname = "runtime.unix.Microsoft.Win32.Primitives"; version = "4.3.0"; hash = "sha256-LZb23lRXzr26tRS5aA0xyB08JxiblPDoA7HBvn6awXg="; }) - (fetchNuGet { pname = "runtime.unix.System.Console"; version = "4.3.0"; hash = "sha256-AHkdKShTRHttqfMjmi+lPpTuCrM5vd/WRy6Kbtie190="; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; }) - (fetchNuGet { pname = "runtime.unix.System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-Pf4mRl6YDK2x2KMh0WdyNgv0VUNdSKVDLlHqozecy5I="; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Primitives"; version = "4.3.0"; hash = "sha256-pHJ+I6i16MV6m77uhTC6GPY6jWGReE3SSP3fVB59ti0="; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Sockets"; version = "4.3.0"; hash = "sha256-IvgOeA2JuBjKl5yAVGjPYMPDzs9phb3KANs95H9v1w4="; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; }) - (fetchNuGet { pname = "SHA3.Net"; version = "2.0.0"; hash = "sha256-rNwk9ry52bN95FeNqNC29FokNRRzKw3XnojO/UzHlYc="; }) - (fetchNuGet { pname = "SharpZipLib"; version = "1.4.2"; hash = "sha256-/giVqikworG2XKqfN9uLyjUSXr35zBuZ2FX2r8X/WUY="; }) - (fetchNuGet { pname = "SharpZstd.Interop"; version = "1.5.6"; hash = "sha256-Y1sCo7RTRtXjkTG2ZAPFx/qXzX4yW8BEaot7Ngfbg8g="; }) - (fetchNuGet { pname = "ShimSkiaSharp"; version = "2.0.0.2"; hash = "sha256-Q1ok5/R8FWDCQubbhPsbRWigGqfiADFYUoiLlCvk/20="; }) - (fetchNuGet { pname = "SimpleInfoName"; version = "3.0.1"; hash = "sha256-9p/BiEqlQczjjUfpUxcFKn71cLAJC7GGvYqRs8fSuuQ="; }) - (fetchNuGet { pname = "SkiaSharp"; version = "2.88.6"; hash = "sha256-y0wzgwdQXtgl5boCz/EgLWbK3SwC0cFVRUbBxOUPQXc="; }) - (fetchNuGet { pname = "SkiaSharp"; version = "2.88.8"; hash = "sha256-rD5gc4SnlRTXwz367uHm8XG5eAIQpZloGqLRGnvNu0A="; }) - (fetchNuGet { pname = "SkiaSharp.HarfBuzz"; version = "2.88.6"; hash = "sha256-gpHiTuHfiXgbkBkzipXb8EXIatefsod75nyrFdPcwcA="; }) - (fetchNuGet { pname = "SkiaSharp.HarfBuzz"; version = "2.88.8"; hash = "sha256-W9jNuEo/8q+k2aHNC19FfKcBUIEWx2zDcGwM+jDZ1o8="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Linux"; version = "2.88.8"; hash = "sha256-fOmNbbjuTazIasOvPkd2NPmuQHVCWPnow7AxllRGl7Y="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.macOS"; version = "2.88.8"; hash = "sha256-CdcrzQHwCcmOCPtS8EGtwsKsgdljnH41sFytW7N9PmI="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.WebAssembly"; version = "2.88.8"; hash = "sha256-GWWsE98f869LiOlqZuXMc9+yuuIhey2LeftGNk3/z3w="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Win32"; version = "2.88.8"; hash = "sha256-b8Vb94rNjwPKSJDQgZ0Xv2dWV7gMVFl5GwTK/QiZPPM="; }) - (fetchNuGet { pname = "Spectre.Console"; version = "0.49.1"; hash = "sha256-tqSVojyuQjuB34lXo759NOcyLgNIw815mKXJPq5JFDo="; }) - (fetchNuGet { pname = "Spectre.Console.Cli"; version = "0.49.1"; hash = "sha256-sar9rhft1ivDMj1kU683+4KxUPUZL+Fb++ewMA6RD4Q="; }) - (fetchNuGet { pname = "Spectre.Console.Testing"; version = "0.49.1"; hash = "sha256-NFZE0ubRmjeOOnkf8EXCp8lya0XK1tclMmtodxJPt1I="; }) - (fetchNuGet { pname = "Splat"; version = "14.8.12"; hash = "sha256-9KTsYPHVN/wiL8/Yy1KQafrFRy7x8VCEHdzgB+9+8SU="; }) - (fetchNuGet { pname = "Splat"; version = "15.1.1"; hash = "sha256-WipAVaUx2HrYNQ9LcYm496LndmSpVbuzJxzP9FA6Ohg="; }) - (fetchNuGet { pname = "Splat"; version = "15.2.22"; hash = "sha256-GSD6XrFYlYj6jkmI7Z4bYCcRIQCRAyzcuVWHmAll5K4="; }) - (fetchNuGet { pname = "Splat.Microsoft.Extensions.Logging"; version = "15.2.22"; hash = "sha256-4QO7NAcOqTDxwsheB2wyXRdH626JylEbahQaKWKZpIc="; }) - (fetchNuGet { pname = "StrawberryShake.Core"; version = "14.1.0"; hash = "sha256-h1Ozv0vdR2UvHIw3JqoBNKPVuD1S31aui7IQ8i8hcnE="; }) - (fetchNuGet { pname = "StrawberryShake.Resources"; version = "14.1.0"; hash = "sha256-6uOb5V7UeHM9OKUTJ4p8/YwvI16LcrC12tPhSAw3U0Q="; }) - (fetchNuGet { pname = "StrawberryShake.Server"; version = "14.1.0"; hash = "sha256-6K6TnX8YL0Dbt8wTv9FmBlbSo+UfaucHi9a5CqWCjoY="; }) - (fetchNuGet { pname = "StrawberryShake.Transport.Http"; version = "14.1.0"; hash = "sha256-Pa2vACAYMgLrAxiZUR7PxBvPY9wrclQRYGZod/VMG5Q="; }) - (fetchNuGet { pname = "StrawberryShake.Transport.WebSockets"; version = "14.1.0"; hash = "sha256-Hqp6GSxMcYorg5v8ns24DNfUDwYGY3urg0FKPleD86I="; }) - (fetchNuGet { pname = "Svg.Custom"; version = "2.0.0.2"; hash = "sha256-6sWw1V2oPdLgLDybH/FT/hUo+CKZiaIfOYv0KUaiTxk="; }) - (fetchNuGet { pname = "Svg.Model"; version = "2.0.0.2"; hash = "sha256-TGkz0qMKvvjMdliqHEsJE1rqKIbezUZrkjofKRduAk8="; }) - (fetchNuGet { pname = "Svg.Skia"; version = "2.0.0.2"; hash = "sha256-8F9LAgj3pdfv5VmnsuS/iHAmI1tajvuSZeTeenS13Lc="; }) - (fetchNuGet { pname = "System.AppContext"; version = "4.3.0"; hash = "sha256-yg95LNQOwFlA1tWxXdQkVyJqT4AnoDc+ACmrNvzGiZg="; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.3.0"; hash = "sha256-XqZWb4Kd04960h4U9seivjKseGA/YEIpdplfHYHQ9jk="; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; hash = "sha256-wws90sfi9M7kuCPWkv1CEYMJtCqx9QB/kj0ymlsNaxI="; }) - (fetchNuGet { pname = "System.CodeDom"; version = "5.0.0"; hash = "sha256-UNqyPrK9eshU5kgJukvPamkaxLAp9BmR/J22OjEX+pM="; }) - (fetchNuGet { pname = "System.CodeDom"; version = "8.0.0"; hash = "sha256-uwVhi3xcvX7eiOGQi7dRETk3Qx1EfHsUfchZsEto338="; }) - (fetchNuGet { pname = "System.CodeDom"; version = "9.0.0"; hash = "sha256-578lcBgswW0eM16r0EnJzfGodPx86RxxFoZHc2PSzsw="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.0.11"; hash = "sha256-puoFMkx4Z55C1XPxNw3np8nzNGjH+G24j43yTIsDRL0="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.0.12"; hash = "sha256-zIEM7AB4SyE9u6G8+o+gCLLwkgi6+3rHQVPdn/dEwB8="; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.3.0"; hash = "sha256-KMY5DfJnDeIsa13DpqvyN8NkReZEMAFnlmNglVoFIXI="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "1.2.0"; hash = "sha256-FQ3l+ulbLSPhQ0JcQCC4D4SzjTnHsRqcOj56Ywy7pMo="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "5.0.0"; hash = "sha256-GdwSIjLMM0uVfE56VUSLVNgpW0B//oCeSFj8/hSlbM8="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "7.0.0"; hash = "sha256-9an2wbxue2qrtugYES9awshQg+KfJqajhnhs45kQIdk="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "8.0.0"; hash = "sha256-F7OVjKNwpqbUh8lTidbqJWYi476nsq9n+6k0+QVRo3w="; }) - (fetchNuGet { pname = "System.CommandLine"; version = "2.0.0-beta4.22272.1"; hash = "sha256-zSO+CYnMH8deBHDI9DHhCPj79Ce3GOzHCyH1/TiHxcc="; }) - (fetchNuGet { pname = "System.ComponentModel"; version = "4.3.0"; hash = "sha256-i00uujMO4JEDIEPKLmdLY3QJ6vdSpw6Gh9oOzkFYBiU="; }) - (fetchNuGet { pname = "System.ComponentModel.Annotations"; version = "4.3.0"; hash = "sha256-zQVRu6SnLS7aKetDaxvo7zAHWLOB7K/mtgs/uaQtYqk="; }) - (fetchNuGet { pname = "System.ComponentModel.Annotations"; version = "4.5.0"; hash = "sha256-15yE2NoT9vmL9oGCaxHClQR1jLW1j1ef5hHMg55xRso="; }) - (fetchNuGet { pname = "System.ComponentModel.Annotations"; version = "5.0.0"; hash = "sha256-0pST1UHgpeE6xJrYf5R+U7AwIlH3rVC3SpguilI/MAg="; }) - (fetchNuGet { pname = "System.ComponentModel.Composition"; version = "4.5.0"; hash = "sha256-xxeZs1zIkhl2ZXU8CaOtCkMX1N290IK7bbHYeEKD0aQ="; }) - (fetchNuGet { pname = "System.Composition"; version = "1.0.31"; hash = "sha256-wcQEG6MCRa1S03s3Yb3E3tfsIBZid99M7WDhcb48Qik="; }) - (fetchNuGet { pname = "System.Composition"; version = "7.0.0"; hash = "sha256-YjhxuzuVdAzRBHNQy9y/1ES+ll3QtLcd2o+o8wIyMao="; }) - (fetchNuGet { pname = "System.Composition.AttributedModel"; version = "1.0.31"; hash = "sha256-u+XnXfj6LQ3OXwrb9KqHRW4a/a9yHzLrJOXwDQ1a/sY="; }) - (fetchNuGet { pname = "System.Composition.AttributedModel"; version = "7.0.0"; hash = "sha256-3s52Dyk2J66v/B4LLYFBMyXl0I8DFDshjE+sMjW4ubM="; }) - (fetchNuGet { pname = "System.Composition.Convention"; version = "1.0.31"; hash = "sha256-GQWo1YDyQ3r2OMcKW+GbR3BbZNIAdwK79XAfinNj+AE="; }) - (fetchNuGet { pname = "System.Composition.Convention"; version = "7.0.0"; hash = "sha256-N4MkkBXSQkcFKsEdcSe6zmyFyMmFOHmI2BNo3wWxftk="; }) - (fetchNuGet { pname = "System.Composition.Hosting"; version = "1.0.31"; hash = "sha256-fg9BIY+zWtiEBIJefYP2lKHDYa4r/vtPTr3ZI8e0K7g="; }) - (fetchNuGet { pname = "System.Composition.Hosting"; version = "7.0.0"; hash = "sha256-7liQGMaVKNZU1iWTIXvqf0SG8zPobRoLsW7q916XC3M="; }) - (fetchNuGet { pname = "System.Composition.Runtime"; version = "1.0.31"; hash = "sha256-mqfxjAnVyE1YCgXMOcV34IWhYFnvXVKjMo9Y/d3yDuo="; }) - (fetchNuGet { pname = "System.Composition.Runtime"; version = "7.0.0"; hash = "sha256-Oo1BxSGLETmdNcYvnkGdgm7JYAnQmv1jY0gL0j++Pd0="; }) - (fetchNuGet { pname = "System.Composition.TypedParts"; version = "1.0.31"; hash = "sha256-w9ApcUJr7jYP4Vf5+efIIqoWmr5v9R56W4uC0n8KktQ="; }) - (fetchNuGet { pname = "System.Composition.TypedParts"; version = "7.0.0"; hash = "sha256-6ZzNdk35qQG3ttiAi4OXrihla7LVP+y2fL3bx40/32s="; }) - (fetchNuGet { pname = "System.Configuration.ConfigurationManager"; version = "4.4.0"; hash = "sha256-+8wGYllXnIxRzy9dLhZFB88GoPj8ivYXS0KUfcivT8I="; }) - (fetchNuGet { pname = "System.Console"; version = "4.3.0"; hash = "sha256-Xh3PPBZr0pDbDaK8AEHbdGz7ePK6Yi1ZyRWI1JM6mbo="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.0.11"; hash = "sha256-P+rSQJVoN6M56jQbs76kZ9G3mAWFdtF27P/RijN8sj4="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "4.3.0"; hash = "sha256-OFJRb0ygep0Z3yDBLwAgM/Tkfs4JCDtsNhwDH9cd1Xw="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "8.0.0"; hash = "sha256-+aODaDEQMqla5RYZeq0Lh66j+xkPYxykrVvSCmJQ+Vs="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "9.0.0"; hash = "sha256-1VzO9i8Uq2KlTw1wnCCrEdABPZuB2JBD5gBsMTFTSvE="; }) - (fetchNuGet { pname = "System.Diagnostics.EventLog"; version = "6.0.0"; hash = "sha256-zUXIQtAFKbiUMKCrXzO4mOTD5EUphZzghBYKXprowSM="; }) - (fetchNuGet { pname = "System.Diagnostics.EventLog"; version = "8.0.0"; hash = "sha256-rt8xc3kddpQY4HEdghlBeOK4gdw5yIj4mcZhAVtk2/Y="; }) - (fetchNuGet { pname = "System.Diagnostics.EventLog"; version = "9.0.0"; hash = "sha256-tPvt6yoAp56sK/fe+/ei8M65eavY2UUhRnbrREj/Ems="; }) - (fetchNuGet { pname = "System.Diagnostics.Tools"; version = "4.3.0"; hash = "sha256-gVOv1SK6Ape0FQhCVlNOd9cvQKBvMxRX9K0JPVi8w0Y="; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.1.0"; hash = "sha256-JA0jJcLbU3zh52ub3zweob2EVHvxOqiC6SCYHrY5WbQ="; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.0.11"; hash = "sha256-qWqFVxuXioesVftv2RVJZOnmojUvRjb7cS3Oh3oTit4="; }) - (fetchNuGet { pname = "System.Formats.Asn1"; version = "5.0.0"; hash = "sha256-9nL3dN4w/dZ49W1pCkTjRqZm6Dh0mMVExNungcBHrKs="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.0.11"; hash = "sha256-rbSgc2PIEc2c2rN6LK3qCREAX3DqA2Nq1WcLrZYsDBw="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.3.0"; hash = "sha256-uNOD0EOVFgnS2fMKvMiEtI9aOw00+Pfy/H+qucAQlPc="; }) - (fetchNuGet { pname = "System.Globalization.Extensions"; version = "4.3.0"; hash = "sha256-mmJWA27T0GRVuFP9/sj+4TrR4GJWrzNIk2PDrbr7RQk="; }) - (fetchNuGet { pname = "System.IO"; version = "4.1.0"; hash = "sha256-V6oyQFwWb8NvGxAwvzWnhPxy9dKOfj/XBM3tEC5aHrw="; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; }) - (fetchNuGet { pname = "System.IO.Abstractions"; version = "21.0.29"; hash = "sha256-91e2/Bd4ZgANw19mKkTdxAy2tv7NutyG0lQTKhMiEpo="; }) - (fetchNuGet { pname = "System.IO.Compression"; version = "4.3.0"; hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; }) - (fetchNuGet { pname = "System.IO.Compression.ZipFile"; version = "4.3.0"; hash = "sha256-WQl+JgWs+GaRMeiahTFUbrhlXIHapzcpTFXbRvAtvvs="; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; }) - (fetchNuGet { pname = "System.IO.Hashing"; version = "8.0.0"; hash = "sha256-szOGt0TNBo6dEdC3gf6H+e9YW3Nw0woa6UnCGGGK5cE="; }) - (fetchNuGet { pname = "System.IO.Hashing"; version = "9.0.0"; hash = "sha256-k6Pdndm5fTD6CB1QsQfP7G+2h4B30CWIsuvjHuBg3fc="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "6.0.3"; hash = "sha256-v+FOmjRRKlDtDW6+TfmyMiiki010YGVTa0EwXu9X7ck="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "7.0.0"; hash = "sha256-W2181khfJUTxLqhuAVRhCa52xZ3+ePGOLIPwEN8WisY="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "8.0.0"; hash = "sha256-LdpB1s4vQzsOODaxiKstLks57X9DTD5D6cPx8DE1wwE="; }) - (fetchNuGet { pname = "System.Linq"; version = "4.1.0"; hash = "sha256-ZQpFtYw5N1F1aX0jUK3Tw+XvM5tnlnshkTCNtfVA794="; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; }) - (fetchNuGet { pname = "System.Linq.Async"; version = "6.0.1"; hash = "sha256-uH5fZhcyQVtnsFc6GTUaRRrAQm05v5euJyWCXSFSOYI="; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.1.0"; hash = "sha256-7zqB+FXgkvhtlBzpcZyd81xczWP0D3uWssyAGw3t7b4="; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.3.0"; hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; }) - (fetchNuGet { pname = "System.Management"; version = "5.0.0"; hash = "sha256-upx2lBRhITuOz9rKth+pBNGvxaLNU3ZOSaS0D+7YHiY="; }) - (fetchNuGet { pname = "System.Management"; version = "8.0.0"; hash = "sha256-HwpfDb++q7/vxR6q57mGFgl5U0vxy+oRJ6orFKORfP0="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.3"; hash = "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.5"; hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; }) - (fetchNuGet { pname = "System.Net.Http"; version = "4.3.0"; hash = "sha256-UoBB7WPDp2Bne/fwxKF0nE8grJ6FzTMXdT/jfsphj8Q="; }) - (fetchNuGet { pname = "System.Net.NameResolution"; version = "4.3.0"; hash = "sha256-eGZwCBExWsnirWBHyp2sSSSXp6g7I6v53qNmwPgtJ5c="; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.3.0"; hash = "sha256-MY7Z6vOtFMbEKaLW9nOSZeAjcWpwCtdO7/W1mkGZBzE="; }) - (fetchNuGet { pname = "System.Net.Sockets"; version = "4.3.0"; hash = "sha256-il7dr5VT/QWDg/0cuh+4Es2u8LY//+qqiY9BZmYxSus="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.4.0"; hash = "sha256-auXQK2flL/JpnB/rEcAcUm4vYMCYMEMiWOCAlIaqu2U="; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.0.12"; hash = "sha256-MudZ/KYcvYsn2cST3EE049mLikrNkmE7QoUoYKKby+s="; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.3.0"; hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; }) - (fetchNuGet { pname = "System.Reactive"; version = "5.0.0"; hash = "sha256-M5Z8pw8rVb8ilbnTdaOptzk5VFd5DlKa7zzCpuytTtE="; }) - (fetchNuGet { pname = "System.Reactive"; version = "6.0.1"; hash = "sha256-Lo5UMqp8DsbVSUxa2UpClR1GoYzqQQcSxkfyFqB/d4Q="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.1.0"; hash = "sha256-idZHGH2Yl/hha1CM4VzLhsaR8Ljo/rV7TYe7mwRJSMs="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.0.1"; hash = "sha256-F1MvYoQWHCY89/O4JBwswogitqVvKuVfILFqA7dmuHk="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.3.0"; hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.7.0"; hash = "sha256-Fw/CSRD+wajH1MqfKS3Q/sIrUH7GN4K+F+Dx68UPNIg="; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.0.1"; hash = "sha256-YG+eJBG5P+5adsHiw/lhJwvREnvdHw6CJyS8ZV4Ujd0="; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.3.0"; hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.3.0"; hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.0.1"; hash = "sha256-NsfmzM9G/sN3H8X2cdnheTGRsh7zbRzvegnjDzDH/FQ="; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "1.3.0"; hash = "sha256-a/RQr++mSsziWaOTknicfIQX/zJrwPFExfhK6PM0tfg="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "1.6.0"; hash = "sha256-JJfgaPav7UfEh4yRAQdGhLZF1brr0tUWPl6qmfNWq/E="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "5.0.0"; hash = "sha256-Wo+MiqhcP9dQ6NuFGrQTw6hpbJORFwp+TBNTq2yhGp8="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "7.0.0"; hash = "sha256-GwAKQhkhPBYTqmRdG9c9taqrKSKDwyUgOEhWLKxWNPI="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "8.0.0"; hash = "sha256-dQGC30JauIDWNWXMrSNOJncVa1umR1sijazYwUDdSIE="; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.0.1"; hash = "sha256-SFSfpWEyCBMAOerrMCOiKnpT+UAWTvRcmoRquJR6Vq0="; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.1.0"; hash = "sha256-R0YZowmFda+xzKNR4kKg7neFoE30KfZwp/IwfRSKVK4="; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.3.0"; hash = "sha256-4U4/XNQAnddgQIHIJq3P2T80hN0oPdU2uCeghsDTWng="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.0.1"; hash = "sha256-cZ2/3/fczLjEpn6j3xkgQV9ouOVjy4Kisgw5xWw9kSw="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.1.0"; hash = "sha256-FViNGM/4oWtlP6w0JC0vJU+k9efLKZ+yaXrnEeabDQo="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.2"; hash = "sha256-8eUXXGWO2LL7uATMZye2iCpQOETn2jCcjUhG6coR5O8="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.3"; hash = "sha256-lnZMUqRO4RYRUeSO8HSJ9yBHqFHLVbmenwHWkIU20ak="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "5.0.0"; hash = "sha256-neARSpLPUzPxEKhJRwoBzhPxK+cKIitLx7WBYncsYgo="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.1.0"; hash = "sha256-X7DZ5CbPY7jHs20YZ7bmcXs9B5Mxptu/HnBUvUnNhGc="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.1.0"; hash = "sha256-QceAYlJvkPRJc/+5jR+wQpNNI3aqGySWWSO30e/FfQY="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices.RuntimeInformation"; version = "4.3.0"; hash = "sha256-MYpl6/ZyC6hjmzWRIe+iDoldOMW1mfbwXsduAnXIKGA="; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.3.0"; hash = "sha256-P5jHCgMbgFMYiONvzmaKFeOqcAIDPu/U8bOVrNPYKqc="; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "4.4.0"; hash = "sha256-J3T2ECVdL0JiBA999CUz77az545CVOYB11/NPA/huEc="; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "4.5.0"; hash = "sha256-AFsKPb/nTk2/mqH/PYpaoI8PLsiKKimaXf+7Mb5VfPM="; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "5.0.0"; hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; }) - (fetchNuGet { pname = "System.Security.Claims"; version = "4.3.0"; hash = "sha256-Fua/rDwAqq4UByRVomAxMPmDBGd5eImRqHVQIeSxbks="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.3.0"; hash = "sha256-tAJvNSlczYBJ3Ed24Ae27a55tq/n4D3fubNQdwcKWA8="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.3.0"; hash = "sha256-u17vy6wNhqok91SrVLno2M1EzLHZm6VMca85xbVChsw="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "5.0.0"; hash = "sha256-nOJP3vdmQaYA07TI373OvZX6uWshETipvi5KpL7oExo="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Csp"; version = "4.3.0"; hash = "sha256-oefdTU/Z2PWU9nlat8uiRDGq/PGZoSPRgkML11pmvPQ="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.3.0"; hash = "sha256-Yuge89N6M+NcblcvXMeyHZ6kZDfwBv3LPMDiF8HhJss="; }) - (fetchNuGet { pname = "System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-DL+D2sc2JrQiB4oAcUggTFyD8w3aLEjJfod5JPe+Oz4="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Pkcs"; version = "5.0.0"; hash = "sha256-kq/tvYQSa24mKSvikFK2fKUAnexSL4PO4LkPppqtYkE="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.3.0"; hash = "sha256-fnFi7B3SnVj5a+BbgXnbjnGNvWrCEU6Hp/wjsjWz318="; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "4.4.0"; hash = "sha256-Ri53QmFX8I8UH0x4PikQ1ZA07ZSnBUXStd5rBfGWFOE="; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.3.0"; hash = "sha256-MG3V/owDh273GCUPsGGraNwaVpcydupl3EtPXj6TVG0="; }) - (fetchNuGet { pname = "System.Security.Permissions"; version = "4.5.0"; hash = "sha256-Fa6dX6Gyse1A/RBoin8cVaHQePbfBvp6jjWxUXPhXKQ="; }) - (fetchNuGet { pname = "System.Security.Principal"; version = "4.3.0"; hash = "sha256-rjudVUHdo8pNJg2EVEn0XxxwNo5h2EaYo+QboPkXlYk="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.3.0"; hash = "sha256-mbdLVUcEwe78p3ZnB6jYsizNEqxMaCAWI3tEQNhRQAE="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.4.0"; hash = "sha256-lwNBM33EW45j6o8bM4hKWirEUZCvep0VYFchc50JOYc="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.5.0"; hash = "sha256-BkUYNguz0e4NJp1kkW7aJBn3dyH9STwB5N8XqnlCsmY="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.0.11"; hash = "sha256-PEailOvG05CVgPTyKLtpAgRydlSHmtd5K0Y8GSHY2Lc="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "4.5.1"; hash = "sha256-PIhkv59IXjyiuefdhKxS9hQfEwO9YWRuNudpo53HQfw="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "7.0.0"; hash = "sha256-eCKTVwumD051ZEcoJcDVRGnIGAsEvKpfH3ydKluHxmo="; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.0.11"; hash = "sha256-+kf7J3dEhgCbnCM5vHYlsTm5/R/Ud0Jr6elpHm922iI="; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "8.0.0"; hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; }) - (fetchNuGet { pname = "System.Text.Json"; version = "8.0.0"; hash = "sha256-XFcCHMW1u2/WujlWNHaIWkbW1wn8W4kI0QdrwPtWmow="; }) - (fetchNuGet { pname = "System.Text.Json"; version = "8.0.4"; hash = "sha256-g5oT7fbXxQ9Iah1nMCr4UUX/a2l+EVjJyTrw3FTbIaI="; }) - (fetchNuGet { pname = "System.Text.Json"; version = "8.0.5"; hash = "sha256-yKxo54w5odWT6nPruUVsaX53oPRe+gKzGvLnnxtwP68="; }) - (fetchNuGet { pname = "System.Text.RegularExpressions"; version = "4.3.0"; hash = "sha256-VLCk1D1kcN2wbAe3d0YQM/PqCsPHOuqlBY1yd2Yo+K0="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.0.11"; hash = "sha256-mob1Zv3qLQhQ1/xOLXZmYqpniNUMCfn02n8ZkaAhqac="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; }) - (fetchNuGet { pname = "System.Threading.Channels"; version = "7.0.0"; hash = "sha256-Cu0gjQsLIR8Yvh0B4cOPJSYVq10a+3F9pVz/C43CNeM="; }) - (fetchNuGet { pname = "System.Threading.RateLimiting"; version = "8.0.0"; hash = "sha256-KOEWEt6ZthvZHJ2Wp70d9nBhBrPqobGQDi2twlKYh/w="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.0.11"; hash = "sha256-5SLxzFg1df6bTm2t09xeI01wa5qQglqUwwJNlQPJIVs="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Dataflow"; version = "4.6.0"; hash = "sha256-YYrT3GRzVBdendxt8FUDCnOBJi0nw/CJ9VrzcPJWLSg="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.3.0"; hash = "sha256-X2hQ5j+fxcmnm88Le/kSavjiGOmkcumBGTZKBLvorPc="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; }) - (fetchNuGet { pname = "System.Threading.ThreadPool"; version = "4.3.0"; hash = "sha256-wW0QdvssRoaOfQLazTGSnwYTurE4R8FxDx70pYkL+gg="; }) - (fetchNuGet { pname = "System.Threading.Timer"; version = "4.3.0"; hash = "sha256-pmhslmhQhP32TWbBzoITLZ4BoORBqYk25OWbru04p9s="; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.3.0"; hash = "sha256-QQ8KgU0lu4F5Unh+TbechO//zaAGZ4MfgvW72Cn1hzA="; }) - (fetchNuGet { pname = "System.Xml.XDocument"; version = "4.3.0"; hash = "sha256-rWtdcmcuElNOSzCehflyKwHkDRpiOhJJs8CeQ0l1CCI="; }) - (fetchNuGet { pname = "TestableIO.System.IO.Abstractions"; version = "21.0.29"; hash = "sha256-OFpu9RcDRPLYntQyesBevoG1XxyH96ukHOH0uXqO5ls="; }) - (fetchNuGet { pname = "TestableIO.System.IO.Abstractions.Wrappers"; version = "21.0.29"; hash = "sha256-2q1HzbyRPIm6VKYzZzZnkXBJzV8S+HBtT6Lej1pv84Y="; }) - (fetchNuGet { pname = "TextMateSharp"; version = "1.0.59"; hash = "sha256-qfAGSgVpTrWMZSk0TFDVP1IgWWi6O1jEEvWc0Pvw9i0="; }) - (fetchNuGet { pname = "TextMateSharp"; version = "1.0.64"; hash = "sha256-49Fdf6ndcb4BKMlWYjkjpJ3pLp17Z10FcGJpfdXvvzc="; }) - (fetchNuGet { pname = "TextMateSharp.Grammars"; version = "1.0.59"; hash = "sha256-ru5VxQK4PFRJhHu+MvCzDt3EwbC/94n1whtDovUAUDA="; }) - (fetchNuGet { pname = "TextMateSharp.Grammars"; version = "1.0.64"; hash = "sha256-ykBZOyvaX1/iFmZjue754qJG4jfPx38ZdHevEZvh7w8="; }) - (fetchNuGet { pname = "Tmds.DBus.Protocol"; version = "0.20.0"; hash = "sha256-CRW/tkgsuBiBJfRwou12ozRQsWhHDooeP88E5wWpWJw="; }) - (fetchNuGet { pname = "TransparentValueObjects"; version = "1.0.2"; hash = "sha256-5d9pIf8hbbcBtj6/oc87f98xEuhBiT6Yq5FR2b/mvUQ="; }) - (fetchNuGet { pname = "Validation"; version = "2.3.7"; hash = "sha256-VTSUT1Ij87fN8zlz7w2HTIUMMx3NBRdbfXmMtFvV5es="; }) - (fetchNuGet { pname = "Validation"; version = "2.4.18"; hash = "sha256-ByITVSjsqVglWPIRaZ3i1P3bHh8+OB6BWgDA8f8qTFI="; }) - (fetchNuGet { pname = "ValveKeyValue"; version = "0.10.0.360"; hash = "sha256-LPQ6isUsA3cQKiO6ADijrCQ2ucx4TD01+kGzei3jIGY="; }) - (fetchNuGet { pname = "Verify"; version = "26.5.0"; hash = "sha256-74kcD01cOebR2lFFnLEJseY6wLpoBzA5FPa73rWIoMM="; }) - (fetchNuGet { pname = "Verify"; version = "27.0.0"; hash = "sha256-eBvZNh7NAUJgyHD/LOdxhd0GnZOADdshhb0HA8Gz8j8="; }) - (fetchNuGet { pname = "Verify"; version = "28.2.1"; hash = "sha256-SF2IgbAseEANZDnFXGd//oQ9uLusWrk0TY/GynyBqTI="; }) - (fetchNuGet { pname = "Verify.ImageMagick"; version = "3.6.0"; hash = "sha256-U6i0pR1ceSDy7+iiRN8RQen3okp6X3De0DK8R5IxxfA="; }) - (fetchNuGet { pname = "Verify.SourceGenerators"; version = "2.5.0"; hash = "sha256-i9TpQJ2+JhSQ7RXkdmC6pkND32V4cLyEaPLGrD/EpYk="; }) - (fetchNuGet { pname = "Verify.Xunit"; version = "28.2.1"; hash = "sha256-2PeJmxMrO8Q3muNtPdscxLsb9q04cTPZ8jQZIG1mDbM="; }) - (fetchNuGet { pname = "Weave"; version = "2.1.0"; hash = "sha256-jyo3pdqJOz3y1GO//jIGxJ9WwRlqMFK+BZET4NfSHVw="; }) - (fetchNuGet { pname = "xunit"; version = "2.9.2"; hash = "sha256-h5+yTTfCmokCPy4lqdEw8RGzQlrlsQAW3Am0Jh0q7oo="; }) - (fetchNuGet { pname = "xunit.abstractions"; version = "2.0.1"; hash = "sha256-v5iPVeoUFsZp9zQMt3rg6xgw6UwF4VMIgzVYFIeb/zA="; }) - (fetchNuGet { pname = "xunit.abstractions"; version = "2.0.2"; hash = "sha256-w5APCW7suBdoDOmQqm/8Gq6+Sk88JcTR09zjmj9s17E="; }) - (fetchNuGet { pname = "xunit.abstractions"; version = "2.0.3"; hash = "sha256-0D1y/C34iARI96gb3bAOG8tcGPMjx+fMabTPpydGlAM="; }) - (fetchNuGet { pname = "xunit.analyzers"; version = "1.16.0"; hash = "sha256-P5Bvl9hvHvF8KY1YWLg4tKiYxlfRnmHyL14jfSACDaU="; }) - (fetchNuGet { pname = "xunit.assert"; version = "2.3.0"; hash = "sha256-lN+NiUEQoHWmoamUjvsNt2PVhHXYeHJHjHRk1BTs6R8="; }) - (fetchNuGet { pname = "xunit.assert"; version = "2.9.2"; hash = "sha256-EE6r526Q4cHn0Ourf1ENpXZ37Lj/P2uNvonHgpdcnq4="; }) - (fetchNuGet { pname = "xunit.core"; version = "2.9.2"; hash = "sha256-zhjV1I5xh0RFckgTEK72tIkLxVl4CPmter2UB++oye8="; }) - (fetchNuGet { pname = "Xunit.DependencyInjection"; version = "9.0.0"; hash = "sha256-nH51bonRwshBIaRYHQr9DUZrQo8q5dggJ03+ngC5bXg="; }) - (fetchNuGet { pname = "Xunit.DependencyInjection"; version = "9.6.0"; hash = "sha256-lZVjKJH961mNw7aX32aG7wSZyCgHoT9okuX92HNqF9c="; }) - (fetchNuGet { pname = "Xunit.DependencyInjection.Logging"; version = "9.0.0"; hash = "sha256-9MerQYIgsByxcZmczyp/fW6ZWgzo4ql6j9Iv/Y47E4A="; }) - (fetchNuGet { pname = "Xunit.DependencyInjection.SkippableFact"; version = "9.0.0"; hash = "sha256-Ub6eSd9/bIhgbqQO+yWtiGfuLIkxSgl6TWfUL4ABkFI="; }) - (fetchNuGet { pname = "xunit.extensibility.core"; version = "2.2.0"; hash = "sha256-et3Se7paKJlg8Ha4Xr9+He40M6vblxyOwS2BQxOgLlE="; }) - (fetchNuGet { pname = "xunit.extensibility.core"; version = "2.4.0"; hash = "sha256-LbuXEcEJjGn3L6FCbC119+MY/QLvfLlGkCeAsCsZqGE="; }) - (fetchNuGet { pname = "xunit.extensibility.core"; version = "2.4.2"; hash = "sha256-wlTMUOQg5NaAPEsWkNSr8QSPbbCNSicpFajp1rowCsA="; }) - (fetchNuGet { pname = "xunit.extensibility.core"; version = "2.9.2"; hash = "sha256-MQAC/4d67Nssu3R+pHPh6vHitBXQYxEEZkVVMGW720c="; }) - (fetchNuGet { pname = "xunit.extensibility.execution"; version = "2.4.0"; hash = "sha256-chRJEazwq93yhVONlbtTI1znqYy0gdAoQajPRnhM/i4="; }) - (fetchNuGet { pname = "xunit.extensibility.execution"; version = "2.4.2"; hash = "sha256-l5Q60IBYWE5tYJCdFEEQnO5rIlXcNEM5S4Ut8vFnL2U="; }) - (fetchNuGet { pname = "xunit.extensibility.execution"; version = "2.9.2"; hash = "sha256-f+9UfoPyK3JIDhQSW0Yu9c4PGqUqZC96DMINCYi2i80="; }) - (fetchNuGet { pname = "xunit.runner.visualstudio"; version = "2.8.2"; hash = "sha256-UlfK348r8kJuraywfdCtpJJxHkv04wPNzpUaz4UM/60="; }) - (fetchNuGet { pname = "Xunit.SkippableFact"; version = "1.4.13"; hash = "sha256-pLtx0/2oTKYO1Y1Vg3k/Eli2OWHT5uorGdBp2uXvFfw="; }) - (fetchNuGet { pname = "ZstdSharp.Port"; version = "0.8.2"; hash = "sha256-mwU4YWaBrbbqQeQ+7ohm/0ewWPD6S8Y2pg6Rqxbi4Ts="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Argon"; + version = "0.24.2"; + hash = "sha256-QUwH6v4XKPU9T/mO/TNvMhoUv8yZHMr/Yg39NO+YV+0="; + }) + (fetchNuGet { + pname = "AutoFixture"; + version = "4.18.1"; + hash = "sha256-reP+aoYiPcIj4GbCIhjd5/OhuWVLCtD4hKuLPHe2EXI="; + }) + (fetchNuGet { + pname = "AutoFixture.Xunit2"; + version = "4.18.1"; + hash = "sha256-5hZm1Rx4n0e2JNsJ6lketE3c8z6AFdquTgKCQORqRfc="; + }) + (fetchNuGet { + pname = "Avalonia"; + version = "11.0.0"; + hash = "sha256-7QE0MtD1QDiG3gRx5xW33E33BXyEtASQSw+Wi3Lmy3E="; + }) + (fetchNuGet { + pname = "Avalonia"; + version = "11.1.3"; + hash = "sha256-kz+k/vkuWoL0XBvRT8SadMOmmRCFk9W/J4k/IM6oYX0="; + }) + (fetchNuGet { + pname = "Avalonia"; + version = "11.2.0"; + hash = "sha256-kG3tnsLdodlvIjYd5feBZ0quGd2FsvV8FIy7uD5UZ5Q="; + }) + (fetchNuGet { + pname = "Avalonia"; + version = "11.2.1"; + hash = "sha256-KdjhwDKlii12v7HNI3NsYAM1qYoXKRsVN2scQJbYMTc="; + }) + (fetchNuGet { + pname = "Avalonia.Angle.Windows.Natives"; + version = "2.1.22045.20230930"; + hash = "sha256-RxPcWUT3b/+R3Tu5E5ftpr5ppCLZrhm+OTsi0SwW3pc="; + }) + (fetchNuGet { + pname = "Avalonia.AvaloniaEdit"; + version = "11.1.0"; + hash = "sha256-K9+hK+4aK93dyuGytYvVU25daz605+KN54hmwQYXFF8="; + }) + (fetchNuGet { + pname = "Avalonia.BuildServices"; + version = "0.0.28"; + hash = "sha256-7NQWQl3xrBDOXhGihCkt5DIrws48KyDGon/7+gPzMDU="; + }) + (fetchNuGet { + pname = "Avalonia.BuildServices"; + version = "0.0.29"; + hash = "sha256-WPHRMNowRnYSCh88DWNBCltWsLPyOfzXGzBqLYE7tRY="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.ColorPicker"; + version = "11.2.1"; + hash = "sha256-yhjVW5pH8Y0JF1vbfcdL5MQfx24wb+Lkp8OBo51he8U="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.DataGrid"; + version = "11.2.1"; + hash = "sha256-IFzA7ztuhgddckQV9DlwkUTSk3RQqkJddCHAtu9yhbY="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.TreeDataGrid"; + version = "11.0.10"; + hash = "sha256-1R2AFOKQQPemN7qXsdxCGXcfMSRztRiC86DLqiV6CpY="; + }) + (fetchNuGet { + pname = "Avalonia.Desktop"; + version = "11.2.1"; + hash = "sha256-Bu4ZEu81g6oWnxd+ew9BZ8zwYETjY8InQsaYvYnGqX4="; + }) + (fetchNuGet { + pname = "Avalonia.Diagnostics"; + version = "11.2.1"; + hash = "sha256-gJhi2clOc+a4NDRZfEoT5BwLTq8DLAWtaxo5FI/OJaY="; + }) + (fetchNuGet { + pname = "Avalonia.FreeDesktop"; + version = "11.2.1"; + hash = "sha256-2j9VfG8uD2BVF+p9REPQ4dp8E41vUh+R3Lh6v5AVmHA="; + }) + (fetchNuGet { + pname = "Avalonia.Headless"; + version = "11.2.1"; + hash = "sha256-3nPxjkPgeH1gJie7b39ezGMe12ZHc5lhuQbYDkoYxME="; + }) + (fetchNuGet { + pname = "Avalonia.Labs.Panels"; + version = "11.2.0"; + hash = "sha256-DhzjF4nhq8XXrCVHh9Eu1NTjVF2oPDNoto4BDQU7EJk="; + }) + (fetchNuGet { + pname = "Avalonia.Native"; + version = "11.2.1"; + hash = "sha256-bBJsvp6gHfBcAWPNKpAAFCk1Wi0gP3tw4qimI93px0U="; + }) + (fetchNuGet { + pname = "Avalonia.ReactiveUI"; + version = "11.2.1"; + hash = "sha256-zEO6YkOuWdSj22KgvKO54UCHnw4rn9F3cd8xXsKRe7s="; + }) + (fetchNuGet { + pname = "Avalonia.Remote.Protocol"; + version = "11.0.0"; + hash = "sha256-gkVpdbk/0RDM7Hhq0jwZwltDpTsGRmbX+ZFTjWYYoKw="; + }) + (fetchNuGet { + pname = "Avalonia.Remote.Protocol"; + version = "11.2.1"; + hash = "sha256-RlO65QbExBdjEUY66CTlHefRdTZWzZbN4ksibVXxKv4="; + }) + (fetchNuGet { + pname = "Avalonia.Skia"; + version = "11.0.0"; + hash = "sha256-A01nrs3Ij1eTo6tPmu7++T1K+Wo/H/9LvpeuOUGbQeU="; + }) + (fetchNuGet { + pname = "Avalonia.Skia"; + version = "11.2.0"; + hash = "sha256-rNR+l+vLtlzTU+F51FpOi4Ujy7nR5+lbTc3NQte8s/o="; + }) + (fetchNuGet { + pname = "Avalonia.Skia"; + version = "11.2.1"; + hash = "sha256-F8Q4q5MaeyCkAm4rc6dPG1DhH5mZMvGzzyr2Z3AUe8s="; + }) + (fetchNuGet { + pname = "Avalonia.Svg.Skia"; + version = "11.2.0"; + hash = "sha256-bbmOWYlVZyQ65BVTYW7BPr++VoM3VwqQLeMzZ6ZnI/o="; + }) + (fetchNuGet { + pname = "Avalonia.Themes.Fluent"; + version = "11.2.1"; + hash = "sha256-yDCJJ9OkL5EIEXr05pdnOK1p+Yp7YIRJn4MVjLX84kE="; + }) + (fetchNuGet { + pname = "Avalonia.Themes.Simple"; + version = "11.2.1"; + hash = "sha256-cdMQ03nOT8jL9cnZrntpzfwgMF/dctE9610eXPV60tA="; + }) + (fetchNuGet { + pname = "Avalonia.Win32"; + version = "11.2.1"; + hash = "sha256-QsQXXKz8vqKwaijR/fZINXHH7Hripwdm+92i9f1k3Xg="; + }) + (fetchNuGet { + pname = "Avalonia.X11"; + version = "11.2.1"; + hash = "sha256-Y2Zem7GhWFHHUwwDT1qUldUCRt8vWZZXi3Fxq+p/Pdg="; + }) + (fetchNuGet { + pname = "AvaloniaEdit.TextMate"; + version = "11.1.0"; + hash = "sha256-Nv52bUxA02VcsKCbMqEAkNBl46gznSivRZ3llLHrhkM="; + }) + (fetchNuGet { + pname = "Bannerlord.LauncherManager"; + version = "1.0.138"; + hash = "sha256-U954PUK8oq1mFBqNjONMXi1DYSudT7gjpueWYBIXDdo="; + }) + (fetchNuGet { + pname = "Bannerlord.LauncherManager.Localization"; + version = "1.0.138"; + hash = "sha256-i7OhCR6pceJU7xyaY1pi67PLSnyDX5YDCIrbHw1Jcuc="; + }) + (fetchNuGet { + pname = "Bannerlord.LauncherManager.Models"; + version = "1.0.138"; + hash = "sha256-mo7Xmj7Ntxgy2/aMzywuyCJ9w/Y1FzbhKOf7fR6ebjw="; + }) + (fetchNuGet { + pname = "Bannerlord.ModuleManager"; + version = "5.0.225"; + hash = "sha256-Kpc2iwgylMJ0w8aL5QkmwHnRsfRXzhV5lFxpbEv0OcU="; + }) + (fetchNuGet { + pname = "Bannerlord.ModuleManager"; + version = "6.0.242"; + hash = "sha256-nHBchr6mLQNOWEyfPGi4nzspaIviQY4j+fGJkUTN0Bs="; + }) + (fetchNuGet { + pname = "Bannerlord.ModuleManager.Models"; + version = "5.0.221"; + hash = "sha256-CWlslG730Ife/Q5ILmNE38IcFikWqlfIqRm6/UwZkzM="; + }) + (fetchNuGet { + pname = "Bannerlord.ModuleManager.Models"; + version = "6.0.242"; + hash = "sha256-iRTxQ7VhrYziaAy3jzD7qEXzq6bOM8eIrB6kyZMurkY="; + }) + (fetchNuGet { + pname = "BenchmarkDotNet"; + version = "0.14.0"; + hash = "sha256-Ynfhr0OsW0dKp81caryZXcrBJsA2YScuKQOCiLVg1rI="; + }) + (fetchNuGet { + pname = "BenchmarkDotNet.Annotations"; + version = "0.14.0"; + hash = "sha256-BKtno0khZ2jZtXF05l9/vsYjbQIqxAimoaSkxyx6L9A="; + }) + (fetchNuGet { + pname = "BitFaster.Caching"; + version = "2.5.2"; + hash = "sha256-rZz3zNPt7DB+H5VDpI3nOrh5Nl4XYvU50CJXGfl3+5A="; + }) + (fetchNuGet { + pname = "BsDiff"; + version = "1.1.0"; + hash = "sha256-JWmzAE+5k8BeGicl4rQNK3Q5F9+VnBpTtUwlKs72pmI="; + }) + (fetchNuGet { + pname = "Castle.Core"; + version = "5.1.1"; + hash = "sha256-oVkQB+ON7S6Q27OhXrTLaxTL0kWB58HZaFFuiw4iTrE="; + }) + (fetchNuGet { + pname = "CliWrap"; + version = "3.6.7"; + hash = "sha256-9j3GILP25inLJoQe0E8sF8egVt8ISqEQBGdIShev4Mk="; + }) + (fetchNuGet { + pname = "ColorDocument.Avalonia"; + version = "11.0.3-a1"; + hash = "sha256-Pkh5FX+4pBzep5oCCyhIiR559QyFCEb1vrfEgG0wREw="; + }) + (fetchNuGet { + pname = "ColorTextBlock.Avalonia"; + version = "11.0.3-a1"; + hash = "sha256-fWJuApxnJLISayQJIKEBVOt/t1Qyj+0s+RezZkMnPio="; + }) + (fetchNuGet { + pname = "CommandLineParser"; + version = "2.9.1"; + hash = "sha256-ApU9y1yX60daSjPk3KYDBeJ7XZByKW8hse9NRZGcjeo="; + }) + (fetchNuGet { + pname = "coverlet.collector"; + version = "6.0.2"; + hash = "sha256-LdSQUrOmjFug47LjtqgtN2MM6BcfG0HR5iL+prVHlDo="; + }) + (fetchNuGet { + pname = "DiffEngine"; + version = "15.5.3"; + hash = "sha256-oZG++i9oWBJhSPHERAQwVODA0GWtp//r2oHpnjgmCeA="; + }) + (fetchNuGet { + pname = "DiffPlex"; + version = "1.7.2"; + hash = "sha256-Vsn81duAmPIPkR40h5bEz7hgtF5Kt5nAAGhQZrQbqxE="; + }) + (fetchNuGet { + pname = "DynamicData"; + version = "8.3.27"; + hash = "sha256-iPZfL1x36PLf5Lq96zRFvR5OLcoRn7OdJIao98X8wac="; + }) + (fetchNuGet { + pname = "DynamicData"; + version = "8.4.1"; + hash = "sha256-r+haH5VlmZFJTEJ3UedsYybw+oddn/CSvfm6x7PrrQ4="; + }) + (fetchNuGet { + pname = "DynamicData"; + version = "9.0.1"; + hash = "sha256-dvo4eSHg8S9oS5QhvfCrbV+y7BVtlYRwH7PN7N1GubM="; + }) + (fetchNuGet { + pname = "DynamicData"; + version = "9.0.4"; + hash = "sha256-3pyiJeWRwfaT7p1ArsoR13aI78Jo13aHOEw3BelTS9g="; + }) + (fetchNuGet { + pname = "EmptyFiles"; + version = "8.5.0"; + hash = "sha256-mLraPiJa1JiXOWQ17GUp8MWuBNrIjcYYjItQRfMjP8s="; + }) + (fetchNuGet { + pname = "ExCSS"; + version = "4.2.3"; + hash = "sha256-M/H6P5p7qqdFz/fgAI2MMBWQ7neN/GIieYSSxxjsM9I="; + }) + (fetchNuGet { + pname = "Fare"; + version = "2.1.1"; + hash = "sha256-n9X3GE2qsT2wpmDymD1AyCYcOoY/c0+t+aIWLiaST70="; + }) + (fetchNuGet { + pname = "FetchBannerlordVersion"; + version = "1.0.6.46"; + hash = "sha256-NS3B8XD4Y398dOXUdjstJ8xrZ+WLGHtGBl+Ewj8agh0="; + }) + (fetchNuGet { + pname = "FetchBannerlordVersion.Models"; + version = "1.0.6.46"; + hash = "sha256-VgTNwXUHGgtoBoLCcXVGgph5Mf36oYYqhISmEgUQMk8="; + }) + (fetchNuGet { + pname = "FluentAssertions"; + version = "5.0.0"; + hash = "sha256-jmGbSHbZhonYWIxqqux8ZOBVY2GNEG9eppNsIn6wEBc="; + }) + (fetchNuGet { + pname = "FluentAssertions"; + version = "6.12.2"; + hash = "sha256-yvbnZapTF610zG8YhMOESn0iXudX4xVCdoSKVo6eu+w="; + }) + (fetchNuGet { + pname = "FluentAssertions.Analyzers"; + version = "0.34.1"; + hash = "sha256-4n26IoSLJRLxyPDyJwF7T+za5xbHO27qM7CarniTADk="; + }) + (fetchNuGet { + pname = "FluentAssertions.OneOf"; + version = "0.0.5"; + hash = "sha256-T/yzpRPwEKh0r6JUPgH2GYkSt36PqOZYr9Qi0grGczo="; + }) + (fetchNuGet { + pname = "FluentResults"; + version = "3.15.2"; + hash = "sha256-NhS7sLhgXDAI4Qwb285HWRtPfUDN6K0tTkKx2QRsI9w="; + }) + (fetchNuGet { + pname = "Fody"; + version = "6.8.0"; + hash = "sha256-2laYscz0i0LalGTAup7dsh6XlYRZSojYpp8XOwZJJfg="; + }) + (fetchNuGet { + pname = "FomodInstaller.Interface"; + version = "1.0.0"; + hash = "sha256-ChhqiNGmj+deuIIYXJWsz7Xmolv9YaeLUlwfothQyjA="; + }) + (fetchNuGet { + pname = "FomodInstaller.Interface"; + version = "1.2.0"; + hash = "sha256-sxylVEA7uiaBtxbQHAeRElsVbZPIj2nm27Ozlik8wmg="; + }) + (fetchNuGet { + pname = "FomodInstaller.Scripting"; + version = "1.0.0"; + hash = "sha256-GNqbLS+lU6aNThUUCfJpmZgP+rd4lF0fKyfMn2Y7Ckg="; + }) + (fetchNuGet { + pname = "FomodInstaller.Scripting.XmlScript"; + version = "1.0.0"; + hash = "sha256-fbekooynf0jQD0k0zbYueDvOTxPa3FIZUKjCcVMPeeY="; + }) + (fetchNuGet { + pname = "FomodInstaller.Utils"; + version = "1.0.0"; + hash = "sha256-H0Fc79msO6GhYstzqtZk9ttRcqxtXuDT9v0zQBwDRHI="; + }) + (fetchNuGet { + pname = "GameFinder"; + version = "4.3.3"; + hash = "sha256-uJzGa5CAa+6oHuG5gU0TN68biDb7ZQYGgqeW1nGLHQc="; + }) + (fetchNuGet { + pname = "GameFinder.Common"; + version = "4.3.3"; + hash = "sha256-0mITSz+9TyknYO8zzvLNB70jWPe5v2Q3sKHPupvGGBk="; + }) + (fetchNuGet { + pname = "GameFinder.Launcher.Heroic"; + version = "4.3.3"; + hash = "sha256-3DuhHRGbWeh4Smj0TXitzUsTPbCwHmtZsk3e+CVZHHA="; + }) + (fetchNuGet { + pname = "GameFinder.RegistryUtils"; + version = "4.3.3"; + hash = "sha256-bd6qpOthn4ljNpwQi7pdVe5P1EN8DnXbyKyR4PnSxJk="; + }) + (fetchNuGet { + pname = "GameFinder.StoreHandlers.EADesktop"; + version = "4.3.3"; + hash = "sha256-jvh672wPSH0T4W6dJHdvMGJi93LWDJBefcVFrkxT6hI="; + }) + (fetchNuGet { + pname = "GameFinder.StoreHandlers.EGS"; + version = "4.3.3"; + hash = "sha256-IKDDTnCor3G7HdsVjo0wYNJQjBoQjQ+a+MgjnGVOaek="; + }) + (fetchNuGet { + pname = "GameFinder.StoreHandlers.GOG"; + version = "4.3.3"; + hash = "sha256-76+W+wi33ms0Xm5OCXQBmHCAilWRaA/OMd343vkkhc0="; + }) + (fetchNuGet { + pname = "GameFinder.StoreHandlers.Origin"; + version = "4.3.3"; + hash = "sha256-Ss48fc+19RqhjkEP0tld5Eui65XwECFeAMu+126JCo4="; + }) + (fetchNuGet { + pname = "GameFinder.StoreHandlers.Steam"; + version = "4.3.3"; + hash = "sha256-EQxtM7k459MfHL0Z2Li45jWji6CgGvpJbJbJv8zXVc4="; + }) + (fetchNuGet { + pname = "GameFinder.StoreHandlers.Xbox"; + version = "4.3.3"; + hash = "sha256-uzIPKS3O/uxqXZMysZfgRlQaDUSUhj1y9hCKAwwhK0g="; + }) + (fetchNuGet { + pname = "GameFinder.Wine"; + version = "4.3.3"; + hash = "sha256-aEFkI7UVHsipCxdvHq3P+mrThgYdrFhpK6EbyFYqU6Y="; + }) + (fetchNuGet { + pname = "Gee.External.Capstone"; + version = "2.3.0"; + hash = "sha256-wdYT/F8SLL72OIVv/Q/hfLMfhlWMnhDNCTWx+wWlPoU="; + }) + (fetchNuGet { + pname = "GitHubActionsTestLogger"; + version = "2.4.1"; + hash = "sha256-bY8RXB3fIsgYIrlLeEuq8dsOfIn8zcbZ0dj2Ra1sFZg="; + }) + (fetchNuGet { + pname = "Google.Protobuf"; + version = "3.22.5"; + hash = "sha256-KuPCqobX6vE9RYElAN9vw+FPonFipms7kE/cRDCLmSQ="; + }) + (fetchNuGet { + pname = "Grpc.Core.Api"; + version = "2.52.0"; + hash = "sha256-ISgN3zWwvV8qD7JFkaYveLbke09+UtUBy3Tux+ZHLNc="; + }) + (fetchNuGet { + pname = "Grpc.Net.Client"; + version = "2.52.0"; + hash = "sha256-4Rhb8PIoV2BiohfRwzx1GYDPbcfqxGAmL2uB0atFFTk="; + }) + (fetchNuGet { + pname = "Grpc.Net.Common"; + version = "2.52.0"; + hash = "sha256-XoY+jt+JIt6SzvCjUSXKKa9Q8Bu5UrNJv2z1hCBKDrY="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp"; + version = "7.3.0.2"; + hash = "sha256-ibgoqzT1NV7Qo5e7X2W6Vt7989TKrkd2M2pu+lhSDg8="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Linux"; + version = "7.3.0.2"; + hash = "sha256-SSfyuyBaduGobJW+reqyioWHhFWsQ+FXa2Gn7TiWxrU="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.macOS"; + version = "7.3.0.2"; + hash = "sha256-dmEqR9MmpCwK8AuscfC7xUlnKIY7+Nvi06V0u5Jff08="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; + version = "7.3.0.3-preview.2.2"; + hash = "sha256-1NlcTnXrWUYZ2r2/N3SPxNIjNcyIpiiv3g7h8XxpNkM="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Win32"; + version = "7.3.0.2"; + hash = "sha256-x4iM3NHs9VyweG57xA74yd4uLuXly147ooe0mvNQ8zo="; + }) + (fetchNuGet { + pname = "HotChocolate.Language.SyntaxTree"; + version = "14.1.0"; + hash = "sha256-4cRFDfLW+A0378BZ0wzPrc7FOiuTdCtlA4gyitSrhiI="; + }) + (fetchNuGet { + pname = "HotChocolate.Transport.Abstractions"; + version = "14.1.0"; + hash = "sha256-i8i4ovnxHcFRrnU/a3U01izWEa+OsOjxgLDRq7wo1vs="; + }) + (fetchNuGet { + pname = "HotChocolate.Transport.Http"; + version = "14.1.0"; + hash = "sha256-e5VoAtmieIhNvhtGMnmPXqYAZE9SrXlfyJmDKF7LBJo="; + }) + (fetchNuGet { + pname = "HotChocolate.Utilities"; + version = "14.1.0"; + hash = "sha256-KIYlc1jDG1BT6gZGZoei6ypHXZo9I3dN4zM/NpDWJuI="; + }) + (fetchNuGet { + pname = "HtmlAgilityPack"; + version = "1.11.70"; + hash = "sha256-V/SI2N1+jNkwjSQRd2Y/XVVhdOKvSNz3/NeIFE9V3wY="; + }) + (fetchNuGet { + pname = "Humanizer"; + version = "2.14.1"; + hash = "sha256-1wGwf5KAmDeiH0Dz8KcTdZw+UMkiNsjKOIOt/VJnnqE="; + }) + (fetchNuGet { + pname = "Humanizer.Core"; + version = "2.14.1"; + hash = "sha256-EXvojddPu+9JKgOG9NSQgUTfWq1RpOYw7adxDPKDJ6o="; + }) + (fetchNuGet { + pname = "Humanizer.Core"; + version = "2.2.0"; + hash = "sha256-5Q6oRaV8wHPONHreKvB74VjV2FW36mwC3n+05It5vyI="; + }) + (fetchNuGet { + pname = "Humanizer.Core.af"; + version = "2.14.1"; + hash = "sha256-8CCgI7OweSa53cZWZBXQ8a7VVt/NPP16zHVBZvzU9KQ="; + }) + (fetchNuGet { + pname = "Humanizer.Core.ar"; + version = "2.14.1"; + hash = "sha256-JRoP+brQgYBZI8OccH/jaM1Z482ZWBiqU2XL3KsIPw8="; + }) + (fetchNuGet { + pname = "Humanizer.Core.az"; + version = "2.14.1"; + hash = "sha256-ubwkbes9zrrisuXTcT4ZgOAiFsUieC6OLd4pgzxsE40="; + }) + (fetchNuGet { + pname = "Humanizer.Core.bg"; + version = "2.14.1"; + hash = "sha256-Xv6DP1xxxGVUfP44TZasWpxgQ/DkriljvmIMtHf+nGk="; + }) + (fetchNuGet { + pname = "Humanizer.Core.bn-BD"; + version = "2.14.1"; + hash = "sha256-6JpReIc3fkExvJIXzk6fUw56wJ78aTEg1dWQ6o+dQow="; + }) + (fetchNuGet { + pname = "Humanizer.Core.cs"; + version = "2.14.1"; + hash = "sha256-MGL86KxSbz0PkDo9+NRj6h1fDjPZXlxAtYNf0Zreg/4="; + }) + (fetchNuGet { + pname = "Humanizer.Core.da"; + version = "2.14.1"; + hash = "sha256-Gpw8kJbgz0KQS2mGY5tmrHqpgUO4abD7dSKIy//ONYM="; + }) + (fetchNuGet { + pname = "Humanizer.Core.de"; + version = "2.14.1"; + hash = "sha256-Eswv8aEQoxI9MZr2CvWtBUn5X9JRZTWQjRzHJkGj80g="; + }) + (fetchNuGet { + pname = "Humanizer.Core.el"; + version = "2.14.1"; + hash = "sha256-wCK2Uy/AV6FxPUSUM0NMbV14pAP+ss25AaVAHMQIeJA="; + }) + (fetchNuGet { + pname = "Humanizer.Core.es"; + version = "2.14.1"; + hash = "sha256-iEHiQXKwg0ABDxh//HSrzwaVOlilQBFI96+GYzzTMwQ="; + }) + (fetchNuGet { + pname = "Humanizer.Core.fa"; + version = "2.14.1"; + hash = "sha256-2Js7k3nvwJvxAjq3yoLn7PUY2S8+vXfgESwU4SbvjaA="; + }) + (fetchNuGet { + pname = "Humanizer.Core.fi-FI"; + version = "2.14.1"; + hash = "sha256-jOWo43r3dhiBsV9cCoDfqK/YqWj5LejZsnfkG6mlkpA="; + }) + (fetchNuGet { + pname = "Humanizer.Core.fr"; + version = "2.14.1"; + hash = "sha256-WCbA+f4B3g/ml7KrkHkzpU2Fj38HtWc/ujoVY5F3lk4="; + }) + (fetchNuGet { + pname = "Humanizer.Core.fr-BE"; + version = "2.14.1"; + hash = "sha256-GydVmoEy+lwEQ1nM39QXSRhYNchqM47p7qhUEimN4Cw="; + }) + (fetchNuGet { + pname = "Humanizer.Core.he"; + version = "2.14.1"; + hash = "sha256-MMf3qjJ+yzxjMxOR7wMWf+eErxWLqpsdWKFhjNCOsyM="; + }) + (fetchNuGet { + pname = "Humanizer.Core.hr"; + version = "2.14.1"; + hash = "sha256-kBv2I9ns6L6D4XfXfyZS1VM6+YwF4yUkCmCA5zqvsok="; + }) + (fetchNuGet { + pname = "Humanizer.Core.hu"; + version = "2.14.1"; + hash = "sha256-vRje+kxqOsl1JCXAE0yDKvauUumzuEhNcnhNsdIdgVM="; + }) + (fetchNuGet { + pname = "Humanizer.Core.hy"; + version = "2.14.1"; + hash = "sha256-UL7PsK4msT5c96lk70/bVAxN63B71l8VOFtvuJQH9a0="; + }) + (fetchNuGet { + pname = "Humanizer.Core.id"; + version = "2.14.1"; + hash = "sha256-nIl64gCuZh4D527qI2hfQRvzt1mTJUCDGMIZwpS3C/A="; + }) + (fetchNuGet { + pname = "Humanizer.Core.is"; + version = "2.14.1"; + hash = "sha256-38vUQ1aVtlhK15kP9ZlDO0Nl0DcOA5iHx6F2SPN1gYM="; + }) + (fetchNuGet { + pname = "Humanizer.Core.it"; + version = "2.14.1"; + hash = "sha256-4ne0VRNi9OAj3bGCQgCy1BNYKMizoHykJ/lchmCsWdc="; + }) + (fetchNuGet { + pname = "Humanizer.Core.ja"; + version = "2.14.1"; + hash = "sha256-oAilMM8J6LumV6qv3gSIBNTm7u2L4vV38cQXtME3PhM="; + }) + (fetchNuGet { + pname = "Humanizer.Core.ko-KR"; + version = "2.14.1"; + hash = "sha256-b70HQl2IWVPATtaYGDyJ+Z6ioPtrM53vXzfTCHYgxpQ="; + }) + (fetchNuGet { + pname = "Humanizer.Core.ku"; + version = "2.14.1"; + hash = "sha256-8LiEH7MaapMtkHFMj7Y3pG+g0QYuIa5gD3VR9nYQn+k="; + }) + (fetchNuGet { + pname = "Humanizer.Core.lv"; + version = "2.14.1"; + hash = "sha256-zyCsE5cD++u5shNIqCQUd+66FkUWOl+NfFrs2JduCaQ="; + }) + (fetchNuGet { + pname = "Humanizer.Core.ms-MY"; + version = "2.14.1"; + hash = "sha256-pSdZLUi9oWo78nBh2DJunPhDR7THdZSZP0msCVbPsrY="; + }) + (fetchNuGet { + pname = "Humanizer.Core.mt"; + version = "2.14.1"; + hash = "sha256-mkX2reEvNpx9w6gtZw+6bkrnj3Di1qgVDMr9q0IeKCw="; + }) + (fetchNuGet { + pname = "Humanizer.Core.nb"; + version = "2.14.1"; + hash = "sha256-QvYJHqjO/SrelWYgtm8Sc7axs7J8wbJE+GbTgVw5LYs="; + }) + (fetchNuGet { + pname = "Humanizer.Core.nb-NO"; + version = "2.14.1"; + hash = "sha256-YW8y2XkmHjwqf2fztNB3rsn3+CgslF1TclITwp0fA9g="; + }) + (fetchNuGet { + pname = "Humanizer.Core.nl"; + version = "2.14.1"; + hash = "sha256-bQM7aXNQMBY+65NfMVQz/xYz9Ad2JC+ryXoB4lcYgmA="; + }) + (fetchNuGet { + pname = "Humanizer.Core.pl"; + version = "2.14.1"; + hash = "sha256-IrPxHI4uQvBeMM9/8PaNueKwVkbN+1zFQlNWRjNfXEA="; + }) + (fetchNuGet { + pname = "Humanizer.Core.pt"; + version = "2.14.1"; + hash = "sha256-XrlC15HNJFmDwLpHIUHb3Bec9A79msQCRB9Dvz8w4l0="; + }) + (fetchNuGet { + pname = "Humanizer.Core.ro"; + version = "2.14.1"; + hash = "sha256-llXtfq4Tr5V2Q4dVD7J0IKITtpiWrFs50DAtJhcSuRI="; + }) + (fetchNuGet { + pname = "Humanizer.Core.ru"; + version = "2.14.1"; + hash = "sha256-lD0dB3mkbFfGExwVWZk6fv24MyQQ8Cdv5OrleuZeChg="; + }) + (fetchNuGet { + pname = "Humanizer.Core.sk"; + version = "2.14.1"; + hash = "sha256-EmyE+wssZwY6tAuEiFXGn5/yzVMZe7QEuTjOcByOXaA="; + }) + (fetchNuGet { + pname = "Humanizer.Core.sl"; + version = "2.14.1"; + hash = "sha256-sWWxh7KZ8Y3Ps6GbBOHbU2GMsNZfkM+BOnUChf3fz4s="; + }) + (fetchNuGet { + pname = "Humanizer.Core.sr"; + version = "2.14.1"; + hash = "sha256-/bA3LULRFn5WYmCscr5R5vaFRjeHC0xjNiF7PXEJ8r0="; + }) + (fetchNuGet { + pname = "Humanizer.Core.sr-Latn"; + version = "2.14.1"; + hash = "sha256-43+o6oj0UNRJKiFoh57MGPSzlsWAq0eRtzlCrewDmVM="; + }) + (fetchNuGet { + pname = "Humanizer.Core.sv"; + version = "2.14.1"; + hash = "sha256-9lXrHveKDs1y/W3Qxd+MVcohhKEU7zNPx21GBVPp/rA="; + }) + (fetchNuGet { + pname = "Humanizer.Core.th-TH"; + version = "2.14.1"; + hash = "sha256-ldCsXINSvL2xom0SCtVQy+qX1IN5//EUoyIOwXiJ3k8="; + }) + (fetchNuGet { + pname = "Humanizer.Core.tr"; + version = "2.14.1"; + hash = "sha256-VZnO1vMXiR7egKEKJ6lBsj7eNgxhFzakFWsYYRW4u2U="; + }) + (fetchNuGet { + pname = "Humanizer.Core.uk"; + version = "2.14.1"; + hash = "sha256-rdvleUrKbj3c06A0O2MkgAZLtXLro9SPB1YqAGE1Vyg="; + }) + (fetchNuGet { + pname = "Humanizer.Core.uz-Cyrl-UZ"; + version = "2.14.1"; + hash = "sha256-Qso1Iz9MTLs63x4F00kK31TZAN4AoFaFsuVzM+1z38k="; + }) + (fetchNuGet { + pname = "Humanizer.Core.uz-Latn-UZ"; + version = "2.14.1"; + hash = "sha256-sVnkZTuEaHfMJIAZmSCqsspnKkYxK9eVBQZnAAqHNW4="; + }) + (fetchNuGet { + pname = "Humanizer.Core.vi"; + version = "2.14.1"; + hash = "sha256-5wDt72+HdNN3mt/iJkxV9LaH13Jc1qr1vB4Lz8ahIPs="; + }) + (fetchNuGet { + pname = "Humanizer.Core.zh-CN"; + version = "2.14.1"; + hash = "sha256-Z3qfFWyovcVT4Hqy51lgW2xGwyfI//Yfv90E0Liy1sw="; + }) + (fetchNuGet { + pname = "Humanizer.Core.zh-Hans"; + version = "2.14.1"; + hash = "sha256-BTGkMEkQYJKRp858EU7hwNOdsHRT+w6vAMa6H8JIyX4="; + }) + (fetchNuGet { + pname = "Humanizer.Core.zh-Hant"; + version = "2.14.1"; + hash = "sha256-N3D1z5aoGwAZ6+ZxrWMtXgacvQcgDG+aLrQQI9uysmM="; + }) + (fetchNuGet { + pname = "Iced"; + version = "1.17.0"; + hash = "sha256-6/5E5v5mqSG7yiE2zHUChZZeC47NRgLzQFD4+7bqKaU="; + }) + (fetchNuGet { + pname = "ini-parser-netstandard"; + version = "2.5.2"; + hash = "sha256-idb2hvuDlxl83x0yttGHnTgEQmwLLdUT7QfMeGDXVJE="; + }) + (fetchNuGet { + pname = "JetBrains.Annotations"; + version = "2024.3.0"; + hash = "sha256-BQYhE7JDJ9Bw588KyWzOvQFvQTiRa0K9maVkI9lZgBc="; + }) + (fetchNuGet { + pname = "K4os.Compression.LZ4"; + version = "1.3.7-beta"; + hash = "sha256-mMNIMLSXnKFF3oAgX+k/n0wipxyRDGE1z2BrI2+7ALc="; + }) + (fetchNuGet { + pname = "K4os.Compression.LZ4"; + version = "1.3.8"; + hash = "sha256-OmT3JwO4qpkZDL7XqiFqZCyxySj64s9t+mXcN1T+IyA="; + }) + (fetchNuGet { + pname = "LinqGen"; + version = "0.3.1"; + hash = "sha256-Yyt1uShHigHVCIjPT8jL2Kth9L9yq1MGrCM5w2+tj9o="; + }) + (fetchNuGet { + pname = "LiveChartsCore"; + version = "2.0.0-rc2"; + hash = "sha256-JSw2bwHOvUDx+axSufcvKSD9RPmqi366tbiIcsym3As="; + }) + (fetchNuGet { + pname = "LiveChartsCore.SkiaSharpView"; + version = "2.0.0-rc2"; + hash = "sha256-tKBTT75B77po0jDqWJL0mOzXkCKmHAGPlQV3biKtZdw="; + }) + (fetchNuGet { + pname = "LiveChartsCore.SkiaSharpView.Avalonia"; + version = "2.0.0-rc2"; + hash = "sha256-pHMtCkoz4sz2MLlVGFbFwwONLC3vzy+9Cg0OmEJ+f/s="; + }) + (fetchNuGet { + pname = "Magick.NET-Q16-AnyCPU"; + version = "14.0.0"; + hash = "sha256-hsFqy7F1s9pO3SWnOuKc4AWEoG7fR8CKSkjfo7pKvzY="; + }) + (fetchNuGet { + pname = "Magick.NET.Core"; + version = "14.0.0"; + hash = "sha256-mwh8d7qmM7m6IbnLSPNq8ZMcD24/1ypM3Gdf6GZm0ao="; + }) + (fetchNuGet { + pname = "Markdown.Avalonia.Tight"; + version = "11.0.3-a1"; + hash = "sha256-KkRzr8BXmUCGCVv/64gg1aiXHUY0yGj5t12OsYAidcw="; + }) + (fetchNuGet { + pname = "MartinCostello.Logging.XUnit"; + version = "0.3.0"; + hash = "sha256-RhcRcww2ZYaB1ZZ/qRN95fMffcsfqP4EKLVeR4+5S9A="; + }) + (fetchNuGet { + pname = "MemoryPack"; + version = "1.21.3"; + hash = "sha256-x0riT7EvbuyX91wq9PIEwDQe1aiBrYD9R9Io16JvprM="; + }) + (fetchNuGet { + pname = "MemoryPack.Core"; + version = "1.21.3"; + hash = "sha256-99ys+oZfBxcmal9PE14bxmR+svGk+J3FqAzxG7qVOHg="; + }) + (fetchNuGet { + pname = "MemoryPack.Generator"; + version = "1.21.3"; + hash = "sha256-TdbsUp0jB/1T4nU1dHS25iizpXLXJ0KWzqo3skMV6KE="; + }) + (fetchNuGet { + pname = "MemoryPack.Streaming"; + version = "1.21.3"; + hash = "sha256-WWJx+aMHnjKVPrOSt0QE0iFh/rNhZCCbUrnww3HdqfI="; + }) + (fetchNuGet { + pname = "MicroCom.Runtime"; + version = "0.11.0"; + hash = "sha256-VdwpP5fsclvNqJuppaOvwEwv2ofnAI5ZSz2V+UEdLF0="; + }) + (fetchNuGet { + pname = "Microsoft.AspNet.WebApi.Client"; + version = "6.0.0"; + hash = "sha256-lNL5C4W7/p8homWooO/3ZKDZQ2M0FUTDixJwqWBPVbo="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.WebUtilities"; + version = "8.0.0"; + hash = "sha256-e4wqTJUgPfq6CfRwuXTw32K9vB+hOpSLxSZDpzv23Yg="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.WebUtilities"; + version = "9.0.0"; + hash = "sha256-LFyhPIJNZLBqOEF4uZ1SpqN/NhjpCHqhzO4R2ApXuj0="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "1.1.0"; + hash = "sha256-QYVojfqSZKbF8P6D/aacfxfumMaRUD9SEEQbzw73Bbc="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "1.1.1"; + hash = "sha256-fAcX4sxE0veWM1CZBtXR/Unky+6sE33yrV7ohrWGKig="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "6.0.0"; + hash = "sha256-49+H/iFwp+AfCICvWcqo9us4CzxApPKC37Q5Eqrw+JU="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "7.0.0"; + hash = "sha256-1e031E26iraIqun84ad0fCIR4MJZ1hcQo4yFN+B7UfE="; + }) + (fetchNuGet { + pname = "Microsoft.Build.Tasks.Git"; + version = "8.0.0"; + hash = "sha256-vX6/kPij8vNAu8f7rrvHHhPrNph20IcufmrBgZNxpQA="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzer.Testing"; + version = "1.1.2"; + hash = "sha256-NeOzfN/9WiX/GsZicQ+oDUuPrZgrxTcP8w7kszAKaaY="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.3.3"; + hash = "sha256-pkZiggwLw8k+CVSXKTzsVGsT+K49LxXUS3VH5PNlpCY="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.3.4"; + hash = "sha256-qDzTfZBSCvAUu9gzq2k+LOvh6/eRvJ9++VCNck/ZpnE="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "1.0.1"; + hash = "sha256-jjWtdrHSISgBF1m94P0DsVbQa4YxKnf2CWRWYHQLTG8="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "3.8.0"; + hash = "sha256-3G9vSc/gHH7FWgOySLTut1+eEaf3H66qcPOvNPLOx4o="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "4.1.0"; + hash = "sha256-g3RLyeHfdOOF6H89VLJi06/k8/eJ6j2dgNYZ/MBdfNU="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "4.11.0"; + hash = "sha256-cX/xgM0VmS+Bsu63KZk2ofjFOOy1mzI+CCVEY6kI+Qk="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "4.8.0"; + hash = "sha256-3IEinVTZq6/aajMVA8XTRO3LTIEt0PuhGyITGJLtqz4="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "3.8.0"; + hash = "sha256-i/r3V/No/VzqmJlWxpGoirvlbJDbBPa/ONZtzYrxuc4="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "4.1.0"; + hash = "sha256-pM9WXvxZI3SS89CGVjxqtAyZyfyiZQzW0UnNCDiQrQA="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "4.11.0"; + hash = "sha256-E9jEOjp9g/CFecsc5/QfRKOPXMRpSw0Tf79XsRgL+Mk="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "4.8.0"; + hash = "sha256-MmOnXJvd/ezs5UPcqyGLnbZz5m+VedpRfB+kFZeeqkU="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.SourceGenerators.Testing"; + version = "1.1.2"; + hash = "sha256-WkdcHsqrFQnXEkcuyWPIPybY25QDzpMEem9KflPwFn0="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.SourceGenerators.Testing.XUnit"; + version = "1.1.2"; + hash = "sha256-wYCDZopLucktDQpzACb/BTj+t4arpFuqUEAKxfjLk7U="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.Workspaces"; + version = "3.8.0"; + hash = "sha256-i6PTXkHepgTXseFFg57iRh5thKtKYc9CH11y/qzDy8k="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.Workspaces"; + version = "4.8.0"; + hash = "sha256-WNzc+6mKqzPviOI0WMdhKyrWs8u32bfGj2XwmfL7bwE="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.SourceGenerators.Testing"; + version = "1.1.2"; + hash = "sha256-5npL4J8jxcBTmNBT9k3CNeGT0lIWfmWBVXwzEiqRypg="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Testing.Verifiers.XUnit"; + version = "1.1.2"; + hash = "sha256-lwRXcej7nA6sa/Ss4HwDBgiMG3NTBx9peiLxn4l0Wrk="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Workspaces.Common"; + version = "1.0.1"; + hash = "sha256-/SYPkq5LhOoEWi+rcBZDyQL2U0cQk2YrykNJODrRLVs="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Workspaces.Common"; + version = "3.8.0"; + hash = "sha256-3D7xV3V1WsUU9OMMEOj+z9GouCDKXSBC4Z/Szs/OcWE="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Workspaces.Common"; + version = "4.8.0"; + hash = "sha256-X8R4SpWVO/gpip5erVZf5jCCx8EX3VzIRtNrQiLDIoM="; + }) + (fetchNuGet { + pname = "Microsoft.CodeCoverage"; + version = "17.11.1"; + hash = "sha256-1dLlK3NGh88PuFYZiYpT+izA96etxhU3BSgixDgdtGA="; + }) + (fetchNuGet { + pname = "Microsoft.Composition"; + version = "1.0.27"; + hash = "sha256-G/3p3zxOWC8HqLt7Ll5cqN7507F6N/G6G/HzKazQRdE="; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.7.0"; + hash = "sha256-Enknv2RsFF68lEPdrf5M+BpV1kHoLTVRApKUwuk/pj0="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.NETCore.Client"; + version = "0.2.251802"; + hash = "sha256-9ZH4rrfACzJP5oiarDW4cD2nczv1SNgZr4GW1J9hlUA="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.Runtime"; + version = "2.2.332302"; + hash = "sha256-5R9xK0owZEhXsucqPKnPaTiwhXBnLo92L2AY7IjyxNg="; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.Tracing.TraceEvent"; + version = "3.1.8"; + hash = "sha256-JFrNrQrXjOJI7v4MpQEDMfmfndM4ThtDZkATAGin9lE="; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.PlatformAbstractions"; + version = "3.1.6"; + hash = "sha256-RfM2qXiqdiamPkXr4IDkNc0IZSF9iTZv4uou/E7zNS0="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.AmbientMetadata.Application"; + version = "9.0.0"; + hash = "sha256-1cEpOtFLK7J9Hnq28Av+pdKaYjRldWVNRD2zhBsbWps="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Compliance.Abstractions"; + version = "9.0.0"; + hash = "sha256-Se92b6d4EEpL9HCD0OwFRlRSGM64+U4PVEid9ncuAqk="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "8.0.0"; + hash = "sha256-9BPsASlxrV8ilmMCjdb3TiUcm5vFZxkBnAI/fNBSEyA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "9.0.0"; + hash = "sha256-uBLeb4z60y8z7NelHs9uT3cLD6wODkdwyfJm6/YZLDM="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "8.0.0"; + hash = "sha256-4eBpDkf7MJozTZnOwQvwcfgRKQGcNXe0K/kF+h5Rl8o="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "9.0.0"; + hash = "sha256-xtG2USC9Qm0f2Nn6jkcklpyEDT3hcEZOxOwTc0ep7uc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "8.0.0"; + hash = "sha256-GanfInGzzoN2bKeNwON8/Hnamr6l7RTpYLA49CNXD9Q="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "9.0.0"; + hash = "sha256-6ajYWcNOQX2WqftgnoUmVtyvC1kkPOtTCif4AiKEffU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.CommandLine"; + version = "8.0.0"; + hash = "sha256-fmPC/o8S+weTtQJWykpnGHm6AKVU21xYE/CaHYU7zgg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.CommandLine"; + version = "9.0.0"; + hash = "sha256-RE6DotU1FM1sy5p3hukT+WOFsDYJRsKX6jx5vhlPceM="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; + version = "8.0.0"; + hash = "sha256-+bjFZvqCsMf2FRM2olqx/fub+QwfM1kBhjGVOT5HC48="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; + version = "9.0.0"; + hash = "sha256-tDJx2prYZpr0RKSwmJfsK9FlUGwaDmyuSz2kqQxsWoI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.FileExtensions"; + version = "8.0.0"; + hash = "sha256-BCxcjVP+kvrDDB0nzsFCJfU74UK4VBvct2JA4r+jNcs="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.FileExtensions"; + version = "9.0.0"; + hash = "sha256-PsLo6mrLGYfbi96rfCG8YS1APXkUXBG4hLstpT60I4s="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Json"; + version = "8.0.0"; + hash = "sha256-Fi/ijcG5l0BOu7i96xHu96aN5/g7zO6SWQbTsI3Qetg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Json"; + version = "9.0.0"; + hash = "sha256-qQn7Ol0CvPYuyecYWYBkPpTMdocO7I6n+jXQI2udzLI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.UserSecrets"; + version = "8.0.0"; + hash = "sha256-/yj5QaEzeRStvOFoBpPRPXlEehGtr2E6/rJb+OEPIK8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.UserSecrets"; + version = "9.0.0"; + hash = "sha256-GoEk+Qq7lbiwWurHYx1LkDaUzIpOzaoTiVGDPfViGak="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "8.0.0"; + hash = "sha256-+qIDR8hRzreCHNEDtUcPfVHQdurzWPo/mqviCH78+EQ="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "9.0.0"; + hash = "sha256-dAH52PPlTLn7X+1aI/7npdrDzMEFPMXRv4isV1a+14k="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "2.0.0"; + hash = "sha256-H1rEnq/veRWvmp8qmUsrQkQIcVlKilUNzmmKsxJ0md8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.0"; + hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.1"; + hash = "sha256-lzTYLpRDAi3wW9uRrkTNJtMmaYdtGJJHdBLbUKu60PM="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.2"; + hash = "sha256-UfLfEQAkXxDaVPC7foE/J3FVEXd31Pu6uQIhTic3JgY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "9.0.0"; + hash = "sha256-CncVwkKZ5CsIG2O0+OM9qXuYXh3p6UGyueTHSLDVL+c="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.AutoActivation"; + version = "9.0.0"; + hash = "sha256-45NiMtCHV4BDkwnSZmsTRJ8dHMDm5WAGhJh4x+z7TiM="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Diagnostics"; + version = "8.0.0"; + hash = "sha256-fBLlb9xAfTgZb1cpBxFs/9eA+BlBvF8Xg0DMkBqdHD4="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Diagnostics"; + version = "9.0.0"; + hash = "sha256-JMbhtjdcWRlrcrbgPlowfj26+pM+MYhnPIaYKnv9byU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Diagnostics.Abstractions"; + version = "8.0.0"; + hash = "sha256-USD5uZOaahMqi6u7owNWx/LR4EDrOwqPrAAim7iRpJY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Diagnostics.Abstractions"; + version = "9.0.0"; + hash = "sha256-wG1LcET+MPRjUdz3HIOTHVEnbG/INFJUqzPErCM79eY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Diagnostics.ExceptionSummarization"; + version = "9.0.0"; + hash = "sha256-Nj8l1ba5iZ5Tubu+vY3a5dgTRkYmGNP2wtXC8Re8aCg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "8.0.0"; + hash = "sha256-uQSXmt47X2HGoVniavjLICbPtD2ReQOYQMgy3l0xuMU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "9.0.0"; + hash = "sha256-mVfLjZ8VrnOQR/uQjv74P2uEG+rgW72jfiGdSZhIfDc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Physical"; + version = "8.0.0"; + hash = "sha256-29y5ZRQ1ZgzVOxHktYxyiH40kVgm5un2yTGdvuSWnRc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Physical"; + version = "9.0.0"; + hash = "sha256-IzFpjKHmF1L3eVbFLUZa2N5aH3oJkJ7KE1duGIS7DP8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileSystemGlobbing"; + version = "8.0.0"; + hash = "sha256-+Oz41JR5jdcJlCJOSpQIL5OMBNi+1Hl2d0JUHfES7sU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileSystemGlobbing"; + version = "9.0.0"; + hash = "sha256-eBLa8pW/y/hRj+JbEr340zbHRABIeFlcdqE0jf5/Uhc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting"; + version = "8.0.0"; + hash = "sha256-sKHa+w4/pMeQb5RRFqLtMTUJy5H6hSIGWchbH2pxSrg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting"; + version = "9.0.0"; + hash = "sha256-apIN4Cz86ujsMp/ibxcvguA9uCFaFqOsZ4kAUPX5ASI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting.Abstractions"; + version = "8.0.0"; + hash = "sha256-0JBx+wwt5p1SPfO4m49KxNOXPAzAU0A+8tEc/itvpQE="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting.Abstractions"; + version = "9.0.0"; + hash = "sha256-NhEDqZGnwCDFyK/NKn1dwLQExYE82j1YVFcrhXVczqY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Http"; + version = "8.0.0"; + hash = "sha256-UgljypOLld1lL7k7h1noazNzvyEHIJw+r+6uGzucFSY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Http"; + version = "9.0.0"; + hash = "sha256-MsStH3oUfyBbcSEoxm+rfxFBKI/rtB5PZrSGvtDjVe0="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Http.Diagnostics"; + version = "9.0.0"; + hash = "sha256-4XtkhRMXTFR1I85rJ73BFa01XDRW/fz4+Jig0S/Wm3M="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Http.Resilience"; + version = "9.0.0"; + hash = "sha256-GFGvnupmgvTgbmknxpF7H3DmxqvX9JOdxKuK2lR6bVM="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "2.0.0"; + hash = "sha256-Bg3bFJPjQRJnPvlEc5v7lzwRaUTzKwXDtz81GjCTfMo="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "2.1.1"; + hash = "sha256-HnEBmAhweBalCAeX+KZ4kEL3GXEVDBg6Uq4H4LJ56oo="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "8.0.0"; + hash = "sha256-Meh0Z0X7KyOEG4l0RWBcuHHihcABcvCyfUXgasmQ91o="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "9.0.0"; + hash = "sha256-kR16c+N8nQrWeYLajqnXPg7RiXjZMSFLnKLEs4VfjcM="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "2.0.0"; + hash = "sha256-cBBNcoREIdCDnwZtnTG+BoAFmVb71P1nhFOAH07UsfQ="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "3.0.3"; + hash = "sha256-UFawgCAhbN5HCtJy39XO4sz5N/P/Zyrs0uqrQHc4SPI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "6.0.1"; + hash = "sha256-v3FWpuKXlBIW5NwqQx0Ffb6y58RlevIyO/byqeLphJ8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "8.0.0"; + hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "9.0.0"; + hash = "sha256-iBTs9twjWXFeERt4CErkIIcoJZU1jrd1RWCI8V5j7KU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Configuration"; + version = "8.0.0"; + hash = "sha256-mzmstNsVjKT0EtQcdAukGRifD30T82BMGYlSu8k4K7U="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Configuration"; + version = "9.0.0"; + hash = "sha256-ysPjBq64p6JM4EmeVndryXnhLWHYYszzlVpPxRWkUkw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Console"; + version = "8.0.0"; + hash = "sha256-bdb9YWWVn//AeySp7se87/tCN2E7e8Gx2GPMw28cd9c="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Console"; + version = "9.0.0"; + hash = "sha256-N2t9EUdlS6ippD4Z04qUUyBuQ4tKSR/8TpmKScb5zRw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Debug"; + version = "8.0.0"; + hash = "sha256-AJunzYBZM2wCg86hnPnMrBuWIIyW/4PnIVoDSU969cA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Debug"; + version = "9.0.0"; + hash = "sha256-5W6fP9Eb98U3MTWKeLzSNl2cRFpE694OOPjpWp/qTAk="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.EventLog"; + version = "8.0.0"; + hash = "sha256-vXBm4yhWGP4uow0CqstuqOkxO8yeZEM15JTTenjPbhc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.EventLog"; + version = "9.0.0"; + hash = "sha256-mIL1I85Ef5+/mXl24odoUpcXet+jCZTRtKCd5z6YUwI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.EventSource"; + version = "8.0.0"; + hash = "sha256-kaR7YOlq5s8W9nZDtH/lKtnfGbrgOuQY4DUPcA2lcj0="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.EventSource"; + version = "9.0.0"; + hash = "sha256-pplZskMsR3gGbs3I0wycGsvIMPIpfWFJpOsR9GkiYRw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.ObjectPool"; + version = "8.0.0"; + hash = "sha256-FxFr5GC0y6vnp5YD2A2vISXYizAz3k/QyrH7sBXP5kg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.ObjectPool"; + version = "9.0.0"; + hash = "sha256-mX2Y2bHwScjXh1xQOweawmwo7jYLw+MhePibk/96dMY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "2.0.0"; + hash = "sha256-EMvaXxGzueI8lT97bYJQr0kAj1IK0pjnAcWN82hTnzw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "8.0.0"; + hash = "sha256-n2m4JSegQKUTlOsKLZUUHHKMq926eJ0w9N9G+I3FoFw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "9.0.0"; + hash = "sha256-DT5euAQY/ItB5LPI8WIp6Dnd0lSvBRP35vFkOXC68ck="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; + version = "8.0.0"; + hash = "sha256-A5Bbzw1kiNkgirk5x8kyxwg9lLTcSngojeD+ocpG1RI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; + version = "9.0.0"; + hash = "sha256-r1Z3sEVSIjeH2UKj+KMj86har68g/zybSqoSjESBcoA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "8.0.0"; + hash = "sha256-FU8qj3DR8bDdc1c+WeGZx/PCZeqqndweZM9epcpXjSo="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "9.0.0"; + hash = "sha256-ZNLusK1CRuq5BZYZMDqaz04PIKScE2Z7sS2tehU7EJs="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Resilience"; + version = "9.0.0"; + hash = "sha256-3zd2zOR8C3+VaPpUnJ+wcCaBbvzU8DjGGuaZ/dxsqQQ="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Telemetry"; + version = "9.0.0"; + hash = "sha256-MKltsZC6s7sE8mO1XpOOzgFbp3CJS7sHGMH92DjXSso="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Telemetry.Abstractions"; + version = "9.0.0"; + hash = "sha256-rGeoVSc3RJlhL8Sv8CgDh2+BOiFHllKl2K9vtXxl+Ec="; + }) + (fetchNuGet { + pname = "Microsoft.IO.RecyclableMemoryStream"; + version = "3.0.0"; + hash = "sha256-WBXkqxC5g4tJ481sa1uft39LqA/5hx5yOfiTfMRMg/4="; + }) + (fetchNuGet { + pname = "Microsoft.Net.Http.Headers"; + version = "9.0.0"; + hash = "sha256-fJ42UoMaftaGZbMA5LlGhZNns1hQY2eLkw6EEeCYcAQ="; + }) + (fetchNuGet { + pname = "Microsoft.NET.Test.Sdk"; + version = "17.11.1"; + hash = "sha256-0JUEucQ2lzaPgkrjm/NFLBTbqU1dfhvhN3Tl3moE6mI="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "2.0.0"; + hash = "sha256-IEvBk6wUXSdyCnkj6tHahOJv290tVVT8tyemYcR0Yro="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "2.1.2"; + hash = "sha256-gYQQO7zsqG+OtN4ywYQyfsiggS2zmxw4+cPXlK+FB5Q="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "5.0.0"; + hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; + }) + (fetchNuGet { + pname = "Microsoft.SourceLink.Common"; + version = "8.0.0"; + hash = "sha256-AfUqleVEqWuHE7z2hNiwOLnquBJ3tuYtbkdGMppHOXc="; + }) + (fetchNuGet { + pname = "Microsoft.SourceLink.GitHub"; + version = "8.0.0"; + hash = "sha256-hNTkpKdCLY5kIuOmznD1mY+pRdJ0PKu2HypyXog9vb0="; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.ObjectModel"; + version = "17.10.0"; + hash = "sha256-3YjVGK2zEObksBGYg8b/CqoJgLQ1jUv4GCWNjDhLRh4="; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.ObjectModel"; + version = "17.11.1"; + hash = "sha256-5vX+vCzFY3S7xfMVIv8OlMMFtdedW9UIJzc0WEc+vm4="; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.TestHost"; + version = "17.11.1"; + hash = "sha256-wSkY0H1fQAq0H3LcKT4u7Y5RzhAAPa6yueVN84g8HxU="; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Composition"; + version = "16.1.8"; + hash = "sha256-yFT4t3Uk31R5EPdAxxsTAmRuiv58MlYoYL4JT1ywlHQ="; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Composition.NetFxAttributes"; + version = "16.1.8"; + hash = "sha256-FFemIG+m8RWUPo5W+kCHPh5Yn4fGS+tpjGiQTcT0sAE="; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Threading"; + version = "17.10.48"; + hash = "sha256-WL8c7TjDBHGjsVLMMPf9cin8rirzOdxusEBQlkUfiVU="; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Threading.Analyzers"; + version = "17.10.48"; + hash = "sha256-EvZGbyxtrJDvHZwsQbZDXtVfWiy0f58oCdTdSzD34wI="; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Validation"; + version = "15.0.82"; + hash = "sha256-7JFaA/HZHVjsEtTh/iHDRLi5RcuA39KKvvCkuI4JQFc="; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Validation"; + version = "17.8.8"; + hash = "sha256-sB8GLRiJHX3Py7qeBUnUANiDWhyPtISon6HQs+8wKms="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.3.0"; + hash = "sha256-mBNDmPXNTW54XLnPAUwBRvkIORFM7/j0D0I2SyQPDEg="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "4.4.0"; + hash = "sha256-ZumsykAAIYKmVtP4QI5kZ0J10n2zcOZZ69PmAK0SEiE="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "5.0.0"; + hash = "sha256-9kylPGfKZc58yFqNKa77stomcoNnMeERXozWJzDcUIA="; + }) + (fetchNuGet { + pname = "Nerdbank.FullDuplexStream"; + version = "1.1.12"; + hash = "sha256-PZwy+qQ8nOdH5gRRQ24go2yh+YmZQhziwbyWC+1qoJc="; + }) + (fetchNuGet { + pname = "Nerdbank.Streams"; + version = "2.11.79"; + hash = "sha256-1bzibVcSH8LJMR8Nb6Q0q/7fieTgxRnVY4C1RvRbrrI="; + }) + (fetchNuGet { + pname = "NetEscapades.EnumGenerators"; + version = "1.0.0-beta07"; + hash = "sha256-SYIuk1B2birutYx6d0vbCshEd8ZEH0pDVrNm9daBxwY="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "1.6.0"; + hash = "sha256-ExWI1EKDCRishcfAeHVS/RoJphqSqohmJIC/wz3ZtVo="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "1.6.1"; + hash = "sha256-iNan1ix7RtncGWC9AjAZ2sk70DoxOsmEOgQ10fXm4Pw="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "12.0.1"; + hash = "sha256-4Xf3RZrJomAh3jaZrEAJX3oPmOowGV8yDB9Y3h0Dw4U="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.1"; + hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.3"; + hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json.Bson"; + version = "1.0.2"; + hash = "sha256-ZUj6YFSMZp5CZtXiamw49eZmbp1iYBuNsIKNnjxcRzA="; + }) + (fetchNuGet { + pname = "NexusMods.Archives.Nx"; + version = "0.6.1"; + hash = "sha256-NDUxypEccSlGBG9nYTJJiTqYrZWjSjV1xt/uUbtfeS8="; + }) + (fetchNuGet { + pname = "NexusMods.Hashing.xxHash3"; + version = "3.0.3"; + hash = "sha256-lhuuHZvH1klH6HE00h1On6icd6CLdFqvLLkfb3x1VVY="; + }) + (fetchNuGet { + pname = "NexusMods.Hashing.xxHash3.Paths"; + version = "3.0.3"; + hash = "sha256-UeOX3Y8MGmAgWHWH3GolsA/MyNM9iam75pxxRXhd50M="; + }) + (fetchNuGet { + pname = "NexusMods.MnemonicDB"; + version = "0.9.97"; + hash = "sha256-b0k/hM6UYvMTZN2QMk53QN9Fw/pomXJ88k9QqfrAF+s="; + }) + (fetchNuGet { + pname = "NexusMods.MnemonicDB.Abstractions"; + version = "0.9.97"; + hash = "sha256-EnWQMeXMKwziMoBXKf7t+Ru6EHZBml4Pt3h1eSP1Ud0="; + }) + (fetchNuGet { + pname = "NexusMods.MnemonicDB.SourceGenerator"; + version = "0.9.97"; + hash = "sha256-KOZVhS3H/qY6bRW9HmSF1Ud4fXv5oEWORDdYET9Ochw="; + }) + (fetchNuGet { + pname = "NexusMods.Paths"; + version = "0.10.0"; + hash = "sha256-tzUKPBrGNyZvVgScDAP0qvVF5nV6635v3NlBvzpnz1M="; + }) + (fetchNuGet { + pname = "NexusMods.Paths"; + version = "0.15.0"; + hash = "sha256-No2kbrDVmJ5ySLm7jH+gNAfNLVnsv4AtLT1phcuOFLc="; + }) + (fetchNuGet { + pname = "NexusMods.Paths.Extensions.Nx"; + version = "0.15.0"; + hash = "sha256-8QT+Iu32u4m5wqMG2bAqramnUQPLDmUB8/c+ew4fRqM="; + }) + (fetchNuGet { + pname = "NexusMods.Paths.TestingHelpers"; + version = "0.15.0"; + hash = "sha256-xUZIAND1Ob0SRuoTTuJqw7N2j/4ncIlck3lgfeWxd5M="; + }) + (fetchNuGet { + pname = "NLog"; + version = "5.3.4"; + hash = "sha256-Cwr1Wu9VbOcRz3GdVKkt7lIpNwC1E4Hdb0g+qEkEr3k="; + }) + (fetchNuGet { + pname = "NLog.Extensions.Logging"; + version = "5.3.14"; + hash = "sha256-Ckb3z1Ou5dAncADgylCu7yOGfQ7Vh47Oc48PInAi1lA="; + }) + (fetchNuGet { + pname = "Noggog.CSharpExt"; + version = "2.67.3"; + hash = "sha256-UjONR5k+miASf4OxLPF9fccYLkfRJsVnktmvvEQDzUc="; + }) + (fetchNuGet { + pname = "NSubstitute"; + version = "5.3.0"; + hash = "sha256-fa6Hn9Qmpia2labWOs1Xp2LnJBOHfrWIwxvqKRRccs0="; + }) + (fetchNuGet { + pname = "NSubstitute.Analyzers.CSharp"; + version = "1.0.17"; + hash = "sha256-HyMhNJMze3ALJbl71pprjuLCqS+KLA/bOeX4Sng/eb4="; + }) + (fetchNuGet { + pname = "NuGet.Common"; + version = "6.3.4"; + hash = "sha256-GDzEyx9/wdVOUAri94uoDjChmfDnBhI90nBfzoHarts="; + }) + (fetchNuGet { + pname = "NuGet.Configuration"; + version = "6.3.4"; + hash = "sha256-qXIONIKcCIXJUmNJQs7MINQ18qIEUByTtW5xsORoZoc="; + }) + (fetchNuGet { + pname = "NuGet.Frameworks"; + version = "6.3.4"; + hash = "sha256-zqogus3HXQYSiqfnhVH2jd2VZXa+uTsmaw/uwD8dlgY="; + }) + (fetchNuGet { + pname = "NuGet.Packaging"; + version = "6.3.4"; + hash = "sha256-1LKM5vgfNKn8v2LcqialwmcynACISR57q13n7I2lQbU="; + }) + (fetchNuGet { + pname = "NuGet.Protocol"; + version = "6.3.4"; + hash = "sha256-j3L4bDzM+0/U4dm9q914DNpOzPpOPWhaolfOFKosdAQ="; + }) + (fetchNuGet { + pname = "NuGet.Resolver"; + version = "6.3.4"; + hash = "sha256-rXYXgdJMtwne3skk4jMgqyZlwh3QCTX9hIHvvXafxUM="; + }) + (fetchNuGet { + pname = "NuGet.Versioning"; + version = "6.3.4"; + hash = "sha256-6CMYVQeGfXu+xner3T3mgl/iQfXiYixoHizmrNA6bvQ="; + }) + (fetchNuGet { + pname = "ObservableCollections"; + version = "3.3.2"; + hash = "sha256-pM/2bPf2QvgOhkqA/cSpd/0jAqhOXrtLn01WWZiuoGc="; + }) + (fetchNuGet { + pname = "ObservableCollections.R3"; + version = "3.3.2"; + hash = "sha256-q/Ch2JW4H/CvE0oFxmqQDKbgQVo1HfHmtuhMrnFQSEU="; + }) + (fetchNuGet { + pname = "OneOf"; + version = "2.1.125"; + hash = "sha256-3XkBNSEMwlNyNpY/H2gtJ47Mc7905p/CJH9d/VJyO3s="; + }) + (fetchNuGet { + pname = "OneOf"; + version = "3.0.271"; + hash = "sha256-tFWy8Jg/XVJfVOddjXeCAizq/AUljJrq6J8PF6ArYSU="; + }) + (fetchNuGet { + pname = "OneOf.Extended"; + version = "2.1.125"; + hash = "sha256-wJaz49zNFzZwSpMTeabEoJR65Kvk7NCrAqyTKxjfFkg="; + }) + (fetchNuGet { + pname = "Onigwrap"; + version = "1.0.6"; + hash = "sha256-p+dhMfIH4C6xLKRUREnUpC0DZwFazjvI+30KRT8TWnU="; + }) + (fetchNuGet { + pname = "OpenTelemetry"; + version = "1.10.0"; + hash = "sha256-ucUy3vIabYb0TGDhraqMEzT+LLPmXrO1NgAjEeyVCO8="; + }) + (fetchNuGet { + pname = "OpenTelemetry.Api"; + version = "1.10.0"; + hash = "sha256-ZSpQFnNgkk3dO8Q7yokJ/VSl4wp5PuIv9nduxgC6UxU="; + }) + (fetchNuGet { + pname = "OpenTelemetry.Api.ProviderBuilderExtensions"; + version = "1.10.0"; + hash = "sha256-hLw3Sf1fviAlVJYhaMudVJEdG5pjX5JvVrqv9DgYAk8="; + }) + (fetchNuGet { + pname = "OpenTelemetry.Exporter.OpenTelemetryProtocol"; + version = "1.10.0"; + hash = "sha256-1sKqD/DsEo1nfD4BuuIde/In7W0wAbIEWD3jvvbO8JA="; + }) + (fetchNuGet { + pname = "OpenTelemetry.Extensions.Hosting"; + version = "1.10.0"; + hash = "sha256-+O9oaAUYaKUItLAaT7yQUs2nrHVDNkj8YcFuUxiTy6M="; + }) + (fetchNuGet { + pname = "Pathoschild.Http.FluentClient"; + version = "4.4.1"; + hash = "sha256-UmMMhtOkhC3l8XHVPsI2aLg9lYgHOePSnkPcUaJumTo="; + }) + (fetchNuGet { + pname = "Perfolizer"; + version = "0.3.17"; + hash = "sha256-EfT9EabewLMOAKrxEwpj7QRzqnHODU0tZ08o1w7aV6Q="; + }) + (fetchNuGet { + pname = "Polly"; + version = "8.5.0"; + hash = "sha256-oXIqYMkFXoF/9y704LJSX5Non9mry19OSKA7JFviu5Q="; + }) + (fetchNuGet { + pname = "Polly.Core"; + version = "8.4.2"; + hash = "sha256-4fn5n6Bu29uqWg8ciii3MDsi9bO2/moPa9B3cJ9Ihe8="; + }) + (fetchNuGet { + pname = "Polly.Core"; + version = "8.5.0"; + hash = "sha256-vN/OoQi5F8+oKNO46FwjPcKrgfhGMGjAQ2yCQUlHtOc="; + }) + (fetchNuGet { + pname = "Polly.Extensions"; + version = "8.4.2"; + hash = "sha256-oyf9CNi8NXLyeMLwBBCifFvV6erIEaurs8i9BZdr0ik="; + }) + (fetchNuGet { + pname = "Polly.RateLimiting"; + version = "8.4.2"; + hash = "sha256-432TfbcJ8UUhDWKLcAFksMjbcU0PlLrK+BrrDxFw4/8="; + }) + (fetchNuGet { + pname = "Projektanker.Icons.Avalonia"; + version = "9.4.1"; + hash = "sha256-RK62Wls48/j7QZTLlzHOLCXV0jK/0WBra5367zyit7s="; + }) + (fetchNuGet { + pname = "Projektanker.Icons.Avalonia.MaterialDesign"; + version = "9.4.1"; + hash = "sha256-YfGVVfl/Yon9WgJCZscXZMbZoCNg+OvGFvdPSxe+Q1I="; + }) + (fetchNuGet { + pname = "QoiSharp"; + version = "1.0.0"; + hash = "sha256-iN/yCXVN0M5+T/Ye9KJ+EGoLsaBxFU/uCIXvX17EhkM="; + }) + (fetchNuGet { + pname = "R3"; + version = "1.0.0"; + hash = "sha256-CikGDRUi/EDN2j32cBRl0g+QtdCVYPUizBt41oSVlUA="; + }) + (fetchNuGet { + pname = "R3"; + version = "1.2.9"; + hash = "sha256-Wb3ELPbVhxEMqkrQq5vIjGC36VAzIuMdiYqSAEnVXpY="; + }) + (fetchNuGet { + pname = "R3Extensions.Avalonia"; + version = "1.2.9"; + hash = "sha256-ZNah6u4+a13E93rYGtZIyYPIb3mkopIjjCzYUgmjCxQ="; + }) + (fetchNuGet { + pname = "ReactiveUI"; + version = "19.5.41"; + hash = "sha256-FsdD1lBZyegqOVzJhZHAz1owCLh7GbVUYXiORbo5euk="; + }) + (fetchNuGet { + pname = "ReactiveUI"; + version = "20.1.1"; + hash = "sha256-p9l2GMzBRchKb4gW9pQ3DIKhs2O9fX3t/V7jDDztBqE="; + }) + (fetchNuGet { + pname = "ReactiveUI"; + version = "20.1.63"; + hash = "sha256-fcLBYRz5WFlPYtIiLA1k/6xxxWhlclVMj7li8z04g68="; + }) + (fetchNuGet { + pname = "ReactiveUI.Fody"; + version = "19.5.41"; + hash = "sha256-LfKELxAfApQLL0fDd7UJCsZML5C4MFN+Gc5ECaBXmUM="; + }) + (fetchNuGet { + pname = "Reloaded.Memory"; + version = "9.4.1"; + hash = "sha256-bXaTAUx+/SiiMLmxuPumV9z5w1HcHpzEoNuR+xNhafs="; + }) + (fetchNuGet { + pname = "Reloaded.Memory"; + version = "9.4.2"; + hash = "sha256-GGS949WoLUPwCYyfbdTOAgXgbV/N0seqL3RegwyPkls="; + }) + (fetchNuGet { + pname = "RocksDB"; + version = "9.4.0.50294"; + hash = "sha256-SHt+2Kaj2eCqoeeH28EGlyRUi+g9Y3e9OzVvp946F7I="; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tools"; + version = "4.3.0"; + hash = "sha256-8yLKFt2wQxkEf7fNfzB+cPUCjYn2qbqNgQ1+EeY2h/I="; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-dsmTLGvt8HqRkDWP8iKVXJCS+akAzENGXKPV18W2RgI="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization.Calendars"; + version = "4.3.0"; + hash = "sha256-AYh39tgXJVFu8aLi9Y/4rK8yWMaza4S4eaxjfcuEEL4="; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-6MYj0RmLh4EVqMtO/MRqBi0HOn5iG4x9JimgCCJ+EFM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Timer"; + version = "4.3.0"; + hash = "sha256-BgHxXCIbicVZtpgMimSXixhFC3V+p5ODqeljDjO8hCs="; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; + }) + (fetchNuGet { + pname = "runtime.native.System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-DWnXs4vlKoU6WxxvCArTJupV6sX3iBbZh8SbqfHace8="; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Http"; + version = "4.3.0"; + hash = "sha256-c556PyheRwpYhweBjSfIwEyZHnAUB8jWioyKEcp/2dg="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + hash = "sha256-2IhBv0i6pTcOyr8FFIyfPEaaCHUmJZ8DYwLUwJ+5waw="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + hash = "sha256-serkd4A7F6eciPiPJtUyJyxzdAtupEcWIZQ9nptEzIM="; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; + }) + (fetchNuGet { + pname = "runtime.unix.Microsoft.Win32.Primitives"; + version = "4.3.0"; + hash = "sha256-LZb23lRXzr26tRS5aA0xyB08JxiblPDoA7HBvn6awXg="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Console"; + version = "4.3.0"; + hash = "sha256-AHkdKShTRHttqfMjmi+lPpTuCrM5vd/WRy6Kbtie190="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; + }) + (fetchNuGet { + pname = "runtime.unix.System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-Pf4mRl6YDK2x2KMh0WdyNgv0VUNdSKVDLlHqozecy5I="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Primitives"; + version = "4.3.0"; + hash = "sha256-pHJ+I6i16MV6m77uhTC6GPY6jWGReE3SSP3fVB59ti0="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Sockets"; + version = "4.3.0"; + hash = "sha256-IvgOeA2JuBjKl5yAVGjPYMPDzs9phb3KANs95H9v1w4="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; + }) + (fetchNuGet { + pname = "SHA3.Net"; + version = "2.0.0"; + hash = "sha256-rNwk9ry52bN95FeNqNC29FokNRRzKw3XnojO/UzHlYc="; + }) + (fetchNuGet { + pname = "SharpZipLib"; + version = "1.4.2"; + hash = "sha256-/giVqikworG2XKqfN9uLyjUSXr35zBuZ2FX2r8X/WUY="; + }) + (fetchNuGet { + pname = "SharpZstd.Interop"; + version = "1.5.6"; + hash = "sha256-Y1sCo7RTRtXjkTG2ZAPFx/qXzX4yW8BEaot7Ngfbg8g="; + }) + (fetchNuGet { + pname = "ShimSkiaSharp"; + version = "2.0.0.2"; + hash = "sha256-Q1ok5/R8FWDCQubbhPsbRWigGqfiADFYUoiLlCvk/20="; + }) + (fetchNuGet { + pname = "SimpleInfoName"; + version = "3.0.1"; + hash = "sha256-9p/BiEqlQczjjUfpUxcFKn71cLAJC7GGvYqRs8fSuuQ="; + }) + (fetchNuGet { + pname = "SkiaSharp"; + version = "2.88.6"; + hash = "sha256-y0wzgwdQXtgl5boCz/EgLWbK3SwC0cFVRUbBxOUPQXc="; + }) + (fetchNuGet { + pname = "SkiaSharp"; + version = "2.88.8"; + hash = "sha256-rD5gc4SnlRTXwz367uHm8XG5eAIQpZloGqLRGnvNu0A="; + }) + (fetchNuGet { + pname = "SkiaSharp.HarfBuzz"; + version = "2.88.6"; + hash = "sha256-gpHiTuHfiXgbkBkzipXb8EXIatefsod75nyrFdPcwcA="; + }) + (fetchNuGet { + pname = "SkiaSharp.HarfBuzz"; + version = "2.88.8"; + hash = "sha256-W9jNuEo/8q+k2aHNC19FfKcBUIEWx2zDcGwM+jDZ1o8="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Linux"; + version = "2.88.8"; + hash = "sha256-fOmNbbjuTazIasOvPkd2NPmuQHVCWPnow7AxllRGl7Y="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.macOS"; + version = "2.88.8"; + hash = "sha256-CdcrzQHwCcmOCPtS8EGtwsKsgdljnH41sFytW7N9PmI="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.WebAssembly"; + version = "2.88.8"; + hash = "sha256-GWWsE98f869LiOlqZuXMc9+yuuIhey2LeftGNk3/z3w="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Win32"; + version = "2.88.8"; + hash = "sha256-b8Vb94rNjwPKSJDQgZ0Xv2dWV7gMVFl5GwTK/QiZPPM="; + }) + (fetchNuGet { + pname = "Spectre.Console"; + version = "0.49.1"; + hash = "sha256-tqSVojyuQjuB34lXo759NOcyLgNIw815mKXJPq5JFDo="; + }) + (fetchNuGet { + pname = "Spectre.Console.Cli"; + version = "0.49.1"; + hash = "sha256-sar9rhft1ivDMj1kU683+4KxUPUZL+Fb++ewMA6RD4Q="; + }) + (fetchNuGet { + pname = "Spectre.Console.Testing"; + version = "0.49.1"; + hash = "sha256-NFZE0ubRmjeOOnkf8EXCp8lya0XK1tclMmtodxJPt1I="; + }) + (fetchNuGet { + pname = "Splat"; + version = "14.8.12"; + hash = "sha256-9KTsYPHVN/wiL8/Yy1KQafrFRy7x8VCEHdzgB+9+8SU="; + }) + (fetchNuGet { + pname = "Splat"; + version = "15.1.1"; + hash = "sha256-WipAVaUx2HrYNQ9LcYm496LndmSpVbuzJxzP9FA6Ohg="; + }) + (fetchNuGet { + pname = "Splat"; + version = "15.2.22"; + hash = "sha256-GSD6XrFYlYj6jkmI7Z4bYCcRIQCRAyzcuVWHmAll5K4="; + }) + (fetchNuGet { + pname = "Splat.Microsoft.Extensions.Logging"; + version = "15.2.22"; + hash = "sha256-4QO7NAcOqTDxwsheB2wyXRdH626JylEbahQaKWKZpIc="; + }) + (fetchNuGet { + pname = "StrawberryShake.Core"; + version = "14.1.0"; + hash = "sha256-h1Ozv0vdR2UvHIw3JqoBNKPVuD1S31aui7IQ8i8hcnE="; + }) + (fetchNuGet { + pname = "StrawberryShake.Resources"; + version = "14.1.0"; + hash = "sha256-6uOb5V7UeHM9OKUTJ4p8/YwvI16LcrC12tPhSAw3U0Q="; + }) + (fetchNuGet { + pname = "StrawberryShake.Server"; + version = "14.1.0"; + hash = "sha256-6K6TnX8YL0Dbt8wTv9FmBlbSo+UfaucHi9a5CqWCjoY="; + }) + (fetchNuGet { + pname = "StrawberryShake.Transport.Http"; + version = "14.1.0"; + hash = "sha256-Pa2vACAYMgLrAxiZUR7PxBvPY9wrclQRYGZod/VMG5Q="; + }) + (fetchNuGet { + pname = "StrawberryShake.Transport.WebSockets"; + version = "14.1.0"; + hash = "sha256-Hqp6GSxMcYorg5v8ns24DNfUDwYGY3urg0FKPleD86I="; + }) + (fetchNuGet { + pname = "Svg.Custom"; + version = "2.0.0.2"; + hash = "sha256-6sWw1V2oPdLgLDybH/FT/hUo+CKZiaIfOYv0KUaiTxk="; + }) + (fetchNuGet { + pname = "Svg.Model"; + version = "2.0.0.2"; + hash = "sha256-TGkz0qMKvvjMdliqHEsJE1rqKIbezUZrkjofKRduAk8="; + }) + (fetchNuGet { + pname = "Svg.Skia"; + version = "2.0.0.2"; + hash = "sha256-8F9LAgj3pdfv5VmnsuS/iHAmI1tajvuSZeTeenS13Lc="; + }) + (fetchNuGet { + pname = "System.AppContext"; + version = "4.3.0"; + hash = "sha256-yg95LNQOwFlA1tWxXdQkVyJqT4AnoDc+ACmrNvzGiZg="; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.3.0"; + hash = "sha256-XqZWb4Kd04960h4U9seivjKseGA/YEIpdplfHYHQ9jk="; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + hash = "sha256-wws90sfi9M7kuCPWkv1CEYMJtCqx9QB/kj0ymlsNaxI="; + }) + (fetchNuGet { + pname = "System.CodeDom"; + version = "5.0.0"; + hash = "sha256-UNqyPrK9eshU5kgJukvPamkaxLAp9BmR/J22OjEX+pM="; + }) + (fetchNuGet { + pname = "System.CodeDom"; + version = "8.0.0"; + hash = "sha256-uwVhi3xcvX7eiOGQi7dRETk3Qx1EfHsUfchZsEto338="; + }) + (fetchNuGet { + pname = "System.CodeDom"; + version = "9.0.0"; + hash = "sha256-578lcBgswW0eM16r0EnJzfGodPx86RxxFoZHc2PSzsw="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.0.11"; + hash = "sha256-puoFMkx4Z55C1XPxNw3np8nzNGjH+G24j43yTIsDRL0="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.0.12"; + hash = "sha256-zIEM7AB4SyE9u6G8+o+gCLLwkgi6+3rHQVPdn/dEwB8="; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.3.0"; + hash = "sha256-KMY5DfJnDeIsa13DpqvyN8NkReZEMAFnlmNglVoFIXI="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "1.2.0"; + hash = "sha256-FQ3l+ulbLSPhQ0JcQCC4D4SzjTnHsRqcOj56Ywy7pMo="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "5.0.0"; + hash = "sha256-GdwSIjLMM0uVfE56VUSLVNgpW0B//oCeSFj8/hSlbM8="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "7.0.0"; + hash = "sha256-9an2wbxue2qrtugYES9awshQg+KfJqajhnhs45kQIdk="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "8.0.0"; + hash = "sha256-F7OVjKNwpqbUh8lTidbqJWYi476nsq9n+6k0+QVRo3w="; + }) + (fetchNuGet { + pname = "System.CommandLine"; + version = "2.0.0-beta4.22272.1"; + hash = "sha256-zSO+CYnMH8deBHDI9DHhCPj79Ce3GOzHCyH1/TiHxcc="; + }) + (fetchNuGet { + pname = "System.ComponentModel"; + version = "4.3.0"; + hash = "sha256-i00uujMO4JEDIEPKLmdLY3QJ6vdSpw6Gh9oOzkFYBiU="; + }) + (fetchNuGet { + pname = "System.ComponentModel.Annotations"; + version = "4.3.0"; + hash = "sha256-zQVRu6SnLS7aKetDaxvo7zAHWLOB7K/mtgs/uaQtYqk="; + }) + (fetchNuGet { + pname = "System.ComponentModel.Annotations"; + version = "4.5.0"; + hash = "sha256-15yE2NoT9vmL9oGCaxHClQR1jLW1j1ef5hHMg55xRso="; + }) + (fetchNuGet { + pname = "System.ComponentModel.Annotations"; + version = "5.0.0"; + hash = "sha256-0pST1UHgpeE6xJrYf5R+U7AwIlH3rVC3SpguilI/MAg="; + }) + (fetchNuGet { + pname = "System.ComponentModel.Composition"; + version = "4.5.0"; + hash = "sha256-xxeZs1zIkhl2ZXU8CaOtCkMX1N290IK7bbHYeEKD0aQ="; + }) + (fetchNuGet { + pname = "System.Composition"; + version = "1.0.31"; + hash = "sha256-wcQEG6MCRa1S03s3Yb3E3tfsIBZid99M7WDhcb48Qik="; + }) + (fetchNuGet { + pname = "System.Composition"; + version = "7.0.0"; + hash = "sha256-YjhxuzuVdAzRBHNQy9y/1ES+ll3QtLcd2o+o8wIyMao="; + }) + (fetchNuGet { + pname = "System.Composition.AttributedModel"; + version = "1.0.31"; + hash = "sha256-u+XnXfj6LQ3OXwrb9KqHRW4a/a9yHzLrJOXwDQ1a/sY="; + }) + (fetchNuGet { + pname = "System.Composition.AttributedModel"; + version = "7.0.0"; + hash = "sha256-3s52Dyk2J66v/B4LLYFBMyXl0I8DFDshjE+sMjW4ubM="; + }) + (fetchNuGet { + pname = "System.Composition.Convention"; + version = "1.0.31"; + hash = "sha256-GQWo1YDyQ3r2OMcKW+GbR3BbZNIAdwK79XAfinNj+AE="; + }) + (fetchNuGet { + pname = "System.Composition.Convention"; + version = "7.0.0"; + hash = "sha256-N4MkkBXSQkcFKsEdcSe6zmyFyMmFOHmI2BNo3wWxftk="; + }) + (fetchNuGet { + pname = "System.Composition.Hosting"; + version = "1.0.31"; + hash = "sha256-fg9BIY+zWtiEBIJefYP2lKHDYa4r/vtPTr3ZI8e0K7g="; + }) + (fetchNuGet { + pname = "System.Composition.Hosting"; + version = "7.0.0"; + hash = "sha256-7liQGMaVKNZU1iWTIXvqf0SG8zPobRoLsW7q916XC3M="; + }) + (fetchNuGet { + pname = "System.Composition.Runtime"; + version = "1.0.31"; + hash = "sha256-mqfxjAnVyE1YCgXMOcV34IWhYFnvXVKjMo9Y/d3yDuo="; + }) + (fetchNuGet { + pname = "System.Composition.Runtime"; + version = "7.0.0"; + hash = "sha256-Oo1BxSGLETmdNcYvnkGdgm7JYAnQmv1jY0gL0j++Pd0="; + }) + (fetchNuGet { + pname = "System.Composition.TypedParts"; + version = "1.0.31"; + hash = "sha256-w9ApcUJr7jYP4Vf5+efIIqoWmr5v9R56W4uC0n8KktQ="; + }) + (fetchNuGet { + pname = "System.Composition.TypedParts"; + version = "7.0.0"; + hash = "sha256-6ZzNdk35qQG3ttiAi4OXrihla7LVP+y2fL3bx40/32s="; + }) + (fetchNuGet { + pname = "System.Configuration.ConfigurationManager"; + version = "4.4.0"; + hash = "sha256-+8wGYllXnIxRzy9dLhZFB88GoPj8ivYXS0KUfcivT8I="; + }) + (fetchNuGet { + pname = "System.Console"; + version = "4.3.0"; + hash = "sha256-Xh3PPBZr0pDbDaK8AEHbdGz7ePK6Yi1ZyRWI1JM6mbo="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.0.11"; + hash = "sha256-P+rSQJVoN6M56jQbs76kZ9G3mAWFdtF27P/RijN8sj4="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "4.3.0"; + hash = "sha256-OFJRb0ygep0Z3yDBLwAgM/Tkfs4JCDtsNhwDH9cd1Xw="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "8.0.0"; + hash = "sha256-+aODaDEQMqla5RYZeq0Lh66j+xkPYxykrVvSCmJQ+Vs="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "9.0.0"; + hash = "sha256-1VzO9i8Uq2KlTw1wnCCrEdABPZuB2JBD5gBsMTFTSvE="; + }) + (fetchNuGet { + pname = "System.Diagnostics.EventLog"; + version = "6.0.0"; + hash = "sha256-zUXIQtAFKbiUMKCrXzO4mOTD5EUphZzghBYKXprowSM="; + }) + (fetchNuGet { + pname = "System.Diagnostics.EventLog"; + version = "8.0.0"; + hash = "sha256-rt8xc3kddpQY4HEdghlBeOK4gdw5yIj4mcZhAVtk2/Y="; + }) + (fetchNuGet { + pname = "System.Diagnostics.EventLog"; + version = "9.0.0"; + hash = "sha256-tPvt6yoAp56sK/fe+/ei8M65eavY2UUhRnbrREj/Ems="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tools"; + version = "4.3.0"; + hash = "sha256-gVOv1SK6Ape0FQhCVlNOd9cvQKBvMxRX9K0JPVi8w0Y="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.1.0"; + hash = "sha256-JA0jJcLbU3zh52ub3zweob2EVHvxOqiC6SCYHrY5WbQ="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.0.11"; + hash = "sha256-qWqFVxuXioesVftv2RVJZOnmojUvRjb7cS3Oh3oTit4="; + }) + (fetchNuGet { + pname = "System.Formats.Asn1"; + version = "5.0.0"; + hash = "sha256-9nL3dN4w/dZ49W1pCkTjRqZm6Dh0mMVExNungcBHrKs="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.0.11"; + hash = "sha256-rbSgc2PIEc2c2rN6LK3qCREAX3DqA2Nq1WcLrZYsDBw="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.3.0"; + hash = "sha256-uNOD0EOVFgnS2fMKvMiEtI9aOw00+Pfy/H+qucAQlPc="; + }) + (fetchNuGet { + pname = "System.Globalization.Extensions"; + version = "4.3.0"; + hash = "sha256-mmJWA27T0GRVuFP9/sj+4TrR4GJWrzNIk2PDrbr7RQk="; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.1.0"; + hash = "sha256-V6oyQFwWb8NvGxAwvzWnhPxy9dKOfj/XBM3tEC5aHrw="; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; + }) + (fetchNuGet { + pname = "System.IO.Abstractions"; + version = "21.0.29"; + hash = "sha256-91e2/Bd4ZgANw19mKkTdxAy2tv7NutyG0lQTKhMiEpo="; + }) + (fetchNuGet { + pname = "System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; + }) + (fetchNuGet { + pname = "System.IO.Compression.ZipFile"; + version = "4.3.0"; + hash = "sha256-WQl+JgWs+GaRMeiahTFUbrhlXIHapzcpTFXbRvAtvvs="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; + }) + (fetchNuGet { + pname = "System.IO.Hashing"; + version = "8.0.0"; + hash = "sha256-szOGt0TNBo6dEdC3gf6H+e9YW3Nw0woa6UnCGGGK5cE="; + }) + (fetchNuGet { + pname = "System.IO.Hashing"; + version = "9.0.0"; + hash = "sha256-k6Pdndm5fTD6CB1QsQfP7G+2h4B30CWIsuvjHuBg3fc="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "6.0.3"; + hash = "sha256-v+FOmjRRKlDtDW6+TfmyMiiki010YGVTa0EwXu9X7ck="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "7.0.0"; + hash = "sha256-W2181khfJUTxLqhuAVRhCa52xZ3+ePGOLIPwEN8WisY="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "8.0.0"; + hash = "sha256-LdpB1s4vQzsOODaxiKstLks57X9DTD5D6cPx8DE1wwE="; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.1.0"; + hash = "sha256-ZQpFtYw5N1F1aX0jUK3Tw+XvM5tnlnshkTCNtfVA794="; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; + }) + (fetchNuGet { + pname = "System.Linq.Async"; + version = "6.0.1"; + hash = "sha256-uH5fZhcyQVtnsFc6GTUaRRrAQm05v5euJyWCXSFSOYI="; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.1.0"; + hash = "sha256-7zqB+FXgkvhtlBzpcZyd81xczWP0D3uWssyAGw3t7b4="; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.3.0"; + hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; + }) + (fetchNuGet { + pname = "System.Management"; + version = "5.0.0"; + hash = "sha256-upx2lBRhITuOz9rKth+pBNGvxaLNU3ZOSaS0D+7YHiY="; + }) + (fetchNuGet { + pname = "System.Management"; + version = "8.0.0"; + hash = "sha256-HwpfDb++q7/vxR6q57mGFgl5U0vxy+oRJ6orFKORfP0="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.3"; + hash = "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.5"; + hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; + }) + (fetchNuGet { + pname = "System.Net.Http"; + version = "4.3.0"; + hash = "sha256-UoBB7WPDp2Bne/fwxKF0nE8grJ6FzTMXdT/jfsphj8Q="; + }) + (fetchNuGet { + pname = "System.Net.NameResolution"; + version = "4.3.0"; + hash = "sha256-eGZwCBExWsnirWBHyp2sSSSXp6g7I6v53qNmwPgtJ5c="; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.3.0"; + hash = "sha256-MY7Z6vOtFMbEKaLW9nOSZeAjcWpwCtdO7/W1mkGZBzE="; + }) + (fetchNuGet { + pname = "System.Net.Sockets"; + version = "4.3.0"; + hash = "sha256-il7dr5VT/QWDg/0cuh+4Es2u8LY//+qqiY9BZmYxSus="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.4.0"; + hash = "sha256-auXQK2flL/JpnB/rEcAcUm4vYMCYMEMiWOCAlIaqu2U="; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.0.12"; + hash = "sha256-MudZ/KYcvYsn2cST3EE049mLikrNkmE7QoUoYKKby+s="; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.3.0"; + hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; + }) + (fetchNuGet { + pname = "System.Reactive"; + version = "5.0.0"; + hash = "sha256-M5Z8pw8rVb8ilbnTdaOptzk5VFd5DlKa7zzCpuytTtE="; + }) + (fetchNuGet { + pname = "System.Reactive"; + version = "6.0.1"; + hash = "sha256-Lo5UMqp8DsbVSUxa2UpClR1GoYzqQQcSxkfyFqB/d4Q="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.1.0"; + hash = "sha256-idZHGH2Yl/hha1CM4VzLhsaR8Ljo/rV7TYe7mwRJSMs="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.0.1"; + hash = "sha256-F1MvYoQWHCY89/O4JBwswogitqVvKuVfILFqA7dmuHk="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.3.0"; + hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.7.0"; + hash = "sha256-Fw/CSRD+wajH1MqfKS3Q/sIrUH7GN4K+F+Dx68UPNIg="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.0.1"; + hash = "sha256-YG+eJBG5P+5adsHiw/lhJwvREnvdHw6CJyS8ZV4Ujd0="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.3.0"; + hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.3.0"; + hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.0.1"; + hash = "sha256-NsfmzM9G/sN3H8X2cdnheTGRsh7zbRzvegnjDzDH/FQ="; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "1.3.0"; + hash = "sha256-a/RQr++mSsziWaOTknicfIQX/zJrwPFExfhK6PM0tfg="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "1.6.0"; + hash = "sha256-JJfgaPav7UfEh4yRAQdGhLZF1brr0tUWPl6qmfNWq/E="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "5.0.0"; + hash = "sha256-Wo+MiqhcP9dQ6NuFGrQTw6hpbJORFwp+TBNTq2yhGp8="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "7.0.0"; + hash = "sha256-GwAKQhkhPBYTqmRdG9c9taqrKSKDwyUgOEhWLKxWNPI="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "8.0.0"; + hash = "sha256-dQGC30JauIDWNWXMrSNOJncVa1umR1sijazYwUDdSIE="; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.0.1"; + hash = "sha256-SFSfpWEyCBMAOerrMCOiKnpT+UAWTvRcmoRquJR6Vq0="; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.1.0"; + hash = "sha256-R0YZowmFda+xzKNR4kKg7neFoE30KfZwp/IwfRSKVK4="; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.3.0"; + hash = "sha256-4U4/XNQAnddgQIHIJq3P2T80hN0oPdU2uCeghsDTWng="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.0.1"; + hash = "sha256-cZ2/3/fczLjEpn6j3xkgQV9ouOVjy4Kisgw5xWw9kSw="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.1.0"; + hash = "sha256-FViNGM/4oWtlP6w0JC0vJU+k9efLKZ+yaXrnEeabDQo="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.2"; + hash = "sha256-8eUXXGWO2LL7uATMZye2iCpQOETn2jCcjUhG6coR5O8="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.3"; + hash = "sha256-lnZMUqRO4RYRUeSO8HSJ9yBHqFHLVbmenwHWkIU20ak="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "5.0.0"; + hash = "sha256-neARSpLPUzPxEKhJRwoBzhPxK+cKIitLx7WBYncsYgo="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.1.0"; + hash = "sha256-X7DZ5CbPY7jHs20YZ7bmcXs9B5Mxptu/HnBUvUnNhGc="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.1.0"; + hash = "sha256-QceAYlJvkPRJc/+5jR+wQpNNI3aqGySWWSO30e/FfQY="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices.RuntimeInformation"; + version = "4.3.0"; + hash = "sha256-MYpl6/ZyC6hjmzWRIe+iDoldOMW1mfbwXsduAnXIKGA="; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.3.0"; + hash = "sha256-P5jHCgMbgFMYiONvzmaKFeOqcAIDPu/U8bOVrNPYKqc="; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "4.4.0"; + hash = "sha256-J3T2ECVdL0JiBA999CUz77az545CVOYB11/NPA/huEc="; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "4.5.0"; + hash = "sha256-AFsKPb/nTk2/mqH/PYpaoI8PLsiKKimaXf+7Mb5VfPM="; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "5.0.0"; + hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; + }) + (fetchNuGet { + pname = "System.Security.Claims"; + version = "4.3.0"; + hash = "sha256-Fua/rDwAqq4UByRVomAxMPmDBGd5eImRqHVQIeSxbks="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.3.0"; + hash = "sha256-tAJvNSlczYBJ3Ed24Ae27a55tq/n4D3fubNQdwcKWA8="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.3.0"; + hash = "sha256-u17vy6wNhqok91SrVLno2M1EzLHZm6VMca85xbVChsw="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "5.0.0"; + hash = "sha256-nOJP3vdmQaYA07TI373OvZX6uWshETipvi5KpL7oExo="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Csp"; + version = "4.3.0"; + hash = "sha256-oefdTU/Z2PWU9nlat8uiRDGq/PGZoSPRgkML11pmvPQ="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.3.0"; + hash = "sha256-Yuge89N6M+NcblcvXMeyHZ6kZDfwBv3LPMDiF8HhJss="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-DL+D2sc2JrQiB4oAcUggTFyD8w3aLEjJfod5JPe+Oz4="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Pkcs"; + version = "5.0.0"; + hash = "sha256-kq/tvYQSa24mKSvikFK2fKUAnexSL4PO4LkPppqtYkE="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.3.0"; + hash = "sha256-fnFi7B3SnVj5a+BbgXnbjnGNvWrCEU6Hp/wjsjWz318="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "4.4.0"; + hash = "sha256-Ri53QmFX8I8UH0x4PikQ1ZA07ZSnBUXStd5rBfGWFOE="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.3.0"; + hash = "sha256-MG3V/owDh273GCUPsGGraNwaVpcydupl3EtPXj6TVG0="; + }) + (fetchNuGet { + pname = "System.Security.Permissions"; + version = "4.5.0"; + hash = "sha256-Fa6dX6Gyse1A/RBoin8cVaHQePbfBvp6jjWxUXPhXKQ="; + }) + (fetchNuGet { + pname = "System.Security.Principal"; + version = "4.3.0"; + hash = "sha256-rjudVUHdo8pNJg2EVEn0XxxwNo5h2EaYo+QboPkXlYk="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.3.0"; + hash = "sha256-mbdLVUcEwe78p3ZnB6jYsizNEqxMaCAWI3tEQNhRQAE="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.4.0"; + hash = "sha256-lwNBM33EW45j6o8bM4hKWirEUZCvep0VYFchc50JOYc="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.5.0"; + hash = "sha256-BkUYNguz0e4NJp1kkW7aJBn3dyH9STwB5N8XqnlCsmY="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.0.11"; + hash = "sha256-PEailOvG05CVgPTyKLtpAgRydlSHmtd5K0Y8GSHY2Lc="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "4.5.1"; + hash = "sha256-PIhkv59IXjyiuefdhKxS9hQfEwO9YWRuNudpo53HQfw="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "7.0.0"; + hash = "sha256-eCKTVwumD051ZEcoJcDVRGnIGAsEvKpfH3ydKluHxmo="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.0.11"; + hash = "sha256-+kf7J3dEhgCbnCM5vHYlsTm5/R/Ud0Jr6elpHm922iI="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "8.0.0"; + hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "8.0.0"; + hash = "sha256-XFcCHMW1u2/WujlWNHaIWkbW1wn8W4kI0QdrwPtWmow="; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "8.0.4"; + hash = "sha256-g5oT7fbXxQ9Iah1nMCr4UUX/a2l+EVjJyTrw3FTbIaI="; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "8.0.5"; + hash = "sha256-yKxo54w5odWT6nPruUVsaX53oPRe+gKzGvLnnxtwP68="; + }) + (fetchNuGet { + pname = "System.Text.RegularExpressions"; + version = "4.3.0"; + hash = "sha256-VLCk1D1kcN2wbAe3d0YQM/PqCsPHOuqlBY1yd2Yo+K0="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.0.11"; + hash = "sha256-mob1Zv3qLQhQ1/xOLXZmYqpniNUMCfn02n8ZkaAhqac="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; + }) + (fetchNuGet { + pname = "System.Threading.Channels"; + version = "7.0.0"; + hash = "sha256-Cu0gjQsLIR8Yvh0B4cOPJSYVq10a+3F9pVz/C43CNeM="; + }) + (fetchNuGet { + pname = "System.Threading.RateLimiting"; + version = "8.0.0"; + hash = "sha256-KOEWEt6ZthvZHJ2Wp70d9nBhBrPqobGQDi2twlKYh/w="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.0.11"; + hash = "sha256-5SLxzFg1df6bTm2t09xeI01wa5qQglqUwwJNlQPJIVs="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Dataflow"; + version = "4.6.0"; + hash = "sha256-YYrT3GRzVBdendxt8FUDCnOBJi0nw/CJ9VrzcPJWLSg="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.3.0"; + hash = "sha256-X2hQ5j+fxcmnm88Le/kSavjiGOmkcumBGTZKBLvorPc="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; + }) + (fetchNuGet { + pname = "System.Threading.ThreadPool"; + version = "4.3.0"; + hash = "sha256-wW0QdvssRoaOfQLazTGSnwYTurE4R8FxDx70pYkL+gg="; + }) + (fetchNuGet { + pname = "System.Threading.Timer"; + version = "4.3.0"; + hash = "sha256-pmhslmhQhP32TWbBzoITLZ4BoORBqYk25OWbru04p9s="; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.3.0"; + hash = "sha256-QQ8KgU0lu4F5Unh+TbechO//zaAGZ4MfgvW72Cn1hzA="; + }) + (fetchNuGet { + pname = "System.Xml.XDocument"; + version = "4.3.0"; + hash = "sha256-rWtdcmcuElNOSzCehflyKwHkDRpiOhJJs8CeQ0l1CCI="; + }) + (fetchNuGet { + pname = "TestableIO.System.IO.Abstractions"; + version = "21.0.29"; + hash = "sha256-OFpu9RcDRPLYntQyesBevoG1XxyH96ukHOH0uXqO5ls="; + }) + (fetchNuGet { + pname = "TestableIO.System.IO.Abstractions.Wrappers"; + version = "21.0.29"; + hash = "sha256-2q1HzbyRPIm6VKYzZzZnkXBJzV8S+HBtT6Lej1pv84Y="; + }) + (fetchNuGet { + pname = "TextMateSharp"; + version = "1.0.59"; + hash = "sha256-qfAGSgVpTrWMZSk0TFDVP1IgWWi6O1jEEvWc0Pvw9i0="; + }) + (fetchNuGet { + pname = "TextMateSharp"; + version = "1.0.64"; + hash = "sha256-49Fdf6ndcb4BKMlWYjkjpJ3pLp17Z10FcGJpfdXvvzc="; + }) + (fetchNuGet { + pname = "TextMateSharp.Grammars"; + version = "1.0.59"; + hash = "sha256-ru5VxQK4PFRJhHu+MvCzDt3EwbC/94n1whtDovUAUDA="; + }) + (fetchNuGet { + pname = "TextMateSharp.Grammars"; + version = "1.0.64"; + hash = "sha256-ykBZOyvaX1/iFmZjue754qJG4jfPx38ZdHevEZvh7w8="; + }) + (fetchNuGet { + pname = "Tmds.DBus.Protocol"; + version = "0.20.0"; + hash = "sha256-CRW/tkgsuBiBJfRwou12ozRQsWhHDooeP88E5wWpWJw="; + }) + (fetchNuGet { + pname = "TransparentValueObjects"; + version = "1.0.2"; + hash = "sha256-5d9pIf8hbbcBtj6/oc87f98xEuhBiT6Yq5FR2b/mvUQ="; + }) + (fetchNuGet { + pname = "Validation"; + version = "2.3.7"; + hash = "sha256-VTSUT1Ij87fN8zlz7w2HTIUMMx3NBRdbfXmMtFvV5es="; + }) + (fetchNuGet { + pname = "Validation"; + version = "2.4.18"; + hash = "sha256-ByITVSjsqVglWPIRaZ3i1P3bHh8+OB6BWgDA8f8qTFI="; + }) + (fetchNuGet { + pname = "ValveKeyValue"; + version = "0.10.0.360"; + hash = "sha256-LPQ6isUsA3cQKiO6ADijrCQ2ucx4TD01+kGzei3jIGY="; + }) + (fetchNuGet { + pname = "Verify"; + version = "26.5.0"; + hash = "sha256-74kcD01cOebR2lFFnLEJseY6wLpoBzA5FPa73rWIoMM="; + }) + (fetchNuGet { + pname = "Verify"; + version = "27.0.0"; + hash = "sha256-eBvZNh7NAUJgyHD/LOdxhd0GnZOADdshhb0HA8Gz8j8="; + }) + (fetchNuGet { + pname = "Verify"; + version = "28.2.1"; + hash = "sha256-SF2IgbAseEANZDnFXGd//oQ9uLusWrk0TY/GynyBqTI="; + }) + (fetchNuGet { + pname = "Verify.ImageMagick"; + version = "3.6.0"; + hash = "sha256-U6i0pR1ceSDy7+iiRN8RQen3okp6X3De0DK8R5IxxfA="; + }) + (fetchNuGet { + pname = "Verify.SourceGenerators"; + version = "2.5.0"; + hash = "sha256-i9TpQJ2+JhSQ7RXkdmC6pkND32V4cLyEaPLGrD/EpYk="; + }) + (fetchNuGet { + pname = "Verify.Xunit"; + version = "28.2.1"; + hash = "sha256-2PeJmxMrO8Q3muNtPdscxLsb9q04cTPZ8jQZIG1mDbM="; + }) + (fetchNuGet { + pname = "Weave"; + version = "2.1.0"; + hash = "sha256-jyo3pdqJOz3y1GO//jIGxJ9WwRlqMFK+BZET4NfSHVw="; + }) + (fetchNuGet { + pname = "xunit"; + version = "2.9.2"; + hash = "sha256-h5+yTTfCmokCPy4lqdEw8RGzQlrlsQAW3Am0Jh0q7oo="; + }) + (fetchNuGet { + pname = "xunit.abstractions"; + version = "2.0.1"; + hash = "sha256-v5iPVeoUFsZp9zQMt3rg6xgw6UwF4VMIgzVYFIeb/zA="; + }) + (fetchNuGet { + pname = "xunit.abstractions"; + version = "2.0.2"; + hash = "sha256-w5APCW7suBdoDOmQqm/8Gq6+Sk88JcTR09zjmj9s17E="; + }) + (fetchNuGet { + pname = "xunit.abstractions"; + version = "2.0.3"; + hash = "sha256-0D1y/C34iARI96gb3bAOG8tcGPMjx+fMabTPpydGlAM="; + }) + (fetchNuGet { + pname = "xunit.analyzers"; + version = "1.16.0"; + hash = "sha256-P5Bvl9hvHvF8KY1YWLg4tKiYxlfRnmHyL14jfSACDaU="; + }) + (fetchNuGet { + pname = "xunit.assert"; + version = "2.3.0"; + hash = "sha256-lN+NiUEQoHWmoamUjvsNt2PVhHXYeHJHjHRk1BTs6R8="; + }) + (fetchNuGet { + pname = "xunit.assert"; + version = "2.9.2"; + hash = "sha256-EE6r526Q4cHn0Ourf1ENpXZ37Lj/P2uNvonHgpdcnq4="; + }) + (fetchNuGet { + pname = "xunit.core"; + version = "2.9.2"; + hash = "sha256-zhjV1I5xh0RFckgTEK72tIkLxVl4CPmter2UB++oye8="; + }) + (fetchNuGet { + pname = "Xunit.DependencyInjection"; + version = "9.0.0"; + hash = "sha256-nH51bonRwshBIaRYHQr9DUZrQo8q5dggJ03+ngC5bXg="; + }) + (fetchNuGet { + pname = "Xunit.DependencyInjection"; + version = "9.6.0"; + hash = "sha256-lZVjKJH961mNw7aX32aG7wSZyCgHoT9okuX92HNqF9c="; + }) + (fetchNuGet { + pname = "Xunit.DependencyInjection.Logging"; + version = "9.0.0"; + hash = "sha256-9MerQYIgsByxcZmczyp/fW6ZWgzo4ql6j9Iv/Y47E4A="; + }) + (fetchNuGet { + pname = "Xunit.DependencyInjection.SkippableFact"; + version = "9.0.0"; + hash = "sha256-Ub6eSd9/bIhgbqQO+yWtiGfuLIkxSgl6TWfUL4ABkFI="; + }) + (fetchNuGet { + pname = "xunit.extensibility.core"; + version = "2.2.0"; + hash = "sha256-et3Se7paKJlg8Ha4Xr9+He40M6vblxyOwS2BQxOgLlE="; + }) + (fetchNuGet { + pname = "xunit.extensibility.core"; + version = "2.4.0"; + hash = "sha256-LbuXEcEJjGn3L6FCbC119+MY/QLvfLlGkCeAsCsZqGE="; + }) + (fetchNuGet { + pname = "xunit.extensibility.core"; + version = "2.4.2"; + hash = "sha256-wlTMUOQg5NaAPEsWkNSr8QSPbbCNSicpFajp1rowCsA="; + }) + (fetchNuGet { + pname = "xunit.extensibility.core"; + version = "2.9.2"; + hash = "sha256-MQAC/4d67Nssu3R+pHPh6vHitBXQYxEEZkVVMGW720c="; + }) + (fetchNuGet { + pname = "xunit.extensibility.execution"; + version = "2.4.0"; + hash = "sha256-chRJEazwq93yhVONlbtTI1znqYy0gdAoQajPRnhM/i4="; + }) + (fetchNuGet { + pname = "xunit.extensibility.execution"; + version = "2.4.2"; + hash = "sha256-l5Q60IBYWE5tYJCdFEEQnO5rIlXcNEM5S4Ut8vFnL2U="; + }) + (fetchNuGet { + pname = "xunit.extensibility.execution"; + version = "2.9.2"; + hash = "sha256-f+9UfoPyK3JIDhQSW0Yu9c4PGqUqZC96DMINCYi2i80="; + }) + (fetchNuGet { + pname = "xunit.runner.visualstudio"; + version = "2.8.2"; + hash = "sha256-UlfK348r8kJuraywfdCtpJJxHkv04wPNzpUaz4UM/60="; + }) + (fetchNuGet { + pname = "Xunit.SkippableFact"; + version = "1.4.13"; + hash = "sha256-pLtx0/2oTKYO1Y1Vg3k/Eli2OWHT5uorGdBp2uXvFfw="; + }) + (fetchNuGet { + pname = "ZstdSharp.Port"; + version = "0.8.2"; + hash = "sha256-mwU4YWaBrbbqQeQ+7ohm/0ewWPD6S8Y2pg6Rqxbi4Ts="; + }) ] diff --git a/pkgs/by-name/nf/nf-test/package.nix b/pkgs/by-name/nf/nf-test/package.nix index 2dd38bae1a4589..d49cbfc2613e4f 100644 --- a/pkgs/by-name/nf/nf-test/package.nix +++ b/pkgs/by-name/nf/nf-test/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchurl -, makeWrapper -, nextflow -, nf-test -, openjdk11 -, stdenv -, testers +{ + lib, + fetchurl, + makeWrapper, + nextflow, + nf-test, + openjdk11, + stdenv, + testers, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/nf/nfd/package.nix b/pkgs/by-name/nf/nfd/package.nix index 49730f44848de2..2039698526173a 100644 --- a/pkgs/by-name/nf/nfd/package.nix +++ b/pkgs/by-name/nf/nfd/package.nix @@ -35,11 +35,14 @@ stdenv.mkDerivation rec { sphinx wafHook ]; - buildInputs = [ - libpcap - ndn-cxx - openssl - ] ++ lib.optional withWebSocket websocketpp ++ lib.optional withSystemd systemd; + buildInputs = + [ + libpcap + ndn-cxx + openssl + ] + ++ lib.optional withWebSocket websocketpp + ++ lib.optional withSystemd systemd; wafConfigureFlags = [ "--boost-includes=${boost.dev}/include" "--boost-libs=${boost.out}/lib" diff --git a/pkgs/by-name/nf/nfdump/package.nix b/pkgs/by-name/nf/nfdump/package.nix index b7335326cc7ee6..6e1afe8aae2ad6 100644 --- a/pkgs/by-name/nf/nfdump/package.nix +++ b/pkgs/by-name/nf/nfdump/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, libtool -, pkg-config -, bzip2 -, libpcap -, flex -, bison +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + pkg-config, + bzip2, + libpcap, + flex, + bison, }: stdenv.mkDerivation rec { @@ -18,7 +19,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "phaag"; repo = "nfdump"; - rev = "refs/tags/v${version}"; + rev = "refs/tags/v${version}"; hash = "sha256-1S55WVVHczYBDGwTxGZr+ND+e4a892jkTINlvIR2xgI="; }; diff --git a/pkgs/by-name/nf/nfft/package.nix b/pkgs/by-name/nf/nfft/package.nix index 86acd30d5da8e6..3d3bdb47eec615 100644 --- a/pkgs/by-name/nf/nfft/package.nix +++ b/pkgs/by-name/nf/nfft/package.nix @@ -1,12 +1,13 @@ -{ autoconf -, automake -, cunit -, fetchFromGitHub -, fftw -, lib -, libtool -, llvmPackages -, stdenv +{ + autoconf, + automake, + cunit, + fetchFromGitHub, + fftw, + lib, + libtool, + llvmPackages, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/nf/nflz/package.nix b/pkgs/by-name/nf/nflz/package.nix index 3d455d908073e2..47811ee95c8413 100644 --- a/pkgs/by-name/nf/nflz/package.nix +++ b/pkgs/by-name/nf/nflz/package.nix @@ -1,6 +1,7 @@ -{ fetchCrate -, lib -, rustPlatform +{ + fetchCrate, + lib, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/nf/nfpm/package.nix b/pkgs/by-name/nf/nfpm/package.nix index 10923260246492..ce41891fdafcfe 100644 --- a/pkgs/by-name/nf/nfpm/package.nix +++ b/pkgs/by-name/nf/nfpm/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, buildPackages +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + buildPackages, }: buildGoModule rec { @@ -19,13 +20,19 @@ buildGoModule rec { vendorHash = "sha256-dGVfWKnlZxVdqgZSIRrEWmqSf360J/LKkyiMkKJ88ro="; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; nativeBuildInputs = [ installShellFiles ]; postInstall = - let emulator = stdenv.hostPlatform.emulator buildPackages; - in '' + let + emulator = stdenv.hostPlatform.emulator buildPackages; + in + '' ${emulator} $out/bin/nfpm man > nfpm.1 installManPage ./nfpm.1 installShellCompletion --cmd nfpm \ @@ -38,7 +45,10 @@ buildGoModule rec { description = "Simple deb and rpm packager written in Go"; homepage = "https://github.com/goreleaser/nfpm"; changelog = "https://github.com/goreleaser/nfpm/releases/tag/v${version}"; - maintainers = with maintainers; [ techknowlogick caarlos0 ]; + maintainers = with maintainers; [ + techknowlogick + caarlos0 + ]; license = with licenses; [ mit ]; mainProgram = "nfpm"; }; diff --git a/pkgs/by-name/nf/nfstrace/package.nix b/pkgs/by-name/nf/nfstrace/package.nix index c54a5deec46fca..11edace296ef40 100644 --- a/pkgs/by-name/nf/nfstrace/package.nix +++ b/pkgs/by-name/nf/nfstrace/package.nix @@ -1,4 +1,14 @@ -{ cmake, fetchFromGitHub, fetchpatch, json_c, libpcap, ncurses, lib, stdenv, libtirpc }: +{ + cmake, + fetchFromGitHub, + fetchpatch, + json_c, + libpcap, + ncurses, + lib, + stdenv, + libtirpc, +}: stdenv.mkDerivation rec { pname = "nfstrace"; @@ -33,19 +43,28 @@ stdenv.mkDerivation rec { ]; postPatch = '' - # -Wall -Wextra -Werror fails on clang and newer gcc - substituteInPlace CMakeLists.txt \ - --replace "-Wno-braced-scalar-init" "" \ - --replace "-Werror" "" + # -Wall -Wextra -Werror fails on clang and newer gcc + substituteInPlace CMakeLists.txt \ + --replace "-Wno-braced-scalar-init" "" \ + --replace "-Werror" "" ''; - buildInputs = [ json_c libpcap ncurses libtirpc ]; + buildInputs = [ + json_c + libpcap + ncurses + libtirpc + ]; nativeBuildInputs = [ cmake ]; # To build with GCC 8+ it needs: CXXFLAGS = "-Wno-class-memaccess -Wno-ignored-qualifiers"; # CMake can't find json_c without: - env.NIX_CFLAGS_COMPILE = toString [ "-I${json_c.dev}/include/json-c" "-Wno-error=address-of-packed-member" "-I${libtirpc.dev}/include/tirpc" ]; + env.NIX_CFLAGS_COMPILE = toString [ + "-I${json_c.dev}/include/json-c" + "-Wno-error=address-of-packed-member" + "-I${libtirpc.dev}/include/tirpc" + ]; NIX_LDFLAGS = [ "-ltirpc" ]; doCheck = false; # requires network access diff --git a/pkgs/by-name/ng/ngadmin/package.nix b/pkgs/by-name/ng/ngadmin/package.nix index fb36a0367c5947..751b2f2b96584b 100644 --- a/pkgs/by-name/ng/ngadmin/package.nix +++ b/pkgs/by-name/ng/ngadmin/package.nix @@ -1,7 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, autoreconfHook, readline -, withReadline ? true -, enableEmu ? true -, enableSpy ? true +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + readline, + withReadline ? true, + enableEmu ? true, + enableSpy ? true, }: stdenv.mkDerivation { @@ -15,9 +20,7 @@ stdenv.mkDerivation { sha256 = "15vixhwqcpbjdxlaznans9w63kwl29mdkds6spvbv2i7l33qnhq4"; }; - nativeBuildInputs = - [ autoreconfHook ] - ++ lib.optional withReadline readline; + nativeBuildInputs = [ autoreconfHook ] ++ lib.optional withReadline readline; enableParallelBuilding = true; configureFlags = lib.optional (!withReadline) "--without-readline" diff --git a/pkgs/by-name/ng/nghttp2/package.nix b/pkgs/by-name/ng/nghttp2/package.nix index f17bd6487dddc9..ff4d4bfa88c68e 100644 --- a/pkgs/by-name/ng/nghttp2/package.nix +++ b/pkgs/by-name/ng/nghttp2/package.nix @@ -1,24 +1,38 @@ -{ lib -, stdenv -, fetchurl -, installShellFiles -, pkg-config - -# Optional dependencies -, enableApp ? with stdenv.hostPlatform; !isWindows && !isStatic -, c-aresMinimal, libev, openssl, zlib -, enableGetAssets ? false, libxml2 -, enableHpack ? false, jansson -, enableHttp3 ? false, ngtcp2, nghttp3, quictls -, enableJemalloc ? false, jemalloc -, enablePython ? false, python3, ncurses - -# Unit tests ; we have to set TZDIR, which is a GNUism. -, enableTests ? stdenv.hostPlatform.isGnu, cunit, tzdata - -# downstream dependencies, for testing -, curl -, libsoup_3 +{ + lib, + stdenv, + fetchurl, + installShellFiles, + pkg-config, + + # Optional dependencies + enableApp ? with stdenv.hostPlatform; !isWindows && !isStatic, + c-aresMinimal, + libev, + openssl, + zlib, + enableGetAssets ? false, + libxml2, + enableHpack ? false, + jansson, + enableHttp3 ? false, + ngtcp2, + nghttp3, + quictls, + enableJemalloc ? false, + jemalloc, + enablePython ? false, + python3, + ncurses, + + # Unit tests ; we have to set TZDIR, which is a GNUism. + enableTests ? stdenv.hostPlatform.isGnu, + cunit, + tzdata, + + # downstream dependencies, for testing + curl, + libsoup_3, }: # Note: this package is used for bootstrapping fetchurl, and thus cannot use fetchpatch! @@ -39,17 +53,31 @@ stdenv.mkDerivation rec { sha256 = "sha256-OmcN83joUrhaIpXyXk9RzCj1bg/MSWQIuMN2QpBTevU="; }; - outputs = [ "out" "dev" "lib" "doc" "man" ]; + outputs = [ + "out" + "dev" + "lib" + "doc" + "man" + ]; - nativeBuildInputs = [ pkg-config ] - ++ lib.optionals (enableApp) [ installShellFiles ]; + nativeBuildInputs = [ pkg-config ] ++ lib.optionals (enableApp) [ installShellFiles ]; - buildInputs = lib.optionals enableApp [ c-aresMinimal libev zlib ] + buildInputs = + lib.optionals enableApp [ + c-aresMinimal + libev + zlib + ] ++ lib.optionals (enableApp && !enableHttp3) [ openssl ] ++ lib.optionals (enableGetAssets) [ libxml2 ] ++ lib.optionals (enableHpack) [ jansson ] ++ lib.optionals (enableJemalloc) [ jemalloc ] - ++ lib.optionals (enableHttp3) [ ngtcp2 nghttp3 quictls ] + ++ lib.optionals (enableHttp3) [ + ngtcp2 + nghttp3 + quictls + ] ++ lib.optionals (enablePython) [ python3 ]; enableParallelBuilding = true; @@ -60,13 +88,20 @@ stdenv.mkDerivation rec { (lib.enableFeature enableHttp3 "http3") ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals (stdenv.hostPlatform.isDarwin && lib.versionOlder stdenv.hostPlatform.darwinMinVersion "10.13") [ - "-faligned-allocation" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals + (stdenv.hostPlatform.isDarwin && lib.versionOlder stdenv.hostPlatform.darwinMinVersion "10.13") + [ + "-faligned-allocation" + ] + ); # Unit tests require CUnit and setting TZDIR environment variable doCheck = enableTests; - nativeCheckInputs = lib.optionals (enableTests) [ cunit tzdata ]; + nativeCheckInputs = lib.optionals (enableTests) [ + cunit + tzdata + ]; preCheck = lib.optionalString (enableTests) '' export TZDIR=${tzdata}/share/zoneinfo ''; @@ -77,15 +112,19 @@ stdenv.mkDerivation rec { substituteInPlace ./config.guess --replace-fail /usr/bin/uname uname ''; - postInstall = lib.optionalString (enableApp) '' - installShellCompletion --bash doc/bash_completion/{h2load,nghttp,nghttpd,nghttpx} - '' + lib.optionalString (!enableApp) '' - rm -r $out/bin - '' + lib.optionalString (enablePython) '' - patchShebangs $out/share/nghttp2 - '' + lib.optionalString (!enablePython) '' - rm -r $out/share - ''; + postInstall = + lib.optionalString (enableApp) '' + installShellCompletion --bash doc/bash_completion/{h2load,nghttp,nghttpd,nghttpx} + '' + + lib.optionalString (!enableApp) '' + rm -r $out/bin + '' + + lib.optionalString (enablePython) '' + patchShebangs $out/share/nghttp2 + '' + + lib.optionalString (!enablePython) '' + rm -r $out/share + ''; passthru.tests = { inherit curl libsoup_3; diff --git a/pkgs/by-name/ng/nginx-config-formatter/package.nix b/pkgs/by-name/ng/nginx-config-formatter/package.nix index edfe912f39835f..637145b3b58f8f 100644 --- a/pkgs/by-name/ng/nginx-config-formatter/package.nix +++ b/pkgs/by-name/ng/nginx-config-formatter/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation rec { version = "1.2.2"; diff --git a/pkgs/by-name/ng/nginx-doc/package.nix b/pkgs/by-name/ng/nginx-doc/package.nix index 4c0409e2e19c9e..01ab35ff1f9c9a 100644 --- a/pkgs/by-name/ng/nginx-doc/package.nix +++ b/pkgs/by-name/ng/nginx-doc/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, libxml2, libxslt, fetchhg }: +{ + lib, + stdenv, + libxml2, + libxslt, + fetchhg, +}: # Upstream maintains documentation (sources of https://nginx.org) in separate # mercurial repository, which do not correspond to particular git commit, but at @@ -15,7 +21,10 @@ stdenv.mkDerivation { sha256 = "029n4mnmjw94h01qalmjgf1c2h3h7wm798xv5knk3padxiy4m28b"; }; patches = [ ./exclude-google-analytics.patch ]; - nativeBuildInputs = [ libxslt libxml2 ]; + nativeBuildInputs = [ + libxslt + libxml2 + ]; # Generated documentation is not local-friendly, since it assumes that link to directory # is the same as link to index.html in that directory, which is not how browsers behave @@ -31,10 +40,10 @@ stdenv.mkDerivation { meta = with lib; { description = "Reverse proxy and lightweight webserver (documentation)"; - homepage = "https://nginx.org/"; - license = licenses.bsd2; - platforms = platforms.all; - priority = 6; + homepage = "https://nginx.org/"; + license = licenses.bsd2; + platforms = platforms.all; + priority = 6; maintainers = with maintainers; [ kaction ]; }; } diff --git a/pkgs/by-name/ng/nginx-language-server/package.nix b/pkgs/by-name/ng/nginx-language-server/package.nix index 39a5a55f5abd9f..03ebbd30807c13 100644 --- a/pkgs/by-name/ng/nginx-language-server/package.nix +++ b/pkgs/by-name/ng/nginx-language-server/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ng/nginx-sso/package.nix b/pkgs/by-name/ng/nginx-sso/package.nix index 578d55b4477e4b..358c70efdd2bb2 100644 --- a/pkgs/by-name/ng/nginx-sso/package.nix +++ b/pkgs/by-name/ng/nginx-sso/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/by-name/ng/ngircd/package.nix b/pkgs/by-name/ng/ngircd/package.nix index 53afea069fea5a..76bb5a9225a476 100644 --- a/pkgs/by-name/ng/ngircd/package.nix +++ b/pkgs/by-name/ng/ngircd/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, zlib, openssl, pam, libiconv }: +{ + lib, + stdenv, + fetchurl, + zlib, + openssl, + pam, + libiconv, +}: stdenv.mkDerivation rec { pname = "ngircd"; @@ -18,13 +26,18 @@ stdenv.mkDerivation rec { "--with-iconv" ]; - buildInputs = [ zlib pam openssl libiconv ]; + buildInputs = [ + zlib + pam + openssl + libiconv + ]; meta = { description = "Next Generation IRC Daemon"; mainProgram = "ngircd"; - homepage = "https://ngircd.barton.de"; - license = lib.licenses.gpl2Plus; - platforms = lib.platforms.all; + homepage = "https://ngircd.barton.de"; + license = lib.licenses.gpl2Plus; + platforms = lib.platforms.all; }; } diff --git a/pkgs/by-name/ng/ngrep/package.nix b/pkgs/by-name/ng/ngrep/package.nix index 31707ce00d5a89..5c0772047f0fac 100644 --- a/pkgs/by-name/ng/ngrep/package.nix +++ b/pkgs/by-name/ng/ngrep/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, libpcap, pcre }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + libpcap, + pcre, +}: stdenv.mkDerivation rec { pname = "ngrep"; @@ -7,7 +15,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "jpr5"; repo = "ngrep"; - rev = "V${lib.replaceStrings ["."] ["_"] version}"; + rev = "V${lib.replaceStrings [ "." ] [ "_" ] version}"; sha256 = "1x2fyd7wdqlj1r76ilal06cl2wmbz0ws6i3ys204sbjh1cj6dcl7"; }; @@ -19,7 +27,10 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ libpcap pcre ]; + buildInputs = [ + libpcap + pcre + ]; configureFlags = [ "--enable-ipv6" @@ -45,7 +56,7 @@ stdenv.mkDerivation rec { ''; homepage = "https://github.com/jpr5/ngrep/"; license = { - shortName = "ngrep"; # BSD-style, see README.md and LICENSE + shortName = "ngrep"; # BSD-style, see README.md and LICENSE url = "https://github.com/jpr5/ngrep/blob/master/LICENSE"; free = true; redistributable = true; diff --git a/pkgs/by-name/ng/ngrid/package.nix b/pkgs/by-name/ng/ngrid/package.nix index b609689663ec2d..193080ad3914b3 100644 --- a/pkgs/by-name/ng/ngrid/package.nix +++ b/pkgs/by-name/ng/ngrid/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3 -, expect +{ + lib, + fetchFromGitHub, + python3, + expect, }: python3.pkgs.buildPythonApplication rec { @@ -30,7 +31,10 @@ python3.pkgs.buildPythonApplication rec { pythonImportsCheck = [ "ngrid.main" ]; - nativeCheckInputs = [ python3.pkgs.pytest expect ]; + nativeCheckInputs = [ + python3.pkgs.pytest + expect + ]; checkPhase = '' runHook preCheck diff --git a/pkgs/by-name/ng/ngt/package.nix b/pkgs/by-name/ng/ngt/package.nix index e42ee750cc09c2..e8ecb466e141ec 100644 --- a/pkgs/by-name/ng/ngt/package.nix +++ b/pkgs/by-name/ng/ngt/package.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, llvmPackages -, enableAVX ? stdenv.hostPlatform.avxSupport +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + llvmPackages, + enableAVX ? stdenv.hostPlatform.avxSupport, }: stdenv.mkDerivation rec { @@ -19,7 +21,7 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; buildInputs = [ llvmPackages.openmp ]; - NIX_ENFORCE_NO_NATIVE = ! enableAVX; + NIX_ENFORCE_NO_NATIVE = !enableAVX; __AVX2__ = if enableAVX then 1 else 0; meta = with lib; { diff --git a/pkgs/by-name/nh/nh/package.nix b/pkgs/by-name/nh/nh/package.nix index 4c8ac994320819..0482c555e4bc9a 100644 --- a/pkgs/by-name/nh/nh/package.nix +++ b/pkgs/by-name/nh/nh/package.nix @@ -1,17 +1,21 @@ -{ stdenv -, lib -, rustPlatform -, installShellFiles -, makeBinaryWrapper -, darwin -, fetchFromGitHub -, nix-update-script -, nvd -, nix-output-monitor +{ + stdenv, + lib, + rustPlatform, + installShellFiles, + makeBinaryWrapper, + darwin, + fetchFromGitHub, + nix-update-script, + nvd, + nix-output-monitor, }: let version = "3.6.0"; - runtimeDeps = [ nvd nix-output-monitor ]; + runtimeDeps = [ + nvd + nix-output-monitor + ]; in rustPlatform.buildRustPackage { inherit version; @@ -31,7 +35,9 @@ rustPlatform.buildRustPackage { makeBinaryWrapper ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; preFixup = '' mkdir completions @@ -56,6 +62,9 @@ rustPlatform.buildRustPackage { homepage = "https://github.com/viperML/nh"; license = lib.licenses.eupl12; mainProgram = "nh"; - maintainers = with lib.maintainers; [ drupol viperML ]; + maintainers = with lib.maintainers; [ + drupol + viperML + ]; }; } diff --git a/pkgs/by-name/nh/nhentai/package.nix b/pkgs/by-name/nh/nhentai/package.nix index f6afd8d608829e..29a9498b2548f1 100644 --- a/pkgs/by-name/nh/nhentai/package.nix +++ b/pkgs/by-name/nh/nhentai/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ni/nibtools/package.nix b/pkgs/by-name/ni/nibtools/package.nix index ea8dad3b2c6295..84b80b412a7973 100644 --- a/pkgs/by-name/ni/nibtools/package.nix +++ b/pkgs/by-name/ni/nibtools/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, opencbm -, cc65 +{ + lib, + stdenv, + fetchFromGitHub, + opencbm, + cc65, }: stdenv.mkDerivation { @@ -27,7 +28,11 @@ stdenv.mkDerivation { ]; preBuild = "mkdir build"; - makeFlags = [ "-f" "GNU/Makefile" "linux" ]; + makeFlags = [ + "-f" + "GNU/Makefile" + "linux" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/ni/nice-dcv-client/package.nix b/pkgs/by-name/ni/nice-dcv-client/package.nix index 6898d0f66d47cc..5d2fcbb4e01a2f 100644 --- a/pkgs/by-name/ni/nice-dcv-client/package.nix +++ b/pkgs/by-name/ni/nice-dcv-client/package.nix @@ -1,38 +1,42 @@ -{ lib -, stdenv -, fetchurl -, glib -, libX11 -, gst_all_1 -, libepoxy -, pango -, cairo -, gdk-pixbuf -, e2fsprogs -, libkrb5 -, libva -, openssl -, pcsclite -, gtk3 -, libselinux -, libxml2 -, libffi -, python3Packages -, cpio -, autoPatchelfHook -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + glib, + libX11, + gst_all_1, + libepoxy, + pango, + cairo, + gdk-pixbuf, + e2fsprogs, + libkrb5, + libva, + openssl, + pcsclite, + gtk3, + libselinux, + libxml2, + libffi, + python3Packages, + cpio, + autoPatchelfHook, + wrapGAppsHook3, }: stdenv.mkDerivation rec { pname = "nice-dcv-client"; version = "2021.2.3797-1"; - src = - fetchurl { - url = "https://d1uj6qtbmh3dt5.cloudfront.net/2021.2/Clients/nice-dcv-viewer-${version}.el8.x86_64.rpm"; - sha256 = "sha256-iLz25SB5v7ghkAZOMGPmpNaPihd8ikzCQS//r1xBNRU="; - }; + src = fetchurl { + url = "https://d1uj6qtbmh3dt5.cloudfront.net/2021.2/Clients/nice-dcv-viewer-${version}.el8.x86_64.rpm"; + sha256 = "sha256-iLz25SB5v7ghkAZOMGPmpNaPihd8ikzCQS//r1xBNRU="; + }; - nativeBuildInputs = [ autoPatchelfHook wrapGAppsHook3 python3Packages.rpm ]; + nativeBuildInputs = [ + autoPatchelfHook + wrapGAppsHook3 + python3Packages.rpm + ]; unpackPhase = '' rpm2cpio $src | ${cpio}/bin/cpio -idm ''; diff --git a/pkgs/by-name/ni/nickel/package.nix b/pkgs/by-name/ni/nickel/package.nix index 8c488d1ec9fe9b..38553c86b9c845 100644 --- a/pkgs/by-name/ni/nickel/package.nix +++ b/pkgs/by-name/ni/nickel/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, python3 -, nix-update-script +{ + lib, + rustPlatform, + fetchFromGitHub, + python3, + nix-update-script, }: rustPlatform.buildRustPackage rec { @@ -18,13 +19,19 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-MaMzwvvWP+vmdBVCefXI6dehuTyPcPW2b6KdarxjBjA="; - cargoBuildFlags = [ "-p nickel-lang-cli" "-p nickel-lang-lsp" ]; + cargoBuildFlags = [ + "-p nickel-lang-cli" + "-p nickel-lang-lsp" + ]; nativeBuildInputs = [ python3 ]; - outputs = [ "out" "nls" ]; + outputs = [ + "out" + "nls" + ]; # This fixes the way comrak is defined as a dependency, without the sed the build fails: # @@ -56,7 +63,10 @@ rustPlatform.buildRustPackage rec { ''; changelog = "https://github.com/tweag/nickel/blob/${version}/RELEASES.md"; license = licenses.mit; - maintainers = with maintainers; [ felschr matthiasbeyer ]; + maintainers = with maintainers; [ + felschr + matthiasbeyer + ]; mainProgram = "nickel"; }; } diff --git a/pkgs/by-name/ni/nicstat/package.nix b/pkgs/by-name/ni/nicstat/package.nix index 1e1e346b822b1d..a60e8a30605006 100644 --- a/pkgs/by-name/ni/nicstat/package.nix +++ b/pkgs/by-name/ni/nicstat/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ni/niff/package.nix b/pkgs/by-name/ni/niff/package.nix index 909aaaa9413c31..768d8b4047b723 100644 --- a/pkgs/by-name/ni/niff/package.nix +++ b/pkgs/by-name/ni/niff/package.nix @@ -1,12 +1,15 @@ -{ lib, stdenv -, python3 -, fetchFromGitHub +{ + lib, + stdenv, + python3, + fetchFromGitHub, }: let pname = "niff"; version = "0.1"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { name = "${pname}-${version}"; src = fetchFromGitHub { diff --git a/pkgs/by-name/ni/nifticlib/package.nix b/pkgs/by-name/ni/nifticlib/package.nix index fee2ea8772b41e..9ace77562c6269 100644 --- a/pkgs/by-name/ni/nifticlib/package.nix +++ b/pkgs/by-name/ni/nifticlib/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, +}: stdenv.mkDerivation rec { pname = "nifticlib"; diff --git a/pkgs/by-name/ni/niftyreg/package.nix b/pkgs/by-name/ni/niftyreg/package.nix index 0be59bcd726a0f..f71fa01325861f 100644 --- a/pkgs/by-name/ni/niftyreg/package.nix +++ b/pkgs/by-name/ni/niftyreg/package.nix @@ -1,7 +1,13 @@ -{ lib, stdenv, fetchurl, cmake, zlib }: +{ + lib, + stdenv, + fetchurl, + cmake, + zlib, +}: stdenv.mkDerivation rec { - pname = "niftyreg"; + pname = "niftyreg"; version = "1.3.9"; src = fetchurl { @@ -19,6 +25,6 @@ stdenv.mkDerivation rec { description = "Medical image registration software"; maintainers = with maintainers; [ bcdarwin ]; platforms = [ "x86_64-linux" ]; - license = licenses.bsd3; + license = licenses.bsd3; }; } diff --git a/pkgs/by-name/ni/niftyseg/package.nix b/pkgs/by-name/ni/niftyseg/package.nix index 0fd658b0addcb5..1c7d59328a45b7 100644 --- a/pkgs/by-name/ni/niftyseg/package.nix +++ b/pkgs/by-name/ni/niftyseg/package.nix @@ -1,7 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, eigen, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + eigen, + zlib, +}: stdenv.mkDerivation rec { - pname = "niftyseg"; + pname = "niftyseg"; version = "1.0"; src = fetchFromGitHub { @@ -12,14 +19,17 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ eigen zlib ]; + buildInputs = [ + eigen + zlib + ]; meta = with lib; { homepage = "http://cmictig.cs.ucl.ac.uk/research/software/software-nifty/niftyseg"; description = "Software for medical image segmentation, bias field correction, and cortical thickness calculation"; maintainers = with maintainers; [ bcdarwin ]; platforms = platforms.unix; - license = licenses.bsd3; + license = licenses.bsd3; }; } diff --git a/pkgs/by-name/ni/nika-fonts/package.nix b/pkgs/by-name/ni/nika-fonts/package.nix index f5076f3c93cb61..165145ff295aba 100644 --- a/pkgs/by-name/ni/nika-fonts/package.nix +++ b/pkgs/by-name/ni/nika-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "nika-fonts"; diff --git a/pkgs/by-name/ni/nikto/package.nix b/pkgs/by-name/ni/nikto/package.nix index 098171de09df13..f82cf130f2b10f 100644 --- a/pkgs/by-name/ni/nikto/package.nix +++ b/pkgs/by-name/ni/nikto/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, perlPackages -, makeWrapper -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + perlPackages, + makeWrapper, + installShellFiles, }: let @@ -32,7 +33,10 @@ stdenv.mkDerivation rec { --replace "LW_SSL_ENGINE=auto" "LW_SSL_ENGINE=SSLeay" ''; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; buildInputs = [ perlPackages.perl diff --git a/pkgs/by-name/ni/nil/package.nix b/pkgs/by-name/ni/nil/package.nix index 71ee69ac6199cb..553b48eb8b2a59 100644 --- a/pkgs/by-name/ni/nil/package.nix +++ b/pkgs/by-name/ni/nil/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, nixVersions, nix-update-script }: +{ + lib, + rustPlatform, + fetchFromGitHub, + nixVersions, + nix-update-script, +}: rustPlatform.buildRustPackage rec { pname = "nil"; @@ -30,8 +36,14 @@ rustPlatform.buildRustPackage rec { description = "Yet another language server for Nix"; homepage = "https://github.com/oxalica/nil"; changelog = "https://github.com/oxalica/nil/releases/tag/${version}"; - license = with licenses; [ mit asl20 ]; - maintainers = with maintainers; [ figsoda oxalica ]; + license = with licenses; [ + mit + asl20 + ]; + maintainers = with maintainers; [ + figsoda + oxalica + ]; mainProgram = "nil"; }; } diff --git a/pkgs/by-name/ni/nilfs-utils/package.nix b/pkgs/by-name/ni/nilfs-utils/package.nix index 79a0fe53367341..3ce0af6d1fd9f3 100644 --- a/pkgs/by-name/ni/nilfs-utils/package.nix +++ b/pkgs/by-name/ni/nilfs-utils/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libuuid, libselinux -, e2fsprogs }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libuuid, + libselinux, + e2fsprogs, +}: stdenv.mkDerivation rec { pname = "nilfs-utils"; @@ -14,7 +21,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ libuuid libselinux ]; + buildInputs = [ + libuuid + libselinux + ]; postPatch = '' # Fix up hardcoded paths. @@ -45,7 +55,10 @@ stdenv.mkDerivation rec { description = "NILFS utilities"; maintainers = [ maintainers.raskin ]; platforms = platforms.linux; - license = with licenses; [ gpl2Plus lgpl21 ]; + license = with licenses; [ + gpl2Plus + lgpl21 + ]; downloadPage = "http://nilfs.sourceforge.net/en/download.html"; }; } diff --git a/pkgs/by-name/ni/nim-atlas/package.nix b/pkgs/by-name/ni/nim-atlas/package.nix index 7f01fab5876d99..4c8d92b3e0952a 100644 --- a/pkgs/by-name/ni/nim-atlas/package.nix +++ b/pkgs/by-name/ni/nim-atlas/package.nix @@ -1,22 +1,29 @@ -{ lib, buildNimPackage, fetchFromGitHub, openssl }: +{ + lib, + buildNimPackage, + fetchFromGitHub, + openssl, +}: -buildNimPackage (final: prev: { - pname = "atlas"; - version = "unstable-2023-09-22"; - src = fetchFromGitHub { - owner = "nim-lang"; - repo = "atlas"; - rev = "ab22f997c22a644924c1a9b920f8ce207da9b77f"; - hash = "sha256-TsZ8TriVuKEY9/mV6KR89eFOgYrgTqXmyv/vKu362GU="; - }; - buildInputs = [ openssl ]; - prePatch = '' - rm config.nims - ''; # never trust a .nims file - doCheck = false; # tests will clone repos - meta = final.src.meta // { - description = "Nim package cloner"; - mainProgram = "atlas"; - license = [ lib.licenses.mit ]; - }; -}) +buildNimPackage ( + final: prev: { + pname = "atlas"; + version = "unstable-2023-09-22"; + src = fetchFromGitHub { + owner = "nim-lang"; + repo = "atlas"; + rev = "ab22f997c22a644924c1a9b920f8ce207da9b77f"; + hash = "sha256-TsZ8TriVuKEY9/mV6KR89eFOgYrgTqXmyv/vKu362GU="; + }; + buildInputs = [ openssl ]; + prePatch = '' + rm config.nims + ''; # never trust a .nims file + doCheck = false; # tests will clone repos + meta = final.src.meta // { + description = "Nim package cloner"; + mainProgram = "atlas"; + license = [ lib.licenses.mit ]; + }; + } +) diff --git a/pkgs/by-name/ni/nim_builder/package.nix b/pkgs/by-name/ni/nim_builder/package.nix index 8466ab8535c932..017fe548aa58e0 100644 --- a/pkgs/by-name/ni/nim_builder/package.nix +++ b/pkgs/by-name/ni/nim_builder/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, nim }: +{ + lib, + stdenv, + nim, +}: stdenv.mkDerivation { pname = "nim_builder"; diff --git a/pkgs/by-name/ni/nimdow/package.nix b/pkgs/by-name/ni/nimdow/package.nix index ad5935a9c34b60..4eb4c7fa536c4f 100644 --- a/pkgs/by-name/ni/nimdow/package.nix +++ b/pkgs/by-name/ni/nimdow/package.nix @@ -1,4 +1,10 @@ -{ lib, buildNimPackage, fetchFromGitHub, nixosTests, testers }: +{ + lib, + buildNimPackage, + fetchFromGitHub, + nixosTests, + testers, +}: buildNimPackage (finalAttrs: { pname = "nimdow"; @@ -35,8 +41,10 @@ buildNimPackage (finalAttrs: { }; }; - meta = with lib; - finalAttrs.src.meta // { + meta = + with lib; + finalAttrs.src.meta + // { description = "Nim based tiling window manager"; platforms = platforms.linux; license = [ licenses.gpl2 ]; diff --git a/pkgs/by-name/ni/nimlsp/package.nix b/pkgs/by-name/ni/nimlsp/package.nix index d9eaa838f7f016..27ea08a571618f 100644 --- a/pkgs/by-name/ni/nimlsp/package.nix +++ b/pkgs/by-name/ni/nimlsp/package.nix @@ -1,4 +1,11 @@ -{ lib, buildNimPackage, fetchFromGitHub, srcOnly, nim-2_0, nim-unwrapped-2_0 }: +{ + lib, + buildNimPackage, + fetchFromGitHub, + srcOnly, + nim-2_0, + nim-unwrapped-2_0, +}: let buildNimPackage' = buildNimPackage.override { @@ -37,7 +44,12 @@ buildNimPackage' (finalAttrs: { "-d:tempDir=/tmp" ]; - nimDefines = [ "nimcore" "nimsuggest" "debugCommunication" "debugLogging" ]; + nimDefines = [ + "nimcore" + "nimsuggest" + "debugCommunication" + "debugLogging" + ]; doCheck = false; diff --git a/pkgs/by-name/ni/nimmm/package.nix b/pkgs/by-name/ni/nimmm/package.nix index 7b72f4a07749d7..3a5dcb628108a2 100644 --- a/pkgs/by-name/ni/nimmm/package.nix +++ b/pkgs/by-name/ni/nimmm/package.nix @@ -1,4 +1,10 @@ -{ lib, buildNimPackage, fetchFromGitHub, termbox, pcre }: +{ + lib, + buildNimPackage, + fetchFromGitHub, + termbox, + pcre, +}: buildNimPackage (finalAttrs: { pname = "nimmm"; @@ -13,7 +19,10 @@ buildNimPackage (finalAttrs: { lockFile = ./lock.json; - buildInputs = [ termbox pcre ]; + buildInputs = [ + termbox + pcre + ]; meta = { description = "Terminal file manager for Linux"; diff --git a/pkgs/by-name/ni/ninjas2/package.nix b/pkgs/by-name/ni/ninjas2/package.nix index 8a2cc317c1375d..e8eed77e4faa44 100644 --- a/pkgs/by-name/ni/ninjas2/package.nix +++ b/pkgs/by-name/ni/ninjas2/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, libjack2, libGL, pkg-config, xorg, mesa, libsndfile, libsamplerate }: +{ + lib, + stdenv, + fetchFromGitHub, + libjack2, + libGL, + pkg-config, + xorg, + mesa, + libsndfile, + libsamplerate, +}: stdenv.mkDerivation rec { pname = "ninjas2"; @@ -18,7 +29,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - libjack2 xorg.libX11 libGL mesa libsndfile libsamplerate + libjack2 + xorg.libX11 + libGL + mesa + libsndfile + libsamplerate ]; installPhase = '' diff --git a/pkgs/by-name/ni/ninka/package.nix b/pkgs/by-name/ni/ninka/package.nix index 76729d71e40192..61e23a95ec5ec4 100644 --- a/pkgs/by-name/ni/ninka/package.nix +++ b/pkgs/by-name/ni/ninka/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, perl, perlPackages }: +{ + lib, + fetchFromGitHub, + perl, + perlPackages, +}: perlPackages.buildPerlPackage { pname = "ninka"; @@ -11,9 +16,17 @@ perlPackages.buildPerlPackage { sha256 = "1grlis1kycbcjvjgqvn7aw81q1qx49ahvxg2k7cgyr79mvgpgi9m"; }; - buildInputs = with perlPackages; [ perl TestOutput DBDSQLite DBI TestPod TestPodCoverage SpreadsheetParseExcel ]; + buildInputs = with perlPackages; [ + perl + TestOutput + DBDSQLite + DBI + TestPod + TestPodCoverage + SpreadsheetParseExcel + ]; - doCheck = false; # hangs + doCheck = false; # hangs preConfigure = '' sed -i.bak -e 's;#!/usr/bin/perl;#!${perl}/bin/perl;g' \ diff --git a/pkgs/by-name/ni/ninvaders/package.nix b/pkgs/by-name/ni/ninvaders/package.nix index 089fa5478a0d66..00e42aa5a9160a 100644 --- a/pkgs/by-name/ni/ninvaders/package.nix +++ b/pkgs/by-name/ni/ninvaders/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ncurses, +}: stdenv.mkDerivation rec { pname = "ninvaders"; diff --git a/pkgs/by-name/ni/nip2/package.nix b/pkgs/by-name/ni/nip2/package.nix index 651baf547a9e7e..207efe86b27e4c 100644 --- a/pkgs/by-name/ni/nip2/package.nix +++ b/pkgs/by-name/ni/nip2/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, glib -, libxml2 -, flex -, bison -, vips -, gtk2 -, fftw -, gsl -, goffice -, libgsf -, makeWrapper +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + libxml2, + flex, + bison, + vips, + gtk2, + fftw, + gsl, + goffice, + libgsf, + makeWrapper, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ni/nitch/package.nix b/pkgs/by-name/ni/nitch/package.nix index e241bcd7e61e7e..9440d029533519 100644 --- a/pkgs/by-name/ni/nitch/package.nix +++ b/pkgs/by-name/ni/nitch/package.nix @@ -1,4 +1,9 @@ -{ lib, buildNimPackage, fetchFromGitHub, fetchpatch }: +{ + lib, + buildNimPackage, + fetchFromGitHub, + fetchpatch, +}: buildNimPackage { pname = "nitch"; diff --git a/pkgs/by-name/ni/nitrogen/package.nix b/pkgs/by-name/ni/nitrogen/package.nix index 6f4c0be19dcdd5..ec57d6c089241b 100644 --- a/pkgs/by-name/ni/nitrogen/package.nix +++ b/pkgs/by-name/ni/nitrogen/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, gtkmm2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + gtkmm2, +}: stdenv.mkDerivation rec { pname = "nitrogen"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib gtkmm2 ]; + buildInputs = [ + glib + gtkmm2 + ]; patchPhase = '' patchShebangs data/icon-theme-installer diff --git a/pkgs/by-name/ni/nitter/package.nix b/pkgs/by-name/ni/nitter/package.nix index 28884a7debf097..0ff628f39416ed 100644 --- a/pkgs/by-name/ni/nitter/package.nix +++ b/pkgs/by-name/ni/nitter/package.nix @@ -1,53 +1,59 @@ -{ lib -, buildNimPackage -, fetchFromGitHub -, nixosTests -, substituteAll -, unstableGitUpdater +{ + lib, + buildNimPackage, + fetchFromGitHub, + nixosTests, + substituteAll, + unstableGitUpdater, }: -buildNimPackage (finalAttrs: prevAttrs: { - pname = "nitter"; - version = "0-unstable-2024-02-26"; - - src = fetchFromGitHub { - owner = "zedeus"; - repo = "nitter"; - rev = "c6edec04901d0a37799499ed4c6921db640fb5a4"; - hash = "sha256-N3d63nyVzUTa2+UemA1REFfVsw6iOVU8xUlYraR55m4="; - }; - - lockFile = ./lock.json; - - patches = [ - (substituteAll { - src = ./nitter-version.patch; - inherit (finalAttrs) version; - inherit (finalAttrs.src) rev; - url = builtins.replaceStrings [ "archive" ".tar.gz" ] [ "commit" "" ] finalAttrs.src.url; - }) - ]; - - postBuild = '' - nim compile ${toString finalAttrs.nimFlags} -r tools/gencss - nim compile ${toString finalAttrs.nimFlags} -r tools/rendermd - ''; - - postInstall = '' - mkdir -p $out/share/nitter - cp -r public $out/share/nitter/public - ''; - - passthru = { - tests = { inherit (nixosTests) nitter; }; - updateScript = unstableGitUpdater { branch = "guest_accounts"; }; - }; - - meta = with lib; { - homepage = "https://github.com/zedeus/nitter"; - description = "Alternative Twitter front-end"; - license = licenses.agpl3Only; - maintainers = with maintainers; [ erdnaxe infinidoge ]; - mainProgram = "nitter"; - }; -}) +buildNimPackage ( + finalAttrs: prevAttrs: { + pname = "nitter"; + version = "0-unstable-2024-02-26"; + + src = fetchFromGitHub { + owner = "zedeus"; + repo = "nitter"; + rev = "c6edec04901d0a37799499ed4c6921db640fb5a4"; + hash = "sha256-N3d63nyVzUTa2+UemA1REFfVsw6iOVU8xUlYraR55m4="; + }; + + lockFile = ./lock.json; + + patches = [ + (substituteAll { + src = ./nitter-version.patch; + inherit (finalAttrs) version; + inherit (finalAttrs.src) rev; + url = builtins.replaceStrings [ "archive" ".tar.gz" ] [ "commit" "" ] finalAttrs.src.url; + }) + ]; + + postBuild = '' + nim compile ${toString finalAttrs.nimFlags} -r tools/gencss + nim compile ${toString finalAttrs.nimFlags} -r tools/rendermd + ''; + + postInstall = '' + mkdir -p $out/share/nitter + cp -r public $out/share/nitter/public + ''; + + passthru = { + tests = { inherit (nixosTests) nitter; }; + updateScript = unstableGitUpdater { branch = "guest_accounts"; }; + }; + + meta = with lib; { + homepage = "https://github.com/zedeus/nitter"; + description = "Alternative Twitter front-end"; + license = licenses.agpl3Only; + maintainers = with maintainers; [ + erdnaxe + infinidoge + ]; + mainProgram = "nitter"; + }; + } +) diff --git a/pkgs/by-name/ni/nix-bash-completions/package.nix b/pkgs/by-name/ni/nix-bash-completions/package.nix index 10fb097fd2c8ed..71ea4e111dfc19 100644 --- a/pkgs/by-name/ni/nix-bash-completions/package.nix +++ b/pkgs/by-name/ni/nix-bash-completions/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { version = "0.6.8"; @@ -52,7 +57,10 @@ stdenv.mkDerivation rec { description = "Bash completions for Nix, NixOS, and NixOps"; license = licenses.bsd3; platforms = platforms.all; - maintainers = with maintainers; [ hedning ncfavier ]; + maintainers = with maintainers; [ + hedning + ncfavier + ]; # Set a lower priority such that Nix wins in case of conflicts. priority = 10; }; diff --git a/pkgs/by-name/ni/nix-binary-cache/package.nix b/pkgs/by-name/ni/nix-binary-cache/package.nix index 393415ae61e256..68c7f15333d24f 100644 --- a/pkgs/by-name/ni/nix-binary-cache/package.nix +++ b/pkgs/by-name/ni/nix-binary-cache/package.nix @@ -1,6 +1,17 @@ -{lib, stdenv -, coreutils, findutils, nix, xz, bzip2, gnused, gnugrep, openssl -, lighttpd, iproute2 }: +{ + lib, + stdenv, + coreutils, + findutils, + nix, + xz, + bzip2, + gnused, + gnugrep, + openssl, + lighttpd, + iproute2, +}: stdenv.mkDerivation rec { version = "2014-06-29-1"; pname = "nix-binary-cache"; @@ -52,9 +63,9 @@ stdenv.mkDerivation rec { nix-binary-cache-start that can be run without any setup to launch a binary cache and get the example arguments for its usage. ''; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; license = lib.licenses.gpl2Plus; platforms = lib.platforms.all; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/by-name/ni/nix-bisect/package.nix b/pkgs/by-name/ni/nix-bisect/package.nix index 9927be16d36a02..10232985c27d7c 100644 --- a/pkgs/by-name/ni/nix-bisect/package.nix +++ b/pkgs/by-name/ni/nix-bisect/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: let diff --git a/pkgs/by-name/ni/nix-btm/package.nix b/pkgs/by-name/ni/nix-btm/package.nix index a7d94b4863b588..657e768d9db7c9 100644 --- a/pkgs/by-name/ni/nix-btm/package.nix +++ b/pkgs/by-name/ni/nix-btm/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, rustPlatform, fetchCrate, darwin }: +{ + lib, + stdenv, + rustPlatform, + fetchCrate, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "nix-btm"; @@ -12,8 +18,13 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-qUZ3zJjQrteFQerBKFH/+Ys0uOzvI7DH9rCaVtseJMM="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin - (with darwin.apple_sdk.frameworks; [ CoreServices SystemConfiguration ]); + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + CoreServices + SystemConfiguration + ] + ); meta = with lib; { description = "Rust tool to monitor Nix processes"; diff --git a/pkgs/by-name/ni/nix-build-uncached/package.nix b/pkgs/by-name/ni/nix-build-uncached/package.nix index 0aa894b3effe8b..5bf09afad6e37a 100644 --- a/pkgs/by-name/ni/nix-build-uncached/package.nix +++ b/pkgs/by-name/ni/nix-build-uncached/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, makeWrapper }: +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, +}: buildGoModule rec { pname = "nix-build-uncached"; diff --git a/pkgs/by-name/ni/nix-bundle/package.nix b/pkgs/by-name/ni/nix-bundle/package.nix index a32f788bf4dca9..d656e972853aa7 100644 --- a/pkgs/by-name/ni/nix-bundle/package.nix +++ b/pkgs/by-name/ni/nix-bundle/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, bzip2 -, coreutils -, gnutar -, gzip -, makeWrapper -, nix +{ + lib, + stdenv, + fetchFromGitHub, + bzip2, + coreutils, + gnutar, + gzip, + makeWrapper, + nix, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ni/nix-doc/package.nix b/pkgs/by-name/ni/nix-doc/package.nix index f594b0648bfae2..d938688022a870 100644 --- a/pkgs/by-name/ni/nix-doc/package.nix +++ b/pkgs/by-name/ni/nix-doc/package.nix @@ -1,16 +1,25 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, boost -, nix -, pkg-config -# Whether to build the nix-doc plugin for Nix -, withPlugin ? false # no longer needed for nix 2.24 +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + boost, + nix, + pkg-config, + # Whether to build the nix-doc plugin for Nix + withPlugin ? false, # no longer needed for nix 2.24 }: let - packageFlags = [ "-p" "nix-doc" ] ++ lib.optionals withPlugin [ "-p" "nix-doc-plugin" ]; + packageFlags = + [ + "-p" + "nix-doc" + ] + ++ lib.optionals withPlugin [ + "-p" + "nix-doc-plugin" + ]; in rustPlatform.buildRustPackage rec { pname = "nix-doc"; @@ -24,9 +33,15 @@ rustPlatform.buildRustPackage rec { }; doCheck = true; - buildInputs = lib.optionals withPlugin [ boost nix ]; + buildInputs = lib.optionals withPlugin [ + boost + nix + ]; - nativeBuildInputs = lib.optionals withPlugin [ pkg-config nix ]; + nativeBuildInputs = lib.optionals withPlugin [ + pkg-config + nix + ]; cargoBuildFlags = packageFlags; cargoTestFlags = packageFlags; diff --git a/pkgs/by-name/ni/nix-health/package.nix b/pkgs/by-name/ni/nix-health/package.nix index 2081714d50a99d..8d366d221f9fde 100644 --- a/pkgs/by-name/ni/nix-health/package.nix +++ b/pkgs/by-name/ni/nix-health/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, rustPlatform -, fetchCrate -, libiconv -, openssl -, pkg-config -, darwin +{ + lib, + stdenv, + rustPlatform, + fetchCrate, + libiconv, + openssl, + pkg-config, + darwin, }: rustPlatform.buildRustPackage rec { @@ -20,19 +22,29 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-mqJA5Fv/sYj6ZkE73emtaHvg9hdT/5lN0kM3sl+GRCo="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libiconv openssl ] + buildInputs = + [ + libiconv + openssl + ] # Use a newer SDK for CoreFoundation, because the sysinfo crate requires # it, https://github.com/GuillaumeGomez/sysinfo/issues/915 - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk_11_0.frameworks; - [ IOKit + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk_11_0.frameworks; + [ + IOKit CoreFoundation - ]); + ] + ); meta = with lib; { description = "Check the health of your Nix setup"; homepage = "https://github.com/juspay/nix-health"; license = licenses.asl20; - maintainers = with maintainers; [ srid shivaraj-bh ]; + maintainers = with maintainers; [ + srid + shivaraj-bh + ]; mainProgram = "nix-health"; }; } diff --git a/pkgs/by-name/ni/nix-init/get_nix_license.nix b/pkgs/by-name/ni/nix-init/get_nix_license.nix index 0e67fb5e044cad..dc4fcf5c722758 100644 --- a/pkgs/by-name/ni/nix-init/get_nix_license.nix +++ b/pkgs/by-name/ni/nix-init/get_nix_license.nix @@ -18,8 +18,9 @@ let warn ; - licenseMap = flip concatMapAttrs licenses - (k: v: optionalAttrs (v ? spdxId && !v.deprecated) { ${v.spdxId} = k; }); + licenseMap = flip concatMapAttrs licenses ( + k: v: optionalAttrs (v ? spdxId && !v.deprecated) { ${v.spdxId} = k; } + ); deprecatedAliases = { "AGPL-3.0" = "agpl3Only"; @@ -43,26 +44,22 @@ let }; lints = { - "deprecated licenses" = intersectLists - (attrNames licenseMap) - (attrNames deprecatedAliases); + "deprecated licenses" = intersectLists (attrNames licenseMap) (attrNames deprecatedAliases); - "invalid aliases" = attrNames (filterAttrs - (_: v: licenses.${v}.deprecated or true) - deprecatedAliases); + "invalid aliases" = attrNames ( + filterAttrs (_: v: licenses.${v}.deprecated or true) deprecatedAliases + ); }; - lint = flip pipe - (flip mapAttrsToList lints (k: v: - if v == [ ] then - id - else - warn "${k}: ${concatStringsSep ", " v}")); + lint = flip pipe ( + flip mapAttrsToList lints (k: v: if v == [ ] then id else warn "${k}: ${concatStringsSep ", " v}") + ); - arms = lint (concatStringsSep "\n " - (mapAttrsToList - (k: v: ''"${k}" => Some("${v}"),'') - (deprecatedAliases // licenseMap))); + arms = lint ( + concatStringsSep "\n " ( + mapAttrsToList (k: v: ''"${k}" => Some("${v}"),'') (deprecatedAliases // licenseMap) + ) + ); in writeText "get-nix-license.rs" '' diff --git a/pkgs/by-name/ni/nix-inspect/package.nix b/pkgs/by-name/ni/nix-inspect/package.nix index 84253e3a4d0891..808da85fb582c6 100644 --- a/pkgs/by-name/ni/nix-inspect/package.nix +++ b/pkgs/by-name/ni/nix-inspect/package.nix @@ -10,7 +10,8 @@ ninja, stdenv, fetchpatch, -}: let +}: +let src = fetchFromGitHub { owner = "bluskript"; repo = "nix-inspect"; @@ -27,7 +28,11 @@ cd worker ''; - nativeBuildInputs = [meson ninja pkg-config]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; # TODO: Remove this patch when this pull request is merged and released: https://github.com/bluskript/nix-inspect/pull/18 patches = [ @@ -46,26 +51,26 @@ mesonBuildType = "release"; }; in - rustPlatform.buildRustPackage { - inherit src; - pname = "nix-inspect"; - version = "0.1.2"; +rustPlatform.buildRustPackage { + inherit src; + pname = "nix-inspect"; + version = "0.1.2"; - cargoHash = "sha256-/0CrHqOL4B0Rx0ZbUpW54FiisfpW6UU4uk6wctfCX5c="; + cargoHash = "sha256-/0CrHqOL4B0Rx0ZbUpW54FiisfpW6UU4uk6wctfCX5c="; - buildInputs = [workerPackage]; + buildInputs = [ workerPackage ]; - postPatch = '' - substituteInPlace src/workers.rs \ - --replace-fail 'env!("WORKER_BINARY_PATH")' '"${workerPackage}/bin/nix-inspect"' - ''; + postPatch = '' + substituteInPlace src/workers.rs \ + --replace-fail 'env!("WORKER_BINARY_PATH")' '"${workerPackage}/bin/nix-inspect"' + ''; - meta = with lib; { - description = "Interactive TUI for inspecting nix configs and other expressions"; - homepage = "https://github.com/bluskript/nix-inspect"; - license = licenses.mit; - maintainers = with maintainers; [blusk]; - platforms = platforms.unix; - mainProgram = "nix-inspect"; - }; - } + meta = with lib; { + description = "Interactive TUI for inspecting nix configs and other expressions"; + homepage = "https://github.com/bluskript/nix-inspect"; + license = licenses.mit; + maintainers = with maintainers; [ blusk ]; + platforms = platforms.unix; + mainProgram = "nix-inspect"; + }; +} diff --git a/pkgs/by-name/ni/nix-lib-nmd/package.nix b/pkgs/by-name/ni/nix-lib-nmd/package.nix index 2fbfa758056cdf..4d0ad668ed6717 100644 --- a/pkgs/by-name/ni/nix-lib-nmd/package.nix +++ b/pkgs/by-name/ni/nix-lib-nmd/package.nix @@ -1,7 +1,13 @@ -{ lib, stdenv, fetchFromSourcehut }: +{ + lib, + stdenv, + fetchFromSourcehut, +}: -let version = "0.5.0"; -in stdenv.mkDerivation { +let + version = "0.5.0"; +in +stdenv.mkDerivation { pname = "nix-lib-nmd"; inherit version; diff --git a/pkgs/by-name/ni/nix-lib-nmt/package.nix b/pkgs/by-name/ni/nix-lib-nmt/package.nix index ed792ae2883d9f..5c3888d91d9910 100644 --- a/pkgs/by-name/ni/nix-lib-nmt/package.nix +++ b/pkgs/by-name/ni/nix-lib-nmt/package.nix @@ -1,7 +1,13 @@ -{ lib, stdenv, fetchFromSourcehut }: +{ + lib, + stdenv, + fetchFromSourcehut, +}: -let version = "0.5.1"; -in stdenv.mkDerivation { +let + version = "0.5.1"; +in +stdenv.mkDerivation { pname = "nix-lib-nmt"; inherit version; diff --git a/pkgs/by-name/ni/nix-melt/package.nix b/pkgs/by-name/ni/nix-melt/package.nix index e39ae415d0385f..31e1a0f0e72c03 100644 --- a/pkgs/by-name/ni/nix-melt/package.nix +++ b/pkgs/by-name/ni/nix-melt/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ni/nix-plugin-pijul/package.nix b/pkgs/by-name/ni/nix-plugin-pijul/package.nix index b1695931b95b66..c39ef22811182a 100644 --- a/pkgs/by-name/ni/nix-plugin-pijul/package.nix +++ b/pkgs/by-name/ni/nix-plugin-pijul/package.nix @@ -15,8 +15,10 @@ nixOverride ? null, nix-plugin-pijul, }: -let nix = if nixOverride != null then nixOverride else nixVersions.nix_2_24; -in stdenv.mkDerivation (finalAttrs: { +let + nix = if nixOverride != null then nixOverride else nixVersions.nix_2_24; +in +stdenv.mkDerivation (finalAttrs: { pname = "nix-plugin-pijul"; version = "0.1.6"; @@ -37,52 +39,57 @@ in stdenv.mkDerivation (finalAttrs: { nix ]; - passthru.tests = let - localRepoCheck = nixOverride: - runCommand "localRepoCheck-${nixOverride.name}" - { - nativeBuildInputs = [ - pijul - nix - ]; - } - '' - export HOME=$(mktemp -d) - export EDITOR=true - pijul identity new --no-link --no-prompt --display-name 'Test User' --email 'test@example.com' + passthru.tests = + let + localRepoCheck = + nixOverride: + runCommand "localRepoCheck-${nixOverride.name}" + { + nativeBuildInputs = [ + pijul + nix + ]; + } + '' + export HOME=$(mktemp -d) + export EDITOR=true + pijul identity new --no-link --no-prompt --display-name 'Test User' --email 'test@example.com' - pijul init repo - cd repo + pijul init repo + cd repo - echo "it works" > foo - pijul add foo - pijul record --message 'Add foo' + echo "it works" > foo + pijul add foo + pijul record --message 'Add foo' - output=$( - nix \ - --option plugin-files ${nix-plugin-pijul.override {inherit nixOverride;}}/lib/nix/plugins/pijul.so \ - --extra-experimental-features 'nix-command flakes' \ - eval --impure --raw --expr "builtins.readFile ((builtins.fetchTree \"pijul+file://$PWD\") + \"/foo\")" - ) + output=$( + nix \ + --option plugin-files ${ + nix-plugin-pijul.override { inherit nixOverride; } + }/lib/nix/plugins/pijul.so \ + --extra-experimental-features 'nix-command flakes' \ + eval --impure --raw --expr "builtins.readFile ((builtins.fetchTree \"pijul+file://$PWD\") + \"/foo\")" + ) - echo $output + echo $output - [[ "$output" = "it works" ]] + [[ "$output" = "it works" ]] - mkdir $out - ''; - in { - stable = localRepoCheck nixVersions.stable; - latest = localRepoCheck nixVersions.latest; - git = localRepoCheck nixVersions.git; - nix_2_24 = localRepoCheck nixVersions.nix_2_24; - }; + mkdir $out + ''; + in + { + stable = localRepoCheck nixVersions.stable; + latest = localRepoCheck nixVersions.latest; + git = localRepoCheck nixVersions.git; + nix_2_24 = localRepoCheck nixVersions.nix_2_24; + }; meta = { description = "Plugin to add Pijul support to the Nix package manager"; homepage = "https://nest.pijul.com/dblsaiko/nix-plugin-pijul"; license = lib.licenses.lgpl3Plus; - maintainers = [lib.maintainers.dblsaiko]; + maintainers = [ lib.maintainers.dblsaiko ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/by-name/ni/nix-plugins/package.nix b/pkgs/by-name/ni/nix-plugins/package.nix index 0da1d1d917f28b..bb0c86e7cba68c 100644 --- a/pkgs/by-name/ni/nix-plugins/package.nix +++ b/pkgs/by-name/ni/nix-plugins/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, nix, cmake, pkg-config, boost }: +{ + lib, + stdenv, + fetchFromGitHub, + nix, + cmake, + pkg-config, + boost, +}: stdenv.mkDerivation rec { pname = "nix-plugins"; @@ -11,7 +19,10 @@ stdenv.mkDerivation rec { hash = "sha256-C4VqKHi6nVAHuXVhqvTRRyn0Bb619ez4LzgUWPH1cbM="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ nix diff --git a/pkgs/by-name/ni/nix-prefetch/package.nix b/pkgs/by-name/ni/nix-prefetch/package.nix index 8ed71d078b78cc..25c2bab4565e52 100644 --- a/pkgs/by-name/ni/nix-prefetch/package.nix +++ b/pkgs/by-name/ni/nix-prefetch/package.nix @@ -1,6 +1,23 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, installShellFiles, makeWrapper, asciidoc -, docbook_xml_dtd_45, git, docbook_xsl, libxml2, libxslt, coreutils, gawk -, gnugrep, gnused, jq, nix }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + installShellFiles, + makeWrapper, + asciidoc, + docbook_xml_dtd_45, + git, + docbook_xsl, + libxml2, + libxslt, + coreutils, + gawk, + gnugrep, + gnused, + jq, + nix, +}: stdenv.mkDerivation rec { pname = "nix-prefetch"; @@ -60,7 +77,17 @@ stdenv.mkDerivation rec { install -Dm555 -t $lib src/*.sh install -Dm444 -t $lib lib/* makeWrapper $lib/main.sh $out/bin/${pname} \ - --prefix PATH : ${lib.makeBinPath [ coreutils gawk git gnugrep gnused jq nix ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + gawk + git + gnugrep + gnused + jq + nix + ] + } installManPage doc/nix-prefetch.? diff --git a/pkgs/by-name/ni/nix-query-tree-viewer/package.nix b/pkgs/by-name/ni/nix-query-tree-viewer/package.nix index 8cd6c141cc20c3..391735a2783628 100644 --- a/pkgs/by-name/ni/nix-query-tree-viewer/package.nix +++ b/pkgs/by-name/ni/nix-query-tree-viewer/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, rustPlatform, glib, gtk3, wrapGAppsHook3 }: +{ + lib, + fetchFromGitHub, + rustPlatform, + glib, + gtk3, + wrapGAppsHook3, +}: rustPlatform.buildRustPackage rec { pname = "nix-query-tree-viewer"; @@ -6,7 +13,7 @@ rustPlatform.buildRustPackage rec { src = fetchFromGitHub { owner = "cdepillabout"; - repo = pname; + repo = pname; rev = "v${version}"; sha256 = "sha256-Lc9hfjybnRrkd7PZMa2ojxOM04bP4GJyagkZUX2nVwY="; }; @@ -25,9 +32,9 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "GTK viewer for the output of `nix store --query --tree`"; mainProgram = "nix-query-tree-viewer"; - homepage = "https://github.com/cdepillabout/nix-query-tree-viewer"; - license = with licenses; [ mit ]; + homepage = "https://github.com/cdepillabout/nix-query-tree-viewer"; + license = with licenses; [ mit ]; maintainers = with maintainers; [ cdepillabout ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ni/nix-script/package.nix b/pkgs/by-name/ni/nix-script/package.nix index 2fb9d88b6fc85d..fb811373056f53 100644 --- a/pkgs/by-name/ni/nix-script/package.nix +++ b/pkgs/by-name/ni/nix-script/package.nix @@ -1,18 +1,23 @@ -{ lib, stdenv, haskellPackages, fetchFromGitHub }: +{ + lib, + stdenv, + haskellPackages, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "nix-script"; version = "2020-03-23"; - src = fetchFromGitHub { - owner = "bennofs"; - repo = "nix-script"; - rev = "7706b45429ff22c35bab575734feb2926bf8840b"; + src = fetchFromGitHub { + owner = "bennofs"; + repo = "nix-script"; + rev = "7706b45429ff22c35bab575734feb2926bf8840b"; sha256 = "0yiqljamcj9x8z801bwj7r30sskrwv4rm6sdf39j83jqql1fyq7y"; }; strictDeps = true; - nativeBuildInputs = [ + nativeBuildInputs = [ (haskellPackages.ghcWithPackages (hs: with hs; [ posix-escape ])) ]; @@ -34,9 +39,12 @@ stdenv.mkDerivation { meta = with lib; { description = "Shebang for running inside nix-shell"; - homepage = "https://github.com/bennofs/nix-script"; - license = licenses.bsd3; - maintainers = with maintainers; [ bennofs rnhmjoj ]; - platforms = haskellPackages.ghc.meta.platforms; + homepage = "https://github.com/bennofs/nix-script"; + license = licenses.bsd3; + maintainers = with maintainers; [ + bennofs + rnhmjoj + ]; + platforms = haskellPackages.ghc.meta.platforms; }; } diff --git a/pkgs/by-name/ni/nix-serve/package.nix b/pkgs/by-name/ni/nix-serve/package.nix index e8a0a09300301a..294258cc5b2704 100644 --- a/pkgs/by-name/ni/nix-serve/package.nix +++ b/pkgs/by-name/ni/nix-serve/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, bzip2 -, nixVersions -, makeWrapper -, nixosTests -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + bzip2, + nixVersions, + makeWrapper, + nixosTests, + fetchpatch, }: let @@ -40,12 +41,26 @@ stdenv.mkDerivation { installPhase = '' install -Dm0755 nix-serve.psgi $out/libexec/nix-serve/nix-serve.psgi - makeWrapper ${perl.withPackages(p: [ p.DBDSQLite p.Plack p.Starman nix.perl-bindings ])}/bin/starman $out/bin/nix-serve \ - --prefix PATH : "${lib.makeBinPath [ bzip2 nix ]}" \ + makeWrapper ${ + perl.withPackages (p: [ + p.DBDSQLite + p.Plack + p.Starman + nix.perl-bindings + ]) + }/bin/starman $out/bin/nix-serve \ + --prefix PATH : "${ + lib.makeBinPath [ + bzip2 + nix + ] + }" \ --add-flags $out/libexec/nix-serve/nix-serve.psgi ''; - /** The nix package that nix-serve got its nix perl bindings from. */ + /** + The nix package that nix-serve got its nix perl bindings from. + */ passthru.nix = nix; passthru.tests = { diff --git a/pkgs/by-name/ni/nix-store-gcs-proxy/package.nix b/pkgs/by-name/ni/nix-store-gcs-proxy/package.nix index 6d2633af065170..b44227c1600c66 100644 --- a/pkgs/by-name/ni/nix-store-gcs-proxy/package.nix +++ b/pkgs/by-name/ni/nix-store-gcs-proxy/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "nix-store-gcs-proxy"; version = "0.1.0"; @@ -12,7 +16,10 @@ buildGoModule rec { vendorHash = "sha256-Bm3yFzm2LXOPYWQDk/UBusV0lPfc/BCKIb3pPlWgDFo="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = { description = "HTTP nix store that proxies requests to Google Storage"; @@ -22,4 +29,3 @@ buildGoModule rec { maintainers = with lib.maintainers; [ zimbatm ]; }; } - diff --git a/pkgs/by-name/ni/nix-tour/package.nix b/pkgs/by-name/ni/nix-tour/package.nix index bde9e099a72769..53d9124ff43555 100644 --- a/pkgs/by-name/ni/nix-tour/package.nix +++ b/pkgs/by-name/ni/nix-tour/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, electron -, makeWrapper -, copyDesktopItems -, makeDesktopItem +{ + lib, + stdenv, + fetchFromGitHub, + electron, + makeWrapper, + copyDesktopItems, + makeDesktopItem, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-BhQz59wkwwY0ShXzqUD6MQl4NE/jUik5RbLzseEc5Bc="; }; - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; buildInputs = [ electron ]; installPhase = '' @@ -33,9 +37,11 @@ stdenv.mkDerivation rec { name = pname; desktopName = "Tour of Nix"; genericName = "Tour of Nix"; - comment = - "Interactive programming guide dedicated to the nix programming language"; - categories = [ "Development" "Documentation" ]; + comment = "Interactive programming guide dedicated to the nix programming language"; + categories = [ + "Development" + "Documentation" + ]; exec = "nix-tour"; }) ]; @@ -44,7 +50,10 @@ stdenv.mkDerivation rec { description = "'the tour of nix' from nixcloud.io/tour as offline version"; homepage = "https://nixcloud.io/tour"; license = licenses.gpl2; - maintainers = with maintainers; [ qknight yuu ]; + maintainers = with maintainers; [ + qknight + yuu + ]; mainProgram = "nix-tour"; }; } diff --git a/pkgs/by-name/ni/nix-unit/package.nix b/pkgs/by-name/ni/nix-unit/package.nix index aefeb2d63ec9ba..04c10a01c9ccd2 100644 --- a/pkgs/by-name/ni/nix-unit/package.nix +++ b/pkgs/by-name/ni/nix-unit/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, boost -, clang-tools -, cmake -, difftastic -, makeWrapper -, meson -, ninja -, nixVersions -, nlohmann_json -, pkg-config -, fetchFromGitHub +{ + stdenv, + lib, + boost, + clang-tools, + cmake, + difftastic, + makeWrapper, + meson, + ninja, + nixVersions, + nlohmann_json, + pkg-config, + fetchFromGitHub, }: stdenv.mkDerivation (finalAttrs: { @@ -50,7 +51,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Nix unit test runner"; homepage = "https://github.com/nix-community/nix-unit"; license = lib.licenses.gpl3; - maintainers = with lib.maintainers; [ mic92 adisbladis ]; + maintainers = with lib.maintainers; [ + mic92 + adisbladis + ]; platforms = lib.platforms.unix; mainProgram = "nix-unit"; }; diff --git a/pkgs/by-name/ni/nix-web/package.nix b/pkgs/by-name/ni/nix-web/package.nix index d6bff84c75a658..443ab1f3d5ae05 100644 --- a/pkgs/by-name/ni/nix-web/package.nix +++ b/pkgs/by-name/ni/nix-web/package.nix @@ -1,16 +1,20 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitea -, pkg-config -, openssl -, nixVersions -, nixPackage ? nixVersions.stable -, darwin +{ + lib, + stdenv, + rustPlatform, + fetchFromGitea, + pkg-config, + openssl, + nixVersions, + nixPackage ? nixVersions.stable, + darwin, }: let - cargoFlags = [ "-p" "nix-web" ]; + cargoFlags = [ + "-p" + "nix-web" + ]; in rustPlatform.buildRustPackage rec { pname = "nix-web"; @@ -26,8 +30,15 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-romL/RALr/pmwUA8/SN4AOwc+Vndspd1Yrqs0AHPYRY="; nativeBuildInputs = [ pkg-config ]; - buildInputs = lib.optional (!stdenv.hostPlatform.isDarwin) openssl - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ Security SystemConfiguration ]); + buildInputs = + lib.optional (!stdenv.hostPlatform.isDarwin) openssl + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Security + SystemConfiguration + ] + ); postPatch = '' substituteInPlace nix-web/nix-web.service \ diff --git a/pkgs/by-name/ni/nix-zsh-completions/package.nix b/pkgs/by-name/ni/nix-zsh-completions/package.nix index 2d4edf3d34ba1c..e8a5f05538f814 100644 --- a/pkgs/by-name/ni/nix-zsh-completions/package.nix +++ b/pkgs/by-name/ni/nix-zsh-completions/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "nix-zsh-completions"; @@ -23,6 +27,11 @@ stdenv.mkDerivation rec { description = "ZSH completions for Nix, NixOS, and NixOps"; license = licenses.bsd3; platforms = platforms.all; - maintainers = with maintainers; [ olejorgenb hedning ma27 sebtm ]; + maintainers = with maintainers; [ + olejorgenb + hedning + ma27 + sebtm + ]; }; } diff --git a/pkgs/by-name/ni/nixdoc/package.nix b/pkgs/by-name/ni/nixdoc/package.nix index 70b49237f16131..685848d2b63f18 100644 --- a/pkgs/by-name/ni/nixdoc/package.nix +++ b/pkgs/by-name/ni/nixdoc/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, darwin }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "nixdoc"; @@ -18,12 +24,12 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Generate documentation for Nix functions"; mainProgram = "nixdoc"; - homepage = "https://github.com/nix-community/nixdoc"; - license = [ licenses.gpl3 ]; + homepage = "https://github.com/nix-community/nixdoc"; + license = [ licenses.gpl3 ]; maintainers = with maintainers; [ infinisil hsjobeki ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ni/nixel/package.nix b/pkgs/by-name/ni/nixel/package.nix index 7f9fb9e7234a5c..fcbfbb5b98d014 100644 --- a/pkgs/by-name/ni/nixel/package.nix +++ b/pkgs/by-name/ni/nixel/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, testers -, nixel +{ + lib, + rustPlatform, + fetchFromGitHub, + testers, + nixel, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ni/nixfmt-rfc-style/generated-package.nix b/pkgs/by-name/ni/nixfmt-rfc-style/generated-package.nix index 80ed05f6a11e8d..fef426625f0cb7 100644 --- a/pkgs/by-name/ni/nixfmt-rfc-style/generated-package.nix +++ b/pkgs/by-name/ni/nixfmt-rfc-style/generated-package.nix @@ -1,9 +1,24 @@ # This file has been autogenerate with cabal2nix. # Update via ./update.sh -{ mkDerivation, base, bytestring, cmdargs, directory, fetchzip -, file-embed, filepath, lib, megaparsec, mtl, parser-combinators -, pretty-simple, safe-exceptions, scientific, text, transformers -, unix +{ + mkDerivation, + base, + bytestring, + cmdargs, + directory, + fetchzip, + file-embed, + filepath, + lib, + megaparsec, + mtl, + parser-combinators, + pretty-simple, + safe-exceptions, + scientific, + text, + transformers, + unix, }: mkDerivation { pname = "nixfmt"; @@ -15,12 +30,26 @@ mkDerivation { isLibrary = true; isExecutable = true; libraryHaskellDepends = [ - base megaparsec mtl parser-combinators pretty-simple scientific - text transformers + base + megaparsec + mtl + parser-combinators + pretty-simple + scientific + text + transformers ]; executableHaskellDepends = [ - base bytestring cmdargs directory file-embed filepath - safe-exceptions text transformers unix + base + bytestring + cmdargs + directory + file-embed + filepath + safe-exceptions + text + transformers + unix ]; jailbreak = true; homepage = "https://github.com/NixOS/nixfmt"; diff --git a/pkgs/by-name/ni/nixops-dns/package.nix b/pkgs/by-name/ni/nixops-dns/package.nix index f1a6cacfe1218d..1a3cb7797c4b5c 100644 --- a/pkgs/by-name/ni/nixops-dns/package.nix +++ b/pkgs/by-name/ni/nixops-dns/package.nix @@ -1,6 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "nixops-dns"; @@ -15,13 +17,19 @@ buildGoModule rec { vendorHash = "sha256-3DVNjvW0AAdogpTi3GMnn92FqqOUWNdQvRBityyKwcI="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/museoa/nixops-dns"; description = "DNS server for resolving NixOps machines"; mainProgram = "nixops-dns"; license = licenses.mit; - maintainers = with maintainers; [ kamilchm sorki ]; + maintainers = with maintainers; [ + kamilchm + sorki + ]; }; } diff --git a/pkgs/by-name/ni/nixos-anywhere/package.nix b/pkgs/by-name/ni/nixos-anywhere/package.nix index a4247f5ccb00b2..051992de6746bc 100644 --- a/pkgs/by-name/ni/nixos-anywhere/package.nix +++ b/pkgs/by-name/ni/nixos-anywhere/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, fetchFromGitHub -, openssh -, gitMinimal -, nix -, coreutils -, curl -, gnugrep -, gawk -, findutils -, gnused -, lib -, makeWrapper -, sshpass -, gnutar +{ + stdenv, + fetchFromGitHub, + openssh, + gitMinimal, + nix, + coreutils, + curl, + gnugrep, + gawk, + findutils, + gnused, + lib, + makeWrapper, + sshpass, + gnutar, }: let runtimeDeps = [ @@ -54,6 +55,10 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "nixos-anywhere"; license = licenses.mit; platforms = platforms.all; - maintainers = [ maintainers.mic92 maintainers.lassulus maintainers.phaer ]; + maintainers = [ + maintainers.mic92 + maintainers.lassulus + maintainers.phaer + ]; }; }) diff --git a/pkgs/by-name/ni/nixos-bgrt-plymouth/package.nix b/pkgs/by-name/ni/nixos-bgrt-plymouth/package.nix index 009773b7fa2577..1529df96ebeafd 100644 --- a/pkgs/by-name/ni/nixos-bgrt-plymouth/package.nix +++ b/pkgs/by-name/ni/nixos-bgrt-plymouth/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + unstableGitUpdater, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ni/nixos-build-vms/build-vms.nix b/pkgs/by-name/ni/nixos-build-vms/build-vms.nix index 12b3c44746a405..710e712bd2420c 100644 --- a/pkgs/by-name/ni/nixos-build-vms/build-vms.nix +++ b/pkgs/by-name/ni/nixos-build-vms/build-vms.nix @@ -1,7 +1,8 @@ -{ system ? builtins.currentSystem -, config ? {} -, nixpkgs -, networkExpr +{ + system ? builtins.currentSystem, + config ? { }, + nixpkgs, + networkExpr, }: let @@ -16,10 +17,14 @@ let inherit system pkgs; }; - interactiveDriver = (testing.makeTest { inherit nodes; name = "network"; testScript = "start_all(); join_all();"; }).test.driverInteractive; + interactiveDriver = + (testing.makeTest { + inherit nodes; + name = "network"; + testScript = "start_all(); join_all();"; + }).test.driverInteractive; in - pkgs.runCommand "nixos-build-vms" { nativeBuildInputs = [ pkgs.makeWrapper ]; } '' mkdir -p $out/bin ln -s ${interactiveDriver}/bin/nixos-test-driver $out/bin/nixos-test-driver diff --git a/pkgs/by-name/ni/nixos-firewall-tool/package.nix b/pkgs/by-name/ni/nixos-firewall-tool/package.nix index b5db510822665d..eb05154124e754 100644 --- a/pkgs/by-name/ni/nixos-firewall-tool/package.nix +++ b/pkgs/by-name/ni/nixos-firewall-tool/package.nix @@ -8,6 +8,10 @@ writeShellApplication { meta = with lib; { description = "Temporarily manipulate the NixOS firewall"; license = licenses.mit; - maintainers = with maintainers; [ clerie rvfg garyguo ]; + maintainers = with maintainers; [ + clerie + rvfg + garyguo + ]; }; } diff --git a/pkgs/by-name/ni/nixos-generators/package.nix b/pkgs/by-name/ni/nixos-generators/package.nix index b4d3581a0ebc0f..eef7650ffb92c3 100644 --- a/pkgs/by-name/ni/nixos-generators/package.nix +++ b/pkgs/by-name/ni/nixos-generators/package.nix @@ -1,4 +1,14 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper, coreutils, jq, findutils, nix, bash }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + coreutils, + jq, + findutils, + nix, + bash, +}: stdenv.mkDerivation rec { pname = "nixos-generators"; @@ -15,15 +25,22 @@ stdenv.mkDerivation rec { installFlags = [ "PREFIX=$(out)" ]; postFixup = '' wrapProgram $out/bin/nixos-generate \ - --prefix PATH : ${lib.makeBinPath [ jq coreutils findutils nix ] } + --prefix PATH : ${ + lib.makeBinPath [ + jq + coreutils + findutils + nix + ] + } ''; meta = with lib; { description = "Collection of image builders"; - homepage = "https://github.com/nix-community/nixos-generators"; - license = licenses.mit; + homepage = "https://github.com/nix-community/nixos-generators"; + license = licenses.mit; maintainers = with maintainers; [ lassulus ]; mainProgram = "nixos-generate"; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ni/nixos-install-tools/package.nix b/pkgs/by-name/ni/nixos-install-tools/package.nix index cef57884ab6f43..853c4d718e380d 100644 --- a/pkgs/by-name/ni/nixos-install-tools/package.nix +++ b/pkgs/by-name/ni/nixos-install-tools/package.nix @@ -13,7 +13,7 @@ binlore, }: let - inherit (nixos {}) config; + inherit (nixos { }) config; version = config.system.nixos.version; in (buildEnv { @@ -25,7 +25,7 @@ in inherit (config.system.build.manual) nixos-configuration-reference-manpage; }; - extraOutputsToInstall = ["man"]; + extraOutputsToInstall = [ "man" ]; meta = { description = "The essential commands from the NixOS installer as a package"; @@ -43,26 +43,29 @@ in passthru.tests = { nixos-tests = lib.recurseIntoAttrs nixosTests.installer; - nixos-install-help = runCommand "test-nixos-install-help" { - nativeBuildInputs = [ - man - nixos-install-tools - ]; - meta.description = '' - Make sure that --help works. It's somewhat non-trivial because it - requires man. - ''; - } '' - nixos-install --help | grep -F 'NixOS Reference Pages' - nixos-install --help | grep -F 'configuration.nix' - nixos-generate-config --help | grep -F 'NixOS Reference Pages' - nixos-generate-config --help | grep -F 'hardware-configuration.nix' + nixos-install-help = + runCommand "test-nixos-install-help" + { + nativeBuildInputs = [ + man + nixos-install-tools + ]; + meta.description = '' + Make sure that --help works. It's somewhat non-trivial because it + requires man. + ''; + } + '' + nixos-install --help | grep -F 'NixOS Reference Pages' + nixos-install --help | grep -F 'configuration.nix' + nixos-generate-config --help | grep -F 'NixOS Reference Pages' + nixos-generate-config --help | grep -F 'hardware-configuration.nix' - # FIXME: Tries to call unshare, which it must not do for --help - # nixos-enter --help | grep -F 'NixOS Reference Pages' + # FIXME: Tries to call unshare, which it must not do for --help + # nixos-enter --help | grep -F 'NixOS Reference Pages' - touch $out - ''; + touch $out + ''; }; # no documented flags show signs of exec; skim of source suggests @@ -70,7 +73,8 @@ in passthru.binlore.out = binlore.synthesize nixos-install-tools '' execer cannot bin/nixos-generate-config ''; -}).overrideAttrs { - inherit version; - pname = "nixos-install-tools"; -} +}).overrideAttrs + { + inherit version; + pname = "nixos-install-tools"; + } diff --git a/pkgs/by-name/ni/nixos-render-docs/package.nix b/pkgs/by-name/ni/nixos-render-docs/package.nix index 956e0fcfc6e09f..9e58c3561c16a2 100644 --- a/pkgs/by-name/ni/nixos-render-docs/package.nix +++ b/pkgs/by-name/ni/nixos-render-docs/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, runCommand +{ + lib, + python3, + runCommand, }: let @@ -23,16 +24,17 @@ python.pkgs.buildPythonApplication rec { format = "pyproject"; src = lib.cleanSourceWith { - filter = name: type: + filter = + name: type: lib.cleanSourceFilter name type - && ! (type == "directory" - && builtins.elem - (baseNameOf name) - [ - ".pytest_cache" - ".mypy_cache" - "__pycache__" - ]); + && !( + type == "directory" + && builtins.elem (baseNameOf name) [ + ".pytest_cache" + ".mypy_cache" + "__pycache__" + ] + ); src = ./src; }; @@ -46,18 +48,31 @@ python.pkgs.buildPythonApplication rec { mdit-py-plugins ]; - pytestFlagsArray = [ "-vvrP" "tests/" ]; + pytestFlagsArray = [ + "-vvrP" + "tests/" + ]; # NOTE this is a CI test rather than a build-time test because we want to keep the # build closures small. mypy has an unreasonably large build closure for docs builds. - passthru.tests.typing = runCommand "${pname}-mypy" { - nativeBuildInputs = [ - (python3.withPackages (ps: with ps; [ mypy pytest markdown-it-py mdit-py-plugins ])) - ]; - } '' - mypy --strict ${src} - touch $out - ''; + passthru.tests.typing = + runCommand "${pname}-mypy" + { + nativeBuildInputs = [ + (python3.withPackages ( + ps: with ps; [ + mypy + pytest + markdown-it-py + mdit-py-plugins + ] + )) + ]; + } + '' + mypy --strict ${src} + touch $out + ''; meta = with lib; { description = "Renderer for NixOS manual and option docs"; diff --git a/pkgs/by-name/ni/nixos-shell/package.nix b/pkgs/by-name/ni/nixos-shell/package.nix index 18c49fe79ede99..b41ee3f470556c 100644 --- a/pkgs/by-name/ni/nixos-shell/package.nix +++ b/pkgs/by-name/ni/nixos-shell/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, nix, jq, fetchFromGitHub, makeWrapper }: +{ + lib, + stdenv, + nix, + jq, + fetchFromGitHub, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "nixos-shell"; @@ -15,7 +22,12 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/nixos-shell \ - --prefix PATH : ${lib.makeBinPath [ nix jq ]} + --prefix PATH : ${ + lib.makeBinPath [ + nix + jq + ] + } ''; installFlags = [ "PREFIX=${placeholder "out"}" ]; diff --git a/pkgs/by-name/ni/nixpacks/package.nix b/pkgs/by-name/ni/nixpacks/package.nix index 9a210cf2eeb578..48d3141cfe3070 100644 --- a/pkgs/by-name/ni/nixpacks/package.nix +++ b/pkgs/by-name/ni/nixpacks/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "nixpacks"; diff --git a/pkgs/by-name/ni/nixpkgs-fmt/package.nix b/pkgs/by-name/ni/nixpkgs-fmt/package.nix index e1d329acc699e5..16f62c1253545c 100644 --- a/pkgs/by-name/ni/nixpkgs-fmt/package.nix +++ b/pkgs/by-name/ni/nixpkgs-fmt/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "nixpkgs-fmt"; version = "1.3.0"; diff --git a/pkgs/by-name/ni/nixpkgs-hammering/package.nix b/pkgs/by-name/ni/nixpkgs-hammering/package.nix index 1ce398f9178036..088ae8425db7ac 100644 --- a/pkgs/by-name/ni/nixpkgs-hammering/package.nix +++ b/pkgs/by-name/ni/nixpkgs-hammering/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, stdenv -, makeWrapper -, python3 -, nix -, unstableGitUpdater +{ + lib, + fetchFromGitHub, + rustPlatform, + stdenv, + makeWrapper, + python3, + nix, + unstableGitUpdater, }: let @@ -49,7 +50,12 @@ stdenv.mkDerivation { install -Dt $out/bin tools/nixpkgs-hammer wrapProgram $out/bin/nixpkgs-hammer \ - --prefix PATH : ${lib.makeBinPath [ nix rust-checks ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + nix + rust-checks + ] + } \ --set AST_CHECK_NAMES ''${AST_CHECK_NAMES%:} cp -r lib overlays $out diff --git a/pkgs/by-name/ni/nixpkgs-lint-community/package.nix b/pkgs/by-name/ni/nixpkgs-lint-community/package.nix index 1bfad00a3fe9e6..10fdb18ec7c742 100644 --- a/pkgs/by-name/ni/nixpkgs-lint-community/package.nix +++ b/pkgs/by-name/ni/nixpkgs-lint-community/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -22,6 +23,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/nix-community/nixpkgs-lint"; changelog = "https://github.com/nix-community/nixpkgs-lint/releases/tag/${src.rev}"; license = licenses.mit; - maintainers = with maintainers; [ artturin figsoda ]; + maintainers = with maintainers; [ + artturin + figsoda + ]; }; } diff --git a/pkgs/by-name/ni/nixpkgs-review/package.nix b/pkgs/by-name/ni/nixpkgs-review/package.nix index e7aebeff6093df..4d7743f0aece24 100644 --- a/pkgs/by-name/ni/nixpkgs-review/package.nix +++ b/pkgs/by-name/ni/nixpkgs-review/package.nix @@ -46,10 +46,13 @@ python3Packages.buildPythonApplication rec { makeWrapperArgs = let - binPath = [ - nix - git - ] ++ lib.optional withSandboxSupport bubblewrap ++ lib.optional withNom nix-output-monitor; + binPath = + [ + nix + git + ] + ++ lib.optional withSandboxSupport bubblewrap + ++ lib.optional withNom nix-output-monitor; in [ "--prefix PATH : ${lib.makeBinPath binPath}" diff --git a/pkgs/by-name/ni/nixseparatedebuginfod/package.nix b/pkgs/by-name/ni/nixseparatedebuginfod/package.nix index ffd82b832032d6..6015405f3ec627 100644 --- a/pkgs/by-name/ni/nixseparatedebuginfod/package.nix +++ b/pkgs/by-name/ni/nixseparatedebuginfod/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, libarchive -, openssl -, rust-jemalloc-sys -, sqlite -, pkg-config -, nixosTests +{ + lib, + fetchFromGitHub, + rustPlatform, + libarchive, + openssl, + rust-jemalloc-sys, + sqlite, + pkg-config, + nixosTests, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/nj/njam/package.nix b/pkgs/by-name/nj/njam/package.nix index 8fce2a1ca8cdad..ab96bc160e7c8d 100644 --- a/pkgs/by-name/nj/njam/package.nix +++ b/pkgs/by-name/nj/njam/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchurl, SDL, SDL_image, SDL_mixer, SDL_net }: +{ + lib, + stdenv, + fetchurl, + SDL, + SDL_image, + SDL_mixer, + SDL_net, +}: stdenv.mkDerivation rec { pname = "njam"; @@ -13,7 +21,12 @@ stdenv.mkDerivation rec { rm src/*.o ''; - buildInputs = [ SDL SDL_image SDL_mixer SDL_net ]; + buildInputs = [ + SDL + SDL_image + SDL_mixer + SDL_net + ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/nk/nkeys/package.nix b/pkgs/by-name/nk/nkeys/package.nix index 7dc25358a83a2e..835d5f039a75ef 100644 --- a/pkgs/by-name/nk/nkeys/package.nix +++ b/pkgs/by-name/nk/nkeys/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/nk/nkf/package.nix b/pkgs/by-name/nk/nkf/package.nix index ae51ad37243b03..dfe70aff968ef2 100644 --- a/pkgs/by-name/nk/nkf/package.nix +++ b/pkgs/by-name/nk/nkf/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "nkf"; diff --git a/pkgs/by-name/nl/nload/package.nix b/pkgs/by-name/nl/nload/package.nix index 3f97981528f5f8..e7b22ce59db23f 100644 --- a/pkgs/by-name/nl/nload/package.nix +++ b/pkgs/by-name/nl/nload/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, fetchpatch, ncurses, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + ncurses, + autoreconfHook, +}: stdenv.mkDerivation rec { version = "0.7.4"; diff --git a/pkgs/by-name/nl/nlohmann_json/package.nix b/pkgs/by-name/nl/nlohmann_json/package.nix index d690cc45b2f925..a9bac354d3e1d8 100644 --- a/pkgs/by-name/nl/nlohmann_json/package.nix +++ b/pkgs/by-name/nl/nlohmann_json/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake +{ + stdenv, + lib, + fetchFromGitHub, + cmake, }: let testData = fetchFromGitHub { @@ -10,7 +11,8 @@ let rev = "v3.1.0"; hash = "sha256-bG34W63ew7haLnC82A3lS7bviPDnApLipaBjJAjLcVk="; }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "nlohmann_json"; version = "3.11.3"; diff --git a/pkgs/by-name/nl/nlohmann_json_schema_validator/package.nix b/pkgs/by-name/nl/nlohmann_json_schema_validator/package.nix index a6317b1f7b288e..23498cb57ad80c 100644 --- a/pkgs/by-name/nl/nlohmann_json_schema_validator/package.nix +++ b/pkgs/by-name/nl/nlohmann_json_schema_validator/package.nix @@ -1,14 +1,18 @@ -{ stdenv -, lib -, fetchFromGitHub -, nlohmann_json -, cmake +{ + stdenv, + lib, + fetchFromGitHub, + nlohmann_json, + cmake, }: stdenv.mkDerivation (finalAttrs: { pname = "nlohmann_json_schema_validator"; version = "2.3.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "pboettch"; diff --git a/pkgs/by-name/nl/nlojet/package.nix b/pkgs/by-name/nl/nlojet/package.nix index 6085906758b07b..501e80f2ddd8ca 100644 --- a/pkgs/by-name/nl/nlojet/package.nix +++ b/pkgs/by-name/nl/nlojet/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "nlojet++"; @@ -13,16 +17,18 @@ stdenv.mkDerivation rec { ./nlojet_clang_fix.patch ]; - env.CXXFLAGS="-std=c++11"; + env.CXXFLAGS = "-std=c++11"; # error: no member named 'finite' in the global namespace; did you mean simply 'finite'? - env.NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) "-Dfinite=isfinite"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 + ) "-Dfinite=isfinite"; meta = { - homepage = "http://www.desy.de/~znagy/Site/NLOJet++.html"; - license = lib.licenses.gpl2; + homepage = "http://www.desy.de/~znagy/Site/NLOJet++.html"; + license = lib.licenses.gpl2; description = "Implementation of calculation of the hadron jet cross sections"; - platforms = lib.platforms.unix; + platforms = lib.platforms.unix; maintainers = with lib.maintainers; [ veprbl ]; }; } diff --git a/pkgs/by-name/nl/nls/package.nix b/pkgs/by-name/nl/nls/package.nix index 0132b35be6884c..961acbd300e5be 100644 --- a/pkgs/by-name/nl/nls/package.nix +++ b/pkgs/by-name/nl/nls/package.nix @@ -1,5 +1,6 @@ -{ symlinkJoin -, nickel +{ + symlinkJoin, + nickel, }: symlinkJoin { @@ -10,7 +11,12 @@ symlinkJoin { paths = [ nickel.nls ]; meta = { - inherit (nickel.meta) homepage changelog license maintainers; + inherit (nickel.meta) + homepage + changelog + license + maintainers + ; description = "Language server for the Nickel programming language"; mainProgram = "nls"; longDescription = '' diff --git a/pkgs/by-name/nm/nmap-formatter/package.nix b/pkgs/by-name/nm/nmap-formatter/package.nix index 173514c7fd0be4..b9ae0d0ae4d713 100644 --- a/pkgs/by-name/nm/nmap-formatter/package.nix +++ b/pkgs/by-name/nm/nmap-formatter/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/nm/nmap-parse/package.nix b/pkgs/by-name/nm/nmap-parse/package.nix index 7a8ab044377f76..5ff2677d3d773b 100644 --- a/pkgs/by-name/nm/nmap-parse/package.nix +++ b/pkgs/by-name/nm/nmap-parse/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/nm/nmh/package.nix b/pkgs/by-name/nm/nmh/package.nix index e32da2708a5b45..0eebc1cb85e023 100644 --- a/pkgs/by-name/nm/nmh/package.nix +++ b/pkgs/by-name/nm/nmh/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, autoreconfHook -, bison -, coreutils -, cyrus_sasl -, db -, fetchFromSavannah -, flex -, gdbm -, liblockfile -, ncurses -, openssl -, readline -, runtimeShell +{ + lib, + stdenv, + autoreconfHook, + bison, + coreutils, + cyrus_sasl, + db, + fetchFromSavannah, + flex, + gdbm, + liblockfile, + ncurses, + openssl, + readline, + runtimeShell, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/nm/nmon/package.nix b/pkgs/by-name/nm/nmon/package.nix index 3de22bfae6d76f..c142a8ec3281a9 100644 --- a/pkgs/by-name/nm/nmon/package.nix +++ b/pkgs/by-name/nm/nmon/package.nix @@ -1,4 +1,9 @@ -{ fetchurl, lib, stdenv, ncurses }: +{ + fetchurl, + lib, + stdenv, + ncurses, +}: stdenv.mkDerivation rec { pname = "nmon"; @@ -13,10 +18,14 @@ stdenv.mkDerivation rec { dontUnpack = true; buildPhase = "${stdenv.cc.targetPrefix}cc -o nmon ${src} -g -O2 -D JFS -D GETUSER -Wall -D LARGEMEM -lncurses -lm -g -D ${ with stdenv.hostPlatform; - if isx86 then "X86" - else if isAarch then "ARM" - else if isPower then "POWER" - else "UNKNOWN" + if isx86 then + "X86" + else if isAarch then + "ARM" + else if isPower then + "POWER" + else + "UNKNOWN" }"; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/nm/nmrpflash/package.nix b/pkgs/by-name/nm/nmrpflash/package.nix index 90a8b1e6feb795..323bcd43fe5802 100644 --- a/pkgs/by-name/nm/nmrpflash/package.nix +++ b/pkgs/by-name/nm/nmrpflash/package.nix @@ -1,9 +1,10 @@ -{ fetchFromGitHub -, lib -, libnl -, libpcap -, pkg-config -, stdenv +{ + fetchFromGitHub, + lib, + libnl, + libpcap, + pkg-config, + stdenv, }: stdenv.mkDerivation rec { pname = "nmrpflash"; @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libnl libpcap ]; + buildInputs = [ + libnl + libpcap + ]; PREFIX = "${placeholder "out"}"; STANDALONE_VERSION = version; diff --git a/pkgs/by-name/nm/nms/package.nix b/pkgs/by-name/nm/nms/package.nix index cf890dc4495626..f7ddc9cfb86c50 100644 --- a/pkgs/by-name/nm/nms/package.nix +++ b/pkgs/by-name/nm/nms/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "nms"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-QVCEpplsZCSQ+Fq1LBtCuPBvnzgLsmLcSrxR+e4nA5I="; }; - buildFlags = [ "nms" "sneakers" ]; + buildFlags = [ + "nms" + "sneakers" + ]; installFlags = [ "prefix=$(out)" ]; meta = with lib; { diff --git a/pkgs/by-name/nn/nncp/package.nix b/pkgs/by-name/nn/nncp/package.nix index bbacef76fbb02e..e02a4421dcd0f3 100644 --- a/pkgs/by-name/nn/nncp/package.nix +++ b/pkgs/by-name/nn/nncp/package.nix @@ -1,18 +1,23 @@ -{ cfgPath ? "/etc/nncp.hjson" -, curl -, fetchurl -, lib -, genericUpdater -, go -, perl -, stdenv -, writeShellScript +{ + cfgPath ? "/etc/nncp.hjson", + curl, + fetchurl, + lib, + genericUpdater, + go, + perl, + stdenv, + writeShellScript, }: stdenv.mkDerivation (finalAttrs: { pname = "nncp"; version = "8.11.0"; - outputs = [ "out" "doc" "info" ]; + outputs = [ + "out" + "doc" + "info" + ]; src = fetchurl { url = "http://www.nncpgo.org/download/nncp-${finalAttrs.version}.tar.xz"; @@ -71,7 +76,10 @@ stdenv.mkDerivation (finalAttrs: { support. But online TCP daemon with full-duplex resumable data transmission exists. ''; - maintainers = with lib.maintainers; [ ehmry woffs ]; + maintainers = with lib.maintainers; [ + ehmry + woffs + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/by-name/nn/nng/package.nix b/pkgs/by-name/nn/nng/package.nix index 9016424d4b3032..a10611f3a89a94 100644 --- a/pkgs/by-name/nn/nng/package.nix +++ b/pkgs/by-name/nn/nng/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, ninja, mbedtlsSupport ? true, mbedtls }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + mbedtlsSupport ? true, + mbedtls, +}: stdenv.mkDerivation rec { pname = "nng"; @@ -11,13 +19,19 @@ stdenv.mkDerivation rec { hash = "sha256-N1ZMILrFhdkwU4PK/zlSCgGjOm0748fgvZRrk7I9YVg="; }; - nativeBuildInputs = [ cmake ninja ] - ++ lib.optionals mbedtlsSupport [ mbedtls ]; + nativeBuildInputs = [ + cmake + ninja + ] ++ lib.optionals mbedtlsSupport [ mbedtls ]; buildInputs = lib.optionals mbedtlsSupport [ mbedtls ]; - cmakeFlags = [ "-G Ninja" ] - ++ lib.optionals mbedtlsSupport [ "-DMBEDTLS_ROOT_DIR=${mbedtls}" "-DNNG_ENABLE_TLS=ON" ]; + cmakeFlags = + [ "-G Ninja" ] + ++ lib.optionals mbedtlsSupport [ + "-DMBEDTLS_ROOT_DIR=${mbedtls}" + "-DNNG_ENABLE_TLS=ON" + ]; meta = with lib; { homepage = "https://nng.nanomsg.org/"; diff --git a/pkgs/by-name/nn/nnn/package.nix b/pkgs/by-name/nn/nnn/package.nix index 39f69c62b2b84d..9e8a0467b3d8da 100644 --- a/pkgs/by-name/nn/nnn/package.nix +++ b/pkgs/by-name/nn/nnn/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles -, makeWrapper -, pkg-config -, file -, ncurses -, readline -, which -, musl-fts -, pcre -, gnused +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + makeWrapper, + pkg-config, + file, + ncurses, + readline, + which, + musl-fts, + pcre, + gnused, # options -, conf ? null -, withIcons ? false -, withNerdIcons ? false -, withEmojis ? false -, withPcre ? false -, extraMakeFlags ? [ ] + conf ? null, + withIcons ? false, + withNerdIcons ? false, + withEmojis ? false, + withPcre ? false, + extraMakeFlags ? [ ], }: # Mutually exclusive options @@ -46,24 +47,40 @@ stdenv.mkDerivation (finalAttrs: { configFile = lib.optionalString (conf != null) (builtins.toFile "nnn.h" conf); preBuild = lib.optionalString (conf != null) "cp ${finalAttrs.configFile} src/nnn.h"; - nativeBuildInputs = [ installShellFiles makeWrapper pkg-config ]; - buildInputs = [ readline ncurses ] + nativeBuildInputs = [ + installShellFiles + makeWrapper + pkg-config + ]; + buildInputs = + [ + readline + ncurses + ] ++ lib.optional stdenv.hostPlatform.isMusl musl-fts ++ lib.optional withPcre pcre; env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isMusl "-I${musl-fts}/include"; NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isMusl "-lfts"; - makeFlags = [ "PREFIX=$(out)" ] + makeFlags = + [ "PREFIX=$(out)" ] ++ lib.optionals withIcons [ "O_ICONS=1" ] ++ lib.optionals withNerdIcons [ "O_NERD=1" ] ++ lib.optionals withEmojis [ "O_EMOJI=1" ] ++ lib.optionals withPcre [ "O_PCRE=1" ] ++ extraMakeFlags; - binPath = lib.makeBinPath [ file which gnused ]; + binPath = lib.makeBinPath [ + file + which + gnused + ]; - installTargets = [ "install" "install-desktop" ]; + installTargets = [ + "install" + "install-desktop" + ]; postInstall = '' installShellCompletion --bash --name nnn.bash misc/auto-completion/bash/nnn-completion.bash diff --git a/pkgs/by-name/nn/nnpdf/package.nix b/pkgs/by-name/nn/nnpdf/package.nix index c1de306e6bf050..83ec6b718466a8 100644 --- a/pkgs/by-name/nn/nnpdf/package.nix +++ b/pkgs/by-name/nn/nnpdf/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, apfel -, gsl -, lhapdf -, libarchive -, yaml-cpp -, python3 -, sqlite -, swig +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + apfel, + gsl, + lhapdf, + libarchive, + yaml-cpp, + python3, + sqlite, + swig, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/nn/nntp-proxy/package.nix b/pkgs/by-name/nn/nntp-proxy/package.nix index 05c8263f436bb8..48c5bc78edf1ea 100644 --- a/pkgs/by-name/nn/nntp-proxy/package.nix +++ b/pkgs/by-name/nn/nntp-proxy/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, libconfig, pkg-config, libevent, openssl, libxcrypt }: +{ + lib, + stdenv, + fetchFromGitHub, + libconfig, + pkg-config, + libevent, + openssl, + libxcrypt, +}: stdenv.mkDerivation { pname = "nntp-proxy"; @@ -12,7 +21,12 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libconfig libevent openssl libxcrypt ]; + buildInputs = [ + libconfig + libevent + openssl + libxcrypt + ]; installFlags = [ "INSTALL_DIR=$(out)/bin/" ]; diff --git a/pkgs/by-name/no/noaa-apt/package.nix b/pkgs/by-name/no/noaa-apt/package.nix index 65024c24b00ebd..be1690fbce7aed 100644 --- a/pkgs/by-name/no/noaa-apt/package.nix +++ b/pkgs/by-name/no/noaa-apt/package.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, atk -, cairo -, gdk-pixbuf -, glib -, gtk3 -, openssl -, pango +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + atk, + cairo, + gdk-pixbuf, + glib, + gtk3, + openssl, + pango, }: rustPlatform.buildRustPackage rec { @@ -63,7 +64,10 @@ rustPlatform.buildRustPackage rec { description = "NOAA APT image decoder"; homepage = "https://noaa-apt.mbernardi.com.ar/"; license = licenses.gpl3Only; - maintainers = with maintainers; [ trepetti tmarkus ]; + maintainers = with maintainers; [ + trepetti + tmarkus + ]; platforms = platforms.all; changelog = "https://github.com/martinber/noaa-apt/releases/tag/v${version}"; mainProgram = "noaa-apt"; diff --git a/pkgs/by-name/no/node-glob/package.nix b/pkgs/by-name/no/node-glob/package.nix index 74013b27b3059f..fb26994e1aff33 100644 --- a/pkgs/by-name/no/node-glob/package.nix +++ b/pkgs/by-name/no/node-glob/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/no/node-hp-scan-to/package.nix b/pkgs/by-name/no/node-hp-scan-to/package.nix index 86498d2b7fd52c..f348b5011935b3 100644 --- a/pkgs/by-name/no/node-hp-scan-to/package.nix +++ b/pkgs/by-name/no/node-hp-scan-to/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, makeWrapper -, nodejs -, fixup-yarn-lock -, yarn +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + makeWrapper, + nodejs, + fixup-yarn-lock, + yarn, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/no/node-manta/package.nix b/pkgs/by-name/no/node-manta/package.nix index ef0d92150360b7..a096217d73de43 100644 --- a/pkgs/by-name/no/node-manta/package.nix +++ b/pkgs/by-name/no/node-manta/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, installShellFiles -, testers -, node-manta +{ + lib, + buildNpmPackage, + fetchFromGitHub, + installShellFiles, + testers, + node-manta, }: buildNpmPackage rec { diff --git a/pkgs/by-name/no/node-problem-detector/package.nix b/pkgs/by-name/no/node-problem-detector/package.nix index 21a7d60638eef6..16e23d8310d6c3 100644 --- a/pkgs/by-name/no/node-problem-detector/package.nix +++ b/pkgs/by-name/no/node-problem-detector/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, systemd }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + systemd, +}: buildGoModule rec { pname = "node-problem-detector"; @@ -19,8 +25,9 @@ buildGoModule rec { # The binary is dynamically linked against systemd libraries, making it a # Linux-only feature. See 'ENABLE_JOURNALD' upstream: # https://github.com/kubernetes/node-problem-detector/blob/master/Makefile - subPackages = [ "cmd/nodeproblemdetector" ] ++ - lib.optionals stdenv.hostPlatform.isLinux [ "cmd/logcounter" ]; + subPackages = [ + "cmd/nodeproblemdetector" + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ "cmd/logcounter" ]; preBuild = '' export CGO_ENABLED=${if stdenv.hostPlatform.isLinux then "1" else "0"} diff --git a/pkgs/by-name/no/nodehun/package.nix b/pkgs/by-name/no/nodehun/package.nix index 5bc067085ed8f4..36426f03ea8320 100644 --- a/pkgs/by-name/no/nodehun/package.nix +++ b/pkgs/by-name/no/nodehun/package.nix @@ -1,12 +1,13 @@ -{ buildNpmPackage -, cctools -, darwin -, fetchFromGitHub -, lib -, node-gyp -, nodejs -, python3 -, stdenv +{ + buildNpmPackage, + cctools, + darwin, + fetchFromGitHub, + lib, + node-gyp, + nodejs, + python3, + stdenv, }: buildNpmPackage { @@ -30,9 +31,13 @@ buildNpmPackage { npmDepsHash = "sha256-mV6rWNf2p2w4H0ESUT0/Ybtx9YEdvO5l2gCvlWFXK+U="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.CoreServices ]; - nativeBuildInputs = [ node-gyp python3 ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreServices + ]; + nativeBuildInputs = [ + node-gyp + python3 + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools ]; postInstall = '' # Only keep the necessary parts of build/Release to reduce closure size diff --git a/pkgs/by-name/no/nodenv/package.nix b/pkgs/by-name/no/nodenv/package.nix index 3eb045c5e9a924..89c6a6a89aa2ef 100644 --- a/pkgs/by-name/no/nodenv/package.nix +++ b/pkgs/by-name/no/nodenv/package.nix @@ -1,6 +1,7 @@ -{ stdenv -, lib -, fetchFromGitHub +{ + stdenv, + lib, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/no/nofi/package.nix b/pkgs/by-name/no/nofi/package.nix index 688c8c397d42ba..4c1cba5dfeaca0 100644 --- a/pkgs/by-name/no/nofi/package.nix +++ b/pkgs/by-name/no/nofi/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, dbus, pkg-config}: +{ + lib, + rustPlatform, + fetchFromGitHub, + dbus, + pkg-config, +}: rustPlatform.buildRustPackage rec { pname = "nofi"; @@ -20,7 +26,10 @@ rustPlatform.buildRustPackage rec { description = "Interruption-free notification system for Linux"; homepage = "https://github.com/ellsclytn/nofi/"; changelog = "https://github.com/ellsclytn/nofi/raw/v${version}/CHANGELOG.md"; - license = [ licenses.asl20 /* or */ licenses.mit ]; + license = [ + licenses.asl20 # or + licenses.mit + ]; mainProgram = "nofi"; maintainers = [ maintainers.magnetophon ]; }; diff --git a/pkgs/by-name/no/noice/package.nix b/pkgs/by-name/no/noice/package.nix index 7421a3816d2920..90ace4c43e4710 100644 --- a/pkgs/by-name/no/noice/package.nix +++ b/pkgs/by-name/no/noice/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchgit, ncurses, conf ? null }: +{ + lib, + stdenv, + fetchgit, + ncurses, + conf ? null, +}: stdenv.mkDerivation rec { pname = "noice"; @@ -16,14 +22,17 @@ stdenv.mkDerivation rec { substituteInPlace noice.c --replace 'printw(str);' 'printw("%s", str);' ''; - configFile = lib.optionalString (conf!=null) (builtins.toFile "config.def.h" conf); - preBuild = lib.optionalString (conf!=null) "cp ${configFile} config.def.h"; + configFile = lib.optionalString (conf != null) (builtins.toFile "config.def.h" conf); + preBuild = lib.optionalString (conf != null) "cp ${configFile} config.def.h"; buildInputs = [ ncurses ]; buildFlags = [ "LDLIBS=-lncurses" ]; - installFlags = [ "DESTDIR=$(out)" "PREFIX=" ]; + installFlags = [ + "DESTDIR=$(out)" + "PREFIX=" + ]; meta = with lib; { description = "Small ncurses-based file browser"; diff --git a/pkgs/by-name/no/noip/package.nix b/pkgs/by-name/no/noip/package.nix index d71cbcec507af2..a2eb079990ff25 100644 --- a/pkgs/by-name/no/noip/package.nix +++ b/pkgs/by-name/no/noip/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "noip"; @@ -10,11 +14,10 @@ stdenv.mkDerivation { }; makeFlags = [ "PREFIX=\${out}" ]; - installPhase = - '' - mkdir -p $out/bin - cp noip2 $out/bin - ''; + installPhase = '' + mkdir -p $out/bin + cp noip2 $out/bin + ''; enableParallelBuilding = true; diff --git a/pkgs/by-name/no/noise-repellent/package.nix b/pkgs/by-name/no/noise-repellent/package.nix index d1860141ebb316..c02b2a565d9d01 100644 --- a/pkgs/by-name/no/noise-repellent/package.nix +++ b/pkgs/by-name/no/noise-repellent/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, pkg-config, cmake, libspecbleach, lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + cmake, + libspecbleach, + lv2, +}: stdenv.mkDerivation rec { pname = "noise-repellent"; @@ -16,15 +26,21 @@ stdenv.mkDerivation rec { "--buildtype=release" ]; - nativeBuildInputs = [ meson ninja pkg-config cmake ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + cmake + ]; buildInputs = [ - libspecbleach lv2 + libspecbleach + lv2 ]; meta = with lib; { description = "LV2 plugin for broadband noise reduction"; - homepage = "https://github.com/lucianodato/noise-repellent"; - license = licenses.gpl3; + homepage = "https://github.com/lucianodato/noise-repellent"; + license = licenses.gpl3; maintainers = [ maintainers.magnetophon ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/no/noisetorch/package.nix b/pkgs/by-name/no/noisetorch/package.nix index 5f3dfc7bf8fd97..6399aa99ddb4a5 100644 --- a/pkgs/by-name/no/noisetorch/package.nix +++ b/pkgs/by-name/no/noisetorch/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "NoiseTorch"; @@ -16,7 +20,12 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X main.version=${version}" "-X main.distribution=nixpkgs" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + "-X main.distribution=nixpkgs" + ]; subPackages = [ "." ]; @@ -36,7 +45,10 @@ buildGoModule rec { homepage = "https://github.com/noisetorch/NoiseTorch"; license = licenses.gpl3Plus; platforms = platforms.linux; - maintainers = with maintainers; [ panaeon lom ]; + maintainers = with maintainers; [ + panaeon + lom + ]; mainProgram = "noisetorch"; }; } diff --git a/pkgs/by-name/no/nomachine-client/package.nix b/pkgs/by-name/no/nomachine-client/package.nix index 79e77cc86badbf..a99a102f61701f 100644 --- a/pkgs/by-name/no/nomachine-client/package.nix +++ b/pkgs/by-name/no/nomachine-client/package.nix @@ -1,94 +1,112 @@ -{ lib, stdenv, file, fetchurl, makeWrapper, - autoPatchelfHook, jsoncpp, libpulseaudio }: +{ + lib, + stdenv, + file, + fetchurl, + makeWrapper, + autoPatchelfHook, + jsoncpp, + libpulseaudio, +}: let versionMajor = "8.13"; versionMinor = "1"; versionBuild_x86_64 = "1"; versionBuild_i686 = "1"; in - stdenv.mkDerivation rec { - pname = "nomachine-client"; - version = "${versionMajor}.${versionMinor}"; +stdenv.mkDerivation rec { + pname = "nomachine-client"; + version = "${versionMajor}.${versionMinor}"; - src = - if stdenv.hostPlatform.system == "x86_64-linux" then - fetchurl { - url = "https://download.nomachine.com/download/${versionMajor}/Linux/nomachine_${version}_${versionBuild_x86_64}_x86_64.tar.gz"; - sha256 = "sha256-8rxlxdtGU8avpvYJr+bpnsy5v91sqtlij/MCGWrcanY="; - } - else if stdenv.hostPlatform.system == "i686-linux" then - fetchurl { - url = "https://download.nomachine.com/download/${versionMajor}/Linux/nomachine_${version}_${versionBuild_i686}_i686.tar.gz"; - sha256 = "sha256-Ekyxc4wODjqWhp0aINhaPGLy9lh6Rt9AmxIt1ulE8Go="; - } - else - throw "NoMachine client is not supported on ${stdenv.hostPlatform.system}"; + src = + if stdenv.hostPlatform.system == "x86_64-linux" then + fetchurl { + url = "https://download.nomachine.com/download/${versionMajor}/Linux/nomachine_${version}_${versionBuild_x86_64}_x86_64.tar.gz"; + sha256 = "sha256-8rxlxdtGU8avpvYJr+bpnsy5v91sqtlij/MCGWrcanY="; + } + else if stdenv.hostPlatform.system == "i686-linux" then + fetchurl { + url = "https://download.nomachine.com/download/${versionMajor}/Linux/nomachine_${version}_${versionBuild_i686}_i686.tar.gz"; + sha256 = "sha256-Ekyxc4wODjqWhp0aINhaPGLy9lh6Rt9AmxIt1ulE8Go="; + } + else + throw "NoMachine client is not supported on ${stdenv.hostPlatform.system}"; - # nxusb-legacy is only needed for kernel versions < 3 - postUnpack = '' - mv $(find . -type f -name nxrunner.tar.gz) . - mv $(find . -type f -name nxplayer.tar.gz) . - rm -r NX/ - tar xf nxrunner.tar.gz - tar xf nxplayer.tar.gz - rm $(find . -maxdepth 1 -type f) - rm -r NX/share/src/nxusb-legacy - rm NX/bin/nxusbd-legacy NX/lib/libnxusb-legacy.so - ''; + # nxusb-legacy is only needed for kernel versions < 3 + postUnpack = '' + mv $(find . -type f -name nxrunner.tar.gz) . + mv $(find . -type f -name nxplayer.tar.gz) . + rm -r NX/ + tar xf nxrunner.tar.gz + tar xf nxplayer.tar.gz + rm $(find . -maxdepth 1 -type f) + rm -r NX/share/src/nxusb-legacy + rm NX/bin/nxusbd-legacy NX/lib/libnxusb-legacy.so + ''; - nativeBuildInputs = [ file makeWrapper autoPatchelfHook ]; - buildInputs = [ jsoncpp libpulseaudio ]; + nativeBuildInputs = [ + file + makeWrapper + autoPatchelfHook + ]; + buildInputs = [ + jsoncpp + libpulseaudio + ]; - installPhase = '' - rm bin/nxplayer bin/nxrunner + installPhase = '' + rm bin/nxplayer bin/nxrunner - mkdir -p $out/NX - cp -r bin lib share $out/NX/ + mkdir -p $out/NX + cp -r bin lib share $out/NX/ - ln -s $out/NX/bin $out/bin + ln -s $out/NX/bin $out/bin - for i in share/icons/*; do - if [[ -d "$i" ]]; then - mkdir -p "$out/share/icons/hicolor/$(basename $i)/apps" - cp "$i"/* "$out/share/icons/hicolor/$(basename $i)/apps/" - fi - done + for i in share/icons/*; do + if [[ -d "$i" ]]; then + mkdir -p "$out/share/icons/hicolor/$(basename $i)/apps" + cp "$i"/* "$out/share/icons/hicolor/$(basename $i)/apps/" + fi + done - mkdir $out/share/applications - cp share/applnk/player/xdg/*.desktop $out/share/applications/ - cp share/applnk/runner/xdg-mime/*.desktop $out/share/applications/ + mkdir $out/share/applications + cp share/applnk/player/xdg/*.desktop $out/share/applications/ + cp share/applnk/runner/xdg-mime/*.desktop $out/share/applications/ - mkdir -p $out/share/mime/packages - cp share/applnk/runner/xdg-mime/*.xml $out/share/mime/packages/ + mkdir -p $out/share/mime/packages + cp share/applnk/runner/xdg-mime/*.xml $out/share/mime/packages/ - for i in $out/share/applications/*.desktop; do - substituteInPlace "$i" --replace /usr/NX/bin $out/bin - done - ''; + for i in $out/share/applications/*.desktop; do + substituteInPlace "$i" --replace /usr/NX/bin $out/bin + done + ''; - postFixup = '' - makeWrapper $out/bin/nxplayer.bin $out/bin/nxplayer --set NX_SYSTEM $out/NX - makeWrapper $out/bin/nxrunner.bin $out/bin/nxrunner --set NX_SYSTEM $out/NX + postFixup = '' + makeWrapper $out/bin/nxplayer.bin $out/bin/nxplayer --set NX_SYSTEM $out/NX + makeWrapper $out/bin/nxrunner.bin $out/bin/nxrunner --set NX_SYSTEM $out/NX - # libnxcau.so needs libpulse.so.0 for audio to work, but doesn't - # have a DT_NEEDED entry for it. - patchelf --add-needed libpulse.so.0 $out/NX/lib/libnxcau.so - ''; + # libnxcau.so needs libpulse.so.0 for audio to work, but doesn't + # have a DT_NEEDED entry for it. + patchelf --add-needed libpulse.so.0 $out/NX/lib/libnxcau.so + ''; - dontBuild = true; - dontStrip = true; + dontBuild = true; + dontStrip = true; - meta = with lib; { - description = "NoMachine remote desktop client (nxplayer)"; - homepage = "https://www.nomachine.com/"; - mainProgram = "nxplayer"; - sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = { - fullName = "NoMachine 7 End-User License Agreement"; - url = "https://www.nomachine.com/licensing-7"; - free = false; - }; - maintainers = with maintainers; [ talyz ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + meta = with lib; { + description = "NoMachine remote desktop client (nxplayer)"; + homepage = "https://www.nomachine.com/"; + mainProgram = "nxplayer"; + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; + license = { + fullName = "NoMachine 7 End-User License Agreement"; + url = "https://www.nomachine.com/licensing-7"; + free = false; }; - } + maintainers = with maintainers; [ talyz ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; + }; +} diff --git a/pkgs/by-name/no/nomad-autoscaler/package.nix b/pkgs/by-name/no/nomad-autoscaler/package.nix index 6a232472f6cd5f..e83fef2c859c27 100644 --- a/pkgs/by-name/no/nomad-autoscaler/package.nix +++ b/pkgs/by-name/no/nomad-autoscaler/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, buildEnv }: +{ + lib, + fetchFromGitHub, + buildGoModule, + buildEnv, +}: let package = buildGoModule rec { @@ -98,14 +103,24 @@ let }; }; - plugins = let - plugins = builtins.filter (n: !(lib.elem n [ "out" "bin" ])) package.outputs; - in lib.genAttrs plugins (output: package.${output}); + plugins = + let + plugins = builtins.filter ( + n: + !(lib.elem n [ + "out" + "bin" + ]) + ) package.outputs; + in + lib.genAttrs plugins (output: package.${output}); # Intended to be used as: (nomad-autoscaler.withPlugins (ps: [ ps.aws_asg ps.nomad_target ]) - withPlugins = f: buildEnv { - name = "nomad-autoscaler-env"; - paths = [ package.bin ] ++ f plugins; - }; + withPlugins = + f: + buildEnv { + name = "nomad-autoscaler-env"; + paths = [ package.bin ] ++ f plugins; + }; in - package +package diff --git a/pkgs/by-name/no/nomad-driver-podman/package.nix b/pkgs/by-name/no/nomad-driver-podman/package.nix index 4b3f6a2b8e82b0..79edefc7ec6949 100644 --- a/pkgs/by-name/no/nomad-driver-podman/package.nix +++ b/pkgs/by-name/no/nomad-driver-podman/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "nomad-driver-podman"; diff --git a/pkgs/by-name/no/nomino/package.nix b/pkgs/by-name/no/nomino/package.nix index 8dd25227323db8..119b6557d542ee 100644 --- a/pkgs/by-name/no/nomino/package.nix +++ b/pkgs/by-name/no/nomino/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "nomino"; @@ -17,7 +21,10 @@ rustPlatform.buildRustPackage rec { description = "Batch rename utility for developers"; homepage = "https://github.com/yaa110/nomino"; changelog = "https://github.com/yaa110/nomino/releases/tag/${src.rev}"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "nomino"; }; diff --git a/pkgs/by-name/no/nomnatong/package.nix b/pkgs/by-name/no/nomnatong/package.nix index 0236e1cde6702a..c4e2fe59218d20 100644 --- a/pkgs/by-name/no/nomnatong/package.nix +++ b/pkgs/by-name/no/nomnatong/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, python3Packages -, nix-update-script +{ + lib, + stdenvNoCC, + fetchFromGitHub, + python3Packages, + nix-update-script, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/no/nordzy-icon-theme/package.nix b/pkgs/by-name/no/nordzy-icon-theme/package.nix index 3aedf3b2c93ff7..8014d85dfcb7a7 100644 --- a/pkgs/by-name/no/nordzy-icon-theme/package.nix +++ b/pkgs/by-name/no/nordzy-icon-theme/package.nix @@ -1,9 +1,10 @@ -{ stdenvNoCC -, fetchFromGitHub -, lib -, gtk3 -, jdupes -, nordzy-themes ? [ "all" ] # Override this to only install selected themes +{ + stdenvNoCC, + fetchFromGitHub, + lib, + gtk3, + jdupes, + nordzy-themes ? [ "all" ], # Override this to only install selected themes }: stdenvNoCC.mkDerivation rec { @@ -33,7 +34,9 @@ stdenvNoCC.mkDerivation rec { runHook preInstall name= ./install.sh --dest $out/share/icons \ - ${lib.optionalString (nordzy-themes != []) (lib.strings.concatMapStrings (theme: "-t ${theme} ") nordzy-themes)} + ${lib.optionalString (nordzy-themes != [ ]) ( + lib.strings.concatMapStrings (theme: "-t ${theme} ") nordzy-themes + )} # Replace duplicate files with hardlinks to the first file in each # set of duplicates, reducing the installed size in about 87% diff --git a/pkgs/by-name/no/normaliz/package.nix b/pkgs/by-name/no/normaliz/package.nix index e7cca5184cbf22..5c660e5de41c15 100644 --- a/pkgs/by-name/no/normaliz/package.nix +++ b/pkgs/by-name/no/normaliz/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, gmpxx -, flint -, arb -, nauty +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gmpxx, + flint, + arb, + nauty, }: stdenv.mkDerivation (finalAttrs: { @@ -26,7 +27,11 @@ stdenv.mkDerivation (finalAttrs: { nauty ]; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; nativeBuildInputs = [ autoreconfHook diff --git a/pkgs/by-name/no/normalize/package.nix b/pkgs/by-name/no/normalize/package.nix index 78951c67e8d86e..e65c50c6992657 100644 --- a/pkgs/by-name/no/normalize/package.nix +++ b/pkgs/by-name/no/normalize/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libmad }: +{ + lib, + stdenv, + fetchurl, + libmad, +}: stdenv.mkDerivation rec { pname = "normalize"; diff --git a/pkgs/by-name/no/norminette/package.nix b/pkgs/by-name/no/norminette/package.nix index 90a978e09948de..f1b7ecf41dc0af 100644 --- a/pkgs/by-name/no/norminette/package.nix +++ b/pkgs/by-name/no/norminette/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/no/norouter/package.nix b/pkgs/by-name/no/norouter/package.nix index efc50fbad2ad03..73b9273e5d64fe 100644 --- a/pkgs/by-name/no/norouter/package.nix +++ b/pkgs/by-name/no/norouter/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/no/norwester-font/package.nix b/pkgs/by-name/no/norwester-font/package.nix index 2efbf45fd3d139..acac0b78e1250c 100644 --- a/pkgs/by-name/no/norwester-font/package.nix +++ b/pkgs/by-name/no/norwester-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "norwester"; diff --git a/pkgs/by-name/no/noseyparker/package.nix b/pkgs/by-name/no/noseyparker/package.nix index 21d2138023706d..be2c5971598f24 100644 --- a/pkgs/by-name/no/noseyparker/package.nix +++ b/pkgs/by-name/no/noseyparker/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, boost -, cmake -, git -, hyperscan -, openssl -, pkg-config +{ + lib, + rustPlatform, + fetchFromGitHub, + boost, + cmake, + git, + hyperscan, + openssl, + pkg-config, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/no/nosqli/package.nix b/pkgs/by-name/no/nosqli/package.nix index 3a1721831a0ab5..7930a9626b5cd3 100644 --- a/pkgs/by-name/no/nosqli/package.nix +++ b/pkgs/by-name/no/nosqli/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/no/notable/package.nix b/pkgs/by-name/no/notable/package.nix index 9d1c4a246627ce..80995ce15d9411 100644 --- a/pkgs/by-name/no/notable/package.nix +++ b/pkgs/by-name/no/notable/package.nix @@ -1,4 +1,9 @@ -{ appimageTools, makeWrapper, fetchurl, lib }: +{ + appimageTools, + makeWrapper, + fetchurl, + lib, +}: let pname = "notable"; @@ -24,7 +29,10 @@ appimageTools.wrapType2 rec { nativeBuildInputs = [ makeWrapper ]; - extraPkgs = pkgs: [ pkgs.at-spi2-atk pkgs.at-spi2-core ]; + extraPkgs = pkgs: [ + pkgs.at-spi2-atk + pkgs.at-spi2-core + ]; extraInstallCommands = '' install -m 444 -D ${appimageContents}/notable.desktop $out/share/applications/notable.desktop diff --git a/pkgs/by-name/no/notary/package.nix b/pkgs/by-name/no/notary/package.nix index 0feb21091df69c..d25575ca856733 100644 --- a/pkgs/by-name/no/notary/package.nix +++ b/pkgs/by-name/no/notary/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { pname = "notary"; diff --git a/pkgs/by-name/no/notation/package.nix b/pkgs/by-name/no/notation/package.nix index 213b91cfa854fd..70f50ef4eb0ed8 100644 --- a/pkgs/by-name/no/notation/package.nix +++ b/pkgs/by-name/no/notation/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, testers, notation }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + notation, +}: buildGoModule rec { pname = "notation"; diff --git a/pkgs/by-name/no/notcurses/package.nix b/pkgs/by-name/no/notcurses/package.nix index 4fca583a6264fa..adeadd172a5096 100644 --- a/pkgs/by-name/no/notcurses/package.nix +++ b/pkgs/by-name/no/notcurses/package.nix @@ -1,15 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libdeflate -, libunistring -, ncurses -, pandoc -, pkg-config -, zlib -, multimediaSupport ? true, ffmpeg -, qrcodegenSupport ? true, qrcodegen +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libdeflate, + libunistring, + ncurses, + pandoc, + pkg-config, + zlib, + multimediaSupport ? true, + ffmpeg, + qrcodegenSupport ? true, + qrcodegen, }: stdenv.mkDerivation rec { @@ -23,7 +26,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-3ddiHzPZ74GN2Hu+6Oe1DaNFn6S9gegGwXSX8fbtPp8="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake @@ -31,14 +37,15 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - libdeflate - libunistring - ncurses - zlib - ] - ++ lib.optional qrcodegenSupport qrcodegen - ++ lib.optional multimediaSupport ffmpeg; + buildInputs = + [ + libdeflate + libunistring + ncurses + zlib + ] + ++ lib.optional qrcodegenSupport qrcodegen + ++ lib.optional multimediaSupport ffmpeg; cmakeFlags = lib.optional (qrcodegenSupport) "-DUSE_QRCODEGEN=ON" diff --git a/pkgs/by-name/no/notejot/package.nix b/pkgs/by-name/no/notejot/package.nix index a2882e16f93ef9..d9d3c1a93c6dd6 100644 --- a/pkgs/by-name/no/notejot/package.nix +++ b/pkgs/by-name/no/notejot/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, gtk4 -, json-glib -, libadwaita -, libgee -, desktop-file-utils -, meson -, ninja -, nix-update-script -, pkg-config -, vala -, wrapGAppsHook4 -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + gtk4, + json-glib, + libadwaita, + libgee, + desktop-file-utils, + meson, + ninja, + nix-update-script, + pkg-config, + vala, + wrapGAppsHook4, + fetchpatch, }: stdenv.mkDerivation rec { @@ -42,7 +43,6 @@ stdenv.mkDerivation rec { libgee ]; - patches = [ # Fixes the compilation error with new Vala compiler. Remove in the next version. (fetchpatch { diff --git a/pkgs/by-name/no/notemap/package.nix b/pkgs/by-name/no/notemap/package.nix index 0611665d6618a7..ebecc896295b91 100644 --- a/pkgs/by-name/no/notemap/package.nix +++ b/pkgs/by-name/no/notemap/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchzip -, pkg-config -, libressl -, memstreamHook +{ + lib, + stdenv, + fetchzip, + pkg-config, + libressl, + memstreamHook, }: stdenv.mkDerivation rec { @@ -19,11 +20,13 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - libressl - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ - memstreamHook - ]; + buildInputs = + [ + libressl + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + memstreamHook + ]; meta = { description = "Mirror notes to IMAP"; diff --git a/pkgs/by-name/no/notes-up/package.nix b/pkgs/by-name/no/notes-up/package.nix index 4541f77dc3d5af..7e9fe5f5bf88ef 100644 --- a/pkgs/by-name/no/notes-up/package.nix +++ b/pkgs/by-name/no/notes-up/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, desktop-file-utils -, meson -, ninja -, pkg-config -, python3 -, vala -, wrapGAppsHook3 -, discount -, glib -, gtk3 -, gtksourceview4 -, gtkspell3 -, libgee -, pantheon -, sqlite -, webkitgtk_4_0 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + desktop-file-utils, + meson, + ninja, + pkg-config, + python3, + vala, + wrapGAppsHook3, + discount, + glib, + gtk3, + gtksourceview4, + gtkspell3, + libgee, + pantheon, + sqlite, + webkitgtk_4_0, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/no/noteshrink/package.nix b/pkgs/by-name/no/noteshrink/package.nix index 4c76c332645fa0..7bb3a83df09964 100644 --- a/pkgs/by-name/no/noteshrink/package.nix +++ b/pkgs/by-name/no/noteshrink/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, python3, imagemagick }: +{ + lib, + fetchFromGitHub, + python3, + imagemagick, +}: with python3.pkgs; @@ -7,18 +12,23 @@ buildPythonApplication rec { version = "0.1.1"; src = fetchFromGitHub { - owner = "mzucker"; - repo = "noteshrink"; - rev = version; + owner = "mzucker"; + repo = "noteshrink"; + rev = version; sha256 = "0xhrvg3d8ffnbbizsrfppcd2y98znvkgxjdmvbvin458m2rwccka"; }; - propagatedBuildInputs = [ numpy scipy imagemagick pillow ]; + propagatedBuildInputs = [ + numpy + scipy + imagemagick + pillow + ]; meta = with lib; { description = "Convert scans of handwritten notes to beautiful, compact PDFs"; - homepage = "https://mzucker.github.io/2016/09/20/noteshrink.html"; - license = licenses.mit; + homepage = "https://mzucker.github.io/2016/09/20/noteshrink.html"; + license = licenses.mit; maintainers = with maintainers; [ rnhmjoj ]; mainProgram = "noteshrink"; }; diff --git a/pkgs/by-name/no/notify-client/package.nix b/pkgs/by-name/no/notify-client/package.nix index b909564685c3ff..2b034f8f13c990 100644 --- a/pkgs/by-name/no/notify-client/package.nix +++ b/pkgs/by-name/no/notify-client/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, cargo -, capnproto -, blueprint-compiler -, wrapGAppsHook4 -, desktop-file-utils -, libadwaita -, gtksourceview5 -, openssl -, sqlite +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + cargo, + capnproto, + blueprint-compiler, + wrapGAppsHook4, + desktop-file-utils, + libadwaita, + gtksourceview5, + openssl, + sqlite, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/no/notify-desktop/package.nix b/pkgs/by-name/no/notify-desktop/package.nix index e1118022edff4b..33405ed0f08fc0 100644 --- a/pkgs/by-name/no/notify-desktop/package.nix +++ b/pkgs/by-name/no/notify-desktop/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, dbus, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + dbus, + pkg-config, +}: stdenv.mkDerivation { pname = "notify-desktop"; diff --git a/pkgs/by-name/no/notify-osd-customizable/package.nix b/pkgs/by-name/no/notify-osd-customizable/package.nix index 20fe2ad6d82b1b..e235f4f0380621 100644 --- a/pkgs/by-name/no/notify-osd-customizable/package.nix +++ b/pkgs/by-name/no/notify-osd-customizable/package.nix @@ -1,18 +1,22 @@ -{ lib, stdenv -, dbus-glib -, fetchurl -, glib -, gnome-common -, libnotify -, libtool -, libwnck -, makeWrapper -, pkg-config -, gsettings-desktop-schemas +{ + lib, + stdenv, + dbus-glib, + fetchurl, + glib, + gnome-common, + libnotify, + libtool, + libwnck, + makeWrapper, + pkg-config, + gsettings-desktop-schemas, }: -let baseURI = "https://launchpad.net/~leolik/+archive/leolik"; -in stdenv.mkDerivation rec { +let + baseURI = "https://launchpad.net/~leolik/+archive/leolik"; +in +stdenv.mkDerivation rec { pname = "notify-osd"; version = "0.9.35+16.04.20160415"; @@ -24,10 +28,18 @@ in stdenv.mkDerivation rec { preConfigure = "./autogen.sh --libexecdir=$(out)/bin"; - nativeBuildInputs = [ pkg-config makeWrapper libtool ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + libtool + ]; buildInputs = [ - glib libwnck libnotify dbus-glib - gsettings-desktop-schemas gnome-common + glib + libwnck + libnotify + dbus-glib + gsettings-desktop-schemas + gnome-common ]; configureFlags = [ "--libexecdir=$(out)/bin" ]; diff --git a/pkgs/by-name/no/notify-osd/package.nix b/pkgs/by-name/no/notify-osd/package.nix index 77b5d52c22cf47..b67cbd0f60093e 100644 --- a/pkgs/by-name/no/notify-osd/package.nix +++ b/pkgs/by-name/no/notify-osd/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, libwnck, libnotify, dbus-glib, makeWrapper, gsettings-desktop-schemas }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + libwnck, + libnotify, + dbus-glib, + makeWrapper, + gsettings-desktop-schemas, +}: stdenv.mkDerivation rec { pname = "notify-osd"; @@ -9,9 +20,15 @@ stdenv.mkDerivation rec { sha256 = "0g5a7a680b05x27apz0y1ldl5csxpp152wqi42s107jymbp0s20j"; }; - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; buildInputs = [ - glib libwnck libnotify dbus-glib + glib + libwnck + libnotify + dbus-glib gsettings-desktop-schemas ]; diff --git a/pkgs/by-name/no/notify-sharp/package.nix b/pkgs/by-name/no/notify-sharp/package.nix index 1cd69074911b0d..0871187848c694 100644 --- a/pkgs/by-name/no/notify-sharp/package.nix +++ b/pkgs/by-name/no/notify-sharp/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitLab, pkg-config, autoreconfHook -, mono, gtk-sharp-3_0, dbus-sharp-1_0, dbus-sharp-glib-1_0 }: +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + autoreconfHook, + mono, + gtk-sharp-3_0, + dbus-sharp-1_0, + dbus-sharp-glib-1_0, +}: stdenv.mkDerivation rec { pname = "notify-sharp"; @@ -15,12 +24,15 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - pkg-config autoreconfHook + pkg-config + autoreconfHook ]; buildInputs = [ - mono gtk-sharp-3_0 - dbus-sharp-1_0 dbus-sharp-glib-1_0 + mono + gtk-sharp-3_0 + dbus-sharp-1_0 + dbus-sharp-glib-1_0 ]; dontStrip = true; diff --git a/pkgs/by-name/no/notify/package.nix b/pkgs/by-name/no/notify/package.nix index 4a22bfaadb4d11..d2a5ae5280ed90 100644 --- a/pkgs/by-name/no/notify/package.nix +++ b/pkgs/by-name/no/notify/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, }: buildGoModule rec { diff --git a/pkgs/by-name/no/notifymuch/package.nix b/pkgs/by-name/no/notifymuch/package.nix index 72a0485b0a7ee7..261dd74f0cb478 100644 --- a/pkgs/by-name/no/notifymuch/package.nix +++ b/pkgs/by-name/no/notifymuch/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, gobject-introspection -, libnotify -, wrapGAppsHook3 -, gtk3 -, python3 +{ + lib, + fetchFromGitHub, + gobject-introspection, + libnotify, + wrapGAppsHook3, + gtk3, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -20,13 +21,15 @@ python3.pkgs.buildPythonApplication rec { sha256 = "1lssr7iv43mp5v6nzrfbqlfzx8jcc7m636wlfyhhnd8ydd39n6k4"; }; - propagatedBuildInputs = [ - libnotify - gtk3 - ] ++ (with python3.pkgs; [ - notmuch - pygobject3 - ]); + propagatedBuildInputs = + [ + libnotify + gtk3 + ] + ++ (with python3.pkgs; [ + notmuch + pygobject3 + ]); nativeBuildInputs = [ gobject-introspection diff --git a/pkgs/by-name/no/notion-app-enhanced/package.nix b/pkgs/by-name/no/notion-app-enhanced/package.nix index 59c36ab17a876c..78057b67b3d696 100644 --- a/pkgs/by-name/no/notion-app-enhanced/package.nix +++ b/pkgs/by-name/no/notion-app-enhanced/package.nix @@ -1,4 +1,8 @@ -{ appimageTools, lib, fetchurl }: +{ + appimageTools, + lib, + fetchurl, +}: let pname = "notion-app-enhanced"; version = "2.0.18-1"; @@ -9,7 +13,8 @@ let }; appimageContents = appimageTools.extract { inherit pname version src; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; extraInstallCommands = '' diff --git a/pkgs/by-name/no/notion/package.nix b/pkgs/by-name/no/notion/package.nix index f430d72c2737b9..ed09967977b037 100644 --- a/pkgs/by-name/no/notion/package.nix +++ b/pkgs/by-name/no/notion/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, fontconfig -, gettext -, groff -, libSM -, libX11 -, libXext -, libXft -, libXinerama -, libXrandr -, lua -, makeWrapper -, pkg-config -, readline -, which -, xmessage -, xterm +{ + lib, + stdenv, + fetchFromGitHub, + fontconfig, + gettext, + groff, + libSM, + libX11, + libXext, + libXft, + libXinerama, + libXrandr, + lua, + makeWrapper, + pkg-config, + readline, + which, + xmessage, + xterm, }: stdenv.mkDerivation (finalAttrs: { @@ -56,7 +57,10 @@ stdenv.mkDerivation (finalAttrs: { readline ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; strictDeps = true; @@ -72,7 +76,12 @@ stdenv.mkDerivation (finalAttrs: { postInstall = '' wrapProgram $out/bin/notion \ - --prefix PATH ":" "${lib.makeBinPath [ xmessage xterm ]}" \ + --prefix PATH ":" "${ + lib.makeBinPath [ + xmessage + xterm + ] + }" \ ''; meta = { @@ -80,7 +89,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://notionwm.net"; license = lib.licenses.lgpl21; mainProgram = "notion"; - maintainers = with lib.maintainers; [ jfb raboof ]; + maintainers = with lib.maintainers; [ + jfb + raboof + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/by-name/no/notmuch-addrlookup/package.nix b/pkgs/by-name/no/notmuch-addrlookup/package.nix index 8fc12d5fd17077..d2f60b6ae64aea 100644 --- a/pkgs/by-name/no/notmuch-addrlookup/package.nix +++ b/pkgs/by-name/no/notmuch-addrlookup/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, glib, notmuch }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + glib, + notmuch, +}: let version = "10"; @@ -10,12 +17,15 @@ stdenv.mkDerivation { src = fetchFromGitHub { owner = "aperezdc"; repo = "notmuch-addrlookup-c"; - rev ="v${version}"; + rev = "v${version}"; sha256 = "sha256-Z59MAptJw95azdK0auOuUyxBrX4PtXwnRNPkhjgI6Ro="; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib notmuch ]; + buildInputs = [ + glib + notmuch + ]; installPhase = "install -D notmuch-addrlookup $out/bin/notmuch-addrlookup"; diff --git a/pkgs/by-name/no/notmuch-bower/package.nix b/pkgs/by-name/no/notmuch-bower/package.nix index 7073c7b911138f..1bb1c050171d28 100644 --- a/pkgs/by-name/no/notmuch-bower/package.nix +++ b/pkgs/by-name/no/notmuch-bower/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, mercury, pandoc, ncurses, gpgme, coreutils, file }: +{ + lib, + stdenv, + fetchFromGitHub, + mercury, + pandoc, + ncurses, + gpgme, + coreutils, + file, +}: stdenv.mkDerivation rec { pname = "notmuch-bower"; @@ -11,15 +21,25 @@ stdenv.mkDerivation rec { sha256 = "sha256-CqA9JU/ujqIn/NvtbPtSWxKDYCv4oDdLCgbf2jj9Av4="; }; - nativeBuildInputs = [ mercury pandoc ]; + nativeBuildInputs = [ + mercury + pandoc + ]; postPatch = '' substituteInPlace src/compose.m --replace 'shell_quoted("base64' 'shell_quoted("${coreutils}/bin/base64' substituteInPlace src/detect_mime_type.m --replace 'shell_quoted("file' 'shell_quoted("${file}/bin/file' ''; - buildInputs = [ ncurses gpgme ]; + buildInputs = [ + ncurses + gpgme + ]; - makeFlags = [ "PARALLEL=-j$(NIX_BUILD_CORES)" "bower" "man" ]; + makeFlags = [ + "PARALLEL=-j$(NIX_BUILD_CORES)" + "bower" + "man" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/no/noto-fonts-cjk-serif/package.nix b/pkgs/by-name/no/noto-fonts-cjk-serif/package.nix index 8fbc05ff269ce3..967a761e1d40cf 100644 --- a/pkgs/by-name/no/noto-fonts-cjk-serif/package.nix +++ b/pkgs/by-name/no/noto-fonts-cjk-serif/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, nixosTests -, gitUpdater +{ + lib, + stdenvNoCC, + fetchFromGitHub, + nixosTests, + gitUpdater, }: stdenvNoCC.mkDerivation rec { @@ -44,6 +45,9 @@ stdenvNoCC.mkDerivation rec { ''; license = licenses.ofl; platforms = platforms.all; - maintainers = with maintainers; [ mathnerd314 emily ]; + maintainers = with maintainers; [ + mathnerd314 + emily + ]; }; } diff --git a/pkgs/by-name/no/noto-fonts-color-emoji/package.nix b/pkgs/by-name/no/noto-fonts-color-emoji/package.nix index 925b0ff68e8daf..39862609e894d5 100644 --- a/pkgs/by-name/no/noto-fonts-color-emoji/package.nix +++ b/pkgs/by-name/no/noto-fonts-color-emoji/package.nix @@ -1,18 +1,23 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, buildPackages -, pkg-config -, cairo -, imagemagick -, zopfli -, pngquant -, which +{ + lib, + stdenvNoCC, + fetchFromGitHub, + buildPackages, + pkg-config, + cairo, + imagemagick, + zopfli, + pngquant, + which, }: let - emojiPythonEnv = - buildPackages.python3.withPackages (p: with p; [ fonttools nototools ]); + emojiPythonEnv = buildPackages.python3.withPackages ( + p: with p; [ + fonttools + nototools + ] + ); in stdenvNoCC.mkDerivation rec { pname = "noto-fonts-color-emoji"; @@ -64,8 +69,14 @@ stdenvNoCC.mkDerivation rec { meta = { description = "Color emoji font"; homepage = "https://github.com/googlefonts/noto-emoji"; - license = with lib.licenses; [ ofl asl20 ]; + license = with lib.licenses; [ + ofl + asl20 + ]; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ mathnerd314 sternenseemann ]; + maintainers = with lib.maintainers; [ + mathnerd314 + sternenseemann + ]; }; } diff --git a/pkgs/by-name/no/noto-fonts-emoji-blob-bin/package.nix b/pkgs/by-name/no/noto-fonts-emoji-blob-bin/package.nix index 311505c3ae48b8..ffd2bd18c00e91 100644 --- a/pkgs/by-name/no/noto-fonts-emoji-blob-bin/package.nix +++ b/pkgs/by-name/no/noto-fonts-emoji-blob-bin/package.nix @@ -1,6 +1,7 @@ - { lib -, stdenvNoCC -, fetchurl +{ + lib, + stdenvNoCC, + fetchurl, }: stdenvNoCC.mkDerivation rec { @@ -23,8 +24,14 @@ stdenvNoCC.mkDerivation rec { meta = { description = "Noto Emoji with extended Blob support"; homepage = "https://github.com/C1710/blobmoji"; - license = with lib.licenses; [ ofl asl20 ]; + license = with lib.licenses; [ + ofl + asl20 + ]; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ rileyinman jk ]; + maintainers = with lib.maintainers; [ + rileyinman + jk + ]; }; } diff --git a/pkgs/by-name/no/noto-fonts/package.nix b/pkgs/by-name/no/noto-fonts/package.nix index 480028f02106f7..a93266fa3e7f30 100644 --- a/pkgs/by-name/no/noto-fonts/package.nix +++ b/pkgs/by-name/no/noto-fonts/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gitUpdater -, nixosTests -, variants ? [ ] -, suffix ? "" -, longDescription ? '' +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gitUpdater, + nixosTests, + variants ? [ ], + suffix ? "", + longDescription ? '' When text is rendered by a computer, sometimes characters are displayed as “tofu”. They are little boxes to indicate your device doesn’t have a font to display the text. @@ -14,7 +15,7 @@ Google’s answer to tofu. The name noto is to convey the idea that Google’s goal is to see “no more tofu”. Noto has multiple styles and weights, and freely available to all. - '' + '', }: stdenvNoCC.mkDerivation rec { @@ -30,34 +31,41 @@ stdenvNoCC.mkDerivation rec { _variants = map (variant: builtins.replaceStrings [ " " ] [ "" ] variant) variants; - installPhase = '' - # We check availability in order of variable -> otf -> ttf - # unhinted -- the hinted versions use autohint - # maintaining maximum coverage. - # - # We have a mix of otf and ttf fonts - local out_font=$out/share/fonts/noto - '' + (if _variants == [ ] then '' - for folder in $(ls -d fonts/*/); do - if [[ -d "$folder"unhinted/variable-ttf ]]; then - install -m444 -Dt $out_font "$folder"unhinted/variable-ttf/*.ttf - elif [[ -d "$folder"unhinted/otf ]]; then - install -m444 -Dt $out_font "$folder"unhinted/otf/*.otf + installPhase = + '' + # We check availability in order of variable -> otf -> ttf + # unhinted -- the hinted versions use autohint + # maintaining maximum coverage. + # + # We have a mix of otf and ttf fonts + local out_font=$out/share/fonts/noto + '' + + ( + if _variants == [ ] then + '' + for folder in $(ls -d fonts/*/); do + if [[ -d "$folder"unhinted/variable-ttf ]]; then + install -m444 -Dt $out_font "$folder"unhinted/variable-ttf/*.ttf + elif [[ -d "$folder"unhinted/otf ]]; then + install -m444 -Dt $out_font "$folder"unhinted/otf/*.otf + else + install -m444 -Dt $out_font "$folder"unhinted/ttf/*.ttf + fi + done + '' else - install -m444 -Dt $out_font "$folder"unhinted/ttf/*.ttf - fi - done - '' else '' - for variant in $_variants; do - if [[ -d fonts/"$variant"/unhinted/variable-ttf ]]; then - install -m444 -Dt $out_font fonts/"$variant"/unhinted/variable-ttf/*.ttf - elif [[ -d fonts/"$variant"/unhinted/otf ]]; then - install -m444 -Dt $out_font fonts/"$variant"/unhinted/otf/*.otf - else - install -m444 -Dt $out_font fonts/"$variant"/unhinted/ttf/*.ttf - fi - done - ''); + '' + for variant in $_variants; do + if [[ -d fonts/"$variant"/unhinted/variable-ttf ]]; then + install -m444 -Dt $out_font fonts/"$variant"/unhinted/variable-ttf/*.ttf + elif [[ -d fonts/"$variant"/unhinted/otf ]]; then + install -m444 -Dt $out_font fonts/"$variant"/unhinted/otf/*.otf + else + install -m444 -Dt $out_font fonts/"$variant"/unhinted/ttf/*.ttf + fi + done + '' + ); passthru.updateScript = gitUpdater { rev-prefix = "noto-monthly-release-"; @@ -71,6 +79,10 @@ stdenvNoCC.mkDerivation rec { inherit longDescription; license = lib.licenses.ofl; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ mathnerd314 emily jopejoe1 ]; + maintainers = with lib.maintainers; [ + mathnerd314 + emily + jopejoe1 + ]; }; } diff --git a/pkgs/by-name/no/nova-filters/package.nix b/pkgs/by-name/no/nova-filters/package.nix index 17d90c6d310b22..09dec37941ec83 100644 --- a/pkgs/by-name/no/nova-filters/package.nix +++ b/pkgs/by-name/no/nova-filters/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, scons -, boost -, ladspaH +{ + lib, + stdenv, + fetchurl, + scons, + boost, + ladspaH, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/no/nova-password/package.nix b/pkgs/by-name/no/nova-password/package.nix index 225366dfacfb74..89c94b2389fa42 100644 --- a/pkgs/by-name/no/nova-password/package.nix +++ b/pkgs/by-name/no/nova-password/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/no/nova/package.nix b/pkgs/by-name/no/nova/package.nix index b8a5f1d9e3c748..c7226f29e2d60e 100644 --- a/pkgs/by-name/no/nova/package.nix +++ b/pkgs/by-name/no/nova/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "nova"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-v3ld3bHpVWNJgQ6K5iS7q8QV4ft4RE42wKi+f4++yqY="; - ldflags = [ "-X main.version=${version}" "-s" "-w" ]; + ldflags = [ + "-X main.version=${version}" + "-s" + "-w" + ]; meta = with lib; { description = "Find outdated or deprecated Helm charts running in your cluster"; diff --git a/pkgs/by-name/no/novnc/package.nix b/pkgs/by-name/no/novnc/package.nix index 5a8866e26be4e5..cf5bf023ad9080 100644 --- a/pkgs/by-name/no/novnc/package.nix +++ b/pkgs/by-name/no/novnc/package.nix @@ -1,4 +1,10 @@ -{ lib, python3, stdenv, substituteAll, fetchFromGitHub }: +{ + lib, + python3, + stdenv, + substituteAll, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "novnc"; @@ -11,12 +17,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-3Q87bYsC824/8A85Kxdqlm+InuuR/D/HjVrYTJZfE9Y="; }; - patches = with python3.pkgs; [ - (substituteAll { - src = ./websockify.patch; - inherit websockify; - }) - ] ++ [ ./fix-paths.patch ]; + patches = + with python3.pkgs; + [ + (substituteAll { + src = ./websockify.patch; + inherit websockify; + }) + ] + ++ [ ./fix-paths.patch ]; postPatch = '' substituteAllInPlace utils/novnc_proxy @@ -35,7 +44,13 @@ stdenv.mkDerivation rec { meta = with lib; { description = "VNC client web application"; homepage = "https://novnc.com"; - license = with licenses; [ mpl20 ofl bsd3 bsd2 mit ]; + license = with licenses; [ + mpl20 + ofl + bsd3 + bsd2 + mit + ]; maintainers = with maintainers; [ neverbehave ]; mainProgram = "novnc"; }; diff --git a/pkgs/by-name/no/novops/package.nix b/pkgs/by-name/no/novops/package.nix index 4e5133841fd60b..be577ab245c8a4 100644 --- a/pkgs/by-name/no/novops/package.nix +++ b/pkgs/by-name/no/novops/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, openssl -, stdenv -, installShellFiles -, libiconv -, darwin +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + stdenv, + installShellFiles, + libiconv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -22,12 +23,14 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-3QB7iuzWlWDgFRrKiwq7Yh9PIW88m1N+nPQ8fdEQ7Ps="; - buildInputs = [ - openssl # required for openssl-sys - ] ++ lib.optional stdenv.hostPlatform.isDarwin [ - libiconv - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl # required for openssl-sys + ] + ++ lib.optional stdenv.hostPlatform.isDarwin [ + libiconv + darwin.apple_sdk.frameworks.SystemConfiguration + ]; nativeBuildInputs = [ installShellFiles @@ -35,9 +38,9 @@ rustPlatform.buildRustPackage rec { ]; cargoTestFlags = [ - # Only run lib tests (unit tests) - # All other tests are integration tests which should not be run with Nix build - "--lib" + # Only run lib tests (unit tests) + # All other tests are integration tests which should not be run with Nix build + "--lib" ]; postInstall = '' diff --git a/pkgs/by-name/no/noweb/package.nix b/pkgs/by-name/no/noweb/package.nix index d0657e935697c5..987731c26c5a12 100644 --- a/pkgs/by-name/no/noweb/package.nix +++ b/pkgs/by-name/no/noweb/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, nawk, groff, icon-lang, useIcon ? true }: +{ + lib, + stdenv, + fetchFromGitHub, + nawk, + groff, + icon-lang, + useIcon ? true, +}: stdenv.mkDerivation (finalAttrs: { pname = "noweb"; @@ -7,7 +15,7 @@ stdenv.mkDerivation (finalAttrs: { src = fetchFromGitHub { owner = "nrnrnr"; repo = "noweb"; - rev = "v${builtins.replaceStrings ["."] ["_"] finalAttrs.version}"; + rev = "v${builtins.replaceStrings [ "." ] [ "_" ] finalAttrs.version}"; sha256 = "sha256-COcWyrYkheRaSr2gqreRRsz9SYRTX2PSl7km+g98ljs="; }; @@ -30,10 +38,12 @@ stdenv.mkDerivation (finalAttrs: { mkdir -p "$out/lib/noweb" ''; - makeFlags = lib.optionals useIcon [ - "LIBSRC=icon" - "ICONC=icont" - ] ++ [ "CC=${stdenv.cc.targetPrefix}cc" ]; + makeFlags = + lib.optionals useIcon [ + "LIBSRC=icon" + "ICONC=icont" + ] + ++ [ "CC=${stdenv.cc.targetPrefix}cc" ]; preInstall = '' mkdir -p "$tex/tex/latex/noweb" @@ -46,7 +56,11 @@ stdenv.mkDerivation (finalAttrs: { ) ''; - installTargets = [ "install-code" "install-tex" "install-elisp" ]; + installTargets = [ + "install-code" + "install-tex" + "install-elisp" + ]; postInstall = '' substituteInPlace "$out/bin/cpif" --replace "PATH=/bin:/usr/bin" "" @@ -69,7 +83,10 @@ stdenv.mkDerivation (finalAttrs: { ln -s "$tex" "$out/share/texmf" ''; - outputs = [ "out" "tex" ]; + outputs = [ + "out" + "tex" + ]; passthru = { tlType = "run"; diff --git a/pkgs/by-name/no/nowplaying-cli/package.nix b/pkgs/by-name/no/nowplaying-cli/package.nix index fc47967113c13b..f959cfd02c6fd1 100644 --- a/pkgs/by-name/no/nowplaying-cli/package.nix +++ b/pkgs/by-name/no/nowplaying-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + darwin, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/no/nox/package.nix b/pkgs/by-name/no/nox/package.nix index b215a8e1d28537..296ddefcd91695 100644 --- a/pkgs/by-name/no/nox/package.nix +++ b/pkgs/by-name/no/nox/package.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchurl, git }: +{ + lib, + python3Packages, + fetchurl, + git, +}: python3Packages.buildPythonApplication rec { pname = "nox"; @@ -12,15 +17,18 @@ python3Packages.buildPythonApplication rec { patches = [ ./nox-review-wip.patch ]; - buildInputs = [ python3Packages.pbr git ]; + buildInputs = [ + python3Packages.pbr + git + ]; propagatedBuildInputs = with python3Packages; [ - dogpile-cache - click - requests - characteristic - setuptools - ]; + dogpile-cache + click + requests + characteristic + setuptools + ]; meta = { homepage = "https://github.com/madjar/nox"; diff --git a/pkgs/by-name/np/np/package.nix b/pkgs/by-name/np/np/package.nix index 5d3d18857e519c..dad49281b034db 100644 --- a/pkgs/by-name/np/np/package.nix +++ b/pkgs/by-name/np/np/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/np/np2kai/package.nix b/pkgs/by-name/np/np2kai/package.nix index 0fc56e28441735..1be4dee6a086ca 100644 --- a/pkgs/by-name/np/np2kai/package.nix +++ b/pkgs/by-name/np/np2kai/package.nix @@ -1,46 +1,49 @@ -{ stdenv -, lib -, fetchFromGitHub -, enable16Bit ? true -, enable32Bit ? true +{ + stdenv, + lib, + fetchFromGitHub, + enable16Bit ? true, + enable32Bit ? true, -, enableSDL ? true -, withSDLVersion ? "2" -, SDL -, SDL_ttf -, SDL_mixer -, SDL2 -, SDL2_ttf -, SDL2_mixer + enableSDL ? true, + withSDLVersion ? "2", + SDL, + SDL_ttf, + SDL_mixer, + SDL2, + SDL2_ttf, + SDL2_mixer, -, enableX11 ? stdenv.hostPlatform.isLinux -, automake -, autoconf -, autoconf-archive -, libtool -, pkg-config -, unzip -, gtk2 -, libusb1 -, libXxf86vm -, nasm -, libICE -, libSM + enableX11 ? stdenv.hostPlatform.isLinux, + automake, + autoconf, + autoconf-archive, + libtool, + pkg-config, + unzip, + gtk2, + libusb1, + libXxf86vm, + nasm, + libICE, + libSM, # HAXM build succeeds but the binary segfaults, seemingly due to the missing HAXM kernel module # Enable once there is a HAXM kernel module option in NixOS? Or somehow bind it to the system kernel having HAXM? # Or leave it disabled by default? # https://github.com/intel/haxm/blob/master/docs/manual-linux.md -, enableHAXM ? false + enableHAXM ? false, }: -assert lib.assertMsg (enable16Bit || enable32Bit) - "Must enable 16-Bit and/or 32-Bit system variant."; -assert lib.assertMsg (enableSDL || enableX11) - "Must enable SDL and/or X11 graphics interfaces."; -assert lib.assertOneOf "withSDLVersion" withSDLVersion [ "1" "2" ]; -assert enableHAXM -> (lib.assertMsg enableX11 - "Must enable X11 graphics interface for HAXM build."); +assert lib.assertMsg ( + enable16Bit || enable32Bit +) "Must enable 16-Bit and/or 32-Bit system variant."; +assert lib.assertMsg (enableSDL || enableX11) "Must enable SDL and/or X11 graphics interfaces."; +assert lib.assertOneOf "withSDLVersion" withSDLVersion [ + "1" + "2" +]; +assert enableHAXM -> (lib.assertMsg enableX11 "Must enable X11 graphics interface for HAXM build."); let inherit (lib) optional optionals optionalString; inherit (lib.strings) concatStringsSep concatMapStringsSep; @@ -59,35 +62,51 @@ let sdlDepsBuildonly = if isSDL2 then sdlDeps1 else sdlDeps2; sdlDepsTarget = if isSDL2 then sdlDeps2 else sdlDeps1; sdlMakefileSuffix = - if stdenv.hostPlatform.isWindows then "win" - else if stdenv.hostPlatform.isDarwin then "mac" - else "unix"; - sdlMakefiles = concatMapStringsSep " " (x: x + "." + sdlMakefileSuffix) - (optionals enable16Bit [ + if stdenv.hostPlatform.isWindows then + "win" + else if stdenv.hostPlatform.isDarwin then + "mac" + else + "unix"; + sdlMakefiles = concatMapStringsSep " " (x: x + "." + sdlMakefileSuffix) ( + optionals enable16Bit [ "Makefile" - ] ++ optionals enable32Bit [ + ] + ++ optionals enable32Bit [ "Makefile21" - ]); - sdlBuildFlags = concatStringsSep " " - (optionals enableSDL [ + ] + ); + sdlBuildFlags = concatStringsSep " " ( + optionals enableSDL [ "SDL_VERSION=${withSDLVersion}" - ]); - sdlBins = concatStringsSep " " - (optionals enable16Bit [ + ] + ); + sdlBins = concatStringsSep " " ( + optionals enable16Bit [ "np2kai" - ] ++ optionals enable32Bit [ + ] + ++ optionals enable32Bit [ "np21kai" - ]); - x11ConfigureFlags = concatStringsSep " " - (( - if ((enableHAXM && (enable16Bit || enable32Bit)) || (enable16Bit && enable32Bit)) then [ - "--enable-build-all" - ] else if enableHAXM then [ - "--enable-haxm" - ] else if enable32Bit then [ - "--enable-ia32" - ] else [ ] - ) ++ optionals (!isSDL2) [ + ] + ); + x11ConfigureFlags = concatStringsSep " " ( + ( + if ((enableHAXM && (enable16Bit || enable32Bit)) || (enable16Bit && enable32Bit)) then + [ + "--enable-build-all" + ] + else if enableHAXM then + [ + "--enable-haxm" + ] + else if enable32Bit then + [ + "--enable-ia32" + ] + else + [ ] + ) + ++ optionals (!isSDL2) [ "--enable-sdl" "--enable-sdlmixer" "--enable-sdlttf" @@ -95,25 +114,29 @@ let "--enable-sdl2=no" "--enable-sdl2mixer=no" "--enable-sdl2ttf=no" - ]); + ] + ); x11BuildFlags = concatStringsSep " " [ "SDL2_CONFIG=sdl2-config" "SDL_CONFIG=sdl-config" "SDL_CFLAGS=\"$(sdl${sdlInfix}-config --cflags)\"" "SDL_LIBS=\"$(sdl${sdlInfix}-config --libs) -lSDL${sdlInfix}_mixer -lSDL${sdlInfix}_ttf\"" ]; - x11Bins = concatStringsSep " " - (optionals enable16Bit [ + x11Bins = concatStringsSep " " ( + optionals enable16Bit [ "xnp2kai" - ] ++ optionals enable32Bit [ + ] + ++ optionals enable32Bit [ "xnp21kai" - ] ++ optionals enableHAXM [ + ] + ++ optionals enableHAXM [ "xnp21kai_haxm" - ]); + ] + ); in stdenv.mkDerivation rec { pname = "np2kai"; - version = "0.86rev22"; #update src.rev to commit rev accordingly + version = "0.86rev22"; # update src.rev to commit rev accordingly src = fetchFromGitHub rec { owner = "AZO234"; @@ -122,72 +145,80 @@ stdenv.mkDerivation rec { sha256 = "0kxysxhx6jyk82mx30ni0ydzmwdcbnlxlnarrlq018rsnwb4md72"; }; - configurePhase = '' - export GIT_VERSION=${builtins.substring 0 7 src.rev} - buildFlags="$buildFlags ''${enableParallelBuilding:+-j$NIX_BUILD_CORES}" - '' + optionalString enableX11 '' - cd x11 - substituteInPlace Makefile.am \ - --replace 'GIT_VERSION :=' 'GIT_VERSION ?=' - ./autogen.sh ${x11ConfigureFlags} - ./configure ${x11ConfigureFlags} - cd .. - ''; + configurePhase = + '' + export GIT_VERSION=${builtins.substring 0 7 src.rev} + buildFlags="$buildFlags ''${enableParallelBuilding:+-j$NIX_BUILD_CORES}" + '' + + optionalString enableX11 '' + cd x11 + substituteInPlace Makefile.am \ + --replace 'GIT_VERSION :=' 'GIT_VERSION ?=' + ./autogen.sh ${x11ConfigureFlags} + ./configure ${x11ConfigureFlags} + cd .. + ''; - nativeBuildInputs = sdlDepsBuildonly + nativeBuildInputs = + sdlDepsBuildonly ++ optionals enableX11 [ - automake - autoconf - autoconf-archive - libtool - pkg-config - unzip - nasm - ]; + automake + autoconf + autoconf-archive + libtool + pkg-config + unzip + nasm + ]; - buildInputs = sdlDepsTarget + buildInputs = + sdlDepsTarget ++ optionals enableX11 [ - gtk2 - libICE - libSM - libusb1 - libXxf86vm - ]; + gtk2 + libICE + libSM + libusb1 + libXxf86vm + ]; enableParallelBuilding = true; # TODO Remove when bumping past rev22 env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-D_DARWIN_C_SOURCE"; - buildPhase = optionalString enableSDL '' - cd sdl2 - for mkfile in ${sdlMakefiles}; do - substituteInPlace $mkfile \ - --replace 'GIT_VERSION :=' 'GIT_VERSION ?=' - echo make -f $mkfile $buildFlags ${sdlBuildFlags} clean - make -f $mkfile $buildFlags ${sdlBuildFlags} clean - make -f $mkfile $buildFlags ${sdlBuildFlags} - done - cd .. - '' + optionalString enableX11 '' - cd x11 - make $buildFlags ${x11BuildFlags} - cd .. - ''; + buildPhase = + optionalString enableSDL '' + cd sdl2 + for mkfile in ${sdlMakefiles}; do + substituteInPlace $mkfile \ + --replace 'GIT_VERSION :=' 'GIT_VERSION ?=' + echo make -f $mkfile $buildFlags ${sdlBuildFlags} clean + make -f $mkfile $buildFlags ${sdlBuildFlags} clean + make -f $mkfile $buildFlags ${sdlBuildFlags} + done + cd .. + '' + + optionalString enableX11 '' + cd x11 + make $buildFlags ${x11BuildFlags} + cd .. + ''; - installPhase = optionalString enableSDL '' - cd sdl2 - for emu in ${sdlBins}; do - install -D -m 755 $emu $out/bin/$emu - done - cd .. - '' + optionalString enableX11 '' - cd x11 - for emu in ${x11Bins}; do - install -D -m 755 $emu $out/bin/$emu - done - cd .. - ''; + installPhase = + optionalString enableSDL '' + cd sdl2 + for emu in ${sdlBins}; do + install -D -m 755 $emu $out/bin/$emu + done + cd .. + '' + + optionalString enableX11 '' + cd x11 + for emu in ${x11Bins}; do + install -D -m 755 $emu $out/bin/$emu + done + cd .. + ''; meta = with lib; { description = "PC-9801 series emulator"; diff --git a/pkgs/by-name/np/npapi_sdk/package.nix b/pkgs/by-name/np/npapi_sdk/package.nix index a61bd0088052af..0663afc7be34b5 100644 --- a/pkgs/by-name/np/npapi_sdk/package.nix +++ b/pkgs/by-name/np/npapi_sdk/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "npapi-sdk"; diff --git a/pkgs/by-name/np/npins/package.nix b/pkgs/by-name/np/npins/package.nix index 37f48f54706241..9d0ab7526f7cce 100644 --- a/pkgs/by-name/np/npins/package.nix +++ b/pkgs/by-name/np/npins/package.nix @@ -1,27 +1,39 @@ -{ lib -, rustPlatform -, makeWrapper -, stdenv -, darwin -, callPackage +{ + lib, + rustPlatform, + makeWrapper, + stdenv, + darwin, + callPackage, # runtime dependencies -, nix # for nix-prefetch-url -, nix-prefetch-git -, git # for git ls-remote + nix, # for nix-prefetch-url + nix-prefetch-git, + git, # for git ls-remote }: let - runtimePath = lib.makeBinPath [ nix nix-prefetch-git git ]; + runtimePath = lib.makeBinPath [ + nix + nix-prefetch-git + git + ]; sources = (lib.importJSON ./sources.json).pins; -in rustPlatform.buildRustPackage rec { +in +rustPlatform.buildRustPackage rec { pname = "npins"; version = src.version; src = passthru.mkSource sources.npins; cargoHash = "sha256-YwMypBl+P1ygf4zUbkZlq4zPrOzf+lPOz2FLg2/xI3k="; - buildInputs = lib.optional stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ Security SystemConfiguration ]); + buildInputs = lib.optional stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Security + SystemConfiguration + ] + ); nativeBuildInputs = [ makeWrapper ]; # (Almost) all tests require internet @@ -39,5 +51,5 @@ in rustPlatform.buildRustPackage rec { maintainers = with maintainers; [ piegames ]; }; - passthru.mkSource = callPackage ./source.nix {}; + passthru.mkSource = callPackage ./source.nix { }; } diff --git a/pkgs/by-name/np/npins/source.nix b/pkgs/by-name/np/npins/source.nix index 49046d8dd3c678..d7f08ede9c8fc7 100644 --- a/pkgs/by-name/np/npins/source.nix +++ b/pkgs/by-name/np/npins/source.nix @@ -10,23 +10,38 @@ # } # ``` -{ fetchgit -, fetchzip -, fetchurl +{ + fetchgit, + fetchzip, + fetchurl, }: let - mkSource = spec: - assert spec ? type; let + mkSource = + spec: + assert spec ? type; + let path = - if spec.type == "Git" then mkGitSource spec - else if spec.type == "GitRelease" then mkGitSource spec - else if spec.type == "PyPi" then mkPyPiSource spec - else if spec.type == "Channel" then mkChannelSource spec - else throw "Unknown source type ${spec.type}"; + if spec.type == "Git" then + mkGitSource spec + else if spec.type == "GitRelease" then + mkGitSource spec + else if spec.type == "PyPi" then + mkPyPiSource spec + else if spec.type == "Channel" then + mkChannelSource spec + else + throw "Unknown source type ${spec.type}"; in spec // { outPath = path; }; - mkGitSource = { repository, revision, url ? null, hash, ... }: + mkGitSource = + { + repository, + revision, + url ? null, + hash, + ... + }: assert repository ? type; # At the moment, either it is a plain git repository (which has an url), or it is a GitHub/GitLab repository # In the latter case, there we will always be an url to the tarball @@ -36,22 +51,26 @@ let sha256 = hash; extension = "tar"; }) - else assert repository.type == "Git"; fetchgit { - url = repository.url; - rev = revision; - }; + else + assert repository.type == "Git"; + fetchgit { + url = repository.url; + rev = revision; + }; - mkPyPiSource = { url, hash, ... }: + mkPyPiSource = + { url, hash, ... }: fetchurl { inherit url; sha256 = hash; }; - mkChannelSource = { url, hash, ... }: + mkChannelSource = + { url, hash, ... }: fetchzip { inherit url; sha256 = hash; extension = "tar"; }; in - mkSource +mkSource diff --git a/pkgs/by-name/np/npkill/package.nix b/pkgs/by-name/np/npkill/package.nix index e62657a8931ae6..517da4bc26c80f 100644 --- a/pkgs/by-name/np/npkill/package.nix +++ b/pkgs/by-name/np/npkill/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, nix-update-script +{ + lib, + buildNpmPackage, + fetchFromGitHub, + nix-update-script, }: buildNpmPackage rec { diff --git a/pkgs/by-name/np/npm-check/package.nix b/pkgs/by-name/np/npm-check/package.nix index 131048f10cbe06..2c4387a9dcd15f 100644 --- a/pkgs/by-name/np/npm-check/package.nix +++ b/pkgs/by-name/np/npm-check/package.nix @@ -1,6 +1,7 @@ -{ buildNpmPackage -, fetchFromGitHub -, lib +{ + buildNpmPackage, + fetchFromGitHub, + lib, }: buildNpmPackage rec { diff --git a/pkgs/by-name/np/npm-lockfile-fix/package.nix b/pkgs/by-name/np/npm-lockfile-fix/package.nix index db886f6821e334..e9aae5f92a84b8 100644 --- a/pkgs/by-name/np/npm-lockfile-fix/package.nix +++ b/pkgs/by-name/np/npm-lockfile-fix/package.nix @@ -1,10 +1,10 @@ -{ lib -, python3 -, fetchFromGitHub -, nix-update-script +{ + lib, + python3, + fetchFromGitHub, + nix-update-script, }: - python3.pkgs.buildPythonApplication rec { pname = "npm-lockfile-fix"; version = "0.1.1"; @@ -22,13 +22,16 @@ python3.pkgs.buildPythonApplication rec { doCheck = false; # no tests - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = with lib; { description = "Add missing integrity and resolved fields to a package-lock.json file"; homepage = "https://github.com/jeslie0/npm-lockfile-fix"; mainProgram = "npm-lockfile-fix"; license = lib.licenses.mit; - maintainers = with maintainers; [ lucasew felschr ]; + maintainers = with maintainers; [ + lucasew + felschr + ]; }; } diff --git a/pkgs/by-name/np/npth/package.nix b/pkgs/by-name/np/npth/package.nix index 815c3dff031ec0..16e386e7214390 100644 --- a/pkgs/by-name/np/npth/package.nix +++ b/pkgs/by-name/np/npth/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, fetchpatch, autoreconfHook, pkgsCross }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + pkgsCross, +}: stdenv.mkDerivation rec { pname = "npth"; diff --git a/pkgs/by-name/nq/nq/package.nix b/pkgs/by-name/nq/nq/package.nix index 967547e2d85d48..03a7039259cd09 100644 --- a/pkgs/by-name/nq/nq/package.nix +++ b/pkgs/by-name/nq/nq/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "nq"; diff --git a/pkgs/by-name/nq/nqc/package.nix b/pkgs/by-name/nq/nqc/package.nix index a7d6cb5f2cdd01..1ff73d14f40427 100644 --- a/pkgs/by-name/nq/nqc/package.nix +++ b/pkgs/by-name/nq/nqc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "nqc"; diff --git a/pkgs/by-name/nq/nqptp/package.nix b/pkgs/by-name/nq/nqptp/package.nix index e045c3fe423791..3fc3bea073a5c2 100644 --- a/pkgs/by-name/nq/nqptp/package.nix +++ b/pkgs/by-name/nq/nqptp/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + gitUpdater, }: stdenv.mkDerivation rec { @@ -23,7 +24,10 @@ stdenv.mkDerivation rec { ./systemd-service-capability.patch ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; passthru.updateScript = gitUpdater { ignoredVersions = ".*(-dev|d0)"; @@ -39,7 +43,10 @@ stdenv.mkDerivation rec { description = "Daemon and companion application to Shairport Sync that monitors timing data from any PTP clocks"; license = lib.licenses.gpl2Only; mainProgram = "nqptp"; - maintainers = with lib.maintainers; [ jordanisaacs adamcstephens ]; + maintainers = with lib.maintainers; [ + jordanisaacs + adamcstephens + ]; platforms = lib.platforms.linux ++ lib.platforms.freebsd; }; } diff --git a/pkgs/by-name/nr/nrf-command-line-tools/package.nix b/pkgs/by-name/nr/nrf-command-line-tools/package.nix index 09644c15137819..f4b1bec1f78e51 100644 --- a/pkgs/by-name/nr/nrf-command-line-tools/package.nix +++ b/pkgs/by-name/nr/nrf-command-line-tools/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, udev -, libusb1 -, segger-jlink +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + udev, + libusb1, + segger-jlink, }: let @@ -27,11 +28,14 @@ let version = "10.23.2"; - url = let - versionWithDashes = builtins.replaceStrings ["."] ["-"] version; - in "https://nsscprodmedia.blob.core.windows.net/prod/software-and-other-downloads/desktop-software/nrf-command-line-tools/sw/versions-${lib.versions.major version}-x-x/${versionWithDashes}/nrf-command-line-tools-${version}_${platform.name}.tar.gz"; + url = + let + versionWithDashes = builtins.replaceStrings [ "." ] [ "-" ] version; + in + "https://nsscprodmedia.blob.core.windows.net/prod/software-and-other-downloads/desktop-software/nrf-command-line-tools/sw/versions-${lib.versions.major version}-x-x/${versionWithDashes}/nrf-command-line-tools-${version}_${platform.name}.tar.gz"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "nrf-command-line-tools"; inherit version; diff --git a/pkgs/by-name/nr/nrf-udev/package.nix b/pkgs/by-name/nr/nrf-udev/package.nix index 848199811c0861..01048df4ec61bc 100644 --- a/pkgs/by-name/nr/nrf-udev/package.nix +++ b/pkgs/by-name/nr/nrf-udev/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gitUpdater +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gitUpdater, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/nr/nrf5-sdk/package.nix b/pkgs/by-name/nr/nrf5-sdk/package.nix index c8667287a00205..4f45b9a47564b6 100644 --- a/pkgs/by-name/nr/nrf5-sdk/package.nix +++ b/pkgs/by-name/nr/nrf5-sdk/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchzip +{ + lib, + stdenv, + fetchzip, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/nr/nrfconnect/package.nix b/pkgs/by-name/nr/nrfconnect/package.nix index a60ddd533441d0..c7f7c529f74d6e 100644 --- a/pkgs/by-name/nr/nrfconnect/package.nix +++ b/pkgs/by-name/nr/nrfconnect/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchurl -, appimageTools +{ + lib, + fetchurl, + appimageTools, }: let @@ -17,7 +18,8 @@ let inherit pname version src; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; extraPkgs = pkgs: [ pkgs.segger-jlink ]; diff --git a/pkgs/by-name/nr/nrg2iso/package.nix b/pkgs/by-name/nr/nrg2iso/package.nix index a196f23544bb92..8bd8a00d495b82 100644 --- a/pkgs/by-name/nr/nrg2iso/package.nix +++ b/pkgs/by-name/nr/nrg2iso/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "nrg2iso"; diff --git a/pkgs/by-name/nr/nrpl/package.nix b/pkgs/by-name/nr/nrpl/package.nix index c842d16ba9a981..29ffdc552a521c 100644 --- a/pkgs/by-name/nr/nrpl/package.nix +++ b/pkgs/by-name/nr/nrpl/package.nix @@ -1,13 +1,22 @@ -{ lib, buildNimPackage, fetchFromGitHub, fetchpatch, makeWrapper, nim, pcre, tinycc }: +{ + lib, + buildNimPackage, + fetchFromGitHub, + fetchpatch, + makeWrapper, + nim, + pcre, + tinycc, +}: buildNimPackage { pname = "nrpl"; version = "20150522"; src = fetchFromGitHub { - owner = "wheineman"; - repo = "nrpl"; - rev = "6d6c189ab7d1c905cc29dc678d66e9e132026f69"; + owner = "wheineman"; + repo = "nrpl"; + rev = "6d6c189ab7d1c905cc29dc678d66e9e132026f69"; hash = "sha256-YpP1LJKX3cTPficoBUBGnUETwQX5rDCyIMxylSFNnrI="; }; @@ -16,8 +25,8 @@ buildNimPackage { patches = [ (fetchpatch { - url = "https://patch-diff.githubusercontent.com/raw/wheineman/nrpl/pull/12.patch"; - name = "update_for_new_nim.patch"; + url = "https://patch-diff.githubusercontent.com/raw/wheineman/nrpl/pull/12.patch"; + name = "update_for_new_nim.patch"; hash = "sha256-4fFj1RAxvQC9ysRBFlbEfMRPCzi+Rcu6lYEOC208zv0="; }) ]; @@ -26,7 +35,12 @@ buildNimPackage { postFixup = '' wrapProgram $out/bin/nrpl \ - --prefix PATH : ${lib.makeBinPath [ nim tinycc ]} + --prefix PATH : ${ + lib.makeBinPath [ + nim + tinycc + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/nr/nrsc5/package.nix b/pkgs/by-name/nr/nrsc5/package.nix index 2b1a2ff22188a8..ddb35c80c66eaa 100644 --- a/pkgs/by-name/nr/nrsc5/package.nix +++ b/pkgs/by-name/nr/nrsc5/package.nix @@ -1,7 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, - autoconf, automake, libtool, cmake, - rtl-sdr, libao, fftwFloat -} : +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + cmake, + rtl-sdr, + libao, + fftwFloat, +}: let src_faad2 = fetchFromGitHub { owner = "dsvensson"; @@ -12,7 +20,8 @@ let version = "1.0"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "nrsc5"; inherit version; @@ -37,10 +46,22 @@ in stdenv.mkDerivation { sed -i "s:set (FAAD2_PREFIX .*):set (FAAD2_PREFIX \"$srcRoot/faad2-prefix\"):" CMakeLists.txt ''; - nativeBuildInputs = [ cmake autoconf automake libtool ]; - buildInputs = [ rtl-sdr libao fftwFloat ]; + nativeBuildInputs = [ + cmake + autoconf + automake + libtool + ]; + buildInputs = [ + rtl-sdr + libao + fftwFloat + ]; - cmakeFlags = [ "-DUSE_COLOR=ON" "-DUSE_FAAD2=ON" ]; + cmakeFlags = [ + "-DUSE_COLOR=ON" + "-DUSE_FAAD2=ON" + ]; meta = with lib; { homepage = "https://github.com/theori-io/nrsc5"; @@ -51,4 +72,3 @@ in stdenv.mkDerivation { mainProgram = "nrsc5"; }; } - diff --git a/pkgs/by-name/ns/nsc/package.nix b/pkgs/by-name/ns/nsc/package.nix index fb9783a9980677..e0e3962e38b715 100644 --- a/pkgs/by-name/ns/nsc/package.nix +++ b/pkgs/by-name/ns/nsc/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/ns/nsf-ordlista/package.nix b/pkgs/by-name/ns/nsf-ordlista/package.nix index d3ec535c44e804..8972d1317821af 100644 --- a/pkgs/by-name/ns/nsf-ordlista/package.nix +++ b/pkgs/by-name/ns/nsf-ordlista/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchzip +{ + lib, + stdenvNoCC, + fetchzip, }: stdenvNoCC.mkDerivation { pname = "nsf-ordlista"; diff --git a/pkgs/by-name/ns/nsh/package.nix b/pkgs/by-name/ns/nsh/package.nix index fc7e5667a4f3d7..17560c92118ee2 100644 --- a/pkgs/by-name/ns/nsh/package.nix +++ b/pkgs/by-name/ns/nsh/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "nsh"; @@ -20,7 +24,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "nsh"; homepage = "https://github.com/nuta/nsh"; changelog = "https://github.com/nuta/nsh/raw/v${version}/docs/changelog.md"; - license = [ licenses.cc0 /* or */ licenses.mit ]; + license = [ + licenses.cc0 # or + licenses.mit + ]; maintainers = with maintainers; [ cafkafk ]; }; diff --git a/pkgs/by-name/ns/nsis/package.nix b/pkgs/by-name/ns/nsis/package.nix index 1651a3c43d9ffb..c16c9cea6bad14 100644 --- a/pkgs/by-name/ns/nsis/package.nix +++ b/pkgs/by-name/ns/nsis/package.nix @@ -1,27 +1,26 @@ -{ lib -, stdenv -, symlinkJoin -, fetchurl -, fetchzip -, scons -, zlib -, libiconv +{ + lib, + stdenv, + symlinkJoin, + fetchurl, + fetchzip, + scons, + zlib, + libiconv, }: stdenv.mkDerivation rec { pname = "nsis"; version = "3.06.1"; - src = - fetchurl { - url = "mirror://sourceforge/project/nsis/NSIS%203/${version}/nsis-${version}-src.tar.bz2"; - sha256 = "1w1z2m982l6j8lw8hy91c3979wbnqglcf4148f9v79vl32znhpcv"; - }; - srcWinDistributable = - fetchzip { - url = "mirror://sourceforge/project/nsis/NSIS%203/${version}/nsis-${version}.zip"; - sha256 = "04qm9jqbcybpwcrjlksggffdyafzwxxcaz9xhjw8w5rb95x7lw5q"; - }; + src = fetchurl { + url = "mirror://sourceforge/project/nsis/NSIS%203/${version}/nsis-${version}-src.tar.bz2"; + sha256 = "1w1z2m982l6j8lw8hy91c3979wbnqglcf4148f9v79vl32znhpcv"; + }; + srcWinDistributable = fetchzip { + url = "mirror://sourceforge/project/nsis/NSIS%203/${version}/nsis-${version}.zip"; + sha256 = "04qm9jqbcybpwcrjlksggffdyafzwxxcaz9xhjw8w5rb95x7lw5q"; + }; postUnpack = '' mkdir -p $out/share/nsis @@ -34,8 +33,8 @@ stdenv.mkDerivation rec { buildInputs = [ zlib ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; CPPPATH = symlinkJoin { - name = "nsis-includes"; - paths = [ zlib.dev ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; + name = "nsis-includes"; + paths = [ zlib.dev ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; }; LIBPATH = symlinkJoin { diff --git a/pkgs/by-name/ns/nsnake/package.nix b/pkgs/by-name/ns/nsnake/package.nix index a4ac391690ecd0..78ff27090da4be 100644 --- a/pkgs/by-name/ns/nsnake/package.nix +++ b/pkgs/by-name/ns/nsnake/package.nix @@ -1,4 +1,9 @@ -{ stdenv, fetchFromGitHub, lib, ncurses }: +{ + stdenv, + fetchFromGitHub, + lib, + ncurses, +}: stdenv.mkDerivation rec { pname = "nsnake"; diff --git a/pkgs/by-name/ns/nsplist/package.nix b/pkgs/by-name/ns/nsplist/package.nix index 92495409f65a7a..64cba193ce319f 100644 --- a/pkgs/by-name/ns/nsplist/package.nix +++ b/pkgs/by-name/ns/nsplist/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, flex +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + flex, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ns/nsq/package.nix b/pkgs/by-name/ns/nsq/package.nix index 94b77602c55038..fd7bc11e06494e 100644 --- a/pkgs/by-name/ns/nsq/package.nix +++ b/pkgs/by-name/ns/nsq/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "nsq"; @@ -15,7 +19,10 @@ buildGoModule rec { excludedPackages = [ "bench" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://nsq.io/"; diff --git a/pkgs/by-name/ns/nss_ldap/package.nix b/pkgs/by-name/ns/nss_ldap/package.nix index 784ecf2b39ccee..ae4c02f4394fc6 100644 --- a/pkgs/by-name/ns/nss_ldap/package.nix +++ b/pkgs/by-name/ns/nss_ldap/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, openldap, perl}: +{ + lib, + stdenv, + fetchurl, + openldap, + perl, +}: stdenv.mkDerivation rec { pname = "nss_ldap"; diff --git a/pkgs/by-name/ns/nss_pam_ldapd/package.nix b/pkgs/by-name/ns/nss_pam_ldapd/package.nix index 0cdbd52f6f6a08..48ecfec520e98f 100644 --- a/pkgs/by-name/ns/nss_pam_ldapd/package.nix +++ b/pkgs/by-name/ns/nss_pam_ldapd/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchurl -, pkg-config, makeWrapper, autoreconfHook -, openldap, python3, pam +{ + lib, + stdenv, + fetchurl, + pkg-config, + makeWrapper, + autoreconfHook, + openldap, + python3, + pam, }: stdenv.mkDerivation rec { @@ -12,8 +19,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-xtZh50aTy/Uxp5BjHKk7c/KR+yPMOUZbCd642iv7DhQ="; }; - nativeBuildInputs = [ pkg-config makeWrapper autoreconfHook ]; - buildInputs = [ openldap pam python3 ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + autoreconfHook + ]; + buildInputs = [ + openldap + pam + python3 + ]; preConfigure = '' substituteInPlace Makefile.in --replace "install-data-local: " "# install-data-local: " diff --git a/pkgs/by-name/ns/nss_wrapper/package.nix b/pkgs/by-name/ns/nss_wrapper/package.nix index 378ebf54c1f7f2..210fe4a311a7b9 100644 --- a/pkgs/by-name/ns/nss_wrapper/package.nix +++ b/pkgs/by-name/ns/nss_wrapper/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, cmake, pkg-config }: +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "nss_wrapper"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-3HmrByd5vkQDtFtgzQRN0TeA1LuWddJ6vxkyrafIqI0="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; meta = with lib; { description = "Wrapper for the user, group and hosts NSS API"; diff --git a/pkgs/by-name/ns/nssmdns/package.nix b/pkgs/by-name/ns/nssmdns/package.nix index 727c6007c71df5..f58f47b00b61e3 100644 --- a/pkgs/by-name/ns/nssmdns/package.nix +++ b/pkgs/by-name/ns/nssmdns/package.nix @@ -1,4 +1,10 @@ -{ lib, autoreconfHook, pkg-config, stdenv, fetchFromGitHub }: +{ + lib, + autoreconfHook, + pkg-config, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "nss-mdns"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-iRaf9/gu9VkGi1VbGpxvC5q+0M8ivezCz/oAKEg5V1M="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; # Note: Although `nss-mdns' works by talking to `avahi-daemon', it # doesn't depend on the Avahi libraries. Instead, it contains diff --git a/pkgs/by-name/ns/nsxiv/package.nix b/pkgs/by-name/ns/nsxiv/package.nix index b4059bbb2fa965..692f9f625ef2dc 100644 --- a/pkgs/by-name/ns/nsxiv/package.nix +++ b/pkgs/by-name/ns/nsxiv/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitea -, giflib -, imlib2 -, libXft -, libexif -, libwebp -, libinotify-kqueue -, conf ? null +{ + lib, + stdenv, + fetchFromGitea, + giflib, + imlib2, + libXft, + libexif, + libwebp, + libinotify-kqueue, + conf ? null, }: stdenv.mkDerivation (finalAttrs: { @@ -22,7 +23,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-UWaet7hVtgfuWTiNY4VcsMWTfS6L9r5w1fb/0dWz8SI="; }; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; buildInputs = [ giflib diff --git a/pkgs/by-name/ns/nsync/package.nix b/pkgs/by-name/ns/nsync/package.nix index 8df7bd6059928b..ccca46fbef079f 100644 --- a/pkgs/by-name/ns/nsync/package.nix +++ b/pkgs/by-name/ns/nsync/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake +{ + stdenv, + lib, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { @@ -25,7 +26,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/google/nsync"; description = "C library that exports various synchronization primitives"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ puffnfresh Luflosi ]; + maintainers = with lib.maintainers; [ + puffnfresh + Luflosi + ]; platforms = lib.platforms.unix; }; } diff --git a/pkgs/by-name/nt/ntbtls/package.nix b/pkgs/by-name/nt/ntbtls/package.nix index e1726a874fcd1b..96e00f37d0b68c 100644 --- a/pkgs/by-name/nt/ntbtls/package.nix +++ b/pkgs/by-name/nt/ntbtls/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, gettext, libgpg-error, libgcrypt, libksba, zlib }: +{ + lib, + stdenv, + fetchurl, + gettext, + libgpg-error, + libgcrypt, + libksba, + zlib, +}: stdenv.mkDerivation rec { pname = "ntbtls"; @@ -9,10 +18,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-vfy5kCSs7JxsS5mK1juzkh30z+5KdyrWwMoyTbvysHw="; }; - outputs = [ "dev" "out" ]; + outputs = [ + "dev" + "out" + ]; - buildInputs = [ libgcrypt libgpg-error libksba zlib ] - ++ lib.optional stdenv.hostPlatform.isDarwin gettext; + buildInputs = [ + libgcrypt + libgpg-error + libksba + zlib + ] ++ lib.optional stdenv.hostPlatform.isDarwin gettext; postInstall = '' moveToOutput "bin/ntbtls-config" $dev diff --git a/pkgs/by-name/nt/ntfs2btrfs/package.nix b/pkgs/by-name/nt/ntfs2btrfs/package.nix index f3f5e00f9f06cf..651a9b73209e79 100644 --- a/pkgs/by-name/nt/ntfs2btrfs/package.nix +++ b/pkgs/by-name/nt/ntfs2btrfs/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, fmt, lzo, pkg-config, zlib, zstd }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fmt, + lzo, + pkg-config, + zlib, + zstd, +}: stdenv.mkDerivation rec { pname = "ntfs2btrfs"; @@ -11,9 +21,17 @@ stdenv.mkDerivation rec { hash = "sha256-sZ8AWREe2jasy3hqLTjaLcOMCNsrDjz2eIuknA2TsEs="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ fmt lzo zlib zstd ]; + buildInputs = [ + fmt + lzo + zlib + zstd + ]; meta = { description = "CLI tool which does in-place conversion of Microsoft's NTFS filesystem to the open-source filesystem Btrfs"; diff --git a/pkgs/by-name/nt/ntirpc/package.nix b/pkgs/by-name/nt/ntirpc/package.nix index c584e1d0b685cc..f88180473f2ffb 100644 --- a/pkgs/by-name/nt/ntirpc/package.nix +++ b/pkgs/by-name/nt/ntirpc/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, krb5, liburcu , libtirpc, libnsl -} : +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + krb5, + liburcu, + libtirpc, + libnsl, +}: stdenv.mkDerivation rec { pname = "ntirpc"; @@ -13,14 +20,21 @@ stdenv.mkDerivation rec { sha256 = "sha256-e4eF09xwX2Qf/y9YfOGy7p6yhDFnKGI5cnrQy3o8c98="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postPatch = '' substituteInPlace ntirpc/netconfig.h --replace "/etc/netconfig" "$out/etc/netconfig" sed '1i#include ' -i src/work_pool.c ''; nativeBuildInputs = [ cmake ]; - buildInputs = [ krb5 liburcu libnsl ]; + buildInputs = [ + krb5 + liburcu + libnsl + ]; postInstall = '' mkdir -p $out/etc diff --git a/pkgs/by-name/nt/ntk/package.nix b/pkgs/by-name/nt/ntk/package.nix index 4ad3ba33cb5c9b..da570f2672ad2b 100644 --- a/pkgs/by-name/nt/ntk/package.nix +++ b/pkgs/by-name/nt/ntk/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cairo, libjpeg, libXft, pkg-config, python3, wafHook }: +{ + lib, + stdenv, + fetchFromGitHub, + cairo, + libjpeg, + libXft, + pkg-config, + python3, + wafHook, +}: stdenv.mkDerivation rec { pname = "ntk"; @@ -10,9 +20,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-NyEdg6e+9CI9V+TIgdpPyH1ei+Vq8pUxD3wPzWY5fEU="; }; - nativeBuildInputs = [ pkg-config wafHook ]; + nativeBuildInputs = [ + pkg-config + wafHook + ]; buildInputs = [ - cairo libjpeg libXft python3 + cairo + libjpeg + libXft + python3 ]; # NOTE: ntk provides its own waf script that is incompatible with new @@ -27,7 +43,10 @@ stdenv.mkDerivation rec { version = version; homepage = "http://non.tuxfamily.org/"; license = lib.licenses.lgpl21; - maintainers = with lib.maintainers; [ magnetophon nico202 ]; + maintainers = with lib.maintainers; [ + magnetophon + nico202 + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/nt/ntl/package.nix b/pkgs/by-name/nt/ntl/package.nix index 776608c4ad9610..028f0eae34239c 100644 --- a/pkgs/by-name/nt/ntl/package.nix +++ b/pkgs/by-name/nt/ntl/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchurl -, perl -, gmp -, gf2x ? null -# I asked the ntl maintainer weather or not to include gf2x by default: -# > If I remember correctly, gf2x is now thread safe, so there's no reason not to use it. -, withGf2x ? true -, tune ? false # tune for current system; non reproducible and time consuming +{ + stdenv, + lib, + fetchurl, + perl, + gmp, + gf2x ? null, + # I asked the ntl maintainer weather or not to include gf2x by default: + # > If I remember correctly, gf2x is now thread safe, so there's no reason not to use it. + withGf2x ? true, + tune ? false, # tune for current system; non reproducible and time consuming }: assert withGf2x -> gf2x != null; @@ -41,23 +42,25 @@ stdenv.mkDerivation rec { configurePlatforms = [ ]; # reference: http://shoup.net/ntl/doc/tour-unix.html - configureFlags = [ - "DEF_PREFIX=$(out)" - "SHARED=on" # genereate a shared library (as well as static) - "NATIVE=off" # don't target code to current hardware (reproducibility, portability) - "TUNE=${ - if tune then - "auto" - else if stdenv.hostPlatform.isx86 then - "x86" # "chooses options that should be well suited for most x86 platforms" - else - "generic" # "chooses options that should be OK for most platforms" - }" - "CXX=${stdenv.cc.targetPrefix}c++" - ] ++ lib.optionals withGf2x [ - "NTL_GF2X_LIB=on" - "GF2X_PREFIX=${gf2x}" - ]; + configureFlags = + [ + "DEF_PREFIX=$(out)" + "SHARED=on" # genereate a shared library (as well as static) + "NATIVE=off" # don't target code to current hardware (reproducibility, portability) + "TUNE=${ + if tune then + "auto" + else if stdenv.hostPlatform.isx86 then + "x86" # "chooses options that should be well suited for most x86 platforms" + else + "generic" # "chooses options that should be OK for most platforms" + }" + "CXX=${stdenv.cc.targetPrefix}c++" + ] + ++ lib.optionals withGf2x [ + "NTL_GF2X_LIB=on" + "GF2X_PREFIX=${gf2x}" + ]; doCheck = true; # takes some time diff --git a/pkgs/by-name/nt/ntlm-challenger/package.nix b/pkgs/by-name/nt/ntlm-challenger/package.nix index 1e96bda9e47026..6de3791b614509 100644 --- a/pkgs/by-name/nt/ntlm-challenger/package.nix +++ b/pkgs/by-name/nt/ntlm-challenger/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication { diff --git a/pkgs/by-name/nt/ntlmrecon/package.nix b/pkgs/by-name/nt/ntlmrecon/package.nix index 10a564706c9a5d..68db2197c5046d 100644 --- a/pkgs/by-name/nt/ntlmrecon/package.nix +++ b/pkgs/by-name/nt/ntlmrecon/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/nt/ntp/package.nix b/pkgs/by-name/nt/ntp/package.nix index 2321455b8bbb2a..a7123dff7a11c4 100644 --- a/pkgs/by-name/nt/ntp/package.nix +++ b/pkgs/by-name/nt/ntp/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchurl, openssl, perl, pps-tools, libcap }: +{ + stdenv, + lib, + fetchurl, + openssl, + perl, + pps-tools, + libcap, +}: stdenv.mkDerivation rec { pname = "ntp"; @@ -18,8 +26,15 @@ stdenv.mkDerivation rec { "--with-yielding-select=yes" ] ++ lib.optional stdenv.hostPlatform.isLinux "--enable-linuxcaps"; - buildInputs = [ openssl perl ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ pps-tools libcap ]; + buildInputs = + [ + openssl + perl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + pps-tools + libcap + ]; hardeningEnable = [ "pie" ]; diff --git a/pkgs/by-name/nt/nttcp/package.nix b/pkgs/by-name/nt/nttcp/package.nix index 7c7302cf19c6f3..d7b73bcee57e6e 100644 --- a/pkgs/by-name/nt/nttcp/package.nix +++ b/pkgs/by-name/nt/nttcp/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "nttcp"; diff --git a/pkgs/by-name/nt/ntttcp/package.nix b/pkgs/by-name/nt/ntttcp/package.nix index abf0acf8a8938d..4ff7ddcb2825a0 100644 --- a/pkgs/by-name/nt/ntttcp/package.nix +++ b/pkgs/by-name/nt/ntttcp/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "ntttcp"; diff --git a/pkgs/by-name/nu/nuXmv/package.nix b/pkgs/by-name/nu/nuXmv/package.nix index 5726796bfa1896..d9580d1f1318a4 100644 --- a/pkgs/by-name/nu/nuXmv/package.nix +++ b/pkgs/by-name/nu/nuXmv/package.nix @@ -1,19 +1,29 @@ -{ lib, stdenv, fetchurl, gmp, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + gmp, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "nuXmv"; version = "2.0.0"; src = fetchurl { - url = "https://es-static.fbk.eu/tools/nuxmv/downloads/nuXmv-${version}-${if stdenv.hostPlatform.isDarwin then "macosx64" else "linux64"}.tar.gz"; - sha256 = if stdenv.hostPlatform.isDarwin - then "sha256-48I+FhJUUam1nMCMMM47CwGO82BYsNz0eHDHXBfqO2E=" - else "sha256-Gf+QgAjTrysZj7qTtt1wcQPganDtO0YtRY4ykhLPzVo="; + url = "https://es-static.fbk.eu/tools/nuxmv/downloads/nuXmv-${version}-${ + if stdenv.hostPlatform.isDarwin then "macosx64" else "linux64" + }.tar.gz"; + sha256 = + if stdenv.hostPlatform.isDarwin then + "sha256-48I+FhJUUam1nMCMMM47CwGO82BYsNz0eHDHXBfqO2E=" + else + "sha256-Gf+QgAjTrysZj7qTtt1wcQPganDtO0YtRY4ykhLPzVo="; }; nativeBuildInputs = [ makeWrapper ]; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ gmp ]; - installPhase= '' + installPhase = '' runHook preInstall install -Dm755 -t $out/bin ./bin/nuXmv runHook postInstall @@ -29,6 +39,9 @@ stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; maintainers = with maintainers; [ siraben ]; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; }; } diff --git a/pkgs/by-name/nu/nucleiparser/package.nix b/pkgs/by-name/nu/nucleiparser/package.nix index d0b5fa1ccf34f3..d1af4451d9cf1f 100644 --- a/pkgs/by-name/nu/nucleiparser/package.nix +++ b/pkgs/by-name/nu/nucleiparser/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/nu/nudoku/package.nix b/pkgs/by-name/nu/nudoku/package.nix index aa1100b3395c67..76d639d07c1aa5 100644 --- a/pkgs/by-name/nu/nudoku/package.nix +++ b/pkgs/by-name/nu/nudoku/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, pkg-config, gettext, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + gettext, + ncurses, +}: stdenv.mkDerivation rec { pname = "nudoku"; @@ -25,7 +34,11 @@ stdenv.mkDerivation rec { substituteInPlace configure.ac --replace 0.19 0.20 ''; - nativeBuildInputs = [ autoreconfHook pkg-config gettext ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + gettext + ]; buildInputs = [ ncurses ]; configureFlags = lib.optional stdenv.hostPlatform.isMusl "--disable-nls"; @@ -39,4 +52,3 @@ stdenv.mkDerivation rec { maintainers = [ ]; }; } - diff --git a/pkgs/by-name/nu/nuget-to-nix/package.nix b/pkgs/by-name/nu/nuget-to-nix/package.nix index 6a746d30a8ff34..8aa73eb3a814a8 100644 --- a/pkgs/by-name/nu/nuget-to-nix/package.nix +++ b/pkgs/by-name/nu/nuget-to-nix/package.nix @@ -1,37 +1,40 @@ -{ lib -, runCommandLocal -, runtimeShell -, substituteAll -, nix -, coreutils -, jq -, xmlstarlet -, curl -, gnugrep -, gawk -, cacert +{ + lib, + runCommandLocal, + runtimeShell, + substituteAll, + nix, + coreutils, + jq, + xmlstarlet, + curl, + gnugrep, + gawk, + cacert, }: -runCommandLocal "nuget-to-nix" { - script = substituteAll { - src = ./nuget-to-nix.sh; - inherit runtimeShell cacert; +runCommandLocal "nuget-to-nix" + { + script = substituteAll { + src = ./nuget-to-nix.sh; + inherit runtimeShell cacert; - binPath = lib.makeBinPath [ - nix - coreutils - jq - xmlstarlet - curl - gnugrep - gawk - ]; - }; + binPath = lib.makeBinPath [ + nix + coreutils + jq + xmlstarlet + curl + gnugrep + gawk + ]; + }; - meta = { - description = "Convert a nuget packages directory to a lockfile for buildDotnetModule"; - mainProgram = "nuget-to-nix"; - }; -} '' - install -Dm755 $script $out/bin/nuget-to-nix -'' + meta = { + description = "Convert a nuget packages directory to a lockfile for buildDotnetModule"; + mainProgram = "nuget-to-nix"; + }; + } + '' + install -Dm755 $script $out/bin/nuget-to-nix + '' diff --git a/pkgs/by-name/nu/nuget/package.nix b/pkgs/by-name/nu/nuget/package.nix index 9473a95f43e4cb..c80812e295d93c 100644 --- a/pkgs/by-name/nu/nuget/package.nix +++ b/pkgs/by-name/nu/nuget/package.nix @@ -1,4 +1,10 @@ -{ stdenv, fetchFromGitHub, makeWrapper, mono, lib }: +{ + stdenv, + fetchFromGitHub, + makeWrapper, + mono, + lib, +}: stdenv.mkDerivation (attrs: { pname = "Nuget"; diff --git a/pkgs/by-name/nu/nuked-md/package.nix b/pkgs/by-name/nu/nuked-md/package.nix index 3f42ce6d2d0773..41db685d2755f1 100644 --- a/pkgs/by-name/nu/nuked-md/package.nix +++ b/pkgs/by-name/nu/nuked-md/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, gitUpdater -, cmake -, SDL2 +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + gitUpdater, + cmake, + SDL2, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/nu/nullidentdmod/package.nix b/pkgs/by-name/nu/nullidentdmod/package.nix index 7df6eac5fb0d6f..347319f6016c3e 100644 --- a/pkgs/by-name/nu/nullidentdmod/package.nix +++ b/pkgs/by-name/nu/nullidentdmod/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ... }: +{ + lib, + stdenv, + fetchFromGitHub, + ... +}: stdenv.mkDerivation rec { pname = "nullidentdmod"; diff --git a/pkgs/by-name/nu/nulloy/package.nix b/pkgs/by-name/nu/nulloy/package.nix index 203ddf84c40993..9355fcc1d24d9f 100644 --- a/pkgs/by-name/nu/nulloy/package.nix +++ b/pkgs/by-name/nu/nulloy/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, which -, pkg-config -, zip -, imagemagick -, qt5 -, taglib -, gst_all_1 +{ + lib, + stdenv, + fetchFromGitHub, + which, + pkg-config, + zip, + imagemagick, + qt5, + taglib, + gst_all_1, }: stdenv.mkDerivation rec { @@ -30,17 +31,19 @@ stdenv.mkDerivation rec { qt5.wrapQtAppsHook ]; - buildInputs = [ - qt5.qtscript - qt5.qtsvg - taglib - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-good - gst-plugins-bad - gst-plugins-ugly - ]); + buildInputs = + [ + qt5.qtscript + qt5.qtsvg + taglib + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + gst-plugins-ugly + ]); prefixKey = "--prefix "; diff --git a/pkgs/by-name/nu/num-utils/package.nix b/pkgs/by-name/nu/num-utils/package.nix index 14784a4e8cfcda..fc032d90699ac9 100644 --- a/pkgs/by-name/nu/num-utils/package.nix +++ b/pkgs/by-name/nu/num-utils/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "num-utils"; diff --git a/pkgs/by-name/nu/numactl/package.nix b/pkgs/by-name/nu/numactl/package.nix index 4eceef0b2bf11b..9621374c457947 100644 --- a/pkgs/by-name/nu/numactl/package.nix +++ b/pkgs/by-name/nu/numactl/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "numactl"; @@ -19,7 +25,11 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; nativeBuildInputs = [ autoreconfHook ]; @@ -35,7 +45,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Library and tools for non-uniform memory access (NUMA) machines"; homepage = "https://github.com/numactl/numactl"; - license = with licenses; [ gpl2Only lgpl21 ]; # libnuma is lgpl21 + license = with licenses; [ + gpl2Only + lgpl21 + ]; # libnuma is lgpl21 platforms = platforms.linux; }; } diff --git a/pkgs/by-name/nu/numad/package.nix b/pkgs/by-name/nu/numad/package.nix index 99c34a7f2f9849..f3128b68709d03 100644 --- a/pkgs/by-name/nu/numad/package.nix +++ b/pkgs/by-name/nu/numad/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchgit, unstableGitUpdater, writeShellScript }: +{ + lib, + stdenv, + fetchgit, + unstableGitUpdater, + writeShellScript, +}: stdenv.mkDerivation { pname = "numad"; diff --git a/pkgs/by-name/nu/numatop/package.nix b/pkgs/by-name/nu/numatop/package.nix index 159afa467dc3da..16f5401f883833 100644 --- a/pkgs/by-name/nu/numatop/package.nix +++ b/pkgs/by-name/nu/numatop/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, pkg-config, numactl, ncurses, check }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + numactl, + ncurses, + check, +}: stdenv.mkDerivation rec { pname = "numatop"; @@ -10,8 +20,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-GJvTwqgx34ZW10eIJj/xiKe3ZkAfs7GlJImz8jrnjfI="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ numactl ncurses ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + numactl + ncurses + ]; nativeCheckInputs = [ check ]; patches = [ @@ -29,7 +45,7 @@ stdenv.mkDerivation rec { }) ]; - doCheck = true; + doCheck = true; meta = with lib; { description = "Tool for runtime memory locality characterization and analysis of processes and threads on a NUMA system"; @@ -38,8 +54,10 @@ stdenv.mkDerivation rec { license = licenses.bsd3; maintainers = with maintainers; [ dtzWill ]; platforms = [ - "i686-linux" "x86_64-linux" - "powerpc64-linux" "powerpc64le-linux" + "i686-linux" + "x86_64-linux" + "powerpc64-linux" + "powerpc64le-linux" ]; }; } diff --git a/pkgs/by-name/nu/numberstation/package.nix b/pkgs/by-name/nu/numberstation/package.nix index 651e4420280df4..2b2db29ab39662 100644 --- a/pkgs/by-name/nu/numberstation/package.nix +++ b/pkgs/by-name/nu/numberstation/package.nix @@ -1,16 +1,17 @@ -{ lib -, python3 -, fetchFromSourcehut -, desktop-file-utils -, glib -, gobject-introspection -, gtk3 -, libhandy -, librsvg -, meson -, ninja -, pkg-config -, wrapGAppsHook3 +{ + lib, + python3, + fetchFromSourcehut, + desktop-file-utils, + glib, + gobject-introspection, + gtk3, + libhandy, + librsvg, + meson, + ninja, + pkg-config, + wrapGAppsHook3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/nu/numcpp/package.nix b/pkgs/by-name/nu/numcpp/package.nix index 34dd82c15076b1..e1f49e44dbd51e 100644 --- a/pkgs/by-name/nu/numcpp/package.nix +++ b/pkgs/by-name/nu/numcpp/package.nix @@ -18,11 +18,14 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-1LGyDvT+PiGRXn7NorcYUjSPzNuRv/YXhQWIaOa7xdo="; }; - nativeCheckInputs = [gtest python3]; + nativeCheckInputs = [ + gtest + python3 + ]; - nativeBuildInputs = [cmake]; + nativeBuildInputs = [ cmake ]; - buildInputs = [boost]; + buildInputs = [ boost ]; cmakeFlags = lib.optionals finalAttrs.finalPackage.doCheck [ "-DBUILD_TESTS=ON" @@ -36,13 +39,13 @@ stdenv.mkDerivation (finalAttrs: { --replace "\''${PACKAGE_PREFIX_DIR}/" "" ''; - NIX_CFLAGS_COMPILE="-Wno-error"; + NIX_CFLAGS_COMPILE = "-Wno-error"; meta = with lib; { description = "Templatized Header Only C++ Implementation of the Python NumPy Library"; homepage = "https://github.com/dpilger26/NumCpp"; license = licenses.mit; - maintainers = with maintainers; [spalf]; + maintainers = with maintainers; [ spalf ]; platforms = platforms.unix; }; }) diff --git a/pkgs/by-name/nu/numdiff/package.nix b/pkgs/by-name/nu/numdiff/package.nix index f12c0fdea5e80d..dc9c37da0e5d09 100644 --- a/pkgs/by-name/nu/numdiff/package.nix +++ b/pkgs/by-name/nu/numdiff/package.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, fetchurl, libintl }: - +{ + lib, + stdenv, + fetchurl, + libintl, +}: stdenv.mkDerivation rec { pname = "numdiff"; diff --git a/pkgs/by-name/nu/numix-cursor-theme/package.nix b/pkgs/by-name/nu/numix-cursor-theme/package.nix index 83961f19caf835..e2063ad8d797c3 100644 --- a/pkgs/by-name/nu/numix-cursor-theme/package.nix +++ b/pkgs/by-name/nu/numix-cursor-theme/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenvNoCC, fetchFromGitHub, inkscape, xcursorgen }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + inkscape, + xcursorgen, +}: stdenvNoCC.mkDerivation rec { pname = "numix-cursor-theme"; @@ -11,7 +17,10 @@ stdenvNoCC.mkDerivation rec { sha256 = "1q3w5i0h3ly6i7s9pqjdrb14kp89i78s0havri7lhiqyxizjvcvh"; }; - nativeBuildInputs = [ inkscape xcursorgen ]; + nativeBuildInputs = [ + inkscape + xcursorgen + ]; buildPhase = '' patchShebangs . diff --git a/pkgs/by-name/nu/numix-gtk-theme/package.nix b/pkgs/by-name/nu/numix-gtk-theme/package.nix index a55970d5dccf6f..9cd859e9906d8c 100644 --- a/pkgs/by-name/nu/numix-gtk-theme/package.nix +++ b/pkgs/by-name/nu/numix-gtk-theme/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, sassc -, glib -, libxml2 -, gdk-pixbuf -, gtk-engine-murrine -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + sassc, + glib, + libxml2, + gdk-pixbuf, + gtk-engine-murrine, + gitUpdater, }: stdenv.mkDerivation rec { @@ -20,7 +21,12 @@ stdenv.mkDerivation rec { hash = "sha256-7KX5xC6Gr6azqL2qyc8rYb3q9UhcGco2uEfltsQ+mgo="; }; - nativeBuildInputs = [ sassc glib libxml2 gdk-pixbuf ]; + nativeBuildInputs = [ + sassc + glib + libxml2 + gdk-pixbuf + ]; propagatedUserEnvPkgs = [ gtk-engine-murrine ]; diff --git a/pkgs/by-name/nu/numix-icon-theme-circle/package.nix b/pkgs/by-name/nu/numix-icon-theme-circle/package.nix index a8eba52dac6bc3..e7ddbccebb59f2 100644 --- a/pkgs/by-name/nu/numix-icon-theme-circle/package.nix +++ b/pkgs/by-name/nu/numix-icon-theme-circle/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenvNoCC, fetchFromGitHub, gtk3, numix-icon-theme, hicolor-icon-theme, gitUpdater }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + numix-icon-theme, + hicolor-icon-theme, + gitUpdater, +}: stdenvNoCC.mkDerivation rec { pname = "numix-icon-theme-circle"; @@ -13,7 +21,10 @@ stdenvNoCC.mkDerivation rec { nativeBuildInputs = [ gtk3 ]; - propagatedBuildInputs = [ numix-icon-theme hicolor-icon-theme ]; + propagatedBuildInputs = [ + numix-icon-theme + hicolor-icon-theme + ]; dontDropIconThemeCache = true; diff --git a/pkgs/by-name/nu/numix-icon-theme-square/package.nix b/pkgs/by-name/nu/numix-icon-theme-square/package.nix index 9511e75ebf9021..fd9c22d052ce28 100644 --- a/pkgs/by-name/nu/numix-icon-theme-square/package.nix +++ b/pkgs/by-name/nu/numix-icon-theme-square/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenvNoCC, fetchFromGitHub, gtk3, numix-icon-theme, hicolor-icon-theme, gitUpdater }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + numix-icon-theme, + hicolor-icon-theme, + gitUpdater, +}: stdenvNoCC.mkDerivation rec { pname = "numix-icon-theme-square"; @@ -13,7 +21,10 @@ stdenvNoCC.mkDerivation rec { nativeBuildInputs = [ gtk3 ]; - propagatedBuildInputs = [ numix-icon-theme hicolor-icon-theme ]; + propagatedBuildInputs = [ + numix-icon-theme + hicolor-icon-theme + ]; dontDropIconThemeCache = true; diff --git a/pkgs/by-name/nu/numix-solarized-gtk-theme/package.nix b/pkgs/by-name/nu/numix-solarized-gtk-theme/package.nix index 55e606e6a0a94d..f7e49daef61f14 100644 --- a/pkgs/by-name/nu/numix-solarized-gtk-theme/package.nix +++ b/pkgs/by-name/nu/numix-solarized-gtk-theme/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, python3, sassc, glib, gdk-pixbuf, inkscape, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + sassc, + glib, + gdk-pixbuf, + inkscape, + gtk-engine-murrine, +}: stdenv.mkDerivation rec { pname = "numix-solarized-gtk-theme"; @@ -11,7 +21,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-r5xCe8Ew+/SuCUaZ0yjlumORTy/y1VwbQQjQ6uEyGsY="; }; - nativeBuildInputs = [ python3 sassc glib gdk-pixbuf inkscape ]; + nativeBuildInputs = [ + python3 + sassc + glib + gdk-pixbuf + inkscape + ]; propagatedUserEnvPkgs = [ gtk-engine-murrine ]; diff --git a/pkgs/by-name/nu/numix-sx-gtk-theme/package.nix b/pkgs/by-name/nu/numix-sx-gtk-theme/package.nix index ee887cbadee16f..c90b81d4e42a2d 100644 --- a/pkgs/by-name/nu/numix-sx-gtk-theme/package.nix +++ b/pkgs/by-name/nu/numix-sx-gtk-theme/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchurl, + gtk-engine-murrine, +}: stdenv.mkDerivation { version = "2017-04-24"; diff --git a/pkgs/by-name/nu/numlockx/package.nix b/pkgs/by-name/nu/numlockx/package.nix index 32eb652d8b721f..9c50ce5d7c82d6 100644 --- a/pkgs/by-name/nu/numlockx/package.nix +++ b/pkgs/by-name/nu/numlockx/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, libX11, libXext }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + libX11, + libXext, +}: stdenv.mkDerivation { version = "1.2"; @@ -11,7 +18,11 @@ stdenv.mkDerivation { hash = "sha256-wrHBelxEADUKugmtR8loWaJ/6s5U4PBBz8V+Dr1yifA="; }; - buildInputs = [ libX11 libXext autoconf ]; + buildInputs = [ + libX11 + libXext + autoconf + ]; meta = { description = "Allows to start X with NumLock turned on"; diff --git a/pkgs/by-name/nu/numworks-epsilon/package.nix b/pkgs/by-name/nu/numworks-epsilon/package.nix index 71da675614da97..337322bfb039d9 100644 --- a/pkgs/by-name/nu/numworks-epsilon/package.nix +++ b/pkgs/by-name/nu/numworks-epsilon/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, libpng -, libjpeg -, freetype -, xorg -, python3 -, imagemagick -, gcc-arm-embedded -, pkg-config -, python3Packages +{ + stdenv, + lib, + fetchFromGitHub, + libpng, + libjpeg, + freetype, + xorg, + python3, + imagemagick, + gcc-arm-embedded, + pkg-config, + python3Packages, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/nu/nuraft/package.nix b/pkgs/by-name/nu/nuraft/package.nix index e26d9f467e7fbb..1176313a2805ee 100644 --- a/pkgs/by-name/nu/nuraft/package.nix +++ b/pkgs/by-name/nu/nuraft/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, boost, asio, openssl, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + boost, + asio, + openssl, + zlib, +}: stdenv.mkDerivation rec { pname = "nuraft"; @@ -22,7 +32,12 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ boost asio openssl zlib ]; + buildInputs = [ + boost + asio + openssl + zlib + ]; meta = with lib; { homepage = "https://github.com/eBay/NuRaft"; diff --git a/pkgs/by-name/nu/nurl/package.nix b/pkgs/by-name/nu/nurl/package.nix index 752427cdb0e943..0e7a927dbabfbf 100644 --- a/pkgs/by-name/nu/nurl/package.nix +++ b/pkgs/by-name/nu/nurl/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, makeBinaryWrapper -, stdenv -, darwin -, gitMinimal -, mercurial -, nix +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + makeBinaryWrapper, + stdenv, + darwin, + gitMinimal, + mercurial, + nix, }: rustPlatform.buildRustPackage rec { @@ -42,7 +43,13 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram $out/bin/nurl \ - --prefix PATH : ${lib.makeBinPath [ gitMinimal mercurial nix ]} + --prefix PATH : ${ + lib.makeBinPath [ + gitMinimal + mercurial + nix + ] + } installManPage artifacts/nurl.1 installShellCompletion artifacts/nurl.{bash,fish} --zsh artifacts/_nurl ''; diff --git a/pkgs/by-name/nu/nusmv/package.nix b/pkgs/by-name/nu/nusmv/package.nix index 058949083caf0d..456970b7ee0aa4 100644 --- a/pkgs/by-name/nu/nusmv/package.nix +++ b/pkgs/by-name/nu/nusmv/package.nix @@ -1,22 +1,30 @@ -{ stdenv -, lib -, fetchurl -, autoPatchelfHook +{ + stdenv, + lib, + fetchurl, + autoPatchelfHook, }: stdenv.mkDerivation rec { pname = "NuSMV"; version = "2.6.0"; - src = with stdenv; fetchurl ( - if isx86_64 && isLinux then { - url = "https://nusmv.fbk.eu/distrib/NuSMV-${version}-linux64.tar.gz"; - sha256 = "1370x2vwjndv9ham5q399nn84hvhm1gj1k7pq576qmh4pi12xc8i"; - } else if isx86_32 && isLinux then { - url = "https://nusmv.fbk.eu/distrib/NuSMV-${version}-linux32.tar.gz"; - sha256 = "1qf41czwbqxlrmv0rv2daxgz2hljza5xks85sx3dhwpjy2iav9jb"; - } else throw "only linux x86_64 and x86_32 are currently supported") ; - + src = + with stdenv; + fetchurl ( + if isx86_64 && isLinux then + { + url = "https://nusmv.fbk.eu/distrib/NuSMV-${version}-linux64.tar.gz"; + sha256 = "1370x2vwjndv9ham5q399nn84hvhm1gj1k7pq576qmh4pi12xc8i"; + } + else if isx86_32 && isLinux then + { + url = "https://nusmv.fbk.eu/distrib/NuSMV-${version}-linux32.tar.gz"; + sha256 = "1qf41czwbqxlrmv0rv2daxgz2hljza5xks85sx3dhwpjy2iav9jb"; + } + else + throw "only linux x86_64 and x86_32 are currently supported" + ); nativeBuildInputs = [ autoPatchelfHook ]; diff --git a/pkgs/by-name/nu/nut/package.nix b/pkgs/by-name/nu/nut/package.nix index cded819dbb5bed..998549a84e96b2 100644 --- a/pkgs/by-name/nu/nut/package.nix +++ b/pkgs/by-name/nu/nut/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, autoreconfHook -, avahi -, coreutils -, fetchurl -, freeipmi -, gd -, i2c-tools -, libgpiod_1 -, libmodbus -, libtool -, libusb1 -, makeWrapper -, neon -, net-snmp -, openssl -, pkg-config -, substituteAll -, systemd -, udev -, gnused +{ + lib, + stdenv, + autoreconfHook, + avahi, + coreutils, + fetchurl, + freeipmi, + gd, + i2c-tools, + libgpiod_1, + libmodbus, + libtool, + libusb1, + makeWrapper, + neon, + net-snmp, + openssl, + pkg-config, + substituteAll, + systemd, + udev, + gnused, }: stdenv.mkDerivation rec { @@ -51,25 +52,50 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ neon libusb1 openssl udev avahi freeipmi libgpiod_1 libmodbus libtool i2c-tools net-snmp gd ]; + buildInputs = [ + neon + libusb1 + openssl + udev + avahi + freeipmi + libgpiod_1 + libmodbus + libtool + i2c-tools + net-snmp + gd + ]; - nativeBuildInputs = [ autoreconfHook pkg-config makeWrapper ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + makeWrapper + ]; - configureFlags = - [ "--with-all" - "--with-ssl" - "--without-powerman" # Until we have it ... - "--with-systemdsystemunitdir=$(out)/lib/systemd/system" - "--with-systemdshutdowndir=$(out)/lib/systemd/system-shutdown" - "--with-systemdtmpfilesdir=$(out)/lib/tmpfiles.d" - "--with-udev-dir=$(out)/etc/udev" - ]; + configureFlags = [ + "--with-all" + "--with-ssl" + "--without-powerman" # Until we have it ... + "--with-systemdsystemunitdir=$(out)/lib/systemd/system" + "--with-systemdshutdowndir=$(out)/lib/systemd/system-shutdown" + "--with-systemdtmpfilesdir=$(out)/lib/tmpfiles.d" + "--with-udev-dir=$(out)/etc/udev" + ]; enableParallelBuilding = true; # Add `cgi-bin` to the default list to avoid pulling in whole # of `gcc` into build closure. - stripDebugList = [ "cgi-bin" "lib" "lib32" "lib64" "libexec" "bin" "sbin" ]; + stripDebugList = [ + "cgi-bin" + "lib" + "lib32" + "lib64" + "libexec" + "bin" + "sbin" + ]; postInstall = '' substituteInPlace $out/lib/systemd/system-shutdown/nutshutdown \ @@ -99,7 +125,11 @@ stdenv.mkDerivation rec { homepage = "https://networkupstools.org/"; platforms = platforms.linux; maintainers = [ maintainers.pierron ]; - license = with licenses; [ gpl1Plus gpl2Plus gpl3Plus ]; + license = with licenses; [ + gpl1Plus + gpl2Plus + gpl3Plus + ]; priority = 10; }; } diff --git a/pkgs/by-name/nu/nuttcp/package.nix b/pkgs/by-name/nu/nuttcp/package.nix index 7bee729c4ed967..c5e700a39a5887 100644 --- a/pkgs/by-name/nu/nuttcp/package.nix +++ b/pkgs/by-name/nu/nuttcp/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, installShellFiles +{ + lib, + stdenv, + fetchurl, + installShellFiles, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/nu/nuv/package.nix b/pkgs/by-name/nu/nuv/package.nix index f4ae78469d9fd8..0cd295b98b9c13 100644 --- a/pkgs/by-name/nu/nuv/package.nix +++ b/pkgs/by-name/nu/nuv/package.nix @@ -1,16 +1,17 @@ -{ lib -, symlinkJoin -, callPackage -, fetchFromGitHub -, buildGoModule -, makeWrapper -, jq -, curl -, kubectl -, eksctl -, kind -, k3sup -, coreutils +{ + lib, + symlinkJoin, + callPackage, + fetchFromGitHub, + buildGoModule, + makeWrapper, + jq, + curl, + kubectl, + eksctl, + kind, + k3sup, + coreutils, }: let @@ -31,7 +32,11 @@ buildGoModule { subPackages = [ "." ]; vendorHash = "sha256-JkQbQ2NEaumXbAfsv0fNiQf/EwMs3SDLHvu7c/bU7fU="; - nativeBuildInputs = [ makeWrapper jq curl ]; + nativeBuildInputs = [ + makeWrapper + jq + curl + ]; ldflags = [ "-s" @@ -43,20 +48,22 @@ buildGoModule { # false because tests require some modifications inside nix-env doCheck = false; - postInstall = let - nuv-bin = symlinkJoin { - name = "nuv-bin"; - paths = [ - coreutils - kubectl - eksctl - kind - k3sup - ]; - }; - in '' - wrapProgram $out/bin/nuv --set NUV_BIN "${nuv-bin}/bin" - ''; + postInstall = + let + nuv-bin = symlinkJoin { + name = "nuv-bin"; + paths = [ + coreutils + kubectl + eksctl + kind + k3sup + ]; + }; + in + '' + wrapProgram $out/bin/nuv --set NUV_BIN "${nuv-bin}/bin" + ''; passthru.tests = { simple = callPackage ./tests.nix { inherit version; }; @@ -67,6 +74,9 @@ buildGoModule { description = "A CLI tool for running tasks using the Nuvolaris serverless engine"; license = lib.licenses.asl20; mainProgram = "nuv"; - maintainers = with lib.maintainers; [ msciabarra d4rkstar ]; + maintainers = with lib.maintainers; [ + msciabarra + d4rkstar + ]; }; } diff --git a/pkgs/by-name/nu/nuv/tests.nix b/pkgs/by-name/nu/nuv/tests.nix index 4e531728e8ff40..e49c2d872b120b 100644 --- a/pkgs/by-name/nu/nuv/tests.nix +++ b/pkgs/by-name/nu/nuv/tests.nix @@ -1,17 +1,22 @@ -{ runCommand, nuv, version }: +{ + runCommand, + nuv, + version, +}: runCommand "nuv-test-run" -{ - nativeBuildInputs = [ nuv ]; -} '' - export TMP_BASE=$(mktemp -d /tmp/.nuv-XXXXX) - export HOME=$TMP_BASE - export NUV_REPO="" - export NUV_ROOT=$TMP_BASE/.nuv/3.0.0/olaris - rm -rf $TMP_BASE/.nuv && \ - mkdir -p $TMP_BASE/.nuv/3.0.0/olaris && \ - mkdir $TMP_BASE/.nuv/tmp - V=$(nuv -version 2>/dev/null) - diff -U3 --color=auto <(echo "$V") <(echo "${version}") - touch $out -'' + { + nativeBuildInputs = [ nuv ]; + } + '' + export TMP_BASE=$(mktemp -d /tmp/.nuv-XXXXX) + export HOME=$TMP_BASE + export NUV_REPO="" + export NUV_ROOT=$TMP_BASE/.nuv/3.0.0/olaris + rm -rf $TMP_BASE/.nuv && \ + mkdir -p $TMP_BASE/.nuv/3.0.0/olaris && \ + mkdir $TMP_BASE/.nuv/tmp + V=$(nuv -version 2>/dev/null) + diff -U3 --color=auto <(echo "$V") <(echo "${version}") + touch $out + '' diff --git a/pkgs/by-name/nu/nuweb/package.nix b/pkgs/by-name/nu/nuweb/package.nix index bc7841843a8d0a..b5c926b02b83b0 100644 --- a/pkgs/by-name/nu/nuweb/package.nix +++ b/pkgs/by-name/nu/nuweb/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, texliveMedium}: +{ + lib, + stdenv, + fetchurl, + texliveMedium, +}: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/nu/nux/package.nix b/pkgs/by-name/nu/nux/package.nix index 45bb1836260500..a457bbd7b001e3 100644 --- a/pkgs/by-name/nu/nux/package.nix +++ b/pkgs/by-name/nu/nux/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, asciidoctor -, installShellFiles +{ + lib, + fetchFromGitHub, + rustPlatform, + asciidoctor, + installShellFiles, }: let @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage { cargoHash = "sha256-wfUr3dcdALMEgJ6CaXhK4Gqk6xflCnov9tELA63drV4="; - nativeBuildInputs = [ asciidoctor installShellFiles ]; + nativeBuildInputs = [ + asciidoctor + installShellFiles + ]; postInstall = '' installManPage $releaseDir/build/nux-*/out/nux.1 diff --git a/pkgs/by-name/nv/nv-codec-headers/package.nix b/pkgs/by-name/nv/nv-codec-headers/package.nix index 39179db9034fbb..fe14a78e3eff3b 100644 --- a/pkgs/by-name/nv/nv-codec-headers/package.nix +++ b/pkgs/by-name/nv/nv-codec-headers/package.nix @@ -8,13 +8,15 @@ let sources = callPackage ./sources.nix { }; - pick = { - "8" = sources.nv-codec-headers-8; - "9" = sources.nv-codec-headers-9; - "10" = sources.nv-codec-headers-10; - "11" = sources.nv-codec-headers-11; - "12" = sources.nv-codec-headers-12; - }.${majorVersion}; + pick = + { + "8" = sources.nv-codec-headers-8; + "9" = sources.nv-codec-headers-9; + "10" = sources.nv-codec-headers-10; + "11" = sources.nv-codec-headers-11; + "12" = sources.nv-codec-headers-12; + } + .${majorVersion}; in stdenvNoCC.mkDerivation { inherit (pick) pname version src; diff --git a/pkgs/by-name/nv/nvd/package.nix b/pkgs/by-name/nv/nvd/package.nix index 22fba65b72976c..2cc7afa9f97e4c 100644 --- a/pkgs/by-name/nv/nvd/package.nix +++ b/pkgs/by-name/nv/nvd/package.nix @@ -1,8 +1,9 @@ -{ fetchFromSourcehut -, installShellFiles -, lib -, python3 -, stdenv +{ + fetchFromSourcehut, + installShellFiles, + lib, + python3, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/nv/nvdtools/package.nix b/pkgs/by-name/nv/nvdtools/package.nix index b797c50da44776..23a160c752cbb1 100644 --- a/pkgs/by-name/nv/nvdtools/package.nix +++ b/pkgs/by-name/nv/nvdtools/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/nv/nvi/package.nix b/pkgs/by-name/nv/nvi/package.nix index c5ef872bffff1c..d8c3fe35c95ffe 100644 --- a/pkgs/by-name/nv/nvi/package.nix +++ b/pkgs/by-name/nv/nvi/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, fetchpatch, ncurses, db }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + ncurses, + db, +}: stdenv.mkDerivation rec { pname = "nvi"; @@ -23,7 +30,10 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ ncurses db ]; + buildInputs = [ + ncurses + db + ]; preConfigure = '' cd build.unix diff --git a/pkgs/by-name/nv/nvidia-container-toolkit/nvidia-docker.nix b/pkgs/by-name/nv/nvidia-container-toolkit/nvidia-docker.nix index 9690be4d7735ae..aedeb2b39599cb 100644 --- a/pkgs/by-name/nv/nvidia-container-toolkit/nvidia-docker.nix +++ b/pkgs/by-name/nv/nvidia-container-toolkit/nvidia-docker.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "nvidia-docker"; version = "2.5.0"; diff --git a/pkgs/by-name/nv/nvidia-container-toolkit/package.nix b/pkgs/by-name/nv/nvidia-container-toolkit/package.nix index 4fa5177d25427b..aa4f28e72e83f9 100644 --- a/pkgs/by-name/nv/nvidia-container-toolkit/package.nix +++ b/pkgs/by-name/nv/nvidia-container-toolkit/package.nix @@ -1,20 +1,26 @@ -{ lib -, glibc -, fetchFromGitLab -, makeWrapper -, buildGoModule -, formats -, configTemplate ? null -, configTemplatePath ? null -, libnvidia-container -, autoAddDriverRunpath +{ + lib, + glibc, + fetchFromGitLab, + makeWrapper, + buildGoModule, + formats, + configTemplate ? null, + configTemplatePath ? null, + libnvidia-container, + autoAddDriverRunpath, }: assert configTemplate != null -> (lib.isAttrs configTemplate && configTemplatePath == null); -assert configTemplatePath != null -> (lib.isStringLike configTemplatePath && configTemplate == null); +assert + configTemplatePath != null -> (lib.isStringLike configTemplatePath && configTemplate == null); let - configToml = if configTemplatePath != null then configTemplatePath else (formats.toml { }).generate "config.toml" configTemplate; + configToml = + if configTemplatePath != null then + configTemplatePath + else + (formats.toml { }).generate "config.toml" configTemplate; # From https://gitlab.com/nvidia/container-toolkit/container-toolkit/-/blob/03cbf9c6cd26c75afef8a2dd68e0306aace80401/Makefile#L54 cliVersionPackage = "github.com/NVIDIA/nvidia-container-toolkit/internal/info"; @@ -31,7 +37,10 @@ buildGoModule rec { }; - outputs = [ "out" "tools" ]; + outputs = [ + "out" + "tools" + ]; vendorHash = null; @@ -84,22 +93,27 @@ buildGoModule rec { "TestDuplicateHook" ]; in - [ "-skip" "${builtins.concatStringsSep "|" skippedTests}" ]; - - postInstall = '' - wrapProgram $out/bin/nvidia-container-runtime-hook \ - --prefix PATH : ${libnvidia-container}/bin - - mkdir -p $tools/bin - mv $out/bin/{containerd,crio,docker,nvidia-toolkit,toolkit} $tools/bin - '' + lib.optionalString (configTemplate != null || configTemplatePath != null) '' - mkdir -p $out/etc/nvidia-container-runtime - - cp ${configToml} $out/etc/nvidia-container-runtime/config.toml - - substituteInPlace $out/etc/nvidia-container-runtime/config.toml \ - --subst-var-by glibcbin ${lib.getBin glibc} - ''; + [ + "-skip" + "${builtins.concatStringsSep "|" skippedTests}" + ]; + + postInstall = + '' + wrapProgram $out/bin/nvidia-container-runtime-hook \ + --prefix PATH : ${libnvidia-container}/bin + + mkdir -p $tools/bin + mv $out/bin/{containerd,crio,docker,nvidia-toolkit,toolkit} $tools/bin + '' + + lib.optionalString (configTemplate != null || configTemplatePath != null) '' + mkdir -p $out/etc/nvidia-container-runtime + + cp ${configToml} $out/etc/nvidia-container-runtime/config.toml + + substituteInPlace $out/etc/nvidia-container-runtime/config.toml \ + --subst-var-by glibcbin ${lib.getBin glibc} + ''; meta = with lib; { homepage = "https://gitlab.com/nvidia/container-toolkit/container-toolkit"; diff --git a/pkgs/by-name/nv/nvidia-container-toolkit/packages.nix b/pkgs/by-name/nv/nvidia-container-toolkit/packages.nix index 83b62a68f2419f..b8f6e2648ed6f8 100644 --- a/pkgs/by-name/nv/nvidia-container-toolkit/packages.nix +++ b/pkgs/by-name/nv/nvidia-container-toolkit/packages.nix @@ -5,40 +5,37 @@ }: # Note this scope isn't recursed into, at the time of writing. -lib.makeScope newScope ( - self: { +lib.makeScope newScope (self: { - # The config is only exposed as an attrset so that the user may reach the - # deafult values, for inspectability purposes. - dockerConfig = { - disable-require = false; - #swarm-resource = "DOCKER_RESOURCE_GPU" + # The config is only exposed as an attrset so that the user may reach the + # deafult values, for inspectability purposes. + dockerConfig = { + disable-require = false; + #swarm-resource = "DOCKER_RESOURCE_GPU" - nvidia-container-cli = { - #root = "/run/nvidia/driver"; - #path = "/usr/bin/nvidia-container-cli"; - environment = [ ]; - #debug = "/var/log/nvidia-container-runtime-hook.log"; - ldcache = "/tmp/ld.so.cache"; - load-kmods = true; - #no-cgroups = false; - #user = "root:video"; - ldconfig = "@@glibcbin@/bin/ldconfig"; - }; - }; - nvidia-container-toolkit-docker = self.callPackage ./package.nix { - configTemplate = self.dockerConfig; + nvidia-container-cli = { + #root = "/run/nvidia/driver"; + #path = "/usr/bin/nvidia-container-cli"; + environment = [ ]; + #debug = "/var/log/nvidia-container-runtime-hook.log"; + ldcache = "/tmp/ld.so.cache"; + load-kmods = true; + #no-cgroups = false; + #user = "root:video"; + ldconfig = "@@glibcbin@/bin/ldconfig"; }; + }; + nvidia-container-toolkit-docker = self.callPackage ./package.nix { + configTemplate = self.dockerConfig; + }; - nvidia-docker = symlinkJoin { - name = "nvidia-docker"; - paths = [ - self.nvidia-docker-unwrapped - self.nvidia-container-toolkit-docker - ]; - inherit (self.nvidia-docker-unwrapped) meta; - }; - nvidia-docker-unwrapped = - self.callPackage ./nvidia-docker.nix { }; - } -) + nvidia-docker = symlinkJoin { + name = "nvidia-docker"; + paths = [ + self.nvidia-docker-unwrapped + self.nvidia-container-toolkit-docker + ]; + inherit (self.nvidia-docker-unwrapped) meta; + }; + nvidia-docker-unwrapped = self.callPackage ./nvidia-docker.nix { }; +}) diff --git a/pkgs/by-name/nv/nvidia-optical-flow-sdk/package.nix b/pkgs/by-name/nv/nvidia-optical-flow-sdk/package.nix index 813821bfb71c20..3dfad2f8eff603 100644 --- a/pkgs/by-name/nv/nvidia-optical-flow-sdk/package.nix +++ b/pkgs/by-name/nv/nvidia-optical-flow-sdk/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cudaPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + cudaPackages, +}: stdenv.mkDerivation { pname = "nvidia-optical-flow-sdk"; diff --git a/pkgs/by-name/nv/nvidia-texture-tools/package.nix b/pkgs/by-name/nv/nvidia-texture-tools/package.nix index 13f285bc66e8d6..72cd0054518ce2 100644 --- a/pkgs/by-name/nv/nvidia-texture-tools/package.nix +++ b/pkgs/by-name/nv/nvidia-texture-tools/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation { @@ -15,17 +16,23 @@ stdenv.mkDerivation { hash = "sha256-BYNm8CxPQbfmnnzNmOQ2Dc8HSyO8mkqzYsBZ5T80398="; }; - postPatch = '' - # Make a recently added pure virtual function just virtual, - # to keep compatibility. - sed -i 's/virtual void endImage() = 0;/virtual void endImage() {}/' src/nvtt/nvtt.h - '' + lib.optionalString stdenv.hostPlatform.isAarch64 '' - # remove x86_64-only libraries - sed -i '/bc1enc/d' src/nvtt/tests/CMakeLists.txt - sed -i '/libsquish/d;/CMP_Core/d' extern/CMakeLists.txt - ''; - - outputs = [ "out" "dev" "lib" ]; + postPatch = + '' + # Make a recently added pure virtual function just virtual, + # to keep compatibility. + sed -i 's/virtual void endImage() = 0;/virtual void endImage() {}/' src/nvtt/nvtt.h + '' + + lib.optionalString stdenv.hostPlatform.isAarch64 '' + # remove x86_64-only libraries + sed -i '/bc1enc/d' src/nvtt/tests/CMakeLists.txt + sed -i '/libsquish/d;/CMP_Core/d' extern/CMakeLists.txt + ''; + + outputs = [ + "out" + "dev" + "lib" + ]; nativeBuildInputs = [ cmake diff --git a/pkgs/by-name/nv/nvidia_cg_toolkit/package.nix b/pkgs/by-name/nv/nvidia_cg_toolkit/package.nix index d6d4fdd448107a..47c8173982472f 100644 --- a/pkgs/by-name/nv/nvidia_cg_toolkit/package.nix +++ b/pkgs/by-name/nv/nvidia_cg_toolkit/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "3.1"; @@ -18,7 +22,8 @@ stdenv.mkDerivation rec { url = "http://developer.download.nvidia.com/cg/Cg_${version}/Cg-${version}_${date}_x86.tgz"; sha256 = "cef3591e436f528852db0e8c145d3842f920e0c89bcfb219c466797cb7b18879"; } - else throw "nvidia-cg-toolkit does not support platform ${stdenv.hostPlatform.system}"; + else + throw "nvidia-cg-toolkit does not support platform ${stdenv.hostPlatform.system}"; installPhase = '' for b in cgc cgfxcat cginfo diff --git a/pkgs/by-name/nv/nvimpager/package.nix b/pkgs/by-name/nv/nvimpager/package.nix index 364b825292f241..18655c60c69f08 100644 --- a/pkgs/by-name/nv/nvimpager/package.nix +++ b/pkgs/by-name/nv/nvimpager/package.nix @@ -1,7 +1,13 @@ -{ fetchFromGitHub -, lib, stdenv -, ncurses, neovim, procps -, scdoc, lua51Packages, util-linux +{ + fetchFromGitHub, + lib, + stdenv, + ncurses, + neovim, + procps, + scdoc, + lua51Packages, + util-linux, }: stdenv.mkDerivation rec { @@ -22,18 +28,27 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ scdoc ]; makeFlags = [ "PREFIX=$(out)" ]; - buildFlags = [ "nvimpager.configured" "nvimpager.1" ]; + buildFlags = [ + "nvimpager.configured" + "nvimpager.1" + ]; preBuild = '' patchShebangs nvimpager substituteInPlace nvimpager --replace-fail ':-nvim' ':-${lib.getExe neovim}' - ''; + ''; doCheck = true; - nativeCheckInputs = [ lua51Packages.busted util-linux neovim ]; + nativeCheckInputs = [ + lua51Packages.busted + util-linux + neovim + ]; # filter out one test that fails in the sandbox of nix or with neovim v0.10 # or on macOS preCheck = '' - checkFlagsArray+=('BUSTED=busted --output TAP --exclude-tags=${"nix,v10" + lib.optionalString stdenv.hostPlatform.isDarwin ",mac"}') + checkFlagsArray+=('BUSTED=busted --output TAP --exclude-tags=${ + "nix,v10" + lib.optionalString stdenv.hostPlatform.isDarwin ",mac" + }') ''; meta = with lib; { diff --git a/pkgs/by-name/nv/nvitop/package.nix b/pkgs/by-name/nv/nvitop/package.nix index a89f5d04d65b30..c52d481caf02f4 100644 --- a/pkgs/by-name/nv/nvitop/package.nix +++ b/pkgs/by-name/nv/nvitop/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { @@ -16,7 +17,6 @@ python3Packages.buildPythonApplication rec { pythonRelaxDeps = [ "nvidia-ml-py" ]; - propagatedBuildInputs = with python3Packages; [ cachetools psutil diff --git a/pkgs/by-name/nv/nvme-cli/package.nix b/pkgs/by-name/nv/nvme-cli/package.nix index f17ee46d75079d..39f2da237ed5fd 100644 --- a/pkgs/by-name/nv/nvme-cli/package.nix +++ b/pkgs/by-name/nv/nvme-cli/package.nix @@ -1,10 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config -, meson -, ninja -, libnvme -, json_c -, zlib -, python3Packages +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + meson, + ninja, + libnvme, + json_c, + zlib, + python3Packages, }: stdenv.mkDerivation rec { @@ -47,7 +51,10 @@ stdenv.mkDerivation rec { ''; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ mic92 vifino ]; + maintainers = with maintainers; [ + mic92 + vifino + ]; mainProgram = "nvme"; }; } diff --git a/pkgs/by-name/nv/nvmet-cli/package.nix b/pkgs/by-name/nv/nvmet-cli/package.nix index eafa8501cdb76a..beaeea887c3955 100644 --- a/pkgs/by-name/nv/nvmet-cli/package.nix +++ b/pkgs/by-name/nv/nvmet-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchurl }: +{ + lib, + python3Packages, + fetchurl, +}: python3Packages.buildPythonApplication rec { pname = "nvmet-cli"; diff --git a/pkgs/by-name/nv/nvmetcfg/package.nix b/pkgs/by-name/nv/nvmetcfg/package.nix index 5edd436ba62106..0c2e29e8a6e0ca 100644 --- a/pkgs/by-name/nv/nvmetcfg/package.nix +++ b/pkgs/by-name/nv/nvmetcfg/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, nixosTests +{ + lib, + rustPlatform, + fetchFromGitHub, + nixosTests, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/nv/nvpy/package.nix b/pkgs/by-name/nv/nvpy/package.nix index ddb76bad3686f7..c937fd46d6a0d7 100644 --- a/pkgs/by-name/nv/nvpy/package.nix +++ b/pkgs/by-name/nv/nvpy/package.nix @@ -1,8 +1,13 @@ -{ pkgs, fetchFromGitHub, python3Packages }: +{ + pkgs, + fetchFromGitHub, + python3Packages, +}: let pythonPackages = python3Packages; -in pythonPackages.buildPythonApplication rec { +in +pythonPackages.buildPythonApplication rec { version = "2.3.1"; pname = "nvpy"; @@ -13,7 +18,6 @@ in pythonPackages.buildPythonApplication rec { sha256 = "sha256-guNdLu/bCk89o5M3gQU7J0W4h7eZdLHM0FG5IAPLE7c="; }; - propagatedBuildInputs = with pythonPackages; [ markdown docutils diff --git a/pkgs/by-name/nw/nwg-bar/package.nix b/pkgs/by-name/nw/nwg-bar/package.nix index d80986db6e0304..17ef7dea548bec 100644 --- a/pkgs/by-name/nw/nwg-bar/package.nix +++ b/pkgs/by-name/nw/nwg-bar/package.nix @@ -1,11 +1,13 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, librsvg -, pkg-config -, gtk3 -, gtk-layer-shell -, wrapGAppsHook3 }: +{ + lib, + buildGoModule, + fetchFromGitHub, + librsvg, + pkg-config, + gtk3, + gtk-layer-shell, + wrapGAppsHook3, +}: buildGoModule rec { pname = "nwg-bar"; @@ -26,9 +28,16 @@ buildGoModule rec { vendorHash = "sha256-/kqhZcIuoN/XA0i1ua3lzVGn4ghkekFYScL1o3kgBX4="; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; - buildInputs = [ gtk3 gtk-layer-shell librsvg ]; + buildInputs = [ + gtk3 + gtk-layer-shell + librsvg + ]; preInstall = '' mkdir -p $out/share/nwg-bar @@ -36,8 +45,7 @@ buildGoModule rec { ''; meta = with lib; { - description = - "GTK3-based button bar for sway and other wlroots-based compositors"; + description = "GTK3-based button bar for sway and other wlroots-based compositors"; mainProgram = "nwg-bar"; homepage = "https://github.com/nwg-piotr/nwg-bar"; license = licenses.mit; diff --git a/pkgs/by-name/nw/nwg-displays/package.nix b/pkgs/by-name/nw/nwg-displays/package.nix index 8adc3991c966bf..e0cd1d5d57c47b 100644 --- a/pkgs/by-name/nw/nwg-displays/package.nix +++ b/pkgs/by-name/nw/nwg-displays/package.nix @@ -1,15 +1,16 @@ -{ lib -, fetchFromGitHub -, atk -, gdk-pixbuf -, gobject-introspection -, gtk-layer-shell -, gtk3 -, pango -, python310Packages -, wrapGAppsHook3 -, hyprlandSupport ? true -, wlr-randr +{ + lib, + fetchFromGitHub, + atk, + gdk-pixbuf, + gobject-introspection, + gtk-layer-shell, + gtk3, + pango, + python310Packages, + wrapGAppsHook3, + hyprlandSupport ? true, + wlr-randr, }: python310Packages.buildPythonApplication rec { @@ -32,17 +33,19 @@ python310Packages.buildPythonApplication rec { gtk3 ]; - propagatedBuildInputs = [ - atk - gdk-pixbuf - gtk-layer-shell - pango - python310Packages.gst-python - python310Packages.i3ipc - python310Packages.pygobject3 - ] ++ lib.optionals hyprlandSupport [ - wlr-randr - ]; + propagatedBuildInputs = + [ + atk + gdk-pixbuf + gtk-layer-shell + pango + python310Packages.gst-python + python310Packages.i3ipc + python310Packages.pygobject3 + ] + ++ lib.optionals hyprlandSupport [ + wlr-randr + ]; dontWrapGApps = true; diff --git a/pkgs/by-name/nw/nwg-dock/package.nix b/pkgs/by-name/nw/nwg-dock/package.nix index 29880d734000fa..9aeefd7d0a4f35 100644 --- a/pkgs/by-name/nw/nwg-dock/package.nix +++ b/pkgs/by-name/nw/nwg-dock/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, pkg-config -, gtk3 -, gtk-layer-shell +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + gtk3, + gtk-layer-shell, }: buildGoModule rec { @@ -19,10 +20,16 @@ buildGoModule rec { vendorHash = "sha256-paRcBQwg2uGouMRX5XF++OyN8Y0JyucXLN0G5O0j3qA="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk3 gtk-layer-shell ]; + buildInputs = [ + gtk3 + gtk-layer-shell + ]; meta = with lib; { description = "GTK3-based dock for sway"; diff --git a/pkgs/by-name/nw/nwg-drawer/package.nix b/pkgs/by-name/nw/nwg-drawer/package.nix index b38554acbf8762..4b843bf3e6a46e 100644 --- a/pkgs/by-name/nw/nwg-drawer/package.nix +++ b/pkgs/by-name/nw/nwg-drawer/package.nix @@ -1,13 +1,14 @@ -{ lib -, buildGoModule -, cairo -, fetchFromGitHub -, gobject-introspection -, gtk-layer-shell -, gtk3 -, pkg-config -, wrapGAppsHook3 -, xdg-utils +{ + lib, + buildGoModule, + cairo, + fetchFromGitHub, + gobject-introspection, + gtk-layer-shell, + gtk3, + pkg-config, + wrapGAppsHook3, + xdg-utils, }: let @@ -24,7 +25,12 @@ let vendorHash = "sha256-r4DtY06z0ZcPoHba4pqpCWqxYo7RbwCKi2g4jdoN1kg="; in buildGoModule { - inherit pname version src vendorHash; + inherit + pname + version + src + vendorHash + ; nativeBuildInputs = [ gobject-introspection diff --git a/pkgs/by-name/nw/nwg-launchers/package.nix b/pkgs/by-name/nw/nwg-launchers/package.nix index 4e2447379bdda2..81d371b51710bd 100644 --- a/pkgs/by-name/nw/nwg-launchers/package.nix +++ b/pkgs/by-name/nw/nwg-launchers/package.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, gtkmm3 -, meson -, ninja -, nlohmann_json -, pkg-config -, swaylock -, makeWrapper -, gtk-layer-shell +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gtkmm3, + meson, + ninja, + nlohmann_json, + pkg-config, + swaylock, + makeWrapper, + gtk-layer-shell, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/nw/nwg-menu/package.nix b/pkgs/by-name/nw/nwg-menu/package.nix index a428c9e3e72219..99d45b46d8c517 100644 --- a/pkgs/by-name/nw/nwg-menu/package.nix +++ b/pkgs/by-name/nw/nwg-menu/package.nix @@ -1,6 +1,15 @@ -{ lib, fetchFromGitHub -, buildGoModule, pkg-config, wrapGAppsHook3, gobject-introspection -, gtk-layer-shell, gtk3, pango, gdk-pixbuf, atk +{ + lib, + fetchFromGitHub, + buildGoModule, + pkg-config, + wrapGAppsHook3, + gobject-introspection, + gtk-layer-shell, + gtk3, + pango, + gdk-pixbuf, + atk, }: buildGoModule rec { @@ -18,8 +27,18 @@ buildGoModule rec { doCheck = false; - buildInputs = [ atk gtk3 gdk-pixbuf gtk-layer-shell pango ]; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 gobject-introspection ]; + buildInputs = [ + atk + gtk3 + gdk-pixbuf + gtk-layer-shell + pango + ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + gobject-introspection + ]; prePatch = '' for file in main.go tools.go; do diff --git a/pkgs/by-name/nw/nwg-wrapper/package.nix b/pkgs/by-name/nw/nwg-wrapper/package.nix index f5b524c890198c..b086291928a17c 100644 --- a/pkgs/by-name/nw/nwg-wrapper/package.nix +++ b/pkgs/by-name/nw/nwg-wrapper/package.nix @@ -1,4 +1,13 @@ -{ lib, python3Packages, fetchFromGitHub, gtk-layer-shell, gtk3, gobject-introspection, wrapGAppsHook3, wlr-randr }: +{ + lib, + python3Packages, + fetchFromGitHub, + gtk-layer-shell, + gtk3, + gobject-introspection, + wrapGAppsHook3, + wlr-randr, +}: python3Packages.buildPythonPackage rec { pname = "nwg-wrapper"; @@ -11,11 +20,20 @@ python3Packages.buildPythonPackage rec { sha256 = "sha256-GKDAdjO67aedCEFHKDukQ+oPMomTPwFE/CvJu112fus="; }; - nativeBuildInputs = [ gobject-introspection wrapGAppsHook3 ]; + nativeBuildInputs = [ + gobject-introspection + wrapGAppsHook3 + ]; - buildInputs = [ gtk3 gtk-layer-shell ]; + buildInputs = [ + gtk3 + gtk-layer-shell + ]; - propagatedBuildInputs = with python3Packages; [ i3ipc pygobject3 ]; + propagatedBuildInputs = with python3Packages; [ + i3ipc + pygobject3 + ]; # No tests doCheck = false; diff --git a/pkgs/by-name/nw/nwipe/package.nix b/pkgs/by-name/nw/nwipe/package.nix index 33264c49e76358..383d18e560adf9 100644 --- a/pkgs/by-name/nw/nwipe/package.nix +++ b/pkgs/by-name/nw/nwipe/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, autoreconfHook -, makeWrapper -, fetchFromGitHub -, ncurses -, parted -, pkg-config -, libconfig -, hdparm -, smartmontools -, dmidecode +{ + lib, + stdenv, + autoreconfHook, + makeWrapper, + fetchFromGitHub, + ncurses, + parted, + pkg-config, + libconfig, + hdparm, + smartmontools, + dmidecode, }: stdenv.mkDerivation rec { @@ -37,7 +38,13 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/nwipe \ - --prefix PATH : ${lib.makeBinPath [ hdparm smartmontools dmidecode ]} + --prefix PATH : ${ + lib.makeBinPath [ + hdparm + smartmontools + dmidecode + ] + } ''; enableParallelBuilding = true; @@ -47,7 +54,10 @@ stdenv.mkDerivation rec { mainProgram = "nwipe"; homepage = "https://github.com/martijnvanbrummelen/nwipe"; license = licenses.gpl2Only; - maintainers = with maintainers; [ vifino woffs ]; + maintainers = with maintainers; [ + vifino + woffs + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/nx/nx-libs/package.nix b/pkgs/by-name/nx/nx-libs/package.nix index a3afc4fa264a61..616ab0ee164caa 100644 --- a/pkgs/by-name/nx/nx-libs/package.nix +++ b/pkgs/by-name/nx/nx-libs/package.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, autoconf, automake, fetchFromGitHub, fetchpatch -, libjpeg_turbo -, libpng, libtool, libxml2, pkg-config, which, xorg -, libtirpc +{ + lib, + stdenv, + autoconf, + automake, + fetchFromGitHub, + fetchpatch, + libjpeg_turbo, + libpng, + libtool, + libxml2, + pkg-config, + which, + xorg, + libtirpc, }: stdenv.mkDerivation rec { pname = "nx-libs"; @@ -21,12 +32,33 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoconf automake libtool pkg-config which - xorg.gccmakedep xorg.imake ]; - buildInputs = [ libjpeg_turbo libpng libxml2 xorg.fontutil - xorg.libXcomposite xorg.libXdamage xorg.libXdmcp xorg.libXext xorg.libXfont2 - xorg.libXinerama xorg.libXpm xorg.libXrandr xorg.libXtst xorg.pixman - xorg.xkbcomp xorg.xkeyboardconfig libtirpc + nativeBuildInputs = [ + autoconf + automake + libtool + pkg-config + which + xorg.gccmakedep + xorg.imake + ]; + buildInputs = [ + libjpeg_turbo + libpng + libxml2 + xorg.fontutil + xorg.libXcomposite + xorg.libXdamage + xorg.libXdmcp + xorg.libXext + xorg.libXfont2 + xorg.libXinerama + xorg.libXpm + xorg.libXrandr + xorg.libXtst + xorg.pixman + xorg.xkbcomp + xorg.xkeyboardconfig + libtirpc ]; env.NIX_CFLAGS_COMPILE = toString [ "-I${libtirpc.dev}/include/tirpc" ]; @@ -44,7 +76,7 @@ stdenv.mkDerivation rec { substituteInPlace nx-X11/config/cf/Imake.tmpl --replace "clq" "cq" ''; - PREFIX=""; # Don't install to $out/usr/local + PREFIX = ""; # Don't install to $out/usr/local installPhase = '' make DESTDIR="$out" install # See: diff --git a/pkgs/by-name/nx/nx2elf/package.nix b/pkgs/by-name/nx/nx2elf/package.nix index a2597b985c0813..b316eb36bf3486 100644 --- a/pkgs/by-name/nx/nx2elf/package.nix +++ b/pkgs/by-name/nx/nx2elf/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, lz4 }: +{ + lib, + stdenv, + fetchFromGitHub, + lz4, +}: stdenv.mkDerivation rec { pname = "nx2elf"; diff --git a/pkgs/by-name/nx/nxengine-evo/assets.nix b/pkgs/by-name/nx/nxengine-evo/assets.nix index 96c2e5f1e70b4b..9524f42e8dd22b 100644 --- a/pkgs/by-name/nx/nxengine-evo/assets.nix +++ b/pkgs/by-name/nx/nxengine-evo/assets.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchzip +{ + lib, + stdenvNoCC, + fetchzip, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/nx/nxengine-evo/package.nix b/pkgs/by-name/nx/nxengine-evo/package.nix index 10acb961d44179..da64333e784c7f 100644 --- a/pkgs/by-name/nx/nxengine-evo/package.nix +++ b/pkgs/by-name/nx/nxengine-evo/package.nix @@ -61,18 +61,21 @@ stdenv.mkDerivation (finalAttrs: { sed -i -e "s,/usr/share/,$out/share/," src/ResourceManager.cpp ''; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - cd .. - mkdir -p $out/bin/ $out/share/nxengine/ - install bin/* $out/bin/ - '' + '' - cp -r ${finalAttrs.finalPackage.assets}/share/nxengine/data $out/share/nxengine/data - chmod -R a=r,a+X $out/share/nxengine/data - '' + '' - runHook postInstall - ''; + cd .. + mkdir -p $out/bin/ $out/share/nxengine/ + install bin/* $out/bin/ + '' + + '' + cp -r ${finalAttrs.finalPackage.assets}/share/nxengine/data $out/share/nxengine/data + chmod -R a=r,a+X $out/share/nxengine/data + '' + + '' + runHook postInstall + ''; passthru = { assets = callPackage ./assets.nix { }; diff --git a/pkgs/by-name/nx/nxpmicro-mfgtools/package.nix b/pkgs/by-name/nx/nxpmicro-mfgtools/package.nix index 78a04adde79773..17d14dce081c4d 100644 --- a/pkgs/by-name/nx/nxpmicro-mfgtools/package.nix +++ b/pkgs/by-name/nx/nxpmicro-mfgtools/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, bzip2 -, installShellFiles -, libusb1 -, libzip -, openssl -, zstd +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + bzip2, + installShellFiles, + libusb1, + libzip, + openssl, + zstd, }: stdenv.mkDerivation rec { @@ -21,9 +23,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-t5usUGbcdLQlqPpZkNDeGncka9VfkpO7U933Kw/Sm7U="; }; - nativeBuildInputs = [ cmake pkg-config installShellFiles ]; + nativeBuildInputs = [ + cmake + pkg-config + installShellFiles + ]; - buildInputs = [ bzip2 libusb1 libzip openssl zstd ]; + buildInputs = [ + bzip2 + libusb1 + libzip + openssl + zstd + ]; preConfigure = "echo ${version} > .tarball-version"; @@ -52,7 +64,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://github.com/NXPmicro/mfgtools"; license = licenses.bsd3; - maintainers = with maintainers; [ bmilanov jraygauthier ]; + maintainers = with maintainers; [ + bmilanov + jraygauthier + ]; mainProgram = "uuu"; platforms = platforms.all; }; diff --git a/pkgs/by-name/ny/nyancat/package.nix b/pkgs/by-name/ny/nyancat/package.nix index 89acccd66fc1ba..e69cf3e6870ab5 100644 --- a/pkgs/by-name/ny/nyancat/package.nix +++ b/pkgs/by-name/ny/nyancat/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "nyancat"; diff --git a/pkgs/by-name/ny/nylon/package.nix b/pkgs/by-name/ny/nylon/package.nix index 37c6d14dfa2785..3627cb2fdfebb1 100644 --- a/pkgs/by-name/ny/nylon/package.nix +++ b/pkgs/by-name/ny/nylon/package.nix @@ -1,9 +1,18 @@ -{ lib, stdenv, fetchurl, libevent, buildEnv }: +{ + lib, + stdenv, + fetchurl, + libevent, + buildEnv, +}: let # failed to find a better way to make it work libevent-comb = buildEnv { inherit (libevent.out) name; - paths = [ libevent.dev libevent.out ]; + paths = [ + libevent.dev + libevent.out + ]; }; in stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ny/nyx/package.nix b/pkgs/by-name/ny/nyx/package.nix index cb697e0f5e669c..9ef34e4ddf7afa 100644 --- a/pkgs/by-name/ny/nyx/package.nix +++ b/pkgs/by-name/ny/nyx/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: with python3Packages; diff --git a/pkgs/by-name/oa/oak/package.nix b/pkgs/by-name/oa/oak/package.nix index 3e5d952a1d498c..3584fccfc39453 100644 --- a/pkgs/by-name/oa/oak/package.nix +++ b/pkgs/by-name/oa/oak/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/oa/oam-tools/package.nix b/pkgs/by-name/oa/oam-tools/package.nix index 7c5d4d98274923..04116a4b23c098 100644 --- a/pkgs/by-name/oa/oam-tools/package.nix +++ b/pkgs/by-name/oa/oam-tools/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/oa/oama/package.nix b/pkgs/by-name/oa/oama/package.nix index 1f87b3bffe434a..73a275f431e007 100644 --- a/pkgs/by-name/oa/oama/package.nix +++ b/pkgs/by-name/oa/oama/package.nix @@ -21,5 +21,10 @@ lib.pipe raw-pkg [ (overrideCabal overrides) # FIXME: eliminate all erroneous references on aarch64-darwin manually, # see https://github.com/NixOS/nixpkgs/issues/318013 - (if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 then lib.id else justStaticExecutables) + ( + if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 then + lib.id + else + justStaticExecutables + ) ] diff --git a/pkgs/by-name/oa/oapi-codegen/package.nix b/pkgs/by-name/oa/oapi-codegen/package.nix index 9cbd1e9f56ffef..42acac59aef8af 100644 --- a/pkgs/by-name/oa/oapi-codegen/package.nix +++ b/pkgs/by-name/oa/oapi-codegen/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -12,7 +13,7 @@ buildGoModule rec { repo = pname; rev = "refs/tags/v${version}"; hash = "sha256-21VhHSyfF+NHkXlr2svjwBNZmfS1O448POBP9XUQxak="; - } ; + }; vendorHash = "sha256-bp5sFZNJFQonwfF1RjCnOMKZQkofHuqG0bXdG5Hf3jU="; @@ -21,7 +22,7 @@ buildGoModule rec { subPackages = [ "cmd/oapi-codegen" ]; - ldflags = [ "-X main.noVCSVersionOverride=${version}" ] ; + ldflags = [ "-X main.noVCSVersionOverride=${version}" ]; meta = with lib; { description = "Go client and server OpenAPI 3 generator"; diff --git a/pkgs/by-name/oa/oath-toolkit/package.nix b/pkgs/by-name/oa/oath-toolkit/package.nix index 15fc4760bc37aa..4754902de053de 100644 --- a/pkgs/by-name/oa/oath-toolkit/package.nix +++ b/pkgs/by-name/oa/oath-toolkit/package.nix @@ -1,12 +1,18 @@ -{ lib, stdenv, fetchurl, nix-update-script, pam, xmlsec }: +{ + lib, + stdenv, + fetchurl, + nix-update-script, + pam, + xmlsec, +}: let # TODO: Switch to OpenPAM once https://gitlab.com/oath-toolkit/oath-toolkit/-/issues/26 is addressed upstream - securityDependency = - if stdenv.hostPlatform.isDarwin then xmlsec - else pam; + securityDependency = if stdenv.hostPlatform.isDarwin then xmlsec else pam; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "oath-toolkit"; version = "2.6.12"; diff --git a/pkgs/by-name/oa/oatpp/package.nix b/pkgs/by-name/oa/oatpp/package.nix index 10b44bdac57215..0bd8645ee3898d 100644 --- a/pkgs/by-name/oa/oatpp/package.nix +++ b/pkgs/by-name/oa/oatpp/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/oa/oauth2-proxy/package.nix b/pkgs/by-name/oa/oauth2-proxy/package.nix index 64ae693f6b40f9..396daa9084f224 100644 --- a/pkgs/by-name/oa/oauth2-proxy/package.nix +++ b/pkgs/by-name/oa/oauth2-proxy/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "oauth2-proxy"; diff --git a/pkgs/by-name/oa/oauth2c/package.nix b/pkgs/by-name/oa/oauth2c/package.nix index 5c01d5e1059617..8a3052b78a281e 100644 --- a/pkgs/by-name/oa/oauth2c/package.nix +++ b/pkgs/by-name/oa/oauth2c/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/oa/oauth2l/package.nix b/pkgs/by-name/oa/oauth2l/package.nix index a47bece266ef1d..ae9ac3dd70c4dd 100644 --- a/pkgs/by-name/oa/oauth2l/package.nix +++ b/pkgs/by-name/oa/oauth2l/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, buildGoModule -, fetchFromGitHub +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -17,7 +18,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; # Fix tests by preventing them from writing to /homeless-shelter. preCheck = "export HOME=$(mktemp -d)"; diff --git a/pkgs/by-name/oa/oauth2ms/package.nix b/pkgs/by-name/oa/oauth2ms/package.nix index 0a4787bacd7d46..2e3b729cf6ebde 100644 --- a/pkgs/by-name/oa/oauth2ms/package.nix +++ b/pkgs/by-name/oa/oauth2ms/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation { pname = "oauth2ms"; @@ -12,11 +17,13 @@ stdenv.mkDerivation { }; buildInputs = [ - (python3.withPackages (ps: with ps; [ - pyxdg - msal - python-gnupg - ])) + (python3.withPackages ( + ps: with ps; [ + pyxdg + msal + python-gnupg + ] + )) ]; installPhase = '' diff --git a/pkgs/by-name/ob/oberon-risc-emu/package.nix b/pkgs/by-name/ob/oberon-risc-emu/package.nix index 331473f59fedf2..92da529579a26f 100644 --- a/pkgs/by-name/ob/oberon-risc-emu/package.nix +++ b/pkgs/by-name/ob/oberon-risc-emu/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, SDL2 }: +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, +}: stdenv.mkDerivation { pname = "oberon-risc-emu"; @@ -19,9 +24,9 @@ stdenv.mkDerivation { ''; meta = with lib; { - homepage = "https://github.com/pdewacht/oberon-risc-emu/"; + homepage = "https://github.com/pdewacht/oberon-risc-emu/"; description = "Emulator for the Oberon RISC machine"; - license = licenses.isc; + license = licenses.isc; maintainers = with maintainers; [ siraben ]; mainProgram = "risc"; }; diff --git a/pkgs/by-name/ob/obex_data_server/package.nix b/pkgs/by-name/ob/obex_data_server/package.nix index fee4a25226904f..d38525342c4178 100644 --- a/pkgs/by-name/ob/obex_data_server/package.nix +++ b/pkgs/by-name/ob/obex_data_server/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, pkg-config, libusb-compat-0_1, glib, dbus-glib, bluez, openobex, dbus }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libusb-compat-0_1, + glib, + dbus-glib, + bluez, + openobex, + dbus, +}: stdenv.mkDerivation rec { pname = "obex-data-server"; @@ -14,13 +25,20 @@ stdenv.mkDerivation rec { pkg-config dbus-glib # required for dbus-binding-tool ]; - buildInputs = [ libusb-compat-0_1 glib dbus-glib bluez openobex dbus ]; + buildInputs = [ + libusb-compat-0_1 + glib + dbus-glib + bluez + openobex + dbus + ]; patches = [ ./obex-data-server-0.4.6-build-fixes-1.patch ]; preConfigure = '' - addToSearchPath PKG_CONFIG_PATH ${openobex}/lib64/pkgconfig - export PKG_CONFIG_PATH="${dbus.dev}/lib/pkgconfig:$PKG_CONFIG_PATH" + addToSearchPath PKG_CONFIG_PATH ${openobex}/lib64/pkgconfig + export PKG_CONFIG_PATH="${dbus.dev}/lib/pkgconfig:$PKG_CONFIG_PATH" ''; meta = with lib; { diff --git a/pkgs/by-name/ob/obexd/package.nix b/pkgs/by-name/ob/obexd/package.nix index c18aa3a1c263bd..fe06453a0f7de7 100644 --- a/pkgs/by-name/ob/obexd/package.nix +++ b/pkgs/by-name/ob/obexd/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, dbus, openobex, bluez, libical }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + dbus, + openobex, + bluez, + libical, +}: stdenv.mkDerivation rec { pname = "obexd"; @@ -9,7 +19,13 @@ stdenv.mkDerivation rec { sha256 = "1i20dnibvnq9lnkkhajr5xx3kxlwf9q5c4jm19kyb0q1klzgzlb8"; }; - buildInputs = [ glib dbus openobex bluez libical ]; + buildInputs = [ + glib + dbus + openobex + bluez + libical + ]; nativeBuildInputs = [ pkg-config ]; diff --git a/pkgs/by-name/ob/obexfs/package.nix b/pkgs/by-name/ob/obexfs/package.nix index 0f37a0363212c9..2d3364cc2a8321 100644 --- a/pkgs/by-name/ob/obexfs/package.nix +++ b/pkgs/by-name/ob/obexfs/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, bluez, fuse, obexftp }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + bluez, + fuse, + obexftp, +}: stdenv.mkDerivation rec { pname = "obexfs"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ fuse obexftp bluez ]; + buildInputs = [ + fuse + obexftp + bluez + ]; meta = with lib; { homepage = "http://dev.zuckschwerdt.org/openobex/wiki/ObexFs"; diff --git a/pkgs/by-name/ob/obexftp/package.nix b/pkgs/by-name/ob/obexftp/package.nix index 5819508f2577eb..9b1a0186cfc599 100644 --- a/pkgs/by-name/ob/obexftp/package.nix +++ b/pkgs/by-name/ob/obexftp/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, openobex, bluez, cmake }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + openobex, + bluez, + cmake, +}: stdenv.mkDerivation rec { pname = "obexftp"; @@ -9,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "18w9r78z78ri5qc8fjym4nk1jfbrkyr789sq7rxrkshf1a7b83yl"; }; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; buildInputs = [ bluez ]; diff --git a/pkgs/by-name/ob/obfs4/package.nix b/pkgs/by-name/ob/obfs4/package.nix index a0b69e54c6d061..744c2cac6965b1 100644 --- a/pkgs/by-name/ob/obfs4/package.nix +++ b/pkgs/by-name/ob/obfs4/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitLab, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitLab, + installShellFiles, +}: buildGoModule rec { pname = "obfs4"; @@ -17,7 +22,10 @@ buildGoModule rec { vendorHash = "sha256-iR3+ZMEF0SB3EoLTf2gtqTe3CQcjtDRhfwwbwGj3pXo="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; subPackages = [ "cmd/lyrebird" ]; @@ -45,6 +53,10 @@ buildGoModule rec { maintainers = with maintainers; [ thoughtpolice ]; mainProgram = "lyrebird"; changelog = "https://gitlab.torproject.org/tpo/anti-censorship/pluggable-transports/lyrebird/-/raw/${src.rev}/ChangeLog"; - license = with lib.licenses; [ bsd2 bsd3 gpl3 ]; + license = with lib.licenses; [ + bsd2 + bsd3 + gpl3 + ]; }; } diff --git a/pkgs/by-name/ob/obj-magic/package.nix b/pkgs/by-name/ob/obj-magic/package.nix index 4f120323d0a327..f298f45f8ef033 100644 --- a/pkgs/by-name/ob/obj-magic/package.nix +++ b/pkgs/by-name/ob/obj-magic/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation { @@ -35,4 +36,3 @@ stdenv.mkDerivation { mainProgram = "obj-magic"; }; } - diff --git a/pkgs/by-name/ob/obs-cli/package.nix b/pkgs/by-name/ob/obs-cli/package.nix index 03a984f82b4624..60b5fe1df44ae7 100644 --- a/pkgs/by-name/ob/obs-cli/package.nix +++ b/pkgs/by-name/ob/obs-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, }: buildGoModule rec { diff --git a/pkgs/by-name/ob/obs-cmd/package.nix b/pkgs/by-name/ob/obs-cmd/package.nix index 86a01d3ce2332c..4d0b125e3b9841 100644 --- a/pkgs/by-name/ob/obs-cmd/package.nix +++ b/pkgs/by-name/ob/obs-cmd/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ob/obs-do/package.nix b/pkgs/by-name/ob/obs-do/package.nix index 29acd2838e8b5b..b274a05aebcac2 100644 --- a/pkgs/by-name/ob/obs-do/package.nix +++ b/pkgs/by-name/ob/obs-do/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "CLI for common OBS operations while streaming using WebSocket"; homepage = "https://github.com/jonhoo/obs-do"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ GaetanLepage ]; mainProgram = "obs-do"; }; diff --git a/pkgs/by-name/ob/obsidian/package.nix b/pkgs/by-name/ob/obsidian/package.nix index 07f1fa66767a37..3b3d668523b639 100644 --- a/pkgs/by-name/ob/obsidian/package.nix +++ b/pkgs/by-name/ob/obsidian/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, fetchurl -, lib -, makeWrapper -, electron -, makeDesktopItem -, imagemagick -, writeScript -, undmg -, unzip -, commandLineArgs ? "" +{ + stdenv, + fetchurl, + lib, + makeWrapper, + electron, + makeDesktopItem, + imagemagick, + writeScript, + undmg, + unzip, + commandLineArgs ? "", }: let pname = "obsidian"; @@ -20,13 +21,25 @@ let downloadPage = "https://github.com/obsidianmd/obsidian-releases/releases"; mainProgram = "obsidian"; license = licenses.obsidian; - maintainers = with maintainers; [ atila conradmearns zaninime qbit kashw2 w-lfchen ]; + maintainers = with maintainers; [ + atila + conradmearns + zaninime + qbit + kashw2 + w-lfchen + ]; }; - filename = if stdenv.hostPlatform.isDarwin then "Obsidian-${version}.dmg" else "obsidian-${version}.tar.gz"; + filename = + if stdenv.hostPlatform.isDarwin then "Obsidian-${version}.dmg" else "obsidian-${version}.tar.gz"; src = fetchurl { url = "https://github.com/obsidianmd/obsidian-releases/releases/download/v${version}/${filename}"; - hash = if stdenv.hostPlatform.isDarwin then "sha256-vzYMTH1yaKxw1AwJOXVdzvKyQTkCMmx7NPPP/99xgMQ=" else "sha256-6IHqBvZx2yxQAvADi3Ok5Le3ip2/c6qafQ3FSpPT0po="; + hash = + if stdenv.hostPlatform.isDarwin then + "sha256-vzYMTH1yaKxw1AwJOXVdzvKyQTkCMmx7NPPP/99xgMQ=" + else + "sha256-6IHqBvZx2yxQAvADi3Ok5Le3ip2/c6qafQ3FSpPT0po="; }; icon = fetchurl { @@ -45,9 +58,23 @@ let }; linux = stdenv.mkDerivation { - inherit pname version src desktopItem icon; - meta = meta // { platforms = [ "x86_64-linux" "aarch64-linux" ]; }; - nativeBuildInputs = [ makeWrapper imagemagick ]; + inherit + pname + version + src + desktopItem + icon + ; + meta = meta // { + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; + }; + nativeBuildInputs = [ + makeWrapper + imagemagick + ]; installPhase = '' runHook preInstall mkdir -p $out/bin @@ -76,10 +103,24 @@ let }; darwin = stdenv.mkDerivation { - inherit pname version src appname; - meta = meta // { platforms = [ "x86_64-darwin" "aarch64-darwin" ]; }; + inherit + pname + version + src + appname + ; + meta = meta // { + platforms = [ + "x86_64-darwin" + "aarch64-darwin" + ]; + }; sourceRoot = "${appname}.app"; - nativeBuildInputs = [ makeWrapper undmg unzip ]; + nativeBuildInputs = [ + makeWrapper + undmg + unzip + ]; installPhase = '' runHook preInstall mkdir -p $out/{Applications/${appname}.app,bin} diff --git a/pkgs/by-name/ob/obuild/package.nix b/pkgs/by-name/ob/obuild/package.nix index 4575226afdec79..48dda80fb8abe1 100644 --- a/pkgs/by-name/ob/obuild/package.nix +++ b/pkgs/by-name/ob/obuild/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ocamlPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + ocamlPackages, +}: stdenv.mkDerivation rec { pname = "obuild"; @@ -13,7 +18,10 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = with ocamlPackages; [ ocaml findlib ]; + nativeBuildInputs = with ocamlPackages; [ + ocaml + findlib + ]; buildPhase = '' patchShebangs ./bootstrap diff --git a/pkgs/by-name/oc/ocaml-top/package.nix b/pkgs/by-name/oc/ocaml-top/package.nix index 538731a15dc8f8..dd9bed5dd17ba8 100644 --- a/pkgs/by-name/oc/ocaml-top/package.nix +++ b/pkgs/by-name/oc/ocaml-top/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, ocamlPackages }: +{ + lib, + fetchFromGitHub, + ocamlPackages, +}: let inherit (ocamlPackages) buildDunePackage lablgtk3-sourceview3 ocp-index; @@ -15,7 +19,10 @@ buildDunePackage rec { hash = "sha256-xmPGGB/zUpfeAxUIhR1PhfoESAJq7sTpqHuf++EH3Lw="; }; - buildInputs = [ lablgtk3-sourceview3 ocp-index ]; + buildInputs = [ + lablgtk3-sourceview3 + ocp-index + ]; meta = { homepage = "https://www.typerex.org/ocaml-top.html"; diff --git a/pkgs/by-name/oc/ocaml_make/package.nix b/pkgs/by-name/oc/ocaml_make/package.nix index a2071a9dfaad9a..0d41e59be0fea4 100644 --- a/pkgs/by-name/oc/ocaml_make/package.nix +++ b/pkgs/by-name/oc/ocaml_make/package.nix @@ -1,11 +1,16 @@ -{stdenv, lib, fetchurl}: +{ + stdenv, + lib, + fetchurl, +}: let version = "6.37.0"; sha256 = "99ff58080ed154cc4bd70f915fe4760dffb026a1c0447caa0b3bdb982b24b0a8"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "ocaml-make"; inherit version; diff --git a/pkgs/by-name/oc/ocenaudio/package.nix b/pkgs/by-name/oc/ocenaudio/package.nix index a78ce59e493017..a6f62dd127ed81 100644 --- a/pkgs/by-name/oc/ocenaudio/package.nix +++ b/pkgs/by-name/oc/ocenaudio/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchurl -, autoPatchelfHook -, dpkg -, qt5 -, libjack2 -, alsa-lib -, bzip2 -, libpulseaudio -, xz +{ + stdenv, + lib, + fetchurl, + autoPatchelfHook, + dpkg, + qt5, + libjack2, + alsa-lib, + bzip2, + libpulseaudio, + xz, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/oc/ocf-resource-agents/package.nix b/pkgs/by-name/oc/ocf-resource-agents/package.nix index 6c0157bb6cbb15..b16cfd631d140e 100644 --- a/pkgs/by-name/oc/ocf-resource-agents/package.nix +++ b/pkgs/by-name/oc/ocf-resource-agents/package.nix @@ -1,17 +1,18 @@ # This combines together OCF definitions from other derivations. # https://github.com/ClusterLabs/resource-agents/blob/master/doc/dev-guides/ra-dev-guide.asc -{ stdenv -, lib -, runCommand -, lndir -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, pkg-config -, python3 -, glib -, drbd -, pacemaker +{ + stdenv, + lib, + runCommand, + lndir, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + python3, + glib, + drbd, + pacemaker, }: let @@ -53,17 +54,22 @@ let python3 ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ - # Needed with GCC 12 but breaks on darwin (with clang) or older gcc - "-Wno-error=maybe-uninitialized" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ + # Needed with GCC 12 but breaks on darwin (with clang) or older gcc + "-Wno-error=maybe-uninitialized" + ] + ); meta = with lib; { homepage = "https://github.com/ClusterLabs/resource-agents"; description = "Combined repository of OCF agents from the RHCS and Linux-HA projects"; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ ryantm astro ]; + maintainers = with maintainers; [ + ryantm + astro + ]; }; }; @@ -71,19 +77,21 @@ in # This combines together OCF definitions from other derivations. # https://github.com/ClusterLabs/resource-agents/blob/master/doc/dev-guides/ra-dev-guide.asc -runCommand "ocf-resource-agents" { - # Fix derivation location so things like - # $ nix edit -f. ocf-resource-agents - # just work. - pos = builtins.unsafeGetAttrPos "version" resource-agentsForOCF; +runCommand "ocf-resource-agents" + { + # Fix derivation location so things like + # $ nix edit -f. ocf-resource-agents + # just work. + pos = builtins.unsafeGetAttrPos "version" resource-agentsForOCF; - # Useful to build and undate inputs individually: - passthru.inputs = { - inherit resource-agentsForOCF drbdForOCF pacemakerForOCF; - }; -} '' - mkdir -p $out/usr/lib/ocf - ${lndir}/bin/lndir -silent "${resource-agentsForOCF}/lib/ocf/" $out/usr/lib/ocf - ${lndir}/bin/lndir -silent "${drbdForOCF}/usr/lib/ocf/" $out/usr/lib/ocf - ${lndir}/bin/lndir -silent "${pacemakerForOCF}/usr/lib/ocf/" $out/usr/lib/ocf -'' + # Useful to build and undate inputs individually: + passthru.inputs = { + inherit resource-agentsForOCF drbdForOCF pacemakerForOCF; + }; + } + '' + mkdir -p $out/usr/lib/ocf + ${lndir}/bin/lndir -silent "${resource-agentsForOCF}/lib/ocf/" $out/usr/lib/ocf + ${lndir}/bin/lndir -silent "${drbdForOCF}/usr/lib/ocf/" $out/usr/lib/ocf + ${lndir}/bin/lndir -silent "${pacemakerForOCF}/usr/lib/ocf/" $out/usr/lib/ocf + '' diff --git a/pkgs/by-name/oc/oci-cli/package.nix b/pkgs/by-name/oc/oci-cli/package.nix index b51d4d50b4a8e3..fca8f519d0be05 100644 --- a/pkgs/by-name/oc/oci-cli/package.nix +++ b/pkgs/by-name/oc/oci-cli/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, fetchPypi -, python3 -, installShellFiles +{ + lib, + fetchFromGitHub, + fetchPypi, + python3, + installShellFiles, }: let @@ -105,7 +106,10 @@ buildPythonApplication rec { meta = with lib; { description = "Command Line Interface for Oracle Cloud Infrastructure"; homepage = "https://docs.cloud.oracle.com/iaas/Content/API/Concepts/cliconcepts.htm"; - license = with licenses; [ asl20 /* or */ upl ]; + license = with licenses; [ + asl20 # or + upl + ]; maintainers = with maintainers; [ ilian ]; }; } diff --git a/pkgs/by-name/oc/oci-seccomp-bpf-hook/package.nix b/pkgs/by-name/oc/oci-seccomp-bpf-hook/package.nix index 4f499197fbfdea..3e572473abdee8 100644 --- a/pkgs/by-name/oc/oci-seccomp-bpf-hook/package.nix +++ b/pkgs/by-name/oc/oci-seccomp-bpf-hook/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, go-md2man -, installShellFiles -, pkg-config -, bcc -, libseccomp +{ + lib, + buildGoModule, + fetchFromGitHub, + go-md2man, + installShellFiles, + pkg-config, + bcc, + libseccomp, }: buildGoModule rec { @@ -19,7 +20,10 @@ buildGoModule rec { }; vendorHash = null; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; nativeBuildInputs = [ go-md2man installShellFiles diff --git a/pkgs/by-name/oc/ocl-icd/package.nix b/pkgs/by-name/oc/ocl-icd/package.nix index 2c092dd57b13e9..ba360ae32f7575 100644 --- a/pkgs/by-name/oc/ocl-icd/package.nix +++ b/pkgs/by-name/oc/ocl-icd/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, ruby -, opencl-headers -, autoreconfHook -, windows +{ + lib, + stdenv, + fetchFromGitHub, + ruby, + opencl-headers, + autoreconfHook, + windows, }: stdenv.mkDerivation rec { @@ -23,8 +24,7 @@ stdenv.mkDerivation rec { ruby ]; - buildInputs = [ opencl-headers ] - ++ lib.optionals stdenv.hostPlatform.isWindows [ windows.dlfcn ]; + buildInputs = [ opencl-headers ] ++ lib.optionals stdenv.hostPlatform.isWindows [ windows.dlfcn ]; configureFlags = [ "--enable-custom-vendordir=/run/opengl-driver/etc/OpenCL/vendors" @@ -36,8 +36,8 @@ stdenv.mkDerivation rec { meta = with lib; { description = "OpenCL ICD Loader for ${opencl-headers.name}"; mainProgram = "cllayerinfo"; - homepage = "https://github.com/OCL-dev/ocl-icd"; - license = licenses.bsd2; + homepage = "https://github.com/OCL-dev/ocl-icd"; + license = licenses.bsd2; platforms = platforms.unix ++ platforms.windows; maintainers = with maintainers; [ r-burns ]; }; diff --git a/pkgs/by-name/oc/oclgrind/package.nix b/pkgs/by-name/oc/oclgrind/package.nix index a95c227fae7682..6a16389664a1df 100644 --- a/pkgs/by-name/oc/oclgrind/package.nix +++ b/pkgs/by-name/oc/oclgrind/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, llvmPackages_12, readline, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + llvmPackages_12, + readline, + python3, +}: stdenv.mkDerivation rec { pname = "oclgrind"; @@ -13,7 +21,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; nativeCheckInputs = [ python3 ]; - buildInputs = [ llvmPackages_12.llvm llvmPackages_12.clang-unwrapped readline ]; + buildInputs = [ + llvmPackages_12.llvm + llvmPackages_12.clang-unwrapped + readline + ]; cmakeFlags = [ "-DCLANG_ROOT=${llvmPackages_12.clang-unwrapped}" diff --git a/pkgs/by-name/oc/ocm/package.nix b/pkgs/by-name/oc/ocm/package.nix index 1f4aedc372eaa0..d228be418b99b1 100644 --- a/pkgs/by-name/oc/ocm/package.nix +++ b/pkgs/by-name/oc/ocm/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, testers, ocm }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + ocm, +}: buildGoModule rec { pname = "ocm"; @@ -14,7 +21,10 @@ buildGoModule rec { vendorHash = "sha256-uj4xmNZViag+j4YavFjDvc/ClMBb99DhwlcKzvGWQ7c="; # Strip the final binary. - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeBuildInputs = [ installShellFiles ]; @@ -28,7 +38,6 @@ buildGoModule rec { "-skip=^TestCLI$" ]; - postInstall = '' installShellCompletion --cmd ocm \ --bash <($out/bin/ocm completion bash) \ @@ -46,6 +55,9 @@ buildGoModule rec { mainProgram = "ocm"; license = licenses.asl20; homepage = "https://github.com/openshift-online/ocm-cli"; - maintainers = with maintainers; [ stehessel jfchevrette ]; + maintainers = with maintainers; [ + stehessel + jfchevrette + ]; }; } diff --git a/pkgs/by-name/oc/ocproxy/package.nix b/pkgs/by-name/oc/ocproxy/package.nix index bc21884e6ac8d5..55f69c7026967c 100644 --- a/pkgs/by-name/oc/ocproxy/package.nix +++ b/pkgs/by-name/oc/ocproxy/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libevent }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libevent, +}: stdenv.mkDerivation rec { version = "1.60"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "03323nnhb4y9nzwva04mq7xg03dvdrgp689g89f69jqc261skcqx"; }; - nativeBuildInputs = [ autoconf automake ]; + nativeBuildInputs = [ + autoconf + automake + ]; buildInputs = [ libevent ]; preConfigure = '' diff --git a/pkgs/by-name/oc/ocr-a/package.nix b/pkgs/by-name/oc/ocr-a/package.nix index 216b960994d7ab..ea47d6282d692a 100644 --- a/pkgs/by-name/oc/ocr-a/package.nix +++ b/pkgs/by-name/oc/ocr-a/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "OCR-A"; diff --git a/pkgs/by-name/oc/ocrad/package.nix b/pkgs/by-name/oc/ocrad/package.nix index c1efa72ad12049..8ffd4ecf8a16af 100644 --- a/pkgs/by-name/oc/ocrad/package.nix +++ b/pkgs/by-name/oc/ocrad/package.nix @@ -1,4 +1,10 @@ -{ fetchurl, lib, stdenv, lzip, texinfo }: +{ + fetchurl, + lib, + stdenv, + lzip, + texinfo, +}: stdenv.mkDerivation rec { pname = "ocrad"; @@ -9,7 +15,9 @@ stdenv.mkDerivation rec { sha256 = "0divffvcaim89g4pvqs8kslbcxi475bcl3b4ynphf284k9zfdgx9"; }; - nativeBuildInputs = [ lzip /* unpack */ ]; + nativeBuildInputs = [ + lzip # unpack + ]; buildInputs = [ texinfo ]; doCheck = true; diff --git a/pkgs/by-name/oc/ocserv/package.nix b/pkgs/by-name/oc/ocserv/package.nix index fd223c12c94ff5..f6dbd0116827f2 100644 --- a/pkgs/by-name/oc/ocserv/package.nix +++ b/pkgs/by-name/oc/ocserv/package.nix @@ -1,6 +1,23 @@ -{ lib, stdenv, fetchFromGitLab, autoreconfHook, pkg-config, nettle, gnutls -, libev, protobufc, guile, geoip, libseccomp, gperf, readline -, lz4, libgssglue, ronn, pam, libxcrypt +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + nettle, + gnutls, + libev, + protobufc, + guile, + geoip, + libseccomp, + gperf, + readline, + lz4, + libgssglue, + ronn, + pam, + libxcrypt, }: stdenv.mkDerivation rec { @@ -14,8 +31,26 @@ stdenv.mkDerivation rec { hash = "sha256-IYiYC9oAw35YjpptUEnhuZQqoDevku25r7qi6SG8xtk="; }; - nativeBuildInputs = [ autoreconfHook gperf pkg-config ronn ]; - buildInputs = [ nettle gnutls libev protobufc guile geoip libseccomp readline lz4 libgssglue pam libxcrypt ]; + nativeBuildInputs = [ + autoreconfHook + gperf + pkg-config + ronn + ]; + buildInputs = [ + nettle + gnutls + libev + protobufc + guile + geoip + libseccomp + readline + lz4 + libgssglue + pam + libxcrypt + ]; meta = with lib; { homepage = "https://gitlab.com/openconnect/ocserv"; diff --git a/pkgs/by-name/oc/ocsigen-i18n/package.nix b/pkgs/by-name/oc/ocsigen-i18n/package.nix index bad8dc09a1c1c2..9ef1f8b35d5444 100644 --- a/pkgs/by-name/oc/ocsigen-i18n/package.nix +++ b/pkgs/by-name/oc/ocsigen-i18n/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, ocamlPackages }: +{ + lib, + fetchFromGitHub, + ocamlPackages, +}: ocamlPackages.buildDunePackage rec { pname = "ocsigen-i18n"; diff --git a/pkgs/by-name/oc/ocsinventory-agent/package.nix b/pkgs/by-name/oc/ocsinventory-agent/package.nix index fc6083282a580f..cdb7d2d6f5404e 100644 --- a/pkgs/by-name/oc/ocsinventory-agent/package.nix +++ b/pkgs/by-name/oc/ocsinventory-agent/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, perlPackages -, fetchFromGitHub -, fetchpatch -, makeWrapper -, shortenPerlShebang -, coreutils -, dmidecode -, findutils -, inetutils -, ipmitool -, iproute2 -, lvm2 -, nmap -, pciutils -, usbutils -, util-linux -, nixosTests -, testers -, ocsinventory-agent -, nix-update-script +{ + lib, + stdenv, + perlPackages, + fetchFromGitHub, + fetchpatch, + makeWrapper, + shortenPerlShebang, + coreutils, + dmidecode, + findutils, + inetutils, + ipmitool, + iproute2, + lvm2, + nmap, + pciutils, + usbutils, + util-linux, + nixosTests, + testers, + ocsinventory-agent, + nix-update-script, }: perlPackages.buildPerlPackage rec { @@ -44,47 +45,62 @@ perlPackages.buildPerlPackage rec { nativeBuildInputs = [ makeWrapper ] ++ lib.optional stdenv.hostPlatform.isDarwin shortenPerlShebang; - buildInputs = with perlPackages; [ - perl - DataUUID - GetoptLong - IOCompress - IOSocketSSL - LWP - LWPProtocolHttps - NetIP - NetNetmask - NetSNMP - ParseEDID - ProcDaemon - ProcPIDFile - XMLSimple - ] ++ lib.optionals stdenv.hostPlatform.isLinux (with perlPackages; [ - NetCUPS # cups-filters is broken on darwin - ]) ++ lib.optionals stdenv.hostPlatform.isDarwin (with perlPackages; [ - MacSysProfile - ]); + buildInputs = + with perlPackages; + [ + perl + DataUUID + GetoptLong + IOCompress + IOSocketSSL + LWP + LWPProtocolHttps + NetIP + NetNetmask + NetSNMP + ParseEDID + ProcDaemon + ProcPIDFile + XMLSimple + ] + ++ lib.optionals stdenv.hostPlatform.isLinux ( + with perlPackages; + [ + NetCUPS # cups-filters is broken on darwin + ] + ) + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with perlPackages; + [ + MacSysProfile + ] + ); - postInstall = let - runtimeDependencies = [ - coreutils # uname, cut, df, stat, uptime - findutils # find - inetutils # ifconfig - ipmitool # ipmitool - nmap # nmap - pciutils # lspci - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - dmidecode # dmidecode - iproute2 # ip - lvm2 # pvs - usbutils # lsusb - util-linux # last, lsblk, mount - ]; - in lib.optionalString stdenv.hostPlatform.isDarwin '' - shortenPerlShebang $out/bin/ocsinventory-agent - '' + '' - wrapProgram $out/bin/ocsinventory-agent --prefix PATH : ${lib.makeBinPath runtimeDependencies} - ''; + postInstall = + let + runtimeDependencies = + [ + coreutils # uname, cut, df, stat, uptime + findutils # find + inetutils # ifconfig + ipmitool # ipmitool + nmap # nmap + pciutils # lspci + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + dmidecode # dmidecode + iproute2 # ip + lvm2 # pvs + usbutils # lsusb + util-linux # last, lsblk, mount + ]; + in + lib.optionalString stdenv.hostPlatform.isDarwin '' + shortenPerlShebang $out/bin/ocsinventory-agent + '' + + '' + wrapProgram $out/bin/ocsinventory-agent --prefix PATH : ${lib.makeBinPath runtimeDependencies} + ''; passthru = { tests = { @@ -109,7 +125,10 @@ perlPackages.buildPerlPackage rec { downloadPage = "https://github.com/OCSInventory-NG/UnixAgent/releases"; license = licenses.gpl2Only; mainProgram = "ocsinventory-agent"; - maintainers = with maintainers; [ totoroot anthonyroussel ]; + maintainers = with maintainers; [ + totoroot + anthonyroussel + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/oc/octomap/package.nix b/pkgs/by-name/oc/octomap/package.nix index af668d279e27ae..cf4e530e425e53 100644 --- a/pkgs/by-name/oc/octomap/package.nix +++ b/pkgs/by-name/oc/octomap/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "octomap"; diff --git a/pkgs/by-name/oc/octopus-caller/package.nix b/pkgs/by-name/oc/octopus-caller/package.nix index c594108c6f47a2..87fae180408f22 100644 --- a/pkgs/by-name/oc/octopus-caller/package.nix +++ b/pkgs/by-name/oc/octopus-caller/package.nix @@ -1,4 +1,16 @@ -{lib, stdenv, fetchurl, fetchFromGitHub, cmake, boost179, gmp, htslib, zlib, xz, pkg-config}: +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + cmake, + boost179, + gmp, + htslib, + zlib, + xz, + pkg-config, +}: stdenv.mkDerivation rec { pname = "octopus"; @@ -11,13 +23,24 @@ stdenv.mkDerivation rec { sha256 = "sha256-FAogksVxUlzMlC0BqRu22Vchj6VX+8yNlHRLyb3g1sE="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ boost179 gmp htslib zlib xz ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + boost179 + gmp + htslib + zlib + xz + ]; - patches = [ (fetchurl { - url = "https://github.com/luntergroup/octopus/commit/17a597d192bcd5192689bf38c5836a98b824867a.patch"; - sha256 = "sha256-VaUr63v7mzhh4VBghH7a7qrqOYwl6vucmmKzTi9yAjY="; - }) ]; + patches = [ + (fetchurl { + url = "https://github.com/luntergroup/octopus/commit/17a597d192bcd5192689bf38c5836a98b824867a.patch"; + sha256 = "sha256-VaUr63v7mzhh4VBghH7a7qrqOYwl6vucmmKzTi9yAjY="; + }) + ]; postPatch = '' # Disable -Werror to avoid build failure on fresh toolchains like diff --git a/pkgs/by-name/oc/octopus/package.nix b/pkgs/by-name/oc/octopus/package.nix index a9b881b2cdc015..fbb2c30694e380 100644 --- a/pkgs/by-name/oc/octopus/package.nix +++ b/pkgs/by-name/oc/octopus/package.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchFromGitLab -, cmake -, pkg-config -, ninja -, gfortran -, which -, perl -, procps -, libvdwxc -, libyaml -, libxc -, fftw -, blas -, lapack -, gsl -, netcdf -, arpack -, spglib -, metis -, scalapack -, mpi -, enableMpi ? true -, python3 +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + pkg-config, + ninja, + gfortran, + which, + perl, + procps, + libvdwxc, + libyaml, + libxc, + fftw, + blas, + lapack, + gsl, + netcdf, + arpack, + spglib, + metis, + scalapack, + mpi, + enableMpi ? true, + python3, }: assert (!blas.isILP64) && (!lapack.isILP64); @@ -93,7 +94,12 @@ stdenv.mkDerivation rec { description = "Real-space time dependent density-functional theory code"; homepage = "https://octopus-code.org"; maintainers = with maintainers; [ markuskowa ]; - license = with licenses; [ gpl2Only asl20 lgpl3Plus bsd3 ]; + license = with licenses; [ + gpl2Only + asl20 + lgpl3Plus + bsd3 + ]; platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/by-name/oc/octosql/package.nix b/pkgs/by-name/oc/octosql/package.nix index e81ca18179c7c9..51be01c38baff1 100644 --- a/pkgs/by-name/oc/octosql/package.nix +++ b/pkgs/by-name/oc/octosql/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -8,15 +9,19 @@ buildGoModule rec { version = "0.13.0"; src = fetchFromGitHub { - owner = "cube2222"; - repo = pname; - rev = "v${version}"; + owner = "cube2222"; + repo = pname; + rev = "v${version}"; hash = "sha256-kzbIts5d2KmFfaAnOdpIXI1fiqBYXe5t981g4Uyk/cc="; }; vendorHash = "sha256-p/2UsvxxywQKtk/9wDa5fjS0z6xLLzDONuQ5AtnUonk="; - ldflags = [ "-s" "-w" "-X github.com/cube2222/octosql/cmd.VERSION=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/cube2222/octosql/cmd.VERSION=${version}" + ]; postInstall = '' rm -v $out/bin/tester diff --git a/pkgs/by-name/oc/octosuite/package.nix b/pkgs/by-name/oc/octosuite/package.nix index 46a4d44027f429..95d7b46be826bb 100644 --- a/pkgs/by-name/oc/octosuite/package.nix +++ b/pkgs/by-name/oc/octosuite/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/od/odamex/package.nix b/pkgs/by-name/od/odamex/package.nix index b813fc0e1c410f..02092d42991a5c 100644 --- a/pkgs/by-name/od/odamex/package.nix +++ b/pkgs/by-name/od/odamex/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, cmake -, pkg-config -, makeWrapper -, SDL -, SDL_mixer -, SDL_net -, wxGTK32 +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + makeWrapper, + SDL, + SDL_mixer, + SDL_net, + wxGTK32, }: stdenv.mkDerivation rec { @@ -32,17 +33,25 @@ stdenv.mkDerivation rec { wxGTK32 ]; - installPhase = '' - runHook preInstall - '' + (if stdenv.hostPlatform.isDarwin then '' - mkdir -p $out/{Applications,bin} - mv odalaunch/odalaunch.app $out/Applications - makeWrapper $out/{Applications/odalaunch.app/Contents/MacOS,bin}/odalaunch - '' else '' - make install - '') + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + '' + + ( + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p $out/{Applications,bin} + mv odalaunch/odalaunch.app $out/Applications + makeWrapper $out/{Applications/odalaunch.app/Contents/MacOS,bin}/odalaunch + '' + else + '' + make install + '' + ) + + '' + runHook postInstall + ''; meta = { homepage = "http://odamex.net/"; diff --git a/pkgs/by-name/od/ode/package.nix b/pkgs/by-name/od/ode/package.nix index 2906c342834280..75d3441b86702e 100644 --- a/pkgs/by-name/od/ode/package.nix +++ b/pkgs/by-name/od/ode/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, darwin +{ + lib, + stdenv, + fetchurl, + darwin, }: stdenv.mkDerivation (finalAttrs: { @@ -27,7 +28,12 @@ stdenv.mkDerivation (finalAttrs: { description = "Open Dynamics Engine"; mainProgram = "ode-config"; homepage = "https://www.ode.org"; - license = with licenses; [ bsd3 lgpl21Only lgpl3Only zlib ]; + license = with licenses; [ + bsd3 + lgpl21Only + lgpl3Only + zlib + ]; maintainers = with maintainers; [ wegank ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/od/odin2/package.nix b/pkgs/by-name/od/odin2/package.nix index ae3a464f43b212..40beb4b2a582cf 100644 --- a/pkgs/by-name/od/odin2/package.nix +++ b/pkgs/by-name/od/odin2/package.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, alsa-lib -, freetype -, libjack2 -, lv2 -, libX11 -, libXcursor -, libXext -, libXinerama -, libXrandr -, libGL -, gcc-unwrapped +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + alsa-lib, + freetype, + libjack2, + lv2, + libX11, + libXcursor, + libXext, + libXinerama, + libXrandr, + libGL, + gcc-unwrapped, }: stdenv.mkDerivation rec { @@ -52,13 +53,15 @@ stdenv.mkDerivation rec { ]; # JUCE dlopen's these at runtime, crashes without them - NIX_LDFLAGS = (toString [ - "-lX11" - "-lXext" - "-lXcursor" - "-lXinerama" - "-lXrandr" - ]); + NIX_LDFLAGS = ( + toString [ + "-lX11" + "-lXext" + "-lXcursor" + "-lXinerama" + "-lXrandr" + ] + ); cmakeFlags = [ "-DCMAKE_AR=${gcc-unwrapped}/bin/gcc-ar" @@ -73,8 +76,7 @@ stdenv.mkDerivation rec { cp -r VST3/Odin2.vst3 $out/lib/vst3 cp -r LV2/Odin2.lv2 $out/lib/lv2 cp -r CLAP/Odin2.clap $out/lib/clap -''; - + ''; meta = with lib; { description = "Odin 2 Synthesizer Plugin"; diff --git a/pkgs/by-name/od/odo/package.nix b/pkgs/by-name/od/odo/package.nix index f907f68914303d..2ebfc08a766991 100644 --- a/pkgs/by-name/od/odo/package.nix +++ b/pkgs/by-name/od/odo/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, odo }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + odo, +}: buildGoModule rec { pname = "odo"; diff --git a/pkgs/by-name/od/odoo/package.nix b/pkgs/by-name/od/odoo/package.nix index 8c7477c074ea5b..46ccb1773b44d5 100644 --- a/pkgs/by-name/od/odoo/package.nix +++ b/pkgs/by-name/od/odoo/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchgit -, fetchzip -, python312 -, rtlcss -, wkhtmltopdf -, nixosTests +{ + lib, + fetchgit, + fetchzip, + python312, + rtlcss, + wkhtmltopdf, + nixosTests, }: let @@ -13,7 +14,8 @@ let python = python312.override { self = python; }; -in python.pkgs.buildPythonApplication rec { +in +python.pkgs.buildPythonApplication rec { pname = "odoo"; version = "${odoo_version}.${odoo_release}"; @@ -27,7 +29,13 @@ in python.pkgs.buildPythonApplication rec { }; makeWrapperArgs = [ - "--prefix" "PATH" ":" "${lib.makeBinPath [ wkhtmltopdf rtlcss ]}" + "--prefix" + "PATH" + ":" + "${lib.makeBinPath [ + wkhtmltopdf + rtlcss + ]}" ]; propagatedBuildInputs = with python.pkgs; [ @@ -94,6 +102,9 @@ in python.pkgs.buildPythonApplication rec { description = "Open Source ERP and CRM"; homepage = "https://www.odoo.com/"; license = licenses.lgpl3Only; - maintainers = with maintainers; [ mkg20001 siriobalmelli ]; + maintainers = with maintainers; [ + mkg20001 + siriobalmelli + ]; }; } diff --git a/pkgs/by-name/od/odoo15/package.nix b/pkgs/by-name/od/odoo15/package.nix index be0f9a690660fe..c149bf1ee2bb8d 100644 --- a/pkgs/by-name/od/odoo15/package.nix +++ b/pkgs/by-name/od/odoo15/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, fetchzip -, python310 -, rtlcss -, wkhtmltopdf -, nixosTests +{ + lib, + fetchFromGitHub, + fetchzip, + python310, + rtlcss, + wkhtmltopdf, + nixosTests, }: let @@ -26,11 +27,15 @@ let dependencies = [ self.setuptools ]; - nativeCheckInputs = with self; [ pytestCheckHook pillow ]; + nativeCheckInputs = with self; [ + pytestCheckHook + pillow + ]; }); }; }; -in python.pkgs.buildPythonApplication rec { +in +python.pkgs.buildPythonApplication rec { pname = "odoo"; version = "${odoo_version}.${odoo_release}"; @@ -47,7 +52,10 @@ in python.pkgs.buildPythonApplication rec { "--prefix" "PATH" ":" - "${lib.makeBinPath [ wkhtmltopdf rtlcss ]}" + "${lib.makeBinPath [ + wkhtmltopdf + rtlcss + ]}" ]; propagatedBuildInputs = with python.pkgs; [ diff --git a/pkgs/by-name/od/odoo16/package.nix b/pkgs/by-name/od/odoo16/package.nix index b2acd426cf6059..73791dbcfcf1a6 100644 --- a/pkgs/by-name/od/odoo16/package.nix +++ b/pkgs/by-name/od/odoo16/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchzip -, python310 -, rtlcss -, wkhtmltopdf -, nixosTests +{ + lib, + fetchzip, + python310, + rtlcss, + wkhtmltopdf, + nixosTests, }: let @@ -12,7 +13,8 @@ let python = python310.override { self = python; }; -in python.pkgs.buildPythonApplication rec { +in +python.pkgs.buildPythonApplication rec { pname = "odoo"; version = "${odoo_version}.${odoo_release}"; @@ -26,7 +28,13 @@ in python.pkgs.buildPythonApplication rec { }; makeWrapperArgs = [ - "--prefix" "PATH" ":" "${lib.makeBinPath [ wkhtmltopdf rtlcss ]}" + "--prefix" + "PATH" + ":" + "${lib.makeBinPath [ + wkhtmltopdf + rtlcss + ]}" ]; propagatedBuildInputs = with python.pkgs; [ diff --git a/pkgs/by-name/od/odp-dpdk/package.nix b/pkgs/by-name/od/odp-dpdk/package.nix index d48a87216d4690..163d1959c47c26 100644 --- a/pkgs/by-name/od/odp-dpdk/package.nix +++ b/pkgs/by-name/od/odp-dpdk/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, dpdk -, libbpf -, libconfig -, libpcap -, numactl -, openssl -, zlib -, zstd -, libbsd -, elfutils -, jansson -, libnl +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + dpdk, + libbpf, + libconfig, + libpcap, + numactl, + openssl, + zlib, + zstd, + libbsd, + elfutils, + jansson, + libnl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/od/odpic/package.nix b/pkgs/by-name/od/odpic/package.nix index a1737adc69fa68..69509c2babdcce 100644 --- a/pkgs/by-name/od/odpic/package.nix +++ b/pkgs/by-name/od/odpic/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fixDarwinDylibNames, oracle-instantclient, libaio }: +{ + lib, + stdenv, + fetchFromGitHub, + fixDarwinDylibNames, + oracle-instantclient, + libaio, +}: let version = "5.4.0"; @@ -19,11 +26,14 @@ stdenv.mkDerivation { nativeBuildInputs = lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; - buildInputs = [ oracle-instantclient ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libaio ]; + buildInputs = [ oracle-instantclient ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libaio ]; dontPatchELF = true; - makeFlags = [ "PREFIX=$(out)" "CC=${stdenv.cc.targetPrefix}cc" "LD=${stdenv.cc.targetPrefix}cc" ]; + makeFlags = [ + "PREFIX=$(out)" + "CC=${stdenv.cc.targetPrefix}cc" + "LD=${stdenv.cc.targetPrefix}cc" + ]; postFixup = '' ${lib.optionalString (stdenv.hostPlatform.isLinux) '' @@ -39,7 +49,11 @@ stdenv.mkDerivation { homepage = "https://oracle.github.io/odpi/"; maintainers = with maintainers; [ mkazulak ]; license = licenses.asl20; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + ]; hydraPlatforms = [ ]; }; } diff --git a/pkgs/by-name/od/odroid-xu3-bootloader/package.nix b/pkgs/by-name/od/odroid-xu3-bootloader/package.nix index 2dbffe3384cec2..33bcc22fd52db1 100644 --- a/pkgs/by-name/od/odroid-xu3-bootloader/package.nix +++ b/pkgs/by-name/od/odroid-xu3-bootloader/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, coreutils, ubootOdroidXU3, runtimeShell }: +{ + stdenv, + lib, + fetchFromGitHub, + coreutils, + ubootOdroidXU3, + runtimeShell, +}: stdenv.mkDerivation { pname = "odroid-xu3-bootloader"; diff --git a/pkgs/by-name/od/odt2txt/package.nix b/pkgs/by-name/od/odt2txt/package.nix index 480c07f9cdccb9..cab3613f3c5f89 100644 --- a/pkgs/by-name/od/odt2txt/package.nix +++ b/pkgs/by-name/od/odt2txt/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, zlib, libiconv }: +{ + lib, + stdenv, + fetchurl, + zlib, + libiconv, +}: stdenv.mkDerivation rec { pname = "odt2txt"; @@ -9,9 +15,12 @@ stdenv.mkDerivation rec { sha256 = "23a889109ca9087a719c638758f14cc3b867a5dcf30a6c90bf6a0985073556dd"; }; - configurePhase="export makeFlags=\"DESTDIR=$out\""; + configurePhase = "export makeFlags=\"DESTDIR=$out\""; - buildInputs = [ zlib libiconv ]; + buildInputs = [ + zlib + libiconv + ]; meta = { description = "Simple .odt to .txt converter"; diff --git a/pkgs/by-name/od/odyssey/package.nix b/pkgs/by-name/od/odyssey/package.nix index 726b12182ebb97..c57bd1c37e56ba 100644 --- a/pkgs/by-name/od/odyssey/package.nix +++ b/pkgs/by-name/od/odyssey/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, openssl, postgresql, zstd, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openssl, + postgresql, + zstd, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "odyssey"; @@ -20,8 +29,15 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ openssl postgresql zstd ]; - cmakeFlags = [ "-DPQ_LIBRARY=${postgresql.lib}/lib" "-DBUILD_COMPRESSION=ON" ]; + buildInputs = [ + openssl + postgresql + zstd + ]; + cmakeFlags = [ + "-DPQ_LIBRARY=${postgresql.lib}/lib" + "-DBUILD_COMPRESSION=ON" + ]; installPhase = '' install -Dm755 -t $out/bin sources/odyssey diff --git a/pkgs/by-name/oe/oed/package.nix b/pkgs/by-name/oe/oed/package.nix index 189dfe345c0dd5..61540a7b6cf9e2 100644 --- a/pkgs/by-name/oe/oed/package.nix +++ b/pkgs/by-name/oe/oed/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/of/offensive-azure/package.nix b/pkgs/by-name/of/offensive-azure/package.nix index fb5dce6798dcd7..0243bab6a4583c 100644 --- a/pkgs/by-name/of/offensive-azure/package.nix +++ b/pkgs/by-name/of/offensive-azure/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/of/office-code-pro/package.nix b/pkgs/by-name/of/office-code-pro/package.nix index 5a7d7440454401..4662170b36c0ca 100644 --- a/pkgs/by-name/of/office-code-pro/package.nix +++ b/pkgs/by-name/of/office-code-pro/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "office-code-pro"; diff --git a/pkgs/by-name/of/offlineimap/package.nix b/pkgs/by-name/of/offlineimap/package.nix index b3743e74fe40a1..97cc447cedb4c0 100644 --- a/pkgs/by-name/of/offlineimap/package.nix +++ b/pkgs/by-name/of/offlineimap/package.nix @@ -1,15 +1,16 @@ -{ lib -, fetchFromGitHub -, python3 -, asciidoc -, cacert -, docbook_xsl -, installShellFiles -, libxml2 -, libxslt -, testers -, offlineimap -, fetchpatch +{ + lib, + fetchFromGitHub, + python3, + asciidoc, + cacert, + docbook_xsl, + installShellFiles, + libxml2, + libxslt, + testers, + offlineimap, + fetchpatch, }: python3.pkgs.buildPythonApplication rec { @@ -35,13 +36,13 @@ python3.pkgs.buildPythonApplication rec { name = "python312-comaptibility.patch"; url = "https://github.com/OfflineIMAP/offlineimap3/commit/a1951559299b297492b8454850fcfe6eb9822a38.patch"; hash = "sha256-CBGMHi+ZzOBJt3TxBf6elrTRMIQ+8wr3JgptL2etkoA="; - }) + }) (fetchpatch { # https://github.com/OfflineIMAP/offlineimap3/pull/161 name = "python312-compatibility.patch"; url = "https://github.com/OfflineIMAP/offlineimap3/commit/3dd8ebc931e3f3716a90072bd34e50ac1df629fa.patch"; hash = "sha256-2IJ0yzESt+zk+r+Z+9js3oKhFF0+xok0xK8Jd3G/gYY="; - }) + }) ]; postPatch = '' diff --git a/pkgs/by-name/of/offpunk/package.nix b/pkgs/by-name/of/offpunk/package.nix index d621dd75e35917..4de31550919925 100644 --- a/pkgs/by-name/of/offpunk/package.nix +++ b/pkgs/by-name/of/offpunk/package.nix @@ -1,14 +1,15 @@ -{ fetchFromSourcehut -, file -, installShellFiles -, less -, lib -, offpunk -, python3Packages -, testers -, timg -, xdg-utils -, xsel +{ + fetchFromSourcehut, + file, + installShellFiles, + less, + lib, + offpunk, + python3Packages, + testers, + timg, + xdg-utils, + xsel, }: let @@ -44,7 +45,10 @@ python3Packages.buildPythonApplication rec { hash = "sha256-ttR8S7FQQs8DkgAEvTIhuQ5zZrHtovy2W8TOw0xhSGk="; }; - nativeBuildInputs = [ python3Packages.hatchling installShellFiles ]; + nativeBuildInputs = [ + python3Packages.hatchling + installShellFiles + ]; propagatedBuildInputs = otherDependencies ++ pythonDependencies; postInstall = '' diff --git a/pkgs/by-name/of/offrss/package.nix b/pkgs/by-name/of/offrss/package.nix index 89853c8a088d6a..4bc3eb3a8094ae 100644 --- a/pkgs/by-name/of/offrss/package.nix +++ b/pkgs/by-name/of/offrss/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, curl, libmrss, podofo, libiconv }: +{ + lib, + stdenv, + fetchurl, + curl, + libmrss, + podofo, + libiconv, +}: stdenv.mkDerivation rec { pname = "offrss"; @@ -9,7 +17,11 @@ stdenv.mkDerivation rec { cp offrss $out/bin ''; - buildInputs = [ curl libmrss ] + buildInputs = + [ + curl + libmrss + ] ++ lib.optional (stdenv.hostPlatform == stdenv.buildPlatform) podofo ++ lib.optional (!stdenv.hostPlatform.isLinux) libiconv; @@ -18,14 +30,17 @@ stdenv.mkDerivation rec { # offrss.o:offrss.h:75: first defined here env.NIX_CFLAGS_COMPILE = "-fcommon"; - configurePhase = '' - substituteInPlace Makefile \ - --replace '$(CC) $(CFLAGS) $(LDFLAGS)' '$(CXX) $(CFLAGS) $(LDFLAGS)' - '' + lib.optionalString (!stdenv.hostPlatform.isLinux) '' - sed 's/#EXTRA/EXTRA/' -i Makefile - '' + lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' - sed 's/^PDF/#PDF/' -i Makefile - ''; + configurePhase = + '' + substituteInPlace Makefile \ + --replace '$(CC) $(CFLAGS) $(LDFLAGS)' '$(CXX) $(CFLAGS) $(LDFLAGS)' + '' + + lib.optionalString (!stdenv.hostPlatform.isLinux) '' + sed 's/#EXTRA/EXTRA/' -i Makefile + '' + + lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' + sed 's/^PDF/#PDF/' -i Makefile + ''; src = fetchurl { url = "http://vicerveza.homeunix.net/~viric/soft/offrss/offrss-${version}.tar.gz"; diff --git a/pkgs/by-name/of/offzip/package.nix b/pkgs/by-name/of/offzip/package.nix index 3ec2165c703b41..6b422ff435e8a7 100644 --- a/pkgs/by-name/of/offzip/package.nix +++ b/pkgs/by-name/of/offzip/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchzip -, zlib +{ + lib, + stdenv, + fetchzip, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/of/ofono/package.nix b/pkgs/by-name/of/ofono/package.nix index c7aa844b7baa35..52dc76dafc4fbc 100644 --- a/pkgs/by-name/of/ofono/package.nix +++ b/pkgs/by-name/of/ofono/package.nix @@ -1,20 +1,25 @@ -{ lib, stdenv -, fetchzip -, autoreconfHook -, pkg-config -, glib -, dbus -, ell -, systemd -, bluez -, mobile-broadband-provider-info +{ + lib, + stdenv, + fetchzip, + autoreconfHook, + pkg-config, + glib, + dbus, + ell, + systemd, + bluez, + mobile-broadband-provider-info, }: stdenv.mkDerivation rec { pname = "ofono"; version = "2.3"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchzip { url = "https://git.kernel.org/pub/scm/network/ofono/ofono.git/snapshot/ofono-${version}.tar.gz"; diff --git a/pkgs/by-name/og/ogdf/package.nix b/pkgs/by-name/og/ogdf/package.nix index e88fc796ba7734..c8f2c94de984b1 100644 --- a/pkgs/by-name/og/ogdf/package.nix +++ b/pkgs/by-name/og/ogdf/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, doxygen }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + doxygen, +}: stdenv.mkDerivation rec { pname = "ogdf"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-zkQ6sS0EUmiigv3T7To+tG3XbFbR3XEbFo15oQ0bWf0="; }; - nativeBuildInputs = [ cmake doxygen ]; + nativeBuildInputs = [ + cmake + doxygen + ]; cmakeFlags = [ "-DCMAKE_CXX_FLAGS=-fPIC" @@ -37,5 +46,5 @@ stdenv.mkDerivation rec { OGDF is developed and supported by Osnabrück University, TU Dortmund, University of Cologne, University of Konstanz, and TU Ilmenau. ''; - }; + }; } diff --git a/pkgs/by-name/og/oggvideotools/package.nix b/pkgs/by-name/og/oggvideotools/package.nix index 004fb3579253e5..11916fc4a790db 100644 --- a/pkgs/by-name/og/oggvideotools/package.nix +++ b/pkgs/by-name/og/oggvideotools/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, fetchpatch, cmake, pkg-config, boost, gd, libogg, libtheora, libvorbis }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + cmake, + pkg-config, + boost, + gd, + libogg, + libtheora, + libvorbis, +}: stdenv.mkDerivation rec { pname = "oggvideotools"; @@ -34,9 +46,18 @@ stdenv.mkDerivation rec { substituteInPlace CMakeLists.txt --replace " -O0 " "" ''; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ boost gd libogg libtheora libvorbis ]; + buildInputs = [ + boost + gd + libogg + libtheora + libvorbis + ]; meta = with lib; { description = "Toolbox for manipulating and creating Ogg video files"; diff --git a/pkgs/by-name/og/ogmtools/package.nix b/pkgs/by-name/og/ogmtools/package.nix index d910383bf956d7..555ddb9834f28e 100644 --- a/pkgs/by-name/og/ogmtools/package.nix +++ b/pkgs/by-name/og/ogmtools/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, libogg, libvorbis, libdvdread }: +{ + lib, + stdenv, + fetchurl, + libogg, + libvorbis, + libdvdread, +}: stdenv.mkDerivation rec { pname = "ogmtools"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "1spx81p5wf59ksl3r3gvf78d77sh7gj8a6lw773iv67bphfivmn8"; }; - buildInputs = [ libogg libvorbis libdvdread ]; + buildInputs = [ + libogg + libvorbis + libdvdread + ]; env.NIX_CFLAGS_COMPILE = toString [ "-std=c++14" ]; diff --git a/pkgs/by-name/og/ograc/package.nix b/pkgs/by-name/og/ograc/package.nix index 538a22ab688c35..aed6c9a232bb77 100644 --- a/pkgs/by-name/og/ograc/package.nix +++ b/pkgs/by-name/og/ograc/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitLab, lib, rustPlatform, }: +{ + fetchFromGitLab, + lib, + rustPlatform, +}: rustPlatform.buildRustPackage { pname = "ograc"; @@ -19,4 +23,3 @@ rustPlatform.buildRustPackage { maintainers = with maintainers; [ sciencentistguy ]; }; } - diff --git a/pkgs/by-name/og/oguri/package.nix b/pkgs/by-name/og/oguri/package.nix index b7cc17014ed3e0..ef9985bc51e368 100644 --- a/pkgs/by-name/og/oguri/package.nix +++ b/pkgs/by-name/og/oguri/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, meson -, ninja -, cairo -, gdk-pixbuf -, wayland -, wayland-protocols -, wayland-scanner +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + meson, + ninja, + cairo, + gdk-pixbuf, + wayland, + wayland-protocols, + wayland-scanner, }: stdenv.mkDerivation rec { @@ -23,7 +24,12 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ pkg-config meson ninja wayland-scanner ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + wayland-scanner + ]; buildInputs = [ cairo gdk-pixbuf diff --git a/pkgs/by-name/oh/oh-my-fish/package.nix b/pkgs/by-name/oh/oh-my-fish/package.nix index 019979bf9f395e..b91a89c0beb182 100644 --- a/pkgs/by-name/oh/oh-my-fish/package.nix +++ b/pkgs/by-name/oh/oh-my-fish/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, fish -, runtimeShell -, substituteAll +{ + lib, + stdenv, + fetchFromGitHub, + fish, + runtimeShell, + substituteAll, }: stdenv.mkDerivation (finalAttrs: { @@ -36,12 +37,14 @@ stdenv.mkDerivation (finalAttrs: { mkdir -pv $out/bin $out/share/oh-my-fish cp -vr * $out/share/oh-my-fish - cp -v ${substituteAll { - name = "omf-install"; - src = ./omf-install; - omf = placeholder "out"; - inherit fish runtimeShell; - }} $out/bin/omf-install + cp -v ${ + substituteAll { + name = "omf-install"; + src = ./omf-install; + omf = placeholder "out"; + inherit fish runtimeShell; + } + } $out/bin/omf-install chmod +x $out/bin/omf-install cat $out/bin/omf-install diff --git a/pkgs/by-name/oh/oh-my-git/package.nix b/pkgs/by-name/oh/oh-my-git/package.nix index 5674e2a0a94d8d..b7f08cffd8852b 100644 --- a/pkgs/by-name/oh/oh-my-git/package.nix +++ b/pkgs/by-name/oh/oh-my-git/package.nix @@ -1,28 +1,29 @@ -{ lib -, autoPatchelfHook -, copyDesktopItems -, fetchFromGitHub -, makeDesktopItem -, stdenv -, alsa-lib -, gcc-unwrapped -, git -, godot3-export-templates -, godot3-headless -, libGLU -, libX11 -, libXcursor -, libXext -, libXfixes -, libXi -, libXinerama -, libXrandr -, libXrender -, libglvnd -, libpulseaudio -, perl -, zlib -, udev # for libudev +{ + lib, + autoPatchelfHook, + copyDesktopItems, + fetchFromGitHub, + makeDesktopItem, + stdenv, + alsa-lib, + gcc-unwrapped, + git, + godot3-export-templates, + godot3-headless, + libGLU, + libX11, + libXcursor, + libXext, + libXfixes, + libXi, + libXinerama, + libXrandr, + libXrender, + libglvnd, + libpulseaudio, + perl, + zlib, + udev, # for libudev }: stdenv.mkDerivation rec { @@ -129,7 +130,7 @@ stdenv.mkDerivation rec { description = "Interactive Git learning game"; mainProgram = "oh-my-git"; license = with licenses; [ blueOak100 ]; - platforms = [ "x86_64-linux" ]; + platforms = [ "x86_64-linux" ]; maintainers = with maintainers; [ jojosch ]; }; } diff --git a/pkgs/by-name/oh/oh-my-posh/package.nix b/pkgs/by-name/oh/oh-my-posh/package.nix index d397ebf3cc24b5..1060858c04d6e4 100644 --- a/pkgs/by-name/oh/oh-my-posh/package.nix +++ b/pkgs/by-name/oh/oh-my-posh/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -57,6 +58,9 @@ buildGoModule rec { homepage = "https://ohmyposh.dev"; changelog = "https://github.com/JanDeDobbeleer/oh-my-posh/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ lucperkins urandom ]; + maintainers = with maintainers; [ + lucperkins + urandom + ]; }; } diff --git a/pkgs/by-name/oh/oh-my-zsh/package.nix b/pkgs/by-name/oh/oh-my-zsh/package.nix index de025a584af349..63138cca8f4559 100644 --- a/pkgs/by-name/oh/oh-my-zsh/package.nix +++ b/pkgs/by-name/oh/oh-my-zsh/package.nix @@ -1,8 +1,23 @@ # This script was inspired by the ArchLinux User Repository package: # # https://aur.archlinux.org/cgit/aur.git/tree/PKGBUILD?h=oh-my-zsh-git -{ lib, stdenv, fetchFromGitHub, nixosTests, writeScript, common-updater-scripts -, git, nix, nixfmt-classic, jq, coreutils, gnused, curl, cacert, bash }: +{ + lib, + stdenv, + fetchFromGitHub, + nixosTests, + writeScript, + common-updater-scripts, + git, + nix, + nixfmt-classic, + jq, + coreutils, + gnused, + curl, + cacert, + bash, +}: stdenv.mkDerivation rec { version = "2024-10-01"; diff --git a/pkgs/by-name/oh/oh/package.nix b/pkgs/by-name/oh/oh/package.nix index 9a0308a70e75db..0277d0194405cd 100644 --- a/pkgs/by-name/oh/oh/package.nix +++ b/pkgs/by-name/oh/oh/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "oh"; diff --git a/pkgs/by-name/oi/oidentd/package.nix b/pkgs/by-name/oi/oidentd/package.nix index 4d3c03d90564e9..4be824f00e4c25 100644 --- a/pkgs/by-name/oi/oidentd/package.nix +++ b/pkgs/by-name/oi/oidentd/package.nix @@ -1,9 +1,18 @@ -{ lib, stdenv, fetchurl, bison, flex }: +{ + lib, + stdenv, + fetchurl, + bison, + flex, +}: stdenv.mkDerivation rec { pname = "oidentd"; version = "3.1.0"; - nativeBuildInputs = [ bison flex ]; + nativeBuildInputs = [ + bison + flex + ]; src = fetchurl { url = "https://files.janikrabe.com/pub/oidentd/releases/${version}/${pname}-${version}.tar.gz"; diff --git a/pkgs/by-name/oi/oil-buku/package.nix b/pkgs/by-name/oi/oil-buku/package.nix index 5f895179f1f478..58ad6883843afb 100644 --- a/pkgs/by-name/oi/oil-buku/package.nix +++ b/pkgs/by-name/oi/oil-buku/package.nix @@ -1,4 +1,12 @@ -{ stdenvNoCC, lib, fetchFromGitHub, jq, gawk, peco, makeWrapper }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, + jq, + gawk, + peco, + makeWrapper, +}: stdenvNoCC.mkDerivation rec { pname = "oil-buku"; diff --git a/pkgs/by-name/oi/oils-for-unix/package.nix b/pkgs/by-name/oi/oils-for-unix/package.nix index d6c2067146a978..b90ddd8eeb3379 100644 --- a/pkgs/by-name/oi/oils-for-unix/package.nix +++ b/pkgs/by-name/oi/oils-for-unix/package.nix @@ -1,9 +1,19 @@ -{ stdenv, lib, fetchurl, symlinkJoin, withReadline ? true, readline }: +{ + stdenv, + lib, + fetchurl, + symlinkJoin, + withReadline ? true, + readline, +}: let readline-all = symlinkJoin { name = "readline-all"; - paths = [ readline readline.dev ]; + paths = [ + readline + readline.dev + ]; }; in stdenv.mkDerivation rec { @@ -45,12 +55,14 @@ stdenv.mkDerivation rec { # whereas running it outside of Nix with clang version 15.0.0 generates just a warning. The shell seems to # work just fine though, so we disable the error here. env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-error=incompatible-function-pointer-types"; - configureFlags = [ - "--datarootdir=${placeholder "out"}" - ] ++ lib.optionals withReadline [ - "--with-readline" - "--readline=${readline-all}" - ]; + configureFlags = + [ + "--datarootdir=${placeholder "out"}" + ] + ++ lib.optionals withReadline [ + "--with-readline" + "--readline=${readline-all}" + ]; meta = { description = "Unix shell with JSON-compatible structured data. It's our upgrade path from bash to a better language and runtime"; @@ -59,7 +71,10 @@ stdenv.mkDerivation rec { license = lib.licenses.asl20; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ mkg20001 melkor333 ]; + maintainers = with lib.maintainers; [ + mkg20001 + melkor333 + ]; changelog = "https://www.oilshell.org/release/${version}/changelog.html"; }; diff --git a/pkgs/by-name/oi/oink/package.nix b/pkgs/by-name/oi/oink/package.nix index fb39bf80247cc2..aac1061ba60e06 100644 --- a/pkgs/by-name/oi/oink/package.nix +++ b/pkgs/by-name/oi/oink/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -25,6 +26,9 @@ buildGoModule rec { homepage = "https://github.com/rlado/oink"; license = lib.licenses.mit; mainProgram = "oink"; - maintainers = with lib.maintainers; [ jtbx pmw ]; + maintainers = with lib.maintainers; [ + jtbx + pmw + ]; }; } diff --git a/pkgs/by-name/ok/okolors/package.nix b/pkgs/by-name/ok/okolors/package.nix index 8d20c7432e8e24..91f972e8cb2510 100644 --- a/pkgs/by-name/ok/okolors/package.nix +++ b/pkgs/by-name/ok/okolors/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ok/oksh/package.nix b/pkgs/by-name/ok/oksh/package.nix index 391ccab4ea5f0f..8d73437a0cbe35 100644 --- a/pkgs/by-name/ok/oksh/package.nix +++ b/pkgs/by-name/ok/oksh/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchFromGitHub -, buildPackages -, ncurses +{ + stdenv, + lib, + fetchFromGitHub, + buildPackages, + ncurses, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ok/okta-aws-cli/package.nix b/pkgs/by-name/ok/okta-aws-cli/package.nix index 35ddc879dbe374..991c08deb52461 100644 --- a/pkgs/by-name/ok/okta-aws-cli/package.nix +++ b/pkgs/by-name/ok/okta-aws-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "okta-aws-cli"; @@ -7,15 +11,18 @@ buildGoModule rec { subPackages = [ "cmd/okta-aws-cli" ]; src = fetchFromGitHub { - owner = "okta"; - repo = "okta-aws-cli"; - rev = "v${version}"; + owner = "okta"; + repo = "okta-aws-cli"; + rev = "v${version}"; sha256 = "sha256-dts2aTd90bsuTkXB6AxFN6IziOQXTG1XLT0XSAC1Avc="; }; vendorHash = "sha256-2VTq8lzGYBKH410/mflloAphWTwFie3mdmz2kLkfuQ0="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "CLI for having Okta as the IdP for AWS CLI operations"; diff --git a/pkgs/by-name/ok/okteto/package.nix b/pkgs/by-name/ok/okteto/package.nix index 03c513df074b80..da499d0484e479 100644 --- a/pkgs/by-name/ok/okteto/package.nix +++ b/pkgs/by-name/ok/okteto/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, testers, okteto }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + okteto, +}: buildGoModule rec { pname = "okteto"; @@ -21,7 +28,10 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - excludedPackages = [ "integration" "samples" ]; + excludedPackages = [ + "integration" + "samples" + ]; ldflags = [ "-s" @@ -29,7 +39,11 @@ buildGoModule rec { "-X github.com/okteto/okteto/pkg/config.VersionString=${version}" ]; - tags = [ "osusergo" "netgo" "static_build" ]; + tags = [ + "osusergo" + "netgo" + "static_build" + ]; preCheck = '' export HOME="$(mktemp -d)" diff --git a/pkgs/by-name/ol/olaris-server/package.nix b/pkgs/by-name/ol/olaris-server/package.nix index 1b50695ffd5b14..fb4de53b716e24 100644 --- a/pkgs/by-name/ol/olaris-server/package.nix +++ b/pkgs/by-name/ol/olaris-server/package.nix @@ -1,10 +1,11 @@ -{ buildGoModule -, fetchFromGitLab -, fetchzip -, ffmpeg -, installShellFiles -, lib -, makeWrapper +{ + buildGoModule, + fetchFromGitLab, + fetchzip, + ffmpeg, + installShellFiles, + lib, + makeWrapper, }: buildGoModule rec { @@ -18,17 +19,19 @@ buildGoModule rec { hash = "sha256-Uhnh6GC85ORKnfHeYNtbSA40osuscxXDF5/kXJrF2Cs="; }; - preBuild = let - olaris-react = fetchzip { - url = "https://gitlab.com/api/v4/projects/olaris%2Folaris-react/jobs/artifacts/v${version}/download?job=build"; - extension = "zip"; - hash = "sha256-MkxBf/mGvtiOu0e79bMpd9Z/D0eOxhzPE+bKic//viM="; - }; - in '' - # cannot build olaris-react https://github.com/NixOS/nixpkgs/issues/203708 - cp -r ${olaris-react} react/build - make generate - ''; + preBuild = + let + olaris-react = fetchzip { + url = "https://gitlab.com/api/v4/projects/olaris%2Folaris-react/jobs/artifacts/v${version}/download?job=build"; + extension = "zip"; + hash = "sha256-MkxBf/mGvtiOu0e79bMpd9Z/D0eOxhzPE+bKic//viM="; + }; + in + '' + # cannot build olaris-react https://github.com/NixOS/nixpkgs/issues/203708 + cp -r ${olaris-react} react/build + make generate + ''; ldflags = [ "-s" @@ -38,7 +41,10 @@ buildGoModule rec { vendorHash = "sha256-bw8zvDGFBci9bELsxAD0otpNocBnO8aAcgyohLZ3Mv0="; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; # integration tests require network access doCheck = false; @@ -48,7 +54,7 @@ buildGoModule rec { --bash <($out/bin/olaris-server completion bash) \ --fish <($out/bin/olaris-server completion fish) \ --zsh <($out/bin/olaris-server completion zsh) - wrapProgram $out/bin/olaris-server --prefix PATH : ${lib.makeBinPath [ffmpeg]} + wrapProgram $out/bin/olaris-server --prefix PATH : ${lib.makeBinPath [ ffmpeg ]} ''; meta = with lib; { diff --git a/pkgs/by-name/ol/oldsindhi/package.nix b/pkgs/by-name/ol/oldsindhi/package.nix index 88692d91456498..a52d3630c63564 100644 --- a/pkgs/by-name/ol/oldsindhi/package.nix +++ b/pkgs/by-name/ol/oldsindhi/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "oldsindhi"; @@ -22,7 +26,10 @@ stdenvNoCC.mkDerivation rec { homepage = "https://github.com/MihailJP/oldsindhi"; description = "Free Sindhi Khudabadi font"; maintainers = with maintainers; [ mathnerd314 ]; - license = with licenses; [ mit ofl ]; + license = with licenses; [ + mit + ofl + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/ol/oldstandard/package.nix b/pkgs/by-name/ol/oldstandard/package.nix index b85d9694613fed..05402cecb1a03d 100644 --- a/pkgs/by-name/ol/oldstandard/package.nix +++ b/pkgs/by-name/ol/oldstandard/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "oldstandard"; diff --git a/pkgs/by-name/ol/olm/package.nix b/pkgs/by-name/ol/olm/package.nix index c83b84fe71e1d1..ea63963a719516 100644 --- a/pkgs/by-name/ol/olm/package.nix +++ b/pkgs/by-name/ol/olm/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, cmake }: +{ + lib, + stdenv, + fetchFromGitLab, + cmake, +}: stdenv.mkDerivation rec { pname = "olm"; @@ -26,52 +31,57 @@ stdenv.mkDerivation rec { description = "Implements double cryptographic ratchet and Megolm ratchet"; homepage = "https://gitlab.matrix.org/matrix-org/olm"; license = licenses.asl20; - maintainers = with maintainers; [ tilpner oxzi ]; - knownVulnerabilities = [ '' - The libolm end‐to‐end encryption library used in many Matrix - clients and Jitsi Meet has been deprecated upstream, and relies - on a cryptography library that has known side‐channel issues and - disclaims that its implementations are not cryptographically secure - and should not be used when cryptographic security is required. - - It is not known if the issues can be exploited over the network in - practical conditions. Upstream does not believe such an attack is - feasible, but has stated that the library should not be used going - forward, and there are no plans to move to another cryptography - implementation or otherwise further maintain the library at all. - - You should make an informed decision about whether to override this - security warning, especially if you critically rely on end‐to‐end - encryption. If you don’t care about that, or don’t use the Matrix - functionality of a multi‐protocol client depending on libolm, - then there should be no additional risk. - - Some clients are investigating migrating away from libolm to maintained - libraries without known vulnerabilities. - - For further information, see: - - * The CVE records for the known vulnerabilities: - - * CVE-2024-45191 - * CVE-2024-45192 - * CVE-2024-45193 - - * The libolm deprecation notice: - - - * The warning from the cryptography code used by libolm: - - - * The blog post disclosing the details of the known vulnerabilities: - - - * The statement about the deprecation and vulnerabilities from the - Matrix.org Foundation: - - - * A (likely incomplete) aggregation of client tracking issue links: - - '' ]; + maintainers = with maintainers; [ + tilpner + oxzi + ]; + knownVulnerabilities = [ + '' + The libolm end‐to‐end encryption library used in many Matrix + clients and Jitsi Meet has been deprecated upstream, and relies + on a cryptography library that has known side‐channel issues and + disclaims that its implementations are not cryptographically secure + and should not be used when cryptographic security is required. + + It is not known if the issues can be exploited over the network in + practical conditions. Upstream does not believe such an attack is + feasible, but has stated that the library should not be used going + forward, and there are no plans to move to another cryptography + implementation or otherwise further maintain the library at all. + + You should make an informed decision about whether to override this + security warning, especially if you critically rely on end‐to‐end + encryption. If you don’t care about that, or don’t use the Matrix + functionality of a multi‐protocol client depending on libolm, + then there should be no additional risk. + + Some clients are investigating migrating away from libolm to maintained + libraries without known vulnerabilities. + + For further information, see: + + * The CVE records for the known vulnerabilities: + + * CVE-2024-45191 + * CVE-2024-45192 + * CVE-2024-45193 + + * The libolm deprecation notice: + + + * The warning from the cryptography code used by libolm: + + + * The blog post disclosing the details of the known vulnerabilities: + + + * The statement about the deprecation and vulnerabilities from the + Matrix.org Foundation: + + + * A (likely incomplete) aggregation of client tracking issue links: + + '' + ]; }; } diff --git a/pkgs/by-name/ol/olsrd/package.nix b/pkgs/by-name/ol/olsrd/package.nix index 5f8985b66cba77..e0b709dbf81679 100644 --- a/pkgs/by-name/ol/olsrd/package.nix +++ b/pkgs/by-name/ol/olsrd/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, bison, flex }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + bison, + flex, +}: stdenv.mkDerivation rec { pname = "olsrd"; @@ -20,7 +27,10 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ bison flex ]; + buildInputs = [ + bison + flex + ]; preConfigure = '' makeFlags="prefix=$out ETCDIR=$out/etc" diff --git a/pkgs/by-name/ol/olvid/package.nix b/pkgs/by-name/ol/olvid/package.nix index 34b73e2a863e43..85798297b37cef 100644 --- a/pkgs/by-name/ol/olvid/package.nix +++ b/pkgs/by-name/ol/olvid/package.nix @@ -1,36 +1,45 @@ -{ stdenv -, lib -, fetchurl -, zlib -, libXext -, libX11 -, libXrender -, libXtst -, libXi -, freetype -, alsa-lib -, jdk21 -, openjfx21 -, autoPatchelfHook -, makeBinaryWrapper -, wrapGAppsHook3 +{ + stdenv, + lib, + fetchurl, + zlib, + libXext, + libX11, + libXrender, + libXtst, + libXi, + freetype, + alsa-lib, + jdk21, + openjfx21, + autoPatchelfHook, + makeBinaryWrapper, + wrapGAppsHook3, }: let repo = "olvid"; - javafxModules = [ "swing" "controls" "media" "fxml" "graphics" "base" ]; + javafxModules = [ + "swing" + "controls" + "media" + "fxml" + "graphics" + "base" + ]; classpath = lib.concatMap (mod: [ "${openjfx21}/modules_src/javafx.${mod}/module-info.java" "${openjfx21}/modules/javafx.${mod}" "${openjfx21}/modules_libs/javafx.${mod}" - ]) javafxModules ++ - [ "$out/share/${repo}/*" ]; + ]) javafxModules + ++ [ "$out/share/${repo}/*" ]; jvmArgs = [ - "-cp" (lib.concatStringsSep ":" classpath) + "-cp" + (lib.concatStringsSep ":" classpath) "-Djpackage.app-version=$version" "-Dolvid.sqlcipher=true" "-Dolvid.dev=false" diff --git a/pkgs/by-name/om/om4/package.nix b/pkgs/by-name/om/om4/package.nix index 4425ae52fb5fcf..078bc8510a4ae5 100644 --- a/pkgs/by-name/om/om4/package.nix +++ b/pkgs/by-name/om/om4/package.nix @@ -1,4 +1,10 @@ -{ stdenv, fetchFromGitHub, bison, flex, lib }: +{ + stdenv, + fetchFromGitHub, + bison, + flex, + lib, +}: stdenv.mkDerivation rec { pname = "om4"; @@ -12,14 +18,22 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ bison flex ]; + nativeBuildInputs = [ + bison + flex + ]; configureFlags = [ "--enable-m4" ]; meta = with lib; { description = "Portable OpenBSD m4 macro processor"; homepage = "https://github.com/ibara/m4"; - license = with licenses; [ bsd2 bsd3 isc publicDomain ]; + license = with licenses; [ + bsd2 + bsd3 + isc + publicDomain + ]; mainProgram = "m4"; platforms = platforms.unix; maintainers = [ ]; diff --git a/pkgs/by-name/om/omake/package.nix b/pkgs/by-name/om/omake/package.nix index 956a4d4a5d018d..2cb994682e724a 100644 --- a/pkgs/by-name/om/omake/package.nix +++ b/pkgs/by-name/om/omake/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ocaml }: +{ + lib, + stdenv, + fetchurl, + ocaml, +}: stdenv.mkDerivation rec { @@ -18,8 +23,8 @@ stdenv.mkDerivation rec { description = "Build system designed for scalability and portability"; homepage = "http://projects.camlcity.org/projects/omake.html"; license = with lib.licenses; [ - mit /* scripts */ - gpl2 /* program */ + mit # scripts + gpl2 # program ]; inherit (ocaml.meta) platforms; }; diff --git a/pkgs/by-name/om/omni-gtk-theme/package.nix b/pkgs/by-name/om/omni-gtk-theme/package.nix index b216eff6193aa5..971a2c4eada7b6 100644 --- a/pkgs/by-name/om/omni-gtk-theme/package.nix +++ b/pkgs/by-name/om/omni-gtk-theme/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchFromGitHub, + gtk-engine-murrine, +}: stdenv.mkDerivation { pname = "omni-gtk-theme"; diff --git a/pkgs/by-name/om/omnictl/package.nix b/pkgs/by-name/om/omnictl/package.nix index cd2629e2a700d5..c7669b06b41895 100644 --- a/pkgs/by-name/om/omnictl/package.nix +++ b/pkgs/by-name/om/omnictl/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "omnictl"; @@ -13,7 +18,10 @@ buildGoModule rec { vendorHash = "sha256-BF/F/siVIYJT4abOlwQjpnQpmNFdOo566VGPIo08PO0="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; GOWORK = "off"; diff --git a/pkgs/by-name/om/omniorb/package.nix b/pkgs/by-name/om/omniorb/package.nix index bbe663911ff494..47a546781e3427 100644 --- a/pkgs/by-name/om/omniorb/package.nix +++ b/pkgs/by-name/om/omniorb/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, python3 +{ + lib, + stdenv, + fetchurl, + pkg-config, + python3, }: stdenv.mkDerivation rec { @@ -44,9 +45,12 @@ stdenv.mkDerivation rec { (for the libraries),and GNU General Public License (for the tools). omniORB is largely CORBA 2.6 compliant. ''; - homepage = "http://omniorb.sourceforge.net/"; - license = with licenses; [ gpl2Plus lgpl21Plus ]; + homepage = "http://omniorb.sourceforge.net/"; + license = with licenses; [ + gpl2Plus + lgpl21Plus + ]; maintainers = with maintainers; [ smironov ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/om/omnisharp-roslyn/deps.nix b/pkgs/by-name/om/omnisharp-roslyn/deps.nix index 2d8a19ef1be6a4..2cdd8a5934feb3 100644 --- a/pkgs/by-name/om/omnisharp-roslyn/deps.nix +++ b/pkgs/by-name/om/omnisharp-roslyn/deps.nix @@ -1,148 +1,741 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Cake.Scripting.Abstractions"; version = "0.15.0"; hash = "sha256-g/94sPb+uLZWEK83pFq/w924q1iBuJftoJkZ/UlJAVo="; }) - (fetchNuGet { pname = "Cake.Scripting.Transport"; version = "0.15.0"; hash = "sha256-VY1Lw6cy6k8KOP7A2GLm2V+KuVJ43QrbilEzrZqy9Hc="; }) - (fetchNuGet { pname = "Cake.Tool"; version = "3.0.0"; hash = "sha256-Z5hkinAqOaWCfMUIaaDfY0uTN1ot71Q1IC1A+xpmSj4="; }) - (fetchNuGet { pname = "Dotnet.Script.DependencyModel"; version = "1.5.0"; hash = "sha256-5E7SF0msST+bFm2IhMjTEBpHHBb6GetUA8N7sKnIiQM="; }) - (fetchNuGet { pname = "Dotnet.Script.DependencyModel.NuGet"; version = "1.5.0"; hash = "sha256-FBiPUfO0S9IujCLr8ZzwUh/OqqKTKPoh3Z4yHzhnwzs="; }) - (fetchNuGet { pname = "Humanizer.Core"; version = "2.14.1"; hash = "sha256-EXvojddPu+9JKgOG9NSQgUTfWq1RpOYw7adxDPKDJ6o="; }) - (fetchNuGet { pname = "ICSharpCode.Decompiler"; version = "8.2.0.7535"; hash = "sha256-4BWs04Va9pc/SLeMA/vKoBydhw+Bu6s9MDtoo/Ucft8="; }) - (fetchNuGet { pname = "McMaster.Extensions.CommandLineUtils"; version = "4.1.0"; hash = "sha256-lPAL8r1/y6WmWpgKqYHzIa3iEz1+Soqkud4XnbpN/N4="; }) - (fetchNuGet { pname = "MediatR"; version = "8.1.0"; hash = "sha256-dyqhDG1NJjY1b+dj37sMmklGkxAm3zKdhh2lBJ0/HTM="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.App.Ref"; version = "6.0.36"; hash = "sha256-9jDkWbjw/nd8yqdzVTagCuqr6owJ/DUMi4BlUZT4hWU="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "7.0.0"; hash = "sha256-1e031E26iraIqun84ad0fCIR4MJZ1hcQo4yFN+B7UfE="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "8.0.0"; hash = "sha256-9aWmiwMJKrKr9ohD1KSuol37y+jdDxPGJct3m2/Bknw="; }) - (fetchNuGet { pname = "Microsoft.Build"; version = "17.3.2"; hash = "sha256-r+jLFj4SFlkcRofhbt4/8IzA4mYnDlfv2IkiwYCa5J0="; }) - (fetchNuGet { pname = "Microsoft.Build.Framework"; version = "17.3.2"; hash = "sha256-x/Cv21DrCXB5pA0mBNass/hGzMqLEI4MDEswHBKbEd0="; }) - (fetchNuGet { pname = "Microsoft.Build.Locator"; version = "1.6.10"; hash = "sha256-hOFFiQiCNkkDqt0Ad/4Y/sggj4t0zWXmfGjE+I/cqqM="; }) - (fetchNuGet { pname = "Microsoft.Build.Tasks.Core"; version = "17.3.2"; hash = "sha256-VIrJ206gph6J25mnSMV2l8kN5KHkyylAeZRGgnM3tdc="; }) - (fetchNuGet { pname = "Microsoft.Build.Utilities.Core"; version = "17.3.2"; hash = "sha256-RLKc+wdx0CKzWy1kCMMF/lwwZJPIM3vouLJfLGWGAmU="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.3.4"; hash = "sha256-qDzTfZBSCvAUu9gzq2k+LOvh6/eRvJ9++VCNck/ZpnE="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.AnalyzerUtilities"; version = "3.3.0"; hash = "sha256-nzFs+H0FFEgZzjl/bcmWyQQVKS2PncS6kMYHOqrxXSw="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "4.12.0-1.24358.3"; hash = "sha256-UQ0tDpF+OxAgRXIPiJuT7z01Weqn2bLo+kIwkdcMaXs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.common/4.12.0-1.24358.3/microsoft.codeanalysis.common.4.12.0-1.24358.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "4.12.0-1.24358.3"; hash = "sha256-OuB9qEQLc64Ido++o3mAZUZ6IvuB8rTzOf663k/0Kcc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.csharp/4.12.0-1.24358.3/microsoft.codeanalysis.csharp.4.12.0-1.24358.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.Features"; version = "4.12.0-1.24358.3"; hash = "sha256-PNPdyFwwsReDd1QC1KmnGrXVMYNPghIShI7il3UEcrA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.csharp.features/4.12.0-1.24358.3/microsoft.codeanalysis.csharp.features.4.12.0-1.24358.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.Scripting"; version = "4.12.0-1.24358.3"; hash = "sha256-titifcvaYU0rc9ZoEoitT2Wbw/CDRYr7bRm1ecSLDU0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.csharp.scripting/4.12.0-1.24358.3/microsoft.codeanalysis.csharp.scripting.4.12.0-1.24358.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.Workspaces"; version = "4.12.0-1.24358.3"; hash = "sha256-9CROWJt789h964idgJ/qqu+rAQkygcwtE2ngyeL/bhE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.csharp.workspaces/4.12.0-1.24358.3/microsoft.codeanalysis.csharp.workspaces.4.12.0-1.24358.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Elfie"; version = "1.0.0"; hash = "sha256-E/+PlegvWZ59e5Ti3TvKJBLa3qCnDKmi7+DcnOo1ufg="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.ExternalAccess.AspNetCore"; version = "4.12.0-1.24358.3"; hash = "sha256-0kv2XunbYQsbusmRl2WchiskolxwZWThx80ZUzcw3c8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.externalaccess.aspnetcore/4.12.0-1.24358.3/microsoft.codeanalysis.externalaccess.aspnetcore.4.12.0-1.24358.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.ExternalAccess.OmniSharp"; version = "4.12.0-1.24358.3"; hash = "sha256-gLIJA1zaq4RbRCDhALlIwUBasRbekjFiuLCNyQckegA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.externalaccess.omnisharp/4.12.0-1.24358.3/microsoft.codeanalysis.externalaccess.omnisharp.4.12.0-1.24358.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.ExternalAccess.OmniSharp.CSharp"; version = "4.12.0-1.24358.3"; hash = "sha256-aXwLNsh6Gmd98rLZ1fWjpNaCCg7TYv70Qc7dRccNk/U="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.externalaccess.omnisharp.csharp/4.12.0-1.24358.3/microsoft.codeanalysis.externalaccess.omnisharp.csharp.4.12.0-1.24358.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Features"; version = "4.12.0-1.24358.3"; hash = "sha256-TCl/MzgHNUBUU56MVSGeOlCUMSTeS8cG5iZkZ/E9ElY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.features/4.12.0-1.24358.3/microsoft.codeanalysis.features.4.12.0-1.24358.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Scripting.Common"; version = "4.12.0-1.24358.3"; hash = "sha256-qvmZdcshzsXJLdWev3QyQscNeliEqzOGE3q7L/hR67w="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.scripting.common/4.12.0-1.24358.3/microsoft.codeanalysis.scripting.common.4.12.0-1.24358.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Workspaces.Common"; version = "4.12.0-1.24358.3"; hash = "sha256-9SQ1nAfJsDswOfASVSZ2iV7GoXcsRmNhVcr+Dv266zk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.workspaces.common/4.12.0-1.24358.3/microsoft.codeanalysis.workspaces.common.4.12.0-1.24358.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.7.0"; hash = "sha256-Enknv2RsFF68lEPdrf5M+BpV1kHoLTVRApKUwuk/pj0="; }) - (fetchNuGet { pname = "Microsoft.DiaSymReader"; version = "2.0.0"; hash = "sha256-8hotZmh8Rb6Q6oD9Meb74SvAdbDo39Y/1m8h43HHjjw="; }) - (fetchNuGet { pname = "Microsoft.DotNet.PlatformAbstractions"; version = "3.1.6"; hash = "sha256-RfM2qXiqdiamPkXr4IDkNc0IZSF9iTZv4uou/E7zNS0="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Caching.Abstractions"; version = "8.0.0"; hash = "sha256-xGpKrywQvU1Wm/WolYIxgHYEFfgkNGeJ+GGc5DT3phI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Caching.Memory"; version = "8.0.0"; hash = "sha256-RUQe2VgOATM9JkZ/wGm9mreKoCmOS4pPyvyJWBqMaC8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "8.0.0"; hash = "sha256-9BPsASlxrV8ilmMCjdb3TiUcm5vFZxkBnAI/fNBSEyA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "8.0.0"; hash = "sha256-4eBpDkf7MJozTZnOwQvwcfgRKQGcNXe0K/kF+h5Rl8o="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "8.0.0"; hash = "sha256-GanfInGzzoN2bKeNwON8/Hnamr6l7RTpYLA49CNXD9Q="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.CommandLine"; version = "8.0.0"; hash = "sha256-fmPC/o8S+weTtQJWykpnGHm6AKVU21xYE/CaHYU7zgg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; version = "8.0.0"; hash = "sha256-+bjFZvqCsMf2FRM2olqx/fub+QwfM1kBhjGVOT5HC48="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.FileExtensions"; version = "8.0.0"; hash = "sha256-BCxcjVP+kvrDDB0nzsFCJfU74UK4VBvct2JA4r+jNcs="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Json"; version = "8.0.0"; hash = "sha256-Fi/ijcG5l0BOu7i96xHu96aN5/g7zO6SWQbTsI3Qetg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "8.0.0"; hash = "sha256-+qIDR8hRzreCHNEDtUcPfVHQdurzWPo/mqviCH78+EQ="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.0"; hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyModel"; version = "8.0.0"; hash = "sha256-qkCdwemqdZY/yIW5Xmh7Exv74XuE39T8aHGHCofoVgo="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "8.0.0"; hash = "sha256-uQSXmt47X2HGoVniavjLICbPtD2ReQOYQMgy3l0xuMU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Physical"; version = "8.0.0"; hash = "sha256-29y5ZRQ1ZgzVOxHktYxyiH40kVgm5un2yTGdvuSWnRc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileSystemGlobbing"; version = "8.0.0"; hash = "sha256-+Oz41JR5jdcJlCJOSpQIL5OMBNi+1Hl2d0JUHfES7sU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "8.0.0"; hash = "sha256-Meh0Z0X7KyOEG4l0RWBcuHHihcABcvCyfUXgasmQ91o="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "7.0.1"; hash = "sha256-05mravm6SK0wNV3BKDTmN+8/1RxcPOM9kaUvGhjWY3c="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "8.0.0"; hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Configuration"; version = "8.0.0"; hash = "sha256-mzmstNsVjKT0EtQcdAukGRifD30T82BMGYlSu8k4K7U="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Console"; version = "8.0.0"; hash = "sha256-bdb9YWWVn//AeySp7se87/tCN2E7e8Gx2GPMw28cd9c="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "8.0.0"; hash = "sha256-n2m4JSegQKUTlOsKLZUUHHKMq926eJ0w9N9G+I3FoFw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; version = "8.0.0"; hash = "sha256-A5Bbzw1kiNkgirk5x8kyxwg9lLTcSngojeD+ocpG1RI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "8.0.0"; hash = "sha256-FU8qj3DR8bDdc1c+WeGZx/PCZeqqndweZM9epcpXjSo="; }) - (fetchNuGet { pname = "Microsoft.IO.Redist"; version = "6.0.0"; hash = "sha256-pa3MT+QWrWeehQwUWtTS/Rwto8IIDgAt+zLqaUAQoJ0="; }) - (fetchNuGet { pname = "Microsoft.NET.StringTools"; version = "17.3.2"; hash = "sha256-Q8owHXaXkJPy13yGlj+VYGS9XMqYWUZYB6yoT0/m4ek="; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Ref"; version = "6.0.36"; hash = "sha256-9LZgVoIFF8qNyUu8kdJrYGLutMF/cL2K82HN2ywwlx8="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "5.0.0"; hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies"; version = "1.0.3"; hash = "sha256-FBoJP5DHZF0QHM0xLm9yd4HJZVQOuSpSKA+VQRpphEE="; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies.net472"; version = "1.0.3"; hash = "sha256-/6ClVwo5+RE5kWTQWB/93vmbXj37ql8iDlziKWm89Xw="; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.ObjectModel"; version = "17.8.0"; hash = "sha256-9TwGrjVvbtyetw67Udp3EMK5MX8j0RFRjduxPCs9ESw="; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.TranslationLayer"; version = "17.8.0"; hash = "sha256-YZG3jGI9zbYx1GZSptBBfvC/qHp5iC2O+TSvCP10JQ0="; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Threading"; version = "17.6.40"; hash = "sha256-5HtsgSPV5RdaPREGDvJ7qMOFubb1wMyHwkfTnZs9Zsc="; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Threading.Analyzers"; version = "17.6.40"; hash = "sha256-WghLNITEsKTV5pCjogmhfsVD3iO7ghTk0KNrOXzKSS0="; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Validation"; version = "17.6.11"; hash = "sha256-Lkjp9Ove4+CFP06x/toYpJEiAinuTfn/o+oh0fW3pGM="; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "5.0.0"; hash = "sha256-9kylPGfKZc58yFqNKa77stomcoNnMeERXozWJzDcUIA="; }) - (fetchNuGet { pname = "Microsoft.Win32.SystemEvents"; version = "6.0.0"; hash = "sha256-N9EVZbl5w1VnMywGXyaVWzT9lh84iaJ3aD48hIBk1zA="; }) - (fetchNuGet { pname = "Nerdbank.Streams"; version = "2.10.69"; hash = "sha256-a0hXKhR7dv6Vm4rlUOD2ffBKG49CC3wzXLCHeTz1ms4="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.0"; hash = "sha256-Pp7fRylai8JrE1O+9TGfIEJrAOmnWTJRLWE+qJBahK0="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.3"; hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; }) - (fetchNuGet { pname = "NuGet.Common"; version = "6.11.0-rc.110"; hash = "sha256-S0K+RiSHJFzx+qbTJ7KY1Mh/L9hDJfL/F1YjzlhP3ao="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.common/6.11.0-rc.110/nuget.common.6.11.0-rc.110.nupkg"; }) - (fetchNuGet { pname = "NuGet.Configuration"; version = "6.11.0-rc.110"; hash = "sha256-NJzuKWDMUAn8aLt/aB4xht65a9CCnwY0IfnHfFHd/p4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.configuration/6.11.0-rc.110/nuget.configuration.6.11.0-rc.110.nupkg"; }) - (fetchNuGet { pname = "NuGet.DependencyResolver.Core"; version = "6.11.0-rc.110"; hash = "sha256-12oRGUo4L7TslA6iV3OoMayG/t3ToOJ4fdGFh2U8Rxo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.dependencyresolver.core/6.11.0-rc.110/nuget.dependencyresolver.core.6.11.0-rc.110.nupkg"; }) - (fetchNuGet { pname = "NuGet.Frameworks"; version = "6.11.0-rc.110"; hash = "sha256-FmvFhdCJ/xH92tr+7uMNdimcpFxyW7Y/roPcS0TJX3g="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.frameworks/6.11.0-rc.110/nuget.frameworks.6.11.0-rc.110.nupkg"; }) - (fetchNuGet { pname = "NuGet.LibraryModel"; version = "6.11.0-rc.110"; hash = "sha256-PYiEmV44XWUCK7Wahs8ZQ8GHcL4yO+fT+Y1OQHna68E="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.librarymodel/6.11.0-rc.110/nuget.librarymodel.6.11.0-rc.110.nupkg"; }) - (fetchNuGet { pname = "NuGet.Packaging"; version = "6.11.0-rc.110"; hash = "sha256-pnGx4JWJ02X18Qko5TX1DTbbbQj1msdKb0Lrphzyjps="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.packaging/6.11.0-rc.110/nuget.packaging.6.11.0-rc.110.nupkg"; }) - (fetchNuGet { pname = "NuGet.ProjectModel"; version = "6.11.0-rc.110"; hash = "sha256-xE1Us1qn3qAbLS/1rdZMWfl5tEO5pCQGp+P+VUrLBOQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.projectmodel/6.11.0-rc.110/nuget.projectmodel.6.11.0-rc.110.nupkg"; }) - (fetchNuGet { pname = "NuGet.Protocol"; version = "6.11.0-rc.110"; hash = "sha256-XS8HsEDPoEjBNbfdo1c+PHB6BUOs8IpdfXvkmDsSZD4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.protocol/6.11.0-rc.110/nuget.protocol.6.11.0-rc.110.nupkg"; }) - (fetchNuGet { pname = "NuGet.Versioning"; version = "6.11.0-rc.110"; hash = "sha256-eyhOSwBFquzExUis+zGgP5gCO/nVSY5IzXcWeeVz/Ww="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.versioning/6.11.0-rc.110/nuget.versioning.6.11.0-rc.110.nupkg"; }) - (fetchNuGet { pname = "OmniSharp.Extensions.JsonRpc"; version = "0.19.9"; hash = "sha256-n/DjyqXDVxWIPZZ/kdNak7gTFD6638bJtvW3hrEZFWU="; }) - (fetchNuGet { pname = "OmniSharp.Extensions.JsonRpc.Generators"; version = "0.19.9"; hash = "sha256-38+lTizxqeBkWp6ZvMOe2dVsCG1PbQXjXgerXAsK+zw="; }) - (fetchNuGet { pname = "OmniSharp.Extensions.LanguageProtocol"; version = "0.19.9"; hash = "sha256-L1O76h4n+qYDCvnKS3j3rwHDW60S4b7s8Cgg8sBbogw="; }) - (fetchNuGet { pname = "OmniSharp.Extensions.LanguageServer"; version = "0.19.9"; hash = "sha256-cGIRuIqUl3pKfYpeT2mY4RigbZOa2yGf1itbSFydZW0="; }) - (fetchNuGet { pname = "OmniSharp.Extensions.LanguageServer.Shared"; version = "0.19.9"; hash = "sha256-S27e9BjRaaVcbUle+MF0nRxjHS/fIhNqDyr3aBZyiog="; }) - (fetchNuGet { pname = "SQLitePCLRaw.bundle_green"; version = "2.1.8"; hash = "sha256-2heeK2naqrjk/ggcEPO1GhcumiXU8sC4VNFh/Xr+wd4="; }) - (fetchNuGet { pname = "SQLitePCLRaw.core"; version = "2.1.8"; hash = "sha256-j7004Tk/GyQigot9Sx5cgAU9dzhFfOGs02zaj412x8g="; }) - (fetchNuGet { pname = "SQLitePCLRaw.lib.e_sqlite3"; version = "2.1.8"; hash = "sha256-Omio9F3a0w52x3CLpk/MOCmB5yeaFxVV9ZOMU18eKew="; }) - (fetchNuGet { pname = "SQLitePCLRaw.provider.dynamic_cdecl"; version = "2.1.8"; hash = "sha256-eo+peRW0MEkrczXtlMPNPOKew9k/jH0e4jUzOXI8Y44="; }) - (fetchNuGet { pname = "SQLitePCLRaw.provider.e_sqlite3"; version = "2.1.8"; hash = "sha256-eE2gvpsXhtAmYqdxLhrne+/u4V/o7tbicuGUEWL4p4s="; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; hash = "sha256-wws90sfi9M7kuCPWkv1CEYMJtCqx9QB/kj0ymlsNaxI="; }) - (fetchNuGet { pname = "System.CodeDom"; version = "6.0.0"; hash = "sha256-uPetUFZyHfxjScu5x4agjk9pIhbCkt5rG4Axj25npcQ="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "8.0.0"; hash = "sha256-F7OVjKNwpqbUh8lTidbqJWYi476nsq9n+6k0+QVRo3w="; }) - (fetchNuGet { pname = "System.ComponentModel.Annotations"; version = "5.0.0"; hash = "sha256-0pST1UHgpeE6xJrYf5R+U7AwIlH3rVC3SpguilI/MAg="; }) - (fetchNuGet { pname = "System.ComponentModel.Composition"; version = "8.0.0"; hash = "sha256-MnKdjE/qIvAmEeRc3gOn5uJhT0TI3UnUJPjj3TLHFQo="; }) - (fetchNuGet { pname = "System.Composition"; version = "8.0.0"; hash = "sha256-rA118MFj6soKN++BvD3y9gXAJf0lZJAtGARuznG5+Xg="; }) - (fetchNuGet { pname = "System.Composition.AttributedModel"; version = "8.0.0"; hash = "sha256-n3aXiBAFIlQicSRLiNtLh++URSUxRBLggsjJ8OMNRpo="; }) - (fetchNuGet { pname = "System.Composition.Convention"; version = "8.0.0"; hash = "sha256-Z9HOAnH1lt1qc38P3Y0qCf5gwBwiLXQD994okcy53IE="; }) - (fetchNuGet { pname = "System.Composition.Hosting"; version = "8.0.0"; hash = "sha256-axKJC71oKiNWKy66TVF/c3yoC81k03XHAWab3mGNbr0="; }) - (fetchNuGet { pname = "System.Composition.Runtime"; version = "8.0.0"; hash = "sha256-AxwZ29+GY0E35Pa255q8AcMnJU52Txr5pBy86t6V1Go="; }) - (fetchNuGet { pname = "System.Composition.TypedParts"; version = "8.0.0"; hash = "sha256-+ZJawThmiYEUNJ+cB9uJK+u/sCAVZarGd5ShZoSifGo="; }) - (fetchNuGet { pname = "System.Configuration.ConfigurationManager"; version = "8.0.0"; hash = "sha256-xhljqSkNQk8DMkEOBSYnn9lzCSEDDq4yO910itptqiE="; }) - (fetchNuGet { pname = "System.Data.DataSetExtensions"; version = "4.5.0"; hash = "sha256-qppO0L8BpI7cgaStqBhn6YJYFjFdSwpXlRih0XFsaT4="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "8.0.0"; hash = "sha256-+aODaDEQMqla5RYZeq0Lh66j+xkPYxykrVvSCmJQ+Vs="; }) - (fetchNuGet { pname = "System.Diagnostics.EventLog"; version = "8.0.0"; hash = "sha256-rt8xc3kddpQY4HEdghlBeOK4gdw5yIj4mcZhAVtk2/Y="; }) - (fetchNuGet { pname = "System.Drawing.Common"; version = "6.0.0"; hash = "sha256-/9EaAbEeOjELRSMZaImS1O8FmUe8j4WuFUw1VOrPyAo="; }) - (fetchNuGet { pname = "System.Formats.Asn1"; version = "6.0.0"; hash = "sha256-KaMHgIRBF7Nf3VwOo+gJS1DcD+41cJDPWFh+TDQ8ee8="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "7.0.0"; hash = "sha256-W2181khfJUTxLqhuAVRhCa52xZ3+ePGOLIPwEN8WisY="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "8.0.0"; hash = "sha256-LdpB1s4vQzsOODaxiKstLks57X9DTD5D6cPx8DE1wwE="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.5"; hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.4.0"; hash = "sha256-auXQK2flL/JpnB/rEcAcUm4vYMCYMEMiWOCAlIaqu2U="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; }) - (fetchNuGet { pname = "System.Reactive"; version = "6.0.0"; hash = "sha256-hXB18OsiUHSCmRF3unAfdUEcbXVbG6/nZxcyz13oe9Y="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "8.0.0"; hash = "sha256-dQGC30JauIDWNWXMrSNOJncVa1umR1sijazYwUDdSIE="; }) - (fetchNuGet { pname = "System.Reflection.MetadataLoadContext"; version = "6.0.0"; hash = "sha256-82aeU8c4rnYPLL3ba1ho1fxfpYQt5qrSK5e6ES+OTsY="; }) - (fetchNuGet { pname = "System.Resources.Extensions"; version = "6.0.0"; hash = "sha256-/EEdeNvp9FrLeVnmowzHk6nn0KmPf6L9Poc7l/R948A="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.3"; hash = "sha256-lnZMUqRO4RYRUeSO8HSJ9yBHqFHLVbmenwHWkIU20ak="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices.RuntimeInformation"; version = "4.0.0"; hash = "sha256-5j53amb76A3SPiE3B0llT2XPx058+CgE7OXL4bLalT4="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices.RuntimeInformation"; version = "4.3.0"; hash = "sha256-MYpl6/ZyC6hjmzWRIe+iDoldOMW1mfbwXsduAnXIKGA="; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "5.0.0"; hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "6.0.0"; hash = "sha256-qOyWEBbNr3EjyS+etFG8/zMbuPjA+O+di717JP9Cxyg="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Pkcs"; version = "6.0.1"; hash = "sha256-OJ4NJ8E/8l86aR+Hsw+k/7II63Y/zPS+MgC+UfeCXHM="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Pkcs"; version = "6.0.4"; hash = "sha256-2e0aRybote+OR66bHaNiYpF//4fCiaO3zbR2e9GABUI="; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "4.4.0"; hash = "sha256-Ri53QmFX8I8UH0x4PikQ1ZA07ZSnBUXStd5rBfGWFOE="; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "8.0.0"; hash = "sha256-fb0pa9sQxN+mr0vnXg1Igbx49CaOqS+GDkTfWNboUvs="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Xml"; version = "6.0.0"; hash = "sha256-jXst4NyUKOTOmLacSwgQB71W12nKZtveJA25dCtpyys="; }) - (fetchNuGet { pname = "System.Security.Permissions"; version = "6.0.0"; hash = "sha256-/MMvtFWGN/vOQfjXdOhet1gsnMgh6lh5DCHimVsnVEs="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "6.0.0"; hash = "sha256-nGc2A6XYnwqGcq8rfgTRjGr+voISxNe/76k2K36coj4="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "7.0.0"; hash = "sha256-eCKTVwumD051ZEcoJcDVRGnIGAsEvKpfH3ydKluHxmo="; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "8.0.0"; hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; }) - (fetchNuGet { pname = "System.Text.Json"; version = "8.0.4"; hash = "sha256-g5oT7fbXxQ9Iah1nMCr4UUX/a2l+EVjJyTrw3FTbIaI="; }) - (fetchNuGet { pname = "System.Threading.Channels"; version = "6.0.0"; hash = "sha256-klGYnsyrjvXaGeqgfnMf/dTAMNtcHY+zM4Xh6v2JfuE="; }) - (fetchNuGet { pname = "System.Threading.Channels"; version = "7.0.0"; hash = "sha256-Cu0gjQsLIR8Yvh0B4cOPJSYVq10a+3F9pVz/C43CNeM="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Dataflow"; version = "8.0.0"; hash = "sha256-Q6fPtMPNW4+SDKCabJzNS+dw4B04Oxd9sHH505bFtQo="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; }) - (fetchNuGet { pname = "System.ValueTuple"; version = "4.5.0"; hash = "sha256-niH6l2fU52vAzuBlwdQMw0OEoRS/7E1w5smBFoqSaAI="; }) - (fetchNuGet { pname = "System.Windows.Extensions"; version = "6.0.0"; hash = "sha256-N+qg1E6FDJ9A9L50wmVt3xPQV8ZxlG1xeXgFuxO+yfM="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Cake.Scripting.Abstractions"; + version = "0.15.0"; + hash = "sha256-g/94sPb+uLZWEK83pFq/w924q1iBuJftoJkZ/UlJAVo="; + }) + (fetchNuGet { + pname = "Cake.Scripting.Transport"; + version = "0.15.0"; + hash = "sha256-VY1Lw6cy6k8KOP7A2GLm2V+KuVJ43QrbilEzrZqy9Hc="; + }) + (fetchNuGet { + pname = "Cake.Tool"; + version = "3.0.0"; + hash = "sha256-Z5hkinAqOaWCfMUIaaDfY0uTN1ot71Q1IC1A+xpmSj4="; + }) + (fetchNuGet { + pname = "Dotnet.Script.DependencyModel"; + version = "1.5.0"; + hash = "sha256-5E7SF0msST+bFm2IhMjTEBpHHBb6GetUA8N7sKnIiQM="; + }) + (fetchNuGet { + pname = "Dotnet.Script.DependencyModel.NuGet"; + version = "1.5.0"; + hash = "sha256-FBiPUfO0S9IujCLr8ZzwUh/OqqKTKPoh3Z4yHzhnwzs="; + }) + (fetchNuGet { + pname = "Humanizer.Core"; + version = "2.14.1"; + hash = "sha256-EXvojddPu+9JKgOG9NSQgUTfWq1RpOYw7adxDPKDJ6o="; + }) + (fetchNuGet { + pname = "ICSharpCode.Decompiler"; + version = "8.2.0.7535"; + hash = "sha256-4BWs04Va9pc/SLeMA/vKoBydhw+Bu6s9MDtoo/Ucft8="; + }) + (fetchNuGet { + pname = "McMaster.Extensions.CommandLineUtils"; + version = "4.1.0"; + hash = "sha256-lPAL8r1/y6WmWpgKqYHzIa3iEz1+Soqkud4XnbpN/N4="; + }) + (fetchNuGet { + pname = "MediatR"; + version = "8.1.0"; + hash = "sha256-dyqhDG1NJjY1b+dj37sMmklGkxAm3zKdhh2lBJ0/HTM="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.App.Ref"; + version = "6.0.36"; + hash = "sha256-9jDkWbjw/nd8yqdzVTagCuqr6owJ/DUMi4BlUZT4hWU="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "7.0.0"; + hash = "sha256-1e031E26iraIqun84ad0fCIR4MJZ1hcQo4yFN+B7UfE="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "8.0.0"; + hash = "sha256-9aWmiwMJKrKr9ohD1KSuol37y+jdDxPGJct3m2/Bknw="; + }) + (fetchNuGet { + pname = "Microsoft.Build"; + version = "17.3.2"; + hash = "sha256-r+jLFj4SFlkcRofhbt4/8IzA4mYnDlfv2IkiwYCa5J0="; + }) + (fetchNuGet { + pname = "Microsoft.Build.Framework"; + version = "17.3.2"; + hash = "sha256-x/Cv21DrCXB5pA0mBNass/hGzMqLEI4MDEswHBKbEd0="; + }) + (fetchNuGet { + pname = "Microsoft.Build.Locator"; + version = "1.6.10"; + hash = "sha256-hOFFiQiCNkkDqt0Ad/4Y/sggj4t0zWXmfGjE+I/cqqM="; + }) + (fetchNuGet { + pname = "Microsoft.Build.Tasks.Core"; + version = "17.3.2"; + hash = "sha256-VIrJ206gph6J25mnSMV2l8kN5KHkyylAeZRGgnM3tdc="; + }) + (fetchNuGet { + pname = "Microsoft.Build.Utilities.Core"; + version = "17.3.2"; + hash = "sha256-RLKc+wdx0CKzWy1kCMMF/lwwZJPIM3vouLJfLGWGAmU="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.3.4"; + hash = "sha256-qDzTfZBSCvAUu9gzq2k+LOvh6/eRvJ9++VCNck/ZpnE="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.AnalyzerUtilities"; + version = "3.3.0"; + hash = "sha256-nzFs+H0FFEgZzjl/bcmWyQQVKS2PncS6kMYHOqrxXSw="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "4.12.0-1.24358.3"; + hash = "sha256-UQ0tDpF+OxAgRXIPiJuT7z01Weqn2bLo+kIwkdcMaXs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.common/4.12.0-1.24358.3/microsoft.codeanalysis.common.4.12.0-1.24358.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "4.12.0-1.24358.3"; + hash = "sha256-OuB9qEQLc64Ido++o3mAZUZ6IvuB8rTzOf663k/0Kcc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.csharp/4.12.0-1.24358.3/microsoft.codeanalysis.csharp.4.12.0-1.24358.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.Features"; + version = "4.12.0-1.24358.3"; + hash = "sha256-PNPdyFwwsReDd1QC1KmnGrXVMYNPghIShI7il3UEcrA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.csharp.features/4.12.0-1.24358.3/microsoft.codeanalysis.csharp.features.4.12.0-1.24358.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.Scripting"; + version = "4.12.0-1.24358.3"; + hash = "sha256-titifcvaYU0rc9ZoEoitT2Wbw/CDRYr7bRm1ecSLDU0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.csharp.scripting/4.12.0-1.24358.3/microsoft.codeanalysis.csharp.scripting.4.12.0-1.24358.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.Workspaces"; + version = "4.12.0-1.24358.3"; + hash = "sha256-9CROWJt789h964idgJ/qqu+rAQkygcwtE2ngyeL/bhE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.csharp.workspaces/4.12.0-1.24358.3/microsoft.codeanalysis.csharp.workspaces.4.12.0-1.24358.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Elfie"; + version = "1.0.0"; + hash = "sha256-E/+PlegvWZ59e5Ti3TvKJBLa3qCnDKmi7+DcnOo1ufg="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.ExternalAccess.AspNetCore"; + version = "4.12.0-1.24358.3"; + hash = "sha256-0kv2XunbYQsbusmRl2WchiskolxwZWThx80ZUzcw3c8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.externalaccess.aspnetcore/4.12.0-1.24358.3/microsoft.codeanalysis.externalaccess.aspnetcore.4.12.0-1.24358.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.ExternalAccess.OmniSharp"; + version = "4.12.0-1.24358.3"; + hash = "sha256-gLIJA1zaq4RbRCDhALlIwUBasRbekjFiuLCNyQckegA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.externalaccess.omnisharp/4.12.0-1.24358.3/microsoft.codeanalysis.externalaccess.omnisharp.4.12.0-1.24358.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.ExternalAccess.OmniSharp.CSharp"; + version = "4.12.0-1.24358.3"; + hash = "sha256-aXwLNsh6Gmd98rLZ1fWjpNaCCg7TYv70Qc7dRccNk/U="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.externalaccess.omnisharp.csharp/4.12.0-1.24358.3/microsoft.codeanalysis.externalaccess.omnisharp.csharp.4.12.0-1.24358.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Features"; + version = "4.12.0-1.24358.3"; + hash = "sha256-TCl/MzgHNUBUU56MVSGeOlCUMSTeS8cG5iZkZ/E9ElY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.features/4.12.0-1.24358.3/microsoft.codeanalysis.features.4.12.0-1.24358.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Scripting.Common"; + version = "4.12.0-1.24358.3"; + hash = "sha256-qvmZdcshzsXJLdWev3QyQscNeliEqzOGE3q7L/hR67w="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.scripting.common/4.12.0-1.24358.3/microsoft.codeanalysis.scripting.common.4.12.0-1.24358.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Workspaces.Common"; + version = "4.12.0-1.24358.3"; + hash = "sha256-9SQ1nAfJsDswOfASVSZ2iV7GoXcsRmNhVcr+Dv266zk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.codeanalysis.workspaces.common/4.12.0-1.24358.3/microsoft.codeanalysis.workspaces.common.4.12.0-1.24358.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.7.0"; + hash = "sha256-Enknv2RsFF68lEPdrf5M+BpV1kHoLTVRApKUwuk/pj0="; + }) + (fetchNuGet { + pname = "Microsoft.DiaSymReader"; + version = "2.0.0"; + hash = "sha256-8hotZmh8Rb6Q6oD9Meb74SvAdbDo39Y/1m8h43HHjjw="; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.PlatformAbstractions"; + version = "3.1.6"; + hash = "sha256-RfM2qXiqdiamPkXr4IDkNc0IZSF9iTZv4uou/E7zNS0="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Caching.Abstractions"; + version = "8.0.0"; + hash = "sha256-xGpKrywQvU1Wm/WolYIxgHYEFfgkNGeJ+GGc5DT3phI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Caching.Memory"; + version = "8.0.0"; + hash = "sha256-RUQe2VgOATM9JkZ/wGm9mreKoCmOS4pPyvyJWBqMaC8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "8.0.0"; + hash = "sha256-9BPsASlxrV8ilmMCjdb3TiUcm5vFZxkBnAI/fNBSEyA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "8.0.0"; + hash = "sha256-4eBpDkf7MJozTZnOwQvwcfgRKQGcNXe0K/kF+h5Rl8o="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "8.0.0"; + hash = "sha256-GanfInGzzoN2bKeNwON8/Hnamr6l7RTpYLA49CNXD9Q="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.CommandLine"; + version = "8.0.0"; + hash = "sha256-fmPC/o8S+weTtQJWykpnGHm6AKVU21xYE/CaHYU7zgg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; + version = "8.0.0"; + hash = "sha256-+bjFZvqCsMf2FRM2olqx/fub+QwfM1kBhjGVOT5HC48="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.FileExtensions"; + version = "8.0.0"; + hash = "sha256-BCxcjVP+kvrDDB0nzsFCJfU74UK4VBvct2JA4r+jNcs="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Json"; + version = "8.0.0"; + hash = "sha256-Fi/ijcG5l0BOu7i96xHu96aN5/g7zO6SWQbTsI3Qetg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "8.0.0"; + hash = "sha256-+qIDR8hRzreCHNEDtUcPfVHQdurzWPo/mqviCH78+EQ="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.0"; + hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyModel"; + version = "8.0.0"; + hash = "sha256-qkCdwemqdZY/yIW5Xmh7Exv74XuE39T8aHGHCofoVgo="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "8.0.0"; + hash = "sha256-uQSXmt47X2HGoVniavjLICbPtD2ReQOYQMgy3l0xuMU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Physical"; + version = "8.0.0"; + hash = "sha256-29y5ZRQ1ZgzVOxHktYxyiH40kVgm5un2yTGdvuSWnRc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileSystemGlobbing"; + version = "8.0.0"; + hash = "sha256-+Oz41JR5jdcJlCJOSpQIL5OMBNi+1Hl2d0JUHfES7sU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "8.0.0"; + hash = "sha256-Meh0Z0X7KyOEG4l0RWBcuHHihcABcvCyfUXgasmQ91o="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "7.0.1"; + hash = "sha256-05mravm6SK0wNV3BKDTmN+8/1RxcPOM9kaUvGhjWY3c="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "8.0.0"; + hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Configuration"; + version = "8.0.0"; + hash = "sha256-mzmstNsVjKT0EtQcdAukGRifD30T82BMGYlSu8k4K7U="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Console"; + version = "8.0.0"; + hash = "sha256-bdb9YWWVn//AeySp7se87/tCN2E7e8Gx2GPMw28cd9c="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "8.0.0"; + hash = "sha256-n2m4JSegQKUTlOsKLZUUHHKMq926eJ0w9N9G+I3FoFw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; + version = "8.0.0"; + hash = "sha256-A5Bbzw1kiNkgirk5x8kyxwg9lLTcSngojeD+ocpG1RI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "8.0.0"; + hash = "sha256-FU8qj3DR8bDdc1c+WeGZx/PCZeqqndweZM9epcpXjSo="; + }) + (fetchNuGet { + pname = "Microsoft.IO.Redist"; + version = "6.0.0"; + hash = "sha256-pa3MT+QWrWeehQwUWtTS/Rwto8IIDgAt+zLqaUAQoJ0="; + }) + (fetchNuGet { + pname = "Microsoft.NET.StringTools"; + version = "17.3.2"; + hash = "sha256-Q8owHXaXkJPy13yGlj+VYGS9XMqYWUZYB6yoT0/m4ek="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Ref"; + version = "6.0.36"; + hash = "sha256-9LZgVoIFF8qNyUu8kdJrYGLutMF/cL2K82HN2ywwlx8="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "5.0.0"; + hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies"; + version = "1.0.3"; + hash = "sha256-FBoJP5DHZF0QHM0xLm9yd4HJZVQOuSpSKA+VQRpphEE="; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies.net472"; + version = "1.0.3"; + hash = "sha256-/6ClVwo5+RE5kWTQWB/93vmbXj37ql8iDlziKWm89Xw="; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.ObjectModel"; + version = "17.8.0"; + hash = "sha256-9TwGrjVvbtyetw67Udp3EMK5MX8j0RFRjduxPCs9ESw="; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.TranslationLayer"; + version = "17.8.0"; + hash = "sha256-YZG3jGI9zbYx1GZSptBBfvC/qHp5iC2O+TSvCP10JQ0="; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Threading"; + version = "17.6.40"; + hash = "sha256-5HtsgSPV5RdaPREGDvJ7qMOFubb1wMyHwkfTnZs9Zsc="; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Threading.Analyzers"; + version = "17.6.40"; + hash = "sha256-WghLNITEsKTV5pCjogmhfsVD3iO7ghTk0KNrOXzKSS0="; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Validation"; + version = "17.6.11"; + hash = "sha256-Lkjp9Ove4+CFP06x/toYpJEiAinuTfn/o+oh0fW3pGM="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "5.0.0"; + hash = "sha256-9kylPGfKZc58yFqNKa77stomcoNnMeERXozWJzDcUIA="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.SystemEvents"; + version = "6.0.0"; + hash = "sha256-N9EVZbl5w1VnMywGXyaVWzT9lh84iaJ3aD48hIBk1zA="; + }) + (fetchNuGet { + pname = "Nerdbank.Streams"; + version = "2.10.69"; + hash = "sha256-a0hXKhR7dv6Vm4rlUOD2ffBKG49CC3wzXLCHeTz1ms4="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.0"; + hash = "sha256-Pp7fRylai8JrE1O+9TGfIEJrAOmnWTJRLWE+qJBahK0="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.3"; + hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; + }) + (fetchNuGet { + pname = "NuGet.Common"; + version = "6.11.0-rc.110"; + hash = "sha256-S0K+RiSHJFzx+qbTJ7KY1Mh/L9hDJfL/F1YjzlhP3ao="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.common/6.11.0-rc.110/nuget.common.6.11.0-rc.110.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Configuration"; + version = "6.11.0-rc.110"; + hash = "sha256-NJzuKWDMUAn8aLt/aB4xht65a9CCnwY0IfnHfFHd/p4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.configuration/6.11.0-rc.110/nuget.configuration.6.11.0-rc.110.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.DependencyResolver.Core"; + version = "6.11.0-rc.110"; + hash = "sha256-12oRGUo4L7TslA6iV3OoMayG/t3ToOJ4fdGFh2U8Rxo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.dependencyresolver.core/6.11.0-rc.110/nuget.dependencyresolver.core.6.11.0-rc.110.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Frameworks"; + version = "6.11.0-rc.110"; + hash = "sha256-FmvFhdCJ/xH92tr+7uMNdimcpFxyW7Y/roPcS0TJX3g="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.frameworks/6.11.0-rc.110/nuget.frameworks.6.11.0-rc.110.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.LibraryModel"; + version = "6.11.0-rc.110"; + hash = "sha256-PYiEmV44XWUCK7Wahs8ZQ8GHcL4yO+fT+Y1OQHna68E="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.librarymodel/6.11.0-rc.110/nuget.librarymodel.6.11.0-rc.110.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Packaging"; + version = "6.11.0-rc.110"; + hash = "sha256-pnGx4JWJ02X18Qko5TX1DTbbbQj1msdKb0Lrphzyjps="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.packaging/6.11.0-rc.110/nuget.packaging.6.11.0-rc.110.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.ProjectModel"; + version = "6.11.0-rc.110"; + hash = "sha256-xE1Us1qn3qAbLS/1rdZMWfl5tEO5pCQGp+P+VUrLBOQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.projectmodel/6.11.0-rc.110/nuget.projectmodel.6.11.0-rc.110.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Protocol"; + version = "6.11.0-rc.110"; + hash = "sha256-XS8HsEDPoEjBNbfdo1c+PHB6BUOs8IpdfXvkmDsSZD4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.protocol/6.11.0-rc.110/nuget.protocol.6.11.0-rc.110.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Versioning"; + version = "6.11.0-rc.110"; + hash = "sha256-eyhOSwBFquzExUis+zGgP5gCO/nVSY5IzXcWeeVz/Ww="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.versioning/6.11.0-rc.110/nuget.versioning.6.11.0-rc.110.nupkg"; + }) + (fetchNuGet { + pname = "OmniSharp.Extensions.JsonRpc"; + version = "0.19.9"; + hash = "sha256-n/DjyqXDVxWIPZZ/kdNak7gTFD6638bJtvW3hrEZFWU="; + }) + (fetchNuGet { + pname = "OmniSharp.Extensions.JsonRpc.Generators"; + version = "0.19.9"; + hash = "sha256-38+lTizxqeBkWp6ZvMOe2dVsCG1PbQXjXgerXAsK+zw="; + }) + (fetchNuGet { + pname = "OmniSharp.Extensions.LanguageProtocol"; + version = "0.19.9"; + hash = "sha256-L1O76h4n+qYDCvnKS3j3rwHDW60S4b7s8Cgg8sBbogw="; + }) + (fetchNuGet { + pname = "OmniSharp.Extensions.LanguageServer"; + version = "0.19.9"; + hash = "sha256-cGIRuIqUl3pKfYpeT2mY4RigbZOa2yGf1itbSFydZW0="; + }) + (fetchNuGet { + pname = "OmniSharp.Extensions.LanguageServer.Shared"; + version = "0.19.9"; + hash = "sha256-S27e9BjRaaVcbUle+MF0nRxjHS/fIhNqDyr3aBZyiog="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.bundle_green"; + version = "2.1.8"; + hash = "sha256-2heeK2naqrjk/ggcEPO1GhcumiXU8sC4VNFh/Xr+wd4="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.core"; + version = "2.1.8"; + hash = "sha256-j7004Tk/GyQigot9Sx5cgAU9dzhFfOGs02zaj412x8g="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.lib.e_sqlite3"; + version = "2.1.8"; + hash = "sha256-Omio9F3a0w52x3CLpk/MOCmB5yeaFxVV9ZOMU18eKew="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.provider.dynamic_cdecl"; + version = "2.1.8"; + hash = "sha256-eo+peRW0MEkrczXtlMPNPOKew9k/jH0e4jUzOXI8Y44="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.provider.e_sqlite3"; + version = "2.1.8"; + hash = "sha256-eE2gvpsXhtAmYqdxLhrne+/u4V/o7tbicuGUEWL4p4s="; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + hash = "sha256-wws90sfi9M7kuCPWkv1CEYMJtCqx9QB/kj0ymlsNaxI="; + }) + (fetchNuGet { + pname = "System.CodeDom"; + version = "6.0.0"; + hash = "sha256-uPetUFZyHfxjScu5x4agjk9pIhbCkt5rG4Axj25npcQ="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "8.0.0"; + hash = "sha256-F7OVjKNwpqbUh8lTidbqJWYi476nsq9n+6k0+QVRo3w="; + }) + (fetchNuGet { + pname = "System.ComponentModel.Annotations"; + version = "5.0.0"; + hash = "sha256-0pST1UHgpeE6xJrYf5R+U7AwIlH3rVC3SpguilI/MAg="; + }) + (fetchNuGet { + pname = "System.ComponentModel.Composition"; + version = "8.0.0"; + hash = "sha256-MnKdjE/qIvAmEeRc3gOn5uJhT0TI3UnUJPjj3TLHFQo="; + }) + (fetchNuGet { + pname = "System.Composition"; + version = "8.0.0"; + hash = "sha256-rA118MFj6soKN++BvD3y9gXAJf0lZJAtGARuznG5+Xg="; + }) + (fetchNuGet { + pname = "System.Composition.AttributedModel"; + version = "8.0.0"; + hash = "sha256-n3aXiBAFIlQicSRLiNtLh++URSUxRBLggsjJ8OMNRpo="; + }) + (fetchNuGet { + pname = "System.Composition.Convention"; + version = "8.0.0"; + hash = "sha256-Z9HOAnH1lt1qc38P3Y0qCf5gwBwiLXQD994okcy53IE="; + }) + (fetchNuGet { + pname = "System.Composition.Hosting"; + version = "8.0.0"; + hash = "sha256-axKJC71oKiNWKy66TVF/c3yoC81k03XHAWab3mGNbr0="; + }) + (fetchNuGet { + pname = "System.Composition.Runtime"; + version = "8.0.0"; + hash = "sha256-AxwZ29+GY0E35Pa255q8AcMnJU52Txr5pBy86t6V1Go="; + }) + (fetchNuGet { + pname = "System.Composition.TypedParts"; + version = "8.0.0"; + hash = "sha256-+ZJawThmiYEUNJ+cB9uJK+u/sCAVZarGd5ShZoSifGo="; + }) + (fetchNuGet { + pname = "System.Configuration.ConfigurationManager"; + version = "8.0.0"; + hash = "sha256-xhljqSkNQk8DMkEOBSYnn9lzCSEDDq4yO910itptqiE="; + }) + (fetchNuGet { + pname = "System.Data.DataSetExtensions"; + version = "4.5.0"; + hash = "sha256-qppO0L8BpI7cgaStqBhn6YJYFjFdSwpXlRih0XFsaT4="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "8.0.0"; + hash = "sha256-+aODaDEQMqla5RYZeq0Lh66j+xkPYxykrVvSCmJQ+Vs="; + }) + (fetchNuGet { + pname = "System.Diagnostics.EventLog"; + version = "8.0.0"; + hash = "sha256-rt8xc3kddpQY4HEdghlBeOK4gdw5yIj4mcZhAVtk2/Y="; + }) + (fetchNuGet { + pname = "System.Drawing.Common"; + version = "6.0.0"; + hash = "sha256-/9EaAbEeOjELRSMZaImS1O8FmUe8j4WuFUw1VOrPyAo="; + }) + (fetchNuGet { + pname = "System.Formats.Asn1"; + version = "6.0.0"; + hash = "sha256-KaMHgIRBF7Nf3VwOo+gJS1DcD+41cJDPWFh+TDQ8ee8="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "7.0.0"; + hash = "sha256-W2181khfJUTxLqhuAVRhCa52xZ3+ePGOLIPwEN8WisY="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "8.0.0"; + hash = "sha256-LdpB1s4vQzsOODaxiKstLks57X9DTD5D6cPx8DE1wwE="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.5"; + hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.4.0"; + hash = "sha256-auXQK2flL/JpnB/rEcAcUm4vYMCYMEMiWOCAlIaqu2U="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; + }) + (fetchNuGet { + pname = "System.Reactive"; + version = "6.0.0"; + hash = "sha256-hXB18OsiUHSCmRF3unAfdUEcbXVbG6/nZxcyz13oe9Y="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "8.0.0"; + hash = "sha256-dQGC30JauIDWNWXMrSNOJncVa1umR1sijazYwUDdSIE="; + }) + (fetchNuGet { + pname = "System.Reflection.MetadataLoadContext"; + version = "6.0.0"; + hash = "sha256-82aeU8c4rnYPLL3ba1ho1fxfpYQt5qrSK5e6ES+OTsY="; + }) + (fetchNuGet { + pname = "System.Resources.Extensions"; + version = "6.0.0"; + hash = "sha256-/EEdeNvp9FrLeVnmowzHk6nn0KmPf6L9Poc7l/R948A="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.3"; + hash = "sha256-lnZMUqRO4RYRUeSO8HSJ9yBHqFHLVbmenwHWkIU20ak="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices.RuntimeInformation"; + version = "4.0.0"; + hash = "sha256-5j53amb76A3SPiE3B0llT2XPx058+CgE7OXL4bLalT4="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices.RuntimeInformation"; + version = "4.3.0"; + hash = "sha256-MYpl6/ZyC6hjmzWRIe+iDoldOMW1mfbwXsduAnXIKGA="; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "5.0.0"; + hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "6.0.0"; + hash = "sha256-qOyWEBbNr3EjyS+etFG8/zMbuPjA+O+di717JP9Cxyg="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Pkcs"; + version = "6.0.1"; + hash = "sha256-OJ4NJ8E/8l86aR+Hsw+k/7II63Y/zPS+MgC+UfeCXHM="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Pkcs"; + version = "6.0.4"; + hash = "sha256-2e0aRybote+OR66bHaNiYpF//4fCiaO3zbR2e9GABUI="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "4.4.0"; + hash = "sha256-Ri53QmFX8I8UH0x4PikQ1ZA07ZSnBUXStd5rBfGWFOE="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "8.0.0"; + hash = "sha256-fb0pa9sQxN+mr0vnXg1Igbx49CaOqS+GDkTfWNboUvs="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Xml"; + version = "6.0.0"; + hash = "sha256-jXst4NyUKOTOmLacSwgQB71W12nKZtveJA25dCtpyys="; + }) + (fetchNuGet { + pname = "System.Security.Permissions"; + version = "6.0.0"; + hash = "sha256-/MMvtFWGN/vOQfjXdOhet1gsnMgh6lh5DCHimVsnVEs="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "6.0.0"; + hash = "sha256-nGc2A6XYnwqGcq8rfgTRjGr+voISxNe/76k2K36coj4="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "7.0.0"; + hash = "sha256-eCKTVwumD051ZEcoJcDVRGnIGAsEvKpfH3ydKluHxmo="; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "8.0.0"; + hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "8.0.4"; + hash = "sha256-g5oT7fbXxQ9Iah1nMCr4UUX/a2l+EVjJyTrw3FTbIaI="; + }) + (fetchNuGet { + pname = "System.Threading.Channels"; + version = "6.0.0"; + hash = "sha256-klGYnsyrjvXaGeqgfnMf/dTAMNtcHY+zM4Xh6v2JfuE="; + }) + (fetchNuGet { + pname = "System.Threading.Channels"; + version = "7.0.0"; + hash = "sha256-Cu0gjQsLIR8Yvh0B4cOPJSYVq10a+3F9pVz/C43CNeM="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Dataflow"; + version = "8.0.0"; + hash = "sha256-Q6fPtMPNW4+SDKCabJzNS+dw4B04Oxd9sHH505bFtQo="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; + }) + (fetchNuGet { + pname = "System.ValueTuple"; + version = "4.5.0"; + hash = "sha256-niH6l2fU52vAzuBlwdQMw0OEoRS/7E1w5smBFoqSaAI="; + }) + (fetchNuGet { + pname = "System.Windows.Extensions"; + version = "6.0.0"; + hash = "sha256-N+qg1E6FDJ9A9L50wmVt3xPQV8ZxlG1xeXgFuxO+yfM="; + }) ] diff --git a/pkgs/by-name/om/omorfi/package.nix b/pkgs/by-name/om/omorfi/package.nix index 9360b0fdd104b5..824751a368d8b9 100644 --- a/pkgs/by-name/om/omorfi/package.nix +++ b/pkgs/by-name/om/omorfi/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, autoreconfHook -, cg3 -, fetchFromGitHub -, fetchpatch -, hfst -, hfst-ospell -, icu -, libvoikko -, makeWrapper -, pkg-config -, python3 -, zip +{ + lib, + stdenv, + autoreconfHook, + cg3, + fetchFromGitHub, + fetchpatch, + hfst, + hfst-ospell, + icu, + libvoikko, + makeWrapper, + pkg-config, + python3, + zip, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/om/omping/package.nix b/pkgs/by-name/om/omping/package.nix index 1efcd98b46f86b..4e39e8294d83c5 100644 --- a/pkgs/by-name/om/omping/package.nix +++ b/pkgs/by-name/om/omping/package.nix @@ -1,22 +1,27 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "omping"; version = "0.0.5"; src = fetchFromGitHub { - owner = "troglobit"; - repo = "omping"; - rev = version; + owner = "troglobit"; + repo = "omping"; + rev = version; sha256 = "1f0vsbnhxp7bbgdnfqshryx3nhz2sqdnxdj068s0nmzsh53ckbf7"; }; patches = [ # This can go in 0.0.6+ (fetchpatch { - url = "https://github.com/troglobit/omping/commit/08a31ec1a6eb4e8f88c301ef679c3b6f9893f333.patch"; + url = "https://github.com/troglobit/omping/commit/08a31ec1a6eb4e8f88c301ef679c3b6f9893f333.patch"; sha256 = "1xafyvd46bq53w2zvjw8bdw7vjqbrcrr21cyh6d0zfcn4gif1k0f"; - name = "fix_manpage_install.patch"; + name = "fix_manpage_install.patch"; }) ]; diff --git a/pkgs/by-name/om/omxplayer/package.nix b/pkgs/by-name/om/omxplayer/package.nix index c9c77c1bbcb95c..9e6b000819d168 100644 --- a/pkgs/by-name/om/omxplayer/package.nix +++ b/pkgs/by-name/om/omxplayer/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchurl -, raspberrypifw -, pcre -, boost -, freetype -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + raspberrypifw, + pcre, + boost, + freetype, + zlib, }: let @@ -20,45 +21,49 @@ let }; configurePlatforms = [ ]; - configureFlags = [ - "--arch=${stdenv.hostPlatform.parsed.cpu.name}" - ] ++ lib.optionals stdenv.hostPlatform.isAarch32 [ - # TODO be better with condition - "--cpu=arm1176jzf-s" - ] ++ [ - "--disable-muxers" - "--enable-muxer=spdif" - "--enable-muxer=adts" - "--disable-encoders" - "--enable-encoder=ac3" - "--enable-encoder=aac" - "--disable-decoder=mpeg_xvmc" - "--disable-devices" - "--disable-ffprobe" - "--disable-ffplay" - "--disable-ffserver" - "--disable-ffmpeg" - "--enable-shared" - "--disable-doc" - "--enable-postproc" - "--enable-gpl" - "--enable-protocol=http" - "--enable-pthreads" - "--disable-runtime-cpudetect" - "--enable-pic" - "--disable-armv5te" - "--disable-neon" - "--enable-armv6t2" - "--enable-armv6" - "--enable-hardcoded-tables" - "--disable-runtime-cpudetect" - "--disable-debug" - "--arch=${stdenv.hostPlatform.parsed.cpu.name}" - "--target_os=${stdenv.hostPlatform.parsed.kernel.name}" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "--cross-prefix=${stdenv.cc.targetPrefix}" - "--enable-cross-compile" - ]; + configureFlags = + [ + "--arch=${stdenv.hostPlatform.parsed.cpu.name}" + ] + ++ lib.optionals stdenv.hostPlatform.isAarch32 [ + # TODO be better with condition + "--cpu=arm1176jzf-s" + ] + ++ [ + "--disable-muxers" + "--enable-muxer=spdif" + "--enable-muxer=adts" + "--disable-encoders" + "--enable-encoder=ac3" + "--enable-encoder=aac" + "--disable-decoder=mpeg_xvmc" + "--disable-devices" + "--disable-ffprobe" + "--disable-ffplay" + "--disable-ffserver" + "--disable-ffmpeg" + "--enable-shared" + "--disable-doc" + "--enable-postproc" + "--enable-gpl" + "--enable-protocol=http" + "--enable-pthreads" + "--disable-runtime-cpudetect" + "--enable-pic" + "--disable-armv5te" + "--disable-neon" + "--enable-armv6t2" + "--enable-armv6" + "--enable-hardcoded-tables" + "--disable-runtime-cpudetect" + "--disable-debug" + "--arch=${stdenv.hostPlatform.parsed.cpu.name}" + "--target_os=${stdenv.hostPlatform.parsed.kernel.name}" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "--cross-prefix=${stdenv.cc.targetPrefix}" + "--enable-cross-compile" + ]; enableParallelBuilding = true; @@ -89,7 +94,14 @@ stdenv.mkDerivation rec { cp omxplayer.bin $out/bin ''; - buildInputs = [ raspberrypifw ffmpeg pcre boost freetype zlib ]; + buildInputs = [ + raspberrypifw + ffmpeg + pcre + boost + freetype + zlib + ]; meta = with lib; { homepage = "https://github.com/huceke/omxplayer"; diff --git a/pkgs/by-name/on/onagre/package.nix b/pkgs/by-name/on/onagre/package.nix index 5afed734171346..45861049059dbc 100644 --- a/pkgs/by-name/on/onagre/package.nix +++ b/pkgs/by-name/on/onagre/package.nix @@ -1,17 +1,18 @@ -{ lib -, fetchFromGitHub -, makeWrapper -, rustPlatform -, cmake -, pkgconf -, freetype -, expat -, wayland -, xorg -, libxkbcommon -, pop-launcher -, vulkan-loader -, libGL +{ + lib, + fetchFromGitHub, + makeWrapper, + rustPlatform, + cmake, + pkgconf, + freetype, + expat, + wayland, + xorg, + libxkbcommon, + pop-launcher, + vulkan-loader, + libGL, }: rustPlatform.buildRustPackage rec { @@ -27,7 +28,11 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-17Hw3jtisOXwARpp0jB0hrNax7nzMWS0kCE3ZAruBj8="; - nativeBuildInputs = [ makeWrapper cmake pkgconf ]; + nativeBuildInputs = [ + makeWrapper + cmake + pkgconf + ]; buildInputs = [ expat freetype @@ -37,21 +42,33 @@ rustPlatform.buildRustPackage rec { xorg.libXrandr ]; - postFixup = let - rpath = lib.makeLibraryPath [ libGL vulkan-loader wayland libxkbcommon ]; - in '' - patchelf --set-rpath ${rpath} $out/bin/onagre - wrapProgram $out/bin/onagre \ - --prefix PATH ':' ${lib.makeBinPath [ - pop-launcher - ]} - ''; + postFixup = + let + rpath = lib.makeLibraryPath [ + libGL + vulkan-loader + wayland + libxkbcommon + ]; + in + '' + patchelf --set-rpath ${rpath} $out/bin/onagre + wrapProgram $out/bin/onagre \ + --prefix PATH ':' ${ + lib.makeBinPath [ + pop-launcher + ] + } + ''; meta = with lib; { description = "General purpose application launcher for X and wayland inspired by rofi/wofi and alfred"; homepage = "https://github.com/onagre-launcher/onagre"; license = licenses.mit; - maintainers = [ maintainers.jfvillablanca maintainers.ilya-epifanov ]; + maintainers = [ + maintainers.jfvillablanca + maintainers.ilya-epifanov + ]; platforms = platforms.linux; mainProgram = "onagre"; }; diff --git a/pkgs/by-name/on/onboard/package.nix b/pkgs/by-name/on/onboard/package.nix index 0ebe02881003bf..1db2da7e1d48fa 100644 --- a/pkgs/by-name/on/onboard/package.nix +++ b/pkgs/by-name/on/onboard/package.nix @@ -1,32 +1,33 @@ -{ fetchurl -, fetchpatch -, lib -, substituteAll -, aspellWithDicts -, at-spi2-core ? null -, atspiSupport ? true -, bash -, glib -, dconf -, gobject-introspection -, gsettings-desktop-schemas -, gtk3 -, hunspell -, hunspellDicts -, hunspellWithDicts -, intltool -, isocodes -, libappindicator-gtk3 -, libcanberra-gtk3 -, mousetweaks -, udev -, libxkbcommon -, pkg-config -, procps -, python3 -, wrapGAppsHook3 -, xorg -, yelp +{ + fetchurl, + fetchpatch, + lib, + substituteAll, + aspellWithDicts, + at-spi2-core ? null, + atspiSupport ? true, + bash, + glib, + dconf, + gobject-introspection, + gsettings-desktop-schemas, + gtk3, + hunspell, + hunspellDicts, + hunspellWithDicts, + intltool, + isocodes, + libappindicator-gtk3, + libcanberra-gtk3, + mousetweaks, + udev, + libxkbcommon, + pkg-config, + procps, + python3, + wrapGAppsHook3, + xorg, + yelp, }: let diff --git a/pkgs/by-name/on/ondir/package.nix b/pkgs/by-name/on/ondir/package.nix index 0bcffd5ade7120..163ebcb13e6785 100644 --- a/pkgs/by-name/on/ondir/package.nix +++ b/pkgs/by-name/on/ondir/package.nix @@ -16,26 +16,26 @@ stdenv.mkDerivation { }; installPhase = '' - runHook preInstall + runHook preInstall - make DESTDIR="$out" PREFIX= install - cp scripts.* $out + make DESTDIR="$out" PREFIX= install + cp scripts.* $out - runHook postInstall + runHook postInstall ''; meta = with lib; { description = "Small program to automate tasks specific to certain directories"; longDescription = '' - It works by executing scripts in directories when you enter and leave them. - This is done by overriding the shell builtins cd, pushd, and popd, - which is a manual action. - The user is required to add a snippet to their shell initialisation file like .bashrc or .profile. + It works by executing scripts in directories when you enter and leave them. + This is done by overriding the shell builtins cd, pushd, and popd, + which is a manual action. + The user is required to add a snippet to their shell initialisation file like .bashrc or .profile. - Which commands are executed on directory entry and leave is done - in predefined locations with a .ondirrc file. + Which commands are executed on directory entry and leave is done + in predefined locations with a .ondirrc file. - See man ondir for more information + See man ondir for more information ''; homepage = "https://github.com/alecthomas/ondir/"; license = licenses.gpl2Only; diff --git a/pkgs/by-name/on/one-click-backup/package.nix b/pkgs/by-name/on/one-click-backup/package.nix index c12693559670cb..26ae411f0fed83 100644 --- a/pkgs/by-name/on/one-click-backup/package.nix +++ b/pkgs/by-name/on/one-click-backup/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitLab -, cmake -, ninja -, qt6 -, extra-cmake-modules +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + ninja, + qt6, + extra-cmake-modules, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/on/onedriver/package.nix b/pkgs/by-name/on/onedriver/package.nix index 20e8474c27edc2..76c5ae58f0c39f 100644 --- a/pkgs/by-name/on/onedriver/package.nix +++ b/pkgs/by-name/on/onedriver/package.nix @@ -1,14 +1,15 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, pkg-config -, webkitgtk_4_1 -, glib -, fuse -, installShellFiles -, wrapGAppsHook3 -, glib-networking -, wrapperDir ? "/run/wrappers/bin" +{ + buildGoModule, + fetchFromGitHub, + lib, + pkg-config, + webkitgtk_4_1, + glib, + fuse, + installShellFiles, + wrapGAppsHook3, + glib-networking, + wrapperDir ? "/run/wrappers/bin", }: let pname = "onedriver"; @@ -25,8 +26,17 @@ buildGoModule { inherit pname version src; vendorHash = "sha256-OOiiKtKb+BiFkoSBUQQfqm4dMfDW3Is+30Kwcdg8LNA="; - nativeBuildInputs = [ pkg-config installShellFiles wrapGAppsHook3 ]; - buildInputs = [ webkitgtk_4_1 glib fuse glib-networking ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + wrapGAppsHook3 + ]; + buildInputs = [ + webkitgtk_4_1 + glib + fuse + glib-networking + ]; ldflags = [ "-X github.com/jstaf/onedriver/cmd/common.commit=v${version}" ]; diff --git a/pkgs/by-name/on/oneko/package.nix b/pkgs/by-name/on/oneko/package.nix index a67bedd42912c8..74eb7231fc8dee 100644 --- a/pkgs/by-name/on/oneko/package.nix +++ b/pkgs/by-name/on/oneko/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, imake -, gccmakedep -, libX11 -, libXext +{ + lib, + stdenv, + fetchFromGitHub, + imake, + gccmakedep, + libX11, + libXext, }: stdenv.mkDerivation rec { @@ -17,23 +18,38 @@ stdenv.mkDerivation rec { rev = version_name; sha256 = "0vx12v5fm8ar3f1g6jbpmd3b1q652d32nc67ahkf28djbqjgcbnc"; }; - nativeBuildInputs = [ imake gccmakedep ]; - buildInputs = [ libX11 libXext ]; + nativeBuildInputs = [ + imake + gccmakedep + ]; + buildInputs = [ + libX11 + libXext + ]; - makeFlags = [ "BINDIR=$(out)/bin" "MANPATH=$(out)/share/man" ]; - installTargets = [ "install" "install.man" ]; + makeFlags = [ + "BINDIR=$(out)/bin" + "MANPATH=$(out)/share/man" + ]; + installTargets = [ + "install" + "install.man" + ]; meta = with lib; { description = "Creates a cute cat chasing around your mouse cursor"; longDescription = '' - Oneko changes your mouse cursor into a mouse - and creates a little cute cat, which starts - chasing around your mouse cursor. - When the cat is done catching the mouse, it starts sleeping. + Oneko changes your mouse cursor into a mouse + and creates a little cute cat, which starts + chasing around your mouse cursor. + When the cat is done catching the mouse, it starts sleeping. ''; homepage = "https://github.com/IreneKnapp/oneko"; license = with licenses; [ publicDomain ]; - maintainers = with maintainers; [ xaverdh irenes ]; + maintainers = with maintainers; [ + xaverdh + irenes + ]; platforms = platforms.unix; mainProgram = "oneko"; }; diff --git a/pkgs/by-name/on/oneshot/package.nix b/pkgs/by-name/on/oneshot/package.nix index 34c9b0d7f7be10..f7b57d070b7217 100644 --- a/pkgs/by-name/on/oneshot/package.nix +++ b/pkgs/by-name/on/oneshot/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildGoModule, testers, oneshot }: +{ + lib, + fetchFromGitHub, + buildGoModule, + testers, + oneshot, +}: buildGoModule rec { pname = "oneshot"; diff --git a/pkgs/by-name/on/onesixtyone/package.nix b/pkgs/by-name/on/onesixtyone/package.nix index 1ff1b0266eaf08..b1392e7b00f7fb 100644 --- a/pkgs/by-name/on/onesixtyone/package.nix +++ b/pkgs/by-name/on/onesixtyone/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "onesixtyone"; @@ -28,4 +32,3 @@ stdenv.mkDerivation rec { mainProgram = "onesixtyone"; }; } - diff --git a/pkgs/by-name/on/onestepback/package.nix b/pkgs/by-name/on/onestepback/package.nix index ed0d0235fc06b7..37c9a05684aaec 100644 --- a/pkgs/by-name/on/onestepback/package.nix +++ b/pkgs/by-name/on/onestepback/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "onestepback"; diff --git a/pkgs/by-name/on/oniguruma/package.nix b/pkgs/by-name/on/oniguruma/package.nix index cf00629e384235..33c79220dd2d0c 100644 --- a/pkgs/by-name/on/oniguruma/package.nix +++ b/pkgs/by-name/on/oniguruma/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "oniguruma"; @@ -10,7 +15,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-YBYr07n8b0iG1MegeSX/03QWdzL1Xc6MSRv9nNgYps8="; }; - outputs = [ "dev" "lib" "out" ]; + outputs = [ + "dev" + "lib" + "out" + ]; outputBin = "dev"; # onig-config nativeBuildInputs = [ autoreconfHook ]; diff --git a/pkgs/by-name/on/onioncircuits/package.nix b/pkgs/by-name/on/onioncircuits/package.nix index e15509925bcb9b..39bc5c47ed4c5d 100644 --- a/pkgs/by-name/on/onioncircuits/package.nix +++ b/pkgs/by-name/on/onioncircuits/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitLab -, gobject-introspection -, intltool -, python3 -, wrapGAppsHook3 +{ + stdenv, + lib, + fetchFromGitLab, + gobject-introspection, + intltool, + python3, + wrapGAppsHook3, }: python3.pkgs.buildPythonApplication rec { @@ -45,4 +46,3 @@ python3.pkgs.buildPythonApplication rec { maintainers = with maintainers; [ wattmto ]; }; } - diff --git a/pkgs/by-name/on/onlykey-agent/package.nix b/pkgs/by-name/on/onlykey-agent/package.nix index d78c1b89b4f6ca..1894f333e21d27 100644 --- a/pkgs/by-name/on/onlykey-agent/package.nix +++ b/pkgs/by-name/on/onlykey-agent/package.nix @@ -1,48 +1,53 @@ -{ lib -, python3Packages -, fetchPypi -, onlykey-cli +{ + lib, + python3Packages, + fetchPypi, + onlykey-cli, }: let - bech32 = with python3Packages; buildPythonPackage rec { - pname = "bech32"; - version = "1.2.0"; + bech32 = + with python3Packages; + buildPythonPackage rec { + pname = "bech32"; + version = "1.2.0"; - src = fetchPypi { - inherit pname version; - sha256 = "sha256-fW24IUYDvXhx/PpsCCbvaLhbCr2Q+iHChanF4h0r2Jk="; + src = fetchPypi { + inherit pname version; + sha256 = "sha256-fW24IUYDvXhx/PpsCCbvaLhbCr2Q+iHChanF4h0r2Jk="; + }; }; - }; # onlykey requires a patched version of libagent - lib-agent = with python3Packages; libagent.overridePythonAttrs (oa: rec{ - version = "1.0.6"; - src = fetchPypi { - inherit version; - pname = "lib-agent"; - sha256 = "sha256-IrJizIHDIPHo4tVduUat7u31zHo3Nt8gcMOyUUqkNu0="; - }; - propagatedBuildInputs = oa.propagatedBuildInputs or [ ] ++ [ - bech32 - cryptography - cython - docutils - pycryptodome - pynacl - wheel - ]; + lib-agent = + with python3Packages; + libagent.overridePythonAttrs (oa: rec { + version = "1.0.6"; + src = fetchPypi { + inherit version; + pname = "lib-agent"; + sha256 = "sha256-IrJizIHDIPHo4tVduUat7u31zHo3Nt8gcMOyUUqkNu0="; + }; + propagatedBuildInputs = oa.propagatedBuildInputs or [ ] ++ [ + bech32 + cryptography + cython + docutils + pycryptodome + pynacl + wheel + ]; - # turn off testing because I can't get it to work - doCheck = false; - pythonImportsCheck = [ "libagent" ]; + # turn off testing because I can't get it to work + doCheck = false; + pythonImportsCheck = [ "libagent" ]; - meta = oa.meta // { - description = "Using OnlyKey as hardware SSH and GPG agent"; - homepage = "https://github.com/trustcrypto/onlykey-agent/tree/ledger"; - maintainers = with lib.maintainers; [ kalbasit ]; - }; - }); + meta = oa.meta // { + description = "Using OnlyKey as hardware SSH and GPG agent"; + homepage = "https://github.com/trustcrypto/onlykey-agent/tree/ledger"; + maintainers = with lib.maintainers; [ kalbasit ]; + }; + }); in python3Packages.buildPythonApplication rec { pname = "onlykey-agent"; @@ -53,7 +58,11 @@ python3Packages.buildPythonApplication rec { hash = "sha256-SbGb7CjcD7cFPvASZtip56B4uxRiFKZBvbsf6sb8fds="; }; - propagatedBuildInputs = with python3Packages; [ lib-agent onlykey-cli setuptools ]; + propagatedBuildInputs = with python3Packages; [ + lib-agent + onlykey-cli + setuptools + ]; # move the python library into the sitePackages. postInstall = '' diff --git a/pkgs/by-name/on/onlykey-cli/package.nix b/pkgs/by-name/on/onlykey-cli/package.nix index be95675dd66e68..df499ea1a69c30 100644 --- a/pkgs/by-name/on/onlykey-cli/package.nix +++ b/pkgs/by-name/on/onlykey-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "onlykey-cli"; diff --git a/pkgs/by-name/on/onlyoffice-documentserver/package.nix b/pkgs/by-name/on/onlyoffice-documentserver/package.nix index e494344d72cd52..76fb0d7f50304d 100644 --- a/pkgs/by-name/on/onlyoffice-documentserver/package.nix +++ b/pkgs/by-name/on/onlyoffice-documentserver/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, buildFHSEnv -, corefonts -, dejavu_fonts -, dpkg -, fetchurl -, gcc-unwrapped -, liberation_ttf_v1 -, writeScript -, xorg +{ + lib, + stdenv, + buildFHSEnv, + corefonts, + dejavu_fonts, + dpkg, + fetchurl, + gcc-unwrapped, + liberation_ttf_v1, + writeScript, + xorg, }: let @@ -17,16 +18,19 @@ let pname = "onlyoffice-documentserver"; version = "8.1.3"; - src = fetchurl ({ - "aarch64-linux" = { - url = "https://github.com/ONLYOFFICE/DocumentServer/releases/download/v${version}/onlyoffice-documentserver_arm64.deb"; - sha256 = "sha256-+7hHz1UcnlJNhBAVaYQwK0m2tkgsfbjqY3oa8XU0yxo="; - }; - "x86_64-linux" = { - url = "https://github.com/ONLYOFFICE/DocumentServer/releases/download/v${version}/onlyoffice-documentserver_amd64.deb"; - sha256 = "sha256-jCwcXb97Z9/ZofKLYneJxKAnaZE/Hwvm34GLQu/BoUM="; - }; - }.${stdenv.hostPlatform.system} or (throw "unsupported system ${stdenv.hostPlatform.system}")); + src = fetchurl ( + { + "aarch64-linux" = { + url = "https://github.com/ONLYOFFICE/DocumentServer/releases/download/v${version}/onlyoffice-documentserver_arm64.deb"; + sha256 = "sha256-+7hHz1UcnlJNhBAVaYQwK0m2tkgsfbjqY3oa8XU0yxo="; + }; + "x86_64-linux" = { + url = "https://github.com/ONLYOFFICE/DocumentServer/releases/download/v${version}/onlyoffice-documentserver_amd64.deb"; + sha256 = "sha256-jCwcXb97Z9/ZofKLYneJxKAnaZE/Hwvm34GLQu/BoUM="; + }; + } + .${stdenv.hostPlatform.system} or (throw "unsupported system ${stdenv.hostPlatform.system}") + ); preferLocalBuild = true; @@ -150,7 +154,10 @@ let ''; homepage = "https://github.com/ONLYOFFICE/DocumentServer"; license = licenses.agpl3Plus; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; sourceProvenance = [ sourceTypes.binaryNativeCode ]; maintainers = with maintainers; [ SuperSandro2000 ]; }; diff --git a/pkgs/by-name/on/onmetal-image/package.nix b/pkgs/by-name/on/onmetal-image/package.nix index 3780bc398b07d9..1ab6200b53701d 100644 --- a/pkgs/by-name/on/onmetal-image/package.nix +++ b/pkgs/by-name/on/onmetal-image/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/on/onscripter-en/package.nix b/pkgs/by-name/on/onscripter-en/package.nix index 87d350dbd8f147..267c48f33a39d5 100644 --- a/pkgs/by-name/on/onscripter-en/package.nix +++ b/pkgs/by-name/on/onscripter-en/package.nix @@ -15,7 +15,6 @@ stdenv, }: - stdenv.mkDerivation (finalAttrs: { pname = "onscripter-en"; version = "20110930"; diff --git a/pkgs/by-name/oo/oobicpl/package.nix b/pkgs/by-name/oo/oobicpl/package.nix index 7f1112311d6b5a..c8d5a85b860e06 100644 --- a/pkgs/by-name/oo/oobicpl/package.nix +++ b/pkgs/by-name/oo/oobicpl/package.nix @@ -1,26 +1,33 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libminc -, bicpl -, arguments -, pcre-cpp }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libminc, + bicpl, + arguments, + pcre-cpp, +}: stdenv.mkDerivation rec { pname = "oobicpl"; version = "unstable-2020-08-12"; src = fetchFromGitHub { - owner = "BIC-MNI"; - repo = pname; - rev = "a9409da8a5bb4925438f32aff577b6333faec28b"; + owner = "BIC-MNI"; + repo = pname; + rev = "a9409da8a5bb4925438f32aff577b6333faec28b"; sha256 = "0b4chjhr32wbb1sash8cq1jfnr7rzdq84hif8anlrjqd3l0gw357"; }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libminc bicpl arguments pcre-cpp ]; + buildInputs = [ + libminc + bicpl + arguments + pcre-cpp + ]; cmakeFlags = [ "-DLIBMINC_DIR=${libminc}/lib/cmake" @@ -34,6 +41,6 @@ stdenv.mkDerivation rec { description = "Brain Imaging Centre object-oriented programming library (and tools)"; maintainers = with maintainers; [ bcdarwin ]; platforms = platforms.unix; - license = licenses.free; + license = licenses.free; }; } diff --git a/pkgs/by-name/oo/ookla-speedtest/package.nix b/pkgs/by-name/oo/ookla-speedtest/package.nix index e36d5f7f177742..95492effde5576 100644 --- a/pkgs/by-name/oo/ookla-speedtest/package.nix +++ b/pkgs/by-name/oo/ookla-speedtest/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: let stdenv = stdenvNoCC; @@ -34,7 +38,8 @@ in stdenv.mkDerivation rec { inherit pname version; - src = srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); sourceRoot = "."; diff --git a/pkgs/by-name/oo/ooklaserver/package.nix b/pkgs/by-name/oo/ooklaserver/package.nix index 0f265470b6fdff..00cf271868b15a 100644 --- a/pkgs/by-name/oo/ooklaserver/package.nix +++ b/pkgs/by-name/oo/ooklaserver/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, unzip +{ + lib, + stdenv, + fetchurl, + unzip, }: let filenameMapping = { diff --git a/pkgs/by-name/oo/oonf-olsrd2/package.nix b/pkgs/by-name/oo/oonf-olsrd2/package.nix index 8cdee7c465e1f9..8f64185dd51b8b 100644 --- a/pkgs/by-name/oo/oonf-olsrd2/package.nix +++ b/pkgs/by-name/oo/oonf-olsrd2/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/oo/ooniprobe-cli/package.nix b/pkgs/by-name/oo/ooniprobe-cli/package.nix index d1ed1447c1a809..9c14e54425d81e 100644 --- a/pkgs/by-name/oo/ooniprobe-cli/package.nix +++ b/pkgs/by-name/oo/ooniprobe-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -18,7 +19,10 @@ buildGoModule rec { subPackages = [ "cmd/ooniprobe" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { changelog = "https://github.com/ooni/probe-cli/releases/tag/${src.rev}"; diff --git a/pkgs/by-name/op/opae/package.nix b/pkgs/by-name/op/opae/package.nix index 339edf234f5377..ccbd9bcb009cb2 100644 --- a/pkgs/by-name/op/opae/package.nix +++ b/pkgs/by-name/op/opae/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, libuuid, json_c -, doxygen, perl, python3 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libuuid, + json_c, + doxygen, + perl, + python3, }: stdenv.mkDerivation rec { @@ -9,12 +16,12 @@ stdenv.mkDerivation rec { # the tag has a silly name for some reason. drop this in the future if # possible - tver = "${version}-5"; + tver = "${version}-5"; src = fetchFromGitHub { - owner = "opae"; - repo = "opae-sdk"; - rev = "refs/tags/${tver}"; + owner = "opae"; + repo = "opae-sdk"; + rev = "refs/tags/${tver}"; sha256 = "1dmkpnr9dqxwjhbdzx2r3fdfylvinda421yyg319am5gzlysxwi8"; }; @@ -26,8 +33,17 @@ stdenv.mkDerivation rec { "-Wno-array-bounds" ]; - nativeBuildInputs = [ cmake doxygen perl python3.pkgs.sphinx ]; - buildInputs = [ libuuid json_c python3 ]; + nativeBuildInputs = [ + cmake + doxygen + perl + python3.pkgs.sphinx + ]; + buildInputs = [ + libuuid + json_c + python3 + ]; # Set the Epoch to 1980; otherwise the Python wheel/zip code # gets very angry @@ -41,9 +57,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Open Programmable Acceleration Engine SDK"; - homepage = "https://01.org/opae"; - license = licenses.bsd3; - platforms = [ "x86_64-linux" ]; + homepage = "https://01.org/opae"; + license = licenses.bsd3; + platforms = [ "x86_64-linux" ]; maintainers = with maintainers; [ thoughtpolice ]; # Needs a major update, not compatible with gcc-11. broken = true; diff --git a/pkgs/by-name/op/opaline/package.nix b/pkgs/by-name/op/opaline/package.nix index e8fbae0f241b8a..f65c5cd3634dda 100644 --- a/pkgs/by-name/op/opaline/package.nix +++ b/pkgs/by-name/op/opaline/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ocamlPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + ocamlPackages, +}: stdenv.mkDerivation rec { version = "0.3.3"; @@ -11,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-6htaiFIcRMUYWn0U7zTNfCyDaTgDEvPch2q57qzvND4="; }; - nativeBuildInputs = with ocamlPackages; [ ocaml findlib ocamlbuild ]; + nativeBuildInputs = with ocamlPackages; [ + ocaml + findlib + ocamlbuild + ]; buildInputs = with ocamlPackages; [ opam-file-format ]; preInstall = "mkdir -p $out/bin"; diff --git a/pkgs/by-name/op/opam2json/package.nix b/pkgs/by-name/op/opam2json/package.nix index 844e6f816134b0..68a35dd36aa73f 100644 --- a/pkgs/by-name/op/opam2json/package.nix +++ b/pkgs/by-name/op/opam2json/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, opam-installer, ocamlPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + opam-installer, + ocamlPackages, +}: stdenv.mkDerivation rec { pname = "opam2json"; version = "0.4"; @@ -10,8 +16,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-5pXfbUfpVABtKbii6aaI2EdAZTjHJ2QntEf0QD2O5AM="; }; - buildInputs = with ocamlPackages; [ yojson opam-file-format cmdliner ]; - nativeBuildInputs = with ocamlPackages; [ ocaml findlib opam-installer ]; + buildInputs = with ocamlPackages; [ + yojson + opam-file-format + cmdliner + ]; + nativeBuildInputs = with ocamlPackages; [ + ocaml + findlib + opam-installer + ]; preInstall = ''export PREFIX="$out"''; diff --git a/pkgs/by-name/op/opcr-policy/package.nix b/pkgs/by-name/op/opcr-policy/package.nix index 8eb77449342a71..3fa49604bfeb99 100644 --- a/pkgs/by-name/op/opcr-policy/package.nix +++ b/pkgs/by-name/op/opcr-policy/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -15,7 +16,11 @@ buildGoModule rec { }; vendorHash = "sha256-ASR8Y/L8ub0w36fO+UpJ5ZpijP+YCLVbRtnhzvMNj9U="; - ldflags = [ "-s" "-w" "-X github.com/opcr-io/policy/pkg/version.ver=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/opcr-io/policy/pkg/version.ver=${version}" + ]; subPackages = [ "cmd/policy" ]; # disable go workspaces @@ -43,6 +48,9 @@ buildGoModule rec { It uses OCI standards to manage artifacts, and the Open Policy Agent (OPA) to compile and run. ''; license = licenses.asl20; - maintainers = with maintainers; [ naphta jk ]; + maintainers = with maintainers; [ + naphta + jk + ]; }; } diff --git a/pkgs/by-name/op/opcua-commander/package.nix b/pkgs/by-name/op/opcua-commander/package.nix index be6a5569a99423..31f00279f87561 100644 --- a/pkgs/by-name/op/opcua-commander/package.nix +++ b/pkgs/by-name/op/opcua-commander/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, typescript -, esbuild -, makeWrapper -, nodejs +{ + lib, + buildNpmPackage, + fetchFromGitHub, + typescript, + esbuild, + makeWrapper, + nodejs, }: buildNpmPackage rec { pname = "opcua-commander"; @@ -18,7 +19,11 @@ buildNpmPackage rec { }; npmDepsHash = "sha256-g4WFLh+UnziQR2NZ4eL84Vrk+Mz99kFQiBkdGmBEMHE="; - nativeBuildInputs = [ esbuild typescript makeWrapper ]; + nativeBuildInputs = [ + esbuild + typescript + makeWrapper + ]; postPatch = '' substituteInPlace package.json \ @@ -31,7 +36,7 @@ buildNpmPackage rec { # ./opcua-commander -e opc.tcp://opcuademo.sterfive.com:26543 postFixup = '' wrapProgram $out/bin/opcua-commander \ - --prefix PATH : "${lib.makeBinPath [nodejs]}" + --prefix PATH : "${lib.makeBinPath [ nodejs ]}" ''; meta = with lib; { diff --git a/pkgs/by-name/op/open-dyslexic/package.nix b/pkgs/by-name/op/open-dyslexic/package.nix index bcfc9fda2b2d86..9df85f40a82409 100644 --- a/pkgs/by-name/op/open-dyslexic/package.nix +++ b/pkgs/by-name/op/open-dyslexic/package.nix @@ -1,6 +1,12 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: -let version = "0.91.12"; in +let + version = "0.91.12"; +in stdenvNoCC.mkDerivation { pname = "open-dyslexic"; inherit version; diff --git a/pkgs/by-name/op/open-ecard/package.nix b/pkgs/by-name/op/open-ecard/package.nix index a3f3f72bc6313a..1a4cd79aa5daef 100644 --- a/pkgs/by-name/op/open-ecard/package.nix +++ b/pkgs/by-name/op/open-ecard/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, jre, pcsclite, makeDesktopItem, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + pcsclite, + makeDesktopItem, + makeWrapper, +}: let version = "1.2.4"; @@ -16,7 +24,8 @@ let sha256 = "0rpmyv10vjx2yfpm03mqliygcww8af2wnrnrppmsazdplksaxkhs"; }; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "open-ecard"; inherit version; @@ -33,7 +42,10 @@ in stdenv.mkDerivation rec { comment = "Client side implementation of the eCard-API-Framework"; icon = "oec_logo_bg-transparent.svg"; exec = pname; - categories = [ "Utility" "Security" ]; + categories = [ + "Utility" + "Security" + ]; }; installPhase = '' diff --git a/pkgs/by-name/op/open-english-wordnet/package.nix b/pkgs/by-name/op/open-english-wordnet/package.nix index ccd661753c0599..47522d7b7829c2 100644 --- a/pkgs/by-name/op/open-english-wordnet/package.nix +++ b/pkgs/by-name/op/open-english-wordnet/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, gzip -, python3 -, stdenvNoCC +{ + lib, + fetchFromGitHub, + fetchpatch, + gzip, + python3, + stdenvNoCC, }: stdenvNoCC.mkDerivation (self: { @@ -17,15 +18,21 @@ stdenvNoCC.mkDerivation (self: { hash = "sha256-a1fWIp39uuJZL1aFX/r+ttLB1+kwh/XPHwphgENTQ5M="; }; - patches = lib.mapAttrsToList (rev: hash: fetchpatch { - url = "https://github.com/globalwordnet/english-wordnet/commit/${rev}.patch"; - inherit hash; - }) { - # Upstream commit bumping the version number, accidentally ommited from the tagged release - "bc07902f8995b62c70f01a282b23f40f30630540" = "sha256-1e4MG/k86g3OFUhiShCCbNXnvDKrYFr1KlGVsGl++KI="; - # PR #982, “merge.py: Make result independent of filesystem order” - "6da46a48dd76a48ad9ff563e6c807b8271fc83cd" = "sha256-QkkJH7NVGy/IbeSWkotU80IGF4esz0b8mIL9soHdQtQ="; - }; + patches = + lib.mapAttrsToList + ( + rev: hash: + fetchpatch { + url = "https://github.com/globalwordnet/english-wordnet/commit/${rev}.patch"; + inherit hash; + } + ) + { + # Upstream commit bumping the version number, accidentally ommited from the tagged release + "bc07902f8995b62c70f01a282b23f40f30630540" = "sha256-1e4MG/k86g3OFUhiShCCbNXnvDKrYFr1KlGVsGl++KI="; + # PR #982, “merge.py: Make result independent of filesystem order” + "6da46a48dd76a48ad9ff563e6c807b8271fc83cd" = "sha256-QkkJH7NVGy/IbeSWkotU80IGF4esz0b8mIL9soHdQtQ="; + }; # TODO(nicoo): make compression optional? nativeBuildInputs = [ diff --git a/pkgs/by-name/op/open-fonts/package.nix b/pkgs/by-name/op/open-fonts/package.nix index a6f2db7542dc6a..a0ff9f38ede879 100644 --- a/pkgs/by-name/op/open-fonts/package.nix +++ b/pkgs/by-name/op/open-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "open-fonts"; diff --git a/pkgs/by-name/op/open-fprintd/package.nix b/pkgs/by-name/op/open-fprintd/package.nix index 06f46d217dfb97..1bdb2f2cade42c 100644 --- a/pkgs/by-name/op/open-fprintd/package.nix +++ b/pkgs/by-name/op/open-fprintd/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, python3Packages, gobject-introspection, wrapGAppsNoGuiHook }: +{ + lib, + fetchFromGitHub, + python3Packages, + gobject-introspection, + wrapGAppsNoGuiHook, +}: python3Packages.buildPythonPackage rec { pname = "open-fprintd"; @@ -11,9 +17,15 @@ python3Packages.buildPythonPackage rec { hash = "sha256-uVFuwtsmR/9epoqot3lJ/5v5OuJjuRjL7FJF7oXNDzU="; }; - nativeBuildInputs = [ wrapGAppsNoGuiHook gobject-introspection ]; + nativeBuildInputs = [ + wrapGAppsNoGuiHook + gobject-introspection + ]; - propagatedBuildInputs = with python3Packages; [ dbus-python pygobject3 ]; + propagatedBuildInputs = with python3Packages; [ + dbus-python + pygobject3 + ]; checkInputs = with python3Packages; [ dbus-python ]; @@ -40,8 +52,7 @@ python3Packages.buildPythonPackage rec { ''; meta = with lib; { - description = - "Fprintd replacement which allows you to have your own backend as a standalone service"; + description = "Fprintd replacement which allows you to have your own backend as a standalone service"; homepage = "https://github.com/uunicorn/open-fprintd"; license = licenses.gpl2Only; platforms = platforms.linux; diff --git a/pkgs/by-name/op/open-in-mpv/package.nix b/pkgs/by-name/op/open-in-mpv/package.nix index 265aa72d729611..c2447d7c0bda3b 100644 --- a/pkgs/by-name/op/open-in-mpv/package.nix +++ b/pkgs/by-name/op/open-in-mpv/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-G6GZO2+CfEAYcf7zBcqDa808A0eJjM8dq7+4VGZ+P4c="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' install -Dm444 -t $out/share/applications scripts/open-in-mpv.desktop diff --git a/pkgs/by-name/op/open-pdf-sign/package.nix b/pkgs/by-name/op/open-pdf-sign/package.nix index 1b87ca87728e3a..3cbd501e7b15d8 100644 --- a/pkgs/by-name/op/open-pdf-sign/package.nix +++ b/pkgs/by-name/op/open-pdf-sign/package.nix @@ -1,9 +1,10 @@ -{ fetchurl -, jre -, lib -, makeBinaryWrapper -, nix-update-script -, stdenv +{ + fetchurl, + jre, + lib, + makeBinaryWrapper, + nix-update-script, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/op/open-policy-agent/package.nix b/pkgs/by-name/op/open-policy-agent/package.nix index 86f509a8eae307..50d92479055724 100644 --- a/pkgs/by-name/op/open-policy-agent/package.nix +++ b/pkgs/by-name/op/open-policy-agent/package.nix @@ -1,13 +1,16 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles - -, enableWasmEval ? false +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, + + enableWasmEval ? false, }: -assert enableWasmEval && stdenv.hostPlatform.isDarwin -> builtins.throw "building with wasm on darwin is failing in nixpkgs"; +assert + enableWasmEval && stdenv.hostPlatform.isDarwin + -> builtins.throw "building with wasm on darwin is failing in nixpkgs"; buildGoModule rec { pname = "open-policy-agent"; @@ -26,31 +29,38 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" "-X github.com/open-policy-agent/opa/version.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/open-policy-agent/opa/version.Version=${version}" + ]; tags = lib.optional enableWasmEval ( - builtins.trace - ("Warning: enableWasmEval breaks reproducability, " - + "ensure you need wasm evaluation. " - + "`opa build` does not need this feature.") - "opa_wasm"); + builtins.trace ( + "Warning: enableWasmEval breaks reproducability, " + + "ensure you need wasm evaluation. " + + "`opa build` does not need this feature." + ) "opa_wasm" + ); checkFlags = lib.optionals (!enableWasmEval) [ "-skip=TestRegoTargetWasmAndTargetPluginDisablesIndexingTopdownStages" ]; - preCheck = '' - # Feed in all but the e2e tests for testing - # This is because subPackages above limits what is built to just what we - # want but also limits the tests - # Also avoid wasm tests on darwin due to wasmtime-go build issues - getGoDirs() { - go list ./... | grep -v -e e2e ${lib.optionalString stdenv.hostPlatform.isDarwin "-e wasm"} - } - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # remove tests that have "too many open files"/"no space left on device" issues on darwin in hydra - rm server/server_test.go - ''; + preCheck = + '' + # Feed in all but the e2e tests for testing + # This is because subPackages above limits what is built to just what we + # want but also limits the tests + # Also avoid wasm tests on darwin due to wasmtime-go build issues + getGoDirs() { + go list ./... | grep -v -e e2e ${lib.optionalString stdenv.hostPlatform.isDarwin "-e wasm"} + } + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # remove tests that have "too many open files"/"no space left on device" issues on darwin in hydra + rm server/server_test.go + ''; postInstall = '' installShellCompletion --cmd opa \ @@ -86,6 +96,9 @@ buildGoModule rec { in microservices, Kubernetes, CI/CD pipelines, API gateways, and more. ''; license = licenses.asl20; - maintainers = with maintainers; [ lewo jk ]; + maintainers = with maintainers; [ + lewo + jk + ]; }; } diff --git a/pkgs/by-name/op/open-sans/package.nix b/pkgs/by-name/op/open-sans/package.nix index 4883cd818b1c15..9cec3689e55fd1 100644 --- a/pkgs/by-name/op/open-sans/package.nix +++ b/pkgs/by-name/op/open-sans/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitLab }: +{ + lib, + stdenvNoCC, + fetchFromGitLab, +}: stdenvNoCC.mkDerivation { pname = "open-sans"; diff --git a/pkgs/by-name/op/open-scq30/package.nix b/pkgs/by-name/op/open-scq30/package.nix index 1028cfb68250b6..9973336ca7ab25 100644 --- a/pkgs/by-name/op/open-scq30/package.nix +++ b/pkgs/by-name/op/open-scq30/package.nix @@ -1,19 +1,20 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, protobuf -, wrapGAppsHook4 -, cairo -, dbus -, gdk-pixbuf -, glib -, gtk4 -, libadwaita -, pango -, stdenv -, darwin -, cargo-make +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + protobuf, + wrapGAppsHook4, + cairo, + dbus, + gdk-pixbuf, + glib, + gtk4, + libadwaita, + pango, + stdenv, + darwin, + cargo-make, }: rustPlatform.buildRustPackage rec { @@ -34,20 +35,22 @@ rustPlatform.buildRustPackage rec { cargo-make ]; - buildInputs = [ - cairo - dbus - gdk-pixbuf - glib - gtk4 - libadwaita - pango - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AppKit - darwin.apple_sdk.frameworks.CoreBluetooth - darwin.apple_sdk.frameworks.CoreGraphics - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + cairo + dbus + gdk-pixbuf + glib + gtk4 + libadwaita + pango + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AppKit + darwin.apple_sdk.frameworks.CoreBluetooth + darwin.apple_sdk.frameworks.CoreGraphics + darwin.apple_sdk.frameworks.Foundation + ]; cargoHash = "sha256-YBJd43xOCumQbrvzfV/+F63McYzHg1bGI3icgGzGZrQ="; diff --git a/pkgs/by-name/op/open-stage-control/package.nix b/pkgs/by-name/op/open-stage-control/package.nix index 504351a1a41fc6..7df60380a38fd2 100644 --- a/pkgs/by-name/op/open-stage-control/package.nix +++ b/pkgs/by-name/op/open-stage-control/package.nix @@ -1,13 +1,14 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, makeBinaryWrapper -, makeDesktopItem -, copyDesktopItems -, nodejs_18 -, electron -, python3 -, nix-update-script +{ + lib, + buildNpmPackage, + fetchFromGitHub, + makeBinaryWrapper, + makeDesktopItem, + copyDesktopItems, + nodejs_18, + electron, + python3, + nix-update-script, }: buildNpmPackage rec { @@ -77,7 +78,12 @@ buildNpmPackage rec { icon = "open-stage-control"; desktopName = "Open Stage Control"; comment = meta.description; - categories = [ "Network" "Audio" "AudioVideo" "Midi" ]; + categories = [ + "Network" + "Audio" + "AudioVideo" + "Midi" + ]; startupWMClass = "open-stage-control"; }) ]; diff --git a/pkgs/by-name/op/open-wbo/package.nix b/pkgs/by-name/op/open-wbo/package.nix index 798643acc1bba7..0776d66a8ae2dc 100644 --- a/pkgs/by-name/op/open-wbo/package.nix +++ b/pkgs/by-name/op/open-wbo/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, zlib, gmp }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + gmp, +}: stdenv.mkDerivation { pname = "open-wbo"; @@ -11,7 +17,10 @@ stdenv.mkDerivation { sha256 = "1742i15qfsbf49c4r837wz35c1p7yafvz7ar6vmgcj6cmfwr8jb4"; }; - buildInputs = [ zlib gmp ]; + buildInputs = [ + zlib + gmp + ]; makeFlags = [ "r" ]; installPhase = '' diff --git a/pkgs/by-name/op/openapi-changes/package.nix b/pkgs/by-name/op/openapi-changes/package.nix index 97d58a58bbc742..05bec35664f1e4 100644 --- a/pkgs/by-name/op/openapi-changes/package.nix +++ b/pkgs/by-name/op/openapi-changes/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGo123Module -, fetchFromGitHub -, git -, makeWrapper +{ + lib, + buildGo123Module, + fetchFromGitHub, + git, + makeWrapper, }: buildGo123Module rec { diff --git a/pkgs/by-name/op/openapi-tui/package.nix b/pkgs/by-name/op/openapi-tui/package.nix index 6673dd6e9ca14f..ec88d90d8a4797 100644 --- a/pkgs/by-name/op/openapi-tui/package.nix +++ b/pkgs/by-name/op/openapi-tui/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/op/openarena/package.nix b/pkgs/by-name/op/openarena/package.nix index 211dbcd2510677..985c2b5c50aa0b 100644 --- a/pkgs/by-name/op/openarena/package.nix +++ b/pkgs/by-name/op/openarena/package.nix @@ -1,24 +1,25 @@ -{ lib -, fetchzip -, fetchFromGitHub -, stdenv -, fetchpatch -, copyDesktopItems -, curl -, makeBinaryWrapper -, pkg-config -, which -, freetype -, libglvnd -, libjpeg -, libogg -, libvorbis -, libxmp -, openal -, SDL2 -, speex -, makeDesktopItem -, nixosTests +{ + lib, + fetchzip, + fetchFromGitHub, + stdenv, + fetchpatch, + copyDesktopItems, + curl, + makeBinaryWrapper, + pkg-config, + which, + freetype, + libglvnd, + libjpeg, + libogg, + libvorbis, + libxmp, + openal, + SDL2, + speex, + makeDesktopItem, + nixosTests, }: let @@ -99,7 +100,10 @@ stdenv.mkDerivation (finalAttrs: { icon = "openarena"; comment = "A fast-paced 3D first-person shooter, similar to id Software Inc.'s Quake III Arena"; desktopName = "OpenArena"; - categories = [ "Game" "ActionGame" ]; + categories = [ + "Game" + "ActionGame" + ]; }) ]; @@ -110,7 +114,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "http://openarena.ws/"; license = lib.licenses.gpl2Plus; mainProgram = "openarena"; - maintainers = with lib.maintainers; [ drupol wyvie ]; + maintainers = with lib.maintainers; [ + drupol + wyvie + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/by-name/op/openbgpd/package.nix b/pkgs/by-name/op/openbgpd/package.nix index f9ccdcf26d15cb..a6decdcf8ff6f8 100644 --- a/pkgs/by-name/op/openbgpd/package.nix +++ b/pkgs/by-name/op/openbgpd/package.nix @@ -1,8 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libtool, m4, bison }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + m4, + bison, +}: let - openbsd_version = - "OPENBSD_6_8"; # This has to be equal to ${src}/OPENBSD_BRANCH + openbsd_version = "OPENBSD_6_8"; # This has to be equal to ${src}/OPENBSD_BRANCH openbsd = fetchFromGitHub { name = "portable"; owner = "openbgpd-portable"; @@ -10,7 +18,8 @@ let rev = openbsd_version; sha256 = "sha256-vCVK5k4g6aW2z2fg7Kv0uvkX7f34aRc8K2myb3jjl6w="; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "opengpd"; version = "6.8p0"; @@ -21,7 +30,13 @@ in stdenv.mkDerivation rec { sha256 = "sha256-TKs6tt/SCWes6kYAGIrSShZgOLf7xKh26xG3Zk7wCCw="; }; - nativeBuildInputs = [ autoconf automake libtool m4 bison ]; + nativeBuildInputs = [ + autoconf + automake + libtool + m4 + bison + ]; preConfigure = '' mkdir ./openbsd @@ -42,8 +57,7 @@ in stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = "-fcommon"; meta = with lib; { - description = - "A free implementation of the Border Gateway Protocol, Version 4. It allows ordinary machines to be used as routers exchanging routes with other systems speaking the BGP protocol"; + description = "A free implementation of the Border Gateway Protocol, Version 4. It allows ordinary machines to be used as routers exchanging routes with other systems speaking the BGP protocol"; license = licenses.isc; homepage = "http://www.openbgpd.org/"; maintainers = with maintainers; [ kloenk ]; diff --git a/pkgs/by-name/op/openboardview/package.nix b/pkgs/by-name/op/openboardview/package.nix index a3a906c25c2b4a..c68764ee1f6afd 100644 --- a/pkgs/by-name/op/openboardview/package.nix +++ b/pkgs/by-name/op/openboardview/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, gitUpdater -, cmake -, pkg-config -, python3 -, SDL2 -, fontconfig -, gtk3 -, wrapGAppsHook3 -, darwin +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + gitUpdater, + cmake, + pkg-config, + python3, + SDL2, + fontconfig, + gtk3, + wrapGAppsHook3, + darwin, }: let @@ -37,10 +38,21 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config python3 wrapGAppsHook3 ]; - buildInputs = [ SDL2 fontconfig gtk3 ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Cocoa + nativeBuildInputs = [ + cmake + pkg-config + python3 + wrapGAppsHook3 ]; + buildInputs = + [ + SDL2 + fontconfig + gtk3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + ]; postPatch = '' substituteInPlace src/openboardview/CMakeLists.txt \ @@ -53,13 +65,15 @@ stdenv.mkDerivation rec { ]; dontWrapGApps = true; - postFixup = lib.optionalString stdenv.hostPlatform.isDarwin '' + postFixup = + lib.optionalString stdenv.hostPlatform.isDarwin '' mkdir -p "$out/Applications" mv "$out/openboardview.app" "$out/Applications/OpenBoardView.app" - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' wrapGApp "$out/bin/${pname}" \ --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ gtk3 ]} - ''; + ''; passthru.updateScript = gitUpdater { ignoredVersions = ''.*\.90\..*''; diff --git a/pkgs/by-name/op/openbox/package.nix b/pkgs/by-name/op/openbox/package.nix index c5f6886c65903a..17587abb9bc51d 100644 --- a/pkgs/by-name/op/openbox/package.nix +++ b/pkgs/by-name/op/openbox/package.nix @@ -1,6 +1,23 @@ -{ lib, stdenv, fetchurl, fetchpatch, autoreconfHook, pkg-config, python3 -, libxml2, libXinerama, libXcursor, libXau, libXrandr, libICE, libSM -, imlib2, pango, libstartup_notification, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + pkg-config, + python3, + libxml2, + libXinerama, + libXcursor, + libXau, + libXrandr, + libICE, + libSM, + imlib2, + pango, + libstartup_notification, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "openbox"; @@ -15,13 +32,19 @@ stdenv.mkDerivation rec { buildInputs = [ libxml2 - libXinerama libXcursor libXau libXrandr libICE libSM + libXinerama + libXcursor + libXau + libXrandr + libICE + libSM libstartup_notification python3 ]; propagatedBuildInputs = [ - pango imlib2 + pango + imlib2 ]; pythonPath = with python3.pkgs; [ diff --git a/pkgs/by-name/op/openbsm/package.nix b/pkgs/by-name/op/openbsm/package.nix index 32d7bf07438431..7fb9dd48fa20af 100644 --- a/pkgs/by-name/op/openbsm/package.nix +++ b/pkgs/by-name/op/openbsm/package.nix @@ -1,4 +1,8 @@ -{ stdenv, fetchFromGitHub, lib }: +{ + stdenv, + fetchFromGitHub, + lib, +}: stdenv.mkDerivation rec { pname = "openbsm"; @@ -7,7 +11,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = pname; repo = pname; - rev = lib.toUpper (builtins.replaceStrings ["." "-"] ["_" "_"] "${pname}-${version}"); + rev = lib.toUpper (builtins.replaceStrings [ "." "-" ] [ "_" "_" ] "${pname}-${version}"); sha256 = "0b98359hd8mm585sh145ss828pg2y8vgz38lqrb7nypapiyqdnd1"; }; diff --git a/pkgs/by-name/op/opencbm/package.nix b/pkgs/by-name/op/opencbm/package.nix index 434b3d421de22b..88fc9aa8a15b81 100644 --- a/pkgs/by-name/op/opencbm/package.nix +++ b/pkgs/by-name/op/opencbm/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cc65 -, ncurses -, pkg-config -, libusb1 +{ + lib, + stdenv, + fetchFromGitHub, + cc65, + ncurses, + pkg-config, + libusb1, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/op/opencl-clang/package.nix b/pkgs/by-name/op/opencl-clang/package.nix index ecd22f70b772c3..3a195fc68aa639 100644 --- a/pkgs/by-name/op/opencl-clang/package.nix +++ b/pkgs/by-name/op/opencl-clang/package.nix @@ -1,22 +1,27 @@ -{ lib -, stdenv -, applyPatches -, fetchFromGitHub -, cmake -, git -, llvmPackages_14 -, spirv-llvm-translator -, buildWithPatches ? true +{ + lib, + stdenv, + applyPatches, + fetchFromGitHub, + cmake, + git, + llvmPackages_14, + spirv-llvm-translator, + buildWithPatches ? true, }: let - addPatches = component: pkg: pkg.overrideAttrs (oldAttrs: { - postPatch = oldAttrs.postPatch or "" + '' - for p in ${passthru.patchesOut}/${component}/*; do - patch -p1 -i "$p" - done - ''; - }); + addPatches = + component: pkg: + pkg.overrideAttrs (oldAttrs: { + postPatch = + oldAttrs.postPatch or "" + + '' + for p in ${passthru.patchesOut}/${component}/*; do + patch -p1 -i "$p" + done + ''; + }); llvmPkgs = llvmPackages_14; inherit (llvmPkgs) llvm; @@ -69,16 +74,18 @@ let ./opencl-headers-dir.patch ]; - postPatch = '' - # fix not be able to find clang from PATH - substituteInPlace cl_headers/CMakeLists.txt \ - --replace " NO_DEFAULT_PATH" "" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Uses linker flags that are not supported on Darwin. - sed -i -e '/SET_LINUX_EXPORTS_FILE/d' CMakeLists.txt - substituteInPlace CMakeLists.txt \ - --replace '-Wl,--no-undefined' "" - ''; + postPatch = + '' + # fix not be able to find clang from PATH + substituteInPlace cl_headers/CMakeLists.txt \ + --replace " NO_DEFAULT_PATH" "" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Uses linker flags that are not supported on Darwin. + sed -i -e '/SET_LINUX_EXPORTS_FILE/d' CMakeLists.txt + substituteInPlace CMakeLists.txt \ + --replace '-Wl,--no-undefined' "" + ''; }; in @@ -86,9 +93,17 @@ stdenv.mkDerivation { pname = "opencl-clang"; inherit version src; - nativeBuildInputs = [ cmake git llvm.dev ]; + nativeBuildInputs = [ + cmake + git + llvm.dev + ]; - buildInputs = [ libclang llvm spirv-llvm-translator' ]; + buildInputs = [ + libclang + llvm + spirv-llvm-translator' + ]; cmakeFlags = [ "-DPREFERRED_LLVM_VERSION=${lib.getVersion llvm}" diff --git a/pkgs/by-name/op/openclonk/package.nix b/pkgs/by-name/op/openclonk/package.nix index bbc1c3be11c7ff..ba22ae6b9e77d4 100644 --- a/pkgs/by-name/op/openclonk/package.nix +++ b/pkgs/by-name/op/openclonk/package.nix @@ -1,8 +1,27 @@ -{ lib, stdenv, fetchurl, fetchFromGitHub, fetchDebianPatch, cmake, pkg-config -, SDL2, libvorbis, libogg, libjpeg, libpng, freetype, glew, tinyxml, openal, libepoxy -, curl -, freealut, readline, libb2, gcc-unwrapped -, enableSoundtrack ? false # Enable the "Open Clonk Soundtrack - Explorers Journey" by David Oerther +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + fetchDebianPatch, + cmake, + pkg-config, + SDL2, + libvorbis, + libogg, + libjpeg, + libpng, + freetype, + glew, + tinyxml, + openal, + libepoxy, + curl, + freealut, + readline, + libb2, + gcc-unwrapped, + enableSoundtrack ? false, # Enable the "Open Clonk Soundtrack - Explorers Journey" by David Oerther }: let @@ -10,7 +29,8 @@ let url = "http://www.openclonk.org/download/Music.ocg"; sha256 = "1ckj0dlpp5zsnkbb5qxxfxpkiq76jj2fgj91fyf3ll7n0gbwcgw5"; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { version = "unstable-2023-10-30"; pname = "openclonk"; @@ -33,20 +53,38 @@ in stdenv.mkDerivation rec { enableParallelInstalling = false; - postInstall = '' - '' + lib.optionalString enableSoundtrack '' - ln -sv ${soundtrack_src} $out/share/games/openclonk/Music.ocg - ''; + postInstall = + '''' + + lib.optionalString enableSoundtrack '' + ln -sv ${soundtrack_src} $out/share/games/openclonk/Music.ocg + ''; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ - SDL2 libvorbis libogg libjpeg libpng freetype glew tinyxml openal freealut - libepoxy curl - readline libb2 + SDL2 + libvorbis + libogg + libjpeg + libpng + freetype + glew + tinyxml + openal + freealut + libepoxy + curl + readline + libb2 ]; - cmakeFlags = [ "-DCMAKE_AR=${gcc-unwrapped}/bin/gcc-ar" "-DCMAKE_RANLIB=${gcc-unwrapped}/bin/gcc-ranlib" ]; + cmakeFlags = [ + "-DCMAKE_AR=${gcc-unwrapped}/bin/gcc-ar" + "-DCMAKE_RANLIB=${gcc-unwrapped}/bin/gcc-ranlib" + ]; cmakeBuildType = "RelWithDebInfo"; @@ -56,6 +94,9 @@ in stdenv.mkDerivation rec { license = if enableSoundtrack then licenses.unfreeRedistributable else licenses.isc; mainProgram = "openclonk"; maintainers = [ ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/by-name/op/opencollada/package.nix b/pkgs/by-name/op/opencollada/package.nix index 67f18a4a2718a5..2e12e13f56c40d 100644 --- a/pkgs/by-name/op/opencollada/package.nix +++ b/pkgs/by-name/op/opencollada/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl, cmake, pkg-config, libxml2, pcre -, darwin}: +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + cmake, + pkg-config, + libxml2, + pcre, + darwin, +}: stdenv.mkDerivation rec { pname = "opencollada"; @@ -23,19 +32,29 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ AGL ]); + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; [ AGL ] + ); - propagatedBuildInputs = [ libxml2 pcre ]; + propagatedBuildInputs = [ + libxml2 + pcre + ]; - postPatch = '' - # Drop blanket -Werror as it tends to fail on newer toolchain for - # minor warnings. In this case it was gcc-13 build failure. - substituteInPlace DAEValidator/CMakeLists.txt --replace-fail ' -Werror"' '"' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace GeneratedSaxParser/src/GeneratedSaxParserUtils.cpp \ - --replace math.h cmath - ''; + postPatch = + '' + # Drop blanket -Werror as it tends to fail on newer toolchain for + # minor warnings. In this case it was gcc-13 build failure. + substituteInPlace DAEValidator/CMakeLists.txt --replace-fail ' -Werror"' '"' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace GeneratedSaxParser/src/GeneratedSaxParserUtils.cpp \ + --replace math.h cmath + ''; meta = { description = "Library for handling the COLLADA file format"; diff --git a/pkgs/by-name/op/opencore-amr/package.nix b/pkgs/by-name/op/opencore-amr/package.nix index 38a50b75027bc3..6eef6bade0e41f 100644 --- a/pkgs/by-name/op/opencore-amr/package.nix +++ b/pkgs/by-name/op/opencore-amr/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "opencore-amr"; diff --git a/pkgs/by-name/op/opencorsairlink/package.nix b/pkgs/by-name/op/opencorsairlink/package.nix index e4e1791c8971fe..7df0acba7b86bd 100644 --- a/pkgs/by-name/op/opencorsairlink/package.nix +++ b/pkgs/by-name/op/opencorsairlink/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, libusb1, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + libusb1, + pkg-config, +}: stdenv.mkDerivation rec { pname = "OpenCorsairLink"; @@ -30,7 +37,7 @@ stdenv.mkDerivation rec { homepage = "https://github.com/audiohacked/OpenCorsairLink"; license = licenses.gpl2Plus; platforms = platforms.all; - maintainers = []; + maintainers = [ ]; mainProgram = "OpenCorsairLink.elf"; }; } diff --git a/pkgs/by-name/op/opencryptoki/package.nix b/pkgs/by-name/op/opencryptoki/package.nix index 67acc540348b44..45e90cc1a34640 100644 --- a/pkgs/by-name/op/opencryptoki/package.nix +++ b/pkgs/by-name/op/opencryptoki/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, bison -, flex -, openldap -, openssl -, trousers -, libcap +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + bison, + flex, + openldap, + openssl, + trousers, + libcap, }: stdenv.mkDerivation rec { @@ -57,11 +58,11 @@ stdenv.mkDerivation rec { ]; meta = with lib; { - changelog = "https://github.com/opencryptoki/opencryptoki/blob/${src.rev}/ChangeLog"; + changelog = "https://github.com/opencryptoki/opencryptoki/blob/${src.rev}/ChangeLog"; description = "PKCS#11 implementation for Linux"; - homepage = "https://github.com/opencryptoki/opencryptoki"; - license = licenses.cpl10; + homepage = "https://github.com/opencryptoki/opencryptoki"; + license = licenses.cpl10; maintainers = [ ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/op/openct/package.nix b/pkgs/by-name/op/openct/package.nix index c8cc99b3f543fc..2b25bf2614c55d 100644 --- a/pkgs/by-name/op/openct/package.nix +++ b/pkgs/by-name/op/openct/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, pcsclite, libusb-compat-0_1 -, doxygen, libxslt +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + pcsclite, + libusb-compat-0_1, + doxygen, + libxslt, }: stdenv.mkDerivation rec { @@ -25,8 +33,16 @@ stdenv.mkDerivation rec { "--sysconfdir=/etc" ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ pcsclite libusb-compat-0_1 doxygen libxslt ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + pcsclite + libusb-compat-0_1 + doxygen + libxslt + ]; preInstall = '' mkdir -p $out/etc diff --git a/pkgs/by-name/op/opendbx/package.nix b/pkgs/by-name/op/opendbx/package.nix index ba66ba5be18a9b..51714e8bbd389e 100644 --- a/pkgs/by-name/op/opendbx/package.nix +++ b/pkgs/by-name/op/opendbx/package.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchurl, readline, libmysqlclient, postgresql, sqlite }: +{ + lib, + stdenv, + fetchurl, + readline, + libmysqlclient, + postgresql, + sqlite, +}: -let inherit (lib) getDev; in +let + inherit (lib) getDev; +in stdenv.mkDerivation rec { pname = "opendbx"; @@ -17,7 +27,12 @@ stdenv.mkDerivation rec { configureFlagsArray=(--with-backends="mysql pgsql sqlite3") ''; - buildInputs = [ readline libmysqlclient postgresql sqlite ]; + buildInputs = [ + readline + libmysqlclient + postgresql + sqlite + ]; env.NIX_CFLAGS_COMPILE = toString [ # Needed with GCC 12 diff --git a/pkgs/by-name/op/opendkim/package.nix b/pkgs/by-name/op/opendkim/package.nix index 8425d5a815bf92..d61d03069f029a 100644 --- a/pkgs/by-name/op/opendkim/package.nix +++ b/pkgs/by-name/op/opendkim/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, libbsd, openssl, libmilter -, autoreconfHook, perl, makeWrapper, unbound }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libbsd, + openssl, + libmilter, + autoreconfHook, + perl, + makeWrapper, + unbound, +}: stdenv.mkDerivation rec { pname = "opendkim"; @@ -8,19 +19,28 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "trusteddomainproject"; repo = "OpenDKIM"; - rev = "rel-opendkim-${lib.replaceStrings ["."] ["-"] version}"; + rev = "rel-opendkim-${lib.replaceStrings [ "." ] [ "-" ] version}"; sha256 = "0nx3in8sa6xna4vfacj8g60hfzk61jpj2ldag80xzxip9c3rd2pw"; }; - configureFlags= [ + configureFlags = [ "--with-milter=${libmilter}" "ac_cv_func_malloc_0_nonnull=yes" "ac_cv_func_realloc_0_nonnull=yes" ] ++ lib.optional stdenv.hostPlatform.isDarwin "--with-unbound=${unbound}"; - nativeBuildInputs = [ autoreconfHook pkg-config makeWrapper ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + makeWrapper + ]; - buildInputs = [ libbsd openssl libmilter perl ] ++ lib.optional stdenv.hostPlatform.isDarwin unbound; + buildInputs = [ + libbsd + openssl + libmilter + perl + ] ++ lib.optional stdenv.hostPlatform.isDarwin unbound; postInstall = '' wrapProgram $out/sbin/opendkim-genkey \ diff --git a/pkgs/by-name/op/opendmarc/package.nix b/pkgs/by-name/op/opendmarc/package.nix index d8af86b6cdb57c..9dba438fa06eaf 100644 --- a/pkgs/by-name/op/opendmarc/package.nix +++ b/pkgs/by-name/op/opendmarc/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libmilter, perl, perlPackages, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libmilter, + perl, + perlPackages, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "opendmarc"; @@ -11,10 +20,18 @@ stdenv.mkDerivation rec { hash = "sha256-vnWtTvHhzCed7P6rN3wAz6zfRvtV0cLn5GhDxLF8H3c="; }; - outputs = [ "bin" "dev" "out" "doc" ]; + outputs = [ + "bin" + "dev" + "out" + "doc" + ]; buildInputs = [ perl ]; - nativeBuildInputs = [ autoreconfHook makeWrapper ]; + nativeBuildInputs = [ + autoreconfHook + makeWrapper + ]; postPatch = '' substituteInPlace configure.ac --replace ' docs/Makefile' "" @@ -27,14 +44,27 @@ stdenv.mkDerivation rec { postFixup = '' for b in $bin/bin/opendmarc-{expire,import,params,reports}; do - wrapProgram $b --set PERL5LIB ${perlPackages.makeFullPerlPath (with perlPackages; [ Switch DBI DBDmysql HTTPMessage ])} + wrapProgram $b --set PERL5LIB ${ + perlPackages.makeFullPerlPath ( + with perlPackages; + [ + Switch + DBI + DBDmysql + HTTPMessage + ] + ) + } done ''; meta = with lib; { description = "Free open source software implementation of the DMARC specification"; homepage = "http://www.trusteddomain.org/opendmarc/"; - license = with licenses; [ bsd3 sendmail ]; + license = with licenses; [ + bsd3 + sendmail + ]; maintainers = teams.helsinki-systems.members; }; } diff --git a/pkgs/by-name/op/opendune/package.nix b/pkgs/by-name/op/opendune/package.nix index c50379d0c4221e..38727c388ebbea 100644 --- a/pkgs/by-name/op/opendune/package.nix +++ b/pkgs/by-name/op/opendune/package.nix @@ -1,5 +1,14 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config -, alsa-lib, libpulseaudio, SDL2, SDL2_image, SDL2_mixer }: +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + alsa-lib, + libpulseaudio, + SDL2, + SDL2_image, + SDL2_mixer, +}: # - set the opendune configuration at ~/.config/opendune/opendune.ini: # [opendune] @@ -24,7 +33,13 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ alsa-lib libpulseaudio SDL2 SDL2_image SDL2_mixer ]; + buildInputs = [ + alsa-lib + libpulseaudio + SDL2 + SDL2_image + SDL2_mixer + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/op/opendungeons/package.nix b/pkgs/by-name/op/opendungeons/package.nix index a66504fa1d83cc..7478934a259ca2 100644 --- a/pkgs/by-name/op/opendungeons/package.nix +++ b/pkgs/by-name/op/opendungeons/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, ogre_13 -, cegui -, boost -, sfml -, openal -, ois +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + ogre_13, + cegui, + boost, + sfml, + openal, + ois, }: let @@ -66,7 +67,15 @@ stdenv.mkDerivation { description = "Open source, real time strategy game sharing game elements with the Dungeon Keeper series and Evil Genius"; mainProgram = "opendungeons"; homepage = "https://opendungeons.github.io"; - license = with licenses; [ gpl3Plus zlib mit cc-by-sa-30 cc0 ofl cc-by-30 ]; + license = with licenses; [ + gpl3Plus + zlib + mit + cc-by-sa-30 + cc0 + ofl + cc-by-30 + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/op/openexrid-unstable/package.nix b/pkgs/by-name/op/openexrid-unstable/package.nix index a8e125cc43b5fa..02e14959dc8778 100644 --- a/pkgs/by-name/op/openexrid-unstable/package.nix +++ b/pkgs/by-name/op/openexrid-unstable/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, re2, openfx, zlib, ilmbase, libGLU, libGL, openexr }: +{ + lib, + stdenv, + fetchFromGitHub, + re2, + openfx, + zlib, + ilmbase, + libGLU, + libGL, + openexr, +}: stdenv.mkDerivation { pname = "openexrid-unstable"; @@ -11,7 +22,11 @@ stdenv.mkDerivation { sha256 = "0h4b74lv59p4hhrvrqdmlnchn2i0v5id4kl8xc7j26l9884q0383"; }; - outputs = [ "dev" "out" "lib" ]; + outputs = [ + "dev" + "out" + "lib" + ]; patches = [ ./openexrid.patch ]; @@ -26,23 +41,31 @@ stdenv.mkDerivation { -I${openfx.dev}/include/OpenFX ''; - buildInputs = [ re2 openfx zlib ilmbase libGLU libGL openexr ]; + buildInputs = [ + re2 + openfx + zlib + ilmbase + libGLU + libGL + openexr + ]; enableParallelBuilding = true; buildPhase = '' - mkdir openexrid/release + mkdir openexrid/release - PREFIX=$out make -C openexrid install + PREFIX=$out make -C openexrid install - mkdir $dev; - mkdir $lib; + mkdir $dev; + mkdir $lib; ''; installPhase = '' - find $out - mv $out/include $dev/ - mv $out/lib $lib/ + find $out + mv $out/include $dev/ + mv $out/lib $lib/ ''; meta = with lib; { diff --git a/pkgs/by-name/op/openfec/package.nix b/pkgs/by-name/op/openfec/package.nix index 8cee39c3a3ab80..613cc2fec67154 100644 --- a/pkgs/by-name/op/openfec/package.nix +++ b/pkgs/by-name/op/openfec/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchzip -, cmake -, gitUpdater +{ + stdenv, + lib, + fetchzip, + cmake, + gitUpdater, }: stdenv.mkDerivation rec { @@ -14,7 +15,10 @@ stdenv.mkDerivation rec { hash = "sha256-lBR8vz8whEdPVHAGVq9eRriKtmS5tUAvtoyXwO4AuEs="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake @@ -26,8 +30,10 @@ stdenv.mkDerivation rec { ]; installPhase = - let so = stdenv.hostPlatform.extensions.library; - in '' + let + so = stdenv.hostPlatform.extensions.library; + in + '' # This is pretty horrible but sadly there is not installation procedure # provided. mkdir -p $dev/include @@ -35,9 +41,11 @@ stdenv.mkDerivation rec { find $dev/include -type f -a ! -iname '*.h' -delete install -D -m755 -t $out/lib ../bin/Release/libopenfec${so} - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' install_name_tool -id $out/lib/libopenfec${so} $out/lib/libopenfec${so} - '' + '' + '' + + '' ln -s libopenfec${so} $out/lib/libopenfec${so}.1 ''; diff --git a/pkgs/by-name/op/openfpgaloader/package.nix b/pkgs/by-name/op/openfpgaloader/package.nix index 2a84bfdc8c9ac7..d43a573ac26853 100644 --- a/pkgs/by-name/op/openfpgaloader/package.nix +++ b/pkgs/by-name/op/openfpgaloader/package.nix @@ -1,14 +1,14 @@ { - cmake -, fetchFromGitHub -, hidapi -, lib -, libftdi1 -, libusb1 -, pkg-config -, stdenv -, udev -, zlib + cmake, + fetchFromGitHub, + hidapi, + lib, + libftdi1, + libusb1, + pkg-config, + stdenv, + udev, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -27,14 +27,16 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - hidapi - libftdi1 - libusb1 - zlib - ] ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform udev) [ - udev - ]; + buildInputs = + [ + hidapi + libftdi1 + libusb1 + zlib + ] + ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform udev) [ + udev + ]; meta = { description = "Universal utility for programming FPGAs"; diff --git a/pkgs/by-name/op/openfst/package.nix b/pkgs/by-name/op/openfst/package.nix index 318a4107a813c8..783a20ea10fadb 100644 --- a/pkgs/by-name/op/openfst/package.nix +++ b/pkgs/by-name/op/openfst/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "openfst"; diff --git a/pkgs/by-name/op/openfx/package.nix b/pkgs/by-name/op/openfx/package.nix index 2bfb0870858821..674ee79287630c 100644 --- a/pkgs/by-name/op/openfx/package.nix +++ b/pkgs/by-name/op/openfx/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "openfx"; @@ -11,18 +15,21 @@ stdenv.mkDerivation { sha256 = "0k9ggzr6bisn77mipjfvawg3mv4bz50b63v8f7w1jhldi1sfy548"; }; - outputs = [ "dev" "out" ]; + outputs = [ + "dev" + "out" + ]; enableParallelBuilding = true; buildPhase = '' - mkdir $dev - mkdir $out - ''; + mkdir $dev + mkdir $out + ''; installPhase = '' - mkdir -p $dev/include/OpenFX/ - cp -r include/* $dev/include/OpenFX/ + mkdir -p $dev/include/OpenFX/ + cp -r include/* $dev/include/OpenFX/ ''; meta = with lib; { diff --git a/pkgs/by-name/op/opengrm-ngram/package.nix b/pkgs/by-name/op/opengrm-ngram/package.nix index ec1b297da8342c..c2ee06353a3394 100644 --- a/pkgs/by-name/op/opengrm-ngram/package.nix +++ b/pkgs/by-name/op/opengrm-ngram/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, autoreconfHook, fetchurl, openfst }: +{ + lib, + stdenv, + autoreconfHook, + fetchurl, + openfst, +}: stdenv.mkDerivation rec { pname = "opengrm-ngram"; diff --git a/pkgs/by-name/op/opengrok/package.nix b/pkgs/by-name/op/opengrok/package.nix index 35116156f969a2..3566bb19bb4320 100644 --- a/pkgs/by-name/op/opengrok/package.nix +++ b/pkgs/by-name/op/opengrok/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "opengrok"; diff --git a/pkgs/by-name/op/opengv/package.nix b/pkgs/by-name/op/opengv/package.nix index 3b6387306609eb..d1737c0d6579d9 100644 --- a/pkgs/by-name/op/opengv/package.nix +++ b/pkgs/by-name/op/opengv/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, eigen -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + eigen, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { pname = "opengv"; @@ -28,14 +29,14 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/laurentkneip/opengv"; license = lib.licenses.bsd2; longDescription = '' - OpenGV is a collection of computer vision methods for solving - geometric vision problems. It contains absolute-pose, relative-pose, - triangulation, and point-cloud alignment methods for the calibrated - case. All problems can be solved with central or non-central cameras, - and embedded into a random sample consensus or nonlinear optimization - context. Matlab and Python interfaces are implemented as well. The link - to the above pages also shows links to precompiled Matlab mex-libraries. - Please consult the documentation for more information. + OpenGV is a collection of computer vision methods for solving + geometric vision problems. It contains absolute-pose, relative-pose, + triangulation, and point-cloud alignment methods for the calibrated + case. All problems can be solved with central or non-central cameras, + and embedded into a random sample consensus or nonlinear optimization + context. Matlab and Python interfaces are implemented as well. The link + to the above pages also shows links to precompiled Matlab mex-libraries. + Please consult the documentation for more information. ''; maintainers = [ lib.maintainers.locochoco ]; platforms = lib.platforms.all; diff --git a/pkgs/by-name/op/openh264/package.nix b/pkgs/by-name/op/openh264/package.nix index 12048b593dd02f..c66ab4bffddda6 100644 --- a/pkgs/by-name/op/openh264/package.nix +++ b/pkgs/by-name/op/openh264/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, fetchpatch2 -, gtest -, meson -, nasm -, ninja -, pkg-config -, stdenv -, windows +{ + lib, + fetchFromGitHub, + fetchpatch2, + gtest, + meson, + nasm, + ninja, + pkg-config, + stdenv, + windows, }: stdenv.mkDerivation (finalAttrs: { @@ -31,7 +32,10 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ meson @@ -40,11 +44,13 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - gtest - ] ++ lib.optionals stdenv.hostPlatform.isWindows [ - windows.pthreads - ]; + buildInputs = + [ + gtest + ] + ++ lib.optionals stdenv.hostPlatform.isWindows [ + windows.pthreads + ]; strictDeps = true; @@ -55,9 +61,14 @@ stdenv.mkDerivation (finalAttrs: { license = with lib.licenses; [ bsd2 ]; maintainers = with lib.maintainers; [ AndersonTorres ]; # See meson.build - platforms = lib.platforms.windows ++ lib.intersectLists - (lib.platforms.x86 ++ lib.platforms.arm ++ lib.platforms.aarch64 ++ - lib.platforms.loongarch64 ++ lib.platforms.riscv64) - (lib.platforms.linux ++ lib.platforms.darwin); + platforms = + lib.platforms.windows + ++ lib.intersectLists ( + lib.platforms.x86 + ++ lib.platforms.arm + ++ lib.platforms.aarch64 + ++ lib.platforms.loongarch64 + ++ lib.platforms.riscv64 + ) (lib.platforms.linux ++ lib.platforms.darwin); }; }) diff --git a/pkgs/by-name/op/openhmd/package.nix b/pkgs/by-name/op/openhmd/package.nix index ce0630bee62fcd..f2d8b845d7c281 100644 --- a/pkgs/by-name/op/openhmd/package.nix +++ b/pkgs/by-name/op/openhmd/package.nix @@ -1,15 +1,19 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, hidapi -, SDL2 -, libGL -, glew -, withExamples ? true +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + hidapi, + SDL2, + libGL, + glew, + withExamples ? true, }: -let examplesOnOff = if withExamples then "ON" else "OFF"; in +let + examplesOnOff = if withExamples then "ON" else "OFF"; +in stdenv.mkDerivation rec { pname = "openhmd"; @@ -22,16 +26,21 @@ stdenv.mkDerivation rec { sha256 = "1hkpdl4zgycag5k8njvqpx01apxmm8m8pvhlsxgxpqiqy9a38ccg"; }; - nativeBuildInputs = [ cmake pkg-config ]; - - buildInputs = [ - hidapi - ] ++ lib.optionals withExamples [ - SDL2 - glew - libGL + nativeBuildInputs = [ + cmake + pkg-config ]; + buildInputs = + [ + hidapi + ] + ++ lib.optionals withExamples [ + SDL2 + glew + libGL + ]; + cmakeFlags = [ "-DBUILD_BOTH_STATIC_SHARED_LIBS=ON" "-DOPENHMD_EXAMPLE_SIMPLE=${examplesOnOff}" diff --git a/pkgs/by-name/op/openimagedenoise/package.nix b/pkgs/by-name/op/openimagedenoise/package.nix index cfd38708cd9aa5..5f4c4336bba6fe 100644 --- a/pkgs/by-name/op/openimagedenoise/package.nix +++ b/pkgs/by-name/op/openimagedenoise/package.nix @@ -28,17 +28,18 @@ stdenv'.mkDerivation (finalAttrs: { patches = lib.optional cudaSupport ./cuda.patch; - postPatch = - '' - substituteInPlace devices/metal/CMakeLists.txt \ - --replace-fail "AppleClang" "Clang" - ''; + postPatch = '' + substituteInPlace devices/metal/CMakeLists.txt \ + --replace-fail "AppleClang" "Clang" + ''; - nativeBuildInputs = [ - cmake - python3 - ispc - ] ++ lib.optional cudaSupport cudaPackages.cuda_nvcc + nativeBuildInputs = + [ + cmake + python3 + ispc + ] + ++ lib.optional cudaSupport cudaPackages.cuda_nvcc ++ lib.optionals stdenv.hostPlatform.isDarwin [ xcodebuild ]; buildInputs = diff --git a/pkgs/by-name/op/openipmi/package.nix b/pkgs/by-name/op/openipmi/package.nix index 4db4048fcd707a..652ec050a24d83 100644 --- a/pkgs/by-name/op/openipmi/package.nix +++ b/pkgs/by-name/op/openipmi/package.nix @@ -1,4 +1,13 @@ -{ stdenv, fetchurl, popt, ncurses, python3, readline, lib, openssl }: +{ + stdenv, + fetchurl, + popt, + ncurses, + python3, + readline, + lib, + openssl, +}: stdenv.mkDerivation rec { pname = "OpenIPMI"; @@ -9,14 +18,28 @@ stdenv.mkDerivation rec { sha256 = "sha256-oEAxSPpfe+2TDJWKTRxVgEfic3Y6QIs6A2jtwTfMVdk="; }; - buildInputs = [ ncurses popt python3 readline openssl ]; + buildInputs = [ + ncurses + popt + python3 + readline + openssl + ]; - outputs = [ "out" "lib" "dev" "man" ]; + outputs = [ + "out" + "lib" + "dev" + "man" + ]; meta = with lib; { homepage = "https://openipmi.sourceforge.io/"; description = "User-level library that provides a higher-level abstraction of IPMI and generic services"; - license = with licenses; [ gpl2Only lgpl2Only ]; + license = with licenses; [ + gpl2Only + lgpl2Only + ]; platforms = platforms.linux; maintainers = with maintainers; [ arezvov ] ++ teams.c3d2.members; }; diff --git a/pkgs/by-name/op/openiscsi/package.nix b/pkgs/by-name/op/openiscsi/package.nix index d1074588b97f98..a383f5fcb6d48a 100644 --- a/pkgs/by-name/op/openiscsi/package.nix +++ b/pkgs/by-name/op/openiscsi/package.nix @@ -1,17 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, pkg-config -, ninja -, perl -, util-linux -, open-isns -, openssl -, kmod -, systemd -, runtimeShell -, nixosTests }: +{ + stdenv, + lib, + fetchFromGitHub, + meson, + pkg-config, + ninja, + perl, + util-linux, + open-isns, + openssl, + kmod, + systemd, + runtimeShell, + nixosTests, +}: stdenv.mkDerivation rec { pname = "open-iscsi"; @@ -62,6 +64,9 @@ stdenv.mkDerivation rec { license = licenses.gpl2Plus; homepage = "https://www.open-iscsi.com"; platforms = platforms.linux; - maintainers = with maintainers; [ cleverca22 zaninime ]; + maintainers = with maintainers; [ + cleverca22 + zaninime + ]; }; } diff --git a/pkgs/by-name/op/openjade/package.nix b/pkgs/by-name/op/openjade/package.nix index 60fa161d20c50c..2991f1606f08a6 100644 --- a/pkgs/by-name/op/openjade/package.nix +++ b/pkgs/by-name/op/openjade/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, opensp, perl }: +{ + lib, + stdenv, + fetchurl, + opensp, + perl, +}: stdenv.mkDerivation rec { pname = "openjade"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { patches = [ ./msggen.patch ]; - buildInputs = [ opensp perl ]; + buildInputs = [ + opensp + perl + ]; configureFlags = [ "--enable-spincludedir=${opensp}/include/OpenSP" diff --git a/pkgs/by-name/op/openjk/package.nix b/pkgs/by-name/op/openjk/package.nix index f1eb4b597ab84e..15b89654ad4eb4 100644 --- a/pkgs/by-name/op/openjk/package.nix +++ b/pkgs/by-name/op/openjk/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, makeDesktopItem, makeWrapper, cmake, libjpeg, zlib, libpng, libGL, SDL2 -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + makeDesktopItem, + makeWrapper, + cmake, + libjpeg, + zlib, + libpng, + libGL, + SDL2, + unstableGitUpdater, }: let @@ -30,7 +41,8 @@ let genericName = "Jedi Outcast"; categories = [ "Game" ]; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "openjk"; version = "0-unstable-2024-04-07"; @@ -43,18 +55,33 @@ in stdenv.mkDerivation { dontAddPrefix = true; - nativeBuildInputs = [ makeWrapper cmake ]; - buildInputs = [ libjpeg zlib libpng libGL SDL2 ]; + nativeBuildInputs = [ + makeWrapper + cmake + ]; + buildInputs = [ + libjpeg + zlib + libpng + libGL + SDL2 + ]; - outputs = [ "out" "openjo" "openja" ]; + outputs = [ + "out" + "openjo" + "openja" + ]; # move from $out/JediAcademy to $out/opt/JediAcademy preConfigure = '' cmakeFlagsArray=("-DCMAKE_INSTALL_PREFIX=$out/opt") ''; - cmakeFlags = ["-DBuildJK2SPEngine:BOOL=ON" - "-DBuildJK2SPGame:BOOL=ON" - "-DBuildJK2SPRdVanilla:BOOL=ON"]; + cmakeFlags = [ + "-DBuildJK2SPEngine:BOOL=ON" + "-DBuildJK2SPGame:BOOL=ON" + "-DBuildJK2SPRdVanilla:BOOL=ON" + ]; postInstall = '' mkdir -p $out/bin $openja/bin $openjo/bin diff --git a/pkgs/by-name/op/openjph/package.nix b/pkgs/by-name/op/openjph/package.nix index d499c898541b89..f3b36b590b28a1 100644 --- a/pkgs/by-name/op/openjph/package.nix +++ b/pkgs/by-name/op/openjph/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, validatePkgConfig, testers, nix-update-script }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + validatePkgConfig, + testers, + nix-update-script, +}: stdenv.mkDerivation (finalAttrs: { pname = "openjph"; @@ -11,9 +19,15 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-cgJlgb4SrmVFqvmqGcG3+qMDteyVFlYzoy1IOo8BjA8="; }; - nativeBuildInputs = [ cmake validatePkgConfig ]; + nativeBuildInputs = [ + cmake + validatePkgConfig + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; cmakeFlags = [ (lib.cmakeBool "OJPH_ENABLE_TIFF_SUPPORT" false) diff --git a/pkgs/by-name/op/openldap/package.nix b/pkgs/by-name/op/openldap/package.nix index 453cb1dfebde7d..e8d0b405c065c2 100644 --- a/pkgs/by-name/op/openldap/package.nix +++ b/pkgs/by-name/op/openldap/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl - -# dependencies -, cyrus_sasl -, groff -, libsodium -, libtool -, openssl -, systemdMinimal -, libxcrypt - -# passthru -, nixosTests +{ + lib, + stdenv, + fetchurl, + + # dependencies + cyrus_sasl, + groff, + libsodium, + libtool, + openssl, + systemdMinimal, + libxcrypt, + + # passthru + nixosTests, }: stdenv.mkDerivation rec { @@ -40,37 +41,42 @@ stdenv.mkDerivation rec { groff ]; - buildInputs = [ - (cyrus_sasl.override { - inherit openssl; - }) - libsodium - libtool - openssl - ] ++ lib.optionals (stdenv.hostPlatform.isLinux) [ - libxcrypt # causes linking issues on *-darwin - systemdMinimal - ]; + buildInputs = + [ + (cyrus_sasl.override { + inherit openssl; + }) + libsodium + libtool + openssl + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux) [ + libxcrypt # causes linking issues on *-darwin + systemdMinimal + ]; preConfigure = lib.optionalString (lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11") '' MACOSX_DEPLOYMENT_TARGET=10.16 ''; - configureFlags = [ - "--enable-argon2" - "--enable-crypt" - "--enable-modules" - "--enable-overlays" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "--with-yielding_select=yes" - "ac_cv_func_memcmp_working=yes" - ] ++ lib.optional stdenv.hostPlatform.isFreeBSD "--with-pic"; + configureFlags = + [ + "--enable-argon2" + "--enable-crypt" + "--enable-modules" + "--enable-overlays" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "--with-yielding_select=yes" + "ac_cv_func_memcmp_working=yes" + ] + ++ lib.optional stdenv.hostPlatform.isFreeBSD "--with-pic"; env.NIX_CFLAGS_COMPILE = toString [ "-DLDAPI_SOCK=\"/run/openldap/ldapi\"" ]; - makeFlags= [ + makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" - "STRIP=" # Disable install stripping as it breaks cross-compiling. We strip binaries anyway in fixupPhase. + "STRIP=" # Disable install stripping as it breaks cross-compiling. We strip binaries anyway in fixupPhase. "STRIP_OPTS=" "prefix=${placeholder "out"}" "sysconfdir=/etc" diff --git a/pkgs/by-name/op/openlibm/package.nix b/pkgs/by-name/op/openlibm/package.nix index a7c5063e54dbab..620e50db522e59 100644 --- a/pkgs/by-name/op/openlibm/package.nix +++ b/pkgs/by-name/op/openlibm/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "openlibm"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-JhyF93XU2Yd6Ia+JtYvF7Dr+d90r6xMZj/fWDwCNeWY="; }; - makeFlags = [ "prefix=$(out)" "CC=${stdenv.cc.targetPrefix}cc" ]; + makeFlags = [ + "prefix=$(out)" + "CC=${stdenv.cc.targetPrefix}cc" + ]; meta = { description = "High quality system independent, portable, open source libm implementation"; diff --git a/pkgs/by-name/op/openmm/package.nix b/pkgs/by-name/op/openmm/package.nix index eb469159df3a97..a570659ec2908f 100644 --- a/pkgs/by-name/op/openmm/package.nix +++ b/pkgs/by-name/op/openmm/package.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, gfortran -, fftwSinglePrec -, doxygen -, swig -, enablePython ? false -, python3Packages -, enableOpencl ? true -, opencl-headers -, ocl-icd -, config -, enableCuda ? config.cudaSupport -, cudaPackages -, addDriverRunpath +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + gfortran, + fftwSinglePrec, + doxygen, + swig, + enablePython ? false, + python3Packages, + enableOpencl ? true, + opencl-headers, + ocl-icd, + config, + enableCuda ? config.cudaSupport, + cudaPackages, + addDriverRunpath, }: stdenv.mkDerivation rec { @@ -36,61 +37,75 @@ stdenv.mkDerivation rec { serialization/tests/TestSerializeIntegrator.cpp ''; - nativeBuildInputs = [ - cmake - gfortran - swig - doxygen - python3Packages.python - ] ++ lib.optionals enablePython [ - python3Packages.build - python3Packages.installer - python3Packages.wheel - ] ++ lib.optional enableCuda addDriverRunpath; + nativeBuildInputs = + [ + cmake + gfortran + swig + doxygen + python3Packages.python + ] + ++ lib.optionals enablePython [ + python3Packages.build + python3Packages.installer + python3Packages.wheel + ] + ++ lib.optional enableCuda addDriverRunpath; - buildInputs = [ fftwSinglePrec ] - ++ lib.optionals enableOpencl [ ocl-icd opencl-headers ] + buildInputs = + [ fftwSinglePrec ] + ++ lib.optionals enableOpencl [ + ocl-icd + opencl-headers + ] ++ lib.optional enableCuda cudaPackages.cudatoolkit; - propagatedBuildInputs = lib.optionals enablePython (with python3Packages; [ - setuptools - python - numpy - cython - ]); + propagatedBuildInputs = lib.optionals enablePython ( + with python3Packages; + [ + setuptools + python + numpy + cython + ] + ); - cmakeFlags = [ - "-DBUILD_TESTING=ON" - "-DOPENMM_BUILD_AMOEBA_PLUGIN=ON" - "-DOPENMM_BUILD_CPU_LIB=ON" - "-DOPENMM_BUILD_C_AND_FORTRAN_WRAPPERS=ON" - "-DOPENMM_BUILD_DRUDE_PLUGIN=ON" - "-DOPENMM_BUILD_PME_PLUGIN=ON" - "-DOPENMM_BUILD_RPMD_PLUGIN=ON" - "-DOPENMM_BUILD_SHARED_LIB=ON" - ] ++ lib.optionals enablePython [ - "-DOPENMM_BUILD_PYTHON_WRAPPERS=ON" - ] ++ lib.optionals enableOpencl [ - "-DOPENMM_BUILD_OPENCL_LIB=ON" - "-DOPENMM_BUILD_AMOEBA_OPENCL_LIB=ON" - "-DOPENMM_BUILD_DRUDE_OPENCL_LIB=ON" - "-DOPENMM_BUILD_RPMD_OPENCL_LIB=ON" - ] ++ lib.optionals enableCuda [ - "-DCUDA_SDK_ROOT_DIR=${cudaPackages.cudatoolkit}" - "-DOPENMM_BUILD_AMOEBA_CUDA_LIB=ON" - "-DOPENMM_BUILD_CUDA_LIB=ON" - "-DOPENMM_BUILD_DRUDE_CUDA_LIB=ON" - "-DOPENMM_BUILD_RPMD_CUDA_LIB=ON" - "-DCMAKE_LIBRARY_PATH=${cudaPackages.cudatoolkit}/lib64/stubs" - ]; + cmakeFlags = + [ + "-DBUILD_TESTING=ON" + "-DOPENMM_BUILD_AMOEBA_PLUGIN=ON" + "-DOPENMM_BUILD_CPU_LIB=ON" + "-DOPENMM_BUILD_C_AND_FORTRAN_WRAPPERS=ON" + "-DOPENMM_BUILD_DRUDE_PLUGIN=ON" + "-DOPENMM_BUILD_PME_PLUGIN=ON" + "-DOPENMM_BUILD_RPMD_PLUGIN=ON" + "-DOPENMM_BUILD_SHARED_LIB=ON" + ] + ++ lib.optionals enablePython [ + "-DOPENMM_BUILD_PYTHON_WRAPPERS=ON" + ] + ++ lib.optionals enableOpencl [ + "-DOPENMM_BUILD_OPENCL_LIB=ON" + "-DOPENMM_BUILD_AMOEBA_OPENCL_LIB=ON" + "-DOPENMM_BUILD_DRUDE_OPENCL_LIB=ON" + "-DOPENMM_BUILD_RPMD_OPENCL_LIB=ON" + ] + ++ lib.optionals enableCuda [ + "-DCUDA_SDK_ROOT_DIR=${cudaPackages.cudatoolkit}" + "-DOPENMM_BUILD_AMOEBA_CUDA_LIB=ON" + "-DOPENMM_BUILD_CUDA_LIB=ON" + "-DOPENMM_BUILD_DRUDE_CUDA_LIB=ON" + "-DOPENMM_BUILD_RPMD_CUDA_LIB=ON" + "-DCMAKE_LIBRARY_PATH=${cudaPackages.cudatoolkit}/lib64/stubs" + ]; postInstall = lib.strings.optionalString enablePython '' - export OPENMM_LIB_PATH=$out/lib - export OPENMM_INCLUDE_PATH=$out/include - cd python - ${python3Packages.python.pythonOnBuildForHost.interpreter} -m build --no-isolation --outdir dist/ --wheel - ${python3Packages.python.pythonOnBuildForHost.interpreter} -m installer --prefix $out dist/*.whl - ''; + export OPENMM_LIB_PATH=$out/lib + export OPENMM_INCLUDE_PATH=$out/include + cd python + ${python3Packages.python.pythonOnBuildForHost.interpreter} -m build --no-isolation --outdir dist/ --wheel + ${python3Packages.python.pythonOnBuildForHost.interpreter} -m installer --prefix $out dist/*.whl + ''; postFixup = '' for lib in $out/lib/plugins/*CUDA.so $out/lib/plugins/*Cuda*.so; do @@ -105,7 +120,11 @@ stdenv.mkDerivation rec { description = "Toolkit for molecular simulation using high performance GPU code"; mainProgram = "TestReferenceHarmonicBondForce"; homepage = "https://openmm.org/"; - license = with licenses; [ gpl3Plus lgpl3Plus mit ]; + license = with licenses; [ + gpl3Plus + lgpl3Plus + mit + ]; platforms = platforms.linux; maintainers = [ maintainers.sheepforce ]; }; diff --git a/pkgs/by-name/op/openmsx/package.nix b/pkgs/by-name/op/openmsx/package.nix index 0680d48ebecd39..7a7014f310e6c8 100644 --- a/pkgs/by-name/op/openmsx/package.nix +++ b/pkgs/by-name/op/openmsx/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, SDL2 -, SDL2_image -, SDL2_ttf -, alsa-lib -, freetype -, glew -, libGL -, libogg -, libpng -, libtheora -, libvorbis -, python3 -, tcl -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + SDL2, + SDL2_image, + SDL2_ttf, + alsa-lib, + freetype, + glew, + libGL, + libogg, + libpng, + libtheora, + libvorbis, + python3, + tcl, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -25,7 +26,7 @@ stdenv.mkDerivation (finalAttrs: { src = fetchFromGitHub { owner = "openMSX"; repo = "openMSX"; - rev = "RELEASE_${builtins.replaceStrings ["."] ["_"] finalAttrs.version}"; + rev = "RELEASE_${builtins.replaceStrings [ "." ] [ "_" ] finalAttrs.version}"; hash = "sha256-iY+oZ7fHZnnEGunM4kOxOGH2Biqj2PfdLhbT8J4mYrA="; fetchSubmodules = true; }; @@ -59,7 +60,7 @@ stdenv.mkDerivation (finalAttrs: { # Many thanks @mthuurne from OpenMSX project for providing support to # Nixpkgs! :) - TCL_CONFIG="${tcl}/lib/"; + TCL_CONFIG = "${tcl}/lib/"; meta = with lib; { homepage = "https://openmsx.org"; @@ -68,7 +69,11 @@ stdenv.mkDerivation (finalAttrs: { OpenMSX is an emulator for the MSX home computer system. Its goal is to emulate all aspects of the MSX with 100% accuracy. ''; - license = with licenses; [ bsd2 boost gpl2Plus ]; + license = with licenses; [ + bsd2 + boost + gpl2Plus + ]; maintainers = with maintainers; [ AndersonTorres ]; platforms = platforms.unix; mainProgram = "openmsx"; diff --git a/pkgs/by-name/op/openntpd/package.nix b/pkgs/by-name/op/openntpd/package.nix index e1497ab085279a..a92a32c151bbae 100644 --- a/pkgs/by-name/op/openntpd/package.nix +++ b/pkgs/by-name/op/openntpd/package.nix @@ -1,6 +1,10 @@ -{ lib, stdenv, fetchurl, libressl -, privsepPath ? "/var/empty" -, privsepUser ? "ntp" +{ + lib, + stdenv, + fetchurl, + libressl, + privsepPath ? "/var/empty", + privsepUser ? "ntp", }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/op/openobex/package.nix b/pkgs/by-name/op/openobex/package.nix index 521505211219e4..6d1b867d4f5591 100644 --- a/pkgs/by-name/op/openobex/package.nix +++ b/pkgs/by-name/op/openobex/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, bluez, libusb-compat-0_1, cmake }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + bluez, + libusb-compat-0_1, + cmake, +}: stdenv.mkDerivation rec { pname = "openobex"; @@ -9,8 +17,14 @@ stdenv.mkDerivation rec { sha256 = "1z6l7pbwgs5pjx3861cyd3r6vq5av984bdp4r3hgrw2jxam6120m"; }; - nativeBuildInputs = [ pkg-config cmake ]; - buildInputs = [ bluez libusb-compat-0_1 ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; + buildInputs = [ + bluez + libusb-compat-0_1 + ]; configureFlags = [ "--enable-apps" ]; @@ -21,7 +35,7 @@ stdenv.mkDerivation rec { substituteInPlace CMakeLists.txt \ --replace '\$'{prefix}/'$'{CMAKE_INSTALL_LIBDIR} '$'{CMAKE_INSTALL_FULL_LIBDIR} \ --replace '\$'{prefix}/'$'{CMAKE_INSTALL_INCLUDEDIR} '$'{CMAKE_INSTALL_FULL_INCLUDEDIR} - ''; + ''; meta = with lib; { homepage = "http://dev.zuckschwerdt.org/openobex/"; diff --git a/pkgs/by-name/op/openocd/package.nix b/pkgs/by-name/op/openocd/package.nix index 86dfd687ed2f98..618b998eefcb62 100644 --- a/pkgs/by-name/op/openocd/package.nix +++ b/pkgs/by-name/op/openocd/package.nix @@ -1,19 +1,22 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, hidapi -, tcl -, jimtcl -, libjaylink -, libusb1 -, libgpiod_1 +{ + stdenv, + lib, + fetchurl, + pkg-config, + hidapi, + tcl, + jimtcl, + libjaylink, + libusb1, + libgpiod_1, -, enableFtdi ? true, libftdi1 + enableFtdi ? true, + libftdi1, -# Allow selection the hardware targets (SBCs, JTAG Programmers, JTAG Adapters) -, extraHardwareSupport ? [] -}: let + # Allow selection the hardware targets (SBCs, JTAG Programmers, JTAG Adapters) + extraHardwareSupport ? [ ], +}: +let isWindows = stdenv.hostPlatform.isWindows; notWindows = !isWindows; @@ -27,13 +30,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-ryVHiL6Yhh8r2RA/5uYKd07Jaow3R0Tu+Rl/YEMHWvo="; }; - nativeBuildInputs = [ pkg-config tcl ]; + nativeBuildInputs = [ + pkg-config + tcl + ]; - buildInputs = [ libusb1 ] - ++ lib.optionals notWindows [ hidapi jimtcl libftdi1 libjaylink ] + buildInputs = + [ libusb1 ] + ++ lib.optionals notWindows [ + hidapi + jimtcl + libftdi1 + libjaylink + ] ++ - # tracking issue for v2 api changes https://sourceforge.net/p/openocd/tickets/306/ - lib.optional stdenv.hostPlatform.isLinux libgpiod_1; + # tracking issue for v2 api changes https://sourceforge.net/p/openocd/tickets/306/ + lib.optional stdenv.hostPlatform.isLinux libgpiod_1; configureFlags = [ "--disable-werror" @@ -45,16 +57,16 @@ stdenv.mkDerivation rec { (lib.enableFeature stdenv.hostPlatform.isLinux "sysfsgpio") (lib.enableFeature isWindows "internal-jimtcl") (lib.enableFeature isWindows "internal-libjaylink") - ] ++ - map (hardware: "--enable-${hardware}") extraHardwareSupport - ; + ] ++ map (hardware: "--enable-${hardware}") extraHardwareSupport; enableParallelBuilding = true; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isGNU [ - "-Wno-error=cpp" - "-Wno-error=strict-prototypes" # fixes build failure with hidapi 0.10.0 - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isGNU [ + "-Wno-error=cpp" + "-Wno-error=strict-prototypes" # fixes build failure with hidapi 0.10.0 + ] + ); postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' mkdir -p "$out/etc/udev/rules.d" @@ -80,7 +92,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://openocd.sourceforge.net/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ bjornfor prusnak ]; + maintainers = with maintainers; [ + bjornfor + prusnak + ]; platforms = platforms.unix ++ platforms.windows; }; } diff --git a/pkgs/by-name/op/openorienteering-mapper/package.nix b/pkgs/by-name/op/openorienteering-mapper/package.nix index 5d9fb8e256cdd8..b4a1fe22911d3f 100644 --- a/pkgs/by-name/op/openorienteering-mapper/package.nix +++ b/pkgs/by-name/op/openorienteering-mapper/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, clipper -, cmake -, cups -, doxygen -, gdal -, ninja -, proj -, qt5 -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + clipper, + cmake, + cups, + doxygen, + gdal, + ninja, + proj, + qt5, + zlib, }: stdenv.mkDerivation rec { @@ -58,36 +59,43 @@ stdenv.mkDerivation rec { zlib ]; - cmakeFlags = [ - # Building the manual and bundling licenses fails - # See https://github.com/NixOS/nixpkgs/issues/85306 - (lib.cmakeBool "LICENSING_PROVIDER" false) - (lib.cmakeBool "Mapper_MANUAL_QTHELP" false) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # FindGDAL is broken and always finds /Library/Framework unless this is - # specified - (lib.cmakeFeature "GDAL_INCLUDE_DIR" "${gdal}/include") - (lib.cmakeFeature "GDAL_CONFIG" "${gdal}/bin/gdal-config") - (lib.cmakeFeature "GDAL_LIBRARY" "${gdal}/lib/libgdal.dylib") - # Don't bundle libraries - (lib.cmakeBool "Mapper_PACKAGE_PROJ" false) - (lib.cmakeBool "Mapper_PACKAGE_QT" false) - (lib.cmakeBool "Mapper_PACKAGE_ASSISTANT" false) - (lib.cmakeBool "Mapper_PACKAGE_GDAL" false) - ]; + cmakeFlags = + [ + # Building the manual and bundling licenses fails + # See https://github.com/NixOS/nixpkgs/issues/85306 + (lib.cmakeBool "LICENSING_PROVIDER" false) + (lib.cmakeBool "Mapper_MANUAL_QTHELP" false) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # FindGDAL is broken and always finds /Library/Framework unless this is + # specified + (lib.cmakeFeature "GDAL_INCLUDE_DIR" "${gdal}/include") + (lib.cmakeFeature "GDAL_CONFIG" "${gdal}/bin/gdal-config") + (lib.cmakeFeature "GDAL_LIBRARY" "${gdal}/lib/libgdal.dylib") + # Don't bundle libraries + (lib.cmakeBool "Mapper_PACKAGE_PROJ" false) + (lib.cmakeBool "Mapper_PACKAGE_QT" false) + (lib.cmakeBool "Mapper_PACKAGE_ASSISTANT" false) + (lib.cmakeBool "Mapper_PACKAGE_GDAL" false) + ]; - postInstall = with stdenv; lib.optionalString isDarwin '' - mkdir -p $out/{Applications,bin} - mv $out/Mapper.app $out/Applications - ln -s $out/Applications/Mapper.app/Contents/MacOS/Mapper $out/bin/Mapper - ''; + postInstall = + with stdenv; + lib.optionalString isDarwin '' + mkdir -p $out/{Applications,bin} + mv $out/Mapper.app $out/Applications + ln -s $out/Applications/Mapper.app/Contents/MacOS/Mapper $out/bin/Mapper + ''; meta = with lib; { homepage = "https://www.openorienteering.org/apps/mapper/"; description = "Orienteering mapmaking program"; changelog = "https://github.com/OpenOrienteering/mapper/releases/tag/v${version}"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ mpickering sikmir ]; + maintainers = with maintainers; [ + mpickering + sikmir + ]; platforms = with platforms; unix; mainProgram = "Mapper"; }; diff --git a/pkgs/by-name/op/openpa/package.nix b/pkgs/by-name/op/openpa/package.nix index 23f025e2aa63bb..bc0c037fb666d3 100644 --- a/pkgs/by-name/op/openpa/package.nix +++ b/pkgs/by-name/op/openpa/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, file }: +{ + lib, + stdenv, + fetchurl, + file, +}: stdenv.mkDerivation rec { pname = "openpa"; @@ -29,5 +34,5 @@ stdenv.mkDerivation rec { learning new assembly dialects in order improve or maintain application portability. ''; - }; + }; } diff --git a/pkgs/by-name/op/openpam/package.nix b/pkgs/by-name/op/openpam/package.nix index f0e823780a4a81..fa68439a5630e9 100644 --- a/pkgs/by-name/op/openpam/package.nix +++ b/pkgs/by-name/op/openpam/package.nix @@ -17,7 +17,10 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; __structuredAttrs = true; diff --git a/pkgs/by-name/op/openpgl/package.nix b/pkgs/by-name/op/openpgl/package.nix index 556d9170df491c..2e8fcfe7e882e7 100644 --- a/pkgs/by-name/op/openpgl/package.nix +++ b/pkgs/by-name/op/openpgl/package.nix @@ -1,9 +1,10 @@ -{ lib -, cmake -, fetchFromGitHub -, ninja -, stdenv -, tbb +{ + lib, + cmake, + fetchFromGitHub, + ninja, + stdenv, + tbb, }: stdenv.mkDerivation (finalAttrs: { @@ -31,7 +32,9 @@ stdenv.mkDerivation (finalAttrs: { "-DTBB_ROOT=${tbb.out}" ]; - env.NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.hostPlatform.isAarch64 && !stdenv.hostPlatform.isDarwin) "-flax-vector-conversions"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.hostPlatform.isAarch64 && !stdenv.hostPlatform.isDarwin + ) "-flax-vector-conversions"; meta = { description = "Intel Open Path Guiding Library"; diff --git a/pkgs/by-name/op/openpgp-ca/package.nix b/pkgs/by-name/op/openpgp-ca/package.nix index e2397c5413dbda..46c07f2be79b5b 100644 --- a/pkgs/by-name/op/openpgp-ca/package.nix +++ b/pkgs/by-name/op/openpgp-ca/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, fetchFromGitLab -, lib -, darwin -, nettle -, nix-update-script -, rustPlatform -, pkg-config -, pcsclite -, openssl -, gnupg -, sqlite +{ + stdenv, + fetchFromGitLab, + lib, + darwin, + nettle, + nix-update-script, + rustPlatform, + pkg-config, + pcsclite, + openssl, + gnupg, + sqlite, }: rustPlatform.buildRustPackage rec { @@ -34,12 +35,21 @@ rustPlatform.buildRustPackage rec { gnupg ]; - buildInputs = [ - openssl - sqlite - pcsclite - nettle - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ PCSC Security SystemConfiguration ]); + buildInputs = + [ + openssl + sqlite + pcsclite + nettle + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + PCSC + Security + SystemConfiguration + ] + ); # Most tests rely on gnupg being able to write to /run/user # gnupg refuses to respect the XDG_RUNTIME_DIR variable, so we skip the tests diff --git a/pkgs/by-name/op/openpgp-card-tools/package.nix b/pkgs/by-name/op/openpgp-card-tools/package.nix index f58d31470029d8..331b787bb2fd7f 100644 --- a/pkgs/by-name/op/openpgp-card-tools/package.nix +++ b/pkgs/by-name/op/openpgp-card-tools/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitea -, installShellFiles -, pkg-config -, pcsclite -, dbus -, testers -, openpgp-card-tools +{ + lib, + stdenv, + rustPlatform, + fetchFromGitea, + installShellFiles, + pkg-config, + pcsclite, + dbus, + testers, + openpgp-card-tools, }: rustPlatform.buildRustPackage rec { @@ -24,9 +25,16 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-G5+lVK41hbzy/Ltc0EKoUfqF0M1OYu679jyVjYKJmn0="; - nativeBuildInputs = [ installShellFiles pkg-config rustPlatform.bindgenHook ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + rustPlatform.bindgenHook + ]; - buildInputs = [ pcsclite dbus ]; + buildInputs = [ + pcsclite + dbus + ]; passthru = { tests.version = testers.testVersion { @@ -44,7 +52,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Tool for inspecting and configuring OpenPGP cards"; homepage = "https://codeberg.org/openpgp-card/openpgp-card-tools"; - license = with licenses ;[ asl20 /* OR */ mit ]; + license = with licenses; [ + asl20 # OR + mit + ]; maintainers = with maintainers; [ nickcao ]; mainProgram = "oct"; }; diff --git a/pkgs/by-name/op/openpomodoro-cli/package.nix b/pkgs/by-name/op/openpomodoro-cli/package.nix index e977bbcfba5675..1ae51d6ecafb87 100644 --- a/pkgs/by-name/op/openpomodoro-cli/package.nix +++ b/pkgs/by-name/op/openpomodoro-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/op/openrct2/package.nix b/pkgs/by-name/op/openrct2/package.nix index 35699d4927779a..025b8018d2305c 100644 --- a/pkgs/by-name/op/openrct2/package.nix +++ b/pkgs/by-name/op/openrct2/package.nix @@ -1,31 +1,32 @@ -{ lib -, stdenv -, fetchFromGitHub - -, SDL2 -, cmake -, curl -, discord-rpc -, duktape -, expat -, flac -, fontconfig -, freetype -, gbenchmark -, icu -, jansson -, libGLU -, libiconv -, libogg -, libpng -, libpthreadstubs -, libvorbis -, libzip -, nlohmann_json -, openssl -, pkg-config -, speexdsp -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + + SDL2, + cmake, + curl, + discord-rpc, + duktape, + expat, + flac, + fontconfig, + freetype, + gbenchmark, + icu, + jansson, + libGLU, + libiconv, + libogg, + libpng, + libpthreadstubs, + libvorbis, + libzip, + nlohmann_json, + openssl, + pkg-config, + speexdsp, + zlib, }: let @@ -132,16 +133,18 @@ stdenv.mkDerivation { preConfigure = # Verify that the correct version of each third party repository is used. - (let - versionCheck = cmakeKey: version: '' - grep -q '^set(${cmakeKey}_VERSION "${version}")$' CMakeLists.txt \ - || (echo "${cmakeKey} differs from expected version!"; exit 1) - ''; - in - (versionCheck "OBJECTS" objects-version) + - (versionCheck "OPENMSX" openmsx-version) + - (versionCheck "OPENSFX" opensfx-version) + - (versionCheck "TITLE_SEQUENCE" title-sequences-version)); + ( + let + versionCheck = cmakeKey: version: '' + grep -q '^set(${cmakeKey}_VERSION "${version}")$' CMakeLists.txt \ + || (echo "${cmakeKey} differs from expected version!"; exit 1) + ''; + in + (versionCheck "OBJECTS" objects-version) + + (versionCheck "OPENMSX" openmsx-version) + + (versionCheck "OPENSFX" opensfx-version) + + (versionCheck "TITLE_SEQUENCE" title-sequences-version) + ); preFixup = "ln -s $out/share/openrct2 $out/bin/data"; diff --git a/pkgs/by-name/op/openresolv/package.nix b/pkgs/by-name/op/openresolv/package.nix index a8fc33df2fccd1..62572f5f44f9ee 100644 --- a/pkgs/by-name/op/openresolv/package.nix +++ b/pkgs/by-name/op/openresolv/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, coreutils }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + coreutils, +}: stdenv.mkDerivation rec { pname = "openresolv"; @@ -13,18 +19,17 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; - configurePhase = - '' - cat > config.mk < config.mk < unixODBC != null; @@ -18,79 +19,97 @@ let throwSystem = throw "Unsupported system: ${stdenv.hostPlatform.system}"; # assemble list of components - components = [ "basic" "sdk" "sqlplus" "tools" ] ++ optional odbcSupport "odbc"; + components = [ + "basic" + "sdk" + "sqlplus" + "tools" + ] ++ optional odbcSupport "odbc"; # determine the version number, there might be different ones per architecture - version = { - x86_64-linux = "21.10.0.0.0"; - aarch64-linux = "19.10.0.0.0"; - x86_64-darwin = "19.8.0.0.0"; - }.${stdenv.hostPlatform.system} or throwSystem; - - directory = { - x86_64-linux = "2110000"; - aarch64-linux = "191000"; - x86_64-darwin = "198000"; - }.${stdenv.hostPlatform.system} or throwSystem; + version = + { + x86_64-linux = "21.10.0.0.0"; + aarch64-linux = "19.10.0.0.0"; + x86_64-darwin = "19.8.0.0.0"; + } + .${stdenv.hostPlatform.system} or throwSystem; + + directory = + { + x86_64-linux = "2110000"; + aarch64-linux = "191000"; + x86_64-darwin = "198000"; + } + .${stdenv.hostPlatform.system} or throwSystem; # hashes per component and architecture - hashes = { - x86_64-linux = { - basic = "sha256-uo0QBOmx7TQyroD+As60IhjEkz//+0Cm1tWvLI3edaE="; - sdk = "sha256-TIBFi1jHLJh+SUNFvuL7aJpxh61hG6gXhFIhvdPgpts="; - sqlplus = "sha256-mF9kLjhZXe/fasYDfmZrYPL2CzAp3xDbi624RJDA4lM="; - tools = "sha256-ay8ynzo1fPHbCg9GoIT5ja//iZPIZA2yXI/auVExiRY="; - odbc = "sha256-3M6/cEtUrIFzQay8eHNiLGE+L0UF+VTmzp4cSBcrzlk="; - }; - aarch64-linux = { - basic = "sha256-DNntH20BAmo5kOz7uEgW2NXaNfwdvJ8l8oMnp50BOsY="; - sdk = "sha256-8VpkNyLyFMUfQwbZpSDV/CB95RoXfaMr8w58cRt/syw="; - sqlplus = "sha256-iHcyijHhAvjsAqN9R+Rxo2R47k940VvPbScc2MWYn0Q="; - tools = "sha256-4QY0EwcnctwPm6ZGDZLudOFM4UycLFmRIluKGXVwR0M="; - odbc = "sha256-T+RIIKzZ9xEg/E72pfs5xqHz2WuIWKx/oRfDrQbw3ms="; - }; - x86_64-darwin = { - basic = "sha256-V+1BmPOhDYPNXdwkcsBY1MOwt4Yka66/a7/HORzBIIc="; - sdk = "sha256-D6iuTEQYqmbOh1z5LnKN16ga6vLmjnkm4QK15S/Iukw="; - sqlplus = "sha256-08uoiwoKPZmTxLZLYRVp0UbN827FXdhOukeDUXvTCVk="; - tools = "sha256-1xFFGZapFq9ogGQ6ePSv4PrXl5qOAgRZWAp4mJ5uxdU="; - odbc = "sha256-S6+5P4daK/+nXwoHmOkj4DIkHtwdzO5GOkCCI612bRY="; - }; - }.${stdenv.hostPlatform.system} or throwSystem; + hashes = + { + x86_64-linux = { + basic = "sha256-uo0QBOmx7TQyroD+As60IhjEkz//+0Cm1tWvLI3edaE="; + sdk = "sha256-TIBFi1jHLJh+SUNFvuL7aJpxh61hG6gXhFIhvdPgpts="; + sqlplus = "sha256-mF9kLjhZXe/fasYDfmZrYPL2CzAp3xDbi624RJDA4lM="; + tools = "sha256-ay8ynzo1fPHbCg9GoIT5ja//iZPIZA2yXI/auVExiRY="; + odbc = "sha256-3M6/cEtUrIFzQay8eHNiLGE+L0UF+VTmzp4cSBcrzlk="; + }; + aarch64-linux = { + basic = "sha256-DNntH20BAmo5kOz7uEgW2NXaNfwdvJ8l8oMnp50BOsY="; + sdk = "sha256-8VpkNyLyFMUfQwbZpSDV/CB95RoXfaMr8w58cRt/syw="; + sqlplus = "sha256-iHcyijHhAvjsAqN9R+Rxo2R47k940VvPbScc2MWYn0Q="; + tools = "sha256-4QY0EwcnctwPm6ZGDZLudOFM4UycLFmRIluKGXVwR0M="; + odbc = "sha256-T+RIIKzZ9xEg/E72pfs5xqHz2WuIWKx/oRfDrQbw3ms="; + }; + x86_64-darwin = { + basic = "sha256-V+1BmPOhDYPNXdwkcsBY1MOwt4Yka66/a7/HORzBIIc="; + sdk = "sha256-D6iuTEQYqmbOh1z5LnKN16ga6vLmjnkm4QK15S/Iukw="; + sqlplus = "sha256-08uoiwoKPZmTxLZLYRVp0UbN827FXdhOukeDUXvTCVk="; + tools = "sha256-1xFFGZapFq9ogGQ6ePSv4PrXl5qOAgRZWAp4mJ5uxdU="; + odbc = "sha256-S6+5P4daK/+nXwoHmOkj4DIkHtwdzO5GOkCCI612bRY="; + }; + } + .${stdenv.hostPlatform.system} or throwSystem; # rels per component and architecture, optional rels = { }.${stdenv.hostPlatform.system} or { }; # convert platform to oracle architecture names - arch = { - x86_64-linux = "linux.x64"; - aarch64-linux = "linux.arm64"; - x86_64-darwin = "macos.x64"; - }.${stdenv.hostPlatform.system} or throwSystem; - - shortArch = { - x86_64-linux = "linux"; - aarch64-linux = "linux"; - x86_64-darwin = "mac"; - }.${stdenv.hostPlatform.system} or throwSystem; + arch = + { + x86_64-linux = "linux.x64"; + aarch64-linux = "linux.arm64"; + x86_64-darwin = "macos.x64"; + } + .${stdenv.hostPlatform.system} or throwSystem; + + shortArch = + { + x86_64-linux = "linux"; + aarch64-linux = "linux"; + x86_64-darwin = "mac"; + } + .${stdenv.hostPlatform.system} or throwSystem; # calculate the filename of a single zip file - srcFilename = component: arch: version: rel: - "instantclient-${component}-${arch}-${version}" + - (optionalString (rel != "") "-${rel}") + - "dbru.zip"; # ¯\_(ツ)_/¯ + srcFilename = + component: arch: version: rel: + "instantclient-${component}-${arch}-${version}" + + (optionalString (rel != "") "-${rel}") + + "dbru.zip"; # ¯\_(ツ)_/¯ # fetcher for the non clickthrough artifacts - fetcher = srcFilename: hash: fetchurl { - url = "https://download.oracle.com/otn_software/${shortArch}/instantclient/${directory}/${srcFilename}"; - sha256 = hash; - }; + fetcher = + srcFilename: hash: + fetchurl { + url = "https://download.oracle.com/otn_software/${shortArch}/instantclient/${directory}/${srcFilename}"; + sha256 = hash; + }; # assemble srcs - srcs = map - (component: - (fetcher (srcFilename component arch version rels.${component} or "") hashes.${component} or "")) - components; + srcs = map ( + component: + (fetcher (srcFilename component arch version rels.${component} or "") hashes.${component} or "") + ) components; pname = "oracle-instantclient"; extLib = stdenv.hostPlatform.extensions.sharedLibrary; @@ -98,15 +117,24 @@ in stdenv.mkDerivation { inherit pname version srcs; - buildInputs = [ (lib.getLib stdenv.cc.cc) ] + buildInputs = + [ (lib.getLib stdenv.cc.cc) ] ++ optional stdenv.hostPlatform.isLinux libaio ++ optional odbcSupport unixODBC; - nativeBuildInputs = [ makeWrapper unzip ] + nativeBuildInputs = + [ + makeWrapper + unzip + ] ++ optional stdenv.hostPlatform.isLinux autoPatchelfHook ++ optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; unpackCmd = "unzip $curSrc"; @@ -142,7 +170,11 @@ stdenv.mkDerivation { ''; sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.unfree; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + ]; maintainers = with maintainers; [ dylanmtaylor ]; hydraPlatforms = [ ]; }; diff --git a/pkgs/by-name/or/oranchelo-icon-theme/package.nix b/pkgs/by-name/or/oranchelo-icon-theme/package.nix index b676b5956c7335..1e52cf5543c2b7 100644 --- a/pkgs/by-name/or/oranchelo-icon-theme/package.nix +++ b/pkgs/by-name/or/oranchelo-icon-theme/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenvNoCC, fetchFromGitHub, gtk3, plasma5Packages, hicolor-icon-theme }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + plasma5Packages, + hicolor-icon-theme, +}: stdenvNoCC.mkDerivation rec { pname = "oranchelo-icon-theme"; diff --git a/pkgs/by-name/or/oranda/package.nix b/pkgs/by-name/or/oranda/package.nix index 0c5e55efe0eff9..1e920f19fcce95 100644 --- a/pkgs/by-name/or/oranda/package.nix +++ b/pkgs/by-name/or/oranda/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, tailwindcss -, oniguruma -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + tailwindcss, + oniguruma, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -26,12 +27,14 @@ rustPlatform.buildRustPackage rec { tailwindcss ]; - buildInputs = [ - oniguruma - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreServices - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + oniguruma + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreServices + darwin.apple_sdk.frameworks.SystemConfiguration + ]; # requires internet access checkFlags = [ @@ -39,19 +42,24 @@ rustPlatform.buildRustPackage rec { "--skip=integration" ]; - env = { - RUSTONIG_SYSTEM_LIBONIG = true; - ORANDA_USE_TAILWIND_BINARY = true; - } // lib.optionalAttrs stdenv.hostPlatform.isDarwin { - # without this, tailwindcss fails with OpenSSL configuration error - OPENSSL_CONF = ""; - }; + env = + { + RUSTONIG_SYSTEM_LIBONIG = true; + ORANDA_USE_TAILWIND_BINARY = true; + } + // lib.optionalAttrs stdenv.hostPlatform.isDarwin { + # without this, tailwindcss fails with OpenSSL configuration error + OPENSSL_CONF = ""; + }; meta = with lib; { description = "Generate beautiful landing pages for your developer tools"; homepage = "https://github.com/axodotdev/oranda"; changelog = "https://github.com/axodotdev/oranda/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "oranda"; }; diff --git a/pkgs/by-name/or/oras/package.nix b/pkgs/by-name/or/oras/package.nix index eb9279d845ea46..28c71f2a0f00a5 100644 --- a/pkgs/by-name/or/oras/package.nix +++ b/pkgs/by-name/or/oras/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, testers, oras }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + oras, +}: buildGoModule rec { pname = "oras"; @@ -53,6 +60,9 @@ buildGoModule rec { description = "ORAS project provides a way to push and pull OCI Artifacts to and from OCI Registries"; mainProgram = "oras"; license = licenses.asl20; - maintainers = with maintainers; [ jk developer-guy ]; + maintainers = with maintainers; [ + jk + developer-guy + ]; }; } diff --git a/pkgs/by-name/or/orbiton/package.nix b/pkgs/by-name/or/orbiton/package.nix index 9bf7ec4b1d5e59..31343b74a76590 100644 --- a/pkgs/by-name/or/orbiton/package.nix +++ b/pkgs/by-name/or/orbiton/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, installShellFiles, makeWrapper, pkg-config -, withGui ? true, vte +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, + makeWrapper, + pkg-config, + withGui ? true, + vte, }: buildGoModule rec { @@ -15,7 +23,11 @@ buildGoModule rec { vendorHash = null; - nativeBuildInputs = [ installShellFiles makeWrapper pkg-config ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + pkg-config + ]; buildInputs = lib.optional withGui vte; @@ -25,14 +37,16 @@ buildGoModule rec { "-skip=TestPBcopy" # Requires impure pbcopy and pbpaste ]; - postInstall = '' - cd .. - installManPage o.1 - mv $out/bin/{orbiton,o} - '' + lib.optionalString withGui '' - make install-gui PREFIX=$out - wrapProgram $out/bin/og --prefix PATH : $out/bin - ''; + postInstall = + '' + cd .. + installManPage o.1 + mv $out/bin/{orbiton,o} + '' + + lib.optionalString withGui '' + make install-gui PREFIX=$out + wrapProgram $out/bin/og --prefix PATH : $out/bin + ''; meta = with lib; { description = "Config-free text editor and IDE limited to VT100"; diff --git a/pkgs/by-name/or/orbitron/package.nix b/pkgs/by-name/or/orbitron/package.nix index ca9cc750437d50..8adca1d63a3336 100644 --- a/pkgs/by-name/or/orbitron/package.nix +++ b/pkgs/by-name/or/orbitron/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "orbitron"; @@ -43,6 +47,9 @@ stdenvNoCC.mkDerivation { ''; license = licenses.ofl; platforms = platforms.all; - maintainers = with lib.maintainers; [ leenaars minijackson ]; + maintainers = with lib.maintainers; [ + leenaars + minijackson + ]; }; } diff --git a/pkgs/by-name/or/orbuculum/package.nix b/pkgs/by-name/or/orbuculum/package.nix index e6a69e22be2d05..8b20e5e78edf21 100644 --- a/pkgs/by-name/or/orbuculum/package.nix +++ b/pkgs/by-name/or/orbuculum/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, czmq -, libusb1 -, ncurses -, SDL2 +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + czmq, + libusb1, + ncurses, + SDL2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/or/orc/package.nix b/pkgs/by-name/or/orc/package.nix index 4d799b04e70258..7cc98b93f7ee84 100644 --- a/pkgs/by-name/or/orc/package.nix +++ b/pkgs/by-name/or/orc/package.nix @@ -1,22 +1,25 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, file -, docbook_xsl -, gtk-doc ? null -, buildDevDoc ? gtk-doc != null +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + file, + docbook_xsl, + gtk-doc ? null, + buildDevDoc ? gtk-doc != null, -# for passthru.tests -, gnuradio -, gst_all_1 -, qt6 -, vips + # for passthru.tests + gnuradio, + gst_all_1, + qt6, + vips, -}: let +}: +let inherit (lib) optional optionals; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "orc"; version = "0.4.40"; @@ -30,21 +33,33 @@ in stdenv.mkDerivation rec { sed -i '/memcpy_speed/d' testsuite/meson.build ''; - outputs = [ "out" "dev" ] - ++ optional buildDevDoc "devdoc" - ; + outputs = [ + "out" + "dev" + ] ++ optional buildDevDoc "devdoc"; outputBin = "dev"; # compilation tools - mesonFlags = - optionals (!buildDevDoc) [ "-Dgtk_doc=disabled" ] - ; + mesonFlags = optionals (!buildDevDoc) [ "-Dgtk_doc=disabled" ]; - nativeBuildInputs = [ meson ninja ] - ++ optionals buildDevDoc [ gtk-doc file docbook_xsl ] - ; + nativeBuildInputs = + [ + meson + ninja + ] + ++ optionals buildDevDoc [ + gtk-doc + file + docbook_xsl + ]; # https://gitlab.freedesktop.org/gstreamer/orc/-/issues/41 - doCheck = !(stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64 && stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12"); + doCheck = + !( + stdenv.hostPlatform.isLinux + && stdenv.hostPlatform.isAarch64 + && stdenv.cc.isGNU + && lib.versionAtLeast stdenv.cc.version "12" + ); passthru.tests = { inherit (gst_all_1) gst-plugins-good gst-plugins-bad gst-plugins-ugly; @@ -58,7 +73,10 @@ in stdenv.mkDerivation rec { changelog = "https://cgit.freedesktop.org/gstreamer/orc/plain/RELEASE?h=${version}"; # The source code implementing the Marsenne Twister algorithm is licensed # under the 3-clause BSD license. The rest is 2-clause BSD license. - license = with licenses; [ bsd3 bsd2 ]; + license = with licenses; [ + bsd3 + bsd2 + ]; platforms = platforms.unix; maintainers = [ ]; }; diff --git a/pkgs/by-name/or/orca-c/package.nix b/pkgs/by-name/or/orca-c/package.nix index 3dfea97ace2a75..0696a6683fed9b 100644 --- a/pkgs/by-name/or/orca-c/package.nix +++ b/pkgs/by-name/or/orca-c/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchgit, ncurses, portmidi }: +{ + lib, + stdenv, + fetchgit, + ncurses, + portmidi, +}: stdenv.mkDerivation { pname = "orca-c"; version = "unstable-2021-02-13"; @@ -9,7 +15,10 @@ stdenv.mkDerivation { sha256 = "sha256-bbIH0kyHRTcMGXV3WdBQIH1br0FyIzKKL88wqpGZ0NY="; }; - buildInputs = [ ncurses portmidi ]; + buildInputs = [ + ncurses + portmidi + ]; postPatch = '' patchShebangs tool diff --git a/pkgs/by-name/or/orca/package.nix b/pkgs/by-name/or/orca/package.nix index 04dbff20fcc63c..8d920bca4bba3e 100644 --- a/pkgs/by-name/or/orca/package.nix +++ b/pkgs/by-name/or/orca/package.nix @@ -1,29 +1,30 @@ -{ lib -, pkg-config -, fetchurl -, meson -, ninja -, wrapGAppsHook3 -, gobject-introspection -, gettext -, yelp-tools -, itstool -, python3 -, gtk3 -, gnome -, substituteAll -, at-spi2-atk -, at-spi2-core -, dbus -, xkbcomp -, procps -, lsof -, coreutils -, gsettings-desktop-schemas -, speechd-minimal -, brltty -, liblouis -, gst_all_1 +{ + lib, + pkg-config, + fetchurl, + meson, + ninja, + wrapGAppsHook3, + gobject-introspection, + gettext, + yelp-tools, + itstool, + python3, + gtk3, + gnome, + substituteAll, + at-spi2-atk, + at-spi2-core, + dbus, + xkbcomp, + procps, + lsof, + coreutils, + gsettings-desktop-schemas, + speechd-minimal, + brltty, + liblouis, + gst_all_1, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/or/orcania/package.nix b/pkgs/by-name/or/orcania/package.nix index e0e3775531df5e..ffd405972c2d29 100644 --- a/pkgs/by-name/or/orcania/package.nix +++ b/pkgs/by-name/or/orcania/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, check, subunit }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + check, + subunit, +}: stdenv.mkDerivation rec { pname = "orcania"; version = "2.3.3"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - nativeCheckInputs = [ check subunit ]; + nativeCheckInputs = [ + check + subunit + ]; cmakeFlags = [ "-DBUILD_ORCANIA_TESTING=on" ]; diff --git a/pkgs/by-name/or/orchard/package.nix b/pkgs/by-name/or/orchard/package.nix index 96299502b6aeee..9cd1a2eb37e9db 100644 --- a/pkgs/by-name/or/orchard/package.nix +++ b/pkgs/by-name/or/orchard/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, installShellFiles }: +{ + lib, + fetchFromGitHub, + buildGoModule, + installShellFiles, +}: buildGoModule rec { pname = "orchard"; @@ -46,8 +51,7 @@ buildGoModule rec { meta = with lib; { mainProgram = "orchard"; - description = - "Orchestrator for running Tart Virtual Machines on a cluster of Apple Silicon devices"; + description = "Orchestrator for running Tart Virtual Machines on a cluster of Apple Silicon devices"; homepage = "https://github.com/cirruslabs/orchard"; license = licenses.fairsource09; maintainers = with maintainers; [ techknowlogick ]; diff --git a/pkgs/by-name/or/orchis-theme/package.nix b/pkgs/by-name/or/orchis-theme/package.nix index e8524c981d3b39..fcb63679336b2f 100644 --- a/pkgs/by-name/or/orchis-theme/package.nix +++ b/pkgs/by-name/or/orchis-theme/package.nix @@ -1,67 +1,84 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gtk3 -, gnome-themes-extra -, gtk-engine-murrine -, sassc -, border-radius ? null # Suggested: 2 < value < 16 -, tweaks ? [ ] # can be "solid" "compact" "black" "primary" "macos" "submenu" "nord|dracula" -, withWallpapers ? false +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + gnome-themes-extra, + gtk-engine-murrine, + sassc, + border-radius ? null, # Suggested: 2 < value < 16 + tweaks ? [ ], # can be "solid" "compact" "black" "primary" "macos" "submenu" "nord|dracula" + withWallpapers ? false, }: let pname = "orchis-theme"; - validTweaks = [ "solid" "compact" "black" "primary" "macos" "submenu" "nord" "dracula" ]; + validTweaks = [ + "solid" + "compact" + "black" + "primary" + "macos" + "submenu" + "nord" + "dracula" + ]; - nordXorDracula = with builtins; lib.assertMsg (!(elem "nord" tweaks) || !(elem "dracula" tweaks)) '' - ${pname}: dracula and nord cannot be mixed. Tweaks ${toString tweaks} - ''; + nordXorDracula = + with builtins; + lib.assertMsg (!(elem "nord" tweaks) || !(elem "dracula" tweaks)) '' + ${pname}: dracula and nord cannot be mixed. Tweaks ${toString tweaks} + ''; in assert nordXorDracula; lib.checkListOfEnum "${pname}: theme tweaks" validTweaks tweaks -stdenvNoCC.mkDerivation -rec { - inherit pname; - version = "2024-11-03"; + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "2024-11-03"; - src = fetchFromGitHub { - repo = "Orchis-theme"; - owner = "vinceliuice"; - rev = version; - hash = "sha256-K8FiS1AiFMhVaz2Jbr0pudQJGqpwBkQ/4NZdZACtM9Q="; - }; + src = fetchFromGitHub { + repo = "Orchis-theme"; + owner = "vinceliuice"; + rev = version; + hash = "sha256-K8FiS1AiFMhVaz2Jbr0pudQJGqpwBkQ/4NZdZACtM9Q="; + }; - nativeBuildInputs = [ gtk3 sassc ]; + nativeBuildInputs = [ + gtk3 + sassc + ]; - buildInputs = [ gnome-themes-extra ]; + buildInputs = [ gnome-themes-extra ]; - propagatedUserEnvPkgs = [ gtk-engine-murrine ]; + propagatedUserEnvPkgs = [ gtk-engine-murrine ]; - preInstall = '' - mkdir -p $out/share/themes - ''; + preInstall = '' + mkdir -p $out/share/themes + ''; - installPhase = '' - runHook preInstall - bash install.sh -d $out/share/themes -t all \ - ${lib.optionalString (tweaks != []) "--tweaks " + builtins.toString tweaks} \ - ${lib.optionalString (border-radius != null) ("--round " + builtins.toString border-radius + "px")} - ${lib.optionalString withWallpapers '' - mkdir -p $out/share/backgrounds - cp src/wallpaper/{1080p,2k,4k}.jpg $out/share/backgrounds - ''} - runHook postInstall - ''; + installPhase = '' + runHook preInstall + bash install.sh -d $out/share/themes -t all \ + ${lib.optionalString (tweaks != [ ]) "--tweaks " + builtins.toString tweaks} \ + ${lib.optionalString (border-radius != null) ( + "--round " + builtins.toString border-radius + "px" + )} + ${lib.optionalString withWallpapers '' + mkdir -p $out/share/backgrounds + cp src/wallpaper/{1080p,2k,4k}.jpg $out/share/backgrounds + ''} + runHook postInstall + ''; - meta = with lib; { - description = "Material Design theme for GNOME/GTK based desktop environments"; - homepage = "https://github.com/vinceliuice/Orchis-theme"; - license = licenses.gpl3Plus; - platforms = platforms.linux; - maintainers = [ maintainers.fufexan ]; - }; -} + meta = with lib; { + description = "Material Design theme for GNOME/GTK based desktop environments"; + homepage = "https://github.com/vinceliuice/Orchis-theme"; + license = licenses.gpl3Plus; + platforms = platforms.linux; + maintainers = [ maintainers.fufexan ]; + }; + } diff --git a/pkgs/by-name/or/ord/package.nix b/pkgs/by-name/or/ord/package.nix index 0bb6ac0abe4d27..4beccb98936a5e 100644 --- a/pkgs/by-name/or/ord/package.nix +++ b/pkgs/by-name/or/ord/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -24,12 +25,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; dontUseCargoParallelTests = true; diff --git a/pkgs/by-name/or/oreo-cursors-plus/package.nix b/pkgs/by-name/or/oreo-cursors-plus/package.nix index d998718ad085cb..14dc1dd73c0465 100644 --- a/pkgs/by-name/or/oreo-cursors-plus/package.nix +++ b/pkgs/by-name/or/oreo-cursors-plus/package.nix @@ -23,7 +23,11 @@ stdenvNoCC.mkDerivation { hash = "sha256-6oTyOQK7mkr+jWYbPNBlJ4BpT815lNJvsJjzdTmj+68="; }; - nativeBuildInputs = lib.optionals (cursorsConf != null) [ ruby inkscape xorg.xcursorgen ]; + nativeBuildInputs = lib.optionals (cursorsConf != null) [ + ruby + inkscape + xorg.xcursorgen + ]; # './cursors.conf' contains definitions of cursor variations to generate. configurePhase = '' @@ -38,33 +42,33 @@ stdenvNoCC.mkDerivation { # The repo already contains the default cursors pre-generated in './dist'. Just copy these if './cursors.conf' is not overwritten. # Otherwise firs remove all default variations and build. - buildPhase ='' - runHook preBuild + buildPhase = '' + runHook preBuild - ${lib.optionalString (cursorsConf != null) '' - rm -r {dist,src/oreo_*} - export HOME=$TMP - ruby generator/convert.rb - make build - ''} + ${lib.optionalString (cursorsConf != null) '' + rm -r {dist,src/oreo_*} + export HOME=$TMP + ruby generator/convert.rb + make build + ''} - runHook postBuild - ''; + runHook postBuild + ''; installPhase = '' - runHook preInstall + runHook preInstall - mkdir -p $out/share - mv ./dist $out/share/icons + mkdir -p $out/share + mv ./dist $out/share/icons - runHook postInstall - ''; + runHook postInstall + ''; meta = { description = "Colored Material cursors with cute animations"; homepage = "https://github.com/Souravgoswami/oreo-cursors"; license = lib.licenses.gpl2Only; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [michaelBrunner]; + maintainers = with lib.maintainers; [ michaelBrunner ]; }; } diff --git a/pkgs/by-name/or/org-stats/package.nix b/pkgs/by-name/or/org-stats/package.nix index 211a1bded75c84..f5699e2728d30f 100644 --- a/pkgs/by-name/or/org-stats/package.nix +++ b/pkgs/by-name/or/org-stats/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, substituteAll -, installShellFiles -, testers -, org-stats +{ + lib, + buildGoModule, + fetchFromGitHub, + substituteAll, + installShellFiles, + testers, + org-stats, }: buildGoModule rec { @@ -33,7 +34,10 @@ buildGoModule rec { installShellFiles ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' $out/bin/org-stats man > org-stats.1 diff --git a/pkgs/by-name/or/orion/package.nix b/pkgs/by-name/or/orion/package.nix index 93ea3633fb5aa1..851ea346b81cd9 100644 --- a/pkgs/by-name/or/orion/package.nix +++ b/pkgs/by-name/or/orion/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchFromGitHub, + gtk-engine-murrine, +}: stdenv.mkDerivation rec { pname = "orion"; diff --git a/pkgs/by-name/or/orjail/package.nix b/pkgs/by-name/or/orjail/package.nix index ed2d64588306a8..d7c2fa0e563dc4 100644 --- a/pkgs/by-name/or/orjail/package.nix +++ b/pkgs/by-name/or/orjail/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, tor -, firejail -, iptables -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + tor, + firejail, + iptables, + makeWrapper, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/or/orocos-kdl/package.nix b/pkgs/by-name/or/orocos-kdl/package.nix index 05a3cefaecebb8..304f1c7de443cb 100644 --- a/pkgs/by-name/or/orocos-kdl/package.nix +++ b/pkgs/by-name/or/orocos-kdl/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, eigen }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + eigen, +}: stdenv.mkDerivation rec { pname = "orocos-kdl"; diff --git a/pkgs/by-name/or/orogene/package.nix b/pkgs/by-name/or/orogene/package.nix index 0f772eac7dfc94..a5ac15d26a2b27 100644 --- a/pkgs/by-name/or/orogene/package.nix +++ b/pkgs/by-name/or/orogene/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -25,11 +26,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; preCheck = '' export CI=true @@ -40,7 +43,10 @@ rustPlatform.buildRustPackage rec { description = "Package manager for tools that use node_modules"; homepage = "https://github.com/orogene/orogene"; changelog = "https://github.com/orogene/orogene/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 isc ]; + license = with licenses; [ + asl20 + isc + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "oro"; }; diff --git a/pkgs/by-name/or/ortp/package.nix b/pkgs/by-name/or/ortp/package.nix index 9940ec12ab70dd..3f5ea02d5e1f0a 100644 --- a/pkgs/by-name/or/ortp/package.nix +++ b/pkgs/by-name/or/ortp/package.nix @@ -1,8 +1,9 @@ -{ bctoolbox -, cmake -, fetchFromGitLab -, lib -, stdenv +{ + bctoolbox, + cmake, + fetchFromGitLab, + lib, + stdenv, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/or/orz/package.nix b/pkgs/by-name/or/orz/package.nix index 1520a76365dabb..6acd6736266dc4 100644 --- a/pkgs/by-name/or/orz/package.nix +++ b/pkgs/by-name/or/orz/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, rust-cbindgen +{ + lib, + rustPlatform, + fetchFromGitHub, + rust-cbindgen, }: rustPlatform.buildRustPackage rec { @@ -17,7 +18,11 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-aUsRbIajBP6esjW7Wj7mqIkbYUCbZ2GgxjRXMPTnHYg="; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; nativeBuildInputs = [ rust-cbindgen diff --git a/pkgs/by-name/os/os-prober/package.nix b/pkgs/by-name/os/os-prober/package.nix index cfe673bd58f6fb..64e5171dc0a944 100644 --- a/pkgs/by-name/os/os-prober/package.nix +++ b/pkgs/by-name/os/os-prober/package.nix @@ -1,13 +1,18 @@ -{ lib, stdenv, fetchFromGitLab, makeWrapper, nixosTests, -# optional dependencies, the command(s) they provide -coreutils, # mktemp -grub2, # grub-mount and grub-probe -cryptsetup, # cryptsetup -libuuid, # blkid and blockdev -systemd, # udevadm -ntfs3g, # ntfs3g -dmraid, # dmraid -lvm2 # lvs +{ + lib, + stdenv, + fetchFromGitLab, + makeWrapper, + nixosTests, + # optional dependencies, the command(s) they provide + coreutils, # mktemp + grub2, # grub-mount and grub-probe + cryptsetup, # cryptsetup + libuuid, # blkid and blockdev + systemd, # udevadm + ntfs3g, # ntfs3g + dmraid, # dmraid + lvm2, # lvs }: stdenv.mkDerivation rec { @@ -56,7 +61,18 @@ stdenv.mkDerivation rec { done; for file in $out/bin/*; do wrapProgram $file \ - --suffix PATH : ${lib.makeBinPath [ grub2 systemd coreutils cryptsetup libuuid ntfs3g lvm2 dmraid ]} \ + --suffix PATH : ${ + lib.makeBinPath [ + grub2 + systemd + coreutils + cryptsetup + libuuid + ntfs3g + lvm2 + dmraid + ] + } \ --run "[ -d /var/lib/os-prober ] || mkdir /var/lib/os-prober" done; ''; diff --git a/pkgs/by-name/os/osc-cli/package.nix b/pkgs/by-name/os/osc-cli/package.nix index 0af589f1e884ee..3a024b86657c1d 100644 --- a/pkgs/by-name/os/osc-cli/package.nix +++ b/pkgs/by-name/os/osc-cli/package.nix @@ -1,7 +1,7 @@ { - lib - , python3 - , fetchFromGitHub + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/os/oscclip/package.nix b/pkgs/by-name/os/oscclip/package.nix index 2b4e6aa7d1f7a6..349079d353292d 100644 --- a/pkgs/by-name/os/oscclip/package.nix +++ b/pkgs/by-name/os/oscclip/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { @@ -27,6 +28,9 @@ python3Packages.buildPythonApplication rec { homepage = "https://github.com/rumpelsepp/oscclip"; license = licenses.gpl3Only; - maintainers = with maintainers; [ rumpelsepp traxys ]; + maintainers = with maintainers; [ + rumpelsepp + traxys + ]; }; } diff --git a/pkgs/by-name/os/osdlyrics/package.nix b/pkgs/by-name/os/osdlyrics/package.nix index d0f12a59125dab..d470003be7510f 100644 --- a/pkgs/by-name/os/osdlyrics/package.nix +++ b/pkgs/by-name/os/osdlyrics/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, -, autoreconfHook -, pkg-config -, intltool + autoreconfHook, + pkg-config, + intltool, -, glib -, gtk2 -, dbus-glib -, libappindicator-gtk2 -, libnotify -, python3 -, runtimeShell + glib, + gtk2, + dbus-glib, + libappindicator-gtk2, + libnotify, + python3, + runtimeShell, }: stdenv.mkDerivation rec { @@ -39,12 +40,14 @@ stdenv.mkDerivation rec { libappindicator-gtk2 libnotify python3.pkgs.wrapPython - (python3.withPackages (pp: with pp; [ - chardet - dbus-python - pycurl - pygobject3 - ])) + (python3.withPackages ( + pp: with pp; [ + chardet + dbus-python + pycurl + pygobject3 + ] + )) ]; postFixup = '' diff --git a/pkgs/by-name/os/oshka/package.nix b/pkgs/by-name/os/oshka/package.nix index 0161382491cf1e..4727b3ab1e1e3f 100644 --- a/pkgs/by-name/os/oshka/package.nix +++ b/pkgs/by-name/os/oshka/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/os/osi/package.nix b/pkgs/by-name/os/osi/package.nix index cb83b2141819e1..98b73755866b6c 100644 --- a/pkgs/by-name/os/osi/package.nix +++ b/pkgs/by-name/os/osi/package.nix @@ -1,7 +1,18 @@ -{ stdenv, lib, fetchFromGitHub, gfortran, pkg-config -, blas, zlib, bzip2, coin-utils -, withGurobi ? false, gurobi -, withCplex ? false, cplex }: +{ + stdenv, + lib, + fetchFromGitHub, + gfortran, + pkg-config, + blas, + zlib, + bzip2, + coin-utils, + withGurobi ? false, + gurobi, + withCplex ? false, + cplex, +}: stdenv.mkDerivation rec { pname = "osi"; @@ -15,16 +26,29 @@ stdenv.mkDerivation rec { }; buildInputs = - [ blas zlib bzip2 coin-utils ] + [ + blas + zlib + bzip2 + coin-utils + ] ++ lib.optional withGurobi gurobi ++ lib.optional withCplex cplex; - nativeBuildInputs = [ gfortran pkg-config ]; + nativeBuildInputs = [ + gfortran + pkg-config + ]; configureFlags = - lib.optionals withGurobi [ "--with-gurobi-incdir=${gurobi}/include" "--with-gurobi-lib=-lgurobi${gurobi.libSuffix}" ] - ++ lib.optionals withCplex [ "--with-cplex-incdir=${cplex}/cplex/include/ilcplex" "--with-cplex-lib=-lcplex${cplex.libSuffix}" ]; + lib.optionals withGurobi [ + "--with-gurobi-incdir=${gurobi}/include" + "--with-gurobi-lib=-lgurobi${gurobi.libSuffix}" + ] + ++ lib.optionals withCplex [ + "--with-cplex-incdir=${cplex}/cplex/include/ilcplex" + "--with-cplex-lib=-lcplex${cplex.libSuffix}" + ]; - NIX_LDFLAGS = - lib.optionalString withCplex "-L${cplex}/cplex/bin/${cplex.libArch}"; + NIX_LDFLAGS = lib.optionalString withCplex "-L${cplex}/cplex/bin/${cplex.libArch}"; # Compile errors env.NIX_CFLAGS_COMPILE = "-Wno-cast-qual"; diff --git a/pkgs/by-name/os/osinfo-db-tools/package.nix b/pkgs/by-name/os/osinfo-db-tools/package.nix index 55abe8e3565760..e89c7416888e86 100644 --- a/pkgs/by-name/os/osinfo-db-tools/package.nix +++ b/pkgs/by-name/os/osinfo-db-tools/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, pkg-config -, meson -, ninja -, gettext -, glib -, libxml2 -, perl -, python3 -, libxslt -, libarchive -, bzip2 -, xz -, json-glib -, libsoup_3 +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + meson, + ninja, + gettext, + glib, + libxml2, + perl, + python3, + libxslt, + libarchive, + bzip2, + xz, + json-glib, + libsoup_3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/os/osinfo-db/package.nix b/pkgs/by-name/os/osinfo-db/package.nix index bfd8f589f9e3d7..7cc5215cd40044 100644 --- a/pkgs/by-name/os/osinfo-db/package.nix +++ b/pkgs/by-name/os/osinfo-db/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, osinfo-db-tools -, gettext -, libxml2 +{ + lib, + stdenv, + fetchurl, + osinfo-db-tools, + gettext, + libxml2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/os/osm-gps-map/package.nix b/pkgs/by-name/os/osm-gps-map/package.nix index 5beaf910e425d9..4bae4c46fd45e2 100644 --- a/pkgs/by-name/os/osm-gps-map/package.nix +++ b/pkgs/by-name/os/osm-gps-map/package.nix @@ -1,4 +1,15 @@ -{ cairo, fetchzip, glib, libsoup_2_4, gnome-common, gtk3, gobject-introspection, pkg-config, lib, stdenv }: +{ + cairo, + fetchzip, + glib, + libsoup_2_4, + gnome-common, + gtk3, + gobject-introspection, + pkg-config, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "osm-gps-map"; @@ -9,12 +20,21 @@ stdenv.mkDerivation rec { sha256 = "sha256-ciw28YXhR+GC6B2VPC+ZxjyhadOk3zYGuOssSgqjwH0="; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; - nativeBuildInputs = [ pkg-config gobject-introspection gnome-common ]; + nativeBuildInputs = [ + pkg-config + gobject-introspection + gnome-common + ]; buildInputs = [ - cairo glib + cairo + glib gtk3 libsoup_2_4 ]; diff --git a/pkgs/by-name/os/osm2pgsql/package.nix b/pkgs/by-name/os/osm2pgsql/package.nix index f05da20d368746..b5c927740f3467 100644 --- a/pkgs/by-name/os/osm2pgsql/package.nix +++ b/pkgs/by-name/os/osm2pgsql/package.nix @@ -1,24 +1,26 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, expat -, fmt_11 -, proj -, bzip2 -, cli11 -, zlib -, boost -, postgresql -, python3 -, withLuaJIT ? false -, lua -, luajit -, libosmium -, nlohmann_json -, opencv -, potrace -, protozero -, testers +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + expat, + fmt_11, + proj, + bzip2, + cli11, + zlib, + boost, + postgresql, + python3, + withLuaJIT ? false, + lua, + luajit, + libosmium, + nlohmann_json, + opencv, + potrace, + protozero, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -39,22 +41,29 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ cmake ]; - buildInputs = [ - boost - bzip2 - cli11 - expat - fmt_11 - libosmium - nlohmann_json - opencv - postgresql - potrace - proj - protozero - (python3.withPackages (p: with p; [ psycopg2 pyosmium ])) - zlib - ] ++ lib.optional withLuaJIT luajit + buildInputs = + [ + boost + bzip2 + cli11 + expat + fmt_11 + libosmium + nlohmann_json + opencv + postgresql + potrace + proj + protozero + (python3.withPackages ( + p: with p; [ + psycopg2 + pyosmium + ] + )) + zlib + ] + ++ lib.optional withLuaJIT luajit ++ lib.optional (!withLuaJIT) lua; cmakeFlags = [ @@ -73,6 +82,11 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://osm2pgsql.org"; license = lib.licenses.gpl2Plus; platforms = lib.platforms.unix; - maintainers = lib.teams.geospatial.members ++ (with lib.maintainers; [ jglukasik das-g ]); + maintainers = + lib.teams.geospatial.members + ++ (with lib.maintainers; [ + jglukasik + das-g + ]); }; }) diff --git a/pkgs/by-name/os/osm2xmap/package.nix b/pkgs/by-name/os/osm2xmap/package.nix index bca60b14a34df9..292b4884711a0d 100644 --- a/pkgs/by-name/os/osm2xmap/package.nix +++ b/pkgs/by-name/os/osm2xmap/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libroxml, proj_7, yaml-cpp_0_3, boost } : +{ + lib, + stdenv, + fetchFromGitHub, + libroxml, + proj_7, + yaml-cpp_0_3, + boost, +}: stdenv.mkDerivation rec { pname = "osm2xmap"; @@ -21,7 +29,12 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = "-DACCEPT_USE_OF_DEPRECATED_PROJ_API_H"; - buildInputs = [ libroxml proj_7 yaml-cpp_0_3 boost ]; + buildInputs = [ + libroxml + proj_7 + yaml-cpp_0_3 + boost + ]; meta = with lib; { homepage = "https://github.com/sembruk/osm2xmap"; diff --git a/pkgs/by-name/os/osmctools/package.nix b/pkgs/by-name/os/osmctools/package.nix index 230bc80d180a17..10026a49e5f24a 100644 --- a/pkgs/by-name/os/osmctools/package.nix +++ b/pkgs/by-name/os/osmctools/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitLab, autoreconfHook, zlib }: +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + zlib, +}: stdenv.mkDerivation rec { pname = "osmctools"; diff --git a/pkgs/by-name/os/osmid/package.nix b/pkgs/by-name/os/osmid/package.nix index 79b809428ea535..57257882b8101d 100644 --- a/pkgs/by-name/os/osmid/package.nix +++ b/pkgs/by-name/os/osmid/package.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, alsa-lib -, libX11 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + alsa-lib, + libX11, }: stdenv.mkDerivation rec { @@ -18,7 +20,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ alsa-lib libX11 ]; + buildInputs = [ + alsa-lib + libX11 + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/os/osmium-tool/package.nix b/pkgs/by-name/os/osmium-tool/package.nix index 7735e7500f9d03..5e38abe5879004 100644 --- a/pkgs/by-name/os/osmium-tool/package.nix +++ b/pkgs/by-name/os/osmium-tool/package.nix @@ -1,15 +1,17 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, installShellFiles -, pandoc -, boost -, bzip2 -, expat -, libosmium -, lz4 -, protozero -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + installShellFiles, + pandoc, + boost, + bzip2, + expat, + libosmium, + lz4, + protozero, + zlib, }: stdenv.mkDerivation rec { @@ -49,7 +51,11 @@ stdenv.mkDerivation rec { description = "Multipurpose command line tool for working with OpenStreetMap data based on the Osmium library"; homepage = "https://osmcode.org/osmium-tool/"; changelog = "https://github.com/osmcode/osmium-tool/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ gpl3Plus mit bsd3 ]; + license = with licenses; [ + gpl3Plus + mit + bsd3 + ]; maintainers = with maintainers; teams.geospatial.members ++ [ das-g ]; mainProgram = "osmium"; }; diff --git a/pkgs/by-name/os/osmo-bsc/package.nix b/pkgs/by-name/os/osmo-bsc/package.nix index ced3be6b350fb7..9caae70947891b 100644 --- a/pkgs/by-name/os/osmo-bsc/package.nix +++ b/pkgs/by-name/os/osmo-bsc/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libosmocore -, libosmoabis -, libosmo-netif -, libosmo-sccp -, osmo-mgw +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libosmocore, + libosmoabis, + libosmo-netif, + libosmo-sccp, + osmo-mgw, }: let @@ -29,7 +30,6 @@ stdenv.mkDerivation rec { echo "${version}" > .tarball-version ''; - nativeBuildInputs = [ autoreconfHook pkg-config diff --git a/pkgs/by-name/os/osmo-bts/package.nix b/pkgs/by-name/os/osmo-bts/package.nix index 4bdddf78451337..4014643900fe6c 100644 --- a/pkgs/by-name/os/osmo-bts/package.nix +++ b/pkgs/by-name/os/osmo-bts/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libosmocore -, libosmoabis -, libosmo-netif +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libosmocore, + libosmoabis, + libosmo-netif, }: stdenv.mkDerivation rec { @@ -23,7 +24,6 @@ stdenv.mkDerivation rec { echo "${version}" > .tarball-version ''; - nativeBuildInputs = [ autoreconfHook pkg-config diff --git a/pkgs/by-name/os/osmo-ggsn/package.nix b/pkgs/by-name/os/osmo-ggsn/package.nix index f2c77d33ddb1fd..67322e9751a807 100644 --- a/pkgs/by-name/os/osmo-ggsn/package.nix +++ b/pkgs/by-name/os/osmo-ggsn/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libosmocore +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libosmocore, }: let @@ -25,7 +26,6 @@ stdenv.mkDerivation rec { echo "${version}" > .tarball-version ''; - nativeBuildInputs = [ autoreconfHook pkg-config diff --git a/pkgs/by-name/os/osmo-hlr/package.nix b/pkgs/by-name/os/osmo-hlr/package.nix index a287619155ed44..2e58ebb6d2d958 100644 --- a/pkgs/by-name/os/osmo-hlr/package.nix +++ b/pkgs/by-name/os/osmo-hlr/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libosmocore -, libosmoabis -, sqlite +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libosmocore, + libosmoabis, + sqlite, }: let @@ -27,7 +28,6 @@ stdenv.mkDerivation rec { echo "${version}" > .tarball-version ''; - nativeBuildInputs = [ autoreconfHook pkg-config diff --git a/pkgs/by-name/os/osmo-hnbgw/package.nix b/pkgs/by-name/os/osmo-hnbgw/package.nix index e074e0100d28a1..63640d549506cd 100644 --- a/pkgs/by-name/os/osmo-hnbgw/package.nix +++ b/pkgs/by-name/os/osmo-hnbgw/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libosmocore -, lksctp-tools -, libosmo-netif -, libasn1c -, libosmo-sccp -, osmo-iuh -, osmo-mgw +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libosmocore, + lksctp-tools, + libosmo-netif, + libasn1c, + libosmo-sccp, + osmo-iuh, + osmo-mgw, }: let @@ -31,7 +32,6 @@ stdenv.mkDerivation rec { echo "${version}" > .tarball-version ''; - nativeBuildInputs = [ autoreconfHook pkg-config diff --git a/pkgs/by-name/os/osmo-hnodeb/package.nix b/pkgs/by-name/os/osmo-hnodeb/package.nix index 27cf6c04f41ae7..035cd37c248297 100644 --- a/pkgs/by-name/os/osmo-hnodeb/package.nix +++ b/pkgs/by-name/os/osmo-hnodeb/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libosmocore -, lksctp-tools -, libasn1c -, libosmoabis -, libosmo-netif -, libosmo-sccp -, osmo-iuh +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libosmocore, + lksctp-tools, + libasn1c, + libosmoabis, + libosmo-netif, + libosmo-sccp, + osmo-iuh, }: let @@ -31,7 +32,6 @@ stdenv.mkDerivation rec { echo "${version}" > .tarball-version ''; - nativeBuildInputs = [ autoreconfHook pkg-config diff --git a/pkgs/by-name/os/osmo-iuh/package.nix b/pkgs/by-name/os/osmo-iuh/package.nix index d4044ac512fd52..8b23f5c20b2153 100644 --- a/pkgs/by-name/os/osmo-iuh/package.nix +++ b/pkgs/by-name/os/osmo-iuh/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libosmocore -, lksctp-tools -, libosmo-netif -, libosmo-sccp -, libasn1c -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libosmocore, + lksctp-tools, + libosmo-netif, + libosmo-sccp, + libasn1c, + python3, }: let @@ -35,7 +36,6 @@ stdenv.mkDerivation rec { echo "${version}" > .tarball-version ''; - nativeBuildInputs = [ autoreconfHook pkg-config diff --git a/pkgs/by-name/os/osmo-mgw/package.nix b/pkgs/by-name/os/osmo-mgw/package.nix index 47ec9bdaf8fe08..e1c6e296b5eb30 100644 --- a/pkgs/by-name/os/osmo-mgw/package.nix +++ b/pkgs/by-name/os/osmo-mgw/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libosmocore -, libosmo-netif -, libosmoabis +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libosmocore, + libosmo-netif, + libosmoabis, }: let @@ -27,7 +28,6 @@ stdenv.mkDerivation rec { echo "${version}" > .tarball-version ''; - nativeBuildInputs = [ autoreconfHook pkg-config diff --git a/pkgs/by-name/os/osmo-msc/package.nix b/pkgs/by-name/os/osmo-msc/package.nix index 352489af8b68db..7e8bb0d8442bb1 100644 --- a/pkgs/by-name/os/osmo-msc/package.nix +++ b/pkgs/by-name/os/osmo-msc/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libosmocore -, sqlite -, libosmoabis -, libosmo-netif -, libosmo-sccp -, osmo-mgw -, osmo-hlr -, lksctp-tools +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libosmocore, + sqlite, + libosmoabis, + libosmo-netif, + libosmo-sccp, + osmo-mgw, + osmo-hlr, + lksctp-tools, }: let @@ -32,7 +33,6 @@ stdenv.mkDerivation rec { echo "${version}" > .tarball-version ''; - nativeBuildInputs = [ autoreconfHook pkg-config diff --git a/pkgs/by-name/os/osmo-pcu/package.nix b/pkgs/by-name/os/osmo-pcu/package.nix index a8b2000ec85259..02f0fc4a6f7122 100644 --- a/pkgs/by-name/os/osmo-pcu/package.nix +++ b/pkgs/by-name/os/osmo-pcu/package.nix @@ -1,10 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libosmocore -, +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libosmocore, }: let @@ -26,7 +26,6 @@ stdenv.mkDerivation rec { echo "${version}" > .tarball-version ''; - nativeBuildInputs = [ autoreconfHook pkg-config diff --git a/pkgs/by-name/os/osmo-sgsn/package.nix b/pkgs/by-name/os/osmo-sgsn/package.nix index 9b71a9e1927d99..f4c245b49934ca 100644 --- a/pkgs/by-name/os/osmo-sgsn/package.nix +++ b/pkgs/by-name/os/osmo-sgsn/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libosmocore -, libosmoabis -, libosmo-netif -, osmo-hlr -, osmo-ggsn -, c-ares +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libosmocore, + libosmoabis, + libosmo-netif, + osmo-hlr, + osmo-ggsn, + c-ares, }: let @@ -30,7 +31,6 @@ stdenv.mkDerivation rec { echo "${version}" > .tarball-version ''; - nativeBuildInputs = [ autoreconfHook pkg-config diff --git a/pkgs/by-name/os/osmo-sip-connector/package.nix b/pkgs/by-name/os/osmo-sip-connector/package.nix index b1f810d0f5f7ec..990967bd564a50 100644 --- a/pkgs/by-name/os/osmo-sip-connector/package.nix +++ b/pkgs/by-name/os/osmo-sip-connector/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libosmocore -, sofia_sip -, glib +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libosmocore, + sofia_sip, + glib, }: let @@ -27,7 +28,6 @@ stdenv.mkDerivation rec { echo "${version}" > .tarball-version ''; - nativeBuildInputs = [ autoreconfHook pkg-config diff --git a/pkgs/by-name/os/osmo/package.nix b/pkgs/by-name/os/osmo/package.nix index de1086f1f53d11..c5bcfc5e08ba4e 100644 --- a/pkgs/by-name/os/osmo/package.nix +++ b/pkgs/by-name/os/osmo/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchurl, pkg-config, gtk3, libxml2, gettext, libical, libnotify -, libarchive, gspell, webkitgtk_4_0, libgringotts, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk3, + libxml2, + gettext, + libical, + libnotify, + libarchive, + gspell, + webkitgtk_4_0, + libgringotts, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "osmo"; @@ -10,9 +24,21 @@ stdenv.mkDerivation rec { sha256 = "19h3dnjgqbawnvgnycyp4n5b6mjsp5zghn3b69b6f3xa3fyi32qy"; }; - nativeBuildInputs = [ pkg-config gettext wrapGAppsHook3 ]; - buildInputs = [ gtk3 libxml2 libical libnotify libarchive - gspell webkitgtk_4_0 libgringotts ]; + nativeBuildInputs = [ + pkg-config + gettext + wrapGAppsHook3 + ]; + buildInputs = [ + gtk3 + libxml2 + libical + libnotify + libarchive + gspell + webkitgtk_4_0 + libgringotts + ]; meta = with lib; { description = "Handy personal organizer"; diff --git a/pkgs/by-name/os/osmtogeojson/package.nix b/pkgs/by-name/os/osmtogeojson/package.nix index 07d989d2cc83cb..33d9e098290ef5 100644 --- a/pkgs/by-name/os/osmtogeojson/package.nix +++ b/pkgs/by-name/os/osmtogeojson/package.nix @@ -1,4 +1,8 @@ -{ lib, buildNpmPackage, fetchFromGitHub }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, +}: buildNpmPackage rec { pname = "osmtogeojson"; diff --git a/pkgs/by-name/os/osqp/package.nix b/pkgs/by-name/os/osqp/package.nix index 55f00d01636a21..0425777a85f83f 100644 --- a/pkgs/by-name/os/osqp/package.nix +++ b/pkgs/by-name/os/osqp/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/os/ossia-score/package.nix b/pkgs/by-name/os/ossia-score/package.nix index ee8e0a99a94888..cc455d3adffc51 100644 --- a/pkgs/by-name/os/ossia-score/package.nix +++ b/pkgs/by-name/os/ossia-score/package.nix @@ -1,41 +1,42 @@ -{ lib -, fetchFromGitHub -, cmake -, ninja -, clangStdenv -, pkg-config -, alsa-lib -, avahi -, avahi-compat -, bluez -, boost185 -, fmt -, ffmpeg -, fftw -, flac -, git -, gnutls -, lame -, libcoap -, libjack2 -, libopus -, libsamplerate -, libsndfile -, libvorbis -, lilv -, lv2 -, mpg123 -, pipewire -, portaudio -, qt6 -, rapidfuzz-cpp -, re2 -, rubberband -, snappy -, SDL2 -, spdlog -, suil -, udev +{ + lib, + fetchFromGitHub, + cmake, + ninja, + clangStdenv, + pkg-config, + alsa-lib, + avahi, + avahi-compat, + bluez, + boost185, + fmt, + ffmpeg, + fftw, + flac, + git, + gnutls, + lame, + libcoap, + libjack2, + libopus, + libsamplerate, + libsndfile, + libvorbis, + lilv, + lv2, + mpg123, + pipewire, + portaudio, + qt6, + rapidfuzz-cpp, + re2, + rubberband, + snappy, + SDL2, + spdlog, + suil, + udev, }: # TODO: figure out LLVM jit @@ -53,7 +54,14 @@ clangStdenv.mkDerivation (finalAttrs: { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake ninja git pkg-config qt6.qttools qt6.wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + ninja + git + pkg-config + qt6.qttools + qt6.wrapQtAppsHook + ]; buildInputs = [ alsa-lib @@ -153,6 +161,9 @@ clangStdenv.mkDerivation (finalAttrs: { ''; platforms = platforms.linux; license = licenses.gpl3Only; - maintainers = with maintainers; [ jcelerier minijackson ]; + maintainers = with maintainers; [ + jcelerier + minijackson + ]; }; }) diff --git a/pkgs/by-name/os/osslsigncode/package.nix b/pkgs/by-name/os/osslsigncode/package.nix index 2fe91c46bcd3ec..27e3db46ddda9d 100644 --- a/pkgs/by-name/os/osslsigncode/package.nix +++ b/pkgs/by-name/os/osslsigncode/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, python3 -, curl -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + python3, + curl, + openssl, }: stdenv.mkDerivation rec { @@ -19,16 +20,26 @@ stdenv.mkDerivation rec { sha256 = "sha256-ENMFhIVQhPL4FDW9Ne2YGR3sXjvW55NN1bErfr/kDZg="; }; - nativeBuildInputs = [ cmake pkg-config python3 ]; + nativeBuildInputs = [ + cmake + pkg-config + python3 + ]; - buildInputs = [ curl openssl ]; + buildInputs = [ + curl + openssl + ]; meta = with lib; { homepage = "https://github.com/mtrojnar/osslsigncode"; description = "OpenSSL based Authenticode signing for PE/MSI/Java CAB files"; mainProgram = "osslsigncode"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ mmahut prusnak ]; + maintainers = with maintainers; [ + mmahut + prusnak + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/os/ossutil/package.nix b/pkgs/by-name/os/ossutil/package.nix index c55faa02d4a7fb..cd32a65cfec0d2 100644 --- a/pkgs/by-name/os/ossutil/package.nix +++ b/pkgs/by-name/os/ossutil/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { version = "1.7.18"; diff --git a/pkgs/by-name/os/ostree-rs-ext/package.nix b/pkgs/by-name/os/ostree-rs-ext/package.nix index 542dfd11cfcfbe..59f987917accbf 100644 --- a/pkgs/by-name/os/ostree-rs-ext/package.nix +++ b/pkgs/by-name/os/ostree-rs-ext/package.nix @@ -1,17 +1,18 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, makeWrapper -, glib -, openssl -, zlib -, ostree -, stdenv -, util-linux -, skopeo -, gnutar -, ima-evm-utils +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + makeWrapper, + glib, + openssl, + zlib, + ostree, + stdenv, + util-linux, + skopeo, + gnutar, + ima-evm-utils, }: rustPlatform.buildRustPackage rec { @@ -64,13 +65,24 @@ rustPlatform.buildRustPackage rec { ]; postInstall = '' - wrapProgram "$out/bin/${meta.mainProgram}" --prefix PATH : ${lib.makeBinPath [ util-linux skopeo gnutar ostree ima-evm-utils ]} + wrapProgram "$out/bin/${meta.mainProgram}" --prefix PATH : ${ + lib.makeBinPath [ + util-linux + skopeo + gnutar + ostree + ima-evm-utils + ] + } ''; meta = with lib; { description = "Rust library with higher level APIs on top of the core ostree API"; homepage = "https://github.com/ostreedev/ostree-rs-ext"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ nickcao ]; mainProgram = "ostree-ext-cli"; }; diff --git a/pkgs/by-name/os/ostrich-sans/package.nix b/pkgs/by-name/os/ostrich-sans/package.nix index 1acfe687df00f4..a31617e6bd4fac 100644 --- a/pkgs/by-name/os/ostrich-sans/package.nix +++ b/pkgs/by-name/os/ostrich-sans/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, +}: stdenvNoCC.mkDerivation { pname = "ostrich-sans"; diff --git a/pkgs/by-name/os/osv-detector/package.nix b/pkgs/by-name/os/osv-detector/package.nix index 3be67c91d265d1..470197738dcbe9 100644 --- a/pkgs/by-name/os/osv-detector/package.nix +++ b/pkgs/by-name/os/osv-detector/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, osv-detector -, testers +{ + lib, + buildGoModule, + fetchFromGitHub, + osv-detector, + testers, }: buildGoModule rec { @@ -38,7 +39,10 @@ buildGoModule rec { "TestRun_Configs" ]; in - [ "-skip" "${builtins.concatStringsSep "|" skippedTests}" ]; + [ + "-skip" + "${builtins.concatStringsSep "|" skippedTests}" + ]; passthru.tests.version = testers.testVersion { package = osv-detector; diff --git a/pkgs/by-name/os/osv-scanner/package.nix b/pkgs/by-name/os/osv-scanner/package.nix index 3426e424ea95de..10803f166fda92 100644 --- a/pkgs/by-name/os/osv-scanner/package.nix +++ b/pkgs/by-name/os/osv-scanner/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, osv-scanner +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + osv-scanner, }: buildGoModule rec { @@ -43,6 +44,9 @@ buildGoModule rec { homepage = "https://github.com/google/osv-scanner"; changelog = "https://github.com/google/osv-scanner/releases/tag/v${version}"; license = licenses.asl20; - maintainers = with maintainers; [ stehessel urandom ]; + maintainers = with maintainers; [ + stehessel + urandom + ]; }; } diff --git a/pkgs/by-name/os/oswald/package.nix b/pkgs/by-name/os/oswald/package.nix index 13008e7b337bb6..c842e8565ea49a 100644 --- a/pkgs/by-name/os/oswald/package.nix +++ b/pkgs/by-name/os/oswald/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "oswald"; diff --git a/pkgs/by-name/os/osxsnarf/package.nix b/pkgs/by-name/os/osxsnarf/package.nix index 534c8bd5b3a60f..aa4f22baa43e15 100644 --- a/pkgs/by-name/os/osxsnarf/package.nix +++ b/pkgs/by-name/os/osxsnarf/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, plan9port, darwin, ... }: +{ + stdenv, + lib, + fetchFromGitHub, + plan9port, + darwin, + ... +}: stdenv.mkDerivation rec { pname = "osxsnarf"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "1vpg39mpc5avnv1j0yfx0x2ncvv38slmm83zv6nmm7alfwfjr2ss"; }; - buildInputs = [ plan9port darwin.apple_sdk.frameworks.Carbon ]; + buildInputs = [ + plan9port + darwin.apple_sdk.frameworks.Carbon + ]; makeFlags = [ "prefix=${placeholder "out"}" ]; meta = with lib; { diff --git a/pkgs/by-name/ot/otel-cli/package.nix b/pkgs/by-name/ot/otel-cli/package.nix index b0c4e38c4c5247..a3550e94225b17 100644 --- a/pkgs/by-name/ot/otel-cli/package.nix +++ b/pkgs/by-name/ot/otel-cli/package.nix @@ -1,4 +1,12 @@ -{ lib, buildGoModule, fetchFromGitHub, getent, coreutils, nix-update-script, stdenv }: +{ + lib, + buildGoModule, + fetchFromGitHub, + getent, + coreutils, + nix-update-script, + stdenv, +}: buildGoModule rec { pname = "otel-cli"; @@ -13,23 +21,33 @@ buildGoModule rec { vendorHash = "sha256-fWQz7ZrU8gulhpOHSN8Prn4EMC0KXy942FZD/PMsLxc="; - preCheck = '' - ln -s $GOPATH/bin/otel-cli . - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - substituteInPlace main_test.go \ - --replace-fail 'const minimumPath = `/bin:/usr/bin`' 'const minimumPath = `${lib.makeBinPath [ getent coreutils ]}`' - ''; + preCheck = + '' + ln -s $GOPATH/bin/otel-cli . + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + substituteInPlace main_test.go \ + --replace-fail 'const minimumPath = `/bin:/usr/bin`' 'const minimumPath = `${ + lib.makeBinPath [ + getent + coreutils + ] + }`' + ''; patches = [ ./patches/bin-echo-patch.patch ]; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = with lib; { homepage = "https://github.com/equinix-labs/otel-cli"; description = "Command-line tool for sending OpenTelemetry traces"; changelog = "https://github.com/equinix-labs/otel-cli/releases/tag/v${version}"; license = licenses.asl20; - maintainers = with lib.maintainers; [ emattiza urandom ]; + maintainers = with lib.maintainers; [ + emattiza + urandom + ]; mainProgram = "otel-cli"; }; } diff --git a/pkgs/by-name/ot/otf2bdf/package.nix b/pkgs/by-name/ot/otf2bdf/package.nix index 6653225b7f4482..110d8138384537 100644 --- a/pkgs/by-name/ot/otf2bdf/package.nix +++ b/pkgs/by-name/ot/otf2bdf/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, freetype +{ + lib, + stdenv, + fetchFromGitHub, + freetype, }: stdenv.mkDerivation rec { @@ -12,9 +13,9 @@ stdenv.mkDerivation rec { # This is a mirror. src = fetchFromGitHub { owner = "jirutka"; - repo = "otf2bdf"; - rev = "v${version}"; - hash = "sha256-HK9ZrnwKhhYcBvSl+3RwFD7m/WSaPkGKX6utXnk5k+A="; + repo = "otf2bdf"; + rev = "v${version}"; + hash = "sha256-HK9ZrnwKhhYcBvSl+3RwFD7m/WSaPkGKX6utXnk5k+A="; }; buildInputs = [ freetype ]; diff --git a/pkgs/by-name/ot/otfcc/package.nix b/pkgs/by-name/ot/otfcc/package.nix index d45c800464ab72..820df7dac464ba 100644 --- a/pkgs/by-name/ot/otfcc/package.nix +++ b/pkgs/by-name/ot/otfcc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, premake5 }: +{ + lib, + stdenv, + fetchFromGitHub, + premake5, +}: stdenv.mkDerivation rec { pname = "otfcc"; diff --git a/pkgs/by-name/ot/otpauth/package.nix b/pkgs/by-name/ot/otpauth/package.nix index f7f4fa3b81442d..b8ab75997f68b8 100644 --- a/pkgs/by-name/ot/otpauth/package.nix +++ b/pkgs/by-name/ot/otpauth/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { diff --git a/pkgs/by-name/ot/otpclient/package.nix b/pkgs/by-name/ot/otpclient/package.nix index d850da3b58f8a9..9569d7a5927b1b 100644 --- a/pkgs/by-name/ot/otpclient/package.nix +++ b/pkgs/by-name/ot/otpclient/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, gtk3 -, wrapGAppsHook3 -, jansson -, libgcrypt -, libzip -, libpng -, libcotp -, protobuf -, protobufc -, qrencode -, libsecret -, libuuid -, zbar +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + gtk3, + wrapGAppsHook3, + jansson, + libgcrypt, + libzip, + libpng, + libcotp, + protobuf, + protobufc, + qrencode, + libsecret, + libuuid, + zbar, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ot/otpw/package.nix b/pkgs/by-name/ot/otpw/package.nix index 337e422eebdd1f..3bac1ca3eb4e5f 100644 --- a/pkgs/by-name/ot/otpw/package.nix +++ b/pkgs/by-name/ot/otpw/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, coreutils -, fetchurl -, libxcrypt -, pam -, procps -, unixtools -, util-linux +{ + lib, + stdenv, + coreutils, + fetchurl, + libxcrypt, + pam, + procps, + unixtools, + util-linux, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ot/ots/package.nix b/pkgs/by-name/ot/ots/package.nix index 7d55bb84d97605..e5975c7f9e6f3e 100644 --- a/pkgs/by-name/ot/ots/package.nix +++ b/pkgs/by-name/ot/ots/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ots"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-qYk8T0sYIO0wJ0R0j+0VetCy11w8usIRRdBm/Z6grJE="; - ldflags = [ "-X main.version=${version}" "-X main.buildSource=nix" ]; + ldflags = [ + "-X main.version=${version}" + "-X main.buildSource=nix" + ]; meta = with lib; { description = "Share end-to-end encrypted secrets with others via a one-time URL"; diff --git a/pkgs/by-name/ot/ott/package.nix b/pkgs/by-name/ot/ott/package.nix index 73de6373e8f057..12890101e612dd 100644 --- a/pkgs/by-name/ot/ott/package.nix +++ b/pkgs/by-name/ot/ott/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, ocamlPackages, opaline }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + ocamlPackages, + opaline, +}: stdenv.mkDerivation rec { pname = "ott"; @@ -11,21 +18,29 @@ stdenv.mkDerivation rec { hash = "sha256-GzeEiok5kigcmfqf/K/UxvlKkl55zy0vOyiRZ2HyMiE="; }; - strictDeps = true; - nativeBuildInputs = [ pkg-config opaline ] ++ (with ocamlPackages; [ findlib ocaml ]); + nativeBuildInputs = + [ + pkg-config + opaline + ] + ++ (with ocamlPackages; [ + findlib + ocaml + ]); buildInputs = with ocamlPackages; [ ocamlgraph ]; installTargets = "ott.install"; - postInstall = '' - opaline -prefix $out - '' - # There is `emacsPackages.ott-mode` for this now. - + '' - rm -r $out/share/emacs - ''; + postInstall = + '' + opaline -prefix $out + '' + # There is `emacsPackages.ott-mode` for this now. + + '' + rm -r $out/share/emacs + ''; meta = { description = "Tool for the working semanticist"; diff --git a/pkgs/by-name/ot/otto-matic/package.nix b/pkgs/by-name/ot/otto-matic/package.nix index fbdbb3366b10e3..717154698f7734 100644 --- a/pkgs/by-name/ot/otto-matic/package.nix +++ b/pkgs/by-name/ot/otto-matic/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, SDL2, cmake, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + cmake, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "OttoMatic"; diff --git a/pkgs/by-name/ot/otus-lisp/package.nix b/pkgs/by-name/ot/otus-lisp/package.nix index a8673652b2edc5..1de3f09f8f0556 100644 --- a/pkgs/by-name/ot/otus-lisp/package.nix +++ b/pkgs/by-name/ot/otus-lisp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, xxd }: +{ + lib, + stdenv, + fetchFromGitHub, + xxd, +}: stdenv.mkDerivation (finalAttrs: { pname = "otus-lisp"; @@ -18,7 +23,10 @@ stdenv.mkDerivation (finalAttrs: { meta = { description = "Purely functional dialect of Lisp"; homepage = "https://yuriy-chumak.github.io/ol/"; - license = with lib.licenses; [ mit lgpl3Only ]; # dual licensed + license = with lib.licenses; [ + mit + lgpl3Only + ]; # dual licensed platforms = lib.platforms.unix; maintainers = with lib.maintainers; [ nagy ]; mainProgram = "ol"; diff --git a/pkgs/by-name/ou/ouch/package.nix b/pkgs/by-name/ou/ouch/package.nix index aff44da469e6fc..ea27974a5a8668 100644 --- a/pkgs/by-name/ou/ouch/package.nix +++ b/pkgs/by-name/ou/ouch/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, bzip2 -, xz -, zlib -, zstd +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + bzip2, + xz, + zlib, + zstd, }: rustPlatform.buildRustPackage rec { @@ -22,9 +23,17 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-OdAu7fStTJCF1JGJG9TRE1Qosy6yjKsWq01MYpbXZcg="; - nativeBuildInputs = [ installShellFiles pkg-config ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + ]; - buildInputs = [ bzip2 xz zlib zstd ]; + buildInputs = [ + bzip2 + xz + zlib + zstd + ]; buildFeatures = [ "zstd/pkg-config" ]; @@ -45,7 +54,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/ouch-org/ouch"; changelog = "https://github.com/ouch-org/ouch/blob/${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ figsoda psibi ]; + maintainers = with maintainers; [ + figsoda + psibi + ]; mainProgram = "ouch"; }; } diff --git a/pkgs/by-name/ou/oui/package.nix b/pkgs/by-name/ou/oui/package.nix index 9fd613a295e7f1..584de64b926e12 100644 --- a/pkgs/by-name/ou/oui/package.nix +++ b/pkgs/by-name/ou/oui/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "oui"; diff --git a/pkgs/by-name/ou/out-of-tree/package.nix b/pkgs/by-name/ou/out-of-tree/package.nix index 2d6fb694318f95..732a6bb5c6e0b1 100644 --- a/pkgs/by-name/ou/out-of-tree/package.nix +++ b/pkgs/by-name/ou/out-of-tree/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchgit, qemu, podman, makeWrapper }: +{ + lib, + buildGoModule, + fetchgit, + qemu, + podman, + makeWrapper, +}: buildGoModule rec { pname = "out-of-tree"; @@ -18,7 +25,12 @@ buildGoModule rec { postFixup = '' wrapProgram $out/bin/out-of-tree \ - --prefix PATH : "${lib.makeBinPath [ qemu podman ]}" + --prefix PATH : "${ + lib.makeBinPath [ + qemu + podman + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/ou/outfox/package.nix b/pkgs/by-name/ou/outfox/package.nix index b3ac739d966393..693d757ff9f2b8 100644 --- a/pkgs/by-name/ou/outfox/package.nix +++ b/pkgs/by-name/ou/outfox/package.nix @@ -1,38 +1,41 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, alsa-lib -, freetype -, libjack2 -, libglvnd -, libpulseaudio -, makeDesktopItem -, makeWrapper +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + alsa-lib, + freetype, + libjack2, + libglvnd, + libpulseaudio, + makeDesktopItem, + makeWrapper, }: stdenv.mkDerivation rec { pname = "outfox"; version = "0.5.0-pre042"; - src = { - i686-linux = fetchurl { - url = "https://github.com/TeamRizu/OutFox/releases/download/OF5.0.0-042/OutFox-alpha-0.5.0-pre042-Linux-14.04-32bit-i386-i386-legacy-date-20231227.tar.gz"; - hash = "sha256-NFjNoqJ7Fq4A7Y0k6oQcWjykV+/b/MiRtJ1p6qlZdjs="; - }; - x86_64-linux = fetchurl { - url = "https://github.com/TeamRizu/OutFox/releases/download/OF5.0.0-042/OutFox-alpha-0.5.0-pre042-Linux-22.04-amd64-current-date-20231224.tar.gz"; - hash = "sha256-dW+g/JYav3rUuI+nHDi6rXu/O5KYiEdk/HH82jgOUnI="; - }; - aarch64-linux = fetchurl { - url = "https://github.com/TeamRizu/OutFox/releases/download/OF5.0.0-042/OutFox-alpha-0.5.0-pre042-Raspberry-Pi-Linux-18.04-arm64-arm64v8-modern-date-20231225.tar.gz"; - hash = "sha256-7Qrq6t8KmUSIK4Rskkxw5l4UZ2vsb9/orzPegHySaJ4="; - }; - armv7l-linux = fetchurl { - url = "https://github.com/TeamRizu/OutFox/releases/download/OF5.0.0-042/OutFox-alpha-0.5.0-pre042-Raspberry-Pi-Linux-14.04-arm32-arm32v7-legacy-date-20231227.tar.gz"; - hash = "sha256-PRp7kuqFBRy7nextTCB+/poc+A9AX2EiQphx6aUfT8E="; - }; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + { + i686-linux = fetchurl { + url = "https://github.com/TeamRizu/OutFox/releases/download/OF5.0.0-042/OutFox-alpha-0.5.0-pre042-Linux-14.04-32bit-i386-i386-legacy-date-20231227.tar.gz"; + hash = "sha256-NFjNoqJ7Fq4A7Y0k6oQcWjykV+/b/MiRtJ1p6qlZdjs="; + }; + x86_64-linux = fetchurl { + url = "https://github.com/TeamRizu/OutFox/releases/download/OF5.0.0-042/OutFox-alpha-0.5.0-pre042-Linux-22.04-amd64-current-date-20231224.tar.gz"; + hash = "sha256-dW+g/JYav3rUuI+nHDi6rXu/O5KYiEdk/HH82jgOUnI="; + }; + aarch64-linux = fetchurl { + url = "https://github.com/TeamRizu/OutFox/releases/download/OF5.0.0-042/OutFox-alpha-0.5.0-pre042-Raspberry-Pi-Linux-18.04-arm64-arm64v8-modern-date-20231225.tar.gz"; + hash = "sha256-7Qrq6t8KmUSIK4Rskkxw5l4UZ2vsb9/orzPegHySaJ4="; + }; + armv7l-linux = fetchurl { + url = "https://github.com/TeamRizu/OutFox/releases/download/OF5.0.0-042/OutFox-alpha-0.5.0-pre042-Raspberry-Pi-Linux-14.04-arm32-arm32v7-legacy-date-20231227.tar.gz"; + hash = "sha256-PRp7kuqFBRy7nextTCB+/poc+A9AX2EiQphx6aUfT8E="; + }; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); nativeBuildInputs = [ autoPatchelfHook @@ -73,7 +76,12 @@ stdenv.mkDerivation rec { changelog = "https://projectoutfox.com/releases/${version}"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - platforms = [ "x86_64-linux" "i686-linux" "aarch64-linux" "armv7l-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + "aarch64-linux" + "armv7l-linux" + ]; maintainers = with maintainers; [ maxwell-lt ]; mainProgram = "OutFox"; }; diff --git a/pkgs/by-name/ou/outils/package.nix b/pkgs/by-name/ou/outils/package.nix index e29e6440edcb72..a133d68e30c8c8 100644 --- a/pkgs/by-name/ou/outils/package.nix +++ b/pkgs/by-name/ou/outils/package.nix @@ -1,4 +1,8 @@ -{ stdenv, fetchFromGitHub, lib }: +{ + stdenv, + fetchFromGitHub, + lib, +}: stdenv.mkDerivation rec { pname = "outils"; diff --git a/pkgs/by-name/ou/outputcheck/package.nix b/pkgs/by-name/ou/outputcheck/package.nix index b7ae0b61f27b8b..9025c26c5ec568 100644 --- a/pkgs/by-name/ou/outputcheck/package.nix +++ b/pkgs/by-name/ou/outputcheck/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, lit +{ + lib, + python3, + fetchFromGitHub, + lit, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ov/ov/package.nix b/pkgs/by-name/ov/ov/package.nix index aa0b24a4959b84..b6cc370e4215e6 100644 --- a/pkgs/by-name/ov/ov/package.nix +++ b/pkgs/by-name/ov/ov/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles -, pandoc -, makeWrapper -, testers -, ov +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, + pandoc, + makeWrapper, + testers, + ov, }: buildGoModule rec { @@ -37,23 +38,28 @@ buildGoModule rec { makeWrapper ]; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; - postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - installShellCompletion --cmd ov \ - --bash <($out/bin/ov --completion bash) \ - --fish <($out/bin/ov --completion fish) \ - --zsh <($out/bin/ov --completion zsh) - '' + '' - mkdir -p $out/share/$name - cp $src/ov-less.yaml $out/share/$name/less-config.yaml - makeWrapper $out/bin/ov $out/bin/ov-less --add-flags "--config $out/share/$name/less-config.yaml" + postInstall = + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + installShellCompletion --cmd ov \ + --bash <($out/bin/ov --completion bash) \ + --fish <($out/bin/ov --completion fish) \ + --zsh <($out/bin/ov --completion zsh) + '' + + '' + mkdir -p $out/share/$name + cp $src/ov-less.yaml $out/share/$name/less-config.yaml + makeWrapper $out/bin/ov $out/bin/ov-less --add-flags "--config $out/share/$name/less-config.yaml" - mkdir -p $doc/share/doc/$name - pandoc -s < $src/README.md > $doc/share/doc/$name/README.html - mkdir -p $doc/share/$name - cp $src/ov.yaml $doc/share/$name/sample-config.yaml - ''; + mkdir -p $doc/share/doc/$name + pandoc -s < $src/README.md > $doc/share/doc/$name/README.html + mkdir -p $doc/share/$name + cp $src/ov.yaml $doc/share/$name/sample-config.yaml + ''; passthru.tests = { version = testers.testVersion { @@ -67,6 +73,9 @@ buildGoModule rec { homepage = "https://noborus.github.io/ov"; changelog = "https://github.com/noborus/ov/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ farcaller figsoda ]; + maintainers = with maintainers; [ + farcaller + figsoda + ]; }; } diff --git a/pkgs/by-name/ov/oven-media-engine/package.nix b/pkgs/by-name/ov/oven-media-engine/package.nix index dd7bbc54ea912f..9afc107d91faa2 100644 --- a/pkgs/by-name/ov/oven-media-engine/package.nix +++ b/pkgs/by-name/ov/oven-media-engine/package.nix @@ -1,19 +1,21 @@ -{ lib, stdenv -, fetchFromGitHub -, srt -, bc -, pkg-config -, perl -, openssl -, zlib -, ffmpeg -, libvpx -, libopus -, libuuid -, srtp -, jemalloc -, pcre2 -, hiredis +{ + lib, + stdenv, + fetchFromGitHub, + srt, + bc, + pkg-config, + perl, + openssl, + zlib, + ffmpeg, + libvpx, + libopus, + libuuid, + srtp, + jemalloc, + pcre2, + hiredis, }: stdenv.mkDerivation rec { @@ -33,11 +35,35 @@ stdenv.mkDerivation rec { ./support-ffmpeg-7.patch ]; - makeFlags = [ "release" "CONFIG_LIBRARY_PATHS=" "CONFIG_PKG_PATHS=" "GLOBAL_CC=$(CC)" "GLOBAL_CXX=$(CXX)" "GLOBAL_LD=$(CXX)" "SHELL=${stdenv.shell}" ]; + makeFlags = [ + "release" + "CONFIG_LIBRARY_PATHS=" + "CONFIG_PKG_PATHS=" + "GLOBAL_CC=$(CC)" + "GLOBAL_CXX=$(CXX)" + "GLOBAL_LD=$(CXX)" + "SHELL=${stdenv.shell}" + ]; enableParallelBuilding = true; - nativeBuildInputs = [ bc pkg-config perl ]; - buildInputs = [ openssl srt zlib ffmpeg libvpx libopus srtp jemalloc pcre2 libuuid hiredis ]; + nativeBuildInputs = [ + bc + pkg-config + perl + ]; + buildInputs = [ + openssl + srt + zlib + ffmpeg + libvpx + libopus + srtp + jemalloc + pcre2 + libuuid + hiredis + ]; preBuild = '' cd src @@ -60,9 +86,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Open-source streaming video service with sub-second latency"; mainProgram = "OvenMediaEngine"; - homepage = "https://ovenmediaengine.com"; - license = licenses.agpl3Only; + homepage = "https://ovenmediaengine.com"; + license = licenses.agpl3Only; maintainers = with maintainers; [ lukegb ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/ov/overcommit/gemset.nix b/pkgs/by-name/ov/overcommit/gemset.nix index ed1b0fd5351e0e..2b03bf49ae8f2d 100644 --- a/pkgs/by-name/ov/overcommit/gemset.nix +++ b/pkgs/by-name/ov/overcommit/gemset.nix @@ -1,51 +1,55 @@ { childprocess = { - dependencies = ["logger"]; - groups = ["default"]; - platforms = []; + dependencies = [ "logger" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1v5nalaarxnfdm6rxb7q6fmc6nx097jd630ax6h9ch7xw95li3cs"; type = "gem"; }; version = "5.1.0"; }; iniparse = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wb1qy4i2xrrd92dc34pi7q7ibrjpapzk9y465v0n9caiplnb89n"; type = "gem"; }; version = "1.5.0"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; overcommit = { - dependencies = ["childprocess" "iniparse" "rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "childprocess" + "iniparse" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lpl1ppjrqwsmywsb4srfjfm31dna30jrjyx2lkmws7s2jchy94v"; type = "gem"; }; version = "0.64.0"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09shc1dvg88c4yx83d4c9wf26z838nlapa3cmlq8iqdci39a98v2"; type = "gem"; }; diff --git a/pkgs/by-name/ov/overmind/package.nix b/pkgs/by-name/ov/overmind/package.nix index ceaec16839f9e5..54bbc8153267c5 100644 --- a/pkgs/by-name/ov/overmind/package.nix +++ b/pkgs/by-name/ov/overmind/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, tmux, which, makeWrapper }: +{ + lib, + buildGoModule, + fetchFromGitHub, + tmux, + which, + makeWrapper, +}: buildGoModule rec { pname = "overmind"; @@ -7,7 +14,12 @@ buildGoModule rec { nativeBuildInputs = [ makeWrapper ]; postInstall = '' - wrapProgram "$out/bin/overmind" --prefix PATH : "${lib.makeBinPath [ tmux which ]}" + wrapProgram "$out/bin/overmind" --prefix PATH : "${ + lib.makeBinPath [ + tmux + which + ] + }" ''; src = fetchFromGitHub { diff --git a/pkgs/by-name/ov/overpass/package.nix b/pkgs/by-name/ov/overpass/package.nix index 521c08c85cea1f..b0eabb5f7b14d8 100644 --- a/pkgs/by-name/ov/overpass/package.nix +++ b/pkgs/by-name/ov/overpass/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "overpass"; diff --git a/pkgs/by-name/ov/overskride/package.nix b/pkgs/by-name/ov/overskride/package.nix index f99244a8bd08ad..80603bb4ef9d47 100644 --- a/pkgs/by-name/ov/overskride/package.nix +++ b/pkgs/by-name/ov/overskride/package.nix @@ -1,12 +1,30 @@ -{ lib, fetchFromGitHub, rustPlatform, cargo, rustc, meson, ninja -, pkg-config, wrapGAppsHook4, desktop-file-utils, appstream-glib -, blueprint-compiler, dbus, gtk4, libadwaita, bluez, libpulseaudio }: let +{ + lib, + fetchFromGitHub, + rustPlatform, + cargo, + rustc, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + desktop-file-utils, + appstream-glib, + blueprint-compiler, + dbus, + gtk4, + libadwaita, + bluez, + libpulseaudio, +}: +let -owner = "kaii-lb"; -name = "overskride"; -version = "0.6.1"; + owner = "kaii-lb"; + name = "overskride"; + version = "0.6.1"; -in rustPlatform.buildRustPackage { +in +rustPlatform.buildRustPackage { pname = name; inherit version; @@ -32,7 +50,13 @@ in rustPlatform.buildRustPackage { rustc ]; - buildInputs = [ dbus gtk4 libadwaita bluez libpulseaudio ]; + buildInputs = [ + dbus + gtk4 + libadwaita + bluez + libpulseaudio + ]; buildPhase = '' runHook preBuild @@ -53,8 +77,7 @@ in rustPlatform.buildRustPackage { ''; meta = with lib; { - description = - "A Bluetooth and Obex client that is straight to the point, DE/WM agnostic, and beautiful"; + description = "A Bluetooth and Obex client that is straight to the point, DE/WM agnostic, and beautiful"; homepage = "https://github.com/${owner}/${name}"; changelog = "https://github.com/${owner}/${name}/blob/v${version}/CHANGELOG.md"; license = licenses.gpl3Only; diff --git a/pkgs/by-name/ov/oversteer/package.nix b/pkgs/by-name/ov/oversteer/package.nix index 3eb17719b35d20..fd1e063529ae21 100644 --- a/pkgs/by-name/ov/oversteer/package.nix +++ b/pkgs/by-name/ov/oversteer/package.nix @@ -1,9 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, gettext, python3, python3Packages -, meson, ninja, udev, appstream, appstream-glib, desktop-file-utils, gtk3 -, wrapGAppsHook3, gobject-introspection, bash, }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + gettext, + python3, + python3Packages, + meson, + ninja, + udev, + appstream, + appstream-glib, + desktop-file-utils, + gtk3, + wrapGAppsHook3, + gobject-introspection, + bash, +}: let - python = python3.withPackages (p: - with p; [ + python = python3.withPackages ( + p: with p; [ pygobject3 pyudev pyxdg @@ -12,10 +28,12 @@ let scipy gtk3 pygobject3 - ]); + ] + ); version = "0.8.3"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit version; pname = "oversteer"; @@ -27,7 +45,10 @@ in stdenv.mkDerivation { sha256 = "sha256-X58U7lFH53nCaXnE7uXgV7aea6qntNfH5TIt68xSefY="; }; - buildInputs = [ bash gtk3 ]; + buildInputs = [ + bash + gtk3 + ]; nativeBuildInputs = [ pkg-config @@ -45,7 +66,11 @@ in stdenv.mkDerivation { dontUseCmakeConfigure = true; - propagatedBuildInputs = [ python gtk3 python3Packages.pygobject3 ]; + propagatedBuildInputs = [ + python + gtk3 + python3Packages.pygobject3 + ]; mesonFlags = [ "--prefix" diff --git a/pkgs/by-name/ov/ovftool/package.nix b/pkgs/by-name/ov/ovftool/package.nix index 6df3491c085dcf..10156450bec7e8 100644 --- a/pkgs/by-name/ov/ovftool/package.nix +++ b/pkgs/by-name/ov/ovftool/package.nix @@ -1,20 +1,21 @@ -{ autoPatchelfHook -, c-ares -, darwin -, expat -, fetchurl -, glibc -, icu60 -, lib -, libiconv -, libredirect -, libxcrypt-legacy -, libxml2 -, makeWrapper -, stdenv -, unzip -, xercesc -, zlib +{ + autoPatchelfHook, + c-ares, + darwin, + expat, + fetchurl, + glibc, + icu60, + lib, + libiconv, + libredirect, + libxcrypt-legacy, + libxml2, + makeWrapper, + stdenv, + unzip, + xercesc, + zlib, }: let @@ -57,23 +58,28 @@ stdenv.mkDerivation { inherit (ovftoolSystem) name url hash; }; - buildInputs = [ - c-ares - expat - icu60 - libiconv - libxcrypt-legacy - xercesc - zlib - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - glibc - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.Libsystem - libxml2 - ]; - - nativeBuildInputs = [ unzip makeWrapper ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ autoPatchelfHook ]; + buildInputs = + [ + c-ares + expat + icu60 + libiconv + libxcrypt-legacy + xercesc + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + glibc + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.Libsystem + libxml2 + ]; + + nativeBuildInputs = [ + unzip + makeWrapper + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ autoPatchelfHook ]; postUnpack = '' # The linux package wraps ovftool.bin with ovftool. Wrapping @@ -84,26 +90,28 @@ stdenv.mkDerivation { fi ''; - installPhase = '' - runHook preInstall - - # Based on https://aur.archlinux.org/packages/vmware-ovftool/ - # with the addition of a libexec directory and a Nix-style binary wrapper. - - # Almost all libs in the package appear to be VMware proprietary except for - # libgoogleurl and libcurl. The rest of the libraries that the installer - # extracts are omitted here, and provided in buildInputs. Since libcurl - # depends on VMware's OpenSSL, both libs are still used. - # FIXME: Replace libgoogleurl? Possibly from Chromium? - # FIXME: Tell VMware to use a modern version of OpenSSL. As of ovftool - # v4.6.2 ovftool uses openssl-1.0.2zh which in seems to be the extended - # support LTS release: https://www.openssl.org/support/contracts.html - - # Install all libs that are not patched in preFixup. - # Darwin dylibs are under `lib` in the zip. - install -m 755 -d "$out/lib" - install -m 644 -t "$out/lib" \ - '' + lib.optionalString stdenv.hostPlatform.isLinux '' + installPhase = + '' + runHook preInstall + + # Based on https://aur.archlinux.org/packages/vmware-ovftool/ + # with the addition of a libexec directory and a Nix-style binary wrapper. + + # Almost all libs in the package appear to be VMware proprietary except for + # libgoogleurl and libcurl. The rest of the libraries that the installer + # extracts are omitted here, and provided in buildInputs. Since libcurl + # depends on VMware's OpenSSL, both libs are still used. + # FIXME: Replace libgoogleurl? Possibly from Chromium? + # FIXME: Tell VMware to use a modern version of OpenSSL. As of ovftool + # v4.6.2 ovftool uses openssl-1.0.2zh which in seems to be the extended + # support LTS release: https://www.openssl.org/support/contracts.html + + # Install all libs that are not patched in preFixup. + # Darwin dylibs are under `lib` in the zip. + install -m 755 -d "$out/lib" + install -m 644 -t "$out/lib" \ + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' libcrypto.so.1.0.2 \ libcurl.so.4 \ libgoogleurl.so.59 \ @@ -112,7 +120,8 @@ stdenv.mkDerivation { libvim-types.so \ libvmacore.so \ libvmomi.so - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' lib/libcrypto.1.0.2.dylib \ lib/libcurl.4.dylib \ lib/libgoogleurl.59.0.30.45.2.dylib \ @@ -121,91 +130,97 @@ stdenv.mkDerivation { lib/libvim-types.dylib \ lib/libvmacore.dylib \ lib/libvmomi.dylib - '' + '' - # Install libexec binaries - # ovftool expects to be run relative to certain directories, namely `env`. - # Place the binary and those dirs in libexec. - install -m 755 -d "$out/libexec" - install -m 755 -t "$out/libexec" ovftool - [ -f ovftool.bin ] && install -m 755 -t "$out/libexec" ovftool.bin - install -m 644 -t "$out/libexec" icudt44l.dat - - # Install other libexec resources that need to be relative to the `ovftool` - # binary. - for subdir in "certs" "env" "env/en" "schemas/DMTF" "schemas/vmware"; do - install -m 755 -d "$out/libexec/$subdir" - install -m 644 -t "$out/libexec/$subdir" "$subdir"/*.* - done - - # Install EULA/OSS files - install -m 755 -d "$out/share/licenses" - install -m 644 -t "$out/share/licenses" \ - "vmware.eula" \ - "vmware-eula.rtf" \ - "open_source_licenses.txt" - - # Install Docs - install -m 755 -d "$out/share/doc" - install -m 644 -t "$out/share/doc" "README.txt" - - # Install final executable - install -m 755 -d "$out/bin" - makeWrapper "$out/libexec/ovftool" "$out/bin/ovftool" \ - '' + lib.optionalString stdenv.hostPlatform.isLinux '' + '' + + '' + # Install libexec binaries + # ovftool expects to be run relative to certain directories, namely `env`. + # Place the binary and those dirs in libexec. + install -m 755 -d "$out/libexec" + install -m 755 -t "$out/libexec" ovftool + [ -f ovftool.bin ] && install -m 755 -t "$out/libexec" ovftool.bin + install -m 644 -t "$out/libexec" icudt44l.dat + + # Install other libexec resources that need to be relative to the `ovftool` + # binary. + for subdir in "certs" "env" "env/en" "schemas/DMTF" "schemas/vmware"; do + install -m 755 -d "$out/libexec/$subdir" + install -m 644 -t "$out/libexec/$subdir" "$subdir"/*.* + done + + # Install EULA/OSS files + install -m 755 -d "$out/share/licenses" + install -m 644 -t "$out/share/licenses" \ + "vmware.eula" \ + "vmware-eula.rtf" \ + "open_source_licenses.txt" + + # Install Docs + install -m 755 -d "$out/share/doc" + install -m 644 -t "$out/share/doc" "README.txt" + + # Install final executable + install -m 755 -d "$out/bin" + makeWrapper "$out/libexec/ovftool" "$out/bin/ovftool" \ + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' --prefix LD_LIBRARY_PATH : "$out/lib" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' --prefix DYLD_LIBRARY_PATH : "$out/lib" - '' + '' - runHook postInstall - ''; - - preFixup = lib.optionalString stdenv.hostPlatform.isLinux '' - addAutoPatchelfSearchPath "$out/lib" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - change_args=() - - # Change relative @loader_path dylibs to absolute paths. - for lib in $out/lib/*.dylib; do - libname=$(basename $lib) - change_args+=(-change "@loader_path/lib/$libname" "$out/lib/$libname") - done - - # Patches for ovftool binary - change_args+=(-change /usr/lib/libSystem.B.dylib ${darwin.Libsystem}/lib/libSystem.B.dylib) - change_args+=(-change /usr/lib/libc++.1.dylib ${stdenv.cc.libcxx}/lib/libc++.1.dylib) - change_args+=(-change /usr/lib/libiconv.2.dylib ${libiconv}/lib/libiconv.2.dylib) - change_args+=(-change /usr/lib/libxml2.2.dylib ${libxml2}/lib/libxml2.2.dylib) - change_args+=(-change /usr/lib/libz.1.dylib ${zlib}/lib/libz.1.dylib) - change_args+=(-change @loader_path/lib/libcares.2.dylib ${c-ares}/lib/libcares.2.dylib) - change_args+=(-change @loader_path/lib/libexpat.dylib ${expat}/lib/libexpat.dylib) - change_args+=(-change @loader_path/lib/libicudata.60.2.dylib ${icu60}/lib/libicudata.60.2.dylib) - change_args+=(-change @loader_path/lib/libicuuc.60.2.dylib ${icu60}/lib/libicuuc.60.2.dylib) - change_args+=(-change @loader_path/lib/libxerces-c-3.2.dylib ${xercesc}/lib/libxerces-c-3.2.dylib) - - # Patch binary - install_name_tool "''${change_args[@]}" "$out/libexec/ovftool" - - # Additional patches for ovftool dylibs - change_args+=(-change /usr/lib/libresolv.9.dylib ${darwin.Libsystem}/lib/libresolv.9.dylib) - change_args+=(-change @loader_path/libcares.2.dylib ${c-ares}/lib/libcares.2.dylib) - change_args+=(-change @loader_path/libexpat.dylib ${expat}/lib/libexpat.dylib) - change_args+=(-change @loader_path/libicudata.60.2.dylib ${icu60}/lib/libicudata.60.2.dylib) - change_args+=(-change @loader_path/libicuuc.60.2.dylib ${icu60}/lib/libicuuc.60.2.dylib) - change_args+=(-change @loader_path/libxerces-c-3.2.dylib ${xercesc}/lib/libxerces-c-3.2.dylib) - - # Add new abolute paths for other libs to all libs - for lib in $out/lib/*.dylib; do - libname=$(basename $lib) - change_args+=(-change "@loader_path/$libname" "$out/lib/$libname") - done - - # Patch all libs - for lib in $out/lib/*.dylib; do - libname=$(basename $lib) - install_name_tool -id "$libname" "$lib" - install_name_tool "''${change_args[@]}" "$lib" - done - ''; + '' + + '' + runHook postInstall + ''; + + preFixup = + lib.optionalString stdenv.hostPlatform.isLinux '' + addAutoPatchelfSearchPath "$out/lib" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + change_args=() + + # Change relative @loader_path dylibs to absolute paths. + for lib in $out/lib/*.dylib; do + libname=$(basename $lib) + change_args+=(-change "@loader_path/lib/$libname" "$out/lib/$libname") + done + + # Patches for ovftool binary + change_args+=(-change /usr/lib/libSystem.B.dylib ${darwin.Libsystem}/lib/libSystem.B.dylib) + change_args+=(-change /usr/lib/libc++.1.dylib ${stdenv.cc.libcxx}/lib/libc++.1.dylib) + change_args+=(-change /usr/lib/libiconv.2.dylib ${libiconv}/lib/libiconv.2.dylib) + change_args+=(-change /usr/lib/libxml2.2.dylib ${libxml2}/lib/libxml2.2.dylib) + change_args+=(-change /usr/lib/libz.1.dylib ${zlib}/lib/libz.1.dylib) + change_args+=(-change @loader_path/lib/libcares.2.dylib ${c-ares}/lib/libcares.2.dylib) + change_args+=(-change @loader_path/lib/libexpat.dylib ${expat}/lib/libexpat.dylib) + change_args+=(-change @loader_path/lib/libicudata.60.2.dylib ${icu60}/lib/libicudata.60.2.dylib) + change_args+=(-change @loader_path/lib/libicuuc.60.2.dylib ${icu60}/lib/libicuuc.60.2.dylib) + change_args+=(-change @loader_path/lib/libxerces-c-3.2.dylib ${xercesc}/lib/libxerces-c-3.2.dylib) + + # Patch binary + install_name_tool "''${change_args[@]}" "$out/libexec/ovftool" + + # Additional patches for ovftool dylibs + change_args+=(-change /usr/lib/libresolv.9.dylib ${darwin.Libsystem}/lib/libresolv.9.dylib) + change_args+=(-change @loader_path/libcares.2.dylib ${c-ares}/lib/libcares.2.dylib) + change_args+=(-change @loader_path/libexpat.dylib ${expat}/lib/libexpat.dylib) + change_args+=(-change @loader_path/libicudata.60.2.dylib ${icu60}/lib/libicudata.60.2.dylib) + change_args+=(-change @loader_path/libicuuc.60.2.dylib ${icu60}/lib/libicuuc.60.2.dylib) + change_args+=(-change @loader_path/libxerces-c-3.2.dylib ${xercesc}/lib/libxerces-c-3.2.dylib) + + # Add new abolute paths for other libs to all libs + for lib in $out/lib/*.dylib; do + libname=$(basename $lib) + change_args+=(-change "@loader_path/$libname" "$out/lib/$libname") + done + + # Patch all libs + for lib in $out/lib/*.dylib; do + libname=$(basename $lib) + install_name_tool -id "$libname" "$lib" + install_name_tool "''${change_args[@]}" "$lib" + done + ''; # These paths are need for install check tests propagatedSandboxProfile = lib.optionalString stdenv.hostPlatform.isDarwin '' @@ -216,42 +231,47 @@ stdenv.mkDerivation { doInstallCheck = true; - postInstallCheck = lib.optionalString stdenv.hostPlatform.isDarwin '' - export HOME=$TMPDIR - # Construct a dummy /etc/passwd file - ovftool attempts to determine the - # user's "real" home using this - DUMMY_PASSWD="$(realpath $HOME/dummy-passwd)" - cat > $DUMMY_PASSWD < $DUMMY_PASSWD <> scripts/libmakepkg/util/compress.sh.in - substituteInPlace meson.build \ - --replace-fail "install_dir : SYSCONFDIR" "install_dir : '$out/etc'" \ - --replace-fail "join_paths(DATAROOTDIR, 'libalpm/hooks/')" "'${sysHookDir}'" \ - --replace-fail "join_paths(SYSCONFDIR, 'makepkg.conf.d/')" "'$out/etc/makepkg.conf.d/'" - substituteInPlace doc/meson.build \ - --replace-fail "/bin/true" "${coreutils}/bin/true" - substituteInPlace scripts/repo-add.sh.in \ - --replace-fail bsdtar "${libarchive}/bin/bsdtar" + postPatch = + let + compressionTools = [ + gzip + bzip2 + xz + zstd + lrzip + lzop + ncompress + lz4 + lzip + ]; + in + '' + echo 'export PATH=${lib.makeBinPath compressionTools}:$PATH' >> scripts/libmakepkg/util/compress.sh.in + substituteInPlace meson.build \ + --replace-fail "install_dir : SYSCONFDIR" "install_dir : '$out/etc'" \ + --replace-fail "join_paths(DATAROOTDIR, 'libalpm/hooks/')" "'${sysHookDir}'" \ + --replace-fail "join_paths(SYSCONFDIR, 'makepkg.conf.d/')" "'$out/etc/makepkg.conf.d/'" + substituteInPlace doc/meson.build \ + --replace-fail "/bin/true" "${coreutils}/bin/true" + substituteInPlace scripts/repo-add.sh.in \ + --replace-fail bsdtar "${libarchive}/bin/bsdtar" - # Fix https://gitlab.archlinux.org/pacman/pacman/-/issues/171 - substituteInPlace scripts/libmakepkg/source/git.sh.in \ - --replace-warn "---mirror" "--mirror" - ''; + # Fix https://gitlab.archlinux.org/pacman/pacman/-/issues/171 + substituteInPlace scripts/libmakepkg/source/git.sh.in \ + --replace-warn "---mirror" "--mirror" + ''; mesonFlags = [ "--sysconfdir=/etc" @@ -112,14 +117,16 @@ stdenv.mkDerivation (final: { wrapProgram $out/bin/makepkg \ --prefix PATH : ${lib.makeBinPath [ binutils ]} wrapProgram $out/bin/pacman-key \ - --prefix PATH : ${lib.makeBinPath [ - "${placeholder "out"}" - coreutils - gawk - gettext - gnugrep - gnupg - ]} + --prefix PATH : ${ + lib.makeBinPath [ + "${placeholder "out"}" + coreutils + gawk + gettext + gnugrep + gnupg + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/pa/paco/package.nix b/pkgs/by-name/pa/paco/package.nix index 8fa27994ec3d80..1aee35c2e486a9 100644 --- a/pkgs/by-name/pa/paco/package.nix +++ b/pkgs/by-name/pa/paco/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "paco"; @@ -23,7 +28,10 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Simple compiled programming language"; diff --git a/pkgs/by-name/pa/pacparser/package.nix b/pkgs/by-name/pa/pacparser/package.nix index dfef255c15c9a1..3140a829d5220a 100644 --- a/pkgs/by-name/pa/pacparser/package.nix +++ b/pkgs/by-name/pa/pacparser/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "pacparser"; diff --git a/pkgs/by-name/pa/pacproxy/package.nix b/pkgs/by-name/pa/pacproxy/package.nix index b92cf6e10aceb5..5bb1937f7aeb9e 100644 --- a/pkgs/by-name/pa/pacproxy/package.nix +++ b/pkgs/by-name/pa/pacproxy/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/pa/pacu/package.nix b/pkgs/by-name/pa/pacu/package.nix index 73bf7b1a79476e..c837b5fba94849 100644 --- a/pkgs/by-name/pa/pacu/package.nix +++ b/pkgs/by-name/pa/pacu/package.nix @@ -34,7 +34,6 @@ python.pkgs.buildPythonApplication rec { build-system = with python.pkgs; [ poetry-core ]; - dependencies = [ awscli ] ++ (with python.pkgs; [ diff --git a/pkgs/by-name/pa/pacvim/package.nix b/pkgs/by-name/pa/pacvim/package.nix index 8a24cb99ab2196..a9b1aa50d5143d 100644 --- a/pkgs/by-name/pa/pacvim/package.nix +++ b/pkgs/by-name/pa/pacvim/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + ncurses, +}: stdenv.mkDerivation { pname = "pacvim"; diff --git a/pkgs/by-name/pa/padbuster/package.nix b/pkgs/by-name/pa/padbuster/package.nix index de71010ccba590..0c7f7dba1c2729 100644 --- a/pkgs/by-name/pa/padbuster/package.nix +++ b/pkgs/by-name/pa/padbuster/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation rec { pname = "padbuster"; @@ -12,7 +17,13 @@ stdenv.mkDerivation rec { }; buildInputs = [ - (perl.withPackages (ps: with ps; [ LWP LWPProtocolHttps CryptSSLeay ])) + (perl.withPackages ( + ps: with ps; [ + LWP + LWPProtocolHttps + CryptSSLeay + ] + )) ]; installPhase = '' diff --git a/pkgs/by-name/pa/padre/package.nix b/pkgs/by-name/pa/padre/package.nix index aefea32d538631..9b975e67cc64ae 100644 --- a/pkgs/by-name/pa/padre/package.nix +++ b/pkgs/by-name/pa/padre/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/pa/page/package.nix b/pkgs/by-name/pa/page/package.nix index 889baff28b2599..a469b20a2a4bf7 100644 --- a/pkgs/by-name/pa/page/package.nix +++ b/pkgs/by-name/pa/page/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, fetchpatch, installShellFiles }: +{ + lib, + rustPlatform, + fetchFromGitHub, + fetchpatch, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "page"; diff --git a/pkgs/by-name/pa/pagemon/package.nix b/pkgs/by-name/pa/pagemon/package.nix index c05bd6183fc481..edc7c34c10f6fe 100644 --- a/pkgs/by-name/pa/pagemon/package.nix +++ b/pkgs/by-name/pa/pagemon/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { pname = "pagemon"; diff --git a/pkgs/by-name/pa/paging-calculator/package.nix b/pkgs/by-name/pa/paging-calculator/package.nix index 43ec8ccd74479a..4fd53549deacda 100644 --- a/pkgs/by-name/pa/paging-calculator/package.nix +++ b/pkgs/by-name/pa/paging-calculator/package.nix @@ -1,6 +1,7 @@ -{ fetchCrate -, lib -, rustPlatform +{ + fetchCrate, + lib, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pa/pagmo2/package.nix b/pkgs/by-name/pa/pagmo2/package.nix index e39f059e31d26a..1948ad97b4df88 100644 --- a/pkgs/by-name/pa/pagmo2/package.nix +++ b/pkgs/by-name/pa/pagmo2/package.nix @@ -1,13 +1,15 @@ -{ fetchFromGitHub -, lib, stdenv -, cmake -, eigen -, nlopt -, ipopt -, boost -, tbb - # tests pass but take 30+ minutes -, runTests ? false +{ + fetchFromGitHub, + lib, + stdenv, + cmake, + eigen, + nlopt, + ipopt, + boost, + tbb, + # tests pass but take 30+ minutes + runTests ? false, }: stdenv.mkDerivation rec { @@ -15,28 +17,36 @@ stdenv.mkDerivation rec { version = "2.19.1"; src = fetchFromGitHub { - owner = "esa"; - repo = "pagmo2"; - rev = "v${version}"; - sha256 = "sha256-ido3e0hQLDEPT0AmsfAVTPlGbWe5QBkxgRO6Fg1wp/c="; + owner = "esa"; + repo = "pagmo2"; + rev = "v${version}"; + sha256 = "sha256-ido3e0hQLDEPT0AmsfAVTPlGbWe5QBkxgRO6Fg1wp/c="; }; nativeBuildInputs = [ cmake ]; - buildInputs = [ eigen nlopt boost tbb ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) ipopt; + buildInputs = [ + eigen + nlopt + boost + tbb + ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) ipopt; - cmakeFlags = [ - "-DPAGMO_BUILD_TESTS=${if runTests then "ON" else "OFF"}" - "-DPAGMO_WITH_EIGEN3=yes" - "-DPAGMO_WITH_NLOPT=yes" - "-DNLOPT_LIBRARY=${nlopt}/lib/libnlopt${stdenv.hostPlatform.extensions.sharedLibrary}" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "-DPAGMO_WITH_IPOPT=yes" - "-DCMAKE_CXX_FLAGS='-fuse-ld=gold'" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # FIXME: fails ipopt test with Invalid_Option on darwin, so disable. - "-DPAGMO_WITH_IPOPT=no" - "-DLLVM_USE_LINKER=gold" - ]; + cmakeFlags = + [ + "-DPAGMO_BUILD_TESTS=${if runTests then "ON" else "OFF"}" + "-DPAGMO_WITH_EIGEN3=yes" + "-DPAGMO_WITH_NLOPT=yes" + "-DNLOPT_LIBRARY=${nlopt}/lib/libnlopt${stdenv.hostPlatform.extensions.sharedLibrary}" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "-DPAGMO_WITH_IPOPT=yes" + "-DCMAKE_CXX_FLAGS='-fuse-ld=gold'" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # FIXME: fails ipopt test with Invalid_Option on darwin, so disable. + "-DPAGMO_WITH_IPOPT=no" + "-DLLVM_USE_LINKER=gold" + ]; doCheck = runTests; diff --git a/pkgs/by-name/pa/paho-mqtt-c/package.nix b/pkgs/by-name/pa/paho-mqtt-c/package.nix index 23f0bc99c88adc..f8cc322dbf2890 100644 --- a/pkgs/by-name/pa/paho-mqtt-c/package.nix +++ b/pkgs/by-name/pa/paho-mqtt-c/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, openssl, enableStatic ? stdenv.hostPlatform.isStatic, enableShared ? !stdenv.hostPlatform.isStatic }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openssl, + enableStatic ? stdenv.hostPlatform.isStatic, + enableShared ? !stdenv.hostPlatform.isStatic, +}: stdenv.mkDerivation rec { pname = "paho.mqtt.c"; diff --git a/pkgs/by-name/pa/pahole/package.nix b/pkgs/by-name/pa/pahole/package.nix index d82c76eb769c9e..444b165cb80d01 100644 --- a/pkgs/by-name/pa/pahole/package.nix +++ b/pkgs/by-name/pa/pahole/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchzip -, pkg-config -, libbpf -, cmake -, elfutils -, zlib -, argp-standalone -, musl-obstack -, nixosTests -, fetchpatch +{ + lib, + stdenv, + fetchzip, + pkg-config, + libbpf, + cmake, + elfutils, + zlib, + argp-standalone, + musl-obstack, + nixosTests, + fetchpatch, }: stdenv.mkDerivation rec { @@ -20,12 +21,20 @@ stdenv.mkDerivation rec { hash = "sha256-BwA17lc2yegmOzLfoIu8OmG/PVdc+4sOGzB8Jc4ZjGM="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ elfutils zlib libbpf ] - ++ lib.optionals stdenv.hostPlatform.isMusl [ - argp-standalone - musl-obstack + nativeBuildInputs = [ + cmake + pkg-config ]; + buildInputs = + [ + elfutils + zlib + libbpf + ] + ++ lib.optionals stdenv.hostPlatform.isMusl [ + argp-standalone + musl-obstack + ]; patches = [ # https://github.com/acmel/dwarves/pull/51 / https://lkml.kernel.org/r/20240626032253.3406460-1-asmadeus@codewreck.org @@ -44,7 +53,10 @@ stdenv.mkDerivation rec { ]; # Put libraries in "lib" subdirectory, not top level of $out - cmakeFlags = [ "-D__LIB=lib" "-DLIBBPF_EMBEDDED=OFF" ]; + cmakeFlags = [ + "-D__LIB=lib" + "-DLIBBPF_EMBEDDED=OFF" + ]; passthru.tests = { inherit (nixosTests) bpf; @@ -56,6 +68,9 @@ stdenv.mkDerivation rec { license = licenses.gpl2Only; platforms = platforms.linux; - maintainers = with maintainers; [ bosu martinetd ]; + maintainers = with maintainers; [ + bosu + martinetd + ]; }; } diff --git a/pkgs/by-name/pa/pairdrop/package.nix b/pkgs/by-name/pa/pairdrop/package.nix index f5ffafdb8015bc..9d4fce5c23bac9 100644 --- a/pkgs/by-name/pa/pairdrop/package.nix +++ b/pkgs/by-name/pa/pairdrop/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, nodejs +{ + lib, + buildNpmPackage, + fetchFromGitHub, + nodejs, }: buildNpmPackage rec { diff --git a/pkgs/by-name/pa/pal/package.nix b/pkgs/by-name/pa/pal/package.nix index 69d8bde9a7d418..f8189b385860e4 100644 --- a/pkgs/by-name/pa/pal/package.nix +++ b/pkgs/by-name/pa/pal/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchurl, glib, gettext, readline, pkg-config }: +{ + lib, + stdenv, + fetchurl, + glib, + gettext, + readline, + pkg-config, +}: stdenv.mkDerivation rec { pname = "pal"; @@ -16,7 +24,11 @@ stdenv.mkDerivation rec { makeFlags = [ "prefix=$(out)" ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib gettext readline ]; + buildInputs = [ + glib + gettext + readline + ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/pa/paleta/package.nix b/pkgs/by-name/pa/paleta/package.nix index 6275b3d10e4c1c..e9a26b9274e50e 100644 --- a/pkgs/by-name/pa/paleta/package.nix +++ b/pkgs/by-name/pa/paleta/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, cargo -, meson -, ninja -, pkg-config -, rustc -, wrapGAppsHook4 -, appstream-glib -, desktop-file-utils -, glib -, gtk4 -, libadwaita +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + cargo, + meson, + ninja, + pkg-config, + rustc, + wrapGAppsHook4, + appstream-glib, + desktop-file-utils, + glib, + gtk4, + libadwaita, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pa/palp/package.nix b/pkgs/by-name/pa/palp/package.nix index 0db35ba89ae611..d365d11c015863 100644 --- a/pkgs/by-name/pa/palp/package.nix +++ b/pkgs/by-name/pa/palp/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, dimensions ? 6 # works for <= dimensions dimensions, but is only optimized for that exact value -, doSymlink ? true # symlink the executables to the default location (without dimension postfix) +{ + lib, + stdenv, + fetchurl, + dimensions ? 6, # works for <= dimensions dimensions, but is only optimized for that exact value + doSymlink ? true, # symlink the executables to the default location (without dimension postfix) }: let @@ -42,17 +43,19 @@ stdenv.mkDerivation rec { EOF ''; - installPhase = '' - mkdir -p $out/bin - for file in poly class cws nef mori; do - cp -p $file.x "$out/bin/$file-${dim}d.x" - done - '' + lib.optionalString doSymlink '' - cd $out/bin - for file in poly class cws nef mori; do - ln -sf $file-6d.x $file.x - done - ''; + installPhase = + '' + mkdir -p $out/bin + for file in poly class cws nef mori; do + cp -p $file.x "$out/bin/$file-${dim}d.x" + done + '' + + lib.optionalString doSymlink '' + cd $out/bin + for file in poly class cws nef mori; do + ln -sf $file-6d.x $file.x + done + ''; meta = with lib; { description = "Package for Analyzing Lattice Polytopes"; diff --git a/pkgs/by-name/pa/pam-honeycreds/package.nix b/pkgs/by-name/pa/pam-honeycreds/package.nix index 9c96e1c317fdfd..ea0e155e3cc096 100644 --- a/pkgs/by-name/pa/pam-honeycreds/package.nix +++ b/pkgs/by-name/pa/pam-honeycreds/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, pam +{ + lib, + stdenv, + fetchFromGitHub, + pam, }: stdenv.mkDerivation (finalAttrs: { pname = "pam-honeycreds"; diff --git a/pkgs/by-name/pa/pam-reattach/package.nix b/pkgs/by-name/pa/pam-reattach/package.nix index b077ac031b62c8..6c3ccdf442ddbb 100644 --- a/pkgs/by-name/pa/pam-reattach/package.nix +++ b/pkgs/by-name/pa/pam-reattach/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, openpam, darwin }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openpam, + darwin, +}: let sdkOlderThan11 = lib.versionOlder stdenv.hostPlatform.darwinSdkVersion "11.0"; @@ -19,8 +26,7 @@ stdenv.mkDerivation rec { "-DENABLE_CLI=ON" ] ++ lib.optional sdkOlderThan11 "-DCMAKE_LIBRARY_PATH=${darwin.apple_sdk.sdk}/usr/lib"; - buildInputs = [ openpam ] - ++ lib.optional sdkOlderThan11 darwin.apple_sdk.sdk; + buildInputs = [ openpam ] ++ lib.optional sdkOlderThan11 darwin.apple_sdk.sdk; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/by-name/pa/pam_ccreds/package.nix b/pkgs/by-name/pa/pam_ccreds/package.nix index 1921193d70311a..2a052547817eb6 100644 --- a/pkgs/by-name/pa/pam_ccreds/package.nix +++ b/pkgs/by-name/pa/pam_ccreds/package.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchurl, pam, openssl, db}: +{ + lib, + stdenv, + fetchurl, + pam, + openssl, + db, +}: stdenv.mkDerivation rec { pname = "pam_ccreds"; @@ -12,7 +19,11 @@ stdenv.mkDerivation rec { sed 's/-o root -g root//' -i Makefile.in ''; - buildInputs = [ pam openssl db ]; + buildInputs = [ + pam + openssl + db + ]; meta = with lib; { homepage = "https://www.padl.com/OSS/pam_ccreds.html"; diff --git a/pkgs/by-name/pa/pam_dp9ik/package.nix b/pkgs/by-name/pa/pam_dp9ik/package.nix index bd097caee497ce..c464966b0c4172 100644 --- a/pkgs/by-name/pa/pam_dp9ik/package.nix +++ b/pkgs/by-name/pa/pam_dp9ik/package.nix @@ -1,8 +1,9 @@ -{ lib -, tlsclient -, stdenv -, pkg-config -, pam +{ + lib, + tlsclient, + stdenv, + pkg-config, + pam, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/pa/pam_gnupg/package.nix b/pkgs/by-name/pa/pam_gnupg/package.nix index 1c54c42120ab71..ff5546320ec292 100644 --- a/pkgs/by-name/pa/pam_gnupg/package.nix +++ b/pkgs/by-name/pa/pam_gnupg/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pam, gnupg }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pam, + gnupg, +}: stdenv.mkDerivation rec { pname = "pam_gnupg"; @@ -15,7 +22,10 @@ stdenv.mkDerivation rec { "--with-moduledir=${placeholder "out"}/lib/security" ]; - buildInputs = [ pam gnupg ]; + buildInputs = [ + pam + gnupg + ]; nativeBuildInputs = [ autoreconfHook ]; diff --git a/pkgs/by-name/pa/pam_krb5/package.nix b/pkgs/by-name/pa/pam_krb5/package.nix index 157226373db0a6..bc82835518e4eb 100644 --- a/pkgs/by-name/pa/pam_krb5/package.nix +++ b/pkgs/by-name/pa/pam_krb5/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pam, libkrb5 }: +{ + lib, + stdenv, + fetchurl, + pam, + libkrb5, +}: stdenv.mkDerivation rec { pname = "pam-krb5"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-UDy+LLGv9L39o7z3+T+U+2ulLCbXCJNOcDmyGC/hCyA="; }; - buildInputs = [ pam libkrb5 ]; + buildInputs = [ + pam + libkrb5 + ]; meta = with lib; { homepage = "https://www.eyrie.org/~eagle/software/pam-krb5/"; diff --git a/pkgs/by-name/pa/pam_ldap/package.nix b/pkgs/by-name/pa/pam_ldap/package.nix index 988256808dbb88..98f0c1b493f5fd 100644 --- a/pkgs/by-name/pa/pam_ldap/package.nix +++ b/pkgs/by-name/pa/pam_ldap/package.nix @@ -1,4 +1,10 @@ -{ stdenv, fetchurl, pam, openldap, perl }: +{ + stdenv, + fetchurl, + pam, + openldap, + perl, +}: stdenv.mkDerivation rec { pname = "pam_ldap"; @@ -19,7 +25,10 @@ stdenv.mkDerivation rec { "; nativeBuildInputs = [ perl ]; - buildInputs = [ pam openldap ]; + buildInputs = [ + pam + openldap + ]; meta = { homepage = "https://www.padl.com/OSS/pam_ldap.html"; diff --git a/pkgs/by-name/pa/pam_mktemp/package.nix b/pkgs/by-name/pa/pam_mktemp/package.nix index 04ba58785efabd..8103c0023d9707 100644 --- a/pkgs/by-name/pa/pam_mktemp/package.nix +++ b/pkgs/by-name/pa/pam_mktemp/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, pam -, e2fsprogs +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pam, + e2fsprogs, }: stdenv.mkDerivation rec { @@ -20,7 +21,7 @@ stdenv.mkDerivation rec { name = "inherit_private_prefix_from_home.patch"; url = "https://git.altlinux.org/gears/p/pam_mktemp.git?p=pam_mktemp.git;a=commitdiff_plain;h=3d2e8ad6da6a44c047bf7a8afa1e1bb2a6e36a55"; hash = "sha256-xe44fi2xH9jqlStlIR4QPB0KS7spflRdOsvNPEmxJpU"; - }) + }) (fetchpatch { name = "allow_private_prefix_to_be_stricter.patch"; url = "https://git.altlinux.org/gears/p/pam_mktemp.git?p=pam_mktemp.git;a=commitdiff_plain;h=bb2cee0c695d22310e5364c30d74bccb0dbf3205"; @@ -32,7 +33,10 @@ stdenv.mkDerivation rec { dontConfigure = true; - buildInputs = [ pam e2fsprogs ]; + buildInputs = [ + pam + e2fsprogs + ]; makeFlags = [ "DESTDIR=$(out)" ]; diff --git a/pkgs/by-name/pa/pam_mount/package.nix b/pkgs/by-name/pa/pam_mount/package.nix index 81199cb057c697..950ba5ce1fd085 100644 --- a/pkgs/by-name/pa/pam_mount/package.nix +++ b/pkgs/by-name/pa/pam_mount/package.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pkg-config, libtool, pam, libHX, libxml2, pcre2, perl, openssl, cryptsetup, util-linux }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + libtool, + pam, + libHX, + libxml2, + pcre2, + perl, + openssl, + cryptsetup, + util-linux, +}: stdenv.mkDerivation rec { pname = "pam_mount"; @@ -52,7 +67,12 @@ stdenv.mkDerivation rec { meta = with lib; { description = "PAM module to mount volumes for a user session"; homepage = "https://pam-mount.sourceforge.net/"; - license = with licenses; [ gpl2Plus gpl3 lgpl21 lgpl3 ]; + license = with licenses; [ + gpl2Plus + gpl3 + lgpl21 + lgpl3 + ]; maintainers = with maintainers; [ netali ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/pa/pam_mysql/package.nix b/pkgs/by-name/pa/pam_mysql/package.nix index 1088d8abe7a637..d562b24c12009a 100644 --- a/pkgs/by-name/pa/pam_mysql/package.nix +++ b/pkgs/by-name/pa/pam_mysql/package.nix @@ -1,14 +1,15 @@ -{ lib -, nixosTests -, stdenv -, fetchFromGitHub -, meson -, ninja -, pam -, pkg-config -, libmysqlclient -, mariadb -, libxcrypt +{ + lib, + nixosTests, + stdenv, + fetchFromGitHub, + meson, + ninja, + pam, + pkg-config, + libmysqlclient, + mariadb, + libxcrypt, }: stdenv.mkDerivation rec { @@ -22,8 +23,17 @@ stdenv.mkDerivation rec { sha256 = "07acf0hbhkd0kg49gnj4nb5ilnv3v4xx3dsggvzvjg8gi3cjmsap"; }; - nativeBuildInputs = [ meson pkg-config ninja ]; - buildInputs = [ pam libmysqlclient mariadb libxcrypt ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + ]; + buildInputs = [ + pam + libmysqlclient + mariadb + libxcrypt + ]; passthru.tests = { inherit (nixosTests) auth-mysql; diff --git a/pkgs/by-name/pa/pam_p11/package.nix b/pkgs/by-name/pa/pam_p11/package.nix index a1e1dc109a1582..504b31fe7557be 100644 --- a/pkgs/by-name/pa/pam_p11/package.nix +++ b/pkgs/by-name/pa/pam_p11/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, libp11, pam, libintl, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libp11, + pam, + libintl, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "pam_p11"; @@ -22,9 +32,15 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ pam libp11.passthru.openssl libp11 ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libintl ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + pam + libp11.passthru.openssl + libp11 + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libintl ]; meta = with lib; { homepage = "https://github.com/OpenSC/pam_p11"; diff --git a/pkgs/by-name/pa/pam_pgsql/package.nix b/pkgs/by-name/pa/pam_pgsql/package.nix index 2eabcefe584c6a..326859b3367a11 100644 --- a/pkgs/by-name/pa/pam_pgsql/package.nix +++ b/pkgs/by-name/pa/pam_pgsql/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, postgresql, libgcrypt, pam, libxcrypt }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + postgresql, + libgcrypt, + pam, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "pam_pgsql"; @@ -11,8 +21,16 @@ stdenv.mkDerivation rec { sha256 = "1bvddrwyk1479wibyayzc24h62qzfnlbk9qvdhb31yw9yn17gp6k"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libgcrypt pam postgresql libxcrypt ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libgcrypt + pam + postgresql + libxcrypt + ]; meta = with lib; { description = "Support to authenticate against PostgreSQL for PAM-enabled appliations"; diff --git a/pkgs/by-name/pa/pam_ssh_agent_auth/package.nix b/pkgs/by-name/pa/pam_ssh_agent_auth/package.nix index eca49afa63fedd..178deb281d4d54 100644 --- a/pkgs/by-name/pa/pam_ssh_agent_auth/package.nix +++ b/pkgs/by-name/pa/pam_ssh_agent_auth/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, nixosTests, fetchFromGitHub, pam, openssl, perl }: +{ + lib, + stdenv, + nixosTests, + fetchFromGitHub, + pam, + openssl, + perl, +}: stdenv.mkDerivation rec { pname = "pam_ssh_agent_auth"; @@ -18,7 +26,11 @@ stdenv.mkDerivation rec { sha256 = "ETFpIaWQnlYG8ZuDG2dNjUJddlvibB4ukHquTFn3NZM="; }; - buildInputs = [ pam openssl perl ]; + buildInputs = [ + pam + openssl + perl + ]; patches = [ # Allow multiple colon-separated authorized keys files to be diff --git a/pkgs/by-name/pa/pam_tmpdir/package.nix b/pkgs/by-name/pa/pam_tmpdir/package.nix index 2eee7c92f5c30a..083c4eda73cc4d 100644 --- a/pkgs/by-name/pa/pam_tmpdir/package.nix +++ b/pkgs/by-name/pa/pam_tmpdir/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pam }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pam, +}: stdenv.mkDerivation rec { pname = "pam_tmpdir"; diff --git a/pkgs/by-name/pa/pam_u2f/package.nix b/pkgs/by-name/pa/pam_u2f/package.nix index 715f60e1939933..455592a99506ed 100644 --- a/pkgs/by-name/pa/pam_u2f/package.nix +++ b/pkgs/by-name/pa/pam_u2f/package.nix @@ -1,16 +1,28 @@ -{ lib, stdenv, fetchurl, pkg-config, libfido2, pam, openssl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libfido2, + pam, + openssl, +}: stdenv.mkDerivation rec { pname = "pam_u2f"; version = "1.3.0"; - src = fetchurl { + src = fetchurl { url = "https://developers.yubico.com/pam-u2f/Releases/${pname}-${version}.tar.gz"; sha256 = "sha256-cjYMaHVIXrTfQJ2o+PUrF4k/BeTZmFKcI4gUSA4RUiA="; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libfido2 pam openssl ]; + buildInputs = [ + libfido2 + pam + openssl + ]; preConfigure = '' configureFlagsArray+=("--with-pam-dir=$out/lib/security") diff --git a/pkgs/by-name/pa/pam_ussh/package.nix b/pkgs/by-name/pa/pam_ussh/package.nix index 028b33bc9316b8..cf97026aba39d5 100644 --- a/pkgs/by-name/pa/pam_ussh/package.nix +++ b/pkgs/by-name/pa/pam_ussh/package.nix @@ -1,8 +1,9 @@ -{ buildGoModule -, fetchFromGitHub -, pam -, lib -, nixosTests +{ + buildGoModule, + fetchFromGitHub, + pam, + lib, + nixosTests, }: buildGoModule rec { @@ -12,7 +13,7 @@ buildGoModule rec { src = fetchFromGitHub { owner = "uber"; repo = "pam-ussh"; - rev = "e9524bda90ba19d3b9eb24f49cb63a6a56a19193"; # HEAD as of 2022-03-13 + rev = "e9524bda90ba19d3b9eb24f49cb63a6a56a19193"; # HEAD as of 2022-03-13 sha256 = "0nb9hpqbghgi3zvq41kabydzyc6ffaaw9b4jkc5jrwn1klpw1xk8"; }; diff --git a/pkgs/by-name/pa/pamix/package.nix b/pkgs/by-name/pa/pamix/package.nix index fb1d0bfb3d4121..1c8ebe94ace83b 100644 --- a/pkgs/by-name/pa/pamix/package.nix +++ b/pkgs/by-name/pa/pamix/package.nix @@ -1,15 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, pkg-config, cmake -, libpulseaudio, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + cmake, + libpulseaudio, + ncurses, +}: stdenv.mkDerivation rec { pname = "pamix"; version = "1.6"; src = fetchFromGitHub { - owner = "patroclos"; - repo = "pamix"; - rev = version; + owner = "patroclos"; + repo = "pamix"; + rev = version; sha256 = "1d44ggnwkf2gff62959pj45v3a2k091q8v154wc5pmzamam458wp"; }; @@ -31,14 +38,20 @@ stdenv.mkDerivation rec { substituteInPlace CMakeLists.txt --replace "/etc" "$out/etc/xdg" ''; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libpulseaudio ncurses ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + libpulseaudio + ncurses + ]; meta = with lib; { description = "Pulseaudio terminal mixer"; - homepage = "https://github.com/patroclos/PAmix"; - license = licenses.mit; - platforms = platforms.linux; + homepage = "https://github.com/patroclos/PAmix"; + license = licenses.mit; + platforms = platforms.linux; maintainers = with maintainers; [ ericsagnes ]; mainProgram = "pamix"; }; diff --git a/pkgs/by-name/pa/pamixer/package.nix b/pkgs/by-name/pa/pamixer/package.nix index 65d58ffd57749c..cab4a6e0d8af01 100644 --- a/pkgs/by-name/pa/pamixer/package.nix +++ b/pkgs/by-name/pa/pamixer/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, boost -, cxxopts -, libpulseaudio -, meson -, ninja -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + boost, + cxxopts, + libpulseaudio, + meson, + ninja, + pkg-config, }: stdenv.mkDerivation rec { @@ -20,9 +21,17 @@ stdenv.mkDerivation rec { hash = "sha256-LbRhsW2MiTYWSH6X9Pz9XdJdH9Na0QCO8CFmlzZmDjQ="; }; - nativeBuildInputs = [ pkg-config meson ninja ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + ]; - buildInputs = [ boost cxxopts libpulseaudio ]; + buildInputs = [ + boost + cxxopts + libpulseaudio + ]; meta = with lib; { description = "Pulseaudio command line mixer"; diff --git a/pkgs/by-name/pa/paml/package.nix b/pkgs/by-name/pa/paml/package.nix index 1e21d18242bd21..9fca986e5930e9 100644 --- a/pkgs/by-name/pa/paml/package.nix +++ b/pkgs/by-name/pa/paml/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation (finalAttrs: { @@ -38,10 +39,10 @@ stdenv.mkDerivation (finalAttrs: { ''; meta = { - description = "Phylogenetic Analysis by Maximum Likelihood (PAML)"; + description = "Phylogenetic Analysis by Maximum Likelihood (PAML)"; longDescription = "PAML is a package of programs for phylogenetic analyses of DNA or protein sequences using maximum likelihood. It is maintained and distributed for academic use free of charge by Ziheng Yang. ANSI C source codes are distributed for UNIX/Linux/Mac OSX, and executables are provided for MS Windows. PAML is not good for tree making. It may be used to estimate parameters and test hypotheses to study the evolutionary process, when you have reconstructed trees using other programs such as PAUP*, PHYLIP, MOLPHY, PhyML, RaxML, etc."; - license = lib.licenses.gpl3Only; - homepage = "http://abacus.gene.ucl.ac.uk/software/paml.html"; + license = lib.licenses.gpl3Only; + homepage = "http://abacus.gene.ucl.ac.uk/software/paml.html"; changelog = "https://github.com/abacus-gene/paml/releases/tag/${lib.removePrefix "refs/tags/" finalAttrs.src.rev}"; platforms = lib.platforms.unix; }; diff --git a/pkgs/by-name/pa/pamtester/package.nix b/pkgs/by-name/pa/pamtester/package.nix index 7261be60f77f64..aa8eba4c6f5cb2 100644 --- a/pkgs/by-name/pa/pamtester/package.nix +++ b/pkgs/by-name/pa/pamtester/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, pam }: +{ + lib, + stdenv, + fetchurl, + pam, +}: stdenv.mkDerivation rec { pname = "pamtester"; diff --git a/pkgs/by-name/pa/pan-bindings/package.nix b/pkgs/by-name/pa/pan-bindings/package.nix index 04c240ccc9bc52..904d5e59e548cb 100644 --- a/pkgs/by-name/pa/pan-bindings/package.nix +++ b/pkgs/by-name/pa/pan-bindings/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildGoModule -, cmake -, ncurses -, asio +{ + lib, + stdenv, + fetchFromGitHub, + buildGoModule, + cmake, + ncurses, + asio, }: let @@ -15,12 +16,14 @@ let rev = "4361d30f1c5145a70651c259f2d56369725b0d15"; hash = "sha256-0WxrgXTCM+BwGcjjWBBKiZawje2yxB5RRac6Sk5t3qc="; }; - goDeps = (buildGoModule { - name = "pan-bindings-goDeps"; - inherit src version; - modRoot = "go"; - vendorHash = "sha256-7EitdEJTRtiM29qmVnZUM6w68vCBI8mxZhCA7SnAxLA="; - }); + goDeps = ( + buildGoModule { + name = "pan-bindings-goDeps"; + inherit src version; + modRoot = "go"; + vendorHash = "sha256-7EitdEJTRtiM29qmVnZUM6w68vCBI8mxZhCA7SnAxLA="; + } + ); in stdenv.mkDerivation { diff --git a/pkgs/by-name/pa/pan/package.nix b/pkgs/by-name/pa/pan/package.nix index 4e23246a6d4280..d9d22c6b43a03f 100644 --- a/pkgs/by-name/pa/pan/package.nix +++ b/pkgs/by-name/pa/pan/package.nix @@ -1,23 +1,24 @@ -{ spellChecking ? true -, lib -, stdenv -, fetchFromGitLab -, autoreconfHook -, pkg-config -, gtk3 -, gtkspell3 -, gmime3 -, gettext -, intltool -, itstool -, libxml2 -, libnotify -, gnutls -, makeWrapper -, gnupg -, gnomeSupport ? true -, libsecret -, gcr +{ + spellChecking ? true, + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + gtk3, + gtkspell3, + gmime3, + gettext, + intltool, + itstool, + libxml2, + libnotify, + gnutls, + makeWrapper, + gnupg, + gnomeSupport ? true, + libsecret, + gcr, }: stdenv.mkDerivation rec { @@ -32,19 +33,38 @@ stdenv.mkDerivation rec { hash = "sha256-gcs3TsUzZAW8PhNPMzyOfwu+2SNynjRgfxdGIfAHrpA="; }; - nativeBuildInputs = [ autoreconfHook pkg-config gettext intltool itstool libxml2 makeWrapper ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + gettext + intltool + itstool + libxml2 + makeWrapper + ]; - buildInputs = [ gtk3 gmime3 libnotify gnutls ] + buildInputs = + [ + gtk3 + gmime3 + libnotify + gnutls + ] ++ lib.optional spellChecking gtkspell3 - ++ lib.optionals gnomeSupport [ libsecret gcr ]; + ++ lib.optionals gnomeSupport [ + libsecret + gcr + ]; - configureFlags = [ - "--with-dbus" - "--with-gtk3" - "--with-gnutls" - "--enable-libnotify" - ] ++ lib.optional spellChecking "--with-gtkspell" - ++ lib.optional gnomeSupport "--enable-gkr"; + configureFlags = + [ + "--with-dbus" + "--with-gtk3" + "--with-gnutls" + "--enable-libnotify" + ] + ++ lib.optional spellChecking "--with-gtkspell" + ++ lib.optional gnomeSupport "--enable-gkr"; postInstall = '' wrapProgram $out/bin/pan --suffix PATH : ${gnupg}/bin @@ -58,6 +78,9 @@ stdenv.mkDerivation rec { homepage = "http://pan.rebelbase.com/"; maintainers = with maintainers; [ aleksana ]; platforms = platforms.linux; - license = with licenses; [ gpl2Only fdl11Only ]; + license = with licenses; [ + gpl2Only + fdl11Only + ]; }; } diff --git a/pkgs/by-name/pa/panamax/package.nix b/pkgs/by-name/pa/panamax/package.nix index 3ca774d0d30fdf..759a2d83d5ab97 100644 --- a/pkgs/by-name/pa/panamax/package.nix +++ b/pkgs/by-name/pa/panamax/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, libgit2 -, openssl -, zlib -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + libgit2, + openssl, + zlib, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -22,20 +23,25 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - libgit2 - openssl - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + libgit2 + openssl + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; meta = with lib; { description = "Mirror rustup and crates.io repositories for offline Rust and cargo usage"; mainProgram = "panamax"; homepage = "https://github.com/panamax-rs/panamax"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/pa/pandoc-katex/package.nix b/pkgs/by-name/pa/pandoc-katex/package.nix index d2b9f03e51a47e..12cd5047819b83 100644 --- a/pkgs/by-name/pa/pandoc-katex/package.nix +++ b/pkgs/by-name/pa/pandoc-katex/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "pandoc-katex"; @@ -16,8 +20,14 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Pandoc filter to render math equations using KaTeX"; homepage = "https://github.com/xu-cheng/pandoc-katex"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ minijackson pacien ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + minijackson + pacien + ]; mainProgram = "pandoc-katex"; }; } diff --git a/pkgs/by-name/pa/pandoc-lua-filters/package.nix b/pkgs/by-name/pa/pandoc-lua-filters/package.nix index d779cbb7fa4067..d44b5e94bd2e0e 100644 --- a/pkgs/by-name/pa/pandoc-lua-filters/package.nix +++ b/pkgs/by-name/pa/pandoc-lua-filters/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pa/panicparse/package.nix b/pkgs/by-name/pa/panicparse/package.nix index 379d4ac8ba607d..f0ab5e64e45e81 100644 --- a/pkgs/by-name/pa/panicparse/package.nix +++ b/pkgs/by-name/pa/panicparse/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/pa/panopticon/package.nix b/pkgs/by-name/pa/panopticon/package.nix index 01ba9da439a487..9ed89a80d1264b 100644 --- a/pkgs/by-name/pa/panopticon/package.nix +++ b/pkgs/by-name/pa/panopticon/package.nix @@ -1,5 +1,13 @@ -{ lib, fetchFromGitHub, rustPlatform, qt5, git, cmake -, pkg-config, makeWrapper }: +{ + lib, + fetchFromGitHub, + rustPlatform, + qt5, + git, + cmake, + pkg-config, + makeWrapper, +}: rustPlatform.buildRustPackage rec { pname = "panopticon"; @@ -12,14 +20,18 @@ rustPlatform.buildRustPackage rec { sha256 = "1zv87nqhrzsxx0m891df4vagzssj3kblfv9yp7j96dw0vn9950qa"; }; - nativeBuildInputs = [ cmake pkg-config makeWrapper ]; + nativeBuildInputs = [ + cmake + pkg-config + makeWrapper + ]; propagatedBuildInputs = with qt5; [ - qt5.qtbase - qtdeclarative - qtsvg - qtquickcontrols2 - qtgraphicaleffects - git + qt5.qtbase + qtdeclarative + qtsvg + qtquickcontrols2 + qtgraphicaleffects + git ]; dontWrapQtApps = true; @@ -33,7 +45,7 @@ rustPlatform.buildRustPackage rec { mv $out/bin/${pname} $out/share/${pname} chmod +x $out/share/${pname} makeWrapper $out/share/${pname}/${pname} $out/bin/${pname} - ''; + ''; meta = with lib; { description = "Libre cross-platform disassembler"; diff --git a/pkgs/by-name/pa/panotools/package.nix b/pkgs/by-name/pa/panotools/package.nix index 494fd093ac4adc..1616159e31c1a0 100644 --- a/pkgs/by-name/pa/panotools/package.nix +++ b/pkgs/by-name/pa/panotools/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, cmake -, libjpeg -, libpng -, libtiff -, perl -, darwin +{ + lib, + stdenv, + fetchurl, + cmake, + libjpeg, + libpng, + libtiff, + perl, + darwin, }: stdenv.mkDerivation (finalAttrs: { @@ -25,13 +26,15 @@ stdenv.mkDerivation (finalAttrs: { perl ]; - buildInputs = [ - libjpeg - libpng - libtiff - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Carbon - ]; + buildInputs = + [ + libjpeg + libpng + libtiff + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Carbon + ]; meta = { description = "Free software suite for authoring and displaying virtual reality panoramas"; diff --git a/pkgs/by-name/pa/pantheon-tweaks/package.nix b/pkgs/by-name/pa/pantheon-tweaks/package.nix index ab266b16c43a25..2d76fdd0b3c4e5 100644 --- a/pkgs/by-name/pa/pantheon-tweaks/package.nix +++ b/pkgs/by-name/pa/pantheon-tweaks/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, sassc -, vala -, wrapGAppsHook4 -, gtk4 -, libgee -, pango -, pantheon +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + sassc, + vala, + wrapGAppsHook4, + gtk4, + libgee, + pango, + pantheon, }: stdenv.mkDerivation rec { @@ -34,16 +35,18 @@ stdenv.mkDerivation rec { wrapGAppsHook4 ]; - buildInputs = [ - gtk4 - libgee - pango - ] ++ (with pantheon; [ - elementary-files # settings schemas - elementary-terminal # settings schemas - granite7 - switchboard - ]); + buildInputs = + [ + gtk4 + libgee + pango + ] + ++ (with pantheon; [ + elementary-files # settings schemas + elementary-terminal # settings schemas + granite7 + switchboard + ]); postPatch = '' substituteInPlace src/Settings/ThemeSettings.vala \ diff --git a/pkgs/by-name/pa/pantum-driver/package.nix b/pkgs/by-name/pa/pantum-driver/package.nix index 69e973fd958418..79719279b29d60 100644 --- a/pkgs/by-name/pa/pantum-driver/package.nix +++ b/pkgs/by-name/pa/pantum-driver/package.nix @@ -1,54 +1,71 @@ -{ lib -, stdenv -, fetchzip -, libusb1 -, cups -, dpkg -, libjpeg8 -, makeWrapper -, autoPatchelfHook -, enablePtqpdf ? false # Pantum's version of qpdf +{ + lib, + stdenv, + fetchzip, + libusb1, + cups, + dpkg, + libjpeg8, + makeWrapper, + autoPatchelfHook, + enablePtqpdf ? false, # Pantum's version of qpdf }: let - architecture = { - i686-linux = "i386"; - x86_64-linux = "amd64"; - }.${stdenv.hostPlatform.system} or (throw "unsupported system ${stdenv.hostPlatform.system}"); + architecture = + { + i686-linux = "i386"; + x86_64-linux = "amd64"; + } + .${stdenv.hostPlatform.system} or (throw "unsupported system ${stdenv.hostPlatform.system}"); in stdenv.mkDerivation rec { pname = "pantum-driver"; version = "1.1.123"; src = fetchzip { - url = "https://github.com/ArticExploit/pantum-driver/releases/download/${version}/Pantum.Ubuntu.Driver.V${builtins.replaceStrings ["."] ["_"] version}.zip"; + url = "https://github.com/ArticExploit/pantum-driver/releases/download/${version}/Pantum.Ubuntu.Driver.V${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.zip"; hash = "sha256-TUk6CTnWlSvyG8MOpDRhg/eblAo6X/MDUFOiWuOuro0="; }; - buildInputs = [ libusb1 libjpeg8 cups ]; - nativeBuildInputs = [ dpkg autoPatchelfHook ]; + buildInputs = [ + libusb1 + libjpeg8 + cups + ]; + nativeBuildInputs = [ + dpkg + autoPatchelfHook + ]; - installPhase = '' - dpkg-deb -x ./Resources/pantum_${version}-1_${architecture}.deb . + installPhase = + '' + dpkg-deb -x ./Resources/pantum_${version}-1_${architecture}.deb . - mkdir -p $out $out/lib - cp -r etc $out/ - cp -r usr/lib/cups $out/lib/ - cp -r usr/local/lib/* $out/lib/ - cp -r usr/share $out/ - cp Resources/locale/en_US.UTF-8/* $out/share/doc/pantum/ - '' + lib.optionalString enablePtqpdf '' - cp -r opt/pantum/* $out/ - ln -s $out/lib/libqpdf.so* $out/lib/libqpdf.so - ln -s $out/lib/libqpdf.so $out/lib/libqpdf.so.21 - ''; + mkdir -p $out $out/lib + cp -r etc $out/ + cp -r usr/lib/cups $out/lib/ + cp -r usr/local/lib/* $out/lib/ + cp -r usr/share $out/ + cp Resources/locale/en_US.UTF-8/* $out/share/doc/pantum/ + '' + + lib.optionalString enablePtqpdf '' + cp -r opt/pantum/* $out/ + ln -s $out/lib/libqpdf.so* $out/lib/libqpdf.so + ln -s $out/lib/libqpdf.so $out/lib/libqpdf.so.21 + ''; meta = with lib; { description = "Pantum universal driver"; homepage = "https://global.pantum.com/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = lib.licenses.unfree; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; maintainers = with maintainers; [ deinferno ]; }; } diff --git a/pkgs/by-name/pa/papeer/package.nix b/pkgs/by-name/pa/papeer/package.nix index aba9b64bfab8de..82f11c6cf5a17b 100644 --- a/pkgs/by-name/pa/papeer/package.nix +++ b/pkgs/by-name/pa/papeer/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "papeer"; diff --git a/pkgs/by-name/pa/paper-age/package.nix b/pkgs/by-name/pa/paper-age/package.nix index d9e9bba2a7aac0..4d0332000bd42e 100644 --- a/pkgs/by-name/pa/paper-age/package.nix +++ b/pkgs/by-name/pa/paper-age/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pa/paper-clip/package.nix b/pkgs/by-name/pa/paper-clip/package.nix index d7376dde22266c..6630fe3c9ece70 100644 --- a/pkgs/by-name/pa/paper-clip/package.nix +++ b/pkgs/by-name/pa/paper-clip/package.nix @@ -1,17 +1,18 @@ -{ lib -, desktop-file-utils -, exempi -, fetchFromGitHub -, glib -, gtk4 -, libadwaita -, meson -, ninja -, pkg-config -, poppler -, stdenv -, vala -, wrapGAppsHook4 +{ + lib, + desktop-file-utils, + exempi, + fetchFromGitHub, + glib, + gtk4, + libadwaita, + meson, + ninja, + pkg-config, + poppler, + stdenv, + vala, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pa/paper-gtk-theme/package.nix b/pkgs/by-name/pa/paper-gtk-theme/package.nix index 82852843038125..70d67366707d0d 100644 --- a/pkgs/by-name/pa/paper-gtk-theme/package.nix +++ b/pkgs/by-name/pa/paper-gtk-theme/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, gtk_engines }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gtk_engines, +}: stdenv.mkDerivation { version = "2016-08-16"; @@ -26,6 +32,9 @@ stdenv.mkDerivation { homepage = "https://snwh.org/paper"; license = licenses.gpl3; platforms = platforms.linux; - maintainers = [ maintainers.simonvandel maintainers.romildo ]; + maintainers = [ + maintainers.simonvandel + maintainers.romildo + ]; }; } diff --git a/pkgs/by-name/pa/paper-icon-theme/package.nix b/pkgs/by-name/pa/paper-icon-theme/package.nix index d502fb0d6f954a..29264499efac33 100644 --- a/pkgs/by-name/pa/paper-icon-theme/package.nix +++ b/pkgs/by-name/pa/paper-icon-theme/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenvNoCC, fetchFromGitHub, meson, ninja, gtk3, adwaita-icon-theme, gnome-icon-theme, hicolor-icon-theme, jdupes }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + meson, + ninja, + gtk3, + adwaita-icon-theme, + gnome-icon-theme, + hicolor-icon-theme, + jdupes, +}: stdenvNoCC.mkDerivation rec { pname = "paper-icon-theme"; @@ -41,7 +52,10 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { description = "Modern icon theme designed around bold colours and simple geometric shapes"; homepage = "https://snwh.org/paper"; - license = with licenses; [ cc-by-sa-40 lgpl3 ]; + license = with licenses; [ + cc-by-sa-40 + lgpl3 + ]; # darwin cannot deal with file names differing only in case platforms = platforms.linux; maintainers = with maintainers; [ romildo ]; diff --git a/pkgs/by-name/pa/paper-plane/package.nix b/pkgs/by-name/pa/paper-plane/package.nix index 2028e7a848f20e..648acee73db118 100644 --- a/pkgs/by-name/pa/paper-plane/package.nix +++ b/pkgs/by-name/pa/paper-plane/package.nix @@ -1,23 +1,24 @@ -{ lib -, fetchFromGitHub -, gtk4 -, libadwaita -, tdlib -, rlottie -, stdenv -, rustPlatform -, meson -, ninja -, pkg-config -, rustc -, cargo -, desktop-file-utils -, blueprint-compiler -, libxml2 -, libshumate -, gst_all_1 -, darwin -, buildPackages +{ + lib, + fetchFromGitHub, + gtk4, + libadwaita, + tdlib, + rlottie, + stdenv, + rustPlatform, + meson, + ninja, + pkg-config, + rustc, + cargo, + desktop-file-utils, + blueprint-compiler, + libxml2, + libshumate, + gst_all_1, + darwin, + buildPackages, }: let @@ -34,7 +35,7 @@ let # Paper Plane requires a patch to the gtk4, but may be removed later # https://github.com/paper-plane-developers/paper-plane/tree/main?tab=readme-ov-file#prerequisites gtk4-paperplane = gtk4.overrideAttrs (prev: { - patches = (prev.patches or []) ++ [ "${src}/build-aux/gtk-reversed-list.patch" ]; + patches = (prev.patches or [ ]) ++ [ "${src}/build-aux/gtk-reversed-list.patch" ]; }); wrapPaperPlaneHook = buildPackages.wrapGAppsHook3.override { gtk3 = gtk4-paperplane; @@ -92,18 +93,20 @@ stdenv.mkDerivation { libxml2.bin ]; - buildInputs = [ - libshumate - libadwaita-paperplane - tdlib-paperplane - rlottie-paperplane - gst_all_1.gstreamer - gst_all_1.gst-libav - gst_all_1.gst-plugins-base - gst_all_1.gst-plugins-good - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + libshumate + libadwaita-paperplane + tdlib-paperplane + rlottie-paperplane + gst_all_1.gstreamer + gst_all_1.gst-libav + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-good + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ]; mesonFlags = [ # The API ID and hash provided here are for use with Paper Plane only. @@ -115,12 +118,9 @@ stdenv.mkDerivation { # Workaround for the gettext-sys issue # https://github.com/Koka/gettext-rs/issues/114 - env.NIX_CFLAGS_COMPILE = lib.optionalString - ( - stdenv.cc.isClang && - lib.versionAtLeast stdenv.cc.version "16" - ) - "-Wno-error=incompatible-function-pointer-types"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.cc.isClang && lib.versionAtLeast stdenv.cc.version "16" + ) "-Wno-error=incompatible-function-pointer-types"; meta = with lib; { homepage = "https://github.com/paper-plane-developers/paper-plane"; diff --git a/pkgs/by-name/pa/paperkey/package.nix b/pkgs/by-name/pa/paperkey/package.nix index 3b3a2d81d10681..1aba2f19ad8fc9 100644 --- a/pkgs/by-name/pa/paperkey/package.nix +++ b/pkgs/by-name/pa/paperkey/package.nix @@ -1,4 +1,8 @@ -{ fetchurl, lib, stdenv }: +{ + fetchurl, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "paperkey"; @@ -30,6 +34,9 @@ stdenv.mkDerivation rec { homepage = "https://www.jabberwocky.com/software/paperkey/"; license = licenses.gpl2Plus; platforms = platforms.unix; - maintainers = with maintainers; [ AndersonTorres peterhoeg ]; + maintainers = with maintainers; [ + AndersonTorres + peterhoeg + ]; }; } diff --git a/pkgs/by-name/pa/paperless-asn-qr-codes/package.nix b/pkgs/by-name/pa/paperless-asn-qr-codes/package.nix index 1661d7a5a4859c..5fe69a944eab48 100644 --- a/pkgs/by-name/pa/paperless-asn-qr-codes/package.nix +++ b/pkgs/by-name/pa/paperless-asn-qr-codes/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pa/paperless-ngx/package.nix b/pkgs/by-name/pa/paperless-ngx/package.nix index 7dee06aac9a057..3fcf619c792111 100644 --- a/pkgs/by-name/pa/paperless-ngx/package.nix +++ b/pkgs/by-name/pa/paperless-ngx/package.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch2 -, buildNpmPackage -, nixosTests -, gettext -, python3 -, giflib -, darwin -, ghostscript_headless -, imagemagickBig -, jbig2enc -, optipng -, pngquant -, qpdf -, tesseract5 -, unpaper -, poppler_utils -, liberation_ttf -, xcbuild -, pango -, pkg-config -, nltk-data -, xorg +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch2, + buildNpmPackage, + nixosTests, + gettext, + python3, + giflib, + darwin, + ghostscript_headless, + imagemagickBig, + jbig2enc, + optipng, + pngquant, + qpdf, + tesseract5, + unpaper, + poppler_utils, + liberation_ttf, + xcbuild, + pango, + pkg-config, + nltk-data, + xorg, }: let @@ -44,17 +45,21 @@ let django = prev.django_5; # TODO: drop after https://github.com/NixOS/nixpkgs/pull/306556 or similar got merged - django-allauth = prev.django-allauth.overridePythonAttrs ({ src, nativeCheckInputs, ... }: let - version = "65.0.2"; - in { - inherit version; - src = src.override { - rev = "refs/tags/${version}"; - hash = "sha256-GvYdExkNuySrg8ERnWOJxucFe5HVdPAcHfRNeqiVS7M="; - }; - - nativeCheckInputs = nativeCheckInputs ++ [ prev.fido2 ]; - }); + django-allauth = prev.django-allauth.overridePythonAttrs ( + { src, nativeCheckInputs, ... }: + let + version = "65.0.2"; + in + { + inherit version; + src = src.override { + rev = "refs/tags/${version}"; + hash = "sha256-GvYdExkNuySrg8ERnWOJxucFe5HVdPAcHfRNeqiVS7M="; + }; + + nativeCheckInputs = nativeCheckInputs ++ [ prev.fido2 ]; + } + ); django-extensions = prev.django-extensions.overridePythonAttrs (_: { # fails with: TypeError: 'class Meta' got invalid attribute(s): index_together @@ -77,7 +82,6 @@ let }; }; - path = lib.makeBinPath [ ghostscript_headless imagemagickBig @@ -100,25 +104,31 @@ let npmDepsHash = "sha256-pBCWcdCTQh0N4pRLBWLZXybuhpiat030xvPZ5z7CUJ0="; - nativeBuildInputs = [ - pkg-config - python3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - xcbuild - ]; - - buildInputs = [ - pango - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - giflib - darwin.apple_sdk.frameworks.CoreText - ]; + nativeBuildInputs = + [ + pkg-config + python3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + xcbuild + ]; + + buildInputs = + [ + pango + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + giflib + darwin.apple_sdk.frameworks.CoreText + ]; CYPRESS_INSTALL_BINARY = "0"; NG_CLI_ANALYTICS = "false"; npmBuildFlags = [ - "--" "--configuration" "production" + "--" + "--configuration" + "production" ]; doCheck = true; @@ -161,61 +171,63 @@ python.pkgs.buildPythonApplication rec { xorg.lndir ]; - dependencies = with python.pkgs; [ - bleach - channels - channels-redis - concurrent-log-handler - dateparser - django_5 - django-allauth - django-auditlog - django-celery-results - django-compression-middleware - django-cors-headers - django-extensions - django-filter - django-guardian - django-multiselectfield - django-soft-delete - djangorestframework - djangorestframework-guardian2 - drf-writable-nested - filelock - flower - gotenberg-client - gunicorn - httpx-oauth - imap-tools - inotifyrecursive - jinja2 - langdetect - mysqlclient - nltk - ocrmypdf - pathvalidate - pdf2image - psycopg - python-dateutil - python-dotenv - python-gnupg - python-ipware - python-magic - pyzbar - rapidfuzz - redis - scikit-learn - setproctitle - tika-client - tqdm - uvicorn - watchdog - whitenoise - whoosh - zxing-cpp - ] - ++ redis.optional-dependencies.hiredis - ++ uvicorn.optional-dependencies.standard; + dependencies = + with python.pkgs; + [ + bleach + channels + channels-redis + concurrent-log-handler + dateparser + django_5 + django-allauth + django-auditlog + django-celery-results + django-compression-middleware + django-cors-headers + django-extensions + django-filter + django-guardian + django-multiselectfield + django-soft-delete + djangorestframework + djangorestframework-guardian2 + drf-writable-nested + filelock + flower + gotenberg-client + gunicorn + httpx-oauth + imap-tools + inotifyrecursive + jinja2 + langdetect + mysqlclient + nltk + ocrmypdf + pathvalidate + pdf2image + psycopg + python-dateutil + python-dotenv + python-gnupg + python-ipware + python-magic + pyzbar + rapidfuzz + redis + scikit-learn + setproctitle + tika-client + tqdm + uvicorn + watchdog + whitenoise + whoosh + zxing-cpp + ] + ++ redis.optional-dependencies.hiredis + ++ uvicorn.optional-dependencies.standard; postBuild = '' # Compile manually because `pythonRecompileBytecodeHook` only works @@ -229,24 +241,26 @@ python.pkgs.buildPythonApplication rec { ${python.pythonOnBuildForHost.interpreter} src/manage.py compilemessages ''; - installPhase = let - pythonPath = python.pkgs.makePythonPath dependencies; - in '' - runHook preInstall - - mkdir -p $out/lib/paperless-ngx/static/frontend - cp -r {src,static,LICENSE,gunicorn.conf.py} $out/lib/paperless-ngx - lndir -silent ${frontend}/lib/paperless-ui/frontend $out/lib/paperless-ngx/static/frontend - chmod +x $out/lib/paperless-ngx/src/manage.py - makeWrapper $out/lib/paperless-ngx/src/manage.py $out/bin/paperless-ngx \ - --prefix PYTHONPATH : "${pythonPath}" \ - --prefix PATH : "${path}" - makeWrapper ${lib.getExe python.pkgs.celery} $out/bin/celery \ - --prefix PYTHONPATH : "${pythonPath}:$out/lib/paperless-ngx/src" \ - --prefix PATH : "${path}" - - runHook postInstall - ''; + installPhase = + let + pythonPath = python.pkgs.makePythonPath dependencies; + in + '' + runHook preInstall + + mkdir -p $out/lib/paperless-ngx/static/frontend + cp -r {src,static,LICENSE,gunicorn.conf.py} $out/lib/paperless-ngx + lndir -silent ${frontend}/lib/paperless-ui/frontend $out/lib/paperless-ngx/static/frontend + chmod +x $out/lib/paperless-ngx/src/manage.py + makeWrapper $out/lib/paperless-ngx/src/manage.py $out/bin/paperless-ngx \ + --prefix PYTHONPATH : "${pythonPath}" \ + --prefix PATH : "${path}" + makeWrapper ${lib.getExe python.pkgs.celery} $out/bin/celery \ + --prefix PYTHONPATH : "${pythonPath}:$out/lib/paperless-ngx/src" \ + --prefix PATH : "${path}" + + runHook postInstall + ''; postFixup = '' # Remove tests with samples (~14M) @@ -296,8 +310,17 @@ python.pkgs.buildPythonApplication rec { doCheck = !stdenv.hostPlatform.isDarwin; passthru = { - inherit python path frontend tesseract5; - nltkData = with nltk-data; [ punkt_tab snowball_data stopwords ]; + inherit + python + path + frontend + tesseract5 + ; + nltkData = with nltk-data; [ + punkt_tab + snowball_data + stopwords + ]; tests = { inherit (nixosTests) paperless; }; }; @@ -307,6 +330,10 @@ python.pkgs.buildPythonApplication rec { changelog = "https://github.com/paperless-ngx/paperless-ngx/releases/tag/v${version}"; license = licenses.gpl3Only; platforms = platforms.unix; - maintainers = with maintainers; [ leona SuperSandro2000 erikarvstedt ]; + maintainers = with maintainers; [ + leona + SuperSandro2000 + erikarvstedt + ]; }; } diff --git a/pkgs/by-name/pa/paperlike-go/package.nix b/pkgs/by-name/pa/paperlike-go/package.nix index ad2782bfaf00e1..025858992328f4 100644 --- a/pkgs/by-name/pa/paperlike-go/package.nix +++ b/pkgs/by-name/pa/paperlike-go/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule { diff --git a/pkgs/by-name/pa/papers/package.nix b/pkgs/by-name/pa/papers/package.nix index a96d2fe17968d1..aab00d5121ec8c 100644 --- a/pkgs/by-name/pa/papers/package.nix +++ b/pkgs/by-name/pa/papers/package.nix @@ -1,47 +1,52 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, meson -, ninja -, pkg-config -, appstream -, desktop-file-utils -, gtk4 -, glib -, pango -, gdk-pixbuf -, shared-mime-info -, itstool -, poppler -, nautilus -, darwin -, djvulibre -, libspectre -, libarchive -, libsecret -, wrapGAppsHook4 -, librsvg -, gobject-introspection -, yelp-tools -, gsettings-desktop-schemas -, dbus -, gi-docgen -, libgxps -, withLibsecret ? true -, supportNautilus ? (!stdenv.hostPlatform.isDarwin) -, libadwaita -, exempi -, cargo -, rustPlatform -, rustfmt +{ + lib, + stdenv, + fetchurl, + fetchpatch, + meson, + ninja, + pkg-config, + appstream, + desktop-file-utils, + gtk4, + glib, + pango, + gdk-pixbuf, + shared-mime-info, + itstool, + poppler, + nautilus, + darwin, + djvulibre, + libspectre, + libarchive, + libsecret, + wrapGAppsHook4, + librsvg, + gobject-introspection, + yelp-tools, + gsettings-desktop-schemas, + dbus, + gi-docgen, + libgxps, + withLibsecret ? true, + supportNautilus ? (!stdenv.hostPlatform.isDarwin), + libadwaita, + exempi, + cargo, + rustPlatform, + rustfmt, }: stdenv.mkDerivation (finalAttrs: { pname = "papers"; version = "47.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/papers/${lib.versions.major finalAttrs.version}/papers-${finalAttrs.version}.tar.xz"; @@ -60,7 +65,12 @@ stdenv.mkDerivation (finalAttrs: { cargoRoot = "shell-rs"; cargoDeps = rustPlatform.fetchCargoTarball { - inherit (finalAttrs) src pname version cargoRoot; + inherit (finalAttrs) + src + pname + version + cargoRoot + ; hash = "sha256-/5IySNEUkwiQezLx4n4jlPJdqJhlcgt5bXIelUFftZI="; }; @@ -82,36 +92,43 @@ stdenv.mkDerivation (finalAttrs: { rustfmt ]; - buildInputs = [ - dbus # only needed to find the service directory - djvulibre - exempi - gdk-pixbuf - glib - gtk4 - gsettings-desktop-schemas - libadwaita - libarchive - libgxps - librsvg - libspectre - pango - poppler - ] ++ lib.optionals withLibsecret [ - libsecret - ] ++ lib.optionals supportNautilus [ - nautilus - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - ]; - - mesonFlags = [ - "-Dps=enabled" - ] ++ lib.optionals (!withLibsecret) [ - "-Dkeyring=disabled" - ] ++ lib.optionals (!supportNautilus) [ - "-Dnautilus=false" - ]; + buildInputs = + [ + dbus # only needed to find the service directory + djvulibre + exempi + gdk-pixbuf + glib + gtk4 + gsettings-desktop-schemas + libadwaita + libarchive + libgxps + librsvg + libspectre + pango + poppler + ] + ++ lib.optionals withLibsecret [ + libsecret + ] + ++ lib.optionals supportNautilus [ + nautilus + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ]; + + mesonFlags = + [ + "-Dps=enabled" + ] + ++ lib.optionals (!withLibsecret) [ + "-Dkeyring=disabled" + ] + ++ lib.optionals (!supportNautilus) [ + "-Dnautilus=false" + ]; env.NIX_CFLAGS_COMPILE = lib.optionalString ( stdenv.cc.isClang && lib.versionAtLeast stdenv.cc.version "16" @@ -122,13 +139,15 @@ stdenv.mkDerivation (finalAttrs: { --replace-fail '=papers-thumbnailer' "=$out/bin/papers-thumbnailer" ''; - preFixup = '' - gappsWrapperArgs+=( - --prefix XDG_DATA_DIRS : "${shared-mime-info}/share" - ) - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install_name_tool -add_rpath "$out/lib" "$out/bin/papers" - ''; + preFixup = + '' + gappsWrapperArgs+=( + --prefix XDG_DATA_DIRS : "${shared-mime-info}/share" + ) + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install_name_tool -add_rpath "$out/lib" "$out/bin/papers" + ''; postFixup = '' # Cannot be in postInstall, otherwise _multioutDocs hook in preFixup will move right back. diff --git a/pkgs/by-name/pa/papertrail/gemset.nix b/pkgs/by-name/pa/papertrail/gemset.nix index abfbed17a987fa..99874d153567b6 100644 --- a/pkgs/by-name/pa/papertrail/gemset.nix +++ b/pkgs/by-name/pa/papertrail/gemset.nix @@ -1,30 +1,33 @@ { ansi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14ims9zfal4gs2wpx2m5rd8zsrl2k794d359shkrsgg3fhr2a22l"; type = "gem"; }; version = "1.5.0"; }; chronic = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1hrdkn4g8x7dlzxwb1rfgr8kw3bp4ywg5l4y4i9c2g5cwv62yvvn"; type = "gem"; }; version = "0.10.2"; }; papertrail = { - dependencies = ["ansi" "chronic"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "ansi" + "chronic" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "170zhgahrgpwj4cb9xj8104yqcf9gva8qk5vqpmw3g8rq29jxshy"; type = "gem"; }; diff --git a/pkgs/by-name/pa/papertrail/package.nix b/pkgs/by-name/pa/papertrail/package.nix index a01bc3fb889cbc..e1baafe00c057b 100644 --- a/pkgs/by-name/pa/papertrail/package.nix +++ b/pkgs/by-name/pa/papertrail/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, bundlerEnv, ruby, bundlerUpdateScript, testers, papertrail }: +{ + lib, + stdenv, + bundlerEnv, + ruby, + bundlerUpdateScript, + testers, + papertrail, +}: let papertrail-env = bundlerEnv { @@ -8,7 +16,8 @@ let lockfile = ./Gemfile.lock; gemset = ./gemset.nix; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "papertrail"; version = (import ./gemset.nix).papertrail.version; @@ -26,9 +35,9 @@ in stdenv.mkDerivation { meta = with lib; { description = "Command-line client for Papertrail log management service"; mainProgram = "papertrail"; - homepage = "https://github.com/papertrail/papertrail-cli/"; - license = licenses.mit; + homepage = "https://github.com/papertrail/papertrail-cli/"; + license = licenses.mit; maintainers = with maintainers; [ nicknovitski ]; - platforms = ruby.meta.platforms; + platforms = ruby.meta.platforms; }; } diff --git a/pkgs/by-name/pa/paperview/package.nix b/pkgs/by-name/pa/paperview/package.nix index 3c5cf4c4123e89..58673594ae1b95 100644 --- a/pkgs/by-name/pa/paperview/package.nix +++ b/pkgs/by-name/pa/paperview/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, libX11 -, SDL2 +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + SDL2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pa/papi/package.nix b/pkgs/by-name/pa/papi/package.nix index 7e022bafbb4008..1c4cf77e84279f 100644 --- a/pkgs/by-name/pa/papi/package.nix +++ b/pkgs/by-name/pa/papi/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { @@ -7,7 +9,9 @@ stdenv.mkDerivation rec { pname = "papi"; src = fetchurl { - url = "https://bitbucket.org/icl/papi/get/papi-${lib.replaceStrings ["."] ["-"] version}-t.tar.gz"; + url = "https://bitbucket.org/icl/papi/get/papi-${ + lib.replaceStrings [ "." ] [ "-" ] version + }-t.tar.gz"; sha256 = "sha256-VajhmPW8sEJksfhLjBVlpBH7+AZr4fwKZPAtZxRF1Bk="; }; @@ -23,6 +27,9 @@ stdenv.mkDerivation rec { description = "Library providing access to various hardware performance counters"; license = licenses.bsdOriginal; platforms = platforms.linux; - maintainers = with maintainers; [ costrouc zhaofengli ]; + maintainers = with maintainers; [ + costrouc + zhaofengli + ]; }; } diff --git a/pkgs/by-name/pa/papirus-folders/package.nix b/pkgs/by-name/pa/papirus-folders/package.nix index 7abcd038bac0c5..11c08f69406abc 100644 --- a/pkgs/by-name/pa/papirus-folders/package.nix +++ b/pkgs/by-name/pa/papirus-folders/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, getent }: +{ + lib, + stdenv, + fetchFromGitHub, + getent, +}: stdenv.mkDerivation rec { pname = "papirus-folders"; diff --git a/pkgs/by-name/pa/papirus-nord/package.nix b/pkgs/by-name/pa/papirus-nord/package.nix index 178b1ba3470a76..326c9eb2ca3eee 100644 --- a/pkgs/by-name/pa/papirus-nord/package.nix +++ b/pkgs/by-name/pa/papirus-nord/package.nix @@ -1,10 +1,11 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, gtk3 -, getent -, papirus-icon-theme -, accent ? "frostblue1" +{ + stdenvNoCC, + lib, + fetchFromGitHub, + gtk3, + getent, + papirus-icon-theme, + accent ? "frostblue1", }: let validAccents = [ @@ -34,42 +35,46 @@ let in lib.checkListOfEnum "${pname}: accent colors" validAccents [ accent ] -stdenvNoCC.mkDerivation { - inherit pname version; + stdenvNoCC.mkDerivation + { + inherit pname version; - src = fetchFromGitHub { - owner = "adapta-projects"; - repo = "papirus-nord"; - rev = version; - sha256 = "sha256-KwwTDGJQ4zN9XH/pKFQDQ+EgyuSCFhN2PQAI35G+3YM="; - }; + src = fetchFromGitHub { + owner = "adapta-projects"; + repo = "papirus-nord"; + rev = version; + sha256 = "sha256-KwwTDGJQ4zN9XH/pKFQDQ+EgyuSCFhN2PQAI35G+3YM="; + }; - nativeBuildInputs = [ gtk3 getent ]; + nativeBuildInputs = [ + gtk3 + getent + ]; - postPatch = '' - patchShebangs ./papirus-folders - ''; + postPatch = '' + patchShebangs ./papirus-folders + ''; - installPhase = '' - runHook preInstall - mkdir -p $out/share/icons - cp -r --no-preserve=mode ${papirus-icon-theme}/share/icons/Papirus* $out/share/icons - for size in 64x64 48x48 32x32 24x24 22x22; do - cp -f Icons/$size/* $out/share/icons/Papirus/$size/places - done - for theme in $out/share/icons/*; do - USER_HOME=$HOME DISABLE_UPDATE_ICON_CACHE=1 \ - ./papirus-folders -t $theme -o -C ${accent} - gtk-update-icon-cache --force $theme - done - runHook postInstall - ''; + installPhase = '' + runHook preInstall + mkdir -p $out/share/icons + cp -r --no-preserve=mode ${papirus-icon-theme}/share/icons/Papirus* $out/share/icons + for size in 64x64 48x48 32x32 24x24 22x22; do + cp -f Icons/$size/* $out/share/icons/Papirus/$size/places + done + for theme in $out/share/icons/*; do + USER_HOME=$HOME DISABLE_UPDATE_ICON_CACHE=1 \ + ./papirus-folders -t $theme -o -C ${accent} + gtk-update-icon-cache --force $theme + done + runHook postInstall + ''; - meta = with lib; { - description = "Nord version of Papirus Icon Theme"; - homepage = "https://github.com/Adapta-Projects/Papirus-Nord"; - license = licenses.gpl2Plus; - platforms = platforms.linux; - maintainers = with maintainers; [ aacebedo ]; - }; -} + meta = with lib; { + description = "Nord version of Papirus Icon Theme"; + homepage = "https://github.com/Adapta-Projects/Papirus-Nord"; + license = licenses.gpl2Plus; + platforms = platforms.linux; + maintainers = with maintainers; [ aacebedo ]; + }; + } diff --git a/pkgs/by-name/pa/paprefs/package.nix b/pkgs/by-name/pa/paprefs/package.nix index fa28433fe9cd3d..63ce64a74e2af3 100644 --- a/pkgs/by-name/pa/paprefs/package.nix +++ b/pkgs/by-name/pa/paprefs/package.nix @@ -1,14 +1,15 @@ -{ fetchurl -, lib -, stdenv -, meson -, ninja -, gettext -, pkg-config -, pulseaudioFull -, glibmm -, gtkmm3 -, wrapGAppsHook3 +{ + fetchurl, + lib, + stdenv, + meson, + ninja, + gettext, + pkg-config, + pulseaudioFull, + glibmm, + gtkmm3, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pa/paps/package.nix b/pkgs/by-name/pa/paps/package.nix index 964f08ac27759f..935ef85ee3cbb8 100644 --- a/pkgs/by-name/pa/paps/package.nix +++ b/pkgs/by-name/pa/paps/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub -, autoconf, automake, pkg-config, intltool, pango }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + pkg-config, + intltool, + pango, +}: stdenv.mkDerivation rec { pname = "paps"; @@ -12,7 +20,12 @@ stdenv.mkDerivation rec { sha256 = "129wpm2ayxs6qfh2761d4x9c034ivb2bcmmcnl56qs4448qb9495"; }; - nativeBuildInputs = [ autoconf automake pkg-config intltool ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + intltool + ]; buildInputs = [ pango ]; preConfigure = '' diff --git a/pkgs/by-name/pa/par/package.nix b/pkgs/by-name/pa/par/package.nix index c62df86835c0fe..a6167b8c5ed788 100644 --- a/pkgs/by-name/pa/par/package.nix +++ b/pkgs/by-name/pa/par/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "par"; @@ -22,7 +26,6 @@ stdenv.mkDerivation rec { cp par.1 $out/share/man/man1 ''; - meta = with lib; { homepage = "http://www.nicemice.net/par/"; description = "Paragraph reflow for email"; diff --git a/pkgs/by-name/pa/par2cmdline/package.nix b/pkgs/by-name/pa/par2cmdline/package.nix index 8ccf5d54ebbfe2..6f69f0e48eedcb 100644 --- a/pkgs/by-name/pa/par2cmdline/package.nix +++ b/pkgs/by-name/pa/par2cmdline/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "par2cmdline"; diff --git a/pkgs/by-name/pa/parallel-disk-usage/package.nix b/pkgs/by-name/pa/parallel-disk-usage/package.nix index ef425b3ff051ca..196efc10c641da 100644 --- a/pkgs/by-name/pa/parallel-disk-usage/package.nix +++ b/pkgs/by-name/pa/parallel-disk-usage/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { pname = "parallel-disk-usage"; @@ -19,7 +20,7 @@ rustPlatform.buildRustPackage rec { description = "Highly parallelized, blazing fast directory tree analyzer"; homepage = "https://github.com/KSXGitHub/parallel-disk-usage"; license = licenses.asl20; - maintainers = [maintainers.peret]; + maintainers = [ maintainers.peret ]; mainProgram = "pdu"; }; } diff --git a/pkgs/by-name/pa/parallel-hashmap/package.nix b/pkgs/by-name/pa/parallel-hashmap/package.nix index a84503ee2a14f3..ccb161e778ec3d 100644 --- a/pkgs/by-name/pa/parallel-hashmap/package.nix +++ b/pkgs/by-name/pa/parallel-hashmap/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gtest +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gtest, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pa/paralus-cli/package.nix b/pkgs/by-name/pa/paralus-cli/package.nix index e838acf69cf00c..24961d715afa89 100644 --- a/pkgs/by-name/pa/paralus-cli/package.nix +++ b/pkgs/by-name/pa/paralus-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { diff --git a/pkgs/by-name/pa/parastoo-fonts/package.nix b/pkgs/by-name/pa/parastoo-fonts/package.nix index 214a9ca58d773f..0d3c24cd1c6c09 100644 --- a/pkgs/by-name/pa/parastoo-fonts/package.nix +++ b/pkgs/by-name/pa/parastoo-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "parastoo-fonts"; diff --git a/pkgs/by-name/pa/paratest/package.nix b/pkgs/by-name/pa/paratest/package.nix index c4eca0346a7109..f7e34c1adaf2b8 100644 --- a/pkgs/by-name/pa/paratest/package.nix +++ b/pkgs/by-name/pa/paratest/package.nix @@ -1,28 +1,30 @@ -{ php -, fetchFromGitHub -, lib +{ + php, + fetchFromGitHub, + lib, }: -(php.withExtensions ({ enabled, all }: enabled ++ [ all.pcov ])).buildComposerProject2 (finalAttrs: { - pname = "paratest"; - version = "7.6.0"; +(php.withExtensions ({ enabled, all }: enabled ++ [ all.pcov ])).buildComposerProject2 + (finalAttrs: { + pname = "paratest"; + version = "7.6.0"; - src = fetchFromGitHub { - owner = "paratestphp"; - repo = "paratest"; - rev = "v${finalAttrs.version}"; - hash = "sha256-p7m/MDHy+NOh+MnoIWy74Ipm/5hevp4x6Qwn4uPIEAM="; - }; + src = fetchFromGitHub { + owner = "paratestphp"; + repo = "paratest"; + rev = "v${finalAttrs.version}"; + hash = "sha256-p7m/MDHy+NOh+MnoIWy74Ipm/5hevp4x6Qwn4uPIEAM="; + }; - composerLock = ./composer.lock; - vendorHash = "sha256-NQWwfSYgvAmvWnr563vAKh+IdFRDB/CJZReDUzftOvw="; + composerLock = ./composer.lock; + vendorHash = "sha256-NQWwfSYgvAmvWnr563vAKh+IdFRDB/CJZReDUzftOvw="; - meta = { - changelog = "https://github.com/paratestphp/paratest/releases/tag/v${finalAttrs.version}"; - description = "Parallel testing for PHPUnit"; - homepage = "https://github.com/paratestphp/paratest"; - license = lib.licenses.mit; - mainProgram = "paratest"; - maintainers = [ ]; - }; -}) + meta = { + changelog = "https://github.com/paratestphp/paratest/releases/tag/v${finalAttrs.version}"; + description = "Parallel testing for PHPUnit"; + homepage = "https://github.com/paratestphp/paratest"; + license = lib.licenses.mit; + mainProgram = "paratest"; + maintainers = [ ]; + }; + }) diff --git a/pkgs/by-name/pa/pari-galdata/package.nix b/pkgs/by-name/pa/pari-galdata/package.nix index c7673462805065..9a2e0acb332a47 100644 --- a/pkgs/by-name/pa/pari-galdata/package.nix +++ b/pkgs/by-name/pa/pari-galdata/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/pa/pari-seadata-small/package.nix b/pkgs/by-name/pa/pari-seadata-small/package.nix index 86516fe1ddba27..5056d6992124d9 100644 --- a/pkgs/by-name/pa/pari-seadata-small/package.nix +++ b/pkgs/by-name/pa/pari-seadata-small/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/pa/parinfer-rust/package.nix b/pkgs/by-name/pa/parinfer-rust/package.nix index cc434f14dd6d90..d300092b1907c7 100644 --- a/pkgs/by-name/pa/parinfer-rust/package.nix +++ b/pkgs/by-name/pa/parinfer-rust/package.nix @@ -1,4 +1,9 @@ -{ lib, rustPlatform, fetchFromGitHub, llvmPackages }: +{ + lib, + rustPlatform, + fetchFromGitHub, + llvmPackages, +}: rustPlatform.buildRustPackage rec { pname = "parinfer-rust"; @@ -13,7 +18,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-PW9LIQamQfusaijyJ2R9xe29LhM0GNf9BdxI9vkjVdE="; - nativeBuildInputs = [ llvmPackages.clang rustPlatform.bindgenHook ]; + nativeBuildInputs = [ + llvmPackages.clang + rustPlatform.bindgenHook + ]; postInstall = '' mkdir -p $out/share/kak/autoload/plugins diff --git a/pkgs/by-name/pa/parlatype/package.nix b/pkgs/by-name/pa/parlatype/package.nix index 3d9a3da25c2ea2..56080d475222ab 100644 --- a/pkgs/by-name/pa/parlatype/package.nix +++ b/pkgs/by-name/pa/parlatype/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, appstream-glib -, desktop-file-utils -, gettext -, glib -, gst_all_1 -, gtk4 -, hicolor-icon-theme -, isocodes -, itstool -, libadwaita -, libxml2 -, meson -, ninja -, pkg-config -, python3 -, wrapGAppsHook4 +{ + lib, + stdenv, + fetchFromGitHub, + appstream-glib, + desktop-file-utils, + gettext, + glib, + gst_all_1, + gtk4, + hicolor-icon-theme, + isocodes, + itstool, + libadwaita, + libxml2, + meson, + ninja, + pkg-config, + python3, + wrapGAppsHook4, }: stdenv.mkDerivation rec { @@ -75,7 +76,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://www.parlatype.xyz/"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ alexshpilkin melchips ]; + maintainers = with maintainers; [ + alexshpilkin + melchips + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/pa/parquet-tools/package.nix b/pkgs/by-name/pa/parquet-tools/package.nix index 4775be223afac9..ccc32744c43ed5 100644 --- a/pkgs/by-name/pa/parquet-tools/package.nix +++ b/pkgs/by-name/pa/parquet-tools/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3Packages +{ + lib, + fetchFromGitHub, + python3Packages, }: with python3Packages; diff --git a/pkgs/by-name/pa/parse-cli-bin/package.nix b/pkgs/by-name/pa/parse-cli-bin/package.nix index 0ece2bb4afb0df..a70e398c320867 100644 --- a/pkgs/by-name/pa/parse-cli-bin/package.nix +++ b/pkgs/by-name/pa/parse-cli-bin/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "parse-cli-bin"; @@ -12,9 +16,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Parse Command Line Interface"; mainProgram = "parse"; - homepage = "https://parse.com"; - platforms = platforms.linux; - license = licenses.bsd3; + homepage = "https://parse.com"; + platforms = platforms.linux; + license = licenses.bsd3; }; dontUnpack = true; diff --git a/pkgs/by-name/pa/parsero/package.nix b/pkgs/by-name/pa/parsero/package.nix index 2c3323f25e5251..a059e44a17f0c8 100644 --- a/pkgs/by-name/pa/parsero/package.nix +++ b/pkgs/by-name/pa/parsero/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "parsero"; @@ -23,7 +27,10 @@ python3Packages.buildPythonApplication rec { description = "Robots.txt audit tool"; homepage = "https://github.com/behindthefirewalls/Parsero"; license = licenses.gpl2Only; - maintainers = with maintainers; [ emilytrau fab ]; + maintainers = with maintainers; [ + emilytrau + fab + ]; mainProgram = "parsero"; }; } diff --git a/pkgs/by-name/pa/parsify/package.nix b/pkgs/by-name/pa/parsify/package.nix index b5c122717289db..957f88e2b1ba1a 100644 --- a/pkgs/by-name/pa/parsify/package.nix +++ b/pkgs/by-name/pa/parsify/package.nix @@ -1,6 +1,7 @@ -{ lib -, appimageTools -, fetchurl +{ + lib, + appimageTools, + fetchurl, }: appimageTools.wrapType2 rec { @@ -13,15 +14,17 @@ appimageTools.wrapType2 rec { }; extraInstallCommands = - let contents = appimageTools.extract { inherit pname version src; }; - in '' - install -m 444 -D ${contents}/@parsifydesktop.desktop -t $out/share/applications + let + contents = appimageTools.extract { inherit pname version src; }; + in + '' + install -m 444 -D ${contents}/@parsifydesktop.desktop -t $out/share/applications - substituteInPlace $out/share/applications/@parsifydesktop.desktop \ - --replace "Exec=AppRun" "Exec=${pname}" + substituteInPlace $out/share/applications/@parsifydesktop.desktop \ + --replace "Exec=AppRun" "Exec=${pname}" - cp -r ${contents}/usr/share/* $out/share - ''; + cp -r ${contents}/usr/share/* $out/share + ''; meta = with lib; { description = "Next generation notepad-based calculator, built with extendibility and privacy in mind"; diff --git a/pkgs/by-name/pa/parson/package.nix b/pkgs/by-name/pa/parson/package.nix index 4bdee532eea844..59d1ed43495cd5 100644 --- a/pkgs/by-name/pa/parson/package.nix +++ b/pkgs/by-name/pa/parson/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, +}: stdenv.mkDerivation { pname = "parson"; @@ -11,7 +17,10 @@ stdenv.mkDerivation { hash = "sha256-IEmCa0nauUzG+zcLpr++ySD7i21zVJh/35r9RaQkok0="; }; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; meta = { description = "Lightweight JSON library written in C"; diff --git a/pkgs/by-name/pa/partclone/package.nix b/pkgs/by-name/pa/partclone/package.nix index f10e0ac13b7875..7d14ac5e84bff9 100644 --- a/pkgs/by-name/pa/partclone/package.nix +++ b/pkgs/by-name/pa/partclone/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook -, pkg-config, libuuid, e2fsprogs, nilfs-utils, ntfs3g, openssl +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libuuid, + e2fsprogs, + nilfs-utils, + ntfs3g, + openssl, }: stdenv.mkDerivation rec { @@ -13,9 +22,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-oYxMtVGmD88eLXCwdJJ6z+6X4Blfm3B4iwbGWwSAJ9c="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ - e2fsprogs libuuid stdenv.cc.libc nilfs-utils ntfs3g openssl + e2fsprogs + libuuid + stdenv.cc.libc + nilfs-utils + ntfs3g + openssl (lib.getOutput "static" stdenv.cc.libc) ]; diff --git a/pkgs/by-name/pa/parted/package.nix b/pkgs/by-name/pa/parted/package.nix index f1ed977e9a60cf..4fc1615665e3f6 100644 --- a/pkgs/by-name/pa/parted/package.nix +++ b/pkgs/by-name/pa/parted/package.nix @@ -1,16 +1,18 @@ -{ lib, stdenv -, fetchurl -, lvm2 -, libuuid -, gettext -, readline -, dosfstools -, e2fsprogs -, perl -, python3 -, util-linux -, check -, enableStatic ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchurl, + lvm2, + libuuid, + gettext, + readline, + dosfstools, + e2fsprogs, + perl, + python3, + util-linux, + check, + enableStatic ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { @@ -22,28 +24,39 @@ stdenv.mkDerivation rec { sha256 = "sha256-O0Pb4zzKD5oYYB66tWt4UrEo7Bo986mzDM3l5zNZ5hI="; }; - outputs = [ "out" "dev" "man" "info" ]; + outputs = [ + "out" + "dev" + "man" + "info" + ]; postPatch = '' patchShebangs tests ''; - buildInputs = [ libuuid ] + buildInputs = + [ libuuid ] ++ lib.optional (readline != null) readline ++ lib.optional (gettext != null) gettext ++ lib.optional (lvm2 != null) lvm2; configureFlags = - (if (readline != null) - then [ "--with-readline" ] - else [ "--without-readline" ]) + (if (readline != null) then [ "--with-readline" ] else [ "--without-readline" ]) ++ lib.optional (lvm2 == null) "--disable-device-mapper" ++ lib.optional enableStatic "--enable-static"; # Tests were previously failing due to Hydra running builds as uid 0. # That should hopefully be fixed now. - doCheck = !stdenv.hostPlatform.isMusl; /* translation test */ - nativeCheckInputs = [ check dosfstools e2fsprogs perl python3 util-linux ]; + doCheck = !stdenv.hostPlatform.isMusl; # translation test + nativeCheckInputs = [ + check + dosfstools + e2fsprogs + perl + python3 + util-linux + ]; meta = { description = "Create, destroy, resize, check, and copy partitions"; diff --git a/pkgs/by-name/pa/particl-core/package.nix b/pkgs/by-name/pa/particl-core/package.nix index 12e86358c95447..51204fd9263477 100644 --- a/pkgs/by-name/pa/particl-core/package.nix +++ b/pkgs/by-name/pa/particl-core/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, autoreconfHook -, boost -, db48 -, fetchFromGitHub -, fetchpatch2 -, libevent -, miniupnpc -, openssl -, pkg-config -, zeromq -, zlib -, unixtools -, python3 +{ + lib, + stdenv, + autoreconfHook, + boost, + db48, + fetchFromGitHub, + fetchpatch2, + libevent, + miniupnpc, + openssl, + pkg-config, + zeromq, + zlib, + unixtools, + python3, }: stdenv.mkDerivation rec { @@ -34,16 +35,31 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ openssl db48 boost zlib miniupnpc libevent zeromq unixtools.hexdump python3 ]; - - configureFlags = [ - "--disable-bench" - "--with-boost-libdir=${boost.out}/lib" - ] ++ lib.optionals (!doCheck) [ - "--enable-tests=no" + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + openssl + db48 + boost + zlib + miniupnpc + libevent + zeromq + unixtools.hexdump + python3 ]; + configureFlags = + [ + "--disable-bench" + "--with-boost-libdir=${boost.out}/lib" + ] + ++ lib.optionals (!doCheck) [ + "--enable-tests=no" + ]; + # Always check during Hydra builds doCheck = true; preCheck = "patchShebangs test"; diff --git a/pkgs/by-name/pa/partimage/package.nix b/pkgs/by-name/pa/partimage/package.nix index bb35fdd7c32c4a..9875ed28dc2caf 100644 --- a/pkgs/by-name/pa/partimage/package.nix +++ b/pkgs/by-name/pa/partimage/package.nix @@ -1,14 +1,16 @@ -{lib, stdenv -, fetchurl -, fetchpatch -, bzip2 -, zlib -, newt -, openssl -, pkg-config -, slang -, libxcrypt -, autoreconfHook +{ + lib, + stdenv, + fetchurl, + fetchpatch, + bzip2, + zlib, + newt, + openssl, + pkg-config, + slang, + libxcrypt, + autoreconfHook, }: stdenv.mkDerivation rec { pname = "partimage"; @@ -23,14 +25,26 @@ stdenv.mkDerivation rec { configureFlags = [ "--with-ssl-headers=${openssl.dev}/include/openssl" ]; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ bzip2 zlib newt newt openssl slang libxcrypt ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + bzip2 + zlib + newt + newt + openssl + slang + libxcrypt + ]; patches = [ ./gentoos-zlib.patch (fetchpatch { name = "openssl-1.1.patch"; - url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/sys-block/partimage/files/" + url = + "https://gitweb.gentoo.org/repo/gentoo.git/plain/sys-block/partimage/files/" + "partimage-0.6.9-openssl-1.1-compatibility.patch?id=3fe8e9910002b6523d995512a646b063565d0447"; sha256 = "1hs0krxrncxq1w36bhad02yk8yx71zcfs35cw87c82sl2sfwasjg"; }) @@ -44,7 +58,7 @@ stdenv.mkDerivation rec { description = "Opensource disk backup software"; homepage = "https://www.partimage.org"; license = lib.licenses.gpl2Plus; - maintainers = [lib.maintainers.marcweber]; + maintainers = [ lib.maintainers.marcweber ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/pa/partio/package.nix b/pkgs/by-name/pa/partio/package.nix index 2c117bdabb9005..ceaaf2dc542604 100644 --- a/pkgs/by-name/pa/partio/package.nix +++ b/pkgs/by-name/pa/partio/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, unzip -, cmake -, libglut -, libGLU -, libGL -, zlib -, swig -, doxygen -, xorg -, python3 -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + unzip, + cmake, + libglut, + libGLU, + libGL, + zlib, + swig, + doxygen, + xorg, + python3, + darwin, }: stdenv.mkDerivation rec { @@ -25,7 +26,11 @@ stdenv.mkDerivation rec { hash = "sha256-wV9byR85qwOkoTyLjG0gOLC3Gc19ykwiLpDy4T/MENQ="; }; - outputs = [ "dev" "out" "lib" ]; + outputs = [ + "dev" + "out" + "lib" + ]; nativeBuildInputs = [ unzip @@ -34,19 +39,22 @@ stdenv.mkDerivation rec { python3 ]; - buildInputs = [ - zlib - swig - xorg.libXi - xorg.libXmu - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Cocoa - darwin.apple_sdk.frameworks.GLUT - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - libglut - libGLU - libGL - ]; + buildInputs = + [ + zlib + swig + xorg.libXi + xorg.libXmu + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Cocoa + darwin.apple_sdk.frameworks.GLUT + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libglut + libGLU + libGL + ]; # TODO: # Sexpr support diff --git a/pkgs/by-name/pa/pasco/package.nix b/pkgs/by-name/pa/pasco/package.nix index da9343db393049..847af508fafb0c 100644 --- a/pkgs/by-name/pa/pasco/package.nix +++ b/pkgs/by-name/pa/pasco/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pa/pass-secret-service/package.nix b/pkgs/by-name/pa/pass-secret-service/package.nix index c377adc398915f..6d86978faba4e2 100644 --- a/pkgs/by-name/pa/pass-secret-service/package.nix +++ b/pkgs/by-name/pa/pass-secret-service/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, python3 -, dbus -, gnupg -, coreutils -, nixosTests +{ + lib, + fetchFromGitHub, + python3, + dbus, + gnupg, + coreutils, + nixosTests, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pa/passage/package.nix b/pkgs/by-name/pa/passage/package.nix index 5cd5b481c41321..ac1b68a9d98378 100644 --- a/pkgs/by-name/pa/passage/package.nix +++ b/pkgs/by-name/pa/passage/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeBinaryWrapper -, substituteAll -, age -, getopt -, coreutils -, findutils -, gnugrep -, gnused -, qrencode ? null -, wl-clipboard ? null -, git ? null -, xclip ? null -# Used to pretty-print list of all stored passwords, but is not needed to fetch -# or store password by its name. Most users would want this dependency. -, tree ? null +{ + lib, + stdenv, + fetchFromGitHub, + makeBinaryWrapper, + substituteAll, + age, + getopt, + coreutils, + findutils, + gnugrep, + gnused, + qrencode ? null, + wl-clipboard ? null, + git ? null, + xclip ? null, + # Used to pretty-print list of all stored passwords, but is not needed to fetch + # or store password by its name. Most users would want this dependency. + tree ? null, }: stdenv.mkDerivation (finalAttrs: { @@ -57,14 +58,20 @@ stdenv.mkDerivation (finalAttrs: { wrapProgram $out/bin/passage --prefix PATH : $extraPath --argv0 $pname ''; - installFlags = [ "PREFIX=$(out)" "WITH_ALLCOMP=yes" ]; + installFlags = [ + "PREFIX=$(out)" + "WITH_ALLCOMP=yes" + ]; meta = with lib; { description = "Stores, retrieves, generates, and synchronizes passwords securely"; - homepage = "https://github.com/FiloSottile/passage"; - license = licenses.gpl2Plus; - maintainers = with maintainers; [ kaction ma27 ]; - platforms = platforms.unix; + homepage = "https://github.com/FiloSottile/passage"; + license = licenses.gpl2Plus; + maintainers = with maintainers; [ + kaction + ma27 + ]; + platforms = platforms.unix; mainProgram = "passage"; longDescription = '' diff --git a/pkgs/by-name/pa/passdetective/package.nix b/pkgs/by-name/pa/passdetective/package.nix index 2e921beb8c7d66..842de021361f98 100644 --- a/pkgs/by-name/pa/passdetective/package.nix +++ b/pkgs/by-name/pa/passdetective/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/pa/passerine/package.nix b/pkgs/by-name/pa/passerine/package.nix index 990d6ff078b2d7..44aa5146ae73c6 100644 --- a/pkgs/by-name/pa/passerine/package.nix +++ b/pkgs/by-name/pa/passerine/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "passerine"; diff --git a/pkgs/by-name/pa/passes/package.nix b/pkgs/by-name/pa/passes/package.nix index 74d34f682b0d42..102af396ff4bd3 100644 --- a/pkgs/by-name/pa/passes/package.nix +++ b/pkgs/by-name/pa/passes/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, appstream-glib -, blueprint-compiler -, desktop-file-utils -, gettext -, gtk4 -, libadwaita -, meson -, ninja -, pkg-config -, python3 -, wrapGAppsHook4 -, zint +{ + lib, + stdenv, + fetchFromGitHub, + appstream-glib, + blueprint-compiler, + desktop-file-utils, + gettext, + gtk4, + libadwaita, + meson, + ninja, + pkg-config, + python3, + wrapGAppsHook4, + zint, }: stdenv.mkDerivation (finalAttrs: { @@ -46,7 +47,7 @@ stdenv.mkDerivation (finalAttrs: { meson ninja pkg-config - (python3.withPackages (pp: [pp.pygobject3])) + (python3.withPackages (pp: [ pp.pygobject3 ])) wrapGAppsHook4 ]; diff --git a/pkgs/by-name/pa/passff-host/package.nix b/pkgs/by-name/pa/passff-host/package.nix index d5cf2f8267e2ba..61487c4d2ae4fa 100644 --- a/pkgs/by-name/pa/passff-host/package.nix +++ b/pkgs/by-name/pa/passff-host/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, python3, pass }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + pass, +}: stdenv.mkDerivation rec { pname = "passff-host"; diff --git a/pkgs/by-name/pa/passh/package.nix b/pkgs/by-name/pa/passh/package.nix index 6fc3efba9bd207..16e203f76155df 100644 --- a/pkgs/by-name/pa/passh/package.nix +++ b/pkgs/by-name/pa/passh/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, stdenv }: +{ + lib, + fetchFromGitHub, + stdenv, +}: stdenv.mkDerivation (finalAttrs: { pname = "passh"; diff --git a/pkgs/by-name/pa/passky-desktop/package.nix b/pkgs/by-name/pa/passky-desktop/package.nix index b1030b5ae8eefe..dfeffcb9f85e4c 100644 --- a/pkgs/by-name/pa/passky-desktop/package.nix +++ b/pkgs/by-name/pa/passky-desktop/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, electron_29 -, makeWrapper -, makeDesktopItem -, copyDesktopItems +{ + lib, + stdenv, + fetchFromGitHub, + electron_29, + makeWrapper, + makeDesktopItem, + copyDesktopItems, }: let @@ -49,19 +50,17 @@ stdenv.mkDerivation rec { ''; desktopItems = [ - ( - makeDesktopItem { - name = "passky"; - type = "Application"; - desktopName = "Passky"; - comment = "Simple, modern, open source and secure password manager."; - icon = "passky"; - exec = "passky %U"; - terminal = false; - categories = [ "Utility" ]; - startupWMClass = "Passky"; - } - ) + (makeDesktopItem { + name = "passky"; + type = "Application"; + desktopName = "Passky"; + comment = "Simple, modern, open source and secure password manager."; + icon = "passky"; + exec = "passky %U"; + terminal = false; + categories = [ "Utility" ]; + startupWMClass = "Passky"; + }) ]; meta = with lib; { diff --git a/pkgs/by-name/pa/passmark-performancetest/package.nix b/pkgs/by-name/pa/passmark-performancetest/package.nix index 1d021281f15423..61dddca419641d 100644 --- a/pkgs/by-name/pa/passmark-performancetest/package.nix +++ b/pkgs/by-name/pa/passmark-performancetest/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, curl -, unzip -, ncurses5 -, dmidecode -, coreutils -, util-linux -, autoPatchelfHook -, makeWrapper +{ + lib, + stdenv, + fetchurl, + curl, + unzip, + ncurses5, + dmidecode, + coreutils, + util-linux, + autoPatchelfHook, + makeWrapper, }: let sources = { @@ -26,12 +27,18 @@ stdenv.mkDerivation rec { version = "11.0.1002"; pname = "passmark-performancetest"; - src = fetchurl (sources.${stdenv.system} or (throw "Unsupported system for PassMark performance test")); + src = fetchurl ( + sources.${stdenv.system} or (throw "Unsupported system for PassMark performance test") + ); dontConfigure = true; dontBuild = true; - nativeBuildInputs = [ unzip autoPatchelfHook makeWrapper ]; + nativeBuildInputs = [ + unzip + autoPatchelfHook + makeWrapper + ]; buildInputs = [ (lib.getLib stdenv.cc.cc) @@ -48,11 +55,13 @@ stdenv.mkDerivation rec { # Prefix since program will call sudo postFixup = '' wrapProgram $out/bin/performancetest \ - --prefix PATH ":" ${lib.makeBinPath [ - dmidecode - coreutils - util-linux - ]} + --prefix PATH ":" ${ + lib.makeBinPath [ + dmidecode + coreutils + util-linux + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/pa/passphrase2pgp/package.nix b/pkgs/by-name/pa/passphrase2pgp/package.nix index 0470fd8cfee6da..001eae79cbbfca 100644 --- a/pkgs/by-name/pa/passphrase2pgp/package.nix +++ b/pkgs/by-name/pa/passphrase2pgp/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nix-update-script }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, +}: buildGoModule rec { pname = "passphrase2pgp"; diff --git a/pkgs/by-name/pa/passwdqc/package.nix b/pkgs/by-name/pa/passwdqc/package.nix index f70076243fbbdd..413aa15095a645 100644 --- a/pkgs/by-name/pa/passwdqc/package.nix +++ b/pkgs/by-name/pa/passwdqc/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, libxcrypt -, pam -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + libxcrypt, + pam, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { @@ -26,7 +27,10 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; nativeBuildInputs = [ pkg-config diff --git a/pkgs/by-name/pa/past-time/package.nix b/pkgs/by-name/pa/past-time/package.nix index 4bdcff8c1935d9..1d2b3a15f2dfb0 100644 --- a/pkgs/by-name/pa/past-time/package.nix +++ b/pkgs/by-name/pa/past-time/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pa/pastebinit/package.nix b/pkgs/by-name/pa/pastebinit/package.nix index 27735d615573a4..d798f11ece5677 100644 --- a/pkgs/by-name/pa/pastebinit/package.nix +++ b/pkgs/by-name/pa/pastebinit/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 -, libxslt -, docbook_xsl -, installShellFiles -, callPackage +{ + lib, + stdenv, + fetchFromGitHub, + python3, + libxslt, + docbook_xsl, + installShellFiles, + callPackage, }: stdenv.mkDerivation rec { version = "1.6.2"; @@ -48,7 +49,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://stgraber.org/category/pastebinit/"; description = "Software that lets you send anything you want directly to a pastebin from the command line"; - maintainers = with maintainers; [ raboof samuel-martineau ]; + maintainers = with maintainers; [ + raboof + samuel-martineau + ]; license = licenses.gpl2Plus; platforms = platforms.linux ++ lib.platforms.darwin; }; diff --git a/pkgs/by-name/pa/pasystray/package.nix b/pkgs/by-name/pa/pasystray/package.nix index c0ceb449707df3..b81ace79d9220b 100644 --- a/pkgs/by-name/pa/pasystray/package.nix +++ b/pkgs/by-name/pa/pasystray/package.nix @@ -1,6 +1,18 @@ -{ lib, stdenv, fetchpatch, fetchFromGitHub, pkg-config, autoreconfHook, wrapGAppsHook3 -, adwaita-icon-theme, avahi, gtk3, libayatana-appindicator, libnotify, libpulseaudio -, gsettings-desktop-schemas +{ + lib, + stdenv, + fetchpatch, + fetchFromGitHub, + pkg-config, + autoreconfHook, + wrapGAppsHook3, + adwaita-icon-theme, + avahi, + gtk3, + libayatana-appindicator, + libnotify, + libpulseaudio, + gsettings-desktop-schemas, }: stdenv.mkDerivation rec { @@ -27,12 +39,20 @@ stdenv.mkDerivation rec { url = "https://sources.debian.org/data/main/p/pasystray/0.8.1-1/debian/patches/0002-Require-X11-backend.patch"; sha256 = "sha256-6njC3vqBPWFS1xAsa1katQ4C0KJdVkHAP1MCPiZ6ELM="; }) - ]; + ]; - nativeBuildInputs = [ pkg-config autoreconfHook wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + wrapGAppsHook3 + ]; buildInputs = [ adwaita-icon-theme - avahi gtk3 libayatana-appindicator libnotify libpulseaudio + avahi + gtk3 + libayatana-appindicator + libnotify + libpulseaudio gsettings-desktop-schemas ]; @@ -40,7 +60,10 @@ stdenv.mkDerivation rec { description = "PulseAudio system tray"; homepage = "https://github.com/christophgysin/pasystray"; license = licenses.lgpl21Plus; - maintainers = with maintainers; [ exlevan kamilchm ]; + maintainers = with maintainers; [ + exlevan + kamilchm + ]; platforms = platforms.linux; mainProgram = "pasystray"; }; diff --git a/pkgs/by-name/pa/patatt/package.nix b/pkgs/by-name/pa/patatt/package.nix index 49477035a1101b..b8cef0481b4d45 100644 --- a/pkgs/by-name/pa/patatt/package.nix +++ b/pkgs/by-name/pa/patatt/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "patatt"; @@ -24,6 +28,9 @@ python3Packages.buildPythonApplication rec { DKIM email signature standard to include cryptographic signatures via the X-Developer-Signature email header. ''; - maintainers = with maintainers; [ qyliss yoctocell ]; + maintainers = with maintainers; [ + qyliss + yoctocell + ]; }; } diff --git a/pkgs/by-name/pa/patch2pr/package.nix b/pkgs/by-name/pa/patch2pr/package.nix index b58f84ed100383..3933ec32507c62 100644 --- a/pkgs/by-name/pa/patch2pr/package.nix +++ b/pkgs/by-name/pa/patch2pr/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, patch2pr +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + patch2pr, }: buildGoModule rec { diff --git a/pkgs/by-name/pa/patchPpdFilesHook/package.nix b/pkgs/by-name/pa/patchPpdFilesHook/package.nix index 854f857020aaa8..a37aff60ac8c10 100644 --- a/pkgs/by-name/pa/patchPpdFilesHook/package.nix +++ b/pkgs/by-name/pa/patchPpdFilesHook/package.nix @@ -1,7 +1,8 @@ -{ lib -, makeSetupHook -, which -, callPackage +{ + lib, + makeSetupHook, + which, + callPackage, }: makeSetupHook { @@ -10,7 +11,7 @@ makeSetupHook { which = lib.getBin which; awkscript = ./patch-ppd-lines.awk; }; - passthru.tests.test = callPackage ./test.nix {}; + passthru.tests.test = callPackage ./test.nix { }; meta = { description = "setup hook to patch executable paths in ppd files"; maintainers = [ lib.maintainers.yarny ]; diff --git a/pkgs/by-name/pa/patchPpdFilesHook/test.nix b/pkgs/by-name/pa/patchPpdFilesHook/test.nix index 4f2996b235105a..edb324ecdd8fa3 100644 --- a/pkgs/by-name/pa/patchPpdFilesHook/test.nix +++ b/pkgs/by-name/pa/patchPpdFilesHook/test.nix @@ -1,7 +1,8 @@ -{ substituteAll -, diffutils -, stdenv -, patchPpdFilesHook +{ + substituteAll, + diffutils, + stdenv, + patchPpdFilesHook, }: let @@ -25,7 +26,10 @@ in stdenv.mkDerivation { name = "${patchPpdFilesHook.name}-test"; buildInputs = [ diffutils ]; - nativeBuildInputs = [ diffutils patchPpdFilesHook ]; + nativeBuildInputs = [ + diffutils + patchPpdFilesHook + ]; dontUnpack = true; dontInstall = true; ppdFileCommands = [ "cmp" ]; diff --git a/pkgs/by-name/pa/patchage/package.nix b/pkgs/by-name/pa/patchage/package.nix index c4d1b5ca12c867..fa5f705b8681f2 100644 --- a/pkgs/by-name/pa/patchage/package.nix +++ b/pkgs/by-name/pa/patchage/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitLab -, alsa-lib -, boost -, dbus-glib -, ganv -, glibmm -, gtkmm2 -, libjack2 -, pkg-config -, python3 -, wafHook +{ + lib, + stdenv, + fetchFromGitLab, + alsa-lib, + boost, + dbus-glib, + ganv, + glibmm, + gtkmm2, + libjack2, + pkg-config, + python3, + wafHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pa/patcher9x/package.nix b/pkgs/by-name/pa/patcher9x/package.nix index fdf116a40c8605..f24d259aa21ce7 100644 --- a/pkgs/by-name/pa/patcher9x/package.nix +++ b/pkgs/by-name/pa/patcher9x/package.nix @@ -1,4 +1,9 @@ -{ fasm, lib, stdenv, fetchFromGitHub }: +{ + fasm, + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation (finalAttr: { pname = "patcher9x"; diff --git a/pkgs/by-name/pa/patray/package.nix b/pkgs/by-name/pa/patray/package.nix index b281da1b144ec5..27b286896253ca 100644 --- a/pkgs/by-name/pa/patray/package.nix +++ b/pkgs/by-name/pa/patray/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchPypi -, qt5 +{ + lib, + python3, + fetchPypi, + qt5, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pa/patsh/package.nix b/pkgs/by-name/pa/patsh/package.nix index 476fe420a678fd..7ab0e0e13e1139 100644 --- a/pkgs/by-name/pa/patsh/package.nix +++ b/pkgs/by-name/pa/patsh/package.nix @@ -1,9 +1,10 @@ -{ lib -, runCommand -, rustPlatform -, fetchFromGitHub -, stdenv -, coreutils +{ + lib, + runCommand, + rustPlatform, + fetchFromGitHub, + stdenv, + coreutils, }: let diff --git a/pkgs/by-name/pa/paulstretch/package.nix b/pkgs/by-name/pa/paulstretch/package.nix index c539521f11679d..18648c5e5f3060 100644 --- a/pkgs/by-name/pa/paulstretch/package.nix +++ b/pkgs/by-name/pa/paulstretch/package.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, audiofile, libvorbis, fltk, fftw, fftwFloat -, minixml, pkg-config, libmad, libjack2, portaudio, libsamplerate +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + audiofile, + libvorbis, + fltk, + fftw, + fftwFloat, + minixml, + pkg-config, + libmad, + libjack2, + portaudio, + libsamplerate, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/pa/pax-rs/package.nix b/pkgs/by-name/pa/pax-rs/package.nix index 6152e0c8dc38c6..8278405f3f399c 100644 --- a/pkgs/by-name/pa/pax-rs/package.nix +++ b/pkgs/by-name/pa/pax-rs/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, fetchurl, rustPlatform, runCommand } : +{ + lib, + fetchFromGitHub, + fetchurl, + rustPlatform, + runCommand, +}: rustPlatform.buildRustPackage rec { pname = "pax-rs"; @@ -30,7 +36,7 @@ rustPlatform.buildRustPackage rec { sha256 = "0ff1b64b99cbca1cc2ceabcd2e4f7bc3411e3a2a9fbb9db2204d9240fe38ddeb"; }; in - runCommand "pax-rs-src" {} '' + runCommand "pax-rs-src" { } '' cp -R ${source} $out chmod +w $out cp ${cargo-lock} $out/Cargo.lock diff --git a/pkgs/by-name/pa/pax-utils/package.nix b/pkgs/by-name/pa/pax-utils/package.nix index 015b38455d0d58..14835781a4cee4 100644 --- a/pkgs/by-name/pa/pax-utils/package.nix +++ b/pkgs/by-name/pa/pax-utils/package.nix @@ -1,17 +1,19 @@ -{ stdenv -, lib -, fetchgit -, buildPackages -, docbook_xml_dtd_44 -, docbook_xsl -, withLibcap ? stdenv.hostPlatform.isLinux, libcap -, pkg-config -, meson -, ninja -, xmlto -, python3 - -, gitUpdater +{ + stdenv, + lib, + fetchgit, + buildPackages, + docbook_xml_dtd_44, + docbook_xsl, + withLibcap ? stdenv.hostPlatform.isLinux, + libcap, + pkg-config, + meson, + ninja, + xmlto, + python3, + + gitUpdater, }: stdenv.mkDerivation rec { @@ -31,7 +33,14 @@ stdenv.mkDerivation rec { ]; depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ docbook_xml_dtd_44 docbook_xsl meson ninja pkg-config xmlto ]; + nativeBuildInputs = [ + docbook_xml_dtd_44 + docbook_xsl + meson + ninja + pkg-config + xmlto + ]; buildInputs = lib.optionals withLibcap [ libcap ]; # Needed for lddtree propagatedBuildInputs = [ (python3.withPackages (p: with p; [ pyelftools ])) ]; @@ -52,6 +61,9 @@ stdenv.mkDerivation rec { homepage = "https://wiki.gentoo.org/wiki/Hardened/PaX_Utilities"; license = licenses.gpl2Only; platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice joachifm ]; + maintainers = with maintainers; [ + thoughtpolice + joachifm + ]; }; } diff --git a/pkgs/by-name/pa/paxctl/package.nix b/pkgs/by-name/pa/paxctl/package.nix index bdddcacf195f2c..8f6741d68acbfe 100644 --- a/pkgs/by-name/pa/paxctl/package.nix +++ b/pkgs/by-name/pa/paxctl/package.nix @@ -1,4 +1,9 @@ -{ fetchurl, lib, stdenv, elf-header }: +{ + fetchurl, + lib, + stdenv, + elf-header, +}: stdenv.mkDerivation rec { pname = "paxctl"; @@ -25,9 +30,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Tool for controlling PaX flags on a per binary basis"; mainProgram = "paxctl"; - homepage = "https://pax.grsecurity.net"; - license = licenses.gpl2Only; - platforms = platforms.all; + homepage = "https://pax.grsecurity.net"; + license = licenses.gpl2Only; + platforms = platforms.all; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/pa/paxtest/package.nix b/pkgs/by-name/pa/paxtest/package.nix index b415970a743efe..149c334e891b0d 100644 --- a/pkgs/by-name/pa/paxtest/package.nix +++ b/pkgs/by-name/pa/paxtest/package.nix @@ -1,25 +1,37 @@ -{ lib, stdenv, fetchurl, paxctl }: +{ + lib, + stdenv, + fetchurl, + paxctl, +}: stdenv.mkDerivation rec { pname = "paxtest"; version = "0.9.15"; src = fetchurl { - url = "https://www.grsecurity.net/~spender/${pname}-${version}.tar.gz"; + url = "https://www.grsecurity.net/~spender/${pname}-${version}.tar.gz"; sha256 = "0zv6vlaszlik98gj9200sv0irvfzrvjn46rnr2v2m37x66288lym"; }; enableParallelBuilding = true; - makefile = "Makefile.psm"; - makeFlags = [ "PAXBIN=${paxctl}/bin/paxctl" "BINDIR=$(out)/bin" "RUNDIR=$(out)/lib/paxtest" ]; + makefile = "Makefile.psm"; + makeFlags = [ + "PAXBIN=${paxctl}/bin/paxctl" + "BINDIR=$(out)/bin" + "RUNDIR=$(out)/lib/paxtest" + ]; installFlags = [ "DESTDIR=\"\"" ]; meta = with lib; { description = "Test various memory protection measures"; mainProgram = "paxtest"; - license = licenses.gpl2Only; - platforms = platforms.linux; - maintainers = with maintainers; [ copumpkin joachifm ]; + license = licenses.gpl2Only; + platforms = platforms.linux; + maintainers = with maintainers; [ + copumpkin + joachifm + ]; }; } diff --git a/pkgs/by-name/pa/payload-dumper-go/package.nix b/pkgs/by-name/pa/payload-dumper-go/package.nix index e09322a0138cac..4aea8dc124d7f3 100644 --- a/pkgs/by-name/pa/payload-dumper-go/package.nix +++ b/pkgs/by-name/pa/payload-dumper-go/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, xz +{ + lib, + buildGoModule, + fetchFromGitHub, + xz, }: buildGoModule rec { diff --git a/pkgs/by-name/pa/payload_dumper/package.nix b/pkgs/by-name/pa/payload_dumper/package.nix index ebb717a9e4ceb8..6f971ded3d4a73 100644 --- a/pkgs/by-name/pa/payload_dumper/package.nix +++ b/pkgs/by-name/pa/payload_dumper/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, makeWrapper -, python3 -, fetchFromGitHub +{ + lib, + stdenv, + makeWrapper, + python3, + fetchFromGitHub, }: stdenv.mkDerivation (finalAttrs: { @@ -18,7 +19,10 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ makeWrapper ]; - buildInputs = with python3.pkgs; [ bsdiff4 protobuf ]; + buildInputs = with python3.pkgs; [ + bsdiff4 + protobuf + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/pa/payloadsallthethings/package.nix b/pkgs/by-name/pa/payloadsallthethings/package.nix index 9e70611c7d283d..2fd0fb3d760297 100644 --- a/pkgs/by-name/pa/payloadsallthethings/package.nix +++ b/pkgs/by-name/pa/payloadsallthethings/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, stdenvNoCC +{ + lib, + fetchFromGitHub, + stdenvNoCC, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/pa/payme/package.nix b/pkgs/by-name/pa/payme/package.nix index bab0236db12ec1..70df0c753a3c8f 100644 --- a/pkgs/by-name/pa/payme/package.nix +++ b/pkgs/by-name/pa/payme/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "payme"; diff --git a/pkgs/by-name/pa/pazi/package.nix b/pkgs/by-name/pa/pazi/package.nix index 2ccabe62809831..375527a267df8d 100644 --- a/pkgs/by-name/pa/pazi/package.nix +++ b/pkgs/by-name/pa/pazi/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, darwin, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "pazi"; diff --git a/pkgs/by-name/pb/pb/package.nix b/pkgs/by-name/pb/pb/package.nix index 7e427b1b4e3395..2290e728b45039 100644 --- a/pkgs/by-name/pb/pb/package.nix +++ b/pkgs/by-name/pb/pb/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, pb }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + pb, +}: buildGoModule rec { pname = "pb"; diff --git a/pkgs/by-name/pb/pb_cli/package.nix b/pkgs/by-name/pb/pb_cli/package.nix index ac9b7b6f22c207..bed3937b1d1111 100644 --- a/pkgs/by-name/pb/pb_cli/package.nix +++ b/pkgs/by-name/pb/pb_cli/package.nix @@ -1,5 +1,17 @@ -{ screenshots ? true, video ? false, clipboard ? true -, lib, stdenv, jq, curl, fetchFromGitHub, makeWrapper, maim ? null, xclip ? null, capture ? null }: +{ + screenshots ? true, + video ? false, + clipboard ? true, + lib, + stdenv, + jq, + curl, + fetchFromGitHub, + makeWrapper, + maim ? null, + xclip ? null, + capture ? null, +}: assert screenshots -> maim != null; assert video -> capture != null; @@ -12,15 +24,20 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "ptpb"; repo = "pb_cli"; - rev = "6b9ce1ee45fe651d06d7c479a20026a173dd328b"; + rev = "6b9ce1ee45fe651d06d7c479a20026a173dd328b"; sha256 = "0w6a789zffvz4ixsb92q45n5s4xyx7s2l2f07972i3dajaaai8z7"; }; nativeBuildInputs = [ makeWrapper ]; - liveDeps = [ jq curl ] ++ lib.optional screenshots maim - ++ lib.optional video capture - ++ lib.optional clipboard xclip; + liveDeps = + [ + jq + curl + ] + ++ lib.optional screenshots maim + ++ lib.optional video capture + ++ lib.optional clipboard xclip; installPhase = '' install -Dm755 src/pb.sh $out/bin/pb diff --git a/pkgs/by-name/pb/pbgopy/package.nix b/pkgs/by-name/pb/pbgopy/package.nix index 50d0de133e8e34..a58cce6be11588 100644 --- a/pkgs/by-name/pb/pbgopy/package.nix +++ b/pkgs/by-name/pb/pbgopy/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pbgopy"; diff --git a/pkgs/by-name/pb/pbm/package.nix b/pkgs/by-name/pb/pbm/package.nix index 57646c1db1619e..b4d6f1325f9aad 100644 --- a/pkgs/by-name/pb/pbm/package.nix +++ b/pkgs/by-name/pb/pbm/package.nix @@ -12,7 +12,10 @@ buildDotnetGlobalTool { changelog = "https://cmd.petabridge.com/articles/RELEASE_NOTES.html"; license = licenses.unfree; platforms = platforms.linux; - maintainers = with maintainers; [ anpin mdarocha ]; + maintainers = with maintainers; [ + anpin + mdarocha + ]; mainProgram = "pbm"; }; } diff --git a/pkgs/by-name/pb/pbpctrl/package.nix b/pkgs/by-name/pb/pbpctrl/package.nix index 782fb1ac926b78..7090d712f7cb61 100644 --- a/pkgs/by-name/pb/pbpctrl/package.nix +++ b/pkgs/by-name/pb/pbpctrl/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, dbus -, protobuf +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + dbus, + protobuf, }: rustPlatform.buildRustPackage rec { @@ -19,14 +20,23 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-W59TRrFSm/IrStH9YitoG6nLs9pesDmL9+/DHnty3nw="; - nativeBuildInputs = [ pkg-config protobuf ]; + nativeBuildInputs = [ + pkg-config + protobuf + ]; buildInputs = [ dbus ]; meta = with lib; { description = "Control Google Pixel Buds Pro from the Linux command line"; homepage = "https://github.com/qzed/pbpctrl"; - license = with licenses; [ asl20 mit ]; - maintainers = with maintainers; [ vanilla cafkafk ]; + license = with licenses; [ + asl20 + mit + ]; + maintainers = with maintainers; [ + vanilla + cafkafk + ]; platforms = platforms.linux; mainProgram = "pbpctrl"; }; diff --git a/pkgs/by-name/pb/pbrt/package.nix b/pkgs/by-name/pb/pbrt/package.nix index 07483df7e4d770..cb9b8d6f05198e 100644 --- a/pkgs/by-name/pb/pbrt/package.nix +++ b/pkgs/by-name/pb/pbrt/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchFromGitHub, flex, bison, cmake, zlib}: +{ + lib, + stdenv, + fetchFromGitHub, + flex, + bison, + cmake, + zlib, +}: stdenv.mkDerivation { version = "2018-08-15"; @@ -6,8 +14,8 @@ stdenv.mkDerivation { src = fetchFromGitHub { rev = "86b5821308088deea70b207bc8c22219d0103d65"; - owner = "mmp"; - repo = "pbrt-v3"; + owner = "mmp"; + repo = "pbrt-v3"; sha256 = "0f7ivsczba6zfk5f0bba1js6dcwf6w6jrkiby147qp1sx5k35cv8"; fetchSubmodules = true; }; @@ -17,7 +25,11 @@ stdenv.mkDerivation { ./openexr-cmake-3.12.patch ]; - nativeBuildInputs = [ flex bison cmake ]; + nativeBuildInputs = [ + flex + bison + cmake + ]; buildInputs = [ zlib ]; meta = with lib; { diff --git a/pkgs/by-name/pb/pbzip2/package.nix b/pkgs/by-name/pb/pbzip2/package.nix index d9eecda0d6063f..3348f0b85ee395 100644 --- a/pkgs/by-name/pb/pbzip2/package.nix +++ b/pkgs/by-name/pb/pbzip2/package.nix @@ -1,7 +1,13 @@ -{ lib, stdenv, fetchurl, bzip2 }: +{ + lib, + stdenv, + fetchurl, + bzip2, +}: -let major = "1.1"; - version = "${major}.13"; +let + major = "1.1"; + version = "${major}.13"; in stdenv.mkDerivation rec { pname = "pbzip2"; diff --git a/pkgs/by-name/pb/pbzx/package.nix b/pkgs/by-name/pb/pbzx/package.nix index aa5692d14c5193..4f96d27de10cf3 100644 --- a/pkgs/by-name/pb/pbzx/package.nix +++ b/pkgs/by-name/pb/pbzx/package.nix @@ -1,4 +1,10 @@ -{stdenv, lib, fetchFromGitHub, xz, xar}: +{ + stdenv, + lib, + fetchFromGitHub, + xz, + xar, +}: stdenv.mkDerivation rec { pname = "pbzx"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "0bwd7wmnhpz1n5p39mh6asfyccj4cm06hwigslcwbb3pdwmvxc90"; }; patches = [ ./stdin.patch ]; - buildInputs = [ xz xar ]; + buildInputs = [ + xz + xar + ]; buildPhase = '' ${stdenv.cc.targetPrefix}cc pbzx.c -llzma -lxar -o pbzx ''; diff --git a/pkgs/by-name/pc/pc/package.nix b/pkgs/by-name/pc/pc/package.nix index 6e9c23ee6d8aa0..9abcda1d567b26 100644 --- a/pkgs/by-name/pc/pc/package.nix +++ b/pkgs/by-name/pc/pc/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, byacc -, fetchFromSourcehut -, gitUpdater +{ + lib, + stdenv, + byacc, + fetchFromSourcehut, + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pc/pcalc/package.nix b/pkgs/by-name/pc/pcalc/package.nix index 64ab5acebed2d0..77251404bba42b 100644 --- a/pkgs/by-name/pc/pcalc/package.nix +++ b/pkgs/by-name/pc/pcalc/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, bison, flex }: +{ + lib, + stdenv, + fetchFromGitHub, + bison, + flex, +}: stdenv.mkDerivation rec { pname = "pcalc"; @@ -12,7 +18,10 @@ stdenv.mkDerivation rec { }; makeFlags = [ "DESTDIR= BINDIR=$(out)/bin" ]; - nativeBuildInputs = [ bison flex ]; + nativeBuildInputs = [ + bison + flex + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/pc/pcapc/package.nix b/pkgs/by-name/pc/pcapc/package.nix index 35b338a5f63a82..0e7d8121d9cddc 100644 --- a/pkgs/by-name/pc/pcapc/package.nix +++ b/pkgs/by-name/pc/pcapc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, libpcap }: +{ + lib, + stdenv, + fetchFromGitLab, + libpcap, +}: stdenv.mkDerivation rec { pname = "pcapc"; diff --git a/pkgs/by-name/pc/pcapfix/package.nix b/pkgs/by-name/pc/pcapfix/package.nix index 3f7a5be86ce0fa..9818b57125a19e 100644 --- a/pkgs/by-name/pc/pcapfix/package.nix +++ b/pkgs/by-name/pc/pcapfix/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "pcapfix"; diff --git a/pkgs/by-name/pc/pcaudiolib/package.nix b/pkgs/by-name/pc/pcaudiolib/package.nix index 1152283b1f2c3a..c426e57d09cce0 100644 --- a/pkgs/by-name/pc/pcaudiolib/package.nix +++ b/pkgs/by-name/pc/pcaudiolib/package.nix @@ -1,16 +1,17 @@ -{ config -, lib -, stdenv -, fetchFromGitHub -, alsa-lib -, autoconf -, automake -, libpulseaudio -, libtool -, pkg-config -, portaudio -, which -, pulseaudioSupport ? config.pulseaudio or stdenv.hostPlatform.isLinux +{ + config, + lib, + stdenv, + fetchFromGitHub, + alsa-lib, + autoconf, + automake, + libpulseaudio, + libtool, + pkg-config, + portaudio, + which, + pulseaudioSupport ? config.pulseaudio or stdenv.hostPlatform.isLinux, }: stdenv.mkDerivation (finalAttrs: { @@ -32,19 +33,22 @@ stdenv.mkDerivation (finalAttrs: { which ]; - buildInputs = [ - portaudio - ] - ++ lib.optional stdenv.hostPlatform.isLinux alsa-lib - ++ lib.optional pulseaudioSupport libpulseaudio; + buildInputs = + [ + portaudio + ] + ++ lib.optional stdenv.hostPlatform.isLinux alsa-lib + ++ lib.optional pulseaudioSupport libpulseaudio; # touch ChangeLog to avoid below error on darwin: # Makefile.am: error: required file './ChangeLog.md' not found - preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin '' - touch ChangeLog - '' + '' - ./autogen.sh - ''; + preConfigure = + lib.optionalString stdenv.hostPlatform.isDarwin '' + touch ChangeLog + '' + + '' + ./autogen.sh + ''; meta = with lib; { homepage = "https://github.com/espeak-ng/pcaudiolib"; diff --git a/pkgs/by-name/pc/pcb/package.nix b/pkgs/by-name/pc/pcb/package.nix index f8623d9a7bf7b5..1dd1be7f912a55 100644 --- a/pkgs/by-name/pc/pcb/package.nix +++ b/pkgs/by-name/pc/pcb/package.nix @@ -1,23 +1,25 @@ -{ lib, stdenv -, fetchurl -, pkg-config -, gtk2 -, bison -, intltool -, flex -, netpbm -, imagemagick -, dbus -, freetype -, fontconfig -, libGLU -, libGL -, shared-mime-info -, tcl -, tk -, gnome2 -, gd -, xorg +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + bison, + intltool, + flex, + netpbm, + imagemagick, + dbus, + freetype, + fontconfig, + libGLU, + libGL, + shared-mime-info, + tcl, + tk, + gnome2, + gd, + xorg, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pc/pcb2gcode/package.nix b/pkgs/by-name/pc/pcb2gcode/package.nix index 1ba4a8aea5e4d4..3d0cc9ef7069f0 100644 --- a/pkgs/by-name/pc/pcb2gcode/package.nix +++ b/pkgs/by-name/pc/pcb2gcode/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, pkg-config -, boost -, glibmm -, gtkmm2 -, gerbv -, librsvg +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + pkg-config, + boost, + glibmm, + gtkmm2, + gerbv, + librsvg, }: stdenv.mkDerivation rec { @@ -21,9 +22,18 @@ stdenv.mkDerivation rec { hash = "sha256-c5YabBqZn6ilIkF3lifTsYyLZMsZN21jDj1hNu0PRAc="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ boost glibmm gtkmm2 gerbv librsvg ]; + buildInputs = [ + boost + glibmm + gtkmm2 + gerbv + librsvg + ]; postPatch = '' substituteInPlace ./Makefile.am \ diff --git a/pkgs/by-name/pc/pcem/package.nix b/pkgs/by-name/pc/pcem/package.nix index 9ffa24a66e3081..d3b49edf76f1b5 100644 --- a/pkgs/by-name/pc/pcem/package.nix +++ b/pkgs/by-name/pc/pcem/package.nix @@ -1,5 +1,19 @@ -{ stdenv, lib, fetchzip, wxGTK32, coreutils, SDL2, openal, alsa-lib, pkg-config, gtk3, wrapGAppsHook3 -, autoreconfHook, withNetworking ? true, withALSA ? true }: +{ + stdenv, + lib, + fetchzip, + wxGTK32, + coreutils, + SDL2, + openal, + alsa-lib, + pkg-config, + gtk3, + wrapGAppsHook3, + autoreconfHook, + withNetworking ? true, + withALSA ? true, +}: stdenv.mkDerivation rec { pname = "pcem"; @@ -11,11 +25,21 @@ stdenv.mkDerivation rec { sha256 = "067pbnc15h6a4pnnym82klr1w8qwfm6p0pkx93gx06wvwqsxvbdv"; }; - nativeBuildInputs = [ autoreconfHook pkg-config wrapGAppsHook3 ]; - buildInputs = [ wxGTK32 coreutils SDL2 openal gtk3 ] - ++ lib.optional withALSA alsa-lib; + nativeBuildInputs = [ + autoreconfHook + pkg-config + wrapGAppsHook3 + ]; + buildInputs = [ + wxGTK32 + coreutils + SDL2 + openal + gtk3 + ] ++ lib.optional withALSA alsa-lib; - configureFlags = [ "--enable-release-build" ] + configureFlags = + [ "--enable-release-build" ] ++ lib.optional withNetworking "--enable-networking" ++ lib.optional withALSA "--enable-alsa"; diff --git a/pkgs/by-name/pc/pcg_c/package.nix b/pkgs/by-name/pc/pcg_c/package.nix index 3ad9df8b64bdb8..cef3e641b617e9 100644 --- a/pkgs/by-name/pc/pcg_c/package.nix +++ b/pkgs/by-name/pc/pcg_c/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { version = "0.94"; @@ -13,7 +17,7 @@ stdenv.mkDerivation rec { patches = [ ./prefix-variable.patch - ]; + ]; preInstall = '' sed -i s,/usr/local,$out, Makefile diff --git a/pkgs/by-name/pc/pcimem/package.nix b/pkgs/by-name/pc/pcimem/package.nix index 2f41e4c7395e66..4d81dd4d364236 100644 --- a/pkgs/by-name/pc/pcimem/package.nix +++ b/pkgs/by-name/pc/pcimem/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "pcimem"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "0zlbvcl5q4hgna11p3w00px1p8qgn8ga79lh6a2m7d597g86kbq3"; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; makeFlags = [ "CFLAGS=-Wno-maybe-uninitialized" ]; diff --git a/pkgs/by-name/pc/pcloud/package.nix b/pkgs/by-name/pc/pcloud/package.nix index afec1baa79f6eb..58309913995b24 100644 --- a/pkgs/by-name/pc/pcloud/package.nix +++ b/pkgs/by-name/pc/pcloud/package.nix @@ -16,24 +16,24 @@ { # Build dependencies - appimageTools -, autoPatchelfHook -, fetchzip -, lib -, stdenv + appimageTools, + autoPatchelfHook, + fetchzip, + lib, + stdenv, # Runtime dependencies; # A few additional ones (e.g. Node) are already shipped together with the # AppImage, so we don't have to duplicate them here. -, alsa-lib -, dbus-glib -, fuse -, gsettings-desktop-schemas -, gtk3 -, libdbusmenu-gtk2 -, libXdamage -, nss -, udev + alsa-lib, + dbus-glib, + fuse, + gsettings-desktop-schemas, + gtk3, + libdbusmenu-gtk2, + libXdamage, + nss, + udev, }: let diff --git a/pkgs/by-name/pc/pcm/package.nix b/pkgs/by-name/pc/pcm/package.nix index 0ce82515d1d0fa..1a571fc70e9911 100644 --- a/pkgs/by-name/pc/pcm/package.nix +++ b/pkgs/by-name/pc/pcm/package.nix @@ -1,4 +1,9 @@ -{ cmake, fetchFromGitHub, lib, stdenv }: +{ + cmake, + fetchFromGitHub, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "pcm"; diff --git a/pkgs/by-name/pc/pcmanfm/package.nix b/pkgs/by-name/pc/pcmanfm/package.nix index 3e8d22a65b8d01..9761a386781061 100644 --- a/pkgs/by-name/pc/pcmanfm/package.nix +++ b/pkgs/by-name/pc/pcmanfm/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, glib -, intltool -, libfm -, libX11 -, pango -, pkg-config -, wrapGAppsHook3 -, adwaita-icon-theme -, withGtk3 ? true -, gtk2 -, gtk3 +{ + lib, + stdenv, + fetchurl, + glib, + intltool, + libfm, + libX11, + pango, + pkg-config, + wrapGAppsHook3, + adwaita-icon-theme, + withGtk3 ? true, + gtk2, + gtk3, }: let @@ -28,8 +29,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-FMt7JHSTxMzmX7tZAmEeOtAKeocPvB5QrcUEKMUUDPc="; }; - buildInputs = [ glib gtk libfm' libX11 pango adwaita-icon-theme ]; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 intltool ]; + buildInputs = [ + glib + gtk + libfm' + libX11 + pango + adwaita-icon-theme + ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + intltool + ]; configureFlags = optional withGtk3 "--with-gtk=3"; diff --git a/pkgs/by-name/pc/pcmanx-gtk2/package.nix b/pkgs/by-name/pc/pcmanx-gtk2/package.nix index 6179bbe15fbf57..9e2bea957a66a8 100644 --- a/pkgs/by-name/pc/pcmanx-gtk2/package.nix +++ b/pkgs/by-name/pc/pcmanx-gtk2/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, gtk2, libXft, intltool, automake, autoconf, libtool, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + gtk2, + libXft, + intltool, + automake, + autoconf, + libtool, + pkg-config, +}: stdenv.mkDerivation rec { pname = "pcmanx-gtk2"; @@ -11,8 +22,17 @@ stdenv.mkDerivation rec { sha256 = "0fbwd149wny67rfhczz4cbh713a1qnswjiz7b6c2bxfcwh51f9rc"; }; - nativeBuildInputs = [ pkg-config automake autoconf intltool ]; - buildInputs = [ gtk2 libXft libtool ]; + nativeBuildInputs = [ + pkg-config + automake + autoconf + intltool + ]; + buildInputs = [ + gtk2 + libXft + libtool + ]; preConfigure = '' ./autogen.sh diff --git a/pkgs/by-name/pc/pcmciaUtils/package.nix b/pkgs/by-name/pc/pcmciaUtils/package.nix index bcfb101c6fcb58..5ae0c4d24ab072 100644 --- a/pkgs/by-name/pc/pcmciaUtils/package.nix +++ b/pkgs/by-name/pc/pcmciaUtils/package.nix @@ -1,9 +1,16 @@ -{ config, lib, stdenv, fetchurl -, bison, flex -, sysfsutils, kmod, udev -, firmware ? config.pcmciaUtils.firmware or [] # Special pcmcia cards. -, configOpts ? config.pcmciaUtils.config or null # Special hardware (map memory & port & irq) -}: # used to generate postInstall script. +{ + config, + lib, + stdenv, + fetchurl, + bison, + flex, + sysfsutils, + kmod, + udev, + firmware ? config.pcmciaUtils.firmware or [ ], # Special pcmcia cards. + configOpts ? config.pcmciaUtils.config or null, # Special hardware (map memory & port & irq) +}: # used to generate postInstall script. # FIXME: should add an option to choose between hotplug and udev. stdenv.mkDerivation rec { @@ -15,32 +22,40 @@ stdenv.mkDerivation rec { sha256 = "0sfm3w2n73kl5w7gb1m6q8gy5k4rgwvzz79n6yhs9w3sag3ix8sk"; }; - buildInputs = [udev bison sysfsutils kmod flex]; + buildInputs = [ + udev + bison + sysfsutils + kmod + flex + ]; - patchPhase = '' - sed -i " - s,/sbin/modprobe,${kmod}&,; - s,/lib/udev/,$out/sbin/,; - " udev/* # fix-color */ - sed -i " - s,/lib/firmware,$out&,; - s,/etc/pcmcia,$out&,; - " src/{startup.c,pcmcia-check-broken-cis.c} # fix-color */ - '' - + (lib.optionalString (firmware == []) ''sed -i "s,STARTUP = true,STARTUP = false," Makefile'') - + (lib.optionalString (configOpts != null) "ln -sf ${configOpts} ./config/config.opts") - ; + patchPhase = + '' + sed -i " + s,/sbin/modprobe,${kmod}&,; + s,/lib/udev/,$out/sbin/,; + " udev/* # fix-color */ + sed -i " + s,/lib/firmware,$out&,; + s,/etc/pcmcia,$out&,; + " src/{startup.c,pcmcia-check-broken-cis.c} # fix-color */ + '' + + (lib.optionalString (firmware == [ ]) ''sed -i "s,STARTUP = true,STARTUP = false," Makefile'') + + (lib.optionalString (configOpts != null) "ln -sf ${configOpts} ./config/config.opts"); makeFlags = [ "LEX=flex" ]; - installFlags = [ "INSTALL=install" "DESTDIR=${placeholder "out"}" ]; - postInstall = - lib.concatMapStrings (path: '' - for f in : $(find ${path} -type f); do - test "$f" == ":" && continue; - mkdir -p $(dirname $out/lib/firmware/$\{f#${path}}); - ln -s $f $out/lib/firmware/$\{f#${path}}; - done; - '') firmware; + installFlags = [ + "INSTALL=install" + "DESTDIR=${placeholder "out"}" + ]; + postInstall = lib.concatMapStrings (path: '' + for f in : $(find ${path} -type f); do + test "$f" == ":" && continue; + mkdir -p $(dirname $out/lib/firmware/$\{f#${path}}); + ln -s $f $out/lib/firmware/$\{f#${path}}; + done; + '') firmware; meta = { homepage = "https://www.kernel.org/pub/linux/utils/kernel/pcmcia/"; diff --git a/pkgs/by-name/pc/pcmsolver/package.nix b/pkgs/by-name/pc/pcmsolver/package.nix index c2924426f8bb49..7572e14c3dfd21 100644 --- a/pkgs/by-name/pc/pcmsolver/package.nix +++ b/pkgs/by-name/pc/pcmsolver/package.nix @@ -1,16 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, cmake, perl, gfortran, python3 -, boost, eigen, zlib -} : +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + perl, + gfortran, + python3, + boost, + eigen, + zlib, +}: stdenv.mkDerivation rec { pname = "pcmsolver"; version = "1.3.0"; - src = fetchFromGitHub { + src = fetchFromGitHub { owner = "PCMSolver"; repo = pname; rev = "v${version}"; - sha256= "0jrxr8z21hjy7ik999hna9rdqy221kbkl3qkb06xw7g80rc9x9yr"; + sha256 = "0jrxr8z21hjy7ik999hna9rdqy221kbkl3qkb06xw7g80rc9x9yr"; }; # Glibc 2.34 changed SIGSTKSZ to a dynamic value, which breaks diff --git a/pkgs/by-name/pc/pcp/package.nix b/pkgs/by-name/pc/pcp/package.nix index e9d245c8129d84..a8d6e1c58ba90e 100644 --- a/pkgs/by-name/pc/pcp/package.nix +++ b/pkgs/by-name/pc/pcp/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pcp"; diff --git a/pkgs/by-name/pc/pcsc-cyberjack/package.nix b/pkgs/by-name/pc/pcsc-cyberjack/package.nix index fa96753a54f64c..2dad6ad25a96fd 100644 --- a/pkgs/by-name/pc/pcsc-cyberjack/package.nix +++ b/pkgs/by-name/pc/pcsc-cyberjack/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pkg-config, libusb1, pcsclite }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + libusb1, + pcsclite, +}: let version = "3.99.5"; @@ -11,16 +19,24 @@ stdenv.mkDerivation rec { inherit version; src = fetchurl { - url = - "https://support.reiner-sct.de/downloads/LINUX/V${version}_${suffix}/${pname}_${tarBall}.tar.bz2"; + url = "https://support.reiner-sct.de/downloads/LINUX/V${version}_${suffix}/${pname}_${tarBall}.tar.bz2"; sha256 = "sha256-rLfCgyRQcYdWcTdnxLPvUAgy1lLtUbNRELkQsR69Rno="; }; - outputs = [ "out" "tools" ]; + outputs = [ + "out" + "tools" + ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ libusb1 pcsclite ]; + buildInputs = [ + libusb1 + pcsclite + ]; enableParallelBuilding = true; @@ -38,7 +54,10 @@ stdenv.mkDerivation rec { mainProgram = "cjflash"; homepage = "https://www.reiner-sct.com/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ aszlig flokli ]; + maintainers = with maintainers; [ + aszlig + flokli + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/pc/pcsc-scm-scl011/package.nix b/pkgs/by-name/pc/pcsc-scm-scl011/package.nix index af3a95f0a2aac4..3516a415b3b350 100644 --- a/pkgs/by-name/pc/pcsc-scm-scl011/package.nix +++ b/pkgs/by-name/pc/pcsc-scm-scl011/package.nix @@ -1,9 +1,19 @@ -{ lib, stdenv, fetchurl, unzip, libusb-compat-0_1 }: +{ + lib, + stdenv, + fetchurl, + unzip, + libusb-compat-0_1, +}: let - arch = if stdenv.hostPlatform.system == "i686-linux" then "32" - else if stdenv.hostPlatform.system == "x86_64-linux" then "64" - else throw "Unsupported system: ${stdenv.hostPlatform.system}"; + arch = + if stdenv.hostPlatform.system == "i686-linux" then + "32" + else if stdenv.hostPlatform.system == "x86_64-linux" then + "64" + else + throw "Unsupported system: ${stdenv.hostPlatform.system}"; in stdenv.mkDerivation rec { pname = "pcsc-scm-scl"; diff --git a/pkgs/by-name/pc/pcstat/package.nix b/pkgs/by-name/pc/pcstat/package.nix index 85e6c791990eb6..2b9b2ddb5c2a0d 100644 --- a/pkgs/by-name/pc/pcstat/package.nix +++ b/pkgs/by-name/pc/pcstat/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pcstat"; diff --git a/pkgs/by-name/pc/pcsx2/package.nix b/pkgs/by-name/pc/pcsx2/package.nix index ce38e20d6802ea..17c7245f4b2a8a 100644 --- a/pkgs/by-name/pc/pcsx2/package.nix +++ b/pkgs/by-name/pc/pcsx2/package.nix @@ -135,8 +135,6 @@ llvmPackages_17.stdenv.mkDerivation (finalAttrs: { govanify matteopacini ]; - platforms = lib.systems.inspect.patternLogicalAnd - lib.systems.inspect.patterns.isLinux - lib.systems.inspect.patterns.isx86_64; + platforms = lib.systems.inspect.patternLogicalAnd lib.systems.inspect.patterns.isLinux lib.systems.inspect.patterns.isx86_64; }; }) diff --git a/pkgs/by-name/pc/pcsx2/sources.nix b/pkgs/by-name/pc/pcsx2/sources.nix index 87046847e942ea..c3a210502c4521 100644 --- a/pkgs/by-name/pc/pcsx2/sources.nix +++ b/pkgs/by-name/pc/pcsx2/sources.nix @@ -4,38 +4,40 @@ }: let - pcsx2 = let - self = { - pname = "pcsx2"; - version = "2.3.39"; - src = fetchFromGitHub { - pname = "pcsx2-source"; - inherit (self) version; - owner = "PCSX2"; - repo = "pcsx2"; - rev = "v${self.version}"; - hash = "sha256-Knlkf4GcN8OCgrd1nwdnYVCDA/7lyAfcoV4mLCkrHtg="; + pcsx2 = + let + self = { + pname = "pcsx2"; + version = "2.3.39"; + src = fetchFromGitHub { + pname = "pcsx2-source"; + inherit (self) version; + owner = "PCSX2"; + repo = "pcsx2"; + rev = "v${self.version}"; + hash = "sha256-Knlkf4GcN8OCgrd1nwdnYVCDA/7lyAfcoV4mLCkrHtg="; + }; }; - }; - in + in self; # The pre-zipped files in releases don't have a versioned link, we need to zip # them ourselves - pcsx2_patches = let - self = { - pname = "pcsx2_patches"; - version = "0-unstable-2024-11-23"; - src = fetchFromGitHub { - pname = "pcsx2_patches-source"; - inherit (self) version; - owner = "PCSX2"; - repo = "pcsx2_patches"; - rev = "5cc1d09a72c0afcd04e2ca089a6b279108328fda"; - hash = "sha256-or77ZsWU0YWtxj9LKJ/m8nDvKSyiF1sO140QaH6Jr64="; + pcsx2_patches = + let + self = { + pname = "pcsx2_patches"; + version = "0-unstable-2024-11-23"; + src = fetchFromGitHub { + pname = "pcsx2_patches-source"; + inherit (self) version; + owner = "PCSX2"; + repo = "pcsx2_patches"; + rev = "5cc1d09a72c0afcd04e2ca089a6b279108328fda"; + hash = "sha256-or77ZsWU0YWtxj9LKJ/m8nDvKSyiF1sO140QaH6Jr64="; + }; }; - }; - in + in self; in { diff --git a/pkgs/by-name/pd/pdal/tests.nix b/pkgs/by-name/pd/pdal/tests.nix index 1f71626856b38e..d0b9a3bd13ba8d 100644 --- a/pkgs/by-name/pd/pdal/tests.nix +++ b/pkgs/by-name/pd/pdal/tests.nix @@ -3,8 +3,7 @@ let inherit (pdal) pname; in -runCommand "${pname}-tests" { meta.timeout = 60; } - '' - ${pdal}/bin/pdal --drivers - touch $out - '' +runCommand "${pname}-tests" { meta.timeout = 60; } '' + ${pdal}/bin/pdal --drivers + touch $out +'' diff --git a/pkgs/by-name/pd/pdepend/package.nix b/pkgs/by-name/pd/pdepend/package.nix index ca92bb0e10d714..d6f300746ca5c5 100644 --- a/pkgs/by-name/pd/pdepend/package.nix +++ b/pkgs/by-name/pd/pdepend/package.nix @@ -1,6 +1,7 @@ -{ php -, fetchFromGitHub -, lib +{ + php, + fetchFromGitHub, + lib, }: php.buildComposerProject (finalAttrs: { diff --git a/pkgs/by-name/pd/pdf-quench/package.nix b/pkgs/by-name/pd/pdf-quench/package.nix index 6159bfc7c810fc..b3f396c690eba8 100644 --- a/pkgs/by-name/pd/pdf-quench/package.nix +++ b/pkgs/by-name/pd/pdf-quench/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, pkgs, python3, wrapGAppsHook3, gobject-introspection }: +{ + lib, + fetchFromGitHub, + pkgs, + python3, + wrapGAppsHook3, + gobject-introspection, +}: python3.pkgs.buildPythonApplication { pname = "pdf-quench"; @@ -11,13 +18,19 @@ python3.pkgs.buildPythonApplication { sha256 = "1rp9rlwr6rarcsxygv5x2c5psgwl6r69k0lsgribgyyla9cf2m7n"; }; - nativeBuildInputs = [ wrapGAppsHook3 gobject-introspection ]; + nativeBuildInputs = [ + wrapGAppsHook3 + gobject-introspection + ]; buildInputs = with pkgs; [ gtk3 goocanvas2 poppler_gi ]; - propagatedBuildInputs = with python3.pkgs; [ pygobject3 pypdf2 ]; + propagatedBuildInputs = with python3.pkgs; [ + pygobject3 + pypdf2 + ]; format = "other"; doCheck = false; diff --git a/pkgs/by-name/pd/pdf2djvu/package.nix b/pkgs/by-name/pd/pdf2djvu/package.nix index da741c76c70b46..e92663ad223979 100644 --- a/pkgs/by-name/pd/pdf2djvu/package.nix +++ b/pkgs/by-name/pd/pdf2djvu/package.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, gettext -, libtool -, pkg-config -, djvulibre -, exiv2 -, fontconfig -, graphicsmagick -, libjpeg -, libuuid -, poppler +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + gettext, + libtool, + pkg-config, + djvulibre, + exiv2, + fontconfig, + graphicsmagick, + libjpeg, + libuuid, + poppler, }: stdenv.mkDerivation rec { @@ -25,7 +26,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-j4mYdmLZ56qTA1KbWBjBvyTyLaeuIITKYsALRIO7lj0="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ djvulibre diff --git a/pkgs/by-name/pd/pdf2odt/package.nix b/pkgs/by-name/pd/pdf2odt/package.nix index a5d14a6fc29918..408fe656a35ec3 100644 --- a/pkgs/by-name/pd/pdf2odt/package.nix +++ b/pkgs/by-name/pd/pdf2odt/package.nix @@ -1,16 +1,17 @@ -{ lib -, resholve -, fetchFromGitHub -, bc -, coreutils -, file -, gawk -, ghostscript -, gnused -, imagemagick -, zip -, runtimeShell -, findutils +{ + lib, + resholve, + fetchFromGitHub, + bc, + coreutils, + file, + gawk, + ghostscript, + gnused, + imagemagick, + zip, + runtimeShell, + findutils, }: resholve.mkDerivation rec { diff --git a/pkgs/by-name/pd/pdf2svg/package.nix b/pkgs/by-name/pd/pdf2svg/package.nix index b7da6dad29da47..0bf8860ec766bd 100644 --- a/pkgs/by-name/pd/pdf2svg/package.nix +++ b/pkgs/by-name/pd/pdf2svg/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config -, cairo, gtk2, poppler }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + cairo, + gtk2, + poppler, +}: stdenv.mkDerivation rec { pname = "pdf2svg"; @@ -12,8 +20,15 @@ stdenv.mkDerivation rec { sha256 = "14ffdm4y26imq99wjhkrhy9lp33165xci1l5ndwfia8hz53bl02k"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ cairo poppler gtk2 ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + cairo + poppler + gtk2 + ]; meta = with lib; { description = "PDF converter to SVG format"; diff --git a/pkgs/by-name/pd/pdf4qt/package.nix b/pkgs/by-name/pd/pdf4qt/package.nix index d11d346724d2bd..47613a53fa8484 100644 --- a/pkgs/by-name/pd/pdf4qt/package.nix +++ b/pkgs/by-name/pd/pdf4qt/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, lcms -, cmake -, pkg-config -, qt6 -, wrapGAppsHook3 -, openjpeg -, tbb_2021_11 -, blend2d +{ + lib, + stdenv, + fetchFromGitHub, + lcms, + cmake, + pkg-config, + qt6, + wrapGAppsHook3, + openjpeg, + tbb_2021_11, + blend2d, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pd/pdfannots/package.nix b/pkgs/by-name/pd/pdfannots/package.nix index 7a7cbeeebab485..4cd56f2217c6b9 100644 --- a/pkgs/by-name/pd/pdfannots/package.nix +++ b/pkgs/by-name/pd/pdfannots/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchFromGitHub }: +{ + lib, + python3, + fetchFromGitHub, +}: python3.pkgs.buildPythonApplication rec { pname = "pdfannots"; diff --git a/pkgs/by-name/pd/pdfannots2json/package.nix b/pkgs/by-name/pd/pdfannots2json/package.nix index 90db280c8b9af2..74b2acdc308a92 100644 --- a/pkgs/by-name/pd/pdfannots2json/package.nix +++ b/pkgs/by-name/pd/pdfannots2json/package.nix @@ -1,26 +1,30 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: let pname = "pdfannots2json"; version = "1.0.16"; in - buildGoModule { - inherit pname version; +buildGoModule { + inherit pname version; - src = fetchFromGitHub { - owner = "mgmeyers"; - repo = "pdfannots2json"; - rev = "refs/tags/${version}"; - hash = "sha256-qk4OSws/6SevN/Q0lsyxw+fZkm2uy1WwOYYL7CB7QUk="; - }; + src = fetchFromGitHub { + owner = "mgmeyers"; + repo = "pdfannots2json"; + rev = "refs/tags/${version}"; + hash = "sha256-qk4OSws/6SevN/Q0lsyxw+fZkm2uy1WwOYYL7CB7QUk="; + }; - vendorHash = null; + vendorHash = null; - meta = with lib; { - homepage = "https://github.com/mgmeyers/pdfannots2json"; - license = licenses.agpl3Only; - description = "Tool to convert PDF annotations to JSON"; - mainProgram = "pdfannots2json"; - maintainers = with maintainers; [ _0nyr ]; - }; - } + meta = with lib; { + homepage = "https://github.com/mgmeyers/pdfannots2json"; + license = licenses.agpl3Only; + description = "Tool to convert PDF annotations to JSON"; + mainProgram = "pdfannots2json"; + maintainers = with maintainers; [ _0nyr ]; + }; +} diff --git a/pkgs/by-name/pd/pdfchain/package.nix b/pkgs/by-name/pd/pdfchain/package.nix index 0b94c54870d1f8..ead2d258c08ee8 100644 --- a/pkgs/by-name/pd/pdfchain/package.nix +++ b/pkgs/by-name/pd/pdfchain/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchurl, fetchDebianPatch -, autoconf, gtkmm3, glib, pdftk, pkg-config, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + fetchDebianPatch, + autoconf, + gtkmm3, + glib, + pdftk, + pkg-config, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -12,34 +21,44 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - pkg-config wrapGAppsHook3 autoconf + pkg-config + wrapGAppsHook3 + autoconf ]; buildInputs = [ - gtkmm3 pdftk glib + gtkmm3 + pdftk + glib ]; - patches = let - fetchDebianPatch' = args: fetchDebianPatch ({ - inherit pname; - version = "1:0.4.4.2"; - debianRevision = "2"; - } // args); - in - [ - (fetchDebianPatch' { - patch = "fix_crash_on_startup"; - hash = "sha256-1UyMHHGrmUIFhY53ILdMMsyocSIbcV6CKQ7sLVNhNQw="; - }) - (fetchDebianPatch' { - patch = "fix_desktop_file"; - hash = "sha256-L6lhUs7GqVN1XOQO6bbz6BT29n4upsJtlHCAIGzk1Bw="; - }) - (fetchDebianPatch' { - patch = "fix_spelling"; - hash = "sha256-sOUUslPfcOo2K3zuaLcux+CNdgfWM0phsfe6g4GUFes="; - }) - ]; + patches = + let + fetchDebianPatch' = + args: + fetchDebianPatch ( + { + inherit pname; + version = "1:0.4.4.2"; + debianRevision = "2"; + } + // args + ); + in + [ + (fetchDebianPatch' { + patch = "fix_crash_on_startup"; + hash = "sha256-1UyMHHGrmUIFhY53ILdMMsyocSIbcV6CKQ7sLVNhNQw="; + }) + (fetchDebianPatch' { + patch = "fix_desktop_file"; + hash = "sha256-L6lhUs7GqVN1XOQO6bbz6BT29n4upsJtlHCAIGzk1Bw="; + }) + (fetchDebianPatch' { + patch = "fix_spelling"; + hash = "sha256-sOUUslPfcOo2K3zuaLcux+CNdgfWM0phsfe6g4GUFes="; + }) + ]; postPatch = '' substituteInPlace src/constant.h \ diff --git a/pkgs/by-name/pd/pdfcpu/package.nix b/pkgs/by-name/pd/pdfcpu/package.nix index 55525022162dea..438d0a12e976ca 100644 --- a/pkgs/by-name/pd/pdfcpu/package.nix +++ b/pkgs/by-name/pd/pdfcpu/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pdfcpu"; @@ -45,7 +49,6 @@ buildGoModule rec { ldflags+=" -X main.date=$(cat SOURCE_DATE)" ''; - # No tests doCheck = false; doInstallCheck = true; diff --git a/pkgs/by-name/pd/pdfcrack/package.nix b/pkgs/by-name/pd/pdfcrack/package.nix index ae863e1ec1f572..659d9f1e5fcb5b 100644 --- a/pkgs/by-name/pd/pdfcrack/package.nix +++ b/pkgs/by-name/pd/pdfcrack/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pd/pdfdiff/package.nix b/pkgs/by-name/pd/pdfdiff/package.nix index c80396840e4109..a24d180f6493a5 100644 --- a/pkgs/by-name/pd/pdfdiff/package.nix +++ b/pkgs/by-name/pd/pdfdiff/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3Packages -, xpdf +{ + lib, + fetchFromGitHub, + python3Packages, + xpdf, }: python3Packages.buildPythonApplication rec { @@ -25,13 +26,13 @@ python3Packages.buildPythonApplication rec { substituteInPlace pdfdiff.py \ --replace 'pdftotextProgram = "pdftotext"' 'pdftotextProgram = "${xpdf}/bin/pdftotext"' \ --replace 'progName = "pdfdiff.py"' 'progName = "pdfdiff"' - ''; + ''; installPhase = '' mkdir -p $out/bin cp pdfdiff.py $out/bin/pdfdiff chmod +x $out/bin/pdfdiff - ''; + ''; meta = with lib; { homepage = "https://github.com/cascremers/pdfdiff"; diff --git a/pkgs/by-name/pd/pdfgrep/package.nix b/pkgs/by-name/pd/pdfgrep/package.nix index a1e9ed91f990d3..924fcd19d307be 100644 --- a/pkgs/by-name/pd/pdfgrep/package.nix +++ b/pkgs/by-name/pd/pdfgrep/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, poppler, libgcrypt, pcre2, asciidoc }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + poppler, + libgcrypt, + pcre2, + asciidoc, +}: stdenv.mkDerivation rec { pname = "pdfgrep"; @@ -19,14 +28,24 @@ stdenv.mkDerivation rec { "--with-libgcrypt-prefix=${lib.getDev libgcrypt}" ]; - nativeBuildInputs = [ pkg-config asciidoc ]; - buildInputs = [ poppler libgcrypt pcre2 ]; + nativeBuildInputs = [ + pkg-config + asciidoc + ]; + buildInputs = [ + poppler + libgcrypt + pcre2 + ]; meta = { description = "Commandline utility to search text in PDF files"; homepage = "https://pdfgrep.org/"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ qknight fpletz ]; + maintainers = with lib.maintainers; [ + qknight + fpletz + ]; platforms = with lib.platforms; unix; mainProgram = "pdfgrep"; }; diff --git a/pkgs/by-name/pd/pdfid/package.nix b/pkgs/by-name/pd/pdfid/package.nix index 62e14fa9d22695..321f7ad9f076d1 100644 --- a/pkgs/by-name/pd/pdfid/package.nix +++ b/pkgs/by-name/pd/pdfid/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchzip -, python3 -, python3Packages -, makeBinaryWrapper +{ + lib, + fetchzip, + python3, + python3Packages, + makeBinaryWrapper, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/pd/pdfmm/package.nix b/pkgs/by-name/pd/pdfmm/package.nix index 9f4f17f893c9b5..718d6bde306586 100644 --- a/pkgs/by-name/pd/pdfmm/package.nix +++ b/pkgs/by-name/pd/pdfmm/package.nix @@ -1,12 +1,13 @@ -{ bash -, coreutils -, fetchFromGitHub -, ghostscript -, locale -, zenity -, gnused -, lib -, resholve +{ + bash, + coreutils, + fetchFromGitHub, + ghostscript, + locale, + zenity, + gnused, + lib, + resholve, }: resholve.mkDerivation rec { diff --git a/pkgs/by-name/pd/pdfposter/package.nix b/pkgs/by-name/pd/pdfposter/package.nix index ff7d97969e43ad..f4f36d3291f76f 100644 --- a/pkgs/by-name/pd/pdfposter/package.nix +++ b/pkgs/by-name/pd/pdfposter/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchPypi }: +{ + lib, + python3, + fetchPypi, +}: let localPython = python3.override { self = localPython; @@ -17,7 +21,8 @@ let }; }; in -with localPython.pkgs; buildPythonApplication rec { +with localPython.pkgs; +buildPythonApplication rec { pname = "pdfposter"; version = "0.8.1"; format = "setuptools"; diff --git a/pkgs/by-name/pd/pdfrip/package.nix b/pkgs/by-name/pd/pdfrip/package.nix index 04ba06049976a0..2a94a5510339fa 100644 --- a/pkgs/by-name/pd/pdfrip/package.nix +++ b/pkgs/by-name/pd/pdfrip/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pd/pdfsandwich/package.nix b/pkgs/by-name/pd/pdfsandwich/package.nix index 8343e382c807ba..4568767b200d05 100644 --- a/pkgs/by-name/pd/pdfsandwich/package.nix +++ b/pkgs/by-name/pd/pdfsandwich/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, ocaml, makeWrapper, fetchsvn, ghostscript, imagemagick, perl, poppler_utils, tesseract, unpaper }: +{ + lib, + stdenv, + ocaml, + makeWrapper, + fetchsvn, + ghostscript, + imagemagick, + perl, + poppler_utils, + tesseract, + unpaper, +}: stdenv.mkDerivation { version = "0.1.7"; @@ -12,17 +24,29 @@ stdenv.mkDerivation { strictDeps = true; - nativeBuildInputs = [ makeWrapper ocaml perl ]; + nativeBuildInputs = [ + makeWrapper + ocaml + perl + ]; installPhase = '' mkdir -p $out/bin cp -p pdfsandwich $out/bin - wrapProgram $out/bin/pdfsandwich --prefix PATH : ${lib.makeBinPath [ imagemagick ghostscript poppler_utils unpaper tesseract ]} + wrapProgram $out/bin/pdfsandwich --prefix PATH : ${ + lib.makeBinPath [ + imagemagick + ghostscript + poppler_utils + unpaper + tesseract + ] + } mkdir -p $out/man/man1 cp -p pdfsandwich.1.gz $out/man/man1 ''; -meta = with lib; { + meta = with lib; { description = "OCR tool for scanned PDFs"; homepage = "http://www.tobias-elze.de/pdfsandwich/"; license = licenses.gpl2Plus; diff --git a/pkgs/by-name/pd/pdfslicer/package.nix b/pkgs/by-name/pd/pdfslicer/package.nix index 9d91a89df147e3..34e7c61d3642cb 100644 --- a/pkgs/by-name/pd/pdfslicer/package.nix +++ b/pkgs/by-name/pd/pdfslicer/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gettext -, intltool -, pkg-config -, wrapGAppsHook3 -, gtkmm3 -, libuuid -, poppler -, qpdf +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gettext, + intltool, + pkg-config, + wrapGAppsHook3, + gtkmm3, + libuuid, + poppler, + qpdf, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pd/pdftag/package.nix b/pkgs/by-name/pd/pdftag/package.nix index d5efffd9f11ac8..90400135bd689d 100644 --- a/pkgs/by-name/pd/pdftag/package.nix +++ b/pkgs/by-name/pd/pdftag/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, meson, vala, ninja -, gtk3, poppler, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + meson, + vala, + ninja, + gtk3, + poppler, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "pdftag"; @@ -12,8 +22,17 @@ stdenv.mkDerivation rec { sha256 = "1paj8hs27akzsivn01a30fl3zx5gfn1h89wxg2m72fd806hk0hql"; }; - nativeBuildInputs = [ pkg-config meson ninja wrapGAppsHook3 vala ]; - buildInputs = [ gtk3 poppler ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + wrapGAppsHook3 + vala + ]; + buildInputs = [ + gtk3 + poppler + ]; meta = with lib; { description = "Edit metadata found in PDFs"; diff --git a/pkgs/by-name/pd/pdftk/package.nix b/pkgs/by-name/pd/pdftk/package.nix index 99f25a51877b72..025652d69b872d 100644 --- a/pkgs/by-name/pd/pdftk/package.nix +++ b/pkgs/by-name/pd/pdftk/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitLab, gradle_8, jre, runtimeShell }: +{ + lib, + stdenv, + fetchFromGitLab, + gradle_8, + jre, + runtimeShell, +}: let # "Deprecated Gradle features were used in this build, making it incompatible with Gradle 9.0." gradle = gradle_8; @@ -45,10 +52,13 @@ stdenv.mkDerivation rec { homepage = "https://gitlab.com/pdftk-java/pdftk"; sourceProvenance = with sourceTypes; [ fromSource - binaryBytecode # deps + binaryBytecode # deps ]; license = licenses.gpl2Plus; - maintainers = with maintainers; [ raskin averelld ]; + maintainers = with maintainers; [ + raskin + averelld + ]; platforms = platforms.unix; mainProgram = "pdftk"; }; diff --git a/pkgs/by-name/pd/pdftoipe/package.nix b/pkgs/by-name/pd/pdftoipe/package.nix index 62734d4e610c5e..70e3fc58f3d9fe 100644 --- a/pkgs/by-name/pd/pdftoipe/package.nix +++ b/pkgs/by-name/pd/pdftoipe/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, poppler -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + poppler, + fetchpatch, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pd/pdk/gemset.nix b/pkgs/by-name/pd/pdk/gemset.nix index 77f06054e403ca..8d53eaed9c3869 100644 --- a/pkgs/by-name/pd/pdk/gemset.nix +++ b/pkgs/by-name/pd/pdk/gemset.nix @@ -1,248 +1,273 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; childprocess = { - dependencies = ["logger"]; - groups = ["default"]; - platforms = []; + dependencies = [ "logger" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1v5nalaarxnfdm6rxb7q6fmc6nx097jd630ax6h9ch7xw95li3cs"; type = "gem"; }; version = "5.1.0"; }; cri = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rank6i9p2drwdcmhan6ifkzrz1v3mwpx47fwjl75rskxwjfkgwa"; type = "gem"; }; version = "2.15.12"; }; deep_merge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fjn4civid68a3zxnbgyjj6krs3l30dy8b4djpg6fpzrsyix7kl3"; type = "gem"; }; version = "1.2.2"; }; diff-lcs = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znxccz83m4xgpd239nyqxlifdb7m8rlfayk6s259186nkgj6ci7"; type = "gem"; }; version = "1.5.1"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; hitimes = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ix9rp9rsrwin38z2aqiwpxc8p2dzl6m3ra47az47fsija1cb2qf"; type = "gem"; }; version = "2.0.0"; }; json-schema = { - dependencies = ["addressable"]; - groups = ["default"]; - platforms = []; + dependencies = [ "addressable" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09bq393nrxa7hmphc3li8idgxdnb5hwgj15d0q5qsh4l5g1qvrnm"; type = "gem"; }; version = "4.3.1"; }; json_pure = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kn736pb52j8b9xxq6l8wqp2chs74aa14vfnp0rijjn086m8b4f3"; type = "gem"; }; version = "2.6.3"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; minitar = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f307mpj4j0gp7iq77xj4p149f4krcvbll9rismng3jcijpbn79s"; type = "gem"; }; version = "0.12.1"; }; pastel = { - dependencies = ["tty-color"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-color" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xash2gj08dfjvq4hy6l1z22s5v30fhizwgs10d6nviggpxsj7a8"; type = "gem"; }; version = "0.8.0"; }; pathspec = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08sxih7jrx07rczg3rpw7h9dawr43rxc68afhy498j8r816gzry4"; type = "gem"; }; version = "1.1.3"; }; pdk = { - dependencies = ["childprocess" "cri" "deep_merge" "diff-lcs" "ffi" "hitimes" "json-schema" "json_pure" "minitar" "pathspec" "puppet-modulebuilder" "tty-prompt" "tty-spinner" "tty-which"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "childprocess" + "cri" + "deep_merge" + "diff-lcs" + "ffi" + "hitimes" + "json-schema" + "json_pure" + "minitar" + "pathspec" + "puppet-modulebuilder" + "tty-prompt" + "tty-spinner" + "tty-which" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gildcnii3ayw585as8d8bqhnfb9diqg7n3vmgaz8c5b9wb8c106"; type = "gem"; }; version = "3.3.0"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vqcw3iwby3yc6avs1vb3gfd0vcp2v7q310665dvxfswmcf4xm31"; type = "gem"; }; version = "6.0.1"; }; puppet-modulebuilder = { - dependencies = ["minitar" "pathspec"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "minitar" + "pathspec" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rh31hq24nkddd83cx7n9ln5bsib3a052hrmn120sq0937337173"; type = "gem"; }; version = "1.1.0"; }; tty-color = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0aik4kmhwwrmkysha7qibi2nyzb4c8kp42bd5vxnf8sf7b53g73g"; type = "gem"; }; version = "0.6.0"; }; tty-cursor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j5zw041jgkmn605ya1zc151bxgxl6v192v2i26qhxx7ws2l2lvr"; type = "gem"; }; version = "0.7.1"; }; tty-prompt = { - dependencies = ["pastel" "tty-reader"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "pastel" + "tty-reader" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j4y8ik82azjxshgd4i1v4wwhsv3g9cngpygxqkkz69qaa8cxnzw"; type = "gem"; }; version = "0.23.1"; }; tty-reader = { - dependencies = ["tty-cursor" "tty-screen" "wisper"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "tty-cursor" + "tty-screen" + "wisper" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cf2k7w7d84hshg4kzrjvk9pkyc2g1m3nx2n1rpmdcf0hp4p4af6"; type = "gem"; }; version = "0.9.0"; }; tty-screen = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0l4vh6g333jxm9lakilkva2gn17j6gb052626r1pdbmy2lhnb460"; type = "gem"; }; version = "0.8.2"; }; tty-spinner = { - dependencies = ["tty-cursor"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-cursor" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hh5awmijnzw9flmh5ak610x1d00xiqagxa5mbr63ysggc26y0qf"; type = "gem"; }; version = "0.9.3"; }; tty-which = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rpljdwlfm4qgps2xvq6306w86fm057m89j4gizcji371mgha92q"; type = "gem"; }; version = "0.5.0"; }; wisper = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rpsi0ziy78cj82sbyyywby4d0aw0a5q84v65qd28vqn79fbq5yf"; type = "gem"; }; diff --git a/pkgs/by-name/pd/pdk/package.nix b/pkgs/by-name/pd/pdk/package.nix index 91bd27a53a442a..e1e5b9c71b1550 100644 --- a/pkgs/by-name/pd/pdk/package.nix +++ b/pkgs/by-name/pd/pdk/package.nix @@ -33,6 +33,9 @@ bundlerApp { homepage = "https://github.com/puppetlabs/pdk"; license = lib.licenses.asl20; mainProgram = "pdk"; - maintainers = with lib.maintainers; [ netali anthonyroussel ]; + maintainers = with lib.maintainers; [ + netali + anthonyroussel + ]; }; } diff --git a/pkgs/by-name/pd/pdns-recursor/package.nix b/pkgs/by-name/pd/pdns-recursor/package.nix index 8ac651f38b67cd..fc4ed4524681f3 100644 --- a/pkgs/by-name/pd/pdns-recursor/package.nix +++ b/pkgs/by-name/pd/pdns-recursor/package.nix @@ -1,9 +1,21 @@ -{ lib, stdenv, fetchurl, pkg-config, boost, nixosTests -, openssl, systemd, lua, luajit, protobuf -, libsodium -, curl -, rustPlatform, cargo, rustc -, enableProtoBuf ? false +{ + lib, + stdenv, + fetchurl, + pkg-config, + boost, + nixosTests, + openssl, + systemd, + lua, + luajit, + protobuf, + libsodium, + curl, + rustPlatform, + cargo, + rustc, + enableProtoBuf ? false, }: stdenv.mkDerivation (finalAttrs: { @@ -31,8 +43,11 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; buildInputs = [ - boost openssl systemd - lua luajit + boost + openssl + systemd + lua + luajit libsodium curl ] ++ lib.optional enableProtoBuf protobuf; @@ -57,7 +72,7 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.powerdns.com/"; platforms = platforms.linux; badPlatforms = [ - "i686-linux" # a 64-bit time_t is needed + "i686-linux" # a 64-bit time_t is needed ]; license = licenses.gpl2Only; maintainers = with maintainers; [ rnhmjoj ]; diff --git a/pkgs/by-name/pd/pdnsd/package.nix b/pkgs/by-name/pd/pdnsd/package.nix index 4a09295b79bf53..0a09453b3b3861 100644 --- a/pkgs/by-name/pd/pdnsd/package.nix +++ b/pkgs/by-name/pd/pdnsd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "pdnsd"; @@ -11,12 +16,11 @@ stdenv.mkDerivation rec { patches = # fix build with linux headers >= 5.13 - lib.optional stdenv.hostPlatform.isLinux - (fetchpatch { - name = "fix-build-linux-headers-gte-5.13.patch"; - url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/net-dns/pdnsd/files/pdnsd-1.2.9a-linux-5.13_build_fix.patch?id=7ce35657f269c3b7016e8940ad36e59cf06e12a4"; - hash = "sha256-Sh/0ZyiQpDvFZOWE9OCQ9+ocXurjzJvrE4WNWaGwAwk="; - }); + lib.optional stdenv.hostPlatform.isLinux (fetchpatch { + name = "fix-build-linux-headers-gte-5.13.patch"; + url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/net-dns/pdnsd/files/pdnsd-1.2.9a-linux-5.13_build_fix.patch?id=7ce35657f269c3b7016e8940ad36e59cf06e12a4"; + hash = "sha256-Sh/0ZyiQpDvFZOWE9OCQ9+ocXurjzJvrE4WNWaGwAwk="; + }); postPatch = '' sed -i 's/.*(cachedir).*/:/' Makefile.in diff --git a/pkgs/by-name/pd/pdpmake/package.nix b/pkgs/by-name/pd/pdpmake/package.nix index dcb9794dedec07..58e391d071c98a 100644 --- a/pkgs/by-name/pd/pdpmake/package.nix +++ b/pkgs/by-name/pd/pdpmake/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "pdpmake"; version = "2.0.1"; diff --git a/pkgs/by-name/pe/pe-parse/package.nix b/pkgs/by-name/pe/pe-parse/package.nix index 1a3a602d552789..e259b51aa564fe 100644 --- a/pkgs/by-name/pe/pe-parse/package.nix +++ b/pkgs/by-name/pe/pe-parse/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "pe-parse"; @@ -13,9 +18,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-error=deprecated-declarations" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-error=deprecated-declarations" + ] + ); doInstallCheck = true; installCheckPhase = '' diff --git a/pkgs/by-name/pe/peazip/package.nix b/pkgs/by-name/pe/peazip/package.nix index 57718c2e41104c..ed6ecc48e2bb65 100644 --- a/pkgs/by-name/pe/peazip/package.nix +++ b/pkgs/by-name/pe/peazip/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, libsForQt5 -, fpc -, lazarus -, xorg -, libqt5pas -, runCommand -, _7zz -, archiver -, brotli -, upx -, zpaq -, zstd +{ + stdenv, + lib, + fetchFromGitHub, + libsForQt5, + fpc, + lazarus, + xorg, + libqt5pas, + runCommand, + _7zz, + archiver, + brotli, + upx, + zpaq, + zstd, }: stdenv.mkDerivation rec { @@ -56,7 +57,7 @@ stdenv.mkDerivation rec { ''; # peazip looks for the "7z", not "7zz" - _7z = runCommand "7z" {} '' + _7z = runCommand "7z" { } '' mkdir -p $out/bin ln -s ${_7zz}/bin/7zz $out/bin/7z ''; @@ -65,14 +66,16 @@ stdenv.mkDerivation rec { runHook preInstall install -D dev/{pea,peazip} -t $out/lib/peazip - wrapProgram $out/lib/peazip/peazip --prefix PATH : ${lib.makeBinPath [ - _7z - archiver - brotli - upx - zpaq - zstd - ]} + wrapProgram $out/lib/peazip/peazip --prefix PATH : ${ + lib.makeBinPath [ + _7z + archiver + brotli + upx + zpaq + zstd + ] + } mkdir -p $out/bin ln -s $out/lib/peazip/{pea,peazip} $out/bin/ diff --git a/pkgs/by-name/pe/pebble/package.nix b/pkgs/by-name/pe/pebble/package.nix index 6820431808ff9b..b634fd0f400c90 100644 --- a/pkgs/by-name/pe/pebble/package.nix +++ b/pkgs/by-name/pe/pebble/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { @@ -18,7 +19,8 @@ buildGoModule rec { vendorHash = null; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X main.version=${version}" ]; diff --git a/pkgs/by-name/pe/pecita/package.nix b/pkgs/by-name/pe/pecita/package.nix index 568363889ff239..1fbfbe3542fbc1 100644 --- a/pkgs/by-name/pe/pecita/package.nix +++ b/pkgs/by-name/pe/pecita/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation { pname = "pecita"; diff --git a/pkgs/by-name/pe/peco/package.nix b/pkgs/by-name/pe/peco/package.nix index 774b2f5a0d1e8f..0c794fb719ae0f 100644 --- a/pkgs/by-name/pe/peco/package.nix +++ b/pkgs/by-name/pe/peco/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "peco"; diff --git a/pkgs/by-name/pe/peek/package.nix b/pkgs/by-name/pe/peek/package.nix index a2817d10edcaa9..54921269b88ebb 100644 --- a/pkgs/by-name/pe/peek/package.nix +++ b/pkgs/by-name/pe/peek/package.nix @@ -1,28 +1,29 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, nix-update-script -, meson -, ninja -, gettext -, desktop-file-utils -, appstream-glib -, pkg-config -, txt2man -, vala -, wrapGAppsHook3 -, gsettings-desktop-schemas -, gtk3 -, glib -, cairo -, keybinder3 -, ffmpeg-full -, python3 -, libxml2 -, gst_all_1 -, which -, gifski +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + nix-update-script, + meson, + ninja, + gettext, + desktop-file-utils, + appstream-glib, + pkg-config, + txt2man, + vala, + wrapGAppsHook3, + gsettings-desktop-schemas, + gtk3, + glib, + cairo, + keybinder3, + ffmpeg-full, + python3, + libxml2, + gst_all_1, + which, + gifski, }: stdenv.mkDerivation rec { @@ -75,14 +76,19 @@ stdenv.mkDerivation rec { ''; preFixup = '' - gappsWrapperArgs+=(--prefix PATH : ${lib.makeBinPath [ which ffmpeg-full gifski ]}) + gappsWrapperArgs+=(--prefix PATH : ${ + lib.makeBinPath [ + which + ffmpeg-full + gifski + ] + }) ''; passthru = { updateScript = nix-update-script { }; }; - meta = with lib; { homepage = "https://github.com/phw/peek"; description = "Simple animated GIF screen recorder with an easy to use interface"; diff --git a/pkgs/by-name/pe/peep/package.nix b/pkgs/by-name/pe/peep/package.nix index 071bab99ae9217..4287847d56e375 100644 --- a/pkgs/by-name/pe/peep/package.nix +++ b/pkgs/by-name/pe/peep/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "peep"; diff --git a/pkgs/by-name/pe/peering-manager/package.nix b/pkgs/by-name/pe/peering-manager/package.nix index eb941b85853e62..c5eb8bffc42ab3 100644 --- a/pkgs/by-name/pe/peering-manager/package.nix +++ b/pkgs/by-name/pe/peering-manager/package.nix @@ -1,9 +1,10 @@ -{ python3 -, fetchFromGitHub -, nixosTests -, lib +{ + python3, + fetchFromGitHub, + nixosTests, + lib, -, plugins ? ps: [] + plugins ? ps: [ ], }: python3.pkgs.buildPythonApplication rec { @@ -25,30 +26,33 @@ python3.pkgs.buildPythonApplication rec { ./fix-pyixapi-0.2.3-compatibility.patch ]; - propagatedBuildInputs = with python3.pkgs; [ - django - djangorestframework - django-redis - django-debug-toolbar - django-filter - django-postgresql-netfields - django-prometheus - django-rq - django-tables2 - django-taggit - drf-spectacular - drf-spectacular-sidecar - jinja2 - markdown - napalm - packaging - psycopg2 - pyixapi - pynetbox - pyyaml - requests - tzdata - ] ++ plugins python3.pkgs; + propagatedBuildInputs = + with python3.pkgs; + [ + django + djangorestframework + django-redis + django-debug-toolbar + django-filter + django-postgresql-netfields + django-prometheus + django-rq + django-tables2 + django-taggit + drf-spectacular + drf-spectacular-sidecar + jinja2 + markdown + napalm + packaging + psycopg2 + pyixapi + pynetbox + pyyaml + requests + tzdata + ] + ++ plugins python3.pkgs; buildPhase = '' runHook preBuild diff --git a/pkgs/by-name/pe/peg/package.nix b/pkgs/by-name/pe/peg/package.nix index 988c3d461f85bb..924cb4019280fa 100644 --- a/pkgs/by-name/pe/peg/package.nix +++ b/pkgs/by-name/pe/peg/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "peg"; @@ -14,7 +18,7 @@ stdenv.mkDerivation rec { --replace-fail "strip" '$(STRIP)' ''; - preBuild="makeFlagsArray+=( PREFIX=$out )"; + preBuild = "makeFlagsArray+=( PREFIX=$out )"; meta = with lib; { homepage = "http://piumarta.com/software/peg/"; diff --git a/pkgs/by-name/pe/pekwm/package.nix b/pkgs/by-name/pe/pekwm/package.nix index d657141d7a4e56..270c2d41934ab9 100644 --- a/pkgs/by-name/pe/pekwm/package.nix +++ b/pkgs/by-name/pe/pekwm/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, awk -, cmake -, grep -, libXext -, libXft -, libXinerama -, libXpm -, libXrandr -, libjpeg -, libpng -, pkg-config -, runtimeShell -, sed +{ + lib, + stdenv, + fetchFromGitHub, + awk, + cmake, + grep, + libXext, + libXft, + libXinerama, + libXpm, + libXrandr, + libjpeg, + libpng, + pkg-config, + runtimeShell, + sed, }: stdenv.mkDerivation (finalAttrs: { @@ -24,7 +25,7 @@ stdenv.mkDerivation (finalAttrs: { owner = "pekdon"; repo = "pekwm"; rev = "release-${finalAttrs.version}"; - hash= "sha256-l43xxCowSEBQjwg7hjpBwybFB12ESOep6hqdzSsD3YI="; + hash = "sha256-l43xxCowSEBQjwg7hjpBwybFB12ESOep6hqdzSsD3YI="; }; nativeBuildInputs = [ @@ -42,7 +43,10 @@ stdenv.mkDerivation (finalAttrs: { libpng ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; strictDeps = true; diff --git a/pkgs/by-name/pe/pell/package.nix b/pkgs/by-name/pe/pell/package.nix index 55b5dd3d371083..b244dc8d671aef 100644 --- a/pkgs/by-name/pe/pell/package.nix +++ b/pkgs/by-name/pe/pell/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, scsh, sox, libnotify }: +{ + lib, + stdenv, + fetchFromGitHub, + scsh, + sox, + libnotify, +}: stdenv.mkDerivation rec { pname = "pell"; diff --git a/pkgs/by-name/pe/penna/package.nix b/pkgs/by-name/pe/penna/package.nix index 245078de724dd7..b6f433534774cf 100644 --- a/pkgs/by-name/pe/penna/package.nix +++ b/pkgs/by-name/pe/penna/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "0"; @@ -26,12 +30,15 @@ stdenvNoCC.mkDerivation { homepage = "http://dotcolon.net/font/penna/"; description = "Geometric sans serif designed by Sora Sagano"; longDescription = '' - Penna is a geometric sans serif designed by Sora Sagano, - with outsized counters in the uppercase and a lowercase - with a small x-height. + Penna is a geometric sans serif designed by Sora Sagano, + with outsized counters in the uppercase and a lowercase + with a small x-height. ''; platforms = platforms.all; - maintainers = with maintainers; [ leenaars minijackson ]; + maintainers = with maintainers; [ + leenaars + minijackson + ]; license = licenses.cc0; }; } diff --git a/pkgs/by-name/pe/pentestgpt/package.nix b/pkgs/by-name/pe/pentestgpt/package.nix index 328ba0ca9a8f93..78f00e61c44d97 100644 --- a/pkgs/by-name/pe/pentestgpt/package.nix +++ b/pkgs/by-name/pe/pentestgpt/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pe/perccli/package.nix b/pkgs/by-name/pe/perccli/package.nix index eacc0c26de3315..0f9ad28e5dfe3c 100644 --- a/pkgs/by-name/pe/perccli/package.nix +++ b/pkgs/by-name/pe/perccli/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchzip -, rpmextract +{ + lib, + stdenvNoCC, + fetchzip, + rpmextract, }: stdenvNoCC.mkDerivation rec { @@ -17,7 +18,10 @@ stdenvNoCC.mkDerivation rec { # Dell seems to block "uncommon" user-agents, such as Nixpkgs's custom one. # 403 otherwise - curlOptsList = [ "--user-agent" "Mozilla/5.0" ]; + curlOptsList = [ + "--user-agent" + "Mozilla/5.0" + ]; }; nativeBuildInputs = [ rpmextract ]; @@ -30,15 +34,17 @@ stdenvNoCC.mkDerivation rec { dontConfigure = true; dontBuild = true; - installPhase = let - inherit (stdenvNoCC.hostPlatform) system; - platforms = { - x86_64-linux = '' - install -D ./opt/MegaRAID/perccli/perccli64 $out/bin/perccli64 - ln -s perccli64 $out/bin/perccli - ''; - }; - in platforms.${system} or (throw "unsupported system: ${system}"); + installPhase = + let + inherit (stdenvNoCC.hostPlatform) system; + platforms = { + x86_64-linux = '' + install -D ./opt/MegaRAID/perccli/perccli64 $out/bin/perccli64 + ln -s perccli64 $out/bin/perccli + ''; + }; + in + platforms.${system} or (throw "unsupported system: ${system}"); # Not needed because the binary is statically linked dontFixup = true; diff --git a/pkgs/by-name/pe/perceptualdiff/package.nix b/pkgs/by-name/pe/perceptualdiff/package.nix index 1c8f99e88e9aba..397451a085d8aa 100644 --- a/pkgs/by-name/pe/perceptualdiff/package.nix +++ b/pkgs/by-name/pe/perceptualdiff/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, freeimage }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + freeimage, +}: stdenv.mkDerivation rec { pname = "perceptualdiff"; diff --git a/pkgs/by-name/pe/percollate/package.nix b/pkgs/by-name/pe/percollate/package.nix index 1b9923acc39c8e..174e4de6d5ee4e 100644 --- a/pkgs/by-name/pe/percollate/package.nix +++ b/pkgs/by-name/pe/percollate/package.nix @@ -1,4 +1,10 @@ -{ lib, buildNpmPackage, fetchFromGitHub, chromium, makeWrapper }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, + chromium, + makeWrapper, +}: buildNpmPackage rec { pname = "percollate"; diff --git a/pkgs/by-name/pe/perf-tools/package.nix b/pkgs/by-name/pe/perf-tools/package.nix index c4b8cceb585529..12c62f70e5c950 100644 --- a/pkgs/by-name/pe/perf-tools/package.nix +++ b/pkgs/by-name/pe/perf-tools/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation { pname = "perf-tools"; @@ -13,27 +18,25 @@ stdenv.mkDerivation { buildInputs = [ perl ]; - patchPhase = - '' - for i in execsnoop iolatency iosnoop kernel/funcslower killsnoop opensnoop; do - substituteInPlace $i \ - --replace /usr/bin/gawk "$(type -p gawk)" \ - --replace /usr/bin/mawk /no-such-path \ - --replace /usr/bin/getconf "$(type -p getconf)" \ - --replace awk=awk "awk=$(type -p gawk)" - done + patchPhase = '' + for i in execsnoop iolatency iosnoop kernel/funcslower killsnoop opensnoop; do + substituteInPlace $i \ + --replace /usr/bin/gawk "$(type -p gawk)" \ + --replace /usr/bin/mawk /no-such-path \ + --replace /usr/bin/getconf "$(type -p getconf)" \ + --replace awk=awk "awk=$(type -p gawk)" + done - rm -rf examples deprecated - ''; + rm -rf examples deprecated + ''; - installPhase = - '' - d=$out/libexec/perf-tools - mkdir -p $d $out/share - cp -prvd . $d/ - ln -s $d/bin $out/bin - mv $d/man $out/share/ - ''; + installPhase = '' + d=$out/libexec/perf-tools + mkdir -p $d $out/share + cp -prvd . $d/ + ln -s $d/bin $out/bin + mv $d/man $out/share/ + ''; meta = with lib; { platforms = platforms.linux; diff --git a/pkgs/by-name/pe/perfect-hash/package.nix b/pkgs/by-name/pe/perfect-hash/package.nix index 124758e571e9ad..b9466c77010407 100644 --- a/pkgs/by-name/pe/perfect-hash/package.nix +++ b/pkgs/by-name/pe/perfect-hash/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchFromGitHub }: +{ + lib, + python3, + fetchFromGitHub, +}: python3.pkgs.buildPythonApplication rec { pname = "perfect-hash"; version = "0.4.1"; diff --git a/pkgs/by-name/pe/perl-debug-adapter/package.nix b/pkgs/by-name/pe/perl-debug-adapter/package.nix index 85deced748f6dc..7ad7d2a006e626 100644 --- a/pkgs/by-name/pe/perl-debug-adapter/package.nix +++ b/pkgs/by-name/pe/perl-debug-adapter/package.nix @@ -1,16 +1,22 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, perl -# Needed if you want to use it for a perl script with dependencies. -, extraPerlPackages ? [] +{ + lib, + buildNpmPackage, + fetchFromGitHub, + perl, + # Needed if you want to use it for a perl script with dependencies. + extraPerlPackages ? [ ], }: let - perlInterpreter = perl.withPackages(ps: [ - ps.PadWalker - ] ++ extraPerlPackages); -in buildNpmPackage rec { + perlInterpreter = perl.withPackages ( + ps: + [ + ps.PadWalker + ] + ++ extraPerlPackages + ); +in +buildNpmPackage rec { pname = "perl-debug-adapter"; version = "1.0.6"; @@ -26,7 +32,10 @@ in buildNpmPackage rec { npmBuildScript = "compile"; makeWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath [ perlInterpreter ]) + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ perlInterpreter ]) ]; passthru = { inherit perlInterpreter; diff --git a/pkgs/by-name/pe/perlnavigator/package.nix b/pkgs/by-name/pe/perlnavigator/package.nix index a7d243888587cf..34f216ad4daa1c 100644 --- a/pkgs/by-name/pe/perlnavigator/package.nix +++ b/pkgs/by-name/pe/perlnavigator/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: let @@ -41,7 +42,8 @@ let cp -r . "$out" ''; }; -in buildNpmPackage rec { +in +buildNpmPackage rec { pname = "perlnavigator"; inherit version src; diff --git a/pkgs/by-name/pe/peroxide/package.nix b/pkgs/by-name/pe/peroxide/package.nix index 1275329bcf656c..b3cae30ade3f87 100644 --- a/pkgs/by-name/pe/peroxide/package.nix +++ b/pkgs/by-name/pe/peroxide/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGo122Module -, fetchFromGitHub -, nixosTests +{ + lib, + buildGo122Module, + fetchFromGitHub, + nixosTests, }: buildGo122Module rec { diff --git a/pkgs/by-name/pe/perseus/package.nix b/pkgs/by-name/pe/perseus/package.nix index 63836b7dc76ec9..4b39d2e913954d 100644 --- a/pkgs/by-name/pe/perseus/package.nix +++ b/pkgs/by-name/pe/perseus/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation { pname = "perseus"; diff --git a/pkgs/by-name/pe/persistent-cache-cpp/package.nix b/pkgs/by-name/pe/persistent-cache-cpp/package.nix index b6acb32dda6c21..e1d7bb70efa42f 100644 --- a/pkgs/by-name/pe/persistent-cache-cpp/package.nix +++ b/pkgs/by-name/pe/persistent-cache-cpp/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, gitUpdater -, testers -, boost -, cmake -, doxygen -, gtest -, leveldb -, lomiri -, pkg-config -, python3 -, validatePkgConfig +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + gitUpdater, + testers, + boost, + cmake, + doxygen, + gtest, + leveldb, + lomiri, + pkg-config, + python3, + validatePkgConfig, }: stdenv.mkDerivation (finalAttrs: { @@ -51,20 +52,22 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - postPatch = '' - # Wrong concatenation - substituteInPlace data/libpersistent-cache-cpp.pc.in \ - --replace "\''${prefix}/@CMAKE_INSTALL_LIBDIR@" "\''${prefix}/lib" - - # Runs in parallel to other tests, limit to 1 thread - substituteInPlace tests/headers/compile_headers.py \ - --replace 'multiprocessing.cpu_count()' '1' - - sed '1i#include ' \ - -i tests/core/persistent_string_cache/speed_test.cpp - '' + lib.optionalString finalAttrs.finalPackage.doCheck '' - patchShebangs tests/{headers,whitespace}/*.py - ''; + postPatch = + '' + # Wrong concatenation + substituteInPlace data/libpersistent-cache-cpp.pc.in \ + --replace "\''${prefix}/@CMAKE_INSTALL_LIBDIR@" "\''${prefix}/lib" + + # Runs in parallel to other tests, limit to 1 thread + substituteInPlace tests/headers/compile_headers.py \ + --replace 'multiprocessing.cpu_count()' '1' + + sed '1i#include ' \ + -i tests/core/persistent_string_cache/speed_test.cpp + '' + + lib.optionalString finalAttrs.finalPackage.doCheck '' + patchShebangs tests/{headers,whitespace}/*.py + ''; nativeBuildInputs = [ cmake diff --git a/pkgs/by-name/pe/peru/package.nix b/pkgs/by-name/pe/peru/package.nix index ff3f96a7fac2ba..67e9b0a0688f20 100644 --- a/pkgs/by-name/pe/peru/package.nix +++ b/pkgs/by-name/pe/peru/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "peru"; @@ -13,7 +17,10 @@ python3Packages.buildPythonApplication rec { sha256 = "0p4j51m89glx12cd65lcnbwpvin0v49wkhrx06755skr7v37pm2a"; }; - propagatedBuildInputs = with python3Packages; [ pyyaml docopt ]; + propagatedBuildInputs = with python3Packages; [ + pyyaml + docopt + ]; # No tests in archive doCheck = false; diff --git a/pkgs/by-name/pe/pesign/package.nix b/pkgs/by-name/pe/pesign/package.nix index a4bc4519d118ad..a29bee3ba2b6db 100644 --- a/pkgs/by-name/pe/pesign/package.nix +++ b/pkgs/by-name/pe/pesign/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, nss -, efivar -, util-linux -, popt -, nspr -, mandoc +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + nss, + efivar, + util-linux, + popt, + nspr, + mandoc, }: stdenv.mkDerivation rec { @@ -27,7 +28,14 @@ stdenv.mkDerivation rec { # containing things we already have in `nss`. # We can ignore all the errors pertaining to a missing # nss-util.pc I suppose. - buildInputs = [ efivar util-linux nss popt nspr mandoc ]; + buildInputs = [ + efivar + util-linux + nss + popt + nspr + mandoc + ]; nativeBuildInputs = [ pkg-config ]; makeFlags = [ "INSTALLROOT=$(out)" ]; diff --git a/pkgs/by-name/pe/pest-ide-tools/package.nix b/pkgs/by-name/pe/pest-ide-tools/package.nix index 4e0fdaebdb33e6..8856bd46bb9d22 100644 --- a/pkgs/by-name/pe/pest-ide-tools/package.nix +++ b/pkgs/by-name/pe/pest-ide-tools/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, nix-update-script -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + nix-update-script, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pe/pest/package.nix b/pkgs/by-name/pe/pest/package.nix index 1951b9d6dfbfb3..5267f577d17080 100644 --- a/pkgs/by-name/pe/pest/package.nix +++ b/pkgs/by-name/pe/pest/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, php }: +{ + lib, + fetchFromGitHub, + php, +}: php.buildComposerProject2 (finalAttrs: { pname = "pest"; diff --git a/pkgs/by-name/pe/pet/package.nix b/pkgs/by-name/pe/pet/package.nix index f48604a3b11835..7fcdf452617ccb 100644 --- a/pkgs/by-name/pe/pet/package.nix +++ b/pkgs/by-name/pe/pet/package.nix @@ -1,4 +1,9 @@ -{ buildGoModule, fetchFromGitHub, installShellFiles, lib }: +{ + buildGoModule, + fetchFromGitHub, + installShellFiles, + lib, +}: buildGoModule rec { pname = "pet"; @@ -14,7 +19,9 @@ buildGoModule rec { vendorHash = "sha256-VGhkhpqYJZZLCUMOE0eYBOICeFhRjgSXCGGUEYLDoQo="; ldflags = [ - "-s" "-w" "-X=github.com/knqyf263/pet/cmd.version=${version}" + "-s" + "-w" + "-X=github.com/knqyf263/pet/cmd.version=${version}" ]; doCheck = false; diff --git a/pkgs/by-name/pe/petidomo/package.nix b/pkgs/by-name/pe/petidomo/package.nix index d879d3233a3b25..20b70daea82697 100644 --- a/pkgs/by-name/pe/petidomo/package.nix +++ b/pkgs/by-name/pe/petidomo/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, flex, bison, sendmailPath ? "/run/wrappers/bin/sendmail" }: +{ + lib, + stdenv, + fetchurl, + flex, + bison, + sendmailPath ? "/run/wrappers/bin/sendmail", +}: stdenv.mkDerivation rec { pname = "petidomo"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "0x4dbxc4fcfg1rw5ywpcypvylnzn3y4rh0m6fz4h4cdnzb8p1lvm"; }; - buildInputs = [ flex bison ]; + buildInputs = [ + flex + bison + ]; configureFlags = [ "--with-mta=${sendmailPath}" ]; diff --git a/pkgs/by-name/pe/pev/package.nix b/pkgs/by-name/pe/pev/package.nix index 56b72c24c421ed..5e9defe2cc6505 100644 --- a/pkgs/by-name/pe/pev/package.nix +++ b/pkgs/by-name/pe/pev/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, openssl, fetchFromGitHub }: +{ + lib, + stdenv, + openssl, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "pev"; diff --git a/pkgs/by-name/pe/pew/package.nix b/pkgs/by-name/pe/pew/package.nix index adcfc0efd4c737..dee493ac1a3c6a 100644 --- a/pkgs/by-name/pe/pew/package.nix +++ b/pkgs/by-name/pe/pew/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchPypi }: +{ + lib, + python3, + fetchPypi, +}: with python3.pkgs; @@ -11,7 +15,11 @@ buildPythonApplication rec { sha256 = "04anak82p4v9w0lgfs55s7diywxil6amq8c8bhli143ca8l2fcdq"; }; - propagatedBuildInputs = [ virtualenv virtualenv-clone setuptools ]; + propagatedBuildInputs = [ + virtualenv + virtualenv-clone + setuptools + ]; # no tests are packaged checkPhase = '' diff --git a/pkgs/by-name/pf/pferd/package.nix b/pkgs/by-name/pf/pferd/package.nix index dc06ea3b3a32aa..14be2ae7ecc046 100644 --- a/pkgs/by-name/pf/pferd/package.nix +++ b/pkgs/by-name/pf/pferd/package.nix @@ -31,7 +31,7 @@ python3Packages.buildPythonApplication rec { homepage = "https://github.com/Garmelon/PFERD"; description = "Tool for downloading course-related files from ILIAS"; license = licenses.mit; - maintainers = with maintainers; [_0xbe7a]; + maintainers = with maintainers; [ _0xbe7a ]; mainProgram = "pferd"; }; } diff --git a/pkgs/by-name/pf/pfetch-rs/package.nix b/pkgs/by-name/pf/pfetch-rs/package.nix index f86b71f72c7bd8..17f656c910c72e 100644 --- a/pkgs/by-name/pf/pfetch-rs/package.nix +++ b/pkgs/by-name/pf/pfetch-rs/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, stdenv, darwin }: +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "pfetch-rs"; @@ -18,7 +24,6 @@ rustPlatform.buildRustPackage rec { darwin.apple_sdk.frameworks.DisplayServices ]; - meta = with lib; { description = "Rewrite of the pfetch system information tool in Rust"; homepage = "https://github.com/Gobidev/pfetch-rs"; diff --git a/pkgs/by-name/pf/pfetch/package.nix b/pkgs/by-name/pf/pfetch/package.nix index 732f6800288970..3dbb2865ce429b 100644 --- a/pkgs/by-name/pf/pfetch/package.nix +++ b/pkgs/by-name/pf/pfetch/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchFromGitHub }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "pfetch"; diff --git a/pkgs/by-name/pf/pffft/package.nix b/pkgs/by-name/pf/pffft/package.nix index b68b6d486823f8..07cca51f09a18d 100644 --- a/pkgs/by-name/pf/pffft/package.nix +++ b/pkgs/by-name/pf/pffft/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "pffft"; diff --git a/pkgs/by-name/pf/pfft/package.nix b/pkgs/by-name/pf/pfft/package.nix index 7e91b7d2889663..356c00ab84c032 100644 --- a/pkgs/by-name/pf/pfft/package.nix +++ b/pkgs/by-name/pf/pfft/package.nix @@ -1,14 +1,19 @@ -{ autoreconfHook -, fetchFromGitHub -, fftwMpi -, lib -, llvmPackages -, mpi -, precision ? "double" -, stdenv +{ + autoreconfHook, + fetchFromGitHub, + fftwMpi, + lib, + llvmPackages, + mpi, + precision ? "double", + stdenv, }: -assert lib.elem precision [ "single" "double" "long-double" ]; +assert lib.elem precision [ + "single" + "double" + "long-double" +]; let fftw' = fftwMpi.override { inherit precision; }; @@ -24,7 +29,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-T5nPlkPKjYYRCuT1tSzXNJTPs/o6zwJMv9lPCWOwabw="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ autoreconfHook ]; @@ -38,7 +46,10 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = lib.optional stdenv.cc.isClang llvmPackages.openmp; - propagatedBuildInputs = [ fftw' mpi ]; + propagatedBuildInputs = [ + fftw' + mpi + ]; doCheck = true; diff --git a/pkgs/by-name/pf/pforth/package.nix b/pkgs/by-name/pf/pforth/package.nix index 91efc25fc1e0bc..4c7766cc964324 100644 --- a/pkgs/by-name/pf/pforth/package.nix +++ b/pkgs/by-name/pf/pforth/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildPackages +{ + lib, + stdenv, + fetchFromGitHub, + buildPackages, }: stdenv.mkDerivation (finalAttrs: { @@ -43,7 +44,10 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "pforth"; changelog = "https://github.com/philburk/pforth/blob/v${finalAttrs.version}/RELEASES.md"; license = lib.licenses.bsd0; - maintainers = with lib.maintainers; [ AndersonTorres yrashk ]; + maintainers = with lib.maintainers; [ + AndersonTorres + yrashk + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/by-name/pf/pfsshell/package.nix b/pkgs/by-name/pf/pfsshell/package.nix index 24eb379adf5cd1..5ebe0684e3c899 100644 --- a/pkgs/by-name/pf/pfsshell/package.nix +++ b/pkgs/by-name/pf/pfsshell/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, +}: stdenv.mkDerivation rec { version = "1.1.1"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "0cr91al3knsbfim75rzl7rxdsglcc144x0nizn7q4jx5cad3zbn8"; }; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; # Build errors since 1.1.1 when format hardening is enabled: # cc1: error: '-Wformat-security' ignored without '-Wformat' [-Werror=format-security] @@ -23,7 +32,7 @@ stdenv.mkDerivation rec { platforms = platforms.unix; license = with licenses; [ gpl2Only # the pfsshell software itself - afl20 # APA, PFS, and iomanX libraries which are compiled together with this package + afl20 # APA, PFS, and iomanX libraries which are compiled together with this package ]; maintainers = with maintainers; [ makefu ]; mainProgram = "pfsshell"; diff --git a/pkgs/by-name/pg/pg-dump-anon/package.nix b/pkgs/by-name/pg/pg-dump-anon/package.nix index a097eb8aa9c71b..a7771fcf523ecd 100644 --- a/pkgs/by-name/pg/pg-dump-anon/package.nix +++ b/pkgs/by-name/pg/pg-dump-anon/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitLab, buildGoModule, nixosTests, postgresql_17, makeWrapper }: +{ + lib, + fetchFromGitLab, + buildGoModule, + nixosTests, + postgresql_17, + makeWrapper, +}: buildGoModule rec { pname = "pg-dump-anon"; diff --git a/pkgs/by-name/pg/pg_activity/package.nix b/pkgs/by-name/pg/pg_activity/package.nix index ccb4444c01c967..39e94712f313b1 100644 --- a/pkgs/by-name/pg/pg_activity/package.nix +++ b/pkgs/by-name/pg/pg_activity/package.nix @@ -1,4 +1,8 @@ -{ python3Packages, fetchFromGitHub, lib }: +{ + python3Packages, + fetchFromGitHub, + lib, +}: python3Packages.buildPythonApplication rec { pname = "pg_activity"; diff --git a/pkgs/by-name/pg/pg_checksums/package.nix b/pkgs/by-name/pg/pg_checksums/package.nix index b65299cf1a5064..e01a56206c1c7d 100644 --- a/pkgs/by-name/pg/pg_checksums/package.nix +++ b/pkgs/by-name/pg/pg_checksums/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, libxslt, docbook_xsl, postgresql }: +{ + lib, + stdenv, + fetchFromGitHub, + libxslt, + docbook_xsl, + postgresql, +}: stdenv.mkDerivation rec { pname = "pg_checksums"; @@ -15,7 +22,10 @@ stdenv.mkDerivation rec { buildInputs = [ postgresql ]; - buildFlags = [ "all" "man" ]; + buildFlags = [ + "all" + "man" + ]; preConfigure = '' substituteInPlace doc/stylesheet-man.xsl \ diff --git a/pkgs/by-name/pg/pg_featureserv/package.nix b/pkgs/by-name/pg/pg_featureserv/package.nix index df7bba48abe631..6774bfda4e21ad 100644 --- a/pkgs/by-name/pg/pg_featureserv/package.nix +++ b/pkgs/by-name/pg/pg_featureserv/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "pg_featureserv"; @@ -25,7 +29,11 @@ buildGoModule rec { --replace-fail "AssetsPath = \"./assets\"" "AssetsPath = \"$out/share/assets\"" ''; - ldflags = [ "-s" "-w" "-X github.com/CrunchyData/pg_featureserv/conf.setVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/CrunchyData/pg_featureserv/conf.setVersion=${version}" + ]; postInstall = '' mkdir -p $out/share diff --git a/pkgs/by-name/pg/pg_flame/package.nix b/pkgs/by-name/pg/pg_flame/package.nix index da9cc6c77d5916..35f860063d1abb 100644 --- a/pkgs/by-name/pg/pg_flame/package.nix +++ b/pkgs/by-name/pg/pg_flame/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pg_flame"; diff --git a/pkgs/by-name/pg/pg_tileserv/package.nix b/pkgs/by-name/pg/pg_tileserv/package.nix index 94f633fcaf0550..96d5f6eb5caa39 100644 --- a/pkgs/by-name/pg/pg_tileserv/package.nix +++ b/pkgs/by-name/pg/pg_tileserv/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "pg_tileserv"; @@ -25,7 +29,11 @@ buildGoModule rec { --replace-fail "# AssetsPath = \"/usr/share/pg_tileserv/assets\"" "AssetsPath = \"$out/share/assets\"" ''; - ldflags = [ "-s" "-w" "-X main.programVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.programVersion=${version}" + ]; postInstall = '' mkdir -p $out/share diff --git a/pkgs/by-name/pg/pgagroal/package.nix b/pkgs/by-name/pg/pgagroal/package.nix index 2b89773af833d0..4ec8d31a2e986f 100644 --- a/pkgs/by-name/pg/pgagroal/package.nix +++ b/pkgs/by-name/pg/pgagroal/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cjson, cmake, docutils, libev, openssl, systemd }: +{ + lib, + stdenv, + fetchFromGitHub, + cjson, + cmake, + docutils, + libev, + openssl, + systemd, +}: stdenv.mkDerivation (finalAttrs: { pname = "pgagroal"; @@ -13,10 +23,16 @@ stdenv.mkDerivation (finalAttrs: { patches = [ ./do-not-search-libatomic.patch ]; - nativeBuildInputs = [ cmake docutils ]; + nativeBuildInputs = [ + cmake + docutils + ]; - buildInputs = [ cjson libev openssl ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ systemd ]; + buildInputs = [ + cjson + libev + openssl + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ systemd ]; meta = with lib; { description = "High-performance connection pool for PostgreSQL"; diff --git a/pkgs/by-name/pg/pgbackrest/package.nix b/pkgs/by-name/pg/pgbackrest/package.nix index 78fa48fde463bc..e67e38c598d5a8 100644 --- a/pkgs/by-name/pg/pgbackrest/package.nix +++ b/pkgs/by-name/pg/pgbackrest/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, python3 -, pkg-config -, libbacktrace -, bzip2 -, lz4 -, postgresql -, libxml2 -, libyaml -, zlib -, libssh2 -, zstd +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + python3, + pkg-config, + libbacktrace, + bzip2, + lz4, + postgresql, + libxml2, + libyaml, + zlib, + libssh2, + zstd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pg/pgbouncer/package.nix b/pkgs/by-name/pg/pgbouncer/package.nix index dfffa518a5fd66..b3ee07147c84b5 100644 --- a/pkgs/by-name/pg/pgbouncer/package.nix +++ b/pkgs/by-name/pg/pgbouncer/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, openssl, libevent, c-ares, pkg-config, systemd, nixosTests }: +{ + lib, + stdenv, + fetchurl, + openssl, + libevent, + c-ares, + pkg-config, + systemd, + nixosTests, +}: stdenv.mkDerivation rec { pname = "pgbouncer"; @@ -10,8 +20,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libevent openssl c-ares ] - ++ lib.optional stdenv.hostPlatform.isLinux systemd; + buildInputs = [ + libevent + openssl + c-ares + ] ++ lib.optional stdenv.hostPlatform.isLinux systemd; enableParallelBuilding = true; configureFlags = lib.optional stdenv.hostPlatform.isLinux "--with-systemd"; @@ -23,7 +36,9 @@ stdenv.mkDerivation rec { homepage = "https://www.pgbouncer.org/"; mainProgram = "pgbouncer"; description = "Lightweight connection pooler for PostgreSQL"; - changelog = "https://github.com/pgbouncer/pgbouncer/releases/tag/pgbouncer_${replaceStrings ["."] ["_"] version}"; + changelog = "https://github.com/pgbouncer/pgbouncer/releases/tag/pgbouncer_${ + replaceStrings [ "." ] [ "_" ] version + }"; license = licenses.isc; maintainers = with maintainers; [ _1000101 ]; platforms = platforms.all; diff --git a/pkgs/by-name/pg/pgcenter/package.nix b/pkgs/by-name/pg/pgcenter/package.nix index 0b3dde03b4c6f2..41025c33af0316 100644 --- a/pkgs/by-name/pg/pgcenter/package.nix +++ b/pkgs/by-name/pg/pgcenter/package.nix @@ -1,13 +1,17 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pgcenter"; version = "0.9.2"; src = fetchFromGitHub { - owner = "lesovsky"; - repo = "pgcenter"; - rev = "v${version}"; + owner = "lesovsky"; + repo = "pgcenter"; + rev = "v${version}"; sha256 = "sha256-xaY01T12/5Peww9scRgfc5yHj7QA8BEwOK5l6OedziY="; }; @@ -15,7 +19,13 @@ buildGoModule rec { subPackages = [ "cmd" ]; - ldflags = [ "-w" "-s" "-X main.gitTag=${src.rev}" "-X main.gitCommit=${src.rev}" "-X main.gitBranch=master" ]; + ldflags = [ + "-w" + "-s" + "-X main.gitTag=${src.rev}" + "-X main.gitCommit=${src.rev}" + "-X main.gitBranch=master" + ]; postInstall = '' mv $out/bin/cmd $out/bin/pgcenter diff --git a/pkgs/by-name/pg/pgcopydb/package.nix b/pkgs/by-name/pg/pgcopydb/package.nix index 1fda00a750e915..9cf2992b28baf3 100644 --- a/pkgs/by-name/pg/pgcopydb/package.nix +++ b/pkgs/by-name/pg/pgcopydb/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, libkrb5 -, openssl -, pam -, pkg-config -, postgresql -, readline -, sqlite -, testers -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + libkrb5, + openssl, + pam, + pkg-config, + postgresql, + readline, + sqlite, + testers, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -27,16 +28,18 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - libkrb5 - openssl - postgresql - readline - sqlite - zlib - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - pam - ]; + buildInputs = + [ + libkrb5 + openssl + postgresql + readline + sqlite + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + pam + ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/pg/pget/package.nix b/pkgs/by-name/pg/pget/package.nix index d4c5a702fe05b0..3a7ac72df18d87 100644 --- a/pkgs/by-name/pg/pget/package.nix +++ b/pkgs/by-name/pg/pget/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "pget"; diff --git a/pkgs/by-name/pg/pgf-pie/package.nix b/pkgs/by-name/pg/pgf-pie/package.nix index 4c8bf800e46204..1b5e04b2ad08ae 100644 --- a/pkgs/by-name/pg/pgf-pie/package.nix +++ b/pkgs/by-name/pg/pgf-pie/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pg/pgf-umlcd/package.nix b/pkgs/by-name/pg/pgf-umlcd/package.nix index 293fa6b52e3776..d255e9049712b3 100644 --- a/pkgs/by-name/pg/pgf-umlcd/package.nix +++ b/pkgs/by-name/pg/pgf-umlcd/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pg/pgf-umlsd/package.nix b/pkgs/by-name/pg/pgf-umlsd/package.nix index 4fd32aadf8ce2f..ddaced12f87aba 100644 --- a/pkgs/by-name/pg/pgf-umlsd/package.nix +++ b/pkgs/by-name/pg/pgf-umlsd/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/pg/pgf1/package.nix b/pkgs/by-name/pg/pgf1/package.nix index b0681d1ce8d14c..3ba5c88b08c442 100644 --- a/pkgs/by-name/pg/pgf1/package.nix +++ b/pkgs/by-name/pg/pgf1/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -10,7 +11,7 @@ stdenvNoCC.mkDerivation (finalAttrs: { src = fetchFromGitHub { owner = "pgf-tikz"; repo = "pgf"; - rev = "refs/tags/version-${lib.replaceStrings ["."] ["-"] finalAttrs.version}"; + rev = "refs/tags/version-${lib.replaceStrings [ "." ] [ "-" ] finalAttrs.version}"; hash = "sha256-WZ/191iEDd5VK1bnV9JZx2BZfACUeAUhAqrlyx+ZvA4="; }; diff --git a/pkgs/by-name/pg/pgf2/package.nix b/pkgs/by-name/pg/pgf2/package.nix index 82d20260638293..7612081271ef0c 100644 --- a/pkgs/by-name/pg/pgf2/package.nix +++ b/pkgs/by-name/pg/pgf2/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pg/pgf3/package.nix b/pkgs/by-name/pg/pgf3/package.nix index 3395c15adf6c1d..3accf107d24c4c 100644 --- a/pkgs/by-name/pg/pgf3/package.nix +++ b/pkgs/by-name/pg/pgf3/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pg/pgf_graphics/package.nix b/pkgs/by-name/pg/pgf_graphics/package.nix index e63875c19cd31b..f92be10a6307f9 100644 --- a/pkgs/by-name/pg/pgf_graphics/package.nix +++ b/pkgs/by-name/pg/pgf_graphics/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchzip -, autoreconfHook -, dos2unix -, doxygen -, freeimage -, libpgf +{ + lib, + stdenv, + fetchzip, + autoreconfHook, + dos2unix, + doxygen, + freeimage, + libpgf, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pg/pgformatter/package.nix b/pkgs/by-name/pg/pgformatter/package.nix index cad3d2af45052a..0f3547ed42c7ba 100644 --- a/pkgs/by-name/pg/pgformatter/package.nix +++ b/pkgs/by-name/pg/pgformatter/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, perlPackages, fetchFromGitHub, fetchpatch, shortenPerlShebang }: +{ + lib, + stdenv, + perlPackages, + fetchFromGitHub, + fetchpatch, + shortenPerlShebang, +}: perlPackages.buildPerlPackage rec { pname = "pgformatter"; @@ -47,7 +54,10 @@ perlPackages.buildPerlPackage rec { homepage = "https://github.com/darold/pgFormatter"; changelog = "https://github.com/darold/pgFormatter/releases/tag/v${version}"; maintainers = [ ]; - license = [ licenses.postgresql licenses.artistic2 ]; + license = [ + licenses.postgresql + licenses.artistic2 + ]; mainProgram = "pg_format"; }; } diff --git a/pkgs/by-name/pg/pgfplots/package.nix b/pkgs/by-name/pg/pgfplots/package.nix index 559b34f34ad054..47e1f257a4fbd3 100644 --- a/pkgs/by-name/pg/pgfplots/package.nix +++ b/pkgs/by-name/pg/pgfplots/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pg/pghero/gemset.nix b/pkgs/by-name/pg/pghero/gemset.nix index 55958edada274d..2bd3bf3b817278 100644 --- a/pkgs/by-name/pg/pghero/gemset.nix +++ b/pkgs/by-name/pg/pghero/gemset.nix @@ -1,1020 +1,1188 @@ { actioncable = { - dependencies = ["actionpack" "activesupport" "nio4r" "websocket-driver"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "nio4r" + "websocket-driver" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ms0196bp8gzlghfj32q2qdzszb7hsgg96v3isrv5ysd87w0z2zl"; type = "gem"; }; version = "7.0.8.6"; }; actionmailbox = { - dependencies = ["actionpack" "activejob" "activerecord" "activestorage" "activesupport" "mail" "net-imap" "net-pop" "net-smtp"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activejob" + "activerecord" + "activestorage" + "activesupport" + "mail" + "net-imap" + "net-pop" + "net-smtp" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0mw8casnlqgj3vwqv7qk3d4q3bjszlpmbs9ldpc9gz1qdvafx7cg"; type = "gem"; }; version = "7.0.8.6"; }; actionmailer = { - dependencies = ["actionpack" "actionview" "activejob" "activesupport" "mail" "net-imap" "net-pop" "net-smtp" "rails-dom-testing"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "actionview" + "activejob" + "activesupport" + "mail" + "net-imap" + "net-pop" + "net-smtp" + "rails-dom-testing" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07gpm15k5c0y84q99zipnhcdgq93bwralyjpj252prvqwfjmiw73"; type = "gem"; }; version = "7.0.8.6"; }; actionpack = { - dependencies = ["actionview" "activesupport" "rack" "rack-test" "rails-dom-testing" "rails-html-sanitizer"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionview" + "activesupport" + "rack" + "rack-test" + "rails-dom-testing" + "rails-html-sanitizer" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "19ywl4jp77b51c01hsyzwia093fnj73pw1ipgyj4pk3h2b9faj5n"; type = "gem"; }; version = "7.0.8.6"; }; actiontext = { - dependencies = ["actionpack" "activerecord" "activestorage" "activesupport" "globalid" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activerecord" + "activestorage" + "activesupport" + "globalid" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1j8b29764nbiqz6d7ra42j2i6wf070lbms1fhpq3cl9azbgijb16"; type = "gem"; }; version = "7.0.8.6"; }; actionview = { - dependencies = ["activesupport" "builder" "erubi" "rails-dom-testing" "rails-html-sanitizer"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "builder" + "erubi" + "rails-dom-testing" + "rails-html-sanitizer" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0girx71db1aq5b70ln3qq03z9d7xjdyp297v1a8rdal7k89y859c"; type = "gem"; }; version = "7.0.8.6"; }; activejob = { - dependencies = ["activesupport" "globalid"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "globalid" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gbc0wx9xal5bj0pbz8ygkr75wj4cm5i69hpwknf023psgixaybw"; type = "gem"; }; version = "7.0.8.6"; }; activemodel = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1f6szahjsb4pr2xvlvk4kghk9291xh9c14s8cqwy6wwpm1vcglim"; type = "gem"; }; version = "7.0.8.6"; }; activerecord = { - dependencies = ["activemodel" "activesupport"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activemodel" + "activesupport" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14qs1jc9hwnsm4dzvnai8b36bcq1d7rcqgjxy0dc6wza670lqapf"; type = "gem"; }; version = "7.0.8.6"; }; activerecord-nulldb-adapter = { - dependencies = ["activerecord"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activerecord" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1552py7zlamd5gy2dbkzjixanl9k07y6jqqrr4ic6n52apwd0ijy"; type = "gem"; }; version = "1.0.1"; }; activestorage = { - dependencies = ["actionpack" "activejob" "activerecord" "activesupport" "marcel" "mini_mime"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activejob" + "activerecord" + "activesupport" + "marcel" + "mini_mime" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1nnvqnmc7mdhw2w55j4vnx4zmmdmmwmaf6ax2mbj9j5a48fw19vf"; type = "gem"; }; version = "7.0.8.6"; }; activesupport = { - dependencies = ["concurrent-ruby" "i18n" "minitest" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "i18n" + "minitest" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gj20cysajda05z3r7pl1g9y84nzsqak5dvk9nrz13jpy6297dj1"; type = "gem"; }; version = "7.0.8.6"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gvdg4yx4p9av2glmp7vsxhs0n8fj1ga9kq2xdb8f95j7b04qhzi"; type = "gem"; }; version = "1.3.0"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1f2y7ycq7i3y7p5klsi3gk3p5r5p1vkq6w7dq4zk9grq2hw9f7cv"; type = "gem"; }; version = "1.999.0"; }; aws-sdk-cloudwatch = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "04fw6v3qbbgdv63l7kmc29p30bjdancg0kfrxbqcmidryj00qi2c"; type = "gem"; }; version = "1.104.0"; }; aws-sdk-core = { - dependencies = ["aws-eventstream" "aws-partitions" "aws-sigv4" "jmespath"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-eventstream" + "aws-partitions" + "aws-sigv4" + "jmespath" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "16mvscjhxdyhlvk2rpbxdzqmyikcf64xavb35grk4dkh0pg390rk"; type = "gem"; }; version = "3.211.0"; }; aws-sigv4 = { - dependencies = ["aws-eventstream"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-eventstream" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fq3lbvkgm1vk5wa8l7vdnq3vjnlmsnyf4bbd0jq3qadyd9hf54a"; type = "gem"; }; version = "1.10.1"; }; azure_mgmt_monitor = { - dependencies = ["ms_rest_azure"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ms_rest_azure" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13yqhcdqv4lr6bf3ylh2p1k9x4qg9qlr05y9fv7fi8yj5rqrbjhx"; type = "gem"; }; version = "0.19.0"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; builder = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pw3r2lyagsxkm71bf44v5b74f7l9r7di22brbyji9fwz791hya9"; type = "gem"; }; version = "3.3.0"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; crass = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pfl5c0pyqaparxaqxi6s4gfl21bdldwiawrc0aknyvflli60lfw"; type = "gem"; }; version = "1.0.6"; }; date = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "149jknsq999gnhy865n33fkk22s0r447k76x9pmcnnwldfv2q7wp"; type = "gem"; }; version = "3.3.4"; }; declarative = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yczgnqrbls7shrg63y88g7wand2yp9h6sf56c9bdcksn5nds8c0"; type = "gem"; }; version = "0.0.20"; }; domain_name = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cyr2xm576gqhqicsyqnhanni47408w2pgvrfi8pd13h2li3nsaz"; type = "gem"; }; version = "0.6.20240107"; }; erubi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qnd6ff4az22ysnmni3730c41b979xinilahzg86bn7gv93ip9pw"; type = "gem"; }; version = "1.13.0"; }; faraday = { - dependencies = ["faraday-em_http" "faraday-em_synchrony" "faraday-excon" "faraday-httpclient" "faraday-multipart" "faraday-net_http" "faraday-net_http_persistent" "faraday-patron" "faraday-rack" "faraday-retry" "ruby2_keywords"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-em_http" + "faraday-em_synchrony" + "faraday-excon" + "faraday-httpclient" + "faraday-multipart" + "faraday-net_http" + "faraday-net_http_persistent" + "faraday-patron" + "faraday-rack" + "faraday-retry" + "ruby2_keywords" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "069gmdh5j90v06rbwlqvlhzhq45lxhx74mahz25xd276rm0wb153"; type = "gem"; }; version = "1.10.4"; }; faraday-cookie_jar = { - dependencies = ["faraday" "http-cookie"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "http-cookie" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00hligx26w9wdnpgsrf0qdnqld4rdccy8ym6027h5m735mpvxjzk"; type = "gem"; }; version = "0.0.7"; }; faraday-em_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12cnqpbak4vhikrh2cdn94assh3yxza8rq2p9w2j34bqg5q4qgbs"; type = "gem"; }; version = "1.0.0"; }; faraday-em_synchrony = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vgrbhkp83sngv6k4mii9f2s9v5lmp693hylfxp2ssfc60fas3a6"; type = "gem"; }; version = "1.0.0"; }; faraday-excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h09wkb0k0bhm6dqsd47ac601qiaah8qdzjh8gvxfd376x1chmdh"; type = "gem"; }; version = "1.1.0"; }; faraday-httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fyk0jd3ks7fdn8nv3spnwjpzx2lmxmg2gh4inz3by1zjzqg33sc"; type = "gem"; }; version = "1.0.1"; }; faraday-multipart = { - dependencies = ["multipart-post"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multipart-post" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09871c4hd7s5ws1wl4gs7js1k2wlby6v947m2bbzg43pnld044lh"; type = "gem"; }; version = "1.0.4"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10n6wikd442mfm15hd6gzm0qb527161w1wwch4h5m4iclkz2x6b3"; type = "gem"; }; version = "1.0.2"; }; faraday-net_http_persistent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dc36ih95qw3rlccffcb0vgxjhmipsvxhn6cw71l7ffs0f7vq30b"; type = "gem"; }; version = "1.2.0"; }; faraday-patron = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19wgsgfq0xkski1g7m96snv39la3zxz6x7nbdgiwhg5v82rxfb6w"; type = "gem"; }; version = "1.0.0"; }; faraday-rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h184g4vqql5jv9s9im6igy00jp6mrah2h14py6mpf9bkabfqq7g"; type = "gem"; }; version = "1.0.0"; }; faraday-retry = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "153i967yrwnswqgvnnajgwp981k9p50ys1h80yz3q94rygs59ldd"; type = "gem"; }; version = "1.0.3"; }; globalid = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sbw6b66r7cwdx3jhs46s4lr991969hvigkjpbdl7y3i31qpdgvh"; type = "gem"; }; version = "1.2.1"; }; google-apis-core = { - dependencies = ["addressable" "googleauth" "httpclient" "mini_mime" "mutex_m" "representable" "retriable"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "googleauth" + "httpclient" + "mini_mime" + "mutex_m" + "representable" + "retriable" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "06m775rzhpdz9kalml04sysy5swgfh97jaglsgrv5x8sg4i42j4i"; type = "gem"; }; version = "0.15.1"; }; google-apis-monitoring_v3 = { - dependencies = ["google-apis-core"]; - groups = ["default"]; - platforms = []; + dependencies = [ "google-apis-core" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qzks40qfdxlgy0w72y75rlji9g225v6shf78k6q4p74f7w2ns0s"; type = "gem"; }; version = "0.71.0"; }; google-cloud-env = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ks9yv21d8bl9cw0sz5gy6npll1ig3m2bq9w7yw67j5mw2p64q1w"; type = "gem"; }; version = "2.2.1"; }; google-protobuf = { - dependencies = ["bigdecimal" "rake"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bigdecimal" + "rake" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1d99vyhmyp2n5zd0qmfymzwbcn71dbnwwvc0m4z14msjb7b8dvf0"; type = "gem"; }; version = "4.28.3"; }; googleauth = { - dependencies = ["faraday" "google-cloud-env" "jwt" "multi_json" "os" "signet"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "google-cloud-env" + "jwt" + "multi_json" + "os" + "signet" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07kk8h5f9q62qf1mk7rycgv6m09rd0k8baffdpb3vsksxnpaqsvy"; type = "gem"; }; version = "1.11.2"; }; http-cookie = { - dependencies = ["domain_name"]; - groups = ["default"]; - platforms = []; + dependencies = [ "domain_name" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lr2yk5g5vvf9nzlmkn3p7mhh9mn55gpdc7kl2w21xs46fgkjynb"; type = "gem"; }; version = "1.0.7"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k31wcgnvcvd14snz0pfqj976zv6drfsnq6x8acz10fiyms9l8nw"; type = "gem"; }; version = "1.14.6"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cdw9vw2qly7q7r41s7phnac264rbsdqgj4l0h4nqgbjb157g393"; type = "gem"; }; version = "1.6.2"; }; jwt = { - dependencies = ["base64"]; - groups = ["default"]; - platforms = []; + dependencies = [ "base64" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rba9mji57sfa1kjhj0bwff1377vj0i8yx2rd39j5ik4vp60gzam"; type = "gem"; }; version = "2.9.3"; }; loofah = { - dependencies = ["crass" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "crass" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ppp2cgli5avzk0z3dwnah6y65ymyr793yja28p2fs9vrci7986h"; type = "gem"; }; version = "2.23.1"; }; mail = { - dependencies = ["mini_mime" "net-imap" "net-pop" "net-smtp"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_mime" + "net-imap" + "net-pop" + "net-smtp" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1bf9pysw1jfgynv692hhaycfxa8ckay1gjw5hz3madrbrynryfzc"; type = "gem"; }; version = "2.8.1"; }; marcel = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "190n2mk8m1l708kr88fh6mip9sdsh339d2s6sgrik3sbnvz4jmhd"; type = "gem"; }; version = "1.0.4"; }; method_source = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1igmc3sq9ay90f8xjvfnswd1dybj1s3fi0dwd53inwsvqk4h24qq"; type = "gem"; }; version = "1.1.0"; }; mini_mime = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vycif7pjzkr29mfk4dlqv3disc5dn0va04lkwajlpr1wkibg0c6"; type = "gem"; }; version = "1.1.5"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q1f2sdw3y3y9mnym9dhjgsjr72sq975cfg5c4yx7gwv8nmzbvhk"; type = "gem"; }; version = "2.8.7"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n1akmc6bibkbxkzm1p1wmfb4n9vv397knkgz0ffykb3h1d7kdix"; type = "gem"; }; version = "5.25.1"; }; ms_rest = { - dependencies = ["concurrent-ruby" "faraday" "timeliness"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "faraday" + "timeliness" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1jiha1bda5knpjqjymwik6i41n69gb0phcrgvmgc5icl4mcisai7"; type = "gem"; }; version = "0.7.6"; }; ms_rest_azure = { - dependencies = ["concurrent-ruby" "faraday" "faraday-cookie_jar" "ms_rest"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "faraday" + "faraday-cookie_jar" + "ms_rest" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "06i37b84r2q206kfm5vsi9s1qiiy09091vhvc5pzb7320h0hc1ih"; type = "gem"; }; version = "0.12.0"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a5lrlvmg2kb2dhw3lxcsv6x276bwgsxpnka1752082miqxd0wlq"; type = "gem"; }; version = "2.4.1"; }; mutex_m = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ma093ayps1m92q845hmpk0dmadicvifkbf05rpq9pifhin0rvxn"; type = "gem"; }; version = "0.2.0"; }; net-imap = { - dependencies = ["date" "net-protocol"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "date" + "net-protocol" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "182ap7y5ysmr1xqy23ygssz3as1wcy3r5qcdm1whd1n1yfc1aa5q"; type = "gem"; }; version = "0.5.0"; }; net-pop = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wyz41jd4zpjn0v1xsf9j778qx1vfrl24yc20cpmph8k42c4x2w4"; type = "gem"; }; version = "0.1.2"; }; net-protocol = { - dependencies = ["timeout"]; - groups = ["default"]; - platforms = []; + dependencies = [ "timeout" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a32l4x73hz200cm587bc29q8q9az278syw3x6fkc9d1lv5y0wxa"; type = "gem"; }; version = "0.2.2"; }; net-smtp = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0amlhz8fhnjfmsiqcjajip57ici2xhw089x7zqyhpk51drg43h2z"; type = "gem"; }; version = "0.5.0"; }; nio4r = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a9www524fl1ykspznz54i0phfqya4x45hqaz67in9dvw1lfwpfr"; type = "gem"; }; version = "2.7.4"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15gysw8rassqgdq3kwgl4mhqmrgh7nk2qvrcqp4ijyqazgywn6gq"; type = "gem"; }; version = "1.16.7"; }; os = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gwd20smyhxbm687vdikfh1gpi96h8qb1x28s2pdcysf6dm6v0ap"; type = "gem"; }; version = "1.1.4"; }; pg = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1p2gqqrm895fzr9vi8d118zhql67bm8ydjvgqbq1crdnfggzn7kn"; type = "gem"; }; version = "1.5.9"; }; pg_query = { - dependencies = ["google-protobuf"]; - groups = ["default"]; - platforms = []; + dependencies = [ "google-protobuf" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p8ljf694qvrf5875ljg6kp7gvmndy8490kasjzcq22ghryg9xxp"; type = "gem"; }; version = "5.1.0"; }; pghero = { - dependencies = ["activerecord"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activerecord" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1m4wlwx37n1jsrdzxf824pz7j0p72i1al7ndmy6q5m3r77ngdm76"; type = "gem"; }; version = "3.6.1"; }; propshaft = { - dependencies = ["actionpack" "activesupport" "rack" "railties"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "rack" + "railties" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0sqg0xf46xd47zdpm8d12kfnwl0y5jb2hj10imzb3bk6mwgkd2fk"; type = "gem"; }; version = "1.1.0"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vqcw3iwby3yc6avs1vb3gfd0vcp2v7q310665dvxfswmcf4xm31"; type = "gem"; }; version = "6.0.1"; }; puma = { - dependencies = ["nio4r"]; - groups = ["default"]; - platforms = []; + dependencies = [ "nio4r" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gml1rixrfb0naciq3mrnqkpcvm9ahgps1c04hzxh4b801f69914"; type = "gem"; }; version = "6.4.3"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0byn0c9nkahsl93y9ln5bysq4j31q8xkf2ws42swighxd4lnjzsa"; type = "gem"; }; version = "1.8.1"; }; rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ax778fsfvlhj7c11n0d1wdcb8bxvkb190a9lha5d91biwzyx9g4"; type = "gem"; }; version = "2.2.10"; }; rack-test = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ysx29gk9k14a14zsp5a8czys140wacvp91fja8xcja0j1hzqq8c"; type = "gem"; }; version = "2.1.0"; }; rails = { - dependencies = ["actioncable" "actionmailbox" "actionmailer" "actionpack" "actiontext" "actionview" "activejob" "activemodel" "activerecord" "activestorage" "activesupport" "railties"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actioncable" + "actionmailbox" + "actionmailer" + "actionpack" + "actiontext" + "actionview" + "activejob" + "activemodel" + "activerecord" + "activestorage" + "activesupport" + "railties" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1s42lyl19h74xlqkb6ffl67h688q0slp1lhnd05g09a46z7wapri"; type = "gem"; }; version = "7.0.8.6"; }; rails-dom-testing = { - dependencies = ["activesupport" "minitest" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "minitest" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fx9dx1ag0s1lr6lfr34lbx5i1bvn3bhyf3w3mx6h7yz90p725g5"; type = "gem"; }; version = "2.2.0"; }; rails-html-sanitizer = { - dependencies = ["loofah" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "loofah" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1pm4z853nyz1bhhqr7fzl44alnx4bjachcr6rh6qjj375sfz3sc6"; type = "gem"; }; version = "1.6.0"; }; railties = { - dependencies = ["actionpack" "activesupport" "method_source" "rake" "thor" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "method_source" + "rake" + "thor" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1fcn0ix814074gqicc0k1178f7ahmysiv3pfq8g00phdwj0p3w0g"; type = "gem"; }; version = "7.0.8.6"; }; rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17850wcwkgi30p7yqh60960ypn7yibacjjha0av78zaxwvd3ijs6"; type = "gem"; }; version = "13.2.1"; }; representable = { - dependencies = ["declarative" "trailblazer-option" "uber"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "declarative" + "trailblazer-option" + "uber" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kms3r6w6pnryysnaqqa9fsn0v73zx1ilds9d1c565n3xdzbyafc"; type = "gem"; }; version = "3.2.0"; }; retriable = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q48hqws2dy1vws9schc0kmina40gy7sn5qsndpsfqdslh65snha"; type = "gem"; }; version = "3.1.2"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; signet = { - dependencies = ["addressable" "faraday" "jwt" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "faraday" + "jwt" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cfxa11wy1nv9slmnzjczkdgld0gqizajsb03rliy53zylwkjzsk"; type = "gem"; }; version = "0.19.0"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nmymd86a0vb39pzj2cwv57avdrl6pl3lf5bsz58q594kqxjkw7f"; type = "gem"; }; version = "1.3.2"; }; timeliness = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gvp9b7yn4pykn794cibylc9ys1lw7fzv7djx1433icxw4y26my3"; type = "gem"; }; version = "0.3.10"; }; timeout = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16mvvsmx90023wrhf8dxc1lpqh0m8alk65shb7xcya6a9gflw7vg"; type = "gem"; }; version = "0.4.1"; }; trailblazer-option = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18s48fndi2kfvrfzmq6rxvjfwad347548yby0341ixz1lhpg3r10"; type = "gem"; }; version = "0.1.2"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; uber = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1p1mm7mngg40x05z52md3mbamkng0zpajbzqjjwmsyw0zw3v9vjv"; type = "gem"; }; version = "0.1.0"; }; websocket-driver = { - dependencies = ["websocket-extensions"]; - groups = ["default"]; - platforms = []; + dependencies = [ "websocket-extensions" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nyh873w4lvahcl8kzbjfca26656d5c6z3md4sbqg5y1gfz0157n"; type = "gem"; }; version = "0.7.6"; }; websocket-extensions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hc2g9qps8lmhibl5baa91b4qx8wqw872rgwagml78ydj8qacsqw"; type = "gem"; }; version = "0.1.5"; }; zeitwerk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mi7b90hvc6nqv37q27df4i2m27yy56yfy2ki5073474a1h9hi89"; type = "gem"; }; diff --git a/pkgs/by-name/pg/pghero/package.nix b/pkgs/by-name/pg/pghero/package.nix index 545e8b36816e1c..5699ea4d33c656 100644 --- a/pkgs/by-name/pg/pghero/package.nix +++ b/pkgs/by-name/pg/pghero/package.nix @@ -1,73 +1,81 @@ -{ lib -, stdenv -, bundlerEnv -, buildPackages -, fetchFromGitHub -, makeBinaryWrapper -, nixosTests -, callPackage +{ + lib, + stdenv, + bundlerEnv, + buildPackages, + fetchFromGitHub, + makeBinaryWrapper, + nixosTests, + callPackage, }: -stdenv.mkDerivation (finalAttrs: -let - # Use bundlerEnvArgs from passthru to allow overriding bundlerEnv arguments. - rubyEnv = bundlerEnv finalAttrs.passthru.bundlerEnvArgs; - # We also need a separate nativeRubyEnv to precompile assets on the build - # host. If possible, reuse existing rubyEnv derivation. - nativeRubyEnv = - if stdenv.buildPlatform.canExecute stdenv.hostPlatform then rubyEnv - else buildPackages.bundlerEnv finalAttrs.passthru.bundlerEnvArgs; +stdenv.mkDerivation ( + finalAttrs: + let + # Use bundlerEnvArgs from passthru to allow overriding bundlerEnv arguments. + rubyEnv = bundlerEnv finalAttrs.passthru.bundlerEnvArgs; + # We also need a separate nativeRubyEnv to precompile assets on the build + # host. If possible, reuse existing rubyEnv derivation. + nativeRubyEnv = + if stdenv.buildPlatform.canExecute stdenv.hostPlatform then + rubyEnv + else + buildPackages.bundlerEnv finalAttrs.passthru.bundlerEnvArgs; - bundlerEnvArgs = { - name = "${finalAttrs.pname}-${finalAttrs.version}-gems"; - gemdir = ./.; - }; -in -{ - pname = "pghero"; - version = "3.6.1"; + bundlerEnvArgs = { + name = "${finalAttrs.pname}-${finalAttrs.version}-gems"; + gemdir = ./.; + }; + in + { + pname = "pghero"; + version = "3.6.1"; - src = fetchFromGitHub { - owner = "pghero"; - repo = "pghero"; - rev = "v${finalAttrs.version}"; - hash = "sha256-kABdQRwV5Y/jB9P8kYVmwmntOK0CF/JJYmaINNv26fA="; - }; + src = fetchFromGitHub { + owner = "pghero"; + repo = "pghero"; + rev = "v${finalAttrs.version}"; + hash = "sha256-kABdQRwV5Y/jB9P8kYVmwmntOK0CF/JJYmaINNv26fA="; + }; - strictDeps = true; - nativeBuildInputs = [ nativeRubyEnv makeBinaryWrapper ]; + strictDeps = true; + nativeBuildInputs = [ + nativeRubyEnv + makeBinaryWrapper + ]; - inherit rubyEnv; + inherit rubyEnv; - buildPhase = '' - runHook preBuild - DATABASE_URL=nulldb:/// RAILS_ENV=production rake assets:precompile - runHook postBuild - ''; + buildPhase = '' + runHook preBuild + DATABASE_URL=nulldb:/// RAILS_ENV=production rake assets:precompile + runHook postBuild + ''; - installPhase = '' - runHook preInstall - mkdir -p -- "$out"/{share,bin} - cp -a -- . "$out"/share/pghero - makeWrapper "$rubyEnv"/bin/puma "$out"/bin/pghero \ - --add-flags -C \ - --add-flags config/puma.rb \ - --chdir "$out"/share/pghero - runHook postInstall - ''; + installPhase = '' + runHook preInstall + mkdir -p -- "$out"/{share,bin} + cp -a -- . "$out"/share/pghero + makeWrapper "$rubyEnv"/bin/puma "$out"/bin/pghero \ + --add-flags -C \ + --add-flags config/puma.rb \ + --chdir "$out"/share/pghero + runHook postInstall + ''; - passthru = { - inherit bundlerEnvArgs; - updateScript = callPackage ./update.nix { }; - tests = { - inherit (nixosTests) pghero; + passthru = { + inherit bundlerEnvArgs; + updateScript = callPackage ./update.nix { }; + tests = { + inherit (nixosTests) pghero; + }; }; - }; - meta = { - homepage = "https://github.com/ankane/pghero"; - description = "Performance dashboard for Postgres"; - mainProgram = "pghero"; - license = lib.licenses.mit; - maintainers = [ lib.maintainers.tie ]; - }; -}) + meta = { + homepage = "https://github.com/ankane/pghero"; + description = "Performance dashboard for Postgres"; + mainProgram = "pghero"; + license = lib.licenses.mit; + maintainers = [ lib.maintainers.tie ]; + }; + } +) diff --git a/pkgs/by-name/pg/pghero/update.nix b/pkgs/by-name/pg/pghero/update.nix index 35edcec7b6af8d..4b85dd8f76a320 100644 --- a/pkgs/by-name/pg/pghero/update.nix +++ b/pkgs/by-name/pg/pghero/update.nix @@ -1,22 +1,25 @@ -{ lib -, writeShellScript -, git -, nix -, bundler -, bundix -, coreutils -, common-updater-scripts +{ + lib, + writeShellScript, + git, + nix, + bundler, + bundix, + coreutils, + common-updater-scripts, }: writeShellScript "update-script" '' set -eu - PATH=${lib.makeBinPath [ - git - nix - bundler - bundix - coreutils - common-updater-scripts - ]} + PATH=${ + lib.makeBinPath [ + git + nix + bundler + bundix + coreutils + common-updater-scripts + ] + } nix() { command nix --extra-experimental-features nix-command "$@" } diff --git a/pkgs/by-name/pg/pgloader/package.nix b/pkgs/by-name/pg/pgloader/package.nix index 59f3eeeaeaa932..1eaca6a9504bb9 100644 --- a/pkgs/by-name/pg/pgloader/package.nix +++ b/pkgs/by-name/pg/pgloader/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, makeWrapper, sbcl, sqlite, freetds, libzip, curl, git, cacert, openssl }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + sbcl, + sqlite, + freetds, + libzip, + curl, + git, + cacert, + openssl, +}: stdenv.mkDerivation rec { pname = "pgloader"; version = "3.6.9"; @@ -8,10 +21,28 @@ stdenv.mkDerivation rec { sha256 = "sha256-pdCcRmoJnrfVnkhbT0WqLrRbCtOEmRgGRsXK+3uByeA="; }; - nativeBuildInputs = [ git makeWrapper ]; - buildInputs = [ sbcl cacert sqlite freetds libzip curl openssl ]; + nativeBuildInputs = [ + git + makeWrapper + ]; + buildInputs = [ + sbcl + cacert + sqlite + freetds + libzip + curl + openssl + ]; - LD_LIBRARY_PATH = lib.makeLibraryPath [ sqlite libzip curl git openssl freetds ]; + LD_LIBRARY_PATH = lib.makeLibraryPath [ + sqlite + libzip + curl + git + openssl + freetds + ]; buildPhase = '' export PATH=$PATH:$out/bin diff --git a/pkgs/by-name/pg/pgmanage/package.nix b/pkgs/by-name/pg/pgmanage/package.nix index 0c435dc04fa414..351214ee023773 100644 --- a/pkgs/by-name/pg/pgmanage/package.nix +++ b/pkgs/by-name/pg/pgmanage/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, openssl, nixosTests } : +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + openssl, + nixosTests, +}: stdenv.mkDerivation rec { pname = "pgmanage"; # The last release 11.0.1 from 2018 fails the NixOS test @@ -7,9 +14,9 @@ stdenv.mkDerivation rec { version = "unstable-2022-05-11"; src = fetchFromGitHub { - owner = "pgManage"; - repo = "pgManage"; - rev = "a028604416be382d6d310bc68b4e7c3cd16020fb"; + owner = "pgManage"; + repo = "pgManage"; + rev = "a028604416be382d6d310bc68b4e7c3cd16020fb"; sha256 = "sha256-ibCzZrqfbio1wBVFKB6S/wdRxnCc7s3IQdtI9txxhaM="; }; @@ -21,7 +28,10 @@ stdenv.mkDerivation rec { ./configure --prefix $out ''; - buildInputs = [ postgresql openssl ]; + buildInputs = [ + postgresql + openssl + ]; passthru.tests.sign-in = nixosTests.pgmanage; diff --git a/pkgs/by-name/pg/pgmetrics/package.nix b/pkgs/by-name/pg/pgmetrics/package.nix index bc5ac22b4f659b..e741b8db6ce70e 100644 --- a/pkgs/by-name/pg/pgmetrics/package.nix +++ b/pkgs/by-name/pg/pgmetrics/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pgmetrics"; @@ -15,7 +19,11 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; meta = with lib; { homepage = "https://pgmetrics.io/"; diff --git a/pkgs/by-name/pg/pgmoneta/package.nix b/pkgs/by-name/pg/pgmoneta/package.nix index bbfb6df67d5bf0..fd5dfbe65a5177 100644 --- a/pkgs/by-name/pg/pgmoneta/package.nix +++ b/pkgs/by-name/pg/pgmoneta/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, bzip2 -, cjson -, cmake -, curl -, docutils -, fetchFromGitHub -, libarchive -, libev -, libgccjit -, libssh -, lz4 -, openssl -, systemd -, zlib -, zstd +{ + lib, + stdenv, + bzip2, + cjson, + cmake, + curl, + docutils, + fetchFromGitHub, + libarchive, + libev, + libgccjit, + libssh, + lz4, + openssl, + systemd, + zlib, + zstd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pg/pgo-client/package.nix b/pkgs/by-name/pg/pgo-client/package.nix index c417eb84f879f0..cce769dee9660f 100644 --- a/pkgs/by-name/pg/pgo-client/package.nix +++ b/pkgs/by-name/pg/pgo-client/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pgo-client"; diff --git a/pkgs/by-name/pg/pgpdump/package.nix b/pkgs/by-name/pg/pgpdump/package.nix index 5a9b0d276e0c60..77eaec1928cc3e 100644 --- a/pkgs/by-name/pg/pgpdump/package.nix +++ b/pkgs/by-name/pg/pgpdump/package.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchFromGitHub -, supportCompressedPackets ? true, zlib, bzip2 +{ + lib, + stdenv, + fetchFromGitHub, + supportCompressedPackets ? true, + zlib, + bzip2, }: stdenv.mkDerivation rec { @@ -13,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-JKedgHCTDnvLyLR3nGl4XFAaxXDU1TgHrxPMlRFwtBo="; }; - buildInputs = lib.optionals supportCompressedPackets [ zlib bzip2 ]; + buildInputs = lib.optionals supportCompressedPackets [ + zlib + bzip2 + ]; meta = with lib; { description = "PGP packet visualizer"; diff --git a/pkgs/by-name/pg/pgpkeyserver-lite/package.nix b/pkgs/by-name/pg/pgpkeyserver-lite/package.nix index 6568409b11aa37..f15cb0c9b29e6d 100644 --- a/pkgs/by-name/pg/pgpkeyserver-lite/package.nix +++ b/pkgs/by-name/pg/pgpkeyserver-lite/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "pgpkeyserver-lite"; diff --git a/pkgs/by-name/pg/pgrok/package.nix b/pkgs/by-name/pg/pgrok/package.nix index 5da13036fe6878..360aeea5561923 100644 --- a/pkgs/by-name/pg/pgrok/package.nix +++ b/pkgs/by-name/pg/pgrok/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script -, nodejs -, pnpm +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + nodejs, + pnpm, }: let @@ -20,7 +21,10 @@ in buildGoModule { inherit pname version src; - outputs = [ "out" "server" ]; + outputs = [ + "out" + "server" + ]; nativeBuildInputs = [ nodejs diff --git a/pkgs/by-name/pg/pgroll/package.nix b/pkgs/by-name/pg/pgroll/package.nix index 7c05b3150db56c..0adbe0481b9864 100644 --- a/pkgs/by-name/pg/pgroll/package.nix +++ b/pkgs/by-name/pg/pgroll/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/pg/pgtop/package.nix b/pkgs/by-name/pg/pgtop/package.nix index 066e07fd484a33..dc7414f1949f20 100644 --- a/pkgs/by-name/pg/pgtop/package.nix +++ b/pkgs/by-name/pg/pgtop/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, perlPackages, fetchFromGitHub, shortenPerlShebang }: +{ + lib, + stdenv, + perlPackages, + fetchFromGitHub, + shortenPerlShebang, +}: perlPackages.buildPerlPackage rec { pname = "pgtop"; @@ -13,7 +19,13 @@ perlPackages.buildPerlPackage rec { outputs = [ "out" ]; - buildInputs = with perlPackages; [ DBI DBDPg TermReadKey JSON LWP ]; + buildInputs = with perlPackages; [ + DBI + DBDPg + TermReadKey + JSON + LWP + ]; nativeBuildInputs = lib.optional stdenv.hostPlatform.isDarwin shortenPerlShebang; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' diff --git a/pkgs/by-name/pg/pgweb/package.nix b/pkgs/by-name/pg/pgweb/package.nix index ed539899ba3d4f..9de3a6cd89edf4 100644 --- a/pkgs/by-name/pg/pgweb/package.nix +++ b/pkgs/by-name/pg/pgweb/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, pgweb +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + pgweb, }: buildGoModule rec { @@ -23,7 +24,10 @@ buildGoModule rec { vendorHash = "sha256-Jpvf6cST3kBvYzCQLoJ1fijUC/hP1ouptd2bQZ1J/Lo="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; checkFlags = let @@ -32,13 +36,16 @@ buildGoModule rec { "TestParseOptions" ]; in - [ "-skip" "${builtins.concatStringsSep "|" skippedTests}" ]; + [ + "-skip" + "${builtins.concatStringsSep "|" skippedTests}" + ]; - passthru.tests.version = testers.testVersion { - version = "v${version}"; - package = pgweb; - command = "pgweb --version"; - }; + passthru.tests.version = testers.testVersion { + version = "v${version}"; + package = pgweb; + command = "pgweb --version"; + }; meta = with lib; { changelog = "https://github.com/sosedoff/pgweb/releases/tag/v${version}"; @@ -50,6 +57,9 @@ buildGoModule rec { homepage = "https://sosedoff.github.io/pgweb/"; license = licenses.mit; mainProgram = "pgweb"; - maintainers = with maintainers; [ zupo luisnquin ]; + maintainers = with maintainers; [ + zupo + luisnquin + ]; }; } diff --git a/pkgs/by-name/ph/phantomsocks/package.nix b/pkgs/by-name/ph/phantomsocks/package.nix index 1a720efb9381b4..9f93d06139be9b 100644 --- a/pkgs/by-name/ph/phantomsocks/package.nix +++ b/pkgs/by-name/ph/phantomsocks/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, stdenv -, libpcap +{ + lib, + buildGoModule, + fetchFromGitHub, + stdenv, + libpcap, # Cann't be build with both pcap and rawsocket tags -, withPcap ? (!stdenv.hostPlatform.isLinux && !withRawsocket) -, withRawsocket ? (stdenv.hostPlatform.isLinux && !withPcap) + withPcap ? (!stdenv.hostPlatform.isLinux && !withRawsocket), + withRawsocket ? (stdenv.hostPlatform.isLinux && !withPcap), }: buildGoModule rec { @@ -26,10 +27,9 @@ buildGoModule rec { "-w" ]; buildInputs = lib.optional withPcap libpcap; - tags = lib.optional withPcap "pcap" - ++ lib.optional withRawsocket "rawsocket"; + tags = lib.optional withPcap "pcap" ++ lib.optional withRawsocket "rawsocket"; - meta = with lib;{ + meta = with lib; { homepage = "https://github.com/macronut/phantomsocks"; description = "Cross-platform proxy client/server for Linux/Windows/macOS"; longDescription = '' diff --git a/pkgs/by-name/ph/pharo/package.nix b/pkgs/by-name/ph/pharo/package.nix index f05cf275252228..fd0602681c2296 100644 --- a/pkgs/by-name/ph/pharo/package.nix +++ b/pkgs/by-name/ph/pharo/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, cairo -, cmake -, fetchzip -, freetype -, libffi -, libgit2 -, libpng -, libuuid -, makeBinaryWrapper -, openssl -, pixman -, SDL2 +{ + lib, + stdenv, + cairo, + cmake, + fetchzip, + freetype, + libffi, + libgit2, + libpng, + libuuid, + makeBinaryWrapper, + openssl, + pixman, + SDL2, }: stdenv.mkDerivation (finalAttrs: { @@ -66,16 +67,21 @@ stdenv.mkDerivation (finalAttrs: { runHook postInstall ''; - preFixup = let - libPath = lib.makeLibraryPath (finalAttrs.buildInputs ++ [ - stdenv.cc.cc - "$out" - ]); - in '' - patchelf --allowed-rpath-prefixes "$NIX_STORE" --shrink-rpath "$out/bin/pharo" - ln -s "${libgit2}/lib/libgit2.so" $out/lib/libgit2.so.1.1 - wrapProgram "$out/bin/pharo" --argv0 $out/bin/pharo --prefix LD_LIBRARY_PATH ":" "${libPath}" - ''; + preFixup = + let + libPath = lib.makeLibraryPath ( + finalAttrs.buildInputs + ++ [ + stdenv.cc.cc + "$out" + ] + ); + in + '' + patchelf --allowed-rpath-prefixes "$NIX_STORE" --shrink-rpath "$out/bin/pharo" + ln -s "${libgit2}/lib/libgit2.so" $out/lib/libgit2.so.1.1 + wrapProgram "$out/bin/pharo" --argv0 $out/bin/pharo --prefix LD_LIBRARY_PATH ":" "${libPath}" + ''; meta = { description = "Clean and innovative Smalltalk-inspired environment"; diff --git a/pkgs/by-name/ph/phash/package.nix b/pkgs/by-name/ph/phash/package.nix index 8f40cd0d9a71c9..8f692c6837ad62 100644 --- a/pkgs/by-name/ph/phash/package.nix +++ b/pkgs/by-name/ph/phash/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, pkg-config, cimg, imagemagick }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + cimg, + imagemagick, +}: stdenv.mkDerivation rec { pname = "pHash"; @@ -12,7 +20,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - configureFlags = ["--enable-video-hash=no" "--enable-audio-hash=no"]; + configureFlags = [ + "--enable-video-hash=no" + "--enable-audio-hash=no" + ]; postInstall = '' cp ${cimg}/include/CImg.h $out/include/ ''; @@ -34,7 +45,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Compute the perceptual hash of an image"; license = licenses.gpl3; - maintainers = [maintainers.imalsogreg]; + maintainers = [ maintainers.imalsogreg ]; platforms = platforms.all; homepage = "http://www.phash.org"; downloadPage = "https://github.com/clearscene/pHash"; diff --git a/pkgs/by-name/ph/phd2/package.nix b/pkgs/by-name/ph/phd2/package.nix index b463a2845bdccf..96bf387061867e 100644 --- a/pkgs/by-name/ph/phd2/package.nix +++ b/pkgs/by-name/ph/phd2/package.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, cmake, gtk3, wxGTK32 -, curl, gettext, glib, indi-full, libnova, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + gtk3, + wxGTK32, + curl, + gettext, + glib, + indi-full, + libnova, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "phd2"; diff --git a/pkgs/by-name/ph/phinger-cursors/package.nix b/pkgs/by-name/ph/phinger-cursors/package.nix index 03ec5d53bc9271..29a310d064cbad 100644 --- a/pkgs/by-name/ph/phinger-cursors/package.nix +++ b/pkgs/by-name/ph/phinger-cursors/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "phinger-cursors"; diff --git a/pkgs/by-name/ph/phockup/package.nix b/pkgs/by-name/ph/phockup/package.nix index 8df388e1f64fd3..c749974ced485e 100644 --- a/pkgs/by-name/ph/phockup/package.nix +++ b/pkgs/by-name/ph/phockup/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, python3, fetchFromGitHub, exiftool, makeWrapper }: +{ + lib, + stdenv, + python3, + fetchFromGitHub, + exiftool, + makeWrapper, +}: let pythonEnv = python3.withPackages (p: with p; [ tqdm ]); in diff --git a/pkgs/by-name/ph/phodav/package.nix b/pkgs/by-name/ph/phodav/package.nix index ac84016c4abc75..9d3a5d1c47f75b 100644 --- a/pkgs/by-name/ph/phodav/package.nix +++ b/pkgs/by-name/ph/phodav/package.nix @@ -1,19 +1,24 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, libsoup_3 -, libxml2 -, meson -, ninja -, gnome +{ + stdenv, + lib, + fetchurl, + pkg-config, + libsoup_3, + libxml2, + meson, + ninja, + gnome, }: stdenv.mkDerivation rec { pname = "phodav"; version = "3.0"; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; src = fetchurl { url = "mirror://gnome/sources/phodav/${version}/phodav-${version}.tar.xz"; diff --git a/pkgs/by-name/ph/phoronix-test-suite/package.nix b/pkgs/by-name/ph/phoronix-test-suite/package.nix index 8c7453a4fceadd..f74401c3ed8eda 100644 --- a/pkgs/by-name/ph/phoronix-test-suite/package.nix +++ b/pkgs/by-name/ph/phoronix-test-suite/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, php, which, makeWrapper, gnumake, gcc, callPackage }: +{ + lib, + stdenv, + fetchurl, + php, + which, + makeWrapper, + gnumake, + gcc, + callPackage, +}: stdenv.mkDerivation rec { pname = "phoronix-test-suite"; @@ -10,7 +20,10 @@ stdenv.mkDerivation rec { }; buildInputs = [ php ]; - nativeBuildInputs = [ which makeWrapper ]; + nativeBuildInputs = [ + which + makeWrapper + ]; installPhase = '' runHook preInstall @@ -18,7 +31,12 @@ stdenv.mkDerivation rec { ./install-sh $out wrapProgram $out/bin/phoronix-test-suite \ --set PHP_BIN ${php}/bin/php \ - --prefix PATH : ${lib.makeBinPath [ gnumake gcc ]} + --prefix PATH : ${ + lib.makeBinPath [ + gnumake + gcc + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/ph/phoronix-test-suite/tests.nix b/pkgs/by-name/ph/phoronix-test-suite/tests.nix index 85249c1242ff1b..0a0970123eced1 100644 --- a/pkgs/by-name/ph/phoronix-test-suite/tests.nix +++ b/pkgs/by-name/ph/phoronix-test-suite/tests.nix @@ -4,17 +4,16 @@ let inherit (phoronix-test-suite) pname version; in -runCommand "${pname}-tests" { meta.timeout = 60; } - '' - # automatic initial setup to prevent interactive questions - ${phoronix-test-suite}/bin/phoronix-test-suite enterprise-setup >/dev/null - # get version of installed program and compare with package version - if [[ `${phoronix-test-suite}/bin/phoronix-test-suite version` != *"${version}"* ]]; then - echo "Error: program version does not match package version" - exit 1 - fi - # run dummy command - ${phoronix-test-suite}/bin/phoronix-test-suite dummy_module.dummy-command >/dev/null - # needed for Nix to register the command as successful - touch $out - '' +runCommand "${pname}-tests" { meta.timeout = 60; } '' + # automatic initial setup to prevent interactive questions + ${phoronix-test-suite}/bin/phoronix-test-suite enterprise-setup >/dev/null + # get version of installed program and compare with package version + if [[ `${phoronix-test-suite}/bin/phoronix-test-suite version` != *"${version}"* ]]; then + echo "Error: program version does not match package version" + exit 1 + fi + # run dummy command + ${phoronix-test-suite}/bin/phoronix-test-suite dummy_module.dummy-command >/dev/null + # needed for Nix to register the command as successful + touch $out +'' diff --git a/pkgs/by-name/ph/photocollage/package.nix b/pkgs/by-name/ph/photocollage/package.nix index 46c6bedd771041..03894fb27b0ad8 100644 --- a/pkgs/by-name/ph/photocollage/package.nix +++ b/pkgs/by-name/ph/photocollage/package.nix @@ -1,10 +1,11 @@ -{ lib -, python3Packages -, fetchFromGitHub -, gettext -, gdk-pixbuf -, gobject-introspection -, wrapGAppsHook3 +{ + lib, + python3Packages, + fetchFromGitHub, + gettext, + gdk-pixbuf, + gobject-introspection, + wrapGAppsHook3, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ph/photofield/package.nix b/pkgs/by-name/ph/photofield/package.nix index d26788d07a03c1..1674ec28013e75 100644 --- a/pkgs/by-name/ph/photofield/package.nix +++ b/pkgs/by-name/ph/photofield/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, buildGo122Module -, buildNpmPackage -, makeWrapper -, exiftool -, ffmpeg -, testers -, photofield -, nix-update-script +{ + lib, + fetchFromGitHub, + buildGo122Module, + buildNpmPackage, + makeWrapper, + exiftool, + ffmpeg, + testers, + photofield, + nix-update-script, }: let @@ -60,7 +61,12 @@ buildGo122Module { postInstall = '' wrapProgram $out/bin/photofield \ - --prefix PATH : "${lib.makeBinPath [exiftool ffmpeg]}" + --prefix PATH : "${ + lib.makeBinPath [ + exiftool + ffmpeg + ] + }" ''; passthru = { diff --git a/pkgs/by-name/ph/photon-rss/package.nix b/pkgs/by-name/ph/photon-rss/package.nix index 1717327d865c15..cb613b044a8130 100644 --- a/pkgs/by-name/ph/photon-rss/package.nix +++ b/pkgs/by-name/ph/photon-rss/package.nix @@ -1,4 +1,9 @@ -{ buildGoModule, fetchFromSourcehut, lib, xorg }: +{ + buildGoModule, + fetchFromSourcehut, + lib, + xorg, +}: buildGoModule rec { pname = "photon"; diff --git a/pkgs/by-name/ph/photon/package.nix b/pkgs/by-name/ph/photon/package.nix index 5a60e145aeda74..8be4fbe6b242b0 100644 --- a/pkgs/by-name/ph/photon/package.nix +++ b/pkgs/by-name/ph/photon/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "photon"; @@ -15,7 +19,11 @@ python3Packages.buildPythonApplication rec { dontBuild = true; doCheck = false; - propagatedBuildInputs = with python3Packages; [ requests urllib3 tld ]; + propagatedBuildInputs = with python3Packages; [ + requests + urllib3 + tld + ]; installPhase = '' mkdir -p "$out"/{bin,share/photon} diff --git a/pkgs/by-name/ph/photonvision/package.nix b/pkgs/by-name/ph/photonvision/package.nix index 09330c9c442b5f..b5953459d42236 100644 --- a/pkgs/by-name/ph/photonvision/package.nix +++ b/pkgs/by-name/ph/photonvision/package.nix @@ -1,27 +1,30 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, temurin-jre-bin-11 -, bash -, suitesparse -, nixosTests +{ + lib, + stdenv, + fetchurl, + makeWrapper, + temurin-jre-bin-11, + bash, + suitesparse, + nixosTests, }: stdenv.mkDerivation rec { pname = "photonvision"; version = "2024.3.1"; - src = { - "x86_64-linux" = fetchurl { - url = "https://github.com/PhotonVision/photonvision/releases/download/v${version}/photonvision-v${version}-linuxx64.jar"; - hash = "sha256-t9drkGFA3IurZqWAkzEaONVJkp5JHMEFBBW50r+SD68="; - }; - "aarch64-linux" = fetchurl { - url = "https://github.com/PhotonVision/photonvision/releases/download/v${version}/photonvision-v${version}-linuxarm64.jar"; - hash = "sha256-ninCVxse0x6lBA2NL3kwMeuHAeNzSa9rdP2dnmMNFgc="; - }; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + { + "x86_64-linux" = fetchurl { + url = "https://github.com/PhotonVision/photonvision/releases/download/v${version}/photonvision-v${version}-linuxx64.jar"; + hash = "sha256-t9drkGFA3IurZqWAkzEaONVJkp5JHMEFBBW50r+SD68="; + }; + "aarch64-linux" = fetchurl { + url = "https://github.com/PhotonVision/photonvision/releases/download/v${version}/photonvision-v${version}-linuxarm64.jar"; + hash = "sha256-ninCVxse0x6lBA2NL3kwMeuHAeNzSa9rdP2dnmMNFgc="; + }; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); dontUnpack = true; @@ -33,8 +36,18 @@ stdenv.mkDerivation rec { install -D $src $out/lib/photonvision.jar makeWrapper ${temurin-jre-bin-11}/bin/java $out/bin/photonvision \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ stdenv.cc.cc suitesparse ]} \ - --prefix PATH : ${lib.makeBinPath [ temurin-jre-bin-11 bash.out ]} \ + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + stdenv.cc.cc + suitesparse + ] + } \ + --prefix PATH : ${ + lib.makeBinPath [ + temurin-jre-bin-11 + bash.out + ] + } \ --add-flags "-jar $out/lib/photonvision.jar" runHook postInstall @@ -50,6 +63,9 @@ stdenv.mkDerivation rec { license = licenses.gpl3; maintainers = with maintainers; [ max-niederman ]; mainProgram = "photonvision"; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; }; } diff --git a/pkgs/by-name/ph/photoprism/backend.nix b/pkgs/by-name/ph/photoprism/backend.nix index a996e966dfc0b8..898171820c7dd3 100644 --- a/pkgs/by-name/ph/photoprism/backend.nix +++ b/pkgs/by-name/ph/photoprism/backend.nix @@ -1,6 +1,12 @@ -{ lib, buildGoModule, coreutils, libtensorflow, src, version -, pkg-config -, vips +{ + lib, + buildGoModule, + coreutils, + libtensorflow, + src, + version, + pkg-config, + vips, }: buildGoModule rec { diff --git a/pkgs/by-name/ph/photoprism/frontend.nix b/pkgs/by-name/ph/photoprism/frontend.nix index 84449f758d2409..c297335d103a1f 100644 --- a/pkgs/by-name/ph/photoprism/frontend.nix +++ b/pkgs/by-name/ph/photoprism/frontend.nix @@ -1,4 +1,9 @@ -{ lib, buildNpmPackage, src, version }: +{ + lib, + buildNpmPackage, + src, + version, +}: buildNpmPackage { inherit src version; diff --git a/pkgs/by-name/ph/photoprism/libtensorflow.nix b/pkgs/by-name/ph/photoprism/libtensorflow.nix index db1be8d95e24b7..f8dcf84d061772 100644 --- a/pkgs/by-name/ph/photoprism/libtensorflow.nix +++ b/pkgs/by-name/ph/photoprism/libtensorflow.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ... }: +{ + lib, + stdenv, + fetchurl, + ... +}: let inherit (stdenv.hostPlatform) system; in @@ -10,17 +15,21 @@ stdenv.mkDerivation rec { # Photoprism-packaged libtensorflow tarball (with pre-built libs for both arm64 and amd64) # We need this specific version because of https://github.com/photoprism/photoprism/issues/222 (fetchurl { - sha256 = { - x86_64-linux = "sha256-bZAC3PJxqcjuGM4RcNtzYtkg3FD3SrO5beDsPoKenzc="; - aarch64-linux = "sha256-qnj4vhSWgrk8SIjzIH1/4waMxMsxMUvqdYZPaSaUJRk="; - }.${system}; + sha256 = + { + x86_64-linux = "sha256-bZAC3PJxqcjuGM4RcNtzYtkg3FD3SrO5beDsPoKenzc="; + aarch64-linux = "sha256-qnj4vhSWgrk8SIjzIH1/4waMxMsxMUvqdYZPaSaUJRk="; + } + .${system}; url = let - systemName = { - x86_64-linux = "amd64"; - aarch64-linux = "arm64"; - }.${system}; + systemName = + { + x86_64-linux = "amd64"; + aarch64-linux = "arm64"; + } + .${system}; in "https://dl.photoprism.app/tensorflow/${systemName}/libtensorflow-${systemName}-${version}.tar.gz"; }) @@ -53,7 +62,10 @@ stdenv.mkDerivation rec { # Patch library to use our libc, libstdc++ and others patchPhase = let - rpath = lib.makeLibraryPath [ stdenv.cc.libc stdenv.cc.cc ]; + rpath = lib.makeLibraryPath [ + stdenv.cc.libc + stdenv.cc.cc + ]; in '' chmod -R +w lib @@ -82,7 +94,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://dl.photoprism.app/tensorflow/"; description = "Libtensorflow version for usage with photoprism backend"; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; license = licenses.asl20; maintainers = with maintainers; [ benesim ]; }; diff --git a/pkgs/by-name/ph/photoprism/package.nix b/pkgs/by-name/ph/photoprism/package.nix index 61076419ee15d0..14c8b832876be7 100644 --- a/pkgs/by-name/ph/photoprism/package.nix +++ b/pkgs/by-name/ph/photoprism/package.nix @@ -1,7 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, fetchzip, darktable, rawtherapee, ffmpeg, libheif, exiftool, imagemagick, makeWrapper, testers -, callPackage -, nixosTests -, librsvg }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchzip, + darktable, + rawtherapee, + ffmpeg, + libheif, + exiftool, + imagemagick, + makeWrapper, + testers, + callPackage, + nixosTests, + librsvg, +}: let version = "240711-2197af848"; @@ -18,7 +31,8 @@ let backend = callPackage ./backend.nix { inherit libtensorflow src version; }; frontend = callPackage ./frontend.nix { inherit src version; }; - fetchModel = { name, hash }: + fetchModel = + { name, hash }: fetchzip { inherit hash; url = "https://dl.photoprism.org/tensorflow/${name}.zip"; diff --git a/pkgs/by-name/ph/phrase-cli/package.nix b/pkgs/by-name/ph/phrase-cli/package.nix index 0a52c3366d3783..d15a43ba38978f 100644 --- a/pkgs/by-name/ph/phrase-cli/package.nix +++ b/pkgs/by-name/ph/phrase-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "phrase-cli"; diff --git a/pkgs/by-name/ph/phrasendrescher/package.nix b/pkgs/by-name/ph/phrasendrescher/package.nix index 2f6017fd10ec49..8cb3d0cf91aad4 100644 --- a/pkgs/by-name/ph/phrasendrescher/package.nix +++ b/pkgs/by-name/ph/phrasendrescher/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, openssl, libssh2, gpgme }: +{ + lib, + stdenv, + fetchurl, + openssl, + libssh2, + gpgme, +}: stdenv.mkDerivation rec { pname = "phrasendrescher"; @@ -14,7 +21,11 @@ stdenv.mkDerivation rec { --replace 'SSL_LIB="ssl"' 'SSL_LIB="crypto"' ''; - buildInputs = [ openssl libssh2 gpgme ]; + buildInputs = [ + openssl + libssh2 + gpgme + ]; configureFlags = [ "--with-plugins" ]; diff --git a/pkgs/by-name/ph/phylactery/package.nix b/pkgs/by-name/ph/phylactery/package.nix index 43c6032f101fcf..4f922cab202bf0 100644 --- a/pkgs/by-name/ph/phylactery/package.nix +++ b/pkgs/by-name/ph/phylactery/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchzip, nixosTests }: +{ + lib, + buildGoModule, + fetchzip, + nixosTests, +}: buildGoModule rec { pname = "phylactery"; @@ -11,7 +16,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests.phylactery = nixosTests.phylactery; diff --git a/pkgs/by-name/ph/physac/package.nix b/pkgs/by-name/ph/physac/package.nix index 5d6ff694e5abf1..bc81fb2698db46 100644 --- a/pkgs/by-name/ph/physac/package.nix +++ b/pkgs/by-name/ph/physac/package.nix @@ -1,7 +1,7 @@ { stdenvNoCC, fetchFromGitHub, - lib + lib, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ph/physlock/package.nix b/pkgs/by-name/ph/physlock/package.nix index 993ec8447c3a4d..fbd7d5d908b6bf 100644 --- a/pkgs/by-name/ph/physlock/package.nix +++ b/pkgs/by-name/ph/physlock/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pam, systemd }: +{ + lib, + stdenv, + fetchFromGitHub, + pam, + systemd, +}: stdenv.mkDerivation rec { version = "13"; @@ -10,14 +16,20 @@ stdenv.mkDerivation rec { sha256 = "1mz4xxjip5ldiw9jgfq9zvqb6w10bcjfx6939w1appqg8f521a7s"; }; - buildInputs = [ pam systemd ]; + buildInputs = [ + pam + systemd + ]; preConfigure = '' substituteInPlace Makefile \ --replace "-m 4755 -o root -g root" "" ''; - makeFlags = [ "PREFIX=$(out)" "SESSION=systemd" ]; + makeFlags = [ + "PREFIX=$(out)" + "SESSION=systemd" + ]; meta = with lib; { description = "Secure suspend/hibernate-friendly alternative to `vlock -an`"; diff --git a/pkgs/by-name/pi/pianobar/package.nix b/pkgs/by-name/pi/pianobar/package.nix index b1a4825a88c81b..58a93296f57da7 100644 --- a/pkgs/by-name/pi/pianobar/package.nix +++ b/pkgs/by-name/pi/pianobar/package.nix @@ -1,4 +1,14 @@ -{ fetchFromGitHub, lib, stdenv, pkg-config, libao, json_c, libgcrypt, ffmpeg, curl }: +{ + fetchFromGitHub, + lib, + stdenv, + pkg-config, + libao, + json_c, + libgcrypt, + ffmpeg, + curl, +}: stdenv.mkDerivation rec { pname = "pianobar"; @@ -13,7 +23,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - libao json_c libgcrypt ffmpeg curl + libao + json_c + libgcrypt + ffmpeg + curl ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/pi/pianotrans/package.nix b/pkgs/by-name/pi/pianotrans/package.nix index d36fffb0c990e0..3d73cbf97e6c9e 100644 --- a/pkgs/by-name/pi/pianotrans/package.nix +++ b/pkgs/by-name/pi/pianotrans/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3 -, ffmpeg +{ + lib, + fetchFromGitHub, + python3, + ffmpeg, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pi/picard-tools/package.nix b/pkgs/by-name/pi/picard-tools/package.nix index 5435503e7f140a..a73167fe8a941a 100644 --- a/pkgs/by-name/pi/picard-tools/package.nix +++ b/pkgs/by-name/pi/picard-tools/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, jre, makeWrapper}: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "picard-tools"; diff --git a/pkgs/by-name/pi/picat/package.nix b/pkgs/by-name/pi/picat/package.nix index 04c80884670dd8..7aeeb75be2e7f7 100644 --- a/pkgs/by-name/pi/picat/package.nix +++ b/pkgs/by-name/pi/picat/package.nix @@ -1,13 +1,20 @@ -{ lib, stdenv, fetchurl, zlib }: +{ + lib, + stdenv, + fetchurl, + zlib, +}: let - ARCH = { - x86_64-linux = "linux64"; - aarch64-linux = "linux64"; - x86_64-cygwin = "cygwin64"; - x86_64-darwin = "mac64"; - aarch64-darwin = "mac64"; - }."${stdenv.hostPlatform.system}" or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + ARCH = + { + x86_64-linux = "linux64"; + aarch64-linux = "linux64"; + x86_64-cygwin = "cygwin64"; + x86_64-darwin = "mac64"; + aarch64-darwin = "mac64"; + } + ."${stdenv.hostPlatform.system}" or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); in stdenv.mkDerivation { pname = "picat"; @@ -39,15 +46,18 @@ stdenv.mkDerivation { meta = with lib; { description = "Logic-based programming language"; mainProgram = "picat"; - homepage = "http://picat-lang.org/"; - license = licenses.mpl20; - platforms = [ + homepage = "http://picat-lang.org/"; + license = licenses.mpl20; + platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-cygwin" "x86_64-darwin" "aarch64-darwin" ]; - maintainers = with maintainers; [ earldouglas thoughtpolice ]; + maintainers = with maintainers; [ + earldouglas + thoughtpolice + ]; }; } diff --git a/pkgs/by-name/pi/pick/package.nix b/pkgs/by-name/pi/pick/package.nix index cee77d3a158805..307cf5f58509e9 100644 --- a/pkgs/by-name/pi/pick/package.nix +++ b/pkgs/by-name/pi/pick/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { pname = "pick"; diff --git a/pkgs/by-name/pi/pico-sdk/package.nix b/pkgs/by-name/pi/pico-sdk/package.nix index 259e47426b766b..28a1f2ba6d43ac 100644 --- a/pkgs/by-name/pi/pico-sdk/package.nix +++ b/pkgs/by-name/pi/pico-sdk/package.nix @@ -21,10 +21,11 @@ stdenv.mkDerivation (finalAttrs: { repo = "pico-sdk"; rev = finalAttrs.version; fetchSubmodules = withSubmodules; - hash = if (withSubmodules) then - "sha256-fVSpBVmjeP5pwkSPhhSCfBaEr/FEtA82mQOe/cHFh0A=" - else - "sha256-d6mEjuG8S5jvJS4g8e90gFII3sEqUVlT2fgd9M9LUkA="; + hash = + if (withSubmodules) then + "sha256-fVSpBVmjeP5pwkSPhhSCfBaEr/FEtA82mQOe/cHFh0A=" + else + "sha256-d6mEjuG8S5jvJS4g8e90gFII3sEqUVlT2fgd9M9LUkA="; }; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/by-name/pi/picoc/package.nix b/pkgs/by-name/pi/picoc/package.nix index eaf08de7b99485..24e6fedc9bba46 100644 --- a/pkgs/by-name/pi/picoc/package.nix +++ b/pkgs/by-name/pi/picoc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, readline }: +{ + lib, + stdenv, + fetchFromGitLab, + readline, +}: stdenv.mkDerivation { pname = "picoc"; @@ -15,9 +20,11 @@ stdenv.mkDerivation { makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-Wno-error=implicit-function-declaration" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-Wno-error=implicit-function-declaration" + ] + ); enableParallelBuilding = true; diff --git a/pkgs/by-name/pi/picolisp/package.nix b/pkgs/by-name/pi/picolisp/package.nix index c751746ec645f0..d211fd3afcb6d1 100644 --- a/pkgs/by-name/pi/picolisp/package.nix +++ b/pkgs/by-name/pi/picolisp/package.nix @@ -8,7 +8,7 @@ openssl, pkg-config, readline, - stdenv + stdenv, }: stdenv.mkDerivation { @@ -20,7 +20,14 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ clang libffi llvm openssl pkg-config readline ]; + buildInputs = [ + clang + libffi + llvm + openssl + pkg-config + readline + ]; sourceRoot = ''pil21''; buildPhase = '' cd src @@ -46,4 +53,3 @@ stdenv.mkDerivation { platforms = platforms.all; }; } - diff --git a/pkgs/by-name/pi/picoloop/package.nix b/pkgs/by-name/pi/picoloop/package.nix index cc9d0646d9879c..64165d9d06c40d 100644 --- a/pkgs/by-name/pi/picoloop/package.nix +++ b/pkgs/by-name/pi/picoloop/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, libpulseaudio, SDL2, SDL2_image, SDL2_ttf, alsa-lib, libjack2 }: +{ + lib, + stdenv, + fetchFromGitHub, + libpulseaudio, + SDL2, + SDL2_image, + SDL2_ttf, + alsa-lib, + libjack2, +}: stdenv.mkDerivation rec { pname = "picoloop"; diff --git a/pkgs/by-name/pi/picoprobe-udev-rules/package.nix b/pkgs/by-name/pi/picoprobe-udev-rules/package.nix index 4a651bf473e5b7..4f4c16a5fd1f29 100644 --- a/pkgs/by-name/pi/picoprobe-udev-rules/package.nix +++ b/pkgs/by-name/pi/picoprobe-udev-rules/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: ## Usage # In NixOS, simply add this package to services.udev.packages: diff --git a/pkgs/by-name/pi/picosat/package.nix b/pkgs/by-name/pi/picosat/package.nix index 23fc2776ba8137..812e5abaef75bc 100644 --- a/pkgs/by-name/pi/picosat/package.nix +++ b/pkgs/by-name/pi/picosat/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "picosat"; @@ -19,26 +23,28 @@ stdenv.mkDerivation rec { configurePhase = "./configure.sh --shared --trace"; - makeFlags = lib.optional stdenv.hostPlatform.isDarwin - "SONAME=-Wl,-install_name,$(out)/lib/libpicosat.so"; + makeFlags = lib.optional stdenv.hostPlatform.isDarwin "SONAME=-Wl,-install_name,$(out)/lib/libpicosat.so"; installPhase = '' - mkdir -p $out/bin $out/lib $out/share $out/include/picosat - cp picomus picomcs picosat picogcnf "$out"/bin + mkdir -p $out/bin $out/lib $out/share $out/include/picosat + cp picomus picomcs picosat picogcnf "$out"/bin - cp VERSION "$out"/share/picosat.version - cp picosat.o "$out"/lib - cp libpicosat.a "$out"/lib - cp libpicosat.so "$out"/lib + cp VERSION "$out"/share/picosat.version + cp picosat.o "$out"/lib + cp libpicosat.a "$out"/lib + cp libpicosat.so "$out"/lib - cp picosat.h "$out"/include/picosat + cp picosat.h "$out"/include/picosat ''; meta = { description = "SAT solver with proof and core support"; - homepage = "https://fmv.jku.at/picosat/"; - license = lib.licenses.mit; - platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ roconnor thoughtpolice ]; + homepage = "https://fmv.jku.at/picosat/"; + license = lib.licenses.mit; + platforms = lib.platforms.unix; + maintainers = with lib.maintainers; [ + roconnor + thoughtpolice + ]; }; } diff --git a/pkgs/by-name/pi/picoscope/package.nix b/pkgs/by-name/pi/picoscope/package.nix index eef60df059f898..65e51ef983cb42 100644 --- a/pkgs/by-name/pi/picoscope/package.nix +++ b/pkgs/by-name/pi/picoscope/package.nix @@ -1,18 +1,31 @@ -{ stdenv, lib, fetchurl, dpkg, makeWrapper , mono, gtk-sharp-3_0 -, glib, libusb1 , zlib, gtk3-x11, callPackage, writeTextDir -, scopes ? [ - "picocv" - "ps2000" - "ps2000a" - "ps3000" - "ps3000a" - "ps4000" - "ps4000a" - "ps5000" - "ps5000a" - "ps6000" - "ps6000a" -] }: +{ + stdenv, + lib, + fetchurl, + dpkg, + makeWrapper, + mono, + gtk-sharp-3_0, + glib, + libusb1, + zlib, + gtk3-x11, + callPackage, + writeTextDir, + scopes ? [ + "picocv" + "ps2000" + "ps2000a" + "ps3000" + "ps3000a" + "ps4000" + "ps4000a" + "ps5000" + "ps5000a" + "ps6000" + "ps6000a" + ], +}: let shared_meta = lib: { @@ -22,12 +35,22 @@ let license = lib.licenses.unfree; }; - libpicoipp = callPackage ({ stdenv, lib, fetchurl, autoPatchelfHook, dpkg }: + libpicoipp = callPackage ( + { + stdenv, + lib, + fetchurl, + autoPatchelfHook, + dpkg, + }: stdenv.mkDerivation rec { pname = "libpicoipp"; inherit (sources.libpicoipp) version; src = fetchurl { inherit (sources.libpicoipp) url sha256; }; - nativeBuildInputs = [ dpkg autoPatchelfHook ]; + nativeBuildInputs = [ + dpkg + autoPatchelfHook + ]; buildInputs = [ (lib.getLib stdenv.cc.cc) ]; installPhase = '' @@ -41,15 +64,21 @@ let sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; description = "library for picotech oscilloscope software"; }; - }) { }; + } + ) { }; # If we don't have a platform available, put a dummy version here, so at # least evaluation succeeds. sources = (lib.importJSON ./sources.json).${stdenv.system} or (throw "unsupported system ${stdenv.system}"); - scopePkg = name: - { url, version, sha256 }: + scopePkg = + name: + { + url, + version, + sha256, + }: stdenv.mkDerivation rec { pname = "lib${name}"; inherit version; @@ -62,33 +91,49 @@ let cp -d opt/picoscope/lib/* $out/lib runHook postInstall ''; - meta = with lib; - shared_meta lib // { + meta = + with lib; + shared_meta lib + // { description = "library for picotech oscilloscope ${name} series"; }; }; scopePkgs = lib.mapAttrs scopePkg sources; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "picoscope"; inherit (sources.picoscope) version; src = fetchurl { inherit (sources.picoscope) url sha256; }; - nativeBuildInputs = [ dpkg makeWrapper ]; - buildInputs = [ gtk-sharp-3_0 mono glib libusb1 zlib ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; + buildInputs = [ + gtk-sharp-3_0 + mono + glib + libusb1 + zlib + ]; scopeLibs = lib.attrVals (map (x: "lib${x}") scopes) scopePkgs; - MONO_PATH = "${gtk-sharp-3_0}/lib/mono/gtk-sharp-3.0:" + (lib.makeLibraryPath - ([ - glib - gtk3-x11 - gtk-sharp-3_0 - libusb1 - zlib - libpicoipp - ] ++ scopeLibs)); + MONO_PATH = + "${gtk-sharp-3_0}/lib/mono/gtk-sharp-3.0:" + + (lib.makeLibraryPath ( + [ + glib + gtk3-x11 + gtk-sharp-3_0 + libusb1 + zlib + libpicoipp + ] + ++ scopeLibs + )); installPhase = '' runHook preInstall @@ -111,10 +156,11 @@ in stdenv.mkDerivation rec { SUBSYSTEMS=="usb", ATTRS{idVendor}=="0ce9", MODE="664",GROUP="pico" ''; - meta = with lib; - shared_meta lib // { - description = - "Oscilloscope application that works with all PicoScope models"; + meta = + with lib; + shared_meta lib + // { + description = "Oscilloscope application that works with all PicoScope models"; longDescription = '' PicoScope for Linux is a powerful oscilloscope application that works with all PicoScope models. The most important features from PicoScope @@ -129,4 +175,3 @@ in stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryBytecode ]; }; } - diff --git a/pkgs/by-name/pi/picosnitch/package.nix b/pkgs/by-name/pi/picosnitch/package.nix index d0cb9f82c56bb8..6d80caf6f6d4ea 100644 --- a/pkgs/by-name/pi/picosnitch/package.nix +++ b/pkgs/by-name/pi/picosnitch/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchPypi -, bcc +{ + lib, + python3, + fetchPypi, + bcc, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pi/picotool/package.nix b/pkgs/by-name/pi/picotool/package.nix index b4cbcde8265248..54a8b4f8e6d9de 100644 --- a/pkgs/by-name/pi/picotool/package.nix +++ b/pkgs/by-name/pi/picotool/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, libusb1, pico-sdk, mbedtls_2 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libusb1, + pico-sdk, + mbedtls_2, +}: stdenv.mkDerivation rec { pname = "picotool"; @@ -19,8 +28,14 @@ stdenv.mkDerivation rec { --replace-fail "''$"'{PICO_SDK_PATH}/lib/mbedtls' '${mbedtls_2.src}' ''; - buildInputs = [ libusb1 pico-sdk ]; - nativeBuildInputs = [ cmake pkg-config ]; + buildInputs = [ + libusb1 + pico-sdk + ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; cmakeFlags = [ "-DPICO_SDK_PATH=${pico-sdk}/lib/pico-sdk" ]; postInstall = '' diff --git a/pkgs/by-name/pi/picotts/package.nix b/pkgs/by-name/pi/picotts/package.nix index 0b470aca5f9428..eff8184f8b3e1a 100644 --- a/pkgs/by-name/pi/picotts/package.nix +++ b/pkgs/by-name/pi/picotts/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libtool, popt }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + popt, +}: stdenv.mkDerivation (finalAttrs: { pname = "picotts"; @@ -10,8 +18,14 @@ stdenv.mkDerivation (finalAttrs: { rev = "2f86050dc5da9ab68fc61510b594d8e6975c4d2d"; sha256 = "1k2mdv9llkh77jr4qr68yf0zgjqk87np35fgfmnc3rpdp538sccl"; }; - nativeBuildInputs = [ autoconf automake ]; - buildInputs = [ libtool popt ]; + nativeBuildInputs = [ + autoconf + automake + ]; + buildInputs = [ + libtool + popt + ]; sourceRoot = "${finalAttrs.src.name}/pico"; preConfigure = "./autogen.sh"; meta = { diff --git a/pkgs/by-name/pi/pict-rs/0.3.nix b/pkgs/by-name/pi/pict-rs/0.3.nix index 9e7ad6e3d2049f..bf869e53603603 100644 --- a/pkgs/by-name/pi/pict-rs/0.3.nix +++ b/pkgs/by-name/pi/pict-rs/0.3.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitea -, rustPlatform -, makeWrapper -, protobuf -, Security -, imagemagick -, ffmpeg -, exiftool -, nixosTests +{ + stdenv, + lib, + fetchFromGitea, + rustPlatform, + makeWrapper, + protobuf, + Security, + imagemagick, + ffmpeg, + exiftool, + nixosTests, }: rustPlatform.buildRustPackage rec { @@ -39,7 +40,13 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram "$out/bin/pict-rs" \ - --prefix PATH : "${lib.makeBinPath [ imagemagick ffmpeg exiftool ]}" + --prefix PATH : "${ + lib.makeBinPath [ + imagemagick + ffmpeg + exiftool + ] + }" ''; passthru.tests = { inherit (nixosTests) pict-rs; }; diff --git a/pkgs/by-name/pi/pict-rs/package.nix b/pkgs/by-name/pi/pict-rs/package.nix index fddfd6fffebd68..0a2a2e2dda107a 100644 --- a/pkgs/by-name/pi/pict-rs/package.nix +++ b/pkgs/by-name/pi/pict-rs/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitea -, rustPlatform -, makeWrapper -, protobuf -, darwin -, imagemagick -, ffmpeg -, exiftool -, nixosTests +{ + stdenv, + lib, + fetchFromGitea, + rustPlatform, + makeWrapper, + protobuf, + darwin, + imagemagick, + ffmpeg, + exiftool, + nixosTests, }: rustPlatform.buildRustPackage rec { @@ -34,7 +35,13 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram "$out/bin/pict-rs" \ - --prefix PATH : "${lib.makeBinPath [ imagemagick ffmpeg exiftool ]}" + --prefix PATH : "${ + lib.makeBinPath [ + imagemagick + ffmpeg + exiftool + ] + }" ''; passthru.tests = { inherit (nixosTests) pict-rs; }; diff --git a/pkgs/by-name/pi/pid1/package.nix b/pkgs/by-name/pi/pid1/package.nix index d991d01be84870..c8ed12bf13fe3e 100644 --- a/pkgs/by-name/pi/pid1/package.nix +++ b/pkgs/by-name/pi/pid1/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "pid1"; diff --git a/pkgs/by-name/pi/pies/package.nix b/pkgs/by-name/pi/pies/package.nix index 4bea37d9c7a240..4d9e858669beb0 100644 --- a/pkgs/by-name/pi/pies/package.nix +++ b/pkgs/by-name/pi/pies/package.nix @@ -1,4 +1,9 @@ -{ fetchurl, lib, stdenv, libxcrypt }: +{ + fetchurl, + lib, + stdenv, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "pies"; @@ -11,7 +16,7 @@ stdenv.mkDerivation rec { buildInputs = [ libxcrypt ]; - configureFlags = ["--sysconfdir=/etc"]; + configureFlags = [ "--sysconfdir=/etc" ]; hardeningDisable = [ "format" ]; @@ -21,25 +26,25 @@ stdenv.mkDerivation rec { description = "Program invocation and execution supervisor"; longDescription = '' - The name Pies (pronounced "p-yes") stands for Program Invocation and - Execution Supervisor. This utility starts and controls execution of - external programs, called components. Each component is a - stand-alone program, which is executed in the foreground. Upon - startup, pies reads the list of components from its configuration - file, starts them, and remains in the background, controlling their - execution. If any of the components terminates, the default action - of Pies is to restart it. However, it can also be programmed to - perform a variety of another actions such as, e.g., sending mail - notifications to the system administrator, invoking another external - program, etc. - - Pies can be used for a wide variety of tasks. Its most obious use - is to put in backgound a program which normally cannot detach itself - from the controlling terminal, such as, e.g., minicom. It can - launch and control components of some complex system, such as - Jabberd or MeTA1 (and it offers much more control over them than the - native utilities). Finally, it can replace the inetd utility! - ''; + The name Pies (pronounced "p-yes") stands for Program Invocation and + Execution Supervisor. This utility starts and controls execution of + external programs, called components. Each component is a + stand-alone program, which is executed in the foreground. Upon + startup, pies reads the list of components from its configuration + file, starts them, and remains in the background, controlling their + execution. If any of the components terminates, the default action + of Pies is to restart it. However, it can also be programmed to + perform a variety of another actions such as, e.g., sending mail + notifications to the system administrator, invoking another external + program, etc. + + Pies can be used for a wide variety of tasks. Its most obious use + is to put in backgound a program which normally cannot detach itself + from the controlling terminal, such as, e.g., minicom. It can + launch and control components of some complex system, such as + Jabberd or MeTA1 (and it offers much more control over them than the + native utilities). Finally, it can replace the inetd utility! + ''; license = lib.licenses.gpl3Plus; diff --git a/pkgs/by-name/pi/pietrasanta-traceroute/package.nix b/pkgs/by-name/pi/pietrasanta-traceroute/package.nix index 78ec9b53728961..4deb0b754009bc 100644 --- a/pkgs/by-name/pi/pietrasanta-traceroute/package.nix +++ b/pkgs/by-name/pi/pietrasanta-traceroute/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, unstableGitUpdater -, stdenv -, openssl +{ + lib, + fetchFromGitHub, + unstableGitUpdater, + stdenv, + openssl, }: stdenv.mkDerivation rec { @@ -32,7 +33,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://github.com/catchpoint/Networking.traceroute/"; changelog = "https://github.com/catchpoint/Networking.traceroute/blob/${src.rev}/ChangeLog"; - license = with licenses; [ gpl2Only lgpl21Only ]; + license = with licenses; [ + gpl2Only + lgpl21Only + ]; mainProgram = "traceroute"; maintainers = with maintainers; [ nicoo ]; platforms = platforms.all; diff --git a/pkgs/by-name/pi/pifpaf/package.nix b/pkgs/by-name/pi/pifpaf/package.nix index a06aaf90d22c02..18bdd1d2fa73b1 100644 --- a/pkgs/by-name/pi/pifpaf/package.nix +++ b/pkgs/by-name/pi/pifpaf/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pi/pig/package.nix b/pkgs/by-name/pi/pig/package.nix index 42938d1246f9ed..9eeae06834572a 100644 --- a/pkgs/by-name/pi/pig/package.nix +++ b/pkgs/by-name/pi/pig/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeWrapper, hadoop, jre, bash }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + hadoop, + jre, + bash, +}: stdenv.mkDerivation rec { pname = "pig"; @@ -21,7 +29,12 @@ stdenv.mkDerivation rec { for n in $out/{bin,sbin}"/"*; do wrapProgram $n \ - --prefix PATH : "${lib.makeBinPath [ jre bash ]}" \ + --prefix PATH : "${ + lib.makeBinPath [ + jre + bash + ] + }" \ --set JAVA_HOME "${jre}" --set HADOOP_PREFIX "${hadoop}" done ''; diff --git a/pkgs/by-name/pi/pigeon/package.nix b/pkgs/by-name/pi/pigeon/package.nix index bfd6672530bf2a..6492341b8d8b32 100644 --- a/pkgs/by-name/pi/pigeon/package.nix +++ b/pkgs/by-name/pi/pigeon/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pigeon"; diff --git a/pkgs/by-name/pi/piglit/package.nix b/pkgs/by-name/pi/piglit/package.nix index f620e2723bd64c..212e692062a0fb 100644 --- a/pkgs/by-name/pi/piglit/package.nix +++ b/pkgs/by-name/pi/piglit/package.nix @@ -1,22 +1,23 @@ -{ stdenv -, fetchFromGitLab -, lib -, cmake -, libglut -, libGL -, libGLU -, libglvnd -, makeWrapper -, ninja -, pkg-config -, python3 -, waffle -, wayland -, libX11 -, libXrender -, libxcb -, libxkbcommon -, mesa +{ + stdenv, + fetchFromGitLab, + lib, + cmake, + libglut, + libGL, + libGLU, + libglvnd, + makeWrapper, + ninja, + pkg-config, + python3, + waffle, + wayland, + libX11, + libXrender, + libxcb, + libxkbcommon, + mesa, }: stdenv.mkDerivation rec { @@ -40,10 +41,12 @@ stdenv.mkDerivation rec { libXrender libxcb libxkbcommon - (python3.withPackages (ps: with ps; [ - mako - numpy - ])) + (python3.withPackages ( + ps: with ps; [ + mako + numpy + ] + )) waffle wayland ]; @@ -64,7 +67,12 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/piglit \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ libGL libglvnd ]} \ + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + libGL + libglvnd + ] + } \ --prefix PATH : "${waffle}/bin" ''; diff --git a/pkgs/by-name/pi/pigz/package.nix b/pkgs/by-name/pi/pigz/package.nix index a6eaab1a6ef23b..9e0b55b3a7a5f6 100644 --- a/pkgs/by-name/pi/pigz/package.nix +++ b/pkgs/by-name/pi/pigz/package.nix @@ -1,14 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, zlib, util-linux }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + util-linux, +}: stdenv.mkDerivation rec { pname = "pigz"; version = "2.8"; src = fetchFromGitHub { - owner = "madler"; - repo = pname; - rev = "refs/tags/v${version}"; - sha256 = "sha256-PzdxyO4mCg2jE/oBk1MH+NUdWM95wIIIbncBg71BkmQ="; + owner = "madler"; + repo = pname; + rev = "refs/tags/v${version}"; + sha256 = "sha256-PzdxyO4mCg2jE/oBk1MH+NUdWM95wIIIbncBg71BkmQ="; }; enableParallelBuilding = true; diff --git a/pkgs/by-name/pi/pijul/package.nix b/pkgs/by-name/pi/pijul/package.nix index 95d974bfa145b4..4abc01cfdf726f 100644 --- a/pkgs/by-name/pi/pijul/package.nix +++ b/pkgs/by-name/pi/pijul/package.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, fetchCrate -, rustPlatform -, installShellFiles -, pkg-config -, libsodium -, openssl -, xxHash -, darwin -, gitImportSupport ? true -, libgit2 ? null +{ + lib, + stdenv, + fetchCrate, + rustPlatform, + installShellFiles, + pkg-config, + libsodium, + openssl, + xxHash, + darwin, + gitImportSupport ? true, + libgit2 ? null, }: rustPlatform.buildRustPackage rec { @@ -23,12 +25,25 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-iXGvb4qmZK7Sjbf/Jkyzj+nhpZFV3ngjtJfz6x/8z2s="; doCheck = false; - nativeBuildInputs = [ installShellFiles pkg-config ]; - buildInputs = [ openssl libsodium xxHash ] + nativeBuildInputs = [ + installShellFiles + pkg-config + ]; + buildInputs = + [ + openssl + libsodium + xxHash + ] ++ (lib.optionals gitImportSupport [ libgit2 ]) - ++ (lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - CoreServices Security SystemConfiguration - ])); + ++ (lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + CoreServices + Security + SystemConfiguration + ] + )); buildFeatures = lib.optional gitImportSupport "git"; @@ -43,7 +58,11 @@ rustPlatform.buildRustPackage rec { description = "Distributed version control system"; homepage = "https://pijul.org"; license = with licenses; [ gpl2Plus ]; - maintainers = with maintainers; [ gal_bolle dywedir fabianhjr ]; + maintainers = with maintainers; [ + gal_bolle + dywedir + fabianhjr + ]; mainProgram = "pijul"; }; } diff --git a/pkgs/by-name/pi/pika-backup/package.nix b/pkgs/by-name/pi/pika-backup/package.nix index f446dc47fffb37..0a2da631d60cf1 100644 --- a/pkgs/by-name/pi/pika-backup/package.nix +++ b/pkgs/by-name/pi/pika-backup/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitLab -, rustPlatform -, substituteAll -, cargo -, desktop-file-utils -, git -, itstool -, meson -, ninja -, pkg-config -, python3 -, rustc -, wrapGAppsHook4 -, borgbackup -, gtk4 -, libadwaita -, libsecret +{ + lib, + stdenv, + fetchFromGitLab, + rustPlatform, + substituteAll, + cargo, + desktop-file-utils, + git, + itstool, + meson, + ninja, + pkg-config, + python3, + rustc, + wrapGAppsHook4, + borgbackup, + gtk4, + libadwaita, + libsecret, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pi/pika/package.nix b/pkgs/by-name/pi/pika/package.nix index e1e5726eb54d37..9288b69ef0a7fc 100644 --- a/pkgs/by-name/pi/pika/package.nix +++ b/pkgs/by-name/pi/pika/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchurl -, stdenv -, undmg +{ + lib, + fetchurl, + stdenv, + undmg, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pi/pikchr/package.nix b/pkgs/by-name/pi/pikchr/package.nix index 2910bfaad4f633..afb2ddf44aaf71 100644 --- a/pkgs/by-name/pi/pikchr/package.nix +++ b/pkgs/by-name/pi/pikchr/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchfossil -, tcl +{ + lib, + stdenv, + fetchfossil, + tcl, -, enableTcl ? true + enableTcl ? true, }: stdenv.mkDerivation { @@ -30,16 +31,19 @@ stdenv.mkDerivation { buildFlags = [ "pikchr" ] ++ lib.optional enableTcl "piktcl"; - installPhase = '' - runHook preInstall - install -Dm755 pikchr $out/bin/pikchr - install -Dm755 pikchr.out $out/lib/pikchr.o - install -Dm644 pikchr.h $out/include/pikchr.h - '' + lib.optionalString enableTcl '' - cp -r piktcl $out/lib/piktcl - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + install -Dm755 pikchr $out/bin/pikchr + install -Dm755 pikchr.out $out/lib/pikchr.o + install -Dm644 pikchr.h $out/include/pikchr.h + '' + + lib.optionalString enableTcl '' + cp -r piktcl $out/lib/piktcl + '' + + '' + runHook postInstall + ''; dontWrapTclBinaries = true; diff --git a/pkgs/by-name/pi/piknik/package.nix b/pkgs/by-name/pi/piknik/package.nix index d3b2a8266b8869..d10c7d4df743a7 100644 --- a/pkgs/by-name/pi/piknik/package.nix +++ b/pkgs/by-name/pi/piknik/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, piknik +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + piknik, }: buildGoModule rec { @@ -18,7 +19,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests = { version = testers.testVersion { diff --git a/pkgs/by-name/pi/pim6sd/package.nix b/pkgs/by-name/pi/pim6sd/package.nix index 81b60d46e28b65..de22a71526d86e 100644 --- a/pkgs/by-name/pi/pim6sd/package.nix +++ b/pkgs/by-name/pi/pim6sd/package.nix @@ -1,4 +1,11 @@ -{ stdenv, fetchFromGitHub, lib, autoreconfHook, bison, flex }: +{ + stdenv, + fetchFromGitHub, + lib, + autoreconfHook, + bison, + flex, +}: stdenv.mkDerivation rec { pname = "pim6sd"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "0x7dyark2mp9xqz9cnmmgaf0z143vxn2835clllpji4ylg77zdjw"; }; - nativeBuildInputs = [ autoreconfHook bison flex ]; + nativeBuildInputs = [ + autoreconfHook + bison + flex + ]; meta = with lib; { description = "PIM for IPv6 sparse mode daemon"; diff --git a/pkgs/by-name/pi/pinball/package.nix b/pkgs/by-name/pi/pinball/package.nix index f1ce5fb9d78c8b..67f35ab0b1e33c 100644 --- a/pkgs/by-name/pi/pinball/package.nix +++ b/pkgs/by-name/pi/pinball/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pkg-config -, libglvnd, SDL, SDL_image, SDL_mixer, xorg +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + libglvnd, + SDL, + SDL_image, + SDL_mixer, + xorg, }: stdenv.mkDerivation rec { @@ -15,8 +24,17 @@ stdenv.mkDerivation rec { sed -i 's/^AUTOMAKE_OPTIONS = gnu$/AUTOMAKE_OPTIONS = foreign/' Makefile.am ''; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libglvnd SDL SDL_image SDL_mixer xorg.libSM ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libglvnd + SDL + SDL_image + SDL_mixer + xorg.libSM + ]; strictDeps = true; configureFlags = [ diff --git a/pkgs/by-name/pi/pinecone/package.nix b/pkgs/by-name/pi/pinecone/package.nix index 4bc503fff312f4..ad8933af0b9aa1 100644 --- a/pkgs/by-name/pi/pinecone/package.nix +++ b/pkgs/by-name/pi/pinecone/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule { pname = "pinecone"; diff --git a/pkgs/by-name/pi/pinentry-bemenu/package.nix b/pkgs/by-name/pi/pinentry-bemenu/package.nix index e165fad36737c4..aabea86e36b1f7 100644 --- a/pkgs/by-name/pi/pinentry-bemenu/package.nix +++ b/pkgs/by-name/pi/pinentry-bemenu/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, pkg-config, libassuan -, libgpg-error, popt, bemenu }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + libassuan, + libgpg-error, + popt, + bemenu, +}: stdenv.mkDerivation rec { pname = "pinentry-bemenu"; @@ -12,8 +22,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-kiGUCcQIS58XjE4r0yiK4hJ85Sg5wrtBqeSYcgUKAmo="; }; - nativeBuildInputs = [ meson ninja pkg-config ]; - buildInputs = [ libassuan libgpg-error popt bemenu ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; + buildInputs = [ + libassuan + libgpg-error + popt + bemenu + ]; meta = with lib; { description = "Pinentry implementation based on bemenu"; diff --git a/pkgs/by-name/pi/pinentry-rofi/package.nix b/pkgs/by-name/pi/pinentry-rofi/package.nix index 3dd94b1e0fa14a..a67ab511a00cc6 100644 --- a/pkgs/by-name/pi/pinentry-rofi/package.nix +++ b/pkgs/by-name/pi/pinentry-rofi/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, autoreconfHook -, autoconf-archive -, guile -, texinfo -, rofi +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + autoreconfHook, + autoconf-archive, + guile, + texinfo, + rofi, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pi/pinfo/package.nix b/pkgs/by-name/pi/pinfo/package.nix index 5ec9e939ce5567..d2c5abf2f83290 100644 --- a/pkgs/by-name/pi/pinfo/package.nix +++ b/pkgs/by-name/pi/pinfo/package.nix @@ -1,12 +1,13 @@ -{ lib -, autoreconfHook -, fetchFromGitHub -, fetchpatch -, gettext -, ncurses -, readline -, stdenv -, texinfo +{ + lib, + autoreconfHook, + fetchFromGitHub, + fetchpatch, + gettext, + ncurses, + readline, + stdenv, + texinfo, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pi/pingme/package.nix b/pkgs/by-name/pi/pingme/package.nix index 9914d4c8ee22fe..c59f8e973c32f8 100644 --- a/pkgs/by-name/pi/pingme/package.nix +++ b/pkgs/by-name/pi/pingme/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -24,7 +25,11 @@ buildGoModule rec { ''; proxyVendor = true; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; meta = { changelog = "https://github.com/kha7iq/pingme/releases/tag/${src.rev}"; diff --git a/pkgs/by-name/pi/pingtcp/package.nix b/pkgs/by-name/pi/pingtcp/package.nix index 88476ab856869b..71b6ca9c8aa8d3 100644 --- a/pkgs/by-name/pi/pingtcp/package.nix +++ b/pkgs/by-name/pi/pingtcp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "pingtcp"; diff --git a/pkgs/by-name/pi/pingtunnel/package.nix b/pkgs/by-name/pi/pingtunnel/package.nix index e91e12fba747e8..4f142c97a7642c 100644 --- a/pkgs/by-name/pi/pingtunnel/package.nix +++ b/pkgs/by-name/pi/pingtunnel/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-SkBHFvQn3Q6fl/d1npEspTYhq1YrnusXNWr/Ky4bv64="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' mv $out/bin/cmd $out/bin/pingtunnel diff --git a/pkgs/by-name/pi/pingus/package.nix b/pkgs/by-name/pi/pingus/package.nix index efee89fc0716fd..7695408eeaf666 100644 --- a/pkgs/by-name/pi/pingus/package.nix +++ b/pkgs/by-name/pi/pingus/package.nix @@ -1,11 +1,38 @@ -{lib, stdenv, fetchgit, cmake, SDL2, SDL2_image, boost, libpng, SDL2_mixer -, pkg-config, libGLU, libGL, git, jsoncpp }: +{ + lib, + stdenv, + fetchgit, + cmake, + SDL2, + SDL2_image, + boost, + libpng, + SDL2_mixer, + pkg-config, + libGLU, + libGL, + git, + jsoncpp, +}: stdenv.mkDerivation rec { pname = "pingus"; version = "unstable-0.7.6.0.20191104"; - nativeBuildInputs = [ cmake pkg-config git ]; - buildInputs = [ SDL2 SDL2_image boost libpng SDL2_mixer libGLU libGL jsoncpp ]; + nativeBuildInputs = [ + cmake + pkg-config + git + ]; + buildInputs = [ + SDL2 + SDL2_image + boost + libpng + SDL2_mixer + libGLU + libGL + jsoncpp + ]; src = fetchgit { url = "https://gitlab.com/pingus/pingus/"; rev = "709546d9b9c4d6d5f45fc9112b45ac10c7f9417d"; @@ -22,7 +49,7 @@ stdenv.mkDerivation rec { description = "Puzzle game with mechanics similar to Lemmings"; mainProgram = "pingus"; platforms = lib.platforms.linux; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; license = lib.licenses.gpl3; }; } diff --git a/pkgs/by-name/pi/pinniped/package.nix b/pkgs/by-name/pi/pinniped/package.nix index 3e442256a6f844..f304fff8c4fafa 100644 --- a/pkgs/by-name/pi/pinniped/package.nix +++ b/pkgs/by-name/pi/pinniped/package.nix @@ -1,6 +1,11 @@ -{ lib, fetchFromGitHub, buildGoModule, installShellFiles }: - -buildGoModule rec{ +{ + lib, + fetchFromGitHub, + buildGoModule, + installShellFiles, +}: + +buildGoModule rec { pname = "pinniped"; version = "0.35.0"; @@ -15,7 +20,10 @@ buildGoModule rec{ vendorHash = "sha256-I8lO4jUMFh0icwxSBCTgtFBn2nq10FKOx39XBHDdEZg="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeBuildInputs = [ installShellFiles ]; diff --git a/pkgs/by-name/pi/pinokio/package.nix b/pkgs/by-name/pi/pinokio/package.nix index f71f7800c46208..94491c396b061c 100644 --- a/pkgs/by-name/pi/pinokio/package.nix +++ b/pkgs/by-name/pi/pinokio/package.nix @@ -1,22 +1,26 @@ -{ lib -, stdenv -, fetchurl -, pkgs -, appimageTools +{ + lib, + stdenv, + fetchurl, + pkgs, + appimageTools, }: let pname = "pinokio"; version = "1.3.4"; - src = fetchurl { - x86_64-darwin = { - url = "https://github.com/pinokiocomputer/pinokio/releases/download/${version}/Pinokio-${version}.dmg"; - hash = "sha256-Il5zaVWu4icSsKmMjU9u1/Mih34fd+xNpF1nkFAFFGo="; - }; - x86_64-linux = { - url = "https://github.com/pinokiocomputer/pinokio/releases/download/${version}/Pinokio-${version}.AppImage"; - hash = "sha256-/E/IAOUgxH9RWpE2/vLlQy92LOgwpHF79K/1XEtSpXI="; - }; - }.${stdenv.system} or (throw "Unsupported system: ${stdenv.system}"); + src = + fetchurl + { + x86_64-darwin = { + url = "https://github.com/pinokiocomputer/pinokio/releases/download/${version}/Pinokio-${version}.dmg"; + hash = "sha256-Il5zaVWu4icSsKmMjU9u1/Mih34fd+xNpF1nkFAFFGo="; + }; + x86_64-linux = { + url = "https://github.com/pinokiocomputer/pinokio/releases/download/${version}/Pinokio-${version}.AppImage"; + hash = "sha256-/E/IAOUgxH9RWpE2/vLlQy92LOgwpHF79K/1XEtSpXI="; + }; + } + .${stdenv.system} or (throw "Unsupported system: ${stdenv.system}"); appimageContents = appimageTools.extractType2 { inherit pname version src; }; @@ -25,16 +29,23 @@ let description = "Browser to install, run, and programmatically control ANY application automatically"; license = lib.licenses.mit; maintainers = with lib.maintainers; [ ByteSudoer ]; - platforms = [ "x86_64-darwin" "x86_64-linux" ]; + platforms = [ + "x86_64-darwin" + "x86_64-linux" + ]; mainProgram = "pinokio"; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; }; in if stdenv.hostPlatform.isDarwin then - stdenv.mkDerivation - { - inherit pname version src meta; + stdenv.mkDerivation { + inherit + pname + version + src + meta + ; sourceRoot = "."; @@ -49,7 +60,12 @@ if stdenv.hostPlatform.isDarwin then } else appimageTools.wrapType2 { - inherit pname version src meta; + inherit + pname + version + src + meta + ; extraInstallCommands = '' mkdir -p $out/share/pinokio diff --git a/pkgs/by-name/pi/pinpoint/package.nix b/pkgs/by-name/pi/pinpoint/package.nix index d0b682e9b9663a..a0afef7c60447c 100644 --- a/pkgs/by-name/pi/pinpoint/package.nix +++ b/pkgs/by-name/pi/pinpoint/package.nix @@ -1,5 +1,16 @@ -{ fetchurl, lib, stdenv, pkg-config, autoconf, automake, clutter, clutter-gst -, gdk-pixbuf, cairo, clutter-gtk }: +{ + fetchurl, + lib, + stdenv, + pkg-config, + autoconf, + automake, + clutter, + clutter-gst, + gdk-pixbuf, + cairo, + clutter-gtk, +}: stdenv.mkDerivation rec { pname = "pinpoint"; @@ -8,9 +19,18 @@ stdenv.mkDerivation rec { url = "http://ftp.gnome.org/pub/GNOME/sources/pinpoint/0.1/${pname}-${version}.tar.xz"; sha256 = "1jp8chr9vjlpb5lybwp5cg6g90ak5jdzz9baiqkbg0anlg8ps82s"; }; - nativeBuildInputs = [ pkg-config autoconf automake ]; - buildInputs = [ clutter clutter-gst gdk-pixbuf - cairo clutter-gtk ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; + buildInputs = [ + clutter + clutter-gst + gdk-pixbuf + cairo + clutter-gtk + ]; meta = with lib; { homepage = "https://gitlab.gnome.org/Archive/pinpoint"; diff --git a/pkgs/by-name/pi/pinsel/package.nix b/pkgs/by-name/pi/pinsel/package.nix index de6cc3700838de..0fc192511c8448 100644 --- a/pkgs/by-name/pi/pinsel/package.nix +++ b/pkgs/by-name/pi/pinsel/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, gtk3, lua, glib }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + gtk3, + lua, + glib, +}: stdenv.mkDerivation rec { pname = "pinsel"; @@ -13,9 +21,15 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ pkg-config glib ]; + nativeBuildInputs = [ + pkg-config + glib + ]; - buildInputs = [ lua gtk3 ]; + buildInputs = [ + lua + gtk3 + ]; makeFlags = [ "INSTALLDIR=${placeholder "out"}/bin" ]; diff --git a/pkgs/by-name/pi/pinta/deps.nix b/pkgs/by-name/pi/pinta/deps.nix index 6d7e63396d7683..1f7c4fd9e199e4 100644 --- a/pkgs/by-name/pi/pinta/deps.nix +++ b/pkgs/by-name/pi/pinta/deps.nix @@ -1,19 +1,76 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "AtkSharp"; version = "3.24.24.38"; hash = "sha256-J9/+MU+zky18Lk3gfTCox6Jtm1SyjQQAK0vCb5Ecu4k="; }) - (fetchNuGet { pname = "CairoSharp"; version = "3.24.24.38"; hash = "sha256-DeXSAuSiGc7SzHb3HsUkLDLe5HZVpRn7VQFNhAAvflg="; }) - (fetchNuGet { pname = "GdkSharp"; version = "3.24.24.38"; hash = "sha256-JpggYCsUlrGZ1CKjCZMawiCjJDWQQc45YdYuA8L7rzA="; }) - (fetchNuGet { pname = "GioSharp"; version = "3.24.24.38"; hash = "sha256-RLd7hlelMgp9Eqga+0YxZVHN6GtbCe6IcHct2bPKcaw="; }) - (fetchNuGet { pname = "GLibSharp"; version = "3.24.24.38"; hash = "sha256-df/8vV4OeQ2v8k7HPNrKcoEQdfPUWrHmM2S1F3DrEag="; }) - (fetchNuGet { pname = "GtkSharp"; version = "3.24.24.38"; hash = "sha256-Uvx7/ylLL4HROPWifMZnOYD9fe0qxlc8QsCayN5TyDI="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "6.0.0"; hash = "sha256-49+H/iFwp+AfCICvWcqo9us4CzxApPKC37Q5Eqrw+JU="; }) - (fetchNuGet { pname = "NGettext"; version = "0.6.7"; hash = "sha256-fmIODwPZkNJsnoNJG+EL1J5mpbuxYI4BsrgD1B4N2NI="; }) - (fetchNuGet { pname = "PangoSharp"; version = "3.24.24.38"; hash = "sha256-dq1c/G05iCmWmWZxwLV0e8qvQMS0620Bd0MSz4hEqjI="; }) - (fetchNuGet { pname = "ParagonClipper"; version = "6.4.2"; hash = "sha256-jCT6rkghEqMuGwiVeiIAspHW+kuiB2jRl9ireBwhVV0="; }) - (fetchNuGet { pname = "SharpZipLib"; version = "1.4.1"; hash = "sha256-ZsmWYdcr73k6Vd9HK1sKBrit6LLiSr+haH8l9h+UAbY="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.7.0"; hash = "sha256-Fw/CSRD+wajH1MqfKS3Q/sIrUH7GN4K+F+Dx68UPNIg="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.7.0"; hash = "sha256-rWBM2U8Kq3rEdaa1MPZSYOOkbtMGgWyB8iPrpIqmpqg="; }) - (fetchNuGet { pname = "Tmds.DBus"; version = "0.11.0"; hash = "sha256-xNArjhSaEZcRiRB+mb9ZwUPQUqbLjRYt4JV2WUtM+hg="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "AtkSharp"; + version = "3.24.24.38"; + hash = "sha256-J9/+MU+zky18Lk3gfTCox6Jtm1SyjQQAK0vCb5Ecu4k="; + }) + (fetchNuGet { + pname = "CairoSharp"; + version = "3.24.24.38"; + hash = "sha256-DeXSAuSiGc7SzHb3HsUkLDLe5HZVpRn7VQFNhAAvflg="; + }) + (fetchNuGet { + pname = "GdkSharp"; + version = "3.24.24.38"; + hash = "sha256-JpggYCsUlrGZ1CKjCZMawiCjJDWQQc45YdYuA8L7rzA="; + }) + (fetchNuGet { + pname = "GioSharp"; + version = "3.24.24.38"; + hash = "sha256-RLd7hlelMgp9Eqga+0YxZVHN6GtbCe6IcHct2bPKcaw="; + }) + (fetchNuGet { + pname = "GLibSharp"; + version = "3.24.24.38"; + hash = "sha256-df/8vV4OeQ2v8k7HPNrKcoEQdfPUWrHmM2S1F3DrEag="; + }) + (fetchNuGet { + pname = "GtkSharp"; + version = "3.24.24.38"; + hash = "sha256-Uvx7/ylLL4HROPWifMZnOYD9fe0qxlc8QsCayN5TyDI="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "6.0.0"; + hash = "sha256-49+H/iFwp+AfCICvWcqo9us4CzxApPKC37Q5Eqrw+JU="; + }) + (fetchNuGet { + pname = "NGettext"; + version = "0.6.7"; + hash = "sha256-fmIODwPZkNJsnoNJG+EL1J5mpbuxYI4BsrgD1B4N2NI="; + }) + (fetchNuGet { + pname = "PangoSharp"; + version = "3.24.24.38"; + hash = "sha256-dq1c/G05iCmWmWZxwLV0e8qvQMS0620Bd0MSz4hEqjI="; + }) + (fetchNuGet { + pname = "ParagonClipper"; + version = "6.4.2"; + hash = "sha256-jCT6rkghEqMuGwiVeiIAspHW+kuiB2jRl9ireBwhVV0="; + }) + (fetchNuGet { + pname = "SharpZipLib"; + version = "1.4.1"; + hash = "sha256-ZsmWYdcr73k6Vd9HK1sKBrit6LLiSr+haH8l9h+UAbY="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.7.0"; + hash = "sha256-Fw/CSRD+wajH1MqfKS3Q/sIrUH7GN4K+F+Dx68UPNIg="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.7.0"; + hash = "sha256-rWBM2U8Kq3rEdaa1MPZSYOOkbtMGgWyB8iPrpIqmpqg="; + }) + (fetchNuGet { + pname = "Tmds.DBus"; + version = "0.11.0"; + hash = "sha256-xNArjhSaEZcRiRB+mb9ZwUPQUqbLjRYt4JV2WUtM+hg="; + }) ] diff --git a/pkgs/by-name/pi/pio/package.nix b/pkgs/by-name/pi/pio/package.nix index f79c12256e234f..69e9c2ff06f69f 100644 --- a/pkgs/by-name/pi/pio/package.nix +++ b/pkgs/by-name/pi/pio/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, stdenv, darwin }: +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "pio"; diff --git a/pkgs/by-name/pi/pioasm/package.nix b/pkgs/by-name/pi/pioasm/package.nix index 150a26757036f2..5abaf4f712fb95 100644 --- a/pkgs/by-name/pi/pioasm/package.nix +++ b/pkgs/by-name/pi/pioasm/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, }: stdenv.mkDerivation (finalAttrs: { @@ -17,7 +18,10 @@ stdenv.mkDerivation (finalAttrs: { }; sourceRoot = "${finalAttrs.src.name}/tools/pioasm"; - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/pi/pioneer/package.nix b/pkgs/by-name/pi/pioneer/package.nix index 57518f084bc398..4b178e593516c8 100644 --- a/pkgs/by-name/pi/pioneer/package.nix +++ b/pkgs/by-name/pi/pioneer/package.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, assimp -, curl -, freetype -#, glew -, libGL -, libGLU -, libpng -, libsigcxx -, libvorbis -, lua5_2 -, mesa -, SDL2 -, SDL2_image +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + assimp, + curl, + freetype, + #, glew + libGL, + libGLU, + libpng, + libsigcxx, + libvorbis, + lua5_2, + mesa, + SDL2, + SDL2_image, }: stdenv.mkDerivation rec { pname = "pioneer"; version = "20240710"; - src = fetchFromGitHub{ + src = fetchFromGitHub { owner = "pioneerspacesim"; repo = "pioneer"; rev = version; @@ -34,7 +35,10 @@ stdenv.mkDerivation rec { --replace 'string(TIMESTAMP PROJECT_VERSION "%Y%m%d")' 'set(PROJECT_VERSION ${version})' ''; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ assimp @@ -56,14 +60,21 @@ stdenv.mkDerivation rec { "-DUSE_SYSTEM_LIBLUA:BOOL=YES" ]; - makeFlags = [ "all" "build-data" ]; + makeFlags = [ + "all" + "build-data" + ]; meta = with lib; { description = "Space adventure game set in the Milky Way galaxy at the turn of the 31st century"; homepage = "https://pioneerspacesim.net"; license = with licenses; [ - gpl3Only cc-by-sa-30 + gpl3Only + cc-by-sa-30 + ]; + platforms = [ + "x86_64-linux" + "i686-linux" ]; - platforms = [ "x86_64-linux" "i686-linux" ]; }; } diff --git a/pkgs/by-name/pi/pioneers/package.nix b/pkgs/by-name/pi/pioneers/package.nix index ae1eb8c8776645..fe68481031ed5f 100644 --- a/pkgs/by-name/pi/pioneers/package.nix +++ b/pkgs/by-name/pi/pioneers/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchurl -, pkg-config -, intltool -, itstool -, gtk3 -, libxml2 +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + itstool, + gtk3, + libxml2, }: stdenv.mkDerivation rec { @@ -16,13 +18,20 @@ stdenv.mkDerivation rec { sha256 = "07b3xdd81n8ybsb4fzc5lx0813y9crzp1hj69khncf4faj48sdcs"; }; - nativeBuildInputs = [ pkg-config intltool itstool ]; + nativeBuildInputs = [ + pkg-config + intltool + itstool + ]; - buildInputs = [ gtk3 libxml2 ]; + buildInputs = [ + gtk3 + libxml2 + ]; meta = with lib; { description = "Addicting game based on The Settlers of Catan"; - homepage = "https://pio.sourceforge.net/"; # https does not work + homepage = "https://pio.sourceforge.net/"; # https does not work license = licenses.gpl2Plus; maintainers = [ ]; platforms = platforms.linux; diff --git a/pkgs/by-name/pi/pipe-rename/package.nix b/pkgs/by-name/pi/pipe-rename/package.nix index dc8e545a7d8e43..556b3947a60c09 100644 --- a/pkgs/by-name/pi/pipe-rename/package.nix +++ b/pkgs/by-name/pi/pipe-rename/package.nix @@ -1,4 +1,9 @@ -{ lib, rustPlatform, fetchCrate, python3 }: +{ + lib, + rustPlatform, + fetchCrate, + python3, +}: rustPlatform.buildRustPackage rec { pname = "pipe-rename"; diff --git a/pkgs/by-name/pi/pipectl/package.nix b/pkgs/by-name/pi/pipectl/package.nix index 1854e414093c87..9c77e631429e37 100644 --- a/pkgs/by-name/pi/pipectl/package.nix +++ b/pkgs/by-name/pi/pipectl/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, scdoc +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + scdoc, }: stdenv.mkDerivation rec { @@ -16,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-pNBw1ukNaqu40qPXnORUGApYpJ/0EAO9Tq5zAbDe33I="; }; - nativeBuildInputs = [ cmake scdoc ]; + nativeBuildInputs = [ + cmake + scdoc + ]; cmakeFlags = [ "-DINSTALL_DOCUMENTATION=ON" diff --git a/pkgs/by-name/pi/pipenv/package.nix b/pkgs/by-name/pi/pipenv/package.nix index 0843e6162227b8..35a160858278f1 100644 --- a/pkgs/by-name/pi/pipenv/package.nix +++ b/pkgs/by-name/pi/pipenv/package.nix @@ -1,30 +1,35 @@ -{ lib -, stdenv -, python3 -, fetchFromGitHub -, installShellFiles -, pipenv -, runCommand +{ + lib, + stdenv, + python3, + fetchFromGitHub, + installShellFiles, + pipenv, + runCommand, }: with python3.pkgs; let - runtimeDeps = ps: with ps; [ - certifi - setuptools - pip - virtualenv - virtualenv-clone - ] - ++ lib.optionals stdenv.hostPlatform.isAndroid [ - pyjnius - ]; + runtimeDeps = + ps: + with ps; + [ + certifi + setuptools + pip + virtualenv + virtualenv-clone + ] + ++ lib.optionals stdenv.hostPlatform.isAndroid [ + pyjnius + ]; pythonEnv = python3.withPackages runtimeDeps; -in buildPythonApplication rec { +in +buildPythonApplication rec { pname = "pipenv"; version = "2024.2.0"; format = "pyproject"; @@ -78,7 +83,7 @@ in buildPythonApplication rec { ]; passthru.tests = { - verify-venv-patch = runCommand "${pname}-test-verify-venv-patch" {} '' + verify-venv-patch = runCommand "${pname}-test-verify-venv-patch" { } '' export PIPENV_VENV_IN_PROJECT=1 # "pipenv install" should be able to create a venv diff --git a/pkgs/by-name/pi/piper-phonemize/package.nix b/pkgs/by-name/pi/piper-phonemize/package.nix index b08495cae74c3b..ed0a1396994ae4 100644 --- a/pkgs/by-name/pi/piper-phonemize/package.nix +++ b/pkgs/by-name/pi/piper-phonemize/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, -# build -, cmake -, pkg-config + # build + cmake, + pkg-config, -# runtime -, espeak-ng -, onnxruntime + # runtime + espeak-ng, + onnxruntime, }: let diff --git a/pkgs/by-name/pi/pipes-rs/package.nix b/pkgs/by-name/pi/pipes-rs/package.nix index d1ca26da475874..dcdd1af1a80922 100644 --- a/pkgs/by-name/pi/pipes-rs/package.nix +++ b/pkgs/by-name/pi/pipes-rs/package.nix @@ -1,4 +1,8 @@ -{ rustPlatform, fetchFromGitHub, lib }: +{ + rustPlatform, + fetchFromGitHub, + lib, +}: rustPlatform.buildRustPackage rec { pname = "pipes-rs"; diff --git a/pkgs/by-name/pi/pipes/package.nix b/pkgs/by-name/pi/pipes/package.nix index bbabd02f4751d7..a2a8b951081d78 100644 --- a/pkgs/by-name/pi/pipes/package.nix +++ b/pkgs/by-name/pi/pipes/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, coreutils, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + coreutils, + ncurses, +}: stdenv.mkDerivation rec { pname = "pipes"; @@ -18,7 +25,12 @@ stdenv.mkDerivation rec { make PREFIX=$out/ install wrapProgram $out/bin/pipes.sh \ - --set PATH "${lib.makeBinPath [ coreutils ncurses ]}" + --set PATH "${ + lib.makeBinPath [ + coreutils + ncurses + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/pi/pipework/package.nix b/pkgs/by-name/pi/pipework/package.nix index fa3698b362061a..94b272eccdbb5b 100644 --- a/pkgs/by-name/pi/pipework/package.nix +++ b/pkgs/by-name/pi/pipework/package.nix @@ -1,5 +1,15 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper -, bridge-utils, iproute2, lxc, openvswitch, docker, busybox, dhcpcd +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + bridge-utils, + iproute2, + lxc, + openvswitch, + docker, + busybox, + dhcpcd, }: stdenv.mkDerivation { @@ -15,7 +25,17 @@ stdenv.mkDerivation { installPhase = '' install -D pipework $out/bin/pipework wrapProgram $out/bin/pipework --prefix PATH : \ - ${lib.makeBinPath [ bridge-utils iproute2 lxc openvswitch docker busybox dhcpcd ]}; + ${ + lib.makeBinPath [ + bridge-utils + iproute2 + lxc + openvswitch + docker + busybox + dhcpcd + ] + }; ''; meta = with lib; { description = "Software-Defined Networking tools for LXC"; diff --git a/pkgs/by-name/pi/pipeworld/package.nix b/pkgs/by-name/pi/pipeworld/package.nix index 52c411d8377746..364367fb68fa42 100644 --- a/pkgs/by-name/pi/pipeworld/package.nix +++ b/pkgs/by-name/pi/pipeworld/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation (finalPackages: { diff --git a/pkgs/by-name/pi/pipr/package.nix b/pkgs/by-name/pi/pipr/package.nix index 466451443e470b..4dfa47b0cf27c1 100644 --- a/pkgs/by-name/pi/pipr/package.nix +++ b/pkgs/by-name/pi/pipr/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, bubblewrap -, makeWrapper +{ + lib, + fetchFromGitHub, + rustPlatform, + bubblewrap, + makeWrapper, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pi/pipreqs/package.nix b/pkgs/by-name/pi/pipreqs/package.nix index 49062b3a5cb859..afa52bfc156861 100644 --- a/pkgs/by-name/pi/pipreqs/package.nix +++ b/pkgs/by-name/pi/pipreqs/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchPypi }: +{ + lib, + python3, + fetchPypi, +}: with python3.pkgs; @@ -11,7 +15,10 @@ buildPythonApplication rec { hash = "sha256-oX8WeIC2khvjdTPOTIHdxuIrRlwQeq1VfbQ7Gt1WqZs="; }; - propagatedBuildInputs = [ yarg docopt ]; + propagatedBuildInputs = [ + yarg + docopt + ]; # Tests requires network access. Works fine without sandboxing doCheck = false; diff --git a/pkgs/by-name/pi/pirate-get/package.nix b/pkgs/by-name/pi/pirate-get/package.nix index 06d322b8386906..3824efe0016fb4 100644 --- a/pkgs/by-name/pi/pirate-get/package.nix +++ b/pkgs/by-name/pi/pirate-get/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: with python3Packages; @@ -11,7 +15,11 @@ buildPythonApplication rec { hash = "sha256-VtnVyJqrdGXTqcyzpHCOMUI9G7/BkXzihDrBrsxl7Eg="; }; - propagatedBuildInputs = [ colorama veryprettytable pyperclip ]; + propagatedBuildInputs = [ + colorama + veryprettytable + pyperclip + ]; meta = with lib; { description = "Command line interface for The Pirate Bay"; diff --git a/pkgs/by-name/pi/pistol/package.nix b/pkgs/by-name/pi/pistol/package.nix index c1b01697988d0a..b38a4a34e6e865 100644 --- a/pkgs/by-name/pi/pistol/package.nix +++ b/pkgs/by-name/pi/pistol/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, file -, installShellFiles -, asciidoctor +{ + lib, + buildGoModule, + fetchFromGitHub, + file, + installShellFiles, + asciidoctor, }: buildGoModule rec { @@ -35,7 +36,11 @@ buildGoModule rec { installManPage pistol.1 ''; - ldflags = [ "-s" "-w" "-X main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.Version=${version}" + ]; meta = with lib; { description = "General purpose file previewer designed for Ranger, Lf to make scope.sh redundant"; diff --git a/pkgs/by-name/pi/piston-cli/package.nix b/pkgs/by-name/pi/piston-cli/package.nix index 0309832787a40e..f5ac2cf200b697 100644 --- a/pkgs/by-name/pi/piston-cli/package.nix +++ b/pkgs/by-name/pi/piston-cli/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, python3Packages, fetchPypi }: +{ + stdenv, + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "piston-cli"; @@ -10,7 +15,14 @@ python3Packages.buildPythonApplication rec { sha256 = "qvDGVJcaMXUajdUQWl4W1dost8k0PsS9XX/o8uQrtfY="; }; - propagatedBuildInputs = with python3Packages; [ rich prompt-toolkit requests pygments pyyaml more-itertools ]; + propagatedBuildInputs = with python3Packages; [ + rich + prompt-toolkit + requests + pygments + pyyaml + more-itertools + ]; checkPhase = '' $out/bin/piston --help > /dev/null diff --git a/pkgs/by-name/pi/pitch-black/package.nix b/pkgs/by-name/pi/pitch-black/package.nix index 092208f4f417d3..221c577744d485 100644 --- a/pkgs/by-name/pi/pitch-black/package.nix +++ b/pkgs/by-name/pi/pitch-black/package.nix @@ -1,6 +1,10 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: -stdenvNoCC.mkDerivation rec{ +stdenvNoCC.mkDerivation rec { pname = "pitch-black"; version = "unstable-2019-07-23"; diff --git a/pkgs/by-name/pi/pitivi/package.nix b/pkgs/by-name/pi/pitivi/package.nix index 616cce1a389876..6682826cbc6d79 100644 --- a/pkgs/by-name/pi/pitivi/package.nix +++ b/pkgs/by-name/pi/pitivi/package.nix @@ -1,22 +1,23 @@ -{ lib -, fetchurl -, pkg-config -, gettext -, itstool -, python3 -, wrapGAppsHook3 -, gst_all_1 -, gtk3 -, gobject-introspection -, libpeas -, librsvg -, gnome -, libnotify -, gsound -, meson -, ninja -, gsettings-desktop-schemas -, hicolor-icon-theme +{ + lib, + fetchurl, + pkg-config, + gettext, + itstool, + python3, + wrapGAppsHook3, + gst_all_1, + gtk3, + gobject-introspection, + libpeas, + librsvg, + gnome, + libnotify, + gsound, + meson, + ninja, + gsettings-desktop-schemas, + hicolor-icon-theme, }: python3.pkgs.buildPythonApplication rec { @@ -48,23 +49,25 @@ python3.pkgs.buildPythonApplication rec { gobject-introspection ]; - buildInputs = [ - gtk3 - libpeas - librsvg - gsound - gsettings-desktop-schemas - libnotify - ] ++ (with gst_all_1; [ - gstreamer - gst-editing-services - gst-plugins-base - (gst-plugins-good.override { gtkSupport = true; }) - gst-plugins-bad - gst-plugins-ugly - gst-libav - gst-devtools - ]); + buildInputs = + [ + gtk3 + libpeas + librsvg + gsound + gsettings-desktop-schemas + libnotify + ] + ++ (with gst_all_1; [ + gstreamer + gst-editing-services + gst-plugins-base + (gst-plugins-good.override { gtkSupport = true; }) + gst-plugins-bad + gst-plugins-ugly + gst-libav + gst-devtools + ]); pythonPath = with python3.pkgs; [ pygobject3 diff --git a/pkgs/by-name/pi/pius/package.nix b/pkgs/by-name/pi/pius/package.nix index 39c129b6b423ce..946d4590b6fcb6 100644 --- a/pkgs/by-name/pi/pius/package.nix +++ b/pkgs/by-name/pi/pius/package.nix @@ -1,6 +1,14 @@ -{ fetchFromGitHub, lib, python3Packages, gnupg, perl }: - -let version = "3.0.0"; in +{ + fetchFromGitHub, + lib, + python3Packages, + gnupg, + perl, +}: + +let + version = "3.0.0"; +in python3Packages.buildPythonApplication { pname = "pius"; namePrefix = ""; diff --git a/pkgs/by-name/pi/piv-agent/package.nix b/pkgs/by-name/pi/piv-agent/package.nix index 84f7db49becb06..227ff18f4b64bd 100644 --- a/pkgs/by-name/pi/piv-agent/package.nix +++ b/pkgs/by-name/pi/piv-agent/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, buildGoModule -, darwin -, fetchFromGitHub -, pcsclite -, pkg-config +{ + lib, + stdenv, + buildGoModule, + darwin, + fetchFromGitHub, + pcsclite, + pkg-config, }: buildGoModule rec { @@ -22,14 +23,17 @@ buildGoModule rec { subPackages = [ "cmd/piv-agent" ]; - ldflags = [ "-s" "-w" "-X main.version=${version}" "-X main.shortCommit=${src.rev}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + "-X main.shortCommit=${src.rev}" + ]; nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ]; buildInputs = - if stdenv.hostPlatform.isDarwin - then [ darwin.apple_sdk.frameworks.PCSC ] - else [ pcsclite ]; + if stdenv.hostPlatform.isDarwin then [ darwin.apple_sdk.frameworks.PCSC ] else [ pcsclite ]; meta = with lib; { description = "SSH and GPG agent which you can use with your PIV hardware security device (e.g. a Yubikey)"; diff --git a/pkgs/by-name/pi/pix/package.nix b/pkgs/by-name/pi/pix/package.nix index e1fe6e7f2e7698..93cee176fb392b 100644 --- a/pkgs/by-name/pi/pix/package.nix +++ b/pkgs/by-name/pi/pix/package.nix @@ -1,34 +1,35 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, meson -, ninja -, brasero -, colord -, exiv2 -, libheif -, libjpeg -, libjxl -, libtiff -, gst_all_1 -, libraw -, libsecret -, glib -, gtk3 -, gsettings-desktop-schemas -, librsvg -, libwebp -, libX11 -, lcms2 -, bison -, flex -, wrapGAppsHook3 -, shared-mime-info -, python3 -, desktop-file-utils -, itstool -, xapp +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + meson, + ninja, + brasero, + colord, + exiv2, + libheif, + libjpeg, + libjxl, + libtiff, + gst_all_1, + libraw, + libsecret, + glib, + gtk3, + gsettings-desktop-schemas, + librsvg, + libwebp, + libX11, + lcms2, + bison, + flex, + wrapGAppsHook3, + shared-mime-info, + python3, + desktop-file-utils, + itstool, + xapp, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pi/pixd/package.nix b/pkgs/by-name/pi/pixd/package.nix index 84ad2c92e20741..57487c9f5efe96 100644 --- a/pkgs/by-name/pi/pixd/package.nix +++ b/pkgs/by-name/pi/pixd/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "pixd"; diff --git a/pkgs/by-name/pi/pixel-code/package.nix b/pkgs/by-name/pi/pixel-code/package.nix index 7c08deca93c240..92b3886685e9e0 100644 --- a/pkgs/by-name/pi/pixel-code/package.nix +++ b/pkgs/by-name/pi/pixel-code/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "pixel-code"; @@ -7,7 +11,7 @@ stdenvNoCC.mkDerivation rec { src = fetchzip { url = "https://github.com/qwerasd205/PixelCode/releases/download/v${version}/otf.zip"; hash = "sha256-GNYEnv0bIWz5d8821N46FD2NBNBf3Dd7DNqjSdJKDoE="; - stripRoot=false; + stripRoot = false; }; installPhase = '' diff --git a/pkgs/by-name/pi/pixelnuke/package.nix b/pkgs/by-name/pi/pixelnuke/package.nix index c40a41590b70ee..592e6d44b9b845 100644 --- a/pkgs/by-name/pi/pixelnuke/package.nix +++ b/pkgs/by-name/pi/pixelnuke/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, libevent, glew, glfw }: +{ + lib, + stdenv, + fetchFromGitHub, + libevent, + glew, + glfw, +}: stdenv.mkDerivation (finalAttrs: { pname = "pixelnuke"; @@ -13,7 +20,11 @@ stdenv.mkDerivation (finalAttrs: { sourceRoot = "${finalAttrs.src.name}/pixelnuke"; - buildInputs = [ libevent glew glfw ]; + buildInputs = [ + libevent + glew + glfw + ]; installPhase = '' install -Dm755 ./pixelnuke $out/bin/pixelnuke diff --git a/pkgs/by-name/pi/pixeluvo/package.nix b/pkgs/by-name/pi/pixeluvo/package.nix index c89c2707116b6b..585621045bb665 100644 --- a/pkgs/by-name/pi/pixeluvo/package.nix +++ b/pkgs/by-name/pi/pixeluvo/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchurl, dpkg, autoPatchelfHook, makeWrapper -, gtk3-x11 }: +{ + lib, + stdenv, + fetchurl, + dpkg, + autoPatchelfHook, + makeWrapper, + gtk3-x11, +}: stdenv.mkDerivation rec { pname = "pixeluvo"; diff --git a/pkgs/by-name/pi/pixiecore/package.nix b/pkgs/by-name/pi/pixiecore/package.nix index f6cb11d2392180..f449bdb8d27658 100644 --- a/pkgs/by-name/pi/pixiecore/package.nix +++ b/pkgs/by-name/pi/pixiecore/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pixiecore"; @@ -21,7 +25,7 @@ buildGoModule rec { meta = { description = "Tool to manage network booting of machines"; homepage = "https://github.com/danderson/netboot/tree/master/pixiecore"; - license = lib.licenses.asl20; + license = lib.licenses.asl20; maintainers = with lib.maintainers; [ bbigras ]; mainProgram = "pixiecore"; }; diff --git a/pkgs/by-name/pi/pixiewps/package.nix b/pkgs/by-name/pi/pixiewps/package.nix index 044ccee37977fc..d3ea7e82461238 100644 --- a/pkgs/by-name/pi/pixiewps/package.nix +++ b/pkgs/by-name/pi/pixiewps/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "pixiewps"; diff --git a/pkgs/by-name/pi/pixman/package.nix b/pkgs/by-name/pi/pixman/package.nix index 0678539b79a3be..0e78b595987abc 100644 --- a/pkgs/by-name/pi/pixman/package.nix +++ b/pkgs/by-name/pi/pixman/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, libpng -, glib /*just passthru*/ +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + libpng, + glib, # just passthru -# for passthru.tests -, cairo -, qemu -, scribus -, tigervnc -, wlroots_0_17 -, wlroots_0_18 -, xwayland + # for passthru.tests + cairo, + qemu, + scribus, + tigervnc, + wlroots_0_17, + wlroots_0_18, + xwayland, -, gitUpdater -, testers + gitUpdater, + testers, -, __flattenIncludeHackHook + __flattenIncludeHackHook, }: stdenv.mkDerivation (finalAttrs: { @@ -42,7 +43,12 @@ stdenv.mkDerivation (finalAttrs: { separateDebugInfo = !stdenv.hostPlatform.isStatic; - nativeBuildInputs = [ meson ninja pkg-config __flattenIncludeHackHook ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + __flattenIncludeHackHook + ]; buildInputs = [ libpng ]; @@ -50,11 +56,12 @@ stdenv.mkDerivation (finalAttrs: { # architectures and requires used to disable them: # https://gitlab.freedesktop.org/pixman/pixman/-/issues/88 mesonAutoFeatures = "auto"; - mesonFlags = [ - "-Diwmmxt=disabled" - ] - # Disable until https://gitlab.freedesktop.org/pixman/pixman/-/issues/46 is resolved - ++ lib.optional (stdenv.hostPlatform.isAarch64 && !stdenv.cc.isGNU) "-Da64-neon=disabled"; + mesonFlags = + [ + "-Diwmmxt=disabled" + ] + # Disable until https://gitlab.freedesktop.org/pixman/pixman/-/issues/46 is resolved + ++ lib.optional (stdenv.hostPlatform.isAarch64 && !stdenv.cc.isGNU) "-Da64-neon=disabled"; preConfigure = '' # https://gitlab.freedesktop.org/pixman/pixman/-/issues/62 @@ -67,7 +74,15 @@ stdenv.mkDerivation (finalAttrs: { passthru = { tests = { - inherit cairo qemu scribus tigervnc wlroots_0_17 wlroots_0_18 xwayland; + inherit + cairo + qemu + scribus + tigervnc + wlroots_0_17 + wlroots_0_18 + xwayland + ; pkg-config = testers.hasPkgConfigModules { package = finalAttrs.finalPackage; }; diff --git a/pkgs/by-name/pi/pixz/package.nix b/pkgs/by-name/pi/pixz/package.nix index 4e221ae18fc93b..33d95b38ffdae4 100644 --- a/pkgs/by-name/pi/pixz/package.nix +++ b/pkgs/by-name/pi/pixz/package.nix @@ -1,24 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, libtool -, pkg-config -, asciidoc -, libxslt -, libxml2 -, docbook_xml_dtd_45 -, docbook_xsl -, libarchive -, xz +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + pkg-config, + asciidoc, + libxslt, + libxml2, + docbook_xml_dtd_45, + docbook_xsl, + libarchive, + xz, }: stdenv.mkDerivation rec { pname = "pixz"; version = "1.0.7"; - nativeBuildInputs = [ pkg-config autoconf automake ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; buildInputs = [ libtool asciidoc diff --git a/pkgs/by-name/pi/pizarra/package.nix b/pkgs/by-name/pi/pizarra/package.nix index 2167eb3a9caf44..241208d4796785 100644 --- a/pkgs/by-name/pi/pizarra/package.nix +++ b/pkgs/by-name/pi/pizarra/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitLab -, rustPlatform -, pkg-config -, gtk3-x11 -, atk -, glib -, librsvg -, gdk-pixbuf -, wrapGAppsHook3 +{ + lib, + fetchFromGitLab, + rustPlatform, + pkg-config, + gtk3-x11, + atk, + glib, + librsvg, + gdk-pixbuf, + wrapGAppsHook3, }: rustPlatform.buildRustPackage rec { @@ -24,9 +25,18 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-btvMUKADGHlXLmeKF1K9Js44SljZ0MejGId8aDwPhVU="; - nativeBuildInputs = [ wrapGAppsHook3 pkg-config gdk-pixbuf ]; + nativeBuildInputs = [ + wrapGAppsHook3 + pkg-config + gdk-pixbuf + ]; - buildInputs = [ gtk3-x11 atk glib librsvg ]; + buildInputs = [ + gtk3-x11 + atk + glib + librsvg + ]; postInstall = '' install -Dm444 res/icons/tk.categulario.pizarra.svg $out/share/icons/hicolor/scalable/apps/pizarra.svg diff --git a/pkgs/by-name/pk/pk2cmd/package.nix b/pkgs/by-name/pk/pk2cmd/package.nix index 9b04a668dadbe0..2f26bbab365bc3 100644 --- a/pkgs/by-name/pk/pk2cmd/package.nix +++ b/pkgs/by-name/pk/pk2cmd/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, libusb-compat-0_1, makeWrapper}: +{ + lib, + stdenv, + fetchurl, + libusb-compat-0_1, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "pk2cmd"; @@ -8,7 +14,10 @@ stdenv.mkDerivation rec { sha256 = "1yjpi2qshnqfpan4w3ggakkr3znfrx5cxkny92ka7v9na3g2fc4h"; }; - makeFlags = [ "LIBUSB=${libusb-compat-0_1.dev}" "linux" ]; + makeFlags = [ + "LIBUSB=${libusb-compat-0_1.dev}" + "linux" + ]; installPhase = '' mkdir -p $out/bin $out/share/pk2 @@ -22,7 +31,7 @@ stdenv.mkDerivation rec { meta = { homepage = "https://www.microchip.com/pickit2"; - license = lib.licenses.unfree; #MicroChip-PK2 + license = lib.licenses.unfree; # MicroChip-PK2 description = "Microchip PIC programming software for the PICKit2 programmer"; mainProgram = "pk2cmd"; }; diff --git a/pkgs/by-name/pk/pkcrack/package.nix b/pkgs/by-name/pk/pkcrack/package.nix index 5cbe977c38ec10..8422fd49c17bad 100644 --- a/pkgs/by-name/pk/pkcrack/package.nix +++ b/pkgs/by-name/pk/pkcrack/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pk/pkcs11helper/package.nix b/pkgs/by-name/pk/pkcs11helper/package.nix index 3723a6806ad9d1..73699df0ead2a0 100644 --- a/pkgs/by-name/pk/pkcs11helper/package.nix +++ b/pkgs/by-name/pk/pkcs11helper/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, openssl, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + openssl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "pkcs11-helper"; @@ -11,14 +18,20 @@ stdenv.mkDerivation rec { hash = "sha256-FP3y/YHsPPqey4QfxIiC4QjruuK1K2Bg+2QL2gXDT+k="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ openssl ]; enableParallelBuilding = true; meta = with lib; { homepage = "https://github.com/OpenSC/pkcs11-helper"; - license = with licenses; [ bsd3 gpl2Only ]; + license = with licenses; [ + bsd3 + gpl2Only + ]; description = "Library that simplifies the interaction with PKCS#11 providers"; platforms = platforms.unix; }; diff --git a/pkgs/by-name/pk/pkg-config-unwrapped/package.nix b/pkgs/by-name/pk/pkg-config-unwrapped/package.nix index a04b8874e990f7..bcd386b134b457 100644 --- a/pkgs/by-name/pk/pkg-config-unwrapped/package.nix +++ b/pkgs/by-name/pk/pkg-config-unwrapped/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libiconv, vanilla ? false }: +{ + lib, + stdenv, + fetchurl, + libiconv, + vanilla ? false, +}: stdenv.mkDerivation rec { pname = "pkg-config"; @@ -9,13 +15,18 @@ stdenv.mkDerivation rec { sha256 = "14fmwzki1rlz8bs2p810lk6jqdxsk966d8drgsjmi54cd00rrikg"; }; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; strictDeps = true; # Process Requires.private properly, see # http://bugs.freedesktop.org/show_bug.cgi?id=4738, migrated to # https://gitlab.freedesktop.org/pkg-config/pkg-config/issues/28 - patches = lib.optional (!vanilla) ./requires-private.patch + patches = + lib.optional (!vanilla) ./requires-private.patch ++ lib.optional stdenv.hostPlatform.isCygwin ./2.36.3-not-win32.patch; # These three tests fail due to a (desired) behavior change from our ./requires-private.patch @@ -24,27 +35,34 @@ stdenv.mkDerivation rec { # necessary for FreeBSD code path in configure '' substituteInPlace ./config.guess ./glib/config.guess --replace-fail /usr/bin/uname uname - '' + lib.optionalString (!vanilla) '' + '' + + lib.optionalString (!vanilla) '' rm -f check/check-requires-private check/check-gtk check/missing ''; buildInputs = [ libiconv ]; - configureFlags = [ "--with-internal-glib" ] - ++ lib.optionals (stdenv.hostPlatform.isSunOS) [ "--with-libiconv=gnu" "--with-system-library-path" "--with-system-include-path" "CFLAGS=-DENABLE_NLS" ] - # Can't run these tests while cross-compiling - ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) - [ "glib_cv_stack_grows=no" - "glib_cv_uscore=no" - "ac_cv_func_posix_getpwuid_r=yes" - "ac_cv_func_posix_getgrgid_r=yes" - ]; + configureFlags = + [ "--with-internal-glib" ] + ++ lib.optionals (stdenv.hostPlatform.isSunOS) [ + "--with-libiconv=gnu" + "--with-system-library-path" + "--with-system-include-path" + "CFLAGS=-DENABLE_NLS" + ] + # Can't run these tests while cross-compiling + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "glib_cv_stack_grows=no" + "glib_cv_uscore=no" + "ac_cv_func_posix_getpwuid_r=yes" + "ac_cv_func_posix_getgrgid_r=yes" + ]; env.NIX_CFLAGS_COMPILE = toString ( # Silence "incompatible integer to pointer conversion passing 'gsize'" when building with Clang. - lib.optionals stdenv.cc.isClang ["-Wno-int-conversion"] + lib.optionals stdenv.cc.isClang [ "-Wno-int-conversion" ] # Silence fprintf format errors when building for Windows. - ++ lib.optionals stdenv.hostPlatform.isWindows ["-Wno-error=format"] + ++ lib.optionals stdenv.hostPlatform.isWindows [ "-Wno-error=format" ] ); enableParallelBuilding = true; diff --git a/pkgs/by-name/pk/pkg/package.nix b/pkgs/by-name/pk/pkg/package.nix index 76890f4bd515fb..f1ee76af415c5c 100644 --- a/pkgs/by-name/pk/pkg/package.nix +++ b/pkgs/by-name/pk/pkg/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, m4, pkg-config, tcl -, bzip2, elfutils, libarchive, libbsd, xz, openssl, zlib +{ + lib, + stdenv, + fetchFromGitHub, + m4, + pkg-config, + tcl, + bzip2, + elfutils, + libarchive, + libbsd, + xz, + openssl, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -16,9 +28,19 @@ stdenv.mkDerivation (finalAttrs: { setOutputFlags = false; separateDebugInfo = true; - nativeBuildInputs = [ m4 pkg-config tcl ]; - buildInputs = [ bzip2 elfutils libarchive openssl xz zlib ] - ++ lib.optional stdenv.hostPlatform.isLinux libbsd; + nativeBuildInputs = [ + m4 + pkg-config + tcl + ]; + buildInputs = [ + bzip2 + elfutils + libarchive + openssl + xz + zlib + ] ++ lib.optional stdenv.hostPlatform.isLinux libbsd; enableParallelBuilding = true; diff --git a/pkgs/by-name/pk/pkgdiff/package.nix b/pkgs/by-name/pk/pkgdiff/package.nix index 139c0f8e2d56cc..68e5143e6ecc88 100644 --- a/pkgs/by-name/pk/pkgdiff/package.nix +++ b/pkgs/by-name/pk/pkgdiff/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, perl, wdiff }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + perl, + wdiff, +}: stdenv.mkDerivation rec { version = "1.7.2"; diff --git a/pkgs/by-name/pk/pkger/package.nix b/pkgs/by-name/pk/pkger/package.nix index 37895fbeed65bf..5dbad7a889cab0 100644 --- a/pkgs/by-name/pk/pkger/package.nix +++ b/pkgs/by-name/pk/pkger/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: diff --git a/pkgs/by-name/pk/pkgtop/package.nix b/pkgs/by-name/pk/pkgtop/package.nix index acb56dd47d4b04..c730478d8410c5 100644 --- a/pkgs/by-name/pk/pkgtop/package.nix +++ b/pkgs/by-name/pk/pkgtop/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/pk/pktgen/package.nix b/pkgs/by-name/pk/pktgen/package.nix index 7fbc445902e9bc..6f7e723450c57a 100644 --- a/pkgs/by-name/pk/pktgen/package.nix +++ b/pkgs/by-name/pk/pktgen/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, dpdk -, libbsd -, libpcap -, lua5_3 -, numactl -, util-linux -, gtk2 -, which -, withGtk ? false +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + dpdk, + libbsd, + libpcap, + lua5_3, + numactl, + util-linux, + gtk2, + which, + withGtk ? false, }: stdenv.mkDerivation rec { @@ -26,14 +27,25 @@ stdenv.mkDerivation rec { sha256 = "sha256-eujVEU+XkxF1kIGQJoBW3oXXNSqBEzx6mwR2XYoHinM="; }; - nativeBuildInputs = [ meson ninja pkg-config ]; - - buildInputs = [ - dpdk libbsd libpcap lua5_3 numactl which - ] ++ lib.optionals withGtk [ - gtk2 + nativeBuildInputs = [ + meson + ninja + pkg-config ]; + buildInputs = + [ + dpdk + libbsd + libpcap + lua5_3 + numactl + which + ] + ++ lib.optionals withGtk [ + gtk2 + ]; + RTE_SDK = dpdk; GUI = lib.optionalString withGtk "true"; @@ -58,7 +70,7 @@ stdenv.mkDerivation rec { description = "Traffic generator powered by DPDK"; homepage = "http://dpdk.org/"; license = licenses.bsdOriginal; - platforms = platforms.linux; + platforms = platforms.linux; maintainers = [ maintainers.abuibrahim ]; }; } diff --git a/pkgs/by-name/pl/planarity/package.nix b/pkgs/by-name/pl/planarity/package.nix index 21791267e1aecb..c7e11394511b2c 100644 --- a/pkgs/by-name/pl/planarity/package.nix +++ b/pkgs/by-name/pl/planarity/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pl/planetary_annihilation/package.nix b/pkgs/by-name/pl/planetary_annihilation/package.nix index fc94f80aa53735..4419612af2ff63 100644 --- a/pkgs/by-name/pl/planetary_annihilation/package.nix +++ b/pkgs/by-name/pl/planetary_annihilation/package.nix @@ -1,5 +1,26 @@ -{ lib, stdenv, patchelf, makeWrapper, gtk2, glib, udev, alsa-lib, atk -, nspr, fontconfig, cairo, pango, nss, freetype, gnome2, gdk-pixbuf, curl, systemd, xorg, requireFile }: +{ + lib, + stdenv, + patchelf, + makeWrapper, + gtk2, + glib, + udev, + alsa-lib, + atk, + nspr, + fontconfig, + cairo, + pango, + nss, + freetype, + gnome2, + gdk-pixbuf, + curl, + systemd, + xorg, + requireFile, +}: stdenv.mkDerivation rec { pname = "planetary-annihalation"; @@ -11,7 +32,10 @@ stdenv.mkDerivation rec { sha256 = "0imi3k5144dsn3ka9khx3dj76klkw46ga7m6rddqjk4yslwabh3k"; }; - nativeBuildInputs = [ patchelf makeWrapper ]; + nativeBuildInputs = [ + patchelf + makeWrapper + ]; installPhase = '' mkdir -p $out/{bin,lib} @@ -23,12 +47,58 @@ stdenv.mkDerivation rec { ln -s ${systemd}/lib/libudev.so.1 $out/lib/libudev.so.0 patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" "$out/PA" - patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" --set-rpath "${lib.makeLibraryPath [ stdenv.cc.cc xorg.libXdamage xorg.libXfixes gtk2 glib stdenv.cc.libc "$out" xorg.libXext pango udev xorg.libX11 xorg.libXcomposite alsa-lib atk nspr fontconfig cairo pango nss freetype gnome2.GConf gdk-pixbuf xorg.libXrender ]}:${lib.getLib stdenv.cc.cc}/lib64:${stdenv.cc.libc}/lib64" "$out/host/CoherentUI_Host" + patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" --set-rpath "${ + lib.makeLibraryPath [ + stdenv.cc.cc + xorg.libXdamage + xorg.libXfixes + gtk2 + glib + stdenv.cc.libc + "$out" + xorg.libXext + pango + udev + xorg.libX11 + xorg.libXcomposite + alsa-lib + atk + nspr + fontconfig + cairo + pango + nss + freetype + gnome2.GConf + gdk-pixbuf + xorg.libXrender + ] + }:${lib.getLib stdenv.cc.cc}/lib64:${stdenv.cc.libc}/lib64" "$out/host/CoherentUI_Host" - wrapProgram $out/PA --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ stdenv.cc.cc stdenv.cc.libc xorg.libX11 xorg.libXcursor gtk2 glib curl "$out" ]}:${lib.getLib stdenv.cc.cc}/lib64:${stdenv.cc.libc}/lib64" + wrapProgram $out/PA --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + stdenv.cc.cc + stdenv.cc.libc + xorg.libX11 + xorg.libXcursor + gtk2 + glib + curl + "$out" + ] + }:${lib.getLib stdenv.cc.cc}/lib64:${stdenv.cc.libc}/lib64" for f in $out/lib/*; do - patchelf --set-rpath "${lib.makeLibraryPath [ stdenv.cc.cc curl xorg.libX11 stdenv.cc.libc xorg.libXcursor "$out" ]}:${lib.getLib stdenv.cc.cc}/lib64:${stdenv.cc.libc}/lib64" $f + patchelf --set-rpath "${ + lib.makeLibraryPath [ + stdenv.cc.cc + curl + xorg.libX11 + stdenv.cc.libc + xorg.libXcursor + "$out" + ] + }:${lib.getLib stdenv.cc.cc}/lib64:${stdenv.cc.libc}/lib64" $f done ''; diff --git a/pkgs/by-name/pl/planify/package.nix b/pkgs/by-name/pl/planify/package.nix index 06059f87fef862..66933b0b48af7b 100644 --- a/pkgs/by-name/pl/planify/package.nix +++ b/pkgs/by-name/pl/planify/package.nix @@ -1,29 +1,30 @@ -{ stdenv -, lib -, fetchFromGitHub -, desktop-file-utils -, meson -, ninja -, pkg-config -, vala -, wrapGAppsHook4 -, evolution-data-server-gtk4 -, glib -, glib-networking -, gst_all_1 -, gtk4 -, gtksourceview5 -, gxml -, json-glib -, libadwaita -, libgee -, libical -, libportal-gtk4 -, libsecret -, libsoup_3 -, pantheon -, sqlite -, webkitgtk_6_0 +{ + stdenv, + lib, + fetchFromGitHub, + desktop-file-utils, + meson, + ninja, + pkg-config, + vala, + wrapGAppsHook4, + evolution-data-server-gtk4, + glib, + glib-networking, + gst_all_1, + gtk4, + gtksourceview5, + gxml, + json-glib, + libadwaita, + libgee, + libical, + libportal-gtk4, + libsecret, + libsoup_3, + pantheon, + sqlite, + webkitgtk_6_0, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pl/plank/package.nix b/pkgs/by-name/pl/plank/package.nix index cd03f1521abfad..bcfc33c653fb61 100644 --- a/pkgs/by-name/pl/plank/package.nix +++ b/pkgs/by-name/pl/plank/package.nix @@ -1,28 +1,30 @@ -{ lib, stdenv -, fetchurl -, vala -, atk -, cairo -, dconf -, glib -, gnome-common -, gtk3 -, libwnck -, libX11 -, libXfixes -, libXi -, pango -, gettext -, pkg-config -, libxml2 -, bamf -, gdk-pixbuf -, libdbusmenu-gtk3 -, file -, gnome-menus -, libgee -, wrapGAppsHook3 -, autoreconfHook +{ + lib, + stdenv, + fetchurl, + vala, + atk, + cairo, + dconf, + glib, + gnome-common, + gtk3, + libwnck, + libX11, + libXfixes, + libXi, + pango, + gettext, + pkg-config, + libxml2, + bamf, + gdk-pixbuf, + libdbusmenu-gtk3, + file, + gnome-menus, + libgee, + wrapGAppsHook3, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pl/planner/package.nix b/pkgs/by-name/pl/planner/package.nix index e27fd037df446b..24b026d257d1e0 100644 --- a/pkgs/by-name/pl/planner/package.nix +++ b/pkgs/by-name/pl/planner/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitLab -, desktop-file-utils -, gsettings-desktop-schemas -, glib -, gtk3 -, libgda -, libxml2 -, libxslt -, makeWrapper -, meson -, ninja -, pkg-config -, shared-mime-info +{ + lib, + stdenv, + fetchFromGitLab, + desktop-file-utils, + gsettings-desktop-schemas, + glib, + gtk3, + libgda, + libxml2, + libxslt, + makeWrapper, + meson, + ninja, + pkg-config, + shared-mime-info, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pl/plano-theme/package.nix b/pkgs/by-name/pl/plano-theme/package.nix index c321dc235c49a5..a19385c8cd9979 100644 --- a/pkgs/by-name/pl/plano-theme/package.nix +++ b/pkgs/by-name/pl/plano-theme/package.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, fetchFromGitHub -, meson -, ninja -, gdk-pixbuf -, gtk_engines -, gtk-engine-murrine -, librsvg -, sassc +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + gdk-pixbuf, + gtk_engines, + gtk-engine-murrine, + librsvg, + sassc, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pl/planus/package.nix b/pkgs/by-name/pl/planus/package.nix index b92906e182651f..b0bde1b7caac6a 100644 --- a/pkgs/by-name/pl/planus/package.nix +++ b/pkgs/by-name/pl/planus/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchCrate -, installShellFiles -, stdenv +{ + lib, + rustPlatform, + fetchCrate, + installShellFiles, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -33,7 +34,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "planus"; homepage = "https://github.com/planus-org/planus"; changelog = "https://github.com/planus-org/planus/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/pl/plasma-hud/package.nix b/pkgs/by-name/pl/plasma-hud/package.nix index e70162b79af748..078bda093c5b85 100644 --- a/pkgs/by-name/pl/plasma-hud/package.nix +++ b/pkgs/by-name/pl/plasma-hud/package.nix @@ -1,9 +1,10 @@ -{ wrapGAppsHook3 -, lib -, python3Packages -, fetchFromGitHub -, rofi -, gobject-introspection +{ + wrapGAppsHook3, + lib, + python3Packages, + fetchFromGitHub, + rofi, + gobject-introspection, }: python3Packages.buildPythonApplication rec { @@ -23,12 +24,14 @@ python3Packages.buildPythonApplication rec { wrapGAppsHook3 ]; - propagatedBuildInputs = (with python3Packages; [ - dbus-python - pygobject3 - setproctitle - xlib - ]) ++ [ rofi ]; + propagatedBuildInputs = + (with python3Packages; [ + dbus-python + pygobject3 + setproctitle + xlib + ]) + ++ [ rofi ]; postPatch = '' sed -i "s:/usr/lib/plasma-hud:$out/bin:" etc/xdg/autostart/plasma-hud.desktop diff --git a/pkgs/by-name/pl/plasma-overdose-kde-theme/package.nix b/pkgs/by-name/pl/plasma-overdose-kde-theme/package.nix index dc80c669804a3f..261a1b10e2daf0 100644 --- a/pkgs/by-name/pl/plasma-overdose-kde-theme/package.nix +++ b/pkgs/by-name/pl/plasma-overdose-kde-theme/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "plasma-overdose-kde-theme"; diff --git a/pkgs/by-name/pl/platform-folders/package.nix b/pkgs/by-name/pl/platform-folders/package.nix index 27f4446891bd0c..5fa41c39159501 100644 --- a/pkgs/by-name/pl/platform-folders/package.nix +++ b/pkgs/by-name/pl/platform-folders/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, gitUpdater }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gitUpdater, +}: stdenv.mkDerivation rec { pname = "platform-folders"; diff --git a/pkgs/by-name/pl/platformsh/package.nix b/pkgs/by-name/pl/platformsh/package.nix index 730990f103ff4e..e5960098085d8a 100644 --- a/pkgs/by-name/pl/platformsh/package.nix +++ b/pkgs/by-name/pl/platformsh/package.nix @@ -4,18 +4,27 @@ fetchurl, testers, installShellFiles, - platformsh + platformsh, }: -let versions = lib.importJSON ./versions.json; - arch = if stdenvNoCC.hostPlatform.isx86_64 then "amd64" - else if stdenvNoCC.hostPlatform.isAarch64 then "arm64" - else throw "Unsupported architecture"; - os = if stdenvNoCC.hostPlatform.isLinux then "linux" - else if stdenvNoCC.hostPlatform.isDarwin then "darwin" - else throw "Unsupported os"; - versionInfo = versions."${os}-${arch}"; - inherit (versionInfo) hash url; +let + versions = lib.importJSON ./versions.json; + arch = + if stdenvNoCC.hostPlatform.isx86_64 then + "amd64" + else if stdenvNoCC.hostPlatform.isAarch64 then + "arm64" + else + throw "Unsupported architecture"; + os = + if stdenvNoCC.hostPlatform.isLinux then + "linux" + else if stdenvNoCC.hostPlatform.isDarwin then + "darwin" + else + throw "Unsupported os"; + versionInfo = versions."${os}-${arch}"; + inherit (versionInfo) hash url; in stdenvNoCC.mkDerivation (finalAttrs: { @@ -55,8 +64,16 @@ stdenvNoCC.mkDerivation (finalAttrs: { homepage = "https://github.com/platformsh/cli"; license = lib.licenses.mit; mainProgram = "platform"; - maintainers = with lib.maintainers; [ shyim spk ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + maintainers = with lib.maintainers; [ + shyim + spk + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; }; }) diff --git a/pkgs/by-name/pl/platinum-searcher/package.nix b/pkgs/by-name/pl/platinum-searcher/package.nix index 92386af9cb34e6..76568d9482e01d 100644 --- a/pkgs/by-name/pl/platinum-searcher/package.nix +++ b/pkgs/by-name/pl/platinum-searcher/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "the_platinum_searcher"; @@ -21,7 +26,10 @@ buildGoModule rec { }) ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/monochromegane/the_platinum_searcher"; diff --git a/pkgs/by-name/pl/platypus/package.nix b/pkgs/by-name/pl/platypus/package.nix index 56e18522139619..893377db79a171 100644 --- a/pkgs/by-name/pl/platypus/package.nix +++ b/pkgs/by-name/pl/platypus/package.nix @@ -1,8 +1,18 @@ -{lib, stdenv, fetchFromGitHub, python27, htslib, zlib, makeWrapper}: - -let python = python27.withPackages (ps: with ps; [ cython ]); - -in stdenv.mkDerivation { +{ + lib, + stdenv, + fetchFromGitHub, + python27, + htslib, + zlib, + makeWrapper, +}: + +let + python = python27.withPackages (ps: with ps; [ cython ]); + +in +stdenv.mkDerivation { pname = "platypus-unstable"; version = "2018-07-22"; @@ -14,7 +24,11 @@ in stdenv.mkDerivation { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ htslib python zlib ]; + buildInputs = [ + htslib + python + zlib + ]; buildPhase = '' patchShebangs . diff --git a/pkgs/by-name/pl/play-with-mpv/package.nix b/pkgs/by-name/pl/play-with-mpv/package.nix index 16e645eb44550f..32fba102e68008 100644 --- a/pkgs/by-name/pl/play-with-mpv/package.nix +++ b/pkgs/by-name/pl/play-with-mpv/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3Packages -, fetchFromGitHub -, fetchurl -, youtube-dl +{ + lib, + python3Packages, + fetchFromGitHub, + fetchurl, + youtube-dl, }: let diff --git a/pkgs/by-name/pl/playerctl/package.nix b/pkgs/by-name/pl/playerctl/package.nix index e65f9a20989b5b..e4a4b10d1e6df0 100644 --- a/pkgs/by-name/pl/playerctl/package.nix +++ b/pkgs/by-name/pl/playerctl/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, buildPackages -, docbook_xsl -, fetchFromGitHub -, glib -, gobject-introspection -, gtk-doc -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, withDocs ? stdenv.hostPlatform.emulatorAvailable buildPackages +{ + lib, + stdenv, + buildPackages, + docbook_xsl, + fetchFromGitHub, + glib, + gobject-introspection, + gtk-doc, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + withDocs ? stdenv.hostPlatform.emulatorAvailable buildPackages, }: stdenv.mkDerivation rec { @@ -24,16 +25,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-OiGKUnsKX0ihDRceZoNkcZcEAnz17h2j2QUOSVcxQEY="; }; - nativeBuildInputs = [ - docbook_xsl - gobject-introspection - gtk-doc - meson - ninja - pkg-config - ] ++ lib.optionals (withDocs && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + docbook_xsl + gobject-introspection + gtk-doc + meson + ninja + pkg-config + ] + ++ lib.optionals (withDocs && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ glib ]; mesonFlags = [ diff --git a/pkgs/by-name/pl/please-cli/package.nix b/pkgs/by-name/pl/please-cli/package.nix index 35d877d6eebe65..664b11dcfd2b75 100644 --- a/pkgs/by-name/pl/please-cli/package.nix +++ b/pkgs/by-name/pl/please-cli/package.nix @@ -1,11 +1,12 @@ -{ lib -, curl -, fetchFromGitHub -, jq -, makeBinaryWrapper -, please-cli -, stdenv -, testers +{ + lib, + curl, + fetchFromGitHub, + jq, + makeBinaryWrapper, + please-cli, + stdenv, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -25,7 +26,12 @@ stdenv.mkDerivation (finalAttrs: { runHook preInstall install -Dm555 please.sh "$out/bin/please" wrapProgram $out/bin/please \ - --prefix PATH : ${lib.makeBinPath [ curl jq ]} + --prefix PATH : ${ + lib.makeBinPath [ + curl + jq + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/pl/please/package.nix b/pkgs/by-name/pl/please/package.nix index 4cdaa9b8099f8f..f3616493419e02 100644 --- a/pkgs/by-name/pl/please/package.nix +++ b/pkgs/by-name/pl/please/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitLab -, installShellFiles -, pam -, nixosTests +{ + lib, + rustPlatform, + fetchFromGitLab, + installShellFiles, + pam, + nixosTests, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pl/plecost/package.nix b/pkgs/by-name/pl/plecost/package.nix index 477ed9e82645bb..942b0f232665b9 100644 --- a/pkgs/by-name/pl/plecost/package.nix +++ b/pkgs/by-name/pl/plecost/package.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchFromGitHub, fetchpatch }: +{ + lib, + python3Packages, + fetchFromGitHub, + fetchpatch, +}: python3Packages.buildPythonApplication rec { pname = "plecost"; diff --git a/pkgs/by-name/pl/plemoljp-hs/package.nix b/pkgs/by-name/pl/plemoljp-hs/package.nix index e96b5547263740..c459c6a39c048b 100644 --- a/pkgs/by-name/pl/plemoljp-hs/package.nix +++ b/pkgs/by-name/pl/plemoljp-hs/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "plemoljp-hs"; diff --git a/pkgs/by-name/pl/plemoljp-nf/package.nix b/pkgs/by-name/pl/plemoljp-nf/package.nix index c4675319ec0e62..c010d58baeb5f6 100644 --- a/pkgs/by-name/pl/plemoljp-nf/package.nix +++ b/pkgs/by-name/pl/plemoljp-nf/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "plemoljp-nf"; diff --git a/pkgs/by-name/pl/plemoljp/package.nix b/pkgs/by-name/pl/plemoljp/package.nix index 8f7f092de310c1..877a0295f3fd9a 100644 --- a/pkgs/by-name/pl/plemoljp/package.nix +++ b/pkgs/by-name/pl/plemoljp/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "plemoljp"; diff --git a/pkgs/by-name/pl/plib/package.nix b/pkgs/by-name/pl/plib/package.nix index de93d6944c9397..50c113b5466e19 100644 --- a/pkgs/by-name/pl/plib/package.nix +++ b/pkgs/by-name/pl/plib/package.nix @@ -1,5 +1,18 @@ -{ fetchurl, fetchpatch, lib, stdenv, libGLU, libGL, libglut, SDL -, libXi, libSM, libXmu, libXext, libX11 }: +{ + fetchurl, + fetchpatch, + lib, + stdenv, + libGLU, + libGL, + libglut, + SDL, + libXi, + libSM, + libXmu, + libXext, + libX11, +}: stdenv.mkDerivation rec { pname = "plib"; @@ -27,10 +40,17 @@ stdenv.mkDerivation rec { ]; propagatedBuildInputs = [ - libGLU libGL libglut SDL + libGLU + libGL + libglut + SDL # The following libs ought to be propagated build inputs of Mesa. - libXi libSM libXmu libXext libX11 + libXi + libSM + libXmu + libXext + libX11 ]; meta = { diff --git a/pkgs/by-name/pl/plink-ng/package.nix b/pkgs/by-name/pl/plink-ng/package.nix index b66bed97a94a5a..74b04c56eccea4 100644 --- a/pkgs/by-name/pl/plink-ng/package.nix +++ b/pkgs/by-name/pl/plink-ng/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, zlib, blas, lapack, darwin}: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + blas, + lapack, + darwin, +}: stdenv.mkDerivation rec { pname = "plink-ng"; @@ -11,7 +19,17 @@ stdenv.mkDerivation rec { sha256 = "1zhffjbwpd50dxywccbnv1rxy9njwz73l4awc5j7i28rgj3davcq"; }; - buildInputs = [ zlib ] ++ (if stdenv.hostPlatform.isDarwin then [ darwin.apple_sdk.frameworks.Accelerate ] else [ blas lapack ]) ; + buildInputs = + [ zlib ] + ++ ( + if stdenv.hostPlatform.isDarwin then + [ darwin.apple_sdk.frameworks.Accelerate ] + else + [ + blas + lapack + ] + ); preBuild = '' sed -i 's|zlib-1.2.8/zlib.h|zlib.h|g' *.c *.h diff --git a/pkgs/by-name/pl/plistcpp/package.nix b/pkgs/by-name/pl/plistcpp/package.nix index c2e765e4f5d052..4b1aea8d121851 100644 --- a/pkgs/by-name/pl/plistcpp/package.nix +++ b/pkgs/by-name/pl/plistcpp/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, boost -, nsplist -, pugixml +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + nsplist, + pugixml, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/pl/plistwatch/package.nix b/pkgs/by-name/pl/plistwatch/package.nix index 0c99363510c86f..691c164f623480 100644 --- a/pkgs/by-name/pl/plistwatch/package.nix +++ b/pkgs/by-name/pl/plistwatch/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/pl/plm/package.nix b/pkgs/by-name/pl/plm/package.nix index a0a16515e228d4..df50f2e1554b98 100644 --- a/pkgs/by-name/pl/plm/package.nix +++ b/pkgs/by-name/pl/plm/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre, gcc, valgrind }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, + gcc, + valgrind, +}: # gcc and valgrind are not strict dependencies, they could be made # optional. They are here because plm can only help you learn C if you # have them installed. @@ -13,7 +21,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ jre gcc valgrind ]; + buildInputs = [ + jre + gcc + valgrind + ]; dontUnpack = true; diff --git a/pkgs/by-name/pl/plocate/package.nix b/pkgs/by-name/pl/plocate/package.nix index ebd751d1caf929..5a38cd82123f61 100644 --- a/pkgs/by-name/pl/plocate/package.nix +++ b/pkgs/by-name/pl/plocate/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchgit -, pkg-config -, meson -, ninja -, systemd -, liburing -, zstd +{ + stdenv, + lib, + fetchgit, + pkg-config, + meson, + ninja, + systemd, + liburing, + zstd, }: stdenv.mkDerivation rec { pname = "plocate"; @@ -23,9 +24,17 @@ stdenv.mkDerivation rec { -e '/mkdir\.sh/d' ''; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; - buildInputs = [ systemd liburing zstd ]; + buildInputs = [ + systemd + liburing + zstd + ]; mesonFlags = [ "-Dsystemunitdir=${placeholder "out"}/etc/systemd/system" @@ -37,7 +46,10 @@ stdenv.mkDerivation rec { description = "Much faster locate"; homepage = "https://plocate.sesse.net/"; license = licenses.mit; - maintainers = with maintainers; [ peterhoeg SuperSandro2000 ]; + maintainers = with maintainers; [ + peterhoeg + SuperSandro2000 + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/pl/plog/package.nix b/pkgs/by-name/pl/plog/package.nix index 45b0fa49a1ab5a..87d8e066ec861f 100644 --- a/pkgs/by-name/pl/plog/package.nix +++ b/pkgs/by-name/pl/plog/package.nix @@ -1,14 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { pname = "plog"; version = "1.1.10"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "SergiusTheBest"; @@ -31,6 +35,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/SergiusTheBest/plog"; license = licenses.mit; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ raphaelr erdnaxe ]; + maintainers = with maintainers; [ + raphaelr + erdnaxe + ]; }; } diff --git a/pkgs/by-name/pl/ploticus/package.nix b/pkgs/by-name/pl/ploticus/package.nix index b9ffbe78b0bf6b..63f2409da4b82c 100644 --- a/pkgs/by-name/pl/ploticus/package.nix +++ b/pkgs/by-name/pl/ploticus/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, zlib -, libX11 -, libpng -, libjpeg -, gd -, freetype -, runCommand +{ + lib, + stdenv, + fetchurl, + zlib, + libX11, + libpng, + libjpeg, + gd, + freetype, + runCommand, }: stdenv.mkDerivation (finalAttrs: { @@ -15,7 +16,9 @@ stdenv.mkDerivation (finalAttrs: { version = "2.42"; src = fetchurl { - url = "mirror://sourceforge/ploticus/ploticus/${finalAttrs.version}/ploticus${lib.replaceStrings [ "." ] [ "" ] finalAttrs.version}_src.tar.gz"; + url = "mirror://sourceforge/ploticus/ploticus/${finalAttrs.version}/ploticus${ + lib.replaceStrings [ "." ] [ "" ] finalAttrs.version + }_src.tar.gz"; sha256 = "PynkufQFIDqT7+yQDlgW2eG0OBghiB4kHAjKt91m4LA="; }; @@ -69,13 +72,16 @@ stdenv.mkDerivation (finalAttrs: { ''; passthru.tests = { - prefab = runCommand "ploticus-prefab-test" { - nativeBuildInputs = [ finalAttrs.finalPackage ]; - } '' - # trivial test to see if the prefab path munging works - mkdir $out/ - pl -prefab scat inlinedata="A 1 2" x=2 y=3 -png -o $out/out.png - ''; + prefab = + runCommand "ploticus-prefab-test" + { + nativeBuildInputs = [ finalAttrs.finalPackage ]; + } + '' + # trivial test to see if the prefab path munging works + mkdir $out/ + pl -prefab scat inlinedata="A 1 2" x=2 y=3 -png -o $out/out.png + ''; }; meta = with lib; { diff --git a/pkgs/by-name/pl/plotinus/package.nix b/pkgs/by-name/pl/plotinus/package.nix index f8b50d55cdf497..4d66711a32202b 100644 --- a/pkgs/by-name/pl/plotinus/package.nix +++ b/pkgs/by-name/pl/plotinus/package.nix @@ -1,14 +1,17 @@ -{ lib, stdenv -, fetchFromGitHub -, gettext -, libxml2 -, pkg-config -, gtk3 -, cmake -, ninja -, vala -, nixosTests -, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + gettext, + libxml2, + pkg-config, + gtk3, + cmake, + ninja, + vala, + nixosTests, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "plotinus"; diff --git a/pkgs/by-name/pl/plots/package.nix b/pkgs/by-name/pl/plots/package.nix index c53a0a57beb3bc..781309d7aa5484 100644 --- a/pkgs/by-name/pl/plots/package.nix +++ b/pkgs/by-name/pl/plots/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, python3Packages -, gobject-introspection -, libadwaita -, wrapGAppsHook4 -, lmmath +{ + lib, + fetchFromGitHub, + python3Packages, + gobject-introspection, + libadwaita, + wrapGAppsHook4, + lmmath, }: python3Packages.buildPythonApplication rec { @@ -18,7 +19,10 @@ python3Packages.buildPythonApplication rec { hash = "sha256-GjNpaorxkkhZsqrKq4kO5nqF5+4I4tmSc023AZpY8Sw="; }; - nativeBuildInputs = [ gobject-introspection wrapGAppsHook4 ]; + nativeBuildInputs = [ + gobject-introspection + wrapGAppsHook4 + ]; buildInputs = [ libadwaita ]; propagatedBuildInputs = with python3Packages; [ diff --git a/pkgs/by-name/pl/plotutils/package.nix b/pkgs/by-name/pl/plotutils/package.nix index da1aeb806ecac8..18f3da2c1bcdd3 100644 --- a/pkgs/by-name/pl/plotutils/package.nix +++ b/pkgs/by-name/pl/plotutils/package.nix @@ -1,4 +1,10 @@ -{ fetchurl, lib, stdenv, libpng, autoreconfHook }: +{ + fetchurl, + lib, + stdenv, + libpng, + autoreconfHook, +}: # debian splits this package into plotutils and libplot2c2 @@ -16,7 +22,8 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; buildInputs = [ libpng ]; - patches = map fetchurl (import ./debian-patches.nix) + patches = + map fetchurl (import ./debian-patches.nix) # `pic2plot/gram.cc` uses the register storage class specifier, which is not supported in C++17. # This prevents clang 16 from building plotutils because it defaults to C++17. ++ [ ./c++17-register-usage-fix.patch ]; diff --git a/pkgs/by-name/pl/plow/package.nix b/pkgs/by-name/pl/plow/package.nix index 981787d16d94d0..25baa628f55fdc 100644 --- a/pkgs/by-name/pl/plow/package.nix +++ b/pkgs/by-name/pl/plow/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, plow }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + plow, +}: buildGoModule rec { pname = "plow"; @@ -13,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-t2lBPyCn8bu9hLsWmaCGir9egbX0mQR+8kB0RfY7nHE="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests.version = testers.testVersion { package = plow; diff --git a/pkgs/by-name/pl/plowshare/package.nix b/pkgs/by-name/pl/plowshare/package.nix index 36151642767436..50ccefde02a2cb 100644 --- a/pkgs/by-name/pl/plowshare/package.nix +++ b/pkgs/by-name/pl/plowshare/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, curl, recode, spidermonkey_115 }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + curl, + recode, + spidermonkey_115, +}: stdenv.mkDerivation rec { @@ -20,7 +28,13 @@ stdenv.mkDerivation rec { make PREFIX="$out" install for fn in plow{del,down,list,mod,probe,up}; do - wrapProgram "$out/bin/$fn" --prefix PATH : "${lib.makeBinPath [ curl recode spidermonkey_115 ]}" + wrapProgram "$out/bin/$fn" --prefix PATH : "${ + lib.makeBinPath [ + curl + recode + spidermonkey_115 + ] + }" done ''; diff --git a/pkgs/by-name/pl/pls/package.nix b/pkgs/by-name/pl/pls/package.nix index 0b51b8bad0ba84..b4a0b9a5f50f93 100644 --- a/pkgs/by-name/pl/pls/package.nix +++ b/pkgs/by-name/pl/pls/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pl/plugdata/package.nix b/pkgs/by-name/pl/plugdata/package.nix index 6998cb00eaebbe..1d6fa9ce4e240b 100644 --- a/pkgs/by-name/pl/plugdata/package.nix +++ b/pkgs/by-name/pl/plugdata/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, ensureNewerSourcesForZipFilesHook -, makeDesktopItem -, imagemagick -, cmake -, pkg-config -, alsa-lib -, freetype -, webkitgtk_4_0 -, zenity -, curl -, xorg -, python3 -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + ensureNewerSourcesForZipFilesHook, + makeDesktopItem, + imagemagick, + cmake, + pkg-config, + alsa-lib, + freetype, + webkitgtk_4_0, + zenity, + curl, + xorg, + python3, + makeWrapper, }: let @@ -25,7 +26,10 @@ let icon = "plugdata_logo.png"; comment = "Pure Data as a plugin, with a new GUI"; type = "Application"; - categories = [ "AudioVideo" "Music" ]; + categories = [ + "AudioVideo" + "Music" + ]; }; in stdenv.mkDerivation (finalAttrs: { @@ -61,14 +65,16 @@ stdenv.mkDerivation (finalAttrs: { xorg.libXrandr ]; # Standard fix for JUCE programs: https://github.com/NixOS/nixpkgs/blob/5014727e62ae7b22fb1afc61d789ca6ad9170435/pkgs/applications/audio/bespokesynth/default.nix#L137 - env.NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isLinux "-rpath ${lib.makeLibraryPath ([ - xorg.libX11 - xorg.libXrandr - xorg.libXinerama - xorg.libXext - xorg.libXcursor - xorg.libXrender - ])}"; + env.NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isLinux "-rpath ${ + lib.makeLibraryPath ([ + xorg.libX11 + xorg.libXrandr + xorg.libXinerama + xorg.libXext + xorg.libXcursor + xorg.libXrender + ]) + }"; dontPatchELF = true; # needed or nix will try to optimize the binary by removing "useless" rpath postPatch = '' @@ -98,18 +104,22 @@ stdenv.mkDerivation (finalAttrs: { ''; postInstall = '' - # Ensure zenity is available, or it won't be able to open new files. - # These X11 libs get dlopen'd, they cause visual bugs when unavailable. - wrapProgram $out/bin/plugdata \ - --prefix PATH : '${lib.makeBinPath [ + # Ensure zenity is available, or it won't be able to open new files. + # These X11 libs get dlopen'd, they cause visual bugs when unavailable. + wrapProgram $out/bin/plugdata \ + --prefix PATH : '${ + lib.makeBinPath [ zenity - ]}' \ - --prefix LD_LIBRARY_PATH : '${lib.makeLibraryPath [ - xorg.libXrandr - xorg.libXinerama - xorg.libXcursor - xorg.libXrender - ]}' + ] + }' \ + --prefix LD_LIBRARY_PATH : '${ + lib.makeLibraryPath [ + xorg.libXrandr + xorg.libXinerama + xorg.libXcursor + xorg.libXrender + ] + }' ''; meta = with lib; { diff --git a/pkgs/by-name/pl/plugin-torture/package.nix b/pkgs/by-name/pl/plugin-torture/package.nix index 4b5f0c4acd2f99..5e116eb6e3ef86 100644 --- a/pkgs/by-name/pl/plugin-torture/package.nix +++ b/pkgs/by-name/pl/plugin-torture/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, boost, ladspaH, lilv, lv2, pkg-config, serd, sord, sratom }: +{ + lib, + stdenv, + fetchFromGitHub, + boost, + ladspaH, + lilv, + lv2, + pkg-config, + serd, + sord, + sratom, +}: stdenv.mkDerivation { pname = "plugin-torture"; @@ -12,7 +24,15 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ boost ladspaH lilv lv2 serd sord sratom ]; + buildInputs = [ + boost + ladspaH + lilv + lv2 + serd + sord + sratom + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/pl/plujain-ramp/package.nix b/pkgs/by-name/pl/plujain-ramp/package.nix index c8af8a1c5a1e7c..de8c14bf4032a0 100644 --- a/pkgs/by-name/pl/plujain-ramp/package.nix +++ b/pkgs/by-name/pl/plujain-ramp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + lv2, +}: stdenv.mkDerivation rec { version = "1.1.3"; diff --git a/pkgs/by-name/pl/plumber/package.nix b/pkgs/by-name/pl/plumber/package.nix index 28265a13c4450b..febd8ca76fb41b 100644 --- a/pkgs/by-name/pl/plumber/package.nix +++ b/pkgs/by-name/pl/plumber/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "plumber"; diff --git a/pkgs/by-name/pl/plumed/package.nix b/pkgs/by-name/pl/plumed/package.nix index 643ee2bc228c0c..3809e5fccc84cc 100644 --- a/pkgs/by-name/pl/plumed/package.nix +++ b/pkgs/by-name/pl/plumed/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, blas +{ + stdenv, + lib, + fetchFromGitHub, + blas, }: assert !blas.isILP64; diff --git a/pkgs/by-name/pl/pluto/package.nix b/pkgs/by-name/pl/pluto/package.nix index 66bd0f480bdb5d..4ce48aceaf4fda 100644 --- a/pkgs/by-name/pl/pluto/package.nix +++ b/pkgs/by-name/pl/pluto/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pluto"; @@ -14,7 +18,8 @@ buildGoModule rec { vendorHash = "sha256-VkaFANSzKOpmHWUwFp7YjwvsJegcJOrvJOBNNAIxOak="; ldflags = [ - "-w" "-s" + "-w" + "-s" "-X main.version=v${version}" ]; @@ -23,6 +28,9 @@ buildGoModule rec { description = "Find deprecated Kubernetes apiVersions"; mainProgram = "pluto"; license = licenses.asl20; - maintainers = with maintainers; [ peterromfeldhk kashw2 ]; + maintainers = with maintainers; [ + peterromfeldhk + kashw2 + ]; }; } diff --git a/pkgs/by-name/pl/plymouth/package.nix b/pkgs/by-name/pl/plymouth/package.nix index aa4daabb3a9abc..ae5e4ee2339c43 100644 --- a/pkgs/by-name/pl/plymouth/package.nix +++ b/pkgs/by-name/pl/plymouth/package.nix @@ -1,30 +1,34 @@ -{ lib -, stdenv -, fetchFromGitLab -, writeText -, substituteAll -, meson -, pkg-config -, ninja -, docbook-xsl-nons -, gettext -, libxslt -, gtk3 -, libdrm -, libevdev -, libpng -, libxkbcommon -, pango -, systemd -, xorg -, fontconfig +{ + lib, + stdenv, + fetchFromGitLab, + writeText, + substituteAll, + meson, + pkg-config, + ninja, + docbook-xsl-nons, + gettext, + libxslt, + gtk3, + libdrm, + libevdev, + libpng, + libxkbcommon, + pango, + systemd, + xorg, + fontconfig, }: stdenv.mkDerivation (finalAttrs: { pname = "plymouth"; version = "24.004.60"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitLab { domain = "gitlab.freedesktop.org"; @@ -68,25 +72,27 @@ stdenv.mkDerivation (finalAttrs: { xorg.xkeyboardconfig ]; - mesonFlags = let - # https://gitlab.freedesktop.org/plymouth/plymouth/-/blob/a5eda165689864cc9a25ec14fd8c6da458598f42/meson.build#L47 - crossFile = writeText "cross-file.conf" '' - [binaries] - systemd-tty-ask-password-agent = '${lib.getBin systemd}/bin/systemd-tty-ask-password-agent' - ''; - in [ - "--sysconfdir=/etc" - "--localstatedir=/var" - "-Dlogo=/etc/plymouth/logo.png" - "-Dbackground-color=0x000000" - "-Dbackground-start-color-stop=0x000000" - "-Dbackground-end-color-stop=0x000000" - "-Drelease-file=/etc/os-release" - "-Dudev=enabled" - "-Drunstatedir=/run" - "-Druntime-plugins=true" - "--cross-file=${crossFile}" - ]; + mesonFlags = + let + # https://gitlab.freedesktop.org/plymouth/plymouth/-/blob/a5eda165689864cc9a25ec14fd8c6da458598f42/meson.build#L47 + crossFile = writeText "cross-file.conf" '' + [binaries] + systemd-tty-ask-password-agent = '${lib.getBin systemd}/bin/systemd-tty-ask-password-agent' + ''; + in + [ + "--sysconfdir=/etc" + "--localstatedir=/var" + "-Dlogo=/etc/plymouth/logo.png" + "-Dbackground-color=0x000000" + "-Dbackground-start-color-stop=0x000000" + "-Dbackground-end-color-stop=0x000000" + "-Drelease-file=/etc/os-release" + "-Dudev=enabled" + "-Drunstatedir=/run" + "-Druntime-plugins=true" + "--cross-file=${crossFile}" + ]; postPatch = '' substituteInPlace meson.build \ diff --git a/pkgs/by-name/pl/plzip/package.nix b/pkgs/by-name/pl/plzip/package.nix index 4e361f6a32116a..82a8c0b6f3c3a1 100644 --- a/pkgs/by-name/pl/plzip/package.nix +++ b/pkgs/by-name/pl/plzip/package.nix @@ -1,9 +1,20 @@ -{ lib, stdenv, fetchurl, lzip, lzlib, texinfo }: +{ + lib, + stdenv, + fetchurl, + lzip, + lzlib, + texinfo, +}: stdenv.mkDerivation (finalAttrs: { pname = "plzip"; version = "1.11"; - outputs = [ "out" "man" "info" ]; + outputs = [ + "out" + "man" + "info" + ]; src = fetchurl { url = "mirror://savannah/lzip/plzip/plzip-${finalAttrs.version}.tar.lz"; @@ -11,7 +22,10 @@ stdenv.mkDerivation (finalAttrs: { # hash from release email }; - nativeBuildInputs = [ lzip texinfo ]; + nativeBuildInputs = [ + lzip + texinfo + ]; buildInputs = [ lzlib ]; enableParallelBuilding = true; @@ -23,7 +37,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Massively parallel lossless data compressor based on the lzlib compression library"; license = lib.licenses.gpl2Plus; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ _360ied ehmry ]; + maintainers = with lib.maintainers; [ + _360ied + ehmry + ]; mainProgram = "plzip"; }; }) diff --git a/pkgs/by-name/pm/pm2/package.nix b/pkgs/by-name/pm/pm2/package.nix index 271c4eec105c8d..6884ea8d91ebfd 100644 --- a/pkgs/by-name/pm/pm2/package.nix +++ b/pkgs/by-name/pm/pm2/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/pm/pmacct/package.nix b/pkgs/by-name/pm/pmacct/package.nix index 3cd43ec9a873c7..7687e19493e58d 100644 --- a/pkgs/by-name/pm/pmacct/package.nix +++ b/pkgs/by-name/pm/pmacct/package.nix @@ -1,19 +1,28 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, autoreconfHook -, libtool -, libpcap -, libcdada -# Optional Dependencies -, withJansson ? true, jansson -, withNflog ? true, libnetfilter_log -, withSQLite ? true, sqlite -, withPgSQL ? true, postgresql -, withMysql ? true, libmysqlclient, zlib, numactl -, gnutlsSupport ? false, gnutls -, testers +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + libtool, + libpcap, + libcdada, + # Optional Dependencies + withJansson ? true, + jansson, + withNflog ? true, + libnetfilter_log, + withSQLite ? true, + sqlite, + withPgSQL ? true, + postgresql, + withMysql ? true, + libmysqlclient, + zlib, + numactl, + gnutlsSupport ? false, + gnutls, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -32,29 +41,40 @@ stdenv.mkDerivation (finalAttrs: { pkg-config libtool ]; - buildInputs = [ - libcdada - libpcap - ] ++ lib.optional withJansson jansson - ++ lib.optional withNflog libnetfilter_log - ++ lib.optional withSQLite sqlite - ++ lib.optional withPgSQL postgresql - ++ lib.optionals withMysql [ libmysqlclient zlib numactl ] - ++ lib.optional gnutlsSupport gnutls; + buildInputs = + [ + libcdada + libpcap + ] + ++ lib.optional withJansson jansson + ++ lib.optional withNflog libnetfilter_log + ++ lib.optional withSQLite sqlite + ++ lib.optional withPgSQL postgresql + ++ lib.optionals withMysql [ + libmysqlclient + zlib + numactl + ] + ++ lib.optional gnutlsSupport gnutls; MYSQL_CONFIG = lib.optionalString withMysql "${lib.getDev libmysqlclient}/bin/mysql_config"; - configureFlags = [ - "--with-pcap-includes=${libpcap}/include" - ] ++ lib.optional withJansson "--enable-jansson" - ++ lib.optional withNflog "--enable-nflog" - ++ lib.optional withSQLite "--enable-sqlite3" - ++ lib.optional withPgSQL "--enable-pgsql" - ++ lib.optional withMysql "--enable-mysql" - ++ lib.optional gnutlsSupport "--enable-gnutls"; + configureFlags = + [ + "--with-pcap-includes=${libpcap}/include" + ] + ++ lib.optional withJansson "--enable-jansson" + ++ lib.optional withNflog "--enable-nflog" + ++ lib.optional withSQLite "--enable-sqlite3" + ++ lib.optional withPgSQL "--enable-pgsql" + ++ lib.optional withMysql "--enable-mysql" + ++ lib.optional gnutlsSupport "--enable-gnutls"; passthru.tests = { - version = testers.testVersion { package = finalAttrs.finalPackage; command = "pmacct -V"; }; + version = testers.testVersion { + package = finalAttrs.finalPackage; + command = "pmacct -V"; + }; }; meta = with lib; { diff --git a/pkgs/by-name/pm/pmbootstrap/package.nix b/pkgs/by-name/pm/pmbootstrap/package.nix index 1263a698840610..8cff6df159f232 100644 --- a/pkgs/by-name/pm/pmbootstrap/package.nix +++ b/pkgs/by-name/pm/pmbootstrap/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, git -, multipath-tools -, openssl -, ps -, fetchFromGitLab -, sudo -, python3Packages -, gitUpdater +{ + stdenv, + lib, + git, + multipath-tools, + openssl, + ps, + fetchFromGitLab, + sudo, + python3Packages, + gitUpdater, }: python3Packages.buildPythonApplication rec { @@ -113,16 +114,26 @@ python3Packages.buildPythonApplication rec { "test_version" ]; - makeWrapperArgs = [ "--prefix PATH : ${lib.makeBinPath [ git openssl multipath-tools ]}" ]; + makeWrapperArgs = [ + "--prefix PATH : ${ + lib.makeBinPath [ + git + openssl + multipath-tools + ] + }" + ]; passthru.updateScript = gitUpdater { }; meta = with lib; { - description = - "Sophisticated chroot/build/flash tool to develop and install postmarketOS"; + description = "Sophisticated chroot/build/flash tool to develop and install postmarketOS"; homepage = "https://gitlab.com/postmarketOS/pmbootstrap"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ onny lucasew ]; + maintainers = with maintainers; [ + onny + lucasew + ]; mainProgram = "pmbootstrap"; }; } diff --git a/pkgs/by-name/pm/pmccabe/package.nix b/pkgs/by-name/pm/pmccabe/package.nix index 1fd58fd14a2fe5..9f3982397daec3 100644 --- a/pkgs/by-name/pm/pmccabe/package.nix +++ b/pkgs/by-name/pm/pmccabe/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "pmccabe"; @@ -19,7 +23,7 @@ stdenv.mkDerivation rec { -e "s,^DESTDIR =.*$,DESTDIR = $out," \ -e "s,^INSTALL = install.*$,INSTALL = install," \ -e "s,^all:.*$,all: \$(PROGS)," - ''; + ''; checkPhase = "make test"; diff --git a/pkgs/by-name/pm/pmenu/package.nix b/pkgs/by-name/pm/pmenu/package.nix index 5fbcff2b291153..f61fdc5859e2b1 100644 --- a/pkgs/by-name/pm/pmenu/package.nix +++ b/pkgs/by-name/pm/pmenu/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, writeText -, fontconfig -, imlib2 -, libX11 -, libXext -, libXft -, libXinerama -, libXrender -, conf ? null +{ + lib, + stdenv, + fetchFromGitHub, + writeText, + fontconfig, + imlib2, + libX11, + libXext, + libXft, + libXinerama, + libXrender, + conf ? null, }: stdenv.mkDerivation (finalAttrs: { @@ -33,10 +34,10 @@ stdenv.mkDerivation (finalAttrs: { libXrender ]; - postPatch = let + postPatch = + let configFile = - if lib.isDerivation conf || builtins.isPath conf - then conf else writeText "config.h" conf; + if lib.isDerivation conf || builtins.isPath conf then conf else writeText "config.h" conf; in lib.optionalString (conf != null) "mv ${configFile} config.h"; diff --git a/pkgs/by-name/pm/pmidi/package.nix b/pkgs/by-name/pm/pmidi/package.nix index f2e2310bd4c479..e8c6212d99e1bf 100644 --- a/pkgs/by-name/pm/pmidi/package.nix +++ b/pkgs/by-name/pm/pmidi/package.nix @@ -1,6 +1,10 @@ -{ lib, stdenv, fetchurl, alsa-lib -, version ? "1.7.1" -, sourceSha256 ? "051mv6f13c8y13c1iv3279k1hhzpz4fm9sfczhgp9sim2bjdj055" +{ + lib, + stdenv, + fetchurl, + alsa-lib, + version ? "1.7.1", + sourceSha256 ? "051mv6f13c8y13c1iv3279k1hhzpz4fm9sfczhgp9sim2bjdj055", }: stdenv.mkDerivation { pname = "pmidi"; diff --git a/pkgs/by-name/pm/pmount/package.nix b/pkgs/by-name/pm/pmount/package.nix index 94ab7b7e3c2db1..7e52083021d4f7 100644 --- a/pkgs/by-name/pm/pmount/package.nix +++ b/pkgs/by-name/pm/pmount/package.nix @@ -1,7 +1,13 @@ -{ lib, stdenv, fetchurl, intltool, ntfs3g, util-linux -, mediaDir ? "/media/" -, lockDir ? "/var/lock/pmount" -, whiteList ? "/etc/pmount.allow" +{ + lib, + stdenv, + fetchurl, + intltool, + ntfs3g, + util-linux, + mediaDir ? "/media/", + lockDir ? "/var/lock/pmount", + whiteList ? "/etc/pmount.allow", }: # constraint mention in the configure.ac @@ -16,7 +22,10 @@ stdenv.mkDerivation rec { sha256 = "db38fc290b710e8e9e9d442da2fb627d41e13b3ee80326c15cc2595ba00ea036"; }; - nativeBuildInputs = [ intltool util-linux ]; + nativeBuildInputs = [ + intltool + util-linux + ]; buildInputs = [ util-linux ]; configureFlags = [ diff --git a/pkgs/by-name/pm/pms/package.nix b/pkgs/by-name/pm/pms/package.nix index 77883d27834ff3..08205cc9fd5089 100644 --- a/pkgs/by-name/pm/pms/package.nix +++ b/pkgs/by-name/pm/pms/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule { pname = "pms"; diff --git a/pkgs/by-name/pm/pmtiles/package.nix b/pkgs/by-name/pm/pmtiles/package.nix index 056a5fa2dbd0aa..567c9a4749e6e7 100644 --- a/pkgs/by-name/pm/pmtiles/package.nix +++ b/pkgs/by-name/pm/pmtiles/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pmtiles"; version = "1.22.2"; @@ -12,7 +16,12 @@ buildGoModule rec { vendorHash = "sha256-KRjMEH17cvSjtRP/qYeWRFUo6f6v1ZxEd+H3xvZ1udQ="; - ldflags = [ "-s" "-w" "-X main.version=${version}" "-X main.commit=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + "-X main.commit=v${version}" + ]; postInstall = '' mv $out/bin/go-pmtiles $out/bin/pmtiles diff --git a/pkgs/by-name/pm/pmutils/package.nix b/pkgs/by-name/pm/pmutils/package.nix index 3eccb6381cd170..f1301f1670b7cf 100644 --- a/pkgs/by-name/pm/pmutils/package.nix +++ b/pkgs/by-name/pm/pmutils/package.nix @@ -1,13 +1,29 @@ -{ lib, stdenv, fetchurl, coreutils, gnugrep, util-linux, kmod -, procps, kbd, dbus }: +{ + lib, + stdenv, + fetchurl, + coreutils, + gnugrep, + util-linux, + kmod, + procps, + kbd, + dbus, +}: let - binPath = lib.makeBinPath - [ coreutils gnugrep util-linux kmod procps kbd dbus ]; + binPath = lib.makeBinPath [ + coreutils + gnugrep + util-linux + kmod + procps + kbd + dbus + ]; - sbinPath = lib.makeSearchPathOutput "bin" "sbin" - [ procps ]; + sbinPath = lib.makeSearchPathOutput "bin" "sbin" [ procps ]; in @@ -22,30 +38,28 @@ stdenv.mkDerivation rec { configureFlags = [ "--sysconfdir=/etc" ]; - preConfigure = - '' - # Install the manpages (xmlto isn't really needed). - substituteInPlace man/Makefile.in --replace '@HAVE_XMLTO_TRUE@' "" + preConfigure = '' + # Install the manpages (xmlto isn't really needed). + substituteInPlace man/Makefile.in --replace '@HAVE_XMLTO_TRUE@' "" - # Set the PATH properly. - substituteInPlace pm/pm-functions.in --replace '/sbin:/usr/sbin:/bin:/usr/bin' '$PATH:${binPath}:${sbinPath}' + # Set the PATH properly. + substituteInPlace pm/pm-functions.in --replace '/sbin:/usr/sbin:/bin:/usr/bin' '$PATH:${binPath}:${sbinPath}' - substituteInPlace src/pm-action.in --replace 'tr ' '${coreutils}/bin/tr ' + substituteInPlace src/pm-action.in --replace 'tr ' '${coreutils}/bin/tr ' - substituteInPlace pm/sleep.d/00logging --replace /bin/uname "$(type -P uname)" + substituteInPlace pm/sleep.d/00logging --replace /bin/uname "$(type -P uname)" - substituteInPlace pm/sleep.d/90clock --replace /sbin/hwclock hwclock - ''; + substituteInPlace pm/sleep.d/90clock --replace /sbin/hwclock hwclock + ''; - postInstall = - '' - # Remove some hooks that have doubtful usefulness. See - # http://zinc.canonical.com/~cking/power-benchmarking/pm-utils-results/results.txt. - # In particular, journal-commit breaks things if you have - # read-only bind mounts, since it ends up remounting the - # underlying filesystem read-only. - rm $out/lib/pm-utils/power.d/{journal-commit,readahead} - ''; + postInstall = '' + # Remove some hooks that have doubtful usefulness. See + # http://zinc.canonical.com/~cking/power-benchmarking/pm-utils-results/results.txt. + # In particular, journal-commit breaks things if you have + # read-only bind mounts, since it ends up remounting the + # underlying filesystem read-only. + rm $out/lib/pm-utils/power.d/{journal-commit,readahead} + ''; meta = { homepage = "https://pm-utils.freedesktop.org/wiki/"; diff --git a/pkgs/by-name/pn/pn/package.nix b/pkgs/by-name/pn/pn/package.nix index ddb6e6ea1f888d..9eeec4cde95245 100644 --- a/pkgs/by-name/pn/pn/package.nix +++ b/pkgs/by-name/pn/pn/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libphonenumber, icu, protobuf }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libphonenumber, + icu, + protobuf, +}: stdenv.mkDerivation rec { pname = "pn"; @@ -12,7 +20,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libphonenumber icu protobuf ]; + buildInputs = [ + libphonenumber + icu + protobuf + ]; meta = with lib; { description = "Libphonenumber command-line wrapper"; diff --git a/pkgs/by-name/pn/pnfft/package.nix b/pkgs/by-name/pn/pnfft/package.nix index 10d6278aec8bfb..8d6b9bfcb6d7d9 100644 --- a/pkgs/by-name/pn/pnfft/package.nix +++ b/pkgs/by-name/pn/pnfft/package.nix @@ -1,15 +1,20 @@ -{ autoreconfHook -, fetchurl -, fftwMpi -, gsl -, lib -, llvmPackages -, pfft -, precision ? "double" -, stdenv +{ + autoreconfHook, + fetchurl, + fftwMpi, + gsl, + lib, + llvmPackages, + pfft, + precision ? "double", + stdenv, }: -assert lib.elem precision [ "single" "double" "long-double" ]; +assert lib.elem precision [ + "single" + "double" + "long-double" +]; let fftw' = fftwMpi.override { inherit precision; }; @@ -24,7 +29,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-/aVY/1fuMRl1Q2O7bmc5M4aA0taGD+fcQgCdhVYr1no="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ autoreconfHook ]; diff --git a/pkgs/by-name/pn/pngcheck/package.nix b/pkgs/by-name/pn/pngcheck/package.nix index d6ed7a6960fc3e..f6bc2a5f3e4680 100644 --- a/pkgs/by-name/pn/pngcheck/package.nix +++ b/pkgs/by-name/pn/pngcheck/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, zlib, installShellFiles }: +{ + lib, + stdenv, + fetchurl, + zlib, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "pngcheck"; diff --git a/pkgs/by-name/pn/pngcrush/package.nix b/pkgs/by-name/pn/pngcrush/package.nix index ba9911b264ed51..0fac3e2168d6b4 100644 --- a/pkgs/by-name/pn/pngcrush/package.nix +++ b/pkgs/by-name/pn/pngcrush/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fetchpatch2, libpng }: +{ + lib, + stdenv, + fetchurl, + fetchpatch2, + libpng, +}: stdenv.mkDerivation rec { pname = "pngcrush"; @@ -16,7 +22,10 @@ stdenv.mkDerivation rec { }) ]; - makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "LD=${stdenv.cc.targetPrefix}cc" ]; # gcc and/or clang compat + makeFlags = [ + "CC=${stdenv.cc.targetPrefix}cc" + "LD=${stdenv.cc.targetPrefix}cc" + ]; # gcc and/or clang compat configurePhase = '' sed -i s,/usr,$out, Makefile diff --git a/pkgs/by-name/pn/pngloss/package.nix b/pkgs/by-name/pn/pngloss/package.nix index 7eca91f42d7dc1..6fe7c035c61ab6 100644 --- a/pkgs/by-name/pn/pngloss/package.nix +++ b/pkgs/by-name/pn/pngloss/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, libpng, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libpng, + zlib, +}: stdenv.mkDerivation rec { pname = "pngloss"; diff --git a/pkgs/by-name/pn/pngnq/package.nix b/pkgs/by-name/pn/pngnq/package.nix index fa7bd56c3e04a7..c418ecbb9ecd0e 100644 --- a/pkgs/by-name/pn/pngnq/package.nix +++ b/pkgs/by-name/pn/pngnq/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, libpng, zlib }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libpng, + zlib, +}: stdenv.mkDerivation rec { pname = "pngnq"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libpng zlib ]; + buildInputs = [ + libpng + zlib + ]; patchPhase = '' sed -i '/png.h/a \#include ' src/rwpng.c diff --git a/pkgs/by-name/pn/pngoptimizer/package.nix b/pkgs/by-name/pn/pngoptimizer/package.nix index c75ba0fb1015e2..d87379370d6aae 100644 --- a/pkgs/by-name/pn/pngoptimizer/package.nix +++ b/pkgs/by-name/pn/pngoptimizer/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, gtk3, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + gtk3, + pkg-config, +}: stdenv.mkDerivation rec { pname = "pngoptimizer"; @@ -15,7 +21,10 @@ stdenv.mkDerivation rec { buildInputs = [ gtk3 ]; - makeFlags = [ "CONFIG=release" "DESTDIR=$(out)" ]; + makeFlags = [ + "CONFIG=release" + "DESTDIR=$(out)" + ]; postInstall = '' mv $out/usr/bin $out/bin @@ -27,7 +36,11 @@ stdenv.mkDerivation rec { homepage = "https://psydk.org/pngoptimizer"; description = "PNG optimizer and converter"; # https://github.com/hadrien-psydk/pngoptimizer#license-information - license = with licenses; [ gpl2Only lgpl21Only zlib ]; + license = with licenses; [ + gpl2Only + lgpl21Only + zlib + ]; maintainers = with maintainers; [ smitop ]; platforms = with platforms; linux; }; diff --git a/pkgs/by-name/pn/pngout/package.nix b/pkgs/by-name/pn/pngout/package.nix index 03d25acd298638..c8a59c29033a11 100644 --- a/pkgs/by-name/pn/pngout/package.nix +++ b/pkgs/by-name/pn/pngout/package.nix @@ -1,22 +1,46 @@ -{ lib -, stdenv -, fetchurl -, unzip +{ + lib, + stdenv, + fetchurl, + unzip, }: let platforms = { - aarch64-linux = { folder = "aarch64"; ld-linux = "ld-linux-aarch64.so.1"; }; - armv7l-linux = { folder = "armv7"; ld-linux = "ld-linux-armhf.so.3"; }; - i686-linux = { folder = "i686"; ld-linux = "ld-linux.so.2"; }; - x86_64-darwin = { folder = "."; }; - x86_64-linux = { folder = "amd64"; ld-linux = "ld-linux-x86-64.so.2"; }; + aarch64-linux = { + folder = "aarch64"; + ld-linux = "ld-linux-aarch64.so.1"; + }; + armv7l-linux = { + folder = "armv7"; + ld-linux = "ld-linux-armhf.so.3"; + }; + i686-linux = { + folder = "i686"; + ld-linux = "ld-linux.so.2"; + }; + x86_64-darwin = { + folder = "."; + }; + x86_64-linux = { + folder = "amd64"; + ld-linux = "ld-linux-x86-64.so.2"; + }; }; - platform = platforms."${stdenv.hostPlatform.system}" - or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); - download = if stdenv.hostPlatform.isDarwin - then { extension = "macos.zip"; hash = "sha256-MnL6lH7q/BrACG4fFJNfnvoh0JClVeaJIlX+XIj2aG4="; } - else { extension = "linux.tar.gz"; hash = "sha256-rDi7pvDeKQM96GZTjDr6ZDQTGbaVu+OI77xf2egw6Sg="; }; + platform = + platforms."${stdenv.hostPlatform.system}" + or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + download = + if stdenv.hostPlatform.isDarwin then + { + extension = "macos.zip"; + hash = "sha256-MnL6lH7q/BrACG4fFJNfnvoh0JClVeaJIlX+XIj2aG4="; + } + else + { + extension = "linux.tar.gz"; + hash = "sha256-rDi7pvDeKQM96GZTjDr6ZDQTGbaVu+OI77xf2egw6Sg="; + }; in stdenv.mkDerivation rec { pname = "pngout"; @@ -32,12 +56,14 @@ stdenv.mkDerivation rec { # pngout is code-signed on Darwin, so don’t alter the binary to avoid breaking the signature. dontFixup = stdenv.hostPlatform.isDarwin; - installPhase = '' - mkdir -p $out/bin - cp ${platform.folder}/pngout $out/bin - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - patchelf --set-interpreter ${stdenv.cc.libc}/lib/${platform.ld-linux} $out/bin/pngout - ''; + installPhase = + '' + mkdir -p $out/bin + cp ${platform.folder}/pngout $out/bin + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + patchelf --set-interpreter ${stdenv.cc.libc}/lib/${platform.ld-linux} $out/bin/pngout + ''; meta = { description = "Tool that aggressively optimizes the sizes of PNG images"; diff --git a/pkgs/by-name/pn/pngpp/package.nix b/pkgs/by-name/pn/pngpp/package.nix index e3aa6af942e2d0..e697003b502629 100644 --- a/pkgs/by-name/pn/pngpp/package.nix +++ b/pkgs/by-name/pn/pngpp/package.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchurl, libpng -, docSupport ? true, doxygen ? null +{ + lib, + stdenv, + fetchurl, + libpng, + docSupport ? true, + doxygen ? null, }: assert docSupport -> doxygen != null; @@ -25,11 +30,13 @@ stdenv.mkDerivation rec { propagatedBuildInputs = [ libpng ]; - preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace error.hpp --replace "#if (_POSIX_C_SOURCE >= 200112L || _XOPEN_SOURCE >= 600) && !_GNU_SOURCE" "#if (__clang__ || _POSIX_C_SOURCE >= 200112L || _XOPEN_SOURCE >= 600) && !_GNU_SOURCE" - '' + '' - sed "s|\(PNGPP := .\)|PREFIX := ''${out}\n\\1|" -i Makefile - ''; + preConfigure = + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace error.hpp --replace "#if (_POSIX_C_SOURCE >= 200112L || _XOPEN_SOURCE >= 600) && !_GNU_SOURCE" "#if (__clang__ || _POSIX_C_SOURCE >= 200112L || _XOPEN_SOURCE >= 600) && !_GNU_SOURCE" + '' + + '' + sed "s|\(PNGPP := .\)|PREFIX := ''${out}\n\\1|" -i Makefile + ''; makeFlags = lib.optional docSupport "docs"; diff --git a/pkgs/by-name/pn/pngquant/package.nix b/pkgs/by-name/pn/pngquant/package.nix index 5a2dd5b3006770..42c8ada5f0877e 100644 --- a/pkgs/by-name/pn/pngquant/package.nix +++ b/pkgs/by-name/pn/pngquant/package.nix @@ -1,10 +1,21 @@ -{ lib, rustPlatform, fetchFromGitHub, pkg-config, libpng, zlib, lcms2 }: +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libpng, + zlib, + lcms2, +}: rustPlatform.buildRustPackage rec { pname = "pngquant"; version = "3.0.3"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchFromGitHub { owner = "kornelski"; @@ -21,7 +32,11 @@ rustPlatform.buildRustPackage rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libpng zlib lcms2 ]; + buildInputs = [ + libpng + zlib + lcms2 + ]; doCheck = false; # Has no Rust-based tests @@ -34,7 +49,11 @@ rustPlatform.buildRustPackage rec { description = "Tool to convert 24/32-bit RGBA PNGs to 8-bit palette with alpha channel preserved"; changelog = "https://github.com/kornelski/pngquant/raw/${version}/CHANGELOG"; platforms = platforms.unix; - license = with licenses; [ gpl3Plus hpnd bsd2 ]; + license = with licenses; [ + gpl3Plus + hpnd + bsd2 + ]; mainProgram = "pngquant"; maintainers = [ ]; }; diff --git a/pkgs/by-name/pn/pngtoico/package.nix b/pkgs/by-name/pn/pngtoico/package.nix index a537e16d96aecc..7c73121f11fd07 100644 --- a/pkgs/by-name/pn/pngtoico/package.nix +++ b/pkgs/by-name/pn/pngtoico/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libpng, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + libpng, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "pngtoico"; diff --git a/pkgs/by-name/pn/pngtools/package.nix b/pkgs/by-name/pn/pngtools/package.nix index 563c8af50ae8c3..16fc925ba135d9 100644 --- a/pkgs/by-name/pn/pngtools/package.nix +++ b/pkgs/by-name/pn/pngtools/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, libpng12, fetchFromGitHub }: +{ + lib, + stdenv, + libpng12, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "pngtools"; diff --git a/pkgs/by-name/pn/pnmixer/package.nix b/pkgs/by-name/pn/pnmixer/package.nix index a65cad09b47dcc..06204e425d25c5 100644 --- a/pkgs/by-name/pn/pnmixer/package.nix +++ b/pkgs/by-name/pn/pnmixer/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, gettext, alsa-lib, gtk3, glib, libnotify, libX11, pcre }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + gettext, + alsa-lib, + gtk3, + glib, + libnotify, + libX11, + pcre, +}: stdenv.mkDerivation rec { pname = "pnmixer"; @@ -11,16 +24,30 @@ stdenv.mkDerivation rec { sha256 = "0416pa933ddf4b7ph9zxhk5jppkk7ppcq1aqph6xsrfnka4yb148"; }; - nativeBuildInputs = [ cmake pkg-config gettext ]; + nativeBuildInputs = [ + cmake + pkg-config + gettext + ]; - buildInputs = [ alsa-lib gtk3 glib libnotify libX11 pcre ]; + buildInputs = [ + alsa-lib + gtk3 + glib + libnotify + libX11 + pcre + ]; meta = with lib; { homepage = "https://github.com/nicklan/pnmixer"; description = "ALSA volume mixer for the system tray"; license = licenses.gpl3; platforms = platforms.linux; - maintainers = with maintainers; [ campadrenalin romildo ]; + maintainers = with maintainers; [ + campadrenalin + romildo + ]; mainProgram = "pnmixer"; }; } diff --git a/pkgs/by-name/po/poco/package.nix b/pkgs/by-name/po/poco/package.nix index 097edd0953c766..86a8eba7aff376 100644 --- a/pkgs/by-name/po/poco/package.nix +++ b/pkgs/by-name/po/poco/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, zlib, pcre2, expat, sqlite, openssl, unixODBC, libmysqlclient }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + zlib, + pcre2, + expat, + sqlite, + openssl, + unixODBC, + libmysqlclient, +}: stdenv.mkDerivation rec { pname = "poco"; @@ -12,12 +25,27 @@ stdenv.mkDerivation rec { rev = "poco-${version}-release"; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ unixODBC libmysqlclient ]; - propagatedBuildInputs = [ zlib pcre2 expat sqlite openssl ]; + buildInputs = [ + unixODBC + libmysqlclient + ]; + propagatedBuildInputs = [ + zlib + pcre2 + expat + sqlite + openssl + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; MYSQL_DIR = libmysqlclient; MYSQL_INCLUDE_DIR = "${MYSQL_DIR}/include/mysql"; @@ -37,7 +65,10 @@ stdenv.mkDerivation rec { homepage = "https://pocoproject.org/"; description = "Cross-platform C++ libraries with a network/internet focus"; license = licenses.boost; - maintainers = with maintainers; [ orivej tomodachi94 ]; + maintainers = with maintainers; [ + orivej + tomodachi94 + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/po/pod2mdoc/package.nix b/pkgs/by-name/po/pod2mdoc/package.nix index 6b3792bf500e2a..97dcc55908542f 100644 --- a/pkgs/by-name/po/pod2mdoc/package.nix +++ b/pkgs/by-name/po/pod2mdoc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "pod2mdoc"; diff --git a/pkgs/by-name/po/podgrab/package.nix b/pkgs/by-name/po/podgrab/package.nix index 74ed3d56862c57..6092a440923af2 100644 --- a/pkgs/by-name/po/podgrab/package.nix +++ b/pkgs/by-name/po/podgrab/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, nixosTests }: +{ + lib, + fetchFromGitHub, + buildGoModule, + nixosTests, +}: buildGoModule rec { pname = "podgrab"; diff --git a/pkgs/by-name/po/podiff/package.nix b/pkgs/by-name/po/podiff/package.nix index 1a2fb97391394c..0c858d8e43dee5 100644 --- a/pkgs/by-name/po/podiff/package.nix +++ b/pkgs/by-name/po/podiff/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "podiff"; diff --git a/pkgs/by-name/po/podman/package.nix b/pkgs/by-name/po/podman/package.nix index 93ad4f71bb9847..f014ae9f0bf27d 100644 --- a/pkgs/by-name/po/podman/package.nix +++ b/pkgs/by-name/po/podman/package.nix @@ -1,67 +1,75 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, installShellFiles -, buildGoModule -, gpgme -, lvm2 -, btrfs-progs -, libapparmor -, libseccomp -, libselinux -, systemd -, go-md2man -, nixosTests -, python3 -, makeWrapper -, runtimeShell -, symlinkJoin -, substituteAll -, extraPackages ? [ ] -, crun -, runc -, conmon -, extraRuntimes ? lib.optionals stdenv.hostPlatform.isLinux [ runc ] # e.g.: runc, gvisor, youki -, fuse-overlayfs -, util-linux -, iptables -, iproute2 -, catatonit -, gvproxy -, aardvark-dns -, netavark -, passt -, vfkit -, testers -, podman +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + installShellFiles, + buildGoModule, + gpgme, + lvm2, + btrfs-progs, + libapparmor, + libseccomp, + libselinux, + systemd, + go-md2man, + nixosTests, + python3, + makeWrapper, + runtimeShell, + symlinkJoin, + substituteAll, + extraPackages ? [ ], + crun, + runc, + conmon, + extraRuntimes ? lib.optionals stdenv.hostPlatform.isLinux [ runc ], # e.g.: runc, gvisor, youki + fuse-overlayfs, + util-linux, + iptables, + iproute2, + catatonit, + gvproxy, + aardvark-dns, + netavark, + passt, + vfkit, + testers, + podman, }: let # do not add qemu to this wrapper, store paths get written to the podman vm config and break when GCed - binPath = lib.makeBinPath (lib.optionals stdenv.hostPlatform.isLinux [ - fuse-overlayfs - util-linux - iptables - iproute2 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - vfkit - ] ++ extraPackages); + binPath = lib.makeBinPath ( + lib.optionals stdenv.hostPlatform.isLinux [ + fuse-overlayfs + util-linux + iptables + iproute2 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + vfkit + ] + ++ extraPackages + ); helpersBin = symlinkJoin { name = "podman-helper-binary-wrapper"; # this only works for some binaries, others may need to be added to `binPath` or in the modules - paths = [ - gvproxy - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - aardvark-dns - catatonit # added here for the pause image and also set in `containersConf` for `init_path` - netavark - passt - conmon - crun - ] ++ extraRuntimes; + paths = + [ + gvproxy + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + aardvark-dns + catatonit # added here for the pause image and also set in `containersConf` for `init_path` + netavark + passt + conmon + crun + ] + ++ extraRuntimes; }; in buildGoModule rec { @@ -89,9 +97,18 @@ buildGoModule rec { doCheck = false; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - nativeBuildInputs = [ pkg-config go-md2man installShellFiles makeWrapper python3 ]; + nativeBuildInputs = [ + pkg-config + go-md2man + installShellFiles + makeWrapper + python3 + ]; buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ btrfs-progs @@ -110,22 +127,32 @@ buildGoModule rec { runHook preBuild patchShebangs . substituteInPlace Makefile --replace "/bin/bash" "${runtimeShell}" - ${if stdenv.hostPlatform.isDarwin then '' - make podman-remote # podman-mac-helper uses FHS paths - '' else '' - make bin/podman bin/rootlessport bin/quadlet - ''} + ${ + if stdenv.hostPlatform.isDarwin then + '' + make podman-remote # podman-mac-helper uses FHS paths + '' + else + '' + make bin/podman bin/rootlessport bin/quadlet + '' + } make docs runHook postBuild ''; installPhase = '' runHook preInstall - ${if stdenv.hostPlatform.isDarwin then '' - install bin/darwin/podman -Dt $out/bin - '' else '' - make install.bin install.systemd - ''} + ${ + if stdenv.hostPlatform.isDarwin then + '' + install bin/darwin/podman -Dt $out/bin + '' + else + '' + make install.bin install.systemd + '' + } make install.completions install.man mkdir -p ${HELPER_BINARIES_DIR} ln -s ${helpersBin}/bin/* ${HELPER_BINARIES_DIR} @@ -139,19 +166,21 @@ buildGoModule rec { patchelf --set-rpath "${lib.makeLibraryPath [ systemd ]}":$RPATH $out/bin/.podman-wrapped ''; - passthru.tests = { - version = testers.testVersion { - package = podman; - command = "HOME=$TMPDIR podman --version"; + passthru.tests = + { + version = testers.testVersion { + package = podman; + command = "HOME=$TMPDIR podman --version"; + }; + } + // lib.optionalAttrs stdenv.hostPlatform.isLinux { + inherit (nixosTests) podman; + # related modules + inherit (nixosTests) + podman-tls-ghostunnel + ; + oci-containers-podman = nixosTests.oci-containers.podman; }; - } // lib.optionalAttrs stdenv.hostPlatform.isLinux { - inherit (nixosTests) podman; - # related modules - inherit (nixosTests) - podman-tls-ghostunnel - ; - oci-containers-podman = nixosTests.oci-containers.podman; - }; meta = with lib; { homepage = "https://podman.io/"; diff --git a/pkgs/by-name/po/pods/package.nix b/pkgs/by-name/po/pods/package.nix index 201fcf89988bcb..b0e442bb2c35df 100644 --- a/pkgs/by-name/po/pods/package.nix +++ b/pkgs/by-name/po/pods/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, cargo -, desktop-file-utils -, glib -, gtk4 -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, wrapGAppsHook4 -, gtksourceview5 -, libadwaita -, libpanel -, vte-gtk4 +{ + lib, + stdenv, + fetchFromGitHub, + cargo, + desktop-file-utils, + glib, + gtk4, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + wrapGAppsHook4, + gtksourceview5, + libadwaita, + libpanel, + vte-gtk4, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/po/poethepoet/package.nix b/pkgs/by-name/po/poethepoet/package.nix index 8179b9c7e7d00a..5ec66c2852c861 100644 --- a/pkgs/by-name/po/poethepoet/package.nix +++ b/pkgs/by-name/po/poethepoet/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/po/poetry/package.nix b/pkgs/by-name/po/poetry/package.nix index dda8d0a132a194..b6d61b80e17960 100644 --- a/pkgs/by-name/po/poetry/package.nix +++ b/pkgs/by-name/po/poetry/package.nix @@ -1,8 +1,13 @@ -{ lib, python3, fetchFromGitHub }: +{ + lib, + python3, + fetchFromGitHub, +}: let newPackageOverrides = - self: super: { + self: super: + { poetry = self.callPackage ./unwrapped.nix { }; # The versions of Poetry and poetry-core need to match exactly, @@ -21,39 +26,48 @@ let }; patches = [ ]; }); - } // (plugins self); + } + // (plugins self); python = python3.override (old: { self = python; - packageOverrides = lib.composeManyExtensions - ((if old ? packageOverrides then [ old.packageOverrides ] else [ ]) ++ [ newPackageOverrides ]); + packageOverrides = lib.composeManyExtensions ( + (if old ? packageOverrides then [ old.packageOverrides ] else [ ]) ++ [ newPackageOverrides ] + ); }); - plugins = ps: with ps; { - poetry-audit-plugin = callPackage ./plugins/poetry-audit-plugin.nix { }; - poetry-plugin-export = callPackage ./plugins/poetry-plugin-export.nix { }; - poetry-plugin-up = callPackage ./plugins/poetry-plugin-up.nix { }; - poetry-plugin-poeblix = callPackage ./plugins/poetry-plugin-poeblix.nix { }; - }; + plugins = + ps: with ps; { + poetry-audit-plugin = callPackage ./plugins/poetry-audit-plugin.nix { }; + poetry-plugin-export = callPackage ./plugins/poetry-plugin-export.nix { }; + poetry-plugin-up = callPackage ./plugins/poetry-plugin-up.nix { }; + poetry-plugin-poeblix = callPackage ./plugins/poetry-plugin-poeblix.nix { }; + }; # selector is a function mapping pythonPackages to a list of plugins # e.g. poetry.withPlugins (ps: with ps; [ poetry-plugin-up ]) - withPlugins = selector: let - selected = selector (plugins python.pkgs); - in python.pkgs.toPythonApplication (python.pkgs.poetry.overridePythonAttrs (old: { - dependencies = old.dependencies ++ selected; + withPlugins = + selector: + let + selected = selector (plugins python.pkgs); + in + python.pkgs.toPythonApplication ( + python.pkgs.poetry.overridePythonAttrs (old: { + dependencies = old.dependencies ++ selected; - # save some build time when adding plugins by disabling tests - doCheck = selected == [ ]; + # save some build time when adding plugins by disabling tests + doCheck = selected == [ ]; - # Propagating dependencies leaks them through $PYTHONPATH which causes issues - # when used in nix-shell. - postFixup = '' - rm $out/nix-support/propagated-build-inputs - ''; + # Propagating dependencies leaks them through $PYTHONPATH which causes issues + # when used in nix-shell. + postFixup = '' + rm $out/nix-support/propagated-build-inputs + ''; - passthru = { - plugins = plugins python.pkgs; - inherit withPlugins python; - }; - })); -in withPlugins (ps: [ ]) + passthru = { + plugins = plugins python.pkgs; + inherit withPlugins python; + }; + }) + ); +in +withPlugins (ps: [ ]) diff --git a/pkgs/by-name/po/poetry/plugins/poetry-audit-plugin.nix b/pkgs/by-name/po/poetry/plugins/poetry-audit-plugin.nix index 6c3f120171bef3..ec9289738349ae 100644 --- a/pkgs/by-name/po/poetry/plugins/poetry-audit-plugin.nix +++ b/pkgs/by-name/po/poetry/plugins/poetry-audit-plugin.nix @@ -1,11 +1,12 @@ -{ lib -, buildPythonPackage -, pythonOlder -, fetchFromGitHub -, poetry-core -, poetry -, safety -, pytestCheckHook +{ + lib, + buildPythonPackage, + pythonOlder, + fetchFromGitHub, + poetry-core, + poetry, + safety, + pytestCheckHook, }: buildPythonPackage rec { @@ -37,7 +38,7 @@ buildPythonPackage rec { pythonImportsCheck = [ "poetry_audit_plugin" ]; nativeCheckInputs = [ - poetry # for the executable + poetry # for the executable pytestCheckHook ]; diff --git a/pkgs/by-name/po/poetry/plugins/poetry-plugin-export.nix b/pkgs/by-name/po/poetry/plugins/poetry-plugin-export.nix index aa365ebb36b344..e9539ccfaf5398 100644 --- a/pkgs/by-name/po/poetry/plugins/poetry-plugin-export.nix +++ b/pkgs/by-name/po/poetry/plugins/poetry-plugin-export.nix @@ -1,7 +1,8 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, poetry-core +{ + lib, + buildPythonPackage, + fetchFromGitHub, + poetry-core, }: buildPythonPackage rec { @@ -26,7 +27,7 @@ buildPythonPackage rec { # infinite recursion with poetry doCheck = false; - pythonImportsCheck = []; + pythonImportsCheck = [ ]; meta = with lib; { changelog = "https://github.com/python-poetry/poetry-plugin-export/blob/${src.rev}/CHANGELOG.md"; diff --git a/pkgs/by-name/po/poetry/plugins/poetry-plugin-poeblix.nix b/pkgs/by-name/po/poetry/plugins/poetry-plugin-poeblix.nix index df32b8e797b9fa..399645532dfa80 100644 --- a/pkgs/by-name/po/poetry/plugins/poetry-plugin-poeblix.nix +++ b/pkgs/by-name/po/poetry/plugins/poetry-plugin-poeblix.nix @@ -1,7 +1,8 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, poetry-core +{ + lib, + buildPythonPackage, + fetchFromGitHub, + poetry-core, }: buildPythonPackage rec { @@ -25,7 +26,7 @@ buildPythonPackage rec { ]; doCheck = false; - pythonImportsCheck = ["poeblix"]; + pythonImportsCheck = [ "poeblix" ]; meta = with lib; { changelog = "https://github.com/spoorn/poeblix/releases/tag/${lib.removePrefix "refs/tags/" src.rev}"; diff --git a/pkgs/by-name/po/poetry/plugins/poetry-plugin-up.nix b/pkgs/by-name/po/poetry/plugins/poetry-plugin-up.nix index 69a3804edba219..90feed499dc282 100644 --- a/pkgs/by-name/po/poetry/plugins/poetry-plugin-up.nix +++ b/pkgs/by-name/po/poetry/plugins/poetry-plugin-up.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, buildPythonPackage -, poetry-core -, pytestCheckHook -, pytest-mock -, poetry +{ + lib, + fetchFromGitHub, + buildPythonPackage, + poetry-core, + pytestCheckHook, + pytest-mock, + poetry, }: buildPythonPackage rec { diff --git a/pkgs/by-name/po/poetry/unwrapped.nix b/pkgs/by-name/po/poetry/unwrapped.nix index 1caa9575bb35b3..335d2ba8089d9d 100644 --- a/pkgs/by-name/po/poetry/unwrapped.nix +++ b/pkgs/by-name/po/poetry/unwrapped.nix @@ -1,39 +1,40 @@ -{ lib -, stdenv -, buildPythonPackage -, pythonOlder -, fetchFromGitHub -, installShellFiles -, build -, cachecontrol -, cleo -, crashtest -, dulwich -, fastjsonschema -, installer -, keyring -, packaging -, pexpect -, pkginfo -, platformdirs -, poetry-core -, poetry-plugin-export -, pyproject-hooks -, requests -, requests-toolbelt -, shellingham -, tomlkit -, trove-classifiers -, virtualenv -, xattr -, tomli -, importlib-metadata -, deepdiff -, pytestCheckHook -, httpretty -, pytest-mock -, pytest-xdist -, darwin +{ + lib, + stdenv, + buildPythonPackage, + pythonOlder, + fetchFromGitHub, + installShellFiles, + build, + cachecontrol, + cleo, + crashtest, + dulwich, + fastjsonschema, + installer, + keyring, + packaging, + pexpect, + pkginfo, + platformdirs, + poetry-core, + poetry-plugin-export, + pyproject-hooks, + requests, + requests-toolbelt, + shellingham, + tomlkit, + trove-classifiers, + virtualenv, + xattr, + tomli, + importlib-metadata, + deepdiff, + pytestCheckHook, + httpretty, + pytest-mock, + pytest-xdist, + darwin, }: buildPythonPackage rec { @@ -64,35 +65,40 @@ buildPythonPackage rec { "virtualenv" ]; - dependencies = [ - build - cachecontrol - cleo - crashtest - dulwich - fastjsonschema - installer - keyring - packaging - pexpect - pkginfo - platformdirs - poetry-core - poetry-plugin-export - pyproject-hooks - requests - requests-toolbelt - shellingham - tomlkit - trove-classifiers - virtualenv - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ - xattr - ] ++ lib.optionals (pythonOlder "3.11") [ - tomli - ] ++ lib.optionals (pythonOlder "3.10") [ - importlib-metadata - ] ++ cachecontrol.optional-dependencies.filecache; + dependencies = + [ + build + cachecontrol + cleo + crashtest + dulwich + fastjsonschema + installer + keyring + packaging + pexpect + pkginfo + platformdirs + poetry-core + poetry-plugin-export + pyproject-hooks + requests + requests-toolbelt + shellingham + tomlkit + trove-classifiers + virtualenv + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ + xattr + ] + ++ lib.optionals (pythonOlder "3.11") [ + tomli + ] + ++ lib.optionals (pythonOlder "3.10") [ + importlib-metadata + ] + ++ cachecontrol.optional-dependencies.filecache; postInstall = '' installShellCompletion --cmd poetry \ @@ -101,22 +107,27 @@ buildPythonPackage rec { --zsh <($out/bin/poetry completions zsh) \ ''; - nativeCheckInputs = [ - deepdiff - pytestCheckHook - httpretty - pytest-mock - pytest-xdist - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.ps - ]; - - preCheck = ('' - export HOME=$TMPDIR - '' + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' - # https://github.com/python/cpython/issues/74570#issuecomment-1093748531 - export no_proxy='*'; - ''); + nativeCheckInputs = + [ + deepdiff + pytestCheckHook + httpretty + pytest-mock + pytest-xdist + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.ps + ]; + + preCheck = ( + '' + export HOME=$TMPDIR + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' + # https://github.com/python/cpython/issues/74570#issuecomment-1093748531 + export no_proxy='*'; + '' + ); postCheck = lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' unset no_proxy @@ -141,14 +152,17 @@ buildPythonPackage rec { # Unset ambient PYTHONPATH in the wrapper, so Poetry only ever runs with its own, # isolated set of dependencies. This works because the correct PYTHONPATH is set # in the Python script, which runs after the wrapper. - makeWrapperArgs = ["--unset PYTHONPATH"]; + makeWrapperArgs = [ "--unset PYTHONPATH" ]; meta = with lib; { changelog = "https://github.com/python-poetry/poetry/blob/${src.rev}/CHANGELOG.md"; homepage = "https://python-poetry.org/"; description = "Python dependency management and packaging made easy"; license = licenses.mit; - maintainers = with maintainers; [ jakewaksbaum dotlambda ]; + maintainers = with maintainers; [ + jakewaksbaum + dotlambda + ]; mainProgram = "poetry"; }; } diff --git a/pkgs/by-name/po/poetry2conda/package.nix b/pkgs/by-name/po/poetry2conda/package.nix index 9b0975bd01cf67..ee2c500ad28d3f 100644 --- a/pkgs/by-name/po/poetry2conda/package.nix +++ b/pkgs/by-name/po/poetry2conda/package.nix @@ -1,10 +1,12 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, python3 +{ + lib, + fetchFromGitHub, + fetchpatch, + python3, }: -with python3.pkgs; buildPythonApplication rec { +with python3.pkgs; +buildPythonApplication rec { pname = "poetry2conda"; version = "0.3.0"; diff --git a/pkgs/by-name/po/poezio/package.nix b/pkgs/by-name/po/poezio/package.nix index d36f1829b7ed30..b222f1c1a54f69 100644 --- a/pkgs/by-name/po/poezio/package.nix +++ b/pkgs/by-name/po/poezio/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitea -, pkg-config -, python3 +{ + lib, + fetchFromGitea, + pkg-config, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/po/poke/package.nix b/pkgs/by-name/po/poke/package.nix index 66fa43394f2bc5..51b8b4e9479840 100644 --- a/pkgs/by-name/po/poke/package.nix +++ b/pkgs/by-name/po/poke/package.nix @@ -1,17 +1,20 @@ -{ lib -, stdenv -, fetchurl -, help2man -, pkg-config -, texinfo -, boehmgc -, readline -, nbdSupport ? !stdenv.hostPlatform.isDarwin, libnbd -, textStylingSupport ? true, gettext -, dejagnu +{ + lib, + stdenv, + fetchurl, + help2man, + pkg-config, + texinfo, + boehmgc, + readline, + nbdSupport ? !stdenv.hostPlatform.isDarwin, + libnbd, + textStylingSupport ? true, + gettext, + dejagnu, # update script only -, writeScript + writeScript, }: let @@ -26,7 +29,13 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-iq825h42elMUDqQOJVnp7FEud5xCvuNOesJLNLoRm94="; }; - outputs = [ "out" "dev" "info" "lib" ] + outputs = + [ + "out" + "dev" + "info" + "lib" + ] # help2man can't cross compile because it runs `poke --help` to # generate the man page ++ lib.optional (!isCross) "man"; @@ -37,14 +46,20 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - nativeBuildInputs = [ - pkg-config - texinfo - ] ++ lib.optionals (!isCross) [ - help2man - ]; - - buildInputs = [ boehmgc readline ] + nativeBuildInputs = + [ + pkg-config + texinfo + ] + ++ lib.optionals (!isCross) [ + help2man + ]; + + buildInputs = + [ + boehmgc + readline + ] ++ lib.optional nbdSupport libnbd ++ lib.optional textStylingSupport gettext ++ lib.optional finalAttrs.finalPackage.doCheck dejagnu; diff --git a/pkgs/by-name/po/pokeget-rs/package.nix b/pkgs/by-name/po/pokeget-rs/package.nix index 08f84c9a78c9b2..3f07917681f71f 100644 --- a/pkgs/by-name/po/pokeget-rs/package.nix +++ b/pkgs/by-name/po/pokeget-rs/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/po/pokemon-colorscripts-mac/package.nix b/pkgs/by-name/po/pokemon-colorscripts-mac/package.nix index 5205e8ad6eafae..79023583ac2232 100644 --- a/pkgs/by-name/po/pokemon-colorscripts-mac/package.nix +++ b/pkgs/by-name/po/pokemon-colorscripts-mac/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, coreutils -, fetchFromGitHub +{ + lib, + stdenv, + coreutils, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/po/pokemon-cursor/package.nix b/pkgs/by-name/po/pokemon-cursor/package.nix index eeaec0a8b68bff..3a7494e70c434d 100644 --- a/pkgs/by-name/po/pokemon-cursor/package.nix +++ b/pkgs/by-name/po/pokemon-cursor/package.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, lib -, stdenvNoCC - -, # build deps - clickgen -, python3Packages +{ + fetchFromGitHub, + lib, + stdenvNoCC, + + # build deps + clickgen, + python3Packages, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/po/pokemonsay/package.nix b/pkgs/by-name/po/pokemonsay/package.nix index 669fa6a494134c..01abfe0bfcc879 100644 --- a/pkgs/by-name/po/pokemonsay/package.nix +++ b/pkgs/by-name/po/pokemonsay/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, fetchpatch -, cowsay -, coreutils -, findutils +{ + lib, + stdenvNoCC, + fetchFromGitHub, + fetchpatch, + cowsay, + coreutils, + findutils, }: stdenvNoCC.mkDerivation rec { @@ -19,7 +20,8 @@ stdenvNoCC.mkDerivation rec { }; patches = [ - (fetchpatch { # https://github.com/HRKings/pokemonsay-newgenerations/pull/5 + (fetchpatch { + # https://github.com/HRKings/pokemonsay-newgenerations/pull/5 name = "word-wrap-fix.patch"; url = "https://github.com/pbsds/pokemonsay-newgenerations/commit/7056d7ba689479a8e6c14ec000be1dfcd83afeb0.patch"; hash = "sha256-aqUJkyJDWArLjChxLZ4BbC6XAB53LAqARzTvEAxrFCI="; diff --git a/pkgs/by-name/po/pokete/package.nix b/pkgs/by-name/po/pokete/package.nix index beb262edee7049..8419520a6c731d 100644 --- a/pkgs/by-name/po/pokete/package.nix +++ b/pkgs/by-name/po/pokete/package.nix @@ -1,9 +1,10 @@ -{ lib -, python3 -, fetchFromGitHub -, testers -, pokete -, faketty +{ + lib, + python3, + fetchFromGitHub, + testers, + pokete, + faketty, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/po/polar-bookshelf/package.nix b/pkgs/by-name/po/polar-bookshelf/package.nix index 955b45784e923e..5306343a48cb82 100644 --- a/pkgs/by-name/po/polar-bookshelf/package.nix +++ b/pkgs/by-name/po/polar-bookshelf/package.nix @@ -1,47 +1,47 @@ -{ stdenv -, lib -, makeWrapper -, fetchurl -, dpkg -, wrapGAppsHook3 -, autoPatchelfHook -, gtk3 -, cairo -, pango -, atk -, gdk-pixbuf -, glib -, at-spi2-atk -, dbus -, libX11 -, libxcb -, libXi -, libXcursor -, libXdamage -, libXrandr -, libXcomposite -, libXext -, libXfixes -, libXrender -, libXtst -, libXScrnSaver -, nss -, nspr -, alsa-lib -, cups -, fontconfig -, expat -, libudev0-shim -, glibc -, curl -, openssl -, libnghttp2 -, gsettings-desktop-schemas -, libdrm -, mesa +{ + stdenv, + lib, + makeWrapper, + fetchurl, + dpkg, + wrapGAppsHook3, + autoPatchelfHook, + gtk3, + cairo, + pango, + atk, + gdk-pixbuf, + glib, + at-spi2-atk, + dbus, + libX11, + libxcb, + libXi, + libXcursor, + libXdamage, + libXrandr, + libXcomposite, + libXext, + libXfixes, + libXrender, + libXtst, + libXScrnSaver, + nss, + nspr, + alsa-lib, + cups, + fontconfig, + expat, + libudev0-shim, + glibc, + curl, + openssl, + libnghttp2, + gsettings-desktop-schemas, + libdrm, + mesa, }: - stdenv.mkDerivation rec { pname = "polar-bookshelf"; version = "2.0.103"; @@ -91,7 +91,13 @@ stdenv.mkDerivation rec { dpkg ]; - runtimeLibs = lib.makeLibraryPath [ libudev0-shim glibc curl openssl libnghttp2 ]; + runtimeLibs = lib.makeLibraryPath [ + libudev0-shim + glibc + curl + openssl + libnghttp2 + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/po/polar-bookshelf1/package.nix b/pkgs/by-name/po/polar-bookshelf1/package.nix index cd04ca69d1e4b3..5ea080a27dbbbf 100644 --- a/pkgs/by-name/po/polar-bookshelf1/package.nix +++ b/pkgs/by-name/po/polar-bookshelf1/package.nix @@ -1,42 +1,43 @@ -{ lib -, stdenv -, fetchurl -, alsa-lib -, at-spi2-atk -, atk -, autoPatchelfHook -, cairo -, cups -, curl -, dbus -, dpkg -, expat -, fontconfig -, gdk-pixbuf -, glib -, glibc -, gsettings-desktop-schemas -, gtk3 -, libX11 -, libXScrnSaver -, libXcomposite -, libXcursor -, libXdamage -, libXext -, libXfixes -, libXi -, libXrandr -, libXrender -, libXtst -, libnghttp2 -, libudev0-shim -, libxcb -, makeWrapper -, nspr -, nss -, openssl -, pango -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + alsa-lib, + at-spi2-atk, + atk, + autoPatchelfHook, + cairo, + cups, + curl, + dbus, + dpkg, + expat, + fontconfig, + gdk-pixbuf, + glib, + glibc, + gsettings-desktop-schemas, + gtk3, + libX11, + libXScrnSaver, + libXcomposite, + libXcursor, + libXdamage, + libXext, + libXfixes, + libXi, + libXrandr, + libXrender, + libXtst, + libnghttp2, + libudev0-shim, + libxcb, + makeWrapper, + nspr, + nss, + openssl, + pango, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -85,7 +86,13 @@ stdenv.mkDerivation rec { wrapGAppsHook3 ]; - runtimeLibs = lib.makeLibraryPath [ libudev0-shim glibc curl openssl libnghttp2 ]; + runtimeLibs = lib.makeLibraryPath [ + libudev0-shim + glibc + curl + openssl + libnghttp2 + ]; installPhase = '' mkdir -p $out/share/polar-bookshelf $out/bin $out/lib diff --git a/pkgs/by-name/po/policycoreutils/package.nix b/pkgs/by-name/po/policycoreutils/package.nix index 6a2296fda4fce8..b06be84ccd7026 100644 --- a/pkgs/by-name/po/policycoreutils/package.nix +++ b/pkgs/by-name/po/policycoreutils/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, gettext, libsepol, libselinux, libsemanage, libxcrypt }: +{ + lib, + stdenv, + fetchurl, + gettext, + libsepol, + libselinux, + libsemanage, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "policycoreutils"; @@ -18,7 +27,12 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ gettext ]; - buildInputs = [ libsepol libselinux libsemanage libxcrypt ]; + buildInputs = [ + libsepol + libselinux + libsemanage + libxcrypt + ]; makeFlags = [ "PREFIX=$(out)" diff --git a/pkgs/by-name/po/polipo/package.nix b/pkgs/by-name/po/polipo/package.nix index 350954d8e4dde6..f050199942c0a3 100644 --- a/pkgs/by-name/po/polipo/package.nix +++ b/pkgs/by-name/po/polipo/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, texinfo }: +{ + lib, + stdenv, + fetchurl, + texinfo, +}: stdenv.mkDerivation rec { pname = "polipo"; @@ -10,7 +15,10 @@ stdenv.mkDerivation rec { }; buildInputs = [ texinfo ]; - makeFlags = [ "PREFIX=$(out)" "LOCAL_ROOT=$(out)/share/polipo/www" ]; + makeFlags = [ + "PREFIX=$(out)" + "LOCAL_ROOT=$(out)/share/polipo/www" + ]; meta = with lib; { homepage = "http://www.pps.jussieu.fr/~jch/software/polipo/"; diff --git a/pkgs/by-name/po/polkit/package.nix b/pkgs/by-name/po/polkit/package.nix index 80a966f035d27f..9ceb10a5bc2d91 100644 --- a/pkgs/by-name/po/polkit/package.nix +++ b/pkgs/by-name/po/polkit/package.nix @@ -1,35 +1,38 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, glib -, expat -, pam -, meson -, mesonEmulatorHook -, ninja -, perl -, python3 -, gettext -, duktape -, gobject-introspection -, libxslt -, docbook-xsl-nons -, dbus -, docbook_xml_dtd_412 -, gtk-doc -, coreutils -, fetchpatch -, useSystemd ? lib.meta.availableOn stdenv.hostPlatform systemdMinimal -, systemdMinimal -, elogind -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -# A few tests currently fail on musl (polkitunixusertest, polkitunixgrouptest, polkitidentitytest segfault). -# Not yet investigated; it may be due to the "Make netgroup support optional" -# patch not updating the tests correctly yet, or doing something wrong, -# or being unrelated to that. -, doCheck ? (stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isMusl) +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + glib, + expat, + pam, + meson, + mesonEmulatorHook, + ninja, + perl, + python3, + gettext, + duktape, + gobject-introspection, + libxslt, + docbook-xsl-nons, + dbus, + docbook_xml_dtd_412, + gtk-doc, + coreutils, + fetchpatch, + useSystemd ? lib.meta.availableOn stdenv.hostPlatform systemdMinimal, + systemdMinimal, + elogind, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + # A few tests currently fail on musl (polkitunixusertest, polkitunixgrouptest, polkitidentitytest segfault). + # Not yet investigated; it may be due to the "Make netgroup support optional" + # patch not updating the tests correctly yet, or doing something wrong, + # or being unrelated to that. + doCheck ? (stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isMusl), }: let @@ -40,7 +43,11 @@ stdenv.mkDerivation rec { pname = "polkit"; version = "124"; - outputs = [ "bin" "dev" "out" ]; # small man pages in $bin + outputs = [ + "bin" + "dev" + "out" + ]; # small man pages in $bin # Tarballs do not contain subprojects. src = fetchFromGitHub { @@ -69,34 +76,39 @@ stdenv.mkDerivation rec { pkg-config ]; - nativeBuildInputs = [ - glib - pkg-config - gettext - meson - ninja - perl - - # man pages - libxslt - docbook-xsl-nons - docbook_xml_dtd_412 - ] ++ lib.optionals withIntrospection [ - gobject-introspection - gtk-doc - ] ++ lib.optionals (withIntrospection && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + glib + pkg-config + gettext + meson + ninja + perl + + # man pages + libxslt + docbook-xsl-nons + docbook_xml_dtd_412 + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + gtk-doc + ] + ++ lib.optionals (withIntrospection && !stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; - buildInputs = [ - expat - pam - dbus - duktape - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - # On Linux, fall back to elogind when systemd support is off. - (if useSystemd then systemdMinimal else elogind) - ]; + buildInputs = + [ + expat + pam + dbus + duktape + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + # On Linux, fall back to elogind when systemd support is off. + (if useSystemd then systemdMinimal else elogind) + ]; propagatedBuildInputs = [ glib # in .pc Requires @@ -104,44 +116,49 @@ stdenv.mkDerivation rec { nativeCheckInputs = [ dbus - (python3.pythonOnBuildForHost.withPackages (pp: with pp; [ - dbus-python - (python-dbusmock.overridePythonAttrs (attrs: { - # Avoid dependency cycle. - doCheck = false; - })) - ])) - ]; - - env = { - PKG_CONFIG_SYSTEMD_SYSTEMDSYSTEMUNITDIR = "${placeholder "out"}/lib/systemd/system"; - PKG_CONFIG_SYSTEMD_SYSUSERS_DIR = "${placeholder "out"}/lib/sysusers.d"; - - # HACK: We want to install policy files files to $out/share but polkit - # should read them from /run/current-system/sw/share on a NixOS system. - # Similarly for config files in /etc. - # With autotools, it was possible to override Make variables - # at install time but Meson does not support this - # so we need to convince it to install all files to a temporary - # location using DESTDIR and then move it to proper one in postInstall. - DESTDIR = "dest"; - } // lib.optionalAttrs stdenv.cc.isGNU { - NIX_CFLAGS_COMPILE = "-Wno-error=implicit-function-declaration"; - }; - - mesonFlags = [ - "--datadir=${system}/share" - "--sysconfdir=/etc" - "-Dpolkitd_user=polkituser" #TODO? config.ids.uids.polkituser - "-Dos_type=redhat" # only affects PAM includes - "-Dintrospection=${lib.boolToString withIntrospection}" - "-Dtests=${lib.boolToString doCheck}" - "-Dgtk_doc=${lib.boolToString withIntrospection}" - "-Dman=true" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "-Dsession_tracking=${if useSystemd then "libsystemd-login" else "libelogind"}" + (python3.pythonOnBuildForHost.withPackages ( + pp: with pp; [ + dbus-python + (python-dbusmock.overridePythonAttrs (attrs: { + # Avoid dependency cycle. + doCheck = false; + })) + ] + )) ]; + env = + { + PKG_CONFIG_SYSTEMD_SYSTEMDSYSTEMUNITDIR = "${placeholder "out"}/lib/systemd/system"; + PKG_CONFIG_SYSTEMD_SYSUSERS_DIR = "${placeholder "out"}/lib/sysusers.d"; + + # HACK: We want to install policy files files to $out/share but polkit + # should read them from /run/current-system/sw/share on a NixOS system. + # Similarly for config files in /etc. + # With autotools, it was possible to override Make variables + # at install time but Meson does not support this + # so we need to convince it to install all files to a temporary + # location using DESTDIR and then move it to proper one in postInstall. + DESTDIR = "dest"; + } + // lib.optionalAttrs stdenv.cc.isGNU { + NIX_CFLAGS_COMPILE = "-Wno-error=implicit-function-declaration"; + }; + + mesonFlags = + [ + "--datadir=${system}/share" + "--sysconfdir=/etc" + "-Dpolkitd_user=polkituser" # TODO? config.ids.uids.polkituser + "-Dos_type=redhat" # only affects PAM includes + "-Dintrospection=${lib.boolToString withIntrospection}" + "-Dtests=${lib.boolToString doCheck}" + "-Dgtk_doc=${lib.boolToString withIntrospection}" + "-Dman=true" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "-Dsession_tracking=${if useSystemd then "libsystemd-login" else "libelogind"}" + ]; inherit doCheck; diff --git a/pkgs/by-name/po/polkit_gnome/package.nix b/pkgs/by-name/po/polkit_gnome/package.nix index d738e6c6bb3ad7..8fca7ae90c7b9f 100644 --- a/pkgs/by-name/po/polkit_gnome/package.nix +++ b/pkgs/by-name/po/polkit_gnome/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, polkit, gtk3, pkg-config, intltool }: +{ + lib, + stdenv, + fetchurl, + polkit, + gtk3, + pkg-config, + intltool, +}: stdenv.mkDerivation (finalAttrs: { pname = "polkit-gnome"; version = "0.105"; @@ -8,8 +16,14 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-F4RJSWO4v5oA7txs06KGj7EjuKXlFuZsXtpI3xerk2k="; }; - buildInputs = [ polkit gtk3 ]; - nativeBuildInputs = [ pkg-config intltool ]; + buildInputs = [ + polkit + gtk3 + ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; configureFlags = [ "--disable-introspection" ]; diff --git a/pkgs/by-name/po/pololu-tic/package.nix b/pkgs/by-name/po/pololu-tic/package.nix index 322ff8fa6455c0..51b6af2c01e50c 100644 --- a/pkgs/by-name/po/pololu-tic/package.nix +++ b/pkgs/by-name/po/pololu-tic/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, libusbp -, cmake -, pkg-config -, qt5 +{ + lib, + stdenv, + fetchFromGitHub, + libusbp, + cmake, + pkg-config, + qt5, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/po/polonium/package.nix b/pkgs/by-name/po/polonium/package.nix index 412774af533b86..addaf26b93230c 100644 --- a/pkgs/by-name/po/polonium/package.nix +++ b/pkgs/by-name/po/polonium/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildNpmPackage -, libsForQt5 +{ + lib, + fetchFromGitHub, + buildNpmPackage, + libsForQt5, }: # how to update: @@ -26,7 +27,10 @@ buildNpmPackage rec { # the installer does a bunch of stuff that fails in our sandbox, so just build here and then we # manually do the install - buildFlags = [ "res" "src" ]; + buildFlags = [ + "res" + "src" + ]; nativeBuildInputs = with libsForQt5; [ plasma-framework ]; diff --git a/pkgs/by-name/po/poly/package.nix b/pkgs/by-name/po/poly/package.nix index 50dfb502035430..bffa196606a24c 100644 --- a/pkgs/by-name/po/poly/package.nix +++ b/pkgs/by-name/po/poly/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { name = "poly"; @@ -15,7 +20,7 @@ stdenv.mkDerivation rec { sha256 = "1chzcy3kyi7wpr4iq4aj1v24fq1wwph1v5z96dimlqcrnvm66h2l"; }; - nativeBuildInputs = [unzip]; + nativeBuildInputs = [ unzip ]; sourceRoot = "."; diff --git a/pkgs/by-name/po/poly2tri-c/package.nix b/pkgs/by-name/po/poly2tri-c/package.nix index 0c68c2950eb2ab..817c0558fca4a1 100644 --- a/pkgs/by-name/po/poly2tri-c/package.nix +++ b/pkgs/by-name/po/poly2tri-c/package.nix @@ -1,15 +1,21 @@ -{ lib, stdenv -, fetchFromGitLab -, autoreconfHook -, pkg-config -, glib +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + glib, }: stdenv.mkDerivation rec { pname = "poly2tri-c"; version = "0.1.0"; - outputs = [ "bin" "out" "dev" ]; + outputs = [ + "bin" + "out" + "dev" + ]; src = fetchFromGitLab { domain = "gitlab.gnome.org"; diff --git a/pkgs/by-name/po/polybar-pulseaudio-control/package.nix b/pkgs/by-name/po/polybar-pulseaudio-control/package.nix index 44067422bf1f7a..1aca3360c8175c 100644 --- a/pkgs/by-name/po/polybar-pulseaudio-control/package.nix +++ b/pkgs/by-name/po/polybar-pulseaudio-control/package.nix @@ -1,13 +1,14 @@ -{ lib -, bash -, coreutils -, fetchFromGitHub -, gnused -, gnugrep -, gawk -, makeWrapper -, pulseaudio -, stdenv +{ + lib, + bash, + coreutils, + fetchFromGitHub, + gnused, + gnugrep, + gawk, + makeWrapper, + pulseaudio, + stdenv, }: stdenv.mkDerivation (finalAttrs: { @@ -30,7 +31,16 @@ stdenv.mkDerivation (finalAttrs: { install -Dm755 pulseaudio-control.bash $out/bin/pulseaudio-control wrapProgram "$out/bin/pulseaudio-control" \ - --prefix PATH : "${lib.makeBinPath [ bash coreutils gnused gnugrep gawk pulseaudio ]}" + --prefix PATH : "${ + lib.makeBinPath [ + bash + coreutils + gnused + gnugrep + gawk + pulseaudio + ] + }" runHook postInstall ''; @@ -41,6 +51,9 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/marioortizmanero/polybar-pulseaudio-control"; platforms = platforms.linux; license = licenses.mit; - maintainers = with maintainers; [ benlemasurier wesleyjrz ]; + maintainers = with maintainers; [ + benlemasurier + wesleyjrz + ]; }; }) diff --git a/pkgs/by-name/po/polybar/package.nix b/pkgs/by-name/po/polybar/package.nix index ab3bf1e8e69181..8e90ffa4389715 100644 --- a/pkgs/by-name/po/polybar/package.nix +++ b/pkgs/by-name/po/polybar/package.nix @@ -1,43 +1,44 @@ -{ config -, cairo -, cmake -, fetchFromGitHub -, libuv -, libXdmcp -, libpthreadstubs -, libxcb -, pcre -, pkg-config -, python3 -, python3Packages # sphinx-build -, lib -, stdenv -, xcbproto -, xcbutil -, xcbutilcursor -, xcbutilimage -, xcbutilrenderutil -, xcbutilwm -, xcbutilxrm -, makeWrapper -, removeReferencesTo -, alsa-lib -, curl -, libmpdclient -, libpulseaudio -, wirelesstools -, libnl -, i3 -, jsoncpp +{ + config, + cairo, + cmake, + fetchFromGitHub, + libuv, + libXdmcp, + libpthreadstubs, + libxcb, + pcre, + pkg-config, + python3, + python3Packages, # sphinx-build + lib, + stdenv, + xcbproto, + xcbutil, + xcbutilcursor, + xcbutilimage, + xcbutilrenderutil, + xcbutilwm, + xcbutilxrm, + makeWrapper, + removeReferencesTo, + alsa-lib, + curl, + libmpdclient, + libpulseaudio, + wirelesstools, + libnl, + i3, + jsoncpp, # override the variables ending in 'Support' to enable or disable modules -, alsaSupport ? true -, githubSupport ? false -, mpdSupport ? false -, pulseSupport ? config.pulseaudio or false -, iwSupport ? false -, nlSupport ? true -, i3Support ? false + alsaSupport ? true, + githubSupport ? false, + mpdSupport ? false, + pulseSupport ? config.pulseaudio or false, + iwSupport ? false, + nlSupport ? true, + i3Support ? false, }: stdenv.mkDerivation (finalAttrs: { @@ -59,28 +60,33 @@ stdenv.mkDerivation (finalAttrs: { removeReferencesTo ] ++ lib.optional i3Support makeWrapper; - buildInputs = [ - cairo - libuv - libXdmcp - libpthreadstubs - libxcb - pcre - python3 - xcbproto - xcbutil - xcbutilcursor - xcbutilimage - xcbutilrenderutil - xcbutilwm - xcbutilxrm - ] ++ lib.optional alsaSupport alsa-lib - ++ lib.optional githubSupport curl - ++ lib.optional mpdSupport libmpdclient - ++ lib.optional pulseSupport libpulseaudio - ++ lib.optional iwSupport wirelesstools - ++ lib.optional nlSupport libnl - ++ lib.optionals i3Support [ jsoncpp i3 ]; + buildInputs = + [ + cairo + libuv + libXdmcp + libpthreadstubs + libxcb + pcre + python3 + xcbproto + xcbutil + xcbutilcursor + xcbutilimage + xcbutilrenderutil + xcbutilwm + xcbutilxrm + ] + ++ lib.optional alsaSupport alsa-lib + ++ lib.optional githubSupport curl + ++ lib.optional mpdSupport libmpdclient + ++ lib.optional pulseSupport libpulseaudio + ++ lib.optional iwSupport wirelesstools + ++ lib.optional nlSupport libnl + ++ lib.optionals i3Support [ + jsoncpp + i3 + ]; patches = [ ./remove-hardcoded-etc.diff ]; @@ -90,12 +96,14 @@ stdenv.mkDerivation (finalAttrs: { substituteAllInPlace src/utils/file.cpp ''; - postInstall = '' - remove-references-to -t ${stdenv.cc} $out/bin/polybar - '' + (lib.optionalString i3Support '' - wrapProgram $out/bin/polybar \ - --prefix PATH : "${i3}/bin" - ''); + postInstall = + '' + remove-references-to -t ${stdenv.cc} $out/bin/polybar + '' + + (lib.optionalString i3Support '' + wrapProgram $out/bin/polybar \ + --prefix PATH : "${i3}/bin" + ''); meta = with lib; { homepage = "https://polybar.github.io/"; @@ -107,7 +115,11 @@ stdenv.mkDerivation (finalAttrs: { having a black belt in shell scripting. ''; license = licenses.mit; - maintainers = with maintainers; [ afldcr Br1ght0ne moni ]; + maintainers = with maintainers; [ + afldcr + Br1ght0ne + moni + ]; mainProgram = "polybar"; platforms = platforms.linux; }; diff --git a/pkgs/by-name/po/polygon-cli/package.nix b/pkgs/by-name/po/polygon-cli/package.nix index 07bfa97045571d..e69036f993118e 100644 --- a/pkgs/by-name/po/polygon-cli/package.nix +++ b/pkgs/by-name/po/polygon-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonPackage rec { diff --git a/pkgs/by-name/po/polygraph/package.nix b/pkgs/by-name/po/polygraph/package.nix index f4742e660d834f..9629cf098cc2c7 100644 --- a/pkgs/by-name/po/polygraph/package.nix +++ b/pkgs/by-name/po/polygraph/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, openssl, zlib, ncurses }: +{ + lib, + stdenv, + fetchurl, + openssl, + zlib, + ncurses, +}: stdenv.mkDerivation rec { pname = "polygraph"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "1rwzci3n7q33hw3spd79adnclzwgwlxcisc9szzjmcjqhbkcpj1a"; }; - buildInputs = [ openssl zlib ncurses ]; + buildInputs = [ + openssl + zlib + ncurses + ]; meta = with lib; { homepage = "http://www.web-polygraph.org"; diff --git a/pkgs/by-name/po/polylith/package.nix b/pkgs/by-name/po/polylith/package.nix index 54c1954380f2a8..8e2a5598119338 100644 --- a/pkgs/by-name/po/polylith/package.nix +++ b/pkgs/by-name/po/polylith/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jdk, runtimeShell }: +{ + lib, + stdenv, + fetchurl, + jdk, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "polylith"; @@ -47,7 +53,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/polyfy/polylith"; sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.epl10; - maintainers = with maintainers; [ ericdallo jlesquembre ]; + maintainers = with maintainers; [ + ericdallo + jlesquembre + ]; platforms = jdk.meta.platforms; }; } diff --git a/pkgs/by-name/po/polylux2pdfpc/package.nix b/pkgs/by-name/po/polylux2pdfpc/package.nix index cfe1290d193910..a080b2b123e687 100644 --- a/pkgs/by-name/po/polylux2pdfpc/package.nix +++ b/pkgs/by-name/po/polylux2pdfpc/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, nix-update-script +{ + lib, + rustPlatform, + fetchFromGitHub, + nix-update-script, }: let diff --git a/pkgs/by-name/po/polymake/package.nix b/pkgs/by-name/po/polymake/package.nix index eb4c835353939d..a0b90178df2746 100644 --- a/pkgs/by-name/po/polymake/package.nix +++ b/pkgs/by-name/po/polymake/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchurl -, gmp -, mpfr -, flint -, boost -, bliss -, ppl -, singular -, cddlib -, lrs -, nauty -, ninja -, ant -, openjdk -, perl -, perlPackages -, makeWrapper +{ + lib, + stdenv, + fetchurl, + gmp, + mpfr, + flint, + boost, + bliss, + ppl, + singular, + cddlib, + lrs, + nauty, + ninja, + ant, + openjdk, + perl, + perlPackages, + makeWrapper, }: # polymake compiles its own version of sympol and atint because we @@ -41,27 +42,32 @@ stdenv.mkDerivation rec { perl ]; - buildInputs = [ - perl - gmp - mpfr - flint - boost - bliss - ppl - singular - cddlib - lrs - nauty - openjdk - ] ++ (with perlPackages; [ - JSON - TermReadLineGnu - TermReadKey - XMLSAX - ]); + buildInputs = + [ + perl + gmp + mpfr + flint + boost + bliss + ppl + singular + cddlib + lrs + nauty + openjdk + ] + ++ (with perlPackages; [ + JSON + TermReadLineGnu + TermReadKey + XMLSAX + ]); - ninjaFlags = [ "-C" "build/Opt" ]; + ninjaFlags = [ + "-C" + "build/Opt" + ]; postInstall = '' for i in "$out"/bin/*; do diff --git a/pkgs/by-name/po/polypane/package.nix b/pkgs/by-name/po/polypane/package.nix index 5b6d17985d0405..e14675f70057b2 100644 --- a/pkgs/by-name/po/polypane/package.nix +++ b/pkgs/by-name/po/polypane/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools }: +{ + lib, + fetchurl, + appimageTools, +}: let pname = "polypane"; @@ -13,7 +17,8 @@ let appimageContents = appimageTools.extractType2 { inherit pname src version; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname src version; extraPkgs = pkgs: [ pkgs.bash ]; diff --git a/pkgs/by-name/po/polytopes_db/package.nix b/pkgs/by-name/po/polytopes_db/package.nix index 8e9e7b44a4aac8..a46acf47d242dc 100644 --- a/pkgs/by-name/po/polytopes_db/package.nix +++ b/pkgs/by-name/po/polytopes_db/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/po/pom/package.nix b/pkgs/by-name/po/pom/package.nix index 4b9fc2615f6c5a..843012a86335f3 100644 --- a/pkgs/by-name/po/pom/package.nix +++ b/pkgs/by-name/po/pom/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pom"; @@ -13,13 +17,20 @@ buildGoModule rec { vendorHash = "sha256-xJNcFX+sZjZwXFTNrhsDnj3eR/r8+NH6tzpEJOhtkeY="; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; meta = with lib; { description = "Pomodoro timer in your terminal"; homepage = "https://github.com/maaslalani/pom"; license = licenses.mit; - maintainers = with maintainers; [ maaslalani redyf ]; + maintainers = with maintainers; [ + maaslalani + redyf + ]; mainProgram = "pom"; }; } diff --git a/pkgs/by-name/po/pomerium-cli/package.nix b/pkgs/by-name/po/pomerium-cli/package.nix index 328717aca5817c..990f1bb348e3df 100644 --- a/pkgs/by-name/po/pomerium-cli/package.nix +++ b/pkgs/by-name/po/pomerium-cli/package.nix @@ -1,10 +1,16 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: let - inherit (lib) concatStringsSep concatMap id mapAttrsToList; + inherit (lib) + concatStringsSep + concatMap + id + mapAttrsToList + ; in buildGoModule rec { pname = "pomerium-cli"; @@ -23,27 +29,29 @@ buildGoModule rec { "cmd/pomerium-cli" ]; - ldflags = let - # Set a variety of useful meta variables for stamping the build with. - setVars = { - "github.com/pomerium/cli/version" = { - Version = "v${version}"; - BuildMeta = "nixpkgs"; - ProjectName = "pomerium-cli"; - ProjectURL = "github.com/pomerium/cli"; + ldflags = + let + # Set a variety of useful meta variables for stamping the build with. + setVars = { + "github.com/pomerium/cli/version" = { + Version = "v${version}"; + BuildMeta = "nixpkgs"; + ProjectName = "pomerium-cli"; + ProjectURL = "github.com/pomerium/cli"; + }; }; - }; - concatStringsSpace = list: concatStringsSep " " list; - mapAttrsToFlatList = fn: list: concatMap id (mapAttrsToList fn list); - varFlags = concatStringsSpace ( - mapAttrsToFlatList (package: packageVars: - mapAttrsToList (variable: value: - "-X ${package}.${variable}=${value}" - ) packageVars - ) setVars); - in [ - "${varFlags}" - ]; + concatStringsSpace = list: concatStringsSep " " list; + mapAttrsToFlatList = fn: list: concatMap id (mapAttrsToList fn list); + varFlags = concatStringsSpace ( + mapAttrsToFlatList ( + package: packageVars: + mapAttrsToList (variable: value: "-X ${package}.${variable}=${value}") packageVars + ) setVars + ); + in + [ + "${varFlags}" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/po/pomerium/package.nix b/pkgs/by-name/po/pomerium/package.nix index 2dcbf2069c38db..b19b8c130e3db3 100644 --- a/pkgs/by-name/po/pomerium/package.nix +++ b/pkgs/by-name/po/pomerium/package.nix @@ -1,15 +1,21 @@ -{ buildGo123Module -, fetchFromGitHub -, lib -, envoy -, mkYarnPackage -, fetchYarnDeps -, nixosTests -, pomerium-cli +{ + buildGo123Module, + fetchFromGitHub, + lib, + envoy, + mkYarnPackage, + fetchYarnDeps, + nixosTests, + pomerium-cli, }: let - inherit (lib) concatStringsSep concatMap id mapAttrsToList; + inherit (lib) + concatStringsSep + concatMap + id + mapAttrsToList + ; in buildGo123Module rec { pname = "pomerium"; @@ -57,30 +63,32 @@ buildGo123Module rec { ./0001-envoy-allow-specification-of-external-binary.patch ]; - ldflags = let - # Set a variety of useful meta variables for stamping the build with. - setVars = { - "github.com/pomerium/pomerium/internal/version" = { - Version = "v${version}"; - BuildMeta = "nixpkgs"; - ProjectName = "pomerium"; - ProjectURL = "github.com/pomerium/pomerium"; + ldflags = + let + # Set a variety of useful meta variables for stamping the build with. + setVars = { + "github.com/pomerium/pomerium/internal/version" = { + Version = "v${version}"; + BuildMeta = "nixpkgs"; + ProjectName = "pomerium"; + ProjectURL = "github.com/pomerium/pomerium"; + }; + "github.com/pomerium/pomerium/pkg/envoy" = { + OverrideEnvoyPath = "${envoy}/bin/envoy"; + }; }; - "github.com/pomerium/pomerium/pkg/envoy" = { - OverrideEnvoyPath = "${envoy}/bin/envoy"; - }; - }; - concatStringsSpace = list: concatStringsSep " " list; - mapAttrsToFlatList = fn: list: concatMap id (mapAttrsToList fn list); - varFlags = concatStringsSpace ( - mapAttrsToFlatList (package: packageVars: - mapAttrsToList (variable: value: - "-X ${package}.${variable}=${value}" - ) packageVars - ) setVars); - in [ - "${varFlags}" - ]; + concatStringsSpace = list: concatStringsSep " " list; + mapAttrsToFlatList = fn: list: concatMap id (mapAttrsToList fn list); + varFlags = concatStringsSpace ( + mapAttrsToFlatList ( + package: packageVars: + mapAttrsToList (variable: value: "-X ${package}.${variable}=${value}") packageVars + ) setVars + ); + in + [ + "${varFlags}" + ]; preBuild = '' # Replace embedded envoy with nothing. @@ -124,7 +132,13 @@ buildGo123Module rec { description = "Authenticating reverse proxy"; mainProgram = "pomerium"; license = licenses.asl20; - maintainers = with maintainers; [ lukegb devusb ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + maintainers = with maintainers; [ + lukegb + devusb + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; }; } diff --git a/pkgs/by-name/po/pommed_light/package.nix b/pkgs/by-name/po/pommed_light/package.nix index 11a5cebc76bfbe..0def37b1b7c48c 100644 --- a/pkgs/by-name/po/pommed_light/package.nix +++ b/pkgs/by-name/po/pommed_light/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, pciutils -, libconfuse -, alsa-lib -, audiofile -, pkg-config -, zlib -, eject +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pciutils, + libconfuse, + alsa-lib, + audiofile, + pkg-config, + zlib, + eject, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/po/pomodoro-gtk/package.nix b/pkgs/by-name/po/pomodoro-gtk/package.nix index b373535960c9b3..e31da5221375c6 100644 --- a/pkgs/by-name/po/pomodoro-gtk/package.nix +++ b/pkgs/by-name/po/pomodoro-gtk/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, gjs -, gobject-introspection -, blueprint-compiler -, wrapGAppsHook4 -, desktop-file-utils -, libadwaita -, libgda6 -, gsound -, gst_all_1 -, libportal-gtk4 +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + gjs, + gobject-introspection, + blueprint-compiler, + wrapGAppsHook4, + desktop-file-utils, + libadwaita, + libgda6, + gsound, + gst_all_1, + libportal-gtk4, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/po/pomsky/package.nix b/pkgs/by-name/po/pomsky/package.nix index d86b138861bf20..3b96abba05a463 100644 --- a/pkgs/by-name/po/pomsky/package.nix +++ b/pkgs/by-name/po/pomsky/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, pkg-config, oniguruma }: +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + oniguruma, +}: rustPlatform.buildRustPackage rec { pname = "pomsky"; @@ -39,7 +45,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "pomsky"; homepage = "https://pomsky-lang.org"; changelog = "https://github.com/pomsky-lang/pomsky/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/po/pong3d/package.nix b/pkgs/by-name/po/pong3d/package.nix index 9e965c95482a6d..32614d8db29236 100644 --- a/pkgs/by-name/po/pong3d/package.nix +++ b/pkgs/by-name/po/pong3d/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, libX11}: +{ + lib, + stdenv, + fetchurl, + libX11, +}: stdenv.mkDerivation rec { pname = "3dpong"; diff --git a/pkgs/by-name/po/ponymix/package.nix b/pkgs/by-name/po/ponymix/package.nix index e0cf106e460b77..c3072757a57e6e 100644 --- a/pkgs/by-name/po/ponymix/package.nix +++ b/pkgs/by-name/po/ponymix/package.nix @@ -1,17 +1,27 @@ -{ lib, stdenv, fetchFromGitHub, libpulseaudio, libnotify, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + libpulseaudio, + libnotify, + pkg-config, +}: stdenv.mkDerivation rec { pname = "ponymix"; version = "5"; src = fetchFromGitHub { - owner = "falconindy"; - repo = "ponymix"; - rev = version; + owner = "falconindy"; + repo = "ponymix"; + rev = version; sha256 = "08yp7fprmzm6px5yx2rvzri0l60bra5h59l26pn0k071a37ks1rb"; }; - buildInputs = [ libpulseaudio libnotify ]; + buildInputs = [ + libpulseaudio + libnotify + ]; nativeBuildInputs = [ pkg-config ]; postPatch = ''substituteInPlace Makefile --replace "\$(DESTDIR)/usr" "$out"''; diff --git a/pkgs/by-name/po/ponysay/package.nix b/pkgs/by-name/po/ponysay/package.nix index f58d78285d7fbd..fcbc75e1819627 100644 --- a/pkgs/by-name/po/ponysay/package.nix +++ b/pkgs/by-name/po/ponysay/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, python3, texinfo, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + texinfo, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "ponysay"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ python3 texinfo ]; + buildInputs = [ + python3 + texinfo + ]; inherit python3; diff --git a/pkgs/by-name/po/pop-gtk-theme/package.nix b/pkgs/by-name/po/pop-gtk-theme/package.nix index dd4c0281fa8668..b8e34f536fab95 100644 --- a/pkgs/by-name/po/pop-gtk-theme/package.nix +++ b/pkgs/by-name/po/pop-gtk-theme/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, sassc -, gtk3 -, inkscape -, optipng -, gtk-engine-murrine -, gdk-pixbuf -, librsvg -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + sassc, + gtk3, + inkscape, + optipng, + gtk-engine-murrine, + gdk-pixbuf, + librsvg, + python3, }: stdenv.mkDerivation rec { @@ -58,7 +59,11 @@ stdenv.mkDerivation rec { meta = with lib; { description = "System76 Pop GTK+ Theme"; homepage = "https://github.com/pop-os/gtk-theme"; - license = with licenses; [ gpl3 lgpl21 cc-by-sa-40 ]; + license = with licenses; [ + gpl3 + lgpl21 + cc-by-sa-40 + ]; platforms = platforms.linux; maintainers = [ ]; }; diff --git a/pkgs/by-name/po/pop-icon-theme/package.nix b/pkgs/by-name/po/pop-icon-theme/package.nix index 8d4467e3abad6a..fd0a63376b7bad 100644 --- a/pkgs/by-name/po/pop-icon-theme/package.nix +++ b/pkgs/by-name/po/pop-icon-theme/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, meson -, ninja -, gtk3 -, adwaita-icon-theme -, hicolor-icon-theme +{ + lib, + stdenvNoCC, + fetchFromGitHub, + meson, + ninja, + gtk3, + adwaita-icon-theme, + hicolor-icon-theme, }: stdenvNoCC.mkDerivation rec { @@ -35,7 +36,10 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { description = "Icon theme for Pop!_OS with a semi-flat design and raised 3D motifs"; homepage = "https://github.com/pop-os/icon-theme"; - license = with licenses; [ cc-by-sa-40 gpl3 ]; + license = with licenses; [ + cc-by-sa-40 + gpl3 + ]; platforms = platforms.linux; # hash mismatch on darwin due to file names differing only in case maintainers = with maintainers; [ romildo ]; }; diff --git a/pkgs/by-name/po/pop/package.nix b/pkgs/by-name/po/pop/package.nix index f20ab86c85c90a..d320feb46e8227 100644 --- a/pkgs/by-name/po/pop/package.nix +++ b/pkgs/by-name/po/pop/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, installShellFiles, fetchFromGitHub }: +{ + lib, + buildGoModule, + installShellFiles, + fetchFromGitHub, +}: buildGoModule rec { pname = "pop"; @@ -19,7 +24,11 @@ buildGoModule rec { installShellFiles ]; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; postInstall = '' $out/bin/pop man > pop.1 @@ -35,7 +44,10 @@ buildGoModule rec { homepage = "https://github.com/charmbracelet/pop"; changelog = "https://github.com/charmbracelet/pop/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ caarlos0 maaslalani ]; + maintainers = with maintainers; [ + caarlos0 + maaslalani + ]; mainProgram = "pop"; }; } diff --git a/pkgs/by-name/po/popa3d/package.nix b/pkgs/by-name/po/popa3d/package.nix index da7ba498f243b9..b4ced4eb19e25b 100644 --- a/pkgs/by-name/po/popa3d/package.nix +++ b/pkgs/by-name/po/popa3d/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, openssl, libxcrypt }: +{ + lib, + stdenv, + fetchurl, + openssl, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "popa3d"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1g48cd74sqhl496wmljhq44iyfpghaz363a1ip8nyhpjz7d57f03"; }; - buildInputs = [ openssl libxcrypt ]; + buildInputs = [ + openssl + libxcrypt + ]; patches = [ ./fix-mail-spool-path.patch diff --git a/pkgs/by-name/po/popcorntime/package.nix b/pkgs/by-name/po/popcorntime/package.nix index 28fd5b60e6898b..93413a04572d15 100644 --- a/pkgs/by-name/po/popcorntime/package.nix +++ b/pkgs/by-name/po/popcorntime/package.nix @@ -1,18 +1,19 @@ -{ autoPatchelfHook -, fetchurl -, gcc-unwrapped -, gsettings-desktop-schemas -, gtk3 -, lib -, libGL -, makeDesktopItem -, makeWrapper -, nwjs -, stdenv -, unzip -, udev -, wrapGAppsHook3 -, copyDesktopItems +{ + autoPatchelfHook, + fetchurl, + gcc-unwrapped, + gsettings-desktop-schemas, + gtk3, + lib, + libGL, + makeDesktopItem, + makeWrapper, + nwjs, + stdenv, + unzip, + udev, + wrapGAppsHook3, + copyDesktopItems, }: stdenv.mkDerivation rec { @@ -46,20 +47,30 @@ stdenv.mkDerivation rec { dontUnpack = true; makeWrapperArgs = [ - "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ gcc-unwrapped.lib gtk3 udev libGL ]}" + "--prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + gcc-unwrapped.lib + gtk3 + udev + libGL + ] + }" "--prefix PATH : ${lib.makeBinPath [ stdenv.cc ]}" ]; desktopItem = makeDesktopItem { - name = pname; - exec = pname; - icon = pname; - comment = meta.description; - genericName = meta.description; - type = "Application"; - desktopName = "Popcorn-Time"; - categories = [ "Video" "AudioVideo" ]; - }; + name = pname; + exec = pname; + icon = pname; + comment = meta.description; + genericName = meta.description; + type = "Application"; + desktopName = "Popcorn-Time"; + categories = [ + "Video" + "AudioVideo" + ]; + }; # Extract and copy executable in $out/bin installPhase = '' diff --git a/pkgs/by-name/po/popeye/package.nix b/pkgs/by-name/po/popeye/package.nix index 7f6f7dae86387e..135ed614047382 100644 --- a/pkgs/by-name/po/popeye/package.nix +++ b/pkgs/by-name/po/popeye/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "popeye"; @@ -12,7 +17,8 @@ buildGoModule rec { }; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/derailed/popeye/cmd.version=${version}" "-X github.com/derailed/popeye/cmd.commit=${version}" ]; diff --git a/pkgs/by-name/po/popfile/package.nix b/pkgs/by-name/po/popfile/package.nix index b902a75bb47679..2189104b8f7063 100644 --- a/pkgs/by-name/po/popfile/package.nix +++ b/pkgs/by-name/po/popfile/package.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchzip, makeWrapper, perlPackages, -... }: +{ + lib, + stdenv, + fetchzip, + makeWrapper, + perlPackages, + ... +}: stdenv.mkDerivation rec { appname = "popfile"; @@ -13,21 +19,24 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = (with perlPackages; [ - ## These are all taken from the popfile documentation as applicable to Linux - ## https://getpopfile.org/docs/howtos:allplatformsrequireperl - perl - DBI - DBDSQLite - HTMLTagset - TimeDate # == DateParse - HTMLTemplate - # IO::Socket::Socks is not in nixpkgs - # IOSocketSocks - IOSocketSSL - NetSSLeay - SOAPLite - ]); + buildInputs = ( + with perlPackages; + [ + ## These are all taken from the popfile documentation as applicable to Linux + ## https://getpopfile.org/docs/howtos:allplatformsrequireperl + perl + DBI + DBDSQLite + HTMLTagset + TimeDate # == DateParse + HTMLTemplate + # IO::Socket::Socks is not in nixpkgs + # IOSocketSocks + IOSocketSSL + NetSSLeay + SOAPLite + ] + ); installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/po/popl/package.nix b/pkgs/by-name/po/popl/package.nix index b72b97172e379e..0eb4dd306d0070 100644 --- a/pkgs/by-name/po/popl/package.nix +++ b/pkgs/by-name/po/popl/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/po/poppins/package.nix b/pkgs/by-name/po/poppins/package.nix index f72ce9ffcc6923..32ee21503798c2 100644 --- a/pkgs/by-name/po/poppins/package.nix +++ b/pkgs/by-name/po/poppins/package.nix @@ -15,7 +15,7 @@ stdenvNoCC.mkDerivation rec { hash = "sha256-7+RQHYxNFqOw2EeS2hgrbK/VbUAiPorUtkyRb5MFh5w="; }; - nativeBuildInputs = [unzip]; + nativeBuildInputs = [ unzip ]; installPhase = '' runHook preInstall @@ -29,7 +29,7 @@ stdenvNoCC.mkDerivation rec { description = "Devanagari + Latin family for Google Fonts"; homepage = "https://github.com/itfoundry/Poppins/"; license = lib.licenses.ofl; - maintainers = with lib.maintainers; [nyawox]; + maintainers = with lib.maintainers; [ nyawox ]; platforms = lib.platforms.all; }; } diff --git a/pkgs/by-name/po/poppler_data/package.nix b/pkgs/by-name/po/poppler_data/package.nix index 392761a9bd2509..6c11f81ea0afa5 100644 --- a/pkgs/by-name/po/poppler_data/package.nix +++ b/pkgs/by-name/po/poppler_data/package.nix @@ -1,9 +1,10 @@ -{ fetchurl -, lib -, stdenv -, cmake -, ninja -, poppler +{ + fetchurl, + lib, + stdenv, + cmake, + ninja, + poppler, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/po/popsicle/package.nix b/pkgs/by-name/po/popsicle/package.nix index 315ac11abb6c8b..a7d5a90624dbfd 100644 --- a/pkgs/by-name/po/popsicle/package.nix +++ b/pkgs/by-name/po/popsicle/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, cargo -, glib -, pkg-config -, rustc -, wrapGAppsHook3 -, gdk-pixbuf -, gtk3 +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + cargo, + glib, + pkg-config, + rustc, + wrapGAppsHook3, + gdk-pixbuf, + gtk3, }: stdenv.mkDerivation rec { @@ -50,7 +51,10 @@ stdenv.mkDerivation rec { description = "Multiple USB File Flasher"; homepage = "https://github.com/pop-os/popsicle"; changelog = "https://github.com/pop-os/popsicle/releases/tag/${version}"; - maintainers = with maintainers; [ _13r0ck figsoda ]; + maintainers = with maintainers; [ + _13r0ck + figsoda + ]; license = licenses.mit; platforms = platforms.linux; }; diff --git a/pkgs/by-name/po/popt/package.nix b/pkgs/by-name/po/popt/package.nix index 282203a98af7b1..eb9e4f3685ed48 100644 --- a/pkgs/by-name/po/popt/package.nix +++ b/pkgs/by-name/po/popt/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch2 -, updateAutotoolsGnuConfigScriptsHook +{ + lib, + stdenv, + fetchurl, + fetchpatch2, + updateAutotoolsGnuConfigScriptsHook, }: stdenv.mkDerivation rec { @@ -16,27 +17,29 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook ]; - patches = lib.optionals stdenv.hostPlatform.isCygwin [ - ./1.16-cygwin.patch - ./1.16-vpath.patch - ] ++ lib.optionals stdenv.hostPlatform.isMinGW [ - # Do not require - (fetchpatch2 { - url = "https://aur.archlinux.org/cgit/aur.git/plain/get-w32-console-maxcols.mingw32.patch?h=mingw-w64-popt&id=63f2cdb0de116362c49681cef20f7a8b4355e85a"; - sha256 = "zv43l1RBqNzT/JG+jQaMVFaFv+ZYPuIiAtKUDzJJBbc="; - stripLen = 1; - extraPrefix = "src/"; - }) + patches = + lib.optionals stdenv.hostPlatform.isCygwin [ + ./1.16-cygwin.patch + ./1.16-vpath.patch + ] + ++ lib.optionals stdenv.hostPlatform.isMinGW [ + # Do not require + (fetchpatch2 { + url = "https://aur.archlinux.org/cgit/aur.git/plain/get-w32-console-maxcols.mingw32.patch?h=mingw-w64-popt&id=63f2cdb0de116362c49681cef20f7a8b4355e85a"; + sha256 = "zv43l1RBqNzT/JG+jQaMVFaFv+ZYPuIiAtKUDzJJBbc="; + stripLen = 1; + extraPrefix = "src/"; + }) - # Do not try to detect setuid, it is not a thing. - (fetchpatch2 { - url = "https://github.com/rpm-software-management/popt/commit/905544c5d9767894edaf71a1e3ce5126944c5695.patch"; - sha256 = "3PmcxeiEZ/Hof0zoVFSytEXvQ8gE8Sp5UdagExPVICU="; - stripLen = 1; - extraPrefix = "src/"; - revert = true; - }) - ]; + # Do not try to detect setuid, it is not a thing. + (fetchpatch2 { + url = "https://github.com/rpm-software-management/popt/commit/905544c5d9767894edaf71a1e3ce5126944c5695.patch"; + sha256 = "3PmcxeiEZ/Hof0zoVFSytEXvQ8gE8Sp5UdagExPVICU="; + stripLen = 1; + extraPrefix = "src/"; + revert = true; + }) + ]; doCheck = false; # fails diff --git a/pkgs/by-name/po/popura/package.nix b/pkgs/by-name/po/popura/package.nix index c7e5174452adc3..b28cee329d4932 100644 --- a/pkgs/by-name/po/popura/package.nix +++ b/pkgs/by-name/po/popura/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,12 +17,16 @@ buildGoModule rec { vendorHash = "sha256-9lQC35yt1S2uch3qgwNfa/1FHy+Qi1D5Jo7DWNMgU9w="; - ldflags = let pkgSrc = "github.com/yggdrasil-network/yggdrasil-go/src/version"; in [ - "-s" - "-w" - "-X=${pkgSrc}.buildName=yggdrasil" - "-X=${pkgSrc}.buildVersion=${version}" - ]; + ldflags = + let + pkgSrc = "github.com/yggdrasil-network/yggdrasil-go/src/version"; + in + [ + "-s" + "-w" + "-X=${pkgSrc}.buildName=yggdrasil" + "-X=${pkgSrc}.buildVersion=${version}" + ]; meta = with lib; { description = "Alternative Yggdrasil network client"; diff --git a/pkgs/by-name/po/porsmo/package.nix b/pkgs/by-name/po/porsmo/package.nix index 6d9ed5ee2c98e1..d67b7782867a39 100644 --- a/pkgs/by-name/po/porsmo/package.nix +++ b/pkgs/by-name/po/porsmo/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, alsa-lib -, stdenv -, darwin -, testers -, porsmo +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + alsa-lib, + stdenv, + darwin, + testers, + porsmo, }: rustPlatform.buildRustPackage rec { @@ -27,12 +28,14 @@ rustPlatform.buildRustPackage rec { rustPlatform.bindgenHook ]; - buildInputs = [ - alsa-lib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreAudio - darwin.apple_sdk.frameworks.CoreFoundation - ]; + buildInputs = + [ + alsa-lib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreAudio + darwin.apple_sdk.frameworks.CoreFoundation + ]; passthru.tests.version = testers.testVersion { package = porsmo; diff --git a/pkgs/by-name/po/portal/package.nix b/pkgs/by-name/po/portal/package.nix index 221526b7f34238..c64c8050c53159 100644 --- a/pkgs/by-name/po/portal/package.nix +++ b/pkgs/by-name/po/portal/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "portal"; diff --git a/pkgs/by-name/po/portfolio-filemanager/package.nix b/pkgs/by-name/po/portfolio-filemanager/package.nix index 6b19d9564f6822..04bb70bd0c71fb 100644 --- a/pkgs/by-name/po/portfolio-filemanager/package.nix +++ b/pkgs/by-name/po/portfolio-filemanager/package.nix @@ -1,18 +1,19 @@ -{ lib -, python3 -, fetchFromGitHub -, appstream-glib -, desktop-file-utils -, gettext -, gobject-introspection -, gtk3 -, gtk4 -, libadwaita -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, nix-update-script +{ + lib, + python3, + fetchFromGitHub, + appstream-glib, + desktop-file-utils, + gettext, + gobject-introspection, + gtk3, + gtk4, + libadwaita, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + nix-update-script, }: python3.pkgs.buildPythonApplication rec { @@ -78,6 +79,9 @@ python3.pkgs.buildPythonApplication rec { license = licenses.gpl3Plus; platforms = platforms.linux; mainProgram = "dev.tchx84.Portfolio"; - maintainers = with maintainers; [ dotlambda chuangzhu ]; + maintainers = with maintainers; [ + dotlambda + chuangzhu + ]; }; } diff --git a/pkgs/by-name/po/portunus/package.nix b/pkgs/by-name/po/portunus/package.nix index 1cbc81afdd9790..96408db6f66d9d 100644 --- a/pkgs/by-name/po/portunus/package.nix +++ b/pkgs/by-name/po/portunus/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, libxcrypt -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + libxcrypt, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/by-name/po/posteid-seed-extractor/package.nix b/pkgs/by-name/po/posteid-seed-extractor/package.nix index b0c1f04d21a479..3a9976508fe112 100644 --- a/pkgs/by-name/po/posteid-seed-extractor/package.nix +++ b/pkgs/by-name/po/posteid-seed-extractor/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication { @@ -17,19 +18,19 @@ python3Packages.buildPythonApplication { format = "other"; pythonPath = with python3Packages; [ - certifi - cffi - charset-normalizer - cryptography - idna - jwcrypto - pycparser - pycryptodome - pyotp - qrcode - requests - urllib3 - wrapt + certifi + cffi + charset-normalizer + cryptography + idna + jwcrypto + pycparser + pycryptodome + pyotp + qrcode + requests + urllib3 + wrapt ]; installPhase = '' diff --git a/pkgs/by-name/po/posterazor/package.nix b/pkgs/by-name/po/posterazor/package.nix index 6ccb0598506ed8..300f959bb0f276 100644 --- a/pkgs/by-name/po/posterazor/package.nix +++ b/pkgs/by-name/po/posterazor/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, cmake -, unzip -, pkg-config -, libXpm -, fltk13 -, freeimage +{ + lib, + stdenv, + fetchurl, + cmake, + unzip, + pkg-config, + libXpm, + fltk13, + freeimage, }: stdenv.mkDerivation rec { @@ -20,8 +21,16 @@ stdenv.mkDerivation rec { hardeningDisable = [ "format" ]; - nativeBuildInputs = [ cmake pkg-config unzip ]; - buildInputs = [ libXpm fltk13 freeimage ]; + nativeBuildInputs = [ + cmake + pkg-config + unzip + ]; + buildInputs = [ + libXpm + fltk13 + freeimage + ]; unpackPhase = '' unzip $src -d posterazor diff --git a/pkgs/by-name/po/postgres-lsp/package.nix b/pkgs/by-name/po/postgres-lsp/package.nix index b267442cae830c..b2927a6600cf8a 100644 --- a/pkgs/by-name/po/postgres-lsp/package.nix +++ b/pkgs/by-name/po/postgres-lsp/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, protobuf +{ + lib, + rustPlatform, + fetchFromGitHub, + protobuf, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/po/postgresqlTestHook/test.nix b/pkgs/by-name/po/postgresqlTestHook/test.nix index 9881ed1016cc16..44650bc60ecadc 100644 --- a/pkgs/by-name/po/postgresqlTestHook/test.nix +++ b/pkgs/by-name/po/postgresqlTestHook/test.nix @@ -1,4 +1,8 @@ -{ postgresql, postgresqlTestHook, stdenv }: +{ + postgresql, + postgresqlTestHook, + stdenv, +}: stdenv.mkDerivation { name = "postgresql-test-hook-test"; @@ -6,7 +10,7 @@ stdenv.mkDerivation { nativeCheckInputs = [ postgresql ]; dontUnpack = true; doCheck = true; - passAsFile = ["sql"]; + passAsFile = [ "sql" ]; sql = '' CREATE TABLE hello ( message text diff --git a/pkgs/by-name/po/postgresql_jdbc/package.nix b/pkgs/by-name/po/postgresql_jdbc/package.nix index f1e93e352eb83a..7b3846cb18dfe2 100644 --- a/pkgs/by-name/po/postgresql_jdbc/package.nix +++ b/pkgs/by-name/po/postgresql_jdbc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchMavenArtifact }: +{ + lib, + stdenv, + fetchMavenArtifact, +}: stdenv.mkDerivation rec { pname = "postgresql-jdbc"; diff --git a/pkgs/by-name/po/postgrey/package.nix b/pkgs/by-name/po/postgrey/package.nix index dc872f968bd7f5..9710debf5b78e6 100644 --- a/pkgs/by-name/po/postgrey/package.nix +++ b/pkgs/by-name/po/postgrey/package.nix @@ -1,27 +1,47 @@ -{ fetchurl, perlPackages, lib, runCommand, postfix }: +{ + fetchurl, + perlPackages, + lib, + runCommand, + postfix, +}: let - mk-perl-flags = inputs: lib.concatStringsSep " " (map (dep: "-I ${dep}/${perlPackages.perl.libPrefix}") inputs); - postgrey-flags = mk-perl-flags (with perlPackages; [ - NetServer BerkeleyDB DigestSHA1 NetAddrIP IOMultiplex - ]); - policy-test-flags = mk-perl-flags (with perlPackages; [ + mk-perl-flags = + inputs: lib.concatStringsSep " " (map (dep: "-I ${dep}/${perlPackages.perl.libPrefix}") inputs); + postgrey-flags = mk-perl-flags ( + with perlPackages; + [ + NetServer + BerkeleyDB + DigestSHA1 + NetAddrIP + IOMultiplex + ] + ); + policy-test-flags = mk-perl-flags ( + with perlPackages; + [ ParseSyslog - ]); - version = "1.37"; - name = "postgrey-${version}"; -in runCommand name { - src = fetchurl { - url = "https://postgrey.schweikert.ch/pub/${name}.tar.gz"; - sha256 = "1xx51xih4711vrvc6d57il9ccallbljj5zhgqdb07jzmz11rakgz"; - }; - meta = with lib; { - description = "Postfix policy server to provide greylisting"; - homepage = "https://postgrey.schweikert.ch/"; - platforms = postfix.meta.platforms; - license = licenses.gpl2Plus; - }; -} '' + ] + ); + version = "1.37"; + name = "postgrey-${version}"; +in +runCommand name + { + src = fetchurl { + url = "https://postgrey.schweikert.ch/pub/${name}.tar.gz"; + sha256 = "1xx51xih4711vrvc6d57il9ccallbljj5zhgqdb07jzmz11rakgz"; + }; + meta = with lib; { + description = "Postfix policy server to provide greylisting"; + homepage = "https://postgrey.schweikert.ch/"; + platforms = postfix.meta.platforms; + license = licenses.gpl2Plus; + }; + } + '' mkdir -p $out/bin cd $out tar -xzf $src --strip-components=1 @@ -31,4 +51,4 @@ in runCommand name { bin/postgrey sed -i -e "s,#!/usr/bin/perl,#!${perlPackages.perl}/bin/perl ${policy-test-flags}," \ bin/policy-test -'' + '' diff --git a/pkgs/by-name/po/postiats-utilities/package.nix b/pkgs/by-name/po/postiats-utilities/package.nix index 6ac021e1ba0924..8e00897e79cd93 100644 --- a/pkgs/by-name/po/postiats-utilities/package.nix +++ b/pkgs/by-name/po/postiats-utilities/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, python3, python3Packages }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + python3Packages, +}: stdenv.mkDerivation rec { pname = "postiats-utilities"; @@ -17,7 +23,10 @@ stdenv.mkDerivation rec { maintainers = [ maintainers.ttuegel ]; }; - buildInputs = [ python3 python3Packages.wrapPython ]; + buildInputs = [ + python3 + python3Packages.wrapPython + ]; postPatch = '' for f in pats-* postiats/*.py; do diff --git a/pkgs/by-name/po/postlight-parser/package.nix b/pkgs/by-name/po/postlight-parser/package.nix index bf72c9a19c3eda..2a7f2418fcd1d3 100644 --- a/pkgs/by-name/po/postlight-parser/package.nix +++ b/pkgs/by-name/po/postlight-parser/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, yarnConfigHook -, yarnBuildHook -, yarnInstallHook -, nodejs +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + yarnConfigHook, + yarnBuildHook, + yarnInstallHook, + nodejs, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/po/postman/darwin.nix b/pkgs/by-name/po/postman/darwin.nix index 79458298dcc1d7..1e648396eba1cd 100644 --- a/pkgs/by-name/po/postman/darwin.nix +++ b/pkgs/by-name/po/postman/darwin.nix @@ -1,24 +1,28 @@ -{ stdenvNoCC -, fetchurl -, unzip -, pname -, version -, meta +{ + stdenvNoCC, + fetchurl, + unzip, + pname, + version, + meta, }: let appName = "Postman.app"; - dist = { - aarch64-darwin = { - arch = "arm64"; - sha256 = "sha256-V+JLXl12DnwZlPF0qNs2lQqRpWbSDiPXDTtl4FGcZcM="; - }; - - x86_64-darwin = { - arch = "64"; - sha256 = "sha256-l7J4Rrq+kUyk+0Chq5qo50K1VXC/7E3FC/hQ1DQ0PGA="; - }; - }.${stdenvNoCC.hostPlatform.system} or (throw "Unsupported system: ${stdenvNoCC.hostPlatform.system}"); + dist = + { + aarch64-darwin = { + arch = "arm64"; + sha256 = "sha256-V+JLXl12DnwZlPF0qNs2lQqRpWbSDiPXDTtl4FGcZcM="; + }; + + x86_64-darwin = { + arch = "64"; + sha256 = "sha256-l7J4Rrq+kUyk+0Chq5qo50K1VXC/7E3FC/hQ1DQ0PGA="; + }; + } + .${stdenvNoCC.hostPlatform.system} + or (throw "Unsupported system: ${stdenvNoCC.hostPlatform.system}"); in diff --git a/pkgs/by-name/po/postman/linux.nix b/pkgs/by-name/po/postman/linux.nix index fe15275bfb7d58..c5fdabc1592cba 100644 --- a/pkgs/by-name/po/postman/linux.nix +++ b/pkgs/by-name/po/postman/linux.nix @@ -1,67 +1,70 @@ -{ lib -, stdenv -, fetchurl -, makeDesktopItem -, wrapGAppsHook3 -, atk -, at-spi2-atk -, at-spi2-core -, alsa-lib -, cairo -, cups -, dbus -, expat -, gdk-pixbuf -, glib -, gtk3 -, freetype -, fontconfig -, nss -, nspr -, pango -, udev -, libsecret -, libuuid -, libX11 -, libxcb -, libXi -, libXcursor -, libXdamage -, libXrandr -, libXcomposite -, libXext -, libXfixes -, libXrender -, libXtst -, libXScrnSaver -, libxkbcommon -, libdrm -, mesa -# It's unknown which version of openssl that postman expects but it seems that -# OpenSSL 3+ seems to work fine (cf. -# https://github.com/NixOS/nixpkgs/issues/254325). If postman breaks apparently -# around OpenSSL stuff then try changing this dependency version. -, openssl -, xorg -, pname -, version -, meta -, copyDesktopItems -, makeWrapper +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + wrapGAppsHook3, + atk, + at-spi2-atk, + at-spi2-core, + alsa-lib, + cairo, + cups, + dbus, + expat, + gdk-pixbuf, + glib, + gtk3, + freetype, + fontconfig, + nss, + nspr, + pango, + udev, + libsecret, + libuuid, + libX11, + libxcb, + libXi, + libXcursor, + libXdamage, + libXrandr, + libXcomposite, + libXext, + libXfixes, + libXrender, + libXtst, + libXScrnSaver, + libxkbcommon, + libdrm, + mesa, + # It's unknown which version of openssl that postman expects but it seems that + # OpenSSL 3+ seems to work fine (cf. + # https://github.com/NixOS/nixpkgs/issues/254325). If postman breaks apparently + # around OpenSSL stuff then try changing this dependency version. + openssl, + xorg, + pname, + version, + meta, + copyDesktopItems, + makeWrapper, }: let - dist = { - aarch64-linux = { - arch = "arm64"; - sha256 = "sha256-yq2J5KRv/NJDaQG7e7RKyzbJqKWRolSU9X6khHxlrNo="; - }; + dist = + { + aarch64-linux = { + arch = "arm64"; + sha256 = "sha256-yq2J5KRv/NJDaQG7e7RKyzbJqKWRolSU9X6khHxlrNo="; + }; - x86_64-linux = { - arch = "64"; - sha256 = "sha256-fAaxrLZSXGBYr4Vu0Cz2pZwXivSTkaIF5wL217cB9qM="; - }; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + x86_64-linux = { + arch = "64"; + sha256 = "sha256-fAaxrLZSXGBYr4Vu0Cz2pZwXivSTkaIF5wL217cB9qM="; + }; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); in stdenv.mkDerivation rec { @@ -76,7 +79,7 @@ stdenv.mkDerivation rec { dontConfigure = true; desktopItems = [ - (makeDesktopItem { + (makeDesktopItem { name = "postman"; exec = "postman %U"; icon = "postman"; @@ -126,7 +129,10 @@ stdenv.mkDerivation rec { xorg.libxshmfence ]; - nativeBuildInputs = [ wrapGAppsHook3 copyDesktopItems ]; + nativeBuildInputs = [ + wrapGAppsHook3 + copyDesktopItems + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/po/postman/package.nix b/pkgs/by-name/po/postman/package.nix index ae2ea6f86230db..ae8c27f750b133 100644 --- a/pkgs/by-name/po/postman/package.nix +++ b/pkgs/by-name/po/postman/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, callPackage, lib }: +{ + stdenvNoCC, + callPackage, + lib, +}: let pname = "postman"; @@ -8,12 +12,23 @@ let description = "API Development Environment"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.postman; - platforms = [ "x86_64-linux" "aarch64-linux" "aarch64-darwin" "x86_64-darwin" ]; - maintainers = with maintainers; [ johnrichardrinehart evanjs tricktron Crafter ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "aarch64-darwin" + "x86_64-darwin" + ]; + maintainers = with maintainers; [ + johnrichardrinehart + evanjs + tricktron + Crafter + ]; }; in -if stdenvNoCC.hostPlatform.isDarwin -then callPackage ./darwin.nix { inherit pname version meta; } -else callPackage ./linux.nix { inherit pname version meta; } +if stdenvNoCC.hostPlatform.isDarwin then + callPackage ./darwin.nix { inherit pname version meta; } +else + callPackage ./linux.nix { inherit pname version meta; } diff --git a/pkgs/by-name/po/postscript-lexmark/package.nix b/pkgs/by-name/po/postscript-lexmark/package.nix index d9544e4b330d32..5bb559f49d5b9e 100644 --- a/pkgs/by-name/po/postscript-lexmark/package.nix +++ b/pkgs/by-name/po/postscript-lexmark/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, rpmextract }: +{ + lib, + stdenv, + fetchurl, + rpmextract, +}: let version = "20160218"; in diff --git a/pkgs/by-name/po/postsrsd/package.nix b/pkgs/by-name/po/postsrsd/package.nix index 65e6b83a693ff6..f100d56d94cffc 100644 --- a/pkgs/by-name/po/postsrsd/package.nix +++ b/pkgs/by-name/po/postsrsd/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, help2man }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + help2man, +}: stdenv.mkDerivation rec { pname = "postsrsd"; @@ -11,13 +17,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-aSI9TR1wSyMA0SKkbavk+IugRfW4ZEgpzrNiXn0F5ak="; }; - cmakeFlags = [ "-DGENERATE_SRS_SECRET=OFF" "-DINIT_FLAVOR=systemd" ]; + cmakeFlags = [ + "-DGENERATE_SRS_SECRET=OFF" + "-DINIT_FLAVOR=systemd" + ]; preConfigure = '' sed -i "s,\"/etc\",\"$out/etc\",g" CMakeLists.txt ''; - nativeBuildInputs = [ cmake help2man ]; + nativeBuildInputs = [ + cmake + help2man + ]; meta = with lib; { homepage = "https://github.com/roehling/postsrsd"; diff --git a/pkgs/by-name/po/posy-cursors/package.nix b/pkgs/by-name/po/posy-cursors/package.nix index 1b607569198a40..18a1e39b485e45 100644 --- a/pkgs/by-name/po/posy-cursors/package.nix +++ b/pkgs/by-name/po/posy-cursors/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "posy-cursors"; diff --git a/pkgs/by-name/po/potrace/package.nix b/pkgs/by-name/po/potrace/package.nix index 5a7093396283a4..aeaa1c93d540c7 100644 --- a/pkgs/by-name/po/potrace/package.nix +++ b/pkgs/by-name/po/potrace/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, zlib }: +{ + lib, + stdenv, + fetchurl, + zlib, +}: stdenv.mkDerivation rec { pname = "potrace"; diff --git a/pkgs/by-name/po/potreeconverter/package.nix b/pkgs/by-name/po/potreeconverter/package.nix index ae7acec3522f47..ce7a6452380c1f 100644 --- a/pkgs/by-name/po/potreeconverter/package.nix +++ b/pkgs/by-name/po/potreeconverter/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, boost -, tbb -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + tbb, + makeWrapper, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/po/pouf/package.nix b/pkgs/by-name/po/pouf/package.nix index 0754ca0c09f1ac..3aea1c0749a81d 100644 --- a/pkgs/by-name/po/pouf/package.nix +++ b/pkgs/by-name/po/pouf/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/po/pounce/package.nix b/pkgs/by-name/po/pounce/package.nix index 7ad43825b15160..84fac59714c638 100644 --- a/pkgs/by-name/po/pounce/package.nix +++ b/pkgs/by-name/po/pounce/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, libressl, fetchzip, pkg-config, libxcrypt }: +{ + lib, + stdenv, + libressl, + fetchzip, + pkg-config, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "pounce"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-6PGiaU5sOwqO4V2PKJgIi3kI2jXsBOldEH51D7Sx9tg="; }; - buildInputs = [ libressl libxcrypt ]; + buildInputs = [ + libressl + libxcrypt + ]; nativeBuildInputs = [ pkg-config ]; diff --git a/pkgs/by-name/po/power-calibrate/package.nix b/pkgs/by-name/po/power-calibrate/package.nix index d7dfa684211c3d..5162b39f3f9923 100644 --- a/pkgs/by-name/po/power-calibrate/package.nix +++ b/pkgs/by-name/po/power-calibrate/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "power-calibrate"; diff --git a/pkgs/by-name/po/poweralertd/package.nix b/pkgs/by-name/po/poweralertd/package.nix index c61f5af1b41d10..4225bd7d74f6d8 100644 --- a/pkgs/by-name/po/poweralertd/package.nix +++ b/pkgs/by-name/po/poweralertd/package.nix @@ -1,10 +1,22 @@ -{ lib, stdenv, fetchFromSourcehut, meson, ninja, pkg-config, scdoc, systemd }: +{ + lib, + stdenv, + fetchFromSourcehut, + meson, + ninja, + pkg-config, + scdoc, + systemd, +}: stdenv.mkDerivation rec { pname = "poweralertd"; version = "0.3.0"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchFromSourcehut { owner = "~kennylevinsen"; diff --git a/pkgs/by-name/po/powercap/package.nix b/pkgs/by-name/po/powercap/package.nix index e705b6a3485717..e38ea1713f392f 100644 --- a/pkgs/by-name/po/powercap/package.nix +++ b/pkgs/by-name/po/powercap/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, +}: stdenv.mkDerivation rec { pname = "powercap"; diff --git a/pkgs/by-name/po/powerdns-admin/package.nix b/pkgs/by-name/po/powerdns-admin/package.nix index 2ee95b13dcbd31..31f7c15777f472 100644 --- a/pkgs/by-name/po/powerdns-admin/package.nix +++ b/pkgs/by-name/po/powerdns-admin/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchYarnDeps, yarnConfigHook, nixosTests, writeText, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + yarnConfigHook, + nixosTests, + writeText, + python3, +}: let pname = "powerdns-admin"; @@ -14,11 +23,49 @@ let pythonDeps = with python.pkgs; [ distutils - flask flask-assets flask-login flask-sqlalchemy flask-migrate flask-seasurf flask-mail flask-session flask-session-captcha flask-sslify - mysqlclient psycopg2 sqlalchemy - certifi cffi configobj cryptography bcrypt requests python-ldap pyotp qrcode dnspython - gunicorn itsdangerous python3-saml pytz rcssmin rjsmin authlib bravado-core - lima lxml passlib pyasn1 pytimeparse pyyaml jinja2 itsdangerous webcolors werkzeug zipp zxcvbn + flask + flask-assets + flask-login + flask-sqlalchemy + flask-migrate + flask-seasurf + flask-mail + flask-session + flask-session-captcha + flask-sslify + mysqlclient + psycopg2 + sqlalchemy + certifi + cffi + configobj + cryptography + bcrypt + requests + python-ldap + pyotp + qrcode + dnspython + gunicorn + itsdangerous + python3-saml + pytz + rcssmin + rjsmin + authlib + bravado-core + lima + lxml + passlib + pyasn1 + pytimeparse + pyyaml + jinja2 + itsdangerous + webcolors + werkzeug + zipp + zxcvbn ]; all_patches = [ @@ -62,7 +109,8 @@ let assets.register('js_main', 'generated/main.js') assets.register('css_main', 'generated/main.css') ''; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname version src; nativeBuildInputs = [ python.pkgs.wrapPython ]; @@ -121,6 +169,9 @@ in stdenv.mkDerivation { mainProgram = "powerdns-admin"; homepage = "https://github.com/PowerDNS-Admin/PowerDNS-Admin"; license = licenses.mit; - maintainers = with maintainers; [ Flakebi zhaofengli ]; + maintainers = with maintainers; [ + Flakebi + zhaofengli + ]; }; } diff --git a/pkgs/by-name/po/powerhub/package.nix b/pkgs/by-name/po/powerhub/package.nix index 2200985699660c..62305f6fa07a4c 100644 --- a/pkgs/by-name/po/powerhub/package.nix +++ b/pkgs/by-name/po/powerhub/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/po/powerline-fonts/package.nix b/pkgs/by-name/po/powerline-fonts/package.nix index ea2da0fe2ecff1..a9f0dc164ac09d 100644 --- a/pkgs/by-name/po/powerline-fonts/package.nix +++ b/pkgs/by-name/po/powerline-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "powerline-fonts"; @@ -29,7 +33,11 @@ stdenvNoCC.mkDerivation { longDescription = '' Pre-patched and adjusted fonts for usage with the Powerline plugin. ''; - license = with licenses; [ asl20 free ofl ]; + license = with licenses; [ + asl20 + free + ofl + ]; platforms = platforms.all; maintainers = with maintainers; [ malyn ]; }; diff --git a/pkgs/by-name/po/powerline-go/package.nix b/pkgs/by-name/po/powerline-go/package.nix index 791eb851fae15d..852a49f4981eb7 100644 --- a/pkgs/by-name/po/powerline-go/package.nix +++ b/pkgs/by-name/po/powerline-go/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/po/powerline-symbols/package.nix b/pkgs/by-name/po/powerline-symbols/package.nix index 39bdc4d373454e..8c23ea08da8317 100644 --- a/pkgs/by-name/po/powerline-symbols/package.nix +++ b/pkgs/by-name/po/powerline-symbols/package.nix @@ -1,18 +1,25 @@ -{ lib, runCommand, powerline }: +{ + lib, + runCommand, + powerline, +}: let inherit (powerline) version; -in runCommand "powerline-symbols-${version}" { - meta = { - inherit (powerline.meta) license; - priority = (powerline.meta.priority or lib.meta.defaultPriority) + 1; - maintainers = with lib.maintainers; [ midchildan ]; - }; -} '' - install -Dm644 \ - ${powerline.src}/font/PowerlineSymbols.otf \ - $out/share/fonts/OTF/PowerlineSymbols.otf - install -Dm644 \ - ${powerline.src}/font/10-powerline-symbols.conf \ - $out/etc/fonts/conf.d/10-powerline-symbols.conf -'' +in +runCommand "powerline-symbols-${version}" + { + meta = { + inherit (powerline.meta) license; + priority = (powerline.meta.priority or lib.meta.defaultPriority) + 1; + maintainers = with lib.maintainers; [ midchildan ]; + }; + } + '' + install -Dm644 \ + ${powerline.src}/font/PowerlineSymbols.otf \ + $out/share/fonts/OTF/PowerlineSymbols.otf + install -Dm644 \ + ${powerline.src}/font/10-powerline-symbols.conf \ + $out/etc/fonts/conf.d/10-powerline-symbols.conf + '' diff --git a/pkgs/by-name/po/powermanga/package.nix b/pkgs/by-name/po/powermanga/package.nix index eaa45460be9227..cc050d4a3b2e0d 100644 --- a/pkgs/by-name/po/powermanga/package.nix +++ b/pkgs/by-name/po/powermanga/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, autoconf -, automake -, SDL -, SDL_mixer -, libpng +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + SDL, + SDL_mixer, + libpng, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/po/powershell/package.nix b/pkgs/by-name/po/powershell/package.nix index d9b74cf564dc10..a5c63c6a4a86ef 100644 --- a/pkgs/by-name/po/powershell/package.nix +++ b/pkgs/by-name/po/powershell/package.nix @@ -1,81 +1,93 @@ -{ lib -, stdenv -, fetchurl -, less -, makeWrapper -, autoPatchelfHook -, curl -, icu -, libuuid -, libunwind -, openssl -, darwin -, lttng-ust -, pam -, testers -, powershell -, writeShellScript -, common-updater-scripts -, gnused -, jq +{ + lib, + stdenv, + fetchurl, + less, + makeWrapper, + autoPatchelfHook, + curl, + icu, + libuuid, + libunwind, + openssl, + darwin, + lttng-ust, + pam, + testers, + powershell, + writeShellScript, + common-updater-scripts, + gnused, + jq, }: let ext = stdenv.hostPlatform.extensions.sharedLibrary; - platformLdLibraryPath = { - darwin = "DYLD_FALLBACK_LIBRARY_PATH"; - linux = "LD_LIBRARY_PATH"; - }.${stdenv.hostPlatform.parsed.kernel.name} or (throw "unsupported platform"); + platformLdLibraryPath = + { + darwin = "DYLD_FALLBACK_LIBRARY_PATH"; + linux = "LD_LIBRARY_PATH"; + } + .${stdenv.hostPlatform.parsed.kernel.name} or (throw "unsupported platform"); in stdenv.mkDerivation rec { pname = "powershell"; version = "7.4.6"; - src = passthru.sources.${stdenv.hostPlatform.system} - or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + passthru.sources.${stdenv.hostPlatform.system} + or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); sourceRoot = "."; strictDeps = true; - nativeBuildInputs = [ - less - makeWrapper - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - autoPatchelfHook - ]; + nativeBuildInputs = + [ + less + makeWrapper + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + autoPatchelfHook + ]; - buildInputs = [ - curl - icu - libuuid - libunwind - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.Libsystem - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - lttng-ust - pam - ]; + buildInputs = + [ + curl + icu + libuuid + libunwind + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.Libsystem + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + lttng-ust + pam + ]; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - mkdir -p $out/{bin,share/powershell} - cp -R * $out/share/powershell - chmod +x $out/share/powershell/pwsh - makeWrapper $out/share/powershell/pwsh $out/bin/pwsh \ - --prefix ${platformLdLibraryPath} : "${lib.makeLibraryPath buildInputs}" \ - --set TERM xterm \ - --set POWERSHELL_TELEMETRY_OPTOUT 1 \ - --set DOTNET_CLI_TELEMETRY_OPTOUT 1 + mkdir -p $out/{bin,share/powershell} + cp -R * $out/share/powershell + chmod +x $out/share/powershell/pwsh + makeWrapper $out/share/powershell/pwsh $out/bin/pwsh \ + --prefix ${platformLdLibraryPath} : "${lib.makeLibraryPath buildInputs}" \ + --set TERM xterm \ + --set POWERSHELL_TELEMETRY_OPTOUT 1 \ + --set DOTNET_CLI_TELEMETRY_OPTOUT 1 - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - patchelf --replace-needed liblttng-ust${ext}.0 liblttng-ust${ext}.1 $out/share/powershell/libcoreclrtraceptprovider.so + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + patchelf --replace-needed liblttng-ust${ext}.0 liblttng-ust${ext}.1 $out/share/powershell/libcoreclrtraceptprovider.so - '' + '' - runHook postInstall - ''; + '' + + '' + runHook postInstall + ''; dontStrip = true; @@ -105,7 +117,14 @@ stdenv.mkDerivation rec { }; updateScript = writeShellScript "update-powershell" '' set -o errexit - export PATH="${lib.makeBinPath [ common-updater-scripts curl gnused jq ]}" + export PATH="${ + lib.makeBinPath [ + common-updater-scripts + curl + gnused + jq + ] + }" NEW_VERSION=$(curl -s https://api.github.com/repos/PowerShell/PowerShell/releases/latest | jq .tag_name --raw-output | sed -e 's/v//') if [[ "${version}" = "$NEW_VERSION" ]]; then diff --git a/pkgs/by-name/po/powersploit/package.nix b/pkgs/by-name/po/powersploit/package.nix index 5a63dcf9f003ff..1f2600a7493d73 100644 --- a/pkgs/by-name/po/powersploit/package.nix +++ b/pkgs/by-name/po/powersploit/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, stdenvNoCC +{ + lib, + fetchFromGitHub, + stdenvNoCC, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/po/powerstat/package.nix b/pkgs/by-name/po/powerstat/package.nix index b7a88a0d9ec9d3..1a4838d5bb487f 100644 --- a/pkgs/by-name/po/powerstat/package.nix +++ b/pkgs/by-name/po/powerstat/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "powerstat"; diff --git a/pkgs/by-name/po/powersupply/package.nix b/pkgs/by-name/po/powersupply/package.nix index 31216d84675a3e..d20287e3e41b60 100644 --- a/pkgs/by-name/po/powersupply/package.nix +++ b/pkgs/by-name/po/powersupply/package.nix @@ -1,14 +1,15 @@ -{ lib -, python3 -, fetchFromGitLab -, desktop-file-utils -, gobject-introspection -, gtk3 -, libhandy -, meson -, ninja -, pkg-config -, wrapGAppsHook3 +{ + lib, + python3, + fetchFromGitLab, + desktop-file-utils, + gobject-introspection, + gtk3, + libhandy, + meson, + ninja, + pkg-config, + wrapGAppsHook3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pp/ppl/package.nix b/pkgs/by-name/pp/ppl/package.nix index 37e5f78c602785..b36ae47ecbf1f3 100644 --- a/pkgs/by-name/pp/ppl/package.nix +++ b/pkgs/by-name/pp/ppl/package.nix @@ -1,6 +1,16 @@ -{ fetchurl, fetchpatch, lib, stdenv, gmpxx, perl, gnum4 }: +{ + fetchurl, + fetchpatch, + lib, + stdenv, + gmpxx, + perl, + gnum4, +}: -let version = "1.2"; in +let + version = "1.2"; +in stdenv.mkDerivation { pname = "ppl"; @@ -11,11 +21,13 @@ stdenv.mkDerivation { sha256 = "1wgxcbgmijgk11df43aiqfzv31r3bkxmgb4yl68g21194q60nird"; }; - patches = [(fetchpatch { - name = "clang5-support.patch"; - url = "https://raw.githubusercontent.com/sagemath/sage/9.2/build/pkgs/ppl/patches/clang5-support.patch"; - sha256 = "1zj90hm25pkgvk4jlkfzh18ak9b98217gbidl3731fdccbw6hr87"; - })]; + patches = [ + (fetchpatch { + name = "clang5-support.patch"; + url = "https://raw.githubusercontent.com/sagemath/sage/9.2/build/pkgs/ppl/patches/clang5-support.patch"; + sha256 = "1zj90hm25pkgvk4jlkfzh18ak9b98217gbidl3731fdccbw6hr87"; + }) + ]; postPatch = lib.optionalString stdenv.cc.isClang '' substituteInPlace src/PIP_Tree.cc \ @@ -24,13 +36,19 @@ stdenv.mkDerivation { --replace "std::mem_fun_ref" "std::mem_fn" ''; - nativeBuildInputs = [ perl gnum4 ]; + nativeBuildInputs = [ + perl + gnum4 + ]; propagatedBuildInputs = [ gmpxx ]; - configureFlags = [ "--disable-watchdog" ] ++ - lib.optionals stdenv.hostPlatform.isDarwin [ + configureFlags = + [ "--disable-watchdog" ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ "CPPFLAGS=-fexceptions" - "--disable-ppl_lcdd" "--disable-ppl_lpsol" "--disable-ppl_pips" + "--disable-ppl_lcdd" + "--disable-ppl_lpsol" + "--disable-ppl_pips" ]; # Beware! It took ~6 hours to compile PPL and run its tests on a 1.2 GHz diff --git a/pkgs/by-name/pp/pplatex/package.nix b/pkgs/by-name/pp/pplatex/package.nix index 7bd1e4d0eb1ea4..f7f0a04f2181f8 100644 --- a/pkgs/by-name/pp/pplatex/package.nix +++ b/pkgs/by-name/pp/pplatex/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, pcre +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + pcre, }: stdenv.mkDerivation (finalAttrs: { @@ -33,8 +34,7 @@ stdenv.mkDerivation (finalAttrs: { ''; meta = with lib; { - description = - "A tool to reformat the output of latex and friends into readable messages"; + description = "A tool to reformat the output of latex and friends into readable messages"; mainProgram = "pplatex"; homepage = "https://github.com/stefanhepp/pplatex"; license = licenses.gpl3Plus; diff --git a/pkgs/by-name/pp/pplite/package.nix b/pkgs/by-name/pp/pplite/package.nix index ba5c4514105d49..520bbbb057eda6 100644 --- a/pkgs/by-name/pp/pplite/package.nix +++ b/pkgs/by-name/pp/pplite/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, flint, gmp }: +{ + stdenv, + lib, + fetchurl, + flint, + gmp, +}: stdenv.mkDerivation { pname = "pplite"; @@ -9,7 +15,10 @@ stdenv.mkDerivation { hash = "sha256-9qulVEIZRPHV5GnVmp65nMrGrUwRGkR8i8ORbLdHb1E="; }; - buildInputs = [ flint gmp ]; + buildInputs = [ + flint + gmp + ]; meta = { homepage = "https://github.com/ezaffanella/PPLite"; diff --git a/pkgs/by-name/pp/pprof/package.nix b/pkgs/by-name/pp/pprof/package.nix index 11dbc8595f1838..4f279abc9be6a7 100644 --- a/pkgs/by-name/pp/pprof/package.nix +++ b/pkgs/by-name/pp/pprof/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/pp/pps-tools/package.nix b/pkgs/by-name/pp/pps-tools/package.nix index 66754e5148ec6c..069e5fcf008b68 100644 --- a/pkgs/by-name/pp/pps-tools/package.nix +++ b/pkgs/by-name/pp/pps-tools/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "pps-tools"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-eLLFHrCgOQzOtVxlAsZ5X91KK+vZiKMGL7zbQFiIZtI="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/pp/ppsspp/package.nix b/pkgs/by-name/pp/ppsspp/package.nix index afa9e0edbd4988..d5272ce0bdd162 100644 --- a/pkgs/by-name/pp/ppsspp/package.nix +++ b/pkgs/by-name/pp/ppsspp/package.nix @@ -22,8 +22,8 @@ enableQt ? false, enableVulkan ? true, forceWayland ? false, - useSystemFfmpeg? false, - useSystemSnappy? true, + useSystemFfmpeg ? false, + useSystemSnappy ? true, }: let @@ -34,10 +34,11 @@ in # Only SDL frontend needs to specify whether to use Wayland assert forceWayland -> !enableQt; stdenv.mkDerivation (finalAttrs: { - pname = "ppsspp" - + lib.optionalString enableQt "-qt" - + lib.optionalString (!enableQt) "-sdl" - + lib.optionalString forceWayland "-wayland"; + pname = + "ppsspp" + + lib.optionalString enableQt "-qt" + + lib.optionalString (!enableQt) "-sdl" + + lib.optionalString forceWayland "-wayland"; version = "1.18.1"; src = fetchFromGitHub { @@ -63,27 +64,30 @@ stdenv.mkDerivation (finalAttrs: { makeWrapper pkg-config python3 - ] - ++ lib.optionals enableQt [ wrapQtAppsHook ]; + ] ++ lib.optionals enableQt [ wrapQtAppsHook ]; - buildInputs = [ - SDL2 - glew - libzip - zlib - ] - ++ lib.optionals useSystemFfmpeg [ - ffmpeg_6 - ] - ++ lib.optionals useSystemSnappy [ - snappy - ] - ++ lib.optionals enableQt [ - qtbase - qtmultimedia - ] - ++ lib.optionals enableVulkan [ vulkan-loader ] - ++ lib.optionals vulkanWayland [ wayland libffi ]; + buildInputs = + [ + SDL2 + glew + libzip + zlib + ] + ++ lib.optionals useSystemFfmpeg [ + ffmpeg_6 + ] + ++ lib.optionals useSystemSnappy [ + snappy + ] + ++ lib.optionals enableQt [ + qtbase + qtmultimedia + ] + ++ lib.optionals enableVulkan [ vulkan-loader ] + ++ lib.optionals vulkanWayland [ + wayland + libffi + ]; cmakeFlags = [ (lib.cmakeBool "HEADLESS" (!enableQt)) @@ -102,49 +106,61 @@ stdenv.mkDerivation (finalAttrs: { exec = "ppsspp"; icon = "ppsspp"; comment = "Play PSP games on your computer"; - categories = [ "Game" "Emulator" ]; + categories = [ + "Game" + "Emulator" + ]; }) ]; - installPhase = - lib.concatStringsSep "\n" ([ + installPhase = lib.concatStringsSep "\n" ( + [ ''runHook preInstall'' ] ++ [ ''mkdir -p $out/share/{applications,ppsspp/bin,icons}'' ] - ++ (if enableQt then [ - ''install -Dm555 PPSSPPQt $out/share/ppsspp/bin/'' - ] else [ - ''install -Dm555 PPSSPPHeadless $out/share/ppsspp/bin/'' - ''makeWrapper $out/share/ppsspp/bin/PPSSPPHeadless $out/bin/ppsspp-headless'' - ''install -Dm555 PPSSPPSDL $out/share/ppsspp/bin/'' - ]) + ++ ( + if enableQt then + [ + ''install -Dm555 PPSSPPQt $out/share/ppsspp/bin/'' + ] + else + [ + ''install -Dm555 PPSSPPHeadless $out/share/ppsspp/bin/'' + ''makeWrapper $out/share/ppsspp/bin/PPSSPPHeadless $out/bin/ppsspp-headless'' + ''install -Dm555 PPSSPPSDL $out/share/ppsspp/bin/'' + ] + ) ++ [ ''mv assets $out/share/ppsspp'' ''mv ../icons/hicolor $out/share/icons'' ] ++ [ ''runHook postInstall'' - ]); + ] + ); postFixup = let - wrapperArgs = - lib.concatStringsSep " " - (lib.optionals enableVulkan [ - "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ vulkan-loader ]}" - ] ++ lib.optionals (!enableQt) [ - "--set SDL_VIDEODRIVER ${if forceWayland then "wayland" else "x11"}" - ]); + wrapperArgs = lib.concatStringsSep " " ( + lib.optionals enableVulkan [ + "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ vulkan-loader ]}" + ] + ++ lib.optionals (!enableQt) [ + "--set SDL_VIDEODRIVER ${if forceWayland then "wayland" else "x11"}" + ] + ); binToBeWrapped = if enableQt then "PPSSPPQt" else "PPSSPPSDL"; in - ''makeWrapper $out/share/ppsspp/bin/${binToBeWrapped} $out/bin/ppsspp ${wrapperArgs}''; + ''makeWrapper $out/share/ppsspp/bin/${binToBeWrapped} $out/bin/ppsspp ${wrapperArgs}''; meta = { homepage = "https://www.ppsspp.org/"; - description = "HLE Playstation Portable emulator, written in C++ (" - + (if enableQt then "Qt" else "SDL + headless") + ")"; + description = + "HLE Playstation Portable emulator, written in C++ (" + + (if enableQt then "Qt" else "SDL + headless") + + ")"; longDescription = '' PPSSPP is a PSP emulator, which means that it can run games and other software that was originally made for the Sony PSP. diff --git a/pkgs/by-name/pp/pptp/package.nix b/pkgs/by-name/pp/pptp/package.nix index 38734375be0ade..239884dd78d4dd 100644 --- a/pkgs/by-name/pp/pptp/package.nix +++ b/pkgs/by-name/pp/pptp/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, perl, ppp, iproute2 }: +{ + lib, + stdenv, + fetchurl, + perl, + ppp, + iproute2, +}: stdenv.mkDerivation rec { pname = "pptp"; diff --git a/pkgs/by-name/pp/pptpd/package.nix b/pkgs/by-name/pp/pptpd/package.nix index 37a92475c984af..75afbd812f058b 100644 --- a/pkgs/by-name/pp/pptpd/package.nix +++ b/pkgs/by-name/pp/pptpd/package.nix @@ -1,11 +1,16 @@ -{ lib, stdenv, fetchurl, ppp }: +{ + lib, + stdenv, + fetchurl, + ppp, +}: stdenv.mkDerivation rec { - pname = "pptpd"; + pname = "pptpd"; version = "1.4.0"; src = fetchurl { - url = "mirror://sourceforge/poptop/${pname}/${pname}-${version}/${pname}-${version}.tar.gz"; + url = "mirror://sourceforge/poptop/${pname}/${pname}-${version}/${pname}-${version}.tar.gz"; sha256 = "1h06gyxj51ba6kbbnf6hyivwjia0i6gsmjz8kyggaany8a58pkcg"; }; @@ -20,9 +25,9 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - homepage = "https://poptop.sourceforge.net/dox/"; + homepage = "https://poptop.sourceforge.net/dox/"; description = "PPTP Server for Linux"; - platforms = platforms.linux; + platforms = platforms.linux; maintainers = with maintainers; [ obadz ]; license = licenses.gpl2Only; }; diff --git a/pkgs/by-name/pq/pql/package.nix b/pkgs/by-name/pq/pql/package.nix index 9697d80ad25f7d..590364b3a9cf36 100644 --- a/pkgs/by-name/pq/pql/package.nix +++ b/pkgs/by-name/pq/pql/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-j/R+1PWfX+lmm99cHWSuo+v8RxKg089Bvb4rFHpmpfE="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Pipelined Query Language"; diff --git a/pkgs/by-name/pq/pqos-wrapper/package.nix b/pkgs/by-name/pq/pqos-wrapper/package.nix index d0235fedc3a716..d993ad6b1db031 100644 --- a/pkgs/by-name/pq/pqos-wrapper/package.nix +++ b/pkgs/by-name/pq/pqos-wrapper/package.nix @@ -1,7 +1,8 @@ -{ lib -, intel-cmt-cat -, fetchFromGitLab -, python3 +{ + lib, + intel-cmt-cat, + fetchFromGitLab, + python3, }: python3.pkgs.buildPythonApplication rec { pname = "pqos-wrapper"; diff --git a/pkgs/by-name/pq/pqrs/package.nix b/pkgs/by-name/pq/pqrs/package.nix index 1d406394ac122c..7f26f0e1c96b9e 100644 --- a/pkgs/by-name/pq/pqrs/package.nix +++ b/pkgs/by-name/pq/pqrs/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "pqrs"; @@ -17,7 +21,10 @@ rustPlatform.buildRustPackage rec { description = "CLI tool to inspect Parquet files"; mainProgram = "pqrs"; homepage = "https://github.com/manojkarthick/pqrs"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = [ maintainers.manojkarthick ]; }; } diff --git a/pkgs/by-name/pr/pr-tracker/package.nix b/pkgs/by-name/pr/pr-tracker/package.nix index 14c87204013d13..e146ca3ac1990f 100644 --- a/pkgs/by-name/pr/pr-tracker/package.nix +++ b/pkgs/by-name/pr/pr-tracker/package.nix @@ -1,9 +1,10 @@ -{ rustPlatform -, lib -, fetchzip -, openssl -, pkg-config -, systemd +{ + rustPlatform, + lib, + fetchzip, + openssl, + pkg-config, + systemd, }: rustPlatform.buildRustPackage rec { @@ -18,7 +19,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-t+jiOr5pjJNMpaOLYKlk194b2njT1XWKKlPQtKsUu3E="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl systemd ]; + buildInputs = [ + openssl + systemd + ]; meta = with lib; { changelog = "https://git.qyliss.net/pr-tracker/plain/NEWS?h=${version}"; @@ -30,7 +34,10 @@ rustPlatform.buildRustPackage rec { platforms = platforms.linux; homepage = "https://git.qyliss.net/pr-tracker"; license = licenses.agpl3Plus; - maintainers = with maintainers; [ qyliss sumnerevans ]; + maintainers = with maintainers; [ + qyliss + sumnerevans + ]; mainProgram = "pr-tracker"; }; } diff --git a/pkgs/by-name/pr/praat/package.nix b/pkgs/by-name/pr/praat/package.nix index 57c8e8f5707366..f893cfe8a6e956 100644 --- a/pkgs/by-name/pr/praat/package.nix +++ b/pkgs/by-name/pr/praat/package.nix @@ -1,12 +1,12 @@ { - alsa-lib -, fetchFromGitHub -, gtk3 -, lib -, libpulseaudio -, pkg-config -, stdenv -, wrapGAppsHook3 + alsa-lib, + fetchFromGitHub, + gtk3, + lib, + libpulseaudio, + pkg-config, + stdenv, + wrapGAppsHook3, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pr/prboom-plus/package.nix b/pkgs/by-name/pr/prboom-plus/package.nix index f4723eb82ec8fd..9367745fc611dd 100644 --- a/pkgs/by-name/pr/prboom-plus/package.nix +++ b/pkgs/by-name/pr/prboom-plus/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, SDL2 -, SDL2_mixer -, SDL2_image -, SDL2_net -, fluidsynth -, soundfont-fluid -, portmidi -, dumb -, libvorbis -, libmad -, pcre +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + SDL2, + SDL2_mixer, + SDL2_image, + SDL2_net, + fluidsynth, + soundfont-fluid, + portmidi, + dumb, + libvorbis, + libmad, + pcre, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pr/pre-commit-hook-ensure-sops/package.nix b/pkgs/by-name/pr/pre-commit-hook-ensure-sops/package.nix index 3b0fcacd4892e8..7d8570e74807f3 100644 --- a/pkgs/by-name/pr/pre-commit-hook-ensure-sops/package.nix +++ b/pkgs/by-name/pr/pre-commit-hook-ensure-sops/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3Packages -, fetchFromGitHub -, fetchpatch +{ + lib, + python3Packages, + fetchFromGitHub, + fetchpatch, }: python3Packages.buildPythonApplication rec { @@ -20,8 +21,7 @@ python3Packages.buildPythonApplication rec { # Add the command-line entrypoint to pyproject.toml # Can be removed after v1.2 release that includes changes (fetchpatch { - url = - "https://github.com/yuvipanda/pre-commit-hook-ensure-sops/commit/ed88126afa253df6009af7cbe5aa2369f963be1c.patch"; + url = "https://github.com/yuvipanda/pre-commit-hook-ensure-sops/commit/ed88126afa253df6009af7cbe5aa2369f963be1c.patch"; hash = "sha256-mMxAoC3WEciO799Rq8gZ2PJ6FT/GbeSpxlr1EPj7r4s="; }) ]; diff --git a/pkgs/by-name/pr/pre2k/package.nix b/pkgs/by-name/pr/pre2k/package.nix index 98b763cb011dfd..1cda899bd70bd5 100644 --- a/pkgs/by-name/pr/pre2k/package.nix +++ b/pkgs/by-name/pr/pre2k/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pr/precice-config-visualizer/package.nix b/pkgs/by-name/pr/precice-config-visualizer/package.nix index 743d107ee534af..af1a86b366cdc6 100644 --- a/pkgs/by-name/pr/precice-config-visualizer/package.nix +++ b/pkgs/by-name/pr/precice-config-visualizer/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { @@ -14,7 +15,10 @@ python3Packages.buildPythonApplication rec { hash = "sha256-2dnpkec9hN4oAqwu+1WmDJrfeu+JbfqZ6guv3bC4H1c="; }; - propagatedBuildInputs = with python3Packages; [ lxml pydot ]; + propagatedBuildInputs = with python3Packages; [ + lxml + pydot + ]; doCheck = false; diff --git a/pkgs/by-name/pr/precice/package.nix b/pkgs/by-name/pr/precice/package.nix index 56dd58781bdf3e..2f5572a2eab744 100644 --- a/pkgs/by-name/pr/precice/package.nix +++ b/pkgs/by-name/pr/precice/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, cmake, gcc, boost, eigen, libxml2, mpi, python3, petsc, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gcc, + boost, + eigen, + libxml2, + mpi, + python3, + petsc, + pkg-config, +}: stdenv.mkDerivation rec { pname = "precice"; @@ -24,8 +37,20 @@ stdenv.mkDerivation rec { ++ [ "-fpermissive" ] ); - nativeBuildInputs = [ cmake gcc pkg-config python3 python3.pkgs.numpy ]; - buildInputs = [ boost eigen libxml2 mpi petsc ]; + nativeBuildInputs = [ + cmake + gcc + pkg-config + python3 + python3.pkgs.numpy + ]; + buildInputs = [ + boost + eigen + libxml2 + mpi + petsc + ]; meta = { description = "preCICE stands for Precise Code Interaction Coupling Environment"; diff --git a/pkgs/by-name/pr/prelink/package.nix b/pkgs/by-name/pr/prelink/package.nix index d5c7428411908f..a8f29b17754187 100644 --- a/pkgs/by-name/pr/prelink/package.nix +++ b/pkgs/by-name/pr/prelink/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchgit -, autoreconfHook -, libelf -, libiberty +{ + stdenv, + lib, + fetchgit, + autoreconfHook, + libelf, + libiberty, }: stdenv.mkDerivation rec { @@ -19,7 +20,10 @@ stdenv.mkDerivation rec { strictDeps = true; - configurePlatforms = [ "build" "host" ]; + configurePlatforms = [ + "build" + "host" + ]; nativeBuildInputs = [ autoreconfHook @@ -36,7 +40,7 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - meta = with lib;{ + meta = with lib; { description = "ELF prelinking utility to speed up dynamic linking"; homepage = "https://wiki.yoctoproject.org/wiki/Cross-Prelink"; license = licenses.gpl2Plus; diff --git a/pkgs/by-name/pr/preload/package.nix b/pkgs/by-name/pr/preload/package.nix index 2240fa5a2cdb6f..252d925cff66cc 100644 --- a/pkgs/by-name/pr/preload/package.nix +++ b/pkgs/by-name/pr/preload/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchzip, autoconf, automake, pkg-config, glib }: +{ + lib, + stdenv, + fetchzip, + autoconf, + automake, + pkg-config, + glib, +}: stdenv.mkDerivation rec { pname = "preload"; @@ -14,7 +22,11 @@ stdenv.mkDerivation rec { ./0001-prevent-building-to-var-directories.patch ]; - nativeBuildInputs = [ autoconf automake pkg-config ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + ]; buildInputs = [ glib ]; configureFlags = [ "--localstatedir=/var" ]; diff --git a/pkgs/by-name/pr/premid/package.nix b/pkgs/by-name/pr/premid/package.nix index 876c4c33de28e4..0d94f09defc281 100644 --- a/pkgs/by-name/pr/premid/package.nix +++ b/pkgs/by-name/pr/premid/package.nix @@ -1,9 +1,49 @@ -{ autoPatchelfHook, makeDesktopItem, lib, stdenv, wrapGAppsHook3, fetchurl, copyDesktopItems -, alsa-lib, at-spi2-atk, at-spi2-core, atk, cairo, cups, dbus, expat, fontconfig -, freetype, gdk-pixbuf, glib, gtk3, libcxx, libdrm, libnotify, libpulseaudio, libuuid -, libX11, libXScrnSaver, libXcomposite, libXcursor, libXdamage, libXext -, libXfixes, libXi, libXrandr, libXrender, libXtst, libxcb, libxshmfence -, mesa, nspr, nss, pango, systemd, libappindicator-gtk3, libdbusmenu +{ + autoPatchelfHook, + makeDesktopItem, + lib, + stdenv, + wrapGAppsHook3, + fetchurl, + copyDesktopItems, + alsa-lib, + at-spi2-atk, + at-spi2-core, + atk, + cairo, + cups, + dbus, + expat, + fontconfig, + freetype, + gdk-pixbuf, + glib, + gtk3, + libcxx, + libdrm, + libnotify, + libpulseaudio, + libuuid, + libX11, + libXScrnSaver, + libXcomposite, + libXcursor, + libXdamage, + libXext, + libXfixes, + libXi, + libXrandr, + libXrender, + libXtst, + libxcb, + libxshmfence, + mesa, + nspr, + nss, + pango, + systemd, + libappindicator-gtk3, + libdbusmenu, }: stdenv.mkDerivation rec { @@ -41,13 +81,46 @@ stdenv.mkDerivation rec { dontConfigure = true; libPath = lib.makeLibraryPath [ - libcxx systemd libpulseaudio libdrm mesa - stdenv.cc.cc alsa-lib atk at-spi2-atk at-spi2-core cairo cups dbus expat fontconfig freetype - gdk-pixbuf glib gtk3 libnotify libX11 libXcomposite libuuid - libXcursor libXdamage libXext libXfixes libXi libXrandr libXrender - libXtst nspr nss libxcb pango systemd libXScrnSaver - libappindicator-gtk3 libdbusmenu - ]; + libcxx + systemd + libpulseaudio + libdrm + mesa + stdenv.cc.cc + alsa-lib + atk + at-spi2-atk + at-spi2-core + cairo + cups + dbus + expat + fontconfig + freetype + gdk-pixbuf + glib + gtk3 + libnotify + libX11 + libXcomposite + libuuid + libXcursor + libXdamage + libXext + libXfixes + libXi + libXrandr + libXrender + libXtst + nspr + nss + libxcb + pango + systemd + libXScrnSaver + libappindicator-gtk3 + libdbusmenu + ]; installPhase = '' mkdir -p $out/{bin,opt/PreMiD,share/pixmaps} diff --git a/pkgs/by-name/pr/presage/package.nix b/pkgs/by-name/pr/presage/package.nix index c9e44e58591463..79d2fafac4852b 100644 --- a/pkgs/by-name/pr/presage/package.nix +++ b/pkgs/by-name/pr/presage/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, autoreconfHook -, dbus -, doxygen -, fontconfig -, gettext -, graphviz -, help2man -, pkg-config -, sqlite -, tinyxml -, cppunit +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + dbus, + doxygen, + fontconfig, + gettext, + graphviz, + help2man, + pkg-config, + sqlite, + tinyxml, + cppunit, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pr/present-cli/package.nix b/pkgs/by-name/pr/present-cli/package.nix index 0f425accb69924..8df4ea1e21fc9a 100644 --- a/pkgs/by-name/pr/present-cli/package.nix +++ b/pkgs/by-name/pr/present-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pr/present/package.nix b/pkgs/by-name/pr/present/package.nix index aa586aded146d0..e2294908b45f55 100644 --- a/pkgs/by-name/pr/present/package.nix +++ b/pkgs/by-name/pr/present/package.nix @@ -1,15 +1,19 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: let - # https://github.com/NixOS/nixpkgs/issues/348788 - mistune_2 = python3Packages.mistune.overridePythonAttrs(oldAttrs: rec { - version = "2.0.5"; - src = fetchPypi { - inherit (oldAttrs) pname; - inherit version; - hash = "sha256-AkYRPLJJLbh1xr5Wl0p8iTMzvybNkokchfYxUc7gnTQ="; - }; - }); + # https://github.com/NixOS/nixpkgs/issues/348788 + mistune_2 = python3Packages.mistune.overridePythonAttrs (oldAttrs: rec { + version = "2.0.5"; + src = fetchPypi { + inherit (oldAttrs) pname; + inherit version; + hash = "sha256-AkYRPLJJLbh1xr5Wl0p8iTMzvybNkokchfYxUc7gnTQ="; + }; + }); in python3Packages.buildPythonPackage rec { pname = "present"; diff --git a/pkgs/by-name/pr/pretalx/package.nix b/pkgs/by-name/pr/pretalx/package.nix index 78fdd3f34b6690..dc9b6ece9bf679 100644 --- a/pkgs/by-name/pr/pretalx/package.nix +++ b/pkgs/by-name/pr/pretalx/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildNpmPackage -, gettext -, python3 -, fetchFromGitHub -, plugins ? [ ] -, nixosTests +{ + lib, + buildNpmPackage, + gettext, + python3, + fetchFromGitHub, + plugins ? [ ], + nixosTests, }: let @@ -52,7 +53,7 @@ let homepage = "https://github.com/pretalx/pretalx"; changelog = "https://docs.pretalx.org/changelog/#${version}"; license = licenses.asl20; - maintainers = with maintainers; [ hexa] ++ teams.c3d2.members; + maintainers = with maintainers; [ hexa ] ++ teams.c3d2.members; platforms = platforms.linux; }; @@ -112,46 +113,48 @@ python.pkgs.buildPythonApplication rec { "whitenoise" ]; - dependencies = with python.pkgs; [ - beautifulsoup4 - bleach - celery - css-inline - csscompressor - cssutils - defusedcsv - defusedxml - django - django-bootstrap4 - django-compressor - django-context-decorator - django-countries - django-csp - django-filter - django-formset-js-improved - django-formtools - django-hierarkey - django-i18nfield - django-libsass - django-scopes - djangorestframework - libsass - markdown - pillow - publicsuffixlist - python-dateutil - qrcode - reportlab - requests - rules - urlman - vobject - whitenoise - zxcvbn - ] - ++ beautifulsoup4.optional-dependencies.lxml - ++ django.optional-dependencies.argon2 - ++ plugins; + dependencies = + with python.pkgs; + [ + beautifulsoup4 + bleach + celery + css-inline + csscompressor + cssutils + defusedcsv + defusedxml + django + django-bootstrap4 + django-compressor + django-context-decorator + django-countries + django-csp + django-filter + django-formset-js-improved + django-formtools + django-hierarkey + django-i18nfield + django-libsass + django-scopes + djangorestframework + libsass + markdown + pillow + publicsuffixlist + python-dateutil + qrcode + reportlab + requests + rules + urlman + vobject + whitenoise + zxcvbn + ] + ++ beautifulsoup4.optional-dependencies.lxml + ++ django.optional-dependencies.argon2 + ++ plugins; optional-dependencies = { postgres = with python.pkgs; [ @@ -194,17 +197,20 @@ python.pkgs.buildPythonApplication rec { cd src ''; - nativeCheckInputs = with python.pkgs; [ - faker - freezegun - jsonschema - pytest-cov-stub - pytest-django - pytest-mock - pytest-xdist - pytestCheckHook - responses - ] ++ lib.flatten (lib.attrValues optional-dependencies); + nativeCheckInputs = + with python.pkgs; + [ + faker + freezegun + jsonschema + pytest-cov-stub + pytest-django + pytest-mock + pytest-xdist + pytestCheckHook + responses + ] + ++ lib.flatten (lib.attrValues optional-dependencies); disabledTests = [ # tries to run npm run i18n:extract diff --git a/pkgs/by-name/pr/pretender/package.nix b/pkgs/by-name/pr/pretender/package.nix index 9d7df071224d44..def2259c93ca21 100644 --- a/pkgs/by-name/pr/pretender/package.nix +++ b/pkgs/by-name/pr/pretender/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/pr/pretix/package.nix b/pkgs/by-name/pr/pretix/package.nix index fce02ede99c384..f178d109c5591b 100644 --- a/pkgs/by-name/pr/pretix/package.nix +++ b/pkgs/by-name/pr/pretix/package.nix @@ -1,12 +1,13 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, fetchPypi -, nodejs -, python3 -, gettext -, nixosTests -, plugins ? [ ] +{ + lib, + buildNpmPackage, + fetchFromGitHub, + fetchPypi, + nodejs, + python3, + gettext, + nixosTests, + plugins ? [ ], }: let @@ -132,86 +133,88 @@ python.pkgs.buildPythonApplication rec { tomli ]; - dependencies = with python.pkgs; [ - arabic-reshaper - babel - beautifulsoup4 - bleach - celery - chardet - cryptography - css-inline - defusedcsv - django - django-bootstrap3 - django-compressor - django-countries - django-filter - django-formset-js-improved - django-formtools - django-hierarkey - django-hijack - django-i18nfield - django-libsass - django-localflavor - django-markup - django-oauth-toolkit - django-otp - django-phonenumber-field - django-redis - django-scopes - django-statici18n - djangorestframework - dnspython - drf-ujson2 - geoip2 - importlib-metadata - isoweek - jsonschema - kombu - libsass - lxml - markdown - mt-940 - oauthlib - openpyxl - packaging - paypalrestsdk - paypal-checkout-serversdk - pyjwt - phonenumberslite - pillow - pretix-plugin-build - protobuf - psycopg2-binary - pycountry - pycparser - pycryptodome - pypdf - python-bidi - python-dateutil - pytz - pytz-deprecation-shim - pyuca - qrcode - redis - reportlab - requests - sentry-sdk - sepaxml - slimit - stripe - text-unidecode - tlds - tqdm - ua-parser - vat-moss - vobject - webauthn - zeep - ] - ++ django.optional-dependencies.argon2 - ++ plugins; + dependencies = + with python.pkgs; + [ + arabic-reshaper + babel + beautifulsoup4 + bleach + celery + chardet + cryptography + css-inline + defusedcsv + django + django-bootstrap3 + django-compressor + django-countries + django-filter + django-formset-js-improved + django-formtools + django-hierarkey + django-hijack + django-i18nfield + django-libsass + django-localflavor + django-markup + django-oauth-toolkit + django-otp + django-phonenumber-field + django-redis + django-scopes + django-statici18n + djangorestframework + dnspython + drf-ujson2 + geoip2 + importlib-metadata + isoweek + jsonschema + kombu + libsass + lxml + markdown + mt-940 + oauthlib + openpyxl + packaging + paypalrestsdk + paypal-checkout-serversdk + pyjwt + phonenumberslite + pillow + pretix-plugin-build + protobuf + psycopg2-binary + pycountry + pycparser + pycryptodome + pypdf + python-bidi + python-dateutil + pytz + pytz-deprecation-shim + pyuca + qrcode + redis + reportlab + requests + sentry-sdk + sepaxml + slimit + stripe + text-unidecode + tlds + tqdm + ua-parser + vat-moss + vobject + webauthn + zeep + ] + ++ django.optional-dependencies.argon2 + ++ plugins; optional-dependencies = with python.pkgs; { memcached = [ @@ -229,20 +232,24 @@ python.pkgs.buildPythonApplication rec { dontStrip = true; # no binaries - nativeCheckInputs = with python.pkgs; [ - pytestCheckHook - pytest-xdist - pytest-mock - pytest-django - pytest-asyncio - pytest-rerunfailures - freezegun - fakeredis - responses - ] ++ lib.flatten (lib.attrValues optional-dependencies); + nativeCheckInputs = + with python.pkgs; + [ + pytestCheckHook + pytest-xdist + pytest-mock + pytest-django + pytest-asyncio + pytest-rerunfailures + freezegun + fakeredis + responses + ] + ++ lib.flatten (lib.attrValues optional-dependencies); pytestFlagsArray = [ - "--reruns" "3" + "--reruns" + "3" ]; disabledTests = [ @@ -266,9 +273,9 @@ python.pkgs.buildPythonApplication rec { inherit npmDeps python - ; - plugins = lib.recurseIntoAttrs - (python.pkgs.callPackage ./plugins { + ; + plugins = lib.recurseIntoAttrs ( + python.pkgs.callPackage ./plugins { inherit (python.pkgs) callPackage; } ); diff --git a/pkgs/by-name/pr/pretix/plugins/default.nix b/pkgs/by-name/pr/pretix/plugins/default.nix index a60316e521e484..5e3b8fa2014240 100644 --- a/pkgs/by-name/pr/pretix/plugins/default.nix +++ b/pkgs/by-name/pr/pretix/plugins/default.nix @@ -1,5 +1,6 @@ -{ callPackage -, ... +{ + callPackage, + ... }: { diff --git a/pkgs/by-name/pr/pretix/plugins/pages.nix b/pkgs/by-name/pr/pretix/plugins/pages.nix index 97e40967938517..2fc108eb58b74b 100644 --- a/pkgs/by-name/pr/pretix/plugins/pages.nix +++ b/pkgs/by-name/pr/pretix/plugins/pages.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, pretix-plugin-build -, setuptools +{ + lib, + buildPythonPackage, + fetchFromGitHub, + pretix-plugin-build, + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/by-name/pr/pretix/plugins/passbook.nix b/pkgs/by-name/pr/pretix/plugins/passbook.nix index ccb14543b7ab0a..d5ca08315f18a0 100644 --- a/pkgs/by-name/pr/pretix/plugins/passbook.nix +++ b/pkgs/by-name/pr/pretix/plugins/passbook.nix @@ -1,18 +1,19 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, substituteAll - -# build-system -, pretix-plugin-build -, setuptools - -# runtime -, openssl - -# dependencies -, googlemaps -, wallet-py3k +{ + lib, + buildPythonPackage, + fetchFromGitHub, + substituteAll, + + # build-system + pretix-plugin-build, + setuptools, + + # runtime + openssl, + + # dependencies + googlemaps, + wallet-py3k, }: buildPythonPackage rec { diff --git a/pkgs/by-name/pr/pretix/plugins/reluctant-stripe.nix b/pkgs/by-name/pr/pretix/plugins/reluctant-stripe.nix index 40ab96a36bca30..e61497499488e7 100644 --- a/pkgs/by-name/pr/pretix/plugins/reluctant-stripe.nix +++ b/pkgs/by-name/pr/pretix/plugins/reluctant-stripe.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, pretix-plugin-build -, setuptools +{ + lib, + buildPythonPackage, + fetchFromGitHub, + pretix-plugin-build, + setuptools, }: buildPythonPackage { diff --git a/pkgs/by-name/pr/pretix/plugins/stretchgoals.nix b/pkgs/by-name/pr/pretix/plugins/stretchgoals.nix index 4d1cb8d02e8487..afdb4616bcd101 100644 --- a/pkgs/by-name/pr/pretix/plugins/stretchgoals.nix +++ b/pkgs/by-name/pr/pretix/plugins/stretchgoals.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, pretix-plugin-build -, setuptools +{ + lib, + buildPythonPackage, + fetchFromGitHub, + pretix-plugin-build, + setuptools, }: buildPythonPackage { diff --git a/pkgs/by-name/pr/prettier-d-slim/package.nix b/pkgs/by-name/pr/prettier-d-slim/package.nix index 1f3938968fb211..6278fee6b51379 100644 --- a/pkgs/by-name/pr/prettier-d-slim/package.nix +++ b/pkgs/by-name/pr/prettier-d-slim/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/pr/pretty-simple/package.nix b/pkgs/by-name/pr/pretty-simple/package.nix index 0a33b6e6b2eaff..fd302d220c354b 100644 --- a/pkgs/by-name/pr/pretty-simple/package.nix +++ b/pkgs/by-name/pr/pretty-simple/package.nix @@ -1,12 +1,17 @@ -{ haskell, haskellPackages, lib }: +{ + haskell, + haskellPackages, + lib, +}: -haskell.lib.compose.justStaticExecutables (haskell.lib.compose.overrideCabal (oldAttrs: { - maintainers = (oldAttrs.maintainers or []) ++ [ - lib.maintainers.cdepillabout - ]; +haskell.lib.compose.justStaticExecutables ( + haskell.lib.compose.overrideCabal (oldAttrs: { + maintainers = (oldAttrs.maintainers or [ ]) ++ [ + lib.maintainers.cdepillabout + ]; - configureFlags = (oldAttrs.configureFlags or []) ++ ["-fbuildexe"]; - - buildDepends = (oldAttrs.buildDepends or []) ++ [haskellPackages.optparse-applicative]; -}) haskellPackages.pretty-simple) + configureFlags = (oldAttrs.configureFlags or [ ]) ++ [ "-fbuildexe" ]; + buildDepends = (oldAttrs.buildDepends or [ ]) ++ [ haskellPackages.optparse-applicative ]; + }) haskellPackages.pretty-simple +) diff --git a/pkgs/by-name/pr/prettyping/package.nix b/pkgs/by-name/pr/prettyping/package.nix index 3f42a07261dd2a..1d629216b0d671 100644 --- a/pkgs/by-name/pr/prettyping/package.nix +++ b/pkgs/by-name/pr/prettyping/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "prettyping"; diff --git a/pkgs/by-name/pr/prettypst/package.nix b/pkgs/by-name/pr/prettypst/package.nix index 51bc7fd39be273..dc48d89c9295b6 100644 --- a/pkgs/by-name/pr/prettypst/package.nix +++ b/pkgs/by-name/pr/prettypst/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pr/prevo-data/package.nix b/pkgs/by-name/pr/prevo-data/package.nix index 15f7eb66187ce5..5056d194a8fe2c 100644 --- a/pkgs/by-name/pr/prevo-data/package.nix +++ b/pkgs/by-name/pr/prevo-data/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, prevo-tools }: +{ + lib, + stdenv, + fetchFromGitHub, + prevo-tools, +}: stdenv.mkDerivation { pname = "prevo-data"; @@ -25,8 +30,7 @@ stdenv.mkDerivation { ''; meta = { - description = - "data for offline version of the Esperanto dictionary Reta Vortaro"; + description = "data for offline version of the Esperanto dictionary Reta Vortaro"; longDescription = '' PReVo is the "portable" ReVo, i.e., the offline version of the Esperanto dictionary Reta Vortaro. @@ -35,6 +39,9 @@ stdenv.mkDerivation { ''; homepage = "https://github.com/bpeel/revo"; license = lib.licenses.gpl2Only; - maintainers = with lib.maintainers; [ das-g ehmry ]; + maintainers = with lib.maintainers; [ + das-g + ehmry + ]; }; } diff --git a/pkgs/by-name/pr/prevo-tools/package.nix b/pkgs/by-name/pr/prevo-tools/package.nix index a4bb505357b041..5f8b9502d95725 100644 --- a/pkgs/by-name/pr/prevo-tools/package.nix +++ b/pkgs/by-name/pr/prevo-tools/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, pkg-config, glib, expat -, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + glib, + expat, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "prevo-tools"; @@ -21,16 +30,22 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config installShellFiles ]; - buildInputs = [ glib expat ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + installShellFiles + ]; + buildInputs = [ + glib + expat + ]; postInstall = '' installShellCompletion --bash src/prevo-completion ''; meta = { - description = - "CLI tools for the offline version of the Esperanto dictionary Reta Vortaro"; + description = "CLI tools for the offline version of the Esperanto dictionary Reta Vortaro"; longDescription = '' PReVo is the "portable" ReVo, i.e., the offline version of the Esperanto dictionary Reta Vortaro. @@ -42,7 +57,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/bpeel/prevodb"; license = lib.licenses.gpl2Only; mainProgram = "prevo"; - maintainers = with lib.maintainers; [ das-g ehmry ]; + maintainers = with lib.maintainers; [ + das-g + ehmry + ]; platforms = lib.platforms.unix; }; } diff --git a/pkgs/by-name/pr/prevo/package.nix b/pkgs/by-name/pr/prevo/package.nix index 5a0ecff4d88536..b45d0cd1f785c1 100644 --- a/pkgs/by-name/pr/prevo/package.nix +++ b/pkgs/by-name/pr/prevo/package.nix @@ -1,4 +1,11 @@ -{ lib, symlinkJoin, man, prevo-tools, prevo-data, makeWrapper }: +{ + lib, + symlinkJoin, + man, + prevo-tools, + prevo-data, + makeWrapper, +}: symlinkJoin rec { name = "prevo-${version}"; @@ -24,6 +31,9 @@ symlinkJoin rec { homepage = "https://github.com/bpeel/prevodb"; license = lib.licenses.gpl2Only; mainProgram = "prevo"; - maintainers = with lib.maintainers; [ das-g ehmry ]; + maintainers = with lib.maintainers; [ + das-g + ehmry + ]; }; } diff --git a/pkgs/by-name/pr/pridecat/package.nix b/pkgs/by-name/pr/pridecat/package.nix index 4d4ed57fc23525..00c3c3e3889dfb 100644 --- a/pkgs/by-name/pr/pridecat/package.nix +++ b/pkgs/by-name/pr/pridecat/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "pridecat"; diff --git a/pkgs/by-name/pr/pridefetch/package.nix b/pkgs/by-name/pr/pridefetch/package.nix index dedd3b336d78ab..971c3c482d26ae 100644 --- a/pkgs/by-name/pr/pridefetch/package.nix +++ b/pkgs/by-name/pr/pridefetch/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, python3 -, stdenv -, strip-nondeterminism -, zip +{ + lib, + fetchFromGitHub, + python3, + stdenv, + strip-nondeterminism, + zip, }: let @@ -28,9 +29,11 @@ stdenv.mkDerivation { ]; buildInputs = [ - (python3.withPackages (pythonPackages: with pythonPackages; [ - distro - ])) + (python3.withPackages ( + pythonPackages: with pythonPackages; [ + distro + ] + )) ]; buildPhase = '' diff --git a/pkgs/by-name/pr/prime-server/package.nix b/pkgs/by-name/pr/prime-server/package.nix index 946fbb0dff18b0..41bd6671019f43 100644 --- a/pkgs/by-name/pr/prime-server/package.nix +++ b/pkgs/by-name/pr/prime-server/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config -, curl, zeromq, czmq, libsodium }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + curl, + zeromq, + czmq, + libsodium, +}: stdenv.mkDerivation rec { pname = "prime-server"; @@ -13,8 +22,16 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ curl zeromq czmq libsodium ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + curl + zeromq + czmq + libsodium + ]; # https://github.com/kevinkreiser/prime_server/issues/95 env.NIX_CFLAGS_COMPILE = toString [ "-Wno-error=unused-variable" ]; diff --git a/pkgs/by-name/pr/principia/package.nix b/pkgs/by-name/pr/principia/package.nix index ee6fcc9d33736a..85edd081024d42 100644 --- a/pkgs/by-name/pr/principia/package.nix +++ b/pkgs/by-name/pr/principia/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + wrapGAppsHook3, -, curl -, freetype -, glew -, gtk3 -, libGL -, libjpeg -, libpng -, SDL2 -, SDL2_gfx -, SDL2_image -, SDL2_mixer -, SDL2_ttf + curl, + freetype, + glew, + gtk3, + libGL, + libjpeg, + libpng, + SDL2, + SDL2_gfx, + SDL2_image, + SDL2_mixer, + SDL2_ttf, }: stdenv.mkDerivation (finalAttrs: { @@ -57,7 +58,9 @@ stdenv.mkDerivation (finalAttrs: { ]; meta = with lib; { - changelog = "https://principia-web.se/wiki/Changelog#${lib.replaceStrings ["."] ["-"] finalAttrs.version}"; + changelog = "https://principia-web.se/wiki/Changelog#${ + lib.replaceStrings [ "." ] [ "-" ] finalAttrs.version + }"; description = "Physics-based sandbox game"; mainProgram = "principia"; homepage = "https://principia-web.se/"; diff --git a/pkgs/by-name/pr/printrun/package.nix b/pkgs/by-name/pr/printrun/package.nix index 70dbfe40677208..84d3bc77ebc35e 100644 --- a/pkgs/by-name/pr/printrun/package.nix +++ b/pkgs/by-name/pr/printrun/package.nix @@ -1,4 +1,10 @@ -{ lib, python3Packages, fetchFromGitHub, glib, wrapGAppsHook3 }: +{ + lib, + python3Packages, + fetchFromGitHub, + glib, + wrapGAppsHook3, +}: python3Packages.buildPythonApplication rec { pname = "printrun"; @@ -18,16 +24,32 @@ python3Packages.buildPythonApplication rec { sed -i -r "s|/usr(/local)?/share/|$out/share/|g" printrun/utils.py ''; - nativeBuildInputs = [ glib wrapGAppsHook3 ]; + nativeBuildInputs = [ + glib + wrapGAppsHook3 + ]; propagatedBuildInputs = with python3Packages; [ - appdirs cython dbus-python numpy six wxpython psutil pyglet pyopengl pyserial cffi cairosvg lxml puremagic + appdirs + cython + dbus-python + numpy + six + wxpython + psutil + pyglet + pyopengl + pyserial + cffi + cairosvg + lxml + puremagic ]; # pyglet.canvas.xlib.NoSuchDisplayException: Cannot connect to "None" doCheck = false; - setupPyBuildFlags = ["-i"]; + setupPyBuildFlags = [ "-i" ]; postInstall = '' for f in $out/share/applications/*.desktop; do diff --git a/pkgs/by-name/pr/prio/package.nix b/pkgs/by-name/pr/prio/package.nix index 620e4f9382cee4..bc41616e738f0f 100644 --- a/pkgs/by-name/pr/prio/package.nix +++ b/pkgs/by-name/pr/prio/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pr/prism/package.nix b/pkgs/by-name/pr/prism/package.nix index a2f42aa00c4e34..86227fdb840ed3 100644 --- a/pkgs/by-name/pr/prism/package.nix +++ b/pkgs/by-name/pr/prism/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "prism"; diff --git a/pkgs/by-name/pr/pritunl-client/package.nix b/pkgs/by-name/pr/pritunl-client/package.nix index cad06f7aa4b6ea..fc650790a9fa61 100644 --- a/pkgs/by-name/pr/pritunl-client/package.nix +++ b/pkgs/by-name/pr/pritunl-client/package.nix @@ -1,22 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, runtimeShell -, runCommand -, makeWrapper -, installShellFiles -, buildGoModule -, coreutils -, which -, gnugrep -, gnused -, openresolv -, systemd -, iproute2 -, openvpn -, electron -}: let +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + runtimeShell, + runCommand, + makeWrapper, + installShellFiles, + buildGoModule, + coreutils, + which, + gnugrep, + gnused, + openresolv, + systemd, + iproute2, + openvpn, + electron, +}: +let version = "1.3.4083.88"; src = fetchFromGitHub { owner = "pritunl"; @@ -47,51 +49,63 @@ nativeBuildInputs = [ makeWrapper ]; - postPatch = '' - sed -Ei service/connection/scripts.go \ - -e 's|#!\s*(/usr)?/bin/(env )?bash\b|#! ${runtimeShell}|g' - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - sed -Ei service/connection/scripts.go \ - -e 's|(/usr)?/s?bin/busctl\b|busctl|g' \ - -e 's|(/usr)?/s?bin/resolvectl\b|resolvectl|g' \ - -e 's|(/usr)?/s?bin/ip\b|ip|g' - ''; + postPatch = + '' + sed -Ei service/connection/scripts.go \ + -e 's|#!\s*(/usr)?/bin/(env )?bash\b|#! ${runtimeShell}|g' + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + sed -Ei service/connection/scripts.go \ + -e 's|(/usr)?/s?bin/busctl\b|busctl|g' \ + -e 's|(/usr)?/s?bin/resolvectl\b|resolvectl|g' \ + -e 's|(/usr)?/s?bin/ip\b|ip|g' + ''; - postInstall = '' - mv $out/bin/service $out/bin/pritunl-client-service - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - mkdir -p $out/lib/systemd/system/ - cp $src/resources_linux/pritunl-client.service $out/lib/systemd/system/ - substituteInPlace $out/lib/systemd/system/pritunl-client.service \ - --replace-warn "/usr" "$out" - ''; + postInstall = + '' + mv $out/bin/service $out/bin/pritunl-client-service + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + mkdir -p $out/lib/systemd/system/ + cp $src/resources_linux/pritunl-client.service $out/lib/systemd/system/ + substituteInPlace $out/lib/systemd/system/pritunl-client.service \ + --replace-warn "/usr" "$out" + ''; - postFixup = let - hookScriptsDeps = [ - coreutils - which - gnused - gnugrep - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - openresolv - systemd - iproute2 - ]; - openvpn-wrapped = runCommand "openvpn-wrapped" { - nativeBuildInputs = [ makeWrapper ]; - } '' - mkdir -p $out/bin - makeWrapper ${openvpn}/bin/openvpn $out/bin/openvpn \ - --prefix PATH : ${lib.makeBinPath hookScriptsDeps} \ - --add-flags "--setenv PATH \$PATH" + postFixup = + let + hookScriptsDeps = + [ + coreutils + which + gnused + gnugrep + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + openresolv + systemd + iproute2 + ]; + openvpn-wrapped = + runCommand "openvpn-wrapped" + { + nativeBuildInputs = [ makeWrapper ]; + } + '' + mkdir -p $out/bin + makeWrapper ${openvpn}/bin/openvpn $out/bin/openvpn \ + --prefix PATH : ${lib.makeBinPath hookScriptsDeps} \ + --add-flags "--setenv PATH \$PATH" + ''; + in + lib.optionalString stdenv.hostPlatform.isLinux '' + wrapProgram $out/bin/pritunl-client-service \ + --prefix PATH : "${lib.makeBinPath ([ openvpn-wrapped ])}" ''; - in lib.optionalString stdenv.hostPlatform.isLinux '' - wrapProgram $out/bin/pritunl-client-service \ - --prefix PATH : "${lib.makeBinPath ([ openvpn-wrapped ])}" - ''; passthru.updateScript = nix-update-script { }; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "pritunl-client"; inherit version src; @@ -103,45 +117,51 @@ in stdenv.mkDerivation { installShellFiles ]; - installPhase = '' - runHook preInstall - - mkdir -p $out/bin/ - ln -s ${cli}/bin/pritunl-client $out/bin/ - ln -s ${service}/bin/pritunl-client-service $out/bin/ - - mkdir -p $out/lib/ - cp -r client $out/lib/pritunl_client_electron + installPhase = + '' + runHook preInstall - makeWrapper ${electron}/bin/electron $out/bin/pritunl-client-electron \ - --add-flags $out/lib/pritunl_client_electron + mkdir -p $out/bin/ + ln -s ${cli}/bin/pritunl-client $out/bin/ + ln -s ${service}/bin/pritunl-client-service $out/bin/ - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - mkdir -p $out/lib/systemd/system/ - ln -s ${service}/lib/systemd/system/pritunl-client.service $out/lib/systemd/system/ + mkdir -p $out/lib/ + cp -r client $out/lib/pritunl_client_electron - mkdir -p $out/share/icons/ - cp -r resources_linux/icons $out/share/icons/hicolor + makeWrapper ${electron}/bin/electron $out/bin/pritunl-client-electron \ + --add-flags $out/lib/pritunl_client_electron - mkdir -p $out/share/applications/ - cp resources_linux/pritunl-client-electron.desktop $out/share/applications/ - substituteInPlace $out/share/applications/pritunl-client-electron.desktop \ - --replace-fail "/usr/lib/pritunl_client_electron/Pritunl" "$out/bin/pritunl-client-electron" - '' + '' - # install shell completions for pritunl-client - installShellCompletion --cmd pritunl-client \ - --bash <($out/bin/pritunl-client completion bash) \ - --fish <($out/bin/pritunl-client completion fish) \ - --zsh <($out/bin/pritunl-client completion zsh) - - runHook postInstall - ''; + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + mkdir -p $out/lib/systemd/system/ + ln -s ${service}/lib/systemd/system/pritunl-client.service $out/lib/systemd/system/ + + mkdir -p $out/share/icons/ + cp -r resources_linux/icons $out/share/icons/hicolor + + mkdir -p $out/share/applications/ + cp resources_linux/pritunl-client-electron.desktop $out/share/applications/ + substituteInPlace $out/share/applications/pritunl-client-electron.desktop \ + --replace-fail "/usr/lib/pritunl_client_electron/Pritunl" "$out/bin/pritunl-client-electron" + '' + + '' + # install shell completions for pritunl-client + installShellCompletion --cmd pritunl-client \ + --bash <($out/bin/pritunl-client completion bash) \ + --fish <($out/bin/pritunl-client completion fish) \ + --zsh <($out/bin/pritunl-client completion zsh) + + runHook postInstall + ''; passthru.updateScript = nix-update-script { }; meta = with lib; { description = "Pritunl OpenVPN client"; homepage = "https://client.pritunl.com/"; license = licenses.unfree; - maintainers = with maintainers; [ minizilla andrevmatos ]; + maintainers = with maintainers; [ + minizilla + andrevmatos + ]; }; } diff --git a/pkgs/by-name/pr/pritunl-ssh/package.nix b/pkgs/by-name/pr/pritunl-ssh/package.nix index 75440cc5e06cb1..31c41e894a0b4e 100644 --- a/pkgs/by-name/pr/pritunl-ssh/package.nix +++ b/pkgs/by-name/pr/pritunl-ssh/package.nix @@ -1,7 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation rec { - pname = "pritunl-ssh"; + pname = "pritunl-ssh"; version = "1.0.3231.6"; src = fetchFromGitHub { diff --git a/pkgs/by-name/pr/private-gpt/package.nix b/pkgs/by-name/pr/private-gpt/package.nix index 4912c42212c864..419772ec32cf11 100644 --- a/pkgs/by-name/pr/private-gpt/package.nix +++ b/pkgs/by-name/pr/private-gpt/package.nix @@ -1,19 +1,22 @@ -{ python3Packages -, makeBinaryWrapper +{ + python3Packages, + makeBinaryWrapper, }: -python3Packages.toPythonApplication (python3Packages.private-gpt.overrideAttrs (oldAttrs: { - nativeBuildInputs = oldAttrs.nativeBuildInputs ++ [ makeBinaryWrapper ]; +python3Packages.toPythonApplication ( + python3Packages.private-gpt.overrideAttrs (oldAttrs: { + nativeBuildInputs = oldAttrs.nativeBuildInputs ++ [ makeBinaryWrapper ]; - passthru = (oldAttrs.passthru or {}) // { - cl100k_base = { - inherit (python3Packages.private-gpt.cl100k_base) tiktoken; + passthru = (oldAttrs.passthru or { }) // { + cl100k_base = { + inherit (python3Packages.private-gpt.cl100k_base) tiktoken; + }; }; - }; - postInstall = '' - makeWrapper ${python3Packages.python.interpreter} $out/bin/private-gpt \ - --prefix PYTHONPATH : "$PYTHONPATH" \ - --add-flags "-m private_gpt" - ''; -})) + postInstall = '' + makeWrapper ${python3Packages.python.interpreter} $out/bin/private-gpt \ + --prefix PYTHONPATH : "$PYTHONPATH" \ + --add-flags "-m private_gpt" + ''; + }) +) diff --git a/pkgs/by-name/pr/probe-rs-tools/package.nix b/pkgs/by-name/pr/probe-rs-tools/package.nix index 1dc76b3f323787..20955ed5217aba 100644 --- a/pkgs/by-name/pr/probe-rs-tools/package.nix +++ b/pkgs/by-name/pr/probe-rs-tools/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, cmake -, gitMinimal -, pkg-config -, libusb1 -, openssl +{ + lib, + rustPlatform, + fetchFromGitHub, + cmake, + gitMinimal, + pkg-config, + libusb1, + openssl, }: rustPlatform.buildRustPackage rec { @@ -33,7 +34,10 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ libusb1 openssl ]; + buildInputs = [ + libusb1 + openssl + ]; checkFlags = [ # require a physical probe @@ -60,7 +64,13 @@ rustPlatform.buildRustPackage rec { description = "CLI tool for on-chip debugging and flashing of ARM chips"; homepage = "https://probe.rs/"; changelog = "https://github.com/probe-rs/probe-rs/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ xgroleau newam ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + xgroleau + newam + ]; }; } diff --git a/pkgs/by-name/pr/procdump/package.nix b/pkgs/by-name/pr/procdump/package.nix index 45e6516c745d7e..a547f7f69f35a3 100644 --- a/pkgs/by-name/pr/procdump/package.nix +++ b/pkgs/by-name/pr/procdump/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, bash, coreutils, gdb, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + bash, + coreutils, + gdb, + zlib, +}: stdenv.mkDerivation rec { pname = "procdump"; @@ -22,7 +31,11 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ zlib ]; - buildInputs = [ bash coreutils gdb ]; + buildInputs = [ + bash + coreutils + gdb + ]; postPatch = '' substituteInPlace src/CoreDumpWriter.c \ diff --git a/pkgs/by-name/pr/process-compose/package.nix b/pkgs/by-name/pr/process-compose/package.nix index 0c8e98ed50fdd8..f75ac0b261de73 100644 --- a/pkgs/by-name/pr/process-compose/package.nix +++ b/pkgs/by-name/pr/process-compose/package.nix @@ -1,10 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: -let config-module = "github.com/f1bonacc1/process-compose/src/config"; +let + config-module = "github.com/f1bonacc1/process-compose/src/config"; in buildGoModule rec { pname = "process-compose"; diff --git a/pkgs/by-name/pr/process-viewer/package.nix b/pkgs/by-name/pr/process-viewer/package.nix index 10f55aced9ead1..646245950944ad 100644 --- a/pkgs/by-name/pr/process-viewer/package.nix +++ b/pkgs/by-name/pr/process-viewer/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, gtk4 -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + gtk4, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -20,9 +21,11 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk4 ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk_11_0.frameworks.Foundation - ]; + buildInputs = + [ gtk4 ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk_11_0.frameworks.Foundation + ]; postInstall = '' install -Dm644 assets/fr.guillaume_gomez.ProcessViewer.desktop -t $out/share/applications diff --git a/pkgs/by-name/pr/prociono/package.nix b/pkgs/by-name/pr/prociono/package.nix index 021036a6392409..598d479909cbba 100644 --- a/pkgs/by-name/pr/prociono/package.nix +++ b/pkgs/by-name/pr/prociono/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, +}: stdenvNoCC.mkDerivation { pname = "prociono"; diff --git a/pkgs/by-name/pr/procmail/package.nix b/pkgs/by-name/pr/procmail/package.nix index 3bd280766b16d9..dfb4bdb5a8955f 100644 --- a/pkgs/by-name/pr/procmail/package.nix +++ b/pkgs/by-name/pr/procmail/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fetchpatch, buildPackages }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + buildPackages, +}: stdenv.mkDerivation rec { pname = "procmail"; @@ -21,27 +27,31 @@ stdenv.mkDerivation rec { # getline is defined differently in glibc now. So rename it. # Without the .PHONY target "make install" won't install anything on Darwin. - postPatch = '' - sed -i Makefile \ - -e "s%^RM.*$%#%" \ - -e "s%^BASENAME.*%\BASENAME=$out%" \ - -e "s%^LIBS=.*%LIBS=-lm%" - sed -e "s%getline%thisgetline%g" -i src/*.c src/*.h - sed -e "3i\ - .PHONY: install - " -i Makefile - '' + lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - substituteInPlace src/Makefile.0 \ - --replace-fail '@./_autotst' '@${stdenv.hostPlatform.emulator buildPackages} ./_autotst' - sed -e '3i\ - _autotst() { ${stdenv.hostPlatform.emulator buildPackages} ./_autotst "$@"; } \ - _locktst() { ${stdenv.hostPlatform.emulator buildPackages} ./_locktst "$@"; } \ - ' -i src/autoconf - ''; + postPatch = + '' + sed -i Makefile \ + -e "s%^RM.*$%#%" \ + -e "s%^BASENAME.*%\BASENAME=$out%" \ + -e "s%^LIBS=.*%LIBS=-lm%" + sed -e "s%getline%thisgetline%g" -i src/*.c src/*.h + sed -e "3i\ + .PHONY: install + " -i Makefile + '' + + lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + substituteInPlace src/Makefile.0 \ + --replace-fail '@./_autotst' '@${stdenv.hostPlatform.emulator buildPackages} ./_autotst' + sed -e '3i\ + _autotst() { ${stdenv.hostPlatform.emulator buildPackages} ./_autotst "$@"; } \ + _locktst() { ${stdenv.hostPlatform.emulator buildPackages} ./_locktst "$@"; } \ + ' -i src/autoconf + ''; # default target is binaries + manpages; manpages don't cross compile without more work. makeFlags = lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ "bins" ]; - installTargets = lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ "install.bin" ]; + installTargets = lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + "install.bin" + ]; meta = with lib; { description = "Mail processing and filtering utility"; diff --git a/pkgs/by-name/pr/procyon/package.nix b/pkgs/by-name/pr/procyon/package.nix index 984459f2a4f60c..4fe075bd8886e6 100644 --- a/pkgs/by-name/pr/procyon/package.nix +++ b/pkgs/by-name/pr/procyon/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, runtimeShell, jre_headless }: +{ + lib, + stdenv, + fetchurl, + runtimeShell, + jre_headless, +}: stdenv.mkDerivation rec { pname = "procyon"; diff --git a/pkgs/by-name/pr/prodigal/package.nix b/pkgs/by-name/pr/prodigal/package.nix index cd83a723f91e39..616ce2f6c5f889 100644 --- a/pkgs/by-name/pr/prodigal/package.nix +++ b/pkgs/by-name/pr/prodigal/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "prodigal"; diff --git a/pkgs/by-name/pr/professor/package.nix b/pkgs/by-name/pr/professor/package.nix index 60a030f5282117..79ae452d1da294 100644 --- a/pkgs/by-name/pr/professor/package.nix +++ b/pkgs/by-name/pr/professor/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitLab -, eigen -, makeWrapper -, python3 +{ + lib, + stdenv, + fetchFromGitLab, + eigen, + makeWrapper, + python3, }: stdenv.mkDerivation rec { @@ -21,13 +22,15 @@ stdenv.mkDerivation rec { ''; }; - postPatch = '' - substituteInPlace Makefile \ - --replace-fail 'pip install ' 'pip install --prefix $(out) ' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace Makefile \ - --replace-fail '-shared -o' '-shared -install_name "$(out)/$@" -o' - ''; + postPatch = + '' + substituteInPlace Makefile \ + --replace-fail 'pip install ' 'pip install --prefix $(out) ' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace Makefile \ + --replace-fail '-shared -o' '-shared -install_name "$(out)/$@" -o' + ''; nativeBuildInputs = [ python3.pkgs.cython diff --git a/pkgs/by-name/pr/profetch/package.nix b/pkgs/by-name/pr/profetch/package.nix index fc5f3cea4a0f60..27b1fbbdf62335 100644 --- a/pkgs/by-name/pr/profetch/package.nix +++ b/pkgs/by-name/pr/profetch/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, gprolog }: +{ + stdenv, + lib, + fetchFromGitHub, + gprolog, +}: stdenv.mkDerivation rec { pname = "profetch"; diff --git a/pkgs/by-name/pr/profile-cleaner/package.nix b/pkgs/by-name/pr/profile-cleaner/package.nix index 8e5d8325d05965..48b0916e9ac282 100644 --- a/pkgs/by-name/pr/profile-cleaner/package.nix +++ b/pkgs/by-name/pr/profile-cleaner/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, parallel, sqlite, bc, file }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + parallel, + sqlite, + bc, + file, +}: stdenv.mkDerivation rec { version = "2.45"; @@ -16,7 +25,14 @@ stdenv.mkDerivation rec { installPhase = '' PREFIX=\"\" DESTDIR=$out make install wrapProgram $out/bin/profile-cleaner \ - --prefix PATH : "${lib.makeBinPath [ parallel sqlite bc file ]}" + --prefix PATH : "${ + lib.makeBinPath [ + parallel + sqlite + bc + file + ] + }" ''; meta = { diff --git a/pkgs/by-name/pr/profile-sync-daemon/package.nix b/pkgs/by-name/pr/profile-sync-daemon/package.nix index 20b6c1aed36651..100848d523ab6d 100644 --- a/pkgs/by-name/pr/profile-sync-daemon/package.nix +++ b/pkgs/by-name/pr/profile-sync-daemon/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, util-linux, coreutils }: +{ + lib, + stdenv, + fetchFromGitHub, + util-linux, + coreutils, +}: stdenv.mkDerivation rec { pname = "profile-sync-daemon"; diff --git a/pkgs/by-name/pr/proggyfonts/package.nix b/pkgs/by-name/pr/proggyfonts/package.nix index 919cdf2a3dce34..046798a444aac7 100644 --- a/pkgs/by-name/pr/proggyfonts/package.nix +++ b/pkgs/by-name/pr/proggyfonts/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, mkfontscale }: +{ + lib, + stdenv, + fetchurl, + mkfontscale, +}: stdenv.mkDerivation rec { pname = "proggyfonts"; diff --git a/pkgs/by-name/pr/programmer-calculator/package.nix b/pkgs/by-name/pr/programmer-calculator/package.nix index cc418feb763ddb..75c4b15b7c120a 100644 --- a/pkgs/by-name/pr/programmer-calculator/package.nix +++ b/pkgs/by-name/pr/programmer-calculator/package.nix @@ -1,4 +1,9 @@ -{ lib, gccStdenv, fetchFromGitHub, ncurses }: +{ + lib, + gccStdenv, + fetchFromGitHub, + ncurses, +}: gccStdenv.mkDerivation rec { pname = "programmer-calculator"; diff --git a/pkgs/by-name/pr/progress/package.nix b/pkgs/by-name/pr/progress/package.nix index 063d4d122acb41..ec6d2916fdd6bf 100644 --- a/pkgs/by-name/pr/progress/package.nix +++ b/pkgs/by-name/pr/progress/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, ncurses, which }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + ncurses, + which, +}: stdenv.mkDerivation rec { pname = "progress"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-riewkageSZIlwDNMjYep9Pb2q1GJ+WMXazokJGbb4bE="; }; - nativeBuildInputs = [ pkg-config which ]; + nativeBuildInputs = [ + pkg-config + which + ]; buildInputs = [ ncurses ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/pr/proj-datumgrid/package.nix b/pkgs/by-name/pr/proj-datumgrid/package.nix index cfc75ce0c51aa5..a1c7121f017ca2 100644 --- a/pkgs/by-name/pr/proj-datumgrid/package.nix +++ b/pkgs/by-name/pr/proj-datumgrid/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "proj-datumgrid"; diff --git a/pkgs/by-name/pr/projectable/package.nix b/pkgs/by-name/pr/projectable/package.nix index b296e6a7ff1cf1..efd4e42b36f315 100644 --- a/pkgs/by-name/pr/projectable/package.nix +++ b/pkgs/by-name/pr/projectable/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libgit2 -, openssl -, zlib -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libgit2, + openssl, + zlib, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -26,13 +27,15 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - libgit2 - openssl - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreServices - ]; + buildInputs = + [ + libgit2 + openssl + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreServices + ]; env = { LIBGIT2_NO_VENDOR = 1; diff --git a/pkgs/by-name/pr/prometheus-dcgm-exporter/package.nix b/pkgs/by-name/pr/prometheus-dcgm-exporter/package.nix index df9ac3ef4d4147..9c522e558941d2 100644 --- a/pkgs/by-name/pr/prometheus-dcgm-exporter/package.nix +++ b/pkgs/by-name/pr/prometheus-dcgm-exporter/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, autoAddDriverRunpath -, dcgm +{ + lib, + buildGoModule, + fetchFromGitHub, + autoAddDriverRunpath, + dcgm, }: buildGoModule rec { pname = "dcgm-exporter"; diff --git a/pkgs/by-name/pr/prometheus-deluge-exporter/package.nix b/pkgs/by-name/pr/prometheus-deluge-exporter/package.nix index 4adcaf0a747d63..1524f5ee3abf82 100644 --- a/pkgs/by-name/pr/prometheus-deluge-exporter/package.nix +++ b/pkgs/by-name/pr/prometheus-deluge-exporter/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pr/prometheus-dnssec-exporter/package.nix b/pkgs/by-name/pr/prometheus-dnssec-exporter/package.nix index 3f366b789924f8..88a9a7ee313888 100644 --- a/pkgs/by-name/pr/prometheus-dnssec-exporter/package.nix +++ b/pkgs/by-name/pr/prometheus-dnssec-exporter/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub, }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule { pname = "prometheus-dnssec-exporter"; version = "0-unstable-2023-03-05"; @@ -19,4 +23,3 @@ buildGoModule { maintainers = with maintainers; [ swendel ]; }; } - diff --git a/pkgs/by-name/pr/prometheus-frr-exporter/package.nix b/pkgs/by-name/pr/prometheus-frr-exporter/package.nix index 890107dd07f51e..9ed36908c77bea 100644 --- a/pkgs/by-name/pr/prometheus-frr-exporter/package.nix +++ b/pkgs/by-name/pr/prometheus-frr-exporter/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: let version = "1.3.1"; diff --git a/pkgs/by-name/pr/prometheus-node-exporter/package.nix b/pkgs/by-name/pr/prometheus-node-exporter/package.nix index 5f1e9c50cc6bf4..b3be17cd99983d 100644 --- a/pkgs/by-name/pr/prometheus-node-exporter/package.nix +++ b/pkgs/by-name/pr/prometheus-node-exporter/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, nixosTests, darwin }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + nixosTests, + darwin, +}: buildGoModule rec { pname = "node_exporter"; @@ -17,7 +24,13 @@ buildGoModule rec { # FIXME: tests fail due to read-only nix store doCheck = false; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ CoreFoundation IOKit ]); + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + CoreFoundation + IOKit + ] + ); excludedPackages = [ "docs/node-mixin" ]; @@ -39,6 +52,11 @@ buildGoModule rec { homepage = "https://github.com/prometheus/node_exporter"; changelog = "https://github.com/prometheus/node_exporter/blob/v${version}/CHANGELOG.md"; license = licenses.asl20; - maintainers = with maintainers; [ benley fpletz globin Frostman ]; + maintainers = with maintainers; [ + benley + fpletz + globin + Frostman + ]; }; } diff --git a/pkgs/by-name/pr/prometheus-pushgateway/package.nix b/pkgs/by-name/pr/prometheus-pushgateway/package.nix index fde0bab3691619..08210d806f1333 100644 --- a/pkgs/by-name/pr/prometheus-pushgateway/package.nix +++ b/pkgs/by-name/pr/prometheus-pushgateway/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests, testers, prometheus-pushgateway }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, + testers, + prometheus-pushgateway, +}: buildGoModule rec { pname = "pushgateway"; diff --git a/pkgs/by-name/pr/prometheus-restic-exporter/package.nix b/pkgs/by-name/pr/prometheus-restic-exporter/package.nix index d2dc4875282f09..b8cdb0267dcfea 100644 --- a/pkgs/by-name/pr/prometheus-restic-exporter/package.nix +++ b/pkgs/by-name/pr/prometheus-restic-exporter/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, python3 -, restic -, nixosTests +{ + lib, + stdenvNoCC, + fetchFromGitHub, + python3, + restic, + nixosTests, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/pr/prometheus-smartctl-exporter/package.nix b/pkgs/by-name/pr/prometheus-smartctl-exporter/package.nix index 707c8bbb0c1dec..75fdd328cbcfc7 100644 --- a/pkgs/by-name/pr/prometheus-smartctl-exporter/package.nix +++ b/pkgs/by-name/pr/prometheus-smartctl-exporter/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, nixosTests -, smartmontools +{ + lib, + fetchFromGitHub, + buildGoModule, + nixosTests, + smartmontools, }: buildGoModule rec { @@ -35,6 +36,9 @@ buildGoModule rec { homepage = "https://github.com/prometheus-community/smartctl_exporter"; license = licenses.lgpl3; platforms = platforms.linux; - maintainers = with maintainers; [ hexa Frostman ]; + maintainers = with maintainers; [ + hexa + Frostman + ]; }; } diff --git a/pkgs/by-name/pr/prometheus-squid-exporter/package.nix b/pkgs/by-name/pr/prometheus-squid-exporter/package.nix index 0dc4acd2c0bbb0..9073641c66e18e 100644 --- a/pkgs/by-name/pr/prometheus-squid-exporter/package.nix +++ b/pkgs/by-name/pr/prometheus-squid-exporter/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub, }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "squid-exporter"; diff --git a/pkgs/by-name/pr/prometheus-surfboard-exporter/package.nix b/pkgs/by-name/pr/prometheus-surfboard-exporter/package.nix index 780d090f41cff6..bcb3fa0e65e8e0 100644 --- a/pkgs/by-name/pr/prometheus-surfboard-exporter/package.nix +++ b/pkgs/by-name/pr/prometheus-surfboard-exporter/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "surfboard_exporter"; diff --git a/pkgs/by-name/pr/prometheus/package.nix b/pkgs/by-name/pr/prometheus/package.nix index 35ec025212a259..00dd43637f6dc9 100644 --- a/pkgs/by-name/pr/prometheus/package.nix +++ b/pkgs/by-name/pr/prometheus/package.nix @@ -1,33 +1,34 @@ -{ stdenv -, lib -, go -, buildGoModule -, fetchFromGitHub -, fetchurl -, nixosTests -, enableAWS ? true -, enableAzure ? true -, enableConsul ? true -, enableDigitalOcean ? true -, enableDNS ? true -, enableEureka ? true -, enableGCE ? true -, enableHetzner ? true -, enableIONOS ? true -, enableKubernetes ? true -, enableLinode ? true -, enableMarathon ? true -, enableMoby ? true -, enableNomad ? true -, enableOpenstack ? true -, enableOVHCloud ? true -, enablePuppetDB ? true -, enableScaleway ? true -, enableTriton ? true -, enableUyuni ? true -, enableVultr ? true -, enableXDS ? true -, enableZookeeper ? true +{ + stdenv, + lib, + go, + buildGoModule, + fetchFromGitHub, + fetchurl, + nixosTests, + enableAWS ? true, + enableAzure ? true, + enableConsul ? true, + enableDigitalOcean ? true, + enableDNS ? true, + enableEureka ? true, + enableGCE ? true, + enableHetzner ? true, + enableIONOS ? true, + enableKubernetes ? true, + enableLinode ? true, + enableMarathon ? true, + enableMoby ? true, + enableNomad ? true, + enableOpenstack ? true, + enableOVHCloud ? true, + enablePuppetDB ? true, + enableScaleway ? true, + enableTriton ? true, + enableUyuni ? true, + enableVultr ? true, + enableXDS ? true, + enableZookeeper ? true, }: let @@ -41,7 +42,11 @@ buildGoModule rec { pname = "prometheus"; inherit version; - outputs = [ "out" "doc" "cli" ]; + outputs = [ + "out" + "doc" + "cli" + ]; src = fetchFromGitHub { owner = "prometheus"; @@ -52,7 +57,10 @@ buildGoModule rec { vendorHash = "sha256-c96YnWPLH/tbGRb2Zlqrl3PXSZvI+NeYTGlef6REAOw="; - excludedPackages = [ "documentation/prometheus-mixin" "web/ui/mantine-ui/src/promql/tools" ]; + excludedPackages = [ + "documentation/prometheus-mixin" + "web/ui/mantine-ui/src/promql/tools" + ]; postPatch = '' tar -C web/ui -xzf ${webUiStatic} @@ -62,29 +70,29 @@ buildGoModule rec { # Enable only select service discovery to shrink binaries. ( true # prevent bash syntax error when all plugins are disabled - ${lib.optionalString enableAWS "echo - github.com/prometheus/prometheus/discovery/aws"} - ${lib.optionalString enableAzure "echo - github.com/prometheus/prometheus/discovery/azure"} - ${lib.optionalString enableConsul "echo - github.com/prometheus/prometheus/discovery/consul"} + ${lib.optionalString enableAWS "echo - github.com/prometheus/prometheus/discovery/aws"} + ${lib.optionalString enableAzure "echo - github.com/prometheus/prometheus/discovery/azure"} + ${lib.optionalString enableConsul "echo - github.com/prometheus/prometheus/discovery/consul"} ${lib.optionalString enableDigitalOcean "echo - github.com/prometheus/prometheus/discovery/digitalocean"} - ${lib.optionalString enableDNS "echo - github.com/prometheus/prometheus/discovery/dns"} - ${lib.optionalString enableEureka "echo - github.com/prometheus/prometheus/discovery/eureka"} - ${lib.optionalString enableGCE "echo - github.com/prometheus/prometheus/discovery/gce"} - ${lib.optionalString enableHetzner "echo - github.com/prometheus/prometheus/discovery/hetzner"} - ${lib.optionalString enableIONOS "echo - github.com/prometheus/prometheus/discovery/ionos"} - ${lib.optionalString enableKubernetes "echo - github.com/prometheus/prometheus/discovery/kubernetes"} - ${lib.optionalString enableLinode "echo - github.com/prometheus/prometheus/discovery/linode"} - ${lib.optionalString enableMarathon "echo - github.com/prometheus/prometheus/discovery/marathon"} - ${lib.optionalString enableMoby "echo - github.com/prometheus/prometheus/discovery/moby"} - ${lib.optionalString enableNomad "echo - github.com/prometheus/prometheus/discovery/nomad"} - ${lib.optionalString enableOpenstack "echo - github.com/prometheus/prometheus/discovery/openstack"} - ${lib.optionalString enableOVHCloud "echo - github.com/prometheus/prometheus/discovery/ovhcloud"} - ${lib.optionalString enablePuppetDB "echo - github.com/prometheus/prometheus/discovery/puppetdb"} - ${lib.optionalString enableScaleway "echo - github.com/prometheus/prometheus/discovery/scaleway"} - ${lib.optionalString enableTriton "echo - github.com/prometheus/prometheus/discovery/triton"} - ${lib.optionalString enableUyuni "echo - github.com/prometheus/prometheus/discovery/uyuni"} - ${lib.optionalString enableVultr "echo - github.com/prometheus/prometheus/discovery/vultr"} - ${lib.optionalString enableXDS "echo - github.com/prometheus/prometheus/discovery/xds"} - ${lib.optionalString enableZookeeper "echo - github.com/prometheus/prometheus/discovery/zookeeper"} + ${lib.optionalString enableDNS "echo - github.com/prometheus/prometheus/discovery/dns"} + ${lib.optionalString enableEureka "echo - github.com/prometheus/prometheus/discovery/eureka"} + ${lib.optionalString enableGCE "echo - github.com/prometheus/prometheus/discovery/gce"} + ${lib.optionalString enableHetzner "echo - github.com/prometheus/prometheus/discovery/hetzner"} + ${lib.optionalString enableIONOS "echo - github.com/prometheus/prometheus/discovery/ionos"} + ${lib.optionalString enableKubernetes "echo - github.com/prometheus/prometheus/discovery/kubernetes"} + ${lib.optionalString enableLinode "echo - github.com/prometheus/prometheus/discovery/linode"} + ${lib.optionalString enableMarathon "echo - github.com/prometheus/prometheus/discovery/marathon"} + ${lib.optionalString enableMoby "echo - github.com/prometheus/prometheus/discovery/moby"} + ${lib.optionalString enableNomad "echo - github.com/prometheus/prometheus/discovery/nomad"} + ${lib.optionalString enableOpenstack "echo - github.com/prometheus/prometheus/discovery/openstack"} + ${lib.optionalString enableOVHCloud "echo - github.com/prometheus/prometheus/discovery/ovhcloud"} + ${lib.optionalString enablePuppetDB "echo - github.com/prometheus/prometheus/discovery/puppetdb"} + ${lib.optionalString enableScaleway "echo - github.com/prometheus/prometheus/discovery/scaleway"} + ${lib.optionalString enableTriton "echo - github.com/prometheus/prometheus/discovery/triton"} + ${lib.optionalString enableUyuni "echo - github.com/prometheus/prometheus/discovery/uyuni"} + ${lib.optionalString enableVultr "echo - github.com/prometheus/prometheus/discovery/vultr"} + ${lib.optionalString enableXDS "echo - github.com/prometheus/prometheus/discovery/xds"} + ${lib.optionalString enableZookeeper "echo - github.com/prometheus/prometheus/discovery/zookeeper"} ) > plugins.yml ''; @@ -128,6 +136,10 @@ buildGoModule rec { description = "Service monitoring system and time series database"; homepage = "https://prometheus.io"; license = licenses.asl20; - maintainers = with maintainers; [ fpletz willibutz Frostman ]; + maintainers = with maintainers; [ + fpletz + willibutz + Frostman + ]; }; } diff --git a/pkgs/by-name/pr/promexplorer/package.nix b/pkgs/by-name/pr/promexplorer/package.nix index ce4b22bfb34049..7515412585fd65 100644 --- a/pkgs/by-name/pr/promexplorer/package.nix +++ b/pkgs/by-name/pr/promexplorer/package.nix @@ -1,4 +1,8 @@ -{ lib, buildNimPackage, fetchFromGitHub }: +{ + lib, + buildNimPackage, + fetchFromGitHub, +}: buildNimPackage (finalAttrs: { pname = "promexplorer"; version = "0.0.5"; diff --git a/pkgs/by-name/pr/promptfoo/package.nix b/pkgs/by-name/pr/promptfoo/package.nix index 1773bb734d5382..3dda7203bd4e7c 100644 --- a/pkgs/by-name/pr/promptfoo/package.nix +++ b/pkgs/by-name/pr/promptfoo/package.nix @@ -1,6 +1,7 @@ -{ buildNpmPackage -, fetchFromGitHub -, lib +{ + buildNpmPackage, + fetchFromGitHub, + lib, }: buildNpmPackage rec { diff --git a/pkgs/by-name/pr/promql-cli/package.nix b/pkgs/by-name/pr/promql-cli/package.nix index d5188e83f29357..b92927a19f64fe 100644 --- a/pkgs/by-name/pr/promql-cli/package.nix +++ b/pkgs/by-name/pr/promql-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-jhNll04xGaxS6NJTh4spSW9zPrff8jk5OEQiRevPQwU="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' mv -v $out/bin/promql-cli $out/bin/promql diff --git a/pkgs/by-name/pr/promscale/package.nix b/pkgs/by-name/pr/promscale/package.nix index e814132627d749..9c350a7f88661e 100644 --- a/pkgs/by-name/pr/promscale/package.nix +++ b/pkgs/by-name/pr/promscale/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, promscale -, testers +{ + lib, + buildGoModule, + fetchFromGitHub, + promscale, + testers, }: buildGoModule rec { @@ -51,6 +52,9 @@ buildGoModule rec { homepage = "https://github.com/timescale/promscale"; changelog = "https://github.com/timescale/promscale/blob/${version}/CHANGELOG.md"; license = licenses.asl20; - maintainers = with maintainers; [ _0x4A6F anpin ]; + maintainers = with maintainers; [ + _0x4A6F + anpin + ]; }; } diff --git a/pkgs/by-name/pr/proot/package.nix b/pkgs/by-name/pr/proot/package.nix index adcbb1de9d2a9e..b3fb0a36629dc2 100644 --- a/pkgs/by-name/pr/proot/package.nix +++ b/pkgs/by-name/pr/proot/package.nix @@ -1,8 +1,16 @@ -{ lib, stdenv, fetchFromGitHub -, talloc -, pkg-config -, ncurses -, docutils, swig, python3, coreutils, enablePython ? true }: +{ + lib, + stdenv, + fetchFromGitHub, + talloc, + pkg-config, + ncurses, + docutils, + swig, + python3, + coreutils, + enablePython ? true, +}: stdenv.mkDerivation rec { pname = "proot"; @@ -22,8 +30,14 @@ stdenv.mkDerivation rec { sed -i /CROSS_COMPILE/d src/GNUmakefile ''; - buildInputs = [ ncurses talloc ] ++ lib.optional enablePython python3; - nativeBuildInputs = [ pkg-config docutils ] ++ lib.optional enablePython swig; + buildInputs = [ + ncurses + talloc + ] ++ lib.optional enablePython python3; + nativeBuildInputs = [ + pkg-config + docutils + ] ++ lib.optional enablePython swig; enableParallelBuilding = true; @@ -47,7 +61,11 @@ stdenv.mkDerivation rec { description = "User-space implementation of chroot, mount --bind and binfmt_misc"; platforms = platforms.linux; license = licenses.gpl2Plus; - maintainers = with maintainers; [ ianwookim makefu veprbl ]; + maintainers = with maintainers; [ + ianwookim + makefu + veprbl + ]; mainProgram = "proot"; }; } diff --git a/pkgs/by-name/pr/properties-cpp/package.nix b/pkgs/by-name/pr/properties-cpp/package.nix index 2c510afdfa1586..887c1e2eeec907 100644 --- a/pkgs/by-name/pr/properties-cpp/package.nix +++ b/pkgs/by-name/pr/properties-cpp/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitLab -, gitUpdater -, testers -, cmake -, pkg-config -, gtest -, doxygen -, graphviz -, lomiri +{ + lib, + stdenv, + fetchFromGitLab, + gitUpdater, + testers, + cmake, + pkg-config, + gtest, + doxygen, + graphviz, + lomiri, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pr/prosody-filer/package.nix b/pkgs/by-name/pr/prosody-filer/package.nix index 0f8530215dbfdf..24abc41e7ee3f5 100644 --- a/pkgs/by-name/pr/prosody-filer/package.nix +++ b/pkgs/by-name/pr/prosody-filer/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "prosody-filer"; diff --git a/pkgs/by-name/pr/protege-distribution/package.nix b/pkgs/by-name/pr/protege-distribution/package.nix index 3aa234b406bde9..b01313b4cddc16 100644 --- a/pkgs/by-name/pr/protege-distribution/package.nix +++ b/pkgs/by-name/pr/protege-distribution/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, unzip -, jdk11 -, copyDesktopItems -, iconConvTools -, makeDesktopItem -, makeWrapper +{ + lib, + stdenv, + fetchurl, + unzip, + jdk11, + copyDesktopItems, + iconConvTools, + makeDesktopItem, + makeWrapper, }: stdenv.mkDerivation rec { @@ -76,7 +77,12 @@ stdenv.mkDerivation rec { homepage = "https://protege.stanford.edu/"; downloadPage = "https://protege.stanford.edu/products.php#desktop-protege"; maintainers = with maintainers; [ nessdoor ]; - license = with licenses; [ asl20 bsd2 epl10 lgpl3 ]; + license = with licenses; [ + asl20 + bsd2 + epl10 + lgpl3 + ]; platforms = platforms.linux; mainProgram = "run-protege"; }; diff --git a/pkgs/by-name/pr/protege/package.nix b/pkgs/by-name/pr/protege/package.nix index efb34e4def488b..4ef2318e150d55 100644 --- a/pkgs/by-name/pr/protege/package.nix +++ b/pkgs/by-name/pr/protege/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, copyDesktopItems -, iconConvTools -, makeDesktopItem -, makeWrapper -, jdk11 -, maven +{ + lib, + fetchFromGitHub, + copyDesktopItems, + iconConvTools, + makeDesktopItem, + makeWrapper, + jdk11, + maven, }: maven.buildMavenPackage rec { @@ -86,6 +87,9 @@ maven.buildMavenPackage rec { # will leave the task to someone who has the right tools and knowledge. platforms = lib.platforms.unix; mainProgram = "protege"; - sourceProvenance = with lib.sourceTypes; [ fromSource binaryBytecode ]; + sourceProvenance = with lib.sourceTypes; [ + fromSource + binaryBytecode + ]; }; } diff --git a/pkgs/by-name/pr/proteus/package.nix b/pkgs/by-name/pr/proteus/package.nix index ab2bdae4ef0fc0..c3d77453260679 100644 --- a/pkgs/by-name/pr/proteus/package.nix +++ b/pkgs/by-name/pr/proteus/package.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, autoPatchelfHook, cmake, pkg-config -, alsa-lib, freetype, libjack2 -, libX11, libXext, libXcursor, libXinerama, libXrandr, libXrender +{ + lib, + stdenv, + fetchFromGitHub, + autoPatchelfHook, + cmake, + pkg-config, + alsa-lib, + freetype, + libjack2, + libX11, + libXext, + libXcursor, + libXinerama, + libXrandr, + libXrender, }: stdenv.mkDerivation rec { @@ -15,10 +28,21 @@ stdenv.mkDerivation rec { hash = "sha256-WhJh+Sx64JYxQQ1LXpDUwXeodFU1EZ0TmMhn+6w0hQg="; }; - nativeBuildInputs = [ autoPatchelfHook cmake pkg-config ]; + nativeBuildInputs = [ + autoPatchelfHook + cmake + pkg-config + ]; buildInputs = [ - alsa-lib freetype libjack2 - libX11 libXext libXcursor libXinerama libXrandr libXrender + alsa-lib + freetype + libjack2 + libX11 + libXext + libXcursor + libXinerama + libXrandr + libXrender ]; # JUCE loads most dependencies at runtime: runtimeDependencies = map lib.getLib buildInputs; diff --git a/pkgs/by-name/pr/proto-contrib/package.nix b/pkgs/by-name/pr/proto-contrib/package.nix index 5437fd11345ac6..0581335fe17fec 100644 --- a/pkgs/by-name/pr/proto-contrib/package.nix +++ b/pkgs/by-name/pr/proto-contrib/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "proto-contrib"; diff --git a/pkgs/by-name/pr/proto/package.nix b/pkgs/by-name/pr/proto/package.nix index 1b737f49efba36..bfb2b24def177e 100644 --- a/pkgs/by-name/pr/proto/package.nix +++ b/pkgs/by-name/pr/proto/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, darwin -, libiconv -, makeBinaryWrapper -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, + libiconv, + makeBinaryWrapper, + pkg-config, }: rustPlatform.buildRustPackage rec { @@ -25,11 +26,17 @@ rustPlatform.buildRustPackage rec { darwin.apple_sdk.frameworks.SystemConfiguration libiconv ]; - nativeBuildInputs = [ makeBinaryWrapper pkg-config ]; + nativeBuildInputs = [ + makeBinaryWrapper + pkg-config + ]; # Tests requires network access doCheck = false; - cargoBuildFlags = [ "--bin proto" "--bin proto-shim" ]; + cargoBuildFlags = [ + "--bin proto" + "--bin proto-shim" + ]; postInstall = '' # proto looks up a proto-shim executable file in $PROTO_LOOKUP_DIR diff --git a/pkgs/by-name/pr/protobufc/package.nix b/pkgs/by-name/pr/protobufc/package.nix index 7681c5b2591c06..62c55c8bd62f94 100644 --- a/pkgs/by-name/pr/protobufc/package.nix +++ b/pkgs/by-name/pr/protobufc/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, protobuf_25 -, zlib -, buildPackages +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + protobuf_25, + zlib, + buildPackages, }: stdenv.mkDerivation rec { @@ -19,11 +20,21 @@ stdenv.mkDerivation rec { hash = "sha256-Dkpcc7ZfvAIVY91trRiHuiRFcUGUbQxbheYKTBcq80I="; }; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ protobuf_25 zlib ]; + buildInputs = [ + protobuf_25 + zlib + ]; env.PROTOC = lib.getExe buildPackages.protobuf_25; diff --git a/pkgs/by-name/pr/protoc-gen-connect-go/package.nix b/pkgs/by-name/pr/protoc-gen-connect-go/package.nix index 36a5bb15e35c40..0e1ecdc6c1f1bd 100644 --- a/pkgs/by-name/pr/protoc-gen-connect-go/package.nix +++ b/pkgs/by-name/pr/protoc-gen-connect-go/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -31,6 +32,9 @@ buildGoModule rec { homepage = "https://github.com/connectrpc/connect-go"; changelog = "https://github.com/connectrpc/connect-go/releases/tag/v${version}"; license = licenses.asl20; - maintainers = with maintainers; [ kilimnik jk ]; + maintainers = with maintainers; [ + kilimnik + jk + ]; }; } diff --git a/pkgs/by-name/pr/protoc-gen-doc/package.nix b/pkgs/by-name/pr/protoc-gen-doc/package.nix index 09eb0a057aeed5..0b9d1bc03165a3 100644 --- a/pkgs/by-name/pr/protoc-gen-doc/package.nix +++ b/pkgs/by-name/pr/protoc-gen-doc/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "protoc-gen-doc"; diff --git a/pkgs/by-name/pr/protoc-gen-entgrpc/package.nix b/pkgs/by-name/pr/protoc-gen-entgrpc/package.nix index b4751caa883a20..f7eed9ab1c33f6 100644 --- a/pkgs/by-name/pr/protoc-gen-entgrpc/package.nix +++ b/pkgs/by-name/pr/protoc-gen-entgrpc/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "protoc-gen-entgrpc"; @@ -15,7 +19,10 @@ buildGoModule rec { subPackages = [ "entproto/cmd/protoc-gen-entgrpc" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Generator of an implementation of the service interface for ent protobuff"; @@ -26,4 +33,3 @@ buildGoModule rec { maintainers = [ ]; }; } - diff --git a/pkgs/by-name/pr/protoc-gen-go-grpc/package.nix b/pkgs/by-name/pr/protoc-gen-go-grpc/package.nix index 863b82f3f791af..271a77e832f512 100644 --- a/pkgs/by-name/pr/protoc-gen-go-grpc/package.nix +++ b/pkgs/by-name/pr/protoc-gen-go-grpc/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/pr/protoc-gen-go-vtproto/package.nix b/pkgs/by-name/pr/protoc-gen-go-vtproto/package.nix index 11764e7e8e3c31..0c39bb857a4f66 100644 --- a/pkgs/by-name/pr/protoc-gen-go-vtproto/package.nix +++ b/pkgs/by-name/pr/protoc-gen-go-vtproto/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { pname = "protoc-gen-go-vtproto"; diff --git a/pkgs/by-name/pr/protoc-gen-go/package.nix b/pkgs/by-name/pr/protoc-gen-go/package.nix index 19618f41323e8d..d375813c454326 100644 --- a/pkgs/by-name/pr/protoc-gen-go/package.nix +++ b/pkgs/by-name/pr/protoc-gen-go/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "protoc-gen-go"; diff --git a/pkgs/by-name/pr/protoc-gen-rust-grpc/package.nix b/pkgs/by-name/pr/protoc-gen-rust-grpc/package.nix index 3aefd22b8c676b..53fbba4b13131c 100644 --- a/pkgs/by-name/pr/protoc-gen-rust-grpc/package.nix +++ b/pkgs/by-name/pr/protoc-gen-rust-grpc/package.nix @@ -1,4 +1,8 @@ -{ fetchCrate, lib, rustPlatform }: +{ + fetchCrate, + lib, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "protoc-gen-rust-grpc"; diff --git a/pkgs/by-name/pr/protoc-gen-rust/package.nix b/pkgs/by-name/pr/protoc-gen-rust/package.nix index 72b8652bf826a5..d103460cee90a3 100644 --- a/pkgs/by-name/pr/protoc-gen-rust/package.nix +++ b/pkgs/by-name/pr/protoc-gen-rust/package.nix @@ -1,7 +1,8 @@ -{ fetchCrate -, lib -, rustPlatform -, protobuf +{ + fetchCrate, + lib, + rustPlatform, + protobuf, }: rustPlatform.buildRustPackage rec { @@ -16,7 +17,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-RO3kVYkvHw8kwLaRfANtGtz88knjJ8HtmU3i0xgIDMY="; - cargoBuildFlags = ["--bin" pname]; + cargoBuildFlags = [ + "--bin" + pname + ]; nativeBuildInputs = [ protobuf ]; diff --git a/pkgs/by-name/pr/protoc-gen-twirp/package.nix b/pkgs/by-name/pr/protoc-gen-twirp/package.nix index 4f59af22d6e9c1..a1072f95780068 100644 --- a/pkgs/by-name/pr/protoc-gen-twirp/package.nix +++ b/pkgs/by-name/pr/protoc-gen-twirp/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "protoc-gen-twirp"; diff --git a/pkgs/by-name/pr/protoc-gen-twirp_php/package.nix b/pkgs/by-name/pr/protoc-gen-twirp_php/package.nix index 5d12aa44beace0..7fb1401a37aa50 100644 --- a/pkgs/by-name/pr/protoc-gen-twirp_php/package.nix +++ b/pkgs/by-name/pr/protoc-gen-twirp_php/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchgit }: +{ + lib, + buildGoModule, + fetchgit, +}: buildGoModule rec { pname = "protoc-gen-twirp_php"; diff --git a/pkgs/by-name/pr/protoc-gen-twirp_swagger/package.nix b/pkgs/by-name/pr/protoc-gen-twirp_swagger/package.nix index 1445f60f676fbc..b62de34b0ae40f 100644 --- a/pkgs/by-name/pr/protoc-gen-twirp_swagger/package.nix +++ b/pkgs/by-name/pr/protoc-gen-twirp_swagger/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule { pname = "protoc-gen-twirp_swagger"; diff --git a/pkgs/by-name/pr/protoc-gen-twirp_typescript/package.nix b/pkgs/by-name/pr/protoc-gen-twirp_typescript/package.nix index 340b21784712be..cf4ed6f0253ed2 100644 --- a/pkgs/by-name/pr/protoc-gen-twirp_typescript/package.nix +++ b/pkgs/by-name/pr/protoc-gen-twirp_typescript/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule { pname = "protoc-gen-twirp_typescript"; @@ -21,6 +25,9 @@ buildGoModule { mainProgram = "protoc-gen-twirp_typescript"; homepage = "https://github.com/larrymyers/protoc-gen-twirp_typescript"; license = licenses.mit; - maintainers = with maintainers; [ jojosch dgollings ]; + maintainers = with maintainers; [ + jojosch + dgollings + ]; }; } diff --git a/pkgs/by-name/pr/protoc-gen-validate/package.nix b/pkgs/by-name/pr/protoc-gen-validate/package.nix index b8266c6f223b43..2fedd5b4992fcf 100644 --- a/pkgs/by-name/pr/protoc-gen-validate/package.nix +++ b/pkgs/by-name/pr/protoc-gen-validate/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "protoc-gen-validate"; diff --git a/pkgs/by-name/pr/protoc-go-inject-tag/package.nix b/pkgs/by-name/pr/protoc-go-inject-tag/package.nix index cddd70559d9125..5d6d1cc8330d1f 100644 --- a/pkgs/by-name/pr/protoc-go-inject-tag/package.nix +++ b/pkgs/by-name/pr/protoc-go-inject-tag/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "protoc-go-inject-tag"; @@ -19,7 +20,7 @@ buildGoModule rec { description = "Inject custom tags to protobuf golang struct"; homepage = "https://github.com/favadi/protoc-go-inject-tag/tree/v1.4.0"; license = licenses.bsd2; - maintainers = with maintainers; [elrohirgt]; + maintainers = with maintainers; [ elrohirgt ]; mainProgram = "protoc-go-inject-tag"; }; } diff --git a/pkgs/by-name/pr/protocol/package.nix b/pkgs/by-name/pr/protocol/package.nix index 15067e2d9ab2e1..6d79950358750e 100644 --- a/pkgs/by-name/pr/protocol/package.nix +++ b/pkgs/by-name/pr/protocol/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pr/protolint/package.nix b/pkgs/by-name/pr/protolint/package.nix index 1df3383d153054..620964b440e5d5 100644 --- a/pkgs/by-name/pr/protolint/package.nix +++ b/pkgs/by-name/pr/protolint/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "protolint"; version = "0.51.0"; @@ -20,14 +24,16 @@ buildGoModule rec { # util_test.go:35: open : no such file or directory excludedPackages = [ "internal" ]; - ldflags = let - rev = builtins.substring 0 7 src.rev; - in [ - "-X github.com/yoheimuta/protolint/internal/cmd.version=${version}" - "-X github.com/yoheimuta/protolint/internal/cmd.revision=${rev}" - "-X github.com/yoheimuta/protolint/internal/cmd/protocgenprotolint.version=${version}" - "-X github.com/yoheimuta/protolint/internal/cmd/protocgenprotolint.revision=${rev}" - ]; + ldflags = + let + rev = builtins.substring 0 7 src.rev; + in + [ + "-X github.com/yoheimuta/protolint/internal/cmd.version=${version}" + "-X github.com/yoheimuta/protolint/internal/cmd.revision=${rev}" + "-X github.com/yoheimuta/protolint/internal/cmd/protocgenprotolint.version=${version}" + "-X github.com/yoheimuta/protolint/internal/cmd/protocgenprotolint.revision=${rev}" + ]; meta = with lib; { description = "Pluggable linter and fixer to enforce Protocol Buffer style and conventions"; diff --git a/pkgs/by-name/pr/protolock/package.nix b/pkgs/by-name/pr/protolock/package.nix index f8483eb5d68b35..663219e3e71981 100644 --- a/pkgs/by-name/pr/protolock/package.nix +++ b/pkgs/by-name/pr/protolock/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "protolock"; diff --git a/pkgs/by-name/pr/proton-caller/package.nix b/pkgs/by-name/pr/proton-caller/package.nix index e0fd948eb86668..354181609e1a67 100644 --- a/pkgs/by-name/pr/proton-caller/package.nix +++ b/pkgs/by-name/pr/proton-caller/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "proton-caller"; diff --git a/pkgs/by-name/pr/protonmail-bridge-gui/package.nix b/pkgs/by-name/pr/protonmail-bridge-gui/package.nix index 3cb289b6142694..3d159ffb6459f0 100644 --- a/pkgs/by-name/pr/protonmail-bridge-gui/package.nix +++ b/pkgs/by-name/pr/protonmail-bridge-gui/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, pkg-config -, libsecret -, cmake -, ninja -, qt6 -, grpc -, protobuf -, zlib -, gtest -, sentry-native -, protonmail-bridge +{ + lib, + stdenv, + pkg-config, + libsecret, + cmake, + ninja, + qt6, + grpc, + protobuf, + zlib, + gtest, + sentry-native, + protonmail-bridge, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pr/protonmail-bridge/package.nix b/pkgs/by-name/pr/protonmail-bridge/package.nix index dcc926174838d6..295ecf3a608eb6 100644 --- a/pkgs/by-name/pr/protonmail-bridge/package.nix +++ b/pkgs/by-name/pr/protonmail-bridge/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, pkg-config, libsecret }: +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + libsecret, +}: buildGoModule rec { pname = "protonmail-bridge"; @@ -23,7 +29,9 @@ buildGoModule rec { ''; ldflags = - let constants = "github.com/ProtonMail/proton-bridge/v3/internal/constants"; in + let + constants = "github.com/ProtonMail/proton-bridge/v3/internal/constants"; + in [ "-X ${constants}.Version=${version}" "-X ${constants}.Revision=${src.rev}" @@ -52,6 +60,9 @@ buildGoModule rec { To work, use secret-service freedesktop.org API (e.g. Gnome keyring) or pass. ''; mainProgram = "protonmail-bridge"; - maintainers = with lib.maintainers; [ mrfreezeex daniel-fahey ]; + maintainers = with lib.maintainers; [ + mrfreezeex + daniel-fahey + ]; }; } diff --git a/pkgs/by-name/pr/protoscope/package.nix b/pkgs/by-name/pr/protoscope/package.nix index 98ebbc995617a4..28e3176a1c7855 100644 --- a/pkgs/by-name/pr/protoscope/package.nix +++ b/pkgs/by-name/pr/protoscope/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "protoscope"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-mK8eGo6oembs4nofvROn4g0+oO5E5/zQrmPKMe3xXik="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Simple, human-editable language for representing and emitting the Protobuf wire format"; diff --git a/pkgs/by-name/pr/prototool/package.nix b/pkgs/by-name/pr/prototool/package.nix index c65dad2bb717ff..211c86bd7c0724 100644 --- a/pkgs/by-name/pr/prototool/package.nix +++ b/pkgs/by-name/pr/prototool/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, makeWrapper, protobuf }: +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + protobuf, +}: buildGoModule rec { pname = "prototool"; diff --git a/pkgs/by-name/pr/prototypejs/package.nix b/pkgs/by-name/pr/prototypejs/package.nix index b3ded7025e99cf..7f6257aeb40428 100644 --- a/pkgs/by-name/pr/prototypejs/package.nix +++ b/pkgs/by-name/pr/prototypejs/package.nix @@ -1,7 +1,8 @@ { lib, fetchurl, ... }: let version = "1.7.3.0"; -in fetchurl { +in +fetchurl { name = "prototype-${version}.js"; url = "https://ajax.googleapis.com/ajax/libs/prototype/${version}/prototype.js"; sha256 = "0q43vvrsb22h4jvavs1gk3v4ps61yx9k85b5n6q9mxivhmxprg26"; diff --git a/pkgs/by-name/pr/protox/package.nix b/pkgs/by-name/pr/protox/package.nix index d8375a87867665..5821c574c74796 100644 --- a/pkgs/by-name/pr/protox/package.nix +++ b/pkgs/by-name/pr/protox/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -24,7 +25,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "protox"; homepage = "https://github.com/andrewhickman/protox"; changelog = "https://github.com/andrewhickman/protox/blob/${version}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/pr/protozero/package.nix b/pkgs/by-name/pr/protozero/package.nix index ed3e67fdeed103..708a61d65c5019 100644 --- a/pkgs/by-name/pr/protozero/package.nix +++ b/pkgs/by-name/pr/protozero/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "protozero"; @@ -16,7 +21,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Minimalistic protocol buffer decoder and encoder in C++"; homepage = "https://github.com/mapbox/protozero"; - license = with licenses; [ bsd2 asl20 ]; + license = with licenses; [ + bsd2 + asl20 + ]; changelog = [ "https://github.com/mapbox/protozero/releases/tag/v${version}" "https://github.com/mapbox/protozero/blob/v${version}/CHANGELOG.md" diff --git a/pkgs/by-name/pr/prover9/package.nix b/pkgs/by-name/pr/prover9/package.nix index a82e44c8a5109d..ddf47d74d4cae8 100644 --- a/pkgs/by-name/pr/prover9/package.nix +++ b/pkgs/by-name/pr/prover9/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "prover9"; diff --git a/pkgs/by-name/pr/proverif/package.nix b/pkgs/by-name/pr/proverif/package.nix index 5cd0e5ff9e39ff..7addcf4008b596 100644 --- a/pkgs/by-name/pr/proverif/package.nix +++ b/pkgs/by-name/pr/proverif/package.nix @@ -1,17 +1,25 @@ -{ lib, stdenv, fetchurl, ocamlPackages }: +{ + lib, + stdenv, + fetchurl, + ocamlPackages, +}: stdenv.mkDerivation rec { pname = "proverif"; version = "2.05"; src = fetchurl { - url = "https://bblanche.gitlabpages.inria.fr/proverif/proverif${version}.tar.gz"; + url = "https://bblanche.gitlabpages.inria.fr/proverif/proverif${version}.tar.gz"; hash = "sha256-SHH1PDKrSgRmmgYMSIa6XZCASWlj+5gKmmLSxCnOq8Q="; }; strictDeps = true; - nativeBuildInputs = with ocamlPackages; [ ocaml findlib ]; + nativeBuildInputs = with ocamlPackages; [ + ocaml + findlib + ]; buildPhase = "./build -nointeract"; installPhase = '' @@ -23,9 +31,12 @@ stdenv.mkDerivation rec { meta = { description = "Cryptographic protocol verifier in the formal model"; - homepage = "https://bblanche.gitlabpages.inria.fr/proverif/"; - license = lib.licenses.gpl2; - platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ thoughtpolice vbgl ]; + homepage = "https://bblanche.gitlabpages.inria.fr/proverif/"; + license = lib.licenses.gpl2; + platforms = lib.platforms.unix; + maintainers = with lib.maintainers; [ + thoughtpolice + vbgl + ]; }; } diff --git a/pkgs/by-name/pr/prox/package.nix b/pkgs/by-name/pr/prox/package.nix index 7f3713364196ab..adc0751adb2de6 100644 --- a/pkgs/by-name/pr/prox/package.nix +++ b/pkgs/by-name/pr/prox/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/pr/proxify/package.nix b/pkgs/by-name/pr/proxify/package.nix index bf307f366a3742..a3cc3927aed35f 100644 --- a/pkgs/by-name/pr/proxify/package.nix +++ b/pkgs/by-name/pr/proxify/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/pr/proximity-sort/package.nix b/pkgs/by-name/pr/proximity-sort/package.nix index 3b0f1ca5be3d50..fff76ceda5680c 100644 --- a/pkgs/by-name/pr/proximity-sort/package.nix +++ b/pkgs/by-name/pr/proximity-sort/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "proximity-sort"; @@ -16,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Simple command-line utility for sorting inputs by proximity to a path argument"; homepage = "https://github.com/jonhoo/proximity-sort"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "proximity-sort"; }; diff --git a/pkgs/by-name/pr/proxmove/package.nix b/pkgs/by-name/pr/proxmove/package.nix index 0d7dbbbbb9b089..8007f2a7787436 100644 --- a/pkgs/by-name/pr/proxmove/package.nix +++ b/pkgs/by-name/pr/proxmove/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pr/proxmox-backup-client/package.nix b/pkgs/by-name/pr/proxmox-backup-client/package.nix index fde70e9a8f9ab9..c6cde45e985922 100644 --- a/pkgs/by-name/pr/proxmox-backup-client/package.nix +++ b/pkgs/by-name/pr/proxmox-backup-client/package.nix @@ -1,20 +1,21 @@ -{ lib -, fetchgit -, rustPlatform -, pkg-config -, pkgconf -, openssl -, fuse3 -, libuuid -, acl -, libxcrypt -, git -, installShellFiles -, sphinx -, stdenv -, fetchpatch -, testers -, proxmox-backup-client +{ + lib, + fetchgit, + rustPlatform, + pkg-config, + pkgconf, + openssl, + fuse3, + libuuid, + acl, + libxcrypt, + git, + installShellFiles, + sphinx, + stdenv, + fetchpatch, + testers, + proxmox-backup-client, }: let @@ -137,8 +138,21 @@ rustPlatform.buildRustPackage { doCheck = false; - nativeBuildInputs = [ git pkg-config pkgconf rustPlatform.bindgenHook installShellFiles sphinx ]; - buildInputs = [ openssl fuse3 libuuid acl libxcrypt ]; + nativeBuildInputs = [ + git + pkg-config + pkgconf + rustPlatform.bindgenHook + installShellFiles + sphinx + ]; + buildInputs = [ + openssl + fuse3 + libuuid + acl + libxcrypt + ]; passthru.tests.version = testers.testVersion { package = proxmox-backup-client; @@ -150,7 +164,10 @@ rustPlatform.buildRustPackage { homepage = "https://pbs.proxmox.com/docs/backup-client.html"; changelog = "https://git.proxmox.com/?p=proxmox-backup.git;a=blob;f=debian/changelog;hb=refs/tags/v${version}"; license = licenses.agpl3Only; - maintainers = with maintainers; [ cofob christoph-heiss ]; + maintainers = with maintainers; [ + cofob + christoph-heiss + ]; platforms = platforms.linux; mainProgram = "proxmox-backup-client"; }; diff --git a/pkgs/by-name/pr/proxychains-ng/package.nix b/pkgs/by-name/pr/proxychains-ng/package.nix index 64e3bb57c4ac98..96d5269f07f6fa 100644 --- a/pkgs/by-name/pr/proxychains-ng/package.nix +++ b/pkgs/by-name/pr/proxychains-ng/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pr/proxychains/package.nix b/pkgs/by-name/pr/proxychains/package.nix index e78b1b0fcd6c6a..04b472fc659b90 100644 --- a/pkgs/by-name/pr/proxychains/package.nix +++ b/pkgs/by-name/pr/proxychains/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pr/proxysql/package.nix b/pkgs/by-name/pr/proxysql/package.nix index ed04908180eeb2..edf8d11267dd43 100644 --- a/pkgs/by-name/pr/proxysql/package.nix +++ b/pkgs/by-name/pr/proxysql/package.nix @@ -1,33 +1,34 @@ -{ stdenv -, lib -, applyPatches -, fetchFromGitHub -, autoconf -, automake -, bison -, cmake -, libtool -, civetweb -, coreutils -, curl -, flex -, gnutls -, libconfig -, libdaemon -, libev -, libgcrypt -, libinjection -, libmicrohttpd -, libuuid -, lz4 -, nlohmann_json -, openssl -, pcre -, perl -, python3 -, prometheus-cpp -, zlib -, texinfo +{ + stdenv, + lib, + applyPatches, + fetchFromGitHub, + autoconf, + automake, + bison, + cmake, + libtool, + civetweb, + coreutils, + curl, + flex, + gnutls, + libconfig, + libdaemon, + libev, + libgcrypt, + libinjection, + libmicrohttpd, + libuuid, + lz4, + nlohmann_json, + openssl, + pcre, + perl, + python3, + prometheus-cpp, + zlib, + texinfo, }: stdenv.mkDerivation (finalAttrs: { @@ -53,7 +54,7 @@ stdenv.mkDerivation (finalAttrs: { libtool perl python3 - texinfo # for makeinfo + texinfo # for makeinfo ]; buildInputs = [ @@ -73,87 +74,127 @@ stdenv.mkDerivation (finalAttrs: { dontConfigure = true; # replace and fix some vendored dependencies - preBuild = /* sh */ '' - pushd deps - - function replace_dep() { - local folder="$1" - local src="$2" - local symlink="$3" - local name="$4" - - pushd "$folder" - - rm -rf "$symlink" - if [ -d "$src" ]; then - cp -R "$src"/. "$symlink" - chmod -R u+w "$symlink" - else - tar xf "$src" - ln -s "$name" "$symlink" - fi + preBuild = # sh + '' + pushd deps + + function replace_dep() { + local folder="$1" + local src="$2" + local symlink="$3" + local name="$4" + + pushd "$folder" + + rm -rf "$symlink" + if [ -d "$src" ]; then + cp -R "$src"/. "$symlink" + chmod -R u+w "$symlink" + else + tar xf "$src" + ln -s "$name" "$symlink" + fi + + popd + } + + ${lib.concatMapStringsSep "\n" + ( + x: + ''replace_dep "${x.f}" "${x.p.src}" "${ + x.p.pname or (builtins.parseDrvName x.p.name).name + }" "${x.p.name}"'' + ) + ( + map + (x: { + inherit (x) f; + p = x.p // { + src = applyPatches { + inherit (x.p) src patches; + }; + }; + }) + [ + { + f = "curl"; + p = curl; + } + { + f = "libconfig"; + p = libconfig; + } + { + f = "libdaemon"; + p = libdaemon; + } + { + f = "libev"; + p = libev; + } + { + f = "libinjection"; + p = libinjection; + } + { + f = "libmicrohttpd"; + p = libmicrohttpd; + } + { + f = "libssl"; + p = openssl; + } + { + f = "lz4"; + p = lz4; + } + { + f = "pcre"; + p = pcre; + } + { + f = "prometheus-cpp"; + p = prometheus-cpp; + } + ] + ) + } + + pushd libhttpserver + tar xf libhttpserver-*.tar.gz + sed -i s_/bin/pwd_${coreutils}/bin/pwd_g libhttpserver/configure.ac + popd + pushd json + rm json.hpp + ln -s ${nlohmann_json.src}/single_include/nlohmann/json.hpp . popd - } - - ${lib.concatMapStringsSep "\n" - (x: ''replace_dep "${x.f}" "${x.p.src}" "${x.p.pname or (builtins.parseDrvName x.p.name).name}" "${x.p.name}"'') ( - map (x: { - inherit (x) f; - p = x.p // { - src = applyPatches { - inherit (x.p) src patches; - }; - }; - }) [ - { f = "curl"; p = curl; } - { f = "libconfig"; p = libconfig; } - { f = "libdaemon"; p = libdaemon; } - { f = "libev"; p = libev; } - { f = "libinjection"; p = libinjection; } - { f = "libmicrohttpd"; p = libmicrohttpd; } - { f = "libssl"; p = openssl; } - { f = "lz4"; p = lz4; } - { f = "pcre"; p = pcre; } - { f = "prometheus-cpp"; p = prometheus-cpp; } - ] - )} - - pushd libhttpserver - tar xf libhttpserver-*.tar.gz - sed -i s_/bin/pwd_${coreutils}/bin/pwd_g libhttpserver/configure.ac - popd - - pushd json - rm json.hpp - ln -s ${nlohmann_json.src}/single_include/nlohmann/json.hpp . - popd - - pushd prometheus-cpp/prometheus-cpp/3rdparty - replace_dep . "${civetweb.src}" civetweb - popd - - sed -i s_/usr/bin/env_${coreutils}/bin/env_g libssl/openssl/config - - pushd libmicrohttpd/libmicrohttpd - autoreconf - popd - - pushd libconfig/libconfig - autoreconf - popd - - pushd libdaemon/libdaemon - autoreconf - popd - - pushd pcre/pcre - autoreconf - popd - - popd - patchShebangs . - ''; + + pushd prometheus-cpp/prometheus-cpp/3rdparty + replace_dep . "${civetweb.src}" civetweb + popd + + sed -i s_/usr/bin/env_${coreutils}/bin/env_g libssl/openssl/config + + pushd libmicrohttpd/libmicrohttpd + autoreconf + popd + + pushd libconfig/libconfig + autoreconf + popd + + pushd libdaemon/libdaemon + autoreconf + popd + + pushd pcre/pcre + autoreconf + popd + + popd + patchShebangs . + ''; preInstall = '' mkdir -p $out/{etc,bin,lib/systemd/system} diff --git a/pkgs/by-name/pr/proycon-wayout/package.nix b/pkgs/by-name/pr/proycon-wayout/package.nix index d19ea6894546a5..94f66bda4ad879 100644 --- a/pkgs/by-name/pr/proycon-wayout/package.nix +++ b/pkgs/by-name/pr/proycon-wayout/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromSourcehut -, meson -, wayland-protocols -, wayland -, cairo -, pango -, scdoc -, ninja -, cmake -, pkg-config -, wayland-scanner +{ + stdenv, + lib, + fetchFromSourcehut, + meson, + wayland-protocols, + wayland, + cairo, + pango, + scdoc, + ninja, + cmake, + pkg-config, + wayland-scanner, }: stdenv.mkDerivation rec { @@ -34,8 +35,20 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ scdoc ninja meson cmake pkg-config wayland-scanner ]; - buildInputs = [ wayland-protocols wayland cairo pango ]; + nativeBuildInputs = [ + scdoc + ninja + meson + cmake + pkg-config + wayland-scanner + ]; + buildInputs = [ + wayland-protocols + wayland + cairo + pango + ]; meta = with lib; { description = "Takes text from standard input and outputs it to a desktop-widget on Wayland desktops"; diff --git a/pkgs/by-name/pr/prqlc/package.nix b/pkgs/by-name/pr/prqlc/package.nix index 06fcb68038c787..c940bf1d4d5adf 100644 --- a/pkgs/by-name/pr/prqlc/package.nix +++ b/pkgs/by-name/pr/prqlc/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, sqlite -, zlib -, stdenv -, darwin -, python3 +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + sqlite, + zlib, + stdenv, + darwin, + python3, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pr/prr/package.nix b/pkgs/by-name/pr/prr/package.nix index ba07cd6fe0c956..dc818bfc5afcb9 100644 --- a/pkgs/by-name/pr/prr/package.nix +++ b/pkgs/by-name/pr/prr/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, openssl -, pkg-config -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + openssl, + pkg-config, + darwin, }: rustPlatform.buildRustPackage rec { @@ -20,10 +21,12 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-vCZjgmBYO+I6MZLCOMp50bWEeHwLbZsxSz5gRmBykvI="; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; nativeBuildInputs = [ pkg-config ]; @@ -35,4 +38,3 @@ rustPlatform.buildRustPackage rec { maintainers = with maintainers; [ evalexpr ]; }; } - diff --git a/pkgs/by-name/pr/pru/gemset.nix b/pkgs/by-name/pr/pru/gemset.nix index 76d469ef1b72ad..5dcd769ea30f06 100644 --- a/pkgs/by-name/pr/pru/gemset.nix +++ b/pkgs/by-name/pr/pru/gemset.nix @@ -1,9 +1,9 @@ { pru = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1imavf7wlbdfxvkrf838pp3cyfib0r7nzv0chnhyxagy1kk969r2"; type = "gem"; }; diff --git a/pkgs/by-name/pr/pru/package.nix b/pkgs/by-name/pr/pru/package.nix index 5126c6dc0e27ea..f48fc2c32069e5 100644 --- a/pkgs/by-name/pr/pru/package.nix +++ b/pkgs/by-name/pr/pru/package.nix @@ -1,6 +1,7 @@ -{ lib -, bundlerApp -, bundlerUpdateScript +{ + lib, + bundlerApp, + bundlerUpdateScript, }: bundlerApp { diff --git a/pkgs/by-name/ps/ps2client/package.nix b/pkgs/by-name/ps/ps2client/package.nix index 87d4e75c33e3ac..e090a3d0e83800 100644 --- a/pkgs/by-name/ps/ps2client/package.nix +++ b/pkgs/by-name/ps/ps2client/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { version = "unstable-2018-10-18"; @@ -6,13 +10,13 @@ stdenv.mkDerivation { src = fetchFromGitHub { owner = "ps2dev"; - repo = "ps2client"; + repo = "ps2client"; rev = "92fcaf18aabf74daaed40bd50d428cce326a87c0"; sha256 = "1rlmns44pxm6dkh6d3cz9sw8v7pvi53r7r5r3kgwdzkhixjj0cdg"; }; patchPhase = '' - sed -i -e "s|-I/usr/include||g" -e "s|-I/usr/local/include||g" Makefile + sed -i -e "s|-I/usr/include||g" -e "s|-I/usr/local/include||g" Makefile ''; installPhase = '' diff --git a/pkgs/by-name/ps/ps2eps/package.nix b/pkgs/by-name/ps/ps2eps/package.nix index c8f558889c60eb..bc325d331fc832 100644 --- a/pkgs/by-name/ps/ps2eps/package.nix +++ b/pkgs/by-name/ps/ps2eps/package.nix @@ -1,12 +1,12 @@ -{ lib -, fetchFromGitHub -, perlPackages -, substituteAll -, ghostscript -, installShellFiles +{ + lib, + fetchFromGitHub, + perlPackages, + substituteAll, + ghostscript, + installShellFiles, }: - perlPackages.buildPerlPackage rec { pname = "ps2eps"; version = "1.70"; @@ -44,7 +44,10 @@ perlPackages.buildPerlPackage rec { ''; # Override buildPerlPackage's outputs setting - outputs = ["out" "man"]; + outputs = [ + "out" + "man" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/ps/ps3iso-utils/package.nix b/pkgs/by-name/ps/ps3iso-utils/package.nix index 63093b59b2cc8d..ea54787523ad6c 100644 --- a/pkgs/by-name/ps/ps3iso-utils/package.nix +++ b/pkgs/by-name/ps/ps3iso-utils/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, fetchFromGitHub -, unstableGitUpdater -, lib +{ + stdenv, + fetchFromGitHub, + unstableGitUpdater, + lib, }: stdenv.mkDerivation { pname = "ps3iso-utils"; @@ -35,4 +36,3 @@ stdenv.mkDerivation { platforms = platforms.all; }; } - diff --git a/pkgs/by-name/ps/ps3netsrv/package.nix b/pkgs/by-name/ps/ps3netsrv/package.nix index 4d9e221a30b9d0..4f01cfae445c49 100644 --- a/pkgs/by-name/ps/ps3netsrv/package.nix +++ b/pkgs/by-name/ps/ps3netsrv/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchzip, mbedtls, meson, ninja }: +{ + lib, + stdenv, + fetchzip, + mbedtls, + meson, + ninja, +}: let webManModVersion = "1.47.42"; in diff --git a/pkgs/by-name/ps/psc-package/package.nix b/pkgs/by-name/ps/psc-package/package.nix index 99947491cde03a..dcdceee7cd93ed 100644 --- a/pkgs/by-name/ps/psc-package/package.nix +++ b/pkgs/by-name/ps/psc-package/package.nix @@ -1,5 +1,14 @@ # Based on https://github.com/justinwoo/easy-purescript-nix/blob/master/psc-package-simple.nix -{ stdenv, lib, fetchurl, gmp, zlib, libiconv, darwin, installShellFiles }: +{ + stdenv, + lib, + fetchurl, + gmp, + zlib, + libiconv, + darwin, + installShellFiles, +}: let dynamic-linker = stdenv.cc.bintools.dynamicLinker; @@ -10,51 +19,63 @@ stdenv.mkDerivation rec { version = "0.6.2"; - src = if stdenv.hostPlatform.isDarwin - then fetchurl { - url = "https://github.com/purescript/psc-package/releases/download/v0.6.2/macos.tar.gz"; - sha256 = "17dh3bc5b6ahfyx0pi6n9qnrhsyi83qdynnca6k1kamxwjimpcq1"; - } - else fetchurl { - url = "https://github.com/purescript/psc-package/releases/download/v0.6.2/linux64.tar.gz"; - sha256 = "1zvay9q3xj6yd76w6qyb9la4jaj9zvpf4dp78xcznfqbnbhm1a54"; - }; + src = + if stdenv.hostPlatform.isDarwin then + fetchurl { + url = "https://github.com/purescript/psc-package/releases/download/v0.6.2/macos.tar.gz"; + sha256 = "17dh3bc5b6ahfyx0pi6n9qnrhsyi83qdynnca6k1kamxwjimpcq1"; + } + else + fetchurl { + url = "https://github.com/purescript/psc-package/releases/download/v0.6.2/linux64.tar.gz"; + sha256 = "1zvay9q3xj6yd76w6qyb9la4jaj9zvpf4dp78xcznfqbnbhm1a54"; + }; - buildInputs = [ gmp zlib ]; + buildInputs = [ + gmp + zlib + ]; nativeBuildInputs = [ installShellFiles ]; libPath = lib.makeLibraryPath buildInputs; dontStrip = true; - installPhase = '' - mkdir -p $out/bin - - PSC_PACKAGE=$out/bin/psc-package - - install -D -m555 -T psc-package $PSC_PACKAGE - chmod u+w $PSC_PACKAGE - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install_name_tool \ - -change /usr/lib/libSystem.B.dylib ${darwin.Libsystem}/lib/libSystem.B.dylib \ - -change /usr/lib/libiconv.2.dylib ${libiconv}/libiconv.2.dylib \ - $PSC_PACKAGE - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - patchelf --interpreter ${dynamic-linker} --set-rpath ${libPath} $PSC_PACKAGE - '' + '' - chmod u-w $PSC_PACKAGE - - installShellCompletion --cmd psc-package \ - --bash <($PSC_PACKAGE --bash-completion-script $PSC_PACKAGE) \ - --fish <($PSC_PACKAGE --fish-completion-script $PSC_PACKAGE) \ - --zsh <($PSC_PACKAGE --zsh-completion-script $PSC_PACKAGE) - ''; + installPhase = + '' + mkdir -p $out/bin + + PSC_PACKAGE=$out/bin/psc-package + + install -D -m555 -T psc-package $PSC_PACKAGE + chmod u+w $PSC_PACKAGE + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install_name_tool \ + -change /usr/lib/libSystem.B.dylib ${darwin.Libsystem}/lib/libSystem.B.dylib \ + -change /usr/lib/libiconv.2.dylib ${libiconv}/libiconv.2.dylib \ + $PSC_PACKAGE + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + patchelf --interpreter ${dynamic-linker} --set-rpath ${libPath} $PSC_PACKAGE + '' + + '' + chmod u-w $PSC_PACKAGE + + installShellCompletion --cmd psc-package \ + --bash <($PSC_PACKAGE --bash-completion-script $PSC_PACKAGE) \ + --fish <($PSC_PACKAGE --fish-completion-script $PSC_PACKAGE) \ + --zsh <($PSC_PACKAGE --zsh-completion-script $PSC_PACKAGE) + ''; meta = with lib; { description = "Package manager for PureScript based on package sets"; mainProgram = "psc-package"; license = licenses.bsd3; maintainers = [ ]; - platforms = [ "x86_64-darwin" "x86_64-linux" ]; + platforms = [ + "x86_64-darwin" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/ps/pscale/package.nix b/pkgs/by-name/ps/pscale/package.nix index b7372a94ad3ffd..c5ff8377d3fff8 100644 --- a/pkgs/by-name/ps/pscale/package.nix +++ b/pkgs/by-name/ps/pscale/package.nix @@ -1,9 +1,10 @@ -{ buildGoModule -, fetchFromGitHub -, installShellFiles -, lib -, pscale -, testers +{ + buildGoModule, + fetchFromGitHub, + installShellFiles, + lib, + pscale, + testers, }: buildGoModule rec { @@ -20,7 +21,8 @@ buildGoModule rec { vendorHash = "sha256-0SRP995sOLM5FRRWXA/a+7D4v1c53P6VTFk4RSfmOfI="; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X main.version=v${version}" "-X main.commit=v${version}" "-X main.date=unknown" @@ -47,6 +49,9 @@ buildGoModule rec { changelog = "https://github.com/planetscale/cli/releases/tag/v${version}"; homepage = "https://www.planetscale.com/"; license = licenses.asl20; - maintainers = with maintainers; [ pimeys kashw2 ]; + maintainers = with maintainers; [ + pimeys + kashw2 + ]; }; } diff --git a/pkgs/by-name/ps/pscircle/package.nix b/pkgs/by-name/ps/pscircle/package.nix index a1e80ffac0b773..29e7ec26bd393b 100644 --- a/pkgs/by-name/ps/pscircle/package.nix +++ b/pkgs/by-name/ps/pscircle/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitLab, meson, pkg-config, ninja, cairo }: +{ + lib, + stdenv, + fetchFromGitLab, + meson, + pkg-config, + ninja, + cairo, +}: stdenv.mkDerivation rec { pname = "pscircle"; diff --git a/pkgs/by-name/ps/psftools/package.nix b/pkgs/by-name/ps/psftools/package.nix index 8ece64950c2417..23316365b9a9d3 100644 --- a/pkgs/by-name/ps/psftools/package.nix +++ b/pkgs/by-name/ps/psftools/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "psftools"; version = "1.1.2"; @@ -6,7 +10,12 @@ stdenv.mkDerivation rec { url = "https://www.seasip.info/Unix/PSF/${pname}-${version}.tar.gz"; sha256 = "sha256-d/XlKPqYy9x8KNT+8G6zv9ST/uU53Tg4pYrlA17Jh94="; }; - outputs = ["out" "man" "dev" "lib"]; + outputs = [ + "out" + "man" + "dev" + "lib" + ]; meta = with lib; { homepage = "https://www.seasip.info/Unix/PSF"; diff --git a/pkgs/by-name/ps/psi-notify/package.nix b/pkgs/by-name/ps/psi-notify/package.nix index b984cc5cd5c3d3..75bbee8ded2a29 100644 --- a/pkgs/by-name/ps/psi-notify/package.nix +++ b/pkgs/by-name/ps/psi-notify/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, systemd, libnotify, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + systemd, + libnotify, + pkg-config, +}: stdenv.mkDerivation rec { pname = "psi-notify"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-GhGiSI5r0Ki6+MYNa5jCDyYZEW5R9LDNZ/S8K+6L0jo="; }; - buildInputs = [ systemd libnotify ]; + buildInputs = [ + systemd + libnotify + ]; nativeBuildInputs = [ pkg-config ]; installPhase = '' diff --git a/pkgs/by-name/ps/psitop/package.nix b/pkgs/by-name/ps/psitop/package.nix index 74edad8b18c0dc..573c6e970c9fa3 100644 --- a/pkgs/by-name/ps/psitop/package.nix +++ b/pkgs/by-name/ps/psitop/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-oLtKpBvTsM5TbzfWIDfqgb7DL5D3Mldu0oimVeiUeSc="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Top for /proc/pressure"; diff --git a/pkgs/by-name/ps/psitransfer/package.nix b/pkgs/by-name/ps/psitransfer/package.nix index 621ad70184a6cd..63f57bd75ac867 100644 --- a/pkgs/by-name/ps/psitransfer/package.nix +++ b/pkgs/by-name/ps/psitransfer/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, pkg-config -, vips +{ + lib, + buildNpmPackage, + fetchFromGitHub, + pkg-config, + vips, }: let @@ -30,14 +31,15 @@ let cp -r ../public/app $out ''; }; -in buildNpmPackage { +in +buildNpmPackage { inherit pname version src; npmDepsHash = "sha256-EW/Fej58LE/nbJomPtWvEjDveAUdo0jIWwC+ziN0gy0="; nativeBuildInputs = [ pkg-config ]; buildInputs = [ - vips # for 'sharp' dependency + vips # for 'sharp' dependency ]; postPatch = '' diff --git a/pkgs/by-name/ps/pslib/package.nix b/pkgs/by-name/ps/pslib/package.nix index 13a2b17a3e01d4..e11d87fc2db3e4 100644 --- a/pkgs/by-name/ps/pslib/package.nix +++ b/pkgs/by-name/ps/pslib/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, cmake, pkg-config, zlib, libpng, libjpeg, giflib, libtiff +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + zlib, + libpng, + libjpeg, + giflib, + libtiff, }: stdenv.mkDerivation rec { @@ -11,8 +21,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-gaWNvBLuUUy0o+HWCOyG6KmzxDrYCY6PV3WbA/jjH64="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ zlib libpng libjpeg giflib libtiff ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + zlib + libpng + libjpeg + giflib + libtiff + ]; env = lib.optionalAttrs stdenv.hostPlatform.isDarwin { NIX_CFLAGS_COMPILE = "-Wno-error=implicit-function-declaration"; @@ -20,7 +39,11 @@ stdenv.mkDerivation rec { doCheck = true; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; installPhase = '' mkdir -p $out/lib @@ -39,8 +62,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "C-library for generating multi page PostScript documents"; homepage = "https://pslib.sourceforge.net/"; - changelog = - "https://sourceforge.net/p/pslib/git/ci/master/tree/pslib/ChangeLog"; + changelog = "https://sourceforge.net/p/pslib/git/ci/master/tree/pslib/ChangeLog"; license = licenses.gpl2; maintainers = with maintainers; [ ShamrockLee ]; platforms = platforms.unix; diff --git a/pkgs/by-name/ps/psmisc/package.nix b/pkgs/by-name/ps/psmisc/package.nix index 2e8003ab891abe..d96dfa9456b7e6 100644 --- a/pkgs/by-name/ps/psmisc/package.nix +++ b/pkgs/by-name/ps/psmisc/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitLab -, autoconf -, automake -, gettext -, ncurses +{ + lib, + stdenv, + fetchFromGitLab, + autoconf, + automake, + gettext, + ncurses, }: stdenv.mkDerivation rec { @@ -18,17 +19,23 @@ stdenv.mkDerivation rec { hash = "sha256-49YpdIh0DxLHfxos4sw1HUkV0XQBqmm4M9b0T4eN2xI="; }; - nativeBuildInputs = [ autoconf automake gettext ]; + nativeBuildInputs = [ + autoconf + automake + gettext + ]; buildInputs = [ ncurses ]; - preConfigure = lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' - # Goes past the rpl_malloc linking failure - export ac_cv_func_malloc_0_nonnull=yes - export ac_cv_func_realloc_0_nonnull=yes - '' + '' - echo $version > .tarball-version - ./autogen.sh - ''; + preConfigure = + lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' + # Goes past the rpl_malloc linking failure + export ac_cv_func_malloc_0_nonnull=yes + export ac_cv_func_realloc_0_nonnull=yes + '' + + '' + echo $version > .tarball-version + ./autogen.sh + ''; meta = with lib; { homepage = "https://gitlab.com/psmisc/psmisc"; diff --git a/pkgs/by-name/ps/psol/package.nix b/pkgs/by-name/ps/psol/package.nix index b6b9d0bac51344..9b6a6d05ed066a 100644 --- a/pkgs/by-name/ps/psol/package.nix +++ b/pkgs/by-name/ps/psol/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "psol"; diff --git a/pkgs/by-name/ps/pspg/package.nix b/pkgs/by-name/ps/pspg/package.nix index 4424b8cc47d9b0..7646dac9aef573 100644 --- a/pkgs/by-name/ps/pspg/package.nix +++ b/pkgs/by-name/ps/pspg/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, gnugrep, ncurses, pkg-config, installShellFiles, readline, postgresql }: +{ + lib, + stdenv, + fetchFromGitHub, + gnugrep, + ncurses, + pkg-config, + installShellFiles, + readline, + postgresql, +}: stdenv.mkDerivation rec { pname = "pspg"; @@ -11,8 +21,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-SE+62EODKWcKFpMMbWDw+Dp5b2D/XKbMFiJiD/ObrhU="; }; - nativeBuildInputs = [ pkg-config installShellFiles ]; - buildInputs = [ gnugrep ncurses readline postgresql ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; + buildInputs = [ + gnugrep + ncurses + readline + postgresql + ]; makeFlags = [ "PREFIX=${placeholder "out"}" ]; diff --git a/pkgs/by-name/ps/pspp/package.nix b/pkgs/by-name/ps/pspp/package.nix index 100cb5b9bc0568..738178abc80c55 100644 --- a/pkgs/by-name/ps/pspp/package.nix +++ b/pkgs/by-name/ps/pspp/package.nix @@ -1,7 +1,26 @@ -{ lib, stdenv, fetchurl, libxml2, readline, zlib, perl, cairo, gtk3, gsl -, pkg-config, gtksourceview4, pango, gettext, dconf -, makeWrapper, gsettings-desktop-schemas, hicolor-icon-theme -, texinfo, ssw, python3, iconv +{ + lib, + stdenv, + fetchurl, + libxml2, + readline, + zlib, + perl, + cairo, + gtk3, + gsl, + pkg-config, + gtksourceview4, + pango, + gettext, + dconf, + makeWrapper, + gsettings-desktop-schemas, + hicolor-icon-theme, + texinfo, + ssw, + python3, + iconv, }: stdenv.mkDerivation rec { @@ -13,15 +32,31 @@ stdenv.mkDerivation rec { sha256 = "sha256-jtuw8J6M+AEMrZ4FWeAjDX/FquRyHHVsNQVU3zMCTAA="; }; - nativeBuildInputs = [ pkg-config texinfo python3 makeWrapper ]; - buildInputs = [ libxml2 readline zlib perl cairo gtk3 gsl - gtksourceview4 pango gettext - gsettings-desktop-schemas hicolor-icon-theme ssw iconv - ]; + nativeBuildInputs = [ + pkg-config + texinfo + python3 + makeWrapper + ]; + buildInputs = [ + libxml2 + readline + zlib + perl + cairo + gtk3 + gsl + gtksourceview4 + pango + gettext + gsettings-desktop-schemas + hicolor-icon-theme + ssw + iconv + ]; C_INCLUDE_PATH = - "${libxml2.dev}/include/libxml2/:" + - lib.makeSearchPathOutput "dev" "include" buildInputs; + "${libxml2.dev}/include/libxml2/:" + lib.makeSearchPathOutput "dev" "include" buildInputs; LIBRARY_PATH = lib.makeLibraryPath buildInputs; doCheck = false; diff --git a/pkgs/by-name/ps/psql2csv/package.nix b/pkgs/by-name/ps/psql2csv/package.nix index 729582f2e404a3..1e010d10077cee 100644 --- a/pkgs/by-name/ps/psql2csv/package.nix +++ b/pkgs/by-name/ps/psql2csv/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, coreutils -, gnused -, postgresql -, makeWrapper +{ + lib, + stdenvNoCC, + fetchFromGitHub, + coreutils, + gnused, + postgresql, + makeWrapper, }: stdenvNoCC.mkDerivation rec { @@ -28,7 +29,13 @@ stdenvNoCC.mkDerivation rec { install -Dm755 -t $out/bin psql2csv wrapProgram $out/bin/psql2csv \ - --prefix PATH : ${lib.makeBinPath [ coreutils gnused postgresql ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + gnused + postgresql + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/ps/psqlodbc/package.nix b/pkgs/by-name/ps/psqlodbc/package.nix index 1b162d2393ff02..3b3de027f1f9d0 100644 --- a/pkgs/by-name/ps/psqlodbc/package.nix +++ b/pkgs/by-name/ps/psqlodbc/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchurl, postgresql, openssl -, withLibiodbc ? false, libiodbc -, withUnixODBC ? true, unixODBC +{ + lib, + stdenv, + fetchurl, + postgresql, + openssl, + withLibiodbc ? false, + libiodbc, + withUnixODBC ? true, + unixODBC, }: assert lib.xor withLibiodbc withUnixODBC; @@ -14,12 +21,13 @@ stdenv.mkDerivation rec { hash = "sha256-r9iS+J0uzujT87IxTxvVvy0CIBhyxuNDHlwxCW7KTIs="; }; - buildInputs = [ - postgresql - openssl - ] - ++ lib.optional withLibiodbc libiodbc - ++ lib.optional withUnixODBC unixODBC; + buildInputs = + [ + postgresql + openssl + ] + ++ lib.optional withLibiodbc libiodbc + ++ lib.optional withUnixODBC unixODBC; passthru = lib.optionalAttrs withUnixODBC { fancyName = "PostgreSQL"; @@ -28,8 +36,7 @@ stdenv.mkDerivation rec { configureFlags = [ "--with-libpq=${lib.getDev postgresql}/bin/pg_config" - ] - ++ lib.optional withLibiodbc "--with-iodbc=${libiodbc}"; + ] ++ lib.optional withLibiodbc "--with-iodbc=${libiodbc}"; meta = with lib; { homepage = "https://odbc.postgresql.org/"; diff --git a/pkgs/by-name/ps/pssh/package.nix b/pkgs/by-name/ps/pssh/package.nix index 69236a690968f0..7b01d058ed1690 100644 --- a/pkgs/by-name/ps/pssh/package.nix +++ b/pkgs/by-name/ps/pssh/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, python3Packages, openssh, rsync }: +{ + lib, + fetchFromGitHub, + python3Packages, + openssh, + rsync, +}: python3Packages.buildPythonApplication rec { pname = "pssh"; diff --git a/pkgs/by-name/ps/psstop/package.nix b/pkgs/by-name/ps/psstop/package.nix index 1adb6c4e5ed5d1..67968128d828cd 100644 --- a/pkgs/by-name/ps/psstop/package.nix +++ b/pkgs/by-name/ps/psstop/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, glib }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + glib, +}: stdenv.mkDerivation rec { pname = "psstop"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "03ir3jjpzm7q8n1qc5jr99hqarr9r529w1zb6f7q4wak2vfj7w9h"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ glib ]; diff --git a/pkgs/by-name/ps/pstoedit/package.nix b/pkgs/by-name/ps/pstoedit/package.nix index 69b69d1c4c8bd1..b72b2650e9b68c 100644 --- a/pkgs/by-name/ps/pstoedit/package.nix +++ b/pkgs/by-name/ps/pstoedit/package.nix @@ -1,6 +1,18 @@ -{ stdenv, fetchurl, pkg-config, darwin, lib -, zlib, ghostscript, imagemagick, plotutils, gd -, libjpeg, libwebp, libiconv, makeWrapper +{ + stdenv, + fetchurl, + pkg-config, + darwin, + lib, + zlib, + ghostscript, + imagemagick, + plotutils, + gd, + libjpeg, + libwebp, + libiconv, + makeWrapper, }: stdenv.mkDerivation rec { @@ -12,12 +24,31 @@ stdenv.mkDerivation rec { hash = "sha256-RZdlq3NssQ+VVKesAsXqfzVcbC6fz9IXYRx9UQKxB2s="; }; - outputs = [ "out" "dev" ]; - nativeBuildInputs = [ makeWrapper pkg-config ]; - buildInputs = [ zlib ghostscript imagemagick plotutils gd libjpeg libwebp ] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - libiconv ApplicationServices - ]); + outputs = [ + "out" + "dev" + ]; + nativeBuildInputs = [ + makeWrapper + pkg-config + ]; + buildInputs = + [ + zlib + ghostscript + imagemagick + plotutils + gd + libjpeg + libwebp + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + libiconv + ApplicationServices + ] + ); # '@LIBPNG_LDFLAGS@' is no longer substituted by autoconf (the code is commented out) # so we need to remove it from the pkg-config file as well diff --git a/pkgs/by-name/ps/pstreams/package.nix b/pkgs/by-name/ps/pstreams/package.nix index 2baa3b35502397..eace6957c08803 100644 --- a/pkgs/by-name/ps/pstreams/package.nix +++ b/pkgs/by-name/ps/pstreams/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchgit +{ + lib, + stdenv, + fetchgit, }: stdenv.mkDerivation rec { @@ -8,8 +10,11 @@ stdenv.mkDerivation rec { src = fetchgit { url = "https://git.code.sf.net/p/pstreams/code"; - rev = let dot2Underscore = lib.strings.stringAsChars (c: if c == "." then "_" else c); - in "RELEASE_${dot2Underscore version}"; + rev = + let + dot2Underscore = lib.strings.stringAsChars (c: if c == "." then "_" else c); + in + "RELEASE_${dot2Underscore version}"; sha256 = "0r8aj0nh5mkf8cvnzl8bdy4nm7i74vs83axxfimcd74kjfn0irys"; }; @@ -18,8 +23,8 @@ stdenv.mkDerivation rec { doCheck = true; preInstall = "rm INSTALL"; - # `make install` fails on case-insensitive file systems (e.g. APFS by - # default) because this target exists + # `make install` fails on case-insensitive file systems (e.g. APFS by + # default) because this target exists meta = with lib; { description = "POSIX Process Control in C++"; diff --git a/pkgs/by-name/ps/pstree/package.nix b/pkgs/by-name/ps/pstree/package.nix index 7b979d486faa44..ded439f93cc105 100644 --- a/pkgs/by-name/ps/pstree/package.nix +++ b/pkgs/by-name/ps/pstree/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "pstree"; diff --git a/pkgs/by-name/ps/psutils/package.nix b/pkgs/by-name/ps/psutils/package.nix index 93c7b9f2a23a49..0bf3cfe7d3798f 100644 --- a/pkgs/by-name/ps/psutils/package.nix +++ b/pkgs/by-name/ps/psutils/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "psutils"; diff --git a/pkgs/by-name/ps/psw/package.nix b/pkgs/by-name/ps/psw/package.nix index bcf67bfa5f1114..4a6d36aae7ce82 100644 --- a/pkgs/by-name/ps/psw/package.nix +++ b/pkgs/by-name/ps/psw/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Command line tool to write random bytes to stdout"; homepage = "https://github.com/Wulfsta/psw"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ wulfsta ]; }; } diff --git a/pkgs/by-name/pt/pt/gemset.nix b/pkgs/by-name/pt/pt/gemset.nix index 9cd83a90721d91..b1aea68c7b57c6 100644 --- a/pkgs/by-name/pt/pt/gemset.nix +++ b/pkgs/by-name/pt/pt/gemset.nix @@ -1,270 +1,302 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bcm2hchn897xjhqj9zzsxf3n9xhddymj4lsclz508f4vw3av46l"; type = "gem"; }; version = "2.6.0"; }; axiom-types = { - dependencies = ["descendants_tracker" "ice_nine" "thread_safe"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "descendants_tracker" + "ice_nine" + "thread_safe" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10q3k04pll041mkgy0m5fn2b1lazm6ly1drdbcczl5p57lzi3zy1"; type = "gem"; }; version = "0.1.1"; }; coercible = { - dependencies = ["descendants_tracker"]; - groups = ["default"]; - platforms = []; + dependencies = [ "descendants_tracker" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1p5azydlsz0nkxmcq0i1gzmcfq02lgxc4as7wmf47j1c6ljav0ah"; type = "gem"; }; version = "1.0.0"; }; colored = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b0x5jmsyi0z69bm6sij1k89z7h0laag3cb4mdn7zkl9qmxb90lx"; type = "gem"; }; version = "1.2"; }; declarative = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0642xvwzzbgi3kp1bg467wma4g3xqrrn0sk369hjam7w579gnv5j"; type = "gem"; }; version = "0.0.10"; }; declarative-option = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g4ibxq566f1frnhdymzi9hxxcm4g2gw4n21mpjk2mhwym4q6l0p"; type = "gem"; }; version = "0.1.0"; }; descendants_tracker = { - dependencies = ["thread_safe"]; - groups = ["default"]; - platforms = []; + dependencies = [ "thread_safe" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15q8g3fcqyb41qixn6cky0k3p86291y7xsh1jfd851dvrza1vi79"; type = "gem"; }; version = "0.0.4"; }; equalizer = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kjmx3fygx8njxfrwcmn7clfhjhb6bvv3scy2lyyi0wqyi3brra4"; type = "gem"; }; version = "0.0.11"; }; excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vcplvlykirg2vc56jjxavgpkllzq26xgp7ind7wc5ikaqaz64gn"; type = "gem"; }; version = "0.64.0"; }; faraday = { - dependencies = ["multipart-post"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multipart-post" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kplqkpn2s2yl3lxdf6h7sfldqvkbkpxwwxhyk7mdhjplb5faqh6"; type = "gem"; }; version = "0.9.2"; }; faraday_middleware = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a93rs58bakqck7bcihasz66a1riy22h2zpwrpmb13gp8mw3wkmr"; type = "gem"; }; version = "0.13.1"; }; highline = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g0zpalfj8wvca86hcnirir5py2zyqrhkgdgv9f87fxkjaw815wr"; type = "gem"; }; version = "2.0.2"; }; hirb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mzch3c2lvmf8gskgzlx6j53d10j42ir6ik2dkrl27sblhy76cji"; type = "gem"; }; version = "0.7.3"; }; hirb-unicode = { - dependencies = ["hirb" "unicode-display_width"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "hirb" + "unicode-display_width" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1b7hka1p4mkjdy2wr2cxsivnsmnz31zz1bswznmmxnvf5a6c00jk"; type = "gem"; }; version = "0.0.5"; }; ice_nine = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nv35qg1rps9fsis28hz2cq2fx1i96795f91q4nmkm934xynll2x"; type = "gem"; }; version = "0.11.2"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rl0qy4inf1mp8mybfk56dfga0mvx97zwpmq5xmiwl5r770171nv"; type = "gem"; }; version = "1.13.1"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09k0b3cybqilk1gwrwwain95rdypixb2q9w65gd44gfzsd84xi1x"; type = "gem"; }; version = "2.0.0"; }; pt = { - dependencies = ["colored" "highline" "hirb" "hirb-unicode" "thor" "tracker_api"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "colored" + "highline" + "hirb" + "hirb-unicode" + "thor" + "tracker_api" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ypyya7bk0w7zd9c3224zsizhv5wbs1icjpn0023wh3ii1by16a8"; type = "gem"; }; version = "0.10.0"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08q64b5br692dd3v0a9wq9q5dvycc6kmiqmjbdxkxbfizggsvx6l"; type = "gem"; }; version = "3.0.3"; }; representable = { - dependencies = ["declarative" "declarative-option" "uber"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "declarative" + "declarative-option" + "uber" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qm9rgi1j5a6nv726ka4mmixivlxfsg91h8rpp72wwd4vqbkkm07"; type = "gem"; }; version = "3.0.4"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yhrnp9x8qcy5vc7g438amd5j9sw83ih7c30dr6g6slgw9zj3g29"; type = "gem"; }; version = "0.20.3"; }; thread_safe = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nmhcgq6cgz44srylra07bmaw99f5271l0dpsvl5f75m44l0gmwy"; type = "gem"; }; version = "0.3.6"; }; tracker_api = { - dependencies = ["addressable" "equalizer" "excon" "faraday" "faraday_middleware" "multi_json" "representable" "virtus"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "addressable" + "equalizer" + "excon" + "faraday" + "faraday_middleware" + "multi_json" + "representable" + "virtus" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pxwzbjzxign81wynl44napkvkrrhlyl7rm4ywrcdqahmzxmavsp"; type = "gem"; }; version = "1.6.0"; }; uber = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1p1mm7mngg40x05z52md3mbamkng0zpajbzqjjwmsyw0zw3v9vjv"; type = "gem"; }; version = "0.1.0"; }; unicode-display_width = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06dpm3yqc974qfy6nyx7b0w0f6b8k08jadd5l9xnmla3fji6c405"; type = "gem"; }; version = "0.1.1"; }; virtus = { - dependencies = ["axiom-types" "coercible" "descendants_tracker" "equalizer"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "axiom-types" + "coercible" + "descendants_tracker" + "equalizer" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06iphwi3c4f7y9i2rvhvaizfswqbaflilziz4dxqngrdysgkn1fk"; type = "gem"; }; diff --git a/pkgs/by-name/pt/pt/package.nix b/pkgs/by-name/pt/pt/package.nix index 2cbcbdd7faa069..f549ab2e23a5b3 100644 --- a/pkgs/by-name/pt/pt/package.nix +++ b/pkgs/by-name/pt/pt/package.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "pt"; @@ -9,10 +13,14 @@ bundlerApp { meta = with lib; { description = "Minimalist command-line Pivotal Tracker client"; - homepage = "http://www.github.com/raul/pt"; - license = licenses.mit; - maintainers = with maintainers; [ ebzzry manveru nicknovitski ]; - platforms = platforms.unix; + homepage = "http://www.github.com/raul/pt"; + license = licenses.mit; + maintainers = with maintainers; [ + ebzzry + manveru + nicknovitski + ]; + platforms = platforms.unix; mainProgram = "pt"; }; } diff --git a/pkgs/by-name/pt/pt2-clone/package.nix b/pkgs/by-name/pt/pt2-clone/package.nix index c04c5155432823..e87977736bd634 100644 --- a/pkgs/by-name/pt/pt2-clone/package.nix +++ b/pkgs/by-name/pt/pt2-clone/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, nixosTests -, alsa-lib -, SDL2 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + nixosTests, + alsa-lib, + SDL2, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pt/ptags/package.nix b/pkgs/by-name/pt/ptags/package.nix index b855a648a53787..be54ec6bda0c31 100644 --- a/pkgs/by-name/pt/ptags/package.nix +++ b/pkgs/by-name/pt/ptags/package.nix @@ -1,8 +1,9 @@ -{ fetchFromGitHub -, ctags -, lib -, makeWrapper -, rustPlatform +{ + fetchFromGitHub, + ctags, + lib, + makeWrapper, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pt/ptask/package.nix b/pkgs/by-name/pt/ptask/package.nix index fc2432fcabdf43..88fff269fc71d6 100644 --- a/pkgs/by-name/pt/ptask/package.nix +++ b/pkgs/by-name/pt/ptask/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, makeWrapper, gtk3, json_c, taskwarrior2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + makeWrapper, + gtk3, + json_c, + taskwarrior2, +}: stdenv.mkDerivation rec { pname = "ptask"; @@ -9,11 +18,20 @@ stdenv.mkDerivation rec { sha256 = "13nirr7b29bv3w2zc8zxphhmc9ayhs61i11jl4819nabk7vy1kdq"; }; - buildInputs = [ gtk3 json_c ]; + buildInputs = [ + gtk3 + json_c + ]; - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; - patches = [ ./tw-version.patch ./json_c_is_error.patch ]; + patches = [ + ./tw-version.patch + ./json_c_is_error.patch + ]; preFixup = '' wrapProgram "$out/bin/ptask" \ diff --git a/pkgs/by-name/pt/ptcollab/package.nix b/pkgs/by-name/pt/ptcollab/package.nix index d2db8def2ab8ae..67eeddb6168158 100644 --- a/pkgs/by-name/pt/ptcollab/package.nix +++ b/pkgs/by-name/pt/ptcollab/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, nix-update-script -, libsForQt5 -, libvorbis -, pkg-config -, rtmidi +{ + stdenv, + lib, + fetchFromGitHub, + nix-update-script, + libsForQt5, + libvorbis, + pkg-config, + rtmidi, }: stdenv.mkDerivation (finalAttrs: { @@ -19,21 +20,25 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-9u2K79QJRfYKL66e1lsRrQMEqmKTWbK+ucal3/u4rP4="; }; - nativeBuildInputs = [ - pkg-config - ] ++ (with libsForQt5; [ - qmake - qttools - wrapQtAppsHook - ]); - - buildInputs = [ - libvorbis - rtmidi - ] ++ (with libsForQt5; [ - qtbase - qtmultimedia - ]); + nativeBuildInputs = + [ + pkg-config + ] + ++ (with libsForQt5; [ + qmake + qttools + wrapQtAppsHook + ]); + + buildInputs = + [ + libvorbis + rtmidi + ] + ++ (with libsForQt5; [ + qtbase + qtmultimedia + ]); postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' # Move appbundles to Applications before wrapping happens diff --git a/pkgs/by-name/pt/pterm/package.nix b/pkgs/by-name/pt/pterm/package.nix index 463a05ac06978d..c6d0d35ae75f67 100644 --- a/pkgs/by-name/pt/pterm/package.nix +++ b/pkgs/by-name/pt/pterm/package.nix @@ -1,16 +1,21 @@ -{ lib -, stdenv -, fetchurl -, libsndfile -, wxGTK32 -, SDL +{ + lib, + stdenv, + fetchurl, + libsndfile, + wxGTK32, + SDL, }: stdenv.mkDerivation rec { pname = "pterm"; version = "6.0.4"; - buildInputs = [ libsndfile SDL wxGTK32 ]; + buildInputs = [ + libsndfile + SDL + wxGTK32 + ]; src = fetchurl { url = "https://www.cyber1.org/download/linux/pterm-${version}.tar.bz2"; diff --git a/pkgs/by-name/pt/ptex/package.nix b/pkgs/by-name/pt/ptex/package.nix index 930217dab39c75..4887e0ab4f67c5 100644 --- a/pkgs/by-name/pt/ptex/package.nix +++ b/pkgs/by-name/pt/ptex/package.nix @@ -1,7 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, zlib, cmake }: - -stdenv.mkDerivation rec { + lib, + stdenv, + fetchFromGitHub, + zlib, + cmake, +}: + +stdenv.mkDerivation rec { pname = "ptex"; version = "2.4.2"; @@ -12,7 +17,12 @@ stdenv.mkDerivation rec sha256 = "sha256-PR1ld9rXmL6BK4llznAsD5PNvi3anFMz2i9NDsG95DQ="; }; - outputs = [ "bin" "dev" "out" "lib" ]; + outputs = [ + "bin" + "dev" + "out" + "lib" + ]; nativeBuildInputs = [ cmake ]; buildInputs = [ zlib ]; diff --git a/pkgs/by-name/pt/ptouch-driver/package.nix b/pkgs/by-name/pt/ptouch-driver/package.nix index 851fb0862aa396..95c04d04d4626f 100644 --- a/pkgs/by-name/pt/ptouch-driver/package.nix +++ b/pkgs/by-name/pt/ptouch-driver/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, cups -, cups-filters -, foomatic-db-engine -, fetchpatch -, ghostscript -, libpng -, libxml2 -, autoreconfHook -, perl -, patchPpdFilesHook +{ + lib, + stdenv, + fetchFromGitHub, + cups, + cups-filters, + foomatic-db-engine, + fetchpatch, + ghostscript, + libpng, + libxml2, + autoreconfHook, + perl, + patchPpdFilesHook, }: stdenv.mkDerivation rec { @@ -33,7 +34,13 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ cups cups-filters ghostscript libpng libxml2 ]; + buildInputs = [ + cups + cups-filters + ghostscript + libpng + libxml2 + ]; nativeBuildInputs = [ autoreconfHook foomatic-db-engine diff --git a/pkgs/by-name/pt/ptouch-print/package.nix b/pkgs/by-name/pt/ptouch-print/package.nix index e8c51514e0a994..2a4088e25a1c8c 100644 --- a/pkgs/by-name/pt/ptouch-print/package.nix +++ b/pkgs/by-name/pt/ptouch-print/package.nix @@ -1,15 +1,16 @@ -{ cmake -, fetchgit -, gd -, gettext -, git -, lib -, libjpeg -, libpng -, libusb1 -, pkg-config -, stdenv -, zlib +{ + cmake, + fetchgit, + gd, + gettext, + git, + lib, + libjpeg, + libpng, + libusb1, + pkg-config, + stdenv, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pt/ptunnel/package.nix b/pkgs/by-name/pt/ptunnel/package.nix index 1730a0615d7695..1a3e180b876b49 100644 --- a/pkgs/by-name/pt/ptunnel/package.nix +++ b/pkgs/by-name/pt/ptunnel/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, libpcap +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libpcap, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pu/public-sans/package.nix b/pkgs/by-name/pu/public-sans/package.nix index 7a8538c027d2b4..30b40c3f068fee 100644 --- a/pkgs/by-name/pu/public-sans/package.nix +++ b/pkgs/by-name/pu/public-sans/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "public-sans"; diff --git a/pkgs/by-name/pu/publicsuffix-list/package.nix b/pkgs/by-name/pu/publicsuffix-list/package.nix index ef24d576513338..284cc64a1d5618 100644 --- a/pkgs/by-name/pu/publicsuffix-list/package.nix +++ b/pkgs/by-name/pu/publicsuffix-list/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchFromGitHub, unstableGitUpdater }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + unstableGitUpdater, +}: stdenvNoCC.mkDerivation { pname = "publicsuffix-list"; diff --git a/pkgs/by-name/pu/publii/package.nix b/pkgs/by-name/pu/publii/package.nix index ff0a7228fa21da..c3dd794635cba1 100644 --- a/pkgs/by-name/pu/publii/package.nix +++ b/pkgs/by-name/pu/publii/package.nix @@ -1,28 +1,29 @@ -{ stdenv -, lib -, fetchurl -, autoPatchelfHook -, makeShellWrapper -, wrapGAppsHook3 -, alsa-lib -, at-spi2-atk -, at-spi2-core -, atk -, cairo -, cups -, dbus -, expat -, glib -, glibc -, gtk3 -, libsecret -, mesa -, musl -, nss -, pango -, udev -, xdg-utils -, xorg +{ + stdenv, + lib, + fetchurl, + autoPatchelfHook, + makeShellWrapper, + wrapGAppsHook3, + alsa-lib, + at-spi2-atk, + at-spi2-core, + atk, + cairo, + cups, + dbus, + expat, + glib, + glibc, + gtk3, + libsecret, + mesa, + musl, + nss, + pango, + udev, + xdg-utils, + xorg, }: stdenv.mkDerivation rec { @@ -101,7 +102,10 @@ stdenv.mkDerivation rec { homepage = "https://getpublii.com"; changelog = "https://github.com/getpublii/publii/releases/tag/v${version}"; license = licenses.gpl3Only; - maintainers = with lib.maintainers; [ urandom sebtm ]; + maintainers = with lib.maintainers; [ + urandom + sebtm + ]; platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/by-name/pu/pubs/package.nix b/pkgs/by-name/pu/pubs/package.nix index 1dcd011f0aced8..fbdb529616f926 100644 --- a/pkgs/by-name/pu/pubs/package.nix +++ b/pkgs/by-name/pu/pubs/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, python3 +{ + lib, + fetchFromGitHub, + fetchpatch, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -76,6 +77,9 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://github.com/pubs/pubs"; changelog = "https://github.com/pubs/pubs/blob/v${version}/changelog.md"; license = licenses.lgpl3Only; - maintainers = with maintainers; [ gebner dotlambda ]; + maintainers = with maintainers; [ + gebner + dotlambda + ]; }; } diff --git a/pkgs/by-name/pu/pufferpanel/package.nix b/pkgs/by-name/pu/pufferpanel/package.nix index e70106200b1308..590e622c3cc433 100644 --- a/pkgs/by-name/pu/pufferpanel/package.nix +++ b/pkgs/by-name/pu/pufferpanel/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, buildNpmPackage -, makeWrapper -, go-swag -, nixosTests -, testers -, pufferpanel +{ + lib, + fetchFromGitHub, + buildGoModule, + buildNpmPackage, + makeWrapper, + go-swag, + nixosTests, + testers, + pufferpanel, }: buildGoModule rec { @@ -52,11 +53,17 @@ buildGoModule rec { npmDepsHash = "sha256-oWFXtV/dxzHv3sfIi01l1lHE5tcJgpVq87XgS6Iy62g="; NODE_OPTIONS = "--openssl-legacy-provider"; - npmBuildFlags = [ "--" "--dest=${placeholder "out"}" ]; + npmBuildFlags = [ + "--" + "--dest=${placeholder "out"}" + ]; dontNpmInstall = true; }; - nativeBuildInputs = [ makeWrapper go-swag ]; + nativeBuildInputs = [ + makeWrapper + go-swag + ]; vendorHash = "sha256-1U7l7YW1fu5M0/pPHTLamLsTQdEltesRODUn21SuP8w="; proxyVendor = true; diff --git a/pkgs/by-name/pu/pugixml/package.nix b/pkgs/by-name/pu/pugixml/package.nix index fc0eb1dfa29127..6aa070fd41a3c9 100644 --- a/pkgs/by-name/pu/pugixml/package.nix +++ b/pkgs/by-name/pu/pugixml/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, cmake, check, validatePkgConfig, shared ? false }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + check, + validatePkgConfig, + shared ? false, +}: stdenv.mkDerivation rec { pname = "pugixml"; @@ -13,7 +21,10 @@ stdenv.mkDerivation rec { outputs = [ "out" ] ++ lib.optionals shared [ "dev" ]; - nativeBuildInputs = [ cmake validatePkgConfig ]; + nativeBuildInputs = [ + cmake + validatePkgConfig + ]; cmakeFlags = [ "-DBUILD_TESTS=ON" diff --git a/pkgs/by-name/pu/pulldown-cmark/package.nix b/pkgs/by-name/pu/pulldown-cmark/package.nix index e919aea61f50c7..f6cf4bc23c1494 100644 --- a/pkgs/by-name/pu/pulldown-cmark/package.nix +++ b/pkgs/by-name/pu/pulldown-cmark/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pu/pulsar/package.nix b/pkgs/by-name/pu/pulsar/package.nix index cc2112a9a8cca4..d1f3c5e4e0e603 100644 --- a/pkgs/by-name/pu/pulsar/package.nix +++ b/pkgs/by-name/pu/pulsar/package.nix @@ -1,48 +1,51 @@ -{ lib -, stdenv -, git -, git-lfs -, fetchurl -, wrapGAppsHook3 -, alsa-lib -, at-spi2-atk -, cairo -, coreutils -, cups -, dbus -, expat -, gdk-pixbuf -, glib -, gtk3 -, mesa -, nss -, nspr -, xorg -, libdrm -, libsecret -, libxkbcommon -, pango -, systemd -, hunspellDicts -, useHunspell ? true -, languages ? [ "en_US" ] -, withNemoAction ? true -, makeDesktopItem -, copyDesktopItems -, asar -, python3 +{ + lib, + stdenv, + git, + git-lfs, + fetchurl, + wrapGAppsHook3, + alsa-lib, + at-spi2-atk, + cairo, + coreutils, + cups, + dbus, + expat, + gdk-pixbuf, + glib, + gtk3, + mesa, + nss, + nspr, + xorg, + libdrm, + libsecret, + libxkbcommon, + pango, + systemd, + hunspellDicts, + useHunspell ? true, + languages ? [ "en_US" ], + withNemoAction ? true, + makeDesktopItem, + copyDesktopItems, + asar, + python3, }: let pname = "pulsar"; version = "1.123.0"; - sourcesPath = { - x86_64-linux.tarname = "Linux.${pname}-${version}.tar.gz"; - x86_64-linux.hash = "sha256-PVNk4auxJB+mLFqYH7uJiK7L/SVqn5Z3BE8wmknBNjs="; - aarch64-linux.tarname = "ARM.Linux.${pname}-${version}-arm64.tar.gz"; - aarch64-linux.hash = "sha256-Y4qaaWvVsd4HDQx50ntq5W40MVy8oWAePOVsPSFE8q0="; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + sourcesPath = + { + x86_64-linux.tarname = "Linux.${pname}-${version}.tar.gz"; + x86_64-linux.hash = "sha256-PVNk4auxJB+mLFqYH7uJiK7L/SVqn5Z3BE8wmknBNjs="; + aarch64-linux.tarname = "ARM.Linux.${pname}-${version}-arm64.tar.gz"; + aarch64-linux.hash = "sha256-Y4qaaWvVsd4HDQx50ntq5W40MVy8oWAePOVsPSFE8q0="; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); newLibpath = lib.makeLibraryPath [ alsa-lib @@ -77,15 +80,19 @@ let # Hunspell hunspellDirs = builtins.map (lang: "${hunspellDicts.${lang}}/share/hunspell") languages; hunspellTargetDirs = "$out/opt/Pulsar/resources/app.asar.unpacked/node_modules/spellchecker/vendor/hunspell_dictionaries"; - hunspellCopyCommands = lib.concatMapStringsSep "\n" (lang: "cp -r ${lang}/* ${hunspellTargetDirs};") hunspellDirs; + hunspellCopyCommands = lib.concatMapStringsSep "\n" ( + lang: "cp -r ${lang}/* ${hunspellTargetDirs};" + ) hunspellDirs; in stdenv.mkDerivation { inherit pname version; - src = with sourcesPath; fetchurl { - url = "https://github.com/pulsar-edit/pulsar/releases/download/v${version}/${tarname}"; - inherit hash; - }; + src = + with sourcesPath; + fetchurl { + url = "https://github.com/pulsar-edit/pulsar/releases/download/v${version}/${tarname}"; + inherit hash; + }; nativeBuildInputs = [ wrapGAppsHook3 @@ -110,97 +117,103 @@ stdenv.mkDerivation { runHook postInstall ''; - preFixup = '' - gappsWrapperArgs+=( - # needed for gio executable to be able to delete files - --prefix "PATH" : "${lib.makeBinPath [ glib ]}" - ) - '' + lib.optionalString useHunspell '' - # On all platforms, we must inject our dictionnaries - ${hunspellCopyCommands} - ''; + preFixup = + '' + gappsWrapperArgs+=( + # needed for gio executable to be able to delete files + --prefix "PATH" : "${lib.makeBinPath [ glib ]}" + ) + '' + + lib.optionalString useHunspell '' + # On all platforms, we must inject our dictionnaries + ${hunspellCopyCommands} + ''; - postFixup = '' - opt=$out/opt/Pulsar - # Patch the prebuilt binaries - patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath "${newLibpath}:$opt" \ - --add-needed libffmpeg.so \ - --add-needed libxshmfence.so.1 \ - --add-needed libxkbcommon.so.0 \ - --add-needed libxkbfile.so.1 \ - --add-needed libsecret-1.so.0 \ - $opt/pulsar - patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath "${newLibpath}" \ - $opt/resources/app/ppm/bin/node - patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - $opt/resources/app.asar.unpacked/node_modules/symbol-provider-ctags/vendor/ctags-linux - - # Replace the bundled git with the one from nixpkgs - dugite=$opt/resources/app.asar.unpacked/node_modules/dugite - rm -f $dugite/git/bin/git - ln -s ${git}/bin/git $dugite/git/bin/git - - # Not only do we need to replace the git binary itself, we also need to replace - # all the symlinks in dugite/git/libexec/git-core. - for file in "$dugite/git/libexec/git-core"/*; do - if [ -x "$file" ] && file "$file" | grep -q "ELF"; then - # Remove ELF executable - rm "$file" - - # Get the corresponding filename in nixpkgs's git - filename=$(basename "$file") - git_executable="${git}/libexec/git-core/$filename" - - # Create symlink to $git_executable - ln -s "$git_executable" "$file" - - echo "Replaced $file with symlink to $git_executable" - fi - done - - # Was symlinked in previous loop, but actually, nixpkgs has a separate package for git-lfs - # Unlink to avoid a "File exists" error and relink correctly - unlink $dugite/git/libexec/git-core/git-lfs - ln -s ${git-lfs}/bin/git-lfs $dugite/git/libexec/git-core/git-lfs - '' + lib.optionalString (stdenv.hostPlatform.system == "x86_64-linux") '' - # We have to patch a prebuilt binary in the asar archive - # But asar complains because the node_gyp unpacked dependency uses a prebuilt Python3 itself - - rm $opt/resources/app.asar.unpacked/node_modules/tree-sitter-bash/build/node_gyp_bins/python3 - ln -s ${python3.interpreter} $opt/resources/app.asar.unpacked/node_modules/tree-sitter-bash/build/node_gyp_bins/python3 - '' + '' - # Patch the bundled node executables - find $opt -name "*.node" -exec patchelf --set-rpath "${newLibpath}:$opt" {} \; - # Also patch the node executable for apm - patchelf --set-rpath "${newLibpath}:$opt" $opt/resources/app/ppm/bin/node - - # The pre-packaged ASAR bundle comes with prebuild binaries, expecting libstdc++.so.6 - asarBundle=$TMPDIR/asarbundle - asar e $opt/resources/app.asar $asarBundle - find $asarBundle -name "*.node" -exec patchelf --set-rpath "${newLibpath}:$opt" --add-needed libstdc++.so.6 {} \; - unlink $asarBundle/node_modules/document-register-element/dre # Self referencing symlink, breaking asar rebundling - asar p $asarBundle $opt/resources/app.asar - rm -rf $asarBundle - - # Pulsar uses `PULSAR_PATH` to know where it is intalled - mkdir -p $out/bin - wrapProgram $opt/resources/pulsar.sh \ - --suffix "PATH" : "${lib.makeBinPath [ coreutils ]}" \ - --set "PULSAR_PATH" "$opt" - ln -s $opt/resources/pulsar.sh $out/bin/pulsar - ln -s $opt/resources/app/ppm/bin/apm $out/bin/ppm - - # Copy the icons - mkdir -p $out/share/icons/hicolor/scalable/apps $out/share/icons/hicolor/1024x1024/apps - cp $opt/resources/pulsar.svg $out/share/icons/hicolor/scalable/apps/pulsar.svg - cp $opt/resources/pulsar.png $out/share/icons/hicolor/1024x1024/apps/pulsar.png - '' + lib.optionalString withNemoAction '' - # Copy the nemo action file - mkdir -p $out/share/nemo/actions - cp ${./pulsar.nemo_action} $out/share/nemo/actions/pulsar.nemo_action - ''; + postFixup = + '' + opt=$out/opt/Pulsar + # Patch the prebuilt binaries + patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ + --set-rpath "${newLibpath}:$opt" \ + --add-needed libffmpeg.so \ + --add-needed libxshmfence.so.1 \ + --add-needed libxkbcommon.so.0 \ + --add-needed libxkbfile.so.1 \ + --add-needed libsecret-1.so.0 \ + $opt/pulsar + patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ + --set-rpath "${newLibpath}" \ + $opt/resources/app/ppm/bin/node + patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ + $opt/resources/app.asar.unpacked/node_modules/symbol-provider-ctags/vendor/ctags-linux + + # Replace the bundled git with the one from nixpkgs + dugite=$opt/resources/app.asar.unpacked/node_modules/dugite + rm -f $dugite/git/bin/git + ln -s ${git}/bin/git $dugite/git/bin/git + + # Not only do we need to replace the git binary itself, we also need to replace + # all the symlinks in dugite/git/libexec/git-core. + for file in "$dugite/git/libexec/git-core"/*; do + if [ -x "$file" ] && file "$file" | grep -q "ELF"; then + # Remove ELF executable + rm "$file" + + # Get the corresponding filename in nixpkgs's git + filename=$(basename "$file") + git_executable="${git}/libexec/git-core/$filename" + + # Create symlink to $git_executable + ln -s "$git_executable" "$file" + + echo "Replaced $file with symlink to $git_executable" + fi + done + + # Was symlinked in previous loop, but actually, nixpkgs has a separate package for git-lfs + # Unlink to avoid a "File exists" error and relink correctly + unlink $dugite/git/libexec/git-core/git-lfs + ln -s ${git-lfs}/bin/git-lfs $dugite/git/libexec/git-core/git-lfs + '' + + lib.optionalString (stdenv.hostPlatform.system == "x86_64-linux") '' + # We have to patch a prebuilt binary in the asar archive + # But asar complains because the node_gyp unpacked dependency uses a prebuilt Python3 itself + + rm $opt/resources/app.asar.unpacked/node_modules/tree-sitter-bash/build/node_gyp_bins/python3 + ln -s ${python3.interpreter} $opt/resources/app.asar.unpacked/node_modules/tree-sitter-bash/build/node_gyp_bins/python3 + '' + + '' + # Patch the bundled node executables + find $opt -name "*.node" -exec patchelf --set-rpath "${newLibpath}:$opt" {} \; + # Also patch the node executable for apm + patchelf --set-rpath "${newLibpath}:$opt" $opt/resources/app/ppm/bin/node + + # The pre-packaged ASAR bundle comes with prebuild binaries, expecting libstdc++.so.6 + asarBundle=$TMPDIR/asarbundle + asar e $opt/resources/app.asar $asarBundle + find $asarBundle -name "*.node" -exec patchelf --set-rpath "${newLibpath}:$opt" --add-needed libstdc++.so.6 {} \; + unlink $asarBundle/node_modules/document-register-element/dre # Self referencing symlink, breaking asar rebundling + asar p $asarBundle $opt/resources/app.asar + rm -rf $asarBundle + + # Pulsar uses `PULSAR_PATH` to know where it is intalled + mkdir -p $out/bin + wrapProgram $opt/resources/pulsar.sh \ + --suffix "PATH" : "${lib.makeBinPath [ coreutils ]}" \ + --set "PULSAR_PATH" "$opt" + ln -s $opt/resources/pulsar.sh $out/bin/pulsar + ln -s $opt/resources/app/ppm/bin/apm $out/bin/ppm + + # Copy the icons + mkdir -p $out/share/icons/hicolor/scalable/apps $out/share/icons/hicolor/1024x1024/apps + cp $opt/resources/pulsar.svg $out/share/icons/hicolor/scalable/apps/pulsar.svg + cp $opt/resources/pulsar.png $out/share/icons/hicolor/1024x1024/apps/pulsar.png + '' + + lib.optionalString withNemoAction '' + # Copy the nemo action file + mkdir -p $out/share/nemo/actions + cp ${./pulsar.nemo_action} $out/share/nemo/actions/pulsar.nemo_action + ''; desktopItems = [ (makeDesktopItem { @@ -210,7 +223,11 @@ stdenv.mkDerivation { icon = "pulsar"; comment = "A Community-led Hyper-Hackable Text Editor"; genericName = "Text Editor"; - categories = [ "Development" "TextEditor" "Utility" ]; + categories = [ + "Development" + "TextEditor" + "Utility" + ]; mimeTypes = [ "text/plain" ]; }) ]; @@ -228,7 +245,10 @@ stdenv.mkDerivation { sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; license = lib.licenses.mit; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ bryango pbsds ]; + maintainers = with lib.maintainers; [ + bryango + pbsds + ]; knownVulnerabilities = [ # electron 12.2.3, efforts are in place to bump it "CVE-2023-5217" diff --git a/pkgs/by-name/pu/pulsarctl/package.nix b/pkgs/by-name/pu/pulsarctl/package.nix index 9105ea9b0a1f6f..df1f75db3e145a 100644 --- a/pkgs/by-name/pu/pulsarctl/package.nix +++ b/pkgs/by-name/pu/pulsarctl/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, nix-update-script -, go -, testers -, pulsarctl +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + nix-update-script, + go, + testers, + pulsarctl, }: buildGoModule rec { @@ -33,7 +34,9 @@ buildGoModule rec { GoVersion = "go${go.version}"; }; in - (lib.mapAttrsToList (k: v: "-X github.com/streamnative/pulsarctl/pkg/cmdutils.${k}=${v}") buildVars); + (lib.mapAttrsToList ( + k: v: "-X github.com/streamnative/pulsarctl/pkg/cmdutils.${k}=${v}" + ) buildVars); excludedPackages = [ "./pkg/test" diff --git a/pkgs/by-name/pu/pulseaudio-ctl/package.nix b/pkgs/by-name/pu/pulseaudio-ctl/package.nix index e58d8edba6f9c7..da9c2d5757da03 100644 --- a/pkgs/by-name/pu/pulseaudio-ctl/package.nix +++ b/pkgs/by-name/pu/pulseaudio-ctl/package.nix @@ -1,11 +1,29 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper -, bc, dbus, gawk, gnused, libnotify, pulseaudio }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + bc, + dbus, + gawk, + gnused, + libnotify, + pulseaudio, +}: let - path = lib.makeBinPath [ bc dbus gawk gnused libnotify pulseaudio ]; + path = lib.makeBinPath [ + bc + dbus + gawk + gnused + libnotify + pulseaudio + ]; pname = "pulseaudio-ctl"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { name = "${pname}-${version}"; version = "1.70"; diff --git a/pkgs/by-name/pu/pulseaudio-dlna/package.nix b/pkgs/by-name/pu/pulseaudio-dlna/package.nix index 8027ec70aa5cf7..46a53c17e616e3 100644 --- a/pkgs/by-name/pu/pulseaudio-dlna/package.nix +++ b/pkgs/by-name/pu/pulseaudio-dlna/package.nix @@ -1,19 +1,20 @@ -{ fetchFromGitHub -, lib -, python3Packages -, mp3Support ? true -, lame -, opusSupport ? true -, opusTools -, faacSupport ? false -, faac -, flacSupport ? true -, flac -, soxSupport ? true -, sox -, vorbisSupport ? true -, vorbis-tools -, pulseaudio +{ + fetchFromGitHub, + lib, + python3Packages, + mp3Support ? true, + lame, + opusSupport ? true, + opusTools, + faacSupport ? false, + faac, + flacSupport ? true, + flac, + soxSupport ? true, + sox, + vorbisSupport ? true, + vorbis-tools, + pulseaudio, }: python3Packages.buildPythonApplication { @@ -31,29 +32,31 @@ python3Packages.buildPythonApplication { ./0001-setup.py-remove-dbus-python-from-list.patch ]; - propagatedBuildInputs = with python3Packages; [ - dbus-python - docopt - requests - setproctitle - protobuf - psutil - chardet - netifaces - notify2 - pyroute2 - pygobject3 - pychromecast - lxml - setuptools - zeroconf - ] - ++ lib.optional mp3Support lame - ++ lib.optional opusSupport opusTools - ++ lib.optional faacSupport faac - ++ lib.optional flacSupport flac - ++ lib.optional soxSupport sox - ++ lib.optional vorbisSupport vorbis-tools; + propagatedBuildInputs = + with python3Packages; + [ + dbus-python + docopt + requests + setproctitle + protobuf + psutil + chardet + netifaces + notify2 + pyroute2 + pygobject3 + pychromecast + lxml + setuptools + zeroconf + ] + ++ lib.optional mp3Support lame + ++ lib.optional opusSupport opusTools + ++ lib.optional faacSupport faac + ++ lib.optional flacSupport flac + ++ lib.optional soxSupport sox + ++ lib.optional vorbisSupport vorbis-tools; # pulseaudio-dlna shells out to pactl to configure sinks and sources. # As pactl might not be in $PATH, add --suffix it (so pactl configured by the diff --git a/pkgs/by-name/pu/pulseaudio-dlna/zeroconf.nix b/pkgs/by-name/pu/pulseaudio-dlna/zeroconf.nix index 5448e3b3b2e684..4e2c7dfeebb45b 100644 --- a/pkgs/by-name/pu/pulseaudio-dlna/zeroconf.nix +++ b/pkgs/by-name/pu/pulseaudio-dlna/zeroconf.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonPackage -, fetchPypi -, ifaddr -, typing -, pythonOlder -, netifaces -, six -, enum-compat +{ + lib, + buildPythonPackage, + fetchPypi, + ifaddr, + typing, + pythonOlder, + netifaces, + six, + enum-compat, }: buildPythonPackage rec { @@ -18,8 +19,12 @@ buildPythonPackage rec { sha256 = "0ykzg730n915qbrq9bn5pn06bv6rb5zawal4sqjyfnjjm66snkj3"; }; - propagatedBuildInputs = [ netifaces six enum-compat ifaddr ] - ++ lib.optionals (pythonOlder "3.5") [ typing ]; + propagatedBuildInputs = [ + netifaces + six + enum-compat + ifaddr + ] ++ lib.optionals (pythonOlder "3.5") [ typing ]; meta = with lib; { description = "Pure python implementation of multicast DNS service discovery"; diff --git a/pkgs/by-name/pu/pulseaudio-module-xrdp/package.nix b/pkgs/by-name/pu/pulseaudio-module-xrdp/package.nix index c83d08fc828f26..26c607b210229a 100644 --- a/pkgs/by-name/pu/pulseaudio-module-xrdp/package.nix +++ b/pkgs/by-name/pu/pulseaudio-module-xrdp/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, fetchFromGitHub -, lib -, pulseaudio -, autoreconfHook -, pkg-config -, nixosTests -, gitUpdater +{ + stdenv, + fetchFromGitHub, + lib, + pulseaudio, + autoreconfHook, + pkg-config, + nixosTests, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pu/pulseeffects-legacy/package.nix b/pkgs/by-name/pu/pulseeffects-legacy/package.nix index 6daaf094b33417..995b3be2a4779b 100644 --- a/pkgs/by-name/pu/pulseeffects-legacy/package.nix +++ b/pkgs/by-name/pu/pulseeffects-legacy/package.nix @@ -1,37 +1,39 @@ -{ lib, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, itstool -, python3 -, libxml2 -, desktop-file-utils -, wrapGAppsHook3 -, gst_all_1 -, pulseaudio -, gtk3 -, glib -, glibmm -, gtkmm3 -, lilv -, lv2 -, serd -, sord -, sratom -, libbs2b -, libsamplerate -, libsndfile -, libebur128 -, rnnoise -, boost -, dbus -, fftwFloat -, calf -, zita-convolver -, zam-plugins -, rubberband -, lsp-plugins +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + itstool, + python3, + libxml2, + desktop-file-utils, + wrapGAppsHook3, + gst_all_1, + pulseaudio, + gtk3, + glib, + glibmm, + gtkmm3, + lilv, + lv2, + serd, + sord, + sratom, + libbs2b, + libsamplerate, + libsndfile, + libebur128, + rnnoise, + boost, + dbus, + fftwFloat, + calf, + zita-convolver, + zam-plugins, + rubberband, + lsp-plugins, }: let @@ -43,7 +45,8 @@ let rubberband # pitch shifting zam-plugins # maximizer ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "pulseeffects"; version = "4.8.7"; @@ -75,7 +78,11 @@ in stdenv.mkDerivation rec { gst_all_1.gst-plugins-base # gst-fft gst_all_1.gst-plugins-good # pulsesrc gst_all_1.gst-plugins-bad - lilv lv2 serd sord sratom + lilv + lv2 + serd + sord + sratom libbs2b libebur128 libsamplerate diff --git a/pkgs/by-name/pu/pulsemixer/package.nix b/pkgs/by-name/pu/pulsemixer/package.nix index f38a741b66822d..32beb377fc2c4d 100644 --- a/pkgs/by-name/pu/pulsemixer/package.nix +++ b/pkgs/by-name/pu/pulsemixer/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, python3, libpulseaudio }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + libpulseaudio, +}: stdenv.mkDerivation rec { pname = "pulsemixer"; diff --git a/pkgs/by-name/pu/pulumi/package.nix b/pkgs/by-name/pu/pulumi/package.nix index f46f3c25775e66..6cbb1c81d58ccf 100644 --- a/pkgs/by-name/pu/pulumi/package.nix +++ b/pkgs/by-name/pu/pulumi/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, buildGoModule -, coreutils -, fetchFromGitHub -, fetchpatch -, installShellFiles -, git +{ + stdenv, + lib, + buildGoModule, + coreutils, + fetchFromGitHub, + fetchpatch, + installShellFiles, + git, # passthru -, runCommand -, makeWrapper -, pulumi -, pulumiPackages + runCommand, + makeWrapper, + pulumi, + pulumiPackages, }: buildGoModule rec { @@ -57,26 +58,28 @@ buildGoModule rec { git ]; - preCheck = '' - # The tests require `version.Version` to be unset - ldflags=''${ldflags//"$importpathFlags"/} + preCheck = + '' + # The tests require `version.Version` to be unset + ldflags=''${ldflags//"$importpathFlags"/} - # Create some placeholders for plugins used in tests. Otherwise, Pulumi - # tries to donwload them and fails, resulting in really long test runs - dummyPluginPath=$(mktemp -d) - for name in pulumi-{resource-pkg{A,B},-pkgB}; do - ln -s ${coreutils}/bin/true "$dummyPluginPath/$name" - done + # Create some placeholders for plugins used in tests. Otherwise, Pulumi + # tries to donwload them and fails, resulting in really long test runs + dummyPluginPath=$(mktemp -d) + for name in pulumi-{resource-pkg{A,B},-pkgB}; do + ln -s ${coreutils}/bin/true "$dummyPluginPath/$name" + done - export PATH=$dummyPluginPath''${PATH:+:}$PATH + export PATH=$dummyPluginPath''${PATH:+:}$PATH - # Code generation tests also download dependencies from network - rm codegen/{docs,dotnet,go,nodejs,python,schema}/*_test.go - rm -R codegen/{dotnet,go,nodejs,python}/gen_program_test + # Code generation tests also download dependencies from network + rm codegen/{docs,dotnet,go,nodejs,python,schema}/*_test.go + rm -R codegen/{dotnet,go,nodejs,python}/gen_program_test - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - export PULUMI_HOME=$(mktemp -d) - ''; + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + export PULUMI_HOME=$(mktemp -d) + ''; checkFlags = let @@ -124,16 +127,18 @@ buildGoModule rec { passthru = { pkgs = pulumiPackages; - withPackages = f: runCommand "${pulumi.name}-with-packages" - { - nativeBuildInputs = [ makeWrapper ]; - } - '' - mkdir -p $out/bin - makeWrapper ${pulumi}/bin/pulumi $out/bin/pulumi \ - --suffix PATH : ${lib.makeBinPath (f pulumiPackages)} \ - --set LD_LIBRARY_PATH "${lib.getLib stdenv.cc.cc}/lib" - ''; + withPackages = + f: + runCommand "${pulumi.name}-with-packages" + { + nativeBuildInputs = [ makeWrapper ]; + } + '' + mkdir -p $out/bin + makeWrapper ${pulumi}/bin/pulumi $out/bin/pulumi \ + --suffix PATH : ${lib.makeBinPath (f pulumiPackages)} \ + --set LD_LIBRARY_PATH "${lib.getLib stdenv.cc.cc}/lib" + ''; }; meta = with lib; { diff --git a/pkgs/by-name/pu/pulumictl/package.nix b/pkgs/by-name/pu/pulumictl/package.nix index b96c87bdf32cff..1602cb2e31966e 100644 --- a/pkgs/by-name/pu/pulumictl/package.nix +++ b/pkgs/by-name/pu/pulumictl/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pulumictl"; @@ -14,7 +18,9 @@ buildGoModule rec { vendorHash = "sha256-Wktr3TXSIIzbkiT3Gk5i4K58gahnxySi6ht30li+Z0o="; ldflags = [ - "-s" "-w" "-X=github.com/pulumi/pulumictl/pkg/version.Version=${src.rev}" + "-s" + "-w" + "-X=github.com/pulumi/pulumictl/pkg/version.Version=${src.rev}" ]; subPackages = [ "cmd/pulumictl" ]; diff --git a/pkgs/by-name/pu/pup/package.nix b/pkgs/by-name/pu/pup/package.nix index 3df3ef3bc42b8e..7ea3743527fe41 100644 --- a/pkgs/by-name/pu/pup/package.nix +++ b/pkgs/by-name/pu/pup/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pup"; diff --git a/pkgs/by-name/pu/pupdate/deps.nix b/pkgs/by-name/pu/pupdate/deps.nix index 81e83f507c0a81..b254c6554f172f 100644 --- a/pkgs/by-name/pu/pupdate/deps.nix +++ b/pkgs/by-name/pu/pupdate/deps.nix @@ -1,193 +1,946 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "CommandLineParser"; version = "2.9.1"; hash = "sha256-ApU9y1yX60daSjPk3KYDBeJ7XZByKW8hse9NRZGcjeo="; }) - (fetchNuGet { pname = "ConsoleMenu-simple"; version = "2.6.1"; hash = "sha256-1bMCCWLnJ7rCtaLyz+AF8YOZK9qktqy0HZhqyPQ5ce0="; }) - (fetchNuGet { pname = "Crc32.NET"; version = "1.2.0"; hash = "sha256-sMQNIppJXHU2mULn5b//uRbbPMyguH9QlG6HKVIYUmE="; }) - (fetchNuGet { pname = "Libuv"; version = "1.9.1"; hash = "sha256-bQdVn50eId1GzSQa9CFth0meKAQMYCFQ98zLN9pqL0k="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.App.Ref"; version = "7.0.20"; hash = "sha256-OEDXXjQ1HDRPiA4Y1zPr1xUeH6wlzTCJpts+DZL61wI="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; version = "7.0.20"; hash = "sha256-ewal9R6o20GV0R02ylSijVFdWZAbdN8TK1PCc/ltHBQ="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; version = "7.0.20"; hash = "sha256-vq59xMfrET8InzUhkAsbs2xp3ML+SO9POsbwAiYKzkA="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "1.1.0"; hash = "sha256-7KrZfK3kUbmeT82eVadvHurZcaFq3FDj4qkIIeExJiM="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "1.3.0"; hash = "sha256-Jcw54WWyfPKdkeqRAG4xjihiGP/djjAkvpR6KM2I+CQ="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "1.3.0"; hash = "sha256-OqqvMHNj9Xql4YTEPMlzoGXXELoLC7JkRGjS0pil+m4="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.VisualBasic"; version = "1.3.0"; hash = "sha256-lIKN1dG59aY8zeYgkY8Kdnv4UBgSwVbghz5ngPyEzKA="; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.0.1"; hash = "sha256-0huoqR2CJ3Z9Q2peaKD09TV3E6saYSqDGZ290K8CrH8="; }) - (fetchNuGet { pname = "Microsoft.NET.ILLink.Analyzers"; version = "7.0.100-1.23401.1"; hash = "sha256-jGyhmj7DZxTv9Hir6YonkpL+SDsRore8Ph4RNN+2q94="; }) - (fetchNuGet { pname = "Microsoft.NET.ILLink.Tasks"; version = "7.0.100-1.23401.1"; hash = "sha256-n95rHugj0BOtCBvv5209zJ5ttPX0A2+RWLjEwwtxgRA="; }) - (fetchNuGet { pname = "Microsoft.NETCore.App"; version = "1.0.4"; hash = "sha256-NqJEOTW98eO0UlbiZcIVrsZCY4MUa+CkSmtAx3e2g3k="; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Host.linux-arm64"; version = "7.0.20"; hash = "sha256-/20dMbO1Ft0WVhl+Lv1916Thvr4kPP9LuuX4bKE+czE="; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Host.linux-x64"; version = "7.0.20"; hash = "sha256-Y1Dg8Sqhya86xD+9aJOuznT4mJUyFmoF/YZc0+5LBdc="; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Ref"; version = "7.0.20"; hash = "sha256-W9RU3bja4BQLAbsaIhANQPJJh6DycDiBR+WZ3mK6Zrs="; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; version = "7.0.20"; hash = "sha256-TemMvbNrDzJVHWwxVgnNN2CnTyI6TcvvZDpF4ts6IAw="; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Runtime.linux-x64"; version = "7.0.20"; hash = "sha256-L+WaGvoXVMT3tZ7R5xFE06zaLcC3SI7LEf4ATBkUAGQ="; }) - (fetchNuGet { pname = "Microsoft.NETCore.DotNetHost"; version = "1.0.1"; hash = "sha256-yiyZ4KGVRDZRgAuoSl4ZNWnRR3ityniyRPvzS799JOM="; }) - (fetchNuGet { pname = "Microsoft.NETCore.DotNetHostPolicy"; version = "1.0.3"; hash = "sha256-doP+2c5SFVldt/EzgWW3nqKK+NNZKvBnanJbn2SKr2Q="; }) - (fetchNuGet { pname = "Microsoft.NETCore.DotNetHostResolver"; version = "1.0.1"; hash = "sha256-hGJLA8Q6R+up9zHzk+Up2KF1a+fXZeEWrAZ+iNfQP4E="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Jit"; version = "1.0.6"; hash = "sha256-MuphzrzUdSpgyB3ZU2Ly3DwaGSRuLUvonovIzBasB6o="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.0.2"; hash = "sha256-YLJ2+BONtCWb0lY4Rttdqzbcm4z+5N5uNr3byRWQOZ8="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Runtime.CoreCLR"; version = "1.0.6"; hash = "sha256-iZnxpUpUJDoEE/NjktTFfOYmi25RwC32NMu/OKXG3gA="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.0.1"; hash = "sha256-lxxw/Gy32xHi0fLgFWNj4YTFBSBkjx5l6ucmbTyf7V4="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Windows.ApiSets"; version = "1.0.1"; hash = "sha256-6PR4o/wQxBaJ5eRdt/awSO80EP3QqpWIk0XkCR9kaJo="; }) - (fetchNuGet { pname = "Microsoft.VisualBasic"; version = "10.0.1"; hash = "sha256-7HHzZcWLVTTQ1K1rCIyoB+UxLHMvOIz+O5av6XDa22A="; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.0.1"; hash = "sha256-B4t5El/ViBdxALMcpZulewc4j/3SIXf71HhJWhm4Ctk="; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.3.0"; hash = "sha256-mBNDmPXNTW54XLnPAUwBRvkIORFM7/j0D0I2SyQPDEg="; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "4.0.0"; hash = "sha256-M/06F/Z2wTHCh4pZOgtCjUGLD1FJXEJKCmzOeFMl7uo="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "1.6.0"; hash = "sha256-ExWI1EKDCRishcfAeHVS/RoJphqSqohmJIC/wz3ZtVo="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.0"; hash = "sha256-Pp7fRylai8JrE1O+9TGfIEJrAOmnWTJRLWE+qJBahK0="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.3"; hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tools"; version = "4.3.0"; hash = "sha256-8yLKFt2wQxkEf7fNfzB+cPUCjYn2qbqNgQ1+EeY2h/I="; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-dsmTLGvt8HqRkDWP8iKVXJCS+akAzENGXKPV18W2RgI="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization.Calendars"; version = "4.3.0"; hash = "sha256-AYh39tgXJVFu8aLi9Y/4rK8yWMaza4S4eaxjfcuEEL4="; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-6MYj0RmLh4EVqMtO/MRqBi0HOn5iG4x9JimgCCJ+EFM="; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Timer"; version = "4.3.0"; hash = "sha256-BgHxXCIbicVZtpgMimSXixhFC3V+p5ODqeljDjO8hCs="; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.0.0"; hash = "sha256-bmaM0ovT4X4aqDJOR255Yda/u3fmHZskU++lMnsy894="; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; }) - (fetchNuGet { pname = "runtime.native.System.IO.Compression"; version = "4.1.0"; hash = "sha256-085JrZxNEwIHdBWKKKFsh1JzpF0AblvrUsz5T8kH4jQ="; }) - (fetchNuGet { pname = "runtime.native.System.IO.Compression"; version = "4.3.0"; hash = "sha256-DWnXs4vlKoU6WxxvCArTJupV6sX3iBbZh8SbqfHace8="; }) - (fetchNuGet { pname = "runtime.native.System.Net.Http"; version = "4.0.1"; hash = "sha256-5nWnTQrA1T6t9r8MqIiV4yTNu+IH0of2OX1qteoS+8E="; }) - (fetchNuGet { pname = "runtime.native.System.Net.Security"; version = "4.0.1"; hash = "sha256-E64W+qCHZGYbhzQOEeToCob/4K8cTg3uOO7ltZG7ZNo="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography"; version = "4.0.0"; hash = "sha256-6Q8eYzC32BbGIiTHoQaE6B3cD81vYQcH5SCswYRSp0w="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; }) - (fetchNuGet { pname = "runtime.unix.Microsoft.Win32.Primitives"; version = "4.3.0"; hash = "sha256-LZb23lRXzr26tRS5aA0xyB08JxiblPDoA7HBvn6awXg="; }) - (fetchNuGet { pname = "runtime.unix.System.Console"; version = "4.3.0"; hash = "sha256-AHkdKShTRHttqfMjmi+lPpTuCrM5vd/WRy6Kbtie190="; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; }) - (fetchNuGet { pname = "runtime.unix.System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-Pf4mRl6YDK2x2KMh0WdyNgv0VUNdSKVDLlHqozecy5I="; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Primitives"; version = "4.3.0"; hash = "sha256-pHJ+I6i16MV6m77uhTC6GPY6jWGReE3SSP3fVB59ti0="; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Sockets"; version = "4.3.0"; hash = "sha256-IvgOeA2JuBjKl5yAVGjPYMPDzs9phb3KANs95H9v1w4="; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; }) - (fetchNuGet { pname = "System.AppContext"; version = "4.1.0"; hash = "sha256-v6YfyfrKmhww+EYHUq6cwYUMj00MQ6SOfJtcGVRlYzs="; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.0.0"; hash = "sha256-+YUymoyS0O+xVyF2+LiAdZlMww8nofPN4ja9ylYqRo8="; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.3.0"; hash = "sha256-XqZWb4Kd04960h4U9seivjKseGA/YEIpdplfHYHQ9jk="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.0.11"; hash = "sha256-puoFMkx4Z55C1XPxNw3np8nzNGjH+G24j43yTIsDRL0="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.0.12"; hash = "sha256-zIEM7AB4SyE9u6G8+o+gCLLwkgi6+3rHQVPdn/dEwB8="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "1.2.0"; hash = "sha256-FQ3l+ulbLSPhQ0JcQCC4D4SzjTnHsRqcOj56Ywy7pMo="; }) - (fetchNuGet { pname = "System.ComponentModel"; version = "4.0.1"; hash = "sha256-X5T36S49q1odsn6wAET6EGNlsxOyd66naMr5T3G9mGw="; }) - (fetchNuGet { pname = "System.ComponentModel.Annotations"; version = "4.1.0"; hash = "sha256-jhvr6zS+iC4OXBkdXr+S8rPy/5nfhZtDVVJiAc0f1VA="; }) - (fetchNuGet { pname = "System.Console"; version = "4.0.0"; hash = "sha256-jtZfT/TpJtLisV/y5Mk3IfCpE79zwhBYXtyGP9jC3Xo="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.0.11"; hash = "sha256-P+rSQJVoN6M56jQbs76kZ9G3mAWFdtF27P/RijN8sj4="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "4.0.0"; hash = "sha256-dYh9UoFesuGcHY+ewsI+z2WnNy+bwHPsHQ3t85cbzNg="; }) - (fetchNuGet { pname = "System.Diagnostics.FileVersionInfo"; version = "4.0.0"; hash = "sha256-Yy94jPhDXF2QHOF7qTmqKkn1048K9xkKryuBeDzsu+g="; }) - (fetchNuGet { pname = "System.Diagnostics.Process"; version = "4.1.0"; hash = "sha256-OgW6ogQ+oYADYS0PHmwXdhrOKQJpqXlwzSvmfjTLNBg="; }) - (fetchNuGet { pname = "System.Diagnostics.StackTrace"; version = "4.0.1"; hash = "sha256-gqqCAwpDsca242nli+fejgqwPAuwROv3NoNeOnFXSWA="; }) - (fetchNuGet { pname = "System.Diagnostics.Tools"; version = "4.0.1"; hash = "sha256-vSBqTbmWXylvRa37aWyktym+gOpsvH43mwr6A962k6U="; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.1.0"; hash = "sha256-JA0jJcLbU3zh52ub3zweob2EVHvxOqiC6SCYHrY5WbQ="; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.0.11"; hash = "sha256-qWqFVxuXioesVftv2RVJZOnmojUvRjb7cS3Oh3oTit4="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.0.11"; hash = "sha256-rbSgc2PIEc2c2rN6LK3qCREAX3DqA2Nq1WcLrZYsDBw="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.0.1"; hash = "sha256-EJN3LbN+b0O9Dr2eg7kfThCYpne0iJ/H/GIyUTNVYC8="; }) - (fetchNuGet { pname = "System.Globalization.Extensions"; version = "4.0.1"; hash = "sha256-zLtkPryJwqTGcJqMC6zoMMvMrT+aAL5GoumjmMtqUEI="; }) - (fetchNuGet { pname = "System.IO"; version = "4.1.0"; hash = "sha256-V6oyQFwWb8NvGxAwvzWnhPxy9dKOfj/XBM3tEC5aHrw="; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; }) - (fetchNuGet { pname = "System.IO.Compression"; version = "4.1.0"; hash = "sha256-UT4KEfJNZOk7b4X0AqLFUsqfHu6myVH/BhbRKYc+1Uc="; }) - (fetchNuGet { pname = "System.IO.Compression"; version = "4.3.0"; hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; }) - (fetchNuGet { pname = "System.IO.Compression.ZipFile"; version = "4.3.0"; hash = "sha256-WQl+JgWs+GaRMeiahTFUbrhlXIHapzcpTFXbRvAtvvs="; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.0.1"; hash = "sha256-4VKXFgcGYCTWVXjAlniAVq0dO3o5s8KHylg2wg2/7k0="; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.0.1"; hash = "sha256-IpigKMomqb6pmYWkrlf0ZdpILtRluX2cX5sOKVW0Feg="; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; }) - (fetchNuGet { pname = "System.IO.FileSystem.Watcher"; version = "4.0.0"; hash = "sha256-OcLhbiHvn453sJsZBHe6RmtDlCaaarcqRB439HGU7mU="; }) - (fetchNuGet { pname = "System.IO.MemoryMappedFiles"; version = "4.0.0"; hash = "sha256-1VQa8FoMUNAsja31OvOn7ungif+IPusAe9YcR+kRF6o="; }) - (fetchNuGet { pname = "System.IO.UnmanagedMemoryStream"; version = "4.0.1"; hash = "sha256-Sx60QjHjvXQMAL7O4aN81321gu13LE0XzCRtt7hFTwQ="; }) - (fetchNuGet { pname = "System.Linq"; version = "4.1.0"; hash = "sha256-ZQpFtYw5N1F1aX0jUK3Tw+XvM5tnlnshkTCNtfVA794="; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.1.1"; hash = "sha256-nwRmq03bvyYhohaDJtCYj4Z6hHsp0AlhjFJzuw7fsdk="; }) - (fetchNuGet { pname = "System.Linq.Parallel"; version = "4.0.1"; hash = "sha256-TV1F3KYFipPmPnWFjX6hOZQNFsG2m729EdgPSFzqY0Q="; }) - (fetchNuGet { pname = "System.Linq.Queryable"; version = "4.0.1"; hash = "sha256-XOFRO+lyoxsWtIUJfg5JCqv9Gx35ASOc94WIR8ZMVoY="; }) - (fetchNuGet { pname = "System.Net.Http"; version = "4.1.1"; hash = "sha256-+JTAbEt2BicpnP3ooKXludoS5nClzBOnUyI9C/XxyyM="; }) - (fetchNuGet { pname = "System.Net.NameResolution"; version = "4.0.0"; hash = "sha256-EAO67qEDqrtxEa+J3xccA5/lgCJ0PiRU9DYZsO++QzY="; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.0.11"; hash = "sha256-2YSijNhCdw/ZU2yfH7vE+ReA8pgxRCXPnWr+ab36v4M="; }) - (fetchNuGet { pname = "System.Net.Requests"; version = "4.0.11"; hash = "sha256-MLXxaUhHQC3pId/6r4q0EF37CIExt0+4Na8ZpUtRs44="; }) - (fetchNuGet { pname = "System.Net.Security"; version = "4.0.0"; hash = "sha256-65Vqr/B5B336KEW69aM95+f7s5u2Q7/OiJmBarV2fnk="; }) - (fetchNuGet { pname = "System.Net.Sockets"; version = "4.1.0"; hash = "sha256-muK7oXIX7ykqhXskuUt0KX6Hzg5VogJhUS0JiOB2BY0="; }) - (fetchNuGet { pname = "System.Net.WebHeaderCollection"; version = "4.0.1"; hash = "sha256-uJSV6kmL+V/9/ot1LhHXGCd8Ndcu6zk+AJ8wgGS/fYE="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.1.1"; hash = "sha256-Kv4FrStml5+X7hGDCLhJJaIwJDvdJdYMBfcCcOjNf/Y="; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.0.12"; hash = "sha256-MudZ/KYcvYsn2cST3EE049mLikrNkmE7QoUoYKKby+s="; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.1.0"; hash = "sha256-idZHGH2Yl/hha1CM4VzLhsaR8Ljo/rV7TYe7mwRJSMs="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; }) - (fetchNuGet { pname = "System.Reflection.DispatchProxy"; version = "4.0.1"; hash = "sha256-GdjA81UywW1yeAyNi+MR5agmOXl859GrWwiOui2jT9U="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.0.1"; hash = "sha256-F1MvYoQWHCY89/O4JBwswogitqVvKuVfILFqA7dmuHk="; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.0.1"; hash = "sha256-YG+eJBG5P+5adsHiw/lhJwvREnvdHw6CJyS8ZV4Ujd0="; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.0.1"; hash = "sha256-uVvNOnL64CPqsgZP2OLqNmxdkZl6Q0fTmKmv9gcBi+g="; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.0.1"; hash = "sha256-NsfmzM9G/sN3H8X2cdnheTGRsh7zbRzvegnjDzDH/FQ="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "1.3.0"; hash = "sha256-a/RQr++mSsziWaOTknicfIQX/zJrwPFExfhK6PM0tfg="; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.0.1"; hash = "sha256-SFSfpWEyCBMAOerrMCOiKnpT+UAWTvRcmoRquJR6Vq0="; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.1.0"; hash = "sha256-R0YZowmFda+xzKNR4kKg7neFoE30KfZwp/IwfRSKVK4="; }) - (fetchNuGet { pname = "System.Resources.Reader"; version = "4.0.0"; hash = "sha256-NOax26EYc/L4bfedL2a33fg4sFXVkBwzVTQ41saJTsk="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.0.1"; hash = "sha256-cZ2/3/fczLjEpn6j3xkgQV9ouOVjy4Kisgw5xWw9kSw="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.1.0"; hash = "sha256-FViNGM/4oWtlP6w0JC0vJU+k9efLKZ+yaXrnEeabDQo="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.1.0"; hash = "sha256-X7DZ5CbPY7jHs20YZ7bmcXs9B5Mxptu/HnBUvUnNhGc="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.0.1"; hash = "sha256-j2QgVO9ZOjv7D1het98CoFpjoYgxjupuIhuBUmLLH7w="; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.1.0"; hash = "sha256-QceAYlJvkPRJc/+5jR+wQpNNI3aqGySWWSO30e/FfQY="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices.RuntimeInformation"; version = "4.0.0"; hash = "sha256-5j53amb76A3SPiE3B0llT2XPx058+CgE7OXL4bLalT4="; }) - (fetchNuGet { pname = "System.Runtime.Loader"; version = "4.0.0"; hash = "sha256-gE5/ehU3Qq5phhSxGuPmSv1DFVQeiyl1/+YyrO+I7lI="; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.0.1"; hash = "sha256-1pJt5ZGxLPTX1mjOi8qZPXyyOMkYV0NstoUCv91HYPg="; }) - (fetchNuGet { pname = "System.Security.Claims"; version = "4.0.1"; hash = "sha256-xqI0HHahNAd9g3jqgnLKH4P/pIueef6cy3qvRDQFvA0="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.2.0"; hash = "sha256-BelNIpEyToEp/VYKnje/q1P7KNEpQNtOzGPU18pLGpE="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.2.0"; hash = "sha256-7F+m3HnmBsgE4xWF8FeCGlaEgQM3drqA6HEaQr6MEoU="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Csp"; version = "4.0.0"; hash = "sha256-WHyR6vVK3zaT4De7jgQFUar1P5fiX9ECwiVkJDFFm7M="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.0.0"; hash = "sha256-ZO7ha39J5uHkIF2RoEKv/bW/bLbVvYMO4+rWyYsKHik="; }) - (fetchNuGet { pname = "System.Security.Cryptography.OpenSsl"; version = "4.0.0"; hash = "sha256-mLijAozynzjiOMyh2P5BHcfVq3Ovd0T/phG08SIbXZs="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.0.0"; hash = "sha256-sEdPftfTxQd/8DpdpqUZC2XWC0SjVCPqAkEleLl17EQ="; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.1.0"; hash = "sha256-sBUUhJP+yYDXvcjNMKqNpn8yzGUpVABwK9vVUvYKjzI="; }) - (fetchNuGet { pname = "System.Security.Principal"; version = "4.0.1"; hash = "sha256-9wBgPnJfFOtrhKZ7wDXZ4q12GklQ49Ka02/9v7Frf9k="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.0.0"; hash = "sha256-38wEUCB889Mpm4WgRFEQBB+4HtE0X0wu+knrDyJie7Q="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.0.11"; hash = "sha256-PEailOvG05CVgPTyKLtpAgRydlSHmtd5K0Y8GSHY2Lc="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "4.0.1"; hash = "sha256-wxtwWQSTv5tuFP79KhUAhaL6bL4d8lSzSWkCn9aolwM="; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.0.11"; hash = "sha256-+kf7J3dEhgCbnCM5vHYlsTm5/R/Ud0Jr6elpHm922iI="; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; }) - (fetchNuGet { pname = "System.Text.RegularExpressions"; version = "4.1.0"; hash = "sha256-x6OQN6MCN7S0fJ6EFTfv4rczdUWjwuWE9QQ0P6fbh9c="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.0.11"; hash = "sha256-mob1Zv3qLQhQ1/xOLXZmYqpniNUMCfn02n8ZkaAhqac="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; }) - (fetchNuGet { pname = "System.Threading.Overlapped"; version = "4.0.1"; hash = "sha256-CAWZlavcuBQHs+kaSX9CmkpHF7wC8rFrug3XPb5KJzo="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.0.11"; hash = "sha256-5SLxzFg1df6bTm2t09xeI01wa5qQglqUwwJNlQPJIVs="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Dataflow"; version = "4.6.0"; hash = "sha256-YYrT3GRzVBdendxt8FUDCnOBJi0nw/CJ9VrzcPJWLSg="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.0.0"; hash = "sha256-+YdcPkMhZhRbMZHnfsDwpNbUkr31X7pQFGxXYcAPZbE="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Parallel"; version = "4.0.1"; hash = "sha256-5VyRZ97Fug4reK/cQ6wsCrJ5jH53aGu1a4ZkKMZrnIQ="; }) - (fetchNuGet { pname = "System.Threading.Thread"; version = "4.0.0"; hash = "sha256-7EtSJuKqcW107FYA5Ko9NFXEWUPIzNDtlfKaQV2pvb8="; }) - (fetchNuGet { pname = "System.Threading.ThreadPool"; version = "4.0.10"; hash = "sha256-/fowWjM/0ZZFC1Rwu0i5N71iRxV2JOd3jQV2Jn0wuTk="; }) - (fetchNuGet { pname = "System.Threading.Timer"; version = "4.0.1"; hash = "sha256-5lU6zt1O9JDSPr2KAHw4BYgysHnt0yyZrMNa5IIjxZY="; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.0.11"; hash = "sha256-haZAFFQ9Sl2DhfvEbdx2YRqKEoxNMU5STaqpMmXw0zA="; }) - (fetchNuGet { pname = "System.Xml.XDocument"; version = "4.0.11"; hash = "sha256-KPz1kxe0RUBM+aoktJ/f9p51GudMERU8Pmwm//HdlFg="; }) - (fetchNuGet { pname = "System.Xml.XmlDocument"; version = "4.0.1"; hash = "sha256-gdoFrPo54v1LjkBF79f8EvtltVVjHz9ZI9kc5ve0GkY="; }) - (fetchNuGet { pname = "System.Xml.XPath"; version = "4.0.1"; hash = "sha256-lQCoK2M51SGRuGjfiuIW26Y2goABY2RLE6cZ4816WDo="; }) - (fetchNuGet { pname = "System.Xml.XPath.XDocument"; version = "4.0.1"; hash = "sha256-H/zyMMB1YB8vd+StYJr99KLqWmSHhaP7RHDLRcFhzbo="; }) - (fetchNuGet { pname = "UrlCombine"; version = "2.0.0"; hash = "sha256-yvBqXgZsqre+JIyxY/e8y+oBs2+K7PtJkITR3YEtHlU="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "CommandLineParser"; + version = "2.9.1"; + hash = "sha256-ApU9y1yX60daSjPk3KYDBeJ7XZByKW8hse9NRZGcjeo="; + }) + (fetchNuGet { + pname = "ConsoleMenu-simple"; + version = "2.6.1"; + hash = "sha256-1bMCCWLnJ7rCtaLyz+AF8YOZK9qktqy0HZhqyPQ5ce0="; + }) + (fetchNuGet { + pname = "Crc32.NET"; + version = "1.2.0"; + hash = "sha256-sMQNIppJXHU2mULn5b//uRbbPMyguH9QlG6HKVIYUmE="; + }) + (fetchNuGet { + pname = "Libuv"; + version = "1.9.1"; + hash = "sha256-bQdVn50eId1GzSQa9CFth0meKAQMYCFQ98zLN9pqL0k="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.App.Ref"; + version = "7.0.20"; + hash = "sha256-OEDXXjQ1HDRPiA4Y1zPr1xUeH6wlzTCJpts+DZL61wI="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; + version = "7.0.20"; + hash = "sha256-ewal9R6o20GV0R02ylSijVFdWZAbdN8TK1PCc/ltHBQ="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; + version = "7.0.20"; + hash = "sha256-vq59xMfrET8InzUhkAsbs2xp3ML+SO9POsbwAiYKzkA="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "1.1.0"; + hash = "sha256-7KrZfK3kUbmeT82eVadvHurZcaFq3FDj4qkIIeExJiM="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "1.3.0"; + hash = "sha256-Jcw54WWyfPKdkeqRAG4xjihiGP/djjAkvpR6KM2I+CQ="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "1.3.0"; + hash = "sha256-OqqvMHNj9Xql4YTEPMlzoGXXELoLC7JkRGjS0pil+m4="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.VisualBasic"; + version = "1.3.0"; + hash = "sha256-lIKN1dG59aY8zeYgkY8Kdnv4UBgSwVbghz5ngPyEzKA="; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.0.1"; + hash = "sha256-0huoqR2CJ3Z9Q2peaKD09TV3E6saYSqDGZ290K8CrH8="; + }) + (fetchNuGet { + pname = "Microsoft.NET.ILLink.Analyzers"; + version = "7.0.100-1.23401.1"; + hash = "sha256-jGyhmj7DZxTv9Hir6YonkpL+SDsRore8Ph4RNN+2q94="; + }) + (fetchNuGet { + pname = "Microsoft.NET.ILLink.Tasks"; + version = "7.0.100-1.23401.1"; + hash = "sha256-n95rHugj0BOtCBvv5209zJ5ttPX0A2+RWLjEwwtxgRA="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App"; + version = "1.0.4"; + hash = "sha256-NqJEOTW98eO0UlbiZcIVrsZCY4MUa+CkSmtAx3e2g3k="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Host.linux-arm64"; + version = "7.0.20"; + hash = "sha256-/20dMbO1Ft0WVhl+Lv1916Thvr4kPP9LuuX4bKE+czE="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Host.linux-x64"; + version = "7.0.20"; + hash = "sha256-Y1Dg8Sqhya86xD+9aJOuznT4mJUyFmoF/YZc0+5LBdc="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Ref"; + version = "7.0.20"; + hash = "sha256-W9RU3bja4BQLAbsaIhANQPJJh6DycDiBR+WZ3mK6Zrs="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; + version = "7.0.20"; + hash = "sha256-TemMvbNrDzJVHWwxVgnNN2CnTyI6TcvvZDpF4ts6IAw="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Runtime.linux-x64"; + version = "7.0.20"; + hash = "sha256-L+WaGvoXVMT3tZ7R5xFE06zaLcC3SI7LEf4ATBkUAGQ="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.DotNetHost"; + version = "1.0.1"; + hash = "sha256-yiyZ4KGVRDZRgAuoSl4ZNWnRR3ityniyRPvzS799JOM="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.DotNetHostPolicy"; + version = "1.0.3"; + hash = "sha256-doP+2c5SFVldt/EzgWW3nqKK+NNZKvBnanJbn2SKr2Q="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.DotNetHostResolver"; + version = "1.0.1"; + hash = "sha256-hGJLA8Q6R+up9zHzk+Up2KF1a+fXZeEWrAZ+iNfQP4E="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Jit"; + version = "1.0.6"; + hash = "sha256-MuphzrzUdSpgyB3ZU2Ly3DwaGSRuLUvonovIzBasB6o="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.0.2"; + hash = "sha256-YLJ2+BONtCWb0lY4Rttdqzbcm4z+5N5uNr3byRWQOZ8="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Runtime.CoreCLR"; + version = "1.0.6"; + hash = "sha256-iZnxpUpUJDoEE/NjktTFfOYmi25RwC32NMu/OKXG3gA="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.0.1"; + hash = "sha256-lxxw/Gy32xHi0fLgFWNj4YTFBSBkjx5l6ucmbTyf7V4="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Windows.ApiSets"; + version = "1.0.1"; + hash = "sha256-6PR4o/wQxBaJ5eRdt/awSO80EP3QqpWIk0XkCR9kaJo="; + }) + (fetchNuGet { + pname = "Microsoft.VisualBasic"; + version = "10.0.1"; + hash = "sha256-7HHzZcWLVTTQ1K1rCIyoB+UxLHMvOIz+O5av6XDa22A="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.0.1"; + hash = "sha256-B4t5El/ViBdxALMcpZulewc4j/3SIXf71HhJWhm4Ctk="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.3.0"; + hash = "sha256-mBNDmPXNTW54XLnPAUwBRvkIORFM7/j0D0I2SyQPDEg="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "4.0.0"; + hash = "sha256-M/06F/Z2wTHCh4pZOgtCjUGLD1FJXEJKCmzOeFMl7uo="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "1.6.0"; + hash = "sha256-ExWI1EKDCRishcfAeHVS/RoJphqSqohmJIC/wz3ZtVo="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.0"; + hash = "sha256-Pp7fRylai8JrE1O+9TGfIEJrAOmnWTJRLWE+qJBahK0="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.3"; + hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tools"; + version = "4.3.0"; + hash = "sha256-8yLKFt2wQxkEf7fNfzB+cPUCjYn2qbqNgQ1+EeY2h/I="; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-dsmTLGvt8HqRkDWP8iKVXJCS+akAzENGXKPV18W2RgI="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization.Calendars"; + version = "4.3.0"; + hash = "sha256-AYh39tgXJVFu8aLi9Y/4rK8yWMaza4S4eaxjfcuEEL4="; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-6MYj0RmLh4EVqMtO/MRqBi0HOn5iG4x9JimgCCJ+EFM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Timer"; + version = "4.3.0"; + hash = "sha256-BgHxXCIbicVZtpgMimSXixhFC3V+p5ODqeljDjO8hCs="; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.0.0"; + hash = "sha256-bmaM0ovT4X4aqDJOR255Yda/u3fmHZskU++lMnsy894="; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; + }) + (fetchNuGet { + pname = "runtime.native.System.IO.Compression"; + version = "4.1.0"; + hash = "sha256-085JrZxNEwIHdBWKKKFsh1JzpF0AblvrUsz5T8kH4jQ="; + }) + (fetchNuGet { + pname = "runtime.native.System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-DWnXs4vlKoU6WxxvCArTJupV6sX3iBbZh8SbqfHace8="; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Http"; + version = "4.0.1"; + hash = "sha256-5nWnTQrA1T6t9r8MqIiV4yTNu+IH0of2OX1qteoS+8E="; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Security"; + version = "4.0.1"; + hash = "sha256-E64W+qCHZGYbhzQOEeToCob/4K8cTg3uOO7ltZG7ZNo="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography"; + version = "4.0.0"; + hash = "sha256-6Q8eYzC32BbGIiTHoQaE6B3cD81vYQcH5SCswYRSp0w="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; + }) + (fetchNuGet { + pname = "runtime.unix.Microsoft.Win32.Primitives"; + version = "4.3.0"; + hash = "sha256-LZb23lRXzr26tRS5aA0xyB08JxiblPDoA7HBvn6awXg="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Console"; + version = "4.3.0"; + hash = "sha256-AHkdKShTRHttqfMjmi+lPpTuCrM5vd/WRy6Kbtie190="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; + }) + (fetchNuGet { + pname = "runtime.unix.System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-Pf4mRl6YDK2x2KMh0WdyNgv0VUNdSKVDLlHqozecy5I="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Primitives"; + version = "4.3.0"; + hash = "sha256-pHJ+I6i16MV6m77uhTC6GPY6jWGReE3SSP3fVB59ti0="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Sockets"; + version = "4.3.0"; + hash = "sha256-IvgOeA2JuBjKl5yAVGjPYMPDzs9phb3KANs95H9v1w4="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; + }) + (fetchNuGet { + pname = "System.AppContext"; + version = "4.1.0"; + hash = "sha256-v6YfyfrKmhww+EYHUq6cwYUMj00MQ6SOfJtcGVRlYzs="; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.0.0"; + hash = "sha256-+YUymoyS0O+xVyF2+LiAdZlMww8nofPN4ja9ylYqRo8="; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.3.0"; + hash = "sha256-XqZWb4Kd04960h4U9seivjKseGA/YEIpdplfHYHQ9jk="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.0.11"; + hash = "sha256-puoFMkx4Z55C1XPxNw3np8nzNGjH+G24j43yTIsDRL0="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.0.12"; + hash = "sha256-zIEM7AB4SyE9u6G8+o+gCLLwkgi6+3rHQVPdn/dEwB8="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "1.2.0"; + hash = "sha256-FQ3l+ulbLSPhQ0JcQCC4D4SzjTnHsRqcOj56Ywy7pMo="; + }) + (fetchNuGet { + pname = "System.ComponentModel"; + version = "4.0.1"; + hash = "sha256-X5T36S49q1odsn6wAET6EGNlsxOyd66naMr5T3G9mGw="; + }) + (fetchNuGet { + pname = "System.ComponentModel.Annotations"; + version = "4.1.0"; + hash = "sha256-jhvr6zS+iC4OXBkdXr+S8rPy/5nfhZtDVVJiAc0f1VA="; + }) + (fetchNuGet { + pname = "System.Console"; + version = "4.0.0"; + hash = "sha256-jtZfT/TpJtLisV/y5Mk3IfCpE79zwhBYXtyGP9jC3Xo="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.0.11"; + hash = "sha256-P+rSQJVoN6M56jQbs76kZ9G3mAWFdtF27P/RijN8sj4="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "4.0.0"; + hash = "sha256-dYh9UoFesuGcHY+ewsI+z2WnNy+bwHPsHQ3t85cbzNg="; + }) + (fetchNuGet { + pname = "System.Diagnostics.FileVersionInfo"; + version = "4.0.0"; + hash = "sha256-Yy94jPhDXF2QHOF7qTmqKkn1048K9xkKryuBeDzsu+g="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Process"; + version = "4.1.0"; + hash = "sha256-OgW6ogQ+oYADYS0PHmwXdhrOKQJpqXlwzSvmfjTLNBg="; + }) + (fetchNuGet { + pname = "System.Diagnostics.StackTrace"; + version = "4.0.1"; + hash = "sha256-gqqCAwpDsca242nli+fejgqwPAuwROv3NoNeOnFXSWA="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tools"; + version = "4.0.1"; + hash = "sha256-vSBqTbmWXylvRa37aWyktym+gOpsvH43mwr6A962k6U="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.1.0"; + hash = "sha256-JA0jJcLbU3zh52ub3zweob2EVHvxOqiC6SCYHrY5WbQ="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.0.11"; + hash = "sha256-qWqFVxuXioesVftv2RVJZOnmojUvRjb7cS3Oh3oTit4="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.0.11"; + hash = "sha256-rbSgc2PIEc2c2rN6LK3qCREAX3DqA2Nq1WcLrZYsDBw="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.0.1"; + hash = "sha256-EJN3LbN+b0O9Dr2eg7kfThCYpne0iJ/H/GIyUTNVYC8="; + }) + (fetchNuGet { + pname = "System.Globalization.Extensions"; + version = "4.0.1"; + hash = "sha256-zLtkPryJwqTGcJqMC6zoMMvMrT+aAL5GoumjmMtqUEI="; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.1.0"; + hash = "sha256-V6oyQFwWb8NvGxAwvzWnhPxy9dKOfj/XBM3tEC5aHrw="; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; + }) + (fetchNuGet { + pname = "System.IO.Compression"; + version = "4.1.0"; + hash = "sha256-UT4KEfJNZOk7b4X0AqLFUsqfHu6myVH/BhbRKYc+1Uc="; + }) + (fetchNuGet { + pname = "System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; + }) + (fetchNuGet { + pname = "System.IO.Compression.ZipFile"; + version = "4.3.0"; + hash = "sha256-WQl+JgWs+GaRMeiahTFUbrhlXIHapzcpTFXbRvAtvvs="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.0.1"; + hash = "sha256-4VKXFgcGYCTWVXjAlniAVq0dO3o5s8KHylg2wg2/7k0="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.0.1"; + hash = "sha256-IpigKMomqb6pmYWkrlf0ZdpILtRluX2cX5sOKVW0Feg="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Watcher"; + version = "4.0.0"; + hash = "sha256-OcLhbiHvn453sJsZBHe6RmtDlCaaarcqRB439HGU7mU="; + }) + (fetchNuGet { + pname = "System.IO.MemoryMappedFiles"; + version = "4.0.0"; + hash = "sha256-1VQa8FoMUNAsja31OvOn7ungif+IPusAe9YcR+kRF6o="; + }) + (fetchNuGet { + pname = "System.IO.UnmanagedMemoryStream"; + version = "4.0.1"; + hash = "sha256-Sx60QjHjvXQMAL7O4aN81321gu13LE0XzCRtt7hFTwQ="; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.1.0"; + hash = "sha256-ZQpFtYw5N1F1aX0jUK3Tw+XvM5tnlnshkTCNtfVA794="; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.1.1"; + hash = "sha256-nwRmq03bvyYhohaDJtCYj4Z6hHsp0AlhjFJzuw7fsdk="; + }) + (fetchNuGet { + pname = "System.Linq.Parallel"; + version = "4.0.1"; + hash = "sha256-TV1F3KYFipPmPnWFjX6hOZQNFsG2m729EdgPSFzqY0Q="; + }) + (fetchNuGet { + pname = "System.Linq.Queryable"; + version = "4.0.1"; + hash = "sha256-XOFRO+lyoxsWtIUJfg5JCqv9Gx35ASOc94WIR8ZMVoY="; + }) + (fetchNuGet { + pname = "System.Net.Http"; + version = "4.1.1"; + hash = "sha256-+JTAbEt2BicpnP3ooKXludoS5nClzBOnUyI9C/XxyyM="; + }) + (fetchNuGet { + pname = "System.Net.NameResolution"; + version = "4.0.0"; + hash = "sha256-EAO67qEDqrtxEa+J3xccA5/lgCJ0PiRU9DYZsO++QzY="; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.0.11"; + hash = "sha256-2YSijNhCdw/ZU2yfH7vE+ReA8pgxRCXPnWr+ab36v4M="; + }) + (fetchNuGet { + pname = "System.Net.Requests"; + version = "4.0.11"; + hash = "sha256-MLXxaUhHQC3pId/6r4q0EF37CIExt0+4Na8ZpUtRs44="; + }) + (fetchNuGet { + pname = "System.Net.Security"; + version = "4.0.0"; + hash = "sha256-65Vqr/B5B336KEW69aM95+f7s5u2Q7/OiJmBarV2fnk="; + }) + (fetchNuGet { + pname = "System.Net.Sockets"; + version = "4.1.0"; + hash = "sha256-muK7oXIX7ykqhXskuUt0KX6Hzg5VogJhUS0JiOB2BY0="; + }) + (fetchNuGet { + pname = "System.Net.WebHeaderCollection"; + version = "4.0.1"; + hash = "sha256-uJSV6kmL+V/9/ot1LhHXGCd8Ndcu6zk+AJ8wgGS/fYE="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.1.1"; + hash = "sha256-Kv4FrStml5+X7hGDCLhJJaIwJDvdJdYMBfcCcOjNf/Y="; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.0.12"; + hash = "sha256-MudZ/KYcvYsn2cST3EE049mLikrNkmE7QoUoYKKby+s="; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.1.0"; + hash = "sha256-idZHGH2Yl/hha1CM4VzLhsaR8Ljo/rV7TYe7mwRJSMs="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; + }) + (fetchNuGet { + pname = "System.Reflection.DispatchProxy"; + version = "4.0.1"; + hash = "sha256-GdjA81UywW1yeAyNi+MR5agmOXl859GrWwiOui2jT9U="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.0.1"; + hash = "sha256-F1MvYoQWHCY89/O4JBwswogitqVvKuVfILFqA7dmuHk="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.0.1"; + hash = "sha256-YG+eJBG5P+5adsHiw/lhJwvREnvdHw6CJyS8ZV4Ujd0="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.0.1"; + hash = "sha256-uVvNOnL64CPqsgZP2OLqNmxdkZl6Q0fTmKmv9gcBi+g="; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.0.1"; + hash = "sha256-NsfmzM9G/sN3H8X2cdnheTGRsh7zbRzvegnjDzDH/FQ="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "1.3.0"; + hash = "sha256-a/RQr++mSsziWaOTknicfIQX/zJrwPFExfhK6PM0tfg="; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.0.1"; + hash = "sha256-SFSfpWEyCBMAOerrMCOiKnpT+UAWTvRcmoRquJR6Vq0="; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.1.0"; + hash = "sha256-R0YZowmFda+xzKNR4kKg7neFoE30KfZwp/IwfRSKVK4="; + }) + (fetchNuGet { + pname = "System.Resources.Reader"; + version = "4.0.0"; + hash = "sha256-NOax26EYc/L4bfedL2a33fg4sFXVkBwzVTQ41saJTsk="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.0.1"; + hash = "sha256-cZ2/3/fczLjEpn6j3xkgQV9ouOVjy4Kisgw5xWw9kSw="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.1.0"; + hash = "sha256-FViNGM/4oWtlP6w0JC0vJU+k9efLKZ+yaXrnEeabDQo="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.1.0"; + hash = "sha256-X7DZ5CbPY7jHs20YZ7bmcXs9B5Mxptu/HnBUvUnNhGc="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.0.1"; + hash = "sha256-j2QgVO9ZOjv7D1het98CoFpjoYgxjupuIhuBUmLLH7w="; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.1.0"; + hash = "sha256-QceAYlJvkPRJc/+5jR+wQpNNI3aqGySWWSO30e/FfQY="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices.RuntimeInformation"; + version = "4.0.0"; + hash = "sha256-5j53amb76A3SPiE3B0llT2XPx058+CgE7OXL4bLalT4="; + }) + (fetchNuGet { + pname = "System.Runtime.Loader"; + version = "4.0.0"; + hash = "sha256-gE5/ehU3Qq5phhSxGuPmSv1DFVQeiyl1/+YyrO+I7lI="; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.0.1"; + hash = "sha256-1pJt5ZGxLPTX1mjOi8qZPXyyOMkYV0NstoUCv91HYPg="; + }) + (fetchNuGet { + pname = "System.Security.Claims"; + version = "4.0.1"; + hash = "sha256-xqI0HHahNAd9g3jqgnLKH4P/pIueef6cy3qvRDQFvA0="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.2.0"; + hash = "sha256-BelNIpEyToEp/VYKnje/q1P7KNEpQNtOzGPU18pLGpE="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.2.0"; + hash = "sha256-7F+m3HnmBsgE4xWF8FeCGlaEgQM3drqA6HEaQr6MEoU="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Csp"; + version = "4.0.0"; + hash = "sha256-WHyR6vVK3zaT4De7jgQFUar1P5fiX9ECwiVkJDFFm7M="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.0.0"; + hash = "sha256-ZO7ha39J5uHkIF2RoEKv/bW/bLbVvYMO4+rWyYsKHik="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.OpenSsl"; + version = "4.0.0"; + hash = "sha256-mLijAozynzjiOMyh2P5BHcfVq3Ovd0T/phG08SIbXZs="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.0.0"; + hash = "sha256-sEdPftfTxQd/8DpdpqUZC2XWC0SjVCPqAkEleLl17EQ="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.1.0"; + hash = "sha256-sBUUhJP+yYDXvcjNMKqNpn8yzGUpVABwK9vVUvYKjzI="; + }) + (fetchNuGet { + pname = "System.Security.Principal"; + version = "4.0.1"; + hash = "sha256-9wBgPnJfFOtrhKZ7wDXZ4q12GklQ49Ka02/9v7Frf9k="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.0.0"; + hash = "sha256-38wEUCB889Mpm4WgRFEQBB+4HtE0X0wu+knrDyJie7Q="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.0.11"; + hash = "sha256-PEailOvG05CVgPTyKLtpAgRydlSHmtd5K0Y8GSHY2Lc="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "4.0.1"; + hash = "sha256-wxtwWQSTv5tuFP79KhUAhaL6bL4d8lSzSWkCn9aolwM="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.0.11"; + hash = "sha256-+kf7J3dEhgCbnCM5vHYlsTm5/R/Ud0Jr6elpHm922iI="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; + }) + (fetchNuGet { + pname = "System.Text.RegularExpressions"; + version = "4.1.0"; + hash = "sha256-x6OQN6MCN7S0fJ6EFTfv4rczdUWjwuWE9QQ0P6fbh9c="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.0.11"; + hash = "sha256-mob1Zv3qLQhQ1/xOLXZmYqpniNUMCfn02n8ZkaAhqac="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; + }) + (fetchNuGet { + pname = "System.Threading.Overlapped"; + version = "4.0.1"; + hash = "sha256-CAWZlavcuBQHs+kaSX9CmkpHF7wC8rFrug3XPb5KJzo="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.0.11"; + hash = "sha256-5SLxzFg1df6bTm2t09xeI01wa5qQglqUwwJNlQPJIVs="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Dataflow"; + version = "4.6.0"; + hash = "sha256-YYrT3GRzVBdendxt8FUDCnOBJi0nw/CJ9VrzcPJWLSg="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.0.0"; + hash = "sha256-+YdcPkMhZhRbMZHnfsDwpNbUkr31X7pQFGxXYcAPZbE="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Parallel"; + version = "4.0.1"; + hash = "sha256-5VyRZ97Fug4reK/cQ6wsCrJ5jH53aGu1a4ZkKMZrnIQ="; + }) + (fetchNuGet { + pname = "System.Threading.Thread"; + version = "4.0.0"; + hash = "sha256-7EtSJuKqcW107FYA5Ko9NFXEWUPIzNDtlfKaQV2pvb8="; + }) + (fetchNuGet { + pname = "System.Threading.ThreadPool"; + version = "4.0.10"; + hash = "sha256-/fowWjM/0ZZFC1Rwu0i5N71iRxV2JOd3jQV2Jn0wuTk="; + }) + (fetchNuGet { + pname = "System.Threading.Timer"; + version = "4.0.1"; + hash = "sha256-5lU6zt1O9JDSPr2KAHw4BYgysHnt0yyZrMNa5IIjxZY="; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.0.11"; + hash = "sha256-haZAFFQ9Sl2DhfvEbdx2YRqKEoxNMU5STaqpMmXw0zA="; + }) + (fetchNuGet { + pname = "System.Xml.XDocument"; + version = "4.0.11"; + hash = "sha256-KPz1kxe0RUBM+aoktJ/f9p51GudMERU8Pmwm//HdlFg="; + }) + (fetchNuGet { + pname = "System.Xml.XmlDocument"; + version = "4.0.1"; + hash = "sha256-gdoFrPo54v1LjkBF79f8EvtltVVjHz9ZI9kc5ve0GkY="; + }) + (fetchNuGet { + pname = "System.Xml.XPath"; + version = "4.0.1"; + hash = "sha256-lQCoK2M51SGRuGjfiuIW26Y2goABY2RLE6cZ4816WDo="; + }) + (fetchNuGet { + pname = "System.Xml.XPath.XDocument"; + version = "4.0.1"; + hash = "sha256-H/zyMMB1YB8vd+StYJr99KLqWmSHhaP7RHDLRcFhzbo="; + }) + (fetchNuGet { + pname = "UrlCombine"; + version = "2.0.0"; + hash = "sha256-yvBqXgZsqre+JIyxY/e8y+oBs2+K7PtJkITR3YEtHlU="; + }) ] diff --git a/pkgs/by-name/pu/pupdate/package.nix b/pkgs/by-name/pu/pupdate/package.nix index 71ff2d7251ba4f..4f62897370647d 100644 --- a/pkgs/by-name/pu/pupdate/package.nix +++ b/pkgs/by-name/pu/pupdate/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, buildDotnetModule -, dotnetCorePackages -, openssl -, zlib -, nix-update-script +{ + stdenv, + lib, + fetchFromGitHub, + buildDotnetModule, + dotnetCorePackages, + openssl, + zlib, + nix-update-script, }: buildDotnetModule rec { diff --git a/pkgs/by-name/pu/puppet-bolt/gemset.nix b/pkgs/by-name/pu/puppet-bolt/gemset.nix index 72746d92dc0d72..536eabfe265609 100644 --- a/pkgs/by-name/pu/puppet-bolt/gemset.nix +++ b/pkgs/by-name/pu/puppet-bolt/gemset.nix @@ -1,936 +1,1066 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gvdg4yx4p9av2glmp7vsxhs0n8fj1ga9kq2xdb8f95j7b04qhzi"; type = "gem"; }; version = "1.3.0"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0m74rrlwv741wlp2imw5y93ybrzczx0r2jvcgp1v4zq299z3zy29"; type = "gem"; }; version = "1.968.0"; }; aws-sdk-core = { - dependencies = ["aws-eventstream" "aws-partitions" "aws-sigv4" "jmespath"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-eventstream" + "aws-partitions" + "aws-sigv4" + "jmespath" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0l5c37gvarb3p3zsip1p9mpmir0zdccp0aibgx9cy61im4pwaj0q"; type = "gem"; }; version = "3.201.5"; }; aws-sdk-ec2 = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0z7zk5z9zyqqljh8fxhq8ngp8pixbm85pa9ygpr0nmgdl2b1i7ff"; type = "gem"; }; version = "1.470.0"; }; aws-sigv4 = { - dependencies = ["aws-eventstream"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-eventstream" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yf396fxashbqn0drbnvd9srxfg7w06v70q8kqpzi04zqchf6lvp"; type = "gem"; }; version = "1.9.1"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; bindata = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08r67nglsqnxrbn803szf5bdnqhchhq8kf2by94f37fcl65wpp19"; type = "gem"; }; version = "2.5.0"; }; bolt = { - dependencies = ["CFPropertyList" "addressable" "aws-sdk-ec2" "concurrent-ruby" "ffi" "hiera-eyaml" "jwt" "logging" "minitar" "net-scp" "net-ssh" "net-ssh-krb" "orchestrator_client" "puppet" "puppet-resource_api" "puppet-strings" "puppetfile-resolver" "r10k" "ruby_smb" "terminal-table" "winrm" "winrm-fs"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "CFPropertyList" + "addressable" + "aws-sdk-ec2" + "concurrent-ruby" + "ffi" + "hiera-eyaml" + "jwt" + "logging" + "minitar" + "net-scp" + "net-ssh" + "net-ssh-krb" + "orchestrator_client" + "puppet" + "puppet-resource_api" + "puppet-strings" + "puppetfile-resolver" + "r10k" + "ruby_smb" + "terminal-table" + "winrm" + "winrm-fs" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0krs4mmy1db531gyibhzaxmghb606yjmqqyfghvriy7b9sgi6bq8"; type = "gem"; }; version = "3.30.0"; }; builder = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pw3r2lyagsxkm71bf44v5b74f7l9r7di22brbyji9fwz791hya9"; type = "gem"; }; version = "3.3.0"; }; CFPropertyList = { - dependencies = ["base64" "nkf" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "nkf" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k1w5i4lb1z941m7ds858nly33f3iv12wvr1zav5x3fa99hj2my4"; type = "gem"; }; version = "3.0.7"; }; colored2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jlbqa9q4mvrm73aw9mxh23ygzbjiqwisl32d8szfb5fxvbjng5i"; type = "gem"; }; version = "3.1.2"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; connection_pool = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; cri = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rank6i9p2drwdcmhan6ifkzrz1v3mwpx47fwjl75rskxwjfkgwa"; type = "gem"; }; version = "2.15.12"; }; deep_merge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fjn4civid68a3zxnbgyjj6krs3l30dy8b4djpg6fpzrsyix7kl3"; type = "gem"; }; version = "1.2.2"; }; erubi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qnd6ff4az22ysnmni3730c41b979xinilahzg86bn7gv93ip9pw"; type = "gem"; }; version = "1.13.0"; }; facter = { - dependencies = ["hocon" "thor"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "hocon" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0pxpldfcf40dr9khra3sa131ij7gzd97bba2vpw89c785pl736a7"; type = "gem"; }; version = "4.6.1"; }; faraday = { - dependencies = ["faraday-em_http" "faraday-em_synchrony" "faraday-excon" "faraday-httpclient" "faraday-multipart" "faraday-net_http" "faraday-net_http_persistent" "faraday-patron" "faraday-rack" "faraday-retry" "ruby2_keywords"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-em_http" + "faraday-em_synchrony" + "faraday-excon" + "faraday-httpclient" + "faraday-multipart" + "faraday-net_http" + "faraday-net_http_persistent" + "faraday-patron" + "faraday-rack" + "faraday-retry" + "ruby2_keywords" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1c760q0ks4vj4wmaa7nh1dgvgqiwaw0mjr7v8cymy7i3ffgjxx90"; type = "gem"; }; version = "1.10.3"; }; faraday-em_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12cnqpbak4vhikrh2cdn94assh3yxza8rq2p9w2j34bqg5q4qgbs"; type = "gem"; }; version = "1.0.0"; }; faraday-em_synchrony = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vgrbhkp83sngv6k4mii9f2s9v5lmp693hylfxp2ssfc60fas3a6"; type = "gem"; }; version = "1.0.0"; }; faraday-excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h09wkb0k0bhm6dqsd47ac601qiaah8qdzjh8gvxfd376x1chmdh"; type = "gem"; }; version = "1.1.0"; }; faraday-httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fyk0jd3ks7fdn8nv3spnwjpzx2lmxmg2gh4inz3by1zjzqg33sc"; type = "gem"; }; version = "1.0.1"; }; faraday-multipart = { - dependencies = ["multipart-post"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multipart-post" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09871c4hd7s5ws1wl4gs7js1k2wlby6v947m2bbzg43pnld044lh"; type = "gem"; }; version = "1.0.4"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10n6wikd442mfm15hd6gzm0qb527161w1wwch4h5m4iclkz2x6b3"; type = "gem"; }; version = "1.0.2"; }; faraday-net_http_persistent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dc36ih95qw3rlccffcb0vgxjhmipsvxhn6cw71l7ffs0f7vq30b"; type = "gem"; }; version = "1.2.0"; }; faraday-patron = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19wgsgfq0xkski1g7m96snv39la3zxz6x7nbdgiwhg5v82rxfb6w"; type = "gem"; }; version = "1.0.0"; }; faraday-rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h184g4vqql5jv9s9im6igy00jp6mrah2h14py6mpf9bkabfqq7g"; type = "gem"; }; version = "1.0.0"; }; faraday-retry = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "153i967yrwnswqgvnnajgwp981k9p50ys1h80yz3q94rygs59ldd"; type = "gem"; }; version = "1.0.3"; }; faraday_middleware = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bw8mfh4yin2xk7138rg3fhb2p5g2dlmdma88k82psah9mbmvlfy"; type = "gem"; }; version = "1.2.0"; }; fast_gettext = { - dependencies = ["prime"]; - groups = ["default"]; - platforms = []; + dependencies = [ "prime" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gsz2ywvnms7b4w7bs4dg7cykhgx7z74fa7xy0sbw45a0v2c89px"; type = "gem"; }; version = "2.4.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; forwardable = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1b5g1i3xdvmxxpq4qp0z4v78ivqnazz26w110fh4cvzsdayz8zgi"; type = "gem"; }; version = "1.3.3"; }; getoptlong = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "198vy9dxyzibqdbw9jg8p2ljj9iknkyiqlyl229vz55rjxrz08zx"; type = "gem"; }; version = "0.2.1"; }; gettext = { - dependencies = ["erubi" "locale" "prime" "racc" "text"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "erubi" + "locale" + "prime" + "racc" + "text" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "16h0kda5z4s4zqygyk0f52xzs9mlz9r4lnhjwk729hhmdbz68a19"; type = "gem"; }; version = "3.4.9"; }; gettext-setup = { - dependencies = ["fast_gettext" "gettext" "locale"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "fast_gettext" + "gettext" + "locale" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1v6liz934gmx1wv1z6bvpim6aanbr66xjhb90lc9z1jxayczmm1a"; type = "gem"; }; version = "1.1.0"; }; gssapi = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qdfhj12aq8v0y961v4xv96a1y2z80h3xhvzrs9vsfgf884g6765"; type = "gem"; }; version = "1.3.1"; }; gyoku = { - dependencies = ["builder" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "builder" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kd2q59xpm39hpvmmvyi6g3f1fr05xjbnxwkrdqz4xy7hirqi79q"; type = "gem"; }; version = "1.4.0"; }; hiera-eyaml = { - dependencies = ["highline" "optimist"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "highline" + "optimist" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0m7zr33qfhvwxqx4kh61rabmbkhp3y4ans66kfpgrzjyvj1vdb6d"; type = "gem"; }; version = "3.4.0"; }; highline = { - dependencies = ["reline"]; - groups = ["default"]; - platforms = []; + dependencies = [ "reline" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sxqnaz6wvkwbwzsipwsqcg1zw2kn67x7l362whv87zl5133w60l"; type = "gem"; }; version = "3.1.0"; }; hocon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "106dmzsl1bxkqw5xaif012nwwfr3k9wff32cqc77ibjngknj6477"; type = "gem"; }; version = "1.4.0"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; io-console = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08d2lx42pa8jjav0lcjbzfzmw61b8imxr9041pva8xzqabrczp7h"; type = "gem"; }; version = "0.7.2"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cdw9vw2qly7q7r41s7phnac264rbsdqgj4l0h4nqgbjb157g393"; type = "gem"; }; version = "1.6.2"; }; jwt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16z11alz13vfc4zs5l3fk6n51n2jw9lskvc4h4prnww0y797qd87"; type = "gem"; }; version = "2.7.1"; }; little-plugger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1frilv82dyxnlg8k1jhrvyd73l6k17mxc5vwxx080r4x1p04gwym"; type = "gem"; }; version = "1.1.4"; }; locale = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "107pm4ccmla23z963kyjldgngfigvchnv85wr6m69viyxxrrjbsj"; type = "gem"; }; version = "2.1.4"; }; log4r = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ri90q0frfmigkirqv5ihyrj59xm8pq5zcmf156cbdv4r4l2jicv"; type = "gem"; }; version = "1.1.10"; }; logging = { - dependencies = ["little-plugger" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "little-plugger" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1jqcq2yxh973f3aw63nd3wxhqyhkncz3pf8v2gs3df0iqair725s"; type = "gem"; }; version = "2.4.0"; }; minitar = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f307mpj4j0gp7iq77xj4p149f4krcvbll9rismng3jcijpbn79s"; type = "gem"; }; version = "0.12.1"; }; molinillo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p846facmh1j5xmbrpgzadflspvk7bzs3sykrh5s7qi4cdqz5gzg"; type = "gem"; }; version = "0.8.0"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a5lrlvmg2kb2dhw3lxcsv6x276bwgsxpnka1752082miqxd0wlq"; type = "gem"; }; version = "2.4.1"; }; net-http-persistent = { - dependencies = ["connection_pool"]; - groups = ["default"]; - platforms = []; + dependencies = [ "connection_pool" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0i1as2lgnw7b4jid0gw5glv5hnxz36nmfsbr9rmxbcap72ijgy03"; type = "gem"; }; version = "4.0.2"; }; net-scp = { - dependencies = ["net-ssh"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-ssh" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1si2nq9l6jy5n2zw1q59a5gaji7v9vhy8qx08h4fg368906ysbdk"; type = "gem"; }; version = "4.0.0"; }; net-ssh = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sqbq5aks9xxnldbd2hy20ypnd59zcra98ql0r7jjc26s5rgc18n"; type = "gem"; }; version = "7.2.3"; }; net-ssh-krb = { - dependencies = ["gssapi" "net-ssh"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "gssapi" + "net-ssh" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "120mns6drrapn8i63cbgxngjql4cyclv6asyrkgc87bv5prlh50c"; type = "gem"; }; version = "0.5.1"; }; nkf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09piyp2pd74klb9wcn0zw4mb5l0k9wzwppxggxi1yi95l2ym3hgv"; type = "gem"; }; version = "0.2.0"; }; nori = { - dependencies = ["bigdecimal"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bigdecimal" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qb84bbi74q0zgs09sdkq750jf2ri3lblbry0xi4g1ard4rwsrk1"; type = "gem"; }; version = "2.7.1"; }; optimist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0q4jqq3v1bxlfr9jgqmahnygkvl81lr6s1rhm8qg66c9xr9nz241"; type = "gem"; }; version = "3.1.0"; }; orchestrator_client = { - dependencies = ["faraday" "net-http-persistent"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "net-http-persistent" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05jb10gjffrj5wy8ps1chki3n0z734bx1nx7a6wahh7cjnrqqmsg"; type = "gem"; }; version = "0.7.0"; }; prime = { - dependencies = ["forwardable" "singleton"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "forwardable" + "singleton" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1973kz8lbck6ga5v42f55jk8b8pnbgwp9p67dl1xw15gvz55dsfl"; type = "gem"; }; version = "0.1.2"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vqcw3iwby3yc6avs1vb3gfd0vcp2v7q310665dvxfswmcf4xm31"; type = "gem"; }; version = "6.0.1"; }; puppet = { - dependencies = ["concurrent-ruby" "deep_merge" "facter" "fast_gettext" "getoptlong" "locale" "multi_json" "puppet-resource_api" "scanf" "semantic_puppet"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "deep_merge" + "facter" + "fast_gettext" + "getoptlong" + "locale" + "multi_json" + "puppet-resource_api" + "scanf" + "semantic_puppet" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0v2jqkan3nidifxdlpm7lk0ih5s8khl9ps0nz62wj3zlywck0wsi"; type = "gem"; }; version = "8.8.1"; }; puppet-resource_api = { - dependencies = ["hocon"]; - groups = ["default"]; - platforms = []; + dependencies = [ "hocon" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rxy5s7hl707x4sc1b4v2yqyii6pkym2gmsam3ri0f0xmmzyg0jb"; type = "gem"; }; version = "1.9.0"; }; puppet-strings = { - dependencies = ["rgen" "yard"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rgen" + "yard" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0zcs25xxkfymks4knilryfpr8k0v7z3nazdm61v7a1x4rxhs7sxp"; type = "gem"; }; version = "4.1.2"; }; puppet_forge = { - dependencies = ["faraday" "faraday_middleware" "minitar" "semantic_puppet"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "faraday_middleware" + "minitar" + "semantic_puppet" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "03aaznd1gyf3wpqg34y32zfj2yxf67r85m6zfz05pv9ijizrmdnj"; type = "gem"; }; version = "3.2.0"; }; puppetfile-resolver = { - dependencies = ["molinillo" "semantic_puppet"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "molinillo" + "semantic_puppet" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kil8sbrl9c34ygrgm35893zygr4j6fjvfhbs4rs0b5n3cjrainm"; type = "gem"; }; version = "0.6.3"; }; r10k = { - dependencies = ["colored2" "cri" "fast_gettext" "gettext" "gettext-setup" "jwt" "log4r" "minitar" "multi_json" "puppet_forge"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "colored2" + "cri" + "fast_gettext" + "gettext" + "gettext-setup" + "jwt" + "log4r" + "minitar" + "multi_json" + "puppet_forge" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1f9fwfmr44lbnx31fdiabm7sb41nsbf10awm96zl79clp8kafxcp"; type = "gem"; }; version = "3.16.2"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0byn0c9nkahsl93y9ln5bysq4j31q8xkf2ws42swighxd4lnjzsa"; type = "gem"; }; version = "1.8.1"; }; reline = { - dependencies = ["io-console"]; - groups = ["default"]; - platforms = []; + dependencies = [ "io-console" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0y6kyz7kcilwdpfy3saqfgnar38vr5ys9sp40ndffy6h1znxfbax"; type = "gem"; }; version = "0.5.9"; }; rexml = { - dependencies = ["strscan"]; - groups = ["default"]; - platforms = []; + dependencies = [ "strscan" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ik3in0957l9s6iwdm3nsk4za072cj27riiqgpx6zzcd22flbw3s"; type = "gem"; }; version = "3.3.6"; }; rgen = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1abg3frzak6inwbr4caq6mfd5spx37xnwlxss8615jr12wh525vp"; type = "gem"; }; version = "0.9.1"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; ruby_smb = { - dependencies = ["bindata" "rubyntlm" "windows_error"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bindata" + "rubyntlm" + "windows_error" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "125pimmaskp13nkk5j138nfk1kd8n91sfdlx4dhj2j9zk342wsf4"; type = "gem"; }; version = "1.1.0"; }; rubyntlm = { - dependencies = ["base64"]; - groups = ["default"]; - platforms = []; + dependencies = [ "base64" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x8l0d1v88m40mby4jvgal46137cv8gga2lk7zlrxqlsp41380a7"; type = "gem"; }; version = "0.6.5"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; scanf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "000vxsci3zq8m1wl7mmppj7sarznrqlm6v2x2hdfmbxcwpvvfgak"; type = "gem"; }; version = "1.0.0"; }; semantic_puppet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ndqm3jnpdlwkk1jwqdyyb7yw7gv6r4kmjs30g09ap8siv80ilaj"; type = "gem"; }; version = "1.1.0"; }; singleton = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qq54imvbksnckzf9hrq9bjzcdb0n8wfv6l5jc0di10n88277jx6"; type = "gem"; }; version = "0.2.0"; }; strscan = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mamrl7pxacbc79ny5hzmakc9grbjysm3yy6119ppgsg44fsif01"; type = "gem"; }; version = "3.1.0"; }; terminal-table = { - dependencies = ["unicode-display_width"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unicode-display_width" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14dfmfjppmng5hwj7c5ka6qdapawm3h6k9lhn8zj001ybypvclgr"; type = "gem"; }; version = "3.0.2"; }; text = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x6kkmsr49y3rnrin91rv8mpc3dhrf3ql08kbccw8yffq61brfrg"; type = "gem"; }; version = "1.3.1"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vq1fjp45az9hfp6fxljhdrkv75cvbab1jfrwcw738pnsiqk8zps"; type = "gem"; }; version = "1.3.1"; }; unicode-display_width = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d0azx233nags5jx3fqyr23qa2rhgzbhv8pxp46dgbg1mpf82xky"; type = "gem"; }; version = "2.5.0"; }; windows_error = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1825v7hvcl0xss6scyfv76i0cs0kvj72wy20kn7xqylw9avjga2r"; type = "gem"; }; version = "0.1.5"; }; winrm = { - dependencies = ["builder" "erubi" "gssapi" "gyoku" "httpclient" "logging" "nori" "rexml" "rubyntlm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "builder" + "erubi" + "gssapi" + "gyoku" + "httpclient" + "logging" + "nori" + "rexml" + "rubyntlm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "01jxpshw5kx5ha21ymaaj14vibv5bvm0dd80ccc6xl3jaxy7cszg"; type = "gem"; }; version = "2.3.9"; }; winrm-fs = { - dependencies = ["erubi" "logging" "rubyzip" "winrm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "erubi" + "logging" + "rubyzip" + "winrm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gb91k6s1yjqw387x4w1nkpnxblq3pjdqckayl0qvz5n3ygdsb0d"; type = "gem"; }; version = "1.3.5"; }; yard = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1r0b8w58p7gy06wph1qdjv2p087hfnmhd9jk23vjdj803dn761am"; type = "gem"; }; diff --git a/pkgs/by-name/pu/puppet-bolt/package.nix b/pkgs/by-name/pu/puppet-bolt/package.nix index a9377526985599..4129e0654bda72 100644 --- a/pkgs/by-name/pu/puppet-bolt/package.nix +++ b/pkgs/by-name/pu/puppet-bolt/package.nix @@ -42,9 +42,13 @@ changelog = "https://github.com/puppetlabs/bolt/blob/main/CHANGELOG.md"; license = lib.licenses.asl20; mainProgram = "bolt"; - maintainers = with lib.maintainers; [ uvnikita anthonyroussel ]; + maintainers = with lib.maintainers; [ + uvnikita + anthonyroussel + ]; platforms = lib.platforms.unix; }; -}).overrideAttrs (old: { - name = "puppet-bolt-${(import ./gemset.nix).bolt.version}"; -}) +}).overrideAttrs + (old: { + name = "puppet-bolt-${(import ./gemset.nix).bolt.version}"; + }) diff --git a/pkgs/by-name/pu/puppet-lint/gemset.nix b/pkgs/by-name/pu/puppet-lint/gemset.nix index f936a39af0a060..9a30ccf7c232b4 100644 --- a/pkgs/by-name/pu/puppet-lint/gemset.nix +++ b/pkgs/by-name/pu/puppet-lint/gemset.nix @@ -1,9 +1,9 @@ { puppet-lint = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n2pffwxj1n33hc7aw74g6a4gn5v7rawcs7rglidbdq1g4kzd829"; type = "gem"; }; diff --git a/pkgs/by-name/pu/puppet/gemset.nix b/pkgs/by-name/pu/puppet/gemset.nix index 0542cb050d0526..3817f53b33fe2f 100644 --- a/pkgs/by-name/pu/puppet/gemset.nix +++ b/pkgs/by-name/pu/puppet/gemset.nix @@ -1,122 +1,135 @@ { concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qh1b14jwbbj242klkyz5fc7npd4j0mvndz62gajhvl1l3wd7zc2"; type = "gem"; }; version = "1.2.3"; }; deep_merge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fjn4civid68a3zxnbgyjj6krs3l30dy8b4djpg6fpzrsyix7kl3"; type = "gem"; }; version = "1.2.2"; }; facter = { - dependencies = ["hocon" "thor"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "hocon" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bigvzjqmfd7s0wwmg22372iffy4jz71x25g1r1ij8h60bk1097h"; type = "gem"; }; version = "4.7.0"; }; fast_gettext = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "112gsrqah2w03kgi9mjsn6hl74mrwckphf223h36iayc4djf4lq2"; type = "gem"; }; version = "2.3.0"; }; hocon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "106dmzsl1bxkqw5xaif012nwwfr3k9wff32cqc77ibjngknj6477"; type = "gem"; }; version = "1.4.0"; }; locale = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "107pm4ccmla23z963kyjldgngfigvchnv85wr6m69viyxxrrjbsj"; type = "gem"; }; version = "2.1.4"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; puppet = { - dependencies = ["concurrent-ruby" "deep_merge" "facter" "fast_gettext" "locale" "multi_json" "puppet-resource_api" "scanf" "semantic_puppet"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "concurrent-ruby" + "deep_merge" + "facter" + "fast_gettext" + "locale" + "multi_json" + "puppet-resource_api" + "scanf" + "semantic_puppet" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1b9a1spqh5zfmpr0f1rz597wr7s4d7d796768ms04ssd634r4539"; type = "gem"; }; version = "8.6.0"; }; puppet-resource_api = { - dependencies = ["hocon"]; - groups = ["default"]; - platforms = []; + dependencies = [ "hocon" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rxy5s7hl707x4sc1b4v2yqyii6pkym2gmsam3ri0f0xmmzyg0jb"; type = "gem"; }; version = "1.9.0"; }; scanf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "000vxsci3zq8m1wl7mmppj7sarznrqlm6v2x2hdfmbxcwpvvfgak"; type = "gem"; }; version = "1.0.0"; }; semantic_puppet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ndqm3jnpdlwkk1jwqdyyb7yw7gv6r4kmjs30g09ap8siv80ilaj"; type = "gem"; }; version = "1.1.0"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k7j2wn14h1pl4smibasw0bp66kg626drxb59z7rzflch99cd4rg"; type = "gem"; }; diff --git a/pkgs/by-name/pu/puppeteer-cli/package.nix b/pkgs/by-name/pu/puppeteer-cli/package.nix index 6a2eea146f0ca3..03b71b728ab597 100644 --- a/pkgs/by-name/pu/puppeteer-cli/package.nix +++ b/pkgs/by-name/pu/puppeteer-cli/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, makeWrapper -, chromium +{ + lib, + buildNpmPackage, + fetchFromGitHub, + makeWrapper, + chromium, }: buildNpmPackage rec { diff --git a/pkgs/by-name/pu/pur/package.nix b/pkgs/by-name/pu/pur/package.nix index 3b79fbc2ce1637..d482cf0bc7a6d5 100644 --- a/pkgs/by-name/pu/pur/package.nix +++ b/pkgs/by-name/pu/pur/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/pu/pure-ftpd/package.nix b/pkgs/by-name/pu/pure-ftpd/package.nix index 22a7d65fc1c37a..1167bb654bfde2 100644 --- a/pkgs/by-name/pu/pure-ftpd/package.nix +++ b/pkgs/by-name/pu/pure-ftpd/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, openssl, pam, libxcrypt }: +{ + lib, + stdenv, + fetchurl, + openssl, + pam, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "pure-ftpd"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-ESbzqVhW0IiJ/4lwPLGqnsmSTZOdFU6WkEySDwXcPHQ="; }; - buildInputs = [ openssl pam libxcrypt ]; + buildInputs = [ + openssl + pam + libxcrypt + ]; configureFlags = [ "--with-tls" ]; diff --git a/pkgs/by-name/pu/pure-prompt/package.nix b/pkgs/by-name/pu/pure-prompt/package.nix index 20da12041805b9..4339c54f3b4d85 100644 --- a/pkgs/by-name/pu/pure-prompt/package.nix +++ b/pkgs/by-name/pu/pure-prompt/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "pure-prompt"; @@ -24,6 +28,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/sindresorhus/pure"; license = licenses.mit; platforms = platforms.all; - maintainers = with maintainers; [ pacien pablovsky ]; + maintainers = with maintainers; [ + pacien + pablovsky + ]; }; } diff --git a/pkgs/by-name/pu/puremapping/package.nix b/pkgs/by-name/pu/puremapping/package.nix index 5aef92ab61fb02..e0727483cee59f 100644 --- a/pkgs/by-name/pu/puremapping/package.nix +++ b/pkgs/by-name/pu/puremapping/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, unzip, puredata }: +{ + lib, + stdenv, + fetchurl, + unzip, + puredata, +}: stdenv.mkDerivation rec { pname = "puremapping"; diff --git a/pkgs/by-name/pu/purescm/package.nix b/pkgs/by-name/pu/purescm/package.nix index 0eebd7f23e179d..faee196e3eb92c 100644 --- a/pkgs/by-name/pu/purescm/package.nix +++ b/pkgs/by-name/pu/purescm/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildNpmPackage -, fetchNpmDeps -, testers +{ + lib, + buildNpmPackage, + fetchNpmDeps, + testers, }: let diff --git a/pkgs/by-name/pu/purpur/package.nix b/pkgs/by-name/pu/purpur/package.nix index ad8f1b81097d10..74d2d332924349 100644 --- a/pkgs/by-name/pu/purpur/package.nix +++ b/pkgs/by-name/pu/purpur/package.nix @@ -1,11 +1,20 @@ -{ lib, stdenv, fetchurl, nixosTests, jre_headless, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + nixosTests, + jre_headless, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "purpur"; version = "1.19.2r1763"; src = fetchurl { - url = "https://api.purpurmc.org/v2/purpur/${builtins.replaceStrings [ "r" ] [ "/" ] version}/download"; + url = "https://api.purpurmc.org/v2/purpur/${ + builtins.replaceStrings [ "r" ] [ "/" ] version + }/download"; sha256 = "sha256-6wcCwVIGV32YQlgB57qthy6uWtuXGN4G8S7uAAgVyDE="; }; diff --git a/pkgs/by-name/pv/pv-migrate/package.nix b/pkgs/by-name/pv/pv-migrate/package.nix index ebb00206586d74..b1d3f8786d6cc9 100644 --- a/pkgs/by-name/pv/pv-migrate/package.nix +++ b/pkgs/by-name/pv/pv-migrate/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "pv-migrate"; @@ -40,6 +45,9 @@ buildGoModule rec { homepage = "https://github.com/utkuozdemir/pv-migrate"; changelog = "https://github.com/utkuozdemir/pv-migrate/releases/tag/${version}"; license = licenses.afl20; - maintainers = with lib.maintainers; [ ivankovnatsky qjoly ]; + maintainers = with lib.maintainers; [ + ivankovnatsky + qjoly + ]; }; } diff --git a/pkgs/by-name/pv/pv/package.nix b/pkgs/by-name/pv/pv/package.nix index 4430a14ce9ab30..58932554733c7c 100644 --- a/pkgs/by-name/pv/pv/package.nix +++ b/pkgs/by-name/pv/pv/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/pv/pvsneslib/package.nix b/pkgs/by-name/pv/pvsneslib/package.nix index fe78293e2e0799..1289fa2fff63e3 100644 --- a/pkgs/by-name/pv/pvsneslib/package.nix +++ b/pkgs/by-name/pv/pvsneslib/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gcc +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gcc, }: stdenv.mkDerivation rec { @@ -17,7 +18,10 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ gcc cmake ]; + nativeBuildInputs = [ + gcc + cmake + ]; dontConfigure = true; diff --git a/pkgs/by-name/pw/pw-volume/package.nix b/pkgs/by-name/pw/pw-volume/package.nix index 290cd4ffbf2d26..5ebb94322d3941 100644 --- a/pkgs/by-name/pw/pw-volume/package.nix +++ b/pkgs/by-name/pw/pw-volume/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/smasher164/pw-volume"; changelog = "https://github.com/smasher164/pw-volume/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ astro figsoda ]; + maintainers = with maintainers; [ + astro + figsoda + ]; platforms = platforms.linux; mainProgram = "pw-volume"; }; diff --git a/pkgs/by-name/pw/pw3270/package.nix b/pkgs/by-name/pw/pw3270/package.nix index d344b4e2dd2a74..2c4f1a34267606 100644 --- a/pkgs/by-name/pw/pw3270/package.nix +++ b/pkgs/by-name/pw/pw3270/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, which -, pkg-config -, automake -, autoconf -, libtool -, gtk3 -, libv3270 -, lib3270 -, openssl -, gettext -, desktop-file-utils -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + which, + pkg-config, + automake, + autoconf, + libtool, + gtk3, + libv3270, + lib3270, + openssl, + gettext, + desktop-file-utils, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pw/pwalarmctl/package.nix b/pkgs/by-name/pw/pwalarmctl/package.nix index ed0522307ebd75..8e30f53f98c6db 100644 --- a/pkgs/by-name/pw/pwalarmctl/package.nix +++ b/pkgs/by-name/pw/pwalarmctl/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, alsa-lib +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + alsa-lib, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pw/pwalarmd/package.nix b/pkgs/by-name/pw/pwalarmd/package.nix index 39a686f992883e..77c3043f73d89d 100644 --- a/pkgs/by-name/pw/pwalarmd/package.nix +++ b/pkgs/by-name/pw/pwalarmd/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, alsa-lib +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + alsa-lib, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/pw/pwgen-secure/package.nix b/pkgs/by-name/pw/pwgen-secure/package.nix index cc88e43875372d..a9827117a99429 100644 --- a/pkgs/by-name/pw/pwgen-secure/package.nix +++ b/pkgs/by-name/pw/pwgen-secure/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: let inherit (python3Packages) buildPythonApplication pythonOlder; diff --git a/pkgs/by-name/pw/pwgen/package.nix b/pkgs/by-name/pw/pwgen/package.nix index 3c0ce6b21d506e..05585886da8b13 100644 --- a/pkgs/by-name/pw/pwgen/package.nix +++ b/pkgs/by-name/pw/pwgen/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/pw/pwnat/package.nix b/pkgs/by-name/pw/pwnat/package.nix index d95608d5b648c4..29d1b4c6e5bdc1 100644 --- a/pkgs/by-name/pw/pwnat/package.nix +++ b/pkgs/by-name/pw/pwnat/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { @@ -11,9 +12,9 @@ stdenv.mkDerivation rec { version = "2023-03-31"; src = fetchFromGitHub { - owner = "samyk"; - repo = pname; - rev = "8ec62cdae53a2d573c9f9c906133ca45bbd3360a"; + owner = "samyk"; + repo = pname; + rev = "8ec62cdae53a2d573c9f9c906133ca45bbd3360a"; sha256 = "sha256-QodNw3ab8/TurKamg6AgMfQ08aalp4j6q663B+sWmRM="; }; @@ -31,11 +32,11 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - homepage = "http://samy.pl/pwnat/"; + homepage = "http://samy.pl/pwnat/"; description = "ICMP NAT to NAT client-server communication"; - license = lib.licenses.gpl3Plus; + license = lib.licenses.gpl3Plus; maintainers = [ ]; - platforms = with platforms; linux; + platforms = with platforms; linux; mainProgram = "pwnat"; }; } diff --git a/pkgs/by-name/pw/pwndbg/package.nix b/pkgs/by-name/pw/pwndbg/package.nix index 5c612e7bfaa969..a87f63d004513a 100644 --- a/pkgs/by-name/pw/pwndbg/package.nix +++ b/pkgs/by-name/pw/pwndbg/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, python3 -, makeWrapper -, gdb +{ + lib, + stdenv, + python3, + makeWrapper, + gdb, }: let @@ -10,12 +11,15 @@ let pythonPath = python3.pkgs.makePythonPath [ pwndbg-py ]; - binPath = lib.makeBinPath ([ - python3.pkgs.pwntools # ref: https://github.com/pwndbg/pwndbg/blob/2022.12.19/pwndbg/wrappers/checksec.py#L8 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - python3.pkgs.ropper # ref: https://github.com/pwndbg/pwndbg/blob/2022.12.19/pwndbg/commands/ropper.py#L30 - python3.pkgs.ropgadget # ref: https://github.com/pwndbg/pwndbg/blob/2022.12.19/pwndbg/commands/rop.py#L32 - ]); + binPath = lib.makeBinPath ( + [ + python3.pkgs.pwntools # ref: https://github.com/pwndbg/pwndbg/blob/2022.12.19/pwndbg/wrappers/checksec.py#L8 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + python3.pkgs.ropper # ref: https://github.com/pwndbg/pwndbg/blob/2022.12.19/pwndbg/commands/ropper.py#L30 + python3.pkgs.ropgadget # ref: https://github.com/pwndbg/pwndbg/blob/2022.12.19/pwndbg/commands/rop.py#L32 + ] + ); in stdenv.mkDerivation { pname = "pwndbg"; @@ -62,7 +66,11 @@ stdenv.mkDerivation { homepage = "https://github.com/pwndbg/pwndbg"; license = licenses.mit; platforms = platforms.all; - maintainers = with maintainers; [ mic92 patryk4815 msanft ]; + maintainers = with maintainers; [ + mic92 + patryk4815 + msanft + ]; # not supported on aarch64-darwin see: https://inbox.sourceware.org/gdb/3185c3b8-8a91-4beb-a5d5-9db6afb93713@Spark/ broken = stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64; }; diff --git a/pkgs/by-name/pw/pwru/package.nix b/pkgs/by-name/pw/pwru/package.nix index 33012d43aa2686..42b8745f50e8fd 100644 --- a/pkgs/by-name/pw/pwru/package.nix +++ b/pkgs/by-name/pw/pwru/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, clang -, libpcap +{ + lib, + buildGoModule, + fetchFromGitHub, + clang, + libpcap, }: buildGoModule rec { diff --git a/pkgs/by-name/pw/pwsafe/package.nix b/pkgs/by-name/pw/pwsafe/package.nix index 87a937da7f1a90..0ef4f94a3df1ff 100644 --- a/pkgs/by-name/pw/pwsafe/package.nix +++ b/pkgs/by-name/pw/pwsafe/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, zip -, gettext -, perl -, wxGTK32 -, libXext -, libXi -, libXt -, libXtst -, xercesc -, qrencode -, libuuid -, libyubikey -, yubikey-personalization -, curl -, openssl -, file -, darwin -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + zip, + gettext, + perl, + wxGTK32, + libXext, + libXi, + libXt, + libXtst, + xercesc, + qrencode, + libuuid, + libyubikey, + yubikey-personalization, + curl, + openssl, + file, + darwin, + gitUpdater, }: let @@ -48,52 +49,59 @@ stdenv.mkDerivation rec { zip ]; - buildInputs = [ - wxGTK32 - curl - qrencode - openssl - xercesc - file - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libXext - libXi - libXt - libXtst - libuuid - libyubikey - yubikey-personalization - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Cocoa - ]; + buildInputs = + [ + wxGTK32 + curl + qrencode + openssl + xercesc + file + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libXext + libXi + libXt + libXtst + libuuid + libyubikey + yubikey-personalization + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + ]; - cmakeFlags = [ - "-DNO_GTEST=ON" - "-DCMAKE_CXX_FLAGS=-I${yubikey-personalization}/include/ykpers-1" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DNO_YUBI=ON" - ]; + cmakeFlags = + [ + "-DNO_GTEST=ON" + "-DCMAKE_CXX_FLAGS=-I${yubikey-personalization}/include/ykpers-1" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DNO_YUBI=ON" + ]; - postPatch = '' - # Fix perl scripts used during the build. - for f in $(find . -type f -name '*.pl') ; do - patchShebangs $f - done + postPatch = + '' + # Fix perl scripts used during the build. + for f in $(find . -type f -name '*.pl') ; do + patchShebangs $f + done - # Fix hard coded paths. - for f in $(grep -Rl /usr/share/ src install/desktop) ; do - substituteInPlace $f --replace /usr/share/ $out/share/ - done + # Fix hard coded paths. + for f in $(grep -Rl /usr/share/ src install/desktop) ; do + substituteInPlace $f --replace /usr/share/ $out/share/ + done - # Fix hard coded zip path. - substituteInPlace help/Makefile.linux --replace /usr/bin/zip ${zip}/bin/zip + # Fix hard coded zip path. + substituteInPlace help/Makefile.linux --replace /usr/bin/zip ${zip}/bin/zip - for f in $(grep -Rl /usr/bin/ .) ; do - substituteInPlace $f --replace /usr/bin/ "" - done - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace src/ui/cli/CMakeLists.txt --replace "uuid" "" - ''; + for f in $(grep -Rl /usr/bin/ .) ; do + substituteInPlace $f --replace /usr/bin/ "" + done + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace src/ui/cli/CMakeLists.txt --replace "uuid" "" + ''; installFlags = [ "PREFIX=${placeholder "out"}" ]; @@ -112,7 +120,10 @@ stdenv.mkDerivation rec { username/password combinations that you use. ''; homepage = "https://pwsafe.org/"; - maintainers = with maintainers; [ c0bw3b pjones ]; + maintainers = with maintainers; [ + c0bw3b + pjones + ]; platforms = platforms.unix; license = licenses.artistic2; }; diff --git a/pkgs/by-name/pw/pwvucontrol/package.nix b/pkgs/by-name/pw/pwvucontrol/package.nix index 2033158861680f..30976363b5b03a 100644 --- a/pkgs/by-name/pw/pwvucontrol/package.nix +++ b/pkgs/by-name/pw/pwvucontrol/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchFromGitLab -, cargo -, desktop-file-utils -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, wrapGAppsHook4 -, cairo -, gdk-pixbuf -, glib -, gtk4 -, libadwaita -, pango -, pipewire -, wireplumber +{ + lib, + stdenv, + fetchFromGitHub, + fetchFromGitLab, + cargo, + desktop-file-utils, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + wrapGAppsHook4, + cairo, + gdk-pixbuf, + glib, + gtk4, + libadwaita, + pango, + pipewire, + wireplumber, }: let diff --git a/pkgs/by-name/px/pxattr/package.nix b/pkgs/by-name/px/pxattr/package.nix index a5a7ab40115cce..a3d0fd4e732dcc 100644 --- a/pkgs/by-name/px/pxattr/package.nix +++ b/pkgs/by-name/px/pxattr/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gcc }: +{ + lib, + stdenv, + fetchurl, + gcc, +}: stdenv.mkDerivation rec { pname = "pxattr"; diff --git a/pkgs/by-name/px/pxder/package.nix b/pkgs/by-name/px/pxder/package.nix index 8621621fe85027..e01b261ae78154 100644 --- a/pkgs/by-name/px/pxder/package.nix +++ b/pkgs/by-name/px/pxder/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, makeWrapper -, fixup-yarn-lock -, yarn -, nodejs +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + makeWrapper, + fixup-yarn-lock, + yarn, + nodejs, }: stdenv.mkDerivation rec { @@ -24,7 +25,7 @@ stdenv.mkDerivation rec { hash = "sha256-++MqWIUntXQwOYpgAJ3nhAtZ5nxmEreioVHQokYkw7w="; }; - nativeBuildInputs = [ + nativeBuildInputs = [ makeWrapper fixup-yarn-lock yarn diff --git a/pkgs/by-name/px/pxlib/package.nix b/pkgs/by-name/px/pxlib/package.nix index 6b31ef3257ddd3..b0ac6d42e7fe18 100644 --- a/pkgs/by-name/px/pxlib/package.nix +++ b/pkgs/by-name/px/pxlib/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, intltool }: +{ + lib, + stdenv, + fetchurl, + intltool, +}: stdenv.mkDerivation rec { pname = "pxlib"; diff --git a/pkgs/by-name/px/pxview/package.nix b/pkgs/by-name/px/pxview/package.nix index 53698261560e9d..ea3542adc879ad 100644 --- a/pkgs/by-name/px/pxview/package.nix +++ b/pkgs/by-name/px/pxview/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, perl, perlPackages, pxlib }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + perl, + perlPackages, + pxlib, +}: stdenv.mkDerivation rec { pname = "pxview"; @@ -8,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "1kpdqs6lvnyj02v9fbz1s427yqhgrxp7zw63rzfgiwd4iqp75139"; }; - buildInputs = [ pxlib perl ] ++ (with perlPackages; [ libxml_perl ]); + buildInputs = [ + pxlib + perl + ] ++ (with perlPackages; [ libxml_perl ]); nativeBuildInputs = [ pkg-config ]; configureFlags = [ "--with-pxlib=${pxlib.out}" ]; diff --git a/pkgs/by-name/px/pxz/package.nix b/pkgs/by-name/px/pxz/package.nix index f61e80cbc06515..3e33115975cb5c 100644 --- a/pkgs/by-name/px/pxz/package.nix +++ b/pkgs/by-name/px/pxz/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, testers -, pxz -, xz +{ + lib, + stdenv, + fetchFromGitHub, + testers, + pxz, + xz, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/py/py3c/package.nix b/pkgs/by-name/py/py3c/package.nix index 32e7d124911870..c8c75cff2ef7ae 100644 --- a/pkgs/by-name/py/py3c/package.nix +++ b/pkgs/by-name/py/py3c/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python311 }: +{ + lib, + stdenv, + fetchFromGitHub, + python311, +}: stdenv.mkDerivation rec { pname = "py3c"; diff --git a/pkgs/by-name/py/pyCA/package.nix b/pkgs/by-name/py/pyCA/package.nix index eab7c5a7d23312..3af887e0c05100 100644 --- a/pkgs/by-name/py/pyCA/package.nix +++ b/pkgs/by-name/py/pyCA/package.nix @@ -1,9 +1,10 @@ -{ lib -, python3 -, buildNpmPackage -, fetchFromGitHub -, jq -, stdenv +{ + lib, + python3, + buildNpmPackage, + fetchFromGitHub, + jq, + stdenv, }: let @@ -28,7 +29,10 @@ let npmDepsHash = "sha256-0U+semrNWTkNu3uQQkiJKZT1hB0/IfkL84G7/oP8XYY="; - nativeBuildInputs = [ jq python ]; + nativeBuildInputs = [ + jq + python + ]; postPatch = '' ${jq}/bin/jq '. += {"version": "${version}"}' < package.json > package.json.tmp diff --git a/pkgs/by-name/py/pybibget/package.nix b/pkgs/by-name/py/pybibget/package.nix index c57d74bf5d2d39..83eb642ce5b7aa 100644 --- a/pkgs/by-name/py/pybibget/package.nix +++ b/pkgs/by-name/py/pybibget/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: let @@ -13,7 +14,7 @@ let }; in -python3.pkgs.buildPythonApplication { +python3.pkgs.buildPythonApplication { inherit pname version src; pyproject = true; diff --git a/pkgs/by-name/py/pydf/package.nix b/pkgs/by-name/py/pydf/package.nix index 61f79edeab16b7..d1e2e5291dd66e 100644 --- a/pkgs/by-name/py/pydf/package.nix +++ b/pkgs/by-name/py/pydf/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonPackage rec { pname = "pydf"; diff --git a/pkgs/by-name/py/pykms/package.nix b/pkgs/by-name/py/pykms/package.nix index b94922d3559648..ba8710caeba363 100644 --- a/pkgs/by-name/py/pykms/package.nix +++ b/pkgs/by-name/py/pykms/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, python3 -, writeText -, writeShellScript -, sqlite -, nixosTests +{ + lib, + fetchFromGitHub, + python3, + writeText, + writeShellScript, + sqlite, + nixosTests, }: let pypkgs = python3.pkgs; @@ -46,7 +47,12 @@ pypkgs.buildPythonApplication rec { sourceRoot = "${src.name}/py-kms"; - propagatedBuildInputs = with pypkgs; [ systemd pytz tzlocal dnspython ]; + propagatedBuildInputs = with pypkgs; [ + systemd + pytz + tzlocal + dnspython + ]; postPatch = '' siteDir=$out/${python3.sitePackages} @@ -90,6 +96,9 @@ pypkgs.buildPythonApplication rec { description = "Windows KMS (Key Management Service) server written in Python"; homepage = "https://github.com/Py-KMS-Organization/py-kms"; license = licenses.unlicense; - maintainers = with maintainers; [ peterhoeg zopieux ]; + maintainers = with maintainers; [ + peterhoeg + zopieux + ]; }; } diff --git a/pkgs/by-name/py/pylint-exit/package.nix b/pkgs/by-name/py/pylint-exit/package.nix index 6bd5591b57e92f..9095d4456e9dab 100644 --- a/pkgs/by-name/py/pylint-exit/package.nix +++ b/pkgs/by-name/py/pylint-exit/package.nix @@ -1,6 +1,11 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: -with python3Packages; buildPythonApplication rec { +with python3Packages; +buildPythonApplication rec { pname = "pylint-exit"; version = "1.2.0"; diff --git a/pkgs/by-name/py/pylode/package.nix b/pkgs/by-name/py/pylode/package.nix index 7212da7b867f49..0652522a945d53 100644 --- a/pkgs/by-name/py/pylode/package.nix +++ b/pkgs/by-name/py/pylode/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/py/pympress/package.nix b/pkgs/by-name/py/pympress/package.nix index f370ecec9ddfd5..8c8801fe8cd93b 100644 --- a/pkgs/by-name/py/pympress/package.nix +++ b/pkgs/by-name/py/pympress/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, python3Packages -, fetchPypi -, wrapGAppsHook3 -, gtk3 -, gobject-introspection -, libcanberra-gtk3 -, poppler_gi -, withGstreamer ? stdenv.hostPlatform.isLinux -, gst_all_1 -, withVLC ? stdenv.hostPlatform.isLinux +{ + lib, + stdenv, + python3Packages, + fetchPypi, + wrapGAppsHook3, + gtk3, + gobject-introspection, + libcanberra-gtk3, + poppler_gi, + withGstreamer ? stdenv.hostPlatform.isLinux, + gst_all_1, + withVLC ? stdenv.hostPlatform.isLinux, }: python3Packages.buildPythonApplication rec { @@ -27,26 +28,31 @@ python3Packages.buildPythonApplication rec { gobject-introspection ]; - buildInputs = [ - gtk3 - poppler_gi - ] ++ lib.optionals withGstreamer [ - libcanberra-gtk3 - gst_all_1.gstreamer - gst_all_1.gst-plugins-base - gst_all_1.gst-plugins-bad - gst_all_1.gst-plugins-ugly - (gst_all_1.gst-plugins-good.override {gtkSupport = true;}) - gst_all_1.gst-libav - gst_all_1.gst-vaapi - ]; + buildInputs = + [ + gtk3 + poppler_gi + ] + ++ lib.optionals withGstreamer [ + libcanberra-gtk3 + gst_all_1.gstreamer + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-bad + gst_all_1.gst-plugins-ugly + (gst_all_1.gst-plugins-good.override { gtkSupport = true; }) + gst_all_1.gst-libav + gst_all_1.gst-vaapi + ]; - propagatedBuildInputs = with python3Packages; [ - pycairo - pygobject3 - setuptools - watchdog - ] ++ lib.optional withVLC python-vlc; + propagatedBuildInputs = + with python3Packages; + [ + pycairo + pygobject3 + setuptools + watchdog + ] + ++ lib.optional withVLC python-vlc; doCheck = false; # there are no tests diff --git a/pkgs/by-name/py/pynac/package.nix b/pkgs/by-name/py/pynac/package.nix index 1389a5a77ece97..0b9977c5590684 100644 --- a/pkgs/by-name/py/pynac/package.nix +++ b/pkgs/by-name/py/pynac/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchpatch -, fetchFromGitHub -, autoreconfHook -, pkg-config -, flint -, gmp -, python3 -, singular -, ncurses +{ + lib, + stdenv, + fetchpatch, + fetchFromGitHub, + autoreconfHook, + pkg-config, + flint, + gmp, + python3, + singular, + ncurses, }: stdenv.mkDerivation (finalAttrs: { @@ -58,9 +60,9 @@ stdenv.mkDerivation (finalAttrs: { It is a lite version of GiNaC as well, not implementing all the features of the full GiNaC, and it is *only* meant to be used as a Python library. ''; - homepage = "http://pynac.org"; + homepage = "http://pynac.org"; license = licenses.gpl2Plus; maintainers = teams.sage.members; - platforms = platforms.unix; + platforms = platforms.unix; }; }) diff --git a/pkgs/by-name/py/pynitrokey/package.nix b/pkgs/by-name/py/pynitrokey/package.nix index aadc6d4a56e8ed..c0fb4438251f15 100644 --- a/pkgs/by-name/py/pynitrokey/package.nix +++ b/pkgs/by-name/py/pynitrokey/package.nix @@ -1,3 +1,4 @@ { python3 }: -with python3.pkgs; toPythonApplication pynitrokey +with python3.pkgs; +toPythonApplication pynitrokey diff --git a/pkgs/by-name/py/pyp/package.nix b/pkgs/by-name/py/pyp/package.nix index 08f3fdc63d4915..88b51e0943ea2f 100644 --- a/pkgs/by-name/py/pyp/package.nix +++ b/pkgs/by-name/py/pyp/package.nix @@ -1,8 +1,9 @@ -{ lib -, bc -, fetchFromGitHub -, jq -, python3 +{ + lib, + bc, + fetchFromGitHub, + jq, + python3, }: let @@ -24,12 +25,14 @@ let flit-core ]; - nativeCheckInputs = (with pythonPackages; [ - pytestCheckHook - ]) ++ [ - bc - jq - ]; + nativeCheckInputs = + (with pythonPackages; [ + pytestCheckHook + ]) + ++ [ + bc + jq + ]; pythonImportsCheck = [ "pyp" @@ -40,7 +43,7 @@ let preCheck = '' _OLD_PATH_=$PATH PATH=$out/bin:$PATH - ''; + ''; # And a cleanup! postCheck = '' @@ -53,7 +56,10 @@ let changelog = "https://github.com/hauntsaninja/pyp/blob/${finalAttrs.version}/CHANGELOG.md"; license = with lib.licenses; [ mit ]; mainProgram = "pyp"; - maintainers = with lib.maintainers; [ rmcgibbo AndersonTorres ]; + maintainers = with lib.maintainers; [ + rmcgibbo + AndersonTorres + ]; }; }; in diff --git a/pkgs/by-name/py/pypi-mirror/package.nix b/pkgs/by-name/py/pypi-mirror/package.nix index 8d55d7b73cf992..e1c0cea0e8f8ac 100644 --- a/pkgs/by-name/py/pypi-mirror/package.nix +++ b/pkgs/by-name/py/pypi-mirror/package.nix @@ -1,6 +1,7 @@ -{ fetchFromGitHub -, lib -, python3 +{ + fetchFromGitHub, + lib, + python3, }: python3.pkgs.buildPythonApplication rec { pname = "pypi-mirror"; diff --git a/pkgs/by-name/py/pyprland/package.nix b/pkgs/by-name/py/pyprland/package.nix index 009fae318cff94..04b1737ab5077c 100644 --- a/pkgs/by-name/py/pyprland/package.nix +++ b/pkgs/by-name/py/pyprland/package.nix @@ -61,7 +61,7 @@ python3Packages.buildPythonApplication rec { "pyprland.plugins.workspaces_follow_focus" ]; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = { mainProgram = "pypr"; diff --git a/pkgs/by-name/py/pyradio/package.nix b/pkgs/by-name/py/pyradio/package.nix index 85ccaedd97a8b9..2031fff68d417a 100644 --- a/pkgs/by-name/py/pyradio/package.nix +++ b/pkgs/by-name/py/pyradio/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3Packages -, fetchFromGitHub -, installShellFiles +{ + lib, + python3Packages, + fetchFromGitHub, + installShellFiles, }: python3Packages.buildPythonApplication rec { @@ -48,6 +49,9 @@ python3Packages.buildPythonApplication rec { mainProgram = "pyradio"; changelog = "https://github.com/coderholic/pyradio/releases/tag/${version}"; license = licenses.mit; - maintainers = with maintainers; [ contrun yayayayaka ]; + maintainers = with maintainers; [ + contrun + yayayayaka + ]; }; } diff --git a/pkgs/by-name/py/pyrosimple/package.nix b/pkgs/by-name/py/pyrosimple/package.nix index cea1cf216a2e01..a47aa447d1c95c 100644 --- a/pkgs/by-name/py/pyrosimple/package.nix +++ b/pkgs/by-name/py/pyrosimple/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pyrosimple -, python3 -, testers -, withInotify ? stdenv.hostPlatform.isLinux +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pyrosimple, + python3, + testers, + withInotify ? stdenv.hostPlatform.isLinux, }: python3.pkgs.buildPythonApplication rec { @@ -29,22 +30,26 @@ python3.pkgs.buildPythonApplication rec { poetry-core ]; - propagatedBuildInputs = with python3.pkgs; [ - bencode-py - apscheduler - jinja2 - python-daemon - importlib-resources - parsimonious - prometheus-client - prompt-toolkit - requests - shtab - python-box - tomli-w - ] ++ lib.optionals (pythonOlder "3.11") [ - tomli - ] ++ lib.optional withInotify inotify; + propagatedBuildInputs = + with python3.pkgs; + [ + bencode-py + apscheduler + jinja2 + python-daemon + importlib-resources + parsimonious + prometheus-client + prompt-toolkit + requests + shtab + python-box + tomli-w + ] + ++ lib.optionals (pythonOlder "3.11") [ + tomli + ] + ++ lib.optional withInotify inotify; nativeCheckInputs = with python3.pkgs; [ pytestCheckHook @@ -63,6 +68,9 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://kannibalox.github.io/pyrosimple/"; changelog = "https://github.com/kannibalox/pyrosimple/blob/v${version}/CHANGELOG.md"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ ne9z vamega ]; + maintainers = with maintainers; [ + ne9z + vamega + ]; }; } diff --git a/pkgs/by-name/py/pyrseas/package.nix b/pkgs/by-name/py/pyrseas/package.nix index 03b0a5cecbbbf7..b408f480b572ba 100644 --- a/pkgs/by-name/py/pyrseas/package.nix +++ b/pkgs/by-name/py/pyrseas/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: let pgdbconn = python3Packages.buildPythonPackage rec { @@ -15,7 +19,10 @@ let # The tests are impure (they try to access a PostgreSQL server) doCheck = false; - propagatedBuildInputs = with python3Packages; [ psycopg2 pytest ]; + propagatedBuildInputs = with python3Packages; [ + psycopg2 + pytest + ]; }; in diff --git a/pkgs/by-name/py/pysentation/package.nix b/pkgs/by-name/py/pysentation/package.nix index 41568d0295b321..508d0486562df5 100644 --- a/pkgs/by-name/py/pysentation/package.nix +++ b/pkgs/by-name/py/pysentation/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/py/pyspread/package.nix b/pkgs/by-name/py/pyspread/package.nix index 3342daef620089..de0b06f85e08d7 100644 --- a/pkgs/by-name/py/pyspread/package.nix +++ b/pkgs/by-name/py/pyspread/package.nix @@ -1,9 +1,10 @@ -{ lib -, python3 -, fetchPypi -, copyDesktopItems -, libsForQt5 -, makeDesktopItem +{ + lib, + python3, + fetchPypi, + copyDesktopItems, + libsForQt5, + makeDesktopItem, }: let @@ -16,7 +17,8 @@ let }; inherit (libsForQt5) qtsvg - wrapQtAppsHook; + wrapQtAppsHook + ; in python3.pkgs.buildPythonApplication { inherit pname version src; @@ -54,7 +56,11 @@ python3.pkgs.buildPythonApplication { desktopName = "Pyspread"; genericName = "Spreadsheet"; comment = "A Python-oriented spreadsheet application"; - categories = [ "Office" "Development" "Spreadsheet" ]; + categories = [ + "Office" + "Development" + "Spreadsheet" + ]; }) ]; diff --git a/pkgs/by-name/py/pystring/package.nix b/pkgs/by-name/py/pystring/package.nix index 4ed250439803be..3e885d78d1c603 100644 --- a/pkgs/by-name/py/pystring/package.nix +++ b/pkgs/by-name/py/pystring/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, cmake }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, +}: stdenv.mkDerivation rec { pname = "pystring"; diff --git a/pkgs/by-name/py/python-cosmopolitan/package.nix b/pkgs/by-name/py/python-cosmopolitan/package.nix index a513c097fbcbe3..8e24c76668053e 100644 --- a/pkgs/by-name/py/python-cosmopolitan/package.nix +++ b/pkgs/by-name/py/python-cosmopolitan/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, cosmopolitan, unzip, bintools-unwrapped }: +{ + lib, + stdenv, + cosmopolitan, + unzip, + bintools-unwrapped, +}: stdenv.mkDerivation rec { pname = "python-cosmopolitan"; @@ -6,7 +12,10 @@ stdenv.mkDerivation rec { src = cosmopolitan.dist; - nativeBuildInputs = [ bintools-unwrapped unzip ]; + nativeBuildInputs = [ + bintools-unwrapped + unzip + ]; # slashes are significant because upstream uses o/$(MODE)/foo.o buildFlags = [ "o//third_party/python" ]; diff --git a/pkgs/by-name/py/python-launcher/package.nix b/pkgs/by-name/py/python-launcher/package.nix index 854f1e39e1a2d7..ebdc31a1ebf753 100644 --- a/pkgs/by-name/py/python-launcher/package.nix +++ b/pkgs/by-name/py/python-launcher/package.nix @@ -1,4 +1,9 @@ -{ lib, rustPlatform, fetchFromGitHub, python3 }: +{ + lib, + rustPlatform, + fetchFromGitHub, + python3, +}: rustPlatform.buildRustPackage rec { pname = "python-launcher"; diff --git a/pkgs/by-name/py/pytrainer/package.nix b/pkgs/by-name/py/pytrainer/package.nix index 80ebfc7c5a110f..aa075f4f8604ae 100644 --- a/pkgs/by-name/py/pytrainer/package.nix +++ b/pkgs/by-name/py/pytrainer/package.nix @@ -1,31 +1,35 @@ -{ lib -, python3 -, fetchFromGitHub -, gdk-pixbuf -, adwaita-icon-theme -, gpsbabel -, glib-networking -, glibcLocales -, gobject-introspection -, gtk3 -, perl -, sqlite -, tzdata -, webkitgtk_4_0 -, wrapGAppsHook3 -, xvfb-run +{ + lib, + python3, + fetchFromGitHub, + gdk-pixbuf, + adwaita-icon-theme, + gpsbabel, + glib-networking, + glibcLocales, + gobject-introspection, + gtk3, + perl, + sqlite, + tzdata, + webkitgtk_4_0, + wrapGAppsHook3, + xvfb-run, }: let python = python3.override { self = python; - packageOverrides = (self: super: { - matplotlib = super.matplotlib.override { - enableGtk3 = true; - }; - }); + packageOverrides = ( + self: super: { + matplotlib = super.matplotlib.override { + enableGtk3 = true; + }; + } + ); }; -in python.pkgs.buildPythonApplication rec { +in +python.pkgs.buildPythonApplication rec { pname = "pytrainer"; version = "2.2.1"; @@ -61,17 +65,25 @@ in python.pkgs.buildPythonApplication rec { ]; makeWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath [ perl gpsbabel ]) + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ + perl + gpsbabel + ]) ]; - nativeCheckInputs = [ - glibcLocales - perl - xvfb-run - ] ++ (with python.pkgs; [ - mysqlclient - psycopg2 - ]); + nativeCheckInputs = + [ + glibcLocales + perl + xvfb-run + ] + ++ (with python.pkgs; [ + mysqlclient + psycopg2 + ]); postPatch = '' substituteInPlace pytrainer/platform.py \ @@ -92,7 +104,10 @@ in python.pkgs.buildPythonApplication rec { homepage = "https://github.com/pytrainer/pytrainer"; description = "Application for logging and graphing sporting excursions"; mainProgram = "pytrainer"; - maintainers = with maintainers; [ rycee dotlambda ]; + maintainers = with maintainers; [ + rycee + dotlambda + ]; license = licenses.gpl2Plus; platforms = platforms.linux; }; diff --git a/pkgs/by-name/pz/pzip/package.nix b/pkgs/by-name/pz/pzip/package.nix index 625f1f4492bc41..36a95dd991dfb3 100644 --- a/pkgs/by-name/pz/pzip/package.nix +++ b/pkgs/by-name/pz/pzip/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, unzip +{ + lib, + buildGoModule, + fetchFromGitHub, + unzip, }: buildGoModule rec { @@ -21,7 +22,10 @@ buildGoModule rec { unzip ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Fast concurrent zip archiver and extractor"; diff --git a/pkgs/by-name/q-/q-text-as-data/package.nix b/pkgs/by-name/q-/q-text-as-data/package.nix index 5a63752b82383a..aff72741d8740e 100644 --- a/pkgs/by-name/q-/q-text-as-data/package.nix +++ b/pkgs/by-name/q-/q-text-as-data/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "q-text-as-data"; diff --git a/pkgs/by-name/qa/qadwaitadecorations/package.nix b/pkgs/by-name/qa/qadwaitadecorations/package.nix index bbfeec06f27db2..dfeb8bde120796 100644 --- a/pkgs/by-name/qa/qadwaitadecorations/package.nix +++ b/pkgs/by-name/qa/qadwaitadecorations/package.nix @@ -1,23 +1,25 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qt5 -, qt6 -, wayland -, nix-update-script -, useQt6 ? false - -# Shadows support on Qt5 requires the feature backported from Qt6: -# https://src.fedoraproject.org/rpms/qt5-qtwayland/blob/rawhide/f/qtwayland-decoration-support-backports-from-qt6.patch -, qt5ShadowsSupport ? false +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qt5, + qt6, + wayland, + nix-update-script, + useQt6 ? false, + + # Shadows support on Qt5 requires the feature backported from Qt6: + # https://src.fedoraproject.org/rpms/qt5-qtwayland/blob/rawhide/f/qtwayland-decoration-support-backports-from-qt6.patch + qt5ShadowsSupport ? false, }: let qt = if useQt6 then qt6 else qt5; qtVersion = if useQt6 then "6" else "5"; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "qadwaitadecorations"; version = "0.1.6"; @@ -41,9 +43,11 @@ in stdenv.mkDerivation (finalAttrs: { dontWrapQtApps = true; - cmakeFlags = [ - "-DQT_PLUGINS_DIR=${placeholder "out"}/${qt.qtbase.qtPluginPrefix}" - ] ++ lib.optional useQt6 "-DUSE_QT6=true" + cmakeFlags = + [ + "-DQT_PLUGINS_DIR=${placeholder "out"}/${qt.qtbase.qtPluginPrefix}" + ] + ++ lib.optional useQt6 "-DUSE_QT6=true" ++ lib.optional qt5ShadowsSupport "-DHAS_QT6_SUPPORT=true"; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/by-name/qa/qalculate-gtk/package.nix b/pkgs/by-name/qa/qalculate-gtk/package.nix index a4b148ad8da38d..c1ee7e570322ec 100644 --- a/pkgs/by-name/qa/qalculate-gtk/package.nix +++ b/pkgs/by-name/qa/qalculate-gtk/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, intltool, autoreconfHook, pkg-config, libqalculate, gtk3, curl, wrapGAppsHook3, desktopToDarwinBundle }: +{ + lib, + stdenv, + fetchFromGitHub, + intltool, + autoreconfHook, + pkg-config, + libqalculate, + gtk3, + curl, + wrapGAppsHook3, + desktopToDarwinBundle, +}: stdenv.mkDerivation (finalAttrs: { pname = "qalculate-gtk"; @@ -13,9 +25,17 @@ stdenv.mkDerivation (finalAttrs: { hardeningDisable = [ "format" ]; - nativeBuildInputs = [ intltool pkg-config autoreconfHook wrapGAppsHook3 ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; - buildInputs = [ libqalculate gtk3 curl ]; + nativeBuildInputs = [ + intltool + pkg-config + autoreconfHook + wrapGAppsHook3 + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; + buildInputs = [ + libqalculate + gtk3 + curl + ]; enableParallelBuilding = true; meta = with lib; { diff --git a/pkgs/by-name/qb/qbe/package.nix b/pkgs/by-name/qb/qbe/package.nix index f37de57b535e5a..194b374e4faf8e 100644 --- a/pkgs/by-name/qb/qbe/package.nix +++ b/pkgs/by-name/qb/qbe/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchzip -, callPackage +{ + lib, + stdenv, + fetchzip, + callPackage, }: stdenv.mkDerivation (finalAttrs: { pname = "qbe"; diff --git a/pkgs/by-name/qb/qbe/test-can-run-hello-world.nix b/pkgs/by-name/qb/qbe/test-can-run-hello-world.nix index 5192bb881f3435..8194f08eeccec1 100644 --- a/pkgs/by-name/qb/qbe/test-can-run-hello-world.nix +++ b/pkgs/by-name/qb/qbe/test-can-run-hello-world.nix @@ -1,25 +1,28 @@ -{ stdenv -, writeText -, qbe +{ + stdenv, + writeText, + qbe, }: # The hello world program available at https://c9x.me/compile/ -let helloWorld = writeText "hello-world.ssa" '' - function w $add(w %a, w %b) { # Define a function add - @start - %c =w add %a, %b # Adds the 2 arguments - ret %c # Return the result - } - export function w $main() { # Main function - @start - %r =w call $add(w 1, w 1) # Call add(1, 1) - call $printf(l $fmt, w %r, ...) # Show the result - ret 0 - } - data $fmt = { b "One and one make %d!\n", b 0 } -''; +let + helloWorld = writeText "hello-world.ssa" '' + function w $add(w %a, w %b) { # Define a function add + @start + %c =w add %a, %b # Adds the 2 arguments + ret %c # Return the result + } + export function w $main() { # Main function + @start + %r =w call $add(w 1, w 1) # Call add(1, 1) + call $printf(l $fmt, w %r, ...) # Show the result + ret 0 + } + data $fmt = { b "One and one make %d!\n", b 0 } + ''; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { name = "qbe-test-can-run-hello-world"; meta.timeout = 10; buildCommand = '' @@ -29,4 +32,3 @@ in stdenv.mkDerivation { touch $out ''; } - diff --git a/pkgs/by-name/qb/qbec/package.nix b/pkgs/by-name/qb/qbec/package.nix index c6451cebfedd3b..3024e29a8feeca 100644 --- a/pkgs/by-name/qb/qbec/package.nix +++ b/pkgs/by-name/qb/qbec/package.nix @@ -1,4 +1,9 @@ -{ lib, go, buildGoModule, fetchFromGitHub }: +{ + lib, + go, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "qbec"; @@ -16,7 +21,8 @@ buildGoModule rec { doCheck = false; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/splunk/qbec/internal/commands.version=${version}" "-X github.com/splunk/qbec/internal/commands.commit=${src.rev}" "-X github.com/splunk/qbec/internal/commands.goVersion=${lib.getVersion go}" diff --git a/pkgs/by-name/qc/qc/package.nix b/pkgs/by-name/qc/qc/package.nix index 02e6cefd9ff4b9..31121dc707bbe4 100644 --- a/pkgs/by-name/qc/qc/package.nix +++ b/pkgs/by-name/qc/qc/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "qc"; @@ -14,7 +19,9 @@ buildGoModule rec { vendorHash = "sha256-Cg1Op/4okIi2UTtqWnR0N3iMWzrYEaYxmXzvWIibftg="; ldflags = [ - "-s" "-w" "-X=github.com/qownnotes/qc/cmd.version=${version}" + "-s" + "-w" + "-X=github.com/qownnotes/qc/cmd.version=${version}" ]; # There are no automated tests @@ -39,6 +46,9 @@ buildGoModule rec { mainProgram = "qc"; homepage = "https://github.com/qownnotes/qc"; license = licenses.mit; - maintainers = with maintainers; [ pbek totoroot ]; + maintainers = with maintainers; [ + pbek + totoroot + ]; }; } diff --git a/pkgs/by-name/qc/qcard/package.nix b/pkgs/by-name/qc/qcard/package.nix index 16ffb5d686feac..2b16fc335a705b 100644 --- a/pkgs/by-name/qc/qcard/package.nix +++ b/pkgs/by-name/qc/qcard/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromSourcehut +{ + lib, + buildGoModule, + fetchFromSourcehut, }: buildGoModule rec { diff --git a/pkgs/by-name/qc/qcdnum/package.nix b/pkgs/by-name/qc/qcdnum/package.nix index 565a0c317cd85c..2db2f8f837c8ed 100644 --- a/pkgs/by-name/qc/qcdnum/package.nix +++ b/pkgs/by-name/qc/qcdnum/package.nix @@ -1,11 +1,19 @@ -{ lib, stdenv, fetchurl, gfortran, zlib }: +{ + lib, + stdenv, + fetchurl, + gfortran, + zlib, +}: stdenv.mkDerivation rec { pname = "QCDNUM"; version = "18-00-00"; src = fetchurl { - url = "http://www.nikhef.nl/user/h24/qcdnum-files/download/qcdnum${builtins.replaceStrings ["-"] [""] version}.tar.gz"; + url = "http://www.nikhef.nl/user/h24/qcdnum-files/download/qcdnum${ + builtins.replaceStrings [ "-" ] [ "" ] version + }.tar.gz"; hash = "sha256-4Qj5JreEA1LkCAunGRTTQD7YEYNk+HcQ4iH97DIO4gA="; }; @@ -21,9 +29,9 @@ stdenv.mkDerivation rec { meta = { description = "Very fast QCD evolution program written in FORTRAN77"; mainProgram = "qcdnum-config"; - license = lib.licenses.gpl3; - homepage = "https://www.nikhef.nl/~h24/qcdnum/index.html"; - platforms = lib.platforms.unix; + license = lib.licenses.gpl3; + homepage = "https://www.nikhef.nl/~h24/qcdnum/index.html"; + platforms = lib.platforms.unix; maintainers = with lib.maintainers; [ veprbl ]; }; } diff --git a/pkgs/by-name/qd/qdl/package.nix b/pkgs/by-name/qd/qdl/package.nix index 24c62722c1411f..7edc70d122c792 100644 --- a/pkgs/by-name/qd/qdl/package.nix +++ b/pkgs/by-name/qd/qdl/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, libxml2 -, systemd -, libusb1 -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libxml2, + systemd, + libusb1, + unstableGitUpdater, }: stdenv.mkDerivation { - pname = "qdl"; + pname = "qdl"; version = "unstable-2024-06-10"; src = fetchFromGitHub { @@ -20,7 +21,11 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ systemd libxml2 libusb1 ]; + buildInputs = [ + systemd + libxml2 + libusb1 + ]; installPhase = '' runHook preInstall @@ -32,7 +37,10 @@ stdenv.mkDerivation { homepage = "https://github.com/linux-msm/qdl"; description = "Tool for flashing images to Qualcomm devices"; license = licenses.bsd3; - maintainers = with maintainers; [ muscaln anas ]; + maintainers = with maintainers; [ + muscaln + anas + ]; platforms = platforms.linux; mainProgram = "qdl"; }; diff --git a/pkgs/by-name/qe/qemacs/package.nix b/pkgs/by-name/qe/qemacs/package.nix index 46ecfa0259599d..a745ea233978fc 100644 --- a/pkgs/by-name/qe/qemacs/package.nix +++ b/pkgs/by-name/qe/qemacs/package.nix @@ -1,11 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildPackages -, which -, texi2html -, enableX11 ? true -, libX11, libXext, libXv, libpng +{ + lib, + stdenv, + fetchFromGitHub, + buildPackages, + which, + texi2html, + enableX11 ? true, + libX11, + libXext, + libXv, + libpng, }: stdenv.mkDerivation rec { @@ -25,16 +29,26 @@ stdenv.mkDerivation rec { '$(INSTALL) -m 755 -s --strip-program=${stdenv.cc.targetPrefix}strip' ''; - nativeBuildInputs = [ which texi2html ]; - buildInputs = lib.optionals enableX11 [ libpng libX11 libXext libXv ]; + nativeBuildInputs = [ + which + texi2html + ]; + buildInputs = lib.optionals enableX11 [ + libpng + libX11 + libXext + libXv + ]; enableParallelBuilding = true; - configureFlags = [ - "--cross-prefix=${stdenv.cc.targetPrefix}" - ] ++ lib.optionals (!enableX11) [ - "--disable-x11" - ]; + configureFlags = + [ + "--cross-prefix=${stdenv.cc.targetPrefix}" + ] + ++ lib.optionals (!enableX11) [ + "--disable-x11" + ]; makeFlags = [ # is actually used as BUILD_CC diff --git a/pkgs/by-name/qg/qgrep/package.nix b/pkgs/by-name/qg/qgrep/package.nix index f485aa0d9147ee..dbcd06c4ce6706 100644 --- a/pkgs/by-name/qg/qgrep/package.nix +++ b/pkgs/by-name/qg/qgrep/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + darwin, }: stdenv.mkDerivation rec { @@ -30,10 +31,12 @@ stdenv.mkDerivation rec { darwin.apple_sdk.frameworks.CoreFoundation ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-Wno-error=unused-command-line-argument" - "-Wno-error=unqualified-std-cast-call" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-Wno-error=unused-command-line-argument" + "-Wno-error=unqualified-std-cast-call" + ] + ); installPhase = '' runHook preInstall diff --git a/pkgs/by-name/qh/qhull/package.nix b/pkgs/by-name/qh/qhull/package.nix index 998575bb166c15..84777ff28cdcb9 100644 --- a/pkgs/by-name/qh/qhull/package.nix +++ b/pkgs/by-name/qh/qhull/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, fixDarwinDylibNames }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fixDarwinDylibNames, +}: stdenv.mkDerivation rec { pname = "qhull"; @@ -11,8 +17,7 @@ stdenv.mkDerivation rec { sha256 = "sha256-djUO3qzY8ch29AuhY3Bn1ajxWZ4/W70icWVrxWRAxRc="; }; - nativeBuildInputs = [ cmake ] - ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; + nativeBuildInputs = [ cmake ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; meta = with lib; { homepage = "http://www.qhull.org/"; diff --git a/pkgs/by-name/qm/qm-dsp/package.nix b/pkgs/by-name/qm/qm-dsp/package.nix index 2201f02c62e876..634029eb900b9f 100644 --- a/pkgs/by-name/qm/qm-dsp/package.nix +++ b/pkgs/by-name/qm/qm-dsp/package.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, kissfft +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + kissfft, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/qm/qmidiarp/package.nix b/pkgs/by-name/qm/qmidiarp/package.nix index 1208697dc3a44d..2b3f4ae16f96fd 100644 --- a/pkgs/by-name/qm/qmidiarp/package.nix +++ b/pkgs/by-name/qm/qmidiarp/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchgit -, autoreconfHook -, lv2 -, pkg-config -, qt5 -, alsa-lib -, libjack2 +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + lv2, + pkg-config, + qt5, + alsa-lib, + libjack2, }: stdenv.mkDerivation rec { @@ -24,13 +26,15 @@ stdenv.mkDerivation rec { qt5.wrapQtAppsHook ]; - buildInputs = [ - alsa-lib - lv2 - libjack2 - ] ++ (with qt5; [ - qttools - ]); + buildInputs = + [ + alsa-lib + lv2 + libjack2 + ] + ++ (with qt5; [ + qttools + ]); meta = with lib; { description = "Advanced MIDI arpeggiator"; diff --git a/pkgs/by-name/qm/qmk-udev-rules/package.nix b/pkgs/by-name/qm/qmk-udev-rules/package.nix index bd322bfa100e94..8775e8dd37ee7a 100644 --- a/pkgs/by-name/qm/qmk-udev-rules/package.nix +++ b/pkgs/by-name/qm/qmk-udev-rules/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: ## Usage # In NixOS, set hardware.keyboard.qmk.enable = true; diff --git a/pkgs/by-name/qm/qmk/package.nix b/pkgs/by-name/qm/qmk/package.nix index b45d480ba16d15..730d45db20614c 100644 --- a/pkgs/by-name/qm/qmk/package.nix +++ b/pkgs/by-name/qm/qmk/package.nix @@ -1,14 +1,15 @@ -{ lib -, python3 -, fetchPypi -, pkgsCross -, avrdude -, dfu-programmer -, dfu-util -, wb32-dfu-updater -, gcc-arm-embedded -, gnumake -, teensy-loader-cli +{ + lib, + python3, + fetchPypi, + pkgsCross, + avrdude, + dfu-programmer, + dfu-util, + wb32-dfu-updater, + gcc-arm-embedded, + gnumake, + teensy-loader-cli, }: python3.pkgs.buildPythonApplication rec { @@ -25,29 +26,33 @@ python3.pkgs.buildPythonApplication rec { setuptools ]; - propagatedBuildInputs = with python3.pkgs; [ - dotty-dict - hid - hjson - jsonschema - milc - pygments - pyserial - pyusb - pillow - ] ++ [ # Binaries need to be in the path so this is in propagatedBuildInputs - avrdude - dfu-programmer - dfu-util - wb32-dfu-updater - teensy-loader-cli - gcc-arm-embedded - gnumake - pkgsCross.avr.buildPackages.binutils - pkgsCross.avr.buildPackages.binutils.bintools - pkgsCross.avr.buildPackages.gcc - pkgsCross.avr.libcCross - ]; + propagatedBuildInputs = + with python3.pkgs; + [ + dotty-dict + hid + hjson + jsonschema + milc + pygments + pyserial + pyusb + pillow + ] + ++ [ + # Binaries need to be in the path so this is in propagatedBuildInputs + avrdude + dfu-programmer + dfu-util + wb32-dfu-updater + teensy-loader-cli + gcc-arm-embedded + gnumake + pkgsCross.avr.buildPackages.binutils + pkgsCross.avr.buildPackages.binutils.bintools + pkgsCross.avr.buildPackages.gcc + pkgsCross.avr.libcCross + ]; # no tests implemented doCheck = false; @@ -70,7 +75,10 @@ python3.pkgs.buildPythonApplication rec { - ... and many more! ''; license = licenses.mit; - maintainers = with maintainers; [ bhipple ekleog ]; + maintainers = with maintainers; [ + bhipple + ekleog + ]; mainProgram = "qmk"; }; } diff --git a/pkgs/by-name/qm/qmk_hid/package.nix b/pkgs/by-name/qm/qmk_hid/package.nix index f620dabb19cd7e..24872834515379 100644 --- a/pkgs/by-name/qm/qmk_hid/package.nix +++ b/pkgs/by-name/qm/qmk_hid/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, systemd +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + systemd, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/qm/qmqtt/package.nix b/pkgs/by-name/qm/qmqtt/package.nix index 6ccf272f61e26d..45789db4a2bff6 100644 --- a/pkgs/by-name/qm/qmqtt/package.nix +++ b/pkgs/by-name/qm/qmqtt/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qt5 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qt5, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/qn/qnial/package.nix b/pkgs/by-name/qn/qnial/package.nix index 0ba34b8a657239..afba39d315f6cf 100644 --- a/pkgs/by-name/qn/qnial/package.nix +++ b/pkgs/by-name/qn/qnial/package.nix @@ -25,8 +25,8 @@ stdenv.mkDerivation (finalAttrs: { ]; buildInputs = [ - ncurses - libxcrypt + ncurses + libxcrypt ]; strictDeps = true; diff --git a/pkgs/by-name/qo/qodem/package.nix b/pkgs/by-name/qo/qodem/package.nix index 3398e9749d0888..f0025b9915c53b 100644 --- a/pkgs/by-name/qo/qodem/package.nix +++ b/pkgs/by-name/qo/qodem/package.nix @@ -51,13 +51,15 @@ stdenv.mkDerivation (finalAttrs: { autoreconfHook ]; - buildInputs = [ - ncurses - SDL - miniupnpc - ] ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform gpm) [ - gpm - ]; + buildInputs = + [ + ncurses + SDL + miniupnpc + ] + ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform gpm) [ + gpm + ]; configureFlags = lib.optionals (!(lib.meta.availableOn stdenv.hostPlatform gpm)) [ "--disable-gpm" diff --git a/pkgs/by-name/qo/qogir-icon-theme/package.nix b/pkgs/by-name/qo/qogir-icon-theme/package.nix index bfa4e33fc8ca69..97ce4e43593560 100644 --- a/pkgs/by-name/qo/qogir-icon-theme/package.nix +++ b/pkgs/by-name/qo/qogir-icon-theme/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gitUpdater -, gtk3 -, hicolor-icon-theme -, jdupes -, colorVariants ? [] # default is all -, themeVariants ? [] # default is all +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gitUpdater, + gtk3, + hicolor-icon-theme, + jdupes, + colorVariants ? [ ], # default is all + themeVariants ? [ ], # default is all }: let @@ -14,55 +15,62 @@ let in lib.checkListOfEnum "${pname}: color variants" [ "standard" "dark" "all" ] colorVariants -lib.checkListOfEnum "${pname}: theme variants" [ "default" "manjaro" "ubuntu" "all" ] themeVariants + lib.checkListOfEnum + "${pname}: theme variants" + [ "default" "manjaro" "ubuntu" "all" ] + themeVariants -stdenvNoCC.mkDerivation rec { - inherit pname; - version = "2023-06-05"; + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "2023-06-05"; - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = version; - sha256 = "sha256-qiHmA/K4hdXVSFzergGhgssKR+kXp3X0cqtX1X5ayM4="; - }; + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = version; + sha256 = "sha256-qiHmA/K4hdXVSFzergGhgssKR+kXp3X0cqtX1X5ayM4="; + }; - nativeBuildInputs = [ gtk3 jdupes ]; + nativeBuildInputs = [ + gtk3 + jdupes + ]; - propagatedBuildInputs = [ hicolor-icon-theme ]; + propagatedBuildInputs = [ hicolor-icon-theme ]; - dontDropIconThemeCache = true; + dontDropIconThemeCache = true; - # These fixup steps are slow and unnecessary. - dontPatchELF = true; - dontRewriteSymlinks = true; + # These fixup steps are slow and unnecessary. + dontPatchELF = true; + dontRewriteSymlinks = true; - postPatch = '' - patchShebangs install.sh - ''; + postPatch = '' + patchShebangs install.sh + ''; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $out/share/icons + mkdir -p $out/share/icons - name= ./install.sh \ - ${lib.optionalString (themeVariants != []) ("--theme " + builtins.toString themeVariants)} \ - ${lib.optionalString (colorVariants != []) ("--color " + builtins.toString colorVariants)} \ - --dest $out/share/icons + name= ./install.sh \ + ${lib.optionalString (themeVariants != [ ]) ("--theme " + builtins.toString themeVariants)} \ + ${lib.optionalString (colorVariants != [ ]) ("--color " + builtins.toString colorVariants)} \ + --dest $out/share/icons - jdupes --quiet --link-soft --recurse $out/share + jdupes --quiet --link-soft --recurse $out/share - runHook postInstall - ''; + runHook postInstall + ''; - passthru.updateScript = gitUpdater { }; + passthru.updateScript = gitUpdater { }; - meta = with lib; { - description = "Flat colorful design icon theme"; - homepage = "https://github.com/vinceliuice/Qogir-icon-theme"; - license = with licenses; [ gpl3Only ]; - platforms = platforms.linux; - maintainers = with maintainers; [ romildo ]; - }; -} + meta = with lib; { + description = "Flat colorful design icon theme"; + homepage = "https://github.com/vinceliuice/Qogir-icon-theme"; + license = with licenses; [ gpl3Only ]; + platforms = platforms.linux; + maintainers = with maintainers; [ romildo ]; + }; + } diff --git a/pkgs/by-name/qo/qogir-theme/package.nix b/pkgs/by-name/qo/qogir-theme/package.nix index 223e077bfe476e..622c7cdf85ae38 100644 --- a/pkgs/by-name/qo/qogir-theme/package.nix +++ b/pkgs/by-name/qo/qogir-theme/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, gitUpdater -, gdk-pixbuf -, gnome-themes-extra -, gtk-engine-murrine -, jdupes -, librsvg -, sassc -, which -, themeVariants ? [] # default: blue -, colorVariants ? [] # default: all -, tweaks ? [] +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + gdk-pixbuf, + gnome-themes-extra, + gtk-engine-murrine, + jdupes, + librsvg, + sassc, + which, + themeVariants ? [ ], # default: blue + colorVariants ? [ ], # default: all + tweaks ? [ ], }: let @@ -19,68 +20,75 @@ let in lib.checkListOfEnum "${pname}: theme variants" [ "default" "manjaro" "ubuntu" "all" ] themeVariants -lib.checkListOfEnum "${pname}: color variants" [ "standard" "light" "dark" ] colorVariants -lib.checkListOfEnum "${pname}: tweaks" [ "image" "square" "round" ] tweaks - -stdenv.mkDerivation rec { - inherit pname; - version = "2024-05-22"; - - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = version; - sha256 = "Q9DWBzaLZjwXsYRa/oDIrccypO3TCbSRXTkbXWRmm70="; - }; - - nativeBuildInputs = [ - jdupes - sassc - which - ]; - - buildInputs = [ - gdk-pixbuf # pixbuf engine for Gtk2 - gnome-themes-extra # adwaita engine for Gtk2 - librsvg # pixbuf loader for svg - ]; - - propagatedUserEnvPkgs = [ - gtk-engine-murrine # murrine engine for Gtk2 - ]; - - postPatch = '' - patchShebangs install.sh clean-old-theme.sh - ''; - - installPhase = '' - runHook preInstall - - mkdir -p $out/share/themes - - name= HOME="$TMPDIR" ./install.sh \ - ${lib.optionalString (themeVariants != []) "--theme " + builtins.toString themeVariants} \ - ${lib.optionalString (colorVariants != []) "--color " + builtins.toString colorVariants} \ - ${lib.optionalString (tweaks != []) "--tweaks " + builtins.toString tweaks} \ - --dest $out/share/themes - - mkdir -p $out/share/doc/${pname} - cp -a src/firefox $out/share/doc/${pname} - - rm $out/share/themes/*/{AUTHORS,COPYING} - - jdupes --quiet --link-soft --recurse $out/share - - runHook postInstall - ''; - - passthru.updateScript = gitUpdater { }; - - meta = with lib; { - description = "Flat Design theme for GTK based desktop environments"; - homepage = "https://github.com/vinceliuice/Qogir-theme"; - license = licenses.gpl3Only; - platforms = platforms.unix; - maintainers = [ maintainers.romildo ]; - }; -} + lib.checkListOfEnum + "${pname}: color variants" + [ "standard" "light" "dark" ] + colorVariants + lib.checkListOfEnum + "${pname}: tweaks" + [ "image" "square" "round" ] + tweaks + + stdenv.mkDerivation + rec { + inherit pname; + version = "2024-05-22"; + + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = version; + sha256 = "Q9DWBzaLZjwXsYRa/oDIrccypO3TCbSRXTkbXWRmm70="; + }; + + nativeBuildInputs = [ + jdupes + sassc + which + ]; + + buildInputs = [ + gdk-pixbuf # pixbuf engine for Gtk2 + gnome-themes-extra # adwaita engine for Gtk2 + librsvg # pixbuf loader for svg + ]; + + propagatedUserEnvPkgs = [ + gtk-engine-murrine # murrine engine for Gtk2 + ]; + + postPatch = '' + patchShebangs install.sh clean-old-theme.sh + ''; + + installPhase = '' + runHook preInstall + + mkdir -p $out/share/themes + + name= HOME="$TMPDIR" ./install.sh \ + ${lib.optionalString (themeVariants != [ ]) "--theme " + builtins.toString themeVariants} \ + ${lib.optionalString (colorVariants != [ ]) "--color " + builtins.toString colorVariants} \ + ${lib.optionalString (tweaks != [ ]) "--tweaks " + builtins.toString tweaks} \ + --dest $out/share/themes + + mkdir -p $out/share/doc/${pname} + cp -a src/firefox $out/share/doc/${pname} + + rm $out/share/themes/*/{AUTHORS,COPYING} + + jdupes --quiet --link-soft --recurse $out/share + + runHook postInstall + ''; + + passthru.updateScript = gitUpdater { }; + + meta = with lib; { + description = "Flat Design theme for GTK based desktop environments"; + homepage = "https://github.com/vinceliuice/Qogir-theme"; + license = licenses.gpl3Only; + platforms = platforms.unix; + maintainers = [ maintainers.romildo ]; + }; + } diff --git a/pkgs/by-name/qo/qoi/package.nix b/pkgs/by-name/qo/qoi/package.nix index c5d527aa3ec552..eeb6c32988d11a 100644 --- a/pkgs/by-name/qo/qoi/package.nix +++ b/pkgs/by-name/qo/qoi/package.nix @@ -1,12 +1,13 @@ -{ fetchFromGitHub -, lib -, stb -, stdenv +{ + fetchFromGitHub, + lib, + stb, + stdenv, }: stdenv.mkDerivation (finalAttrs: { pname = "qoi"; - version = "unstable-2023-08-10"; # no upstream version yet. + version = "unstable-2023-08-10"; # no upstream version yet. src = fetchFromGitHub { owner = "phoboslab"; @@ -15,7 +16,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-E1hMtjMuDS2zma2s5hlHby/sroRGhtyZm9gLQ+VztsM="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ stb ]; diff --git a/pkgs/by-name/qp/qpdf/package.nix b/pkgs/by-name/qp/qpdf/package.nix index 4a9e520f2a979f..aa56c57ab7ffb9 100644 --- a/pkgs/by-name/qp/qpdf/package.nix +++ b/pkgs/by-name/qp/qpdf/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libjpeg -, perl -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libjpeg, + perl, + zlib, -# for passthru.tests -, cups-filters -, pdfmixtool -, pdfslicer -, python3 -, testers -, versionCheckHook + # for passthru.tests + cups-filters, + pdfmixtool, + pdfslicer, + python3, + testers, + versionCheckHook, }: stdenv.mkDerivation (finalAttrs: { @@ -34,9 +35,15 @@ stdenv.mkDerivation (finalAttrs: { "out" ]; - nativeBuildInputs = [ cmake perl ]; + nativeBuildInputs = [ + cmake + perl + ]; - buildInputs = [ zlib libjpeg ]; + buildInputs = [ + zlib + libjpeg + ]; nativeInstallCheckInputs = [ versionCheckHook ]; doInstallCheck = true; @@ -57,7 +64,7 @@ stdenv.mkDerivation (finalAttrs: { cups-filters pdfmixtool pdfslicer - ; + ; }; meta = { diff --git a/pkgs/by-name/qp/qperf/package.nix b/pkgs/by-name/qp/qperf/package.nix index 896b5f5c1ff481..4ec27077d53282 100644 --- a/pkgs/by-name/qp/qperf/package.nix +++ b/pkgs/by-name/qp/qperf/package.nix @@ -1,6 +1,13 @@ -{ stdenv, lib -, fetchFromGitHub, fetchpatch -, autoconf, automake, perl, rdma-core }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + autoconf, + automake, + perl, + rdma-core, +}: stdenv.mkDerivation rec { pname = "qperf"; @@ -13,16 +20,23 @@ stdenv.mkDerivation rec { hash = "sha256-x9l8xqwMDHlXRZpWt3XiqN5xyCTV5rk8jp/ClRPPECI="; }; - patches = [ (fetchpatch { - name = "version-bump.patch"; - url = "https://github.com/linux-rdma/qperf/commit/34ec57ddb7e5ae1adfcfc8093065dff90b69a275.patch"; - hash = "sha256-+7ckhUUB+7BG6qRKv0wgyIxkyvll2xjf3Wk1hpRsDo0="; - }) ]; + patches = [ + (fetchpatch { + name = "version-bump.patch"; + url = "https://github.com/linux-rdma/qperf/commit/34ec57ddb7e5ae1adfcfc8093065dff90b69a275.patch"; + hash = "sha256-+7ckhUUB+7BG6qRKv0wgyIxkyvll2xjf3Wk1hpRsDo0="; + }) + ]; - nativeBuildInputs = [ autoconf automake perl rdma-core ]; + nativeBuildInputs = [ + autoconf + automake + perl + rdma-core + ]; buildInputs = [ rdma-core ]; - postUnpack = '' + postUnpack = '' patchShebangs . ''; diff --git a/pkgs/by-name/qp/qpid-cpp/package.nix b/pkgs/by-name/qp/qpid-cpp/package.nix index 1760814771f91a..5d69a4c87416f2 100644 --- a/pkgs/by-name/qp/qpid-cpp/package.nix +++ b/pkgs/by-name/qp/qpid-cpp/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchpatch -, fetchurl -, boost -, cmake -, libuuid -, python3 -, ruby +{ + lib, + stdenv, + fetchpatch, + fetchurl, + boost, + cmake, + libuuid, + python3, + ruby, }: stdenv.mkDerivation rec { @@ -17,8 +19,15 @@ stdenv.mkDerivation rec { hash = "sha256-eYDQ6iHVV1WUFFdyHGnbqGIjE9CrhHzh0jP7amjoDSE="; }; - nativeBuildInputs = [ cmake python3 ]; - buildInputs = [ boost libuuid ruby ]; + nativeBuildInputs = [ + cmake + python3 + ]; + buildInputs = [ + boost + libuuid + ruby + ]; patches = [ (fetchpatch { @@ -36,11 +45,14 @@ stdenv.mkDerivation rec { sed -i '/management/d' CMakeLists.txt ''; - env.NIX_CFLAGS_COMPILE = toString ([ - "-Wno-error=maybe-uninitialized" - ] ++ lib.optionals stdenv.cc.isGNU [ - "-Wno-error=deprecated-copy" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-Wno-error=maybe-uninitialized" + ] + ++ lib.optionals stdenv.cc.isGNU [ + "-Wno-error=deprecated-copy" + ] + ); meta = with lib; { homepage = "https://qpid.apache.org"; diff --git a/pkgs/by-name/qp/qprint/package.nix b/pkgs/by-name/qp/qprint/package.nix index c0953f69a7f974..8dba3ab67ce44c 100644 --- a/pkgs/by-name/qp/qprint/package.nix +++ b/pkgs/by-name/qp/qprint/package.nix @@ -1,4 +1,8 @@ -{ fetchurl, lib, stdenv }: +{ + fetchurl, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "qprint"; diff --git a/pkgs/by-name/qr/qrcode/package.nix b/pkgs/by-name/qr/qrcode/package.nix index 0d919daf813771..ccb66cc4c53905 100644 --- a/pkgs/by-name/qr/qrcode/package.nix +++ b/pkgs/by-name/qr/qrcode/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, unstableGitUpdater }: +{ + lib, + stdenv, + fetchFromGitHub, + unstableGitUpdater, +}: stdenv.mkDerivation { pname = "qrcode"; @@ -25,7 +30,10 @@ stdenv.mkDerivation { description = "Small QR-code tool"; homepage = "https://github.com/qsantos/qrcode"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ raskin lucasew ]; + maintainers = with maintainers; [ + raskin + lucasew + ]; platforms = with platforms; unix; mainProgram = "qrcode"; }; diff --git a/pkgs/by-name/qr/qrcodegen/package.nix b/pkgs/by-name/qr/qrcodegen/package.nix index 53ed6eeb80ec1b..118d1db277aeb8 100644 --- a/pkgs/by-name/qr/qrcodegen/package.nix +++ b/pkgs/by-name/qr/qrcodegen/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/qr/qrcodegencpp/package.nix b/pkgs/by-name/qr/qrcodegencpp/package.nix index 655b948e81e10f..19525ee38fd056 100644 --- a/pkgs/by-name/qr/qrcodegencpp/package.nix +++ b/pkgs/by-name/qr/qrcodegencpp/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, qrcodegen +{ + lib, + stdenv, + qrcodegen, }: stdenv.mkDerivation (finalAttrs: { @@ -27,6 +28,12 @@ stdenv.mkDerivation (finalAttrs: { ''; meta = { - inherit (qrcodegen.meta) description homepage license maintainers platforms; + inherit (qrcodegen.meta) + description + homepage + license + maintainers + platforms + ; }; }) diff --git a/pkgs/by-name/qr/qrcp/package.nix b/pkgs/by-name/qr/qrcp/package.nix index 748412e17cba6c..1e965ad41bdd79 100644 --- a/pkgs/by-name/qr/qrcp/package.nix +++ b/pkgs/by-name/qr/qrcp/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -20,7 +21,11 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" "-X github.com/claudiodangelis/qrcp/version.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/claudiodangelis/qrcp/version.version=${version}" + ]; nativeBuildInputs = [ installShellFiles diff --git a/pkgs/by-name/qr/qrscan/package.nix b/pkgs/by-name/qr/qrscan/package.nix index 479c6102818abb..4bcb3bb0eeaa08 100644 --- a/pkgs/by-name/qr/qrscan/package.nix +++ b/pkgs/by-name/qr/qrscan/package.nix @@ -1,4 +1,10 @@ -{ clang_15, lib, rustPlatform, fetchFromGitHub, stdenv }: +{ + clang_15, + lib, + rustPlatform, + fetchFromGitHub, + stdenv, +}: rustPlatform.buildRustPackage rec { pname = "qrscan"; diff --git a/pkgs/by-name/qr/qrupdate/package.nix b/pkgs/by-name/qr/qrupdate/package.nix index 27c569ccad3990..d59e9ad1c0c6e9 100644 --- a/pkgs/by-name/qr/qrupdate/package.nix +++ b/pkgs/by-name/qr/qrupdate/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, lapack -, which -, gfortran -, blas +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + lapack, + which, + gfortran, + blas, }: stdenv.mkDerivation (finalAttrs: { @@ -19,19 +20,27 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-dHxLPrN00wwozagY2JyfZkD3sKUD2+BcnbjNgZepzFg="; }; - cmakeFlags = assert (blas.isILP64 == lapack.isILP64); [ - "-DCMAKE_Fortran_FLAGS=${toString ([ - "-std=legacy" - ] ++ lib.optionals blas.isILP64 [ - # If another application intends to use qrupdate compiled with blas with - # 64 bit support, it should add this to it's FFLAGS as well. See (e.g): - # https://savannah.gnu.org/bugs/?50339 - "-fdefault-integer-8" - ])}" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # prevent cmake from using Accelerate, which causes all tests to segfault - "-DBLA_VENDOR=Generic" - ]; + cmakeFlags = + assert (blas.isILP64 == lapack.isILP64); + [ + "-DCMAKE_Fortran_FLAGS=${ + toString ( + [ + "-std=legacy" + ] + ++ lib.optionals blas.isILP64 [ + # If another application intends to use qrupdate compiled with blas with + # 64 bit support, it should add this to it's FFLAGS as well. See (e.g): + # https://savannah.gnu.org/bugs/?50339 + "-fdefault-integer-8" + ] + ) + }" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # prevent cmake from using Accelerate, which causes all tests to segfault + "-DBLA_VENDOR=Generic" + ]; # https://github.com/mpimd-csc/qrupdate-ng/issues/4 patches = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ diff --git a/pkgs/by-name/qs/qsreplace/package.nix b/pkgs/by-name/qs/qsreplace/package.nix index 6949374e212f44..bc0e71483ed73a 100644 --- a/pkgs/by-name/qs/qsreplace/package.nix +++ b/pkgs/by-name/qs/qsreplace/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/tomnomnom/qsreplace"; diff --git a/pkgs/by-name/qt/qtractor/package.nix b/pkgs/by-name/qt/qtractor/package.nix index 8cd939fa8ed220..c305a89fc8d77c 100644 --- a/pkgs/by-name/qt/qtractor/package.nix +++ b/pkgs/by-name/qt/qtractor/package.nix @@ -1,30 +1,31 @@ -{ lib -, alsa-lib -, aubio -, cmake -, dssi -, fetchurl -, flac -, libjack2 -, ladspaH -, ladspaPlugins -, liblo -, libmad -, libsamplerate -, libsndfile -, libtool -, libvorbis -, lilv -, lv2 -, opusfile -, pkg-config -, qt6 -, rubberband -, serd -, stdenv -, sord -, sratom -, suil +{ + lib, + alsa-lib, + aubio, + cmake, + dssi, + fetchurl, + flac, + libjack2, + ladspaH, + ladspaPlugins, + liblo, + libmad, + libsamplerate, + libsndfile, + libtool, + libvorbis, + lilv, + lv2, + opusfile, + pkg-config, + qt6, + rubberband, + serd, + stdenv, + sord, + sratom, + suil, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/qu/QuadProgpp/package.nix b/pkgs/by-name/qu/QuadProgpp/package.nix index dfd33ed603afc8..d7306f01ba9833 100644 --- a/pkgs/by-name/qu/QuadProgpp/package.nix +++ b/pkgs/by-name/qu/QuadProgpp/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/qu/quadrafuzz/package.nix b/pkgs/by-name/qu/quadrafuzz/package.nix index e2156b391007e6..6b20364913a6e1 100644 --- a/pkgs/by-name/qu/quadrafuzz/package.nix +++ b/pkgs/by-name/qu/quadrafuzz/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, boost, cairo, lv2, pkg-config }: +{ + stdenv, + lib, + fetchFromGitHub, + boost, + cairo, + lv2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "quadrafuzz"; @@ -19,7 +27,9 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - boost cairo lv2 + boost + cairo + lv2 ]; makeFlags = [ diff --git a/pkgs/by-name/qu/quake3e/package.nix b/pkgs/by-name/qu/quake3e/package.nix index 8bf6ed19ab0f08..d4d18a33b833e8 100644 --- a/pkgs/by-name/qu/quake3e/package.nix +++ b/pkgs/by-name/qu/quake3e/package.nix @@ -1,24 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, curl -, libGL -, libX11 -, libXxf86dga -, alsa-lib -, libXrandr -, libXxf86vm -, libXext -, SDL2 -, glibc -, copyDesktopItems -, makeDesktopItem +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + curl, + libGL, + libX11, + libXxf86dga, + alsa-lib, + libXrandr, + libXxf86vm, + libXext, + SDL2, + glibc, + copyDesktopItems, + makeDesktopItem, }: let - arch = - /**/ if stdenv.hostPlatform.isx86_64 then "x64" - else stdenv.hostPlatform.parsed.cpu.name; + arch = if stdenv.hostPlatform.isx86_64 then "x64" else stdenv.hostPlatform.parsed.cpu.name; in stdenv.mkDerivation rec { pname = "Quake3e"; @@ -31,8 +30,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-tQgrHiP+QhBzcUnHRwzaDe38Th0uDt450fra8O3Vjqc="; }; - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; - buildInputs = [ curl libGL libX11 libXxf86dga alsa-lib libXrandr libXxf86vm libXext SDL2 glibc ]; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; + buildInputs = [ + curl + libGL + libX11 + libXxf86dga + alsa-lib + libXrandr + libXxf86vm + libXext + SDL2 + glibc + ]; env.NIX_CFLAGS_COMPILE = "-I${SDL2.dev}/include/SDL2"; enableParallelBuilding = true; @@ -75,6 +88,9 @@ stdenv.mkDerivation rec { description = "Improved Quake III Arena engine"; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ pmiddend alx ]; + maintainers = with maintainers; [ + pmiddend + alx + ]; }; } diff --git a/pkgs/by-name/qu/quantlib/package.nix b/pkgs/by-name/qu/quantlib/package.nix index aad65c6045db14..62f54b6ecbceec 100644 --- a/pkgs/by-name/qu/quantlib/package.nix +++ b/pkgs/by-name/qu/quantlib/package.nix @@ -1,15 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, boost186 # (boost181) breaks on darwin +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost186, # (boost181) breaks on darwin }: stdenv.mkDerivation (finalAttrs: { pname = "quantlib"; version = "1.36"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "lballabio"; diff --git a/pkgs/by-name/qu/quantomatic/package.nix b/pkgs/by-name/qu/quantomatic/package.nix index 05011313bccea8..2f531c5e0e8d17 100644 --- a/pkgs/by-name/qu/quantomatic/package.nix +++ b/pkgs/by-name/qu/quantomatic/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "quantomatic"; diff --git a/pkgs/by-name/qu/quantumminigolf/package.nix b/pkgs/by-name/qu/quantumminigolf/package.nix index b7e8feae242864..1a1674d4620692 100644 --- a/pkgs/by-name/qu/quantumminigolf/package.nix +++ b/pkgs/by-name/qu/quantumminigolf/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fftwSinglePrec, freetype, SDL, SDL_ttf }: +{ + lib, + stdenv, + fetchurl, + fftwSinglePrec, + freetype, + SDL, + SDL_ttf, +}: stdenv.mkDerivation rec { pname = "quantumminigolf"; diff --git a/pkgs/by-name/qu/quark-engine/package.nix b/pkgs/by-name/qu/quark-engine/package.nix index a5651b71c1cdb1..4227a63032c402 100644 --- a/pkgs/by-name/qu/quark-engine/package.nix +++ b/pkgs/by-name/qu/quark-engine/package.nix @@ -19,7 +19,6 @@ python3.pkgs.buildPythonApplication rec { build-system = with python3.pkgs; [ setuptools ]; - dependencies = with python3.pkgs; [ androguard click diff --git a/pkgs/by-name/qu/quark/package.nix b/pkgs/by-name/qu/quark/package.nix index e178fe91a34aff..0bed342181817d 100644 --- a/pkgs/by-name/qu/quark/package.nix +++ b/pkgs/by-name/qu/quark/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchgit, patches ? null }: +{ + lib, + stdenv, + fetchgit, + patches ? null, +}: stdenv.mkDerivation { pname = "quark"; diff --git a/pkgs/by-name/qu/quarkus/package.nix b/pkgs/by-name/qu/quarkus/package.nix index a8f0bddb4bce72..da50bae84d0812 100644 --- a/pkgs/by-name/qu/quarkus/package.nix +++ b/pkgs/by-name/qu/quarkus/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, jdk +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jdk, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/qu/quartus-prime-lite/package.nix b/pkgs/by-name/qu/quartus-prime-lite/package.nix index a5d39818639ebd..75ddc5450147c4 100644 --- a/pkgs/by-name/qu/quartus-prime-lite/package.nix +++ b/pkgs/by-name/qu/quartus-prime-lite/package.nix @@ -1,9 +1,25 @@ -{ lib, buildFHSEnv, callPackage, makeDesktopItem, runtimeShell -, runCommand, unstick, quartus-prime-lite, libfaketime, pkgsi686Linux -, withQuesta ? true -, supportedDevices ? [ "Arria II" "Cyclone V" "Cyclone IV" "Cyclone 10 LP" "MAX II/V" "MAX 10 FPGA" ] -, unwrapped ? callPackage ./quartus.nix { inherit unstick supportedDevices withQuesta; } -, extraProfile ? "" +{ + lib, + buildFHSEnv, + callPackage, + makeDesktopItem, + runtimeShell, + runCommand, + unstick, + quartus-prime-lite, + libfaketime, + pkgsi686Linux, + withQuesta ? true, + supportedDevices ? [ + "Arria II" + "Cyclone V" + "Cyclone IV" + "Cyclone 10 LP" + "MAX II/V" + "MAX 10 FPGA" + ], + unwrapped ? callPackage ./quartus.nix { inherit unstick supportedDevices withQuesta; }, + extraProfile ? "", }: let @@ -15,59 +31,68 @@ let genericName = "Quartus Prime"; categories = [ "Development" ]; }; +in # I think questa_fse/linux/vlm checksums itself, so use FHSUserEnv instead of `patchelf` -in buildFHSEnv rec { +buildFHSEnv rec { pname = "quartus-prime-lite"; # wrapped inherit (unwrapped) version; - targetPkgs = pkgs: with pkgs; [ - (runCommand "ld-lsb-compat" {} ('' - mkdir -p "$out/lib" - ln -sr "${glibc}/lib/ld-linux-x86-64.so.2" "$out/lib/ld-lsb-x86-64.so.3" - '' + lib.optionalString withQuesta '' - ln -sr "${pkgsi686Linux.glibc}/lib/ld-linux.so.2" "$out/lib/ld-lsb.so.3" - '')) - # quartus requirements - glib - xorg.libICE - xorg.libSM - xorg.libXau - xorg.libXdmcp - libudev0-shim - bzip2 - brotli - expat - dbus - # qsys requirements - xorg.libXtst - xorg.libXi - dejavu_fonts - gnumake - ]; + targetPkgs = + pkgs: with pkgs; [ + (runCommand "ld-lsb-compat" { } ( + '' + mkdir -p "$out/lib" + ln -sr "${glibc}/lib/ld-linux-x86-64.so.2" "$out/lib/ld-lsb-x86-64.so.3" + '' + + lib.optionalString withQuesta '' + ln -sr "${pkgsi686Linux.glibc}/lib/ld-linux.so.2" "$out/lib/ld-lsb.so.3" + '' + )) + # quartus requirements + glib + xorg.libICE + xorg.libSM + xorg.libXau + xorg.libXdmcp + libudev0-shim + bzip2 + brotli + expat + dbus + # qsys requirements + xorg.libXtst + xorg.libXi + dejavu_fonts + gnumake + ]; # Also support 32-bit executables used by simulator. multiArch = withQuesta; # these libs are installed as 64 bit, plus as 32 bit when multiArch is true - multiPkgs = pkgs: with pkgs; let - # This seems ugly - can we override `libpng = libpng12` for all `pkgs`? - freetype = pkgs.freetype.override { libpng = libpng12; }; - fontconfig = pkgs.fontconfig.override { inherit freetype; }; - libXft = pkgs.xorg.libXft.override { inherit freetype fontconfig; }; - in [ - # questa requirements - libxml2 - ncurses5 - unixODBC - libXft - # common requirements - freetype - fontconfig - xorg.libX11 - xorg.libXext - xorg.libXrender - libxcrypt-legacy - ]; + multiPkgs = + pkgs: + with pkgs; + let + # This seems ugly - can we override `libpng = libpng12` for all `pkgs`? + freetype = pkgs.freetype.override { libpng = libpng12; }; + fontconfig = pkgs.fontconfig.override { inherit freetype; }; + libXft = pkgs.xorg.libXft.override { inherit freetype fontconfig; }; + in + [ + # questa requirements + libxml2 + ncurses5 + unixODBC + libXft + # common requirements + freetype + fontconfig + xorg.libX11 + xorg.libXext + xorg.libXrender + libxcrypt-legacy + ]; extraInstallCommands = '' mkdir -p $out/share/applications $out/share/icons/hicolor/64x64/apps @@ -116,31 +141,38 @@ in buildFHSEnv rec { ln --symbolic --relative --target-directory ./bin ''${progs_wrapped[@]} ''; - profile = '' - # LD_PRELOAD fixes issues in the licensing system that cause memory corruption and crashes when - # starting most operations in many containerized environments, including WSL2, Docker, and LXC - # (a similiar fix involving LD_PRELOADing tcmalloc did not solve the issue in my situation) - # https://community.intel.com/t5/Intel-FPGA-Software-Installation/Running-Quartus-Prime-Standard-on-WSL-crashes-in-libudev-so/m-p/1189032 - # - # But, as can be seen in the above resource, LD_PRELOADing libudev breaks - # compiling encrypted device libraries in Questa (with error - # `(vlog-2163) Macro ` is undefined.`), so only use LD_PRELOAD - # for non-Questa wrappers. - if [ "$NIXPKGS_IS_QUESTA_WRAPPER" != 1 ]; then - export LD_PRELOAD=''${LD_PRELOAD:+$LD_PRELOAD:}/usr/lib/libudev.so.0 - fi - - # Implement the SOURCE_DATE_EPOCH specification for reproducible builds - # (https://reproducible-builds.org/specs/source-date-epoch). - # Require opt-in with NIXPKGS_QUARTUS_REPRODUCIBLE_BUILD=1 for now, in case - # the blocklist is incomplete. - if [ -n "$SOURCE_DATE_EPOCH" ] && [ "$NIXPKGS_QUARTUS_REPRODUCIBLE_BUILD" = 1 ] && [ "$NIXPKGS_QUARTUS_THIS_PROG_SUPPORTS_FIXED_CLOCK" = 1 ]; then - export LD_LIBRARY_PATH="${lib.makeLibraryPath [ libfaketime pkgsi686Linux.libfaketime ]}''${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}" - export LD_PRELOAD=libfaketime.so.1''${LD_PRELOAD:+:$LD_PRELOAD} - export FAKETIME_FMT="%s" - export FAKETIME="$SOURCE_DATE_EPOCH" - fi - '' + extraProfile; + profile = + '' + # LD_PRELOAD fixes issues in the licensing system that cause memory corruption and crashes when + # starting most operations in many containerized environments, including WSL2, Docker, and LXC + # (a similiar fix involving LD_PRELOADing tcmalloc did not solve the issue in my situation) + # https://community.intel.com/t5/Intel-FPGA-Software-Installation/Running-Quartus-Prime-Standard-on-WSL-crashes-in-libudev-so/m-p/1189032 + # + # But, as can be seen in the above resource, LD_PRELOADing libudev breaks + # compiling encrypted device libraries in Questa (with error + # `(vlog-2163) Macro ` is undefined.`), so only use LD_PRELOAD + # for non-Questa wrappers. + if [ "$NIXPKGS_IS_QUESTA_WRAPPER" != 1 ]; then + export LD_PRELOAD=''${LD_PRELOAD:+$LD_PRELOAD:}/usr/lib/libudev.so.0 + fi + + # Implement the SOURCE_DATE_EPOCH specification for reproducible builds + # (https://reproducible-builds.org/specs/source-date-epoch). + # Require opt-in with NIXPKGS_QUARTUS_REPRODUCIBLE_BUILD=1 for now, in case + # the blocklist is incomplete. + if [ -n "$SOURCE_DATE_EPOCH" ] && [ "$NIXPKGS_QUARTUS_REPRODUCIBLE_BUILD" = 1 ] && [ "$NIXPKGS_QUARTUS_THIS_PROG_SUPPORTS_FIXED_CLOCK" = 1 ]; then + export LD_LIBRARY_PATH="${ + lib.makeLibraryPath [ + libfaketime + pkgsi686Linux.libfaketime + ] + }''${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}" + export LD_PRELOAD=libfaketime.so.1''${LD_PRELOAD:+:$LD_PRELOAD} + export FAKETIME_FMT="%s" + export FAKETIME="$SOURCE_DATE_EPOCH" + fi + '' + + extraProfile; # Run the wrappers directly, instead of going via bash. runScript = ""; @@ -148,40 +180,44 @@ in buildFHSEnv rec { passthru = { inherit unwrapped; tests = { - buildSof = runCommand "quartus-prime-lite-test-build-sof" - { nativeBuildInputs = [ quartus-prime-lite ]; - env.NIXPKGS_QUARTUS_REPRODUCIBLE_BUILD = "1"; - } - '' - cat >mydesign.vhd <&2 - exit 1 - fi - - sha1sum mydesign.sof > "$out" - ''; - questaEncryptedModel = runCommand "quartus-prime-lite-test-questa-encrypted-model" - { env.NIXPKGS_QUARTUS_REPRODUCIBLE_BUILD = "1"; + buildSof = + runCommand "quartus-prime-lite-test-build-sof" + { + nativeBuildInputs = [ quartus-prime-lite ]; + env.NIXPKGS_QUARTUS_REPRODUCIBLE_BUILD = "1"; + } + '' + cat >mydesign.vhd <&2 + exit 1 + fi + + sha1sum mydesign.sof > "$out" + ''; + questaEncryptedModel = + runCommand "quartus-prime-lite-test-questa-encrypted-model" + { + env.NIXPKGS_QUARTUS_REPRODUCIBLE_BUILD = "1"; } '' "${quartus-prime-lite}/bin/vlog" "${quartus-prime-lite.unwrapped}/questa_fse/intel/verilog/src/arriav_atoms_ncrypt.v" diff --git a/pkgs/by-name/qu/quartus-prime-lite/quartus.nix b/pkgs/by-name/qu/quartus-prime-lite/quartus.nix index e668fe9e43fe6c..0b301ad87d5425 100644 --- a/pkgs/by-name/qu/quartus-prime-lite/quartus.nix +++ b/pkgs/by-name/qu/quartus-prime-lite/quartus.nix @@ -1,6 +1,17 @@ -{ stdenv, lib, unstick, fetchurl -, withQuesta ? true -, supportedDevices ? [ "Arria II" "Cyclone V" "Cyclone IV" "Cyclone 10 LP" "MAX II/V" "MAX 10 FPGA" ] +{ + stdenv, + lib, + unstick, + fetchurl, + withQuesta ? true, + supportedDevices ? [ + "Arria II" + "Cyclone V" + "Cyclone IV" + "Cyclone 10 LP" + "MAX II/V" + "MAX 10 FPGA" + ], }: let @@ -14,15 +25,18 @@ let }; supportedDeviceIds = - assert lib.assertMsg (lib.all (name: lib.hasAttr name deviceIds) supportedDevices) - "Supported devices are: ${lib.concatStringsSep ", " (lib.attrNames deviceIds)}"; - lib.listToAttrs (map (name: { - inherit name; - value = deviceIds.${name}; - }) supportedDevices); + assert lib.assertMsg (lib.all ( + name: lib.hasAttr name deviceIds + ) supportedDevices) "Supported devices are: ${lib.concatStringsSep ", " (lib.attrNames deviceIds)}"; + lib.listToAttrs ( + map (name: { + inherit name; + value = deviceIds.${name}; + }) supportedDevices + ); - unsupportedDeviceIds = lib.filterAttrs (name: value: - !(lib.hasAttr name supportedDeviceIds) + unsupportedDeviceIds = lib.filterAttrs ( + name: value: !(lib.hasAttr name supportedDeviceIds) ) deviceIds; componentHashes = { @@ -36,46 +50,61 @@ let version = "23.1std.0.991"; - download = {name, sha256}: fetchurl { - inherit name sha256; - # e.g. "23.1std.0.991" -> "23.1std/921" - url = "https://downloads.intel.com/akdlm/software/acdsinst/${lib.versions.majorMinor version}std/${lib.elemAt (lib.splitVersion version) 4}/ib_installers/${name}"; - }; + download = + { name, sha256 }: + fetchurl { + inherit name sha256; + # e.g. "23.1std.0.991" -> "23.1std/921" + url = "https://downloads.intel.com/akdlm/software/acdsinst/${lib.versions.majorMinor version}std/${lib.elemAt (lib.splitVersion version) 4}/ib_installers/${name}"; + }; - installers = map download ([{ - name = "QuartusLiteSetup-${version}-linux.run"; - sha256 = "1mg4db56rg407kdsvpzys96z59bls8djyddfzxi6bdikcklxz98h"; - }] ++ lib.optional withQuesta { - name = "QuestaSetup-${version}-linux.run"; - sha256 = "0f9lyphk4vf4ijif3kb4iqf18jl357z9h8g16kwnzaqwfngh2ixk"; - }); - components = map (id: download { - name = "${id}-${version}.qdz"; - sha256 = lib.getAttr id componentHashes; - }) (lib.attrValues supportedDeviceIds); + installers = map download ( + [ + { + name = "QuartusLiteSetup-${version}-linux.run"; + sha256 = "1mg4db56rg407kdsvpzys96z59bls8djyddfzxi6bdikcklxz98h"; + } + ] + ++ lib.optional withQuesta { + name = "QuestaSetup-${version}-linux.run"; + sha256 = "0f9lyphk4vf4ijif3kb4iqf18jl357z9h8g16kwnzaqwfngh2ixk"; + } + ); + components = map ( + id: + download { + name = "${id}-${version}.qdz"; + sha256 = lib.getAttr id componentHashes; + } + ) (lib.attrValues supportedDeviceIds); -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { inherit version; pname = "quartus-prime-lite-unwrapped"; nativeBuildInputs = [ unstick ]; - buildCommand = let - copyInstaller = installer: '' + buildCommand = + let + copyInstaller = installer: '' # `$(cat $NIX_CC/nix-support/dynamic-linker) $src[0]` often segfaults, so cp + patchelf cp ${installer} $TEMP/${installer.name} chmod u+w,+x $TEMP/${installer.name} patchelf --interpreter $(cat $NIX_CC/nix-support/dynamic-linker) $TEMP/${installer.name} ''; - copyComponent = component: "cp ${component} $TEMP/${component.name}"; - # leaves enabled: quartus, devinfo - disabledComponents = [ - "quartus_help" - "quartus_update" - "questa_fe" - ] ++ (lib.optional (!withQuesta) "questa_fse") - ++ (lib.attrValues unsupportedDeviceIds); - in '' + copyComponent = component: "cp ${component} $TEMP/${component.name}"; + # leaves enabled: quartus, devinfo + disabledComponents = + [ + "quartus_help" + "quartus_update" + "questa_fe" + ] + ++ (lib.optional (!withQuesta) "questa_fse") + ++ (lib.attrValues unsupportedDeviceIds); + in + '' echo "setting up installer..." ${lib.concatMapStringsSep "\n" copyInstaller installers} ${lib.concatMapStringsSep "\n" copyComponent components} @@ -102,6 +131,9 @@ in stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ bjornfor kwohlfahrt ]; + maintainers = with maintainers; [ + bjornfor + kwohlfahrt + ]; }; } diff --git a/pkgs/by-name/qu/quast/package.nix b/pkgs/by-name/qu/quast/package.nix index e390b5d3ec6718..97ec9186e265f6 100644 --- a/pkgs/by-name/qu/quast/package.nix +++ b/pkgs/by-name/qu/quast/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, python3Packages, zlib, bash }: +{ + lib, + stdenv, + fetchurl, + python3Packages, + zlib, + bash, +}: let pythonPackages = python3Packages; @@ -14,7 +21,12 @@ pythonPackages.buildPythonApplication rec { sha256 = "13ml8qywbb4cc7wf2x7z5mz1rjqg51ab8wkizwcg4f6c40zgif6d"; }; - pythonPath = with pythonPackages; [ simplejson joblib setuptools matplotlib ]; + pythonPath = with pythonPackages; [ + simplejson + joblib + setuptools + matplotlib + ]; buildInputs = [ zlib ] ++ pythonPath; @@ -32,13 +44,13 @@ pythonPackages.buildPythonApplication rec { --prefix="$out" ''; - postFixup = '' - for file in $(find $out -type f -type f -perm /0111); do - old_rpath=$(patchelf --print-rpath $file) && \ - patchelf --set-rpath $old_rpath:${lib.getLib stdenv.cc.cc}/lib $file || true - done - # Link to the master program - ln -s $out/bin/quast.py $out/bin/quast + postFixup = '' + for file in $(find $out -type f -type f -perm /0111); do + old_rpath=$(patchelf --print-rpath $file) && \ + patchelf --set-rpath $old_rpath:${lib.getLib stdenv.cc.cc}/lib $file || true + done + # Link to the master program + ln -s $out/bin/quast.py $out/bin/quast ''; dontPatchELF = true; @@ -46,12 +58,12 @@ pythonPackages.buildPythonApplication rec { # Tests need to download data files, so manual run after packaging is needed doCheck = false; - meta = with lib ; { + meta = with lib; { description = "Evaluates genome assemblies by computing various metrics"; homepage = "https://github.com/ablab/quast"; sourceProvenance = with sourceTypes; [ fromSource - binaryNativeCode # source bundles binary dependencies + binaryNativeCode # source bundles binary dependencies ]; license = licenses.gpl2; maintainers = [ maintainers.bzizou ]; diff --git a/pkgs/by-name/qu/quattrocento-sans/package.nix b/pkgs/by-name/qu/quattrocento-sans/package.nix index ce702c1c599303..6493e7511ba872 100644 --- a/pkgs/by-name/qu/quattrocento-sans/package.nix +++ b/pkgs/by-name/qu/quattrocento-sans/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "quattrocento-sans"; diff --git a/pkgs/by-name/qu/quattrocento/package.nix b/pkgs/by-name/qu/quattrocento/package.nix index 14618cb2ef3993..7404d720736d1d 100644 --- a/pkgs/by-name/qu/quattrocento/package.nix +++ b/pkgs/by-name/qu/quattrocento/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "quattrocento"; diff --git a/pkgs/by-name/qu/qubes-core-vchan-xen/package.nix b/pkgs/by-name/qu/qubes-core-vchan-xen/package.nix index 7def14890300d0..6693bd9762b29b 100644 --- a/pkgs/by-name/qu/qubes-core-vchan-xen/package.nix +++ b/pkgs/by-name/qu/qubes-core-vchan-xen/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, xen +{ + lib, + stdenv, + fetchFromGitHub, + xen, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/qu/quesoglc/package.nix b/pkgs/by-name/qu/quesoglc/package.nix index d0b4d22b87e344..ff38dc30757a00 100644 --- a/pkgs/by-name/qu/quesoglc/package.nix +++ b/pkgs/by-name/qu/quesoglc/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, libGLU, libGL, glew, freetype, fontconfig, fribidi, libX11 }: +{ + lib, + stdenv, + fetchurl, + libGLU, + libGL, + glew, + freetype, + fontconfig, + fribidi, + libX11, +}: stdenv.mkDerivation rec { pname = "quesoglc"; version = "0.7.2"; @@ -6,7 +17,15 @@ stdenv.mkDerivation rec { url = "mirror://sourceforge/${pname}/${pname}-${version}.tar.bz2"; sha256 = "0cf9ljdzii5d4i2m23gdmf3kn521ljcldzq69lsdywjid3pg5zjl"; }; - buildInputs = [ libGLU libGL glew freetype fontconfig fribidi libX11 ]; + buildInputs = [ + libGLU + libGL + glew + freetype + fontconfig + fribidi + libX11 + ]; # FIXME: Configure fails to use system glew. meta = with lib; { description = "Free implementation of the OpenGL Character Renderer"; diff --git a/pkgs/by-name/qu/questdb/package.nix b/pkgs/by-name/qu/questdb/package.nix index d635c67df38221..c152ecca1516a1 100644 --- a/pkgs/by-name/qu/questdb/package.nix +++ b/pkgs/by-name/qu/questdb/package.nix @@ -3,7 +3,7 @@ jdk17_headless, lib, makeBinaryWrapper, - stdenv + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/qu/quich/package.nix b/pkgs/by-name/qu/quich/package.nix index cc7131678a5528..1af37a17715cdf 100644 --- a/pkgs/by-name/qu/quich/package.nix +++ b/pkgs/by-name/qu/quich/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "quich"; @@ -13,7 +17,11 @@ stdenv.mkDerivation rec { doCheck = true; - makeFlags = [ "DESTDIR=" "PREFIX=$(out)" "CC=${stdenv.cc.targetPrefix}cc" ]; + makeFlags = [ + "DESTDIR=" + "PREFIX=$(out)" + "CC=${stdenv.cc.targetPrefix}cc" + ]; meta = with lib; { description = "Advanced terminal calculator"; diff --git a/pkgs/by-name/qu/quick-lint-js/package.nix b/pkgs/by-name/qu/quick-lint-js/package.nix index 86b76bf99c071d..028a40cc96a836 100644 --- a/pkgs/by-name/qu/quick-lint-js/package.nix +++ b/pkgs/by-name/qu/quick-lint-js/package.nix @@ -1,4 +1,13 @@ -{ buildPackages, cmake, fetchFromGitHub, lib, ninja, stdenv, testers, quick-lint-js }: +{ + buildPackages, + cmake, + fetchFromGitHub, + lib, + ninja, + stdenv, + testers, + quick-lint-js, +}: let version = "3.2.0"; @@ -14,7 +23,10 @@ let pname = "quick-lint-js-build-tools"; inherit version src; - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; doCheck = false; cmakeFlags = [ @@ -35,7 +47,10 @@ stdenv.mkDerivation rec { pname = "quick-lint-js"; inherit version src; - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; doCheck = true; cmakeFlags = [ diff --git a/pkgs/by-name/qu/quickgui/package.nix b/pkgs/by-name/qu/quickgui/package.nix index e60d7949ec3a6f..3bd968a1cb12a7 100644 --- a/pkgs/by-name/qu/quickgui/package.nix +++ b/pkgs/by-name/qu/quickgui/package.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, makeDesktopItem -, copyDesktopItems -, lib -, flutter -, quickemu -, zenity +{ + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + lib, + flutter, + quickemu, + zenity, }: flutter.buildFlutterApplication rec { pname = "quickgui"; @@ -22,7 +23,12 @@ flutter.buildFlutterApplication rec { window_size = "sha256-XelNtp7tpZ91QCEcvewVphNUtgQX7xrp5QP0oFo6DgM="; }; - extraWrapProgramArgs = "--prefix PATH : ${lib.makeBinPath [ quickemu zenity ]}"; + extraWrapProgramArgs = "--prefix PATH : ${ + lib.makeBinPath [ + quickemu + zenity + ] + }"; nativeBuildInputs = [ copyDesktopItems ]; @@ -40,7 +46,10 @@ flutter.buildFlutterApplication rec { icon = "quickgui"; desktopName = "Quickgui"; comment = "An elegant virtual machine manager for the desktop"; - categories = [ "Development" "System" ]; + categories = [ + "Development" + "System" + ]; }) ]; @@ -49,7 +58,10 @@ flutter.buildFlutterApplication rec { homepage = "https://github.com/quickemu-project/quickgui"; changelog = "https://github.com/quickemu-project/quickgui/releases/"; license = licenses.mit; - maintainers = with maintainers; [ flexiondotorg heyimnova ]; + maintainers = with maintainers; [ + flexiondotorg + heyimnova + ]; platforms = [ "x86_64-linux" ]; mainProgram = "quickgui"; }; diff --git a/pkgs/by-name/qu/quickjs/package.nix b/pkgs/by-name/qu/quickjs/package.nix index c22e3e5b6c58d1..8eba3c47e00230 100644 --- a/pkgs/by-name/qu/quickjs/package.nix +++ b/pkgs/by-name/qu/quickjs/package.nix @@ -89,34 +89,34 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://bellard.org/quickjs/"; description = "Small and embeddable Javascript engine"; longDescription = '' - QuickJS is a small and embeddable Javascript engine. It supports the - ES2023 specification including modules, asynchronous generators, proxies - and BigInt. - - It optionally supports mathematical extensions such as big decimal - floating point numbers (BigDecimal), big binary floating point numbers - (BigFloat) and operator overloading. - - Main Features: - - - Small and easily embeddable: just a few C files, no external - dependency, 210 KiB of x86 code for a simple hello world program. - - Fast interpreter with very low startup time: runs the 76000 tests of - the ECMAScript Test Suite in less than 2 minutes on a single core of a - desktop PC. The complete life cycle of a runtime instance completes in - less than 300 microseconds. - - Almost complete ES2023 support including modules, asynchronous - generators and full Annex B support (legacy web compatibility). - - Passes nearly 100% of the ECMAScript Test Suite tests when selecting - the ES2023 features. A summary is available at Test262 Report. - - Can compile Javascript sources to executables with no external dependency. - - Garbage collection using reference counting (to reduce memory usage and - have deterministic behavior) with cycle removal. - - Mathematical extensions: BigDecimal, BigFloat, operator overloading, - bigint mode, math mode. - - Command line interpreter with contextual colorization implemented in - Javascript. - - Small built-in standard library with C library wrappers. + QuickJS is a small and embeddable Javascript engine. It supports the + ES2023 specification including modules, asynchronous generators, proxies + and BigInt. + + It optionally supports mathematical extensions such as big decimal + floating point numbers (BigDecimal), big binary floating point numbers + (BigFloat) and operator overloading. + + Main Features: + + - Small and easily embeddable: just a few C files, no external + dependency, 210 KiB of x86 code for a simple hello world program. + - Fast interpreter with very low startup time: runs the 76000 tests of + the ECMAScript Test Suite in less than 2 minutes on a single core of a + desktop PC. The complete life cycle of a runtime instance completes in + less than 300 microseconds. + - Almost complete ES2023 support including modules, asynchronous + generators and full Annex B support (legacy web compatibility). + - Passes nearly 100% of the ECMAScript Test Suite tests when selecting + the ES2023 features. A summary is available at Test262 Report. + - Can compile Javascript sources to executables with no external dependency. + - Garbage collection using reference counting (to reduce memory usage and + have deterministic behavior) with cycle removal. + - Mathematical extensions: BigDecimal, BigFloat, operator overloading, + bigint mode, math mode. + - Command line interpreter with contextual colorization implemented in + Javascript. + - Small built-in standard library with C library wrappers. ''; license = lib.licenses.mit; diff --git a/pkgs/by-name/qu/quickmem/package.nix b/pkgs/by-name/qu/quickmem/package.nix index 91b170030aaf9e..54ada1f9aff3b5 100644 --- a/pkgs/by-name/qu/quickmem/package.nix +++ b/pkgs/by-name/qu/quickmem/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitLab -, cmake -, doxygen -, graphviz -, arpa2common -, arpa2cm +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + doxygen, + graphviz, + arpa2common, + arpa2cm, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/qu/quicksand/package.nix b/pkgs/by-name/qu/quicksand/package.nix index e4fc1c2d5e0167..106f0bf90550f0 100644 --- a/pkgs/by-name/qu/quicksand/package.nix +++ b/pkgs/by-name/qu/quicksand/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "quicksand"; @@ -9,7 +13,7 @@ stdenvNoCC.mkDerivation { repo = "QuicksandFamily"; rev = "be4b9d638e1c79fa42d4a0ab0aa7fe29466419c7"; hash = "sha256-zkxm2u35Ll2qyCoUeuA0eumVjNSel+y1kkWoHxeNI/g="; - sparseCheckout = ["fonts"]; + sparseCheckout = [ "fonts" ]; }; installPhase = '' diff --git a/pkgs/by-name/qu/quickserve/package.nix b/pkgs/by-name/qu/quickserve/package.nix index b5a760617974f9..8c4535b16c84d6 100644 --- a/pkgs/by-name/qu/quickserve/package.nix +++ b/pkgs/by-name/qu/quickserve/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, makeWrapper, fetchzip, python3, python3Packages }: +{ + lib, + stdenv, + makeWrapper, + fetchzip, + python3, + python3Packages, +}: let threaded_servers = python3Packages.buildPythonPackage { name = "threaded_servers"; @@ -11,7 +18,8 @@ let doCheck = false; }; wrappedPython = python3.withPackages (_: [ threaded_servers ]); -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "quickserve"; version = "2018"; diff --git a/pkgs/by-name/qu/quicksynergy/package.nix b/pkgs/by-name/qu/quicksynergy/package.nix index 5a93f647291d2b..bb69683e685852 100644 --- a/pkgs/by-name/qu/quicksynergy/package.nix +++ b/pkgs/by-name/qu/quicksynergy/package.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchurl, pkg-config, gtk2, synergy}: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + synergy, +}: stdenv.mkDerivation rec { pname = "quicksynergy"; diff --git a/pkgs/by-name/qu/quicktemplate/package.nix b/pkgs/by-name/qu/quicktemplate/package.nix index a339c8e2896186..37e6b1e92ecf03 100644 --- a/pkgs/by-name/qu/quicktemplate/package.nix +++ b/pkgs/by-name/qu/quicktemplate/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "quicktemplate"; diff --git a/pkgs/by-name/qu/quicktun/package.nix b/pkgs/by-name/qu/quicktun/package.nix index 2dcb9b21b623aa..ca215dfff275ff 100644 --- a/pkgs/by-name/qu/quicktun/package.nix +++ b/pkgs/by-name/qu/quicktun/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, libsodium, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + libsodium, + nixosTests, +}: stdenv.mkDerivation { pname = "quicktun"; diff --git a/pkgs/by-name/qu/quicktype/package.nix b/pkgs/by-name/qu/quicktype/package.nix index ecf33e6e92a57b..1bbf69aa63b6cd 100644 --- a/pkgs/by-name/qu/quicktype/package.nix +++ b/pkgs/by-name/qu/quicktype/package.nix @@ -1,4 +1,11 @@ -{ lib, buildNpmPackage, fetchFromGitHub, jq, quicktype, testers }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, + jq, + quicktype, + testers, +}: buildNpmPackage rec { pname = "quicktype"; diff --git a/pkgs/by-name/qu/quill-qr/package.nix b/pkgs/by-name/qu/quill-qr/package.nix index 826f2e51799ca1..ec31feb4b01338 100644 --- a/pkgs/by-name/qu/quill-qr/package.nix +++ b/pkgs/by-name/qu/quill-qr/package.nix @@ -1,11 +1,12 @@ -{ coreutils -, fetchFromGitHub -, gzip -, jq -, lib -, makeWrapper -, qrencode -, stdenvNoCC +{ + coreutils, + fetchFromGitHub, + gzip, + jq, + lib, + makeWrapper, + qrencode, + stdenvNoCC, }: stdenvNoCC.mkDerivation rec { @@ -28,12 +29,14 @@ stdenvNoCC.mkDerivation rec { cp -a quill-qr.sh $out/bin/quill-qr.sh patchShebangs $out/bin - wrapProgram $out/bin/quill-qr.sh --prefix PATH : "${lib.makeBinPath [ - qrencode - coreutils - jq - gzip - ]}" + wrapProgram $out/bin/quill-qr.sh --prefix PATH : "${ + lib.makeBinPath [ + qrencode + coreutils + jq + gzip + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/qu/quilt/package.nix b/pkgs/by-name/qu/quilt/package.nix index 477b4d14bb452d..5f2e634e927f1d 100644 --- a/pkgs/by-name/qu/quilt/package.nix +++ b/pkgs/by-name/qu/quilt/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, bash -, coreutils -, diffstat -, diffutils -, findutils -, gawk -, gnugrep -, gnused -, patch -, perl -, unixtools +{ + lib, + stdenv, + fetchurl, + makeWrapper, + bash, + coreutils, + diffstat, + diffutils, + findutils, + gawk, + gnugrep, + gnused, + patch, + perl, + unixtools, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/qu/quintom-cursor-theme/package.nix b/pkgs/by-name/qu/quintom-cursor-theme/package.nix index 3267d619b7a5e2..037cbc74988855 100644 --- a/pkgs/by-name/qu/quintom-cursor-theme/package.nix +++ b/pkgs/by-name/qu/quintom-cursor-theme/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, fetchFromGitLab, lib }: +{ + stdenvNoCC, + fetchFromGitLab, + lib, +}: stdenvNoCC.mkDerivation { pname = "quintom-cursor-theme"; @@ -22,7 +26,10 @@ stdenvNoCC.mkDerivation { description = "Cursor theme designed to look decent"; homepage = "https://gitlab.com/Burning_Cube/quintom-cursor-theme"; platforms = platforms.unix; - license = with licenses; [ cc-by-sa-40 gpl3Only ]; + license = with licenses; [ + cc-by-sa-40 + gpl3Only + ]; maintainers = with maintainers; [ frogamic ]; }; } diff --git a/pkgs/by-name/qu/quinze/package.nix b/pkgs/by-name/qu/quinze/package.nix index dd029db212370a..1f6edf2404a723 100644 --- a/pkgs/by-name/qu/quinze/package.nix +++ b/pkgs/by-name/qu/quinze/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { name = "quinze"; diff --git a/pkgs/by-name/qu/quirc/package.nix b/pkgs/by-name/qu/quirc/package.nix index 43144ce037b0e8..d85f3d3473d3ec 100644 --- a/pkgs/by-name/qu/quirc/package.nix +++ b/pkgs/by-name/qu/quirc/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch2, SDL_gfx, SDL, libjpeg, libpng -, opencv, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch2, + SDL_gfx, + SDL, + libjpeg, + libpng, + opencv, + pkg-config, +}: stdenv.mkDerivation (finalAttrs: { pname = "quirc"; @@ -20,24 +30,32 @@ stdenv.mkDerivation (finalAttrs: { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ SDL SDL_gfx libjpeg libpng opencv ]; + buildInputs = [ + SDL + SDL_gfx + libjpeg + libpng + opencv + ]; makeFlags = [ "PREFIX=$(out)" ]; env.NIX_CFLAGS_COMPILE = "-I${lib.getDev SDL}/include/SDL -I${SDL_gfx}/include/SDL"; - patches = [ - (fetchpatch2 { - url = "https://github.com/dlbeer/quirc/commit/2c350d8aaf37246e538a2c93b2cce8c78600d2fc.patch?full_index=1"; - hash = "sha256-ZTcy/EoOBoyOjtXjmT+J/JcbX8lxGKmbWer23lymbWo="; - }) - (fetchpatch2 { - url = "https://github.com/dlbeer/quirc/commit/257c6c94d99960819ecabf72199e5822f60a3bc5.patch?full_index=1"; - hash = "sha256-WLQK7vy34VmgJzppTnRjAcZoSGWVaXQSaGq9An8W0rw="; - }) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # Disable building of linux-only demos on darwin systems - ./0001-Don-t-build-demos.patch - ]; + patches = + [ + (fetchpatch2 { + url = "https://github.com/dlbeer/quirc/commit/2c350d8aaf37246e538a2c93b2cce8c78600d2fc.patch?full_index=1"; + hash = "sha256-ZTcy/EoOBoyOjtXjmT+J/JcbX8lxGKmbWer23lymbWo="; + }) + (fetchpatch2 { + url = "https://github.com/dlbeer/quirc/commit/257c6c94d99960819ecabf72199e5822f60a3bc5.patch?full_index=1"; + hash = "sha256-WLQK7vy34VmgJzppTnRjAcZoSGWVaXQSaGq9An8W0rw="; + }) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # Disable building of linux-only demos on darwin systems + ./0001-Don-t-build-demos.patch + ]; preInstall = '' mkdir -p "$out"/{bin,lib,include} @@ -47,19 +65,24 @@ stdenv.mkDerivation (finalAttrs: { | xargs cp -t "$out"/bin ''; - postInstall = '' - # don't install static library - rm $out/lib/libquirc.a - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Set absolute install name to avoid the need for DYLD_LIBRARY_PATH - dylib=$out/lib/libquirc.${finalAttrs.version}.dylib - ${stdenv.cc.targetPrefix}install_name_tool -id "$dylib" "$dylib" - ''; + postInstall = + '' + # don't install static library + rm $out/lib/libquirc.a + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Set absolute install name to avoid the need for DYLD_LIBRARY_PATH + dylib=$out/lib/libquirc.${finalAttrs.version}.dylib + ${stdenv.cc.targetPrefix}install_name_tool -id "$dylib" "$dylib" + ''; meta = { description = "Small QR code decoding library"; license = lib.licenses.isc; maintainers = [ lib.maintainers.raskin ]; - platforms = lib.platforms.linux ++ [ "x86_64-darwin" "aarch64-darwin" ]; + platforms = lib.platforms.linux ++ [ + "x86_64-darwin" + "aarch64-darwin" + ]; }; }) diff --git a/pkgs/by-name/qu/quivira/package.nix b/pkgs/by-name/qu/quivira/package.nix index db01e2b7d15084..0649c5972fa525 100644 --- a/pkgs/by-name/qu/quivira/package.nix +++ b/pkgs/by-name/qu/quivira/package.nix @@ -2,7 +2,8 @@ let pname = "quivira"; version = "4.1"; -in fetchurl { +in +fetchurl { name = "${pname}-${version}"; url = "http://www.quivira-font.com/files/Quivira.otf"; diff --git a/pkgs/by-name/qu/quorum/package.nix b/pkgs/by-name/qu/quorum/package.nix index ca323bba3a7bb3..5d7d48744084be 100644 --- a/pkgs/by-name/qu/quorum/package.nix +++ b/pkgs/by-name/qu/quorum/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, nixosTests }: +{ + lib, + fetchFromGitHub, + buildGoModule, + nixosTests, +}: buildGoModule rec { pname = "quorum"; @@ -18,7 +23,10 @@ buildGoModule rec { "cmd/bootnode" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests = { inherit (nixosTests) quorum; }; diff --git a/pkgs/by-name/r0/r0vm/package.nix b/pkgs/by-name/r0/r0vm/package.nix index e47a41260b60f5..0e2b23d719dc3d 100644 --- a/pkgs/by-name/r0/r0vm/package.nix +++ b/pkgs/by-name/r0/r0vm/package.nix @@ -1,12 +1,13 @@ -{ rustPlatform -, stdenv -, fetchFromGitHub -, fetchurl -, pkg-config -, perl -, openssl -, lib -, darwin +{ + rustPlatform, + stdenv, + fetchFromGitHub, + fetchurl, + pkg-config, + perl, + openssl, + lib, + darwin, }: rustPlatform.buildRustPackage rec { pname = "r0vm"; @@ -25,11 +26,13 @@ rustPlatform.buildRustPackage rec { perl ]; - buildInputs = [ - openssl.dev - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl.dev + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; doCheck = false; diff --git a/pkgs/by-name/r1/r10k/gemset.nix b/pkgs/by-name/r1/r10k/gemset.nix index dc0e87c20aea30..47ddb6a768ba68 100644 --- a/pkgs/by-name/r1/r10k/gemset.nix +++ b/pkgs/by-name/r1/r10k/gemset.nix @@ -1,270 +1,300 @@ { base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; colored2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jlbqa9q4mvrm73aw9mxh23ygzbjiqwisl32d8szfb5fxvbjng5i"; type = "gem"; }; version = "3.1.2"; }; cri = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rank6i9p2drwdcmhan6ifkzrz1v3mwpx47fwjl75rskxwjfkgwa"; type = "gem"; }; version = "2.15.12"; }; erubi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qnd6ff4az22ysnmni3730c41b979xinilahzg86bn7gv93ip9pw"; type = "gem"; }; version = "1.13.0"; }; faraday = { - dependencies = ["faraday-net_http" "logger"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "faraday-net_http" + "logger" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "104s7n9505488p923cs0pl3jlgn4naam28clkm2885hrysizpjbb"; type = "gem"; }; version = "2.10.1"; }; faraday-follow_redirects = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1y87p3yk15bjbk0z9mf01r50lzxvp7agr56lbm9gxiz26mb9fbfr"; type = "gem"; }; version = "0.3.0"; }; faraday-net_http = { - dependencies = ["net-http"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-http" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f49frpfdr8czwm2mjkfny4pini6fy49b6hamw4jrppl4vsg14ys"; type = "gem"; }; version = "3.1.1"; }; fast_gettext = { - dependencies = ["prime"]; - groups = ["default"]; - platforms = []; + dependencies = [ "prime" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gsz2ywvnms7b4w7bs4dg7cykhgx7z74fa7xy0sbw45a0v2c89px"; type = "gem"; }; version = "2.4.0"; }; forwardable = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1b5g1i3xdvmxxpq4qp0z4v78ivqnazz26w110fh4cvzsdayz8zgi"; type = "gem"; }; version = "1.3.3"; }; gettext = { - dependencies = ["erubi" "locale" "prime" "racc" "text"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "erubi" + "locale" + "prime" + "racc" + "text" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16h0kda5z4s4zqygyk0f52xzs9mlz9r4lnhjwk729hhmdbz68a19"; type = "gem"; }; version = "3.4.9"; }; gettext-setup = { - dependencies = ["fast_gettext" "gettext" "locale"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "fast_gettext" + "gettext" + "locale" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1v6liz934gmx1wv1z6bvpim6aanbr66xjhb90lc9z1jxayczmm1a"; type = "gem"; }; version = "1.1.0"; }; jwt = { - dependencies = ["base64"]; - groups = ["default"]; - platforms = []; + dependencies = [ "base64" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04mw326i9vsdcqwm4bf0zvnqw237f8l7022nhlbmak92bqqpg62s"; type = "gem"; }; version = "2.8.2"; }; locale = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "107pm4ccmla23z963kyjldgngfigvchnv85wr6m69viyxxrrjbsj"; type = "gem"; }; version = "2.1.4"; }; log4r = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ri90q0frfmigkirqv5ihyrj59xm8pq5zcmf156cbdv4r4l2jicv"; type = "gem"; }; version = "1.1.10"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gpg8gzi0xwymw4aaq2iafcbx31i3xzkg3fb30mdxn1d4qhc3dqa"; type = "gem"; }; version = "1.6.0"; }; minitar = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f307mpj4j0gp7iq77xj4p149f4krcvbll9rismng3jcijpbn79s"; type = "gem"; }; version = "0.12.1"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; net-http = { - dependencies = ["uri"]; - groups = ["default"]; - platforms = []; + dependencies = [ "uri" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10n2n9aq00ih8v881af88l1zyrqgs5cl3njdw8argjwbl5ggqvm9"; type = "gem"; }; version = "0.4.1"; }; prime = { - dependencies = ["forwardable" "singleton"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "forwardable" + "singleton" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1973kz8lbck6ga5v42f55jk8b8pnbgwp9p67dl1xw15gvz55dsfl"; type = "gem"; }; version = "0.1.2"; }; puppet_forge = { - dependencies = ["faraday" "faraday-follow_redirects" "minitar" "semantic_puppet"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "faraday" + "faraday-follow_redirects" + "minitar" + "semantic_puppet" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0d65zri1nmpph8iki5iigdzfqd6rfyc1mlgdfhg69q3566rcff06"; type = "gem"; }; version = "5.0.4"; }; r10k = { - dependencies = ["colored2" "cri" "gettext-setup" "jwt" "log4r" "minitar" "multi_json" "puppet_forge"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "colored2" + "cri" + "gettext-setup" + "jwt" + "log4r" + "minitar" + "multi_json" + "puppet_forge" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k3fr2f0pwyrabs12wqig31f37sqrqs8qza7jrn01d6blvhvkrb4"; type = "gem"; }; version = "4.1.0"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0byn0c9nkahsl93y9ln5bysq4j31q8xkf2ws42swighxd4lnjzsa"; type = "gem"; }; version = "1.8.1"; }; semantic_puppet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ndqm3jnpdlwkk1jwqdyyb7yw7gv6r4kmjs30g09ap8siv80ilaj"; type = "gem"; }; version = "1.1.0"; }; singleton = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qq54imvbksnckzf9hrq9bjzcdb0n8wfv6l5jc0di10n88277jx6"; type = "gem"; }; version = "0.2.0"; }; text = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x6kkmsr49y3rnrin91rv8mpc3dhrf3ql08kbccw8yffq61brfrg"; type = "gem"; }; version = "1.3.1"; }; uri = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "094gk72ckazf495qc76gk09b5i318d5l9m7bicg2wxlrjcm3qm96"; type = "gem"; }; diff --git a/pkgs/by-name/r1/r10k/package.nix b/pkgs/by-name/r1/r10k/package.nix index ab38363ab59662..864f1ea797334f 100644 --- a/pkgs/by-name/r1/r10k/package.nix +++ b/pkgs/by-name/r1/r10k/package.nix @@ -40,7 +40,12 @@ bundlerApp { description = "Puppet environment and module deployment"; homepage = "https://github.com/puppetlabs/r10k"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ zimbatm manveru nicknovitski anthonyroussel ]; + maintainers = with lib.maintainers; [ + zimbatm + manveru + nicknovitski + anthonyroussel + ]; platforms = lib.platforms.unix; mainProgram = "r10k"; }; diff --git a/pkgs/by-name/r1/r128gain/package.nix b/pkgs/by-name/r1/r128gain/package.nix index 7ff5a13b775e58..e63664594568a3 100644 --- a/pkgs/by-name/r1/r128gain/package.nix +++ b/pkgs/by-name/r1/r128gain/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, gitUpdater -, substituteAll -, ffmpeg -, python3Packages -, sox +{ + lib, + fetchFromGitHub, + gitUpdater, + substituteAll, + ffmpeg, + python3Packages, + sox, }: python3Packages.buildPythonApplication rec { @@ -25,8 +26,16 @@ python3Packages.buildPythonApplication rec { }) ]; - propagatedBuildInputs = with python3Packages; [ crcmod ffmpeg-python mutagen tqdm ]; - nativeCheckInputs = with python3Packages; [ requests sox ]; + propagatedBuildInputs = with python3Packages; [ + crcmod + ffmpeg-python + mutagen + tqdm + ]; + nativeCheckInputs = with python3Packages; [ + requests + sox + ]; # Testing downloads media files for testing, which requires the # sandbox to be disabled. diff --git a/pkgs/by-name/r2/r2modman/package.nix b/pkgs/by-name/r2/r2modman/package.nix index 71792c115b5c1e..42739aad291369 100644 --- a/pkgs/by-name/r2/r2modman/package.nix +++ b/pkgs/by-name/r2/r2modman/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, yarn -, fetchYarnDeps -, fixup-yarn-lock -, nodejs -, electron -, fetchFromGitHub -, nix-update-script -, makeWrapper -, makeDesktopItem -, copyDesktopItems +{ + lib, + stdenv, + yarn, + fetchYarnDeps, + fixup-yarn-lock, + nodejs, + electron, + fetchFromGitHub, + nix-update-script, + makeWrapper, + makeDesktopItem, + copyDesktopItems, }: stdenv.mkDerivation (finalAttrs: { @@ -99,7 +100,11 @@ stdenv.mkDerivation (finalAttrs: { desktopName = "r2modman"; comment = finalAttrs.meta.description; categories = [ "Game" ]; - keywords = [ "launcher" "mod manager" "thunderstore" ]; + keywords = [ + "launcher" + "mod manager" + "thunderstore" + ]; }) ]; @@ -111,7 +116,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/ebkr/r2modmanPlus"; license = lib.licenses.mit; mainProgram = "r2modman"; - maintainers = with lib.maintainers; [ aidalgol huantian ]; + maintainers = with lib.maintainers; [ + aidalgol + huantian + ]; inherit (electron.meta) platforms; }; }) diff --git a/pkgs/by-name/r5/r53-ddns/package.nix b/pkgs/by-name/r5/r53-ddns/package.nix index 5e83a3793b72bc..548f5c062886ad 100644 --- a/pkgs/by-name/r5/r53-ddns/package.nix +++ b/pkgs/by-name/r5/r53-ddns/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "r53-ddns"; diff --git a/pkgs/by-name/ra/ra-multiplex/package.nix b/pkgs/by-name/ra/ra-multiplex/package.nix index 6efa73f23d7bc6..0281268ad64a62 100644 --- a/pkgs/by-name/ra/ra-multiplex/package.nix +++ b/pkgs/by-name/ra/ra-multiplex/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, makeWrapper -, rustPlatform -, rust-analyzer +{ + lib, + fetchFromGitHub, + makeWrapper, + rustPlatform, + rust-analyzer, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ra/rabbit/package.nix b/pkgs/by-name/ra/rabbit/package.nix index 9fb39a70857772..e462a8c8993b56 100644 --- a/pkgs/by-name/ra/rabbit/package.nix +++ b/pkgs/by-name/ra/rabbit/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ra/rabbitmq-c/package.nix b/pkgs/by-name/ra/rabbitmq-c/package.nix index 39f4434999aad0..c8db41ed2c1f90 100644 --- a/pkgs/by-name/ra/rabbitmq-c/package.nix +++ b/pkgs/by-name/ra/rabbitmq-c/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, openssl, popt, xmlto }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openssl, + popt, + xmlto, +}: stdenv.mkDerivation rec { pname = "rabbitmq-c"; @@ -12,7 +20,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ openssl popt xmlto ]; + buildInputs = [ + openssl + popt + xmlto + ]; meta = with lib; { description = "RabbitMQ C AMQP client library"; diff --git a/pkgs/by-name/ra/rabtap/package.nix b/pkgs/by-name/ra/rabtap/package.nix index 05f552ea16e66d..91b312e2bedc2f 100644 --- a/pkgs/by-name/ra/rabtap/package.nix +++ b/pkgs/by-name/ra/rabtap/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "rabtap"; diff --git a/pkgs/by-name/ra/racer/package.nix b/pkgs/by-name/ra/racer/package.nix index c6d9f654a480ee..828ac2f48a2cdd 100644 --- a/pkgs/by-name/ra/racer/package.nix +++ b/pkgs/by-name/ra/racer/package.nix @@ -1,20 +1,35 @@ -{ fetchurl, lib, stdenv, allegro, libjpeg, makeWrapper }: +{ + fetchurl, + lib, + stdenv, + allegro, + libjpeg, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "racer"; version = "1.1"; - src = if stdenv.hostPlatform.system == "i686-linux" then fetchurl { - url = "http://hippo.nipax.cz/src/racer-${version}.tar.gz"; - sha256 = "0fll1qkqfcjq87k0jzsilcw701z92lfxn2y5ga1n038772lymxl9"; - } else if stdenv.hostPlatform.system == "x86_64-linux" then fetchurl { - url = "https://hippo.nipax.cz/src/racer-${version}.64.tar.gz"; - sha256 = "0rjy3gmlhwfkb9zs58j0mc0dar0livwpbc19r6zw5r2k6r7xdan0"; - } else - throw "System not supported"; + src = + if stdenv.hostPlatform.system == "i686-linux" then + fetchurl { + url = "http://hippo.nipax.cz/src/racer-${version}.tar.gz"; + sha256 = "0fll1qkqfcjq87k0jzsilcw701z92lfxn2y5ga1n038772lymxl9"; + } + else if stdenv.hostPlatform.system == "x86_64-linux" then + fetchurl { + url = "https://hippo.nipax.cz/src/racer-${version}.64.tar.gz"; + sha256 = "0rjy3gmlhwfkb9zs58j0mc0dar0livwpbc19r6zw5r2k6r7xdan0"; + } + else + throw "System not supported"; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ allegro libjpeg ]; + buildInputs = [ + allegro + libjpeg + ]; prePatch = '' sed -i s,/usr/local,$out, Makefile src/HGFX.cpp src/STDH.cpp diff --git a/pkgs/by-name/ra/radamsa/package.nix b/pkgs/by-name/ra/radamsa/package.nix index e619a248137c54..36d5870b231a75 100644 --- a/pkgs/by-name/ra/radamsa/package.nix +++ b/pkgs/by-name/ra/radamsa/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fetchFromGitLab, bash }: +{ + lib, + stdenv, + fetchurl, + fetchFromGitLab, + bash, +}: let # Fetch explicitly, otherwise build will try to do so @@ -28,7 +34,10 @@ stdenv.mkDerivation rec { patchShebangs tests ''; - makeFlags = [ "PREFIX=${placeholder "out"}" "BINDIR=" ]; + makeFlags = [ + "PREFIX=${placeholder "out"}" + "BINDIR=" + ]; nativeCheckInputs = [ bash ]; doCheck = true; @@ -37,7 +46,7 @@ stdenv.mkDerivation rec { description = "General purpose fuzzer"; mainProgram = "radamsa"; longDescription = "Radamsa is a general purpose data fuzzer. It reads data from given sample files, or standard input if none are given, and outputs modified data. It is usually used to generate malformed data for testing programs."; - homepage = "https://gitlab.com/akihe/radamsa"; + homepage = "https://gitlab.com/akihe/radamsa"; maintainers = [ ]; platforms = lib.platforms.all; }; diff --git a/pkgs/by-name/ra/radeontools/package.nix b/pkgs/by-name/ra/radeontools/package.nix index 01b83f87911994..5dce7e17cfc594 100644 --- a/pkgs/by-name/ra/radeontools/package.nix +++ b/pkgs/by-name/ra/radeontools/package.nix @@ -1,8 +1,11 @@ -{ lib, stdenv, fetchurl -, autoreconfHook -, pciutils -, pkg-config -, xorg +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pciutils, + pkg-config, + xorg, }: stdenv.mkDerivation rec { @@ -14,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "0mjk9wr9rsb17yy92j6yi16hfpa6v5r1dbyiy60zp4r125wr63za"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ xorg.libpciaccess ]; meta = with lib; { diff --git a/pkgs/by-name/ra/radeontop/package.nix b/pkgs/by-name/ra/radeontop/package.nix index 221a26f623406e..2f766860a52032 100644 --- a/pkgs/by-name/ra/radeontop/package.nix +++ b/pkgs/by-name/ra/radeontop/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, gettext, makeWrapper -, ncurses, libdrm, libpciaccess, libxcb }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + gettext, + makeWrapper, + ncurses, + libdrm, + libpciaccess, + libxcb, +}: stdenv.mkDerivation rec { pname = "radeontop"; @@ -12,8 +22,17 @@ stdenv.mkDerivation rec { owner = "clbr"; }; - buildInputs = [ ncurses libdrm libpciaccess libxcb ]; - nativeBuildInputs = [ pkg-config gettext makeWrapper ]; + buildInputs = [ + ncurses + libdrm + libpciaccess + libxcb + ]; + nativeBuildInputs = [ + pkg-config + gettext + makeWrapper + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/ra/radioboat/package.nix b/pkgs/by-name/ra/radioboat/package.nix index ebb19dcf479e1a..f874642fe91fc0 100644 --- a/pkgs/by-name/ra/radioboat/package.nix +++ b/pkgs/by-name/ra/radioboat/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, mpv -, makeWrapper -, installShellFiles -, nix-update-script -, testers -, radioboat +{ + lib, + fetchFromGitHub, + buildGoModule, + mpv, + makeWrapper, + installShellFiles, + nix-update-script, + testers, + radioboat, }: buildGoModule rec { @@ -28,7 +29,10 @@ buildGoModule rec { "-X github.com/slashformotion/radioboat/internal/buildinfo.Version=${version}" ]; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; preFixup = '' wrapProgram $out/bin/radioboat --prefix PATH ":" "${lib.makeBinPath [ mpv ]}"; diff --git a/pkgs/by-name/ra/radsecproxy/package.nix b/pkgs/by-name/ra/radsecproxy/package.nix index 493dd6c0e835e9..a6b0b40cc141bf 100644 --- a/pkgs/by-name/ra/radsecproxy/package.nix +++ b/pkgs/by-name/ra/radsecproxy/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, openssl, autoreconfHook, nettle }: +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + autoreconfHook, + nettle, +}: stdenv.mkDerivation rec { pname = "radsecproxy"; @@ -12,12 +19,15 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ openssl nettle ]; + buildInputs = [ + openssl + nettle + ]; configureFlags = [ - "--with-ssl=${openssl.dev}" - "--sysconfdir=/etc" - "--localstatedir=/var" + "--with-ssl=${openssl.dev}" + "--sysconfdir=/etc" + "--localstatedir=/var" ]; meta = with lib; { diff --git a/pkgs/by-name/ra/raffi/package.nix b/pkgs/by-name/ra/raffi/package.nix index 5a0832b2562914..3acc8504ae7e56 100644 --- a/pkgs/by-name/ra/raffi/package.nix +++ b/pkgs/by-name/ra/raffi/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, makeBinaryWrapper -, fuzzel -, additionalPrograms ? [ ] +{ + lib, + fetchFromGitHub, + rustPlatform, + makeBinaryWrapper, + fuzzel, + additionalPrograms ? [ ], }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ra/raft-canonical/package.nix b/pkgs/by-name/ra/raft-canonical/package.nix index 4d60456d8ab216..c109f8de76064c 100644 --- a/pkgs/by-name/ra/raft-canonical/package.nix +++ b/pkgs/by-name/ra/raft-canonical/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, file, libuv, lz4, lxd-lts }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + file, + libuv, + lz4, + lxd-lts, +}: stdenv.mkDerivation rec { pname = "raft-canonical"; @@ -11,8 +21,15 @@ stdenv.mkDerivation rec { hash = "sha256-ogTw0+ZFhMRaLAxAAXzHSlLRYFuX8W/zjqglXHfvUv4="; }; - nativeBuildInputs = [ autoreconfHook file pkg-config ]; - buildInputs = [ libuv lz4 ]; + nativeBuildInputs = [ + autoreconfHook + file + pkg-config + ]; + buildInputs = [ + libuv + lz4 + ]; enableParallelBuilding = true; @@ -30,7 +47,10 @@ stdenv.mkDerivation rec { doCheck = true; - outputs = [ "dev" "out" ]; + outputs = [ + "dev" + "out" + ]; passthru.tests = { inherit lxd-lts; diff --git a/pkgs/by-name/ra/raft-cowsql/package.nix b/pkgs/by-name/ra/raft-cowsql/package.nix index 65835a086284e8..b916743e7591d1 100644 --- a/pkgs/by-name/ra/raft-cowsql/package.nix +++ b/pkgs/by-name/ra/raft-cowsql/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, libuv -, lz4 -, pkg-config -, incus -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libuv, + lz4, + pkg-config, + incus, + gitUpdater, }: stdenv.mkDerivation rec { @@ -20,8 +21,14 @@ stdenv.mkDerivation rec { hash = "sha256-aGw/ATu8Xdjfqa0qWg8Sld9PKCmQsMtZhuNBwagER7M="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libuv lz4 ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libuv + lz4 + ]; enableParallelBuilding = true; @@ -39,7 +46,10 @@ stdenv.mkDerivation rec { doCheck = true; - outputs = [ "dev" "out" ]; + outputs = [ + "dev" + "out" + ]; passthru = { inherit (incus) tests; diff --git a/pkgs/by-name/ra/rage/package.nix b/pkgs/by-name/ra/rage/package.nix index f8539df67e5ef2..d7853cda2f638a 100644 --- a/pkgs/by-name/ra/rage/package.nix +++ b/pkgs/by-name/ra/rage/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, installShellFiles -, darwin +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + installShellFiles, + darwin, }: rustPlatform.buildRustPackage rec { @@ -42,7 +43,10 @@ rustPlatform.buildRustPackage rec { description = "Simple, secure and modern encryption tool with small explicit keys, no config options, and UNIX-style composability"; homepage = "https://github.com/str4d/rage"; changelog = "https://github.com/str4d/rage/blob/v${version}/rage/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; # either at your option + license = with licenses; [ + asl20 + mit + ]; # either at your option maintainers = with maintainers; [ ryantm ]; mainProgram = "rage"; }; diff --git a/pkgs/by-name/ra/ragnarwm/package.nix b/pkgs/by-name/ra/ragnarwm/package.nix index 6ffdc8a0a39e25..d177c112bdce8e 100644 --- a/pkgs/by-name/ra/ragnarwm/package.nix +++ b/pkgs/by-name/ra/ragnarwm/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, writeText -, fontconfig -, libX11 -, libXft -, libXcursor -, libXcomposite -, conf ? null -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + writeText, + fontconfig, + libX11, + libXft, + libXcursor, + libXcomposite, + conf ? null, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { @@ -31,8 +32,7 @@ stdenv.mkDerivation (finalAttrs: { postPatch = let configFile = - if lib.isDerivation conf || builtins.isPath conf - then conf else writeText "config.h" conf; + if lib.isDerivation conf || builtins.isPath conf then conf else writeText "config.h" conf; in lib.optionalString (conf != null) "cp ${configFile} config.h"; diff --git a/pkgs/by-name/ra/raider/package.nix b/pkgs/by-name/ra/raider/package.nix index b205e1521c5aeb..bfb46e90efcf51 100644 --- a/pkgs/by-name/ra/raider/package.nix +++ b/pkgs/by-name/ra/raider/package.nix @@ -1,16 +1,17 @@ -{ appstream -, blueprint-compiler -, desktop-file-utils -, fetchFromGitHub -, gtk4 -, lib -, libadwaita -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, stdenv -, wrapGAppsHook4 +{ + appstream, + blueprint-compiler, + desktop-file-utils, + fetchFromGitHub, + gtk4, + lib, + libadwaita, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation rec { @@ -24,17 +25,19 @@ stdenv.mkDerivation rec { hash = "sha256-LkGSEUoruWfEq/ttM3LkA/UjHc3ZrlvGF44HsJLntAo="; }; - nativeBuildInputs = [ - appstream - blueprint-compiler - desktop-file-utils - meson - ninja - pkg-config - wrapGAppsHook4 - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + appstream + blueprint-compiler + desktop-file-utils + meson + ninja + pkg-config + wrapGAppsHook4 + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ gtk4 @@ -57,7 +60,10 @@ stdenv.mkDerivation rec { homepage = "https://apps.gnome.org/Raider"; license = licenses.gpl3Plus; mainProgram = "raider"; - maintainers = with maintainers; [ benediktbroich aleksana ]; + maintainers = with maintainers; [ + benediktbroich + aleksana + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ra/rain/package.nix b/pkgs/by-name/ra/rain/package.nix index c5921f90bff63b..5df5e7c559a28b 100644 --- a/pkgs/by-name/ra/rain/package.nix +++ b/pkgs/by-name/ra/rain/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, rain +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + rain, }: buildGoModule rec { @@ -20,7 +21,10 @@ buildGoModule rec { subPackages = [ "cmd/rain" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests.version = testers.testVersion { package = rain; diff --git a/pkgs/by-name/ra/raiseorlaunch/package.nix b/pkgs/by-name/ra/raiseorlaunch/package.nix index 22eddd71bd11aa..8f2d92f80ebac3 100644 --- a/pkgs/by-name/ra/raiseorlaunch/package.nix +++ b/pkgs/by-name/ra/raiseorlaunch/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "raiseorlaunch"; diff --git a/pkgs/by-name/ra/rakkess/package.nix b/pkgs/by-name/ra/rakkess/package.nix index 6b101e0b890cac..a1a349637ab875 100644 --- a/pkgs/by-name/ra/rakkess/package.nix +++ b/pkgs/by-name/ra/rakkess/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "rakkess"; @@ -12,7 +16,11 @@ buildGoModule rec { }; vendorHash = "sha256-lVxJ4wFBhHc8JVpkmqphLYPE9Z8Cr6o+aAHvC1naqyE="; - ldflags = [ "-s" "-w" "-X github.com/corneliusweig/rakkess/internal/version.version=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/corneliusweig/rakkess/internal/version.version=v${version}" + ]; meta = with lib; { homepage = "https://github.com/corneliusweig/rakkess"; diff --git a/pkgs/by-name/ra/raleway/package.nix b/pkgs/by-name/ra/raleway/package.nix index c8a91165f30a13..f1b0c6dd3d43c5 100644 --- a/pkgs/by-name/ra/raleway/package.nix +++ b/pkgs/by-name/ra/raleway/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchzip, stdenvNoCC }: +{ + lib, + fetchzip, + stdenvNoCC, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "raleway"; diff --git a/pkgs/by-name/ra/rambox/package.nix b/pkgs/by-name/ra/rambox/package.nix index 52ee8d79266a17..fb42c557772076 100644 --- a/pkgs/by-name/ra/rambox/package.nix +++ b/pkgs/by-name/ra/rambox/package.nix @@ -1,4 +1,9 @@ -{ appimageTools, lib, fetchurl, makeDesktopItem }: +{ + appimageTools, + lib, + fetchurl, + makeDesktopItem, +}: let pname = "rambox"; @@ -9,13 +14,15 @@ let hash = "sha256-ndFv5rNTWyqrGGC8t1JNR+bQC0Jsit4I9p4ng7h/gcU="; }; - desktopItem = (makeDesktopItem { - desktopName = "Rambox"; - name = pname; - exec = "rambox"; - icon = pname; - categories = [ "Network" ]; - }); + desktopItem = ( + makeDesktopItem { + desktopName = "Rambox"; + name = pname; + exec = "rambox"; + icon = pname; + categories = [ "Network" ]; + } + ); appimageContents = appimageTools.extract { inherit pname version src; diff --git a/pkgs/by-name/ra/ramfetch/package.nix b/pkgs/by-name/ra/ramfetch/package.nix index c8055f99fe44f0..d8d1de5c66783f 100644 --- a/pkgs/by-name/ra/ramfetch/package.nix +++ b/pkgs/by-name/ra/ramfetch/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchgit +{ + lib, + stdenv, + fetchgit, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ra/rancher/package.nix b/pkgs/by-name/ra/rancher/package.nix index 820cc94d931337..5288eebe1c3179 100644 --- a/pkgs/by-name/ra/rancher/package.nix +++ b/pkgs/by-name/ra/rancher/package.nix @@ -1,14 +1,18 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "rancher"; version = "2.9.0"; src = fetchFromGitHub { - owner = "rancher"; - repo = "cli"; - rev = "v${version}"; - hash = "sha256-YyNzqihoQNMmROLeD7/KOU6mTe/UMKgRwGPxCjIglDM="; + owner = "rancher"; + repo = "cli"; + rev = "v${version}"; + hash = "sha256-YyNzqihoQNMmROLeD7/KOU6mTe/UMKgRwGPxCjIglDM="; }; ldflags = [ diff --git a/pkgs/by-name/ra/rancid/package.nix b/pkgs/by-name/ra/rancid/package.nix index f23cb1f9c7126e..a6ed377ebc295f 100644 --- a/pkgs/by-name/ra/rancid/package.nix +++ b/pkgs/by-name/ra/rancid/package.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchFromGitHub -, writeShellScriptBin -, autoreconfHook -, libtool -, makeBinaryWrapper -, coreutils -, expect -, git -, gnugrep -, inetutils # for telnet -, gnused -, openssh -, perl -, runtimeShell +{ + stdenv, + lib, + fetchFromGitHub, + writeShellScriptBin, + autoreconfHook, + libtool, + makeBinaryWrapper, + coreutils, + expect, + git, + gnugrep, + inetutils, # for telnet + gnused, + openssh, + perl, + runtimeShell, }: # we cannot use resholve.mkDerivation yet - the scripts are too hairy, although it might be possible @@ -21,7 +22,12 @@ let inherit (lib) - concatStringsSep getExe makeBinPath mapAttrsToList replaceStrings; + concatStringsSep + getExe + makeBinPath + mapAttrsToList + replaceStrings + ; # The installer executes ping to figure out how to call it and then sets the full path to the # binary. This script "handles" it by pretending everything is OK and has very much not been @@ -67,7 +73,20 @@ stdenv.mkDerivation (finalAttrs: { --replace 'm4_esyscmd(configure.vers package_version),' ${finalAttrs.version}, substituteInPlace etc/rancid.conf.sample.in \ - --replace @ENV_PATH@ ${makeBinPath [ "/run/wrappers" (placeholder "out") coreutils git gnugrep gnused openssh perl runtimeShell telnet' ]} + --replace @ENV_PATH@ ${ + makeBinPath [ + "/run/wrappers" + (placeholder "out") + coreutils + git + gnugrep + gnused + openssh + perl + runtimeShell + telnet' + ] + } for f in bin/*.in; do \ if grep -q /usr/bin/tail $f ; then @@ -90,18 +109,28 @@ stdenv.mkDerivation (finalAttrs: { enableParallelBuilding = true; - nativeBuildInputs = [ autoreconfHook libtool makeBinaryWrapper wrappedPing ]; - - buildInputs = [ expect openssh perl telnet' ]; - - postInstall = concatStringsSep "\n" (mapAttrsToList - (n: v: '' + nativeBuildInputs = [ + autoreconfHook + libtool + makeBinaryWrapper + wrappedPing + ]; + + buildInputs = [ + expect + openssh + perl + telnet' + ]; + + postInstall = concatStringsSep "\n" ( + mapAttrsToList (n: v: '' mkdir -p $out/libexec mv $out/bin/${n} $out/libexec/ makeWrapper $out/libexec/${n} $out/bin/${n} \ --prefix PATH : ${makeBinPath v} - '') - needsBin); + '') needsBin + ); meta = with lib; { description = "Really Awesome New Cisco confIg Differ"; diff --git a/pkgs/by-name/ra/randoop/package.nix b/pkgs/by-name/ra/randoop/package.nix index 552f5fef7cae3c..f3e78214ef70aa 100644 --- a/pkgs/by-name/ra/randoop/package.nix +++ b/pkgs/by-name/ra/randoop/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { version = "4.3.3"; diff --git a/pkgs/by-name/ra/randtype/package.nix b/pkgs/by-name/ra/randtype/package.nix index ba5c40367ec0b0..af2b91eb6b1ce8 100644 --- a/pkgs/by-name/ra/randtype/package.nix +++ b/pkgs/by-name/ra/randtype/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchzip, zlib }: +{ + lib, + stdenv, + fetchzip, + zlib, +}: stdenv.mkDerivation rec { pname = "randtype"; diff --git a/pkgs/by-name/ra/rang/package.nix b/pkgs/by-name/ra/rang/package.nix index 050beef5ea3079..61b6fa19afe07d 100644 --- a/pkgs/by-name/ra/rang/package.nix +++ b/pkgs/by-name/ra/rang/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "rang"; version = "3.1.0"; @@ -10,8 +15,7 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; meta = with lib; { - description = - "A Minimal, Header only Modern c++ library for terminal goodies"; + description = "A Minimal, Header only Modern c++ library for terminal goodies"; homepage = "https://agauniyal.github.io/rang/"; license = licenses.unlicense; maintainers = [ maintainers.HaoZeke ]; diff --git a/pkgs/by-name/ra/range-v3/package.nix b/pkgs/by-name/ra/range-v3/package.nix index b3b4635d476d66..1b5d5caa8e7ae6 100644 --- a/pkgs/by-name/ra/range-v3/package.nix +++ b/pkgs/by-name/ra/range-v3/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "range-v3"; @@ -15,8 +20,9 @@ stdenv.mkDerivation rec { # Building the tests currently fails on AArch64 due to internal compiler # errors (with GCC 9.2): - cmakeFlags = [ "-DRANGES_ENABLE_WERROR=OFF" ] - ++ lib.optional stdenv.hostPlatform.isAarch64 "-DRANGE_V3_TESTS=OFF"; + cmakeFlags = [ + "-DRANGES_ENABLE_WERROR=OFF" + ] ++ lib.optional stdenv.hostPlatform.isAarch64 "-DRANGE_V3_TESTS=OFF"; doCheck = !stdenv.hostPlatform.isAarch64; checkTarget = "test"; diff --git a/pkgs/by-name/ra/ranger/package.nix b/pkgs/by-name/ra/ranger/package.nix index 48d161e22d5def..557e6ddfb7013d 100644 --- a/pkgs/by-name/ra/ranger/package.nix +++ b/pkgs/by-name/ra/ranger/package.nix @@ -1,9 +1,17 @@ -{ lib, fetchFromGitHub, python3Packages, file, less, highlight, w3m, imagemagick -, imagePreviewSupport ? true -, sixelPreviewSupport ? true -, neoVimSupport ? true -, improvedEncodingDetection ? true -, rightToLeftTextSupport ? false +{ + lib, + fetchFromGitHub, + python3Packages, + file, + less, + highlight, + w3m, + imagemagick, + imagePreviewSupport ? true, + sixelPreviewSupport ? true, + neoVimSupport ? true, + improvedEncodingDetection ? true, + rightToLeftTextSupport ? false, }: python3Packages.buildPythonApplication rec { @@ -19,44 +27,55 @@ python3Packages.buildPythonApplication rec { LC_ALL = "en_US.UTF-8"; - nativeCheckInputs = with python3Packages; [ pytestCheckHook astroid pylint ]; - propagatedBuildInputs = [ - less - file - ] ++ lib.optionals imagePreviewSupport [ python3Packages.pillow ] + nativeCheckInputs = with python3Packages; [ + pytestCheckHook + astroid + pylint + ]; + propagatedBuildInputs = + [ + less + file + ] + ++ lib.optionals imagePreviewSupport [ python3Packages.pillow ] ++ lib.optionals sixelPreviewSupport [ imagemagick ] ++ lib.optionals neoVimSupport [ python3Packages.pynvim ] ++ lib.optionals improvedEncodingDetection [ python3Packages.chardet ] ++ lib.optionals rightToLeftTextSupport [ python3Packages.python-bidi ]; - preConfigure = '' - ${lib.optionalString (highlight != null) '' - sed -i -e 's|^\s*highlight\b|${highlight}/bin/highlight|' \ - ranger/data/scope.sh - ''} - - substituteInPlace ranger/__init__.py \ - --replace "DEFAULT_PAGER = 'less'" "DEFAULT_PAGER = '${lib.getBin less}/bin/less'" - - # give file previews out of the box - substituteInPlace ranger/config/rc.conf \ - --replace /usr/share $out/share \ - --replace "#set preview_script ~/.config/ranger/scope.sh" "set preview_script $out/share/doc/ranger/config/scope.sh" - '' + lib.optionalString imagePreviewSupport '' - substituteInPlace ranger/ext/img_display.py \ - --replace /usr/lib/w3m ${w3m}/libexec/w3m - - # give image previews out of the box when building with w3m - substituteInPlace ranger/config/rc.conf \ - --replace "set preview_images false" "set preview_images true" - ''; - - meta = with lib; { + preConfigure = + '' + ${lib.optionalString (highlight != null) '' + sed -i -e 's|^\s*highlight\b|${highlight}/bin/highlight|' \ + ranger/data/scope.sh + ''} + + substituteInPlace ranger/__init__.py \ + --replace "DEFAULT_PAGER = 'less'" "DEFAULT_PAGER = '${lib.getBin less}/bin/less'" + + # give file previews out of the box + substituteInPlace ranger/config/rc.conf \ + --replace /usr/share $out/share \ + --replace "#set preview_script ~/.config/ranger/scope.sh" "set preview_script $out/share/doc/ranger/config/scope.sh" + '' + + lib.optionalString imagePreviewSupport '' + substituteInPlace ranger/ext/img_display.py \ + --replace /usr/lib/w3m ${w3m}/libexec/w3m + + # give image previews out of the box when building with w3m + substituteInPlace ranger/config/rc.conf \ + --replace "set preview_images false" "set preview_images true" + ''; + + meta = with lib; { description = "File manager with minimalistic curses interface"; homepage = "https://ranger.github.io/"; license = licenses.gpl3Only; platforms = platforms.unix; - maintainers = with maintainers; [ toonn magnetophon ]; + maintainers = with maintainers; [ + toonn + magnetophon + ]; mainProgram = "ranger"; }; } diff --git a/pkgs/by-name/ra/rankwidth/package.nix b/pkgs/by-name/ra/rankwidth/package.nix index c00d579702ccb9..4b3a8c3d21e751 100644 --- a/pkgs/by-name/ra/rankwidth/package.nix +++ b/pkgs/by-name/ra/rankwidth/package.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ra/rapidcheck/package.nix b/pkgs/by-name/ra/rapidcheck/package.nix index ce369eb6ff3fd4..aefe46093b0e57 100644 --- a/pkgs/by-name/ra/rapidcheck/package.nix +++ b/pkgs/by-name/ra/rapidcheck/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, unstableGitUpdater -, testers +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + unstableGitUpdater, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -12,12 +13,15 @@ stdenv.mkDerivation (finalAttrs: { src = fetchFromGitHub { owner = "emil-e"; - repo = "rapidcheck"; - rev = "ff6af6fc683159deb51c543b065eba14dfcf329b"; + repo = "rapidcheck"; + rev = "ff6af6fc683159deb51c543b065eba14dfcf329b"; hash = "sha256-Ixz5RpY0n8Un/Pv4XoTfbs40+70iyMbkQUjDqoLaWOg="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/by-name/ra/rapidfuzz-cpp/package.nix b/pkgs/by-name/ra/rapidfuzz-cpp/package.nix index 72978aa7c6ab9e..62aa7a1e362722 100644 --- a/pkgs/by-name/ra/rapidfuzz-cpp/package.nix +++ b/pkgs/by-name/ra/rapidfuzz-cpp/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, catch2_3 -, python3Packages +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + catch2_3, + python3Packages, }: stdenv.mkDerivation (finalAttrs: { @@ -36,7 +37,9 @@ stdenv.mkDerivation (finalAttrs: { passthru = { tests = { - /** `python3Packages.levenshtein` crucially depends on `rapidfuzz-cpp` */ + /** + `python3Packages.levenshtein` crucially depends on `rapidfuzz-cpp` + */ inherit (python3Packages) levenshtein; }; }; diff --git a/pkgs/by-name/ra/rapidsvn/package.nix b/pkgs/by-name/ra/rapidsvn/package.nix index 4ed034c500f99c..3d6e5a3c9e1baf 100644 --- a/pkgs/by-name/ra/rapidsvn/package.nix +++ b/pkgs/by-name/ra/rapidsvn/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, wxGTK32 -, subversion -, apr -, aprutil -, python3 -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + wxGTK32, + subversion, + apr, + aprutil, + python3, + darwin, }: stdenv.mkDerivation rec { @@ -30,15 +31,17 @@ stdenv.mkDerivation rec { autoreconfHook ]; - buildInputs = [ - wxGTK32 - subversion - apr - aprutil - python3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Cocoa - ]; + buildInputs = + [ + wxGTK32 + subversion + apr + aprutil + python3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Cocoa + ]; configureFlags = [ "--with-svn-include=${subversion.dev}/include" diff --git a/pkgs/by-name/ra/rapidxml/package.nix b/pkgs/by-name/ra/rapidxml/package.nix index c433f32728e1ce..7d695b8b60c967 100644 --- a/pkgs/by-name/ra/rapidxml/package.nix +++ b/pkgs/by-name/ra/rapidxml/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "rapidxml"; diff --git a/pkgs/by-name/ra/rapidyaml/package.nix b/pkgs/by-name/ra/rapidyaml/package.nix index bab70f5a6f5666..2e57198c43d213 100644 --- a/pkgs/by-name/ra/rapidyaml/package.nix +++ b/pkgs/by-name/ra/rapidyaml/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, git +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + git, }: stdenv.mkDerivation rec { @@ -17,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-vAYafhWo9xavM2j+mT3OGcX7ZSS25mieR/3b79BO+jA="; }; - nativeBuildInputs = [ cmake git ]; + nativeBuildInputs = [ + cmake + git + ]; meta = with lib; { description = "Library to parse and emit YAML, and do it fast"; diff --git a/pkgs/by-name/ra/rappel/package.nix b/pkgs/by-name/ra/rappel/package.nix index 6a4ff7133e5c99..e8f00c133b4391 100644 --- a/pkgs/by-name/ra/rappel/package.nix +++ b/pkgs/by-name/ra/rappel/package.nix @@ -1,8 +1,10 @@ -{ fetchFromGitHub -, libedit -, makeWrapper -, nasm -, lib, stdenv +{ + fetchFromGitHub, + libedit, + makeWrapper, + nasm, + lib, + stdenv, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ra/rar2fs/package.nix b/pkgs/by-name/ra/rar2fs/package.nix index 0181c0d0ef4f82..0671159ab88efb 100644 --- a/pkgs/by-name/ra/rar2fs/package.nix +++ b/pkgs/by-name/ra/rar2fs/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, fuse2 -, unrar +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + fuse2, + unrar, }: stdenv.mkDerivation rec { @@ -23,7 +24,10 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ fuse2 unrar ]; + buildInputs = [ + fuse2 + unrar + ]; configureFlags = [ "--with-unrar=${unrar.src}/unrar" @@ -34,7 +38,10 @@ stdenv.mkDerivation rec { description = "FUSE file system for reading RAR archives"; homepage = "https://hasse69.github.io/rar2fs/"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ kraem wegank ]; + maintainers = with maintainers; [ + kraem + wegank + ]; platforms = with platforms; linux ++ freebsd; }; } diff --git a/pkgs/by-name/ra/rarcrack/package.nix b/pkgs/by-name/ra/rarcrack/package.nix index 40043022f278c0..31a10c9531c481 100644 --- a/pkgs/by-name/ra/rarcrack/package.nix +++ b/pkgs/by-name/ra/rarcrack/package.nix @@ -1,4 +1,13 @@ -{lib, stdenv, fetchFromGitHub, libxml2, file, p7zip, unrar, unzip}: +{ + lib, + stdenv, + fetchFromGitHub, + libxml2, + file, + p7zip, + unrar, + unzip, +}: stdenv.mkDerivation { pname = "rarcrack"; @@ -12,12 +21,17 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ unzip ]; - buildInputs = [ libxml2 file p7zip unrar ]; + buildInputs = [ + libxml2 + file + p7zip + unrar + ]; buildFlags = lib.optional stdenv.cc.isClang "CC=clang"; installFlags = [ "PREFIX=\${out}" ]; patchPhase = '' - substituteInPlace rarcrack.c --replace "file -i" "${file}/bin/file -i" + substituteInPlace rarcrack.c --replace "file -i" "${file}/bin/file -i" ''; preInstall = '' @@ -27,9 +41,9 @@ stdenv.mkDerivation { meta = with lib; { description = "This program can crack zip,7z and rar file passwords"; longDescription = '' - If you forget your password for compressed archive (rar, 7z, zip), this program is the solution. - This program uses bruteforce algorithm to find correct password. You can specify wich characters will be used in password generations. - Warning: Please don't use this program for any illegal things! + If you forget your password for compressed archive (rar, 7z, zip), this program is the solution. + This program uses bruteforce algorithm to find correct password. You can specify wich characters will be used in password generations. + Warning: Please don't use this program for any illegal things! ''; homepage = "https://github.com/jaredsburrows/Rarcrack"; license = licenses.gpl2Only; @@ -37,4 +51,3 @@ stdenv.mkDerivation { platforms = with platforms; unix; }; } - diff --git a/pkgs/by-name/ra/rare-regex/package.nix b/pkgs/by-name/ra/rare-regex/package.nix index 1c9bece2ffee80..25c74392f88a7e 100644 --- a/pkgs/by-name/ra/rare-regex/package.nix +++ b/pkgs/by-name/ra/rare-regex/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, withPcre2 ? stdenv.hostPlatform.isLinux -, pcre2 -, testers -, rare-regex +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + withPcre2 ? stdenv.hostPlatform.isLinux, + pcre2, + testers, + rare-regex, }: buildGoModule rec { diff --git a/pkgs/by-name/ra/rargs/package.nix b/pkgs/by-name/ra/rargs/package.nix index 7d97a9ecacba4b..1b465e5071b518 100644 --- a/pkgs/by-name/ra/rargs/package.nix +++ b/pkgs/by-name/ra/rargs/package.nix @@ -1,24 +1,28 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { - pname = "rargs"; + pname = "rargs"; version = "0.3.0"; src = fetchFromGitHub { - owner = "lotabout"; - repo = pname; - rev = "v${version}"; + owner = "lotabout"; + repo = pname; + rev = "v${version}"; sha256 = "188gj05rbivci1z4z29vwdwxlj2w01v5i4avwrxjnj1dd6mmlbxd"; }; cargoHash = "sha256-cPfuABjn62Wuxtk8nQlGcLpiPe7/kqNr4IZ7+W8jzaM="; - doCheck=false; # `rargs`'s test depends on the deprecated `assert_cli` crate, which in turn is not in Nixpkgs + doCheck = false; # `rargs`'s test depends on the deprecated `assert_cli` crate, which in turn is not in Nixpkgs meta = with lib; { description = "xargs + awk with pattern matching support"; - homepage = "https://github.com/lolabout/rargs"; - license = with licenses; [ mit ]; + homepage = "https://github.com/lolabout/rargs"; + license = with licenses; [ mit ]; maintainers = with maintainers; [ pblkt ]; mainProgram = "rargs"; }; diff --git a/pkgs/by-name/ra/rars/package.nix b/pkgs/by-name/ra/rars/package.nix index b1ce9eecde5250..e136a312399252 100644 --- a/pkgs/by-name/ra/rars/package.nix +++ b/pkgs/by-name/ra/rars/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, stdenvNoCC, makeWrapper, jre }: +{ + lib, + fetchurl, + stdenvNoCC, + makeWrapper, + jre, +}: stdenvNoCC.mkDerivation rec { pname = "rars"; diff --git a/pkgs/by-name/ra/rascal/package.nix b/pkgs/by-name/ra/rascal/package.nix index 2ddebe96e8a7e8..6f4683d30d2545 100644 --- a/pkgs/by-name/ra/rascal/package.nix +++ b/pkgs/by-name/ra/rascal/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, jdk }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jdk, +}: stdenv.mkDerivation rec { pname = "rascal"; @@ -14,12 +20,11 @@ stdenv.mkDerivation rec { dontUnpack = true; - installPhase = - '' - mkdir -p $out/bin - makeWrapper ${jdk}/bin/java $out/bin/rascal \ - --add-flags "-jar ${src}" \ - ''; + installPhase = '' + mkdir -p $out/bin + makeWrapper ${jdk}/bin/java $out/bin/rascal \ + --add-flags "-jar ${src}" \ + ''; meta = { homepage = "https://www.rascal-mpl.org/"; diff --git a/pkgs/by-name/ra/rasdaemon/package.nix b/pkgs/by-name/ra/rasdaemon/package.nix index 5a1df895b4c035..3bf564a6e499f0 100644 --- a/pkgs/by-name/ra/rasdaemon/package.nix +++ b/pkgs/by-name/ra/rasdaemon/package.nix @@ -1,9 +1,19 @@ -{ lib, stdenv, fetchFromGitHub -, autoreconfHook, pkg-config -, glibcLocales, kmod, coreutils, perl -, dmidecode, hwdata, sqlite, libtraceevent -, fetchpatch -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + glibcLocales, + kmod, + coreutils, + perl, + dmidecode, + hwdata, + sqlite, + libtraceevent, + fetchpatch, + nixosTests, }: stdenv.mkDerivation rec { @@ -18,14 +28,18 @@ stdenv.mkDerivation rec { }; patches = [ - (fetchpatch { # fix #295002 (segfault on AMD), will be in the release after 0.8.0 + (fetchpatch { + # fix #295002 (segfault on AMD), will be in the release after 0.8.0 name = "fix crash on AMD"; url = "https://github.com/mchehab/rasdaemon/commit/f1ea76375281001cdf4a048c1a4a24d86c6fbe48.patch"; hash = "sha256-1VPDTrAsvZGiGbh52EUdG6tYV/n6wUS0mphOSXzran0="; }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ coreutils @@ -34,9 +48,13 @@ stdenv.mkDerivation rec { kmod sqlite libtraceevent - (perl.withPackages (ps: with ps; [ DBI DBDSQLite ])) - ] - ++ lib.optionals (!stdenv.hostPlatform.isAarch64) [ dmidecode ]; + (perl.withPackages ( + ps: with ps; [ + DBI + DBDSQLite + ] + )) + ] ++ lib.optionals (!stdenv.hostPlatform.isAarch64) [ dmidecode ]; configureFlags = [ "--sysconfdir=/etc" @@ -63,29 +81,35 @@ stdenv.mkDerivation rec { # therefore, stripping these from the generated Makefile # (needed in the config flags because those set where the tools look for these) -# easy way out, ends up installing /nix/store/...rasdaemon/bin in $out + # easy way out, ends up installing /nix/store/...rasdaemon/bin in $out postConfigure = '' substituteInPlace Makefile \ --replace '"$(DESTDIR)/etc/ras/dimm_labels.d"' '"$(prefix)/etc/ras/dimm_labels.d"' ''; - outputs = [ "out" "dev" "man" "inject" ]; + outputs = [ + "out" + "dev" + "man" + "inject" + ]; postInstall = '' install -Dm 0755 contrib/edac-fake-inject $inject/bin/edac-fake-inject install -Dm 0755 contrib/edac-tests $inject/bin/edac-tests ''; - postFixup = '' - # Fix dmidecode and modprobe paths - substituteInPlace $out/bin/ras-mc-ctl \ - --replace 'find_prog ("modprobe") or exit (1)' '"${kmod}/bin/modprobe"' - '' - + lib.optionalString (!stdenv.hostPlatform.isAarch64) '' - substituteInPlace $out/bin/ras-mc-ctl \ - --replace 'find_prog ("dmidecode")' '"${dmidecode}/bin/dmidecode"' - ''; + postFixup = + '' + # Fix dmidecode and modprobe paths + substituteInPlace $out/bin/ras-mc-ctl \ + --replace 'find_prog ("modprobe") or exit (1)' '"${kmod}/bin/modprobe"' + '' + + lib.optionalString (!stdenv.hostPlatform.isAarch64) '' + substituteInPlace $out/bin/ras-mc-ctl \ + --replace 'find_prog ("dmidecode")' '"${dmidecode}/bin/dmidecode"' + ''; passthru.tests = nixosTests.rasdaemon; diff --git a/pkgs/by-name/ra/rasm/package.nix b/pkgs/by-name/ra/rasm/package.nix index e2161bb065065d..cf20b5ddb9ed68 100644 --- a/pkgs/by-name/ra/rasm/package.nix +++ b/pkgs/by-name/ra/rasm/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "rasm"; diff --git a/pkgs/by-name/ra/raspberrypi-eeprom/package.nix b/pkgs/by-name/ra/raspberrypi-eeprom/package.nix index 41272ae45533cd..958601bd96e42a 100644 --- a/pkgs/by-name/ra/raspberrypi-eeprom/package.nix +++ b/pkgs/by-name/ra/raspberrypi-eeprom/package.nix @@ -1,15 +1,16 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, makeWrapper -, python3 -, binutils-unwrapped -, findutils -, flashrom -, gawk -, kmod -, pciutils -, libraspberrypi +{ + stdenvNoCC, + lib, + fetchFromGitHub, + makeWrapper, + python3, + binutils-unwrapped, + findutils, + flashrom, + gawk, + kmod, + pciutils, + libraspberrypi, }: stdenvNoCC.mkDerivation (finalAttrs: { pname = "raspberrypi-eeprom"; @@ -50,25 +51,36 @@ stdenvNoCC.mkDerivation (finalAttrs: { wrapProgram $out/bin/$i \ --set FIRMWARE_ROOT "$out/lib/firmware/raspberrypi/bootloader" \ ${lib.optionalString stdenvNoCC.hostPlatform.isAarch64 "--set VCMAILBOX ${libraspberrypi}/bin/vcmailbox"} \ - --prefix PATH : "${lib.makeBinPath ([ - binutils-unwrapped - findutils - flashrom - gawk - kmod - pciutils - (placeholder "out") - ] ++ lib.optionals stdenvNoCC.hostPlatform.isAarch64 [ - libraspberrypi - ])}" + --prefix PATH : "${ + lib.makeBinPath ( + [ + binutils-unwrapped + findutils + flashrom + gawk + kmod + pciutils + (placeholder "out") + ] + ++ lib.optionals stdenvNoCC.hostPlatform.isAarch64 [ + libraspberrypi + ] + ) + }" done ''; meta = with lib; { description = "Installation scripts and binaries for the closed sourced Raspberry Pi 4 and 5 bootloader EEPROMs"; homepage = "https://www.raspberrypi.com/documentation/computers/raspberry-pi.html#raspberry-pi-4-boot-eeprom"; - license = with licenses; [ bsd3 unfreeRedistributableFirmware ]; - maintainers = with maintainers; [ das_j Luflosi ]; + license = with licenses; [ + bsd3 + unfreeRedistributableFirmware + ]; + maintainers = with maintainers; [ + das_j + Luflosi + ]; platforms = platforms.linux; }; }) diff --git a/pkgs/by-name/ra/raspberrypiWirelessFirmware/package.nix b/pkgs/by-name/ra/raspberrypiWirelessFirmware/package.nix index b2125170db14df..a8d4dc74c60134 100644 --- a/pkgs/by-name/ra/raspberrypiWirelessFirmware/package.nix +++ b/pkgs/by-name/ra/raspberrypiWirelessFirmware/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "raspberrypi-wireless-firmware"; diff --git a/pkgs/by-name/ra/ratchet/tests.nix b/pkgs/by-name/ra/ratchet/tests.nix index 75ae285d734e34..aefa1fedee0532 100644 --- a/pkgs/by-name/ra/ratchet/tests.nix +++ b/pkgs/by-name/ra/ratchet/tests.nix @@ -1,16 +1,16 @@ { runCommand, ratchet, -}: let +}: +let inherit (ratchet) pname version; in - runCommand "${pname}-tests" {meta.timeout = 60;} - '' - set -euo pipefail +runCommand "${pname}-tests" { meta.timeout = 60; } '' + set -euo pipefail - # Ensure ratchet is executable - ${ratchet}/bin/ratchet --version - ${ratchet}/bin/ratchet --help + # Ensure ratchet is executable + ${ratchet}/bin/ratchet --version + ${ratchet}/bin/ratchet --help - touch $out - '' + touch $out +'' diff --git a/pkgs/by-name/ra/ratman/package.nix b/pkgs/by-name/ra/ratman/package.nix index ebadc2a41c9339..9541f42714fd23 100644 --- a/pkgs/by-name/ra/ratman/package.nix +++ b/pkgs/by-name/ra/ratman/package.nix @@ -1,15 +1,16 @@ -{ lib -, fetchFromGitLab -, installShellFiles -, libsodium -, pkg-config -, protobuf -, rustPlatform -, fetchYarnDeps -, fixup-yarn-lock -, stdenv -, yarn -, nodejs +{ + lib, + fetchFromGitLab, + installShellFiles, + libsodium, + pkg-config, + protobuf, + rustPlatform, + fetchYarnDeps, + fixup-yarn-lock, + stdenv, + yarn, + nodejs, }: rustPlatform.buildRustPackage rec { @@ -26,9 +27,17 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Nsux0QblBtzlhLEgfKYvkQrOz8+oVd2pqT3CL8TnQEc="; - nativeBuildInputs = [ protobuf pkg-config installShellFiles ]; - - cargoBuildFlags = [ "--all-features" "-p" "ratman" ]; + nativeBuildInputs = [ + protobuf + pkg-config + installShellFiles + ]; + + cargoBuildFlags = [ + "--all-features" + "-p" + "ratman" + ]; cargoTestFlags = cargoBuildFlags; buildInputs = [ libsodium ]; @@ -49,9 +58,16 @@ rustPlatform.buildRustPackage rec { sha256 = "sha256-pWjKL41r/bTvWv+5qCgCFVL9+o64BiV2/ISdLeKEOqE="; }; - nativeBuildInputs = [ yarn nodejs fixup-yarn-lock ]; + nativeBuildInputs = [ + yarn + nodejs + fixup-yarn-lock + ]; - outputs = [ "out" "dist" ]; + outputs = [ + "out" + "dist" + ]; buildPhase = '' # Yarn writes temporary files to $HOME. Copied from mkYarnModules. diff --git a/pkgs/by-name/ra/ratmen/package.nix b/pkgs/by-name/ra/ratmen/package.nix index 9a6ea5af761638..736b0971e4edd4 100644 --- a/pkgs/by-name/ra/ratmen/package.nix +++ b/pkgs/by-name/ra/ratmen/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, perl, xorgproto, libX11 }: +{ + lib, + stdenv, + fetchurl, + perl, + xorgproto, + libX11, +}: stdenv.mkDerivation rec { pname = "ratmen"; diff --git a/pkgs/by-name/ra/ratools/package.nix b/pkgs/by-name/ra/ratools/package.nix index 1399fc4c8d599b..9bfb9b38bba6ad 100644 --- a/pkgs/by-name/ra/ratools/package.nix +++ b/pkgs/by-name/ra/ratools/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "ratools"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "07m45bn9lzgbfihmxic23wqp73nxg5ihrvkigr450jq6gzvgwawq"; }; - makeFlags = [ "-C" "src" ]; + makeFlags = [ + "-C" + "src" + ]; installPhase = '' install -vD bin/* -t $out/bin diff --git a/pkgs/by-name/ra/ratox/package.nix b/pkgs/by-name/ra/ratox/package.nix index 4a80071a6cea76..77e6b356a339fc 100644 --- a/pkgs/by-name/ra/ratox/package.nix +++ b/pkgs/by-name/ra/ratox/package.nix @@ -1,10 +1,16 @@ -{ lib, stdenv, fetchgit, libtoxcore -, conf ? null }: +{ + lib, + stdenv, + fetchgit, + libtoxcore, + conf ? null, +}: let - configFile = lib.optionalString (conf!=null) (builtins.toFile "config.h" conf); + configFile = lib.optionalString (conf != null) (builtins.toFile "config.h" conf); -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "ratox"; version = "0.4.20180303"; @@ -20,7 +26,7 @@ in stdenv.mkDerivation { substituteInPlace config.mk \ --replace '-lsodium -lopus -lvpx ' "" - ${lib.optionalString (conf!=null) "cp ${configFile} config.def.h"} + ${lib.optionalString (conf != null) "cp ${configFile} config.def.h"} ''; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/ra/ratpoints/package.nix b/pkgs/by-name/ra/ratpoints/package.nix index 4aaed4a1b0edc4..8caba2276334f3 100644 --- a/pkgs/by-name/ra/ratpoints/package.nix +++ b/pkgs/by-name/ra/ratpoints/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fetchpatch, gmp }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + gmp, +}: stdenv.mkDerivation rec { pname = "ratpoints"; version = "2.1.3.p4"; @@ -20,7 +26,10 @@ stdenv.mkDerivation rec { buildInputs = [ gmp ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; - buildFlags = lib.optionals stdenv.hostPlatform.isDarwin ["CCFLAGS2=-lgmp -lc -lm" "CCFLAGS=-UUSE_SSE"]; + buildFlags = lib.optionals stdenv.hostPlatform.isDarwin [ + "CCFLAGS2=-lgmp -lc -lm" + "CCFLAGS=-UUSE_SSE" + ]; installFlags = [ "INSTALL_DIR=$(out)" ]; preInstall = ''mkdir -p "$out"/{bin,share,lib,include}''; @@ -29,7 +38,7 @@ stdenv.mkDerivation rec { description = "Program to find rational points on hyperelliptic curves"; mainProgram = "ratpoints"; license = lib.licenses.gpl2Plus; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.unix; homepage = "http://www.mathe2.uni-bayreuth.de/stoll/programs/"; }; diff --git a/pkgs/by-name/ra/ratpoison/package.nix b/pkgs/by-name/ra/ratpoison/package.nix index 6a2f63159f6529..cb53917d7165fd 100644 --- a/pkgs/by-name/ra/ratpoison/package.nix +++ b/pkgs/by-name/ra/ratpoison/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, fontconfig -, freetype -, libX11 -, libXft -, libXi -, libXpm -, libXrandr -, libXt -, libXtst -, perl -, pkg-config -, readline -, texinfo -, xorgproto +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + fontconfig, + freetype, + libX11, + libXft, + libXi, + libXpm, + libXrandr, + libXt, + libXtst, + perl, + pkg-config, + readline, + texinfo, + xorgproto, }: stdenv.mkDerivation (finalAttrs: { @@ -48,7 +49,13 @@ stdenv.mkDerivation (finalAttrs: { xorgproto ]; - outputs = [ "out" "contrib" "man" "doc" "info" ]; + outputs = [ + "out" + "contrib" + "man" + "doc" + "info" + ]; strictDeps = true; @@ -67,18 +74,18 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.nongnu.org/ratpoison/"; description = "Simple mouse-free tiling window manager"; longDescription = '' - Ratpoison is a simple window manager with no fat library - dependencies, no fancy graphics, no window decorations, and no - rodent dependence. It is largely modelled after GNU Screen which - has done wonders in the virtual terminal market. + Ratpoison is a simple window manager with no fat library + dependencies, no fancy graphics, no window decorations, and no + rodent dependence. It is largely modelled after GNU Screen which + has done wonders in the virtual terminal market. - The screen can be split into non-overlapping frames. All windows - are kept maximized inside their frames to take full advantage of - your precious screen real estate. + The screen can be split into non-overlapping frames. All windows + are kept maximized inside their frames to take full advantage of + your precious screen real estate. - All interaction with the window manager is done through keystrokes. - Ratpoison has a prefix map to minimize the key clobbering that - cripples Emacs and other quality pieces of software. + All interaction with the window manager is done through keystrokes. + Ratpoison has a prefix map to minimize the key clobbering that + cripples Emacs and other quality pieces of software. ''; license = lib.licenses.gpl2Plus; mainProgram = "ratpoison"; diff --git a/pkgs/by-name/ra/ratslap/package.nix b/pkgs/by-name/ra/ratslap/package.nix index 59ff8ffb8e1e82..748063896d3661 100644 --- a/pkgs/by-name/ra/ratslap/package.nix +++ b/pkgs/by-name/ra/ratslap/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, libusb1 -, pkg-config -, installShellFiles -, git +{ + stdenv, + lib, + fetchFromGitHub, + libusb1, + pkg-config, + installShellFiles, + git, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ra/ratt/package.nix b/pkgs/by-name/ra/ratt/package.nix index 788dde7c5c9ca8..525f1b7f95d98b 100644 --- a/pkgs/by-name/ra/ratt/package.nix +++ b/pkgs/by-name/ra/ratt/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromSourcehut, lib }: +{ + buildGoModule, + fetchFromSourcehut, + lib, +}: buildGoModule rec { pname = "ratt"; version = "unstable-2023-02-12"; diff --git a/pkgs/by-name/ra/rauc/package.nix b/pkgs/by-name/ra/rauc/package.nix index 03c0fb176d7908..369b0683b8be13 100644 --- a/pkgs/by-name/ra/rauc/package.nix +++ b/pkgs/by-name/ra/rauc/package.nix @@ -1,18 +1,19 @@ -{ curl -, dbus -, fetchFromGitHub -, glib -, json-glib -, lib -, nix-update-script -, openssl -, pkg-config -, stdenv -, meson -, ninja -, util-linux -, libnl -, systemd +{ + curl, + dbus, + fetchFromGitHub, + glib, + json-glib, + lib, + nix-update-script, + openssl, + pkg-config, + stdenv, + meson, + ninja, + util-linux, + libnl, + systemd, }: stdenv.mkDerivation rec { @@ -32,9 +33,23 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - nativeBuildInputs = [ pkg-config meson ninja glib ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + glib + ]; - buildInputs = [ curl dbus glib json-glib openssl util-linux libnl systemd ]; + buildInputs = [ + curl + dbus + glib + json-glib + openssl + util-linux + libnl + systemd + ]; mesonFlags = [ "--buildtype=release" diff --git a/pkgs/by-name/ra/ravedude/package.nix b/pkgs/by-name/ra/ravedude/package.nix index 36777a2075a7bf..2ee907a4a4fbd7 100644 --- a/pkgs/by-name/ra/ravedude/package.nix +++ b/pkgs/by-name/ra/ravedude/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, udev -, avrdude -, makeBinaryWrapper -, nix-update-script -, testers -, ravedude +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + udev, + avrdude, + makeBinaryWrapper, + nix-update-script, + testers, + ravedude, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-HeFmQsgr6uHrWi6s5sMQ6n63a44Msarb5p0+wUzKFkE="; - nativeBuildInputs = [ pkg-config makeBinaryWrapper ]; + nativeBuildInputs = [ + pkg-config + makeBinaryWrapper + ]; buildInputs = [ udev ]; @@ -40,9 +44,15 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Tool to easily flash code onto an AVR microcontroller with avrdude"; homepage = "https://crates.io/crates/ravedude"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; platforms = platforms.linux; - maintainers = with maintainers; [ rvarago liff ]; + maintainers = with maintainers; [ + rvarago + liff + ]; mainProgram = "ravedude"; }; } diff --git a/pkgs/by-name/ra/raven-reader/package.nix b/pkgs/by-name/ra/raven-reader/package.nix index 275ef729016f4b..c011ddb8099949 100644 --- a/pkgs/by-name/ra/raven-reader/package.nix +++ b/pkgs/by-name/ra/raven-reader/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools }: +{ + lib, + fetchurl, + appimageTools, +}: let pname = "raven-reader"; diff --git a/pkgs/by-name/ra/raxml/package.nix b/pkgs/by-name/ra/raxml/package.nix index 94ccafd36d00ca..74090f0d1fad05 100644 --- a/pkgs/by-name/ra/raxml/package.nix +++ b/pkgs/by-name/ra/raxml/package.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchFromGitHub -, useMpi ? false -, mpi +{ + lib, + stdenv, + fetchFromGitHub, + useMpi ? false, + mpi, }: stdenv.mkDerivation rec { @@ -18,23 +20,34 @@ stdenv.mkDerivation rec { buildInputs = lib.optionals useMpi [ mpi ]; # TODO darwin, AVX and AVX2 makefile targets - buildPhase = if useMpi then '' - make -f Makefile.MPI.gcc - '' else '' - make -f Makefile.SSE3.PTHREADS.gcc - ''; + buildPhase = + if useMpi then + '' + make -f Makefile.MPI.gcc + '' + else + '' + make -f Makefile.SSE3.PTHREADS.gcc + ''; - installPhase = if useMpi then '' - mkdir -p $out/bin && cp raxmlHPC-MPI $out/bin - '' else '' - mkdir -p $out/bin && cp raxmlHPC-PTHREADS-SSE3 $out/bin - ''; + installPhase = + if useMpi then + '' + mkdir -p $out/bin && cp raxmlHPC-MPI $out/bin + '' + else + '' + mkdir -p $out/bin && cp raxmlHPC-PTHREADS-SSE3 $out/bin + ''; meta = with lib; { description = "Tool for Phylogenetic Analysis and Post-Analysis of Large Phylogenies"; license = licenses.gpl3; homepage = "https://sco.h-its.org/exelixis/web/software/raxml/"; maintainers = [ maintainers.unode ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/ra/raygui/package.nix b/pkgs/by-name/ra/raygui/package.nix index 3c5b427e828fb2..e860ac71b8e3d9 100644 --- a/pkgs/by-name/ra/raygui/package.nix +++ b/pkgs/by-name/ra/raygui/package.nix @@ -1,7 +1,7 @@ { stdenvNoCC, fetchFromGitHub, - lib + lib, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/rb/rbdoom-3-bfg/package.nix b/pkgs/by-name/rb/rbdoom-3-bfg/package.nix index 07f809662d6bbe..137be74c7a0d93 100644 --- a/pkgs/by-name/rb/rbdoom-3-bfg/package.nix +++ b/pkgs/by-name/rb/rbdoom-3-bfg/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, directx-shader-compiler -, libGLU -, libpng -, libjpeg_turbo -, openal -, rapidjson -, SDL2 -, vulkan-headers -, vulkan-loader -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + directx-shader-compiler, + libGLU, + libpng, + libjpeg_turbo, + openal, + rapidjson, + SDL2, + vulkan-headers, + vulkan-loader, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/rc/rc-9front/package.nix b/pkgs/by-name/rc/rc-9front/package.nix index cd6e18064b3650..995aa8e35b6ad2 100644 --- a/pkgs/by-name/rc/rc-9front/package.nix +++ b/pkgs/by-name/rc/rc-9front/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFrom9Front -, unstableGitUpdater -, byacc -, installShellFiles +{ + lib, + stdenv, + fetchFrom9Front, + unstableGitUpdater, + byacc, + installShellFiles, }: stdenv.mkDerivation { @@ -19,7 +20,10 @@ stdenv.mkDerivation { }; strictDeps = true; - nativeBuildInputs = [ byacc installShellFiles ]; + nativeBuildInputs = [ + byacc + installShellFiles + ]; enableParallelBuilding = true; patches = [ ./path.patch ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/rc/rc/package.nix b/pkgs/by-name/rc/rc/package.nix index 15b35211b30149..c4a964fc369977 100644 --- a/pkgs/by-name/rc/rc/package.nix +++ b/pkgs/by-name/rc/rc/package.nix @@ -1,22 +1,32 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkgsStatic -, byacc -, ed -, ncurses -, readline -, installShellFiles -, historySupport ? true -, readlineSupport ? true -, lineEditingLibrary ? if (stdenv.hostPlatform.isDarwin - || stdenv.hostPlatform.isStatic) - then "null" - else "readline" +{ + lib, + stdenv, + fetchFromGitHub, + pkgsStatic, + byacc, + ed, + ncurses, + readline, + installShellFiles, + historySupport ? true, + readlineSupport ? true, + lineEditingLibrary ? + if (stdenv.hostPlatform.isDarwin || stdenv.hostPlatform.isStatic) then "null" else "readline", }: -assert lib.elem lineEditingLibrary [ "null" "edit" "editline" "readline" "vrl" ]; -assert !(lib.elem lineEditingLibrary [ "edit" "editline" "vrl" ]); # broken +assert lib.elem lineEditingLibrary [ + "null" + "edit" + "editline" + "readline" + "vrl" +]; +assert + !(lib.elem lineEditingLibrary [ + "edit" + "editline" + "vrl" + ]); # broken assert (lineEditingLibrary == "readline") -> readlineSupport; stdenv.mkDerivation (finalAttrs: { pname = "rc"; @@ -29,7 +39,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-Yql3mt7hTO2W7wTfPje+X2zBGTHiNXGGXYORJewJIM8="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; # TODO: think on a less ugly fixup postPatch = '' @@ -52,16 +65,17 @@ stdenv.mkDerivation (finalAttrs: { installShellFiles ]; - buildInputs = [ - ncurses - ] - ++ lib.optionals readlineSupport [ - readline - ]; + buildInputs = + [ + ncurses + ] + ++ lib.optionals readlineSupport [ + readline + ]; strictDeps = true; - makeFlags = [ + makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "PREFIX=${placeholder "out"}" "MANPREFIX=${placeholder "man"}/share/man" @@ -69,11 +83,13 @@ stdenv.mkDerivation (finalAttrs: { "EDIT=${lineEditingLibrary}" ]; - buildFlags = [ - "all" - ] ++ lib.optionals historySupport [ - "history" - ]; + buildFlags = + [ + "all" + ] + ++ lib.optionals historySupport [ + "history" + ]; postInstall = lib.optionalString historySupport '' installManPage history.1 diff --git a/pkgs/by-name/rc/rcm/package.nix b/pkgs/by-name/rc/rcm/package.nix index 3aa8ba412e17ce..d8c923fbfcfda4 100644 --- a/pkgs/by-name/rc/rcm/package.nix +++ b/pkgs/by-name/rc/rcm/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { @@ -24,7 +25,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/thoughtbot/rcm"; description = "Management Suite for Dotfiles"; license = licenses.bsd3; - maintainers = with maintainers; [ malyn AndersonTorres ]; + maintainers = with maintainers; [ + malyn + AndersonTorres + ]; platforms = with platforms; unix; }; } diff --git a/pkgs/by-name/rc/rcodesign/package.nix b/pkgs/by-name/rc/rcodesign/package.nix index c4e2f601a19335..3b6efcc0ce78d6 100644 --- a/pkgs/by-name/rc/rcodesign/package.nix +++ b/pkgs/by-name/rc/rcodesign/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, apple-sdk_11 -, uutils-coreutils +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + apple-sdk_11, + uutils-coreutils, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/rc/rcon/package.nix b/pkgs/by-name/rc/rcon/package.nix index e51dc3fac37176..48fd4373a3f83b 100644 --- a/pkgs/by-name/rc/rcon/package.nix +++ b/pkgs/by-name/rc/rcon/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, glib, libbsd, check, pcre }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + glib, + libbsd, + check, + pcre, +}: stdenv.mkDerivation rec { pname = "rcon"; @@ -11,7 +21,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-bHm6JeWmpg42VZQXikHl+BMx9zimRLBQWemTqOxyLhw="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ glib diff --git a/pkgs/by-name/rc/rconc/package.nix b/pkgs/by-name/rc/rconc/package.nix index d8af7fb6e9e177..59dfbd99fbc7c5 100644 --- a/pkgs/by-name/rc/rconc/package.nix +++ b/pkgs/by-name/rc/rconc/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { version = "0.1.4"; diff --git a/pkgs/by-name/rc/rcp/package.nix b/pkgs/by-name/rc/rcp/package.nix index 2ba6a2ffbf36dc..e845f13507283d 100644 --- a/pkgs/by-name/rc/rcp/package.nix +++ b/pkgs/by-name/rc/rcp/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, }: rustPlatform.buildRustPackage rec { @@ -16,9 +17,12 @@ rustPlatform.buildRustPackage rec { hash = "sha256-gFkrUqG3GXPAg9Zqv7Wr3axQ30axYGXw8bo+P1kmSJM="; }; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - IOKit - ]); + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + IOKit + ] + ); cargoHash = "sha256-loS55mQUVbIm+5VcQnPf6olERNTm3dbnQu5SPXe6a8I="; diff --git a/pkgs/by-name/rc/rcs/package.nix b/pkgs/by-name/rc/rcs/package.nix index 7cfeb20e8de23d..bd1cab4a46f5e3 100644 --- a/pkgs/by-name/rc/rcs/package.nix +++ b/pkgs/by-name/rc/rcs/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, buildPackages, diffutils, ed, lzip }: +{ + lib, + stdenv, + fetchurl, + buildPackages, + diffutils, + ed, + lzip, +}: stdenv.mkDerivation rec { pname = "rcs"; @@ -13,9 +21,10 @@ stdenv.mkDerivation rec { DIFF = "${diffutils}/bin/diff"; DIFF3 = "${diffutils}/bin/diff3"; - disallowedReferences = - lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) - [ buildPackages.diffutils buildPackages.ed ]; + disallowedReferences = lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + buildPackages.diffutils + buildPackages.ed + ]; env.NIX_CFLAGS_COMPILE = "-std=c99"; diff --git a/pkgs/by-name/rc/rcshist/package.nix b/pkgs/by-name/rc/rcshist/package.nix index f11c515b5399e3..f22aaaf7718791 100644 --- a/pkgs/by-name/rc/rcshist/package.nix +++ b/pkgs/by-name/rc/rcshist/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, musl-fts +{ + lib, + stdenv, + fetchurl, + musl-fts, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/rc/rcu/package.nix b/pkgs/by-name/rc/rcu/package.nix index 17d6d1c1e5b0d2..25838bba9940e0 100644 --- a/pkgs/by-name/rc/rcu/package.nix +++ b/pkgs/by-name/rc/rcu/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, requireFile -, runCommand -, rcu -, testers -, copyDesktopItems -, desktopToDarwinBundle -, libsForQt5 -, makeDesktopItem -, python3Packages -, system-config-printer +{ + stdenv, + lib, + requireFile, + runCommand, + rcu, + testers, + copyDesktopItems, + desktopToDarwinBundle, + libsForQt5, + makeDesktopItem, + python3Packages, + system-config-printer, }: python3Packages.buildPythonApplication rec { @@ -18,17 +19,19 @@ python3Packages.buildPythonApplication rec { format = "other"; - src = let - src-tarball = requireFile { - name = "rcu-d${version}-source.tar.gz"; - hash = "sha256-Ywk28gJBMSSQL6jEcHE8h253KOsXIGwVOag6PBWs8kg="; - url = "http://www.davisr.me/projects/rcu/"; - }; - in runCommand "${src-tarball.name}-unpacked" {} '' - gunzip -ck ${src-tarball} | tar -xvf- - mv rcu $out - ln -s ${src-tarball} $out/src - ''; + src = + let + src-tarball = requireFile { + name = "rcu-d${version}-source.tar.gz"; + hash = "sha256-Ywk28gJBMSSQL6jEcHE8h253KOsXIGwVOag6PBWs8kg="; + url = "http://www.davisr.me/projects/rcu/"; + }; + in + runCommand "${src-tarball.name}-unpacked" { } '' + gunzip -ck ${src-tarball} | tar -xvf- + mv rcu $out + ln -s ${src-tarball} $out/src + ''; patches = [ ./Port-to-paramiko-3.x.patch @@ -42,12 +45,14 @@ python3Packages.buildPythonApplication rec { --replace-fail 'GROUP="yourgroup"' 'GROUP="users"' ''; - nativeBuildInputs = [ - copyDesktopItems - libsForQt5.wrapQtAppsHook - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - desktopToDarwinBundle - ]; + nativeBuildInputs = + [ + copyDesktopItems + libsForQt5.wrapQtAppsHook + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + desktopToDarwinBundle + ]; buildInputs = [ libsForQt5.qtbase @@ -81,64 +86,75 @@ python3Packages.buildPythonApplication rec { # No tests doCheck = false; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - mkdir -p $out/{bin,share} - cp -r src $out/share/rcu + mkdir -p $out/{bin,share} + cp -r src $out/share/rcu - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - install -Dm644 package_support/gnulinux/50-remarkable.rules $out/etc/udev/rules.d/50-remarkable.rules - '' + '' + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + install -Dm644 package_support/gnulinux/50-remarkable.rules $out/etc/udev/rules.d/50-remarkable.rules + '' + + '' - # Keep source from being GC'd by linking into it + # Keep source from being GC'd by linking into it - for icondir in $(find icons -type d -name '[0-9]*x[0-9]*'); do - iconsize=$(basename $icondir) - mkdir -p $out/share/icons/hicolor/$iconsize/apps - ln -s ${src}/icons/$iconsize/rcu-icon-$iconsize.png $out/share/icons/hicolor/$iconsize/apps/rcu.png - done + for icondir in $(find icons -type d -name '[0-9]*x[0-9]*'); do + iconsize=$(basename $icondir) + mkdir -p $out/share/icons/hicolor/$iconsize/apps + ln -s ${src}/icons/$iconsize/rcu-icon-$iconsize.png $out/share/icons/hicolor/$iconsize/apps/rcu.png + done - mkdir -p $out/share/icons/hicolor/scalable/apps - ln -s ${src}/icons/64x64/rcu-icon-64x64.svg $out/share/icons/hicolor/scalable/apps/rcu.svg + mkdir -p $out/share/icons/hicolor/scalable/apps + ln -s ${src}/icons/64x64/rcu-icon-64x64.svg $out/share/icons/hicolor/scalable/apps/rcu.svg - mkdir -p $out/share/doc/rcu - for docfile in {COPYING,manual.pdf}; do - ln -s ${src}/manual/$docfile $out/share/doc/rcu/$docfile - done + mkdir -p $out/share/doc/rcu + for docfile in {COPYING,manual.pdf}; do + ln -s ${src}/manual/$docfile $out/share/doc/rcu/$docfile + done - mkdir -p $out/share/licenses/rcu - ln -s ${src}/COPYING $out/share/licenses/rcu/COPYING + mkdir -p $out/share/licenses/rcu + ln -s ${src}/COPYING $out/share/licenses/rcu/COPYING - runHook postInstall - ''; + runHook postInstall + ''; # Manually creating wrapper, hook struggles with lack of shebang & symlink dontWrapPythonPrograms = true; - preFixup = '' - makeWrapperArgs+=( - "''${qtWrapperArgs[@]}" - '' + lib.optionalString stdenv.hostPlatform.isLinux '' + preFixup = + '' + makeWrapperArgs+=( + "''${qtWrapperArgs[@]}" + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' --prefix PATH : ${lib.makeBinPath [ system-config-printer ]} - '' + '' - ) - ''; + '' + + '' + ) + ''; postFixup = '' makeWrapper ${lib.getExe python3Packages.python} $out/bin/rcu \ ''${makeWrapperArgs[@]} \ - --prefix PYTHONPATH : ${python3Packages.makePythonPath (propagatedBuildInputs ++ [(placeholder "out")])} \ + --prefix PYTHONPATH : ${ + python3Packages.makePythonPath (propagatedBuildInputs ++ [ (placeholder "out") ]) + } \ --add-flags $out/share/rcu/main.py ''; passthru = { tests.version = testers.testVersion { package = rcu; - version = let - versionSuffixPos = (lib.strings.stringLength rcu.version) - 1; - in - "d${lib.strings.substring 0 versionSuffixPos rcu.version}(${lib.strings.substring versionSuffixPos 1 rcu.version})"; + version = + let + versionSuffixPos = (lib.strings.stringLength rcu.version) - 1; + in + "d${lib.strings.substring 0 versionSuffixPos rcu.version}(${ + lib.strings.substring versionSuffixPos 1 rcu.version + })"; }; }; diff --git a/pkgs/by-name/rd/rdap/package.nix b/pkgs/by-name/rd/rdap/package.nix index 3ea80e07dabbf1..a5fefe708662a2 100644 --- a/pkgs/by-name/rd/rdap/package.nix +++ b/pkgs/by-name/rd/rdap/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "rdap"; @@ -14,7 +18,11 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X \"github.com/openrdap/rdap.version=OpenRDAP ${version}\"" ]; + ldflags = [ + "-s" + "-w" + "-X \"github.com/openrdap/rdap.version=OpenRDAP ${version}\"" + ]; meta = with lib; { homepage = "https://www.openrdap.org/"; diff --git a/pkgs/by-name/rd/rdesktop/package.nix b/pkgs/by-name/rd/rdesktop/package.nix index b92822b17d3f6a..1711a259195d9e 100644 --- a/pkgs/by-name/rd/rdesktop/package.nix +++ b/pkgs/by-name/rd/rdesktop/package.nix @@ -1,7 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, openssl, libX11, krb5, libXcursor, libtasn1 -, nettle, gnutls, pkg-config, autoreconfHook, libiconv -, enableCredssp ? (!stdenv.hostPlatform.isDarwin) -} : +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + libX11, + krb5, + libXcursor, + libtasn1, + nettle, + gnutls, + pkg-config, + autoreconfHook, + libiconv, + enableCredssp ? (!stdenv.hostPlatform.isDarwin), +}: stdenv.mkDerivation (rec { pname = "rdesktop"; @@ -14,8 +26,19 @@ stdenv.mkDerivation (rec { sha256 = "1s6k1jwd28y38ymk3lfv76ch4arpfwrbdhpkbnwwy3fc4617gb78"; }; - nativeBuildInputs = [pkg-config autoreconfHook]; - buildInputs = [openssl libX11 libXcursor libtasn1 nettle gnutls] + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = + [ + openssl + libX11 + libXcursor + libtasn1 + nettle + gnutls + ] ++ lib.optional enableCredssp krb5 ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; diff --git a/pkgs/by-name/rd/rdfind/package.nix b/pkgs/by-name/rd/rdfind/package.nix index 0e7c8fd42d63dd..579dee9a3bd435 100644 --- a/pkgs/by-name/rd/rdfind/package.nix +++ b/pkgs/by-name/rd/rdfind/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, nettle }: +{ + lib, + stdenv, + fetchurl, + nettle, +}: stdenv.mkDerivation rec { pname = "rdfind"; diff --git a/pkgs/by-name/rd/rdiff-backup/package.nix b/pkgs/by-name/rd/rdiff-backup/package.nix index 33050e805f9abd..a28a8f27ad3bc0 100644 --- a/pkgs/by-name/rd/rdiff-backup/package.nix +++ b/pkgs/by-name/rd/rdiff-backup/package.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, librsync }: +{ + lib, + python3Packages, + fetchPypi, + librsync, +}: let pypkgs = python3Packages; diff --git a/pkgs/by-name/rd/rdkafka/package.nix b/pkgs/by-name/rd/rdkafka/package.nix index a3378ef222c308..9028ed6f05c56e 100644 --- a/pkgs/by-name/rd/rdkafka/package.nix +++ b/pkgs/by-name/rd/rdkafka/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, zlib, zstd, pkg-config, python3, openssl, which, curl }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + zstd, + pkg-config, + python3, + openssl, + which, + curl, +}: stdenv.mkDerivation (finalAttrs: { pname = "rdkafka"; @@ -11,9 +22,18 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-qgy5VVB7H0FECtQR6HkTJ58vrHIU9TAFurDNuZGGgvw="; }; - nativeBuildInputs = [ pkg-config python3 which ]; - - buildInputs = [ zlib zstd openssl curl ]; + nativeBuildInputs = [ + pkg-config + python3 + which + ]; + + buildInputs = [ + zlib + zstd + openssl + curl + ]; env.NIX_CFLAGS_COMPILE = "-Wno-error=strict-overflow"; diff --git a/pkgs/by-name/rd/rdma-core/package.nix b/pkgs/by-name/rd/rdma-core/package.nix index a86cb1de9f5d7a..f10c23b60e3fce 100644 --- a/pkgs/by-name/rd/rdma-core/package.nix +++ b/pkgs/by-name/rd/rdma-core/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, docutils -, pandoc -, ethtool -, iproute2 -, libnl -, udev -, python3 -, perl -} : +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + docutils, + pandoc, + ethtool, + iproute2, + libnl, + udev, + python3, + perl, +}: stdenv.mkDerivation (finalAttrs: { pname = "rdma-core"; @@ -26,7 +27,11 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - outputs = [ "out" "man" "dev" ]; + outputs = [ + "out" + "man" + "dev" + ]; nativeBuildInputs = [ cmake diff --git a/pkgs/by-name/rd/rdocker/package.nix b/pkgs/by-name/rd/rdocker/package.nix index fa823ec4d4c94e..9e5f04133e8086 100644 --- a/pkgs/by-name/rd/rdocker/package.nix +++ b/pkgs/by-name/rd/rdocker/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, openssh }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + openssh, +}: stdenv.mkDerivation { pname = "rdocker"; diff --git a/pkgs/by-name/rd/rdrview/package.nix b/pkgs/by-name/rd/rdrview/package.nix index e4d56be3ffb9a1..c9327a4944301a 100644 --- a/pkgs/by-name/rd/rdrview/package.nix +++ b/pkgs/by-name/rd/rdrview/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libxml2, curl, libseccomp, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + libxml2, + curl, + libseccomp, + installShellFiles, +}: stdenv.mkDerivation { pname = "rdrview"; @@ -11,7 +19,11 @@ stdenv.mkDerivation { sha256 = "02VC8r8PdcAfMYB0/NtbPnhsWatpLQc4mW4TmSE1+zk="; }; - buildInputs = [ libxml2 curl libseccomp ]; + buildInputs = [ + libxml2 + curl + libseccomp + ]; nativeBuildInputs = [ installShellFiles ]; installPhase = '' diff --git a/pkgs/by-name/rd/rdup/package.nix b/pkgs/by-name/rd/rdup/package.nix index 2363ea8f75f165..1649ad98882a37 100644 --- a/pkgs/by-name/rd/rdup/package.nix +++ b/pkgs/by-name/rd/rdup/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, autoreconfHook, glib, pcre }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + glib, + pcre, +}: stdenv.mkDerivation { pname = "rdup"; @@ -11,14 +19,20 @@ stdenv.mkDerivation { sha256 = "0bzyv6qmnivxnv9nw7lnfn46k0m1dlxcjj53zcva6v8y8084l1iw"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ glib pcre ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + glib + pcre + ]; meta = { description = "Only backup program that doesn't make backups"; - homepage = "https://github.com/miekg/rdup"; - license = lib.licenses.gpl3; - platforms = lib.platforms.linux; + homepage = "https://github.com/miekg/rdup"; + license = lib.licenses.gpl3; + platforms = lib.platforms.linux; maintainers = with lib.maintainers; [ sternenseemann ]; }; } diff --git a/pkgs/by-name/rd/rdwatool/package.nix b/pkgs/by-name/rd/rdwatool/package.nix index 7ae9db0bfae767..5e783454a87f69 100644 --- a/pkgs/by-name/rd/rdwatool/package.nix +++ b/pkgs/by-name/rd/rdwatool/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/re/re-isearch/package.nix b/pkgs/by-name/re/re-isearch/package.nix index 45dbedcd466d3b..0789820c33e653 100644 --- a/pkgs/by-name/re/re-isearch/package.nix +++ b/pkgs/by-name/re/re-isearch/package.nix @@ -1,4 +1,11 @@ -{ stdenv, fetchFromGitHub, lib, db, file, libnsl }: +{ + stdenv, + fetchFromGitHub, + lib, + db, + file, + libnsl, +}: stdenv.mkDerivation rec { pname = "re-Isearch"; @@ -23,7 +30,9 @@ stdenv.mkDerivation rec { ]; makeFlags = [ - "CC=g++" "cc=gcc" "LD=g++" + "CC=g++" + "cc=gcc" + "LD=g++" "INSTALL=${placeholder "out"}/bin" ]; diff --git a/pkgs/by-name/re/re2c/package.nix b/pkgs/by-name/re/re2c/package.nix index f06a2b5424ef14..47a54d0060723d 100644 --- a/pkgs/by-name/re/re2c/package.nix +++ b/pkgs/by-name/re/re2c/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, nix-update-script -, python3 - -# for passthru.tests -, ninja -, php -, spamassassin +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + nix-update-script, + python3, + + # for passthru.tests + ninja, + php, + spamassassin, }: stdenv.mkDerivation rec { @@ -16,9 +17,9 @@ stdenv.mkDerivation rec { version = "3.1"; src = fetchFromGitHub { - owner = "skvadrik"; - repo = "re2c"; - rev = version; + owner = "skvadrik"; + repo = "re2c"; + rev = version; sha256 = "sha256-7zZdLby7HdNoURgdkg+xnlp6VDCACcyGCTtjM43OLd4="; }; @@ -37,7 +38,10 @@ stdenv.mkDerivation rec { passthru = { updateScript = nix-update-script { # Skip non-release tags like `python-experimental`. - extraArgs = [ "--version-regex" "([0-9.]+)" ]; + extraArgs = [ + "--version-regex" + "([0-9.]+)" + ]; }; tests = { inherit ninja php spamassassin; @@ -46,9 +50,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Tool for writing very fast and very flexible scanners"; - homepage = "https://re2c.org"; - license = licenses.publicDomain; - platforms = platforms.all; + homepage = "https://re2c.org"; + license = licenses.publicDomain; + platforms = platforms.all; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/re/react-native-debugger/package.nix b/pkgs/by-name/re/react-native-debugger/package.nix index 61d808e23c6db0..5540cf7cedba87 100644 --- a/pkgs/by-name/re/react-native-debugger/package.nix +++ b/pkgs/by-name/re/react-native-debugger/package.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchurl -, unzip -, cairo -, xorg -, gdk-pixbuf -, fontconfig -, pango -, atk -, at-spi2-atk -, at-spi2-core -, gtk3 -, glib -, freetype -, dbus -, nss -, nspr -, alsa-lib -, cups -, expat -, udev -, makeDesktopItem -, libdrm -, libxkbcommon -, mesa -, makeWrapper +{ + lib, + stdenv, + fetchurl, + unzip, + cairo, + xorg, + gdk-pixbuf, + fontconfig, + pango, + atk, + at-spi2-atk, + at-spi2-core, + gtk3, + glib, + freetype, + dbus, + nss, + nspr, + alsa-lib, + cups, + expat, + udev, + makeDesktopItem, + libdrm, + libxkbcommon, + mesa, + makeWrapper, }: let @@ -73,7 +74,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-RioBe0MAR47M84aavFaTJikGsJtcZDak8Tkg3WtX2l0="; }; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; buildCommand = '' shopt -s extglob mkdir -p $out @@ -102,7 +106,10 @@ stdenv.mkDerivation rec { exec = "react-native-debugger"; desktopName = "React Native Debugger"; genericName = "React Native Debugger"; - categories = [ "Development" "Debugger" ]; + categories = [ + "Development" + "Debugger" + ]; }; meta = with lib; { diff --git a/pkgs/by-name/re/react-static/package.nix b/pkgs/by-name/re/react-static/package.nix index 5307f93a4b4c8d..bf10eeb9494fe6 100644 --- a/pkgs/by-name/re/react-static/package.nix +++ b/pkgs/by-name/re/react-static/package.nix @@ -1,7 +1,8 @@ -{ lib -, mkYarnPackage -, fetchFromGitHub -, fetchYarnDeps +{ + lib, + mkYarnPackage, + fetchFromGitHub, + fetchYarnDeps, }: mkYarnPackage rec { diff --git a/pkgs/by-name/re/reaction/package.nix b/pkgs/by-name/re/reaction/package.nix index 3636131db83262..fb28bbd643eb60 100644 --- a/pkgs/by-name/re/reaction/package.nix +++ b/pkgs/by-name/re/reaction/package.nix @@ -5,7 +5,8 @@ }: let version = "1.4.1"; -in buildGoModule { +in +buildGoModule { inherit version; pname = "reaction"; @@ -39,7 +40,7 @@ in buildGoModule { changelog = "https://framagit.org/ppom/reaction/-/releases/v${version}"; license = licenses.agpl3Plus; mainProgram = "reaction"; - maintainers = with maintainers; [ppom]; + maintainers = with maintainers; [ ppom ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/re/reactphysics3d/package.nix b/pkgs/by-name/re/reactphysics3d/package.nix index 9ed933cf5e52b4..b91c49b1f5eec2 100644 --- a/pkgs/by-name/re/reactphysics3d/package.nix +++ b/pkgs/by-name/re/reactphysics3d/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation (finalAttrs: { pname = "reactphysics3d"; diff --git a/pkgs/by-name/re/read-edid/package.nix b/pkgs/by-name/re/read-edid/package.nix index 6e040d3cbffb87..09224699b0b87c 100644 --- a/pkgs/by-name/re/read-edid/package.nix +++ b/pkgs/by-name/re/read-edid/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, cmake, libx86 }: +{ + stdenv, + lib, + fetchurl, + cmake, + libx86, +}: stdenv.mkDerivation rec { pname = "read-edid"; @@ -20,7 +26,6 @@ stdenv.mkDerivation rec { cmakeFlags = [ "-DCLASSICBUILD=${if stdenv.hostPlatform.isx86 then "ON" else "OFF"}" ]; - meta = with lib; { description = "Tool for reading and parsing EDID data from monitors"; homepage = "http://www.polypux.org/projects/read-edid/"; diff --git a/pkgs/by-name/re/read-it-later/package.nix b/pkgs/by-name/re/read-it-later/package.nix index d25117c00b4c53..5c8e417841b147 100644 --- a/pkgs/by-name/re/read-it-later/package.nix +++ b/pkgs/by-name/re/read-it-later/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitLab -, rustPlatform -, meson -, ninja -, pkg-config -, rustc -, cargo -, wrapGAppsHook4 -, desktop-file-utils -, libxml2 -, libadwaita -, openssl -, libsoup_3 -, webkitgtk_6_0 -, sqlite +{ + lib, + stdenv, + fetchFromGitLab, + rustPlatform, + meson, + ninja, + pkg-config, + rustc, + cargo, + wrapGAppsHook4, + desktop-file-utils, + libxml2, + libadwaita, + openssl, + libsoup_3, + webkitgtk_6_0, + sqlite, }: stdenv.mkDerivation rec { @@ -44,7 +45,7 @@ stdenv.mkDerivation rec { cargo wrapGAppsHook4 desktop-file-utils - libxml2.bin #xmllint + libxml2.bin # xmllint ]; buildInputs = [ diff --git a/pkgs/by-name/re/readability-cli/package.nix b/pkgs/by-name/re/readability-cli/package.nix index aea915c73ef4e0..8dd2190a180ad3 100644 --- a/pkgs/by-name/re/readability-cli/package.nix +++ b/pkgs/by-name/re/readability-cli/package.nix @@ -1,4 +1,9 @@ -{ lib, buildNpmPackage, fetchFromGitLab, installShellFiles }: +{ + lib, + buildNpmPackage, + fetchFromGitLab, + installShellFiles, +}: buildNpmPackage rec { pname = "readability-cli"; diff --git a/pkgs/by-name/re/readability-extractor/package.nix b/pkgs/by-name/re/readability-extractor/package.nix index 56a317c991f959..ee0a81678dd592 100644 --- a/pkgs/by-name/re/readability-extractor/package.nix +++ b/pkgs/by-name/re/readability-extractor/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/re/readarr/package.nix b/pkgs/by-name/re/readarr/package.nix index c95ef654703bd9..b7d34a7e366233 100644 --- a/pkgs/by-name/re/readarr/package.nix +++ b/pkgs/by-name/re/readarr/package.nix @@ -1,18 +1,36 @@ -{ lib, stdenv, fetchurl, libmediainfo, sqlite, curl, makeWrapper, icu, dotnet-runtime, openssl, nixosTests, zlib }: +{ + lib, + stdenv, + fetchurl, + libmediainfo, + sqlite, + curl, + makeWrapper, + icu, + dotnet-runtime, + openssl, + nixosTests, + zlib, +}: let os = if stdenv.hostPlatform.isDarwin then "osx" else "linux"; - arch = { - x86_64-linux = "x64"; - aarch64-linux = "arm64"; - x86_64-darwin = "x64"; - }."${stdenv.hostPlatform.system}" or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); - hash = { - x64-linux_hash = "sha256-48ZlBTr/lO1AAsYInu48fDB77RXH+b2hXjDPwWdeZW4="; - arm64-linux_hash = "sha256-vyNoI1ffqWyYCfH+3rRNtaECkku3pF3pD+2RBchD+6o="; - x64-osx_hash = "sha256-VeGq+kVuBLGqERcWyvPfcygAG0/262J9/RPr49X4jtE="; - }."${arch}-${os}_hash"; -in stdenv.mkDerivation rec { + arch = + { + x86_64-linux = "x64"; + aarch64-linux = "arm64"; + x86_64-darwin = "x64"; + } + ."${stdenv.hostPlatform.system}" or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + hash = + { + x64-linux_hash = "sha256-48ZlBTr/lO1AAsYInu48fDB77RXH+b2hXjDPwWdeZW4="; + arm64-linux_hash = "sha256-vyNoI1ffqWyYCfH+3rRNtaECkku3pF3pD+2RBchD+6o="; + x64-osx_hash = "sha256-VeGq+kVuBLGqERcWyvPfcygAG0/262J9/RPr49X4jtE="; + } + ."${arch}-${os}_hash"; +in +stdenv.mkDerivation rec { pname = "readarr"; version = "0.4.4.2686"; @@ -30,12 +48,20 @@ in stdenv.mkDerivation rec { cp -r * $out/share/${pname}-${version}/. makeWrapper "${dotnet-runtime}/bin/dotnet" $out/bin/Readarr \ --add-flags "$out/share/${pname}-${version}/Readarr.dll" \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ curl sqlite libmediainfo icu openssl zlib ]} + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + curl + sqlite + libmediainfo + icu + openssl + zlib + ] + } runHook postInstall ''; - passthru = { updateScript = ./update.sh; tests.smoke-test = nixosTests.readarr; @@ -45,10 +71,16 @@ in stdenv.mkDerivation rec { description = "Usenet/BitTorrent ebook downloader"; homepage = "https://readarr.com"; license = lib.licenses.gpl3; - maintainers = with lib.maintainers; [ jocelynthode devusb ]; + maintainers = with lib.maintainers; [ + jocelynthode + devusb + ]; mainProgram = "Readarr"; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + ]; }; } - diff --git a/pkgs/by-name/re/readosm/package.nix b/pkgs/by-name/re/readosm/package.nix index 0f746c36483c66..a97e21d8f4efb0 100644 --- a/pkgs/by-name/re/readosm/package.nix +++ b/pkgs/by-name/re/readosm/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, expat, zlib, validatePkgConfig }: +{ + lib, + stdenv, + fetchurl, + expat, + zlib, + validatePkgConfig, +}: stdenv.mkDerivation rec { pname = "readosm"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ validatePkgConfig ]; - buildInputs = [ expat zlib ]; + buildInputs = [ + expat + zlib + ]; enableParallelBuilding = true; @@ -20,7 +30,11 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Open source library to extract valid data from within an Open Street Map input file"; homepage = "https://www.gaia-gis.it/fossil/readosm"; - license = with licenses; [ mpl11 gpl2Plus lgpl21Plus ]; + license = with licenses; [ + mpl11 + gpl2Plus + lgpl21Plus + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/re/readstat/package.nix b/pkgs/by-name/re/readstat/package.nix index 6abae18c5c66a5..627788996e82bb 100644 --- a/pkgs/by-name/re/readstat/package.nix +++ b/pkgs/by-name/re/readstat/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, pkg-config, libiconv }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + libiconv, +}: stdenv.mkDerivation rec { pname = "readstat"; @@ -25,7 +33,10 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; buildInputs = [ libiconv ]; diff --git a/pkgs/by-name/re/ready-check/package.nix b/pkgs/by-name/re/ready-check/package.nix index 84dcc83454a78d..7eca87bf957a92 100644 --- a/pkgs/by-name/re/ready-check/package.nix +++ b/pkgs/by-name/re/ready-check/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/re/real_time_config_quick_scan/package.nix b/pkgs/by-name/re/real_time_config_quick_scan/package.nix index 8bc2553f521b04..250880231b79a9 100644 --- a/pkgs/by-name/re/real_time_config_quick_scan/package.nix +++ b/pkgs/by-name/re/real_time_config_quick_scan/package.nix @@ -1,13 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, perlPackages, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + perlPackages, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "realTimeConfigQuickScan"; version = "unstable-2020-07-23"; src = fetchFromGitHub { - owner = "raboof"; - repo = pname; - rev = "4697ba093d43d512b74a73b89531cb8c5adaa274"; + owner = "raboof"; + repo = pname; + rev = "4697ba093d43d512b74a73b89531cb8c5adaa274"; sha256 = "16kanzp5i353x972zjkwgi3m8z90wc58613mlfzb0n01djdnm6k5"; }; @@ -47,7 +53,6 @@ stdenv.mkDerivation rec { homepage = "https://github.com/raboof/realtimeconfigquickscan"; license = licenses.gpl2Plus; maintainers = with maintainers; [ magnetophon ]; - platforms = platforms.linux ; + platforms = platforms.linux; }; } - diff --git a/pkgs/by-name/re/realesrgan-ncnn-vulkan/package.nix b/pkgs/by-name/re/realesrgan-ncnn-vulkan/package.nix index 450e36e6d3ee83..6e0cd13ee84e91 100644 --- a/pkgs/by-name/re/realesrgan-ncnn-vulkan/package.nix +++ b/pkgs/by-name/re/realesrgan-ncnn-vulkan/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchzip -, fetchFromGitHub -, cmake -, vulkan-headers -, vulkan-loader -, glslang -, libwebp -, ncnn +{ + lib, + stdenv, + fetchzip, + fetchFromGitHub, + cmake, + vulkan-headers, + vulkan-loader, + glslang, + libwebp, + ncnn, }: stdenv.mkDerivation rec { @@ -42,7 +43,13 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ vulkan-headers vulkan-loader glslang libwebp ncnn ]; + buildInputs = [ + vulkan-headers + vulkan-loader + glslang + libwebp + ncnn + ]; postPatch = '' substituteInPlace main.cpp --replace REPLACE_MODELS $out/share/models @@ -63,7 +70,10 @@ stdenv.mkDerivation rec { description = "NCNN implementation of Real-ESRGAN. Real-ESRGAN aims at developing Practical Algorithms for General Image Restoration"; homepage = "https://github.com/xinntao/Real-ESRGAN-ncnn-vulkan"; license = licenses.mit; - maintainers = with maintainers; [ tilcreator iynaix ]; + maintainers = with maintainers; [ + tilcreator + iynaix + ]; platforms = platforms.all; mainProgram = "realesrgan-ncnn-vulkan"; }; diff --git a/pkgs/by-name/re/realm/package.nix b/pkgs/by-name/re/realm/package.nix index 34914df2987e3d..efe93beb7713aa 100644 --- a/pkgs/by-name/re/realm/package.nix +++ b/pkgs/by-name/re/realm/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin -, nix-update-script -, nixosTests +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, + nix-update-script, + nixosTests, }: rustPlatform.buildRustPackage rec { @@ -31,7 +32,6 @@ rustPlatform.buildRustPackage rec { tests = { inherit (nixosTests) realm; }; }; - meta = with lib; { description = "A simple, high performance relay server written in rust"; homepage = "https://github.com/zhboner/realm"; diff --git a/pkgs/by-name/re/realvnc-vnc-viewer/darwin.nix b/pkgs/by-name/re/realvnc-vnc-viewer/darwin.nix index bde3c440f4ea2a..34dad92842bbeb 100644 --- a/pkgs/by-name/re/realvnc-vnc-viewer/darwin.nix +++ b/pkgs/by-name/re/realvnc-vnc-viewer/darwin.nix @@ -1,17 +1,18 @@ -{ stdenvNoCC -, fetchurl -, undmg -, pname -, version -, meta +{ + stdenvNoCC, + fetchurl, + undmg, + pname, + version, + meta, }: stdenvNoCC.mkDerivation (finalAttrs: { inherit pname version meta; src = fetchurl rec { - name = "VNC-Viewer-${finalAttrs.version}-MacOSX-universal.dmg"; - url = "https://downloads.realvnc.com/download/file/viewer.files/${name}"; - hash = "sha256-SiBlw9ihKDLDWBPUxn3cfM0jbUaWDxQ9JDaeDNczQ7c="; + name = "VNC-Viewer-${finalAttrs.version}-MacOSX-universal.dmg"; + url = "https://downloads.realvnc.com/download/file/viewer.files/${name}"; + hash = "sha256-SiBlw9ihKDLDWBPUxn3cfM0jbUaWDxQ9JDaeDNczQ7c="; }; sourceRoot = "."; diff --git a/pkgs/by-name/re/realvnc-vnc-viewer/linux.nix b/pkgs/by-name/re/realvnc-vnc-viewer/linux.nix index 9be2308705c922..87152c4da86c07 100644 --- a/pkgs/by-name/re/realvnc-vnc-viewer/linux.nix +++ b/pkgs/by-name/re/realvnc-vnc-viewer/linux.nix @@ -1,27 +1,37 @@ -{ stdenv -, fetchurl -, autoPatchelfHook -, rpmextract -, libX11 -, libXext -, pname -, version -, meta +{ + stdenv, + fetchurl, + autoPatchelfHook, + rpmextract, + libX11, + libXext, + pname, + version, + meta, }: stdenv.mkDerivation (finalAttrs: { inherit pname version; - src = { - "x86_64-linux" = fetchurl rec { - name = "VNC-Viewer-${finalAttrs.version}-Linux-x64.rpm"; - url = "https://downloads.realvnc.com/download/file/viewer.files/${name}"; - hash = "sha256-fwMfQdOyLnYVfdBj80JHWT+CnKpq/9oM5oNF3aP+jgo="; - }; - }.${stdenv.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); - - nativeBuildInputs = [ autoPatchelfHook rpmextract ]; - buildInputs = [ libX11 libXext stdenv.cc.cc.libgcc or null ]; + src = + { + "x86_64-linux" = fetchurl rec { + name = "VNC-Viewer-${finalAttrs.version}-Linux-x64.rpm"; + url = "https://downloads.realvnc.com/download/file/viewer.files/${name}"; + hash = "sha256-fwMfQdOyLnYVfdBj80JHWT+CnKpq/9oM5oNF3aP+jgo="; + }; + } + .${stdenv.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + + nativeBuildInputs = [ + autoPatchelfHook + rpmextract + ]; + buildInputs = [ + libX11 + libXext + stdenv.cc.cc.libgcc or null + ]; unpackPhase = '' rpmextract $src @@ -42,5 +52,7 @@ stdenv.mkDerivation (finalAttrs: { runHook postInstall ''; - meta = meta // { mainProgram = "vncviewer"; }; + meta = meta // { + mainProgram = "vncviewer"; + }; }) diff --git a/pkgs/by-name/re/realvnc-vnc-viewer/package.nix b/pkgs/by-name/re/realvnc-vnc-viewer/package.nix index b25f227eff19a2..5c769651e219e4 100644 --- a/pkgs/by-name/re/realvnc-vnc-viewer/package.nix +++ b/pkgs/by-name/re/realvnc-vnc-viewer/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, callPackage +{ + lib, + stdenv, + callPackage, }: let pname = "realvnc-vnc-viewer"; @@ -15,10 +16,15 @@ let url = "https://static.realvnc.com/media/documents/LICENSE-4.0a_en.pdf"; free = false; }; - maintainers = with lib.maintainers; [ emilytrau onedragon ]; + maintainers = with lib.maintainers; [ + emilytrau + onedragon + ]; platforms = [ "x86_64-linux" ] ++ lib.platforms.darwin; mainProgram = "vncviewer"; }; in -if stdenv.hostPlatform.isDarwin then callPackage ./darwin.nix { inherit pname version meta; } -else callPackage ./linux.nix { inherit pname version meta; } +if stdenv.hostPlatform.isDarwin then + callPackage ./darwin.nix { inherit pname version meta; } +else + callPackage ./linux.nix { inherit pname version meta; } diff --git a/pkgs/by-name/re/reap/package.nix b/pkgs/by-name/re/reap/package.nix index f8ba9fa6b0ec4f..4dfe7e175ea15e 100644 --- a/pkgs/by-name/re/reap/package.nix +++ b/pkgs/by-name/re/reap/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "reap"; diff --git a/pkgs/by-name/re/reason-shell/package.nix b/pkgs/by-name/re/reason-shell/package.nix index 015b5c97ebf31a..a5bedae0d98b94 100644 --- a/pkgs/by-name/re/reason-shell/package.nix +++ b/pkgs/by-name/re/reason-shell/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -24,11 +25,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreServices - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreServices + ]; meta = with lib; { description = "Shell for research papers"; diff --git a/pkgs/by-name/re/reaverwps-t6x/package.nix b/pkgs/by-name/re/reaverwps-t6x/package.nix index 83479a6d88ed3e..880d33b773d41e 100644 --- a/pkgs/by-name/re/reaverwps-t6x/package.nix +++ b/pkgs/by-name/re/reaverwps-t6x/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, libpcap, pixiewps, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + libpcap, + pixiewps, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "reaver-wps-t6x"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ libpcap pixiewps ]; + buildInputs = [ + libpcap + pixiewps + ]; sourceRoot = "${src.name}/src"; diff --git a/pkgs/by-name/re/reaverwps/package.nix b/pkgs/by-name/re/reaverwps/package.nix index 050cadf3ed6415..ee4e491d72198d 100644 --- a/pkgs/by-name/re/reaverwps/package.nix +++ b/pkgs/by-name/re/reaverwps/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, libpcap, sqlite, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + libpcap, + sqlite, + makeWrapper, +}: stdenv.mkDerivation rec { version = "1.4"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ libpcap sqlite ]; + buildInputs = [ + libpcap + sqlite + ]; # Workaround build failure on -fno-common toolchains: # ld: crypto/dh_groups.o:src/crypto/../globule.h:141: multiple definition of diff --git a/pkgs/by-name/re/recapp/package.nix b/pkgs/by-name/re/recapp/package.nix index b6cb8c6377bbac..0852d24fba54c9 100644 --- a/pkgs/by-name/re/recapp/package.nix +++ b/pkgs/by-name/re/recapp/package.nix @@ -1,20 +1,21 @@ -{ lib -, python3 -, fetchFromGitHub -, appstream-glib -, desktop-file-utils -, gettext -, glib -, gobject-introspection -, gtk3 -, gst_all_1 -, libnotify -, librsvg -, meson -, ninja -, pkg-config -, slop -, wrapGAppsHook3 +{ + lib, + python3, + fetchFromGitHub, + appstream-glib, + desktop-file-utils, + gettext, + glib, + gobject-introspection, + gtk3, + gst_all_1, + libnotify, + librsvg, + meson, + ninja, + pkg-config, + slop, + wrapGAppsHook3, }: python3.pkgs.buildPythonApplication rec { @@ -68,7 +69,12 @@ python3.pkgs.buildPythonApplication rec { preFixup = '' makeWrapperArgs+=( "''${gappsWrapperArgs[@]}" - "--prefix" "PATH" ":" "${lib.makeBinPath [ gst_all_1.gstreamer.dev slop ]}" + "--prefix" "PATH" ":" "${ + lib.makeBinPath [ + gst_all_1.gstreamer.dev + slop + ] + }" ) ''; diff --git a/pkgs/by-name/re/recastnavigation/package.nix b/pkgs/by-name/re/recastnavigation/package.nix index b4119f1133f5fc..ef5f55978adf93 100644 --- a/pkgs/by-name/re/recastnavigation/package.nix +++ b/pkgs/by-name/re/recastnavigation/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchFromGitHub, cmake, libGL, SDL2, libGLU, catch }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + libGL, + SDL2, + libGLU, + catch, +}: stdenv.mkDerivation rec { pname = "recastai"; @@ -13,25 +22,31 @@ stdenv.mkDerivation rec { sha256 = "sha256-WVzDI7+UuAl10Tm1Zjkea/FMk0cIe7pWg0iyFLbwAdI="; }; - postPatch = '' - cp ${catch}/include/catch/catch.hpp Tests/catch.hpp - - # https://github.com/recastnavigation/recastnavigation/issues/524 - substituteInPlace CMakeLists.txt \ - --replace '\$'{exec_prefix}/'$'{CMAKE_INSTALL_LIBDIR} '$'{CMAKE_INSTALL_FULL_LIBDIR} \ - --replace '\$'{prefix}/'$'{CMAKE_INSTALL_INCLUDEDIR} '$'{CMAKE_INSTALL_FULL_INCLUDEDIR} - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Expects SDL2.framework in specific location, which we don't have - # Change where SDL2 headers are searched for to match what we do have - substituteInPlace RecastDemo/CMakeLists.txt \ - --replace 'include_directories(''${SDL2_LIBRARY}/Headers)' 'include_directories(${SDL2.dev}/include/SDL2)' - ''; + postPatch = + '' + cp ${catch}/include/catch/catch.hpp Tests/catch.hpp + + # https://github.com/recastnavigation/recastnavigation/issues/524 + substituteInPlace CMakeLists.txt \ + --replace '\$'{exec_prefix}/'$'{CMAKE_INSTALL_LIBDIR} '$'{CMAKE_INSTALL_FULL_LIBDIR} \ + --replace '\$'{prefix}/'$'{CMAKE_INSTALL_INCLUDEDIR} '$'{CMAKE_INSTALL_FULL_INCLUDEDIR} + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Expects SDL2.framework in specific location, which we don't have + # Change where SDL2 headers are searched for to match what we do have + substituteInPlace RecastDemo/CMakeLists.txt \ + --replace 'include_directories(''${SDL2_LIBRARY}/Headers)' 'include_directories(${SDL2.dev}/include/SDL2)' + ''; doCheck = true; nativeBuildInputs = [ cmake ]; - buildInputs = [ libGL SDL2 libGLU ]; + buildInputs = [ + libGL + SDL2 + libGLU + ]; meta = with lib; { homepage = "https://github.com/recastnavigation/recastnavigation"; diff --git a/pkgs/by-name/re/recode/package.nix b/pkgs/by-name/re/recode/package.nix index 0ded5eea09cd26..1e96a4b6e2cedb 100644 --- a/pkgs/by-name/re/recode/package.nix +++ b/pkgs/by-name/re/recode/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, python3Packages -, flex -, texinfo -, libiconv -, libintl +{ + lib, + stdenv, + fetchurl, + python3Packages, + flex, + texinfo, + libiconv, + libintl, }: stdenv.mkDerivation (finalAttrs: { @@ -18,7 +19,12 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-eGqv1USFGisTsKN36sFQD4IM5iYVzMLmMLUB53Q7nzM="; }; - nativeBuildInputs = [ python3Packages.python flex texinfo libiconv ]; + nativeBuildInputs = [ + python3Packages.python + flex + texinfo + libiconv + ]; buildInputs = [ libintl ]; @@ -37,7 +43,10 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "recode"; changelog = "https://github.com/rrthomas/recode/raw/v${finalAttrs.version}/NEWS"; platforms = lib.platforms.unix; - license = with lib.licenses; [ lgpl3Plus gpl3Plus ]; + license = with lib.licenses; [ + lgpl3Plus + gpl3Plus + ]; maintainers = with lib.maintainers; [ jcumming ]; }; }) diff --git a/pkgs/by-name/re/recoverdm/package.nix b/pkgs/by-name/re/recoverdm/package.nix index d5e4aeb7fc0d80..9a244bd15ac12b 100644 --- a/pkgs/by-name/re/recoverdm/package.nix +++ b/pkgs/by-name/re/recoverdm/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitLab -, installShellFiles +{ + lib, + stdenv, + fetchFromGitLab, + installShellFiles, }: stdenv.mkDerivation (finalAttrs: { @@ -16,13 +17,17 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-1iW3Ug85ZLGpvG29N5zJt8oooSQGnLsr+8XIcp4aSSM="; }; - patches = let patch = name: "./debian/patches/${name}"; in [ - (patch "10_fix-makefile.patch") - (patch "20_fix-typo-binary.patch") - (patch "30-fix-BTS-mergebad-crash.patch") - (patch "40_dev-c.patch") - ./0001-darwin-build-fixes.patch - ]; + patches = + let + patch = name: "./debian/patches/${name}"; + in + [ + (patch "10_fix-makefile.patch") + (patch "20_fix-typo-binary.patch") + (patch "30-fix-BTS-mergebad-crash.patch") + (patch "40_dev-c.patch") + ./0001-darwin-build-fixes.patch + ]; postPatch = '' substituteInPlace Makefile \ diff --git a/pkgs/by-name/re/recoverjpeg/package.nix b/pkgs/by-name/re/recoverjpeg/package.nix index b49c6dd7dad1e3..a4b28e3bc834e3 100644 --- a/pkgs/by-name/re/recoverjpeg/package.nix +++ b/pkgs/by-name/re/recoverjpeg/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeWrapper, python3, exif, imagemagick }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + python3, + exif, + imagemagick, +}: stdenv.mkDerivation rec { pname = "recoverjpeg"; @@ -15,7 +23,12 @@ stdenv.mkDerivation rec { postFixup = '' wrapProgram $out/bin/sort-pictures \ - --prefix PATH : ${lib.makeBinPath [ exif imagemagick ]} + --prefix PATH : ${ + lib.makeBinPath [ + exif + imagemagick + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/re/recursive/package.nix b/pkgs/by-name/re/recursive/package.nix index c01bd294ea374f..4327759425c86b 100644 --- a/pkgs/by-name/re/recursive/package.nix +++ b/pkgs/by-name/re/recursive/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchzip, stdenvNoCC }: +{ + lib, + fetchzip, + stdenvNoCC, +}: stdenvNoCC.mkDerivation rec { pname = "recursive"; @@ -14,7 +18,6 @@ stdenvNoCC.mkDerivation rec { install -D -t $out/share/fonts/truetype/ $(find $src -type f -name '*.ttf') ''; - meta = with lib; { homepage = "https://recursive.design/"; description = "Variable font family for code & UI"; diff --git a/pkgs/by-name/re/recutils/package.nix b/pkgs/by-name/re/recutils/package.nix index 61f6f60def0429..de1a79649fc14e 100644 --- a/pkgs/by-name/re/recutils/package.nix +++ b/pkgs/by-name/re/recutils/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, bc -, check -, curl +{ + lib, + stdenv, + fetchurl, + bc, + check, + curl, -, withEncryption ? true -, libgcrypt -, libgpg-error + withEncryption ? true, + libgcrypt, + libgpg-error, -, withUuid ? true -, libuuid + withUuid ? true, + libuuid, -, withBashBuiltins ? true -, bash + withBashBuiltins ? true, + bash, }: stdenv.mkDerivation rec { @@ -27,22 +28,25 @@ stdenv.mkDerivation rec { hardeningDisable = lib.optional stdenv.cc.isClang "format"; - configureFlags = - lib.optionals withBashBuiltins [ - "--with-bash-headers=${bash.dev}/include/bash" - ]; - - buildInputs = [ - curl - ] ++ lib.optionals withEncryption [ - libgpg-error.dev - libgcrypt.dev - ] ++ lib.optionals withUuid [ - libuuid - ] ++ lib.optionals withBashBuiltins [ - bash.dev + configureFlags = lib.optionals withBashBuiltins [ + "--with-bash-headers=${bash.dev}/include/bash" ]; + buildInputs = + [ + curl + ] + ++ lib.optionals withEncryption [ + libgpg-error.dev + libgcrypt.dev + ] + ++ lib.optionals withUuid [ + libuuid + ] + ++ lib.optionals withBashBuiltins [ + bash.dev + ]; + nativeCheckInputs = [ bc check diff --git a/pkgs/by-name/re/red/package.nix b/pkgs/by-name/re/red/package.nix index 676ecb721cc412..38b84f4f16995c 100644 --- a/pkgs/by-name/re/red/package.nix +++ b/pkgs/by-name/re/red/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, stdenv_32bit, pkgsi686Linux, fetchFromGitHub, fetchurl }: +{ + lib, + stdenv, + stdenv_32bit, + pkgsi686Linux, + fetchFromGitHub, + fetchurl, +}: stdenv.mkDerivation rec { pname = "red"; @@ -15,7 +22,10 @@ stdenv.mkDerivation rec { sha256 = "1c1v0pyhf3d8z98qc93a5zmx0bbl0qq5lr8mbkdgygqsq2bv2xbz"; }; - buildInputs = [ pkgsi686Linux.curl stdenv_32bit ]; + buildInputs = [ + pkgsi686Linux.curl + stdenv_32bit + ]; r2 = "./rebol/releases/rebol-core/rebol"; @@ -86,7 +96,10 @@ stdenv.mkDerivation rec { ''; mainProgram = "red"; maintainers = with maintainers; [ uralbash ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; license = licenses.bsd3; homepage = "https://www.red-lang.org/"; }; diff --git a/pkgs/by-name/re/redeclipse/package.nix b/pkgs/by-name/re/redeclipse/package.nix index 28c112fba3531f..1bb741380b4588 100644 --- a/pkgs/by-name/re/redeclipse/package.nix +++ b/pkgs/by-name/re/redeclipse/package.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchurl -, curl, ed, pkg-config, freetype, zlib, libX11 -, SDL2, SDL2_image, SDL2_mixer +{ + lib, + stdenv, + fetchurl, + curl, + ed, + pkg-config, + freetype, + zlib, + libX11, + SDL2, + SDL2_image, + SDL2_mixer, }: stdenv.mkDerivation rec { @@ -13,22 +23,32 @@ stdenv.mkDerivation rec { }; buildInputs = [ - libX11 freetype zlib - SDL2 SDL2_image SDL2_mixer + libX11 + freetype + zlib + SDL2 + SDL2_image + SDL2_mixer ]; nativeBuildInputs = [ - curl ed pkg-config + curl + ed + pkg-config ]; - makeFlags = [ "-C" "src/" "prefix=$(out)" ]; + makeFlags = [ + "-C" + "src/" + "prefix=$(out)" + ]; enableParallelBuilding = true; installTargets = [ "system-install" ]; postInstall = '' - cp -R -t $out/share/redeclipse/data/ data/* + cp -R -t $out/share/redeclipse/data/ data/* ''; meta = with lib; { @@ -40,9 +60,12 @@ stdenv.mkDerivation rec { environments. ''; homepage = "https://www.redeclipse.net"; - license = with licenses; [ licenses.zlib cc-by-sa-30 ]; + license = with licenses; [ + licenses.zlib + cc-by-sa-30 + ]; maintainers = with maintainers; [ lambda-11235 ]; platforms = platforms.linux; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/by-name/re/redfang/package.nix b/pkgs/by-name/re/redfang/package.nix index 776479d389a12b..a55d954d844489 100644 --- a/pkgs/by-name/re/redfang/package.nix +++ b/pkgs/by-name/re/redfang/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitLab, fetchpatch, bluez }: +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + bluez, +}: stdenv.mkDerivation rec { pname = "redfang"; diff --git a/pkgs/by-name/re/redfishtool/package.nix b/pkgs/by-name/re/redfishtool/package.nix index 020adb304479d0..c145f7823ea4a6 100644 --- a/pkgs/by-name/re/redfishtool/package.nix +++ b/pkgs/by-name/re/redfishtool/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchPypi -, python3 +{ + lib, + fetchPypi, + python3, }: let @@ -16,7 +17,10 @@ python3.pkgs.buildPythonApplication { hash = "sha256-X/G6osOHCBidKZG/Y2nmHadifDacJhjBIc7WYrUCPn8="; }; - propagatedBuildInputs = with python3.pkgs; [ requests python-dateutil ]; + propagatedBuildInputs = with python3.pkgs; [ + requests + python-dateutil + ]; meta = with lib; { description = "Python34 program that implements a command line tool for accessing the Redfish API"; diff --git a/pkgs/by-name/re/redhat-official-fonts/package.nix b/pkgs/by-name/re/redhat-official-fonts/package.nix index dcfe0c789b00c7..5460860d712c81 100644 --- a/pkgs/by-name/re/redhat-official-fonts/package.nix +++ b/pkgs/by-name/re/redhat-official-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "redhat-official"; diff --git a/pkgs/by-name/re/redict/package.nix b/pkgs/by-name/re/redict/package.nix index a916cfcd3ba7e7..81b11efd31b85d 100644 --- a/pkgs/by-name/re/redict/package.nix +++ b/pkgs/by-name/re/redict/package.nix @@ -1,13 +1,26 @@ -{ lib, stdenv, fetchFromGitea, fetchurl, lua, jemalloc, pkg-config, nixosTests -, tcl, which, ps, getconf -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, systemd -# dependency ordering is broken at the moment when building with openssl -, tlsSupport ? !stdenv.hostPlatform.isStatic, openssl - -# Using system jemalloc fixes cross-compilation and various setups. -# However the experimental 'active defragmentation' feature of redict requires -# their custom patched version of jemalloc. -, useSystemJemalloc ? true +{ + lib, + stdenv, + fetchFromGitea, + fetchurl, + lua, + jemalloc, + pkg-config, + nixosTests, + tcl, + which, + ps, + getconf, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + # dependency ordering is broken at the moment when building with openssl + tlsSupport ? !stdenv.hostPlatform.isStatic, + openssl, + + # Using system jemalloc fixes cross-compilation and various setups. + # However the experimental 'active defragmentation' feature of redict requires + # their custom patched version of jemalloc. + useSystemJemalloc ? true, }: stdenv.mkDerivation (finalAttrs: { @@ -32,7 +45,8 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ lua ] + buildInputs = + [ lua ] ++ lib.optional useSystemJemalloc jemalloc ++ lib.optional withSystemd systemd ++ lib.optionals tlsSupport [ openssl ]; @@ -42,8 +56,12 @@ stdenv.mkDerivation (finalAttrs: { ''; # More cross-compiling fixes. - makeFlags = [ "PREFIX=${placeholder "out"}" ] - ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ "AR=${stdenv.cc.targetPrefix}ar" "RANLIB=${stdenv.cc.targetPrefix}ranlib" ] + makeFlags = + [ "PREFIX=${placeholder "out"}" ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "AR=${stdenv.cc.targetPrefix}ar" + "RANLIB=${stdenv.cc.targetPrefix}ranlib" + ] ++ lib.optionals withSystemd [ "USE_SYSTEMD=yes" ] ++ lib.optionals tlsSupport [ "BUILD_TLS=yes" ]; @@ -55,7 +73,11 @@ stdenv.mkDerivation (finalAttrs: { # darwin currently lacks a pure `pgrep` which is extensively used here doCheck = !stdenv.hostPlatform.isDarwin; - nativeCheckInputs = [ which tcl ps ] ++ lib.optionals stdenv.hostPlatform.isStatic [ getconf ]; + nativeCheckInputs = [ + which + tcl + ps + ] ++ lib.optionals stdenv.hostPlatform.isStatic [ getconf ]; checkPhase = '' runHook preCheck diff --git a/pkgs/by-name/re/redir/package.nix b/pkgs/by-name/re/redir/package.nix index e92401c90f6d64..f69650db085e32 100644 --- a/pkgs/by-name/re/redir/package.nix +++ b/pkgs/by-name/re/redir/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "redir"; diff --git a/pkgs/by-name/re/redis-plus-plus/package.nix b/pkgs/by-name/re/redis-plus-plus/package.nix index e2ead013722839..656dd94c9249b4 100644 --- a/pkgs/by-name/re/redis-plus-plus/package.nix +++ b/pkgs/by-name/re/redis-plus-plus/package.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, hiredis -, enableShared ? !stdenv.hostPlatform.isStatic -, enableStatic ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + hiredis, + enableShared ? !stdenv.hostPlatform.isStatic, + enableStatic ? stdenv.hostPlatform.isStatic, }: # You must build at one type of library @@ -24,13 +29,16 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; propagatedBuildInputs = [ hiredis ]; - cmakeFlags = [ - "-DREDIS_PLUS_PLUS_BUILD_TEST=OFF" - ] ++ lib.optionals (!enableShared) [ - "-DREDIS_PLUS_PLUS_BUILD_SHARED=OFF" - ] ++ lib.optionals (!enableStatic) [ - "-DREDIS_PLUS_PLUS_BUILD_STATIC=OFF" - ]; + cmakeFlags = + [ + "-DREDIS_PLUS_PLUS_BUILD_TEST=OFF" + ] + ++ lib.optionals (!enableShared) [ + "-DREDIS_PLUS_PLUS_BUILD_SHARED=OFF" + ] + ++ lib.optionals (!enableStatic) [ + "-DREDIS_PLUS_PLUS_BUILD_STATIC=OFF" + ]; meta = with lib; { homepage = "https://github.com/sewenew/redis-plus-plus"; diff --git a/pkgs/by-name/re/redis/package.nix b/pkgs/by-name/re/redis/package.nix index b39d9258ae64f6..5e008b7d4d900d 100644 --- a/pkgs/by-name/re/redis/package.nix +++ b/pkgs/by-name/re/redis/package.nix @@ -1,13 +1,26 @@ -{ lib, stdenv, fetchurl, fetchpatch, lua, jemalloc, pkg-config, nixosTests -, tcl, which, ps, getconf -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, systemd -# dependency ordering is broken at the moment when building with openssl -, tlsSupport ? !stdenv.hostPlatform.isStatic, openssl - -# Using system jemalloc fixes cross-compilation and various setups. -# However the experimental 'active defragmentation' feature of redis requires -# their custom patched version of jemalloc. -, useSystemJemalloc ? true +{ + lib, + stdenv, + fetchurl, + fetchpatch, + lua, + jemalloc, + pkg-config, + nixosTests, + tcl, + which, + ps, + getconf, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + # dependency ordering is broken at the moment when building with openssl + tlsSupport ? !stdenv.hostPlatform.isStatic, + openssl, + + # Using system jemalloc fixes cross-compilation and various setups. + # However the experimental 'active defragmentation' feature of redis requires + # their custom patched version of jemalloc. + useSystemJemalloc ? true, }: stdenv.mkDerivation (finalAttrs: { @@ -19,24 +32,27 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-+xDWei/itFVvbLhABk3W5uMXXOjKA18HJpkOwtqfPQ4="; }; - patches = [ - # fixes: make test [exception]: Executing test client: permission denied - # https://github.com/redis/redis/issues/12792 - (fetchpatch { - url = "https://github.com/redis/redis/pull/12887.diff"; - hash = "sha256-VZEMShW7Ckn5hLJHffQvE94Uly41WZW1bwvxny+Y3W8="; - }) - ] ++ lib.optionals useSystemJemalloc [ - # use system jemalloc - (fetchurl { - url = "https://gitlab.archlinux.org/archlinux/packaging/packages/redis/-/raw/102cc861713c796756abd541bf341a4512eb06e6/redis-5.0-use-system-jemalloc.patch"; - hash = "sha256-VPRfoSnctkkkzLrXEWQX3Lh5HmZaCXoJafyOG007KzM="; - }) - ]; + patches = + [ + # fixes: make test [exception]: Executing test client: permission denied + # https://github.com/redis/redis/issues/12792 + (fetchpatch { + url = "https://github.com/redis/redis/pull/12887.diff"; + hash = "sha256-VZEMShW7Ckn5hLJHffQvE94Uly41WZW1bwvxny+Y3W8="; + }) + ] + ++ lib.optionals useSystemJemalloc [ + # use system jemalloc + (fetchurl { + url = "https://gitlab.archlinux.org/archlinux/packaging/packages/redis/-/raw/102cc861713c796756abd541bf341a4512eb06e6/redis-5.0-use-system-jemalloc.patch"; + hash = "sha256-VPRfoSnctkkkzLrXEWQX3Lh5HmZaCXoJafyOG007KzM="; + }) + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ lua ] + buildInputs = + [ lua ] ++ lib.optional useSystemJemalloc jemalloc ++ lib.optional withSystemd systemd ++ lib.optionals tlsSupport [ openssl ]; @@ -46,8 +62,12 @@ stdenv.mkDerivation (finalAttrs: { ''; # More cross-compiling fixes. - makeFlags = [ "PREFIX=${placeholder "out"}" ] - ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ "AR=${stdenv.cc.targetPrefix}ar" "RANLIB=${stdenv.cc.targetPrefix}ranlib" ] + makeFlags = + [ "PREFIX=${placeholder "out"}" ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "AR=${stdenv.cc.targetPrefix}ar" + "RANLIB=${stdenv.cc.targetPrefix}ranlib" + ] ++ lib.optionals withSystemd [ "USE_SYSTEMD=yes" ] ++ lib.optionals tlsSupport [ "BUILD_TLS=yes" ]; @@ -59,7 +79,11 @@ stdenv.mkDerivation (finalAttrs: { # darwin currently lacks a pure `pgrep` which is extensively used here doCheck = !stdenv.hostPlatform.isDarwin; - nativeCheckInputs = [ which tcl ps ] ++ lib.optionals stdenv.hostPlatform.isStatic [ getconf ]; + nativeCheckInputs = [ + which + tcl + ps + ] ++ lib.optionals stdenv.hostPlatform.isStatic [ getconf ]; checkPhase = '' runHook preCheck @@ -93,7 +117,10 @@ stdenv.mkDerivation (finalAttrs: { license = licenses.bsd3; platforms = platforms.all; changelog = "https://github.com/redis/redis/raw/${finalAttrs.version}/00-RELEASENOTES"; - maintainers = with maintainers; [ berdario globin ]; + maintainers = with maintainers; [ + berdario + globin + ]; mainProgram = "redis-cli"; }; }) diff --git a/pkgs/by-name/re/redka/package.nix b/pkgs/by-name/re/redka/package.nix index debc2180892aba..339353d9470fbb 100644 --- a/pkgs/by-name/re/redka/package.nix +++ b/pkgs/by-name/re/redka/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "redka"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-aX0X6TWVEouo884LunCt+UzLyvDHgmvuxdV0wh0r7Ro="; - subPackages = [ "cmd/redka" "cmd/cli" ]; + subPackages = [ + "cmd/redka" + "cmd/cli" + ]; ldflags = [ "-X main.version=v${version}" ]; diff --git a/pkgs/by-name/re/redli/package.nix b/pkgs/by-name/re/redli/package.nix index 07897de0397a23..84f717b610562c 100644 --- a/pkgs/by-name/re/redli/package.nix +++ b/pkgs/by-name/re/redli/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "redli"; diff --git a/pkgs/by-name/re/redo-apenwarr/package.nix b/pkgs/by-name/re/redo-apenwarr/package.nix index 22841cb20d174d..30a6feafbf131c 100644 --- a/pkgs/by-name/re/redo-apenwarr/package.nix +++ b/pkgs/by-name/re/redo-apenwarr/package.nix @@ -1,7 +1,16 @@ -{ stdenv, lib, python3, fetchFromGitHub, which, coreutils -, perl, installShellFiles, gnumake42 -, doCheck ? true -}: stdenv.mkDerivation rec { +{ + stdenv, + lib, + python3, + fetchFromGitHub, + which, + coreutils, + perl, + installShellFiles, + gnumake42, + doCheck ? true, +}: +stdenv.mkDerivation rec { pname = "redo-apenwarr"; version = "0.42d"; @@ -13,35 +22,40 @@ sha256 = "/QIMXpVhVLAIJa3LiOlRKzbUztIWZygkWZUKN4Nrh+M="; }; - postPatch = '' + postPatch = + '' - patchShebangs minimal/do + patchShebangs minimal/do - '' + lib.optionalString doCheck '' - unset CC CXX + '' + + lib.optionalString doCheck '' + unset CC CXX - substituteInPlace minimal/do.test \ - --replace "/bin/pwd" "${coreutils}/bin/pwd" + substituteInPlace minimal/do.test \ + --replace "/bin/pwd" "${coreutils}/bin/pwd" - substituteInPlace t/105-sympath/all.do \ - --replace "/bin/pwd" "${coreutils}/bin/pwd" + substituteInPlace t/105-sympath/all.do \ + --replace "/bin/pwd" "${coreutils}/bin/pwd" - substituteInPlace t/all.do \ - --replace "/bin/ls" "ls" + substituteInPlace t/all.do \ + --replace "/bin/ls" "ls" - substituteInPlace t/110-compile/hello.o.do \ - --replace "/usr/include" "${lib.getDev stdenv.cc.libc}/include" + substituteInPlace t/110-compile/hello.o.do \ + --replace "/usr/include" "${lib.getDev stdenv.cc.libc}/include" - substituteInPlace t/200-shell/nonshelltest.do \ - --replace "/usr/bin/env perl" "${perl}/bin/perl" + substituteInPlace t/200-shell/nonshelltest.do \ + --replace "/usr/bin/env perl" "${perl}/bin/perl" - ''; + ''; inherit doCheck; checkTarget = "test"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; installFlags = [ "PREFIX=$(out)" @@ -50,7 +64,10 @@ nativeBuildInputs = [ python3 - (with python3.pkgs; [ beautifulsoup4 markdown ]) + (with python3.pkgs; [ + beautifulsoup4 + markdown + ]) which installShellFiles gnumake42 # fails with make 4.4 diff --git a/pkgs/by-name/re/redo-c/package.nix b/pkgs/by-name/re/redo-c/package.nix index ffa93b0d7dcb58..f7588b18515f04 100644 --- a/pkgs/by-name/re/redo-c/package.nix +++ b/pkgs/by-name/re/redo-c/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "redo-c"; version = "0.3"; diff --git a/pkgs/by-name/re/redo-sh/package.nix b/pkgs/by-name/re/redo-sh/package.nix index 67dd66d8eeee18..9222bd0e6c7228 100644 --- a/pkgs/by-name/re/redo-sh/package.nix +++ b/pkgs/by-name/re/redo-sh/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, coreutils }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + coreutils, +}: stdenv.mkDerivation { version = "4.0.4"; @@ -24,7 +30,7 @@ stdenv.mkDerivation { meta = with lib; { description = "Redo implementation in Bourne Shell"; homepage = "http://news.dieweltistgarnichtso.net/bin/redo-sh.html"; - license = licenses.agpl3Plus; + license = licenses.agpl3Plus; platforms = platforms.unix; maintainers = with maintainers; [ sternenseemann ]; }; diff --git a/pkgs/by-name/re/redoc-cli/package.nix b/pkgs/by-name/re/redoc-cli/package.nix index de30e43d5eaf9d..15d3e4f84dad7d 100644 --- a/pkgs/by-name/re/redoc-cli/package.nix +++ b/pkgs/by-name/re/redoc-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/re/redocly/package.nix b/pkgs/by-name/re/redocly/package.nix index a0cf3d87c4bbbe..04a0d7f32bd1c7 100644 --- a/pkgs/by-name/re/redocly/package.nix +++ b/pkgs/by-name/re/redocly/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, makeWrapper -, redocly -, testers +{ + lib, + buildNpmPackage, + fetchFromGitHub, + makeWrapper, + redocly, + testers, }: buildNpmPackage rec { diff --git a/pkgs/by-name/re/redoflacs/package.nix b/pkgs/by-name/re/redoflacs/package.nix index 75425375f6af1b..3c9dd24957aa78 100644 --- a/pkgs/by-name/re/redoflacs/package.nix +++ b/pkgs/by-name/re/redoflacs/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, makeWrapper -, installShellFiles -, flac -, sox +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + installShellFiles, + flac, + sox, }: stdenv.mkDerivation rec { @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { dontBuild = true; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; installPhase = '' runHook preInstall @@ -34,7 +38,12 @@ stdenv.mkDerivation rec { postFixup = '' wrapProgram $out/bin/redoflacs \ - --prefix PATH : ${lib.makeBinPath ([ flac sox ])} + --prefix PATH : ${ + lib.makeBinPath ([ + flac + sox + ]) + } ''; meta = with lib; { diff --git a/pkgs/by-name/re/redpanda-client/package.nix b/pkgs/by-name/re/redpanda-client/package.nix index 3605ac2a0e6830..42947f04597d89 100644 --- a/pkgs/by-name/re/redpanda-client/package.nix +++ b/pkgs/by-name/re/redpanda-client/package.nix @@ -1,9 +1,10 @@ -{ buildGoModule -, doCheck ? !stdenv.hostPlatform.isDarwin # Can't start localhost test server in MacOS sandbox. -, fetchFromGitHub -, installShellFiles -, lib -, stdenv +{ + buildGoModule, + doCheck ? !stdenv.hostPlatform.isDarwin, # Can't start localhost test server in MacOS sandbox. + fetchFromGitHub, + installShellFiles, + lib, + stdenv, }: let version = "24.2.11"; @@ -40,7 +41,10 @@ buildGoModule rec { description = "Redpanda client"; homepage = "https://redpanda.com/"; license = licenses.bsl11; - maintainers = with maintainers; [ avakhrenev happysalada ]; + maintainers = with maintainers; [ + avakhrenev + happysalada + ]; platforms = platforms.all; mainProgram = "rpk"; }; diff --git a/pkgs/by-name/re/redprl/package.nix b/pkgs/by-name/re/redprl/package.nix index a6354a091665e7..fbe1b8051078ea 100644 --- a/pkgs/by-name/re/redprl/package.nix +++ b/pkgs/by-name/re/redprl/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, mlton }: +{ + lib, + stdenv, + fetchFromGitHub, + mlton, +}: stdenv.mkDerivation { pname = "redprl"; diff --git a/pkgs/by-name/re/redshift_jdbc/package.nix b/pkgs/by-name/re/redshift_jdbc/package.nix index ab15b136e14c98..98a73424f9ca1c 100644 --- a/pkgs/by-name/re/redshift_jdbc/package.nix +++ b/pkgs/by-name/re/redshift_jdbc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchMavenArtifact }: +{ + lib, + stdenv, + fetchMavenArtifact, +}: stdenv.mkDerivation rec { pname = "redshift-jdbc"; @@ -19,8 +23,7 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/aws/amazon-redshift-jdbc-driver/"; - description = - "JDBC 4.2 driver for Amazon Redshift allowing Java programs to connect to a Redshift database"; + description = "JDBC 4.2 driver for Amazon Redshift allowing Java programs to connect to a Redshift database"; license = licenses.asl20; platforms = platforms.unix; maintainers = with maintainers; [ sir4ur0n ]; diff --git a/pkgs/by-name/re/redsocks/package.nix b/pkgs/by-name/re/redsocks/package.nix index f97dd01e074d33..cc63ba8bd3d47d 100644 --- a/pkgs/by-name/re/redsocks/package.nix +++ b/pkgs/by-name/re/redsocks/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libevent }: +{ + lib, + stdenv, + fetchFromGitHub, + libevent, +}: stdenv.mkDerivation rec { pname = "redsocks"; @@ -11,12 +16,11 @@ stdenv.mkDerivation rec { sha256 = "170cpvvivb6y2kwsqj9ppx5brgds9gkn8mixrnvj8z9c15xhvplm"; }; - installPhase = - '' - mkdir -p $out/{bin,share} - mv redsocks $out/bin - mv doc $out/share - ''; + installPhase = '' + mkdir -p $out/{bin,share} + mv redsocks $out/bin + mv doc $out/share + ''; buildInputs = [ libevent ]; diff --git a/pkgs/by-name/re/redstore/package.nix b/pkgs/by-name/re/redstore/package.nix index 321f91770c7ccd..56f4b21ee8f61e 100644 --- a/pkgs/by-name/re/redstore/package.nix +++ b/pkgs/by-name/re/redstore/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchurl, redland, pkg-config, gmp, zlib, librdf_raptor2 - , librdf_rasqal }: +{ + lib, + stdenv, + fetchurl, + redland, + pkg-config, + gmp, + zlib, + librdf_raptor2, + librdf_rasqal, +}: stdenv.mkDerivation rec { pname = "redstore"; @@ -11,7 +20,13 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gmp redland zlib librdf_raptor2 librdf_rasqal ]; + buildInputs = [ + gmp + redland + zlib + librdf_raptor2 + librdf_rasqal + ]; preConfigure = '' # Define _XOPEN_SOURCE to enable, e.g., getaddrinfo. @@ -25,8 +40,7 @@ stdenv.mkDerivation rec { mainProgram = "redstore"; homepage = "https://www.aelius.com/njh/redstore/"; maintainers = [ lib.maintainers.raskin ]; - platforms = with lib.platforms; - linux ++ freebsd ++ gnu; + platforms = with lib.platforms; linux ++ freebsd ++ gnu; license = lib.licenses.gpl3Plus; }; } diff --git a/pkgs/by-name/re/redux/package.nix b/pkgs/by-name/re/redux/package.nix index 1ddf62dd2ca2d1..5c282338ec1d42 100644 --- a/pkgs/by-name/re/redux/package.nix +++ b/pkgs/by-name/re/redux/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, writeScript -, libX11 -, libXext -, alsa-lib -, autoPatchelfHook -, releasePath ? null +{ + lib, + stdenv, + fetchurl, + writeScript, + libX11, + libXext, + alsa-lib, + autoPatchelfHook, + releasePath ? null, }: # To use the full release version (same as renoise): @@ -19,14 +20,21 @@ stdenv.mkDerivation rec { pname = "redux"; version = "1.3.5"; - src = if releasePath != null then releasePath - else fetchurl { - urls = [ - "https://files.renoise.com/demo/Renoise_Redux_${lib.replaceStrings ["."] ["_"] version}_Demo_Linux_x86_64.tar.gz" - "https://files.renoise.com/demo/archive/Renoise_Redux_${lib.replaceStrings ["."] ["_"] version}_Demo_Linux_x86_64.tar.gz" - ]; - sha256 = "sha256-eznsdLzgdJ7MyWe5WAEg1MHId5VlfyanoZ6+I9nI/0I="; - }; + src = + if releasePath != null then + releasePath + else + fetchurl { + urls = [ + "https://files.renoise.com/demo/Renoise_Redux_${ + lib.replaceStrings [ "." ] [ "_" ] version + }_Demo_Linux_x86_64.tar.gz" + "https://files.renoise.com/demo/archive/Renoise_Redux_${ + lib.replaceStrings [ "." ] [ "_" ] version + }_Demo_Linux_x86_64.tar.gz" + ]; + sha256 = "sha256-eznsdLzgdJ7MyWe5WAEg1MHId5VlfyanoZ6+I9nI/0I="; + }; nativeBuildInputs = [ autoPatchelfHook @@ -49,7 +57,6 @@ stdenv.mkDerivation rec { runHook postInstall ''; - passthru.updateScript = writeScript "update-redux" '' #!/usr/bin/env nix-shell #!nix-shell -I nixpkgs=./. -i bash -p curl htmlq common-updater-scripts diff --git a/pkgs/by-name/re/refind/package.nix b/pkgs/by-name/re/refind/package.nix index 0b011096fdf19a..c9d351eaaae65b 100644 --- a/pkgs/by-name/re/refind/package.nix +++ b/pkgs/by-name/re/refind/package.nix @@ -1,25 +1,39 @@ -{ lib -, stdenv -, fetchurl -, gnu-efi -, nixosTests -, efibootmgr -, openssl -, withSbsigntool ? false # currently, cross compiling sbsigntool is broken, so default to false -, sbsigntool -, makeWrapper +{ + lib, + stdenv, + fetchurl, + gnu-efi, + nixosTests, + efibootmgr, + openssl, + withSbsigntool ? false, # currently, cross compiling sbsigntool is broken, so default to false + sbsigntool, + makeWrapper, }: let archids = { - x86_64-linux = { hostarch = "x86_64"; efiPlatform = "x64"; }; - i686-linux = rec { hostarch = "ia32"; efiPlatform = hostarch; }; - aarch64-linux = { hostarch = "aarch64"; efiPlatform = "aa64"; }; + x86_64-linux = { + hostarch = "x86_64"; + efiPlatform = "x64"; + }; + i686-linux = rec { + hostarch = "ia32"; + efiPlatform = hostarch; + }; + aarch64-linux = { + hostarch = "aarch64"; + efiPlatform = "aa64"; + }; }; inherit - (archids.${stdenv.hostPlatform.system} or (throw "unsupported system: ${stdenv.hostPlatform.system}")) - hostarch efiPlatform; + (archids.${stdenv.hostPlatform.system} + or (throw "unsupported system: ${stdenv.hostPlatform.system}") + ) + hostarch + efiPlatform + ; in stdenv.mkDerivation rec { @@ -45,19 +59,24 @@ stdenv.mkDerivation rec { hardeningDisable = [ "stackprotector" ]; makeFlags = - [ "prefix=" + [ + "prefix=" "EFIINC=${gnu-efi}/include/efi" "EFILIB=${gnu-efi}/lib" "GNUEFILIB=${gnu-efi}/lib" "EFICRT0=${gnu-efi}/lib" "HOSTARCH=${hostarch}" "ARCH=${hostarch}" - ] ++ lib.optional stdenv.hostPlatform.isAarch64 [ + ] + ++ lib.optional stdenv.hostPlatform.isAarch64 [ # aarch64 is special for GNU-EFI, see BUILDING.txt "GNUEFI_ARM64_TARGET_SUPPORT=y" ]; - buildFlags = [ "gnuefi" "fs_gnuefi" ]; + buildFlags = [ + "gnuefi" + "fs_gnuefi" + ]; installPhase = '' runHook preInstall @@ -119,7 +138,15 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/refind-install \ - --prefix PATH : ${lib.makeBinPath ( [ efibootmgr openssl ] ++ lib.optional withSbsigntool sbsigntool )} + --prefix PATH : ${ + lib.makeBinPath ( + [ + efibootmgr + openssl + ] + ++ lib.optional withSbsigntool sbsigntool + ) + } wrapProgram $out/bin/refind-mvrefind \ --prefix PATH : ${lib.makeBinPath [ efibootmgr ]} ''; @@ -147,7 +174,11 @@ stdenv.mkDerivation rec { ''; homepage = "http://refind.sourceforge.net/"; maintainers = with maintainers; [ chewblacka ]; - platforms = [ "i686-linux" "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + "aarch64-linux" + ]; license = licenses.gpl3Plus; }; diff --git a/pkgs/by-name/re/refinery-cli/package.nix b/pkgs/by-name/re/refinery-cli/package.nix index 59a5dd255ba693..5c366be4ab1e98 100644 --- a/pkgs/by-name/re/refinery-cli/package.nix +++ b/pkgs/by-name/re/refinery-cli/package.nix @@ -1,4 +1,12 @@ -{ fetchCrate, lib, stdenv, openssl, pkg-config, rustPlatform, darwin }: +{ + fetchCrate, + lib, + stdenv, + openssl, + pkg-config, + rustPlatform, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "refinery-cli"; @@ -14,8 +22,9 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; + buildInputs = [ + openssl + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; meta = with lib; { description = "Run migrations for the Refinery ORM for Rust via the CLI"; diff --git a/pkgs/by-name/re/reflex/package.nix b/pkgs/by-name/re/reflex/package.nix index 0c536d21142170..36c9487c65161e 100644 --- a/pkgs/by-name/re/reflex/package.nix +++ b/pkgs/by-name/re/reflex/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "reflex"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-JCtVYDHbhH2i7tGNK1jvgHCjU6gMMkNhQ2ZnlTeqtmA="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Small tool to watch a directory and rerun a command when certain files change"; diff --git a/pkgs/by-name/re/refmt/package.nix b/pkgs/by-name/re/refmt/package.nix index 5946e75f3f20fe..74ae4397f4f55a 100644 --- a/pkgs/by-name/re/refmt/package.nix +++ b/pkgs/by-name/re/refmt/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "refmt"; diff --git a/pkgs/by-name/re/reftools/package.nix b/pkgs/by-name/re/reftools/package.nix index 151f1accccf20f..bb41cfea37a7ac 100644 --- a/pkgs/by-name/re/reftools/package.nix +++ b/pkgs/by-name/re/reftools/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, lib -, fetchFromGitHub +{ + buildGoModule, + lib, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/re/refurb/package.nix b/pkgs/by-name/re/refurb/package.nix index 275039b601a307..f9ca563951b593 100644 --- a/pkgs/by-name/re/refurb/package.nix +++ b/pkgs/by-name/re/refurb/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3Packages +{ + lib, + fetchFromGitHub, + python3Packages, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/re/reg/package.nix b/pkgs/by-name/re/reg/package.nix index 545b208035b3c2..9669e621aab08a 100644 --- a/pkgs/by-name/re/reg/package.nix +++ b/pkgs/by-name/re/reg/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchpatch -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchpatch, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { diff --git a/pkgs/by-name/re/regal/package.nix b/pkgs/by-name/re/regal/package.nix index 90a037f87397f5..bb6aa6b32c7686 100644 --- a/pkgs/by-name/re/regal/package.nix +++ b/pkgs/by-name/re/regal/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { name = "regal"; @@ -14,7 +18,8 @@ buildGoModule rec { vendorHash = "sha256-BvGzoATrMmtquO7fipNQkaQv8HpZs0sNK0EF/RzFTPU="; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/styrainc/regal/pkg/version.Version=${version}" "-X github.com/styrainc/regal/pkg/version.Commit=${version}" ]; diff --git a/pkgs/by-name/re/regclient/package.nix b/pkgs/by-name/re/regclient/package.nix index 7d1aad0fd75269..c9c5985c45549b 100644 --- a/pkgs/by-name/re/regclient/package.nix +++ b/pkgs/by-name/re/regclient/package.nix @@ -1,13 +1,20 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, lndir -, testers -, regclient +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + lndir, + testers, + regclient, }: -let bins = [ "regbot" "regctl" "regsync" ]; in +let + bins = [ + "regbot" + "regctl" + "regsync" + ]; +in buildGoModule rec { pname = "regclient"; @@ -30,26 +37,27 @@ buildGoModule rec { "-X github.com/regclient/regclient/internal/version.vcsTag=${tag}" ]; - nativeBuildInputs = [ installShellFiles lndir ]; + nativeBuildInputs = [ + installShellFiles + lndir + ]; - postInstall = lib.concatMapStringsSep "\n" - (bin: '' - export bin=''$${bin} - export outputBin=bin + postInstall = lib.concatMapStringsSep "\n" (bin: '' + export bin=''$${bin} + export outputBin=bin - mkdir -p $bin/bin - mv $out/bin/${bin} $bin/bin + mkdir -p $bin/bin + mv $out/bin/${bin} $bin/bin - installShellCompletion --cmd ${bin} \ - --bash <($bin/bin/${bin} completion bash) \ - --fish <($bin/bin/${bin} completion fish) \ - --zsh <($bin/bin/${bin} completion zsh) + installShellCompletion --cmd ${bin} \ + --bash <($bin/bin/${bin} completion bash) \ + --fish <($bin/bin/${bin} completion fish) \ + --zsh <($bin/bin/${bin} completion zsh) - lndir -silent $bin $out + lndir -silent $bin $out - unset bin outputBin - '') - bins; + unset bin outputBin + '') bins; checkFlags = [ # touches network @@ -57,15 +65,13 @@ buildGoModule rec { ]; passthru.tests = lib.mergeAttrsList ( - map - (bin: { - "${bin}Version" = testers.testVersion { - package = regclient; - command = "${bin} version"; - version = tag; - }; - }) - bins + map (bin: { + "${bin}Version" = testers.testVersion { + package = regclient; + command = "${bin} version"; + version = tag; + }; + }) bins ); __darwinAllowLocalNetworking = true; diff --git a/pkgs/by-name/re/regenkfs/package.nix b/pkgs/by-name/re/regenkfs/package.nix index b8d4ed3b155452..4279b9cb58856b 100644 --- a/pkgs/by-name/re/regenkfs/package.nix +++ b/pkgs/by-name/re/regenkfs/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage { pname = "regenkfs"; diff --git a/pkgs/by-name/re/regex-cli/package.nix b/pkgs/by-name/re/regex-cli/package.nix index 0f197e66181d4b..f9b15784b20917 100644 --- a/pkgs/by-name/re/regex-cli/package.nix +++ b/pkgs/by-name/re/regex-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -18,7 +19,10 @@ rustPlatform.buildRustPackage rec { description = "Command line tool for debugging, ad hoc benchmarking and generating regular expressions"; mainProgram = "regex-cli"; homepage = "https://github.com/rust-lang/regex/tree/master/regex-cli"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/re/regex2json/package.nix b/pkgs/by-name/re/regex2json/package.nix index e728adab042638..c9f56908963e91 100644 --- a/pkgs/by-name/re/regex2json/package.nix +++ b/pkgs/by-name/re/regex2json/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitLab }: +{ + lib, + buildGoModule, + fetchFromGitLab, +}: buildGoModule rec { pname = "regex2json"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-myMUs9urHjYaOQ/UaPYlLZstvClOuvF5xJao4lTP5bY="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = { description = "Convert text to JSON using only regular expressions"; diff --git a/pkgs/by-name/re/regexploit/package.nix b/pkgs/by-name/re/regexploit/package.nix index b921cbcc3b3c09..0ed524edd4fa70 100644 --- a/pkgs/by-name/re/regexploit/package.nix +++ b/pkgs/by-name/re/regexploit/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/re/regextester/package.nix b/pkgs/by-name/re/regextester/package.nix index 8508f65727e052..8ca42ead79a669 100644 --- a/pkgs/by-name/re/regextester/package.nix +++ b/pkgs/by-name/re/regextester/package.nix @@ -1,19 +1,22 @@ -{ lib, stdenv -, fetchFromGitHub -, vala -, gettext -, libxml2 -, pkg-config -, glib -, gtk3 -, libgee -, meson -, ninja -, gobject-introspection -, gsettings-desktop-schemas -, desktop-file-utils -, pantheon -, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + vala, + gettext, + libxml2, + pkg-config, + glib, + gtk3, + libgee, + meson, + ninja, + gobject-introspection, + gsettings-desktop-schemas, + desktop-file-utils, + pantheon, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "regextester"; diff --git a/pkgs/by-name/re/regina/package.nix b/pkgs/by-name/re/regina/package.nix index f805ffe2465f1f..09254c6734a9a4 100644 --- a/pkgs/by-name/re/regina/package.nix +++ b/pkgs/by-name/re/regina/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, ncurses +{ + lib, + stdenv, + fetchurl, + ncurses, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/re/regionset/package.nix b/pkgs/by-name/re/regionset/package.nix index 07154a1fc9a1be..547a307ea1fbf0 100644 --- a/pkgs/by-name/re/regionset/package.nix +++ b/pkgs/by-name/re/regionset/package.nix @@ -1,6 +1,12 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: -let version = "0.2"; in +let + version = "0.2"; +in stdenv.mkDerivation { pname = "regionset"; inherit version; diff --git a/pkgs/by-name/re/regols/package.nix b/pkgs/by-name/re/regols/package.nix index af8f81ff776d9e..847162030ed324 100644 --- a/pkgs/by-name/re/regols/package.nix +++ b/pkgs/by-name/re/regols/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "regols"; diff --git a/pkgs/by-name/re/regpg/package.nix b/pkgs/by-name/re/regpg/package.nix index e14fdbbbb7593c..690ae917b2f22f 100644 --- a/pkgs/by-name/re/regpg/package.nix +++ b/pkgs/by-name/re/regpg/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, gnupg -, perl +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + gnupg, + perl, }: let @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { sha256 = "2ea99950804078190e1cc2a76d4740e3fdd5395a9043db3f3fe86bf2477d3a7d"; }; - nativeBuildInputs = [ makeWrapper perlEnv ]; + nativeBuildInputs = [ + makeWrapper + perlEnv + ]; postPatch = '' patchShebangs ./util/insert-here.pl ./util/markdown.pl diff --git a/pkgs/by-name/re/rehex/package.nix b/pkgs/by-name/re/rehex/package.nix index e971360b64e36e..d0355c64e8ee22 100644 --- a/pkgs/by-name/re/rehex/package.nix +++ b/pkgs/by-name/re/rehex/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, which -, zip -, libicns -, botan3 -, capstone -, jansson -, libunistring -, wxGTK32 -, lua53Packages -, perlPackages -, gtk3 -, apple-sdk_11 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + which, + zip, + libicns, + botan3, + capstone, + jansson, + libunistring, + wxGTK32, + lua53Packages, + perlPackages, + gtk3, + apple-sdk_11, }: stdenv.mkDerivation rec { @@ -27,12 +28,28 @@ stdenv.mkDerivation rec { hash = "sha256-RlYpg3aon1d25n8K/bbHGVLn5/iOOUSlvjT8U0fp9hA="; }; - nativeBuildInputs = [ pkg-config which zip ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libicns ]; + nativeBuildInputs = [ + pkg-config + which + zip + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libicns ]; - buildInputs = [ botan3 capstone jansson libunistring wxGTK32 ] - ++ (with lua53Packages; [ lua busted ]) - ++ (with perlPackages; [ perl TemplateToolkit ]) + buildInputs = + [ + botan3 + capstone + jansson + libunistring + wxGTK32 + ] + ++ (with lua53Packages; [ + lua + busted + ]) + ++ (with perlPackages; [ + perl + TemplateToolkit + ]) ++ lib.optionals stdenv.hostPlatform.isLinux [ gtk3 ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ apple-sdk_11 ]; @@ -57,7 +74,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/solemnwarning/rehex"; changelog = "https://github.com/solemnwarning/rehex/raw/${version}/CHANGES.txt"; license = licenses.gpl2Only; - maintainers = with maintainers; [ markus1189 wegank ]; + maintainers = with maintainers; [ + markus1189 + wegank + ]; platforms = platforms.all; mainProgram = "rehex"; }; diff --git a/pkgs/by-name/re/reindeer/package.nix b/pkgs/by-name/re/reindeer/package.nix index 2ada097d0bf598..afdb1213436f42 100644 --- a/pkgs/by-name/re/reindeer/package.nix +++ b/pkgs/by-name/re/reindeer/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, nix-update-script +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + nix-update-script, }: rustPlatform.buildRustPackage rec { @@ -33,4 +34,3 @@ rustPlatform.buildRustPackage rec { maintainers = with maintainers; [ nickgerace ]; }; } - diff --git a/pkgs/by-name/re/reiser4progs/package.nix b/pkgs/by-name/re/reiser4progs/package.nix index 63247da847d464..51bef2c7db74b0 100644 --- a/pkgs/by-name/re/reiser4progs/package.nix +++ b/pkgs/by-name/re/reiser4progs/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, libaal}: +{ + lib, + stdenv, + fetchurl, + libaal, +}: stdenv.mkDerivation rec { pname = "reiser4progs"; @@ -9,7 +14,7 @@ stdenv.mkDerivation rec { sha256 = "sha256-DBR2C5h6ue4aqHmDG50jCLXe13DSWAYwfibrzTM+7Sw="; }; - buildInputs = [libaal]; + buildInputs = [ libaal ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/re/reiserfsprogs/package.nix b/pkgs/by-name/re/reiserfsprogs/package.nix index 1118c9ac27429f..68aaafcf0318b0 100644 --- a/pkgs/by-name/re/reiserfsprogs/package.nix +++ b/pkgs/by-name/re/reiserfsprogs/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, libuuid, autoreconfHook, e2fsprogs, acl }: +{ + lib, + stdenv, + fetchurl, + libuuid, + autoreconfHook, + e2fsprogs, + acl, +}: stdenv.mkDerivation rec { pname = "reiserfsprogs"; @@ -10,9 +18,16 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ libuuid e2fsprogs acl ]; + buildInputs = [ + libuuid + e2fsprogs + acl + ]; - env.NIX_CFLAGS_COMPILE = toString [ "-std=gnu90" "-D_GNU_SOURCE" ]; + env.NIX_CFLAGS_COMPILE = toString [ + "-std=gnu90" + "-D_GNU_SOURCE" + ]; meta = { inherit version; diff --git a/pkgs/by-name/re/release-plz/package.nix b/pkgs/by-name/re/release-plz/package.nix index adf9b4ac077a30..e04340e8fe8d45 100644 --- a/pkgs/by-name/re/release-plz/package.nix +++ b/pkgs/by-name/re/release-plz/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, installShellFiles -, pkg-config -, perl -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + installShellFiles, + pkg-config, + perl, + openssl, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,11 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-GptaDa8NjCcWg5OsyujIgxGH4egWGBVVTLaYp4fqP3Q="; - nativeBuildInputs = [ installShellFiles pkg-config perl ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + perl + ]; buildInputs = [ openssl ]; @@ -41,7 +46,10 @@ rustPlatform.buildRustPackage rec { description = "Publish Rust crates from CI with a Release PR"; homepage = "https://release-plz.ieni.dev"; changelog = "https://github.com/MarcoIeni/release-plz/blob/release-plz-v${version}/CHANGELOG.md"; - license = with lib.licenses; [ asl20 mit ]; + license = with lib.licenses; [ + asl20 + mit + ]; maintainers = with lib.maintainers; [ dannixon ]; mainProgram = "release-plz"; broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/by-name/re/remake/package.nix b/pkgs/by-name/re/remake/package.nix index 886034e4a270cb..baca92f494ffe8 100644 --- a/pkgs/by-name/re/remake/package.nix +++ b/pkgs/by-name/re/remake/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, readline -, guileSupport ? false -, guile +{ + lib, + stdenv, + fetchurl, + pkg-config, + readline, + guileSupport ? false, + guile, }: stdenv.mkDerivation rec { @@ -25,8 +26,7 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ readline ] - ++ lib.optionals guileSupport [ guile ]; + buildInputs = [ readline ] ++ lib.optionals guileSupport [ guile ]; # make check fails, see https://github.com/rocky/remake/issues/117 @@ -36,6 +36,9 @@ stdenv.mkDerivation rec { description = "GNU Make with comprehensible tracing and a debugger"; mainProgram = "remake"; platforms = with lib.platforms; linux ++ darwin; - maintainers = with lib.maintainers; [ bjornfor shamilton ]; + maintainers = with lib.maintainers; [ + bjornfor + shamilton + ]; }; } diff --git a/pkgs/by-name/re/remarkable-toolchain/package.nix b/pkgs/by-name/re/remarkable-toolchain/package.nix index 1ff4e5c62459b3..98c995585e598f 100644 --- a/pkgs/by-name/re/remarkable-toolchain/package.nix +++ b/pkgs/by-name/re/remarkable-toolchain/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, libarchive, python3, file, which }: +{ + lib, + stdenv, + fetchurl, + libarchive, + python3, + file, + which, +}: stdenv.mkDerivation rec { pname = "remarkable-toolchain"; @@ -30,7 +38,10 @@ stdenv.mkDerivation rec { homepage = "https://remarkable.engineering/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.gpl2Plus; - maintainers = with maintainers; [ nickhu siraben ]; + maintainers = with maintainers; [ + nickhu + siraben + ]; platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/by-name/re/remarkable2-toolchain/package.nix b/pkgs/by-name/re/remarkable2-toolchain/package.nix index 6e6b79e8f2e927..9c8ea70e815b00 100644 --- a/pkgs/by-name/re/remarkable2-toolchain/package.nix +++ b/pkgs/by-name/re/remarkable2-toolchain/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, libarchive, python3, file, which }: +{ + lib, + stdenv, + fetchurl, + libarchive, + python3, + file, + which, +}: stdenv.mkDerivation rec { pname = "remarkable2-toolchain"; diff --git a/pkgs/by-name/re/remkrom/package.nix b/pkgs/by-name/re/remkrom/package.nix index c7a8fb21241e6c..a89fa590c20de3 100644 --- a/pkgs/by-name/re/remkrom/package.nix +++ b/pkgs/by-name/re/remkrom/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage { pname = "remkrom"; diff --git a/pkgs/by-name/re/remontoire/package.nix b/pkgs/by-name/re/remontoire/package.nix index 95e3fecef272c0..d04d0e23ec11a6 100644 --- a/pkgs/by-name/re/remontoire/package.nix +++ b/pkgs/by-name/re/remontoire/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, wrapGAppsHook3 -, desktop-file-utils -, glib -, gtk3 -, json-glib -, libgee -, meson -, ninja -, pkg-config -, python3 -, vala +{ + lib, + stdenv, + fetchFromGitHub, + wrapGAppsHook3, + desktop-file-utils, + glib, + gtk3, + json-glib, + libgee, + meson, + ninja, + pkg-config, + python3, + vala, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/re/remote-touchpad/package.nix b/pkgs/by-name/re/remote-touchpad/package.nix index 59e448c46170c9..8f7db022320681 100644 --- a/pkgs/by-name/re/remote-touchpad/package.nix +++ b/pkgs/by-name/re/remote-touchpad/package.nix @@ -1,10 +1,11 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, libXi -, libXrandr -, libXt -, libXtst +{ + buildGoModule, + fetchFromGitHub, + lib, + libXi, + libXrandr, + libXt, + libXtst, }: buildGoModule rec { @@ -18,7 +19,12 @@ buildGoModule rec { sha256 = "sha256-C/qaLEYvIbl0XINsumAFLnsQgy+EDjoX446BJnuE6eQ="; }; - buildInputs = [ libXi libXrandr libXt libXtst ]; + buildInputs = [ + libXi + libXrandr + libXt + libXtst + ]; tags = [ "portal,x11" ]; vendorHash = "sha256-bt5KUgNDgWX7CVHvX5c0uYqoxGRDbGbae52+mpnBEZU="; diff --git a/pkgs/by-name/re/remotebox/package.nix b/pkgs/by-name/re/remotebox/package.nix index 7aede37fe70c5d..8919dd46246303 100644 --- a/pkgs/by-name/re/remotebox/package.nix +++ b/pkgs/by-name/re/remotebox/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, makeWrapper, perl, perlPackages }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + perl, + perlPackages, +}: stdenv.mkDerivation rec { pname = "remotebox"; @@ -9,7 +16,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-oIWSli/pc+kqMkYqkeHr3fZshWUHx6ecqAZXf6fl2ik="; }; - buildInputs = with perlPackages; [ perl Glib Gtk2 Pango SOAPLite ]; + buildInputs = with perlPackages; [ + perl + Glib + Gtk2 + Pango + SOAPLite + ]; nativeBuildInputs = [ makeWrapper ]; installPhase = '' diff --git a/pkgs/by-name/re/ren-find/package.nix b/pkgs/by-name/re/ren-find/package.nix index 0008b398093e1c..7f1fef94380b37 100644 --- a/pkgs/by-name/re/ren-find/package.nix +++ b/pkgs/by-name/re/ren-find/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/re/rename/package.nix b/pkgs/by-name/re/rename/package.nix index d7eed90d063970..a14365c764e75d 100644 --- a/pkgs/by-name/re/rename/package.nix +++ b/pkgs/by-name/re/rename/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, perlPackages }: +{ + lib, + fetchFromGitHub, + perlPackages, +}: perlPackages.buildPerlPackage rec { pname = "rename"; @@ -13,7 +17,10 @@ perlPackages.buildPerlPackage rec { meta = with lib; { description = "Rename files according to a Perl rewrite expression"; homepage = "https://github.com/pstray/rename"; - maintainers = with maintainers; [ mkg cyplo ]; + maintainers = with maintainers; [ + mkg + cyplo + ]; license = with licenses; [ gpl1Plus ]; mainProgram = "rename"; }; diff --git a/pkgs/by-name/re/renameutils/package.nix b/pkgs/by-name/re/renameutils/package.nix index e09b7c60f97189..77180071f16823 100644 --- a/pkgs/by-name/re/renameutils/package.nix +++ b/pkgs/by-name/re/renameutils/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, readline, coreutils }: +{ + lib, + stdenv, + fetchurl, + readline, + coreutils, +}: stdenv.mkDerivation rec { pname = "renameutils"; diff --git a/pkgs/by-name/re/renderizer/package.nix b/pkgs/by-name/re/renderizer/package.nix index 18aea30413325d..1b3f49fa5d685b 100644 --- a/pkgs/by-name/re/renderizer/package.nix +++ b/pkgs/by-name/re/renderizer/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "renderizer"; @@ -12,7 +16,11 @@ buildGoModule rec { }; ldflags = [ - "-s" "-w" "-X main.version=${version}" "-X main.commitHash=${src.rev}" "-X main.date=19700101T000000" + "-s" + "-w" + "-X main.version=${version}" + "-X main.commitHash=${src.rev}" + "-X main.date=19700101T000000" ]; vendorHash = null; diff --git a/pkgs/by-name/re/renode-dts2repl/package.nix b/pkgs/by-name/re/renode-dts2repl/package.nix index 871b14be107863..97e2b3baefce44 100644 --- a/pkgs/by-name/re/renode-dts2repl/package.nix +++ b/pkgs/by-name/re/renode-dts2repl/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, unstableGitUpdater +{ + lib, + python3, + fetchFromGitHub, + unstableGitUpdater, }: python3.pkgs.buildPythonApplication { diff --git a/pkgs/by-name/re/renode-unstable/package.nix b/pkgs/by-name/re/renode-unstable/package.nix index 95a18ec25f26df..7164233f75598f 100644 --- a/pkgs/by-name/re/renode-unstable/package.nix +++ b/pkgs/by-name/re/renode-unstable/package.nix @@ -1,35 +1,38 @@ -{ renode -, fetchurl -, writeScript +{ + renode, + fetchurl, + writeScript, }: -renode.overrideAttrs (finalAttrs: _: { - pname = "renode-unstable"; - version = "1.15.3+20241112git6e850cb52"; +renode.overrideAttrs ( + finalAttrs: _: { + pname = "renode-unstable"; + version = "1.15.3+20241112git6e850cb52"; - src = fetchurl { - url = "https://builds.renode.io/renode-${finalAttrs.version}.linux-dotnet.tar.gz"; - hash = "sha256-GkmzPc0pPRglkuGzPU+rLUcwlhw8v4VgQnxnkzT/+cI="; - }; + src = fetchurl { + url = "https://builds.renode.io/renode-${finalAttrs.version}.linux-dotnet.tar.gz"; + hash = "sha256-GkmzPc0pPRglkuGzPU+rLUcwlhw8v4VgQnxnkzT/+cI="; + }; - passthru.updateScript = - let - versionRegex = "[0-9\.\+]+[^\+]*."; - in - writeScript "${finalAttrs.pname}-updater" '' - #!/usr/bin/env nix-shell - #!nix-shell -i bash -p common-updater-scripts curl gnugrep gnused pup + passthru.updateScript = + let + versionRegex = "[0-9\.\+]+[^\+]*."; + in + writeScript "${finalAttrs.pname}-updater" '' + #!/usr/bin/env nix-shell + #!nix-shell -i bash -p common-updater-scripts curl gnugrep gnused pup - latestVersion=$( - curl -sS https://builds.renode.io \ - | pup 'a text{}' \ - | egrep 'renode-${versionRegex}\.linux-dotnet\.tar\.gz' \ - | head -n1 \ - | sed -e 's,renode-\(.*\)\.linux-dotnet\.tar\.gz,\1,g' - ) + latestVersion=$( + curl -sS https://builds.renode.io \ + | pup 'a text{}' \ + | egrep 'renode-${versionRegex}\.linux-dotnet\.tar\.gz' \ + | head -n1 \ + | sed -e 's,renode-\(.*\)\.linux-dotnet\.tar\.gz,\1,g' + ) - update-source-version ${finalAttrs.pname} "$latestVersion" \ - --file=pkgs/by-name/re/${finalAttrs.pname}/package.nix \ - --system=x86_64-linux - ''; -}) + update-source-version ${finalAttrs.pname} "$latestVersion" \ + --file=pkgs/by-name/re/${finalAttrs.pname}/package.nix \ + --system=x86_64-linux + ''; + } +) diff --git a/pkgs/by-name/re/renode/package.nix b/pkgs/by-name/re/renode/package.nix index 98c88f8d111cef..888f29cfb5ac77 100644 --- a/pkgs/by-name/re/renode/package.nix +++ b/pkgs/by-name/re/renode/package.nix @@ -1,41 +1,44 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchurl -, autoPatchelfHook -, makeWrapper -, nix-update-script -, glibcLocales -, python3Packages -, dotnetCorePackages -, gtk-sharp-3_0 -, gtk3-x11 -, dconf +{ + stdenv, + lib, + fetchFromGitHub, + fetchurl, + autoPatchelfHook, + makeWrapper, + nix-update-script, + glibcLocales, + python3Packages, + dotnetCorePackages, + gtk-sharp-3_0, + gtk3-x11, + dconf, }: let - pythonLibs = with python3Packages; makePythonPath [ - construct - psutil - pyyaml - requests - tkinter - - # from tools/csv2resd/requirements.txt - construct - - # from tools/execution_tracer/requirements.txt - pyelftools - - (robotframework.overrideDerivation (oldAttrs: { - src = fetchFromGitHub { - owner = "robotframework"; - repo = "robotframework"; - rev = "v6.1"; - hash = "sha256-l1VupBKi52UWqJMisT2CVnXph3fGxB63mBVvYdM1NWE="; - }; - })) - ]; + pythonLibs = + with python3Packages; + makePythonPath [ + construct + psutil + pyyaml + requests + tkinter + + # from tools/csv2resd/requirements.txt + construct + + # from tools/execution_tracer/requirements.txt + pyelftools + + (robotframework.overrideDerivation (oldAttrs: { + src = fetchFromGitHub { + owner = "robotframework"; + repo = "robotframework"; + rev = "v6.1"; + hash = "sha256-l1VupBKi52UWqJMisT2CVnXph3fGxB63mBVvYdM1NWE="; + }; + })) + ]; in stdenv.mkDerivation (finalAttrs: { pname = "renode"; diff --git a/pkgs/by-name/re/renoise/package.nix b/pkgs/by-name/re/renoise/package.nix index dd350e02249afc..5e61472f119035 100644 --- a/pkgs/by-name/re/renoise/package.nix +++ b/pkgs/by-name/re/renoise/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, writeScript -, alsa-lib -, fetchurl -, libjack2 -, libX11 -, libXcursor -, libXext -, libXinerama -, libXrandr -, libXtst -, mpg123 -, pipewire -, releasePath ? null +{ + lib, + stdenv, + writeScript, + alsa-lib, + fetchurl, + libjack2, + libX11, + libXcursor, + libXext, + libXinerama, + libXrandr, + libXtst, + mpg123, + pipewire, + releasePath ? null, }: # To use the full release version: @@ -32,23 +33,26 @@ let }; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "renoise"; version = "3.4.4"; - src = if releasePath != null then - releasePath - else - let - platform = platforms.${stdenv.system} or (throw "unsupported system ${stdenv.hostPlatform.system}"); - urlVersion = lib.replaceStrings [ "." ] [ "_" ] version; - in fetchurl { - urls = [ - "https://files.renoise.com/demo/Renoise_${urlVersion}_Demo_Linux_${platform.archSuffix}.tar.gz" - "https://files.renoise.com/demo/archive/Renoise_${urlVersion}_Demo_Linux_${platform.archSuffix}.tar.gz" - ]; - hash = platform.hash; - }; + src = + if releasePath != null then + releasePath + else + let + platform = platforms.${stdenv.system} or (throw "unsupported system ${stdenv.hostPlatform.system}"); + urlVersion = lib.replaceStrings [ "." ] [ "_" ] version; + in + fetchurl { + urls = [ + "https://files.renoise.com/demo/Renoise_${urlVersion}_Demo_Linux_${platform.archSuffix}.tar.gz" + "https://files.renoise.com/demo/archive/Renoise_${urlVersion}_Demo_Linux_${platform.archSuffix}.tar.gz" + ]; + hash = platform.hash; + }; buildInputs = [ alsa-lib diff --git a/pkgs/by-name/re/rep-grep/package.nix b/pkgs/by-name/re/rep-grep/package.nix index de67de3f7be1ad..332a3ec5052894 100644 --- a/pkgs/by-name/re/rep-grep/package.nix +++ b/pkgs/by-name/re/rep-grep/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/re/rep-gtk/package.nix b/pkgs/by-name/re/rep-gtk/package.nix index 872eacb5011ea5..a4aac2e74b8f72 100644 --- a/pkgs/by-name/re/rep-gtk/package.nix +++ b/pkgs/by-name/re/rep-gtk/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, gtk2-x11 -, librep -, pkg-config +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + gtk2-x11, + librep, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/re/rep/package.nix b/pkgs/by-name/re/rep/package.nix index 78b9c2612e4221..3a8782691f0c93 100644 --- a/pkgs/by-name/re/rep/package.nix +++ b/pkgs/by-name/re/rep/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, asciidoc-full }: +{ + lib, + stdenv, + fetchFromGitHub, + asciidoc-full, +}: stdenv.mkDerivation rec { pname = "rep"; diff --git a/pkgs/by-name/re/repgrep/package.nix b/pkgs/by-name/re/repgrep/package.nix index 1fb6156dfc4ec5..fb8d6012b24bfc 100644 --- a/pkgs/by-name/re/repgrep/package.nix +++ b/pkgs/by-name/re/repgrep/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, asciidoctor -, installShellFiles -, makeWrapper -, ripgrep +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + asciidoctor, + installShellFiles, + makeWrapper, + ripgrep, }: rustPlatform.buildRustPackage rec { @@ -27,26 +28,32 @@ rustPlatform.buildRustPackage rec { makeWrapper ]; - postInstall = '' - wrapProgram $out/bin/rgr \ - --prefix PATH : ${lib.makeBinPath [ ripgrep ]} + postInstall = + '' + wrapProgram $out/bin/rgr \ + --prefix PATH : ${lib.makeBinPath [ ripgrep ]} - pushd "$(dirname "$(find -path '**/repgrep-stamp' | head -n 1)")" - installManPage rgr.1 - popd - '' + lib.optionalString (stdenv.hostPlatform.canExecute stdenv.buildPlatform) '' - # As it can be seen here: https://github.com/acheronfail/repgrep/blob/0.15.0/.github/workflows/release.yml#L206, the completions are just the same as ripgrep - installShellCompletion --cmd rgr \ - --bash <(${lib.getExe ripgrep} --generate complete-bash | sed 's/-c rg/-c rgr/') \ - --zsh <(${lib.getExe ripgrep} --generate complete-zsh | sed 's/-c rg/-c rgr/') \ - --fish <(${lib.getExe ripgrep} --generate complete-fish | sed 's/-c rg/-c rgr/') - ''; + pushd "$(dirname "$(find -path '**/repgrep-stamp' | head -n 1)")" + installManPage rgr.1 + popd + '' + + lib.optionalString (stdenv.hostPlatform.canExecute stdenv.buildPlatform) '' + # As it can be seen here: https://github.com/acheronfail/repgrep/blob/0.15.0/.github/workflows/release.yml#L206, the completions are just the same as ripgrep + installShellCompletion --cmd rgr \ + --bash <(${lib.getExe ripgrep} --generate complete-bash | sed 's/-c rg/-c rgr/') \ + --zsh <(${lib.getExe ripgrep} --generate complete-zsh | sed 's/-c rg/-c rgr/') \ + --fish <(${lib.getExe ripgrep} --generate complete-fish | sed 's/-c rg/-c rgr/') + ''; meta = with lib; { description = "Interactive replacer for ripgrep that makes it easy to find and replace across files on the command line"; homepage = "https://github.com/acheronfail/repgrep"; changelog = "https://github.com/acheronfail/repgrep/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ mit asl20 unlicense ]; + license = with licenses; [ + mit + asl20 + unlicense + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "rgr"; }; diff --git a/pkgs/by-name/re/replace/package.nix b/pkgs/by-name/re/replace/package.nix index 61c6a65322d149..a23e4427962276 100644 --- a/pkgs/by-name/re/replace/package.nix +++ b/pkgs/by-name/re/replace/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "replace"; @@ -9,7 +13,10 @@ stdenv.mkDerivation rec { sha256 = "18hkwhaz25s6209n5mpx9hmkyznlzygqj488p2l7nvp9zrlxb9sf"; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; makeFlags = [ "TREE=\$(out)" @@ -24,7 +31,7 @@ stdenv.mkDerivation rec { preInstall = "mkdir -p \$out/share/man"; postInstall = "mv \$out/bin/replace \$out/bin/replace-literal"; - patches = [./malloc.patch]; + patches = [ ./malloc.patch ]; meta = { description = "Tool to replace verbatim strings"; diff --git a/pkgs/by-name/re/replacement/package.nix b/pkgs/by-name/re/replacement/package.nix index fd0533852aef3e..0c72e617ff6434 100644 --- a/pkgs/by-name/re/replacement/package.nix +++ b/pkgs/by-name/re/replacement/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3Packages +{ + lib, + fetchFromGitHub, + python3Packages, }: python3Packages.buildPythonApplication rec { @@ -30,16 +31,16 @@ python3Packages.buildPythonApplication rec { description = "Tool to execute yaml templates and output text"; mainProgram = "replacement"; longDescription = '' - Replacement is a python utility - that parses a yaml template and outputs text. + Replacement is a python utility + that parses a yaml template and outputs text. - A 'template' is a YAML file containing a 'replacement' object. + A 'template' is a YAML file containing a 'replacement' object. - A 'replacement' object contains a list of blocks, - each of which is executed in sequence. + A 'replacement' object contains a list of blocks, + each of which is executed in sequence. - This tool is useful in generating configuration files, - static websites and the like. + This tool is useful in generating configuration files, + static websites and the like. ''; license = licenses.asl20; maintainers = with maintainers; [ siriobalmelli ]; diff --git a/pkgs/by-name/re/replxx/package.nix b/pkgs/by-name/re/replxx/package.nix index 705b12deda356b..b94936bb3c9df0 100644 --- a/pkgs/by-name/re/replxx/package.nix +++ b/pkgs/by-name/re/replxx/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, enableStatic ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + enableStatic ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/re/reposilite/package.nix b/pkgs/by-name/re/reposilite/package.nix index d5a3b2645e7076..0340e1cfac1c11 100644 --- a/pkgs/by-name/re/reposilite/package.nix +++ b/pkgs/by-name/re/reposilite/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, makeWrapper, jre_headless }: +{ + stdenv, + lib, + fetchurl, + makeWrapper, + jre_headless, +}: stdenv.mkDerivation (finalAttrs: { pname = "Reposilite"; diff --git a/pkgs/by-name/re/reposurgeon/package.nix b/pkgs/by-name/re/reposurgeon/package.nix index 40ce515938e5f3..aec51ab75d221e 100644 --- a/pkgs/by-name/re/reposurgeon/package.nix +++ b/pkgs/by-name/re/reposurgeon/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, buildGoModule, asciidoctor, ruby +{ + lib, + fetchurl, + buildGoModule, + asciidoctor, + ruby, }: buildGoModule rec { @@ -14,7 +19,10 @@ buildGoModule rec { subPackages = [ "." ]; - nativeBuildInputs = [ asciidoctor ruby ]; + nativeBuildInputs = [ + asciidoctor + ruby + ]; postBuild = '' patchShebangs . diff --git a/pkgs/by-name/re/repro-get/package.nix b/pkgs/by-name/re/repro-get/package.nix index 95d5902be00658..e3f94b5374eeab 100644 --- a/pkgs/by-name/re/repro-get/package.nix +++ b/pkgs/by-name/re/repro-get/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, testers -, repro-get -, cacert +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + repro-get, + cacert, }: buildGoModule rec { @@ -44,7 +45,9 @@ buildGoModule rec { passthru.tests = { "pkg-version" = repro-get.overrideAttrs (old: { # see invalidateFetcherByDrvHash - name = "${repro-get.pname}-${builtins.unsafeDiscardStringContext (lib.substring 0 12 (baseNameOf repro-get.drvPath))}"; + name = "${repro-get.pname}-${ + builtins.unsafeDiscardStringContext (lib.substring 0 12 (baseNameOf repro-get.drvPath)) + }"; subPackages = [ "pkg/version" ]; installPhase = '' rm -rf $out diff --git a/pkgs/by-name/re/reproc/package.nix b/pkgs/by-name/re/reproc/package.nix index 5092cc2ab7bdff..d00a691ff63667 100644 --- a/pkgs/by-name/re/reproc/package.nix +++ b/pkgs/by-name/re/reproc/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, cmake, fetchpatch +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + fetchpatch, }: stdenv.mkDerivation rec { @@ -13,12 +18,12 @@ stdenv.mkDerivation rec { }; patches = [ - (fetchpatch{ + (fetchpatch { name = "reproc-gcc-13-2.patch"; url = "https://github.com/DaanDeMeyer/reproc/commit/0b23d88894ccedde04537fa23ea55cb2f8365342.patch"; sha256 = "sha256-QyC0UcKAWCKSvSvyZTLI2eF/TuuqbGGH6cOQrS2DiCE="; }) - (fetchpatch{ + (fetchpatch { name = "reproc-gcc-13-1.patch"; url = "https://github.com/DaanDeMeyer/reproc/commit/9f399675b821e175f85ac3ee6e3fd2e6056573eb.patch"; sha256 = "sha256-h/gnDFPWPpUFkys10YXjjEPibgRT1atHSVwbO0kId+U="; diff --git a/pkgs/by-name/re/reproxy/package.nix b/pkgs/by-name/re/reproxy/package.nix index 18485d99109919..cae8a22373e81f 100644 --- a/pkgs/by-name/re/reproxy/package.nix +++ b/pkgs/by-name/re/reproxy/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "reproxy"; @@ -14,7 +18,9 @@ buildGoModule rec { vendorHash = null; ldflags = [ - "-s" "-w" "-X main.revision=${version}" + "-s" + "-w" + "-X main.revision=${version}" ]; checkFlags = [ diff --git a/pkgs/by-name/re/repseek/package.nix b/pkgs/by-name/re/repseek/package.nix index 9b38171b34ef28..90c306f66a8897 100644 --- a/pkgs/by-name/re/repseek/package.nix +++ b/pkgs/by-name/re/repseek/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "repseek"; @@ -8,14 +12,16 @@ stdenv.mkDerivation rec { sha256 = "1jiknji3ivrv7zmrfbf2mccfpdwhin3lfxfsciaqwf69b3sda8nf"; }; - preConfigure = '' - mkdir -p $out/bin - substituteInPlace Makefile \ - --replace "INSTALLDIR = \$\$HOME/bin" "INSTALLDIR = $out/bin/" \ - --replace "CC= gcc" "CC = $CC" - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace Makefile --replace "MACHINE = MACOSX" "MACHINE = LINUX" - ''; + preConfigure = + '' + mkdir -p $out/bin + substituteInPlace Makefile \ + --replace "INSTALLDIR = \$\$HOME/bin" "INSTALLDIR = $out/bin/" \ + --replace "CC= gcc" "CC = $CC" + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace Makefile --replace "MACHINE = MACOSX" "MACHINE = LINUX" + ''; meta = { description = "Tool to retrieve approximate repeats from large DNA sequences"; diff --git a/pkgs/by-name/re/reptyr/package.nix b/pkgs/by-name/re/reptyr/package.nix index 5a9e58c3f6f976..88b1b6f2e2833d 100644 --- a/pkgs/by-name/re/reptyr/package.nix +++ b/pkgs/by-name/re/reptyr/package.nix @@ -1,8 +1,14 @@ -{ stdenv, lib, fetchFromGitHub, python3 }: +{ + stdenv, + lib, + fetchFromGitHub, + python3, +}: let python = python3.withPackages (p: [ p.pexpect ]); -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { version = "0.10.0"; pname = "reptyr"; @@ -13,7 +19,10 @@ in stdenv.mkDerivation rec { sha256 = "sha256-jlO/ykrwGJkgKiPxfRQEX4TSksrbPQhkQs+QddwqaQ4="; }; - makeFlags = [ "PREFIX=" "DESTDIR=$(out)" ]; + makeFlags = [ + "PREFIX=" + "DESTDIR=$(out)" + ]; nativeCheckInputs = [ python ]; @@ -37,7 +46,7 @@ in stdenv.mkDerivation rec { "aarch64-linux" "riscv64-linux" ]; - maintainers = with lib.maintainers; [raskin]; + maintainers = with lib.maintainers; [ raskin ]; license = lib.licenses.mit; description = "Reparent a running program to a new terminal"; mainProgram = "reptyr"; diff --git a/pkgs/by-name/re/requestly/package.nix b/pkgs/by-name/re/requestly/package.nix index 6f5dec9975594b..8f033c4f4ed364 100644 --- a/pkgs/by-name/re/requestly/package.nix +++ b/pkgs/by-name/re/requestly/package.nix @@ -1,6 +1,7 @@ -{ lib -, appimageTools -, fetchurl +{ + lib, + appimageTools, + fetchurl, }: let diff --git a/pkgs/by-name/re/reredirect/package.nix b/pkgs/by-name/re/reredirect/package.nix index 479c8ac28e543a..afe82bddc0a2ff 100644 --- a/pkgs/by-name/re/reredirect/package.nix +++ b/pkgs/by-name/re/reredirect/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "reredirect"; @@ -23,7 +27,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/jerome-pouiller/reredirect"; license = licenses.mit; maintainers = [ maintainers.tobim ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } - diff --git a/pkgs/by-name/re/resgate/package.nix b/pkgs/by-name/re/resgate/package.nix index 7f74898234258a..160c7b42d8c62c 100644 --- a/pkgs/by-name/re/resgate/package.nix +++ b/pkgs/by-name/re/resgate/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/re/reshape/package.nix b/pkgs/by-name/re/reshape/package.nix index 256f6515efd6cf..1bc023ed1a5134 100644 --- a/pkgs/by-name/re/reshape/package.nix +++ b/pkgs/by-name/re/reshape/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchCrate -, darwin -, postgresqlTestHook -, postgresql -, stdenv +{ + lib, + rustPlatform, + fetchCrate, + darwin, + postgresqlTestHook, + postgresql, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -18,8 +19,9 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-VTJ3FNhVLgxo/VVBhk1yF9UUktLXcbrEkYwoyoWFhXA="; - buildInputs = - lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; nativeCheckInputs = [ postgresqlTestHook diff --git a/pkgs/by-name/re/resilio-sync/package.nix b/pkgs/by-name/re/resilio-sync/package.nix index f9f74a4af5b5fb..fc179d5ff27a3e 100644 --- a/pkgs/by-name/re/resilio-sync/package.nix +++ b/pkgs/by-name/re/resilio-sync/package.nix @@ -1,25 +1,33 @@ -{ lib, stdenv, fetchurl, autoPatchelfHook, libxcrypt-legacy }: +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + libxcrypt-legacy, +}: stdenv.mkDerivation rec { pname = "resilio-sync"; version = "2.8.1.1390"; - src = { - x86_64-linux = fetchurl { - url = "https://download-cdn.resilio.com/${version}/linux/x64/0/resilio-sync_x64.tar.gz"; - sha256 = "sha256-XrfE2frDxOS32MzO7gpJEsMd0WY+b7TS0h/H94M7Py4="; - }; - - i686-linux = fetchurl { - url = "https://download-cdn.resilio.com/${version}/linux/i386/0/resilio-sync_i386.tar.gz"; - sha256 = "sha256-tWwb9DHLlXeyimzyo/yxVKqlkP3jlAxT2Yzs6h2bIgs="; - }; - - aarch64-linux = fetchurl { - url = "https://download-cdn.resilio.com/${version}/linux/arm64/0/resilio-sync_arm64.tar.gz"; - sha256 = "sha256-b859DqxTfnBMMeiwXlGKTQ+Mpmr2Rpg24l/GNkxSWbA="; - }; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + { + x86_64-linux = fetchurl { + url = "https://download-cdn.resilio.com/${version}/linux/x64/0/resilio-sync_x64.tar.gz"; + sha256 = "sha256-XrfE2frDxOS32MzO7gpJEsMd0WY+b7TS0h/H94M7Py4="; + }; + + i686-linux = fetchurl { + url = "https://download-cdn.resilio.com/${version}/linux/i386/0/resilio-sync_i386.tar.gz"; + sha256 = "sha256-tWwb9DHLlXeyimzyo/yxVKqlkP3jlAxT2Yzs6h2bIgs="; + }; + + aarch64-linux = fetchurl { + url = "https://download-cdn.resilio.com/${version}/linux/arm64/0/resilio-sync_arm64.tar.gz"; + sha256 = "sha256-b859DqxTfnBMMeiwXlGKTQ+Mpmr2Rpg24l/GNkxSWbA="; + }; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); dontStrip = true; # Don't strip, otherwise patching the rpaths breaks sourceRoot = "."; @@ -39,11 +47,15 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Automatically sync files via secure, distributed technology"; - homepage = "https://www.resilio.com/"; + homepage = "https://www.resilio.com/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.unfreeRedistributable; - platforms = platforms.linux; - maintainers = with maintainers; [ domenkozar thoughtpolice cwoac ]; + license = licenses.unfreeRedistributable; + platforms = platforms.linux; + maintainers = with maintainers; [ + domenkozar + thoughtpolice + cwoac + ]; mainProgram = "rslsync"; }; } diff --git a/pkgs/by-name/re/resolv_wrapper/package.nix b/pkgs/by-name/re/resolv_wrapper/package.nix index bb58fbaad37029..197978a47b7c8e 100644 --- a/pkgs/by-name/re/resolv_wrapper/package.nix +++ b/pkgs/by-name/re/resolv_wrapper/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, cmake, pkg-config }: +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "resolv_wrapper"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-+8MPd9o+EuzU72bM9at34LdEkwzNiQYkBAgvkoqOwuA="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; meta = with lib; { description = "Wrapper for the user, group and hosts NSS API"; diff --git a/pkgs/by-name/re/resolve-march-native/package.nix b/pkgs/by-name/re/resolve-march-native/package.nix index 312d0d11c50cb9..d8fe8f4128833f 100644 --- a/pkgs/by-name/re/resolve-march-native/package.nix +++ b/pkgs/by-name/re/resolve-march-native/package.nix @@ -1,7 +1,8 @@ -{ python3Packages -, fetchFromGitHub -, gcc -, lib +{ + python3Packages, + fetchFromGitHub, + gcc, + lib, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/re/resonance/package.nix b/pkgs/by-name/re/resonance/package.nix index fe7be58060a31f..4e642c2d736c16 100644 --- a/pkgs/by-name/re/resonance/package.nix +++ b/pkgs/by-name/re/resonance/package.nix @@ -1,25 +1,26 @@ -{ lib -, cargo -, dbus -, desktop-file-utils -, fetchFromGitHub -, glib -, gst_all_1 -, gtk4 -, libadwaita -, libxml2 -, meson -, ninja -, nix-update-script -, openssl -, pkg-config -, python3 -, python3Packages -, rustPlatform -, rustc -, sqlite -, stdenv -, wrapGAppsHook4 +{ + lib, + cargo, + dbus, + desktop-file-utils, + fetchFromGitHub, + glib, + gst_all_1, + gtk4, + libadwaita, + libxml2, + meson, + ninja, + nix-update-script, + openssl, + pkg-config, + python3, + python3Packages, + rustPlatform, + rustc, + sqlite, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { pname = "resonance"; @@ -49,25 +50,36 @@ stdenv.mkDerivation (finalAttrs: { wrapGAppsHook4 ]; - buildInputs = [ - dbus - glib - gtk4 - libadwaita - libxml2 - openssl - sqlite - ] ++ (with gst_all_1; [ - gst-libav - gst-plugins-bad - gst-plugins-base - gst-plugins-good - gst-plugins-ugly - gstreamer - ]); + buildInputs = + [ + dbus + glib + gtk4 + libadwaita + libxml2 + openssl + sqlite + ] + ++ (with gst_all_1; [ + gst-libav + gst-plugins-bad + gst-plugins-base + gst-plugins-good + gst-plugins-ugly + gstreamer + ]); preFixup = '' - gappsWrapperArgs+=(--prefix PYTHONPATH : ${python3.pkgs.makePythonPath (with python3Packages; [ tqdm mutagen loguru ])}) + gappsWrapperArgs+=(--prefix PYTHONPATH : ${ + python3.pkgs.makePythonPath ( + with python3Packages; + [ + tqdm + mutagen + loguru + ] + ) + }) ''; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/by-name/re/responder/package.nix b/pkgs/by-name/re/responder/package.nix index 9c6b343eb5c1af..de309f97c40ffb 100644 --- a/pkgs/by-name/re/responder/package.nix +++ b/pkgs/by-name/re/responder/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, makeWrapper -, python3 +{ + lib, + fetchFromGitHub, + makeWrapper, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/re/restic-integrity/package.nix b/pkgs/by-name/re/restic-integrity/package.nix index 41bb1c318ff548..a46510bb4decee 100644 --- a/pkgs/by-name/re/restic-integrity/package.nix +++ b/pkgs/by-name/re/restic-integrity/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitea +{ + lib, + rustPlatform, + fetchFromGitea, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/re/restinio/package.nix b/pkgs/by-name/re/restinio/package.nix index d9fc3d97d61d3c..3f4a00491f134a 100644 --- a/pkgs/by-name/re/restinio/package.nix +++ b/pkgs/by-name/re/restinio/package.nix @@ -34,18 +34,25 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ cmake ]; - propagatedBuildInputs = [ - expected-lite - fmt - llhttp - openssl - pcre2 - zlib - ] ++ (if with_boost_asio then [ - boost - ] else [ - asio - ]); + propagatedBuildInputs = + [ + expected-lite + fmt + llhttp + openssl + pcre2 + zlib + ] + ++ ( + if with_boost_asio then + [ + boost + ] + else + [ + asio + ] + ); checkInputs = [ catch2_3 diff --git a/pkgs/by-name/re/restish/package.nix b/pkgs/by-name/re/restish/package.nix index a1fd639b72c1c4..6fbc233c9c0f81 100644 --- a/pkgs/by-name/re/restish/package.nix +++ b/pkgs/by-name/re/restish/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, buildGoModule -, darwin -, fetchFromGitHub -, restish -, testers -, xorg +{ + lib, + stdenv, + buildGoModule, + darwin, + fetchFromGitHub, + restish, + testers, + xorg, }: buildGoModule rec { @@ -21,16 +22,18 @@ buildGoModule rec { vendorHash = "sha256-qeArar0WnMACUnKBlC+PcFeJPzofwbK440A4M/rQ04U="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Cocoa - darwin.apple_sdk.frameworks.Kernel - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - xorg.libX11 - xorg.libXcursor - xorg.libXi - xorg.libXinerama - xorg.libXrandr - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Cocoa + darwin.apple_sdk.frameworks.Kernel + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + xorg.libX11 + xorg.libXcursor + xorg.libXi + xorg.libXinerama + xorg.libXrandr + ]; ldflags = [ "-s" diff --git a/pkgs/by-name/re/restls/package.nix b/pkgs/by-name/re/restls/package.nix index c0164322322c03..80a430d7cada52 100644 --- a/pkgs/by-name/re/restls/package.nix +++ b/pkgs/by-name/re/restls/package.nix @@ -1,9 +1,10 @@ -{ fetchFromGitHub -, rustPlatform -, lib +{ + fetchFromGitHub, + rustPlatform, + lib, }: -rustPlatform.buildRustPackage rec{ +rustPlatform.buildRustPackage rec { pname = "restls"; version = "0.1.1"; diff --git a/pkgs/by-name/re/restool/package.nix b/pkgs/by-name/re/restool/package.nix index 98e4a9c325296e..09a18b327a577a 100644 --- a/pkgs/by-name/re/restool/package.nix +++ b/pkgs/by-name/re/restool/package.nix @@ -1,4 +1,17 @@ -{ stdenv, lib, fetchFromGitHub, bash, coreutils, dtc, file, gawk, gnugrep, gnused, pandoc, which }: +{ + stdenv, + lib, + fetchFromGitHub, + bash, + coreutils, + dtc, + file, + gawk, + gnugrep, + gnused, + pandoc, + which, +}: stdenv.mkDerivation rec { pname = "restool"; @@ -11,8 +24,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-ryTDyqSy39e8Omf7l8lK4mLWr8jccDhMVPldkVGSQVo="; }; - nativeBuildInputs = [ file pandoc ]; - buildInputs = [ bash coreutils dtc gawk gnugrep gnused which ]; + nativeBuildInputs = [ + file + pandoc + ]; + buildInputs = [ + bash + coreutils + dtc + gawk + gnugrep + gnused + which + ]; enableParallelBuilding = true; makeFlags = [ diff --git a/pkgs/by-name/re/restream/package.nix b/pkgs/by-name/re/restream/package.nix index b5e808339f99d4..80587208efc2f9 100644 --- a/pkgs/by-name/re/restream/package.nix +++ b/pkgs/by-name/re/restream/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, lz4 -, ffmpeg-full -, fetchFromGitHub -, openssh -, netcat +{ + lib, + stdenv, + lz4, + ffmpeg-full, + fetchFromGitHub, + openssh, + netcat, }: stdenv.mkDerivation rec { @@ -30,23 +31,25 @@ stdenv.mkDerivation rec { runHook postInstall ''; - postInstall = let - deps = [ - # `ffmpeg-full` is used here to bring in `ffplay`, which is used - # to display the reMarkable framebuffer - ffmpeg-full - lz4 - openssh - # Libressl netcat brings in `nc` which used for --uncompressed mode. - netcat - ]; - in '' - # This `sed` command has the same effect as `wrapProgram`, except - # without .restream-wrapped store paths appearing everywhere. - sed -i \ - '2i export PATH=$PATH''${PATH:+':'}${lib.makeBinPath deps}' \ - "$out/bin/restream" - ''; + postInstall = + let + deps = [ + # `ffmpeg-full` is used here to bring in `ffplay`, which is used + # to display the reMarkable framebuffer + ffmpeg-full + lz4 + openssh + # Libressl netcat brings in `nc` which used for --uncompressed mode. + netcat + ]; + in + '' + # This `sed` command has the same effect as `wrapProgram`, except + # without .restream-wrapped store paths appearing everywhere. + sed -i \ + '2i export PATH=$PATH''${PATH:+':'}${lib.makeBinPath deps}' \ + "$out/bin/restream" + ''; meta = with lib; { description = "reMarkable screen sharing over SSH"; diff --git a/pkgs/by-name/re/resumed/package.nix b/pkgs/by-name/re/resumed/package.nix index 81550925368e21..78d8836a55923d 100644 --- a/pkgs/by-name/re/resumed/package.nix +++ b/pkgs/by-name/re/resumed/package.nix @@ -1,4 +1,8 @@ -{ lib, buildNpmPackage, fetchFromGitHub }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, +}: buildNpmPackage rec { pname = "resumed"; diff --git a/pkgs/by-name/re/resvg/package.nix b/pkgs/by-name/re/resvg/package.nix index ab505c4e386307..97b3817ef7c551 100644 --- a/pkgs/by-name/re/resvg/package.nix +++ b/pkgs/by-name/re/resvg/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "resvg"; diff --git a/pkgs/by-name/re/retool/package.nix b/pkgs/by-name/re/retool/package.nix index 15e2c15a5e85ce..659784f8583933 100644 --- a/pkgs/by-name/re/retool/package.nix +++ b/pkgs/by-name/re/retool/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, python3 -, fetchFromGitHub -, qt6 +{ + lib, + stdenv, + python3, + fetchFromGitHub, + qt6, }: python3.pkgs.buildPythonApplication rec { @@ -26,12 +27,13 @@ python3.pkgs.buildPythonApplication rec { pythonRelaxDeps = true; - buildInputs = [ - qt6.qtbase - ] ++ - lib.optionals (stdenv.hostPlatform.isLinux) [ - qt6.qtwayland - ]; + buildInputs = + [ + qt6.qtbase + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux) [ + qt6.qtwayland + ]; propagatedBuildInputs = with python3.pkgs; [ alive-progress diff --git a/pkgs/by-name/re/retro-gtk/package.nix b/pkgs/by-name/re/retro-gtk/package.nix index 07498530824403..29ff180ad15cf9 100644 --- a/pkgs/by-name/re/retro-gtk/package.nix +++ b/pkgs/by-name/re/retro-gtk/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, meson -, ninja -, pkg-config -, libepoxy -, glib -, gtk3 -, libpulseaudio -, libsamplerate -, gobject-introspection -, vala -, gtk-doc +{ + lib, + stdenv, + fetchurl, + fetchpatch, + meson, + ninja, + pkg-config, + libepoxy, + glib, + gtk3, + libpulseaudio, + libsamplerate, + gobject-introspection, + vala, + gtk-doc, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/re/retroarch-bare/package.nix b/pkgs/by-name/re/retroarch-bare/package.nix index c34dd7e924690b..584724f7490ec7 100644 --- a/pkgs/by-name/re/retroarch-bare/package.nix +++ b/pkgs/by-name/re/retroarch-bare/package.nix @@ -67,10 +67,13 @@ stdenv.mkDerivation rec { rev = "v${version}"; }; - nativeBuildInputs = [ - pkg-config - qt5.wrapQtAppsHook - ] ++ lib.optional withWayland wayland ++ lib.optional (runtimeLibs != [ ]) makeBinaryWrapper; + nativeBuildInputs = + [ + pkg-config + qt5.wrapQtAppsHook + ] + ++ lib.optional withWayland wayland + ++ lib.optional (runtimeLibs != [ ]) makeBinaryWrapper; buildInputs = [ diff --git a/pkgs/by-name/re/retrofe/package.nix b/pkgs/by-name/re/retrofe/package.nix index 37e05f744d8bf1..adfeed89ed97d2 100644 --- a/pkgs/by-name/re/retrofe/package.nix +++ b/pkgs/by-name/re/retrofe/package.nix @@ -1,5 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, cmake, glib, gst_all_1, makeWrapper, pkg-config -, python3, SDL2, SDL2_image, SDL2_mixer, SDL2_ttf, sqlite, zlib, runtimeShell +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + glib, + gst_all_1, + makeWrapper, + pkg-config, + python3, + SDL2, + SDL2_image, + SDL2_mixer, + SDL2_ttf, + sqlite, + zlib, + runtimeShell, }: stdenv.mkDerivation { @@ -13,11 +28,29 @@ stdenv.mkDerivation { sha256 = "sha256-uBfECbU2Df/pPpEXXq62S7Ec0YU4lPIsZ8k5UmKD7xQ="; }; - nativeBuildInputs = [ cmake makeWrapper pkg-config python3 ]; + nativeBuildInputs = [ + cmake + makeWrapper + pkg-config + python3 + ]; - buildInputs = [ - glib gst_all_1.gstreamer SDL2 SDL2_image SDL2_mixer SDL2_ttf sqlite zlib - ] ++ (with gst_all_1; [ gst-libav gst-plugins-base gst-plugins-good ]); + buildInputs = + [ + glib + gst_all_1.gstreamer + SDL2 + SDL2_image + SDL2_mixer + SDL2_ttf + sqlite + zlib + ] + ++ (with gst_all_1; [ + gst-libav + gst-plugins-base + gst-plugins-good + ]); configurePhase = '' cmake RetroFE/Source -BRetroFE/Build -DCMAKE_BUILD_TYPE=Release \ diff --git a/pkgs/by-name/re/retrospy/deps.nix b/pkgs/by-name/re/retrospy/deps.nix index 1c0186bf83e819..f4d0d2becadc5b 100644 --- a/pkgs/by-name/re/retrospy/deps.nix +++ b/pkgs/by-name/re/retrospy/deps.nix @@ -1,71 +1,336 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Avalonia"; version = "11.1.3"; hash = "sha256-kz+k/vkuWoL0XBvRT8SadMOmmRCFk9W/J4k/IM6oYX0="; }) - (fetchNuGet { pname = "Avalonia.Angle.Windows.Natives"; version = "2.1.22045.20230930"; hash = "sha256-RxPcWUT3b/+R3Tu5E5ftpr5ppCLZrhm+OTsi0SwW3pc="; }) - (fetchNuGet { pname = "Avalonia.BuildServices"; version = "0.0.29"; hash = "sha256-WPHRMNowRnYSCh88DWNBCltWsLPyOfzXGzBqLYE7tRY="; }) - (fetchNuGet { pname = "Avalonia.Controls.ColorPicker"; version = "11.1.3"; hash = "sha256-W17Wvmi8/47cf5gCF3QRcaKLz0ZpXtZYCCkaERkbyXU="; }) - (fetchNuGet { pname = "Avalonia.Controls.DataGrid"; version = "11.1.3"; hash = "sha256-OOKTovi5kckn0x/8dMcq56cvq57UVMLzA9LRXDxm2Vc="; }) - (fetchNuGet { pname = "Avalonia.Desktop"; version = "11.1.3"; hash = "sha256-mNFscbtyqLlodzGa3SJ3oVY467JjWwY45LxZiKDAn/w="; }) - (fetchNuGet { pname = "Avalonia.Diagnostics"; version = "11.1.3"; hash = "sha256-PD9ZIeBZJrLaVDjmWBz4GocrdUSNUou11gAERU+xWDo="; }) - (fetchNuGet { pname = "Avalonia.FreeDesktop"; version = "11.1.3"; hash = "sha256-nUBhSRE0Bly3dVC14wXwU19vP3g0VbE4bCUohx7DCVI="; }) - (fetchNuGet { pname = "Avalonia.Native"; version = "11.1.3"; hash = "sha256-byAVGW7XgkyzDj1TnqaCeDU/xTD9z8ACGrSJgwJ+XXs="; }) - (fetchNuGet { pname = "Avalonia.ReactiveUI"; version = "11.1.3"; hash = "sha256-1VCFAJPKpLx9KyM5AK/8XbGtxNpGriQEFqidgN9eCtE="; }) - (fetchNuGet { pname = "Avalonia.Remote.Protocol"; version = "11.1.3"; hash = "sha256-CKF+62zCbK1Rd/HiC6MGrags3ylXrVQ1lni3Um0Muqk="; }) - (fetchNuGet { pname = "Avalonia.Skia"; version = "11.1.3"; hash = "sha256-EtB86g+nz6i8wL6xytMkYl2Ehgt3GFMMNPzQfhbfopM="; }) - (fetchNuGet { pname = "Avalonia.Themes.Fluent"; version = "11.1.3"; hash = "sha256-qfmRK2gLGSgHx4dNIeVesWxLUjcook9ET2xru/Xyiw8="; }) - (fetchNuGet { pname = "Avalonia.Themes.Simple"; version = "11.1.3"; hash = "sha256-Q6jL5J/6aBtOY85I641RVp8RpuqJbPy6C6LxnRkFtMM="; }) - (fetchNuGet { pname = "Avalonia.Win32"; version = "11.1.3"; hash = "sha256-zcxTpEnpLf50p8Yaiylk5/CS9MNDe7lK1uX1CPaJBUc="; }) - (fetchNuGet { pname = "Avalonia.X11"; version = "11.1.3"; hash = "sha256-M2+y661/znDxZRdwNRIQi4mS2m6T4kQkBbYeE7KyQAw="; }) - (fetchNuGet { pname = "ColorTextBlock.Avalonia"; version = "11.0.2"; hash = "sha256-FmaYhszWp/VCIp4BUnWXGMQr62WzVNUo/IKEbN59bX8="; }) - (fetchNuGet { pname = "Desktop.Robot"; version = "1.5.0"; hash = "sha256-ITeVX2oAcST/HMbG4Ygg+inPuciXZaBVJ5Ozk/Zl6Pg="; }) - (fetchNuGet { pname = "DialogHost.Avalonia"; version = "0.7.7"; hash = "sha256-pXRv4P4i/zxZ1Ucq3kaGs9HKNG+4CNB4n33YswbjEio="; }) - (fetchNuGet { pname = "DynamicData"; version = "7.9.5"; hash = "sha256-3XjOMuFathku9oWyss360+Ze5UMP7tSmUbMoax7qONU="; }) - (fetchNuGet { pname = "HarfBuzzSharp"; version = "7.3.0.2"; hash = "sha256-ibgoqzT1NV7Qo5e7X2W6Vt7989TKrkd2M2pu+lhSDg8="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Linux"; version = "7.3.0.2"; hash = "sha256-SSfyuyBaduGobJW+reqyioWHhFWsQ+FXa2Gn7TiWxrU="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.macOS"; version = "7.3.0.2"; hash = "sha256-dmEqR9MmpCwK8AuscfC7xUlnKIY7+Nvi06V0u5Jff08="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; version = "7.3.0.2"; hash = "sha256-aEZr9uKAlCTeeHoYNR1Rs6L3P54765CemyrgJF8x09c="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Win32"; version = "7.3.0.2"; hash = "sha256-x4iM3NHs9VyweG57xA74yd4uLuXly147ooe0mvNQ8zo="; }) - (fetchNuGet { pname = "LibUsbDotNet"; version = "3.0.102-alpha"; hash = "sha256-oJGtzJvnKM53fcZLnvQZKvBOwjAiH/T7o+b8IhUyHxY="; }) - (fetchNuGet { pname = "Markdown.Avalonia.Tight"; version = "11.0.2"; hash = "sha256-9P3/ZCF1psp8VoZMzJJlnoqz2y2EytmBGDc4QXIS4tc="; }) - (fetchNuGet { pname = "MessageBox.Avalonia"; version = "3.1.6"; hash = "sha256-Jg7Ul2JkLq9eUvd42vD8B7itsZYtxHhm4XRQWHkhLN0="; }) - (fetchNuGet { pname = "MicroCom.Runtime"; version = "0.11.0"; hash = "sha256-VdwpP5fsclvNqJuppaOvwEwv2ofnAI5ZSz2V+UEdLF0="; }) - (fetchNuGet { pname = "Microsoft.Win32.SystemEvents"; version = "6.0.0"; hash = "sha256-N9EVZbl5w1VnMywGXyaVWzT9lh84iaJ3aD48hIBk1zA="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.3"; hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; }) - (fetchNuGet { pname = "NodaTime"; version = "3.1.11"; hash = "sha256-ZvJlCEjq61KS3qr4Lw/C+yyagic4rESZ7qa0RGul/sU="; }) - (fetchNuGet { pname = "ReactiveUI"; version = "18.3.1"; hash = "sha256-1rf4icGRKTR3XIWJpkQJCG7ObRM+72ITB5K+ND1is9M="; }) - (fetchNuGet { pname = "runtime.linux-arm.runtime.native.System.IO.Ports"; version = "8.0.0"; hash = "sha256-m5+od7ZhlzImwSE9E7Qq1nH3A3muXwCnsvrVUoJ7+WE="; }) - (fetchNuGet { pname = "runtime.linux-arm64.runtime.native.System.IO.Ports"; version = "8.0.0"; hash = "sha256-IgbG3HT3A0VItWl5asE7Hk0zaQjQneKQS9f65cQAjLI="; }) - (fetchNuGet { pname = "runtime.linux-x64.runtime.native.System.IO.Ports"; version = "8.0.0"; hash = "sha256-44oujSHhc0Nl2WCvLYkScrAyqNAlbGfOnlzPwCofwlA="; }) - (fetchNuGet { pname = "runtime.native.System.IO.Ports"; version = "8.0.0"; hash = "sha256-BqExVU/zHj7o++mzOpY9y+i9yZZVbcGmO/D4mRzigY8="; }) - (fetchNuGet { pname = "runtime.osx-arm64.runtime.native.System.IO.Ports"; version = "8.0.0"; hash = "sha256-oFMF60yyTy3fXwLlXJkNUtzdRz4EyxevAUIcfcVESCE="; }) - (fetchNuGet { pname = "runtime.osx-x64.runtime.native.System.IO.Ports"; version = "8.0.0"; hash = "sha256-b2J9DcunMtChpuyNC0XN39Z01Wr738HI/syJW1n9bfE="; }) - (fetchNuGet { pname = "SharpGen.Runtime"; version = "2.1.2-beta"; hash = "sha256-wM8plHp9m+pnKPK0vu9BRburPMIL2lwxdRkQFEhjbDk="; }) - (fetchNuGet { pname = "SharpGen.Runtime.COM"; version = "2.1.2-beta"; hash = "sha256-VGmWpeLV4v8gfqtJKKU43rUad9CDgdIO+lmUUa65XJE="; }) - (fetchNuGet { pname = "SixLabors.ImageSharp"; version = "3.1.5"; hash = "sha256-3UehX9T+I81nfgv2dTHlpoPgYzXFk7kHr1mmlQOCBfw="; }) - (fetchNuGet { pname = "SkiaSharp"; version = "2.88.8"; hash = "sha256-rD5gc4SnlRTXwz367uHm8XG5eAIQpZloGqLRGnvNu0A="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Linux"; version = "2.88.8"; hash = "sha256-fOmNbbjuTazIasOvPkd2NPmuQHVCWPnow7AxllRGl7Y="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.macOS"; version = "2.88.8"; hash = "sha256-CdcrzQHwCcmOCPtS8EGtwsKsgdljnH41sFytW7N9PmI="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.WebAssembly"; version = "2.88.8"; hash = "sha256-GWWsE98f869LiOlqZuXMc9+yuuIhey2LeftGNk3/z3w="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Win32"; version = "2.88.8"; hash = "sha256-b8Vb94rNjwPKSJDQgZ0Xv2dWV7gMVFl5GwTK/QiZPPM="; }) - (fetchNuGet { pname = "Splat"; version = "14.4.1"; hash = "sha256-i1yzIVpKdFjZMI4J8H970nZCxszklgDitYTEKKz0zA8="; }) - (fetchNuGet { pname = "SSH.NET"; version = "2024.1.0"; hash = "sha256-R1KYZTq0XGO2gIiCeGzgw36ByQRxb+2Oip/NvDeZqzs="; }) - (fetchNuGet { pname = "System.CodeDom"; version = "8.0.0"; hash = "sha256-uwVhi3xcvX7eiOGQi7dRETk3Qx1EfHsUfchZsEto338="; }) - (fetchNuGet { pname = "System.Configuration.ConfigurationManager"; version = "8.0.0"; hash = "sha256-xhljqSkNQk8DMkEOBSYnn9lzCSEDDq4yO910itptqiE="; }) - (fetchNuGet { pname = "System.Diagnostics.EventLog"; version = "8.0.0"; hash = "sha256-rt8xc3kddpQY4HEdghlBeOK4gdw5yIj4mcZhAVtk2/Y="; }) - (fetchNuGet { pname = "System.Drawing.Common"; version = "6.0.0"; hash = "sha256-/9EaAbEeOjELRSMZaImS1O8FmUe8j4WuFUw1VOrPyAo="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "6.0.0"; hash = "sha256-xfjF4UqTMJpf8KsBWUyJlJkzPTOO/H5MW023yTYNQSA="; }) - (fetchNuGet { pname = "System.IO.Ports"; version = "8.0.0"; hash = "sha256-G8j9c0erBzZfJAVlW08XoE58gPhiNWJE78sFaBV2e4Q="; }) - (fetchNuGet { pname = "System.Management"; version = "8.0.0"; hash = "sha256-HwpfDb++q7/vxR6q57mGFgl5U0vxy+oRJ6orFKORfP0="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; }) - (fetchNuGet { pname = "System.Reactive"; version = "6.0.0"; hash = "sha256-hXB18OsiUHSCmRF3unAfdUEcbXVbG6/nZxcyz13oe9Y="; }) - (fetchNuGet { pname = "System.Reactive"; version = "6.0.1"; hash = "sha256-Lo5UMqp8DsbVSUxa2UpClR1GoYzqQQcSxkfyFqB/d4Q="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.7.1"; hash = "sha256-UvyoDV8O0oY3HPG1GbA56YVdvwTGEfjYR5gW1O7IK4U="; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "8.0.0"; hash = "sha256-fb0pa9sQxN+mr0vnXg1Igbx49CaOqS+GDkTfWNboUvs="; }) - (fetchNuGet { pname = "Tmds.DBus.Protocol"; version = "0.16.0"; hash = "sha256-vKYEaa1EszR7alHj48R8G3uYArhI+zh2ZgiBv955E98="; }) - (fetchNuGet { pname = "Vortice.DirectInput"; version = "3.5.0"; hash = "sha256-TxUIn0YXlzWHGyMAOVVC0SiNaM2vFqa0ddFpoWH0fwI="; }) - (fetchNuGet { pname = "Vortice.DirectX"; version = "3.5.0"; hash = "sha256-cHoY2+czSdj3w3qcGeCTN0iU2nY9xbMrfK80RGEoDzk="; }) - (fetchNuGet { pname = "Vortice.Mathematics"; version = "1.7.8"; hash = "sha256-8tHkHDvHMT3iDKDkVIms9tZnspBaw0nbvYyXUsUGv8A="; }) - (fetchNuGet { pname = "Vortice.XInput"; version = "3.5.0"; hash = "sha256-w4VJlkGjEmD/QElDZ3ZJS+GbN/4+yyVeJq1Le7Mdas8="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Avalonia"; + version = "11.1.3"; + hash = "sha256-kz+k/vkuWoL0XBvRT8SadMOmmRCFk9W/J4k/IM6oYX0="; + }) + (fetchNuGet { + pname = "Avalonia.Angle.Windows.Natives"; + version = "2.1.22045.20230930"; + hash = "sha256-RxPcWUT3b/+R3Tu5E5ftpr5ppCLZrhm+OTsi0SwW3pc="; + }) + (fetchNuGet { + pname = "Avalonia.BuildServices"; + version = "0.0.29"; + hash = "sha256-WPHRMNowRnYSCh88DWNBCltWsLPyOfzXGzBqLYE7tRY="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.ColorPicker"; + version = "11.1.3"; + hash = "sha256-W17Wvmi8/47cf5gCF3QRcaKLz0ZpXtZYCCkaERkbyXU="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.DataGrid"; + version = "11.1.3"; + hash = "sha256-OOKTovi5kckn0x/8dMcq56cvq57UVMLzA9LRXDxm2Vc="; + }) + (fetchNuGet { + pname = "Avalonia.Desktop"; + version = "11.1.3"; + hash = "sha256-mNFscbtyqLlodzGa3SJ3oVY467JjWwY45LxZiKDAn/w="; + }) + (fetchNuGet { + pname = "Avalonia.Diagnostics"; + version = "11.1.3"; + hash = "sha256-PD9ZIeBZJrLaVDjmWBz4GocrdUSNUou11gAERU+xWDo="; + }) + (fetchNuGet { + pname = "Avalonia.FreeDesktop"; + version = "11.1.3"; + hash = "sha256-nUBhSRE0Bly3dVC14wXwU19vP3g0VbE4bCUohx7DCVI="; + }) + (fetchNuGet { + pname = "Avalonia.Native"; + version = "11.1.3"; + hash = "sha256-byAVGW7XgkyzDj1TnqaCeDU/xTD9z8ACGrSJgwJ+XXs="; + }) + (fetchNuGet { + pname = "Avalonia.ReactiveUI"; + version = "11.1.3"; + hash = "sha256-1VCFAJPKpLx9KyM5AK/8XbGtxNpGriQEFqidgN9eCtE="; + }) + (fetchNuGet { + pname = "Avalonia.Remote.Protocol"; + version = "11.1.3"; + hash = "sha256-CKF+62zCbK1Rd/HiC6MGrags3ylXrVQ1lni3Um0Muqk="; + }) + (fetchNuGet { + pname = "Avalonia.Skia"; + version = "11.1.3"; + hash = "sha256-EtB86g+nz6i8wL6xytMkYl2Ehgt3GFMMNPzQfhbfopM="; + }) + (fetchNuGet { + pname = "Avalonia.Themes.Fluent"; + version = "11.1.3"; + hash = "sha256-qfmRK2gLGSgHx4dNIeVesWxLUjcook9ET2xru/Xyiw8="; + }) + (fetchNuGet { + pname = "Avalonia.Themes.Simple"; + version = "11.1.3"; + hash = "sha256-Q6jL5J/6aBtOY85I641RVp8RpuqJbPy6C6LxnRkFtMM="; + }) + (fetchNuGet { + pname = "Avalonia.Win32"; + version = "11.1.3"; + hash = "sha256-zcxTpEnpLf50p8Yaiylk5/CS9MNDe7lK1uX1CPaJBUc="; + }) + (fetchNuGet { + pname = "Avalonia.X11"; + version = "11.1.3"; + hash = "sha256-M2+y661/znDxZRdwNRIQi4mS2m6T4kQkBbYeE7KyQAw="; + }) + (fetchNuGet { + pname = "ColorTextBlock.Avalonia"; + version = "11.0.2"; + hash = "sha256-FmaYhszWp/VCIp4BUnWXGMQr62WzVNUo/IKEbN59bX8="; + }) + (fetchNuGet { + pname = "Desktop.Robot"; + version = "1.5.0"; + hash = "sha256-ITeVX2oAcST/HMbG4Ygg+inPuciXZaBVJ5Ozk/Zl6Pg="; + }) + (fetchNuGet { + pname = "DialogHost.Avalonia"; + version = "0.7.7"; + hash = "sha256-pXRv4P4i/zxZ1Ucq3kaGs9HKNG+4CNB4n33YswbjEio="; + }) + (fetchNuGet { + pname = "DynamicData"; + version = "7.9.5"; + hash = "sha256-3XjOMuFathku9oWyss360+Ze5UMP7tSmUbMoax7qONU="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp"; + version = "7.3.0.2"; + hash = "sha256-ibgoqzT1NV7Qo5e7X2W6Vt7989TKrkd2M2pu+lhSDg8="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Linux"; + version = "7.3.0.2"; + hash = "sha256-SSfyuyBaduGobJW+reqyioWHhFWsQ+FXa2Gn7TiWxrU="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.macOS"; + version = "7.3.0.2"; + hash = "sha256-dmEqR9MmpCwK8AuscfC7xUlnKIY7+Nvi06V0u5Jff08="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; + version = "7.3.0.2"; + hash = "sha256-aEZr9uKAlCTeeHoYNR1Rs6L3P54765CemyrgJF8x09c="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Win32"; + version = "7.3.0.2"; + hash = "sha256-x4iM3NHs9VyweG57xA74yd4uLuXly147ooe0mvNQ8zo="; + }) + (fetchNuGet { + pname = "LibUsbDotNet"; + version = "3.0.102-alpha"; + hash = "sha256-oJGtzJvnKM53fcZLnvQZKvBOwjAiH/T7o+b8IhUyHxY="; + }) + (fetchNuGet { + pname = "Markdown.Avalonia.Tight"; + version = "11.0.2"; + hash = "sha256-9P3/ZCF1psp8VoZMzJJlnoqz2y2EytmBGDc4QXIS4tc="; + }) + (fetchNuGet { + pname = "MessageBox.Avalonia"; + version = "3.1.6"; + hash = "sha256-Jg7Ul2JkLq9eUvd42vD8B7itsZYtxHhm4XRQWHkhLN0="; + }) + (fetchNuGet { + pname = "MicroCom.Runtime"; + version = "0.11.0"; + hash = "sha256-VdwpP5fsclvNqJuppaOvwEwv2ofnAI5ZSz2V+UEdLF0="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.SystemEvents"; + version = "6.0.0"; + hash = "sha256-N9EVZbl5w1VnMywGXyaVWzT9lh84iaJ3aD48hIBk1zA="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.3"; + hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; + }) + (fetchNuGet { + pname = "NodaTime"; + version = "3.1.11"; + hash = "sha256-ZvJlCEjq61KS3qr4Lw/C+yyagic4rESZ7qa0RGul/sU="; + }) + (fetchNuGet { + pname = "ReactiveUI"; + version = "18.3.1"; + hash = "sha256-1rf4icGRKTR3XIWJpkQJCG7ObRM+72ITB5K+ND1is9M="; + }) + (fetchNuGet { + pname = "runtime.linux-arm.runtime.native.System.IO.Ports"; + version = "8.0.0"; + hash = "sha256-m5+od7ZhlzImwSE9E7Qq1nH3A3muXwCnsvrVUoJ7+WE="; + }) + (fetchNuGet { + pname = "runtime.linux-arm64.runtime.native.System.IO.Ports"; + version = "8.0.0"; + hash = "sha256-IgbG3HT3A0VItWl5asE7Hk0zaQjQneKQS9f65cQAjLI="; + }) + (fetchNuGet { + pname = "runtime.linux-x64.runtime.native.System.IO.Ports"; + version = "8.0.0"; + hash = "sha256-44oujSHhc0Nl2WCvLYkScrAyqNAlbGfOnlzPwCofwlA="; + }) + (fetchNuGet { + pname = "runtime.native.System.IO.Ports"; + version = "8.0.0"; + hash = "sha256-BqExVU/zHj7o++mzOpY9y+i9yZZVbcGmO/D4mRzigY8="; + }) + (fetchNuGet { + pname = "runtime.osx-arm64.runtime.native.System.IO.Ports"; + version = "8.0.0"; + hash = "sha256-oFMF60yyTy3fXwLlXJkNUtzdRz4EyxevAUIcfcVESCE="; + }) + (fetchNuGet { + pname = "runtime.osx-x64.runtime.native.System.IO.Ports"; + version = "8.0.0"; + hash = "sha256-b2J9DcunMtChpuyNC0XN39Z01Wr738HI/syJW1n9bfE="; + }) + (fetchNuGet { + pname = "SharpGen.Runtime"; + version = "2.1.2-beta"; + hash = "sha256-wM8plHp9m+pnKPK0vu9BRburPMIL2lwxdRkQFEhjbDk="; + }) + (fetchNuGet { + pname = "SharpGen.Runtime.COM"; + version = "2.1.2-beta"; + hash = "sha256-VGmWpeLV4v8gfqtJKKU43rUad9CDgdIO+lmUUa65XJE="; + }) + (fetchNuGet { + pname = "SixLabors.ImageSharp"; + version = "3.1.5"; + hash = "sha256-3UehX9T+I81nfgv2dTHlpoPgYzXFk7kHr1mmlQOCBfw="; + }) + (fetchNuGet { + pname = "SkiaSharp"; + version = "2.88.8"; + hash = "sha256-rD5gc4SnlRTXwz367uHm8XG5eAIQpZloGqLRGnvNu0A="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Linux"; + version = "2.88.8"; + hash = "sha256-fOmNbbjuTazIasOvPkd2NPmuQHVCWPnow7AxllRGl7Y="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.macOS"; + version = "2.88.8"; + hash = "sha256-CdcrzQHwCcmOCPtS8EGtwsKsgdljnH41sFytW7N9PmI="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.WebAssembly"; + version = "2.88.8"; + hash = "sha256-GWWsE98f869LiOlqZuXMc9+yuuIhey2LeftGNk3/z3w="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Win32"; + version = "2.88.8"; + hash = "sha256-b8Vb94rNjwPKSJDQgZ0Xv2dWV7gMVFl5GwTK/QiZPPM="; + }) + (fetchNuGet { + pname = "Splat"; + version = "14.4.1"; + hash = "sha256-i1yzIVpKdFjZMI4J8H970nZCxszklgDitYTEKKz0zA8="; + }) + (fetchNuGet { + pname = "SSH.NET"; + version = "2024.1.0"; + hash = "sha256-R1KYZTq0XGO2gIiCeGzgw36ByQRxb+2Oip/NvDeZqzs="; + }) + (fetchNuGet { + pname = "System.CodeDom"; + version = "8.0.0"; + hash = "sha256-uwVhi3xcvX7eiOGQi7dRETk3Qx1EfHsUfchZsEto338="; + }) + (fetchNuGet { + pname = "System.Configuration.ConfigurationManager"; + version = "8.0.0"; + hash = "sha256-xhljqSkNQk8DMkEOBSYnn9lzCSEDDq4yO910itptqiE="; + }) + (fetchNuGet { + pname = "System.Diagnostics.EventLog"; + version = "8.0.0"; + hash = "sha256-rt8xc3kddpQY4HEdghlBeOK4gdw5yIj4mcZhAVtk2/Y="; + }) + (fetchNuGet { + pname = "System.Drawing.Common"; + version = "6.0.0"; + hash = "sha256-/9EaAbEeOjELRSMZaImS1O8FmUe8j4WuFUw1VOrPyAo="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "6.0.0"; + hash = "sha256-xfjF4UqTMJpf8KsBWUyJlJkzPTOO/H5MW023yTYNQSA="; + }) + (fetchNuGet { + pname = "System.IO.Ports"; + version = "8.0.0"; + hash = "sha256-G8j9c0erBzZfJAVlW08XoE58gPhiNWJE78sFaBV2e4Q="; + }) + (fetchNuGet { + pname = "System.Management"; + version = "8.0.0"; + hash = "sha256-HwpfDb++q7/vxR6q57mGFgl5U0vxy+oRJ6orFKORfP0="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; + }) + (fetchNuGet { + pname = "System.Reactive"; + version = "6.0.0"; + hash = "sha256-hXB18OsiUHSCmRF3unAfdUEcbXVbG6/nZxcyz13oe9Y="; + }) + (fetchNuGet { + pname = "System.Reactive"; + version = "6.0.1"; + hash = "sha256-Lo5UMqp8DsbVSUxa2UpClR1GoYzqQQcSxkfyFqB/d4Q="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.7.1"; + hash = "sha256-UvyoDV8O0oY3HPG1GbA56YVdvwTGEfjYR5gW1O7IK4U="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "8.0.0"; + hash = "sha256-fb0pa9sQxN+mr0vnXg1Igbx49CaOqS+GDkTfWNboUvs="; + }) + (fetchNuGet { + pname = "Tmds.DBus.Protocol"; + version = "0.16.0"; + hash = "sha256-vKYEaa1EszR7alHj48R8G3uYArhI+zh2ZgiBv955E98="; + }) + (fetchNuGet { + pname = "Vortice.DirectInput"; + version = "3.5.0"; + hash = "sha256-TxUIn0YXlzWHGyMAOVVC0SiNaM2vFqa0ddFpoWH0fwI="; + }) + (fetchNuGet { + pname = "Vortice.DirectX"; + version = "3.5.0"; + hash = "sha256-cHoY2+czSdj3w3qcGeCTN0iU2nY9xbMrfK80RGEoDzk="; + }) + (fetchNuGet { + pname = "Vortice.Mathematics"; + version = "1.7.8"; + hash = "sha256-8tHkHDvHMT3iDKDkVIms9tZnspBaw0nbvYyXUsUGv8A="; + }) + (fetchNuGet { + pname = "Vortice.XInput"; + version = "3.5.0"; + hash = "sha256-w4VJlkGjEmD/QElDZ3ZJS+GbN/4+yyVeJq1Le7Mdas8="; + }) ] diff --git a/pkgs/by-name/re/retrospy/package.nix b/pkgs/by-name/re/retrospy/package.nix index a207150e1e4723..06348fbf92ede6 100644 --- a/pkgs/by-name/re/retrospy/package.nix +++ b/pkgs/by-name/re/retrospy/package.nix @@ -1,10 +1,11 @@ -{ buildDotnetModule -, fetchFromGitHub -, dotnetCorePackages -, copyDesktopItems -, makeDesktopItem -, lib -, runCommandLocal +{ + buildDotnetModule, + fetchFromGitHub, + dotnetCorePackages, + copyDesktopItems, + makeDesktopItem, + lib, + runCommandLocal, }: let version = "6.6"; @@ -25,7 +26,9 @@ let retrospy-icons = runCommandLocal "retrospy-icons" { } '' mkdir -p $out/share/retrospy - ${builtins.concatStringsSep "\n" (map (e: "cp ${src}/${e}.ico $out/share/retrospy/${e}.ico") executables)} + ${builtins.concatStringsSep "\n" ( + map (e: "cp ${src}/${e}.ico $out/share/retrospy/${e}.ico") executables + )} ''; in buildDotnetModule { @@ -54,16 +57,17 @@ buildDotnetModule { passthru.updateScript = ./update.sh; - desktopItems = map - (e: (makeDesktopItem { + desktopItems = map ( + e: + (makeDesktopItem { name = e; exec = e; icon = "${retrospy-icons}/share/retrospy/${e}.ico"; desktopName = "${e}"; categories = [ "Utility" ]; startupWMClass = e; - })) - executables; + }) + ) executables; meta = { description = "Live controller viewer for Nintendo consoles as well as many other retro consoles and computers"; @@ -74,4 +78,3 @@ buildDotnetModule { platforms = lib.platforms.linux; }; } - diff --git a/pkgs/by-name/re/retry/package.nix b/pkgs/by-name/re/retry/package.nix index 998ba8cb728685..2adc778d53db4a 100644 --- a/pkgs/by-name/re/retry/package.nix +++ b/pkgs/by-name/re/retry/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, txt2man -, which +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + txt2man, + which, }: stdenv.mkDerivation rec { @@ -17,7 +18,11 @@ stdenv.mkDerivation rec { hash = "sha256-5H2MnnThi4rT/o3oTkGDKXStQwob4G9mMsZewItPub4="; }; - nativeBuildInputs = [ autoreconfHook txt2man which ]; + nativeBuildInputs = [ + autoreconfHook + txt2man + which + ]; meta = with lib; { homepage = "https://github.com/minfrin/retry"; @@ -28,4 +33,3 @@ stdenv.mkDerivation rec { mainProgram = "retry"; }; } - diff --git a/pkgs/by-name/re/revanced-cli/package.nix b/pkgs/by-name/re/revanced-cli/package.nix index dd85f8e83cc2b5..00e725434f6dac 100644 --- a/pkgs/by-name/re/revanced-cli/package.nix +++ b/pkgs/by-name/re/revanced-cli/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "revanced-cli"; diff --git a/pkgs/by-name/re/reveal-md/package.nix b/pkgs/by-name/re/reveal-md/package.nix index 5f38af559d9f90..1489e1fe9b7070 100644 --- a/pkgs/by-name/re/reveal-md/package.nix +++ b/pkgs/by-name/re/reveal-md/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/re/reversal-icon-theme/package.nix b/pkgs/by-name/re/reversal-icon-theme/package.nix index a9e4dcba89b902..c56104e4c28890 100644 --- a/pkgs/by-name/re/reversal-icon-theme/package.nix +++ b/pkgs/by-name/re/reversal-icon-theme/package.nix @@ -1,77 +1,92 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gtk3 -, jdupes -, adwaita-icon-theme -, hicolor-icon-theme -, numix-icon-theme-circle -, gitUpdater -, allColorVariants ? false -, colorVariants ? [] +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + jdupes, + adwaita-icon-theme, + hicolor-icon-theme, + numix-icon-theme-circle, + gitUpdater, + allColorVariants ? false, + colorVariants ? [ ], }: let pname = "reversal-icon-theme"; in -lib.checkListOfEnum "${pname}: color variants" [ "-blue" "-red" "-pink" "-purple" "-green" "-orange" "-brown" "-grey" "-black" "-cyan" ] colorVariants - -stdenvNoCC.mkDerivation rec { - inherit pname; - version = "unstable-2023-05-13"; - - src = fetchFromGitHub { - owner = "yeyushengfan258"; - repo = pname; - rev = "bdae2ea365731b25a869fc2c8c6a1fb849eaf5b2"; - hash = "sha256-Cd+1ggyS+Y2Sk8w5zifc4IFOwbFrbjL6S6awES/W0EE="; - }; - - nativeBuildInputs = [ - gtk3 - jdupes - ]; - - propagatedBuildInputs = [ - adwaita-icon-theme - hicolor-icon-theme - numix-icon-theme-circle - ]; - - dontDropIconThemeCache = true; - - # These fixup steps are slow and unnecessary for this package. - # Package may install many small files. - dontPatchELF = true; - dontRewriteSymlinks = true; - - postPatch = '' - patchShebangs install.sh - ''; - - installPhase = '' - runHook preInstall - - mkdir -p $out/share/icons - - name= ./install.sh \ - ${if allColorVariants then "-a" else builtins.toString colorVariants} \ - -d $out/share/icons - - rm $out/share/icons/*/{AUTHORS,COPYING} - - jdupes --quiet --link-soft --recurse $out/share - - runHook postInstall - ''; - - passthru.updateScript = gitUpdater { }; - - meta = with lib; { - description = "Colorful Design Rectangle icon theme"; - homepage = "https://github.com/yeyushengfan258/Reversal-icon-theme"; - license = licenses.gpl3Plus; - platforms = platforms.all; - maintainers = with maintainers; [ romildo ]; - }; -} +lib.checkListOfEnum "${pname}: color variants" + [ + "-blue" + "-red" + "-pink" + "-purple" + "-green" + "-orange" + "-brown" + "-grey" + "-black" + "-cyan" + ] + colorVariants + + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "unstable-2023-05-13"; + + src = fetchFromGitHub { + owner = "yeyushengfan258"; + repo = pname; + rev = "bdae2ea365731b25a869fc2c8c6a1fb849eaf5b2"; + hash = "sha256-Cd+1ggyS+Y2Sk8w5zifc4IFOwbFrbjL6S6awES/W0EE="; + }; + + nativeBuildInputs = [ + gtk3 + jdupes + ]; + + propagatedBuildInputs = [ + adwaita-icon-theme + hicolor-icon-theme + numix-icon-theme-circle + ]; + + dontDropIconThemeCache = true; + + # These fixup steps are slow and unnecessary for this package. + # Package may install many small files. + dontPatchELF = true; + dontRewriteSymlinks = true; + + postPatch = '' + patchShebangs install.sh + ''; + + installPhase = '' + runHook preInstall + + mkdir -p $out/share/icons + + name= ./install.sh \ + ${if allColorVariants then "-a" else builtins.toString colorVariants} \ + -d $out/share/icons + + rm $out/share/icons/*/{AUTHORS,COPYING} + + jdupes --quiet --link-soft --recurse $out/share + + runHook postInstall + ''; + + passthru.updateScript = gitUpdater { }; + + meta = with lib; { + description = "Colorful Design Rectangle icon theme"; + homepage = "https://github.com/yeyushengfan258/Reversal-icon-theme"; + license = licenses.gpl3Plus; + platforms = platforms.all; + maintainers = with maintainers; [ romildo ]; + }; + } diff --git a/pkgs/by-name/re/reviewdog/package.nix b/pkgs/by-name/re/reviewdog/package.nix index 5bd179d231c00d..099ee1949cb1c9 100644 --- a/pkgs/by-name/re/reviewdog/package.nix +++ b/pkgs/by-name/re/reviewdog/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "reviewdog"; @@ -17,7 +21,11 @@ buildGoModule rec { subPackages = [ "cmd/reviewdog" ]; - ldflags = [ "-s" "-w" "-X github.com/reviewdog/reviewdog/commands.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/reviewdog/reviewdog/commands.Version=${version}" + ]; meta = with lib; { description = "Automated code review tool integrated with any code analysis tools regardless of programming language"; diff --git a/pkgs/by-name/re/revolt-desktop/package.nix b/pkgs/by-name/re/revolt-desktop/package.nix index c996610308bf4f..ecac7b49bba5ba 100644 --- a/pkgs/by-name/re/revolt-desktop/package.nix +++ b/pkgs/by-name/re/revolt-desktop/package.nix @@ -1,10 +1,11 @@ -{ stdenvNoCC -, lib -, fetchurl -, fetchzip -, appimageTools -, makeWrapper -, electron +{ + stdenvNoCC, + lib, + fetchurl, + fetchzip, + appimageTools, + makeWrapper, + electron, }: (stdenvNoCC.mkDerivation { pname = "revolt-desktop"; diff --git a/pkgs/by-name/re/rewritefs/package.nix b/pkgs/by-name/re/rewritefs/package.nix index fc3915c66a6091..03638fb5cf57ca 100644 --- a/pkgs/by-name/re/rewritefs/package.nix +++ b/pkgs/by-name/re/rewritefs/package.nix @@ -1,18 +1,28 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, fuse3, pcre }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + fuse3, + pcre, +}: stdenv.mkDerivation { pname = "rewritefs"; version = "unstable-2021-10-03"; src = fetchFromGitHub { - owner = "sloonz"; - repo = "rewritefs"; - rev = "3a56de8b5a2d44968b8bc3885c7d661d46367306"; + owner = "sloonz"; + repo = "rewritefs"; + rev = "3a56de8b5a2d44968b8bc3885c7d661d46367306"; sha256 = "1w2rik0lhqm3wr68x51zs45gqfx79l7fi4p0sqznlfq7sz5s8xxn"; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ fuse3 pcre ]; + buildInputs = [ + fuse3 + pcre + ]; prePatch = '' # do not set sticky bit in nix store @@ -23,9 +33,9 @@ stdenv.mkDerivation { meta = with lib; { description = "A FUSE filesystem intended to be used like Apache mod_rewrite"; - homepage = "https://github.com/sloonz/rewritefs"; - license = licenses.gpl2Only; + homepage = "https://github.com/sloonz/rewritefs"; + license = licenses.gpl2Only; maintainers = with maintainers; [ rnhmjoj ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/re/rewrk/package.nix b/pkgs/by-name/re/rewrk/package.nix index c4f4755f4b5be0..5e87c9104bea8f 100644 --- a/pkgs/by-name/re/rewrk/package.nix +++ b/pkgs/by-name/re/rewrk/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/re/rex/package.nix b/pkgs/by-name/re/rex/package.nix index 0af9628f41a9ad..881a30c23f1b4d 100644 --- a/pkgs/by-name/re/rex/package.nix +++ b/pkgs/by-name/re/rex/package.nix @@ -1,4 +1,14 @@ -{ pkgs, lib, fetchurl, fetchpatch, perlPackages, rsync, which, installShellFiles, ... }: +{ + pkgs, + lib, + fetchurl, + fetchpatch, + perlPackages, + rsync, + which, + installShellFiles, + ... +}: perlPackages.buildPerlPackage rec { pname = "Rex"; version = "1.14.3"; @@ -47,7 +57,10 @@ perlPackages.buildPerlPackage rec { }) ]; - nativeBuildInputs = with perlPackages; [ installShellFiles ParallelForkManager ]; + nativeBuildInputs = with perlPackages; [ + installShellFiles + ParallelForkManager + ]; propagatedBuildInputs = with perlPackages; [ AWSSignature4 diff --git a/pkgs/by-name/rf/rfc-bibtex/package.nix b/pkgs/by-name/rf/rfc-bibtex/package.nix index d9bed694669726..8555ae20d8c2de 100644 --- a/pkgs/by-name/rf/rfc-bibtex/package.nix +++ b/pkgs/by-name/rf/rfc-bibtex/package.nix @@ -1,9 +1,11 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: -with python3.pkgs; buildPythonApplication rec { +with python3.pkgs; +buildPythonApplication rec { pname = "rfc-bibtex"; version = "0.3.2"; format = "setuptools"; diff --git a/pkgs/by-name/rf/rfc/package.nix b/pkgs/by-name/rf/rfc/package.nix index 136e4567c18d78..815dbc08d4d37f 100644 --- a/pkgs/by-name/rf/rfc/package.nix +++ b/pkgs/by-name/rf/rfc/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, curl -, installShellFiles -, makeWrapper +{ + lib, + stdenvNoCC, + fetchFromGitHub, + curl, + installShellFiles, + makeWrapper, }: stdenvNoCC.mkDerivation rec { @@ -17,7 +18,10 @@ stdenvNoCC.mkDerivation rec { hash = "sha256-bCqgLkbZGQFcxhLwekVw+rUGinXTc7QJHlVRGtNf6Jc="; }; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; dontConfigure = true; dontBuild = true; diff --git a/pkgs/by-name/rg/rgbds/package.nix b/pkgs/by-name/rg/rgbds/package.nix index 3b37e19fa2fb10..6b0aec7123ef67 100644 --- a/pkgs/by-name/rg/rgbds/package.nix +++ b/pkgs/by-name/rg/rgbds/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchFromGitHub, bison, flex, pkg-config, libpng}: +{ + lib, + stdenv, + fetchFromGitHub, + bison, + flex, + pkg-config, + libpng, +}: stdenv.mkDerivation rec { pname = "rgbds"; @@ -9,7 +17,11 @@ stdenv.mkDerivation rec { rev = "v${version}"; hash = "sha256-rSPYnbZjCoAKJBNCJCKsLBenolOzS78Zm850BJ8mKhA="; }; - nativeBuildInputs = [ bison flex pkg-config ]; + nativeBuildInputs = [ + bison + flex + pkg-config + ]; buildInputs = [ libpng ]; postPatch = '' patchShebangs --host src/bison.sh @@ -30,7 +42,10 @@ stdenv.mkDerivation rec { This is a fork of the original RGBDS which aims to make the programs more like other UNIX tools. ''; - maintainers = with maintainers; [ matthewbauer NieDzejkob ]; + maintainers = with maintainers; [ + matthewbauer + NieDzejkob + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/rg/rgxg/package.nix b/pkgs/by-name/rg/rgxg/package.nix index 4cc1722392ecf7..eac1b2d99c5292 100644 --- a/pkgs/by-name/rg/rgxg/package.nix +++ b/pkgs/by-name/rg/rgxg/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { pname = "rgxg"; diff --git a/pkgs/by-name/rh/rhack/package.nix b/pkgs/by-name/rh/rhack/package.nix index 5be698ca6eb81f..ce2b518dc90469 100644 --- a/pkgs/by-name/rh/rhack/package.nix +++ b/pkgs/by-name/rh/rhack/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "rhack"; diff --git a/pkgs/by-name/rh/rhai-doc/package.nix b/pkgs/by-name/rh/rhai-doc/package.nix index dd07b8df9926cc..50d2580a21cef5 100644 --- a/pkgs/by-name/rh/rhai-doc/package.nix +++ b/pkgs/by-name/rh/rhai-doc/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,10 @@ rustPlatform.buildRustPackage rec { description = "Tool to auto-generate documentation for Rhai source code"; homepage = "https://github.com/rhaiscript/rhai-doc"; changelog = "https://github.com/rhaiscript/rhai-doc/releases/tag/${src.rev}"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "rhai-doc"; }; diff --git a/pkgs/by-name/rh/rhash/package.nix b/pkgs/by-name/rh/rhash/package.nix index cdad16bb4b43c4..9daddbfce993ee 100644 --- a/pkgs/by-name/rh/rhash/package.nix +++ b/pkgs/by-name/rh/rhash/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, which -, enableStatic ? stdenv.hostPlatform.isStatic -, gettext +{ + lib, + stdenv, + fetchFromGitHub, + which, + enableStatic ? stdenv.hostPlatform.isStatic, + gettext, }: stdenv.mkDerivation rec { @@ -17,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-3CW41ULdXoID4cOgrcG2j85tgIJ/sz5hU7A83qpuxf4="; }; - patches = [ ./dont-fail-ln.patch ./do-link-so.patch ]; + patches = [ + ./dont-fail-ln.patch + ./do-link-so.patch + ]; nativeBuildInputs = [ which ]; buildInputs = lib.optionals stdenv.hostPlatform.isFreeBSD [ gettext ]; @@ -38,12 +42,14 @@ stdenv.mkDerivation rec { checkTarget = "test-full"; - installTargets = [ - "install" - "install-lib-headers" - ] ++ lib.optionals (!enableStatic) [ - "install-lib-so-link" - ]; + installTargets = + [ + "install" + "install-lib-headers" + ] + ++ lib.optionals (!enableStatic) [ + "install-lib-so-link" + ]; meta = with lib; { homepage = "https://rhash.sourceforge.net/"; diff --git a/pkgs/by-name/rh/rhoas/package.nix b/pkgs/by-name/rh/rhoas/package.nix index aedfd490a661b5..304f15e412f14f 100644 --- a/pkgs/by-name/rh/rhoas/package.nix +++ b/pkgs/by-name/rh/rhoas/package.nix @@ -1,4 +1,12 @@ -{ lib, buildGoModule, fetchFromGitHub, stdenv, installShellFiles, testers, rhoas }: +{ + lib, + buildGoModule, + fetchFromGitHub, + stdenv, + installShellFiles, + testers, + rhoas, +}: buildGoModule rec { pname = "rhoas"; @@ -19,7 +27,7 @@ buildGoModule rec { "-X github.com/redhat-developer/app-services-cli/internal/build.Version=${version}" ]; - nativeBuildInputs = [installShellFiles]; + nativeBuildInputs = [ installShellFiles ]; # Networking tests fail. doCheck = false; @@ -41,7 +49,7 @@ buildGoModule rec { license = licenses.asl20; homepage = "https://github.com/redhat-developer/app-services-cli"; changelog = "https://github.com/redhat-developer/app-services-cli/releases/v${version}"; - maintainers = with maintainers; [stehessel]; + maintainers = with maintainers; [ stehessel ]; mainProgram = "rhoas"; }; } diff --git a/pkgs/by-name/rh/rhodium-libre/package.nix b/pkgs/by-name/rh/rhodium-libre/package.nix index 114061db1b239b..d39f806ee24de8 100644 --- a/pkgs/by-name/rh/rhodium-libre/package.nix +++ b/pkgs/by-name/rh/rhodium-libre/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "RhodiumLibre"; diff --git a/pkgs/by-name/rh/rhvoice/package.nix b/pkgs/by-name/rh/rhvoice/package.nix index d7676ca22df0c3..cb0d6d020b6ac5 100644 --- a/pkgs/by-name/rh/rhvoice/package.nix +++ b/pkgs/by-name/rh/rhvoice/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, ensureNewerSourcesForZipFilesHook -, pkg-config -, scons -, glibmm -, libpulseaudio -, libao -, speechd-minimal +{ + lib, + stdenv, + fetchFromGitHub, + ensureNewerSourcesForZipFilesHook, + pkg-config, + scons, + glibmm, + libpulseaudio, + libao, + speechd-minimal, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/rh/rhythmbox/package.nix b/pkgs/by-name/rh/rhythmbox/package.nix index 0095ffd154447f..2490bc1599ee21 100644 --- a/pkgs/by-name/rh/rhythmbox/package.nix +++ b/pkgs/by-name/rh/rhythmbox/package.nix @@ -1,36 +1,40 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, meson -, ninja -, python3 -, vala -, glib -, gtk3 -, libpeas -, libsoup_3 -, libxml2 -, libsecret -, libnotify -, libdmapsharing -, gnome -, gobject-introspection -, totem-pl-parser -, libgudev -, libgpod -, libmtp -, lirc -, brasero-unwrapped # libdvdcss is not needed for rhythmbox -, grilo -, tdb -, json-glib -, itstool -, wrapGAppsHook3 -, desktop-file-utils -, gst_all_1 -, gst_plugins ? with gst_all_1; [ gst-plugins-good gst-plugins-ugly ] -, check +{ + stdenv, + lib, + fetchurl, + pkg-config, + meson, + ninja, + python3, + vala, + glib, + gtk3, + libpeas, + libsoup_3, + libxml2, + libsecret, + libnotify, + libdmapsharing, + gnome, + gobject-introspection, + totem-pl-parser, + libgudev, + libgpod, + libmtp, + lirc, + brasero-unwrapped, # libdvdcss is not needed for rhythmbox + grilo, + tdb, + json-glib, + itstool, + wrapGAppsHook3, + desktop-file-utils, + gst_all_1, + gst_plugins ? with gst_all_1; [ + gst-plugins-good + gst-plugins-ugly + ], + check, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ri/rich-cli/package.nix b/pkgs/by-name/ri/rich-cli/package.nix index 8399cbb8d32b23..6b5d19757189b3 100644 --- a/pkgs/by-name/ri/rich-cli/package.nix +++ b/pkgs/by-name/ri/rich-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, python3 +{ + lib, + fetchFromGitHub, + fetchpatch, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ri/richgo/package.nix b/pkgs/by-name/ri/richgo/package.nix index 3435572580acd4..04e4a6b689b7dc 100644 --- a/pkgs/by-name/ri/richgo/package.nix +++ b/pkgs/by-name/ri/richgo/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "richgo"; diff --git a/pkgs/by-name/ri/ricochet-refresh/package.nix b/pkgs/by-name/ri/ricochet-refresh/package.nix index 99ebaff5a1cd92..2817ca6a427a29 100644 --- a/pkgs/by-name/ri/ricochet-refresh/package.nix +++ b/pkgs/by-name/ri/ricochet-refresh/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, qt5 -, openssl -, protobuf -, pkg-config -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + qt5, + openssl, + protobuf, + pkg-config, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -24,16 +25,18 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - buildInputs = (with qt5; [ - qtbase - qttools - qtmultimedia - qtquickcontrols2 - qtwayland - ]) ++ [ - openssl - protobuf - ]; + buildInputs = + (with qt5; [ + qtbase + qttools + qtmultimedia + qtquickcontrols2 + qtwayland + ]) + ++ [ + openssl + protobuf + ]; nativeBuildInputs = [ pkg-config diff --git a/pkgs/by-name/ri/ricty/package.nix b/pkgs/by-name/ri/ricty/package.nix index 7c1c6d35873609..edd07a226950e6 100644 --- a/pkgs/by-name/ri/ricty/package.nix +++ b/pkgs/by-name/ri/ricty/package.nix @@ -1,12 +1,20 @@ -{ lib, stdenv, fetchurl, google-fonts, migu, fontforge, which }: +{ + lib, + stdenv, + fetchurl, + google-fonts, + migu, + fontforge, + which, +}: stdenv.mkDerivation rec { pname = "ricty"; version = "4.1.1"; src = fetchurl { - url = "https://rictyfonts.github.io/files/ricty_generator-${version}.sh"; - sha256 = "03fngb8f5hl7ifigdm5yljhs4z2x80cq8y8kna86d07ghknhzgw6"; + url = "https://rictyfonts.github.io/files/ricty_generator-${version}.sh"; + sha256 = "03fngb8f5hl7ifigdm5yljhs4z2x80cq8y8kna86d07ghknhzgw6"; }; unpackPhase = '' @@ -17,7 +25,12 @@ stdenv.mkDerivation rec { sed -i 's/fonts_directories=".*"/fonts_directories="$inconsolata $migu"/' ricty_generator.sh ''; - buildInputs = [ google-fonts migu fontforge which ]; + buildInputs = [ + google-fonts + migu + fontforge + which + ]; buildPhase = '' inconsolata=${google-fonts} migu=${migu} ./ricty_generator.sh auto @@ -34,4 +47,3 @@ stdenv.mkDerivation rec { maintainers = [ maintainers.mikoim ]; }; } - diff --git a/pkgs/by-name/ri/rictydiminished-with-firacode/package.nix b/pkgs/by-name/ri/rictydiminished-with-firacode/package.nix index d5ff8b1513b115..73b0558334bc45 100644 --- a/pkgs/by-name/ri/rictydiminished-with-firacode/package.nix +++ b/pkgs/by-name/ri/rictydiminished-with-firacode/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fontforge, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + fontforge, + python3, +}: stdenv.mkDerivation rec { pname = "rictydiminished-with-firacode"; @@ -46,4 +52,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ mt-caret ]; }; } - diff --git a/pkgs/by-name/ri/riemann/package.nix b/pkgs/by-name/ri/riemann/package.nix index 0b678a0a0fd70e..915f8319dd0f0f 100644 --- a/pkgs/by-name/ri/riemann/package.nix +++ b/pkgs/by-name/ri/riemann/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "riemann"; diff --git a/pkgs/by-name/ri/riemann_c_client/package.nix b/pkgs/by-name/ri/riemann_c_client/package.nix index 788e0821fc01fe..e4b2898d77edd1 100644 --- a/pkgs/by-name/ri/riemann_c_client/package.nix +++ b/pkgs/by-name/ri/riemann_c_client/package.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, fetchFromGitea, autoreconfHook, check, pkg-config, file, protobufc -,withWolfSSL ? false, wolfssl -,withGnuTLS ? false, gnutls -,withJSON ? true, json_c +{ + lib, + stdenv, + fetchFromGitea, + autoreconfHook, + check, + pkg-config, + file, + protobufc, + withWolfSSL ? false, + wolfssl, + withGnuTLS ? false, + gnutls, + withJSON ? true, + json_c, }: stdenv.mkDerivation rec { @@ -16,19 +27,28 @@ stdenv.mkDerivation rec { hash = "sha256-l9iUDhagODi58FDT9vEb90tsiIcrcMmGYCmH3ML3RCM="; }; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; - nativeBuildInputs = [ autoreconfHook check pkg-config ]; - buildInputs = [ file protobufc ] + nativeBuildInputs = [ + autoreconfHook + check + pkg-config + ]; + buildInputs = + [ + file + protobufc + ] ++ lib.optional withWolfSSL wolfssl ++ lib.optional withGnuTLS gnutls - ++ lib.optional withJSON json_c - ; + ++ lib.optional withJSON json_c; - configureFlags = [] - ++ lib.optional withWolfSSL "--with-tls=wolfssl" - ++ lib.optional withGnuTLS "--with-tls=gnutls" - ; + configureFlags = + [ ] ++ lib.optional withWolfSSL "--with-tls=wolfssl" ++ lib.optional withGnuTLS "--with-tls=gnutls"; doCheck = true; enableParallelBuilding = true; diff --git a/pkgs/by-name/ri/ries/package.nix b/pkgs/by-name/ri/ries/package.nix index 5c0626913e3c93..fe6a93b0282605 100644 --- a/pkgs/by-name/ri/ries/package.nix +++ b/pkgs/by-name/ri/ries/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { pname = "ries"; version = "2018.04.11-1"; @@ -20,4 +24,3 @@ stdenv.mkDerivation rec { license = licenses.gpl3Plus; }; } - diff --git a/pkgs/by-name/ri/riff/package.nix b/pkgs/by-name/ri/riff/package.nix index aa85616720ddb5..9bec268b41e635 100644 --- a/pkgs/by-name/ri/riff/package.nix +++ b/pkgs/by-name/ri/riff/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, makeWrapper -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + makeWrapper, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -26,11 +27,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; postInstall = '' wrapProgram $out/bin/riff --set-default RIFF_DISABLE_TELEMETRY true diff --git a/pkgs/by-name/ri/rifiuti/package.nix b/pkgs/by-name/ri/rifiuti/package.nix index d1134e22882122..459ea2da6b0818 100644 --- a/pkgs/by-name/ri/rifiuti/package.nix +++ b/pkgs/by-name/ri/rifiuti/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchzip -, fetchurl +{ + lib, + stdenv, + fetchzip, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ri/rig/package.nix b/pkgs/by-name/ri/rig/package.nix index 45304f3e56f4d4..f2b5cddca3739d 100644 --- a/pkgs/by-name/ri/rig/package.nix +++ b/pkgs/by-name/ri/rig/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl } : +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "1.11"; diff --git a/pkgs/by-name/ri/rigsofrods-bin/package.nix b/pkgs/by-name/ri/rigsofrods-bin/package.nix index 5fc17950561418..45ce5373184c46 100644 --- a/pkgs/by-name/ri/rigsofrods-bin/package.nix +++ b/pkgs/by-name/ri/rigsofrods-bin/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, makeWrapper -, unzip -, libGL -, libICE -, libSM -, libX11 -, libXrandr -, zlib -, alsa-lib +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + makeWrapper, + unzip, + libGL, + libICE, + libSM, + libX11, + libXrandr, + zlib, + alsa-lib, }: stdenv.mkDerivation rec { @@ -63,7 +64,10 @@ stdenv.mkDerivation rec { description = "Free/libre soft-body physics simulator mainly targeted at simulating vehicle physics"; homepage = "https://www.rigsofrods.org"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ raskin wegank ]; + maintainers = with maintainers; [ + raskin + wegank + ]; platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/by-name/ri/riko4/package.nix b/pkgs/by-name/ri/riko4/package.nix index b3721f7f78f43f..047c28aef0ad25 100644 --- a/pkgs/by-name/ri/riko4/package.nix +++ b/pkgs/by-name/ri/riko4/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, SDL2, libGLU, luajit, curl, curlpp }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + SDL2, + libGLU, + luajit, + curl, + curlpp, +}: let # Newer versions of sdl-gpu don't work with Riko4 (corrupted graphics), @@ -13,7 +23,10 @@ let rev = "a4ff1ab02410f154b004c29ec46e07b22890fa1f"; sha256 = "1wdwg331s7r4dhq1l8w4dvlqf4iywskpdrscgbwrz9j0c6nqqi3v"; }; - buildInputs = [ SDL2 libGLU ]; + buildInputs = [ + SDL2 + libGLU + ]; nativeBuildInputs = [ cmake ]; meta = with lib; { @@ -35,7 +48,13 @@ stdenv.mkDerivation rec { sha256 = "008i9991sn616dji96jfwq6gszrspbx4x7cynxb1cjw66phyy5zp"; }; - buildInputs = [ SDL2 luajit sdl-gpu curl curlpp ]; + buildInputs = [ + SDL2 + luajit + sdl-gpu + curl + curlpp + ]; nativeBuildInputs = [ cmake ]; hardeningDisable = [ "fortify" ]; diff --git a/pkgs/by-name/ri/rili/package.nix b/pkgs/by-name/ri/rili/package.nix index 4737be3ffc4c39..73fdac61ca7e27 100644 --- a/pkgs/by-name/ri/rili/package.nix +++ b/pkgs/by-name/ri/rili/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchpatch, SDL_mixer, SDL, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + SDL_mixer, + SDL, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "ri_li"; @@ -24,16 +32,19 @@ stdenv.mkDerivation rec { CPPFLAGS = "-I${lib.getDev SDL}/include -I${lib.getDev SDL}/include/SDL -I${SDL_mixer}/include"; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ SDL SDL_mixer ]; + buildInputs = [ + SDL + SDL_mixer + ]; meta = { homepage = "https://ri-li.sourceforge.net"; license = lib.licenses.gpl2Plus; description = "Children's train game"; longDescription = '' - Ri-li is an arcade game licensed under the GPL (General Public License). -You drive a toy wood engine in many levels and you must collect all the coaches -to win. + Ri-li is an arcade game licensed under the GPL (General Public License). + You drive a toy wood engine in many levels and you must collect all the coaches + to win. ''; maintainers = with lib.maintainers; [ jcumming ]; platforms = with lib.platforms; linux; diff --git a/pkgs/by-name/ri/rime-cli/package.nix b/pkgs/by-name/ri/rime-cli/package.nix index 9c89db21259585..40c08fa5e66fb4 100644 --- a/pkgs/by-name/ri/rime-cli/package.nix +++ b/pkgs/by-name/ri/rime-cli/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "rime-cli"; diff --git a/pkgs/by-name/ri/rime-data/fetchSchema.nix b/pkgs/by-name/ri/rime-data/fetchSchema.nix index 6ceb44fefe5ca7..2ea9d31cac424f 100644 --- a/pkgs/by-name/ri/rime-data/fetchSchema.nix +++ b/pkgs/by-name/ri/rime-data/fetchSchema.nix @@ -1,137 +1,180 @@ # Generated using generateFetchSchema.sh -fetchFromGitHub: -'' -mkdir -p package/rime -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-array"; - rev = "b37aad383ff6e71e457aa6d1d47d2040af8649b9"; - sha256 = "0krvxnjr35r49wwi6bcjdnld6zbk791l7vm294wmdy36qfp2924y"; -}} package/rime/array -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-bopomofo"; - rev = "c7618f4f5728e1634417e9d02ea50d82b71956ab"; - sha256 = "0g77nv0jrwqnbqqna0ib0kqcy6l5zl62kh49ny67d6bjwnwz9186"; -}} package/rime/bopomofo -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-cangjie"; - rev = "8dfad9e537f18821b71ba28773315d9c670ae245"; - sha256 = "029kw9nx6x0acg4f0m8wj1ziqffffhy9yyj51nlx17cnia0qcrby"; -}} package/rime/cangjie -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-cantonese"; - rev = "e3c6b17e638ac8a9aeab4d5852e5909b049c5ab3"; - sha256 = "171a64l17yb6isgiih2z0cp2vgzvdcn0vby3rk8556b0ir4j545q"; -}} package/rime/cantonese -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-combo-pinyin"; - rev = "17b66079a23a00d3214639fee2b8ae97d3e620dc"; - sha256 = "1izx29hawfryapfzadysjbb2zfw0yq6vwsw56khkf6gsaz1faamn"; -}} package/rime/combo-pinyin -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-double-pinyin"; - rev = "69bf85d4dfe8bac139c36abbd68d530b8b6622ea"; - sha256 = "093wif5avvvw45fqbwj5wkbxrychy4pagl4mwsmbrayc8jkp69ak"; -}} package/rime/double-pinyin -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-emoji"; - rev = "a18b09997e7c457066e4c92adf249a4b3e235f9c"; - sha256 = "0gaa9r3yx1s135jlqxp85iyygcwqgz2k4n1bpvjr2n8xkn9297b6"; -}} package/rime/emoji -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-essay"; - rev = "e0519d0579722a0871efb68189272cba61a7350b"; - sha256 = "1g7188vgklxindvm6p65b5jlm6z47fdmhmp0hqrrd6smg9pz4qpw"; -}} package/rime/essay -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-ipa"; - rev = "22b71710e029bcb412e9197192a638ab11bc2abf"; - sha256 = "0zdk4f9qkfj3q5hmjnairj1lv6f6y27mic12k886n6sxywwbwr2k"; -}} package/rime/ipa -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-jyutping"; - rev = "50100769f645bf92afef5170e3bf42be5147b41b"; - sha256 = "1dmw2ssbqxbs93iab0whjzncsvv66vyw3hwb30kly2v18bwkagq0"; -}} package/rime/jyutping -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-luna-pinyin"; - rev = "79aeae200a7370720be98232844c0715f277e1c0"; - sha256 = "06vff5hq85dkbmqch9d3w2rww2n8sk41c7say0pdlkfphyjs76ps"; -}} package/rime/luna-pinyin -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-middle-chinese"; - rev = "582e144e525525ac2b6c2498097d7c7919e84174"; - sha256 = "0ixj2f3syc0hv9n5r0cavcq0jrdf1www2frjl11855gwydp4lsx5"; -}} package/rime/middle-chinese -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-pinyin-simp"; - rev = "52b9c75f085479799553f2499c4f4c611d618cdf"; - sha256 = "1zi9yqgijb4r3q5ah89hdwbli5xhlmg19xj8sq1grnpfbw2hbdbj"; -}} package/rime/pinyin-simp -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-prelude"; - rev = "dd84abecc33f0b05469f1d744e32d2b60b3529e3"; - sha256 = "14wn86xqvb6r73pgksi51wgfc70pj95iqrl85m2i0fwl43zg2y5g"; -}} package/rime/prelude -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-quick"; - rev = "3fe5911ba608cb2df1b6301b76ad1573bd482a76"; - sha256 = "08bh87ym5qvw55lyw20l3m7jd4c2z5rvil8h5q8790r7z6j6ijy9"; -}} package/rime/quick -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-scj"; - rev = "cab5a0858765eff0553dd685a2d61d5536e9149c"; - sha256 = "0ard2bjp4896a8dimmcwyjwgmp9kl4rz92yc92jnd3y4rgwl6fvk"; -}} package/rime/scj -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-soutzoe"; - rev = "beeaeca72d8e17dfd1e9af58680439e9012987dc"; - sha256 = "0jyqx0q9s0qxn168l5n8zav8jcl2g5ppr7pa8jm1vwrllf20slcc"; -}} package/rime/soutzoe -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-stenotype"; - rev = "f3e9189d5ce33c55d3936cc58e39d0c88b3f0c88"; - sha256 = "0dl6px7lrh3xa87knjzwzdcwjj1k1dg4l72q7lb48an4s9f1cy5d"; -}} package/rime/stenotype -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-stroke"; - rev = "e6c7608925009636577ff7469eecc870f1de18f3"; - sha256 = "1rzclksf09s9js6z9mjm4ibgybr6kg2c4xq4j6sg9b3pnjbjwv8g"; -}} package/rime/stroke -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-terra-pinyin"; - rev = "9427853de91d645d9aca9ceace8fe9e9d8bc5b50"; - sha256 = "0f1wiqasy41hp3kw3qc5zk6z0rgfrswdw91kc66v1w1a3skb6wpp"; -}} package/rime/terra-pinyin -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-wubi"; - rev = "152a0d3f3efe40cae216d1e3b338242446848d07"; - sha256 = "1p2ikcw40q84fx0ixarm1jfp8ax276pabansybchrj34cqs53sr1"; -}} package/rime/wubi -ln -sv ${fetchFromGitHub { - owner = "rime"; - repo = "rime-wugniu"; - rev = "abd1ee98efbf170258fcf43875c21a4259e00b61"; - sha256 = "0qn54d3cclny106ixdw08r5n6wn52ffs1hgrma3k0j4pv0kr9nlq"; -}} package/rime/wugniu +fetchFromGitHub: '' + mkdir -p package/rime + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-array"; + rev = "b37aad383ff6e71e457aa6d1d47d2040af8649b9"; + sha256 = "0krvxnjr35r49wwi6bcjdnld6zbk791l7vm294wmdy36qfp2924y"; + } + } package/rime/array + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-bopomofo"; + rev = "c7618f4f5728e1634417e9d02ea50d82b71956ab"; + sha256 = "0g77nv0jrwqnbqqna0ib0kqcy6l5zl62kh49ny67d6bjwnwz9186"; + } + } package/rime/bopomofo + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-cangjie"; + rev = "8dfad9e537f18821b71ba28773315d9c670ae245"; + sha256 = "029kw9nx6x0acg4f0m8wj1ziqffffhy9yyj51nlx17cnia0qcrby"; + } + } package/rime/cangjie + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-cantonese"; + rev = "e3c6b17e638ac8a9aeab4d5852e5909b049c5ab3"; + sha256 = "171a64l17yb6isgiih2z0cp2vgzvdcn0vby3rk8556b0ir4j545q"; + } + } package/rime/cantonese + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-combo-pinyin"; + rev = "17b66079a23a00d3214639fee2b8ae97d3e620dc"; + sha256 = "1izx29hawfryapfzadysjbb2zfw0yq6vwsw56khkf6gsaz1faamn"; + } + } package/rime/combo-pinyin + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-double-pinyin"; + rev = "69bf85d4dfe8bac139c36abbd68d530b8b6622ea"; + sha256 = "093wif5avvvw45fqbwj5wkbxrychy4pagl4mwsmbrayc8jkp69ak"; + } + } package/rime/double-pinyin + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-emoji"; + rev = "a18b09997e7c457066e4c92adf249a4b3e235f9c"; + sha256 = "0gaa9r3yx1s135jlqxp85iyygcwqgz2k4n1bpvjr2n8xkn9297b6"; + } + } package/rime/emoji + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-essay"; + rev = "e0519d0579722a0871efb68189272cba61a7350b"; + sha256 = "1g7188vgklxindvm6p65b5jlm6z47fdmhmp0hqrrd6smg9pz4qpw"; + } + } package/rime/essay + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-ipa"; + rev = "22b71710e029bcb412e9197192a638ab11bc2abf"; + sha256 = "0zdk4f9qkfj3q5hmjnairj1lv6f6y27mic12k886n6sxywwbwr2k"; + } + } package/rime/ipa + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-jyutping"; + rev = "50100769f645bf92afef5170e3bf42be5147b41b"; + sha256 = "1dmw2ssbqxbs93iab0whjzncsvv66vyw3hwb30kly2v18bwkagq0"; + } + } package/rime/jyutping + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-luna-pinyin"; + rev = "79aeae200a7370720be98232844c0715f277e1c0"; + sha256 = "06vff5hq85dkbmqch9d3w2rww2n8sk41c7say0pdlkfphyjs76ps"; + } + } package/rime/luna-pinyin + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-middle-chinese"; + rev = "582e144e525525ac2b6c2498097d7c7919e84174"; + sha256 = "0ixj2f3syc0hv9n5r0cavcq0jrdf1www2frjl11855gwydp4lsx5"; + } + } package/rime/middle-chinese + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-pinyin-simp"; + rev = "52b9c75f085479799553f2499c4f4c611d618cdf"; + sha256 = "1zi9yqgijb4r3q5ah89hdwbli5xhlmg19xj8sq1grnpfbw2hbdbj"; + } + } package/rime/pinyin-simp + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-prelude"; + rev = "dd84abecc33f0b05469f1d744e32d2b60b3529e3"; + sha256 = "14wn86xqvb6r73pgksi51wgfc70pj95iqrl85m2i0fwl43zg2y5g"; + } + } package/rime/prelude + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-quick"; + rev = "3fe5911ba608cb2df1b6301b76ad1573bd482a76"; + sha256 = "08bh87ym5qvw55lyw20l3m7jd4c2z5rvil8h5q8790r7z6j6ijy9"; + } + } package/rime/quick + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-scj"; + rev = "cab5a0858765eff0553dd685a2d61d5536e9149c"; + sha256 = "0ard2bjp4896a8dimmcwyjwgmp9kl4rz92yc92jnd3y4rgwl6fvk"; + } + } package/rime/scj + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-soutzoe"; + rev = "beeaeca72d8e17dfd1e9af58680439e9012987dc"; + sha256 = "0jyqx0q9s0qxn168l5n8zav8jcl2g5ppr7pa8jm1vwrllf20slcc"; + } + } package/rime/soutzoe + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-stenotype"; + rev = "f3e9189d5ce33c55d3936cc58e39d0c88b3f0c88"; + sha256 = "0dl6px7lrh3xa87knjzwzdcwjj1k1dg4l72q7lb48an4s9f1cy5d"; + } + } package/rime/stenotype + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-stroke"; + rev = "e6c7608925009636577ff7469eecc870f1de18f3"; + sha256 = "1rzclksf09s9js6z9mjm4ibgybr6kg2c4xq4j6sg9b3pnjbjwv8g"; + } + } package/rime/stroke + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-terra-pinyin"; + rev = "9427853de91d645d9aca9ceace8fe9e9d8bc5b50"; + sha256 = "0f1wiqasy41hp3kw3qc5zk6z0rgfrswdw91kc66v1w1a3skb6wpp"; + } + } package/rime/terra-pinyin + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-wubi"; + rev = "152a0d3f3efe40cae216d1e3b338242446848d07"; + sha256 = "1p2ikcw40q84fx0ixarm1jfp8ax276pabansybchrj34cqs53sr1"; + } + } package/rime/wubi + ln -sv ${ + fetchFromGitHub { + owner = "rime"; + repo = "rime-wugniu"; + rev = "abd1ee98efbf170258fcf43875c21a4259e00b61"; + sha256 = "0qn54d3cclny106ixdw08r5n6wn52ffs1hgrma3k0j4pv0kr9nlq"; + } + } package/rime/wugniu '' diff --git a/pkgs/by-name/ri/rime-data/package.nix b/pkgs/by-name/ri/rime-data/package.nix index 15c33238e8da3e..fc19f47b490a2e 100644 --- a/pkgs/by-name/ri/rime-data/package.nix +++ b/pkgs/by-name/ri/rime-data/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, librime }: +{ + lib, + stdenv, + fetchFromGitHub, + librime, +}: stdenv.mkDerivation { pname = "rime-data"; diff --git a/pkgs/by-name/ri/rinetd/package.nix b/pkgs/by-name/ri/rinetd/package.nix index e9abb0ceab49ef..8e90ce6628b86d 100644 --- a/pkgs/by-name/ri/rinetd/package.nix +++ b/pkgs/by-name/ri/rinetd/package.nix @@ -1,9 +1,10 @@ -{ lib -, autoreconfHook -, fetchFromGitHub -, rinetd -, stdenv -, testers +{ + lib, + autoreconfHook, + fetchFromGitHub, + rinetd, + stdenv, + testers, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ri/ringfairy/package.nix b/pkgs/by-name/ri/ringfairy/package.nix index 67563b58315c7d..3610062207dcf7 100644 --- a/pkgs/by-name/ri/ringfairy/package.nix +++ b/pkgs/by-name/ri/ringfairy/package.nix @@ -20,12 +20,13 @@ rustPlatform.buildRustPackage { cargoHash = "sha256-cmW+y57AAK1NNBJ6xE2EvHsSoKddLWgdtnAmSjzAN0k="; - nativeBuildInputs = [pkg-config]; + nativeBuildInputs = [ pkg-config ]; buildInputs = - [openssl] + [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin ( - with darwin.apple_sdk.frameworks; [ + with darwin.apple_sdk.frameworks; + [ Security SystemConfiguration ] @@ -35,7 +36,7 @@ rustPlatform.buildRustPackage { description = "Static webring generator in Rust"; homepage = "https://github.com/k3rs3d/ringfairy"; license = lib.licenses.gpl3Only; - maintainers = with lib.maintainers; [uncenter]; + maintainers = with lib.maintainers; [ uncenter ]; mainProgram = "ringfairy"; }; } diff --git a/pkgs/by-name/ri/ringracers/package.nix b/pkgs/by-name/ri/ringracers/package.nix index 2f8368b848c06a..8cb144d870cc5b 100644 --- a/pkgs/by-name/ri/ringracers/package.nix +++ b/pkgs/by-name/ri/ringracers/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchzip -, fetchFromGitHub -, cmake -, curl -, nasm -, game-music-emu -, libpng -, SDL2 -, SDL2_mixer -, libvpx -, libyuv -, zlib -, makeWrapper -, makeDesktopItem -, copyDesktopItems +{ + lib, + stdenv, + fetchzip, + fetchFromGitHub, + cmake, + curl, + nasm, + game-music-emu, + libpng, + SDL2, + SDL2_mixer, + libvpx, + libyuv, + zlib, + makeWrapper, + makeDesktopItem, + copyDesktopItems, }: stdenv.mkDerivation (finalAttrs: { @@ -89,7 +90,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://kartkrew.org"; platforms = platforms.linux; license = licenses.gpl2Plus; - maintainers = with maintainers; [ donovanglover thehans255 ]; + maintainers = with maintainers; [ + donovanglover + thehans255 + ]; mainProgram = "ringracers"; }; }) diff --git a/pkgs/by-name/ri/rinutils/package.nix b/pkgs/by-name/ri/rinutils/package.nix index 45b9f299aa2d50..ca5717a34fdddb 100644 --- a/pkgs/by-name/ri/rinutils/package.nix +++ b/pkgs/by-name/ri/rinutils/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchurl -, cmake -, perl +{ + stdenv, + lib, + fetchurl, + cmake, + perl, }: stdenv.mkDerivation rec { @@ -14,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-+eUn03psyMe4hwraY8qiTzKrDSn9ERbfPrtoZYMDCVU="; }; - nativeBuildInputs = [ cmake perl ]; + nativeBuildInputs = [ + cmake + perl + ]; # https://github.com/shlomif/rinutils/issues/5 # (variable was unused at time of writing) diff --git a/pkgs/by-name/ri/riot-redis/package.nix b/pkgs/by-name/ri/riot-redis/package.nix index 755228361b1fab..5832e916c5813f 100644 --- a/pkgs/by-name/ri/riot-redis/package.nix +++ b/pkgs/by-name/ri/riot-redis/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchzip -, jre_headless -, makeWrapper +{ + lib, + stdenv, + fetchzip, + jre_headless, + makeWrapper, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ri/ripdrag/package.nix b/pkgs/by-name/ri/ripdrag/package.nix index 9521ac120bcfde..ff254fbbc758c1 100644 --- a/pkgs/by-name/ri/ripdrag/package.nix +++ b/pkgs/by-name/ri/ripdrag/package.nix @@ -1,4 +1,11 @@ -{ lib, rustPlatform, fetchFromGitHub, pkg-config, wrapGAppsHook4, gtk4 }: +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + wrapGAppsHook4, + gtk4, +}: rustPlatform.buildRustPackage rec { pname = "ripdrag"; @@ -13,7 +20,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-9POXKvbt1Xr1wKYHhfLb14puKorLIlT1ckzEVd6eWa0="; - nativeBuildInputs = [ pkg-config wrapGAppsHook4 ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook4 + ]; buildInputs = [ gtk4 ]; diff --git a/pkgs/by-name/ri/ripe-atlas-tools/package.nix b/pkgs/by-name/ri/ripe-atlas-tools/package.nix index 0fc3897b878073..60e32ead5b6111 100644 --- a/pkgs/by-name/ri/ripe-atlas-tools/package.nix +++ b/pkgs/by-name/ri/ripe-atlas-tools/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, installShellFiles +{ + lib, + python3, + fetchFromGitHub, + installShellFiles, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ri/ripgrep/package.nix b/pkgs/by-name/ri/ripgrep/package.nix index c6d3884921beea..d90ad5d81bdd8b 100644 --- a/pkgs/by-name/ri/ripgrep/package.nix +++ b/pkgs/by-name/ri/ripgrep/package.nix @@ -1,18 +1,21 @@ -{ lib, stdenv -, buildPackages -, fetchFromGitHub -, rustPlatform -, installShellFiles -, pkg-config -, apple-sdk_11 -, withPCRE2 ? true -, pcre2 +{ + lib, + stdenv, + buildPackages, + fetchFromGitHub, + rustPlatform, + installShellFiles, + pkg-config, + apple-sdk_11, + withPCRE2 ? true, + pcre2, }: let canRunRg = stdenv.hostPlatform.emulatorAvailable buildPackages; rg = "${stdenv.hostPlatform.emulator buildPackages} $out/bin/rg"; -in rustPlatform.buildRustPackage rec { +in +rustPlatform.buildRustPackage rec { pname = "ripgrep"; version = "14.1.1"; @@ -25,9 +28,9 @@ in rustPlatform.buildRustPackage rec { cargoHash = "sha256-b+iA8iTYWlczBpNq9eyHrWG8LMU4WPBzaU6pQRht+yE="; - nativeBuildInputs = [ installShellFiles ] - ++ lib.optional withPCRE2 pkg-config; - buildInputs = lib.optional withPCRE2 pcre2 + nativeBuildInputs = [ installShellFiles ] ++ lib.optional withPCRE2 pkg-config; + buildInputs = + lib.optional withPCRE2 pcre2 ++ lib.optional stdenv.hostPlatform.isDarwin apple-sdk_11; buildFeatures = lib.optional withPCRE2 "pcre2"; @@ -43,21 +46,30 @@ in rustPlatform.buildRustPackage rec { ''; doInstallCheck = true; - installCheckPhase = '' - file="$(mktemp)" - echo "abc\nbcd\ncde" > "$file" - ${rg} -N 'bcd' "$file" - ${rg} -N 'cd' "$file" - '' + lib.optionalString withPCRE2 '' - echo '(a(aa)aa)' | ${rg} -P '\((a*|(?R))*\)' - ''; + installCheckPhase = + '' + file="$(mktemp)" + echo "abc\nbcd\ncde" > "$file" + ${rg} -N 'bcd' "$file" + ${rg} -N 'cd' "$file" + '' + + lib.optionalString withPCRE2 '' + echo '(a(aa)aa)' | ${rg} -P '\((a*|(?R))*\)' + ''; meta = with lib; { description = "Utility that combines the usability of The Silver Searcher with the raw speed of grep"; homepage = "https://github.com/BurntSushi/ripgrep"; changelog = "https://github.com/BurntSushi/ripgrep/releases/tag/${version}"; - license = with licenses; [ unlicense /* or */ mit ]; - maintainers = with maintainers; [ globin ma27 zowoq ]; + license = with licenses; [ + unlicense # or + mit + ]; + maintainers = with maintainers; [ + globin + ma27 + zowoq + ]; mainProgram = "rg"; }; } diff --git a/pkgs/by-name/ri/ripmime/package.nix b/pkgs/by-name/ri/ripmime/package.nix index f1bcc58f4dcd52..b4e302618ee998 100644 --- a/pkgs/by-name/ri/ripmime/package.nix +++ b/pkgs/by-name/ri/ripmime/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ripmime"; @@ -13,11 +17,13 @@ stdenv.mkDerivation rec { mkdir -p "$out/bin" "$out/share/man/man1" ''; - env = { - NIX_CFLAGS_COMPILE = " -Wno-error "; - } // lib.optionalAttrs stdenv.hostPlatform.isDarwin { - NIX_LDFLAGS = "-liconv"; - }; + env = + { + NIX_CFLAGS_COMPILE = " -Wno-error "; + } + // lib.optionalAttrs stdenv.hostPlatform.isDarwin { + NIX_LDFLAGS = "-liconv"; + }; meta = with lib; { description = "Attachment extractor for MIME messages"; diff --git a/pkgs/by-name/ri/rippkgs/package.nix b/pkgs/by-name/ri/rippkgs/package.nix index ae64a4d93bee6d..9ca01128450b49 100644 --- a/pkgs/by-name/ri/rippkgs/package.nix +++ b/pkgs/by-name/ri/rippkgs/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, sqlite +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + sqlite, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ri/ripsecrets/package.nix b/pkgs/by-name/ri/ripsecrets/package.nix index 3783e5ef0983b8..c5450449ed2be7 100644 --- a/pkgs/by-name/ri/ripsecrets/package.nix +++ b/pkgs/by-name/ri/ripsecrets/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ri/ripser/package.nix b/pkgs/by-name/ri/ripser/package.nix index 38a00d504406b6..204f8a0f02443b 100644 --- a/pkgs/by-name/ri/ripser/package.nix +++ b/pkgs/by-name/ri/ripser/package.nix @@ -1,12 +1,19 @@ -{ lib, stdenv, fetchFromGitHub -, useCoefficients ? false -, indicateProgress ? false -, useGoogleHashmap ? false, sparsehash ? null -, fileFormat ? "lowerTriangularCsv" +{ + lib, + stdenv, + fetchFromGitHub, + useCoefficients ? false, + indicateProgress ? false, + useGoogleHashmap ? false, + sparsehash ? null, + fileFormat ? "lowerTriangularCsv", }: -assert lib.assertOneOf "fileFormat" fileFormat - ["lowerTriangularCsv" "upperTriangularCsv" "dipha"]; +assert lib.assertOneOf "fileFormat" fileFormat [ + "lowerTriangularCsv" + "upperTriangularCsv" + "dipha" +]; assert useGoogleHashmap -> sparsehash != null; let @@ -25,18 +32,18 @@ stdenv.mkDerivation { buildInputs = lib.optional useGoogleHashmap sparsehash; - buildFlags = [ - "-std=c++11" - "-O3" - "-D NDEBUG" - ] - ++ lib.optional useCoefficients "-D USE_COEFFICIENTS" - ++ lib.optional indicateProgress "-D INDICATE_PROGRESS" - ++ lib.optional useGoogleHashmap "-D USE_GOOGLE_HASHMAP" - ++ lib.optional (fileFormat == "lowerTriangularCsv") "-D FILE_FORMAT_LOWER_TRIANGULAR_CSV" - ++ lib.optional (fileFormat == "upperTriangularCsv") "-D FILE_FORMAT_UPPER_TRIANGULAR_CSV" - ++ lib.optional (fileFormat == "dipha") "-D FILE_FORMAT_DIPHA" - ; + buildFlags = + [ + "-std=c++11" + "-O3" + "-D NDEBUG" + ] + ++ lib.optional useCoefficients "-D USE_COEFFICIENTS" + ++ lib.optional indicateProgress "-D INDICATE_PROGRESS" + ++ lib.optional useGoogleHashmap "-D USE_GOOGLE_HASHMAP" + ++ lib.optional (fileFormat == "lowerTriangularCsv") "-D FILE_FORMAT_LOWER_TRIANGULAR_CSV" + ++ lib.optional (fileFormat == "upperTriangularCsv") "-D FILE_FORMAT_UPPER_TRIANGULAR_CSV" + ++ lib.optional (fileFormat == "dipha") "-D FILE_FORMAT_DIPHA"; buildPhase = "c++ ripser.cpp -o ripser $buildFlags"; @@ -50,7 +57,7 @@ stdenv.mkDerivation { mainProgram = "ripser"; homepage = "https://github.com/Ripser/ripser"; license = lib.licenses.lgpl3; - maintainers = with lib.maintainers; [erikryb]; + maintainers = with lib.maintainers; [ erikryb ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/ri/ripunzip/package.nix b/pkgs/by-name/ri/ripunzip/package.nix index d60bedc482cdd7..5071f03953dd05 100644 --- a/pkgs/by-name/ri/ripunzip/package.nix +++ b/pkgs/by-name/ri/ripunzip/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, openssl -, darwin -, pkg-config -, testers -, fetchzip -, ripunzip +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + openssl, + darwin, + pkg-config, + testers, + fetchzip, + ripunzip, }: rustPlatform.buildRustPackage rec { @@ -23,17 +24,26 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-1ZHAbJIWRQh876rshMYeuCz7UMlwdqrScO0eIkGjZao="; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ Security SystemConfiguration ]); + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Security + SystemConfiguration + ] + ); nativeBuildInputs = [ pkg-config ]; setupHook = ./setup-hook.sh; passthru.tests = { - fetchzipWithRipunzip = testers.invalidateFetcherByDrvHash (fetchzip.override { unzip = ripunzip; }) { - url = "https://github.com/google/ripunzip/archive/cb9caa3ba4b0e27a85e165be64c40f1f6dfcc085.zip"; - hash = "sha256-BoErC5VL3Vpvkx6xJq6J+eUJrBnjVEdTuSo7zh98Jy4="; - }; + fetchzipWithRipunzip = + testers.invalidateFetcherByDrvHash (fetchzip.override { unzip = ripunzip; }) + { + url = "https://github.com/google/ripunzip/archive/cb9caa3ba4b0e27a85e165be64c40f1f6dfcc085.zip"; + hash = "sha256-BoErC5VL3Vpvkx6xJq6J+eUJrBnjVEdTuSo7zh98Jy4="; + }; version = testers.testVersion { package = ripunzip; }; @@ -43,7 +53,10 @@ rustPlatform.buildRustPackage rec { description = "Tool to unzip files in parallel"; mainProgram = "ripunzip"; homepage = "https://github.com/google/ripunzip"; - license = with lib.licenses; [ mit asl20 ]; + license = with lib.licenses; [ + mit + asl20 + ]; maintainers = [ maintainers.lesuisse ]; }; } diff --git a/pkgs/by-name/ri/riscv-pk/package.nix b/pkgs/by-name/ri/riscv-pk/package.nix index 83ce454935f278..95d8d77dbe36be 100644 --- a/pkgs/by-name/ri/riscv-pk/package.nix +++ b/pkgs/by-name/ri/riscv-pk/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, payload ? null }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + payload ? null, +}: stdenv.mkDerivation { pname = "riscv-pk"; @@ -20,8 +26,7 @@ stdenv.mkDerivation { configureScript = "../configure"; - configureFlags = lib.optional (payload != null) - "--with-payload=${payload}"; + configureFlags = lib.optional (payload != null) "--with-payload=${payload}"; hardeningDisable = [ "all" ]; diff --git a/pkgs/by-name/ri/risor/package.nix b/pkgs/by-name/ri/risor/package.nix index cbac6e69e03b8a..050d8062186009 100644 --- a/pkgs/by-name/ri/risor/package.nix +++ b/pkgs/by-name/ri/risor/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, risor +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + risor, }: buildGoModule rec { @@ -45,4 +46,3 @@ buildGoModule rec { maintainers = with maintainers; [ figsoda ]; }; } - diff --git a/pkgs/by-name/ri/ristate/package.nix b/pkgs/by-name/ri/ristate/package.nix index 9a0541d03f8ad9..cce06401a2ae0a 100644 --- a/pkgs/by-name/ri/ristate/package.nix +++ b/pkgs/by-name/ri/ristate/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitLab }: +{ + lib, + rustPlatform, + fetchFromGitLab, +}: rustPlatform.buildRustPackage rec { pname = "ristate"; diff --git a/pkgs/by-name/ri/rita/package.nix b/pkgs/by-name/ri/rita/package.nix index 4ebe27f8fbe4ef..2f17660f689813 100644 --- a/pkgs/by-name/ri/rita/package.nix +++ b/pkgs/by-name/ri/rita/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ri/rivalcfg/package.nix b/pkgs/by-name/ri/rivalcfg/package.nix index 5a56aa478cadd4..8ece23daf957fb 100644 --- a/pkgs/by-name/ri/rivalcfg/package.nix +++ b/pkgs/by-name/ri/rivalcfg/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonPackage rec { pname = "rivalcfg"; @@ -11,7 +15,10 @@ python3Packages.buildPythonPackage rec { sha256 = "sha256-LQpEHcKXkepfsgG7tGYsmM43FkUSBgm1Cn5C1RmTggI="; }; - propagatedBuildInputs = with python3Packages; [ hidapi setuptools ]; + propagatedBuildInputs = with python3Packages; [ + hidapi + setuptools + ]; checkInputs = [ python3Packages.pytest ]; checkPhase = "pytest"; diff --git a/pkgs/by-name/ri/river-bnf/package.nix b/pkgs/by-name/ri/river-bnf/package.nix index bae48c268483cb..fa8f0b58c8f383 100644 --- a/pkgs/by-name/ri/river-bnf/package.nix +++ b/pkgs/by-name/ri/river-bnf/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromSourcehut -, wayland -, wayland-scanner -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromSourcehut, + wayland, + wayland-scanner, + unstableGitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ri/river-filtile/package.nix b/pkgs/by-name/ri/river-filtile/package.nix index 5b0b9962f0bce5..06f4b4007ca5ef 100644 --- a/pkgs/by-name/ri/river-filtile/package.nix +++ b/pkgs/by-name/ri/river-filtile/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ri/river-luatile/package.nix b/pkgs/by-name/ri/river-luatile/package.nix index 8999ea2445e575..1168f7d744333e 100644 --- a/pkgs/by-name/ri/river-luatile/package.nix +++ b/pkgs/by-name/ri/river-luatile/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, luajit +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + luajit, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ri/river-tag-overlay/package.nix b/pkgs/by-name/ri/river-tag-overlay/package.nix index af78bab02eac2f..eb30df877c5f86 100644 --- a/pkgs/by-name/ri/river-tag-overlay/package.nix +++ b/pkgs/by-name/ri/river-tag-overlay/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromSourcehut -, fetchpatch -, wayland -, pixman -, pkg-config -, wayland-scanner +{ + lib, + stdenv, + fetchFromSourcehut, + fetchpatch, + wayland, + pixman, + pkg-config, + wayland-scanner, }: stdenv.mkDerivation rec { @@ -27,8 +28,14 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ pixman wayland ]; - nativeBuildInputs = [ pkg-config wayland-scanner ]; + buildInputs = [ + pixman + wayland + ]; + nativeBuildInputs = [ + pkg-config + wayland-scanner + ]; makeFlags = [ "DESTDIR=${placeholder "out"}" diff --git a/pkgs/by-name/ri/rivercarro/package.nix b/pkgs/by-name/ri/rivercarro/package.nix index 747bf3ec16f6bd..ac5ddf72f841d6 100644 --- a/pkgs/by-name/ri/rivercarro/package.nix +++ b/pkgs/by-name/ri/rivercarro/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, callPackage -, fetchFromSourcehut -, pkg-config -, river -, wayland -, wayland-protocols -, wayland-scanner -, zig_0_12 +{ + lib, + stdenv, + callPackage, + fetchFromSourcehut, + pkg-config, + river, + wayland, + wayland-protocols, + wayland-scanner, + zig_0_12, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/rk/rkbin/package.nix b/pkgs/by-name/rk/rkbin/package.nix index 0813255c4ceb32..4ac8be8e88f8ff 100644 --- a/pkgs/by-name/rk/rkbin/package.nix +++ b/pkgs/by-name/rk/rkbin/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, rkbin +{ + stdenv, + lib, + fetchFromGitHub, + rkbin, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/rk/rkboot/package.nix b/pkgs/by-name/rk/rkboot/package.nix index f352446e7a1b11..2d30a55f549812 100644 --- a/pkgs/by-name/rk/rkboot/package.nix +++ b/pkgs/by-name/rk/rkboot/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, rkbin -, qemu +{ + stdenv, + lib, + rkbin, + qemu, }: stdenv.mkDerivation { @@ -38,6 +39,9 @@ stdenv.mkDerivation { homepage = "https://github.com/rockchip-linux/rkbin"; license = licenses.unfreeRedistributable; maintainers = with maintainers; [ matthewcroughan ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; }; } diff --git a/pkgs/by-name/rk/rkdeveloptool-pine64/package.nix b/pkgs/by-name/rk/rkdeveloptool-pine64/package.nix index 1c53f6d664f263..fd46328ebe0e83 100644 --- a/pkgs/by-name/rk/rkdeveloptool-pine64/package.nix +++ b/pkgs/by-name/rk/rkdeveloptool-pine64/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, meson -, pkg-config -, libusb1 -, scdoc -, ninja -, cmake +{ + lib, + stdenv, + fetchurl, + meson, + pkg-config, + libusb1, + scdoc, + ninja, + cmake, }: let @@ -27,7 +28,13 @@ stdenv.mkDerivation { "udev_rules_dir = '$out/lib/udev'" ''; - nativeBuildInputs = [ meson ninja cmake pkg-config scdoc ]; + nativeBuildInputs = [ + meson + ninja + cmake + pkg-config + scdoc + ]; buildInputs = [ libusb1 ]; diff --git a/pkgs/by-name/rk/rkdeveloptool/package.nix b/pkgs/by-name/rk/rkdeveloptool/package.nix index dcbcfcf432c876..6c06584d796830 100644 --- a/pkgs/by-name/rk/rkdeveloptool/package.nix +++ b/pkgs/by-name/rk/rkdeveloptool/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, libusb1 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libusb1, +}: stdenv.mkDerivation { pname = "rkdeveloptool"; @@ -11,7 +18,10 @@ stdenv.mkDerivation { sha256 = "eIFzyoY6l3pdfCN0uS16hbVp0qzdG3MtcS1jnDX1Yk0="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libusb1 ]; diff --git a/pkgs/by-name/rk/rke/package.nix b/pkgs/by-name/rk/rke/package.nix index 1cd9c415cfe01e..3fe4279725b264 100644 --- a/pkgs/by-name/rk/rke/package.nix +++ b/pkgs/by-name/rk/rke/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "rke"; @@ -15,7 +19,11 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" "-X=main.VERSION=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.VERSION=v${version}" + ]; meta = with lib; { homepage = "https://github.com/rancher/rke"; diff --git a/pkgs/by-name/rk/rkflashtool/package.nix b/pkgs/by-name/rk/rkflashtool/package.nix index 95c5351b7a02ba..edece60a45b3e0 100644 --- a/pkgs/by-name/rk/rkflashtool/package.nix +++ b/pkgs/by-name/rk/rkflashtool/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libusb1 }: +{ + lib, + stdenv, + fetchurl, + libusb1, +}: stdenv.mkDerivation rec { pname = "rkflashtool"; diff --git a/pkgs/by-name/rk/rkrlv2/package.nix b/pkgs/by-name/rk/rkrlv2/package.nix index fa62fcfa47ac6b..f4f297884ea969 100644 --- a/pkgs/by-name/rk/rkrlv2/package.nix +++ b/pkgs/by-name/rk/rkrlv2/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, lv2, fftw, cmake, libXpm -, libXft, libjack2, libsamplerate, libsndfile }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + lv2, + fftw, + cmake, + libXpm, + libXft, + libjack2, + libsamplerate, + libsndfile, +}: stdenv.mkDerivation rec { pname = "rkrlv2"; @@ -12,8 +24,19 @@ stdenv.mkDerivation rec { sha256 = "WjpPNUEYw4aGrh57J+7kkxKFXgCJWNaWAmueFbNUJJo="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libXft libXpm lv2 fftw libjack2 libsamplerate libsndfile ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + libXft + libXpm + lv2 + fftw + libjack2 + libsamplerate + libsndfile + ]; meta = with lib; { description = "Rakarrak effects ported to LV2"; diff --git a/pkgs/by-name/rk/rkvm/package.nix b/pkgs/by-name/rk/rkvm/package.nix index 4dee8423437bf1..08c516c28af021 100644 --- a/pkgs/by-name/rk/rkvm/package.nix +++ b/pkgs/by-name/rk/rkvm/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, libevdev -, openssl -, makeWrapper -, nixosTests +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + libevdev, + openssl, + makeWrapper, + nixosTests, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,11 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-aq8Ky29jXY0cW5s0E4NDs29DY8RIA0Fvy2R72WPAYsk="; - nativeBuildInputs = [ pkg-config rustPlatform.bindgenHook makeWrapper ]; + nativeBuildInputs = [ + pkg-config + rustPlatform.bindgenHook + makeWrapper + ]; buildInputs = [ libevdev ]; postInstall = '' diff --git a/pkgs/by-name/rl/rl_json/package.nix b/pkgs/by-name/rl/rl_json/package.nix index ac6e7950f4114d..c9c000718135aa 100644 --- a/pkgs/by-name/rl/rl_json/package.nix +++ b/pkgs/by-name/rl/rl_json/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, tcl +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + tcl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/rl/rlaunch/package.nix b/pkgs/by-name/rl/rlaunch/package.nix index 52499df258e061..0d454daa41ed38 100644 --- a/pkgs/by-name/rl/rlaunch/package.nix +++ b/pkgs/by-name/rl/rlaunch/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, xorg +{ + lib, + fetchFromGitHub, + rustPlatform, + xorg, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,16 @@ rustPlatform.buildRustPackage rec { # The x11_dl crate dlopen()s these libraries, so we have to inject them into rpath. postFixup = '' - patchelf --set-rpath ${lib.makeLibraryPath (with xorg; [ libX11 libXft libXinerama ])} $out/bin/rlaunch + patchelf --set-rpath ${ + lib.makeLibraryPath ( + with xorg; + [ + libX11 + libXft + libXinerama + ] + ) + } $out/bin/rlaunch ''; meta = with lib; { diff --git a/pkgs/by-name/rl/rlci/package.nix b/pkgs/by-name/rl/rlci/package.nix index 01c9e491b11f01..97d49889cb1b8e 100644 --- a/pkgs/by-name/rl/rlci/package.nix +++ b/pkgs/by-name/rl/rlci/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/rl/rlog/package.nix b/pkgs/by-name/rl/rlog/package.nix index 75760fed577f0e..22e2d659e244e0 100644 --- a/pkgs/by-name/rl/rlog/package.nix +++ b/pkgs/by-name/rl/rlog/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "rlog"; diff --git a/pkgs/by-name/rl/rlottie/package.nix b/pkgs/by-name/rl/rlottie/package.nix index 2243e482a56942..5c23b1bf9f9b01 100644 --- a/pkgs/by-name/rl/rlottie/package.nix +++ b/pkgs/by-name/rl/rlottie/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, ninja -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + ninja, + pkg-config, }: stdenv.mkDerivation rec { @@ -21,23 +22,34 @@ stdenv.mkDerivation rec { patches = [ # Fixed build with GCC 11 (fetchpatch { - url = "https://github.com/Samsung/rlottie/commit/2d7b1fa2b005bba3d4b45e8ebfa632060e8a157a.patch"; - hash = "sha256-2JPsj0WiBMMu0N3NUYDrHumvPN2YS8nPq5Zwagx6UWE="; + url = "https://github.com/Samsung/rlottie/commit/2d7b1fa2b005bba3d4b45e8ebfa632060e8a157a.patch"; + hash = "sha256-2JPsj0WiBMMu0N3NUYDrHumvPN2YS8nPq5Zwagx6UWE="; }) ]; - nativeBuildInputs = [ cmake ninja pkg-config ]; + nativeBuildInputs = [ + cmake + ninja + pkg-config + ]; cmakeFlags = [ (lib.cmakeFeature "LIB_INSTALL_DIR" "${placeholder "out"}/lib") ]; - env.NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) "-U__ARM_NEON__"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 + ) "-U__ARM_NEON__"; meta = with lib; { homepage = "https://github.com/Samsung/rlottie"; description = "Platform independent standalone c++ library for rendering vector based animations and art in realtime"; - license = with licenses; [ mit bsd3 mpl11 ftl ]; + license = with licenses; [ + mit + bsd3 + mpl11 + ftl + ]; platforms = platforms.all; maintainers = with maintainers; [ CRTified ]; }; diff --git a/pkgs/by-name/rl/rlwrap/package.nix b/pkgs/by-name/rl/rlwrap/package.nix index 68baa3318871e3..5d465fac34726e 100644 --- a/pkgs/by-name/rl/rlwrap/package.nix +++ b/pkgs/by-name/rl/rlwrap/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, perl, readline }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + perl, + readline, +}: stdenv.mkDerivation rec { pname = "rlwrap"; @@ -16,7 +23,10 @@ stdenv.mkDerivation rec { --replace "if(*p >= 0 && *p < ' ')" "if(*p >= 0 && (*p >= 0) && (*p < ' '))" ''; - nativeBuildInputs = [ autoreconfHook perl ]; + nativeBuildInputs = [ + autoreconfHook + perl + ]; buildInputs = [ readline ]; diff --git a/pkgs/by-name/rm/rm-improved/package.nix b/pkgs/by-name/rm/rm-improved/package.nix index 38fcfd3a339bd7..b9f7f30138a288 100644 --- a/pkgs/by-name/rm/rm-improved/package.nix +++ b/pkgs/by-name/rm/rm-improved/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, rustPlatform, lib }: +{ + fetchFromGitHub, + rustPlatform, + lib, +}: rustPlatform.buildRustPackage rec { pname = "rm-improved"; diff --git a/pkgs/by-name/rm/rmapi/package.nix b/pkgs/by-name/rm/rmapi/package.nix index 1c2765976a84b6..182a98e8058f6a 100644 --- a/pkgs/by-name/rm/rmapi/package.nix +++ b/pkgs/by-name/rm/rmapi/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "rmapi"; diff --git a/pkgs/by-name/rm/rmate-sh/package.nix b/pkgs/by-name/rm/rmate-sh/package.nix index b362807f19d236..d0e1d344601d75 100644 --- a/pkgs/by-name/rm/rmate-sh/package.nix +++ b/pkgs/by-name/rm/rmate-sh/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, patsh -, hostname +{ + lib, + stdenv, + fetchFromGitHub, + patsh, + hostname, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/rm/rmenu/package.nix b/pkgs/by-name/rm/rmenu/package.nix index f5abbc9dd65ab4..d5b2bd3a9085ac 100644 --- a/pkgs/by-name/rm/rmenu/package.nix +++ b/pkgs/by-name/rm/rmenu/package.nix @@ -1,13 +1,14 @@ -{ fetchFromGitHub -, glib -, gtk3 -, lib -, libsoup_3 -, networkmanager -, pkg-config -, rustPlatform -, webkitgtk_4_1 -, wrapGAppsHook3 +{ + fetchFromGitHub, + glib, + gtk3, + lib, + libsoup_3, + networkmanager, + pkg-config, + rustPlatform, + webkitgtk_4_1, + wrapGAppsHook3, }: rustPlatform.buildRustPackage rec { pname = "rmenu"; diff --git a/pkgs/by-name/rm/rmfuse/package.nix b/pkgs/by-name/rm/rmfuse/package.nix index 72e7162d987ead..6ae5c1c1d04255 100644 --- a/pkgs/by-name/rm/rmfuse/package.nix +++ b/pkgs/by-name/rm/rmfuse/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/rm/rmg/package.nix b/pkgs/by-name/rm/rmg/package.nix index 8dcd685da4dd4e..4c2525b01b92ed 100644 --- a/pkgs/by-name/rm/rmg/package.nix +++ b/pkgs/by-name/rm/rmg/package.nix @@ -1,32 +1,38 @@ -{ lib -, stdenv -, fetchFromGitHub -, gitUpdater -, boost -, cmake -, discord-rpc -, freetype -, hidapi -, libpng -, libsamplerate -, minizip -, nasm -, pkg-config -, qt6Packages -, SDL2 -, speexdsp -, vulkan-headers -, vulkan-loader -, which -, xdg-user-dirs -, zlib -, withWayland ? false -# Affects final license -, withAngrylionRdpPlus ? false +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + boost, + cmake, + discord-rpc, + freetype, + hidapi, + libpng, + libsamplerate, + minizip, + nasm, + pkg-config, + qt6Packages, + SDL2, + speexdsp, + vulkan-headers, + vulkan-loader, + which, + xdg-user-dirs, + zlib, + withWayland ? false, + # Affects final license + withAngrylionRdpPlus ? false, }: let - inherit (qt6Packages) qtbase qtsvg qtwayland wrapQtAppsHook; + inherit (qt6Packages) + qtbase + qtsvg + qtwayland + wrapQtAppsHook + ; in stdenv.mkDerivation rec { pname = "rmg"; @@ -73,9 +79,11 @@ stdenv.mkDerivation rec { "-DUSE_ANGRYLION=${lib.boolToString withAngrylionRdpPlus}" ]; - qtWrapperArgs = lib.optionals stdenv.hostPlatform.isLinux [ - "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ vulkan-loader ]}" - ] ++ lib.optional withWayland "--set RMG_WAYLAND 1"; + qtWrapperArgs = + lib.optionals stdenv.hostPlatform.isLinux [ + "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ vulkan-loader ]}" + ] + ++ lib.optional withWayland "--set RMG_WAYLAND 1"; passthru.updateScript = gitUpdater { rev-prefix = "v"; }; diff --git a/pkgs/by-name/rm/rmount/package.nix b/pkgs/by-name/rm/rmount/package.nix index 257db9af80f681..30d2d86942e13f 100644 --- a/pkgs/by-name/rm/rmount/package.nix +++ b/pkgs/by-name/rm/rmount/package.nix @@ -1,8 +1,17 @@ -{ lib, stdenv, nmap, jq, cifs-utils, sshfs, fetchFromGitHub, makeWrapper }: +{ + lib, + stdenv, + nmap, + jq, + cifs-utils, + sshfs, + fetchFromGitHub, + makeWrapper, +}: stdenv.mkDerivation rec { - pname = "rmount"; + pname = "rmount"; version = "1.1.0"; src = fetchFromGitHub { @@ -19,7 +28,14 @@ stdenv.mkDerivation rec { install -D ${src}/rmount.bash $out/bin/rmount install -D ${src}/config.json $out/share/config.json - wrapProgram $out/bin/rmount --prefix PATH : ${lib.makeBinPath [ nmap jq cifs-utils sshfs ]} + wrapProgram $out/bin/rmount --prefix PATH : ${ + lib.makeBinPath [ + nmap + jq + cifs-utils + sshfs + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/rm/rmtrash/package.nix b/pkgs/by-name/rm/rmtrash/package.nix index 793cd49d418856..68f889ed20f6a8 100644 --- a/pkgs/by-name/rm/rmtrash/package.nix +++ b/pkgs/by-name/rm/rmtrash/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenvNoCC, fetchFromGitHub, makeWrapper -, trash-cli, coreutils, which, getopt }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + makeWrapper, + trash-cli, + coreutils, + which, + getopt, +}: stdenvNoCC.mkDerivation rec { pname = "rmtrash"; @@ -18,7 +26,14 @@ stdenvNoCC.mkDerivation rec { for f in rm{,dir}trash; do install -D ./$f $out/bin/$f wrapProgram $out/bin/$f \ - --prefix PATH : ${lib.makeBinPath [ trash-cli coreutils which getopt ]} + --prefix PATH : ${ + lib.makeBinPath [ + trash-cli + coreutils + which + getopt + ] + } done ''; diff --git a/pkgs/by-name/rm/rmw/package.nix b/pkgs/by-name/rm/rmw/package.nix index a6bbb408402974..f405ef621d921b 100644 --- a/pkgs/by-name/rm/rmw/package.nix +++ b/pkgs/by-name/rm/rmw/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, ncurses +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + ncurses, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/rn/rnd-name/package.nix b/pkgs/by-name/rn/rnd-name/package.nix index 6a60add9b9b37a..9b10a3ca766e5e 100644 --- a/pkgs/by-name/rn/rnd-name/package.nix +++ b/pkgs/by-name/rn/rnd-name/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, }: let version = "1.0.0"; diff --git a/pkgs/by-name/rn/rng-tools/package.nix b/pkgs/by-name/rn/rng-tools/package.nix index f17615eaa1dd5b..4ada86ef692de9 100644 --- a/pkgs/by-name/rn/rng-tools/package.nix +++ b/pkgs/by-name/rn/rng-tools/package.nix @@ -1,20 +1,28 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, libtool -, pkg-config -, psmisc -, argp-standalone -, openssl -, libcap -, jitterentropy, withJitterEntropy ? true +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libtool, + pkg-config, + psmisc, + argp-standalone, + openssl, + libcap, + jitterentropy, + withJitterEntropy ? true, # WARNING: DO NOT USE BEACON GENERATED VALUES AS SECRET CRYPTOGRAPHIC KEYS # https://www.nist.gov/programs-projects/nist-randomness-beacon -, curl, jansson, libxml2, withNistBeacon ? false -, libp11, opensc, withPkcs11 ? true -, rtl-sdr, withRtlsdr ? true -, withQrypt ? false + curl, + jansson, + libxml2, + withNistBeacon ? false, + libp11, + opensc, + withPkcs11 ? true, + rtl-sdr, + withRtlsdr ? true, + withQrypt ? false, }: stdenv.mkDerivation rec { @@ -28,31 +36,51 @@ stdenv.mkDerivation rec { hash = "sha256-wqJvLvxmNG2nb5P525w25Y8byUUJi24QIHNJomCKeG8="; }; - nativeBuildInputs = [ autoreconfHook libtool pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + libtool + pkg-config + ]; configureFlags = [ (lib.enableFeature (withJitterEntropy) "jitterentropy") - (lib.withFeature (withNistBeacon) "nistbeacon") - (lib.withFeature (withPkcs11) "pkcs11") - (lib.withFeature (withRtlsdr) "rtlsdr") - (lib.withFeature (withQrypt) "qrypt") + (lib.withFeature (withNistBeacon) "nistbeacon") + (lib.withFeature (withPkcs11) "pkcs11") + (lib.withFeature (withRtlsdr) "rtlsdr") + (lib.withFeature (withQrypt) "qrypt") ]; - buildInputs = [ openssl libcap ] + buildInputs = + [ + openssl + libcap + ] ++ lib.optionals stdenv.hostPlatform.isMusl [ argp-standalone ] ++ lib.optionals withJitterEntropy [ jitterentropy ] - ++ lib.optionals withNistBeacon [ curl jansson libxml2 ] - ++ lib.optionals withPkcs11 [ libp11 libp11.passthru.openssl ] - ++ lib.optionals withRtlsdr [ rtl-sdr ] - ++ lib.optionals withQrypt [ curl jansson ]; + ++ lib.optionals withNistBeacon [ + curl + jansson + libxml2 + ] + ++ lib.optionals withPkcs11 [ + libp11 + libp11.passthru.openssl + ] + ++ lib.optionals withRtlsdr [ rtl-sdr ] + ++ lib.optionals withQrypt [ + curl + jansson + ]; enableParallelBuilding = true; - makeFlags = [ - "AR:=$(AR)" # For cross-compilation - ] ++ lib.optionals withPkcs11 [ - "PKCS11_ENGINE=${opensc}/lib/opensc-pkcs11.so" # Overrides configure script paths - ]; + makeFlags = + [ + "AR:=$(AR)" # For cross-compilation + ] + ++ lib.optionals withPkcs11 [ + "PKCS11_ENGINE=${opensc}/lib/opensc-pkcs11.so" # Overrides configure script paths + ]; doCheck = true; preCheck = '' @@ -82,6 +110,9 @@ stdenv.mkDerivation rec { changelog = "https://github.com/nhorman/rng-tools/releases/tag/v${version}"; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ johnazoidberg c0bw3b ]; + maintainers = with maintainers; [ + johnazoidberg + c0bw3b + ]; }; } diff --git a/pkgs/by-name/rn/rnix-hashes/package.nix b/pkgs/by-name/rn/rnix-hashes/package.nix index d69c7e6ef96f2b..12144247e290a7 100644 --- a/pkgs/by-name/rn/rnix-hashes/package.nix +++ b/pkgs/by-name/rn/rnix-hashes/package.nix @@ -1,4 +1,9 @@ -{ lib, rustPlatform, fetchFromGitHub, fetchpatch }: +{ + lib, + rustPlatform, + fetchFromGitHub, + fetchpatch, +}: rustPlatform.buildRustPackage rec { pname = "rnix-hashes"; @@ -26,6 +31,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "rnix-hashes"; homepage = "https://github.com/numtide/rnix-hashes"; license = licenses.asl20; - maintainers = with maintainers; [ rizary SuperSandro2000 ]; + maintainers = with maintainers; [ + rizary + SuperSandro2000 + ]; }; } diff --git a/pkgs/by-name/rn/rnm/package.nix b/pkgs/by-name/rn/rnm/package.nix index 479feabb8ebc5c..98fa3fbb2fe3e9 100644 --- a/pkgs/by-name/rn/rnm/package.nix +++ b/pkgs/by-name/rn/rnm/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, gmp -, jpcre2 -, pcre2 +{ + lib, + stdenv, + fetchFromGitHub, + gmp, + jpcre2, + pcre2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/rn/rnnoise/package.nix b/pkgs/by-name/rn/rnnoise/package.nix index eb77106fd29faf..96127916b5ccad 100644 --- a/pkgs/by-name/rn/rnnoise/package.nix +++ b/pkgs/by-name/rn/rnnoise/package.nix @@ -1,5 +1,13 @@ -{ stdenv, lib, fetchurl, fetchzip, autoreconfHook, writeScript, fetchpatch -, modelUrl ? "", modelHash ? "" # Allow overriding the model URL and hash +{ + stdenv, + lib, + fetchurl, + fetchzip, + autoreconfHook, + writeScript, + fetchpatch, + modelUrl ? "", + modelHash ? "", # Allow overriding the model URL and hash }: let @@ -9,10 +17,15 @@ let default_model_version = modelVersionJSON.version; # Either use the default model or the one provided by package override - model_url = if (modelUrl == "") then "https://media.xiph.org/rnnoise/models/rnnoise_data-${default_model_version}.tar.gz" else modelUrl; + model_url = + if (modelUrl == "") then + "https://media.xiph.org/rnnoise/models/rnnoise_data-${default_model_version}.tar.gz" + else + modelUrl; model_hash = if (modelHash == "") then modelVersionJSON.hash else modelHash; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "rnnoise"; version = "0.2"; diff --git a/pkgs/by-name/rn/rnp/package.nix b/pkgs/by-name/rn/rnp/package.nix index 686fe3e53431c4..f8cd8b45da9d08 100644 --- a/pkgs/by-name/rn/rnp/package.nix +++ b/pkgs/by-name/rn/rnp/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, asciidoctor -, botan3 -, bzip2 -, cmake -, fetchFromGitHub -, gnupg -, gtest -, json_c -, pkg-config -, python3 -, sexpp -, zlib +{ + lib, + stdenv, + asciidoctor, + botan3, + bzip2, + cmake, + fetchFromGitHub, + gnupg, + gtest, + json_c, + pkg-config, + python3, + sexpp, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -25,7 +26,13 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-jUh7BxRnB6KePCk1jIvKzXgxSmWdKlQYmxshZZY4SBQ"; }; - buildInputs = [ zlib bzip2 json_c botan3 sexpp ]; + buildInputs = [ + zlib + bzip2 + json_c + botan3 + sexpp + ]; patches = [ ]; @@ -39,13 +46,24 @@ stdenv.mkDerivation (finalAttrs: { "-DSYSTEM_LIBSEXPP=on" ]; - nativeBuildInputs = [ asciidoctor cmake gnupg gtest pkg-config python3 ]; + nativeBuildInputs = [ + asciidoctor + cmake + gnupg + gtest + pkg-config + python3 + ]; # NOTE: check-only inputs should ideally be moved to nativeCheckInputs, but it # would fail during buildPhase. # nativeCheckInputs = [ gtest python3 ]; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; preConfigure = '' echo "v${finalAttrs.version}" > version.txt diff --git a/pkgs/by-name/rn/rnr/package.nix b/pkgs/by-name/rn/rnr/package.nix index 31f627d4bae6b2..cc9d7683f96bc4 100644 --- a/pkgs/by-name/rn/rnr/package.nix +++ b/pkgs/by-name/rn/rnr/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "rnr"; diff --git a/pkgs/by-name/rn/rnv/package.nix b/pkgs/by-name/rn/rnv/package.nix index 1ee3355d10529b..80e53c99370f2c 100644 --- a/pkgs/by-name/rn/rnv/package.nix +++ b/pkgs/by-name/rn/rnv/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, expat }: +{ + lib, + stdenv, + fetchurl, + expat, +}: stdenv.mkDerivation rec { pname = "rnv"; diff --git a/pkgs/by-name/ro/roadrunner/package.nix b/pkgs/by-name/ro/roadrunner/package.nix index 164d4812012482..59d63405c2a90f 100644 --- a/pkgs/by-name/ro/roadrunner/package.nix +++ b/pkgs/by-name/ro/roadrunner/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/ro/roam-research/darwin.nix b/pkgs/by-name/ro/roam-research/darwin.nix index 721e9e8fc7e9d0..b7b2f5663f6f87 100644 --- a/pkgs/by-name/ro/roam-research/darwin.nix +++ b/pkgs/by-name/ro/roam-research/darwin.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, _7zz, fetchurl }: +{ + lib, + stdenv, + _7zz, + fetchurl, +}: let common = import ./common.nix { inherit fetchurl; }; inherit (stdenv.hostPlatform) system; @@ -29,7 +34,10 @@ stdenv.mkDerivation rec { maintainers = with lib.maintainers; [ dbalan ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - platforms = [ "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-darwin" + "aarch64-darwin" + ]; mainProgram = "roam-research"; }; } diff --git a/pkgs/by-name/ro/roam-research/linux.nix b/pkgs/by-name/ro/roam-research/linux.nix index 04a05d95ffc2f4..c37ae5f13984e6 100644 --- a/pkgs/by-name/ro/roam-research/linux.nix +++ b/pkgs/by-name/ro/roam-research/linux.nix @@ -1,8 +1,39 @@ -{ stdenv, lib, fetchurl, alsa-lib, atk, cairo, cups, dbus, dpkg, expat -, gdk-pixbuf, glib, gtk3, libX11, libXScrnSaver, libXcomposite, libXcursor -, libXdamage, libXext, libXfixes, libXi, libXrandr, libXrender, libXtst, libdrm -, libpulseaudio, libxcb, libxkbcommon, libxshmfence, mesa, nspr, nss, pango -, udev, }: +{ + stdenv, + lib, + fetchurl, + alsa-lib, + atk, + cairo, + cups, + dbus, + dpkg, + expat, + gdk-pixbuf, + glib, + gtk3, + libX11, + libXScrnSaver, + libXcomposite, + libXcursor, + libXdamage, + libXext, + libXfixes, + libXi, + libXrandr, + libXrender, + libXtst, + libdrm, + libpulseaudio, + libxcb, + libxkbcommon, + libxshmfence, + mesa, + nspr, + nss, + pango, + udev, +}: let common = import ./common.nix { inherit fetchurl; }; @@ -40,7 +71,8 @@ let libpulseaudio udev ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { inherit (common) pname version; src = common.sources.${system} or (throw "Source for ${pname} is not available for ${system}"); diff --git a/pkgs/by-name/ro/robin-map/package.nix b/pkgs/by-name/ro/robin-map/package.nix index d15bada3e813c0..2605faabea8569 100644 --- a/pkgs/by-name/ro/robin-map/package.nix +++ b/pkgs/by-name/ro/robin-map/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ro/robo3t/package.nix b/pkgs/by-name/ro/robo3t/package.nix index c2ea6a2a25520c..784ecf6cb244b1 100644 --- a/pkgs/by-name/ro/robo3t/package.nix +++ b/pkgs/by-name/ro/robo3t/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, curlWithGnuTls -, zlib -, glib -, xorg -, dbus -, fontconfig -, libGL -, freetype -, xkeyboard_config -, makeDesktopItem -, makeWrapper +{ + lib, + stdenv, + fetchurl, + curlWithGnuTls, + zlib, + glib, + xorg, + dbus, + fontconfig, + libGL, + freetype, + xkeyboard_config, + makeDesktopItem, + makeWrapper, }: stdenv.mkDerivation rec { @@ -36,7 +37,10 @@ stdenv.mkDerivation rec { comment = "Query GUI for mongodb"; desktopName = "Robo3T"; genericName = "MongoDB management tool"; - categories = [ "Development" "IDE" ]; + categories = [ + "Development" + "IDE" + ]; }; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/by-name/ro/robodoc/package.nix b/pkgs/by-name/ro/robodoc/package.nix index 8ebd078b9696ad..a380bb6111cf9e 100644 --- a/pkgs/by-name/ro/robodoc/package.nix +++ b/pkgs/by-name/ro/robodoc/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ro/robotfindskitten/package.nix b/pkgs/by-name/ro/robotfindskitten/package.nix index a955d337753ef4..327b0aca626b3e 100644 --- a/pkgs/by-name/ro/robotfindskitten/package.nix +++ b/pkgs/by-name/ro/robotfindskitten/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, ncurses -, pkg-config -, texinfo +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + ncurses, + pkg-config, + texinfo, }: stdenv.mkDerivation (finalAttrs: { @@ -18,7 +19,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-z6//Yfp3BtJAtUdY05m1eKVrTdH19MvK7LZOwX5S1CM="; }; - outputs = [ "out" "man" "info" ]; + outputs = [ + "out" + "man" + "info" + ]; nativeBuildInputs = [ autoreconfHook diff --git a/pkgs/by-name/ro/roboto-mono/package.nix b/pkgs/by-name/ro/roboto-mono/package.nix index 5d7cc57a4b435b..3c71e0f2171415 100644 --- a/pkgs/by-name/ro/roboto-mono/package.nix +++ b/pkgs/by-name/ro/roboto-mono/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let # Latest commit touching the robotomono tree diff --git a/pkgs/by-name/ro/roboto-serif/package.nix b/pkgs/by-name/ro/roboto-serif/package.nix index ba8aa7a831e09e..7a4bc9a186e91e 100644 --- a/pkgs/by-name/ro/roboto-serif/package.nix +++ b/pkgs/by-name/ro/roboto-serif/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, unzip +{ + lib, + stdenvNoCC, + fetchurl, + unzip, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/ro/roboto-slab/package.nix b/pkgs/by-name/ro/roboto-slab/package.nix index dc37c8258564c9..cd5c62bd4a7bd7 100644 --- a/pkgs/by-name/ro/roboto-slab/package.nix +++ b/pkgs/by-name/ro/roboto-slab/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "roboto-slab"; diff --git a/pkgs/by-name/ro/roboto/package.nix b/pkgs/by-name/ro/roboto/package.nix index b9e287945a4c2b..b22a68fde94590 100644 --- a/pkgs/by-name/ro/roboto/package.nix +++ b/pkgs/by-name/ro/roboto/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "roboto"; diff --git a/pkgs/by-name/ro/robustirc-bridge/package.nix b/pkgs/by-name/ro/robustirc-bridge/package.nix index 2d5c6ef1231b81..32907b1894af80 100644 --- a/pkgs/by-name/ro/robustirc-bridge/package.nix +++ b/pkgs/by-name/ro/robustirc-bridge/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "robustirc-bridge"; diff --git a/pkgs/by-name/ro/roc-toolkit/package.nix b/pkgs/by-name/ro/roc-toolkit/package.nix index 6c579774e4bfc5..410563c4150ef1 100644 --- a/pkgs/by-name/ro/roc-toolkit/package.nix +++ b/pkgs/by-name/ro/roc-toolkit/package.nix @@ -1,4 +1,5 @@ -{ stdenv, +{ + stdenv, lib, fetchFromGitHub, scons, @@ -18,14 +19,17 @@ soxSupport ? true, sox, libsndfileSupport ? true, - libsndfile + libsndfile, }: stdenv.mkDerivation rec { pname = "roc-toolkit"; version = "0.4.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "roc-streaming"; @@ -41,29 +45,38 @@ stdenv.mkDerivation rec { pkg-config ]; - propagatedBuildInputs = [ - libuv - speexdsp - ] ++ lib.optional openfecSupport openfec + propagatedBuildInputs = + [ + libuv + speexdsp + ] + ++ lib.optional openfecSupport openfec ++ lib.optional libunwindSupport libunwind ++ lib.optional pulseaudioSupport libpulseaudio ++ lib.optional opensslSupport openssl ++ lib.optional soxSupport sox ++ lib.optional libsndfileSupport libsndfile; - sconsFlags = lib.optionals (!stdenv.hostPlatform.isDarwin) - [ "--build=${stdenv.buildPlatform.config}" - "--host=${stdenv.hostPlatform.config}" ] ++ - [ "--prefix=${placeholder "out"}" ] ++ - lib.optional (!opensslSupport) "--disable-openssl" ++ - lib.optional (!soxSupport) "--disable-sox" ++ - lib.optional (!libunwindSupport) "--disable-libunwind" ++ - lib.optional (!pulseaudioSupport) "--disable-pulseaudio" ++ - lib.optional (!libsndfileSupport) "--disable-sndfile" ++ - (if (!openfecSupport) - then ["--disable-openfec"] - else [ "--with-libraries=${openfec}/lib" - "--with-openfec-includes=${openfec.dev}/include" ]); + sconsFlags = + lib.optionals (!stdenv.hostPlatform.isDarwin) [ + "--build=${stdenv.buildPlatform.config}" + "--host=${stdenv.hostPlatform.config}" + ] + ++ [ "--prefix=${placeholder "out"}" ] + ++ lib.optional (!opensslSupport) "--disable-openssl" + ++ lib.optional (!soxSupport) "--disable-sox" + ++ lib.optional (!libunwindSupport) "--disable-libunwind" + ++ lib.optional (!pulseaudioSupport) "--disable-pulseaudio" + ++ lib.optional (!libsndfileSupport) "--disable-sndfile" + ++ ( + if (!openfecSupport) then + [ "--disable-openfec" ] + else + [ + "--with-libraries=${openfec}/lib" + "--with-openfec-includes=${openfec.dev}/include" + ] + ); meta = with lib; { description = "Roc is a toolkit for real-time audio streaming over the network"; diff --git a/pkgs/by-name/ro/roccat-tools/package.nix b/pkgs/by-name/ro/roccat-tools/package.nix index 389d5036b754c7..6bf02cbf351bda 100644 --- a/pkgs/by-name/ro/roccat-tools/package.nix +++ b/pkgs/by-name/ro/roccat-tools/package.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchurl, cmake, pkg-config, gettext -, dbus, dbus-glib, libgaminggear, libgudev, lua -, harfbuzz, runtimeShell, coreutils, kmod +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + gettext, + dbus, + dbus-glib, + libgaminggear, + libgudev, + lua, + harfbuzz, + runtimeShell, + coreutils, + kmod, }: stdenv.mkDerivation rec { @@ -26,8 +39,18 @@ stdenv.mkDerivation rec { --replace "/bin/echo" "${coreutils}/bin/echo" ''; - nativeBuildInputs = [ cmake pkg-config gettext ]; - buildInputs = [ dbus dbus-glib libgaminggear libgudev lua ]; + nativeBuildInputs = [ + cmake + pkg-config + gettext + ]; + buildInputs = [ + dbus + dbus-glib + libgaminggear + libgudev + lua + ]; cmakeFlags = [ "-DUDEVDIR=\${out}/lib/udev/rules.d" diff --git a/pkgs/by-name/ro/rocketchat-desktop/package.nix b/pkgs/by-name/ro/rocketchat-desktop/package.nix index ab9ef85903f9dc..401b1c9f512fae 100644 --- a/pkgs/by-name/ro/rocketchat-desktop/package.nix +++ b/pkgs/by-name/ro/rocketchat-desktop/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, pkgs, fetchurl, wrapGAppsHook3 }: +{ + lib, + stdenv, + pkgs, + fetchurl, + wrapGAppsHook3, +}: let libPathNative = { packages }: lib.makeLibraryPath packages; in @@ -12,7 +18,7 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - wrapGAppsHook3 #to fully work with gnome also needs programs.dconf.enable = true in your configuration.nix + wrapGAppsHook3 # to fully work with gnome also needs programs.dconf.enable = true in your configuration.nix ]; buildInputs = with pkgs; [ diff --git a/pkgs/by-name/ro/rocksdb/package.nix b/pkgs/by-name/ro/rocksdb/package.nix index 7fd53144e6c626..8327560a56c4fe 100644 --- a/pkgs/by-name/ro/rocksdb/package.nix +++ b/pkgs/by-name/ro/rocksdb/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -, bzip2 -, lz4 -, snappy -, zlib -, zstd -, windows -, enableJemalloc ? false -, jemalloc -, enableLiburing ? stdenv.hostPlatform.isLinux -, liburing -, enableShared ? !stdenv.hostPlatform.isStatic -, sse42Support ? stdenv.hostPlatform.sse4_2Support +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + bzip2, + lz4, + snappy, + zlib, + zstd, + windows, + enableJemalloc ? false, + jemalloc, + enableLiburing ? stdenv.hostPlatform.isLinux, + liburing, + enableShared ? !stdenv.hostPlatform.isStatic, + sse42Support ? stdenv.hostPlatform.sse4_2Support, }: stdenv.mkDerivation (finalAttrs: { @@ -28,13 +29,25 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-u5uuShM2SxHc9/zL4UU56IhCcR/ZQbzde0LgOYS44bM="; }; - patches = lib.optional (lib.versionAtLeast finalAttrs.version "6.29.3" && enableLiburing) ./fix-findliburing.patch; + patches = lib.optional ( + lib.versionAtLeast finalAttrs.version "6.29.3" && enableLiburing + ) ./fix-findliburing.patch; - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; - propagatedBuildInputs = [ bzip2 lz4 snappy zlib zstd ]; + propagatedBuildInputs = [ + bzip2 + lz4 + snappy + zlib + zstd + ]; - buildInputs = lib.optional enableJemalloc jemalloc + buildInputs = + lib.optional enableJemalloc jemalloc ++ lib.optional enableLiburing liburing ++ lib.optional stdenv.hostPlatform.isMinGW windows.mingw_w64_pthreads; @@ -43,9 +56,11 @@ stdenv.mkDerivation (finalAttrs: { "tools" ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-faligned-allocation" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-faligned-allocation" + ] + ); cmakeFlags = [ "-DPORTABLE=1" @@ -71,27 +86,32 @@ stdenv.mkDerivation (finalAttrs: { # otherwise "cc1: error: -Wformat-security ignored without -Wformat [-Werror=format-security]" hardeningDisable = lib.optional stdenv.hostPlatform.isWindows "format"; - postPatch = lib.optionalString (lib.versionOlder finalAttrs.version "8") '' - # Fix gcc-13 build failures due to missing and - # includes, fixed upstyream sice 8.x - sed -e '1i #include ' -i db/compaction/compaction_iteration_stats.h - sed -e '1i #include ' -i table/block_based/data_block_hash_index.h - sed -e '1i #include ' -i util/string_util.h - sed -e '1i #include ' -i include/rocksdb/utilities/checkpoint.h - '' + lib.optionalString (lib.versionOlder finalAttrs.version "7") '' - # Fix gcc-13 build failures due to missing and - # includes, fixed upstyream sice 7.x - sed -e '1i #include ' -i third-party/folly/folly/synchronization/detail/ProxyLockable-inl.h - ''; + postPatch = + lib.optionalString (lib.versionOlder finalAttrs.version "8") '' + # Fix gcc-13 build failures due to missing and + # includes, fixed upstyream sice 8.x + sed -e '1i #include ' -i db/compaction/compaction_iteration_stats.h + sed -e '1i #include ' -i table/block_based/data_block_hash_index.h + sed -e '1i #include ' -i util/string_util.h + sed -e '1i #include ' -i include/rocksdb/utilities/checkpoint.h + '' + + lib.optionalString (lib.versionOlder finalAttrs.version "7") '' + # Fix gcc-13 build failures due to missing and + # includes, fixed upstyream sice 7.x + sed -e '1i #include ' -i third-party/folly/folly/synchronization/detail/ProxyLockable-inl.h + ''; - preInstall = '' - mkdir -p $tools/bin - cp tools/{ldb,sst_dump}${stdenv.hostPlatform.extensions.executable} $tools/bin/ - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - ls -1 $tools/bin/* | xargs -I{} install_name_tool -change "@rpath/librocksdb.${lib.versions.major finalAttrs.version}.dylib" $out/lib/librocksdb.dylib {} - '' + lib.optionalString (stdenv.hostPlatform.isLinux && enableShared) '' - ls -1 $tools/bin/* | xargs -I{} patchelf --set-rpath $out/lib:${lib.getLib stdenv.cc.cc}/lib {} - ''; + preInstall = + '' + mkdir -p $tools/bin + cp tools/{ldb,sst_dump}${stdenv.hostPlatform.extensions.executable} $tools/bin/ + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + ls -1 $tools/bin/* | xargs -I{} install_name_tool -change "@rpath/librocksdb.${lib.versions.major finalAttrs.version}.dylib" $out/lib/librocksdb.dylib {} + '' + + lib.optionalString (stdenv.hostPlatform.isLinux && enableShared) '' + ls -1 $tools/bin/* | xargs -I{} patchelf --set-rpath $out/lib:${lib.getLib stdenv.cc.cc}/lib {} + ''; # Old version doesn't ship the .pc file, new version puts wrong paths in there. postFixup = '' @@ -107,6 +127,9 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://github.com/facebook/rocksdb/raw/v${finalAttrs.version}/HISTORY.md"; license = licenses.asl20; platforms = platforms.all; - maintainers = with maintainers; [ adev magenbluten ]; + maintainers = with maintainers; [ + adev + magenbluten + ]; }; }) diff --git a/pkgs/by-name/ro/rocksndiamonds/package.nix b/pkgs/by-name/ro/rocksndiamonds/package.nix index 4aa70ffa5334fc..e33bf73ce212ab 100644 --- a/pkgs/by-name/ro/rocksndiamonds/package.nix +++ b/pkgs/by-name/ro/rocksndiamonds/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, makeDesktopItem -, SDL2 -, SDL2_image -, SDL2_mixer -, SDL2_net -, zlib +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + SDL2, + SDL2_image, + SDL2_mixer, + SDL2_net, + zlib, }: stdenv.mkDerivation rec { @@ -25,10 +26,19 @@ stdenv.mkDerivation rec { comment = meta.description; desktopName = "Rocks'n'Diamonds"; genericName = "Tile-based puzzle"; - categories = [ "Game" "LogicGame" ]; + categories = [ + "Game" + "LogicGame" + ]; }; - buildInputs = [ SDL2 SDL2_image SDL2_mixer SDL2_net zlib ]; + buildInputs = [ + SDL2 + SDL2_image + SDL2_mixer + SDL2_net + zlib + ]; preBuild = '' dataDir="$out/share/rocksndiamonds" diff --git a/pkgs/by-name/ro/rockyou/package.nix b/pkgs/by-name/ro/rockyou/package.nix index 6c941fd28724d9..222c1a24d3f1c0 100644 --- a/pkgs/by-name/ro/rockyou/package.nix +++ b/pkgs/by-name/ro/rockyou/package.nix @@ -1,5 +1,6 @@ -{ seclists -, stdenvNoCC +{ + seclists, + stdenvNoCC, }: stdenvNoCC.mkDerivation { pname = "rockyou"; diff --git a/pkgs/by-name/ro/rofi-blezz/package.nix b/pkgs/by-name/ro/rofi-blezz/package.nix index bc552f1e9344b5..65908a2fe9c157 100644 --- a/pkgs/by-name/ro/rofi-blezz/package.nix +++ b/pkgs/by-name/ro/rofi-blezz/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, cairo -, pkg-config -, rofi-unwrapped +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + cairo, + pkg-config, + rofi-unwrapped, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ro/rofi-bluetooth/package.nix b/pkgs/by-name/ro/rofi-bluetooth/package.nix index 4eb757422ae726..5e1fe1b8e06104 100644 --- a/pkgs/by-name/ro/rofi-bluetooth/package.nix +++ b/pkgs/by-name/ro/rofi-bluetooth/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, bc -, bluez +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + bc, + bluez, }: stdenv.mkDerivation { @@ -26,7 +27,12 @@ stdenv.mkDerivation { install -D --target-directory=$out/bin/ ./rofi-bluetooth wrapProgram $out/bin/rofi-bluetooth \ - --prefix PATH ":" ${lib.makeBinPath [ bc bluez ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + bc + bluez + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/ro/rofi-calc/package.nix b/pkgs/by-name/ro/rofi-calc/package.nix index c8ee440ccd05e2..f94234f7b5dfc2 100644 --- a/pkgs/by-name/ro/rofi-calc/package.nix +++ b/pkgs/by-name/ro/rofi-calc/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, rofi-unwrapped -, libqalculate -, glib -, cairo -, gobject-introspection -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + rofi-unwrapped, + libqalculate, + glib, + cairo, + gobject-introspection, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -51,4 +53,3 @@ stdenv.mkDerivation rec { platforms = with platforms; linux; }; } - diff --git a/pkgs/by-name/ro/rofi-file-browser/package.nix b/pkgs/by-name/ro/rofi-file-browser/package.nix index 95eb5c77ca3a7f..76bd8da4488ae9 100644 --- a/pkgs/by-name/ro/rofi-file-browser/package.nix +++ b/pkgs/by-name/ro/rofi-file-browser/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, rofi, gtk3 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + rofi, + gtk3, +}: stdenv.mkDerivation rec { pname = "rofi-file-browser-extended"; @@ -18,8 +26,14 @@ stdenv.mkDerivation rec { --replace "/usr/share/" "$out/share/" ''; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ rofi gtk3 ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + rofi + gtk3 + ]; ROFI_PLUGINS_DIR = "$out/lib/rofi"; diff --git a/pkgs/by-name/ro/rofi-menugen/package.nix b/pkgs/by-name/ro/rofi-menugen/package.nix index 7d5cb9f3eb89ef..925fc9ce19773a 100644 --- a/pkgs/by-name/ro/rofi-menugen/package.nix +++ b/pkgs/by-name/ro/rofi-menugen/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rofi, gnused }: +{ + lib, + stdenv, + fetchFromGitHub, + rofi, + gnused, +}: stdenv.mkDerivation rec { pname = "rofi-menugen"; diff --git a/pkgs/by-name/ro/rofi-mpd/package.nix b/pkgs/by-name/ro/rofi-mpd/package.nix index ec76fbdf801bb1..2756758e349d71 100644 --- a/pkgs/by-name/ro/rofi-mpd/package.nix +++ b/pkgs/by-name/ro/rofi-mpd/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "rofi-mpd"; @@ -11,7 +15,12 @@ python3Packages.buildPythonApplication rec { sha256 = "0jabyn6gqh8ychn2a06xws3avz0lqdnx3qvqkavfd2xr6sp2q7lg"; }; - propagatedBuildInputs = with python3Packages; [ mutagen mpd2 toml appdirs ]; + propagatedBuildInputs = with python3Packages; [ + mutagen + mpd2 + toml + appdirs + ]; # upstream doesn't contain a test suite doCheck = false; diff --git a/pkgs/by-name/ro/rofi-power-menu/package.nix b/pkgs/by-name/ro/rofi-power-menu/package.nix index c16311e67db233..6746cfdbf4ca5f 100644 --- a/pkgs/by-name/ro/rofi-power-menu/package.nix +++ b/pkgs/by-name/ro/rofi-power-menu/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "rofi-power-menu"; diff --git a/pkgs/by-name/ro/rofi-pulse-select/package.nix b/pkgs/by-name/ro/rofi-pulse-select/package.nix index 857cdddeb638e1..e7d1bceb3129de 100644 --- a/pkgs/by-name/ro/rofi-pulse-select/package.nix +++ b/pkgs/by-name/ro/rofi-pulse-select/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, fetchFromGitLab -, lib -, makeWrapper -, ponymix -, rofi-unwrapped +{ + stdenv, + fetchFromGitLab, + lib, + makeWrapper, + ponymix, + rofi-unwrapped, }: stdenv.mkDerivation rec { @@ -23,7 +24,12 @@ stdenv.mkDerivation rec { install -D --target-directory=$out/bin/ ./rofi-pulse-select wrapProgram $out/bin/rofi-pulse-select \ - --prefix PATH ":" ${lib.makeBinPath [ rofi-unwrapped ponymix ]} + --prefix PATH ":" ${ + lib.makeBinPath [ + rofi-unwrapped + ponymix + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/ro/rofi-screenshot/package.nix b/pkgs/by-name/ro/rofi-screenshot/package.nix index 6b1861dc8fc59a..be23fefbc12eab 100644 --- a/pkgs/by-name/ro/rofi-screenshot/package.nix +++ b/pkgs/by-name/ro/rofi-screenshot/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, libnotify -, slop -, ffcast -, ffmpeg -, xclip -, rofi -, coreutils -, gnused -, procps +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + libnotify, + slop, + ffcast, + ffmpeg, + xclip, + rofi, + coreutils, + gnused, + procps, }: stdenv.mkDerivation rec { @@ -48,8 +49,7 @@ stdenv.mkDerivation rec { ''; meta = { - description = - "Use rofi to perform various types of screenshots and screen captures"; + description = "Use rofi to perform various types of screenshots and screen captures"; mainProgram = "rofi-screenshot"; homepage = "https://github.com/ceuk/rofi-screenshot"; maintainers = with lib.maintainers; [ zopieux ]; diff --git a/pkgs/by-name/ro/rofi-systemd/package.nix b/pkgs/by-name/ro/rofi-systemd/package.nix index 9241a066e71398..aa3bb741fabfe2 100644 --- a/pkgs/by-name/ro/rofi-systemd/package.nix +++ b/pkgs/by-name/ro/rofi-systemd/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, rofi, systemd, coreutils, util-linux, gawk, makeWrapper, jq +{ + lib, + stdenv, + fetchFromGitHub, + rofi, + systemd, + coreutils, + util-linux, + gawk, + makeWrapper, + jq, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ro/rofi-top/package.nix b/pkgs/by-name/ro/rofi-top/package.nix index e7ca95c81e3931..267a9b63759a01 100644 --- a/pkgs/by-name/ro/rofi-top/package.nix +++ b/pkgs/by-name/ro/rofi-top/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, cairo -, glib -, gobject-introspection -, libgtop -, pkg-config -, rofi-unwrapped -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + cairo, + glib, + gobject-introspection, + libgtop, + pkg-config, + rofi-unwrapped, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ro/rofi-vpn/package.nix b/pkgs/by-name/ro/rofi-vpn/package.nix index d900df082076d3..120aa986149194 100644 --- a/pkgs/by-name/ro/rofi-vpn/package.nix +++ b/pkgs/by-name/ro/rofi-vpn/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitLab -, makeWrapper -, networkmanager -, rofi-unwrapped +{ + stdenv, + lib, + fetchFromGitLab, + makeWrapper, + networkmanager, + rofi-unwrapped, }: stdenv.mkDerivation rec { @@ -23,7 +24,12 @@ stdenv.mkDerivation rec { install -D --target-directory=$out/bin/ ./rofi-vpn wrapProgram $out/bin/rofi-vpn \ - --prefix PATH ":" ${lib.makeBinPath [ rofi-unwrapped networkmanager ]} + --prefix PATH ":" ${ + lib.makeBinPath [ + rofi-unwrapped + networkmanager + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/ro/rofimoji/package.nix b/pkgs/by-name/ro/rofimoji/package.nix index 8cc67c634e465b..71232975124528 100644 --- a/pkgs/by-name/ro/rofimoji/package.nix +++ b/pkgs/by-name/ro/rofimoji/package.nix @@ -1,16 +1,17 @@ -{ lib -, python3Packages -, fetchFromGitHub -, installShellFiles - -, waylandSupport ? true -, x11Support ? true - -, rofi -, wl-clipboard -, wtype -, xdotool -, xsel +{ + lib, + python3Packages, + fetchFromGitHub, + installShellFiles, + + waylandSupport ? true, + x11Support ? true, + + rofi, + wl-clipboard, + wtype, + xdotool, + xsel, }: python3Packages.buildPythonApplication rec { @@ -32,9 +33,19 @@ python3Packages.buildPythonApplication rec { # `rofi` and the `waylandSupport` and `x11Support` dependencies # contain binaries needed at runtime. - propagatedBuildInputs = [ python3Packages.configargparse rofi ] - ++ lib.optionals waylandSupport [ wl-clipboard wtype ] - ++ lib.optionals x11Support [ xdotool xsel ]; + propagatedBuildInputs = + [ + python3Packages.configargparse + rofi + ] + ++ lib.optionals waylandSupport [ + wl-clipboard + wtype + ] + ++ lib.optionals x11Support [ + xdotool + xsel + ]; # The 'extractors' sub-module is used for development # and has additional dependencies. diff --git a/pkgs/by-name/ro/rojo/package.nix b/pkgs/by-name/ro/rojo/package.nix index ada53d437f4a0e..9f2cc09443f506 100644 --- a/pkgs/by-name/ro/rojo/package.nix +++ b/pkgs/by-name/ro/rojo/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, pkg-config -, openssl -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + darwin, }: let @@ -28,12 +29,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreServices - SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + SystemConfiguration + ]; # reqwest's native-tls-vendored feature flag uses vendored openssl. this disables that OPENSSL_NO_VENDOR = "1"; diff --git a/pkgs/by-name/ro/rolespec/package.nix b/pkgs/by-name/ro/rolespec/package.nix index e5870d582e982d..f6b12a6f788bfb 100644 --- a/pkgs/by-name/ro/rolespec/package.nix +++ b/pkgs/by-name/ro/rolespec/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "rolespec"; diff --git a/pkgs/by-name/ro/ronn/gemset.nix b/pkgs/by-name/ro/ronn/gemset.nix index 0a65000304be4e..eb829046e9bc02 100644 --- a/pkgs/by-name/ro/ronn/gemset.nix +++ b/pkgs/by-name/ro/ronn/gemset.nix @@ -1,83 +1,91 @@ { kramdown = { - dependencies = ["rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rexml" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ic14hdcqxn821dvzki99zhmcy130yhv5fqfffkcf87asv5mnbmn"; type = "gem"; }; version = "2.4.0"; }; kramdown-parser-gfm = { - dependencies = ["kramdown"]; - groups = ["default"]; - platforms = []; + dependencies = [ "kramdown" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a8pb3v951f4x7h968rqfsa19c8arz21zw1vaj42jza22rap8fgv"; type = "gem"; }; version = "1.1.0"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kl9c3kdchjabrihdqfmcplk3lq4cw1rr9f378y6q22qwy5dndvs"; type = "gem"; }; version = "2.8.5"; }; mustache = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l0p4wx15mi3wnamfv92ipkia4nsx8qi132c6g51jfdma3fiz2ch"; type = "gem"; }; version = "1.1.1"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l8b0i24h4irivyhwy9xmkjbggw86cxkzkiqdqg0jpcp9qc8h4rl"; type = "gem"; }; version = "1.16.0"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01b9662zd2x9bp4rdjfid07h09zxj7kvn7f5fghbqhzc625ap1dp"; type = "gem"; }; version = "1.7.3"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05i8518ay14kjbma550mv0jm8a6di8yp5phzrd8rj44z9qnrlrp0"; type = "gem"; }; version = "3.2.6"; }; ronn-ng = { - dependencies = ["kramdown" "kramdown-parser-gfm" "mustache" "nokogiri"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "kramdown" + "kramdown-parser-gfm" + "mustache" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h2y2v3wkl5c710wfanqwxlxi74l1ssva8yrzsg8iypvq22h3ssf"; type = "gem"; }; diff --git a/pkgs/by-name/ro/ronn/package.nix b/pkgs/by-name/ro/ronn/package.nix index 3e0d49271177a4..5c68b9ada796d8 100644 --- a/pkgs/by-name/ro/ronn/package.nix +++ b/pkgs/by-name/ro/ronn/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, bundlerEnv, bundlerUpdateScript, makeWrapper, groff, callPackage }: +{ + stdenv, + lib, + bundlerEnv, + bundlerUpdateScript, + makeWrapper, + groff, + callPackage, +}: stdenv.mkDerivation rec { pname = "ronn"; @@ -34,7 +42,10 @@ stdenv.mkDerivation rec { mainProgram = "ronn"; homepage = "https://github.com/apjanke/ronn-ng"; license = licenses.mit; - maintainers = with maintainers; [ zimbatm nicknovitski ]; + maintainers = with maintainers; [ + zimbatm + nicknovitski + ]; platforms = env.ruby.meta.platforms; }; } diff --git a/pkgs/by-name/ro/ronn/test-reproducible-html.nix b/pkgs/by-name/ro/ronn/test-reproducible-html.nix index 6bc9d6cdbf9fb9..5606a045b6b152 100644 --- a/pkgs/by-name/ro/ronn/test-reproducible-html.nix +++ b/pkgs/by-name/ro/ronn/test-reproducible-html.nix @@ -1,6 +1,7 @@ -{ runCommand -, diffutils -, ronn +{ + runCommand, + diffutils, + ronn, }: runCommand "ronn-test-reproducible-html" { } '' set -euo pipefail diff --git a/pkgs/by-name/ro/roogle/package.nix b/pkgs/by-name/ro/roogle/package.nix index 2964f07f06b680..26cb21501157ae 100644 --- a/pkgs/by-name/ro/roogle/package.nix +++ b/pkgs/by-name/ro/roogle/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "roogle"; @@ -22,7 +26,10 @@ rustPlatform.buildRustPackage rec { description = "Rust API search engine which allows you to search functions by names and type signatures"; mainProgram = "roogle"; homepage = "https://github.com/hkmatsumoto/roogle"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ro/roomeqwizard/package.nix b/pkgs/by-name/ro/roomeqwizard/package.nix index cd67e3ad144062..f5aa37186d5be4 100644 --- a/pkgs/by-name/ro/roomeqwizard/package.nix +++ b/pkgs/by-name/ro/roomeqwizard/package.nix @@ -1,15 +1,16 @@ -{ coreutils -, fetchurl -, gawk -, gnused -, jdk8 -, lib -, makeDesktopItem -, makeWrapper -, stdenv -, writeScript -, writeTextFile -, recommendedUdevRules ? true +{ + coreutils, + fetchurl, + gawk, + gnused, + jdk8, + lib, + makeDesktopItem, + makeWrapper, + stdenv, + writeScript, + writeTextFile, + recommendedUdevRules ? true, }: stdenv.mkDerivation rec { @@ -17,7 +18,9 @@ stdenv.mkDerivation rec { version = "5.31.3"; src = fetchurl { - url = "https://www.roomeqwizard.com/installers/REW_linux_no_jre_${lib.replaceStrings [ "." ] [ "_" ] version}.sh"; + url = "https://www.roomeqwizard.com/installers/REW_linux_no_jre_${ + lib.replaceStrings [ "." ] [ "_" ] version + }.sh"; sha256 = "sha256-qaGkKVoiBJ2UWVKAMqbuqNFi6FGcblMxAbYwhf/71CY="; }; @@ -75,7 +78,13 @@ stdenv.mkDerivation rec { mkdir -p $out/bin $out/lib/udev/rules.d $out/share/icons/hicolor/256x256/apps makeWrapper $out/share/roomeqwizard/roomeqwizard $out/bin/roomeqwizard \ --set INSTALL4J_JAVA_HOME_OVERRIDE ${jdk8} \ - --prefix PATH : ${lib.makeBinPath [ coreutils gnused gawk ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + gnused + gawk + ] + } cp -r "$desktopItem/share/applications" $out/share/ cp $out/share/roomeqwizard/.install4j/roomeqwizard.png "$out/share/icons/hicolor/256x256/apps/${pname}.png" @@ -108,7 +117,10 @@ stdenv.mkDerivation rec { homepage = "https://www.roomeqwizard.com/"; license = licenses.unfree; platforms = platforms.all; - maintainers = with maintainers; [ orivej zaninime ]; + maintainers = with maintainers; [ + orivej + zaninime + ]; description = "Room Acoustics Software"; longDescription = '' REW is free software for room acoustic measurement, loudspeaker diff --git a/pkgs/by-name/ro/roon-bridge/package.nix b/pkgs/by-name/ro/roon-bridge/package.nix index 876702f6beb7aa..3e34874f0399c7 100644 --- a/pkgs/by-name/ro/roon-bridge/package.nix +++ b/pkgs/by-name/ro/roon-bridge/package.nix @@ -1,26 +1,35 @@ -{ alsa-lib -, alsa-utils -, autoPatchelfHook -, fetchurl -, ffmpeg -, lib -, makeWrapper -, openssl -, stdenv -, zlib +{ + alsa-lib, + alsa-utils, + autoPatchelfHook, + fetchurl, + ffmpeg, + lib, + makeWrapper, + openssl, + stdenv, + zlib, }: let version = "1.8-1125"; urlVersion = builtins.replaceStrings [ "." "-" ] [ "00" "0" ] version; host = stdenv.hostPlatform.system; - system = if host == "x86_64-linux" then "linuxx64" - else if host == "aarch64-linux" then "linuxarmv8" - else throw "Unsupported platform ${host}"; + system = + if host == "x86_64-linux" then + "linuxx64" + else if host == "aarch64-linux" then + "linuxarmv8" + else + throw "Unsupported platform ${host}"; src = fetchurl { url = "https://download.roonlabs.com/updates/stable/RoonBridge_${system}_${urlVersion}.tar.bz2"; - hash = if system == "linuxx64" then "sha256-DbtKPFEz2WIoKTxP+zoehzz+BjfsLZ2ZQk/FMh+zFBM=" - else if system == "linuxarmv8" then "sha256-+przEj96R+f1z4ewETFarF4oY6tT2VW/ukSTgUBLiYk=" - else throw "Unsupported platform ${host}"; + hash = + if system == "linuxx64" then + "sha256-DbtKPFEz2WIoKTxP+zoehzz+BjfsLZ2ZQk/FMh+zFBM=" + else if system == "linuxarmv8" then + "sha256-+przEj96R+f1z4ewETFarF4oY6tT2VW/ukSTgUBLiYk=" + else + throw "Unsupported platform ${host}"; }; in stdenv.mkDerivation { @@ -36,7 +45,10 @@ stdenv.mkDerivation { (lib.getLib stdenv.cc.cc) ]; - nativeBuildInputs = [ autoPatchelfHook makeWrapper ]; + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + ]; installPhase = let @@ -46,8 +58,19 @@ stdenv.mkDerivation { sed -i 's@^SCRIPT=.*@SCRIPT="$(basename "${binPath}")"@' ${binPath} wrapProgram ${binPath} \ --argv0 "$(basename ${binPath})" \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ alsa-lib ffmpeg openssl ]}" \ - --prefix PATH : "${lib.makeBinPath [ alsa-utils ffmpeg ]}" + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + alsa-lib + ffmpeg + openssl + ] + }" \ + --prefix PATH : "${ + lib.makeBinPath [ + alsa-utils + ffmpeg + ] + }" ) ''; in @@ -77,7 +100,10 @@ stdenv.mkDerivation { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; maintainers = with maintainers; [ lovesegfault ]; - platforms = [ "aarch64-linux" "x86_64-linux" ]; + platforms = [ + "aarch64-linux" + "x86_64-linux" + ]; mainProgram = "RoonBridge"; }; } diff --git a/pkgs/by-name/ro/roon-server/package.nix b/pkgs/by-name/ro/roon-server/package.nix index dd79f2b66da5ac..793f23baf000a4 100644 --- a/pkgs/by-name/ro/roon-server/package.nix +++ b/pkgs/by-name/ro/roon-server/package.nix @@ -1,18 +1,19 @@ -{ alsa-lib -, alsa-utils -, autoPatchelfHook -, cifs-utils -, fetchurl -, ffmpeg -, freetype -, icu66 -, krb5 -, lib -, libtasn1 -, lttng-ust_2_12 -, makeWrapper -, openssl -, stdenv +{ + alsa-lib, + alsa-utils, + autoPatchelfHook, + cifs-utils, + fetchurl, + ffmpeg, + freetype, + icu66, + krb5, + lib, + libtasn1, + lttng-ust_2_12, + makeWrapper, + openssl, + stdenv, }: let version = "2.0-1483"; @@ -39,7 +40,10 @@ stdenv.mkDerivation { (lib.getLib stdenv.cc.cc) ]; - nativeBuildInputs = [ autoPatchelfHook makeWrapper ]; + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + ]; installPhase = let @@ -60,9 +64,22 @@ stdenv.mkDerivation { makeWrapper "$dotnetDir/$binName" "${binPath}" \ --add-flags "$binDir/$binName.dll" \ --argv0 "$binName" \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ alsa-lib icu66 ffmpeg openssl ]}" \ + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + alsa-lib + icu66 + ffmpeg + openssl + ] + }" \ --prefix PATH : "$dotnetDir" \ - --prefix PATH : "${lib.makeBinPath [ alsa-utils cifs-utils ffmpeg ]}" \ + --prefix PATH : "${ + lib.makeBinPath [ + alsa-utils + cifs-utils + ffmpeg + ] + }" \ --chdir "$binDir" \ --set DOTNET_ROOT "$dotnetDir" ) @@ -93,7 +110,10 @@ stdenv.mkDerivation { homepage = "https://roonlabs.com"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - maintainers = with maintainers; [ lovesegfault steell ]; + maintainers = with maintainers; [ + lovesegfault + steell + ]; platforms = [ "x86_64-linux" ]; mainProgram = "RoonServer"; }; diff --git a/pkgs/by-name/ro/roon-tui/package.nix b/pkgs/by-name/ro/roon-tui/package.nix index 5f3157cd70bdee..a319ccad98234e 100644 --- a/pkgs/by-name/ro/roon-tui/package.nix +++ b/pkgs/by-name/ro/roon-tui/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ro/root/tests/test-thisroot.nix b/pkgs/by-name/ro/root/tests/test-thisroot.nix index 3610e23acbffbe..9927d312d90d20 100644 --- a/pkgs/by-name/ro/root/tests/test-thisroot.nix +++ b/pkgs/by-name/ro/root/tests/test-thisroot.nix @@ -1,17 +1,19 @@ -{ lib -, runCommand -, root -, bash -, fish -, tcsh -, zsh -}: runCommand "test-thisroot" { - meta = with lib; { - description = "Test for root thisroot.* sourcing"; - maintainers = unique ((with maintainers; [ ShamrockLee ]) ++ root.meta.maintainers); - }; -} + lib, + runCommand, + root, + bash, + fish, + tcsh, + zsh, +}: +runCommand "test-thisroot" + { + meta = with lib; { + description = "Test for root thisroot.* sourcing"; + maintainers = unique ((with maintainers; [ ShamrockLee ]) ++ root.meta.maintainers); + }; + } '' set -eu -o pipefail declare -a shellNameArray shellOutpathArray sourcefileNameArray sourceCommandArray diff --git a/pkgs/by-name/ro/root5/package.nix b/pkgs/by-name/ro/root5/package.nix index 01fb35ee76d811..375fff26a01c87 100644 --- a/pkgs/by-name/ro/root5/package.nix +++ b/pkgs/by-name/ro/root5/package.nix @@ -137,42 +137,45 @@ stdenv.mkDerivation rec { substituteInPlace rootx/src/rootx.cxx --replace "gNoLogo = false" "gNoLogo = true" ''; - cmakeFlags = [ - "-Drpath=ON" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - "-DCMAKE_CXX_FLAGS=-std=c++11" - "-Dalien=OFF" - "-Dbonjour=OFF" - "-Dcastor=OFF" - "-Dchirp=OFF" - "-Ddavix=OFF" - "-Ddcache=OFF" - "-Dfftw3=OFF" - "-Dfitsio=OFF" - "-Dfortran=OFF" - "-Dgfal=OFF" - "-Dgsl_shared=ON" - "-Dgviz=OFF" - "-Dhdfs=OFF" - "-Dkrb5=OFF" - "-Dldap=OFF" - "-Dmathmore=ON" - "-Dmonalisa=OFF" - "-Dmysql=OFF" - "-Dodbc=OFF" - "-Dopengl=ON" - "-Doracle=OFF" - "-Dpgsql=OFF" - "-Dpythia6=OFF" - "-Dpythia8=OFF" - "-Drfio=OFF" - "-Dsqlite=OFF" - "-Dssl=OFF" - "-Dxml=ON" - "-Dxrootd=OFF" - ] - ++ lib.optional ((!stdenv.hostPlatform.isDarwin) && (stdenv.cc.libc != null)) "-DC_INCLUDE_DIRS=${lib.getDev stdenv.cc.libc}/include"; + cmakeFlags = + [ + "-Drpath=ON" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + "-DCMAKE_CXX_FLAGS=-std=c++11" + "-Dalien=OFF" + "-Dbonjour=OFF" + "-Dcastor=OFF" + "-Dchirp=OFF" + "-Ddavix=OFF" + "-Ddcache=OFF" + "-Dfftw3=OFF" + "-Dfitsio=OFF" + "-Dfortran=OFF" + "-Dgfal=OFF" + "-Dgsl_shared=ON" + "-Dgviz=OFF" + "-Dhdfs=OFF" + "-Dkrb5=OFF" + "-Dldap=OFF" + "-Dmathmore=ON" + "-Dmonalisa=OFF" + "-Dmysql=OFF" + "-Dodbc=OFF" + "-Dopengl=ON" + "-Doracle=OFF" + "-Dpgsql=OFF" + "-Dpythia6=OFF" + "-Dpythia8=OFF" + "-Drfio=OFF" + "-Dsqlite=OFF" + "-Dssl=OFF" + "-Dxml=ON" + "-Dxrootd=OFF" + ] + ++ lib.optional ( + (!stdenv.hostPlatform.isDarwin) && (stdenv.cc.libc != null) + ) "-DC_INCLUDE_DIRS=${lib.getDev stdenv.cc.libc}/include"; env.NIX_CFLAGS_COMPILE = "-fpermissive"; diff --git a/pkgs/by-name/ro/rootbar/package.nix b/pkgs/by-name/ro/rootbar/package.nix index 1901a33f11ff89..b4f5446672cc64 100644 --- a/pkgs/by-name/ro/rootbar/package.nix +++ b/pkgs/by-name/ro/rootbar/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchhg -, pkg-config -, meson -, ninja -, gtk3 -, json_c -, libpulseaudio -, wayland -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchhg, + pkg-config, + meson, + ninja, + gtk3, + json_c, + libpulseaudio, + wayland, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -21,7 +23,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - meson ninja pkg-config wrapGAppsHook3 + meson + ninja + pkg-config + wrapGAppsHook3 ]; buildInputs = [ diff --git a/pkgs/by-name/ro/rootlesskit/package.nix b/pkgs/by-name/ro/rootlesskit/package.nix index d3f7dd2af9221c..63ad234b0f17f9 100644 --- a/pkgs/by-name/ro/rootlesskit/package.nix +++ b/pkgs/by-name/ro/rootlesskit/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, nix-update-script, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + nixosTests, +}: buildGoModule rec { pname = "rootlesskit"; diff --git a/pkgs/by-name/ro/rosa/package.nix b/pkgs/by-name/ro/rosa/package.nix index 95b1d9f68476f5..8c24388bb71a9f 100644 --- a/pkgs/by-name/ro/rosa/package.nix +++ b/pkgs/by-name/ro/rosa/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, buildGoModule, fetchFromGitHub, installShellFiles, testers, rosa, nix-update-script }: +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + rosa, + nix-update-script, +}: buildGoModule rec { pname = "rosa"; @@ -12,7 +21,10 @@ buildGoModule rec { }; vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; __darwinAllowLocalNetworking = true; @@ -25,8 +37,7 @@ buildGoModule rec { skippedTests = [ "TestCluster" "TestRhRegionCommand" - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ "TestCache" ]; + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ "TestCache" ]; in [ "-skip=^${lib.concatStringsSep "$|^" skippedTests}$" ]; diff --git a/pkgs/by-name/ro/rose-pine-cursor/package.nix b/pkgs/by-name/ro/rose-pine-cursor/package.nix index 812a52854afcdb..d29bbc9888d639 100644 --- a/pkgs/by-name/ro/rose-pine-cursor/package.nix +++ b/pkgs/by-name/ro/rose-pine-cursor/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchurl +{ + lib, + stdenvNoCC, + fetchurl, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ro/rose-pine-gtk-theme/package.nix b/pkgs/by-name/ro/rose-pine-gtk-theme/package.nix index d211a99ef0800b..9a92d5f769ec59 100644 --- a/pkgs/by-name/ro/rose-pine-gtk-theme/package.nix +++ b/pkgs/by-name/ro/rose-pine-gtk-theme/package.nix @@ -1,9 +1,10 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, gnome-themes-extra -, gtk-engine-murrine -, gtk_engines +{ + stdenvNoCC, + lib, + fetchFromGitHub, + gnome-themes-extra, + gtk-engine-murrine, + gtk_engines, }: stdenvNoCC.mkDerivation rec { @@ -48,6 +49,9 @@ stdenvNoCC.mkDerivation rec { homepage = "https://github.com/rose-pine/gtk"; license = licenses.gpl3Only; platforms = platforms.linux; - maintainers = with maintainers; [romildo the-argus]; + maintainers = with maintainers; [ + romildo + the-argus + ]; }; } diff --git a/pkgs/by-name/ro/rose-pine-icon-theme/package.nix b/pkgs/by-name/ro/rose-pine-icon-theme/package.nix index 051294c5d3a89d..b2aef432e2a9db 100644 --- a/pkgs/by-name/ro/rose-pine-icon-theme/package.nix +++ b/pkgs/by-name/ro/rose-pine-icon-theme/package.nix @@ -1,7 +1,8 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, gtk3 +{ + stdenvNoCC, + lib, + fetchFromGitHub, + gtk3, }: stdenvNoCC.mkDerivation rec { @@ -42,6 +43,9 @@ stdenvNoCC.mkDerivation rec { homepage = "https://github.com/rose-pine/gtk"; license = licenses.gpl3Only; platforms = platforms.linux; - maintainers = with maintainers; [romildo the-argus]; + maintainers = with maintainers; [ + romildo + the-argus + ]; }; } diff --git a/pkgs/by-name/ro/rosie/package.nix b/pkgs/by-name/ro/rosie/package.nix index 5cad6650d2ce15..0d719c3a5763b8 100644 --- a/pkgs/by-name/ro/rosie/package.nix +++ b/pkgs/by-name/ro/rosie/package.nix @@ -1,9 +1,9 @@ -{ lib -, stdenv -, fetchgit -, libbsd -, readline -, +{ + lib, + stdenv, + fetchgit, + libbsd, + readline, }: stdenv.mkDerivation rec { pname = "rosie"; @@ -50,7 +50,10 @@ stdenv.mkDerivation rec { makeFlags = [ "DESTDIR=${placeholder "out"}" ]; - buildInputs = [ libbsd readline ]; + buildInputs = [ + libbsd + readline + ]; meta = with lib; { homepage = "https://rosie-lang.org"; diff --git a/pkgs/by-name/ro/roslyn-ls/deps.nix b/pkgs/by-name/ro/roslyn-ls/deps.nix index 68dc8ec760578b..1f9fcc73e3489f 100644 --- a/pkgs/by-name/ro/roslyn-ls/deps.nix +++ b/pkgs/by-name/ro/roslyn-ls/deps.nix @@ -1,209 +1,1230 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "dotnet-format"; version = "7.0.360304"; hash = "sha256-TuhZIhearocl702hLzGJCcRd8+RWoI4tDY02Bf6Lus8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/dotnet-format/7.0.360304/dotnet-format.7.0.360304.nupkg"; }) - (fetchNuGet { pname = "Humanizer.Core"; version = "2.14.1"; hash = "sha256-EXvojddPu+9JKgOG9NSQgUTfWq1RpOYw7adxDPKDJ6o="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/humanizer.core/2.14.1/humanizer.core.2.14.1.nupkg"; }) - (fetchNuGet { pname = "ICSharpCode.Decompiler"; version = "8.1.1.7464"; hash = "sha256-71/e9zuQIfqRXOiWxZkUFW/tMAj63nE8tg/sR7bGzuM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/icsharpcode.decompiler/8.1.1.7464/icsharpcode.decompiler.8.1.1.7464.nupkg"; }) - (fetchNuGet { pname = "MessagePack"; version = "2.5.108"; hash = "sha256-+vMXyEbfutY5WOFuFnNF24uLcKJTTdntVrVlSJH4yjI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/messagepack/2.5.108/messagepack.2.5.108.nupkg"; }) - (fetchNuGet { pname = "MessagePack"; version = "2.5.124"; hash = "sha256-3ZUXCiDKpD82W+prJ5yLFm/gmztNsm8W0NPRs74bgrw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/messagepack/2.5.124/messagepack.2.5.124.nupkg"; }) - (fetchNuGet { pname = "MessagePack.Annotations"; version = "2.5.108"; hash = "sha256-u3Qu8UftNIz3oIzQUMa7Z0G6VzmDLcAnAeNQ3lB3YVk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/messagepack.annotations/2.5.108/messagepack.annotations.2.5.108.nupkg"; }) - (fetchNuGet { pname = "MessagePack.Annotations"; version = "2.5.124"; hash = "sha256-4zgAUW6py8CA2hMGUUrHr7Q6vKeRBqOCmcKgAR9fRGg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/messagepack.annotations/2.5.124/messagepack.annotations.2.5.124.nupkg"; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Razor.ExternalAccess.RoslynWorkspace"; version = "9.0.0-preview.24555.12"; hash = "sha256-SMOU22F2xZkFM6KRRETeRR79BuVccALMGH+zcgyqq4M="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.aspnetcore.razor.externalaccess.roslynworkspace/9.0.0-preview.24555.12/microsoft.aspnetcore.razor.externalaccess.roslynworkspace.9.0.0-preview.24555.12.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "8.0.0"; hash = "sha256-9aWmiwMJKrKr9ohD1KSuol37y+jdDxPGJct3m2/Bknw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.bcl.asyncinterfaces/8.0.0/microsoft.bcl.asyncinterfaces.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build"; version = "17.12.0-preview-24426-07"; hash = "sha256-OHQd2npzibOaNSR2sq3NrKKtAALOmnIARmFoBaXiJ0k="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.build/17.12.0-preview-24426-07/microsoft.build.17.12.0-preview-24426-07.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build"; version = "17.3.4"; hash = "sha256-LHtjk4vxeVSLzAKAcG8BN+S20d2sUR2DAOsSXLNIy5U="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.build/17.3.4/microsoft.build.17.3.4.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build"; version = "17.7.2"; hash = "sha256-k35nFdPxC8t0zAltVSmAJtsepp/ubNIjPOsJ6k8jSqM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build/17.7.2/microsoft.build.17.7.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Framework"; version = "17.12.0-preview-24426-07"; hash = "sha256-p5JNAp442gjiu14gfM4eF477iT9Ttac8ALHXISbsecs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.build.framework/17.12.0-preview-24426-07/microsoft.build.framework.17.12.0-preview-24426-07.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Framework"; version = "17.3.4"; hash = "sha256-p2JG7pMBGfDVP6sOzBOqOkImZmwotlGvfS+8BjjVYf8="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.build.framework/17.3.4/microsoft.build.framework.17.3.4.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Framework"; version = "17.7.2"; hash = "sha256-fNWmVQYFTJDveAGmxEdNqJRAczV6+Ep8RA8clKBJFqw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.framework/17.7.2/microsoft.build.framework.17.7.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Locator"; version = "1.6.10"; hash = "sha256-hOFFiQiCNkkDqt0Ad/4Y/sggj4t0zWXmfGjE+I/cqqM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.locator/1.6.10/microsoft.build.locator.1.6.10.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Tasks.Core"; version = "17.12.0-preview-24426-07"; hash = "sha256-2igOkxetlTeRv2Xq5wVcQXU7hxdP43yMJq3aK6vndoI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.build.tasks.core/17.12.0-preview-24426-07/microsoft.build.tasks.core.17.12.0-preview-24426-07.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Tasks.Core"; version = "17.3.4"; hash = "sha256-0RA95pD6zHBf1lgYyrrAuEuNeGwuCgGxNdhEJ0cJUCs="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.build.tasks.core/17.3.4/microsoft.build.tasks.core.17.3.4.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Tasks.Core"; version = "17.7.2"; hash = "sha256-OrV/qWgZHzGlNUmaSfX5wDBcmg1aQeF3/OUHpSH+uZU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.tasks.core/17.7.2/microsoft.build.tasks.core.17.7.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Utilities.Core"; version = "17.12.0-preview-24426-07"; hash = "sha256-np372GONmrZJ8ppPxjZrvtofA5gTnUf2n/Pn9f02ilo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.build.utilities.core/17.12.0-preview-24426-07/microsoft.build.utilities.core.17.12.0-preview-24426-07.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Utilities.Core"; version = "17.3.4"; hash = "sha256-SfZxr5xDANnDnC1HCUgho2H9MnF6n51cM47Rrf07fWw="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.build.utilities.core/17.3.4/microsoft.build.utilities.core.17.3.4.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Utilities.Core"; version = "17.7.2"; hash = "sha256-oatF0KfuP1nb4+OLNKg2/R/ZLO4EiACaO5leaxMEY4A="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.utilities.core/17.7.2/microsoft.build.utilities.core.17.7.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.11.0"; hash = "sha256-hQ2l6E6PO4m7i+ZsfFlEx+93UsLPo4IY3wDkNG11/Sw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.analyzers/3.11.0/microsoft.codeanalysis.analyzers.3.11.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.AnalyzerUtilities"; version = "3.3.0"; hash = "sha256-nzFs+H0FFEgZzjl/bcmWyQQVKS2PncS6kMYHOqrxXSw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.analyzerutilities/3.3.0/microsoft.codeanalysis.analyzerutilities.3.3.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.BannedApiAnalyzers"; version = "3.11.0-beta1.24081.1"; hash = "sha256-5UN//A8oc2w+UoxAwWmXWRXykQD+2mpa1hbJrAfh2Lg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a54510f9-4b2c-4e69-b96a-6096683aaa1f/nuget/v3/flat2/microsoft.codeanalysis.bannedapianalyzers/3.11.0-beta1.24081.1/microsoft.codeanalysis.bannedapianalyzers.3.11.0-beta1.24081.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "4.1.0"; hash = "sha256-g3RLyeHfdOOF6H89VLJi06/k8/eJ6j2dgNYZ/MBdfNU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.common/4.1.0/microsoft.codeanalysis.common.4.1.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Elfie"; version = "1.0.0"; hash = "sha256-E/+PlegvWZ59e5Ti3TvKJBLa3qCnDKmi7+DcnOo1ufg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.elfie/1.0.0/microsoft.codeanalysis.elfie.1.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.NetAnalyzers"; version = "8.0.0-preview.23468.1"; hash = "sha256-2wF9nG7tL92RKT46l5A0EQB3uow93516Dh8hSw7kUvg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/49a1bb2b-12b0-475f-adbd-1560fc76be38/nuget/v3/flat2/microsoft.codeanalysis.netanalyzers/8.0.0-preview.23468.1/microsoft.codeanalysis.netanalyzers.8.0.0-preview.23468.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.PerformanceSensitiveAnalyzers"; version = "3.3.4-beta1.22504.1"; hash = "sha256-HYGDtRhUgaIG5t4VpOt3ZFQ8nqLSJ6mTR5964FMmK50="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/e31c6eea-0277-49f3-8194-142be67a9f72/nuget/v3/flat2/microsoft.codeanalysis.performancesensitiveanalyzers/3.3.4-beta1.22504.1/microsoft.codeanalysis.performancesensitiveanalyzers.3.3.4-beta1.22504.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.PublicApiAnalyzers"; version = "3.11.0-beta1.24081.1"; hash = "sha256-nXx0MSYXVzdr0jcNo9aZLocZU1ywN+n/vdD2kYBh5TI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a54510f9-4b2c-4e69-b96a-6096683aaa1f/nuget/v3/flat2/microsoft.codeanalysis.publicapianalyzers/3.11.0-beta1.24081.1/microsoft.codeanalysis.publicapianalyzers.3.11.0-beta1.24081.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.7.0"; hash = "sha256-Enknv2RsFF68lEPdrf5M+BpV1kHoLTVRApKUwuk/pj0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.csharp/4.7.0/microsoft.csharp.4.7.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.DiaSymReader"; version = "2.0.0"; hash = "sha256-8hotZmh8Rb6Q6oD9Meb74SvAdbDo39Y/1m8h43HHjjw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.diasymreader/2.0.0/microsoft.diasymreader.2.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.DotNet.Arcade.Sdk"; version = "9.0.0-beta.24572.2"; hash = "sha256-dTYFN1KH3grxcf/On6GLW5WdFliq91Y37DeWDCwiryM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.dotnet.arcade.sdk/9.0.0-beta.24572.2/microsoft.dotnet.arcade.sdk.9.0.0-beta.24572.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.DotNet.XliffTasks"; version = "9.0.0-beta.24076.5"; hash = "sha256-5cREL85PwcDwo4yyc2Eh908HQ/Cm36w9uZSIvVELZH0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.dotnet.xlifftasks/9.0.0-beta.24076.5/microsoft.dotnet.xlifftasks.9.0.0-beta.24076.5.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "8.0.0"; hash = "sha256-9BPsASlxrV8ilmMCjdb3TiUcm5vFZxkBnAI/fNBSEyA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.configuration/8.0.0/microsoft.extensions.configuration.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "8.0.0"; hash = "sha256-4eBpDkf7MJozTZnOwQvwcfgRKQGcNXe0K/kF+h5Rl8o="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.configuration.abstractions/8.0.0/microsoft.extensions.configuration.abstractions.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "8.0.0"; hash = "sha256-GanfInGzzoN2bKeNwON8/Hnamr6l7RTpYLA49CNXD9Q="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.configuration.binder/8.0.0/microsoft.extensions.configuration.binder.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "8.0.0"; hash = "sha256-+qIDR8hRzreCHNEDtUcPfVHQdurzWPo/mqviCH78+EQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.dependencyinjection/8.0.0/microsoft.extensions.dependencyinjection.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.0"; hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.dependencyinjection.abstractions/8.0.0/microsoft.extensions.dependencyinjection.abstractions.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileSystemGlobbing"; version = "8.0.0"; hash = "sha256-+Oz41JR5jdcJlCJOSpQIL5OMBNi+1Hl2d0JUHfES7sU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.filesystemglobbing/8.0.0/microsoft.extensions.filesystemglobbing.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "8.0.0"; hash = "sha256-Meh0Z0X7KyOEG4l0RWBcuHHihcABcvCyfUXgasmQ91o="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.logging/8.0.0/microsoft.extensions.logging.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "8.0.0"; hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.logging.abstractions/8.0.0/microsoft.extensions.logging.abstractions.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Configuration"; version = "8.0.0"; hash = "sha256-mzmstNsVjKT0EtQcdAukGRifD30T82BMGYlSu8k4K7U="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.logging.configuration/8.0.0/microsoft.extensions.logging.configuration.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Console"; version = "8.0.0"; hash = "sha256-bdb9YWWVn//AeySp7se87/tCN2E7e8Gx2GPMw28cd9c="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.logging.console/8.0.0/microsoft.extensions.logging.console.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.ObjectPool"; version = "8.0.0"; hash = "sha256-FxFr5GC0y6vnp5YD2A2vISXYizAz3k/QyrH7sBXP5kg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.objectpool/8.0.0/microsoft.extensions.objectpool.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "8.0.0"; hash = "sha256-n2m4JSegQKUTlOsKLZUUHHKMq926eJ0w9N9G+I3FoFw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.options/8.0.0/microsoft.extensions.options.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; version = "8.0.0"; hash = "sha256-A5Bbzw1kiNkgirk5x8kyxwg9lLTcSngojeD+ocpG1RI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.options.configurationextensions/8.0.0/microsoft.extensions.options.configurationextensions.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "8.0.0"; hash = "sha256-FU8qj3DR8bDdc1c+WeGZx/PCZeqqndweZM9epcpXjSo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.primitives/8.0.0/microsoft.extensions.primitives.8.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.IO.Redist"; version = "6.0.1"; hash = "sha256-IaATAy1M/MEBTid0mQiTrHj4aTwo2POCtckxSbLc3lU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.io.redist/6.0.1/microsoft.io.redist.6.0.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NET.StringTools"; version = "17.12.0-preview-24426-07"; hash = "sha256-yoReTrCOhI6ud3v6fLGi5ivS0RuBDhDWw/giD9+bYOk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.net.stringtools/17.12.0-preview-24426-07/microsoft.net.stringtools.17.12.0-preview-24426-07.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NET.StringTools"; version = "17.4.0"; hash = "sha256-+9uBaUDZ3roUJwyYJUL30Mz+3C6LE16FzfQKgS0Yveo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.net.stringtools/17.4.0/microsoft.net.stringtools.17.4.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NET.StringTools"; version = "17.6.3"; hash = "sha256-H2Qw8x47WyFOd/VmgRmGMc+uXySgUv68UISgK8Frsjw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.net.stringtools/17.6.3/microsoft.net.stringtools.17.6.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NET.StringTools"; version = "17.7.2"; hash = "sha256-hQE07TCgcQuyu9ZHVq2gPDb0+xe8ECJUdrgh17bJP4o="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.net.stringtools/17.7.2/microsoft.net.stringtools.17.7.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "5.0.0"; hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/5.0.0/microsoft.netcore.platforms.5.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.targets/1.1.0/microsoft.netcore.targets.1.1.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.3"; hash = "sha256-WLsf1NuUfRWyr7C7Rl9jiua9jximnVvzy6nk2D2bVRc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.targets/1.1.3/microsoft.netcore.targets.1.1.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies"; version = "1.0.3"; hash = "sha256-FBoJP5DHZF0QHM0xLm9yd4HJZVQOuSpSKA+VQRpphEE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies/1.0.3/microsoft.netframework.referenceassemblies.1.0.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies.net472"; version = "1.0.3"; hash = "sha256-/6ClVwo5+RE5kWTQWB/93vmbXj37ql8iDlziKWm89Xw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies.net472/1.0.3/microsoft.netframework.referenceassemblies.net472.1.0.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.ServiceHub.Analyzers"; version = "4.7.32-beta"; hash = "sha256-vYKNtk5BauoAwUt2g+0GodmRZ9JWHWfFIBrcOPFHuyQ="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.servicehub.analyzers/4.7.32-beta/microsoft.servicehub.analyzers.4.7.32-beta.nupkg"; }) - (fetchNuGet { pname = "Microsoft.ServiceHub.Client"; version = "4.2.1017"; hash = "sha256-Achfy4EpZfcIOf02P8onWJH1cte+rP9ZAy94Gf4MVCA="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/2a239fd0-3e21-40b0-b9d6-bc122fec7eb2/nuget/v3/flat2/microsoft.servicehub.client/4.2.1017/microsoft.servicehub.client.4.2.1017.nupkg"; }) - (fetchNuGet { pname = "Microsoft.ServiceHub.Framework"; version = "4.7.32-beta"; hash = "sha256-QGtg9LL8FRRjDiMn5sJYPn1gliSzzxokyMVsa1uvDfs="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.servicehub.framework/4.7.32-beta/microsoft.servicehub.framework.4.7.32-beta.nupkg"; }) - (fetchNuGet { pname = "Microsoft.ServiceHub.Resources"; version = "4.2.1017"; hash = "sha256-6nq1jsXLThMritNI1CZj5Batfo/0W0Pt2iLY72yZGNw="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/2a239fd0-3e21-40b0-b9d6-bc122fec7eb2/nuget/v3/flat2/microsoft.servicehub.resources/4.2.1017/microsoft.servicehub.resources.4.2.1017.nupkg"; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.ObjectModel"; version = "17.5.0"; hash = "sha256-M8Ct2u3RaTxWip0XBLPtL2xeGsYz1rjKgfsV++nZDPg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.testplatform.objectmodel/17.5.0/microsoft.testplatform.objectmodel.17.5.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.TranslationLayer"; version = "17.5.0"; hash = "sha256-rVgeXl/F8jqXJhQcrm2tV6jvsYHA6UF+5crLVr4GZBA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.testplatform.translationlayer/17.5.0/microsoft.testplatform.translationlayer.17.5.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Composition"; version = "17.12.17-preview"; hash = "sha256-RxakGlbjWXC28F50Z5Ayez5gVsmCeyPqOKw3aBCKrDc="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.visualstudio.composition/17.12.17-preview/microsoft.visualstudio.composition.17.12.17-preview.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Composition.Analyzers"; version = "17.12.17-preview"; hash = "sha256-tZ7SmS9wq1f7FJMLo+c5YRdeAoJ7ZHemhgtXiTTzqIU="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.visualstudio.composition.analyzers/17.12.17-preview/microsoft.visualstudio.composition.analyzers.17.12.17-preview.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.RemoteControl"; version = "16.3.52"; hash = "sha256-J/egIc9ovDi1MUrnyKnpadECQqAB1WUUyrbxINv4zRE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.remotecontrol/16.3.52/microsoft.visualstudio.remotecontrol.16.3.52.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Setup.Configuration.Interop"; version = "3.2.2146"; hash = "sha256-ic5h0cmHIaowJfItTLXLnmFhIg4NhaoMoWVAFMHKdzQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.setup.configuration.interop/3.2.2146/microsoft.visualstudio.setup.configuration.interop.3.2.2146.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Telemetry"; version = "17.12.32"; hash = "sha256-HkAQyMovZEABmgcaaSo/DOyRbx+pyVOZGxEm7GEKd2E="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.visualstudio.telemetry/17.12.32/microsoft.visualstudio.telemetry.17.12.32.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Threading"; version = "17.12.13-preview"; hash = "sha256-StuzZma2nOXFJ5Al9AZZPo0kM4FrTgHYz2ji+zKgtlM="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.visualstudio.threading/17.12.13-preview/microsoft.visualstudio.threading.17.12.13-preview.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Threading.Analyzers"; version = "17.12.13-preview"; hash = "sha256-wrCnLYNSujq8fcpmjm/yTTY7uVOPAjpJA+1X8ujuVbA="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.visualstudio.threading.analyzers/17.12.13-preview/microsoft.visualstudio.threading.analyzers.17.12.13-preview.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Utilities.Internal"; version = "16.3.73"; hash = "sha256-zwk4jWuCw2ANhG00TnwT9JE7n/h2EQkYKeq6o966ilo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.utilities.internal/16.3.73/microsoft.visualstudio.utilities.internal.16.3.73.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Validation"; version = "17.8.8"; hash = "sha256-sB8GLRiJHX3Py7qeBUnUANiDWhyPtISon6HQs+8wKms="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.validation/17.8.8/microsoft.visualstudio.validation.17.8.8.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.3.0"; hash = "sha256-mBNDmPXNTW54XLnPAUwBRvkIORFM7/j0D0I2SyQPDEg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.primitives/4.3.0/microsoft.win32.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "5.0.0"; hash = "sha256-9kylPGfKZc58yFqNKa77stomcoNnMeERXozWJzDcUIA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.registry/5.0.0/microsoft.win32.registry.5.0.0.nupkg"; }) - (fetchNuGet { pname = "Nerdbank.Streams"; version = "2.11.79"; hash = "sha256-1bzibVcSH8LJMR8Nb6Q0q/7fieTgxRnVY4C1RvRbrrI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/nerdbank.streams/2.11.79/nerdbank.streams.2.11.79.nupkg"; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.0"; hash = "sha256-Pp7fRylai8JrE1O+9TGfIEJrAOmnWTJRLWE+qJBahK0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/netstandard.library/2.0.0/netstandard.library.2.0.0.nupkg"; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/netstandard.library/2.0.3/netstandard.library.2.0.3.nupkg"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.3"; hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/newtonsoft.json/13.0.3/newtonsoft.json.13.0.3.nupkg"; }) - (fetchNuGet { pname = "NuGet.Common"; version = "6.8.0-rc.112"; hash = "sha256-LfIF8idaAeEfEeaXlhUhw4KcY0QXzMNwHqvAInSgF5c="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.common/6.8.0-rc.112/nuget.common.6.8.0-rc.112.nupkg"; }) - (fetchNuGet { pname = "NuGet.Configuration"; version = "6.8.0-rc.112"; hash = "sha256-tWhwgxiaXcWPXdZVnDS2wsdblN6FoPR/uGmW57y3Fnw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.configuration/6.8.0-rc.112/nuget.configuration.6.8.0-rc.112.nupkg"; }) - (fetchNuGet { pname = "NuGet.DependencyResolver.Core"; version = "6.8.0-rc.112"; hash = "sha256-nS0Km+T6sRdIQLzwqjluHoV3MQe2dxwYhCrnKuURoSs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.dependencyresolver.core/6.8.0-rc.112/nuget.dependencyresolver.core.6.8.0-rc.112.nupkg"; }) - (fetchNuGet { pname = "NuGet.Frameworks"; version = "5.11.0"; hash = "sha256-n+hxcrf+sXM80Tv9YH9x4+hwTslVidFq4tjBNPAzYnM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/nuget.frameworks/5.11.0/nuget.frameworks.5.11.0.nupkg"; }) - (fetchNuGet { pname = "NuGet.Frameworks"; version = "6.8.0-rc.112"; hash = "sha256-0dmY/5/Pa+FW3ck0q8zdeHjt59PAeNNCh0tu+wY2260="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.frameworks/6.8.0-rc.112/nuget.frameworks.6.8.0-rc.112.nupkg"; }) - (fetchNuGet { pname = "NuGet.LibraryModel"; version = "6.8.0-rc.112"; hash = "sha256-8D1DetEC3pkDDRGdmjlfrKRQ9xqEwqnga3ZixZYMsIg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.librarymodel/6.8.0-rc.112/nuget.librarymodel.6.8.0-rc.112.nupkg"; }) - (fetchNuGet { pname = "NuGet.Packaging"; version = "6.8.0-rc.112"; hash = "sha256-Z9E9TIQSd+8gkOyc2k4LompDwdLQJMGNbHEt3DG1I4g="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.packaging/6.8.0-rc.112/nuget.packaging.6.8.0-rc.112.nupkg"; }) - (fetchNuGet { pname = "NuGet.ProjectModel"; version = "6.8.0-rc.112"; hash = "sha256-geQh1fSRTp2FTzeilFL8gxFFq7q8u7YaakShPKiTwns="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.projectmodel/6.8.0-rc.112/nuget.projectmodel.6.8.0-rc.112.nupkg"; }) - (fetchNuGet { pname = "NuGet.Protocol"; version = "6.8.0-rc.112"; hash = "sha256-6r/MJCo2ngibSAfNdH+xmeNUl38EPjQkaewKsTJpfvU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.protocol/6.8.0-rc.112/nuget.protocol.6.8.0-rc.112.nupkg"; }) - (fetchNuGet { pname = "NuGet.Versioning"; version = "6.8.0-rc.112"; hash = "sha256-BzAWS5wpGnNj0gU33sfWao7BELGjrQBT4xj3EC7qRRE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.versioning/6.8.0-rc.112/nuget.versioning.6.8.0-rc.112.nupkg"; }) - (fetchNuGet { pname = "PowerShell"; version = "7.0.0"; hash = "sha256-ioasr71UIhDmeZ2Etw52lQ7QsioEd1pnbpVlEeCyUI4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/powershell/7.0.0/powershell.7.0.0.nupkg"; }) - (fetchNuGet { pname = "RichCodeNav.EnvVarDump"; version = "0.1.1643-alpha"; hash = "sha256-bwND+Na9iEnkEdeL1elY34+m4/F4BYATBHv/2BEw4d4="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/58ca65bb-e6c1-4210-88ac-fa55c1cd7877/nuget/v3/flat2/richcodenav.envvardump/0.1.1643-alpha/richcodenav.envvardump.0.1.1643-alpha.nupkg"; }) - (fetchNuGet { pname = "Roslyn.Diagnostics.Analyzers"; version = "3.11.0-beta1.24081.1"; hash = "sha256-wIOhKwvYetwytnuNX0uNC5oyBDU7xAhLqzTvyuGDVMM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a54510f9-4b2c-4e69-b96a-6096683aaa1f/nuget/v3/flat2/roslyn.diagnostics.analyzers/3.11.0-beta1.24081.1/roslyn.diagnostics.analyzers.3.11.0-beta1.24081.1.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.collections/4.3.0/runtime.any.system.collections.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-dsmTLGvt8HqRkDWP8iKVXJCS+akAzENGXKPV18W2RgI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.diagnostics.tracing/4.3.0/runtime.any.system.diagnostics.tracing.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.globalization/4.3.0/runtime.any.system.globalization.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.io/4.3.0/runtime.any.system.io.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.reflection/4.3.0/runtime.any.system.reflection.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.reflection.primitives/4.3.0/runtime.any.system.reflection.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.resources.resourcemanager/4.3.0/runtime.any.system.resources.resourcemanager.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.runtime/4.3.0/runtime.any.system.runtime.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.runtime.handles/4.3.0/runtime.any.system.runtime.handles.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.runtime.interopservices/4.3.0/runtime.any.system.runtime.interopservices.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.text.encoding/4.3.0/runtime.any.system.text.encoding.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-6MYj0RmLh4EVqMtO/MRqBi0HOn5iG4x9JimgCCJ+EFM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.text.encoding.extensions/4.3.0/runtime.any.system.text.encoding.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.threading.tasks/4.3.0/runtime.any.system.threading.tasks.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system/4.3.0/runtime.native.system.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.security.cryptography.openssl/4.3.0/runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.Microsoft.Win32.Primitives"; version = "4.3.0"; hash = "sha256-LZb23lRXzr26tRS5aA0xyB08JxiblPDoA7HBvn6awXg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.microsoft.win32.primitives/4.3.0/runtime.unix.microsoft.win32.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.diagnostics.debug/4.3.0/runtime.unix.system.diagnostics.debug.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-Pf4mRl6YDK2x2KMh0WdyNgv0VUNdSKVDLlHqozecy5I="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.io.filesystem/4.3.0/runtime.unix.system.io.filesystem.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Primitives"; version = "4.3.0"; hash = "sha256-pHJ+I6i16MV6m77uhTC6GPY6jWGReE3SSP3fVB59ti0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.net.primitives/4.3.0/runtime.unix.system.net.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Sockets"; version = "4.3.0"; hash = "sha256-IvgOeA2JuBjKl5yAVGjPYMPDzs9phb3KANs95H9v1w4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.net.sockets/4.3.0/runtime.unix.system.net.sockets.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.private.uri/4.3.0/runtime.unix.system.private.uri.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.runtime.extensions/4.3.0/runtime.unix.system.runtime.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "SQLitePCLRaw.bundle_green"; version = "2.1.0"; hash = "sha256-W14WMqNZndRmnySqLdFqmvfbH14kJxMV6+/4dIS0CwE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/sqlitepclraw.bundle_green/2.1.0/sqlitepclraw.bundle_green.2.1.0.nupkg"; }) - (fetchNuGet { pname = "SQLitePCLRaw.core"; version = "2.1.0"; hash = "sha256-l1lfw114VmMprNFNn1fM/wzKEbDywXDlgdTQWWbqBU8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/sqlitepclraw.core/2.1.0/sqlitepclraw.core.2.1.0.nupkg"; }) - (fetchNuGet { pname = "SQLitePCLRaw.lib.e_sqlite3"; version = "2.1.0"; hash = "sha256-XsObwf7Fza9G1JCZvQ+SqMqQUdZNU3WcJYYp3cqfc8U="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/sqlitepclraw.lib.e_sqlite3/2.1.0/sqlitepclraw.lib.e_sqlite3.2.1.0.nupkg"; }) - (fetchNuGet { pname = "SQLitePCLRaw.provider.dynamic_cdecl"; version = "2.1.0"; hash = "sha256-2JLlOroGdfziGi+VpgBjtm9IHofG976T+9lZb+fQRok="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/sqlitepclraw.provider.dynamic_cdecl/2.1.0/sqlitepclraw.provider.dynamic_cdecl.2.1.0.nupkg"; }) - (fetchNuGet { pname = "SQLitePCLRaw.provider.e_sqlite3"; version = "2.1.0"; hash = "sha256-VkGdCCECj+0oaha/QsyfF9CQoaurC/KO2RHR2GaI77w="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/sqlitepclraw.provider.e_sqlite3/2.1.0/sqlitepclraw.provider.e_sqlite3.2.1.0.nupkg"; }) - (fetchNuGet { pname = "StreamJsonRpc"; version = "2.20.8-beta"; hash = "sha256-cELu//Ad7sAITbq/i5ISi4g1Mvf9mUIYT6vDTukUjQY="; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/streamjsonrpc/2.20.8-beta/streamjsonrpc.2.20.8-beta.nupkg"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; hash = "sha256-wws90sfi9M7kuCPWkv1CEYMJtCqx9QB/kj0ymlsNaxI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.5.1/system.buffers.4.5.1.nupkg"; }) - (fetchNuGet { pname = "System.CodeDom"; version = "7.0.0"; hash = "sha256-7IPt39cY+0j0ZcRr/J45xPtEjnSXdUJ/5ai3ebaYQiE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.codedom/7.0.0/system.codedom.7.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections/4.3.0/system.collections.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "8.0.0"; hash = "sha256-F7OVjKNwpqbUh8lTidbqJWYi476nsq9n+6k0+QVRo3w="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.immutable/8.0.0/system.collections.immutable.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.CommandLine"; version = "2.0.0-beta4.24528.1"; hash = "sha256-C1CMTF8ejnnk9h6Yih8ajWeNiQK6czWZTgBSEhGZNGQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/516521bf-6417-457e-9a9c-0a4bdfde03e7/nuget/v3/flat2/system.commandline/2.0.0-beta4.24528.1/system.commandline.2.0.0-beta4.24528.1.nupkg"; }) - (fetchNuGet { pname = "System.ComponentModel.Composition"; version = "8.0.0"; hash = "sha256-MnKdjE/qIvAmEeRc3gOn5uJhT0TI3UnUJPjj3TLHFQo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.componentmodel.composition/8.0.0/system.componentmodel.composition.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Composition"; version = "8.0.0"; hash = "sha256-rA118MFj6soKN++BvD3y9gXAJf0lZJAtGARuznG5+Xg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.composition/8.0.0/system.composition.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Composition.AttributedModel"; version = "8.0.0"; hash = "sha256-n3aXiBAFIlQicSRLiNtLh++URSUxRBLggsjJ8OMNRpo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.composition.attributedmodel/8.0.0/system.composition.attributedmodel.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Composition.Convention"; version = "8.0.0"; hash = "sha256-Z9HOAnH1lt1qc38P3Y0qCf5gwBwiLXQD994okcy53IE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.composition.convention/8.0.0/system.composition.convention.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Composition.Hosting"; version = "8.0.0"; hash = "sha256-axKJC71oKiNWKy66TVF/c3yoC81k03XHAWab3mGNbr0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.composition.hosting/8.0.0/system.composition.hosting.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Composition.Runtime"; version = "8.0.0"; hash = "sha256-AxwZ29+GY0E35Pa255q8AcMnJU52Txr5pBy86t6V1Go="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.composition.runtime/8.0.0/system.composition.runtime.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Composition.TypedParts"; version = "8.0.0"; hash = "sha256-+ZJawThmiYEUNJ+cB9uJK+u/sCAVZarGd5ShZoSifGo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.composition.typedparts/8.0.0/system.composition.typedparts.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Configuration.ConfigurationManager"; version = "8.0.0"; hash = "sha256-xhljqSkNQk8DMkEOBSYnn9lzCSEDDq4yO910itptqiE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.configuration.configurationmanager/8.0.0/system.configuration.configurationmanager.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Data.DataSetExtensions"; version = "4.5.0"; hash = "sha256-qppO0L8BpI7cgaStqBhn6YJYFjFdSwpXlRih0XFsaT4="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.data.datasetextensions/4.5.0/system.data.datasetextensions.4.5.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.debug/4.3.0/system.diagnostics.debug.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "8.0.1"; hash = "sha256-zmwHjcJgKcbkkwepH038QhcnsWMJcHys+PEbFGC0Jgo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.diagnosticsource/8.0.1/system.diagnostics.diagnosticsource.8.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.EventLog"; version = "8.0.0"; hash = "sha256-rt8xc3kddpQY4HEdghlBeOK4gdw5yIj4mcZhAVtk2/Y="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.eventlog/8.0.0/system.diagnostics.eventlog.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.PerformanceCounter"; version = "7.0.0"; hash = "sha256-t+l5WgfxivrZhWKjr0rpqtCcNXyRgytsGgWf/BIv5PU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.performancecounter/7.0.0/system.diagnostics.performancecounter.7.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Process"; version = "4.3.0"; hash = "sha256-Rzo24qXhuJDDgrGNHr2eQRHhwLmsYmWDqAg/P5fOlzw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.process/4.3.0/system.diagnostics.process.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.TraceSource"; version = "4.3.0"; hash = "sha256-xpxwaXsRcgso8Gj0cqY4+Hvvz6vZkmEMh5/J204j3M8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracesource/4.3.0/system.diagnostics.tracesource.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracing/4.3.0/system.diagnostics.tracing.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Formats.Asn1"; version = "7.0.0"; hash = "sha256-eMF+SD/yeslf/wOIlOTlpfpj3LtP6HUilGeSj++bJKg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.formats.asn1/7.0.0/system.formats.asn1.7.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization/4.3.0/system.globalization.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io/4.3.0/system.io.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem/4.3.0/system.io.filesystem.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO.FileSystem.AccessControl"; version = "5.0.0"; hash = "sha256-c9MlDKJfj63YRvl7brRBNs59olrmbL+G1A6oTS8ytEc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem.accesscontrol/5.0.0/system.io.filesystem.accesscontrol.5.0.0.nupkg"; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem.primitives/4.3.0/system.io.filesystem.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "8.0.0"; hash = "sha256-LdpB1s4vQzsOODaxiKstLks57X9DTD5D6cPx8DE1wwE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.pipelines/8.0.0/system.io.pipelines.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.IO.Pipes"; version = "4.3.0"; hash = "sha256-2QA4FIwDB7mT4Hs8bj0oDJcCzr4ycsw+tSzF+58J+/k="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.pipes/4.3.0/system.io.pipes.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Management"; version = "7.0.0"; hash = "sha256-QEdYBz8f80t9mvhSzOHsSIc7J0VeOEOzkZnROr/kffQ="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.management/7.0.0/system.management.7.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.5"; hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.memory/4.5.5/system.memory.4.5.5.nupkg"; }) - (fetchNuGet { pname = "System.Net.NameResolution"; version = "4.3.0"; hash = "sha256-eGZwCBExWsnirWBHyp2sSSSXp6g7I6v53qNmwPgtJ5c="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.nameresolution/4.3.0/system.net.nameresolution.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.3.0"; hash = "sha256-MY7Z6vOtFMbEKaLW9nOSZeAjcWpwCtdO7/W1mkGZBzE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.primitives/4.3.0/system.net.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Net.Sockets"; version = "4.3.0"; hash = "sha256-il7dr5VT/QWDg/0cuh+4Es2u8LY//+qqiY9BZmYxSus="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.sockets/4.3.0/system.net.sockets.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.numerics.vectors/4.5.0/system.numerics.vectors.4.5.0.nupkg"; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.2"; hash = "sha256-jB2+W3tTQ6D9XHy5sEFMAazIe1fu2jrENUO0cb48OgU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.private.uri/4.3.2/system.private.uri.4.3.2.nupkg"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection/4.3.0/system.reflection.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.7.0"; hash = "sha256-Fw/CSRD+wajH1MqfKS3Q/sIrUH7GN4K+F+Dx68UPNIg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit/4.7.0/system.reflection.emit.4.7.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.7.0"; hash = "sha256-GUnQeGo/DtvZVQpFnESGq7lJcjB30/KnDY7Kd2G/ElE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit.ilgeneration/4.7.0/system.reflection.emit.ilgeneration.4.7.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.7.0"; hash = "sha256-V0Wz/UUoNIHdTGS9e1TR89u58zJjo/wPUWw6VaVyclU="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit.lightweight/4.7.0/system.reflection.emit.lightweight.4.7.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "8.0.0"; hash = "sha256-dQGC30JauIDWNWXMrSNOJncVa1umR1sijazYwUDdSIE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadata/8.0.0/system.reflection.metadata.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.MetadataLoadContext"; version = "7.0.0"; hash = "sha256-VYl6SFD130K9Aw4eJH16ApJ9Sau4Xu0dcxEip2veuTI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadataloadcontext/7.0.0/system.reflection.metadataloadcontext.7.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.MetadataLoadContext"; version = "8.0.0"; hash = "sha256-jS5XPZiHjY2CJFnLSxL6U7lMrU3ZknvB4EOgMbG0LEo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadataloadcontext/8.0.0/system.reflection.metadataloadcontext.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.primitives/4.3.0/system.reflection.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Resources.Extensions"; version = "8.0.0"; hash = "sha256-5dHZdRwq0tdQanaU5Hw3QISvqSijSGrTa2VdgwifGDI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.extensions/8.0.0/system.resources.extensions.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.resourcemanager/4.3.0/system.resources.resourcemanager.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime/4.3.0/system.runtime.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.compilerservices.unsafe/6.0.0/system.runtime.compilerservices.unsafe.6.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.extensions/4.3.0/system.runtime.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.handles/4.3.0/system.runtime.handles.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices/4.3.0/system.runtime.interopservices.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "5.0.0"; hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.accesscontrol/5.0.0/system.security.accesscontrol.5.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Pkcs"; version = "7.0.2"; hash = "sha256-qS5Z/Yo8J+f3ExVX5Qkcpj1Z57oUZqz5rWa1h5bVpl8="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.pkcs/7.0.2/system.security.cryptography.pkcs.7.0.2.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "8.0.0"; hash = "sha256-fb0pa9sQxN+mr0vnXg1Igbx49CaOqS+GDkTfWNboUvs="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.protecteddata/8.0.0/system.security.cryptography.protecteddata.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Xml"; version = "7.0.1"; hash = "sha256-CH8+JVC8LyCSW75/6ZQ7ecMbSOAE1c16z4dG8JTp01w="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.xml/7.0.1/system.security.cryptography.xml.7.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Security.Permissions"; version = "8.0.0"; hash = "sha256-+YUPY+3HnTmfPLZzr+5qEk0RqalCbFZBgLXee1yCH1M="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.permissions/8.0.0/system.security.permissions.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Principal"; version = "4.3.0"; hash = "sha256-rjudVUHdo8pNJg2EVEn0XxxwNo5h2EaYo+QboPkXlYk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.principal/4.3.0/system.security.principal.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.3.0"; hash = "sha256-mbdLVUcEwe78p3ZnB6jYsizNEqxMaCAWI3tEQNhRQAE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.principal.windows/4.3.0/system.security.principal.windows.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.principal.windows/5.0.0/system.security.principal.windows.5.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding/4.3.0/system.text.encoding.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "7.0.0"; hash = "sha256-eCKTVwumD051ZEcoJcDVRGnIGAsEvKpfH3ydKluHxmo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.codepages/7.0.0/system.text.encoding.codepages.7.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.extensions/4.3.0/system.text.encoding.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "8.0.0"; hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encodings.web/8.0.0/system.text.encodings.web.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Json"; version = "8.0.4"; hash = "sha256-g5oT7fbXxQ9Iah1nMCr4UUX/a2l+EVjJyTrw3FTbIaI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.json/8.0.4/system.text.json.8.0.4.nupkg"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading/4.3.0/system.threading.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Channels"; version = "7.0.0"; hash = "sha256-Cu0gjQsLIR8Yvh0B4cOPJSYVq10a+3F9pVz/C43CNeM="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.channels/7.0.0/system.threading.channels.7.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Overlapped"; version = "4.3.0"; hash = "sha256-tUX099CChkqWiHyP/1e4jGYzZAjgIthMOdMmiOGMUNk="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.overlapped/4.3.0/system.threading.overlapped.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks/4.3.0/system.threading.tasks.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Dataflow"; version = "8.0.0"; hash = "sha256-Q6fPtMPNW4+SDKCabJzNS+dw4B04Oxd9sHH505bFtQo="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.dataflow/8.0.0/system.threading.tasks.dataflow.8.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.extensions/4.5.4/system.threading.tasks.extensions.4.5.4.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Thread"; version = "4.3.0"; hash = "sha256-pMs6RNFC3nQOGz9EqIcyWmO8YLaqay+q/Qde5hqPXXg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.thread/4.3.0/system.threading.thread.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.ThreadPool"; version = "4.3.0"; hash = "sha256-wW0QdvssRoaOfQLazTGSnwYTurE4R8FxDx70pYkL+gg="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.threadpool/4.3.0/system.threading.threadpool.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.ValueTuple"; version = "4.5.0"; hash = "sha256-niH6l2fU52vAzuBlwdQMw0OEoRS/7E1w5smBFoqSaAI="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.valuetuple/4.5.0/system.valuetuple.4.5.0.nupkg"; }) - (fetchNuGet { pname = "System.Windows.Extensions"; version = "8.0.0"; hash = "sha256-aHkz7LtmUDDRS7swQM0i6dDVUytRCMYeA2CfaeVA2Y0="; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.windows.extensions/8.0.0/system.windows.extensions.8.0.0.nupkg"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "dotnet-format"; + version = "7.0.360304"; + hash = "sha256-TuhZIhearocl702hLzGJCcRd8+RWoI4tDY02Bf6Lus8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/dotnet-format/7.0.360304/dotnet-format.7.0.360304.nupkg"; + }) + (fetchNuGet { + pname = "Humanizer.Core"; + version = "2.14.1"; + hash = "sha256-EXvojddPu+9JKgOG9NSQgUTfWq1RpOYw7adxDPKDJ6o="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/humanizer.core/2.14.1/humanizer.core.2.14.1.nupkg"; + }) + (fetchNuGet { + pname = "ICSharpCode.Decompiler"; + version = "8.1.1.7464"; + hash = "sha256-71/e9zuQIfqRXOiWxZkUFW/tMAj63nE8tg/sR7bGzuM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/icsharpcode.decompiler/8.1.1.7464/icsharpcode.decompiler.8.1.1.7464.nupkg"; + }) + (fetchNuGet { + pname = "MessagePack"; + version = "2.5.108"; + hash = "sha256-+vMXyEbfutY5WOFuFnNF24uLcKJTTdntVrVlSJH4yjI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/messagepack/2.5.108/messagepack.2.5.108.nupkg"; + }) + (fetchNuGet { + pname = "MessagePack"; + version = "2.5.124"; + hash = "sha256-3ZUXCiDKpD82W+prJ5yLFm/gmztNsm8W0NPRs74bgrw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/messagepack/2.5.124/messagepack.2.5.124.nupkg"; + }) + (fetchNuGet { + pname = "MessagePack.Annotations"; + version = "2.5.108"; + hash = "sha256-u3Qu8UftNIz3oIzQUMa7Z0G6VzmDLcAnAeNQ3lB3YVk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/messagepack.annotations/2.5.108/messagepack.annotations.2.5.108.nupkg"; + }) + (fetchNuGet { + pname = "MessagePack.Annotations"; + version = "2.5.124"; + hash = "sha256-4zgAUW6py8CA2hMGUUrHr7Q6vKeRBqOCmcKgAR9fRGg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/messagepack.annotations/2.5.124/messagepack.annotations.2.5.124.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Razor.ExternalAccess.RoslynWorkspace"; + version = "9.0.0-preview.24555.12"; + hash = "sha256-SMOU22F2xZkFM6KRRETeRR79BuVccALMGH+zcgyqq4M="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.aspnetcore.razor.externalaccess.roslynworkspace/9.0.0-preview.24555.12/microsoft.aspnetcore.razor.externalaccess.roslynworkspace.9.0.0-preview.24555.12.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "8.0.0"; + hash = "sha256-9aWmiwMJKrKr9ohD1KSuol37y+jdDxPGJct3m2/Bknw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.bcl.asyncinterfaces/8.0.0/microsoft.bcl.asyncinterfaces.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build"; + version = "17.12.0-preview-24426-07"; + hash = "sha256-OHQd2npzibOaNSR2sq3NrKKtAALOmnIARmFoBaXiJ0k="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.build/17.12.0-preview-24426-07/microsoft.build.17.12.0-preview-24426-07.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build"; + version = "17.3.4"; + hash = "sha256-LHtjk4vxeVSLzAKAcG8BN+S20d2sUR2DAOsSXLNIy5U="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.build/17.3.4/microsoft.build.17.3.4.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build"; + version = "17.7.2"; + hash = "sha256-k35nFdPxC8t0zAltVSmAJtsepp/ubNIjPOsJ6k8jSqM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build/17.7.2/microsoft.build.17.7.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Framework"; + version = "17.12.0-preview-24426-07"; + hash = "sha256-p5JNAp442gjiu14gfM4eF477iT9Ttac8ALHXISbsecs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.build.framework/17.12.0-preview-24426-07/microsoft.build.framework.17.12.0-preview-24426-07.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Framework"; + version = "17.3.4"; + hash = "sha256-p2JG7pMBGfDVP6sOzBOqOkImZmwotlGvfS+8BjjVYf8="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.build.framework/17.3.4/microsoft.build.framework.17.3.4.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Framework"; + version = "17.7.2"; + hash = "sha256-fNWmVQYFTJDveAGmxEdNqJRAczV6+Ep8RA8clKBJFqw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.framework/17.7.2/microsoft.build.framework.17.7.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Locator"; + version = "1.6.10"; + hash = "sha256-hOFFiQiCNkkDqt0Ad/4Y/sggj4t0zWXmfGjE+I/cqqM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.locator/1.6.10/microsoft.build.locator.1.6.10.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Tasks.Core"; + version = "17.12.0-preview-24426-07"; + hash = "sha256-2igOkxetlTeRv2Xq5wVcQXU7hxdP43yMJq3aK6vndoI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.build.tasks.core/17.12.0-preview-24426-07/microsoft.build.tasks.core.17.12.0-preview-24426-07.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Tasks.Core"; + version = "17.3.4"; + hash = "sha256-0RA95pD6zHBf1lgYyrrAuEuNeGwuCgGxNdhEJ0cJUCs="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.build.tasks.core/17.3.4/microsoft.build.tasks.core.17.3.4.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Tasks.Core"; + version = "17.7.2"; + hash = "sha256-OrV/qWgZHzGlNUmaSfX5wDBcmg1aQeF3/OUHpSH+uZU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.tasks.core/17.7.2/microsoft.build.tasks.core.17.7.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Utilities.Core"; + version = "17.12.0-preview-24426-07"; + hash = "sha256-np372GONmrZJ8ppPxjZrvtofA5gTnUf2n/Pn9f02ilo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.build.utilities.core/17.12.0-preview-24426-07/microsoft.build.utilities.core.17.12.0-preview-24426-07.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Utilities.Core"; + version = "17.3.4"; + hash = "sha256-SfZxr5xDANnDnC1HCUgho2H9MnF6n51cM47Rrf07fWw="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.build.utilities.core/17.3.4/microsoft.build.utilities.core.17.3.4.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Utilities.Core"; + version = "17.7.2"; + hash = "sha256-oatF0KfuP1nb4+OLNKg2/R/ZLO4EiACaO5leaxMEY4A="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.utilities.core/17.7.2/microsoft.build.utilities.core.17.7.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.11.0"; + hash = "sha256-hQ2l6E6PO4m7i+ZsfFlEx+93UsLPo4IY3wDkNG11/Sw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.analyzers/3.11.0/microsoft.codeanalysis.analyzers.3.11.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.AnalyzerUtilities"; + version = "3.3.0"; + hash = "sha256-nzFs+H0FFEgZzjl/bcmWyQQVKS2PncS6kMYHOqrxXSw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.analyzerutilities/3.3.0/microsoft.codeanalysis.analyzerutilities.3.3.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.BannedApiAnalyzers"; + version = "3.11.0-beta1.24081.1"; + hash = "sha256-5UN//A8oc2w+UoxAwWmXWRXykQD+2mpa1hbJrAfh2Lg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a54510f9-4b2c-4e69-b96a-6096683aaa1f/nuget/v3/flat2/microsoft.codeanalysis.bannedapianalyzers/3.11.0-beta1.24081.1/microsoft.codeanalysis.bannedapianalyzers.3.11.0-beta1.24081.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "4.1.0"; + hash = "sha256-g3RLyeHfdOOF6H89VLJi06/k8/eJ6j2dgNYZ/MBdfNU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.common/4.1.0/microsoft.codeanalysis.common.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Elfie"; + version = "1.0.0"; + hash = "sha256-E/+PlegvWZ59e5Ti3TvKJBLa3qCnDKmi7+DcnOo1ufg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.elfie/1.0.0/microsoft.codeanalysis.elfie.1.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.NetAnalyzers"; + version = "8.0.0-preview.23468.1"; + hash = "sha256-2wF9nG7tL92RKT46l5A0EQB3uow93516Dh8hSw7kUvg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/49a1bb2b-12b0-475f-adbd-1560fc76be38/nuget/v3/flat2/microsoft.codeanalysis.netanalyzers/8.0.0-preview.23468.1/microsoft.codeanalysis.netanalyzers.8.0.0-preview.23468.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.PerformanceSensitiveAnalyzers"; + version = "3.3.4-beta1.22504.1"; + hash = "sha256-HYGDtRhUgaIG5t4VpOt3ZFQ8nqLSJ6mTR5964FMmK50="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/e31c6eea-0277-49f3-8194-142be67a9f72/nuget/v3/flat2/microsoft.codeanalysis.performancesensitiveanalyzers/3.3.4-beta1.22504.1/microsoft.codeanalysis.performancesensitiveanalyzers.3.3.4-beta1.22504.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.PublicApiAnalyzers"; + version = "3.11.0-beta1.24081.1"; + hash = "sha256-nXx0MSYXVzdr0jcNo9aZLocZU1ywN+n/vdD2kYBh5TI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a54510f9-4b2c-4e69-b96a-6096683aaa1f/nuget/v3/flat2/microsoft.codeanalysis.publicapianalyzers/3.11.0-beta1.24081.1/microsoft.codeanalysis.publicapianalyzers.3.11.0-beta1.24081.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.7.0"; + hash = "sha256-Enknv2RsFF68lEPdrf5M+BpV1kHoLTVRApKUwuk/pj0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.csharp/4.7.0/microsoft.csharp.4.7.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.DiaSymReader"; + version = "2.0.0"; + hash = "sha256-8hotZmh8Rb6Q6oD9Meb74SvAdbDo39Y/1m8h43HHjjw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.diasymreader/2.0.0/microsoft.diasymreader.2.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.Arcade.Sdk"; + version = "9.0.0-beta.24572.2"; + hash = "sha256-dTYFN1KH3grxcf/On6GLW5WdFliq91Y37DeWDCwiryM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.dotnet.arcade.sdk/9.0.0-beta.24572.2/microsoft.dotnet.arcade.sdk.9.0.0-beta.24572.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.XliffTasks"; + version = "9.0.0-beta.24076.5"; + hash = "sha256-5cREL85PwcDwo4yyc2Eh908HQ/Cm36w9uZSIvVELZH0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.dotnet.xlifftasks/9.0.0-beta.24076.5/microsoft.dotnet.xlifftasks.9.0.0-beta.24076.5.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "8.0.0"; + hash = "sha256-9BPsASlxrV8ilmMCjdb3TiUcm5vFZxkBnAI/fNBSEyA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.configuration/8.0.0/microsoft.extensions.configuration.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "8.0.0"; + hash = "sha256-4eBpDkf7MJozTZnOwQvwcfgRKQGcNXe0K/kF+h5Rl8o="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.configuration.abstractions/8.0.0/microsoft.extensions.configuration.abstractions.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "8.0.0"; + hash = "sha256-GanfInGzzoN2bKeNwON8/Hnamr6l7RTpYLA49CNXD9Q="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.configuration.binder/8.0.0/microsoft.extensions.configuration.binder.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "8.0.0"; + hash = "sha256-+qIDR8hRzreCHNEDtUcPfVHQdurzWPo/mqviCH78+EQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.dependencyinjection/8.0.0/microsoft.extensions.dependencyinjection.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.0"; + hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.dependencyinjection.abstractions/8.0.0/microsoft.extensions.dependencyinjection.abstractions.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileSystemGlobbing"; + version = "8.0.0"; + hash = "sha256-+Oz41JR5jdcJlCJOSpQIL5OMBNi+1Hl2d0JUHfES7sU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.filesystemglobbing/8.0.0/microsoft.extensions.filesystemglobbing.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "8.0.0"; + hash = "sha256-Meh0Z0X7KyOEG4l0RWBcuHHihcABcvCyfUXgasmQ91o="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.logging/8.0.0/microsoft.extensions.logging.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "8.0.0"; + hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.logging.abstractions/8.0.0/microsoft.extensions.logging.abstractions.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Configuration"; + version = "8.0.0"; + hash = "sha256-mzmstNsVjKT0EtQcdAukGRifD30T82BMGYlSu8k4K7U="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.logging.configuration/8.0.0/microsoft.extensions.logging.configuration.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Console"; + version = "8.0.0"; + hash = "sha256-bdb9YWWVn//AeySp7se87/tCN2E7e8Gx2GPMw28cd9c="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.logging.console/8.0.0/microsoft.extensions.logging.console.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.ObjectPool"; + version = "8.0.0"; + hash = "sha256-FxFr5GC0y6vnp5YD2A2vISXYizAz3k/QyrH7sBXP5kg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.objectpool/8.0.0/microsoft.extensions.objectpool.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "8.0.0"; + hash = "sha256-n2m4JSegQKUTlOsKLZUUHHKMq926eJ0w9N9G+I3FoFw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.options/8.0.0/microsoft.extensions.options.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; + version = "8.0.0"; + hash = "sha256-A5Bbzw1kiNkgirk5x8kyxwg9lLTcSngojeD+ocpG1RI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.options.configurationextensions/8.0.0/microsoft.extensions.options.configurationextensions.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "8.0.0"; + hash = "sha256-FU8qj3DR8bDdc1c+WeGZx/PCZeqqndweZM9epcpXjSo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.extensions.primitives/8.0.0/microsoft.extensions.primitives.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.IO.Redist"; + version = "6.0.1"; + hash = "sha256-IaATAy1M/MEBTid0mQiTrHj4aTwo2POCtckxSbLc3lU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.io.redist/6.0.1/microsoft.io.redist.6.0.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NET.StringTools"; + version = "17.12.0-preview-24426-07"; + hash = "sha256-yoReTrCOhI6ud3v6fLGi5ivS0RuBDhDWw/giD9+bYOk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.net.stringtools/17.12.0-preview-24426-07/microsoft.net.stringtools.17.12.0-preview-24426-07.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NET.StringTools"; + version = "17.4.0"; + hash = "sha256-+9uBaUDZ3roUJwyYJUL30Mz+3C6LE16FzfQKgS0Yveo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.net.stringtools/17.4.0/microsoft.net.stringtools.17.4.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NET.StringTools"; + version = "17.6.3"; + hash = "sha256-H2Qw8x47WyFOd/VmgRmGMc+uXySgUv68UISgK8Frsjw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.net.stringtools/17.6.3/microsoft.net.stringtools.17.6.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NET.StringTools"; + version = "17.7.2"; + hash = "sha256-hQE07TCgcQuyu9ZHVq2gPDb0+xe8ECJUdrgh17bJP4o="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.net.stringtools/17.7.2/microsoft.net.stringtools.17.7.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "5.0.0"; + hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/5.0.0/microsoft.netcore.platforms.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.targets/1.1.0/microsoft.netcore.targets.1.1.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.3"; + hash = "sha256-WLsf1NuUfRWyr7C7Rl9jiua9jximnVvzy6nk2D2bVRc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.targets/1.1.3/microsoft.netcore.targets.1.1.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies"; + version = "1.0.3"; + hash = "sha256-FBoJP5DHZF0QHM0xLm9yd4HJZVQOuSpSKA+VQRpphEE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies/1.0.3/microsoft.netframework.referenceassemblies.1.0.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies.net472"; + version = "1.0.3"; + hash = "sha256-/6ClVwo5+RE5kWTQWB/93vmbXj37ql8iDlziKWm89Xw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies.net472/1.0.3/microsoft.netframework.referenceassemblies.net472.1.0.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.ServiceHub.Analyzers"; + version = "4.7.32-beta"; + hash = "sha256-vYKNtk5BauoAwUt2g+0GodmRZ9JWHWfFIBrcOPFHuyQ="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.servicehub.analyzers/4.7.32-beta/microsoft.servicehub.analyzers.4.7.32-beta.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.ServiceHub.Client"; + version = "4.2.1017"; + hash = "sha256-Achfy4EpZfcIOf02P8onWJH1cte+rP9ZAy94Gf4MVCA="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/2a239fd0-3e21-40b0-b9d6-bc122fec7eb2/nuget/v3/flat2/microsoft.servicehub.client/4.2.1017/microsoft.servicehub.client.4.2.1017.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.ServiceHub.Framework"; + version = "4.7.32-beta"; + hash = "sha256-QGtg9LL8FRRjDiMn5sJYPn1gliSzzxokyMVsa1uvDfs="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.servicehub.framework/4.7.32-beta/microsoft.servicehub.framework.4.7.32-beta.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.ServiceHub.Resources"; + version = "4.2.1017"; + hash = "sha256-6nq1jsXLThMritNI1CZj5Batfo/0W0Pt2iLY72yZGNw="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/2a239fd0-3e21-40b0-b9d6-bc122fec7eb2/nuget/v3/flat2/microsoft.servicehub.resources/4.2.1017/microsoft.servicehub.resources.4.2.1017.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.ObjectModel"; + version = "17.5.0"; + hash = "sha256-M8Ct2u3RaTxWip0XBLPtL2xeGsYz1rjKgfsV++nZDPg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.testplatform.objectmodel/17.5.0/microsoft.testplatform.objectmodel.17.5.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.TranslationLayer"; + version = "17.5.0"; + hash = "sha256-rVgeXl/F8jqXJhQcrm2tV6jvsYHA6UF+5crLVr4GZBA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.testplatform.translationlayer/17.5.0/microsoft.testplatform.translationlayer.17.5.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Composition"; + version = "17.12.17-preview"; + hash = "sha256-RxakGlbjWXC28F50Z5Ayez5gVsmCeyPqOKw3aBCKrDc="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.visualstudio.composition/17.12.17-preview/microsoft.visualstudio.composition.17.12.17-preview.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Composition.Analyzers"; + version = "17.12.17-preview"; + hash = "sha256-tZ7SmS9wq1f7FJMLo+c5YRdeAoJ7ZHemhgtXiTTzqIU="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.visualstudio.composition.analyzers/17.12.17-preview/microsoft.visualstudio.composition.analyzers.17.12.17-preview.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.RemoteControl"; + version = "16.3.52"; + hash = "sha256-J/egIc9ovDi1MUrnyKnpadECQqAB1WUUyrbxINv4zRE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.remotecontrol/16.3.52/microsoft.visualstudio.remotecontrol.16.3.52.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Setup.Configuration.Interop"; + version = "3.2.2146"; + hash = "sha256-ic5h0cmHIaowJfItTLXLnmFhIg4NhaoMoWVAFMHKdzQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.setup.configuration.interop/3.2.2146/microsoft.visualstudio.setup.configuration.interop.3.2.2146.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Telemetry"; + version = "17.12.32"; + hash = "sha256-HkAQyMovZEABmgcaaSo/DOyRbx+pyVOZGxEm7GEKd2E="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.visualstudio.telemetry/17.12.32/microsoft.visualstudio.telemetry.17.12.32.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Threading"; + version = "17.12.13-preview"; + hash = "sha256-StuzZma2nOXFJ5Al9AZZPo0kM4FrTgHYz2ji+zKgtlM="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.visualstudio.threading/17.12.13-preview/microsoft.visualstudio.threading.17.12.13-preview.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Threading.Analyzers"; + version = "17.12.13-preview"; + hash = "sha256-wrCnLYNSujq8fcpmjm/yTTY7uVOPAjpJA+1X8ujuVbA="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/microsoft.visualstudio.threading.analyzers/17.12.13-preview/microsoft.visualstudio.threading.analyzers.17.12.13-preview.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Utilities.Internal"; + version = "16.3.73"; + hash = "sha256-zwk4jWuCw2ANhG00TnwT9JE7n/h2EQkYKeq6o966ilo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.utilities.internal/16.3.73/microsoft.visualstudio.utilities.internal.16.3.73.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Validation"; + version = "17.8.8"; + hash = "sha256-sB8GLRiJHX3Py7qeBUnUANiDWhyPtISon6HQs+8wKms="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.validation/17.8.8/microsoft.visualstudio.validation.17.8.8.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.3.0"; + hash = "sha256-mBNDmPXNTW54XLnPAUwBRvkIORFM7/j0D0I2SyQPDEg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.primitives/4.3.0/microsoft.win32.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "5.0.0"; + hash = "sha256-9kylPGfKZc58yFqNKa77stomcoNnMeERXozWJzDcUIA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.registry/5.0.0/microsoft.win32.registry.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Nerdbank.Streams"; + version = "2.11.79"; + hash = "sha256-1bzibVcSH8LJMR8Nb6Q0q/7fieTgxRnVY4C1RvRbrrI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/nerdbank.streams/2.11.79/nerdbank.streams.2.11.79.nupkg"; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.0"; + hash = "sha256-Pp7fRylai8JrE1O+9TGfIEJrAOmnWTJRLWE+qJBahK0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/netstandard.library/2.0.0/netstandard.library.2.0.0.nupkg"; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/netstandard.library/2.0.3/netstandard.library.2.0.3.nupkg"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.3"; + hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/newtonsoft.json/13.0.3/newtonsoft.json.13.0.3.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Common"; + version = "6.8.0-rc.112"; + hash = "sha256-LfIF8idaAeEfEeaXlhUhw4KcY0QXzMNwHqvAInSgF5c="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.common/6.8.0-rc.112/nuget.common.6.8.0-rc.112.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Configuration"; + version = "6.8.0-rc.112"; + hash = "sha256-tWhwgxiaXcWPXdZVnDS2wsdblN6FoPR/uGmW57y3Fnw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.configuration/6.8.0-rc.112/nuget.configuration.6.8.0-rc.112.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.DependencyResolver.Core"; + version = "6.8.0-rc.112"; + hash = "sha256-nS0Km+T6sRdIQLzwqjluHoV3MQe2dxwYhCrnKuURoSs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.dependencyresolver.core/6.8.0-rc.112/nuget.dependencyresolver.core.6.8.0-rc.112.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Frameworks"; + version = "5.11.0"; + hash = "sha256-n+hxcrf+sXM80Tv9YH9x4+hwTslVidFq4tjBNPAzYnM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/nuget.frameworks/5.11.0/nuget.frameworks.5.11.0.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Frameworks"; + version = "6.8.0-rc.112"; + hash = "sha256-0dmY/5/Pa+FW3ck0q8zdeHjt59PAeNNCh0tu+wY2260="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.frameworks/6.8.0-rc.112/nuget.frameworks.6.8.0-rc.112.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.LibraryModel"; + version = "6.8.0-rc.112"; + hash = "sha256-8D1DetEC3pkDDRGdmjlfrKRQ9xqEwqnga3ZixZYMsIg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.librarymodel/6.8.0-rc.112/nuget.librarymodel.6.8.0-rc.112.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Packaging"; + version = "6.8.0-rc.112"; + hash = "sha256-Z9E9TIQSd+8gkOyc2k4LompDwdLQJMGNbHEt3DG1I4g="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.packaging/6.8.0-rc.112/nuget.packaging.6.8.0-rc.112.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.ProjectModel"; + version = "6.8.0-rc.112"; + hash = "sha256-geQh1fSRTp2FTzeilFL8gxFFq7q8u7YaakShPKiTwns="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.projectmodel/6.8.0-rc.112/nuget.projectmodel.6.8.0-rc.112.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Protocol"; + version = "6.8.0-rc.112"; + hash = "sha256-6r/MJCo2ngibSAfNdH+xmeNUl38EPjQkaewKsTJpfvU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.protocol/6.8.0-rc.112/nuget.protocol.6.8.0-rc.112.nupkg"; + }) + (fetchNuGet { + pname = "NuGet.Versioning"; + version = "6.8.0-rc.112"; + hash = "sha256-BzAWS5wpGnNj0gU33sfWao7BELGjrQBT4xj3EC7qRRE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/nuget.versioning/6.8.0-rc.112/nuget.versioning.6.8.0-rc.112.nupkg"; + }) + (fetchNuGet { + pname = "PowerShell"; + version = "7.0.0"; + hash = "sha256-ioasr71UIhDmeZ2Etw52lQ7QsioEd1pnbpVlEeCyUI4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/powershell/7.0.0/powershell.7.0.0.nupkg"; + }) + (fetchNuGet { + pname = "RichCodeNav.EnvVarDump"; + version = "0.1.1643-alpha"; + hash = "sha256-bwND+Na9iEnkEdeL1elY34+m4/F4BYATBHv/2BEw4d4="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/58ca65bb-e6c1-4210-88ac-fa55c1cd7877/nuget/v3/flat2/richcodenav.envvardump/0.1.1643-alpha/richcodenav.envvardump.0.1.1643-alpha.nupkg"; + }) + (fetchNuGet { + pname = "Roslyn.Diagnostics.Analyzers"; + version = "3.11.0-beta1.24081.1"; + hash = "sha256-wIOhKwvYetwytnuNX0uNC5oyBDU7xAhLqzTvyuGDVMM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a54510f9-4b2c-4e69-b96a-6096683aaa1f/nuget/v3/flat2/roslyn.diagnostics.analyzers/3.11.0-beta1.24081.1/roslyn.diagnostics.analyzers.3.11.0-beta1.24081.1.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.collections/4.3.0/runtime.any.system.collections.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-dsmTLGvt8HqRkDWP8iKVXJCS+akAzENGXKPV18W2RgI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.diagnostics.tracing/4.3.0/runtime.any.system.diagnostics.tracing.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.globalization/4.3.0/runtime.any.system.globalization.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.io/4.3.0/runtime.any.system.io.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.reflection/4.3.0/runtime.any.system.reflection.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.reflection.primitives/4.3.0/runtime.any.system.reflection.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.resources.resourcemanager/4.3.0/runtime.any.system.resources.resourcemanager.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.runtime/4.3.0/runtime.any.system.runtime.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.runtime.handles/4.3.0/runtime.any.system.runtime.handles.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.runtime.interopservices/4.3.0/runtime.any.system.runtime.interopservices.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.text.encoding/4.3.0/runtime.any.system.text.encoding.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-6MYj0RmLh4EVqMtO/MRqBi0HOn5iG4x9JimgCCJ+EFM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.text.encoding.extensions/4.3.0/runtime.any.system.text.encoding.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.threading.tasks/4.3.0/runtime.any.system.threading.tasks.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system/4.3.0/runtime.native.system.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.security.cryptography.openssl/4.3.0/runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.Microsoft.Win32.Primitives"; + version = "4.3.0"; + hash = "sha256-LZb23lRXzr26tRS5aA0xyB08JxiblPDoA7HBvn6awXg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.microsoft.win32.primitives/4.3.0/runtime.unix.microsoft.win32.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.diagnostics.debug/4.3.0/runtime.unix.system.diagnostics.debug.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-Pf4mRl6YDK2x2KMh0WdyNgv0VUNdSKVDLlHqozecy5I="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.io.filesystem/4.3.0/runtime.unix.system.io.filesystem.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Primitives"; + version = "4.3.0"; + hash = "sha256-pHJ+I6i16MV6m77uhTC6GPY6jWGReE3SSP3fVB59ti0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.net.primitives/4.3.0/runtime.unix.system.net.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Sockets"; + version = "4.3.0"; + hash = "sha256-IvgOeA2JuBjKl5yAVGjPYMPDzs9phb3KANs95H9v1w4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.net.sockets/4.3.0/runtime.unix.system.net.sockets.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.private.uri/4.3.0/runtime.unix.system.private.uri.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.runtime.extensions/4.3.0/runtime.unix.system.runtime.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.bundle_green"; + version = "2.1.0"; + hash = "sha256-W14WMqNZndRmnySqLdFqmvfbH14kJxMV6+/4dIS0CwE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/sqlitepclraw.bundle_green/2.1.0/sqlitepclraw.bundle_green.2.1.0.nupkg"; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.core"; + version = "2.1.0"; + hash = "sha256-l1lfw114VmMprNFNn1fM/wzKEbDywXDlgdTQWWbqBU8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/sqlitepclraw.core/2.1.0/sqlitepclraw.core.2.1.0.nupkg"; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.lib.e_sqlite3"; + version = "2.1.0"; + hash = "sha256-XsObwf7Fza9G1JCZvQ+SqMqQUdZNU3WcJYYp3cqfc8U="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/sqlitepclraw.lib.e_sqlite3/2.1.0/sqlitepclraw.lib.e_sqlite3.2.1.0.nupkg"; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.provider.dynamic_cdecl"; + version = "2.1.0"; + hash = "sha256-2JLlOroGdfziGi+VpgBjtm9IHofG976T+9lZb+fQRok="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/sqlitepclraw.provider.dynamic_cdecl/2.1.0/sqlitepclraw.provider.dynamic_cdecl.2.1.0.nupkg"; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.provider.e_sqlite3"; + version = "2.1.0"; + hash = "sha256-VkGdCCECj+0oaha/QsyfF9CQoaurC/KO2RHR2GaI77w="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/sqlitepclraw.provider.e_sqlite3/2.1.0/sqlitepclraw.provider.e_sqlite3.2.1.0.nupkg"; + }) + (fetchNuGet { + pname = "StreamJsonRpc"; + version = "2.20.8-beta"; + hash = "sha256-cELu//Ad7sAITbq/i5ISi4g1Mvf9mUIYT6vDTukUjQY="; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/491596af-6d2d-439e-80bb-1ebb3b54f9a8/nuget/v3/flat2/streamjsonrpc/2.20.8-beta/streamjsonrpc.2.20.8-beta.nupkg"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + hash = "sha256-wws90sfi9M7kuCPWkv1CEYMJtCqx9QB/kj0ymlsNaxI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.5.1/system.buffers.4.5.1.nupkg"; + }) + (fetchNuGet { + pname = "System.CodeDom"; + version = "7.0.0"; + hash = "sha256-7IPt39cY+0j0ZcRr/J45xPtEjnSXdUJ/5ai3ebaYQiE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.codedom/7.0.0/system.codedom.7.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections/4.3.0/system.collections.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "8.0.0"; + hash = "sha256-F7OVjKNwpqbUh8lTidbqJWYi476nsq9n+6k0+QVRo3w="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.immutable/8.0.0/system.collections.immutable.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.CommandLine"; + version = "2.0.0-beta4.24528.1"; + hash = "sha256-C1CMTF8ejnnk9h6Yih8ajWeNiQK6czWZTgBSEhGZNGQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/516521bf-6417-457e-9a9c-0a4bdfde03e7/nuget/v3/flat2/system.commandline/2.0.0-beta4.24528.1/system.commandline.2.0.0-beta4.24528.1.nupkg"; + }) + (fetchNuGet { + pname = "System.ComponentModel.Composition"; + version = "8.0.0"; + hash = "sha256-MnKdjE/qIvAmEeRc3gOn5uJhT0TI3UnUJPjj3TLHFQo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.componentmodel.composition/8.0.0/system.componentmodel.composition.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Composition"; + version = "8.0.0"; + hash = "sha256-rA118MFj6soKN++BvD3y9gXAJf0lZJAtGARuznG5+Xg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.composition/8.0.0/system.composition.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Composition.AttributedModel"; + version = "8.0.0"; + hash = "sha256-n3aXiBAFIlQicSRLiNtLh++URSUxRBLggsjJ8OMNRpo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.composition.attributedmodel/8.0.0/system.composition.attributedmodel.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Composition.Convention"; + version = "8.0.0"; + hash = "sha256-Z9HOAnH1lt1qc38P3Y0qCf5gwBwiLXQD994okcy53IE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.composition.convention/8.0.0/system.composition.convention.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Composition.Hosting"; + version = "8.0.0"; + hash = "sha256-axKJC71oKiNWKy66TVF/c3yoC81k03XHAWab3mGNbr0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.composition.hosting/8.0.0/system.composition.hosting.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Composition.Runtime"; + version = "8.0.0"; + hash = "sha256-AxwZ29+GY0E35Pa255q8AcMnJU52Txr5pBy86t6V1Go="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.composition.runtime/8.0.0/system.composition.runtime.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Composition.TypedParts"; + version = "8.0.0"; + hash = "sha256-+ZJawThmiYEUNJ+cB9uJK+u/sCAVZarGd5ShZoSifGo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.composition.typedparts/8.0.0/system.composition.typedparts.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Configuration.ConfigurationManager"; + version = "8.0.0"; + hash = "sha256-xhljqSkNQk8DMkEOBSYnn9lzCSEDDq4yO910itptqiE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.configuration.configurationmanager/8.0.0/system.configuration.configurationmanager.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Data.DataSetExtensions"; + version = "4.5.0"; + hash = "sha256-qppO0L8BpI7cgaStqBhn6YJYFjFdSwpXlRih0XFsaT4="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.data.datasetextensions/4.5.0/system.data.datasetextensions.4.5.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.debug/4.3.0/system.diagnostics.debug.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "8.0.1"; + hash = "sha256-zmwHjcJgKcbkkwepH038QhcnsWMJcHys+PEbFGC0Jgo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.diagnosticsource/8.0.1/system.diagnostics.diagnosticsource.8.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.EventLog"; + version = "8.0.0"; + hash = "sha256-rt8xc3kddpQY4HEdghlBeOK4gdw5yIj4mcZhAVtk2/Y="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.eventlog/8.0.0/system.diagnostics.eventlog.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.PerformanceCounter"; + version = "7.0.0"; + hash = "sha256-t+l5WgfxivrZhWKjr0rpqtCcNXyRgytsGgWf/BIv5PU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.performancecounter/7.0.0/system.diagnostics.performancecounter.7.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Process"; + version = "4.3.0"; + hash = "sha256-Rzo24qXhuJDDgrGNHr2eQRHhwLmsYmWDqAg/P5fOlzw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.process/4.3.0/system.diagnostics.process.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.TraceSource"; + version = "4.3.0"; + hash = "sha256-xpxwaXsRcgso8Gj0cqY4+Hvvz6vZkmEMh5/J204j3M8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracesource/4.3.0/system.diagnostics.tracesource.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + hash = "sha256-hCETZpHHGVhPYvb4C0fh4zs+8zv4GPoixagkLZjpa9Q="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracing/4.3.0/system.diagnostics.tracing.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Formats.Asn1"; + version = "7.0.0"; + hash = "sha256-eMF+SD/yeslf/wOIlOTlpfpj3LtP6HUilGeSj++bJKg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.formats.asn1/7.0.0/system.formats.asn1.7.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization/4.3.0/system.globalization.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io/4.3.0/system.io.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem/4.3.0/system.io.filesystem.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.AccessControl"; + version = "5.0.0"; + hash = "sha256-c9MlDKJfj63YRvl7brRBNs59olrmbL+G1A6oTS8ytEc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem.accesscontrol/5.0.0/system.io.filesystem.accesscontrol.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem.primitives/4.3.0/system.io.filesystem.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "8.0.0"; + hash = "sha256-LdpB1s4vQzsOODaxiKstLks57X9DTD5D6cPx8DE1wwE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.pipelines/8.0.0/system.io.pipelines.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.Pipes"; + version = "4.3.0"; + hash = "sha256-2QA4FIwDB7mT4Hs8bj0oDJcCzr4ycsw+tSzF+58J+/k="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.pipes/4.3.0/system.io.pipes.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Management"; + version = "7.0.0"; + hash = "sha256-QEdYBz8f80t9mvhSzOHsSIc7J0VeOEOzkZnROr/kffQ="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.management/7.0.0/system.management.7.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.5"; + hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.memory/4.5.5/system.memory.4.5.5.nupkg"; + }) + (fetchNuGet { + pname = "System.Net.NameResolution"; + version = "4.3.0"; + hash = "sha256-eGZwCBExWsnirWBHyp2sSSSXp6g7I6v53qNmwPgtJ5c="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.nameresolution/4.3.0/system.net.nameresolution.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.3.0"; + hash = "sha256-MY7Z6vOtFMbEKaLW9nOSZeAjcWpwCtdO7/W1mkGZBzE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.primitives/4.3.0/system.net.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Net.Sockets"; + version = "4.3.0"; + hash = "sha256-il7dr5VT/QWDg/0cuh+4Es2u8LY//+qqiY9BZmYxSus="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.sockets/4.3.0/system.net.sockets.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.numerics.vectors/4.5.0/system.numerics.vectors.4.5.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.2"; + hash = "sha256-jB2+W3tTQ6D9XHy5sEFMAazIe1fu2jrENUO0cb48OgU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.private.uri/4.3.2/system.private.uri.4.3.2.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection/4.3.0/system.reflection.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.7.0"; + hash = "sha256-Fw/CSRD+wajH1MqfKS3Q/sIrUH7GN4K+F+Dx68UPNIg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit/4.7.0/system.reflection.emit.4.7.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.7.0"; + hash = "sha256-GUnQeGo/DtvZVQpFnESGq7lJcjB30/KnDY7Kd2G/ElE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit.ilgeneration/4.7.0/system.reflection.emit.ilgeneration.4.7.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.7.0"; + hash = "sha256-V0Wz/UUoNIHdTGS9e1TR89u58zJjo/wPUWw6VaVyclU="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.emit.lightweight/4.7.0/system.reflection.emit.lightweight.4.7.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "8.0.0"; + hash = "sha256-dQGC30JauIDWNWXMrSNOJncVa1umR1sijazYwUDdSIE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadata/8.0.0/system.reflection.metadata.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.MetadataLoadContext"; + version = "7.0.0"; + hash = "sha256-VYl6SFD130K9Aw4eJH16ApJ9Sau4Xu0dcxEip2veuTI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadataloadcontext/7.0.0/system.reflection.metadataloadcontext.7.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.MetadataLoadContext"; + version = "8.0.0"; + hash = "sha256-jS5XPZiHjY2CJFnLSxL6U7lMrU3ZknvB4EOgMbG0LEo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadataloadcontext/8.0.0/system.reflection.metadataloadcontext.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.primitives/4.3.0/system.reflection.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Resources.Extensions"; + version = "8.0.0"; + hash = "sha256-5dHZdRwq0tdQanaU5Hw3QISvqSijSGrTa2VdgwifGDI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.extensions/8.0.0/system.resources.extensions.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.resourcemanager/4.3.0/system.resources.resourcemanager.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime/4.3.0/system.runtime.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.compilerservices.unsafe/6.0.0/system.runtime.compilerservices.unsafe.6.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.extensions/4.3.0/system.runtime.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.handles/4.3.0/system.runtime.handles.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices/4.3.0/system.runtime.interopservices.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "5.0.0"; + hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.accesscontrol/5.0.0/system.security.accesscontrol.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Pkcs"; + version = "7.0.2"; + hash = "sha256-qS5Z/Yo8J+f3ExVX5Qkcpj1Z57oUZqz5rWa1h5bVpl8="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.pkcs/7.0.2/system.security.cryptography.pkcs.7.0.2.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "8.0.0"; + hash = "sha256-fb0pa9sQxN+mr0vnXg1Igbx49CaOqS+GDkTfWNboUvs="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.protecteddata/8.0.0/system.security.cryptography.protecteddata.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Xml"; + version = "7.0.1"; + hash = "sha256-CH8+JVC8LyCSW75/6ZQ7ecMbSOAE1c16z4dG8JTp01w="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.xml/7.0.1/system.security.cryptography.xml.7.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Permissions"; + version = "8.0.0"; + hash = "sha256-+YUPY+3HnTmfPLZzr+5qEk0RqalCbFZBgLXee1yCH1M="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.permissions/8.0.0/system.security.permissions.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Principal"; + version = "4.3.0"; + hash = "sha256-rjudVUHdo8pNJg2EVEn0XxxwNo5h2EaYo+QboPkXlYk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.principal/4.3.0/system.security.principal.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.3.0"; + hash = "sha256-mbdLVUcEwe78p3ZnB6jYsizNEqxMaCAWI3tEQNhRQAE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.principal.windows/4.3.0/system.security.principal.windows.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.principal.windows/5.0.0/system.security.principal.windows.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding/4.3.0/system.text.encoding.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "7.0.0"; + hash = "sha256-eCKTVwumD051ZEcoJcDVRGnIGAsEvKpfH3ydKluHxmo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.codepages/7.0.0/system.text.encoding.codepages.7.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.extensions/4.3.0/system.text.encoding.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "8.0.0"; + hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encodings.web/8.0.0/system.text.encodings.web.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "8.0.4"; + hash = "sha256-g5oT7fbXxQ9Iah1nMCr4UUX/a2l+EVjJyTrw3FTbIaI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.json/8.0.4/system.text.json.8.0.4.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading/4.3.0/system.threading.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Channels"; + version = "7.0.0"; + hash = "sha256-Cu0gjQsLIR8Yvh0B4cOPJSYVq10a+3F9pVz/C43CNeM="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.channels/7.0.0/system.threading.channels.7.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Overlapped"; + version = "4.3.0"; + hash = "sha256-tUX099CChkqWiHyP/1e4jGYzZAjgIthMOdMmiOGMUNk="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.overlapped/4.3.0/system.threading.overlapped.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks/4.3.0/system.threading.tasks.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Dataflow"; + version = "8.0.0"; + hash = "sha256-Q6fPtMPNW4+SDKCabJzNS+dw4B04Oxd9sHH505bFtQo="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.dataflow/8.0.0/system.threading.tasks.dataflow.8.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.extensions/4.5.4/system.threading.tasks.extensions.4.5.4.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Thread"; + version = "4.3.0"; + hash = "sha256-pMs6RNFC3nQOGz9EqIcyWmO8YLaqay+q/Qde5hqPXXg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.thread/4.3.0/system.threading.thread.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.ThreadPool"; + version = "4.3.0"; + hash = "sha256-wW0QdvssRoaOfQLazTGSnwYTurE4R8FxDx70pYkL+gg="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.threadpool/4.3.0/system.threading.threadpool.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.ValueTuple"; + version = "4.5.0"; + hash = "sha256-niH6l2fU52vAzuBlwdQMw0OEoRS/7E1w5smBFoqSaAI="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.valuetuple/4.5.0/system.valuetuple.4.5.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Windows.Extensions"; + version = "8.0.0"; + hash = "sha256-aHkz7LtmUDDRS7swQM0i6dDVUytRCMYeA2CfaeVA2Y0="; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.windows.extensions/8.0.0/system.windows.extensions.8.0.0.nupkg"; + }) ] diff --git a/pkgs/by-name/ro/roslyn/deps.nix b/pkgs/by-name/ro/roslyn/deps.nix index 9362f8aab133dc..ca2adee219d3af 100644 --- a/pkgs/by-name/ro/roslyn/deps.nix +++ b/pkgs/by-name/ro/roslyn/deps.nix @@ -1,175 +1,1026 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "dotnet-format"; version = "6.2.315104"; sha256 = "0b802r9xbxibds3dj57ywzl377kyi2h4cmy1iajp82kqbd4707cl"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/825db618-e3eb-4426-ba54-b1d6e6c944d8/nuget/v3/flat2/dotnet-format/6.2.315104/dotnet-format.6.2.315104.nupkg"; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.App.Ref"; version = "3.1.10"; sha256 = "0xn4zh7shvijqlr03fqsmps6gz856isd9bg9rk4z2c4599ggal77"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.aspnetcore.app.ref/3.1.10/microsoft.aspnetcore.app.ref.3.1.10.nupkg"; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; version = "3.1.32"; sha256 = "00ha2sl4gvqv68mbrsizd6ngqy0vv6vamngzjxr338k1w7a276dx"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.aspnetcore.app.runtime.linux-arm64/3.1.32/microsoft.aspnetcore.app.runtime.linux-arm64.3.1.32.nupkg"; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; version = "3.1.32"; sha256 = "0ywz63q8vrdp25ix2j9b7h2jp5grc68hqfl64c6lqk26q9xwhp9r"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.aspnetcore.app.runtime.linux-x64/3.1.32/microsoft.aspnetcore.app.runtime.linux-x64.3.1.32.nupkg"; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; version = "3.1.32"; sha256 = "1crk54a1wvj76s9gnh46pi7wk8ryympm9xh2jq4s4rpp329fqgic"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.aspnetcore.app.runtime.osx-x64/3.1.32/microsoft.aspnetcore.app.runtime.osx-x64.3.1.32.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Framework"; version = "16.5.0"; sha256 = "1xgr02r7s9i6s70n237hss4yi9zicssia3zd2ny6s8vyxb7jpdyb"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.framework/16.5.0/microsoft.build.framework.16.5.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Tasks.Core"; version = "16.5.0"; sha256 = "08mpdcnjbjpsggfzb3plpmjg1jhx2j4zslm8m2p3icnrpw8swxz4"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.tasks.core/16.5.0/microsoft.build.tasks.core.16.5.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Tasks.Git"; version = "1.2.0-beta-22167-02"; sha256 = "1zb5vhlc9kzqbw22hg84hakhqms0aa7ghy585229hsf278rfh2sy"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.build.tasks.git/1.2.0-beta-22167-02/microsoft.build.tasks.git.1.2.0-beta-22167-02.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Build.Utilities.Core"; version = "16.5.0"; sha256 = "127l700qqky1nfrljncrpk7y4f0qi0811kpk2j87659nnv81bxs7"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.utilities.core/16.5.0/microsoft.build.utilities.core.16.5.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.3.3"; sha256 = "09m4cpry8ivm9ga1abrxmvw16sslxhy2k5sl14zckhqb1j164im6"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.analyzers/3.3.3/microsoft.codeanalysis.analyzers.3.3.3.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.BannedApiAnalyzers"; version = "3.3.4-beta1.22160.2"; sha256 = "1g95w9jbwg74f04dif3wbdbcigrx5rwv1ng4g102970l1lbx898b"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/49e5305d-d845-4a14-9d69-6f5dbfb9570c/nuget/v3/flat2/microsoft.codeanalysis.bannedapianalyzers/3.3.4-beta1.22160.2/microsoft.codeanalysis.bannedapianalyzers.3.3.4-beta1.22160.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "3.8.0"; sha256 = "12n7rvr39bzkf2maw7zplw8rwpxpxss4ich3bb2pw770rx4nyvyw"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.common/3.8.0/microsoft.codeanalysis.common.3.8.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.NetAnalyzers"; version = "6.0.0-rc1.21366.2"; sha256 = "18svr40y7c0gv68hv9g9fzd9f8hm7bqwygrwvax3i8cajbfwmzp4"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/825db618-e3eb-4426-ba54-b1d6e6c944d8/nuget/v3/flat2/microsoft.codeanalysis.netanalyzers/6.0.0-rc1.21366.2/microsoft.codeanalysis.netanalyzers.6.0.0-rc1.21366.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.PerformanceSensitiveAnalyzers"; version = "3.3.4-beta1.22160.2"; sha256 = "01jaajr4qmc70dwixzrxyh638wkf5s33hm0km4lwrw4n5j1xivp1"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/e31c6eea-0277-49f3-8194-142be67a9f72/nuget/v3/flat2/microsoft.codeanalysis.performancesensitiveanalyzers/3.3.4-beta1.22160.2/microsoft.codeanalysis.performancesensitiveanalyzers.3.3.4-beta1.22160.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.PublicApiAnalyzers"; version = "3.3.4-beta1.22160.2"; sha256 = "0ih091ls51x5k9q998g14pfy4r3g1ygvzihj1gkrl79wydn7b0n3"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/49e5305d-d845-4a14-9d69-6f5dbfb9570c/nuget/v3/flat2/microsoft.codeanalysis.publicapianalyzers/3.3.4-beta1.22160.2/microsoft.codeanalysis.publicapianalyzers.3.3.4-beta1.22160.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.7.0"; sha256 = "0gd67zlw554j098kabg887b5a6pq9kzavpa3jjy5w53ccjzjfy8j"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.csharp/4.7.0/microsoft.csharp.4.7.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.DiaSymReader.Native"; version = "17.0.0-beta1.21524.1"; sha256 = "0gash3xgzvcb78w2xqv003l0cld199zpfilnjbagwbr5ikdh6f3s"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.diasymreader.native/17.0.0-beta1.21524.1/microsoft.diasymreader.native.17.0.0-beta1.21524.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.DotNet.Arcade.Sdk"; version = "7.0.0-beta.22171.2"; sha256 = "15y26skavivkwhnpfa984if3cnpnllbbwbdsjiyfdcalp32fhmjq"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.dotnet.arcade.sdk/7.0.0-beta.22171.2/microsoft.dotnet.arcade.sdk.7.0.0-beta.22171.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.DotNet.XliffTasks"; version = "1.0.0-beta.22169.1"; sha256 = "12fcin3d4m0lawla9fflz9f2qispzgvzf1mwkpscmlk5lnvb0riw"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.dotnet.xlifftasks/1.0.0-beta.22169.1/microsoft.dotnet.xlifftasks.1.0.0-beta.22169.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Net.Compilers.Toolset"; version = "4.2.0-1.final"; sha256 = "02zas22hj29gv2w7h74q786i0cvxffgwqai21ri0zj41nb2hwhyq"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.net.compilers.toolset/4.2.0-1.final/microsoft.net.compilers.toolset.4.2.0-1.final.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Host.linux-arm64"; version = "3.1.32"; sha256 = "1zygp70xrk5zggs3q4a6yc6jfdwzcsjjsapqpwn6qyx35m69b72p"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.host.linux-arm64/3.1.32/microsoft.netcore.app.host.linux-arm64.3.1.32.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Host.linux-x64"; version = "3.1.32"; sha256 = "08sar3s7j6z1q5prjmz2jrbsq5ms81mrsi1c1zbfrkplkfjpld3a"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.host.linux-x64/3.1.32/microsoft.netcore.app.host.linux-x64.3.1.32.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Host.osx-x64"; version = "3.1.32"; sha256 = "186gjn8sbhp4z6pq8fw4g8nqk9dwyaplwvdz2y3fbbvg36lggsh0"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.host.osx-x64/3.1.32/microsoft.netcore.app.host.osx-x64.3.1.32.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Ref"; version = "3.1.0"; sha256 = "08svsiilx9spvjamcnjswv0dlpdrgryhr3asdz7cvnl914gjzq4y"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.ref/3.1.0/microsoft.netcore.app.ref.3.1.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; version = "3.1.32"; sha256 = "13pcn74z1swz73s72zjl07f118j35wacnzgk7kbjqn83nwgqdgvq"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.runtime.linux-arm64/3.1.32/microsoft.netcore.app.runtime.linux-arm64.3.1.32.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Runtime.linux-x64"; version = "3.1.32"; sha256 = "0mmc57dl8plrspdxwb7209wz29vhiwqds4nfbdfws7zg35yy70c7"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.runtime.linux-x64/3.1.32/microsoft.netcore.app.runtime.linux-x64.3.1.32.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Runtime.osx-x64"; version = "3.1.32"; sha256 = "06bk39zcv27cwshjsxfg5d6wzkkzdhfk08sipdc7mr1s8pk7ihi1"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.runtime.osx-x64/3.1.32/microsoft.netcore.app.runtime.osx-x64.3.1.32.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.0.1"; sha256 = "01al6cfxp68dscl15z7rxfw9zvhm64dncsw09a1vmdkacsa2v6lr"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/1.0.1/microsoft.netcore.platforms.1.0.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/1.1.0/microsoft.netcore.platforms.1.1.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.1"; sha256 = "164wycgng4mi9zqi2pnsf1pq6gccbqvw6ib916mqizgjmd8f44pj"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/1.1.1/microsoft.netcore.platforms.1.1.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "5.0.0"; sha256 = "0mwpwdflidzgzfx2dlpkvvnkgkr2ayaf0s80737h4wa35gaj11rc"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/5.0.0/microsoft.netcore.platforms.5.0.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.0.1"; sha256 = "0ppdkwy6s9p7x9jix3v4402wb171cdiibq7js7i13nxpdky7074p"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.targets/1.0.1/microsoft.netcore.targets.1.0.1.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.targets/1.1.0/microsoft.netcore.targets.1.1.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies"; version = "1.0.2"; sha256 = "0i42rn8xmvhn08799manpym06kpw89qy9080myyy2ngy565pqh0a"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies/1.0.2/microsoft.netframework.referenceassemblies.1.0.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies.net472"; version = "1.0.2"; sha256 = "1dny43jksy6dm9zrkdm8j80gb25w6wdvjlxnphj7ngf0fbg3dd2c"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies.net472/1.0.2/microsoft.netframework.referenceassemblies.net472.1.0.2.nupkg"; }) - (fetchNuGet { pname = "Microsoft.SourceLink.AzureRepos.Git"; version = "1.2.0-beta-22167-02"; sha256 = "1mqzajvp0xa8smhilrakp9nr18r2lbqgn0jb79443srvjf93f6sl"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.sourcelink.azurerepos.git/1.2.0-beta-22167-02/microsoft.sourcelink.azurerepos.git.1.2.0-beta-22167-02.nupkg"; }) - (fetchNuGet { pname = "Microsoft.SourceLink.Common"; version = "1.2.0-beta-22167-02"; sha256 = "1s4x6syw1vfs0wrlyjvf5n7xiqgqnyv9cmmnaxzmx41f7zydirj6"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.sourcelink.common/1.2.0-beta-22167-02/microsoft.sourcelink.common.1.2.0-beta-22167-02.nupkg"; }) - (fetchNuGet { pname = "Microsoft.SourceLink.GitHub"; version = "1.2.0-beta-22167-02"; sha256 = "0zwc5sxvcz26rcyirrbd55cnz1v7s0njlj91jk3rdjxw6aw2bgnr"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.sourcelink.github/1.2.0-beta-22167-02/microsoft.sourcelink.github.1.2.0-beta-22167-02.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Setup.Configuration.Interop"; version = "1.16.30"; sha256 = "14022lx03vdcqlvbbdmbsxg5pqfx1rfq2jywxlyaz9v68cvsb0g4"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.setup.configuration.interop/1.16.30/microsoft.visualstudio.setup.configuration.interop.1.16.30.nupkg"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Threading.Analyzers"; version = "17.2.20-alpha"; sha256 = "199690hc75yb01npwjwb7mdch0syrczcxyx6mphm1hn2cm108qax"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.threading.analyzers/17.2.20-alpha/microsoft.visualstudio.threading.analyzers.17.2.20-alpha.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.3.0"; sha256 = "0j0c1wj4ndj21zsgivsc24whiya605603kxrbiw6wkfdync464wq"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.primitives/4.3.0/microsoft.win32.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "4.3.0"; sha256 = "1gxyzxam8163vk1kb6xzxjj4iwspjsz9zhgn1w9rjzciphaz0ig7"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.registry/4.3.0/microsoft.win32.registry.4.3.0.nupkg"; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; sha256 = "1fn9fxppfcg4jgypp2pmrpr6awl3qz1xmnri0cygpkwvyx27df1y"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/netstandard.library/2.0.3/netstandard.library.2.0.3.nupkg"; }) - (fetchNuGet { pname = "PowerShell"; version = "7.0.0"; sha256 = "13jhnbh12rcmdrkmlxq45ard03lmfq7bg14xg7k108jlpnpsr1la"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/powershell/7.0.0/powershell.7.0.0.nupkg"; }) - (fetchNuGet { pname = "RichCodeNav.EnvVarDump"; version = "0.1.1643-alpha"; sha256 = "1pp1608xizvv0h9q01bqy7isd3yzb3lxb2yp27j4k25xsvw460vg"; url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/58ca65bb-e6c1-4210-88ac-fa55c1cd7877/nuget/v3/flat2/richcodenav.envvardump/0.1.1643-alpha/richcodenav.envvardump.0.1.1643-alpha.nupkg"; }) - (fetchNuGet { pname = "Roslyn.Diagnostics.Analyzers"; version = "3.3.4-beta1.22160.2"; sha256 = "0rr7q46vc5lbywm3mf4ld1kjkg9w7fbmkkyka0bi8idrfib7kn0i"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/49e5305d-d845-4a14-9d69-6f5dbfb9570c/nuget/v3/flat2/roslyn.diagnostics.analyzers/3.3.4-beta1.22160.2/roslyn.diagnostics.analyzers.3.3.4-beta1.22160.2.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.collections/4.3.0/runtime.any.system.collections.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tracing"; version = "4.3.0"; sha256 = "00j6nv2xgmd3bi347k00m7wr542wjlig53rmj28pmw7ddcn97jbn"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.diagnostics.tracing/4.3.0/runtime.any.system.diagnostics.tracing.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.globalization/4.3.0/runtime.any.system.globalization.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization.Calendars"; version = "4.3.0"; sha256 = "1ghhhk5psqxcg6w88sxkqrc35bxcz27zbqm2y5p5298pv3v7g201"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.globalization.calendars/4.3.0/runtime.any.system.globalization.calendars.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.io/4.3.0/runtime.any.system.io.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.reflection/4.3.0/runtime.any.system.reflection.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.reflection.primitives/4.3.0/runtime.any.system.reflection.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.resources.resourcemanager/4.3.0/runtime.any.system.resources.resourcemanager.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.runtime/4.3.0/runtime.any.system.runtime.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.runtime.handles/4.3.0/runtime.any.system.runtime.handles.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.runtime.interopservices/4.3.0/runtime.any.system.runtime.interopservices.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.text.encoding/4.3.0/runtime.any.system.text.encoding.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.text.encoding.extensions/4.3.0/runtime.any.system.text.encoding.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.threading.tasks/4.3.0/runtime.any.system.threading.tasks.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "16rnxzpk5dpbbl1x354yrlsbvwylrq456xzpsha1n9y3glnhyx9d"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0rwpqngkqiapqc5c2cpkj7idhngrgss5qpnqg0yh40mbyflcxf8i"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0hkg03sgm2wyq8nqk6dbm9jh5vcq57ry42lkqdmfklrw89lsmr59"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1n06gxwlinhs0w7s8a94r1q3lwqzvynxwd3mp10ws9bg6gck8n4r"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0c2p354hjx58xhhz7wv6div8xpi90sc6ibdm40qin21bvi7ymcaa"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0404wqrc7f2yc0wxv71y3nnybvqx8v4j9d47hlscxy759a525mc3"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system/4.3.0/runtime.native.system.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.native.System.Net.Http"; version = "4.3.0"; sha256 = "1n6rgz5132lcibbch1qlf0g9jk60r0kqv087hxc0lisy50zpm7kk"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.net.http/4.3.0/runtime.native.system.net.http.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; sha256 = "1b61p6gw1m02cc1ry996fl49liiwky6181dzr873g9ds92zl326q"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.security.cryptography.apple/4.3.0/runtime.native.system.security.cryptography.apple.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "18pzfdlwsg2nb1jjjjzyb5qlgy6xjxzmhnfaijq5s2jw3cm3ab97"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.security.cryptography.openssl/4.3.0/runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0zy5r25jppz48i2bkg8b9lfig24xixg6nm3xyr1379zdnqnpm8f6"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.security.cryptography.openssl/4.3.2/runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0qyynf9nz5i7pc26cwhgi8j62ps27sqmf78ijcfgzab50z9g8ay3"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "096ch4n4s8k82xga80lfmpimpzahd2ip1mgwdqgar0ywbbl6x438"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "1klrs545awhayryma6l7g2pvnp9xy4z0r1i40r80zb45q3i9nbyf"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1dm8fifl7rf1gy7lnwln78ch4rw54g0pl5g1c189vawavll7p6rj"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; sha256 = "10yc8jdrwgcl44b4g93f1ds76b176bajd3zqi2faf5rvh1vy9smi"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.apple/4.3.0/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.apple.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0zcxjv5pckplvkg0r6mw3asggm7aqzbdjimhvsasb0cgm59x09l3"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1m9z1k9kzva9n9kwinqxl97x2vgl79qhqjlv17k9s2ymcyv2bwr6"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0vhynn79ih7hw7cwjazn87rm9z9fj0rvxgzlab36jybgcpcgphsn"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1cpx56mcfxz7cpn57wvj18sjisvzq8b5vd9rw16ihd2i6mcp3wa1"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "160p68l2c7cqmyqjwxydcvgw7lvl1cr0znkw8fp24d1by9mqc8p3"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "15gsm1a8jdmgmf8j5v1slfz8ks124nfdhk2vxs2rw3asrxalg8hi"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "15zrc8fgd8zx28hdghcj5f5i34wf3l6bq5177075m2bc2j34jrqy"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0q0n5q1r1wnqmr5i5idsrd9ywl33k0js4pngkwq9p368mbxp8x1w"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "1p4dgxax6p7rlgj4q73k73rslcnz4wdcv8q2flg1s8ygwcm58ld5"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1x0g58pbpjrmj2x2qw17rdwwnrcl0wvim2hdwz48lixvwvp22n9c"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.Microsoft.Win32.Primitives"; version = "4.3.0"; sha256 = "0y61k9zbxhdi0glg154v30kkq7f8646nif8lnnxbvkjpakggd5id"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.microsoft.win32.primitives/4.3.0/runtime.unix.microsoft.win32.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.diagnostics.debug/4.3.0/runtime.unix.system.diagnostics.debug.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.System.IO.FileSystem"; version = "4.3.0"; sha256 = "14nbkhvs7sji5r1saj2x8daz82rnf9kx28d3v2qss34qbr32dzix"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.io.filesystem/4.3.0/runtime.unix.system.io.filesystem.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Primitives"; version = "4.3.0"; sha256 = "0bdnglg59pzx9394sy4ic66kmxhqp8q8bvmykdxcbs5mm0ipwwm4"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.net.primitives/4.3.0/runtime.unix.system.net.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.private.uri/4.3.0/runtime.unix.system.private.uri.4.3.0.nupkg"; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.runtime.extensions/4.3.0/runtime.unix.system.runtime.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.3.0"; sha256 = "0fgns20ispwrfqll4q1zc1waqcmylb3zc50ys9x8zlwxh9pmd9jy"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.3.0/system.buffers.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.5.1/system.buffers.4.5.1.nupkg"; }) - (fetchNuGet { pname = "System.CodeDom"; version = "4.4.0"; sha256 = "1zgbafm5p380r50ap5iddp11kzhr9khrf2pnai6k593wjar74p1g"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.codedom/4.4.0/system.codedom.4.4.0.nupkg"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.0.11"; sha256 = "1ga40f5lrwldiyw6vy67d0sg7jd7ww6kgwbksm19wrvq9hr0bsm6"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections/4.0.11/system.collections.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections/4.3.0/system.collections.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.0.12"; sha256 = "07y08kvrzpak873pmyxs129g1ch8l27zmg51pcyj2jvq03n0r0fc"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.concurrent/4.0.12/system.collections.concurrent.4.0.12.nupkg"; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.3.0"; sha256 = "0wi10md9aq33jrkh2c24wr2n9hrpyamsdhsxdcnf43b7y86kkii8"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.concurrent/4.3.0/system.collections.concurrent.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "1.5.0"; sha256 = "1d5gjn5afnrf461jlxzawcvihz195gayqpcfbv6dd7pxa9ialn06"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.immutable/1.5.0/system.collections.immutable.1.5.0.nupkg"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "5.0.0"; sha256 = "1kvcllagxz2q92g81zkz81djkn2lid25ayjfgjalncyc68i15p0r"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.immutable/5.0.0/system.collections.immutable.5.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.0.11"; sha256 = "0gmjghrqmlgzxivd2xl50ncbglb7ljzb66rlx8ws6dv8jm0d5siz"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.debug/4.0.11/system.diagnostics.debug.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.debug/4.3.0/system.diagnostics.debug.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "4.3.0"; sha256 = "0z6m3pbiy0qw6rn3n209rrzf9x1k4002zh90vwcrsym09ipm2liq"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.diagnosticsource/4.3.0/system.diagnostics.diagnosticsource.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.1.0"; sha256 = "1d2r76v1x610x61ahfpigda89gd13qydz6vbwzhpqlyvq8jj6394"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracing/4.1.0/system.diagnostics.tracing.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; sha256 = "1m3bx6c2s958qligl67q7grkwfz3w53hpy7nc97mh6f7j5k168c4"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracing/4.3.0/system.diagnostics.tracing.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.0.11"; sha256 = "070c5jbas2v7smm660zaf1gh0489xanjqymkvafcs4f8cdrs1d5d"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization/4.0.11/system.globalization.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization/4.3.0/system.globalization.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.3.0"; sha256 = "1xwl230bkakzzkrggy1l1lxmm3xlhk4bq2pkv790j5lm8g887lxq"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization.calendars/4.3.0/system.globalization.calendars.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Globalization.Extensions"; version = "4.3.0"; sha256 = "02a5zfxavhv3jd437bsncbhd2fp1zv4gxzakp1an9l6kdq1mcqls"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization.extensions/4.3.0/system.globalization.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO"; version = "4.1.0"; sha256 = "1g0yb8p11vfd0kbkyzlfsbsp5z44lwsvyc0h3dpw6vqnbi035ajp"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io/4.1.0/system.io.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io/4.3.0/system.io.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; sha256 = "0z2dfrbra9i6y16mm9v1v6k47f0fm617vlb7s5iybjjsz6g1ilmw"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem/4.3.0/system.io.filesystem.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem.primitives/4.3.0/system.io.filesystem.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.IO.Pipes.AccessControl"; version = "5.0.0"; sha256 = "0jl5b95cy8biivi1kdn2wi0gy2m1a0gyj8fy88djybrg2705c8fz"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.pipes.accesscontrol/5.0.0/system.io.pipes.accesscontrol.5.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Linq"; version = "4.1.0"; sha256 = "1ppg83svb39hj4hpp5k7kcryzrf3sfnm08vxd5sm2drrijsla2k5"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.linq/4.1.0/system.linq.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.linq/4.3.0/system.linq.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Linq.Parallel"; version = "4.0.1"; sha256 = "0i33x9f4h3yq26yvv6xnq4b0v51rl5z8v1bm7vk972h5lvf4apad"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.linq.parallel/4.0.1/system.linq.parallel.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.memory/4.5.4/system.memory.4.5.4.nupkg"; }) - (fetchNuGet { pname = "System.Net.Http"; version = "4.3.4"; sha256 = "0kdp31b8819v88l719j6my0yas6myv9d1viql3qz5577mv819jhl"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.http/4.3.4/system.net.http.4.3.4.nupkg"; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.3.0"; sha256 = "0c87k50rmdgmxx7df2khd9qj7q35j9rzdmm2572cc55dygmdk3ii"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.primitives/4.3.0/system.net.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.4.0"; sha256 = "0rdvma399070b0i46c4qq1h2yvjj3k013sqzkilz4bz5cwmx1rba"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.numerics.vectors/4.4.0/system.numerics.vectors.4.4.0.nupkg"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; sha256 = "1kzrj37yzawf1b19jq0253rcs8hsq1l2q8g69d7ipnhzb0h97m59"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.numerics.vectors/4.5.0/system.numerics.vectors.4.5.0.nupkg"; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.private.uri/4.3.0/system.private.uri.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.1.0"; sha256 = "1js89429pfw79mxvbzp8p3q93il6rdff332hddhzi5wqglc4gml9"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection/4.1.0/system.reflection.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection/4.3.0/system.reflection.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "1.6.0"; sha256 = "1wdbavrrkajy7qbdblpbpbalbdl48q3h34cchz24gvdgyrlf15r4"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadata/1.6.0/system.reflection.metadata.1.6.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "5.0.0"; sha256 = "17qsl5nanlqk9iz0l5wijdn6ka632fs1m1fvx18dfgswm258r3ss"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadata/5.0.0/system.reflection.metadata.5.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.0.1"; sha256 = "1bangaabhsl4k9fg8khn83wm6yial8ik1sza7401621jc6jrym28"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.primitives/4.0.1/system.reflection.primitives.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.primitives/4.3.0/system.reflection.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.1.0"; sha256 = "1bjli8a7sc7jlxqgcagl9nh8axzfl11f4ld3rjqsyxc516iijij7"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.typeextensions/4.1.0/system.reflection.typeextensions.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Resources.Extensions"; version = "4.6.0"; sha256 = "0inch9jgchgmsg3xjivbhh9mpin40mhdd8dgf4i1p3g42i0hzc0j"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.extensions/4.6.0/system.resources.extensions.4.6.0.nupkg"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.0.1"; sha256 = "0b4i7mncaf8cnai85jv3wnw6hps140cxz8vylv2bik6wyzgvz7bi"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.resourcemanager/4.0.1/system.resources.resourcemanager.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.resourcemanager/4.3.0/system.resources.resourcemanager.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Resources.Writer"; version = "4.0.0"; sha256 = "07hp218kjdcvpl27djspnixgnacbp9apma61zz3wsca9fx5g3lmv"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.writer/4.0.0/system.resources.writer.4.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.1.0"; sha256 = "02hdkgk13rvsd6r9yafbwzss8kr55wnj8d5c7xjnp8gqrwc8sn0m"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime/4.1.0/system.runtime.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime/4.3.0/system.runtime.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.7.1"; sha256 = "119br3pd85lq8zcgh4f60jzmv1g976q1kdgi3hvqdlhfbw6siz2j"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.compilerservices.unsafe/4.7.1/system.runtime.compilerservices.unsafe.4.7.1.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.compilerservices.unsafe/6.0.0/system.runtime.compilerservices.unsafe.6.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.1.0"; sha256 = "0rw4rm4vsm3h3szxp9iijc3ksyviwsv6f63dng3vhqyg4vjdkc2z"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.extensions/4.1.0/system.runtime.extensions.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.extensions/4.3.0/system.runtime.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.0.1"; sha256 = "1g0zrdi5508v49pfm3iii2hn6nm00bgvfpjq1zxknfjrxxa20r4g"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.handles/4.0.1/system.runtime.handles.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.handles/4.3.0/system.runtime.handles.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.1.0"; sha256 = "01kxqppx3dr3b6b286xafqilv4s2n0gqvfgzfd4z943ga9i81is1"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices/4.1.0/system.runtime.interopservices.4.1.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices/4.3.0/system.runtime.interopservices.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Loader"; version = "4.3.0"; sha256 = "07fgipa93g1xxgf7193a6vw677mpzgr0z0cfswbvqqb364cva8dk"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.loader/4.3.0/system.runtime.loader.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.3.0"; sha256 = "19rav39sr5dky7afygh309qamqqmi9kcwvz3i0c5700v0c5cg61z"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.numerics/4.3.0/system.runtime.numerics.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Runtime.Serialization.Primitives"; version = "4.1.1"; sha256 = "042rfjixknlr6r10vx2pgf56yming8lkjikamg3g4v29ikk78h7k"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.serialization.primitives/4.1.1/system.runtime.serialization.primitives.4.1.1.nupkg"; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "5.0.0"; sha256 = "17n3lrrl6vahkqmhlpn3w20afgz09n7i6rv0r3qypngwi7wqdr5r"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.accesscontrol/5.0.0/system.security.accesscontrol.5.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.3.0"; sha256 = "03sq183pfl5kp7gkvq77myv7kbpdnq3y0xj7vi4q1kaw54sny0ml"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.algorithms/4.3.0/system.security.cryptography.algorithms.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.3.0"; sha256 = "1k468aswafdgf56ab6yrn7649kfqx2wm9aslywjam1hdmk5yypmv"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.cng/4.3.0/system.security.cryptography.cng.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Csp"; version = "4.3.0"; sha256 = "1x5wcrddf2s3hb8j78cry7yalca4lb5vfnkrysagbn6r9x6xvrx1"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.csp/4.3.0/system.security.cryptography.csp.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.3.0"; sha256 = "1jr6w70igqn07k5zs1ph6xja97hxnb3mqbspdrff6cvssgrixs32"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.encoding/4.3.0/system.security.cryptography.encoding.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0givpvvj8yc7gv4lhb6s1prq6p2c4147204a0wib89inqzd87gqc"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.openssl/4.3.0/system.security.cryptography.openssl.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.3.0"; sha256 = "0pyzncsv48zwly3lw4f2dayqswcfvdwq2nz0dgwmi7fj3pn64wby"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.primitives/4.3.0/system.security.cryptography.primitives.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.3.0"; sha256 = "0valjcz5wksbvijylxijjxb1mp38mdhv03r533vnx1q3ikzdav9h"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.x509certificates/4.3.0/system.security.cryptography.x509certificates.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; sha256 = "1mpk7xj76lxgz97a5yg93wi8lj0l8p157a5d50mmjy3gbz1904q8"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.principal.windows/5.0.0/system.security.principal.windows.5.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.0.11"; sha256 = "1dyqv0hijg265dwxg6l7aiv74102d6xjiwplh2ar1ly6xfaa4iiw"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding/4.0.11/system.text.encoding.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding/4.3.0/system.text.encoding.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "4.0.1"; sha256 = "00wpm3b9y0k996rm9whxprngm8l500ajmzgy2ip9pgwk0icp06y3"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.codepages/4.0.1/system.text.encoding.codepages.4.0.1.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "4.5.1"; sha256 = "1z21qyfs6sg76rp68qdx0c9iy57naan89pg7p6i3qpj8kyzn921w"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.codepages/4.5.1/system.text.encoding.codepages.4.5.1.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "6.0.0"; sha256 = "0gm2kiz2ndm9xyzxgi0jhazgwslcs427waxgfa30m7yqll1kcrww"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.codepages/6.0.0/system.text.encoding.codepages.6.0.0.nupkg"; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.extensions/4.3.0/system.text.encoding.extensions.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.0.11"; sha256 = "19x946h926bzvbsgj28csn46gak2crv2skpwsx80hbgazmkgb1ls"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading/4.0.11/system.threading.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading/4.3.0/system.threading.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.0.11"; sha256 = "0nr1r41rak82qfa5m0lhk9mp0k93bvfd7bbd9sdzwx9mb36g28p5"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks/4.0.11/system.threading.tasks.4.0.11.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks/4.3.0/system.threading.tasks.4.3.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Dataflow"; version = "4.9.0"; sha256 = "1g6s9pjg4z8iy98df60y9a01imdqy59zd767vz74rrng78jl2dk5"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.dataflow/4.9.0/system.threading.tasks.dataflow.4.9.0.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; sha256 = "0y6ncasgfcgnjrhynaf0lwpkpkmv4a07sswwkwbwb5h7riisj153"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.extensions/4.5.4/system.threading.tasks.extensions.4.5.4.nupkg"; }) - (fetchNuGet { pname = "System.Threading.Thread"; version = "4.0.0"; sha256 = "1gxxm5fl36pjjpnx1k688dcw8m9l7nmf802nxis6swdaw8k54jzc"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.thread/4.0.0/system.threading.thread.4.0.0.nupkg"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "dotnet-format"; + version = "6.2.315104"; + sha256 = "0b802r9xbxibds3dj57ywzl377kyi2h4cmy1iajp82kqbd4707cl"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/825db618-e3eb-4426-ba54-b1d6e6c944d8/nuget/v3/flat2/dotnet-format/6.2.315104/dotnet-format.6.2.315104.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.App.Ref"; + version = "3.1.10"; + sha256 = "0xn4zh7shvijqlr03fqsmps6gz856isd9bg9rk4z2c4599ggal77"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.aspnetcore.app.ref/3.1.10/microsoft.aspnetcore.app.ref.3.1.10.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; + version = "3.1.32"; + sha256 = "00ha2sl4gvqv68mbrsizd6ngqy0vv6vamngzjxr338k1w7a276dx"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.aspnetcore.app.runtime.linux-arm64/3.1.32/microsoft.aspnetcore.app.runtime.linux-arm64.3.1.32.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; + version = "3.1.32"; + sha256 = "0ywz63q8vrdp25ix2j9b7h2jp5grc68hqfl64c6lqk26q9xwhp9r"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.aspnetcore.app.runtime.linux-x64/3.1.32/microsoft.aspnetcore.app.runtime.linux-x64.3.1.32.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; + version = "3.1.32"; + sha256 = "1crk54a1wvj76s9gnh46pi7wk8ryympm9xh2jq4s4rpp329fqgic"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.aspnetcore.app.runtime.osx-x64/3.1.32/microsoft.aspnetcore.app.runtime.osx-x64.3.1.32.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Framework"; + version = "16.5.0"; + sha256 = "1xgr02r7s9i6s70n237hss4yi9zicssia3zd2ny6s8vyxb7jpdyb"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.framework/16.5.0/microsoft.build.framework.16.5.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Tasks.Core"; + version = "16.5.0"; + sha256 = "08mpdcnjbjpsggfzb3plpmjg1jhx2j4zslm8m2p3icnrpw8swxz4"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.tasks.core/16.5.0/microsoft.build.tasks.core.16.5.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Tasks.Git"; + version = "1.2.0-beta-22167-02"; + sha256 = "1zb5vhlc9kzqbw22hg84hakhqms0aa7ghy585229hsf278rfh2sy"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.build.tasks.git/1.2.0-beta-22167-02/microsoft.build.tasks.git.1.2.0-beta-22167-02.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Utilities.Core"; + version = "16.5.0"; + sha256 = "127l700qqky1nfrljncrpk7y4f0qi0811kpk2j87659nnv81bxs7"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.build.utilities.core/16.5.0/microsoft.build.utilities.core.16.5.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.3.3"; + sha256 = "09m4cpry8ivm9ga1abrxmvw16sslxhy2k5sl14zckhqb1j164im6"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.analyzers/3.3.3/microsoft.codeanalysis.analyzers.3.3.3.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.BannedApiAnalyzers"; + version = "3.3.4-beta1.22160.2"; + sha256 = "1g95w9jbwg74f04dif3wbdbcigrx5rwv1ng4g102970l1lbx898b"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/49e5305d-d845-4a14-9d69-6f5dbfb9570c/nuget/v3/flat2/microsoft.codeanalysis.bannedapianalyzers/3.3.4-beta1.22160.2/microsoft.codeanalysis.bannedapianalyzers.3.3.4-beta1.22160.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "3.8.0"; + sha256 = "12n7rvr39bzkf2maw7zplw8rwpxpxss4ich3bb2pw770rx4nyvyw"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.codeanalysis.common/3.8.0/microsoft.codeanalysis.common.3.8.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.NetAnalyzers"; + version = "6.0.0-rc1.21366.2"; + sha256 = "18svr40y7c0gv68hv9g9fzd9f8hm7bqwygrwvax3i8cajbfwmzp4"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/825db618-e3eb-4426-ba54-b1d6e6c944d8/nuget/v3/flat2/microsoft.codeanalysis.netanalyzers/6.0.0-rc1.21366.2/microsoft.codeanalysis.netanalyzers.6.0.0-rc1.21366.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.PerformanceSensitiveAnalyzers"; + version = "3.3.4-beta1.22160.2"; + sha256 = "01jaajr4qmc70dwixzrxyh638wkf5s33hm0km4lwrw4n5j1xivp1"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/e31c6eea-0277-49f3-8194-142be67a9f72/nuget/v3/flat2/microsoft.codeanalysis.performancesensitiveanalyzers/3.3.4-beta1.22160.2/microsoft.codeanalysis.performancesensitiveanalyzers.3.3.4-beta1.22160.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.PublicApiAnalyzers"; + version = "3.3.4-beta1.22160.2"; + sha256 = "0ih091ls51x5k9q998g14pfy4r3g1ygvzihj1gkrl79wydn7b0n3"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/49e5305d-d845-4a14-9d69-6f5dbfb9570c/nuget/v3/flat2/microsoft.codeanalysis.publicapianalyzers/3.3.4-beta1.22160.2/microsoft.codeanalysis.publicapianalyzers.3.3.4-beta1.22160.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.7.0"; + sha256 = "0gd67zlw554j098kabg887b5a6pq9kzavpa3jjy5w53ccjzjfy8j"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.csharp/4.7.0/microsoft.csharp.4.7.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.DiaSymReader.Native"; + version = "17.0.0-beta1.21524.1"; + sha256 = "0gash3xgzvcb78w2xqv003l0cld199zpfilnjbagwbr5ikdh6f3s"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.diasymreader.native/17.0.0-beta1.21524.1/microsoft.diasymreader.native.17.0.0-beta1.21524.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.Arcade.Sdk"; + version = "7.0.0-beta.22171.2"; + sha256 = "15y26skavivkwhnpfa984if3cnpnllbbwbdsjiyfdcalp32fhmjq"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.dotnet.arcade.sdk/7.0.0-beta.22171.2/microsoft.dotnet.arcade.sdk.7.0.0-beta.22171.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.XliffTasks"; + version = "1.0.0-beta.22169.1"; + sha256 = "12fcin3d4m0lawla9fflz9f2qispzgvzf1mwkpscmlk5lnvb0riw"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/1a5f89f6-d8da-4080-b15f-242650c914a8/nuget/v3/flat2/microsoft.dotnet.xlifftasks/1.0.0-beta.22169.1/microsoft.dotnet.xlifftasks.1.0.0-beta.22169.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Net.Compilers.Toolset"; + version = "4.2.0-1.final"; + sha256 = "02zas22hj29gv2w7h74q786i0cvxffgwqai21ri0zj41nb2hwhyq"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.net.compilers.toolset/4.2.0-1.final/microsoft.net.compilers.toolset.4.2.0-1.final.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Host.linux-arm64"; + version = "3.1.32"; + sha256 = "1zygp70xrk5zggs3q4a6yc6jfdwzcsjjsapqpwn6qyx35m69b72p"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.host.linux-arm64/3.1.32/microsoft.netcore.app.host.linux-arm64.3.1.32.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Host.linux-x64"; + version = "3.1.32"; + sha256 = "08sar3s7j6z1q5prjmz2jrbsq5ms81mrsi1c1zbfrkplkfjpld3a"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.host.linux-x64/3.1.32/microsoft.netcore.app.host.linux-x64.3.1.32.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Host.osx-x64"; + version = "3.1.32"; + sha256 = "186gjn8sbhp4z6pq8fw4g8nqk9dwyaplwvdz2y3fbbvg36lggsh0"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.host.osx-x64/3.1.32/microsoft.netcore.app.host.osx-x64.3.1.32.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Ref"; + version = "3.1.0"; + sha256 = "08svsiilx9spvjamcnjswv0dlpdrgryhr3asdz7cvnl914gjzq4y"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.ref/3.1.0/microsoft.netcore.app.ref.3.1.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; + version = "3.1.32"; + sha256 = "13pcn74z1swz73s72zjl07f118j35wacnzgk7kbjqn83nwgqdgvq"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.runtime.linux-arm64/3.1.32/microsoft.netcore.app.runtime.linux-arm64.3.1.32.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Runtime.linux-x64"; + version = "3.1.32"; + sha256 = "0mmc57dl8plrspdxwb7209wz29vhiwqds4nfbdfws7zg35yy70c7"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.runtime.linux-x64/3.1.32/microsoft.netcore.app.runtime.linux-x64.3.1.32.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Runtime.osx-x64"; + version = "3.1.32"; + sha256 = "06bk39zcv27cwshjsxfg5d6wzkkzdhfk08sipdc7mr1s8pk7ihi1"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.app.runtime.osx-x64/3.1.32/microsoft.netcore.app.runtime.osx-x64.3.1.32.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.0.1"; + sha256 = "01al6cfxp68dscl15z7rxfw9zvhm64dncsw09a1vmdkacsa2v6lr"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/1.0.1/microsoft.netcore.platforms.1.0.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/1.1.0/microsoft.netcore.platforms.1.1.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.1"; + sha256 = "164wycgng4mi9zqi2pnsf1pq6gccbqvw6ib916mqizgjmd8f44pj"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/1.1.1/microsoft.netcore.platforms.1.1.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "5.0.0"; + sha256 = "0mwpwdflidzgzfx2dlpkvvnkgkr2ayaf0s80737h4wa35gaj11rc"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.platforms/5.0.0/microsoft.netcore.platforms.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.0.1"; + sha256 = "0ppdkwy6s9p7x9jix3v4402wb171cdiibq7js7i13nxpdky7074p"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.targets/1.0.1/microsoft.netcore.targets.1.0.1.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netcore.targets/1.1.0/microsoft.netcore.targets.1.1.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies"; + version = "1.0.2"; + sha256 = "0i42rn8xmvhn08799manpym06kpw89qy9080myyy2ngy565pqh0a"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies/1.0.2/microsoft.netframework.referenceassemblies.1.0.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies.net472"; + version = "1.0.2"; + sha256 = "1dny43jksy6dm9zrkdm8j80gb25w6wdvjlxnphj7ngf0fbg3dd2c"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.netframework.referenceassemblies.net472/1.0.2/microsoft.netframework.referenceassemblies.net472.1.0.2.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.SourceLink.AzureRepos.Git"; + version = "1.2.0-beta-22167-02"; + sha256 = "1mqzajvp0xa8smhilrakp9nr18r2lbqgn0jb79443srvjf93f6sl"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.sourcelink.azurerepos.git/1.2.0-beta-22167-02/microsoft.sourcelink.azurerepos.git.1.2.0-beta-22167-02.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.SourceLink.Common"; + version = "1.2.0-beta-22167-02"; + sha256 = "1s4x6syw1vfs0wrlyjvf5n7xiqgqnyv9cmmnaxzmx41f7zydirj6"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.sourcelink.common/1.2.0-beta-22167-02/microsoft.sourcelink.common.1.2.0-beta-22167-02.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.SourceLink.GitHub"; + version = "1.2.0-beta-22167-02"; + sha256 = "0zwc5sxvcz26rcyirrbd55cnz1v7s0njlj91jk3rdjxw6aw2bgnr"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/d1622942-d16f-48e5-bc83-96f4539e7601/nuget/v3/flat2/microsoft.sourcelink.github/1.2.0-beta-22167-02/microsoft.sourcelink.github.1.2.0-beta-22167-02.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Setup.Configuration.Interop"; + version = "1.16.30"; + sha256 = "14022lx03vdcqlvbbdmbsxg5pqfx1rfq2jywxlyaz9v68cvsb0g4"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.setup.configuration.interop/1.16.30/microsoft.visualstudio.setup.configuration.interop.1.16.30.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Threading.Analyzers"; + version = "17.2.20-alpha"; + sha256 = "199690hc75yb01npwjwb7mdch0syrczcxyx6mphm1hn2cm108qax"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.visualstudio.threading.analyzers/17.2.20-alpha/microsoft.visualstudio.threading.analyzers.17.2.20-alpha.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.3.0"; + sha256 = "0j0c1wj4ndj21zsgivsc24whiya605603kxrbiw6wkfdync464wq"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.primitives/4.3.0/microsoft.win32.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "4.3.0"; + sha256 = "1gxyzxam8163vk1kb6xzxjj4iwspjsz9zhgn1w9rjzciphaz0ig7"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/microsoft.win32.registry/4.3.0/microsoft.win32.registry.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + sha256 = "1fn9fxppfcg4jgypp2pmrpr6awl3qz1xmnri0cygpkwvyx27df1y"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/netstandard.library/2.0.3/netstandard.library.2.0.3.nupkg"; + }) + (fetchNuGet { + pname = "PowerShell"; + version = "7.0.0"; + sha256 = "13jhnbh12rcmdrkmlxq45ard03lmfq7bg14xg7k108jlpnpsr1la"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/powershell/7.0.0/powershell.7.0.0.nupkg"; + }) + (fetchNuGet { + pname = "RichCodeNav.EnvVarDump"; + version = "0.1.1643-alpha"; + sha256 = "1pp1608xizvv0h9q01bqy7isd3yzb3lxb2yp27j4k25xsvw460vg"; + url = "https://pkgs.dev.azure.com/azure-public/3ccf6661-f8ce-4e8a-bb2e-eff943ddd3c7/_packaging/58ca65bb-e6c1-4210-88ac-fa55c1cd7877/nuget/v3/flat2/richcodenav.envvardump/0.1.1643-alpha/richcodenav.envvardump.0.1.1643-alpha.nupkg"; + }) + (fetchNuGet { + pname = "Roslyn.Diagnostics.Analyzers"; + version = "3.3.4-beta1.22160.2"; + sha256 = "0rr7q46vc5lbywm3mf4ld1kjkg9w7fbmkkyka0bi8idrfib7kn0i"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/49e5305d-d845-4a14-9d69-6f5dbfb9570c/nuget/v3/flat2/roslyn.diagnostics.analyzers/3.3.4-beta1.22160.2/roslyn.diagnostics.analyzers.3.3.4-beta1.22160.2.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.collections/4.3.0/runtime.any.system.collections.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tracing"; + version = "4.3.0"; + sha256 = "00j6nv2xgmd3bi347k00m7wr542wjlig53rmj28pmw7ddcn97jbn"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.diagnostics.tracing/4.3.0/runtime.any.system.diagnostics.tracing.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.globalization/4.3.0/runtime.any.system.globalization.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization.Calendars"; + version = "4.3.0"; + sha256 = "1ghhhk5psqxcg6w88sxkqrc35bxcz27zbqm2y5p5298pv3v7g201"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.globalization.calendars/4.3.0/runtime.any.system.globalization.calendars.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.io/4.3.0/runtime.any.system.io.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.reflection/4.3.0/runtime.any.system.reflection.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.reflection.primitives/4.3.0/runtime.any.system.reflection.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.resources.resourcemanager/4.3.0/runtime.any.system.resources.resourcemanager.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.runtime/4.3.0/runtime.any.system.runtime.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.runtime.handles/4.3.0/runtime.any.system.runtime.handles.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.runtime.interopservices/4.3.0/runtime.any.system.runtime.interopservices.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.text.encoding/4.3.0/runtime.any.system.text.encoding.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.text.encoding.extensions/4.3.0/runtime.any.system.text.encoding.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.any.system.threading.tasks/4.3.0/runtime.any.system.threading.tasks.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "16rnxzpk5dpbbl1x354yrlsbvwylrq456xzpsha1n9y3glnhyx9d"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0rwpqngkqiapqc5c2cpkj7idhngrgss5qpnqg0yh40mbyflcxf8i"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.debian.8-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0hkg03sgm2wyq8nqk6dbm9jh5vcq57ry42lkqdmfklrw89lsmr59"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1n06gxwlinhs0w7s8a94r1q3lwqzvynxwd3mp10ws9bg6gck8n4r"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.fedora.23-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0c2p354hjx58xhhz7wv6div8xpi90sc6ibdm40qin21bvi7ymcaa"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0404wqrc7f2yc0wxv71y3nnybvqx8v4j9d47hlscxy759a525mc3"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.fedora.24-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system/4.3.0/runtime.native.system.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Http"; + version = "4.3.0"; + sha256 = "1n6rgz5132lcibbch1qlf0g9jk60r0kqv087hxc0lisy50zpm7kk"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.net.http/4.3.0/runtime.native.system.net.http.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + sha256 = "1b61p6gw1m02cc1ry996fl49liiwky6181dzr873g9ds92zl326q"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.security.cryptography.apple/4.3.0/runtime.native.system.security.cryptography.apple.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "18pzfdlwsg2nb1jjjjzyb5qlgy6xjxzmhnfaijq5s2jw3cm3ab97"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.security.cryptography.openssl/4.3.0/runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0zy5r25jppz48i2bkg8b9lfig24xixg6nm3xyr1379zdnqnpm8f6"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.native.system.security.cryptography.openssl/4.3.2/runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0qyynf9nz5i7pc26cwhgi8j62ps27sqmf78ijcfgzab50z9g8ay3"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "096ch4n4s8k82xga80lfmpimpzahd2ip1mgwdqgar0ywbbl6x438"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.opensuse.13.2-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "1klrs545awhayryma6l7g2pvnp9xy4z0r1i40r80zb45q3i9nbyf"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1dm8fifl7rf1gy7lnwln78ch4rw54g0pl5g1c189vawavll7p6rj"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.opensuse.42.1-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + sha256 = "10yc8jdrwgcl44b4g93f1ds76b176bajd3zqi2faf5rvh1vy9smi"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.apple/4.3.0/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.apple.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0zcxjv5pckplvkg0r6mw3asggm7aqzbdjimhvsasb0cgm59x09l3"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1m9z1k9kzva9n9kwinqxl97x2vgl79qhqjlv17k9s2ymcyv2bwr6"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.osx.10.10-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0vhynn79ih7hw7cwjazn87rm9z9fj0rvxgzlab36jybgcpcgphsn"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1cpx56mcfxz7cpn57wvj18sjisvzq8b5vd9rw16ihd2i6mcp3wa1"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.rhel.7-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "160p68l2c7cqmyqjwxydcvgw7lvl1cr0znkw8fp24d1by9mqc8p3"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "15gsm1a8jdmgmf8j5v1slfz8ks124nfdhk2vxs2rw3asrxalg8hi"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.ubuntu.14.04-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "15zrc8fgd8zx28hdghcj5f5i34wf3l6bq5177075m2bc2j34jrqy"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0q0n5q1r1wnqmr5i5idsrd9ywl33k0js4pngkwq9p368mbxp8x1w"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.ubuntu.16.04-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "1p4dgxax6p7rlgj4q73k73rslcnz4wdcv8q2flg1s8ygwcm58ld5"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl/4.3.0/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1x0g58pbpjrmj2x2qw17rdwwnrcl0wvim2hdwz48lixvwvp22n9c"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl/4.3.2/runtime.ubuntu.16.10-x64.runtime.native.system.security.cryptography.openssl.4.3.2.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.Microsoft.Win32.Primitives"; + version = "4.3.0"; + sha256 = "0y61k9zbxhdi0glg154v30kkq7f8646nif8lnnxbvkjpakggd5id"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.microsoft.win32.primitives/4.3.0/runtime.unix.microsoft.win32.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.diagnostics.debug/4.3.0/runtime.unix.system.diagnostics.debug.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.System.IO.FileSystem"; + version = "4.3.0"; + sha256 = "14nbkhvs7sji5r1saj2x8daz82rnf9kx28d3v2qss34qbr32dzix"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.io.filesystem/4.3.0/runtime.unix.system.io.filesystem.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Primitives"; + version = "4.3.0"; + sha256 = "0bdnglg59pzx9394sy4ic66kmxhqp8q8bvmykdxcbs5mm0ipwwm4"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.net.primitives/4.3.0/runtime.unix.system.net.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.private.uri/4.3.0/runtime.unix.system.private.uri.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.unix.system.runtime.extensions/4.3.0/runtime.unix.system.runtime.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.3.0"; + sha256 = "0fgns20ispwrfqll4q1zc1waqcmylb3zc50ys9x8zlwxh9pmd9jy"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.3.0/system.buffers.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.buffers/4.5.1/system.buffers.4.5.1.nupkg"; + }) + (fetchNuGet { + pname = "System.CodeDom"; + version = "4.4.0"; + sha256 = "1zgbafm5p380r50ap5iddp11kzhr9khrf2pnai6k593wjar74p1g"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.codedom/4.4.0/system.codedom.4.4.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.0.11"; + sha256 = "1ga40f5lrwldiyw6vy67d0sg7jd7ww6kgwbksm19wrvq9hr0bsm6"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections/4.0.11/system.collections.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections/4.3.0/system.collections.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.0.12"; + sha256 = "07y08kvrzpak873pmyxs129g1ch8l27zmg51pcyj2jvq03n0r0fc"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.concurrent/4.0.12/system.collections.concurrent.4.0.12.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.3.0"; + sha256 = "0wi10md9aq33jrkh2c24wr2n9hrpyamsdhsxdcnf43b7y86kkii8"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.concurrent/4.3.0/system.collections.concurrent.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "1.5.0"; + sha256 = "1d5gjn5afnrf461jlxzawcvihz195gayqpcfbv6dd7pxa9ialn06"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.immutable/1.5.0/system.collections.immutable.1.5.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "5.0.0"; + sha256 = "1kvcllagxz2q92g81zkz81djkn2lid25ayjfgjalncyc68i15p0r"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.collections.immutable/5.0.0/system.collections.immutable.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.0.11"; + sha256 = "0gmjghrqmlgzxivd2xl50ncbglb7ljzb66rlx8ws6dv8jm0d5siz"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.debug/4.0.11/system.diagnostics.debug.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.debug/4.3.0/system.diagnostics.debug.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "4.3.0"; + sha256 = "0z6m3pbiy0qw6rn3n209rrzf9x1k4002zh90vwcrsym09ipm2liq"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.diagnosticsource/4.3.0/system.diagnostics.diagnosticsource.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.1.0"; + sha256 = "1d2r76v1x610x61ahfpigda89gd13qydz6vbwzhpqlyvq8jj6394"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracing/4.1.0/system.diagnostics.tracing.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + sha256 = "1m3bx6c2s958qligl67q7grkwfz3w53hpy7nc97mh6f7j5k168c4"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.diagnostics.tracing/4.3.0/system.diagnostics.tracing.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.0.11"; + sha256 = "070c5jbas2v7smm660zaf1gh0489xanjqymkvafcs4f8cdrs1d5d"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization/4.0.11/system.globalization.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization/4.3.0/system.globalization.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.3.0"; + sha256 = "1xwl230bkakzzkrggy1l1lxmm3xlhk4bq2pkv790j5lm8g887lxq"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization.calendars/4.3.0/system.globalization.calendars.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Globalization.Extensions"; + version = "4.3.0"; + sha256 = "02a5zfxavhv3jd437bsncbhd2fp1zv4gxzakp1an9l6kdq1mcqls"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.globalization.extensions/4.3.0/system.globalization.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.1.0"; + sha256 = "1g0yb8p11vfd0kbkyzlfsbsp5z44lwsvyc0h3dpw6vqnbi035ajp"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io/4.1.0/system.io.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io/4.3.0/system.io.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + sha256 = "0z2dfrbra9i6y16mm9v1v6k47f0fm617vlb7s5iybjjsz6g1ilmw"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem/4.3.0/system.io.filesystem.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.filesystem.primitives/4.3.0/system.io.filesystem.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.IO.Pipes.AccessControl"; + version = "5.0.0"; + sha256 = "0jl5b95cy8biivi1kdn2wi0gy2m1a0gyj8fy88djybrg2705c8fz"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.io.pipes.accesscontrol/5.0.0/system.io.pipes.accesscontrol.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.1.0"; + sha256 = "1ppg83svb39hj4hpp5k7kcryzrf3sfnm08vxd5sm2drrijsla2k5"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.linq/4.1.0/system.linq.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.linq/4.3.0/system.linq.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Linq.Parallel"; + version = "4.0.1"; + sha256 = "0i33x9f4h3yq26yvv6xnq4b0v51rl5z8v1bm7vk972h5lvf4apad"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.linq.parallel/4.0.1/system.linq.parallel.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.memory/4.5.4/system.memory.4.5.4.nupkg"; + }) + (fetchNuGet { + pname = "System.Net.Http"; + version = "4.3.4"; + sha256 = "0kdp31b8819v88l719j6my0yas6myv9d1viql3qz5577mv819jhl"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.http/4.3.4/system.net.http.4.3.4.nupkg"; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.3.0"; + sha256 = "0c87k50rmdgmxx7df2khd9qj7q35j9rzdmm2572cc55dygmdk3ii"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.net.primitives/4.3.0/system.net.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.4.0"; + sha256 = "0rdvma399070b0i46c4qq1h2yvjj3k013sqzkilz4bz5cwmx1rba"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.numerics.vectors/4.4.0/system.numerics.vectors.4.4.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + sha256 = "1kzrj37yzawf1b19jq0253rcs8hsq1l2q8g69d7ipnhzb0h97m59"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.numerics.vectors/4.5.0/system.numerics.vectors.4.5.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.private.uri/4.3.0/system.private.uri.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.1.0"; + sha256 = "1js89429pfw79mxvbzp8p3q93il6rdff332hddhzi5wqglc4gml9"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection/4.1.0/system.reflection.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection/4.3.0/system.reflection.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "1.6.0"; + sha256 = "1wdbavrrkajy7qbdblpbpbalbdl48q3h34cchz24gvdgyrlf15r4"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadata/1.6.0/system.reflection.metadata.1.6.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "5.0.0"; + sha256 = "17qsl5nanlqk9iz0l5wijdn6ka632fs1m1fvx18dfgswm258r3ss"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadata/5.0.0/system.reflection.metadata.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.0.1"; + sha256 = "1bangaabhsl4k9fg8khn83wm6yial8ik1sza7401621jc6jrym28"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.primitives/4.0.1/system.reflection.primitives.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.primitives/4.3.0/system.reflection.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.1.0"; + sha256 = "1bjli8a7sc7jlxqgcagl9nh8axzfl11f4ld3rjqsyxc516iijij7"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.typeextensions/4.1.0/system.reflection.typeextensions.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Resources.Extensions"; + version = "4.6.0"; + sha256 = "0inch9jgchgmsg3xjivbhh9mpin40mhdd8dgf4i1p3g42i0hzc0j"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.extensions/4.6.0/system.resources.extensions.4.6.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.0.1"; + sha256 = "0b4i7mncaf8cnai85jv3wnw6hps140cxz8vylv2bik6wyzgvz7bi"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.resourcemanager/4.0.1/system.resources.resourcemanager.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.resourcemanager/4.3.0/system.resources.resourcemanager.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Resources.Writer"; + version = "4.0.0"; + sha256 = "07hp218kjdcvpl27djspnixgnacbp9apma61zz3wsca9fx5g3lmv"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.resources.writer/4.0.0/system.resources.writer.4.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.1.0"; + sha256 = "02hdkgk13rvsd6r9yafbwzss8kr55wnj8d5c7xjnp8gqrwc8sn0m"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime/4.1.0/system.runtime.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime/4.3.0/system.runtime.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.7.1"; + sha256 = "119br3pd85lq8zcgh4f60jzmv1g976q1kdgi3hvqdlhfbw6siz2j"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.compilerservices.unsafe/4.7.1/system.runtime.compilerservices.unsafe.4.7.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.compilerservices.unsafe/6.0.0/system.runtime.compilerservices.unsafe.6.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.1.0"; + sha256 = "0rw4rm4vsm3h3szxp9iijc3ksyviwsv6f63dng3vhqyg4vjdkc2z"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.extensions/4.1.0/system.runtime.extensions.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.extensions/4.3.0/system.runtime.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.0.1"; + sha256 = "1g0zrdi5508v49pfm3iii2hn6nm00bgvfpjq1zxknfjrxxa20r4g"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.handles/4.0.1/system.runtime.handles.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.handles/4.3.0/system.runtime.handles.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.1.0"; + sha256 = "01kxqppx3dr3b6b286xafqilv4s2n0gqvfgzfd4z943ga9i81is1"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices/4.1.0/system.runtime.interopservices.4.1.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.interopservices/4.3.0/system.runtime.interopservices.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Loader"; + version = "4.3.0"; + sha256 = "07fgipa93g1xxgf7193a6vw677mpzgr0z0cfswbvqqb364cva8dk"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.loader/4.3.0/system.runtime.loader.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.3.0"; + sha256 = "19rav39sr5dky7afygh309qamqqmi9kcwvz3i0c5700v0c5cg61z"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.numerics/4.3.0/system.runtime.numerics.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Runtime.Serialization.Primitives"; + version = "4.1.1"; + sha256 = "042rfjixknlr6r10vx2pgf56yming8lkjikamg3g4v29ikk78h7k"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.runtime.serialization.primitives/4.1.1/system.runtime.serialization.primitives.4.1.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "5.0.0"; + sha256 = "17n3lrrl6vahkqmhlpn3w20afgz09n7i6rv0r3qypngwi7wqdr5r"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.accesscontrol/5.0.0/system.security.accesscontrol.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.3.0"; + sha256 = "03sq183pfl5kp7gkvq77myv7kbpdnq3y0xj7vi4q1kaw54sny0ml"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.algorithms/4.3.0/system.security.cryptography.algorithms.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.3.0"; + sha256 = "1k468aswafdgf56ab6yrn7649kfqx2wm9aslywjam1hdmk5yypmv"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.cng/4.3.0/system.security.cryptography.cng.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Csp"; + version = "4.3.0"; + sha256 = "1x5wcrddf2s3hb8j78cry7yalca4lb5vfnkrysagbn6r9x6xvrx1"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.csp/4.3.0/system.security.cryptography.csp.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.3.0"; + sha256 = "1jr6w70igqn07k5zs1ph6xja97hxnb3mqbspdrff6cvssgrixs32"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.encoding/4.3.0/system.security.cryptography.encoding.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0givpvvj8yc7gv4lhb6s1prq6p2c4147204a0wib89inqzd87gqc"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.openssl/4.3.0/system.security.cryptography.openssl.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.3.0"; + sha256 = "0pyzncsv48zwly3lw4f2dayqswcfvdwq2nz0dgwmi7fj3pn64wby"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.primitives/4.3.0/system.security.cryptography.primitives.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.3.0"; + sha256 = "0valjcz5wksbvijylxijjxb1mp38mdhv03r533vnx1q3ikzdav9h"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.cryptography.x509certificates/4.3.0/system.security.cryptography.x509certificates.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + sha256 = "1mpk7xj76lxgz97a5yg93wi8lj0l8p157a5d50mmjy3gbz1904q8"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.security.principal.windows/5.0.0/system.security.principal.windows.5.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.0.11"; + sha256 = "1dyqv0hijg265dwxg6l7aiv74102d6xjiwplh2ar1ly6xfaa4iiw"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding/4.0.11/system.text.encoding.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding/4.3.0/system.text.encoding.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "4.0.1"; + sha256 = "00wpm3b9y0k996rm9whxprngm8l500ajmzgy2ip9pgwk0icp06y3"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.codepages/4.0.1/system.text.encoding.codepages.4.0.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "4.5.1"; + sha256 = "1z21qyfs6sg76rp68qdx0c9iy57naan89pg7p6i3qpj8kyzn921w"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.codepages/4.5.1/system.text.encoding.codepages.4.5.1.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "6.0.0"; + sha256 = "0gm2kiz2ndm9xyzxgi0jhazgwslcs427waxgfa30m7yqll1kcrww"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.codepages/6.0.0/system.text.encoding.codepages.6.0.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.text.encoding.extensions/4.3.0/system.text.encoding.extensions.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.0.11"; + sha256 = "19x946h926bzvbsgj28csn46gak2crv2skpwsx80hbgazmkgb1ls"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading/4.0.11/system.threading.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading/4.3.0/system.threading.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.0.11"; + sha256 = "0nr1r41rak82qfa5m0lhk9mp0k93bvfd7bbd9sdzwx9mb36g28p5"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks/4.0.11/system.threading.tasks.4.0.11.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks/4.3.0/system.threading.tasks.4.3.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Dataflow"; + version = "4.9.0"; + sha256 = "1g6s9pjg4z8iy98df60y9a01imdqy59zd767vz74rrng78jl2dk5"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.dataflow/4.9.0/system.threading.tasks.dataflow.4.9.0.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + sha256 = "0y6ncasgfcgnjrhynaf0lwpkpkmv4a07sswwkwbwb5h7riisj153"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.tasks.extensions/4.5.4/system.threading.tasks.extensions.4.5.4.nupkg"; + }) + (fetchNuGet { + pname = "System.Threading.Thread"; + version = "4.0.0"; + sha256 = "1gxxm5fl36pjjpnx1k688dcw8m9l7nmf802nxis6swdaw8k54jzc"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.threading.thread/4.0.0/system.threading.thread.4.0.0.nupkg"; + }) ] diff --git a/pkgs/by-name/ro/roswell/package.nix b/pkgs/by-name/ro/roswell/package.nix index f60bd61e80c28e..342da78bae4b8b 100644 --- a/pkgs/by-name/ro/roswell/package.nix +++ b/pkgs/by-name/ro/roswell/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, curl -, autoconf -, automake -, makeWrapper -, sbcl +{ + lib, + stdenv, + fetchFromGitHub, + curl, + autoconf, + automake, + makeWrapper, + sbcl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ro/rot8/package.nix b/pkgs/by-name/ro/rot8/package.nix index 6a62d05b5a5d55..c6bac9263d0735 100644 --- a/pkgs/by-name/ro/rot8/package.nix +++ b/pkgs/by-name/ro/rot8/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "rot8"; diff --git a/pkgs/by-name/ro/rotate-backups/package.nix b/pkgs/by-name/ro/rotate-backups/package.nix index 08f1c3ff3bc8f6..70708d1238807f 100644 --- a/pkgs/by-name/ro/rotate-backups/package.nix +++ b/pkgs/by-name/ro/rotate-backups/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ro/rote/package.nix b/pkgs/by-name/ro/rote/package.nix index 65e2ecd0915017..b139fae6c09892 100644 --- a/pkgs/by-name/ro/rote/package.nix +++ b/pkgs/by-name/ro/rote/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "rote"; diff --git a/pkgs/by-name/ro/rotonda/package.nix b/pkgs/by-name/ro/rotonda/package.nix index f049049279d5c8..9c3bc5805c983e 100644 --- a/pkgs/by-name/ro/rotonda/package.nix +++ b/pkgs/by-name/ro/rotonda/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ro/rotp/package.nix b/pkgs/by-name/ro/rotp/package.nix index a5ff60c25a40dc..8240ec58fd1193 100644 --- a/pkgs/by-name/ro/rotp/package.nix +++ b/pkgs/by-name/ro/rotp/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, jdk, jre }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + jdk, + jre, +}: stdenv.mkDerivation { pname = "remnants-of-the-precursors"; @@ -11,7 +18,10 @@ stdenv.mkDerivation { sha256 = "sha256-oMA8LRpBoBX7t4G+HuRz0a8g+UEwYO7Ya0Qq4j8AWec="; }; - nativeBuildInputs = [ jdk makeWrapper ]; + nativeBuildInputs = [ + jdk + makeWrapper + ]; # By default, the game tries to write to the java class path. If that fails # (and it always does, since they are in the read-only nix store), it won't diff --git a/pkgs/by-name/ro/round/package.nix b/pkgs/by-name/ro/round/package.nix index b65567dcab4004..dc55727a2b093e 100644 --- a/pkgs/by-name/ro/round/package.nix +++ b/pkgs/by-name/ro/round/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -20,9 +21,9 @@ buildGoModule rec { meta = with lib; { description = "Round image corners from CLI"; - homepage = "https://github.com/mingrammer/round"; - license = licenses.mit; - maintainers = with maintainers; [ addict3d ]; + homepage = "https://github.com/mingrammer/round"; + license = licenses.mit; + maintainers = with maintainers; [ addict3d ]; mainProgram = "round"; }; } diff --git a/pkgs/by-name/ro/rounded-mgenplus/package.nix b/pkgs/by-name/ro/rounded-mgenplus/package.nix index b314fd45eef89b..4fa521cf798744 100644 --- a/pkgs/by-name/ro/rounded-mgenplus/package.nix +++ b/pkgs/by-name/ro/rounded-mgenplus/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchurl, p7zip }: +{ + lib, + stdenvNoCC, + fetchurl, + p7zip, +}: stdenvNoCC.mkDerivation rec { pname = "rounded-mgenplus"; diff --git a/pkgs/by-name/ro/roundup/package.nix b/pkgs/by-name/ro/roundup/package.nix index 2993b5f8294646..743b224c07fa92 100644 --- a/pkgs/by-name/ro/roundup/package.nix +++ b/pkgs/by-name/ro/roundup/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, ronn, shocco }: +{ + lib, + stdenv, + fetchFromGitHub, + ronn, + shocco, +}: stdenv.mkDerivation rec { pname = "roundup"; @@ -18,9 +24,15 @@ stdenv.mkDerivation rec { substituteInPlace Makefile --replace "{1..9}" "1 5" ''; - nativeBuildInputs = [ ronn shocco ]; + nativeBuildInputs = [ + ronn + shocco + ]; - installTargets = [ "install" "install-man" ]; + installTargets = [ + "install" + "install-man" + ]; preInstall = '' for i in 1 5; do diff --git a/pkgs/by-name/ro/route-graph/package.nix b/pkgs/by-name/ro/route-graph/package.nix index 8e1a4e183ce06a..72e4113ce522a2 100644 --- a/pkgs/by-name/ro/route-graph/package.nix +++ b/pkgs/by-name/ro/route-graph/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, graphviz -, python3 +{ + lib, + fetchFromGitHub, + graphviz, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -25,13 +26,15 @@ python3.pkgs.buildPythonApplication rec { poetry-core ]; - propagatedBuildInputs = [ - graphviz - ] ++ (with python3.pkgs; [ - scapy - typer - typing-extensions - ]); + propagatedBuildInputs = + [ + graphviz + ] + ++ (with python3.pkgs; [ + scapy + typer + typing-extensions + ]); # Project has no tests doCheck = false; diff --git a/pkgs/by-name/ro/route159/package.nix b/pkgs/by-name/ro/route159/package.nix index 96ae4e4ebb2694..28ca44711b1e91 100644 --- a/pkgs/by-name/ro/route159/package.nix +++ b/pkgs/by-name/ro/route159/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "1"; @@ -26,7 +30,10 @@ stdenvNoCC.mkDerivation { homepage = "http://dotcolon.net/font/route159/"; description = "Weighted sans serif font"; platforms = platforms.all; - maintainers = with maintainers; [ leenaars minijackson ]; + maintainers = with maintainers; [ + leenaars + minijackson + ]; license = licenses.ofl; }; } diff --git a/pkgs/by-name/ro/routedns/package.nix b/pkgs/by-name/ro/routedns/package.nix index 0b6f6822bb8d08..434491ae88be79 100644 --- a/pkgs/by-name/ro/routedns/package.nix +++ b/pkgs/by-name/ro/routedns/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -18,7 +19,10 @@ buildGoModule rec { subPackages = [ "./cmd/routedns" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/folbricht/routedns"; diff --git a/pkgs/by-name/ro/router/librusty_v8.nix b/pkgs/by-name/ro/router/librusty_v8.nix index 82cdb5e1575ee3..46c17dfd01c61c 100644 --- a/pkgs/by-name/ro/router/librusty_v8.nix +++ b/pkgs/by-name/ro/router/librusty_v8.nix @@ -1,15 +1,21 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let - fetch_librusty_v8 = args: fetchurl { - name = "librusty_v8-${args.version}"; - url = "https://github.com/denoland/rusty_v8/releases/download/v${args.version}/librusty_v8_release_${stdenv.hostPlatform.rust.rustcTarget}.a"; - sha256 = args.shas.${stdenv.hostPlatform.system}; - meta = { - inherit (args) version; - sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; + fetch_librusty_v8 = + args: + fetchurl { + name = "librusty_v8-${args.version}"; + url = "https://github.com/denoland/rusty_v8/releases/download/v${args.version}/librusty_v8_release_${stdenv.hostPlatform.rust.rustcTarget}.a"; + sha256 = args.shas.${stdenv.hostPlatform.system}; + meta = { + inherit (args) version; + sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; + }; }; - }; in fetch_librusty_v8 { version = "0.74.3"; diff --git a/pkgs/by-name/ro/routersploit/package.nix b/pkgs/by-name/ro/routersploit/package.nix index 14de115541afae..0ff779a6de1dd2 100644 --- a/pkgs/by-name/ro/routersploit/package.nix +++ b/pkgs/by-name/ro/routersploit/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ro/routinator/package.nix b/pkgs/by-name/ro/routinator/package.nix index 14adef52117ad2..63b88774c79067 100644 --- a/pkgs/by-name/ro/routinator/package.nix +++ b/pkgs/by-name/ro/routinator/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -18,7 +19,13 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-1JxAbQPCQqDVry3wGIdY4q18rzCXlJ7Dnc8LIvhkW1g="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ Security SystemConfiguration ]); + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Security + SystemConfiguration + ] + ); meta = with lib; { description = "RPKI Validator written in Rust"; diff --git a/pkgs/by-name/ro/routino/package.nix b/pkgs/by-name/ro/routino/package.nix index e430a3063e2c54..adffbdb9fd5e89 100644 --- a/pkgs/by-name/ro/routino/package.nix +++ b/pkgs/by-name/ro/routino/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchpatch, perl, zlib, bzip2 }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + perl, + zlib, + bzip2, +}: stdenv.mkDerivation rec { pname = "routino"; @@ -28,9 +36,15 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ perl ]; - buildInputs = [ zlib bzip2 ]; + buildInputs = [ + zlib + bzip2 + ]; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; CLANG = lib.optionalString stdenv.cc.isClang "1"; diff --git a/pkgs/by-name/ro/rowhammer-test/package.nix b/pkgs/by-name/ro/rowhammer-test/package.nix index 0287a3d3a5fb75..6d888b3149bd10 100644 --- a/pkgs/by-name/ro/rowhammer-test/package.nix +++ b/pkgs/by-name/ro/rowhammer-test/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "rowhammer-test"; @@ -25,6 +29,9 @@ stdenv.mkDerivation { homepage = "https://github.com/google/rowhammer-test"; license = licenses.asl20; maintainers = [ ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/by-name/ro/roxterm/package.nix b/pkgs/by-name/ro/roxterm/package.nix index 6ede89e9340a07..355d98b1f3fb9c 100644 --- a/pkgs/by-name/ro/roxterm/package.nix +++ b/pkgs/by-name/ro/roxterm/package.nix @@ -1,32 +1,32 @@ { - at-spi2-core -, cmake -, dbus -, dbus-glib -, docbook_xsl -, fetchFromGitHub -, glib -, gtk3 -, harfbuzz -, lib -, libXdmcp -, libXtst -, libepoxy -, libpthreadstubs -, libselinux -, libsepol -, libtasn1 -, libxkbcommon -, libxslt -, nixosTests -, p11-kit -, pcre2 -, pkg-config -, stdenv -, util-linuxMinimal -, vte -, wrapGAppsHook3 -, xmlto + at-spi2-core, + cmake, + dbus, + dbus-glib, + docbook_xsl, + fetchFromGitHub, + glib, + gtk3, + harfbuzz, + lib, + libXdmcp, + libXtst, + libepoxy, + libpthreadstubs, + libselinux, + libsepol, + libtasn1, + libxkbcommon, + libxslt, + nixosTests, + p11-kit, + pcre2, + pkg-config, + stdenv, + util-linuxMinimal, + vte, + wrapGAppsHook3, + xmlto, }: stdenv.mkDerivation (finalAttrs: { @@ -90,7 +90,11 @@ stdenv.mkDerivation (finalAttrs: { desktop environments. ''; changelog = "https://github.com/realh/roxterm/blob/${finalAttrs.src.rev}/debian/changelog"; - license = with lib.licenses; [ gpl2Plus gpl3Plus lgpl3Plus ]; + license = with lib.licenses; [ + gpl2Plus + gpl3Plus + lgpl3Plus + ]; mainProgram = "roxterm"; maintainers = with lib.maintainers; [ AndersonTorres ]; platforms = lib.platforms.linux; diff --git a/pkgs/by-name/rp/rpPPPoE/package.nix b/pkgs/by-name/rp/rpPPPoE/package.nix index 6fd6c40ce30824..940ada94fac890 100644 --- a/pkgs/by-name/rp/rpPPPoE/package.nix +++ b/pkgs/by-name/rp/rpPPPoE/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ppp } : +{ + lib, + stdenv, + fetchFromGitHub, + ppp, +}: let in stdenv.mkDerivation rec { @@ -19,7 +24,9 @@ stdenv.mkDerivation rec { export PPPD=${ppp}/sbin/pppd ''; - configureFlags = [ "--enable-plugin=${ppp}/include" ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ "rpppoe_cv_pack_bitfields=rev" ]; + configureFlags = [ + "--enable-plugin=${ppp}/include" + ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ "rpppoe_cv_pack_bitfields=rev" ]; postConfigure = '' sed -i Makefile -e 's@DESTDIR)/etc/ppp@out)/etc/ppp@' diff --git a/pkgs/by-name/rp/rpcbind/package.nix b/pkgs/by-name/rp/rpcbind/package.nix index 00763ceee550c5..f1dadd3a78579e 100644 --- a/pkgs/by-name/rp/rpcbind/package.nix +++ b/pkgs/by-name/rp/rpcbind/package.nix @@ -1,5 +1,14 @@ -{ fetchgit, lib, stdenv, pkg-config, libnsl, libtirpc, autoreconfHook -, useSystemd ? true, systemd }: +{ + fetchgit, + lib, + stdenv, + pkg-config, + libnsl, + libtirpc, + autoreconfHook, + useSystemd ? true, + systemd, +}: stdenv.mkDerivation { pname = "rpcbind"; @@ -15,16 +24,23 @@ stdenv.mkDerivation { ./sunrpc.patch ]; - buildInputs = [ libnsl libtirpc ] - ++ lib.optional useSystemd systemd; + buildInputs = [ + libnsl + libtirpc + ] ++ lib.optional useSystemd systemd; configureFlags = [ - "--with-systemdsystemunitdir=${if useSystemd then "${placeholder "out"}/etc/systemd/system" else "no"}" + "--with-systemdsystemunitdir=${ + if useSystemd then "${placeholder "out"}/etc/systemd/system" else "no" + }" "--enable-warmstarts" "--with-rpcuser=rpc" ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; meta = with lib; { description = "ONC RPC portmapper"; diff --git a/pkgs/by-name/rp/rpcemu/package.nix b/pkgs/by-name/rp/rpcemu/package.nix index 25930470412af1..648da19c8cefd8 100644 --- a/pkgs/by-name/rp/rpcemu/package.nix +++ b/pkgs/by-name/rp/rpcemu/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchhg -, qt5 +{ + lib, + stdenv, + fetchhg, + qt5, }: let @@ -58,7 +59,7 @@ stdenv.mkDerivation (finalAttrs: { using them with RPCEmu. ''; license = lib.licenses.gpl2Plus; - maintainers = builtins.attrValues { + maintainers = builtins.attrValues { inherit (lib.maintainers) AndersonTorres; }; platforms = lib.platforms.linux; diff --git a/pkgs/by-name/rp/rpcs3/package.nix b/pkgs/by-name/rp/rpcs3/package.nix index deaeac82bda814..9158bc16bbef67 100644 --- a/pkgs/by-name/rp/rpcs3/package.nix +++ b/pkgs/by-name/rp/rpcs3/package.nix @@ -1,34 +1,35 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, git -, qt6Packages -, openal -, glew -, vulkan-headers -, vulkan-loader -, libpng -, libSM -, ffmpeg -, libevdev -, libusb1 -, zlib -, curl -, wolfssl -, python3 -, pugixml -, flatbuffers -, llvm_16 -, cubeb -, enableDiscordRpc ? false -, faudioSupport ? true -, faudio -, SDL2 -, waylandSupport ? true -, wayland -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + git, + qt6Packages, + openal, + glew, + vulkan-headers, + vulkan-loader, + libpng, + libSM, + ffmpeg, + libevdev, + libusb1, + zlib, + curl, + wolfssl, + python3, + pugixml, + flatbuffers, + llvm_16, + cubeb, + enableDiscordRpc ? false, + faudioSupport ? true, + faudio, + SDL2, + waylandSupport ? true, + wayland, + wrapGAppsHook3, }: let @@ -38,7 +39,12 @@ let rpcs3Revision = "8b8396b9455394486656660c960d420c5b6c446c"; rpcs3Hash = "sha256-LUgKUzoBNY4ZemRBsLOjtXxLXHyRkPivtdSSgUGw5h4="; - inherit (qt6Packages) qtbase qtmultimedia wrapQtAppsHook qtwayland; + inherit (qt6Packages) + qtbase + qtmultimedia + wrapQtAppsHook + qtwayland + ; in stdenv.mkDerivation { pname = "rpcs3"; @@ -84,14 +90,42 @@ stdenv.mkDerivation { dontWrapGApps = true; - nativeBuildInputs = [ cmake pkg-config git wrapQtAppsHook wrapGAppsHook3 ]; + nativeBuildInputs = [ + cmake + pkg-config + git + wrapQtAppsHook + wrapGAppsHook3 + ]; - buildInputs = [ - qtbase qtmultimedia openal glew vulkan-headers vulkan-loader libpng ffmpeg - libevdev zlib libusb1 curl wolfssl python3 pugixml SDL2 flatbuffers llvm_16 libSM - ] ++ cubeb.passthru.backendLibs + buildInputs = + [ + qtbase + qtmultimedia + openal + glew + vulkan-headers + vulkan-loader + libpng + ffmpeg + libevdev + zlib + libusb1 + curl + wolfssl + python3 + pugixml + SDL2 + flatbuffers + llvm_16 + libSM + ] + ++ cubeb.passthru.backendLibs ++ lib.optional faudioSupport faudio - ++ lib.optionals waylandSupport [ wayland qtwayland ]; + ++ lib.optionals waylandSupport [ + wayland + qtwayland + ]; preFixup = '' qtWrapperArgs+=("''${gappsWrapperArgs[@]}") @@ -107,9 +141,17 @@ stdenv.mkDerivation { meta = with lib; { description = "PS3 emulator/debugger"; homepage = "https://rpcs3.net/"; - maintainers = with maintainers; [ abbradar neonfuz ilian zane ]; + maintainers = with maintainers; [ + abbradar + neonfuz + ilian + zane + ]; license = licenses.gpl2Only; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; mainProgram = "rpcs3"; }; } diff --git a/pkgs/by-name/rp/rpcsvc-proto/package.nix b/pkgs/by-name/rp/rpcsvc-proto/package.nix index 2de8bdefc880db..89331a7dff9d77 100644 --- a/pkgs/by-name/rp/rpcsvc-proto/package.nix +++ b/pkgs/by-name/rp/rpcsvc-proto/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, autoreconfHook, buildPackages, fetchpatch, targetPackages }: +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + buildPackages, + fetchpatch, + targetPackages, +}: stdenv.mkDerivation rec { pname = "rpcsvc-proto"; @@ -20,21 +28,27 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "out" "man" "dev" ]; + outputs = [ + "out" + "man" + "dev" + ]; nativeBuildInputs = [ autoreconfHook ]; RPCGEN_CPP = "${stdenv.cc.targetPrefix}cpp"; - postPatch = '' - # replace fallback cpp with the target prefixed cpp - substituteInPlace rpcgen/rpc_main.c \ - --replace 'CPP = "cpp"' \ - 'CPP = "${targetPackages.stdenv.cc.targetPrefix}cpp"' - '' + lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - substituteInPlace rpcsvc/Makefile.am \ - --replace '$(top_builddir)/rpcgen/rpcgen' '${buildPackages.rpcsvc-proto}/bin/rpcgen' - ''; + postPatch = + '' + # replace fallback cpp with the target prefixed cpp + substituteInPlace rpcgen/rpc_main.c \ + --replace 'CPP = "cpp"' \ + 'CPP = "${targetPackages.stdenv.cc.targetPrefix}cpp"' + '' + + lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + substituteInPlace rpcsvc/Makefile.am \ + --replace '$(top_builddir)/rpcgen/rpcgen' '${buildPackages.rpcsvc-proto}/bin/rpcgen' + ''; meta = with lib; { homepage = "https://github.com/thkukuk/rpcsvc-proto"; diff --git a/pkgs/by-name/rp/rpg-cli/package.nix b/pkgs/by-name/rp/rpg-cli/package.nix index f6c3249c725943..7484ba694e2cb6 100644 --- a/pkgs/by-name/rp/rpg-cli/package.nix +++ b/pkgs/by-name/rp/rpg-cli/package.nix @@ -1,4 +1,8 @@ -{ rustPlatform, fetchFromGitHub, lib }: +{ + rustPlatform, + fetchFromGitHub, + lib, +}: rustPlatform.buildRustPackage rec { pname = "rpg-cli"; diff --git a/pkgs/by-name/rp/rpiplay/package.nix b/pkgs/by-name/rp/rpiplay/package.nix index 8ca4cb5341971d..dc43891fed8866 100644 --- a/pkgs/by-name/rp/rpiplay/package.nix +++ b/pkgs/by-name/rp/rpiplay/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, pkg-config, fetchFromGitHub, fetchpatch, cmake, wrapGAppsHook3, avahi, avahi-compat, openssl, gst_all_1, libplist }: +{ + lib, + stdenv, + pkg-config, + fetchFromGitHub, + fetchpatch, + cmake, + wrapGAppsHook3, + avahi, + avahi-compat, + openssl, + gst_all_1, + libplist, +}: stdenv.mkDerivation rec { pname = "rpiplay"; diff --git a/pkgs/by-name/rp/rpl/package.nix b/pkgs/by-name/rp/rpl/package.nix index 9feb4fd04fbb54..74b890a6ee20ab 100644 --- a/pkgs/by-name/rp/rpl/package.nix +++ b/pkgs/by-name/rp/rpl/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchPypi, python3Packages }: +{ + lib, + fetchPypi, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "rpl"; diff --git a/pkgs/by-name/rp/rpm-ostree/package.nix b/pkgs/by-name/rp/rpm-ostree/package.nix index 87bd920db1c714..63b14942e5de83 100644 --- a/pkgs/by-name/rp/rpm-ostree/package.nix +++ b/pkgs/by-name/rp/rpm-ostree/package.nix @@ -1,48 +1,55 @@ -{ lib, stdenv -, fetchurl -, ostree -, rpm -, which -, autoconf -, automake -, libtool -, pkg-config -, cargo -, rustc -, gobject-introspection -, gtk-doc -, libxml2 -, libxslt -, docbook_xsl -, docbook_xml_dtd_42 -, docbook_xml_dtd_43 -, gperf -, cmake -, libcap -, glib -, systemd -, json-glib -, libarchive -, libsolv -, librepo -, polkit -, bubblewrap -, pcre -, check -, python3 -, json_c -, zchunk -, libmodulemd -, util-linux -, sqlite -, cppunit +{ + lib, + stdenv, + fetchurl, + ostree, + rpm, + which, + autoconf, + automake, + libtool, + pkg-config, + cargo, + rustc, + gobject-introspection, + gtk-doc, + libxml2, + libxslt, + docbook_xsl, + docbook_xml_dtd_42, + docbook_xml_dtd_43, + gperf, + cmake, + libcap, + glib, + systemd, + json-glib, + libarchive, + libsolv, + librepo, + polkit, + bubblewrap, + pcre, + check, + python3, + json_c, + zchunk, + libmodulemd, + util-linux, + sqlite, + cppunit, }: stdenv.mkDerivation rec { pname = "rpm-ostree"; version = "2024.8"; - outputs = [ "out" "dev" "man" "devdoc" ]; + outputs = [ + "out" + "dev" + "man" + "devdoc" + ]; src = fetchurl { url = "https://github.com/coreos/rpm-ostree/releases/download/v${version}/rpm-ostree-${version}.tar.xz"; diff --git a/pkgs/by-name/rp/rpm2targz/package.nix b/pkgs/by-name/rp/rpm2targz/package.nix index c9fa1a0e639784..9914bc433dbed1 100644 --- a/pkgs/by-name/rp/rpm2targz/package.nix +++ b/pkgs/by-name/rp/rpm2targz/package.nix @@ -1,13 +1,14 @@ -{ bzip2 -, coreutils -, cpio -, fetchurl -, gnutar -, gzip -, lib -, stdenv -, xz -, zstd +{ + bzip2, + coreutils, + cpio, + fetchurl, + gnutar, + gzip, + lib, + stdenv, + xz, + zstd, }: stdenv.mkDerivation rec { @@ -20,23 +21,25 @@ stdenv.mkDerivation rec { hash = "sha256-rcV+o9V2wWKznqSW2rA8xgnpQ02kpK4te6mYvLRC5vQ="; }; - postPatch = let - shdeps = [ - bzip2 - coreutils - cpio - gnutar - gzip - xz - zstd - ]; - in '' - substituteInPlace rpm2targz --replace "=\"rpmoffset\"" "=\"$out/bin/rpmoffset\"" - # rpm2targz relies on the executable name - # to guess what compressor it should use - # this is more reliable than wrapProgram - sed -i -e '2iexport PATH="${lib.makeBinPath shdeps}"' rpm2targz - ''; + postPatch = + let + shdeps = [ + bzip2 + coreutils + cpio + gnutar + gzip + xz + zstd + ]; + in + '' + substituteInPlace rpm2targz --replace "=\"rpmoffset\"" "=\"$out/bin/rpmoffset\"" + # rpm2targz relies on the executable name + # to guess what compressor it should use + # this is more reliable than wrapProgram + sed -i -e '2iexport PATH="${lib.makeBinPath shdeps}"' rpm2targz + ''; installFlags = [ "prefix=$(out)" ]; diff --git a/pkgs/by-name/rp/rpmextract/package.nix b/pkgs/by-name/rp/rpmextract/package.nix index ccb37cc5b5674e..5decce67d5aafc 100644 --- a/pkgs/by-name/rp/rpmextract/package.nix +++ b/pkgs/by-name/rp/rpmextract/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, rpm, cpio, substituteAll }: +{ + lib, + stdenv, + rpm, + cpio, + substituteAll, +}: stdenv.mkDerivation { name = "rpmextract"; diff --git a/pkgs/by-name/rq/rq/package.nix b/pkgs/by-name/rq/rq/package.nix index b5624092c852a5..b128d2c7e30aec 100644 --- a/pkgs/by-name/rq/rq/package.nix +++ b/pkgs/by-name/rq/rq/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "rq"; @@ -31,6 +35,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "rq"; homepage = "https://github.com/dflemstr/rq"; license = with licenses; [ asl20 ]; - maintainers = with maintainers; [ aristid Br1ght0ne figsoda ]; + maintainers = with maintainers; [ + aristid + Br1ght0ne + figsoda + ]; }; } diff --git a/pkgs/by-name/rq/rqlite/package.nix b/pkgs/by-name/rq/rqlite/package.nix index ec025beef2b0b3..ed805591a1f1d4 100644 --- a/pkgs/by-name/rq/rqlite/package.nix +++ b/pkgs/by-name/rq/rqlite/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,12 +17,17 @@ buildGoModule rec { vendorHash = "sha256-yoowUrS7UDk6sCfTYmDEVWzGBtzT7DR1vuqPWlcqRzU="; - subPackages = [ "cmd/rqlite" "cmd/rqlited" "cmd/rqbench" ]; + subPackages = [ + "cmd/rqlite" + "cmd/rqlited" + "cmd/rqbench" + ]; # Leaving other flags from https://github.com/rqlite/rqlite/blob/master/package.sh # since automatically retriving those is nontrivial and inessential ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/rqlite/rqlite/cmd.Version=${src.rev}" ]; diff --git a/pkgs/by-name/rr/rrootage/package.nix b/pkgs/by-name/rr/rrootage/package.nix index f1ad7b7e978d38..819a560d2b871c 100644 --- a/pkgs/by-name/rr/rrootage/package.nix +++ b/pkgs/by-name/rr/rrootage/package.nix @@ -1,15 +1,26 @@ -{ lib, stdenv, fetchpatch, fetchurl, SDL, SDL_mixer, bulletml }: +{ + lib, + stdenv, + fetchpatch, + fetchurl, + SDL, + SDL_mixer, + bulletml, +}: let version = "0.23a"; debianRevision = "12"; - debianPatch = patchname: hash: fetchpatch { - name = "${patchname}.patch"; - url = "https://sources.debian.org/data/main/r/rrootage/${version}-${debianRevision}/debian/patches/${patchname}.patch"; - sha256 = hash; - }; + debianPatch = + patchname: hash: + fetchpatch { + name = "${patchname}.patch"; + url = "https://sources.debian.org/data/main/r/rrootage/${version}-${debianRevision}/debian/patches/${patchname}.patch"; + sha256 = hash; + }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "rrootage"; inherit version; src = fetchurl { @@ -18,36 +29,16 @@ in stdenv.mkDerivation { }; patches = [ - (debianPatch - "01_makefile" - "0wgplznx9kgb82skwqplpydbpallgrby3w662h52wky5zl0pyijj") - (debianPatch - "02_data_dir" - "12vw60s94by3f6k8pk45k555h4y7gzlqfds0a96nrrryammpgnq3") - (debianPatch - "03_texture_filename" - "1qxkxy6821xvanacf25mi43wj8nf40c1qiyavhc8av798xprpkjh") - (debianPatch - "04_home" - "0s15b0liv40jzjd9l4zsq688ky1yp9b1gmb1xhi3bih4y7q9awdz") - (debianPatch - "05_gcc" - "06ihgbfrklabs7cb6216w1jjb9sglv86iagzhhmyydwyph4fb782") - (debianPatch - "06_rrootage_highres" - "0ifjmh236yiv3g896nfwwydgcnq3njdb8ldah7s3jxp3xkpvwcga") - (debianPatch - "07_use_system_bulletml" - "1sxsl1yzx3msvz8mf0jk1vnahqb1ahq9drm391idgh0afy77l6j7") - (debianPatch - "08_windowed_mode" - "0knx4g445ngilsz4dvdkq69f5f8i2xv2fnmdmq037xd5rhfg0b23") - (debianPatch - "09_rootage_make_highres_default" - "1zqz8s54rl8jmqmvdi9c3ayfcma6qkbfkx5vw0fzyn268wcs022p") - (debianPatch - "10_deg_out_of_range" - "1wr76az4rlv1gaj9xdknzqcjazw6h8myqw6y3753q259hxbq4cah") + (debianPatch "01_makefile" "0wgplznx9kgb82skwqplpydbpallgrby3w662h52wky5zl0pyijj") + (debianPatch "02_data_dir" "12vw60s94by3f6k8pk45k555h4y7gzlqfds0a96nrrryammpgnq3") + (debianPatch "03_texture_filename" "1qxkxy6821xvanacf25mi43wj8nf40c1qiyavhc8av798xprpkjh") + (debianPatch "04_home" "0s15b0liv40jzjd9l4zsq688ky1yp9b1gmb1xhi3bih4y7q9awdz") + (debianPatch "05_gcc" "06ihgbfrklabs7cb6216w1jjb9sglv86iagzhhmyydwyph4fb782") + (debianPatch "06_rrootage_highres" "0ifjmh236yiv3g896nfwwydgcnq3njdb8ldah7s3jxp3xkpvwcga") + (debianPatch "07_use_system_bulletml" "1sxsl1yzx3msvz8mf0jk1vnahqb1ahq9drm391idgh0afy77l6j7") + (debianPatch "08_windowed_mode" "0knx4g445ngilsz4dvdkq69f5f8i2xv2fnmdmq037xd5rhfg0b23") + (debianPatch "09_rootage_make_highres_default" "1zqz8s54rl8jmqmvdi9c3ayfcma6qkbfkx5vw0fzyn268wcs022p") + (debianPatch "10_deg_out_of_range" "1wr76az4rlv1gaj9xdknzqcjazw6h8myqw6y3753q259hxbq4cah") ]; postPatch = '' substituteInPlace "src/screen.c" --replace "/usr/share/games/rrootage" "$out/share/games/rrootage" @@ -55,9 +46,19 @@ in stdenv.mkDerivation { substituteInPlace "src/barragemanager.cc" --replace "/usr/share/games/rrootage" "$out/share/games/rrootage" ''; - buildInputs = [ SDL SDL_mixer bulletml ]; - makeFlags = [ "-C src" "-f makefile.lin" ]; - hardeningDisable = [ "stackprotector" "fortify" ]; # buffer overflow without this + buildInputs = [ + SDL + SDL_mixer + bulletml + ]; + makeFlags = [ + "-C src" + "-f makefile.lin" + ]; + hardeningDisable = [ + "stackprotector" + "fortify" + ]; # buffer overflow without this installPhase = '' install -d "$out"/share/games diff --git a/pkgs/by-name/rs/rs-git-fsmonitor/package.nix b/pkgs/by-name/rs/rs-git-fsmonitor/package.nix index ffde4f16f157c9..77ebac70578abb 100644 --- a/pkgs/by-name/rs/rs-git-fsmonitor/package.nix +++ b/pkgs/by-name/rs/rs-git-fsmonitor/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, makeWrapper -, watchman +{ + lib, + fetchFromGitHub, + rustPlatform, + makeWrapper, + watchman, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/rs/rs-tftpd/package.nix b/pkgs/by-name/rs/rs-tftpd/package.nix index 79b5180c065a84..6dfc92961a40d2 100644 --- a/pkgs/by-name/rs/rs-tftpd/package.nix +++ b/pkgs/by-name/rs/rs-tftpd/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, nix-update-script +{ + lib, + rustPlatform, + fetchFromGitHub, + nix-update-script, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,7 @@ rustPlatform.buildRustPackage rec { buildFeatures = [ "client" ]; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = with lib; { description = "TFTP Server Daemon implemented in Rust"; diff --git a/pkgs/by-name/rs/rs/package.nix b/pkgs/by-name/rs/rs/package.nix index ab5e4fcb4ddd26..35596386ecab32 100644 --- a/pkgs/by-name/rs/rs/package.nix +++ b/pkgs/by-name/rs/rs/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, installShellFiles -, libbsd +{ + lib, + stdenv, + fetchurl, + installShellFiles, + libbsd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/rs/rsass/package.nix b/pkgs/by-name/rs/rsass/package.nix index b71dca0b3953ef..2198ac273cf42e 100644 --- a/pkgs/by-name/rs/rsass/package.nix +++ b/pkgs/by-name/rs/rsass/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "rsass"; @@ -17,7 +21,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "rsass"; homepage = "https://github.com/kaj/rsass"; changelog = "https://github.com/kaj/rsass/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/rs/rsbep/package.nix b/pkgs/by-name/rs/rsbep/package.nix index b30ddddb2b07f0..0327871f807e5a 100644 --- a/pkgs/by-name/rs/rsbep/package.nix +++ b/pkgs/by-name/rs/rsbep/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, coreutils, gawk, fetchFromGitHub }: +{ + lib, + stdenv, + coreutils, + gawk, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "rsbep"; @@ -20,7 +26,12 @@ stdenv.mkDerivation rec { mv rsbep_chopper $libexecDir # Fix store dependencies in scripts - path="export PATH=$out/bin:$libexecDir:${lib.makeBinPath [ coreutils gawk ]}" + path="export PATH=$out/bin:$libexecDir:${ + lib.makeBinPath [ + coreutils + gawk + ] + }" sed -i "2i$path" freeze.sh sed -i "2i$path" melt.sh diff --git a/pkgs/by-name/rs/rsbkb/package.nix b/pkgs/by-name/rs/rsbkb/package.nix index 5da4d8dd2a3456..1e05dbd157219a 100644 --- a/pkgs/by-name/rs/rsbkb/package.nix +++ b/pkgs/by-name/rs/rsbkb/package.nix @@ -1,12 +1,14 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, enableAppletSymlinks ? true +{ + lib, + fetchFromGitHub, + rustPlatform, + enableAppletSymlinks ? true, }: let version = "1.4"; -in rustPlatform.buildRustPackage { +in +rustPlatform.buildRustPackage { pname = "rsbkb"; inherit version; diff --git a/pkgs/by-name/rs/rsclock/package.nix b/pkgs/by-name/rs/rsclock/package.nix index a8d0a89d4800f2..ecc2f2f6ae58f3 100644 --- a/pkgs/by-name/rs/rsclock/package.nix +++ b/pkgs/by-name/rs/rsclock/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "rsClock"; @@ -17,7 +21,7 @@ rustPlatform.buildRustPackage rec { description = "Simple terminal clock written in Rust"; homepage = "https://github.com/valebes/rsClock"; license = licenses.mit; - maintainers = with maintainers; [valebes]; + maintainers = with maintainers; [ valebes ]; mainProgram = "rsclock"; }; } diff --git a/pkgs/by-name/rs/rscw/package.nix b/pkgs/by-name/rs/rscw/package.nix index 7fe638df61d0c6..1945db62b91750 100644 --- a/pkgs/by-name/rs/rscw/package.nix +++ b/pkgs/by-name/rs/rscw/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, fftw -, gtk2 -, pkg-config +{ + lib, + stdenv, + fetchurl, + fftw, + gtk2, + pkg-config, }: stdenv.mkDerivation rec { @@ -18,7 +19,10 @@ stdenv.mkDerivation rec { sourceRoot = "."; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk2 fftw ]; + buildInputs = [ + gtk2 + fftw + ]; installPhase = '' install -D -m 0755 noisycw $out/bin/noisycw diff --git a/pkgs/by-name/rs/rset/package.nix b/pkgs/by-name/rs/rset/package.nix index 2d6a8da445c1fc..3b820b49e9de02 100644 --- a/pkgs/by-name/rs/rset/package.nix +++ b/pkgs/by-name/rs/rset/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, coreutils, openssh, gnutar }: +{ + lib, + stdenv, + fetchurl, + coreutils, + openssh, + gnutar, +}: stdenv.mkDerivation rec { pname = "rset"; diff --git a/pkgs/by-name/rs/rsgain/package.nix b/pkgs/by-name/rs/rsgain/package.nix index 0d58a47e8b6bb7..caa5271fbe7801 100644 --- a/pkgs/by-name/rs/rsgain/package.nix +++ b/pkgs/by-name/rs/rsgain/package.nix @@ -1,37 +1,48 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, cmake -, libebur128 -, taglib -, ffmpeg -, inih -, fmt -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + libebur128, + taglib, + ffmpeg, + inih, + fmt, + zlib, }: stdenv.mkDerivation rec { - pname = "rsgain"; - version = "3.5.3"; + pname = "rsgain"; + version = "3.5.3"; - src = fetchFromGitHub { - owner = "complexlogic"; - repo = "rsgain"; - rev = "v${version}"; - hash = "sha256-4LEvcuP2Eyco3iQvT6rZhbfY02Y70rW2n5PaS+rGDkQ="; - }; + src = fetchFromGitHub { + owner = "complexlogic"; + repo = "rsgain"; + rev = "v${version}"; + hash = "sha256-4LEvcuP2Eyco3iQvT6rZhbfY02Y70rW2n5PaS+rGDkQ="; + }; - nativeBuildInputs = [pkg-config cmake]; - buildInputs = [libebur128 taglib ffmpeg inih fmt zlib]; + nativeBuildInputs = [ + pkg-config + cmake + ]; + buildInputs = [ + libebur128 + taglib + ffmpeg + inih + fmt + zlib + ]; - meta = with lib; { - description = "Simple, but powerful ReplayGain 2.0 tagging utility"; - mainProgram = "rsgain"; - homepage = "https://github.com/complexlogic/rsgain"; - changelog = "https://github.com/complexlogic/rsgain/blob/v${version}/CHANGELOG"; - license = licenses.bsd2; - platforms = platforms.all; - maintainers = [maintainers.felipeqq2]; - }; + meta = with lib; { + description = "Simple, but powerful ReplayGain 2.0 tagging utility"; + mainProgram = "rsgain"; + homepage = "https://github.com/complexlogic/rsgain"; + changelog = "https://github.com/complexlogic/rsgain/blob/v${version}/CHANGELOG"; + license = licenses.bsd2; + platforms = platforms.all; + maintainers = [ maintainers.felipeqq2 ]; + }; } diff --git a/pkgs/by-name/rs/rshijack/package.nix b/pkgs/by-name/rs/rshijack/package.nix index 6984d538c5d40b..ebb47ead1c54a2 100644 --- a/pkgs/by-name/rs/rshijack/package.nix +++ b/pkgs/by-name/rs/rshijack/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "rshijack"; diff --git a/pkgs/by-name/rs/rshim-user-space/package.nix b/pkgs/by-name/rs/rshim-user-space/package.nix index 75ff19f1bc36fb..82a6e55aaea470 100644 --- a/pkgs/by-name/rs/rshim-user-space/package.nix +++ b/pkgs/by-name/rs/rshim-user-space/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoconf -, automake -, makeBinaryWrapper -, pkg-config -, pciutils -, libusb1 -, fuse -, busybox -, pv -, withBfbInstall ? true +{ + stdenv, + lib, + fetchFromGitHub, + autoconf, + automake, + makeBinaryWrapper, + pkg-config, + pciutils, + libusb1, + fuse, + busybox, + pv, + withBfbInstall ? true, }: stdenv.mkDerivation rec { @@ -44,16 +45,23 @@ stdenv.mkDerivation rec { preConfigure = "./bootstrap.sh"; - installPhase = '' - mkdir -p "$out"/bin - cp -a src/rshim "$out"/bin/ - '' + lib.optionalString withBfbInstall '' - cp -a scripts/bfb-install "$out"/bin/ - ''; + installPhase = + '' + mkdir -p "$out"/bin + cp -a src/rshim "$out"/bin/ + '' + + lib.optionalString withBfbInstall '' + cp -a scripts/bfb-install "$out"/bin/ + ''; postFixup = lib.optionalString withBfbInstall '' wrapProgram $out/bin/bfb-install \ - --set PATH ${lib.makeBinPath [ busybox pv ]} + --set PATH ${ + lib.makeBinPath [ + busybox + pv + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/rs/rsign2/package.nix b/pkgs/by-name/rs/rsign2/package.nix index 10a526a7b2cb51..b548c092495a4a 100644 --- a/pkgs/by-name/rs/rsign2/package.nix +++ b/pkgs/by-name/rs/rsign2/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/rs/rslint/package.nix b/pkgs/by-name/rs/rslint/package.nix index 28dfadd4cd7527..667f3e491daa63 100644 --- a/pkgs/by-name/rs/rslint/package.nix +++ b/pkgs/by-name/rs/rslint/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "rslint"; @@ -14,8 +18,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-bqF5v52uxbvmVmphXAmcWlCI6nbQzZemCxlTcqhRDTY="; cargoBuildFlags = [ - "-p" "rslint_cli" - "-p" "rslint_lsp" + "-p" + "rslint_cli" + "-p" + "rslint_lsp" ]; meta = with lib; { diff --git a/pkgs/by-name/rs/rsmangler/package.nix b/pkgs/by-name/rs/rsmangler/package.nix index 7621eb14a752a0..32b0e65677ed0b 100644 --- a/pkgs/by-name/rs/rsmangler/package.nix +++ b/pkgs/by-name/rs/rsmangler/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, testers -, ruby +{ + lib, + stdenvNoCC, + fetchFromGitHub, + testers, + ruby, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/rs/rsnapshot/package.nix b/pkgs/by-name/rs/rsnapshot/package.nix index ff65d94fc11f90..012ad55a413443 100644 --- a/pkgs/by-name/rs/rsnapshot/package.nix +++ b/pkgs/by-name/rs/rsnapshot/package.nix @@ -1,4 +1,12 @@ -{ fetchurl, lib, stdenv, perl, openssh, rsync, logger }: +{ + fetchurl, + lib, + stdenv, + perl, + openssh, + rsync, + logger, +}: stdenv.mkDerivation rec { pname = "rsnapshot"; @@ -9,7 +17,12 @@ stdenv.mkDerivation rec { sha256 = "sha256-ELdeAcolUR6CZqrNSVUxl1rRqK1VYha2pXx20CizgkI="; }; - propagatedBuildInputs = [perl openssh rsync logger]; + propagatedBuildInputs = [ + perl + openssh + rsync + logger + ]; configureFlags = [ "--sysconfdir=/etc --prefix=/" ]; makeFlags = [ "DESTDIR=$(out)" ]; diff --git a/pkgs/by-name/rs/rsonpath/package.nix b/pkgs/by-name/rs/rsonpath/package.nix index 02a867788a4b79..c3f8e8bb5e04ef 100644 --- a/pkgs/by-name/rs/rsonpath/package.nix +++ b/pkgs/by-name/rs/rsonpath/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/rs/rspamd-trainer/package.nix b/pkgs/by-name/rs/rspamd-trainer/package.nix index e00bddcbfbceaf..11c8155a57c5b1 100644 --- a/pkgs/by-name/rs/rspamd-trainer/package.nix +++ b/pkgs/by-name/rs/rspamd-trainer/package.nix @@ -1,10 +1,11 @@ -{ lib -, python3 -, python3Packages -, fetchFromGitLab -, fetchpatch -, rspamd -, nixosTests +{ + lib, + python3, + python3Packages, + fetchFromGitLab, + fetchpatch, + rspamd, + nixosTests, }: python3Packages.buildPythonApplication { diff --git a/pkgs/by-name/rs/rss-bridge-cli/package.nix b/pkgs/by-name/rs/rss-bridge-cli/package.nix index e7714a21b1293f..fff9a2e9665a8c 100644 --- a/pkgs/by-name/rs/rss-bridge-cli/package.nix +++ b/pkgs/by-name/rs/rss-bridge-cli/package.nix @@ -1,28 +1,39 @@ -{ lib, writeShellScriptBin, rss-bridge, php }: +{ + lib, + writeShellScriptBin, + rss-bridge, + php, +}: let - phpWithExts = (php.withExtensions - ({ all, ... }: with all; [ - curl - filter - iconv - mbstring - openssl - simplexml - sqlite3 - ]) + phpWithExts = ( + php.withExtensions ( + { all, ... }: + with all; + [ + curl + filter + iconv + mbstring + openssl + simplexml + sqlite3 + ] + ) ); phpBin = "${phpWithExts}/bin/php"; -in (writeShellScriptBin "rss-bridge-cli" '' +in +(writeShellScriptBin "rss-bridge-cli" '' ${phpBin} ${rss-bridge}/index.php "$@" -'').overrideAttrs (oldAttrs: rec { - version = rss-bridge.version; +'').overrideAttrs + (oldAttrs: rec { + version = rss-bridge.version; - meta = with lib; { - description = "Command-line interface for RSS-Bridge"; - homepage = "https://github.com/RSS-Bridge/rss-bridge"; - license = licenses.unlicense; - maintainers = with maintainers; [ ymeister ]; - mainProgram = "rss-bridge-cli"; - }; -}) + meta = with lib; { + description = "Command-line interface for RSS-Bridge"; + homepage = "https://github.com/RSS-Bridge/rss-bridge"; + license = licenses.unlicense; + maintainers = with maintainers; [ ymeister ]; + mainProgram = "rss-bridge-cli"; + }; + }) diff --git a/pkgs/by-name/rs/rss-bridge/package.nix b/pkgs/by-name/rs/rss-bridge/package.nix index 6d5be6e40233b4..0db4808b502e4f 100644 --- a/pkgs/by-name/rs/rss-bridge/package.nix +++ b/pkgs/by-name/rs/rss-bridge/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, nixosTests, nix-update-script }: +{ + stdenv, + lib, + fetchFromGitHub, + nixosTests, + nix-update-script, +}: stdenv.mkDerivation rec { pname = "rss-bridge"; @@ -27,7 +33,10 @@ stdenv.mkDerivation rec { description = "RSS feed for websites missing it"; homepage = "https://github.com/RSS-Bridge/rss-bridge"; license = licenses.unlicense; - maintainers = with maintainers; [ dawidsowa mynacol ]; + maintainers = with maintainers; [ + dawidsowa + mynacol + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/rs/rss-glx/package.nix b/pkgs/by-name/rs/rss-glx/package.nix index f8e0479b36c2ae..d59b6f3b2c616f 100644 --- a/pkgs/by-name/rs/rss-glx/package.nix +++ b/pkgs/by-name/rs/rss-glx/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, autoconf -, pkg-config -, libX11 -, libXext -, libGLU -, libGL -, imagemagick6 -, libtiff -, bzip2 +{ + lib, + stdenv, + fetchurl, + autoconf, + pkg-config, + libX11, + libXext, + libGLU, + libGL, + imagemagick6, + libtiff, + bzip2, }: stdenv.mkDerivation rec { @@ -21,8 +22,19 @@ stdenv.mkDerivation rec { sha256 = "1aikafjqrfmv23jnrrm5d56dg6injh4l67zjdxzdapv9chw7g3cg"; }; - nativeBuildInputs = [ autoconf pkg-config ]; - buildInputs = [ libGLU libGL libX11 libXext imagemagick6 libtiff bzip2 ]; + nativeBuildInputs = [ + autoconf + pkg-config + ]; + buildInputs = [ + libGLU + libGL + libX11 + libXext + imagemagick6 + libtiff + bzip2 + ]; patches = [ ./cstddef.patch diff --git a/pkgs/by-name/rs/rsstail/package.nix b/pkgs/by-name/rs/rsstail/package.nix index c654bd4e8a1d92..a2c7d2d2e70474 100644 --- a/pkgs/by-name/rs/rsstail/package.nix +++ b/pkgs/by-name/rs/rsstail/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libmrss }: +{ + lib, + stdenv, + fetchFromGitHub, + libmrss, +}: stdenv.mkDerivation (final: { pname = "rsstail"; diff --git a/pkgs/by-name/rs/rstfmt/package.nix b/pkgs/by-name/rs/rstfmt/package.nix index f69c8c69bd5fe5..868dbc5a558b35 100644 --- a/pkgs/by-name/rs/rstfmt/package.nix +++ b/pkgs/by-name/rs/rstfmt/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/rt/rt-tests/package.nix b/pkgs/by-name/rt/rt-tests/package.nix index 16970a15b1d81f..8bc5d3b47f3984 100644 --- a/pkgs/by-name/rt/rt-tests/package.nix +++ b/pkgs/by-name/rt/rt-tests/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, makeWrapper -, fetchurl -, numactl -, python3 +{ + stdenv, + lib, + makeWrapper, + fetchurl, + numactl, + python3, }: stdenv.mkDerivation rec { @@ -16,9 +17,16 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ numactl python3 ]; + buildInputs = [ + numactl + python3 + ]; - makeFlags = [ "prefix=$(out)" "DESTDIR=" "PYLIB=$(out)/${python3.sitePackages}" ]; + makeFlags = [ + "prefix=$(out)" + "DESTDIR=" + "PYLIB=$(out)/${python3.sitePackages}" + ]; postInstall = '' wrapProgram "$out/bin/determine_maximum_mpps.sh" --prefix PATH : $out/bin diff --git a/pkgs/by-name/rt/rt/package.nix b/pkgs/by-name/rt/rt/package.nix index 59933570d7b15c..d2b0752f9b2233 100644 --- a/pkgs/by-name/rt/rt/package.nix +++ b/pkgs/by-name/rt/rt/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, autoreconfHook, buildEnv, fetchFromGitHub, perl, perlPackages, makeWrapper, gnupg, openssl }: +{ + lib, + stdenv, + autoreconfHook, + buildEnv, + fetchFromGitHub, + perl, + perlPackages, + makeWrapper, + gnupg, + openssl, +}: stdenv.mkDerivation rec { pname = "rt"; @@ -12,7 +23,7 @@ stdenv.mkDerivation rec { }; patches = [ - ./dont-check-users_groups.patch # needed for "make testdeps" to work in the build + ./dont-check-users_groups.patch # needed for "make testdeps" to work in the build ./override-generated.patch ]; @@ -25,97 +36,99 @@ stdenv.mkDerivation rec { perl (buildEnv { name = "rt-perl-deps"; - paths = with perlPackages; (requiredPerlModules [ - ApacheSession - BusinessHours - CGIEmulatePSGI - CGIPSGI - CSSMinifierXS - CSSSquish - ConvertColor - CryptEksblowfish - CryptSSLeay - CryptX509 - DBDPg - DBIxSearchBuilder - DataGUID - DataICal - DataPage - DataPagePageset - DateExtract - DateManip - DateTimeFormatNatural - DevelGlobalDestruction - EmailAddress - EmailAddressList - EncodeDetect - EncodeHanExtra - FCGI - FCGIProcManager - FileShareDir - FileWhich - GD - GDGraph - GnuPGInterface - GraphViz2 - HTMLFormatExternal - HTMLFormatTextWithLinks - HTMLFormatTextWithLinksAndTables - HTMLGumbo - HTMLMason - HTMLMasonPSGIHandler - HTMLQuoted - HTMLRewriteAttributes - HTMLScrubber - IPCRun - IPCRun3 - JSON - JavaScriptMinifierXS - LWP - LWPProtocolHttps - LocaleMaketextFuzzy - LocaleMaketextLexicon - LogDispatch - MIMETools - MIMETypes - MailTools - ModulePath - ModuleRefresh - ModuleVersionsReport - Moose - MooseXNonMoose - MooseXRoleParameterized - MozillaCA - NetCIDR - NetIP - ParallelForkManager - PathDispatcher - PerlIOeol - Plack - PodParser - RegexpCommon - RegexpCommonnetCIDR - RegexpIPv6 - RoleBasic - ScopeUpper - Starlet - Starman - StringShellQuote - SymbolGlobalName - TermReadKey - TextPasswordPronounceable - TextQuoted - TextTemplate - TextWikiFormat - TextWordDiff - TextWrapper - TimeParseDate - TreeSimple - UNIVERSALrequire - WebMachine - XMLRSS - perlldap - ]); + paths = + with perlPackages; + (requiredPerlModules [ + ApacheSession + BusinessHours + CGIEmulatePSGI + CGIPSGI + CSSMinifierXS + CSSSquish + ConvertColor + CryptEksblowfish + CryptSSLeay + CryptX509 + DBDPg + DBIxSearchBuilder + DataGUID + DataICal + DataPage + DataPagePageset + DateExtract + DateManip + DateTimeFormatNatural + DevelGlobalDestruction + EmailAddress + EmailAddressList + EncodeDetect + EncodeHanExtra + FCGI + FCGIProcManager + FileShareDir + FileWhich + GD + GDGraph + GnuPGInterface + GraphViz2 + HTMLFormatExternal + HTMLFormatTextWithLinks + HTMLFormatTextWithLinksAndTables + HTMLGumbo + HTMLMason + HTMLMasonPSGIHandler + HTMLQuoted + HTMLRewriteAttributes + HTMLScrubber + IPCRun + IPCRun3 + JSON + JavaScriptMinifierXS + LWP + LWPProtocolHttps + LocaleMaketextFuzzy + LocaleMaketextLexicon + LogDispatch + MIMETools + MIMETypes + MailTools + ModulePath + ModuleRefresh + ModuleVersionsReport + Moose + MooseXNonMoose + MooseXRoleParameterized + MozillaCA + NetCIDR + NetIP + ParallelForkManager + PathDispatcher + PerlIOeol + Plack + PodParser + RegexpCommon + RegexpCommonnetCIDR + RegexpIPv6 + RoleBasic + ScopeUpper + Starlet + Starman + StringShellQuote + SymbolGlobalName + TermReadKey + TextPasswordPronounceable + TextQuoted + TextTemplate + TextWikiFormat + TextWordDiff + TextWrapper + TimeParseDate + TreeSimple + UNIVERSALrequire + WebMachine + XMLRSS + perlldap + ]); }) ]; @@ -145,7 +158,12 @@ stdenv.mkDerivation rec { postFixup = '' for i in $(find $out/bin -type f); do wrapProgram $i --prefix PERL5LIB ':' $PERL5LIB \ - --prefix PATH ":" "${lib.makeBinPath [ openssl gnupg ]}" + --prefix PATH ":" "${ + lib.makeBinPath [ + openssl + gnupg + ] + }" done rm -r $out/var diff --git a/pkgs/by-name/rt/rt5677-firmware/package.nix b/pkgs/by-name/rt/rt5677-firmware/package.nix index 47e0068cc3483c..675e42660adaf3 100644 --- a/pkgs/by-name/rt/rt5677-firmware/package.nix +++ b/pkgs/by-name/rt/rt5677-firmware/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { name = "rt5677-firmware"; diff --git a/pkgs/by-name/rt/rtaudio_6/package.nix b/pkgs/by-name/rt/rtaudio_6/package.nix index a8b5f61cc76604..e1fffde9adc014 100644 --- a/pkgs/by-name/rt/rtaudio_6/package.nix +++ b/pkgs/by-name/rt/rtaudio_6/package.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, config -, fetchFromGitHub -, testers -, cmake -, pkg-config -, alsaSupport ? stdenv.hostPlatform.isLinux -, alsa-lib -, pulseaudioSupport ? config.pulseaudio or stdenv.hostPlatform.isLinux -, libpulseaudio -, jackSupport ? true -, libjack2 -, coreaudioSupport ? stdenv.hostPlatform.isDarwin -, darwin -, validatePkgConfig +{ + stdenv, + lib, + config, + fetchFromGitHub, + testers, + cmake, + pkg-config, + alsaSupport ? stdenv.hostPlatform.isLinux, + alsa-lib, + pulseaudioSupport ? config.pulseaudio or stdenv.hostPlatform.isLinux, + libpulseaudio, + jackSupport ? true, + libjack2, + coreaudioSupport ? stdenv.hostPlatform.isDarwin, + darwin, + validatePkgConfig, }: stdenv.mkDerivation (finalAttrs: { @@ -35,15 +36,19 @@ stdenv.mkDerivation (finalAttrs: { validatePkgConfig ]; - buildInputs = lib.optionals alsaSupport [ - alsa-lib - ] ++ lib.optionals pulseaudioSupport [ - libpulseaudio - ] ++ lib.optionals jackSupport [ - libjack2 - ] ++ lib.optionals coreaudioSupport [ - darwin.apple_sdk.frameworks.CoreAudio - ]; + buildInputs = + lib.optionals alsaSupport [ + alsa-lib + ] + ++ lib.optionals pulseaudioSupport [ + libpulseaudio + ] + ++ lib.optionals jackSupport [ + libjack2 + ] + ++ lib.optionals coreaudioSupport [ + darwin.apple_sdk.frameworks.CoreAudio + ]; cmakeFlags = [ (lib.cmakeBool "RTAUDIO_API_ALSA" alsaSupport) diff --git a/pkgs/by-name/rt/rtfm/package.nix b/pkgs/by-name/rt/rtfm/package.nix index 655dd90fdb342e..d097bf8f249947 100644 --- a/pkgs/by-name/rt/rtfm/package.nix +++ b/pkgs/by-name/rt/rtfm/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, crystal -, wrapGAppsHook4 -, gobject-introspection -, desktopToDarwinBundle -, webkitgtk_6_0 -, sqlite -, libadwaita -, gtk4 -, pango -, substituteAll +{ + stdenv, + lib, + fetchFromGitHub, + crystal, + wrapGAppsHook4, + gobject-introspection, + desktopToDarwinBundle, + webkitgtk_6_0, + sqlite, + libadwaita, + gtk4, + pango, + substituteAll, }: let gtk4' = gtk4.override { x11Support = true; }; @@ -62,7 +63,11 @@ crystal.buildCrystalPackage rec { pango' ]; - buildTargets = [ "configure" "rtfm" "docsets" ]; + buildTargets = [ + "configure" + "rtfm" + "docsets" + ]; preBuild = '' mkdir gtk-doc/ diff --git a/pkgs/by-name/rt/rtkit/package.nix b/pkgs/by-name/rt/rtkit/package.nix index 12dc6bbe392f12..53c5fe6f8235bb 100644 --- a/pkgs/by-name/rt/rtkit/package.nix +++ b/pkgs/by-name/rt/rtkit/package.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, meson, ninja, pkg-config, unixtools -, dbus, libcap, polkit, systemd +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + meson, + ninja, + pkg-config, + unixtools, + dbus, + libcap, + polkit, + systemd, }: stdenv.mkDerivation rec { @@ -20,8 +30,18 @@ stdenv.mkDerivation rec { ./rtkit-daemon-dont-log-debug-messages-by-default.patch ]; - nativeBuildInputs = [ meson ninja pkg-config unixtools.xxd ]; - buildInputs = [ dbus libcap polkit systemd ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + unixtools.xxd + ]; + buildInputs = [ + dbus + libcap + polkit + systemd + ]; mesonFlags = [ "-Dinstalled_tests=false" @@ -37,7 +57,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/heftig/rtkit"; description = "Daemon that hands out real-time priority to processes"; mainProgram = "rtkitctl"; - license = with licenses; [ gpl3 bsd0 ]; # lib is bsd license + license = with licenses; [ + gpl3 + bsd0 + ]; # lib is bsd license platforms = platforms.linux; }; } diff --git a/pkgs/by-name/rt/rtl-ais/package.nix b/pkgs/by-name/rt/rtl-ais/package.nix index 57cd7420d7542d..87a6ccfc9e7c83 100644 --- a/pkgs/by-name/rt/rtl-ais/package.nix +++ b/pkgs/by-name/rt/rtl-ais/package.nix @@ -1,10 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, libusb1, rtl-sdr }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libusb1, + rtl-sdr, +}: stdenv.mkDerivation { pname = "rtl-ais"; version = "0.8.1"; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ rtl-sdr libusb1 ]; + buildInputs = [ + rtl-sdr + libusb1 + ]; src = fetchFromGitHub { owner = "dgiardini"; diff --git a/pkgs/by-name/rt/rtl8192su-firmware/package.nix b/pkgs/by-name/rt/rtl8192su-firmware/package.nix index 49a3b9c13ac4fe..1d6642deabb5d2 100644 --- a/pkgs/by-name/rt/rtl8192su-firmware/package.nix +++ b/pkgs/by-name/rt/rtl8192su-firmware/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "rtl8192su"; version = "unstable-2016-10-05"; diff --git a/pkgs/by-name/rt/rtl8761b-firmware/package.nix b/pkgs/by-name/rt/rtl8761b-firmware/package.nix index c3fbe79537c469..56ffafe1e9a2b3 100644 --- a/pkgs/by-name/rt/rtl8761b-firmware/package.nix +++ b/pkgs/by-name/rt/rtl8761b-firmware/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { name = "rtl8761b-firmware"; diff --git a/pkgs/by-name/rt/rtl_433/package.nix b/pkgs/by-name/rt/rtl_433/package.nix index c1a5f1cea877aa..cb77ea75658d9d 100644 --- a/pkgs/by-name/rt/rtl_433/package.nix +++ b/pkgs/by-name/rt/rtl_433/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config -, libusb1, rtl-sdr, soapysdr-with-plugins +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libusb1, + rtl-sdr, + soapysdr-with-plugins, }: stdenv.mkDerivation rec { @@ -13,9 +20,16 @@ stdenv.mkDerivation rec { hash = "sha256-o4eAG6iYK4JXbh9JRv5NLmSxg396ErH++H0J8tTXiUA="; }; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; - buildInputs = [ libusb1 rtl-sdr soapysdr-with-plugins ]; + buildInputs = [ + libusb1 + rtl-sdr + soapysdr-with-plugins + ]; doCheck = true; @@ -23,7 +37,10 @@ stdenv.mkDerivation rec { description = "Decode traffic from devices that broadcast on 433.9 MHz, 868 MHz, 315 MHz, 345 MHz and 915 MHz"; homepage = "https://github.com/merbanan/rtl_433"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ earldouglas markuskowa ]; + maintainers = with maintainers; [ + earldouglas + markuskowa + ]; platforms = platforms.all; mainProgram = "rtl_433"; }; diff --git a/pkgs/by-name/rt/rtl_fm_streamer/package.nix b/pkgs/by-name/rt/rtl_fm_streamer/package.nix index beb45686508a0b..d2505587201a5b 100644 --- a/pkgs/by-name/rt/rtl_fm_streamer/package.nix +++ b/pkgs/by-name/rt/rtl_fm_streamer/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, libusb1 -, libev +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libusb1, + libev, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/rt/rtlcss/package.nix b/pkgs/by-name/rt/rtlcss/package.nix index 4143e649ea5c78..8e39dc0c959d75 100644 --- a/pkgs/by-name/rt/rtlcss/package.nix +++ b/pkgs/by-name/rt/rtlcss/package.nix @@ -1,4 +1,9 @@ -{ buildNpmPackage, fetchFromGitHub, lib, ... }: +{ + buildNpmPackage, + fetchFromGitHub, + lib, + ... +}: buildNpmPackage rec { pname = "rtlcss"; diff --git a/pkgs/by-name/rt/rtptools/package.nix b/pkgs/by-name/rt/rtptools/package.nix index c7d0a991a9e14c..2eb78c0a80bc82 100644 --- a/pkgs/by-name/rt/rtptools/package.nix +++ b/pkgs/by-name/rt/rtptools/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchurl }: +{ + stdenv, + lib, + fetchurl, +}: stdenv.mkDerivation rec { pname = "rtptools"; version = "1.22"; diff --git a/pkgs/by-name/rt/rtrlib/package.nix b/pkgs/by-name/rt/rtrlib/package.nix index 2f0ae61b9a9c3d..03cb328651b838 100644 --- a/pkgs/by-name/rt/rtrlib/package.nix +++ b/pkgs/by-name/rt/rtrlib/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, stdenv, cmake, libssh, openssl }: +{ + lib, + fetchFromGitHub, + stdenv, + cmake, + libssh, + openssl, +}: stdenv.mkDerivation rec { pname = "rtrlib"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libssh openssl ]; + buildInputs = [ + libssh + openssl + ]; postFixup = '' substituteInPlace "$out"/lib/pkgconfig/rtrlib.pc \ diff --git a/pkgs/by-name/rt/rtss/package.nix b/pkgs/by-name/rt/rtss/package.nix index 5545d90281cdfb..3e30aa0dd59262 100644 --- a/pkgs/by-name/rt/rtss/package.nix +++ b/pkgs/by-name/rt/rtss/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "rtss"; diff --git a/pkgs/by-name/rt/rttr/package.nix b/pkgs/by-name/rt/rttr/package.nix index de4d81918cd08a..cc8d057d86511a 100644 --- a/pkgs/by-name/rt/rttr/package.nix +++ b/pkgs/by-name/rt/rttr/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, ninja }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, +}: stdenv.mkDerivation rec { pname = "rttr"; diff --git a/pkgs/by-name/rt/rtz/package.nix b/pkgs/by-name/rt/rtz/package.nix index a5f55342a13a27..d48fa2dadd62f5 100644 --- a/pkgs/by-name/rt/rtz/package.nix +++ b/pkgs/by-name/rt/rtz/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, fetchurl -, pkg-config -, bzip2 -, openssl -, zstd -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + fetchurl, + pkg-config, + bzip2, + openssl, + zstd, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -32,14 +33,16 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - bzip2 - openssl - zstd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + bzip2 + openssl + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; buildFeatures = [ "web" ]; diff --git a/pkgs/by-name/ru/ruapu/package.nix b/pkgs/by-name/ru/ruapu/package.nix index cae2203d72454d..4b688ce9fd6399 100644 --- a/pkgs/by-name/ru/ruapu/package.nix +++ b/pkgs/by-name/ru/ruapu/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ru/rubber/package.nix b/pkgs/by-name/ru/rubber/package.nix index 641dade6457f79..e2febe3d0b939a 100644 --- a/pkgs/by-name/ru/rubber/package.nix +++ b/pkgs/by-name/ru/rubber/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitLab, python3Packages, texinfo }: +{ + lib, + stdenv, + fetchFromGitLab, + python3Packages, + texinfo, +}: let pypkgs = python3Packages; @@ -23,7 +29,10 @@ pypkgs.buildPythonApplication rec { --replace-fail /var/tmp /tmp ''; - nativeBuildInputs = [ pypkgs.hatchling texinfo ]; + nativeBuildInputs = [ + pypkgs.hatchling + texinfo + ]; checkPhase = '' runHook preCheck @@ -48,7 +57,10 @@ pypkgs.buildPythonApplication rec { ''; license = licenses.gpl2Plus; homepage = "https://gitlab.com/latex-rubber/rubber"; - maintainers = with maintainers; [ ttuegel peterhoeg ]; + maintainers = with maintainers; [ + ttuegel + peterhoeg + ]; platforms = platforms.unix; mainProgram = "rubber"; }; diff --git a/pkgs/by-name/ru/rubik/package.nix b/pkgs/by-name/ru/rubik/package.nix index d77753f515de11..5528829d28adf4 100644 --- a/pkgs/by-name/ru/rubik/package.nix +++ b/pkgs/by-name/ru/rubik/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchurl }: +{ + stdenv, + lib, + fetchurl, +}: let # Latest commit touching the rubik tree commit = "054aa9d546cd6308f8ff7139b332490e0967aebe"; diff --git a/pkgs/by-name/ru/rubiks/package.nix b/pkgs/by-name/ru/rubiks/package.nix index a3fba32d05c3e2..7d158c95aead7e 100644 --- a/pkgs/by-name/ru/rubiks/package.nix +++ b/pkgs/by-name/ru/rubiks/package.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchurl -, fetchpatch -, coreutils -, dos2unix +{ + lib, + stdenv, + fetchurl, + fetchpatch, + coreutils, + dos2unix, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ru/rubyripper/package.nix b/pkgs/by-name/ru/rubyripper/package.nix index a30eca6a7686ce..453f171ae9010b 100644 --- a/pkgs/by-name/ru/rubyripper/package.nix +++ b/pkgs/by-name/ru/rubyripper/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper -, cdparanoia, cddiscid, ruby }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + cdparanoia, + cddiscid, + ruby, +}: stdenv.mkDerivation rec { version = "0.8.0rc3"; @@ -30,7 +37,13 @@ stdenv.mkDerivation rec { postFixup = '' wrapProgram $out/bin/rrip_cli \ - --prefix PATH : ${lib.makeBinPath [ cddiscid cdparanoia ruby ]} + --prefix PATH : ${ + lib.makeBinPath [ + cddiscid + cdparanoia + ruby + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/ru/rucksack/package.nix b/pkgs/by-name/ru/rucksack/package.nix index 1aad7a5c8da1b1..c6d84a6f296194 100644 --- a/pkgs/by-name/ru/rucksack/package.nix +++ b/pkgs/by-name/ru/rucksack/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, liblaxjson, cmake, freeimage }: +{ + lib, + stdenv, + fetchFromGitHub, + liblaxjson, + cmake, + freeimage, +}: stdenv.mkDerivation rec { version = "3.1.0"; @@ -12,11 +19,17 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ liblaxjson freeimage ]; + buildInputs = [ + liblaxjson + freeimage + ]; meta = with lib; { description = "Texture packer and resource bundler"; - platforms = [ "i686-linux" "x86_64-linux" ]; # fails on Darwin and AArch64 + platforms = [ + "i686-linux" + "x86_64-linux" + ]; # fails on Darwin and AArch64 homepage = "https://github.com/andrewrk/rucksack"; license = licenses.mit; maintainers = [ maintainers.andrewrk ]; diff --git a/pkgs/by-name/ru/run-scaled/package.nix b/pkgs/by-name/ru/run-scaled/package.nix index b9cdc20f78aa5d..fb86a8514c781d 100644 --- a/pkgs/by-name/ru/run-scaled/package.nix +++ b/pkgs/by-name/ru/run-scaled/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, bc, xorgserver, xpra, xrandr }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + bc, + xorgserver, + xpra, + xrandr, +}: stdenv.mkDerivation { version = "unstable-2018-06-03"; @@ -17,7 +26,12 @@ stdenv.mkDerivation { mkdir -p $out/bin cp run_scaled $out/bin wrapProgram $out/bin/run_scaled --prefix PATH ":" \ - ${lib.makeBinPath [ bc xorgserver xpra xrandr ]} + ${lib.makeBinPath [ + bc + xorgserver + xpra + xrandr + ]} ''; meta = with lib; { diff --git a/pkgs/by-name/ru/run/package.nix b/pkgs/by-name/ru/run/package.nix index 794fb32c5cfebd..759f97102aca85 100644 --- a/pkgs/by-name/ru/run/package.nix +++ b/pkgs/by-name/ru/run/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "run"; version = "0.11.2"; @@ -17,8 +21,11 @@ buildGoModule rec { meta = with lib; { description = "Easily manage and invoke small scripts and wrappers"; mainProgram = "run"; - homepage = "https://github.com/TekWizely/run"; - license = licenses.mit; - maintainers = with maintainers; [ rawkode Br1ght0ne ]; + homepage = "https://github.com/TekWizely/run"; + license = licenses.mit; + maintainers = with maintainers; [ + rawkode + Br1ght0ne + ]; }; } diff --git a/pkgs/by-name/ru/rund/package.nix b/pkgs/by-name/ru/rund/package.nix index ef0701d9343ed7..93ebb751e7d340 100644 --- a/pkgs/by-name/ru/rund/package.nix +++ b/pkgs/by-name/ru/rund/package.nix @@ -1,4 +1,10 @@ -{stdenv, lib, fetchFromGitHub, ldc ? null, dcompiler ? ldc }: +{ + stdenv, + lib, + fetchFromGitHub, + ldc ? null, + dcompiler ? ldc, +}: assert dcompiler != null; diff --git a/pkgs/by-name/ru/rune-languageserver/package.nix b/pkgs/by-name/ru/rune-languageserver/package.nix index 41977f89e90961..12582104d922a6 100644 --- a/pkgs/by-name/ru/rune-languageserver/package.nix +++ b/pkgs/by-name/ru/rune-languageserver/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchCrate -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -28,7 +29,10 @@ rustPlatform.buildRustPackage rec { description = "Language server for the Rune Language, an embeddable dynamic programming language for Rust"; homepage = "https://crates.io/crates/rune-languageserver"; changelog = "https://github.com/rune-rs/rune/releases/tag/${version}"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "rune-languageserver"; }; diff --git a/pkgs/by-name/ru/rune/package.nix b/pkgs/by-name/ru/rune/package.nix index 41d61aa9cc8b0f..dc0ca743448b73 100644 --- a/pkgs/by-name/ru/rune/package.nix +++ b/pkgs/by-name/ru/rune/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchCrate -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -30,7 +31,10 @@ rustPlatform.buildRustPackage rec { description = "Interpreter for the Rune Language, an embeddable dynamic programming language for Rust"; homepage = "https://rune-rs.github.io/"; changelog = "https://github.com/rune-rs/rune/releases/tag/${version}"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "rune"; }; diff --git a/pkgs/by-name/ru/runelite/package.nix b/pkgs/by-name/ru/runelite/package.nix index 101bfbe3b01abb..158cc94fb9ce25 100644 --- a/pkgs/by-name/ru/runelite/package.nix +++ b/pkgs/by-name/ru/runelite/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, makeDesktopItem -, makeWrapper -, maven -, jdk17 -, jre -, xorg -, gitUpdater -, libGL +{ + lib, + fetchFromGitHub, + makeDesktopItem, + makeWrapper, + maven, + jdk17, + jre, + xorg, + gitUpdater, + libGL, }: maven.buildMavenPackage rec { @@ -49,7 +50,12 @@ maven.buildMavenPackage rec { ln -s ${desktop}/share/applications/RuneLite.desktop $out/share/applications/RuneLite.desktop makeWrapper ${jre}/bin/java $out/bin/runelite \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ xorg.libXxf86vm libGL ]}" \ + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + xorg.libXxf86vm + libGL + ] + }" \ --add-flags "-jar $out/share/RuneLite.jar" ''; @@ -63,7 +69,10 @@ maven.buildMavenPackage rec { binaryNativeCode ]; license = lib.licenses.bsd2; - maintainers = with lib.maintainers; [ kmeakin moody ]; + maintainers = with lib.maintainers; [ + kmeakin + moody + ]; platforms = [ "x86_64-linux" ]; mainProgram = "runelite"; }; diff --git a/pkgs/by-name/ru/runescape/package.nix b/pkgs/by-name/ru/runescape/package.nix index 00296f7f9faca1..990466cb823233 100644 --- a/pkgs/by-name/ru/runescape/package.nix +++ b/pkgs/by-name/ru/runescape/package.nix @@ -1,27 +1,28 @@ -{ stdenv -, lib -, autoPatchelfHook -, buildFHSEnv -, cairo -, dpkg -, fetchurl -, gcc-unwrapped -, glib -, glibc -, gtk2-x11 -, libGL -, libpulseaudio -, libSM -, libXxf86vm -, libX11 -, openssl_1_1 -, pango -, SDL2 -, wrapGAppsHook3 -, xdg-utils -, xorg -, xorg_sys_opengl -, zlib +{ + stdenv, + lib, + autoPatchelfHook, + buildFHSEnv, + cairo, + dpkg, + fetchurl, + gcc-unwrapped, + glib, + glibc, + gtk2-x11, + libGL, + libpulseaudio, + libSM, + libXxf86vm, + libX11, + openssl_1_1, + pango, + SDL2, + wrapGAppsHook3, + xdg-utils, + xorg, + xorg_sys_opengl, + zlib, }: let @@ -93,7 +94,6 @@ let rm -r $out/usr ''; - meta = with lib; { description = "Launcher for RuneScape 3, the current main RuneScape"; homepage = "https://www.runescape.com/"; @@ -106,50 +106,50 @@ let in - /* +/* * We can patch the runescape launcher, but it downloads a client at runtime and checks it for changes. * For that we need use a buildFHSEnv. * FHS simulates a classic linux shell - */ - buildFHSEnv { - pname = "RuneScape"; - inherit (runescape) version; - targetPkgs = pkgs: [ - runescape - cairo - dpkg - gcc-unwrapped - glib - glibc - gtk2-x11 - libGL - libpulseaudio - libSM - libXxf86vm - libX11 - openssl_1_1 - pango - SDL2 - xdg-utils - xorg.libX11 - xorg_sys_opengl - zlib - ]; - multiPkgs = pkgs: [ libGL ]; - runScript = "runescape-launcher"; - extraInstallCommands = '' - mkdir -p "$out/share/applications" - cp ${runescape}/share/applications/runescape-launcher.desktop "$out/share/applications" - cp -r ${runescape}/share/icons "$out/share/icons" - substituteInPlace "$out/share/applications/runescape-launcher.desktop" \ - --replace "/usr/bin/runescape-launcher" "RuneScape" - ''; - - meta = with lib; { - description = "RuneScape Game Client (NXT) - Launcher for RuneScape 3"; - homepage = "https://www.runescape.com/"; - license = licenses.unfree; - maintainers = with maintainers; [ grburst ]; - platforms = [ "x86_64-linux" ]; - }; - } +*/ +buildFHSEnv { + pname = "RuneScape"; + inherit (runescape) version; + targetPkgs = pkgs: [ + runescape + cairo + dpkg + gcc-unwrapped + glib + glibc + gtk2-x11 + libGL + libpulseaudio + libSM + libXxf86vm + libX11 + openssl_1_1 + pango + SDL2 + xdg-utils + xorg.libX11 + xorg_sys_opengl + zlib + ]; + multiPkgs = pkgs: [ libGL ]; + runScript = "runescape-launcher"; + extraInstallCommands = '' + mkdir -p "$out/share/applications" + cp ${runescape}/share/applications/runescape-launcher.desktop "$out/share/applications" + cp -r ${runescape}/share/icons "$out/share/icons" + substituteInPlace "$out/share/applications/runescape-launcher.desktop" \ + --replace "/usr/bin/runescape-launcher" "RuneScape" + ''; + + meta = with lib; { + description = "RuneScape Game Client (NXT) - Launcher for RuneScape 3"; + homepage = "https://www.runescape.com/"; + license = licenses.unfree; + maintainers = with maintainers; [ grburst ]; + platforms = [ "x86_64-linux" ]; + }; +} diff --git a/pkgs/by-name/ru/runiq/package.nix b/pkgs/by-name/ru/runiq/package.nix index bcc7952d74b03c..ba807d84b2ef3d 100644 --- a/pkgs/by-name/ru/runiq/package.nix +++ b/pkgs/by-name/ru/runiq/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, stdenv, darwin }: +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "runiq"; diff --git a/pkgs/by-name/ru/runit/package.nix b/pkgs/by-name/ru/runit/package.nix index f300ab2a33ac02..9e8a971f81a1da 100644 --- a/pkgs/by-name/ru/runit/package.nix +++ b/pkgs/by-name/ru/runit/package.nix @@ -1,7 +1,11 @@ -{ lib, stdenv, fetchurl, darwin +{ + lib, + stdenv, + fetchurl, + darwin, -# Build runit-init as a static binary -, static ? false + # Build runit-init as a static binary + static ? false, }: stdenv.mkDerivation rec { @@ -17,23 +21,32 @@ stdenv.mkDerivation rec { ./fix-ar-ranlib.patch ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; sourceRoot = "admin/${pname}-${version}"; doCheck = true; - buildInputs = lib.optionals static [ stdenv.cc.libc stdenv.cc.libc.static ] ++ - lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.libs.utmp; + buildInputs = + lib.optionals static [ + stdenv.cc.libc + stdenv.cc.libc.static + ] + ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.libs.utmp; - postPatch = '' - sed -i "s,\(#define RUNIT\) .*,\1 \"$out/bin/runit\"," src/runit.h - # usernamespace sandbox of nix seems to conflict with runit's assumptions - # about unix users. Therefor skip the check - sed -i '/.\/chkshsgr/d' src/Makefile - '' + lib.optionalString (!static) '' - sed -i 's,-static,,g' src/Makefile - ''; + postPatch = + '' + sed -i "s,\(#define RUNIT\) .*,\1 \"$out/bin/runit\"," src/runit.h + # usernamespace sandbox of nix seems to conflict with runit's assumptions + # about unix users. Therefor skip the check + sed -i '/.\/chkshsgr/d' src/Makefile + '' + + lib.optionalString (!static) '' + sed -i 's,-static,,g' src/Makefile + ''; preBuild = '' cd src diff --git a/pkgs/by-name/ru/runitor/package.nix b/pkgs/by-name/ru/runitor/package.nix index d78417e6ee05fe..b5e157aca97027 100644 --- a/pkgs/by-name/ru/runitor/package.nix +++ b/pkgs/by-name/ru/runitor/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, runitor }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + runitor, +}: buildGoModule rec { pname = "runitor"; @@ -13,7 +19,9 @@ buildGoModule rec { }; ldflags = [ - "-s" "-w" "-X main.Version=v${version}" + "-s" + "-w" + "-X main.Version=v${version}" ]; passthru.tests.version = testers.testVersion { diff --git a/pkgs/by-name/ru/runningx/package.nix b/pkgs/by-name/ru/runningx/package.nix index 01c3bb5e0233d8..38fbc0c551cd96 100644 --- a/pkgs/by-name/ru/runningx/package.nix +++ b/pkgs/by-name/ru/runningx/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libX11 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libX11, +}: stdenv.mkDerivation { pname = "runningx"; diff --git a/pkgs/by-name/ru/runzip/package.nix b/pkgs/by-name/ru/runzip/package.nix index 90eb6d1013876d..7f196224b6763c 100644 --- a/pkgs/by-name/ru/runzip/package.nix +++ b/pkgs/by-name/ru/runzip/package.nix @@ -1,11 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, libzip, libiconv, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + libzip, + libiconv, + autoreconfHook, +}: stdenv.mkDerivation rec { version = "1.4"; pname = "runzip"; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ libiconv libzip ]; + buildInputs = [ + libiconv + libzip + ]; src = fetchFromGitHub { owner = "vlm"; diff --git a/pkgs/by-name/ru/rust-audit-info/package.nix b/pkgs/by-name/ru/rust-audit-info/package.nix index 381e6d5bc71d61..fb0d0b8bb8f380 100644 --- a/pkgs/by-name/ru/rust-audit-info/package.nix +++ b/pkgs/by-name/ru/rust-audit-info/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "rust-audit-info"; @@ -15,7 +19,10 @@ rustPlatform.buildRustPackage rec { description = "Command-line tool to extract the dependency trees embedded in binaries by cargo-auditable"; mainProgram = "rust-audit-info"; homepage = "https://github.com/rust-secure-code/cargo-auditable/tree/master/rust-audit-info"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ru/rust-code-analysis/package.nix b/pkgs/by-name/ru/rust-code-analysis/package.nix index 7427a8bd76d648..ecb56299faa92b 100644 --- a/pkgs/by-name/ru/rust-code-analysis/package.nix +++ b/pkgs/by-name/ru/rust-code-analysis/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "rust-code-analysis"; diff --git a/pkgs/by-name/ru/rust-petname/package.nix b/pkgs/by-name/ru/rust-petname/package.nix index 8879dd282cfaf5..8f9a1a4463d8d8 100644 --- a/pkgs/by-name/ru/rust-petname/package.nix +++ b/pkgs/by-name/ru/rust-petname/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "rust-petname"; diff --git a/pkgs/by-name/ru/rust-script/package.nix b/pkgs/by-name/ru/rust-script/package.nix index d9df9404fbca39..8e85fe0590451c 100644 --- a/pkgs/by-name/ru/rust-script/package.nix +++ b/pkgs/by-name/ru/rust-script/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "rust-script"; @@ -21,7 +25,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "rust-script"; homepage = "https://rust-script.org"; changelog = "https://github.com/fornwall/rust-script/releases/tag/${version}"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ru/rust-traverse/package.nix b/pkgs/by-name/ru/rust-traverse/package.nix index ffe10184710593..643324a8feb3bc 100644 --- a/pkgs/by-name/ru/rust-traverse/package.nix +++ b/pkgs/by-name/ru/rust-traverse/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, bzip2 -, zstd -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + bzip2, + zstd, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -25,12 +26,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - bzip2 - zstd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk_11_0.frameworks.Foundation - ]; + buildInputs = + [ + bzip2 + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk_11_0.frameworks.Foundation + ]; env = { ZSTD_SYS_USE_PKG_CONFIG = true; diff --git a/pkgs/by-name/ru/rustc-demangle/package.nix b/pkgs/by-name/ru/rustc-demangle/package.nix index 4e142c5845293a..edb6be2d7321e0 100644 --- a/pkgs/by-name/ru/rustc-demangle/package.nix +++ b/pkgs/by-name/ru/rustc-demangle/package.nix @@ -1,4 +1,9 @@ -{ rustPlatform, fetchFromGitHub, lib, stdenv }: +{ + rustPlatform, + fetchFromGitHub, + lib, + stdenv, +}: rustPlatform.buildRustPackage rec { pname = "rustc-demangle"; @@ -16,7 +21,10 @@ rustPlatform.buildRustPackage rec { lockFile = ./Cargo.lock; }; - cargoBuildFlags = [ "-p" "rustc-demangle-capi" ]; + cargoBuildFlags = [ + "-p" + "rustc-demangle-capi" + ]; postPatch = '' ln -s ${./Cargo.lock} Cargo.lock @@ -31,7 +39,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Rust symbol demangling"; homepage = "https://github.com/alexcrichton/rustc-demangle"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; # upstream supports other platforms, but maintainer can only test on linux platforms = platforms.linux; maintainers = with maintainers; [ _1000teslas ]; diff --git a/pkgs/by-name/ru/rustfilt/package.nix b/pkgs/by-name/ru/rustfilt/package.nix index 45312ccd7e49d4..351cfa9af57d8f 100644 --- a/pkgs/by-name/ru/rustfilt/package.nix +++ b/pkgs/by-name/ru/rustfilt/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ru/rusti-cal/package.nix b/pkgs/by-name/ru/rusti-cal/package.nix index f03783cbc5e2cb..2d31a44fedf959 100644 --- a/pkgs/by-name/ru/rusti-cal/package.nix +++ b/pkgs/by-name/ru/rusti-cal/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, darwin +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ru/rustls-ffi/package.nix b/pkgs/by-name/ru/rustls-ffi/package.nix index 7dd4fe038f0e12..8b83c212e4f15c 100644 --- a/pkgs/by-name/ru/rustls-ffi/package.nix +++ b/pkgs/by-name/ru/rustls-ffi/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, cargo -, rustPlatform -, cargo-c -, validatePkgConfig -, rust -, libiconv -, darwin -, curl -, apacheHttpd -, testers +{ + lib, + stdenv, + fetchFromGitHub, + cargo, + rustPlatform, + cargo-c, + validatePkgConfig, + rust, + libiconv, + darwin, + curl, + apacheHttpd, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -30,9 +31,17 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-IaOhQfDEgLhGmes0xzhLVym29aP691TY0EXdOIgXEMA="; }; - propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv darwin.apple_sdk.frameworks.Security ]; + propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + darwin.apple_sdk.frameworks.Security + ]; - nativeBuildInputs = [ cargo rustPlatform.cargoSetupHook cargo-c validatePkgConfig ]; + nativeBuildInputs = [ + cargo + rustPlatform.cargoSetupHook + cargo-c + validatePkgConfig + ]; buildPhase = '' runHook preBuild @@ -53,7 +62,11 @@ stdenv.mkDerivation (finalAttrs: { ''; passthru.tests = { - curl = curl.override { opensslSupport = false; rustlsSupport = true; rustls-ffi = finalAttrs.finalPackage; }; + curl = curl.override { + opensslSupport = false; + rustlsSupport = true; + rustls-ffi = finalAttrs.finalPackage; + }; pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; }; @@ -61,7 +74,11 @@ stdenv.mkDerivation (finalAttrs: { description = "C-to-rustls bindings"; homepage = "https://github.com/rustls/rustls-ffi/"; pkgConfigModules = [ "rustls" ]; - license = with lib.licenses; [ mit asl20 isc ]; + license = with lib.licenses; [ + mit + asl20 + isc + ]; maintainers = [ maintainers.lesuisse ]; }; }) diff --git a/pkgs/by-name/ru/rustmission/package.nix b/pkgs/by-name/ru/rustmission/package.nix index 241a0b71dc63f4..6a883d1292812d 100644 --- a/pkgs/by-name/ru/rustmission/package.nix +++ b/pkgs/by-name/ru/rustmission/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -22,12 +23,13 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] + buildInputs = + [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreFoundation - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + darwin.apple_sdk.frameworks.CoreFoundation + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; # There is no tests doCheck = false; diff --git a/pkgs/by-name/ru/rustplayer/package.nix b/pkgs/by-name/ru/rustplayer/package.nix index 8c4757c2799187..e07f2b5802595d 100644 --- a/pkgs/by-name/ru/rustplayer/package.nix +++ b/pkgs/by-name/ru/rustplayer/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, openssl -, alsa-lib -, ffmpeg_6 +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + alsa-lib, + ffmpeg_6, }: rustPlatform.buildRustPackage { @@ -29,8 +30,15 @@ rustPlatform.buildRustPackage { "ffmpeg-sys-next-6.0.1" = "sha256-/CcyWDPeVLVSV8NfWFJhj1tGmuqLPnnyvVosIXM27NI="; }; }; - nativeBuildInputs = [ pkg-config rustPlatform.bindgenHook ]; - buildInputs = [ alsa-lib openssl ffmpeg_6 ]; + nativeBuildInputs = [ + pkg-config + rustPlatform.bindgenHook + ]; + buildInputs = [ + alsa-lib + openssl + ffmpeg_6 + ]; checkFlags = [ # network required diff --git a/pkgs/by-name/ru/rusty-diceware/package.nix b/pkgs/by-name/ru/rusty-diceware/package.nix index acc271e0f7a1ff..996f5fbc7bef3d 100644 --- a/pkgs/by-name/ru/rusty-diceware/package.nix +++ b/pkgs/by-name/ru/rusty-diceware/package.nix @@ -1,6 +1,7 @@ -{ fetchFromGitLab -, lib -, rustPlatform +{ + fetchFromGitLab, + lib, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ru/rusty-man/package.nix b/pkgs/by-name/ru/rusty-man/package.nix index 164977facbe9ea..023febdd38fb2e 100644 --- a/pkgs/by-name/ru/rusty-man/package.nix +++ b/pkgs/by-name/ru/rusty-man/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromSourcehut }: +{ + lib, + rustPlatform, + fetchFromSourcehut, +}: rustPlatform.buildRustPackage rec { pname = "rusty-man"; diff --git a/pkgs/by-name/ru/rusty-psn/package.nix b/pkgs/by-name/ru/rusty-psn/package.nix index ecd5948b4d9cad..5945caf102bf31 100644 --- a/pkgs/by-name/ru/rusty-psn/package.nix +++ b/pkgs/by-name/ru/rusty-psn/package.nix @@ -1,18 +1,19 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, makeDesktopItem -, copyDesktopItems -, pkg-config -, cmake -, fontconfig -, glib -, gtk3 -, freetype -, openssl -, xorg -, libGL -, withGui ? false # build GUI version +{ + lib, + rustPlatform, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + pkg-config, + cmake, + fontconfig, + glib, + gtk3, + freetype, + openssl, + xorg, + libGL, + withGui ? false, # build GUI version }: rustPlatform.buildRustPackage rec { @@ -33,38 +34,44 @@ rustPlatform.buildRustPackage rec { # Tests require network access doCheck = false; - nativeBuildInputs = [ - pkg-config - ] ++ lib.optionals withGui [ - copyDesktopItems - cmake - ]; + nativeBuildInputs = + [ + pkg-config + ] + ++ lib.optionals withGui [ + copyDesktopItems + cmake + ]; - buildInputs = [ - openssl - ] ++ lib.optionals withGui [ - fontconfig - glib - gtk3 - freetype - openssl - xorg.libxcb - xorg.libX11 - xorg.libXcursor - xorg.libXrandr - xorg.libXi - xorg.libxcb - libGL - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals withGui [ + fontconfig + glib + gtk3 + freetype + openssl + xorg.libxcb + xorg.libX11 + xorg.libXcursor + xorg.libXrandr + xorg.libXi + xorg.libxcb + libGL + ]; buildNoDefaultFeatures = true; buildFeatures = [ (if withGui then "egui" else "cli") ]; - postFixup = '' - patchelf --set-rpath "${lib.makeLibraryPath buildInputs}" $out/bin/rusty-psn - '' + lib.optionalString withGui '' - mv $out/bin/rusty-psn $out/bin/rusty-psn-gui - ''; + postFixup = + '' + patchelf --set-rpath "${lib.makeLibraryPath buildInputs}" $out/bin/rusty-psn + '' + + lib.optionalString withGui '' + mv $out/bin/rusty-psn $out/bin/rusty-psn-gui + ''; desktopItem = lib.optionalString withGui (makeDesktopItem { name = "rusty-psn"; diff --git a/pkgs/by-name/ru/rustycli/package.nix b/pkgs/by-name/ru/rustycli/package.nix index ce16743a07158b..a275889580fb52 100644 --- a/pkgs/by-name/ru/rustycli/package.nix +++ b/pkgs/by-name/ru/rustycli/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchCrate -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ru/rustypaste-cli/package.nix b/pkgs/by-name/ru/rustypaste-cli/package.nix index a596683537390b..28723865954b5b 100644 --- a/pkgs/by-name/ru/rustypaste-cli/package.nix +++ b/pkgs/by-name/ru/rustypaste-cli/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ru/rustypaste/package.nix b/pkgs/by-name/ru/rustypaste/package.nix index f0a1fc8c3b9c1f..eef90e5c0858d5 100644 --- a/pkgs/by-name/ru/rustypaste/package.nix +++ b/pkgs/by-name/ru/rustypaste/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, stdenv, darwin }: +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "rustypaste"; @@ -32,7 +38,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/orhun/rustypaste"; changelog = "https://github.com/orhun/rustypaste/blob/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ figsoda seqizz ]; + maintainers = with maintainers; [ + figsoda + seqizz + ]; mainProgram = "rustypaste"; }; } diff --git a/pkgs/by-name/ru/rustywind/package.nix b/pkgs/by-name/ru/rustywind/package.nix index 98ae24be7fb3b6..b113c86fa2e831 100644 --- a/pkgs/by-name/ru/rustywind/package.nix +++ b/pkgs/by-name/ru/rustywind/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ru/rutabaga_gfx/package.nix b/pkgs/by-name/ru/rutabaga_gfx/package.nix index 9b8f5bec42f378..36592007c9425f 100644 --- a/pkgs/by-name/ru/rutabaga_gfx/package.nix +++ b/pkgs/by-name/ru/rutabaga_gfx/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchgit -, fetchpatch -, cargo -, pkg-config -, rustPlatform -, aemu -, gfxstream -, libdrm -, libiconv +{ + lib, + stdenv, + fetchgit, + fetchpatch, + cargo, + pkg-config, + rustPlatform, + aemu, + gfxstream, + libdrm, + libiconv, }: stdenv.mkDerivation (finalAttrs: { @@ -41,13 +42,22 @@ stdenv.mkDerivation (finalAttrs: { ./darwin-install.patch ]; - nativeBuildInputs = [ cargo pkg-config rustPlatform.cargoSetupHook ]; - buildInputs = [ libiconv ] ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform gfxstream) ([ - aemu - gfxstream - ] ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform libdrm) [ - libdrm - ]); + nativeBuildInputs = [ + cargo + pkg-config + rustPlatform.cargoSetupHook + ]; + buildInputs = + [ libiconv ] + ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform gfxstream) ( + [ + aemu + gfxstream + ] + ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform libdrm) [ + libdrm + ] + ); cargoDeps = rustPlatform.fetchCargoTarball { inherit (finalAttrs) src; @@ -55,8 +65,7 @@ stdenv.mkDerivation (finalAttrs: { }; CARGO_BUILD_TARGET = stdenv.hostPlatform.rust.rustcTargetSpec; - "CARGO_TARGET_${stdenv.hostPlatform.rust.cargoEnvVarTarget}_LINKER" = - "${stdenv.cc.targetPrefix}cc"; + "CARGO_TARGET_${stdenv.hostPlatform.rust.cargoEnvVarTarget}_LINKER" = "${stdenv.cc.targetPrefix}cc"; postConfigure = '' cd rutabaga_gfx/ffi diff --git a/pkgs/by-name/ru/rutorrent/package.nix b/pkgs/by-name/ru/rutorrent/package.nix index 43267de48b82d3..7d76c9000f6bda 100644 --- a/pkgs/by-name/ru/rutorrent/package.nix +++ b/pkgs/by-name/ru/rutorrent/package.nix @@ -1,4 +1,8 @@ -{stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "rutorrent"; diff --git a/pkgs/by-name/ru/ruwudu/package.nix b/pkgs/by-name/ru/ruwudu/package.nix index 025c0a2ece4357..e4decd04df9931 100644 --- a/pkgs/by-name/ru/ruwudu/package.nix +++ b/pkgs/by-name/ru/ruwudu/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "ruwudu"; diff --git a/pkgs/by-name/rv/rvvm/package.nix b/pkgs/by-name/rv/rvvm/package.nix index 4693999e8f1116..2625cd3f5e5ac1 100644 --- a/pkgs/by-name/rv/rvvm/package.nix +++ b/pkgs/by-name/rv/rvvm/package.nix @@ -1,21 +1,28 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, -, SDL2 + SDL2, -, libX11 -, libXext + libX11, + libXext, -, guiBackend ? "sdl" + guiBackend ? "sdl", -, enableSDL ? guiBackend == "sdl" -, enableX11 ? guiBackend == "x11" + enableSDL ? guiBackend == "sdl", + enableX11 ? guiBackend == "x11", }: -assert lib.assertMsg (builtins.elem guiBackend ["sdl" "x11" "none"]) "Unsupported GUI backend"; +assert lib.assertMsg (builtins.elem guiBackend [ + "sdl" + "x11" + "none" +]) "Unsupported GUI backend"; assert lib.assertMsg (!(enableSDL && enableX11)) "RVVM can have only one GUI backend at a time"; -assert lib.assertMsg (stdenv.hostPlatform.isDarwin -> !enableX11) "macOS supports only SDL GUI backend"; +assert lib.assertMsg ( + stdenv.hostPlatform.isDarwin -> !enableX11 +) "macOS supports only SDL GUI backend"; stdenv.mkDerivation rec { pname = "rvvm"; @@ -28,22 +35,33 @@ stdenv.mkDerivation rec { sha256 = "sha256-5nSlKyWDAx0EeKFzzwP5+99XuJz9BHXEF1WNkRMLa9U="; }; - buildInputs = [] + buildInputs = + [ ] ++ lib.optionals enableSDL [ SDL2 ] - ++ lib.optionals enableX11 [ libX11 libXext ]; + ++ lib.optionals enableX11 [ + libX11 + libXext + ]; enableParallelBuilding = true; - buildFlags = [ "all" "lib" ]; + buildFlags = [ + "all" + "lib" + ]; - makeFlags = [ "PREFIX=$(out)" ] + makeFlags = + [ "PREFIX=$(out)" ] ++ lib.optional enableSDL "USE_SDL=2" # Use SDL2 instead of SDL1 ++ lib.optional (!enableSDL && !enableX11) "USE_FB=0"; meta = with lib; { homepage = "https://github.com/LekKit/RVVM"; description = "RISC-V Virtual Machine"; - license = with licenses; [ gpl3 /* or */ mpl20 ]; + license = with licenses; [ + gpl3 # or + mpl20 + ]; platforms = platforms.linux ++ platforms.darwin; maintainers = with maintainers; [ kamillaova ]; mainProgram = "rvvm"; diff --git a/pkgs/by-name/rw/rw/package.nix b/pkgs/by-name/rw/rw/package.nix index e77009f7969f04..70372c31894e14 100644 --- a/pkgs/by-name/rw/rw/package.nix +++ b/pkgs/by-name/rw/rw/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "rw"; diff --git a/pkgs/by-name/rw/rwc/package.nix b/pkgs/by-name/rw/rwc/package.nix index e283fb4005b072..7369a086f79cae 100644 --- a/pkgs/by-name/rw/rwc/package.nix +++ b/pkgs/by-name/rw/rwc/package.nix @@ -1,4 +1,8 @@ -{ stdenv, fetchFromGitHub, lib }: +{ + stdenv, + fetchFromGitHub, + lib, +}: stdenv.mkDerivation rec { pname = "rwc"; diff --git a/pkgs/by-name/rw/rwedid/package.nix b/pkgs/by-name/rw/rwedid/package.nix index 3b7870fdc9b350..f62b18cb9c9c3c 100644 --- a/pkgs/by-name/rw/rwedid/package.nix +++ b/pkgs/by-name/rw/rwedid/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitea -, pkg-config -, xz +{ + lib, + rustPlatform, + fetchFromGitea, + pkg-config, + xz, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/rw/rwpspread/package.nix b/pkgs/by-name/rw/rwpspread/package.nix index 9efdc473860ca1..84bd7da27912ae 100644 --- a/pkgs/by-name/rw/rwpspread/package.nix +++ b/pkgs/by-name/rw/rwpspread/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libxkbcommon -, nix-update-script +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libxkbcommon, + nix-update-script, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/rx/rx/package.nix b/pkgs/by-name/rx/rx/package.nix index 943f46fab649c2..3f564a6476e039 100644 --- a/pkgs/by-name/rx/rx/package.nix +++ b/pkgs/by-name/rx/rx/package.nix @@ -1,7 +1,14 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, makeWrapper -, cmake, pkg-config -, xorg ? null -, libGL ? null }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + makeWrapper, + cmake, + pkg-config, + xorg ? null, + libGL ? null, +}: rustPlatform.buildRustPackage rec { pname = "rx"; @@ -16,13 +23,24 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-4hi1U4jl6QA7H8AKHlU+Hqz5iKGYHRXHDsrcqY7imkU="; - nativeBuildInputs = [ cmake pkg-config makeWrapper ]; + nativeBuildInputs = [ + cmake + pkg-config + makeWrapper + ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux - (with xorg; [ - # glfw-sys dependencies: - libX11 libXrandr libXinerama libXcursor libXi libXext - ]); + buildInputs = lib.optionals stdenv.hostPlatform.isLinux ( + with xorg; + [ + # glfw-sys dependencies: + libX11 + libXrandr + libXinerama + libXcursor + libXi + libXext + ] + ); # FIXME: GLFW (X11) requires DISPLAY env variable for all tests doCheck = false; @@ -38,7 +56,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "rx"; homepage = "https://rx.cloudhead.io/"; license = licenses.gpl3; - maintainers = with maintainers; [ minijackson Br1ght0ne ]; + maintainers = with maintainers; [ + minijackson + Br1ght0ne + ]; platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/by-name/rx/rxp/package.nix b/pkgs/by-name/rx/rxp/package.nix index fe93607d27f2d1..e36b34ae67d342 100644 --- a/pkgs/by-name/rx/rxp/package.nix +++ b/pkgs/by-name/rx/rxp/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl} : +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "rxp"; diff --git a/pkgs/by-name/rx/rxvt/package.nix b/pkgs/by-name/rx/rxvt/package.nix index 9894a8cdb05a53..9c0dd2d69c23ea 100644 --- a/pkgs/by-name/rx/rxvt/package.nix +++ b/pkgs/by-name/rx/rxvt/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchurl -, pkg-config, libtool -, libX11, libXt, libXpm }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libtool, + libX11, + libXt, + libXpm, +}: stdenv.mkDerivation rec { pname = "rxvt"; @@ -12,7 +19,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libtool libX11 libXt libXpm ]; + buildInputs = [ + libtool + libX11 + libXt + libXpm + ]; configurePhase = '' LIBTOOL=${libtool}/bin/libtool ./configure --prefix=$out --enable-everything --enable-smart-resize --enable-256-color diff --git a/pkgs/by-name/ry/rymcast/package.nix b/pkgs/by-name/ry/rymcast/package.nix index ddd9c751083f02..4f6fd4b060ae8d 100644 --- a/pkgs/by-name/ry/rymcast/package.nix +++ b/pkgs/by-name/ry/rymcast/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchzip, autoPatchelfHook, makeWrapper -, alsa-lib, curl, gtk3, webkitgtk_4_0, zenity }: +{ + lib, + stdenv, + fetchzip, + autoPatchelfHook, + makeWrapper, + alsa-lib, + curl, + gtk3, + webkitgtk_4_0, + zenity, +}: stdenv.mkDerivation rec { pname = "rymcast"; @@ -11,9 +21,19 @@ stdenv.mkDerivation rec { stripRoot = false; }; - nativeBuildInputs = [ autoPatchelfHook makeWrapper ]; + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + ]; - buildInputs = [ alsa-lib curl gtk3 (lib.getLib stdenv.cc.cc) webkitgtk_4_0 zenity ]; + buildInputs = [ + alsa-lib + curl + gtk3 + (lib.getLib stdenv.cc.cc) + webkitgtk_4_0 + zenity + ]; installPhase = '' mkdir -p "$out/bin" diff --git a/pkgs/by-name/ry/ryujinx/deps.nix b/pkgs/by-name/ry/ryujinx/deps.nix index 6a1c37ce1a876f..3af2f7275daabc 100644 --- a/pkgs/by-name/ry/ryujinx/deps.nix +++ b/pkgs/by-name/ry/ryujinx/deps.nix @@ -1,206 +1,1011 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Avalonia"; version = "11.0.10"; hash = "sha256-FuGl5admJ9AeRNrg/faGfqx8pwxGxdkmbnth9Jxhelc="; }) - (fetchNuGet { pname = "Avalonia.Angle.Windows.Natives"; version = "2.1.0.2023020321"; hash = "sha256-TWop9cvak6cMv2vrA/GlpuYBxS8Fuj5UmupGIV7Q5Ks="; }) - (fetchNuGet { pname = "Avalonia.BuildServices"; version = "0.0.29"; hash = "sha256-WPHRMNowRnYSCh88DWNBCltWsLPyOfzXGzBqLYE7tRY="; }) - (fetchNuGet { pname = "Avalonia.Controls.ColorPicker"; version = "11.0.10"; hash = "sha256-G0ooIjNRW5YHKvQ6qPxe5gaE3HPwGfiCQUo34PSxXGg="; }) - (fetchNuGet { pname = "Avalonia.Controls.ColorPicker"; version = "11.0.4"; hash = "sha256-Jp0j/58RF9Qooc7ATtq80FtX3TVLhi54JfgrbKdiDes="; }) - (fetchNuGet { pname = "Avalonia.Controls.DataGrid"; version = "11.0.10"; hash = "sha256-0v4evkV0jbLffwfQG/QO/RQbHXlCBmFv8A2pBZjS5Y0="; }) - (fetchNuGet { pname = "Avalonia.Controls.ItemsRepeater"; version = "11.0.4"; hash = "sha256-P8MfWKkDQrsk6x/vraNxxdYSMHytS8U3fMY2o8b49dw="; }) - (fetchNuGet { pname = "Avalonia.Desktop"; version = "11.0.10"; hash = "sha256-fIty7TfiTC+OX9gCH4tA8Fs9dF4+G7Mhs9XnZadUR2g="; }) - (fetchNuGet { pname = "Avalonia.Diagnostics"; version = "11.0.10"; hash = "sha256-itnN+LIZ2S+1CjD0ZS/woKtpgWbC/srMYzbYfX3a8LA="; }) - (fetchNuGet { pname = "Avalonia.FreeDesktop"; version = "11.0.10"; hash = "sha256-uVNOOVTQIqQ2pDgSsz5saI7+fMvps40vJlMp1/XdyaE="; }) - (fetchNuGet { pname = "Avalonia.Markup.Xaml.Loader"; version = "11.0.10"; hash = "sha256-Xv6L8U34QEiH6r3SQWLwuVFk9N9REmCUHa9hEbv2m24="; }) - (fetchNuGet { pname = "Avalonia.Native"; version = "11.0.10"; hash = "sha256-P9j01FDXDpixo8wBVH3XK0Am6UBhG52HDrzt1ZqD8Ro="; }) - (fetchNuGet { pname = "Avalonia.Remote.Protocol"; version = "11.0.10"; hash = "sha256-qtvlczTg2yUZWyyqXkkboB8lK9aYv+STbfDvSKb55Vw="; }) - (fetchNuGet { pname = "Avalonia.Remote.Protocol"; version = "11.0.4"; hash = "sha256-13qXDjlWElmwQ0sb00+ny9gOgKuDOHKvALuQB6EZxCQ="; }) - (fetchNuGet { pname = "Avalonia.Skia"; version = "11.0.0"; hash = "sha256-A01nrs3Ij1eTo6tPmu7++T1K+Wo/H/9LvpeuOUGbQeU="; }) - (fetchNuGet { pname = "Avalonia.Skia"; version = "11.0.10"; hash = "sha256-1SU17j43Fiw4LbEEgqx10zE/iIVPfb8G1JVbfD2RhXA="; }) - (fetchNuGet { pname = "Avalonia.Skia"; version = "11.0.4"; hash = "sha256-1XfPTcAaNj1926uYkvo7P62++ds5M2gHvkv1hRzBVfs="; }) - (fetchNuGet { pname = "Avalonia.Svg"; version = "11.0.0.18"; hash = "sha256-U4bafxxxFE0tKmKVxguxH+doFrTHlM6DjFP8wz6Xm9U="; }) - (fetchNuGet { pname = "Avalonia.Svg.Skia"; version = "11.0.0.18"; hash = "sha256-M4AQkL42efqOSck4Lf7C1naIRjEPMlnxi3OVC8zLJaQ="; }) - (fetchNuGet { pname = "Avalonia.Themes.Simple"; version = "11.0.10"; hash = "sha256-54fc2g1yvM7pPRaF062lSjXaQDe2i61xQRM8m81vWm8="; }) - (fetchNuGet { pname = "Avalonia.Win32"; version = "11.0.10"; hash = "sha256-+o228ElrBJBxBkZKGbo3x8/52wKpnAk/x6Yon5pyA74="; }) - (fetchNuGet { pname = "Avalonia.X11"; version = "11.0.10"; hash = "sha256-/CRivMxpcbW1FnIuwZbF2ucdcbn4TCyjKzLXgdGtCfQ="; }) - (fetchNuGet { pname = "CommandLineParser"; version = "2.9.1"; hash = "sha256-ApU9y1yX60daSjPk3KYDBeJ7XZByKW8hse9NRZGcjeo="; }) - (fetchNuGet { pname = "Concentus"; version = "2.2.0"; hash = "sha256-7wbB76WoTd2CISIODGhmEiPIrydI0dqDMZGf4gdkogM="; }) - (fetchNuGet { pname = "DiscordRichPresence"; version = "1.2.1.24"; hash = "sha256-oRNrlF1/yK0QvrW2+48RsmSg9h9/pDIfA56/bpoHXFU="; }) - (fetchNuGet { pname = "DynamicData"; version = "9.0.4"; hash = "sha256-3pyiJeWRwfaT7p1ArsoR13aI78Jo13aHOEw3BelTS9g="; }) - (fetchNuGet { pname = "ExCSS"; version = "4.2.3"; hash = "sha256-M/H6P5p7qqdFz/fgAI2MMBWQ7neN/GIieYSSxxjsM9I="; }) - (fetchNuGet { pname = "FluentAvaloniaUI"; version = "2.0.5"; hash = "sha256-EaJ6qR2yn+7p8lf62yx2vL3sGhnPOfbP5jBjR+pGY7o="; }) - (fetchNuGet { pname = "FSharp.Core"; version = "7.0.200"; hash = "sha256-680VgvYbZbztPQosO17r5y8vxg/Y/4Vmr5K3iLIJKMo="; }) - (fetchNuGet { pname = "GtkSharp.Dependencies"; version = "1.1.1"; hash = "sha256-/IpSj5JnUTREfQsdA3XW+eqNhqApTds65DQoNpjl3jk="; }) - (fetchNuGet { pname = "HarfBuzzSharp"; version = "2.8.2.3"; hash = "sha256-4tbdgUabPjlkBm3aUFeocj4Fdslmms2olDFpzOLyqoQ="; }) - (fetchNuGet { pname = "HarfBuzzSharp"; version = "7.3.0"; hash = "sha256-LlPQO/NYgIMWicvLOtWsQzCp512QpIImYDP9/n2rDOc="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Linux"; version = "2.8.2.3"; hash = "sha256-3xwVfNfKTkuLdnT+e3bfG9tNTdEmar7ByzY+NTlUKLg="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Linux"; version = "7.3.0"; hash = "sha256-AEHjgqX0o+Fob0SeZ6EikGKoEe6rRxess5fVJ31UL0U="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.macOS"; version = "2.8.2.3"; hash = "sha256-ZohUEaovj/sRB4rjuJIOq6S9eim3m+qMlpHIebNDTRQ="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.macOS"; version = "7.3.0"; hash = "sha256-6oFcdKb17UX5wyAUeCCKXGvzkf0w3MNdZOVMvs54tqw="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; version = "2.8.2.3"; hash = "sha256-ZsiBGpXfODHUHPgU/50k9QR/j6Klo7rsB0SUt8zYcBA="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; version = "7.3.0"; hash = "sha256-9VI0xCavuuIIStuQ7ipBfWu5HrAt+Kk/F2j57C1llTU="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Win32"; version = "2.8.2.3"; hash = "sha256-5GSzM5IUoOwK+zJg0d74WlT3n1VZly8pKlyjiqVocCI="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Win32"; version = "7.3.0"; hash = "sha256-WnB7l73hneU9Kpbm8S9zEYbZHjFre24vWz0vl8+v28M="; }) - (fetchNuGet { pname = "LibHac"; version = "0.19.0"; hash = "sha256-FDEmeGHbX/aCFjFbFk8QwO2rTfFizt9UKb+KFDt23hk="; }) - (fetchNuGet { pname = "MicroCom.CodeGenerator.MSBuild"; version = "0.11.0"; hash = "sha256-TsxziX9V8T3qRrEA3o9wY84ocDcUUUBzvARi5QZW23o="; }) - (fetchNuGet { pname = "MicroCom.Runtime"; version = "0.11.0"; hash = "sha256-VdwpP5fsclvNqJuppaOvwEwv2ofnAI5ZSz2V+UEdLF0="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.0.0"; hash = "sha256-KDbCfsBWSJ5ohEXUKp1s1LX9xA2NPvXE/xVzj68EdC0="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.3.4"; hash = "sha256-qDzTfZBSCvAUu9gzq2k+LOvh6/eRvJ9++VCNck/ZpnE="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "3.8.0"; hash = "sha256-3G9vSc/gHH7FWgOySLTut1+eEaf3H66qcPOvNPLOx4o="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "4.9.2"; hash = "sha256-QU/nyiJWpdPQGHBdaOEVc+AghnGHcKBFBX0oyhRZ9CQ="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "3.8.0"; hash = "sha256-i/r3V/No/VzqmJlWxpGoirvlbJDbBPa/ONZtzYrxuc4="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "4.9.2"; hash = "sha256-j06Q4A9E65075SBXdXVCMRgeLxA63Rv1vxarydmmVAA="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.Scripting"; version = "3.8.0"; hash = "sha256-fA9Qu+vTyMZ9REzxJ4aMg/SHCDRk4q9k4ZGUdynoHnA="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Scripting.Common"; version = "3.8.0"; hash = "sha256-866jMHp8kbc1FYpKuUWnd7ViU6kGJTAxPcL/IjXrT0I="; }) - (fetchNuGet { pname = "Microsoft.CodeCoverage"; version = "17.9.0"; hash = "sha256-OaGa4+jRPHs+T+p/oekm2Miluqfd2IX8Rt+BmUx8kr4="; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.3.0"; hash = "sha256-a3dAiPaVuky0wpcHmpTVtAQJNGZ2v91/oArA+dpJgj8="; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.7.0"; hash = "sha256-Enknv2RsFF68lEPdrf5M+BpV1kHoLTVRApKUwuk/pj0="; }) - (fetchNuGet { pname = "Microsoft.DotNet.PlatformAbstractions"; version = "3.1.6"; hash = "sha256-RfM2qXiqdiamPkXr4IDkNc0IZSF9iTZv4uou/E7zNS0="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyModel"; version = "8.0.0"; hash = "sha256-qkCdwemqdZY/yIW5Xmh7Exv74XuE39T8aHGHCofoVgo="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.Abstractions"; version = "8.0.1"; hash = "sha256-zPWUKTCfGm4MWcYPU037NzezsFE1g8tEijjQkw5iooI="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.JsonWebTokens"; version = "8.0.1"; hash = "sha256-Xv9MUnjb66U3xeR9drOcSX5n2DjOCIJZPMNSKjWHo9Y="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.Logging"; version = "8.0.1"; hash = "sha256-FfwrH/2eLT521Kqw+RBIoVfzlTNyYMqlWP3z+T6Wy2Y="; }) - (fetchNuGet { pname = "Microsoft.IdentityModel.Tokens"; version = "8.0.1"; hash = "sha256-beVbbVQy874HlXkTKarPTT5/r7XR1NGHA/50ywWp7YA="; }) - (fetchNuGet { pname = "Microsoft.IO.RecyclableMemoryStream"; version = "3.0.1"; hash = "sha256-unFg/5EcU/XKJbob4GtQC43Ydgi5VjeBGs7hfhj4EYo="; }) - (fetchNuGet { pname = "Microsoft.NET.Test.Sdk"; version = "17.9.0"; hash = "sha256-q/1AJ7eNlk02wvN76qvjl2xBx5iJ+h5ssiE/4akLmtI="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "2.0.0"; hash = "sha256-IEvBk6wUXSdyCnkj6tHahOJv290tVVT8tyemYcR0Yro="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "2.1.2"; hash = "sha256-gYQQO7zsqG+OtN4ywYQyfsiggS2zmxw4+cPXlK+FB5Q="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.ObjectModel"; version = "17.9.0"; hash = "sha256-iiXUFzpvT8OWdzMj9FGJDqanwHx40s1TXVY9l3ii+s0="; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.TestHost"; version = "17.9.0"; hash = "sha256-1BZIY1z+C9TROgdTV/tq4zsPy7Q71GQksr/LoMKAzqU="; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "4.5.0"; hash = "sha256-WMBXsIb0DgPFPaFkNVxY9b9vcMxPqtgFgijKYMJfV/0="; }) - (fetchNuGet { pname = "MsgPack.Cli"; version = "1.0.1"; hash = "sha256-Gf0Ed9XHH4oFpJIkzhg/xhDVpenunSol65qa8IZeYrY="; }) - (fetchNuGet { pname = "NetCoreServer"; version = "8.0.7"; hash = "sha256-RUYic8uAgJGdhUCrMJQULKlHB6xvw9H1lnNGU1axNZw="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.0"; hash = "sha256-Pp7fRylai8JrE1O+9TGfIEJrAOmnWTJRLWE+qJBahK0="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.1"; hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; }) - (fetchNuGet { pname = "NUnit"; version = "3.13.3"; hash = "sha256-Zn+sJIF7ieNqu/t2RwJx6WPFb1jl9UuNHidb/Px0v3E="; }) - (fetchNuGet { pname = "NUnit3TestAdapter"; version = "4.1.0"; hash = "sha256-nDPiYdTFulqozEJrujr8/cqjG7m15Vkd/Frqem0Jr/w="; }) - (fetchNuGet { pname = "OpenTK.Audio.OpenAL"; version = "4.8.2"; hash = "sha256-i5KRiTYTNMB4Y5Qd5xewaYrb9sBbnXMDu2QXbM3RCeU="; }) - (fetchNuGet { pname = "OpenTK.Core"; version = "4.8.2"; hash = "sha256-59S4Vj13y8HtZT6RZTwO6ZZbk1GUNDcYx1rMdv5jr4I="; }) - (fetchNuGet { pname = "OpenTK.Graphics"; version = "4.8.2"; hash = "sha256-DNpXqtM9Oj6wDGYSF2FD4A4ueWG892Wk6uGWffNspo0="; }) - (fetchNuGet { pname = "OpenTK.Mathematics"; version = "4.8.2"; hash = "sha256-TPsts443n6iEajfH2EuYTKtubrWuTLiCrTB1F4FndIo="; }) - (fetchNuGet { pname = "OpenTK.redist.glfw"; version = "3.3.8.39"; hash = "sha256-bg8bGfoDDqmZ/efLFVm8l5etQajIVvOcQ/Nv+yKD4Bc="; }) - (fetchNuGet { pname = "OpenTK.Windowing.GraphicsLibraryFramework"; version = "4.8.2"; hash = "sha256-a1MGtU+27pBNns55g8mOsxXpZxfEr6M62zLkIkkJTIY="; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; }) - (fetchNuGet { pname = "Ryujinx.AtkSharp"; version = "3.24.24.59-ryujinx"; hash = "sha256-mK1zXkd6bdo7YqOm/rcI8MTniugvs5Kjw+esGmHYJxE="; }) - (fetchNuGet { pname = "Ryujinx.Audio.OpenAL.Dependencies"; version = "1.21.0.1"; hash = "sha256-NHGzMcYduuYJjduIlf8M8zSQQuJcXAEaMNmKIqAgs3w="; }) - (fetchNuGet { pname = "Ryujinx.CairoSharp"; version = "3.24.24.59-ryujinx"; hash = "sha256-+gV4Vlkd0jMZ6yGCz1/KoiE32/O26gHOZiHXmZ292rE="; }) - (fetchNuGet { pname = "Ryujinx.GdkSharp"; version = "3.24.24.59-ryujinx"; hash = "sha256-r1UK7YzhMOJ3Z8eWuUyTf0nGQ0Bdlic8Qri170ilEbs="; }) - (fetchNuGet { pname = "Ryujinx.GioSharp"; version = "3.24.24.59-ryujinx"; hash = "sha256-sbfdn16UoQtcU9gAgvP2kjBUbYi9nKy09bmhvn9IGtU="; }) - (fetchNuGet { pname = "Ryujinx.GLibSharp"; version = "3.24.24.59-ryujinx"; hash = "sha256-zZv0B4BvKuRdse8oqSbb4P6FFq79w4M+MCk8EqqLVWk="; }) - (fetchNuGet { pname = "Ryujinx.Graphics.Nvdec.Dependencies"; version = "5.0.3-build14"; hash = "sha256-+ff+tlWggY+qZTBJroOOphRpOjBDg5cQgwGtVOTiqRQ="; }) - (fetchNuGet { pname = "Ryujinx.Graphics.Vulkan.Dependencies.MoltenVK"; version = "1.2.0"; hash = "sha256-vdDw6YGoyQzv6ustyXP6v7YWUIKEXaZOyUKAaVbRauI="; }) - (fetchNuGet { pname = "Ryujinx.GtkSharp"; version = "3.24.24.59-ryujinx"; hash = "sha256-2duc6+KLuctobfwqeuewxRLZnXn83QomF4rN0hEoMTc="; }) - (fetchNuGet { pname = "Ryujinx.PangoSharp"; version = "3.24.24.59-ryujinx"; hash = "sha256-gGAK/aEfTUAxEihjlBOtHlhPZZFAwCasgUB/Umapva0="; }) - (fetchNuGet { pname = "Ryujinx.SDL2-CS"; version = "2.30.0-build32"; hash = "sha256-KrrlDq0pXcunnOhJL12dt1CAdNbaupbDlnza5gXuVKE="; }) - (fetchNuGet { pname = "securifybv.PropertyStore"; version = "0.1.0"; hash = "sha256-jTPT9E2LyElgJq4HMavkdwT8tA9uklnJv00mlIx66+g="; }) - (fetchNuGet { pname = "securifybv.ShellLink"; version = "0.1.0"; hash = "sha256-Am+ZednCVJUDgB7TePyY3CTxKDQ6Lr8M8KiCVAJoouw="; }) - (fetchNuGet { pname = "shaderc.net"; version = "0.1.0"; hash = "sha256-+K7ObC9ucilwWY+Tlf9KcrAVoTFS65V6Di7JDWDSZTg="; }) - (fetchNuGet { pname = "SharpZipLib"; version = "1.4.2"; hash = "sha256-/giVqikworG2XKqfN9uLyjUSXr35zBuZ2FX2r8X/WUY="; }) - (fetchNuGet { pname = "ShimSkiaSharp"; version = "1.0.0.18"; hash = "sha256-72NV+OuW8bCfI/EOXwgS6dleLZnomLJTYeQPPmfhuu8="; }) - (fetchNuGet { pname = "Silk.NET.Core"; version = "2.21.0"; hash = "sha256-D4ZUCm1Gf/EiRWrSwSLrdXT6U54icY2E/vrvCD/bRHw="; }) - (fetchNuGet { pname = "Silk.NET.Vulkan"; version = "2.21.0"; hash = "sha256-Xnxl13+ziJ1+jNxMFSrEuh6NvL1FBrYmJ/d3HQXpgzY="; }) - (fetchNuGet { pname = "Silk.NET.Vulkan.Extensions.EXT"; version = "2.21.0"; hash = "sha256-udELG0ppCOP9eT2yl/sI9MgKOVOuK0py9znmoaBGDpk="; }) - (fetchNuGet { pname = "Silk.NET.Vulkan.Extensions.KHR"; version = "2.21.0"; hash = "sha256-KyiGHW6CNkXE3EdHk3ufwTVG7oLvSyHwx+MmIJhsiBk="; }) - (fetchNuGet { pname = "SkiaSharp"; version = "2.88.3"; hash = "sha256-WyMAjnQt8ZsuWpGLI89l/f4bHvv+cg7FdTAL7CtJBvs="; }) - (fetchNuGet { pname = "SkiaSharp"; version = "2.88.6"; hash = "sha256-y0wzgwdQXtgl5boCz/EgLWbK3SwC0cFVRUbBxOUPQXc="; }) - (fetchNuGet { pname = "SkiaSharp"; version = "2.88.7"; hash = "sha256-Ip3afwTr4QOqtwOUKqK6g/9Ug4dMSebTci5K29Jc3Dg="; }) - (fetchNuGet { pname = "SkiaSharp.HarfBuzz"; version = "2.88.6"; hash = "sha256-gpHiTuHfiXgbkBkzipXb8EXIatefsod75nyrFdPcwcA="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Linux"; version = "2.88.3"; hash = "sha256-eExWAAURgnwwm2fRwsK/rf+TeOAPs2n02XZzC0zeUjU="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Linux"; version = "2.88.7"; hash = "sha256-QdQRN1IBjqohmI8U+6WJRPgOsh8a9soN2UvVObs1H1w="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.macOS"; version = "2.88.3"; hash = "sha256-8G4swiLMr6XS3kjfO/YC1PyoVdfSq7nxZthZZ+KTKqQ="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.macOS"; version = "2.88.6"; hash = "sha256-7hOMjlYTOiNPLNwfLFUjTcdgiGEtmYUI1EubiRiC6bo="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.macOS"; version = "2.88.7"; hash = "sha256-WgPldXSqPMm0TrdUWAyjge5rcRhd9G3/Ix/v/2NQvBc="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.WebAssembly"; version = "2.88.3"; hash = "sha256-/SkV2pIZnt0ziSKB7gt7U2Rltk2Id+zOzbmqgfWUtvA="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.WebAssembly"; version = "2.88.7"; hash = "sha256-oIjFF+Rv+g8AKyNaaVAgnHX3eeP/l8K2sgHs9bRyUMw="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Win32"; version = "2.88.3"; hash = "sha256-2PhMTwRHitT13KCKiZltKIFieAvNY4jBmVZ2ndVynA8="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Win32"; version = "2.88.6"; hash = "sha256-ljD4QmAO2/vwA6I8GIUNkONpOzmGsOVJJy9vPDnjVfA="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Win32"; version = "2.88.7"; hash = "sha256-+7RxCAr+ne9MZWdXKKpV4ZbHW0k6hLD20ZFWWOCiNYU="; }) - (fetchNuGet { pname = "SPB"; version = "0.0.4-build32"; hash = "sha256-GUzbV5rLWtXTpiddYrKnWWLujG38vBDCO4xRStwAaDo="; }) - (fetchNuGet { pname = "Svg.Custom"; version = "1.0.0.18"; hash = "sha256-RguRPwBM/KCogaiOgjELlvuqN1Tr+b3HA4Odz1rXBgU="; }) - (fetchNuGet { pname = "Svg.Model"; version = "1.0.0.18"; hash = "sha256-CXZC45txfcd8MuRmDENw2ujlGk74YaUPNs7dXq+Zcg8="; }) - (fetchNuGet { pname = "Svg.Skia"; version = "1.0.0.18"; hash = "sha256-o5VnCaAGX4LuwNyl7QM0KOg2gNfkD5uNMNthxB7w0m4="; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; hash = "sha256-wws90sfi9M7kuCPWkv1CEYMJtCqx9QB/kj0ymlsNaxI="; }) - (fetchNuGet { pname = "System.CodeDom"; version = "4.4.0"; hash = "sha256-L1xyspJ8pDJNVPYKl+FMGf4Zwm0tlqtAyQCNW6pT6/0="; }) - (fetchNuGet { pname = "System.CodeDom"; version = "8.0.0"; hash = "sha256-uwVhi3xcvX7eiOGQi7dRETk3Qx1EfHsUfchZsEto338="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "5.0.0"; hash = "sha256-GdwSIjLMM0uVfE56VUSLVNgpW0B//oCeSFj8/hSlbM8="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "8.0.0"; hash = "sha256-F7OVjKNwpqbUh8lTidbqJWYi476nsq9n+6k0+QVRo3w="; }) - (fetchNuGet { pname = "System.ComponentModel.Annotations"; version = "4.5.0"; hash = "sha256-15yE2NoT9vmL9oGCaxHClQR1jLW1j1ef5hHMg55xRso="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.3.0"; hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; }) - (fetchNuGet { pname = "System.IO.Hashing"; version = "8.0.0"; hash = "sha256-szOGt0TNBo6dEdC3gf6H+e9YW3Nw0woa6UnCGGGK5cE="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "6.0.0"; hash = "sha256-xfjF4UqTMJpf8KsBWUyJlJkzPTOO/H5MW023yTYNQSA="; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.3.0"; hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; }) - (fetchNuGet { pname = "System.Management"; version = "8.0.0"; hash = "sha256-HwpfDb++q7/vxR6q57mGFgl5U0vxy+oRJ6orFKORfP0="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.5"; hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.3.0"; hash = "sha256-eog2Sp8CAntRlyp2Aar1tpAwDrojGFZ5LIdqsmuIchY="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.4.0"; hash = "sha256-auXQK2flL/JpnB/rEcAcUm4vYMCYMEMiWOCAlIaqu2U="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.3.0"; hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; }) - (fetchNuGet { pname = "System.Reactive"; version = "6.0.1"; hash = "sha256-Lo5UMqp8DsbVSUxa2UpClR1GoYzqQQcSxkfyFqB/d4Q="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.3.0"; hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.3.0"; hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.3.0"; hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "1.6.0"; hash = "sha256-JJfgaPav7UfEh4yRAQdGhLZF1brr0tUWPl6qmfNWq/E="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "5.0.0"; hash = "sha256-Wo+MiqhcP9dQ6NuFGrQTw6hpbJORFwp+TBNTq2yhGp8="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "8.0.0"; hash = "sha256-dQGC30JauIDWNWXMrSNOJncVa1umR1sijazYwUDdSIE="; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.3.0"; hash = "sha256-4U4/XNQAnddgQIHIJq3P2T80hN0oPdU2uCeghsDTWng="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.7.1"; hash = "sha256-UvyoDV8O0oY3HPG1GbA56YVdvwTGEfjYR5gW1O7IK4U="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "5.0.0"; hash = "sha256-neARSpLPUzPxEKhJRwoBzhPxK+cKIitLx7WBYncsYgo="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "4.5.0"; hash = "sha256-AFsKPb/nTk2/mqH/PYpaoI8PLsiKKimaXf+7Mb5VfPM="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.5.0"; hash = "sha256-BkUYNguz0e4NJp1kkW7aJBn3dyH9STwB5N8XqnlCsmY="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "4.5.1"; hash = "sha256-PIhkv59IXjyiuefdhKxS9hQfEwO9YWRuNudpo53HQfw="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "8.0.0"; hash = "sha256-fjCLQc1PRW0Ix5IZldg0XKv+J1DqPSfu9pjMyNBp7dE="; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "8.0.0"; hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; }) - (fetchNuGet { pname = "System.Text.Json"; version = "8.0.0"; hash = "sha256-XFcCHMW1u2/WujlWNHaIWkbW1wn8W4kI0QdrwPtWmow="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; }) - (fetchNuGet { pname = "Tmds.DBus.Protocol"; version = "0.15.0"; hash = "sha256-4gk2vXDjKFaBh82gTkwg3c/5GRjiH+bvM5elfDSbKTU="; }) - (fetchNuGet { pname = "UnicornEngine.Unicorn"; version = "2.0.2-rc1-fb78016"; hash = "sha256-NrJ4/o4FmCt2zoB1fWAzqdonvpYhTFsWwh3h0lxZg+Q="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Avalonia"; + version = "11.0.10"; + hash = "sha256-FuGl5admJ9AeRNrg/faGfqx8pwxGxdkmbnth9Jxhelc="; + }) + (fetchNuGet { + pname = "Avalonia.Angle.Windows.Natives"; + version = "2.1.0.2023020321"; + hash = "sha256-TWop9cvak6cMv2vrA/GlpuYBxS8Fuj5UmupGIV7Q5Ks="; + }) + (fetchNuGet { + pname = "Avalonia.BuildServices"; + version = "0.0.29"; + hash = "sha256-WPHRMNowRnYSCh88DWNBCltWsLPyOfzXGzBqLYE7tRY="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.ColorPicker"; + version = "11.0.10"; + hash = "sha256-G0ooIjNRW5YHKvQ6qPxe5gaE3HPwGfiCQUo34PSxXGg="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.ColorPicker"; + version = "11.0.4"; + hash = "sha256-Jp0j/58RF9Qooc7ATtq80FtX3TVLhi54JfgrbKdiDes="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.DataGrid"; + version = "11.0.10"; + hash = "sha256-0v4evkV0jbLffwfQG/QO/RQbHXlCBmFv8A2pBZjS5Y0="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.ItemsRepeater"; + version = "11.0.4"; + hash = "sha256-P8MfWKkDQrsk6x/vraNxxdYSMHytS8U3fMY2o8b49dw="; + }) + (fetchNuGet { + pname = "Avalonia.Desktop"; + version = "11.0.10"; + hash = "sha256-fIty7TfiTC+OX9gCH4tA8Fs9dF4+G7Mhs9XnZadUR2g="; + }) + (fetchNuGet { + pname = "Avalonia.Diagnostics"; + version = "11.0.10"; + hash = "sha256-itnN+LIZ2S+1CjD0ZS/woKtpgWbC/srMYzbYfX3a8LA="; + }) + (fetchNuGet { + pname = "Avalonia.FreeDesktop"; + version = "11.0.10"; + hash = "sha256-uVNOOVTQIqQ2pDgSsz5saI7+fMvps40vJlMp1/XdyaE="; + }) + (fetchNuGet { + pname = "Avalonia.Markup.Xaml.Loader"; + version = "11.0.10"; + hash = "sha256-Xv6L8U34QEiH6r3SQWLwuVFk9N9REmCUHa9hEbv2m24="; + }) + (fetchNuGet { + pname = "Avalonia.Native"; + version = "11.0.10"; + hash = "sha256-P9j01FDXDpixo8wBVH3XK0Am6UBhG52HDrzt1ZqD8Ro="; + }) + (fetchNuGet { + pname = "Avalonia.Remote.Protocol"; + version = "11.0.10"; + hash = "sha256-qtvlczTg2yUZWyyqXkkboB8lK9aYv+STbfDvSKb55Vw="; + }) + (fetchNuGet { + pname = "Avalonia.Remote.Protocol"; + version = "11.0.4"; + hash = "sha256-13qXDjlWElmwQ0sb00+ny9gOgKuDOHKvALuQB6EZxCQ="; + }) + (fetchNuGet { + pname = "Avalonia.Skia"; + version = "11.0.0"; + hash = "sha256-A01nrs3Ij1eTo6tPmu7++T1K+Wo/H/9LvpeuOUGbQeU="; + }) + (fetchNuGet { + pname = "Avalonia.Skia"; + version = "11.0.10"; + hash = "sha256-1SU17j43Fiw4LbEEgqx10zE/iIVPfb8G1JVbfD2RhXA="; + }) + (fetchNuGet { + pname = "Avalonia.Skia"; + version = "11.0.4"; + hash = "sha256-1XfPTcAaNj1926uYkvo7P62++ds5M2gHvkv1hRzBVfs="; + }) + (fetchNuGet { + pname = "Avalonia.Svg"; + version = "11.0.0.18"; + hash = "sha256-U4bafxxxFE0tKmKVxguxH+doFrTHlM6DjFP8wz6Xm9U="; + }) + (fetchNuGet { + pname = "Avalonia.Svg.Skia"; + version = "11.0.0.18"; + hash = "sha256-M4AQkL42efqOSck4Lf7C1naIRjEPMlnxi3OVC8zLJaQ="; + }) + (fetchNuGet { + pname = "Avalonia.Themes.Simple"; + version = "11.0.10"; + hash = "sha256-54fc2g1yvM7pPRaF062lSjXaQDe2i61xQRM8m81vWm8="; + }) + (fetchNuGet { + pname = "Avalonia.Win32"; + version = "11.0.10"; + hash = "sha256-+o228ElrBJBxBkZKGbo3x8/52wKpnAk/x6Yon5pyA74="; + }) + (fetchNuGet { + pname = "Avalonia.X11"; + version = "11.0.10"; + hash = "sha256-/CRivMxpcbW1FnIuwZbF2ucdcbn4TCyjKzLXgdGtCfQ="; + }) + (fetchNuGet { + pname = "CommandLineParser"; + version = "2.9.1"; + hash = "sha256-ApU9y1yX60daSjPk3KYDBeJ7XZByKW8hse9NRZGcjeo="; + }) + (fetchNuGet { + pname = "Concentus"; + version = "2.2.0"; + hash = "sha256-7wbB76WoTd2CISIODGhmEiPIrydI0dqDMZGf4gdkogM="; + }) + (fetchNuGet { + pname = "DiscordRichPresence"; + version = "1.2.1.24"; + hash = "sha256-oRNrlF1/yK0QvrW2+48RsmSg9h9/pDIfA56/bpoHXFU="; + }) + (fetchNuGet { + pname = "DynamicData"; + version = "9.0.4"; + hash = "sha256-3pyiJeWRwfaT7p1ArsoR13aI78Jo13aHOEw3BelTS9g="; + }) + (fetchNuGet { + pname = "ExCSS"; + version = "4.2.3"; + hash = "sha256-M/H6P5p7qqdFz/fgAI2MMBWQ7neN/GIieYSSxxjsM9I="; + }) + (fetchNuGet { + pname = "FluentAvaloniaUI"; + version = "2.0.5"; + hash = "sha256-EaJ6qR2yn+7p8lf62yx2vL3sGhnPOfbP5jBjR+pGY7o="; + }) + (fetchNuGet { + pname = "FSharp.Core"; + version = "7.0.200"; + hash = "sha256-680VgvYbZbztPQosO17r5y8vxg/Y/4Vmr5K3iLIJKMo="; + }) + (fetchNuGet { + pname = "GtkSharp.Dependencies"; + version = "1.1.1"; + hash = "sha256-/IpSj5JnUTREfQsdA3XW+eqNhqApTds65DQoNpjl3jk="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp"; + version = "2.8.2.3"; + hash = "sha256-4tbdgUabPjlkBm3aUFeocj4Fdslmms2olDFpzOLyqoQ="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp"; + version = "7.3.0"; + hash = "sha256-LlPQO/NYgIMWicvLOtWsQzCp512QpIImYDP9/n2rDOc="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Linux"; + version = "2.8.2.3"; + hash = "sha256-3xwVfNfKTkuLdnT+e3bfG9tNTdEmar7ByzY+NTlUKLg="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Linux"; + version = "7.3.0"; + hash = "sha256-AEHjgqX0o+Fob0SeZ6EikGKoEe6rRxess5fVJ31UL0U="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.macOS"; + version = "2.8.2.3"; + hash = "sha256-ZohUEaovj/sRB4rjuJIOq6S9eim3m+qMlpHIebNDTRQ="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.macOS"; + version = "7.3.0"; + hash = "sha256-6oFcdKb17UX5wyAUeCCKXGvzkf0w3MNdZOVMvs54tqw="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; + version = "2.8.2.3"; + hash = "sha256-ZsiBGpXfODHUHPgU/50k9QR/j6Klo7rsB0SUt8zYcBA="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; + version = "7.3.0"; + hash = "sha256-9VI0xCavuuIIStuQ7ipBfWu5HrAt+Kk/F2j57C1llTU="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Win32"; + version = "2.8.2.3"; + hash = "sha256-5GSzM5IUoOwK+zJg0d74WlT3n1VZly8pKlyjiqVocCI="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Win32"; + version = "7.3.0"; + hash = "sha256-WnB7l73hneU9Kpbm8S9zEYbZHjFre24vWz0vl8+v28M="; + }) + (fetchNuGet { + pname = "LibHac"; + version = "0.19.0"; + hash = "sha256-FDEmeGHbX/aCFjFbFk8QwO2rTfFizt9UKb+KFDt23hk="; + }) + (fetchNuGet { + pname = "MicroCom.CodeGenerator.MSBuild"; + version = "0.11.0"; + hash = "sha256-TsxziX9V8T3qRrEA3o9wY84ocDcUUUBzvARi5QZW23o="; + }) + (fetchNuGet { + pname = "MicroCom.Runtime"; + version = "0.11.0"; + hash = "sha256-VdwpP5fsclvNqJuppaOvwEwv2ofnAI5ZSz2V+UEdLF0="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.0.0"; + hash = "sha256-KDbCfsBWSJ5ohEXUKp1s1LX9xA2NPvXE/xVzj68EdC0="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.3.4"; + hash = "sha256-qDzTfZBSCvAUu9gzq2k+LOvh6/eRvJ9++VCNck/ZpnE="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "3.8.0"; + hash = "sha256-3G9vSc/gHH7FWgOySLTut1+eEaf3H66qcPOvNPLOx4o="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "4.9.2"; + hash = "sha256-QU/nyiJWpdPQGHBdaOEVc+AghnGHcKBFBX0oyhRZ9CQ="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "3.8.0"; + hash = "sha256-i/r3V/No/VzqmJlWxpGoirvlbJDbBPa/ONZtzYrxuc4="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "4.9.2"; + hash = "sha256-j06Q4A9E65075SBXdXVCMRgeLxA63Rv1vxarydmmVAA="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.Scripting"; + version = "3.8.0"; + hash = "sha256-fA9Qu+vTyMZ9REzxJ4aMg/SHCDRk4q9k4ZGUdynoHnA="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Scripting.Common"; + version = "3.8.0"; + hash = "sha256-866jMHp8kbc1FYpKuUWnd7ViU6kGJTAxPcL/IjXrT0I="; + }) + (fetchNuGet { + pname = "Microsoft.CodeCoverage"; + version = "17.9.0"; + hash = "sha256-OaGa4+jRPHs+T+p/oekm2Miluqfd2IX8Rt+BmUx8kr4="; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.3.0"; + hash = "sha256-a3dAiPaVuky0wpcHmpTVtAQJNGZ2v91/oArA+dpJgj8="; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.7.0"; + hash = "sha256-Enknv2RsFF68lEPdrf5M+BpV1kHoLTVRApKUwuk/pj0="; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.PlatformAbstractions"; + version = "3.1.6"; + hash = "sha256-RfM2qXiqdiamPkXr4IDkNc0IZSF9iTZv4uou/E7zNS0="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyModel"; + version = "8.0.0"; + hash = "sha256-qkCdwemqdZY/yIW5Xmh7Exv74XuE39T8aHGHCofoVgo="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.Abstractions"; + version = "8.0.1"; + hash = "sha256-zPWUKTCfGm4MWcYPU037NzezsFE1g8tEijjQkw5iooI="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.JsonWebTokens"; + version = "8.0.1"; + hash = "sha256-Xv9MUnjb66U3xeR9drOcSX5n2DjOCIJZPMNSKjWHo9Y="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.Logging"; + version = "8.0.1"; + hash = "sha256-FfwrH/2eLT521Kqw+RBIoVfzlTNyYMqlWP3z+T6Wy2Y="; + }) + (fetchNuGet { + pname = "Microsoft.IdentityModel.Tokens"; + version = "8.0.1"; + hash = "sha256-beVbbVQy874HlXkTKarPTT5/r7XR1NGHA/50ywWp7YA="; + }) + (fetchNuGet { + pname = "Microsoft.IO.RecyclableMemoryStream"; + version = "3.0.1"; + hash = "sha256-unFg/5EcU/XKJbob4GtQC43Ydgi5VjeBGs7hfhj4EYo="; + }) + (fetchNuGet { + pname = "Microsoft.NET.Test.Sdk"; + version = "17.9.0"; + hash = "sha256-q/1AJ7eNlk02wvN76qvjl2xBx5iJ+h5ssiE/4akLmtI="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "2.0.0"; + hash = "sha256-IEvBk6wUXSdyCnkj6tHahOJv290tVVT8tyemYcR0Yro="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "2.1.2"; + hash = "sha256-gYQQO7zsqG+OtN4ywYQyfsiggS2zmxw4+cPXlK+FB5Q="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.ObjectModel"; + version = "17.9.0"; + hash = "sha256-iiXUFzpvT8OWdzMj9FGJDqanwHx40s1TXVY9l3ii+s0="; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.TestHost"; + version = "17.9.0"; + hash = "sha256-1BZIY1z+C9TROgdTV/tq4zsPy7Q71GQksr/LoMKAzqU="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "4.5.0"; + hash = "sha256-WMBXsIb0DgPFPaFkNVxY9b9vcMxPqtgFgijKYMJfV/0="; + }) + (fetchNuGet { + pname = "MsgPack.Cli"; + version = "1.0.1"; + hash = "sha256-Gf0Ed9XHH4oFpJIkzhg/xhDVpenunSol65qa8IZeYrY="; + }) + (fetchNuGet { + pname = "NetCoreServer"; + version = "8.0.7"; + hash = "sha256-RUYic8uAgJGdhUCrMJQULKlHB6xvw9H1lnNGU1axNZw="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.0"; + hash = "sha256-Pp7fRylai8JrE1O+9TGfIEJrAOmnWTJRLWE+qJBahK0="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.1"; + hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; + }) + (fetchNuGet { + pname = "NUnit"; + version = "3.13.3"; + hash = "sha256-Zn+sJIF7ieNqu/t2RwJx6WPFb1jl9UuNHidb/Px0v3E="; + }) + (fetchNuGet { + pname = "NUnit3TestAdapter"; + version = "4.1.0"; + hash = "sha256-nDPiYdTFulqozEJrujr8/cqjG7m15Vkd/Frqem0Jr/w="; + }) + (fetchNuGet { + pname = "OpenTK.Audio.OpenAL"; + version = "4.8.2"; + hash = "sha256-i5KRiTYTNMB4Y5Qd5xewaYrb9sBbnXMDu2QXbM3RCeU="; + }) + (fetchNuGet { + pname = "OpenTK.Core"; + version = "4.8.2"; + hash = "sha256-59S4Vj13y8HtZT6RZTwO6ZZbk1GUNDcYx1rMdv5jr4I="; + }) + (fetchNuGet { + pname = "OpenTK.Graphics"; + version = "4.8.2"; + hash = "sha256-DNpXqtM9Oj6wDGYSF2FD4A4ueWG892Wk6uGWffNspo0="; + }) + (fetchNuGet { + pname = "OpenTK.Mathematics"; + version = "4.8.2"; + hash = "sha256-TPsts443n6iEajfH2EuYTKtubrWuTLiCrTB1F4FndIo="; + }) + (fetchNuGet { + pname = "OpenTK.redist.glfw"; + version = "3.3.8.39"; + hash = "sha256-bg8bGfoDDqmZ/efLFVm8l5etQajIVvOcQ/Nv+yKD4Bc="; + }) + (fetchNuGet { + pname = "OpenTK.Windowing.GraphicsLibraryFramework"; + version = "4.8.2"; + hash = "sha256-a1MGtU+27pBNns55g8mOsxXpZxfEr6M62zLkIkkJTIY="; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; + }) + (fetchNuGet { + pname = "Ryujinx.AtkSharp"; + version = "3.24.24.59-ryujinx"; + hash = "sha256-mK1zXkd6bdo7YqOm/rcI8MTniugvs5Kjw+esGmHYJxE="; + }) + (fetchNuGet { + pname = "Ryujinx.Audio.OpenAL.Dependencies"; + version = "1.21.0.1"; + hash = "sha256-NHGzMcYduuYJjduIlf8M8zSQQuJcXAEaMNmKIqAgs3w="; + }) + (fetchNuGet { + pname = "Ryujinx.CairoSharp"; + version = "3.24.24.59-ryujinx"; + hash = "sha256-+gV4Vlkd0jMZ6yGCz1/KoiE32/O26gHOZiHXmZ292rE="; + }) + (fetchNuGet { + pname = "Ryujinx.GdkSharp"; + version = "3.24.24.59-ryujinx"; + hash = "sha256-r1UK7YzhMOJ3Z8eWuUyTf0nGQ0Bdlic8Qri170ilEbs="; + }) + (fetchNuGet { + pname = "Ryujinx.GioSharp"; + version = "3.24.24.59-ryujinx"; + hash = "sha256-sbfdn16UoQtcU9gAgvP2kjBUbYi9nKy09bmhvn9IGtU="; + }) + (fetchNuGet { + pname = "Ryujinx.GLibSharp"; + version = "3.24.24.59-ryujinx"; + hash = "sha256-zZv0B4BvKuRdse8oqSbb4P6FFq79w4M+MCk8EqqLVWk="; + }) + (fetchNuGet { + pname = "Ryujinx.Graphics.Nvdec.Dependencies"; + version = "5.0.3-build14"; + hash = "sha256-+ff+tlWggY+qZTBJroOOphRpOjBDg5cQgwGtVOTiqRQ="; + }) + (fetchNuGet { + pname = "Ryujinx.Graphics.Vulkan.Dependencies.MoltenVK"; + version = "1.2.0"; + hash = "sha256-vdDw6YGoyQzv6ustyXP6v7YWUIKEXaZOyUKAaVbRauI="; + }) + (fetchNuGet { + pname = "Ryujinx.GtkSharp"; + version = "3.24.24.59-ryujinx"; + hash = "sha256-2duc6+KLuctobfwqeuewxRLZnXn83QomF4rN0hEoMTc="; + }) + (fetchNuGet { + pname = "Ryujinx.PangoSharp"; + version = "3.24.24.59-ryujinx"; + hash = "sha256-gGAK/aEfTUAxEihjlBOtHlhPZZFAwCasgUB/Umapva0="; + }) + (fetchNuGet { + pname = "Ryujinx.SDL2-CS"; + version = "2.30.0-build32"; + hash = "sha256-KrrlDq0pXcunnOhJL12dt1CAdNbaupbDlnza5gXuVKE="; + }) + (fetchNuGet { + pname = "securifybv.PropertyStore"; + version = "0.1.0"; + hash = "sha256-jTPT9E2LyElgJq4HMavkdwT8tA9uklnJv00mlIx66+g="; + }) + (fetchNuGet { + pname = "securifybv.ShellLink"; + version = "0.1.0"; + hash = "sha256-Am+ZednCVJUDgB7TePyY3CTxKDQ6Lr8M8KiCVAJoouw="; + }) + (fetchNuGet { + pname = "shaderc.net"; + version = "0.1.0"; + hash = "sha256-+K7ObC9ucilwWY+Tlf9KcrAVoTFS65V6Di7JDWDSZTg="; + }) + (fetchNuGet { + pname = "SharpZipLib"; + version = "1.4.2"; + hash = "sha256-/giVqikworG2XKqfN9uLyjUSXr35zBuZ2FX2r8X/WUY="; + }) + (fetchNuGet { + pname = "ShimSkiaSharp"; + version = "1.0.0.18"; + hash = "sha256-72NV+OuW8bCfI/EOXwgS6dleLZnomLJTYeQPPmfhuu8="; + }) + (fetchNuGet { + pname = "Silk.NET.Core"; + version = "2.21.0"; + hash = "sha256-D4ZUCm1Gf/EiRWrSwSLrdXT6U54icY2E/vrvCD/bRHw="; + }) + (fetchNuGet { + pname = "Silk.NET.Vulkan"; + version = "2.21.0"; + hash = "sha256-Xnxl13+ziJ1+jNxMFSrEuh6NvL1FBrYmJ/d3HQXpgzY="; + }) + (fetchNuGet { + pname = "Silk.NET.Vulkan.Extensions.EXT"; + version = "2.21.0"; + hash = "sha256-udELG0ppCOP9eT2yl/sI9MgKOVOuK0py9znmoaBGDpk="; + }) + (fetchNuGet { + pname = "Silk.NET.Vulkan.Extensions.KHR"; + version = "2.21.0"; + hash = "sha256-KyiGHW6CNkXE3EdHk3ufwTVG7oLvSyHwx+MmIJhsiBk="; + }) + (fetchNuGet { + pname = "SkiaSharp"; + version = "2.88.3"; + hash = "sha256-WyMAjnQt8ZsuWpGLI89l/f4bHvv+cg7FdTAL7CtJBvs="; + }) + (fetchNuGet { + pname = "SkiaSharp"; + version = "2.88.6"; + hash = "sha256-y0wzgwdQXtgl5boCz/EgLWbK3SwC0cFVRUbBxOUPQXc="; + }) + (fetchNuGet { + pname = "SkiaSharp"; + version = "2.88.7"; + hash = "sha256-Ip3afwTr4QOqtwOUKqK6g/9Ug4dMSebTci5K29Jc3Dg="; + }) + (fetchNuGet { + pname = "SkiaSharp.HarfBuzz"; + version = "2.88.6"; + hash = "sha256-gpHiTuHfiXgbkBkzipXb8EXIatefsod75nyrFdPcwcA="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Linux"; + version = "2.88.3"; + hash = "sha256-eExWAAURgnwwm2fRwsK/rf+TeOAPs2n02XZzC0zeUjU="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Linux"; + version = "2.88.7"; + hash = "sha256-QdQRN1IBjqohmI8U+6WJRPgOsh8a9soN2UvVObs1H1w="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.macOS"; + version = "2.88.3"; + hash = "sha256-8G4swiLMr6XS3kjfO/YC1PyoVdfSq7nxZthZZ+KTKqQ="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.macOS"; + version = "2.88.6"; + hash = "sha256-7hOMjlYTOiNPLNwfLFUjTcdgiGEtmYUI1EubiRiC6bo="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.macOS"; + version = "2.88.7"; + hash = "sha256-WgPldXSqPMm0TrdUWAyjge5rcRhd9G3/Ix/v/2NQvBc="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.WebAssembly"; + version = "2.88.3"; + hash = "sha256-/SkV2pIZnt0ziSKB7gt7U2Rltk2Id+zOzbmqgfWUtvA="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.WebAssembly"; + version = "2.88.7"; + hash = "sha256-oIjFF+Rv+g8AKyNaaVAgnHX3eeP/l8K2sgHs9bRyUMw="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Win32"; + version = "2.88.3"; + hash = "sha256-2PhMTwRHitT13KCKiZltKIFieAvNY4jBmVZ2ndVynA8="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Win32"; + version = "2.88.6"; + hash = "sha256-ljD4QmAO2/vwA6I8GIUNkONpOzmGsOVJJy9vPDnjVfA="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Win32"; + version = "2.88.7"; + hash = "sha256-+7RxCAr+ne9MZWdXKKpV4ZbHW0k6hLD20ZFWWOCiNYU="; + }) + (fetchNuGet { + pname = "SPB"; + version = "0.0.4-build32"; + hash = "sha256-GUzbV5rLWtXTpiddYrKnWWLujG38vBDCO4xRStwAaDo="; + }) + (fetchNuGet { + pname = "Svg.Custom"; + version = "1.0.0.18"; + hash = "sha256-RguRPwBM/KCogaiOgjELlvuqN1Tr+b3HA4Odz1rXBgU="; + }) + (fetchNuGet { + pname = "Svg.Model"; + version = "1.0.0.18"; + hash = "sha256-CXZC45txfcd8MuRmDENw2ujlGk74YaUPNs7dXq+Zcg8="; + }) + (fetchNuGet { + pname = "Svg.Skia"; + version = "1.0.0.18"; + hash = "sha256-o5VnCaAGX4LuwNyl7QM0KOg2gNfkD5uNMNthxB7w0m4="; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + hash = "sha256-wws90sfi9M7kuCPWkv1CEYMJtCqx9QB/kj0ymlsNaxI="; + }) + (fetchNuGet { + pname = "System.CodeDom"; + version = "4.4.0"; + hash = "sha256-L1xyspJ8pDJNVPYKl+FMGf4Zwm0tlqtAyQCNW6pT6/0="; + }) + (fetchNuGet { + pname = "System.CodeDom"; + version = "8.0.0"; + hash = "sha256-uwVhi3xcvX7eiOGQi7dRETk3Qx1EfHsUfchZsEto338="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "5.0.0"; + hash = "sha256-GdwSIjLMM0uVfE56VUSLVNgpW0B//oCeSFj8/hSlbM8="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "8.0.0"; + hash = "sha256-F7OVjKNwpqbUh8lTidbqJWYi476nsq9n+6k0+QVRo3w="; + }) + (fetchNuGet { + pname = "System.ComponentModel.Annotations"; + version = "4.5.0"; + hash = "sha256-15yE2NoT9vmL9oGCaxHClQR1jLW1j1ef5hHMg55xRso="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.3.0"; + hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; + }) + (fetchNuGet { + pname = "System.IO.Hashing"; + version = "8.0.0"; + hash = "sha256-szOGt0TNBo6dEdC3gf6H+e9YW3Nw0woa6UnCGGGK5cE="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "6.0.0"; + hash = "sha256-xfjF4UqTMJpf8KsBWUyJlJkzPTOO/H5MW023yTYNQSA="; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.3.0"; + hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; + }) + (fetchNuGet { + pname = "System.Management"; + version = "8.0.0"; + hash = "sha256-HwpfDb++q7/vxR6q57mGFgl5U0vxy+oRJ6orFKORfP0="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.5"; + hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.3.0"; + hash = "sha256-eog2Sp8CAntRlyp2Aar1tpAwDrojGFZ5LIdqsmuIchY="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.4.0"; + hash = "sha256-auXQK2flL/JpnB/rEcAcUm4vYMCYMEMiWOCAlIaqu2U="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.3.0"; + hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; + }) + (fetchNuGet { + pname = "System.Reactive"; + version = "6.0.1"; + hash = "sha256-Lo5UMqp8DsbVSUxa2UpClR1GoYzqQQcSxkfyFqB/d4Q="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.3.0"; + hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.3.0"; + hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.3.0"; + hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "1.6.0"; + hash = "sha256-JJfgaPav7UfEh4yRAQdGhLZF1brr0tUWPl6qmfNWq/E="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "5.0.0"; + hash = "sha256-Wo+MiqhcP9dQ6NuFGrQTw6hpbJORFwp+TBNTq2yhGp8="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "8.0.0"; + hash = "sha256-dQGC30JauIDWNWXMrSNOJncVa1umR1sijazYwUDdSIE="; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.3.0"; + hash = "sha256-4U4/XNQAnddgQIHIJq3P2T80hN0oPdU2uCeghsDTWng="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.7.1"; + hash = "sha256-UvyoDV8O0oY3HPG1GbA56YVdvwTGEfjYR5gW1O7IK4U="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "5.0.0"; + hash = "sha256-neARSpLPUzPxEKhJRwoBzhPxK+cKIitLx7WBYncsYgo="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "4.5.0"; + hash = "sha256-AFsKPb/nTk2/mqH/PYpaoI8PLsiKKimaXf+7Mb5VfPM="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.5.0"; + hash = "sha256-BkUYNguz0e4NJp1kkW7aJBn3dyH9STwB5N8XqnlCsmY="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "4.5.1"; + hash = "sha256-PIhkv59IXjyiuefdhKxS9hQfEwO9YWRuNudpo53HQfw="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "8.0.0"; + hash = "sha256-fjCLQc1PRW0Ix5IZldg0XKv+J1DqPSfu9pjMyNBp7dE="; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "8.0.0"; + hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "8.0.0"; + hash = "sha256-XFcCHMW1u2/WujlWNHaIWkbW1wn8W4kI0QdrwPtWmow="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; + }) + (fetchNuGet { + pname = "Tmds.DBus.Protocol"; + version = "0.15.0"; + hash = "sha256-4gk2vXDjKFaBh82gTkwg3c/5GRjiH+bvM5elfDSbKTU="; + }) + (fetchNuGet { + pname = "UnicornEngine.Unicorn"; + version = "2.0.2-rc1-fb78016"; + hash = "sha256-NrJ4/o4FmCt2zoB1fWAzqdonvpYhTFsWwh3h0lxZg+Q="; + }) ] diff --git a/pkgs/by-name/ry/ryzenadj/package.nix b/pkgs/by-name/ry/ryzenadj/package.nix index 79b761be98908a..91e790b7c9cd89 100644 --- a/pkgs/by-name/ry/ryzenadj/package.nix +++ b/pkgs/by-name/ry/ryzenadj/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pciutils, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + pciutils, + cmake, +}: stdenv.mkDerivation rec { pname = "ryzenadj"; version = "0.16.0"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-VuIrA5UrRqwUta/mrYd+6F4gh/Z65+zzoTXUlRA8wzA="; }; - nativeBuildInputs = [ pciutils cmake ]; + nativeBuildInputs = [ + pciutils + cmake + ]; installPhase = '' install -D libryzenadj.so $out/lib/libryzenadj.so diff --git a/pkgs/by-name/rz/rzip/package.nix b/pkgs/by-name/rz/rzip/package.nix index 333f29e53a218a..cd2c4b42ba7a31 100644 --- a/pkgs/by-name/rz/rzip/package.nix +++ b/pkgs/by-name/rz/rzip/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fetchpatch, bzip2 }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + bzip2, +}: stdenv.mkDerivation rec { pname = "rzip"; diff --git a/pkgs/by-name/s-/s-tar/package.nix b/pkgs/by-name/s-/s-tar/package.nix index f16c9eaf498215..b6782f7f14ceb6 100644 --- a/pkgs/by-name/s-/s-tar/package.nix +++ b/pkgs/by-name/s-/s-tar/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "s-tar"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { preConfigure = "rm configure"; preBuild = "sed 's_/bin/__g' -i RULES/*"; makeFlags = [ "GMAKE_NOWARN=true" ]; - installFlags = [ "DESTDIR=$(out)" "INS_BASE=/" ]; + installFlags = [ + "DESTDIR=$(out)" + "INS_BASE=/" + ]; postInstall = '' find $out/bin -type l -delete rm -r $out/etc $out/include $out/sbin diff --git a/pkgs/by-name/s-/s-tui/package.nix b/pkgs/by-name/s-/s-tui/package.nix index c153b3033f86d1..070b44544dd4bb 100644 --- a/pkgs/by-name/s-/s-tui/package.nix +++ b/pkgs/by-name/s-/s-tui/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, python3Packages -, fetchPypi -, nix-update-script -, s-tui -, testers +{ + lib, + stdenv, + python3Packages, + fetchPypi, + nix-update-script, + s-tui, + testers, }: python3Packages.buildPythonPackage rec { diff --git a/pkgs/by-name/s2/s2png/package.nix b/pkgs/by-name/s2/s2png/package.nix index 71f8661dfa2c77..e3b5c6cad0ef4c 100644 --- a/pkgs/by-name/s2/s2png/package.nix +++ b/pkgs/by-name/s2/s2png/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, diffutils, gd, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + diffutils, + gd, + pkg-config, +}: stdenv.mkDerivation rec { pname = "s2png"; @@ -12,8 +19,14 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ diffutils gd ]; - installFlags = [ "prefix=" "DESTDIR=$(out)" ]; + buildInputs = [ + diffutils + gd + ]; + installFlags = [ + "prefix=" + "DESTDIR=$(out)" + ]; meta = { homepage = "https://github.com/dbohdan/s2png/"; diff --git a/pkgs/by-name/s3/s3backer/package.nix b/pkgs/by-name/s3/s3backer/package.nix index bb5877f0acb170..51945c40b1089e 100644 --- a/pkgs/by-name/s3/s3backer/package.nix +++ b/pkgs/by-name/s3/s3backer/package.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchFromGitHub -, autoreconfHook, pkg-config -, fuse, curl, expat }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + fuse, + curl, + expat, +}: stdenv.mkDerivation rec { pname = "s3backer"; @@ -19,8 +26,15 @@ stdenv.mkDerivation rec { ./fix-darwin-builds.patch ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ fuse curl expat ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + fuse + curl + expat + ]; # AC_CHECK_DECLS doesn't work with clang postPatch = lib.optionalString stdenv.cc.isClang '' diff --git a/pkgs/by-name/s3/s3bro/package.nix b/pkgs/by-name/s3/s3bro/package.nix index ee35c619fb7451..fb5b8e8237e66f 100644 --- a/pkgs/by-name/s3/s3bro/package.nix +++ b/pkgs/by-name/s3/s3bro/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/s3/s3proxy/package.nix b/pkgs/by-name/s3/s3proxy/package.nix index d24f3728da1184..b2281b7f2ad954 100644 --- a/pkgs/by-name/s3/s3proxy/package.nix +++ b/pkgs/by-name/s3/s3proxy/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, jre -, makeWrapper -, maven +{ + lib, + stdenv, + fetchFromGitHub, + jre, + makeWrapper, + maven, }: let @@ -41,4 +42,3 @@ maven.buildMavenPackage { maintainers = with maintainers; [ camelpunch ]; }; } - diff --git a/pkgs/by-name/s3/s3scanner/package.nix b/pkgs/by-name/s3/s3scanner/package.nix index dde1360b2bfcfd..96ab22cdfd80ac 100644 --- a/pkgs/by-name/s3/s3scanner/package.nix +++ b/pkgs/by-name/s3/s3scanner/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "s3scanner"; diff --git a/pkgs/by-name/s4/s4cmd/package.nix b/pkgs/by-name/s4/s4cmd/package.nix index 1f4dc14d27f774..0d6686908390a5 100644 --- a/pkgs/by-name/s4/s4cmd/package.nix +++ b/pkgs/by-name/s4/s4cmd/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "s4cmd"; @@ -9,7 +13,10 @@ python3Packages.buildPythonApplication rec { sha256 = "0d4mx98i3qhvlmr9x898mjvf827smzx6x5ji6daiwgjdlxc60mj2"; }; - propagatedBuildInputs = with python3Packages; [ boto3 pytz ]; + propagatedBuildInputs = with python3Packages; [ + boto3 + pytz + ]; # The upstream package tries to install some bash shell completion scripts in /etc. # Setuptools is bugged and doesn't handle --prefix properly: https://github.com/pypa/setuptools/issues/130 diff --git a/pkgs/by-name/s5/s5/package.nix b/pkgs/by-name/s5/s5/package.nix index 85aca4e60dc6f1..0a5debe0e08798 100644 --- a/pkgs/by-name/s5/s5/package.nix +++ b/pkgs/by-name/s5/s5/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "s5"; diff --git a/pkgs/by-name/s5/s5cmd/package.nix b/pkgs/by-name/s5/s5cmd/package.nix index 292169d77f7724..f399d4f695bad4 100644 --- a/pkgs/by-name/s5/s5cmd/package.nix +++ b/pkgs/by-name/s5/s5cmd/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "s5cmd"; diff --git a/pkgs/by-name/s9/s9fes/package.nix b/pkgs/by-name/s9/s9fes/package.nix index 4107b28e1cf9f1..464bb51eb7a121 100644 --- a/pkgs/by-name/s9/s9fes/package.nix +++ b/pkgs/by-name/s9/s9fes/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, ncurses, buildPackages }: +{ + stdenv, + lib, + fetchurl, + ncurses, + buildPackages, +}: let isCrossCompiling = stdenv.hostPlatform != stdenv.buildPlatform; @@ -25,7 +31,10 @@ stdenv.mkDerivation rec { preBuild = '' makeFlagsArray+=(CFLAGS="-O2 -std=c89") ''; - makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "PREFIX=$(out)" ]; + makeFlags = [ + "CC=${stdenv.cc.targetPrefix}cc" + "PREFIX=$(out)" + ]; enableParallelBuilding = true; # ...-bash-5.2-p15/bin/bash: line 1: ...-s9fes-20181205/bin/s9help: No such file or directory diff --git a/pkgs/by-name/sa/sacad/package.nix b/pkgs/by-name/sa/sacad/package.nix index 5868962781b7ea..314aee13dec781 100644 --- a/pkgs/by-name/sa/sacad/package.nix +++ b/pkgs/by-name/sa/sacad/package.nix @@ -1,4 +1,10 @@ -{ lib, python3Packages, fetchPypi, jpegoptim, optipng }: +{ + lib, + python3Packages, + fetchPypi, + jpegoptim, + optipng, +}: python3Packages.buildPythonApplication rec { pname = "sacad"; diff --git a/pkgs/by-name/sa/sacc/package.nix b/pkgs/by-name/sa/sacc/package.nix index 50599651c985d0..edea63ac742c16 100644 --- a/pkgs/by-name/sa/sacc/package.nix +++ b/pkgs/by-name/sa/sacc/package.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchurl, ncurses, libressl -, patches ? [] # allow users to easily override config.def.h +{ + lib, + stdenv, + fetchurl, + ncurses, + libressl, + patches ? [ ], # allow users to easily override config.def.h }: stdenv.mkDerivation rec { @@ -13,7 +18,10 @@ stdenv.mkDerivation rec { inherit patches; - buildInputs = [ ncurses libressl ]; + buildInputs = [ + ncurses + libressl + ]; makeFlags = lib.optionals stdenv.hostPlatform.isDarwin [ "OSCFLAGS=-D_DARWIN_C_SOURCE" @@ -23,7 +31,7 @@ stdenv.mkDerivation rec { substituteInPlace config.mk \ --replace curses ncurses \ --replace "/usr/local" "$out" - ''; + ''; meta = with lib; { description = "Terminal gopher client"; diff --git a/pkgs/by-name/sa/sacd/package.nix b/pkgs/by-name/sa/sacd/package.nix index ddd2c2dcd8c8b1..65d04693b08ecb 100644 --- a/pkgs/by-name/sa/sacd/package.nix +++ b/pkgs/by-name/sa/sacd/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sa/sacrifice/package.nix b/pkgs/by-name/sa/sacrifice/package.nix index b6b53446473fc5..cfbc68f40747c0 100644 --- a/pkgs/by-name/sa/sacrifice/package.nix +++ b/pkgs/by-name/sa/sacrifice/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, boost, hepmc2, lhapdf, pythia, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + boost, + hepmc2, + lhapdf, + pythia, + makeWrapper, +}: stdenv.mkDerivation { pname = "sacrifice"; @@ -9,7 +18,12 @@ stdenv.mkDerivation { sha256 = "10bvpq63kmszy1habydwncm0j1dgvam0fkrmvkgbkvf804dcjp6g"; }; - buildInputs = [ boost hepmc2 lhapdf pythia ]; + buildInputs = [ + boost + hepmc2 + lhapdf + pythia + ]; nativeBuildInputs = [ makeWrapper ]; patches = [ @@ -17,33 +31,38 @@ stdenv.mkDerivation { ./pythia83xx.patch ]; - preConfigure = '' - substituteInPlace configure --replace HAVE_LCG=yes HAVE_LCG=no - '' - + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace configure --replace LIB_SUFFIX=\"so\" LIB_SUFFIX=\"dylib\" - ''; + preConfigure = + '' + substituteInPlace configure --replace HAVE_LCG=yes HAVE_LCG=no + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace configure --replace LIB_SUFFIX=\"so\" LIB_SUFFIX=\"dylib\" + ''; configureFlags = [ "--with-HepMC=${hepmc2}" "--with-pythia=${pythia}" ]; - postInstall = if stdenv.hostPlatform.isDarwin then '' - install_name_tool -add_rpath ${pythia}/lib "$out"/bin/run-pythia - '' else '' - wrapProgram $out/bin/run-pythia \ - --prefix LD_LIBRARY_PATH : "${pythia}/lib" - ''; + postInstall = + if stdenv.hostPlatform.isDarwin then + '' + install_name_tool -add_rpath ${pythia}/lib "$out"/bin/run-pythia + '' + else + '' + wrapProgram $out/bin/run-pythia \ + --prefix LD_LIBRARY_PATH : "${pythia}/lib" + ''; enableParallelBuilding = true; meta = { description = "Standalone contribution to AGILe for steering Pythia 8"; mainProgram = "run-pythia"; - license = lib.licenses.gpl2; - homepage = "https://agile.hepforge.org/trac/wiki/Sacrifice"; - platforms = lib.platforms.unix; + license = lib.licenses.gpl2; + homepage = "https://agile.hepforge.org/trac/wiki/Sacrifice"; + platforms = lib.platforms.unix; maintainers = with lib.maintainers; [ veprbl ]; # never built on aarch64-darwin since first introduction in nixpkgs broken = stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64; diff --git a/pkgs/by-name/sa/safe-rm/package.nix b/pkgs/by-name/sa/safe-rm/package.nix index d3802098de34b7..e9158630269cd0 100644 --- a/pkgs/by-name/sa/safe-rm/package.nix +++ b/pkgs/by-name/sa/safe-rm/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchgit, coreutils, installShellFiles }: +{ + lib, + rustPlatform, + fetchgit, + coreutils, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "safe-rm"; diff --git a/pkgs/by-name/sa/safe/package.nix b/pkgs/by-name/sa/safe/package.nix index 83562ac8f13105..70bade379cd77c 100644 --- a/pkgs/by-name/sa/safe/package.nix +++ b/pkgs/by-name/sa/safe/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/sa/safecloset/package.nix b/pkgs/by-name/sa/safecloset/package.nix index d173777bc3bcf7..0f9ca43291a934 100644 --- a/pkgs/by-name/sa/safecloset/package.nix +++ b/pkgs/by-name/sa/safecloset/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin -, xorg +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, + xorg, }: rustPlatform.buildRustPackage rec { @@ -19,11 +20,13 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-rxNp9dOvy/UTx6Q9pzZGccEKmIiWxzWVYyMxb+h5bqw="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AppKit - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - xorg.libxcb - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AppKit + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + xorg.libxcb + ]; checkFlags = [ # skip flaky test diff --git a/pkgs/by-name/sa/safecopy/package.nix b/pkgs/by-name/sa/safecopy/package.nix index c38b76aeb2eabc..14cc7418a8efe9 100644 --- a/pkgs/by-name/sa/safecopy/package.nix +++ b/pkgs/by-name/sa/safecopy/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "safecopy"; diff --git a/pkgs/by-name/sa/safeeyes/package.nix b/pkgs/by-name/sa/safeeyes/package.nix index 8d83b3c3bb02f8..0873611cedc063 100644 --- a/pkgs/by-name/sa/safeeyes/package.nix +++ b/pkgs/by-name/sa/safeeyes/package.nix @@ -1,16 +1,17 @@ -{ lib -, python3 -, fetchPypi -, alsa-utils -, gobject-introspection -, libnotify -, wlrctl -, gtk3 -, safeeyes -, testers -, xprintidle -, xprop -, wrapGAppsHook3 +{ + lib, + python3, + fetchPypi, + alsa-utils, + gobject-introspection, + libnotify, + wlrctl, + gtk3, + safeeyes, + testers, + xprintidle, + xprop, + wrapGAppsHook3, }: with python3.pkgs; @@ -59,7 +60,14 @@ buildPythonApplication rec { preFixup = '' makeWrapperArgs+=( "''${gappsWrapperArgs[@]}" - --prefix PATH : ${lib.makeBinPath [ alsa-utils wlrctl xprintidle xprop ]} + --prefix PATH : ${ + lib.makeBinPath [ + alsa-utils + wlrctl + xprintidle + xprop + ] + } ) ''; diff --git a/pkgs/by-name/sa/safefile/package.nix b/pkgs/by-name/sa/safefile/package.nix index 279ce4356b691f..507f1bbcdd450c 100644 --- a/pkgs/by-name/sa/safefile/package.nix +++ b/pkgs/by-name/sa/safefile/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "safefile"; version = "1.0.5"; diff --git a/pkgs/by-name/sa/sage/env-locations.nix b/pkgs/by-name/sa/sage/env-locations.nix index 1ca0f471a7ee28..8a9974af763e5b 100644 --- a/pkgs/by-name/sa/sage/env-locations.nix +++ b/pkgs/by-name/sa/sage/env-locations.nix @@ -1,17 +1,18 @@ -{ writeTextFile -, pari_data -, pari -, singular -, maxima -, graphs -, elliptic_curves -, polytopes_db -, gap -, combinatorial_designs -, jmol -, mathjax -, three -, cysignals +{ + writeTextFile, + pari_data, + pari, + singular, + maxima, + graphs, + elliptic_curves, + polytopes_db, + gap, + combinatorial_designs, + jmol, + mathjax, + three, + cysignals, }: # A bash script setting various environment variables to tell sage where diff --git a/pkgs/by-name/sa/sage/package.nix b/pkgs/by-name/sa/sage/package.nix index 95ad7ab120134c..a3f06f4a9e4545 100644 --- a/pkgs/by-name/sa/sage/package.nix +++ b/pkgs/by-name/sa/sage/package.nix @@ -1,7 +1,8 @@ -{ pkgs -, withDoc ? false -, requireSageTests ? true -, extraPythonPackages ? ps: [] +{ + pkgs, + withDoc ? false, + requireSageTests ? true, + extraPythonPackages ? ps: [ ], }: # Here sage and its dependencies are put together. Some dependencies may be pinned @@ -12,24 +13,26 @@ let inherit (pkgs) symlinkJoin callPackage nodePackages; python3 = pkgs.python3 // { - pkgs = pkgs.python3.pkgs.overrideScope (self: super: { - # `sagelib`, i.e. all of sage except some wrappers and runtime dependencies - sagelib = self.callPackage ./sagelib.nix { - inherit flint3; - inherit sage-src env-locations singular; - inherit (maxima) lisp-compiler; - linbox = pkgs.linbox; - pkg-config = pkgs.pkg-config; # not to confuse with pythonPackages.pkg-config - }; - - sage-docbuild = self.callPackage ./python-modules/sage-docbuild.nix { - inherit sage-src; - }; - - sage-setup = self.callPackage ./python-modules/sage-setup.nix { - inherit sage-src; - }; - }); + pkgs = pkgs.python3.pkgs.overrideScope ( + self: super: { + # `sagelib`, i.e. all of sage except some wrappers and runtime dependencies + sagelib = self.callPackage ./sagelib.nix { + inherit flint3; + inherit sage-src env-locations singular; + inherit (maxima) lisp-compiler; + linbox = pkgs.linbox; + pkg-config = pkgs.pkg-config; # not to confuse with pythonPackages.pkg-config + }; + + sage-docbuild = self.callPackage ./python-modules/sage-docbuild.nix { + inherit sage-src; + }; + + sage-setup = self.callPackage ./python-modules/sage-setup.nix { + inherit sage-src; + }; + } + ); }; # matches src/sage/repl/ipython_kernel/install.py:kernel_spec @@ -73,7 +76,14 @@ let sagelib = python3.pkgs.sagelib; sage-docbuild = python3.pkgs.sage-docbuild; inherit env-locations; - inherit python3 singular palp flint3 pythonEnv maxima; + inherit + python3 + singular + palp + flint3 + pythonEnv + maxima + ; pkg-config = pkgs.pkg-config; # not to confuse with pythonPackages.pkg-config }; @@ -100,31 +110,38 @@ let pytest = python3.pkgs.pytest; }; - sage-src = callPackage ./sage-src.nix {}; - - pythonRuntimeDeps = with python3.pkgs; [ - sagelib - sage-docbuild - cvxopt - networkx - service-identity - psutil - sympy - fpylll - matplotlib - tkinter # optional, as a matplotlib backend (use with `%matplotlib tk`) - scipy - ipywidgets - notebook # for "sage -n" - rpy2 - sphinx - pillow - ] ++ extraPythonPackages python3.pkgs; - - pythonEnv = python3.buildEnv.override { - extraLibs = pythonRuntimeDeps; - ignoreCollisions = true; - } // { extraLibs = pythonRuntimeDeps; }; # make the libs accessible + sage-src = callPackage ./sage-src.nix { }; + + pythonRuntimeDeps = + with python3.pkgs; + [ + sagelib + sage-docbuild + cvxopt + networkx + service-identity + psutil + sympy + fpylll + matplotlib + tkinter # optional, as a matplotlib backend (use with `%matplotlib tk`) + scipy + ipywidgets + notebook # for "sage -n" + rpy2 + sphinx + pillow + ] + ++ extraPythonPackages python3.pkgs; + + pythonEnv = + python3.buildEnv.override { + extraLibs = pythonRuntimeDeps; + ignoreCollisions = true; + } + // { + extraLibs = pythonRuntimeDeps; + }; # make the libs accessible singular = pkgs.singular.override { inherit flint3; }; @@ -155,10 +172,22 @@ let palp = symlinkJoin { name = "palp-${pkgs.palp.version}"; paths = [ - (pkgs.palp.override { dimensions = 4; doSymlink = false; }) - (pkgs.palp.override { dimensions = 5; doSymlink = false; }) - (pkgs.palp.override { dimensions = 6; doSymlink = true; }) - (pkgs.palp.override { dimensions = 11; doSymlink = false; }) + (pkgs.palp.override { + dimensions = 4; + doSymlink = false; + }) + (pkgs.palp.override { + dimensions = 5; + doSymlink = false; + }) + (pkgs.palp.override { + dimensions = 6; + doSymlink = true; + }) + (pkgs.palp.override { + dimensions = 11; + doSymlink = false; + }) ]; }; @@ -173,6 +202,12 @@ let in # A wrapper around sage that makes sure sage finds its docs (if they were build). callPackage ./sage.nix { - inherit sage-tests sage-with-env sagedoc jupyter-kernel-definition jupyter-kernel-specs; + inherit + sage-tests + sage-with-env + sagedoc + jupyter-kernel-definition + jupyter-kernel-specs + ; inherit withDoc requireSageTests; } diff --git a/pkgs/by-name/sa/sage/python-modules/sage-docbuild.nix b/pkgs/by-name/sa/sage/python-modules/sage-docbuild.nix index 43f67b97a278e9..f55a9288b02005 100644 --- a/pkgs/by-name/sa/sage/python-modules/sage-docbuild.nix +++ b/pkgs/by-name/sa/sage/python-modules/sage-docbuild.nix @@ -1,11 +1,12 @@ -{ lib -, buildPythonPackage -, sage-src -, furo -, jupyter-sphinx -, sphinx -, sphinx-copybutton -, sphinx-inline-tabs +{ + lib, + buildPythonPackage, + sage-src, + furo, + jupyter-sphinx, + sphinx, + sphinx-copybutton, + sphinx-inline-tabs, }: buildPythonPackage rec { diff --git a/pkgs/by-name/sa/sage/python-modules/sage-setup.nix b/pkgs/by-name/sa/sage/python-modules/sage-setup.nix index e1c497678d50bf..29dea0671ea24b 100644 --- a/pkgs/by-name/sa/sage/python-modules/sage-setup.nix +++ b/pkgs/by-name/sa/sage/python-modules/sage-setup.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonPackage -, sage-src -, cython -, jinja2 -, pkgconfig # the python module, not the pkg-config alias +{ + lib, + buildPythonPackage, + sage-src, + cython, + jinja2, + pkgconfig, # the python module, not the pkg-config alias }: buildPythonPackage rec { diff --git a/pkgs/by-name/sa/sage/sage-env.nix b/pkgs/by-name/sa/sage/sage-env.nix index 2dffa14c6614f8..0a1dabb1434746 100644 --- a/pkgs/by-name/sa/sage/sage-env.nix +++ b/pkgs/by-name/sa/sage/sage-env.nix @@ -1,56 +1,57 @@ -{ stdenv -, lib -, writeTextFile -, sagelib -, sage-docbuild -, env-locations -, gfortran -, ninja -, bash -, coreutils -, gnused -, gnugrep -, gawk -, binutils -, pythonEnv -, python3 -, pkg-config -, pari -, gap -, maxima -, singular -, fflas-ffpack -, givaro -, gd -, libpng -, linbox -, m4ri -, giac -, palp -, rWrapper -, gfan -, cddlib -, jmol -, tachyon -, glpk -, eclib -, sympow -, nauty -, sqlite -, ppl -, ecm -, lcalc -, rubiks -, blas -, lapack -, flint3 -, gmp -, mpfr -, zlib -, gsl -, ntl -, jre8 -, less +{ + stdenv, + lib, + writeTextFile, + sagelib, + sage-docbuild, + env-locations, + gfortran, + ninja, + bash, + coreutils, + gnused, + gnugrep, + gawk, + binutils, + pythonEnv, + python3, + pkg-config, + pari, + gap, + maxima, + singular, + fflas-ffpack, + givaro, + gd, + libpng, + linbox, + m4ri, + giac, + palp, + rWrapper, + gfan, + cddlib, + jmol, + tachyon, + glpk, + eclib, + sympow, + nauty, + sqlite, + ppl, + ecm, + lcalc, + rubiks, + blas, + lapack, + flint3, + gmp, + mpfr, + zlib, + gsl, + ntl, + jre8, + less, }: assert (!blas.isILP64) && (!lapack.isILP64); @@ -60,137 +61,157 @@ assert (!blas.isILP64) && (!lapack.isILP64); # dependencies. let - runtimepath = (lib.makeBinPath ([ - "@sage-local@" - "@sage-local@/build" - pythonEnv - gfortran # for inline fortran - ninja # for inline fortran via numpy.f2py - stdenv.cc # for cython - bash - coreutils - gnused - gnugrep - gawk - binutils.bintools - pkg-config - pari - gap - maxima.lisp-compiler - maxima - singular - giac - palp - # needs to be rWrapper since the default `R` doesn't include R's default libraries - rWrapper - gfan - cddlib - jmol - tachyon - glpk - eclib - sympow - nauty - sqlite - ppl - ecm - lcalc - rubiks - jre8 # only needed for `jmol` (https://sourceforge.net/p/jmol/mailman/message/58818762/), which will be optional in sage 10.5 - less # needed to prevent transient test errors until https://github.com/ipython/ipython/pull/11864 is resolved - ] - )); + runtimepath = ( + lib.makeBinPath ([ + "@sage-local@" + "@sage-local@/build" + pythonEnv + gfortran # for inline fortran + ninja # for inline fortran via numpy.f2py + stdenv.cc # for cython + bash + coreutils + gnused + gnugrep + gawk + binutils.bintools + pkg-config + pari + gap + maxima.lisp-compiler + maxima + singular + giac + palp + # needs to be rWrapper since the default `R` doesn't include R's default libraries + rWrapper + gfan + cddlib + jmol + tachyon + glpk + eclib + sympow + nauty + sqlite + ppl + ecm + lcalc + rubiks + jre8 # only needed for `jmol` (https://sourceforge.net/p/jmol/mailman/message/58818762/), which will be optional in sage 10.5 + less # needed to prevent transient test errors until https://github.com/ipython/ipython/pull/11864 is resolved + ]) + ); in writeTextFile rec { name = "sage-env"; destination = "/${name}"; - text = '' - export PKG_CONFIG_PATH='${lib.makeSearchPathOutput "dev" "lib/pkgconfig" [ - # This should only be needed during build. However, since the doctests - # also test the cython build (for example in src/sage/misc/cython.py), - # it is also needed for the testsuite to pass. We could fix the - # testsuite instead, but since all the packages are also runtime - # dependencies it doesn't really hurt to include them here. - singular - blas lapack - fflas-ffpack givaro - gd - libpng zlib - gsl - linbox - m4ri - ] - }' - export SAGE_ROOT='${sagelib.src}' - '' + - # TODO: is using pythonEnv instead of @sage-local@ here a good - # idea? there is a test in src/sage/env.py that checks if the values - # SAGE_ROOT and SAGE_LOCAL set here match the ones set in env.py. - # we fix up env.py's SAGE_ROOT in sage-src.nix (which does not - # have access to sage-with-env), but env.py autodetects - # SAGE_LOCAL to be pythonEnv. - # setting SAGE_LOCAL to pythonEnv also avoids having to create - # python3, ipython, ipython3 and jupyter symlinks in - # sage-with-env.nix. - '' - export SAGE_LOCAL='${pythonEnv}' + text = + '' + export PKG_CONFIG_PATH='${ + lib.makeSearchPathOutput "dev" "lib/pkgconfig" [ + # This should only be needed during build. However, since the doctests + # also test the cython build (for example in src/sage/misc/cython.py), + # it is also needed for the testsuite to pass. We could fix the + # testsuite instead, but since all the packages are also runtime + # dependencies it doesn't really hurt to include them here. + singular + blas + lapack + fflas-ffpack + givaro + gd + libpng + zlib + gsl + linbox + m4ri + ] + }' + export SAGE_ROOT='${sagelib.src}' + '' + + + # TODO: is using pythonEnv instead of @sage-local@ here a good + # idea? there is a test in src/sage/env.py that checks if the values + # SAGE_ROOT and SAGE_LOCAL set here match the ones set in env.py. + # we fix up env.py's SAGE_ROOT in sage-src.nix (which does not + # have access to sage-with-env), but env.py autodetects + # SAGE_LOCAL to be pythonEnv. + # setting SAGE_LOCAL to pythonEnv also avoids having to create + # python3, ipython, ipython3 and jupyter symlinks in + # sage-with-env.nix. + '' + export SAGE_LOCAL='${pythonEnv}' - export SAGE_SHARE='${sagelib}/share' - export SAGE_ENV_CONFIG_SOURCED=1 # sage-env complains if sage-env-config is not sourced beforehand - orig_path="$PATH" - export PATH='${runtimepath}' + export SAGE_SHARE='${sagelib}/share' + export SAGE_ENV_CONFIG_SOURCED=1 # sage-env complains if sage-env-config is not sourced beforehand + orig_path="$PATH" + export PATH='${runtimepath}' - # set dependent vars, like JUPYTER_CONFIG_DIR - source "${sagelib.src}/src/bin/sage-env" - export PATH="$RUNTIMEPATH_PREFIX:${runtimepath}:$orig_path" # sage-env messes with PATH + # set dependent vars, like JUPYTER_CONFIG_DIR + source "${sagelib.src}/src/bin/sage-env" + export PATH="$RUNTIMEPATH_PREFIX:${runtimepath}:$orig_path" # sage-env messes with PATH - export SAGE_LOGS="$TMPDIR/sage-logs" - export SAGE_DOC="''${SAGE_DOC_OVERRIDE:-doc-placeholder}" - export SAGE_DOC_SRC="''${SAGE_DOC_SRC_OVERRIDE:-${sagelib.src}/src/doc}" + export SAGE_LOGS="$TMPDIR/sage-logs" + export SAGE_DOC="''${SAGE_DOC_OVERRIDE:-doc-placeholder}" + export SAGE_DOC_SRC="''${SAGE_DOC_SRC_OVERRIDE:-${sagelib.src}/src/doc}" - # set locations of dependencies - . ${env-locations}/sage-env-locations + # set locations of dependencies + . ${env-locations}/sage-env-locations - # needed for cython - export CC='${stdenv.cc}/bin/${stdenv.cc.targetPrefix}cc' - export CXX='${stdenv.cc}/bin/${stdenv.cc.targetPrefix}c++' - # cython needs to find these libraries, otherwise will fail with `ld: cannot find -lflint` or similar - export LDFLAGS='${ - lib.concatStringsSep " " (map (pkg: "-L${pkg}/lib") [ - flint3 - gap - glpk - gmp - mpfr - pari - zlib - eclib - gsl - ntl - jmol - sympow - ]) - }' - export CFLAGS='${ - lib.concatStringsSep " " (map (pkg: "-isystem ${pkg}/include") [ - singular - gmp.dev - glpk - flint3 - gap - mpfr.dev - ]) - }' - export CXXFLAGS=$CFLAGS + # needed for cython + export CC='${stdenv.cc}/bin/${stdenv.cc.targetPrefix}cc' + export CXX='${stdenv.cc}/bin/${stdenv.cc.targetPrefix}c++' + # cython needs to find these libraries, otherwise will fail with `ld: cannot find -lflint` or similar + export LDFLAGS='${ + lib.concatStringsSep " " ( + map (pkg: "-L${pkg}/lib") [ + flint3 + gap + glpk + gmp + mpfr + pari + zlib + eclib + gsl + ntl + jmol + sympow + ] + ) + }' + export CFLAGS='${ + lib.concatStringsSep " " ( + map (pkg: "-isystem ${pkg}/include") [ + singular + gmp.dev + glpk + flint3 + gap + mpfr.dev + ] + ) + }' + export CXXFLAGS=$CFLAGS - export SAGE_LIB='${sagelib}/${python3.sitePackages}' + export SAGE_LIB='${sagelib}/${python3.sitePackages}' - export SAGE_EXTCODE='${sagelib.src}/src/sage/ext_data' + export SAGE_EXTCODE='${sagelib.src}/src/sage/ext_data' - # for find_library - export DYLD_LIBRARY_PATH="${lib.makeLibraryPath [stdenv.cc.libc singular giac gap]}''${DYLD_LIBRARY_PATH:+:}$DYLD_LIBRARY_PATH" - ''; -} // { # equivalent of `passthru`, which `writeTextFile` doesn't support + # for find_library + export DYLD_LIBRARY_PATH="${ + lib.makeLibraryPath [ + stdenv.cc.libc + singular + giac + gap + ] + }''${DYLD_LIBRARY_PATH:+:}$DYLD_LIBRARY_PATH" + ''; +} +// { + # equivalent of `passthru`, which `writeTextFile` doesn't support lib = sagelib; docbuild = sage-docbuild; } diff --git a/pkgs/by-name/sa/sage/sage-src.nix b/pkgs/by-name/sa/sage/sage-src.nix index 1ccc6b8eb587c5..d191b4a2ef70fe 100644 --- a/pkgs/by-name/sa/sage/sage-src.nix +++ b/pkgs/by-name/sa/sage/sage-src.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, fetchurl +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + fetchurl, }: # This file is responsible for fetching the sage source and adding necessary patches. @@ -32,23 +33,25 @@ stdenv.mkDerivation rec { # Patches needed because of particularities of nix or the way this is packaged. # The goal is to upstream all of them and get rid of this list. - nixPatches = [ - # Parallelize docubuild using subprocesses, fixing an isolation issue. See - # https://groups.google.com/forum/#!topic/sage-packaging/YGOm8tkADrE - ./patches/sphinx-docbuild-subprocesses.patch - - # After updating smypow to (https://github.com/sagemath/sage/issues/3360) - # we can now set the cache dir to be within the .sage directory. This is - # not strictly necessary, but keeps us from littering in the user's HOME. - ./patches/sympow-cache.patch - ] ++ lib.optionals (stdenv.cc.isClang) [ - # https://github.com/NixOS/nixpkgs/pull/264126 - # Dead links in python sysconfig cause LLVM linker warnings, leading to cython doctest failures. - ./patches/silence-linker.patch - - # Stack overflows during doctests; this does not change functionality. - ./patches/disable-singular-doctest.patch - ]; + nixPatches = + [ + # Parallelize docubuild using subprocesses, fixing an isolation issue. See + # https://groups.google.com/forum/#!topic/sage-packaging/YGOm8tkADrE + ./patches/sphinx-docbuild-subprocesses.patch + + # After updating smypow to (https://github.com/sagemath/sage/issues/3360) + # we can now set the cache dir to be within the .sage directory. This is + # not strictly necessary, but keeps us from littering in the user's HOME. + ./patches/sympow-cache.patch + ] + ++ lib.optionals (stdenv.cc.isClang) [ + # https://github.com/NixOS/nixpkgs/pull/264126 + # Dead links in python sysconfig cause LLVM linker warnings, leading to cython doctest failures. + ./patches/silence-linker.patch + + # Stack overflows during doctests; this does not change functionality. + ./patches/disable-singular-doctest.patch + ]; # Since sage unfortunately does not release bugfix releases, packagers must # fix those bugs themselves. This is for critical bugfixes, where "critical" @@ -78,7 +81,10 @@ stdenv.mkDerivation rec { patches = nixPatches ++ bugfixPatches ++ packageUpgradePatches; # do not create .orig backup files if patch applies with fuzz - patchFlags = [ "--no-backup-if-mismatch" "-p1" ]; + patchFlags = [ + "--no-backup-if-mismatch" + "-p1" + ]; postPatch = '' # Make sure sage can at least be imported without setting any environment diff --git a/pkgs/by-name/sa/sage/sage-tests.nix b/pkgs/by-name/sa/sage/sage-tests.nix index e50754986709c4..6080d8204fc15f 100644 --- a/pkgs/by-name/sa/sage/sage-tests.nix +++ b/pkgs/by-name/sa/sage/sage-tests.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, pytest -, sage-with-env -, makeWrapper -, files ? null # "null" means run all tests -, longTests ? true # run tests marked as "long time" (roughly doubles runtime) -# Run as many tests as possible in approximately n seconds. This will give each -# file to test a "time budget" and stop tests if it is exceeded. 300 is the -# upstream default value. -# https://trac.sagemath.org/ticket/25270 for details. -, timeLimit ? null +{ + stdenv, + lib, + pytest, + sage-with-env, + makeWrapper, + files ? null, # "null" means run all tests + longTests ? true, # run tests marked as "long time" (roughly doubles runtime) + # Run as many tests as possible in approximately n seconds. This will give each + # file to test a "time budget" and stop tests if it is exceeded. 300 is the + # upstream default value. + # https://trac.sagemath.org/ticket/25270 for details. + timeLimit ? null, }: # for a quick test of some source files: diff --git a/pkgs/by-name/sa/sage/sage-with-env.nix b/pkgs/by-name/sa/sage/sage-with-env.nix index 88c753e89c9da9..44d2c62c4426ea 100644 --- a/pkgs/by-name/sa/sage/sage-with-env.nix +++ b/pkgs/by-name/sa/sage/sage-with-env.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, sage-env -, blas -, lapack -, pkg-config -, three -, singular -, gap -, giac -, maxima -, pari -, gmp -, gfan -, python3 -, eclib -, ntl -, ecm -, pythonEnv +{ + stdenv, + lib, + sage-env, + blas, + lapack, + pkg-config, + three, + singular, + gap, + giac, + maxima, + pari, + gmp, + gfan, + python3, + eclib, + ntl, + ecm, + pythonEnv, }: # lots of segfaults with (64 bit) blas @@ -29,7 +30,8 @@ let nativeBuildInputs = [ pkg-config ]; buildInputs = [ pythonEnv # for patchShebangs - blas lapack + blas + lapack singular three giac @@ -45,41 +47,48 @@ let # remove python prefix, replace "-" in the name by "_", apply patch_names # python3.8-some-pkg-1.0 -> some_pkg-1.0 - pkg_to_spkg_name = pkg: patch_names: let - parts = lib.splitString "-" pkg.name; - # remove python3.8- - stripped_parts = if (builtins.head parts) == python3.libPrefix then builtins.tail parts else parts; - version = lib.last stripped_parts; - orig_pkgname = lib.init stripped_parts; - pkgname = patch_names (lib.concatStringsSep "_" orig_pkgname); - in pkgname + "-" + version; - + pkg_to_spkg_name = + pkg: patch_names: + let + parts = lib.splitString "-" pkg.name; + # remove python3.8- + stripped_parts = if (builtins.head parts) == python3.libPrefix then builtins.tail parts else parts; + version = lib.last stripped_parts; + orig_pkgname = lib.init stripped_parts; + pkgname = patch_names (lib.concatStringsSep "_" orig_pkgname); + in + pkgname + "-" + version; # return the names of all dependencies in the transitive closure - transitiveClosure = dep: - if dep == null then - # propagatedBuildInputs might contain null - # (although that might be considered a programming error in the derivation) - [] - else - [ dep ] ++ ( - if builtins.hasAttr "propagatedBuildInputs" dep then - lib.unique (builtins.concatLists (map transitiveClosure dep.propagatedBuildInputs)) - else - [] - ); + transitiveClosure = + dep: + if dep == null then + # propagatedBuildInputs might contain null + # (although that might be considered a programming error in the derivation) + [ ] + else + [ dep ] + ++ ( + if builtins.hasAttr "propagatedBuildInputs" dep then + lib.unique (builtins.concatLists (map transitiveClosure dep.propagatedBuildInputs)) + else + [ ] + ); allInputs = lib.remove null (nativeBuildInputs ++ buildInputs ++ pythonEnv.extraLibs); - transitiveDeps = lib.unique (builtins.concatLists (map transitiveClosure allInputs )); + transitiveDeps = lib.unique (builtins.concatLists (map transitiveClosure allInputs)); # fix differences between spkg and sage names # (could patch sage instead, but this is more lightweight and also works for packages depending on sage) - patch_names = builtins.replaceStrings [ - "zope.interface" - "node_three" - ] [ - "zope-interface" - "threejs" - ]; + patch_names = + builtins.replaceStrings + [ + "zope.interface" + "node_three" + ] + [ + "zope-interface" + "threejs" + ]; # spkg names (this_is_a_package-version) of all transitive deps input_names = map (dep: pkg_to_spkg_name dep patch_names) transitiveDeps; in diff --git a/pkgs/by-name/sa/sage/sage.nix b/pkgs/by-name/sa/sage/sage.nix index cc39624b7f1107..e909d1ef58e010 100644 --- a/pkgs/by-name/sa/sage/sage.nix +++ b/pkgs/by-name/sa/sage/sage.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, makeWrapper -, sage-tests -, sage-with-env -, jupyter-kernel-definition -, jupyter-kernel-specs -, sagedoc -, withDoc -, requireSageTests +{ + lib, + stdenv, + makeWrapper, + sage-tests, + sage-with-env, + jupyter-kernel-definition, + jupyter-kernel-specs, + sagedoc, + withDoc, + requireSageTests, }: # A wrapper that makes sure sage finds its docs (if they were build) and the @@ -31,9 +33,7 @@ stdenv.mkDerivation rec { installPhase = '' mkdir -p "$out/bin" makeWrapper "${sage-with-env}/bin/sage" "$out/bin/sage" \ - --set SAGE_DOC_SRC_OVERRIDE "${src}/src/doc" ${ - lib.optionalString withDoc "--set SAGE_DOC_OVERRIDE ${sagedoc}/share/doc/sage" - } \ + --set SAGE_DOC_SRC_OVERRIDE "${src}/src/doc" ${lib.optionalString withDoc "--set SAGE_DOC_OVERRIDE ${sagedoc}/share/doc/sage"} \ --prefix JUPYTER_PATH : "${jupyter-kernel-specs}" ''; @@ -44,15 +44,20 @@ stdenv.mkDerivation rec { "$out/bin/sage" -c 'browse_sage_doc._open("reference", testing=True)' ''; - passthru = { - tests = sage-tests; - quicktest = sage-tests.override { longTests = false; timeLimit = 600; }; # as many tests as possible in ~10m - lib = sage-with-env.env.lib; - with-env = sage-with-env; - kernelspec = jupyter-kernel-definition; - } // lib.optionalAttrs withDoc { - doc = sagedoc; - }; + passthru = + { + tests = sage-tests; + quicktest = sage-tests.override { + longTests = false; + timeLimit = 600; + }; # as many tests as possible in ~10m + lib = sage-with-env.env.lib; + with-env = sage-with-env; + kernelspec = jupyter-kernel-definition; + } + // lib.optionalAttrs withDoc { + doc = sagedoc; + }; meta = with lib; { description = "Open Source Mathematics Software, free alternative to Magma, Maple, Mathematica, and Matlab"; diff --git a/pkgs/by-name/sa/sage/sagedoc.nix b/pkgs/by-name/sa/sage/sagedoc.nix index cbf593398ac440..7db4d6b4e07e42 100644 --- a/pkgs/by-name/sa/sage/sagedoc.nix +++ b/pkgs/by-name/sa/sage/sagedoc.nix @@ -1,7 +1,8 @@ -{ stdenv -, sage-with-env -, python3 -, jupyter-kernel-specs +{ + stdenv, + sage-with-env, + python3, + jupyter-kernel-specs, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sa/sage/sagelib.nix b/pkgs/by-name/sa/sage/sagelib.nix index 1a138eea81d9ed..98096eadb66961 100644 --- a/pkgs/by-name/sa/sage/sagelib.nix +++ b/pkgs/by-name/sa/sage/sagelib.nix @@ -1,85 +1,86 @@ -{ sage-src -, env-locations -, python -, buildPythonPackage -, m4 -, perl -, pkg-config -, sage-setup -, setuptools -, gd -, iml -, libpng -, readline -, blas -, boost -, brial -, cliquer -, eclib -, ecm -, fflas-ffpack -, flint3 -, gap -, giac -, givaro -, glpk -, gsl -, lapack -, lcalc -, libbraiding -, libhomfly -, libmpc -, linbox -, lisp-compiler -, lrcalc -, m4ri -, m4rie -, mpfi -, mpfr -, ntl -, pari -, planarity -, ppl -, rankwidth -, ratpoints -, singular -, sqlite -, symmetrica -, conway-polynomials -, cvxopt -, cypari2 -, cysignals -, cython -, fpylll -, gmpy2 -, importlib-metadata -, importlib-resources -, ipykernel -, ipython -, ipywidgets -, jinja2 -, jupyter-client -, jupyter-core -, lrcalc-python -, matplotlib -, memory-allocator -, meson-python -, mpmath -, networkx -, numpy -, pexpect -, pillow -, pip -, pkgconfig -, pplpy -, primecountpy -, ptyprocess -, requests -, rpy2 -, scipy -, sphinx -, sympy -, typing-extensions +{ + sage-src, + env-locations, + python, + buildPythonPackage, + m4, + perl, + pkg-config, + sage-setup, + setuptools, + gd, + iml, + libpng, + readline, + blas, + boost, + brial, + cliquer, + eclib, + ecm, + fflas-ffpack, + flint3, + gap, + giac, + givaro, + glpk, + gsl, + lapack, + lcalc, + libbraiding, + libhomfly, + libmpc, + linbox, + lisp-compiler, + lrcalc, + m4ri, + m4rie, + mpfi, + mpfr, + ntl, + pari, + planarity, + ppl, + rankwidth, + ratpoints, + singular, + sqlite, + symmetrica, + conway-polynomials, + cvxopt, + cypari2, + cysignals, + cython, + fpylll, + gmpy2, + importlib-metadata, + importlib-resources, + ipykernel, + ipython, + ipywidgets, + jinja2, + jupyter-client, + jupyter-core, + lrcalc-python, + matplotlib, + memory-allocator, + meson-python, + mpmath, + networkx, + numpy, + pexpect, + pillow, + pip, + pkgconfig, + pplpy, + primecountpy, + ptyprocess, + requests, + rpy2, + scipy, + sphinx, + sympy, + typing-extensions, }: assert (!blas.isILP64) && (!lapack.isILP64); diff --git a/pkgs/by-name/sa/sagetex/package.nix b/pkgs/by-name/sa/sagetex/package.nix index 96513b4f9f3963..ed31393e365eed 100644 --- a/pkgs/by-name/sa/sagetex/package.nix +++ b/pkgs/by-name/sa/sagetex/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, writeShellScript -, texliveBasic +{ + lib, + stdenv, + fetchFromGitHub, + writeShellScript, + texliveBasic, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sa/sagittarius-scheme/package.nix b/pkgs/by-name/sa/sagittarius-scheme/package.nix index e370c56f028130..c586a0f622e8e6 100644 --- a/pkgs/by-name/sa/sagittarius-scheme/package.nix +++ b/pkgs/by-name/sa/sagittarius-scheme/package.nix @@ -1,18 +1,25 @@ -{ lib, stdenv -, fetchurl -, cmake -, pkg-config -, libffi -, boehmgc -, openssl -, zlib -, odbcSupport ? !stdenv.hostPlatform.isDarwin -, libiodbc +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + libffi, + boehmgc, + openssl, + zlib, + odbcSupport ? !stdenv.hostPlatform.isDarwin, + libiodbc, }: -let platformLdLibraryPath = if stdenv.hostPlatform.isDarwin then "DYLD_FALLBACK_LIBRARY_PATH" - else if (stdenv.hostPlatform.isLinux or stdenv.hostPlatform.isBSD) then "LD_LIBRARY_PATH" - else throw "unsupported platform"; +let + platformLdLibraryPath = + if stdenv.hostPlatform.isDarwin then + "DYLD_FALLBACK_LIBRARY_PATH" + else if (stdenv.hostPlatform.isLinux or stdenv.hostPlatform.isBSD) then + "LD_LIBRARY_PATH" + else + throw "unsupported platform"; in stdenv.mkDerivation rec { pname = "sagittarius-scheme"; @@ -22,21 +29,32 @@ stdenv.mkDerivation rec { hash = "sha256-w6aQkC7/vKO8exvDpsSsLyLXrm4FSKh8XYGJgseEII0="; }; preBuild = '' - # since we lack rpath during build, need to explicitly add build path - # to LD_LIBRARY_PATH so we can load libsagittarius.so as required to - # build extensions - export ${platformLdLibraryPath}="$(pwd)/build" - ''; - nativeBuildInputs = [ pkg-config cmake ]; + # since we lack rpath during build, need to explicitly add build path + # to LD_LIBRARY_PATH so we can load libsagittarius.so as required to + # build extensions + export ${platformLdLibraryPath}="$(pwd)/build" + ''; + nativeBuildInputs = [ + pkg-config + cmake + ]; - buildInputs = [ libffi boehmgc openssl zlib ] ++ lib.optional odbcSupport libiodbc; + buildInputs = [ + libffi + boehmgc + openssl + zlib + ] ++ lib.optional odbcSupport libiodbc; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-Wno-error=int-conversion" - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ - # error: '__builtin_ia32_aeskeygenassist128' needs target feature aes - "-maes" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-Wno-error=int-conversion" + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + # error: '__builtin_ia32_aeskeygenassist128' needs target feature aes + "-maes" + ] + ); meta = with lib; { description = "R6RS/R7RS Scheme system"; diff --git a/pkgs/by-name/sa/sagoin/package.nix b/pkgs/by-name/sa/sagoin/package.nix index 7764781dc01bd4..4d2740f071dff9 100644 --- a/pkgs/by-name/sa/sagoin/package.nix +++ b/pkgs/by-name/sa/sagoin/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sa/sahel-fonts/package.nix b/pkgs/by-name/sa/sahel-fonts/package.nix index 7fc48704e798a3..30d09d2fa36fc7 100644 --- a/pkgs/by-name/sa/sahel-fonts/package.nix +++ b/pkgs/by-name/sa/sahel-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "sahel-fonts"; diff --git a/pkgs/by-name/sa/sailsd/package.nix b/pkgs/by-name/sa/sailsd/package.nix index 50eb8e61ca3278..62e2da16fe4c29 100644 --- a/pkgs/by-name/sa/sailsd/package.nix +++ b/pkgs/by-name/sa/sailsd/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, jansson }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + jansson, +}: let libsailing = fetchFromGitHub { @@ -19,7 +25,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ jansson libsailing ]; + buildInputs = [ + jansson + libsailing + ]; INSTALL_PATH = "$(out)"; diff --git a/pkgs/by-name/sa/sakura/package.nix b/pkgs/by-name/sa/sakura/package.nix index f9c1b3f31a55ed..4b2687dd98a8de 100644 --- a/pkgs/by-name/sa/sakura/package.nix +++ b/pkgs/by-name/sa/sakura/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, glib -, gtk3 -, gettext -, pango -, makeWrapper -, pcre2 -, perl -, pkg-config -, vte -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + glib, + gtk3, + gettext, + pango, + makeWrapper, + pcre2, + perl, + pkg-config, + vte, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { @@ -66,8 +67,11 @@ stdenv.mkDerivation (finalAttrs: { options. No more no less. ''; license = lib.licenses.gpl2Only; - maintainers = with lib.maintainers; [ astsmtl codyopel ]; + maintainers = with lib.maintainers; [ + astsmtl + codyopel + ]; platforms = lib.platforms.linux; mainProgram = "sakura"; - }; + }; }) diff --git a/pkgs/by-name/sa/saldl/package.nix b/pkgs/by-name/sa/saldl/package.nix index 7f1551cd85b8d0..530cba04b078cc 100644 --- a/pkgs/by-name/sa/saldl/package.nix +++ b/pkgs/by-name/sa/saldl/package.nix @@ -1,16 +1,18 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config -, wafHook -, python3 -, asciidoc -, docbook_xml_dtd_45 -, docbook_xsl -, libxml2 -, libxslt -, curl -, libevent -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + wafHook, + python3, + asciidoc, + docbook_xml_dtd_45, + docbook_xsl, + libxml2, + libxslt, + curl, + libevent, + fetchpatch, }: stdenv.mkDerivation rec { @@ -43,11 +45,20 @@ stdenv.mkDerivation rec { libxslt ]; - buildInputs = [ curl libevent ]; + buildInputs = [ + curl + libevent + ]; - wafConfigureFlags = [ "--saldl-version ${version}" "--no-werror" ]; + wafConfigureFlags = [ + "--saldl-version ${version}" + "--no-werror" + ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; meta = with lib; { description = "CLI downloader optimized for speed and early preview"; diff --git a/pkgs/by-name/sa/saleae-logic-2/package.nix b/pkgs/by-name/sa/saleae-logic-2/package.nix index 69e972afa7b723..6a447c5876608d 100644 --- a/pkgs/by-name/sa/saleae-logic-2/package.nix +++ b/pkgs/by-name/sa/saleae-logic-2/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, makeDesktopItem, appimageTools }: +{ + lib, + fetchurl, + makeDesktopItem, + appimageTools, +}: let pname = "saleae-logic-2"; version = "2.4.13"; @@ -23,50 +28,54 @@ appimageTools.wrapType2 { let appimageContents = appimageTools.extractType2 { inherit pname version src; }; in - '' - mkdir -p $out/etc/udev/rules.d - cp ${appimageContents}/resources/linux-x64/99-SaleaeLogic.rules $out/etc/udev/rules.d/ - mkdir -p $out/share/pixmaps - ln -s ${desktopItem}/share/applications $out/share/ - cp ${appimageContents}/usr/share/icons/hicolor/256x256/apps/Logic.png $out/share/pixmaps/Logic.png - ''; + '' + mkdir -p $out/etc/udev/rules.d + cp ${appimageContents}/resources/linux-x64/99-SaleaeLogic.rules $out/etc/udev/rules.d/ + mkdir -p $out/share/pixmaps + ln -s ${desktopItem}/share/applications $out/share/ + cp ${appimageContents}/usr/share/icons/hicolor/256x256/apps/Logic.png $out/share/pixmaps/Logic.png + ''; - extraPkgs = pkgs: with pkgs; [ - wget - unzip - glib - xorg.libX11 - xorg.libxcb - xorg.libXcomposite - xorg.libXcursor - xorg.libXdamage - xorg.libXext - xorg.libXfixes - xorg.libXi - xorg.libXrender - xorg.libXtst - nss - nspr - dbus - gdk-pixbuf - gtk3 - pango - atk - cairo - expat - xorg.libXrandr - xorg.libXScrnSaver - alsa-lib - at-spi2-core - cups - libxcrypt-legacy - ]; + extraPkgs = + pkgs: with pkgs; [ + wget + unzip + glib + xorg.libX11 + xorg.libxcb + xorg.libXcomposite + xorg.libXcursor + xorg.libXdamage + xorg.libXext + xorg.libXfixes + xorg.libXi + xorg.libXrender + xorg.libXtst + nss + nspr + dbus + gdk-pixbuf + gtk3 + pango + atk + cairo + expat + xorg.libXrandr + xorg.libXScrnSaver + alsa-lib + at-spi2-core + cups + libxcrypt-legacy + ]; meta = with lib; { homepage = "https://www.saleae.com/"; description = "Software for Saleae logic analyzers"; license = licenses.unfree; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ j-hui newam ]; + maintainers = with maintainers; [ + j-hui + newam + ]; }; } diff --git a/pkgs/by-name/sa/salmon/package.nix b/pkgs/by-name/sa/salmon/package.nix index bfc12deedd6b9d..4e46c4e2dc0569 100644 --- a/pkgs/by-name/sa/salmon/package.nix +++ b/pkgs/by-name/sa/salmon/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, boost -, bzip2 -, cereal_1_3_2 -, cmake -, curl -, fetchFromGitHub -, jemalloc -, libgff -, libiconv -, libstaden-read -, pkg-config -, tbb_2021_11 -, xz -, zlib +{ + lib, + stdenv, + boost, + bzip2, + cereal_1_3_2, + cmake, + curl, + fetchFromGitHub, + jemalloc, + libgff, + libiconv, + libstaden-read, + pkg-config, + tbb_2021_11, + xz, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -42,7 +43,10 @@ stdenv.mkDerivation (finalAttrs: { postPatch = "patchShebangs ."; buildInputs = [ - (boost.override { enableShared = false; enabledStatic = true; }) + (boost.override { + enableShared = false; + enabledStatic = true; + }) bzip2 cereal_1_3_2 curl @@ -54,13 +58,15 @@ stdenv.mkDerivation (finalAttrs: { zlib ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; strictDeps = true; meta = { - description = - "Tool for quantifying the expression of transcripts using RNA-seq data"; + description = "Tool for quantifying the expression of transcripts using RNA-seq data"; mainProgram = "salmon"; longDescription = '' Salmon is a tool for quantifying the expression of transcripts @@ -74,8 +80,7 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://combine-lab.github.io/salmon"; downloadPage = "https://github.com/COMBINE-lab/salmon/releases"; - changelog = "https://github.com/COMBINE-lab/salmon/releases/tag/" + - "v${finalAttrs.version}"; + changelog = "https://github.com/COMBINE-lab/salmon/releases/tag/" + "v${finalAttrs.version}"; license = lib.licenses.gpl3Only; platforms = lib.platforms.all; maintainers = [ lib.maintainers.kupac ]; diff --git a/pkgs/by-name/sa/salt/package.nix b/pkgs/by-name/sa/salt/package.nix index de836d4e82271d..206d43ed228424 100644 --- a/pkgs/by-name/sa/salt/package.nix +++ b/pkgs/by-name/sa/salt/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, python3 -, fetchPypi -, openssl +{ + lib, + stdenv, + python3, + fetchPypi, + openssl, # Many Salt modules require various Python modules to be installed, # passing them in this array enables Salt to find them. -, extraInputs ? [] + extraInputs ? [ ], }: python3.pkgs.buildPythonApplication rec { @@ -37,21 +38,24 @@ python3.pkgs.buildPythonApplication rec { --replace 'pyzmq==25.0.2 ; sys_platform == "win32"' "" ''; - propagatedBuildInputs = with python3.pkgs; [ - distro - jinja2 - jmespath - looseversion - markupsafe - msgpack - packaging - psutil - pycryptodomex - pyyaml - pyzmq - requests - tornado - ] ++ extraInputs; + propagatedBuildInputs = + with python3.pkgs; + [ + distro + jinja2 + jmespath + looseversion + markupsafe + msgpack + packaging + psutil + pycryptodomex + pyyaml + pyzmq + requests + tornado + ] + ++ extraInputs; # Don't use fixed dependencies on Darwin USE_STATIC_REQUIREMENTS = "0"; diff --git a/pkgs/by-name/sa/salut/package.nix b/pkgs/by-name/sa/salut/package.nix index 5e61e524e4fa7d..82d5d5960de01e 100644 --- a/pkgs/by-name/sa/salut/package.nix +++ b/pkgs/by-name/sa/salut/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitLab -, pkg-config -, fontconfig -, libxkbcommon -, wayland +{ + lib, + rustPlatform, + fetchFromGitLab, + pkg-config, + fontconfig, + libxkbcommon, + wayland, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sa/sam-ba/package.nix b/pkgs/by-name/sa/sam-ba/package.nix index 6a383cd4fc4e16..26122689315c06 100644 --- a/pkgs/by-name/sa/sam-ba/package.nix +++ b/pkgs/by-name/sa/sam-ba/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchzip, glib, zlib, libglvnd, python3, autoPatchelfHook }: +{ + lib, + stdenv, + fetchzip, + glib, + zlib, + libglvnd, + python3, + autoPatchelfHook, +}: stdenv.mkDerivation rec { version = "3.5"; @@ -14,7 +23,7 @@ stdenv.mkDerivation rec { libglvnd zlib - (python3.withPackages (ps: [ps.pyserial])) + (python3.withPackages (ps: [ ps.pyserial ])) ]; nativeBuildInputs = [ autoPatchelfHook ]; diff --git a/pkgs/by-name/sa/sambamba/package.nix b/pkgs/by-name/sa/sambamba/package.nix index e62a5bb14aae4f..9cf37daf1606ec 100644 --- a/pkgs/by-name/sa/sambamba/package.nix +++ b/pkgs/by-name/sa/sambamba/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 -, which -, ldc -, zlib -, lz4 +{ + lib, + stdenv, + fetchFromGitHub, + python3, + which, + ldc, + zlib, + lz4, }: stdenv.mkDerivation rec { @@ -20,8 +21,15 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ which python3 ldc ]; - buildInputs = [ zlib lz4 ]; + nativeBuildInputs = [ + which + python3 + ldc + ]; + buildInputs = [ + zlib + lz4 + ]; buildFlags = [ "CC=${stdenv.cc.targetPrefix}cc" diff --git a/pkgs/by-name/sa/samblaster/package.nix b/pkgs/by-name/sa/samblaster/package.nix index f16d0e42d8ef51..fba9560557c30a 100644 --- a/pkgs/by-name/sa/samblaster/package.nix +++ b/pkgs/by-name/sa/samblaster/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "samblaster"; diff --git a/pkgs/by-name/sa/samdump2/package.nix b/pkgs/by-name/sa/samdump2/package.nix index a1a045af7664fe..0489423d9fefdf 100644 --- a/pkgs/by-name/sa/samdump2/package.nix +++ b/pkgs/by-name/sa/samdump2/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, openssl -, pkg-config -, which +{ + lib, + stdenv, + fetchurl, + fetchpatch, + openssl, + pkg-config, + which, }: stdenv.mkDerivation (finalAttrs: { @@ -16,7 +17,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-YCZZrzDFZXUPoBZQ4KIj0mNVtd+Y8vvDDjpsWT7U5SY="; }; - nativeBuildInputs = [ pkg-config which ]; + nativeBuildInputs = [ + pkg-config + which + ]; buildInputs = [ openssl ]; @@ -63,7 +67,7 @@ stdenv.mkDerivation (finalAttrs: { description = "Dump password hashes from a Windows NT/2k/XP installation"; mainProgram = "samdump2"; homepage = "https://sourceforge.net/projects/ophcrack/files/samdump2"; - license = licenses.gpl2Plus; + license = licenses.gpl2Plus; maintainers = with maintainers; [ d3vil0p3r ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/sa/sameboy/package.nix b/pkgs/by-name/sa/sameboy/package.nix index d1e7c13c6694cd..a2eb80b3c075c9 100644 --- a/pkgs/by-name/sa/sameboy/package.nix +++ b/pkgs/by-name/sa/sameboy/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, gtk3, rgbds, SDL2, wrapGAppsHook3, glib }: +{ + lib, + stdenv, + fetchFromGitHub, + gtk3, + rgbds, + SDL2, + wrapGAppsHook3, + glib, +}: stdenv.mkDerivation rec { pname = "sameboy"; @@ -13,7 +22,11 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; # glib and wrapGAppsHook3 are needed to make the Open ROM menu work. - nativeBuildInputs = [ rgbds glib wrapGAppsHook3 ]; + nativeBuildInputs = [ + rgbds + glib + wrapGAppsHook3 + ]; buildInputs = [ SDL2 ]; makeFlags = [ diff --git a/pkgs/by-name/sa/samim-fonts/package.nix b/pkgs/by-name/sa/samim-fonts/package.nix index 2f36075bad93e2..b5df4039595fb7 100644 --- a/pkgs/by-name/sa/samim-fonts/package.nix +++ b/pkgs/by-name/sa/samim-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "samim-fonts"; diff --git a/pkgs/by-name/sa/sammler/package.nix b/pkgs/by-name/sa/sammler/package.nix index 7a7990aee1f946..7a1c9247a85a8e 100644 --- a/pkgs/by-name/sa/sammler/package.nix +++ b/pkgs/by-name/sa/sammler/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/sa/sampler/package.nix b/pkgs/by-name/sa/sampler/package.nix index 7ee3d4573d9aac..ec2e35728b1c3f 100644 --- a/pkgs/by-name/sa/sampler/package.nix +++ b/pkgs/by-name/sa/sampler/package.nix @@ -1,4 +1,12 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch, darwin, alsa-lib, stdenv }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + darwin, + alsa-lib, + stdenv, +}: buildGoModule rec { pname = "sampler"; @@ -25,10 +33,11 @@ buildGoModule rec { subPackages = [ "." ]; - buildInputs = lib.optional stdenv.hostPlatform.isLinux alsa-lib + buildInputs = + lib.optional stdenv.hostPlatform.isLinux alsa-lib ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.OpenAL - ]; + darwin.apple_sdk.frameworks.OpenAL + ]; meta = with lib; { description = "Tool for shell commands execution, visualization and alerting"; diff --git a/pkgs/by-name/sa/samplicator/package.nix b/pkgs/by-name/sa/samplicator/package.nix index 80349b1704841f..92d0c1cd362aaf 100644 --- a/pkgs/by-name/sa/samplicator/package.nix +++ b/pkgs/by-name/sa/samplicator/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "samplicator"; diff --git a/pkgs/by-name/sa/samply/package.nix b/pkgs/by-name/sa/samply/package.nix index 98dfbc3aca1e58..20c15023db3cfd 100644 --- a/pkgs/by-name/sa/samply/package.nix +++ b/pkgs/by-name/sa/samply/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchCrate -, jq -, moreutils -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + jq, + moreutils, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -50,7 +51,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "samply"; homepage = "https://github.com/mstange/samply"; changelog = "https://github.com/mstange/samply/releases/tag/samply-v${version}"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/sa/sampradaya/package.nix b/pkgs/by-name/sa/sampradaya/package.nix index 8c0545d2c7fe51..6149f13578a02f 100644 --- a/pkgs/by-name/sa/sampradaya/package.nix +++ b/pkgs/by-name/sa/sampradaya/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "sampradaya"; diff --git a/pkgs/by-name/sa/samsung-unified-linux-driver_1_00_36/module.nix b/pkgs/by-name/sa/samsung-unified-linux-driver_1_00_36/module.nix index 1b9ea38a3006cf..63dfb21a31a777 100644 --- a/pkgs/by-name/sa/samsung-unified-linux-driver_1_00_36/module.nix +++ b/pkgs/by-name/sa/samsung-unified-linux-driver_1_00_36/module.nix @@ -14,30 +14,33 @@ # and simple-scan. errors indicate an I/O error. scanning works # again after turning the device off and on. atm i have no idea how # to fix this and no time to do more about it. -{config, pkgs, lib ? pkgs.lib, ...}: +{ + config, + pkgs, + lib ? pkgs.lib, + ... +}: let cfg = config.services.samsung-unified-linux-driver_1_00_36; pkg = pkgs.samsung-unified-linux-driver_1_00_36; -in { +in +{ options = { services.samsung-unified-linux-driver_1_00_36 = { enable = lib.mkEnableOption "samsung-unified-linux-driver_1_00_36"; }; }; config = lib.mkIf cfg.enable { - services.printing.drivers = [pkg]; - hardware.sane.extraBackends = [pkg]; + services.printing.drivers = [ pkg ]; + hardware.sane.extraBackends = [ pkg ]; environment.etc = { - "samsung/scanner/share/oem.conf".source - = "${pkg}/etc/samsung/scanner/share/oem.conf"; - "smfp-common/scanner/share/libsane-smfp.cfg".source - = "${pkg}/etc/smfp-common/scanner/share/libsane-smfp.cfg"; - "smfp-common/scanner/share/pagesize.xml".source - = "${pkg}/etc/smfp-common/scanner/share/pagesize.xml"; - "sane.d/smfp.conf".source - = "${pkg}/etc/sane.d/smfp.conf"; - "sane.d/dll.d/smfp-scanner.conf".source - = "${pkg}/etc/sane.d/dll.d/smfp-scanner.conf"; + "samsung/scanner/share/oem.conf".source = "${pkg}/etc/samsung/scanner/share/oem.conf"; + "smfp-common/scanner/share/libsane-smfp.cfg".source = + "${pkg}/etc/smfp-common/scanner/share/libsane-smfp.cfg"; + "smfp-common/scanner/share/pagesize.xml".source = + "${pkg}/etc/smfp-common/scanner/share/pagesize.xml"; + "sane.d/smfp.conf".source = "${pkg}/etc/sane.d/smfp.conf"; + "sane.d/dll.d/smfp-scanner.conf".source = "${pkg}/etc/sane.d/dll.d/smfp-scanner.conf"; }; }; } diff --git a/pkgs/by-name/sa/samsung-unified-linux-driver_1_00_36/package.nix b/pkgs/by-name/sa/samsung-unified-linux-driver_1_00_36/package.nix index 0a09bdb272e659..1e9b34579ba661 100644 --- a/pkgs/by-name/sa/samsung-unified-linux-driver_1_00_36/package.nix +++ b/pkgs/by-name/sa/samsung-unified-linux-driver_1_00_36/package.nix @@ -1,12 +1,19 @@ -{ lib, stdenv, fetchurl, cups, libusb-compat-0_1, libxml2, perl }: +{ + lib, + stdenv, + fetchurl, + cups, + libusb-compat-0_1, + libxml2, + perl, +}: let - arch = if stdenv.system == "x86_64-linux" - then "x86_64" - else "i386"; + arch = if stdenv.system == "x86_64-linux" then "x86_64" else "i386"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "samsung-unified-linux-driver"; version = "1.00.36"; diff --git a/pkgs/by-name/sa/samurai/package.nix b/pkgs/by-name/sa/samurai/package.nix index 15a20cd343f144..7ecb57adcbb372 100644 --- a/pkgs/by-name/sa/samurai/package.nix +++ b/pkgs/by-name/sa/samurai/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, }: stdenv.mkDerivation rec { @@ -15,7 +16,10 @@ stdenv.mkDerivation rec { hash = "sha256-RPY3MFlnSDBZ5LOkdWnMiR/CZIBdqIFo9uLU+SAKPBI="; }; - makeFlags = [ "DESTDIR=" "PREFIX=${placeholder "out"}" ]; + makeFlags = [ + "DESTDIR=" + "PREFIX=${placeholder "out"}" + ]; patches = [ # NULL pointer dereference in writefile() in util.c; remove this at the next @@ -50,10 +54,12 @@ stdenv.mkDerivation rec { respectively. ''; homepage = "https://github.com/michaelforney/samurai"; - license = with licenses; [ mit asl20 ]; # see LICENSE + license = with licenses; [ + mit + asl20 + ]; # see LICENSE maintainers = with maintainers; [ dtzWill ]; mainProgram = "samu"; platforms = platforms.all; }; } - diff --git a/pkgs/by-name/sa/sanctity/package.nix b/pkgs/by-name/sa/sanctity/package.nix index 05e6a5ed46d6a5..531181ed266a97 100644 --- a/pkgs/by-name/sa/sanctity/package.nix +++ b/pkgs/by-name/sa/sanctity/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitea }: +{ + lib, + rustPlatform, + fetchFromGitea, +}: rustPlatform.buildRustPackage rec { pname = "sanctity"; diff --git a/pkgs/by-name/sa/sandbar/package.nix b/pkgs/by-name/sa/sandbar/package.nix index 8c754289aa0019..b5918209a6e805 100644 --- a/pkgs/by-name/sa/sandbar/package.nix +++ b/pkgs/by-name/sa/sandbar/package.nix @@ -7,7 +7,7 @@ pkg-config, wayland-protocols, wayland-scanner, - wayland + wayland, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sa/sane-airscan/package.nix b/pkgs/by-name/sa/sane-airscan/package.nix index b4ac219a17e4a7..c7d02167820362 100644 --- a/pkgs/by-name/sa/sane-airscan/package.nix +++ b/pkgs/by-name/sa/sane-airscan/package.nix @@ -1,11 +1,36 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, pkg-config, avahi, libjpeg, libpng, libtiff -, libxml2, gnutls, sane-backends }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + avahi, + libjpeg, + libpng, + libtiff, + libxml2, + gnutls, + sane-backends, +}: stdenv.mkDerivation rec { pname = "sane-airscan"; version = "0.99.30"; - nativeBuildInputs = [ meson ninja pkg-config ]; - buildInputs = [ avahi gnutls libjpeg libpng libxml2 libtiff sane-backends ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; + buildInputs = [ + avahi + gnutls + libjpeg + libpng + libxml2 + libtiff + sane-backends + ]; src = fetchFromGitHub { owner = "alexpevzner"; diff --git a/pkgs/by-name/sa/sanoid/package.nix b/pkgs/by-name/sa/sanoid/package.nix index aa960b7227266e..6a01474c0f65db 100644 --- a/pkgs/by-name/sa/sanoid/package.nix +++ b/pkgs/by-name/sa/sanoid/package.nix @@ -1,5 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, nixosTests, makeWrapper, zfs -, perlPackages, procps, which, openssh, mbuffer, pv, lzop, gzip, pigz }: +{ + lib, + stdenv, + fetchFromGitHub, + nixosTests, + makeWrapper, + zfs, + perlPackages, + procps, + which, + openssh, + mbuffer, + pv, + lzop, + gzip, + pigz, +}: stdenv.mkDerivation rec { pname = "sanoid"; @@ -13,7 +28,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = with perlPackages; [ perl ConfigIniFiles CaptureTiny ]; + buildInputs = with perlPackages; [ + perl + ConfigIniFiles + CaptureTiny + ]; passthru.tests = nixosTests.sanoid; @@ -31,17 +50,41 @@ stdenv.mkDerivation rec { # incompatibilities with the ZFS kernel module. wrapProgram "$out/bin/sanoid" \ --prefix PERL5LIB : "$PERL5LIB" \ - --prefix PATH : "${lib.makeBinPath [ procps "/run/booted-system/sw" zfs ]}" + --prefix PATH : "${ + lib.makeBinPath [ + procps + "/run/booted-system/sw" + zfs + ] + }" install -m755 syncoid "$out/bin/syncoid" wrapProgram "$out/bin/syncoid" \ --prefix PERL5LIB : "$PERL5LIB" \ - --prefix PATH : "${lib.makeBinPath [ openssh procps which pv mbuffer lzop gzip pigz "/run/booted-system/sw" zfs ]}" + --prefix PATH : "${ + lib.makeBinPath [ + openssh + procps + which + pv + mbuffer + lzop + gzip + pigz + "/run/booted-system/sw" + zfs + ] + }" install -m755 findoid "$out/bin/findoid" wrapProgram "$out/bin/findoid" \ --prefix PERL5LIB : "$PERL5LIB" \ - --prefix PATH : "${lib.makeBinPath [ "/run/booted-system/sw" zfs ]}" + --prefix PATH : "${ + lib.makeBinPath [ + "/run/booted-system/sw" + zfs + ] + }" runHook postInstall ''; @@ -50,7 +93,10 @@ stdenv.mkDerivation rec { description = "Policy-driven snapshot management tool for ZFS filesystems"; homepage = "https://github.com/jimsalterjrs/sanoid"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ lopsided98 Frostman ]; + maintainers = with maintainers; [ + lopsided98 + Frostman + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/sa/sarabun-font/package.nix b/pkgs/by-name/sa/sarabun-font/package.nix index 3e4fa018e71252..ada14957a01954 100644 --- a/pkgs/by-name/sa/sarabun-font/package.nix +++ b/pkgs/by-name/sa/sarabun-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "sarabun"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "jcSQ72WK0GucZPgG7IQKrKzCOEbGgbQVl21RIKSF6A0="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; buildPhase = '' mkdir -p $doc/${pname} $out/share/fonts/truetype diff --git a/pkgs/by-name/sa/sassc/package.nix b/pkgs/by-name/sa/sassc/package.nix index 3501f826895eb0..eabf0ef0c347f4 100644 --- a/pkgs/by-name/sa/sassc/package.nix +++ b/pkgs/by-name/sa/sassc/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libsass }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libsass, +}: stdenv.mkDerivation rec { pname = "sassc"; @@ -26,7 +32,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/sass/sassc/"; license = licenses.mit; mainProgram = "sassc"; - maintainers = with maintainers; [ codyopel pjones ]; + maintainers = with maintainers; [ + codyopel + pjones + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/sa/sasutils/package.nix b/pkgs/by-name/sa/sasutils/package.nix index 3ca570c8e853c5..540d573bcb230e 100644 --- a/pkgs/by-name/sa/sasutils/package.nix +++ b/pkgs/by-name/sa/sasutils/package.nix @@ -1,4 +1,10 @@ -{ lib, python3Packages, fetchFromGitHub, installShellFiles, sg3_utils }: +{ + lib, + python3Packages, + fetchFromGitHub, + installShellFiles, + sg3_utils, +}: python3Packages.buildPythonApplication rec { pname = "sasutils"; diff --git a/pkgs/by-name/sa/satty/package.nix b/pkgs/by-name/sa/satty/package.nix index 54c434e975c3c6..b7dde12f925c2a 100644 --- a/pkgs/by-name/sa/satty/package.nix +++ b/pkgs/by-name/sa/satty/package.nix @@ -1,16 +1,17 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, wrapGAppsHook4 -, gdk-pixbuf -, glib -, gtk4 -, libadwaita -, libepoxy -, libGL -, copyDesktopItems -, installShellFiles +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + wrapGAppsHook4, + gdk-pixbuf, + glib, + gtk4, + libadwaita, + libepoxy, + libGL, + copyDesktopItems, + installShellFiles, }: rustPlatform.buildRustPackage rec { @@ -58,7 +59,10 @@ rustPlatform.buildRustPackage rec { description = "Screenshot annotation tool inspired by Swappy and Flameshot"; homepage = "https://github.com/gabm/Satty"; license = licenses.mpl20; - maintainers = with maintainers; [ pinpox donovanglover ]; + maintainers = with maintainers; [ + pinpox + donovanglover + ]; mainProgram = "satty"; platforms = lib.platforms.linux; }; diff --git a/pkgs/by-name/sa/savepagenow/package.nix b/pkgs/by-name/sa/savepagenow/package.nix index 9e723d53f54f0a..3e1dfc256bc91e 100644 --- a/pkgs/by-name/sa/savepagenow/package.nix +++ b/pkgs/by-name/sa/savepagenow/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "savepagenow"; @@ -11,7 +15,10 @@ python3Packages.buildPythonApplication rec { sha256 = "1lz6rc47cds9rb35jdf8n13gr61wdkh5jqzx4skikm1yrqkwjyhm"; }; - propagatedBuildInputs = with python3Packages; [ click requests ]; + propagatedBuildInputs = with python3Packages; [ + click + requests + ]; # requires network access doCheck = false; diff --git a/pkgs/by-name/sa/sawfish/package.nix b/pkgs/by-name/sa/sawfish/package.nix index c5bd29d2589fef..8a0ac60f5541c2 100644 --- a/pkgs/by-name/sa/sawfish/package.nix +++ b/pkgs/by-name/sa/sawfish/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, gdk-pixbuf-xlib -, gettext -, gtk2-x11 -, libICE -, libSM -, libxcrypt -, libXinerama -, libXrandr -, libXtst -, librep -, makeWrapper -, pango -, pkg-config -, rep-gtk -, texinfo -, which +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + gdk-pixbuf-xlib, + gettext, + gtk2-x11, + libICE, + libSM, + libxcrypt, + libXinerama, + libXrandr, + libXtst, + librep, + makeWrapper, + pango, + pkg-config, + rep-gtk, + texinfo, + which, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sa/sawjap/package.nix b/pkgs/by-name/sa/sawjap/package.nix index bc48b0342ab2b4..db15be31108770 100644 --- a/pkgs/by-name/sa/sawjap/package.nix +++ b/pkgs/by-name/sa/sawjap/package.nix @@ -1,6 +1,8 @@ { stdenv, ocamlPackages }: -let inherit (ocamlPackages) ocaml findlib sawja; in +let + inherit (ocamlPackages) ocaml findlib sawja; +in stdenv.mkDerivation { @@ -12,7 +14,10 @@ stdenv.mkDerivation { strictDeps = true; - nativeBuildInputs = [ ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; buildInputs = [ sawja ]; buildPhase = '' diff --git a/pkgs/by-name/sb/sbagen/package.nix b/pkgs/by-name/sb/sbagen/package.nix index 4ddfa6f9cf2865..368ff98ce364e2 100644 --- a/pkgs/by-name/sb/sbagen/package.nix +++ b/pkgs/by-name/sb/sbagen/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "sbagen"; diff --git a/pkgs/by-name/sb/sbc/package.nix b/pkgs/by-name/sb/sbc/package.nix index 7cdd3072c56c2b..f7a45d562599d3 100644 --- a/pkgs/by-name/sb/sbc/package.nix +++ b/pkgs/by-name/sb/sbc/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libsndfile }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libsndfile, +}: stdenv.mkDerivation rec { pname = "sbc"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-jxI2jh279V4UU2UgRzz7M4yEs5KTnMm2Qpg2D9SgeZI="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ pkg-config ]; buildInputs = [ libsndfile ]; diff --git a/pkgs/by-name/sb/sblim-sfcc/package.nix b/pkgs/by-name/sb/sblim-sfcc/package.nix index 351eb5c154794c..fb73c7c0d625c7 100644 --- a/pkgs/by-name/sb/sblim-sfcc/package.nix +++ b/pkgs/by-name/sb/sblim-sfcc/package.nix @@ -1,13 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, curl }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + curl, +}: stdenv.mkDerivation rec { pname = "sblim-sfcc"; version = "2.2.9"; # this is technically 2.2.9-preview src = fetchFromGitHub { - owner = "kkaempf"; - repo = "sblim-sfcc"; - rev = "514a76af2020fd6dc6fc380df76cbe27786a76a2"; + owner = "kkaempf"; + repo = "sblim-sfcc"; + rev = "514a76af2020fd6dc6fc380df76cbe27786a76a2"; sha256 = "06c1mskl9ixbf26v88w0lvn6v2xd6n5f0jd5mckqrn9j4vmh70hs"; }; @@ -19,9 +25,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Small Footprint CIM Client Library"; - homepage = "https://sourceforge.net/projects/sblim/"; - license = licenses.cpl10; + homepage = "https://sourceforge.net/projects/sblim/"; + license = licenses.cpl10; maintainers = with maintainers; [ deepfire ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/sb/sbom-utility/package.nix b/pkgs/by-name/sb/sbom-utility/package.nix index 7e745b811b900b..d50bc6100de92f 100644 --- a/pkgs/by-name/sb/sbom-utility/package.nix +++ b/pkgs/by-name/sb/sbom-utility/package.nix @@ -1,7 +1,7 @@ { - lib -, buildGoModule -, fetchFromGitHub + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/sb/sbs/package.nix b/pkgs/by-name/sb/sbs/package.nix index cddf508ead0215..55baf84c374917 100644 --- a/pkgs/by-name/sb/sbs/package.nix +++ b/pkgs/by-name/sb/sbs/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libX11, imlib2, libXinerama, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + imlib2, + libXinerama, + pkg-config, +}: stdenv.mkDerivation rec { pname = "sbs"; @@ -13,7 +21,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ imlib2 libX11 libXinerama ]; + buildInputs = [ + imlib2 + libX11 + libXinerama + ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/sb/sbsigntool/package.nix b/pkgs/by-name/sb/sbsigntool/package.nix index 4422dd16b474d7..0064476b70364e 100644 --- a/pkgs/by-name/sb/sbsigntool/package.nix +++ b/pkgs/by-name/sb/sbsigntool/package.nix @@ -1,6 +1,15 @@ -{ lib, stdenv -, fetchgit, autoconf, automake, pkg-config, help2man -, openssl, libuuid, gnu-efi, libbfd +{ + lib, + stdenv, + fetchgit, + autoconf, + automake, + pkg-config, + help2man, + openssl, + libuuid, + gnu-efi, + libbfd, }: stdenv.mkDerivation rec { @@ -17,8 +26,18 @@ stdenv.mkDerivation rec { prePatch = "patchShebangs ."; - nativeBuildInputs = [ autoconf automake pkg-config help2man ]; - buildInputs = [ openssl libuuid libbfd gnu-efi ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + help2man + ]; + buildInputs = [ + openssl + libuuid + libbfd + gnu-efi + ]; configurePhase = '' substituteInPlace configure.ac --replace "@@NIX_GNUEFI@@" "${gnu-efi}" @@ -39,9 +58,15 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Tools for maintaining UEFI signature databases"; - homepage = "http://jk.ozlabs.org/docs/sbkeysync-maintaing-uefi-key-databases"; - maintainers = with maintainers; [ hmenke raitobezarius ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; # Broken on i686 - license = licenses.gpl3; + homepage = "http://jk.ozlabs.org/docs/sbkeysync-maintaing-uefi-key-databases"; + maintainers = with maintainers; [ + hmenke + raitobezarius + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; # Broken on i686 + license = licenses.gpl3; }; } diff --git a/pkgs/by-name/sb/sbt-extras/package.nix b/pkgs/by-name/sb/sbt-extras/package.nix index 385cfc5c087ae5..b9b38b50fbeea4 100644 --- a/pkgs/by-name/sb/sbt-extras/package.nix +++ b/pkgs/by-name/sb/sbt-extras/package.nix @@ -1,6 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, which, curl, makeWrapper, jdk, writeScript -, common-updater-scripts, cacert, git, nixfmt-classic, nix, jq, coreutils -, gnused }: +{ + lib, + stdenv, + fetchFromGitHub, + which, + curl, + makeWrapper, + jdk, + writeScript, + common-updater-scripts, + cacert, + git, + nixfmt-classic, + nix, + jq, + coreutils, + gnused, +}: stdenv.mkDerivation rec { pname = "sbt-extras"; @@ -27,7 +42,12 @@ stdenv.mkDerivation rec { install bin/sbt $out/bin - wrapProgram $out/bin/sbt --prefix PATH : ${lib.makeBinPath [ which curl ]} + wrapProgram $out/bin/sbt --prefix PATH : ${ + lib.makeBinPath [ + which + curl + ] + } runHook postInstall ''; @@ -68,11 +88,13 @@ stdenv.mkDerivation rec { ''; meta = { - description = - "A more featureful runner for sbt, the simple/scala/standard build tool"; + description = "A more featureful runner for sbt, the simple/scala/standard build tool"; homepage = "https://github.com/paulp/sbt-extras"; license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [ nequissimus puffnfresh ]; + maintainers = with lib.maintainers; [ + nequissimus + puffnfresh + ]; mainProgram = "sbt"; platforms = lib.platforms.unix; }; diff --git a/pkgs/by-name/sc/sc68/package.nix b/pkgs/by-name/sc/sc68/package.nix index a779576d05d9c3..7a5f7e781ed14a 100644 --- a/pkgs/by-name/sc/sc68/package.nix +++ b/pkgs/by-name/sc/sc68/package.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, fetchsvn -, pkg-config -, which -, autoconf -, automake -, libtool -, hexdump -, libao -, zlib -, curl +{ + lib, + stdenv, + fetchsvn, + pkg-config, + which, + autoconf, + automake, + libtool, + hexdump, + libao, + zlib, + curl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sc/sca2d/package.nix b/pkgs/by-name/sc/sca2d/package.nix index 314a840ba262a4..f2c04ab9f7526c 100644 --- a/pkgs/by-name/sc/sca2d/package.nix +++ b/pkgs/by-name/sc/sca2d/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitLab -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitLab, + fetchFromGitHub, }: let python = python3.override { @@ -36,7 +37,10 @@ python.pkgs.buildPythonApplication rec { hash = "sha256-P+7g57AH8H7q0hBE2I9w8A+bN5M6MPbc9gA0b889aoQ="; }; - propagatedBuildInputs = with python.pkgs; [ lark010 colorama ]; + propagatedBuildInputs = with python.pkgs; [ + lark010 + colorama + ]; pythonImportsCheck = [ "sca2d" ]; diff --git a/pkgs/by-name/sc/scala-update/package.nix b/pkgs/by-name/sc/scala-update/package.nix index d15292c4d32ea7..451447617cb732 100644 --- a/pkgs/by-name/sc/scala-update/package.nix +++ b/pkgs/by-name/sc/scala-update/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, coursier, buildGraalvmNativeImage }: +{ + lib, + stdenv, + coursier, + buildGraalvmNativeImage, +}: let baseName = "scala-update"; @@ -15,7 +20,8 @@ let outputHashAlgo = "sha256"; outputHash = "kNnFzzHn+rFq4taqRYjBYaDax0MHW+vIoSFVN3wxA8M="; }; -in buildGraalvmNativeImage { +in +buildGraalvmNativeImage { pname = baseName; inherit version; @@ -23,8 +29,11 @@ in buildGraalvmNativeImage { src = "${deps}/share/java/${baseName}_2.13-${version}.jar"; - extraNativeImageBuildArgs = - [ "--no-fallback" "--enable-url-protocols=https" "update.Main" ]; + extraNativeImageBuildArgs = [ + "--no-fallback" + "--enable-url-protocols=https" + "update.Main" + ]; buildPhase = '' runHook preBuild diff --git a/pkgs/by-name/sc/scalafmt/package.nix b/pkgs/by-name/sc/scalafmt/package.nix index 588274bcab895b..108b93e5cb62d9 100644 --- a/pkgs/by-name/sc/scalafmt/package.nix +++ b/pkgs/by-name/sc/scalafmt/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, jre, coursier, makeWrapper, setJavaClassPath }: +{ + lib, + stdenv, + jre, + coursier, + makeWrapper, + setJavaClassPath, +}: let baseName = "scalafmt"; @@ -19,7 +26,10 @@ stdenv.mkDerivation { pname = baseName; inherit version; - nativeBuildInputs = [ makeWrapper setJavaClassPath ]; + nativeBuildInputs = [ + makeWrapper + setJavaClassPath + ]; buildInputs = [ deps ]; dontUnpack = true; diff --git a/pkgs/by-name/sc/scalapack/package.nix b/pkgs/by-name/sc/scalapack/package.nix index 3efd66dff395de..69caf221c5a6fc 100644 --- a/pkgs/by-name/sc/scalapack/package.nix +++ b/pkgs/by-name/sc/scalapack/package.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake -, mpiCheckPhaseHook, mpi, blas, lapack -} : +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + mpiCheckPhaseHook, + mpi, + blas, + lapack, +}: assert blas.isILP64 == lapack.isILP64; @@ -20,11 +28,13 @@ stdenv.mkDerivation rec { __structuredAttrs = true; # upstream patch, remove with next release - patches = [ (fetchpatch { - name = "gcc-10"; - url = "https://github.com/Reference-ScaLAPACK/scalapack/commit/a0f76fc0c1c16646875b454b7d6f8d9d17726b5a.patch"; - sha256 = "0civn149ikghakic30bynqg1bal097hr7i12cm4kq3ssrhq073bp"; - })]; + patches = [ + (fetchpatch { + name = "gcc-10"; + url = "https://github.com/Reference-ScaLAPACK/scalapack/commit/a0f76fc0c1c16646875b454b7d6f8d9d17726b5a.patch"; + sha256 = "0civn149ikghakic30bynqg1bal097hr7i12cm4kq3ssrhq073bp"; + }) + ]; # Required to activate ILP64. # See https://github.com/Reference-ScaLAPACK/scalapack/pull/19 @@ -36,13 +46,21 @@ stdenv.mkDerivation rec { sed -i '/xssep/d;/xsgsep/d;/xssyevr/d' TESTING/CMakeLists.txt ''; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake ]; nativeCheckInputs = [ mpiCheckPhaseHook ]; - buildInputs = [ blas lapack ]; + buildInputs = [ + blas + lapack + ]; propagatedBuildInputs = [ mpi ]; - hardeningDisable = lib.optionals (stdenv.hostPlatform.isAarch64 && stdenv.hostPlatform.isDarwin) [ "stackprotector" ]; + hardeningDisable = lib.optionals (stdenv.hostPlatform.isAarch64 && stdenv.hostPlatform.isDarwin) [ + "stackprotector" + ]; # xslu and xsllt tests seem to time out on x86_64-darwin. # this line is left so those who force installation on x86_64-darwin can still build @@ -54,10 +72,12 @@ stdenv.mkDerivation rec { -DLAPACK_LIBRARIES="-llapack" -DBLAS_LIBRARIES="-lblas" -DCMAKE_Fortran_COMPILER=${lib.getDev mpi}/bin/mpif90 - -DCMAKE_C_FLAGS="${lib.concatStringsSep " " [ - "-Wno-implicit-function-declaration" - (lib.optionalString passthru.isILP64 "-DInt=long") - ]}" + -DCMAKE_C_FLAGS="${ + lib.concatStringsSep " " [ + "-Wno-implicit-function-declaration" + (lib.optionalString passthru.isILP64 "-DInt=long") + ] + }" ${lib.optionalString passthru.isILP64 ''-DCMAKE_Fortran_FLAGS="-fdefault-integer-8"''} ) ''; @@ -79,7 +99,11 @@ stdenv.mkDerivation rec { description = "Library of high-performance linear algebra routines for parallel distributed memory machines"; license = licenses.bsd3; platforms = platforms.unix; - maintainers = with maintainers; [ costrouc markuskowa gdinh ]; + maintainers = with maintainers; [ + costrouc + markuskowa + gdinh + ]; # xslu and xsllt tests fail on x86 darwin broken = stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64; }; diff --git a/pkgs/by-name/sc/scaleft/package.nix b/pkgs/by-name/sc/scaleft/package.nix index a184e048869260..3b80b518a65829 100644 --- a/pkgs/by-name/sc/scaleft/package.nix +++ b/pkgs/by-name/sc/scaleft/package.nix @@ -1,20 +1,31 @@ -{ lib, stdenv, fetchurl, rpmextract, patchelf, testers, scaleft }: +{ + lib, + stdenv, + fetchurl, + rpmextract, + patchelf, + testers, + scaleft, +}: stdenv.mkDerivation rec { pname = "scaleft"; version = "1.80.1"; - src = - fetchurl { - url = "https://dist.scaleft.com/repos/rpm/stable/centos/9/x86_64/1.80.1/scaleft-client-tools-${version}-1.x86_64.rpm"; - sha256 = "sha256-QrkqAgkplFF6Tp6FWKb2TJaqeOw8ec4zd9pymDP2IyY="; - }; + src = fetchurl { + url = "https://dist.scaleft.com/repos/rpm/stable/centos/9/x86_64/1.80.1/scaleft-client-tools-${version}-1.x86_64.rpm"; + sha256 = "sha256-QrkqAgkplFF6Tp6FWKb2TJaqeOw8ec4zd9pymDP2IyY="; + }; - nativeBuildInputs = [ patchelf rpmextract ]; + nativeBuildInputs = [ + patchelf + rpmextract + ]; - libPath = - lib.makeLibraryPath - [ stdenv.cc stdenv.cc.cc ]; + libPath = lib.makeLibraryPath [ + stdenv.cc + stdenv.cc.cc + ]; buildCommand = '' mkdir -p $out/bin/ diff --git a/pkgs/by-name/sc/scaleway-cli/package.nix b/pkgs/by-name/sc/scaleway-cli/package.nix index 4b7c7ec5dc995d..acf6a9fd26d342 100644 --- a/pkgs/by-name/sc/scaleway-cli/package.nix +++ b/pkgs/by-name/sc/scaleway-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "scaleway-cli"; @@ -56,6 +60,10 @@ buildGoModule rec { description = "Interact with Scaleway API from the command line"; homepage = "https://github.com/scaleway/scaleway-cli"; license = licenses.mit; - maintainers = with maintainers; [ nickhu techknowlogick kashw2 ]; + maintainers = with maintainers; [ + nickhu + techknowlogick + kashw2 + ]; }; } diff --git a/pkgs/by-name/sc/scalingo/package.nix b/pkgs/by-name/sc/scalingo/package.nix index 6f488735670aa8..8300ad167c3653 100644 --- a/pkgs/by-name/sc/scalingo/package.nix +++ b/pkgs/by-name/sc/scalingo/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "scalingo"; diff --git a/pkgs/by-name/sc/scalpel/package.nix b/pkgs/by-name/sc/scalpel/package.nix index 94246fff868269..e481d9e2224328 100644 --- a/pkgs/by-name/sc/scalpel/package.nix +++ b/pkgs/by-name/sc/scalpel/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, stdenv -, autoconf -, automake -, libtool -, tre +{ + lib, + fetchFromGitHub, + stdenv, + autoconf, + automake, + libtool, + tre, }: stdenv.mkDerivation (finalAttrs: { @@ -31,7 +32,8 @@ stdenv.mkDerivation (finalAttrs: { src/scalpel.h ''; - env.CXXFLAGS = "-std=c++14" + lib.optionalString stdenv.cc.isClang " -Wno-error=reserved-user-defined-literal"; + env.CXXFLAGS = + "-std=c++14" + lib.optionalString stdenv.cc.isClang " -Wno-error=reserved-user-defined-literal"; preConfigure = '' ./bootstrap diff --git a/pkgs/by-name/sc/scalr-cli/package.nix b/pkgs/by-name/sc/scalr-cli/package.nix index 364a5f0c981a96..0198f6c72e700c 100644 --- a/pkgs/by-name/sc/scalr-cli/package.nix +++ b/pkgs/by-name/sc/scalr-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -17,7 +18,8 @@ buildGoModule rec { vendorHash = "sha256-0p4f+KKD04IFAUQG8F3b+2sx9suYemt3wbgSNNOOIlk="; ldflags = [ - "-s" "-w" + "-s" + "-w" ]; preConfigure = '' diff --git a/pkgs/by-name/sc/scanbd/package.nix b/pkgs/by-name/sc/scanbd/package.nix index 3f2331a0de04d2..d04226c6b4a88d 100644 --- a/pkgs/by-name/sc/scanbd/package.nix +++ b/pkgs/by-name/sc/scanbd/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchurl, pkg-config -, dbus, libconfuse, libjpeg, sane-backends, systemd }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + dbus, + libconfuse, + libjpeg, + sane-backends, + systemd, +}: stdenv.mkDerivation rec { pname = "scanbd"; @@ -11,19 +20,27 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dbus libconfuse libjpeg sane-backends systemd ]; - - configureFlags = [ - "--disable-Werror" - "--enable-udev" - "--with-scanbdconfdir=/etc/scanbd" - "--with-systemdsystemunitdir=$out/lib/systemd/system" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - # AC_FUNC_MALLOC is broken on cross builds. - "ac_cv_func_malloc_0_nonnull=yes" - "ac_cv_func_realloc_0_nonnull=yes" + buildInputs = [ + dbus + libconfuse + libjpeg + sane-backends + systemd ]; + configureFlags = + [ + "--disable-Werror" + "--enable-udev" + "--with-scanbdconfdir=/etc/scanbd" + "--with-systemdsystemunitdir=$out/lib/systemd/system" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + # AC_FUNC_MALLOC is broken on cross builds. + "ac_cv_func_malloc_0_nonnull=yes" + "ac_cv_func_realloc_0_nonnull=yes" + ]; + enableParallelBuilding = true; installFlags = [ diff --git a/pkgs/by-name/sc/scanmem/package.nix b/pkgs/by-name/sc/scanmem/package.nix index 15d8f1c02f1ec9..42f665e2093a07 100644 --- a/pkgs/by-name/sc/scanmem/package.nix +++ b/pkgs/by-name/sc/scanmem/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, gobject-introspection -, intltool -, wrapGAppsHook3 -, procps -, python3 -, readline +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gobject-introspection, + intltool, + wrapGAppsHook3, + procps, + python3, + readline, }: stdenv.mkDerivation rec { @@ -15,15 +16,23 @@ stdenv.mkDerivation rec { version = "0.17"; src = fetchFromGitHub { - owner = "scanmem"; - repo = "scanmem"; - rev = "v${version}"; + owner = "scanmem"; + repo = "scanmem"; + rev = "v${version}"; sha256 = "17p8sh0rj8yqz36ria5bp48c8523zzw3y9g8sbm2jwq7sc27i7s9"; }; - nativeBuildInputs = [ autoreconfHook gobject-introspection intltool wrapGAppsHook3 ]; - buildInputs = [ readline python3 ]; - configureFlags = ["--enable-gui"]; + nativeBuildInputs = [ + autoreconfHook + gobject-introspection + intltool + wrapGAppsHook3 + ]; + buildInputs = [ + readline + python3 + ]; + configureFlags = [ "--enable-gui" ]; # we don't need to wrap the main executable, just the GUI dontWrapGApps = true; diff --git a/pkgs/by-name/sc/scaphandre/package.nix b/pkgs/by-name/sc/scaphandre/package.nix index 4d7d0c50607530..31146c66972236 100644 --- a/pkgs/by-name/sc/scaphandre/package.nix +++ b/pkgs/by-name/sc/scaphandre/package.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, nix-update-script -, runCommand -, dieHook -, nixosTests -, testers -, scaphandre +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + nix-update-script, + runCommand, + dieHook, + nixosTests, + testers, + scaphandre, }: rustPlatform.buildRustPackage rec { @@ -42,15 +43,19 @@ rustPlatform.buildRustPackage rec { passthru = { updateScript = nix-update-script { }; tests = { - stdout = self: runCommand "${pname}-test" { - buildInputs = [ - self - dieHook - ]; - } '' - ${self}/bin/scaphandre stdout -t 4 > $out || die "Scaphandre failed to measure consumption" - [ -s $out ] - ''; + stdout = + self: + runCommand "${pname}-test" + { + buildInputs = [ + self + dieHook + ]; + } + '' + ${self}/bin/scaphandre stdout -t 4 > $out || die "Scaphandre failed to measure consumption" + [ -s $out ] + ''; vm = nixosTests.scaphandre; version = testers.testVersion { inherit version; diff --git a/pkgs/by-name/sc/sccache/package.nix b/pkgs/by-name/sc/sccache/package.nix index a539e4d380724f..cabc240fdd2b63 100644 --- a/pkgs/by-name/sc/sccache/package.nix +++ b/pkgs/by-name/sc/sccache/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -23,12 +24,14 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; # Tests fail because of client server setup which is not possible inside the # pure environment, see https://github.com/mozilla/sccache/issues/460 @@ -39,7 +42,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "sccache"; homepage = "https://github.com/mozilla/sccache"; changelog = "https://github.com/mozilla/sccache/releases/tag/v${version}"; - maintainers = with maintainers; [ doronbehar figsoda ]; + maintainers = with maintainers; [ + doronbehar + figsoda + ]; license = licenses.asl20; }; } diff --git a/pkgs/by-name/sc/scd2html/package.nix b/pkgs/by-name/sc/scd2html/package.nix index 8ca7f8824a80de..d562af3fe8fcc2 100644 --- a/pkgs/by-name/sc/scd2html/package.nix +++ b/pkgs/by-name/sc/scd2html/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromSourcehut -, scdoc +{ + lib, + stdenv, + fetchFromSourcehut, + scdoc, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sc/scdoc/package.nix b/pkgs/by-name/sc/scdoc/package.nix index 1d1f63963f7e93..c9a7305b3bcd98 100644 --- a/pkgs/by-name/sc/scdoc/package.nix +++ b/pkgs/by-name/sc/scdoc/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromSourcehut -, buildPackages +{ + lib, + stdenv, + fetchFromSourcehut, + buildPackages, }: stdenv.mkDerivation (finalAttrs: { @@ -15,18 +16,24 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-MbLDhLn/JY6OcdOz9/mIPAQRp5TZ6IKuQ/FQ/R3wjGc="; }; - outputs = [ "out" "man" "dev" ]; + outputs = [ + "out" + "man" + "dev" + ]; postPatch = '' substituteInPlace Makefile \ --replace "LDFLAGS+=-static" "LDFLAGS+=" ''; - makeFlags = [ - "PREFIX=${placeholder "out"}" - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - "HOST_SCDOC=${lib.getExe buildPackages.scdoc}" - ]; + makeFlags = + [ + "PREFIX=${placeholder "out"}" + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + "HOST_SCDOC=${lib.getExe buildPackages.scdoc}" + ]; doCheck = true; @@ -36,7 +43,10 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://git.sr.ht/~sircmpwn/scdoc/refs/${finalAttrs.src.rev}"; license = lib.licenses.mit; mainProgram = "scdoc"; - maintainers = with lib.maintainers; [ primeos AndersonTorres ]; + maintainers = with lib.maintainers; [ + primeos + AndersonTorres + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/by-name/sc/scenebuilder/package.nix b/pkgs/by-name/sc/scenebuilder/package.nix index 7f650a7085018c..3dd1354f8c9fb8 100644 --- a/pkgs/by-name/sc/scenebuilder/package.nix +++ b/pkgs/by-name/sc/scenebuilder/package.nix @@ -1,12 +1,13 @@ -{ lib -, jdk21 -, maven -, fetchFromGitHub -, makeDesktopItem -, copyDesktopItems -, glib -, makeWrapper -, wrapGAppsHook3 +{ + lib, + jdk21, + maven, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + glib, + makeWrapper, + wrapGAppsHook3, }: let @@ -80,7 +81,11 @@ maven.buildMavenPackage rec { icon = "scenebuilder"; comment = "A visual, drag'n'drop, layout tool for designing JavaFX application user interfaces."; desktopName = "Scene Builder"; - mimeTypes = [ "application/java" "application/java-vm" "application/java-archive" ]; + mimeTypes = [ + "application/java" + "application/java-vm" + "application/java-archive" + ]; categories = [ "Development" ]; }) ]; @@ -99,4 +104,3 @@ maven.buildMavenPackage rec { ]; }; } - diff --git a/pkgs/by-name/sc/scenic-view/package.nix b/pkgs/by-name/sc/scenic-view/package.nix index e0c79ed08f7780..1f0b215fcf93b2 100644 --- a/pkgs/by-name/sc/scenic-view/package.nix +++ b/pkgs/by-name/sc/scenic-view/package.nix @@ -1,9 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, openjdk, openjfx, gradle_7, makeDesktopItem, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + openjdk, + openjfx, + gradle_7, + makeDesktopItem, + makeWrapper, +}: let - jdk = openjdk.override (lib.optionalAttrs stdenv.hostPlatform.isLinux { - enableJavaFX = true; - openjfx_jdk = openjfx.override { withWebKit = true; }; - }); + jdk = openjdk.override ( + lib.optionalAttrs stdenv.hostPlatform.isLinux { + enableJavaFX = true; + openjfx_jdk = openjfx.override { withWebKit = true; }; + } + ); pname = "scenic-view"; version = "11.0.2"; @@ -22,13 +33,21 @@ let desktopName = pname; exec = pname; comment = "JavaFx application to visualize and modify the scenegraph of running JavaFx applications."; - mimeTypes = [ "application/java" "application/java-vm" "application/java-archive" ]; + mimeTypes = [ + "application/java" + "application/java-vm" + "application/java-archive" + ]; categories = [ "Development" ]; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { inherit pname version src; - nativeBuildInputs = [ gradle makeWrapper ]; + nativeBuildInputs = [ + gradle + makeWrapper + ]; mitmCache = gradle.fetchDeps { inherit pname; @@ -63,7 +82,7 @@ in stdenv.mkDerivation rec { homepage = "https://github.com/JonathanGiles/scenic-view/"; sourceProvenance = with sourceTypes; [ fromSource - binaryBytecode # deps + binaryBytecode # deps ]; license = licenses.gpl3Plus; maintainers = with maintainers; [ wirew0rm ]; diff --git a/pkgs/by-name/sc/schedtool/package.nix b/pkgs/by-name/sc/schedtool/package.nix index 0ee35df74449e6..fbbbee1c096868 100644 --- a/pkgs/by-name/sc/schedtool/package.nix +++ b/pkgs/by-name/sc/schedtool/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "schedtool"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1wdw6fnf9a01xfjhdah3mn8bp1bvahf2lfq74i6hk5b2cagkppyp"; }; - makeFlags = [ "DESTDIR=$(out)" "DESTPREFIX=" ]; + makeFlags = [ + "DESTDIR=$(out)" + "DESTPREFIX=" + ]; meta = with lib; { description = "Query or alter a process' scheduling policy under Linux"; diff --git a/pkgs/by-name/sc/schema2ldif/package.nix b/pkgs/by-name/sc/schema2ldif/package.nix index fc4a2153d662d0..3fe969008dca1d 100644 --- a/pkgs/by-name/sc/schema2ldif/package.nix +++ b/pkgs/by-name/sc/schema2ldif/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenvNoCC, fetchurl, makeWrapper, perlPackages }: +{ + lib, + stdenvNoCC, + fetchurl, + makeWrapper, + perlPackages, +}: stdenvNoCC.mkDerivation rec { pname = "schema2ldif"; diff --git a/pkgs/by-name/sc/scheme-bytestructures/package.nix b/pkgs/by-name/sc/scheme-bytestructures/package.nix index 9ff23f2327eb87..3ba94982174f93 100644 --- a/pkgs/by-name/sc/scheme-bytestructures/package.nix +++ b/pkgs/by-name/sc/scheme-bytestructures/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, guile -, autoreconfHook -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + guile, + autoreconfHook, + pkg-config, }: stdenv.mkDerivation rec { @@ -19,7 +20,9 @@ stdenv.mkDerivation rec { strictDeps = true; nativeBuildInputs = [ - autoreconfHook guile pkg-config + autoreconfHook + guile + pkg-config ]; buildInputs = [ guile diff --git a/pkgs/by-name/sc/scheme-manpages/package.nix b/pkgs/by-name/sc/scheme-manpages/package.nix index 96d8d9ac1194b7..c4e9dfffe78c8b 100644 --- a/pkgs/by-name/sc/scheme-manpages/package.nix +++ b/pkgs/by-name/sc/scheme-manpages/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchFromGitHub, unstableGitUpdater }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + unstableGitUpdater, +}: stdenvNoCC.mkDerivation rec { pname = "scheme-manpages"; diff --git a/pkgs/by-name/sc/scheme48/package.nix b/pkgs/by-name/sc/scheme48/package.nix index 82bd58469bd320..72cdfe8fc90827 100644 --- a/pkgs/by-name/sc/scheme48/package.nix +++ b/pkgs/by-name/sc/scheme48/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "scheme48"; diff --git a/pkgs/by-name/sc/schemes/package.nix b/pkgs/by-name/sc/schemes/package.nix index acf3cd8cf10270..7b1b887a8c3aa0 100644 --- a/pkgs/by-name/sc/schemes/package.nix +++ b/pkgs/by-name/sc/schemes/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitLab -, appstream-glib -, desktop-file-utils -, glib -, gtk4 -, gtksourceview5 -, libadwaita -, libpanel -, meson -, ninja -, pkg-config -, wrapGAppsHook4 +{ + lib, + stdenv, + fetchFromGitLab, + appstream-glib, + desktop-file-utils, + glib, + gtk4, + gtksourceview5, + libadwaita, + libpanel, + meson, + ninja, + pkg-config, + wrapGAppsHook4, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sc/scid-vs-pc/package.nix b/pkgs/by-name/sc/scid-vs-pc/package.nix index d46f077a25b7cb..e1cf8503ae6810 100644 --- a/pkgs/by-name/sc/scid-vs-pc/package.nix +++ b/pkgs/by-name/sc/scid-vs-pc/package.nix @@ -1,4 +1,14 @@ -{ lib, fetchurl, tcl, tk, libX11, zlib, makeWrapper, which, makeDesktopItem }: +{ + lib, + fetchurl, + tcl, + tk, + libX11, + zlib, + makeWrapper, + which, + makeDesktopItem, +}: tcl.mkTclDerivation rec { pname = "scid-vs-pc"; @@ -15,8 +25,15 @@ tcl.mkTclDerivation rec { --replace "which fc-cache" "false" ''; - nativeBuildInputs = [ makeWrapper which ]; - buildInputs = [ tk libX11 zlib ]; + nativeBuildInputs = [ + makeWrapper + which + ]; + buildInputs = [ + tk + libX11 + zlib + ]; configureFlags = [ "BINDIR=${placeholder "out"}/bin" @@ -37,7 +54,10 @@ tcl.mkTclDerivation rec { comment = meta.description; icon = "scid"; exec = "scid"; - categories = [ "Game" "BoardGame" ]; + categories = [ + "Game" + "BoardGame" + ]; }; meta = with lib; { diff --git a/pkgs/by-name/sc/scid/package.nix b/pkgs/by-name/sc/scid/package.nix index c4dcef454b8be5..ed1d0049b5d3fe 100644 --- a/pkgs/by-name/sc/scid/package.nix +++ b/pkgs/by-name/sc/scid/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, tcl -, tk -, libX11 -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + tcl, + tk, + libX11, + zlib, }: tcl.mkTclDerivation rec { diff --git a/pkgs/by-name/sc/scientifica/package.nix b/pkgs/by-name/sc/scientifica/package.nix index 1b57c9f286d3dc..fcd996cf368160 100644 --- a/pkgs/by-name/sc/scientifica/package.nix +++ b/pkgs/by-name/sc/scientifica/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "scientifica"; diff --git a/pkgs/by-name/sc/scilab-bin/package.nix b/pkgs/by-name/sc/scilab-bin/package.nix index e3ca7bef52a4b1..243f17def1f102 100644 --- a/pkgs/by-name/sc/scilab-bin/package.nix +++ b/pkgs/by-name/sc/scilab-bin/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, undmg -, autoPatchelfHook -, alsa-lib -, ncurses5 -, xorg +{ + lib, + stdenv, + fetchurl, + makeWrapper, + undmg, + autoPatchelfHook, + alsa-lib, + ncurses5, + xorg, }: let @@ -27,19 +28,29 @@ let sha256 = "sha256-PuGnz2YdAhriavwnuf5Qyy0cnCeRHlWC6dQzfr7bLHk="; }; }; - src = srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); meta = { homepage = "http://www.scilab.org/"; description = "Scientific software package for numerical computations (Matlab lookalike)"; - platforms = [ "aarch64-darwin" "x86_64-darwin" "x86_64-linux" ]; + platforms = [ + "aarch64-darwin" + "x86_64-darwin" + "x86_64-linux" + ]; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; license = lib.licenses.gpl2Only; mainProgram = "scilab"; }; darwin = stdenv.mkDerivation rec { - inherit pname version src meta; + inherit + pname + version + src + meta + ; nativeBuildInputs = [ makeWrapper @@ -60,27 +71,34 @@ let }; linux = stdenv.mkDerivation rec { - inherit pname version src meta; + inherit + pname + version + src + meta + ; nativeBuildInputs = [ autoPatchelfHook ]; - buildInputs = [ - alsa-lib - ncurses5 - stdenv.cc.cc - ] ++ (with xorg; [ - libX11 - libXcursor - libXext - libXft - libXi - libXrandr - libXrender - libXtst - libXxf86vm - ]); + buildInputs = + [ + alsa-lib + ncurses5 + stdenv.cc.cc + ] + ++ (with xorg; [ + libX11 + libXcursor + libXext + libXft + libXi + libXrandr + libXrender + libXtst + libXxf86vm + ]); installPhase = '' runHook preInstall diff --git a/pkgs/by-name/sc/scimark/package.nix b/pkgs/by-name/sc/scimark/package.nix index c9a88e6d2b59e3..ac6e7ab458d853 100644 --- a/pkgs/by-name/sc/scimark/package.nix +++ b/pkgs/by-name/sc/scimark/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, unzip +{ + lib, + stdenv, + fetchurl, + unzip, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sc/scion-apps/package.nix b/pkgs/by-name/sc/scion-apps/package.nix index f4dfd933d24f2a..a382474d9ce4d8 100644 --- a/pkgs/by-name/sc/scion-apps/package.nix +++ b/pkgs/by-name/sc/scion-apps/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, openpam +{ + lib, + buildGoModule, + fetchFromGitHub, + openpam, }: buildGoModule { @@ -42,12 +43,18 @@ buildGoModule { openpam ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Public repository for SCION applications"; homepage = "https://github.com/netsec-ethz/scion-apps"; license = licenses.asl20; - maintainers = with maintainers; [ matthewcroughan sarcasticadmin ]; + maintainers = with maintainers; [ + matthewcroughan + sarcasticadmin + ]; }; } diff --git a/pkgs/by-name/sc/scion-bootstrapper/package.nix b/pkgs/by-name/sc/scion-bootstrapper/package.nix index 8b6e6f115c198a..20e4817ac574e1 100644 --- a/pkgs/by-name/sc/scion-bootstrapper/package.nix +++ b/pkgs/by-name/sc/scion-bootstrapper/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -18,7 +19,10 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' mv $out/bin/bootstrapper $out/bin/scion-bootstrapper @@ -28,7 +32,10 @@ buildGoModule rec { description = "bootstrapper for SCION network configuration"; homepage = "https://github.com/netsec-ethz/bootstrapper"; license = licenses.asl20; - maintainers = with maintainers; [ matthewcroughan sarcasticadmin ]; + maintainers = with maintainers; [ + matthewcroughan + sarcasticadmin + ]; mainProgram = "scion-bootstrapper"; }; } diff --git a/pkgs/by-name/sc/scip-go/package.nix b/pkgs/by-name/sc/scip-go/package.nix index 5b7511062663a2..7ffaa1ad8fddfc 100644 --- a/pkgs/by-name/sc/scip-go/package.nix +++ b/pkgs/by-name/sc/scip-go/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-E/1ubWGIx+sGC+owqw4nOkrwUFJfgTeqDNpH8HCwNhA="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; doCheck = false; diff --git a/pkgs/by-name/sc/scip/package.nix b/pkgs/by-name/sc/scip/package.nix index 22f26382026cb9..1ddfc127de6d1c 100644 --- a/pkgs/by-name/sc/scip/package.nix +++ b/pkgs/by-name/sc/scip/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, scip +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + scip, }: buildGoModule rec { diff --git a/pkgs/by-name/sc/scitokens-cpp/package.nix b/pkgs/by-name/sc/scitokens-cpp/package.nix index fee6a28bb4e546..c46f9758890bde 100644 --- a/pkgs/by-name/sc/scitokens-cpp/package.nix +++ b/pkgs/by-name/sc/scitokens-cpp/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, libuuid, curl, sqlite, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libuuid, + curl, + sqlite, + openssl, +}: stdenv.mkDerivation rec { pname = "scitokens-cpp"; @@ -12,7 +22,10 @@ stdenv.mkDerivation rec { hash = "sha256-87mV1hyoUI/pWzRXaI051H3+FN5TXcachhgAPTtQYHg="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libuuid openssl @@ -20,11 +33,9 @@ stdenv.mkDerivation rec { sqlite ]; - meta = with lib; { homepage = "https://github.com/scitokens/scitokens-cpp/"; - description = - "A C++ implementation of the SciTokens library with a C library interface"; + description = "A C++ implementation of the SciTokens library with a C library interface"; platforms = platforms.unix; license = licenses.asl20; maintainers = with maintainers; [ evey ]; diff --git a/pkgs/by-name/sc/scli/package.nix b/pkgs/by-name/sc/scli/package.nix index a16770df8611d7..a57c52f421d300 100644 --- a/pkgs/by-name/sc/scli/package.nix +++ b/pkgs/by-name/sc/scli/package.nix @@ -1,11 +1,12 @@ -{ lib -, python3 -, fetchFromGitHub -, dbus -, signal-cli -, xclip -, testers -, scli +{ + lib, + python3, + fetchFromGitHub, + dbus, + signal-cli, + xclip, + testers, + scli, }: python3.pkgs.buildPythonApplication rec { @@ -39,7 +40,14 @@ python3.pkgs.buildPythonApplication rec { ''; makeWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath [ dbus signal-cli xclip ]) + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ + dbus + signal-cli + xclip + ]) ]; passthru.tests = { diff --git a/pkgs/by-name/sc/scmccid/package.nix b/pkgs/by-name/sc/scmccid/package.nix index 73fb6a6dcf6e44..684c8116fc72bf 100644 --- a/pkgs/by-name/sc/scmccid/package.nix +++ b/pkgs/by-name/sc/scmccid/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, patchelf, libusb-compat-0_1}: +{ + lib, + stdenv, + fetchurl, + patchelf, + libusb-compat-0_1, +}: assert stdenv ? cc && stdenv.cc.libc != null; @@ -6,15 +12,19 @@ stdenv.mkDerivation rec { pname = "scmccid"; version = "5.0.11"; - src = if stdenv.hostPlatform.system == "i686-linux" then (fetchurl { - url = "http://www.scmmicro.com/support/download/scmccid_${version}_linux.tar.gz"; - sha256 = "1r5wkarhzl09ncgj55baizf573czw0nplh1pgddzx9xck66kh5bm"; - }) - else if stdenv.hostPlatform.system == "x86_64-linux" then (fetchurl { + src = + if stdenv.hostPlatform.system == "i686-linux" then + (fetchurl { + url = "http://www.scmmicro.com/support/download/scmccid_${version}_linux.tar.gz"; + sha256 = "1r5wkarhzl09ncgj55baizf573czw0nplh1pgddzx9xck66kh5bm"; + }) + else if stdenv.hostPlatform.system == "x86_64-linux" then + (fetchurl { url = "http://www.scmmicro.com/support/download/scmccid_${version}_linux_x64.tar.gz"; sha256 = "0k9lzlk01sl4ycfqgrqqy3bildz0mcr1r0kkicgjz96l4s0jgz0i"; - }) - else throw "Architecture not supported"; + }) + else + throw "Architecture not supported"; nativeBuildInputs = [ patchelf ]; diff --git a/pkgs/by-name/sc/scmpuff/package.nix b/pkgs/by-name/sc/scmpuff/package.nix index a94099e30478b8..dabc7226af316a 100644 --- a/pkgs/by-name/sc/scmpuff/package.nix +++ b/pkgs/by-name/sc/scmpuff/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, scmpuff }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + scmpuff, +}: buildGoModule rec { pname = "scmpuff"; @@ -13,7 +19,11 @@ buildGoModule rec { vendorHash = "sha256-7WHVSEz3y1nxWfbxkzkfHhINLC8+snmWknHyUUpNy7c="; - ldflags = [ "-s" "-w" "-X main.VERSION=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.VERSION=${version}" + ]; passthru.tests.version = testers.testVersion { package = scmpuff; diff --git a/pkgs/by-name/sc/scons/package.nix b/pkgs/by-name/sc/scons/package.nix index 06d97f81b18547..14d5e993ba354c 100644 --- a/pkgs/by-name/sc/scons/package.nix +++ b/pkgs/by-name/sc/scons/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, fetchpatch, python3Packages }: +{ + lib, + fetchFromGitHub, + fetchpatch, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "scons"; version = "4.7.0"; diff --git a/pkgs/by-name/sc/scope-lite/package.nix b/pkgs/by-name/sc/scope-lite/package.nix index 37cf8d12fd00e2..130c5704ecabf6 100644 --- a/pkgs/by-name/sc/scope-lite/package.nix +++ b/pkgs/by-name/sc/scope-lite/package.nix @@ -1,6 +1,13 @@ -{ stdenv, cmake, fetchFromGitHub, lib }: let +{ + stdenv, + cmake, + fetchFromGitHub, + lib, +}: +let version = "0.2.0"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { name = "scope-lite-${version}"; src = fetchFromGitHub { diff --git a/pkgs/by-name/sc/scorched3d/package.nix b/pkgs/by-name/sc/scorched3d/package.nix index fa8b7bcc8dd447..da9b404812ebb6 100644 --- a/pkgs/by-name/sc/scorched3d/package.nix +++ b/pkgs/by-name/sc/scorched3d/package.nix @@ -1,5 +1,24 @@ -{ lib, stdenv, fetchurl, libGLU, libGL, glew, pkg-config, openalSoft, freealut, wxGTK32, libogg -, freetype, libvorbis, fftwSinglePrec, SDL, SDL_net, expat, libjpeg, libpng }: +{ + lib, + stdenv, + fetchurl, + libGLU, + libGL, + glew, + pkg-config, + openalSoft, + freealut, + wxGTK32, + libogg, + freetype, + libvorbis, + fftwSinglePrec, + SDL, + SDL_net, + expat, + libjpeg, + libpng, +}: stdenv.mkDerivation rec { version = "44"; @@ -9,10 +28,23 @@ stdenv.mkDerivation rec { sha256 = "1fldi9pn7cz6hc9h70pacgb7sbykzcac44yp3pkhn0qh4axj10qw"; }; - buildInputs = - [ libGLU libGL glew openalSoft freealut wxGTK32 libogg freetype libvorbis - SDL SDL_net expat libjpeg libpng fftwSinglePrec - ]; + buildInputs = [ + libGLU + libGL + glew + openalSoft + freealut + wxGTK32 + libogg + freetype + libvorbis + SDL + SDL_net + expat + libjpeg + libpng + fftwSinglePrec + ]; nativeBuildInputs = [ pkg-config ]; diff --git a/pkgs/by-name/sc/scorecard/package.nix b/pkgs/by-name/sc/scorecard/package.nix index de2f9b9b07dc72..7ed3d944d27ee6 100644 --- a/pkgs/by-name/sc/scorecard/package.nix +++ b/pkgs/by-name/sc/scorecard/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, testers -, scorecard +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + scorecard, }: buildGoModule rec { @@ -89,6 +90,9 @@ buildGoModule rec { description = "Security health metrics for Open Source"; mainProgram = "scorecard"; license = licenses.asl20; - maintainers = with maintainers; [ jk developer-guy ]; + maintainers = with maintainers; [ + jk + developer-guy + ]; }; } diff --git a/pkgs/by-name/sc/scout/package.nix b/pkgs/by-name/sc/scout/package.nix index 4c1a80ff109b2e..e0935322b27456 100644 --- a/pkgs/by-name/sc/scout/package.nix +++ b/pkgs/by-name/sc/scout/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/sc/scowl/package.nix b/pkgs/by-name/sc/scowl/package.nix index 53988a728de319..cc129a42c8881c 100644 --- a/pkgs/by-name/sc/scowl/package.nix +++ b/pkgs/by-name/sc/scowl/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, unzip, zip, libiconv, perl, aspell, dos2unix -, singleWordlist ? null +{ + lib, + stdenv, + fetchFromGitHub, + unzip, + zip, + libiconv, + perl, + aspell, + dos2unix, + singleWordlist ? null, }: stdenv.mkDerivation rec { @@ -18,7 +27,13 @@ stdenv.mkDerivation rec { --replace g++ c++ ''; - nativeBuildInputs = [ unzip zip perl aspell dos2unix ]; + nativeBuildInputs = [ + unzip + zip + perl + aspell + dos2unix + ]; buildInputs = lib.optional (!stdenv.hostPlatform.isLinux) libiconv; env.NIX_CFLAGS_COMPILE = "-Wno-narrowing"; @@ -38,73 +53,77 @@ stdenv.mkDerivation rec { enableParallelBuilding = false; - installPhase = if singleWordlist == null then '' - eval "$preInstall" - - mkdir -p "$out/share/scowl" - mkdir -p "$out/lib" "$out/share/hunspell" "$out/share/myspell" - mkdir -p "$out/share/dict" - - cp -r scowl/speller/aspell "$out/lib/aspell" - cp scowl/speller/*.{aff,dic} "$out/share/hunspell" - ln -s "$out/share/hunspell" "$out/share/myspell/dicts" - - cp scowl/final/* "$out/share/scowl" - - ( - cd scowl - for region in american british british_s british_z canadian australian; do - case $region in - american) - regcode=en-us; - ;; - british) - regcode=en-gb-ise; - ;; - british_s) - regcode=en-gb-ise; - ;; - british_z) - regcode=en-gb-ize; - ;; - canadian) - regcode=en-ca; - ;; - australian) - regcode=en-au; - ;; - esac - regcode_var="$regcode" - if test "$region" = british; then - regcode_var="en-gb" - fi - - echo $region $regcode $regcode_sz - for s in 10 20 30 35 40 50 55 60 70 80 90 95; do - ./mk-list $regcode $s > "$out/share/dict/w$region.$s" - ./mk-list --variants=1 $regcode_var $s > "$out/share/dict/w$region.variants.$s" - ./mk-list --variants=2 $regcode_var $s > "$out/share/dict/w$region.acceptable.$s" - done - ./mk-list $regcode 60 > "$out/share/dict/w$region.txt" - ./mk-list --variants=1 $regcode_var 60 > "$out/share/dict/w$region.variants.txt" - ./mk-list --variants=2 $regcode_var 80 > "$out/share/dict/w$region.scrabble.txt" - done - ./mk-list --variants=1 en-gb 60 > "$out/share/dict/words.variants.txt" - ./mk-list --variants=1 en-gb 80 > "$out/share/dict/words.scrabble.txt" - ./mk-list en-gb-ise 60 > "$out/share/dict/words.txt" - ) - - eval "$postInstall" - '' else '' - mkdir -p "$out/share/dict" - cd scowl - ./mk-list ${singleWordlist} > "$out/share/dict/words.txt" - ''; + installPhase = + if singleWordlist == null then + '' + eval "$preInstall" + + mkdir -p "$out/share/scowl" + mkdir -p "$out/lib" "$out/share/hunspell" "$out/share/myspell" + mkdir -p "$out/share/dict" + + cp -r scowl/speller/aspell "$out/lib/aspell" + cp scowl/speller/*.{aff,dic} "$out/share/hunspell" + ln -s "$out/share/hunspell" "$out/share/myspell/dicts" + + cp scowl/final/* "$out/share/scowl" + + ( + cd scowl + for region in american british british_s british_z canadian australian; do + case $region in + american) + regcode=en-us; + ;; + british) + regcode=en-gb-ise; + ;; + british_s) + regcode=en-gb-ise; + ;; + british_z) + regcode=en-gb-ize; + ;; + canadian) + regcode=en-ca; + ;; + australian) + regcode=en-au; + ;; + esac + regcode_var="$regcode" + if test "$region" = british; then + regcode_var="en-gb" + fi + + echo $region $regcode $regcode_sz + for s in 10 20 30 35 40 50 55 60 70 80 90 95; do + ./mk-list $regcode $s > "$out/share/dict/w$region.$s" + ./mk-list --variants=1 $regcode_var $s > "$out/share/dict/w$region.variants.$s" + ./mk-list --variants=2 $regcode_var $s > "$out/share/dict/w$region.acceptable.$s" + done + ./mk-list $regcode 60 > "$out/share/dict/w$region.txt" + ./mk-list --variants=1 $regcode_var 60 > "$out/share/dict/w$region.variants.txt" + ./mk-list --variants=2 $regcode_var 80 > "$out/share/dict/w$region.scrabble.txt" + done + ./mk-list --variants=1 en-gb 60 > "$out/share/dict/words.variants.txt" + ./mk-list --variants=1 en-gb 80 > "$out/share/dict/words.scrabble.txt" + ./mk-list en-gb-ise 60 > "$out/share/dict/words.txt" + ) + + eval "$postInstall" + '' + else + '' + mkdir -p "$out/share/dict" + cd scowl + ./mk-list ${singleWordlist} > "$out/share/dict/words.txt" + ''; meta = { description = "Spell checker oriented word lists"; license = lib.licenses.mit; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.unix; homepage = "http://wordlist.aspell.net/"; }; diff --git a/pkgs/by-name/sc/scponly/package.nix b/pkgs/by-name/sc/scponly/package.nix index 11cfee7b2d919c..ad8cb9d4a65a22 100644 --- a/pkgs/by-name/sc/scponly/package.nix +++ b/pkgs/by-name/sc/scponly/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, openssh, debugLevel ? 0 }: +{ + stdenv, + lib, + fetchFromGitHub, + openssh, + debugLevel ? 0, +}: stdenv.mkDerivation { pname = "scponly"; @@ -24,9 +30,7 @@ stdenv.mkDerivation { ]; postInstall = lib.optionalString (debugLevel > 0) '' - mkdir -p $out/etc/scponly && echo ${ - toString debugLevel - } > $out/etc/scponly/debuglevel + mkdir -p $out/etc/scponly && echo ${toString debugLevel} > $out/etc/scponly/debuglevel ''; passthru.shellPath = "/bin/scponly"; diff --git a/pkgs/by-name/sc/scream/package.nix b/pkgs/by-name/sc/scream/package.nix index cc09b218753538..2c63f34bec4a4c 100644 --- a/pkgs/by-name/sc/scream/package.nix +++ b/pkgs/by-name/sc/scream/package.nix @@ -1,8 +1,19 @@ -{ stdenv, lib, config, fetchFromGitHub, cmake, pkg-config -, alsaSupport ? stdenv.hostPlatform.isLinux, alsa-lib -, pulseSupport ? config.pulseaudio or stdenv.hostPlatform.isLinux, libpulseaudio -, jackSupport ? false, libjack2, soxr -, pcapSupport ? false, libpcap +{ + stdenv, + lib, + config, + fetchFromGitHub, + cmake, + pkg-config, + alsaSupport ? stdenv.hostPlatform.isLinux, + alsa-lib, + pulseSupport ? config.pulseaudio or stdenv.hostPlatform.isLinux, + libpulseaudio, + jackSupport ? false, + libjack2, + soxr, + pcapSupport ? false, + libpcap, }: stdenv.mkDerivation rec { @@ -16,11 +27,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-lP5mdNhZjkEVjgQUEsisPy+KXUqsE6xj6dFWcgD+VGM="; }; - buildInputs = lib.optional pulseSupport libpulseaudio - ++ lib.optionals jackSupport [ libjack2 soxr ] + buildInputs = + lib.optional pulseSupport libpulseaudio + ++ lib.optionals jackSupport [ + libjack2 + soxr + ] ++ lib.optional alsaSupport alsa-lib ++ lib.optional pcapSupport libpcap; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; cmakeFlags = [ "-DPULSEAUDIO_ENABLE=${if pulseSupport then "ON" else "OFF"}" diff --git a/pkgs/by-name/sc/screen-message/package.nix b/pkgs/by-name/sc/screen-message/package.nix index c8ad7e050a9698..2d5eb30aecae82 100644 --- a/pkgs/by-name/sc/screen-message/package.nix +++ b/pkgs/by-name/sc/screen-message/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, gtk3 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + gtk3, +}: stdenv.mkDerivation rec { pname = "screen-message"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-fwKle+aXZuiNo5ksrigj7BGLv2fUILN2GluHHZ6co6s="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ gtk3 ]; # screen-message installs its binary in $(prefix)/games per default diff --git a/pkgs/by-name/sc/screenfetch/package.nix b/pkgs/by-name/sc/screenfetch/package.nix index 0be861492826c0..12185ee31bd1e7 100644 --- a/pkgs/by-name/sc/screenfetch/package.nix +++ b/pkgs/by-name/sc/screenfetch/package.nix @@ -1,31 +1,59 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper, coreutils, gawk, procps, gnused -, bc, findutils, xdpyinfo, xprop, gnugrep, ncurses, pciutils -, darwin +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + coreutils, + gawk, + procps, + gnused, + bc, + findutils, + xdpyinfo, + xprop, + gnugrep, + ncurses, + pciutils, + darwin, }: let - path = lib.makeBinPath ([ - coreutils gawk gnused findutils - gnugrep ncurses bc pciutils - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - procps - xdpyinfo - xprop - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin; [ - adv_cmds - DarwinTools - system_cmds - "/usr" # some commands like defaults is not available to us - ])); + path = lib.makeBinPath ( + [ + coreutils + gawk + gnused + findutils + gnugrep + ncurses + bc + pciutils + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + procps + xdpyinfo + xprop + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin; + [ + adv_cmds + DarwinTools + system_cmds + "/usr" # some commands like defaults is not available to us + ] + ) + ); -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "screenfetch"; version = "3.9.9"; src = fetchFromGitHub { - owner = "KittyKatt"; - repo = "screenFetch"; - rev = "v${version}"; + owner = "KittyKatt"; + repo = "screenFetch"; + rev = "v${version}"; sha256 = "sha256-UNZMCLXhH4wDV0/fGWsB+KAi6aJVuPs6zpWXIQAqnjo="; }; diff --git a/pkgs/by-name/sc/screenkey/package.nix b/pkgs/by-name/sc/screenkey/package.nix index 59e53f3ccdc857..5a7a5698c1611e 100644 --- a/pkgs/by-name/sc/screenkey/package.nix +++ b/pkgs/by-name/sc/screenkey/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitLab -, wrapGAppsHook3 -, xorg -, gobject-introspection -, gtk3 -, libappindicator-gtk3 -, slop -, python3 +{ + lib, + fetchFromGitLab, + wrapGAppsHook3, + xorg, + gobject-introspection, + gtk3, + libappindicator-gtk3, + slop, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/sc/script-directory/package.nix b/pkgs/by-name/sc/script-directory/package.nix index 1cd0218c30dcdf..5d9bbca76acce5 100644 --- a/pkgs/by-name/sc/script-directory/package.nix +++ b/pkgs/by-name/sc/script-directory/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, installShellFiles -, patsh +{ + lib, + stdenvNoCC, + fetchFromGitHub, + installShellFiles, + patsh, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/sc/scriptaculous/package.nix b/pkgs/by-name/sc/scriptaculous/package.nix index 50171324b386ee..dc2d4f0c811cbd 100644 --- a/pkgs/by-name/sc/scriptaculous/package.nix +++ b/pkgs/by-name/sc/scriptaculous/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, unzip, ... }: +{ + lib, + stdenv, + fetchurl, + unzip, + ... +}: stdenv.mkDerivation rec { pname = "scriptaculous"; diff --git a/pkgs/by-name/sc/scriptisto/package.nix b/pkgs/by-name/sc/scriptisto/package.nix index 5efcd30c90183f..1065712928d9f2 100644 --- a/pkgs/by-name/sc/scriptisto/package.nix +++ b/pkgs/by-name/sc/scriptisto/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sc/scriv/package.nix b/pkgs/by-name/sc/scriv/package.nix index 40038fa796ddad..f3c7c8da3fdcea 100644 --- a/pkgs/by-name/sc/scriv/package.nix +++ b/pkgs/by-name/sc/scriv/package.nix @@ -1,10 +1,11 @@ -{ lib -, python3 -, fetchPypi -, pandoc -, git -, scriv -, testers +{ + lib, + python3, + fetchPypi, + pandoc, + git, + scriv, + testers, }: python3.pkgs.buildPythonApplication rec { @@ -16,16 +17,19 @@ python3.pkgs.buildPythonApplication rec { hash = "sha256-MK6f+NFE+ODPOUxOHTeVQvGzgjdnZClVtU7EDcALMrY="; }; - propagatedBuildInputs = with python3.pkgs; [ - attrs - click - click-log - jinja2 - markdown-it-py - requests - ] ++ lib.optionals (python3.pythonOlder "3.11") [ - tomli - ]; + propagatedBuildInputs = + with python3.pkgs; + [ + attrs + click + click-log + jinja2 + markdown-it-py + requests + ] + ++ lib.optionals (python3.pythonOlder "3.11") [ + tomli + ]; nativeCheckInputs = with python3.pkgs; [ pytestCheckHook diff --git a/pkgs/by-name/sc/scrolls/package.nix b/pkgs/by-name/sc/scrolls/package.nix index 7478df20e9930d..743da81e53d9e2 100644 --- a/pkgs/by-name/sc/scrolls/package.nix +++ b/pkgs/by-name/sc/scrolls/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchurl, gcc -, libGLU, libX11, libXext, libXcursor, libpulseaudio +{ + lib, + stdenv, + fetchurl, + gcc, + libGLU, + libX11, + libXext, + libXcursor, + libpulseaudio, }: stdenv.mkDerivation { pname = "scrolls"; diff --git a/pkgs/by-name/sc/scrot/package.nix b/pkgs/by-name/sc/scrot/package.nix index ef8a9e29588eff..8a8bebc041e2d6 100644 --- a/pkgs/by-name/sc/scrot/package.nix +++ b/pkgs/by-name/sc/scrot/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, imlib2 -, autoreconfHook -, autoconf-archive -, libX11 -, libXext -, libXfixes -, libXcomposite -, libXinerama -, pkg-config -, libbsd +{ + lib, + stdenv, + fetchFromGitHub, + imlib2, + autoreconfHook, + autoconf-archive, + libX11, + libXext, + libXfixes, + libXcomposite, + libXinerama, + pkg-config, + libbsd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sc/scrounge-ntfs/package.nix b/pkgs/by-name/sc/scrounge-ntfs/package.nix index 51c0b1860750d3..25523e6d971da5 100644 --- a/pkgs/by-name/sc/scrounge-ntfs/package.nix +++ b/pkgs/by-name/sc/scrounge-ntfs/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sc/scrub/package.nix b/pkgs/by-name/sc/scrub/package.nix index 2fc2b43ea29c2a..b65e9bfb65b437 100644 --- a/pkgs/by-name/sc/scrub/package.nix +++ b/pkgs/by-name/sc/scrub/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libtool }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, +}: stdenv.mkDerivation rec { pname = "scrub"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "0ndcri2ddzqlsxvy1b607ajyd4dxpiagzx331yyi7hf3ijph129f"; }; - nativeBuildInputs = [ autoconf automake ]; + nativeBuildInputs = [ + autoconf + automake + ]; buildInputs = [ libtool ]; preConfigure = "./autogen.sh"; diff --git a/pkgs/by-name/sc/scryer-prolog/package.nix b/pkgs/by-name/sc/scryer-prolog/package.nix index 58a853e66d8865..28ae3a4bdcf305 100644 --- a/pkgs/by-name/sc/scryer-prolog/package.nix +++ b/pkgs/by-name/sc/scryer-prolog/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -22,10 +23,11 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; CARGO_FEATURE_USE_SYSTEM_LIBS = true; @@ -34,6 +36,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "scryer-prolog"; homepage = "https://github.com/mthom/scryer-prolog"; license = with licenses; [ bsd3 ]; - maintainers = with maintainers; [ malbarbo wkral ]; + maintainers = with maintainers; [ + malbarbo + wkral + ]; }; } diff --git a/pkgs/by-name/sc/scrypt/package.nix b/pkgs/by-name/sc/scrypt/package.nix index d199ee37725ea5..b4d46c2be725e7 100644 --- a/pkgs/by-name/sc/scrypt/package.nix +++ b/pkgs/by-name/sc/scrypt/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, openssl -, getconf -, util-linux +{ + lib, + stdenv, + fetchurl, + openssl, + getconf, + util-linux, }: stdenv.mkDerivation rec { @@ -15,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-1jLBGTQgrG+uv5SC5l4z06VmTszWQ7CaUJ0h0cHym+I="; }; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; configureFlags = [ "--enable-libscrypt-kdf" ]; @@ -38,9 +43,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Encryption utility"; mainProgram = "scrypt"; - homepage = "https://www.tarsnap.com/scrypt.html"; - license = licenses.bsd2; - platforms = platforms.all; + homepage = "https://www.tarsnap.com/scrypt.html"; + license = licenses.bsd2; + platforms = platforms.all; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/by-name/sc/scsh/package.nix b/pkgs/by-name/sc/scsh/package.nix index 35fec3d2a2b504..d6d9d1a2ca22fb 100644 --- a/pkgs/by-name/sc/scsh/package.nix +++ b/pkgs/by-name/sc/scsh/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, scheme48, unstableGitUpdater }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + scheme48, + unstableGitUpdater, +}: stdenv.mkDerivation { pname = "scsh"; diff --git a/pkgs/by-name/sc/sct/package.nix b/pkgs/by-name/sc/sct/package.nix index 9bf1f6d89a1262..38bd267341b8d2 100644 --- a/pkgs/by-name/sc/sct/package.nix +++ b/pkgs/by-name/sc/sct/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchzip, libX11, libXrandr, xorgproto }: +{ + lib, + stdenv, + fetchzip, + libX11, + libXrandr, + xorgproto, +}: stdenv.mkDerivation rec { pname = "sct"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-nyYcdnCq8KcSUpc0HPCGzJI6NNrrTJLAHqPawfwPR/Q="; }; - buildInputs = [ libX11 libXrandr xorgproto ]; + buildInputs = [ + libX11 + libXrandr + xorgproto + ]; preInstall = '' mkdir -p $out/bin $out/share/man/man1 @@ -20,7 +31,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://www.umaxx.net/"; description = "Minimal utility to set display colour temperature"; - maintainers = with maintainers; [ raskin somasis ]; + maintainers = with maintainers; [ + raskin + somasis + ]; license = licenses.publicDomain; platforms = with platforms; linux ++ freebsd ++ openbsd; }; diff --git a/pkgs/by-name/sc/scudcloud/package.nix b/pkgs/by-name/sc/scudcloud/package.nix index 6f85141f22fe70..36764bdb7ab4af 100644 --- a/pkgs/by-name/sc/scudcloud/package.nix +++ b/pkgs/by-name/sc/scudcloud/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonPackage rec { pname = "scudcloud"; @@ -11,7 +15,11 @@ python3Packages.buildPythonPackage rec { sha256 = "1ffdy74igll74fwpmnn3brvcxbk4iianqscdzz18sx1pfqpw16cl"; }; - propagatedBuildInputs = with python3Packages; [ pyqt5-webkit dbus-python jsmin ]; + propagatedBuildInputs = with python3Packages; [ + pyqt5-webkit + dbus-python + jsmin + ]; meta = with lib; { description = "Non-official desktop client for Slack"; diff --git a/pkgs/by-name/sd/SDL2_Pango/package.nix b/pkgs/by-name/sd/SDL2_Pango/package.nix index 755c0a1af463f9..2746a5fe5d8289 100644 --- a/pkgs/by-name/sd/SDL2_Pango/package.nix +++ b/pkgs/by-name/sd/SDL2_Pango/package.nix @@ -27,15 +27,20 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - SDL2 - freetype - pango - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.libobjc - ]; + buildInputs = + [ + SDL2 + freetype + pango + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.libobjc + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; strictDeps = true; @@ -43,8 +48,7 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/markuskimius/SDL2_Pango"; description = "Library for graphically rendering internationalized and tagged text in SDL2 using TrueType fonts"; license = lib.licenses.lgpl21Plus; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ rardiol ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ rardiol ]); inherit (SDL2.meta) platforms; }; }) diff --git a/pkgs/by-name/sd/SDL2_gfx/package.nix b/pkgs/by-name/sd/SDL2_gfx/package.nix index b5a68c23e49b6e..4d6f6d77bbd7f1 100644 --- a/pkgs/by-name/sd/SDL2_gfx/package.nix +++ b/pkgs/by-name/sd/SDL2_gfx/package.nix @@ -1,4 +1,5 @@ -{ lib, +{ + lib, SDL2, darwin, fetchurl, @@ -24,14 +25,18 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - SDL2 - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.libobjc - ]; + buildInputs = + [ + SDL2 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.libobjc + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; configureFlags = [ (lib.enableFeature enableMmx "mmx") @@ -67,8 +72,7 @@ stdenv.mkDerivation (finalAttrs: { written in plain C and can be used in C++ code. ''; license = lib.licenses.zlib; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ ]); pkgConfigModules = [ "SDL2_gfx" ]; inherit (SDL2.meta) platforms; }; diff --git a/pkgs/by-name/sd/SDL2_image/package.nix b/pkgs/by-name/sd/SDL2_image/package.nix index 19028ab115a070..fac3b30056ad35 100644 --- a/pkgs/by-name/sd/SDL2_image/package.nix +++ b/pkgs/by-name/sd/SDL2_image/package.nix @@ -45,19 +45,21 @@ stdenv.mkDerivation (finalAttrs: { zlib ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Foundation ]; - configureFlags = [ - # Disable dynamically loaded dependencies - (lib.enableFeature false "jpg-shared") - (lib.enableFeature false "png-shared") - (lib.enableFeature false "tif-shared") - (lib.enableFeature false "webp-shared") - (lib.enableFeature enableSdltest "sdltest") - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # Don't use native macOS frameworks - # Caution: do not set this as (!stdenv.hostPlatform.isDarwin) since it would be true - # outside Darwin - and ImageIO does not exist outisde Darwin - (lib.enableFeature false "imageio") - ]; + configureFlags = + [ + # Disable dynamically loaded dependencies + (lib.enableFeature false "jpg-shared") + (lib.enableFeature false "png-shared") + (lib.enableFeature false "tif-shared") + (lib.enableFeature false "webp-shared") + (lib.enableFeature enableSdltest "sdltest") + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # Don't use native macOS frameworks + # Caution: do not set this as (!stdenv.hostPlatform.isDarwin) since it would be true + # outside Darwin - and ImageIO does not exist outisde Darwin + (lib.enableFeature false "imageio") + ]; strictDeps = true; diff --git a/pkgs/by-name/sd/SDL2_mixer/package.nix b/pkgs/by-name/sd/SDL2_mixer/package.nix index 27f9bc993371cb..766eab7d9b8e47 100644 --- a/pkgs/by-name/sd/SDL2_mixer/package.nix +++ b/pkgs/by-name/sd/SDL2_mixer/package.nix @@ -58,29 +58,31 @@ stdenv.mkDerivation (finalAttrs: { timidity ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; strictDeps = true; configureFlags = [ - (lib.enableFeature false "music-ogg-shared") - (lib.enableFeature false "music-flac-shared") - (lib.enableFeature false "music-mod-modplug-shared") - (lib.enableFeature false "music-mp3-mpg123-shared") - (lib.enableFeature false "music-opus-shared") - (lib.enableFeature false "music-midi-fluidsynth-shared") - (lib.enableFeature enableSdltest "sdltest") - (lib.enableFeature enableSmpegtest "smpegtest") - # override default path to allow MIDI files to be played - (lib.withFeatureAs true "timidity-cfg" "${timidity}/share/timidity/timidity.cfg") + (lib.enableFeature false "music-ogg-shared") + (lib.enableFeature false "music-flac-shared") + (lib.enableFeature false "music-mod-modplug-shared") + (lib.enableFeature false "music-mp3-mpg123-shared") + (lib.enableFeature false "music-opus-shared") + (lib.enableFeature false "music-midi-fluidsynth-shared") + (lib.enableFeature enableSdltest "sdltest") + (lib.enableFeature enableSmpegtest "smpegtest") + # override default path to allow MIDI files to be played + (lib.withFeatureAs true "timidity-cfg" "${timidity}/share/timidity/timidity.cfg") ]; meta = { homepage = "https://github.com/libsdl-org/SDL_mixer"; description = "SDL multi-channel audio mixer library"; license = lib.licenses.zlib; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ ]); platforms = lib.platforms.unix; }; }) diff --git a/pkgs/by-name/sd/SDL2_mixer_2_0/package.nix b/pkgs/by-name/sd/SDL2_mixer_2_0/package.nix index 9413b8dda96e6b..a886e85d5a9e1a 100644 --- a/pkgs/by-name/sd/SDL2_mixer_2_0/package.nix +++ b/pkgs/by-name/sd/SDL2_mixer_2_0/package.nix @@ -37,4 +37,5 @@ let passthru.tests.lzwolf = lzwolf; }; -in SDL2_mixer.overrideAttrs(_: attrset) +in +SDL2_mixer.overrideAttrs (_: attrset) diff --git a/pkgs/by-name/sd/SDL2_net/package.nix b/pkgs/by-name/sd/SDL2_net/package.nix index 0325e6aa4c1203..fb8d1eeedb3b55 100644 --- a/pkgs/by-name/sd/SDL2_net/package.nix +++ b/pkgs/by-name/sd/SDL2_net/package.nix @@ -20,7 +20,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-sEcKn/apA6FcR7ijb7sfuvP03ZdVfjkNZTXsasK8fAI="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ SDL2 @@ -44,8 +47,7 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/libsdl-org/SDL_net"; description = "SDL multiplatform networking library"; license = lib.licenses.zlib; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ ]); inherit (SDL2.meta) platforms; }; }) diff --git a/pkgs/by-name/sd/SDL2_sound/package.nix b/pkgs/by-name/sd/SDL2_sound/package.nix index 46517c42cb32bb..9ec2ec4e3cff94 100644 --- a/pkgs/by-name/sd/SDL2_sound/package.nix +++ b/pkgs/by-name/sd/SDL2_sound/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, cmake -, SDL2 -, flac -, libmikmod -, libvorbis -, timidity -, darwin +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, + SDL2, + flac, + libmikmod, + libvorbis, + timidity, + darwin, }: let inherit (darwin.apple_sdk.frameworks) AudioToolbox CoreAudio - ; + ; in stdenv.mkDerivation rec { pname = "SDL2_sound"; @@ -41,8 +42,18 @@ stdenv.mkDerivation rec { cmakeFlags = [ "-DSDLSOUND_DECODER_MIDI=1" ]; - buildInputs = [ SDL2 flac libmikmod libvorbis timidity ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ AudioToolbox CoreAudio ]; + buildInputs = + [ + SDL2 + flac + libmikmod + libvorbis + timidity + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AudioToolbox + CoreAudio + ]; meta = with lib; { description = "SDL2 sound library"; diff --git a/pkgs/by-name/sd/SDL2_ttf/package.nix b/pkgs/by-name/sd/SDL2_ttf/package.nix index dcc5fee21f33dc..93daeee6cbe30d 100644 --- a/pkgs/by-name/sd/SDL2_ttf/package.nix +++ b/pkgs/by-name/sd/SDL2_ttf/package.nix @@ -27,17 +27,18 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - SDL2 - freetype - harfbuzz - ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - libGL - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.libobjc - ]; + buildInputs = + [ + SDL2 + freetype + harfbuzz + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libGL + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.libobjc + ]; configureFlags = [ (lib.enableFeature false "harfbuzz-builtin") @@ -57,8 +58,7 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/libsdl-org/SDL_ttf"; description = "Support for TrueType (.ttf) font files with Simple Directmedia Layer"; license = lib.licenses.zlib; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ ]); inherit (SDL2.meta) platforms; pkgConfigModules = [ "SDL2_ttf" ]; }; diff --git a/pkgs/by-name/sd/SDL_Pango/package.nix b/pkgs/by-name/sd/SDL_Pango/package.nix index 78e5d40d0a90da..cfe8c5dd852bc4 100644 --- a/pkgs/by-name/sd/SDL_Pango/package.nix +++ b/pkgs/by-name/sd/SDL_Pango/package.nix @@ -50,8 +50,7 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://sdlpango.sourceforge.net/"; description = "Connects the Pango rendering engine to SDL"; license = lib.licenses.lgpl21Plus; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ puckipedia ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ puckipedia ]); inherit (SDL.meta) platforms; }; }) diff --git a/pkgs/by-name/sd/SDL_audiolib/package.nix b/pkgs/by-name/sd/SDL_audiolib/package.nix index af84b5c0d0dc5a..5e919d9ce3af75 100644 --- a/pkgs/by-name/sd/SDL_audiolib/package.nix +++ b/pkgs/by-name/sd/SDL_audiolib/package.nix @@ -52,8 +52,7 @@ stdenv.mkDerivation (finalAttrs: { description = "Audio decoding, resampling and mixing library for SDL"; homepage = "https://github.com/realnc/SDL_audiolib"; license = lib.licenses.lgpl3Plus; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ ]); inherit (SDL2.meta) platforms; }; }) diff --git a/pkgs/by-name/sd/SDL_compat/package.nix b/pkgs/by-name/sd/SDL_compat/package.nix index ac7d8ff68b81f8..561ca909cbf340 100644 --- a/pkgs/by-name/sd/SDL_compat/package.nix +++ b/pkgs/by-name/sd/SDL_compat/package.nix @@ -1,16 +1,17 @@ -{ lib -, SDL2 -, cmake -, darwin -, fetchFromGitHub -, libGLU -, libiconv -, mesa -, pkg-config -, stdenv -# Boolean flags -, libGLSupported ? lib.elem stdenv.hostPlatform.system mesa.meta.platforms -, openglSupport ? libGLSupported +{ + lib, + SDL2, + cmake, + darwin, + fetchFromGitHub, + libGLU, + libiconv, + mesa, + pkg-config, + stdenv, + # Boolean flags + libGLSupported ? lib.elem stdenv.hostPlatform.system mesa.meta.platforms, + openglSupport ? libGLSupported, }: let @@ -28,11 +29,21 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-f2dl3L7/qoYNl4sjik1npcW/W09zsEumiV9jHuKnUmM="; }; - nativeBuildInputs = [ cmake pkg-config ] - ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ autoSignDarwinBinariesHook ]; + nativeBuildInputs = + [ + cmake + pkg-config + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + autoSignDarwinBinariesHook + ]; - propagatedBuildInputs = [ SDL2 ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv Cocoa ] + propagatedBuildInputs = + [ SDL2 ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Cocoa + ] ++ lib.optionals openglSupport [ libGLU ]; enableParallelBuilding = true; @@ -42,11 +53,20 @@ stdenv.mkDerivation (finalAttrs: { postFixup = '' for lib in $out/lib/*${stdenv.hostPlatform.extensions.sharedLibrary}* ; do if [[ -L "$lib" ]]; then - ${if stdenv.hostPlatform.isDarwin then '' - install_name_tool ${lib.strings.concatMapStrings (x: " -add_rpath ${lib.makeLibraryPath [x]} ") finalAttrs.propagatedBuildInputs} "$lib" - '' else '' - patchelf --set-rpath "$(patchelf --print-rpath $lib):${lib.makeLibraryPath finalAttrs.propagatedBuildInputs}" "$lib" - ''} + ${ + if stdenv.hostPlatform.isDarwin then + '' + install_name_tool ${ + lib.strings.concatMapStrings ( + x: " -add_rpath ${lib.makeLibraryPath [ x ]} " + ) finalAttrs.propagatedBuildInputs + } "$lib" + '' + else + '' + patchelf --set-rpath "$(patchelf --print-rpath $lib):${lib.makeLibraryPath finalAttrs.propagatedBuildInputs}" "$lib" + '' + } fi done ''; diff --git a/pkgs/by-name/sd/SDL_gfx/package.nix b/pkgs/by-name/sd/SDL_gfx/package.nix index 5677d62b7b937a..a6044b31790f16 100644 --- a/pkgs/by-name/sd/SDL_gfx/package.nix +++ b/pkgs/by-name/sd/SDL_gfx/package.nix @@ -51,8 +51,7 @@ stdenv.mkDerivation (finalAttrs: { written in plain C and can be used in C++ code. ''; license = lib.licenses.zlib; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ ]); inherit (SDL.meta) platforms; }; }) diff --git a/pkgs/by-name/sd/SDL_mixer/package.nix b/pkgs/by-name/sd/SDL_mixer/package.nix index 84af162a738469..d1c96b7c0e1148 100644 --- a/pkgs/by-name/sd/SDL_mixer/package.nix +++ b/pkgs/by-name/sd/SDL_mixer/package.nix @@ -86,15 +86,17 @@ stdenv.mkDerivation (finalAttrs: { (lib.enableFeature enableSmpegtest "smpegtest") ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; strictDeps = true; meta = { description = "SDL multi-channel audio mixer library"; homepage = "http://www.libsdl.org/projects/SDL_mixer/"; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ ]); license = lib.licenses.zlib; inherit (SDL.meta) platforms; }; diff --git a/pkgs/by-name/sd/SDL_net/package.nix b/pkgs/by-name/sd/SDL_net/package.nix index 369f956fdf942b..125f68558f9171 100644 --- a/pkgs/by-name/sd/SDL_net/package.nix +++ b/pkgs/by-name/sd/SDL_net/package.nix @@ -5,7 +5,7 @@ pkg-config, stdenv, # Boolean flags - enableSdltest ? (!stdenv.hostPlatform.isDarwin) + enableSdltest ? (!stdenv.hostPlatform.isDarwin), }: stdenv.mkDerivation (finalAttrs: { @@ -36,8 +36,7 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/libsdl-org/SDL_net"; description = "SDL networking library"; license = lib.licenses.zlib; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ ]); inherit (SDL.meta) platforms; }; }) diff --git a/pkgs/by-name/sd/SDL_sixel/package.nix b/pkgs/by-name/sd/SDL_sixel/package.nix index c4e383183bec10..5232b0080cf507 100644 --- a/pkgs/by-name/sd/SDL_sixel/package.nix +++ b/pkgs/by-name/sd/SDL_sixel/package.nix @@ -32,8 +32,7 @@ stdenv.mkDerivation { description = "SDL 1.2 patched with libsixel support"; license = lib.licenses.lgpl21; mainProgram = "sdl-config"; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ ]); platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/sd/SDL_sound/package.nix b/pkgs/by-name/sd/SDL_sound/package.nix index 33a15ff71b6876..2c32e32960da65 100644 --- a/pkgs/by-name/sd/SDL_sound/package.nix +++ b/pkgs/by-name/sd/SDL_sound/package.nix @@ -7,7 +7,7 @@ libvorbis, stdenv, # Boolean flags - enableSdltest ? (!stdenv.hostPlatform.isDarwin) + enableSdltest ? (!stdenv.hostPlatform.isDarwin), }: stdenv.mkDerivation (finalAttrs: { @@ -40,8 +40,7 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.icculus.org/SDL_sound/"; description = "SDL sound library"; license = lib.licenses.lgpl21Plus; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ ]); mainProgram = "playsound"; inherit (SDL.meta) platforms; }; diff --git a/pkgs/by-name/sd/SDL_ttf/package.nix b/pkgs/by-name/sd/SDL_ttf/package.nix index 2617f8e28eff7c..d243dc90ab122c 100644 --- a/pkgs/by-name/sd/SDL_ttf/package.nix +++ b/pkgs/by-name/sd/SDL_ttf/package.nix @@ -48,8 +48,7 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/libsdl-org/SDL_ttf"; description = "SDL TrueType library"; license = lib.licenses.zlib; - maintainers = lib.teams.sdl.members - ++ (with lib.maintainers; [ ]); + maintainers = lib.teams.sdl.members ++ (with lib.maintainers; [ ]); inherit (SDL.meta) platforms; }; }) diff --git a/pkgs/by-name/sd/sd-local/package.nix b/pkgs/by-name/sd/sd-local/package.nix index ea9bf5e4d6c264..bf8e34fbb382f8 100644 --- a/pkgs/by-name/sd/sd-local/package.nix +++ b/pkgs/by-name/sd/sd-local/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "sd-local"; diff --git a/pkgs/by-name/sd/sd-mux-ctrl/package.nix b/pkgs/by-name/sd/sd-mux-ctrl/package.nix index 28916ed78045b2..1458f5635c1529 100644 --- a/pkgs/by-name/sd/sd-mux-ctrl/package.nix +++ b/pkgs/by-name/sd/sd-mux-ctrl/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchgit, cmake, pkg-config, installShellFiles, libftdi1, popt}: +{ + lib, + stdenv, + fetchgit, + cmake, + pkg-config, + installShellFiles, + libftdi1, + popt, +}: stdenv.mkDerivation rec { pname = "sd-mux-ctrl-unstable"; @@ -10,9 +19,16 @@ stdenv.mkDerivation rec { hash = "sha256-b0uoxVPfSrqNt0wJoQho9jlpQQUjofgFm93P+UNFtDs="; }; - nativeBuildInputs = [ cmake pkg-config installShellFiles ]; + nativeBuildInputs = [ + cmake + pkg-config + installShellFiles + ]; - buildInputs = [ libftdi1 popt ]; + buildInputs = [ + libftdi1 + popt + ]; postInstall = '' install -D -m 644 ../doc/man/sd-mux-ctrl.1 $out/share/man/man1/sd-mux-ctrl.1 @@ -24,7 +40,10 @@ stdenv.mkDerivation rec { description = "Tool for controlling multiple sd-mux devices"; homepage = "https://git.tizen.org/cgit/tools/testlab/sd-mux"; license = licenses.asl20; - maintainers = with maintainers; [ newam sarcasticadmin ]; + maintainers = with maintainers; [ + newam + sarcasticadmin + ]; platforms = platforms.unix; mainProgram = "sd-mux-ctrl"; }; diff --git a/pkgs/by-name/sd/sd-switch/package.nix b/pkgs/by-name/sd/sd-switch/package.nix index f14595d655be45..b2137c12e3ef8f 100644 --- a/pkgs/by-name/sd/sd-switch/package.nix +++ b/pkgs/by-name/sd/sd-switch/package.nix @@ -1,7 +1,14 @@ -{ lib, fetchFromSourcehut, rustPlatform, nix-update-script }: +{ + lib, + fetchFromSourcehut, + rustPlatform, + nix-update-script, +}: -let version = "0.5.1"; -in rustPlatform.buildRustPackage { +let + version = "0.5.1"; +in +rustPlatform.buildRustPackage { pname = "sd-switch"; inherit version; diff --git a/pkgs/by-name/sd/sdat2img/package.nix b/pkgs/by-name/sd/sdat2img/package.nix index 93493356eb5124..6ddcf6e85bbd9b 100644 --- a/pkgs/by-name/sd/sdat2img/package.nix +++ b/pkgs/by-name/sd/sdat2img/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication { pname = "sdat2img"; diff --git a/pkgs/by-name/sd/sdate/package.nix b/pkgs/by-name/sd/sdate/package.nix index 71ab04c807d8a5..dea6aa1ed3ee3b 100644 --- a/pkgs/by-name/sd/sdate/package.nix +++ b/pkgs/by-name/sd/sdate/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "sdate"; diff --git a/pkgs/by-name/sd/sdcc/package.nix b/pkgs/by-name/sd/sdcc/package.nix index e8c20ac045c309..e90b3b00ff38e9 100644 --- a/pkgs/by-name/sd/sdcc/package.nix +++ b/pkgs/by-name/sd/sdcc/package.nix @@ -1,21 +1,35 @@ -{ lib -, stdenv -, fetchurl -, autoconf -, bison -, boost -, flex -, gputils -, texinfo -, zlib -, withGputils ? false -, excludePorts ? [] +{ + lib, + stdenv, + fetchurl, + autoconf, + bison, + boost, + flex, + gputils, + texinfo, + zlib, + withGputils ? false, + excludePorts ? [ ], }: -assert lib.subtractLists [ - "ds390" "ds400" "gbz80" "hc08" "mcs51" "pic14" "pic16" "r2k" "r3ka" "s08" - "stm8" "tlcs90" "z80" "z180" -] excludePorts == []; +assert + lib.subtractLists [ + "ds390" + "ds400" + "gbz80" + "hc08" + "mcs51" + "pic14" + "pic16" + "r2k" + "r3ka" + "s08" + "stm8" + "tlcs90" + "z80" + "z180" + ] excludePorts == [ ]; stdenv.mkDerivation (finalAttrs: { pname = "sdcc"; version = "4.4.0"; @@ -25,7 +39,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-rowSFl6xdoDf9EsyjYh5mWMGtyQe+jqDsuOy0veQanU="; }; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; enableParallelBuilding = true; @@ -35,18 +53,25 @@ stdenv.mkDerivation (finalAttrs: { flex ]; - buildInputs = [ - boost - texinfo - zlib - ] ++ lib.optionals withGputils [ - gputils - ]; + buildInputs = + [ + boost + texinfo + zlib + ] + ++ lib.optionals withGputils [ + gputils + ]; - configureFlags = let - excludedPorts = excludePorts - ++ (lib.optionals (!withGputils) [ "pic14" "pic16" ]); - in + configureFlags = + let + excludedPorts = + excludePorts + ++ (lib.optionals (!withGputils) [ + "pic14" + "pic16" + ]); + in map (f: "--disable-${f}-port") excludedPorts; preConfigure = '' @@ -66,11 +91,12 @@ stdenv.mkDerivation (finalAttrs: { 2000/3000, Rabbit 3000A). Work is in progress on supporting the Microchip PIC16 and PIC18 targets. It can be retargeted for other microprocessors. ''; - license = if withGputils - then lib.licenses.unfreeRedistributable - else lib.licenses.gpl2Plus; + license = if withGputils then lib.licenses.unfreeRedistributable else lib.licenses.gpl2Plus; mainProgram = "sdcc"; - maintainers = with lib.maintainers; [ bjornfor yorickvp ]; + maintainers = with lib.maintainers; [ + bjornfor + yorickvp + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/by-name/sd/sdcv/package.nix b/pkgs/by-name/sd/sdcv/package.nix index a4a890f9c7ba1f..e1773891ed8dcd 100644 --- a/pkgs/by-name/sd/sdcv/package.nix +++ b/pkgs/by-name/sd/sdcv/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, glib, gettext, readline }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + glib, + gettext, + readline, +}: stdenv.mkDerivation rec { pname = "sdcv"; @@ -12,8 +21,15 @@ stdenv.mkDerivation rec { }; hardeningDisable = [ "format" ]; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ glib gettext readline ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + glib + gettext + readline + ]; postPatch = '' # https://github.com/Dushistov/sdcv/pull/104 diff --git a/pkgs/by-name/sd/sdl-jstest/package.nix b/pkgs/by-name/sd/sdl-jstest/package.nix index 5b71e441b8782c..2d2bd48387a3f0 100644 --- a/pkgs/by-name/sd/sdl-jstest/package.nix +++ b/pkgs/by-name/sd/sdl-jstest/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, SDL, SDL2, ncurses, docbook_xsl, git }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + SDL, + SDL2, + ncurses, + docbook_xsl, + git, +}: stdenv.mkDerivation { pname = "sdl-jstest"; @@ -12,8 +23,17 @@ stdenv.mkDerivation { fetchSubmodules = true; }; - buildInputs = [ SDL SDL2 ncurses ]; - nativeBuildInputs = [ cmake pkg-config docbook_xsl git ]; + buildInputs = [ + SDL + SDL2 + ncurses + ]; + nativeBuildInputs = [ + cmake + pkg-config + docbook_xsl + git + ]; meta = with lib; { homepage = "https://github.com/Grumbel/sdl-jstest"; diff --git a/pkgs/by-name/sd/sdlookup/package.nix b/pkgs/by-name/sd/sdlookup/package.nix index d4b4e6b3ad5452..9b41119a581267 100644 --- a/pkgs/by-name/sd/sdlookup/package.nix +++ b/pkgs/by-name/sd/sdlookup/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/sd/sdlpop/package.nix b/pkgs/by-name/sd/sdlpop/package.nix index 5defb942e7e9a4..e79cf801c28d60 100644 --- a/pkgs/by-name/sd/sdlpop/package.nix +++ b/pkgs/by-name/sd/sdlpop/package.nix @@ -1,9 +1,13 @@ -{ lib, stdenv -, makeWrapper -, makeDesktopItem, copyDesktopItems -, fetchFromGitHub -, pkg-config -, SDL2, SDL2_image +{ + lib, + stdenv, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + fetchFromGitHub, + pkg-config, + SDL2, + SDL2_image, }: stdenv.mkDerivation rec { @@ -17,11 +21,21 @@ stdenv.mkDerivation rec { sha256 = "sha256-UI7NfOC/+druRYL5g2AhIjTPEq4ta1qEThcxgyrFjHY="; }; - nativeBuildInputs = [ pkg-config makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + copyDesktopItems + ]; - buildInputs = [ SDL2 SDL2_image ]; + buildInputs = [ + SDL2 + SDL2_image + ]; - makeFlags = [ "-C" "src" ]; + makeFlags = [ + "-C" + "src" + ]; preBuild = '' substituteInPlace src/Makefile \ @@ -51,14 +65,19 @@ stdenv.mkDerivation rec { runHook postInstall ''; - desktopItems = [ (makeDesktopItem { - name = "sdlpop"; - icon = "sdlpop"; - exec = "prince"; - desktopName = "SDLPoP"; - comment = "An open-source port of Prince of Persia"; - categories = [ "Game" "AdventureGame" ]; - }) ]; + desktopItems = [ + (makeDesktopItem { + name = "sdlpop"; + icon = "sdlpop"; + exec = "prince"; + desktopName = "SDLPoP"; + comment = "An open-source port of Prince of Persia"; + categories = [ + "Game" + "AdventureGame" + ]; + }) + ]; meta = with lib; { description = "Open-source port of Prince of Persia"; diff --git a/pkgs/by-name/sd/sdparm/package.nix b/pkgs/by-name/sd/sdparm/package.nix index 2bd1a0946674ee..e6908ff96fad35 100644 --- a/pkgs/by-name/sd/sdparm/package.nix +++ b/pkgs/by-name/sd/sdparm/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "sdparm"; diff --git a/pkgs/by-name/sd/sdrplay/package.nix b/pkgs/by-name/sd/sdrplay/package.nix index b3259412da244e..c3532f5fe4eaf9 100644 --- a/pkgs/by-name/sd/sdrplay/package.nix +++ b/pkgs/by-name/sd/sdrplay/package.nix @@ -1,10 +1,21 @@ -{ stdenv, lib, fetchurl, autoPatchelfHook, udev, libusb1 }: +{ + stdenv, + lib, + fetchurl, + autoPatchelfHook, + udev, + libusb1, +}: let arch = - if stdenv.hostPlatform.isx86_64 then "x86_64" - else if stdenv.hostPlatform.isi686 then "i686" - else if stdenv.hostPlatform.isAarch64 then "aarch64" - else throw "unsupported architecture"; + if stdenv.hostPlatform.isx86_64 then + "x86_64" + else if stdenv.hostPlatform.isi686 then + "i686" + else if stdenv.hostPlatform.isAarch64 then + "aarch64" + else + throw "unsupported architecture"; version = "3.07.1"; @@ -30,7 +41,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoPatchelfHook ]; - buildInputs = [ libusb1 udev (lib.getLib stdenv.cc.cc) ]; + buildInputs = [ + libusb1 + udev + (lib.getLib stdenv.cc.cc) + ]; unpackPhase = '' sh "$src" --noexec --target source @@ -62,7 +77,10 @@ stdenv.mkDerivation rec { homepage = "https://www.sdrplay.com/downloads/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - maintainers = with maintainers; [ pmenke zaninime ]; + maintainers = with maintainers; [ + pmenke + zaninime + ]; platforms = platforms.linux; mainProgram = "sdrplay_apiService"; }; diff --git a/pkgs/by-name/se/sea-orm-cli/package.nix b/pkgs/by-name/se/sea-orm-cli/package.nix index d191944289d350..4a2b9a31df1a71 100644 --- a/pkgs/by-name/se/sea-orm-cli/package.nix +++ b/pkgs/by-name/se/sea-orm-cli/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, rustPlatform -, fetchCrate -, pkg-config -, openssl -, darwin +{ + lib, + stdenv, + rustPlatform, + fetchCrate, + pkg-config, + openssl, + darwin, }: rustPlatform.buildRustPackage rec { pname = "sea-orm-cli"; @@ -17,15 +18,19 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; + buildInputs = [ + openssl + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; cargoHash = "sha256-r5nqzu79z/XdrqvaJ+5ylZI6tC/SKTzmoOSgkbAaPn4="; meta = with lib; { homepage = "https://www.sea-ql.org/SeaORM"; description = " Command line utility for SeaORM"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ traxys ]; }; } diff --git a/pkgs/by-name/se/seabird/package.nix b/pkgs/by-name/se/seabird/package.nix index b364c52b482353..5c9ff436fe6cc8 100644 --- a/pkgs/by-name/se/seabird/package.nix +++ b/pkgs/by-name/se/seabird/package.nix @@ -1,15 +1,16 @@ -{ lib -, buildGoModule -, copyDesktopItems -, fetchFromGitHub -, pkg-config -, wrapGAppsHook4 -, gobject-introspection -, gtk4 -, gtksourceview5 -, libadwaita -, libxml2 -, vte-gtk4 +{ + lib, + buildGoModule, + copyDesktopItems, + fetchFromGitHub, + pkg-config, + wrapGAppsHook4, + gobject-introspection, + gtk4, + gtksourceview5, + libadwaita, + libxml2, + vte-gtk4, }: buildGoModule rec { @@ -40,7 +41,10 @@ buildGoModule rec { vte-gtk4 ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/se/seafile-shared/package.nix b/pkgs/by-name/se/seafile-shared/package.nix index dd4cafbfc8b6be..4e9f5c40d3f329 100644 --- a/pkgs/by-name/se/seafile-shared/package.nix +++ b/pkgs/by-name/se/seafile-shared/package.nix @@ -1,15 +1,17 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, curl -, libevent -, libsearpc -, libuuid -, pkg-config -, python3 -, sqlite -, vala -, libwebsockets +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + curl, + libevent, + libsearpc, + libuuid, + pkg-config, + python3, + sqlite, + vala, + libwebsockets, }: stdenv.mkDerivation rec { @@ -59,6 +61,9 @@ stdenv.mkDerivation rec { description = "Shared components of Seafile: seafile-daemon, libseafile, libseafile python bindings, manuals, and icons"; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ greizgh schmittlauch ]; + maintainers = with maintainers; [ + greizgh + schmittlauch + ]; }; } diff --git a/pkgs/by-name/se/seahorse/package.nix b/pkgs/by-name/se/seahorse/package.nix index 832bca687d0729..1abdef69c7345e 100644 --- a/pkgs/by-name/se/seahorse/package.nix +++ b/pkgs/by-name/se/seahorse/package.nix @@ -1,30 +1,31 @@ -{ stdenv -, lib -, fetchurl -, vala -, meson -, ninja -, libpwquality -, pkg-config -, gtk3 -, glib -, glib-networking -, wrapGAppsHook3 -, itstool -, gnupg -, desktop-file-utils -, libsoup_3 -, gnome -, gpgme -, python3 -, openldap -, gcr -, libsecret -, avahi -, p11-kit -, openssh -, gsettings-desktop-schemas -, libhandy +{ + stdenv, + lib, + fetchurl, + vala, + meson, + ninja, + libpwquality, + pkg-config, + gtk3, + glib, + glib-networking, + wrapGAppsHook3, + itstool, + gnupg, + desktop-file-utils, + libsoup_3, + gnome, + gpgme, + python3, + openldap, + gcr, + libsecret, + avahi, + p11-kit, + openssh, + gsettings-desktop-schemas, + libhandy, }: stdenv.mkDerivation rec { @@ -72,13 +73,15 @@ stdenv.mkDerivation rec { patchShebangs build-aux/gpg_check_version.py ''; - env = lib.optionalAttrs (stdenv.cc.isGNU && (lib.versionAtLeast (lib.getVersion stdenv.cc.cc) "14")) { - NIX_CFLAGS_COMPILE = toString [ - "-Wno-error=implicit-function-declaration" - "-Wno-error=int-conversion" - "-Wno-error=return-mismatch" - ]; - }; + env = + lib.optionalAttrs (stdenv.cc.isGNU && (lib.versionAtLeast (lib.getVersion stdenv.cc.cc) "14")) + { + NIX_CFLAGS_COMPILE = toString [ + "-Wno-error=implicit-function-declaration" + "-Wno-error=int-conversion" + "-Wno-error=return-mismatch" + ]; + }; preCheck = '' # Add “org.gnome.crypto.pgp” GSettings schema to path diff --git a/pkgs/by-name/se/searxng/package.nix b/pkgs/by-name/se/searxng/package.nix index cd77009da8ea5b..2af550d7c23ea1 100644 --- a/pkgs/by-name/se/searxng/package.nix +++ b/pkgs/by-name/se/searxng/package.nix @@ -2,7 +2,7 @@ lib, python3, fetchFromGitHub, - nixosTests + nixosTests, }: python3.pkgs.toPythonModule ( diff --git a/pkgs/by-name/se/seashells/package.nix b/pkgs/by-name/se/seashells/package.nix index c928bca8cefbdd..c190a458fbce92 100644 --- a/pkgs/by-name/se/seashells/package.nix +++ b/pkgs/by-name/se/seashells/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "seashells"; diff --git a/pkgs/by-name/se/seasocks/package.nix b/pkgs/by-name/se/seasocks/package.nix index 96db323f90a7c0..34bb25e5704e67 100644 --- a/pkgs/by-name/se/seasocks/package.nix +++ b/pkgs/by-name/se/seasocks/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, python3, zlib, catch2 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, + zlib, + catch2, +}: stdenv.mkDerivation rec { pname = "seasocks"; @@ -16,7 +24,10 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ cmake ]; - buildInputs = [ zlib python3 ]; + buildInputs = [ + zlib + python3 + ]; doCheck = true; diff --git a/pkgs/by-name/se/seatd/package.nix b/pkgs/by-name/se/seatd/package.nix index b47e6bc4619936..d9197f5dafdc4d 100644 --- a/pkgs/by-name/se/seatd/package.nix +++ b/pkgs/by-name/se/seatd/package.nix @@ -1,12 +1,14 @@ -{ fetchFromSourcehut -, lib -, meson -, ninja -, pkg-config -, scdoc -, stdenv -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, systemd -, nixosTests +{ + fetchFromSourcehut, + lib, + meson, + ninja, + pkg-config, + scdoc, + stdenv, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { @@ -20,7 +22,12 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-6F+TPSpcEwX4wW5GPy5Ck2AeHyH/Ba2oBUSUnVyAMeA="; }; - outputs = [ "bin" "out" "dev" "man" ]; + outputs = [ + "bin" + "out" + "dev" + "man" + ]; depsBuildBuild = [ pkg-config diff --git a/pkgs/by-name/se/seaview/package.nix b/pkgs/by-name/se/seaview/package.nix index 06549748018d6a..927489cabcdd2a 100644 --- a/pkgs/by-name/se/seaview/package.nix +++ b/pkgs/by-name/se/seaview/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, coreutils, fltk, libjpeg }: +{ + lib, + stdenv, + fetchurl, + coreutils, + fltk, + libjpeg, +}: stdenv.mkDerivation rec { version = "5.0.5"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-zo9emLpHiDv6kekbx55NOibxWN2Zg7XngzGkUqSx+PI="; }; - buildInputs = [ fltk libjpeg ]; + buildInputs = [ + fltk + libjpeg + ]; patchPhase = "sed -i 's#PATH=/bin:/usr/bin rm#'${coreutils}/bin/rm'#' seaview.cxx"; installPhase = "mkdir -p $out/bin; cp seaview $out/bin"; diff --git a/pkgs/by-name/se/seaweedfs/package.nix b/pkgs/by-name/se/seaweedfs/package.nix index 934dd431ed8935..2c7b531854fbd4 100644 --- a/pkgs/by-name/se/seaweedfs/package.nix +++ b/pkgs/by-name/se/seaweedfs/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, testers -, seaweedfs +{ + lib, + fetchFromGitHub, + buildGoModule, + testers, + seaweedfs, }: buildGoModule rec { @@ -54,7 +55,11 @@ buildGoModule rec { meta = with lib; { description = "Simple and highly scalable distributed file system"; homepage = "https://github.com/chrislusf/seaweedfs"; - maintainers = with maintainers; [ azahi cmacrae wozeparrot ]; + maintainers = with maintainers; [ + azahi + cmacrae + wozeparrot + ]; mainProgram = "weed"; license = licenses.asl20; }; diff --git a/pkgs/by-name/se/sec/package.nix b/pkgs/by-name/se/sec/package.nix index 8a1f83ba67933c..96c9192eacf601 100644 --- a/pkgs/by-name/se/sec/package.nix +++ b/pkgs/by-name/se/sec/package.nix @@ -1,4 +1,9 @@ -{ fetchFromGitHub, perl, lib, stdenv }: +{ + fetchFromGitHub, + perl, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "sec"; diff --git a/pkgs/by-name/se/seccure/package.nix b/pkgs/by-name/se/seccure/package.nix index 07c8d0382ca5b4..4c51a81fc34fd3 100644 --- a/pkgs/by-name/se/seccure/package.nix +++ b/pkgs/by-name/se/seccure/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libgcrypt }: +{ + lib, + stdenv, + fetchurl, + libgcrypt, +}: stdenv.mkDerivation rec { pname = "seccure"; diff --git a/pkgs/by-name/se/seclists/package.nix b/pkgs/by-name/se/seclists/package.nix index f16eb981f10953..b38841e4418e58 100644 --- a/pkgs/by-name/se/seclists/package.nix +++ b/pkgs/by-name/se/seclists/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, stdenvNoCC +{ + lib, + fetchFromGitHub, + stdenvNoCC, }: stdenvNoCC.mkDerivation { @@ -28,7 +29,9 @@ stdenvNoCC.mkDerivation { description = "Collection of multiple types of lists used during security assessments, collected in one place"; homepage = "https://github.com/danielmiessler/seclists"; license = licenses.mit; - maintainers = with maintainers; [ tochiaha pamplemousse ]; + maintainers = with maintainers; [ + tochiaha + pamplemousse + ]; }; } - diff --git a/pkgs/by-name/se/secp256k1/package.nix b/pkgs/by-name/se/secp256k1/package.nix index 1da8079995fee1..aacba81c732c56 100644 --- a/pkgs/by-name/se/secp256k1/package.nix +++ b/pkgs/by-name/se/secp256k1/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/se/secrets-extractor/package.nix b/pkgs/by-name/se/secrets-extractor/package.nix index b8118e6cf95cea..338df990aadb80 100644 --- a/pkgs/by-name/se/secrets-extractor/package.nix +++ b/pkgs/by-name/se/secrets-extractor/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, libpcap +{ + lib, + buildGoModule, + fetchFromGitHub, + libpcap, }: buildGoModule rec { diff --git a/pkgs/by-name/se/secretscanner/package.nix b/pkgs/by-name/se/secretscanner/package.nix index db23b87058f418..330afcda9324a6 100644 --- a/pkgs/by-name/se/secretscanner/package.nix +++ b/pkgs/by-name/se/secretscanner/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, hyperscan -, pkg-config -, protobuf -, protoc-gen-go -, protoc-gen-go-grpc +{ + lib, + buildGoModule, + fetchFromGitHub, + hyperscan, + pkg-config, + protobuf, + protoc-gen-go, + protoc-gen-go-grpc, }: buildGoModule rec { @@ -56,4 +57,3 @@ buildGoModule rec { maintainers = with maintainers; [ fab ]; }; } - diff --git a/pkgs/by-name/se/sedutil/package.nix b/pkgs/by-name/se/sedutil/package.nix index 0e83472da0e706..5b731b96206921 100644 --- a/pkgs/by-name/se/sedutil/package.nix +++ b/pkgs/by-name/se/sedutil/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/se/see/package.nix b/pkgs/by-name/se/see/package.nix index f2c68cca97c412..256f34461a33e9 100644 --- a/pkgs/by-name/se/see/package.nix +++ b/pkgs/by-name/se/see/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchFromGitHub }: +{ + lib, + python3, + fetchFromGitHub, +}: python3.pkgs.buildPythonApplication { pname = "see"; diff --git a/pkgs/by-name/se/seehecht/package.nix b/pkgs/by-name/se/seehecht/package.nix index 0b1fb3bcef72db..c40578d7f950ea 100644 --- a/pkgs/by-name/se/seehecht/package.nix +++ b/pkgs/by-name/se/seehecht/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitea }: +{ + lib, + rustPlatform, + fetchFromGitea, +}: rustPlatform.buildRustPackage rec { pname = "seehecht"; diff --git a/pkgs/by-name/se/segger-jlink/package.nix b/pkgs/by-name/se/segger-jlink/package.nix index a092097bce3bc1..a0db9726edcc9c 100644 --- a/pkgs/by-name/se/segger-jlink/package.nix +++ b/pkgs/by-name/se/segger-jlink/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, callPackage -, autoPatchelfHook -, udev -, config -, acceptLicense ? config.segger-jlink.acceptLicense or false -, headless ? false -, makeDesktopItem -, copyDesktopItems +{ + lib, + stdenv, + fetchurl, + callPackage, + autoPatchelfHook, + udev, + config, + acceptLicense ? config.segger-jlink.acceptLicense or false, + headless ? false, + makeDesktopItem, + copyDesktopItems, }: let source = import ./source.nix; - supported = removeAttrs source ["version"]; + supported = removeAttrs source [ "version" ]; platform = supported.${stdenv.system} or (throw "unsupported platform ${stdenv.system}"); @@ -22,45 +23,50 @@ let url = "https://www.segger.com/downloads/jlink/JLink_Linux_V${version}_${platform.name}.tgz"; src = - assert !acceptLicense -> throw '' - Use of the "SEGGER JLink Software and Documentation pack" requires the - acceptance of the following licenses: - - - SEGGER Downloads Terms of Use [1] - - SEGGER Software Licensing [2] - - You can express acceptance by setting acceptLicense to true in your - configuration. Note that this is not a free license so it requires allowing - unfree licenses as well. - - configuration.nix: - nixpkgs.config.allowUnfree = true; - nixpkgs.config.segger-jlink.acceptLicense = true; - - config.nix: - allowUnfree = true; - segger-jlink.acceptLicense = true; - - [1]: ${url} - [2]: https://www.segger.com/purchase/licensing/ - ''; - fetchurl { - inherit url; - inherit (platform) hash; - curlOpts = "--data accept_license_agreement=accepted"; - }; + assert + !acceptLicense + -> throw '' + Use of the "SEGGER JLink Software and Documentation pack" requires the + acceptance of the following licenses: + + - SEGGER Downloads Terms of Use [1] + - SEGGER Software Licensing [2] + + You can express acceptance by setting acceptLicense to true in your + configuration. Note that this is not a free license so it requires allowing + unfree licenses as well. + + configuration.nix: + nixpkgs.config.allowUnfree = true; + nixpkgs.config.segger-jlink.acceptLicense = true; + + config.nix: + allowUnfree = true; + segger-jlink.acceptLicense = true; + + [1]: ${url} + [2]: https://www.segger.com/purchase/licensing/ + ''; + fetchurl { + inherit url; + inherit (platform) hash; + curlOpts = "--data accept_license_agreement=accepted"; + }; qt4-bundled = callPackage ./qt4-bundled.nix { inherit src version; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "segger-jlink"; inherit src version; - nativeBuildInputs = [ - autoPatchelfHook - ] ++ lib.optionals (!headless) [ - copyDesktopItems - ]; + nativeBuildInputs = + [ + autoPatchelfHook + ] + ++ lib.optionals (!headless) [ + copyDesktopItems + ]; buildInputs = lib.optionals (!headless) [ qt4-bundled @@ -75,32 +81,35 @@ in stdenv.mkDerivation { dontBuild = true; desktopItems = lib.optionals (!headless) ( - map (entry: - (makeDesktopItem { - name = entry; - exec = entry; - icon = "applications-utilities"; - desktopName = entry; - genericName = "SEGGER ${entry}"; - categories = [ "Development" ]; - type = "Application"; - terminal = false; - startupNotify = false; - }) - ) [ - "JFlash" - "JFlashLite" - "JFlashSPI" - "JLinkConfig" - "JLinkGDBServer" - "JLinkLicenseManager" - "JLinkRTTViewer" - "JLinkRegistration" - "JLinkRemoteServer" - "JLinkSWOViewer" - "JLinkUSBWebServer" - "JMem" - ] + map + ( + entry: + (makeDesktopItem { + name = entry; + exec = entry; + icon = "applications-utilities"; + desktopName = entry; + genericName = "SEGGER ${entry}"; + categories = [ "Development" ]; + type = "Application"; + terminal = false; + startupNotify = false; + }) + ) + [ + "JFlash" + "JFlashLite" + "JFlashSPI" + "JLinkConfig" + "JLinkGDBServer" + "JLinkLicenseManager" + "JLinkRTTViewer" + "JLinkRegistration" + "JLinkRemoteServer" + "JLinkSWOViewer" + "JLinkUSBWebServer" + "JMem" + ] ); installPhase = '' diff --git a/pkgs/by-name/se/segger-jlink/qt4-bundled.nix b/pkgs/by-name/se/segger-jlink/qt4-bundled.nix index 76fb252afe251f..a26145cc5f1fff 100644 --- a/pkgs/by-name/se/segger-jlink/qt4-bundled.nix +++ b/pkgs/by-name/se/segger-jlink/qt4-bundled.nix @@ -1,11 +1,11 @@ { - lib -, stdenv -, src -, version -, autoPatchelfHook -, fontconfig -, xorg + lib, + stdenv, + src, + version, + autoPatchelfHook, + fontconfig, + xorg, }: stdenv.mkDerivation { @@ -71,4 +71,3 @@ stdenv.mkDerivation { ]; }; } - diff --git a/pkgs/by-name/se/segger-ozone/package.nix b/pkgs/by-name/se/segger-ozone/package.nix index ea8ddd53c09f4e..b8a177e09e6e84 100644 --- a/pkgs/by-name/se/segger-ozone/package.nix +++ b/pkgs/by-name/se/segger-ozone/package.nix @@ -1,32 +1,39 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, fontconfig -, freetype -, libICE -, libSM -, libX11 -, libXcursor -, libXfixes -, libXrandr -, libXrender +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + fontconfig, + freetype, + libICE, + libSM, + libX11, + libXcursor, + libXfixes, + libXrandr, + libXrender, }: stdenv.mkDerivation rec { pname = "segger-ozone"; version = "3.30b"; - src = { - x86_64-linux = fetchurl { - url = "https://www.segger.com/downloads/jlink/Ozone_Linux_V${builtins.replaceStrings ["."] [""] version}_x86_64.tgz"; - hash = "sha256-W8Fo0q58pAn1aB92CjYARcN3vMLEguvsyozsS7VRArQ="; - }; - i686-linux = fetchurl { - url = "https://www.segger.com/downloads/jlink/Ozone_Linux_V${builtins.replaceStrings ["."] [""] version}_i386.tgz"; - hash = "sha256-Xq/69lwF2Ll5VdkYMDNRtc0YUUvWc+XR0FHJXxOLNQ4="; - }; - }.${stdenv.hostPlatform.system} or (throw "unsupported system: ${stdenv.hostPlatform.system}"); + src = + { + x86_64-linux = fetchurl { + url = "https://www.segger.com/downloads/jlink/Ozone_Linux_V${ + builtins.replaceStrings [ "." ] [ "" ] version + }_x86_64.tgz"; + hash = "sha256-W8Fo0q58pAn1aB92CjYARcN3vMLEguvsyozsS7VRArQ="; + }; + i686-linux = fetchurl { + url = "https://www.segger.com/downloads/jlink/Ozone_Linux_V${ + builtins.replaceStrings [ "." ] [ "" ] version + }_i386.tgz"; + hash = "sha256-Xq/69lwF2Ll5VdkYMDNRtc0YUUvWc+XR0FHJXxOLNQ4="; + }; + } + .${stdenv.hostPlatform.system} or (throw "unsupported system: ${stdenv.hostPlatform.system}"); nativeBuildInputs = [ autoPatchelfHook @@ -82,6 +89,9 @@ stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; maintainers = [ maintainers.bmilanov ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/by-name/se/seilfahrt/package.nix b/pkgs/by-name/se/seilfahrt/package.nix index db7afebe6e0029..380498612a8a5f 100644 --- a/pkgs/by-name/se/seilfahrt/package.nix +++ b/pkgs/by-name/se/seilfahrt/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, pandoc +{ + lib, + buildGoModule, + fetchFromGitHub, + pandoc, }: buildGoModule rec { diff --git a/pkgs/by-name/se/selendroid/package.nix b/pkgs/by-name/se/selendroid/package.nix index 66a9b97d0db90d..170ef05845b445 100644 --- a/pkgs/by-name/se/selendroid/package.nix +++ b/pkgs/by-name/se/selendroid/package.nix @@ -1,19 +1,26 @@ -{ lib, stdenv, fetchurl, makeWrapper, jdk, selenium-server-standalone }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jdk, + selenium-server-standalone, +}: let - pname = "selendroid-standalone"; - pluginName = "selendroid-grid-plugin-${version}"; - version = "0.17.0"; - srcs = { - jar = fetchurl { - url = "https://github.com/selendroid/selendroid/releases/download/${version}/selendroid-standalone-${version}-with-dependencies.jar"; - sha256 = "10lxdsgp711pv8r6dk2aagnbvnn1b25zfqjvz7plc73zqhx1dxvw"; - }; - gridPlugin = fetchurl { - url = "https://search.maven.org/remotecontent?filepath=io/selendroid/selendroid-grid-plugin/${version}/${pluginName}.jar"; - sha256 = "1x6cjmp2hpghbgbf8vss0qaj2n4sfl29wp3bc4k1s3hnnpccvz70"; - }; + pname = "selendroid-standalone"; + pluginName = "selendroid-grid-plugin-${version}"; + version = "0.17.0"; + srcs = { + jar = fetchurl { + url = "https://github.com/selendroid/selendroid/releases/download/${version}/selendroid-standalone-${version}-with-dependencies.jar"; + sha256 = "10lxdsgp711pv8r6dk2aagnbvnn1b25zfqjvz7plc73zqhx1dxvw"; }; + gridPlugin = fetchurl { + url = "https://search.maven.org/remotecontent?filepath=io/selendroid/selendroid-grid-plugin/${version}/${pluginName}.jar"; + sha256 = "1x6cjmp2hpghbgbf8vss0qaj2n4sfl29wp3bc4k1s3hnnpccvz70"; + }; + }; in stdenv.mkDerivation { inherit pname version; diff --git a/pkgs/by-name/se/selene/package.nix b/pkgs/by-name/se/selene/package.nix index bcd1409b9985e4..543f225050ae62 100644 --- a/pkgs/by-name/se/selene/package.nix +++ b/pkgs/by-name/se/selene/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, robloxSupport ? true -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + robloxSupport ? true, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -25,11 +26,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = lib.optionals robloxSupport [ - openssl - ] ++ lib.optionals (robloxSupport && stdenv.hostPlatform.isDarwin) [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + lib.optionals robloxSupport [ + openssl + ] + ++ lib.optionals (robloxSupport && stdenv.hostPlatform.isDarwin) [ + darwin.apple_sdk.frameworks.Security + ]; buildNoDefaultFeatures = !robloxSupport; diff --git a/pkgs/by-name/se/selenium-server-standalone/package.nix b/pkgs/by-name/se/selenium-server-standalone/package.nix index b1cc26bec519ce..9c8ff8ecbc679a 100644 --- a/pkgs/by-name/se/selenium-server-standalone/package.nix +++ b/pkgs/by-name/se/selenium-server-standalone/package.nix @@ -1,11 +1,20 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre -, htmlunit-driver, chromedriver, chromeSupport ? true }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, + htmlunit-driver, + chromedriver, + chromeSupport ? true, +}: let minorVersion = "3.141"; patchVersion = "59"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "selenium-server-standalone"; version = "${minorVersion}.${patchVersion}"; @@ -33,7 +42,10 @@ in stdenv.mkDerivation rec { description = "Selenium Server for remote WebDriver"; sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.asl20; - maintainers = with maintainers; [ coconnor offline ]; + maintainers = with maintainers; [ + coconnor + offline + ]; mainProgram = "selenium-server"; platforms = platforms.all; }; diff --git a/pkgs/by-name/se/selfoss/package.nix b/pkgs/by-name/se/selfoss/package.nix index b0b888012f4635..11542c6ddfbc15 100644 --- a/pkgs/by-name/se/selfoss/package.nix +++ b/pkgs/by-name/se/selfoss/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchurl, unzip }: +{ + lib, + stdenvNoCC, + fetchurl, + unzip, +}: stdenvNoCC.mkDerivation rec { pname = "selfoss"; @@ -30,7 +35,10 @@ stdenvNoCC.mkDerivation rec { description = "Web-based news feed (RSS/Atom) aggregator"; homepage = "https://selfoss.aditu.de"; license = licenses.gpl3Only; - maintainers = with maintainers; [ jtojnar regnat ]; + maintainers = with maintainers; [ + jtojnar + regnat + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/se/selinux-python/package.nix b/pkgs/by-name/se/selinux-python/package.nix index 2211db1c38b1e1..3d15b6dd502ca4 100644 --- a/pkgs/by-name/se/selinux-python/package.nix +++ b/pkgs/by-name/se/selinux-python/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchurl, python3 -, libselinux, libsemanage, libsepol, setools }: +{ + lib, + stdenv, + fetchurl, + python3, + libselinux, + libsemanage, + libsepol, + setools, +}: # this is python3 only because setools only supports python3 stdenv.mkDerivation rec { @@ -21,7 +29,12 @@ stdenv.mkDerivation rec { python3.pkgs.wrapPython ]; buildInputs = [ libsepol ]; - propagatedBuildInputs = [ libselinux libsemanage setools python3.pkgs.ipy ]; + propagatedBuildInputs = [ + libselinux + libsemanage + setools + python3.pkgs.ipy + ]; postPatch = '' substituteInPlace sepolicy/Makefile --replace "echo --root" "echo --prefix" @@ -38,7 +51,6 @@ stdenv.mkDerivation rec { "LIBSEPOLA=${lib.getLib libsepol}/lib/libsepol.a" ]; - postFixup = '' wrapPythonPrograms ''; diff --git a/pkgs/by-name/se/selinux-sandbox/package.nix b/pkgs/by-name/se/selinux-sandbox/package.nix index cbddfc3ec50a3d..62e5f2761fcbb5 100644 --- a/pkgs/by-name/se/selinux-sandbox/package.nix +++ b/pkgs/by-name/se/selinux-sandbox/package.nix @@ -1,6 +1,18 @@ -{ lib, stdenv, fetchurl, bash, coreutils, python3 -, libcap_ng, policycoreutils, selinux-python, dbus -, xorgserver, openbox, xmodmap }: +{ + lib, + stdenv, + fetchurl, + bash, + coreutils, + python3, + libcap_ng, + policycoreutils, + selinux-python, + dbus, + xorgserver, + openbox, + xmodmap, +}: # this is python3 only as it depends on selinux-python @@ -17,8 +29,21 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ wrapPython ]; - buildInputs = [ bash coreutils libcap_ng policycoreutils python3 xorgserver openbox xmodmap dbus ]; - propagatedBuildInputs = [ pygobject3 selinux-python ]; + buildInputs = [ + bash + coreutils + libcap_ng + policycoreutils + python3 + xorgserver + openbox + xmodmap + dbus + ]; + propagatedBuildInputs = [ + pygobject3 + selinux-python + ]; postPatch = '' # Fix setuid install diff --git a/pkgs/by-name/se/sem/package.nix b/pkgs/by-name/se/sem/package.nix index 2a3732ca6b333c..cab3dbca45398f 100644 --- a/pkgs/by-name/se/sem/package.nix +++ b/pkgs/by-name/se/sem/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "sem"; @@ -14,7 +18,10 @@ buildGoModule rec { vendorHash = "sha256-p8+M+pRp12P7tYlFpXjU94JcJOugQpD8rFdowhonh74="; subPackages = [ "." ]; - ldflags = [ "-X main.version=${version}" "-X main.buildSource=nix" ]; + ldflags = [ + "-X main.version=${version}" + "-X main.buildSource=nix" + ]; postInstall = '' install -m755 $out/bin/cli $out/bin/sem diff --git a/pkgs/by-name/se/semantic-release/package.nix b/pkgs/by-name/se/semantic-release/package.nix index 8ece8fcfbad340..ecb368efc85245 100644 --- a/pkgs/by-name/se/semantic-release/package.nix +++ b/pkgs/by-name/se/semantic-release/package.nix @@ -1,9 +1,10 @@ -{ cctools -, buildNpmPackage -, fetchFromGitHub -, lib -, python3 -, stdenv +{ + cctools, + buildNpmPackage, + fetchFromGitHub, + lib, + python3, + stdenv, }: buildNpmPackage rec { diff --git a/pkgs/by-name/se/semiphemeral/package.nix b/pkgs/by-name/se/semiphemeral/package.nix index 173431e526f72d..6dbacb7d50d698 100644 --- a/pkgs/by-name/se/semiphemeral/package.nix +++ b/pkgs/by-name/se/semiphemeral/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { @@ -16,7 +17,13 @@ python3.pkgs.buildPythonApplication rec { pythonImportsCheck = [ "semiphemeral" ]; - propagatedBuildInputs = with python3.pkgs; [ click sqlalchemy flask tweepy colorama ]; + propagatedBuildInputs = with python3.pkgs; [ + click + sqlalchemy + flask + tweepy + colorama + ]; meta = with lib; { description = "Automatically delete your old tweets, except for the ones you want to keep"; diff --git a/pkgs/by-name/se/semodule-utils/package.nix b/pkgs/by-name/se/semodule-utils/package.nix index ffc5639cf85c35..9c9343ead745ad 100644 --- a/pkgs/by-name/se/semodule-utils/package.nix +++ b/pkgs/by-name/se/semodule-utils/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libsepol }: +{ + lib, + stdenv, + fetchurl, + libsepol, +}: stdenv.mkDerivation rec { pname = "semodule-utils"; diff --git a/pkgs/by-name/se/semver-tool/package.nix b/pkgs/by-name/se/semver-tool/package.nix index a26c99171662d9..6dc1e3b7097d8e 100644 --- a/pkgs/by-name/se/semver-tool/package.nix +++ b/pkgs/by-name/se/semver-tool/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "semver-tool"; diff --git a/pkgs/by-name/se/semver/package.nix b/pkgs/by-name/se/semver/package.nix index 750d86eea1139d..a73fea385575ed 100644 --- a/pkgs/by-name/se/semver/package.nix +++ b/pkgs/by-name/se/semver/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, git }: +{ + lib, + buildGoModule, + fetchFromGitHub, + git, +}: buildGoModule rec { pname = "semver"; diff --git a/pkgs/by-name/se/sendme/package.nix b/pkgs/by-name/se/sendme/package.nix index 3aafd204c600a8..75dc8053732437 100644 --- a/pkgs/by-name/se/sendme/package.nix +++ b/pkgs/by-name/se/sendme/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,8 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-W2R00nhoDVz1TuGyQxN6mWKoFIU5TfywtsdduNEp+j8="; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( - with darwin.apple_sdk.frameworks; [ + with darwin.apple_sdk.frameworks; + [ SystemConfiguration ] ); @@ -27,7 +29,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Tool to send files and directories, based on iroh"; homepage = "https://iroh.computer/sendme"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ cameronfyfe ]; mainProgram = "sendme"; }; diff --git a/pkgs/by-name/se/senpai/package.nix b/pkgs/by-name/se/senpai/package.nix index f27a31e6608876..d11d21315d2053 100644 --- a/pkgs/by-name/se/senpai/package.nix +++ b/pkgs/by-name/se/senpai/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromSourcehut, installShellFiles, scdoc }: +{ + lib, + buildGoModule, + fetchFromSourcehut, + installShellFiles, + scdoc, +}: buildGoModule rec { pname = "senpai"; diff --git a/pkgs/by-name/se/sensible-side-buttons/package.nix b/pkgs/by-name/se/sensible-side-buttons/package.nix index 135ca6a60dbd3c..8e9f0cb0ad401a 100644 --- a/pkgs/by-name/se/sensible-side-buttons/package.nix +++ b/pkgs/by-name/se/sensible-side-buttons/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchurl -, undmg -, stdenv +{ + lib, + fetchurl, + undmg, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/se/sensible-utils/package.nix b/pkgs/by-name/se/sensible-utils/package.nix index c60220c0341cd7..249c11cf7ad5e9 100644 --- a/pkgs/by-name/se/sensible-utils/package.nix +++ b/pkgs/by-name/se/sensible-utils/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitLab, makeWrapper }: +{ + stdenv, + lib, + fetchFromGitLab, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "sensible-utils"; @@ -25,10 +30,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Collection of utilities used by programs to sensibly select and spawn an appropriate browser, editor, or pager"; longDescription = '' - The specific utilities included are: - - sensible-browser - - sensible-editor - - sensible-pager + The specific utilities included are: + - sensible-browser + - sensible-editor + - sensible-pager ''; homepage = "https://salsa.debian.org/debian/sensible-utils"; changelog = "https://salsa.debian.org/debian/sensible-utils/-/tags"; @@ -37,4 +42,3 @@ stdenv.mkDerivation rec { platforms = platforms.unix; }; } - diff --git a/pkgs/by-name/se/sent/package.nix b/pkgs/by-name/se/sent/package.nix index 9f11cfa53bb201..ab46ecbc6e4731 100644 --- a/pkgs/by-name/se/sent/package.nix +++ b/pkgs/by-name/se/sent/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchurl, farbfeld, libX11, libXft, makeWrapper -, patches ? [] }: +{ + lib, + stdenv, + fetchurl, + farbfeld, + libX11, + libXft, + makeWrapper, + patches ? [ ], +}: stdenv.mkDerivation rec { pname = "sent"; @@ -10,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "0cxysz5lp25mgww73jl0mgip68x7iyvialyzdbriyaff269xxwvv"; }; - buildInputs = [ libX11 libXft ]; + buildInputs = [ + libX11 + libXft + ]; nativeBuildInputs = [ makeWrapper ]; # unpacking doesn't create a directory diff --git a/pkgs/by-name/se/sentencepiece/package.nix b/pkgs/by-name/se/sentencepiece/package.nix index 0c40f67c21ee50..335eff7d718e84 100644 --- a/pkgs/by-name/se/sentencepiece/package.nix +++ b/pkgs/by-name/se/sentencepiece/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, stdenv -, cmake -, gperftools - -, withGPerfTools ? true +{ + lib, + fetchFromGitHub, + stdenv, + cmake, + gperftools, + + withGPerfTools ? true, }: stdenv.mkDerivation rec { @@ -22,7 +23,11 @@ stdenv.mkDerivation rec { buildInputs = lib.optionals withGPerfTools [ gperftools ]; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; # https://github.com/google/sentencepiece/issues/754 postPatch = '' diff --git a/pkgs/by-name/se/senv/package.nix b/pkgs/by-name/se/senv/package.nix index 999b140c5fe2ad..d7fd3e766918ea 100644 --- a/pkgs/by-name/se/senv/package.nix +++ b/pkgs/by-name/se/senv/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "senv"; diff --git a/pkgs/by-name/se/seq-cli/deps.nix b/pkgs/by-name/se/seq-cli/deps.nix index d99b2edc3be70d..ce66ce910aae74 100644 --- a/pkgs/by-name/se/seq-cli/deps.nix +++ b/pkgs/by-name/se/seq-cli/deps.nix @@ -1,23 +1,96 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Autofac"; version = "8.1.1"; hash = "sha256-///N/c/OmCa7DUVz9/hIA/rFsaJ4TMltqdrVk7Ycmq8="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.3"; hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; }) - (fetchNuGet { pname = "Seq.Api"; version = "2024.3.0"; hash = "sha256-OUBZ9VV7C5p/CzW0hoN3N9m1RAEGg24wNYFZgfJgk4s="; }) - (fetchNuGet { pname = "Seq.Apps"; version = "2023.4.0"; hash = "sha256-PLN0KYbxH9aQkMCTOSmb16NcGD+XDooJdU4QIej1i+0="; }) - (fetchNuGet { pname = "Seq.Syntax"; version = "1.0.0"; hash = "sha256-FcDdFhRE2EIgQjoTHDjKLq/Pl9mKzezL/B75pGhvk9s="; }) - (fetchNuGet { pname = "Serilog"; version = "4.0.2"; hash = "sha256-vkd4s/PsKnnVzN1+f9haIP5LoxNWxnhdv3mBQYl/2Hc="; }) - (fetchNuGet { pname = "Serilog.Expressions"; version = "5.0.0"; hash = "sha256-xpAT8U0pzTvRGa/qBd2M3YOQDD1xgAHCMVN9NEz0L4E="; }) - (fetchNuGet { pname = "Serilog.Formatting.Compact"; version = "3.0.0"; hash = "sha256-nejEYqJEMG9P2iFZvbsCUPr5LZRtxbdUTLCI9N71jHY="; }) - (fetchNuGet { pname = "Serilog.Formatting.Compact.Reader"; version = "4.0.0"; hash = "sha256-89+SaaXp9Pt8YTkTwVuMV3PzlPMg9mOHiFBKs3oHOUs="; }) - (fetchNuGet { pname = "Serilog.Sinks.Console"; version = "6.0.0"; hash = "sha256-QH8ykDkLssJ99Fgl+ZBFBr+RQRl0wRTkeccQuuGLyro="; }) - (fetchNuGet { pname = "Serilog.Sinks.File"; version = "5.0.0"; hash = "sha256-GKy9hwOdlu2W0Rw8LiPyEwus+sDtSOTl8a5l9uqz+SQ="; }) - (fetchNuGet { pname = "Serilog.Sinks.Seq"; version = "8.0.0"; hash = "sha256-1AEtDLODwS9WBkJ2yrmjKl2Rq3q2VPs1H9bQCUhC05s="; }) - (fetchNuGet { pname = "SerilogTracing"; version = "2.1.2"; hash = "sha256-fhSiUgk21s7kiz4QYF2fy9YLC1X0YHibi95x2flPqMM="; }) - (fetchNuGet { pname = "Superpower"; version = "3.0.0"; hash = "sha256-5MNmhBDYyOs+sTH364Qdn+Ck328BAQaVC1KMQ7yK2Vw="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "8.0.1"; hash = "sha256-zmwHjcJgKcbkkwepH038QhcnsWMJcHys+PEbFGC0Jgo="; }) - (fetchNuGet { pname = "System.Reactive"; version = "6.0.1"; hash = "sha256-Lo5UMqp8DsbVSUxa2UpClR1GoYzqQQcSxkfyFqB/d4Q="; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "8.0.0"; hash = "sha256-fb0pa9sQxN+mr0vnXg1Igbx49CaOqS+GDkTfWNboUvs="; }) - (fetchNuGet { pname = "Tavis.UriTemplates"; version = "2.0.0"; hash = "sha256-Rd3VH55GFiXhMDbUcnKri2jDVIA1M7CQ+6Fjdsn/PSE="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Autofac"; + version = "8.1.1"; + hash = "sha256-///N/c/OmCa7DUVz9/hIA/rFsaJ4TMltqdrVk7Ycmq8="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.3"; + hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; + }) + (fetchNuGet { + pname = "Seq.Api"; + version = "2024.3.0"; + hash = "sha256-OUBZ9VV7C5p/CzW0hoN3N9m1RAEGg24wNYFZgfJgk4s="; + }) + (fetchNuGet { + pname = "Seq.Apps"; + version = "2023.4.0"; + hash = "sha256-PLN0KYbxH9aQkMCTOSmb16NcGD+XDooJdU4QIej1i+0="; + }) + (fetchNuGet { + pname = "Seq.Syntax"; + version = "1.0.0"; + hash = "sha256-FcDdFhRE2EIgQjoTHDjKLq/Pl9mKzezL/B75pGhvk9s="; + }) + (fetchNuGet { + pname = "Serilog"; + version = "4.0.2"; + hash = "sha256-vkd4s/PsKnnVzN1+f9haIP5LoxNWxnhdv3mBQYl/2Hc="; + }) + (fetchNuGet { + pname = "Serilog.Expressions"; + version = "5.0.0"; + hash = "sha256-xpAT8U0pzTvRGa/qBd2M3YOQDD1xgAHCMVN9NEz0L4E="; + }) + (fetchNuGet { + pname = "Serilog.Formatting.Compact"; + version = "3.0.0"; + hash = "sha256-nejEYqJEMG9P2iFZvbsCUPr5LZRtxbdUTLCI9N71jHY="; + }) + (fetchNuGet { + pname = "Serilog.Formatting.Compact.Reader"; + version = "4.0.0"; + hash = "sha256-89+SaaXp9Pt8YTkTwVuMV3PzlPMg9mOHiFBKs3oHOUs="; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Console"; + version = "6.0.0"; + hash = "sha256-QH8ykDkLssJ99Fgl+ZBFBr+RQRl0wRTkeccQuuGLyro="; + }) + (fetchNuGet { + pname = "Serilog.Sinks.File"; + version = "5.0.0"; + hash = "sha256-GKy9hwOdlu2W0Rw8LiPyEwus+sDtSOTl8a5l9uqz+SQ="; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Seq"; + version = "8.0.0"; + hash = "sha256-1AEtDLODwS9WBkJ2yrmjKl2Rq3q2VPs1H9bQCUhC05s="; + }) + (fetchNuGet { + pname = "SerilogTracing"; + version = "2.1.2"; + hash = "sha256-fhSiUgk21s7kiz4QYF2fy9YLC1X0YHibi95x2flPqMM="; + }) + (fetchNuGet { + pname = "Superpower"; + version = "3.0.0"; + hash = "sha256-5MNmhBDYyOs+sTH364Qdn+Ck328BAQaVC1KMQ7yK2Vw="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "8.0.1"; + hash = "sha256-zmwHjcJgKcbkkwepH038QhcnsWMJcHys+PEbFGC0Jgo="; + }) + (fetchNuGet { + pname = "System.Reactive"; + version = "6.0.1"; + hash = "sha256-Lo5UMqp8DsbVSUxa2UpClR1GoYzqQQcSxkfyFqB/d4Q="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "8.0.0"; + hash = "sha256-fb0pa9sQxN+mr0vnXg1Igbx49CaOqS+GDkTfWNboUvs="; + }) + (fetchNuGet { + pname = "Tavis.UriTemplates"; + version = "2.0.0"; + hash = "sha256-Rd3VH55GFiXhMDbUcnKri2jDVIA1M7CQ+6Fjdsn/PSE="; + }) ] diff --git a/pkgs/by-name/se/seq24/package.nix b/pkgs/by-name/se/seq24/package.nix index 441f858a1055c1..53f6c2acd53b2b 100644 --- a/pkgs/by-name/se/seq24/package.nix +++ b/pkgs/by-name/se/seq24/package.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchurl, alsa-lib, gtkmm2, libjack2, pkg-config }: +{ + lib, + stdenv, + fetchurl, + alsa-lib, + gtkmm2, + libjack2, + pkg-config, +}: -stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "seq24"; version = "0.9.3"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { patches = [ ./mutex_no_nameclash.patch ]; - buildInputs = [ alsa-lib gtkmm2 libjack2 ]; + buildInputs = [ + alsa-lib + gtkmm2 + libjack2 + ]; nativeBuildInputs = [ pkg-config ]; meta = with lib; { diff --git a/pkgs/by-name/se/seqkit/package.nix b/pkgs/by-name/se/seqkit/package.nix index c5fb63c66eda1c..1b049a4bc7e068 100644 --- a/pkgs/by-name/se/seqkit/package.nix +++ b/pkgs/by-name/se/seqkit/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { diff --git a/pkgs/by-name/se/seqtk/package.nix b/pkgs/by-name/se/seqtk/package.nix index 856248de917db4..5e223163500b77 100644 --- a/pkgs/by-name/se/seqtk/package.nix +++ b/pkgs/by-name/se/seqtk/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, zlib -, libdeflate -, isa-l +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + libdeflate, + isa-l, }: stdenv.mkDerivation rec { @@ -17,7 +18,11 @@ stdenv.mkDerivation rec { hash = "sha256-W6IUn7R9tlnWrKe/qOHJL+43AL4EZB7zj7M5u9l83WE="; }; - buildInputs = [ zlib libdeflate isa-l ]; + buildInputs = [ + zlib + libdeflate + isa-l + ]; makeFlags = [ "CC:=$(CC)" diff --git a/pkgs/by-name/se/sequeler/package.nix b/pkgs/by-name/se/sequeler/package.nix index aa76a65a175238..798b8503ad6a39 100644 --- a/pkgs/by-name/se/sequeler/package.nix +++ b/pkgs/by-name/se/sequeler/package.nix @@ -1,7 +1,26 @@ -{ lib, stdenv, fetchFromGitHub, nix-update-script -, vala, meson, ninja, pkg-config, pantheon, gettext, wrapGAppsHook3, python3, desktop-file-utils -, gtk3, glib, libgee, libgda, gtksourceview, libxml2, libsecret, libssh2 }: - +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + vala, + meson, + ninja, + pkg-config, + pantheon, + gettext, + wrapGAppsHook3, + python3, + desktop-file-utils, + gtk3, + glib, + libgee, + libgda, + gtksourceview, + libxml2, + libsecret, + libssh2, +}: let sqlGda = libgda.override { @@ -9,7 +28,8 @@ let postgresSupport = true; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "sequeler"; version = "0.8.2"; @@ -20,9 +40,28 @@ in stdenv.mkDerivation rec { sha256 = "sha256-MsHHTYERe0v+u3KnVtx+jmJTKORJTJ7bNfJMZHV9Ly4="; }; - nativeBuildInputs = [ meson ninja pkg-config vala gettext wrapGAppsHook3 python3 desktop-file-utils ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + vala + gettext + wrapGAppsHook3 + python3 + desktop-file-utils + ]; - buildInputs = [ gtk3 glib pantheon.granite libgee sqlGda gtksourceview libxml2 libsecret libssh2 ]; + buildInputs = [ + gtk3 + glib + pantheon.granite + libgee + sqlGda + gtksourceview + libxml2 + libsecret + libssh2 + ]; postPatch = '' chmod +x build-aux/meson_post_install.py diff --git a/pkgs/by-name/se/sequelpro/package.nix b/pkgs/by-name/se/sequelpro/package.nix index dd1aca73b7db88..8ded5e56349a4f 100644 --- a/pkgs/by-name/se/sequelpro/package.nix +++ b/pkgs/by-name/se/sequelpro/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, undmg }: +{ + lib, + stdenv, + fetchurl, + undmg, +}: stdenv.mkDerivation { pname = "sequel-pro"; diff --git a/pkgs/by-name/se/sequoia-chameleon-gnupg/package.nix b/pkgs/by-name/se/sequoia-chameleon-gnupg/package.nix index 8d93ec1087bdd0..5a522c3dfd0371 100644 --- a/pkgs/by-name/se/sequoia-chameleon-gnupg/package.nix +++ b/pkgs/by-name/se/sequoia-chameleon-gnupg/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitLab -, pkg-config -, nettle -, openssl -, sqlite +{ + lib, + stdenv, + rustPlatform, + fetchFromGitLab, + pkg-config, + nettle, + openssl, + sqlite, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/se/sequoia-sq/package.nix b/pkgs/by-name/se/sequoia-sq/package.nix index e27d63939973f5..3188f030696f0f 100644 --- a/pkgs/by-name/se/sequoia-sq/package.nix +++ b/pkgs/by-name/se/sequoia-sq/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, fetchFromGitLab -, lib -, darwin -, nettle -, nix-update-script -, rustPlatform -, pkg-config -, capnproto -, installShellFiles -, openssl -, sqlite +{ + stdenv, + fetchFromGitLab, + lib, + darwin, + nettle, + nix-update-script, + rustPlatform, + pkg-config, + capnproto, + installShellFiles, + openssl, + sqlite, }: rustPlatform.buildRustPackage rec { @@ -32,11 +33,19 @@ rustPlatform.buildRustPackage rec { installShellFiles ]; - buildInputs = [ - openssl - sqlite - nettle - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ Security SystemConfiguration ]); + buildInputs = + [ + openssl + sqlite + nettle + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Security + SystemConfiguration + ] + ); checkFlags = [ # https://gitlab.com/sequoia-pgp/sequoia-sq/-/issues/297 @@ -68,7 +77,11 @@ rustPlatform.buildRustPackage rec { homepage = "https://sequoia-pgp.org/"; changelog = "https://gitlab.com/sequoia-pgp/sequoia-sq/-/blob/v${version}/NEWS"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ minijackson doronbehar dvn0 ]; + maintainers = with lib.maintainers; [ + minijackson + doronbehar + dvn0 + ]; mainProgram = "sq"; }; } diff --git a/pkgs/by-name/se/sequoia-sqop/package.nix b/pkgs/by-name/se/sequoia-sqop/package.nix index ff62b5793f0e55..6b464de530bcdb 100644 --- a/pkgs/by-name/se/sequoia-sqop/package.nix +++ b/pkgs/by-name/se/sequoia-sqop/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitLab -, nettle -, nix-update-script -, installShellFiles -, rustPlatform -, pkg-config +{ + lib, + fetchFromGitLab, + nettle, + nix-update-script, + installShellFiles, + rustPlatform, + pkg-config, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/se/sequoia-sqv/package.nix b/pkgs/by-name/se/sequoia-sqv/package.nix index 591a547425ba2b..c3b7e01b709fd8 100644 --- a/pkgs/by-name/se/sequoia-sqv/package.nix +++ b/pkgs/by-name/se/sequoia-sqv/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitLab -, nettle -, nix-update-script -, rustPlatform -, pkg-config -, installShellFiles +{ + lib, + fetchFromGitLab, + nettle, + nix-update-script, + rustPlatform, + pkg-config, + installShellFiles, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/se/sequoia-wot/package.nix b/pkgs/by-name/se/sequoia-wot/package.nix index 09ae4d8bd9f27a..cd881884c365b3 100644 --- a/pkgs/by-name/se/sequoia-wot/package.nix +++ b/pkgs/by-name/se/sequoia-wot/package.nix @@ -30,15 +30,18 @@ rustPlatform.buildRustPackage rec { installShellFiles ]; - buildInputs = [ - openssl - sqlite - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - # See comment near sequoia-openpgp/crypto- buildFeatures - ] ++ lib.optionals (!stdenv.targetPlatform.isWindows) [ - nettle - ]; + buildInputs = + [ + openssl + sqlite + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + # See comment near sequoia-openpgp/crypto- buildFeatures + ] + ++ lib.optionals (!stdenv.targetPlatform.isWindows) [ + nettle + ]; buildFeatures = [ # Upstream uses the sequoia-openpgp crate, which doesn't force you to use a @@ -48,10 +51,11 @@ rustPlatform.buildRustPackage rec { # propagate this logic here as well. # # [1]: https://crates.io/crates/sequoia-openpgp#user-content-intermediate-crate - (if stdenv.targetPlatform.isWindows then - "sequoia-openpgp/crypto-cng" - else - "sequoia-openpgp/crypto-nettle" + ( + if stdenv.targetPlatform.isWindows then + "sequoia-openpgp/crypto-cng" + else + "sequoia-openpgp/crypto-nettle" ) ]; @@ -84,7 +88,10 @@ rustPlatform.buildRustPackage rec { description = "Rust CLI tool for authenticating bindings and exploring a web of trust"; homepage = "https://gitlab.com/sequoia-pgp/sequoia-wot"; license = lib.licenses.gpl2Only; - maintainers = with lib.maintainers; [ doronbehar Cryolitia ]; + maintainers = with lib.maintainers; [ + doronbehar + Cryolitia + ]; mainProgram = "sq-wot"; }; } diff --git a/pkgs/by-name/se/ser2net/package.nix b/pkgs/by-name/se/ser2net/package.nix index 2d580ce8ba0cb3..287897119cbaf3 100644 --- a/pkgs/by-name/se/ser2net/package.nix +++ b/pkgs/by-name/se/ser2net/package.nix @@ -1,11 +1,12 @@ -{ autoreconfHook -, fetchFromGitHub -, gensio -, lib -, libyaml -, nix-update-script -, pkg-config -, stdenv +{ + autoreconfHook, + fetchFromGitHub, + gensio, + lib, + libyaml, + nix-update-script, + pkg-config, + stdenv, }: stdenv.mkDerivation rec { @@ -23,9 +24,15 @@ stdenv.mkDerivation rec { updateScript = nix-update-script { }; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; - buildInputs = [ gensio libyaml ]; + buildInputs = [ + gensio + libyaml + ]; meta = with lib; { description = "Serial to network connection server"; diff --git a/pkgs/by-name/se/seren/package.nix b/pkgs/by-name/se/seren/package.nix index 80484114f32fc9..23033872d848e4 100644 --- a/pkgs/by-name/se/seren/package.nix +++ b/pkgs/by-name/se/seren/package.nix @@ -1,18 +1,25 @@ -{ lib -, stdenv -, fetchurl -, alsa-lib -, libopus -, libogg -, gmp -, ncurses +{ + lib, + stdenv, + fetchurl, + alsa-lib, + libopus, + libogg, + gmp, + ncurses, }: stdenv.mkDerivation rec { pname = "seren"; version = "0.0.21"; - buildInputs = [ alsa-lib libopus libogg gmp ncurses ]; + buildInputs = [ + alsa-lib + libopus + libogg + gmp + ncurses + ]; src = fetchurl { url = "http://holdenc.altervista.org/seren/downloads/${pname}-${version}.tar.gz"; @@ -32,7 +39,10 @@ stdenv.mkDerivation rec { homepage = "http://holdenc.altervista.org/seren/"; changelog = "http://holdenc.altervista.org/seren/"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ matthewcroughan nixinator ]; + maintainers = with maintainers; [ + matthewcroughan + nixinator + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/se/serf/package.nix b/pkgs/by-name/se/serf/package.nix index 07138596d05de6..2924049e075c6a 100644 --- a/pkgs/by-name/se/serf/package.nix +++ b/pkgs/by-name/se/serf/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, apr -, scons -, openssl -, aprutil -, zlib -, libkrb5 -, pkg-config -, libiconv -, fetchpatch +{ + lib, + stdenv, + fetchurl, + apr, + scons, + openssl, + aprutil, + zlib, + libkrb5, + pkg-config, + libiconv, + fetchpatch, }: stdenv.mkDerivation rec { @@ -21,9 +22,17 @@ stdenv.mkDerivation rec { hash = "sha256-voHvCLqiUW7Np2p3rffe97wyJ+61eLmjO0X3tB3AZOY="; }; - nativeBuildInputs = [ pkg-config scons ]; - buildInputs = [ apr openssl aprutil zlib libiconv ] - ++ lib.optional (!stdenv.hostPlatform.isCygwin) libkrb5; + nativeBuildInputs = [ + pkg-config + scons + ]; + buildInputs = [ + apr + openssl + aprutil + zlib + libiconv + ] ++ lib.optional (!stdenv.hostPlatform.isCygwin) libkrb5; patches = [ ./scons.patch @@ -36,15 +45,17 @@ stdenv.mkDerivation rec { prefixKey = "PREFIX="; - preConfigure = '' - sconsFlags+=" APR=$(echo ${apr.dev}/bin/*-config)" - sconsFlags+=" APU=$(echo ${aprutil.dev}/bin/*-config)" - sconsFlags+=" CC=$CC" - sconsFlags+=" OPENSSL=${openssl}" - sconsFlags+=" ZLIB=${zlib}" - '' + lib.optionalString (!stdenv.hostPlatform.isCygwin) '' - sconsFlags+=" GSSAPI=${libkrb5.dev}" - ''; + preConfigure = + '' + sconsFlags+=" APR=$(echo ${apr.dev}/bin/*-config)" + sconsFlags+=" APU=$(echo ${aprutil.dev}/bin/*-config)" + sconsFlags+=" CC=$CC" + sconsFlags+=" OPENSSL=${openssl}" + sconsFlags+=" ZLIB=${zlib}" + '' + + lib.optionalString (!stdenv.hostPlatform.isCygwin) '' + sconsFlags+=" GSSAPI=${libkrb5.dev}" + ''; enableParallelBuilding = true; @@ -52,7 +63,10 @@ stdenv.mkDerivation rec { description = "HTTP client library based on APR"; homepage = "https://serf.apache.org/"; license = licenses.asl20; - maintainers = with maintainers; [ orivej raskin ]; + maintainers = with maintainers; [ + orivej + raskin + ]; platforms = platforms.linux ++ platforms.darwin; }; } diff --git a/pkgs/by-name/se/serfdom/package.nix b/pkgs/by-name/se/serfdom/package.nix index 1b8d4ca271c93b..1abb60f71748a1 100644 --- a/pkgs/by-name/se/serfdom/package.nix +++ b/pkgs/by-name/se/serfdom/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -21,12 +22,11 @@ buildGoModule rec { # These values are expected by version/version.go # https://github.com/hashicorp/serf/blob/7faa1b06262f70780c3c35ac25a4c96d754f06f3/version/version.go#L8-L22 - ldflags = lib.mapAttrsToList - (n: v: "-X github.com/hashicorp/serf/version.${n}=${v}") { - GitCommit = rev; - Version = version; - VersionPrerelease = ""; - }; + ldflags = lib.mapAttrsToList (n: v: "-X github.com/hashicorp/serf/version.${n}=${v}") { + GitCommit = rev; + Version = version; + VersionPrerelease = ""; + }; # There are no tests for cmd/serf. doCheck = false; diff --git a/pkgs/by-name/se/serial-unit-testing/package.nix b/pkgs/by-name/se/serial-unit-testing/package.nix index dd45dc760cf783..9971033ea0b6ec 100644 --- a/pkgs/by-name/se/serial-unit-testing/package.nix +++ b/pkgs/by-name/se/serial-unit-testing/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, udev +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + udev, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/se/serialdv/package.nix b/pkgs/by-name/se/serialdv/package.nix index 549d0369337554..655831830da178 100644 --- a/pkgs/by-name/se/serialdv/package.nix +++ b/pkgs/by-name/se/serialdv/package.nix @@ -1,8 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "serialdv"; - version ="1.1.4"; + version = "1.1.4"; src = fetchFromGitHub { owner = "f4exb"; @@ -22,4 +27,3 @@ stdenv.mkDerivation rec { license = licenses.gpl3; }; } - diff --git a/pkgs/by-name/se/serious-sans/package.nix b/pkgs/by-name/se/serious-sans/package.nix index b66af28dd22a5f..64159fc2d482a5 100644 --- a/pkgs/by-name/se/serious-sans/package.nix +++ b/pkgs/by-name/se/serious-sans/package.nix @@ -1,6 +1,7 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub +{ + stdenvNoCC, + lib, + fetchFromGitHub, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/se/serpent/package.nix b/pkgs/by-name/se/serpent/package.nix index 670986b3ffc5c9..a121a4826d6eab 100644 --- a/pkgs/by-name/se/serpent/package.nix +++ b/pkgs/by-name/se/serpent/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ... }: +{ + lib, + stdenv, + fetchFromGitHub, + ... +}: stdenv.mkDerivation { pname = "serpent"; diff --git a/pkgs/by-name/se/serverless/package.nix b/pkgs/by-name/se/serverless/package.nix index c7ab60a5be592a..315a027bc73044 100644 --- a/pkgs/by-name/se/serverless/package.nix +++ b/pkgs/by-name/se/serverless/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/se/service-wrapper/package.nix b/pkgs/by-name/se/service-wrapper/package.nix index 08f7d00bc96280..3a6c450449fd34 100644 --- a/pkgs/by-name/se/service-wrapper/package.nix +++ b/pkgs/by-name/se/service-wrapper/package.nix @@ -1,29 +1,36 @@ -{ lib, stdenv, runCommand, substituteAll, coreutils }: +{ + lib, + stdenv, + runCommand, + substituteAll, + coreutils, +}: let name = "service-wrapper-${version}"; version = "19.04"; # Akin to Ubuntu Release in -runCommand name { - script = substituteAll { - src = ./service-wrapper.sh; - isExecutable = true; - inherit (stdenv) shell; - inherit coreutils; - }; +runCommand name + { + script = substituteAll { + src = ./service-wrapper.sh; + isExecutable = true; + inherit (stdenv) shell; + inherit coreutils; + }; - meta = with lib; { - description = "Convenient wrapper for the systemctl commands, borrow from Ubuntu"; - mainProgram = "service"; - license = licenses.gpl2Plus; - platforms = platforms.linux; - maintainers = with maintainers; [ DerTim1 ]; - # Shellscript has been modified but upstream source is: https://git.launchpad.net/ubuntu/+source/init-system-helpers - }; -} -'' - mkdir -p $out/bin - ln -s $out/bin $out/sbin - cp $script $out/bin/service - chmod a+x $out/bin/service -'' + meta = with lib; { + description = "Convenient wrapper for the systemctl commands, borrow from Ubuntu"; + mainProgram = "service"; + license = licenses.gpl2Plus; + platforms = platforms.linux; + maintainers = with maintainers; [ DerTim1 ]; + # Shellscript has been modified but upstream source is: https://git.launchpad.net/ubuntu/+source/init-system-helpers + }; + } + '' + mkdir -p $out/bin + ln -s $out/bin $out/sbin + cp $script $out/bin/service + chmod a+x $out/bin/service + '' diff --git a/pkgs/by-name/se/serviio/package.nix b/pkgs/by-name/se/serviio/package.nix index f2e652adaae3d7..122eb602072b71 100644 --- a/pkgs/by-name/se/serviio/package.nix +++ b/pkgs/by-name/se/serviio/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "serviio"; diff --git a/pkgs/by-name/se/seshat/package.nix b/pkgs/by-name/se/seshat/package.nix index a04bb1feb6f5f4..aaaedde2ee006e 100644 --- a/pkgs/by-name/se/seshat/package.nix +++ b/pkgs/by-name/se/seshat/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "0"; @@ -36,7 +40,10 @@ stdenvNoCC.mkDerivation { It incorporates symbols and ligatures used in the European region. ''; platforms = platforms.all; - maintainers = with maintainers; [ leenaars minijackson ]; + maintainers = with maintainers; [ + leenaars + minijackson + ]; license = licenses.cc0; }; } diff --git a/pkgs/by-name/se/setbfree/package.nix b/pkgs/by-name/se/setbfree/package.nix index 2284df444ec5d3..64211ac59fcc53 100644 --- a/pkgs/by-name/se/setbfree/package.nix +++ b/pkgs/by-name/se/setbfree/package.nix @@ -1,8 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, alsa-lib, freetype, ftgl, libjack2, libX11, lv2 -, libGLU, libGL, pkg-config, ttf_bitstream_vera +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + alsa-lib, + freetype, + ftgl, + libjack2, + libX11, + lv2, + libGLU, + libGL, + pkg-config, + ttf_bitstream_vera, }: -stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "setbfree"; version = "0.8.12"; @@ -30,7 +43,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - alsa-lib freetype ftgl libjack2 libX11 lv2 libGLU libGL + alsa-lib + freetype + ftgl + libjack2 + libX11 + lv2 + libGLU + libGL ttf_bitstream_vera ]; @@ -49,7 +69,10 @@ stdenv.mkDerivation rec { description = "DSP tonewheel organ emulator"; homepage = "https://setbfree.org"; license = licenses.gpl2; - platforms = [ "x86_64-linux" "i686-linux" ]; # fails on ARM and Darwin + platforms = [ + "x86_64-linux" + "i686-linux" + ]; # fails on ARM and Darwin maintainers = [ ]; }; } diff --git a/pkgs/by-name/se/setools/package.nix b/pkgs/by-name/se/setools/package.nix index 7442815f3a7da1..fc9a6c31b6f994 100644 --- a/pkgs/by-name/se/setools/package.nix +++ b/pkgs/by-name/se/setools/package.nix @@ -1,6 +1,11 @@ -{ lib, fetchFromGitHub, python3 -, libsepol, libselinux, checkpolicy -, withGraphics ? false +{ + lib, + fetchFromGitHub, + python3, + libsepol, + libselinux, + checkpolicy, + withGraphics ? false, }: python3.pkgs.buildPythonApplication rec { @@ -16,10 +21,20 @@ python3.pkgs.buildPythonApplication rec { nativeBuildInputs = [ python3.pkgs.cython ]; buildInputs = [ libsepol ]; - propagatedBuildInputs = with python3.pkgs; [ enum34 libselinux networkx setuptools ] + propagatedBuildInputs = + with python3.pkgs; + [ + enum34 + libselinux + networkx + setuptools + ] ++ lib.optionals withGraphics [ pyqt5 ]; - nativeCheckInputs = [ python3.pkgs.tox checkpolicy ]; + nativeCheckInputs = [ + python3.pkgs.tox + checkpolicy + ]; preCheck = '' export CHECKPOLICY=${checkpolicy}/bin/checkpolicy ''; diff --git a/pkgs/by-name/se/setroot/package.nix b/pkgs/by-name/se/setroot/package.nix index 2c7729eab3ad35..7bb722ffdb15f3 100644 --- a/pkgs/by-name/se/setroot/package.nix +++ b/pkgs/by-name/se/setroot/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, libX11, imlib2, pkg-config, fetchpatch -, enableXinerama ? true, libXinerama +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + imlib2, + pkg-config, + fetchpatch, + enableXinerama ? true, + libXinerama, }: stdenv.mkDerivation rec { @@ -22,10 +30,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libX11 imlib2 ] - ++ lib.optionals enableXinerama [ libXinerama ]; + buildInputs = [ + libX11 + imlib2 + ] ++ lib.optionals enableXinerama [ libXinerama ]; - buildFlags = [ (if enableXinerama then "xinerama=1" else "xinerama=0") ] ; + buildFlags = [ (if enableXinerama then "xinerama=1" else "xinerama=0") ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/se/setserial/package.nix b/pkgs/by-name/se/setserial/package.nix index 5a03c69d7e848c..05564384699add 100644 --- a/pkgs/by-name/se/setserial/package.nix +++ b/pkgs/by-name/se/setserial/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, groff }: +{ + lib, + stdenv, + fetchurl, + groff, +}: stdenv.mkDerivation rec { pname = "setserial"; diff --git a/pkgs/by-name/se/setup-envtest/package.nix b/pkgs/by-name/se/setup-envtest/package.nix index a43b97b6a40000..32b38df934b543 100644 --- a/pkgs/by-name/se/setup-envtest/package.nix +++ b/pkgs/by-name/se/setup-envtest/package.nix @@ -1,22 +1,28 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "setup-envtest"; version = "0.19.0"; - src = fetchFromGitHub { - owner = "kubernetes-sigs"; - repo = "controller-runtime"; - rev = "v${version}"; - hash = "sha256-9AqZMiA+OIJD+inmeUc/lq57kV7L85jk1I4ywiSKirg="; - } + "/tools/setup-envtest"; + src = + fetchFromGitHub { + owner = "kubernetes-sigs"; + repo = "controller-runtime"; + rev = "v${version}"; + hash = "sha256-9AqZMiA+OIJD+inmeUc/lq57kV7L85jk1I4ywiSKirg="; + } + + "/tools/setup-envtest"; vendorHash = "sha256-sn3HiKTpQzjrFTOVOGFJwoNpxU+XWgkWD2EOcPilePY="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; __darwinAllowLocalNetworking = true; diff --git a/pkgs/by-name/se/seturgent/package.nix b/pkgs/by-name/se/seturgent/package.nix index b8c02f47d0eeb0..1b3dbbc647bc29 100644 --- a/pkgs/by-name/se/seturgent/package.nix +++ b/pkgs/by-name/se/seturgent/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchgit, libX11, xorgproto }: +{ + lib, + stdenv, + fetchgit, + libX11, + xorgproto, +}: stdenv.mkDerivation rec { pname = "seturgent"; diff --git a/pkgs/by-name/se/sewer/package.nix b/pkgs/by-name/se/sewer/package.nix index a2d8eb2cb1b5b6..41b134e7d61a9a 100644 --- a/pkgs/by-name/se/sewer/package.nix +++ b/pkgs/by-name/se/sewer/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "sewer"; @@ -9,7 +13,11 @@ python3Packages.buildPythonApplication rec { sha256 = "sha256-a4VdbZY8pYxrXIaUHJpnLuTB928tJn4UCdnt+m8UBug="; }; - propagatedBuildInputs = with python3Packages; [ pyopenssl requests tldextract ]; + propagatedBuildInputs = with python3Packages; [ + pyopenssl + requests + tldextract + ]; meta = with lib; { homepage = "https://github.com/komuw/sewer"; diff --git a/pkgs/by-name/se/sexpp/package.nix b/pkgs/by-name/se/sexpp/package.nix index 1da355e2b59582..608f044ceb5fd9 100644 --- a/pkgs/by-name/se/sexpp/package.nix +++ b/pkgs/by-name/se/sexpp/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, bzip2 -, cmake -, fetchFromGitHub -, gtest -, pkg-config -, zlib +{ + lib, + stdenv, + bzip2, + cmake, + fetchFromGitHub, + gtest, + pkg-config, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -19,7 +20,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-mNt6J8nhzT5sF28ktl3jOkQMKn6x9iE04MMrwwVxyZs="; }; - buildInputs = [ zlib bzip2 ]; + buildInputs = [ + zlib + bzip2 + ]; cmakeFlags = [ "-DCMAKE_INSTALL_PREFIX=${placeholder "out"}" @@ -30,9 +34,17 @@ stdenv.mkDerivation (finalAttrs: { "-DWITH_SANITIZERS=off" ]; - nativeBuildInputs = [ cmake gtest pkg-config ]; + nativeBuildInputs = [ + cmake + gtest + pkg-config + ]; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; preConfigure = '' echo "v${finalAttrs.version}" > version.txt diff --git a/pkgs/by-name/se/seyren/package.nix b/pkgs/by-name/se/seyren/package.nix index 25f83587af7c89..a9a1e114d2256c 100644 --- a/pkgs/by-name/se/seyren/package.nix +++ b/pkgs/by-name/se/seyren/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "seyren"; diff --git a/pkgs/by-name/sf/sfeed/package.nix b/pkgs/by-name/sf/sfeed/package.nix index 818f84ed37dff7..a3d3349b504faa 100644 --- a/pkgs/by-name/sf/sfeed/package.nix +++ b/pkgs/by-name/sf/sfeed/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchgit, ncurses }: +{ + stdenv, + lib, + fetchgit, + ncurses, +}: stdenv.mkDerivation rec { pname = "sfeed"; @@ -12,7 +17,11 @@ stdenv.mkDerivation rec { buildInputs = [ ncurses ]; - makeFlags = [ "RANLIB:=$(RANLIB)" "SFEED_CURSES_LDFLAGS:=-lncurses" ] + makeFlags = + [ + "RANLIB:=$(RANLIB)" + "SFEED_CURSES_LDFLAGS:=-lncurses" + ] # use macOS's strlcat() and strlcpy() instead of vendored ones ++ lib.optional stdenv.hostPlatform.isDarwin "COMPATOBJ:="; diff --git a/pkgs/by-name/sf/sfizz/package.nix b/pkgs/by-name/sf/sfizz/package.nix index a76654fdd9098e..39b35f4e664d44 100644 --- a/pkgs/by-name/sf/sfizz/package.nix +++ b/pkgs/by-name/sf/sfizz/package.nix @@ -1,6 +1,23 @@ -{ lib, stdenv, fetchFromGitHub, libjack2, libsndfile, xorg, freetype -, libxkbcommon, cairo, glib, zenity, flac, libogg, libvorbis, libopus, cmake -, pango, pkg-config, catch2 +{ + lib, + stdenv, + fetchFromGitHub, + libjack2, + libsndfile, + xorg, + freetype, + libxkbcommon, + cairo, + glib, + zenity, + flac, + libogg, + libvorbis, + libopus, + cmake, + pango, + pkg-config, + catch2, }: stdenv.mkDerivation rec { @@ -38,10 +55,13 @@ stdenv.mkDerivation rec { freetype pango ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; # Fix missing include - patches = [./gcc13.patch]; + patches = [ ./gcc13.patch ]; postPatch = '' cp ${catch2}/include/catch2/catch.hpp tests/catch2/catch.hpp diff --git a/pkgs/by-name/sf/sfm/package.nix b/pkgs/by-name/sf/sfm/package.nix index 8a3aaee4418e96..55ba36cf83aba7 100644 --- a/pkgs/by-name/sf/sfm/package.nix +++ b/pkgs/by-name/sf/sfm/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, writeText, conf ? null }: +{ + lib, + stdenv, + fetchFromGitHub, + writeText, + conf ? null, +}: stdenv.mkDerivation rec { pname = "sfm"; @@ -11,9 +17,9 @@ stdenv.mkDerivation rec { hash = "sha256-VwPux6n+azpR4qDkzZJia95pJJOaFDBBoz6/VwlC0zw="; }; - configFile = lib.optionalString (conf!=null) (writeText "config.def.h" conf); + configFile = lib.optionalString (conf != null) (writeText "config.def.h" conf); - postPatch = lib.optionalString (conf!=null) "cp ${configFile} config.def.h"; + postPatch = lib.optionalString (conf != null) "cp ${configFile} config.def.h"; makeFlags = [ "CC:=$(CC)" ]; diff --git a/pkgs/by-name/sf/sfrotz/package.nix b/pkgs/by-name/sf/sfrotz/package.nix index 49f903b8610119..5a798b5f03b708 100644 --- a/pkgs/by-name/sf/sfrotz/package.nix +++ b/pkgs/by-name/sf/sfrotz/package.nix @@ -1,23 +1,26 @@ -{ fetchFromGitLab -, freetype -, libao -, libjpeg -, libmodplug -, libpng -, libsamplerate -, libsndfile -, libvorbis -, pkg-config -, SDL2 -, SDL2_mixer -, lib, stdenv -, zlib }: +{ + fetchFromGitLab, + freetype, + libao, + libjpeg, + libmodplug, + libpng, + libsamplerate, + libsndfile, + libvorbis, + pkg-config, + SDL2, + SDL2_mixer, + lib, + stdenv, + zlib, +}: stdenv.mkDerivation rec { pname = "sfrotz"; version = "2.54"; - src = fetchFromGitLab { + src = fetchFromGitLab { domain = "gitlab.com"; owner = "DavidGriffith"; repo = "frotz"; @@ -44,8 +47,7 @@ stdenv.mkDerivation rec { installTargets = [ "install_sfrotz" ]; meta = with lib; { - description = - "Interpreter for Infocom and other Z-Machine games (SDL interface)"; + description = "Interpreter for Infocom and other Z-Machine games (SDL interface)"; mainProgram = "sfrotz"; longDescription = '' Frotz is a Z-Machine interpreter. The Z-machine is a virtual machine diff --git a/pkgs/by-name/sf/sfsexp/package.nix b/pkgs/by-name/sf/sfsexp/package.nix index 3d047ccd7f50de..c7e9cde3ad1ea6 100644 --- a/pkgs/by-name/sf/sfsexp/package.nix +++ b/pkgs/by-name/sf/sfsexp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "sfsexp"; diff --git a/pkgs/by-name/sf/sftpgo/package.nix b/pkgs/by-name/sf/sftpgo/package.nix index bf7c1b8d650d69..a5d0edde103c91 100644 --- a/pkgs/by-name/sf/sftpgo/package.nix +++ b/pkgs/by-name/sf/sftpgo/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + nixosTests, }: buildGoModule rec { @@ -58,7 +59,10 @@ buildGoModule rec { local filesystem, encrypted local filesystem, S3 (compatible) Object Storage, Google Cloud Storage, Azure Blob Storage, SFTP. ''; - license = with licenses; [ agpl3Only unfreeRedistributable ]; # Software is AGPLv3, web UI is unfree + license = with licenses; [ + agpl3Only + unfreeRedistributable + ]; # Software is AGPLv3, web UI is unfree maintainers = with maintainers; [ thenonameguy ]; mainProgram = "sftpgo"; }; diff --git a/pkgs/by-name/sf/sftpman/package.nix b/pkgs/by-name/sf/sftpman/package.nix index 579c03992ddefb..c0274be1de797f 100644 --- a/pkgs/by-name/sf/sftpman/package.nix +++ b/pkgs/by-name/sf/sftpman/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "sftpman"; diff --git a/pkgs/by-name/sf/sfxr/package.nix b/pkgs/by-name/sf/sfxr/package.nix index 03813ff35248df..5f2fe5e75d87ef 100644 --- a/pkgs/by-name/sf/sfxr/package.nix +++ b/pkgs/by-name/sf/sfxr/package.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, fetchurl -, fetchpatch -, pkg-config -, desktop-file-utils -, SDL -, gtk3 -, gsettings-desktop-schemas -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + desktop-file-utils, + SDL, + gtk3, + gsettings-desktop-schemas, + wrapGAppsHook3, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sf/sfz/package.nix b/pkgs/by-name/sf/sfz/package.nix index 768afed6679d1a..c50f9985dbb2fd 100644 --- a/pkgs/by-name/sf/sfz/package.nix +++ b/pkgs/by-name/sf/sfz/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "sfz"; @@ -19,7 +23,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Simple static file serving command-line tool written in Rust"; homepage = "https://github.com/weihanglo/sfz"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ dit7ya ]; mainProgram = "sfz"; }; diff --git a/pkgs/by-name/sg/sg3_utils/package.nix b/pkgs/by-name/sg/sg3_utils/package.nix index 3975a5927f475f..a5951ab87eafd7 100644 --- a/pkgs/by-name/sg/sg3_utils/package.nix +++ b/pkgs/by-name/sg/sg3_utils/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "sg3_utils"; @@ -13,6 +17,9 @@ stdenv.mkDerivation rec { homepage = "https://sg.danny.cz/sg/"; description = "Utilities that send SCSI commands to devices"; platforms = platforms.linux; - license = with licenses; [ bsd2 gpl2Plus ]; + license = with licenses; [ + bsd2 + gpl2Plus + ]; }; } diff --git a/pkgs/by-name/sg/sgfutils/package.nix b/pkgs/by-name/sg/sgfutils/package.nix index 586a3ab1e096d6..106dfb788e8251 100644 --- a/pkgs/by-name/sg/sgfutils/package.nix +++ b/pkgs/by-name/sg/sgfutils/package.nix @@ -1,14 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, openssl -, libiconv -, makeWrapper -, imagemagick -, makeFontsConf -}: -stdenv.mkDerivation { + lib, + stdenv, + fetchFromGitHub, + openssl, + libiconv, + makeWrapper, + imagemagick, + makeFontsConf, +}: +stdenv.mkDerivation { pname = "sgfutils"; version = "0.25-unstable-2017-11-27"; src = fetchFromGitHub { @@ -36,7 +36,7 @@ stdenv.mkDerivation postFixup = '' wrapProgram $out/bin/sgftopng \ --prefix PATH : ${lib.makeBinPath [ imagemagick ]} \ - --set-default FONTCONFIG_FILE ${makeFontsConf { fontDirectories = []; }} + --set-default FONTCONFIG_FILE ${makeFontsConf { fontDirectories = [ ]; }} ''; meta = with lib; { homepage = "https://homepages.cwi.nl/~aeb/go/sgfutils/html/sgfutils.html"; diff --git a/pkgs/by-name/sg/sgp4/package.nix b/pkgs/by-name/sg/sgp4/package.nix index b2095e93aa11b8..be069dead65bb4 100644 --- a/pkgs/by-name/sg/sgp4/package.nix +++ b/pkgs/by-name/sg/sgp4/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation { pname = "sgp4"; diff --git a/pkgs/by-name/sg/sgrep/package.nix b/pkgs/by-name/sg/sgrep/package.nix index 4b7476e55f6d0c..4c93b1b6954e23 100644 --- a/pkgs/by-name/sg/sgrep/package.nix +++ b/pkgs/by-name/sg/sgrep/package.nix @@ -1,4 +1,12 @@ -{ stdenv, sgrep, fetchurl, runCommand, lib, m4, makeWrapper }: +{ + stdenv, + sgrep, + fetchurl, + runCommand, + lib, + m4, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "sgrep"; diff --git a/pkgs/by-name/sg/sgx-azure-dcap-client/package.nix b/pkgs/by-name/sg/sgx-azure-dcap-client/package.nix index 99e5c4b1a09c13..2ccace2d3c27f9 100644 --- a/pkgs/by-name/sg/sgx-azure-dcap-client/package.nix +++ b/pkgs/by-name/sg/sgx-azure-dcap-client/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, fetchFromGitHub -, fetchpatch -, lib -, curl -, nlohmann_json -, openssl -, pkg-config -, linkFarmFromDrvs -, callPackage +{ + stdenv, + fetchFromGitHub, + fetchpatch, + lib, + curl, + nlohmann_json, + openssl, + pkg-config, + linkFarmFromDrvs, + callPackage, }: let # Although those headers are also included in the source of `sgx-psw`, the `azure-dcap-client` build needs specific versions @@ -87,7 +88,11 @@ stdenv.mkDerivation rec { meta = { description = "Interfaces between SGX SDKs and the Azure Attestation SGX Certification Cache"; homepage = "https://github.com/microsoft/azure-dcap-client"; - maintainers = with lib.maintainers; [ phlip9 trundle veehaitch ]; + maintainers = with lib.maintainers; [ + phlip9 + trundle + veehaitch + ]; platforms = [ "x86_64-linux" ]; license = [ lib.licenses.mit ]; }; diff --git a/pkgs/by-name/sg/sgx-azure-dcap-client/test-suite.nix b/pkgs/by-name/sg/sgx-azure-dcap-client/test-suite.nix index 40d80ece8abfba..5363efd55835a4 100644 --- a/pkgs/by-name/sg/sgx-azure-dcap-client/test-suite.nix +++ b/pkgs/by-name/sg/sgx-azure-dcap-client/test-suite.nix @@ -1,7 +1,8 @@ -{ lib -, sgx-azure-dcap-client -, gtest -, makeWrapper +{ + lib, + sgx-azure-dcap-client, + gtest, + makeWrapper, }: sgx-azure-dcap-client.overrideAttrs (old: { nativeBuildInputs = old.nativeBuildInputs ++ [ @@ -9,7 +10,7 @@ sgx-azure-dcap-client.overrideAttrs (old: { gtest ]; - patches = (old.patches or []) ++ [ + patches = (old.patches or [ ]) ++ [ ./tests-missing-includes.patch ]; diff --git a/pkgs/by-name/sg/sgx-ssl/package.nix b/pkgs/by-name/sg/sgx-ssl/package.nix index 73cde2e030af4a..f67a960ace58e6 100644 --- a/pkgs/by-name/sg/sgx-ssl/package.nix +++ b/pkgs/by-name/sg/sgx-ssl/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, callPackage -, fetchFromGitHub -, fetchurl -, lib -, perl -, sgx-sdk -, which -, debug ? false +{ + stdenv, + callPackage, + fetchFromGitHub, + fetchurl, + lib, + perl, + sgx-sdk, + which, + debug ? false, }: let sgxVersion = sgx-sdk.versionTag; @@ -49,11 +50,13 @@ stdenv.mkDerivation { which ]; - makeFlags = [ - "-C Linux" - ] ++ lib.optionals debug [ - "DEBUG=1" - ]; + makeFlags = + [ + "-C Linux" + ] + ++ lib.optionals debug [ + "DEBUG=1" + ]; installFlags = [ "DESTDIR=$(out)" @@ -67,15 +70,28 @@ stdenv.mkDerivation { # nix run .#sgx-ssl.tests.SIM # ``` passthru.tests = { - HW = callPackage ./tests.nix { sgxMode = "HW"; inherit opensslVersion; }; - SIM = callPackage ./tests.nix { sgxMode = "SIM"; inherit opensslVersion; }; + HW = callPackage ./tests.nix { + sgxMode = "HW"; + inherit opensslVersion; + }; + SIM = callPackage ./tests.nix { + sgxMode = "SIM"; + inherit opensslVersion; + }; }; meta = { description = "Cryptographic library for Intel SGX enclave applications based on OpenSSL"; homepage = "https://github.com/intel/intel-sgx-ssl"; - maintainers = with lib.maintainers; [ phlip9 trundle veehaitch ]; + maintainers = with lib.maintainers; [ + phlip9 + trundle + veehaitch + ]; platforms = [ "x86_64-linux" ]; - license = with lib.licenses; [ bsd3 openssl ]; + license = with lib.licenses; [ + bsd3 + openssl + ]; }; } diff --git a/pkgs/by-name/sg/sgx-ssl/tests.nix b/pkgs/by-name/sg/sgx-ssl/tests.nix index d9357ba0431028..a7cf2b0ea8d3b4 100644 --- a/pkgs/by-name/sg/sgx-ssl/tests.nix +++ b/pkgs/by-name/sg/sgx-ssl/tests.nix @@ -13,38 +13,41 @@ # These tests are split out from the parent pkg since recompiling the parent # takes like 30 min : ) -{ lib -, openssl -, sgx-psw -, sgx-sdk -, sgx-ssl -, stdenv -, which -, opensslVersion ? throw "required parameter" -, sgxMode ? throw "required parameter" # "SIM" or "HW" +{ + lib, + openssl, + sgx-psw, + sgx-sdk, + sgx-ssl, + stdenv, + which, + opensslVersion ? throw "required parameter", + sgxMode ? throw "required parameter", # "SIM" or "HW" }: stdenv.mkDerivation { inherit (sgx-ssl) postPatch src version; pname = sgx-ssl.pname + "-tests-${sgxMode}"; - postUnpack = sgx-ssl.postUnpack + '' - sourceRootAbs=$(readlink -e $sourceRoot) - packageDir=$sourceRootAbs/Linux/package + postUnpack = + sgx-ssl.postUnpack + + '' + sourceRootAbs=$(readlink -e $sourceRoot) + packageDir=$sourceRootAbs/Linux/package - # Do the inverse of 'make install' and symlink built artifacts back into - # '$src/Linux/package/' to avoid work. - mkdir $packageDir/lib $packageDir/lib64 - ln -s ${lib.getLib sgx-ssl}/lib/* $packageDir/lib/ - ln -s ${lib.getLib sgx-ssl}/lib64/* $packageDir/lib64/ - ln -sf ${lib.getDev sgx-ssl}/include/* $packageDir/include/ + # Do the inverse of 'make install' and symlink built artifacts back into + # '$src/Linux/package/' to avoid work. + mkdir $packageDir/lib $packageDir/lib64 + ln -s ${lib.getLib sgx-ssl}/lib/* $packageDir/lib/ + ln -s ${lib.getLib sgx-ssl}/lib64/* $packageDir/lib64/ + ln -sf ${lib.getDev sgx-ssl}/include/* $packageDir/include/ - # test_app needs some internal openssl headers. - # See: tail end of 'Linux/build_openssl.sh' - tar -C $sourceRootAbs/openssl_source -xf $sourceRootAbs/openssl_source/openssl-${opensslVersion}.tar.gz - echo '#define OPENSSL_VERSION_STR "${opensslVersion}"' > $sourceRootAbs/Linux/sgx/osslverstr.h - ln -s $sourceRootAbs/openssl_source/openssl-${opensslVersion}/include/crypto $sourceRootAbs/Linux/sgx/test_app/enclave/ - ln -s $sourceRootAbs/openssl_source/openssl-${opensslVersion}/include/internal $sourceRootAbs/Linux/sgx/test_app/enclave/ - ''; + # test_app needs some internal openssl headers. + # See: tail end of 'Linux/build_openssl.sh' + tar -C $sourceRootAbs/openssl_source -xf $sourceRootAbs/openssl_source/openssl-${opensslVersion}.tar.gz + echo '#define OPENSSL_VERSION_STR "${opensslVersion}"' > $sourceRootAbs/Linux/sgx/osslverstr.h + ln -s $sourceRootAbs/openssl_source/openssl-${opensslVersion}/include/crypto $sourceRootAbs/Linux/sgx/test_app/enclave/ + ln -s $sourceRootAbs/openssl_source/openssl-${opensslVersion}/include/internal $sourceRootAbs/Linux/sgx/test_app/enclave/ + ''; nativeBuildInputs = [ openssl.bin diff --git a/pkgs/by-name/sh/sha1collisiondetection/package.nix b/pkgs/by-name/sh/sha1collisiondetection/package.nix index 07c9ed9b240834..4f65e3034f1615 100644 --- a/pkgs/by-name/sh/sha1collisiondetection/package.nix +++ b/pkgs/by-name/sh/sha1collisiondetection/package.nix @@ -1,6 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libtool, which }: +{ + lib, + stdenv, + fetchFromGitHub, + libtool, + which, +}: -stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "sha1collisiondetection"; version = "1.0.3"; @@ -15,7 +21,10 @@ stdenv.mkDerivation rec { doCheck = true; - nativeBuildInputs = [ libtool which ]; + nativeBuildInputs = [ + libtool + which + ]; meta = with lib; { description = "Library and command line tool to detect SHA-1 collision"; @@ -26,7 +35,7 @@ stdenv.mkDerivation rec { detect cryptanalytic collision attacks against SHA-1 present in each file. It is very fast and takes less than twice the amount of time as regular SHA-1. - ''; + ''; platforms = platforms.all; maintainers = with maintainers; [ leenaars ]; license = licenses.mit; diff --git a/pkgs/by-name/sh/sha2wordlist/package.nix b/pkgs/by-name/sh/sha2wordlist/package.nix index c3a6710efb1765..e84c045284e6a6 100644 --- a/pkgs/by-name/sh/sha2wordlist/package.nix +++ b/pkgs/by-name/sh/sha2wordlist/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, libbsd +{ + lib, + stdenv, + fetchFromGitHub, + libbsd, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/sh/shab/package.nix b/pkgs/by-name/sh/shab/package.nix index 25e2baf034e205..ee4fca701e4b4a 100644 --- a/pkgs/by-name/sh/shab/package.nix +++ b/pkgs/by-name/sh/shab/package.nix @@ -1,4 +1,11 @@ -{ bash, stdenv, lib, runCommand, writeText, fetchFromGitHub }: +{ + bash, + stdenv, + lib, + runCommand, + writeText, + fetchFromGitHub, +}: let version = "1.0.0"; @@ -53,12 +60,15 @@ let shabScript: a path or filename to use as a template parameters.name: the name to use as part of the store path parameters: variables to expose to the template - */ - render = shabScript: parameters: - let extraParams = { - inherit shabScript; - }; - in runCommand "out" (parameters // extraParams) '' + */ + render = + shabScript: parameters: + let + extraParams = { + inherit shabScript; + }; + in + runCommand "out" (parameters // extraParams) '' ${shab}/bin/shab "$shabScript" >$out ''; @@ -66,9 +76,8 @@ let shabScriptText: a string to use as a template parameters.name: the name to use as part of the store path parameters: variables to expose to the template - */ - renderText = shabScriptText: parameters: - render (writeText "template" shabScriptText) parameters; + */ + renderText = shabScriptText: parameters: render (writeText "template" shabScriptText) parameters; in - shab +shab diff --git a/pkgs/by-name/sh/shabnam-fonts/package.nix b/pkgs/by-name/sh/shabnam-fonts/package.nix index fd8f146eb35585..8676e7310ffa59 100644 --- a/pkgs/by-name/sh/shabnam-fonts/package.nix +++ b/pkgs/by-name/sh/shabnam-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "shabnam-fonts"; diff --git a/pkgs/by-name/sh/shadered/package.nix b/pkgs/by-name/sh/shadered/package.nix index cebb9704d180b9..ff9d322b98548d 100644 --- a/pkgs/by-name/sh/shadered/package.nix +++ b/pkgs/by-name/sh/shadered/package.nix @@ -1,13 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, sfml -, glm -, python3 -, glew -, pkg-config -, SDL2 }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + sfml, + glm, + python3, + glew, + pkg-config, + SDL2, +}: stdenv.mkDerivation rec { pname = "SHADERed"; diff --git a/pkgs/by-name/sh/shadershark/package.nix b/pkgs/by-name/sh/shadershark/package.nix index 8585dd8c015a87..a9fc8bb1384db0 100644 --- a/pkgs/by-name/sh/shadershark/package.nix +++ b/pkgs/by-name/sh/shadershark/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchhg -, libepoxy -, xorg -, libGLU -, glm -, pkg-config -, imagemagick -, makeWrapper -, installShellFiles -, genericUpdater -, writeShellScript +{ + stdenv, + lib, + fetchhg, + libepoxy, + xorg, + libGLU, + glm, + pkg-config, + imagemagick, + makeWrapper, + installShellFiles, + genericUpdater, + writeShellScript, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sh/shades-of-gray-theme/package.nix b/pkgs/by-name/sh/shades-of-gray-theme/package.nix index e4c4cfb3ba51ef..6a4f1bad37a117 100644 --- a/pkgs/by-name/sh/shades-of-gray-theme/package.nix +++ b/pkgs/by-name/sh/shades-of-gray-theme/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, gtk_engines, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchFromGitHub, + gtk_engines, + gtk-engine-murrine, +}: stdenv.mkDerivation rec { pname = "shades-of-gray-theme"; diff --git a/pkgs/by-name/sh/shadow-tls/package.nix b/pkgs/by-name/sh/shadow-tls/package.nix index 481729feff67f9..b0219c46f26b85 100644 --- a/pkgs/by-name/sh/shadow-tls/package.nix +++ b/pkgs/by-name/sh/shadow-tls/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: -rustPlatform.buildRustPackage rec{ +rustPlatform.buildRustPackage rec { pname = "shadow-tls"; version = "0.2.25"; diff --git a/pkgs/by-name/sh/shadowfox/package.nix b/pkgs/by-name/sh/shadowfox/package.nix index d9fca5d4011e26..3fb2b145bff529 100644 --- a/pkgs/by-name/sh/shadowfox/package.nix +++ b/pkgs/by-name/sh/shadowfox/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, fetchpatch }: +{ + lib, + fetchFromGitHub, + buildGoModule, + fetchpatch, +}: buildGoModule rec { pname = "shadowfox"; diff --git a/pkgs/by-name/sh/shadowsocks-libev/package.nix b/pkgs/by-name/sh/shadowsocks-libev/package.nix index b6544c60edaff8..60d41aa39e0f3f 100644 --- a/pkgs/by-name/sh/shadowsocks-libev/package.nix +++ b/pkgs/by-name/sh/shadowsocks-libev/package.nix @@ -1,6 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, libsodium, mbedtls_2, libev, c-ares, pcre -, asciidoc, xmlto, docbook_xml_dtd_45, docbook_xsl, libxslt +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libsodium, + mbedtls_2, + libev, + c-ares, + pcre, + asciidoc, + xmlto, + docbook_xml_dtd_45, + docbook_xsl, + libxslt, }: stdenv.mkDerivation rec { @@ -16,11 +28,25 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - buildInputs = [ libsodium mbedtls_2 libev c-ares pcre ]; - nativeBuildInputs = [ cmake asciidoc xmlto docbook_xml_dtd_45 - docbook_xsl libxslt ]; + buildInputs = [ + libsodium + mbedtls_2 + libev + c-ares + pcre + ]; + nativeBuildInputs = [ + cmake + asciidoc + xmlto + docbook_xml_dtd_45 + docbook_xsl + libxslt + ]; - cmakeFlags = [ "-DWITH_STATIC=OFF" "-DCMAKE_BUILD_WITH_INSTALL_NAME_DIR=ON" + cmakeFlags = [ + "-DWITH_STATIC=OFF" + "-DCMAKE_BUILD_WITH_INSTALL_NAME_DIR=ON" # RPATH of binary /nix/store/.../bin/... contains a forbidden reference to /build/ "-DCMAKE_SKIP_BUILD_RPATH=ON" ]; diff --git a/pkgs/by-name/sh/shadowsocks-v2ray-plugin/package.nix b/pkgs/by-name/sh/shadowsocks-v2ray-plugin/package.nix index 12117252abf68a..b1192385c714a0 100644 --- a/pkgs/by-name/sh/shadowsocks-v2ray-plugin/package.nix +++ b/pkgs/by-name/sh/shadowsocks-v2ray-plugin/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "shadowsocks-v2ray-plugin"; @@ -25,4 +29,3 @@ buildGoModule rec { mainProgram = "v2ray-plugin"; }; } - diff --git a/pkgs/by-name/sh/shairport-sync/package.nix b/pkgs/by-name/sh/shairport-sync/package.nix index a667dbec02576d..364e5c4009e899 100644 --- a/pkgs/by-name/sh/shairport-sync/package.nix +++ b/pkgs/by-name/sh/shairport-sync/package.nix @@ -1,49 +1,50 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, openssl -, avahi -, alsa-lib -, libplist -, glib -, libdaemon -, libsodium -, libgcrypt -, ffmpeg -, libuuid -, unixtools -, popt -, libconfig -, libpulseaudio -, libjack2 -, libsndfile -, libao -, libsoundio -, mosquitto -, pipewire -, soxr -, alac -, sndio -, enableAirplay2 ? false -, enableStdout ? true -, enableAlsa ? true -, enableSndio ? true -, enablePulse ? true -, enablePipe ? true -, enablePipewire ? true -, enableAo ? true -, enableJack ? true -, enableSoundio ? true -, enableMetadata ? true -, enableMpris ? stdenv.hostPlatform.isLinux -, enableMqttClient ? true -, enableDbus ? stdenv.hostPlatform.isLinux -, enableSoxr ? true -, enableAlac ? true -, enableConvolution ? true -, enableLibdaemon ? false +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + openssl, + avahi, + alsa-lib, + libplist, + glib, + libdaemon, + libsodium, + libgcrypt, + ffmpeg, + libuuid, + unixtools, + popt, + libconfig, + libpulseaudio, + libjack2, + libsndfile, + libao, + libsoundio, + mosquitto, + pipewire, + soxr, + alac, + sndio, + enableAirplay2 ? false, + enableStdout ? true, + enableAlsa ? true, + enableSndio ? true, + enablePulse ? true, + enablePipe ? true, + enablePipewire ? true, + enableAo ? true, + enableJack ? true, + enableSoundio ? true, + enableMetadata ? true, + enableMpris ? stdenv.hostPlatform.isLinux, + enableMqttClient ? true, + enableDbus ? stdenv.hostPlatform.isLinux, + enableSoxr ? true, + enableAlac ? true, + enableConvolution ? true, + enableLibdaemon ? false, }: let @@ -61,45 +62,48 @@ stdenv.mkDerivation rec { hash = "sha256-GYu/n4JoghqUHnkCiSQJYm9WSLww585WKgXTEiWGq4g="; }; - nativeBuildInputs = [ - autoreconfHook - pkg-config - # For glib we want the `dev` output for the same library we are - # also linking against, since pkgsHostTarget.glib.dev exposes - # some extra tools that are built for build->host execution. - # To achieve this, we coerce the output to a string to prevent - # mkDerivation's splicing logic from kicking in. - "${glib.dev}" - ] ++ optional enableAirplay2 [ - unixtools.xxd - ]; + nativeBuildInputs = + [ + autoreconfHook + pkg-config + # For glib we want the `dev` output for the same library we are + # also linking against, since pkgsHostTarget.glib.dev exposes + # some extra tools that are built for build->host execution. + # To achieve this, we coerce the output to a string to prevent + # mkDerivation's splicing logic from kicking in. + "${glib.dev}" + ] + ++ optional enableAirplay2 [ + unixtools.xxd + ]; - buildInputs = [ - openssl - avahi - popt - libconfig - ] - ++ optional enableLibdaemon libdaemon - ++ optional enableAlsa alsa-lib - ++ optional enableSndio sndio - ++ optional enableMqttClient mosquitto - ++ optional enablePulse libpulseaudio - ++ optional enablePipewire pipewire - ++ optional enableAo libao - ++ optional enableJack libjack2 - ++ optional enableSoundio libsoundio - ++ optional enableSoxr soxr - ++ optional enableAlac alac - ++ optional enableConvolution libsndfile - ++ optionals enableAirplay2 [ - libplist - libsodium - libgcrypt - libuuid - ffmpeg - ] - ++ optional stdenv.hostPlatform.isLinux glib; + buildInputs = + [ + openssl + avahi + popt + libconfig + ] + ++ optional enableLibdaemon libdaemon + ++ optional enableAlsa alsa-lib + ++ optional enableSndio sndio + ++ optional enableMqttClient mosquitto + ++ optional enablePulse libpulseaudio + ++ optional enablePipewire pipewire + ++ optional enableAo libao + ++ optional enableJack libjack2 + ++ optional enableSoundio libsoundio + ++ optional enableSoxr soxr + ++ optional enableAlac alac + ++ optional enableConvolution libsndfile + ++ optionals enableAirplay2 [ + libplist + libsodium + libgcrypt + libuuid + ffmpeg + ] + ++ optional stdenv.hostPlatform.isLinux glib; postPatch = '' sed -i -e 's/G_BUS_TYPE_SYSTEM/G_BUS_TYPE_SESSION/g' dbus-service.c @@ -108,31 +112,32 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - configureFlags = [ - "--without-configfiles" - "--sysconfdir=/etc" - "--with-ssl=openssl" - "--with-stdout" - "--with-avahi" - ] - ++ optional enablePulse "--with-pa" - ++ optional enablePipewire "--with-pw" - ++ optional enableAlsa "--with-alsa" - ++ optional enableSndio "--with-sndio" - ++ optional enableAo "--with-ao" - ++ optional enableJack "--with-jack" - ++ optional enableSoundio "--with-soundio" - ++ optional enableStdout "--with-stdout" - ++ optional enablePipe "--with-pipe" - ++ optional enableSoxr "--with-soxr" - ++ optional enableAlac "--with-apple-alac" - ++ optional enableConvolution "--with-convolution" - ++ optional enableDbus "--with-dbus-interface" - ++ optional enableMetadata "--with-metadata" - ++ optional enableMpris "--with-mpris-interface" - ++ optional enableMqttClient "--with-mqtt-client" - ++ optional enableLibdaemon "--with-libdaemon" - ++ optional enableAirplay2 "--with-airplay-2"; + configureFlags = + [ + "--without-configfiles" + "--sysconfdir=/etc" + "--with-ssl=openssl" + "--with-stdout" + "--with-avahi" + ] + ++ optional enablePulse "--with-pa" + ++ optional enablePipewire "--with-pw" + ++ optional enableAlsa "--with-alsa" + ++ optional enableSndio "--with-sndio" + ++ optional enableAo "--with-ao" + ++ optional enableJack "--with-jack" + ++ optional enableSoundio "--with-soundio" + ++ optional enableStdout "--with-stdout" + ++ optional enablePipe "--with-pipe" + ++ optional enableSoxr "--with-soxr" + ++ optional enableAlac "--with-apple-alac" + ++ optional enableConvolution "--with-convolution" + ++ optional enableDbus "--with-dbus-interface" + ++ optional enableMetadata "--with-metadata" + ++ optional enableMpris "--with-mpris-interface" + ++ optional enableMqttClient "--with-mqtt-client" + ++ optional enableLibdaemon "--with-libdaemon" + ++ optional enableAirplay2 "--with-airplay-2"; strictDeps = true; @@ -141,7 +146,10 @@ stdenv.mkDerivation rec { description = "Airtunes server and emulator with multi-room capabilities"; license = lib.licenses.mit; mainProgram = "shairport-sync"; - maintainers = with lib.maintainers; [ lnl7 jordanisaacs ]; + maintainers = with lib.maintainers; [ + lnl7 + jordanisaacs + ]; platforms = lib.platforms.unix; }; } diff --git a/pkgs/by-name/sh/shallot/package.nix b/pkgs/by-name/sh/shallot/package.nix index 4fbd07f38e329e..c03097e20410c6 100644 --- a/pkgs/by-name/sh/shallot/package.nix +++ b/pkgs/by-name/sh/shallot/package.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + openssl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sh/shanggu-fonts/package.nix b/pkgs/by-name/sh/shanggu-fonts/package.nix index 96d366dedf1fb7..8de63b3266e974 100644 --- a/pkgs/by-name/sh/shanggu-fonts/package.nix +++ b/pkgs/by-name/sh/shanggu-fonts/package.nix @@ -34,15 +34,18 @@ stdenvNoCC.mkDerivation { nativeBuildInputs = [ p7zip ]; - unpackPhase = '' - runHook preUnpack - '' + lib.strings.concatLines ( - lib.attrsets.mapAttrsToList (name: value: '' - 7z x ${value} -o${name} - '') source - ) + '' - runHook postUnpack - ''; + unpackPhase = + '' + runHook preUnpack + '' + + lib.strings.concatLines ( + lib.attrsets.mapAttrsToList (name: value: '' + 7z x ${value} -o${name} + '') source + ) + + '' + runHook postUnpack + ''; installPhase = '' @@ -55,7 +58,8 @@ stdenvNoCC.mkDerivation { install -Dm444 ${name}/*.ttc -t ${placeholder name}/share/fonts/truetype ln -s "${placeholder name}" /share/fonts/truetype/*.ttc $out/share/fonts/truetype '') - ) + '' + ) + + '' runHook postInstall ''; diff --git a/pkgs/by-name/sh/shapelib/package.nix b/pkgs/by-name/sh/shapelib/package.nix index fe93064e3f1f1c..f906d315570365 100644 --- a/pkgs/by-name/sh/shapelib/package.nix +++ b/pkgs/by-name/sh/shapelib/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sh/shaq/package.nix b/pkgs/by-name/sh/shaq/package.nix index d615a95219cb5e..ff7abe883a6bcb 100644 --- a/pkgs/by-name/sh/shaq/package.nix +++ b/pkgs/by-name/sh/shaq/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, ffmpeg +{ + lib, + python3, + fetchFromGitHub, + ffmpeg, }: python3.pkgs.buildPythonApplication rec { @@ -58,7 +59,10 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://github.com/woodruffw/shaq"; changelog = "https://github.com/woodruffw/shaq/releases/tag/${src.rev}"; license = licenses.mit; - maintainers = with maintainers; [ figsoda mig4ng ]; + maintainers = with maintainers; [ + figsoda + mig4ng + ]; mainProgram = "shaq"; }; } diff --git a/pkgs/by-name/sh/share-preview/package.nix b/pkgs/by-name/sh/share-preview/package.nix index 4f3cda10bd763a..fd9d73de29c22a 100644 --- a/pkgs/by-name/sh/share-preview/package.nix +++ b/pkgs/by-name/sh/share-preview/package.nix @@ -43,13 +43,15 @@ stdenv.mkDerivation (finalAttrs: { desktop-file-utils ]; - buildInputs = [ - libadwaita - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + libadwaita + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + darwin.apple_sdk.frameworks.SystemConfiguration + ]; env.NIX_CFLAGS_COMPILE = toString ( lib.optionals stdenv.hostPlatform.isDarwin [ "-Wno-error=incompatible-function-pointer-types" ] diff --git a/pkgs/by-name/sh/shared-mime-info/package.nix b/pkgs/by-name/sh/shared-mime-info/package.nix index e5507075bcaeda..fe45a0287b987d 100644 --- a/pkgs/by-name/sh/shared-mime-info/package.nix +++ b/pkgs/by-name/sh/shared-mime-info/package.nix @@ -1,20 +1,24 @@ -{ stdenv -, lib -, fetchFromGitLab -, meson -, ninja -, pkg-config -, gettext -, libxml2 -, glib -, shared-mime-info +{ + stdenv, + lib, + fetchFromGitLab, + meson, + ninja, + pkg-config, + gettext, + libxml2, + glib, + shared-mime-info, }: stdenv.mkDerivation rec { pname = "shared-mime-info"; version = "2.4"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitLab { domain = "gitlab.freedesktop.org"; diff --git a/pkgs/by-name/sh/shared_desktop_ontologies/package.nix b/pkgs/by-name/sh/shared_desktop_ontologies/package.nix index fdbd2991cdeed7..f5aea74954704c 100644 --- a/pkgs/by-name/sh/shared_desktop_ontologies/package.nix +++ b/pkgs/by-name/sh/shared_desktop_ontologies/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, cmake }: +{ + lib, + stdenv, + fetchurl, + cmake, +}: stdenv.mkDerivation rec { pname = "shared-desktop-ontologies"; diff --git a/pkgs/by-name/sh/sharing/package.nix b/pkgs/by-name/sh/sharing/package.nix index dd5df06ad46de4..9292ebf5c89423 100644 --- a/pkgs/by-name/sh/sharing/package.nix +++ b/pkgs/by-name/sh/sharing/package.nix @@ -1,6 +1,7 @@ -{ buildNpmPackage -, fetchFromGitHub -, lib +{ + buildNpmPackage, + fetchFromGitHub, + lib, }: buildNpmPackage rec { diff --git a/pkgs/by-name/sh/sharness/package.nix b/pkgs/by-name/sh/sharness/package.nix index 7829b0009b498a..df23130742fc2d 100644 --- a/pkgs/by-name/sh/sharness/package.nix +++ b/pkgs/by-name/sh/sharness/package.nix @@ -1,9 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, perl -, perlPackages -, sharnessExtensions ? {} }: +{ + stdenv, + lib, + fetchFromGitHub, + perl, + perlPackages, + sharnessExtensions ? { }, +}: stdenv.mkDerivation (finalAttrs: { pname = "sharness"; @@ -17,15 +19,21 @@ stdenv.mkDerivation (finalAttrs: { }; # Used for testing - nativeBuildInputs = [ perl perlPackages.IOTty ]; + nativeBuildInputs = [ + perl + perlPackages.IOTty + ]; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; makeFlags = [ "prefix=$(out)" ]; extensions = lib.mapAttrsToList (k: v: "${k}.sh ${v}") sharnessExtensions; - postInstall = lib.optionalString (sharnessExtensions != {}) '' + postInstall = lib.optionalString (sharnessExtensions != { }) '' extDir=$out/share/sharness/sharness.d mkdir -p "$extDir" linkExtensions() { diff --git a/pkgs/by-name/sh/sharpsat-td/package.nix b/pkgs/by-name/sh/sharpsat-td/package.nix index 4c5e22ba9b4f28..88515bc32acb65 100644 --- a/pkgs/by-name/sh/sharpsat-td/package.nix +++ b/pkgs/by-name/sh/sharpsat-td/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchzip -, cmake -, gmp -, mpfr +{ + lib, + stdenv, + fetchFromGitHub, + fetchzip, + cmake, + gmp, + mpfr, }: let @@ -22,7 +23,8 @@ let sha256 = "sha256-l61SKEx4pBocADrEGPVacQ6F2ep9IuvNZ8W08dKeZKg="; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "sharpsat-td"; version = "unstable-2021-09-05"; @@ -49,7 +51,10 @@ in stdenv.mkDerivation rec { ''; nativeBuildInputs = [ cmake ]; - buildInputs = [ gmp mpfr ]; + buildInputs = [ + gmp + mpfr + ]; installPhase = '' runHook preInstall @@ -75,9 +80,15 @@ in stdenv.mkDerivation rec { meta = { description = "Fast solver for the #SAT model counting problem"; homepage = "https://github.com/Laakeri/sharpsat-td"; - license = with lib.licenses; [ mit asl20 ]; + license = with lib.licenses; [ + mit + asl20 + ]; maintainers = with lib.maintainers; [ ris ]; # uses clhash, which is non-portable - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; }; } diff --git a/pkgs/by-name/sh/sharutils/package.nix b/pkgs/by-name/sh/sharutils/package.nix index 6a30ae1ff9469f..bc0bd331f4d331 100644 --- a/pkgs/by-name/sh/sharutils/package.nix +++ b/pkgs/by-name/sh/sharutils/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchpatch, gettext, coreutils, updateAutotoolsGnuConfigScriptsHook }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + gettext, + coreutils, + updateAutotoolsGnuConfigScriptsHook, +}: stdenv.mkDerivation rec { pname = "sharutils"; @@ -12,7 +20,10 @@ stdenv.mkDerivation rec { hardeningDisable = [ "format" ]; # GNU Gettext is needed on non-GNU platforms. - buildInputs = [ coreutils gettext ]; + buildInputs = [ + coreutils + gettext + ]; nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook ]; # These tests try to hit /etc/passwd to find out your username if pass in a submitter @@ -46,13 +57,15 @@ stdenv.mkDerivation rec { }) ]; - postPatch = let + postPatch = + let # This evaluates to a string containing: # # substituteInPlace tests/shar-2 --replace '${SHAR}' '${SHAR} -s submitter' # substituteInPlace tests/shar-2 --replace '${SHAR}' '${SHAR} -s submitter' shar_sub = "\${SHAR}"; - in '' + in + '' substituteInPlace tests/shar-1 --replace '${shar_sub}' '${shar_sub} -s submitter' substituteInPlace tests/shar-2 --replace '${shar_sub}' '${shar_sub} -s submitter' @@ -67,21 +80,21 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Tools for remote synchronization and `shell archives'"; longDescription = '' - GNU shar makes so-called shell archives out of many files, preparing - them for transmission by electronic mail services. A shell archive - is a collection of files that can be unpacked by /bin/sh. A wide - range of features provide extensive flexibility in manufacturing - shars and in specifying shar smartness. For example, shar may - compress files, uuencode binary files, split long files and - construct multi-part mailings, ensure correct unsharing order, and - provide simplistic checksums. + GNU shar makes so-called shell archives out of many files, preparing + them for transmission by electronic mail services. A shell archive + is a collection of files that can be unpacked by /bin/sh. A wide + range of features provide extensive flexibility in manufacturing + shars and in specifying shar smartness. For example, shar may + compress files, uuencode binary files, split long files and + construct multi-part mailings, ensure correct unsharing order, and + provide simplistic checksums. - GNU unshar scans a set of mail messages looking for the start of - shell archives. It will automatically strip off the mail headers - and other introductory text. The archive bodies are then unpacked - by a copy of the shell. unshar may also process files containing - concatenated shell archives. - ''; + GNU unshar scans a set of mail messages looking for the start of + shell archives. It will automatically strip off the mail headers + and other introductory text. The archive bodies are then unpacked + by a copy of the shell. unshar may also process files containing + concatenated shell archives. + ''; homepage = "https://www.gnu.org/software/sharutils/"; license = licenses.gpl3Plus; maintainers = [ ]; diff --git a/pkgs/by-name/sh/shavee/package.nix b/pkgs/by-name/sh/shavee/package.nix index 6b6864669622a7..a34066fb880059 100644 --- a/pkgs/by-name/sh/shavee/package.nix +++ b/pkgs/by-name/sh/shavee/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pam -, pkg-config -, openssl -, zlib +{ + lib, + rustPlatform, + fetchFromGitHub, + pam, + pkg-config, + openssl, + zlib, }: rustPlatform.buildRustPackage rec { @@ -30,7 +31,7 @@ rustPlatform.buildRustPackage rec { zlib ]; - # these tests require network access + # these tests require network access checkFlags = [ "--skip=filehash::tests::remote_file_hash" "--skip=filehash::tests::get_filehash_unit_test" diff --git a/pkgs/by-name/sh/shc/package.nix b/pkgs/by-name/sh/shc/package.nix index f7f3f8a088836a..a56a282f716fcd 100644 --- a/pkgs/by-name/sh/shc/package.nix +++ b/pkgs/by-name/sh/shc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "shc"; diff --git a/pkgs/by-name/sh/shell-genie/package.nix b/pkgs/by-name/sh/shell-genie/package.nix index 60b3ce9548ce8b..bc02cbabbf5317 100644 --- a/pkgs/by-name/sh/shell-genie/package.nix +++ b/pkgs/by-name/sh/shell-genie/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: with python3.pkgs; diff --git a/pkgs/by-name/sh/shell-gpt/package.nix b/pkgs/by-name/sh/shell-gpt/package.nix index cafb67f0f0a9a3..85f70a6dfe8b6f 100644 --- a/pkgs/by-name/sh/shell-gpt/package.nix +++ b/pkgs/by-name/sh/shell-gpt/package.nix @@ -26,7 +26,6 @@ python3.pkgs.buildPythonApplication rec { build-system = with python3.pkgs; [ hatchling ]; - propagatedBuildInputs = with python3.pkgs; [ click distro diff --git a/pkgs/by-name/sh/shell-hist/package.nix b/pkgs/by-name/sh/shell-hist/package.nix index ee5d2da6e543dc..f906d7a9b8100b 100644 --- a/pkgs/by-name/sh/shell-hist/package.nix +++ b/pkgs/by-name/sh/shell-hist/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage { pname = "shell-hist"; @@ -16,7 +20,10 @@ rustPlatform.buildRustPackage { meta = with lib; { description = "Inspect your shell history"; homepage = "https://github.com/jamesmunns/shell-hist"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = [ maintainers.spacekookie ]; mainProgram = "shell-hist"; }; diff --git a/pkgs/by-name/sh/shell2http/package.nix b/pkgs/by-name/sh/shell2http/package.nix index f4dbaf9e102082..0a60684c2abb01 100644 --- a/pkgs/by-name/sh/shell2http/package.nix +++ b/pkgs/by-name/sh/shell2http/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, testers -, shell2http +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + shell2http, }: buildGoModule rec { diff --git a/pkgs/by-name/sh/shellclear/package.nix b/pkgs/by-name/sh/shellclear/package.nix index 3ab52fda2a70dc..41ea8f012c8a36 100644 --- a/pkgs/by-name/sh/shellclear/package.nix +++ b/pkgs/by-name/sh/shellclear/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sh/shelldap/package.nix b/pkgs/by-name/sh/shelldap/package.nix index 1b3fd5c5806d5f..2ae32cf0ce21fd 100644 --- a/pkgs/by-name/sh/shelldap/package.nix +++ b/pkgs/by-name/sh/shelldap/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, perlPackages -, shortenPerlShebang +{ + lib, + stdenv, + fetchFromGitHub, + perlPackages, + shortenPerlShebang, }: perlPackages.buildPerlPackage rec { @@ -54,7 +55,10 @@ perlPackages.buildPerlPackage rec { description = "Handy shell-like interface for browsing LDAP servers and editing their content"; changelog = "https://github.com/mahlonsmith/shelldap/blob/v${version}/CHANGELOG"; license = with licenses; [ bsd3 ]; - maintainers = with maintainers; [ clerie tobiasBora ]; + maintainers = with maintainers; [ + clerie + tobiasBora + ]; platforms = platforms.unix; mainProgram = "shelldap"; }; diff --git a/pkgs/by-name/sh/shellharden/package.nix b/pkgs/by-name/sh/shellharden/package.nix index e1965aa2b006fd..7d385ad357b404 100644 --- a/pkgs/by-name/sh/shellharden/package.nix +++ b/pkgs/by-name/sh/shellharden/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "shellharden"; diff --git a/pkgs/by-name/sh/shellhub-agent/package.nix b/pkgs/by-name/sh/shellhub-agent/package.nix index 92ca7ad326f6da..5ac4dac1fc4800 100644 --- a/pkgs/by-name/sh/shellhub-agent/package.nix +++ b/pkgs/by-name/sh/shellhub-agent/package.nix @@ -1,12 +1,13 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script -, makeWrapper -, openssh -, libxcrypt -, testers -, shellhub-agent +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + makeWrapper, + openssh, + libxcrypt, + testers, + shellhub-agent, }: buildGoModule rec { @@ -24,7 +25,11 @@ buildGoModule rec { vendorHash = "sha256-jQNWuOwaAx//wDUVOrMc+ETWWbTCTp/SLwL2guERJB8="; - ldflags = [ "-s" "-w" "-X main.AgentVersion=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.AgentVersion=v${version}" + ]; passthru = { updateScript = nix-update-script { }; @@ -44,8 +49,7 @@ buildGoModule rec { ''; meta = with lib; { - description = - "Enables easy access any Linux device behind firewall and NAT"; + description = "Enables easy access any Linux device behind firewall and NAT"; longDescription = '' ShellHub is a modern SSH server for remotely accessing Linux devices via command line (using any SSH client) or web-based user interface, designed diff --git a/pkgs/by-name/sh/shellnoob/package.nix b/pkgs/by-name/sh/shellnoob/package.nix index ef9488239bd066..c50570333c91e2 100644 --- a/pkgs/by-name/sh/shellnoob/package.nix +++ b/pkgs/by-name/sh/shellnoob/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchFromGitHub, python3 }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + python3, +}: stdenvNoCC.mkDerivation rec { pname = "shellnoob"; diff --git a/pkgs/by-name/sh/shellspec/package.nix b/pkgs/by-name/sh/shellspec/package.nix index b355f0fc023284..367f789456b661 100644 --- a/pkgs/by-name/sh/shellspec/package.nix +++ b/pkgs/by-name/sh/shellspec/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, bash }: +{ + lib, + stdenv, + fetchFromGitHub, + bash, +}: stdenv.mkDerivation rec { pname = "shellspec"; @@ -24,11 +29,9 @@ stdenv.mkDerivation rec { dontBuild = true; meta = with lib; { - description = - "A full-featured BDD unit testing framework for bash, ksh, zsh, dash and all POSIX shells"; + description = "A full-featured BDD unit testing framework for bash, ksh, zsh, dash and all POSIX shells"; homepage = "https://shellspec.info/"; - changelog = - "https://github.com/shellspec/shellspec/releases/tag/${version}"; + changelog = "https://github.com/shellspec/shellspec/releases/tag/${version}"; license = licenses.mit; maintainers = with maintainers; [ j0hax ]; platforms = platforms.unix; diff --git a/pkgs/by-name/sh/shellz/package.nix b/pkgs/by-name/sh/shellz/package.nix index e7d44bd21926f3..b1a263c3fddc20 100644 --- a/pkgs/by-name/sh/shellz/package.nix +++ b/pkgs/by-name/sh/shellz/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/sh/shen-sbcl/package.nix b/pkgs/by-name/sh/shen-sbcl/package.nix index 538f5e7f13565d..fac033bcf2e430 100644 --- a/pkgs/by-name/sh/shen-sbcl/package.nix +++ b/pkgs/by-name/sh/shen-sbcl/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, shen-sources -, sbcl +{ + lib, + stdenv, + fetchurl, + shen-sources, + sbcl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sh/shen-sources/package.nix b/pkgs/by-name/sh/shen-sources/package.nix index 99e72fbea1128e..595467dbe63544 100644 --- a/pkgs/by-name/sh/shen-sources/package.nix +++ b/pkgs/by-name/sh/shen-sources/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sh/shepherd/package.nix b/pkgs/by-name/sh/shepherd/package.nix index 19205b6617c658..6f6313ea003586 100644 --- a/pkgs/by-name/sh/shepherd/package.nix +++ b/pkgs/by-name/sh/shepherd/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, makeWrapper -, nodejs -, fixup-yarn-lock -, yarn +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + makeWrapper, + nodejs, + fixup-yarn-lock, + yarn, }: stdenv.mkDerivation rec { @@ -24,7 +25,7 @@ stdenv.mkDerivation rec { hash = "sha256-tJXJ8ePr5ArAV+0JcuJsTo/B2PUcgsXfZrSDCpna/9k="; }; - nativeBuildInputs = [ + nativeBuildInputs = [ makeWrapper nodejs fixup-yarn-lock diff --git a/pkgs/by-name/sh/sherpa/package.nix b/pkgs/by-name/sh/sherpa/package.nix index b1fbbab8781fbd..16f64236b94187 100644 --- a/pkgs/by-name/sh/sherpa/package.nix +++ b/pkgs/by-name/sh/sherpa/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, autoconf, gfortran, hepmc3, fastjet, lhapdf, rivet, sqlite }: +{ + lib, + stdenv, + fetchurl, + autoconf, + gfortran, + hepmc3, + fastjet, + lhapdf, + rivet, + sqlite, +}: stdenv.mkDerivation rec { pname = "sherpa"; @@ -13,9 +24,16 @@ stdenv.mkDerivation rec { sed -ie '/sys\/sysctl.h/d' ATOOLS/Org/Run_Parameter.C ''; - nativeBuildInputs = [ autoconf gfortran ]; + nativeBuildInputs = [ + autoconf + gfortran + ]; - buildInputs = [ sqlite lhapdf rivet ]; + buildInputs = [ + sqlite + lhapdf + rivet + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/sh/shfm/package.nix b/pkgs/by-name/sh/shfm/package.nix index 47bb6dfdbe8c80..0bd635d4b84a27 100644 --- a/pkgs/by-name/sh/shfm/package.nix +++ b/pkgs/by-name/sh/shfm/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sh/shfmt/package.nix b/pkgs/by-name/sh/shfmt/package.nix index 4cf05bd98a76d1..8235c088300be8 100644 --- a/pkgs/by-name/sh/shfmt/package.nix +++ b/pkgs/by-name/sh/shfmt/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, scdoc }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + scdoc, +}: buildGoModule rec { pname = "shfmt"; @@ -15,9 +21,16 @@ buildGoModule rec { subPackages = [ "cmd/shfmt" ]; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; - nativeBuildInputs = [ installShellFiles scdoc ]; + nativeBuildInputs = [ + installShellFiles + scdoc + ]; postBuild = '' scdoc < cmd/shfmt/shfmt.1.scd > shfmt.1 @@ -32,7 +45,10 @@ buildGoModule rec { You can feed it standard input, any number of files or any number of directories to recurse into. ''; license = licenses.bsd3; - maintainers = with maintainers; [ zowoq SuperSandro2000 ]; + maintainers = with maintainers; [ + zowoq + SuperSandro2000 + ]; mainProgram = "shfmt"; }; } diff --git a/pkgs/by-name/sh/shhmsg/package.nix b/pkgs/by-name/sh/shhmsg/package.nix index ad6a40716bcdd5..a58723db25f9b6 100644 --- a/pkgs/by-name/sh/shhmsg/package.nix +++ b/pkgs/by-name/sh/shhmsg/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "shhmsg"; diff --git a/pkgs/by-name/sh/shhopt/package.nix b/pkgs/by-name/sh/shhopt/package.nix index 324cb8203484b1..0b36bfc8cd8cd5 100644 --- a/pkgs/by-name/sh/shhopt/package.nix +++ b/pkgs/by-name/sh/shhopt/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "shhopt"; diff --git a/pkgs/by-name/sh/shibboleth-sp/package.nix b/pkgs/by-name/sh/shibboleth-sp/package.nix index f38db198bd307c..4a300718c737ba 100644 --- a/pkgs/by-name/sh/shibboleth-sp/package.nix +++ b/pkgs/by-name/sh/shibboleth-sp/package.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchgit, autoreconfHook, boost, fcgi, openssl, opensaml-cpp, log4shib, pkg-config, xercesc, xml-security-c, xml-tooling-c, darwin }: +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + boost, + fcgi, + openssl, + opensaml-cpp, + log4shib, + pkg-config, + xercesc, + xml-security-c, + xml-tooling-c, + darwin, +}: stdenv.mkDerivation rec { pname = "shibboleth-sp"; @@ -10,12 +25,28 @@ stdenv.mkDerivation rec { sha256 = "1qb4dbz5gk10b9w1rf6f4vv7c2wb3a8bfzif6yiaq96ilqad7gdr"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ boost fcgi openssl opensaml-cpp log4shib xercesc xml-security-c xml-tooling-c ] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - CoreServices - SystemConfiguration - ]); + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = + [ + boost + fcgi + openssl + opensaml-cpp + log4shib + xercesc + xml-security-c + xml-tooling-c + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + CoreServices + SystemConfiguration + ] + ); configureFlags = [ "--without-apxs" @@ -28,10 +59,10 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; meta = with lib; { - homepage = "https://shibboleth.net/products/service-provider.html"; + homepage = "https://shibboleth.net/products/service-provider.html"; description = "Enables SSO and Federation web applications written with any programming language or framework"; - platforms = platforms.unix; - license = licenses.asl20; + platforms = platforms.unix; + license = licenses.asl20; maintainers = [ ]; }; } diff --git a/pkgs/by-name/sh/shikane/package.nix b/pkgs/by-name/sh/shikane/package.nix index edf83aea2d0659..f638d7c1988399 100644 --- a/pkgs/by-name/sh/shikane/package.nix +++ b/pkgs/by-name/sh/shikane/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitLab -, installShellFiles -, pandoc +{ + lib, + rustPlatform, + fetchFromGitLab, + installShellFiles, + pandoc, }: rustPlatform.buildRustPackage rec { @@ -39,7 +40,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://gitlab.com/w0lff/shikane"; changelog = "https://gitlab.com/w0lff/shikane/-/tags/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ michaelpachec0 natsukium ]; + maintainers = with maintainers; [ + michaelpachec0 + natsukium + ]; platforms = platforms.linux; mainProgram = "shikane"; }; diff --git a/pkgs/by-name/sh/shim-unsigned/package.nix b/pkgs/by-name/sh/shim-unsigned/package.nix index e4220cf5cc8ecf..c9c2116b0999c6 100644 --- a/pkgs/by-name/sh/shim-unsigned/package.nix +++ b/pkgs/by-name/sh/shim-unsigned/package.nix @@ -1,16 +1,25 @@ -{ stdenv, fetchFromGitHub, lib, elfutils, vendorCertFile ? null -, defaultLoader ? null }: +{ + stdenv, + fetchFromGitHub, + lib, + elfutils, + vendorCertFile ? null, + defaultLoader ? null, +}: let inherit (stdenv.hostPlatform) system; throwSystem = throw "Unsupported system: ${system}"; - archSuffix = { - x86_64-linux = "x64"; - aarch64-linux = "aa64"; - }.${system} or throwSystem; -in stdenv.mkDerivation rec { + archSuffix = + { + x86_64-linux = "x64"; + aarch64-linux = "aa64"; + } + .${system} or throwSystem; +in +stdenv.mkDerivation rec { pname = "shim"; version = "15.8"; @@ -30,7 +39,7 @@ in stdenv.mkDerivation rec { lib.optional (vendorCertFile != null) "VENDOR_CERT_FILE=${vendorCertFile}" ++ lib.optional (defaultLoader != null) "DEFAULT_LOADER=${defaultLoader}"; - installTargets = ["install-as-data"]; + installTargets = [ "install-as-data" ]; installFlags = [ "DATATARGETDIR=$(out)/share/shim" ]; @@ -49,7 +58,13 @@ in stdenv.mkDerivation rec { description = "UEFI shim loader"; homepage = "https://github.com/rhboot/shim"; license = licenses.bsd1; - platforms = [ "x86_64-linux" "aarch64-linux" ]; - maintainers = with maintainers; [ baloo raitobezarius ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; + maintainers = with maintainers; [ + baloo + raitobezarius + ]; }; } diff --git a/pkgs/by-name/sh/shine/package.nix b/pkgs/by-name/sh/shine/package.nix index 433e4dcc617951..c9107390d57565 100644 --- a/pkgs/by-name/sh/shine/package.nix +++ b/pkgs/by-name/sh/shine/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "shine"; diff --git a/pkgs/by-name/sh/shiori/package.nix b/pkgs/by-name/sh/shiori/package.nix index 7da2ff2a54a3c9..b36e99feaac55e 100644 --- a/pkgs/by-name/sh/shiori/package.nix +++ b/pkgs/by-name/sh/shiori/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests, installShellFiles, stdenv }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, + installShellFiles, + stdenv, +}: buildGoModule rec { pname = "shiori"; @@ -35,6 +42,9 @@ buildGoModule rec { mainProgram = "shiori"; homepage = "https://github.com/go-shiori/shiori"; license = licenses.mit; - maintainers = with maintainers; [ minijackson CaptainJawZ ]; + maintainers = with maintainers; [ + minijackson + CaptainJawZ + ]; }; } diff --git a/pkgs/by-name/sh/shipments/package.nix b/pkgs/by-name/sh/shipments/package.nix index 1bcb2e4e104f44..f22cbed39da7b8 100644 --- a/pkgs/by-name/sh/shipments/package.nix +++ b/pkgs/by-name/sh/shipments/package.nix @@ -1,15 +1,16 @@ -{ desktop-file-utils -, fetchFromSourcehut -, gobject-introspection -, gtk3 -, lib -, libhandy -, meson -, ninja -, pkg-config -, python3 -, stdenv -, wrapGAppsHook3 +{ + desktop-file-utils, + fetchFromSourcehut, + gobject-introspection, + gtk3, + lib, + libhandy, + meson, + ninja, + pkg-config, + python3, + stdenv, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -35,10 +36,12 @@ stdenv.mkDerivation rec { buildInputs = [ gtk3 libhandy - (python3.withPackages (ps: with ps; [ - pygobject3 - requests - ])) + (python3.withPackages ( + ps: with ps; [ + pygobject3 + requests + ] + )) ]; meta = with lib; { diff --git a/pkgs/by-name/sh/shipwright/package.nix b/pkgs/by-name/sh/shipwright/package.nix index ee23cbc332bf1f..97c32fbe7e3ed8 100644 --- a/pkgs/by-name/sh/shipwright/package.nix +++ b/pkgs/by-name/sh/shipwright/package.nix @@ -1,32 +1,33 @@ -{ stdenv -, cmake -, lsb-release -, ninja -, lib -, fetchFromGitHub -, fetchurl -, copyDesktopItems -, makeDesktopItem -, python3 -, libX11 -, libXrandr -, libXinerama -, libXcursor -, libXi -, libXext -, glew -, boost -, SDL2 -, SDL2_net -, pkg-config -, libpulseaudio -, libpng -, imagemagick -, zenity -, makeWrapper -, darwin -, apple-sdk_11 -, libicns +{ + stdenv, + cmake, + lsb-release, + ninja, + lib, + fetchFromGitHub, + fetchurl, + copyDesktopItems, + makeDesktopItem, + python3, + libX11, + libXrandr, + libXinerama, + libXcursor, + libXi, + libXext, + glew, + boost, + SDL2, + SDL2_net, + pkg-config, + libpulseaudio, + libpng, + imagemagick, + zenity, + makeWrapper, + darwin, + apple-sdk_11, + libicns, }: stdenv.mkDerivation (finalAttrs: { pname = "shipwright"; @@ -52,45 +53,50 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-atjc0t921l6JSUAd/Yk7uup2R7mCp5ivAh6Dr7HBY7I="; }; - nativeBuildInputs = [ - cmake - ninja - pkg-config - python3 - imagemagick - makeWrapper - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - lsb-release - copyDesktopItems - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libicns - darwin.sigtool - ]; + nativeBuildInputs = + [ + cmake + ninja + pkg-config + python3 + imagemagick + makeWrapper + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + lsb-release + copyDesktopItems + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libicns + darwin.sigtool + ]; - buildInputs = [ - boost - glew - SDL2 - SDL2_net - libpng - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libX11 - libXrandr - libXinerama - libXcursor - libXi - libXext - libpulseaudio - zenity - ] ++ lib.optional stdenv.hostPlatform.isDarwin apple-sdk_11; + buildInputs = + [ + boost + glew + SDL2 + SDL2_net + libpng + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libX11 + libXrandr + libXinerama + libXcursor + libXi + libXext + libpulseaudio + zenity + ] + ++ lib.optional stdenv.hostPlatform.isDarwin apple-sdk_11; cmakeFlags = [ (lib.cmakeBool "NON_PORTABLE" true) (lib.cmakeFeature "CMAKE_INSTALL_PREFIX" "${placeholder "out"}/lib") ]; - env.NIX_CFLAGS_COMPILE = - lib.optionalString stdenv.hostPlatform.isDarwin "-Wno-int-conversion -Wno-implicit-int"; + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-Wno-int-conversion -Wno-implicit-int"; dontAddPrefix = true; @@ -104,58 +110,62 @@ stdenv.mkDerivation (finalAttrs: { popd ''; - preInstall = lib.optionalString stdenv.hostPlatform.isLinux '' - # Cmake likes it here for its install paths - cp ../OTRExporter/soh.otr .. - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - cp ../OTRExporter/soh.otr soh/soh.otr - ''; - - postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' - mkdir -p $out/bin - ln -s $out/lib/soh.elf $out/bin/soh - install -Dm644 ../soh/macosx/sohIcon.png $out/share/pixmaps/soh.png - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Recreate the macOS bundle (without using cpack) - # We mirror the structure of the bundle distributed by the project - - mkdir -p $out/Applications/soh.app/Contents - cp $src/soh/macosx/Info.plist.in $out/Applications/soh.app/Contents/Info.plist - substituteInPlace $out/Applications/soh.app/Contents/Info.plist \ - --replace-fail "@CMAKE_PROJECT_VERSION@" "${finalAttrs.version}" - - mv $out/MacOS $out/Applications/soh.app/Contents/MacOS - - # Wrapper - cp $src/soh/macosx/soh-macos.sh.in $out/Applications/soh.app/Contents/MacOS/soh - chmod +x $out/Applications/soh.app/Contents/MacOS/soh - patchShebangs $out/Applications/soh.app/Contents/MacOS/soh - - # "lib" contains all resources that are in "Resources" in the official bundle. - # We move them to the right place and symlink them back to $out/lib, - # as that's where the game expects them. - mv $out/Resources $out/Applications/soh.app/Contents/Resources - mv $out/lib/** $out/Applications/soh.app/Contents/Resources - rm -rf $out/lib - ln -s $out/Applications/soh.app/Contents/Resources $out/lib - - # Copy icons - cp -r ../build/macosx/soh.icns $out/Applications/soh.app/Contents/Resources/soh.icns - - # Fix executable - install_name_tool -change @executable_path/../Frameworks/libSDL2-2.0.0.dylib \ - ${SDL2}/lib/libSDL2-2.0.0.dylib \ - $out/Applications/soh.app/Contents/Resources/soh-macos - install_name_tool -change @executable_path/../Frameworks/libGLEW.2.2.0.dylib \ - ${glew}/lib/libGLEW.2.2.0.dylib \ - $out/Applications/soh.app/Contents/Resources/soh-macos - install_name_tool -change @executable_path/../Frameworks/libpng16.16.dylib \ - ${libpng}/lib/libpng16.16.dylib \ - $out/Applications/soh.app/Contents/Resources/soh-macos - - # Codesign (ad-hoc) - codesign -f -s - $out/Applications/soh.app/Contents/Resources/soh-macos - ''; + preInstall = + lib.optionalString stdenv.hostPlatform.isLinux '' + # Cmake likes it here for its install paths + cp ../OTRExporter/soh.otr .. + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + cp ../OTRExporter/soh.otr soh/soh.otr + ''; + + postInstall = + lib.optionalString stdenv.hostPlatform.isLinux '' + mkdir -p $out/bin + ln -s $out/lib/soh.elf $out/bin/soh + install -Dm644 ../soh/macosx/sohIcon.png $out/share/pixmaps/soh.png + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Recreate the macOS bundle (without using cpack) + # We mirror the structure of the bundle distributed by the project + + mkdir -p $out/Applications/soh.app/Contents + cp $src/soh/macosx/Info.plist.in $out/Applications/soh.app/Contents/Info.plist + substituteInPlace $out/Applications/soh.app/Contents/Info.plist \ + --replace-fail "@CMAKE_PROJECT_VERSION@" "${finalAttrs.version}" + + mv $out/MacOS $out/Applications/soh.app/Contents/MacOS + + # Wrapper + cp $src/soh/macosx/soh-macos.sh.in $out/Applications/soh.app/Contents/MacOS/soh + chmod +x $out/Applications/soh.app/Contents/MacOS/soh + patchShebangs $out/Applications/soh.app/Contents/MacOS/soh + + # "lib" contains all resources that are in "Resources" in the official bundle. + # We move them to the right place and symlink them back to $out/lib, + # as that's where the game expects them. + mv $out/Resources $out/Applications/soh.app/Contents/Resources + mv $out/lib/** $out/Applications/soh.app/Contents/Resources + rm -rf $out/lib + ln -s $out/Applications/soh.app/Contents/Resources $out/lib + + # Copy icons + cp -r ../build/macosx/soh.icns $out/Applications/soh.app/Contents/Resources/soh.icns + + # Fix executable + install_name_tool -change @executable_path/../Frameworks/libSDL2-2.0.0.dylib \ + ${SDL2}/lib/libSDL2-2.0.0.dylib \ + $out/Applications/soh.app/Contents/Resources/soh-macos + install_name_tool -change @executable_path/../Frameworks/libGLEW.2.2.0.dylib \ + ${glew}/lib/libGLEW.2.2.0.dylib \ + $out/Applications/soh.app/Contents/Resources/soh-macos + install_name_tool -change @executable_path/../Frameworks/libpng16.16.dylib \ + ${libpng}/lib/libpng16.16.dylib \ + $out/Applications/soh.app/Contents/Resources/soh-macos + + # Codesign (ad-hoc) + codesign -f -s - $out/Applications/soh.app/Contents/Resources/soh-macos + ''; fixupPhase = lib.optionalString stdenv.hostPlatform.isLinux '' wrapProgram $out/lib/soh.elf --prefix PATH ":" ${lib.makeBinPath [ zenity ]} @@ -178,7 +188,10 @@ stdenv.mkDerivation (finalAttrs: { description = "A PC port of Ocarina of Time with modern controls, widescreen, high-resolution, and more"; mainProgram = "soh"; platforms = [ "x86_64-linux" ] ++ lib.platforms.darwin; - maintainers = with lib.maintainers; [ j0lol matteopacini ]; + maintainers = with lib.maintainers; [ + j0lol + matteopacini + ]; license = with lib.licenses; [ # OTRExporter, OTRGui, ZAPDTR, libultraship mit diff --git a/pkgs/by-name/sh/shisho/package.nix b/pkgs/by-name/sh/shisho/package.nix index f5a137a84671b6..99590098f82831 100644 --- a/pkgs/by-name/sh/shisho/package.nix +++ b/pkgs/by-name/sh/shisho/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, installShellFiles -, rustfmt -, stdenv +{ + lib, + fetchFromGitHub, + rustPlatform, + installShellFiles, + rustfmt, + stdenv, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sh/shittier/package.nix b/pkgs/by-name/sh/shittier/package.nix index 2ba1bd3d0f94d6..97cdc57b046a7e 100644 --- a/pkgs/by-name/sh/shittier/package.nix +++ b/pkgs/by-name/sh/shittier/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/sh/shmig/package.nix b/pkgs/by-name/sh/shmig/package.nix index 797ee27eeeb2b0..3f57bed763cf57 100644 --- a/pkgs/by-name/sh/shmig/package.nix +++ b/pkgs/by-name/sh/shmig/package.nix @@ -1,7 +1,17 @@ -{ stdenv, fetchFromGitHub -, withMySQL ? true, withPSQL ? false, withSQLite ? false -, mariadb, postgresql, sqlite, gawk, gnugrep, findutils, gnused -, lib +{ + stdenv, + fetchFromGitHub, + withMySQL ? true, + withPSQL ? false, + withSQLite ? false, + mariadb, + postgresql, + sqlite, + gawk, + gnugrep, + findutils, + gnused, + lib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sh/shncpd/package.nix b/pkgs/by-name/sh/shncpd/package.nix index ed724c24cf7907..787371f1211241 100644 --- a/pkgs/by-name/sh/shncpd/package.nix +++ b/pkgs/by-name/sh/shncpd/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "shncpd"; diff --git a/pkgs/by-name/sh/shntool/package.nix b/pkgs/by-name/sh/shntool/package.nix index 51d8830736d5bb..a176c11ce5e2ee 100644 --- a/pkgs/by-name/sh/shntool/package.nix +++ b/pkgs/by-name/sh/shntool/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, flac }: +{ + lib, + stdenv, + fetchFromGitLab, + flac, +}: stdenv.mkDerivation rec { version = "3.0.10+git20130108.4ca41f4-1"; diff --git a/pkgs/by-name/sh/shocco/package.nix b/pkgs/by-name/sh/shocco/package.nix index 6fc11f6ef0baee..63ce139be60089 100644 --- a/pkgs/by-name/sh/shocco/package.nix +++ b/pkgs/by-name/sh/shocco/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, perlPackages, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + perlPackages, + python3, +}: stdenv.mkDerivation rec { pname = "shocco"; @@ -16,7 +22,10 @@ stdenv.mkDerivation rec { substituteInPlace configure --replace PATH= NIRVANA= ''; - buildInputs = [ perlPackages.TextMarkdown python3.pkgs.pygments ]; + buildInputs = [ + perlPackages.TextMarkdown + python3.pkgs.pygments + ]; meta = with lib; { description = "Quick-and-dirty, literate-programming-style documentation generator for / in POSIX shell"; diff --git a/pkgs/by-name/sh/shod/package.nix b/pkgs/by-name/sh/shod/package.nix index a71efe4b52c10f..9bdd79ea155526 100644 --- a/pkgs/by-name/sh/shod/package.nix +++ b/pkgs/by-name/sh/shod/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, writeText -, fontconfig -, libX11 -, libXft -, libXpm -, libXrandr -, libXrender -, conf ? null +{ + lib, + stdenv, + fetchFromGitHub, + writeText, + fontconfig, + libX11, + libXft, + libXpm, + libXrandr, + libXrender, + conf ? null, }: stdenv.mkDerivation rec { @@ -34,8 +35,7 @@ stdenv.mkDerivation rec { postPatch = let configFile = - if lib.isDerivation conf || builtins.isPath conf - then conf else writeText "config.h" conf; + if lib.isDerivation conf || builtins.isPath conf then conf else writeText "config.h" conf; in lib.optionalString (conf != null) "cp ${configFile} config.h"; diff --git a/pkgs/by-name/sh/shopify-themekit/package.nix b/pkgs/by-name/sh/shopify-themekit/package.nix index d6bb23a8ed21f7..cbe076825c2170 100644 --- a/pkgs/by-name/sh/shopify-themekit/package.nix +++ b/pkgs/by-name/sh/shopify-themekit/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "shopify-themekit"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-o928qjp7+/U1W03esYTwVEfQ4A3TmPnmgmh4oWpqJoo="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' # Keep `theme` only diff --git a/pkgs/by-name/sh/shopware-cli/package.nix b/pkgs/by-name/sh/shopware-cli/package.nix index 16b8eb29d2a920..ef092fcaf393c4 100644 --- a/pkgs/by-name/sh/shopware-cli/package.nix +++ b/pkgs/by-name/sh/shopware-cli/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, makeWrapper -, dart-sass -, git +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + makeWrapper, + dart-sass, + git, }: buildGoModule rec { @@ -17,8 +18,14 @@ buildGoModule rec { hash = "sha256-F5QFcXFK40Nz4/rwpk9HGuLr7ly8qjYne6521GtB93M="; }; - nativeBuildInputs = [ installShellFiles makeWrapper ]; - nativeCheckInputs = [ git dart-sass ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; + nativeCheckInputs = [ + git + dart-sass + ]; vendorHash = "sha256-RpOL45NtgYFFcQZviZKOihKXw1Ow7tRAkJ7lACyHsyE="; diff --git a/pkgs/by-name/sh/shorewall/package.nix b/pkgs/by-name/sh/shorewall/package.nix index f3edc8d0d01c76..8535a2dc170517 100644 --- a/pkgs/by-name/sh/shorewall/package.nix +++ b/pkgs/by-name/sh/shorewall/package.nix @@ -1,23 +1,25 @@ -{ coreutils -, fetchurl -, gnugrep -, gnused -, iproute2 -, iptables -, perl -, perlPackages -, lib, stdenv -, util-linux +{ + coreutils, + fetchurl, + gnugrep, + gnused, + iproute2, + iptables, + perl, + perlPackages, + lib, + stdenv, + util-linux, }: let - PATH = lib.concatStringsSep ":" - [ "${coreutils}/bin" - "${iproute2}/bin" - "${iptables}/bin" - "${util-linux}/bin" - "${gnugrep}/bin" - "${gnused}/bin" - ]; + PATH = lib.concatStringsSep ":" [ + "${coreutils}/bin" + "${iproute2}/bin" + "${iptables}/bin" + "${util-linux}/bin" + "${gnugrep}/bin" + "${gnused}/bin" + ]; in stdenv.mkDerivation rec { pname = "shorewall"; @@ -39,17 +41,19 @@ stdenv.mkDerivation rec { ]; sourceRoot = "."; - buildInputs = [ - coreutils - iproute2 - iptables - util-linux - gnugrep - gnused - perl - ] ++ (with perlPackages; [ - DigestSHA1 - ]); + buildInputs = + [ + coreutils + iproute2 + iptables + util-linux + gnugrep + gnused + perl + ] + ++ (with perlPackages; [ + DigestSHA1 + ]); prePatch = '' # Patch configure and install.sh files patchShebangs . diff --git a/pkgs/by-name/sh/shortcat/package.nix b/pkgs/by-name/sh/shortcat/package.nix index e67e230a46b947..b8022c3fcc7acf 100644 --- a/pkgs/by-name/sh/shortcat/package.nix +++ b/pkgs/by-name/sh/shortcat/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, unzip, ... }: +{ + lib, + stdenv, + fetchurl, + unzip, + ... +}: stdenv.mkDerivation rec { pname = "shortcat"; diff --git a/pkgs/by-name/sh/shot-scraper/package.nix b/pkgs/by-name/sh/shot-scraper/package.nix index f162570c341c53..f5a9a2f7ff5e4b 100644 --- a/pkgs/by-name/sh/shot-scraper/package.nix +++ b/pkgs/by-name/sh/shot-scraper/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/sh/shotgun/package.nix b/pkgs/by-name/sh/shotgun/package.nix index e71f0d7cc9d22b..3d30c485785901 100644 --- a/pkgs/by-name/sh/shotgun/package.nix +++ b/pkgs/by-name/sh/shotgun/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "shotgun"; @@ -17,7 +21,10 @@ rustPlatform.buildRustPackage rec { description = "Minimal X screenshot utility"; homepage = "https://github.com/neXromancers/shotgun"; license = with licenses; [ mpl20 ]; - maintainers = with maintainers; [ figsoda lumi ]; + maintainers = with maintainers; [ + figsoda + lumi + ]; platforms = platforms.linux; mainProgram = "shotgun"; }; diff --git a/pkgs/by-name/sh/shotman/package.nix b/pkgs/by-name/sh/shotman/package.nix index 078157bb10e2be..6b4a07da910fb9 100644 --- a/pkgs/by-name/sh/shotman/package.nix +++ b/pkgs/by-name/sh/shotman/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromSourcehut -, rustPlatform -, pkg-config -, libxkbcommon -, makeWrapper -, slurp +{ + lib, + fetchFromSourcehut, + rustPlatform, + pkg-config, + libxkbcommon, + makeWrapper, + slurp, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-a70zJdhPncagah/gCvkHtSvnYhnYMTINCd5ZyBeDwAE="; - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; buildInputs = [ libxkbcommon ]; @@ -34,6 +38,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://git.sr.ht/~whynothugo/shotman"; license = licenses.isc; platforms = platforms.linux; - maintainers = with maintainers; [ zendo fpletz ]; + maintainers = with maintainers; [ + zendo + fpletz + ]; }; } diff --git a/pkgs/by-name/sh/shotwell/package.nix b/pkgs/by-name/sh/shotwell/package.nix index 8305afb563ab61..272e607725a74b 100644 --- a/pkgs/by-name/sh/shotwell/package.nix +++ b/pkgs/by-name/sh/shotwell/package.nix @@ -1,39 +1,40 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, adwaita-icon-theme -, gtk3 -, libexif -, libgphoto2 -, libwebp -, libsoup_3 -, libxml2 -, vala -, sqlite -, pkg-config -, gnome -, gst_all_1 -, libgudev -, libraw -, glib -, glib-networking -, json-glib -, gcr -, libgee -, gexiv2 -, librest -, gettext -, desktop-file-utils -, gdk-pixbuf -, librsvg -, wrapGAppsHook3 -, gobject-introspection -, itstool -, libsecret -, libportal-gtk3 -, gsettings-desktop-schemas +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + adwaita-icon-theme, + gtk3, + libexif, + libgphoto2, + libwebp, + libsoup_3, + libxml2, + vala, + sqlite, + pkg-config, + gnome, + gst_all_1, + libgudev, + libraw, + glib, + glib-networking, + json-glib, + gcr, + libgee, + gexiv2, + librest, + gettext, + desktop-file-utils, + gdk-pixbuf, + librsvg, + wrapGAppsHook3, + gobject-introspection, + itstool, + libsecret, + libportal-gtk3, + gsettings-desktop-schemas, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sh/show-midi/package.nix b/pkgs/by-name/sh/show-midi/package.nix index c7c16d1d15b9dc..3fc5da619ee81c 100644 --- a/pkgs/by-name/sh/show-midi/package.nix +++ b/pkgs/by-name/sh/show-midi/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, alsa-lib -, freetype -, libX11 -, libXrandr -, libXinerama -, libXext -, libXcursor -, makeDesktopItem -, copyDesktopItems +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + alsa-lib, + freetype, + libX11, + libXrandr, + libXinerama, + libXext, + libXcursor, + makeDesktopItem, + copyDesktopItems, }: stdenv.mkDerivation (finalAttrs: { @@ -69,15 +70,17 @@ stdenv.mkDerivation (finalAttrs: { runHook postInstall ''; - desktopItems = [(makeDesktopItem { - name = "ShowMIDI"; - exec = finalAttrs.meta.mainProgram; - comment = finalAttrs.meta.description; - type = "Application"; - icon = "show-midi"; - desktopName = "ShowMIDI"; - categories = [ "Audio" ]; - })]; + desktopItems = [ + (makeDesktopItem { + name = "ShowMIDI"; + exec = finalAttrs.meta.mainProgram; + comment = finalAttrs.meta.description; + type = "Application"; + icon = "show-midi"; + desktopName = "ShowMIDI"; + categories = [ "Audio" ]; + }) + ]; # JUCE dlopens these, make sure they are in rpath # Otherwise, segfault will happen diff --git a/pkgs/by-name/sh/showmethekey/package.nix b/pkgs/by-name/sh/showmethekey/package.nix index 4521a27c525587..56320b83d94dc0 100644 --- a/pkgs/by-name/sh/showmethekey/package.nix +++ b/pkgs/by-name/sh/showmethekey/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, libevdev -, json-glib -, libinput -, gtk4 -, libadwaita -, wrapGAppsHook4 -, libxkbcommon -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + libevdev, + json-glib, + libinput, + gtk4, + libadwaita, + wrapGAppsHook4, + libxkbcommon, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sh/shpool/package.nix b/pkgs/by-name/sh/shpool/package.nix index 3f252a80087e85..744c0c41d3cf42 100644 --- a/pkgs/by-name/sh/shpool/package.nix +++ b/pkgs/by-name/sh/shpool/package.nix @@ -18,7 +18,6 @@ rustPlatform.buildRustPackage rec { hash = "sha256-pSSMC4pUtB38c6UNOj+Ma/Y1jcSfm33QV1B4tA/MyKY="; }; - postPatch = '' substituteInPlace systemd/shpool.service \ --replace-fail '/usr/bin/shpool' "$out/bin/shpool" diff --git a/pkgs/by-name/sh/shrikhand/package.nix b/pkgs/by-name/sh/shrikhand/package.nix index ce3423003dbd58..585f7303bc8ce2 100644 --- a/pkgs/by-name/sh/shrikhand/package.nix +++ b/pkgs/by-name/sh/shrikhand/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation { pname = "shrikhand"; diff --git a/pkgs/by-name/sh/shticker-book-unwritten/package.nix b/pkgs/by-name/sh/shticker-book-unwritten/package.nix index cab24d8917c8ff..426b4e93cf3782 100644 --- a/pkgs/by-name/sh/shticker-book-unwritten/package.nix +++ b/pkgs/by-name/sh/shticker-book-unwritten/package.nix @@ -1,12 +1,18 @@ -{ buildFHSEnv, callPackage, lib }: +{ + buildFHSEnv, + callPackage, + lib, +}: let shticker-book-unwritten-unwrapped = callPackage ./unwrapped.nix { }; -in buildFHSEnv { +in +buildFHSEnv { pname = "shticker_book_unwritten"; inherit (shticker-book-unwritten-unwrapped) version; - targetPkgs = pkgs: with pkgs; [ + targetPkgs = + pkgs: with pkgs; [ alsa-lib libglvnd libpulseaudio @@ -14,7 +20,7 @@ in buildFHSEnv { xorg.libX11 xorg.libXcursor xorg.libXext - ]; + ]; runScript = "shticker_book_unwritten"; meta = with lib; { diff --git a/pkgs/by-name/sh/shticker-book-unwritten/unwrapped.nix b/pkgs/by-name/sh/shticker-book-unwritten/unwrapped.nix index f81cf8b2c7aa1c..527564a0d21915 100644 --- a/pkgs/by-name/sh/shticker-book-unwritten/unwrapped.nix +++ b/pkgs/by-name/sh/shticker-book-unwritten/unwrapped.nix @@ -1,4 +1,9 @@ -{ rustPlatform, fetchCrate, pkg-config, openssl }: +{ + rustPlatform, + fetchCrate, + pkg-config, + openssl, +}: rustPlatform.buildRustPackage rec { pname = "shticker-book-unwritten"; diff --git a/pkgs/by-name/sh/shtns/package.nix b/pkgs/by-name/sh/shtns/package.nix index a720213b3913b8..1b9e10619e4496 100644 --- a/pkgs/by-name/sh/shtns/package.nix +++ b/pkgs/by-name/sh/shtns/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchgit, fftw }: +{ + lib, + stdenv, + fetchgit, + fftw, +}: stdenv.mkDerivation rec { pname = "shtns"; diff --git a/pkgs/by-name/sh/shunit2/package.nix b/pkgs/by-name/sh/shunit2/package.nix index 57f1957a7e0e2a..671bcb5f17a349 100644 --- a/pkgs/by-name/sh/shunit2/package.nix +++ b/pkgs/by-name/sh/shunit2/package.nix @@ -1,12 +1,13 @@ -{ lib -, resholve -, fetchFromGitHub -, bash -, coreutils -, gnused -, gnugrep -, findutils -, ncurses +{ + lib, + resholve, + fetchFromGitHub, + bash, + coreutils, + gnused, + gnugrep, + findutils, + ncurses, }: resholve.mkDerivation rec { @@ -36,7 +37,13 @@ resholve.mkDerivation rec { # Caution: see __SHUNIT_CMD_ECHO_ESC before changing interpreter = "${bash}/bin/sh"; scripts = [ "bin/shunit2" ]; - inputs = [ coreutils gnused gnugrep findutils ncurses ]; + inputs = [ + coreutils + gnused + gnugrep + findutils + ncurses + ]; # resholve's Nix API is analogous to the CLI flags # documented in 'man resholve' fake = { @@ -57,18 +64,22 @@ resholve.mkDerivation rec { # stray absolute path; make it resolve from coreutils "/usr/bin/od" = true; /* - Caution: this one is contextually debatable. shunit2 - sets this variable after testing whether `echo -e test` - yields `test` or `-e test`. Since we're setting the - interpreter, we can pre-test this. But if we go fiddle - the interpreter later, I guess we _could_ break it. + Caution: this one is contextually debatable. shunit2 + sets this variable after testing whether `echo -e test` + yields `test` or `-e test`. Since we're setting the + interpreter, we can pre-test this. But if we go fiddle + the interpreter later, I guess we _could_ break it. */ "$__SHUNIT_CMD_ECHO_ESC" = [ "echo -e" ]; "$SHUNIT_CMD_TPUT" = [ "tput" ]; # from ncurses }; keep = { # dynamically defined in shunit2:_shunit_mktempFunc - eval = [ "shunit_condition_" "_shunit_test_" "_shunit_prepForSourcing" ]; + eval = [ + "shunit_condition_" + "_shunit_test_" + "_shunit_prepForSourcing" + ]; # dynamic based on CLI flag "$_SHUNIT_LINENO_" = true; @@ -83,7 +94,10 @@ resholve.mkDerivation rec { meta = with lib; { homepage = "https://github.com/kward/shunit2"; description = "XUnit based unit test framework for Bourne based shell scripts"; - maintainers = with maintainers; [ abathur utdemir ]; + maintainers = with maintainers; [ + abathur + utdemir + ]; license = licenses.asl20; platforms = platforms.unix; mainProgram = "shunit2"; diff --git a/pkgs/by-name/sh/shutter/package.nix b/pkgs/by-name/sh/shutter/package.nix index fe4286aa4b5b12..3ba076eeccea69 100644 --- a/pkgs/by-name/sh/shutter/package.nix +++ b/pkgs/by-name/sh/shutter/package.nix @@ -1,65 +1,66 @@ -{ lib -, stdenv -, fetchFromGitHub -, perlPackages -, wrapGAppsHook3 -, imagemagick -, gdk-pixbuf -, librsvg -, hicolor-icon-theme -, procps -, libwnck -, libappindicator-gtk3 -, xdg-utils +{ + lib, + stdenv, + fetchFromGitHub, + perlPackages, + wrapGAppsHook3, + imagemagick, + gdk-pixbuf, + librsvg, + hicolor-icon-theme, + procps, + libwnck, + libappindicator-gtk3, + xdg-utils, }: let perlModules = with perlPackages; [ - ImageMagick - Cairo - FileBaseDir - FileWhich - FileCopyRecursive - XMLSimple - XMLTwig - XMLParser - SortNaturally - LocaleGettext - ProcProcessTable - X11Protocol - ProcSimple - ImageExifTool - JSON - JSONMaybeXS - NetOAuth - PathClass - LWP - LWPProtocolHttps - NetDBus - TryTiny - WWWMechanize - HTTPMessage - HTTPDate - HTMLForm - HTMLParser - HTMLTagset - HTTPCookies - EncodeLocale - URI - CarpAlways - GlibObjectIntrospection - NumberBytesHuman - CairoGObject - Readonly - Gtk3ImageView - Gtk3 - Glib - Pango - GooCanvas2 - GooCanvas2CairoTypes - commonsense - TypesSerialiser - ]; + ImageMagick + Cairo + FileBaseDir + FileWhich + FileCopyRecursive + XMLSimple + XMLTwig + XMLParser + SortNaturally + LocaleGettext + ProcProcessTable + X11Protocol + ProcSimple + ImageExifTool + JSON + JSONMaybeXS + NetOAuth + PathClass + LWP + LWPProtocolHttps + NetDBus + TryTiny + WWWMechanize + HTTPMessage + HTTPDate + HTMLForm + HTMLParser + HTMLTagset + HTTPCookies + EncodeLocale + URI + CarpAlways + GlibObjectIntrospection + NumberBytesHuman + CairoGObject + Readonly + Gtk3ImageView + Gtk3 + Glib + Pango + GooCanvas2 + GooCanvas2CairoTypes + commonsense + TypesSerialiser + ]; in stdenv.mkDerivation rec { pname = "shutter"; @@ -95,8 +96,8 @@ stdenv.mkDerivation rec { # make xdg-open overrideable at runtime gappsWrapperArgs+=( --set PERL5LIB ${perlPackages.makePerlPath perlModules} \ - --prefix PATH : ${lib.makeBinPath [ imagemagick ] } - --suffix PATH : ${lib.makeBinPath [ xdg-utils ] } + --prefix PATH : ${lib.makeBinPath [ imagemagick ]} + --suffix PATH : ${lib.makeBinPath [ xdg-utils ]} ) ''; diff --git a/pkgs/by-name/si/sic-image-cli/package.nix b/pkgs/by-name/si/sic-image-cli/package.nix index 42dae849fc9fca..782a764e99d3f0 100644 --- a/pkgs/by-name/si/sic-image-cli/package.nix +++ b/pkgs/by-name/si/sic-image-cli/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, installShellFiles, nasm }: +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + nasm, +}: rustPlatform.buildRustPackage rec { pname = "sic-image-cli"; @@ -13,7 +19,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Pw5PJ0xQCLfPaVEzsfqeHJ0E3miDwlj+71J98KRrYDs="; - nativeBuildInputs = [ installShellFiles nasm ]; + nativeBuildInputs = [ + installShellFiles + nasm + ]; postBuild = '' cargo run --example gen_completions @@ -28,7 +37,10 @@ rustPlatform.buildRustPackage rec { description = "Accessible image processing and conversion from the terminal"; homepage = "https://github.com/foresterre/sic"; changelog = "https://github.com/foresterre/sic/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "sic"; }; diff --git a/pkgs/by-name/si/sic/package.nix b/pkgs/by-name/si/sic/package.nix index 82c5852128e992..0edf706b0fb6ac 100644 --- a/pkgs/by-name/si/sic/package.nix +++ b/pkgs/by-name/si/sic/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "sic"; diff --git a/pkgs/by-name/si/sidequest/package.nix b/pkgs/by-name/si/sidequest/package.nix index 2bf49bad8e31de..07250ca00ca3ec 100644 --- a/pkgs/by-name/si/sidequest/package.nix +++ b/pkgs/by-name/si/sidequest/package.nix @@ -1,62 +1,67 @@ -{ stdenv -, lib -, fetchurl -, buildFHSEnv -, makeDesktopItem -, makeWrapper -, alsa-lib -, at-spi2-atk -, cairo -, cups -, dbus -, expat -, gdk-pixbuf -, glib -, gtk3 -, mesa -, nss -, nspr -, libdrm -, xorg -, libxkbcommon -, libxshmfence -, pango -, systemd -, icu -, openssl -, zlib +{ + stdenv, + lib, + fetchurl, + buildFHSEnv, + makeDesktopItem, + makeWrapper, + alsa-lib, + at-spi2-atk, + cairo, + cups, + dbus, + expat, + gdk-pixbuf, + glib, + gtk3, + mesa, + nss, + nspr, + libdrm, + xorg, + libxkbcommon, + libxshmfence, + pango, + systemd, + icu, + openssl, + zlib, }: - let - pname = "sidequest"; - version = "0.10.33"; +let + pname = "sidequest"; + version = "0.10.33"; - desktopItem = makeDesktopItem rec { - name = "SideQuest"; - exec = "SideQuest"; - desktopName = name; - genericName = "VR App Store"; - categories = [ "Settings" "PackageManager" ]; - }; + desktopItem = makeDesktopItem rec { + name = "SideQuest"; + exec = "SideQuest"; + desktopName = name; + genericName = "VR App Store"; + categories = [ + "Settings" + "PackageManager" + ]; + }; - sidequest = stdenv.mkDerivation { - inherit pname version; + sidequest = stdenv.mkDerivation { + inherit pname version; - src = fetchurl { - url = "https://github.com/SideQuestVR/SideQuest/releases/download/v${version}/SideQuest-${version}.tar.xz"; - sha256 = "8ac3d97400a8e3ce86902b5bea7b8d042a092acd888d20e5139490a38507f995"; - }; - dontUnpack = true; + src = fetchurl { + url = "https://github.com/SideQuestVR/SideQuest/releases/download/v${version}/SideQuest-${version}.tar.xz"; + sha256 = "8ac3d97400a8e3ce86902b5bea7b8d042a092acd888d20e5139490a38507f995"; + }; + dontUnpack = true; - nativeBuildInputs = [ makeWrapper ]; + nativeBuildInputs = [ makeWrapper ]; - installPhase = '' - mkdir -p "$out/lib/SideQuest" "$out/bin" - tar -xJf "$src" -C "$out/lib/SideQuest" --strip-components 1 + installPhase = '' + mkdir -p "$out/lib/SideQuest" "$out/bin" + tar -xJf "$src" -C "$out/lib/SideQuest" --strip-components 1 - ln -s "$out/lib/SideQuest/sidequest" "$out/bin" - ''; + ln -s "$out/lib/SideQuest/sidequest" "$out/bin" + ''; - postFixup = let + postFixup = + let libPath = lib.makeLibraryPath [ alsa-lib at-spi2-atk @@ -85,43 +90,51 @@ (lib.getLib stdenv.cc.cc) systemd ]; - in '' + in + '' patchelf \ --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ --set-rpath "${libPath}:$out/lib/SideQuest" \ "$out/lib/SideQuest/sidequest" ''; - }; - in buildFHSEnv { - pname = "SideQuest"; - inherit version; + }; +in +buildFHSEnv { + pname = "SideQuest"; + inherit version; - passthru = { - inherit pname version; + passthru = { + inherit pname version; - meta = with lib; { - description = "Open app store and side-loading tool for Android-based VR devices such as the Oculus Go, Oculus Quest or Moverio BT 300"; - homepage = "https://github.com/SideQuestVR/SideQuest"; - downloadPage = "https://github.com/SideQuestVR/SideQuest/releases"; - sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.mit; - maintainers = with maintainers; [ joepie91 rvolosatovs ]; - platforms = [ "x86_64-linux" ]; - mainProgram = "SideQuest"; - }; + meta = with lib; { + description = "Open app store and side-loading tool for Android-based VR devices such as the Oculus Go, Oculus Quest or Moverio BT 300"; + homepage = "https://github.com/SideQuestVR/SideQuest"; + downloadPage = "https://github.com/SideQuestVR/SideQuest/releases"; + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; + license = licenses.mit; + maintainers = with maintainers; [ + joepie91 + rvolosatovs + ]; + platforms = [ "x86_64-linux" ]; + mainProgram = "SideQuest"; }; + }; - targetPkgs = pkgs: [ - sidequest - # Needed in the environment on runtime, to make QuestSaberPatch work - icu openssl zlib - libxkbcommon libxshmfence - ]; + targetPkgs = pkgs: [ + sidequest + # Needed in the environment on runtime, to make QuestSaberPatch work + icu + openssl + zlib + libxkbcommon + libxshmfence + ]; - extraInstallCommands = '' - mkdir -p "$out/share/applications" - ln -s ${desktopItem}/share/applications/* "$out/share/applications" - ''; + extraInstallCommands = '' + mkdir -p "$out/share/applications" + ln -s ${desktopItem}/share/applications/* "$out/share/applications" + ''; - runScript = "sidequest"; - } + runScript = "sidequest"; +} diff --git a/pkgs/by-name/si/sienna/package.nix b/pkgs/by-name/si/sienna/package.nix index bee862ba2a08a1..e1a5a39f12ff2b 100644 --- a/pkgs/by-name/si/sienna/package.nix +++ b/pkgs/by-name/si/sienna/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, love, makeWrapper, makeDesktopItem, copyDesktopItems }: +{ + lib, + stdenv, + fetchurl, + love, + makeWrapper, + makeDesktopItem, + copyDesktopItems, +}: stdenv.mkDerivation rec { pname = "sienna"; @@ -14,17 +22,22 @@ stdenv.mkDerivation rec { sha256 = "12q2rhk39dmb6ir50zafn8dylaad5gns8z3y21mfjabc5l5g02nn"; }; - desktopItems = [ (makeDesktopItem { - name = "sienna"; - exec = pname; - icon = icon; - comment = "Fast-paced one button platformer"; - desktopName = "Sienna"; - genericName = "sienna"; - categories = [ "Game" ]; - }) ]; - - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; + desktopItems = [ + (makeDesktopItem { + name = "sienna"; + exec = pname; + icon = icon; + comment = "Fast-paced one button platformer"; + desktopName = "Sienna"; + genericName = "sienna"; + categories = [ "Game" ]; + }) + ]; + + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; dontUnpack = true; diff --git a/pkgs/by-name/si/sierra-gtk-theme/package.nix b/pkgs/by-name/si/sierra-gtk-theme/package.nix index 41c27b2482b929..97183f760251ae 100644 --- a/pkgs/by-name/si/sierra-gtk-theme/package.nix +++ b/pkgs/by-name/si/sierra-gtk-theme/package.nix @@ -1,74 +1,85 @@ -{ lib -, stdenv -, fetchFromGitHub -, gdk-pixbuf -, gtk-engine-murrine -, jdupes -, librsvg -, libxml2 -, buttonVariants ? [] # default to all -, colorVariants ? [] # default to all -, opacityVariants ? [] # default to all -, sizeVariants ? [] # default to all +{ + lib, + stdenv, + fetchFromGitHub, + gdk-pixbuf, + gtk-engine-murrine, + jdupes, + librsvg, + libxml2, + buttonVariants ? [ ], # default to all + colorVariants ? [ ], # default to all + opacityVariants ? [ ], # default to all + sizeVariants ? [ ], # default to all }: let pname = "sierra-gtk-theme"; in lib.checkListOfEnum "${pname}: button variants" [ "standard" "alt" ] buttonVariants -lib.checkListOfEnum "${pname}: color variants" [ "light" "dark" ] colorVariants -lib.checkListOfEnum "${pname}: opacity variants" [ "standard" "solid" ] opacityVariants -lib.checkListOfEnum "${pname}: size variants" [ "standard" "compact" ] sizeVariants + lib.checkListOfEnum + "${pname}: color variants" + [ "light" "dark" ] + colorVariants + lib.checkListOfEnum + "${pname}: opacity variants" + [ "standard" "solid" ] + opacityVariants + lib.checkListOfEnum + "${pname}: size variants" + [ "standard" "compact" ] + sizeVariants -stdenv.mkDerivation { - inherit pname; - version = "unstable-2021-05-24"; + stdenv.mkDerivation + { + inherit pname; + version = "unstable-2021-05-24"; - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = "05899001c4fc2fec87c4d222cb3997c414e0affd"; - sha256 = "174l5mryc34ma1r42pk6572c6i9hmzr9vj1a6w06nqz5qcfm1hds"; - }; + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = "05899001c4fc2fec87c4d222cb3997c414e0affd"; + sha256 = "174l5mryc34ma1r42pk6572c6i9hmzr9vj1a6w06nqz5qcfm1hds"; + }; - nativeBuildInputs = [ - jdupes - libxml2 - ]; + nativeBuildInputs = [ + jdupes + libxml2 + ]; - buildInputs = [ - gdk-pixbuf - librsvg - ]; + buildInputs = [ + gdk-pixbuf + librsvg + ]; - propagatedUserEnvPkgs = [ - gtk-engine-murrine - ]; + propagatedUserEnvPkgs = [ + gtk-engine-murrine + ]; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - patchShebangs install.sh + patchShebangs install.sh - mkdir -p $out/share/themes - name= ./install.sh --dest $out/share/themes \ - ${lib.optionalString (buttonVariants != []) "--alt " + builtins.toString buttonVariants} \ - ${lib.optionalString (colorVariants != []) "--color " + builtins.toString colorVariants} \ - ${lib.optionalString (opacityVariants != []) "--opacity " + builtins.toString opacityVariants} \ - ${lib.optionalString (sizeVariants != []) "--flat " + builtins.toString sizeVariants} + mkdir -p $out/share/themes + name= ./install.sh --dest $out/share/themes \ + ${lib.optionalString (buttonVariants != [ ]) "--alt " + builtins.toString buttonVariants} \ + ${lib.optionalString (colorVariants != [ ]) "--color " + builtins.toString colorVariants} \ + ${lib.optionalString (opacityVariants != [ ]) "--opacity " + builtins.toString opacityVariants} \ + ${lib.optionalString (sizeVariants != [ ]) "--flat " + builtins.toString sizeVariants} - # Replace duplicate files with hardlinks to the first file in each - # set of duplicates, reducing the installed size in about 79% - jdupes -L -r $out/share + # Replace duplicate files with hardlinks to the first file in each + # set of duplicates, reducing the installed size in about 79% + jdupes -L -r $out/share - runHook postInstall - ''; + runHook postInstall + ''; - meta = with lib; { - description = "Mac OSX like theme for GTK based desktop environments"; - homepage = "https://github.com/vinceliuice/Sierra-gtk-theme"; - license = licenses.gpl3; - platforms = platforms.unix; - maintainers = [ maintainers.romildo ]; - }; -} + meta = with lib; { + description = "Mac OSX like theme for GTK based desktop environments"; + homepage = "https://github.com/vinceliuice/Sierra-gtk-theme"; + license = licenses.gpl3; + platforms = platforms.unix; + maintainers = [ maintainers.romildo ]; + }; + } diff --git a/pkgs/by-name/si/sieve-connect/package.nix b/pkgs/by-name/si/sieve-connect/package.nix index 6bc3e1f7d50ae3..8a576bd7be3f5e 100644 --- a/pkgs/by-name/si/sieve-connect/package.nix +++ b/pkgs/by-name/si/sieve-connect/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, perlPackages, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + perlPackages, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "sieve-connect"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; buildInputs = [ perlPackages.perl ]; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; preBuild = '' # Fixes failing build when not building in git repo @@ -22,7 +32,11 @@ stdenv.mkDerivation rec { echo "$(date +%Y-%m-%d)" > datefile ''; - buildFlags = [ "PERL5LIB=${perlPackages.makePerlPath [ perlPackages.FileSlurp ]}" "bin" "man" ]; + buildFlags = [ + "PERL5LIB=${perlPackages.makePerlPath [ perlPackages.FileSlurp ]}" + "bin" + "man" + ]; installPhase = '' mkdir -p $out/bin @@ -30,9 +44,19 @@ stdenv.mkDerivation rec { installManPage sieve-connect.1 wrapProgram $out/bin/sieve-connect \ - --prefix PERL5LIB : "${with perlPackages; makePerlPath [ - AuthenSASL Socket6 IOSocketINET6 IOSocketSSL NetSSLeay NetDNS - TermReadKey TermReadLineGnu ]}" + --prefix PERL5LIB : "${ + with perlPackages; + makePerlPath [ + AuthenSASL + Socket6 + IOSocketINET6 + IOSocketSSL + NetSSLeay + NetDNS + TermReadKey + TermReadLineGnu + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/si/sift/package.nix b/pkgs/by-name/si/sift/package.nix index 04ca7f0c213664..0fe1069b702059 100644 --- a/pkgs/by-name/si/sift/package.nix +++ b/pkgs/by-name/si/sift/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + installShellFiles, +}: buildGoModule rec { pname = "sift"; @@ -23,7 +29,10 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' installShellCompletion --cmd sift --bash sift-completion.bash diff --git a/pkgs/by-name/si/sigal/package.nix b/pkgs/by-name/si/sigal/package.nix index d9b4c4cfd53bce..594edec88205aa 100644 --- a/pkgs/by-name/si/sigal/package.nix +++ b/pkgs/by-name/si/sigal/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, python3 -, fetchPypi -, ffmpeg +{ + stdenv, + lib, + python3, + fetchPypi, + ffmpeg, }: python3.pkgs.buildPythonApplication rec { @@ -35,11 +36,13 @@ python3.pkgs.buildPythonApplication rec { cryptography ]; - nativeCheckInputs = [ - ffmpeg - ] ++ (with python3.pkgs; [ - pytestCheckHook - ]); + nativeCheckInputs = + [ + ffmpeg + ] + ++ (with python3.pkgs; [ + pytestCheckHook + ]); disabledTests = lib.optionals stdenv.hostPlatform.isDarwin [ "test_nonmedia_files" @@ -54,6 +57,9 @@ python3.pkgs.buildPythonApplication rec { mainProgram = "sigal"; homepage = "http://sigal.saimon.org/"; license = licenses.mit; - maintainers = with maintainers; [ domenkozar matthiasbeyer ]; + maintainers = with maintainers; [ + domenkozar + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/si/sigi/package.nix b/pkgs/by-name/si/sigi/package.nix index 9bab8e985375bc..ba92c47224c637 100644 --- a/pkgs/by-name/si/sigi/package.nix +++ b/pkgs/by-name/si/sigi/package.nix @@ -1,4 +1,11 @@ -{ lib, rustPlatform, fetchCrate, installShellFiles, testers, sigi }: +{ + lib, + rustPlatform, + fetchCrate, + installShellFiles, + testers, + sigi, +}: rustPlatform.buildRustPackage rec { pname = "sigi"; diff --git a/pkgs/by-name/si/siglo/package.nix b/pkgs/by-name/si/siglo/package.nix index 4825b00c895967..147a784d1dcd9c 100644 --- a/pkgs/by-name/si/siglo/package.nix +++ b/pkgs/by-name/si/siglo/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, glib -, meson -, ninja -, wrapGAppsHook3 -, desktop-file-utils -, gobject-introspection -, gtk3 -, python3 +{ + stdenv, + lib, + fetchFromGitHub, + glib, + meson, + ninja, + wrapGAppsHook3, + desktop-file-utils, + gobject-introspection, + gtk3, + python3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/si/signal-cli/package.nix b/pkgs/by-name/si/signal-cli/package.nix index 759bbe122642d4..015e232c16c361 100644 --- a/pkgs/by-name/si/signal-cli/package.nix +++ b/pkgs/by-name/si/signal-cli/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchurl, makeWrapper, openjdk21_headless, libmatthew_java, dbus, dbus_java }: +{ + stdenv, + lib, + fetchurl, + makeWrapper, + openjdk21_headless, + libmatthew_java, + dbus, + dbus_java, +}: stdenv.mkDerivation rec { pname = "signal-cli"; @@ -10,24 +19,35 @@ stdenv.mkDerivation rec { hash = "sha256-libAHGRdOinL48riMwKtacI5YlRw8JGoqOynVUCGyeA="; }; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libmatthew_java dbus dbus_java ]; + buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ + libmatthew_java + dbus + dbus_java + ]; nativeBuildInputs = [ makeWrapper ]; - installPhase = '' - mkdir -p $out/bin - cp -r lib $out/lib - cp bin/signal-cli $out/bin/signal-cli - '' + (if stdenv.hostPlatform.isLinux then '' - makeWrapper ${openjdk21_headless}/bin/java $out/bin/signal-cli \ - --set JAVA_HOME "${openjdk21_headless}" \ - --add-flags "-classpath '$out/lib/*:${libmatthew_java}/lib/jni'" \ - --add-flags "-Djava.library.path=${libmatthew_java}/lib/jni:${dbus_java}/share/java/dbus:$out/lib" \ - --add-flags "org.asamk.signal.Main" - '' else '' - wrapProgram $out/bin/signal-cli \ - --prefix PATH : ${lib.makeBinPath [ openjdk21_headless ]} \ - --set JAVA_HOME ${openjdk21_headless} - ''); + installPhase = + '' + mkdir -p $out/bin + cp -r lib $out/lib + cp bin/signal-cli $out/bin/signal-cli + '' + + ( + if stdenv.hostPlatform.isLinux then + '' + makeWrapper ${openjdk21_headless}/bin/java $out/bin/signal-cli \ + --set JAVA_HOME "${openjdk21_headless}" \ + --add-flags "-classpath '$out/lib/*:${libmatthew_java}/lib/jni'" \ + --add-flags "-Djava.library.path=${libmatthew_java}/lib/jni:${dbus_java}/share/java/dbus:$out/lib" \ + --add-flags "org.asamk.signal.Main" + '' + else + '' + wrapProgram $out/bin/signal-cli \ + --prefix PATH : ${lib.makeBinPath [ openjdk21_headless ]} \ + --set JAVA_HOME ${openjdk21_headless} + '' + ); # Execution in the macOS (10.13) sandbox fails with # dyld: Library not loaded: /System/Library/Frameworks/Cocoa.framework/Versions/A/Cocoa diff --git a/pkgs/by-name/si/signald/package.nix b/pkgs/by-name/si/signald/package.nix index 47d79cd88b6d9f..7b5a2e99025d80 100644 --- a/pkgs/by-name/si/signald/package.nix +++ b/pkgs/by-name/si/signald/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitLab, jdk17_headless, coreutils, findutils, gnused, -gradle_8, git, makeWrapper, jre_minimal +{ + lib, + stdenv, + fetchFromGitLab, + jdk17_headless, + coreutils, + findutils, + gnused, + gradle_8, + git, + makeWrapper, + jre_minimal, }: let @@ -35,7 +45,8 @@ let # "Deprecated Gradle features were used in this build, making it incompatible with Gradle 9.0." gradle = gradle_8; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname src version; mitmCache = gradle.fetchDeps { @@ -55,13 +66,23 @@ in stdenv.mkDerivation { mkdir -p $out tar xvf ./build/distributions/signald.tar --strip-components=1 --directory $out/ wrapProgram $out/bin/signald \ - --prefix PATH : ${lib.makeBinPath [ coreutils findutils gnused ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + findutils + gnused + ] + } \ --set JAVA_HOME "${jre'}" runHook postInstall ''; - nativeBuildInputs = [ git gradle makeWrapper ]; + nativeBuildInputs = [ + git + gradle + makeWrapper + ]; doCheck = true; @@ -84,10 +105,15 @@ in stdenv.mkDerivation { homepage = "https://signald.org"; sourceProvenance = with sourceTypes; [ fromSource - binaryBytecode # deps + binaryBytecode # deps ]; license = licenses.gpl3Plus; - maintainers = []; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + maintainers = [ ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; }; } diff --git a/pkgs/by-name/si/signaldctl/package.nix b/pkgs/by-name/si/signaldctl/package.nix index 128ecd0f5b56fa..59e1984f4d717b 100644 --- a/pkgs/by-name/si/signaldctl/package.nix +++ b/pkgs/by-name/si/signaldctl/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitLab -, gitUpdater +{ + lib, + buildGoModule, + fetchFromGitLab, + gitUpdater, }: buildGoModule rec { diff --git a/pkgs/by-name/si/signaturepdf/package.nix b/pkgs/by-name/si/signaturepdf/package.nix index 3b5d66508efbed..c53077252a81ee 100644 --- a/pkgs/by-name/si/signaturepdf/package.nix +++ b/pkgs/by-name/si/signaturepdf/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, php -, makeWrapper -, imagemagick -, librsvg -, potrace -, pdftk -, ghostscript +{ + lib, + stdenv, + fetchFromGitHub, + php, + makeWrapper, + imagemagick, + librsvg, + potrace, + pdftk, + ghostscript, }: stdenv.mkDerivation rec { @@ -36,7 +37,15 @@ stdenv.mkDerivation rec { makeWrapper ${lib.getExe php} $out/bin/signaturepdf \ --inherit-argv0 \ --chdir $out/share/signaturepdf \ - --prefix PATH : ${lib.makeBinPath [ imagemagick librsvg potrace pdftk ghostscript ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + imagemagick + librsvg + potrace + pdftk + ghostscript + ] + } \ --run 'port=$1' \ --run '[ $# -ge 1 ] || ( echo "Usage $0 -d upload_max_filesize=24M -d post_max_size=24M -d max_file_uploads=201" >&2 && exit 1 )' \ --run 'shift' \ @@ -50,8 +59,7 @@ stdenv.mkDerivation rec { description = "Web software for signing PDFs and also organize pages, edit metadata and compress pdf"; mainProgram = "signaturepdf"; homepage = "https://pdf.24eme.fr/"; - changelog = - "https://github.com/24eme/signaturepdf/releases/tag/v${version}"; + changelog = "https://github.com/24eme/signaturepdf/releases/tag/v${version}"; license = licenses.agpl3Only; platforms = platforms.all; maintainers = with maintainers; [ DamienCassou ]; diff --git a/pkgs/by-name/si/signify/package.nix b/pkgs/by-name/si/signify/package.nix index fe1c2bf4534529..33b188a92261b1 100644 --- a/pkgs/by-name/si/signify/package.nix +++ b/pkgs/by-name/si/signify/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, libbsd, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + libbsd, + pkg-config, +}: stdenv.mkDerivation rec { pname = "signify"; diff --git a/pkgs/by-name/si/signing-party/package.nix b/pkgs/by-name/si/signing-party/package.nix index 5780fca0250e1e..bd64a183cc1ea4 100644 --- a/pkgs/by-name/si/signing-party/package.nix +++ b/pkgs/by-name/si/signing-party/package.nix @@ -1,17 +1,45 @@ -{ lib, stdenv, fetchFromGitLab, autoconf, automake, makeWrapper -, python3, perl, perlPackages -, libmd, gnupg, which, getopt, libpaper, nettools, qprint -, sendmailPath ? "/run/wrappers/bin/sendmail" }: +{ + lib, + stdenv, + fetchFromGitLab, + autoconf, + automake, + makeWrapper, + python3, + perl, + perlPackages, + libmd, + gnupg, + which, + getopt, + libpaper, + nettools, + qprint, + sendmailPath ? "/run/wrappers/bin/sendmail", +}: let # All runtime dependencies from the CPAN graph: # https://widgets.stratopan.com/wheel?q=GnuPG-Interface-0.52&runtime=1&fs=1 GnuPGInterfaceRuntimeDependencies = with perlPackages; [ - strictures ClassMethodModifiers DataPerl DevelGlobalDestruction ExporterTiny - GnuPGInterface ListMoreUtils ModuleRuntime Moo MooXHandlesVia MooXlate - RoleTiny SubExporterProgressive SubQuote TypeTiny + strictures + ClassMethodModifiers + DataPerl + DevelGlobalDestruction + ExporterTiny + GnuPGInterface + ListMoreUtils + ModuleRuntime + Moo + MooXHandlesVia + MooXlate + RoleTiny + SubExporterProgressive + SubQuote + TypeTiny ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "signing-party"; version = "2.11"; @@ -43,8 +71,18 @@ in stdenv.mkDerivation rec { # Perl is required for it's pod2man. # Python and Perl are required for patching the script interpreter paths. - nativeBuildInputs = [ autoconf automake makeWrapper ]; - buildInputs = [ python3 perl perlPackages.GnuPGInterface libmd gnupg ]; + nativeBuildInputs = [ + autoconf + automake + makeWrapper + ]; + buildInputs = [ + python3 + perl + perlPackages.GnuPGInterface + libmd + gnupg + ]; postInstall = '' # Install all tools which aren't handled by 'make install'. @@ -119,81 +157,124 @@ in stdenv.mkDerivation rec { ''; postFixup = '' - # Add the runtime dependencies for all programs (but mainly for the Perl - # scripts) - - wrapProgram $out/bin/caff --set PERL5LIB \ - ${with perlPackages; makePerlPath ([ - TextTemplate MIMETools MailTools TimeDate NetIDNEncode SubHandlesVia ] - ++ GnuPGInterfaceRuntimeDependencies)} \ - --prefix PATH ":" \ - "${lib.makeBinPath [ nettools gnupg ]}" - - wrapProgram $out/bin/gpg-key2latex --set PERL5LIB \ - ${perlPackages.makePerlPath GnuPGInterfaceRuntimeDependencies} \ - --prefix PATH ":" \ - "${lib.makeBinPath [ gnupg libpaper ]}" - - wrapProgram $out/bin/gpg-key2ps --prefix PATH ":" \ - "${lib.makeBinPath [ which gnupg libpaper ]}" - - wrapProgram $out/bin/gpg-mailkeys --prefix PATH ":" \ - "${lib.makeBinPath [ gnupg qprint ]}" - - wrapProgram $out/bin/gpgdir --set PERL5LIB \ - ${with perlPackages; makePerlPath ([ - TermReadKey ] - ++ GnuPGInterfaceRuntimeDependencies)} \ - --prefix PATH ":" \ - "${lib.makeBinPath [ gnupg ]}" - - wrapProgram $out/bin/gpglist --prefix PATH ":" \ - "${lib.makeBinPath [ gnupg ]}" - - wrapProgram $out/bin/gpgparticipants --prefix PATH ":" \ - "${lib.makeBinPath [ getopt gnupg ]}" - -# wrapProgram $out/bin/gpgparticipants-prefill - - wrapProgram $out/bin/gpgparticipants-filter --prefix PATH ":" \ - "${lib.makeBinPath [ gnupg ]}" - - wrapProgram $out/bin/gpgsigs --set PERL5LIB \ - ${perlPackages.makePerlPath GnuPGInterfaceRuntimeDependencies} \ - --prefix PATH ":" \ - "${lib.makeBinPath [ gnupg ]}" - - wrapProgram $out/bin/gpgwrap --prefix PATH ":" \ - "${lib.makeBinPath [ gnupg ]}" - -# wrapProgram $out/bin/keyanalyze --set PERL5LIB \ - - wrapProgram $out/bin/keyart --prefix PATH ":" \ - "${lib.makeBinPath [ gnupg ]}" - - wrapProgram $out/bin/keylookup --prefix PATH ":" \ - "${lib.makeBinPath [ gnupg ]}" - - wrapProgram $out/bin/pgp-clean --set PERL5LIB \ - ${perlPackages.makePerlPath GnuPGInterfaceRuntimeDependencies} \ - --prefix PATH ":" \ - "${lib.makeBinPath [ gnupg ]}" - - wrapProgram $out/bin/pgp-fixkey --set PERL5LIB \ - ${perlPackages.makePerlPath GnuPGInterfaceRuntimeDependencies} \ - --prefix PATH ":" \ - "${lib.makeBinPath [ gnupg ]}" - -# wrapProgram $out/bin/pgpring - -# wrapProgram $out/bin/process_keys - - # Upstream-Bug: Seems like sig2dot doesn't work with 2.1 (modern) anymore, - # please use 2.0 (stable) instead. -# wrapProgram $out/bin/sig2dot - - wrapProgram $out/bin/springgraph --set PERL5LIB \ - ${with perlPackages; makePerlPath [ GD ]} + # Add the runtime dependencies for all programs (but mainly for the Perl + # scripts) + + wrapProgram $out/bin/caff --set PERL5LIB \ + ${ + with perlPackages; + makePerlPath ( + [ + TextTemplate + MIMETools + MailTools + TimeDate + NetIDNEncode + SubHandlesVia + ] + ++ GnuPGInterfaceRuntimeDependencies + ) + } \ + --prefix PATH ":" \ + "${ + lib.makeBinPath [ + nettools + gnupg + ] + }" + + wrapProgram $out/bin/gpg-key2latex --set PERL5LIB \ + ${perlPackages.makePerlPath GnuPGInterfaceRuntimeDependencies} \ + --prefix PATH ":" \ + "${ + lib.makeBinPath [ + gnupg + libpaper + ] + }" + + wrapProgram $out/bin/gpg-key2ps --prefix PATH ":" \ + "${ + lib.makeBinPath [ + which + gnupg + libpaper + ] + }" + + wrapProgram $out/bin/gpg-mailkeys --prefix PATH ":" \ + "${ + lib.makeBinPath [ + gnupg + qprint + ] + }" + + wrapProgram $out/bin/gpgdir --set PERL5LIB \ + ${ + with perlPackages; + makePerlPath ( + [ + TermReadKey + ] + ++ GnuPGInterfaceRuntimeDependencies + ) + } \ + --prefix PATH ":" \ + "${lib.makeBinPath [ gnupg ]}" + + wrapProgram $out/bin/gpglist --prefix PATH ":" \ + "${lib.makeBinPath [ gnupg ]}" + + wrapProgram $out/bin/gpgparticipants --prefix PATH ":" \ + "${ + lib.makeBinPath [ + getopt + gnupg + ] + }" + + # wrapProgram $out/bin/gpgparticipants-prefill + + wrapProgram $out/bin/gpgparticipants-filter --prefix PATH ":" \ + "${lib.makeBinPath [ gnupg ]}" + + wrapProgram $out/bin/gpgsigs --set PERL5LIB \ + ${perlPackages.makePerlPath GnuPGInterfaceRuntimeDependencies} \ + --prefix PATH ":" \ + "${lib.makeBinPath [ gnupg ]}" + + wrapProgram $out/bin/gpgwrap --prefix PATH ":" \ + "${lib.makeBinPath [ gnupg ]}" + + # wrapProgram $out/bin/keyanalyze --set PERL5LIB \ + + wrapProgram $out/bin/keyart --prefix PATH ":" \ + "${lib.makeBinPath [ gnupg ]}" + + wrapProgram $out/bin/keylookup --prefix PATH ":" \ + "${lib.makeBinPath [ gnupg ]}" + + wrapProgram $out/bin/pgp-clean --set PERL5LIB \ + ${perlPackages.makePerlPath GnuPGInterfaceRuntimeDependencies} \ + --prefix PATH ":" \ + "${lib.makeBinPath [ gnupg ]}" + + wrapProgram $out/bin/pgp-fixkey --set PERL5LIB \ + ${perlPackages.makePerlPath GnuPGInterfaceRuntimeDependencies} \ + --prefix PATH ":" \ + "${lib.makeBinPath [ gnupg ]}" + + # wrapProgram $out/bin/pgpring + + # wrapProgram $out/bin/process_keys + + # Upstream-Bug: Seems like sig2dot doesn't work with 2.1 (modern) anymore, + # please use 2.0 (stable) instead. + # wrapProgram $out/bin/sig2dot + + wrapProgram $out/bin/springgraph --set PERL5LIB \ + ${with perlPackages; makePerlPath [ GD ]} ''; meta = with lib; { @@ -219,7 +300,13 @@ in stdenv.mkDerivation rec { * keyart: creates a random ASCII art of a PGP key file * gpg-key2latex: generate LaTeX file with fingerprint paper slips ''; - license = with licenses; [ bsd2 bsd3 gpl2Only gpl2Plus gpl3Plus ]; + license = with licenses; [ + bsd2 + bsd3 + gpl2Only + gpl2Plus + gpl3Plus + ]; maintainers = with maintainers; [ primeos ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/si/signwriting/package.nix b/pkgs/by-name/si/signwriting/package.nix index ae5f0bb0fb9308..46a92e04540982 100644 --- a/pkgs/by-name/si/signwriting/package.nix +++ b/pkgs/by-name/si/signwriting/package.nix @@ -1,32 +1,37 @@ -{ lib, runCommand, fetchurl }: +{ + lib, + runCommand, + fetchurl, +}: -runCommand "signwriting-1.1.4" { - src1 = fetchurl { - url = "https://github.com/Slevinski/signwriting_2010_fonts/raw/61c8e7123a1168657b5d34d85266a637f67b9d2b/fonts/SignWriting%202010.ttf"; - name = "SignWriting_2010.ttf"; - sha256 = "1abjzykbjx2hal8mrxp51rvblv3q84akyn9qhjfaj20rwphkf5zj"; - }; +runCommand "signwriting-1.1.4" + { + src1 = fetchurl { + url = "https://github.com/Slevinski/signwriting_2010_fonts/raw/61c8e7123a1168657b5d34d85266a637f67b9d2b/fonts/SignWriting%202010.ttf"; + name = "SignWriting_2010.ttf"; + sha256 = "1abjzykbjx2hal8mrxp51rvblv3q84akyn9qhjfaj20rwphkf5zj"; + }; - src2 = fetchurl { - url = "https://github.com/Slevinski/signwriting_2010_fonts/raw/61c8e7123a1168657b5d34d85266a637f67b9d2b/fonts/SignWriting%202010%20Filling.ttf"; - name = "SignWriting_2010_Filling.ttf"; - sha256 = "0am5wbf7jdy9szxkbsc5f3959cxvbj7mr0hy1ziqmkz02c6xjw2m"; - }; + src2 = fetchurl { + url = "https://github.com/Slevinski/signwriting_2010_fonts/raw/61c8e7123a1168657b5d34d85266a637f67b9d2b/fonts/SignWriting%202010%20Filling.ttf"; + name = "SignWriting_2010_Filling.ttf"; + sha256 = "0am5wbf7jdy9szxkbsc5f3959cxvbj7mr0hy1ziqmkz02c6xjw2m"; + }; - outputHashAlgo = "sha256"; - outputHashMode = "recursive"; - outputHash = "0cn37s3lc7gbr8036l7ia2869qmxglkmgllh3r9q5j54g3sfjc7q"; + outputHashAlgo = "sha256"; + outputHashMode = "recursive"; + outputHash = "0cn37s3lc7gbr8036l7ia2869qmxglkmgllh3r9q5j54g3sfjc7q"; - meta = with lib; { - homepage = "https://github.com/Slevinski/signwriting_2010_fonts"; - description = "Typeface for written sign languages"; - maintainers = with maintainers; [ mathnerd314 ]; - license = licenses.ofl; - platforms = platforms.all; - }; -} -'' - mkdir -p $out/share/fonts/truetype - cp $src1 $out/share/fonts/truetype/SignWriting_2010.ttf - cp $src2 $out/share/fonts/truetype/SignWriting_2010_Filling.ttf -'' + meta = with lib; { + homepage = "https://github.com/Slevinski/signwriting_2010_fonts"; + description = "Typeface for written sign languages"; + maintainers = with maintainers; [ mathnerd314 ]; + license = licenses.ofl; + platforms = platforms.all; + }; + } + '' + mkdir -p $out/share/fonts/truetype + cp $src1 $out/share/fonts/truetype/SignWriting_2010.ttf + cp $src2 $out/share/fonts/truetype/SignWriting_2010_Filling.ttf + '' diff --git a/pkgs/by-name/si/sigrok-cli/package.nix b/pkgs/by-name/si/sigrok-cli/package.nix index f239d03cb6a42f..666dfc1446d315 100644 --- a/pkgs/by-name/si/sigrok-cli/package.nix +++ b/pkgs/by-name/si/sigrok-cli/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchgit, autoreconfHook, pkg-config, glib, libsigrok, libsigrokdecode }: +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + pkg-config, + glib, + libsigrok, + libsigrokdecode, +}: stdenv.mkDerivation rec { pname = "sigrok-cli"; @@ -10,8 +19,15 @@ stdenv.mkDerivation rec { hash = "sha256-B2FJxRkfKELrtqxZDv5QTvntpu9zJnTK15CAUYbf+5M="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ glib libsigrok libsigrokdecode ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + glib + libsigrok + libsigrokdecode + ]; meta = with lib; { description = "Command-line frontend for the sigrok signal analysis software suite"; @@ -19,6 +35,9 @@ stdenv.mkDerivation rec { homepage = "https://sigrok.org/"; license = licenses.gpl3Plus; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ bjornfor vifino ]; + maintainers = with maintainers; [ + bjornfor + vifino + ]; }; } diff --git a/pkgs/by-name/si/sigrok-firmware-fx2lafw/package.nix b/pkgs/by-name/si/sigrok-firmware-fx2lafw/package.nix index 44a095bf59f9d5..5fcc883c4720cd 100644 --- a/pkgs/by-name/si/sigrok-firmware-fx2lafw/package.nix +++ b/pkgs/by-name/si/sigrok-firmware-fx2lafw/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchgit -, autoreconfHook -, sdcc +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + sdcc, }: stdenv.mkDerivation rec { @@ -17,7 +18,10 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - nativeBuildInputs = [ autoreconfHook sdcc ]; + nativeBuildInputs = [ + autoreconfHook + sdcc + ]; meta = with lib; { description = "Firmware for FX2 logic analyzers"; @@ -26,12 +30,15 @@ stdenv.mkDerivation rec { # licensing details explained in: # https://sigrok.org/gitweb/?p=sigrok-firmware-fx2lafw.git;a=blob;f=README;hb=HEAD#l122 license = with licenses; [ - gpl2Plus # overall - lgpl21Plus # fx2lib, Hantek 6022BE, Sainsmart DDS120 firmwares + gpl2Plus # overall + lgpl21Plus # fx2lib, Hantek 6022BE, Sainsmart DDS120 firmwares ]; sourceProvenance = with sourceTypes; [ fromSource ]; platforms = platforms.all; - maintainers = with maintainers; [ panicgh vifino ]; + maintainers = with maintainers; [ + panicgh + vifino + ]; }; } diff --git a/pkgs/by-name/si/sigslot/package.nix b/pkgs/by-name/si/sigslot/package.nix index 8a97ab9d32e9ab..244d56e91cc0b0 100644 --- a/pkgs/by-name/si/sigslot/package.nix +++ b/pkgs/by-name/si/sigslot/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/si/sigtop/package.nix b/pkgs/by-name/si/sigtop/package.nix index 08043c391bc94c..0935e9900b3645 100644 --- a/pkgs/by-name/si/sigtop/package.nix +++ b/pkgs/by-name/si/sigtop/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { name = "sigtop"; diff --git a/pkgs/by-name/si/sigutils/package.nix b/pkgs/by-name/si/sigutils/package.nix index 8b384af02270d9..a0ebb704137eab 100644 --- a/pkgs/by-name/si/sigutils/package.nix +++ b/pkgs/by-name/si/sigutils/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, fftwSinglePrec -, libsndfile -, volk +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + fftwSinglePrec, + libsndfile, + volk, }: stdenv.mkDerivation rec { @@ -35,6 +36,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/BatchDrake/sigutils"; license = licenses.gpl3; platforms = platforms.all; - maintainers = with maintainers; [ polygon oxapentane ]; + maintainers = with maintainers; [ + polygon + oxapentane + ]; }; } diff --git a/pkgs/by-name/si/siji/package.nix b/pkgs/by-name/si/siji/package.nix index 0ae5914eb1318c..9fea0e378f9cfe 100644 --- a/pkgs/by-name/si/siji/package.nix +++ b/pkgs/by-name/si/siji/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, libfaketime, xorg }: +{ + lib, + stdenv, + fetchFromGitHub, + libfaketime, + xorg, +}: stdenv.mkDerivation rec { pname = "siji"; @@ -11,7 +17,11 @@ stdenv.mkDerivation rec { sha256 = "1408g4nxwdd682vjqpmgv0cp0bfnzzzwls62cjs9zrds16xa9dpf"; }; - nativeBuildInputs = [ libfaketime xorg.fonttosfnt xorg.mkfontscale ]; + nativeBuildInputs = [ + libfaketime + xorg.fonttosfnt + xorg.mkfontscale + ]; buildPhase = '' # compress pcf fonts @@ -32,7 +42,10 @@ stdenv.mkDerivation rec { mkfontdir "$bdf/share/fonts/misc" ''; - outputs = [ "out" "bdf" ]; + outputs = [ + "out" + "bdf" + ]; meta = with lib; { homepage = "https://github.com/stark/siji"; diff --git a/pkgs/by-name/si/sil-abyssinica/package.nix b/pkgs/by-name/si/sil-abyssinica/package.nix index d0571fae0bfdaf..3f8e34c8264e29 100644 --- a/pkgs/by-name/si/sil-abyssinica/package.nix +++ b/pkgs/by-name/si/sil-abyssinica/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "sil-abyssinica"; diff --git a/pkgs/by-name/si/sil-padauk/package.nix b/pkgs/by-name/si/sil-padauk/package.nix index f3df1d1febe286..911d5c93707219 100644 --- a/pkgs/by-name/si/sil-padauk/package.nix +++ b/pkgs/by-name/si/sil-padauk/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "sil-padauk"; diff --git a/pkgs/by-name/si/sil-q/package.nix b/pkgs/by-name/si/sil-q/package.nix index 796ab12e2ea9f0..b8ab1befd9256a 100644 --- a/pkgs/by-name/si/sil-q/package.nix +++ b/pkgs/by-name/si/sil-q/package.nix @@ -1,4 +1,13 @@ -{ pkgs, lib, stdenv, fetchFromGitHub, writeScript, makeWrapper, ncurses, libX11 }: +{ + pkgs, + lib, + stdenv, + fetchFromGitHub, + writeScript, + makeWrapper, + ncurses, + libX11, +}: let setup = writeScript "setup" '' @@ -8,7 +17,8 @@ let # the copied files need to be writable chmod +w -R "$ANGBAND_PATH" ''; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "sil-q"; version = "1.5.0"; @@ -20,7 +30,10 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ ncurses libX11 ]; + buildInputs = [ + ncurses + libX11 + ]; # Makefile(s) and config are not top-level sourceRoot = "${src.name}/src"; @@ -48,7 +61,7 @@ in stdenv.mkDerivation rec { ''; passthru.tests = { - saveDirCreation = pkgs.runCommand "save-dir-creation" {} '' + saveDirCreation = pkgs.runCommand "save-dir-creation" { } '' HOME=$(pwd) ${lib.getExe pkgs.sil-q} --help test -d .sil-q && touch $out ''; diff --git a/pkgs/by-name/si/sil/package.nix b/pkgs/by-name/si/sil/package.nix index f50fc358efe2ff..9e72ff583a8287 100644 --- a/pkgs/by-name/si/sil/package.nix +++ b/pkgs/by-name/si/sil/package.nix @@ -1,5 +1,17 @@ -{ pkgs, lib, stdenv, fetchzip, ncurses, libX11, libXaw, libXt, libXext, libXmu -, makeWrapper, writeScript }: +{ + pkgs, + lib, + stdenv, + fetchzip, + ncurses, + libX11, + libXaw, + libXt, + libXext, + libXmu, + makeWrapper, + writeScript, +}: let setup = writeScript "setup" '' @@ -21,7 +33,14 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ ncurses libX11 libXaw libXt libXext libXmu ]; + buildInputs = [ + ncurses + libX11 + libXaw + libXt + libXext + libXmu + ]; sourceRoot = "${src.name}/Sil/src"; @@ -60,7 +79,7 @@ stdenv.mkDerivation rec { ''; passthru.tests = { - saveDirCreation = pkgs.runCommand "save-dir-creation" {} '' + saveDirCreation = pkgs.runCommand "save-dir-creation" { } '' HOME=$(pwd) ${lib.getExe pkgs.sil} --help test -d .sil && touch $out ''; @@ -77,7 +96,10 @@ stdenv.mkDerivation rec { ''; homepage = "http://www.amirrorclear.net/flowers/game/sil/index.html"; license = lib.licenses.gpl2Only; - maintainers = with lib.maintainers; [ michaelpj kenran ]; + maintainers = with lib.maintainers; [ + michaelpj + kenran + ]; platforms = lib.platforms.linux; mainProgram = "sil"; }; diff --git a/pkgs/by-name/si/silc_client/package.nix b/pkgs/by-name/si/silc_client/package.nix index 7a64e5cc123324..80c263b51ae0f1 100644 --- a/pkgs/by-name/si/silc_client/package.nix +++ b/pkgs/by-name/si/silc_client/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchurl, perl, pkg-config, glib, ncurses -, enablePlugin ? false }: +{ + lib, + stdenv, + fetchurl, + perl, + pkg-config, + glib, + ncurses, + enablePlugin ? false, +}: # Enabling the plugin and using it with a recent irssi, segafults on join: # http://marc.info/?l=silc-devel&m=125610477802211 @@ -26,7 +34,11 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ perl glib ncurses ]; + buildInputs = [ + perl + glib + ncurses + ]; meta = { homepage = "http://silcnet.org/"; diff --git a/pkgs/by-name/si/silc_server/package.nix b/pkgs/by-name/si/silc_server/package.nix index 6ed1a2dd5e9198..22d706ce3fa4f5 100644 --- a/pkgs/by-name/si/silc_server/package.nix +++ b/pkgs/by-name/si/silc_server/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "silc-server"; diff --git a/pkgs/by-name/si/silenthound/package.nix b/pkgs/by-name/si/silenthound/package.nix index 22ecb946d4a642..1df9d25c8c37f5 100644 --- a/pkgs/by-name/si/silenthound/package.nix +++ b/pkgs/by-name/si/silenthound/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/si/silice/package.nix b/pkgs/by-name/si/silice/package.nix index 4dfc83f9944b37..cdc062c5c0c9c2 100644 --- a/pkgs/by-name/si/silice/package.nix +++ b/pkgs/by-name/si/silice/package.nix @@ -1,10 +1,20 @@ -{ stdenv, fetchFromGitHub, lib -, cmake, pkg-config, openjdk -, libuuid, python3 -, glfw -, yosys, nextpnr, verilator -, dfu-util, icestorm, trellis -, unstableGitUpdater +{ + stdenv, + fetchFromGitHub, + lib, + cmake, + pkg-config, + openjdk, + libuuid, + python3, + glfw, + yosys, + nextpnr, + verilator, + dfu-util, + icestorm, + trellis, + unstableGitUpdater, }: stdenv.mkDerivation (finalAttrs: { @@ -54,39 +64,42 @@ stdenv.mkDerivation (finalAttrs: { passthru.tests = let silice = finalAttrs.finalPackage; - testProject = project: stdenv.mkDerivation { - name = "${silice.name}-test-${project}"; - nativeBuildInputs = [ - silice - yosys - nextpnr - verilator - dfu-util - icestorm - trellis - ]; - src = "${silice.src}/projects"; - sourceRoot = "projects/${project}"; - buildPhase = '' - targets=() - for target in $(cat configs | tr -d '\r') ; do - [[ $target != Makefile* ]] || continue - make $target ARGS="--no_program" - targets+=($target) - done - if test "''${#targets[@]}" -eq 0; then - >&2 echo "ERROR: no target found!" - false - fi - ''; - installPhase = '' - mkdir $out - for target in "''${targets[@]}" ; do - [[ $target != Makefile* ]] || continue - done - ''; - }; - in { + testProject = + project: + stdenv.mkDerivation { + name = "${silice.name}-test-${project}"; + nativeBuildInputs = [ + silice + yosys + nextpnr + verilator + dfu-util + icestorm + trellis + ]; + src = "${silice.src}/projects"; + sourceRoot = "projects/${project}"; + buildPhase = '' + targets=() + for target in $(cat configs | tr -d '\r') ; do + [[ $target != Makefile* ]] || continue + make $target ARGS="--no_program" + targets+=($target) + done + if test "''${#targets[@]}" -eq 0; then + >&2 echo "ERROR: no target found!" + false + fi + ''; + installPhase = '' + mkdir $out + for target in "''${targets[@]}" ; do + [[ $target != Makefile* ]] || continue + done + ''; + }; + in + { # a selection of test projects that build with the FPGA tools in # nixpkgs audio_sdcard_streamer = testProject "audio_sdcard_streamer"; diff --git a/pkgs/by-name/si/silicon/package.nix b/pkgs/by-name/si/silicon/package.nix index 2c0bb500e4a6b1..31920757f9525a 100644 --- a/pkgs/by-name/si/silicon/package.nix +++ b/pkgs/by-name/si/silicon/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, cmake -, expat -, freetype -, libxcb -, python3 -, libiconv -, darwin -, fira-code -, fontconfig -, harfbuzz +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + cmake, + expat, + freetype, + libxcb, + python3, + libiconv, + darwin, + fira-code, + fontconfig, + harfbuzz, }: rustPlatform.buildRustPackage rec { @@ -33,17 +34,30 @@ rustPlatform.buildRustPackage rec { }; }; - buildInputs = [ expat freetype fira-code fontconfig harfbuzz ] + buildInputs = + [ + expat + freetype + fira-code + fontconfig + harfbuzz + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libxcb ] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - libiconv - AppKit - CoreText - Security - ]); + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + libiconv + AppKit + CoreText + Security + ] + ); - nativeBuildInputs = [ cmake pkg-config rustPlatform.bindgenHook ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ python3 ]; + nativeBuildInputs = [ + cmake + pkg-config + rustPlatform.bindgenHook + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ python3 ]; preCheck = '' export HOME=$TMPDIR @@ -52,8 +66,14 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Create beautiful image of your source code"; homepage = "https://github.com/Aloxaf/silicon"; - license = with licenses; [ mit /* or */ asl20 ]; - maintainers = with maintainers; [ evanjs _0x4A6F ]; + license = with licenses; [ + mit # or + asl20 + ]; + maintainers = with maintainers; [ + evanjs + _0x4A6F + ]; mainProgram = "silicon"; }; } diff --git a/pkgs/by-name/si/silver-searcher/package.nix b/pkgs/by-name/si/silver-searcher/package.nix index c5e5986d6b98e9..2c225bdd585fbc 100644 --- a/pkgs/by-name/si/silver-searcher/package.nix +++ b/pkgs/by-name/si/silver-searcher/package.nix @@ -1,4 +1,13 @@ -{lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, pcre, zlib, xz}: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + pcre, + zlib, + xz, +}: stdenv.mkDerivation rec { pname = "silver-searcher"; @@ -21,8 +30,15 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = "-fcommon"; NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isLinux "-lgcc_s"; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ pcre zlib xz ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + pcre + zlib + xz + ]; meta = with lib; { homepage = "https://github.com/ggreer/the_silver_searcher/"; diff --git a/pkgs/by-name/si/simde/package.nix b/pkgs/by-name/si/simde/package.nix index e3896021e0de8b..894a02de384ee2 100644 --- a/pkgs/by-name/si/simde/package.nix +++ b/pkgs/by-name/si/simde/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, meson, ninja }: +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, +}: stdenv.mkDerivation rec { pname = "simde"; @@ -11,21 +17,27 @@ stdenv.mkDerivation rec { hash = "sha256-igjDHCpKXy6EbA9Mf6peL4OTVRPYTV0Y2jbgYQuWMT4="; }; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; meta = with lib; { homepage = "https://simd-everywhere.github.io"; description = "Implementations of SIMD instruction sets for systems which don't natively support them"; - license = with licenses; [mit]; + license = with licenses; [ mit ]; maintainers = with maintainers; [ whiteley ]; - platforms = flatten (with platforms; [ - arm - armv7 - aarch64 - x86 - power - mips - riscv - ]); + platforms = flatten ( + with platforms; + [ + arm + armv7 + aarch64 + x86 + power + mips + riscv + ] + ); }; } diff --git a/pkgs/by-name/si/simdjson/package.nix b/pkgs/by-name/si/simdjson/package.nix index 3fdf54e181b382..9707162cf0c0ea 100644 --- a/pkgs/by-name/si/simdjson/package.nix +++ b/pkgs/by-name/si/simdjson/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "simdjson"; @@ -13,15 +18,18 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - cmakeFlags = [ - "-DSIMDJSON_DEVELOPER_MODE=OFF" - ] ++ lib.optionals stdenv.hostPlatform.isStatic [ - "-DBUILD_SHARED_LIBS=OFF" - ] ++ lib.optionals (with stdenv.hostPlatform; isPower && isBigEndian) [ - # Assume required CPU features are available, since otherwise we - # just get a failed build. - "-DCMAKE_CXX_FLAGS=-mpower8-vector" - ]; + cmakeFlags = + [ + "-DSIMDJSON_DEVELOPER_MODE=OFF" + ] + ++ lib.optionals stdenv.hostPlatform.isStatic [ + "-DBUILD_SHARED_LIBS=OFF" + ] + ++ lib.optionals (with stdenv.hostPlatform; isPower && isBigEndian) [ + # Assume required CPU features are available, since otherwise we + # just get a failed build. + "-DCMAKE_CXX_FLAGS=-mpower8-vector" + ]; meta = with lib; { homepage = "https://simdjson.org/"; diff --git a/pkgs/by-name/si/simdutf/package.nix b/pkgs/by-name/si/simdutf/package.nix index 5bec4d0ca1d9d2..299780adaf9783 100644 --- a/pkgs/by-name/si/simdutf/package.nix +++ b/pkgs/by-name/si/simdutf/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libiconv +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libiconv, }: stdenv.mkDerivation (finalAttrs: { @@ -32,7 +33,10 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Unicode routines validation and transcoding at billions of characters per second"; homepage = "https://github.com/simdutf/simdutf"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ rewine ]; mainProgram = "simdutf"; platforms = platforms.all; diff --git a/pkgs/by-name/si/simgear/package.nix b/pkgs/by-name/si/simgear/package.nix index 416274e1c54521..232f5b31eeda4c 100644 --- a/pkgs/by-name/si/simgear/package.nix +++ b/pkgs/by-name/si/simgear/package.nix @@ -1,7 +1,30 @@ -{ lib, stdenv, fetchurl, plib, libglut, xorgproto, libX11, libXext, libXi -, libICE, libSM, libXt, libXmu, libGLU, libGL, boost179, zlib, libjpeg, freealut -, openscenegraph, openal, expat, cmake, apr, xz -, curl +{ + lib, + stdenv, + fetchurl, + plib, + libglut, + xorgproto, + libX11, + libXext, + libXi, + libICE, + libSM, + libXt, + libXmu, + libGLU, + libGL, + boost179, + zlib, + libjpeg, + freealut, + openscenegraph, + openal, + expat, + cmake, + apr, + xz, + curl, }: let version = "2020.3.19"; @@ -17,9 +40,30 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ plib libglut xorgproto libX11 libXext libXi - libICE libSM libXt libXmu libGLU libGL boost179 zlib libjpeg freealut - openscenegraph openal expat apr curl xz ]; + buildInputs = [ + plib + libglut + xorgproto + libX11 + libXext + libXi + libICE + libSM + libXt + libXmu + libGLU + libGL + boost179 + zlib + libjpeg + freealut + openscenegraph + openal + expat + apr + curl + xz + ]; meta = with lib; { description = "Simulation construction toolkit"; diff --git a/pkgs/by-name/si/simgrid/package.nix b/pkgs/by-name/si/simgrid/package.nix index 81a474f2d9aa89..7f019e0c2450a9 100644 --- a/pkgs/by-name/si/simgrid/package.nix +++ b/pkgs/by-name/si/simgrid/package.nix @@ -1,15 +1,32 @@ -{ stdenv, lib, fetchFromGitLab, cmake, perl, python3, boost -, fortranSupport ? false, gfortran -, buildDocumentation ? false, fig2dev, ghostscript, doxygen -, buildJavaBindings ? false, openjdk -, buildPythonBindings ? true, python3Packages -, modelCheckingSupport ? false, libunwind, libevent, elfutils # Inside elfutils: libelf and libdw -, bmfSupport ? true, eigen -, minimalBindings ? false -, debug ? false -, optimize ? (!debug) -, moreTests ? false -, withoutBin ? false +{ + stdenv, + lib, + fetchFromGitLab, + cmake, + perl, + python3, + boost, + fortranSupport ? false, + gfortran, + buildDocumentation ? false, + fig2dev, + ghostscript, + doxygen, + buildJavaBindings ? false, + openjdk, + buildPythonBindings ? true, + python3Packages, + modelCheckingSupport ? false, + libunwind, + libevent, + elfutils, # Inside elfutils: libelf and libdw + bmfSupport ? true, + eigen, + minimalBindings ? false, + debug ? false, + optimize ? (!debug), + moreTests ? false, + withoutBin ? false, }: stdenv.mkDerivation rec { @@ -25,16 +42,28 @@ stdenv.mkDerivation rec { }; propagatedBuildInputs = [ boost ]; - nativeBuildInputs = [ cmake perl python3 ] + nativeBuildInputs = + [ + cmake + perl + python3 + ] ++ lib.optionals fortranSupport [ gfortran ] ++ lib.optionals buildJavaBindings [ openjdk ] ++ lib.optionals buildPythonBindings [ python3Packages.pybind11 ] - ++ lib.optionals buildDocumentation [ fig2dev ghostscript doxygen ] + ++ lib.optionals buildDocumentation [ + fig2dev + ghostscript + doxygen + ] ++ lib.optionals bmfSupport [ eigen ] - ++ lib.optionals modelCheckingSupport [ libunwind libevent elfutils ]; + ++ lib.optionals modelCheckingSupport [ + libunwind + libevent + elfutils + ]; - outputs = [ "out" ] - ++ lib.optionals buildPythonBindings [ "python" ]; + outputs = [ "out" ] ++ lib.optionals buildPythonBindings [ "python" ]; # "Release" does not work. non-debug mode is Debug compiled with optimization cmakeBuildType = "Debug"; @@ -87,15 +116,17 @@ stdenv.mkDerivation rec { make tests -j $NIX_BUILD_CORES ''; - postInstall = lib.optionalString withoutBin '' - # remove bin from output if requested. - # having a specific bin output would be cleaner but it does not work currently (circular references) - rm -rf $out/bin - '' + lib.optionalString buildPythonBindings '' - # manually install the python binding if requested. - mkdir -p $python/lib/python${lib.versions.majorMinor python3.version}/site-packages/ - cp ./lib/simgrid.cpython*.so $python/lib/python${lib.versions.majorMinor python3.version}/site-packages/ - ''; + postInstall = + lib.optionalString withoutBin '' + # remove bin from output if requested. + # having a specific bin output would be cleaner but it does not work currently (circular references) + rm -rf $out/bin + '' + + lib.optionalString buildPythonBindings '' + # manually install the python binding if requested. + mkdir -p $python/lib/python${lib.versions.majorMinor python3.version}/site-packages/ + cp ./lib/simgrid.cpython*.so $python/lib/python${lib.versions.majorMinor python3.version}/site-packages/ + ''; # improve debuggability if requested hardeningDisable = lib.optionals debug [ "fortify" ]; @@ -113,7 +144,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://simgrid.org/"; license = licenses.lgpl2Plus; - maintainers = with maintainers; [ mickours mpoquet ]; + maintainers = with maintainers; [ + mickours + mpoquet + ]; platforms = platforms.all; broken = stdenv.hostPlatform.isDarwin; }; diff --git a/pkgs/by-name/si/simh/package.nix b/pkgs/by-name/si/simh/package.nix index 74419d500a53e5..7b0b349cd254c3 100644 --- a/pkgs/by-name/si/simh/package.nix +++ b/pkgs/by-name/si/simh/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchFromGitHub -, SDL2 -, SDL2_ttf -, libpcap -, vde2 -, pcre +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + SDL2_ttf, + libpcap, + vde2, + pcre, }: stdenv.mkDerivation rec { @@ -18,7 +20,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-65+YfOWpVXPeT64TZcSaWJY+ODQ0q/pwF9jb8xGdpIs="; }; - buildInputs = [ SDL2 SDL2_ttf libpcap vde2 pcre ]; + buildInputs = [ + SDL2 + SDL2_ttf + libpcap + vde2 + pcre + ]; dontConfigure = true; @@ -27,7 +35,11 @@ stdenv.mkDerivation rec { # https://github.com/simh/simh/issues/794 env.NIX_CFLAGS_COMPILE = toString [ "-fcommon" ]; - makeFlags = [ "GCC=${stdenv.cc.targetPrefix}cc" "CC_STD=-std=c99" "LDFLAGS=-lm" ]; + makeFlags = [ + "GCC=${stdenv.cc.targetPrefix}cc" + "CC_STD=-std=c99" + "LDFLAGS=-lm" + ]; preInstall = '' install -d ${placeholder "out"}/bin diff --git a/pkgs/by-name/si/simp1e-cursors/package.nix b/pkgs/by-name/si/simp1e-cursors/package.nix index fd2cd4fd9daa09..394f362cd56283 100644 --- a/pkgs/by-name/si/simp1e-cursors/package.nix +++ b/pkgs/by-name/si/simp1e-cursors/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenvNoCC, fetchFromGitLab, python3, librsvg, xcursorgen }: +{ + lib, + stdenvNoCC, + fetchFromGitLab, + python3, + librsvg, + xcursorgen, +}: stdenvNoCC.mkDerivation rec { pname = "simp1e-cursors"; diff --git a/pkgs/by-name/si/simple-dlna-browser/package.nix b/pkgs/by-name/si/simple-dlna-browser/package.nix index 1ae74f90761ce8..0f12883dc6b0cb 100644 --- a/pkgs/by-name/si/simple-dlna-browser/package.nix +++ b/pkgs/by-name/si/simple-dlna-browser/package.nix @@ -36,14 +36,16 @@ stdenv.mkDerivation { mkdir -p $out/bin cp sh/tools/simple-dlna-browser $outputWrapped makeWrapper $outputWrapped $outputWrapper \ - --prefix PATH : ${lib.makeBinPath [ - curl - gawk - gnugrep - gnused - socat - wget - ]} + --prefix PATH : ${ + lib.makeBinPath [ + curl + gawk + gnugrep + gnused + socat + wget + ] + } # Set the program name to a fixed value # Normally it is guessed by the filename, but we don't want it to be the name of the wrapper @@ -65,4 +67,3 @@ stdenv.mkDerivation { maintainers = with lib.maintainers; [ ]; }; } - diff --git a/pkgs/by-name/si/simple-http-server/package.nix b/pkgs/by-name/si/simple-http-server/package.nix index fe84eaf3a2d3c5..333a34838aba17 100644 --- a/pkgs/by-name/si/simple-http-server/package.nix +++ b/pkgs/by-name/si/simple-http-server/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -22,9 +23,11 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; # Currently no tests are implemented, so we avoid building the package twice doCheck = false; @@ -34,7 +37,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/TheWaWaR/simple-http-server"; changelog = "https://github.com/TheWaWaR/simple-http-server/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ figsoda mephistophiles ]; + maintainers = with maintainers; [ + figsoda + mephistophiles + ]; mainProgram = "simple-http-server"; }; } diff --git a/pkgs/by-name/si/simple-mtpfs/package.nix b/pkgs/by-name/si/simple-mtpfs/package.nix index 994b785c444e48..77cc2f2611b68b 100644 --- a/pkgs/by-name/si/simple-mtpfs/package.nix +++ b/pkgs/by-name/si/simple-mtpfs/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, autoconf-archive -, pkg-config -, fuse -, libmtp +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + autoconf-archive, + pkg-config, + fuse, + libmtp, }: stdenv.mkDerivation rec { pname = "simple-mtpfs"; @@ -18,8 +19,15 @@ stdenv.mkDerivation rec { hash = "sha256-vAqi2owa4LJK7y7S7TwkPAqDxzyHrZZBTu0MBwMT0gI="; }; - nativeBuildInputs = [ autoreconfHook autoconf-archive pkg-config ]; - buildInputs = [ fuse libmtp ]; + nativeBuildInputs = [ + autoreconfHook + autoconf-archive + pkg-config + ]; + buildInputs = [ + fuse + libmtp + ]; meta = with lib; { description = "Simple MTP fuse filesystem driver"; diff --git a/pkgs/by-name/si/simple-scan/package.nix b/pkgs/by-name/si/simple-scan/package.nix index 5529d594ff15ff..6ee79585d4a889 100644 --- a/pkgs/by-name/si/simple-scan/package.nix +++ b/pkgs/by-name/si/simple-scan/package.nix @@ -1,26 +1,28 @@ -{ lib, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, gettext -, itstool -, python3 -, wrapGAppsHook4 -, cairo -, gdk-pixbuf -, colord -, glib -, libadwaita -, gtk4 -, gusb -, packagekit -, libwebp -, libxml2 -, sane-backends -, vala -, gnome -, gobject-introspection +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + gettext, + itstool, + python3, + wrapGAppsHook4, + cairo, + gdk-pixbuf, + colord, + glib, + libadwaita, + gtk4, + gusb, + packagekit, + libwebp, + libxml2, + sane-backends, + vala, + gnome, + gobject-introspection, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/si/simpleTpmPk11/package.nix b/pkgs/by-name/si/simpleTpmPk11/package.nix index 842eb342c25fbe..e963955a255f9e 100644 --- a/pkgs/by-name/si/simpleTpmPk11/package.nix +++ b/pkgs/by-name/si/simpleTpmPk11/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, trousers, openssl, opencryptoki, autoreconfHook, libtool }: +{ + lib, + stdenv, + fetchFromGitHub, + trousers, + openssl, + opencryptoki, + autoreconfHook, + libtool, +}: stdenv.mkDerivation rec { pname = "simple-tpm-pk11"; @@ -11,8 +20,15 @@ stdenv.mkDerivation rec { sha256 = "0vpbaklr4r1a2am0pqcm6m41ph22mkcrq33y8ab5h8qkhkvhd6a6"; }; - nativeBuildInputs = [ autoreconfHook libtool ]; - buildInputs = [ trousers openssl opencryptoki ]; + nativeBuildInputs = [ + autoreconfHook + libtool + ]; + buildInputs = [ + trousers + openssl + opencryptoki + ]; enableParallelBuilding = true; @@ -21,9 +37,9 @@ stdenv.mkDerivation rec { longDescription = '' A simple library for using the TPM chip to secure SSH keys. ''; - homepage = "https://github.com/ThomasHabets/simple-tpm-pk11"; - license = licenses.asl20; + homepage = "https://github.com/ThomasHabets/simple-tpm-pk11"; + license = licenses.asl20; maintainers = [ ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/si/simplehttp2server/package.nix b/pkgs/by-name/si/simplehttp2server/package.nix index 3ec200a1d20163..190257b16e9267 100644 --- a/pkgs/by-name/si/simplehttp2server/package.nix +++ b/pkgs/by-name/si/simplehttp2server/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "simplehttp2server"; diff --git a/pkgs/by-name/si/simplenes/package.nix b/pkgs/by-name/si/simplenes/package.nix index 061717d5c6560d..9745808d35211b 100644 --- a/pkgs/by-name/si/simplenes/package.nix +++ b/pkgs/by-name/si/simplenes/package.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, sfml +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + sfml, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/si/simpleproxy/package.nix b/pkgs/by-name/si/simpleproxy/package.nix index 3b2b614e282cd1..54dbcb2bec6736 100644 --- a/pkgs/by-name/si/simpleproxy/package.nix +++ b/pkgs/by-name/si/simpleproxy/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "simpleproxy"; diff --git a/pkgs/by-name/si/simplex-chat-desktop/package.nix b/pkgs/by-name/si/simplex-chat-desktop/package.nix index 5fe138d1942067..dc7848d1afdcb8 100644 --- a/pkgs/by-name/si/simplex-chat-desktop/package.nix +++ b/pkgs/by-name/si/simplex-chat-desktop/package.nix @@ -1,7 +1,8 @@ -{ lib -, appimageTools -, fetchurl -, gitUpdater +{ + lib, + appimageTools, + fetchurl, + gitUpdater, }: let @@ -16,19 +17,20 @@ let appimageContents = appimageTools.extract { inherit pname version src; }; -in appimageTools.wrapType2 { - inherit pname version src; +in +appimageTools.wrapType2 { + inherit pname version src; - extraBwrapArgs = [ - "--setenv _JAVA_AWT_WM_NONREPARENTING 1" - ]; + extraBwrapArgs = [ + "--setenv _JAVA_AWT_WM_NONREPARENTING 1" + ]; - extraInstallCommands = '' - install --mode=444 -D ${appimageContents}/chat.simplex.app.desktop --target-directory=$out/share/applications - substituteInPlace $out/share/applications/chat.simplex.app.desktop \ - --replace-fail 'Exec=simplex' 'Exec=simplex-chat-desktop' - cp -r ${appimageContents}/usr/share/icons $out/share - ''; + extraInstallCommands = '' + install --mode=444 -D ${appimageContents}/chat.simplex.app.desktop --target-directory=$out/share/applications + substituteInPlace $out/share/applications/chat.simplex.app.desktop \ + --replace-fail 'Exec=simplex' 'Exec=simplex-chat-desktop' + cp -r ${appimageContents}/usr/share/icons $out/share + ''; passthru.updateScript = gitUpdater { url = "https://github.com/simplex-chat/simplex-chat"; diff --git a/pkgs/by-name/si/simplotask/package.nix b/pkgs/by-name/si/simplotask/package.nix index 0ac5b17ac0680a..ac0c46cc9361dd 100644 --- a/pkgs/by-name/si/simplotask/package.nix +++ b/pkgs/by-name/si/simplotask/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "simplotask"; diff --git a/pkgs/by-name/si/simutrans/package.nix b/pkgs/by-name/si/simutrans/package.nix index b6452819bee51b..b4a01db9642f38 100644 --- a/pkgs/by-name/si/simutrans/package.nix +++ b/pkgs/by-name/si/simutrans/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchurl, pkg-config, unzip, zlib, libpng, bzip2, SDL, SDL_mixer -, buildEnv, config, runtimeShell +{ + lib, + stdenv, + fetchurl, + pkg-config, + unzip, + zlib, + libpng, + bzip2, + SDL, + SDL_mixer, + buildEnv, + config, + runtimeShell, }: let @@ -7,14 +19,16 @@ let paksets = config.simutrans.paksets or "pak64 pak64.japan pak128 pak128.britain pak128.german"; result = withPaks ( - if paksets == "*" then lib.attrValues pakSpec # taking all - else map (name: pakSpec.${name}) (lib.splitString " " paksets) + if paksets == "*" then + lib.attrValues pakSpec # taking all + else + map (name: pakSpec.${name}) (lib.splitString " " paksets) ); ver1 = "121"; ver2 = "0"; ver3 = ""; - version = "${ver1}.${ver2}${lib.optionalString (ver3 != "") ".${ver3}"}"; + version = "${ver1}.${ver2}${lib.optionalString (ver3 != "") ".${ver3}"}"; ver_dash = "${ver1}-${ver2}${lib.optionalString (ver3 != "") "-${ver3}"}"; binary_src = fetchurl { @@ -22,11 +36,8 @@ let sha256 = "1f463r6kr5ig0zd3mncc74k93xbjywsq3d06j5r17831jyc9bzb9"; }; - # As of 2021/07, many of these paksets have not been updated for years, so are on old versions. - pakSpec = lib.mapAttrs - (pakName: attrs: mkPak (attrs // {inherit pakName;})) - { + pakSpec = lib.mapAttrs (pakName: attrs: mkPak (attrs // { inherit pakName; })) { pak64 = { srcPath = "${ver_dash}/simupak64-${ver_dash}"; sha256 = "1k335kh8dhm1hdn5iwn3sdgnrlpk0rqxmmgqgqcwsi09cmw45m5c"; @@ -45,67 +56,81 @@ let srcPath = "pak128.Britain%20for%20120-1/pak128.Britain.1.18-120-3"; sha256 = "1kyb0s54kysvdr0zdln9106yx75d71j4lbw3v87k3i440cj3r1d3"; }; - "pak128.cs" = { # note: it needs pak128 to work + "pak128.cs" = { + # note: it needs pak128 to work url = "mirror://sourceforge/simutrans/Pak128.CS/pak128.cz_v.0.2.1.zip"; sha256 = "008d8x1s0vxsq78rkczlnf57pv1n5hi1v5nbd1l5w3yls7lk11sc"; }; "pak128.german" = { - url = "mirror://sourceforge/simutrans/PAK128.german/" + url = + "mirror://sourceforge/simutrans/PAK128.german/" + "pak128.german_1.2_for_ST_121.0/PAK128.german_1.2_for_ST_121-0.zip"; sha256 = "1cv1rzl1a3i5dvk476zq094wawk9hhdh2f0y4xrdny5gn17mb2xi"; }; - /* This release contains accented filenames that prevent unzipping. - "pak192.comic" = { - srcPath = "pak192comic%20for%20${ver2_dash}/pak192comic-0.4-${ver2_dash}up"; - sha256 = throw ""; - }; + /* + This release contains accented filenames that prevent unzipping. + "pak192.comic" = { + srcPath = "pak192comic%20for%20${ver2_dash}/pak192comic-0.4-${ver2_dash}up"; + sha256 = throw ""; + }; */ }; - - mkPak = { - sha256, pakName, srcPath ? null - , url ? "mirror://sourceforge/simutrans/${pakName}/${srcPath}.zip" - }: + mkPak = + { + sha256, + pakName, + srcPath ? null, + url ? "mirror://sourceforge/simutrans/${pakName}/${srcPath}.zip", + }: stdenv.mkDerivation { name = "simutrans-${pakName}"; dontUnpack = true; preferLocalBuild = true; - installPhase = let src = fetchurl { inherit url sha256; }; - in '' - mkdir -p "$out/share/simutrans/${pakName}" - cd "$out/share/simutrans/${pakName}" - "${unzip}/bin/unzip" "${src}" - chmod -R +w . # some zipfiles need that - - set +o pipefail # no idea why it's needed - toStrip=`find . -iname '*.pak' | head -n 1 | sed 's|\./\(.*\)/[^/]*$|\1|'` - echo "Detected path '$toStrip' to strip" - mv ./"$toStrip"/* . - rm -f "$toStrip/.directory" #pak128.german had this - rmdir -p "$toStrip" - ''; + installPhase = + let + src = fetchurl { inherit url sha256; }; + in + '' + mkdir -p "$out/share/simutrans/${pakName}" + cd "$out/share/simutrans/${pakName}" + "${unzip}/bin/unzip" "${src}" + chmod -R +w . # some zipfiles need that + + set +o pipefail # no idea why it's needed + toStrip=`find . -iname '*.pak' | head -n 1 | sed 's|\./\(.*\)/[^/]*$|\1|'` + echo "Detected path '$toStrip' to strip" + mv ./"$toStrip"/* . + rm -f "$toStrip/.directory" #pak128.german had this + rmdir -p "$toStrip" + ''; }; - /* The binaries need all data in one directory; the default is directory - of the executable, and another option is the current directory :-/ */ - withPaks = paks: buildEnv { - inherit (binaries) name; - paths = [binaries] ++ paks; - postBuild = '' - rm "$out/bin" && mkdir "$out/bin" - cat > "$out/bin/simutrans" < "$out/bin/simutrans" < config.default + '' + echo "${config}" > config.default - # Use ~/.simutrans instead of ~/simutrans - substituteInPlace simsys.cc --replace '%s/simutrans' '%s/.simutrans' + # Use ~/.simutrans instead of ~/simutrans + substituteInPlace simsys.cc --replace '%s/simutrans' '%s/.simutrans' - # use -O2 optimization (defaults are -O or -O3) - sed -i -e '/CFLAGS += -O/d' Makefile - export CFLAGS+=-O2 - ''; + # use -O2 optimization (defaults are -O or -O3) + sed -i -e '/CFLAGS += -O/d' Makefile + export CFLAGS+=-O2 + ''; enableParallelBuilding = true; @@ -163,10 +203,14 @@ let ''; homepage = "http://www.simutrans.com/"; - license = with lib.licenses; [ artistic1 gpl1Plus ]; + license = with lib.licenses; [ + artistic1 + gpl1Plus + ]; maintainers = [ ]; platforms = lib.platforms.linux; # TODO: ++ darwin; }; }; -in result +in +result diff --git a/pkgs/by-name/si/sing-box/package.nix b/pkgs/by-name/si/sing-box/package.nix index ea40096a5a215d..a8b8247d28aeff 100644 --- a/pkgs/by-name/si/sing-box/package.nix +++ b/pkgs/by-name/si/sing-box/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles -, buildPackages -, coreutils -, nix-update-script -, nixosTests +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, + buildPackages, + coreutils, + nix-update-script, + nixosTests, }: buildGoModule rec { @@ -44,24 +45,28 @@ buildGoModule rec { "-X=github.com/sagernet/sing-box/constant.Version=${version}" ]; - postInstall = let emulator = stdenv.hostPlatform.emulator buildPackages; in '' - installShellCompletion --cmd sing-box \ - --bash <(${emulator} $out/bin/sing-box completion bash) \ - --fish <(${emulator} $out/bin/sing-box completion fish) \ - --zsh <(${emulator} $out/bin/sing-box completion zsh ) + postInstall = + let + emulator = stdenv.hostPlatform.emulator buildPackages; + in + '' + installShellCompletion --cmd sing-box \ + --bash <(${emulator} $out/bin/sing-box completion bash) \ + --fish <(${emulator} $out/bin/sing-box completion fish) \ + --zsh <(${emulator} $out/bin/sing-box completion zsh ) - substituteInPlace release/config/sing-box{,@}.service \ - --replace-fail "/usr/bin/sing-box" "$out/bin/sing-box" \ - --replace-fail "/bin/kill" "${coreutils}/bin/kill" - install -Dm444 -t "$out/lib/systemd/system/" release/config/sing-box{,@}.service - ''; + substituteInPlace release/config/sing-box{,@}.service \ + --replace-fail "/usr/bin/sing-box" "$out/bin/sing-box" \ + --replace-fail "/bin/kill" "${coreutils}/bin/kill" + install -Dm444 -t "$out/lib/systemd/system/" release/config/sing-box{,@}.service + ''; passthru = { updateScript = nix-update-script { }; tests = { inherit (nixosTests) sing-box; }; }; - meta = with lib;{ + meta = with lib; { homepage = "https://sing-box.sagernet.org"; description = "Universal proxy platform"; license = licenses.gpl3Plus; diff --git a/pkgs/by-name/si/sing-geoip/package.nix b/pkgs/by-name/si/sing-geoip/package.nix index 2e128c6efe3626..8695ccf554479b 100644 --- a/pkgs/by-name/si/sing-geoip/package.nix +++ b/pkgs/by-name/si/sing-geoip/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, buildGoModule -, fetchFromGitHub -, dbip-country-lite +{ + lib, + stdenvNoCC, + buildGoModule, + fetchFromGitHub, + dbip-country-lite, }: let diff --git a/pkgs/by-name/si/sing-geosite/package.nix b/pkgs/by-name/si/sing-geosite/package.nix index 8540eb5340018f..cedbdf3cd49004 100644 --- a/pkgs/by-name/si/sing-geosite/package.nix +++ b/pkgs/by-name/si/sing-geosite/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, substituteAll -, v2ray-domain-list-community +{ + lib, + buildGoModule, + fetchFromGitHub, + substituteAll, + v2ray-domain-list-community, }: let diff --git a/pkgs/by-name/si/single-file-cli/package.nix b/pkgs/by-name/si/single-file-cli/package.nix index 0af72089592a18..541fd9bdd95cde 100644 --- a/pkgs/by-name/si/single-file-cli/package.nix +++ b/pkgs/by-name/si/single-file-cli/package.nix @@ -18,7 +18,7 @@ buildNpmPackage { }; npmDepsHash = "sha256-wiBpWw9nb/pWVGIc4Vl/IxxR5ic0LzLMMr3WxRNvYdM="; - nativeCheckInputs = [chromium]; + nativeCheckInputs = [ chromium ]; doCheck = stdenv.hostPlatform.isLinux; postBuild = '' @@ -48,7 +48,7 @@ buildNpmPackage { description = "CLI tool for saving a faithful copy of a complete web page in a single HTML file"; homepage = "https://github.com/gildas-lormeau/single-file-cli"; license = lib.licenses.agpl3Only; - maintainers = with lib.maintainers; [n8henrie]; + maintainers = with lib.maintainers; [ n8henrie ]; mainProgram = "single-file"; }; } diff --git a/pkgs/by-name/si/singular/package.nix b/pkgs/by-name/si/singular/package.nix index f26e1e8d1edd1b..47e6c2445191ae 100644 --- a/pkgs/by-name/si/singular/package.nix +++ b/pkgs/by-name/si/singular/package.nix @@ -1,22 +1,31 @@ -{ stdenv, fetchFromGitHub, gmp, bison, perl, ncurses, readline, coreutils, pkg-config -, lib -, autoreconfHook -, buildPackages -, sharutils -, file -, getconf -, flint3 -, ntl -, mpfr -, cddlib -, gfan -, lrcalc -, doxygen -, graphviz -, latex2html -, texinfo -, texliveSmall -, enableDocs ? true +{ + stdenv, + fetchFromGitHub, + gmp, + bison, + perl, + ncurses, + readline, + coreutils, + pkg-config, + lib, + autoreconfHook, + buildPackages, + sharutils, + file, + getconf, + flint3, + ntl, + mpfr, + cddlib, + gfan, + lrcalc, + doxygen, + graphviz, + latex2html, + texinfo, + texliveSmall, + enableDocs ? true, }: stdenv.mkDerivation rec { @@ -30,7 +39,7 @@ stdenv.mkDerivation rec { # if a release is tagged (which sometimes does not happen), it will # be in the format below. - rev = "Release-${lib.replaceStrings ["."] ["-"] version}"; + rev = "Release-${lib.replaceStrings [ "." ] [ "-" ] version}"; hash = "sha256-QxMMMnXaWe+0ogA6+3eOtdROb0RolSveya6DIx97/YY="; # the repository's .gitattributes file contains the lines "/Tst/ @@ -39,13 +48,15 @@ stdenv.mkDerivation rec { forceFetchGit = true; }; - configureFlags = [ - "--enable-gfanlib" - "--with-ntl=${ntl}" - "--with-flint=${flint3}" - ] ++ lib.optionals enableDocs [ - "--enable-doc-build" - ]; + configureFlags = + [ + "--enable-gfanlib" + "--with-ntl=${ntl}" + "--with-flint=${flint3}" + ] + ++ lib.optionals enableDocs [ + "--enable-doc-build" + ]; prePatch = '' # don't let the tests depend on `hostname` @@ -72,19 +83,22 @@ stdenv.mkDerivation rec { cddlib ]; - nativeBuildInputs = [ - bison - perl - pkg-config - autoreconfHook - sharutils # needed for regress.cmd install checks - ] ++ lib.optionals enableDocs [ - doxygen - graphviz - latex2html - texinfo - texliveSmall - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ getconf ]; + nativeBuildInputs = + [ + bison + perl + pkg-config + autoreconfHook + sharutils # needed for regress.cmd install checks + ] + ++ lib.optionals enableDocs [ + doxygen + graphviz + latex2html + texinfo + texliveSmall + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ getconf ]; depsBuildBuild = [ buildPackages.stdenv.cc ]; preAutoreconf = '' @@ -99,18 +113,21 @@ stdenv.mkDerivation rec { doCheck = true; # very basic checks, does not test any libraries - installPhase = '' - # clean up any artefacts a previous non-sandboxed docbuild may have left behind - rm /tmp/conic.log /tmp/conic.tex /tmp/tropicalcurve*.tex || true - make install - '' + lib.optionalString enableDocs '' - # Sage uses singular.info, which is not installed by default - mkdir -p $out/share/info - cp doc/singular.info $out/share/info - '' + '' - # Make sure patchelf picks up the right libraries - rm -rf libpolys factory resources omalloc Singular - ''; + installPhase = + '' + # clean up any artefacts a previous non-sandboxed docbuild may have left behind + rm /tmp/conic.log /tmp/conic.tex /tmp/tropicalcurve*.tex || true + make install + '' + + lib.optionalString enableDocs '' + # Sage uses singular.info, which is not installed by default + mkdir -p $out/share/info + cp doc/singular.info $out/share/info + '' + + '' + # Make sure patchelf picks up the right libraries + rm -rf libpolys factory resources omalloc Singular + ''; # singular tests are a bit complicated, see # https://github.com/Singular/Singular/tree/spielwiese/Tst diff --git a/pkgs/by-name/si/sink-rotate/package.nix b/pkgs/by-name/si/sink-rotate/package.nix index 1f684cb7960484..058289484f8553 100644 --- a/pkgs/by-name/si/sink-rotate/package.nix +++ b/pkgs/by-name/si/sink-rotate/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pipewire -, wireplumber -, makeWrapper +{ + lib, + rustPlatform, + fetchFromGitHub, + pipewire, + wireplumber, + makeWrapper, }: let version = "2.2.0"; @@ -38,4 +39,3 @@ rustPlatform.buildRustPackage { platforms = platforms.linux; }; } - diff --git a/pkgs/by-name/si/sioclient/package.nix b/pkgs/by-name/si/sioclient/package.nix index 55fc1495b2f309..fcf5a02ef7b389 100644 --- a/pkgs/by-name/si/sioclient/package.nix +++ b/pkgs/by-name/si/sioclient/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, asio -, rapidjson -, websocketpp +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + asio, + rapidjson, + websocketpp, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/si/sipcalc/package.nix b/pkgs/by-name/si/sipcalc/package.nix index 1ba4db5bc0d25c..3c17aabd32d8e3 100644 --- a/pkgs/by-name/si/sipcalc/package.nix +++ b/pkgs/by-name/si/sipcalc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "sipcalc"; diff --git a/pkgs/by-name/si/sipexer/package.nix b/pkgs/by-name/si/sipexer/package.nix index 98aaf67d80e692..47933243e0dcfb 100644 --- a/pkgs/by-name/si/sipexer/package.nix +++ b/pkgs/by-name/si/sipexer/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/si/sipp/package.nix b/pkgs/by-name/si/sipp/package.nix index ae5441edb25185..7ad501f87bdbe8 100644 --- a/pkgs/by-name/si/sipp/package.nix +++ b/pkgs/by-name/si/sipp/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, ncurses, libpcap, cmake, openssl, git, lksctp-tools }: +{ + lib, + stdenv, + fetchurl, + ncurses, + libpcap, + cmake, + openssl, + git, + lksctp-tools, +}: stdenv.mkDerivation rec { version = "3.6.1"; @@ -24,9 +34,15 @@ stdenv.mkDerivation rec { ]; enableParallelBuilding = true; - nativeBuildInputs = [ cmake git ]; - buildInputs = [ ncurses libpcap openssl ] - ++ lib.optional (stdenv.hostPlatform.isLinux) lksctp-tools; + nativeBuildInputs = [ + cmake + git + ]; + buildInputs = [ + ncurses + libpcap + openssl + ] ++ lib.optional (stdenv.hostPlatform.isLinux) lksctp-tools; meta = with lib; { homepage = "http://sipp.sf.net"; diff --git a/pkgs/by-name/si/siproxd/package.nix b/pkgs/by-name/si/siproxd/package.nix index 7c6319e450bda0..45e3ce71eee27c 100644 --- a/pkgs/by-name/si/siproxd/package.nix +++ b/pkgs/by-name/si/siproxd/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libosip, sqlite }: +{ + lib, + stdenv, + fetchurl, + libosip, + sqlite, +}: stdenv.mkDerivation rec { pname = "siproxd"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { patches = [ ./cheaders.patch ]; - buildInputs = [ libosip sqlite ]; + buildInputs = [ + libosip + sqlite + ]; meta = { homepage = "http://siproxd.sourceforge.net/"; diff --git a/pkgs/by-name/si/sipsak/package.nix b/pkgs/by-name/si/sipsak/package.nix index ba6325cd53f0d3..9302326748fc8c 100644 --- a/pkgs/by-name/si/sipsak/package.nix +++ b/pkgs/by-name/si/sipsak/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, c-ares, openssl ? null }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + c-ares, + openssl ? null, +}: stdenv.mkDerivation rec { pname = "sipsak"; @@ -33,4 +40,3 @@ stdenv.mkDerivation rec { }; } - diff --git a/pkgs/by-name/si/sipvicious/package.nix b/pkgs/by-name/si/sipvicious/package.nix index 8b0fa05cf0b511..29bb19b4d7e575 100644 --- a/pkgs/by-name/si/sipvicious/package.nix +++ b/pkgs/by-name/si/sipvicious/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, installShellFiles -, python3 +{ + lib, + fetchFromGitHub, + installShellFiles, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -16,11 +17,13 @@ python3.pkgs.buildPythonApplication rec { hash = "sha256-O8/9Vz/u8BoF1dfGceOJdzPPYLfkdBp2DkwA5WQ3dgo="; }; - build-system = [ - installShellFiles - ] ++ (with python3.pkgs; [ - setuptools - ]); + build-system = + [ + installShellFiles + ] + ++ (with python3.pkgs; [ + setuptools + ]); dependencies = with python3.pkgs; [ scapy diff --git a/pkgs/by-name/si/sipwitch/package.nix b/pkgs/by-name/si/sipwitch/package.nix index 0c11ffe8c1eea8..b79edcd0848ad7 100644 --- a/pkgs/by-name/si/sipwitch/package.nix +++ b/pkgs/by-name/si/sipwitch/package.nix @@ -1,4 +1,14 @@ -{ fetchurl, lib, stdenv, pkg-config, ucommon, libosip, libexosip, gnutls, zlib }: +{ + fetchurl, + lib, + stdenv, + pkg-config, + ucommon, + libosip, + libexosip, + gnutls, + zlib, +}: stdenv.mkDerivation rec { pname = "sipwitch"; @@ -10,7 +20,13 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ ucommon libosip libexosip gnutls zlib ]; + buildInputs = [ + ucommon + libosip + libexosip + gnutls + zlib + ]; preConfigure = '' export configureFlags="--sysconfdir=$out/etc" diff --git a/pkgs/by-name/si/sirikali/package.nix b/pkgs/by-name/si/sirikali/package.nix index 978d938f2b7e37..e122665acb4c63 100644 --- a/pkgs/by-name/si/sirikali/package.nix +++ b/pkgs/by-name/si/sirikali/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, libpwquality -, hicolor-icon-theme -, fetchFromGitHub -, cmake -, pkg-config -, qt6 -, kdePackages -, cryfs -, encfs -, fscrypt-experimental -, gocryptfs -, securefs -, sshfs -, libgcrypt -, libsecret -, withKWallet ? true -, withLibsecret ? true +{ + lib, + stdenv, + libpwquality, + hicolor-icon-theme, + fetchFromGitHub, + cmake, + pkg-config, + qt6, + kdePackages, + cryfs, + encfs, + fscrypt-experimental, + gocryptfs, + securefs, + sshfs, + libgcrypt, + libsecret, + withKWallet ? true, + withLibsecret ? true, }: stdenv.mkDerivation rec { @@ -30,15 +31,15 @@ stdenv.mkDerivation rec { hash = "sha256-UtgK+q06J6T6RJ8jQiwzg5yVtgGZaZzmfadNyXxTCIk="; }; - buildInputs = [ - qt6.qtbase - libpwquality - hicolor-icon-theme - libgcrypt - ] - ++ lib.optionals withKWallet [ kdePackages.kwallet ] - ++ lib.optionals withLibsecret [ libsecret ] - ; + buildInputs = + [ + qt6.qtbase + libpwquality + hicolor-icon-theme + libgcrypt + ] + ++ lib.optionals withKWallet [ kdePackages.kwallet ] + ++ lib.optionals withLibsecret [ libsecret ]; nativeBuildInputs = [ qt6.wrapQtAppsHook @@ -47,14 +48,16 @@ stdenv.mkDerivation rec { ]; qtWrapperArgs = [ - ''--prefix PATH : ${lib.makeBinPath [ - cryfs - encfs - fscrypt-experimental - gocryptfs - securefs - sshfs - ]}'' + ''--prefix PATH : ${ + lib.makeBinPath [ + cryfs + encfs + fscrypt-experimental + gocryptfs + securefs + sshfs + ] + }'' ]; doCheck = true; diff --git a/pkgs/by-name/si/siril/package.nix b/pkgs/by-name/si/siril/package.nix index 39f58adfc41d3a..7e4e3e11fca2dc 100644 --- a/pkgs/by-name/si/siril/package.nix +++ b/pkgs/by-name/si/siril/package.nix @@ -1,8 +1,33 @@ -{ lib, stdenv, fetchFromGitLab, pkg-config, meson, ninja, cmake -, git, criterion, gtk3, libconfig, gnuplot, opencv, json-glib -, fftwFloat, cfitsio, gsl, exiv2, librtprocess, wcslib, ffmpeg -, libraw, libtiff, libpng, libjpeg, libheif, ffms, wrapGAppsHook3 -, curl +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + meson, + ninja, + cmake, + git, + criterion, + gtk3, + libconfig, + gnuplot, + opencv, + json-glib, + fftwFloat, + cfitsio, + gsl, + exiv2, + librtprocess, + wcslib, + ffmpeg, + libraw, + libtiff, + libpng, + libjpeg, + libheif, + ffms, + wrapGAppsHook3, + curl, }: stdenv.mkDerivation rec { @@ -17,12 +42,34 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - meson ninja cmake pkg-config git criterion wrapGAppsHook3 + meson + ninja + cmake + pkg-config + git + criterion + wrapGAppsHook3 ]; buildInputs = [ - gtk3 cfitsio gsl exiv2 gnuplot opencv fftwFloat librtprocess wcslib - libconfig libraw libtiff libpng libjpeg libheif ffms ffmpeg json-glib + gtk3 + cfitsio + gsl + exiv2 + gnuplot + opencv + fftwFloat + librtprocess + wcslib + libconfig + libraw + libtiff + libpng + libjpeg + libheif + ffms + ffmpeg + json-glib curl ]; diff --git a/pkgs/by-name/si/sirius/package.nix b/pkgs/by-name/si/sirius/package.nix index 58c6e6a6dd2efd..9d1b48d4171cc6 100644 --- a/pkgs/by-name/si/sirius/package.nix +++ b/pkgs/by-name/si/sirius/package.nix @@ -1,41 +1,47 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, mpi -, mpiCheckPhaseHook -, gfortran -, blas -, lapack -, gsl -, libxc -, hdf5 -, spglib -, spfft -, spla -, costa -, umpire -, scalapack -, boost -, eigen -, libvdwxc -, enablePython ? false -, pythonPackages ? null -, llvmPackages -, cudaPackages -, rocmPackages -, config -, gpuBackend ? ( - if config.cudaSupport - then "cuda" - else if config.rocmSupport - then "rocm" - else "none" -) +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + mpi, + mpiCheckPhaseHook, + gfortran, + blas, + lapack, + gsl, + libxc, + hdf5, + spglib, + spfft, + spla, + costa, + umpire, + scalapack, + boost, + eigen, + libvdwxc, + enablePython ? false, + pythonPackages ? null, + llvmPackages, + cudaPackages, + rocmPackages, + config, + gpuBackend ? ( + if config.cudaSupport then + "cuda" + else if config.rocmSupport then + "rocm" + else + "none" + ), }: -assert builtins.elem gpuBackend [ "none" "cuda" "rocm" ]; +assert builtins.elem gpuBackend [ + "none" + "cuda" + "rocm" +]; assert enablePython -> pythonPackages != null; stdenv.mkDerivation rec { @@ -49,8 +55,10 @@ stdenv.mkDerivation rec { hash = "sha256-JvI75AbthNThXep2jcriLTPC8GGiPgrg5nYCCbCi+EI="; }; - - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake @@ -58,70 +66,86 @@ stdenv.mkDerivation rec { pkg-config ] ++ lib.optional (gpuBackend == "cuda") cudaPackages.cuda_nvcc; - buildInputs = [ - blas - lapack - gsl - libxc - hdf5 - umpire - mpi - spglib - spfft - spla - costa - scalapack - boost - eigen - libvdwxc - ] - ++ lib.optionals (gpuBackend == "cuda") [ - cudaPackages.cuda_cudart - cudaPackages.cuda_profiler_api - cudaPackages.cudatoolkit - cudaPackages.libcublas - ] ++ lib.optionals (gpuBackend == "rocm") [ - rocmPackages.clr - rocmPackages.rocblas - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - llvmPackages.openmp - ] ++ lib.optionals enablePython (with pythonPackages; [ - python - pybind11 - ]); - - propagatedBuildInputs = [ - (lib.getBin mpi) - ] ++ lib.optionals enablePython (with pythonPackages; [ - mpi4py - voluptuous - numpy - h5py - scipy - pyyaml - ]); + buildInputs = + [ + blas + lapack + gsl + libxc + hdf5 + umpire + mpi + spglib + spfft + spla + costa + scalapack + boost + eigen + libvdwxc + ] + ++ lib.optionals (gpuBackend == "cuda") [ + cudaPackages.cuda_cudart + cudaPackages.cuda_profiler_api + cudaPackages.cudatoolkit + cudaPackages.libcublas + ] + ++ lib.optionals (gpuBackend == "rocm") [ + rocmPackages.clr + rocmPackages.rocblas + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + llvmPackages.openmp + ] + ++ lib.optionals enablePython ( + with pythonPackages; + [ + python + pybind11 + ] + ); + + propagatedBuildInputs = + [ + (lib.getBin mpi) + ] + ++ lib.optionals enablePython ( + with pythonPackages; + [ + mpi4py + voluptuous + numpy + h5py + scipy + pyyaml + ] + ); CXXFLAGS = [ # GCC 13: error: 'uintptr_t' in namespace 'std' does not name a type "-include cstdint" ]; - cmakeFlags = [ - "-DSIRIUS_USE_SCALAPACK=ON" - "-DSIRIUS_USE_VDWXC=ON" - "-DSIRIUS_CREATE_FORTRAN_BINDINGS=ON" - "-DSIRIUS_USE_OPENMP=ON" - "-DBUILD_TESTING=ON" - ] ++ lib.optionals (gpuBackend == "cuda") [ - "-DSIRIUS_USE_CUDA=ON" - "-DCUDA_TOOLKIT_ROOT_DIR=${cudaPackages.cudatoolkit}" - (lib.cmakeFeature "CMAKE_CUDA_ARCHITECTURES" cudaPackages.flags.cmakeCudaArchitecturesString) - ] ++ lib.optionals (gpuBackend == "rocm") [ - "-DSIRIUS_USE_ROCM=ON" - "-DHIP_ROOT_DIR=${rocmPackages.clr}" - ] ++ lib.optionals enablePython [ - "-DSIRIUS_CREATE_PYTHON_MODULE=ON" - ]; + cmakeFlags = + [ + "-DSIRIUS_USE_SCALAPACK=ON" + "-DSIRIUS_USE_VDWXC=ON" + "-DSIRIUS_CREATE_FORTRAN_BINDINGS=ON" + "-DSIRIUS_USE_OPENMP=ON" + "-DBUILD_TESTING=ON" + ] + ++ lib.optionals (gpuBackend == "cuda") [ + "-DSIRIUS_USE_CUDA=ON" + "-DCUDA_TOOLKIT_ROOT_DIR=${cudaPackages.cudatoolkit}" + (lib.cmakeFeature "CMAKE_CUDA_ARCHITECTURES" cudaPackages.flags.cmakeCudaArchitecturesString) + ] + ++ lib.optionals (gpuBackend == "rocm") [ + "-DSIRIUS_USE_ROCM=ON" + "-DHIP_ROOT_DIR=${rocmPackages.clr}" + ] + ++ lib.optionals enablePython [ + "-DSIRIUS_CREATE_PYTHON_MODULE=ON" + ]; doCheck = true; diff --git a/pkgs/by-name/si/sirula/package.nix b/pkgs/by-name/si/sirula/package.nix index 27b7b55ba14fdd..0088cd00b1ba8a 100644 --- a/pkgs/by-name/si/sirula/package.nix +++ b/pkgs/by-name/si/sirula/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, gtk3 -, gtk-layer-shell +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + gtk3, + gtk-layer-shell, }: rustPlatform.buildRustPackage rec { @@ -26,7 +27,10 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk3 gtk-layer-shell ]; + buildInputs = [ + gtk3 + gtk-layer-shell + ]; meta = with lib; { description = "Simple app launcher for wayland written in rust"; diff --git a/pkgs/by-name/si/sish/package.nix b/pkgs/by-name/si/sish/package.nix index be17d6fe885bec..f42c32eb336c55 100644 --- a/pkgs/by-name/si/sish/package.nix +++ b/pkgs/by-name/si/sish/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, sish +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + sish, }: buildGoModule rec { diff --git a/pkgs/by-name/si/sispmctl/package.nix b/pkgs/by-name/si/sispmctl/package.nix index 7a09e9471d13bf..921850dfe86d7d 100644 --- a/pkgs/by-name/si/sispmctl/package.nix +++ b/pkgs/by-name/si/sispmctl/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, libusb-compat-0_1 +{ + lib, + stdenv, + fetchurl, + pkg-config, + libusb-compat-0_1, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/si/sitelen-seli-kiwen/package.nix b/pkgs/by-name/si/sitelen-seli-kiwen/package.nix index 363ce2da596117..5e773b75e9e90d 100644 --- a/pkgs/by-name/si/sitelen-seli-kiwen/package.nix +++ b/pkgs/by-name/si/sitelen-seli-kiwen/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { pname = "sitelen-seli-kiwen"; diff --git a/pkgs/by-name/si/sitespeed-io/package.nix b/pkgs/by-name/si/sitespeed-io/package.nix index e59fc2de97b4f3..886fe060694ddb 100644 --- a/pkgs/by-name/si/sitespeed-io/package.nix +++ b/pkgs/by-name/si/sitespeed-io/package.nix @@ -1,27 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildNpmPackage -, nodejs_18 -, coreutils -, ffmpeg-headless -, imagemagick_light -, procps -, python3 -, xorg -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + buildNpmPackage, + nodejs_18, + coreutils, + ffmpeg-headless, + imagemagick_light, + procps, + python3, + xorg, + nix-update-script, -# chromedriver is more efficient than geckodriver, but is available on less platforms. + # chromedriver is more efficient than geckodriver, but is available on less platforms. -, withChromium ? (lib.elem stdenv.hostPlatform.system chromedriver.meta.platforms) -, chromedriver -, chromium + withChromium ? (lib.elem stdenv.hostPlatform.system chromedriver.meta.platforms), + chromedriver, + chromium, -, withFirefox ? (lib.elem stdenv.hostPlatform.system geckodriver.meta.platforms) -, geckodriver -, firefox + withFirefox ? (lib.elem stdenv.hostPlatform.system geckodriver.meta.platforms), + geckodriver, + firefox, }: -assert (!withFirefox && !withChromium) -> throw "Either `withFirefox` or `withChromium` must be enabled."; +assert + (!withFirefox && !withChromium) -> throw "Either `withFirefox` or `withChromium` must be enabled."; buildNpmPackage rec { pname = "sitespeed-io"; version = "34.0.1"; @@ -68,14 +70,20 @@ buildNpmPackage rec { in '' wrapProgram $out/bin/sitespeed-io \ - --set PATH ${lib.makeBinPath ([ - (python3.withPackages (p: [p.numpy p.opencv4 p.pyssim])) - ffmpeg-headless - imagemagick_light - xorg.xorgserver - procps - coreutils - ])} \ + --set PATH ${ + lib.makeBinPath ([ + (python3.withPackages (p: [ + p.numpy + p.opencv4 + p.pyssim + ])) + ffmpeg-headless + imagemagick_light + xorg.xorgserver + procps + coreutils + ]) + } \ ${lib.optionalString withChromium "--add-flags '${chromiumArgs}'"} \ ${lib.optionalString withFirefox "--add-flags '${firefoxArgs}'"} \ ${lib.optionalString (!withFirefox && withChromium) "--add-flags '-b chrome'"} \ diff --git a/pkgs/by-name/si/sixpair/package.nix b/pkgs/by-name/si/sixpair/package.nix index 92f7e81c0ccd14..aae35dca39438b 100644 --- a/pkgs/by-name/si/sixpair/package.nix +++ b/pkgs/by-name/si/sixpair/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libusb-compat-0_1 }: +{ + lib, + stdenv, + fetchurl, + libusb-compat-0_1, +}: stdenv.mkDerivation { pname = "sixpair"; version = "unstable-2007-04-18"; diff --git a/pkgs/by-name/sj/sjasmplus/package.nix b/pkgs/by-name/sj/sjasmplus/package.nix index b9c6a4b171ea28..51ef3793cc03ff 100644 --- a/pkgs/by-name/sj/sjasmplus/package.nix +++ b/pkgs/by-name/sj/sjasmplus/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "sjasmplus"; diff --git a/pkgs/by-name/sk/skaffold/package.nix b/pkgs/by-name/sk/skaffold/package.nix index 4303257d4b5b0f..5bcb0a583a89aa 100644 --- a/pkgs/by-name/sk/skaffold/package.nix +++ b/pkgs/by-name/sk/skaffold/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, makeWrapper }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + makeWrapper, +}: buildGoModule rec { pname = "skaffold"; @@ -13,16 +19,24 @@ buildGoModule rec { vendorHash = null; - subPackages = ["cmd/skaffold"]; + subPackages = [ "cmd/skaffold" ]; - ldflags = let t = "github.com/GoogleContainerTools/skaffold/v2/pkg/skaffold"; in [ - "-s" "-w" - "-X ${t}/version.version=v${version}" - "-X ${t}/version.gitCommit=${src.rev}" - "-X ${t}/version.buildDate=unknown" - ]; + ldflags = + let + t = "github.com/GoogleContainerTools/skaffold/v2/pkg/skaffold"; + in + [ + "-s" + "-w" + "-X ${t}/version.version=v${version}" + "-X ${t}/version.gitCommit=${src.rev}" + "-X ${t}/version.buildDate=unknown" + ]; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; doInstallCheck = true; installCheckPhase = '' @@ -49,6 +63,9 @@ buildGoModule rec { It also provides building blocks and describe customizations for a CI/CD pipeline. ''; license = licenses.asl20; - maintainers = with maintainers; [ vdemeester bryanasdev000]; + maintainers = with maintainers; [ + vdemeester + bryanasdev000 + ]; }; } diff --git a/pkgs/by-name/sk/skate/package.nix b/pkgs/by-name/sk/skate/package.nix index af420e27e21a98..0c61df5a1b0adc 100644 --- a/pkgs/by-name/sk/skate/package.nix +++ b/pkgs/by-name/sk/skate/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "skate"; @@ -14,14 +18,21 @@ buildGoModule rec { proxyVendor = true; vendorHash = "sha256-nCT9PsRPxefjC4q4cr5UigTITUkx0JmQtdv7/ZXbXVI="; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; meta = with lib; { description = "Personal multi-machine syncable key value store"; homepage = "https://github.com/charmbracelet/skate"; changelog = "https://github.com/charmbracelet/skate/releases/tag/${src.rev}"; license = licenses.mit; - maintainers = with maintainers; [ figsoda penguwin ]; + maintainers = with maintainers; [ + figsoda + penguwin + ]; mainProgram = "skate"; }; } diff --git a/pkgs/by-name/sk/skeu/package.nix b/pkgs/by-name/sk/skeu/package.nix index d8b0c1896572d0..6790521ca97175 100644 --- a/pkgs/by-name/sk/skeu/package.nix +++ b/pkgs/by-name/sk/skeu/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitHub -, gdk-pixbuf -, gtk-engine-murrine -, gtk_engines -, librsvg +{ + lib, + stdenv, + fetchFromGitHub, + gdk-pixbuf, + gtk-engine-murrine, + gtk_engines, + librsvg, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sk/skimpdf/package.nix b/pkgs/by-name/sk/skimpdf/package.nix index da7f2da2d6fe1b..07167de4d48b23 100644 --- a/pkgs/by-name/sk/skimpdf/package.nix +++ b/pkgs/by-name/sk/skimpdf/package.nix @@ -14,7 +14,7 @@ stdenv.mkDerivation rec { hash = "sha256-AMHEzlipL0Bv68Gnyq040t4DQhPkQcmDixZ6Oo0Vobc="; }; - nativeBuildInputs = [undmg]; + nativeBuildInputs = [ undmg ]; sourceRoot = "."; @@ -29,9 +29,9 @@ stdenv.mkDerivation rec { description = "Skim is a PDF reader and note-taker for OS X"; homepage = "https://skim-app.sourceforge.io/"; license = licenses.bsd0; - sourceProvenance = with sourceTypes; [binaryNativeCode]; + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; mainProgram = "Skim.app"; - maintainers = with maintainers; [YvesStraten]; + maintainers = with maintainers; [ YvesStraten ]; platforms = platforms.darwin; }; } diff --git a/pkgs/by-name/sk/skjold/package.nix b/pkgs/by-name/sk/skjold/package.nix index bbd5f57a778d08..694052b7dcbb92 100644 --- a/pkgs/by-name/sk/skjold/package.nix +++ b/pkgs/by-name/sk/skjold/package.nix @@ -20,7 +20,6 @@ python3.pkgs.buildPythonApplication rec { build-system = with python3.pkgs; [ poetry-core ]; - dependencies = with python3.pkgs; [ click packaging diff --git a/pkgs/by-name/sk/skktools/package.nix b/pkgs/by-name/sk/skktools/package.nix index 537c77a1394e5c..7fb5f1992a84b9 100644 --- a/pkgs/by-name/sk/skktools/package.nix +++ b/pkgs/by-name/sk/skktools/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, gdbm, glib }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + gdbm, + glib, +}: # Note (2017-10-24, yuriaisaka): # - Version 1.3.3 dates from Jul. 19, 2013. @@ -14,7 +21,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "skk-dev"; repo = "skktools"; - rev = "skktools-${lib.replaceStrings ["."] ["_"] version}"; + rev = "skktools-${lib.replaceStrings [ "." ] [ "_" ] version}"; sha256 = "1zway8jsm18279xq8zlpr84iqiw373x3v0ysay74n9bjqxbl234a"; }; # # See "12.2. Package naming" @@ -28,7 +35,10 @@ stdenv.mkDerivation rec { # }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gdbm glib ]; + buildInputs = [ + gdbm + glib + ]; meta = { description = "Collection of tools to edit SKK dictionaries"; diff --git a/pkgs/by-name/sk/skopeo/package.nix b/pkgs/by-name/sk/skopeo/package.nix index 953b4338f2cacb..977909cff72f43 100644 --- a/pkgs/by-name/sk/skopeo/package.nix +++ b/pkgs/by-name/sk/skopeo/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, gpgme -, lvm2 -, btrfs-progs -, pkg-config -, go-md2man -, installShellFiles -, makeWrapper -, fuse-overlayfs -, dockerTools -, runCommand -, testers -, skopeo +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + gpgme, + lvm2, + btrfs-progs, + pkg-config, + go-md2man, + installShellFiles, + makeWrapper, + fuse-overlayfs, + dockerTools, + runCommand, + testers, + skopeo, }: buildGoModule rec { @@ -27,16 +28,28 @@ buildGoModule rec { hash = "sha256-IoYeCGiGOjz+8HPzYPXUWsHADtrWHvJm9YhKeMJJf0k="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; vendorHash = null; doCheck = false; - nativeBuildInputs = [ pkg-config go-md2man installShellFiles makeWrapper ]; + nativeBuildInputs = [ + pkg-config + go-md2man + installShellFiles + makeWrapper + ]; - buildInputs = [ gpgme ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ lvm2 btrfs-progs ]; + buildInputs = + [ gpgme ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + lvm2 + btrfs-progs + ]; buildPhase = '' runHook preBuild @@ -45,16 +58,19 @@ buildGoModule rec { runHook postBuild ''; - installPhase = '' - runHook preInstall - PREFIX=${placeholder "out"} make install-binary install-completions install-docs - install ${passthru.policy}/default-policy.json -Dt $out/etc/containers - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - wrapProgram $out/bin/skopeo \ - --prefix PATH : ${lib.makeBinPath [ fuse-overlayfs ]} - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + PREFIX=${placeholder "out"} make install-binary install-completions install-docs + install ${passthru.policy}/default-policy.json -Dt $out/etc/containers + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + wrapProgram $out/bin/skopeo \ + --prefix PATH : ${lib.makeBinPath [ fuse-overlayfs ]} + '' + + '' + runHook postInstall + ''; passthru = { policy = runCommand "policy" { } '' @@ -73,7 +89,13 @@ buildGoModule rec { description = "Command line utility for various operations on container images and image repositories"; mainProgram = "skopeo"; homepage = "https://github.com/containers/skopeo"; - maintainers = with maintainers; [ lewo developer-guy ] ++ teams.podman.members; + maintainers = + with maintainers; + [ + lewo + developer-guy + ] + ++ teams.podman.members; license = licenses.asl20; }; } diff --git a/pkgs/by-name/sk/skribilo/package.nix b/pkgs/by-name/sk/skribilo/package.nix index 63083457bee513..51544741ad158d 100644 --- a/pkgs/by-name/sk/skribilo/package.nix +++ b/pkgs/by-name/sk/skribilo/package.nix @@ -1,24 +1,30 @@ -{ lib -, stdenv -, fetchurl -, fig2dev -, gettext -, ghostscript -, guile -, guile-lib -, guile-reader -, imagemagick -, makeWrapper -, pkg-config -, enableEmacs ? false, emacs -, enableLout ? stdenv.hostPlatform.isLinux, lout -, enablePloticus ? stdenv.hostPlatform.isLinux, ploticus -, enableTex ? true, texliveSmall +{ + lib, + stdenv, + fetchurl, + fig2dev, + gettext, + ghostscript, + guile, + guile-lib, + guile-reader, + imagemagick, + makeWrapper, + pkg-config, + enableEmacs ? false, + emacs, + enableLout ? stdenv.hostPlatform.isLinux, + lout, + enablePloticus ? stdenv.hostPlatform.isLinux, + ploticus, + enableTex ? true, + texliveSmall, }: let inherit (lib) optional; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "skribilo"; version = "0.10.0"; @@ -32,19 +38,20 @@ in stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - fig2dev - gettext - ghostscript - guile - guile-lib - guile-reader - imagemagick - ] - ++ optional enableEmacs emacs - ++ optional enableLout lout - ++ optional enablePloticus ploticus - ++ optional enableTex texliveSmall; + buildInputs = + [ + fig2dev + gettext + ghostscript + guile + guile-lib + guile-reader + imagemagick + ] + ++ optional enableEmacs emacs + ++ optional enableLout lout + ++ optional enablePloticus ploticus + ++ optional enableTex texliveSmall; postInstall = '' wrapProgram $out/bin/skribilo \ diff --git a/pkgs/by-name/sk/skydns/package.nix b/pkgs/by-name/sk/skydns/package.nix index 27581d18546367..c247c27ffa8e66 100644 --- a/pkgs/by-name/sk/skydns/package.nix +++ b/pkgs/by-name/sk/skydns/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "skydns"; @@ -23,7 +29,10 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = { description = "Distributed service for announcement and discovery of services"; diff --git a/pkgs/by-name/sk/skypeexport/package.nix b/pkgs/by-name/sk/skypeexport/package.nix index 028f70d2f19e4e..430d45c731c6c3 100644 --- a/pkgs/by-name/sk/skypeexport/package.nix +++ b/pkgs/by-name/sk/skypeexport/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, boost }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + boost, +}: stdenv.mkDerivation (finalAttrs: { pname = "skypeexport"; diff --git a/pkgs/by-name/sk/skytemple/package.nix b/pkgs/by-name/sk/skytemple/package.nix index daf10d19c5298a..b9832bc93a3c0f 100644 --- a/pkgs/by-name/sk/skytemple/package.nix +++ b/pkgs/by-name/sk/skytemple/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, gobject-introspection -, gtk3 -, gtksourceview4 -, webkitgtk_4_0 -, wrapGAppsHook3 -, python3Packages +{ + lib, + fetchFromGitHub, + gobject-introspection, + gtk3, + gtksourceview4, + webkitgtk_4_0, + wrapGAppsHook3, + python3Packages, }: python3Packages.buildPythonApplication rec { @@ -36,25 +37,28 @@ python3Packages.buildPythonApplication rec { wrapGAppsHook3 ]; - dependencies = with python3Packages; [ - cairosvg - natsort - ndspy - packaging - pycairo - pygal - psutil - pypresence - sentry-sdk - setuptools - skytemple-dtef - skytemple-eventserver - skytemple-files - skytemple-icons - skytemple-ssb-debugger - tilequant - wheel - ] ++ skytemple-files.optional-dependencies.spritecollab; + dependencies = + with python3Packages; + [ + cairosvg + natsort + ndspy + packaging + pycairo + pygal + psutil + pypresence + sentry-sdk + setuptools + skytemple-dtef + skytemple-eventserver + skytemple-files + skytemple-icons + skytemple-ssb-debugger + tilequant + wheel + ] + ++ skytemple-files.optional-dependencies.spritecollab; doCheck = false; # there are no tests diff --git a/pkgs/by-name/sl/sl/package.nix b/pkgs/by-name/sl/sl/package.nix index bcb8de78c61300..a4b14dab2db37c 100644 --- a/pkgs/by-name/sl/sl/package.nix +++ b/pkgs/by-name/sl/sl/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { pname = "sl"; diff --git a/pkgs/by-name/sl/slack-cli/package.nix b/pkgs/by-name/sl/slack-cli/package.nix index 56248107115e03..49e1543e1a25a8 100644 --- a/pkgs/by-name/sl/slack-cli/package.nix +++ b/pkgs/by-name/sl/slack-cli/package.nix @@ -5,8 +5,17 @@ # for token storage, except that it would make the Nix package inconsistent with # upstream and other distributions. -{ stdenv, lib, fetchFromGitHub, curl, jq, coreutils, gnugrep, gnused -, runtimeShell }: +{ + stdenv, + lib, + fetchFromGitHub, + curl, + jq, + coreutils, + gnugrep, + gnused, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "slack-cli"; @@ -34,7 +43,15 @@ stdenv.mkDerivation rec { MESSAGE - export PATH=${lib.makeBinPath [ curl jq coreutils gnugrep gnused ]}:"\$PATH" + export PATH=${ + lib.makeBinPath [ + curl + jq + coreutils + gnugrep + gnused + ] + }:"\$PATH" exec "$out/bin/.slack-wrapped" "\$@" WRAPPER diff --git a/pkgs/by-name/sl/slack-term/package.nix b/pkgs/by-name/sl/slack-term/package.nix index a7c302dbd4b62d..8d2e09808bea78 100644 --- a/pkgs/by-name/sl/slack-term/package.nix +++ b/pkgs/by-name/sl/slack-term/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "slack-term"; diff --git a/pkgs/by-name/sl/slang/package.nix b/pkgs/by-name/sl/slang/package.nix index 7d67d22eb3e0d9..f6a921a494bcdd 100644 --- a/pkgs/by-name/sl/slang/package.nix +++ b/pkgs/by-name/sl/slang/package.nix @@ -1,11 +1,14 @@ -{ lib, stdenv, fetchurl -, libiconv -, libpng -, ncurses -, pcre -, readline -, zlib -, writeScript +{ + lib, + stdenv, + fetchurl, + libiconv, + libpng, + ncurses, + pcre, + readline, + zlib, + writeScript, }: stdenv.mkDerivation rec { @@ -17,7 +20,12 @@ stdenv.mkDerivation rec { sha256 = "sha256-+RRQVK4TGXPGEgjqgkhtXdEOPFza0jt8SgYXdDyPWhg="; }; - outputs = [ "out" "dev" "man" "doc" ]; + outputs = [ + "out" + "dev" + "man" + "doc" + ]; # Fix some wrong hardcoded paths preConfigure = '' diff --git a/pkgs/by-name/sl/sleek-grub-theme/package.nix b/pkgs/by-name/sl/sleek-grub-theme/package.nix index 0fe50fcd417514..f9814c485842ac 100644 --- a/pkgs/by-name/sl/sleek-grub-theme/package.nix +++ b/pkgs/by-name/sl/sleek-grub-theme/package.nix @@ -1,11 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, withBanner ? "Grub Bootloader" # use override to specify your own banner text -, withStyle ? "light" # use override to specify one of "dark" / "orange" / "bigSur" +{ + lib, + stdenv, + fetchFromGitHub, + withBanner ? "Grub Bootloader", # use override to specify your own banner text + withStyle ? "light", # use override to specify one of "dark" / "orange" / "bigSur" }: -assert builtins.any (s: withStyle == s) ["light" "dark" "orange" "bigSur"]; +assert builtins.any (s: withStyle == s) [ + "light" + "dark" + "orange" + "bigSur" +]; stdenv.mkDerivation { pname = "sleek-grub-theme"; diff --git a/pkgs/by-name/sl/sleek/package.nix b/pkgs/by-name/sl/sleek/package.nix index 0218917a2caa9b..d7d959ec1b7daf 100644 --- a/pkgs/by-name/sl/sleek/package.nix +++ b/pkgs/by-name/sl/sleek/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sl/sleep-on-lan/package.nix b/pkgs/by-name/sl/sleep-on-lan/package.nix index bd55711830bc24..b9f655d04633c8 100644 --- a/pkgs/by-name/sl/sleep-on-lan/package.nix +++ b/pkgs/by-name/sl/sleep-on-lan/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/sl/sleuthkit/package.nix b/pkgs/by-name/sl/sleuthkit/package.nix index 53d148a53028cf..dcd2912250d774 100644 --- a/pkgs/by-name/sl/sleuthkit/package.nix +++ b/pkgs/by-name/sl/sleuthkit/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, ant -, jdk -, perl -, stripJavaArchivesHook -, afflib -, libewf -, openssl -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + ant, + jdk, + perl, + stripJavaArchivesHook, + afflib, + libewf, + openssl, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -28,7 +29,10 @@ stdenv.mkDerivation (finalAttrs: { name = "sleuthkit-${finalAttrs.version}-deps"; inherit (finalAttrs) src; - nativeBuildInputs = [ ant jdk ]; + nativeBuildInputs = [ + ant + jdk + ]; # unpack, build, install dontConfigure = true; @@ -101,7 +105,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Forensic/data recovery tool"; homepage = "https://www.sleuthkit.org/"; changelog = "https://github.com/sleuthkit/sleuthkit/blob/${finalAttrs.src.rev}/NEWS.txt"; - maintainers = with maintainers; [ raskin gfrascadorio ]; + maintainers = with maintainers; [ + raskin + gfrascadorio + ]; platforms = platforms.linux; sourceProvenance = with sourceTypes; [ fromSource diff --git a/pkgs/by-name/sl/slic3r/package.nix b/pkgs/by-name/sl/slic3r/package.nix index 102dc8f4b3c8dd..1790d103d986a1 100644 --- a/pkgs/by-name/sl/slic3r/package.nix +++ b/pkgs/by-name/sl/slic3r/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, perl, makeWrapper -, makeDesktopItem, which, perlPackages, boost, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + perl, + makeWrapper, + makeDesktopItem, + which, + perlPackages, + boost, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -13,17 +23,40 @@ stdenv.mkDerivation rec { sha256 = "sha256-cf0QTOzhLyTcbJryCQoTVzU8kfrPV6SLpqi4s36X5N0="; }; - nativeBuildInputs = [ makeWrapper which wrapGAppsHook3 ]; + nativeBuildInputs = [ + makeWrapper + which + wrapGAppsHook3 + ]; buildInputs = - [boost] ++ - (with perlPackages; [ perl - EncodeLocale MathClipper ExtUtilsXSpp - MathConvexHullMonotoneChain MathGeometryVoronoi MathPlanePath Moo - IOStringy ClassXSAccessor Wx GrowlGNTP NetDBus ImportInto XMLSAX - ExtUtilsMakeMaker OpenGL WxGLCanvas ModuleBuild LWP - ExtUtilsCppGuess ModuleBuildWithXSpp ExtUtilsTypemapsDefault - DevelChecklib locallib - ]); + [ boost ] + ++ (with perlPackages; [ + perl + EncodeLocale + MathClipper + ExtUtilsXSpp + MathConvexHullMonotoneChain + MathGeometryVoronoi + MathPlanePath + Moo + IOStringy + ClassXSAccessor + Wx + GrowlGNTP + NetDBus + ImportInto + XMLSAX + ExtUtilsMakeMaker + OpenGL + WxGLCanvas + ModuleBuild + LWP + ExtUtilsCppGuess + ModuleBuildWithXSpp + ExtUtilsTypemapsDefault + DevelChecklib + locallib + ]); desktopItem = makeDesktopItem { name = "slic3r"; diff --git a/pkgs/by-name/sl/slides/package.nix b/pkgs/by-name/sl/slides/package.nix index 0c97ff7f14fa93..59076db89ef2ba 100644 --- a/pkgs/by-name/sl/slides/package.nix +++ b/pkgs/by-name/sl/slides/package.nix @@ -1,8 +1,9 @@ -{ lib -, bash -, buildGoModule -, fetchFromGitHub -, go +{ + lib, + bash, + buildGoModule, + fetchFromGitHub, + go, }: buildGoModule rec { @@ -34,7 +35,10 @@ buildGoModule rec { homepage = "https://github.com/maaslalani/slides"; changelog = "https://github.com/maaslalani/slides/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ maaslalani penguwin ]; + maintainers = with maintainers; [ + maaslalani + penguwin + ]; mainProgram = "slides"; }; } diff --git a/pkgs/by-name/sl/slimerjs/package.nix b/pkgs/by-name/sl/slimerjs/package.nix index dd3c5fd6d09b53..09bb4dae87db12 100644 --- a/pkgs/by-name/sl/slimerjs/package.nix +++ b/pkgs/by-name/sl/slimerjs/package.nix @@ -1,11 +1,12 @@ -{ lib -, bash -, fetchFromGitHub -, firefox -, strip-nondeterminism -, stdenv -, unzip -, zip +{ + lib, + bash, + fetchFromGitHub, + firefox, + strip-nondeterminism, + stdenv, + unzip, + zip, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sl/slingshot/package.nix b/pkgs/by-name/sl/slingshot/package.nix index 1cf9fe854c3d2d..b2a18dda5297ec 100644 --- a/pkgs/by-name/sl/slingshot/package.nix +++ b/pkgs/by-name/sl/slingshot/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sl/slint-lsp/package.nix b/pkgs/by-name/sl/slint-lsp/package.nix index a65350cac598a5..50a47c9be9b069 100644 --- a/pkgs/by-name/sl/slint-lsp/package.nix +++ b/pkgs/by-name/sl/slint-lsp/package.nix @@ -1,27 +1,39 @@ -{ lib -, stdenv -, rustPlatform -, fetchCrate -, pkg-config -, cmake -, fontconfig -, libGL -, xorg -, libxkbcommon -, wayland +{ + lib, + stdenv, + rustPlatform, + fetchCrate, + pkg-config, + cmake, + fontconfig, + libGL, + xorg, + libxkbcommon, + wayland, # Darwin Frameworks -, AppKit -, CoreGraphics -, CoreServices -, CoreText -, Foundation -, libiconv -, OpenGL + AppKit, + CoreGraphics, + CoreServices, + CoreText, + Foundation, + libiconv, + OpenGL, }: let - rpathLibs = [ fontconfig libGL xorg.libxcb xorg.libX11 xorg.libXcursor xorg.libXi ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libxkbcommon wayland ]; + rpathLibs = + [ + fontconfig + libGL + xorg.libxcb + xorg.libX11 + xorg.libXcursor + xorg.libXi + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libxkbcommon + wayland + ]; in rustPlatform.buildRustPackage rec { pname = "slint-lsp"; @@ -34,22 +46,28 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-wyzrFg3hwsJ7SV8KGLKo+gNHzLFpnMx9/jgMalGkufY="; - nativeBuildInputs = [ cmake pkg-config fontconfig ]; - buildInputs = rpathLibs ++ [ xorg.libxcb.dev ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - CoreGraphics - CoreServices - CoreText - Foundation - libiconv - OpenGL + nativeBuildInputs = [ + cmake + pkg-config + fontconfig ]; + buildInputs = + rpathLibs + ++ [ xorg.libxcb.dev ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + CoreGraphics + CoreServices + CoreText + Foundation + libiconv + OpenGL + ]; # Tests requires `i_slint_backend_testing` which is only a dev dependency doCheck = false; - postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' + postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' patchelf --set-rpath ${lib.makeLibraryPath rpathLibs} $out/bin/slint-lsp ''; diff --git a/pkgs/by-name/sl/slippy/package.nix b/pkgs/by-name/sl/slippy/package.nix index a7e6a75a7a7eaf..29ac95bfb9c806 100644 --- a/pkgs/by-name/sl/slippy/package.nix +++ b/pkgs/by-name/sl/slippy/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, jq -, moreutils -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + jq, + moreutils, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -47,17 +48,22 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; meta = with lib; { description = "Markdown slideshows in Rust"; homepage = "https://github.com/axodotdev/slippy"; changelog = "https://github.com/axodotdev/slippy/releases/tag/${src.rev}"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "slippy"; }; diff --git a/pkgs/by-name/sl/slirp4netns/package.nix b/pkgs/by-name/sl/slirp4netns/package.nix index ef7dae065e3865..f44dd73b4515d6 100644 --- a/pkgs/by-name/sl/slirp4netns/package.nix +++ b/pkgs/by-name/sl/slirp4netns/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, glib -, libcap -, libseccomp -, libslirp -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + glib, + libcap, + libseccomp, + libslirp, + nixosTests, }: stdenv.mkDerivation rec { @@ -21,9 +22,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-dXz5gNALrVjaFGUgEFp0k47c7aWDzwLMflphe6R6GaM="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ glib libcap libseccomp libslirp ]; + buildInputs = [ + glib + libcap + libseccomp + libslirp + ]; enableParallelBuilding = true; strictDeps = true; diff --git a/pkgs/by-name/sl/sloccount/package.nix b/pkgs/by-name/sl/sloccount/package.nix index fc619612a48bb6..0761d0d502278c 100644 --- a/pkgs/by-name/sl/sloccount/package.nix +++ b/pkgs/by-name/sl/sloccount/package.nix @@ -1,4 +1,10 @@ -{ fetchurl, lib, stdenv, perl, makeWrapper }: +{ + fetchurl, + lib, + stdenv, + perl, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "sloccount"; @@ -31,7 +37,10 @@ stdenv.mkDerivation rec { done ''; - makeFlags = [ "PREFIX=$(out)" "CC=${stdenv.cc.targetPrefix}cc" ]; + makeFlags = [ + "PREFIX=$(out)" + "CC=${stdenv.cc.targetPrefix}cc" + ]; doCheck = true; checkPhase = ''HOME="$TMPDIR" PATH="$PWD:$PATH" make test''; @@ -47,7 +56,7 @@ stdenv.mkDerivation rec { isScript "$w" || continue wrapProgram "$w" --prefix PATH : "$out/bin" done - ''; + ''; meta = { description = "Set of tools for counting physical Source Lines of Code (SLOC)"; diff --git a/pkgs/by-name/sl/slop/package.nix b/pkgs/by-name/sl/slop/package.nix index f993d259433826..3233dfe822bf1e 100644 --- a/pkgs/by-name/sl/slop/package.nix +++ b/pkgs/by-name/sl/slop/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, glew -, glm -, libGLU -, libGL -, libX11 -, libXext -, libXrender -, icu -, libSM +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + glew, + glm, + libGLU, + libGL, + libX11, + libXext, + libXrender, + icu, + libSM, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sl/sloth-app/package.nix b/pkgs/by-name/sl/sloth-app/package.nix index 1da8d8aac54d5e..1b9a2bbb8934c8 100644 --- a/pkgs/by-name/sl/sloth-app/package.nix +++ b/pkgs/by-name/sl/sloth-app/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, unzip -, makeBinaryWrapper +{ + lib, + stdenv, + fetchurl, + unzip, + makeBinaryWrapper, }: stdenv.mkDerivation (finalAttrs: { @@ -16,7 +17,10 @@ stdenv.mkDerivation (finalAttrs: { dontUnpack = true; - nativeBuildInputs = [ unzip makeBinaryWrapper ]; + nativeBuildInputs = [ + unzip + makeBinaryWrapper + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/sl/sloth/package.nix b/pkgs/by-name/sl/sloth/package.nix index 2386b5a54a86ef..8258994e546fe1 100644 --- a/pkgs/by-name/sl/sloth/package.nix +++ b/pkgs/by-name/sl/sloth/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/sl/slowhttptest/package.nix b/pkgs/by-name/sl/slowhttptest/package.nix index 94e60a6a008450..1bb1d18a96788a 100644 --- a/pkgs/by-name/sl/slowhttptest/package.nix +++ b/pkgs/by-name/sl/slowhttptest/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + openssl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sl/slrn/package.nix b/pkgs/by-name/sl/slrn/package.nix index 9819f2a9ceb4c5..78de45eb990495 100644 --- a/pkgs/by-name/sl/slrn/package.nix +++ b/pkgs/by-name/sl/slrn/package.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchurl -, slang, ncurses, openssl }: +{ + lib, + stdenv, + fetchurl, + slang, + ncurses, + openssl, +}: stdenv.mkDerivation rec { pname = "slrn"; @@ -23,7 +29,11 @@ stdenv.mkDerivation rec { "--with-slrnpull" ]; - buildInputs = [ slang ncurses openssl ]; + buildInputs = [ + slang + ncurses + openssl + ]; meta = with lib; { description = "Slrn (S-Lang read news) newsreader"; diff --git a/pkgs/by-name/sl/slsnif/package.nix b/pkgs/by-name/sl/slsnif/package.nix index 7ac1a846484f56..579cd311b80397 100644 --- a/pkgs/by-name/sl/slsnif/package.nix +++ b/pkgs/by-name/sl/slsnif/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "slsnif"; diff --git a/pkgs/by-name/sl/slurm-nm/package.nix b/pkgs/by-name/sl/slurm-nm/package.nix index 27112a55ad0ace..cee4e5ee8f75b7 100644 --- a/pkgs/by-name/sl/slurm-nm/package.nix +++ b/pkgs/by-name/sl/slurm-nm/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, meson -, ncurses -, ninja +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + meson, + ncurses, + ninja, }: stdenv.mkDerivation rec { @@ -18,7 +19,11 @@ stdenv.mkDerivation rec { hash = "sha256-w77SIXFctMwwNw9cQm0HQaEaMs/5NXQjn1LpvkpCCB8="; }; - nativeBuildInputs = [ pkg-config meson ninja ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + ]; buildInputs = [ ncurses ]; meta = with lib; { diff --git a/pkgs/by-name/sl/slurm-spank-stunnel/package.nix b/pkgs/by-name/sl/slurm-spank-stunnel/package.nix index 3534c8981a2699..0dc9c42d4b8c0a 100644 --- a/pkgs/by-name/sl/slurm-spank-stunnel/package.nix +++ b/pkgs/by-name/sl/slurm-spank-stunnel/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, slurm } : +{ + lib, + stdenv, + fetchFromGitHub, + slurm, +}: stdenv.mkDerivation rec { pname = "slurm-spank-stunnel"; diff --git a/pkgs/by-name/sl/slurm-spank-x11/package.nix b/pkgs/by-name/sl/slurm-spank-x11/package.nix index 278e1320fa0a12..072328288f4a4f 100644 --- a/pkgs/by-name/sl/slurm-spank-x11/package.nix +++ b/pkgs/by-name/sl/slurm-spank-x11/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, slurm } : +{ + lib, + stdenv, + fetchFromGitHub, + slurm, +}: stdenv.mkDerivation rec { pname = "slurm-spank-x11"; version = "0.2.5"; @@ -13,17 +18,17 @@ stdenv.mkDerivation rec { patches = [ ./hostlist.patch ]; buildPhase = '' - gcc -DX11_LIBEXEC_PROG="\"$out/bin/slurm-spank-x11\"" \ - -g -o slurm-spank-x11 slurm-spank-x11.c - gcc -I${lib.getDev slurm}/include -DX11_LIBEXEC_PROG="\"$out/bin/slurm-spank-x11\"" -shared -fPIC \ - -g -o x11.so slurm-spank-x11-plug.c - ''; + gcc -DX11_LIBEXEC_PROG="\"$out/bin/slurm-spank-x11\"" \ + -g -o slurm-spank-x11 slurm-spank-x11.c + gcc -I${lib.getDev slurm}/include -DX11_LIBEXEC_PROG="\"$out/bin/slurm-spank-x11\"" -shared -fPIC \ + -g -o x11.so slurm-spank-x11-plug.c + ''; installPhase = '' - mkdir -p $out/bin $out/lib - install -m 755 slurm-spank-x11 $out/bin - install -m 755 x11.so $out/lib - ''; + mkdir -p $out/bin $out/lib + install -m 755 slurm-spank-x11 $out/bin + install -m 755 x11.so $out/lib + ''; meta = with lib; { homepage = "https://github.com/hautreux/slurm-spank-x11"; @@ -34,6 +39,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ markuskowa ]; }; } - - - diff --git a/pkgs/by-name/sl/slurm/package.nix b/pkgs/by-name/sl/slurm/package.nix index ff321bf76b3df2..7ef1c4b6aa8cb7 100644 --- a/pkgs/by-name/sl/slurm/package.nix +++ b/pkgs/by-name/sl/slurm/package.nix @@ -1,15 +1,38 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, libtool, curl -, python3, munge, perl, pam, shadow, coreutils, dbus, libbpf -, ncurses, libmysqlclient, lua, hwloc, numactl -, readline, freeipmi, xorg, lz4, rdma-core, nixosTests -, pmix -, libjwt -, libyaml -, json_c -, http-parser -# enable internal X11 support via libssh2 -, enableX11 ? true -, enableGtk2 ? false, gtk2 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libtool, + curl, + python3, + munge, + perl, + pam, + shadow, + coreutils, + dbus, + libbpf, + ncurses, + libmysqlclient, + lua, + hwloc, + numactl, + readline, + freeipmi, + xorg, + lz4, + rdma-core, + nixosTests, + pmix, + libjwt, + libyaml, + json_c, + http-parser, + # enable internal X11 support via libssh2 + enableX11 ? true, + enableGtk2 ? false, + gtk2, }: stdenv.mkDerivation rec { @@ -22,11 +45,14 @@ stdenv.mkDerivation rec { owner = "SchedMD"; repo = "slurm"; # The release tags use - instead of . - rev = "${pname}-${builtins.replaceStrings ["."] ["-"] version}"; + rev = "${pname}-${builtins.replaceStrings [ "." ] [ "-" ] version}"; hash = "sha256-waUCyzLCK3NRp8DfkvzWjGjzlB1MIZ7N9X+nfjrdAFY="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; patches = [ # increase string length to allow for full @@ -34,37 +60,63 @@ stdenv.mkDerivation rec { ./common-env-echo.patch ]; - prePatch = '' - substituteInPlace src/common/env.c \ - --replace "/bin/echo" "${coreutils}/bin/echo" + prePatch = + '' + substituteInPlace src/common/env.c \ + --replace "/bin/echo" "${coreutils}/bin/echo" - # Autoconf does not support split packages for pmix (libs and headers). - # Fix the path to the pmix libraries, so dlopen can find it. - substituteInPlace src/plugins/mpi/pmix/mpi_pmix.c \ - --replace 'xstrfmtcat(full_path, "%s/", PMIXP_LIBPATH)' \ - 'xstrfmtcat(full_path, "${lib.getLib pmix}/lib/")' + # Autoconf does not support split packages for pmix (libs and headers). + # Fix the path to the pmix libraries, so dlopen can find it. + substituteInPlace src/plugins/mpi/pmix/mpi_pmix.c \ + --replace 'xstrfmtcat(full_path, "%s/", PMIXP_LIBPATH)' \ + 'xstrfmtcat(full_path, "${lib.getLib pmix}/lib/")' - '' + (lib.optionalString enableX11 '' - substituteInPlace src/common/x11_util.c \ - --replace '"/usr/bin/xauth"' '"${xorg.xauth}/bin/xauth"' - ''); + '' + + (lib.optionalString enableX11 '' + substituteInPlace src/common/x11_util.c \ + --replace '"/usr/bin/xauth"' '"${xorg.xauth}/bin/xauth"' + ''); # nixos test fails to start slurmd with 'undefined symbol: slurm_job_preempt_mode' # https://groups.google.com/forum/#!topic/slurm-devel/QHOajQ84_Es # this doesn't fix tests completely at least makes slurmd to launch hardeningDisable = [ "bindnow" ]; - nativeBuildInputs = [ pkg-config libtool python3 perl ]; - buildInputs = [ - curl python3 munge pam - libmysqlclient ncurses lz4 rdma-core - lua hwloc numactl readline freeipmi shadow.su - pmix json_c libjwt libyaml dbus libbpf - http-parser - ] ++ lib.optionals enableX11 [ xorg.xauth ] - ++ lib.optionals enableGtk2 [ gtk2 ]; - - configureFlags = [ + nativeBuildInputs = [ + pkg-config + libtool + python3 + perl + ]; + buildInputs = + [ + curl + python3 + munge + pam + libmysqlclient + ncurses + lz4 + rdma-core + lua + hwloc + numactl + readline + freeipmi + shadow.su + pmix + json_c + libjwt + libyaml + dbus + libbpf + http-parser + ] + ++ lib.optionals enableX11 [ xorg.xauth ] + ++ lib.optionals enableGtk2 [ gtk2 ]; + + configureFlags = + [ "--with-freeipmi=${freeipmi}" "--with-http-parser=${http-parser}" "--with-hwloc=${lib.getDev hwloc}" @@ -78,9 +130,9 @@ stdenv.mkDerivation rec { "--with-pmix=${lib.getDev pmix}" "--with-bpf=${libbpf}" "--without-rpath" # Required for configure to pick up the right dlopen path - ] ++ (lib.optional enableGtk2 "--disable-gtktest") - ++ (lib.optional (!enableX11) "--disable-x11"); - + ] + ++ (lib.optional enableGtk2 "--disable-gtktest") + ++ (lib.optional (!enableX11) "--disable-x11"); preConfigure = '' patchShebangs ./doc/html/shtml2html.py @@ -100,6 +152,9 @@ stdenv.mkDerivation rec { description = "Simple Linux Utility for Resource Management"; platforms = platforms.linux; license = licenses.gpl2Only; - maintainers = with maintainers; [ jagajaga markuskowa ]; + maintainers = with maintainers; [ + jagajaga + markuskowa + ]; }; } diff --git a/pkgs/by-name/sm/smack/package.nix b/pkgs/by-name/sm/smack/package.nix index 3adfd4c710e2eb..08c66c2a15d93e 100644 --- a/pkgs/by-name/sm/smack/package.nix +++ b/pkgs/by-name/sm/smack/package.nix @@ -1,11 +1,17 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "smack"; version = "4.1.9"; src = fetchurl { - url = "http://www.igniterealtime.org/downloadServlet?filename=smack/smack_${lib.replaceStrings ["."] ["_"] version}.tar.gz"; + url = "http://www.igniterealtime.org/downloadServlet?filename=smack/smack_${ + lib.replaceStrings [ "." ] [ "_" ] version + }.tar.gz"; sha256 = "009x0qcxd4dkvwcjz2nla470pwbabwvg37wc21pslpw42ldi0bzp"; }; diff --git a/pkgs/by-name/sm/smag/package.nix b/pkgs/by-name/sm/smag/package.nix index 794ee78e859102..160098cd141399 100644 --- a/pkgs/by-name/sm/smag/package.nix +++ b/pkgs/by-name/sm/smag/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "smag"; diff --git a/pkgs/by-name/sm/smallwm/package.nix b/pkgs/by-name/sm/smallwm/package.nix index 35b23f0bf31605..2df4596dd7a5d3 100644 --- a/pkgs/by-name/sm/smallwm/package.nix +++ b/pkgs/by-name/sm/smallwm/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, doxygen -, graphviz -, libX11 -, libXrandr +{ + lib, + stdenv, + fetchFromGitHub, + doxygen, + graphviz, + libX11, + libXrandr, }: stdenv.mkDerivation (finalAttrs: { @@ -37,7 +38,10 @@ stdenv.mkDerivation (finalAttrs: { "CXX=${stdenv.cc.targetPrefix}c++" ]; - buildFlags = [ "all" "doc" ]; + buildFlags = [ + "all" + "doc" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/sm/smart-wallpaper/package.nix b/pkgs/by-name/sm/smart-wallpaper/package.nix index bdcc572377d31a..957fb3043ed6c7 100644 --- a/pkgs/by-name/sm/smart-wallpaper/package.nix +++ b/pkgs/by-name/sm/smart-wallpaper/package.nix @@ -1,12 +1,13 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, makeWrapper -, xdpyinfo -, killall -, xwinwrap -, swaybg -, redshift +{ + stdenvNoCC, + lib, + fetchFromGitHub, + makeWrapper, + xdpyinfo, + killall, + xwinwrap, + swaybg, + redshift, }: stdenvNoCC.mkDerivation { @@ -25,7 +26,15 @@ stdenvNoCC.mkDerivation { installPhase = '' install -Dm755 -t $out/bin smart-wallpaper wrapProgram $out/bin/smart-wallpaper \ - --prefix PATH : ${lib.makeBinPath [ xdpyinfo killall xwinwrap swaybg redshift ]} + --prefix PATH : ${ + lib.makeBinPath [ + xdpyinfo + killall + xwinwrap + swaybg + redshift + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/sm/smartcat/package.nix b/pkgs/by-name/sm/smartcat/package.nix index 691c73f2c2deab..3e7bbf43005fd6 100644 --- a/pkgs/by-name/sm/smartcat/package.nix +++ b/pkgs/by-name/sm/smartcat/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, -, darwin -, openssl -, pkg-config -, stdenv + darwin, + openssl, + pkg-config, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -25,14 +26,15 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AppKit - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AppKit + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; meta = { description = "Integrate large language models into the command line"; diff --git a/pkgs/by-name/sm/smartcrop/package.nix b/pkgs/by-name/sm/smartcrop/package.nix index 7660607a9a4790..a65b19f456704a 100644 --- a/pkgs/by-name/sm/smartcrop/package.nix +++ b/pkgs/by-name/sm/smartcrop/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule { @@ -16,7 +17,10 @@ buildGoModule { vendorHash = "sha256-ov3dHF/NxqxWPaVzddaJSjz3boLpZtIPtvP1iNBtiTc="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Find good image crops for arbitrary crop sizes"; diff --git a/pkgs/by-name/sm/smartdns/package.nix b/pkgs/by-name/sm/smartdns/package.nix index 12325afc48be7b..c7b0f7ecd63069 100644 --- a/pkgs/by-name/sm/smartdns/package.nix +++ b/pkgs/by-name/sm/smartdns/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, openssl, testers, smartdns }: +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + testers, + smartdns, +}: stdenv.mkDerivation rec { pname = "smartdns"; @@ -31,8 +38,7 @@ stdenv.mkDerivation rec { }; meta = with lib; { - description = - "A local DNS server to obtain the fastest website IP for the best Internet experience"; + description = "A local DNS server to obtain the fastest website IP for the best Internet experience"; longDescription = '' SmartDNS is a local DNS server. SmartDNS accepts DNS query requests from local clients, obtains DNS query results from multiple upstream DNS servers, and returns the fastest access results to clients. Avoiding DNS pollution and improving network access speed, supports high-performance ad filtering. diff --git a/pkgs/by-name/sm/smartgithg/package.nix b/pkgs/by-name/sm/smartgithg/package.nix index d636c9d9b1eded..df3322024973d8 100644 --- a/pkgs/by-name/sm/smartgithg/package.nix +++ b/pkgs/by-name/sm/smartgithg/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, makeDesktopItem -, openjdk21 -, gtk3 -, glib -, adwaita-icon-theme -, wrapGAppsHook3 -, libXtst -, which +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + openjdk21, + gtk3, + glib, + adwaita-icon-theme, + wrapGAppsHook3, + libXtst, + which, }: let jre = openjdk21; @@ -18,22 +19,35 @@ stdenv.mkDerivation rec { version = "23.1.3"; src = fetchurl { - url = "https://www.syntevo.com/downloads/smartgit/smartgit-linux-${builtins.replaceStrings [ "." ] [ "_" ] version}.tar.gz"; + url = "https://www.syntevo.com/downloads/smartgit/smartgit-linux-${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.tar.gz"; hash = "sha256-UvdHr1L5MYwl7eT1BVS/M8Ydtw8VjDG+QuqMW0Q5La4="; }; nativeBuildInputs = [ wrapGAppsHook3 ]; - buildInputs = [ jre adwaita-icon-theme gtk3 ]; + buildInputs = [ + jre + adwaita-icon-theme + gtk3 + ]; preFixup = '' gappsWrapperArgs+=( \ - --prefix PATH : ${lib.makeBinPath [ jre which ]} \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ - gtk3 - glib - libXtst - ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + jre + which + ] + } \ + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + gtk3 + glib + libXtst + ] + } \ --prefix JRE_HOME : ${jre} \ --prefix JAVA_HOME : ${jre} \ --prefix SMARTGITHG_JAVA_HOME : ${jre} \ diff --git a/pkgs/by-name/sm/smarty3-i18n/package.nix b/pkgs/by-name/sm/smarty3-i18n/package.nix index e617ba58e8b44d..cd7e2ac511c84c 100644 --- a/pkgs/by-name/sm/smarty3-i18n/package.nix +++ b/pkgs/by-name/sm/smarty3-i18n/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ... }: +{ + lib, + stdenv, + fetchFromGitHub, + ... +}: stdenv.mkDerivation rec { pname = "smarty-i18n"; diff --git a/pkgs/by-name/sm/smarty3/package.nix b/pkgs/by-name/sm/smarty3/package.nix index 6059bed339e630..1e0b41001e6cfd 100644 --- a/pkgs/by-name/sm/smarty3/package.nix +++ b/pkgs/by-name/sm/smarty3/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ... }: +{ + lib, + stdenv, + fetchFromGitHub, + ... +}: stdenv.mkDerivation rec { pname = "smarty3"; diff --git a/pkgs/by-name/sm/smatch/package.nix b/pkgs/by-name/sm/smatch/package.nix index 6acf05652319a2..b373f462a365ba 100644 --- a/pkgs/by-name/sm/smatch/package.nix +++ b/pkgs/by-name/sm/smatch/package.nix @@ -30,10 +30,13 @@ stdenv.mkDerivation { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - sqlite - openssl - ] ++ lib.optionals buildllvmsparse [ libllvm ] ++ lib.optionals buildc2xml [ libxml2.dev ]; + buildInputs = + [ + sqlite + openssl + ] + ++ lib.optionals buildllvmsparse [ libllvm ] + ++ lib.optionals buildc2xml [ libxml2.dev ]; makeFlags = [ "PREFIX=${placeholder "out"}" diff --git a/pkgs/by-name/sm/smb3-foundry/package.nix b/pkgs/by-name/sm/smb3-foundry/package.nix index 2f78261f854ec5..6c7bf56660922f 100644 --- a/pkgs/by-name/sm/smb3-foundry/package.nix +++ b/pkgs/by-name/sm/smb3-foundry/package.nix @@ -1,15 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + python3, }: let - python = (python3.withPackages (ps: with ps; [ - pyside6 - py65 - qdarkstyle - ])); + python = ( + python3.withPackages ( + ps: with ps; [ + pyside6 + py65 + qdarkstyle + ] + ) + ); in stdenv.mkDerivation (finalAttrs: { pname = "smb3-foundry"; diff --git a/pkgs/by-name/sm/smbnetfs/package.nix b/pkgs/by-name/sm/smbnetfs/package.nix index 01596088505d23..f1f40f0f5439e7 100644 --- a/pkgs/by-name/sm/smbnetfs/package.nix +++ b/pkgs/by-name/sm/smbnetfs/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, fuse, samba, pkg-config, glib, autoconf, attr, libsecret }: +{ + lib, + stdenv, + fetchurl, + fuse, + samba, + pkg-config, + glib, + autoconf, + attr, + libsecret, +}: stdenv.mkDerivation rec { pname = "smbnetfs"; @@ -8,8 +19,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-6sN7l2n76cP0uvPrZMYaa1mtTyqgXf3culoaxK301WA="; }; - nativeBuildInputs = [ pkg-config autoconf ]; - buildInputs = [ fuse samba glib attr libsecret ]; + nativeBuildInputs = [ + pkg-config + autoconf + ]; + buildInputs = [ + fuse + samba + glib + attr + libsecret + ]; meta = with lib; { description = "FUSE FS for mounting Samba shares"; diff --git a/pkgs/by-name/sm/smbscan/package.nix b/pkgs/by-name/sm/smbscan/package.nix index ea2a99b64bb0df..0171ab87d7548f 100644 --- a/pkgs/by-name/sm/smbscan/package.nix +++ b/pkgs/by-name/sm/smbscan/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/sm/smc-chilanka/package.nix b/pkgs/by-name/sm/smc-chilanka/package.nix index f5e5ee2cb5d87b..17a0d5685b7ed1 100644 --- a/pkgs/by-name/sm/smc-chilanka/package.nix +++ b/pkgs/by-name/sm/smc-chilanka/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenvNoCC, fetchFromGitLab, python3Packages, gnumake, truetype ? false }: +{ + lib, + stdenvNoCC, + fetchFromGitLab, + python3Packages, + gnumake, + truetype ? false, +}: stdenvNoCC.mkDerivation rec { pname = "chilanka"; @@ -12,7 +19,10 @@ stdenvNoCC.mkDerivation rec { hash = "sha256-VvotRUQks8vUqJOcYHqy6cuwaAKYg4OqtiAjaBIdBRk="; }; - nativeBuildInputs = [ gnumake python3Packages.fontmake ]; + nativeBuildInputs = [ + gnumake + python3Packages.fontmake + ]; buildFlags = [ "otf" ] ++ lib.optional truetype "ttf"; diff --git a/pkgs/by-name/sm/smc/package.nix b/pkgs/by-name/sm/smc/package.nix index 99ed8de45e451e..b1a0060e0e645e 100644 --- a/pkgs/by-name/sm/smc/package.nix +++ b/pkgs/by-name/sm/smc/package.nix @@ -1,11 +1,19 @@ -{ lib, stdenv, fetchurl, jre, runtimeShell }: +{ + lib, + stdenv, + fetchurl, + jre, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "smc"; version = "6.6.3"; src = fetchurl { - url = "mirror://sourceforge/project/smc/smc/${lib.replaceStrings ["."] ["_"] version}/smc_${lib.replaceStrings ["."] ["_"] version}.tgz"; + url = "mirror://sourceforge/project/smc/smc/${lib.replaceStrings [ "." ] [ "_" ] version}/smc_${ + lib.replaceStrings [ "." ] [ "_" ] version + }.tgz"; sha256 = "1gv0hrgdl4wp562virpf9sib6pdhapwv4zvwbl0d5f5xyx04il11"; }; diff --git a/pkgs/by-name/sm/smcroute/package.nix b/pkgs/by-name/sm/smcroute/package.nix index 09d2ef89131a28..8b1dd8420ca1ec 100644 --- a/pkgs/by-name/sm/smcroute/package.nix +++ b/pkgs/by-name/sm/smcroute/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, libcap }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libcap, +}: stdenv.mkDerivation rec { pname = "smcroute"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-b1FsaDw5wAZkOwc6Y7TsMwyfxIRQ2rNUTK+knEzOn7w="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libcap ]; configureFlags = [ diff --git a/pkgs/by-name/sm/smem/package.nix b/pkgs/by-name/sm/smem/package.nix index cd8633303c8b21..70ef87692d0c70 100644 --- a/pkgs/by-name/sm/smem/package.nix +++ b/pkgs/by-name/sm/smem/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, python3 }: +{ + lib, + stdenv, + fetchurl, + python3, +}: stdenv.mkDerivation rec { pname = "smem"; @@ -13,11 +18,10 @@ stdenv.mkDerivation rec { makeFlags = [ "smemcap" ]; - installPhase = - '' - install -Dm555 -t $out/bin/ smem smemcap - install -Dm444 -t $out/share/man/man8/ smem.8 - ''; + installPhase = '' + install -Dm555 -t $out/bin/ smem smemcap + install -Dm444 -t $out/share/man/man8/ smem.8 + ''; meta = { homepage = "https://www.selenic.com/smem/"; diff --git a/pkgs/by-name/sm/smemstat/package.nix b/pkgs/by-name/sm/smemstat/package.nix index a6cdaf978c663f..a267d9905aac97 100644 --- a/pkgs/by-name/sm/smemstat/package.nix +++ b/pkgs/by-name/sm/smemstat/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, ncurses }: +{ + stdenv, + lib, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { pname = "smemstat"; diff --git a/pkgs/by-name/sm/smenu/package.nix b/pkgs/by-name/sm/smenu/package.nix index 8521e549ecc6f5..8a76da58bd4b0b 100644 --- a/pkgs/by-name/sm/smenu/package.nix +++ b/pkgs/by-name/sm/smenu/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { version = "1.4.0"; diff --git a/pkgs/by-name/sm/smile/package.nix b/pkgs/by-name/sm/smile/package.nix index a7d98caf20131a..e3921824a8f862 100644 --- a/pkgs/by-name/sm/smile/package.nix +++ b/pkgs/by-name/sm/smile/package.nix @@ -1,15 +1,16 @@ -{ lib -, python3 -, fetchFromGitHub -, desktop-file-utils -, glib -, gobject-introspection -, meson -, ninja -, wrapGAppsHook4 -, libadwaita -, xdotool -, wl-clipboard +{ + lib, + python3, + fetchFromGitHub, + desktop-file-utils, + glib, + gobject-introspection, + meson, + ninja, + wrapGAppsHook4, + libadwaita, + xdotool, + wl-clipboard, }: python3.pkgs.buildPythonApplication rec { @@ -48,10 +49,12 @@ python3.pkgs.buildPythonApplication rec { preFixup = '' makeWrapperArgs+=( "''${gappsWrapperArgs[@]}" - --prefix PATH : ${lib.makeBinPath [ - xdotool - wl-clipboard - ]} + --prefix PATH : ${ + lib.makeBinPath [ + xdotool + wl-clipboard + ] + } ) ''; @@ -62,6 +65,9 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://mijorus.it/projects/smile/"; license = lib.licenses.gpl3Plus; mainProgram = "smile"; - maintainers = with lib.maintainers; [ koppor aleksana ]; + maintainers = with lib.maintainers; [ + koppor + aleksana + ]; }; } diff --git a/pkgs/by-name/sm/smiley-sans/package.nix b/pkgs/by-name/sm/smiley-sans/package.nix index d136695c8aed16..2b7d6ffc381228 100644 --- a/pkgs/by-name/sm/smiley-sans/package.nix +++ b/pkgs/by-name/sm/smiley-sans/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchzip, nix-update-script }: +{ + lib, + stdenvNoCC, + fetchzip, + nix-update-script, +}: stdenvNoCC.mkDerivation rec { pname = "smiley-sans"; diff --git a/pkgs/by-name/sm/smimesign/package.nix b/pkgs/by-name/sm/smimesign/package.nix index 812d6a24d2bd8b..59c468ccc11137 100644 --- a/pkgs/by-name/sm/smimesign/package.nix +++ b/pkgs/by-name/sm/smimesign/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "smimesign"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-wLqYUICL+gdvRCLNrA0ZNcFI4oV3Oik762q7xF115Lw="; - ldflags = [ "-s" "-w" "-X main.versionString=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.versionString=v${version}" + ]; # Fails in sandbox doCheck = false; diff --git a/pkgs/by-name/sm/smlfmt/package.nix b/pkgs/by-name/sm/smlfmt/package.nix index a8a1d4fb4d62fd..d3e75b598f116e 100644 --- a/pkgs/by-name/sm/smlfmt/package.nix +++ b/pkgs/by-name/sm/smlfmt/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, mlton }: +{ + lib, + stdenv, + fetchFromGitHub, + mlton, +}: stdenv.mkDerivation rec { pname = "smlfmt"; diff --git a/pkgs/by-name/sm/smlfut/package.nix b/pkgs/by-name/sm/smlfut/package.nix index 97ade088ed5789..21938595b30158 100644 --- a/pkgs/by-name/sm/smlfut/package.nix +++ b/pkgs/by-name/sm/smlfut/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, mlton, mlkit, futhark }: +{ + lib, + stdenv, + fetchFromGitHub, + mlton, + mlkit, + futhark, +}: stdenv.mkDerivation rec { pname = "smlfut"; @@ -17,11 +24,14 @@ stdenv.mkDerivation rec { env.MLCOMP = "mlton"; - installFlags = ["PREFIX=$(out)"]; + installFlags = [ "PREFIX=$(out)" ]; doCheck = true; - nativeCheckInputs = [ futhark mlkit ]; + nativeCheckInputs = [ + futhark + mlkit + ]; checkTarget = "run_test"; diff --git a/pkgs/by-name/sm/smlpkg/package.nix b/pkgs/by-name/sm/smlpkg/package.nix index be7592c1c6d88e..6a77c6878e7b16 100644 --- a/pkgs/by-name/sm/smlpkg/package.nix +++ b/pkgs/by-name/sm/smlpkg/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, mlton, unzip }: +{ + lib, + stdenv, + fetchFromGitHub, + mlton, + unzip, +}: stdenv.mkDerivation rec { pname = "smlpkg"; @@ -18,8 +24,8 @@ stdenv.mkDerivation rec { # Set as an environment variable in all the phase scripts. MLCOMP = "mlton"; - buildFlags = ["all"]; - installFlags = ["prefix=$(out)"]; + buildFlags = [ "all" ]; + installFlags = [ "prefix=$(out)" ]; doCheck = true; diff --git a/pkgs/by-name/sm/smokeping/package.nix b/pkgs/by-name/sm/smokeping/package.nix index bfae54dc352200..a2668529c6902c 100644 --- a/pkgs/by-name/sm/smokeping/package.nix +++ b/pkgs/by-name/sm/smokeping/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, fetchpatch, fping, rrdtool, perlPackages, autoreconfHook, nixosTests }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + fping, + rrdtool, + perlPackages, + autoreconfHook, + nixosTests, +}: stdenv.mkDerivation rec { pname = "smokeping"; @@ -15,9 +25,24 @@ stdenv.mkDerivation rec { }) ]; - propagatedBuildInputs = [ rrdtool ] ++ - (with perlPackages; [ perl FCGI CGI CGIFast ConfigGrammar DigestHMAC NetTelnet - NetOpenSSH NetSNMP LWP IOTty fping NetDNS perlldap ]); + propagatedBuildInputs = + [ rrdtool ] + ++ (with perlPackages; [ + perl + FCGI + CGI + CGIFast + ConfigGrammar + DigestHMAC + NetTelnet + NetOpenSSH + NetSNMP + LWP + IOTty + fping + NetDNS + perlldap + ]); nativeBuildInputs = [ autoreconfHook ]; diff --git a/pkgs/by-name/sm/smooth/package.nix b/pkgs/by-name/sm/smooth/package.nix index 3cb227b12d3feb..4fdeb5a47b242c 100644 --- a/pkgs/by-name/sm/smooth/package.nix +++ b/pkgs/by-name/sm/smooth/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, -, bzip2 -, curl -, fribidi -, gtk3 -, iconv -, libcpuid -, libjpeg -, libpng -, libwebp -, libxml2 -, zlib + bzip2, + curl, + fribidi, + gtk3, + iconv, + libcpuid, + libjpeg, + libpng, + libwebp, + libxml2, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sm/smpeg/package.nix b/pkgs/by-name/sm/smpeg/package.nix index d310e3653e7f1b..0d4a67d36631ae 100644 --- a/pkgs/by-name/sm/smpeg/package.nix +++ b/pkgs/by-name/sm/smpeg/package.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, SDL, autoconf, automake, libtool, gtk2, m4, pkg-config, libGLU, libGL, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + SDL, + autoconf, + automake, + libtool, + gtk2, + m4, + pkg-config, + libGLU, + libGL, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "smpeg"; @@ -7,7 +22,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "icculus"; repo = "smpeg"; - rev = "release_${builtins.replaceStrings ["."] ["_"] version}"; + rev = "release_${builtins.replaceStrings [ "." ] [ "_" ] version}"; sha256 = "sha256-nq/i7cFGpJXIuTwN/ScLMX7FN8NMdgdsRM9xOD3uycs="; }; @@ -36,11 +51,27 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - nativeBuildInputs = [ autoconf automake libtool m4 pkg-config makeWrapper ]; + nativeBuildInputs = [ + autoconf + automake + libtool + m4 + pkg-config + makeWrapper + ]; - buildInputs = [ SDL ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ gtk2 libGLU libGL ]; + buildInputs = + [ SDL ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + gtk2 + libGLU + libGL + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; preConfigure = '' touch NEWS AUTHORS ChangeLog diff --git a/pkgs/by-name/sm/smpeg2/package.nix b/pkgs/by-name/sm/smpeg2/package.nix index bcece08e6195fb..c12560f2d7b26f 100644 --- a/pkgs/by-name/sm/smpeg2/package.nix +++ b/pkgs/by-name/sm/smpeg2/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, autoconf -, automake -, darwin -, fetchFromGitHub -, makeWrapper -, pkg-config -, SDL2 +{ + lib, + stdenv, + autoconf, + automake, + darwin, + fetchFromGitHub, + makeWrapper, + pkg-config, + SDL2, }: stdenv.mkDerivation rec { @@ -19,12 +21,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-Z0u83K1GIXd0jUYo5ZyWUH2Zt7Hn8z+yr06DAtAEukw="; }; - nativeBuildInputs = [ autoconf automake makeWrapper pkg-config ]; + nativeBuildInputs = [ + autoconf + automake + makeWrapper + pkg-config + ]; - buildInputs = [ SDL2 ] - ++ lib.optional stdenv.hostPlatform.isDarwin darwin.libobjc; + buildInputs = [ SDL2 ] ++ lib.optional stdenv.hostPlatform.isDarwin darwin.libobjc; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; preConfigure = '' sh autogen.sh diff --git a/pkgs/by-name/sm/smpq/package.nix b/pkgs/by-name/sm/smpq/package.nix index 117e05d08735db..e32f27e6fd6342 100644 --- a/pkgs/by-name/sm/smpq/package.nix +++ b/pkgs/by-name/sm/smpq/package.nix @@ -30,7 +30,10 @@ stdenv.mkDerivation (finalAttrs: { description = "StormLib MPQ archiving utility"; license = lib.licenses.gpl3Only; mainProgram = "smpq"; - maintainers = with lib.maintainers; [ aanderse karolchmist ]; + maintainers = with lib.maintainers; [ + aanderse + karolchmist + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/by-name/sm/smu/package.nix b/pkgs/by-name/sm/smu/package.nix index 63c9bb8d024f10..dbbd80702aa09c 100644 --- a/pkgs/by-name/sm/smu/package.nix +++ b/pkgs/by-name/sm/smu/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "smu"; @@ -26,4 +30,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ oxzi ]; }; } - diff --git a/pkgs/by-name/sm/smug/package.nix b/pkgs/by-name/sm/smug/package.nix index 213d8ee7713949..c7745d1a5ceea8 100644 --- a/pkgs/by-name/sm/smug/package.nix +++ b/pkgs/by-name/sm/smug/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "smug"; @@ -17,7 +22,11 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - ldflags = [ "-s" "-w" "-X=main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.version=${version}" + ]; postInstall = '' installManPage ./man/man1/smug.1 diff --git a/pkgs/by-name/sm/smuview/package.nix b/pkgs/by-name/sm/smuview/package.nix index a030d649992dd5..05c3423f711067 100644 --- a/pkgs/by-name/sm/smuview/package.nix +++ b/pkgs/by-name/sm/smuview/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, cmake -, glib -, boost -, libsigrok -, libserialport -, libzip -, libftdi1 -, hidapi -, glibmm -, python3 -, bluez -, pcre -, libsForQt5 -, desktopToDarwinBundle -, qt5 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + glib, + boost, + libsigrok, + libserialport, + libzip, + libftdi1, + hidapi, + glibmm, + python3, + bluez, + pcre, + libsForQt5, + desktopToDarwinBundle, + qt5, }: stdenv.mkDerivation rec { @@ -30,8 +31,11 @@ stdenv.mkDerivation rec { hash = "sha256-WH8X75yk0aMivbBBOyODcM1eBWwa5UO/3nTaKV1LCGs="; }; - nativeBuildInputs = [ cmake pkg-config qt5.wrapQtAppsHook ] - ++ lib.optional stdenv.hostPlatform.isDarwin desktopToDarwinBundle; + nativeBuildInputs = [ + cmake + pkg-config + qt5.wrapQtAppsHook + ] ++ lib.optional stdenv.hostPlatform.isDarwin desktopToDarwinBundle; buildInputs = [ glib diff --git a/pkgs/by-name/sm/smuxi/package.nix b/pkgs/by-name/sm/smuxi/package.nix index 72354275e39819..0903db1952c033 100644 --- a/pkgs/by-name/sm/smuxi/package.nix +++ b/pkgs/by-name/sm/smuxi/package.nix @@ -1,26 +1,30 @@ -{ stdenv -, autoconf, automake, itstool, intltool, pkg-config -, fetchFromGitHub -, glib -, gettext -, sqlite -, mono -, stfl -, makeWrapper, lib -, guiSupport ? true -, gtk-sharp-2_0 -, gdk-pixbuf -, pango +{ + stdenv, + autoconf, + automake, + itstool, + intltool, + pkg-config, + fetchFromGitHub, + glib, + gettext, + sqlite, + mono, + stfl, + makeWrapper, + lib, + guiSupport ? true, + gtk-sharp-2_0, + gdk-pixbuf, + pango, }: stdenv.mkDerivation rec { pname = "smuxi"; version = "unstable-2023-07-01"; - runtimeLoaderEnvVariableName = if stdenv.hostPlatform.isDarwin then - "DYLD_FALLBACK_LIBRARY_PATH" - else - "LD_LIBRARY_PATH"; + runtimeLoaderEnvVariableName = + if stdenv.hostPlatform.isDarwin then "DYLD_FALLBACK_LIBRARY_PATH" else "LD_LIBRARY_PATH"; src = fetchFromGitHub { owner = "meebey"; @@ -30,13 +34,25 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ pkg-config makeWrapper ]; - buildInputs = [ autoconf automake itstool intltool gettext - mono - stfl ] ++ lib.optionals (guiSupport) [ + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; + buildInputs = + [ + autoconf + automake + itstool + intltool + gettext + mono + stfl + ] + ++ lib.optionals (guiSupport) [ gtk-sharp-2_0 # loaded at runtime by GTK# - gdk-pixbuf pango + gdk-pixbuf + pango ]; preConfigure = '' @@ -51,32 +67,46 @@ stdenv.mkDerivation rec { postInstall = '' makeWrapper "${mono}/bin/mono" "$out/bin/smuxi-message-buffer" \ --add-flags "$out/lib/smuxi/smuxi-message-buffer.exe" \ - --prefix ${runtimeLoaderEnvVariableName} : ${lib.makeLibraryPath [ - gettext sqlite - ]} + --prefix ${runtimeLoaderEnvVariableName} : ${ + lib.makeLibraryPath [ + gettext + sqlite + ] + } makeWrapper "${mono}/bin/mono" "$out/bin/smuxi-server" \ --add-flags "$out/lib/smuxi/smuxi-server.exe" \ - --prefix ${runtimeLoaderEnvVariableName} : ${lib.makeLibraryPath [ - gettext sqlite - ]} + --prefix ${runtimeLoaderEnvVariableName} : ${ + lib.makeLibraryPath [ + gettext + sqlite + ] + } makeWrapper "${mono}/bin/mono" "$out/bin/smuxi-frontend-stfl" \ --add-flags "$out/lib/smuxi/smuxi-frontend-stfl.exe" \ - --prefix ${runtimeLoaderEnvVariableName} : ${lib.makeLibraryPath [ - gettext sqlite stfl - ]} + --prefix ${runtimeLoaderEnvVariableName} : ${ + lib.makeLibraryPath [ + gettext + sqlite + stfl + ] + } makeWrapper "${mono}/bin/mono" "$out/bin/smuxi-frontend-gnome" \ --add-flags "$out/lib/smuxi/smuxi-frontend-gnome.exe" \ --prefix MONO_GAC_PREFIX : ${if guiSupport then gtk-sharp-2_0 else ""} \ - --prefix ${runtimeLoaderEnvVariableName} : ${lib.makeLibraryPath [ - gettext - glib - sqlite - gtk-sharp-2_0 - gtk-sharp-2_0.gtk gdk-pixbuf pango - ]} + --prefix ${runtimeLoaderEnvVariableName} : ${ + lib.makeLibraryPath [ + gettext + glib + sqlite + gtk-sharp-2_0 + gtk-sharp-2_0.gtk + gdk-pixbuf + pango + ] + } # install log4net and nini libraries mkdir -p $out/lib/smuxi/ @@ -84,10 +114,15 @@ stdenv.mkDerivation rec { cp -a lib/Nini.dll $out/lib/smuxi/ # install GTK+ icon theme on Darwin - ${if guiSupport && stdenv.hostPlatform.isDarwin then " + ${ + if guiSupport && stdenv.hostPlatform.isDarwin then + " mkdir -p $out/lib/smuxi/icons/ cp -a images/Smuxi-Symbolic $out/lib/smuxi/icons/ - " else ""} + " + else + "" + } ''; meta = with lib; { diff --git a/pkgs/by-name/sn/sn-pro/package.nix b/pkgs/by-name/sn/sn-pro/package.nix index a01df57eee5a08..6dfa9fe5faf560 100644 --- a/pkgs/by-name/sn/sn-pro/package.nix +++ b/pkgs/by-name/sn/sn-pro/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "sn-pro"; diff --git a/pkgs/by-name/sn/sn0int/package.nix b/pkgs/by-name/sn/sn0int/package.nix index 6e9afcd4a1491f..09517d974fd464 100644 --- a/pkgs/by-name/sn/sn0int/package.nix +++ b/pkgs/by-name/sn/sn0int/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, libseccomp -, libsodium -, pkg-config -, pkgs -, sqlite -, stdenv -, installShellFiles +{ + lib, + fetchFromGitHub, + rustPlatform, + libseccomp, + libsodium, + pkg-config, + pkgs, + sqlite, + stdenv, + installShellFiles, }: rustPlatform.buildRustPackage rec { @@ -28,20 +29,23 @@ rustPlatform.buildRustPackage rec { installShellFiles ]; - buildInputs = [ - libsodium - sqlite - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libseccomp - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - pkgs.darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + libsodium + sqlite + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libseccomp + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + pkgs.darwin.apple_sdk.frameworks.Security + ]; # One of the dependencies (chrootable-https) tries to read "/etc/resolv.conf" # in "checkPhase", hence fails in sandbox of "nix". doCheck = false; - postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' installShellCompletion --cmd sn0int \ --bash <($out/bin/sn0int completions bash) \ --fish <($out/bin/sn0int completions fish) \ @@ -53,7 +57,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/kpcyrd/sn0int"; changelog = "https://github.com/kpcyrd/sn0int/releases/tag/v${version}"; license = with licenses; [ gpl3Plus ]; - maintainers = with maintainers; [ fab xrelkd ]; + maintainers = with maintainers; [ + fab + xrelkd + ]; platforms = platforms.linux ++ platforms.darwin; mainProgram = "sn0int"; }; diff --git a/pkgs/by-name/sn/snabb/package.nix b/pkgs/by-name/sn/snabb/package.nix index 0c0b009cc7a86a..2adae8cc4dd832 100644 --- a/pkgs/by-name/sn/snabb/package.nix +++ b/pkgs/by-name/sn/snabb/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sn/snake4/package.nix b/pkgs/by-name/sn/snake4/package.nix index 79524e974c4d21..0d3856a9d5b59d 100644 --- a/pkgs/by-name/sn/snake4/package.nix +++ b/pkgs/by-name/sn/snake4/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, shhmsg, shhopt, xorg }: +{ + lib, + stdenv, + fetchurl, + shhmsg, + shhopt, + xorg, +}: stdenv.mkDerivation rec { pname = "snake4"; @@ -9,7 +16,15 @@ stdenv.mkDerivation rec { sha256 = "14cng9l857np42zixp440mbc8y5675frb6lhsds53j1cws9cncw9"; }; - buildInputs = with xorg; [ shhmsg shhopt libX11 libXt libXpm libXaw libXext ]; + buildInputs = with xorg; [ + shhmsg + shhopt + libX11 + libXt + libXpm + libXaw + libXext + ]; preInstall = '' substituteInPlace Makefile \ @@ -17,9 +32,11 @@ stdenv.mkDerivation rec { --replace "4755" "755" ''; - installFlags = [ "INSTLIBDIR=$(out)/lib" - "INSTBINDIR=$(out)/bin" - "INSTMANDIR=$(out)/man" ]; + installFlags = [ + "INSTLIBDIR=$(out)/lib" + "INSTBINDIR=$(out)/bin" + "INSTMANDIR=$(out)/man" + ]; meta = with lib; { description = "Game starring a fruit-eating snake"; diff --git a/pkgs/by-name/sn/snap7/package.nix b/pkgs/by-name/sn/snap7/package.nix index 39cdf6d2b45e2e..1beca5d3e06d32 100644 --- a/pkgs/by-name/sn/snap7/package.nix +++ b/pkgs/by-name/sn/snap7/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchzip, p7zip }: +{ + stdenv, + lib, + fetchzip, + p7zip, +}: stdenv.mkDerivation rec { pname = "snap7"; @@ -14,7 +19,11 @@ stdenv.mkDerivation rec { ''; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; makefile = "x86_64_linux.mk"; makeFlags = [ "LibInstall=$(out)/lib" ]; diff --git a/pkgs/by-name/sn/snapdragon-profiler/package.nix b/pkgs/by-name/sn/snapdragon-profiler/package.nix index 1d93bbe715c682..9236487769116e 100644 --- a/pkgs/by-name/sn/snapdragon-profiler/package.nix +++ b/pkgs/by-name/sn/snapdragon-profiler/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, icoutils -, mono -, jre -, androidenv -, gtk-sharp-2_0 -, gtk2 -, libcxx -, coreutils -, requireFile -, archive ? requireFile { +{ + lib, + stdenv, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + icoutils, + mono, + jre, + androidenv, + gtk-sharp-2_0, + gtk2, + libcxx, + coreutils, + requireFile, + archive ? requireFile { name = "snapdragonprofiler_external_linux.tar.gz"; message = '' This nix expression requires that "snapdragonprofiler_external_linux.tar.gz" is @@ -21,7 +22,7 @@ and add it to the nix store with nix-store --add-fixed sha256 . ''; sha256 = "c6731c417ca39fa9b0f190bd80c99b1603cf97d23becab9e47db6beafd6206b7"; - } + }, }: stdenv.mkDerivation rec { @@ -52,7 +53,13 @@ stdenv.mkDerivation rec { cp -r * $out/lib/snapdragon-profiler makeWrapper "${mono}/bin/mono" $out/bin/snapdragon-profiler \ --add-flags "$out/lib/snapdragon-profiler/SnapdragonProfiler.exe" \ - --suffix PATH : ${lib.makeBinPath [ jre androidenv.androidPkgs.platform-tools coreutils ]} \ + --suffix PATH : ${ + lib.makeBinPath [ + jre + androidenv.androidPkgs.platform-tools + coreutils + ] + } \ --prefix MONO_GAC_PREFIX : ${gtk-sharp-2_0} \ --suffix LD_LIBRARY_PATH : $(echo $NIX_LDFLAGS | sed 's/ -L/:/g;s/ -rpath /:/g;s/-rpath //') \ --chdir "$out/lib/snapdragon-profiler" # Fixes themes not loading correctly @@ -65,14 +72,21 @@ stdenv.mkDerivation rec { runHook postInstall ''; - desktopItems = [(makeDesktopItem { - name = pname; - desktopName = "Snapdragon Profiler"; - exec = "snapdragon-profiler"; - icon = "snapdragon-profiler"; - comment = meta.description; - categories = [ "Development" "Debugger" "Graphics" "3DGraphics" ]; - })]; + desktopItems = [ + (makeDesktopItem { + name = pname; + desktopName = "Snapdragon Profiler"; + exec = "snapdragon-profiler"; + icon = "snapdragon-profiler"; + comment = meta.description; + categories = [ + "Development" + "Debugger" + "Graphics" + "3DGraphics" + ]; + }) + ]; dontStrip = true; # Always needed on Mono dontPatchELF = true; # Certain libraries are to be deployed to the remote device, they should not be patched diff --git a/pkgs/by-name/sn/snapper-gui/package.nix b/pkgs/by-name/sn/snapper-gui/package.nix index f4df09504fc26c..83789dfa31beeb 100644 --- a/pkgs/by-name/sn/snapper-gui/package.nix +++ b/pkgs/by-name/sn/snapper-gui/package.nix @@ -1,6 +1,14 @@ -{ lib, fetchFromGitHub, python3, python3Packages -, adwaita-icon-theme, gtk3, wrapGAppsHook3, gtksourceview3, snapper -, gobject-introspection +{ + lib, + fetchFromGitHub, + python3, + python3Packages, + adwaita-icon-theme, + gtk3, + wrapGAppsHook3, + gtksourceview3, + snapper, + gobject-introspection, }: python3Packages.buildPythonApplication rec { @@ -14,7 +22,10 @@ python3Packages.buildPythonApplication rec { sha256 = "13j4spbi9pxg69zifzai8ifk4207sn0vwh6vjqryi0snd5sylh7h"; }; - nativeBuildInputs = [ wrapGAppsHook3 gobject-introspection ]; + nativeBuildInputs = [ + wrapGAppsHook3 + gobject-introspection + ]; buildInputs = [ python3 diff --git a/pkgs/by-name/sn/snappy/package.nix b/pkgs/by-name/sn/snappy/package.nix index 21785e251841ec..cb6c6e559b8922 100644 --- a/pkgs/by-name/sn/snappy/package.nix +++ b/pkgs/by-name/sn/snappy/package.nix @@ -1,6 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, fetchpatch -, static ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fetchpatch, + static ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { @@ -25,7 +29,10 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/by-name/sn/snappymail/package.nix b/pkgs/by-name/sn/snappymail/package.nix index 56fc5a5307cb6b..bb3d11ef998f26 100644 --- a/pkgs/by-name/sn/snappymail/package.nix +++ b/pkgs/by-name/sn/snappymail/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, writeText -, dataPath ? "/var/lib/snappymail" +{ + lib, + stdenv, + fetchurl, + writeText, + dataPath ? "/var/lib/snappymail", }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sn/snapshot/package.nix b/pkgs/by-name/sn/snapshot/package.nix index fcf98fe93a3fa1..895c16ff61d930 100644 --- a/pkgs/by-name/sn/snapshot/package.nix +++ b/pkgs/by-name/sn/snapshot/package.nix @@ -1,24 +1,25 @@ -{ stdenv -, lib -, fetchurl -, glycin-loaders -, cargo -, desktop-file-utils -, jq -, meson -, moreutils -, ninja -, pkg-config -, rustc -, wrapGAppsHook4 -, glib -, gst_all_1 -, gtk4 -, libadwaita -, libcamera -, libseccomp -, pipewire -, gnome +{ + stdenv, + lib, + fetchurl, + glycin-loaders, + cargo, + desktop-file-utils, + jq, + meson, + moreutils, + ninja, + pkg-config, + rustc, + wrapGAppsHook4, + glib, + gst_all_1, + gtk4, + libadwaita, + libcamera, + libseccomp, + pipewire, + gnome, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sn/snazy/package.nix b/pkgs/by-name/sn/snazy/package.nix index 0eb2b588f25dbc..e4431592f22ced 100644 --- a/pkgs/by-name/sn/snazy/package.nix +++ b/pkgs/by-name/sn/snazy/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -45,6 +46,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/chmouel/snazy/"; changelog = "https://github.com/chmouel/snazy/releases/tag/${src.rev}"; license = licenses.asl20; - maintainers = with maintainers; [ figsoda jk ]; + maintainers = with maintainers; [ + figsoda + jk + ]; }; } diff --git a/pkgs/by-name/sn/sndio/package.nix b/pkgs/by-name/sn/sndio/package.nix index 40f308280e6290..aa5ba4e85abda4 100644 --- a/pkgs/by-name/sn/sndio/package.nix +++ b/pkgs/by-name/sn/sndio/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, alsa-lib, fixDarwinDylibNames, gitUpdater }: +{ + lib, + stdenv, + fetchurl, + alsa-lib, + fixDarwinDylibNames, + gitUpdater, +}: stdenv.mkDerivation (finalAttrs: { pname = "sndio"; @@ -11,7 +18,7 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; buildInputs = lib.optional stdenv.hostPlatform.isLinux alsa-lib; - configurePlatforms = []; + configurePlatforms = [ ]; postInstall = '' install -Dm644 contrib/sndiod.service $out/lib/systemd/system/sndiod.service diff --git a/pkgs/by-name/sn/sndpeek/package.nix b/pkgs/by-name/sn/sndpeek/package.nix index 7cf8636ad10747..6cf92d9a656fb0 100644 --- a/pkgs/by-name/sn/sndpeek/package.nix +++ b/pkgs/by-name/sn/sndpeek/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchurl, libsndfile, libglut, alsa-lib, mesa, libGLU, libX11, libXmu -, libXext, libXi }: +{ + lib, + stdenv, + fetchurl, + libsndfile, + libglut, + alsa-lib, + mesa, + libGLU, + libX11, + libXmu, + libXext, + libXi, +}: stdenv.mkDerivation rec { pname = "sndpeek"; @@ -36,18 +48,18 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Real-time 3D animated audio display/playback"; longDescription = '' - sndpeek is just what it sounds (and looks) like: - * real-time 3D animated display/playback - * can use mic-input or wav/aiff/snd/raw/mat file (with playback) - * time-domain waveform - * FFT magnitude spectrum - * 3D waterfall plot - * lissajous! (interchannel correlation) - * rotatable and scalable display - * freeze frame! (for didactic purposes) - * real-time spectral feature extraction (centroid, rms, flux, rolloff) - * available on MacOS X, Linux, and Windows under GPL - * part of the sndtools distribution. + sndpeek is just what it sounds (and looks) like: + * real-time 3D animated display/playback + * can use mic-input or wav/aiff/snd/raw/mat file (with playback) + * time-domain waveform + * FFT magnitude spectrum + * 3D waterfall plot + * lissajous! (interchannel correlation) + * rotatable and scalable display + * freeze frame! (for didactic purposes) + * real-time spectral feature extraction (centroid, rms, flux, rolloff) + * available on MacOS X, Linux, and Windows under GPL + * part of the sndtools distribution. ''; homepage = "https://soundlab.cs.princeton.edu/software/sndpeek/"; license = licenses.gpl2; diff --git a/pkgs/by-name/sn/snekim/package.nix b/pkgs/by-name/sn/snekim/package.nix index 8c8841b9dbd7dd..5591b97234baf2 100644 --- a/pkgs/by-name/sn/snekim/package.nix +++ b/pkgs/by-name/sn/snekim/package.nix @@ -1,4 +1,8 @@ -{ lib, buildNimPackage, fetchFromGitea }: +{ + lib, + buildNimPackage, + fetchFromGitea, +}: buildNimPackage (finalAttrs: { pname = "snekim"; diff --git a/pkgs/by-name/sn/snes9x/package.nix b/pkgs/by-name/sn/snes9x/package.nix index 31aa73db6a9238..3c027f6068e947 100644 --- a/pkgs/by-name/sn/snes9x/package.nix +++ b/pkgs/by-name/sn/snes9x/package.nix @@ -42,51 +42,54 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-INMVyB3alwmsApO7ToAaUWgh7jlg2MeLxqHCEnUO88U="; }; - nativeBuildInputs = [ - pkg-config - python3 - ] - ++ lib.optionals withGtk [ - cmake - ninja - wrapGAppsHook3 - ]; + nativeBuildInputs = + [ + pkg-config + python3 + ] + ++ lib.optionals withGtk [ + cmake + ninja + wrapGAppsHook3 + ]; - buildInputs = [ - libX11 - libXv - minizip - zlib - ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - pulseaudio - libselinux - util-linuxMinimal # provides libmount - ] - ++ lib.optionals (!withGtk) [ - libpng - libXext - libXinerama - ] - ++ lib.optionals withGtk [ - gtkmm3 - libepoxy - libXdmcp - libXrandr - pcre2 - portaudio - SDL2 - ]; + buildInputs = + [ + libX11 + libXv + minizip + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + pulseaudio + libselinux + util-linuxMinimal # provides libmount + ] + ++ lib.optionals (!withGtk) [ + libpng + libXext + libXinerama + ] + ++ lib.optionals withGtk [ + gtkmm3 + libepoxy + libXdmcp + libXrandr + pcre2 + portaudio + SDL2 + ]; hardeningDisable = [ "format" ]; - configureFlags = lib.optionals stdenv.hostPlatform.sse4_1Support [ - "--enable-sse41" - ] - ++ lib.optionals stdenv.hostPlatform.avx2Support [ - "--enable-avx2" - ]; + configureFlags = + lib.optionals stdenv.hostPlatform.sse4_1Support [ + "--enable-sse41" + ] + ++ lib.optionals stdenv.hostPlatform.avx2Support [ + "--enable-avx2" + ]; postPatch = '' substituteInPlace external/glad/src/egl.c \ @@ -112,9 +115,10 @@ stdenv.mkDerivation (finalAttrs: { enableParallelBuilding = true; - meta = let - interface = if withGtk then "GTK" else "X11"; - in + meta = + let + interface = if withGtk then "GTK" else "X11"; + in { homepage = "https://www.snes9x.com"; description = "Super Nintendo Entertainment System (SNES) emulator, ${interface} version"; diff --git a/pkgs/by-name/sn/sngrep/package.nix b/pkgs/by-name/sn/sngrep/package.nix index 1e841d10327fd1..c9936abc1931a8 100644 --- a/pkgs/by-name/sn/sngrep/package.nix +++ b/pkgs/by-name/sn/sngrep/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, autoconf -, automake -, fetchFromGitHub -, libpcap -, ncurses -, openssl -, pcre +{ + lib, + stdenv, + autoconf, + automake, + fetchFromGitHub, + libpcap, + ncurses, + openssl, + pcre, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sn/sniffglue/package.nix b/pkgs/by-name/sn/sniffglue/package.nix index 5bafa510776fe8..28c22a04089e02 100644 --- a/pkgs/by-name/sn/sniffglue/package.nix +++ b/pkgs/by-name/sn/sniffglue/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, libpcap -, libseccomp -, pkg-config -, rustPlatform -, stdenv +{ + lib, + fetchFromGitHub, + libpcap, + libseccomp, + pkg-config, + rustPlatform, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -22,11 +23,13 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - libpcap - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libseccomp - ]; + buildInputs = + [ + libpcap + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libseccomp + ]; meta = with lib; { description = "Secure multithreaded packet sniffer"; diff --git a/pkgs/by-name/sn/sniffnet/package.nix b/pkgs/by-name/sn/sniffnet/package.nix index 146c0941e85077..240fe74c1da31b 100644 --- a/pkgs/by-name/sn/sniffnet/package.nix +++ b/pkgs/by-name/sn/sniffnet/package.nix @@ -1,18 +1,19 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libpcap -, libxkbcommon -, openssl -, stdenv -, alsa-lib -, expat -, fontconfig -, vulkan-loader -, wayland -, xorg -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libpcap, + libxkbcommon, + openssl, + stdenv, + alsa-lib, + expat, + fontconfig, + vulkan-loader, + wayland, + xorg, + darwin, }: rustPlatform.buildRustPackage rec { @@ -30,22 +31,25 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - libpcap - openssl - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - expat - fontconfig - vulkan-loader - xorg.libX11 - xorg.libXcursor - xorg.libXi - xorg.libXrandr - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AppKit - rustPlatform.bindgenHook - ]; + buildInputs = + [ + libpcap + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + expat + fontconfig + vulkan-loader + xorg.libX11 + xorg.libXcursor + xorg.libXi + xorg.libXrandr + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AppKit + rustPlatform.bindgenHook + ]; # requires internet access checkFlags = [ @@ -64,14 +68,24 @@ rustPlatform.buildRustPackage rec { postFixup = lib.optionalString stdenv.hostPlatform.isLinux '' patchelf $out/bin/sniffnet \ - --add-rpath ${lib.makeLibraryPath [ vulkan-loader xorg.libX11 libxkbcommon wayland ]} + --add-rpath ${ + lib.makeLibraryPath [ + vulkan-loader + xorg.libX11 + libxkbcommon + wayland + ] + } ''; meta = with lib; { description = "Cross-platform application to monitor your network traffic with ease"; homepage = "https://github.com/gyulyvgc/sniffnet"; changelog = "https://github.com/gyulyvgc/sniffnet/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "sniffnet"; }; diff --git a/pkgs/by-name/sn/sniglet/package.nix b/pkgs/by-name/sn/sniglet/package.nix index bbf29b9a781754..5f12432be069bc 100644 --- a/pkgs/by-name/sn/sniglet/package.nix +++ b/pkgs/by-name/sn/sniglet/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, +}: stdenvNoCC.mkDerivation { pname = "sniglet"; diff --git a/pkgs/by-name/sn/snippetexpander/package.nix b/pkgs/by-name/sn/snippetexpander/package.nix index 4aed8b58adeb52..3112747257ad81 100644 --- a/pkgs/by-name/sn/snippetexpander/package.nix +++ b/pkgs/by-name/sn/snippetexpander/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, makeWrapper -, scdoc -, installShellFiles -, snippetexpanderd -, snippetexpanderx +{ + lib, + buildGoModule, + makeWrapper, + scdoc, + installShellFiles, + snippetexpanderd, + snippetexpanderx, }: buildGoModule rec { @@ -43,7 +44,12 @@ buildGoModule rec { postFixup = '' # Ensure snippetexpanderd and snippetexpanderx are available to start/stop. wrapProgram $out/bin/snippetexpander \ - --prefix PATH : ${lib.makeBinPath [ snippetexpanderd snippetexpanderx ]} + --prefix PATH : ${ + lib.makeBinPath [ + snippetexpanderd + snippetexpanderx + ] + } ''; meta = { diff --git a/pkgs/by-name/sn/snippetexpanderd/package.nix b/pkgs/by-name/sn/snippetexpanderd/package.nix index e657ed758ff787..dbab53d5041670 100644 --- a/pkgs/by-name/sn/snippetexpanderd/package.nix +++ b/pkgs/by-name/sn/snippetexpanderd/package.nix @@ -1,13 +1,14 @@ -{ lib -, buildGoModule -, fetchFromSourcehut -, makeWrapper -, scdoc -, installShellFiles -, xclip -, wl-clipboard -, xdotool -, wtype +{ + lib, + buildGoModule, + fetchFromSourcehut, + makeWrapper, + scdoc, + installShellFiles, + xclip, + wl-clipboard, + xdotool, + wtype, }: buildGoModule rec { @@ -54,7 +55,14 @@ buildGoModule rec { postFixup = '' # Ensure xclip/wcopy and xdotool/wtype are available for copy and paste duties. wrapProgram $out/bin/snippetexpanderd \ - --prefix PATH : ${lib.makeBinPath [ xclip wl-clipboard xdotool wtype ]} + --prefix PATH : ${ + lib.makeBinPath [ + xclip + wl-clipboard + xdotool + wtype + ] + } ''; meta = { diff --git a/pkgs/by-name/sn/snippetexpandergui/package.nix b/pkgs/by-name/sn/snippetexpandergui/package.nix index ed496b76b905d3..4926187910469d 100644 --- a/pkgs/by-name/sn/snippetexpandergui/package.nix +++ b/pkgs/by-name/sn/snippetexpandergui/package.nix @@ -1,14 +1,15 @@ -{ lib -, buildGoModule -, wrapGAppsHook3 -, wails -, scdoc -, installShellFiles -, xorg -, gtk3 -, webkitgtk_4_0 -, snippetexpanderd -, snippetexpanderx +{ + lib, + buildGoModule, + wrapGAppsHook3, + wails, + scdoc, + installShellFiles, + xorg, + gtk3, + webkitgtk_4_0, + snippetexpanderd, + snippetexpanderx, }: buildGoModule rec { @@ -57,7 +58,12 @@ buildGoModule rec { preFixup = '' gappsWrapperArgs+=( # Ensure snippetexpanderd and snippetexpanderx are available to start/stop. - --prefix PATH : ${lib.makeBinPath [ snippetexpanderd snippetexpanderx ]} + --prefix PATH : ${ + lib.makeBinPath [ + snippetexpanderd + snippetexpanderx + ] + } ) ''; diff --git a/pkgs/by-name/sn/snippetexpanderx/package.nix b/pkgs/by-name/sn/snippetexpanderx/package.nix index e88cbe15ae0d3d..2596a255a159a3 100644 --- a/pkgs/by-name/sn/snippetexpanderx/package.nix +++ b/pkgs/by-name/sn/snippetexpanderx/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, pkg-config -, vala -, wrapGAppsHook3 -, installShellFiles -, scdoc -, at-spi2-atk -, at-spi2-core -, dbus -, gtk3 -, ibus -, libgee -, xorg -, snippetexpanderd +{ + lib, + stdenv, + pkg-config, + vala, + wrapGAppsHook3, + installShellFiles, + scdoc, + at-spi2-atk, + at-spi2-core, + dbus, + gtk3, + ibus, + libgee, + xorg, + snippetexpanderd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sn/snippetpixie/package.nix b/pkgs/by-name/sn/snippetpixie/package.nix index 49b633b02f0127..1e0382ff5f6150 100644 --- a/pkgs/by-name/sn/snippetpixie/package.nix +++ b/pkgs/by-name/sn/snippetpixie/package.nix @@ -1,25 +1,27 @@ -{ lib, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, vala -, pkg-config -, wrapGAppsHook3 -, appstream -, desktop-file-utils -, python3 -, libgee -, glib -, gtk3 -, sqlite -, at-spi2-atk -, at-spi2-core -, dbus -, ibus -, json-glib -, pantheon -, xorg +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + vala, + pkg-config, + wrapGAppsHook3, + appstream, + desktop-file-utils, + python3, + libgee, + glib, + gtk3, + sqlite, + at-spi2-atk, + at-spi2-core, + dbus, + ibus, + json-glib, + pantheon, + xorg, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sn/sniproxy/package.nix b/pkgs/by-name/sn/sniproxy/package.nix index 778681063b6165..9714d6de36d19f 100644 --- a/pkgs/by-name/sn/sniproxy/package.nix +++ b/pkgs/by-name/sn/sniproxy/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, gettext, libev, pcre, pkg-config, udns }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gettext, + libev, + pcre, + pkg-config, + udns, +}: stdenv.mkDerivation rec { pname = "sniproxy"; @@ -11,14 +21,25 @@ stdenv.mkDerivation rec { sha256 = "sha256-htM9CrzaGnn1dnsWQ+0V6N65Og7rsFob3BlSc4UGfFU="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ gettext libev pcre udns ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + gettext + libev + pcre + udns + ]; meta = with lib; { homepage = "https://github.com/dlundquist/sniproxy"; description = "Transparent TLS and HTTP layer 4 proxy with SNI support"; license = licenses.bsd2; - maintainers = with maintainers; [ womfoo raitobezarius ]; + maintainers = with maintainers; [ + womfoo + raitobezarius + ]; platforms = platforms.linux; mainProgram = "sniproxy"; }; diff --git a/pkgs/by-name/sn/snixembed/package.nix b/pkgs/by-name/sn/snixembed/package.nix index 21ec5dac81dfff..09792c91334a6b 100644 --- a/pkgs/by-name/sn/snixembed/package.nix +++ b/pkgs/by-name/sn/snixembed/package.nix @@ -1,4 +1,12 @@ -{ fetchFromSourcehut, gtk3, lib, libdbusmenu-gtk3, pkg-config, stdenv, vala }: +{ + fetchFromSourcehut, + gtk3, + lib, + libdbusmenu-gtk3, + pkg-config, + stdenv, + vala, +}: stdenv.mkDerivation rec { pname = "snixembed"; @@ -11,9 +19,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-co32Xlklg6KVyi+xEoDJ6TeN28V+wCSx73phwnl/05E="; }; - nativeBuildInputs = [ pkg-config vala ]; + nativeBuildInputs = [ + pkg-config + vala + ]; - buildInputs = [ gtk3 libdbusmenu-gtk3 ]; + buildInputs = [ + gtk3 + libdbusmenu-gtk3 + ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/sn/snmpcheck/package.nix b/pkgs/by-name/sn/snmpcheck/package.nix index dbf6c95de8ac1f..c02787b68f0ffc 100644 --- a/pkgs/by-name/sn/snmpcheck/package.nix +++ b/pkgs/by-name/sn/snmpcheck/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchurl, ruby }: +{ + stdenv, + lib, + fetchurl, + ruby, +}: let rubyEnv = ruby.withPackages (ps: [ ps.snmp ]); diff --git a/pkgs/by-name/sn/snobol4/package.nix b/pkgs/by-name/sn/snobol4/package.nix index c0edda03dc64c5..4fda12fcaa5241 100644 --- a/pkgs/by-name/sn/snobol4/package.nix +++ b/pkgs/by-name/sn/snobol4/package.nix @@ -1,17 +1,18 @@ -{ lib -, fetchurl -, stdenv -, bzip2 -, gdbm -, gnum4 -, gzip -, libffi -, openssl -, readline -, sqlite -, tcl -, xz -, zlib +{ + lib, + fetchurl, + stdenv, + bzip2, + gdbm, + gnum4, + gzip, + libffi, + openssl, + readline, + sqlite, + tcl, + xz, + zlib, }: stdenv.mkDerivation rec { @@ -27,12 +28,29 @@ stdenv.mkDerivation rec { hash = "sha256-QeMB6d0YDXARfWTzaU+d1U+e2QmjajJYfIvthatorBU="; }; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; # gzip used by Makefile to compress man pages - nativeBuildInputs = [ gnum4 gzip ]; + nativeBuildInputs = [ + gnum4 + gzip + ]; # enable all features (undocumented, based on manual review of configure script) - buildInputs = [ bzip2 libffi openssl readline sqlite tcl xz zlib ] + buildInputs = + [ + bzip2 + libffi + openssl + readline + sqlite + tcl + xz + zlib + ] # ndbm compat library ++ lib.optional stdenv.hostPlatform.isLinux gdbm; configureFlags = lib.optional (tcl != null) "--with-tcl=${tcl}/lib/tclConfig.sh"; diff --git a/pkgs/by-name/sn/snooze/package.nix b/pkgs/by-name/sn/snooze/package.nix index 1a719a494f84c8..d57f48e36a0e1d 100644 --- a/pkgs/by-name/sn/snooze/package.nix +++ b/pkgs/by-name/sn/snooze/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "snooze"; version = "0.5"; @@ -8,7 +12,10 @@ stdenv.mkDerivation rec { rev = "v${version}"; sha256 = "sha256-K77axli/mapUr3yxpmUfFq4iWwgRmEVUlP6+/0Iezwo="; }; - makeFlags = [ "DESTDIR=$(out)" "PREFIX=/" ]; + makeFlags = [ + "DESTDIR=$(out)" + "PREFIX=/" + ]; meta = with lib; { description = "Tool for waiting until a particular time and then running a command"; diff --git a/pkgs/by-name/sn/snore/package.nix b/pkgs/by-name/sn/snore/package.nix index 572f504873f857..2ad183f5f5b707 100644 --- a/pkgs/by-name/sn/snore/package.nix +++ b/pkgs/by-name/sn/snore/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { version = "0.3.1"; diff --git a/pkgs/by-name/sn/snort/package.nix b/pkgs/by-name/sn/snort/package.nix index 9a6dd217e5de71..5fd3607b5d83c2 100644 --- a/pkgs/by-name/sn/snort/package.nix +++ b/pkgs/by-name/sn/snort/package.nix @@ -1,5 +1,19 @@ -{lib, stdenv, pkg-config, luajit, openssl, fetchurl, libpcap, pcre, libdnet, daq, zlib, flex, bison, makeWrapper -, libtirpc +{ + lib, + stdenv, + pkg-config, + luajit, + openssl, + fetchurl, + libpcap, + pcre, + libdnet, + daq, + zlib, + flex, + bison, + makeWrapper, + libtirpc, }: stdenv.mkDerivation rec { @@ -12,8 +26,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-KUAOE/U7GDHguLEOwSJKHLqm3BUzpTIqIN2Au4S0mBw="; }; - nativeBuildInputs = [ makeWrapper pkg-config ]; - buildInputs = [ luajit openssl libpcap pcre libdnet daq zlib flex bison libtirpc ]; + nativeBuildInputs = [ + makeWrapper + pkg-config + ]; + buildInputs = [ + luajit + openssl + libpcap + pcre + libdnet + daq + zlib + flex + bison + libtirpc + ]; env.NIX_CFLAGS_COMPILE = toString [ "-I${libtirpc.dev}/include/tirpc" ]; diff --git a/pkgs/by-name/sn/snow/package.nix b/pkgs/by-name/sn/snow/package.nix index 5e7cb013a4edcd..2bb684d10e8df8 100644 --- a/pkgs/by-name/sn/snow/package.nix +++ b/pkgs/by-name/sn/snow/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "snow"; diff --git a/pkgs/by-name/sn/snowblind/package.nix b/pkgs/by-name/sn/snowblind/package.nix index d36fe232442160..77444ca17d9701 100644 --- a/pkgs/by-name/sn/snowblind/package.nix +++ b/pkgs/by-name/sn/snowblind/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchFromGitLab, + gtk-engine-murrine, +}: stdenv.mkDerivation rec { pname = "snowblind"; diff --git a/pkgs/by-name/sn/snowcat/package.nix b/pkgs/by-name/sn/snowcat/package.nix index 0054c7a81322e4..aa4899dda9979a 100644 --- a/pkgs/by-name/sn/snowcat/package.nix +++ b/pkgs/by-name/sn/snowcat/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "snowcat"; @@ -12,7 +16,10 @@ buildGoModule rec { }; vendorHash = "sha256-D6ipwGMxT0B3uYUzg6Oo2TYnsOVBY0mYO5lC7vtVPc0="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/praetorian-inc/snowcat"; diff --git a/pkgs/by-name/sn/snowcrash/package.nix b/pkgs/by-name/sn/snowcrash/package.nix index b787b0da59b71e..ff969164dab61c 100644 --- a/pkgs/by-name/sn/snowcrash/package.nix +++ b/pkgs/by-name/sn/snowcrash/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/sn/snowflake/package.nix b/pkgs/by-name/sn/snowflake/package.nix index fa1ac4d3c388f0..9179ba4b499c40 100644 --- a/pkgs/by-name/sn/snowflake/package.nix +++ b/pkgs/by-name/sn/snowflake/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitLab }: +{ + lib, + buildGoModule, + fetchFromGitLab, +}: buildGoModule rec { pname = "snowflake"; @@ -19,7 +23,10 @@ buildGoModule rec { description = "System to defeat internet censorship"; homepage = "https://snowflake.torproject.org/"; changelog = "https://gitlab.torproject.org/tpo/anti-censorship/pluggable-transports/snowflake/-/raw/v${version}/ChangeLog"; - maintainers = with maintainers; [ bbjubjub yayayayaka ]; + maintainers = with maintainers; [ + bbjubjub + yayayayaka + ]; license = licenses.bsd3; }; } diff --git a/pkgs/by-name/sn/snowmachine/package.nix b/pkgs/by-name/sn/snowmachine/package.nix index 124575160afeff..a46037891ead84 100644 --- a/pkgs/by-name/sn/snowmachine/package.nix +++ b/pkgs/by-name/sn/snowmachine/package.nix @@ -1,4 +1,8 @@ -{ python3Packages, lib, fetchPypi }: +{ + python3Packages, + lib, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "snowmachine"; @@ -10,7 +14,11 @@ python3Packages.buildPythonApplication rec { hash = "sha256:119e6da12f430af1519f1a9f091b77b7676c7a9dbeaab6616cb196fe793d8e61"; }; - propagatedBuildInputs = with python3Packages; [ click colorama hatchling ]; + propagatedBuildInputs = with python3Packages; [ + click + colorama + hatchling + ]; doCheck = false; pythonImportsCheck = [ "snowmachine" ]; @@ -20,6 +28,9 @@ python3Packages.buildPythonApplication rec { homepage = "https://github.com/sontek/snowmachine"; mainProgram = "snowmachine"; license = with licenses; [ bsd3 ]; - maintainers = with maintainers; [ djanatyn sontek ]; + maintainers = with maintainers; [ + djanatyn + sontek + ]; }; } diff --git a/pkgs/by-name/sn/snowsql/package.nix b/pkgs/by-name/sn/snowsql/package.nix index 677f33d267b74e..ac72739b7cd605 100644 --- a/pkgs/by-name/sn/snowsql/package.nix +++ b/pkgs/by-name/sn/snowsql/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, rpmextract -, patchelf -, makeWrapper -, openssl -, libxcrypt-legacy +{ + lib, + stdenv, + fetchurl, + rpmextract, + patchelf, + makeWrapper, + openssl, + libxcrypt-legacy, }: stdenv.mkDerivation rec { @@ -17,9 +18,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-KKCCj+pIwWhuzOuxljQ8Y11mAwD/GONspbXuPAMBdhE="; }; - nativeBuildInputs = [ rpmextract makeWrapper ]; + nativeBuildInputs = [ + rpmextract + makeWrapper + ]; - libPath = lib.makeLibraryPath [ openssl libxcrypt-legacy ]; + libPath = lib.makeLibraryPath [ + openssl + libxcrypt-legacy + ]; buildCommand = '' mkdir -p $out/bin/ diff --git a/pkgs/by-name/sn/snpeff/package.nix b/pkgs/by-name/sn/snpeff/package.nix index 269d6e307f1da7..c5706f22fd117b 100644 --- a/pkgs/by-name/sn/snpeff/package.nix +++ b/pkgs/by-name/sn/snpeff/package.nix @@ -1,15 +1,27 @@ -{lib, stdenv, fetchurl, jre, unzip, makeWrapper}: +{ + lib, + stdenv, + fetchurl, + jre, + unzip, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "snpeff"; version = "4.3t"; src = fetchurl { - url = "mirror://sourceforge/project/snpeff/snpEff_v${builtins.replaceStrings [ "." ] [ "_" ] version}_core.zip"; + url = "mirror://sourceforge/project/snpeff/snpEff_v${ + builtins.replaceStrings [ "." ] [ "_" ] version + }_core.zip"; sha256 = "0i12mv93bfv8xjwc3rs2x73d6hkvi7kgbbbx3ry984l3ly4p6nnm"; }; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; buildInputs = [ jre ]; sourceRoot = "snpEff"; diff --git a/pkgs/by-name/sn/snx-rs/package.nix b/pkgs/by-name/sn/snx-rs/package.nix index caf3f333e812ee..6c79e2e0242033 100644 --- a/pkgs/by-name/sn/snx-rs/package.nix +++ b/pkgs/by-name/sn/snx-rs/package.nix @@ -1,4 +1,15 @@ -{ fetchFromGitHub, rustPlatform, lib, pkg-config, openssl, glib, atk, gtk3, libsoup_3, webkitgtk_4_1 }: +{ + fetchFromGitHub, + rustPlatform, + lib, + pkg-config, + openssl, + glib, + atk, + gtk3, + libsoup_3, + webkitgtk_4_1, +}: rustPlatform.buildRustPackage { pname = "snx-rs"; version = "2.2.3"; @@ -11,7 +22,14 @@ rustPlatform.buildRustPackage { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl glib atk gtk3 libsoup_3 webkitgtk_4_1 ]; + buildInputs = [ + openssl + glib + atk + gtk3 + libsoup_3 + webkitgtk_4_1 + ]; checkFlags = [ "--skip=platform::linux::net::tests::test_default_ip" diff --git a/pkgs/by-name/sn/snzip/package.nix b/pkgs/by-name/sn/snzip/package.nix index b6e671839ab03f..8010d22eb06fba 100644 --- a/pkgs/by-name/sn/snzip/package.nix +++ b/pkgs/by-name/sn/snzip/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, snappy +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + snappy, }: stdenv.mkDerivation (finalAttrs: { @@ -36,4 +37,3 @@ stdenv.mkDerivation (finalAttrs: { platforms = platforms.linux; }; }) - diff --git a/pkgs/by-name/so/soapyremote/package.nix b/pkgs/by-name/so/soapyremote/package.nix index 4191b8ae95cebb..7fe21410cf5022 100644 --- a/pkgs/by-name/so/soapyremote/package.nix +++ b/pkgs/by-name/so/soapyremote/package.nix @@ -1,9 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, cmake, soapysdr, avahi }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + soapysdr, + avahi, +}: let version = "0.5.2"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "soapyremote"; inherit version; @@ -15,11 +23,16 @@ in stdenv.mkDerivation { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ soapysdr avahi ]; + buildInputs = [ + soapysdr + avahi + ]; cmakeFlags = [ "-DSoapySDR_DIR=${soapysdr}/share/cmake/SoapySDR/" ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ "-include sys/select.h" ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ "-include sys/select.h" ] + ); meta = with lib; { homepage = "https://github.com/pothosware/SoapyRemote"; diff --git a/pkgs/by-name/so/soapysdrplay/package.nix b/pkgs/by-name/so/soapysdrplay/package.nix index 80c9c409e1ee28..bd462c61069bb1 100644 --- a/pkgs/by-name/so/soapysdrplay/package.nix +++ b/pkgs/by-name/so/soapysdrplay/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, cmake, pkg-config, soapysdr, sdrplay }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + soapysdr, + sdrplay, +}: stdenv.mkDerivation rec { pname = "soapysdr-sdrplay3"; @@ -11,9 +19,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-WMcAw0uR2o2SrQR4mBtdVEZlJ/ZXRqwo6zMJNsB/5U4="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ soapysdr sdrplay ]; + buildInputs = [ + soapysdr + sdrplay + ]; cmakeFlags = [ "-DSoapySDR_DIR=${soapysdr}/share/cmake/SoapySDR/" diff --git a/pkgs/by-name/so/socat/package.nix b/pkgs/by-name/so/socat/package.nix index ce8b5f32ecc0a9..1410945e6f633a 100644 --- a/pkgs/by-name/so/socat/package.nix +++ b/pkgs/by-name/so/socat/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchurl -, nettools -, openssl -, readline -, stdenv -, which -, buildPackages +{ + lib, + fetchurl, + nettools, + openssl, + readline, + stdenv, + which, + buildPackages, }: stdenv.mkDerivation rec { @@ -24,13 +25,19 @@ stdenv.mkDerivation rec { --replace /sbin/ifconfig ifconfig ''; - buildInputs = [ openssl readline ]; + buildInputs = [ + openssl + readline + ]; hardeningEnable = [ "pie" ]; enableParallelBuilding = true; - nativeCheckInputs = [ which nettools ]; + nativeCheckInputs = [ + which + nettools + ]; doCheck = false; # fails a bunch, hangs passthru.tests = lib.optionalAttrs stdenv.buildPlatform.isLinux { diff --git a/pkgs/by-name/so/social-engineer-toolkit/package.nix b/pkgs/by-name/so/social-engineer-toolkit/package.nix index 4f2d5895cc789b..696ed2d71fb2fe 100644 --- a/pkgs/by-name/so/social-engineer-toolkit/package.nix +++ b/pkgs/by-name/so/social-engineer-toolkit/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, python3Packages, makeWrapper, metasploit }: +{ + lib, + fetchFromGitHub, + python3Packages, + makeWrapper, + metasploit, +}: python3Packages.buildPythonApplication rec { pname = "social-engineer-toolkit"; diff --git a/pkgs/by-name/so/sockdump/package.nix b/pkgs/by-name/so/sockdump/package.nix index 98e88d0d6f83f0..d79b4bf4a0b736 100644 --- a/pkgs/by-name/so/sockdump/package.nix +++ b/pkgs/by-name/so/sockdump/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, python3, bcc }: +{ + lib, + fetchFromGitHub, + python3, + bcc, +}: python3.pkgs.buildPythonApplication rec { pname = "sockdump"; @@ -21,6 +26,9 @@ python3.pkgs.buildPythonApplication rec { description = "Dump unix domain socket traffic with bpf"; mainProgram = "sockdump"; license = lib.licenses.unlicense; - maintainers = with lib.maintainers; [ ehmry picnoir ]; + maintainers = with lib.maintainers; [ + ehmry + picnoir + ]; }; } diff --git a/pkgs/by-name/so/socket_wrapper/package.nix b/pkgs/by-name/so/socket_wrapper/package.nix index 475a92e79c3e1e..3b80ffff7e0588 100644 --- a/pkgs/by-name/so/socket_wrapper/package.nix +++ b/pkgs/by-name/so/socket_wrapper/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, cmake, pkg-config }: +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "socket_wrapper"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-CWz7TqucebUtss51JsVeUI8GZb/qxsS8ZqPIMh2HU1g="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; meta = with lib; { description = "Library passing all socket communications through unix sockets"; diff --git a/pkgs/by-name/so/socklog/package.nix b/pkgs/by-name/so/socklog/package.nix index 8ba9ab21b13d31..69a6b9a1167b09 100644 --- a/pkgs/by-name/so/socklog/package.nix +++ b/pkgs/by-name/so/socklog/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "socklog"; @@ -11,7 +15,11 @@ stdenv.mkDerivation rec { sourceRoot = "admin/socklog-${version}"; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; postPatch = '' # Fails to run as user without supplementary groups diff --git a/pkgs/by-name/so/sockperf/package.nix b/pkgs/by-name/so/sockperf/package.nix index 6181138a7b6df7..7a1415d2e1f33c 100644 --- a/pkgs/by-name/so/sockperf/package.nix +++ b/pkgs/by-name/so/sockperf/package.nix @@ -1,6 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, doxygen -, enableTool ? false -, enableTest ? false }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + doxygen, + enableTool ? false, + enableTest ? false, +}: stdenv.mkDerivation rec { pname = "sockperf"; @@ -13,9 +19,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-VvxL/bcn69uL7CBpDu4qwbKZwlC4N/kNeRX4k3UzxPI="; }; - nativeBuildInputs = [ autoreconfHook doxygen ]; + nativeBuildInputs = [ + autoreconfHook + doxygen + ]; - configureFlags = [ "--enable-doc" ] + configureFlags = + [ "--enable-doc" ] ++ lib.optional enableTest "--enable-test" ++ lib.optional enableTool "--enable-tool"; diff --git a/pkgs/by-name/so/soco-cli/package.nix b/pkgs/by-name/so/soco-cli/package.nix index b2b415414c79b1..437d2cd92b5336 100644 --- a/pkgs/by-name/so/soco-cli/package.nix +++ b/pkgs/by-name/so/soco-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/so/sof-firmware/package.nix b/pkgs/by-name/so/sof-firmware/package.nix index 4744dbc7baf967..a8cec90efeb23a 100644 --- a/pkgs/by-name/so/sof-firmware/package.nix +++ b/pkgs/by-name/so/sof-firmware/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchurl -, stdenvNoCC +{ + lib, + fetchurl, + stdenvNoCC, }: stdenvNoCC.mkDerivation rec { @@ -30,8 +31,15 @@ stdenvNoCC.mkDerivation rec { changelog = "https://github.com/thesofproject/sof-bin/releases/tag/v${version}"; description = "Sound Open Firmware"; homepage = "https://www.sofproject.org/"; - license = with licenses; [ bsd3 isc ]; - maintainers = with maintainers; [ lblasc evenbrenden hmenke ]; + license = with licenses; [ + bsd3 + isc + ]; + maintainers = with maintainers; [ + lblasc + evenbrenden + hmenke + ]; platforms = with platforms; linux; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; diff --git a/pkgs/by-name/so/sof-tools/package.nix b/pkgs/by-name/so/sof-tools/package.nix index e7a591849f073b..a48693df45c2dd 100644 --- a/pkgs/by-name/so/sof-tools/package.nix +++ b/pkgs/by-name/so/sof-tools/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, alsa-lib }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + alsa-lib, +}: stdenv.mkDerivation rec { pname = "sof-tools"; diff --git a/pkgs/by-name/so/softnet/package.nix b/pkgs/by-name/so/softnet/package.nix index b1a9cb3a97f765..2604e32fd8c0d2 100644 --- a/pkgs/by-name/so/softnet/package.nix +++ b/pkgs/by-name/so/softnet/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchurl +{ + lib, + stdenvNoCC, + fetchurl, }: stdenvNoCC.mkDerivation (finalAttrs: { pname = "softnet"; diff --git a/pkgs/by-name/so/sokol/package.nix b/pkgs/by-name/so/sokol/package.nix index bfb034cfce6c81..22d84ceaa478e7 100644 --- a/pkgs/by-name/so/sokol/package.nix +++ b/pkgs/by-name/so/sokol/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "sokol"; @@ -32,4 +36,3 @@ stdenv.mkDerivation { maintainers = with maintainers; [ jonnybolton ]; }; } - diff --git a/pkgs/by-name/so/sol2/package.nix b/pkgs/by-name/so/sol2/package.nix index 5ec615942545d3..dc8decfef06263 100644 --- a/pkgs/by-name/so/sol2/package.nix +++ b/pkgs/by-name/so/sol2/package.nix @@ -1,8 +1,9 @@ -{ fetchFromGitHub -, lib -, stdenv -, cmake -, lua +{ + fetchFromGitHub, + lib, + stdenv, + cmake, + lua, }: stdenv.mkDerivation (finalAttrs: { pname = "sol2"; @@ -14,14 +15,17 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-7QHZRudxq3hdsfEAYKKJydc4rv6lyN6UIt/2Zmaejx8="; }; - nativeBuildInputs = [ cmake lua ]; + nativeBuildInputs = [ + cmake + lua + ]; cmakeFlags = [ "-DSOL2_LUA_VERSION=${lua.version}" "-DSOL2_BUILD_LUA=FALSE" ]; - meta = with lib;{ + meta = with lib; { description = "Lua API wrapper with advanced features and top notch performance"; longDescription = '' sol2 is a C++ library binding to Lua. diff --git a/pkgs/by-name/so/solaar/package.nix b/pkgs/by-name/so/solaar/package.nix index 4c2e59b2ab8db3..803385cfe4a276 100644 --- a/pkgs/by-name/so/solaar/package.nix +++ b/pkgs/by-name/so/solaar/package.nix @@ -1,12 +1,13 @@ -{ fetchFromGitHub -, lib -, gobject-introspection -, gtk3 -, python3Packages -, wrapGAppsHook3 -, gdk-pixbuf -, libappindicator -, librsvg +{ + fetchFromGitHub, + lib, + gobject-introspection, + gtk3, + python3Packages, + wrapGAppsHook3, + gdk-pixbuf, + libappindicator, + librsvg, }: # Although we copy in the udev rules here, you probably just want to use @@ -23,7 +24,10 @@ python3Packages.buildPythonApplication rec { hash = "sha256-sYJrVAeZi0a7yD0i/zIIxcu9X/c5HvgoI/n50eXD47s="; }; - outputs = [ "out" "udev" ]; + outputs = [ + "out" + "udev" + ]; nativeBuildInputs = [ gdk-pixbuf @@ -81,7 +85,11 @@ python3Packages.buildPythonApplication rec { ''; homepage = "https://pwr-solaar.github.io/Solaar/"; license = licenses.gpl2Only; - maintainers = with maintainers; [ spinus ysndr oxalica ]; + maintainers = with maintainers; [ + spinus + ysndr + oxalica + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/so/solana-cli/package.nix b/pkgs/by-name/so/solana-cli/package.nix index 710d6ec7c43ab6..f9b41352a791e9 100644 --- a/pkgs/by-name/so/solana-cli/package.nix +++ b/pkgs/by-name/so/solana-cli/package.nix @@ -1,34 +1,37 @@ -{ stdenv -, fetchFromGitHub -, lib -, rustPlatform -, darwin -, udev -, protobuf -, libcxx -, rocksdb_8_3 -, installShellFiles -, pkg-config -, openssl -, nix-update-script +{ + stdenv, + fetchFromGitHub, + lib, + rustPlatform, + darwin, + udev, + protobuf, + libcxx, + rocksdb_8_3, + installShellFiles, + pkg-config, + openssl, + nix-update-script, # Taken from https://github.com/solana-labs/solana/blob/master/scripts/cargo-install-all.sh#L84 -, solanaPkgs ? [ - "solana" - "solana-bench-tps" - "solana-faucet" - "solana-gossip" - "solana-install" - "solana-keygen" - "solana-ledger-tool" - "solana-log-analyzer" - "solana-net-shaper" - "solana-validator" - "solana-test-validator" - ] ++ [ - # XXX: Ensure `solana-genesis` is built LAST! - # See https://github.com/solana-labs/solana/issues/5826 - "solana-genesis" - ] + solanaPkgs ? + [ + "solana" + "solana-bench-tps" + "solana-faucet" + "solana-gossip" + "solana-install" + "solana-keygen" + "solana-ledger-tool" + "solana-log-analyzer" + "solana-net-shaper" + "solana-validator" + "solana-test-validator" + ] + ++ [ + # XXX: Ensure `solana-genesis` is built LAST! + # See https://github.com/solana-labs/solana/issues/5826 + "solana-genesis" + ], }: let version = "1.18.26"; @@ -36,7 +39,12 @@ let rocksdb = rocksdb_8_3; inherit (darwin.apple_sdk_11_0) Libsystem; - inherit (darwin.apple_sdk_11_0.frameworks) System IOKit AppKit Security; + inherit (darwin.apple_sdk_11_0.frameworks) + System + IOKit + AppKit + Security + ; in rustPlatform.buildRustPackage rec { pname = "solana-cli"; @@ -70,17 +78,25 @@ rustPlatform.buildRustPackage rec { # I'm not in the mood ((ΦωΦ)) doCheck = false; - nativeBuildInputs = [ installShellFiles protobuf pkg-config ]; - buildInputs = [ openssl rustPlatform.bindgenHook ] + nativeBuildInputs = [ + installShellFiles + protobuf + pkg-config + ]; + buildInputs = + [ + openssl + rustPlatform.bindgenHook + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ udev ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libcxx - IOKit - Security - AppKit - System - Libsystem - ]; + libcxx + IOKit + Security + AppKit + System + Libsystem + ]; postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' installShellCompletion --cmd solana \ @@ -107,7 +123,11 @@ rustPlatform.buildRustPackage rec { description = "Web-Scale Blockchain for fast, secure, scalable, decentralized apps and marketplaces"; homepage = "https://solana.com"; license = licenses.asl20; - maintainers = with maintainers; [ netfox happysalada aikooo7 ]; + maintainers = with maintainers; [ + netfox + happysalada + aikooo7 + ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/so/solarc-gtk-theme/package.nix b/pkgs/by-name/so/solarc-gtk-theme/package.nix index a6ae8ce2e91485..04ae6fd250465c 100644 --- a/pkgs/by-name/so/solarc-gtk-theme/package.nix +++ b/pkgs/by-name/so/solarc-gtk-theme/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, pkg-config, - gtk-engine-murrine, gtk3 +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + pkg-config, + gtk-engine-murrine, + gtk3, }: stdenv.mkDerivation { @@ -13,9 +20,17 @@ stdenv.mkDerivation { sha256 = "005b66whyxba3403yzykpnlkz0q4m154pxpb4jzcny3fggy9r70s"; }; - nativeBuildInputs = [ autoconf automake pkg-config gtk3 ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + gtk3 + ]; - propagatedUserEnvPkgs = [ gtk-engine-murrine gtk3 ]; + propagatedUserEnvPkgs = [ + gtk-engine-murrine + gtk3 + ]; buildPhase = '' ./autogen.sh --prefix=$out diff --git a/pkgs/by-name/so/solc/package.nix b/pkgs/by-name/so/solc/package.nix index 73476c939ce809..db9dada8db202f 100644 --- a/pkgs/by-name/so/solc/package.nix +++ b/pkgs/by-name/so/solc/package.nix @@ -1,22 +1,27 @@ -{ lib, gccStdenv, fetchzip -, pkgs -, boost -, cmake -, coreutils -, jq -, ncurses -, python3 -, z3Support ? true -, z3_4_11 ? null -, cvc4Support ? gccStdenv.hostPlatform.isLinux -, cvc4 ? null -, cln ? null -, gmp ? null +{ + lib, + gccStdenv, + fetchzip, + pkgs, + boost, + cmake, + coreutils, + jq, + ncurses, + python3, + z3Support ? true, + z3_4_11 ? null, + cvc4Support ? gccStdenv.hostPlatform.isLinux, + cvc4 ? null, + cln ? null, + gmp ? null, }: # compiling source/libsmtutil/CVC4Interface.cpp breaks on clang on Darwin, # general commandline tests fail at abiencoderv2_no_warning/ on clang on NixOS -let z3 = z3_4_11; in +let + z3 = z3_4_11; +in assert z3Support -> z3 != null && lib.versionAtLeast z3.version "4.11.0"; assert cvc4Support -> cvc4 != null && cln != null && gmp != null; @@ -49,85 +54,125 @@ let description = "Compiler for Ethereum smart contract language Solidity"; homepage = "https://github.com/ethereum/solidity"; license = licenses.gpl3; - maintainers = with maintainers; [ dbrock akru lionello sifmelcara ]; - }; - - solc = if gccStdenv.hostPlatform.isLinux then gccStdenv.mkDerivation rec { - inherit pname version meta; - - # upstream suggests avoid using archive generated by github - src = fetchzip { - url = "https://github.com/ethereum/solidity/releases/download/v${version}/solidity_${version}.tar.gz"; - sha256 = "sha256-6EeRmxAmb1nCQ2FTNtWfQ7HCH0g9nJXC3jnhV0KEOwk="; - }; - - postPatch = '' - substituteInPlace cmake/jsoncpp.cmake \ - --replace "${jsoncppUrl}" ${jsoncpp} - substituteInPlace cmake/range-v3.cmake \ - --replace "${range3Url}" ${range3} - substituteInPlace cmake/fmtlib.cmake \ - --replace "${fmtlibUrl}" ${fmtlib} - ''; - - cmakeFlags = [ - "-DBoost_USE_STATIC_LIBS=OFF" - - ] ++ (if z3Support then [ - "-DSTRICT_Z3_VERSION=OFF" - ] else [ - "-DUSE_Z3=OFF" - ]) ++ lib.optionals (!cvc4Support) [ - "-DUSE_CVC4=OFF" + maintainers = with maintainers; [ + dbrock + akru + lionello + sifmelcara ]; - - nativeBuildInputs = [ cmake ]; - buildInputs = [ boost ] - ++ lib.optionals z3Support [ z3 ] - ++ lib.optionals cvc4Support [ cvc4 cln gmp ]; - nativeCheckInputs = [ jq ncurses (python3.withPackages (ps: with ps; [ colorama deepdiff devtools docopt docutils requests sphinx tabulate z3-solver ])) ]; # contextlib2 glob2 textwrap3 traceback2 urllib3 - - # tests take 60+ minutes to complete, only run as part of passthru tests - doCheck = false; - - checkPhase = '' - pushd .. - # IPC tests need aleth avaliable, so we disable it - sed -i "s/IPC_ENABLED=true/IPC_ENABLED=false\nIPC_FLAGS=\"--no-ipc\"/" ./scripts/tests.sh - for i in ./scripts/*.sh ./scripts/*.py ./test/*.sh ./test/*.py; do - patchShebangs "$i" - done - ## TODO: reenable tests below after adding evmone and hera and their dependencies to nixpkgs - #TERM=xterm ./scripts/tests.sh ${lib.optionalString z3Support "--no-smt"} - popd - ''; - - doInstallCheck = true; - installCheckPhase = '' - $out/bin/solc --version > /dev/null - ''; - - passthru.tests = { - solcWithTests = solc.overrideAttrs (attrs: { doCheck = true; }); - }; - } else gccStdenv.mkDerivation rec { - inherit pname version meta; - - src = pkgs.fetchurl { - url = "https://github.com/ethereum/solidity/releases/download/v${version}/solc-macos"; - sha256 = "sha256-GdBldJ+wjL/097RShKxVhTBjhl9q6GIeTe+l2Ti5pQI="; - }; - dontUnpack = true; - - installPhase = '' - runHook preInstall - - mkdir -p $out/bin - cp ${src} $out/bin/solc - chmod +x $out/bin/solc - - runHook postInstall - ''; }; + + solc = + if gccStdenv.hostPlatform.isLinux then + gccStdenv.mkDerivation rec { + inherit pname version meta; + + # upstream suggests avoid using archive generated by github + src = fetchzip { + url = "https://github.com/ethereum/solidity/releases/download/v${version}/solidity_${version}.tar.gz"; + sha256 = "sha256-6EeRmxAmb1nCQ2FTNtWfQ7HCH0g9nJXC3jnhV0KEOwk="; + }; + + postPatch = '' + substituteInPlace cmake/jsoncpp.cmake \ + --replace "${jsoncppUrl}" ${jsoncpp} + substituteInPlace cmake/range-v3.cmake \ + --replace "${range3Url}" ${range3} + substituteInPlace cmake/fmtlib.cmake \ + --replace "${fmtlibUrl}" ${fmtlib} + ''; + + cmakeFlags = + [ + "-DBoost_USE_STATIC_LIBS=OFF" + + ] + ++ ( + if z3Support then + [ + "-DSTRICT_Z3_VERSION=OFF" + ] + else + [ + "-DUSE_Z3=OFF" + ] + ) + ++ lib.optionals (!cvc4Support) [ + "-DUSE_CVC4=OFF" + ]; + + nativeBuildInputs = [ cmake ]; + buildInputs = + [ boost ] + ++ lib.optionals z3Support [ z3 ] + ++ lib.optionals cvc4Support [ + cvc4 + cln + gmp + ]; + nativeCheckInputs = [ + jq + ncurses + (python3.withPackages ( + ps: with ps; [ + colorama + deepdiff + devtools + docopt + docutils + requests + sphinx + tabulate + z3-solver + ] + )) + ]; # contextlib2 glob2 textwrap3 traceback2 urllib3 + + # tests take 60+ minutes to complete, only run as part of passthru tests + doCheck = false; + + checkPhase = '' + pushd .. + # IPC tests need aleth avaliable, so we disable it + sed -i "s/IPC_ENABLED=true/IPC_ENABLED=false\nIPC_FLAGS=\"--no-ipc\"/" ./scripts/tests.sh + for i in ./scripts/*.sh ./scripts/*.py ./test/*.sh ./test/*.py; do + patchShebangs "$i" + done + ## TODO: reenable tests below after adding evmone and hera and their dependencies to nixpkgs + #TERM=xterm ./scripts/tests.sh ${lib.optionalString z3Support "--no-smt"} + popd + ''; + + doInstallCheck = true; + installCheckPhase = '' + $out/bin/solc --version > /dev/null + ''; + + passthru.tests = { + solcWithTests = solc.overrideAttrs (attrs: { + doCheck = true; + }); + }; + } + else + gccStdenv.mkDerivation rec { + inherit pname version meta; + + src = pkgs.fetchurl { + url = "https://github.com/ethereum/solidity/releases/download/v${version}/solc-macos"; + sha256 = "sha256-GdBldJ+wjL/097RShKxVhTBjhl9q6GIeTe+l2Ti5pQI="; + }; + dontUnpack = true; + + installPhase = '' + runHook preInstall + + mkdir -p $out/bin + cp ${src} $out/bin/solc + chmod +x $out/bin/solc + + runHook postInstall + ''; + }; in - solc +solc diff --git a/pkgs/by-name/so/solicurses/package.nix b/pkgs/by-name/so/solicurses/package.nix index 5ed776f9f1c6f7..df7211b9ebb61f 100644 --- a/pkgs/by-name/so/solicurses/package.nix +++ b/pkgs/by-name/so/solicurses/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, ncurses +{ + stdenv, + lib, + fetchFromGitHub, + ncurses, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/so/solitaire-tui/package.nix b/pkgs/by-name/so/solitaire-tui/package.nix index feba37c1d9298e..b7756af73687c9 100644 --- a/pkgs/by-name/so/solitaire-tui/package.nix +++ b/pkgs/by-name/so/solitaire-tui/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule { @@ -16,7 +17,10 @@ buildGoModule { vendorHash = "sha256-jFbxT0ekimBNjIHGgMmCUrwZTS3Sdop/MFQMVdBF/38="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/brianstrauch/solitaire-tui"; diff --git a/pkgs/by-name/so/sollya/package.nix b/pkgs/by-name/so/sollya/package.nix index 2b741aec29ab1a..8879712efcf1fc 100644 --- a/pkgs/by-name/so/sollya/package.nix +++ b/pkgs/by-name/so/sollya/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, gmp -, mpfr -, mpfi -, libxml2 -, fplll +{ + lib, + stdenv, + fetchurl, + gmp, + mpfr, + mpfi, + libxml2, + fplll, }: stdenv.mkDerivation rec { @@ -17,7 +18,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-WNc0+aL8jmczwR+W0t+aslvvJNccQBIw4p8KEzmoEZI="; }; - buildInputs = [ gmp mpfr mpfi libxml2 fplll ]; + buildInputs = [ + gmp + mpfr + mpfi + libxml2 + fplll + ]; doCheck = true; diff --git a/pkgs/by-name/so/solo5/package.nix b/pkgs/by-name/so/solo5/package.nix index 667141fe3cf777..37d78ff98dda5f 100644 --- a/pkgs/by-name/so/solo5/package.nix +++ b/pkgs/by-name/so/solo5/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchurl, dosfstools, libseccomp, makeWrapper, mtools, parted -, pkg-config, qemu_test, syslinux, util-linux }: +{ + lib, + stdenv, + fetchurl, + dosfstools, + libseccomp, + makeWrapper, + mtools, + parted, + pkg-config, + qemu_test, + syslinux, + util-linux, +}: let version = "0.9.0"; @@ -12,11 +24,15 @@ let "virtio" "xen" ]; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "solo5"; inherit version; - nativeBuildInputs = [ makeWrapper pkg-config ]; + nativeBuildInputs = [ + makeWrapper + pkg-config + ]; buildInputs = lib.optional (stdenv.hostPlatform.isLinux) libseccomp; src = fetchurl { @@ -35,7 +51,7 @@ in stdenv.mkDerivation { enableParallelBuilding = true; separateDebugInfo = true; - # debugging requires information for both the unikernel and the tender + # debugging requires information for both the unikernel and the tender installPhase = '' runHook preInstall @@ -49,13 +65,23 @@ in stdenv.mkDerivation { --replace "cp " "cp --no-preserve=mode " wrapProgram $out/bin/solo5-virtio-mkimage \ - --prefix PATH : ${lib.makeBinPath [ dosfstools mtools parted syslinux ]} + --prefix PATH : ${ + lib.makeBinPath [ + dosfstools + mtools + parted + syslinux + ] + } runHook postInstall ''; doCheck = stdenv.hostPlatform.isLinux; - nativeCheckInputs = [ util-linux qemu_test ]; + nativeCheckInputs = [ + util-linux + qemu_test + ]; checkPhase = '' runHook preCheck patchShebangs tests @@ -71,8 +97,16 @@ in stdenv.mkDerivation { license = licenses.isc; maintainers = [ maintainers.ehmry ]; platforms = mapCartesianProduct ({ arch, os }: "${arch}-${os}") { - arch = [ "aarch64" "x86_64" ]; - os = [ "freebsd" "genode" "linux" "openbsd" ]; + arch = [ + "aarch64" + "x86_64" + ]; + os = [ + "freebsd" + "genode" + "linux" + "openbsd" + ]; }; }; diff --git a/pkgs/by-name/so/solvespace/package.nix b/pkgs/by-name/so/solvespace/package.nix index fc360943fae398..dcb9fdc58d72fd 100644 --- a/pkgs/by-name/so/solvespace/package.nix +++ b/pkgs/by-name/so/solvespace/package.nix @@ -1,32 +1,33 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, wrapGAppsHook3 -, at-spi2-core -, cairo -, dbus -, eigen -, freetype -, fontconfig -, glew -, gtkmm3 -, json_c -, libdatrie -, libepoxy -, libGLU -, libpng -, libselinux -, libsepol -, libspnav -, libthai -, libxkbcommon -, pangomm -, pcre -, util-linuxMinimal # provides libmount -, xorg -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + wrapGAppsHook3, + at-spi2-core, + cairo, + dbus, + eigen, + freetype, + fontconfig, + glew, + gtkmm3, + json_c, + libdatrie, + libepoxy, + libGLU, + libpng, + libselinux, + libsepol, + libspnav, + libthai, + libxkbcommon, + pangomm, + pcre, + util-linuxMinimal, # provides libmount + xorg, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/so/somafm-cli/package.nix b/pkgs/by-name/so/somafm-cli/package.nix index 45f79e5bddfff9..7a9042b6836b09 100644 --- a/pkgs/by-name/so/somafm-cli/package.nix +++ b/pkgs/by-name/so/somafm-cli/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitHub -, makeWrapper -, curl -, jq -, mpv +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + curl, + jq, + mpv, }: stdenv.mkDerivation rec { @@ -21,7 +23,13 @@ stdenv.mkDerivation rec { installPhase = '' install -m0755 -D src/somafm $out/bin/somafm - wrapProgram $out/bin/somafm --prefix PATH ":" "${lib.makeBinPath [ curl jq mpv ]}"; + wrapProgram $out/bin/somafm --prefix PATH ":" "${ + lib.makeBinPath [ + curl + jq + mpv + ] + }"; ''; meta = with lib; { diff --git a/pkgs/by-name/so/somatic-sniper/package.nix b/pkgs/by-name/so/somatic-sniper/package.nix index 553725fb4566b2..e979fcee2cb755 100644 --- a/pkgs/by-name/so/somatic-sniper/package.nix +++ b/pkgs/by-name/so/somatic-sniper/package.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchFromGitHub, cmake, zlib, ncurses}: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, + ncurses, +}: stdenv.mkDerivation rec { pname = "somatic-sniper"; @@ -14,7 +21,10 @@ stdenv.mkDerivation rec { patches = [ ./somatic-sniper.patch ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ zlib ncurses ]; + buildInputs = [ + zlib + ncurses + ]; enableParallelBuilding = false; diff --git a/pkgs/by-name/so/somebar/package.nix b/pkgs/by-name/so/somebar/package.nix index 4c2545fe9c9638..95436d5547b613 100644 --- a/pkgs/by-name/so/somebar/package.nix +++ b/pkgs/by-name/so/somebar/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromSourcehut -, meson -, ninja -, pkg-config -, wayland -, pango -, wayland-protocols -, wayland-scanner -, conf ? null +{ + lib, + stdenv, + fetchFromSourcehut, + meson, + ninja, + pkg-config, + wayland, + pango, + wayland-protocols, + wayland-scanner, + conf ? null, }: let @@ -27,8 +28,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-PBxCy1dZrOL1nmhVDQozvF0XL79uKMhhERGNpPPzaRU="; }; - nativeBuildInputs = [ meson ninja pkg-config wayland-scanner ]; - buildInputs = [ pango wayland wayland-protocols ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + wayland-scanner + ]; + buildInputs = [ + pango + wayland + wayland-protocols + ]; prePatch = '' cp ${configFile} src/config.hpp diff --git a/pkgs/by-name/so/sonarlint-ls/package.nix b/pkgs/by-name/so/sonarlint-ls/package.nix index 7c043da4e359b2..5ffc83975d5367 100644 --- a/pkgs/by-name/so/sonarlint-ls/package.nix +++ b/pkgs/by-name/so/sonarlint-ls/package.nix @@ -1,17 +1,18 @@ -{ lib -, fetchFromGitHub -, jre_headless -, maven -, jdk17 -, makeWrapper -, writeShellApplication -, runCommand -, sonarlint-ls -, curl -, pcre -, common-updater-scripts -, jq -, gnused +{ + lib, + fetchFromGitHub, + jre_headless, + maven, + jdk17, + makeWrapper, + writeShellApplication, + runCommand, + sonarlint-ls, + curl, + pcre, + common-updater-scripts, + jq, + gnused, }: maven.buildMavenPackage rec { @@ -35,7 +36,6 @@ maven.buildMavenPackage rec { buildOffline = true; - # disable node and npm module installation because the need network access # for the tests. mvnDepsParameters = "-Dskip.installnodenpm=true -Dskip.npm package"; @@ -87,7 +87,13 @@ maven.buildMavenPackage rec { in lib.getExe (writeShellApplication { name = "update-${pname}"; - runtimeInputs = [ curl pcre common-updater-scripts jq gnused ]; + runtimeInputs = [ + curl + pcre + common-updater-scripts + jq + gnused + ]; text = '' LATEST_TAG=$(curl https://api.github.com/repos/${src.owner}/${src.repo}/tags | \ jq -r '[.[] | select(.name | test("^[0-9]"))] | sort_by(.name | split(".") | @@ -115,4 +121,3 @@ maven.buildMavenPackage rec { maintainers = with lib.maintainers; [ tricktron ]; }; } - diff --git a/pkgs/by-name/so/sonata/package.nix b/pkgs/by-name/so/sonata/package.nix index 36c0f9239973b2..2311c8d3ba132b 100644 --- a/pkgs/by-name/so/sonata/package.nix +++ b/pkgs/by-name/so/sonata/package.nix @@ -1,9 +1,28 @@ -{ lib, fetchFromGitHub, wrapGAppsHook3, gettext -, python3Packages, adwaita-icon-theme, gtk3, glib, gdk-pixbuf, gsettings-desktop-schemas, gobject-introspection }: +{ + lib, + fetchFromGitHub, + wrapGAppsHook3, + gettext, + python3Packages, + adwaita-icon-theme, + gtk3, + glib, + gdk-pixbuf, + gsettings-desktop-schemas, + gobject-introspection, +}: let - inherit (python3Packages) buildPythonApplication isPy3k dbus-python pygobject3 mpd2 setuptools; -in buildPythonApplication rec { + inherit (python3Packages) + buildPythonApplication + isPy3k + dbus-python + pygobject3 + mpd2 + setuptools + ; +in +buildPythonApplication rec { pname = "sonata"; version = "1.7.0"; diff --git a/pkgs/by-name/so/songrec/package.nix b/pkgs/by-name/so/songrec/package.nix index a682c2b0df3c17..7709d6058cbb72 100644 --- a/pkgs/by-name/so/songrec/package.nix +++ b/pkgs/by-name/so/songrec/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, gtk3 -, openssl -, alsa-lib -, pkg-config -, ffmpeg -, dbus -, libpulseaudio +{ + lib, + rustPlatform, + fetchFromGitHub, + gtk3, + openssl, + alsa-lib, + pkg-config, + ffmpeg, + dbus, + libpulseaudio, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/so/sonic/package.nix b/pkgs/by-name/so/sonic/package.nix index 6b82b5f4f04fc1..488224eb2724f9 100644 --- a/pkgs/by-name/so/sonic/package.nix +++ b/pkgs/by-name/so/sonic/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fftw, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + fftw, + installShellFiles, +}: stdenv.mkDerivation { pname = "sonic-unstable"; @@ -11,17 +17,22 @@ stdenv.mkDerivation { sha256 = "0ah54nizb6iwcx277w104wsfnx05vrp4sh56d2pfxhf8xghg54m6"; }; - makeFlags = [ "PREFIX=${placeholder "out"}" "CC=${stdenv.cc.targetPrefix}cc" ]; + makeFlags = [ + "PREFIX=${placeholder "out"}" + "CC=${stdenv.cc.targetPrefix}cc" + ]; nativeBuildInputs = [ installShellFiles ]; buildInputs = [ fftw ]; - postInstall = '' - installManPage sonic.1 - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install_name_tool -id $out/lib/libsonic.so.0.3.0 $out/lib/libsonic.so.0.3.0 - ''; + postInstall = + '' + installManPage sonic.1 + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install_name_tool -id $out/lib/libsonic.so.0.3.0 $out/lib/libsonic.so.0.3.0 + ''; meta = with lib; { description = "Simple library to speed up or slow down speech"; diff --git a/pkgs/by-name/so/sonivox/package.nix b/pkgs/by-name/so/sonivox/package.nix index e69f64c1f29a5d..fb741d6a22085e 100644 --- a/pkgs/by-name/so/sonivox/package.nix +++ b/pkgs/by-name/so/sonivox/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "sonivox"; diff --git a/pkgs/by-name/so/sonixd/package.nix b/pkgs/by-name/so/sonixd/package.nix index e535a574ab9a29..1d991ef3840559 100644 --- a/pkgs/by-name/so/sonixd/package.nix +++ b/pkgs/by-name/so/sonixd/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchurl -, appimageTools +{ + lib, + fetchurl, + appimageTools, }: let diff --git a/pkgs/by-name/so/sonobus/package.nix b/pkgs/by-name/so/sonobus/package.nix index bbf52c11b99034..e752dddf7b6a55 100644 --- a/pkgs/by-name/so/sonobus/package.nix +++ b/pkgs/by-name/so/sonobus/package.nix @@ -1,22 +1,23 @@ -{ lib -, pkg-config -, stdenv -, fetchFromGitHub -, autoPatchelfHook -, alsa-lib -, cmake -, freetype -, libGL -, libX11 -, libXcursor -, libXext -, libXinerama -, libXrandr -, libjack2 -, libopus -, curl -, gtk3 -, webkitgtk_4_0 +{ + lib, + pkg-config, + stdenv, + fetchFromGitHub, + autoPatchelfHook, + alsa-lib, + cmake, + freetype, + libGL, + libX11, + libXcursor, + libXext, + libXinerama, + libXrandr, + libjack2, + libopus, + curl, + gtk3, + webkitgtk_4_0, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/so/sonota/package.nix b/pkgs/by-name/so/sonota/package.nix index efc7ab22b46879..5bc4e99a1c6e5e 100644 --- a/pkgs/by-name/so/sonota/package.nix +++ b/pkgs/by-name/so/sonota/package.nix @@ -1,24 +1,30 @@ -{ fetchFromGitHub, fetchurl, lib, python3Packages -, coreVersion ? "1.13.3" # the version of the binary espurna image to flash -, coreSize ? "1MB" # size of the binary image to flash -, coreSha256 ? "0pkb2nmml0blrfiqpc46xpjc2dw927i89k1lfyqx827wanhc704x" }: +{ + fetchFromGitHub, + fetchurl, + lib, + python3Packages, + coreVersion ? "1.13.3", # the version of the binary espurna image to flash + coreSize ? "1MB", # size of the binary image to flash + coreSha256 ? "0pkb2nmml0blrfiqpc46xpjc2dw927i89k1lfyqx827wanhc704x", +}: with python3Packages; let core = fetchurl { - url = "https://github.com/xoseperez/espurna/releases/download/${coreVersion}/espurna-${coreVersion}-espurna-core-${coreSize}.bin"; + url = "https://github.com/xoseperez/espurna/releases/download/${coreVersion}/espurna-${coreVersion}-espurna-core-${coreSize}.bin"; sha256 = coreSha256; }; -in buildPythonApplication rec { +in +buildPythonApplication rec { pname = "sonota-unstable"; version = "2018-10-07"; src = fetchFromGitHub { - owner = "mirko"; - repo = "SonOTA"; - rev = "d7f4b353858aae7ac403f95475a35560fb7ffeae"; + owner = "mirko"; + repo = "SonOTA"; + rev = "d7f4b353858aae7ac403f95475a35560fb7ffeae"; sha256 = "0jd9xrhcyk8d2plbjnrlpn87536zr6n708797n0k5blf109q3c1z"; }; @@ -32,7 +38,11 @@ in buildPythonApplication rec { format = "other"; - propagatedBuildInputs = [ httplib2 netifaces tornado ]; + propagatedBuildInputs = [ + httplib2 + netifaces + tornado + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/so/sony-headphones-client/package.nix b/pkgs/by-name/so/sony-headphones-client/package.nix index 81d405b9d85acb..0682713cf1c564 100644 --- a/pkgs/by-name/so/sony-headphones-client/package.nix +++ b/pkgs/by-name/so/sony-headphones-client/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, pkg-config, bluez, dbus, glew, glfw, imgui, makeDesktopItem, copyDesktopItems }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + bluez, + dbus, + glew, + glfw, + imgui, + makeDesktopItem, + copyDesktopItems, +}: stdenv.mkDerivation rec { pname = "SonyHeadphonesClient"; @@ -22,8 +36,18 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config copyDesktopItems ]; - buildInputs = [ bluez dbus glew glfw imgui ]; + nativeBuildInputs = [ + cmake + pkg-config + copyDesktopItems + ]; + buildInputs = [ + bluez + dbus + glew + glfw + imgui + ]; sourceRoot = "${src.name}/Client"; @@ -47,7 +71,10 @@ stdenv.mkDerivation rec { icon = "SonyHeadphonesClient"; desktopName = "Sony Headphones Client"; comment = "A client recreating the functionality of the Sony Headphones app"; - categories = [ "Audio" "Mixer" ]; + categories = [ + "Audio" + "Mixer" + ]; }) ]; diff --git a/pkgs/by-name/so/sooperlooper/package.nix b/pkgs/by-name/so/sooperlooper/package.nix index 5e2ea785b281c0..2dd184be7ecf30 100644 --- a/pkgs/by-name/so/sooperlooper/package.nix +++ b/pkgs/by-name/so/sooperlooper/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, pkg-config -, which -, libtool -, liblo -, libxml2 -, libjack2 -, libsndfile -, wxGTK32 -, libsigcxx -, libsamplerate -, rubberband -, gettext -, ncurses -, alsa-lib -, fftw +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + which, + libtool, + liblo, + libxml2, + libjack2, + libsndfile, + wxGTK32, + libsigcxx, + libsamplerate, + rubberband, + gettext, + ncurses, + alsa-lib, + fftw, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/so/sophus/package.nix b/pkgs/by-name/so/sophus/package.nix index aa1f6639a4dbe9..69e59195e7acad 100644 --- a/pkgs/by-name/so/sophus/package.nix +++ b/pkgs/by-name/so/sophus/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, eigen -, fmt -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + eigen, + fmt, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -35,7 +36,10 @@ stdenv.mkDerivation (finalAttrs: { description = "C++ implementation of Lie Groups using Eigen"; homepage = "https://github.com/strasdat/Sophus"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ locochoco acowley ]; + maintainers = with lib.maintainers; [ + locochoco + acowley + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/by-name/so/sops/package.nix b/pkgs/by-name/so/sops/package.nix index 65d84c62740c74..68d5d4cb50eae1 100644 --- a/pkgs/by-name/so/sops/package.nix +++ b/pkgs/by-name/so/sops/package.nix @@ -26,7 +26,11 @@ buildGo122Module rec { subPackages = [ "cmd/sops" ]; - ldflags = [ "-s" "-w" "-X github.com/getsops/sops/v3/version.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/getsops/sops/v3/version.Version=${version}" + ]; passthru.updateScript = nix-update-script { }; @@ -42,7 +46,10 @@ buildGo122Module rec { description = "Simple and flexible tool for managing secrets"; changelog = "https://github.com/getsops/sops/blob/v${version}/CHANGELOG.rst"; mainProgram = "sops"; - maintainers = with maintainers; [ Scrumplex mic92 ]; + maintainers = with maintainers; [ + Scrumplex + mic92 + ]; license = licenses.mpl20; }; } diff --git a/pkgs/by-name/so/sopwith/package.nix b/pkgs/by-name/so/sopwith/package.nix index 3adbfa270cbc71..18bf7955101d8f 100644 --- a/pkgs/by-name/so/sopwith/package.nix +++ b/pkgs/by-name/so/sopwith/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, glib -, SDL2 -, libGL -, pkg-config -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + glib, + SDL2, + libGL, + pkg-config, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/so/sorcer/package.nix b/pkgs/by-name/so/sorcer/package.nix index bcca16089a27cb..baf38880f80e67 100644 --- a/pkgs/by-name/so/sorcer/package.nix +++ b/pkgs/by-name/so/sorcer/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub , boost, cairomm, cmake, libsndfile, lv2, ntk, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + boost, + cairomm, + cmake, + libsndfile, + lv2, + ntk, + pkg-config, +}: stdenv.mkDerivation rec { pname = "sorcer"; @@ -11,14 +22,23 @@ stdenv.mkDerivation rec { sha256 = "1x7pi77nal10717l02qpnhrx6d7w5nqrljkn9zx5w7gpb8fpb3vp"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ boost cairomm libsndfile lv2 ntk ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + boost + cairomm + libsndfile + lv2 + ntk + ]; postPatch = '' - # Fix build with lv2 1.18: https://github.com/brummer10/guitarix/commit/c0334c72 - find . -type f -exec fgrep -q LV2UI_Descriptor {} \; \ - -exec sed -i {} -e 's/const struct _\?LV2UI_Descriptor/const LV2UI_Descriptor/' \; - ''; + # Fix build with lv2 1.18: https://github.com/brummer10/guitarix/commit/c0334c72 + find . -type f -exec fgrep -q LV2UI_Descriptor {} \; \ + -exec sed -i {} -e 's/const struct _\?LV2UI_Descriptor/const LV2UI_Descriptor/' \; + ''; installPhase = '' make install diff --git a/pkgs/by-name/so/sord/package.nix b/pkgs/by-name/so/sord/package.nix index f762fbc3931ec3..aeda79e8a4a58a 100644 --- a/pkgs/by-name/so/sord/package.nix +++ b/pkgs/by-name/so/sord/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, doxygen -, fetchFromGitHub -, meson -, ninja -, pcre2 -, pkg-config -, python3 -, serd -, zix +{ + lib, + stdenv, + doxygen, + fetchFromGitHub, + meson, + ninja, + pcre2, + pkg-config, + python3, + serd, + zix, }: stdenv.mkDerivation rec { @@ -22,7 +23,12 @@ stdenv.mkDerivation rec { hash = "sha256-GDs1m8KoEhJDdCf7kacQMZzCNPoZhESJds6KupQvOkU="; }; - outputs = [ "out" "dev" "doc" "man" ]; + outputs = [ + "out" + "dev" + "doc" + "man" + ]; nativeBuildInputs = [ doxygen @@ -32,14 +38,20 @@ stdenv.mkDerivation rec { python3 ]; buildInputs = [ pcre2 ]; - propagatedBuildInputs = [ serd zix ]; + propagatedBuildInputs = [ + serd + zix + ]; doCheck = true; meta = with lib; { homepage = "http://drobilla.net/software/sord"; description = "Lightweight C library for storing RDF data in memory"; - license = with licenses; [ bsd0 isc ]; + license = with licenses; [ + bsd0 + isc + ]; maintainers = [ ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/so/sorted-grep/package.nix b/pkgs/by-name/so/sorted-grep/package.nix index f0225d8a244476..e744793eb6b217 100644 --- a/pkgs/by-name/so/sorted-grep/package.nix +++ b/pkgs/by-name/so/sorted-grep/package.nix @@ -1,4 +1,8 @@ -{ stdenv, fetchurl, lib }: +{ + stdenv, + fetchurl, + lib, +}: stdenv.mkDerivation rec { pname = "sorted-grep"; diff --git a/pkgs/by-name/so/sortmerna/package.nix b/pkgs/by-name/so/sortmerna/package.nix index b6291ea8529751..57db2720d00040 100644 --- a/pkgs/by-name/so/sortmerna/package.nix +++ b/pkgs/by-name/so/sortmerna/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, cmake -, rocksdb_8_3 -, rapidjson -, pkg-config -, fetchFromGitHub -, zlib +{ + lib, + stdenv, + cmake, + rocksdb_8_3, + rapidjson, + pkg-config, + fetchFromGitHub, + zlib, }: let @@ -22,8 +23,15 @@ stdenv.mkDerivation rec { sha256 = "0r91viylzr069jm7kpcgb45kagvf8sqcj5zc1af4arl9sgfs1f3j"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ zlib rocksdb rapidjson ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + zlib + rocksdb + rapidjson + ]; cmakeFlags = [ "-DPORTABLE=off" diff --git a/pkgs/by-name/so/sorts-mill-goudy/package.nix b/pkgs/by-name/so/sorts-mill-goudy/package.nix index 5b5538a0141fa0..b568ddc87d6f12 100644 --- a/pkgs/by-name/so/sorts-mill-goudy/package.nix +++ b/pkgs/by-name/so/sorts-mill-goudy/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, +}: stdenvNoCC.mkDerivation { pname = "sorts-mill-goudy"; diff --git a/pkgs/by-name/so/souffle/package.nix b/pkgs/by-name/so/souffle/package.nix index f279ce475a4e4d..d0f8a16c7342b0 100644 --- a/pkgs/by-name/so/souffle/package.nix +++ b/pkgs/by-name/so/souffle/package.nix @@ -1,21 +1,38 @@ -{ lib, stdenv, fetchFromGitHub -, bash-completion, perl, ncurses, zlib, sqlite, libffi -, mcpp, cmake, bison, flex, doxygen, graphviz -, makeWrapper, python3, callPackage +{ + lib, + stdenv, + fetchFromGitHub, + bash-completion, + perl, + ncurses, + zlib, + sqlite, + libffi, + mcpp, + cmake, + bison, + flex, + doxygen, + graphviz, + makeWrapper, + python3, + callPackage, }: - let - toolsPath = lib.makeBinPath [ mcpp python3 ]; + toolsPath = lib.makeBinPath [ + mcpp + python3 + ]; in stdenv.mkDerivation rec { pname = "souffle"; version = "2.4.1"; src = fetchFromGitHub { - owner = "souffle-lang"; - repo = "souffle"; - rev = version; + owner = "souffle-lang"; + repo = "souffle"; + rev = version; sha256 = "sha256-U3/1iNOLFzuXiBsVDAc5AXnK4F982Uifp18jjFNUv2o="; }; @@ -26,12 +43,33 @@ stdenv.mkDerivation rec { hardeningDisable = lib.optionals stdenv.hostPlatform.isDarwin [ "strictoverflow" ]; - nativeBuildInputs = [ bison cmake flex mcpp doxygen graphviz makeWrapper perl ]; - buildInputs = [ bash-completion ncurses zlib sqlite libffi python3 ]; + nativeBuildInputs = [ + bison + cmake + flex + mcpp + doxygen + graphviz + makeWrapper + perl + ]; + buildInputs = [ + bash-completion + ncurses + zlib + sqlite + libffi + python3 + ]; # these propagated inputs are needed for the compiled Souffle mode to work, # since generated compiler code uses them. TODO: maybe write a g++ wrapper # that adds these so we can keep the propagated inputs clean? - propagatedBuildInputs = [ ncurses zlib sqlite libffi ]; + propagatedBuildInputs = [ + ncurses + zlib + sqlite + libffi + ]; cmakeFlags = [ "-DSOUFFLE_GIT=OFF" ]; @@ -55,9 +93,14 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Translator of declarative Datalog programs into the C++ language"; - homepage = "https://souffle-lang.github.io/"; - platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice copumpkin wchresta markusscherer ]; - license = licenses.upl; + homepage = "https://souffle-lang.github.io/"; + platforms = platforms.unix; + maintainers = with maintainers; [ + thoughtpolice + copumpkin + wchresta + markusscherer + ]; + license = licenses.upl; }; } diff --git a/pkgs/by-name/so/souffle/tests.nix b/pkgs/by-name/so/souffle/tests.nix index 82b4fa489dae4e..fa8267e7d41463 100644 --- a/pkgs/by-name/so/souffle/tests.nix +++ b/pkgs/by-name/so/souffle/tests.nix @@ -1,6 +1,12 @@ -{ stdenv, lib, souffle, runCommand }: +{ + stdenv, + lib, + souffle, + runCommand, +}: let - simpleTest = { name, commands }: + simpleTest = + { name, commands }: stdenv.mkDerivation { inherit name; meta.timeout = 60; @@ -11,7 +17,8 @@ let touch $out ''; }; -in { +in +{ interpret = simpleTest { name = "souffle-test-interpret"; commands = "${souffle}/bin/souffle A.dl"; diff --git a/pkgs/by-name/so/sound-juicer/package.nix b/pkgs/by-name/so/sound-juicer/package.nix index a2e2c4bc09ef7e..426ee4cfaa0833 100644 --- a/pkgs/by-name/so/sound-juicer/package.nix +++ b/pkgs/by-name/so/sound-juicer/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, glib -, gtk3 -, itstool -, libxml2 -, brasero -, libcanberra-gtk3 -, gnome -, adwaita-icon-theme -, gst_all_1 -, libmusicbrainz5 -, libdiscid -, isocodes -, gsettings-desktop-schemas -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + glib, + gtk3, + itstool, + libxml2, + brasero, + libcanberra-gtk3, + gnome, + adwaita-icon-theme, + gst_all_1, + libmusicbrainz5, + libdiscid, + isocodes, + gsettings-desktop-schemas, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/so/sound-of-sorting/package.nix b/pkgs/by-name/so/sound-of-sorting/package.nix index b7b14312e3588f..a9536517178745 100644 --- a/pkgs/by-name/so/sound-of-sorting/package.nix +++ b/pkgs/by-name/so/sound-of-sorting/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, SDL2 -, wxGTK32 -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + SDL2, + wxGTK32, + darwin, }: stdenv.mkDerivation (finalAttrs: { @@ -22,13 +23,14 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - wxGTK32 - SDL2 - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Cocoa - ]; + buildInputs = + [ + wxGTK32 + SDL2 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Cocoa + ]; meta = { description = "Audibilization and Visualization of Sorting Algorithms"; diff --git a/pkgs/by-name/so/sound-theme-freedesktop/package.nix b/pkgs/by-name/so/sound-theme-freedesktop/package.nix index 2b750a7e9e10f1..58882f5291bb05 100644 --- a/pkgs/by-name/so/sound-theme-freedesktop/package.nix +++ b/pkgs/by-name/so/sound-theme-freedesktop/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, intltool }: +{ + lib, + stdenv, + fetchurl, + intltool, +}: stdenv.mkDerivation rec { pname = "sound-theme-freedesktop"; @@ -15,7 +20,12 @@ stdenv.mkDerivation rec { description = "Freedesktop reference sound theme"; homepage = "http://freedesktop.org/wiki/Specifications/sound-theme-spec"; # See http://cgit.freedesktop.org/sound-theme-freedesktop/tree/CREDITS: - license = with licenses; [ cc-by-30 cc-by-sa-25 gpl2 gpl2Plus ]; + license = with licenses; [ + cc-by-30 + cc-by-sa-25 + gpl2 + gpl2Plus + ]; platforms = with platforms; unix; }; } diff --git a/pkgs/by-name/so/soundfont-arachno/package.nix b/pkgs/by-name/so/soundfont-arachno/package.nix index 1bfcad7fdc4085..b92990e07b25bc 100644 --- a/pkgs/by-name/so/soundfont-arachno/package.nix +++ b/pkgs/by-name/so/soundfont-arachno/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "soundfont-arachno"; @@ -6,7 +10,9 @@ stdenvNoCC.mkDerivation rec { src = fetchzip { # Linked on http://www.arachnosoft.com/main/download.php?id=soundfont-sf2: - url = "https://www.dropbox.com/s/2rnpya9ecb9m4jh/arachno-soundfont-${builtins.replaceStrings ["."] [""] version}-sf2.zip"; + url = "https://www.dropbox.com/s/2rnpya9ecb9m4jh/arachno-soundfont-${ + builtins.replaceStrings [ "." ] [ "" ] version + }-sf2.zip"; hash = "sha256-Z5ETe0AKPCi4KlM2xOlNcyQn1xvCuor3S/tcrF+AwNQ="; stripRoot = false; }; diff --git a/pkgs/by-name/so/soundfont-fluid/package.nix b/pkgs/by-name/so/soundfont-fluid/package.nix index 193c9a60b9fcc9..606341847a0ef9 100644 --- a/pkgs/by-name/so/soundfont-fluid/package.nix +++ b/pkgs/by-name/so/soundfont-fluid/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "Fluid"; diff --git a/pkgs/by-name/so/soundfont-generaluser/package.nix b/pkgs/by-name/so/soundfont-generaluser/package.nix index 446fa606c1bc34..df1a24af958951 100644 --- a/pkgs/by-name/so/soundfont-generaluser/package.nix +++ b/pkgs/by-name/so/soundfont-generaluser/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { pname = "generaluser"; diff --git a/pkgs/by-name/so/soundfont-ydp-grand/package.nix b/pkgs/by-name/so/soundfont-ydp-grand/package.nix index 79453cfbb4bb7d..d0f8833873ffb1 100644 --- a/pkgs/by-name/so/soundfont-ydp-grand/package.nix +++ b/pkgs/by-name/so/soundfont-ydp-grand/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "ydp-grand"; diff --git a/pkgs/by-name/so/soundmodem/package.nix b/pkgs/by-name/so/soundmodem/package.nix index f69fbfecd608ce..041de66795936e 100644 --- a/pkgs/by-name/so/soundmodem/package.nix +++ b/pkgs/by-name/so/soundmodem/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, pkg-config, alsa-lib, audiofile, gtk2, libxml2, copyDesktopItems, makeDesktopItem }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + alsa-lib, + audiofile, + gtk2, + libxml2, + copyDesktopItems, + makeDesktopItem, +}: stdenv.mkDerivation rec { pname = "soundmodem"; @@ -13,7 +24,12 @@ stdenv.mkDerivation rec { pkg-config copyDesktopItems ]; - buildInputs = [ alsa-lib audiofile gtk2 libxml2 ]; + buildInputs = [ + alsa-lib + audiofile + gtk2 + libxml2 + ]; patches = [ ./matFix.patch ]; diff --git a/pkgs/by-name/so/soundtouch/package.nix b/pkgs/by-name/so/soundtouch/package.nix index 606fda594d9186..12540494e97567 100644 --- a/pkgs/by-name/so/soundtouch/package.nix +++ b/pkgs/by-name/so/soundtouch/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitea, autoconf, automake, libtool }: +{ + stdenv, + lib, + fetchFromGitea, + autoconf, + automake, + libtool, +}: stdenv.mkDerivation rec { pname = "soundtouch"; @@ -12,7 +19,11 @@ stdenv.mkDerivation rec { hash = "sha256-imeeTj+3gXxoGTuC/13+BAplwcnQ0wRJdSVt7MPlBxc="; }; - nativeBuildInputs = [ autoconf automake libtool ]; + nativeBuildInputs = [ + autoconf + automake + libtool + ]; preConfigure = "./bootstrap"; diff --git a/pkgs/by-name/so/soundtracker/package.nix b/pkgs/by-name/so/soundtracker/package.nix index 36f90e67a6394f..4fb702a11eb222 100644 --- a/pkgs/by-name/so/soundtracker/package.nix +++ b/pkgs/by-name/so/soundtracker/package.nix @@ -1,15 +1,17 @@ -{ lib, stdenv -, fetchzip -, pkg-config -, autoreconfHook -, gtk2 -, alsa-lib -, SDL -, jack2 -, audiofile -, goocanvas # graphical envelope editing -, libxml2 -, libsndfile +{ + lib, + stdenv, + fetchzip, + pkg-config, + autoreconfHook, + gtk2, + alsa-lib, + SDL, + jack2, + audiofile, + goocanvas, # graphical envelope editing + libxml2, + libsndfile, }: stdenv.mkDerivation (finalAttrs: { @@ -38,11 +40,13 @@ stdenv.mkDerivation (finalAttrs: { sed -i -e '/seteuid/d' -e '/setegid/d' app/main.c ''; - configureFlags = [ - "--with-graphics-backend=gdk" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "--disable-alsa" - ]; + configureFlags = + [ + "--with-graphics-backend=gdk" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "--disable-alsa" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/so/soupault/package.nix b/pkgs/by-name/so/soupault/package.nix index 9912146eb16535..74a42cc54af40d 100644 --- a/pkgs/by-name/so/soupault/package.nix +++ b/pkgs/by-name/so/soupault/package.nix @@ -1,10 +1,11 @@ -{ lib -, darwin -, fetchzip -, ocamlPackages -, soupault -, stdenv -, testers +{ + lib, + darwin, + fetchzip, + ocamlPackages, + soupault, + stdenv, + testers, }: ocamlPackages.buildDunePackage rec { @@ -21,7 +22,9 @@ ocamlPackages.buildDunePackage rec { hash = "sha256-UABbrNNcNaN9NgtAjCs4HUoNXMaK4QvCuWERuEnMG6I="; }; - nativeBuildInputs = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ darwin.sigtool ]; + nativeBuildInputs = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + darwin.sigtool + ]; buildInputs = with ocamlPackages; [ base64 diff --git a/pkgs/by-name/so/source-code-pro/package.nix b/pkgs/by-name/so/source-code-pro/package.nix index 4d3f5155929be1..dd6b4130afa6b5 100644 --- a/pkgs/by-name/so/source-code-pro/package.nix +++ b/pkgs/by-name/so/source-code-pro/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "source-code-pro"; diff --git a/pkgs/by-name/so/source-han-code-jp/package.nix b/pkgs/by-name/so/source-han-code-jp/package.nix index 5c00f564320b33..ea1501750176a0 100644 --- a/pkgs/by-name/so/source-han-code-jp/package.nix +++ b/pkgs/by-name/so/source-han-code-jp/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "source-han-code-jp"; diff --git a/pkgs/by-name/so/source-sans-pro/package.nix b/pkgs/by-name/so/source-sans-pro/package.nix index 2a2d2c70f289c8..645d984ae6e891 100644 --- a/pkgs/by-name/so/source-sans-pro/package.nix +++ b/pkgs/by-name/so/source-sans-pro/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: # Source Sans Pro got renamed to Source Sans 3 (see # https://github.com/adobe-fonts/source-sans/issues/192). This is the diff --git a/pkgs/by-name/so/source-sans/package.nix b/pkgs/by-name/so/source-sans/package.nix index a3e2d4309066e8..64c28e7a4e051d 100644 --- a/pkgs/by-name/so/source-sans/package.nix +++ b/pkgs/by-name/so/source-sans/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "source-sans"; diff --git a/pkgs/by-name/so/source-serif-pro/package.nix b/pkgs/by-name/so/source-serif-pro/package.nix index 698694faf5074e..1a12a8d2fcd4dd 100644 --- a/pkgs/by-name/so/source-serif-pro/package.nix +++ b/pkgs/by-name/so/source-serif-pro/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: # Source Serif Pro got renamed to Source Serif 4 (see # https://github.com/adobe-fonts/source-serif/issues/77). This is the diff --git a/pkgs/by-name/so/source-serif/package.nix b/pkgs/by-name/so/source-serif/package.nix index dd129b10faab9a..fbbe7f40865d29 100644 --- a/pkgs/by-name/so/source-serif/package.nix +++ b/pkgs/by-name/so/source-serif/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "source-serif"; diff --git a/pkgs/by-name/so/sourceHighlight/package.nix b/pkgs/by-name/so/sourceHighlight/package.nix index 715b9d8ce91def..16eaa9e42e6ab7 100644 --- a/pkgs/by-name/so/sourceHighlight/package.nix +++ b/pkgs/by-name/so/sourceHighlight/package.nix @@ -1,39 +1,53 @@ -{ lib, stdenv, fetchpatch, fetchurl, boost, updateAutotoolsGnuConfigScriptsHook, llvmPackages }: +{ + lib, + stdenv, + fetchpatch, + fetchurl, + boost, + updateAutotoolsGnuConfigScriptsHook, + llvmPackages, +}: stdenv.mkDerivation rec { pname = "source-highlight"; version = "3.1.9"; - outputs = [ "out" "doc" "dev" ]; + outputs = [ + "out" + "doc" + "dev" + ]; src = fetchurl { url = "mirror://gnu/src-highlite/${pname}-${version}.tar.gz"; sha256 = "148w47k3zswbxvhg83z38ifi85f9dqcpg7icvvw1cm6bg21x4zrs"; }; - patches = [ - # gcc-11 compat upstream patch - (fetchpatch { - url = "https://git.savannah.gnu.org/cgit/src-highlite.git/patch/?id=904949c9026cb772dc93fbe0947a252ef47127f4"; - hash = "sha256-h9DyD+pmlQT5dmKjWI9t0gCIYHe7pYkP55LnOqsE0vI="; - excludes = [ "ChangeLog" ]; - }) + patches = + [ + # gcc-11 compat upstream patch + (fetchpatch { + url = "https://git.savannah.gnu.org/cgit/src-highlite.git/patch/?id=904949c9026cb772dc93fbe0947a252ef47127f4"; + hash = "sha256-h9DyD+pmlQT5dmKjWI9t0gCIYHe7pYkP55LnOqsE0vI="; + excludes = [ "ChangeLog" ]; + }) - # Upstream fix for clang-13 and gcc-12 test support - (fetchpatch { - name = "gcc-12.patch"; - url = "https://git.savannah.gnu.org/cgit/src-highlite.git/patch/?id=ab9fe5cb9b85c5afab94f2a7f4b6d7d473c14ee9"; - hash = "sha256-wmSLgLnLuFE+IC6AjxzZp/HEnaOCS1VfY2cac0T7Y+w="; - }) - ] ++ lib.optionals stdenv.cc.isClang [ - # Adds compatibility with C++17 by removing the `register` storage class specifier. - (fetchpatch { - name = "remove-register-keyword"; - url = "https://git.savannah.gnu.org/cgit/src-highlite.git/patch/?id=416b39758dba2c74515584514a959ad1b0ad50d1"; - hash = "sha256-R5A7IGHhU82EqceMCsuNBanhRz4dFVqiaH8637dr7jw="; - includes = [ "lib/*" ]; - }) - ]; + # Upstream fix for clang-13 and gcc-12 test support + (fetchpatch { + name = "gcc-12.patch"; + url = "https://git.savannah.gnu.org/cgit/src-highlite.git/patch/?id=ab9fe5cb9b85c5afab94f2a7f4b6d7d473c14ee9"; + hash = "sha256-wmSLgLnLuFE+IC6AjxzZp/HEnaOCS1VfY2cac0T7Y+w="; + }) + ] + ++ lib.optionals stdenv.cc.isClang [ + # Adds compatibility with C++17 by removing the `register` storage class specifier. + (fetchpatch { + name = "remove-register-keyword"; + url = "https://git.savannah.gnu.org/cgit/src-highlite.git/patch/?id=416b39758dba2c74515584514a959ad1b0ad50d1"; + hash = "sha256-R5A7IGHhU82EqceMCsuNBanhRz4dFVqiaH8637dr7jw="; + includes = [ "lib/*" ]; + }) + ]; # source-highlight uses it's own binary to generate documentation. # During cross-compilation, that binary was built for the target @@ -46,10 +60,13 @@ stdenv.mkDerivation rec { # necessary to build on FreeBSD native pending inclusion of # https://git.savannah.gnu.org/cgit/config.git/commit/?id=e4786449e1c26716e3f9ea182caf472e4dbc96e0 nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook ]; - buildInputs = [ boost ] - ++ lib.optional (stdenv.targetPlatform.useLLVM or false) (llvmPackages.compiler-rt.override { - doFakeLibgcc = true; - }); + buildInputs = + [ boost ] + ++ lib.optional (stdenv.targetPlatform.useLLVM or false) ( + llvmPackages.compiler-rt.override { + doFakeLibgcc = true; + } + ); configureFlags = [ "--with-boost=${boost.out}" @@ -74,7 +91,8 @@ stdenv.mkDerivation rec { platforms = platforms.unix; maintainers = with maintainers; [ SuperSandro2000 ]; }; -} // lib.optionalAttrs (stdenv.targetPlatform.useLLVM or false) { +} +// lib.optionalAttrs (stdenv.targetPlatform.useLLVM or false) { # Force linking to "libgcc" so tests pass NIX_CFLAGS_COMPILE = "-lgcc"; } diff --git a/pkgs/by-name/so/soxr/package.nix b/pkgs/by-name/so/soxr/package.nix index a76b30492ab18d..61121b019e5fb3 100644 --- a/pkgs/by-name/so/soxr/package.nix +++ b/pkgs/by-name/so/soxr/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, cmake }: +{ + lib, + stdenv, + fetchurl, + cmake, +}: stdenv.mkDerivation rec { pname = "soxr"; @@ -14,7 +19,11 @@ stdenv.mkDerivation rec { ./arm64-check.patch ]; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/by-name/so/soxt/package.nix b/pkgs/by-name/so/soxt/package.nix index 021554c3a12059..f94c07c912a1cf 100644 --- a/pkgs/by-name/so/soxt/package.nix +++ b/pkgs/by-name/so/soxt/package.nix @@ -1,4 +1,15 @@ -{ fetchhg, lib, stdenv, cmake, coin3d, motif, libXext, libXmu, libGLU, libGL }: +{ + fetchhg, + lib, + stdenv, + cmake, + coin3d, + motif, + libXext, + libXmu, + libGLU, + libGL, +}: stdenv.mkDerivation { pname = "soxt"; @@ -12,7 +23,14 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ coin3d motif libGLU libGL libXext libXmu ]; + buildInputs = [ + coin3d + motif + libGLU + libGL + libXext + libXmu + ]; meta = with lib; { homepage = "https://bitbucket.org/Coin3D/coin/wiki/Home"; diff --git a/pkgs/by-name/so/sozi/package.nix b/pkgs/by-name/so/sozi/package.nix index 612aa93cde2dfe..6492cb32e6c1bf 100644 --- a/pkgs/by-name/so/sozi/package.nix +++ b/pkgs/by-name/so/sozi/package.nix @@ -1,4 +1,8 @@ -{ appimageTools, lib, fetchurl }: +{ + appimageTools, + lib, + fetchurl, +}: let pname = "sozi"; version = "23.7.25-1690311612"; @@ -11,10 +15,15 @@ let appimageContents = appimageTools.extract { inherit version pname src; }; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; - extraPkgs = pkgs: with pkgs; [ polkit udev ]; + extraPkgs = + pkgs: with pkgs; [ + polkit + udev + ]; extraInstallCommands = '' install -m 444 -D ${appimageContents}/sozi.desktop -t $out/share/applications diff --git a/pkgs/by-name/so/sozu/package.nix b/pkgs/by-name/so/sozu/package.nix index ad09cf43dc8c81..0c79ce5a97ed46 100644 --- a/pkgs/by-name/so/sozu/package.nix +++ b/pkgs/by-name/so/sozu/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, darwin -, protobuf -, nix-update-script -, testers -, sozu +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + darwin, + protobuf, + nix-update-script, + testers, + sozu, }: rustPlatform.buildRustPackage rec { @@ -24,8 +25,7 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ protobuf ]; - buildInputs = - lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.Security; + buildInputs = lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.Security; doCheck = false; @@ -39,12 +39,14 @@ rustPlatform.buildRustPackage rec { }; meta = with lib; { - description = - "Open Source HTTP Reverse Proxy built in Rust for Immutable Infrastructures"; + description = "Open Source HTTP Reverse Proxy built in Rust for Immutable Infrastructures"; homepage = "https://www.sozu.io"; changelog = "https://github.com/sozu-proxy/sozu/releases/tag/${version}"; license = licenses.agpl3Only; - maintainers = with maintainers; [ Br1ght0ne gaelreyrol ]; + maintainers = with maintainers; [ + Br1ght0ne + gaelreyrol + ]; mainProgram = "sozu"; # error[E0432]: unresolved import `std::arch::x86_64` broken = !stdenv.hostPlatform.isx86_64; diff --git a/pkgs/by-name/sp/sp800-90b-entropyassessment/package.nix b/pkgs/by-name/sp/sp800-90b-entropyassessment/package.nix index fd15b68e9d4147..65387e27669974 100644 --- a/pkgs/by-name/sp/sp800-90b-entropyassessment/package.nix +++ b/pkgs/by-name/sp/sp800-90b-entropyassessment/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, bzip2 -, libdivsufsort -, jsoncpp -, openssl -, mpfr +{ + lib, + stdenv, + fetchFromGitHub, + bzip2, + libdivsufsort, + jsoncpp, + openssl, + mpfr, }: stdenv.mkDerivation (finalAttrs: { @@ -19,7 +20,13 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-qGJqL77IOuVx8jKDdOk4YkLPbggfn+TQtpdcYEu4hC8="; }; - buildInputs = [ bzip2 libdivsufsort jsoncpp openssl mpfr ]; + buildInputs = [ + bzip2 + libdivsufsort + jsoncpp + openssl + mpfr + ]; postPatch = '' substituteInPlace Makefile \ @@ -45,6 +52,9 @@ stdenv.mkDerivation (finalAttrs: { description = "Implementation of min-entropy assessment methods included in Special Publication 800-90B"; platforms = lib.platforms.linux; license = lib.licenses.nistSoftware; - maintainers = with lib.maintainers; [ orichter thillux ]; + maintainers = with lib.maintainers; [ + orichter + thillux + ]; }; }) diff --git a/pkgs/by-name/sp/spaceFM/package.nix b/pkgs/by-name/sp/spaceFM/package.nix index f7c7eac9a3a3fc..8f74c5efa2f34d 100644 --- a/pkgs/by-name/sp/spaceFM/package.nix +++ b/pkgs/by-name/sp/spaceFM/package.nix @@ -1,6 +1,22 @@ -{ pkgs, fetchFromGitHub, lib, stdenv, gtk3, udev, desktop-file-utils -, shared-mime-info, intltool, pkg-config, wrapGAppsHook3, ffmpegthumbnailer -, jmtpfs, ifuseSupport ? false, ifuse ? null, lsof, udisks2 }: +{ + pkgs, + fetchFromGitHub, + lib, + stdenv, + gtk3, + udev, + desktop-file-utils, + shared-mime-info, + intltool, + pkg-config, + wrapGAppsHook3, + ffmpegthumbnailer, + jmtpfs, + ifuseSupport ? false, + ifuse ? null, + lsof, + udisks2, +}: stdenv.mkDerivation rec { pname = "spacefm"; @@ -45,15 +61,25 @@ stdenv.mkDerivation rec { gappsWrapperArgs+=(--prefix XDG_DATA_DIRS : "${shared-mime-info}/share") ''; - nativeBuildInputs = [ pkg-config intltool ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; buildInputs = [ - gtk3 udev desktop-file-utils shared-mime-info - wrapGAppsHook3 ffmpegthumbnailer jmtpfs lsof udisks2 + gtk3 + udev + desktop-file-utils + shared-mime-info + wrapGAppsHook3 + ffmpegthumbnailer + jmtpfs + lsof + udisks2 ] ++ (lib.optionals ifuseSupport [ ifuse ]); # Introduced because ifuse doesn't build due to CVEs in libplist # Revert when libplist builds again… - meta = with lib; { + meta = with lib; { description = "Multi-panel tabbed file manager"; longDescription = '' Multi-panel tabbed file and desktop manager for Linux @@ -63,6 +89,9 @@ stdenv.mkDerivation rec { homepage = "http://ignorantguru.github.io/spacefm/"; platforms = platforms.linux; license = licenses.gpl3Plus; - maintainers = with maintainers; [ jagajaga obadz ]; + maintainers = with maintainers; [ + jagajaga + obadz + ]; }; } diff --git a/pkgs/by-name/sp/spacenav-cube-example/package.nix b/pkgs/by-name/sp/spacenav-cube-example/package.nix index c34828627b4e3e..a0262defe9ae1a 100644 --- a/pkgs/by-name/sp/spacenav-cube-example/package.nix +++ b/pkgs/by-name/sp/spacenav-cube-example/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, libspnav, libX11, mesa_glu }: +{ + stdenv, + lib, + libspnav, + libX11, + mesa_glu, +}: stdenv.mkDerivation { pname = "spacenav-cube-example"; @@ -6,7 +12,11 @@ stdenv.mkDerivation { sourceRoot = "${libspnav.src.name}/examples/cube"; - buildInputs = [ libX11 mesa_glu libspnav ]; + buildInputs = [ + libX11 + mesa_glu + libspnav + ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; diff --git a/pkgs/by-name/sp/spacer/package.nix b/pkgs/by-name/sp/spacer/package.nix index 5bf584c07a1447..c0b96db011ce48 100644 --- a/pkgs/by-name/sp/spacer/package.nix +++ b/pkgs/by-name/sp/spacer/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sp/spaceship-prompt/package.nix b/pkgs/by-name/sp/spaceship-prompt/package.nix index 2fe86fa4a73a00..e02a91f73a8c9c 100644 --- a/pkgs/by-name/sp/spaceship-prompt/package.nix +++ b/pkgs/by-name/sp/spaceship-prompt/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "spaceship-prompt"; @@ -35,6 +39,10 @@ stdenvNoCC.mkDerivation rec { changelog = "https://github.com/spaceship-prompt/spaceship-prompt/releases/tag/v${version}"; license = licenses.mit; platforms = platforms.unix; - maintainers = with maintainers; [ nyanloutre moni kyleondy ]; + maintainers = with maintainers; [ + nyanloutre + moni + kyleondy + ]; }; } diff --git a/pkgs/by-name/sp/spacevim/init.nix b/pkgs/by-name/sp/spacevim/init.nix index 7174e45c0b77ff..c99e37d8b39b54 100644 --- a/pkgs/by-name/sp/spacevim/init.nix +++ b/pkgs/by-name/sp/spacevim/init.nix @@ -1,10 +1,12 @@ # The Nix expression is a 1:1 mapping of the spacevim toml config which you can find on their website: spacevim.org/quick-start-guide/#configuration { - custom_plugins = [{ - merged = false; - name = "lilydjwg/colorizer"; - }]; + custom_plugins = [ + { + merged = false; + name = "lilydjwg/colorizer"; + } + ]; layers = [ { name = "default"; } { diff --git a/pkgs/by-name/sp/spamassassin/package.nix b/pkgs/by-name/sp/spamassassin/package.nix index 22d482d1bc64a2..790980da20753f 100644 --- a/pkgs/by-name/sp/spamassassin/package.nix +++ b/pkgs/by-name/sp/spamassassin/package.nix @@ -1,4 +1,19 @@ -{ lib, fetchurl, perlPackages, makeBinaryWrapper, gnupg, re2c, gcc, gnumake, libxcrypt, openssl, coreutils, poppler_utils, tesseract, iana-etc }: +{ + lib, + fetchurl, + perlPackages, + makeBinaryWrapper, + gnupg, + re2c, + gcc, + gnumake, + libxcrypt, + openssl, + coreutils, + poppler_utils, + tesseract, + iana-etc, +}: perlPackages.buildPerlPackage rec { pname = "SpamAssassin"; @@ -20,29 +35,58 @@ perlPackages.buildPerlPackage rec { ]; nativeBuildInputs = [ makeBinaryWrapper ]; - buildInputs = (with perlPackages; [ - HTMLParser NetCIDRLite NetDNS NetAddrIP DBFile HTTPDate MailDKIM LWP - LWPProtocolHttps IOSocketSSL DBI EncodeDetect IPCountry NetIdent - Razor2ClientAgent MailSPF NetDNSResolverProgrammable Socket6 - ArchiveZip EmailAddressXS NetLibIDN2 MaxMindDBReader GeoIP MailDMARC - MaxMindDBReaderXS - ]) ++ [ - openssl - ]; + buildInputs = + (with perlPackages; [ + HTMLParser + NetCIDRLite + NetDNS + NetAddrIP + DBFile + HTTPDate + MailDKIM + LWP + LWPProtocolHttps + IOSocketSSL + DBI + EncodeDetect + IPCountry + NetIdent + Razor2ClientAgent + MailSPF + NetDNSResolverProgrammable + Socket6 + ArchiveZip + EmailAddressXS + NetLibIDN2 + MaxMindDBReader + GeoIP + MailDMARC + MaxMindDBReaderXS + ]) + ++ [ + openssl + ]; - makeFlags = [ "PERL_BIN=${perlPackages.perl}/bin/perl" "ENABLE_SSL=yes" ]; + makeFlags = [ + "PERL_BIN=${perlPackages.perl}/bin/perl" + "ENABLE_SSL=yes" + ]; makeMakerFlags = [ "SYSCONFDIR=/etc LOCALSTATEDIR=/var/lib/spamassassin" ]; - checkInputs = (with perlPackages; [ - TextDiff # t/strip2.t - ]) ++ [ - coreutils # date, t/basic_meta.t - poppler_utils # pdftotext, t/extracttext.t - tesseract # tesseract, t/extracttext.t - iana-etc # t/dnsbl_subtests.t (/etc/protocols used by Net::DNS::Nameserver) - re2c gcc gnumake - ]; + checkInputs = + (with perlPackages; [ + TextDiff # t/strip2.t + ]) + ++ [ + coreutils # date, t/basic_meta.t + poppler_utils # pdftotext, t/extracttext.t + tesseract # tesseract, t/extracttext.t + iana-etc # t/dnsbl_subtests.t (/etc/protocols used by Net::DNS::Nameserver) + re2c + gcc + gnumake + ]; preCheck = '' substituteInPlace t/spamc_x_e.t \ --replace "/bin/echo" "${coreutils}/bin/echo" @@ -76,7 +120,14 @@ perlPackages.buildPerlPackage rec { # We don't inherit argv0 so that $^X works properly in e.g. sa-compile makeWrapper "${perlPackages.perl}/bin/perl" "$n" \ --add-flags "-T $perlFlags $orig" \ - --prefix PATH : ${lib.makeBinPath [ gnupg re2c gcc gnumake ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + gnupg + re2c + gcc + gnumake + ] + } \ --prefix C_INCLUDE_PATH : ${lib.makeSearchPathOutput "include" "include" [ libxcrypt ]} done ''; @@ -86,6 +137,9 @@ perlPackages.buildPerlPackage rec { description = "Open-Source Spam Filter"; license = lib.licenses.asl20; platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ qknight qyliss ]; + maintainers = with lib.maintainers; [ + qknight + qyliss + ]; }; } diff --git a/pkgs/by-name/sp/span-lite/package.nix b/pkgs/by-name/sp/span-lite/package.nix index d0a3cd15e7bba5..50940924f3ab59 100644 --- a/pkgs/by-name/sp/span-lite/package.nix +++ b/pkgs/by-name/sp/span-lite/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sp/sparkleshare/package.nix b/pkgs/by-name/sp/sparkleshare/package.nix index ef7da9d880bfbd..66682fd3ed618e 100644 --- a/pkgs/by-name/sp/sparkleshare/package.nix +++ b/pkgs/by-name/sp/sparkleshare/package.nix @@ -58,31 +58,37 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/sparkleshare \ - --set PATH ${symlinkJoin { - name = "mono-path"; - paths = [ - bash - coreutils - git - git-lfs - glib - mono - openssh - openssl - xdg-utils - ]; - }}/bin \ - --set MONO_GAC_PREFIX ${lib.concatStringsSep ":" [ - appindicator-sharp - gtk-sharp-3_0 - webkit2-sharp - ]} \ - --set LD_LIBRARY_PATH ${lib.makeLibraryPath [ - appindicator-sharp - gtk-sharp-3_0.gtk3 - webkit2-sharp - webkit2-sharp.webkitgtk - ]} + --set PATH ${ + symlinkJoin { + name = "mono-path"; + paths = [ + bash + coreutils + git + git-lfs + glib + mono + openssh + openssl + xdg-utils + ]; + } + }/bin \ + --set MONO_GAC_PREFIX ${ + lib.concatStringsSep ":" [ + appindicator-sharp + gtk-sharp-3_0 + webkit2-sharp + ] + } \ + --set LD_LIBRARY_PATH ${ + lib.makeLibraryPath [ + appindicator-sharp + gtk-sharp-3_0.gtk3 + webkit2-sharp + webkit2-sharp.webkitgtk + ] + } ''; meta = { diff --git a/pkgs/by-name/sp/sparrow3d/package.nix b/pkgs/by-name/sp/sparrow3d/package.nix index a502b6249a16c8..6a430bff6fe62a 100644 --- a/pkgs/by-name/sp/sparrow3d/package.nix +++ b/pkgs/by-name/sp/sparrow3d/package.nix @@ -1,21 +1,25 @@ -{ lib -, stdenv -, copyPkgconfigItems -, fetchFromGitHub -, makePkgconfigItem -, pkg-config -, SDL -, SDL_image -, SDL_mixer -, SDL_net -, SDL_ttf +{ + lib, + stdenv, + copyPkgconfigItems, + fetchFromGitHub, + makePkgconfigItem, + pkg-config, + SDL, + SDL_image, + SDL_mixer, + SDL_net, + SDL_ttf, }: stdenv.mkDerivation (finalAttrs: { pname = "sparrow3d"; version = "unstable-2020-10-06"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "theZiz"; diff --git a/pkgs/by-name/sp/sparsehash/package.nix b/pkgs/by-name/sp/sparsehash/package.nix index 813024623a1a7b..413884e6017eef 100644 --- a/pkgs/by-name/sp/sparsehash/package.nix +++ b/pkgs/by-name/sp/sparsehash/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "sparsehash"; diff --git a/pkgs/by-name/sp/spasm-ng/package.nix b/pkgs/by-name/sp/spasm-ng/package.nix index fac19ce6cd3298..db651ea8bb252c 100644 --- a/pkgs/by-name/sp/spasm-ng/package.nix +++ b/pkgs/by-name/sp/spasm-ng/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, gmp, gcc, openssl, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + gmp, + gcc, + openssl, + zlib, +}: stdenv.mkDerivation rec { pname = "spasm-ng"; @@ -13,8 +22,15 @@ stdenv.mkDerivation rec { }; # GCC is needed for Darwin - nativeBuildInputs = [ makeWrapper gcc ]; - buildInputs = [ gmp openssl zlib ]; + nativeBuildInputs = [ + makeWrapper + gcc + ]; + buildInputs = [ + gmp + openssl + zlib + ]; enableParallelBuilding = true; @@ -32,11 +48,11 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - homepage = "https://github.com/alberthdev/spasm-ng"; + homepage = "https://github.com/alberthdev/spasm-ng"; description = "Z80 assembler with extra features to support development for TI calculators"; mainProgram = "spasm"; - license = licenses.gpl2Plus; + license = licenses.gpl2Plus; maintainers = with maintainers; [ siraben ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/sp/spatial-shell/package.nix b/pkgs/by-name/sp/spatial-shell/package.nix index 4b741f8aaec2ba..1147698930ecd8 100644 --- a/pkgs/by-name/sp/spatial-shell/package.nix +++ b/pkgs/by-name/sp/spatial-shell/package.nix @@ -1,7 +1,8 @@ -{ lib -, ocamlPackages -, fetchFromGitHub -, scdoc +{ + lib, + ocamlPackages, + fetchFromGitHub, + scdoc, }: ocamlPackages.buildDunePackage rec { diff --git a/pkgs/by-name/sp/spatialite_tools/package.nix b/pkgs/by-name/sp/spatialite_tools/package.nix index 0b3f7f498f777a..ab23d29b84162d 100644 --- a/pkgs/by-name/sp/spatialite_tools/package.nix +++ b/pkgs/by-name/sp/spatialite_tools/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, freexl -, geos -, expat -, librttopo -, libspatialite -, libxml2 -, libz -, minizip -, proj -, readosm -, sqlite -, testers -, spatialite_tools +{ + lib, + stdenv, + fetchurl, + pkg-config, + freexl, + geos, + expat, + librttopo, + libspatialite, + libxml2, + libz, + minizip, + proj, + readosm, + sqlite, + testers, + spatialite_tools, }: stdenv.mkDerivation rec { @@ -53,7 +54,11 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Complete sqlite3-compatible CLI front-end for libspatialite"; homepage = "https://www.gaia-gis.it/fossil/spatialite-tools"; - license = with licenses; [ mpl11 gpl2Plus lgpl21Plus ]; + license = with licenses; [ + mpl11 + gpl2Plus + lgpl21Plus + ]; platforms = platforms.unix; maintainers = with maintainers; [ dotlambda ]; mainProgram = "spatialite_tool"; diff --git a/pkgs/by-name/sp/spawn_fcgi/package.nix b/pkgs/by-name/sp/spawn_fcgi/package.nix index e8232f90b96a17..1daf28bb0a17ef 100644 --- a/pkgs/by-name/sp/spawn_fcgi/package.nix +++ b/pkgs/by-name/sp/spawn_fcgi/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchsvn, autoconf, automake }: +{ + lib, + stdenv, + fetchsvn, + autoconf, + automake, +}: stdenv.mkDerivation rec { pname = "spawn-fcgi"; @@ -9,17 +15,20 @@ stdenv.mkDerivation rec { sha256 = "07r6nwbg4881mdgp0hqh80c4x9wb7jg6cgc84ghwhfbd2abc2iq5"; }; - nativeBuildInputs = [ automake autoconf ]; + nativeBuildInputs = [ + automake + autoconf + ]; preConfigure = '' ./autogen.sh ''; meta = with lib; { - homepage = "https://redmine.lighttpd.net/projects/spawn-fcgi"; + homepage = "https://redmine.lighttpd.net/projects/spawn-fcgi"; description = "Provides an interface to external programs that support the FastCGI interface"; mainProgram = "spawn-fcgi"; - license = licenses.bsd3; + license = licenses.bsd3; maintainers = [ ]; platforms = with platforms; unix; }; diff --git a/pkgs/by-name/sp/spdk/package.nix b/pkgs/by-name/sp/spdk/package.nix index b611792755062d..738779b2325b4b 100644 --- a/pkgs/by-name/sp/spdk/package.nix +++ b/pkgs/by-name/sp/spdk/package.nix @@ -1,23 +1,25 @@ -{ lib, stdenv -, fetchFromGitHub -, ncurses -, python3 -, cunit -, dpdk -, fuse3 -, libaio -, libbsd -, libuuid -, numactl -, openssl -, pkg-config -, zlib -, zstd -, libpcap -, libnl -, elfutils -, jansson -, ensureNewerSourcesForZipFilesHook +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + python3, + cunit, + dpdk, + fuse3, + libaio, + libbsd, + libuuid, + numactl, + openssl, + pkg-config, + zlib, + zstd, + libpcap, + libnl, + elfutils, + jansson, + ensureNewerSourcesForZipFilesHook, }: stdenv.mkDerivation rec { @@ -91,7 +93,7 @@ stdenv.mkDerivation rec { description = "Set of libraries for fast user-mode storage"; homepage = "https://spdk.io/"; license = licenses.bsd3; - platforms = [ "x86_64-linux" ]; + platforms = [ "x86_64-linux" ]; maintainers = with maintainers; [ orivej ]; }; } diff --git a/pkgs/by-name/sp/spdx-license-list-data/package.nix b/pkgs/by-name/sp/spdx-license-list-data/package.nix index 84ec81af951762..84f9dcbf661278 100644 --- a/pkgs/by-name/sp/spdx-license-list-data/package.nix +++ b/pkgs/by-name/sp/spdx-license-list-data/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchFromGitHub }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "spdx-license-list-data"; @@ -12,7 +16,17 @@ stdenvNoCC.mkDerivation rec { }; # List of file formats to package. - _types = [ "html" "json" "jsonld" "rdfa" "rdfnt" "rdfturtle" "rdfxml" "template" "text" ]; + _types = [ + "html" + "json" + "jsonld" + "rdfa" + "rdfnt" + "rdfturtle" + "rdfxml" + "template" + "text" + ]; outputs = [ "out" ] ++ _types; @@ -40,7 +54,10 @@ stdenvNoCC.mkDerivation rec { description = "Various data formats for the SPDX License List"; homepage = "https://github.com/spdx/license-list-data"; license = licenses.cc0; - maintainers = with maintainers; [ oxzi c0bw3b ]; + maintainers = with maintainers; [ + oxzi + c0bw3b + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/sp/speakersafetyd/package.nix b/pkgs/by-name/sp/speakersafetyd/package.nix index 9cac13c15bc574..d68654742dd97d 100644 --- a/pkgs/by-name/sp/speakersafetyd/package.nix +++ b/pkgs/by-name/sp/speakersafetyd/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, rustPlatform -, fetchCrate -, pkg-config -, alsa-lib -, rust +{ + stdenv, + lib, + rustPlatform, + fetchCrate, + pkg-config, + alsa-lib, + rust, }: rustPlatform.buildRustPackage rec { @@ -41,7 +42,10 @@ rustPlatform.buildRustPackage rec { description = "Userspace daemon written in Rust that implements an analogue of the Texas Instruments Smart Amp speaker protection model"; mainProgram = "speakersafetyd"; homepage = "https://github.com/AsahiLinux/speakersafetyd"; - maintainers = with maintainers; [ flokli yuka ]; + maintainers = with maintainers; [ + flokli + yuka + ]; license = licenses.mit; platforms = platforms.linux; }; diff --git a/pkgs/by-name/sp/specr-transpile/package.nix b/pkgs/by-name/sp/specr-transpile/package.nix index bb15e8c3fa3f56..56e6b46a15e2a5 100644 --- a/pkgs/by-name/sp/specr-transpile/package.nix +++ b/pkgs/by-name/sp/specr-transpile/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -18,7 +19,10 @@ rustPlatform.buildRustPackage rec { description = "Converts Specr lang code to Rust"; mainProgram = "specr-transpile"; homepage = "https://github.com/RalfJung/minirust-tooling"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/sp/spectmorph/package.nix b/pkgs/by-name/sp/spectmorph/package.nix index 8ae8001b6e5c00..2ba089063922f8 100644 --- a/pkgs/by-name/sp/spectmorph/package.nix +++ b/pkgs/by-name/sp/spectmorph/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, pkg-config, libjack2, lv2, glib, qt5, libao, cairo, libsndfile, fftwFloat }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libjack2, + lv2, + glib, + qt5, + libao, + cairo, + libsndfile, + fftwFloat, +}: stdenv.mkDerivation rec { pname = "spectmorph"; @@ -8,7 +21,16 @@ stdenv.mkDerivation rec { hash = "sha256-H/PaczAkjxeu2Q6S/jazZ0PU9oCmhBzsLgbGLusxXm8="; }; - buildInputs = [ libjack2 lv2 glib qt5.qtbase libao cairo libsndfile fftwFloat ]; + buildInputs = [ + libjack2 + lv2 + glib + qt5.qtbase + libao + cairo + libsndfile + fftwFloat + ]; nativeBuildInputs = [ pkg-config ]; @@ -18,7 +40,10 @@ stdenv.mkDerivation rec { description = "Allows to analyze samples of musical instruments, and to combine them (morphing) to construct hybrid sounds"; homepage = "https://spectmorph.org"; license = licenses.gpl3; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ maintainers.magnetophon ]; }; } diff --git a/pkgs/by-name/sp/spectra/package.nix b/pkgs/by-name/sp/spectra/package.nix index 4e4901d6c73dad..0cc351f13e2d2a 100644 --- a/pkgs/by-name/sp/spectra/package.nix +++ b/pkgs/by-name/sp/spectra/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, eigen +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + eigen, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sp/spectral-language-server/package.nix b/pkgs/by-name/sp/spectral-language-server/package.nix index 3a6ac22184ef2b..9efbb3196eb40d 100644 --- a/pkgs/by-name/sp/spectral-language-server/package.nix +++ b/pkgs/by-name/sp/spectral-language-server/package.nix @@ -1,12 +1,13 @@ -{ lib -, buildNpmPackage -, stdenv -, fetchYarnDeps -, yarnConfigHook -, fetchFromGitHub -, typescript -, jq -, fetchpatch +{ + lib, + buildNpmPackage, + stdenv, + fetchYarnDeps, + yarnConfigHook, + fetchFromGitHub, + typescript, + jq, + fetchpatch, }: let # Instead of the build script that spectral-language-server provides (ref: https://github.com/luizcorreia/spectral-language-server/blob/master/script/vscode-spectral-build.sh), we build vscode-spectral manually. @@ -27,7 +28,11 @@ let hash = "sha256-am27A9VyFoXuOlgG9mnvNqV3Q7Bi7GJzDqqVFGDVWIA="; }; - nativeBuildInputs = [ typescript jq yarnConfigHook ]; + nativeBuildInputs = [ + typescript + jq + yarnConfigHook + ]; postPatch = '' cp server/tsconfig.json server/tsconfig.json.bak diff --git a/pkgs/by-name/sp/spectre-cli/package.nix b/pkgs/by-name/sp/spectre-cli/package.nix index ba63b823e73993..bafb0a70f6ca96 100644 --- a/pkgs/by-name/sp/spectre-cli/package.nix +++ b/pkgs/by-name/sp/spectre-cli/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitLab -, cmake -, libsodium -, json_c -, ncurses -, libxml2 -, jq +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + libsodium, + json_c, + ncurses, + libxml2, + jq, }: stdenv.mkDerivation rec { @@ -38,10 +39,10 @@ stdenv.mkDerivation rec { ]; preConfigure = '' - echo "${version}" > VERSION + echo "${version}" > VERSION - # The default buildPhase wants to create a ´build´ dir so we rename the build script to stop conflicts. - mv build build.sh + # The default buildPhase wants to create a ´build´ dir so we rename the build script to stop conflicts. + mv build build.sh ''; # Some tests are expected to fail on ARM64 diff --git a/pkgs/by-name/sp/spectre-meltdown-checker/package.nix b/pkgs/by-name/sp/spectre-meltdown-checker/package.nix index 55372ce4a6aa0c..976647ff3e2591 100644 --- a/pkgs/by-name/sp/spectre-meltdown-checker/package.nix +++ b/pkgs/by-name/sp/spectre-meltdown-checker/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeBinaryWrapper -, coreutils -, binutils-unwrapped +{ + lib, + stdenv, + fetchFromGitHub, + makeBinaryWrapper, + coreutils, + binutils-unwrapped, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sp/spectrojack/package.nix b/pkgs/by-name/sp/spectrojack/package.nix index 92ac92af7e9a31..c3346f675d40fe 100644 --- a/pkgs/by-name/sp/spectrojack/package.nix +++ b/pkgs/by-name/sp/spectrojack/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, libjack2, fftwFloat, gtk2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libjack2, + fftwFloat, + gtk2, +}: stdenv.mkDerivation rec { pname = "spectrojack"; @@ -9,13 +17,17 @@ stdenv.mkDerivation rec { sha256 = "1kiwx0kag7kq7rhg0bvckfm8r7pqmbk76ppa39cq2980jb5v8rfp"; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libjack2 fftwFloat gtk2 ]; - configurePhase= '' + buildInputs = [ + libjack2 + fftwFloat + gtk2 + ]; + configurePhase = '' sed -i 's/.*home.*/#&/' ./Makefile substituteInPlace ./Makefile \ --replace "/usr/share" "$out/usr/share" ''; - installPhase= '' + installPhase = '' install -Dm755 spectrojack $out/bin/spectrojack install -Dm644 spectrojack_icon.svg $out/usr/share/spectrojack/icon.svg install -Dm644 -t $out/usr/share/spectrojack/colormaps colormaps/* diff --git a/pkgs/by-name/sp/spectrwm/package.nix b/pkgs/by-name/sp/spectrwm/package.nix index 52b413452e8273..09c5b19b7cedca 100644 --- a/pkgs/by-name/sp/spectrwm/package.nix +++ b/pkgs/by-name/sp/spectrwm/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, libbsd, pkg-config, xorg }: +{ + lib, + stdenv, + fetchFromGitHub, + libbsd, + pkg-config, + xorg, +}: stdenv.mkDerivation (finalAttrs: { pname = "spectrwm"; @@ -7,33 +14,39 @@ stdenv.mkDerivation (finalAttrs: { src = fetchFromGitHub { owner = "conformal"; repo = "spectrwm"; - rev = "SPECTRWM_${lib.replaceStrings ["."] ["_"] finalAttrs.version}"; + rev = "SPECTRWM_${lib.replaceStrings [ "." ] [ "_" ] finalAttrs.version}"; hash = "sha256-Dnn/iIrceiAVuMR8iMGcc7LqNhWC496eT5gNrYOInRU="; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = (with xorg; [ - libXrandr - libXcursor - libXft - libXt - xcbutil - xcbutilkeysyms - xcbutilwm - ] ++ [ libbsd ]); - - prePatch = let - subdir = if stdenv.hostPlatform.isDarwin then "osx" else "linux"; - in "cd ${subdir}"; + buildInputs = ( + with xorg; + [ + libXrandr + libXcursor + libXft + libXt + xcbutil + xcbutilkeysyms + xcbutilwm + ] + ++ [ libbsd ] + ); + + prePatch = + let + subdir = if stdenv.hostPlatform.isDarwin then "osx" else "linux"; + in + "cd ${subdir}"; makeFlags = [ "PREFIX=${placeholder "out"}" ]; meta = with lib; { description = "Tiling window manager"; - homepage = "https://github.com/conformal/spectrwm"; + homepage = "https://github.com/conformal/spectrwm"; maintainers = with maintainers; [ rake5k ]; - license = licenses.isc; - platforms = platforms.all; + license = licenses.isc; + platforms = platforms.all; longDescription = '' spectrwm is a small dynamic tiling window manager for X11. It diff --git a/pkgs/by-name/sp/speech-denoiser/package.nix b/pkgs/by-name/sp/speech-denoiser/package.nix index a0c3d2d257061f..427b53abfec421 100644 --- a/pkgs/by-name/sp/speech-denoiser/package.nix +++ b/pkgs/by-name/sp/speech-denoiser/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, lv2, meson, ninja }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + lv2, + meson, + ninja, +}: let speech-denoiser-src = fetchFromGitHub { @@ -14,18 +23,30 @@ let src = speech-denoiser-src; sourceRoot = "${speech-denoiser-src.name}/rnnoise"; nativeBuildInputs = [ autoreconfHook ]; - configureFlags = [ "--disable-examples" "--disable-doc" "--disable-shared" "--enable-static" ]; + configureFlags = [ + "--disable-examples" + "--disable-doc" + "--disable-shared" + "--enable-static" + ]; installTargets = [ "install-rnnoise-nu" ]; }; in -stdenv.mkDerivation { +stdenv.mkDerivation { pname = "speech-denoiser"; version = "unstable-07-10-2019"; src = speech-denoiser-src; - nativeBuildInputs = [ pkg-config meson ninja ]; - buildInputs = [ lv2 rnnoise-nu ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + ]; + buildInputs = [ + lv2 + rnnoise-nu + ]; mesonFlags = [ "--prefix=${placeholder "out"}/lib/lv2" ]; diff --git a/pkgs/by-name/sp/speechd/package.nix b/pkgs/by-name/sp/speechd/package.nix index b0472e1b004ab6..58bee929bfab1c 100644 --- a/pkgs/by-name/sp/speechd/package.nix +++ b/pkgs/by-name/sp/speechd/package.nix @@ -1,32 +1,42 @@ -{ stdenv -, lib -, substituteAll -, pkg-config -, fetchurl -, python3Packages -, gettext -, itstool -, libtool -, texinfo -, util-linux -, autoreconfHook -, glib -, dotconf -, libsndfile -, withLibao ? true, libao -, withPulse ? false, libpulseaudio -, withAlsa ? false, alsa-lib -, withOss ? false -, withFlite ? true, flite -, withEspeak ? true, espeak, sonic, pcaudiolib -, mbrola -, withPico ? true, svox -, libsOnly ? false +{ + stdenv, + lib, + substituteAll, + pkg-config, + fetchurl, + python3Packages, + gettext, + itstool, + libtool, + texinfo, + util-linux, + autoreconfHook, + glib, + dotconf, + libsndfile, + withLibao ? true, + libao, + withPulse ? false, + libpulseaudio, + withAlsa ? false, + alsa-lib, + withOss ? false, + withFlite ? true, + flite, + withEspeak ? true, + espeak, + sonic, + pcaudiolib, + mbrola, + withPico ? true, + svox, + libsOnly ? false, }: let inherit (python3Packages) python pyxdg wrapPython; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "speech-dispatcher"; version = "0.11.5"; @@ -35,18 +45,20 @@ in stdenv.mkDerivation rec { sha256 = "sha256-HOR1n/q7rxrrQzpewHOb4Gdum9+66URKezvhsq8+wSs="; }; - patches = [ - (substituteAll { - src = ./fix-paths.patch; - utillinux = util-linux; - }) - ] ++ lib.optionals (withEspeak && espeak.mbrolaSupport) [ - # Replace FHS paths. - (substituteAll { - src = ./fix-mbrola-paths.patch; - inherit espeak mbrola; - }) - ]; + patches = + [ + (substituteAll { + src = ./fix-paths.patch; + utillinux = util-linux; + }) + ] + ++ lib.optionals (withEspeak && espeak.mbrolaSupport) [ + # Replace FHS paths. + (substituteAll { + src = ./fix-mbrola-paths.patch; + inherit espeak mbrola; + }) + ]; nativeBuildInputs = [ pkg-config @@ -58,60 +70,76 @@ in stdenv.mkDerivation rec { wrapPython ]; - buildInputs = [ - glib - dotconf - libsndfile - libao - libpulseaudio - alsa-lib - python - ] ++ lib.optionals withEspeak [ - espeak - sonic - pcaudiolib - ] ++ lib.optionals withFlite [ - flite - ] ++ lib.optionals withPico [ - svox - ]; + buildInputs = + [ + glib + dotconf + libsndfile + libao + libpulseaudio + alsa-lib + python + ] + ++ lib.optionals withEspeak [ + espeak + sonic + pcaudiolib + ] + ++ lib.optionals withFlite [ + flite + ] + ++ lib.optionals withPico [ + svox + ]; pythonPath = [ pyxdg ]; - configureFlags = [ - # Audio method falls back from left to right. - "--with-default-audio-method=\"libao,pulse,alsa,oss\"" - "--with-systemdsystemunitdir=${placeholder "out"}/lib/systemd/system" - ] ++ lib.optionals withPulse [ - "--with-pulse" - ] ++ lib.optionals withAlsa [ - "--with-alsa" - ] ++ lib.optionals withLibao [ - "--with-libao" - ] ++ lib.optionals withOss [ - "--with-oss" - ] ++ lib.optionals withEspeak [ - "--with-espeak-ng" - ] ++ lib.optionals withPico [ - "--with-pico" - ]; + configureFlags = + [ + # Audio method falls back from left to right. + "--with-default-audio-method=\"libao,pulse,alsa,oss\"" + "--with-systemdsystemunitdir=${placeholder "out"}/lib/systemd/system" + ] + ++ lib.optionals withPulse [ + "--with-pulse" + ] + ++ lib.optionals withAlsa [ + "--with-alsa" + ] + ++ lib.optionals withLibao [ + "--with-libao" + ] + ++ lib.optionals withOss [ + "--with-oss" + ] + ++ lib.optionals withEspeak [ + "--with-espeak-ng" + ] + ++ lib.optionals withPico [ + "--with-pico" + ]; postPatch = '' substituteInPlace src/modules/pico.c --replace "/usr/share/pico/lang" "${svox}/share/pico/lang" ''; - postInstall = if libsOnly then '' - rm -rf $out/{bin,etc,lib/speech-dispatcher,lib/systemd,libexec,share} - '' else '' - wrapPythonPrograms - ''; + postInstall = + if libsOnly then + '' + rm -rf $out/{bin,etc,lib/speech-dispatcher,lib/systemd,libexec,share} + '' + else + '' + wrapPythonPrograms + ''; enableParallelBuilding = true; meta = with lib; { - description = "Common interface to speech synthesis" + lib.optionalString libsOnly " - client libraries only"; + description = + "Common interface to speech synthesis" + lib.optionalString libsOnly " - client libraries only"; homepage = "https://devel.freebsoft.org/speechd"; license = licenses.gpl2Plus; maintainers = with maintainers; [ diff --git a/pkgs/by-name/sp/speedread/package.nix b/pkgs/by-name/sp/speedread/package.nix index e62edf48cbadc9..ac277bdf09b667 100644 --- a/pkgs/by-name/sp/speedread/package.nix +++ b/pkgs/by-name/sp/speedread/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation rec { pname = "speedread"; diff --git a/pkgs/by-name/sp/speedtest-rs/package.nix b/pkgs/by-name/sp/speedtest-rs/package.nix index 322d735e645ad2..9087e43d3059b3 100644 --- a/pkgs/by-name/sp/speedtest-rs/package.nix +++ b/pkgs/by-name/sp/speedtest-rs/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, openssl -, pkg-config -, stdenv -, darwin -, nix-update-script -, testers -, speedtest-rs +{ + lib, + rustPlatform, + fetchFromGitHub, + openssl, + pkg-config, + stdenv, + darwin, + nix-update-script, + testers, + speedtest-rs, }: rustPlatform.buildRustPackage rec { @@ -21,8 +22,9 @@ rustPlatform.buildRustPackage rec { hash = "sha256-1FAFYiWDD/KG/7/UTv/EW6Nj2GnU0GZFFq6ouMc0URA="; }; - buildInputs = [ openssl ] ++ - lib.optionals stdenv.hostPlatform.isDarwin [ + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Security darwin.apple_sdk.frameworks.SystemConfiguration ]; @@ -46,7 +48,10 @@ rustPlatform.buildRustPackage rec { description = "Command line internet speedtest tool written in rust"; homepage = "https://github.com/nelsonjchen/speedtest-rs"; changelog = "https://github.com/nelsonjchen/speedtest-rs/blob/v${version}/CHANGELOG.md"; - license = with lib.licenses; [ mit asl20 ]; + license = with lib.licenses; [ + mit + asl20 + ]; maintainers = with lib.maintainers; [ GaetanLepage ]; mainProgram = "speedtest-rs"; }; diff --git a/pkgs/by-name/sp/spfft/package.nix b/pkgs/by-name/sp/spfft/package.nix index 9423978ed24ef9..1045173353b3a8 100644 --- a/pkgs/by-name/sp/spfft/package.nix +++ b/pkgs/by-name/sp/spfft/package.nix @@ -1,24 +1,30 @@ -{ stdenv -, lib -, fetchFromGitHub -, fftw -, cmake -, mpi -, gfortran -, llvmPackages -, cudaPackages -, rocmPackages -, config -, gpuBackend ? ( - if config.cudaSupport - then "cuda" - else if config.rocmSupport - then "rocm" - else "none" -) +{ + stdenv, + lib, + fetchFromGitHub, + fftw, + cmake, + mpi, + gfortran, + llvmPackages, + cudaPackages, + rocmPackages, + config, + gpuBackend ? ( + if config.cudaSupport then + "cuda" + else if config.rocmSupport then + "rocm" + else + "none" + ), }: -assert builtins.elem gpuBackend [ "none" "cuda" "rocm" ]; +assert builtins.elem gpuBackend [ + "none" + "cuda" + "rocm" +]; stdenv.mkDerivation rec { pname = "SpFFT"; @@ -34,36 +40,39 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake gfortran - ] ++ lib.optional (gpuBackend == "cuda") cudaPackages.cuda_nvcc; + ] ++ lib.optional (gpuBackend == "cuda") cudaPackages.cuda_nvcc; - buildInputs = [ - fftw - mpi - ] ++ lib.optionals (gpuBackend == "cuda") [ - cudaPackages.libcufft - cudaPackages.cuda_cudart - ] ++ lib.optionals (gpuBackend == "rocm") [ - rocmPackages.clr - rocmPackages.rocfft - rocmPackages.hipfft - ] ++ lib.optional stdenv.hostPlatform.isDarwin llvmPackages.openmp - ; - - cmakeFlags = [ - "-DSPFFT_OMP=ON" - "-DSPFFT_MPI=ON" - "-DSPFFT_SINGLE_PRECISION=OFF" - "-DSPFFT_FORTRAN=ON" - # Required due to broken CMake files - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] - ++ lib.optional (gpuBackend == "cuda") "-DSPFFT_GPU_BACKEND=CUDA" - ++ lib.optionals (gpuBackend == "rocm") [ - "-DSPFFT_GPU_BACKEND=ROCM" - "-DHIP_ROOT_DIR=${rocmPackages.clr}" - ]; + buildInputs = + [ + fftw + mpi + ] + ++ lib.optionals (gpuBackend == "cuda") [ + cudaPackages.libcufft + cudaPackages.cuda_cudart + ] + ++ lib.optionals (gpuBackend == "rocm") [ + rocmPackages.clr + rocmPackages.rocfft + rocmPackages.hipfft + ] + ++ lib.optional stdenv.hostPlatform.isDarwin llvmPackages.openmp; + cmakeFlags = + [ + "-DSPFFT_OMP=ON" + "-DSPFFT_MPI=ON" + "-DSPFFT_SINGLE_PRECISION=OFF" + "-DSPFFT_FORTRAN=ON" + # Required due to broken CMake files + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optional (gpuBackend == "cuda") "-DSPFFT_GPU_BACKEND=CUDA" + ++ lib.optionals (gpuBackend == "rocm") [ + "-DSPFFT_GPU_BACKEND=ROCM" + "-DHIP_ROOT_DIR=${rocmPackages.clr}" + ]; meta = with lib; { description = "Sparse 3D FFT library with MPI, OpenMP, CUDA and ROCm support"; diff --git a/pkgs/by-name/sp/sphinxsearch/package.nix b/pkgs/by-name/sp/sphinxsearch/package.nix index 58887c5ef5e3df..6b60200ec4a1e3 100644 --- a/pkgs/by-name/sp/sphinxsearch/package.nix +++ b/pkgs/by-name/sp/sphinxsearch/package.nix @@ -1,6 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, expat, libmysqlclient, +{ + lib, + stdenv, + fetchurl, + pkg-config, + expat, + libmysqlclient, enableXmlpipe2 ? false, - enableMysql ? true + enableMysql ? true, }: stdenv.mkDerivation rec { @@ -14,30 +20,37 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - configureFlags = [ - "--program-prefix=sphinxsearch-" - "--enable-id64" - ] ++ lib.optionals (!enableMysql) [ - "--without-mysql" - ]; + configureFlags = + [ + "--program-prefix=sphinxsearch-" + "--enable-id64" + ] + ++ lib.optionals (!enableMysql) [ + "--without-mysql" + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = lib.optionals enableMysql [ - libmysqlclient - ] ++ lib.optionals enableXmlpipe2 [ - expat - ]; + buildInputs = + lib.optionals enableMysql [ + libmysqlclient + ] + ++ lib.optionals enableXmlpipe2 [ + expat + ]; CXXFLAGS = "-std=c++98"; meta = { description = "Open source full text search server"; - homepage = "http://sphinxsearch.com"; - license = lib.licenses.gpl2Plus; - platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ ederoyd46 valodim ]; + homepage = "http://sphinxsearch.com"; + license = lib.licenses.gpl2Plus; + platforms = lib.platforms.all; + maintainers = with lib.maintainers; [ + ederoyd46 + valodim + ]; }; } diff --git a/pkgs/by-name/sp/spice-autorandr/package.nix b/pkgs/by-name/sp/spice-autorandr/package.nix index 4e3ba971fd02ae..a4f50b8a4a0593 100644 --- a/pkgs/by-name/sp/spice-autorandr/package.nix +++ b/pkgs/by-name/sp/spice-autorandr/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, autoreconfHook -, libX11 -, libXrandr +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + libX11, + libXrandr, }: -stdenv.mkDerivation { +stdenv.mkDerivation { pname = "spice-autorandr"; version = "0.0.2"; @@ -18,8 +19,14 @@ stdenv.mkDerivation { hash = "sha256-eBvzalWT3xI8+uNns0/ZyRes91ePpj0beKb8UBVqo0E="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libX11 libXrandr ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libX11 + libXrandr + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/sp/spice-gtk/package.nix b/pkgs/by-name/sp/spice-gtk/package.nix index 048ba14f5f9372..182946d721bf16 100644 --- a/pkgs/by-name/sp/spice-gtk/package.nix +++ b/pkgs/by-name/sp/spice-gtk/package.nix @@ -1,43 +1,44 @@ -{ lib -, stdenv -, fetchurl -, acl -, cyrus_sasl -, docbook_xsl -, libepoxy -, gettext -, gobject-introspection -, gst_all_1 -, gtk-doc -, gtk3 -, hwdata -, json-glib -, libcacard -, libcap_ng -, libdrm -, libjpeg_turbo -, libopus -, libsoup_3 -, libusb1 -, lz4 -, meson -, mesonEmulatorHook -, ninja -, openssl -, perl -, phodav -, pixman -, pkg-config -, polkit -, python3 -, spice-protocol -, usbredir -, vala -, wayland-protocols -, wayland-scanner -, zlib -, wrapGAppsHook3 -, withPolkit ? stdenv.hostPlatform.isLinux +{ + lib, + stdenv, + fetchurl, + acl, + cyrus_sasl, + docbook_xsl, + libepoxy, + gettext, + gobject-introspection, + gst_all_1, + gtk-doc, + gtk3, + hwdata, + json-glib, + libcacard, + libcap_ng, + libdrm, + libjpeg_turbo, + libopus, + libsoup_3, + libusb1, + lz4, + meson, + mesonEmulatorHook, + ninja, + openssl, + perl, + phodav, + pixman, + pkg-config, + polkit, + python3, + spice-protocol, + usbredir, + vala, + wayland-protocols, + wayland-scanner, + zlib, + wrapGAppsHook3, + withPolkit ? stdenv.hostPlatform.isLinux, }: # If this package is built with polkit support (withPolkit=true), @@ -65,7 +66,12 @@ stdenv.mkDerivation rec { pname = "spice-gtk"; version = "0.42"; - outputs = [ "out" "dev" "devdoc" "man" ]; + outputs = [ + "out" + "dev" + "devdoc" + "man" + ]; src = fetchurl { url = "https://www.spice-space.org/download/gtk/${pname}-${version}.tar.xz"; @@ -76,68 +82,78 @@ stdenv.mkDerivation rec { pkg-config ]; - nativeBuildInputs = [ - docbook_xsl - gettext - gobject-introspection - gtk-doc - meson - ninja - perl - pkg-config - python3 - python3.pkgs.pyparsing - python3.pkgs.six - vala - wrapGAppsHook3 - ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ - mesonEmulatorHook - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - wayland-scanner - ]; + nativeBuildInputs = + [ + docbook_xsl + gettext + gobject-introspection + gtk-doc + meson + ninja + perl + pkg-config + python3 + python3.pkgs.pyparsing + python3.pkgs.six + vala + wrapGAppsHook3 + ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + mesonEmulatorHook + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + wayland-scanner + ]; - buildInputs = [ - gst_all_1.gst-plugins-base - gst_all_1.gst-plugins-good - cyrus_sasl - libepoxy - gtk3 - json-glib - libcacard - libjpeg_turbo - libopus - libsoup_3 - libusb1 - lz4 - openssl - phodav - pixman - spice-protocol - usbredir - vala - zlib - ] ++ lib.optionals withPolkit [ - polkit - acl - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libcap_ng - libdrm - wayland-protocols - ]; + buildInputs = + [ + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-good + cyrus_sasl + libepoxy + gtk3 + json-glib + libcacard + libjpeg_turbo + libopus + libsoup_3 + libusb1 + lz4 + openssl + phodav + pixman + spice-protocol + usbredir + vala + zlib + ] + ++ lib.optionals withPolkit [ + polkit + acl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libcap_ng + libdrm + wayland-protocols + ]; PKG_CONFIG_POLKIT_GOBJECT_1_POLICYDIR = "${placeholder "out"}/share/polkit-1/actions"; - mesonFlags = [ - "-Dusb-acl-helper-dir=${placeholder "out"}/bin" - "-Dusb-ids-path=${hwdata}/share/hwdata/usb.ids" - ] ++ lib.optionals (!withPolkit) [ - "-Dpolkit=disabled" - ] ++ lib.optionals (!stdenv.hostPlatform.isLinux) [ - "-Dlibcap-ng=disabled" - "-Degl=disabled" - ] ++ lib.optionals stdenv.hostPlatform.isMusl [ - "-Dcoroutine=gthread" # Fixes "Function missing:makecontext" - ]; + mesonFlags = + [ + "-Dusb-acl-helper-dir=${placeholder "out"}/bin" + "-Dusb-ids-path=${hwdata}/share/hwdata/usb.ids" + ] + ++ lib.optionals (!withPolkit) [ + "-Dpolkit=disabled" + ] + ++ lib.optionals (!stdenv.hostPlatform.isLinux) [ + "-Dlibcap-ng=disabled" + "-Degl=disabled" + ] + ++ lib.optionals stdenv.hostPlatform.isMusl [ + "-Dcoroutine=gthread" # Fixes "Function missing:makecontext" + ]; postPatch = '' # get rid of absolute path to helper in store so we can use a setuid wrapper diff --git a/pkgs/by-name/sp/spice-protocol/package.nix b/pkgs/by-name/sp/spice-protocol/package.nix index d7800859d057a4..a249a4ce38d8b6 100644 --- a/pkgs/by-name/sp/spice-protocol/package.nix +++ b/pkgs/by-name/sp/spice-protocol/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, meson, ninja }: +{ + lib, + stdenv, + fetchurl, + meson, + ninja, +}: stdenv.mkDerivation rec { pname = "spice-protocol"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-BP+6YQ2f1EHPxH36oTXXAJbmCxBG0hGdjbL46g0X2RI="; }; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; postInstall = '' mkdir -p $out/lib diff --git a/pkgs/by-name/sp/spice-up/package.nix b/pkgs/by-name/sp/spice-up/package.nix index ca99f88fa57b6a..48b1bce684c3dc 100644 --- a/pkgs/by-name/sp/spice-up/package.nix +++ b/pkgs/by-name/sp/spice-up/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, python3 -, vala -, wrapGAppsHook3 -, glib -, gtk3 -, json-glib -, libevdev -, libgee -, libgudev -, libsoup_2_4 -, pantheon +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + python3, + vala, + wrapGAppsHook3, + glib, + gtk3, + json-glib, + libevdev, + libgee, + libgudev, + libsoup_2_4, + pantheon, }: stdenv.mkDerivation rec { @@ -61,7 +62,13 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Create simple and beautiful presentations"; homepage = "https://github.com/Philip-Scott/Spice-up"; - maintainers = with maintainers; [ samdroid-apps xiorcale ] ++ teams.pantheon.members; + maintainers = + with maintainers; + [ + samdroid-apps + xiorcale + ] + ++ teams.pantheon.members; platforms = platforms.linux; # The COPYING file has GPLv3; some files have GPLv2+ and some have GPLv3+ license = licenses.gpl3Plus; diff --git a/pkgs/by-name/sp/spice-vdagent/package.nix b/pkgs/by-name/sp/spice-vdagent/package.nix index 3911e1882ccbbc..c8fc1a520f559e 100644 --- a/pkgs/by-name/sp/spice-vdagent/package.nix +++ b/pkgs/by-name/sp/spice-vdagent/package.nix @@ -1,6 +1,20 @@ -{lib, stdenv, fetchurl, pkg-config, alsa-lib, spice-protocol, glib, - libpciaccess, libxcb, libXrandr, libXinerama, libXfixes, dbus, libdrm, - systemd}: +{ + lib, + stdenv, + fetchurl, + pkg-config, + alsa-lib, + spice-protocol, + glib, + libpciaccess, + libxcb, + libXrandr, + libXinerama, + libXfixes, + dbus, + libdrm, + systemd, +}: stdenv.mkDerivation rec { pname = "spice-vdagent"; version = "0.22.1"; @@ -13,18 +27,28 @@ stdenv.mkDerivation rec { substituteInPlace data/spice-vdagent.desktop --replace /usr $out ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ alsa-lib spice-protocol glib libdrm - libpciaccess libxcb libXrandr libXinerama libXfixes - dbus systemd ] ; + buildInputs = [ + alsa-lib + spice-protocol + glib + libdrm + libpciaccess + libxcb + libXrandr + libXinerama + libXfixes + dbus + systemd + ]; meta = { description = "Enhanced SPICE integration for linux QEMU guest"; longDescription = '' - Spice agent for linux guests offering - * Client mouse mode - * Copy and paste - * Automatic adjustment of the X-session resolution - to the client resolution - * Multiple displays + Spice agent for linux guests offering + * Client mouse mode + * Copy and paste + * Automatic adjustment of the X-session resolution + to the client resolution + * Multiple displays ''; homepage = "https://www.spice-space.org/"; license = lib.licenses.gpl3Plus; diff --git a/pkgs/by-name/sp/spice/package.nix b/pkgs/by-name/sp/spice/package.nix index 4ac1b1cdee11c0..d3a4c9df6a08e7 100644 --- a/pkgs/by-name/sp/spice/package.nix +++ b/pkgs/by-name/sp/spice/package.nix @@ -1,28 +1,30 @@ -{ lib, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, pixman -, alsa-lib -, openssl -, libXrandr -, libXfixes -, libXext -, libXrender -, libXinerama -, libjpeg -, zlib -, spice-protocol -, python3 -, glib -, cyrus_sasl -, libcacard -, lz4 -, libopus -, gst_all_1 -, orc -, gdk-pixbuf +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + pixman, + alsa-lib, + openssl, + libXrandr, + libXfixes, + libXext, + libXrender, + libXinerama, + libjpeg, + zlib, + spice-protocol, + python3, + glib, + cyrus_sasl, + libcacard, + lz4, + libopus, + gst_all_1, + orc, + gdk-pixbuf, }: stdenv.mkDerivation rec { @@ -48,30 +50,33 @@ stdenv.mkDerivation rec { python3.pkgs.pyparsing ]; - buildInputs = [ - cyrus_sasl - glib - gst_all_1.gst-plugins-base - libXext - libXfixes - libXinerama - libXrandr - libXrender - libcacard - libjpeg - libopus - lz4 - openssl - orc - pixman - python3.pkgs.pyparsing - spice-protocol - zlib - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - gdk-pixbuf - ]; + buildInputs = + [ + cyrus_sasl + glib + gst_all_1.gst-plugins-base + libXext + libXfixes + libXinerama + libXrandr + libXrender + libcacard + libjpeg + libopus + lz4 + openssl + orc + pixman + python3.pkgs.pyparsing + spice-protocol + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + gdk-pixbuf + ]; env.NIX_CFLAGS_COMPILE = "-fno-stack-protector"; @@ -102,7 +107,10 @@ stdenv.mkDerivation rec { homepage = "https://www.spice-space.org/"; license = licenses.lgpl21; - maintainers = with maintainers; [ bluescreen303 atemu ]; + maintainers = with maintainers; [ + bluescreen303 + atemu + ]; platforms = with platforms; linux ++ darwin; }; } diff --git a/pkgs/by-name/sp/spicy-parser-generator/package.nix b/pkgs/by-name/sp/spicy-parser-generator/package.nix index 6199fad8e63769..d578353f064b20 100644 --- a/pkgs/by-name/sp/spicy-parser-generator/package.nix +++ b/pkgs/by-name/sp/spicy-parser-generator/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, makeWrapper -, python3 -, bison -, flex -, zlib -, apple-sdk_11 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + makeWrapper, + python3, + bison, + flex, + zlib, + apple-sdk_11, }: stdenv.mkDerivation rec { @@ -32,12 +33,14 @@ stdenv.mkDerivation rec { python3 ]; - buildInputs = [ - flex - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - apple-sdk_11 - ]; + buildInputs = + [ + flex + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + apple-sdk_11 + ]; postPatch = '' patchShebangs scripts tests/scripts @@ -49,7 +52,12 @@ stdenv.mkDerivation rec { preFixup = '' for b in $out/bin/* - do wrapProgram "$b" --prefix PATH : "${lib.makeBinPath [ bison flex ]}" + do wrapProgram "$b" --prefix PATH : "${ + lib.makeBinPath [ + bison + flex + ] + }" done ''; diff --git a/pkgs/by-name/sp/spicy/package.nix b/pkgs/by-name/sp/spicy/package.nix index 369747f0d571ad..76db7502048137 100644 --- a/pkgs/by-name/sp/spicy/package.nix +++ b/pkgs/by-name/sp/spicy/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "spicy"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-uy33vfsvyLCep1aN8qO0BMmpPylhzTLhosjjD5ghmHE="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Nintendo 64 segment assembler"; diff --git a/pkgs/by-name/sp/spideroak/package.nix b/pkgs/by-name/sp/spideroak/package.nix index c4ef9831a8ce7e..e89cfeffe78972 100644 --- a/pkgs/by-name/sp/spideroak/package.nix +++ b/pkgs/by-name/sp/spideroak/package.nix @@ -1,19 +1,39 @@ -{ lib, stdenv, fetchurl, makeWrapper, patchelf -, fontconfig, freetype, glib, libICE, libSM -, libX11, libXext, libXrender, zlib +{ + lib, + stdenv, + fetchurl, + makeWrapper, + patchelf, + fontconfig, + freetype, + glib, + libICE, + libSM, + libX11, + libXext, + libXrender, + zlib, }: let sha256 = "6d6ca2b383bcc81af1217c696eb77864a2b6db7428f4b5bde5b5913ce705eec5"; ldpath = lib.makeLibraryPath [ - fontconfig freetype glib libICE libSM - libX11 libXext libXrender zlib + fontconfig + freetype + glib + libICE + libSM + libX11 + libXext + libXrender + zlib ]; version = "7.5.0"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "spideroak"; inherit version; @@ -48,7 +68,10 @@ in stdenv.mkDerivation { sed -i 's/^Exec=.*/Exec=spideroak/' $out/share/applications/SpiderOakONE.desktop ''; - nativeBuildInputs = [ patchelf makeWrapper ]; + nativeBuildInputs = [ + patchelf + makeWrapper + ]; meta = { homepage = "https://spideroak.com"; diff --git a/pkgs/by-name/sp/spigot/package.nix b/pkgs/by-name/sp/spigot/package.nix index da8393210ca133..fa873ab257b103 100644 --- a/pkgs/by-name/sp/spigot/package.nix +++ b/pkgs/by-name/sp/spigot/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, callPackage -, cmake -, gmp -, halibut -, ncurses -, perl +{ + lib, + stdenv, + fetchurl, + callPackage, + cmake, + gmp, + halibut, + ncurses, + perl, }: stdenv.mkDerivation (finalAttrs: { @@ -29,7 +30,10 @@ stdenv.mkDerivation (finalAttrs: { ncurses ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; strictDeps = true; diff --git a/pkgs/by-name/sp/spigot/tests/approximation.nix b/pkgs/by-name/sp/spigot/tests/approximation.nix index fbf4875e1e619f..0062d4449c2f21 100644 --- a/pkgs/by-name/sp/spigot/tests/approximation.nix +++ b/pkgs/by-name/sp/spigot/tests/approximation.nix @@ -1,5 +1,6 @@ -{ stdenv -, spigot +{ + stdenv, + spigot, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/sp/spike/package.nix b/pkgs/by-name/sp/spike/package.nix index d0e79c4f9812df..8eb988bc9ce587 100644 --- a/pkgs/by-name/sp/spike/package.nix +++ b/pkgs/by-name/sp/spike/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, dtc, pkgsCross }: +{ + lib, + stdenv, + fetchFromGitHub, + dtc, + pkgsCross, +}: stdenv.mkDerivation rec { pname = "spike"; @@ -41,7 +47,10 @@ stdenv.mkDerivation rec { description = "RISC-V ISA Simulator"; homepage = "https://github.com/riscv/riscv-isa-sim"; license = licenses.bsd3; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; maintainers = with maintainers; [ blitz ]; }; } diff --git a/pkgs/by-name/sp/spin/package.nix b/pkgs/by-name/sp/spin/package.nix index 6c0f359fff5d6c..c0952a504d3910 100644 --- a/pkgs/by-name/sp/spin/package.nix +++ b/pkgs/by-name/sp/spin/package.nix @@ -1,7 +1,22 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper, bison, gcc, tk, swarm, graphviz }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + bison, + gcc, + tk, + swarm, + graphviz, +}: let - binPath = lib.makeBinPath [ gcc graphviz tk swarm ]; + binPath = lib.makeBinPath [ + gcc + graphviz + tk + swarm + ]; in stdenv.mkDerivation rec { @@ -42,6 +57,9 @@ stdenv.mkDerivation rec { homepage = "https://spinroot.com/"; license = licenses.bsd3; platforms = platforms.unix; - maintainers = with maintainers; [ pSub siraben ]; + maintainers = with maintainers; [ + pSub + siraben + ]; }; } diff --git a/pkgs/by-name/sp/spip/package.nix b/pkgs/by-name/sp/spip/package.nix index 9c9c6e8a20ed66..71fa19fb9949e2 100644 --- a/pkgs/by-name/sp/spip/package.nix +++ b/pkgs/by-name/sp/spip/package.nix @@ -1,19 +1,21 @@ { - fetchFromGitHub, - fetchurl, - lib, - makeWrapper, - rPackages, - rWrapper, - stdenv + fetchFromGitHub, + fetchurl, + lib, + makeWrapper, + rPackages, + rWrapper, + stdenv, }: let - my-r-packages = rWrapper.override{packages = with rPackages; [ - foreach - doParallel - randomForest - ];}; + my-r-packages = rWrapper.override { + packages = with rPackages; [ + foreach + doParallel + randomForest + ]; + }; transcriptome-url = "https://kumisystems.dl.sourceforge.net/project/splicing-prediction-pipeline/transcriptome/"; transcriptome19 = fetchurl { @@ -42,7 +44,7 @@ stdenv.mkDerivation { nativeBuildInputs = [ makeWrapper ]; buildInput = [ my-r-packages ]; - installPhase ='' + installPhase = '' runHook preInstall mkdir -p $out/bin @@ -54,12 +56,12 @@ stdenv.mkDerivation { --add-flags "$out/SPiPv2.1_main.r" runHook postInstall -''; + ''; meta = with lib; { description = "A random forest model for splice prediction in genomics"; - license = licenses.mit; - homepage = "https://github.com/raphaelleman/SPiP"; + license = licenses.mit; + homepage = "https://github.com/raphaelleman/SPiP"; maintainers = with maintainers; [ apraga ]; platforms = platforms.unix; mainProgram = "spip"; diff --git a/pkgs/by-name/sp/spire/package.nix b/pkgs/by-name/sp/spire/package.nix index c1905d7411c8db..7f3a2d1c6c903d 100644 --- a/pkgs/by-name/sp/spire/package.nix +++ b/pkgs/by-name/sp/spire/package.nix @@ -1,10 +1,18 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "spire"; version = "1.11.0"; - outputs = [ "out" "agent" "server" ]; + outputs = [ + "out" + "agent" + "server" + ]; src = fetchFromGitHub { owner = "spiffe"; @@ -15,7 +23,10 @@ buildGoModule rec { vendorHash = "sha256-hvgJvDv4rnpS3T4EOgQBjMp59O6fAPK3AD1eKvplJi4="; - subPackages = [ "cmd/spire-agent" "cmd/spire-server" ]; + subPackages = [ + "cmd/spire-agent" + "cmd/spire-server" + ]; # Usually either the agent or server is needed for a given use case, but not both postInstall = '' diff --git a/pkgs/by-name/sp/spirv-cross/package.nix b/pkgs/by-name/sp/spirv-cross/package.nix index 7115a09bd8e9c8..1661cd71d8498a 100644 --- a/pkgs/by-name/sp/spirv-cross/package.nix +++ b/pkgs/by-name/sp/spirv-cross/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, +}: stdenv.mkDerivation (finalAttrs: { pname = "spirv-cross"; @@ -11,7 +17,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-HKEh/UQzDQEOvJGHQlM6kEYVZrMaUBOcOGjjHWXSPoo="; }; - nativeBuildInputs = [ cmake python3 ]; + nativeBuildInputs = [ + cmake + python3 + ]; postFixup = '' substituteInPlace $out/lib/pkgconfig/*.pc \ diff --git a/pkgs/by-name/sp/spirv-headers/package.nix b/pkgs/by-name/sp/spirv-headers/package.nix index 837967827f31d3..f03f327f5a1b2e 100644 --- a/pkgs/by-name/sp/spirv-headers/package.nix +++ b/pkgs/by-name/sp/spirv-headers/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "spirv-headers"; diff --git a/pkgs/by-name/sp/spirv-tools/package.nix b/pkgs/by-name/sp/spirv-tools/package.nix index b9d4ba12274890..cd7b3bdc82541e 100644 --- a/pkgs/by-name/sp/spirv-tools/package.nix +++ b/pkgs/by-name/sp/spirv-tools/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, python3, spirv-headers }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, + spirv-headers, +}: stdenv.mkDerivation rec { pname = "spirv-tools"; @@ -16,7 +23,10 @@ stdenv.mkDerivation rec { # description patches = lib.optional stdenv.hostPlatform.isStatic ./no-shared-libs.patch; - nativeBuildInputs = [ cmake python3 ]; + nativeBuildInputs = [ + cmake + python3 + ]; cmakeFlags = [ "-DSPIRV-Headers_SOURCE_DIR=${spirv-headers.src}" diff --git a/pkgs/by-name/sp/spla/package.nix b/pkgs/by-name/sp/spla/package.nix index 2e07da1cdb020f..a0016e08ee542c 100644 --- a/pkgs/by-name/sp/spla/package.nix +++ b/pkgs/by-name/sp/spla/package.nix @@ -1,24 +1,30 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, mpi -, blas -, gfortran -, llvmPackages -, cudaPackages -, rocmPackages -, config -, gpuBackend ? ( - if config.cudaSupport - then "cuda" - else if config.rocmSupport - then "rocm" - else "none" -) +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + mpi, + blas, + gfortran, + llvmPackages, + cudaPackages, + rocmPackages, + config, + gpuBackend ? ( + if config.cudaSupport then + "cuda" + else if config.rocmSupport then + "rocm" + else + "none" + ), }: -assert builtins.elem gpuBackend [ "none" "cuda" "rocm" ]; +assert builtins.elem gpuBackend [ + "none" + "cuda" + "rocm" +]; stdenv.mkDerivation rec { pname = "spla"; @@ -31,7 +37,10 @@ stdenv.mkDerivation rec { hash = "sha256-fNH1IOKV1Re8G7GH9Xfn3itR80eonTbEGKQRRD16/2k="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postPatch = '' substituteInPlace src/gpu_util/gpu_blas_api.hpp \ @@ -43,28 +52,29 @@ stdenv.mkDerivation rec { gfortran ]; - buildInputs = [ - blas - mpi - ] - ++ lib.optional (gpuBackend == "cuda") cudaPackages.cudatoolkit - ++ lib.optionals (gpuBackend == "rocm") [ - rocmPackages.clr - rocmPackages.rocblas - ] ++ lib.optional stdenv.hostPlatform.isDarwin llvmPackages.openmp - ; + buildInputs = + [ + blas + mpi + ] + ++ lib.optional (gpuBackend == "cuda") cudaPackages.cudatoolkit + ++ lib.optionals (gpuBackend == "rocm") [ + rocmPackages.clr + rocmPackages.rocblas + ] + ++ lib.optional stdenv.hostPlatform.isDarwin llvmPackages.openmp; - cmakeFlags = [ - "-DSPLA_OMP=ON" - "-DSPLA_FORTRAN=ON" - "-DSPLA_INSTALL=ON" - # Required due to broken CMake files - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] - ++ lib.optional (gpuBackend == "cuda") "-DSPLA_GPU_BACKEND=CUDA" - ++ lib.optional (gpuBackend == "rocm") [ "-DSPLA_GPU_BACKEND=ROCM" ] - ; + cmakeFlags = + [ + "-DSPLA_OMP=ON" + "-DSPLA_FORTRAN=ON" + "-DSPLA_INSTALL=ON" + # Required due to broken CMake files + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optional (gpuBackend == "cuda") "-DSPLA_GPU_BACKEND=CUDA" + ++ lib.optional (gpuBackend == "rocm") [ "-DSPLA_GPU_BACKEND=ROCM" ]; preFixup = '' substituteInPlace $out/lib/cmake/SPLA/SPLASharedTargets-release.cmake \ diff --git a/pkgs/by-name/sp/splat/package.nix b/pkgs/by-name/sp/splat/package.nix index 1bf4e738c71380..a151bc05c48e62 100644 --- a/pkgs/by-name/sp/splat/package.nix +++ b/pkgs/by-name/sp/splat/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, groff, ncurses, bzip2, zlib }: +{ + lib, + stdenv, + fetchurl, + groff, + ncurses, + bzip2, + zlib, +}: stdenv.mkDerivation rec { pname = "splat"; @@ -11,9 +19,15 @@ stdenv.mkDerivation rec { nativeBuildInputs = # configure script needs `clear` - [ groff ncurses ]; + [ + groff + ncurses + ]; - buildInputs = [ bzip2 zlib ]; + buildInputs = [ + bzip2 + zlib + ]; postPatch = "patchShebangs build utils/build"; @@ -45,8 +59,7 @@ stdenv.mkDerivation rec { meta = with lib; { broken = stdenv.hostPlatform.isDarwin; - description = - "SPLAT! is an RF Signal Propagation, Loss, And Terrain analysis tool for the electromagnetic spectrum between 20 MHz and 20 GHz"; + description = "SPLAT! is an RF Signal Propagation, Loss, And Terrain analysis tool for the electromagnetic spectrum between 20 MHz and 20 GHz"; license = licenses.gpl2Only; homepage = "https://www.qsl.net/kd2bd/splat.html"; maintainers = with maintainers; [ ehmry ]; diff --git a/pkgs/by-name/sp/spleen/package.nix b/pkgs/by-name/sp/spleen/package.nix index 48b920a576bd33..c2b7afe24f1a41 100644 --- a/pkgs/by-name/sp/spleen/package.nix +++ b/pkgs/by-name/sp/spleen/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchurl, xorg }: +{ + lib, + stdenvNoCC, + fetchurl, + xorg, +}: stdenvNoCC.mkDerivation rec { pname = "spleen"; diff --git a/pkgs/by-name/sp/splix/package.nix b/pkgs/by-name/sp/splix/package.nix index 142f32dd2593cb..47f8f2d24c7e83 100644 --- a/pkgs/by-name/sp/splix/package.nix +++ b/pkgs/by-name/sp/splix/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchsvn, fetchurl, cups, cups-filters, jbigkit, zlib }: +{ + lib, + stdenv, + fetchsvn, + fetchurl, + cups, + cups-filters, + jbigkit, + zlib, +}: let @@ -17,7 +26,8 @@ let ''; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "splix-svn"; version = "315"; @@ -42,7 +52,11 @@ in stdenv.mkDerivation rec { "CUPSPROFILE=${color-profiles}/share/cups/profiles" ]; - buildInputs = [ cups zlib jbigkit ]; + buildInputs = [ + cups + zlib + jbigkit + ]; meta = with lib; { description = "CUPS drivers for SPL (Samsung Printer Language) printers"; diff --git a/pkgs/by-name/sp/sploitscan/package.nix b/pkgs/by-name/sp/sploitscan/package.nix index 63c2859408b0b6..3b31c88902ebb0 100644 --- a/pkgs/by-name/sp/sploitscan/package.nix +++ b/pkgs/by-name/sp/sploitscan/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/sp/spoof/package.nix b/pkgs/by-name/sp/spoof/package.nix index e7586483d2d494..a9af358d968b43 100644 --- a/pkgs/by-name/sp/spoof/package.nix +++ b/pkgs/by-name/sp/spoof/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/sp/spooftooph/package.nix b/pkgs/by-name/sp/spooftooph/package.nix index 3a78341128c21e..91af880da0bed4 100644 --- a/pkgs/by-name/sp/spooftooph/package.nix +++ b/pkgs/by-name/sp/spooftooph/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, bluez -, ncurses +{ + lib, + stdenv, + fetchurl, + bluez, + ncurses, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sp/spooles/package.nix b/pkgs/by-name/sp/spooles/package.nix index 47738008b02d9f..c2d895e5e9fcd0 100644 --- a/pkgs/by-name/sp/spooles/package.nix +++ b/pkgs/by-name/sp/spooles/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "spooles"; diff --git a/pkgs/by-name/sp/spotify-tray/package.nix b/pkgs/by-name/sp/spotify-tray/package.nix index 7eb84702be0cde..ee10a96697f825 100644 --- a/pkgs/by-name/sp/spotify-tray/package.nix +++ b/pkgs/by-name/sp/spotify-tray/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, pkg-config, gtk3, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + gtk3, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "spotify-tray"; @@ -19,7 +28,11 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config makeWrapper ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + makeWrapper + ]; buildInputs = [ gtk3 ]; diff --git a/pkgs/by-name/sp/spotify/darwin.nix b/pkgs/by-name/sp/spotify/darwin.nix index bc643d4f1b6ee7..264c8386e588f3 100644 --- a/pkgs/by-name/sp/spotify/darwin.nix +++ b/pkgs/by-name/sp/spotify/darwin.nix @@ -1,9 +1,10 @@ -{ stdenv -, pname -, meta -, fetchurl -, undmg -, lib +{ + stdenv, + pname, + meta, + fetchurl, + undmg, + lib, }: stdenv.mkDerivation { @@ -11,16 +12,17 @@ stdenv.mkDerivation { version = "1.2.40.599.g606b7f29"; - src = if stdenv.hostPlatform.isAarch64 then ( - fetchurl { - url = "https://web.archive.org/web/20240622065234/https://download.scdn.co/SpotifyARM64.dmg"; - hash = "sha256-mmjxKYmsX0rFlIU19JOfPbNgOhlcZs5slLUhDhlON1c="; - }) - else ( - fetchurl { - url = "https://web.archive.org/web/20240622065548/https://download.scdn.co/Spotify.dmg"; - hash = "sha256-hvS0xnmJQoQfNJRFsLBQk8AJjDOzDy+OGwNOq5Ms/O0="; - }); + src = + if stdenv.hostPlatform.isAarch64 then + (fetchurl { + url = "https://web.archive.org/web/20240622065234/https://download.scdn.co/SpotifyARM64.dmg"; + hash = "sha256-mmjxKYmsX0rFlIU19JOfPbNgOhlcZs5slLUhDhlON1c="; + }) + else + (fetchurl { + url = "https://web.archive.org/web/20240622065548/https://download.scdn.co/Spotify.dmg"; + hash = "sha256-hvS0xnmJQoQfNJRFsLBQk8AJjDOzDy+OGwNOq5Ms/O0="; + }); nativeBuildInputs = [ undmg ]; diff --git a/pkgs/by-name/sp/spotify/linux.nix b/pkgs/by-name/sp/spotify/linux.nix index a2b7c1eb50e355..0e8a238591557f 100644 --- a/pkgs/by-name/sp/spotify/linux.nix +++ b/pkgs/by-name/sp/spotify/linux.nix @@ -1,11 +1,49 @@ -{ fetchurl, lib, stdenv, squashfsTools, xorg, alsa-lib, makeShellWrapper, wrapGAppsHook3, openssl, freetype -, glib, pango, cairo, atk, gdk-pixbuf, gtk3, cups, nspr, nss_latest, libpng, libnotify -, libgcrypt, systemd, fontconfig, dbus, expat, ffmpeg_4, curlWithGnuTls, zlib, zenity -, at-spi2-atk, at-spi2-core, libpulseaudio, libdrm, mesa, libxkbcommon -, pname, meta, harfbuzz, libayatana-appindicator, libdbusmenu, libGL +{ + fetchurl, + lib, + stdenv, + squashfsTools, + xorg, + alsa-lib, + makeShellWrapper, + wrapGAppsHook3, + openssl, + freetype, + glib, + pango, + cairo, + atk, + gdk-pixbuf, + gtk3, + cups, + nspr, + nss_latest, + libpng, + libnotify, + libgcrypt, + systemd, + fontconfig, + dbus, + expat, + ffmpeg_4, + curlWithGnuTls, + zlib, + zenity, + at-spi2-atk, + at-spi2-core, + libpulseaudio, + libdrm, + mesa, + libxkbcommon, + pname, + meta, + harfbuzz, + libayatana-appindicator, + libdbusmenu, + libGL, # High-DPI support: Spotify's --force-device-scale-factor argument # not added if `null`, otherwise, should be a number. -, deviceScaleFactor ? null + deviceScaleFactor ? null, }: let @@ -91,7 +129,11 @@ stdenv.mkDerivation { hash = "sha512-Ej9SEhZhssQiH1srcgUW5lQuUNg+htudV7mcnK6o0pW5PiBYZ6qOPEIZ/1tZzD9xkUJ8hCq08fJMB8NQ12KXMg=="; }; - nativeBuildInputs = [ wrapGAppsHook3 makeShellWrapper squashfsTools ]; + nativeBuildInputs = [ + wrapGAppsHook3 + makeShellWrapper + squashfsTools + ]; dontStrip = true; dontPatchELF = true; @@ -126,65 +168,71 @@ stdenv.mkDerivation { librarypath = "${lib.makeLibraryPath deps}:${libdir}"; }; - installPhase = - '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $libdir - mv ./usr/* $out/ + mkdir -p $libdir + mv ./usr/* $out/ - # Work around Spotify referring to a specific minor version of - # OpenSSL. + # Work around Spotify referring to a specific minor version of + # OpenSSL. - ln -s ${lib.getLib openssl}/lib/libssl.so $libdir/libssl.so.1.0.0 - ln -s ${lib.getLib openssl}/lib/libcrypto.so $libdir/libcrypto.so.1.0.0 - ln -s ${nspr.out}/lib/libnspr4.so $libdir/libnspr4.so - ln -s ${nspr.out}/lib/libplc4.so $libdir/libplc4.so + ln -s ${lib.getLib openssl}/lib/libssl.so $libdir/libssl.so.1.0.0 + ln -s ${lib.getLib openssl}/lib/libcrypto.so $libdir/libcrypto.so.1.0.0 + ln -s ${nspr.out}/lib/libnspr4.so $libdir/libnspr4.so + ln -s ${nspr.out}/lib/libplc4.so $libdir/libplc4.so - ln -s ${ffmpeg_4.lib}/lib/libavcodec.so* $libdir - ln -s ${ffmpeg_4.lib}/lib/libavformat.so* $libdir + ln -s ${ffmpeg_4.lib}/lib/libavcodec.so* $libdir + ln -s ${ffmpeg_4.lib}/lib/libavformat.so* $libdir - rpath="$out/share/spotify:$libdir" + rpath="$out/share/spotify:$libdir" - chmod +w "$out/share/spotify/spotify" - patchelf \ - --interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath $rpath $out/share/spotify/spotify + chmod +w "$out/share/spotify/spotify" + patchelf \ + --interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ + --set-rpath $rpath $out/share/spotify/spotify - # fix Icon line in the desktop file (#48062) - sed -i "s:^Icon=.*:Icon=spotify-client:" "$out/share/spotify/spotify.desktop" + # fix Icon line in the desktop file (#48062) + sed -i "s:^Icon=.*:Icon=spotify-client:" "$out/share/spotify/spotify.desktop" - # Desktop file - mkdir -p "$out/share/applications/" - cp "$out/share/spotify/spotify.desktop" "$out/share/applications/" + # Desktop file + mkdir -p "$out/share/applications/" + cp "$out/share/spotify/spotify.desktop" "$out/share/applications/" - # Icons - for i in 16 22 24 32 48 64 128 256 512; do - ixi="$i"x"$i" - mkdir -p "$out/share/icons/hicolor/$ixi/apps" - ln -s "$out/share/spotify/icons/spotify-linux-$i.png" \ - "$out/share/icons/hicolor/$ixi/apps/spotify-client.png" - done + # Icons + for i in 16 22 24 32 48 64 128 256 512; do + ixi="$i"x"$i" + mkdir -p "$out/share/icons/hicolor/$ixi/apps" + ln -s "$out/share/spotify/icons/spotify-linux-$i.png" \ + "$out/share/icons/hicolor/$ixi/apps/spotify-client.png" + done - runHook postInstall - ''; + runHook postInstall + ''; - fixupPhase = '' - runHook preFixup + fixupPhase = '' + runHook preFixup - wrapProgramShell $out/share/spotify/spotify \ - ''${gappsWrapperArgs[@]} \ - ${lib.optionalString (deviceScaleFactor != null) '' + wrapProgramShell $out/share/spotify/spotify \ + ''${gappsWrapperArgs[@]} \ + ${ + lib.optionalString (deviceScaleFactor != null) '' --add-flags "--force-device-scale-factor=${toString deviceScaleFactor}" \ - ''} \ - --prefix LD_LIBRARY_PATH : "$librarypath" \ - --prefix PATH : "${zenity}/bin" \ - --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--enable-features=UseOzonePlatform --ozone-platform=wayland --enable-wayland-ime=true}}" + '' + } \ + --prefix LD_LIBRARY_PATH : "$librarypath" \ + --prefix PATH : "${zenity}/bin" \ + --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--enable-features=UseOzonePlatform --ozone-platform=wayland --enable-wayland-ime=true}}" - runHook postFixup - ''; + runHook postFixup + ''; meta = meta // { - maintainers = with lib.maintainers; [ ftrvxmtrx sheenobu timokau ma27 ]; + maintainers = with lib.maintainers; [ + ftrvxmtrx + sheenobu + timokau + ma27 + ]; }; } diff --git a/pkgs/by-name/sp/spotify/package.nix b/pkgs/by-name/sp/spotify/package.nix index fe49e680908f07..2e43a880cf2c78 100644 --- a/pkgs/by-name/sp/spotify/package.nix +++ b/pkgs/by-name/sp/spotify/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, callPackage -, ... +{ + lib, + stdenv, + callPackage, + ... }@args: let @@ -14,10 +15,16 @@ let description = "Play music from the Spotify music service"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - platforms = [ "x86_64-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; mainProgram = "spotify"; }; -in if stdenv.hostPlatform.isDarwin -then callPackage ./darwin.nix (extraArgs // { inherit pname meta; }) -else callPackage ./linux.nix (extraArgs // { inherit pname meta; }) +in +if stdenv.hostPlatform.isDarwin then + callPackage ./darwin.nix (extraArgs // { inherit pname meta; }) +else + callPackage ./linux.nix (extraArgs // { inherit pname meta; }) diff --git a/pkgs/by-name/sp/spotifywm/package.nix b/pkgs/by-name/sp/spotifywm/package.nix index b8a7db9a3d396f..eb15fdc1da6862 100644 --- a/pkgs/by-name/sp/spotifywm/package.nix +++ b/pkgs/by-name/sp/spotifywm/package.nix @@ -45,7 +45,10 @@ stdenv.mkDerivation { description = "Wrapper around Spotify that correctly sets class name before opening the window"; license = lib.licenses.mit; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ jqueiroz the-argus ]; + maintainers = with lib.maintainers; [ + jqueiroz + the-argus + ]; mainProgram = "spotify"; }; } diff --git a/pkgs/by-name/sp/spring-boot-cli/package.nix b/pkgs/by-name/sp/spring-boot-cli/package.nix index fb7a18c32a096d..dd6708bdee9c73 100644 --- a/pkgs/by-name/sp/spring-boot-cli/package.nix +++ b/pkgs/by-name/sp/spring-boot-cli/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchzip, jdk, makeWrapper, installShellFiles, coreutils, testers, gitUpdater }: +{ + lib, + stdenv, + fetchzip, + jdk, + makeWrapper, + installShellFiles, + coreutils, + testers, + gitUpdater, +}: stdenv.mkDerivation (finalAttrs: { pname = "spring-boot-cli"; @@ -9,7 +19,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-jmqmWlp40DE/CWzPEMfApb3OTDDb0upcePCHj1+yTs4="; }; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/sp/spruce/package.nix b/pkgs/by-name/sp/spruce/package.nix index 6127973e795339..7e84b075cfaeb5 100644 --- a/pkgs/by-name/sp/spruce/package.nix +++ b/pkgs/by-name/sp/spruce/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "spruce"; diff --git a/pkgs/by-name/sp/sptk/package.nix b/pkgs/by-name/sp/sptk/package.nix index 07b9bf3eb3c944..79a0c8a4c5013d 100644 --- a/pkgs/by-name/sp/sptk/package.nix +++ b/pkgs/by-name/sp/sptk/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, fetchpatch +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + fetchpatch, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sp/sptlrx/package.nix b/pkgs/by-name/sp/sptlrx/package.nix index 391ebb01a457a9..4c20e7a6d59ac9 100644 --- a/pkgs/by-name/sp/sptlrx/package.nix +++ b/pkgs/by-name/sp/sptlrx/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, nix-update-script, testers, sptlrx }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + testers, + sptlrx, +}: buildGoModule rec { pname = "sptlrx"; @@ -13,7 +20,10 @@ buildGoModule rec { vendorHash = "sha256-pExSQcYjqliZZg/91t52yk6UJ4QCbpToMpONIFUNkwc="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; checkFlags = let @@ -33,8 +43,7 @@ buildGoModule rec { meta = with lib; { description = "Spotify lyrics in your terminal"; homepage = "https://github.com/raitonoberu/sptlrx"; - changelog = - "https://github.com/raitonoberu/sptlrx/releases/tag/v${version}"; + changelog = "https://github.com/raitonoberu/sptlrx/releases/tag/v${version}"; license = licenses.mit; maintainers = with maintainers; [ MoritzBoehme ]; mainProgram = "sptlrx"; diff --git a/pkgs/by-name/sp/spyre/package.nix b/pkgs/by-name/sp/spyre/package.nix index c9a4946b83d980..c9296162f01426 100644 --- a/pkgs/by-name/sp/spyre/package.nix +++ b/pkgs/by-name/sp/spyre/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch -, pkg-config -, yara +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + pkg-config, + yara, }: buildGoModule rec { diff --git a/pkgs/by-name/sq/sq/package.nix b/pkgs/by-name/sq/sq/package.nix index 0f8f1b40f0a499..58fd3a9dfa2586 100644 --- a/pkgs/by-name/sq/sq/package.nix +++ b/pkgs/by-name/sq/sq/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, testers, sq }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + sq, +}: buildGoModule rec { pname = "sq"; diff --git a/pkgs/by-name/sq/sqlboiler-crdb/package.nix b/pkgs/by-name/sq/sqlboiler-crdb/package.nix index df439bce808ee4..8378d8d83177e7 100644 --- a/pkgs/by-name/sq/sqlboiler-crdb/package.nix +++ b/pkgs/by-name/sq/sqlboiler-crdb/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "sqlboiler-crbd"; diff --git a/pkgs/by-name/sq/sqlcheck/package.nix b/pkgs/by-name/sq/sqlcheck/package.nix index 0673061c486d9e..15bd89c81f8fdc 100644 --- a/pkgs/by-name/sq/sqlcheck/package.nix +++ b/pkgs/by-name/sq/sqlcheck/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, +}: stdenv.mkDerivation rec { pname = "sqlcheck"; diff --git a/pkgs/by-name/sq/sqlcipher/package.nix b/pkgs/by-name/sq/sqlcipher/package.nix index dff4e09fa7a72a..c102af52448b17 100644 --- a/pkgs/by-name/sq/sqlcipher/package.nix +++ b/pkgs/by-name/sq/sqlcipher/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, openssl -, tcl -, installShellFiles -, buildPackages -, readline -, ncurses -, zlib -, sqlite +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + tcl, + installShellFiles, + buildPackages, + readline, + ncurses, + zlib, + sqlite, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sq/sqlcmd/package.nix b/pkgs/by-name/sq/sqlcmd/package.nix index 20e7cd0a158767..653a321cfe628e 100644 --- a/pkgs/by-name/sq/sqlcmd/package.nix +++ b/pkgs/by-name/sq/sqlcmd/package.nix @@ -1,9 +1,10 @@ -{ buildGoModule -, fetchFromGitHub -, installShellFiles -, lib -, sqlcmd -, testers +{ + buildGoModule, + fetchFromGitHub, + installShellFiles, + lib, + sqlcmd, + testers, }: buildGoModule rec { @@ -20,7 +21,11 @@ buildGoModule rec { vendorHash = "sha256-gc/pOFtQMCLjHbW9z8r08Q+1QnOe5WllSuhIeiz9Huo="; proxyVendor = true; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; subPackages = [ "cmd/modern" ]; diff --git a/pkgs/by-name/sq/sqldef/package.nix b/pkgs/by-name/sq/sqldef/package.nix index a4db82021ef62c..a662f2852fb097 100644 --- a/pkgs/by-name/sq/sqldef/package.nix +++ b/pkgs/by-name/sq/sqldef/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "sqldef"; @@ -15,14 +19,21 @@ buildGoModule rec { vendorHash = "sha256-R4PTgqx8PmW5WJxt5Hdc7JfYD+93J6MPFGRddZxp2dg="; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; # The test requires a running database doCheck = false; meta = { description = "Idempotent SQL schema management tool"; - license = with lib.licenses; [ mit /* for everything except parser */ asl20 /* for parser */ ]; + license = with lib.licenses; [ + mit # for everything except parser + asl20 # for parser + ]; homepage = "https://github.com/sqldef/sqldef"; changelog = "https://github.com/sqldef/sqldef/blob/v${version}/CHANGELOG.md"; maintainers = with lib.maintainers; [ kgtkr ]; diff --git a/pkgs/by-name/sq/sqlite-jdbc/package.nix b/pkgs/by-name/sq/sqlite-jdbc/package.nix index 01c301e1a45453..d7595c6d790e0c 100644 --- a/pkgs/by-name/sq/sqlite-jdbc/package.nix +++ b/pkgs/by-name/sq/sqlite-jdbc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchMavenArtifact }: +{ + lib, + stdenv, + fetchMavenArtifact, +}: stdenv.mkDerivation rec { pname = "sqlite-jdbc"; @@ -24,4 +28,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ jraygauthier ]; }; } - diff --git a/pkgs/by-name/sq/sqlite-vss/package.nix b/pkgs/by-name/sq/sqlite-vss/package.nix index bc3612ceebe010..c9b71996acebed 100644 --- a/pkgs/by-name/sq/sqlite-vss/package.nix +++ b/pkgs/by-name/sq/sqlite-vss/package.nix @@ -1,12 +1,13 @@ -{ lib -, cmake -, faiss -, fetchFromGitHub -, gomp -, llvmPackages -, nlohmann_json -, sqlite -, stdenv +{ + lib, + cmake, + faiss, + fetchFromGitHub, + gomp, + llvmPackages, + nlohmann_json, + sqlite, + stdenv, }: stdenv.mkDerivation (finalAttrs: { @@ -24,7 +25,12 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ cmake ]; - buildInputs = [ nlohmann_json faiss sqlite ] + buildInputs = + [ + nlohmann_json + faiss + sqlite + ] ++ lib.optional stdenv.hostPlatform.isLinux gomp ++ lib.optional stdenv.hostPlatform.isDarwin llvmPackages.openmp; @@ -42,7 +48,7 @@ stdenv.mkDerivation (finalAttrs: { runHook postInstall ''; - meta = with lib;{ + meta = with lib; { # Low maintenance mode, doesn't support up-to-date faiss # https://github.com/NixOS/nixpkgs/pull/330191#issuecomment-2252965866 broken = lib.versionAtLeast faiss.version "1.8.0"; diff --git a/pkgs/by-name/sq/sqlite-web/package.nix b/pkgs/by-name/sq/sqlite-web/package.nix index 610e872da187f5..b379e426f19969 100644 --- a/pkgs/by-name/sq/sqlite-web/package.nix +++ b/pkgs/by-name/sq/sqlite-web/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchPypi +{ + lib, + python3Packages, + fetchPypi, }: python3Packages.buildPythonApplication rec { @@ -12,7 +13,11 @@ python3Packages.buildPythonApplication rec { hash = "sha256-5Bdd1C9M3HjvfDKdVvGSQ+/I0Iimvf1MZwPonRiqwqU="; }; - propagatedBuildInputs = with python3Packages; [ flask peewee pygments ]; + propagatedBuildInputs = with python3Packages; [ + flask + peewee + pygments + ]; # no tests in repository doCheck = false; diff --git a/pkgs/by-name/sq/sqlite3-to-mysql/package.nix b/pkgs/by-name/sq/sqlite3-to-mysql/package.nix index c0d2126e0af009..817f0da64ee32c 100644 --- a/pkgs/by-name/sq/sqlite3-to-mysql/package.nix +++ b/pkgs/by-name/sq/sqlite3-to-mysql/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, python3Packages -, nixosTests -, testers -, sqlite3-to-mysql -, mysql80 +{ + lib, + fetchFromGitHub, + python3Packages, + nixosTests, + testers, + sqlite3-to-mysql, + mysql80, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/sq/sqlite_orm/package.nix b/pkgs/by-name/sq/sqlite_orm/package.nix index 34a76f4095fc53..2d2ce1dd9024dc 100644 --- a/pkgs/by-name/sq/sqlite_orm/package.nix +++ b/pkgs/by-name/sq/sqlite_orm/package.nix @@ -1,8 +1,9 @@ -{ lib -, cmake -, fetchFromGitHub -, sqlite -, stdenv +{ + lib, + cmake, + fetchFromGitHub, + sqlite, + stdenv, }: stdenv.mkDerivation (finalAttrs: { pname = "sqlite_orm"; diff --git a/pkgs/by-name/sq/sqlitecpp/package.nix b/pkgs/by-name/sq/sqlitecpp/package.nix index a48e9a4ac87a63..e1dcac1598ded7 100644 --- a/pkgs/by-name/sq/sqlitecpp/package.nix +++ b/pkgs/by-name/sq/sqlitecpp/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, sqlite -, gtest +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + sqlite, + gtest, }: stdenv.mkDerivation (finalAttrs: { @@ -36,6 +37,9 @@ stdenv.mkDerivation (finalAttrs: { description = "C++ SQLite3 wrapper"; license = licenses.mit; platforms = platforms.unix; - maintainers = [ maintainers.jbedo maintainers.doronbehar ]; + maintainers = [ + maintainers.jbedo + maintainers.doronbehar + ]; }; }) diff --git a/pkgs/by-name/sq/sqls/package.nix b/pkgs/by-name/sq/sqls/package.nix index fe5735d0e553a4..473beadb4be042 100644 --- a/pkgs/by-name/sq/sqls/package.nix +++ b/pkgs/by-name/sq/sqls/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "sqls"; @@ -13,7 +17,12 @@ buildGoModule rec { vendorHash = "sha256-6IFJvdT7YLnWsg7Icd3nKXXHM6TZKZ+IG9nEBosRCwA="; - ldflags = [ "-s" "-w" "-X main.version=${version}" "-X main.revision=${src.rev}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + "-X main.revision=${src.rev}" + ]; doCheck = false; diff --git a/pkgs/by-name/sq/sqsh/package.nix b/pkgs/by-name/sq/sqsh/package.nix index e7b0342ac697d8..42c2cf884ee569 100644 --- a/pkgs/by-name/sq/sqsh/package.nix +++ b/pkgs/by-name/sq/sqsh/package.nix @@ -1,26 +1,41 @@ -{ lib, stdenv, fetchurl, autoreconfHook, freetds, readline, libiconv }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + freetds, + readline, + libiconv, +}: let mainVersion = "2.5"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "sqsh"; version = "${mainVersion}.16.1"; src = fetchurl { - url = "mirror://sourceforge/sqsh/sqsh/sqsh-${mainVersion}/${pname}-${version}.tgz"; + url = "mirror://sourceforge/sqsh/sqsh/sqsh-${mainVersion}/${pname}-${version}.tgz"; sha256 = "1wi0hdmhk7l8nrz4j3kaa177mmxyklmzhj7sq1gj4q6fb8v1yr6n"; }; - preConfigure = '' - export SYBASE=${freetds} - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace configure --replace "libct.so" "libct.dylib" - ''; + preConfigure = + '' + export SYBASE=${freetds} + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace configure --replace "libct.so" "libct.dylib" + ''; enableParallelBuilding = true; - buildInputs = [ freetds readline libiconv ]; + buildInputs = [ + freetds + readline + libiconv + ]; nativeBuildInputs = [ autoreconfHook ]; diff --git a/pkgs/by-name/sq/squashfsTools/package.nix b/pkgs/by-name/sq/squashfsTools/package.nix index ae658330b28011..8629b8f5394337 100644 --- a/pkgs/by-name/sq/squashfsTools/package.nix +++ b/pkgs/by-name/sq/squashfsTools/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, help2man -, lz4 -, lzo -, nixosTests -, which -, xz -, zlib -, zstd +{ + lib, + stdenv, + fetchFromGitHub, + help2man, + lz4, + lzo, + nixosTests, + which, + xz, + zlib, + zstd, }: stdenv.mkDerivation rec { @@ -29,14 +30,21 @@ stdenv.mkDerivation rec { ]; strictDeps = true; - nativeBuildInputs = [ which ] + nativeBuildInputs = + [ which ] # when cross-compiling help2man cannot run the cross-compiled binary ++ lib.optionals (stdenv.hostPlatform == stdenv.buildPlatform) [ help2man ]; - buildInputs = [ zlib xz zstd lz4 lzo ]; + buildInputs = [ + zlib + xz + zstd + lz4 + lzo + ]; preBuild = '' cd squashfs-tools - '' ; + ''; installFlags = [ "INSTALL_DIR=${placeholder "out"}/bin" diff --git a/pkgs/by-name/sq/squashfuse/package.nix b/pkgs/by-name/sq/squashfuse/package.nix index 2d89160fa7174c..4c295ca88468b0 100644 --- a/pkgs/by-name/sq/squashfuse/package.nix +++ b/pkgs/by-name/sq/squashfuse/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libtool, fuse, - pkg-config, lz4, xz, zlib, lzo, zstd }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libtool, + fuse, + pkg-config, + lz4, + xz, + zlib, + lzo, + zstd, +}: stdenv.mkDerivation rec { @@ -13,8 +25,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-76PQB+6ls/RCjEP8Z4DEtX0xemN3srCsLM7DsDqiTVA="; }; - nativeBuildInputs = [ autoreconfHook libtool pkg-config ]; - buildInputs = [ lz4 xz zlib lzo zstd fuse ]; + nativeBuildInputs = [ + autoreconfHook + libtool + pkg-config + ]; + buildInputs = [ + lz4 + xz + zlib + lzo + zstd + fuse + ]; meta = { description = "FUSE filesystem to mount squashfs archives"; diff --git a/pkgs/by-name/sq/squawk/package.nix b/pkgs/by-name/sq/squawk/package.nix index 2190401c00bdc4..f40ab2c2957e1e 100644 --- a/pkgs/by-name/sq/squawk/package.nix +++ b/pkgs/by-name/sq/squawk/package.nix @@ -1,12 +1,13 @@ -{ darwin -, fetchFromGitHub -, lib -, libiconv -, libpg_query -, openssl -, pkg-config -, rustPlatform -, stdenv +{ + darwin, + fetchFromGitHub, + lib, + libiconv, + libpg_query, + openssl, + pkg-config, + rustPlatform, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -27,13 +28,18 @@ rustPlatform.buildRustPackage rec { rustPlatform.bindgenHook ]; - buildInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ - libiconv - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - CoreFoundation - Security - ]); + buildInputs = + lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libiconv + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + CoreFoundation + Security + ] + ); OPENSSL_NO_VENDOR = 1; diff --git a/pkgs/by-name/sq/squid/package.nix b/pkgs/by-name/sq/squid/package.nix index 998b2d9ada44d6..fef7cb92342f5e 100644 --- a/pkgs/by-name/sq/squid/package.nix +++ b/pkgs/by-name/sq/squid/package.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchurl, perl, openldap, pam, db, cyrus_sasl, libcap -, expat, libxml2, openssl, pkg-config, systemd -, cppunit +{ + lib, + stdenv, + fetchurl, + perl, + openldap, + pam, + db, + cyrus_sasl, + libcap, + expat, + libxml2, + openssl, + pkg-config, + systemd, + cppunit, }: stdenv.mkDerivation (finalAttrs: { @@ -13,25 +26,40 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - perl openldap db cyrus_sasl expat libxml2 openssl - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libcap pam systemd ]; + buildInputs = + [ + perl + openldap + db + cyrus_sasl + expat + libxml2 + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libcap + pam + systemd + ]; enableParallelBuilding = true; - configureFlags = [ - "--enable-ipv6" - "--disable-strict-error-checking" - "--disable-arch-native" - "--with-openssl" - "--enable-ssl-crtd" - "--enable-storeio=ufs,aufs,diskd,rock" - "--enable-removal-policies=lru,heap" - "--enable-delay-pools" - "--enable-x-accelerator-vary" - "--enable-htcp" - ] ++ lib.optional (stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isMusl) - "--enable-linux-netfilter"; + configureFlags = + [ + "--enable-ipv6" + "--disable-strict-error-checking" + "--disable-arch-native" + "--with-openssl" + "--enable-ssl-crtd" + "--enable-storeio=ufs,aufs,diskd,rock" + "--enable-removal-policies=lru,heap" + "--enable-delay-pools" + "--enable-x-accelerator-vary" + "--enable-htcp" + ] + ++ lib.optional ( + stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isMusl + ) "--enable-linux-netfilter"; doCheck = true; nativeCheckInputs = [ cppunit ]; @@ -55,6 +83,8 @@ stdenv.mkDerivation (finalAttrs: { license = licenses.gpl2Plus; platforms = platforms.linux; maintainers = with maintainers; [ raskin ]; - knownVulnerabilities = [ "Squid has multiple unresolved security vulnerabilities, for more information see https://megamansec.github.io/Squid-Security-Audit/" ]; + knownVulnerabilities = [ + "Squid has multiple unresolved security vulnerabilities, for more information see https://megamansec.github.io/Squid-Security-Audit/" + ]; }; }) diff --git a/pkgs/by-name/sq/squirreldisk/package.nix b/pkgs/by-name/sq/squirreldisk/package.nix index d0ea01ba160f75..ae1bc3d5f718d8 100644 --- a/pkgs/by-name/sq/squirreldisk/package.nix +++ b/pkgs/by-name/sq/squirreldisk/package.nix @@ -15,7 +15,8 @@ stdenv, copyDesktopItems, makeDesktopItem, -}: let +}: +let pname = "squirreldisk"; version = "0.3.4"; @@ -39,67 +40,78 @@ dontInstall = true; }; in - rustPlatform.buildRustPackage rec { - inherit version src pname; +rustPlatform.buildRustPackage rec { + inherit version src pname; - sourceRoot = "${src.name}/src-tauri"; + sourceRoot = "${src.name}/src-tauri"; - cargoLock = { - lockFile = ./Cargo.lock; - outputHashes = { - "window-shadows-0.2.1" = "sha256-3meM04TG63PvB0M5wUH1cDMBo7ObcB0zdgwGt2aKHMs="; - }; + cargoLock = { + lockFile = ./Cargo.lock; + outputHashes = { + "window-shadows-0.2.1" = "sha256-3meM04TG63PvB0M5wUH1cDMBo7ObcB0zdgwGt2aKHMs="; }; + }; - # copy the frontend static resources to final build directory - # Also modify tauri.conf.json so that it expects the resources at the new location - postPatch = '' - cp ${./Cargo.lock} Cargo.lock + # copy the frontend static resources to final build directory + # Also modify tauri.conf.json so that it expects the resources at the new location + postPatch = '' + cp ${./Cargo.lock} Cargo.lock - mkdir -p frontend-build - cp -r ${frontend-build}/* frontend-build + mkdir -p frontend-build + cp -r ${frontend-build}/* frontend-build - substituteInPlace tauri.conf.json --replace-fail '"distDir": "../dist"' '"distDir": "./frontend-build"' + substituteInPlace tauri.conf.json --replace-fail '"distDir": "../dist"' '"distDir": "./frontend-build"' - # Copy pdu binary from nixpkgs, since the default packaged binary has issues. - cp ${parallel-disk-usage}/bin/pdu bin/pdu-${stdenv.hostPlatform.config} - ''; + # Copy pdu binary from nixpkgs, since the default packaged binary has issues. + cp ${parallel-disk-usage}/bin/pdu bin/pdu-${stdenv.hostPlatform.config} + ''; - nativeBuildInputs = [pkg-config wrapGAppsHook3 copyDesktopItems]; - buildInputs = [dbus openssl freetype libsoup_2_4 gtk3 webkitgtk_4_0]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + copyDesktopItems + ]; + buildInputs = [ + dbus + openssl + freetype + libsoup_2_4 + gtk3 + webkitgtk_4_0 + ]; - # Disable checkPhase, since the project doesn't contain tests - doCheck = false; + # Disable checkPhase, since the project doesn't contain tests + doCheck = false; - postInstall = '' - mv $out/bin/squirreldisk-tauri $out/bin/squirreldisk - install -DT icons/256x256.png $out/share/icons/hicolor/256x256/apps/squirrel-disk.png - install -DT icons/128x128@2x.png $out/share/icons/hicolor/128x128@2/apps/squirrel-disk.png - install -DT icons/128x128.png $out/share/icons/hicolor/128x128/apps/squirrel-disk.png - install -DT icons/32x32.png $out/share/icons/hicolor/32x32/apps/squirrel-disk.png - ''; + postInstall = '' + mv $out/bin/squirreldisk-tauri $out/bin/squirreldisk + install -DT icons/256x256.png $out/share/icons/hicolor/256x256/apps/squirrel-disk.png + install -DT icons/128x128@2x.png $out/share/icons/hicolor/128x128@2/apps/squirrel-disk.png + install -DT icons/128x128.png $out/share/icons/hicolor/128x128/apps/squirrel-disk.png + install -DT icons/32x32.png $out/share/icons/hicolor/32x32/apps/squirrel-disk.png + ''; - # WEBKIT_DISABLE_COMPOSITING_MODE essential in NVIDIA + compositor https://github.com/NixOS/nixpkgs/issues/212064#issuecomment-1400202079 - postFixup = '' - wrapProgram "$out/bin/squirreldisk" \ - --set WEBKIT_DISABLE_COMPOSITING_MODE 1 - ''; + # WEBKIT_DISABLE_COMPOSITING_MODE essential in NVIDIA + compositor https://github.com/NixOS/nixpkgs/issues/212064#issuecomment-1400202079 + postFixup = '' + wrapProgram "$out/bin/squirreldisk" \ + --set WEBKIT_DISABLE_COMPOSITING_MODE 1 + ''; - desktopItems = [ - (makeDesktopItem { - name = "SquirrelDisk"; - exec = "squirreldisk"; - icon = "squirrel-disk"; - desktopName = "SquirrelDisk"; - comment = meta.description; - }) - ]; + desktopItems = [ + (makeDesktopItem { + name = "SquirrelDisk"; + exec = "squirreldisk"; + icon = "squirrel-disk"; + desktopName = "SquirrelDisk"; + comment = meta.description; + }) + ]; - meta = with lib; { - description = "Cross-platform disk usage analysis tool"; - homepage = "https://www.squirreldisk.com/"; - license = licenses.agpl3Only; - maintainers = with maintainers; [peret]; - mainProgram = "squirreldisk"; - }; - } + meta = with lib; { + description = "Cross-platform disk usage analysis tool"; + homepage = "https://www.squirreldisk.com/"; + license = licenses.agpl3Only; + maintainers = with maintainers; [ peret ]; + mainProgram = "squirreldisk"; + }; +} diff --git a/pkgs/by-name/sr/srain/package.nix b/pkgs/by-name/sr/srain/package.nix index 6984d720b638e1..96eaf54390ecca 100644 --- a/pkgs/by-name/sr/srain/package.nix +++ b/pkgs/by-name/sr/srain/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, gtk3 -, libconfig -, libsoup_3 -, libsecret -, libayatana-appindicator -, openssl -, gettext -, glib -, glib-networking -, appstream-glib -, dbus-glib -, python3Packages -, meson -, ninja -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + gtk3, + libconfig, + libsoup_3, + libsecret, + libayatana-appindicator, + openssl, + gettext, + glib, + glib-networking, + appstream-glib, + dbus-glib, + python3Packages, + meson, + ninja, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sr/srandrd/package.nix b/pkgs/by-name/sr/srandrd/package.nix index 0d51bf4785ecbe..564770f9c06181 100644 --- a/pkgs/by-name/sr/srandrd/package.nix +++ b/pkgs/by-name/sr/srandrd/package.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, libX11 -, libXrandr -, libXinerama +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + libXrandr, + libXinerama, }: stdenv.mkDerivation rec { @@ -16,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-Wf+tVqDaNAiH6UHN8fFv2wM+LEch6wKlZOkqWEqLLkw="; }; - buildInputs = [ libX11 libXrandr libXinerama ]; + buildInputs = [ + libX11 + libXrandr + libXinerama + ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/sr/sratom/package.nix b/pkgs/by-name/sr/sratom/package.nix index 8f793b359886f5..b92c4d2f67e9b0 100644 --- a/pkgs/by-name/sr/sratom/package.nix +++ b/pkgs/by-name/sr/sratom/package.nix @@ -1,20 +1,24 @@ -{ lib -, stdenv -, fetchurl -, lv2 -, meson -, ninja -, pkg-config -, serd -, sord -, writeScript +{ + lib, + stdenv, + fetchurl, + lv2, + meson, + ninja, + pkg-config, + serd, + sord, + writeScript, }: stdenv.mkDerivation rec { pname = "sratom"; version = "0.6.16"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "https://download.drobilla.net/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/sr/srb2/package.nix b/pkgs/by-name/sr/srb2/package.nix index 44209cf468bdba..3d2b1aae3e0c55 100644 --- a/pkgs/by-name/sr/srb2/package.nix +++ b/pkgs/by-name/sr/srb2/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchgit -, fetchFromGitHub -, cmake -, curl -, nasm -, libopenmpt -, game-music-emu -, libGLU -, libpng -, SDL2 -, SDL2_mixer -, zlib -, makeWrapper -, makeDesktopItem -, copyDesktopItems +{ + lib, + stdenv, + fetchgit, + fetchFromGitHub, + cmake, + curl, + nasm, + libopenmpt, + game-music-emu, + libGLU, + libpng, + SDL2, + SDL2_mixer, + zlib, + makeWrapper, + makeDesktopItem, + copyDesktopItems, }: stdenv.mkDerivation (finalAttrs: { @@ -120,7 +121,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.srb2.org/"; platforms = platforms.linux; license = licenses.gpl2Plus; - maintainers = with maintainers; [ zeratax donovanglover ]; + maintainers = with maintainers; [ + zeratax + donovanglover + ]; mainProgram = "srb2"; }; }) diff --git a/pkgs/by-name/sr/srb2kart/package.nix b/pkgs/by-name/sr/srb2kart/package.nix index 8260bdb394080b..72d9c153de33aa 100644 --- a/pkgs/by-name/sr/srb2kart/package.nix +++ b/pkgs/by-name/sr/srb2kart/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchzip -, fetchFromGitHub -, cmake -, curl -, nasm -, game-music-emu -, libpng -, SDL2 -, SDL2_mixer -, zlib -, makeWrapper -, makeDesktopItem -, copyDesktopItems +{ + lib, + stdenv, + fetchzip, + fetchFromGitHub, + cmake, + curl, + nasm, + game-music-emu, + libpng, + SDL2, + SDL2_mixer, + zlib, + makeWrapper, + makeDesktopItem, + copyDesktopItems, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sr/src-cli/package.nix b/pkgs/by-name/sr/src-cli/package.nix index c809b52826caf7..9c1520eb76b35c 100644 --- a/pkgs/by-name/sr/src-cli/package.nix +++ b/pkgs/by-name/sr/src-cli/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, stdenv -, xorg -, darwin -, testers -, src-cli +{ + lib, + buildGoModule, + fetchFromGitHub, + stdenv, + xorg, + darwin, + testers, + src-cli, }: buildGoModule rec { @@ -25,11 +26,13 @@ buildGoModule rec { "cmd/src" ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - xorg.libX11 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Cocoa - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + xorg.libX11 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Cocoa + ]; ldflags = [ "-s" diff --git a/pkgs/by-name/sr/src/package.nix b/pkgs/by-name/sr/src/package.nix index cd86eba4180782..d9e089e4ad20e3 100644 --- a/pkgs/by-name/sr/src/package.nix +++ b/pkgs/by-name/sr/src/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, asciidoc -, fetchFromGitLab -, git -, makeWrapper -, python3 -, rcs +{ + lib, + stdenv, + asciidoc, + fetchFromGitLab, + git, + makeWrapper, + python3, + rcs, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/sr/srecord/package.nix b/pkgs/by-name/sr/srecord/package.nix index 1d542383bfb0e9..153c8003d25740 100644 --- a/pkgs/by-name/sr/srecord/package.nix +++ b/pkgs/by-name/sr/srecord/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, boost, libtool, groff, ghostscript, libgcrypt ? null }: +{ + lib, + stdenv, + fetchurl, + boost, + libtool, + groff, + ghostscript, + libgcrypt ? null, +}: stdenv.mkDerivation rec { pname = "srecord"; @@ -9,7 +18,13 @@ stdenv.mkDerivation rec { sha256 = "1qk75q0k5vzmm3932q9hqz2gp8n9rrdfjacsswxc02656f3l3929"; }; - buildInputs = [ boost libtool groff ghostscript libgcrypt ]; + buildInputs = [ + boost + libtool + groff + ghostscript + libgcrypt + ]; configureFlags = lib.optional (libgcrypt == null) "--without-gcrypt"; diff --git a/pkgs/by-name/sr/sregex/package.nix b/pkgs/by-name/sr/sregex/package.nix index 58ef91c31908bc..05b1786304af09 100644 --- a/pkgs/by-name/sr/sregex/package.nix +++ b/pkgs/by-name/sr/sregex/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "sregex"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { hash = "sha256-HZ9O/3BQHHrTVLLlU0o1fLHxyRSesBhreT3IdGHnNsg="; }; - makeFlags = [ "PREFIX=$(out)" "CC:=$(CC)" ]; + makeFlags = [ + "PREFIX=$(out)" + "CC:=$(CC)" + ]; meta = with lib; { homepage = "https://github.com/openresty/sregex"; diff --git a/pkgs/by-name/sr/srelay/package.nix b/pkgs/by-name/sr/srelay/package.nix index d54d4d79017ab3..eeb3827e6ed7da 100644 --- a/pkgs/by-name/sr/srelay/package.nix +++ b/pkgs/by-name/sr/srelay/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libxcrypt }: +{ + lib, + stdenv, + fetchurl, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "srelay"; diff --git a/pkgs/by-name/sr/srgn/package.nix b/pkgs/by-name/sr/srgn/package.nix index d88ae2a992e93b..0e4023fd92682d 100644 --- a/pkgs/by-name/sr/srgn/package.nix +++ b/pkgs/by-name/sr/srgn/package.nix @@ -1,7 +1,8 @@ -{ rustPlatform -, fetchFromGitHub -, installShellFiles -, lib +{ + rustPlatform, + fetchFromGitHub, + installShellFiles, + lib, }: rustPlatform.buildRustPackage rec { pname = "srgn"; diff --git a/pkgs/by-name/sr/srht-gen-oauth-tok/package.nix b/pkgs/by-name/sr/srht-gen-oauth-tok/package.nix index 581521e0edd93d..5c4db959a6a425 100644 --- a/pkgs/by-name/sr/srht-gen-oauth-tok/package.nix +++ b/pkgs/by-name/sr/srht-gen-oauth-tok/package.nix @@ -1,4 +1,10 @@ -{ stdenv, pkgs, lib, fetchFromSourcehut, nixosTests }: +{ + stdenv, + pkgs, + lib, + fetchFromSourcehut, + nixosTests, +}: let perl = pkgs.perl.withPackages (pps: [ diff --git a/pkgs/by-name/sr/srisum/package.nix b/pkgs/by-name/sr/srisum/package.nix index f9f0a6b4a6b073..5fce3fcacab2a5 100644 --- a/pkgs/by-name/sr/srisum/package.nix +++ b/pkgs/by-name/sr/srisum/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sr/srm/package.nix b/pkgs/by-name/sr/srm/package.nix index 7cde2be4fbc5f7..ccecb22418e134 100644 --- a/pkgs/by-name/sr/srm/package.nix +++ b/pkgs/by-name/sr/srm/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchsvn, autoreconfHook }: +{ + lib, + stdenv, + fetchsvn, + autoreconfHook, +}: stdenv.mkDerivation { pname = "srm"; diff --git a/pkgs/by-name/sr/srsran/package.nix b/pkgs/by-name/sr/srsran/package.nix index af278534a48842..f20c76ae2f6c40 100644 --- a/pkgs/by-name/sr/srsran/package.nix +++ b/pkgs/by-name/sr/srsran/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, cmake -, fetchFromGitHub -, pkg-config -, fftwFloat -, mbedtls -, boost -, lksctp-tools -, libconfig -, pcsclite -, uhd -, soapysdr-with-plugins -, libbladeRF -, zeromq +{ + stdenv, + lib, + cmake, + fetchFromGitHub, + pkg-config, + fftwFloat, + mbedtls, + boost, + lksctp-tools, + libconfig, + pcsclite, + uhd, + soapysdr-with-plugins, + libbladeRF, + zeromq, }: stdenv.mkDerivation rec { @@ -22,11 +23,14 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "srsran"; repo = "srsran"; - rev = "release_${builtins.replaceStrings ["."] ["_"] version}"; + rev = "release_${builtins.replaceStrings [ "." ] [ "_" ] version}"; sha256 = "sha256-3cQMZ75I4cyHpik2d/eBuzw7M4OgbKqroCddycw4uW8="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ fftwFloat @@ -47,7 +51,7 @@ stdenv.mkDerivation rec { homepage = "https://www.srslte.com/"; description = "Open-source 4G and 5G software radio suite"; license = licenses.agpl3Plus; - platforms = with platforms; linux ; + platforms = with platforms; linux; maintainers = with maintainers; [ hexagonal-sun ]; }; } diff --git a/pkgs/by-name/sr/srt-live-server/package.nix b/pkgs/by-name/sr/srt-live-server/package.nix index 8bc3cd330b65b2..47d1d58419e241 100644 --- a/pkgs/by-name/sr/srt-live-server/package.nix +++ b/pkgs/by-name/sr/srt-live-server/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, stdenv -, srt -, zlib +{ + lib, + fetchFromGitHub, + stdenv, + srt, + zlib, }: stdenv.mkDerivation rec { @@ -24,7 +25,10 @@ stdenv.mkDerivation rec { ./add-ctime-include.patch ]; - buildInputs = [ srt zlib ]; + buildInputs = [ + srt + zlib + ]; makeFlags = [ "PREFIX=$(out)" diff --git a/pkgs/by-name/sr/srt-to-vtt-cl/package.nix b/pkgs/by-name/sr/srt-to-vtt-cl/package.nix index b0868c885edd68..a0b4490a094d35 100644 --- a/pkgs/by-name/sr/srt-to-vtt-cl/package.nix +++ b/pkgs/by-name/sr/srt-to-vtt-cl/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "srt-to-vtt-cl"; diff --git a/pkgs/by-name/sr/srt/package.nix b/pkgs/by-name/sr/srt/package.nix index be81970413b845..6b777eb2c28cf3 100644 --- a/pkgs/by-name/sr/srt/package.nix +++ b/pkgs/by-name/sr/srt/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, openssl -, windows +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openssl, + windows, }: stdenv.mkDerivation rec { @@ -19,11 +20,13 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isMinGW [ - windows.mingw_w64_pthreads - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isMinGW [ + windows.mingw_w64_pthreads + ]; patches = lib.optionals stdenv.hostPlatform.isMinGW [ ./no-msvc-compat-headers.patch diff --git a/pkgs/by-name/sr/srtp/package.nix b/pkgs/by-name/sr/srtp/package.nix index a124a3d600ca4c..6d3262407817e9 100644 --- a/pkgs/by-name/sr/srtp/package.nix +++ b/pkgs/by-name/sr/srtp/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, libpcap -, meson -, ninja -, openssl -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + libpcap, + meson, + ninja, + openssl, + pkg-config, }: stdenv.mkDerivation rec { @@ -19,7 +20,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-vWL5bksKT5NUoNkIRiJ2FeGODQthD8SgXjCaA7SeTe4="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ meson diff --git a/pkgs/by-name/sr/srtrelay/package.nix b/pkgs/by-name/sr/srtrelay/package.nix index 8640424be1e953..da9c9e83c527ec 100644 --- a/pkgs/by-name/sr/srtrelay/package.nix +++ b/pkgs/by-name/sr/srtrelay/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, srt, ffmpeg }: +{ + lib, + buildGoModule, + fetchFromGitHub, + srt, + ffmpeg, +}: buildGoModule rec { pname = "srtrelay"; diff --git a/pkgs/by-name/ss/ssb-patchwork/package.nix b/pkgs/by-name/ss/ssb-patchwork/package.nix index 6915cd1f6902ff..806af21e4f070d 100644 --- a/pkgs/by-name/ss/ssb-patchwork/package.nix +++ b/pkgs/by-name/ss/ssb-patchwork/package.nix @@ -1,4 +1,10 @@ -{ appimageTools, symlinkJoin, lib, fetchurl, makeDesktopItem }: +{ + appimageTools, + symlinkJoin, + lib, + fetchurl, + makeDesktopItem, +}: let pname = "ssb-patchwork"; @@ -29,25 +35,29 @@ let }; in - symlinkJoin { - inherit name; - paths = [ binary ]; +symlinkJoin { + inherit name; + paths = [ binary ]; - postBuild = '' - mkdir -p $out/share/pixmaps/ $out/share/applications - cp ${appimage-contents}/ssb-patchwork.png $out/share/pixmaps - cp ${desktopItem}/share/applications/* $out/share/applications/ - ''; + postBuild = '' + mkdir -p $out/share/pixmaps/ $out/share/applications + cp ${appimage-contents}/ssb-patchwork.png $out/share/pixmaps + cp ${desktopItem}/share/applications/* $out/share/applications/ + ''; - meta = with lib; { - description = "Decentralized messaging and sharing app built on top of Secure Scuttlebutt (SSB)"; - longDescription = '' - sea-slang for gossip - a scuttlebutt is basically a watercooler on a ship. - ''; - homepage = "https://www.scuttlebutt.nz/"; - license = licenses.agpl3Only; - maintainers = with maintainers; [ asymmetric picnoir cyplo ]; - mainProgram = "ssb-patchwork"; - platforms = [ "x86_64-linux" ]; - }; - } + meta = with lib; { + description = "Decentralized messaging and sharing app built on top of Secure Scuttlebutt (SSB)"; + longDescription = '' + sea-slang for gossip - a scuttlebutt is basically a watercooler on a ship. + ''; + homepage = "https://www.scuttlebutt.nz/"; + license = licenses.agpl3Only; + maintainers = with maintainers; [ + asymmetric + picnoir + cyplo + ]; + mainProgram = "ssb-patchwork"; + platforms = [ "x86_64-linux" ]; + }; +} diff --git a/pkgs/by-name/ss/ssdeep/package.nix b/pkgs/by-name/ss/ssdeep/package.nix index b3ec01ebdbbf8a..7e5e2298602c6a 100644 --- a/pkgs/by-name/ss/ssdeep/package.nix +++ b/pkgs/by-name/ss/ssdeep/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "ssdeep"; @@ -21,9 +26,9 @@ stdenv.mkDerivation rec { meta = { description = "Program for calculating fuzzy hashes"; mainProgram = "ssdeep"; - homepage = "http://www.ssdeep.sf.net"; - license = lib.licenses.gpl2Plus; - platforms = lib.platforms.unix; + homepage = "http://www.ssdeep.sf.net"; + license = lib.licenses.gpl2Plus; + platforms = lib.platforms.unix; maintainers = [ lib.maintainers.thoughtpolice ]; }; } diff --git a/pkgs/by-name/ss/sselp/package.nix b/pkgs/by-name/ss/sselp/package.nix index de083a32028d7f..87e29597f151f3 100644 --- a/pkgs/by-name/ss/sselp/package.nix +++ b/pkgs/by-name/ss/sselp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libX11 }: +{ + lib, + stdenv, + fetchurl, + libX11, +}: stdenv.mkDerivation rec { version = "0.2"; @@ -21,7 +26,7 @@ stdenv.mkDerivation rec { homepage = "https://tools.suckless.org/sselp"; description = "Prints the X selection to stdout, useful in scripts"; license = lib.licenses.mit; - maintainers = [lib.maintainers.magnetophon ]; + maintainers = [ lib.maintainers.magnetophon ]; platforms = lib.platforms.linux; mainProgram = "sselp"; }; diff --git a/pkgs/by-name/ss/ssh-agents/package.nix b/pkgs/by-name/ss/ssh-agents/package.nix index f9414d9835d368..7c15a763f42fd0 100644 --- a/pkgs/by-name/ss/ssh-agents/package.nix +++ b/pkgs/by-name/ss/ssh-agents/package.nix @@ -1,6 +1,7 @@ -{ fetchFromGitHub -, lib -, stdenvNoCC +{ + fetchFromGitHub, + lib, + stdenvNoCC, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/ss/ssh-askpass-fullscreen/package.nix b/pkgs/by-name/ss/ssh-askpass-fullscreen/package.nix index 0b192024f239ae..cb5a891355356e 100644 --- a/pkgs/by-name/ss/ssh-askpass-fullscreen/package.nix +++ b/pkgs/by-name/ss/ssh-askpass-fullscreen/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, gtk2 -, openssh -, pkg-config +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + gtk2, + openssh, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ss/ssh-chat/package.nix b/pkgs/by-name/ss/ssh-chat/package.nix index f8ae9cdb1e7563..a6592121aae9a1 100644 --- a/pkgs/by-name/ss/ssh-chat/package.nix +++ b/pkgs/by-name/ss/ssh-chat/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ssh-chat"; diff --git a/pkgs/by-name/ss/ssh-ident/package.nix b/pkgs/by-name/ss/ssh-ident/package.nix index 3886828c522102..9fad4154a6bc06 100644 --- a/pkgs/by-name/ss/ssh-ident/package.nix +++ b/pkgs/by-name/ss/ssh-ident/package.nix @@ -1,9 +1,15 @@ -{ stdenvNoCC, lib, fetchFromGitHub, python3, openssh}: +{ + stdenvNoCC, + lib, + fetchFromGitHub, + python3, + openssh, +}: stdenvNoCC.mkDerivation { pname = "ssh-ident"; version = "2016-04-21"; - src = fetchFromGitHub { + src = fetchFromGitHub { owner = "ccontavalli"; repo = "ssh-ident"; rev = "ebf8282728211dc4448d50f7e16e546ed03c22d2"; diff --git a/pkgs/by-name/ss/ssh-key-confirmer/package.nix b/pkgs/by-name/ss/ssh-key-confirmer/package.nix index 408719f746534f..7a9add923ca0d0 100644 --- a/pkgs/by-name/ss/ssh-key-confirmer/package.nix +++ b/pkgs/by-name/ss/ssh-key-confirmer/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "ssh-key-confirmer"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-CkfZ9dImjdka98eu4xuWZ6Xed7WX6DnXw81Ih7bhPm0="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Test ssh login key acceptance without having the private key"; diff --git a/pkgs/by-name/ss/ssh-mitm/package.nix b/pkgs/by-name/ss/ssh-mitm/package.nix index e17925444dea0d..d3bccbd8e4b12d 100644 --- a/pkgs/by-name/ss/ssh-mitm/package.nix +++ b/pkgs/by-name/ss/ssh-mitm/package.nix @@ -24,7 +24,6 @@ let in with py.pkgs; - buildPythonApplication rec { pname = "ssh-mitm"; version = "5.0.0"; diff --git a/pkgs/by-name/ss/ssh-openpgp-auth/daemon.nix b/pkgs/by-name/ss/ssh-openpgp-auth/daemon.nix index cd90df9cb77447..a3e0cf324ef538 100644 --- a/pkgs/by-name/ss/ssh-openpgp-auth/daemon.nix +++ b/pkgs/by-name/ss/ssh-openpgp-auth/daemon.nix @@ -9,6 +9,5 @@ callPackage ./generic.nix { version = "0.3.0"; srcHash = "sha256-IV0Nhdqyn12HDOp1jaKz3sKTI3ktFd5b6qybCLWt27I="; cargoHash = "sha256-/+lZkVMeFUMRD7NQ/MHDU5f3rkKDx1kDv5tjA41RExc="; - metaDescription = - "Command-line tool for creating and managing OpenPGP based trust anchors for SSH host keys"; + metaDescription = "Command-line tool for creating and managing OpenPGP based trust anchors for SSH host keys"; } diff --git a/pkgs/by-name/ss/ssh-openpgp-auth/generic.nix b/pkgs/by-name/ss/ssh-openpgp-auth/generic.nix index 4cfe2b6ec7c4e3..f60424416f0835 100644 --- a/pkgs/by-name/ss/ssh-openpgp-auth/generic.nix +++ b/pkgs/by-name/ss/ssh-openpgp-auth/generic.nix @@ -1,20 +1,25 @@ # This file is based upon upstream's package.nix shared among both # "ssh-openpgp-auth" and "sshd-openpgpg-auth" -{ lib -, rustPlatform -, fetchFromGitea -, pkg-config -, just -, rust-script -, installShellFiles -, nettle -, openssl -, sqlite -, stdenv -, darwin -, openssh -# Arguments not supplied by callPackage -, pname , version , srcHash , cargoHash, metaDescription +{ + lib, + rustPlatform, + fetchFromGitea, + pkg-config, + just, + rust-script, + installShellFiles, + nettle, + openssl, + sqlite, + stdenv, + darwin, + openssh, + # Arguments not supplied by callPackage + pname, + version, + srcHash, + cargoHash, + metaDescription, }: rustPlatform.buildRustPackage { @@ -54,17 +59,18 @@ rustPlatform.buildRustPackage { --zsh shell_completions/_${pname} ''; - - buildInputs = [ - nettle - openssl - sqlite - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk_11_0.frameworks.CoreFoundation - darwin.apple_sdk_11_0.frameworks.IOKit - darwin.apple_sdk_11_0.frameworks.Security - darwin.apple_sdk_11_0.frameworks.SystemConfiguration - ]; + buildInputs = + [ + nettle + openssl + sqlite + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk_11_0.frameworks.CoreFoundation + darwin.apple_sdk_11_0.frameworks.IOKit + darwin.apple_sdk_11_0.frameworks.Security + darwin.apple_sdk_11_0.frameworks.SystemConfiguration + ]; doCheck = true; nativeCheckInputs = [ @@ -74,7 +80,10 @@ rustPlatform.buildRustPackage { meta = with lib; { description = metaDescription; homepage = "https://codeberg.org/wiktor/ssh-openpgp-auth"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ doronbehar ]; mainProgram = pname; }; diff --git a/pkgs/by-name/ss/ssh-openpgp-auth/package.nix b/pkgs/by-name/ss/ssh-openpgp-auth/package.nix index 53509cc0d05c2c..a0850d3dd99bde 100644 --- a/pkgs/by-name/ss/ssh-openpgp-auth/package.nix +++ b/pkgs/by-name/ss/ssh-openpgp-auth/package.nix @@ -5,6 +5,5 @@ callPackage ./generic.nix { version = "0.2.2"; srcHash = "sha256-5ew6jT6Zr54QYaWFQIGYXd8sqC3yHHZjPfoaCossm8o="; cargoHash = "sha256-/k/XAp7PHIJaJWf4Oa1JC1mMSR5pyeM4SSPCcr77cAg="; - metaDescription = - "Command-line tool that provides client-side functionality to transparently verify the identity of remote SSH hosts"; + metaDescription = "Command-line tool that provides client-side functionality to transparently verify the identity of remote SSH hosts"; } diff --git a/pkgs/by-name/ss/ssh-to-age/package.nix b/pkgs/by-name/ss/ssh-to-age/package.nix index b65ba77ff2c1d8..c89c0026d30be1 100644 --- a/pkgs/by-name/ss/ssh-to-age/package.nix +++ b/pkgs/by-name/ss/ssh-to-age/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "ssh-to-age"; diff --git a/pkgs/by-name/ss/ssh-to-pgp/package.nix b/pkgs/by-name/ss/ssh-to-pgp/package.nix index c2cc76ef74b739..9cadd00f5694b4 100644 --- a/pkgs/by-name/ss/ssh-to-pgp/package.nix +++ b/pkgs/by-name/ss/ssh-to-pgp/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, gnupg }: +{ + lib, + fetchFromGitHub, + buildGoModule, + gnupg, +}: buildGoModule rec { pname = "ssh-to-pgp"; diff --git a/pkgs/by-name/ss/ssh-tools/package.nix b/pkgs/by-name/ss/ssh-tools/package.nix index 8d1f69ca538a7e..dc83804f6d7170 100644 --- a/pkgs/by-name/ss/ssh-tools/package.nix +++ b/pkgs/by-name/ss/ssh-tools/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitea, installShellFiles, perl }: +{ + lib, + buildGoModule, + fetchFromGitea, + installShellFiles, + perl, +}: buildGoModule rec { pname = "ssh-tools"; diff --git a/pkgs/by-name/ss/ssh-tpm-agent/package.nix b/pkgs/by-name/ss/ssh-tpm-agent/package.nix index ecffd87e944596..ca13fe9d84ba22 100644 --- a/pkgs/by-name/ss/ssh-tpm-agent/package.nix +++ b/pkgs/by-name/ss/ssh-tpm-agent/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nix-update-script -, openssl +{ + lib, + buildGoModule, + fetchFromGitHub, + nix-update-script, + openssl, }: buildGoModule rec { diff --git a/pkgs/by-name/ss/sshchecker/package.nix b/pkgs/by-name/ss/sshchecker/package.nix index 6f904f52020dd8..9aef78f6887793 100644 --- a/pkgs/by-name/ss/sshchecker/package.nix +++ b/pkgs/by-name/ss/sshchecker/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/ss/sshed/package.nix b/pkgs/by-name/ss/sshed/package.nix index ac221f49ed2b40..3927b72ce3d292 100644 --- a/pkgs/by-name/ss/sshed/package.nix +++ b/pkgs/by-name/ss/sshed/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ss/sshesame/package.nix b/pkgs/by-name/ss/sshesame/package.nix index 8f600712beccef..5006d7e7901f6b 100644 --- a/pkgs/by-name/ss/sshesame/package.nix +++ b/pkgs/by-name/ss/sshesame/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, stdenv -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + stdenv, + nix-update-script, }: buildGoModule rec { @@ -18,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-1v+cNMr2jpLPfxusPsgnFN31DwuNntXuq3sDNpWL0Rg="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; hardeningEnable = lib.optionals (!stdenv.hostPlatform.isDarwin) [ "pie" ]; diff --git a/pkgs/by-name/ss/sshfs-fuse/common.nix b/pkgs/by-name/ss/sshfs-fuse/common.nix index 3654c77cc4b860..ba1a0fd975a5d5 100644 --- a/pkgs/by-name/ss/sshfs-fuse/common.nix +++ b/pkgs/by-name/ss/sshfs-fuse/common.nix @@ -1,15 +1,31 @@ -{ version, sha256, platforms, patches ? [ ] }: +{ + version, + sha256, + platforms, + patches ? [ ], +}: -{ lib, stdenv, fetchFromGitHub -, meson, pkg-config, ninja, docutils, makeWrapper -, fuse3, macfuse-stubs, glib -, which, python3Packages -, openssh +{ + lib, + stdenv, + fetchFromGitHub, + meson, + pkg-config, + ninja, + docutils, + makeWrapper, + fuse3, + macfuse-stubs, + glib, + which, + python3Packages, + openssh, }: let fuse = if stdenv.hostPlatform.isDarwin then macfuse-stubs else fuse3; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "sshfs-fuse"; inherit version; @@ -22,20 +38,34 @@ in stdenv.mkDerivation rec { inherit patches; - nativeBuildInputs = [ meson pkg-config ninja docutils makeWrapper ]; - buildInputs = [ fuse glib ]; - nativeCheckInputs = [ which python3Packages.pytest ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + docutils + makeWrapper + ]; + buildInputs = [ + fuse + glib + ]; + nativeCheckInputs = [ + which + python3Packages.pytest + ]; - env.NIX_CFLAGS_COMPILE = lib.optionalString - (stdenv.hostPlatform.system == "i686-linux") - "-D_FILE_OFFSET_BITS=64"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.hostPlatform.system == "i686-linux" + ) "-D_FILE_OFFSET_BITS=64"; - postInstall = '' - mkdir -p $out/sbin - ln -sf $out/bin/sshfs $out/sbin/mount.sshfs - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - wrapProgram $out/bin/sshfs --prefix PATH : "${openssh}/bin" - ''; + postInstall = + '' + mkdir -p $out/sbin + ln -sf $out/bin/sshfs $out/sbin/mount.sshfs + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + wrapProgram $out/bin/sshfs --prefix PATH : "${openssh}/bin" + ''; # doCheck = true; checkPhase = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' diff --git a/pkgs/by-name/ss/sshfs-fuse/package.nix b/pkgs/by-name/ss/sshfs-fuse/package.nix index bc836ac3abada0..b6cb28aa46fc10 100644 --- a/pkgs/by-name/ss/sshfs-fuse/package.nix +++ b/pkgs/by-name/ss/sshfs-fuse/package.nix @@ -1,7 +1,14 @@ -{ lib, stdenv, callPackage, fetchpatch }: +{ + lib, + stdenv, + callPackage, + fetchpatch, +}: -let mkSSHFS = args: callPackage (import ./common.nix args) { }; -in if stdenv.hostPlatform.isDarwin then +let + mkSSHFS = args: callPackage (import ./common.nix args) { }; +in +if stdenv.hostPlatform.isDarwin then mkSSHFS { version = "2.10"; # macFUSE isn't yet compatible with libfuse 3.x sha256 = "1dmw4kx6vyawcywiv8drrajnam0m29mxfswcp4209qafzx3mjlp1"; diff --git a/pkgs/by-name/ss/sshguard/package.nix b/pkgs/by-name/ss/sshguard/package.nix index 2c5391ae449987..7ce9c6cf5b2aff 100644 --- a/pkgs/by-name/ss/sshguard/package.nix +++ b/pkgs/by-name/ss/sshguard/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, autoreconfHook, bison, flex}: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + bison, + flex, +}: stdenv.mkDerivation rec { version = "2.4.3"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { doCheck = true; - nativeBuildInputs = [ autoreconfHook bison flex ]; + nativeBuildInputs = [ + autoreconfHook + bison + flex + ]; configureFlags = [ "--sysconfdir=/etc" ]; diff --git a/pkgs/by-name/ss/sshlatex/package.nix b/pkgs/by-name/ss/sshlatex/package.nix index a163c934e46d12..2b5da221ea76bb 100644 --- a/pkgs/by-name/ss/sshlatex/package.nix +++ b/pkgs/by-name/ss/sshlatex/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, inotify-tools, openssh, perl, gnutar, bash, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + inotify-tools, + openssh, + perl, + gnutar, + bash, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "sshlatex"; @@ -13,13 +23,21 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; - installPhase = let - binPath = lib.makeBinPath [ openssh perl gnutar bash inotify-tools ]; - in '' - mkdir -p $out/bin - cp sshlatex $out/bin - wrapProgram $out/bin/sshlatex --prefix PATH : "${binPath}" - ''; + installPhase = + let + binPath = lib.makeBinPath [ + openssh + perl + gnutar + bash + inotify-tools + ]; + in + '' + mkdir -p $out/bin + cp sshlatex $out/bin + wrapProgram $out/bin/sshlatex --prefix PATH : "${binPath}" + ''; meta = with lib; { description = "Collection of hacks to efficiently run LaTeX via ssh"; @@ -31,7 +49,7 @@ stdenv.mkDerivation rec { purely local setting. ''; homepage = "https://github.com/iblech/sshlatex"; - license = lib.licenses.gpl3Plus; # actually dual-licensed gpl3Plus | lppl13cplus + license = lib.licenses.gpl3Plus; # actually dual-licensed gpl3Plus | lppl13cplus platforms = lib.platforms.all; maintainers = [ maintainers.iblech ]; mainProgram = "sshlatex"; diff --git a/pkgs/by-name/ss/sshocker/package.nix b/pkgs/by-name/ss/sshocker/package.nix index 0ace4d9e259779..412d73e7d601d2 100644 --- a/pkgs/by-name/ss/sshocker/package.nix +++ b/pkgs/by-name/ss/sshocker/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ss/sshoogr/package.nix b/pkgs/by-name/ss/sshoogr/package.nix index abd42dcb5aa42d..a10bc9b21633f4 100644 --- a/pkgs/by-name/ss/sshoogr/package.nix +++ b/pkgs/by-name/ss/sshoogr/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchzip, jdk, makeWrapper }: +{ + lib, + stdenv, + fetchzip, + jdk, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "sshoogr"; diff --git a/pkgs/by-name/ss/sshpass/package.nix b/pkgs/by-name/ss/sshpass/package.nix index 60ce32a5e74798..11ff5b8cd9ff1f 100644 --- a/pkgs/by-name/ss/sshpass/package.nix +++ b/pkgs/by-name/ss/sshpass/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "sshpass"; diff --git a/pkgs/by-name/ss/sshping/package.nix b/pkgs/by-name/ss/sshping/package.nix index 608c8125f0d2b3..0a9eb06350bc68 100644 --- a/pkgs/by-name/ss/sshping/package.nix +++ b/pkgs/by-name/ss/sshping/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchFromGitHub, libssh}: +{ + lib, + stdenv, + fetchFromGitHub, + libssh, +}: stdenv.mkDerivation rec { pname = "sshping"; @@ -14,12 +19,12 @@ stdenv.mkDerivation rec { buildInputs = [ libssh ]; buildPhase = '' - $CXX -Wall -I ext/ -o bin/sshping src/sshping.cxx -lssh - ''; + $CXX -Wall -I ext/ -o bin/sshping src/sshping.cxx -lssh + ''; installPhase = '' - install -Dm755 bin/sshping $out/bin/sshping - ''; + install -Dm755 bin/sshping $out/bin/sshping + ''; meta = with lib; { homepage = "https://github.com/spook/sshping"; diff --git a/pkgs/by-name/ss/sshportal/package.nix b/pkgs/by-name/ss/sshportal/package.nix index 58c0b5a2077f6c..850a7739eb6676 100644 --- a/pkgs/by-name/ss/sshportal/package.nix +++ b/pkgs/by-name/ss/sshportal/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "sshportal"; @@ -11,7 +15,12 @@ buildGoModule rec { sha256 = "sha256-XJ8Hgc8YoJaH2gYOvoYhcpY4qgasgyr4M+ecKJ/RXTs="; }; - ldflags = [ "-X main.GitTag=${version}" "-X main.GitSha=${version}" "-s" "-w" ]; + ldflags = [ + "-X main.GitTag=${version}" + "-X main.GitSha=${version}" + "-s" + "-w" + ]; vendorHash = "sha256-4dMZwkLHS14OGQVPq5VaT/aEpHEJ/4b2P6q3/WiDicM="; diff --git a/pkgs/by-name/ss/sshuttle/package.nix b/pkgs/by-name/ss/sshuttle/package.nix index e52453e8006d58..c51ea66a177926 100644 --- a/pkgs/by-name/ss/sshuttle/package.nix +++ b/pkgs/by-name/ss/sshuttle/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, python3Packages -, fetchFromGitHub -, installShellFiles -, makeWrapper -, sphinx -, coreutils -, iptables -, nettools -, openssh -, procps +{ + lib, + stdenv, + python3Packages, + fetchFromGitHub, + installShellFiles, + makeWrapper, + sphinx, + coreutils, + iptables, + nettools, + openssh, + procps, }: python3Packages.buildPythonApplication rec { @@ -32,7 +33,10 @@ python3Packages.buildPythonApplication rec { sphinx ]; - nativeCheckInputs = with python3Packages; [ pytest-cov-stub pytestCheckHook ]; + nativeCheckInputs = with python3Packages; [ + pytest-cov-stub + pytestCheckHook + ]; postBuild = '' make man -C docs @@ -42,7 +46,19 @@ python3Packages.buildPythonApplication rec { installManPage docs/_build/man/* wrapProgram $out/bin/sshuttle \ - --prefix PATH : "${lib.makeBinPath ([ coreutils openssh procps ] ++ lib.optionals stdenv.hostPlatform.isLinux [ iptables nettools ])}" \ + --prefix PATH : "${ + lib.makeBinPath ( + [ + coreutils + openssh + procps + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + iptables + nettools + ] + ) + }" \ ''; meta = with lib; { @@ -56,6 +72,9 @@ python3Packages.buildPythonApplication rec { homepage = "https://github.com/sshuttle/sshuttle"; changelog = "https://github.com/sshuttle/sshuttle/blob/v${version}/CHANGES.rst"; license = licenses.lgpl21Plus; - maintainers = with maintainers; [ domenkozar carlosdagos ]; + maintainers = with maintainers; [ + domenkozar + carlosdagos + ]; }; } diff --git a/pkgs/by-name/ss/ssimulacra2/package.nix b/pkgs/by-name/ss/ssimulacra2/package.nix index 9e9992f6d9368a..c06e6308c2735f 100644 --- a/pkgs/by-name/ss/ssimulacra2/package.nix +++ b/pkgs/by-name/ss/ssimulacra2/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, ninja -, cmake -, libpng -, libhwy -, lcms2 -, giflib +{ + lib, + stdenv, + fetchFromGitHub, + ninja, + cmake, + libpng, + libhwy, + lcms2, + giflib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ss/ssl-cert-check/package.nix b/pkgs/by-name/ss/ssl-cert-check/package.nix index 857fc096e06d38..77823ef9a6c890 100644 --- a/pkgs/by-name/ss/ssl-cert-check/package.nix +++ b/pkgs/by-name/ss/ssl-cert-check/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, coreutils -, fetchFromGitHub -, findutils -, gawk -, gnugrep -, gnused -, makeWrapper -, mktemp -, openssl -, which +{ + lib, + stdenv, + coreutils, + fetchFromGitHub, + findutils, + gawk, + gnugrep, + gnused, + makeWrapper, + mktemp, + openssl, + which, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ss/ssl-proxy/package.nix b/pkgs/by-name/ss/ssl-proxy/package.nix index da710379e5fc07..dae973a6833c01 100644 --- a/pkgs/by-name/ss/ssl-proxy/package.nix +++ b/pkgs/by-name/ss/ssl-proxy/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ssl-proxy"; diff --git a/pkgs/by-name/ss/ssldump/package.nix b/pkgs/by-name/ss/ssldump/package.nix index c0b38eec4aaba0..7aafa270a432ce 100644 --- a/pkgs/by-name/ss/ssldump/package.nix +++ b/pkgs/by-name/ss/ssldump/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, json_c -, libnet -, libpcap -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + json_c, + libnet, + libpcap, + openssl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ss/sslh/package.nix b/pkgs/by-name/ss/sslh/package.nix index 7f8d011edb8573..f2cd0599cc8491 100644 --- a/pkgs/by-name/ss/sslh/package.nix +++ b/pkgs/by-name/ss/sslh/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, libcap, libev, libconfig, perl, tcp_wrappers, pcre2, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + libcap, + libev, + libconfig, + perl, + tcp_wrappers, + pcre2, + nixosTests, +}: stdenv.mkDerivation rec { pname = "sslh"; @@ -13,9 +24,22 @@ stdenv.mkDerivation rec { postPatch = "patchShebangs *.sh"; - buildInputs = [ libev libconfig perl pcre2 ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libcap tcp_wrappers ]; + buildInputs = + [ + libev + libconfig + perl + pcre2 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libcap + tcp_wrappers + ]; - makeFlags = lib.optionals stdenv.hostPlatform.isLinux [ "USELIBCAP=1" "USELIBWRAP=1" ]; + makeFlags = lib.optionals stdenv.hostPlatform.isLinux [ + "USELIBCAP=1" + "USELIBWRAP=1" + ]; postInstall = '' # install all flavours @@ -37,7 +61,10 @@ stdenv.mkDerivation rec { description = "Applicative Protocol Multiplexer (e.g. share SSH and HTTPS on the same port)"; license = licenses.gpl2Plus; homepage = "https://www.rutschle.net/tech/sslh/README.html"; - maintainers = with maintainers; [ koral fpletz ]; + maintainers = with maintainers; [ + koral + fpletz + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/ss/sslmate-agent/package.nix b/pkgs/by-name/ss/sslmate-agent/package.nix index e605f8673241f6..f9001d176650b3 100644 --- a/pkgs/by-name/ss/sslmate-agent/package.nix +++ b/pkgs/by-name/ss/sslmate-agent/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, dpkg, autoPatchelfHook }: +{ + lib, + stdenv, + fetchurl, + dpkg, + autoPatchelfHook, +}: stdenv.mkDerivation rec { pname = "sslmate-agent"; diff --git a/pkgs/by-name/ss/sslmate/package.nix b/pkgs/by-name/ss/sslmate/package.nix index 2dded22da82f8b..19987e1d08f716 100644 --- a/pkgs/by-name/ss/sslmate/package.nix +++ b/pkgs/by-name/ss/sslmate/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, perlPackages, makeWrapper, openssl }: +{ + lib, + stdenv, + fetchurl, + perlPackages, + makeWrapper, + openssl, +}: stdenv.mkDerivation rec { pname = "sslmate"; @@ -16,11 +23,14 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/sslmate --prefix PERL5LIB : \ - "${with perlPackages; makePerlPath [ - URI - JSONPP - TermReadKey - ]}" \ + "${ + with perlPackages; + makePerlPath [ + URI + JSONPP + TermReadKey + ] + }" \ --prefix PATH : "${openssl.bin}/bin" ''; diff --git a/pkgs/by-name/ss/sslsplit/package.nix b/pkgs/by-name/ss/sslsplit/package.nix index ca8a96d3321f43..3f1a8fd9e8b7f1 100644 --- a/pkgs/by-name/ss/sslsplit/package.nix +++ b/pkgs/by-name/ss/sslsplit/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, openssl, libevent, libpcap, libnet, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + openssl, + libevent, + libpcap, + libnet, + zlib, +}: stdenv.mkDerivation rec { pname = "sslsplit"; @@ -19,7 +29,13 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ openssl libevent libpcap libnet zlib ]; + buildInputs = [ + openssl + libevent + libpcap + libnet + zlib + ]; makeFlags = [ "PREFIX=$(out)" @@ -34,7 +50,12 @@ stdenv.mkDerivation rec { homepage = "https://www.roe.ch/SSLsplit"; platforms = platforms.all; maintainers = with maintainers; [ contrun ]; - license = with licenses; [ bsd2 mit unlicense free ]; + license = with licenses; [ + bsd2 + mit + unlicense + free + ]; mainProgram = "sslsplit"; }; } diff --git a/pkgs/by-name/ss/sslstrip/package.nix b/pkgs/by-name/ss/sslstrip/package.nix index c9ad3406667f2d..66f83371802841 100644 --- a/pkgs/by-name/ss/sslstrip/package.nix +++ b/pkgs/by-name/ss/sslstrip/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -33,7 +34,7 @@ python3.pkgs.buildPythonApplication rec { ]; # Project has no test - doCheck= false; + doCheck = false; pythonImportsCheck = [ "sslstrip" diff --git a/pkgs/by-name/ss/ssm-session-manager-plugin/package.nix b/pkgs/by-name/ss/ssm-session-manager-plugin/package.nix index 3f571b44c78c2b..a15ca65be19dc1 100644 --- a/pkgs/by-name/ss/ssm-session-manager-plugin/package.nix +++ b/pkgs/by-name/ss/ssm-session-manager-plugin/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, fetchpatch +{ + lib, + fetchFromGitHub, + buildGoModule, + fetchpatch, }: buildGoModule rec { pname = "ssm-session-manager-plugin"; @@ -71,6 +72,9 @@ buildGoModule rec { description = "Amazon SSM Session Manager Plugin"; mainProgram = "session-manager-plugin"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ amarshall mbaillie ]; + maintainers = with lib.maintainers; [ + amarshall + mbaillie + ]; }; } diff --git a/pkgs/by-name/ss/ssmsh/package.nix b/pkgs/by-name/ss/ssmsh/package.nix index d685abcd367d56..e613ec7c0b7aec 100644 --- a/pkgs/by-name/ss/ssmsh/package.nix +++ b/pkgs/by-name/ss/ssmsh/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, ssmsh }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + ssmsh, +}: buildGoModule rec { pname = "ssmsh"; @@ -15,7 +21,11 @@ buildGoModule rec { doCheck = true; - ldflags = [ "-w" "-s" "-X main.Version=${version}" ]; + ldflags = [ + "-w" + "-s" + "-X main.Version=${version}" + ]; passthru.tests = testers.testVersion { package = ssmsh; diff --git a/pkgs/by-name/ss/ssocr/package.nix b/pkgs/by-name/ss/ssocr/package.nix index 520ea84ebd9959..fc3af8db2e266b 100644 --- a/pkgs/by-name/ss/ssocr/package.nix +++ b/pkgs/by-name/ss/ssocr/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, imlib2, libX11, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + imlib2, + libX11, + pkg-config, +}: stdenv.mkDerivation rec { pname = "ssocr"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ imlib2 libX11 ]; + buildInputs = [ + imlib2 + libX11 + ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/ss/ssrc/package.nix b/pkgs/by-name/ss/ssrc/package.nix index 73fd622fbeb23f..0b8a453d80b3c2 100644 --- a/pkgs/by-name/ss/ssrc/package.nix +++ b/pkgs/by-name/ss/ssrc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "ssrc"; @@ -14,7 +18,7 @@ stdenv.mkDerivation rec { installPhase = '' mkdir -p $out/bin cp ssrc ssrc_hp $out/bin - ''; + ''; meta = with lib; { description = "High quality audio sampling rate converter"; @@ -35,7 +39,7 @@ stdenv.mkDerivation rec { version = version; homepage = "https://shibatch.sourceforge.net/"; license = licenses.gpl2; - maintainers = with maintainers; [ leenaars]; + maintainers = with maintainers; [ leenaars ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/ss/sss-cli/package.nix b/pkgs/by-name/ss/sss-cli/package.nix index 80daa4a6627ea0..0c7db346097f0d 100644 --- a/pkgs/by-name/ss/sss-cli/package.nix +++ b/pkgs/by-name/ss/sss-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ss/sssnake/package.nix b/pkgs/by-name/ss/sssnake/package.nix index ee3aefef695402..9f1b12a5dc0e4a 100644 --- a/pkgs/by-name/ss/sssnake/package.nix +++ b/pkgs/by-name/ss/sssnake/package.nix @@ -16,7 +16,7 @@ stdenv.mkDerivation rec { postPatch = '' substituteInPlace makefile --replace '-lncursesw' '-lncursesw -D_XOPEN_SOURCE=500' ''; - buildInputs = [ncurses]; + buildInputs = [ ncurses ]; makeFlags = [ "PREFIX=$(out)" ]; @@ -24,8 +24,8 @@ stdenv.mkDerivation rec { description = "Cli snake game that plays itself"; mainProgram = "sssnake"; homepage = "https://github.com/angeljumbo/sssnake"; - license = with licenses; [mit]; + license = with licenses; [ mit ]; platforms = platforms.unix; - maintainers = with maintainers; [quantenzitrone]; + maintainers = with maintainers; [ quantenzitrone ]; }; } diff --git a/pkgs/by-name/ss/ssss/package.nix b/pkgs/by-name/ss/ssss/package.nix index 9d7b1a894b5b5d..5325b37a5c5195 100644 --- a/pkgs/by-name/ss/ssss/package.nix +++ b/pkgs/by-name/ss/ssss/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, gmp -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + gmp, + installShellFiles, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ss/sstp/package.nix b/pkgs/by-name/ss/sstp/package.nix index e6ae2fa0f5234c..e7a43499895001 100644 --- a/pkgs/by-name/ss/sstp/package.nix +++ b/pkgs/by-name/ss/sstp/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitLab, pkg-config, ppp, libevent, openssl, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + ppp, + libevent, + openssl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "sstp-client"; @@ -22,9 +31,16 @@ stdenv.mkDerivation rec { "--with-pppd-plugin-dir=$(out)/lib/pppd" ]; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; - buildInputs = [ libevent openssl ppp ]; + buildInputs = [ + libevent + openssl + ppp + ]; meta = with lib; { description = "SSTP client for Linux"; diff --git a/pkgs/by-name/ss/ssw/package.nix b/pkgs/by-name/ss/ssw/package.nix index e94c84209fcded..17376013b34c84 100644 --- a/pkgs/by-name/ss/ssw/package.nix +++ b/pkgs/by-name/ss/ssw/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, gtk3 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk3, +}: stdenv.mkDerivation rec { pname = "ssw"; diff --git a/pkgs/by-name/st/sta/package.nix b/pkgs/by-name/st/sta/package.nix index 8e39afa5d42356..64cbc1d4745abd 100644 --- a/pkgs/by-name/st/sta/package.nix +++ b/pkgs/by-name/st/sta/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/st/stabber/package.nix b/pkgs/by-name/st/stabber/package.nix index 5ca07007d14ae4..a2d3a8c6587eef 100644 --- a/pkgs/by-name/st/stabber/package.nix +++ b/pkgs/by-name/st/stabber/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, glib, expat -, libmicrohttpd, darwin +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + glib, + expat, + libmicrohttpd, + darwin, }: stdenv.mkDerivation { pname = "stabber-unstable"; @@ -21,9 +29,15 @@ stdenv.mkDerivation { mkdir m4 ''; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ glib expat libmicrohttpd ] ++ - lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Security ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + glib + expat + libmicrohttpd + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Security ]; meta = with lib; { description = "Stubbed XMPP Server"; diff --git a/pkgs/by-name/st/stackit-cli/package.nix b/pkgs/by-name/st/stackit-cli/package.nix index 84a53d4ba3a601..a3f132d4c60e10 100644 --- a/pkgs/by-name/st/stackit-cli/package.nix +++ b/pkgs/by-name/st/stackit-cli/package.nix @@ -1,12 +1,13 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, makeWrapper -, less -, xdg-utils -, testers -, stackit-cli +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + makeWrapper, + less, + xdg-utils, + testers, + stackit-cli, }: buildGoModule rec { @@ -32,7 +33,10 @@ buildGoModule rec { "-X main.version=${version}" ]; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; postInstall = '' mv $out/bin/{stackit-cli,stackit} # rename the binary @@ -47,7 +51,12 @@ buildGoModule rec { postFixup = '' wrapProgram $out/bin/stackit \ - --suffix PATH : ${lib.makeBinPath [ less xdg-utils ]} + --suffix PATH : ${ + lib.makeBinPath [ + less + xdg-utils + ] + } ''; nativeCheckInputs = [ less ]; diff --git a/pkgs/by-name/st/stacks/package.nix b/pkgs/by-name/st/stacks/package.nix index ddaa6bafd5fd8a..bdc5e929bb1117 100644 --- a/pkgs/by-name/st/stacks/package.nix +++ b/pkgs/by-name/st/stacks/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, zlib }: +{ + lib, + stdenv, + fetchurl, + zlib, +}: stdenv.mkDerivation rec { pname = "stacks"; diff --git a/pkgs/by-name/st/stacktile/package.nix b/pkgs/by-name/st/stacktile/package.nix index 073794e42b989b..87579d3caba129 100644 --- a/pkgs/by-name/st/stacktile/package.nix +++ b/pkgs/by-name/st/stacktile/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromSourcehut -, wayland -, wayland-scanner +{ + lib, + stdenv, + fetchFromSourcehut, + wayland, + wayland-scanner, }: stdenv.mkDerivation (finalAttrs: { @@ -16,7 +17,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-IOFxgYMjh92jx2CPfBRZDL/1ucgfHtUyAL5rS2EG+Gc="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; nativeBuildInputs = [ wayland-scanner diff --git a/pkgs/by-name/st/stacs/package.nix b/pkgs/by-name/st/stacs/package.nix index da66dca1cbd32e..7cc6c87151c0e5 100644 --- a/pkgs/by-name/st/stacs/package.nix +++ b/pkgs/by-name/st/stacs/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/st/stagit/package.nix b/pkgs/by-name/st/stagit/package.nix index 05ea0d2e03e6f8..03a038da51bb2d 100644 --- a/pkgs/by-name/st/stagit/package.nix +++ b/pkgs/by-name/st/stagit/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, libgit2, fetchgit }: +{ + lib, + stdenv, + libgit2, + fetchgit, +}: stdenv.mkDerivation rec { pname = "stagit"; @@ -19,6 +24,9 @@ stdenv.mkDerivation rec { homepage = "https://git.codemadness.org/stagit/file/README.html"; license = licenses.mit; platforms = platforms.all; - maintainers = with maintainers; [ jb55 sikmir ]; + maintainers = with maintainers; [ + jb55 + sikmir + ]; }; } diff --git a/pkgs/by-name/st/stalin/package.nix b/pkgs/by-name/st/stalin/package.nix index 245ebdb0c6cb95..1c341ca1166ff4 100644 --- a/pkgs/by-name/st/stalin/package.nix +++ b/pkgs/by-name/st/stalin/package.nix @@ -1,4 +1,10 @@ -{ fetchurl, lib, stdenv, ncompress, libX11 }: +{ + fetchurl, + lib, + stdenv, + ncompress, + libX11, +}: stdenv.mkDerivation rec { pname = "stalin"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "0lz8riccpigdixwf6dswwva6s4kxaz3dzxhkqhcxgwmffy30vw8s"; }; - buildInputs = [ ncompress libX11 ]; + buildInputs = [ + ncompress + libX11 + ]; buildPhase = "./build "; @@ -41,6 +50,6 @@ stdenv.mkDerivation rec { description = "Optimizing Scheme compiler"; maintainers = [ ]; - platforms = ["i686-linux"]; # doesn't want to work on 64-bit platforms + platforms = [ "i686-linux" ]; # doesn't want to work on 64-bit platforms }; } diff --git a/pkgs/by-name/st/stalonetray/package.nix b/pkgs/by-name/st/stalonetray/package.nix index 45160d65dbc653..c2ce921da8e779 100644 --- a/pkgs/by-name/st/stalonetray/package.nix +++ b/pkgs/by-name/st/stalonetray/package.nix @@ -1,12 +1,13 @@ -{ autoreconfHook -, docbook_xml_dtd_44 -, docbook-xsl-ns -, fetchFromGitHub -, lib -, libX11 -, libXpm -, libxslt -, stdenv +{ + autoreconfHook, + docbook_xml_dtd_44, + docbook-xsl-ns, + fetchFromGitHub, + lib, + libX11, + libXpm, + libxslt, + stdenv, }: stdenv.mkDerivation rec { @@ -26,9 +27,9 @@ stdenv.mkDerivation rec { ac_str = "AC_SUBST(DOCBOOK_ROOT)"; ac_str_sub = "DOCBOOK_ROOT=${db_root}; ${ac_str}"; in - '' - substituteInPlace configure.ac --replace '${ac_str}' '${ac_str_sub}' - ''; + '' + substituteInPlace configure.ac --replace '${ac_str}' '${ac_str_sub}' + ''; nativeBuildInputs = [ autoreconfHook diff --git a/pkgs/by-name/st/star-history/package.nix b/pkgs/by-name/st/star-history/package.nix index 6c2ee875b68a77..da9d1bafd0570a 100644 --- a/pkgs/by-name/st/star-history/package.nix +++ b/pkgs/by-name/st/star-history/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, darwin -, fetchCrate -, pkg-config -, openssl -, stdenv +{ + lib, + rustPlatform, + darwin, + fetchCrate, + pkg-config, + openssl, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -20,14 +21,19 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; meta = with lib; { description = "Command line program to generate a graph showing number of GitHub stars of a user, org or repo over time"; homepage = "https://github.com/dtolnay/star-history"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "star-history"; }; diff --git a/pkgs/by-name/st/star/package.nix b/pkgs/by-name/st/star/package.nix index 3383a78e1d3845..7b2d3405afd55b 100644 --- a/pkgs/by-name/st/star/package.nix +++ b/pkgs/by-name/st/star/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, +}: stdenv.mkDerivation rec { pname = "star"; @@ -19,7 +24,10 @@ stdenv.mkDerivation rec { buildInputs = [ zlib ]; - buildFlags = [ "STAR" "STARlong" ]; + buildFlags = [ + "STAR" + "STARlong" + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/st/starboard/package.nix b/pkgs/by-name/st/starboard/package.nix index f16c1497b46ffa..d02839922187a7 100644 --- a/pkgs/by-name/st/starboard/package.nix +++ b/pkgs/by-name/st/starboard/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "starboard"; diff --git a/pkgs/by-name/st/starcharts/package.nix b/pkgs/by-name/st/starcharts/package.nix index c866f18b2c6af0..48e051049aad04 100644 --- a/pkgs/by-name/st/starcharts/package.nix +++ b/pkgs/by-name/st/starcharts/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/st/stardust/package.nix b/pkgs/by-name/st/stardust/package.nix index df9b2ca190c2f4..53d67ab628d0a2 100644 --- a/pkgs/by-name/st/stardust/package.nix +++ b/pkgs/by-name/st/stardust/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchurl, zlib, libtiff, libxml2, SDL, xorgproto, libX11 -, libXi, libXmu, libXext, libGLU, libGL }: +{ + lib, + stdenv, + fetchurl, + zlib, + libtiff, + libxml2, + SDL, + xorgproto, + libX11, + libXi, + libXmu, + libXext, + libGLU, + libGL, +}: stdenv.mkDerivation rec { pname = "stardust"; @@ -11,8 +25,17 @@ stdenv.mkDerivation rec { }; buildInputs = [ - zlib libtiff libxml2 SDL xorgproto libX11 libXi - libXmu libXext libGLU libGL + zlib + libtiff + libxml2 + SDL + xorgproto + libX11 + libXi + libXmu + libXext + libGLU + libGL ]; installFlags = [ "bindir=\${out}/bin" ]; diff --git a/pkgs/by-name/st/starfetch/package.nix b/pkgs/by-name/st/starfetch/package.nix index 962409d21763e4..34694aa9513609 100644 --- a/pkgs/by-name/st/starfetch/package.nix +++ b/pkgs/by-name/st/starfetch/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "starfetch"; @@ -11,11 +15,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-I2M/FlLRkGtD2+GcK1l5+vFsb5tCb4T3UJTPxRx68Ww="; }; - postPatch = '' - substituteInPlace src/starfetch.cpp --replace /usr/local/ $out/ - '' + lib.optionalString stdenv.cc.isClang '' - substituteInPlace makefile --replace g++ clang++ - ''; + postPatch = + '' + substituteInPlace src/starfetch.cpp --replace /usr/local/ $out/ + '' + + lib.optionalString stdenv.cc.isClang '' + substituteInPlace makefile --replace g++ clang++ + ''; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/st/stargate-libcds/package.nix b/pkgs/by-name/st/stargate-libcds/package.nix index c37365652e725d..362abbd11d168d 100644 --- a/pkgs/by-name/st/stargate-libcds/package.nix +++ b/pkgs/by-name/st/stargate-libcds/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchpatch -, fetchFromGitHub +{ + lib, + stdenv, + fetchpatch, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/st/starlark-rust/package.nix b/pkgs/by-name/st/starlark-rust/package.nix index 499114b3f25819..8c343115e4cd89 100644 --- a/pkgs/by-name/st/starlark-rust/package.nix +++ b/pkgs/by-name/st/starlark-rust/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/st/starry/package.nix b/pkgs/by-name/st/starry/package.nix index cb6535baf3acc6..fc5b7fb2b65843 100644 --- a/pkgs/by-name/st/starry/package.nix +++ b/pkgs/by-name/st/starry/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -22,11 +23,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; meta = with lib; { description = "Current stars history tells only half the story"; diff --git a/pkgs/by-name/st/staruml/package.nix b/pkgs/by-name/st/staruml/package.nix index cf5574be84b022..f3c40c6eff6f85 100644 --- a/pkgs/by-name/st/staruml/package.nix +++ b/pkgs/by-name/st/staruml/package.nix @@ -1,25 +1,61 @@ -{ stdenv, lib, fetchurl -, dpkg, wrapGAppsHook3 -, hicolor-icon-theme -, gtk3, glib, systemd -, xorg, nss, nspr -, atk, at-spi2-atk, dbus -, gdk-pixbuf, pango, cairo -, expat, libdrm, mesa -, alsa-lib, at-spi2-core, cups -, libxkbcommon }: +{ + stdenv, + lib, + fetchurl, + dpkg, + wrapGAppsHook3, + hicolor-icon-theme, + gtk3, + glib, + systemd, + xorg, + nss, + nspr, + atk, + at-spi2-atk, + dbus, + gdk-pixbuf, + pango, + cairo, + expat, + libdrm, + mesa, + alsa-lib, + at-spi2-core, + cups, + libxkbcommon, +}: let LD_LIBRARY_PATH = lib.makeLibraryPath [ - glib gtk3 xorg.libXdamage - xorg.libX11 xorg.libxcb xorg.libXcomposite - xorg.libXcursor xorg.libXext xorg.libXfixes - xorg.libXi xorg.libXrender xorg.libXtst - xorg.libxshmfence libxkbcommon nss - nspr atk at-spi2-atk - dbus gdk-pixbuf pango cairo - xorg.libXrandr expat libdrm - mesa alsa-lib at-spi2-core + glib + gtk3 + xorg.libXdamage + xorg.libX11 + xorg.libxcb + xorg.libXcomposite + xorg.libXcursor + xorg.libXext + xorg.libXfixes + xorg.libXi + xorg.libXrender + xorg.libXtst + xorg.libxshmfence + libxkbcommon + nss + nspr + atk + at-spi2-atk + dbus + gdk-pixbuf + pango + cairo + xorg.libXrandr + expat + libdrm + mesa + alsa-lib + at-spi2-core cups ]; in @@ -28,12 +64,18 @@ stdenv.mkDerivation (finalAttrs: { pname = "staruml"; src = fetchurl { - url = "https://files.staruml.io/releases-v6/StarUML_${finalAttrs.version}_amd64.deb"; - sha256 = "sha256-G63MxjefAJ0J40HzrI9j/sRkHLIdUzBf0GSbw6fAFoI="; - }; + url = "https://files.staruml.io/releases-v6/StarUML_${finalAttrs.version}_amd64.deb"; + sha256 = "sha256-G63MxjefAJ0J40HzrI9j/sRkHLIdUzBf0GSbw6fAFoI="; + }; - nativeBuildInputs = [ wrapGAppsHook3 dpkg ]; - buildInputs = [ glib hicolor-icon-theme ]; + nativeBuildInputs = [ + wrapGAppsHook3 + dpkg + ]; + buildInputs = [ + glib + hicolor-icon-theme + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/st/static-server/package.nix b/pkgs/by-name/st/static-server/package.nix index 3be8eec4b80df5..443d6b9c71704c 100644 --- a/pkgs/by-name/st/static-server/package.nix +++ b/pkgs/by-name/st/static-server/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, curl -, stdenv -, testers -, static-server -, substituteAll +{ + lib, + buildGoModule, + fetchFromGitHub, + curl, + stdenv, + testers, + static-server, + substituteAll, }: buildGoModule rec { @@ -33,7 +34,10 @@ buildGoModule rec { curl ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; # tests sometimes fail with SIGQUIT on darwin doCheck = !stdenv.hostPlatform.isDarwin; diff --git a/pkgs/by-name/st/statifier/package.nix b/pkgs/by-name/st/statifier/package.nix index 9c00cdab40164a..763e1f6a759f10 100644 --- a/pkgs/by-name/st/statifier/package.nix +++ b/pkgs/by-name/st/statifier/package.nix @@ -1,4 +1,8 @@ -{ lib, multiStdenv, fetchurl }: +{ + lib, + multiStdenv, + fetchurl, +}: multiStdenv.mkDerivation rec { pname = "statifier"; @@ -9,7 +13,10 @@ multiStdenv.mkDerivation rec { sha256 = "03lzkla6knjhh186b43cac410x2fmhi28pkmzb3d211n3zp5i9y8"; }; - phaseNames = [ "patchPhase" "installPhase" ]; + phaseNames = [ + "patchPhase" + "installPhase" + ]; postPatch = '' sed -e s@/usr/@"$out/"@g -i */Makefile src/statifier diff --git a/pkgs/by-name/st/statik/package.nix b/pkgs/by-name/st/statik/package.nix index 5dec08d0d6e6eb..8c965a73220d32 100644 --- a/pkgs/by-name/st/statik/package.nix +++ b/pkgs/by-name/st/statik/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "statik"; @@ -14,7 +18,10 @@ buildGoModule rec { vendorHash = null; # Avoid building example - subPackages = [ "." "fs" ]; + subPackages = [ + "." + "fs" + ]; # Tests are checking that the files embedded are preserving # their meta data like dates etc, but it assumes to be in 2048 # which is not the case once entered the nix store diff --git a/pkgs/by-name/st/station/package.nix b/pkgs/by-name/st/station/package.nix index c1a4dab8f70948..7e9391b6866f14 100644 --- a/pkgs/by-name/st/station/package.nix +++ b/pkgs/by-name/st/station/package.nix @@ -1,4 +1,8 @@ -{ appimageTools, fetchurl, lib }: +{ + appimageTools, + fetchurl, + lib, +}: let pname = "station"; @@ -12,7 +16,8 @@ let appimageContents = appimageTools.extractType2 { inherit pname version src; }; -in appimageTools.wrapType2 rec { +in +appimageTools.wrapType2 rec { inherit pname version src; profile = '' diff --git a/pkgs/by-name/st/statix/package.nix b/pkgs/by-name/st/statix/package.nix index 079459f2a2d0b0..8aa5d23e4c93a1 100644 --- a/pkgs/by-name/st/statix/package.nix +++ b/pkgs/by-name/st/statix/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, withJson ? true, stdenv }: +{ + lib, + rustPlatform, + fetchFromGitHub, + withJson ? true, + stdenv, +}: rustPlatform.buildRustPackage rec { pname = "statix"; @@ -26,6 +32,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/nerdypepper/statix"; license = licenses.mit; mainProgram = "statix"; - maintainers = with maintainers; [ figsoda nerdypepper ]; + maintainers = with maintainers; [ + figsoda + nerdypepper + ]; }; } diff --git a/pkgs/by-name/st/statserial/package.nix b/pkgs/by-name/st/statserial/package.nix index 129cf9ad504ce1..47246ec03bf31c 100644 --- a/pkgs/by-name/st/statserial/package.nix +++ b/pkgs/by-name/st/statserial/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, ncurses, glibc }: +{ + lib, + stdenv, + fetchurl, + ncurses, + glibc, +}: stdenv.mkDerivation rec { pname = "statserial"; @@ -17,14 +23,17 @@ stdenv.mkDerivation rec { --replace 'LDFLAGS = -s -N' '#LDFLAGS = -s -N' ''; - buildInputs = [ ncurses glibc ]; + buildInputs = [ + ncurses + glibc + ]; installPhase = '' - mkdir -p $out/bin - cp statserial $out/bin + mkdir -p $out/bin + cp statserial $out/bin - mkdir -p $out/share/man/man1 - cp statserial.1 $out/share/man/man1 + mkdir -p $out/share/man/man1 + cp statserial.1 $out/share/man/man1 ''; meta = with lib; { diff --git a/pkgs/by-name/st/status-im/package.nix b/pkgs/by-name/st/status-im/package.nix index 914050e1dfd663..e027265882df6b 100644 --- a/pkgs/by-name/st/status-im/package.nix +++ b/pkgs/by-name/st/status-im/package.nix @@ -27,14 +27,15 @@ let exec = "status-desktop"; icon = "status"; comment = "Desktop client for the Status Network"; - categories = ["Network"]; + categories = [ "Network" ]; }; icon = fetchurl { url = "https://github.com/status-im/status-desktop/raw/afde83651724a555626b5d9a3d582918de6c3d59/status.png"; hash = "sha256-ViGuOr9LskGs/P7pjPO9zYgosWaZlZZYVuPpliOA5dY="; }; pname = "status-desktop"; -in appimageTools.wrapType2 { +in +appimageTools.wrapType2 { inherit pname version src; extraInstallCommands = '' install -m 444 -D ${desktopEntry}/share/applications/status.desktop $out/share/applications/status.desktop @@ -43,7 +44,7 @@ in appimageTools.wrapType2 { meta = with lib; { description = "Desktop client for the Status Network"; license = licenses.mpl20; - maintainers = with maintainers; [ a-kenji ]; + maintainers = with maintainers; [ a-kenji ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/st/stb/package.nix b/pkgs/by-name/st/stb/package.nix index 5e3cc62ea41b8e..40b79f6259bc3b 100644 --- a/pkgs/by-name/st/stb/package.nix +++ b/pkgs/by-name/st/stb/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, copyPkgconfigItems, makePkgconfigItem }: +{ + lib, + stdenv, + fetchFromGitHub, + copyPkgconfigItems, + makePkgconfigItem, +}: stdenv.mkDerivation rec { pname = "stb"; diff --git a/pkgs/by-name/st/stc-cli/package.nix b/pkgs/by-name/st/stc-cli/package.nix index d04fe5293c3a58..46187cda994dd6 100644 --- a/pkgs/by-name/st/stc-cli/package.nix +++ b/pkgs/by-name/st/stc-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "stc"; diff --git a/pkgs/by-name/st/stderred/package.nix b/pkgs/by-name/st/stderred/package.nix index f159e4328c9c49..b237853616859d 100644 --- a/pkgs/by-name/st/stderred/package.nix +++ b/pkgs/by-name/st/stderred/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, fetchFromGitHub -, cmake -, lib +{ + stdenv, + fetchFromGitHub, + cmake, + lib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/st/stdman/package.nix b/pkgs/by-name/st/stdman/package.nix index e934271b1671ae..56b1bcd5a7b283 100644 --- a/pkgs/by-name/st/stdman/package.nix +++ b/pkgs/by-name/st/stdman/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, curl, fetchFromGitHub }: +{ + lib, + stdenv, + curl, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "stdman"; diff --git a/pkgs/by-name/st/stdmanpages/package.nix b/pkgs/by-name/st/stdmanpages/package.nix index 1fd83700f85a0a..812c71f5c68e5d 100644 --- a/pkgs/by-name/st/stdmanpages/package.nix +++ b/pkgs/by-name/st/stdmanpages/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchurl }: +{ + stdenv, + lib, + fetchurl, +}: stdenv.mkDerivation rec { pname = "std-man-pages"; diff --git a/pkgs/by-name/st/stduuid/package.nix b/pkgs/by-name/st/stduuid/package.nix index d11f9b753c2a7a..a0a2ce6d9faed6 100644 --- a/pkgs/by-name/st/stduuid/package.nix +++ b/pkgs/by-name/st/stduuid/package.nix @@ -1,6 +1,14 @@ -{ stdenv, cmake, fetchFromGitHub, fetchpatch, lib }: let +{ + stdenv, + cmake, + fetchFromGitHub, + fetchpatch, + lib, +}: +let version = "1.2.3"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "stduuid"; inherit version; diff --git a/pkgs/by-name/st/steam-acf/package.nix b/pkgs/by-name/st/steam-acf/package.nix index 7028ed33a39b46..664ff5f465860e 100644 --- a/pkgs/by-name/st/steam-acf/package.nix +++ b/pkgs/by-name/st/steam-acf/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "steam-acf"; @@ -16,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Tool to convert Steam .acf files to JSON"; homepage = "https://github.com/chisui/acf"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ chisui ]; mainProgram = "acf"; }; diff --git a/pkgs/by-name/st/steam-play-none/package.nix b/pkgs/by-name/st/steam-play-none/package.nix index 5585d1aa3cb09d..040c6869b14470 100644 --- a/pkgs/by-name/st/steam-play-none/package.nix +++ b/pkgs/by-name/st/steam-play-none/package.nix @@ -1,7 +1,8 @@ -{ fetchFromGitHub -, stdenvNoCC -, lib -, bash +{ + fetchFromGitHub, + stdenvNoCC, + lib, + bash, }: stdenvNoCC.mkDerivation (finalAttrs: { pname = "steam-play-none"; @@ -14,7 +15,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { }; buildInputs = [ bash ]; strictDeps = true; - outputs = [ "out" "steamcompattool" ]; + outputs = [ + "out" + "steamcompattool" + ]; installPhase = '' runHook preInstall @@ -36,7 +40,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { ''; homepage = "https://github.com/Scrumplex/Steam-Play-None"; license = lib.licenses.cc0; - maintainers = with lib.maintainers; [ matthewcroughan Scrumplex ]; + maintainers = with lib.maintainers; [ + matthewcroughan + Scrumplex + ]; platforms = [ "x86_64-linux" ]; }; }) diff --git a/pkgs/by-name/st/steam-unwrapped/package.nix b/pkgs/by-name/st/steam-unwrapped/package.nix index aff83ec2ef5561..98e1ee15ac45bd 100644 --- a/pkgs/by-name/st/steam-unwrapped/package.nix +++ b/pkgs/by-name/st/steam-unwrapped/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, bash }: +{ + lib, + stdenv, + fetchurl, + bash, +}: stdenv.mkDerivation (finalAttrs: { pname = "steam-unwrapped"; @@ -10,7 +15,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-Gia5182s4J4E3Ia1EeC5kjJX9mSltsr+b+1eRtEXtPk="; }; - makeFlags = [ "DESTDIR=$(out)" "PREFIX=" ]; + makeFlags = [ + "DESTDIR=$(out)" + "PREFIX=" + ]; postInstall = '' rm $out/bin/steamdeps diff --git a/pkgs/by-name/st/steamcmd/package.nix b/pkgs/by-name/st/steamcmd/package.nix index 69d5cd8a7863c8..5eda455f61ed51 100644 --- a/pkgs/by-name/st/steamcmd/package.nix +++ b/pkgs/by-name/st/steamcmd/package.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchurl, steam-run, bash, coreutils -, steamRoot ? "~/.local/share/Steam" +{ + lib, + stdenv, + fetchurl, + steam-run, + bash, + coreutils, + steamRoot ? "~/.local/share/Steam", }: stdenv.mkDerivation { @@ -18,7 +24,10 @@ stdenv.mkDerivation { sourceRoot=. ''; - buildInputs = [ bash steam-run ]; + buildInputs = [ + bash + steam-run + ]; dontBuild = true; diff --git a/pkgs/by-name/st/steamcontroller/package.nix b/pkgs/by-name/st/steamcontroller/package.nix index cd2563779d6fed..92f3fcb1aff349 100644 --- a/pkgs/by-name/st/steamcontroller/package.nix +++ b/pkgs/by-name/st/steamcontroller/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, python3Packages, libusb1, linuxHeaders +{ + lib, + fetchFromGitHub, + python3Packages, + libusb1, + linuxHeaders, }: with python3Packages; @@ -8,9 +13,9 @@ buildPythonApplication { version = "2017-08-11"; src = fetchFromGitHub { - owner = "ynsta"; - repo = "steamcontroller"; - rev = "80928ce237925e0d0d7a65a45b481435ba6b931e"; + owner = "ynsta"; + repo = "steamcontroller"; + rev = "80928ce237925e0d0d7a65a45b481435ba6b931e"; sha256 = "0lv9j2zv8fmkmc0x9r7fa8zac2xrwfczms35qz1nfa1hr84wniid"; }; @@ -20,15 +25,18 @@ buildPythonApplication { ''; buildInputs = [ libusb1 ]; - propagatedBuildInputs = [ psutil python3Packages.libusb1 ]; + propagatedBuildInputs = [ + psutil + python3Packages.libusb1 + ]; doCheck = false; pythonImportsCheck = [ "steamcontroller" ]; meta = with lib; { description = "Standalone Steam controller driver"; - homepage = "https://github.com/ynsta/steamcontroller"; - license = licenses.mit; + homepage = "https://github.com/ynsta/steamcontroller"; + license = licenses.mit; maintainers = with maintainers; [ rnhmjoj ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/st/steamguard-cli/package.nix b/pkgs/by-name/st/steamguard-cli/package.nix index 5293f90e7ebd1e..9e8dd22612d36a 100644 --- a/pkgs/by-name/st/steamguard-cli/package.nix +++ b/pkgs/by-name/st/steamguard-cli/package.nix @@ -1,8 +1,9 @@ -{ installShellFiles -, lib -, rustPlatform -, fetchFromGitHub -, stdenv +{ + installShellFiles, + lib, + rustPlatform, + fetchFromGitHub, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -32,7 +33,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/dyc3/steamguard-cli"; license = with licenses; [ gpl3Only ]; mainProgram = "steamguard"; - maintainers = with maintainers; [ surfaceflinger sigmasquadron ]; + maintainers = with maintainers; [ + surfaceflinger + sigmasquadron + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/st/steamos-devkit/package.nix b/pkgs/by-name/st/steamos-devkit/package.nix index ed0e41b5f84a94..206619d4e65f4b 100644 --- a/pkgs/by-name/st/steamos-devkit/package.nix +++ b/pkgs/by-name/st/steamos-devkit/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, fetchFromGitLab -, python3 -, copyDesktopItems -, makeDesktopItem -, pkg-config -, SDL2 +{ + lib, + fetchFromGitHub, + fetchFromGitLab, + python3, + copyDesktopItems, + makeDesktopItem, + pkg-config, + SDL2, }: let # steamos-devkit requires a build of the unreleased pyimgui 2.0 branch, move to pythonPackages when 2.0 is released. diff --git a/pkgs/by-name/st/steampipe/package.nix b/pkgs/by-name/st/steampipe/package.nix index 25e365445cc017..3209f0b815dc78 100644 --- a/pkgs/by-name/st/steampipe/package.nix +++ b/pkgs/by-name/st/steampipe/package.nix @@ -13,7 +13,7 @@ buildGoModule rec { pname = "steampipe"; version = "1.0.1"; - CGO_ENABLED=0; + CGO_ENABLED = 0; src = fetchFromGitHub { owner = "turbot"; @@ -80,6 +80,9 @@ buildGoModule rec { homepage = "https://steampipe.io/"; license = lib.licenses.agpl3Only; mainProgram = "steampipe"; - maintainers = with lib.maintainers; [ hardselius anthonyroussel ]; + maintainers = with lib.maintainers; [ + hardselius + anthonyroussel + ]; }; } diff --git a/pkgs/by-name/st/steamtinkerlaunch/package.nix b/pkgs/by-name/st/steamtinkerlaunch/package.nix index 0d7551ca30a2d1..039641dfa92aba 100644 --- a/pkgs/by-name/st/steamtinkerlaunch/package.nix +++ b/pkgs/by-name/st/steamtinkerlaunch/package.nix @@ -1,17 +1,18 @@ -{ bash -, fetchFromGitHub -, gawk -, git -, lib -, procps -, stdenvNoCC -, unixtools -, unzip -, wget -, xdotool -, xorg -, yad -, writeShellApplication +{ + bash, + fetchFromGitHub, + gawk, + git, + lib, + procps, + stdenvNoCC, + unixtools, + unzip, + wget, + xdotool, + xorg, + yad, + writeShellApplication, }: stdenvNoCC.mkDerivation { @@ -25,19 +26,24 @@ stdenvNoCC.mkDerivation { hash = "sha256-CGtSGAm+52t2zFsPJEsm76w+FEHhbOd9NYuerGa31tc="; }; - outputs = [ "out" "steamcompattool" ]; + outputs = [ + "out" + "steamcompattool" + ]; installFlags = [ "PREFIX=\${out}" ]; - nativeBuildInputs = let - # We need a `steam` command in order to install the compat tool - fakeSteam = writeShellApplication { - name = "steam"; - text = "exit 0"; - }; - in [ - fakeSteam - ]; + nativeBuildInputs = + let + # We need a `steam` command in order to install the compat tool + fakeSteam = writeShellApplication { + name = "steam"; + text = "exit 0"; + }; + in + [ + fakeSteam + ]; postInstall = let @@ -96,7 +102,10 @@ stdenvNoCC.mkDerivation { mainProgram = "steamtinkerlaunch"; homepage = "https://github.com/sonic2kk/steamtinkerlaunch"; license = licenses.gpl3; - maintainers = with maintainers; [ urandom surfaceflinger ]; + maintainers = with maintainers; [ + urandom + surfaceflinger + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/st/stegseek/package.nix b/pkgs/by-name/st/stegseek/package.nix index dd2c1004575417..ed7868e996697b 100644 --- a/pkgs/by-name/st/stegseek/package.nix +++ b/pkgs/by-name/st/stegseek/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, cmake -, fetchFromGitHub -, libjpeg -, libmcrypt -, libmhash -, libtool -, zlib +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + libjpeg, + libmcrypt, + libmhash, + libtool, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/st/stegsolve/package.nix b/pkgs/by-name/st/stegsolve/package.nix index 9bd8f99114d18d..33c186837a9591 100644 --- a/pkgs/by-name/st/stegsolve/package.nix +++ b/pkgs/by-name/st/stegsolve/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenvNoCC -, fetchurl -, jre -, makeWrapper -, copyDesktopItems -, makeDesktopItem +{ + lib, + stdenvNoCC, + fetchurl, + jre, + makeWrapper, + copyDesktopItems, + makeDesktopItem, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -30,7 +31,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { }) ]; - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/st/stella/package.nix b/pkgs/by-name/st/stella/package.nix index 90cea0687bf1a1..1c96b12925181e 100644 --- a/pkgs/by-name/st/stella/package.nix +++ b/pkgs/by-name/st/stella/package.nix @@ -1,9 +1,10 @@ -{ lib -, SDL2 -, fetchFromGitHub -, sqlite -, pkg-config -, stdenv +{ + lib, + SDL2, + fetchFromGitHub, + sqlite, + pkg-config, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/st/stellar-core/package.nix b/pkgs/by-name/st/stellar-core/package.nix index 16865f7709f342..930efaa35dc6d7 100644 --- a/pkgs/by-name/st/stellar-core/package.nix +++ b/pkgs/by-name/st/stellar-core/package.nix @@ -1,17 +1,18 @@ -{ autoconf -, automake -, bison -, fetchFromGitHub -, fetchpatch -, flex -, git -, lib -, libtool -, libunwind -, pkg-config -, postgresql -, ripgrep -, stdenv +{ + autoconf, + automake, + bison, + fetchFromGitHub, + fetchpatch, + flex, + git, + lib, + libtool, + libunwind, + pkg-config, + postgresql, + ripgrep, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/st/stenc/package.nix b/pkgs/by-name/st/stenc/package.nix index 1f0ea7e2b6a285..b1d15c56f65b5c 100644 --- a/pkgs/by-name/st/stenc/package.nix +++ b/pkgs/by-name/st/stenc/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, gitUpdater -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/st/step-kms-plugin/package.nix b/pkgs/by-name/st/step-kms-plugin/package.nix index 8eee656831f78d..d98ffb7cfe8cc4 100644 --- a/pkgs/by-name/st/step-kms-plugin/package.nix +++ b/pkgs/by-name/st/step-kms-plugin/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, buildGoModule -, fetchFromGitHub -, pkg-config -, pcsclite -, softhsm -, opensc -, yubihsm-shell +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + pcsclite, + softhsm, + opensc, + yubihsm-shell, }: buildGoModule rec { diff --git a/pkgs/by-name/st/stepmania/package.nix b/pkgs/by-name/st/stepmania/package.nix index 000b07c5433d96..f978d8c62bba49 100644 --- a/pkgs/by-name/st/stepmania/package.nix +++ b/pkgs/by-name/st/stepmania/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, nasm -, alsa-lib -, ffmpeg_6 -, glew -, glib -, gtk2 -, libmad -, libogg -, libpng -, libpulseaudio -, libvorbis -, udev -, xorg +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + nasm, + alsa-lib, + ffmpeg_6, + glew, + glib, + gtk2, + libmad, + libogg, + libpng, + libpulseaudio, + libvorbis, + udev, + xorg, }: stdenv.mkDerivation { @@ -24,8 +25,8 @@ stdenv.mkDerivation { src = fetchFromGitHub { owner = "stepmania"; - repo = "stepmania"; - rev = "d55acb1ba26f1c5b5e3048d6d6c0bd116625216f"; + repo = "stepmania"; + rev = "d55acb1ba26f1c5b5e3048d6d6c0bd116625216f"; hash = "sha256-49H2Q61R4l/G0fWsjCjiAUXeWwG3lcsDpV5XvR3l3QE="; }; @@ -42,7 +43,10 @@ stdenv.mkDerivation { sed '1i#include ' -i src/arch/ArchHooks/ArchHooks.h # gcc12 ''; - nativeBuildInputs = [ cmake nasm ]; + nativeBuildInputs = [ + cmake + nasm + ]; buildInputs = [ alsa-lib diff --git a/pkgs/by-name/st/stepreduce/package.nix b/pkgs/by-name/st/stepreduce/package.nix index d6122ec0bbb319..4dc1eb389f8667 100644 --- a/pkgs/by-name/st/stepreduce/package.nix +++ b/pkgs/by-name/st/stepreduce/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitLab +{ + lib, + stdenv, + fetchFromGitLab, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/st/stereotool/package.nix b/pkgs/by-name/st/stereotool/package.nix index 546ecd44068e24..210a3f62ad4cff 100644 --- a/pkgs/by-name/st/stereotool/package.nix +++ b/pkgs/by-name/st/stereotool/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, libX11 -, libXpm -, alsa-lib -, bzip2 -, zlib -, libsForQt5 -, libgcc -, makeWrapper -, copyDesktopItems -, makeDesktopItem +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + libX11, + libXpm, + alsa-lib, + bzip2, + zlib, + libsForQt5, + libgcc, + makeWrapper, + copyDesktopItems, + makeDesktopItem, }: stdenv.mkDerivation rec { @@ -28,7 +29,8 @@ stdenv.mkDerivation rec { url = "https://download.thimeo.com/stereo_tool_icon_${versionNoPoint}.png"; hash = "sha256-dcivH6Cc7pdQ99m80vS4E5mp/SHtTlNu1EHc+0ALIGM="; }) - ] ++ ( + ] + ++ ( { # Alsa version for 64bits. x86_64-linux = [ @@ -105,7 +107,9 @@ stdenv.mkDerivation rec { hash = "sha256-oCGhxQkpT0jNwbWoBnC5nmvVrDjYmr75s3Qq+NftZy0="; }) ]; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}")); + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}") + ); unpackPhase = '' for srcFile in $srcs; do @@ -126,7 +130,11 @@ stdenv.mkDerivation rec { exec = "stereo_tool_gui"; icon = "stereo-tool-icon"; comment = "Broadcast Audio Processing"; - categories = [ "AudioVideo" "Audio" "AudioVideoEditing" ]; + categories = [ + "AudioVideo" + "Audio" + "AudioVideoEditing" + ]; }) (makeDesktopItem { name = "stereotool-jack"; @@ -134,7 +142,11 @@ stdenv.mkDerivation rec { exec = "stereo_tool_gui_jack"; icon = "stereo-tool-icon"; comment = "Broadcast Audio Processing"; - categories = [ "AudioVideo" "Audio" "AudioVideoEditing" ]; + categories = [ + "AudioVideo" + "Audio" + "AudioVideoEditing" + ]; }) ]; @@ -164,7 +176,12 @@ stdenv.mkDerivation rec { description = "Stereo Tool is a software-based audio processor which offers outstanding audio quality and comes with many unique features"; license = licenses.unfree; mainProgram = "stereo_tool_gui"; - platforms = [ "aarch64-linux" "aarch32-linux" "x86_64-linux" "i686-linux" ]; + platforms = [ + "aarch64-linux" + "aarch32-linux" + "x86_64-linux" + "i686-linux" + ]; maintainers = with maintainers; [ RudiOnTheAir ]; }; diff --git a/pkgs/by-name/st/stfl/package.nix b/pkgs/by-name/st/stfl/package.nix index d53d2200603621..8a3079fbf67978 100644 --- a/pkgs/by-name/st/stfl/package.nix +++ b/pkgs/by-name/st/stfl/package.nix @@ -1,11 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { pname = "stfl"; version = "0.24-unstable-2021-11-29"; src = fetchFromGitHub { - owner ="newsboat"; + owner = "newsboat"; repo = "stfl"; rev = "c2c10b8a50fef613c0aacdc5d06a0fa610bf79e9"; hash = "sha256-os1yQ6o4m7yBiEZQIPP64diRleIr7FtuQucUbWs4A6k="; @@ -17,38 +22,43 @@ stdenv.mkDerivation rec { # Silence warnings related to use of implicitly declared library functions and implicit ints. # TODO: Remove and/or fix with patches the next time this package is updated. - env = lib.optionalAttrs stdenv.cc.isClang { - NIX_CFLAGS_COMPILE = toString [ - "-Wno-error=implicit-function-declaration" - "-Wno-error=implicit-int" - ]; - } // lib.optionalAttrs stdenv.hostPlatform.isDarwin { - NIX_LDFLAGS = "-liconv"; - }; + env = + lib.optionalAttrs stdenv.cc.isClang { + NIX_CFLAGS_COMPILE = toString [ + "-Wno-error=implicit-function-declaration" + "-Wno-error=implicit-int" + ]; + } + // lib.optionalAttrs stdenv.hostPlatform.isDarwin { + NIX_LDFLAGS = "-liconv"; + }; + + preBuild = + '' + sed -i s/gcc/cc/g Makefile + sed -i s%ncursesw/ncurses.h%ncurses.h% stfl_internals.h + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + sed -i s/-soname/-install_name/ Makefile + '' + # upstream builds shared library unconditionally. Also, it has no + # support for cross-compilation. + + lib.optionalString stdenv.hostPlatform.isStatic '' + sed -i 's/all:.*/all: libstfl.a stfl.pc/' Makefile + sed -i 's/\tar /\t${stdenv.cc.targetPrefix}ar /' Makefile + sed -i 's/\tranlib /\t${stdenv.cc.targetPrefix}ranlib /' Makefile + sed -i '/install -m 644 libstfl.so./d' Makefile + sed -i '/ln -fs libstfl.so./d' Makefile + ''; - preBuild = '' - sed -i s/gcc/cc/g Makefile - sed -i s%ncursesw/ncurses.h%ncurses.h% stfl_internals.h - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - sed -i s/-soname/-install_name/ Makefile - '' - # upstream builds shared library unconditionally. Also, it has no - # support for cross-compilation. - + lib.optionalString stdenv.hostPlatform.isStatic '' - sed -i 's/all:.*/all: libstfl.a stfl.pc/' Makefile - sed -i 's/\tar /\t${stdenv.cc.targetPrefix}ar /' Makefile - sed -i 's/\tranlib /\t${stdenv.cc.targetPrefix}ranlib /' Makefile - sed -i '/install -m 644 libstfl.so./d' Makefile - sed -i '/ln -fs libstfl.so./d' Makefile - '' ; - - installPhase = '' - DESTDIR=$out prefix=\"\" make install - '' - # some programs rely on libstfl.so.0 to be present, so link it - + lib.optionalString (!stdenv.hostPlatform.isStatic) '' - ln -s $out/lib/libstfl.so.0.24 $out/lib/libstfl.so.0 - ''; + installPhase = + '' + DESTDIR=$out prefix=\"\" make install + '' + # some programs rely on libstfl.so.0 to be present, so link it + + lib.optionalString (!stdenv.hostPlatform.isStatic) '' + ln -s $out/lib/libstfl.so.0.24 $out/lib/libstfl.so.0 + ''; meta = { homepage = "https://web.archive.org/web/20211113222004/http://www.clifford.at/stfl/"; diff --git a/pkgs/by-name/st/stgit/package.nix b/pkgs/by-name/st/stgit/package.nix index 4d44724eddec8b..2f57d8b161bb19 100644 --- a/pkgs/by-name/st/stgit/package.nix +++ b/pkgs/by-name/st/stgit/package.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, installShellFiles -, makeWrapper -, asciidoc -, docbook_xsl -, docbook_xml_dtd_45 -, xmlto -, curl -, git -, perl -, darwin -, libiconv +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + installShellFiles, + makeWrapper, + asciidoc, + docbook_xsl, + docbook_xml_dtd_45, + xmlto, + curl, + git, + perl, + darwin, + libiconv, }: rustPlatform.buildRustPackage rec { @@ -29,16 +30,26 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-s3PFNc1rn01X6tauRXp5B4cg3AIVSishqDFy0lP/8g8="; nativeBuildInputs = [ - pkg-config installShellFiles makeWrapper asciidoc xmlto docbook_xsl - docbook_xml_dtd_45 perl + pkg-config + installShellFiles + makeWrapper + asciidoc + xmlto + docbook_xsl + docbook_xml_dtd_45 + perl ]; buildInputs = [ curl ]; - nativeCheckInputs = [ - git perl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.system_cmds libiconv - ]; + nativeCheckInputs = + [ + git + perl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.system_cmds + libiconv + ]; postPatch = '' for f in Documentation/*.xsl; do @@ -67,7 +78,11 @@ rustPlatform.buildRustPackage rec { checkTarget = "test"; dontCargoInstall = true; - installTargets = [ "install" "install-man" "install-html" ]; + installTargets = [ + "install" + "install-man" + "install-html" + ]; postInstall = '' wrapProgram $out/bin/stg --prefix PATH : ${lib.makeBinPath [ git ]} diff --git a/pkgs/by-name/st/sticky-notes/package.nix b/pkgs/by-name/st/sticky-notes/package.nix index 98fd7d387e6402..d121b2b1c25b4b 100644 --- a/pkgs/by-name/st/sticky-notes/package.nix +++ b/pkgs/by-name/st/sticky-notes/package.nix @@ -1,22 +1,23 @@ -{ lib -, desktop-file-utils -, fetchFromGitHub -, fetchYarnDeps -, fixup_yarn_lock -, gjs -, glib-networking -, gobject-introspection -, gst_all_1 -, gtk4 -, libadwaita -, libsoup_3 -, meson -, ninja -, pkg-config -, stdenv -, wrapGAppsHook4 -, yarn -, nodejs +{ + lib, + desktop-file-utils, + fetchFromGitHub, + fetchYarnDeps, + fixup_yarn_lock, + gjs, + glib-networking, + gobject-introspection, + gst_all_1, + gtk4, + libadwaita, + libsoup_3, + meson, + ninja, + pkg-config, + stdenv, + wrapGAppsHook4, + yarn, + nodejs, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/st/sticky/package.nix b/pkgs/by-name/st/sticky/package.nix index 293c2e46ea81af..25947e1523ddb7 100644 --- a/pkgs/by-name/st/sticky/package.nix +++ b/pkgs/by-name/st/sticky/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, gobject-introspection -, meson -, ninja -, python3 -, wrapGAppsHook3 -, xapp -, glib -, gspell -, gtk3 -, gitUpdater +{ + stdenv, + lib, + fetchFromGitHub, + gobject-introspection, + meson, + ninja, + python3, + wrapGAppsHook3, + xapp, + glib, + gspell, + gtk3, + gitUpdater, }: stdenv.mkDerivation rec { @@ -72,6 +73,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/linuxmint/sticky"; license = licenses.gpl2Only; platforms = platforms.linux; - maintainers = with maintainers; [ linsui bobby285271 ]; + maintainers = with maintainers; [ + linsui + bobby285271 + ]; }; } diff --git a/pkgs/by-name/st/stig/package.nix b/pkgs/by-name/st/stig/package.nix index 19e108f45a3184..7c6dec75cee634 100644 --- a/pkgs/by-name/st/stig/package.nix +++ b/pkgs/by-name/st/stig/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, python310Packages -, testers -, stig +{ + lib, + fetchFromGitHub, + python310Packages, + testers, + stig, }: python310Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/st/stilo-themes/package.nix b/pkgs/by-name/st/stilo-themes/package.nix index 6401c0e28694b3..8ee4cb26784542 100644 --- a/pkgs/by-name/st/stilo-themes/package.nix +++ b/pkgs/by-name/st/stilo-themes/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, sassc, gdk-pixbuf, librsvg, gtk_engines, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + sassc, + gdk-pixbuf, + librsvg, + gtk_engines, + gtk-engine-murrine, +}: stdenv.mkDerivation rec { pname = "stilo-themes"; @@ -11,9 +22,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-YKEDXrOAn7pGWb0VcOx7cKHnuX120yPzqtUVnzyLrDQ="; }; - nativeBuildInputs = [ meson ninja sassc ]; + nativeBuildInputs = [ + meson + ninja + sassc + ]; - buildInputs = [ gdk-pixbuf librsvg gtk_engines ]; + buildInputs = [ + gdk-pixbuf + librsvg + gtk_engines + ]; propagatedUserEnvPkgs = [ gtk-engine-murrine ]; diff --git a/pkgs/by-name/st/stix-otf/package.nix b/pkgs/by-name/st/stix-otf/package.nix index c5505b7a79483e..b9a1b795ce1903 100644 --- a/pkgs/by-name/st/stix-otf/package.nix +++ b/pkgs/by-name/st/stix-otf/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "stix-otf"; diff --git a/pkgs/by-name/st/stix-two/package.nix b/pkgs/by-name/st/stix-two/package.nix index 86ceb388f86aa9..729518d9717102 100644 --- a/pkgs/by-name/st/stix-two/package.nix +++ b/pkgs/by-name/st/stix-two/package.nix @@ -1,11 +1,17 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "stix-two"; version = "2.13"; src = fetchzip { - url = "https://github.com/stipub/stixfonts/raw/v${version}/zipfiles/STIX${builtins.replaceStrings [ "." ] [ "_" ] version}-all.zip"; + url = "https://github.com/stipub/stixfonts/raw/v${version}/zipfiles/STIX${ + builtins.replaceStrings [ "." ] [ "_" ] version + }-all.zip"; stripRoot = false; hash = "sha256-hfQmrw7HjlhQSA0rVTs84i3j3iMVR0k7tCRBcB6hEpU="; }; diff --git a/pkgs/by-name/st/stlink-tool/package.nix b/pkgs/by-name/st/stlink-tool/package.nix index 029bb0a9b25acf..b3b1ea303ab780 100644 --- a/pkgs/by-name/st/stlink-tool/package.nix +++ b/pkgs/by-name/st/stlink-tool/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, pkg-config -, fetchFromGitHub -, libusb1 +{ + lib, + stdenv, + pkg-config, + fetchFromGitHub, + libusb1, }: # IMPORTANT: You need permissions to access the stlink usb devices. diff --git a/pkgs/by-name/st/stm32cubemx/package.nix b/pkgs/by-name/st/stm32cubemx/package.nix index 44f173a1cc8df1..0505e5b92c87df 100644 --- a/pkgs/by-name/st/stm32cubemx/package.nix +++ b/pkgs/by-name/st/stm32cubemx/package.nix @@ -1,12 +1,13 @@ -{ fdupes -, buildFHSEnv -, fetchzip -, icoutils -, imagemagick -, jdk21 -, lib -, makeDesktopItem -, stdenvNoCC +{ + fdupes, + buildFHSEnv, + fetchzip, + icoutils, + imagemagick, + jdk21, + lib, + makeDesktopItem, + stdenvNoCC, }: let @@ -16,12 +17,18 @@ let version = "6.13.0"; src = fetchzip { - url = "https://sw-center.st.com/packs/resource/library/stm32cube_mx_v${builtins.replaceStrings ["."] [""] version}-lin.zip"; + url = "https://sw-center.st.com/packs/resource/library/stm32cube_mx_v${ + builtins.replaceStrings [ "." ] [ "" ] version + }-lin.zip"; hash = "sha256-ypZVVPmAsApaccWl7ZtAECwphD2SUUiVNC2DYC5rYb4="; stripRoot = false; }; - nativeBuildInputs = [ fdupes icoutils imagemagick ]; + nativeBuildInputs = [ + fdupes + icoutils + imagemagick + ]; desktopItem = makeDesktopItem { name = "STM32CubeMX"; exec = "stm32cubemx"; @@ -78,38 +85,41 @@ let homepage = "https://www.st.com/en/development-tools/stm32cubemx.html"; sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.unfree; - maintainers = with maintainers; [ angaz wucke13 ]; + maintainers = with maintainers; [ + angaz + wucke13 + ]; platforms = [ "x86_64-linux" ]; }; }; - in - buildFHSEnv { - inherit (package) pname version meta; - runScript = "${package.outPath}/bin/stm32cubemx"; - targetPkgs = pkgs: - with pkgs; [ - alsa-lib - at-spi2-atk - cairo - cups - dbus - expat - glib - gtk3 - libdrm - libGL - libudev0-shim - libxkbcommon - mesa - nspr - nss - pango - xorg.libX11 - xorg.libxcb - xorg.libXcomposite - xorg.libXdamage - xorg.libXext - xorg.libXfixes - xorg.libXrandr - ]; +in +buildFHSEnv { + inherit (package) pname version meta; + runScript = "${package.outPath}/bin/stm32cubemx"; + targetPkgs = + pkgs: with pkgs; [ + alsa-lib + at-spi2-atk + cairo + cups + dbus + expat + glib + gtk3 + libdrm + libGL + libudev0-shim + libxkbcommon + mesa + nspr + nss + pango + xorg.libX11 + xorg.libxcb + xorg.libXcomposite + xorg.libXdamage + xorg.libXext + xorg.libXfixes + xorg.libXrandr + ]; } diff --git a/pkgs/by-name/st/stm32flash/package.nix b/pkgs/by-name/st/stm32flash/package.nix index fd9703fed4cf8a..7787dc9c05f4c2 100644 --- a/pkgs/by-name/st/stm32flash/package.nix +++ b/pkgs/by-name/st/stm32flash/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "stm32flash"; diff --git a/pkgs/by-name/st/stm8flash/package.nix b/pkgs/by-name/st/stm8flash/package.nix index ee049d3758a207..4c55857b02f109 100644 --- a/pkgs/by-name/st/stm8flash/package.nix +++ b/pkgs/by-name/st/stm8flash/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, libusb1, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + libusb1, + pkg-config, +}: stdenv.mkDerivation { pname = "stm8flash"; diff --git a/pkgs/by-name/st/stochas/package.nix b/pkgs/by-name/st/stochas/package.nix index 67e89ccf3a2ea6..7374b0c97831ff 100644 --- a/pkgs/by-name/st/stochas/package.nix +++ b/pkgs/by-name/st/stochas/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, libX11, libXrandr, libXinerama, libXext, libXcursor, freetype, alsa-lib, libjack2 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libX11, + libXrandr, + libXinerama, + libXext, + libXcursor, + freetype, + alsa-lib, + libjack2, +}: stdenv.mkDerivation rec { pname = "stochas"; @@ -17,10 +31,20 @@ stdenv.mkDerivation rec { lib/JUCE/modules/juce_gui_basics/windows/juce_ComponentPeer.h # gcc12 ''; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ - libX11 libXrandr libXinerama libXext libXcursor freetype alsa-lib libjack2 + libX11 + libXrandr + libXinerama + libXext + libXcursor + freetype + alsa-lib + libjack2 ]; installPhase = '' diff --git a/pkgs/by-name/st/stockfish/package.nix b/pkgs/by-name/st/stockfish/package.nix index 134eaa660d3a14..502f9f9b478f12 100644 --- a/pkgs/by-name/st/stockfish/package.nix +++ b/pkgs/by-name/st/stockfish/package.nix @@ -5,33 +5,39 @@ fetchFromGitHub, apple-sdk, apple-sdk_11, - darwinMinVersionHook + darwinMinVersionHook, }: let - # The x86-64-modern may need to be refined further in the future - # but stdenv.hostPlatform CPU flags do not currently work on Darwin - # https://discourse.nixos.org/t/darwin-system-and-stdenv-hostplatform-features/9745 - archDarwin = if stdenv.hostPlatform.isx86_64 then "x86-64-modern" else "apple-silicon"; - arch = if stdenv.hostPlatform.isDarwin then archDarwin else - if stdenv.hostPlatform.isx86_64 then "x86-64" else - if stdenv.hostPlatform.isi686 then "x86-32" else - if stdenv.hostPlatform.isAarch64 then "armv8" else - "unknown"; + # The x86-64-modern may need to be refined further in the future + # but stdenv.hostPlatform CPU flags do not currently work on Darwin + # https://discourse.nixos.org/t/darwin-system-and-stdenv-hostplatform-features/9745 + archDarwin = if stdenv.hostPlatform.isx86_64 then "x86-64-modern" else "apple-silicon"; + arch = + if stdenv.hostPlatform.isDarwin then + archDarwin + else if stdenv.hostPlatform.isx86_64 then + "x86-64" + else if stdenv.hostPlatform.isi686 then + "x86-32" + else if stdenv.hostPlatform.isAarch64 then + "armv8" + else + "unknown"; - # These files can be found in src/evaluate.h - nnueBigFile = "nn-1111cefa1111.nnue"; - nnueBig = fetchurl { - name = nnueBigFile; - url = "https://tests.stockfishchess.org/api/nn/${nnueBigFile}"; - sha256 = "sha256-ERHO+hERa3cWG9SxTatMUPJuWSDHVvSGFZK+Pc1t4XQ="; - }; - nnueSmallFile = "nn-37f18f62d772.nnue"; - nnueSmall = fetchurl { - name = nnueSmallFile; - url = "https://tests.stockfishchess.org/api/nn/${nnueSmallFile}"; - sha256 = "sha256-N/GPYtdy8xB+HWqso4mMEww8hvKrY+ZVX7vKIGNaiZ0="; - }; + # These files can be found in src/evaluate.h + nnueBigFile = "nn-1111cefa1111.nnue"; + nnueBig = fetchurl { + name = nnueBigFile; + url = "https://tests.stockfishchess.org/api/nn/${nnueBigFile}"; + sha256 = "sha256-ERHO+hERa3cWG9SxTatMUPJuWSDHVvSGFZK+Pc1t4XQ="; + }; + nnueSmallFile = "nn-37f18f62d772.nnue"; + nnueSmall = fetchurl { + name = nnueSmallFile; + url = "https://tests.stockfishchess.org/api/nn/${nnueSmallFile}"; + sha256 = "sha256-N/GPYtdy8xB+HWqso4mMEww8hvKrY+ZVX7vKIGNaiZ0="; + }; in stdenv.mkDerivation rec { @@ -51,16 +57,19 @@ stdenv.mkDerivation rec { cp "${nnueSmall}" "$sourceRoot/${nnueSmallFile}" ''; - makeFlags = [ "PREFIX=$(out)" "ARCH=${arch}" "CXX=${stdenv.cc.targetPrefix}c++" ]; - buildFlags = [ "build" ]; - - buildInputs = lib.optionals ( - stdenv.hostPlatform.isDarwin - && lib.versionOlder apple-sdk.version "11") [ - apple-sdk_11 - (darwinMinVersionHook "10.15") + makeFlags = [ + "PREFIX=$(out)" + "ARCH=${arch}" + "CXX=${stdenv.cc.targetPrefix}c++" ]; + buildFlags = [ "build" ]; + buildInputs = + lib.optionals (stdenv.hostPlatform.isDarwin && lib.versionOlder apple-sdk.version "11") + [ + apple-sdk_11 + (darwinMinVersionHook "10.15") + ]; enableParallelBuilding = true; @@ -71,9 +80,19 @@ stdenv.mkDerivation rec { longDescription = '' Stockfish is one of the strongest chess engines in the world. It is also much stronger than the best human chess grandmasters. - ''; - maintainers = with maintainers; [ luispedro siraben thibaultd ]; - platforms = ["x86_64-linux" "i686-linux" "x86_64-darwin" "aarch64-linux" "aarch64-darwin"]; + ''; + maintainers = with maintainers; [ + luispedro + siraben + thibaultd + ]; + platforms = [ + "x86_64-linux" + "i686-linux" + "x86_64-darwin" + "aarch64-linux" + "aarch64-darwin" + ]; license = licenses.gpl3Only; }; diff --git a/pkgs/by-name/st/stone-kingdoms/package.nix b/pkgs/by-name/st/stone-kingdoms/package.nix index a8b84c60b1e893..6065059b5ee093 100644 --- a/pkgs/by-name/st/stone-kingdoms/package.nix +++ b/pkgs/by-name/st/stone-kingdoms/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenvNoCC -, fetchFromGitLab -, copyDesktopItems -, love -, makeDesktopItem -, makeWrapper -, strip-nondeterminism -, zip +{ + lib, + stdenvNoCC, + fetchFromGitLab, + copyDesktopItems, + love, + makeDesktopItem, + makeWrapper, + strip-nondeterminism, + zip, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/st/stone-phaser/package.nix b/pkgs/by-name/st/stone-phaser/package.nix index f581ae1b1cb647..e1e68d999ac62d 100644 --- a/pkgs/by-name/st/stone-phaser/package.nix +++ b/pkgs/by-name/st/stone-phaser/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, xorg, cairo, libGL, lv2, libjack2, mesa, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + xorg, + cairo, + libGL, + lv2, + libjack2, + mesa, + pkg-config, +}: stdenv.mkDerivation rec { pname = "stone-phaser"; @@ -14,7 +25,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - xorg.libX11 cairo libGL lv2 libjack2 mesa + xorg.libX11 + cairo + libGL + lv2 + libjack2 + mesa ]; postPatch = '' diff --git a/pkgs/by-name/st/stone/package.nix b/pkgs/by-name/st/stone/package.nix index 989a56f0863ab6..d93eaebf3c755f 100644 --- a/pkgs/by-name/st/stone/package.nix +++ b/pkgs/by-name/st/stone/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchurl -, openssl +{ + stdenv, + lib, + fetchurl, + openssl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/st/storcli/package.nix b/pkgs/by-name/st/storcli/package.nix index 7c78a2fefd1744..c04db3df2e8ddd 100644 --- a/pkgs/by-name/st/storcli/package.nix +++ b/pkgs/by-name/st/storcli/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchzip -, rpmextract -, testers +{ + lib, + stdenvNoCC, + fetchzip, + rpmextract, + testers, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -17,16 +18,18 @@ stdenvNoCC.mkDerivation (finalAttrs: { nativeBuildInputs = [ rpmextract ]; - unpackPhase = let - inherit (stdenvNoCC.hostPlatform) system; - platforms = { - x86_64-linux = "Linux"; - aarch64-linux = "ARM/Linux"; - }; - platform = platforms.${system} or (throw "unsupported system: ${system}"); - in '' - rpmextract $src/univ_viva_cli_rel/Unified_storcli_all_os/${platform}/storcli-00${finalAttrs.version}00.0000-1.*.rpm - ''; + unpackPhase = + let + inherit (stdenvNoCC.hostPlatform) system; + platforms = { + x86_64-linux = "Linux"; + aarch64-linux = "ARM/Linux"; + }; + platform = platforms.${system} or (throw "unsupported system: ${system}"); + in + '' + rpmextract $src/univ_viva_cli_rel/Unified_storcli_all_os/${platform}/storcli-00${finalAttrs.version}00.0000-1.*.rpm + ''; dontPatch = true; dontConfigure = true; @@ -56,6 +59,9 @@ stdenvNoCC.mkDerivation (finalAttrs: { license = licenses.unfree; maintainers = with maintainers; [ panicgh ]; mainProgram = "storcli"; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; }; }) diff --git a/pkgs/by-name/st/storeBackup/package.nix b/pkgs/by-name/st/storeBackup/package.nix index 74c867e9ec5e50..8a58698c0cdfb2 100644 --- a/pkgs/by-name/st/storeBackup/package.nix +++ b/pkgs/by-name/st/storeBackup/package.nix @@ -1,4 +1,15 @@ -{lib, stdenv, which, coreutils, perl, fetchurl, makeWrapper, diffutils , writeScriptBin, bzip2}: +{ + lib, + stdenv, + which, + coreutils, + perl, + fetchurl, + makeWrapper, + diffutils, + writeScriptBin, + bzip2, +}: # quick usage: # storeBackup.pl --sourceDir /home/user --backupDir /tmp/my_backup_destination @@ -9,7 +20,8 @@ # known impurity: test cases seem to bu using /tmp/storeBackup.lock .. -let dummyMount = writeScriptBin "mount" "#!${stdenv.shell}"; +let + dummyMount = writeScriptBin "mount" "#!${stdenv.shell}"; in stdenv.mkDerivation rec { @@ -45,7 +57,12 @@ stdenv.mkDerivation rec { -e '1 s@/usr/bin/env perl@${perl.withPackages (p: [ p.DBFile ])}/bin/perl@' for p in $out/bin/* - do wrapProgram "$p" --prefix PATH ":" "${lib.makeBinPath [ which bzip2 ]}" + do wrapProgram "$p" --prefix PATH ":" "${ + lib.makeBinPath [ + which + bzip2 + ] + }" done patchShebangs $out @@ -110,7 +127,7 @@ stdenv.mkDerivation rec { description = "Backup suite that stores files on other disks"; homepage = "https://savannah.nongnu.org/projects/storebackup"; license = lib.licenses.gpl3Plus; - maintainers = [lib.maintainers.marcweber]; + maintainers = [ lib.maintainers.marcweber ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/st/storj-uplink/package.nix b/pkgs/by-name/st/storj-uplink/package.nix index 412310d4de3a61..b31199c4f7b1e7 100644 --- a/pkgs/by-name/st/storj-uplink/package.nix +++ b/pkgs/by-name/st/storj-uplink/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -18,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-5pNYC1ubjxaU7KPd4lsEOyAe/OU95UID4JtFJ6Q+E3w="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Command-line tool for Storj"; diff --git a/pkgs/by-name/st/stormlib/package.nix b/pkgs/by-name/st/stormlib/package.nix index 090ada0d89f79a..bf5163a8f48acf 100644 --- a/pkgs/by-name/st/stormlib/package.nix +++ b/pkgs/by-name/st/stormlib/package.nix @@ -24,14 +24,15 @@ stdenv.mkDerivation (finalAttrs: { cmake ]; - buildInputs = [ - bzip2 - libtomcrypt - zlib - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Carbon - ]; + buildInputs = + [ + bzip2 + libtomcrypt + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Carbon + ]; cmakeFlags = [ (lib.cmakeBool "BUILD_SHARED_LIBS" (!stdenv.hostPlatform.isStatic)) @@ -40,10 +41,12 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-implicit-function-declaration" - "-Wno-int-conversion" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-implicit-function-declaration" + "-Wno-int-conversion" + ] + ); postPatch = '' substituteInPlace CMakeLists.txt \ @@ -54,7 +57,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/ladislav-zezula/StormLib"; description = "Open-source project that can work with Blizzard MPQ archives"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ aanderse karolchmist ]; + maintainers = with lib.maintainers; [ + aanderse + karolchmist + ]; platforms = lib.platforms.all; broken = stdenv.hostPlatform.isDarwin; # installation directory mismatch }; diff --git a/pkgs/by-name/st/storrent/package.nix b/pkgs/by-name/st/storrent/package.nix index 57ea126a16357a..873885eb4417cb 100644 --- a/pkgs/by-name/st/storrent/package.nix +++ b/pkgs/by-name/st/storrent/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "storrent"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-iPKZPXsa6ya29N/u9QYd5LAm42+FtHZLGStRDxsAxe4="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/jech/storrent"; diff --git a/pkgs/by-name/st/stow/package.nix b/pkgs/by-name/st/stow/package.nix index eb1430fddc5fe9..96e98afa4842bd 100644 --- a/pkgs/by-name/st/stow/package.nix +++ b/pkgs/by-name/st/stow/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, perlPackages +{ + lib, + stdenv, + fetchurl, + perlPackages, }: stdenv.mkDerivation (finalAttrs: { @@ -14,7 +15,11 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ perlPackages.perl ]; - buildInputs = with perlPackages; [ perl IOStringy TestOutput ]; + buildInputs = with perlPackages; [ + perl + IOStringy + TestOutput + ]; doCheck = true; diff --git a/pkgs/by-name/st/strace-analyzer/package.nix b/pkgs/by-name/st/strace-analyzer/package.nix index ee4242c1ca3deb..5c257e53cd10c8 100644 --- a/pkgs/by-name/st/strace-analyzer/package.nix +++ b/pkgs/by-name/st/strace-analyzer/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, strace -, stdenv +{ + lib, + rustPlatform, + fetchFromGitHub, + strace, + stdenv, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/st/strace/package.nix b/pkgs/by-name/st/strace/package.nix index b45554f017bb17..6e4978a6577f07 100644 --- a/pkgs/by-name/st/strace/package.nix +++ b/pkgs/by-name/st/strace/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, perl, libunwind, buildPackages, gitUpdater, elfutils }: +{ + lib, + stdenv, + fetchurl, + perl, + libunwind, + buildPackages, + gitUpdater, + elfutils, +}: stdenv.mkDerivation rec { pname = "strace"; @@ -19,12 +28,14 @@ stdenv.mkDerivation rec { # libunwind for -k. # On RISC-V platforms, LLVM's libunwind implementation is unsupported by strace. # The build will silently fall back and -k will not work on RISC-V. - buildInputs = [ libunwind ] + buildInputs = + [ libunwind ] # -kk ++ lib.optional (lib.meta.availableOn stdenv.hostPlatform elfutils) elfutils; - configureFlags = [ "--enable-mpers=check" ] - ++ lib.optional stdenv.cc.isClang "CFLAGS=-Wno-unused-function"; + configureFlags = [ + "--enable-mpers=check" + ] ++ lib.optional stdenv.cc.isClang "CFLAGS=-Wno-unused-function"; passthru.updateScript = gitUpdater { # No nicer place to find latest release. @@ -35,9 +46,16 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://strace.io/"; description = "System call tracer for Linux"; - license = with licenses; [ lgpl21Plus gpl2Plus ]; # gpl2Plus is for the test suite + license = with licenses; [ + lgpl21Plus + gpl2Plus + ]; # gpl2Plus is for the test suite platforms = platforms.linux; - maintainers = with maintainers; [ globin ma27 qyliss ]; + maintainers = with maintainers; [ + globin + ma27 + qyliss + ]; mainProgram = "strace"; }; } diff --git a/pkgs/by-name/st/stratis-cli/package.nix b/pkgs/by-name/st/stratis-cli/package.nix index 799a481339d5be..59715b6af454f5 100644 --- a/pkgs/by-name/st/stratis-cli/package.nix +++ b/pkgs/by-name/st/stratis-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3Packages -, fetchFromGitHub -, nixosTests +{ + lib, + python3Packages, + fetchFromGitHub, + nixosTests, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/st/stratisd/package.nix b/pkgs/by-name/st/stratisd/package.nix index 3a3899cd4251d5..98eee72833c444 100644 --- a/pkgs/by-name/st/stratisd/package.nix +++ b/pkgs/by-name/st/stratisd/package.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, cargo -, rustc -, pkg-config -, asciidoc -, ncurses -, glibc -, dbus -, cryptsetup -, util-linux -, lvm2 -, python3 -, systemd -, xfsprogs -, thin-provisioning-tools -, clevis -, jose -, jq -, curl -, tpm2-tools -, coreutils -, clevisSupport ? false -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + cargo, + rustc, + pkg-config, + asciidoc, + ncurses, + glibc, + dbus, + cryptsetup, + util-linux, + lvm2, + python3, + systemd, + xfsprogs, + thin-provisioning-tools, + clevis, + jose, + jq, + curl, + tpm2-tools, + coreutils, + clevisSupport ? false, + nixosTests, }: stdenv.mkDerivation rec { @@ -77,22 +78,31 @@ stdenv.mkDerivation rec { (python3.withPackages (ps: [ ps.dbus-python ])) ]; - outputs = [ "out" "initrd" ]; + outputs = [ + "out" + "initrd" + ]; - env.EXECUTABLES_PATHS = lib.makeBinPath ([ - xfsprogs - thin-provisioning-tools - ] ++ lib.optionals clevisSupport [ - clevis - jose - jq - cryptsetup - curl - tpm2-tools - coreutils - ]); + env.EXECUTABLES_PATHS = lib.makeBinPath ( + [ + xfsprogs + thin-provisioning-tools + ] + ++ lib.optionals clevisSupport [ + clevis + jose + jq + cryptsetup + curl + tpm2-tools + coreutils + ] + ); - makeFlags = [ "PREFIX=${placeholder "out"}" "INSTALL=install" ]; + makeFlags = [ + "PREFIX=${placeholder "out"}" + "INSTALL=install" + ]; buildFlags = [ "build-all" ]; doCheck = true; diff --git a/pkgs/by-name/st/stratovirt/package.nix b/pkgs/by-name/st/stratovirt/package.nix index 695a021a26dacf..843390d848fd52 100644 --- a/pkgs/by-name/st/stratovirt/package.nix +++ b/pkgs/by-name/st/stratovirt/package.nix @@ -1,7 +1,17 @@ -{ lib, rustPlatform, fetchgit -, pkg-config, pixman, libcap_ng, cyrus_sasl -, libpulseaudio, gtk3, libusbgx, alsa-lib -, linuxHeaders, libseccomp +{ + lib, + rustPlatform, + fetchgit, + pkg-config, + pixman, + libcap_ng, + cyrus_sasl, + libpulseaudio, + gtk3, + libusbgx, + alsa-lib, + linuxHeaders, + libseccomp, }: rustPlatform.buildRustPackage rec { @@ -38,7 +48,10 @@ rustPlatform.buildRustPackage rec { description = "Virtual Machine Manager from Huawei"; license = licenses.mulan-psl2; maintainers = with maintainers; [ astro ]; - platforms = [ "aarch64-linux" "x86_64-linux" ]; + platforms = [ + "aarch64-linux" + "x86_64-linux" + ]; mainProgram = "stratovirt"; }; } diff --git a/pkgs/by-name/st/streamlink/package.nix b/pkgs/by-name/st/streamlink/package.nix index 765a7576dff64c..54f951e8475150 100644 --- a/pkgs/by-name/st/streamlink/package.nix +++ b/pkgs/by-name/st/streamlink/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3Packages -, fetchPypi -, substituteAll -, ffmpeg +{ + lib, + python3Packages, + fetchPypi, + substituteAll, + ffmpeg, }: python3Packages.buildPythonApplication rec { @@ -67,6 +68,10 @@ python3Packages.buildPythonApplication rec { ''; license = lib.licenses.bsd2; mainProgram = "streamlink"; - maintainers = with lib.maintainers; [ dezgeg zraexy DeeUnderscore ]; + maintainers = with lib.maintainers; [ + dezgeg + zraexy + DeeUnderscore + ]; }; } diff --git a/pkgs/by-name/st/streamrip/package.nix b/pkgs/by-name/st/streamrip/package.nix index 8e7f6c683a0ca2..5f264606e8a498 100644 --- a/pkgs/by-name/st/streamrip/package.nix +++ b/pkgs/by-name/st/streamrip/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, -, ffmpeg + ffmpeg, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/st/streamripper/package.nix b/pkgs/by-name/st/streamripper/package.nix index 6874d2f4205978..50ec647755abb7 100644 --- a/pkgs/by-name/st/streamripper/package.nix +++ b/pkgs/by-name/st/streamripper/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl , glib, pkg-config, libogg, libvorbis, libmad }: +{ + lib, + stdenv, + fetchurl, + glib, + pkg-config, + libogg, + libvorbis, + libmad, +}: stdenv.mkDerivation rec { pname = "streamripper"; @@ -10,7 +19,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib libogg libvorbis libmad ]; + buildInputs = [ + glib + libogg + libvorbis + libmad + ]; makeFlags = [ "AR:=$(AR)" diff --git a/pkgs/by-name/st/strelka/package.nix b/pkgs/by-name/st/strelka/package.nix index ad6c0d9e5a4cc7..a7470394213c3b 100644 --- a/pkgs/by-name/st/strelka/package.nix +++ b/pkgs/by-name/st/strelka/package.nix @@ -1,4 +1,13 @@ -{lib, stdenv, fetchFromGitHub, fetchpatch, cmake, boost, zlib, python2}: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + boost, + zlib, + python2, +}: stdenv.mkDerivation rec { pname = "strelka"; @@ -28,7 +37,11 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ cmake ]; - buildInputs = [ boost zlib python2 ]; + buildInputs = [ + boost + zlib + python2 + ]; cmakeFlags = [ "-DCMAKE_CXX_STANDARD=14" diff --git a/pkgs/by-name/st/stress/package.nix b/pkgs/by-name/st/stress/package.nix index 1f66c26578db0b..6aee23949676de 100644 --- a/pkgs/by-name/st/stress/package.nix +++ b/pkgs/by-name/st/stress/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "stress"; diff --git a/pkgs/by-name/st/stressapptest/package.nix b/pkgs/by-name/st/stressapptest/package.nix index 3243db0d0076c6..d0a19a98a6cac3 100644 --- a/pkgs/by-name/st/stressapptest/package.nix +++ b/pkgs/by-name/st/stressapptest/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, libaio +{ + lib, + stdenv, + fetchFromGitHub, + libaio, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/st/stretchly/package.nix b/pkgs/by-name/st/stretchly/package.nix index da0c4928501807..b921992f6817a7 100644 --- a/pkgs/by-name/st/stretchly/package.nix +++ b/pkgs/by-name/st/stretchly/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchurl -, makeWrapper -, electron -, common-updater-scripts -, writeShellScript -, makeDesktopItem +{ + stdenv, + lib, + fetchurl, + makeWrapper, + electron, + common-updater-scripts, + writeShellScript, + makeDesktopItem, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/st/stricat/package.nix b/pkgs/by-name/st/stricat/package.nix index b21498e009f1a9..bfd6397657b77a 100644 --- a/pkgs/by-name/st/stricat/package.nix +++ b/pkgs/by-name/st/stricat/package.nix @@ -1,11 +1,15 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "stricat"; version = "20140609100300"; src = fetchurl { - url = "http://www.stribob.com/dist/${pname}-${version}.tgz"; + url = "http://www.stribob.com/dist/${pname}-${version}.tgz"; sha256 = "1axg8r4g5n5kdqj5013pgck80nni3z172xkg506vz4zx1zcmrm4r"; }; @@ -18,9 +22,9 @@ stdenv.mkDerivation rec { meta = { description = "Multi-use cryptographic tool based on the STRIBOB algorithm"; - homepage = "https://www.stribob.com/stricat/"; - license = lib.licenses.bsd3; - platforms = lib.platforms.unix; + homepage = "https://www.stribob.com/stricat/"; + license = lib.licenses.bsd3; + platforms = lib.platforms.unix; maintainers = [ lib.maintainers.thoughtpolice ]; mainProgram = "stricat"; }; diff --git a/pkgs/by-name/st/strictdoc/package.nix b/pkgs/by-name/st/strictdoc/package.nix index 49475a7f46a8ac..40eaa2b9702f34 100644 --- a/pkgs/by-name/st/strictdoc/package.nix +++ b/pkgs/by-name/st/strictdoc/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/st/string-machine/package.nix b/pkgs/by-name/st/string-machine/package.nix index d679202343d564..b35d6649fe1e8b 100644 --- a/pkgs/by-name/st/string-machine/package.nix +++ b/pkgs/by-name/st/string-machine/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, boost, cairo, libGL, lv2, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + boost, + cairo, + libGL, + lv2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "string-machine"; @@ -29,7 +39,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - boost cairo libGL lv2 + boost + cairo + libGL + lv2 ]; makeFlags = [ diff --git a/pkgs/by-name/st/structorizer/package.nix b/pkgs/by-name/st/structorizer/package.nix index 282a1eb1cb7e57..6b464a4674014a 100644 --- a/pkgs/by-name/st/structorizer/package.nix +++ b/pkgs/by-name/st/structorizer/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, jdk11 -, makeDesktopItem -, makeWrapper -, copyDesktopItems -, nix-update-script +{ + stdenv, + lib, + fetchFromGitHub, + jdk11, + makeDesktopItem, + makeWrapper, + copyDesktopItems, + nix-update-script, }: stdenv.mkDerivation rec { @@ -30,7 +31,10 @@ stdenv.mkDerivation rec { "RasterGraphics" "ComputerScience" ]; - keywords = [ "nsd" "diagrams" ]; + keywords = [ + "nsd" + "diagrams" + ]; }) ]; @@ -41,11 +45,18 @@ stdenv.mkDerivation rec { hash = "sha256-fqvQH4DRl+R0laGOnfWgFz67JSAdUzrws4k7gmQ3S7A="; }; - patches = [ ./makeStructorizer.patch ./makeBigJar.patch ]; + patches = [ + ./makeStructorizer.patch + ./makeBigJar.patch + ]; strictDeps = true; - nativeBuildInputs = [ jdk11 makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + jdk11 + makeWrapper + copyDesktopItems + ]; buildInputs = [ jdk11 ]; diff --git a/pkgs/by-name/st/stt/package.nix b/pkgs/by-name/st/stt/package.nix index 8d3cb54d614b3d..b39a3922fdbff0 100644 --- a/pkgs/by-name/st/stt/package.nix +++ b/pkgs/by-name/st/stt/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchurl, autoPatchelfHook, bzip2, xz }: +{ + stdenv, + lib, + fetchurl, + autoPatchelfHook, + bzip2, + xz, +}: stdenv.mkDerivation rec { pname = "stt"; diff --git a/pkgs/by-name/st/sttr/package.nix b/pkgs/by-name/st/sttr/package.nix index b276581f38a410..fa864df910bca8 100644 --- a/pkgs/by-name/st/sttr/package.nix +++ b/pkgs/by-name/st/sttr/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/st/stuffbin/package.nix b/pkgs/by-name/st/stuffbin/package.nix index 6249c7f5bbd51a..a5b629bf3da193 100644 --- a/pkgs/by-name/st/stuffbin/package.nix +++ b/pkgs/by-name/st/stuffbin/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "stuffbin"; @@ -13,7 +17,11 @@ buildGoModule rec { sha256 = "sha256-dOlc/G2IiuMAN0LqiZtbpXLSYaOpe5cl1+cs3YhaAbg="; }; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; meta = with lib; { description = "Compress and embed static files and assets into Go binaries and access them with a virtual file system in production"; diff --git a/pkgs/by-name/st/stumpish/package.nix b/pkgs/by-name/st/stumpish/package.nix index c776e66da886e4..a7bfd38c07a860 100644 --- a/pkgs/by-name/st/stumpish/package.nix +++ b/pkgs/by-name/st/stumpish/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, substituteAll, fetchFromGitHub, gnused, ncurses, xorg, rlwrap }: +{ + lib, + stdenv, + substituteAll, + fetchFromGitHub, + gnused, + ncurses, + xorg, + rlwrap, +}: stdenv.mkDerivation { pname = "stumpish"; @@ -12,7 +21,10 @@ stdenv.mkDerivation { }; buildInputs = [ - gnused xorg.xprop rlwrap ncurses + gnused + xorg.xprop + rlwrap + ncurses ]; patches = [ diff --git a/pkgs/by-name/st/stun/package.nix b/pkgs/by-name/st/stun/package.nix index de4787eca63a56..01e36817f2b282 100644 --- a/pkgs/by-name/st/stun/package.nix +++ b/pkgs/by-name/st/stun/package.nix @@ -1,21 +1,28 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { - pname = "stun"; + pname = "stun"; version = "0.97"; src = fetchurl { - url = "mirror://sourceforge/${pname}/stund-${version}.tgz"; + url = "mirror://sourceforge/${pname}/stund-${version}.tgz"; sha256 = "1mxirnnqfqdwb9x8hfjjsscp6lx3468ph6ddx32l94ir46fbzqc3"; }; srcManpages = fetchurl { - url = "mirror://ubuntu/pool/universe/s/stun/stun_0.97~dfsg-2.debian.tar.xz"; - name = "stun-debian.tar.xz"; + url = "mirror://ubuntu/pool/universe/s/stun/stun_0.97~dfsg-2.debian.tar.xz"; + name = "stun-debian.tar.xz"; sha256 = "1pr6zrdhia0aafsvywl1hrhlgl00vahp63bw1z2mzvdxri7q88f0"; }; - outputs = [ "out" "server" ]; + outputs = [ + "out" + "server" + ]; preBuild = '' tar Jxvf ${srcManpages} debian/manpages @@ -33,10 +40,13 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Stun server and test client"; - homepage = "https://sourceforge.net/projects/stun/"; - license = licenses.vsl10; - maintainers = with maintainers; [ marcweber obadz ]; - platforms = platforms.linux; + homepage = "https://sourceforge.net/projects/stun/"; + license = licenses.vsl10; + maintainers = with maintainers; [ + marcweber + obadz + ]; + platforms = platforms.linux; mainProgram = "stun"; }; } diff --git a/pkgs/by-name/st/stunnel/package.nix b/pkgs/by-name/st/stunnel/package.nix index b055cc596fe6e9..26381ad4f4b840 100644 --- a/pkgs/by-name/st/stunnel/package.nix +++ b/pkgs/by-name/st/stunnel/package.nix @@ -1,20 +1,24 @@ { - fetchurl -, lib -, nixosTests -, openssl -, stdenv -, systemd -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd -, mimalloc -, mimallocSupport ? false + fetchurl, + lib, + nixosTests, + openssl, + stdenv, + systemd, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, + mimalloc, + mimallocSupport ? false, }: stdenv.mkDerivation (finalAttrs: { pname = "stunnel"; version = "5.73"; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; src = fetchurl { url = "https://www.stunnel.org/archive/${lib.versions.major finalAttrs.version}.x/stunnel-${finalAttrs.version}.tar.gz"; @@ -25,13 +29,16 @@ stdenv.mkDerivation (finalAttrs: { enableParallelBuilding = true; - buildInputs = [ - openssl - ] ++ lib.optionals systemdSupport [ - systemd - ] ++ lib.optionals mimallocSupport [ - mimalloc - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals systemdSupport [ + systemd + ] + ++ lib.optionals mimallocSupport [ + mimalloc + ]; configureFlags = [ "--with-ssl=${openssl.dev}" diff --git a/pkgs/by-name/st/stuntman/package.nix b/pkgs/by-name/st/stuntman/package.nix index 3d2ff6eeb50c5d..580378ad350c4b 100644 --- a/pkgs/by-name/st/stuntman/package.nix +++ b/pkgs/by-name/st/stuntman/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, openssl, boost }: +{ + stdenv, + lib, + fetchFromGitHub, + openssl, + boost, +}: stdenv.mkDerivation { pname = "stuntman"; diff --git a/pkgs/by-name/st/stw/package.nix b/pkgs/by-name/st/stw/package.nix index 5f36e1e1126c27..3f73693a3a334a 100644 --- a/pkgs/by-name/st/stw/package.nix +++ b/pkgs/by-name/st/stw/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, libX11 -, fontconfig -, libXft -, libXrender +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + fontconfig, + libXft, + libXrender, }: stdenv.mkDerivation rec { @@ -18,9 +19,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-YohHF1O0lm6QWJv/wkS4RVJvWaOjcYSZNls6tt4hbqo=="; }; - buildInputs = [ libX11 fontconfig libXft libXrender ]; + buildInputs = [ + libX11 + fontconfig + libXft + libXrender + ]; - makeFlags = [ "CC:=$(CC)" "PREFIX=$(out)" ]; + makeFlags = [ + "CC:=$(CC)" + "PREFIX=$(out)" + ]; meta = with lib; { description = "Simple text widget for X resembling the watch(1) command"; diff --git a/pkgs/by-name/st/stxxl/package.nix b/pkgs/by-name/st/stxxl/package.nix index 31d9098242c2af..d045a889a016d9 100644 --- a/pkgs/by-name/st/stxxl/package.nix +++ b/pkgs/by-name/st/stxxl/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, parallelSupport ? (!stdenv.hostPlatform.isDarwin) +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + parallelSupport ? (!stdenv.hostPlatform.isDarwin), }: let diff --git a/pkgs/by-name/st/stylance-cli/package.nix b/pkgs/by-name/st/stylance-cli/package.nix index fd01a5acf180e0..ba099d5aabfba7 100644 --- a/pkgs/by-name/st/stylance-cli/package.nix +++ b/pkgs/by-name/st/stylance-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { pname = "stylance-cli"; diff --git a/pkgs/by-name/st/stylish/package.nix b/pkgs/by-name/st/stylish/package.nix index 77b3d480ac1d49..6ab7d2a5ab11dc 100644 --- a/pkgs/by-name/st/stylish/package.nix +++ b/pkgs/by-name/st/stylish/package.nix @@ -32,14 +32,16 @@ stdenvNoCC.mkDerivation rec { ''; postInstall = '' - wrapProgram $out/bin/styli.sh --prefix PATH : ${lib.makeBinPath [ - curl - feh - file - jq - util-linux - wget - ]} + wrapProgram $out/bin/styli.sh --prefix PATH : ${ + lib.makeBinPath [ + curl + feh + file + jq + util-linux + wget + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/st/stylua/package.nix b/pkgs/by-name/st/stylua/package.nix index ec3975af81cb97..06e2e45a26be32 100644 --- a/pkgs/by-name/st/stylua/package.nix +++ b/pkgs/by-name/st/stylua/package.nix @@ -1,8 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, # lua54 implies lua52/lua53 -, features ? [ "lua54" "luajit" "luau" ] + features ? [ + "lua54" + "luajit" + "luau" + ], }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/st/styluslabs-write-bin/package.nix b/pkgs/by-name/st/styluslabs-write-bin/package.nix index d15875494d794e..3e5f19a5f05bf5 100644 --- a/pkgs/by-name/st/styluslabs-write-bin/package.nix +++ b/pkgs/by-name/st/styluslabs-write-bin/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, libsForQt5, libglvnd, libX11, libXi, fetchurl, makeDesktopItem }: +{ + stdenv, + lib, + libsForQt5, + libglvnd, + libX11, + libXi, + fetchurl, + makeDesktopItem, +}: let desktopItem = makeDesktopItem { name = "Write"; @@ -7,7 +16,10 @@ let icon = "write_stylus"; desktopName = "Write"; genericName = "Write"; - categories = [ "Office" "Graphics" ]; + categories = [ + "Office" + "Graphics" + ]; }; in stdenv.mkDerivation rec { @@ -35,21 +47,23 @@ stdenv.mkDerivation rec { mkdir -p $out/share/icons ln -s $out/Write/Write144x144.png $out/share/icons/write_stylus.png ''; - preFixup = let - libPath = lib.makeLibraryPath [ - libsForQt5.qtbase # libQt5PrintSupport.so.5 - libsForQt5.qtsvg # libQt5Svg.so.5 - (lib.getLib stdenv.cc.cc) # libstdc++.so.6 - libglvnd # libGL.so.1 - libX11 # libX11.so.6 - libXi # libXi.so.6 - ]; - in '' - patchelf \ - --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath "${libPath}" \ - $out/Write/Write - ''; + preFixup = + let + libPath = lib.makeLibraryPath [ + libsForQt5.qtbase # libQt5PrintSupport.so.5 + libsForQt5.qtsvg # libQt5Svg.so.5 + (lib.getLib stdenv.cc.cc) # libstdc++.so.6 + libglvnd # libGL.so.1 + libX11 # libX11.so.6 + libXi # libXi.so.6 + ]; + in + '' + patchelf \ + --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ + --set-rpath "${libPath}" \ + $out/Write/Write + ''; meta = with lib; { homepage = "http://www.styluslabs.com/"; @@ -57,6 +71,10 @@ stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; platforms = platforms.linux; license = lib.licenses.unfree; - maintainers = with maintainers; [ oyren lukts30 atemu ]; + maintainers = with maintainers; [ + oyren + lukts30 + atemu + ]; }; } diff --git a/pkgs/by-name/st/styx/package.nix b/pkgs/by-name/st/styx/package.nix index 96278fd9c3222f..bc9825efdbabe3 100644 --- a/pkgs/by-name/st/styx/package.nix +++ b/pkgs/by-name/st/styx/package.nix @@ -1,15 +1,26 @@ -{ lib, stdenv, fetchFromGitHub, caddy, asciidoctor -, file, lessc, sass, multimarkdown, linkchecker -, perlPackages, python3Packages }: +{ + lib, + stdenv, + fetchFromGitHub, + caddy, + asciidoctor, + file, + lessc, + sass, + multimarkdown, + linkchecker, + perlPackages, + python3Packages, +}: stdenv.mkDerivation rec { pname = "styx"; version = "0.7.5"; src = fetchFromGitHub { - owner = "styx-static"; - repo = "styx"; - rev = "v${version}"; + owner = "styx-static"; + repo = "styx"; + rev = "v${version}"; hash = "sha256-f6iA/nHpKnm3BALoQq8SzdcSzJLCFSferEf69SpgD2Y="; }; @@ -18,7 +29,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ asciidoctor ]; - outputs = [ "out" "lib" "themes" ]; + outputs = [ + "out" + "lib" + "themes" + ]; propagatedBuildInputs = [ file @@ -61,12 +76,12 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = "Nix based static site generator"; - maintainers = with maintainers; [ ericsagnes ]; - homepage = "https://styx-static.github.io/styx-site/"; + description = "Nix based static site generator"; + maintainers = with maintainers; [ ericsagnes ]; + homepage = "https://styx-static.github.io/styx-site/"; downloadPage = "https://github.com/styx-static/styx/"; - platforms = platforms.all; - license = licenses.mit; - mainProgram = "styx"; + platforms = platforms.all; + license = licenses.mit; + mainProgram = "styx"; }; } diff --git a/pkgs/by-name/su/su-exec/package.nix b/pkgs/by-name/su/su-exec/package.nix index 2af4591784ab20..c65562b5c24853 100644 --- a/pkgs/by-name/su/su-exec/package.nix +++ b/pkgs/by-name/su/su-exec/package.nix @@ -1,13 +1,17 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "su-exec"; version = "0.2"; src = fetchFromGitHub { - owner = "ncopa"; - repo = "su-exec"; - rev = "v${version}"; + owner = "ncopa"; + repo = "su-exec"; + rev = "v${version}"; hash = "sha256-eymE9r9Rm/u4El5wXHbkAh7ma5goWV0EdJIhsq+leIs="; }; @@ -19,9 +23,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "switch user and group id and exec"; mainProgram = "su-exec"; - homepage = "https://github.com/ncopa/su-exec"; - license = licenses.mit; + homepage = "https://github.com/ncopa/su-exec"; + license = licenses.mit; maintainers = with maintainers; [ zimbatm ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/su/sub-batch/package.nix b/pkgs/by-name/su/sub-batch/package.nix index 48b38da01fae57..0cfeddd572dbb3 100644 --- a/pkgs/by-name/su/sub-batch/package.nix +++ b/pkgs/by-name/su/sub-batch/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, rustPlatform -, makeWrapper -, alass +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + makeWrapper, + alass, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/su/subberthehut/package.nix b/pkgs/by-name/su/subberthehut/package.nix index 58860f30dc5a1e..3dd753b787618e 100644 --- a/pkgs/by-name/su/subberthehut/package.nix +++ b/pkgs/by-name/su/subberthehut/package.nix @@ -1,17 +1,29 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, xmlrpc_c, glib, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + xmlrpc_c, + glib, + zlib, +}: stdenv.mkDerivation rec { pname = "subberthehut"; version = "20"; src = fetchFromGitHub { - owner = "mus65"; - repo = "subberthehut"; - rev = version; + owner = "mus65"; + repo = "subberthehut"; + rev = version; sha256 = "19prdqbk19h0wak318g2jn1mnfm7l7f83a633bh0rhskysmqrsj1"; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ xmlrpc_c glib zlib ]; + buildInputs = [ + xmlrpc_c + glib + zlib + ]; installPhase = '' install -Dm755 subberthehut $out/bin/subberthehut diff --git a/pkgs/by-name/su/subdl/package.nix b/pkgs/by-name/su/subdl/package.nix index 61b5af2f0b57b2..95272e63b05417 100644 --- a/pkgs/by-name/su/subdl/package.nix +++ b/pkgs/by-name/su/subdl/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation { pname = "subdl"; diff --git a/pkgs/by-name/su/subedit/package.nix b/pkgs/by-name/su/subedit/package.nix index 9bacdc23de0db1..6537bc913e3271 100644 --- a/pkgs/by-name/su/subedit/package.nix +++ b/pkgs/by-name/su/subedit/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper, libuchardet, dos2unix, file }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + libuchardet, + dos2unix, + file, +}: stdenv.mkDerivation { pname = "subedit"; @@ -13,7 +21,11 @@ stdenv.mkDerivation { nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ libuchardet dos2unix file ]; + buildInputs = [ + libuchardet + dos2unix + file + ]; installPhase = '' mkdir -p $out/bin @@ -21,7 +33,13 @@ stdenv.mkDerivation { ''; postFixup = '' - wrapProgram $out/bin/subedit --prefix PATH : "${lib.makeBinPath [ libuchardet dos2unix file ]}" + wrapProgram $out/bin/subedit --prefix PATH : "${ + lib.makeBinPath [ + libuchardet + dos2unix + file + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/su/subfinder/package.nix b/pkgs/by-name/su/subfinder/package.nix index f973d7fae5c5aa..8a24177d1badb6 100644 --- a/pkgs/by-name/su/subfinder/package.nix +++ b/pkgs/by-name/su/subfinder/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -36,7 +37,11 @@ buildGoModule rec { ''; homepage = "https://github.com/projectdiscovery/subfinder"; license = licenses.mit; - maintainers = with maintainers; [ fpletz Br1ght0ne Misaka13514 ]; + maintainers = with maintainers; [ + fpletz + Br1ght0ne + Misaka13514 + ]; mainProgram = "subfinder"; }; } diff --git a/pkgs/by-name/su/subjs/package.nix b/pkgs/by-name/su/subjs/package.nix index 0bd3c170b65637..9bc455593bba19 100644 --- a/pkgs/by-name/su/subjs/package.nix +++ b/pkgs/by-name/su/subjs/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { @@ -16,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-Ibsgi2MYvs12E1NJgshAD/S5GTJgLl7C+smfvS+aAfg="; - ldflags = [ "-s" "-w" "-X main.AppVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.AppVersion=${version}" + ]; meta = with lib; { description = "Fetcher for Javascript files"; diff --git a/pkgs/by-name/su/sublime-music/package.nix b/pkgs/by-name/su/sublime-music/package.nix index f3ad04e7b01cbd..400b0c1ce10d01 100644 --- a/pkgs/by-name/su/sublime-music/package.nix +++ b/pkgs/by-name/su/sublime-music/package.nix @@ -1,18 +1,19 @@ -{ lib -, fetchFromGitHub -, python3 -, gobject-introspection -, gtk3 -, pango -, wrapGAppsHook3 -, chromecastSupport ? false -, serverSupport ? false -, keyringSupport ? true -, notifySupport ? true -, libnotify -, networkSupport ? true -, networkmanager -, fetchpatch +{ + lib, + fetchFromGitHub, + python3, + gobject-introspection, + gtk3, + pango, + wrapGAppsHook3, + chromecastSupport ? false, + serverSupport ? false, + keyringSupport ? true, + notifySupport ? true, + libnotify, + networkSupport ? true, + networkmanager, + fetchpatch, }: python3.pkgs.buildPythonApplication rec { @@ -44,31 +45,32 @@ python3.pkgs.buildPythonApplication rec { wrapGAppsHook3 ]; - buildInputs = [ - gtk3 - pango - ] - ++ lib.optional notifySupport libnotify - ++ lib.optional networkSupport networkmanager - ; + buildInputs = + [ + gtk3 + pango + ] + ++ lib.optional notifySupport libnotify + ++ lib.optional networkSupport networkmanager; - propagatedBuildInputs = with python3.pkgs; [ - bleach - bottle - dataclasses-json - deepdiff - levenshtein - mpv - peewee - pychromecast - pygobject3 - python-dateutil - requests - semver - thefuzz - ] - ++ lib.optional keyringSupport keyring - ; + propagatedBuildInputs = + with python3.pkgs; + [ + bleach + bottle + dataclasses-json + deepdiff + levenshtein + mpv + peewee + pychromecast + pygobject3 + python-dateutil + requests + semver + thefuzz + ] + ++ lib.optional keyringSupport keyring; nativeCheckInputs = with python3.pkgs; [ pytest-cov-stub @@ -99,7 +101,10 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://sublimemusic.app"; changelog = "https://github.com/sublime-music/sublime-music/blob/v${version}/CHANGELOG.rst"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ albakham sumnerevans ]; + maintainers = with maintainers; [ + albakham + sumnerevans + ]; mainProgram = "sublime-music"; }; } diff --git a/pkgs/by-name/su/sublime/package.nix b/pkgs/by-name/su/sublime/package.nix index 1a62b1256cca05..3f8137f7a783e5 100644 --- a/pkgs/by-name/su/sublime/package.nix +++ b/pkgs/by-name/su/sublime/package.nix @@ -1,6 +1,20 @@ -{ fetchurl, lib, stdenv, glib, xorg, cairo, gtk2, makeDesktopItem }: +{ + fetchurl, + lib, + stdenv, + glib, + xorg, + cairo, + gtk2, + makeDesktopItem, +}: let - libPath = lib.makeLibraryPath [ glib xorg.libX11 gtk2 cairo ]; + libPath = lib.makeLibraryPath [ + glib + xorg.libX11 + gtk2 + cairo + ]; in stdenv.mkDerivation rec { @@ -55,7 +69,10 @@ stdenv.mkDerivation rec { comment = meta.description; desktopName = "Sublime Text"; genericName = "Text Editor"; - categories = [ "TextEditor" "Development" ]; + categories = [ + "TextEditor" + "Development" + ]; icon = "sublime_text"; }; @@ -63,6 +80,9 @@ stdenv.mkDerivation rec { description = "Sophisticated text editor for code, markup and prose"; license = lib.licenses.unfree; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/by-name/su/sublime_syntax_convertor/gemset.nix b/pkgs/by-name/su/sublime_syntax_convertor/gemset.nix index 2412fea8a26452..246a8f8e5297b3 100644 --- a/pkgs/by-name/su/sublime_syntax_convertor/gemset.nix +++ b/pkgs/by-name/su/sublime_syntax_convertor/gemset.nix @@ -1,20 +1,20 @@ { plist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b643i5b7b7galvlb2fc414ifmb78b5lsq47gnvhzl8m27dl559z"; type = "gem"; }; version = "3.7.1"; }; sublime_syntax_convertor = { - dependencies = ["plist"]; - groups = ["default"]; - platforms = []; + dependencies = [ "plist" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gg65xls9rl9df37njja5f7y6mm1cbnf9yafyy3j7cnkcszif43a"; type = "gem"; }; diff --git a/pkgs/by-name/su/sublime_syntax_convertor/package.nix b/pkgs/by-name/su/sublime_syntax_convertor/package.nix index b9be2f7b7056d7..869498bfb4ed37 100644 --- a/pkgs/by-name/su/sublime_syntax_convertor/package.nix +++ b/pkgs/by-name/su/sublime_syntax_convertor/package.nix @@ -1,4 +1,4 @@ -{ lib,bundlerApp }: +{ lib, bundlerApp }: bundlerApp { pname = "sublime_syntax_convertor"; gemdir = ./.; diff --git a/pkgs/by-name/su/subnetcalc/package.nix b/pkgs/by-name/su/subnetcalc/package.nix index 4c88c6cb29f768..b3655666855938 100644 --- a/pkgs/by-name/su/subnetcalc/package.nix +++ b/pkgs/by-name/su/subnetcalc/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/su/subread/package.nix b/pkgs/by-name/su/subread/package.nix index 287e55cb0a74f1..914d2b0e48a2ee 100644 --- a/pkgs/by-name/su/subread/package.nix +++ b/pkgs/by-name/su/subread/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, zlib +{ + lib, + stdenv, + fetchurl, + zlib, }: stdenv.mkDerivation rec { @@ -34,7 +35,10 @@ stdenv.mkDerivation rec { description = "High-performance read alignment, quantification and mutation discovery"; license = licenses.gpl3; maintainers = with maintainers; [ jbedo ]; - platforms = [ "x86_64-darwin" "x86_64-linux" ]; + platforms = [ + "x86_64-darwin" + "x86_64-linux" + ]; homepage = "https://subread.sourceforge.net/"; }; diff --git a/pkgs/by-name/su/subsonic/package.nix b/pkgs/by-name/su/subsonic/package.nix index 8e04dcb1cb98e9..a24f96ad735c00 100644 --- a/pkgs/by-name/su/subsonic/package.nix +++ b/pkgs/by-name/su/subsonic/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, jre }: +{ + lib, + stdenv, + fetchurl, + jre, +}: stdenv.mkDerivation rec { pname = "subsonic"; diff --git a/pkgs/by-name/su/subtitlecomposer/package.nix b/pkgs/by-name/su/subtitlecomposer/package.nix index ce6e7fe6e63569..b7ceb21b7ab51b 100644 --- a/pkgs/by-name/su/subtitlecomposer/package.nix +++ b/pkgs/by-name/su/subtitlecomposer/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitLab -, cmake -, extra-cmake-modules -, ffmpeg -, openal -, stdenv -, libsForQt5 +{ + lib, + fetchFromGitLab, + cmake, + extra-cmake-modules, + ffmpeg, + openal, + stdenv, + libsForQt5, }: stdenv.mkDerivation rec { @@ -20,19 +21,28 @@ stdenv.mkDerivation rec { hash = "sha256-5RBrxOy1EIgDLb21r1y+Pou8d/j05a1YYMRJh1n8vSA="; }; - nativeBuildInputs = [ cmake extra-cmake-modules libsForQt5.wrapQtAppsHook ]; - buildInputs = [ ffmpeg openal ] ++ (with libsForQt5; [ - kcodecs - kconfig - kconfigwidgets - kcoreaddons - ki18n - kio - ktextwidgets - kwidgetsaddons - kxmlgui - sonnet - ]); + nativeBuildInputs = [ + cmake + extra-cmake-modules + libsForQt5.wrapQtAppsHook + ]; + buildInputs = + [ + ffmpeg + openal + ] + ++ (with libsForQt5; [ + kcodecs + kconfig + kconfigwidgets + kcoreaddons + ki18n + kio + ktextwidgets + kwidgetsaddons + kxmlgui + sonnet + ]); meta = with lib; { homepage = "https://apps.kde.org/subtitlecomposer"; diff --git a/pkgs/by-name/su/subtitleeditor/package.nix b/pkgs/by-name/su/subtitleeditor/package.nix index b440c187403e5d..28b563fb9b4620 100644 --- a/pkgs/by-name/su/subtitleeditor/package.nix +++ b/pkgs/by-name/su/subtitleeditor/package.nix @@ -1,6 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, intltool, file, - desktop-file-utils, enchant, gtk3, gtkmm3, gst_all_1, hicolor-icon-theme, - libsigcxx, libxmlxx, xdg-utils, isocodes, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + intltool, + file, + desktop-file-utils, + enchant, + gtk3, + gtkmm3, + gst_all_1, + hicolor-icon-theme, + libsigcxx, + libxmlxx, + xdg-utils, + isocodes, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -14,7 +30,7 @@ stdenv.mkDerivation rec { sha256 = "sha256-1Q1nd3GJ6iDGQv4SM2S1ehVW6kPdbqTn8KTtTb0obiQ="; }; - nativeBuildInputs = [ + nativeBuildInputs = [ autoreconfHook pkg-config intltool @@ -22,7 +38,7 @@ stdenv.mkDerivation rec { wrapGAppsHook3 ]; - buildInputs = [ + buildInputs = [ desktop-file-utils enchant gtk3 @@ -54,7 +70,7 @@ stdenv.mkDerivation rec { can be used for new subtitles or as a tool to transform, edit, correct and refine existing subtitle. This program also shows sound waves, which makes it easier to synchronise subtitles to voices. - ''; + ''; homepage = "http://kitone.github.io/subtitleeditor/"; license = lib.licenses.gpl3Plus; platforms = lib.platforms.linux; diff --git a/pkgs/by-name/su/subtitlr/package.nix b/pkgs/by-name/su/subtitlr/package.nix index 0444fa7d4535c0..ffcb31ed21aec2 100644 --- a/pkgs/by-name/su/subtitlr/package.nix +++ b/pkgs/by-name/su/subtitlr/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "Subtitlr"; @@ -13,7 +18,10 @@ buildGoModule rec { vendorHash = "sha256-ZgJCk9vbbQ0dcYSdKm0Cbw2AmwjpMvGb5zJkgbD+xig="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeBuildInputs = [ installShellFiles diff --git a/pkgs/by-name/su/subunit/package.nix b/pkgs/by-name/su/subunit/package.nix index 188759fc4e7ed7..a40e846e4fd32b 100644 --- a/pkgs/by-name/su/subunit/package.nix +++ b/pkgs/by-name/su/subunit/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, check, cppunit, perl, python3Packages }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + check, + cppunit, + perl, + python3Packages, +}: # NOTE: for subunit python library see pkgs/top-level/python-packages.nix @@ -12,9 +21,17 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ check cppunit perl python3Packages.wrapPython ]; + buildInputs = [ + check + cppunit + perl + python3Packages.wrapPython + ]; - propagatedBuildInputs = with python3Packages; [ testtools testscenarios ]; + propagatedBuildInputs = with python3Packages; [ + testtools + testscenarios + ]; postFixup = "wrapPythonPrograms"; diff --git a/pkgs/by-name/su/sudachi-rs/package.nix b/pkgs/by-name/su/sudachi-rs/package.nix index 34398b1c40d1d9..195bc1be61d3fe 100644 --- a/pkgs/by-name/su/sudachi-rs/package.nix +++ b/pkgs/by-name/su/sudachi-rs/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, sudachidict -, runCommand -, sudachi-rs -, writeScript +{ + lib, + rustPlatform, + fetchFromGitHub, + sudachidict, + runCommand, + sudachi-rs, + writeScript, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/su/sudachidict/package.nix b/pkgs/by-name/su/sudachidict/package.nix index 744439283367c4..87b4c8b3a71d93 100644 --- a/pkgs/by-name/su/sudachidict/package.nix +++ b/pkgs/by-name/su/sudachidict/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchzip -, dict-type ? "core" +{ + lib, + stdenvNoCC, + fetchzip, + dict-type ? "core", }: let @@ -26,35 +27,36 @@ in lib.checkListOfEnum "${pname}: dict-type" [ "core" "full" "small" ] [ dict-type ] -stdenvNoCC.mkDerivation { - inherit pname version; + stdenvNoCC.mkDerivation + { + inherit pname version; - src = srcs.${dict-type}; + src = srcs.${dict-type}; - dontConfigure = true; + dontConfigure = true; - dontBuild = true; + dontBuild = true; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - install -Dm644 system_${dict-type}.dic $out/share/system.dic + install -Dm644 system_${dict-type}.dic $out/share/system.dic - runHook postInstall - ''; + runHook postInstall + ''; - passthru = { - dict-type = dict-type; - }; + passthru = { + dict-type = dict-type; + }; - meta = with lib; { - description = "Lexicon for Sudachi"; - homepage = "https://github.com/WorksApplications/SudachiDict"; - changelog = "https://github.com/WorksApplications/SudachiDict/releases/tag/v${version}"; - license = licenses.asl20; - maintainers = with maintainers; [ natsukium ]; - platforms = platforms.all; - # it is a waste of space and time to build this package in hydra since it is just data - hydraPlatforms = []; - }; -} + meta = with lib; { + description = "Lexicon for Sudachi"; + homepage = "https://github.com/WorksApplications/SudachiDict"; + changelog = "https://github.com/WorksApplications/SudachiDict/releases/tag/v${version}"; + license = licenses.asl20; + maintainers = with maintainers; [ natsukium ]; + platforms = platforms.all; + # it is a waste of space and time to build this package in hydra since it is just data + hydraPlatforms = [ ]; + }; + } diff --git a/pkgs/by-name/su/sudo-font/package.nix b/pkgs/by-name/su/sudo-font/package.nix index 1d0cb0510606d4..940c11a76b2c70 100644 --- a/pkgs/by-name/su/sudo-font/package.nix +++ b/pkgs/by-name/su/sudo-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "sudo-font"; diff --git a/pkgs/by-name/su/sudo-rs/package.nix b/pkgs/by-name/su/sudo-rs/package.nix index 155d23dbad89ff..17a7b4744fa2b9 100644 --- a/pkgs/by-name/su/sudo-rs/package.nix +++ b/pkgs/by-name/su/sudo-rs/package.nix @@ -1,12 +1,13 @@ -{ lib -, bash -, fetchFromGitHub -, installShellFiles -, nix-update-script -, nixosTests -, pam -, pandoc -, rustPlatform +{ + lib, + bash, + fetchFromGitHub, + installShellFiles, + nix-update-script, + nixosTests, + pam, + pandoc, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage rec { }; cargoHash = "sha256-laTcGi2pwc9uWjum03PviyakVMmjijKgxfIPjIpoRy8="; - nativeBuildInputs = [ installShellFiles pandoc ]; + nativeBuildInputs = [ + installShellFiles + pandoc + ]; buildInputs = [ pam ]; @@ -73,7 +77,10 @@ rustPlatform.buildRustPackage rec { description = "Memory safe implementation of sudo and su"; homepage = "https://github.com/trifectatechfoundation/sudo-rs"; changelog = "${meta.homepage}/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ nicoo ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/su/sudo/package.nix b/pkgs/by-name/su/sudo/package.nix index dfa6b854727aa9..a4b35cf890f171 100644 --- a/pkgs/by-name/su/sudo/package.nix +++ b/pkgs/by-name/su/sudo/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, buildPackages -, coreutils -, pam -, groff -, sssd -, nixosTests -, sendmailPath ? "/run/wrappers/bin/sendmail" -, withInsults ? false -, withSssd ? false +{ + lib, + stdenv, + fetchurl, + buildPackages, + coreutils, + pam, + groff, + sssd, + nixosTests, + sendmailPath ? "/run/wrappers/bin/sendmail", + withInsults ? false, + withSssd ? false, }: stdenv.mkDerivation (finalAttrs: { @@ -30,33 +31,35 @@ stdenv.mkDerivation (finalAttrs: { substituteInPlace src/Makefile.in --replace 04755 0755 ''; - configureFlags = [ - "--with-env-editor" - "--with-editor=/run/current-system/sw/bin/nano" - "--with-rundir=/run/sudo" - "--with-vardir=/var/db/sudo" - "--with-logpath=/var/log/sudo.log" - "--with-iologdir=/var/log/sudo-io" - "--with-sendmail=${sendmailPath}" - "--enable-tmpfiles.d=no" - "--with-passprompt=[sudo] password for %p: " # intentional trailing space - ] ++ lib.optionals withInsults [ - "--with-insults" - "--with-all-insults" - ] ++ lib.optionals withSssd [ - "--with-sssd" - "--with-sssd-lib=${sssd}/lib" - ]; + configureFlags = + [ + "--with-env-editor" + "--with-editor=/run/current-system/sw/bin/nano" + "--with-rundir=/run/sudo" + "--with-vardir=/var/db/sudo" + "--with-logpath=/var/log/sudo.log" + "--with-iologdir=/var/log/sudo-io" + "--with-sendmail=${sendmailPath}" + "--enable-tmpfiles.d=no" + "--with-passprompt=[sudo] password for %p: " # intentional trailing space + ] + ++ lib.optionals withInsults [ + "--with-insults" + "--with-all-insults" + ] + ++ lib.optionals withSssd [ + "--with-sssd" + "--with-sssd-lib=${sssd}/lib" + ]; - postConfigure = - '' - cat >> pathnames.h <<'EOF' - #undef _PATH_MV - #define _PATH_MV "${coreutils}/bin/mv" - EOF - makeFlags="install_uid=$(id -u) install_gid=$(id -g)" - installFlags="sudoers_uid=$(id -u) sudoers_gid=$(id -g) sysconfdir=$out/etc rundir=$TMPDIR/dummy vardir=$TMPDIR/dummy DESTDIR=/" - ''; + postConfigure = '' + cat >> pathnames.h <<'EOF' + #undef _PATH_MV + #define _PATH_MV "${coreutils}/bin/mv" + EOF + makeFlags="install_uid=$(id -u) install_gid=$(id -g)" + installFlags="sudoers_uid=$(id -u) sudoers_gid=$(id -g) sysconfdir=$out/etc rundir=$TMPDIR/dummy vardir=$TMPDIR/dummy DESTDIR=/" + ''; depsBuildBuild = [ buildPackages.stdenv.cc ]; nativeBuildInputs = [ groff ]; @@ -74,16 +77,20 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Command to run commands as root"; - longDescription = - '' - Sudo (su "do") allows a system administrator to delegate - authority to give certain users (or groups of users) the ability - to run some (or all) commands as root or another user while - providing an audit trail of the commands and their arguments. - ''; + longDescription = '' + Sudo (su "do") allows a system administrator to delegate + authority to give certain users (or groups of users) the ability + to run some (or all) commands as root or another user while + providing an audit trail of the commands and their arguments. + ''; homepage = "https://www.sudo.ws/"; # From https://www.sudo.ws/about/license/ - license = with licenses; [ sudo bsd2 bsd3 zlib ]; + license = with licenses; [ + sudo + bsd2 + bsd3 + zlib + ]; maintainers = with maintainers; [ rhendric ]; platforms = platforms.linux ++ platforms.freebsd; mainProgram = "sudo"; diff --git a/pkgs/by-name/su/suidChroot/package.nix b/pkgs/by-name/su/suidChroot/package.nix index e12b0d828619a8..a19d0e7de06e53 100644 --- a/pkgs/by-name/su/suidChroot/package.nix +++ b/pkgs/by-name/su/suidChroot/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "suid-chroot"; diff --git a/pkgs/by-name/su/summon/package.nix b/pkgs/by-name/su/summon/package.nix index db3eed974f4507..af4a2bc77b4d17 100644 --- a/pkgs/by-name/su/summon/package.nix +++ b/pkgs/by-name/su/summon/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "summon"; @@ -20,8 +24,7 @@ buildGoModule rec { ''; meta = with lib; { - description = - "CLI that provides on-demand secrets access for common DevOps tools"; + description = "CLI that provides on-demand secrets access for common DevOps tools"; mainProgram = "summon"; homepage = "https://cyberark.github.io/summon"; license = lib.licenses.mit; diff --git a/pkgs/by-name/su/sumo/package.nix b/pkgs/by-name/su/sumo/package.nix index 282a1f23c944c8..22c7889e70ffbc 100644 --- a/pkgs/by-name/su/sumo/package.nix +++ b/pkgs/by-name/su/sumo/package.nix @@ -1,7 +1,34 @@ -{ lib, bzip2, cmake, eigen, fetchFromGitHub, ffmpeg, fox_1_6, gdal, - git, gl2ps, gpp , gtest, jdk, libGL, libGLU, libX11, libjpeg, - libpng, libtiff, libxcrypt, openscenegraph , proj, python3, - python3Packages, stdenv, swig, xercesc, xorg, zlib }: +{ + lib, + bzip2, + cmake, + eigen, + fetchFromGitHub, + ffmpeg, + fox_1_6, + gdal, + git, + gl2ps, + gpp, + gtest, + jdk, + libGL, + libGLU, + libX11, + libjpeg, + libpng, + libtiff, + libxcrypt, + openscenegraph, + proj, + python3, + python3Packages, + stdenv, + swig, + xercesc, + xorg, + zlib, +}: stdenv.mkDerivation rec { pname = "sumo"; @@ -10,7 +37,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "eclipse"; repo = "sumo"; - rev = "v${lib.replaceStrings ["."] ["_"] version}"; + rev = "v${lib.replaceStrings [ "." ] [ "_" ] version}"; hash = "sha256-VST3ZJuDQBWf+YoN0kPyLrlXWmJABubUFDsKEMxfxHY="; fetchSubmodules = true; }; @@ -21,37 +48,39 @@ stdenv.mkDerivation rec { swig ]; - buildInputs = [ - bzip2 - eigen - ffmpeg - fox_1_6 - gdal - gl2ps - gpp - gtest - jdk - libGL - libGLU - libjpeg - libpng - libtiff - libxcrypt - openscenegraph - proj - python3Packages.setuptools - xercesc - zlib - python3 - ] ++ (with xorg; [ - libX11 - libXcursor - libXext - libXfixes - libXft - libXrandr - libXrender - ]); + buildInputs = + [ + bzip2 + eigen + ffmpeg + fox_1_6 + gdal + gl2ps + gpp + gtest + jdk + libGL + libGLU + libjpeg + libpng + libtiff + libxcrypt + openscenegraph + proj + python3Packages.setuptools + xercesc + zlib + python3 + ] + ++ (with xorg; [ + libX11 + libXcursor + libXext + libXfixes + libXft + libXrandr + libXrender + ]); meta = with lib; { description = "SUMO traffic simulator"; diff --git a/pkgs/by-name/su/sundtek/package.nix b/pkgs/by-name/su/sundtek/package.nix index 3cba4a5f15c828..b560a975c0d9e6 100644 --- a/pkgs/by-name/su/sundtek/package.nix +++ b/pkgs/by-name/su/sundtek/package.nix @@ -1,49 +1,62 @@ -{ fetchurl, lib, stdenv }: +{ + fetchurl, + lib, + stdenv, +}: let version = "2016-01-26"; - rpath = lib.makeLibraryPath [ "$out/lib" "$out/bin" ]; - platform = with stdenv; - if isx86_64 then "64bit" + rpath = lib.makeLibraryPath [ + "$out/lib" + "$out/bin" + ]; + platform = + with stdenv; + if isx86_64 then + "64bit" + else if isi686 then + "32bit" else - if isi686 then "32bit" - else throw "${system} not considered in build derivation. Might still be supported."; - sha256 = with stdenv; - if isx86_64 then "1jfsng5n3phw5rqpkid9m5j7m7zgj5bifh7swvba7f97y6imdaax" - else "15y6r5w306pcq4g1rn9f7vf70f3a7qhq237ngaf0wxh2nr0aamxp"; + throw "${system} not considered in build derivation. Might still be supported."; + sha256 = + with stdenv; + if isx86_64 then + "1jfsng5n3phw5rqpkid9m5j7m7zgj5bifh7swvba7f97y6imdaax" + else + "15y6r5w306pcq4g1rn9f7vf70f3a7qhq237ngaf0wxh2nr0aamxp"; in - stdenv.mkDerivation { - src = fetchurl { - url = "http://www.sundtek.de/media/netinst/${platform}/installer.tar.gz"; - sha256 = sha256; - }; - pname = "sundtek"; - inherit version; +stdenv.mkDerivation { + src = fetchurl { + url = "http://www.sundtek.de/media/netinst/${platform}/installer.tar.gz"; + sha256 = sha256; + }; + pname = "sundtek"; + inherit version; - sourceRoot = "."; + sourceRoot = "."; - installPhase = '' - cp -r opt $out + installPhase = '' + cp -r opt $out - # add and fix pkg-config file - mkdir -p $out/lib/pkgconfig - substitute $out/doc/libmedia.pc $out/lib/pkgconfig/libmedia.pc \ - --replace /opt $out - ''; + # add and fix pkg-config file + mkdir -p $out/lib/pkgconfig + substitute $out/doc/libmedia.pc $out/lib/pkgconfig/libmedia.pc \ + --replace /opt $out + ''; - postFixup = '' - find $out -type f -exec \ - patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" {} \ - patchelf --set-rpath ${rpath} {} \; - ''; + postFixup = '' + find $out -type f -exec \ + patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" {} \ + patchelf --set-rpath ${rpath} {} \; + ''; - preferLocalBuild = true; + preferLocalBuild = true; - meta = with lib; { - description = "Sundtek MediaTV driver"; - maintainers = [ maintainers.simonvandel ]; - sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; - platforms = platforms.unix; - license = licenses.unfree; - homepage = "https://support.sundtek.com/index.php/topic,1573.0.html"; - }; - } + meta = with lib; { + description = "Sundtek MediaTV driver"; + maintainers = [ maintainers.simonvandel ]; + sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; + platforms = platforms.unix; + license = licenses.unfree; + homepage = "https://support.sundtek.com/index.php/topic,1573.0.html"; + }; +} diff --git a/pkgs/by-name/su/sunpaper/package.nix b/pkgs/by-name/su/sunpaper/package.nix index fa9917a2d2af18..9dccc07a5e1930 100644 --- a/pkgs/by-name/su/sunpaper/package.nix +++ b/pkgs/by-name/su/sunpaper/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, sunwait -, wallutils +{ + lib, + stdenvNoCC, + fetchFromGitHub, + sunwait, + wallutils, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/su/sunvox/package.nix b/pkgs/by-name/su/sunvox/package.nix index 80a0f709e1f20c..fe39aec2f99558 100644 --- a/pkgs/by-name/su/sunvox/package.nix +++ b/pkgs/by-name/su/sunvox/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchzip -, alsa-lib -, autoPatchelfHook -, libglvnd -, libjack2 -, libX11 -, libXi -, makeWrapper -, SDL2 +{ + lib, + stdenv, + fetchzip, + alsa-lib, + autoPatchelfHook, + libglvnd, + libjack2, + libX11, + libXi, + makeWrapper, + SDL2, }: let @@ -20,7 +21,9 @@ let "x86_64-darwin" = "macos"; "aarch64-darwin" = "macos"; }; - bindir = platforms."${stdenv.hostPlatform.system}" or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + bindir = + platforms."${stdenv.hostPlatform.system}" + or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); in stdenv.mkDerivation (finalAttrs: { pname = "sunvox"; @@ -35,11 +38,13 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-7DZyoOz3jDYsuGqbs0PRs6jdWCxBhSDUKk8KVJQm/3o="; }; - nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - autoPatchelfHook - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - makeWrapper - ]; + nativeBuildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + autoPatchelfHook + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + makeWrapper + ]; buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ alsa-lib @@ -56,41 +61,48 @@ stdenv.mkDerivation (finalAttrs: { dontConfigure = true; dontBuild = true; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - # Delete platform-specific data for all the platforms we're not building for - find sunvox -mindepth 1 -maxdepth 1 -type d -not -name "${bindir}" -exec rm -r {} \; + # Delete platform-specific data for all the platforms we're not building for + find sunvox -mindepth 1 -maxdepth 1 -type d -not -name "${bindir}" -exec rm -r {} \; - mkdir -p $out/{bin,share/sunvox} - mv * $out/share/sunvox/ + mkdir -p $out/{bin,share/sunvox} + mv * $out/share/sunvox/ - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - for binary in $(find $out/share/sunvox/sunvox/${bindir}/ -type f -executable); do - mv $binary $out/bin/$(basename $binary) - done + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + for binary in $(find $out/share/sunvox/sunvox/${bindir}/ -type f -executable); do + mv $binary $out/bin/$(basename $binary) + done - # Cleanup, make sure we didn't miss anything - find $out/share/sunvox/sunvox -type f -name readme.txt -delete - rmdir $out/share/sunvox/sunvox/${bindir} $out/share/sunvox/sunvox - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir $out/Applications - ln -s $out/share/sunvox/sunvox/${bindir}/SunVox.app $out/Applications/ - ln -s $out/share/sunvox/sunvox/${bindir}/reset_sunvox $out/bin/ + # Cleanup, make sure we didn't miss anything + find $out/share/sunvox/sunvox -type f -name readme.txt -delete + rmdir $out/share/sunvox/sunvox/${bindir} $out/share/sunvox/sunvox + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir $out/Applications + ln -s $out/share/sunvox/sunvox/${bindir}/SunVox.app $out/Applications/ + ln -s $out/share/sunvox/sunvox/${bindir}/reset_sunvox $out/bin/ - # Need to use a wrapper, binary checks for files relative to the path it was called via - makeWrapper $out/Applications/SunVox.app/Contents/MacOS/SunVox $out/bin/sunvox - '' + '' + # Need to use a wrapper, binary checks for files relative to the path it was called via + makeWrapper $out/Applications/SunVox.app/Contents/MacOS/SunVox $out/bin/sunvox + '' + + '' - runHook postInstall - ''; + runHook postInstall + ''; meta = with lib; { description = "Small, fast and powerful modular synthesizer with pattern-based sequencer"; license = licenses.unfreeRedistributable; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; homepage = "https://www.warmplace.ru/soft/sunvox/"; - maintainers = with maintainers; [ puffnfresh OPNA2608 ]; + maintainers = with maintainers; [ + puffnfresh + OPNA2608 + ]; platforms = lib.attrNames platforms; }; }) diff --git a/pkgs/by-name/su/sunwait/package.nix b/pkgs/by-name/su/sunwait/package.nix index 2f369c1eb9ce22..770e67b9f73cb0 100644 --- a/pkgs/by-name/su/sunwait/package.nix +++ b/pkgs/by-name/su/sunwait/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation (finalAttrs: { pname = "sunwait"; diff --git a/pkgs/by-name/su/sunxi-tools/package.nix b/pkgs/by-name/su/sunxi-tools/package.nix index 320fcb1b04cd2c..4bf58e3ed202d4 100644 --- a/pkgs/by-name/su/sunxi-tools/package.nix +++ b/pkgs/by-name/su/sunxi-tools/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, dtc, libusb1, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + dtc, + libusb1, + zlib, +}: stdenv.mkDerivation rec { pname = "sunxi-tools"; @@ -12,13 +20,23 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dtc libusb1 zlib ]; + buildInputs = [ + dtc + libusb1 + zlib + ]; makeFlags = [ "PREFIX=$(out)" ]; - buildFlags = [ "tools" "misc" ]; + buildFlags = [ + "tools" + "misc" + ]; - installTargets = [ "install-tools" "install-misc" ]; + installTargets = [ + "install-tools" + "install-misc" + ]; meta = with lib; { description = "Tools for Allwinner SoC devices"; diff --git a/pkgs/by-name/su/supabase-cli/package.nix b/pkgs/by-name/su/supabase-cli/package.nix index ea60e55cb36429..87d9f77f164f62 100644 --- a/pkgs/by-name/su/supabase-cli/package.nix +++ b/pkgs/by-name/su/supabase-cli/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, testers -, supabase-cli -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + supabase-cli, + nix-update-script, }: buildGoModule rec { @@ -51,7 +52,10 @@ buildGoModule rec { description = "CLI for interacting with supabase"; homepage = "https://github.com/supabase/cli"; license = licenses.mit; - maintainers = with maintainers; [ gerschtli kashw2 ]; + maintainers = with maintainers; [ + gerschtli + kashw2 + ]; mainProgram = "supabase"; }; } diff --git a/pkgs/by-name/su/super-tiny-icons/package.nix b/pkgs/by-name/su/super-tiny-icons/package.nix index 48af800e1f2bcd..5e1d283264f734 100644 --- a/pkgs/by-name/su/super-tiny-icons/package.nix +++ b/pkgs/by-name/su/super-tiny-icons/package.nix @@ -1,4 +1,9 @@ -{ pkgs, lib, stdenvNoCC, fetchFromGitHub, }: +{ + pkgs, + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "super-tiny-icons"; diff --git a/pkgs/by-name/su/superTux/package.nix b/pkgs/by-name/su/superTux/package.nix index 3f4031b3b71ab2..46d2bd9bb0c639 100644 --- a/pkgs/by-name/su/superTux/package.nix +++ b/pkgs/by-name/su/superTux/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, cmake -, pkg-config -, boost -, curl -, SDL2 -, SDL2_image -, libSM -, libXext -, libpng -, freetype -, libGLU -, libGL -, glew -, glm -, openal -, libogg -, libvorbis +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + boost, + curl, + SDL2, + SDL2_image, + libSM, + libXext, + libpng, + freetype, + libGLU, + libGL, + glew, + glm, + openal, + libogg, + libvorbis, }: stdenv.mkDerivation rec { @@ -33,7 +34,10 @@ stdenv.mkDerivation rec { sed '1i#include ' -i external/partio_zip/zip_manager.hpp # gcc12 ''; - nativeBuildInputs = [ pkg-config cmake ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; buildInputs = [ boost diff --git a/pkgs/by-name/su/supercronic/package.nix b/pkgs/by-name/su/supercronic/package.nix index b2a2104ac31cb0..49ac6669c58ab9 100644 --- a/pkgs/by-name/su/supercronic/package.nix +++ b/pkgs/by-name/su/supercronic/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, python3 -, bash -, coreutils +{ + lib, + buildGoModule, + fetchFromGitHub, + python3, + bash, + coreutils, }: buildGoModule rec { @@ -21,7 +22,11 @@ buildGoModule rec { excludedPackages = [ "cronexpr/cronexpr" ]; - nativeCheckInputs = [ python3 bash coreutils ]; + nativeCheckInputs = [ + python3 + bash + coreutils + ]; postConfigure = '' # There are tests that set the shell to various paths diff --git a/pkgs/by-name/su/superd/package.nix b/pkgs/by-name/su/superd/package.nix index be018cb24126b0..498988b15a6b41 100644 --- a/pkgs/by-name/su/superd/package.nix +++ b/pkgs/by-name/su/superd/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromSourcehut -, installShellFiles -, scdoc +{ + lib, + buildGoModule, + fetchFromSourcehut, + installShellFiles, + scdoc, }: buildGoModule rec { @@ -38,6 +39,9 @@ buildGoModule rec { homepage = "https://sr.ht/~craftyguy/superd/"; license = licenses.gpl3Plus; platforms = platforms.linux; - maintainers = with maintainers; [ chuangzhu wentam ]; + maintainers = with maintainers; [ + chuangzhu + wentam + ]; }; } diff --git a/pkgs/by-name/su/superfile/package.nix b/pkgs/by-name/su/superfile/package.nix index f1d349af654947..4bc071cb769e15 100644 --- a/pkgs/by-name/su/superfile/package.nix +++ b/pkgs/by-name/su/superfile/package.nix @@ -16,14 +16,20 @@ buildGoModule rec { vendorHash = "sha256-DU0Twutepmk+8lkBM2nDChbsSHh4awt5m33ACUtH4AQ="; - ldflags = ["-s" "-w"]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Pretty fancy and modern terminal file manager"; homepage = "https://github.com/yorukot/superfile"; changelog = "https://github.com/yorukot/superfile/blob/${src.rev}/changelog.md"; license = licenses.mit; - maintainers = with maintainers; [momeemt redyf]; + maintainers = with maintainers; [ + momeemt + redyf + ]; mainProgram = "superfile"; }; } diff --git a/pkgs/by-name/su/supergfxctl-plasmoid/package.nix b/pkgs/by-name/su/supergfxctl-plasmoid/package.nix index d66577c68a7563..2b5ce59fd608ed 100644 --- a/pkgs/by-name/su/supergfxctl-plasmoid/package.nix +++ b/pkgs/by-name/su/supergfxctl-plasmoid/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitLab -, cmake -, kdePackages +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + kdePackages, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/su/supergfxctl/package.nix b/pkgs/by-name/su/supergfxctl/package.nix index 2318a4c96725fb..e0d76bac985b57 100644 --- a/pkgs/by-name/su/supergfxctl/package.nix +++ b/pkgs/by-name/su/supergfxctl/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitLab -, pkg-config -, systemd +{ + lib, + rustPlatform, + fetchFromGitLab, + pkg-config, + systemd, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/su/superlu/package.nix b/pkgs/by-name/su/superlu/package.nix index 4f52c2d6c507a2..9a75318fbb6934 100644 --- a/pkgs/by-name/su/superlu/package.nix +++ b/pkgs/by-name/su/superlu/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchurl, cmake, - gfortran, blas, lapack}: +{ + lib, + stdenv, + fetchurl, + cmake, + gfortran, + blas, + lapack, +}: assert (!blas.isILP64) && (!lapack.isILP64); @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "0qzlb7cd608q62kyppd0a8c65l03vrwqql6gsm465rky23b6dyr8"; }; - nativeBuildInputs = [ cmake gfortran ]; + nativeBuildInputs = [ + cmake + gfortran + ]; propagatedBuildInputs = [ blas ]; diff --git a/pkgs/by-name/su/supermodel/package.nix b/pkgs/by-name/su/supermodel/package.nix index 031f1ffa05d405..15702e89aad86f 100644 --- a/pkgs/by-name/su/supermodel/package.nix +++ b/pkgs/by-name/su/supermodel/package.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, lib -, libGLU -, SDL2 -, SDL2_net -, stdenv -, zlib +{ + fetchFromGitHub, + lib, + libGLU, + SDL2, + SDL2_net, + stdenv, + zlib, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/su/supersonic/package.nix b/pkgs/by-name/su/supersonic/package.nix index 7964d31d965053..7de2b963d5e82e 100644 --- a/pkgs/by-name/su/supersonic/package.nix +++ b/pkgs/by-name/su/supersonic/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, makeDesktopItem -, copyDesktopItems -, pkg-config -, desktopToDarwinBundle -, xorg -, wayland -, wayland-protocols -, libxkbcommon -, libglvnd -, mpv-unwrapped -, darwin -, waylandSupport ? false +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + pkg-config, + desktopToDarwinBundle, + xorg, + wayland, + wayland-protocols, + libxkbcommon, + libglvnd, + mpv-unwrapped, + darwin, + waylandSupport ? false, }: assert waylandSupport -> stdenv.hostPlatform.isLinux; @@ -31,49 +32,58 @@ buildGoModule rec { vendorHash = "sha256-wT1WvwUUAnMIKa+RlRDD2QGJpZMtoecQCxSJekM6PdM="; - nativeBuildInputs = [ - copyDesktopItems - pkg-config - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - desktopToDarwinBundle - ]; + nativeBuildInputs = + [ + copyDesktopItems + pkg-config + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + desktopToDarwinBundle + ]; # go-glfw doesn't support both X11 and Wayland in single build tags = lib.optionals waylandSupport [ "wayland" ]; - buildInputs = [ - libglvnd - mpv-unwrapped - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - xorg.libXxf86vm - xorg.libX11 - ] ++ lib.optionals (stdenv.hostPlatform.isLinux && !waylandSupport) [ - xorg.libXrandr - xorg.libXinerama - xorg.libXcursor - xorg.libXi - xorg.libXext - ] ++ lib.optionals (stdenv.hostPlatform.isLinux && waylandSupport) [ - wayland - wayland-protocols - libxkbcommon - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk_11_0.frameworks.Cocoa - darwin.apple_sdk_11_0.frameworks.Kernel - darwin.apple_sdk_11_0.frameworks.OpenGL - darwin.apple_sdk_11_0.frameworks.UserNotifications - darwin.apple_sdk_11_0.frameworks.MediaPlayer - ]; + buildInputs = + [ + libglvnd + mpv-unwrapped + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + xorg.libXxf86vm + xorg.libX11 + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && !waylandSupport) [ + xorg.libXrandr + xorg.libXinerama + xorg.libXcursor + xorg.libXi + xorg.libXext + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && waylandSupport) [ + wayland + wayland-protocols + libxkbcommon + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk_11_0.frameworks.Cocoa + darwin.apple_sdk_11_0.frameworks.Kernel + darwin.apple_sdk_11_0.frameworks.OpenGL + darwin.apple_sdk_11_0.frameworks.UserNotifications + darwin.apple_sdk_11_0.frameworks.MediaPlayer + ]; - postInstall = '' - for dimension in 128 256 512;do - dimensions=''${dimension}x''${dimension} - mkdir -p $out/share/icons/hicolor/$dimensions/apps - cp res/appicon-$dimension.png $out/share/icons/hicolor/$dimensions/apps/${meta.mainProgram}.png - done - '' + lib.optionalString waylandSupport '' - mv $out/bin/supersonic $out/bin/${meta.mainProgram} - ''; + postInstall = + '' + for dimension in 128 256 512;do + dimensions=''${dimension}x''${dimension} + mkdir -p $out/share/icons/hicolor/$dimensions/apps + cp res/appicon-$dimension.png $out/share/icons/hicolor/$dimensions/apps/${meta.mainProgram}.png + done + '' + + lib.optionalString waylandSupport '' + mv $out/bin/supersonic $out/bin/${meta.mainProgram} + ''; desktopItems = [ (makeDesktopItem { @@ -84,7 +94,10 @@ buildGoModule rec { genericName = "Subsonic Client"; comment = meta.description; type = "Application"; - categories = [ "Audio" "AudioVideo" ]; + categories = [ + "Audio" + "AudioVideo" + ]; }) ]; @@ -94,6 +107,9 @@ buildGoModule rec { homepage = "https://github.com/dweymouth/supersonic"; platforms = platforms.linux ++ platforms.darwin; license = licenses.gpl3Plus; - maintainers = with maintainers; [ zane sochotnicky ]; + maintainers = with maintainers; [ + zane + sochotnicky + ]; }; } diff --git a/pkgs/by-name/su/supertag/package.nix b/pkgs/by-name/su/supertag/package.nix index 9047fe18591818..fe79aaf586819e 100644 --- a/pkgs/by-name/su/supertag/package.nix +++ b/pkgs/by-name/su/supertag/package.nix @@ -1,6 +1,11 @@ -{ lib, rustPlatform, fetchFromGitHub -, pkg-config -, dbus, fuse, sqlite +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + dbus, + fuse, + sqlite, }: rustPlatform.buildRustPackage rec { @@ -20,8 +25,15 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-W5Emkbe1jI9Z+irMckD/3gJO47rACa9E5k5dqAFC1yQ="; - nativeBuildInputs = [ rustPlatform.bindgenHook pkg-config ]; - buildInputs = [ dbus fuse sqlite ]; + nativeBuildInputs = [ + rustPlatform.bindgenHook + pkg-config + ]; + buildInputs = [ + dbus + fuse + sqlite + ]; # The test are requiring extended permissions. doCheck = false; @@ -37,7 +49,10 @@ rustPlatform.buildRustPackage rec { ''; homepage = "https://github.com/amoffat/supertag"; license = licenses.agpl3Plus; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; maintainers = with maintainers; [ oxzi ]; }; } diff --git a/pkgs/by-name/su/supervise/package.nix b/pkgs/by-name/su/supervise/package.nix index 8b6d7d97499c17..5df506576e4e15 100644 --- a/pkgs/by-name/su/supervise/package.nix +++ b/pkgs/by-name/su/supervise/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/su/surelog/package.nix b/pkgs/by-name/su/surelog/package.nix index baec8a830466e2..75511f68e8462c 100644 --- a/pkgs/by-name/su/surelog/package.nix +++ b/pkgs/by-name/su/surelog/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, python3 -, pkg-config -, libuuid -, openjdk -, gperftools -, gtest -, uhdm -, antlr4 -, capnproto -, nlohmann_json +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, + pkg-config, + libuuid, + openjdk, + gperftools, + gtest, + uhdm, + antlr4, + capnproto, + nlohmann_json, }: stdenv.mkDerivation (finalAttrs: { @@ -24,17 +25,19 @@ stdenv.mkDerivation (finalAttrs: { # Once we're back on a stable tag, use "v$(finalAttrs.version}" below. rev = "da88163a02dbc16f1af3514f281b93941d371ad9"; hash = "sha256-TIwXIMcDImZjCIiXwvT2MhukArgrWCgOf2AOvkG/55g="; - fetchSubmodules = false; # we use all dependencies from nix + fetchSubmodules = false; # we use all dependencies from nix }; nativeBuildInputs = [ cmake pkg-config openjdk - (python3.withPackages (p: with p; [ - psutil - orderedmultidict - ])) + (python3.withPackages ( + p: with p; [ + psutil + orderedmultidict + ] + )) gtest antlr4 ]; @@ -70,7 +73,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/chipsalliance/Surelog"; license = lib.licenses.asl20; mainProgram = "surelog"; - maintainers = with lib.maintainers; [ matthuszagh hzeller ]; + maintainers = with lib.maintainers; [ + matthuszagh + hzeller + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/by-name/su/surf-display/package.nix b/pkgs/by-name/su/surf-display/package.nix index 1c68d6cf003150..ca70c40a434734 100644 --- a/pkgs/by-name/su/surf-display/package.nix +++ b/pkgs/by-name/su/surf-display/package.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, fetchgit, makeWrapper -, surf, wmctrl, matchbox, xdotool, unclutter -, xorg, pulseaudio, xprintidle-ng }: +{ + lib, + stdenv, + fetchgit, + makeWrapper, + surf, + wmctrl, + matchbox, + xdotool, + unclutter, + xorg, + pulseaudio, + xprintidle-ng, +}: stdenv.mkDerivation rec { pname = "surf-display"; diff --git a/pkgs/by-name/su/surface-control/package.nix b/pkgs/by-name/su/surface-control/package.nix index 6c82c6efe96e3f..aee2dd5bf0bb8e 100644 --- a/pkgs/by-name/su/surface-control/package.nix +++ b/pkgs/by-name/su/surface-control/package.nix @@ -1,4 +1,12 @@ -{ lib, rustPlatform, fetchFromGitHub, pkg-config, installShellFiles, udev, coreutils }: +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + installShellFiles, + udev, + coreutils, +}: rustPlatform.buildRustPackage rec { pname = "surface-control"; @@ -18,7 +26,10 @@ rustPlatform.buildRustPackage rec { }; }; - nativeBuildInputs = [ pkg-config installShellFiles ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; buildInputs = [ udev ]; postInstall = '' @@ -33,8 +44,7 @@ rustPlatform.buildRustPackage rec { ''; meta = with lib; { - description = - "Control various aspects of Microsoft Surface devices on Linux from the Command-Line"; + description = "Control various aspects of Microsoft Surface devices on Linux from the Command-Line"; homepage = "https://github.com/linux-surface/surface-control"; license = licenses.mit; maintainers = [ ]; diff --git a/pkgs/by-name/su/surfraw/package.nix b/pkgs/by-name/su/surfraw/package.nix index a2c714f3b61f3c..6e4fb9265e5157 100644 --- a/pkgs/by-name/su/surfraw/package.nix +++ b/pkgs/by-name/su/surfraw/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, perl}: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "surfraw"; diff --git a/pkgs/by-name/su/surge-XT/package.nix b/pkgs/by-name/su/surge-XT/package.nix index 6fd7f9caaacea2..395a06019316c5 100644 --- a/pkgs/by-name/su/surge-XT/package.nix +++ b/pkgs/by-name/su/surge-XT/package.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, alsa-lib -, freetype -, libjack2 -, lv2 -, libX11 -, libXcursor -, libXext -, libXinerama -, libXrandr +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + alsa-lib, + freetype, + libjack2, + lv2, + libX11, + libXcursor, + libXext, + libXinerama, + libXrandr, }: stdenv.mkDerivation rec { @@ -55,13 +56,15 @@ stdenv.mkDerivation rec { ]; # JUCE dlopen's these at runtime, crashes without them - NIX_LDFLAGS = (toString [ - "-lX11" - "-lXext" - "-lXcursor" - "-lXinerama" - "-lXrandr" - ]); + NIX_LDFLAGS = ( + toString [ + "-lX11" + "-lXext" + "-lXcursor" + "-lXinerama" + "-lXrandr" + ] + ); # see https://github.com/NixOS/nixpkgs/pull/149487#issuecomment-991747333 postPatch = '' @@ -73,6 +76,9 @@ stdenv.mkDerivation rec { homepage = "https://surge-synthesizer.github.io"; license = licenses.gpl3; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ magnetophon orivej ]; + maintainers = with maintainers; [ + magnetophon + orivej + ]; }; } diff --git a/pkgs/by-name/su/surge-cli/package.nix b/pkgs/by-name/su/surge-cli/package.nix index 13cd941d1a2ba2..0431c69f04d78e 100644 --- a/pkgs/by-name/su/surge-cli/package.nix +++ b/pkgs/by-name/su/surge-cli/package.nix @@ -1,4 +1,8 @@ -{ buildNpmPackage, fetchFromGitHub, lib }: +{ + buildNpmPackage, + fetchFromGitHub, + lib, +}: buildNpmPackage rec { pname = "surge-cli"; diff --git a/pkgs/by-name/su/suricata/package.nix b/pkgs/by-name/su/suricata/package.nix index e8a97c494a9eba..4b120c718118c3 100644 --- a/pkgs/by-name/su/suricata/package.nix +++ b/pkgs/by-name/su/suricata/package.nix @@ -1,34 +1,40 @@ -{ stdenv -, lib -, fetchurl -, clang -, llvm -, pkg-config -, makeWrapper -, elfutils -, file -, hyperscan -, jansson -, libbpf_0 -, libcap_ng -, libevent -, libmaxminddb -, libnet -, libnetfilter_log -, libnetfilter_queue -, libnfnetlink -, libpcap -, libyaml -, luajit -, lz4 -, nspr -, pcre2 -, python3 -, zlib -, redisSupport ? true, redis, hiredis -, rustSupport ? true, rustc, cargo -, nixosTests -}: let +{ + stdenv, + lib, + fetchurl, + clang, + llvm, + pkg-config, + makeWrapper, + elfutils, + file, + hyperscan, + jansson, + libbpf_0, + libcap_ng, + libevent, + libmaxminddb, + libnet, + libnetfilter_log, + libnetfilter_queue, + libnfnetlink, + libpcap, + libyaml, + luajit, + lz4, + nspr, + pcre2, + python3, + zlib, + redisSupport ? true, + redis, + hiredis, + rustSupport ? true, + rustc, + cargo, + nixosTests, +}: +let libmagic = file; hyperscanSupport = stdenv.system == "x86_64-linux" || stdenv.system == "i686-linux"; in @@ -41,43 +47,49 @@ stdenv.mkDerivation rec { hash = "sha256-JtCjYZTVMID8iwm5mbK1qDxASfQK0H72rmnHIlpyi4Y="; }; - nativeBuildInputs = [ - clang - llvm - makeWrapper - pkg-config - ] - ++ lib.optionals rustSupport [ rustc cargo ] - ; + nativeBuildInputs = + [ + clang + llvm + makeWrapper + pkg-config + ] + ++ lib.optionals rustSupport [ + rustc + cargo + ]; propagatedBuildInputs = with python3.pkgs; [ pyyaml ]; - buildInputs = [ - elfutils - jansson - libbpf_0 - libcap_ng - libevent - libmagic - libmaxminddb - libnet - libnetfilter_log - libnetfilter_queue - libnfnetlink - libpcap - libyaml - luajit - lz4 - nspr - pcre2 - python3 - zlib - ] - ++ lib.optional hyperscanSupport hyperscan - ++ lib.optionals redisSupport [ redis hiredis ] - ; + buildInputs = + [ + elfutils + jansson + libbpf_0 + libcap_ng + libevent + libmagic + libmaxminddb + libnet + libnetfilter_log + libnetfilter_queue + libnfnetlink + libpcap + libyaml + luajit + lz4 + nspr + pcre2 + python3 + zlib + ] + ++ lib.optional hyperscanSupport hyperscan + ++ lib.optionals redisSupport [ + redis + hiredis + ]; enableParallelBuilding = true; @@ -93,33 +105,34 @@ stdenv.mkDerivation rec { touch bpf_stubs_workaround/gnu/stubs-32.h ''; - configureFlags = [ - "--disable-gccmarch-native" - "--enable-af-packet" - "--enable-ebpf" - "--enable-ebpf-build" - "--enable-gccprotect" - "--enable-geoip" - "--enable-luajit" - "--enable-nflog" - "--enable-nfqueue" - "--enable-pie" - "--enable-python" - "--enable-unix-socket" - "--localstatedir=/var" - "--sysconfdir=/etc" - "--with-libnet-includes=${libnet}/include" - "--with-libnet-libraries=${libnet}/lib" - ] - ++ lib.optionals hyperscanSupport [ - "--with-libhs-includes=${hyperscan.dev}/include/hs" - "--with-libhs-libraries=${hyperscan}/lib" - ] - ++ lib.optional redisSupport "--enable-hiredis" - ++ lib.optionals rustSupport [ - "--enable-rust" - "--enable-rust-experimental" - ]; + configureFlags = + [ + "--disable-gccmarch-native" + "--enable-af-packet" + "--enable-ebpf" + "--enable-ebpf-build" + "--enable-gccprotect" + "--enable-geoip" + "--enable-luajit" + "--enable-nflog" + "--enable-nfqueue" + "--enable-pie" + "--enable-python" + "--enable-unix-socket" + "--localstatedir=/var" + "--sysconfdir=/etc" + "--with-libnet-includes=${libnet}/include" + "--with-libnet-libraries=${libnet}/lib" + ] + ++ lib.optionals hyperscanSupport [ + "--with-libhs-includes=${hyperscan.dev}/include/hs" + "--with-libhs-libraries=${hyperscan}/lib" + ] + ++ lib.optional redisSupport "--enable-hiredis" + ++ lib.optionals rustSupport [ + "--enable-rust" + "--enable-rust-experimental" + ]; postConfigure = '' # Avoid unintended clousure growth. @@ -127,7 +140,10 @@ stdenv.mkDerivation rec { ''; # zerocallusedregs interferes during BPF compilation; TODO: perhaps improve - hardeningDisable = [ "stackprotector" "zerocallusedregs" ]; + hardeningDisable = [ + "stackprotector" + "zerocallusedregs" + ]; doCheck = true; @@ -145,7 +161,10 @@ stdenv.mkDerivation rec { "sysconfdir=\${out}/etc" ]; - installTargets = [ "install" "install-conf" ]; + installTargets = [ + "install" + "install-conf" + ]; postInstall = '' wrapProgram "$out/bin/suricatasc" \ diff --git a/pkgs/by-name/su/surrealdb/package.nix b/pkgs/by-name/su/surrealdb/package.nix index a7065e119d1238..ebab4440a2601c 100644 --- a/pkgs/by-name/su/surrealdb/package.nix +++ b/pkgs/by-name/su/surrealdb/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, rocksdb_8_3 -, testers -, surrealdb -, darwin -, protobuf +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + rocksdb_8_3, + testers, + surrealdb, + darwin, + protobuf, }: let @@ -45,8 +46,9 @@ rustPlatform.buildRustPackage rec { rustPlatform.bindgenHook ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; + buildInputs = [ + openssl + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; doCheck = false; @@ -69,6 +71,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://surrealdb.com/"; mainProgram = "surreal"; license = licenses.bsl11; - maintainers = with maintainers; [ sikmir happysalada siriobalmelli ]; + maintainers = with maintainers; [ + sikmir + happysalada + siriobalmelli + ]; }; } diff --git a/pkgs/by-name/su/surrealist/package.nix b/pkgs/by-name/su/surrealist/package.nix index c205bb4d9a7edf..e13a41c1bca1f0 100644 --- a/pkgs/by-name/su/surrealist/package.nix +++ b/pkgs/by-name/su/surrealist/package.nix @@ -1,44 +1,52 @@ -{ buildGoModule -, cairo -, cargo -, cargo-tauri -, esbuild -, fetchFromGitHub -, gdk-pixbuf -, glib-networking -, gobject-introspection -, lib -, libsoup_3 -, makeBinaryWrapper -, nodejs -, openssl -, pango -, pkg-config -, pnpm -, rustc -, rustPlatform -, stdenv -, webkitgtk_4_1 +{ + buildGoModule, + cairo, + cargo, + cargo-tauri, + esbuild, + fetchFromGitHub, + gdk-pixbuf, + glib-networking, + gobject-introspection, + lib, + libsoup_3, + makeBinaryWrapper, + nodejs, + openssl, + pango, + pkg-config, + pnpm, + rustc, + rustPlatform, + stdenv, + webkitgtk_4_1, }: let - esbuild_21-5 = let - version = "0.21.5"; - in esbuild.override { - buildGoModule = args: - buildGoModule (args // { - inherit version; - src = fetchFromGitHub { - owner = "evanw"; - repo = "esbuild"; - rev = "v${version}"; - hash = "sha256-FpvXWIlt67G8w3pBKZo/mcp57LunxDmRUaCU/Ne89B8="; - }; - vendorHash = "sha256-+BfxCyg0KkDQpHt/wycy/8CTG6YBA/VJvJFhhzUnSiQ="; - }); - }; + esbuild_21-5 = + let + version = "0.21.5"; + in + esbuild.override { + buildGoModule = + args: + buildGoModule ( + args + // { + inherit version; + src = fetchFromGitHub { + owner = "evanw"; + repo = "esbuild"; + rev = "v${version}"; + hash = "sha256-FpvXWIlt67G8w3pBKZo/mcp57LunxDmRUaCU/Ne89B8="; + }; + vendorHash = "sha256-+BfxCyg0KkDQpHt/wycy/8CTG6YBA/VJvJFhhzUnSiQ="; + } + ); + }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "surrealist"; version = "3.0.8"; diff --git a/pkgs/by-name/su/suscan/package.nix b/pkgs/by-name/su/suscan/package.nix index 62600c440da5d5..0c052705cc2671 100644 --- a/pkgs/by-name/su/suscan/package.nix +++ b/pkgs/by-name/su/suscan/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, fftwSinglePrec -, libsndfile -, sigutils -, soapysdr-with-plugins -, libxml2 -, volk -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + fftwSinglePrec, + libsndfile, + sigutils, + soapysdr-with-plugins, + libxml2, + volk, + zlib, }: stdenv.mkDerivation rec { @@ -47,6 +48,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/BatchDrake/suscan"; license = licenses.gpl3; platforms = platforms.all; - maintainers = with maintainers; [ polygon oxapentane ]; + maintainers = with maintainers; [ + polygon + oxapentane + ]; }; } diff --git a/pkgs/by-name/su/sushi/package.nix b/pkgs/by-name/su/sushi/package.nix index bbcaec75a41258..561c40038cb44e 100644 --- a/pkgs/by-name/su/sushi/package.nix +++ b/pkgs/by-name/su/sushi/package.nix @@ -1,25 +1,27 @@ -{ lib, stdenv -, fetchurl -, pkg-config -, meson -, gettext -, gobject-introspection -, evince -, glib -, gnome -, gtksourceview4 -, gjs -, libsoup_3 -, webkitgtk_4_1 -, icu -, wrapGAppsHook3 -, gst_all_1 -, gdk-pixbuf -, librsvg -, gtk3 -, harfbuzz -, ninja -, libepoxy +{ + lib, + stdenv, + fetchurl, + pkg-config, + meson, + gettext, + gobject-introspection, + evince, + glib, + gnome, + gtksourceview4, + gjs, + libsoup_3, + webkitgtk_4_1, + icu, + wrapGAppsHook3, + gst_all_1, + gdk-pixbuf, + librsvg, + gtk3, + harfbuzz, + ninja, + libepoxy, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/su/sutils/package.nix b/pkgs/by-name/su/sutils/package.nix index f611b7adc07cff..0b30a617e0e6ae 100644 --- a/pkgs/by-name/su/sutils/package.nix +++ b/pkgs/by-name/su/sutils/package.nix @@ -1,27 +1,32 @@ -{ lib, stdenv, fetchFromGitHub, alsa-lib }: +{ + lib, + stdenv, + fetchFromGitHub, + alsa-lib, +}: stdenv.mkDerivation rec { - version = "0.2"; - pname = "sutils"; + version = "0.2"; + pname = "sutils"; - src = fetchFromGitHub { - owner = "baskerville"; - repo = "sutils"; - rev = version; - sha256 = "0i2g6a6xdaq3w613dhq7mnsz4ymwqn6kvkyan5kgy49mzq97va6j"; - }; + src = fetchFromGitHub { + owner = "baskerville"; + repo = "sutils"; + rev = version; + sha256 = "0i2g6a6xdaq3w613dhq7mnsz4ymwqn6kvkyan5kgy49mzq97va6j"; + }; - hardeningDisable = [ "format" ]; + hardeningDisable = [ "format" ]; - buildInputs = [ alsa-lib ]; + buildInputs = [ alsa-lib ]; - prePatch = ''sed -i "s@/usr/local@$out@" Makefile''; + prePatch = ''sed -i "s@/usr/local@$out@" Makefile''; - meta = { - description = "Small command-line utilities"; - homepage = "https://github.com/baskerville/sutils"; - maintainers = [ lib.maintainers.meisternu ]; - license = "Custom"; - platforms = lib.platforms.linux; - }; + meta = { + description = "Small command-line utilities"; + homepage = "https://github.com/baskerville/sutils"; + maintainers = [ lib.maintainers.meisternu ]; + license = "Custom"; + platforms = lib.platforms.linux; + }; } diff --git a/pkgs/by-name/su/suwayomi-server/package.nix b/pkgs/by-name/su/suwayomi-server/package.nix index 1ff61c96cd044d..31da4c3a18331f 100644 --- a/pkgs/by-name/su/suwayomi-server/package.nix +++ b/pkgs/by-name/su/suwayomi-server/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, fetchurl -, makeWrapper -, jdk17_headless -, nixosTests +{ + lib, + stdenvNoCC, + fetchurl, + makeWrapper, + jdk17_headless, + nixosTests, }: let diff --git a/pkgs/by-name/sv/svaba/package.nix b/pkgs/by-name/sv/svaba/package.nix index cdb6c4f9c8aa4b..cdc15398d3c9a7 100644 --- a/pkgs/by-name/sv/svaba/package.nix +++ b/pkgs/by-name/sv/svaba/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, zlib, bzip2, xz, fetchFromGitHub } : +{ + lib, + stdenv, + zlib, + bzip2, + xz, + fetchFromGitHub, +}: stdenv.mkDerivation rec { version = "1.1.0"; @@ -12,7 +19,11 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - buildInputs = [ zlib bzip2 xz ]; + buildInputs = [ + zlib + bzip2 + xz + ]; postPatch = '' # Fix gcc-13 build failure due to missing includes diff --git a/pkgs/by-name/sv/svd2rust/package.nix b/pkgs/by-name/sv/svd2rust/package.nix index c8849693ff5d73..c37197a5baea79 100644 --- a/pkgs/by-name/sv/svd2rust/package.nix +++ b/pkgs/by-name/sv/svd2rust/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "svd2rust"; @@ -21,7 +25,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "svd2rust"; homepage = "https://github.com/rust-embedded/svd2rust"; changelog = "https://github.com/rust-embedded/svd2rust/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ mit asl20 ]; + license = with licenses; [ + mit + asl20 + ]; maintainers = with maintainers; [ newam ]; }; } diff --git a/pkgs/by-name/sv/svdtools/package.nix b/pkgs/by-name/sv/svdtools/package.nix index c42f758e3df00f..909a54ae12fd3e 100644 --- a/pkgs/by-name/sv/svdtools/package.nix +++ b/pkgs/by-name/sv/svdtools/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "svdtools"; homepage = "https://github.com/stm32-rs/svdtools"; changelog = "https://github.com/stm32-rs/svdtools/blob/v${version}/CHANGELOG-rust.md"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ newam ]; }; } diff --git a/pkgs/by-name/sv/svg2pdf/package.nix b/pkgs/by-name/sv/svg2pdf/package.nix index 3e60fbf4377f99..60b1f49838d917 100644 --- a/pkgs/by-name/sv/svg2pdf/package.nix +++ b/pkgs/by-name/sv/svg2pdf/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -24,8 +25,14 @@ rustPlatform.buildRustPackage rec { description = "Convert SVG files to PDFs"; homepage = "https://github.com/typst/svg2pdf"; changelog = "https://github.com/typst/svg2pdf/releases/tag/${src.rev}"; - license = with licenses; [ asl20 mit ]; - maintainers = with maintainers; [ doronbehar figsoda ]; + license = with licenses; [ + asl20 + mit + ]; + maintainers = with maintainers; [ + doronbehar + figsoda + ]; mainProgram = "svg2pdf"; }; } diff --git a/pkgs/by-name/sv/svgbob/package.nix b/pkgs/by-name/sv/svgbob/package.nix index 435ffe99ab146a..e2dd2e92ca2cec 100644 --- a/pkgs/by-name/sv/svgbob/package.nix +++ b/pkgs/by-name/sv/svgbob/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "svgbob"; diff --git a/pkgs/by-name/sv/svgcleaner/package.nix b/pkgs/by-name/sv/svgcleaner/package.nix index 87e7bafa2e5f48..aa9f98b6481d19 100644 --- a/pkgs/by-name/sv/svgcleaner/package.nix +++ b/pkgs/by-name/sv/svgcleaner/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sv/svix-cli/package.nix b/pkgs/by-name/sv/svix-cli/package.nix index 8cefce2bffeb30..33f39c11f926cf 100644 --- a/pkgs/by-name/sv/svix-cli/package.nix +++ b/pkgs/by-name/sv/svix-cli/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, fetchpatch, buildGoModule }: +{ + lib, + fetchFromGitHub, + fetchpatch, + buildGoModule, +}: buildGoModule rec { version = "0.21.1"; @@ -27,8 +32,11 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = - [ "-s" "-w" "-X github.com/svix/svix-cli/version.Version=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/svix/svix-cli/version.Version=v${version}" + ]; meta = with lib; { description = "A CLI for interacting with the Svix API"; diff --git a/pkgs/by-name/sv/svix-server/package.nix b/pkgs/by-name/sv/svix-server/package.nix index 0e5777fbffe292..4f60ee6a286817 100644 --- a/pkgs/by-name/sv/svix-server/package.nix +++ b/pkgs/by-name/sv/svix-server/package.nix @@ -1,5 +1,13 @@ -{ lib, rustPlatform, fetchFromGitHub, pkg-config, openssl, protobuf, stdenv -, darwin }: +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + protobuf, + stdenv, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "svix-server"; @@ -24,14 +32,16 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - openssl - protobuf - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreServices - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + protobuf + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreServices + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; # needed for internal protobuf c wrapper library PROTOC = "${protobuf}/bin/protoc"; @@ -46,8 +56,7 @@ rustPlatform.buildRustPackage rec { mainProgram = "svix-server"; description = "Enterprise-ready webhooks service"; homepage = "https://github.com/svix/svix-webhooks"; - changelog = - "https://github.com/svix/svix-webhooks/releases/tag/v${version}"; + changelog = "https://github.com/svix/svix-webhooks/releases/tag/v${version}"; license = licenses.mit; maintainers = with maintainers; [ techknowlogick ]; broken = stdenv.hostPlatform.isx86_64 && stdenv.hostPlatform.isDarwin; # aws-lc-sys currently broken on darwin x86_64 diff --git a/pkgs/by-name/sv/svlint/package.nix b/pkgs/by-name/sv/svlint/package.nix index b4fb2512596ae2..c67a2b2217c353 100644 --- a/pkgs/by-name/sv/svlint/package.nix +++ b/pkgs/by-name/sv/svlint/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -14,7 +15,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-HBfCTOETQ1hHzLFDw12W58omRmliiWDFGSrmr3PELD8="; - cargoBuildFlags = [ "--bin" "svlint" ]; + cargoBuildFlags = [ + "--bin" + "svlint" + ]; meta = with lib; { description = "SystemVerilog linter"; diff --git a/pkgs/by-name/sv/svls/package.nix b/pkgs/by-name/sv/svls/package.nix index 6faefffee2f5f8..da278e226a9e86 100644 --- a/pkgs/by-name/sv/svls/package.nix +++ b/pkgs/by-name/sv/svls/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sv/svndumpsanitizer/package.nix b/pkgs/by-name/sv/svndumpsanitizer/package.nix index 2c29015fbe803a..486bcf53f6e3a9 100644 --- a/pkgs/by-name/sv/svndumpsanitizer/package.nix +++ b/pkgs/by-name/sv/svndumpsanitizer/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/sv/svnfs/package.nix b/pkgs/by-name/sv/svnfs/package.nix index 2f0e32799d800d..a8f0e51facde24 100644 --- a/pkgs/by-name/sv/svnfs/package.nix +++ b/pkgs/by-name/sv/svnfs/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, autoreconfHook, subversion, fuse, apr, perl }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + subversion, + fuse, + apr, + perl, +}: stdenv.mkDerivation rec { pname = "svnfs"; @@ -10,7 +19,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ subversion fuse apr perl ]; + buildInputs = [ + subversion + fuse + apr + perl + ]; # autoconf's AC_CHECK_HEADERS and AC_CHECK_LIBS fail to detect libfuse on # Darwin if FUSE_USE_VERSION isn't set at configure time. @@ -23,7 +37,7 @@ stdenv.mkDerivation rec { configureFlags = lib.optionals stdenv.hostPlatform.isDarwin [ "CFLAGS=-DFUSE_USE_VERSION=25" ]; # why is this required? - preConfigure='' + preConfigure = '' export LD_LIBRARY_PATH=${subversion.out}/lib ''; @@ -32,13 +46,13 @@ stdenv.mkDerivation rec { # ld: svnclient.o:/build/svnfs-0.4/src/svnfs.h:40: multiple definition of # `dirbuf'; svnfs.o:/build/svnfs-0.4/src/svnfs.h:40: first defined here env.NIX_CFLAGS_COMPILE = "-I ${subversion.dev}/include/subversion-1 -fcommon"; - NIX_LDFLAGS="-lsvn_client-1 -lsvn_subr-1"; + NIX_LDFLAGS = "-lsvn_client-1 -lsvn_subr-1"; meta = { description = "FUSE filesystem for accessing Subversion repositories"; homepage = "https://www.jmadden.eu/index.php/svnfs/"; license = lib.licenses.gpl2Only; - maintainers = [lib.maintainers.marcweber]; + maintainers = [ lib.maintainers.marcweber ]; platforms = lib.platforms.unix; mainProgram = "svnfs"; }; diff --git a/pkgs/by-name/sv/svox/package.nix b/pkgs/by-name/sv/svox/package.nix index acd1de1a20c9eb..7664f04335757c 100644 --- a/pkgs/by-name/sv/svox/package.nix +++ b/pkgs/by-name/sv/svox/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, popt }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + popt, +}: stdenv.mkDerivation { pname = "svox"; diff --git a/pkgs/by-name/sv/svrcore/package.nix b/pkgs/by-name/sv/svrcore/package.nix index fbc17a5e7b218e..f78f7f918e60e5 100644 --- a/pkgs/by-name/sv/svrcore/package.nix +++ b/pkgs/by-name/sv/svrcore/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, nss, nspr }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + nss, + nspr, +}: stdenv.mkDerivation rec { pname = "svrcore"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ nss nspr ]; + buildInputs = [ + nss + nspr + ]; meta = with lib; { description = "Secure PIN handling using NSS crypto"; diff --git a/pkgs/by-name/sv/svt-av1/package.nix b/pkgs/by-name/sv/svt-av1/package.nix index 1b515b792c7983..85f99a5368b0fc 100644 --- a/pkgs/by-name/sv/svt-av1/package.nix +++ b/pkgs/by-name/sv/svt-av1/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitLab -, gitUpdater -, cmake -, nasm - -# for passthru.tests -, ffmpeg +{ + lib, + stdenv, + fetchFromGitLab, + gitUpdater, + cmake, + nasm, + + # for passthru.tests + ffmpeg, }: stdenv.mkDerivation (finalAttrs: { @@ -52,7 +53,10 @@ stdenv.mkDerivation (finalAttrs: { ''; changelog = "https://gitlab.com/AOMediaCodec/SVT-AV1/-/blob/v${finalAttrs.version}/CHANGELOG.md"; - license = with licenses; [ aom bsd3 ]; + license = with licenses; [ + aom + bsd3 + ]; maintainers = with maintainers; [ Madouura ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/sv/svu/package.nix b/pkgs/by-name/sv/svu/package.nix index 15cbe3a2792c57..012adee06657fb 100644 --- a/pkgs/by-name/sv/svu/package.nix +++ b/pkgs/by-name/sv/svu/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, svu }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + svu, +}: buildGoModule rec { pname = "svu"; @@ -13,7 +19,12 @@ buildGoModule rec { vendorHash = "sha256-/FSvNoVDWAkQs09gMrqyoA0su52nlk/nSCYRAhQhbwQ="; - ldflags = [ "-s" "-w" "-X=main.version=${version}" "-X=main.builtBy=nixpkgs" ]; + ldflags = [ + "-s" + "-w" + "-X=main.version=${version}" + "-X=main.builtBy=nixpkgs" + ]; # test assumes source directory to be a git repository postPatch = '' diff --git a/pkgs/by-name/sw/swagger-cli/package.nix b/pkgs/by-name/sw/swagger-cli/package.nix index 8658ad45520a47..f78dd09b46a49d 100644 --- a/pkgs/by-name/sw/swagger-cli/package.nix +++ b/pkgs/by-name/sw/swagger-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/sw/swagger-codegen/package.nix b/pkgs/by-name/sw/swagger-codegen/package.nix index 15e125f64fb9d4..77381c3f66691b 100644 --- a/pkgs/by-name/sw/swagger-codegen/package.nix +++ b/pkgs/by-name/sw/swagger-codegen/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { version = "2.4.38"; diff --git a/pkgs/by-name/sw/swagger-codegen3/package.nix b/pkgs/by-name/sw/swagger-codegen3/package.nix index 59222c1d412de2..39c994df36cd8c 100644 --- a/pkgs/by-name/sw/swagger-codegen3/package.nix +++ b/pkgs/by-name/sw/swagger-codegen3/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper, testers, swagger-codegen3 }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, + testers, + swagger-codegen3, +}: stdenv.mkDerivation rec { version = "3.0.62"; diff --git a/pkgs/by-name/sw/swaggerhole/package.nix b/pkgs/by-name/sw/swaggerhole/package.nix index 507fde0b3086ed..3f07eb76b5d8aa 100644 --- a/pkgs/by-name/sw/swaggerhole/package.nix +++ b/pkgs/by-name/sw/swaggerhole/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/sw/swaglyrics/package.nix b/pkgs/by-name/sw/swaglyrics/package.nix index 4b9095ff59d748..55fd6459ae51a4 100644 --- a/pkgs/by-name/sw/swaglyrics/package.nix +++ b/pkgs/by-name/sw/swaglyrics/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, ncurses +{ + lib, + python3, + fetchFromGitHub, + ncurses, }: python3.pkgs.buildPythonApplication rec { @@ -30,27 +31,30 @@ python3.pkgs.buildPythonApplication rec { unidecode ]; - nativeCheckInputs = with python3.pkgs; [ - blinker - flask - flask-testing - mock - pytestCheckHook - ] ++ [ - ncurses - ]; + nativeCheckInputs = + with python3.pkgs; + [ + blinker + flask + flask-testing + mock + pytestCheckHook + ] + ++ [ + ncurses + ]; preBuild = '' export HOME=$(mktemp -d) ''; disabledTests = [ - # Disable tests which touch network - "test_database_for_unsupported_song" - "test_that_lyrics_works_for_unsupported_songs" - "test_that_get_lyrics_works" - "test_lyrics_are_shown_in_tab" - "test_songchanged_can_raise_songplaying" + # Disable tests which touch network + "test_database_for_unsupported_song" + "test_that_lyrics_works_for_unsupported_songs" + "test_that_get_lyrics_works" + "test_lyrics_are_shown_in_tab" + "test_songchanged_can_raise_songplaying" ]; pythonImportsCheck = [ diff --git a/pkgs/by-name/sw/swaks/package.nix b/pkgs/by-name/sw/swaks/package.nix index a42d6773fc83f4..7e31e49cef1156 100644 --- a/pkgs/by-name/sw/swaks/package.nix +++ b/pkgs/by-name/sw/swaks/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, perl, perlPackages, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + perl, + perlPackages, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "swaks"; @@ -17,9 +24,15 @@ stdenv.mkDerivation rec { mv swaks $out/bin/ wrapProgram $out/bin/swaks --set PERL5LIB \ - "${with perlPackages; makePerlPath [ - NetSSLeay AuthenSASL NetDNS IOSocketINET6 - ]}" + "${ + with perlPackages; + makePerlPath [ + NetSSLeay + AuthenSASL + NetDNS + IOSocketINET6 + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/sw/swapview/package.nix b/pkgs/by-name/sw/swapview/package.nix index 520b2ba4758d93..b15b9d6d062dcd 100644 --- a/pkgs/by-name/sw/swapview/package.nix +++ b/pkgs/by-name/sw/swapview/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "swapview"; diff --git a/pkgs/by-name/sw/swarm/package.nix b/pkgs/by-name/sw/swarm/package.nix index 18ecc912915f94..5ee833114a4587 100644 --- a/pkgs/by-name/sw/swarm/package.nix +++ b/pkgs/by-name/sw/swarm/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "swarm"; diff --git a/pkgs/by-name/sw/sway-assign-cgroups/package.nix b/pkgs/by-name/sw/sway-assign-cgroups/package.nix index 5b879c783c8764..67c3f486266791 100644 --- a/pkgs/by-name/sw/sway-assign-cgroups/package.nix +++ b/pkgs/by-name/sw/sway-assign-cgroups/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3Packages +{ + lib, + fetchFromGitHub, + python3Packages, }: python3Packages.buildPythonApplication rec { @@ -14,7 +15,13 @@ python3Packages.buildPythonApplication rec { }; format = "other"; - propagatedBuildInputs = with python3Packages; [ dbus-next i3ipc psutil tenacity xlib ]; + propagatedBuildInputs = with python3Packages; [ + dbus-next + i3ipc + psutil + tenacity + xlib + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/sw/sway-audio-idle-inhibit/package.nix b/pkgs/by-name/sw/sway-audio-idle-inhibit/package.nix index 42c5421856492c..e4ae54623fbc14 100644 --- a/pkgs/by-name/sw/sway-audio-idle-inhibit/package.nix +++ b/pkgs/by-name/sw/sway-audio-idle-inhibit/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, libpulseaudio -, wayland -, wayland-protocols -, wayland-scanner +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + libpulseaudio, + wayland, + wayland-protocols, + wayland-scanner, }: stdenv.mkDerivation (finalAttrs: { pname = "sway-audio-idle-inhibit"; @@ -21,11 +22,16 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ - meson ninja pkg-config wayland-scanner + meson + ninja + pkg-config + wayland-scanner ]; buildInputs = [ - libpulseaudio wayland wayland-protocols + libpulseaudio + wayland + wayland-protocols ]; meta = with lib; { diff --git a/pkgs/by-name/sw/sway-easyfocus/package.nix b/pkgs/by-name/sw/sway-easyfocus/package.nix index 3d3b73f7c93fe0..dd4082764a29c0 100644 --- a/pkgs/by-name/sw/sway-easyfocus/package.nix +++ b/pkgs/by-name/sw/sway-easyfocus/package.nix @@ -1,15 +1,16 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, wrapGAppsHook3 -, atk -, cairo -, gdk-pixbuf -, glib -, gtk3 -, pango -, gtk-layer-shell +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + wrapGAppsHook3, + atk, + cairo, + gdk-pixbuf, + glib, + gtk3, + pango, + gtk-layer-shell, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sw/sway-launcher-desktop/package.nix b/pkgs/by-name/sw/sway-launcher-desktop/package.nix index 7dd660dddb1636..93cc778fc4e9cf 100644 --- a/pkgs/by-name/sw/sway-launcher-desktop/package.nix +++ b/pkgs/by-name/sw/sway-launcher-desktop/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fzf, gawk, fetchFromGitHub, makeWrapper }: +{ + stdenv, + lib, + fzf, + gawk, + fetchFromGitHub, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "sway-launcher-desktop"; @@ -15,14 +22,22 @@ stdenv.mkDerivation rec { patchShebangs ${pname}.sh ''; - buildInputs = [ fzf gawk ]; + buildInputs = [ + fzf + gawk + ]; nativeBuildInputs = [ makeWrapper ]; installPhase = '' install -d $out/bin install ${pname}.sh $out/bin/${pname} wrapProgram $out/bin/${pname} \ - --prefix PATH : ${lib.makeBinPath [ gawk fzf ]} + --prefix PATH : ${ + lib.makeBinPath [ + gawk + fzf + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/sw/sway-new-workspace/package.nix b/pkgs/by-name/sw/sway-new-workspace/package.nix index 79dcc963df71f4..a38583a1d1e3a1 100644 --- a/pkgs/by-name/sw/sway-new-workspace/package.nix +++ b/pkgs/by-name/sw/sway-new-workspace/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sw/sway-overfocus/package.nix b/pkgs/by-name/sw/sway-overfocus/package.nix index 9e968725d835a0..619f2b4babde43 100644 --- a/pkgs/by-name/sw/sway-overfocus/package.nix +++ b/pkgs/by-name/sw/sway-overfocus/package.nix @@ -1,4 +1,9 @@ -{ fetchFromGitHub, lib, nix-update-script, rustPlatform }: +{ + fetchFromGitHub, + lib, + nix-update-script, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "sway-overfocus"; @@ -27,4 +32,3 @@ rustPlatform.buildRustPackage rec { mainProgram = "sway-overfocus"; }; } - diff --git a/pkgs/by-name/sw/sway/package.nix b/pkgs/by-name/sw/sway/package.nix index 5506447f692ec2..39d0728c0848fe 100644 --- a/pkgs/by-name/sw/sway/package.nix +++ b/pkgs/by-name/sw/sway/package.nix @@ -1,14 +1,23 @@ -{ lib -, sway-unwrapped -, makeWrapper, symlinkJoin, writeShellScriptBin -, withBaseWrapper ? true, extraSessionCommands ? "", dbus -, withGtkWrapper ? false, wrapGAppsHook3, gdk-pixbuf, glib, gtk3 -, extraOptions ? [] # E.g.: [ "--verbose" ] -# Used by the NixOS module: -, isNixOS ? false +{ + lib, + sway-unwrapped, + makeWrapper, + symlinkJoin, + writeShellScriptBin, + withBaseWrapper ? true, + extraSessionCommands ? "", + dbus, + withGtkWrapper ? false, + wrapGAppsHook3, + gdk-pixbuf, + glib, + gtk3, + extraOptions ? [ ], # E.g.: [ "--verbose" ] + # Used by the NixOS module: + isNixOS ? false, -, enableXWayland ? true -, dbusSupport ? true + enableXWayland ? true, + dbusSupport ? true, }: assert extraSessionCommands != "" -> withBaseWrapper; @@ -19,34 +28,39 @@ let inherit (lib.meta) getExe; inherit (lib.strings) concatMapStrings optionalString; - sway = sway-unwrapped.overrideAttrs (oa: { inherit isNixOS enableXWayland; }); + sway = sway-unwrapped.overrideAttrs (oa: { + inherit isNixOS enableXWayland; + }); baseWrapper = writeShellScriptBin sway.meta.mainProgram '' - set -o errexit - if [ ! "$_SWAY_WRAPPER_ALREADY_EXECUTED" ]; then - export XDG_CURRENT_DESKTOP=${sway.meta.mainProgram} - ${extraSessionCommands} - export _SWAY_WRAPPER_ALREADY_EXECUTED=1 - fi - if [ "$DBUS_SESSION_BUS_ADDRESS" ]; then - export DBUS_SESSION_BUS_ADDRESS - exec ${getExe sway} "$@" - else - exec ${optionalString dbusSupport "${dbus}/bin/dbus-run-session"} ${getExe sway} "$@" - fi - ''; -in symlinkJoin rec { - pname = replaceStrings ["-unwrapped"] [""] sway.pname; + set -o errexit + if [ ! "$_SWAY_WRAPPER_ALREADY_EXECUTED" ]; then + export XDG_CURRENT_DESKTOP=${sway.meta.mainProgram} + ${extraSessionCommands} + export _SWAY_WRAPPER_ALREADY_EXECUTED=1 + fi + if [ "$DBUS_SESSION_BUS_ADDRESS" ]; then + export DBUS_SESSION_BUS_ADDRESS + exec ${getExe sway} "$@" + else + exec ${optionalString dbusSupport "${dbus}/bin/dbus-run-session"} ${getExe sway} "$@" + fi + ''; +in +symlinkJoin rec { + pname = replaceStrings [ "-unwrapped" ] [ "" ] sway.pname; inherit (sway) version; name = "${pname}-${version}"; - paths = (optional withBaseWrapper baseWrapper) - ++ [ sway ]; + paths = (optional withBaseWrapper baseWrapper) ++ [ sway ]; strictDeps = false; - nativeBuildInputs = [ makeWrapper ] - ++ (optional withGtkWrapper wrapGAppsHook3); + nativeBuildInputs = [ makeWrapper ] ++ (optional withGtkWrapper wrapGAppsHook3); - buildInputs = optionals withGtkWrapper [ gdk-pixbuf glib gtk3 ]; + buildInputs = optionals withGtkWrapper [ + gdk-pixbuf + glib + gtk3 + ]; # We want to run wrapProgram manually dontWrapGApps = true; @@ -56,7 +70,9 @@ in symlinkJoin rec { wrapProgram $out/bin/${sway.meta.mainProgram} \ ${optionalString withGtkWrapper ''"''${gappsWrapperArgs[@]}"''} \ - ${optionalString (extraOptions != []) "${concatMapStrings (x: " --add-flags " + x) extraOptions}"} + ${optionalString (extraOptions != [ ]) + "${concatMapStrings (x: " --add-flags " + x) extraOptions}" + } ''; passthru = { diff --git a/pkgs/by-name/sw/swaycons/package.nix b/pkgs/by-name/sw/swaycons/package.nix index c4f6e31a6a43d3..28c8faeace1674 100644 --- a/pkgs/by-name/sw/swaycons/package.nix +++ b/pkgs/by-name/sw/swaycons/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/sw/swaycwd/package.nix b/pkgs/by-name/sw/swaycwd/package.nix index 50568b32155203..50f30c1c73cf2c 100644 --- a/pkgs/by-name/sw/swaycwd/package.nix +++ b/pkgs/by-name/sw/swaycwd/package.nix @@ -1,7 +1,15 @@ -{ lib -, buildNimPackage -, fetchFromGitLab -, enableShells ? [ "bash" "zsh" "fish" "sh" "posh" "codium" ] +{ + lib, + buildNimPackage, + fetchFromGitLab, + enableShells ? [ + "bash" + "zsh" + "fish" + "sh" + "posh" + "codium" + ], }: buildNimPackage (finalAttrs: { diff --git a/pkgs/by-name/sw/swayidle/package.nix b/pkgs/by-name/sw/swayidle/package.nix index 35e66bd961a290..9023cb5af80e2d 100644 --- a/pkgs/by-name/sw/swayidle/package.nix +++ b/pkgs/by-name/sw/swayidle/package.nix @@ -1,7 +1,17 @@ -{ lib, stdenv, fetchFromGitHub -, meson, ninja, pkg-config, scdoc, wayland-scanner -, wayland, wayland-protocols, runtimeShell -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, systemd +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + scdoc, + wayland-scanner, + wayland, + wayland-protocols, + runtimeShell, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, }: stdenv.mkDerivation rec { @@ -17,11 +27,22 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson ninja pkg-config scdoc wayland-scanner ]; - buildInputs = [ wayland wayland-protocols ] - ++ lib.optionals systemdSupport [ systemd ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + scdoc + wayland-scanner + ]; + buildInputs = [ + wayland + wayland-protocols + ] ++ lib.optionals systemdSupport [ systemd ]; - mesonFlags = [ "-Dman-pages=enabled" "-Dlogind=${if systemdSupport then "enabled" else "disabled"}" ]; + mesonFlags = [ + "-Dman-pages=enabled" + "-Dlogind=${if systemdSupport then "enabled" else "disabled"}" + ]; postPatch = '' substituteInPlace main.c \ diff --git a/pkgs/by-name/sw/swaykbdd/package.nix b/pkgs/by-name/sw/swaykbdd/package.nix index c4ab6098f21b06..07d73adb07cded 100644 --- a/pkgs/by-name/sw/swaykbdd/package.nix +++ b/pkgs/by-name/sw/swaykbdd/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, json_c, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + json_c, + pkg-config, +}: stdenv.mkDerivation rec { pname = "swaykbdd"; @@ -12,7 +20,11 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; buildInputs = [ json_c ]; meta = with lib; { diff --git a/pkgs/by-name/sw/swaylock-effects/package.nix b/pkgs/by-name/sw/swaylock-effects/package.nix index 0f5ba49711814f..e82eda03070ef1 100644 --- a/pkgs/by-name/sw/swaylock-effects/package.nix +++ b/pkgs/by-name/sw/swaylock-effects/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, scdoc -, wayland -, wayland-protocols -, wayland-scanner -, libxkbcommon -, cairo -, gdk-pixbuf -, pam +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + scdoc, + wayland, + wayland-protocols, + wayland-scanner, + libxkbcommon, + cairo, + gdk-pixbuf, + pam, }: stdenv.mkDerivation rec { @@ -31,8 +32,21 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson ninja pkg-config scdoc wayland-scanner]; - buildInputs = [ wayland wayland-protocols libxkbcommon cairo gdk-pixbuf pam ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + scdoc + wayland-scanner + ]; + buildInputs = [ + wayland + wayland-protocols + libxkbcommon + cairo + gdk-pixbuf + pam + ]; mesonFlags = [ "-Dpam=enabled" diff --git a/pkgs/by-name/sw/swaylock-fancy/package.nix b/pkgs/by-name/sw/swaylock-fancy/package.nix index d821863e84a794..23853af8e8ba06 100644 --- a/pkgs/by-name/sw/swaylock-fancy/package.nix +++ b/pkgs/by-name/sw/swaylock-fancy/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, coreutils -, grim -, gawk -, jq -, swaylock -, imagemagick -, getopt -, fontconfig -, wmctrl -, makeWrapper -, bash +{ + lib, + stdenv, + fetchFromGitHub, + coreutils, + grim, + gawk, + jq, + swaylock, + imagemagick, + getopt, + fontconfig, + wmctrl, + makeWrapper, + bash, }: let diff --git a/pkgs/by-name/sw/swaymux/package.nix b/pkgs/by-name/sw/swaymux/package.nix index 7d9fee3866517f..47b075aa16b3cb 100644 --- a/pkgs/by-name/sw/swaymux/package.nix +++ b/pkgs/by-name/sw/swaymux/package.nix @@ -1,9 +1,10 @@ -{ cmake -, fetchFromGitea -, lib -, nlohmann_json -, qt6 -, stdenv +{ + cmake, + fetchFromGitea, + lib, + nlohmann_json, + qt6, + stdenv, }: stdenv.mkDerivation (finalAttrs: { version = "1.1"; @@ -17,8 +18,15 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-OMJ9wKNuvD1Z9KV7Bp7aIA5gWbBl9PmTdGcGegE0vqM="; }; - buildInputs = [ qt6.qtwayland nlohmann_json qt6.qtbase]; - nativeBuildInputs = [ cmake qt6.wrapQtAppsHook ]; + buildInputs = [ + qt6.qtwayland + nlohmann_json + qt6.qtbase + ]; + nativeBuildInputs = [ + cmake + qt6.wrapQtAppsHook + ]; doCheck = true; diff --git a/pkgs/by-name/sw/swaynag-battery/package.nix b/pkgs/by-name/sw/swaynag-battery/package.nix index cbcb5d90261f1d..b9223980ecef97 100644 --- a/pkgs/by-name/sw/swaynag-battery/package.nix +++ b/pkgs/by-name/sw/swaynag-battery/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "swaynag-battery"; diff --git a/pkgs/by-name/sw/swaynotificationcenter/package.nix b/pkgs/by-name/sw/swaynotificationcenter/package.nix index b2ea718d87e557..74f63187618903 100644 --- a/pkgs/by-name/sw/swaynotificationcenter/package.nix +++ b/pkgs/by-name/sw/swaynotificationcenter/package.nix @@ -1,33 +1,34 @@ -{ lib -, stdenv -, fetchFromGitHub -, testers -, wrapGAppsHook3 -, bash-completion -, dbus -, dbus-glib -, fish -, gdk-pixbuf -, glib -, gobject-introspection -, gtk-layer-shell -, gtk3 -, gvfs -, json-glib -, libgee -, libhandy -, libnotify -, libpulseaudio -, librsvg -, meson -, ninja -, pkg-config -, python3 -, scdoc -, vala -, xvfb-run -, sassc -, pantheon +{ + lib, + stdenv, + fetchFromGitHub, + testers, + wrapGAppsHook3, + bash-completion, + dbus, + dbus-glib, + fish, + gdk-pixbuf, + glib, + gobject-introspection, + gtk-layer-shell, + gtk3, + gvfs, + json-glib, + libgee, + libhandy, + libnotify, + libpulseaudio, + librsvg, + meson, + ninja, + pkg-config, + python3, + scdoc, + vala, + xvfb-run, + sassc, + pantheon, }: stdenv.mkDerivation (finalAttrs: rec { @@ -96,6 +97,9 @@ stdenv.mkDerivation (finalAttrs: rec { license = licenses.gpl3; platforms = platforms.linux; mainProgram = "swaync"; - maintainers = with maintainers; [ berbiche pedrohlc ]; + maintainers = with maintainers; [ + berbiche + pedrohlc + ]; }; }) diff --git a/pkgs/by-name/sw/swayosd/package.nix b/pkgs/by-name/sw/swayosd/package.nix index 6f688436395c6b..1b4d736f56cab9 100644 --- a/pkgs/by-name/sw/swayosd/package.nix +++ b/pkgs/by-name/sw/swayosd/package.nix @@ -59,7 +59,7 @@ stdenv.mkDerivation rec { preFixup = '' gappsWrapperArgs+=( - --prefix PATH : ${lib.makeBinPath [brightnessctl]} + --prefix PATH : ${lib.makeBinPath [ brightnessctl ]} ) ''; diff --git a/pkgs/by-name/sw/swayr/package.nix b/pkgs/by-name/sw/swayr/package.nix index 7368aa60d04c4d..36adeddd31393d 100644 --- a/pkgs/by-name/sw/swayr/package.nix +++ b/pkgs/by-name/sw/swayr/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromSourcehut, rustPlatform }: +{ + lib, + fetchFromSourcehut, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "swayr"; diff --git a/pkgs/by-name/sw/swayrbar/package.nix b/pkgs/by-name/sw/swayrbar/package.nix index d3437590337a60..85a92cbdd4cd46 100644 --- a/pkgs/by-name/sw/swayrbar/package.nix +++ b/pkgs/by-name/sw/swayrbar/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromSourcehut, rustPlatform, makeWrapper, withPulseaudio ? false, pulseaudio }: +{ + lib, + fetchFromSourcehut, + rustPlatform, + makeWrapper, + withPulseaudio ? false, + pulseaudio, +}: rustPlatform.buildRustPackage rec { pname = "swayrbar"; @@ -32,7 +39,7 @@ rustPlatform.buildRustPackage rec { homepage = "https://git.sr.ht/~tsdh/swayr#a-idswayrbarswayrbara"; license = with licenses; [ gpl3Plus ]; platforms = platforms.linux; - maintainers = with maintainers; []; + maintainers = with maintainers; [ ]; mainProgram = "swayrbar"; }; } diff --git a/pkgs/by-name/sw/swaysettings/package.nix b/pkgs/by-name/sw/swaysettings/package.nix index 419695d2e7d8cc..099b9eb3c694a0 100644 --- a/pkgs/by-name/sw/swaysettings/package.nix +++ b/pkgs/by-name/sw/swaysettings/package.nix @@ -1,28 +1,29 @@ -{ lib -, fetchFromGitHub -, accountsservice -, appstream-glib -, dbus -, desktop-file-utils -, gettext -, glib -, gobject-introspection -, gsettings-desktop-schemas -, gtk-layer-shell -, gtk3 -, json-glib -, libgee -, libhandy -, libpulseaudio -, libxml2 -, meson -, ninja -, pantheon -, pkg-config -, python3 -, stdenv -, vala -, wrapGAppsHook3 +{ + lib, + fetchFromGitHub, + accountsservice, + appstream-glib, + dbus, + desktop-file-utils, + gettext, + glib, + gobject-introspection, + gsettings-desktop-schemas, + gtk-layer-shell, + gtk3, + json-glib, + libgee, + libhandy, + libpulseaudio, + libxml2, + meson, + ninja, + pantheon, + pkg-config, + python3, + stdenv, + vala, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sw/swayws/package.nix b/pkgs/by-name/sw/swayws/package.nix index 8041763adef06a..90752a14da04a2 100644 --- a/pkgs/by-name/sw/swayws/package.nix +++ b/pkgs/by-name/sw/swayws/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitLab, rustPlatform }: +{ + lib, + fetchFromGitLab, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "swayws"; diff --git a/pkgs/by-name/sw/swaywsr/package.nix b/pkgs/by-name/sw/swaywsr/package.nix index 8901eb3c69e242..cdec0aab22ab71 100644 --- a/pkgs/by-name/sw/swaywsr/package.nix +++ b/pkgs/by-name/sw/swaywsr/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, rustPlatform, libxcb, python3 }: +{ + lib, + fetchFromGitHub, + rustPlatform, + libxcb, + python3, +}: rustPlatform.buildRustPackage rec { pname = "swaywsr"; diff --git a/pkgs/by-name/sw/swc/package.nix b/pkgs/by-name/sw/swc/package.nix index b9ed6d05d6f4d5..2355bb88018927 100644 --- a/pkgs/by-name/sw/swc/package.nix +++ b/pkgs/by-name/sw/swc/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { @@ -25,6 +26,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "swc"; homepage = "https://github.com/swc-project/swc"; license = licenses.asl20; - maintainers = with maintainers; [ dit7ya kashw2 ]; + maintainers = with maintainers; [ + dit7ya + kashw2 + ]; }; } diff --git a/pkgs/by-name/sw/sweet-folders/package.nix b/pkgs/by-name/sw/sweet-folders/package.nix index e4cd25ed8f51ce..dbbe7a949992be 100644 --- a/pkgs/by-name/sw/sweet-folders/package.nix +++ b/pkgs/by-name/sw/sweet-folders/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/sw/sweet-nova/package.nix b/pkgs/by-name/sw/sweet-nova/package.nix index 15d393bcab76da..6b99c8769c3b48 100644 --- a/pkgs/by-name/sw/sweet-nova/package.nix +++ b/pkgs/by-name/sw/sweet-nova/package.nix @@ -1,7 +1,8 @@ -{ fetchFromGitHub -, gitUpdater -, lib -, stdenvNoCC +{ + fetchFromGitHub, + gitUpdater, + lib, + stdenvNoCC, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/sw/sweet/package.nix b/pkgs/by-name/sw/sweet/package.nix index de979e69118e92..51763fb1b974f4 100644 --- a/pkgs/by-name/sw/sweet/package.nix +++ b/pkgs/by-name/sw/sweet/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, fetchurl -, unzip -, gtk-engine-murrine -, colorVariants ? [] # default: install all icons +{ + lib, + stdenvNoCC, + fetchurl, + unzip, + gtk-engine-murrine, + colorVariants ? [ ], # default: install all icons }: let @@ -26,79 +27,85 @@ let in lib.checkListOfEnum "${pname}: color variants" colorVariantList colorVariants -stdenvNoCC.mkDerivation (finalAttrs: { - inherit pname; - version = "5.0"; + stdenvNoCC.mkDerivation + (finalAttrs: { + inherit pname; + version = "5.0"; - srcs = [ - (fetchurl { - url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Ambar-Blue-Dark-v40.tar.xz"; - hash = "sha256-fCCkkEYr4XPnP5aPrs3HAwIwM/Qb0NFY8Rf1ABu0ygY="; - }) - (fetchurl { - url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Ambar-Blue-Dark.tar.xz"; - hash = "sha256-xMAqUsol1FPeFoq8KLTmKCeZMF34FDAjhiagsRmjGT8="; - }) - (fetchurl { - url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Ambar-Blue-v40.tar.xz"; - hash = "sha256-JlpomJ8Ao4bJFJbCDliRtxNckEG3LzINBqhWzfTARJs="; - }) - (fetchurl { - url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Ambar-Blue.tar.xz"; - hash = "sha256-HKJ/Ca5cy91kJZVEETyMcOcrgLliHF/S2rdBmWfKi08="; - }) - (fetchurl { - url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Ambar-v40.tar.xz"; - hash = "sha256-0LjARDbSPyQWN5nT97k2c//eebxhgStGYsebpNQn9+w="; - }) - (fetchurl { - url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Ambar.tar.xz"; - hash = "sha256-UjH4popJCqQ18HZUngsO6cE4axSAM7/EXwM8nHAdVS4="; - }) - (fetchurl { - url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Dark-v40.tar.xz"; - hash = "sha256-4/e81slrkcO3WdrQ2atGHdZsErlzme4mRImfLvmGJnQ="; - }) - (fetchurl { - url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Dark.tar.xz"; - hash = "sha256-Tv+xtUee1TIdRLlnP84aVfk+V6xgeeeICRZCdeSSjE8="; - }) - (fetchurl { - url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-mars-v40.tar.xz"; - hash = "sha256-FmJoPeQ8iLA6X6lFawBqG8lviQXWBHG5lgQsZvU68BM="; - }) - (fetchurl { - url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-mars.tar.xz"; - hash = "sha256-bqL9jR8yPF9ZnEZ1O+P3/e6E59m+MY7mQNT3BhYVhu4="; - }) - (fetchurl { - url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-v40.tar.xz"; - hash = "sha256-Oesx/McKmTlqwJX8u6RrV3AtOIB73BQveD8slbD14js="; - }) - (fetchurl { - url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet.tar.xz"; - hash = "sha256-m0tQHV/3UkDoOAmBZF6Nvugj6fEkmLbeLPdQ/IFkHOo="; - }) - ]; + srcs = [ + (fetchurl { + url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Ambar-Blue-Dark-v40.tar.xz"; + hash = "sha256-fCCkkEYr4XPnP5aPrs3HAwIwM/Qb0NFY8Rf1ABu0ygY="; + }) + (fetchurl { + url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Ambar-Blue-Dark.tar.xz"; + hash = "sha256-xMAqUsol1FPeFoq8KLTmKCeZMF34FDAjhiagsRmjGT8="; + }) + (fetchurl { + url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Ambar-Blue-v40.tar.xz"; + hash = "sha256-JlpomJ8Ao4bJFJbCDliRtxNckEG3LzINBqhWzfTARJs="; + }) + (fetchurl { + url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Ambar-Blue.tar.xz"; + hash = "sha256-HKJ/Ca5cy91kJZVEETyMcOcrgLliHF/S2rdBmWfKi08="; + }) + (fetchurl { + url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Ambar-v40.tar.xz"; + hash = "sha256-0LjARDbSPyQWN5nT97k2c//eebxhgStGYsebpNQn9+w="; + }) + (fetchurl { + url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Ambar.tar.xz"; + hash = "sha256-UjH4popJCqQ18HZUngsO6cE4axSAM7/EXwM8nHAdVS4="; + }) + (fetchurl { + url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Dark-v40.tar.xz"; + hash = "sha256-4/e81slrkcO3WdrQ2atGHdZsErlzme4mRImfLvmGJnQ="; + }) + (fetchurl { + url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-Dark.tar.xz"; + hash = "sha256-Tv+xtUee1TIdRLlnP84aVfk+V6xgeeeICRZCdeSSjE8="; + }) + (fetchurl { + url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-mars-v40.tar.xz"; + hash = "sha256-FmJoPeQ8iLA6X6lFawBqG8lviQXWBHG5lgQsZvU68BM="; + }) + (fetchurl { + url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-mars.tar.xz"; + hash = "sha256-bqL9jR8yPF9ZnEZ1O+P3/e6E59m+MY7mQNT3BhYVhu4="; + }) + (fetchurl { + url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet-v40.tar.xz"; + hash = "sha256-Oesx/McKmTlqwJX8u6RrV3AtOIB73BQveD8slbD14js="; + }) + (fetchurl { + url = "https://github.com/EliverLara/Sweet/releases/download/v${finalAttrs.version}/Sweet.tar.xz"; + hash = "sha256-m0tQHV/3UkDoOAmBZF6Nvugj6fEkmLbeLPdQ/IFkHOo="; + }) + ]; - nativeBuildInputs = [ unzip ]; + nativeBuildInputs = [ unzip ]; - propagatedUserEnvPkgs = [ gtk-engine-murrine ]; + propagatedUserEnvPkgs = [ gtk-engine-murrine ]; - sourceRoot = "."; + sourceRoot = "."; - installPhase = '' - runHook preInstall - mkdir -p $out/share/themes/ - cp -r ${lib.concatStringsSep " " (if colorVariants != [] then colorVariants else colorVariantList)} $out/share/themes/ - runHook postInstall - ''; + installPhase = '' + runHook preInstall + mkdir -p $out/share/themes/ + cp -r ${ + lib.concatStringsSep " " (if colorVariants != [ ] then colorVariants else colorVariantList) + } $out/share/themes/ + runHook postInstall + ''; - meta = with lib; { - description = "Light and dark colorful Gtk3.20+ theme"; - homepage = "https://github.com/EliverLara/Sweet"; - license = licenses.gpl3Plus; - maintainers = with maintainers; [ fuzen d3vil0p3r ]; - platforms = platforms.unix; - }; -}) + meta = with lib; { + description = "Light and dark colorful Gtk3.20+ theme"; + homepage = "https://github.com/EliverLara/Sweet"; + license = licenses.gpl3Plus; + maintainers = with maintainers; [ + fuzen + d3vil0p3r + ]; + platforms = platforms.unix; + }; + }) diff --git a/pkgs/by-name/sw/swfmill/package.nix b/pkgs/by-name/sw/swfmill/package.nix index e7e28c09a2d8b2..3beae68dfefb31 100644 --- a/pkgs/by-name/sw/swfmill/package.nix +++ b/pkgs/by-name/sw/swfmill/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchurl -, pkg-config, libxslt, freetype, libpng, libxml2 +{ + lib, + stdenv, + fetchurl, + pkg-config, + libxslt, + freetype, + libpng, + libxml2, }: stdenv.mkDerivation rec { @@ -12,7 +19,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libxslt freetype libpng libxml2 ]; + buildInputs = [ + libxslt + freetype + libpng + libxml2 + ]; # fatal error: 'libxml/xpath.h' file not found env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-I${libxml2.dev}/include/libxml2"; diff --git a/pkgs/by-name/sw/swh_lv2/package.nix b/pkgs/by-name/sw/swh_lv2/package.nix index 224ab749593dd6..6e74700ef6242b 100644 --- a/pkgs/by-name/sw/swh_lv2/package.nix +++ b/pkgs/by-name/sw/swh_lv2/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fftwSinglePrec, libxslt, lv2, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + fftwSinglePrec, + libxslt, + lv2, + pkg-config, +}: stdenv.mkDerivation rec { pname = "swh-lv2"; @@ -17,7 +25,10 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ fftwSinglePrec lv2 ]; + buildInputs = [ + fftwSinglePrec + lv2 + ]; installPhase = "make install-system"; diff --git a/pkgs/by-name/sw/swiftdefaultapps/package.nix b/pkgs/by-name/sw/swiftdefaultapps/package.nix index 44a40e8c8a70b2..b929684511f991 100644 --- a/pkgs/by-name/sw/swiftdefaultapps/package.nix +++ b/pkgs/by-name/sw/swiftdefaultapps/package.nix @@ -1,4 +1,8 @@ -{ fetchzip, lib, stdenvNoCC }: +{ + fetchzip, + lib, + stdenvNoCC, +}: stdenvNoCC.mkDerivation rec { pname = "swiftdefaultapps"; diff --git a/pkgs/by-name/sw/swiften/package.nix b/pkgs/by-name/sw/swiften/package.nix index fffe96dbf5c1bf..754ac1b8c79f1c 100644 --- a/pkgs/by-name/sw/swiften/package.nix +++ b/pkgs/by-name/sw/swiften/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, libidn -, lua -, miniupnpc -, expat -, zlib -, fetchurl -, fetchpatch -, openssl -, boost -, scons +{ + stdenv, + lib, + libidn, + lua, + miniupnpc, + expat, + zlib, + fetchurl, + fetchpatch, + openssl, + boost, + scons, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sw/swiftformat/package.nix b/pkgs/by-name/sw/swiftformat/package.nix index 317f0ee416171f..3ff1ce98ffc847 100644 --- a/pkgs/by-name/sw/swiftformat/package.nix +++ b/pkgs/by-name/sw/swiftformat/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: # This derivation is impure: it relies on an Xcode toolchain being installed # and available in the expected place. The values of sandboxProfile and @@ -40,6 +44,6 @@ stdenv.mkDerivation rec { license = licenses.mit; maintainers = [ maintainers.bdesham ]; platforms = platforms.darwin; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/by-name/sw/swiftshader/package.nix b/pkgs/by-name/sw/swiftshader/package.nix index 3063ccc3a18916..6bae629c60301b 100644 --- a/pkgs/by-name/sw/swiftshader/package.nix +++ b/pkgs/by-name/sw/swiftshader/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchgit, python3, cmake, jq }: +{ + lib, + stdenv, + fetchgit, + python3, + cmake, + jq, +}: stdenv.mkDerivation rec { pname = "swiftshader"; @@ -17,7 +24,11 @@ stdenv.mkDerivation rec { ''; }; - nativeBuildInputs = [ cmake python3 jq ]; + nativeBuildInputs = [ + cmake + python3 + jq + ]; # Make sure we include the drivers and icd files in the output as the cmake # generated install command only puts in the spirv-tools stuff. @@ -39,13 +50,12 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = - "A high-performance CPU-based implementation of the Vulkan 1.3 graphics API"; + description = "A high-performance CPU-based implementation of the Vulkan 1.3 graphics API"; homepage = "https://opensource.google/projects/swiftshader"; license = licenses.asl20; # Should be possible to support Darwin by changing the install phase with # 's/Linux/Darwin/' and 's/so/dylib/' or something similar. platforms = with platforms; linux; - maintainers = []; + maintainers = [ ]; }; } diff --git a/pkgs/by-name/sw/swingsane/package.nix b/pkgs/by-name/sw/swingsane/package.nix index 998c3d21103153..7d52e49d5899fd 100644 --- a/pkgs/by-name/sw/swingsane/package.nix +++ b/pkgs/by-name/sw/swingsane/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, makeDesktopItem, unzip, jre, runtimeShell }: +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + unzip, + jre, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "swingsane"; @@ -13,35 +21,37 @@ stdenv.mkDerivation rec { dontConfigure = true; - installPhase = let + installPhase = + let - execWrapper = '' - #!${runtimeShell} - exec ${jre}/bin/java -jar $out/share/java/swingsane/swingsane-${version}.jar "$@" - ''; + execWrapper = '' + #!${runtimeShell} + exec ${jre}/bin/java -jar $out/share/java/swingsane/swingsane-${version}.jar "$@" + ''; - desktopItem = makeDesktopItem { - name = "swingsane"; - exec = "swingsane"; - icon = "swingsane"; - desktopName = "SwingSane"; - genericName = "Scan from local or remote SANE servers"; - comment = meta.description; - categories = [ "Office" ]; - }; + desktopItem = makeDesktopItem { + name = "swingsane"; + exec = "swingsane"; + icon = "swingsane"; + desktopName = "SwingSane"; + genericName = "Scan from local or remote SANE servers"; + comment = meta.description; + categories = [ "Office" ]; + }; - in '' - install -v -m 755 -d $out/share/java/swingsane/ - install -v -m 644 *.jar $out/share/java/swingsane/ + in + '' + install -v -m 755 -d $out/share/java/swingsane/ + install -v -m 644 *.jar $out/share/java/swingsane/ - echo "${execWrapper}" > swingsane - install -v -D -m 755 swingsane $out/bin/swingsane + echo "${execWrapper}" > swingsane + install -v -D -m 755 swingsane $out/bin/swingsane - unzip -j swingsane-${version}.jar "com/swingsane/images/*.png" - install -v -D -m 644 swingsane_512x512.png $out/share/pixmaps/swingsane.png + unzip -j swingsane-${version}.jar "com/swingsane/images/*.png" + install -v -D -m 644 swingsane_512x512.png $out/share/pixmaps/swingsane.png - cp -v -r ${desktopItem}/share/applications $out/share - ''; + cp -v -r ${desktopItem}/share/applications $out/share + ''; meta = with lib; { description = "Java GUI for SANE scanner servers (saned)"; diff --git a/pkgs/by-name/sw/swipe-guess/package.nix b/pkgs/by-name/sw/swipe-guess/package.nix index 881dd9718a6f74..26273fb1101034 100644 --- a/pkgs/by-name/sw/swipe-guess/package.nix +++ b/pkgs/by-name/sw/swipe-guess/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromSourcehut +{ + lib, + stdenv, + fetchFromSourcehut, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/sw/switcheroo-control/package.nix b/pkgs/by-name/sw/switcheroo-control/package.nix index a6993af54910f5..f6cff0ba3169fc 100644 --- a/pkgs/by-name/sw/switcheroo-control/package.nix +++ b/pkgs/by-name/sw/switcheroo-control/package.nix @@ -1,12 +1,13 @@ -{ lib -, ninja -, meson -, fetchFromGitLab -, systemd -, libgudev -, pkg-config -, glib -, python3Packages +{ + lib, + ninja, + meson, + fetchFromGitLab, + systemd, + libgudev, + pkg-config, + glib, + python3Packages, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/sw/switcheroo/package.nix b/pkgs/by-name/sw/switcheroo/package.nix index d61c2a722f69e3..f038534305fc1d 100644 --- a/pkgs/by-name/sw/switcheroo/package.nix +++ b/pkgs/by-name/sw/switcheroo/package.nix @@ -1,20 +1,21 @@ -{ lib -, blueprint-compiler -, cargo -, darwin -, desktop-file-utils -, fetchFromGitLab -, glib -, gtk4 -, imagemagick -, libadwaita -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, stdenv -, wrapGAppsHook4 +{ + lib, + blueprint-compiler, + cargo, + darwin, + desktop-file-utils, + fetchFromGitLab, + glib, + gtk4, + imagemagick, + libadwaita, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { @@ -46,13 +47,15 @@ stdenv.mkDerivation (finalAttrs: { wrapGAppsHook4 ]; - buildInputs = [ - glib - gtk4 - libadwaita - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + glib + gtk4 + libadwaita + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ]; preFixup = '' gappsWrapperArgs+=( @@ -62,12 +65,9 @@ stdenv.mkDerivation (finalAttrs: { # Workaround for the gettext-sys issue # https://github.com/Koka/gettext-rs/issues/114 - env.NIX_CFLAGS_COMPILE = lib.optionalString - ( - stdenv.cc.isClang && - lib.versionAtLeast stdenv.cc.version "16" - ) - "-Wno-error=incompatible-function-pointer-types"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.cc.isClang && lib.versionAtLeast stdenv.cc.version "16" + ) "-Wno-error=incompatible-function-pointer-types"; meta = with lib; { changelog = "https://gitlab.com/adhami3310/Switcheroo/-/releases/v${finalAttrs.version}"; diff --git a/pkgs/by-name/sw/swtpm/package.nix b/pkgs/by-name/sw/swtpm/package.nix index 0332de516e8d02..fb94c21b053a56 100644 --- a/pkgs/by-name/sw/swtpm/package.nix +++ b/pkgs/by-name/sw/swtpm/package.nix @@ -1,18 +1,27 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, pkg-config -, libtasn1, openssl, fuse, glib, libseccomp, json-glib -, libtpms -, unixtools, expect, socat -, gnutls -, perl - -# Tests -, python3, which -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + libtasn1, + openssl, + fuse, + glib, + libseccomp, + json-glib, + libtpms, + unixtools, + expect, + socat, + gnutls, + perl, + + # Tests + python3, + which, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { @@ -37,7 +46,10 @@ stdenv.mkDerivation (finalAttrs: { ]; nativeBuildInputs = [ - pkg-config unixtools.netstat expect socat + pkg-config + unixtools.netstat + expect + socat perl # for pod2man python3 autoreconfHook @@ -47,21 +59,27 @@ stdenv.mkDerivation (finalAttrs: { which ]; - buildInputs = [ - libtpms - openssl libtasn1 - glib json-glib - gnutls - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - fuse - libseccomp - ]; - - configureFlags = [ - "--localstatedir=/var" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "--with-cuse" - ]; + buildInputs = + [ + libtpms + openssl + libtasn1 + glib + json-glib + gnutls + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + fuse + libseccomp + ]; + + configureFlags = + [ + "--localstatedir=/var" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "--with-cuse" + ]; postPatch = '' patchShebangs tests/* @@ -102,7 +120,10 @@ stdenv.mkDerivation (finalAttrs: { doCheck = true; enableParallelBuilding = true; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; passthru.tests = { inherit (nixosTests) systemd-cryptenroll; }; diff --git a/pkgs/by-name/sx/sx-go/package.nix b/pkgs/by-name/sx/sx-go/package.nix index 8c8ceee0fe747a..18679532f6176b 100644 --- a/pkgs/by-name/sx/sx-go/package.nix +++ b/pkgs/by-name/sx/sx-go/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, fetchpatch -, libpcap +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + libpcap, }: buildGoModule rec { diff --git a/pkgs/by-name/sx/sxcs/package.nix b/pkgs/by-name/sx/sxcs/package.nix index 637efb609e6576..b4dd0b871573a9 100644 --- a/pkgs/by-name/sx/sxcs/package.nix +++ b/pkgs/by-name/sx/sxcs/package.nix @@ -3,7 +3,7 @@ stdenv, fetchFromGitea, xorg, - installShellFiles + installShellFiles, }: stdenv.mkDerivation (finalAttrs: { @@ -18,7 +18,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-rYmbbdZjeLCvGvNocI3+KVU2KBkYvRisayTyScTRay8="; }; - buildInputs = [ xorg.libX11 xorg.libXcursor ]; + buildInputs = [ + xorg.libX11 + xorg.libXcursor + ]; nativeBuildInputs = [ installShellFiles ]; buildPhase = '' @@ -27,7 +30,10 @@ stdenv.mkDerivation (finalAttrs: { runHook postBuild ''; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/sx/sxhkd/package.nix b/pkgs/by-name/sx/sxhkd/package.nix index 2ae07339b42091..f2093f835c1327 100644 --- a/pkgs/by-name/sx/sxhkd/package.nix +++ b/pkgs/by-name/sx/sxhkd/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, asciidoc -, libxcb -, xcbutil -, xcbutilkeysyms -, xcbutilwm +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + asciidoc, + libxcb, + xcbutil, + xcbutilkeysyms, + xcbutilwm, }: stdenv.mkDerivation (finalAttrs: { @@ -29,7 +30,11 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; nativeBuildInputs = [ asciidoc @@ -51,7 +56,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/baskerville/sxhkd"; license = lib.licenses.bsd2; mainProgram = "sxhkd"; - maintainers = with lib.maintainers; [ vyp ncfavier ]; + maintainers = with lib.maintainers; [ + vyp + ncfavier + ]; inherit (libxcb.meta) platforms; }; }) diff --git a/pkgs/by-name/sy/sycl-info/package.nix b/pkgs/by-name/sy/sycl-info/package.nix index e0c4296cb27732..9eb73919e1b467 100644 --- a/pkgs/by-name/sy/sycl-info/package.nix +++ b/pkgs/by-name/sy/sycl-info/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, ninja -, ocl-icd -, opencl-headers -, lyra -, nlohmann_json -, ronn -, doctest +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + ocl-icd, + opencl-headers, + lyra, + nlohmann_json, + ronn, + doctest, }: stdenv.mkDerivation rec { @@ -45,13 +47,12 @@ stdenv.mkDerivation rec { # Required for ronn to compile the manpage. RUBYOPT = "-KU -E utf-8:utf-8"; - meta = with lib; - { - homepage = "https://github.com/codeplaysoftware/sycl-info"; - description = "Tool to show information about available SYCL implementations"; - mainProgram = "sycl-info"; - platforms = platforms.linux; - license = licenses.asl20; - maintainers = with maintainers; [ davidtwco ]; - }; + meta = with lib; { + homepage = "https://github.com/codeplaysoftware/sycl-info"; + description = "Tool to show information about available SYCL implementations"; + mainProgram = "sycl-info"; + platforms = platforms.linux; + license = licenses.asl20; + maintainers = with maintainers; [ davidtwco ]; + }; } diff --git a/pkgs/by-name/sy/sylk/package.nix b/pkgs/by-name/sy/sylk/package.nix index ab32ef5463ff26..e124556188fac3 100644 --- a/pkgs/by-name/sy/sylk/package.nix +++ b/pkgs/by-name/sy/sylk/package.nix @@ -1,4 +1,8 @@ -{ appimageTools, fetchurl, lib }: +{ + appimageTools, + fetchurl, + lib, +}: appimageTools.wrapType2 rec { pname = "sylk"; @@ -19,7 +23,10 @@ appimageTools.wrapType2 rec { license = lib.licenses.agpl3Plus; mainProgram = "Sylk"; maintainers = with lib.maintainers; [ zimbatm ]; - platforms = [ "i386-linux" "x86_64-linux" ]; + platforms = [ + "i386-linux" + "x86_64-linux" + ]; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; }; } diff --git a/pkgs/by-name/sy/symbolic-preview/package.nix b/pkgs/by-name/sy/symbolic-preview/package.nix index 46f654b95600e8..e49a98c0286430 100644 --- a/pkgs/by-name/sy/symbolic-preview/package.nix +++ b/pkgs/by-name/sy/symbolic-preview/package.nix @@ -1,6 +1,18 @@ -{ lib, stdenv, fetchurl, wrapGAppsHook4 -, cargo, desktop-file-utils, meson, ninja, pkg-config, rustc -, glib, gtk4, libadwaita, libxml2 +{ + lib, + stdenv, + fetchurl, + wrapGAppsHook4, + cargo, + desktop-file-utils, + meson, + ninja, + pkg-config, + rustc, + glib, + gtk4, + libadwaita, + libxml2, }: stdenv.mkDerivation rec { @@ -13,9 +25,20 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - cargo desktop-file-utils meson ninja pkg-config rustc wrapGAppsHook4 + cargo + desktop-file-utils + meson + ninja + pkg-config + rustc + wrapGAppsHook4 + ]; + buildInputs = [ + glib + gtk4 + libadwaita + libxml2 ]; - buildInputs = [ glib gtk4 libadwaita libxml2 ]; meta = with lib; { homepage = "https://gitlab.gnome.org/World/design/symbolic-preview"; diff --git a/pkgs/by-name/sy/symbolicator/package.nix b/pkgs/by-name/sy/symbolicator/package.nix index 473f9d64d652a1..5ed87d3f18e7cd 100644 --- a/pkgs/by-name/sy/symbolicator/package.nix +++ b/pkgs/by-name/sy/symbolicator/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, bzip2 -, openssl -, zstd -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + bzip2, + openssl, + zstd, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -34,14 +35,16 @@ rustPlatform.buildRustPackage rec { rustPlatform.bindgenHook ]; - buildInputs = [ - bzip2 - openssl - zstd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + bzip2 + openssl + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; env = { SYMBOLICATOR_GIT_VERSION = src.rev; diff --git a/pkgs/by-name/sy/symengine/package.nix b/pkgs/by-name/sy/symengine/package.nix index 9d6ef0f2404c98..d7468c70aa2935 100644 --- a/pkgs/by-name/sy/symengine/package.nix +++ b/pkgs/by-name/sy/symengine/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gmp -, flint -, mpfr -, libmpc -, withShared ? true +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gmp, + flint, + mpfr, + libmpc, + withShared ? true, }: stdenv.mkDerivation rec { @@ -22,21 +23,29 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ gmp flint mpfr libmpc ]; - - cmakeFlags = [ - "-DWITH_FLINT=ON" - "-DINTEGER_CLASS=flint" - "-DWITH_SYMENGINE_THREAD_SAFE=yes" - "-DWITH_MPC=yes" - "-DBUILD_FOR_DISTRIBUTION=yes" - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - # error: unrecognized instruction mnemonic, did you mean: bit, cnt, hint, ins, not? - "-DBUILD_TESTS=OFF" - ] ++ lib.optionals withShared [ - "-DBUILD_SHARED_LIBS=ON" + buildInputs = [ + gmp + flint + mpfr + libmpc ]; + cmakeFlags = + [ + "-DWITH_FLINT=ON" + "-DINTEGER_CLASS=flint" + "-DWITH_SYMENGINE_THREAD_SAFE=yes" + "-DWITH_MPC=yes" + "-DBUILD_FOR_DISTRIBUTION=yes" + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + # error: unrecognized instruction mnemonic, did you mean: bit, cnt, hint, ins, not? + "-DBUILD_TESTS=OFF" + ] + ++ lib.optionals withShared [ + "-DBUILD_SHARED_LIBS=ON" + ]; + doCheck = true; meta = with lib; { diff --git a/pkgs/by-name/sy/symfony-cli/package.nix b/pkgs/by-name/sy/symfony-cli/package.nix index ec3ad41db20ab8..50842e433ca28a 100644 --- a/pkgs/by-name/sy/symfony-cli/package.nix +++ b/pkgs/by-name/sy/symfony-cli/package.nix @@ -1,11 +1,12 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, nix-update-script -, testers -, symfony-cli -, nssTools -, makeBinaryWrapper +{ + buildGoModule, + fetchFromGitHub, + lib, + nix-update-script, + testers, + symfony-cli, + nssTools, + makeBinaryWrapper, }: buildGoModule rec { diff --git a/pkgs/by-name/sy/symfpu/package.nix b/pkgs/by-name/sy/symfpu/package.nix index 2c83793114a15b..f4ba9d4f455884 100644 --- a/pkgs/by-name/sy/symfpu/package.nix +++ b/pkgs/by-name/sy/symfpu/package.nix @@ -1,13 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, copyPkgconfigItems, makePkgconfigItem }: +{ + lib, + stdenv, + fetchFromGitHub, + copyPkgconfigItems, + makePkgconfigItem, +}: stdenv.mkDerivation rec { pname = "symfpu"; version = "unstable-2019-05-17"; src = fetchFromGitHub { - owner = "martin-cs"; - repo = "symfpu"; - rev = "8fbe139bf0071cbe0758d2f6690a546c69ff0053"; + owner = "martin-cs"; + repo = "symfpu"; + rev = "8fbe139bf0071cbe0758d2f6690a546c69ff0053"; sha256 = "1jf5lkn67q136ppfacw3lsry369v7mdr1rhidzjpbz18jfy9zl9q"; }; @@ -41,9 +47,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "A (concrete or symbolic) implementation of IEEE-754 / SMT-LIB floating-point"; - homepage = "https://github.com/martin-cs/symfpu"; - license = licenses.gpl3Only; - platforms = platforms.unix; + homepage = "https://github.com/martin-cs/symfpu"; + license = licenses.gpl3Only; + platforms = platforms.unix; maintainers = with maintainers; [ shadaj ]; }; } diff --git a/pkgs/by-name/sy/symlinks/package.nix b/pkgs/by-name/sy/symlinks/package.nix index 7ca0503676c333..c5709e86c11001 100644 --- a/pkgs/by-name/sy/symlinks/package.nix +++ b/pkgs/by-name/sy/symlinks/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, lib, stdenv }: +{ + fetchFromGitHub, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "symlinks"; diff --git a/pkgs/by-name/sy/symmetrica/package.nix b/pkgs/by-name/sy/symmetrica/package.nix index f215ec0037d49e..e578ccc91e8cda 100644 --- a/pkgs/by-name/sy/symmetrica/package.nix +++ b/pkgs/by-name/sy/symmetrica/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitLab -, autoreconfHook +{ + stdenv, + lib, + fetchFromGitLab, + autoreconfHook, }: stdenv.mkDerivation rec { pname = "symmetrica"; diff --git a/pkgs/by-name/sy/sympa/package.nix b/pkgs/by-name/sy/sympa/package.nix index f431278de4d173..bbab3ac4f5d675 100644 --- a/pkgs/by-name/sy/sympa/package.nix +++ b/pkgs/by-name/sy/sympa/package.nix @@ -1,63 +1,72 @@ -{ lib, stdenv, perl, fetchFromGitHub, autoreconfHook, nixosTests }: +{ + lib, + stdenv, + perl, + fetchFromGitHub, + autoreconfHook, + nixosTests, +}: let dataDir = "/var/lib/sympa"; runtimeDir = "/run/sympa"; - perlEnv = perl.withPackages (p: with p; [ - ArchiveZip - CGI - CGIFast - ClassSingleton - DateTime - DBI - DateTimeFormatMail - DateTimeTimeZone - Encode - FCGI - FileCopyRecursive - FileNFSLock - FilePath - HTMLParser - HTMLFormatter - HTMLTree - HTMLStripScriptsParser - IO - IOStringy - LWP - libintl-perl + perlEnv = perl.withPackages ( + p: with p; [ + ArchiveZip + CGI + CGIFast + ClassSingleton + DateTime + DBI + DateTimeFormatMail + DateTimeTimeZone + Encode + FCGI + FileCopyRecursive + FileNFSLock + FilePath + HTMLParser + HTMLFormatter + HTMLTree + HTMLStripScriptsParser + IO + IOStringy + LWP + libintl-perl - MHonArc - MIMECharset - MIMETools - MIMEEncWords - MIMELiteHTML - MailTools - NetCIDR - ScalarListUtils - SysSyslog - TermProgressBar - TemplateToolkit - URI - UnicodeLineBreak - XMLLibXML + MHonArc + MIMECharset + MIMETools + MIMEEncWords + MIMELiteHTML + MailTools + NetCIDR + ScalarListUtils + SysSyslog + TermProgressBar + TemplateToolkit + URI + UnicodeLineBreak + XMLLibXML - ### Features - Clone - CryptEksblowfish + ### Features + Clone + CryptEksblowfish - DBDPg - DBDSQLite - DBDmysql + DBDPg + DBDSQLite + DBDmysql - DataPassword - EncodeLocale - IOSocketSSL - MailDKIM - NetDNS - perlldap - libnet - SOAPLite - ]); + DataPassword + EncodeLocale + IOSocketSSL + MailDKIM + NetDNS + perlldap + libnet + SOAPLite + ] + ); in stdenv.mkDerivation rec { pname = "sympa"; @@ -112,7 +121,10 @@ stdenv.mkDerivation rec { description = "Open source mailing list manager"; homepage = "https://www.sympa.org"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ sorki mmilata ]; + maintainers = with maintainers; [ + sorki + mmilata + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/sy/symphony/package.nix b/pkgs/by-name/sy/symphony/package.nix index 37ac2e58a213bf..dad1a903dcefb4 100644 --- a/pkgs/by-name/sy/symphony/package.nix +++ b/pkgs/by-name/sy/symphony/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, coin-utils -, coinmp -, gfortran -, libtool -, glpk -, osi -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + coin-utils, + coinmp, + gfortran, + libtool, + glpk, + osi, + pkg-config, }: stdenv.mkDerivation rec { @@ -23,7 +24,15 @@ stdenv.mkDerivation rec { hash = "sha256-OdTUMG3iVhjhw5uKtUnsLCZ4DfMjYHm8+/ozfmw7J6c="; }; - nativeBuildInputs = [ libtool pkg-config glpk gfortran coinmp osi coin-utils ]; + nativeBuildInputs = [ + libtool + pkg-config + glpk + gfortran + coinmp + osi + coin-utils + ]; meta = { description = "SYMPHONY is an open-source solver, callable library, and development framework for mixed-integer linear programs (MILPs) written in C with a number of unique features"; diff --git a/pkgs/by-name/sy/syn2mas/package.nix b/pkgs/by-name/sy/syn2mas/package.nix index 667134361d53f8..c39aa512aa43a1 100644 --- a/pkgs/by-name/sy/syn2mas/package.nix +++ b/pkgs/by-name/sy/syn2mas/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/sy/synaesthesia/package.nix b/pkgs/by-name/sy/synaesthesia/package.nix index c8575d77b50fa2..24cbbb65d8ddd3 100644 --- a/pkgs/by-name/sy/synaesthesia/package.nix +++ b/pkgs/by-name/sy/synaesthesia/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchzip -, SDL -, pkg-config -, libSM +{ + stdenv, + lib, + fetchzip, + SDL, + pkg-config, + libSM, }: stdenv.mkDerivation rec { pname = "synaesthesia"; diff --git a/pkgs/by-name/sy/synapse-admin/package.nix b/pkgs/by-name/sy/synapse-admin/package.nix index 250a0721f56b41..e3423b60cf218e 100644 --- a/pkgs/by-name/sy/synapse-admin/package.nix +++ b/pkgs/by-name/sy/synapse-admin/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, fetchYarnDeps -, mkYarnPackage -, baseUrl ? null -, writeShellScriptBin +{ + lib, + fetchFromGitHub, + fetchYarnDeps, + mkYarnPackage, + baseUrl ? null, + writeShellScriptBin, }: mkYarnPackage rec { @@ -58,6 +59,9 @@ mkYarnPackage rec { homepage = "https://github.com/Awesome-Technologies/synapse-admin"; license = licenses.asl20; platforms = platforms.all; - maintainers = with maintainers; [ mkg20001 ma27 ]; + maintainers = with maintainers; [ + mkg20001 + ma27 + ]; }; } diff --git a/pkgs/by-name/sy/synapse/package.nix b/pkgs/by-name/sy/synapse/package.nix index 1491a4e812911f..0ab4e2326c5c7e 100644 --- a/pkgs/by-name/sy/synapse/package.nix +++ b/pkgs/by-name/sy/synapse/package.nix @@ -1,10 +1,24 @@ -{ lib, stdenv, fetchurl, gettext, pkg-config, glib, libnotify, gtk3, libgee -, keybinder3, json-glib, zeitgeist, vala, gobject-introspection +{ + lib, + stdenv, + fetchurl, + gettext, + pkg-config, + glib, + libnotify, + gtk3, + libgee, + keybinder3, + json-glib, + zeitgeist, + vala, + gobject-introspection, }: let version = "0.2.99.4"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "synapse"; inherit version; @@ -14,12 +28,20 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ - pkg-config gettext vala + pkg-config + gettext + vala # For setup hook gobject-introspection ]; buildInputs = [ - glib libnotify gtk3 libgee keybinder3 json-glib zeitgeist + glib + libnotify + gtk3 + libgee + keybinder3 + json-glib + zeitgeist ]; meta = with lib; { diff --git a/pkgs/by-name/sy/syncall/package.nix b/pkgs/by-name/sy/syncall/package.nix index 1e6392c9e6d0ce..9cfcd9599b05de 100644 --- a/pkgs/by-name/sy/syncall/package.nix +++ b/pkgs/by-name/sy/syncall/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/sy/syncrclone/package.nix b/pkgs/by-name/sy/syncrclone/package.nix index b4a24b57460854..d5fd5968f0e94d 100644 --- a/pkgs/by-name/sy/syncrclone/package.nix +++ b/pkgs/by-name/sy/syncrclone/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/sy/syncstorage-rs/package.nix b/pkgs/by-name/sy/syncstorage-rs/package.nix index fb8af72234cbcd..a1012300e61e40 100644 --- a/pkgs/by-name/sy/syncstorage-rs/package.nix +++ b/pkgs/by-name/sy/syncstorage-rs/package.nix @@ -1,12 +1,13 @@ -{ fetchFromGitHub -, rustPlatform -, pkg-config -, python3 -, cmake -, libmysqlclient -, makeBinaryWrapper -, lib -, nix-update-script +{ + fetchFromGitHub, + rustPlatform, + pkg-config, + python3, + cmake, + libmysqlclient, + makeBinaryWrapper, + lib, + nix-update-script, }: let @@ -56,7 +57,7 @@ rustPlatform.buildRustPackage rec { # almost all tests need a DB to test against doCheck = false; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = { description = "Mozilla Sync Storage built with Rust"; diff --git a/pkgs/by-name/sy/syncterm/package.nix b/pkgs/by-name/sy/syncterm/package.nix index 60b172184fc996..12aff4b8ccb22b 100644 --- a/pkgs/by-name/sy/syncterm/package.nix +++ b/pkgs/by-name/sy/syncterm/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, perl, unzip, autoPatchelfHook, ncurses, SDL2, alsa-lib }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + perl, + unzip, + autoPatchelfHook, + ncurses, + SDL2, + alsa-lib, +}: stdenv.mkDerivation rec { pname = "syncterm"; @@ -13,37 +25,51 @@ stdenv.mkDerivation rec { # Cherry-picks from the upstream Synchronet tree, removing calls to `pthread_yield`. # See upstream issue: https://gitlab.synchro.net/main/sbbs/-/issues/299 (fetchpatch { - url = "https://gitlab.synchro.net/main/sbbs/-/commit/851627df99f48d8eaad33d3a98ef309b4371f359.patch"; - hash = "sha256-DbFAeJnrwFyfEpZgZFN8etqX6vQ3ca2TJwaqp0aHeo4="; + url = "https://gitlab.synchro.net/main/sbbs/-/commit/851627df99f48d8eaad33d3a98ef309b4371f359.patch"; + hash = "sha256-DbFAeJnrwFyfEpZgZFN8etqX6vQ3ca2TJwaqp0aHeo4="; }) ./0001-use-sched-yield-53264f2b.patch ]; # We can't use sourceRoot, as the cherry-picked patches apply to files outside of it. postPatch = ''cd src/syncterm''; - CFLAGS = [ - "-DHAS_INTTYPES_H" - "-DXPDEV_DONT_DEFINE_INTTYPES" + CFLAGS = + [ + "-DHAS_INTTYPES_H" + "-DXPDEV_DONT_DEFINE_INTTYPES" - "-Wno-unused-result" - "-Wformat-overflow=0" - ] ++ (lib.optionals stdenv.hostPlatform.isLinux [ - "-DUSE_ALSA_SOUND" # Don't use OSS for beeps. - ]); + "-Wno-unused-result" + "-Wformat-overflow=0" + ] + ++ (lib.optionals stdenv.hostPlatform.isLinux [ + "-DUSE_ALSA_SOUND" # Don't use OSS for beeps. + ]); makeFlags = [ "PREFIX=$(out)" "RELEASE=1" "USE_SDL_AUDIO=1" ]; - nativeBuildInputs = [ autoPatchelfHook pkg-config SDL2 perl unzip ]; # SDL2 for `sdl2-config`. - buildInputs = [ ncurses SDL2 ] - ++ (lib.optional stdenv.hostPlatform.isLinux alsa-lib); - runtimeDependencies = [ ncurses SDL2 ]; # Both of these are dlopen()'ed at runtime. + nativeBuildInputs = [ + autoPatchelfHook + pkg-config + SDL2 + perl + unzip + ]; # SDL2 for `sdl2-config`. + buildInputs = [ + ncurses + SDL2 + ] ++ (lib.optional stdenv.hostPlatform.isLinux alsa-lib); + runtimeDependencies = [ + ncurses + SDL2 + ]; # Both of these are dlopen()'ed at runtime. meta = with lib; { # error: unsupported option '-fsanitize=safe-stack' for target 'x86_64-apple-darwin' - broken = (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) || stdenv.hostPlatform.isDarwin; + broken = + (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) || stdenv.hostPlatform.isDarwin; homepage = "https://syncterm.bbsdev.net/"; description = "BBS terminal emulator"; mainProgram = "syncterm"; diff --git a/pkgs/by-name/sy/syncyomi/package.nix b/pkgs/by-name/sy/syncyomi/package.nix index 96bb04803eeb84..d12b3800432084 100644 --- a/pkgs/by-name/sy/syncyomi/package.nix +++ b/pkgs/by-name/sy/syncyomi/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, buildGoModule -, nodejs -, pnpm_9 -, esbuild +{ + lib, + stdenvNoCC, + fetchFromGitHub, + buildGoModule, + nodejs, + pnpm_9, + esbuild, }: buildGoModule rec { @@ -26,7 +27,12 @@ buildGoModule rec { sourceRoot = "${finalAttrs.src.name}/web"; pnpmDeps = pnpm_9.fetchDeps { - inherit (finalAttrs) pname version src sourceRoot; + inherit (finalAttrs) + pname + version + src + sourceRoot + ; hash = "sha256-edcZIqshnvM3jJpZWIR/UncI0VCMLq26h/n3VvV/384="; }; @@ -35,18 +41,25 @@ buildGoModule rec { pnpm_9.configHook ]; - env.ESBUILD_BINARY_PATH = lib.getExe (esbuild.override { - buildGoModule = args: buildGoModule (args // rec { - version = "0.17.19"; - src = fetchFromGitHub { - owner = "evanw"; - repo = "esbuild"; - rev = "v${version}"; - hash = "sha256-PLC7OJLSOiDq4OjvrdfCawZPfbfuZix4Waopzrj8qsU="; - }; - vendorHash = "sha256-+BfxCyg0KkDQpHt/wycy/8CTG6YBA/VJvJFhhzUnSiQ="; - }); - }); + env.ESBUILD_BINARY_PATH = lib.getExe ( + esbuild.override { + buildGoModule = + args: + buildGoModule ( + args + // rec { + version = "0.17.19"; + src = fetchFromGitHub { + owner = "evanw"; + repo = "esbuild"; + rev = "v${version}"; + hash = "sha256-PLC7OJLSOiDq4OjvrdfCawZPfbfuZix4Waopzrj8qsU="; + }; + vendorHash = "sha256-+BfxCyg0KkDQpHt/wycy/8CTG6YBA/VJvJFhhzUnSiQ="; + } + ); + } + ); buildPhase = '' runHook preBuild @@ -66,7 +79,8 @@ buildGoModule rec { ''; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X main.version=v${version}" ]; diff --git a/pkgs/by-name/sy/syndication-domination/package.nix b/pkgs/by-name/sy/syndication-domination/package.nix index 10e325d8564253..6bb68402dc95c6 100644 --- a/pkgs/by-name/sy/syndication-domination/package.nix +++ b/pkgs/by-name/sy/syndication-domination/package.nix @@ -8,7 +8,7 @@ pugixml, fmt, html-tidy, - enablePython? false, + enablePython ? false, python3Packages, }: @@ -30,14 +30,16 @@ stdenv.mkDerivation { pkg-config ]; - buildInputs = [ - pugixml - fmt - html-tidy - ] ++ lib.optionals enablePython [ - python3Packages.python - python3Packages.pybind11 - ]; + buildInputs = + [ + pugixml + fmt + html-tidy + ] + ++ lib.optionals enablePython [ + python3Packages.python + python3Packages.pybind11 + ]; mesonFlags = [ (lib.mesonBool "TO_JSON_BINARY" true) diff --git a/pkgs/by-name/sy/synfigstudio/package.nix b/pkgs/by-name/sy/synfigstudio/package.nix index 79ad559a5f3833..3d5cee8a5931f9 100644 --- a/pkgs/by-name/sy/synfigstudio/package.nix +++ b/pkgs/by-name/sy/synfigstudio/package.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, autoreconfHook -, wrapGAppsHook3 - -, boost -, cairo -, darwin -, gettext -, glibmm -, gtk3 -, gtkmm3 -, libjack2 -, libsigcxx -, libxmlxx -, mlt -, pango -, imagemagick -, intltool -, adwaita-icon-theme -, harfbuzz -, freetype -, fribidi -, openexr -, fftw +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + wrapGAppsHook3, + + boost, + cairo, + darwin, + gettext, + glibmm, + gtk3, + gtkmm3, + libjack2, + libsigcxx, + libxmlxx, + mlt, + pango, + imagemagick, + intltool, + adwaita-icon-theme, + harfbuzz, + freetype, + fribidi, + openexr, + fftw, }: let @@ -57,14 +58,16 @@ let sourceRoot = "${src.name}/synfig-core"; - configureFlags = [ - "--with-boost=${boost.dev}" - "--with-boost-libdir=${boost.out}/lib" - ] ++ lib.optionals stdenv.cc.isClang [ - # Newer versions of clang default to C++17, but synfig and some of its dependencies use deprecated APIs that - # are removed in C++17. Setting the language version to C++14 allows it to build. - "CXXFLAGS=-std=c++14" - ]; + configureFlags = + [ + "--with-boost=${boost.dev}" + "--with-boost-libdir=${boost.out}/lib" + ] + ++ lib.optionals stdenv.cc.isClang [ + # Newer versions of clang default to C++17, but synfig and some of its dependencies use deprecated APIs that + # are removed in C++17. Setting the language version to C++14 allows it to build. + "CXXFLAGS=-std=c++14" + ]; enableParallelBuilding = true; @@ -74,24 +77,26 @@ let gettext intltool ]; - buildInputs = [ - ETL - boost - cairo - glibmm - mlt - libsigcxx - libxmlxx - pango - imagemagick - harfbuzz - freetype - fribidi - openexr - fftw - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + ETL + boost + cairo + glibmm + mlt + libsigcxx + libxmlxx + pango + imagemagick + harfbuzz + freetype + fribidi + openexr + fftw + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ]; }; in stdenv.mkDerivation { diff --git a/pkgs/by-name/sy/synology-cloud-sync-decryption-tool/package.nix b/pkgs/by-name/sy/synology-cloud-sync-decryption-tool/package.nix index 0872391e6035c6..24dbcefe6045d6 100644 --- a/pkgs/by-name/sy/synology-cloud-sync-decryption-tool/package.nix +++ b/pkgs/by-name/sy/synology-cloud-sync-decryption-tool/package.nix @@ -1,4 +1,10 @@ -{ lib, writeScript, qt5, fetchurl, autoPatchelfHook }: +{ + lib, + writeScript, + qt5, + fetchurl, + autoPatchelfHook, +}: qt5.mkDerivation rec { pname = "synology-cloud-sync-decryption-tool"; diff --git a/pkgs/by-name/sy/synology-drive-client/package.nix b/pkgs/by-name/sy/synology-drive-client/package.nix index 69f7b4d153c58d..dcf40bf80a67d4 100644 --- a/pkgs/by-name/sy/synology-drive-client/package.nix +++ b/pkgs/by-name/sy/synology-drive-client/package.nix @@ -1,4 +1,19 @@ -{ stdenv, lib, writeScript, qt5, fetchurl, autoPatchelfHook, dpkg, glibc, cpio, xar, undmg, gtk3, pango, libxcb }: +{ + stdenv, + lib, + writeScript, + qt5, + fetchurl, + autoPatchelfHook, + dpkg, + glibc, + cpio, + xar, + undmg, + gtk3, + pango, + libxcb, +}: let pname = "synology-drive-client"; baseUrl = "https://global.synologydownload.com/download/Utility/SynologyDriveClient"; @@ -9,8 +24,15 @@ let homepage = "https://www.synology.com/en-global/dsm/feature/drive"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - maintainers = with maintainers; [ jcouyang MoritzBoehme ]; - platforms = [ "x86_64-linux" "x86_64-darwin" "aarch64-darwin" ]; + maintainers = with maintainers; [ + jcouyang + MoritzBoehme + ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; mainProgram = "synology-drive"; }; passthru.updateScript = writeScript "update-synology-drive-client" '' @@ -26,16 +48,30 @@ let ''; linux = stdenv.mkDerivation { - inherit pname version meta passthru; + inherit + pname + version + meta + passthru + ; src = fetchurl { url = "${baseUrl}/${version}/Ubuntu/Installer/synology-drive-client-${buildNumber}.x86_64.deb"; sha256 = "sha256-VeS5bPcMM4JDCSH5GXkl4OgQjrPKaNDh5PfX28/zqaU="; }; - nativeBuildInputs = [ qt5.wrapQtAppsHook autoPatchelfHook dpkg ]; + nativeBuildInputs = [ + qt5.wrapQtAppsHook + autoPatchelfHook + dpkg + ]; - buildInputs = [ glibc gtk3 pango libxcb ]; + buildInputs = [ + glibc + gtk3 + pango + libxcb + ]; unpackPhase = '' mkdir -p $out @@ -56,14 +92,23 @@ let }; darwin = stdenv.mkDerivation { - inherit pname version meta passthru; + inherit + pname + version + meta + passthru + ; src = fetchurl { url = "${baseUrl}/${version}/Mac/Installer/synology-drive-client-${buildNumber}.dmg"; sha256 = "sha256-VyhROpQCeVHNxxYgPUZdAlng15aJ1/IYadz30FThlsw="; }; - nativeBuildInputs = [ cpio xar undmg ]; + nativeBuildInputs = [ + cpio + xar + undmg + ]; postUnpack = '' xar -xf 'Install Synology Drive Client.pkg' @@ -78,4 +123,5 @@ let cp -R 'Synology Drive Client.app' $out/Applications/ ''; }; -in if stdenv.hostPlatform.isDarwin then darwin else linux +in +if stdenv.hostPlatform.isDarwin then darwin else linux diff --git a/pkgs/by-name/sy/syntax/package.nix b/pkgs/by-name/sy/syntax/package.nix index 01b5ade160fbfc..8dffc4b6ed9eaa 100644 --- a/pkgs/by-name/sy/syntax/package.nix +++ b/pkgs/by-name/sy/syntax/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildNpmPackage -, stdenv -, nix-update-script +{ + lib, + fetchFromGitHub, + buildNpmPackage, + stdenv, + nix-update-script, }: buildNpmPackage rec { diff --git a/pkgs/by-name/sy/syntex/package.nix b/pkgs/by-name/sy/syntex/package.nix index b149333f2eac6f..196825716ba0d1 100644 --- a/pkgs/by-name/sy/syntex/package.nix +++ b/pkgs/by-name/sy/syntex/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchFromGitHub, mono}: +{ + lib, + stdenv, + fetchFromGitHub, + mono, +}: stdenv.mkDerivation rec { pname = "syntex"; version = "0.0pre20160915"; @@ -23,11 +28,11 @@ stdenv.mkDerivation rec { echo "'${mono}/bin/mono' '$out/bin/syntex.exe' \"\$@\"" >> "$out/bin/syntex" chmod a+x "$out/bin/syntex" ''; - buildInputs = [mono]; + buildInputs = [ mono ]; meta = { description = "Texture synthesis from examples"; license = lib.licenses.mit; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/sy/synthesia/package.nix b/pkgs/by-name/sy/synthesia/package.nix index 78c82dd010ddf7..5667962fb0ddfa 100644 --- a/pkgs/by-name/sy/synthesia/package.nix +++ b/pkgs/by-name/sy/synthesia/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchurl -, stdenvNoCC -, runtimeShell -, copyDesktopItems -, makeDesktopItem -, wineWowPackages +{ + lib, + fetchurl, + stdenvNoCC, + runtimeShell, + copyDesktopItems, + makeDesktopItem, + wineWowPackages, }: let @@ -25,7 +26,10 @@ stdenvNoCC.mkDerivation rec { comment = meta.description; exec = "synthesia"; icon = "synthesia"; - categories = [ "Game" "Audio" ]; + categories = [ + "Game" + "Audio" + ]; startupWMClass = "synthesia.exe"; }) ]; diff --git a/pkgs/by-name/sy/sysbench/package.nix b/pkgs/by-name/sy/sysbench/package.nix index 955a0296b72f66..873932a81805c0 100644 --- a/pkgs/by-name/sy/sysbench/package.nix +++ b/pkgs/by-name/sy/sysbench/package.nix @@ -1,22 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libmysqlclient -, libaio -, luajit -# For testing: -, testers -, sysbench +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libmysqlclient, + libaio, + luajit, + # For testing: + testers, + sysbench, }: stdenv.mkDerivation rec { pname = "sysbench"; version = "1.0.20"; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libmysqlclient luajit ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libaio ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libmysqlclient + luajit + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libaio ]; depsBuildBuild = [ pkg-config ]; src = fetchFromGitHub { @@ -45,7 +52,14 @@ stdenv.mkDerivation rec { third_party/concurrency_kit/ck/configure \ --replace-fail \ 'COMPILER=`./.1 2> /dev/null`' \ - "COMPILER=${if stdenv.cc.isGNU then "gcc" else if stdenv.cc.isClang then "clang" else throw "Unsupported compiler"}" \ + "COMPILER=${ + if stdenv.cc.isGNU then + "gcc" + else if stdenv.cc.isClang then + "clang" + else + throw "Unsupported compiler" + }" \ --replace-fail \ 'PLATFORM=`uname -m 2> /dev/null`' \ "PLATFORM=${stdenv.hostPlatform.parsed.cpu.name}" diff --git a/pkgs/by-name/sy/syscall_limiter/package.nix b/pkgs/by-name/sy/syscall_limiter/package.nix index 329ec522c422ee..97a279431df4fb 100644 --- a/pkgs/by-name/sy/syscall_limiter/package.nix +++ b/pkgs/by-name/sy/syscall_limiter/package.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, libseccomp -, perl -, which +{ + lib, + stdenv, + fetchFromGitHub, + libseccomp, + perl, + which, }: stdenv.mkDerivation { @@ -10,9 +12,9 @@ stdenv.mkDerivation { version = "2017-01-23"; src = fetchFromGitHub { - owner = "vi"; - repo = "syscall_limiter"; - rev = "481c8c883f2e1260ebc83b352b63bf61a930a341"; + owner = "vi"; + repo = "syscall_limiter"; + rev = "481c8c883f2e1260ebc83b352b63bf61a930a341"; sha256 = "0z5arj1kq1xczgrbw1b8m9kicbv3vs9bd32wvgfr4r6ndingsp5m"; }; @@ -29,9 +31,9 @@ stdenv.mkDerivation { meta = with lib; { description = "Start Linux programs with only selected syscalls enabled"; - homepage = "https://github.com/vi/syscall_limiter"; - license = licenses.mit; + homepage = "https://github.com/vi/syscall_limiter"; + license = licenses.mit; maintainers = with maintainers; [ obadz ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/sy/sysfsutils/package.nix b/pkgs/by-name/sy/sysfsutils/package.nix index b0fd24c066b32a..2935c5b04a64be 100644 --- a/pkgs/by-name/sy/sysfsutils/package.nix +++ b/pkgs/by-name/sy/sysfsutils/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "sysfsutils"; @@ -11,13 +15,15 @@ stdenv.mkDerivation rec { meta = { homepage = "https://linux-diag.sourceforge.net/Sysfsutils.html"; - longDescription = - '' - These are a set of utilites built upon sysfs, a new virtual - filesystem in Linux kernel versions 2.5+ that exposes a system's - device tree. - ''; - license = with lib.licenses; [ gpl2Plus lgpl21 ]; + longDescription = '' + These are a set of utilites built upon sysfs, a new virtual + filesystem in Linux kernel versions 2.5+ that exposes a system's + device tree. + ''; + license = with lib.licenses; [ + gpl2Plus + lgpl21 + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/sy/sysklogd/package.nix b/pkgs/by-name/sy/sysklogd/package.nix index cfccba6fb542ce..b5608c51e3788e 100644 --- a/pkgs/by-name/sy/sysklogd/package.nix +++ b/pkgs/by-name/sy/sysklogd/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "sysklogd"; @@ -9,11 +13,19 @@ stdenv.mkDerivation rec { sha256 = "00f2wy6f0qng7qzga4iicyzl9j8b7mp6mrpfky5jxj93ms2w2rji"; }; - patches = [ ./systemd.patch ./union-wait.patch ./fix-includes-for-musl.patch ]; + patches = [ + ./systemd.patch + ./union-wait.patch + ./fix-includes-for-musl.patch + ]; env.NIX_CFLAGS_COMPILE = "-DSYSV"; - installFlags = [ "BINDIR=$(out)/sbin" "MANDIR=$(out)/share/man" "INSTALL=install" ]; + installFlags = [ + "BINDIR=$(out)/sbin" + "MANDIR=$(out)/share/man" + "INSTALL=install" + ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" @@ -26,10 +38,9 @@ stdenv.mkDerivation rec { --replace "-m 500 -s" "-m 500" ''; - preConfigure = - '' - sed -e 's@-o \''${MAN_USER} -g \''${MAN_GROUP} -m \''${MAN_PERMS} @@' -i Makefile - ''; + preConfigure = '' + sed -e 's@-o \''${MAN_USER} -g \''${MAN_GROUP} -m \''${MAN_PERMS} @@' -i Makefile + ''; preInstall = "mkdir -p $out/share/man/man5/ $out/share/man/man8/ $out/sbin"; diff --git a/pkgs/by-name/sy/syslinux/package.nix b/pkgs/by-name/sy/syslinux/package.nix index c1424d01f878d1..54a9a5bb11ae79 100644 --- a/pkgs/by-name/sy/syslinux/package.nix +++ b/pkgs/by-name/sy/syslinux/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromRepoOrCz -, gnu-efi -, fetchurl -, fetchpatch -, libuuid -, makeWrapper -, mtools -, nasm -, nixosTests -, perl -, python3 +{ + lib, + stdenv, + fetchFromRepoOrCz, + gnu-efi, + fetchurl, + fetchpatch, + libuuid, + makeWrapper, + mtools, + nasm, + nixosTests, + perl, + python3, }: stdenv.mkDerivation { @@ -25,53 +26,54 @@ stdenv.mkDerivation { hash = "sha256-XNC+X7UYxdMQQAg4MLACQLxRNnI5/ZCOiCJrEkKgPeM="; }; - patches = let - fetchDebianPatch = name: commit: hash: - fetchurl { - url = "https://salsa.debian.org/images-team/syslinux/raw/" - + commit + "/debian/patches/" + name; - inherit name hash; - }; - fetchArchlinuxPatch = name: commit: hash: - fetchurl { - url = "https://raw.githubusercontent.com/archlinux/svntogit-packages/" - + commit + "/trunk/" + name; - inherit name hash; - }; - in [ - ./gcc10.patch - (fetchDebianPatch - "0002-gfxboot-menu-label.patch" - "fa1349f1" - "sha256-0f6QhM4lJmGflLige4n7AZTodL7vnyAvi5dIedd/Lho=") - (fetchArchlinuxPatch - "0005-gnu-efi-version-compatibility.patch" - "821c3da473d1399d930d5b4a086e46a4179eaa45" - "sha256-hhCVnfbAFWj/R4yh60qsMB87ofW9RznarsByhl6L4tc=") - (fetchArchlinuxPatch - "0025-reproducible-build.patch" - "821c3da473d1399d930d5b4a086e46a4179eaa45" - "sha256-mnb291pCSFvDNxY7o4BosJ94ib3BpOGRQIiY8Q3jZmI=") - (fetchDebianPatch - # mbr.bin: too big (452 > 440) - # https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=906414 - "0016-strip-gnu-property.patch" - "7468ef0e38c43" - "sha256-lW+E6THuXlTGvhly0f/D9NwYHhkiKHot2l+bz9Eaxp4=") - (fetchDebianPatch - # mbr.bin: too big (452 > 440) - "0017-single-load-segment.patch" - "012e1dd312eb" - "sha256-C6VmdlTs1blMGUHH3OfOlFBZsfpwRn9vWodwqVn8+Cs=") - (fetchDebianPatch - "0018-prevent-pow-optimization.patch" - "26f0e7b2" - "sha256-dVzXBi/oSV9vYgU85mRFHBKuZdup+1x1BipJX74ED7E=") - # Fixes build with "modern" gnu-efi - ./import-efisetjmp.patch - # Upstream patch: https://www.syslinux.org/archives/2024-February/026903.html - ./define-wchar_t.patch - ]; + patches = + let + fetchDebianPatch = + name: commit: hash: + fetchurl { + url = "https://salsa.debian.org/images-team/syslinux/raw/" + commit + "/debian/patches/" + name; + inherit name hash; + }; + fetchArchlinuxPatch = + name: commit: hash: + fetchurl { + url = "https://raw.githubusercontent.com/archlinux/svntogit-packages/" + commit + "/trunk/" + name; + inherit name hash; + }; + in + [ + ./gcc10.patch + (fetchDebianPatch "0002-gfxboot-menu-label.patch" "fa1349f1" + "sha256-0f6QhM4lJmGflLige4n7AZTodL7vnyAvi5dIedd/Lho=" + ) + (fetchArchlinuxPatch "0005-gnu-efi-version-compatibility.patch" + "821c3da473d1399d930d5b4a086e46a4179eaa45" + "sha256-hhCVnfbAFWj/R4yh60qsMB87ofW9RznarsByhl6L4tc=" + ) + (fetchArchlinuxPatch "0025-reproducible-build.patch" "821c3da473d1399d930d5b4a086e46a4179eaa45" + "sha256-mnb291pCSFvDNxY7o4BosJ94ib3BpOGRQIiY8Q3jZmI=" + ) + (fetchDebianPatch + # mbr.bin: too big (452 > 440) + # https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=906414 + "0016-strip-gnu-property.patch" + "7468ef0e38c43" + "sha256-lW+E6THuXlTGvhly0f/D9NwYHhkiKHot2l+bz9Eaxp4=" + ) + (fetchDebianPatch + # mbr.bin: too big (452 > 440) + "0017-single-load-segment.patch" + "012e1dd312eb" + "sha256-C6VmdlTs1blMGUHH3OfOlFBZsfpwRn9vWodwqVn8+Cs=" + ) + (fetchDebianPatch "0018-prevent-pow-optimization.patch" "26f0e7b2" + "sha256-dVzXBi/oSV9vYgU85mRFHBKuZdup+1x1BipJX74ED7E=" + ) + # Fixes build with "modern" gnu-efi + ./import-efisetjmp.patch + # Upstream patch: https://www.syslinux.org/archives/2024-February/026903.html + ./define-wchar_t.patch + ]; postPatch = '' substituteInPlace Makefile --replace-fail /bin/pwd $(type -P pwd) @@ -97,9 +99,17 @@ stdenv.mkDerivation { # Fails very rarely with 'No rule to make target: ...' enableParallelBuilding = false; - hardeningDisable = [ "pic" "stackprotector" "fortify" ]; + hardeningDisable = [ + "pic" + "stackprotector" + "fortify" + ]; - stripDebugList = [ "bin" "sbin" "share/syslinux/com32" ]; + stripDebugList = [ + "bin" + "sbin" + "share/syslinux/com32" + ]; # Workaround build failure on -fno-common toolchains like upstream # gcc-10. Otherwise build fails as: @@ -107,29 +117,29 @@ stdenv.mkDerivation { # `e820_types'; memory.o:/build/syslinux-b404870/com32/gpllib/../gplinclude/memory.h:40: first defined here env.NIX_CFLAGS_COMPILE = "-fcommon"; - makeFlags = [ - "BINDIR=$(out)/bin" - "SBINDIR=$(out)/sbin" - "DATADIR=$(out)/share" - "MANDIR=$(out)/share/man" - "PERL=perl" - "HEXDATE=0x00000000" - # Works around confusing (unrelated) error messages when upx is not made available - "UPX=false" - - # Configurations needed to make use of external gnu-efi - "LIBEFI=${gnu-efi}/lib/libefi.a" - "LIBDIR=${gnu-efi}/lib/" - "EFIINC=${gnu-efi}/include/efi" - - # Legacy bios boot target is always built - "bios" - ] - # Build "ia32" EFI for i686 - ++ lib.optional stdenv.hostPlatform.isi686 "efi32" - # Build "x86_64" EFI for x86_64 - ++ lib.optional stdenv.hostPlatform.isx86_64 "efi64" - ; + makeFlags = + [ + "BINDIR=$(out)/bin" + "SBINDIR=$(out)/sbin" + "DATADIR=$(out)/share" + "MANDIR=$(out)/share/man" + "PERL=perl" + "HEXDATE=0x00000000" + # Works around confusing (unrelated) error messages when upx is not made available + "UPX=false" + + # Configurations needed to make use of external gnu-efi + "LIBEFI=${gnu-efi}/lib/libefi.a" + "LIBDIR=${gnu-efi}/lib/" + "EFIINC=${gnu-efi}/include/efi" + + # Legacy bios boot target is always built + "bios" + ] + # Build "ia32" EFI for i686 + ++ lib.optional stdenv.hostPlatform.isi686 "efi32" + # Build "x86_64" EFI for x86_64 + ++ lib.optional stdenv.hostPlatform.isx86_64 "efi64"; # Some tests require qemu, some others fail in a sandboxed environment doCheck = false; @@ -149,6 +159,9 @@ stdenv.mkDerivation { description = "Lightweight bootloader"; license = licenses.gpl2Plus; maintainers = [ ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/sy/syslogng/package.nix b/pkgs/by-name/sy/syslogng/package.nix index d70eed9a2f111a..055b5a2b906260 100644 --- a/pkgs/by-name/sy/syslogng/package.nix +++ b/pkgs/by-name/sy/syslogng/package.nix @@ -1,65 +1,67 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf-archive -, autoreconfHook -, bison -, flex -, openssl -, libcap -, curl -, which -, eventlog -, pkg-config -, glib -, hiredis -, systemd -, perl -, python3 -, riemann_c_client -, protobufc -, pcre -, paho-mqtt-c -, python3Packages -, libnet -, json_c -, libuuid -, libivykis -, libxslt -, docbook_xsl -, pcre2 -, mongoc -, rabbitmq-c -, libesmtp -, rdkafka -, gperf -, withGrpc ? true -, grpc -, protobuf +{ + lib, + stdenv, + fetchFromGitHub, + autoconf-archive, + autoreconfHook, + bison, + flex, + openssl, + libcap, + curl, + which, + eventlog, + pkg-config, + glib, + hiredis, + systemd, + perl, + python3, + riemann_c_client, + protobufc, + pcre, + paho-mqtt-c, + python3Packages, + libnet, + json_c, + libuuid, + libivykis, + libxslt, + docbook_xsl, + pcre2, + mongoc, + rabbitmq-c, + libesmtp, + rdkafka, + gperf, + withGrpc ? true, + grpc, + protobuf, }: let - python-deps = ps: with ps; [ - boto3 - botocore - cachetools - certifi - charset-normalizer - google-auth - idna - kubernetes - oauthlib - pyasn1 - pyasn1-modules - python-dateutil - pyyaml - requests - requests-oauthlib - rsa - six - urllib3 - websocket-client - ply - ]; + python-deps = + ps: with ps; [ + boto3 + botocore + cachetools + certifi + charset-normalizer + google-auth + idna + kubernetes + oauthlib + pyasn1 + pyasn1-modules + python-dateutil + pyyaml + requests + requests-oauthlib + rsa + six + urllib3 + websocket-client + ply + ]; py = python3.withPackages python-deps; in stdenv.mkDerivation (finalAttrs: { @@ -73,31 +75,47 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-YdGbDpGMC0DPuPSbfe9HvZshBVdv1s1+hiHDnhYbs6Q="; fetchSubmodules = true; }; - nativeBuildInputs = [ autoreconfHook autoconf-archive pkg-config which bison flex libxslt perl gperf python3Packages.setuptools ]; + nativeBuildInputs = [ + autoreconfHook + autoconf-archive + pkg-config + which + bison + flex + libxslt + perl + gperf + python3Packages.setuptools + ]; - buildInputs = [ - libcap - curl - openssl - eventlog - glib - py - systemd - riemann_c_client - protobufc - pcre - libnet - json_c - libuuid - libivykis - mongoc - rabbitmq-c - libesmtp - pcre2 - paho-mqtt-c - hiredis - rdkafka - ] ++ (lib.optionals withGrpc [ protobuf grpc ]); + buildInputs = + [ + libcap + curl + openssl + eventlog + glib + py + systemd + riemann_c_client + protobufc + pcre + libnet + json_c + libuuid + libivykis + mongoc + rabbitmq-c + libesmtp + pcre2 + paho-mqtt-c + hiredis + rdkafka + ] + ++ (lib.optionals withGrpc [ + protobuf + grpc + ]); configureFlags = [ "--enable-manpages" @@ -116,14 +134,20 @@ stdenv.mkDerivation (finalAttrs: { "--without-compile-date" ] ++ (lib.optionals withGrpc [ "--enable-grpc" ]); - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; enableParallelBuilding = true; meta = { homepage = "https://www.syslog-ng.com"; description = "Next-generation syslogd with advanced networking and filtering capabilities"; - license = with lib.licenses; [ gpl2Plus lgpl21Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl21Plus + ]; maintainers = with lib.maintainers; [ vifino ]; platforms = lib.platforms.linux; }; diff --git a/pkgs/by-name/sy/sysstat/package.nix b/pkgs/by-name/sy/sysstat/package.nix index ea37545672edfd..caf571e6b4b729 100644 --- a/pkgs/by-name/sy/sysstat/package.nix +++ b/pkgs/by-name/sy/sysstat/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, gettext -, bzip2 +{ + lib, + stdenv, + fetchFromGitHub, + gettext, + bzip2, }: stdenv.mkDerivation rec { @@ -26,8 +27,16 @@ stdenv.mkDerivation rec { export COMPRESS_MANPG=n ''; - makeFlags = [ "SYSCONFIG_DIR=$(out)/etc" "IGNORE_FILE_ATTRIBUTES=y" "CHOWN=true" ]; - installTargets = [ "install_base" "install_nls" "install_man" ]; + makeFlags = [ + "SYSCONFIG_DIR=$(out)/etc" + "IGNORE_FILE_ATTRIBUTES=y" + "CHOWN=true" + ]; + installTargets = [ + "install_base" + "install_nls" + "install_man" + ]; patches = [ ./install.patch ]; diff --git a/pkgs/by-name/sy/system-syzygy/package.nix b/pkgs/by-name/sy/system-syzygy/package.nix index d321284b74279d..1d1dffb6875a59 100644 --- a/pkgs/by-name/sy/system-syzygy/package.nix +++ b/pkgs/by-name/sy/system-syzygy/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, rustPlatform, fetchFromGitHub, SDL2, makeWrapper, makeDesktopItem}: +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + SDL2, + makeWrapper, + makeDesktopItem, +}: let desktopFile = makeDesktopItem { @@ -41,7 +49,6 @@ rustPlatform.buildRustPackage rec { substituteAll ${desktopFile}/share/applications/system-syzygy.desktop $out/share/applications/system-syzygy.desktop ''; - meta = with lib; { broken = stdenv.hostPlatform.isDarwin; description = "Story and a puzzle game, where you solve a variety of puzzle"; diff --git a/pkgs/by-name/sy/system76-firmware/package.nix b/pkgs/by-name/sy/system76-firmware/package.nix index d28372a465d966..b604f006cd4b57 100644 --- a/pkgs/by-name/sy/system76-firmware/package.nix +++ b/pkgs/by-name/sy/system76-firmware/package.nix @@ -1,4 +1,14 @@ -{ rustPlatform, lib, fetchFromGitHub, xz, pkg-config, openssl, dbus, efibootmgr, makeWrapper }: +{ + rustPlatform, + lib, + fetchFromGitHub, + xz, + pkg-config, + openssl, + dbus, + efibootmgr, + makeWrapper, +}: rustPlatform.buildRustPackage rec { pname = "system76-firmware"; # Check Makefile when updating, make sure postInstall matches make install @@ -11,9 +21,16 @@ rustPlatform.buildRustPackage rec { sha256 = "sha256-nLbDhs+FxIcoVK66bwUAxAubikic5NT8yOA/mH/irgQ="; }; - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; - buildInputs = [ xz openssl dbus ]; + buildInputs = [ + xz + openssl + dbus + ]; cargoBuildFlags = [ "--workspace" ]; @@ -39,6 +56,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/pop-os/system76-firmware"; license = licenses.gpl3Only; maintainers = with maintainers; [ shlevy ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/sy/system76-keyboard-configurator/package.nix b/pkgs/by-name/sy/system76-keyboard-configurator/package.nix index e9831de3ed00d4..e4fc5166a82446 100644 --- a/pkgs/by-name/sy/system76-keyboard-configurator/package.nix +++ b/pkgs/by-name/sy/system76-keyboard-configurator/package.nix @@ -1,4 +1,15 @@ -{ lib, fetchFromGitHub, rustPlatform, gtk3, glib, wrapGAppsHook3, libusb1, hidapi, udev, pkg-config }: +{ + lib, + fetchFromGitHub, + rustPlatform, + gtk3, + glib, + wrapGAppsHook3, + libusb1, + hidapi, + udev, + pkg-config, +}: # system76-keyboard-configurator tries to spawn a daemon as root via pkexec, so # your system needs a PolicyKit authentication agent running for the diff --git a/pkgs/by-name/sy/system76-power/package.nix b/pkgs/by-name/sy/system76-power/package.nix index 600459921c1a29..6b12959a91c770 100644 --- a/pkgs/by-name/sy/system76-power/package.nix +++ b/pkgs/by-name/sy/system76-power/package.nix @@ -1,4 +1,11 @@ -{ pkg-config, libusb1, dbus, lib, rustPlatform, fetchFromGitHub }: +{ + pkg-config, + libusb1, + dbus, + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "system76-power"; @@ -12,7 +19,10 @@ rustPlatform.buildRustPackage rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dbus libusb1 ]; + buildInputs = [ + dbus + libusb1 + ]; cargoLock = { lockFile = ./Cargo.lock; @@ -32,7 +42,14 @@ rustPlatform.buildRustPackage rec { mainProgram = "system76-power"; homepage = "https://github.com/pop-os/system76-power"; license = lib.licenses.gpl3Plus; - platforms = [ "i686-linux" "x86_64-linux" "aarch64-linux" ]; - maintainers = with lib.maintainers; [ smonson ahoneybun ]; + platforms = [ + "i686-linux" + "x86_64-linux" + "aarch64-linux" + ]; + maintainers = with lib.maintainers; [ + smonson + ahoneybun + ]; }; } diff --git a/pkgs/by-name/sy/system76-scheduler/package.nix b/pkgs/by-name/sy/system76-scheduler/package.nix index 790ae79bc72f07..d8e0ebe89d585d 100644 --- a/pkgs/by-name/sy/system76-scheduler/package.nix +++ b/pkgs/by-name/sy/system76-scheduler/package.nix @@ -1,14 +1,17 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pipewire -, pkg-config -, bcc -, dbus }: +{ + lib, + fetchFromGitHub, + rustPlatform, + pipewire, + pkg-config, + bcc, + dbus, +}: let version = "2.0.2"; -in rustPlatform.buildRustPackage { +in +rustPlatform.buildRustPackage { pname = "system76-scheduler"; inherit version; src = fetchFromGitHub { @@ -19,8 +22,14 @@ in rustPlatform.buildRustPackage { }; cargoHash = "sha256-HxNqGe+KrmOoLgaKY9pniPWFF/hehSi1dgZn4LPE7OA="; - nativeBuildInputs = [ pkg-config rustPlatform.bindgenHook ]; - buildInputs = [ dbus pipewire ]; + nativeBuildInputs = [ + pkg-config + rustPlatform.bindgenHook + ]; + buildInputs = [ + dbus + pipewire + ]; EXECSNOOP_PATH = "${bcc}/bin/execsnoop"; @@ -38,7 +47,11 @@ in rustPlatform.buildRustPackage { mainProgram = "system76-scheduler"; homepage = "https://github.com/pop-os/system76-scheduler"; license = licenses.mpl20; - platforms = [ "x86_64-linux" "x86-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "x86-linux" + "aarch64-linux" + ]; maintainers = [ maintainers.cmm ]; }; } diff --git a/pkgs/by-name/sy/systembus-notify/package.nix b/pkgs/by-name/sy/systembus-notify/package.nix index c059c566fecd36..ce599973c57257 100644 --- a/pkgs/by-name/sy/systembus-notify/package.nix +++ b/pkgs/by-name/sy/systembus-notify/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, formats -, systemd +{ + lib, + stdenv, + fetchFromGitHub, + formats, + systemd, }: let diff --git a/pkgs/by-name/sy/systemc/package.nix b/pkgs/by-name/sy/systemc/package.nix index 54f9a080c1d230..ef1c7a362fe523 100644 --- a/pkgs/by-name/sy/systemc/package.nix +++ b/pkgs/by-name/sy/systemc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "systemc"; @@ -23,9 +28,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Language for System-level design, modeling and verification"; - homepage = "https://systemc.org/"; - license = licenses.asl20; - platforms = platforms.unix; + homepage = "https://systemc.org/"; + license = licenses.asl20; + platforms = platforms.unix; maintainers = with maintainers; [ amiloradovsky ]; }; } diff --git a/pkgs/by-name/sy/systemd-journal2gelf/package.nix b/pkgs/by-name/sy/systemd-journal2gelf/package.nix index cb319fbd52d82b..2d9e8cf2827806 100644 --- a/pkgs/by-name/sy/systemd-journal2gelf/package.nix +++ b/pkgs/by-name/sy/systemd-journal2gelf/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "SystemdJournal2Gelf"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; doCheck = false; @@ -21,7 +28,10 @@ buildGoModule rec { description = "Export entries from systemd's journal and send them to a graylog server using gelf"; homepage = "https://github.com/parse-nl/SystemdJournal2Gelf"; license = licenses.bsd2; - maintainers = with maintainers; [ fadenb fpletz ]; + maintainers = with maintainers; [ + fadenb + fpletz + ]; mainProgram = "SystemdJournal2Gelf"; }; } diff --git a/pkgs/by-name/sy/systemd-lock-handler/package.nix b/pkgs/by-name/sy/systemd-lock-handler/package.nix index 04c52dd2df0a0b..edb4a9028c5bbc 100644 --- a/pkgs/by-name/sy/systemd-lock-handler/package.nix +++ b/pkgs/by-name/sy/systemd-lock-handler/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromSourcehut -, buildGoModule -, nix-update-script -, nixosTests +{ + lib, + fetchFromSourcehut, + buildGoModule, + nix-update-script, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/by-name/sy/systemd-wait/package.nix b/pkgs/by-name/sy/systemd-wait/package.nix index 99e07ebbf49c4d..d1a7e0c1f92f5d 100644 --- a/pkgs/by-name/sy/systemd-wait/package.nix +++ b/pkgs/by-name/sy/systemd-wait/package.nix @@ -1,4 +1,8 @@ -{ python3Packages, fetchFromGitHub, lib }: +{ + python3Packages, + fetchFromGitHub, + lib, +}: python3Packages.buildPythonApplication rec { pname = "systemd-wait"; @@ -12,7 +16,8 @@ python3Packages.buildPythonApplication rec { }; propagatedBuildInputs = with python3Packages; [ - dbus-python pygobject3 + dbus-python + pygobject3 ]; meta = { diff --git a/pkgs/by-name/sy/systemfd/package.nix b/pkgs/by-name/sy/systemfd/package.nix index da562f2bd5496d..6c4e59cca31308 100644 --- a/pkgs/by-name/sy/systemfd/package.nix +++ b/pkgs/by-name/sy/systemfd/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: let diff --git a/pkgs/by-name/sy/systeroid/package.nix b/pkgs/by-name/sy/systeroid/package.nix index 4cedd6db8a17b7..bd483e5ae86f46 100644 --- a/pkgs/by-name/sy/systeroid/package.nix +++ b/pkgs/by-name/sy/systeroid/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, linux-doc -, xorg +{ + lib, + rustPlatform, + fetchFromGitHub, + linux-doc, + xorg, }: rustPlatform.buildRustPackage rec { @@ -34,7 +35,13 @@ rustPlatform.buildRustPackage rec { description = "More powerful alternative to sysctl(8) with a terminal user interface"; homepage = "https://github.com/orhun/systeroid"; changelog = "https://github.com/orhun/systeroid/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; - maintainers = with maintainers; [ figsoda matthiasbeyer ]; + license = with licenses; [ + asl20 + mit + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + ]; }; } diff --git a/pkgs/by-name/sy/systrayhelper/package.nix b/pkgs/by-name/sy/systrayhelper/package.nix index 328ea27e8b8069..2bf9e9e99b7c76 100644 --- a/pkgs/by-name/sy/systrayhelper/package.nix +++ b/pkgs/by-name/sy/systrayhelper/package.nix @@ -1,4 +1,10 @@ -{ lib, pkg-config, libappindicator-gtk3, buildGoModule, fetchFromGitHub }: +{ + lib, + pkg-config, + libappindicator-gtk3, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "systrayhelper"; @@ -24,7 +30,10 @@ buildGoModule rec { "-w" ]; - nativeBuildInputs = [ pkg-config libappindicator-gtk3 ]; + nativeBuildInputs = [ + pkg-config + libappindicator-gtk3 + ]; buildInputs = [ libappindicator-gtk3 ]; doCheck = false; # Display required diff --git a/pkgs/by-name/sy/sysvinit/package.nix b/pkgs/by-name/sy/sysvinit/package.nix index c8ba3164ab09df..546187c7a31481 100644 --- a/pkgs/by-name/sy/sysvinit/package.nix +++ b/pkgs/by-name/sy/sysvinit/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libxcrypt, withoutInitTools ? false }: +{ + lib, + stdenv, + fetchurl, + libxcrypt, + withoutInitTools ? false, +}: stdenv.mkDerivation rec { pname = if withoutInitTools then "sysvtools" else "sysvinit"; @@ -16,19 +22,22 @@ stdenv.mkDerivation rec { buildInputs = [ libxcrypt ]; - makeFlags = [ "SULOGINLIBS=-lcrypt" "ROOT=$(out)" "MANDIR=/share/man" ]; + makeFlags = [ + "SULOGINLIBS=-lcrypt" + "ROOT=$(out)" + "MANDIR=/share/man" + ]; - preInstall = - '' - substituteInPlace src/Makefile --replace /usr / - ''; + preInstall = '' + substituteInPlace src/Makefile --replace /usr / + ''; - postInstall = '' - mv $out/sbin/killall5 $out/bin - ln -sf killall5 $out/bin/pidof - '' - + lib.optionalString withoutInitTools + postInstall = + '' + mv $out/sbin/killall5 $out/bin + ln -sf killall5 $out/bin/pidof '' + + lib.optionalString withoutInitTools '' shopt -s extglob rm -rf $out/sbin/!(sulogin) rm -rf $out/include diff --git a/pkgs/by-name/sy/sysz/package.nix b/pkgs/by-name/sy/sysz/package.nix index aac3bfb29c94af..cbe2f22f68fb4b 100644 --- a/pkgs/by-name/sy/sysz/package.nix +++ b/pkgs/by-name/sy/sysz/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenvNoCC, fetchFromGitHub, makeWrapper, fzf, gawk }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + makeWrapper, + fzf, + gawk, +}: stdenvNoCC.mkDerivation rec { pname = "sysz"; @@ -18,7 +25,12 @@ stdenvNoCC.mkDerivation rec { runHook preInstall install -Dm755 sysz $out/libexec/sysz makeWrapper $out/libexec/sysz $out/bin/sysz \ - --prefix PATH : ${lib.makeBinPath [ fzf gawk ]} + --prefix PATH : ${ + lib.makeBinPath [ + fzf + gawk + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/sz/szip/package.nix b/pkgs/by-name/sz/szip/package.nix index f6d0c619c770d8..814c777f12302d 100644 --- a/pkgs/by-name/sz/szip/package.nix +++ b/pkgs/by-name/sz/szip/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "szip"; diff --git a/pkgs/by-name/sz/szyszka/package.nix b/pkgs/by-name/sz/szyszka/package.nix index 8bd133e6dae01e..caccd45c1f2330 100644 --- a/pkgs/by-name/sz/szyszka/package.nix +++ b/pkgs/by-name/sz/szyszka/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, glib -, cairo -, pango -, atk -, gdk-pixbuf -, gtk4 -, wrapGAppsHook4 -, darwin +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + glib, + cairo, + pango, + atk, + gdk-pixbuf, + gtk4, + wrapGAppsHook4, + darwin, }: rustPlatform.buildRustPackage rec { @@ -31,16 +32,21 @@ rustPlatform.buildRustPackage rec { wrapGAppsHook4 ]; - buildInputs = [ - glib - cairo - pango - atk - gdk-pixbuf - gtk4 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - Foundation - ]); + buildInputs = + [ + glib + cairo + pango + atk + gdk-pixbuf + gtk4 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Foundation + ] + ); postInstall = '' install -m 444 \ diff --git a/pkgs/by-name/t-/t-rex/package.nix b/pkgs/by-name/t-/t-rex/package.nix index 60d44e0247a8d7..e0c41b0d0abfeb 100644 --- a/pkgs/by-name/t-/t-rex/package.nix +++ b/pkgs/by-name/t-/t-rex/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, pkg-config, gdal, openssl, darwin }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + gdal, + openssl, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "t-rex"; @@ -13,10 +22,15 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-nxq4mX2Sy6Hyi8tA2CQsQwISB/kau4DEkAgIm4SvGns="; - nativeBuildInputs = [ pkg-config rustPlatform.bindgenHook ]; + nativeBuildInputs = [ + pkg-config + rustPlatform.bindgenHook + ]; - buildInputs = [ gdal openssl ] - ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.Security; + buildInputs = [ + gdal + openssl + ] ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.Security; meta = with lib; { description = "Vector tile server specialized on publishing MVT tiles"; diff --git a/pkgs/by-name/t1/t1lib/package.nix b/pkgs/by-name/t1/t1lib/package.nix index e09ed7ee32dc73..6bb91c9d19784e 100644 --- a/pkgs/by-name/t1/t1lib/package.nix +++ b/pkgs/by-name/t1/t1lib/package.nix @@ -1,19 +1,44 @@ -{ lib, stdenv, fetchurl, fetchpatch, libX11, libXaw }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libX11, + libXaw, +}: let - getPatch = { name, sha256 }: fetchpatch { - inherit name sha256; - url = "https://projects.archlinux.org/svntogit/packages.git/plain/trunk/${name}" - + "?h=packages/t1lib&id=643a4c2c58e70072b5bc1e9e4624162517b58357"; - }; + getPatch = + { name, sha256 }: + fetchpatch { + inherit name sha256; + url = + "https://projects.archlinux.org/svntogit/packages.git/plain/trunk/${name}" + + "?h=packages/t1lib&id=643a4c2c58e70072b5bc1e9e4624162517b58357"; + }; patches = map getPatch [ - { name = "lib-cleanup.diff"; sha256 = "1w3q1y4zk0y4mf2s2x9z4cd8d4af8i868c8837p40mz3dqrai4zp"; } - { name = "format-security.diff"; sha256 = "0cca94bif9dsc6iwpcnk1504gb3sl3nsqhni85c21q9aywyz26l3"; } - { name = "CVE-2011-0764.diff"; sha256 = "1j0y3f38im7srpqjg9jvx8as6sxkz8gw7hglcxnxl9qylx8mr2jh"; } - { name = "CVE-2011-1552_1553_1554.patch"; sha256 = "16cyq6jhyhh8912j8hapx9pq4rzxk36ljlkxlnyi7i3wr8iz1dir"; } - { name = "CVE-2010-2642.patch"; sha256 = "175zvyr9v1xs22k2svgxqjcpz5nihfa7j46hn9nzvkqcrhm5m9y8"; } - # this ^ also fixes CVE-2011-5244 + { + name = "lib-cleanup.diff"; + sha256 = "1w3q1y4zk0y4mf2s2x9z4cd8d4af8i868c8837p40mz3dqrai4zp"; + } + { + name = "format-security.diff"; + sha256 = "0cca94bif9dsc6iwpcnk1504gb3sl3nsqhni85c21q9aywyz26l3"; + } + { + name = "CVE-2011-0764.diff"; + sha256 = "1j0y3f38im7srpqjg9jvx8as6sxkz8gw7hglcxnxl9qylx8mr2jh"; + } + { + name = "CVE-2011-1552_1553_1554.patch"; + sha256 = "16cyq6jhyhh8912j8hapx9pq4rzxk36ljlkxlnyi7i3wr8iz1dir"; + } + { + name = "CVE-2010-2642.patch"; + sha256 = "175zvyr9v1xs22k2svgxqjcpz5nihfa7j46hn9nzvkqcrhm5m9y8"; + } + # this ^ also fixes CVE-2011-5244 ]; in stdenv.mkDerivation rec { @@ -26,7 +51,10 @@ stdenv.mkDerivation rec { }; inherit patches; - buildInputs = [ libX11 libXaw ]; + buildInputs = [ + libX11 + libXaw + ]; buildFlags = [ "without_doc" ]; postInstall = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' @@ -37,7 +65,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "http://www.t1lib.org/"; description = "Type 1 font rasterizer library for UNIX/X11"; - license = with licenses; [ gpl2 lgpl2 ]; + license = with licenses; [ + gpl2 + lgpl2 + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/t1/t1utils/package.nix b/pkgs/by-name/t1/t1utils/package.nix index be9cf659160bda..243e35d8c9087a 100644 --- a/pkgs/by-name/t1/t1utils/package.nix +++ b/pkgs/by-name/t1/t1utils/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "t1utils"; diff --git a/pkgs/by-name/t4/t4kcommon/package.nix b/pkgs/by-name/t4/t4kcommon/package.nix index 7fa7d686b1780a..d5e07eb4bbde9a 100644 --- a/pkgs/by-name/t4/t4kcommon/package.nix +++ b/pkgs/by-name/t4/t4kcommon/package.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl, cmake, pkg-config, SDL, SDL_image, SDL_mixer, SDL_net, SDL_ttf, libpng, librsvg, libxml2 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + cmake, + pkg-config, + SDL, + SDL_image, + SDL_mixer, + SDL_net, + SDL_ttf, + libpng, + librsvg, + libxml2, +}: stdenv.mkDerivation rec { version = "0.1.1"; @@ -26,8 +41,20 @@ stdenv.mkDerivation rec { # TODO: revisit https://github.com/tux4kids/t4kcommon/pull/10 when merged. env.NIX_CFLAGS_COMPILE = "-fcommon"; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ SDL SDL_image SDL_mixer SDL_net SDL_ttf libpng librsvg libxml2 ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + SDL + SDL_image + SDL_mixer + SDL_net + SDL_ttf + libpng + librsvg + libxml2 + ]; meta = with lib; { description = "Library of code shared between tuxmath and tuxtype"; diff --git a/pkgs/by-name/ta/ta-lib/package.nix b/pkgs/by-name/ta/ta-lib/package.nix index c3f77a9a247a36..094b0004973f68 100644 --- a/pkgs/by-name/ta/ta-lib/package.nix +++ b/pkgs/by-name/ta/ta-lib/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, +}: stdenv.mkDerivation rec { pname = "ta-lib"; @@ -10,12 +16,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-bIzN8f9ZiOLaVzGAXcZUHUh/v9z1U+zY+MnyjJr1lSw="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; hardeningDisable = [ "format" ]; meta = with lib; { - description = - "TA-Lib is a library that provides common functions for the technical analysis of financial market data."; + description = "TA-Lib is a library that provides common functions for the technical analysis of financial market data."; mainProgram = "ta-lib-config"; homepage = "https://ta-lib.org/"; license = lib.licenses.bsd3; diff --git a/pkgs/by-name/ta/tab/package.nix b/pkgs/by-name/ta/tab/package.nix index f812bc9c6be4fe..e719593d8ae08e 100644 --- a/pkgs/by-name/ta/tab/package.nix +++ b/pkgs/by-name/ta/tab/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation rec { version = "9.2"; @@ -34,9 +39,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Programming language/shell calculator"; mainProgram = "tab"; - homepage = "https://tab-lang.xyz"; - license = licenses.boost; + homepage = "https://tab-lang.xyz"; + license = licenses.boost; maintainers = with maintainers; [ mstarzyk ]; - platforms = with platforms; unix; + platforms = with platforms; unix; }; } diff --git a/pkgs/by-name/ta/tabiew/package.nix b/pkgs/by-name/ta/tabiew/package.nix index caa6be91040bc0..67b81b689b1f3a 100644 --- a/pkgs/by-name/ta/tabiew/package.nix +++ b/pkgs/by-name/ta/tabiew/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, installShellFiles +{ + lib, + fetchFromGitHub, + rustPlatform, + installShellFiles, }: rustPlatform.buildRustPackage rec { pname = "tabiew"; @@ -18,7 +19,10 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ installShellFiles ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; postInstall = '' installManPage target/manual/tabiew.1 @@ -32,8 +36,7 @@ rustPlatform.buildRustPackage rec { doCheck = false; # there are no tests meta = { - description = - "Lightweight, terminal-based application to view and query delimiter separated value formatted documents, such as CSV and TSV files"; + description = "Lightweight, terminal-based application to view and query delimiter separated value formatted documents, such as CSV and TSV files"; homepage = "https://github.com/shshemi/tabiew"; changelog = "https://github.com/shshemi/tabiew/releases/tag/v${version}"; license = lib.licenses.mit; diff --git a/pkgs/by-name/ta/tableplus/package.nix b/pkgs/by-name/ta/tableplus/package.nix index 542a3c6000f259..53c7e5c1875262 100644 --- a/pkgs/by-name/ta/tableplus/package.nix +++ b/pkgs/by-name/ta/tableplus/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchurl -, _7zz -, stdenv +{ + lib, + fetchurl, + _7zz, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ta/tabula-java/package.nix b/pkgs/by-name/ta/tabula-java/package.nix index 011f92362a3137..c0ec2ee26bee48 100644 --- a/pkgs/by-name/ta/tabula-java/package.nix +++ b/pkgs/by-name/ta/tabula-java/package.nix @@ -1,8 +1,9 @@ -{ lib -, maven -, fetchFromGitHub -, makeWrapper -, jre +{ + lib, + maven, + fetchFromGitHub, + makeWrapper, + jre, }: maven.buildMavenPackage rec { diff --git a/pkgs/by-name/ta/tacacsplus/package.nix b/pkgs/by-name/ta/tacacsplus/package.nix index b06da38017a7a6..a818498b627bcf 100644 --- a/pkgs/by-name/ta/tacacsplus/package.nix +++ b/pkgs/by-name/ta/tacacsplus/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, tcp_wrappers, flex, bison, perl, libnsl }: +{ + lib, + stdenv, + fetchurl, + tcp_wrappers, + flex, + bison, + perl, + libnsl, +}: stdenv.mkDerivation rec { pname = "tacacsplus"; @@ -9,8 +18,15 @@ stdenv.mkDerivation rec { hash = "sha256-FH8tyY0m0vk/Crp2yYjO0Zb/4cAB3C6R94ihosdHIZ4="; }; - nativeBuildInputs = [ flex bison ]; - buildInputs = [ tcp_wrappers perl libnsl ]; + nativeBuildInputs = [ + flex + bison + ]; + buildInputs = [ + tcp_wrappers + perl + libnsl + ]; meta = with lib; { description = "Protocol for authentication, authorization and accounting (AAA) services for routers and network devices"; diff --git a/pkgs/by-name/ta/tagger/deps.nix b/pkgs/by-name/ta/tagger/deps.nix index 231c388ebe6784..900c0465b1de0c 100644 --- a/pkgs/by-name/ta/tagger/deps.nix +++ b/pkgs/by-name/ta/tagger/deps.nix @@ -1,50 +1,231 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Ace4896.DBus.Services.Secrets"; version = "1.2.0"; hash = "sha256-dgGnQL+y7UubFgG0dVmuz1J/uMhR7bOirKA38dHmOcQ="; }) - (fetchNuGet { pname = "AcoustID.NET"; version = "1.3.3"; hash = "sha256-VF7GwQhk9hVBToj9K2UK356H6toDugMI/rosAT2P2TY="; }) - (fetchNuGet { pname = "Cake.Tool"; version = "4.0.0"; hash = "sha256-guIxNh+ENqZroPaoh7bJ+R0OP9Ed64BAMYSbWKMrbIc="; }) - (fetchNuGet { pname = "FuzzySharp"; version = "2.0.2"; hash = "sha256-GuWqVOo+AG8MSvIbusLPjKfJFQRJhSSJ9eGWljTBA/c="; }) - (fetchNuGet { pname = "GetText.NET"; version = "1.9.14"; hash = "sha256-JAFqmwXkRJCHMOLIN2NShSe5aXtDvo5+II412oBj5KM="; }) - (fetchNuGet { pname = "GirCore.Adw-1"; version = "0.5.0"; hash = "sha256-qfXR3lTI5IeFlZ+eoXiEjvvU7a94ksDA1NDDO+fjEow="; }) - (fetchNuGet { pname = "GirCore.Cairo-1.0"; version = "0.5.0"; hash = "sha256-9vu8cLiI8UJzIwcx/EtNPp0uYBTAYYP7f+K4+78cLfU="; }) - (fetchNuGet { pname = "GirCore.FreeType2-2.0"; version = "0.5.0"; hash = "sha256-ngF0UjqeWWPJM6oHWe1Ii+h1BUccFDQd1Qwz35DNCJk="; }) - (fetchNuGet { pname = "GirCore.Gdk-4.0"; version = "0.5.0"; hash = "sha256-pl04bEdh1kzjzT2MgENyitvU9YNU+7zdxzSQBF+iVuw="; }) - (fetchNuGet { pname = "GirCore.GdkPixbuf-2.0"; version = "0.5.0"; hash = "sha256-2dY45sZRqLAHjXx8G3aLGnftJuMS/367E7oMAtlkdT0="; }) - (fetchNuGet { pname = "GirCore.Gio-2.0"; version = "0.5.0"; hash = "sha256-lEcxgUtvw+/wP68h1xXLodjALdFgA8fWlP8e75kcovs="; }) - (fetchNuGet { pname = "GirCore.GLib-2.0"; version = "0.5.0"; hash = "sha256-e8/5XRtUr5PMROr9t3t1y+S5ittGigeMvkC1x0AaPpk="; }) - (fetchNuGet { pname = "GirCore.GObject-2.0"; version = "0.5.0"; hash = "sha256-cobt8ueN6++TqbOfSn1yKYkjCKlpRc04te8BW2dQZfA="; }) - (fetchNuGet { pname = "GirCore.Graphene-1.0"; version = "0.5.0"; hash = "sha256-mF5paOfxW2T/BIa9MSRBCXI0IxyjPEiHSVAl+58ZyJs="; }) - (fetchNuGet { pname = "GirCore.Gsk-4.0"; version = "0.5.0"; hash = "sha256-joLS4KfAWkp3z8r7i5MtBDotTv2zMnYRw2bTQNNATJQ="; }) - (fetchNuGet { pname = "GirCore.Gtk-4.0"; version = "0.5.0"; hash = "sha256-LN/u9QuAxRMDJfly1LeMwCgJMkTeZyJJ4unrmTpORlI="; }) - (fetchNuGet { pname = "GirCore.HarfBuzz-0.0"; version = "0.5.0"; hash = "sha256-hBFkQK/LPSTIU8M8Tv0hyRG4d4ibh/Iaa3ZySYpg0TI="; }) - (fetchNuGet { pname = "GirCore.Pango-1.0"; version = "0.5.0"; hash = "sha256-6cxAaxynKx7kTsLy++qcrhD+G7OBfVRYohe1MX3Sk1w="; }) - (fetchNuGet { pname = "GirCore.PangoCairo-1.0"; version = "0.5.0"; hash = "sha256-tpIeKhZPrntKIFkeMIYyDHgOSw2Il/L4E7OpBHsUo0g="; }) - (fetchNuGet { pname = "HtmlAgilityPack"; version = "1.11.61"; hash = "sha256-exRJTP7mHNt31CKaejKSSkKPm74ratfnpGl50AqZwlY="; }) - (fetchNuGet { pname = "Markdig"; version = "0.33.0"; hash = "sha256-OWlYrZnvNIFwmxKnmfWTq1wOz9e+hewsiVJW3B43QLY="; }) - (fetchNuGet { pname = "MetaBrainz.Common"; version = "3.0.0"; hash = "sha256-P+XTQhffqSVIn0ZbC5Npl80xlx1QYHoL0y20KTvKRy0="; }) - (fetchNuGet { pname = "MetaBrainz.Common.Json"; version = "6.0.2"; hash = "sha256-4IcF9xZZmI3H7WAiuN2kK61BMXS4gh2T2WrCqkwQhX8="; }) - (fetchNuGet { pname = "MetaBrainz.MusicBrainz"; version = "6.1.0"; hash = "sha256-wZBTTSQNPll/5/sZPPxa6d0QBjwA8FLA2vFE/838VWs="; }) - (fetchNuGet { pname = "MetaBrainz.MusicBrainz.CoverArt"; version = "6.0.0"; hash = "sha256-yN+godNeB6l8ihNupq9cNe+PaYaPTngHJzwkMH9ySbE="; }) - (fetchNuGet { pname = "Meziantou.Framework.Win32.CredentialManager"; version = "1.4.5"; hash = "sha256-aJyLlVg6jKY2Van0hwAC5JEF/j+YtEq5ZFLkyI3scsY="; }) - (fetchNuGet { pname = "Microsoft.Data.Sqlite.Core"; version = "8.0.0"; hash = "sha256-aew8/vRyzCc7MMNHziR8tsg66EFkJC+Snst3F+a3Ehc="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "5.0.0"; hash = "sha256-5rFBJ8Fkw7+11iCG9nMVhOqPCpyVIrbUzrFQhc/2eHw="; }) - (fetchNuGet { pname = "Microsoft.Win32.SystemEvents"; version = "8.0.0"; hash = "sha256-UcxurEamYD+Bua0PbPNMYAZaRulMrov8CfbJGIgTaRQ="; }) - (fetchNuGet { pname = "Nickvision.Aura"; version = "2023.11.4"; hash = "sha256-us9K5RayuZGe2fkhk/c2Qw45gKmrfvyNBvHdcOnzWj0="; }) - (fetchNuGet { pname = "Octokit"; version = "9.0.0"; hash = "sha256-5crRhibEw2pl8M6AmgutI/uA0xcBoFRSF43MDgNPhE8="; }) - (fetchNuGet { pname = "SixLabors.ImageSharp"; version = "3.1.4"; hash = "sha256-zOqHVIInvJiqmx4JF+8USYvdKAGRZVUqQpdncrrjRjM="; }) - (fetchNuGet { pname = "SQLitePCLRaw.bundle_e_sqlcipher"; version = "2.1.6"; hash = "sha256-ikaVYtmka8VuZ2BDbH4rkT/L19uLMZnUIZSdSfzpYpc="; }) - (fetchNuGet { pname = "SQLitePCLRaw.core"; version = "2.1.6"; hash = "sha256-RxWjm52PdmMV98dgDy0BCpF988+BssRZUgALLv7TH/E="; }) - (fetchNuGet { pname = "SQLitePCLRaw.lib.e_sqlcipher"; version = "2.1.6"; hash = "sha256-HyCw64Ir+JTmAQpBRR2Y7L/o1l+RiwoL9URDXoJVhTY="; }) - (fetchNuGet { pname = "SQLitePCLRaw.provider.e_sqlcipher"; version = "2.1.6"; hash = "sha256-OD+cJ6dvUv/bYhMR9hWnsz23un1CHH5WKEnwghtpqMs="; }) - (fetchNuGet { pname = "System.Drawing.Common"; version = "8.0.0"; hash = "sha256-xPNnKUTcZiqnTtRgI2YazMoZgay/prwKrJjbZUbVmcg="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "6.0.0"; hash = "sha256-xfjF4UqTMJpf8KsBWUyJlJkzPTOO/H5MW023yTYNQSA="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.3"; hash = "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.5"; hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "8.0.0"; hash = "sha256-fjCLQc1PRW0Ix5IZldg0XKv+J1DqPSfu9pjMyNBp7dE="; }) - (fetchNuGet { pname = "Tmds.DBus"; version = "0.15.0"; hash = "sha256-hnG44eEULZY79phZ/E1/RG2acjW0y12eIxam67iR5a8="; }) - (fetchNuGet { pname = "Tmds.DBus.Protocol"; version = "0.15.0"; hash = "sha256-4gk2vXDjKFaBh82gTkwg3c/5GRjiH+bvM5elfDSbKTU="; }) - (fetchNuGet { pname = "Ude.NetStandard"; version = "1.2.0"; hash = "sha256-9Dq7UE5OiuvciURQV8Aa13elolt1fzDhvF8c8Yxznhw="; }) - (fetchNuGet { pname = "z440.atl.core"; version = "5.25.0"; hash = "sha256-wyhSBvwzIXFLERBCr2s1zebaebOVANvUcwmJkrNdJi8="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Ace4896.DBus.Services.Secrets"; + version = "1.2.0"; + hash = "sha256-dgGnQL+y7UubFgG0dVmuz1J/uMhR7bOirKA38dHmOcQ="; + }) + (fetchNuGet { + pname = "AcoustID.NET"; + version = "1.3.3"; + hash = "sha256-VF7GwQhk9hVBToj9K2UK356H6toDugMI/rosAT2P2TY="; + }) + (fetchNuGet { + pname = "Cake.Tool"; + version = "4.0.0"; + hash = "sha256-guIxNh+ENqZroPaoh7bJ+R0OP9Ed64BAMYSbWKMrbIc="; + }) + (fetchNuGet { + pname = "FuzzySharp"; + version = "2.0.2"; + hash = "sha256-GuWqVOo+AG8MSvIbusLPjKfJFQRJhSSJ9eGWljTBA/c="; + }) + (fetchNuGet { + pname = "GetText.NET"; + version = "1.9.14"; + hash = "sha256-JAFqmwXkRJCHMOLIN2NShSe5aXtDvo5+II412oBj5KM="; + }) + (fetchNuGet { + pname = "GirCore.Adw-1"; + version = "0.5.0"; + hash = "sha256-qfXR3lTI5IeFlZ+eoXiEjvvU7a94ksDA1NDDO+fjEow="; + }) + (fetchNuGet { + pname = "GirCore.Cairo-1.0"; + version = "0.5.0"; + hash = "sha256-9vu8cLiI8UJzIwcx/EtNPp0uYBTAYYP7f+K4+78cLfU="; + }) + (fetchNuGet { + pname = "GirCore.FreeType2-2.0"; + version = "0.5.0"; + hash = "sha256-ngF0UjqeWWPJM6oHWe1Ii+h1BUccFDQd1Qwz35DNCJk="; + }) + (fetchNuGet { + pname = "GirCore.Gdk-4.0"; + version = "0.5.0"; + hash = "sha256-pl04bEdh1kzjzT2MgENyitvU9YNU+7zdxzSQBF+iVuw="; + }) + (fetchNuGet { + pname = "GirCore.GdkPixbuf-2.0"; + version = "0.5.0"; + hash = "sha256-2dY45sZRqLAHjXx8G3aLGnftJuMS/367E7oMAtlkdT0="; + }) + (fetchNuGet { + pname = "GirCore.Gio-2.0"; + version = "0.5.0"; + hash = "sha256-lEcxgUtvw+/wP68h1xXLodjALdFgA8fWlP8e75kcovs="; + }) + (fetchNuGet { + pname = "GirCore.GLib-2.0"; + version = "0.5.0"; + hash = "sha256-e8/5XRtUr5PMROr9t3t1y+S5ittGigeMvkC1x0AaPpk="; + }) + (fetchNuGet { + pname = "GirCore.GObject-2.0"; + version = "0.5.0"; + hash = "sha256-cobt8ueN6++TqbOfSn1yKYkjCKlpRc04te8BW2dQZfA="; + }) + (fetchNuGet { + pname = "GirCore.Graphene-1.0"; + version = "0.5.0"; + hash = "sha256-mF5paOfxW2T/BIa9MSRBCXI0IxyjPEiHSVAl+58ZyJs="; + }) + (fetchNuGet { + pname = "GirCore.Gsk-4.0"; + version = "0.5.0"; + hash = "sha256-joLS4KfAWkp3z8r7i5MtBDotTv2zMnYRw2bTQNNATJQ="; + }) + (fetchNuGet { + pname = "GirCore.Gtk-4.0"; + version = "0.5.0"; + hash = "sha256-LN/u9QuAxRMDJfly1LeMwCgJMkTeZyJJ4unrmTpORlI="; + }) + (fetchNuGet { + pname = "GirCore.HarfBuzz-0.0"; + version = "0.5.0"; + hash = "sha256-hBFkQK/LPSTIU8M8Tv0hyRG4d4ibh/Iaa3ZySYpg0TI="; + }) + (fetchNuGet { + pname = "GirCore.Pango-1.0"; + version = "0.5.0"; + hash = "sha256-6cxAaxynKx7kTsLy++qcrhD+G7OBfVRYohe1MX3Sk1w="; + }) + (fetchNuGet { + pname = "GirCore.PangoCairo-1.0"; + version = "0.5.0"; + hash = "sha256-tpIeKhZPrntKIFkeMIYyDHgOSw2Il/L4E7OpBHsUo0g="; + }) + (fetchNuGet { + pname = "HtmlAgilityPack"; + version = "1.11.61"; + hash = "sha256-exRJTP7mHNt31CKaejKSSkKPm74ratfnpGl50AqZwlY="; + }) + (fetchNuGet { + pname = "Markdig"; + version = "0.33.0"; + hash = "sha256-OWlYrZnvNIFwmxKnmfWTq1wOz9e+hewsiVJW3B43QLY="; + }) + (fetchNuGet { + pname = "MetaBrainz.Common"; + version = "3.0.0"; + hash = "sha256-P+XTQhffqSVIn0ZbC5Npl80xlx1QYHoL0y20KTvKRy0="; + }) + (fetchNuGet { + pname = "MetaBrainz.Common.Json"; + version = "6.0.2"; + hash = "sha256-4IcF9xZZmI3H7WAiuN2kK61BMXS4gh2T2WrCqkwQhX8="; + }) + (fetchNuGet { + pname = "MetaBrainz.MusicBrainz"; + version = "6.1.0"; + hash = "sha256-wZBTTSQNPll/5/sZPPxa6d0QBjwA8FLA2vFE/838VWs="; + }) + (fetchNuGet { + pname = "MetaBrainz.MusicBrainz.CoverArt"; + version = "6.0.0"; + hash = "sha256-yN+godNeB6l8ihNupq9cNe+PaYaPTngHJzwkMH9ySbE="; + }) + (fetchNuGet { + pname = "Meziantou.Framework.Win32.CredentialManager"; + version = "1.4.5"; + hash = "sha256-aJyLlVg6jKY2Van0hwAC5JEF/j+YtEq5ZFLkyI3scsY="; + }) + (fetchNuGet { + pname = "Microsoft.Data.Sqlite.Core"; + version = "8.0.0"; + hash = "sha256-aew8/vRyzCc7MMNHziR8tsg66EFkJC+Snst3F+a3Ehc="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "5.0.0"; + hash = "sha256-5rFBJ8Fkw7+11iCG9nMVhOqPCpyVIrbUzrFQhc/2eHw="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.SystemEvents"; + version = "8.0.0"; + hash = "sha256-UcxurEamYD+Bua0PbPNMYAZaRulMrov8CfbJGIgTaRQ="; + }) + (fetchNuGet { + pname = "Nickvision.Aura"; + version = "2023.11.4"; + hash = "sha256-us9K5RayuZGe2fkhk/c2Qw45gKmrfvyNBvHdcOnzWj0="; + }) + (fetchNuGet { + pname = "Octokit"; + version = "9.0.0"; + hash = "sha256-5crRhibEw2pl8M6AmgutI/uA0xcBoFRSF43MDgNPhE8="; + }) + (fetchNuGet { + pname = "SixLabors.ImageSharp"; + version = "3.1.4"; + hash = "sha256-zOqHVIInvJiqmx4JF+8USYvdKAGRZVUqQpdncrrjRjM="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.bundle_e_sqlcipher"; + version = "2.1.6"; + hash = "sha256-ikaVYtmka8VuZ2BDbH4rkT/L19uLMZnUIZSdSfzpYpc="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.core"; + version = "2.1.6"; + hash = "sha256-RxWjm52PdmMV98dgDy0BCpF988+BssRZUgALLv7TH/E="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.lib.e_sqlcipher"; + version = "2.1.6"; + hash = "sha256-HyCw64Ir+JTmAQpBRR2Y7L/o1l+RiwoL9URDXoJVhTY="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.provider.e_sqlcipher"; + version = "2.1.6"; + hash = "sha256-OD+cJ6dvUv/bYhMR9hWnsz23un1CHH5WKEnwghtpqMs="; + }) + (fetchNuGet { + pname = "System.Drawing.Common"; + version = "8.0.0"; + hash = "sha256-xPNnKUTcZiqnTtRgI2YazMoZgay/prwKrJjbZUbVmcg="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "6.0.0"; + hash = "sha256-xfjF4UqTMJpf8KsBWUyJlJkzPTOO/H5MW023yTYNQSA="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.3"; + hash = "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.5"; + hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "8.0.0"; + hash = "sha256-fjCLQc1PRW0Ix5IZldg0XKv+J1DqPSfu9pjMyNBp7dE="; + }) + (fetchNuGet { + pname = "Tmds.DBus"; + version = "0.15.0"; + hash = "sha256-hnG44eEULZY79phZ/E1/RG2acjW0y12eIxam67iR5a8="; + }) + (fetchNuGet { + pname = "Tmds.DBus.Protocol"; + version = "0.15.0"; + hash = "sha256-4gk2vXDjKFaBh82gTkwg3c/5GRjiH+bvM5elfDSbKTU="; + }) + (fetchNuGet { + pname = "Ude.NetStandard"; + version = "1.2.0"; + hash = "sha256-9Dq7UE5OiuvciURQV8Aa13elolt1fzDhvF8c8Yxznhw="; + }) + (fetchNuGet { + pname = "z440.atl.core"; + version = "5.25.0"; + hash = "sha256-wyhSBvwzIXFLERBCr2s1zebaebOVANvUcwmJkrNdJi8="; + }) ] diff --git a/pkgs/by-name/ta/tagger/package.nix b/pkgs/by-name/ta/tagger/package.nix index fa4074b8a5249d..fa315e5736411f 100644 --- a/pkgs/by-name/ta/tagger/package.nix +++ b/pkgs/by-name/ta/tagger/package.nix @@ -1,12 +1,13 @@ -{ lib -, buildDotnetModule -, fetchFromGitHub -, dotnetCorePackages -, blueprint-compiler -, chromaprint -, glib -, gtk4 -, libadwaita +{ + lib, + buildDotnetModule, + fetchFromGitHub, + dotnetCorePackages, + blueprint-compiler, + chromaprint, + glib, + gtk4, + libadwaita, }: let @@ -59,6 +60,9 @@ buildDotnetModule rec { mainProgram = "NickvisionTagger.GNOME"; license = licenses.mit; platforms = platforms.linux; - maintainers = with maintainers; [ zendo ratcornu ]; + maintainers = with maintainers; [ + zendo + ratcornu + ]; }; } diff --git a/pkgs/by-name/ta/taglib-sharp/package.nix b/pkgs/by-name/ta/taglib-sharp/package.nix index 78a4026455e6d7..2f44619d21b49d 100644 --- a/pkgs/by-name/ta/taglib-sharp/package.nix +++ b/pkgs/by-name/ta/taglib-sharp/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, which, pkg-config, mono }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + which, + pkg-config, + mono, +}: stdenv.mkDerivation rec { pname = "taglib-sharp"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { sha256 = "12pk4z6ag8w7kj6vzplrlasq5lwddxrww1w1ya5ivxrfki15h5cp"; }; - nativeBuildInputs = [ pkg-config autoreconfHook which ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + which + ]; buildInputs = [ mono ]; dontStrip = true; diff --git a/pkgs/by-name/ta/taglib/package.nix b/pkgs/by-name/ta/taglib/package.nix index 17918f5f43739a..684a37f0172fb6 100644 --- a/pkgs/by-name/ta/taglib/package.nix +++ b/pkgs/by-name/ta/taglib/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, zlib -, testers +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -41,8 +42,14 @@ stdenv.mkDerivation (finalAttrs: { files, Ogg Vorbis comments and ID3 tags and Vorbis comments in FLAC, MPC, Speex, WavPack, TrueAudio, WAV, AIFF, MP4 and ASF files. ''; - license = with licenses; [ lgpl3 mpl11 ]; + license = with licenses; [ + lgpl3 + mpl11 + ]; maintainers = with maintainers; [ ttuegel ]; - pkgConfigModules = [ "taglib" "taglib_c" ]; + pkgConfigModules = [ + "taglib" + "taglib_c" + ]; }; }) diff --git a/pkgs/by-name/ta/taglib_extras/package.nix b/pkgs/by-name/ta/taglib_extras/package.nix index 5ba1a5e2018200..163f9afe3805fd 100644 --- a/pkgs/by-name/ta/taglib_extras/package.nix +++ b/pkgs/by-name/ta/taglib_extras/package.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchurl, cmake, taglib, zlib}: +{ + lib, + stdenv, + fetchurl, + cmake, + taglib, + zlib, +}: stdenv.mkDerivation rec { pname = "taglib-extras"; @@ -8,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "0cln49ws9svvvals5fzxjxlzqm0fzjfymn7yfp4jfcjz655nnm7y"; }; buildInputs = [ taglib ]; - nativeBuildInputs = [ cmake zlib ]; + nativeBuildInputs = [ + cmake + zlib + ]; # Workaround for upstream bug https://bugs.kde.org/show_bug.cgi?id=357181 preConfigure = '' diff --git a/pkgs/by-name/ta/tagparser/package.nix b/pkgs/by-name/ta/tagparser/package.nix index cdd3aacf26d86a..6910a8f1900d7a 100644 --- a/pkgs/by-name/ta/tagparser/package.nix +++ b/pkgs/by-name/ta/tagparser/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, cpp-utilities -, zlib -, isocodes +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + cpp-utilities, + zlib, + isocodes, }: stdenv.mkDerivation rec { @@ -21,7 +22,8 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; buildInputs = [ - cpp-utilities zlib + cpp-utilities + zlib ]; cmakeFlags = [ @@ -36,4 +38,3 @@ stdenv.mkDerivation rec { platforms = platforms.all; }; } - diff --git a/pkgs/by-name/ta/tagref/package.nix b/pkgs/by-name/ta/tagref/package.nix index b54545f8368546..13ec01f5900d1b 100644 --- a/pkgs/by-name/ta/tagref/package.nix +++ b/pkgs/by-name/ta/tagref/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "tagref"; diff --git a/pkgs/by-name/ta/tagtime/package.nix b/pkgs/by-name/ta/tagtime/package.nix index 9ec36c26defcfd..0baf2e05afef63 100644 --- a/pkgs/by-name/ta/tagtime/package.nix +++ b/pkgs/by-name/ta/tagtime/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, perl, xterm, coreutils }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, + xterm, + coreutils, +}: stdenv.mkDerivation { pname = "tagtime"; diff --git a/pkgs/by-name/ta/tagutil/package.nix b/pkgs/by-name/ta/tagutil/package.nix index 51aaf75cddbcfa..61b2945dd18e59 100644 --- a/pkgs/by-name/ta/tagutil/package.nix +++ b/pkgs/by-name/ta/tagutil/package.nix @@ -1,7 +1,14 @@ -{ stdenv, lib, fetchFromGitHub -, pkg-config, cmake, libyaml -, jansson, libvorbis, taglib -, zlib +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + cmake, + libyaml, + jansson, + libvorbis, + taglib, + zlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ta/tahoe-lafs/package.nix b/pkgs/by-name/ta/tahoe-lafs/package.nix index 10d21934b2c0ac..d478dd5e467065 100644 --- a/pkgs/by-name/ta/tahoe-lafs/package.nix +++ b/pkgs/by-name/ta/tahoe-lafs/package.nix @@ -1,4 +1,10 @@ -{ lib, nettools, python311, texinfo, fetchFromGitHub }: +{ + lib, + nettools, + python311, + texinfo, + fetchFromGitHub, +}: # FAILURES: The "running build_ext" phase fails to compile Twisted # plugins, because it tries to write them into Twisted's (immutable) @@ -43,7 +49,11 @@ python3Packages.buildPythonApplication rec { sha256 = "sha256-MuD/ZY+die7RCsuVdcePSD0DdwatXRi7CxW2iFt22L0="; }; - outputs = [ "out" "doc" "info" ]; + outputs = [ + "out" + "doc" + "info" + ]; postPatch = '' sed -i "src/allmydata/util/iputil.py" \ @@ -82,18 +92,48 @@ python3Packages.buildPythonApplication rec { ) ''; - nativeBuildInputs = with python3Packages; [ sphinx texinfo ]; + nativeBuildInputs = with python3Packages; [ + sphinx + texinfo + ]; # The `backup' command requires `sqlite3'. - propagatedBuildInputs = with python3Packages; [ - appdirs beautifulsoup4 characteristic distro eliot fixtures foolscap future - html5lib magic-wormhole netifaces pyasn1 pycrypto pyutil pyyaml recommonmark - service-identity simplejson sphinx-rtd-theme testtools treq twisted zfec - zope-interface - ] ++ twisted.optional-dependencies.tls + propagatedBuildInputs = + with python3Packages; + [ + appdirs + beautifulsoup4 + characteristic + distro + eliot + fixtures + foolscap + future + html5lib + magic-wormhole + netifaces + pyasn1 + pycrypto + pyutil + pyyaml + recommonmark + service-identity + simplejson + sphinx-rtd-theme + testtools + treq + twisted + zfec + zope-interface + ] + ++ twisted.optional-dependencies.tls ++ twisted.optional-dependencies.conch; - nativeCheckInputs = with python3Packages; [ mock hypothesis twisted ]; + nativeCheckInputs = with python3Packages; [ + mock + hypothesis + twisted + ]; # Install the documentation. postInstall = '' @@ -124,7 +164,10 @@ python3Packages.buildPythonApplication rec { are unavailable, malfunctioning, or malicious. ''; homepage = "https://tahoe-lafs.org/"; - license = [ licenses.gpl2Plus /* or */ "TGPPLv1+" ]; + license = [ + licenses.gpl2Plus # or + "TGPPLv1+" + ]; maintainers = with lib.maintainers; [ MostAwesomeDude ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/ta/tailer/package.nix b/pkgs/by-name/ta/tailer/package.nix index 9e8c31790af802..d9899b7d2cac67 100644 --- a/pkgs/by-name/ta/tailer/package.nix +++ b/pkgs/by-name/ta/tailer/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, tailer +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + tailer, }: buildGoModule rec { diff --git a/pkgs/by-name/ta/tailor-gui/package.nix b/pkgs/by-name/ta/tailor-gui/package.nix index 74bfbeafeac9b8..ab26609fb7dd35 100644 --- a/pkgs/by-name/ta/tailor-gui/package.nix +++ b/pkgs/by-name/ta/tailor-gui/package.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, rustPlatform -, cargo -, rustc -, pkg-config -, desktop-file-utils -, appstream-glib -, wrapGAppsHook4 -, meson -, ninja -, libadwaita -, gtk4 -, tuxedo-rs +{ + stdenv, + lib, + rustPlatform, + cargo, + rustc, + pkg-config, + desktop-file-utils, + appstream-glib, + wrapGAppsHook4, + meson, + ninja, + libadwaita, + gtk4, + tuxedo-rs, }: let src = tuxedo-rs.src; @@ -21,7 +22,12 @@ let in stdenv.mkDerivation { - inherit src sourceRoot pname version; + inherit + src + sourceRoot + pname + version + ; cargoDeps = rustPlatform.fetchCargoTarball { inherit src sourceRoot; @@ -55,7 +61,10 @@ stdenv.mkDerivation { ''; homepage = "https://github.com/AaronErhardt/tuxedo-rs"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ mrcjkb xaverdh ]; + maintainers = with maintainers; [ + mrcjkb + xaverdh + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/ta/tailscale-gitops-pusher/package.nix b/pkgs/by-name/ta/tailscale-gitops-pusher/package.nix index 7934dfc60fcdb0..5d76fe6f7a4564 100644 --- a/pkgs/by-name/ta/tailscale-gitops-pusher/package.nix +++ b/pkgs/by-name/ta/tailscale-gitops-pusher/package.nix @@ -1,10 +1,16 @@ -{ lib -, tailscale -, buildGo123Module +{ + lib, + tailscale, + buildGo123Module, }: buildGo123Module { - inherit (tailscale) version src vendorHash CGO_ENABLED; + inherit (tailscale) + version + src + vendorHash + CGO_ENABLED + ; pname = "tailscale-gitops-pusher"; subPackages = [ diff --git a/pkgs/by-name/ta/tailscale-nginx-auth/package.nix b/pkgs/by-name/ta/tailscale-nginx-auth/package.nix index 9423cb2e46a6a1..e160f23c391110 100644 --- a/pkgs/by-name/ta/tailscale-nginx-auth/package.nix +++ b/pkgs/by-name/ta/tailscale-nginx-auth/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, buildGo123Module, tailscale }: +{ + lib, + stdenv, + buildGo123Module, + tailscale, +}: buildGo123Module { pname = "tailscale-nginx-auth"; diff --git a/pkgs/by-name/ta/tailscale-systray/package.nix b/pkgs/by-name/ta/tailscale-systray/package.nix index 842b66ee7cc754..9bff3c33a57ebc 100644 --- a/pkgs/by-name/ta/tailscale-systray/package.nix +++ b/pkgs/by-name/ta/tailscale-systray/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, pkg-config -, gtk3 -, libayatana-appindicator +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + gtk3, + libayatana-appindicator, }: buildGoModule rec { pname = "tailscale-systray"; @@ -19,7 +20,10 @@ buildGoModule rec { vendorHash = "sha256-YJ74SeZAMS+dXyoPhPTJ3L+5uL5bF8gumhMOqfvmlms="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk3 libayatana-appindicator ]; + buildInputs = [ + gtk3 + libayatana-appindicator + ]; proxyVendor = true; diff --git a/pkgs/by-name/ta/tailscale/package.nix b/pkgs/by-name/ta/tailscale/package.nix index a58d312c02b8cc..db6b7cd6c25a9c 100644 --- a/pkgs/by-name/ta/tailscale/package.nix +++ b/pkgs/by-name/ta/tailscale/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, buildGo123Module -, fetchFromGitHub -, fetchpatch -, makeWrapper -, getent -, iproute2 -, iptables -, shadow -, procps -, nixosTests -, installShellFiles -, tailscale-nginx-auth +{ + lib, + stdenv, + buildGo123Module, + fetchFromGitHub, + fetchpatch, + makeWrapper, + getent, + iproute2, + iptables, + shadow, + procps, + nixosTests, + installShellFiles, + tailscale-nginx-auth, }: let @@ -21,7 +22,10 @@ buildGo123Module { pname = "tailscale"; inherit version; - outputs = [ "out" "derper" ]; + outputs = [ + "out" + "derper" + ]; src = fetchFromGitHub { owner = "tailscale"; @@ -41,11 +45,16 @@ buildGo123Module { vendorHash = "sha256-0VB7q9HKd5/QKaWBMpCYycRRiNTWCEjUMc3g3z6agc8="; - nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ makeWrapper ] ++ [ installShellFiles ]; + nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ makeWrapper ] ++ [ + installShellFiles + ]; CGO_ENABLED = 0; - subPackages = [ "cmd/derper" "cmd/tailscaled" ]; + subPackages = [ + "cmd/derper" + "cmd/tailscaled" + ]; ldflags = [ "-w" @@ -60,22 +69,32 @@ buildGo123Module { doCheck = false; - postInstall = '' - ln -s $out/bin/tailscaled $out/bin/tailscale - moveToOutput "bin/derper" "$derper" - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - wrapProgram $out/bin/tailscaled \ - --prefix PATH : ${lib.makeBinPath [ iproute2 iptables getent shadow ]} \ - --suffix PATH : ${lib.makeBinPath [ procps ]} - sed -i -e "s#/usr/sbin#$out/bin#" -e "/^EnvironmentFile/d" ./cmd/tailscaled/tailscaled.service - install -D -m0444 -t $out/lib/systemd/system ./cmd/tailscaled/tailscaled.service - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - local INSTALL="$out/bin/tailscale" - installShellCompletion --cmd tailscale \ - --bash <($out/bin/tailscale completion bash) \ - --fish <($out/bin/tailscale completion fish) \ - --zsh <($out/bin/tailscale completion zsh) - ''; + postInstall = + '' + ln -s $out/bin/tailscaled $out/bin/tailscale + moveToOutput "bin/derper" "$derper" + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + wrapProgram $out/bin/tailscaled \ + --prefix PATH : ${ + lib.makeBinPath [ + iproute2 + iptables + getent + shadow + ] + } \ + --suffix PATH : ${lib.makeBinPath [ procps ]} + sed -i -e "s#/usr/sbin#$out/bin#" -e "/^EnvironmentFile/d" ./cmd/tailscaled/tailscaled.service + install -D -m0444 -t $out/lib/systemd/system ./cmd/tailscaled/tailscaled.service + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + local INSTALL="$out/bin/tailscale" + installShellCompletion --cmd tailscale \ + --bash <($out/bin/tailscale completion bash) \ + --fish <($out/bin/tailscale completion fish) \ + --zsh <($out/bin/tailscale completion zsh) + ''; passthru.tests = { inherit (nixosTests) headscale; @@ -88,6 +107,11 @@ buildGo123Module { changelog = "https://github.com/tailscale/tailscale/releases/tag/v${version}"; license = licenses.bsd3; mainProgram = "tailscale"; - maintainers = with maintainers; [ mbaillie jk mfrw pyrox0 ]; + maintainers = with maintainers; [ + mbaillie + jk + mfrw + pyrox0 + ]; }; } diff --git a/pkgs/by-name/ta/tailscalesd/package.nix b/pkgs/by-name/ta/tailscalesd/package.nix index 1dbbdf09a9d892..718b05df48d913 100644 --- a/pkgs/by-name/ta/tailscalesd/package.nix +++ b/pkgs/by-name/ta/tailscalesd/package.nix @@ -1,7 +1,7 @@ { lib, buildGoModule, - fetchFromGitHub + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ta/tailspin/package.nix b/pkgs/by-name/ta/tailspin/package.nix index bb4c046462b03b..52af0672f4e901 100644 --- a/pkgs/by-name/ta/tailspin/package.nix +++ b/pkgs/by-name/ta/tailspin/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ta/taizen/package.nix b/pkgs/by-name/ta/taizen/package.nix index 01b08de3d4e4ab..1554295613f4b6 100644 --- a/pkgs/by-name/ta/taizen/package.nix +++ b/pkgs/by-name/ta/taizen/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, fetchpatch2 -, pkg-config -, ncurses -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + fetchpatch2, + pkg-config, + ncurses, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -33,12 +34,14 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - ncurses - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + ncurses + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; meta = with lib; { description = "curses based mediawiki browser"; diff --git a/pkgs/by-name/ta/takao/package.nix b/pkgs/by-name/ta/takao/package.nix index 353287d4d77b25..6b9a13961dad7d 100644 --- a/pkgs/by-name/ta/takao/package.nix +++ b/pkgs/by-name/ta/takao/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "takao"; diff --git a/pkgs/by-name/ta/taktuk/package.nix b/pkgs/by-name/ta/taktuk/package.nix index 002bc9da263156..b9d7b8f773a317 100644 --- a/pkgs/by-name/ta/taktuk/package.nix +++ b/pkgs/by-name/ta/taktuk/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { version = "3.7.7"; @@ -12,7 +17,7 @@ stdenv.mkDerivation rec { }; preBuild = '' - substituteInPlace ./taktuk --replace "/usr/bin/perl" "${perl}/bin/perl" + substituteInPlace ./taktuk --replace "/usr/bin/perl" "${perl}/bin/perl" ''; meta = { @@ -32,4 +37,3 @@ stdenv.mkDerivation rec { platforms = lib.platforms.linux; }; } - diff --git a/pkgs/by-name/ta/talecast/package.nix b/pkgs/by-name/ta/talecast/package.nix index e18d5fd5f22c69..de9ee864b9d3f1 100644 --- a/pkgs/by-name/ta/talecast/package.nix +++ b/pkgs/by-name/ta/talecast/package.nix @@ -8,7 +8,7 @@ nix-update-script, stdenv, testers, - talecast + talecast, }: rustPlatform.buildRustPackage rec { @@ -24,8 +24,9 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; + buildInputs = [ + openssl + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; passthru = { updateScript = nix-update-script { }; @@ -37,6 +38,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/TBS1996/TaleCast"; license = lib.licenses.mit; mainProgram = "talecast"; - maintainers = with lib.maintainers; [ confusedalex getchoo ]; + maintainers = with lib.maintainers; [ + confusedalex + getchoo + ]; }; } diff --git a/pkgs/by-name/ta/talentedhack/package.nix b/pkgs/by-name/ta/talentedhack/package.nix index 387fd4f5a0c612..648d5e3b486486 100644 --- a/pkgs/by-name/ta/talentedhack/package.nix +++ b/pkgs/by-name/ta/talentedhack/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, lv2, fftwFloat, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + lv2, + fftwFloat, + pkg-config, +}: stdenv.mkDerivation rec { pname = "talentedhack"; @@ -13,7 +20,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ lv2 fftwFloat ]; + buildInputs = [ + lv2 + fftwFloat + ]; # To avoid name clashes, plugins should be compiled with symbols hidden, except for `lv2_descriptor`: preConfigure = '' diff --git a/pkgs/by-name/ta/talkfilters/package.nix b/pkgs/by-name/ta/talkfilters/package.nix index 1560af6d9967f5..6222b80b159f0e 100644 --- a/pkgs/by-name/ta/talkfilters/package.nix +++ b/pkgs/by-name/ta/talkfilters/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let pname = "talkfilters"; @@ -23,4 +27,3 @@ stdenv.mkDerivation { platforms = with lib.platforms; unix; }; } - diff --git a/pkgs/by-name/ta/talloc/package.nix b/pkgs/by-name/ta/talloc/package.nix index eb1525fb9acbe3..2a9395a1c41ad5 100644 --- a/pkgs/by-name/ta/talloc/package.nix +++ b/pkgs/by-name/ta/talloc/package.nix @@ -1,15 +1,17 @@ -{ lib, stdenv -, fetchurl -, python3 -, pkg-config -, readline -, libxslt -, libxcrypt -, docbook-xsl-nons -, docbook_xml_dtd_42 -, fixDarwinDylibNames -, wafHook -, buildPackages +{ + lib, + stdenv, + fetchurl, + python3, + pkg-config, + readline, + libxslt, + libxcrypt, + docbook-xsl-nons, + docbook_xml_dtd_42, + fixDarwinDylibNames, + wafHook, + buildPackages, }: stdenv.mkDerivation rec { @@ -21,15 +23,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-hez55GXiD5j5lQpS6aQR4UMgvFVfolfYdpe356mx2KY="; }; - nativeBuildInputs = [ - pkg-config - python3 - wafHook - docbook-xsl-nons - docbook_xml_dtd_42 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ]; + nativeBuildInputs = + [ + pkg-config + python3 + wafHook + docbook-xsl-nons + docbook_xml_dtd_42 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ]; buildInputs = [ python3 @@ -47,14 +51,16 @@ stdenv.mkDerivation rec { wafPath = "buildtools/bin/waf"; - wafConfigureFlags = [ - "--enable-talloc-compat1" - "--bundled-libraries=NONE" - "--builtin-libraries=replace" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "--cross-compile" - "--cross-execute=${stdenv.hostPlatform.emulator buildPackages}" - ]; + wafConfigureFlags = + [ + "--enable-talloc-compat1" + "--bundled-libraries=NONE" + "--builtin-libraries=replace" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "--cross-compile" + "--cross-execute=${stdenv.hostPlatform.emulator buildPackages}" + ]; # python-config from build Python gives incorrect values when cross-compiling. # If python-config is not found, the build falls back to using the sysconfig diff --git a/pkgs/by-name/ta/talosctl/package.nix b/pkgs/by-name/ta/talosctl/package.nix index b4c51484e2ca3f..3d6f111c7ad356 100644 --- a/pkgs/by-name/ta/talosctl/package.nix +++ b/pkgs/by-name/ta/talosctl/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "talosctl"; @@ -13,7 +18,10 @@ buildGoModule rec { vendorHash = "sha256-/Xt/WZ+5ptxsiUkm6mplilB9gqv3mz+j7tyNikzJtkA="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; env.GOWORK = "off"; diff --git a/pkgs/by-name/ta/tambura/package.nix b/pkgs/by-name/ta/tambura/package.nix index 9fcf9bb70ef93c..5c7fb003ba3d03 100644 --- a/pkgs/by-name/ta/tambura/package.nix +++ b/pkgs/by-name/ta/tambura/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, faust2jaqt, faust2lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + faust2jaqt, + faust2lv2, +}: stdenv.mkDerivation rec { pname = "Tambura"; version = "1.0"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "1w80cmiyzca1wirf5gypg3hcix1ky777id8wnd3k92mn1jf4a24y"; }; - buildInputs = [ faust2jaqt faust2lv2 ]; + buildInputs = [ + faust2jaqt + faust2lv2 + ]; dontWrapQtApps = true; diff --git a/pkgs/by-name/ta/tamsyn/package.nix b/pkgs/by-name/ta/tamsyn/package.nix index 59ddfb5011e479..32b2bb91bfebfe 100644 --- a/pkgs/by-name/ta/tamsyn/package.nix +++ b/pkgs/by-name/ta/tamsyn/package.nix @@ -1,17 +1,27 @@ -{ lib, stdenv, fetchurl, fontforge, xorg }: +{ + lib, + stdenv, + fetchurl, + fontforge, + xorg, +}: let version = "1.11"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "tamsyn-font"; inherit version; src = fetchurl { url = "http://www.fial.com/~scott/tamsyn-font/download/tamsyn-font-${version}.tar.gz"; sha256 = "0kpjzdj8sv5871b8827mjgj9dswk75h94jj5iia2bds18ih1pglp"; - }; + }; - nativeBuildInputs = [ fontforge xorg.mkfontscale ]; + nativeBuildInputs = [ + fontforge + xorg.mkfontscale + ]; unpackPhase = '' tar -xzf $src --strip-components=1 @@ -48,4 +58,3 @@ in stdenv.mkDerivation { maintainers = [ maintainers.rps ]; }; } - diff --git a/pkgs/by-name/ta/tamzen/package.nix b/pkgs/by-name/ta/tamzen/package.nix index e8706c1971c6a6..632054b9e4d705 100644 --- a/pkgs/by-name/ta/tamzen/package.nix +++ b/pkgs/by-name/ta/tamzen/package.nix @@ -1,4 +1,9 @@ -{ fetchFromGitHub, xorg, lib, stdenv }: +{ + fetchFromGitHub, + xorg, + lib, + stdenv, +}: stdenv.mkDerivation rec { pname = "tamzen-font"; @@ -22,16 +27,15 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Bitmapped programming font based on Tamsyn"; longDescription = '' - Tamzen is a monospace bitmap font. It is programmatically forked - from Tamsyn version 1.11, which backports glyphs from older - versions while deleting deliberately empty glyphs to allow - secondary/fallback fonts to provide real glyphs at those codepoints. - Tamzen also has fonts that additionally provide the Powerline - symbols. + Tamzen is a monospace bitmap font. It is programmatically forked + from Tamsyn version 1.11, which backports glyphs from older + versions while deleting deliberately empty glyphs to allow + secondary/fallback fonts to provide real glyphs at those codepoints. + Tamzen also has fonts that additionally provide the Powerline + symbols. ''; homepage = "https://github.com/sunaku/tamzen-font"; license = licenses.free; maintainers = with maintainers; [ wishfort36 ]; }; } - diff --git a/pkgs/by-name/ta/tandem-aligner/package.nix b/pkgs/by-name/ta/tandem-aligner/package.nix index d44489debbb62c..fdfd781a813345 100644 --- a/pkgs/by-name/ta/tandem-aligner/package.nix +++ b/pkgs/by-name/ta/tandem-aligner/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + zlib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ta/tangerine/package.nix b/pkgs/by-name/ta/tangerine/package.nix index 1ec2d6b362b982..933114e62d7d4d 100644 --- a/pkgs/by-name/ta/tangerine/package.nix +++ b/pkgs/by-name/ta/tangerine/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, ncurses -, SDL2 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + ncurses, + SDL2, }: stdenv.mkDerivation { @@ -27,7 +28,10 @@ stdenv.mkDerivation { ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ ncurses SDL2 ]; + buildInputs = [ + ncurses + SDL2 + ]; meta = with lib; { description = "System for creating 3D models procedurally from a set of Signed Distance Function (SDF) primitive shapes and combining operators"; @@ -37,4 +41,3 @@ stdenv.mkDerivation { broken = stdenv.hostPlatform.isDarwin; # third_party/naive-surface-nets doesn't find std::execution }; } - diff --git a/pkgs/by-name/ta/tango/package.nix b/pkgs/by-name/ta/tango/package.nix index 11b7275d1e94ca..3fb877a9a9a7cf 100644 --- a/pkgs/by-name/ta/tango/package.nix +++ b/pkgs/by-name/ta/tango/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ta/tangram/package.nix b/pkgs/by-name/ta/tangram/package.nix index c119733197ef21..97ef4105b0ea5f 100644 --- a/pkgs/by-name/ta/tangram/package.nix +++ b/pkgs/by-name/ta/tangram/package.nix @@ -1,26 +1,27 @@ -{ stdenv -, lib -, fetchFromGitHub -, appstream-glib -, desktop-file-utils -, gdk-pixbuf -, gettext -, gjs -, glib -, glib-networking -, gobject-introspection -, gsettings-desktop-schemas -, gtk4 -, libadwaita -, gst_all_1 -, hicolor-icon-theme -, meson -, ninja -, pkg-config -, python3 -, webkitgtk_6_0 -, blueprint-compiler -, wrapGAppsHook4 +{ + stdenv, + lib, + fetchFromGitHub, + appstream-glib, + desktop-file-utils, + gdk-pixbuf, + gettext, + gjs, + glib, + glib-networking, + gobject-introspection, + gsettings-desktop-schemas, + gtk4, + libadwaita, + gst_all_1, + hicolor-icon-theme, + meson, + ninja, + pkg-config, + python3, + webkitgtk_6_0, + blueprint-compiler, + wrapGAppsHook4, }: stdenv.mkDerivation rec { @@ -49,22 +50,24 @@ stdenv.mkDerivation rec { wrapGAppsHook4 ]; - buildInputs = [ - gdk-pixbuf - gjs - glib - glib-networking - gsettings-desktop-schemas - gtk4 - libadwaita - webkitgtk_6_0 - ] ++ (with gst_all_1; [ - gstreamer - gst-libav - gst-plugins-base - (gst-plugins-good.override { gtkSupport = true; }) - gst-plugins-bad - ]); + buildInputs = + [ + gdk-pixbuf + gjs + glib + glib-networking + gsettings-desktop-schemas + gtk4 + libadwaita + webkitgtk_6_0 + ] + ++ (with gst_all_1; [ + gstreamer + gst-libav + gst-plugins-base + (gst-plugins-good.override { gtkSupport = true; }) + gst-plugins-bad + ]); dontPatchShebangs = true; @@ -86,6 +89,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/sonnyp/Tangram"; license = licenses.gpl3Only; platforms = platforms.linux; - maintainers = with maintainers; [ austinbutler chuangzhu ]; + maintainers = with maintainers; [ + austinbutler + chuangzhu + ]; }; } diff --git a/pkgs/by-name/ta/tanidvr/package.nix b/pkgs/by-name/ta/tanidvr/package.nix index 74987e00408024..396e76224cfd0e 100644 --- a/pkgs/by-name/ta/tanidvr/package.nix +++ b/pkgs/by-name/ta/tanidvr/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "tanidvr"; diff --git a/pkgs/by-name/ta/tap-plugins/package.nix b/pkgs/by-name/ta/tap-plugins/package.nix index 7cd64eb420868e..aeb56d3375b5c2 100644 --- a/pkgs/by-name/ta/tap-plugins/package.nix +++ b/pkgs/by-name/ta/tap-plugins/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, ladspa-sdk +{ + lib, + stdenv, + fetchFromGitHub, + ladspa-sdk, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ta/taplo/package.nix b/pkgs/by-name/ta/taplo/package.nix index d353127070a8ee..4336cf5d2f76f3 100644 --- a/pkgs/by-name/ta/taplo/package.nix +++ b/pkgs/by-name/ta/taplo/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, openssl -, stdenv -, darwin -, withLsp ? true +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + openssl, + stdenv, + darwin, + withLsp ? true, }: rustPlatform.buildRustPackage rec { @@ -24,12 +25,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; buildFeatures = lib.optional withLsp "lsp"; diff --git a/pkgs/by-name/ta/taproot-assets/package.nix b/pkgs/by-name/ta/taproot-assets/package.nix index d560d3b6db8019..04618d79b0982e 100644 --- a/pkgs/by-name/ta/taproot-assets/package.nix +++ b/pkgs/by-name/ta/taproot-assets/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { @@ -16,9 +17,15 @@ buildGoModule rec { vendorHash = "sha256-IFzYW5vAtBoUC2ebFYnxS/TojQR4kXxQACNbyn2ZkCs="; - subPackages = [ "cmd/tapcli" "cmd/tapd" ]; + subPackages = [ + "cmd/tapcli" + "cmd/tapd" + ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Daemon for the Taro protocol specification"; diff --git a/pkgs/by-name/ta/tapview/package.nix b/pkgs/by-name/ta/tapview/package.nix index 718ef854225a34..bd9918eb7b7505 100644 --- a/pkgs/by-name/ta/tapview/package.nix +++ b/pkgs/by-name/ta/tapview/package.nix @@ -1,7 +1,8 @@ -{ asciidoctor -, fetchFromGitLab -, lib -, stdenv +{ + asciidoctor, + fetchFromGitLab, + lib, + stdenv, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ta/tar2ext4/package.nix b/pkgs/by-name/ta/tar2ext4/package.nix index ddc27c1029e2b7..c33f254122318f 100644 --- a/pkgs/by-name/ta/tar2ext4/package.nix +++ b/pkgs/by-name/ta/tar2ext4/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "tar2ext4"; diff --git a/pkgs/by-name/ta/tarantool/package.nix b/pkgs/by-name/ta/tarantool/package.nix index 6526fdefae694c..b38fce77c26a7f 100644 --- a/pkgs/by-name/ta/tarantool/package.nix +++ b/pkgs/by-name/ta/tarantool/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, zlib -, openssl -, c-ares -, readline -, icu -, git -, gbenchmark -, nghttp2 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, + openssl, + c-ares, + readline, + icu, + git, + gbenchmark, + nghttp2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ta/target-isns/package.nix b/pkgs/by-name/ta/target-isns/package.nix index 397e414490c21c..aac984c348070a 100644 --- a/pkgs/by-name/ta/target-isns/package.nix +++ b/pkgs/by-name/ta/target-isns/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, cmake, fetchFromGitHub, fetchpatch } : +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "target-isns"; diff --git a/pkgs/by-name/ta/targetcli/package.nix b/pkgs/by-name/ta/targetcli/package.nix index a0a2aad949fd7f..9498717b22d6d0 100644 --- a/pkgs/by-name/ta/targetcli/package.nix +++ b/pkgs/by-name/ta/targetcli/package.nix @@ -1,4 +1,12 @@ -{ lib, python3, fetchFromGitHub, nixosTests, wrapGAppsNoGuiHook, gobject-introspection, glib }: +{ + lib, + python3, + fetchFromGitHub, + nixosTests, + wrapGAppsNoGuiHook, + gobject-introspection, + glib, +}: python3.pkgs.buildPythonApplication rec { pname = "targetcli"; @@ -11,10 +19,17 @@ python3.pkgs.buildPythonApplication rec { hash = "sha256-9QYo7jGk9iWr26j0qPQCqYsJ+vLXAsO4Xs7+7VT9/yc="; }; - nativeBuildInputs = [ wrapGAppsNoGuiHook gobject-introspection ]; + nativeBuildInputs = [ + wrapGAppsNoGuiHook + gobject-introspection + ]; buildInputs = [ glib ]; - propagatedBuildInputs = with python3.pkgs; [ configshell rtslib pygobject3 ]; + propagatedBuildInputs = with python3.pkgs; [ + configshell + rtslib + pygobject3 + ]; postInstall = '' install -D targetcli.8 -t $out/share/man/man8/ diff --git a/pkgs/by-name/ta/tarsnap/package.nix b/pkgs/by-name/ta/tarsnap/package.nix index 83d205bb9b50b9..ddc121ad7ed9f8 100644 --- a/pkgs/by-name/ta/tarsnap/package.nix +++ b/pkgs/by-name/ta/tarsnap/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, openssl, zlib, e2fsprogs, bzip2 }: +{ + lib, + stdenv, + fetchurl, + openssl, + zlib, + e2fsprogs, + bzip2, +}: let zshCompletion = fetchurl { @@ -31,15 +39,23 @@ stdenv.mkDerivation rec { install -m 444 -D ${zshCompletion} $out/share/zsh/site-functions/_tarsnap ''; - buildInputs = [ openssl zlib ] ++ lib.optional stdenv.hostPlatform.isLinux e2fsprogs - ++ lib.optional stdenv.hostPlatform.isDarwin bzip2; + buildInputs = + [ + openssl + zlib + ] + ++ lib.optional stdenv.hostPlatform.isLinux e2fsprogs + ++ lib.optional stdenv.hostPlatform.isDarwin bzip2; meta = { description = "Online backups for the truly paranoid"; - homepage = "http://www.tarsnap.com/"; - license = lib.licenses.unfree; - platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ thoughtpolice roconnor ]; + homepage = "http://www.tarsnap.com/"; + license = lib.licenses.unfree; + platforms = lib.platforms.unix; + maintainers = with lib.maintainers; [ + thoughtpolice + roconnor + ]; mainProgram = "tarsnap"; }; } diff --git a/pkgs/by-name/ta/tarsnapper/package.nix b/pkgs/by-name/ta/tarsnapper/package.nix index 204c1ffd7b474a..b1afa06f6008b3 100644 --- a/pkgs/by-name/ta/tarsnapper/package.nix +++ b/pkgs/by-name/ta/tarsnapper/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3Packages -, fetchFromGitHub -, fetchpatch -, tarsnap +{ + lib, + python3Packages, + fetchFromGitHub, + fetchpatch, + tarsnap, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ta/tarssh/package.nix b/pkgs/by-name/ta/tarssh/package.nix index d2ce6e56c8c8ec..02d7cd8e70cc85 100644 --- a/pkgs/by-name/ta/tarssh/package.nix +++ b/pkgs/by-name/ta/tarssh/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, rustPlatform, lib }: +{ + fetchFromGitHub, + rustPlatform, + lib, +}: rustPlatform.buildRustPackage rec { pname = "tarssh"; @@ -18,7 +22,7 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/Freaky/tarssh"; license = [ licenses.mit ]; maintainers = with maintainers; [ sohalt ]; - platforms = platforms.unix ; + platforms = platforms.unix; mainProgram = "tarssh"; }; } diff --git a/pkgs/by-name/ta/tart/package.nix b/pkgs/by-name/ta/tart/package.nix index f5a113653b8f17..297aece524ad76 100644 --- a/pkgs/by-name/ta/tart/package.nix +++ b/pkgs/by-name/ta/tart/package.nix @@ -1,20 +1,22 @@ -{ lib -, stdenvNoCC -, fetchurl -, makeWrapper -# Softnet support ("--net-softnet") is disabled by default as it requires -# passwordless-sudo when installed through nix. Alternatively users may install -# softnet through other means with "setuid"-bit enabled. -# See https://github.com/cirruslabs/softnet#installing -, enableSoftnet ? false, softnet +{ + lib, + stdenvNoCC, + fetchurl, + makeWrapper, + # Softnet support ("--net-softnet") is disabled by default as it requires + # passwordless-sudo when installed through nix. Alternatively users may install + # softnet through other means with "setuid"-bit enabled. + # See https://github.com/cirruslabs/softnet#installing + enableSoftnet ? false, + softnet, }: stdenvNoCC.mkDerivation (finalAttrs: { pname = "tart"; version = "2.20.2"; src = fetchurl { - url = "https://github.com/cirruslabs/tart/releases/download/${finalAttrs.version}/tart-arm64.tar.gz"; - hash = "sha256-caHuBTRpbmFbmTlDRnxZyGM6F95iKjMhKbPTez5Hecc="; + url = "https://github.com/cirruslabs/tart/releases/download/${finalAttrs.version}/tart-arm64.tar.gz"; + hash = "sha256-caHuBTRpbmFbmTlDRnxZyGM6F95iKjMhKbPTez5Hecc="; }; sourceRoot = "."; @@ -39,7 +41,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { description = "macOS VMs on Apple Silicon to use in CI and other automations"; homepage = "https://tart.run"; license = licenses.fairsource09; - maintainers = with maintainers; [ emilytrau aduh95 ]; + maintainers = with maintainers; [ + emilytrau + aduh95 + ]; mainProgram = finalAttrs.pname; platforms = [ "aarch64-darwin" ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; diff --git a/pkgs/by-name/ta/taschenrechner/package.nix b/pkgs/by-name/ta/taschenrechner/package.nix index 391226b72b1542..fa8d7170dd6fff 100644 --- a/pkgs/by-name/ta/taschenrechner/package.nix +++ b/pkgs/by-name/ta/taschenrechner/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitLab +{ + lib, + rustPlatform, + fetchFromGitLab, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ta/taskchampion-sync-server/package.nix b/pkgs/by-name/ta/taskchampion-sync-server/package.nix index 1e41d4751f4007..7782f7b38694b6 100644 --- a/pkgs/by-name/ta/taskchampion-sync-server/package.nix +++ b/pkgs/by-name/ta/taskchampion-sync-server/package.nix @@ -7,12 +7,12 @@ rustPlatform.buildRustPackage rec { pname = "taskchampion-sync-server"; version = "0.4.1-unstable-2024-08-20"; src = fetchFromGitHub { - owner = "GothenburgBitFactory"; - repo = "taskchampion-sync-server"; - rev = "af918bdf0dea7f7b6e920680c947fc37b37ffffb"; - fetchSubmodules = false; - hash = "sha256-BTGD7hZysmOlsT2W+gqj8+Sj6iBN9Jwiyzq5D03PDzM="; - }; + owner = "GothenburgBitFactory"; + repo = "taskchampion-sync-server"; + rev = "af918bdf0dea7f7b6e920680c947fc37b37ffffb"; + fetchSubmodules = false; + hash = "sha256-BTGD7hZysmOlsT2W+gqj8+Sj6iBN9Jwiyzq5D03PDzM="; + }; cargoHash = "sha256-/HfkE+R8JoNGkCCNQpE/JjGSqPHvjCPnTjOFPCFfJ7A="; @@ -23,7 +23,7 @@ rustPlatform.buildRustPackage rec { description = "Sync server for Taskwarrior 3"; license = lib.licenses.mit; homepage = "https://github.com/GothenburgBitFactory/taskchampion-sync-server"; - maintainers = with lib.maintainers; [mlaradji]; + maintainers = with lib.maintainers; [ mlaradji ]; mainProgram = "taskchampion-sync-server"; }; } diff --git a/pkgs/by-name/ta/taskjuggler/gemset.nix b/pkgs/by-name/ta/taskjuggler/gemset.nix index b782b37705a29a..aa9de0e564e1d2 100644 --- a/pkgs/by-name/ta/taskjuggler/gemset.nix +++ b/pkgs/by-name/ta/taskjuggler/gemset.nix @@ -1,137 +1,148 @@ { date = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03skfikihpx37rc27vr3hwrb057gxnmdzxhmzd4bf4jpkl0r55w1"; type = "gem"; }; version = "3.3.3"; }; mail = { - dependencies = ["mini_mime" "net-imap" "net-pop" "net-smtp"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "mini_mime" + "net-imap" + "net-pop" + "net-smtp" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bf9pysw1jfgynv692hhaycfxa8ckay1gjw5hz3madrbrynryfzc"; type = "gem"; }; version = "2.8.1"; }; mini_mime = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lbim375gw2dk6383qirz13hgdmxlan0vc5da2l072j3qw6fqjm5"; type = "gem"; }; version = "1.1.2"; }; net-imap = { - dependencies = ["date" "net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "date" + "net-protocol" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d996zf3g8xz244791b0qsl9vr7zg4lqnnmf9k2kshr9lki5jam8"; type = "gem"; }; version = "0.3.4"; }; net-pop = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wyz41jd4zpjn0v1xsf9j778qx1vfrl24yc20cpmph8k42c4x2w4"; type = "gem"; }; version = "0.1.2"; }; net-protocol = { - dependencies = ["timeout"]; - groups = ["default"]; - platforms = []; + dependencies = [ "timeout" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dxckrlw4q1lcn3qg4mimmjazmg9bma5gllv72f8js3p36fb3b91"; type = "gem"; }; version = "0.2.1"; }; net-smtp = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c6md06hm5bf6rv53sk54dl2vg038pg8kglwv3rayx0vk2mdql9x"; type = "gem"; }; version = "0.3.3"; }; sync = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1z9qlq4icyiv3hz1znvsq1wz2ccqjb1zwd6gkvnwg6n50z65d0v6"; type = "gem"; }; version = "0.5.0"; }; taskjuggler = { - dependencies = ["mail" "term-ansicolor"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "mail" + "term-ansicolor" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07fagka8nl29xwwzfhxx89gp34m5hih5vnq4sha1z814004md53j"; type = "gem"; }; version = "3.7.2"; }; term-ansicolor = { - dependencies = ["tins"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tins" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xq5kci9215skdh27npyd3y55p812v4qb4x2hv3xsjvwqzz9ycwj"; type = "gem"; }; version = "1.7.1"; }; timeout = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pfddf51n5fnj4f9ggwj3wbf23ynj0nbxlxqpz12y1gvl9g7d6r6"; type = "gem"; }; version = "0.3.2"; }; tins = { - dependencies = ["sync"]; - groups = ["default"]; - platforms = []; + dependencies = [ "sync" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0373zn7zkllcn2q4ylbjgjx9mvm8m73ll3jwjav48dx8myplsp5p"; type = "gem"; }; version = "1.32.1"; }; webrick = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13qm7s0gr2pmfcl7dxrmq38asaza4w0i2n9my4yzs499j731wh8r"; type = "gem"; }; diff --git a/pkgs/by-name/ta/taskjuggler/package.nix b/pkgs/by-name/ta/taskjuggler/package.nix index cc2d7218bd4cc3..32c5ab91ede4e2 100644 --- a/pkgs/by-name/ta/taskjuggler/package.nix +++ b/pkgs/by-name/ta/taskjuggler/package.nix @@ -1,21 +1,36 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "taskjuggler"; gemdir = ./.; exes = [ - "tj3" "tj3client" "tj3d" "tj3man" "tj3ss_receiver" "tj3ss_sender" - "tj3ts_receiver" "tj3ts_sender" "tj3ts_summary" "tj3webd" + "tj3" + "tj3client" + "tj3d" + "tj3man" + "tj3ss_receiver" + "tj3ss_sender" + "tj3ts_receiver" + "tj3ts_sender" + "tj3ts_summary" + "tj3webd" ]; passthru.updateScript = bundlerUpdateScript "taskjuggler"; meta = with lib; { description = "Modern and powerful project management tool"; - homepage = "https://taskjuggler.org/"; - license = licenses.gpl2; - platforms = platforms.unix; - maintainers = with maintainers; [ manveru nicknovitski ]; + homepage = "https://taskjuggler.org/"; + license = licenses.gpl2; + platforms = platforms.unix; + maintainers = with maintainers; [ + manveru + nicknovitski + ]; }; } diff --git a/pkgs/by-name/ta/tasknc/package.nix b/pkgs/by-name/ta/tasknc/package.nix index ff478d1415a42d..37c5f5b0bc2c92 100644 --- a/pkgs/by-name/ta/tasknc/package.nix +++ b/pkgs/by-name/ta/tasknc/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, makeWrapper, perl, ncurses5, taskwarrior2 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + makeWrapper, + perl, + ncurses5, + taskwarrior2, +}: stdenv.mkDerivation rec { version = "2020-12-17"; @@ -42,7 +51,6 @@ stdenv.mkDerivation rec { wrapProgram $out/bin/tasknc --prefix PATH : ${taskwarrior2}/bin ''; - meta = with lib; { homepage = "https://github.com/lharding/tasknc"; description = "Ncurses wrapper around taskwarrior"; diff --git a/pkgs/by-name/ta/taskopen/package.nix b/pkgs/by-name/ta/taskopen/package.nix index ee40e19261a98b..8507256139e9fc 100644 --- a/pkgs/by-name/ta/taskopen/package.nix +++ b/pkgs/by-name/ta/taskopen/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, which, perl, perlPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + which, + perl, + perlPackages, +}: stdenv.mkDerivation rec { pname = "taskopen"; @@ -18,8 +26,12 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ which ] - ++ (with perlPackages; [ JSON perl ]); + buildInputs = + [ which ] + ++ (with perlPackages; [ + JSON + perl + ]); installPhase = '' make PREFIX=$out diff --git a/pkgs/by-name/ta/taskserver/package.nix b/pkgs/by-name/ta/taskserver/package.nix index a0d13164901aa3..48a71b30418053 100644 --- a/pkgs/by-name/ta/taskserver/package.nix +++ b/pkgs/by-name/ta/taskserver/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, cmake, libuuid, gnutls, makeWrapper, nixosTests }: +{ + lib, + stdenv, + fetchurl, + cmake, + libuuid, + gnutls, + makeWrapper, + nixosTests, +}: stdenv.mkDerivation rec { pname = "taskserver"; @@ -28,8 +37,14 @@ stdenv.mkDerivation rec { done ''; - buildInputs = [ libuuid gnutls ]; - nativeBuildInputs = [ cmake makeWrapper ]; + buildInputs = [ + libuuid + gnutls + ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; passthru.tests = { inherit (nixosTests) taskserver; }; @@ -38,6 +53,9 @@ stdenv.mkDerivation rec { homepage = "https://taskwarrior.org"; license = lib.licenses.mit; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ matthiasbeyer makefu ]; + maintainers = with lib.maintainers; [ + matthiasbeyer + makefu + ]; }; } diff --git a/pkgs/by-name/ta/tasksh/package.nix b/pkgs/by-name/ta/tasksh/package.nix index 0e169bc998d612..55a4f6f7e8541b 100644 --- a/pkgs/by-name/ta/tasksh/package.nix +++ b/pkgs/by-name/ta/tasksh/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, cmake, readline }: +{ + lib, + stdenv, + fetchurl, + cmake, + readline, +}: stdenv.mkDerivation rec { pname = "tasksh"; diff --git a/pkgs/by-name/ta/taskspooler/package.nix b/pkgs/by-name/ta/taskspooler/package.nix index 26925954778130..ae326ac0133920 100644 --- a/pkgs/by-name/ta/taskspooler/package.nix +++ b/pkgs/by-name/ta/taskspooler/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, makeWrapper, coreutils }: +{ + stdenv, + lib, + fetchurl, + makeWrapper, + coreutils, +}: stdenv.mkDerivation rec { pname = "taskspooler"; diff --git a/pkgs/by-name/ta/tasktimer/package.nix b/pkgs/by-name/ta/tasktimer/package.nix index 18439e02e2b996..de2cdc50fe7121 100644 --- a/pkgs/by-name/ta/tasktimer/package.nix +++ b/pkgs/by-name/ta/tasktimer/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "tasktimer"; @@ -21,7 +25,10 @@ buildGoModule rec { description = "Task Timer (tt) is a dead simple TUI task timer"; homepage = "https://github.com/caarlos0/tasktimer"; license = licenses.mit; - maintainers = with maintainers; [ abbe caarlos0 ]; + maintainers = with maintainers; [ + abbe + caarlos0 + ]; mainProgram = "tt"; }; } diff --git a/pkgs/by-name/ta/taskwarrior-tui/package.nix b/pkgs/by-name/ta/taskwarrior-tui/package.nix index f313d3d1f0ffe2..ba4a34ab062c4c 100644 --- a/pkgs/by-name/ta/taskwarrior-tui/package.nix +++ b/pkgs/by-name/ta/taskwarrior-tui/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ta/tau-hydrogen/package.nix b/pkgs/by-name/ta/tau-hydrogen/package.nix index e883d97b587e2e..745d7638e5bac6 100644 --- a/pkgs/by-name/ta/tau-hydrogen/package.nix +++ b/pkgs/by-name/ta/tau-hydrogen/package.nix @@ -5,7 +5,7 @@ meson, ninja, librsvg, - xorg + xorg, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ta/taxi/package.nix b/pkgs/by-name/ta/taxi/package.nix index 2b39d517560a03..ab29dddb0f6624 100644 --- a/pkgs/by-name/ta/taxi/package.nix +++ b/pkgs/by-name/ta/taxi/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, gobject-introspection -, gtk3 -, libgee -, libhandy -, libsecret -, libsoup_2_4 -, meson -, ninja -, nix-update-script -, pantheon -, pkg-config -, python3 -, vala -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + gobject-introspection, + gtk3, + libgee, + libhandy, + libsecret, + libsoup_2_4, + meson, + ninja, + nix-update-script, + pantheon, + pkg-config, + python3, + vala, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ta/tayga/package.nix b/pkgs/by-name/ta/tayga/package.nix index 1fa1d8dd5610e8..f53491664732b4 100644 --- a/pkgs/by-name/ta/tayga/package.nix +++ b/pkgs/by-name/ta/tayga/package.nix @@ -1,11 +1,16 @@ -{ lib, stdenv, fetchurl, nixosTests }: +{ + lib, + stdenv, + fetchurl, + nixosTests, +}: stdenv.mkDerivation rec { version = "0.9.2"; pname = "tayga"; src = fetchurl { - url= "http://www.litech.org/${pname}/${pname}-${version}.tar.bz2"; + url = "http://www.litech.org/${pname}/${pname}-${version}.tar.bz2"; hash = "sha256-Kx95J6nS3P+Qla/zwnGSSwUsz9L6ypWIsndDGkTwAJw="; }; diff --git a/pkgs/by-name/tb/tbls/package.nix b/pkgs/by-name/tb/tbls/package.nix index 84f4d8ca34b53c..6ef891587148d7 100644 --- a/pkgs/by-name/tb/tbls/package.nix +++ b/pkgs/by-name/tb/tbls/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles -, testers -, tbls +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, + testers, + tbls, }: buildGoModule rec { @@ -22,7 +23,10 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; CGO_CFLAGS = [ "-Wno-format-security" ]; diff --git a/pkgs/by-name/tb/tboot/package.nix b/pkgs/by-name/tb/tboot/package.nix index aabbe94bdb0cfe..a553c9d7ca7d47 100644 --- a/pkgs/by-name/tb/tboot/package.nix +++ b/pkgs/by-name/tb/tboot/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, openssl, perl, trousers, zlib }: +{ + lib, + stdenv, + fetchurl, + openssl, + perl, + trousers, + zlib, +}: stdenv.mkDerivation rec { pname = "tboot"; @@ -9,7 +17,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-TIs/xLxLBkKBN0a0CRB2KMmCq8QgICH1++i485WDU3A="; }; - buildInputs = [ openssl trousers zlib ]; + buildInputs = [ + openssl + trousers + zlib + ]; enableParallelBuilding = true; @@ -26,10 +38,13 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Pre-kernel/VMM module that uses Intel(R) TXT to perform a measured and verified launch of an OS kernel/VMM"; - homepage = "https://sourceforge.net/projects/tboot/"; - changelog = "https://sourceforge.net/p/tboot/code/ci/v${version}/tree/CHANGELOG"; - license = licenses.bsd3; + homepage = "https://sourceforge.net/projects/tboot/"; + changelog = "https://sourceforge.net/p/tboot/code/ci/v${version}/tree/CHANGELOG"; + license = licenses.bsd3; maintainers = with maintainers; [ ak ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/by-name/tb/tbox/package.nix b/pkgs/by-name/tb/tbox/package.nix index 9d1afcec84e12c..f1190af01cd272 100644 --- a/pkgs/by-name/tb/tbox/package.nix +++ b/pkgs/by-name/tb/tbox/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { @@ -34,4 +35,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ rewine ]; }; } - diff --git a/pkgs/by-name/tb/tbump/package.nix b/pkgs/by-name/tb/tbump/package.nix index 1314c1ec6d1262..820f4b5b31389f 100644 --- a/pkgs/by-name/tb/tbump/package.nix +++ b/pkgs/by-name/tb/tbump/package.nix @@ -18,7 +18,6 @@ python3Packages.buildPythonApplication rec { pythonRelaxDeps = [ "tomlkit" ]; - build-system = with python3Packages; [ poetry-core ]; dependencies = with python3Packages; [ diff --git a/pkgs/by-name/tc/tcat/package.nix b/pkgs/by-name/tc/tcat/package.nix index 5afa7e83affaae..25c826e7032610 100644 --- a/pkgs/by-name/tc/tcat/package.nix +++ b/pkgs/by-name/tc/tcat/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "tcat"; diff --git a/pkgs/by-name/tc/tcb/package.nix b/pkgs/by-name/tc/tcb/package.nix index 6a1f5b5eb5f203..ca4e2b4fcc971a 100644 --- a/pkgs/by-name/tc/tcb/package.nix +++ b/pkgs/by-name/tc/tcb/package.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config -, linux-pam, libxcrypt +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + linux-pam, + libxcrypt, }: stdenv.mkDerivation rec { @@ -13,11 +18,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-Sp5u7iTEZZnAqKQXoPO8eWpSkZeBzQqZI82wRQmgU9A="; }; - outputs = [ "out" "bin" "dev" "man" ]; + outputs = [ + "out" + "bin" + "dev" + "man" + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ linux-pam libxcrypt ]; + buildInputs = [ + linux-pam + libxcrypt + ]; patches = [ ./fix-makefiles.patch ]; diff --git a/pkgs/by-name/tc/tcl2048/package.nix b/pkgs/by-name/tc/tcl2048/package.nix index 1435e1ed76e486..523a04c612efcb 100644 --- a/pkgs/by-name/tc/tcl2048/package.nix +++ b/pkgs/by-name/tc/tcl2048/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, tcl, tclPackages, runtimeShell }: +{ + lib, + fetchurl, + tcl, + tclPackages, + runtimeShell, +}: tcl.mkTclDerivation rec { pname = "tcl2048"; diff --git a/pkgs/by-name/tc/tcp-cutter/package.nix b/pkgs/by-name/tc/tcp-cutter/package.nix index 4231ddef243320..9ca1a2dd1399d3 100644 --- a/pkgs/by-name/tc/tcp-cutter/package.nix +++ b/pkgs/by-name/tc/tcp-cutter/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "tcp-cutter"; diff --git a/pkgs/by-name/tc/tcp_wrappers/package.nix b/pkgs/by-name/tc/tcp_wrappers/package.nix index ad8c8b8c2bbbb6..1bfadfbf5ef2c1 100644 --- a/pkgs/by-name/tc/tcp_wrappers/package.nix +++ b/pkgs/by-name/tc/tcp_wrappers/package.nix @@ -1,9 +1,15 @@ -{ fetchurl, lib, stdenv, libnsl }: +{ + fetchurl, + lib, + stdenv, + libnsl, +}: let vanillaVersion = "7.6.q"; patchLevel = "33"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "tcp-wrappers"; version = "${vanillaVersion}-${patchLevel}"; @@ -30,7 +36,11 @@ in stdenv.mkDerivation rec { buildInputs = [ libnsl ]; - makeFlags = [ "REAL_DAEMON_DIR=$(out)/bin" "linux" "AR:=$(AR)" ]; + makeFlags = [ + "REAL_DAEMON_DIR=$(out)/bin" + "linux" + "AR:=$(AR)" + ]; installPhase = '' mkdir -p "$out/bin" diff --git a/pkgs/by-name/tc/tcpcrypt/package.nix b/pkgs/by-name/tc/tcpcrypt/package.nix index 1d34fdd4e71096..bf9552a1ee4584 100644 --- a/pkgs/by-name/tc/tcpcrypt/package.nix +++ b/pkgs/by-name/tc/tcpcrypt/package.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook -, openssl -, libcap, libpcap, libnfnetlink, libnetfilter_conntrack, libnetfilter_queue +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + openssl, + libcap, + libpcap, + libnfnetlink, + libnetfilter_conntrack, + libnetfilter_queue, }: stdenv.mkDerivation rec { @@ -16,10 +24,23 @@ stdenv.mkDerivation rec { postUnpack = "mkdir -vp $sourceRoot/m4"; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ openssl libpcap ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libcap libnfnetlink libnetfilter_conntrack libnetfilter_queue ]; + buildInputs = + [ + openssl + libpcap + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libcap + libnfnetlink + libnetfilter_conntrack + libnetfilter_queue + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/tc/tcpdump/package.nix b/pkgs/by-name/tc/tcpdump/package.nix index b61f42eae308e9..4c46ced1dec554 100644 --- a/pkgs/by-name/tc/tcpdump/package.nix +++ b/pkgs/by-name/tc/tcpdump/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, libpcap, pkg-config, perl }: +{ + lib, + stdenv, + fetchurl, + libpcap, + pkg-config, + perl, +}: stdenv.mkDerivation rec { pname = "tcpdump"; diff --git a/pkgs/by-name/tc/tcpflow/package.nix b/pkgs/by-name/tc/tcpflow/package.nix index 73de0acef4e616..fa6769438c2b9d 100644 --- a/pkgs/by-name/tc/tcpflow/package.nix +++ b/pkgs/by-name/tc/tcpflow/package.nix @@ -1,23 +1,39 @@ -{ stdenv, lib, fetchFromGitHub, automake, autoconf -, openssl, zlib, libpcap, boost -, useCairo ? false, cairo +{ + stdenv, + lib, + fetchFromGitHub, + automake, + autoconf, + openssl, + zlib, + libpcap, + boost, + useCairo ? false, + cairo, }: stdenv.mkDerivation rec { - pname = "tcpflow"; + pname = "tcpflow"; version = "1.6.1"; src = fetchFromGitHub { - owner = "simsong"; - repo = pname; - rev = "${pname}-${version}"; + owner = "simsong"; + repo = pname; + rev = "${pname}-${version}"; sha256 = "0vbm097jhi5n8pg08ia1yhzc225zv9948blb76f4br739l9l22vq"; fetchSubmodules = true; }; - nativeBuildInputs = [ automake autoconf ]; - buildInputs = [ openssl zlib libpcap boost ] - ++ lib.optional useCairo cairo; + nativeBuildInputs = [ + automake + autoconf + ]; + buildInputs = [ + openssl + zlib + libpcap + boost + ] ++ lib.optional useCairo cairo; prePatch = '' substituteInPlace bootstrap.sh \ @@ -39,9 +55,12 @@ stdenv.mkDerivation rec { protocol analysis and debugging. ''; inherit (src.meta) homepage; - license = licenses.gpl3; - maintainers = with maintainers; [ raskin obadz ]; - platforms = platforms.unix; + license = licenses.gpl3; + maintainers = with maintainers; [ + raskin + obadz + ]; + platforms = platforms.unix; mainProgram = "tcpflow"; }; } diff --git a/pkgs/by-name/tc/tcping-go/package.nix b/pkgs/by-name/tc/tcping-go/package.nix index 950c648337ad96..47628d34656ede 100644 --- a/pkgs/by-name/tc/tcping-go/package.nix +++ b/pkgs/by-name/tc/tcping-go/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule { pname = "tcping-go"; diff --git a/pkgs/by-name/tc/tcpkali/package.nix b/pkgs/by-name/tc/tcpkali/package.nix index 805a70f88e741f..a8df1b1ddbbb4e 100644 --- a/pkgs/by-name/tc/tcpkali/package.nix +++ b/pkgs/by-name/tc/tcpkali/package.nix @@ -1,6 +1,14 @@ -{lib, stdenv, autoreconfHook, fetchFromGitHub, bison}: +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + bison, +}: -let version = "1.1.1"; in +let + version = "1.1.1"; +in stdenv.mkDerivation rec { pname = "tcpkali"; @@ -15,7 +23,7 @@ stdenv.mkDerivation rec { sed -ie '/sys\/sysctl\.h/d' src/tcpkali_syslimits.c ''; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ bison]; + buildInputs = [ bison ]; meta = { description = "High performance TCP and WebSocket load generator and sink"; license = lib.licenses.bsd2; diff --git a/pkgs/by-name/tc/tcptraceroute/package.nix b/pkgs/by-name/tc/tcptraceroute/package.nix index 586462e6c2c535..9f35a31eba38a7 100644 --- a/pkgs/by-name/tc/tcptraceroute/package.nix +++ b/pkgs/by-name/tc/tcptraceroute/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, libpcap -, libnet +{ + lib, + stdenv, + fetchFromGitHub, + libpcap, + libnet, }: stdenv.mkDerivation rec { @@ -16,14 +17,16 @@ stdenv.mkDerivation rec { hash = "sha256-KU4MLWtOFzzNr+I99fRbhBokhS1JUNL+OgVltkOGav4="; }; - # for reasons unknown --disable-static configure flag doesn't disable static # linking.. we instead override CFLAGS with -static omitted preBuild = '' makeFlagsArray=(CFLAGS=" -g -O2 -Wall") ''; - buildInputs = [ libpcap libnet ]; + buildInputs = [ + libpcap + libnet + ]; meta = { description = "Traceroute implementation using TCP packets"; diff --git a/pkgs/by-name/tc/tcptrack/package.nix b/pkgs/by-name/tc/tcptrack/package.nix index e638718474e54e..2c54223cc75cf0 100644 --- a/pkgs/by-name/tc/tcptrack/package.nix +++ b/pkgs/by-name/tc/tcptrack/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, ncurses, libpcap }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + ncurses, + libpcap, +}: stdenv.mkDerivation rec { pname = "tcptrack"; @@ -21,7 +28,10 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ ncurses libpcap ]; + buildInputs = [ + ncurses + libpcap + ]; env.NIX_CFLAGS_COMPILE = "-Wno-error=cpp"; diff --git a/pkgs/by-name/td/tdfgo/package.nix b/pkgs/by-name/td/tdfgo/package.nix index 0d9e5950b51a4b..07e0d2721c6c43 100644 --- a/pkgs/by-name/td/tdfgo/package.nix +++ b/pkgs/by-name/td/tdfgo/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "tdfgo"; diff --git a/pkgs/by-name/td/tdlib/package.nix b/pkgs/by-name/td/tdlib/package.nix index 66a70a9c76367a..7c308bec909804 100644 --- a/pkgs/by-name/td/tdlib/package.nix +++ b/pkgs/by-name/td/tdlib/package.nix @@ -1,22 +1,36 @@ -{ fetchFromGitHub, gperf, openssl, readline, zlib, cmake, lib, stdenv, - writeShellApplication, common-updater-scripts, jq }: +{ + fetchFromGitHub, + gperf, + openssl, + readline, + zlib, + cmake, + lib, + stdenv, + writeShellApplication, + common-updater-scripts, + jq, +}: let updateScript = writeShellApplication { - name = "update-tdlib"; + name = "update-tdlib"; - runtimeInputs = [ jq common-updater-scripts ]; + runtimeInputs = [ + jq + common-updater-scripts + ]; - text = '' - commit_msg="^Update version to (?\\\\d+.\\\\d+.\\\\d+)\\\\.$" - commit=$(curl -s "https://api.github.com/repos/tdlib/td/commits?path=CMakeLists.txt" | jq -c "map(select(.commit.message | test(\"''${commit_msg}\"))) | first") + text = '' + commit_msg="^Update version to (?\\\\d+.\\\\d+.\\\\d+)\\\\.$" + commit=$(curl -s "https://api.github.com/repos/tdlib/td/commits?path=CMakeLists.txt" | jq -c "map(select(.commit.message | test(\"''${commit_msg}\"))) | first") - rev=$(echo "$commit" | jq -r ".sha") - version=$(echo "$commit" | jq -r ".commit.message | capture(\"''${commit_msg}\") | .v") + rev=$(echo "$commit" | jq -r ".sha") + version=$(echo "$commit" | jq -r ".commit.message | capture(\"''${commit_msg}\") | .v") - update-source-version tdlib "$version" --rev="$rev" - ''; - }; + update-source-version tdlib "$version" --rev="$rev" + ''; + }; in stdenv.mkDerivation { @@ -34,20 +48,27 @@ stdenv.mkDerivation { hash = "sha256-1TyGv2yMjX75+ccZSox/2m6SMmwEZAkShIhLfCeNmZg="; }; - buildInputs = [ gperf openssl readline zlib ]; + buildInputs = [ + gperf + openssl + readline + zlib + ]; nativeBuildInputs = [ cmake ]; # https://github.com/tdlib/td/issues/1974 - postPatch = '' - substituteInPlace CMake/GeneratePkgConfig.cmake \ - --replace 'function(generate_pkgconfig' \ - 'include(GNUInstallDirs) - function(generate_pkgconfig' \ - --replace '\$'{prefix}/'$'{CMAKE_INSTALL_LIBDIR} '$'{CMAKE_INSTALL_FULL_LIBDIR} \ - --replace '\$'{prefix}/'$'{CMAKE_INSTALL_INCLUDEDIR} '$'{CMAKE_INSTALL_FULL_INCLUDEDIR} - '' + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' - sed -i "/vptr/d" test/CMakeLists.txt - ''; + postPatch = + '' + substituteInPlace CMake/GeneratePkgConfig.cmake \ + --replace 'function(generate_pkgconfig' \ + 'include(GNUInstallDirs) + function(generate_pkgconfig' \ + --replace '\$'{prefix}/'$'{CMAKE_INSTALL_LIBDIR} '$'{CMAKE_INSTALL_FULL_LIBDIR} \ + --replace '\$'{prefix}/'$'{CMAKE_INSTALL_INCLUDEDIR} '$'{CMAKE_INSTALL_FULL_INCLUDEDIR} + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' + sed -i "/vptr/d" test/CMakeLists.txt + ''; passthru.updateScript = lib.getExe updateScript; @@ -56,6 +77,9 @@ stdenv.mkDerivation { homepage = "https://core.telegram.org/tdlib/"; license = [ licenses.boost ]; platforms = platforms.unix; - maintainers = [ maintainers.vyorkin maintainers.vonfry ]; + maintainers = [ + maintainers.vyorkin + maintainers.vonfry + ]; }; } diff --git a/pkgs/by-name/td/tdnf/package.nix b/pkgs/by-name/td/tdnf/package.nix index 315b53a8fe2fab..6e26431d65dd78 100644 --- a/pkgs/by-name/td/tdnf/package.nix +++ b/pkgs/by-name/td/tdnf/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch2 -, cmake -, curl -, gpgme -, libsolv -, libxml2 -, pkg-config -, python3 -, rpm -, sqlite +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch2, + cmake, + curl, + gpgme, + libsolv, + libxml2, + pkg-config, + python3, + rpm, + sqlite, }: stdenv.mkDerivation (finalAttrs: { @@ -77,7 +78,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Tiny Dandified Yum"; homepage = "https://github.com/vmware/tdnf"; changelog = "https://github.com/vmware/tdnf/releases/tag/v${finalAttrs.version}"; - license = with lib.licenses; [ gpl2 lgpl21 ]; + license = with lib.licenses; [ + gpl2 + lgpl21 + ]; maintainers = [ lib.maintainers.malt3 ]; mainProgram = "tdnf"; # rpm only supports linux diff --git a/pkgs/by-name/td/tdns-cli/package.nix b/pkgs/by-name/td/tdns-cli/package.nix index 006e7161b19dbf..2683afb4491e2a 100644 --- a/pkgs/by-name/td/tdns-cli/package.nix +++ b/pkgs/by-name/td/tdns-cli/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "tdns-cli"; diff --git a/pkgs/by-name/td/tdrop/package.nix b/pkgs/by-name/td/tdrop/package.nix index bc9966ab2b7699..017f72e44fac46 100644 --- a/pkgs/by-name/td/tdrop/package.nix +++ b/pkgs/by-name/td/tdrop/package.nix @@ -1,6 +1,16 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper -, xwininfo, xdotool, xprop, gawk, coreutils -, gnugrep, procps }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + xwininfo, + xdotool, + xprop, + gawk, + coreutils, + gnugrep, + procps, +}: stdenv.mkDerivation rec { pname = "tdrop"; @@ -17,19 +27,21 @@ stdenv.mkDerivation rec { installFlags = [ "PREFIX=$(out)" ]; - postInstall = let - binPath = lib.makeBinPath [ - xwininfo - xdotool - xprop - gawk - coreutils - gnugrep - procps - ]; - in '' - wrapProgram $out/bin/tdrop --prefix PATH : ${binPath} - ''; + postInstall = + let + binPath = lib.makeBinPath [ + xwininfo + xdotool + xprop + gawk + coreutils + gnugrep + procps + ]; + in + '' + wrapProgram $out/bin/tdrop --prefix PATH : ${binPath} + ''; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/by-name/te/tea/package.nix b/pkgs/by-name/te/tea/package.nix index 8e985c9ec13dc8..72a8455a416921 100644 --- a/pkgs/by-name/te/tea/package.nix +++ b/pkgs/by-name/te/tea/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitea }: +{ + lib, + buildGoModule, + fetchFromGitea, +}: buildGoModule rec { pname = "tea"; @@ -16,9 +20,12 @@ buildGoModule rec { meta = with lib; { description = "Gitea official CLI client"; - homepage = "https://gitea.com/gitea/tea"; - license = licenses.mit; - maintainers = with maintainers; [ j4m3s techknowlogick ]; + homepage = "https://gitea.com/gitea/tea"; + license = licenses.mit; + maintainers = with maintainers; [ + j4m3s + techknowlogick + ]; mainProgram = "tea"; }; } diff --git a/pkgs/by-name/te/tealdeer/package.nix b/pkgs/by-name/te/tealdeer/package.nix index 51d43799621e9d..b6e634fd005f9b 100644 --- a/pkgs/by-name/te/tealdeer/package.nix +++ b/pkgs/by-name/te/tealdeer/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, installShellFiles -, apple-sdk_11 +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + installShellFiles, + apple-sdk_11, }: rustPlatform.buildRustPackage rec { @@ -45,8 +46,15 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Very fast implementation of tldr in Rust"; homepage = "https://github.com/dbrgn/tealdeer"; - maintainers = with maintainers; [ davidak newam mfrw ]; - license = with licenses; [ asl20 mit ]; + maintainers = with maintainers; [ + davidak + newam + mfrw + ]; + license = with licenses; [ + asl20 + mit + ]; mainProgram = "tldr"; }; } diff --git a/pkgs/by-name/te/teams/package.nix b/pkgs/by-name/te/teams/package.nix index e0fcae460b42ba..b1f8771a431df6 100644 --- a/pkgs/by-name/te/teams/package.nix +++ b/pkgs/by-name/te/teams/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, xar -, cpio -, makeWrapper +{ + lib, + stdenv, + fetchurl, + xar, + cpio, + makeWrapper, }: let @@ -21,7 +22,10 @@ let sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; maintainers = with maintainers; [ tricktron ]; - platforms = [ "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-darwin" + "aarch64-darwin" + ]; mainProgram = "teams"; }; @@ -36,7 +40,11 @@ stdenv.mkDerivation { hash = hashes.darwin; }; - nativeBuildInputs = [ xar cpio makeWrapper ]; + nativeBuildInputs = [ + xar + cpio + makeWrapper + ]; unpackPhase = '' xar -xf $src diff --git a/pkgs/by-name/te/teapot/package.nix b/pkgs/by-name/te/teapot/package.nix index 31ff3c86098741..8662720a189e70 100644 --- a/pkgs/by-name/te/teapot/package.nix +++ b/pkgs/by-name/te/teapot/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libtirpc -, ncurses +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libtirpc, + ncurses, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/te/teavpn2/package.nix b/pkgs/by-name/te/teavpn2/package.nix index cc54259aae0d00..7b2e3060d2886a 100644 --- a/pkgs/by-name/te/teavpn2/package.nix +++ b/pkgs/by-name/te/teavpn2/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, substituteAll -, iproute2 +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + iproute2, }: stdenv.mkDerivation { pname = "teavpn2"; diff --git a/pkgs/by-name/te/tebreak/package.nix b/pkgs/by-name/te/tebreak/package.nix index 879f9b95d846b4..47587b1a8c22c5 100644 --- a/pkgs/by-name/te/tebreak/package.nix +++ b/pkgs/by-name/te/tebreak/package.nix @@ -1,5 +1,13 @@ -{ lib, fetchFromGitHub, last, exonerate, minia, python3, bwa -, samtools }: +{ + lib, + fetchFromGitHub, + last, + exonerate, + minia, + python3, + bwa, + samtools, +}: python3.pkgs.buildPythonApplication rec { pname = "tebreak"; diff --git a/pkgs/by-name/te/techmino/ccloader.nix b/pkgs/by-name/te/techmino/ccloader.nix index 38a4b32c821ae3..ff312555d79187 100644 --- a/pkgs/by-name/te/techmino/ccloader.nix +++ b/pkgs/by-name/te/techmino/ccloader.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, libcoldclear -, luajit +{ + lib, + stdenv, + fetchFromGitHub, + libcoldclear, + luajit, }: stdenv.mkDerivation rec { @@ -17,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-sguV+Dw+etZH43tXZYL46NAdsI/qvyvGWCPUiTEjhy4="; }; - buildInputs = [ libcoldclear luajit ]; + buildInputs = [ + libcoldclear + luajit + ]; buildPhase = '' runHook preBuild diff --git a/pkgs/by-name/te/techmino/libcoldclear.nix b/pkgs/by-name/te/techmino/libcoldclear.nix index 516f5c4dd9cdda..9b97740337a215 100644 --- a/pkgs/by-name/te/techmino/libcoldclear.nix +++ b/pkgs/by-name/te/techmino/libcoldclear.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, ccloader +{ + lib, + rustPlatform, + fetchFromGitHub, + ccloader, }: let diff --git a/pkgs/by-name/te/techmino/package.nix b/pkgs/by-name/te/techmino/package.nix index 3d15feeb49fd55..9da82feeab1c48 100644 --- a/pkgs/by-name/te/techmino/package.nix +++ b/pkgs/by-name/te/techmino/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, callPackage -, makeWrapper -, makeDesktopItem -, love -, luajit -, writeShellScript -, nix-update -, libcoldclear ? callPackage ./libcoldclear.nix { inherit ccloader; } -, ccloader ? callPackage ./ccloader.nix { inherit libcoldclear luajit; } +{ + lib, + stdenv, + fetchurl, + callPackage, + makeWrapper, + makeDesktopItem, + love, + luajit, + writeShellScript, + nix-update, + libcoldclear ? callPackage ./libcoldclear.nix { inherit ccloader; }, + ccloader ? callPackage ./ccloader.nix { inherit libcoldclear luajit; }, }: let diff --git a/pkgs/by-name/te/technitium-dns-server-library/nuget-deps.nix b/pkgs/by-name/te/technitium-dns-server-library/nuget-deps.nix index f3a17967e25c81..dbfecc1b26058f 100644 --- a/pkgs/by-name/te/technitium-dns-server-library/nuget-deps.nix +++ b/pkgs/by-name/te/technitium-dns-server-library/nuget-deps.nix @@ -1,5 +1,6 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ +{ fetchNuGet }: +[ ] diff --git a/pkgs/by-name/te/technitium-dns-server/nuget-deps.nix b/pkgs/by-name/te/technitium-dns-server/nuget-deps.nix index f3a17967e25c81..dbfecc1b26058f 100644 --- a/pkgs/by-name/te/technitium-dns-server/nuget-deps.nix +++ b/pkgs/by-name/te/technitium-dns-server/nuget-deps.nix @@ -1,5 +1,6 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ +{ fetchNuGet }: +[ ] diff --git a/pkgs/by-name/te/tecla/package.nix b/pkgs/by-name/te/tecla/package.nix index 03631469889b49..c5e666681a4e24 100644 --- a/pkgs/by-name/te/tecla/package.nix +++ b/pkgs/by-name/te/tecla/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { @@ -12,7 +13,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-8nV8xVBAhZ/Pj1mgt7JuAYSiK+zkTtlWikU0pHjB7ho="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; postPatch = '' substituteInPlace install-sh \ @@ -27,27 +31,27 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.astro.caltech.edu/~mcs/tecla/"; description = "Command-line editing library"; longDescription = '' - The tecla library provides UNIX and LINUX programs with interactive - command line editing facilities, similar to those of the UNIX tcsh - shell. In addition to simple command-line editing, it supports recall of - previously entered command lines, TAB completion of file names or other - tokens, and in-line wild-card expansion of filenames. The internal - functions which perform file-name completion and wild-card expansion are - also available externally for optional use by programs. - - In addition, the library includes a path-searching module. This allows an - application to provide completion and lookup of files located in UNIX - style paths. Although not built into the line editor by default, it can - easily be called from custom tab-completion callback functions. This was - originally conceived for completing the names of executables and - providing a way to look up their locations in the user's PATH environment - variable, but it can easily be asked to look up and complete other types - of files in any list of directories. - - Note that special care has been taken to allow the use of this library in - threaded programs. The option to enable this is discussed in the - Makefile, and specific discussions of thread safety are presented in the - included man pages. + The tecla library provides UNIX and LINUX programs with interactive + command line editing facilities, similar to those of the UNIX tcsh + shell. In addition to simple command-line editing, it supports recall of + previously entered command lines, TAB completion of file names or other + tokens, and in-line wild-card expansion of filenames. The internal + functions which perform file-name completion and wild-card expansion are + also available externally for optional use by programs. + + In addition, the library includes a path-searching module. This allows an + application to provide completion and lookup of files located in UNIX + style paths. Although not built into the line editor by default, it can + easily be called from custom tab-completion callback functions. This was + originally conceived for completing the names of executables and + providing a way to look up their locations in the user's PATH environment + variable, but it can easily be asked to look up and complete other types + of files in any list of directories. + + Note that special care has been taken to allow the use of this library in + threaded programs. The option to enable this is discussed in the + Makefile, and specific discussions of thread safety are presented in the + included man pages. ''; changelog = "https://sites.astro.caltech.edu/~mcs/tecla/release.html"; license = with lib.licenses; [ mit ]; diff --git a/pkgs/by-name/te/tecnoballz/package.nix b/pkgs/by-name/te/tecnoballz/package.nix index b3f1914bc18eff..82ca81b832938f 100644 --- a/pkgs/by-name/te/tecnoballz/package.nix +++ b/pkgs/by-name/te/tecnoballz/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, autoconf -, automake -, SDL -, SDL_mixer -, SDL_image -, libmikmod -, tinyxml +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + SDL, + SDL_mixer, + SDL_image, + libmikmod, + tinyxml, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/te/tecoc/package.nix b/pkgs/by-name/te/tecoc/package.nix index 8bb5d0b0aa1080..3cb604727665bb 100644 --- a/pkgs/by-name/te/tecoc/package.nix +++ b/pkgs/by-name/te/tecoc/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchFromGitHub -, ncurses -, unstableGitUpdater +{ + stdenv, + lib, + fetchFromGitHub, + ncurses, + unstableGitUpdater, }: stdenv.mkDerivation (finalAttrs: { @@ -18,17 +19,22 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ ncurses ]; - makefile = if stdenv.hostPlatform.isDarwin - then "makefile.osx" - else if stdenv.hostPlatform.isFreeBSD - then "makefile.bsd" - else if stdenv.hostPlatform.isOpenBSD - then "makefile.bsd" - else if stdenv.hostPlatform.isWindows - then "makefile.win" - else "makefile.linux"; # I think Linux is a safe default... + makefile = + if stdenv.hostPlatform.isDarwin then + "makefile.osx" + else if stdenv.hostPlatform.isFreeBSD then + "makefile.bsd" + else if stdenv.hostPlatform.isOpenBSD then + "makefile.bsd" + else if stdenv.hostPlatform.isWindows then + "makefile.win" + else + "makefile.linux"; # I think Linux is a safe default... - makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "-C src/" ]; + makeFlags = [ + "CC=${stdenv.cc.targetPrefix}cc" + "-C src/" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/te/ted/package.nix b/pkgs/by-name/te/ted/package.nix index a6c46c6c7df59e..78edd65d509631 100644 --- a/pkgs/by-name/te/ted/package.nix +++ b/pkgs/by-name/te/ted/package.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchurl, pkg-config, zlib, pcre, xorg, libjpeg, libtiff, libpng, gtk2, libpaper, makeWrapper, ghostscript }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + zlib, + pcre, + xorg, + libjpeg, + libtiff, + libpng, + gtk2, + libpaper, + makeWrapper, + ghostscript, +}: stdenv.mkDerivation rec { pname = "ted"; @@ -35,7 +50,11 @@ stdenv.mkDerivation rec { popd ''; - makeFlags = [ "CONFIGURE_OPTIONS=--with-GTK" "CONFIGURE_OPTIONS+=--prefix=$(out)" "compile.shared" ]; + makeFlags = [ + "CONFIGURE_OPTIONS=--with-GTK" + "CONFIGURE_OPTIONS+=--prefix=$(out)" + "compile.shared" + ]; installPhase = '' runHook preInstall @@ -58,8 +77,23 @@ stdenv.mkDerivation rec { runHook postInstall ''; - nativeBuildInputs = [ pkg-config makeWrapper ]; - buildInputs = [ zlib pcre xorg.libX11 xorg.libICE xorg.libSM xorg.libXpm libjpeg libtiff libpng gtk2 libpaper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; + buildInputs = [ + zlib + pcre + xorg.libX11 + xorg.libICE + xorg.libSM + xorg.libXpm + libjpeg + libtiff + libpng + gtk2 + libpaper + ]; meta = with lib; { description = "An easy rich text processor"; @@ -75,10 +109,10 @@ stdenv.mkDerivation rec { MS-Word. Additionally, Ted also is an RTF to PostScript and an RTF to Acrobat PDF converter. ''; - homepage = "https://nllgg.nl/Ted/"; - license = licenses.gpl2Only; - platforms = platforms.all; - broken = stdenv.hostPlatform.isDarwin; + homepage = "https://nllgg.nl/Ted/"; + license = licenses.gpl2Only; + platforms = platforms.all; + broken = stdenv.hostPlatform.isDarwin; maintainers = with maintainers; [ obadz ]; }; } diff --git a/pkgs/by-name/te/teehee/package.nix b/pkgs/by-name/te/teehee/package.nix index 7015987ae9e6cd..04dc45cdc5701a 100644 --- a/pkgs/by-name/te/teehee/package.nix +++ b/pkgs/by-name/te/teehee/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/te/teensy-cmake-macros/hook.nix b/pkgs/by-name/te/teensy-cmake-macros/hook.nix index 55f9aec729f57c..ab35445bcad8da 100644 --- a/pkgs/by-name/te/teensy-cmake-macros/hook.nix +++ b/pkgs/by-name/te/teensy-cmake-macros/hook.nix @@ -1,5 +1,6 @@ -{ makeSetupHook -, teensy-cmake-macros +{ + makeSetupHook, + teensy-cmake-macros, }: makeSetupHook { diff --git a/pkgs/by-name/te/teensy-cmake-macros/package.nix b/pkgs/by-name/te/teensy-cmake-macros/package.nix index 7254becdbce707..85365cd63f8e1a 100644 --- a/pkgs/by-name/te/teensy-cmake-macros/package.nix +++ b/pkgs/by-name/te/teensy-cmake-macros/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, callPackage +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + callPackage, }: stdenv.mkDerivation (finalAttrs: { @@ -17,7 +18,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-E+BOlsCJtOScr3B5GSv1WM6rFv6cFYvm/iJ893fsmXM="; }; - propagatedBuildInputs = [ cmake pkg-config ]; + propagatedBuildInputs = [ + cmake + pkg-config + ]; passthru = { hook = callPackage ./hook.nix { diff --git a/pkgs/by-name/te/teensy-loader-cli/package.nix b/pkgs/by-name/te/teensy-loader-cli/package.nix index 19f7051f0a3027..ab668e7527d685 100644 --- a/pkgs/by-name/te/teensy-loader-cli/package.nix +++ b/pkgs/by-name/te/teensy-loader-cli/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, go-md2man -, installShellFiles -, libusb-compat-0_1 +{ + stdenv, + lib, + fetchFromGitHub, + go-md2man, + installShellFiles, + libusb-compat-0_1, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/te/teensy-udev-rules/package.nix b/pkgs/by-name/te/teensy-udev-rules/package.nix index 326cf0a3245f7f..1323869cc31dd3 100644 --- a/pkgs/by-name/te/teensy-udev-rules/package.nix +++ b/pkgs/by-name/te/teensy-udev-rules/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, coreutils }: +{ + lib, + stdenv, + coreutils, +}: stdenv.mkDerivation { pname = "teensy-udev-rules"; diff --git a/pkgs/by-name/te/teetertorture/package.nix b/pkgs/by-name/te/teetertorture/package.nix index b87faf6cea0b23..ca697191d19a5a 100644 --- a/pkgs/by-name/te/teetertorture/package.nix +++ b/pkgs/by-name/te/teetertorture/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, SDL, SDL_image, SDL_mixer }: +{ + lib, + stdenv, + fetchurl, + SDL, + SDL_image, + SDL_mixer, +}: stdenv.mkDerivation rec { pname = "teeter-torture"; @@ -8,7 +15,11 @@ stdenv.mkDerivation rec { sha256 = "175gdbkx3m82icyzvwpyzs4v2fd69c695k5n8ca0lnjv81wnw2hr"; }; - buildInputs = [ SDL SDL_image SDL_mixer]; + buildInputs = [ + SDL + SDL_image + SDL_mixer + ]; configurePhase = '' sed -i s,data/,$out/share/teetertorture/, src/teetertorture.c diff --git a/pkgs/by-name/te/tegaki-zinnia-japanese/package.nix b/pkgs/by-name/te/tegaki-zinnia-japanese/package.nix index 6274451364103a..ab4a8ef28c9ee2 100644 --- a/pkgs/by-name/te/tegaki-zinnia-japanese/package.nix +++ b/pkgs/by-name/te/tegaki-zinnia-japanese/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation { pname = "tegaki-zinnia-japanese"; diff --git a/pkgs/by-name/te/tegola/package.nix b/pkgs/by-name/te/tegola/package.nix index deb794f1c71c1f..6d36b39d29c8ee 100644 --- a/pkgs/by-name/te/tegola/package.nix +++ b/pkgs/by-name/te/tegola/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, buildNpmPackage, fetchFromGitHub }: +{ + lib, + buildGoModule, + buildNpmPackage, + fetchFromGitHub, +}: let version = "0.20.0"; @@ -30,7 +35,11 @@ buildGoModule { subPackages = [ "cmd/tegola" ]; - ldflags = [ "-s" "-w" "-X github.com/go-spatial/tegola/internal/build.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/go-spatial/tegola/internal/build.Version=${version}" + ]; preBuild = '' rm -rf ui/dist diff --git a/pkgs/by-name/te/teip/package.nix b/pkgs/by-name/te/teip/package.nix index ab140f2a578c35..7f18790d4efbcd 100644 --- a/pkgs/by-name/te/teip/package.nix +++ b/pkgs/by-name/te/teip/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, perl -, stdenv +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + perl, + stdenv, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/te/tektoncd-cli/package.nix b/pkgs/by-name/te/tektoncd-cli/package.nix index b3bbd31d7a419c..22bb7b9de609ba 100644 --- a/pkgs/by-name/te/tektoncd-cli/package.nix +++ b/pkgs/by-name/te/tektoncd-cli/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "tektoncd-cli"; @@ -13,7 +18,11 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" "-X github.com/tektoncd/cli/pkg/cmd/version.clientVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/tektoncd/cli/pkg/cmd/version.clientVersion=${version}" + ]; nativeBuildInputs = [ installShellFiles ]; @@ -61,7 +70,11 @@ buildGoModule rec { Pipelines. ''; license = licenses.asl20; - maintainers = with maintainers; [ jk mstrangfeld vdemeester ]; + maintainers = with maintainers; [ + jk + mstrangfeld + vdemeester + ]; mainProgram = "tkn"; }; } diff --git a/pkgs/by-name/te/tela-icon-theme/package.nix b/pkgs/by-name/te/tela-icon-theme/package.nix index be46f39bf0304c..fbf67aef18ac68 100644 --- a/pkgs/by-name/te/tela-icon-theme/package.nix +++ b/pkgs/by-name/te/tela-icon-theme/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenvNoCC, fetchFromGitHub, gtk3, jdupes, hicolor-icon-theme }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + jdupes, + hicolor-icon-theme, +}: stdenvNoCC.mkDerivation rec { pname = "tela-icon-theme"; @@ -11,7 +18,10 @@ stdenvNoCC.mkDerivation rec { hash = "sha256-ZzF4U/cTy/7oSDQs4+dezewgNzS5zroba8wpcfPciW4="; }; - nativeBuildInputs = [ gtk3 jdupes ]; + nativeBuildInputs = [ + gtk3 + jdupes + ]; propagatedBuildInputs = [ hicolor-icon-theme ]; diff --git a/pkgs/by-name/te/telegraf/package.nix b/pkgs/by-name/te/telegraf/package.nix index 63a786584b17bd..94bfffaddeb062 100644 --- a/pkgs/by-name/te/telegraf/package.nix +++ b/pkgs/by-name/te/telegraf/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGo123Module -, fetchFromGitHub -, nixosTests -, stdenv -, testers -, telegraf +{ + lib, + buildGo123Module, + fetchFromGitHub, + nixosTests, + stdenv, + testers, + telegraf, }: buildGo123Module rec { @@ -30,13 +31,15 @@ buildGo123Module rec { "-X=github.com/influxdata/telegraf/internal.Version=${version}" ]; - passthru.tests = { - version = testers.testVersion { - package = telegraf; + passthru.tests = + { + version = testers.testVersion { + package = telegraf; + }; + } + // lib.optionalAttrs stdenv.hostPlatform.isLinux { + inherit (nixosTests) telegraf; }; - } // lib.optionalAttrs stdenv.hostPlatform.isLinux { - inherit (nixosTests) telegraf; - }; meta = with lib; { description = "Plugin-driven server agent for collecting & reporting metrics"; @@ -44,6 +47,11 @@ buildGo123Module rec { homepage = "https://www.influxdata.com/time-series-platform/telegraf/"; changelog = "https://github.com/influxdata/telegraf/blob/${src.rev}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ mic92 roblabla timstott zowoq ]; + maintainers = with maintainers; [ + mic92 + roblabla + timstott + zowoq + ]; }; } diff --git a/pkgs/by-name/te/telegraph/package.nix b/pkgs/by-name/te/telegraph/package.nix index 332c09884c6543..0cdeede94e2241 100644 --- a/pkgs/by-name/te/telegraph/package.nix +++ b/pkgs/by-name/te/telegraph/package.nix @@ -1,15 +1,16 @@ -{ lib -, desktop-file-utils -, fetchFromGitHub -, gobject-introspection -, gtk4 -, libadwaita -, meson -, ninja -, pkg-config -, python3 -, stdenv -, wrapGAppsHook4 +{ + lib, + desktop-file-utils, + fetchFromGitHub, + gobject-introspection, + gtk4, + libadwaita, + meson, + ninja, + pkg-config, + python3, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { @@ -35,9 +36,11 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ gtk4 libadwaita - (python3.withPackages (ps: with ps; [ - pygobject3 - ])) + (python3.withPackages ( + ps: with ps; [ + pygobject3 + ] + )) ]; meta = with lib; { diff --git a/pkgs/by-name/te/telepathy-farstream/package.nix b/pkgs/by-name/te/telepathy-farstream/package.nix index 072ca801f31b15..e011327e6755e5 100644 --- a/pkgs/by-name/te/telepathy-farstream/package.nix +++ b/pkgs/by-name/te/telepathy-farstream/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, telepathy-glib, farstream, dbus-glib }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + telepathy-glib, + farstream, + dbus-glib, +}: stdenv.mkDerivation rec { pname = "telepathy-farstream"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ dbus-glib telepathy-glib farstream ]; + propagatedBuildInputs = [ + dbus-glib + telepathy-glib + farstream + ]; meta = with lib; { description = "GObject-based C library that uses Telepathy GLib, Farstream and GStreamer to handle the media streaming part of channels of type Call"; diff --git a/pkgs/by-name/te/telepathy-gabble/package.nix b/pkgs/by-name/te/telepathy-gabble/package.nix index d2e2676af5addd..560d83c604bb8f 100644 --- a/pkgs/by-name/te/telepathy-gabble/package.nix +++ b/pkgs/by-name/te/telepathy-gabble/package.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchurl, pkg-config, libxslt, telepathy-glib, python3, libxml2, dbus-glib, dbus -, sqlite, libsoup_2_4, libnice, gnutls -, fetchpatch +{ + lib, + stdenv, + fetchurl, + pkg-config, + libxslt, + telepathy-glib, + python3, + libxml2, + dbus-glib, + dbus, + sqlite, + libsoup_2_4, + libnice, + gnutls, + fetchpatch, }: stdenv.mkDerivation rec { @@ -19,8 +32,20 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config libxslt python3 ]; - buildInputs = [ libxml2 dbus-glib sqlite libsoup_2_4 libnice telepathy-glib gnutls ]; + nativeBuildInputs = [ + pkg-config + libxslt + python3 + ]; + buildInputs = [ + libxml2 + dbus-glib + sqlite + libsoup_2_4 + libnice + telepathy-glib + gnutls + ]; nativeCheckInputs = [ dbus ]; diff --git a/pkgs/by-name/te/telepathy-haze/package.nix b/pkgs/by-name/te/telepathy-haze/package.nix index 79034b2dd9dcea..56ff4ef9c29362 100644 --- a/pkgs/by-name/te/telepathy-haze/package.nix +++ b/pkgs/by-name/te/telepathy-haze/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, pidgin, telepathy-glib, python3, glib, dbus-glib, pkg-config, libxslt }: +{ + lib, + stdenv, + fetchurl, + pidgin, + telepathy-glib, + python3, + glib, + dbus-glib, + pkg-config, + libxslt, +}: stdenv.mkDerivation rec { pname = "telepathy-haze"; @@ -9,9 +20,18 @@ stdenv.mkDerivation rec { hash = "sha256-cEvvpC7sIXPspLrAH/0AQBRmXyutRtyJSOVCM2TN4wo="; }; - buildInputs = [ glib telepathy-glib dbus-glib pidgin ]; + buildInputs = [ + glib + telepathy-glib + dbus-glib + pidgin + ]; - nativeBuildInputs = [ pkg-config libxslt python3 ]; + nativeBuildInputs = [ + pkg-config + libxslt + python3 + ]; meta = { description = "Telepathy connection manager based on libpurple"; diff --git a/pkgs/by-name/te/telepathy-idle/package.nix b/pkgs/by-name/te/telepathy-idle/package.nix index 18908fbfb74f5c..52559e1202704b 100644 --- a/pkgs/by-name/te/telepathy-idle/package.nix +++ b/pkgs/by-name/te/telepathy-idle/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, glib, dconf, pkg-config, dbus-glib, telepathy-glib, python3, libxslt, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + glib, + dconf, + pkg-config, + dbus-glib, + telepathy-glib, + python3, + libxslt, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "telepathy-idle"; @@ -9,8 +21,18 @@ stdenv.mkDerivation rec { hash = "sha256-g4fiXl+wtMvnAeXcCS1mbWUQuDP9Pn5GLpFw027DwV8="; }; - nativeBuildInputs = [ pkg-config python3 makeWrapper ]; - buildInputs = [ glib telepathy-glib dbus-glib libxslt (lib.getLib dconf) ]; + nativeBuildInputs = [ + pkg-config + python3 + makeWrapper + ]; + buildInputs = [ + glib + telepathy-glib + dbus-glib + libxslt + (lib.getLib dconf) + ]; preFixup = '' wrapProgram "$out/libexec/telepathy-idle" \ diff --git a/pkgs/by-name/te/telepathy-logger/package.nix b/pkgs/by-name/te/telepathy-logger/package.nix index 70612f529434fd..e60aca4e8bf08a 100644 --- a/pkgs/by-name/te/telepathy-logger/package.nix +++ b/pkgs/by-name/te/telepathy-logger/package.nix @@ -1,6 +1,21 @@ -{ lib, stdenv, fetchurl, dbus-glib, libxml2, sqlite, telepathy-glib, python3, pkg-config -, dconf, makeWrapper, intltool, libxslt, gobject-introspection, dbus -, fetchpatch, darwin +{ + lib, + stdenv, + fetchurl, + dbus-glib, + libxml2, + sqlite, + telepathy-glib, + python3, + pkg-config, + dconf, + makeWrapper, + intltool, + libxslt, + gobject-introspection, + dbus, + fetchpatch, + darwin, }: stdenv.mkDerivation rec { @@ -20,16 +35,25 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ - makeWrapper pkg-config intltool libxslt gobject-introspection + makeWrapper + pkg-config + intltool + libxslt + gobject-introspection python3 ]; - buildInputs = [ - dbus-glib libxml2 sqlite telepathy-glib - dbus - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AppKit - darwin.apple_sdk.frameworks.Foundation - ]; + buildInputs = + [ + dbus-glib + libxml2 + sqlite + telepathy-glib + dbus + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AppKit + darwin.apple_sdk.frameworks.Foundation + ]; configureFlags = [ "--enable-call" ]; diff --git a/pkgs/by-name/te/telepathy-mission-control/package.nix b/pkgs/by-name/te/telepathy-mission-control/package.nix index 5d4bfc5eab4b9e..c4ca90ec31e78e 100644 --- a/pkgs/by-name/te/telepathy-mission-control/package.nix +++ b/pkgs/by-name/te/telepathy-mission-control/package.nix @@ -1,20 +1,26 @@ -{ lib, stdenv -, fetchurl -, pkg-config -, dconf -, telepathy-glib -, python3 -, libxslt -, makeWrapper -, autoreconfHook -, gtk-doc +{ + lib, + stdenv, + fetchurl, + pkg-config, + dconf, + telepathy-glib, + python3, + libxslt, + makeWrapper, + autoreconfHook, + gtk-doc, }: stdenv.mkDerivation rec { pname = "telepathy-mission-control"; version = "5.16.6"; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; src = fetchurl { url = "https://telepathy.freedesktop.org/releases/${pname}/${pname}-${version}.tar.gz"; @@ -25,14 +31,16 @@ stdenv.mkDerivation rec { python3 ]; # ToDo: optional stuff missing - nativeBuildInputs = [ - pkg-config - libxslt - makeWrapper - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - autoreconfHook - gtk-doc - ]; + nativeBuildInputs = + [ + pkg-config + libxslt + makeWrapper + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + autoreconfHook + gtk-doc + ]; propagatedBuildInputs = [ telepathy-glib diff --git a/pkgs/by-name/te/telepresence2/package.nix b/pkgs/by-name/te/telepresence2/package.nix index fea60587a55d6f..8cd9de5f56ae2e 100644 --- a/pkgs/by-name/te/telepresence2/package.nix +++ b/pkgs/by-name/te/telepresence2/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, fuse +{ + lib, + fetchFromGitHub, + buildGoModule, + fuse, }: let @@ -20,7 +21,10 @@ let buildInputs = [ fuse ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; subPackages = [ "pkg/main" ]; }; @@ -50,7 +54,9 @@ buildGoModule rec { vendorHash = "sha256-1Of/IBwXqyKzOSXsJE3vavurvo7ZghfBDlLn4QCR40o="; ldflags = [ - "-s" "-w" "-X=github.com/telepresenceio/telepresence/v2/pkg/version.Version=${src.rev}" + "-s" + "-w" + "-X=github.com/telepresenceio/telepresence/v2/pkg/version.Version=${src.rev}" ]; subPackages = [ "cmd/telepresence" ]; @@ -59,7 +65,10 @@ buildGoModule rec { description = "Local development against a remote Kubernetes or OpenShift cluster"; homepage = "https://telepresence.io"; license = licenses.asl20; - maintainers = with maintainers; [ mausch vilsol ]; + maintainers = with maintainers; [ + mausch + vilsol + ]; mainProgram = "telepresence"; }; } diff --git a/pkgs/by-name/te/teler/package.nix b/pkgs/by-name/te/teler/package.nix index 82183323de8a80..30e4815b1e5778 100644 --- a/pkgs/by-name/te/teler/package.nix +++ b/pkgs/by-name/te/teler/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/te/telescope/package.nix b/pkgs/by-name/te/telescope/package.nix index 801cae0b123c53..dbb549ec98bf54 100644 --- a/pkgs/by-name/te/telescope/package.nix +++ b/pkgs/by-name/te/telescope/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, bison -, libevent -, libgrapheme -, libressl -, ncurses -, autoreconfHook -, buildPackages -, memstreamHook +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + bison, + libevent, + libgrapheme, + libressl, + ncurses, + autoreconfHook, + buildPackages, + memstreamHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/te/televido/package.nix b/pkgs/by-name/te/televido/package.nix index f2c31bb9494293..bf82f2a107c90e 100644 --- a/pkgs/by-name/te/televido/package.nix +++ b/pkgs/by-name/te/televido/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, cargo -, wrapGAppsHook4 -, blueprint-compiler -, libadwaita -, desktop-file-utils -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + cargo, + wrapGAppsHook4, + blueprint-compiler, + libadwaita, + desktop-file-utils, + openssl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/te/templ/package.nix b/pkgs/by-name/te/templ/package.nix index 727ddff217e50f..faa97c8a31a595 100644 --- a/pkgs/by-name/te/templ/package.nix +++ b/pkgs/by-name/te/templ/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/te/template-glib/package.nix b/pkgs/by-name/te/template-glib/package.nix index a8dfade71bfdcb..cef7a7a343052e 100644 --- a/pkgs/by-name/te/template-glib/package.nix +++ b/pkgs/by-name/te/template-glib/package.nix @@ -1,26 +1,31 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, glib -, gobject-introspection -, flex -, bison -, vala -, gettext -, gnome -, gtk-doc -, docbook_xsl -, docbook_xml_dtd_43 +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + glib, + gobject-introspection, + flex, + bison, + vala, + gettext, + gnome, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_43, }: stdenv.mkDerivation rec { pname = "template-glib"; version = "3.36.2"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/by-name/te/tempo/package.nix b/pkgs/by-name/te/tempo/package.nix index 2b5ee20b265c4b..2bb64950f8e547 100644 --- a/pkgs/by-name/te/tempo/package.nix +++ b/pkgs/by-name/te/tempo/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGo122Module, fetchFromGitHub }: +{ + lib, + buildGo122Module, + fetchFromGitHub, +}: # Does not build with Go 1.23 # FIXME: check again for next release diff --git a/pkgs/by-name/te/tempora_lgc/package.nix b/pkgs/by-name/te/tempora_lgc/package.nix index ecafc9572bd161..017bfe8cecb4e4 100644 --- a/pkgs/by-name/te/tempora_lgc/package.nix +++ b/pkgs/by-name/te/tempora_lgc/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: let srcs = [ (fetchurl { @@ -35,7 +39,7 @@ stdenv.mkDerivation { meta = { description = "Tempora font"; - license = lib.licenses.gpl2 ; - maintainers = [lib.maintainers.raskin]; + license = lib.licenses.gpl2; + maintainers = [ lib.maintainers.raskin ]; }; } diff --git a/pkgs/by-name/te/temporal-cli/package.nix b/pkgs/by-name/te/temporal-cli/package.nix index 99329977a70813..e1237e95ddceea 100644 --- a/pkgs/by-name/te/temporal-cli/package.nix +++ b/pkgs/by-name/te/temporal-cli/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, buildGoModule, installShellFiles, symlinkJoin, stdenv }: +{ + lib, + fetchFromGitHub, + buildGoModule, + installShellFiles, + symlinkJoin, + stdenv, +}: let metaCommon = with lib; { @@ -32,7 +39,10 @@ let nativeBuildInputs = [ installShellFiles ]; - excludedPackages = [ "./cmd/docgen" "./tests" ]; + excludedPackages = [ + "./cmd/docgen" + "./tests" + ]; ldflags = [ "-s" @@ -80,7 +90,10 @@ let excludedPackages = [ "./cmd/copyright" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; preCheck = '' export HOME="$(mktemp -d)" diff --git a/pkgs/by-name/te/temporalite/package.nix b/pkgs/by-name/te/temporalite/package.nix index 007daac6bef434..578f81790a26ac 100644 --- a/pkgs/by-name/te/temporalite/package.nix +++ b/pkgs/by-name/te/temporalite/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/te/tenacity/package.nix b/pkgs/by-name/te/tenacity/package.nix index 0ef4ed73787bc7..645549e63b36e1 100644 --- a/pkgs/by-name/te/tenacity/package.nix +++ b/pkgs/by-name/te/tenacity/package.nix @@ -1,49 +1,50 @@ -{ stdenv -, lib -, fetchFromGitea -, cmake -, wxGTK32 -, gtk3 -, pkg-config -, python3 -, gettext -, glib -, file -, lame -, libvorbis -, libmad -, libjack2 -, lv2 -, lilv -, makeWrapper -, serd -, sord -, sqlite -, sratom -, suil -, alsa-lib -, libsndfile -, soxr -, flac -, twolame -, expat -, libid3tag -, libopus -, ffmpeg -, soundtouch -, pcre -, portaudio -, linuxHeaders -, at-spi2-core -, dbus -, libepoxy -, libXdmcp -, libXtst -, libpthreadstubs -, libselinux -, libsepol -, libxkbcommon -, util-linux +{ + stdenv, + lib, + fetchFromGitea, + cmake, + wxGTK32, + gtk3, + pkg-config, + python3, + gettext, + glib, + file, + lame, + libvorbis, + libmad, + libjack2, + lv2, + lilv, + makeWrapper, + serd, + sord, + sqlite, + sratom, + suil, + alsa-lib, + libsndfile, + soxr, + flac, + twolame, + expat, + libid3tag, + libopus, + ffmpeg, + soundtouch, + pcre, + portaudio, + linuxHeaders, + at-spi2-core, + dbus, + libepoxy, + libXdmcp, + libXtst, + libpthreadstubs, + libselinux, + libsepol, + libxkbcommon, + util-linux, }: stdenv.mkDerivation rec { @@ -91,56 +92,60 @@ stdenv.mkDerivation rec { "-lswscale" ]; - nativeBuildInputs = [ - cmake - gettext - makeWrapper - pkg-config - python3 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - linuxHeaders - ]; + nativeBuildInputs = + [ + cmake + gettext + makeWrapper + pkg-config + python3 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + linuxHeaders + ]; - buildInputs = [ - alsa-lib - expat - ffmpeg - file - flac - glib - lame - libid3tag - libjack2 - libmad - libopus - libsndfile - libvorbis - lilv - lv2 - pcre - portaudio - serd - sord - soundtouch - soxr - sqlite - sratom - suil - twolame - wxGTK32 - gtk3 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - at-spi2-core - dbus - libepoxy - libXdmcp - libXtst - libpthreadstubs - libxkbcommon - libselinux - libsepol - util-linux - ]; + buildInputs = + [ + alsa-lib + expat + ffmpeg + file + flac + glib + lame + libid3tag + libjack2 + libmad + libopus + libsndfile + libvorbis + lilv + lv2 + pcre + portaudio + serd + sord + soundtouch + soxr + sqlite + sratom + suil + twolame + wxGTK32 + gtk3 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + at-spi2-core + dbus + libepoxy + libXdmcp + libXtst + libpthreadstubs + libxkbcommon + libselinux + libsepol + util-linux + ]; cmakeFlags = [ # RPATH of binary /nix/store/.../bin/... contains a forbidden reference to /build/ diff --git a/pkgs/by-name/te/tendermint/package.nix b/pkgs/by-name/te/tendermint/package.nix index 858a306e95bb3f..919df221934004 100644 --- a/pkgs/by-name/te/tendermint/package.nix +++ b/pkgs/by-name/te/tendermint/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "tendermint"; diff --git a/pkgs/by-name/te/tenderness/package.nix b/pkgs/by-name/te/tenderness/package.nix index e441d22653f968..59d0fa5f6114b4 100644 --- a/pkgs/by-name/te/tenderness/package.nix +++ b/pkgs/by-name/te/tenderness/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "0"; @@ -26,7 +30,10 @@ stdenvNoCC.mkDerivation { homepage = "http://dotcolon.net/font/tenderness/"; description = "Serif font designed by Sora Sagano with old-style figures"; platforms = platforms.all; - maintainers = with maintainers; [ leenaars minijackson ]; + maintainers = with maintainers; [ + leenaars + minijackson + ]; license = licenses.ofl; }; } diff --git a/pkgs/by-name/te/tenki/package.nix b/pkgs/by-name/te/tenki/package.nix index ccf3757bdb3730..9832e910d07858 100644 --- a/pkgs/by-name/te/tenki/package.nix +++ b/pkgs/by-name/te/tenki/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { pname = "tenki"; diff --git a/pkgs/by-name/te/tennix/package.nix b/pkgs/by-name/te/tennix/package.nix index 3968751886ba3c..5868950e7471a7 100644 --- a/pkgs/by-name/te/tennix/package.nix +++ b/pkgs/by-name/te/tennix/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchgit, which, SDL, SDL_mixer, SDL_image, SDL_ttf, SDL_net, python3 } : +{ + lib, + stdenv, + fetchgit, + which, + SDL, + SDL_mixer, + SDL_image, + SDL_ttf, + SDL_net, + python3, +}: stdenv.mkDerivation rec { pname = "tennix"; @@ -12,7 +23,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ which ]; - buildInputs = [ python3 SDL SDL_mixer SDL_image SDL_ttf SDL_net ]; + buildInputs = [ + python3 + SDL + SDL_mixer + SDL_image + SDL_ttf + SDL_net + ]; configurePhase = '' ./configure --prefix $out diff --git a/pkgs/by-name/te/tensorman/package.nix b/pkgs/by-name/te/tensorman/package.nix index b6f11d190c105c..03e372ac0b0d68 100644 --- a/pkgs/by-name/te/tensorman/package.nix +++ b/pkgs/by-name/te/tensorman/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage { diff --git a/pkgs/by-name/te/tenv/package.nix b/pkgs/by-name/te/tenv/package.nix index 8e76ac0c240809..29c4012a70c90f 100644 --- a/pkgs/by-name/te/tenv/package.nix +++ b/pkgs/by-name/te/tenv/package.nix @@ -1,4 +1,12 @@ -{ stdenv, buildGoModule, fetchFromGitHub, installShellFiles, lib, tenv, testers }: +{ + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, + lib, + tenv, + testers, +}: buildGoModule rec { pname = "tenv"; @@ -17,7 +25,8 @@ buildGoModule rec { doCheck = false; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X main.version=v${version}" ]; @@ -41,6 +50,10 @@ buildGoModule rec { description = "OpenTofu, Terraform, Terragrunt and Atmos version manager written in Go"; homepage = "https://tofuutils.github.io/tenv"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ rmgpinto nmishin kvendingoldo ]; + maintainers = with lib.maintainers; [ + rmgpinto + nmishin + kvendingoldo + ]; }; } diff --git a/pkgs/by-name/te/tera-cli/package.nix b/pkgs/by-name/te/tera-cli/package.nix index bafe597a24f5cd..8c90c781130688 100644 --- a/pkgs/by-name/te/tera-cli/package.nix +++ b/pkgs/by-name/te/tera-cli/package.nix @@ -1,7 +1,7 @@ { lib, fetchFromGitHub, - rustPlatform + rustPlatform, }: rustPlatform.buildRustPackage rec { pname = "tera-cli"; @@ -20,7 +20,7 @@ rustPlatform.buildRustPackage rec { description = "Command line utility to render templates from json|toml|yaml and ENV, using the tera templating engine"; homepage = "https://github.com/chevdor/tera-cli"; license = licenses.mit; - maintainers = with maintainers; [_365tuwe]; + maintainers = with maintainers; [ _365tuwe ]; mainProgram = "tera"; platforms = platforms.linux; }; diff --git a/pkgs/by-name/te/tere/package.nix b/pkgs/by-name/te/tere/package.nix index cadf6ec5963532..a0af183e197f10 100644 --- a/pkgs/by-name/te/tere/package.nix +++ b/pkgs/by-name/te/tere/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, rustPlatform, ncurses, stdenv, python3 }: +{ + lib, + fetchFromGitHub, + rustPlatform, + ncurses, + stdenv, + python3, +}: rustPlatform.buildRustPackage { pname = "tere"; @@ -29,7 +36,7 @@ rustPlatform.buildRustPackage { # See https://github.com/NixOS/nixpkgs/issues/145726#issuecomment-971331986 preBuild = let - python-with-toml = python3.withPackages (ps: [ps.toml]); + python-with-toml = python3.withPackages (ps: [ ps.toml ]); script = builtins.toFile "clear_linkers.py" '' from os import path import toml @@ -47,7 +54,7 @@ rustPlatform.buildRustPackage { exit(1) ''; in - "${python-with-toml}/bin/python3 ${script}"; + "${python-with-toml}/bin/python3 ${script}"; meta = with lib; { description = "Faster alternative to cd + ls"; diff --git a/pkgs/by-name/te/termbook/package.nix b/pkgs/by-name/te/termbook/package.nix index 7172de5e41d7f2..d6b450f6b7de00 100644 --- a/pkgs/by-name/te/termbook/package.nix +++ b/pkgs/by-name/te/termbook/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, oniguruma -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + oniguruma, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -28,11 +29,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - oniguruma - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + oniguruma + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; env = { RUSTONIG_SYSTEM_LIBONIG = true; diff --git a/pkgs/by-name/te/termbox/package.nix b/pkgs/by-name/te/termbox/package.nix index 22657cd663a2e6..f0f797b75f54be 100644 --- a/pkgs/by-name/te/termbox/package.nix +++ b/pkgs/by-name/te/termbox/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation (finalAttrs: { pname = "termbox"; diff --git a/pkgs/by-name/te/termcap/package.nix b/pkgs/by-name/te/termcap/package.nix index 9a91ead85985fc..a0cf6eaadeb679 100644 --- a/pkgs/by-name/te/termcap/package.nix +++ b/pkgs/by-name/te/termcap/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, autoreconfHook -, enableStatic ? stdenv.hostPlatform.isStatic -, enableShared ? !stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + enableStatic ? stdenv.hostPlatform.isStatic, + enableShared ? !stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { @@ -24,7 +25,10 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; enableParallelBuilding = true; @@ -36,26 +40,34 @@ stdenv.mkDerivation rec { "AR=${stdenv.cc.targetPrefix}ar" ]; - env.NIX_CFLAGS_COMPILE = toString ([ - "-DSTDC_HEADERS" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-implicit-function-declaration" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-DSTDC_HEADERS" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-implicit-function-declaration" + ] + ); # Library only statically links by default - postInstall = lib.optionalString (!enableStatic) '' - rm $out/lib/libtermcap.a - '' + lib.optionalString enableShared (let - libName = "libtermcap${stdenv.hostPlatform.extensions.sharedLibrary}"; - impLibName = "libtermcap.dll.a"; - winImpLib = lib.optionalString stdenv.hostPlatform.isWindows - "-Wl,--out-implib,${impLibName}"; - in '' - ${stdenv.cc.targetPrefix}cc -shared -o ${libName} termcap.o tparam.o version.o ${winImpLib} - install -Dm644 ${libName} $out/lib - '' + lib.optionalString stdenv.hostPlatform.isWindows '' - install -Dm644 ${impLibName} $out/lib - ''); + postInstall = + lib.optionalString (!enableStatic) '' + rm $out/lib/libtermcap.a + '' + + lib.optionalString enableShared ( + let + libName = "libtermcap${stdenv.hostPlatform.extensions.sharedLibrary}"; + impLibName = "libtermcap.dll.a"; + winImpLib = lib.optionalString stdenv.hostPlatform.isWindows "-Wl,--out-implib,${impLibName}"; + in + '' + ${stdenv.cc.targetPrefix}cc -shared -o ${libName} termcap.o tparam.o version.o ${winImpLib} + install -Dm644 ${libName} $out/lib + '' + + lib.optionalString stdenv.hostPlatform.isWindows '' + install -Dm644 ${impLibName} $out/lib + '' + ); meta = { description = "Terminal feature database"; diff --git a/pkgs/by-name/te/termcolor/package.nix b/pkgs/by-name/te/termcolor/package.nix index f29776226dc299..6741ffdb44704d 100644 --- a/pkgs/by-name/te/termcolor/package.nix +++ b/pkgs/by-name/te/termcolor/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/te/termdbms/package.nix b/pkgs/by-name/te/termdbms/package.nix index 06521cde30a915..342781555a54f4 100644 --- a/pkgs/by-name/te/termdbms/package.nix +++ b/pkgs/by-name/te/termdbms/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "termdbms"; @@ -15,7 +19,11 @@ buildGoModule rec { patches = [ ./viewer.patch ]; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; meta = with lib; { homepage = "https://github.com/mathaou/termdbms/"; diff --git a/pkgs/by-name/te/termimage/package.nix b/pkgs/by-name/te/termimage/package.nix index 3703d5a993e5a8..1b13e33866ec29 100644 --- a/pkgs/by-name/te/termimage/package.nix +++ b/pkgs/by-name/te/termimage/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchCrate -, installShellFiles -, ronn +{ + lib, + rustPlatform, + fetchCrate, + installShellFiles, + ronn, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/te/terminal-colors/package.nix b/pkgs/by-name/te/terminal-colors/package.nix index fc196be625e5b9..332e22a195dc9c 100644 --- a/pkgs/by-name/te/terminal-colors/package.nix +++ b/pkgs/by-name/te/terminal-colors/package.nix @@ -1,9 +1,18 @@ -{ stdenv, lib, help2man, python3, fetchFromGitHub }: +{ + stdenv, + lib, + help2man, + python3, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "terminal-colors"; version = "3.0.2"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchFromGitHub { owner = "eikenb"; diff --git a/pkgs/by-name/te/terminal-notifier/package.nix b/pkgs/by-name/te/terminal-notifier/package.nix index e2bd8dd2f9c56f..60853bfc409866 100644 --- a/pkgs/by-name/te/terminal-notifier/package.nix +++ b/pkgs/by-name/te/terminal-notifier/package.nix @@ -1,4 +1,9 @@ -{ stdenv, runtimeShell, lib, fetchzip }: +{ + stdenv, + runtimeShell, + lib, + fetchzip, +}: stdenv.mkDerivation rec { pname = "terminal-notifier"; @@ -29,6 +34,6 @@ stdenv.mkDerivation rec { maintainers = [ ]; homepage = "https://github.com/julienXX/terminal-notifier"; license = licenses.mit; - platforms = platforms.darwin; + platforms = platforms.darwin; }; } diff --git a/pkgs/by-name/te/terminal-parrot/package.nix b/pkgs/by-name/te/terminal-parrot/package.nix index 3d114302031ab9..f3e7cec81db3e3 100644 --- a/pkgs/by-name/te/terminal-parrot/package.nix +++ b/pkgs/by-name/te/terminal-parrot/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "terminal-parrot"; diff --git a/pkgs/by-name/te/terminal-stocks/package.nix b/pkgs/by-name/te/terminal-stocks/package.nix index 381bed40331538..74932e87cad8ba 100644 --- a/pkgs/by-name/te/terminal-stocks/package.nix +++ b/pkgs/by-name/te/terminal-stocks/package.nix @@ -1,4 +1,9 @@ -{ lib, buildNpmPackage, fetchFromGitHub, nix-update-script }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, + nix-update-script, +}: buildNpmPackage rec { pname = "terminal-stocks"; @@ -14,7 +19,7 @@ buildNpmPackage rec { npmDepsHash = "sha256-0k2+vdfOUF0zV6Tl7VGXS2dNLnCHgSdI12LqvGkbv+k="; dontNpmBuild = true; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = with lib; { description = "Terminal based application that provides stock price information"; diff --git a/pkgs/by-name/te/terminator/package.nix b/pkgs/by-name/te/terminator/package.nix index 01047f26bc634a..e37ceaf8b5ef6c 100644 --- a/pkgs/by-name/te/terminator/package.nix +++ b/pkgs/by-name/te/terminator/package.nix @@ -1,16 +1,17 @@ -{ lib -, fetchFromGitHub -, python3 -, keybinder3 -, intltool -, file -, gtk3 -, gobject-introspection -, libnotify -, makeBinaryWrapper -, wrapGAppsHook3 -, vte -, nixosTests +{ + lib, + fetchFromGitHub, + python3, + keybinder3, + intltool, + file, + gtk3, + gobject-introspection, + libnotify, + makeBinaryWrapper, + wrapGAppsHook3, + vte, + nixosTests, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/te/terminus_font/package.nix b/pkgs/by-name/te/terminus_font/package.nix index 760993dcd8cf2c..9727a61e835bb9 100644 --- a/pkgs/by-name/te/terminus_font/package.nix +++ b/pkgs/by-name/te/terminus_font/package.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchurl, python3 -, bdftopcf, xorg +{ + lib, + stdenv, + fetchurl, + python3, + bdftopcf, + xorg, }: stdenv.mkDerivation rec { @@ -13,8 +18,11 @@ stdenv.mkDerivation rec { patches = [ ./SOURCE_DATE_EPOCH-for-otb.patch ]; - nativeBuildInputs = - [ python3 bdftopcf xorg.mkfontscale ]; + nativeBuildInputs = [ + python3 + bdftopcf + xorg.mkfontscale + ]; enableParallelBuilding = true; @@ -23,7 +31,11 @@ stdenv.mkDerivation rec { substituteInPlace Makefile --replace 'gzip' 'gzip -n' ''; - installTargets = [ "install" "install-otb" "fontdir" ]; + installTargets = [ + "install" + "install-otb" + "fontdir" + ]; # fontdir depends on the previous two targets, but this is not known # to make, so we need to disable parallelism: enableParallelInstalling = false; diff --git a/pkgs/by-name/te/terminus_font_ttf/package.nix b/pkgs/by-name/te/terminus_font_ttf/package.nix index 6591fa0d32d0a4..a68c7952c1142d 100644 --- a/pkgs/by-name/te/terminus_font_ttf/package.nix +++ b/pkgs/by-name/te/terminus_font_ttf/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "terminus-font-ttf"; diff --git a/pkgs/by-name/te/termonad/package.nix b/pkgs/by-name/te/termonad/package.nix index efddfa4546680e..482ab2d3c4f263 100644 --- a/pkgs/by-name/te/termonad/package.nix +++ b/pkgs/by-name/te/termonad/package.nix @@ -1,8 +1,15 @@ -{ stdenv, haskellPackages, makeWrapper, packages ? (pkgSet: []), nixosTests }: +{ + stdenv, + haskellPackages, + makeWrapper, + packages ? (pkgSet: [ ]), + nixosTests, +}: let termonadEnv = haskellPackages.ghcWithPackages (self: [ self.termonad ] ++ packages self); -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "termonad-with-packages"; inherit (termonadEnv) version; diff --git a/pkgs/by-name/te/termplay/package.nix b/pkgs/by-name/te/termplay/package.nix index dccf9d38fe6a25..79fcd6f03687bc 100644 --- a/pkgs/by-name/te/termplay/package.nix +++ b/pkgs/by-name/te/termplay/package.nix @@ -1,4 +1,11 @@ -{ rustPlatform, fetchFromGitLab, lib, makeWrapper, gst_all_1, libsixel }: +{ + rustPlatform, + fetchFromGitLab, + lib, + makeWrapper, + gst_all_1, + libsixel, +}: rustPlatform.buildRustPackage rec { pname = "termplay"; diff --git a/pkgs/by-name/te/termshark/package.nix b/pkgs/by-name/te/termshark/package.nix index 5535ca550b81d0..4e8439fa032928 100644 --- a/pkgs/by-name/te/termshark/package.nix +++ b/pkgs/by-name/te/termshark/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, makeWrapper, buildGoModule, wireshark-cli }: +{ + lib, + fetchFromGitHub, + makeWrapper, + buildGoModule, + wireshark-cli, +}: buildGoModule rec { pname = "termshark"; diff --git a/pkgs/by-name/te/termshot/package.nix b/pkgs/by-name/te/termshot/package.nix index 7ef65ba90e30bc..d3e580ae3244c5 100644 --- a/pkgs/by-name/te/termshot/package.nix +++ b/pkgs/by-name/te/termshot/package.nix @@ -16,7 +16,7 @@ buildGoModule rec { vendorHash = "sha256-JweKjKvShiimFHQwRtoVuongWqqGIPcPz77qEVNec+M="; - patches = [./go-mod.patch]; + patches = [ ./go-mod.patch ]; ldflags = [ "-s" @@ -28,7 +28,7 @@ buildGoModule rec { description = "Creates screenshots based on terminal command output"; homepage = "https://github.com/homeport/termshot"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [defelo]; + maintainers = with lib.maintainers; [ defelo ]; mainProgram = "termshot"; }; } diff --git a/pkgs/by-name/te/termsonic/package.nix b/pkgs/by-name/te/termsonic/package.nix index a91433762f60d7..7d898ae9421700 100644 --- a/pkgs/by-name/te/termsonic/package.nix +++ b/pkgs/by-name/te/termsonic/package.nix @@ -3,7 +3,7 @@ buildGoModule, fetchzip, pkg-config, - alsa-lib + alsa-lib, }: buildGoModule rec { name = "termsonic"; diff --git a/pkgs/by-name/te/termsyn/package.nix b/pkgs/by-name/te/termsyn/package.nix index 50450a04e2d8c5..5ab5b9b2907a23 100644 --- a/pkgs/by-name/te/termsyn/package.nix +++ b/pkgs/by-name/te/termsyn/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, mkfontscale }: +{ + lib, + stdenv, + fetchurl, + mkfontscale, +}: stdenv.mkDerivation rec { pname = "termsyn"; diff --git a/pkgs/by-name/te/termtekst/package.nix b/pkgs/by-name/te/termtekst/package.nix index 76aa0c79832b0b..09b13dd744593a 100644 --- a/pkgs/by-name/te/termtekst/package.nix +++ b/pkgs/by-name/te/termtekst/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, python3Packages, ncurses }: +{ + lib, + fetchFromGitHub, + python3Packages, + ncurses, +}: python3Packages.buildPythonApplication rec { pname = "termtekst"; @@ -11,14 +16,17 @@ python3Packages.buildPythonApplication rec { sha256 = "1gm7j5d49a60wm7px82b76f610i8pl8ccz4r6qsz90z4mp3lyw9b"; }; - propagatedBuildInputs = with python3Packages; [ ncurses requests ]; + propagatedBuildInputs = with python3Packages; [ + ncurses + requests + ]; patchPhase = '' substituteInPlace setup.py \ --replace "assert" "assert 1==1 #" substituteInPlace src/tt \ --replace "locale.setlocale" "#locale.setlocale" - ''; + ''; meta = with lib; { description = "Console NOS Teletekst viewer in Python"; diff --git a/pkgs/by-name/te/termtosvg/package.nix b/pkgs/by-name/te/termtosvg/package.nix index 2de15e155c5845..8904dc581a14c2 100644 --- a/pkgs/by-name/te/termtosvg/package.nix +++ b/pkgs/by-name/te/termtosvg/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "termtosvg"; @@ -9,7 +13,11 @@ python3Packages.buildPythonApplication rec { sha256 = "1vk5kn8w3zf2ymi76l8cpwmvvavkmh3b9lb18xw3x1vzbmhz2f7d"; }; - propagatedBuildInputs = with python3Packages; [ lxml pyte wcwidth ]; + propagatedBuildInputs = with python3Packages; [ + lxml + pyte + wcwidth + ]; meta = with lib; { homepage = "https://nbedos.github.io/termtosvg/"; diff --git a/pkgs/by-name/te/ternimal/package.nix b/pkgs/by-name/te/ternimal/package.nix index 31f796f1ae6008..726d6638864a9e 100644 --- a/pkgs/by-name/te/ternimal/package.nix +++ b/pkgs/by-name/te/ternimal/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustc +{ + lib, + stdenv, + fetchFromGitHub, + rustc, }: stdenv.mkDerivation { pname = "ternimal"; diff --git a/pkgs/by-name/te/terra-station/package.nix b/pkgs/by-name/te/terra-station/package.nix index fe96eebecc1fd4..7cfc3a97e3d9ba 100644 --- a/pkgs/by-name/te/terra-station/package.nix +++ b/pkgs/by-name/te/terra-station/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchurl -, dpkg -, makeWrapper -, electron -, asar +{ + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + electron, + asar, }: let @@ -11,13 +13,17 @@ let throwSystem = throw "Unsupported system: ${stdenv.hostPlatform.system}"; - sha256 = { - "x86_64-linux" = "139nlr191bsinx6ixpi2glcr03lsnzq7b0438h3245napsnjpx6p"; - }."${system}" or throwSystem; + sha256 = + { + "x86_64-linux" = "139nlr191bsinx6ixpi2glcr03lsnzq7b0438h3245napsnjpx6p"; + } + ."${system}" or throwSystem; - arch = { - "x86_64-linux" = "amd64"; - }."${system}" or throwSystem; + arch = + { + "x86_64-linux" = "amd64"; + } + ."${system}" or throwSystem; in @@ -30,7 +36,11 @@ stdenv.mkDerivation rec { inherit sha256; }; - nativeBuildInputs = [ makeWrapper asar dpkg ]; + nativeBuildInputs = [ + makeWrapper + asar + dpkg + ]; dontConfigure = true; dontBuild = true; diff --git a/pkgs/by-name/te/terracognita/package.nix b/pkgs/by-name/te/terracognita/package.nix index 1084fd9b06b085..f5afcc70ef02ea 100644 --- a/pkgs/by-name/te/terracognita/package.nix +++ b/pkgs/by-name/te/terracognita/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "terracognita"; @@ -17,7 +21,11 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" "-X github.com/cycloidio/terracognita/cmd.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/cycloidio/terracognita/cmd.Version=${version}" + ]; meta = with lib; { description = "Reads from existing Cloud Providers (reverse Terraform) and generates your infrastructure as code on Terraform configuration"; diff --git a/pkgs/by-name/te/terraform-backend-git/package.nix b/pkgs/by-name/te/terraform-backend-git/package.nix index 1c96250f991ced..cba0fd94eacaf4 100644 --- a/pkgs/by-name/te/terraform-backend-git/package.nix +++ b/pkgs/by-name/te/terraform-backend-git/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/te/terraform-compliance/package.nix b/pkgs/by-name/te/terraform-compliance/package.nix index 1eba12ac529314..bb1258ad8a6e20 100644 --- a/pkgs/by-name/te/terraform-compliance/package.nix +++ b/pkgs/by-name/te/terraform-compliance/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -56,6 +57,9 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://github.com/terraform-compliance/cli"; changelog = "https://github.com/terraform-compliance/cli/releases/tag/${version}"; license = licenses.mit; - maintainers = with maintainers; [ kalbasit kashw2 ]; + maintainers = with maintainers; [ + kalbasit + kashw2 + ]; }; } diff --git a/pkgs/by-name/te/terraform-inventory/package.nix b/pkgs/by-name/te/terraform-inventory/package.nix index 56763aca067930..aeec2b66e1f576 100644 --- a/pkgs/by-name/te/terraform-inventory/package.nix +++ b/pkgs/by-name/te/terraform-inventory/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, terraform-inventory }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + terraform-inventory, +}: buildGoModule rec { pname = "terraform-inventory"; @@ -13,7 +19,11 @@ buildGoModule rec { vendorHash = "sha256-pj9XLzaGU1PuNnpTL/7XaKJZUymX+i8hFMroZtHIqTc="; - ldflags = [ "-s" "-w" "-X main.build_version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.build_version=${version}" + ]; doCheck = false; diff --git a/pkgs/by-name/te/terraform-ls/package.nix b/pkgs/by-name/te/terraform-ls/package.nix index a1e2b690046074..1210d33d915adf 100644 --- a/pkgs/by-name/te/terraform-ls/package.nix +++ b/pkgs/by-name/te/terraform-ls/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "terraform-ls"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-JW8qs2ZjH+S8zdEh8/da0SptooE3iTS6JqoIUh20R2Y="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; # There's a mixture of tests that use networking and several that fail on aarch64 doCheck = false; @@ -32,6 +39,9 @@ buildGoModule rec { homepage = "https://github.com/hashicorp/terraform-ls"; changelog = "https://github.com/hashicorp/terraform-ls/blob/v${version}/CHANGELOG.md"; license = licenses.mpl20; - maintainers = with maintainers; [ mbaillie jk ]; + maintainers = with maintainers; [ + mbaillie + jk + ]; }; } diff --git a/pkgs/by-name/te/terraform-lsp/package.nix b/pkgs/by-name/te/terraform-lsp/package.nix index 35a503d8b0aadd..385aca330aaa74 100644 --- a/pkgs/by-name/te/terraform-lsp/package.nix +++ b/pkgs/by-name/te/terraform-lsp/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,12 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" "-X main.Version=${version}" "-X main.GitCommit=${src.rev}" ]; + ldflags = [ + "-s" + "-w" + "-X main.Version=${version}" + "-X main.GitCommit=${src.rev}" + ]; meta = with lib; { description = "Language Server Protocol for Terraform"; diff --git a/pkgs/by-name/te/terraform-plugin-docs/package.nix b/pkgs/by-name/te/terraform-plugin-docs/package.nix index 6911bd2f9c2f90..38780239d54b53 100644 --- a/pkgs/by-name/te/terraform-plugin-docs/package.nix +++ b/pkgs/by-name/te/terraform-plugin-docs/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, go -, testers -, terraform-plugin-docs -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + go, + testers, + terraform-plugin-docs, + nix-update-script, }: buildGoModule rec { diff --git a/pkgs/by-name/te/terraformer/package.nix b/pkgs/by-name/te/terraformer/package.nix index e38d753b46887c..25d9083c861b45 100644 --- a/pkgs/by-name/te/terraformer/package.nix +++ b/pkgs/by-name/te/terraformer/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "terraformer"; diff --git a/pkgs/by-name/te/terragrunt/package.nix b/pkgs/by-name/te/terragrunt/package.nix index ede6c2f25fbeca..426d1d28f96103 100644 --- a/pkgs/by-name/te/terragrunt/package.nix +++ b/pkgs/by-name/te/terragrunt/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, go-mockery +{ + lib, + buildGoModule, + fetchFromGitHub, + go-mockery, }: buildGoModule rec { @@ -47,6 +48,10 @@ buildGoModule rec { description = "Thin wrapper for Terraform that supports locking for Terraform state and enforces best practices"; mainProgram = "terragrunt"; license = licenses.mit; - maintainers = with maintainers; [ jk qjoly kashw2 ]; + maintainers = with maintainers; [ + jk + qjoly + kashw2 + ]; }; } diff --git a/pkgs/by-name/te/terranix/package.nix b/pkgs/by-name/te/terranix/package.nix index e5b3222b9b0cb1..65f1d715154c7b 100644 --- a/pkgs/by-name/te/terranix/package.nix +++ b/pkgs/by-name/te/terranix/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, jq, nix, makeWrapper }: +{ + stdenv, + lib, + fetchFromGitHub, + jq, + nix, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "terranix"; @@ -18,7 +25,12 @@ stdenv.mkDerivation rec { mv bin core modules lib share $out/ wrapProgram $out/bin/terranix-doc-json \ - --prefix PATH : ${lib.makeBinPath [ jq nix ]} + --prefix PATH : ${ + lib.makeBinPath [ + jq + nix + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/te/terrapin-scanner/package.nix b/pkgs/by-name/te/terrapin-scanner/package.nix index 2bf04dc676de7b..407bab022e7ef3 100644 --- a/pkgs/by-name/te/terrapin-scanner/package.nix +++ b/pkgs/by-name/te/terrapin-scanner/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/te/terraria-server/package.nix b/pkgs/by-name/te/terraria-server/package.nix index c1e48f259d7991..babfa76a6051cf 100644 --- a/pkgs/by-name/te/terraria-server/package.nix +++ b/pkgs/by-name/te/terraria-server/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl - -, autoPatchelfHook -, unzip -, zlib +{ + lib, + stdenv, + fetchurl, + + autoPatchelfHook, + unzip, + zlib, }: stdenv.mkDerivation rec { @@ -17,8 +18,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-Mk+5s9OlkyTLXZYVT0+8Qcjy2Sb5uy2hcC8CML0biNY="; }; - nativeBuildInputs = [ autoPatchelfHook unzip ]; - buildInputs = [ stdenv.cc.cc.libgcc zlib ]; + nativeBuildInputs = [ + autoPatchelfHook + unzip + ]; + buildInputs = [ + stdenv.cc.cc.libgcc + zlib + ]; installPhase = '' runHook preInstall @@ -37,6 +44,9 @@ stdenv.mkDerivation rec { platforms = [ "x86_64-linux" ]; license = licenses.unfree; mainProgram = "TerrariaServer"; - maintainers = with maintainers; [ ncfavier tomasajt ]; + maintainers = with maintainers; [ + ncfavier + tomasajt + ]; }; } diff --git a/pkgs/by-name/te/terrascan/package.nix b/pkgs/by-name/te/terrascan/package.nix index 416e3cf1fdf5af..049138676f449c 100644 --- a/pkgs/by-name/te/terrascan/package.nix +++ b/pkgs/by-name/te/terrascan/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/te/tes3cmd/package.nix b/pkgs/by-name/te/tes3cmd/package.nix index 18fa0edc43683c..2c7b244cb8ff4d 100644 --- a/pkgs/by-name/te/tes3cmd/package.nix +++ b/pkgs/by-name/te/tes3cmd/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, perlPackages, fetchFromGitHub }: +{ + stdenv, + lib, + perlPackages, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "tes3cmd"; diff --git a/pkgs/by-name/te/teseq/package.nix b/pkgs/by-name/te/teseq/package.nix index c07cc39f84ef79..9416940092eb5a 100644 --- a/pkgs/by-name/te/teseq/package.nix +++ b/pkgs/by-name/te/teseq/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let version = "1.1.1"; diff --git a/pkgs/by-name/te/tesh/package.nix b/pkgs/by-name/te/tesh/package.nix index 13284d8e0db461..0e1ff3a788e3e5 100644 --- a/pkgs/by-name/te/tesh/package.nix +++ b/pkgs/by-name/te/tesh/package.nix @@ -2,7 +2,8 @@ let version = "0.3.2"; -in python3Packages.buildPythonPackage rec { +in +python3Packages.buildPythonPackage rec { pname = "tesh"; inherit version; @@ -17,5 +18,9 @@ in python3Packages.buildPythonPackage rec { checkInputs = [ python3Packages.pytest ]; nativeBuildInputs = [ python3Packages.poetry-core ]; - propagatedBuildInputs = with python3Packages; [ click pexpect distutils ]; + propagatedBuildInputs = with python3Packages; [ + click + pexpect + distutils + ]; } diff --git a/pkgs/by-name/te/tessen/package.nix b/pkgs/by-name/te/tessen/package.nix index 961c86753d7651..21c22f3a2cc0d9 100644 --- a/pkgs/by-name/te/tessen/package.nix +++ b/pkgs/by-name/te/tessen/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenvNoCC -, fetchFromSourcehut -, makeWrapper -, installShellFiles -, wtype -, wl-clipboard -, pass -, bemenu -, scdoc +{ + lib, + stdenvNoCC, + fetchFromSourcehut, + makeWrapper, + installShellFiles, + wtype, + wl-clipboard, + pass, + bemenu, + scdoc, }: stdenvNoCC.mkDerivation rec { @@ -16,19 +17,30 @@ stdenvNoCC.mkDerivation rec { src = fetchFromSourcehut { owner = "~ayushnix"; - repo = pname; + repo = pname; rev = "v${version}"; - sha256 = "sha256-mVGsI1JBG7X8J7gqocdfxWuTVSZpxS23QPGHCUofvV8="; + sha256 = "sha256-mVGsI1JBG7X8J7gqocdfxWuTVSZpxS23QPGHCUofvV8="; }; - nativeBuildInputs = [ makeWrapper installShellFiles scdoc ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + scdoc + ]; dontBuild = true; installPhase = '' runHook preInstall install -D tessen $out/bin/tessen - wrapProgram $out/bin/tessen --prefix PATH : ${ lib.makeBinPath [ bemenu pass wtype wl-clipboard ] } + wrapProgram $out/bin/tessen --prefix PATH : ${ + lib.makeBinPath [ + bemenu + pass + wtype + wl-clipboard + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/te/tessera/package.nix b/pkgs/by-name/te/tessera/package.nix index 03bd6734a9a590..77a5bff8c88b73 100644 --- a/pkgs/by-name/te/tessera/package.nix +++ b/pkgs/by-name/te/tessera/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "tessera"; diff --git a/pkgs/by-name/te/test-drive/package.nix b/pkgs/by-name/te/test-drive/package.nix index 41fc83844287ec..5737fd31365490 100644 --- a/pkgs/by-name/te/test-drive/package.nix +++ b/pkgs/by-name/te/test-drive/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, gfortran, meson, ninja, mesonEmulatorHook }: +{ + stdenv, + lib, + fetchFromGitHub, + gfortran, + meson, + ninja, + mesonEmulatorHook, +}: stdenv.mkDerivation rec { pname = "test-drive"; @@ -11,20 +19,25 @@ stdenv.mkDerivation rec { hash = "sha256-xRx8ErIN9xjxZt/nEsdIQkIGFRltuELdlI8lXA+M030="; }; - nativeBuildInputs = [ - gfortran - meson - ninja - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + gfortran + meson + ninja + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; mesonAutoFeatures = "auto"; meta = with lib; { description = "Procedural Fortran testing framework"; homepage = "https://github.com/fortran-lang/test-drive"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; platforms = platforms.linux; maintainers = [ maintainers.sheepforce ]; }; diff --git a/pkgs/by-name/te/testssl/package.nix b/pkgs/by-name/te/testssl/package.nix index 678262243e2ae8..26197d6df2a6d7 100644 --- a/pkgs/by-name/te/testssl/package.nix +++ b/pkgs/by-name/te/testssl/package.nix @@ -1,5 +1,15 @@ -{ stdenv, fetchFromGitHub, makeWrapper, lib -, dnsutils, coreutils, openssl, nettools, util-linux, procps }: +{ + stdenv, + fetchFromGitHub, + makeWrapper, + lib, + dnsutils, + coreutils, + openssl, + nettools, + util-linux, + procps, +}: stdenv.mkDerivation rec { pname = "testssl.sh"; @@ -15,10 +25,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; buildInputs = [ coreutils # for printf - dnsutils # for dig - nettools # for hostname - openssl # for openssl - procps # for ps + dnsutils # for dig + nettools # for hostname + openssl # for openssl + procps # for ps util-linux # for hexdump ]; diff --git a/pkgs/by-name/te/tet/package.nix b/pkgs/by-name/te/tet/package.nix index 45f1af60ecf969..017e57547d72d5 100644 --- a/pkgs/by-name/te/tet/package.nix +++ b/pkgs/by-name/te/tet/package.nix @@ -1,4 +1,8 @@ -{ fetchurl, lib, stdenv }: +{ + fetchurl, + lib, + stdenv, +}: stdenv.mkDerivation ({ version = "3.8"; @@ -6,7 +10,7 @@ stdenv.mkDerivation ({ src = fetchurl { url = "http://tetworks.opengroup.org/downloads/38/software/Sources/3.8/tet3.8-src.tar.gz"; - sha256 = "1j57hv56df38w249l595b8rsgmsyvjkbysai03a9724gax5jl9av" ; + sha256 = "1j57hv56df38w249l595b8rsgmsyvjkbysai03a9724gax5jl9av"; }; patchPhase = "chmod +x configure"; diff --git a/pkgs/by-name/te/tetragon/package.nix b/pkgs/by-name/te/tetragon/package.nix index 26c687372865d4..018c8c4f3fcd93 100644 --- a/pkgs/by-name/te/tetragon/package.nix +++ b/pkgs/by-name/te/tetragon/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, go -, llvm_16 -, clang_16 -, bash +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + go, + llvm_16, + clang_16, + bash, }: stdenv.mkDerivation (finalAttrs: { @@ -62,13 +63,12 @@ stdenv.mkDerivation (finalAttrs: { ''; meta = with lib; { - description = "Real-time, eBPF-based Security Observability and Runtime Enforcement tool"; - homepage = "https://github.com/cilium/tetragon"; - license = licenses.asl20; - mainProgram = "tetragon"; - maintainers = with maintainers; [ gangaram ]; - platforms = platforms.linux; + description = "Real-time, eBPF-based Security Observability and Runtime Enforcement tool"; + homepage = "https://github.com/cilium/tetragon"; + license = licenses.asl20; + mainProgram = "tetragon"; + maintainers = with maintainers; [ gangaram ]; + platforms = platforms.linux; sourceProvenance = with sourceTypes; [ fromSource ]; }; }) - diff --git a/pkgs/by-name/te/tetraproc/package.nix b/pkgs/by-name/te/tetraproc/package.nix index 2c15d1e205dbc2..915954bea57702 100644 --- a/pkgs/by-name/te/tetraproc/package.nix +++ b/pkgs/by-name/te/tetraproc/package.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchurl, makeWrapper -, expat, fftwFloat, fontconfig, freetype, libjack2, jack2, libclthreads, libclxclient -, libsndfile, libxcb, xorg +{ + lib, + stdenv, + fetchurl, + makeWrapper, + expat, + fftwFloat, + fontconfig, + freetype, + libjack2, + jack2, + libclthreads, + libclxclient, + libsndfile, + libxcb, + xorg, }: stdenv.mkDerivation rec { @@ -15,8 +28,20 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; buildInputs = [ - expat libjack2 libclthreads libclxclient fftwFloat fontconfig libsndfile freetype - libxcb xorg.libX11 xorg.libXau xorg.libXdmcp xorg.libXft xorg.libXrender + expat + libjack2 + libclthreads + libclxclient + fftwFloat + fontconfig + libsndfile + freetype + libxcb + xorg.libX11 + xorg.libXau + xorg.libXdmcp + xorg.libXft + xorg.libXrender ]; makeFlags = [ diff --git a/pkgs/by-name/te/tetrd/package.nix b/pkgs/by-name/te/tetrd/package.nix index a9ccf1d2774ff5..29bf0141b5bfde 100644 --- a/pkgs/by-name/te/tetrd/package.nix +++ b/pkgs/by-name/te/tetrd/package.nix @@ -1,23 +1,24 @@ -{ stdenv -, lib -, fetchurl -, autoPatchelfHook -, makeWrapper -, c-ares -, ffmpeg -, libevent -, libvpx -, libxslt -, xorg -, minizip -, nss -, re2 -, snappy -, libnotify -, libappindicator-gtk3 -, libappindicator -, udev -, mesa # required for libgbm +{ + stdenv, + lib, + fetchurl, + autoPatchelfHook, + makeWrapper, + c-ares, + ffmpeg, + libevent, + libvpx, + libxslt, + xorg, + minizip, + nss, + re2, + snappy, + libnotify, + libappindicator-gtk3, + libappindicator, + udev, + mesa, # required for libgbm }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/te/tev/package.nix b/pkgs/by-name/te/tev/package.nix index 3f682ccbb6ee0f..4fe472b6affcf2 100644 --- a/pkgs/by-name/te/tev/package.nix +++ b/pkgs/by-name/te/tev/package.nix @@ -1,6 +1,15 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, wrapGAppsHook3 -, libX11, libzip, glfw, libpng, xorg, zenity +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + wrapGAppsHook3, + libX11, + libzip, + glfw, + libpng, + xorg, + zenity, }: stdenv.mkDerivation rec { @@ -15,9 +24,25 @@ stdenv.mkDerivation rec { hash = "sha256-ke1T5nOrDoJilpfshAIAFWw/640Gm5OaxZ+ZakCevTs="; }; - nativeBuildInputs = [ cmake wrapGAppsHook3 ]; - buildInputs = [ libX11 libzip glfw libpng ] - ++ (with xorg; [ libXrandr libXinerama libXcursor libXi libXxf86vm libXext ]); + nativeBuildInputs = [ + cmake + wrapGAppsHook3 + ]; + buildInputs = + [ + libX11 + libzip + glfw + libpng + ] + ++ (with xorg; [ + libXrandr + libXinerama + libXcursor + libXi + libXxf86vm + libXext + ]); dontWrapGApps = true; # We also need zenity (see below) diff --git a/pkgs/by-name/te/tevent/package.nix b/pkgs/by-name/te/tevent/package.nix index c9f03ee0555f21..ef2a8dd47d3d0c 100644 --- a/pkgs/by-name/te/tevent/package.nix +++ b/pkgs/by-name/te/tevent/package.nix @@ -1,17 +1,19 @@ -{ lib, stdenv -, fetchurl -, python3 -, pkg-config -, cmocka -, readline -, talloc -, libxslt -, docbook-xsl-nons -, docbook_xml_dtd_42 -, which -, wafHook -, buildPackages -, libxcrypt +{ + lib, + stdenv, + fetchurl, + python3, + pkg-config, + cmocka, + readline, + talloc, + libxslt, + docbook-xsl-nons, + docbook_xml_dtd_42, + which, + wafHook, + buildPackages, + libxcrypt, }: stdenv.mkDerivation rec { @@ -50,13 +52,15 @@ stdenv.mkDerivation rec { wafPath = "buildtools/bin/waf"; - wafConfigureFlags = [ - "--bundled-libraries=NONE" - "--builtin-libraries=replace" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "--cross-compile" - "--cross-execute=${stdenv.hostPlatform.emulator buildPackages}" - ]; + wafConfigureFlags = + [ + "--bundled-libraries=NONE" + "--builtin-libraries=replace" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "--cross-compile" + "--cross-execute=${stdenv.hostPlatform.emulator buildPackages}" + ]; # python-config from build Python gives incorrect values when cross-compiling. # If python-config is not found, the build falls back to using the sysconfig diff --git a/pkgs/by-name/te/tewi-font/package.nix b/pkgs/by-name/te/tewi-font/package.nix index d8906a2284dae5..1a526edaf90deb 100644 --- a/pkgs/by-name/te/tewi-font/package.nix +++ b/pkgs/by-name/te/tewi-font/package.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, python3 -, bdftopcf, xorg -, libfaketime, +{ + lib, + stdenv, + fetchFromGitHub, + python3, + bdftopcf, + xorg, + libfaketime, }: stdenv.mkDerivation rec { @@ -8,16 +13,19 @@ stdenv.mkDerivation rec { version = "2.0.2"; src = fetchFromGitHub { - owner = "lucy"; - repo = pname; - rev = version; + owner = "lucy"; + repo = pname; + rev = version; sha256 = "1axv9bv10xlcmgfyjh3z5kn5fkg3m6n1kskcs5hvlmyb6m1zk91j"; }; - nativeBuildInputs = - [ python3 bdftopcf xorg.mkfontscale - libfaketime xorg.fonttosfnt - ]; + nativeBuildInputs = [ + python3 + bdftopcf + xorg.mkfontscale + libfaketime + xorg.fonttosfnt + ]; postPatch = '' # make gzip deterministic diff --git a/pkgs/by-name/te/tewisay/package.nix b/pkgs/by-name/te/tewisay/package.nix index bcf77c2db2cf7e..cf08d8f9c2b821 100644 --- a/pkgs/by-name/te/tewisay/package.nix +++ b/pkgs/by-name/te/tewisay/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, unstableGitUpdater +{ + lib, + buildGoModule, + fetchFromGitHub, + unstableGitUpdater, }: buildGoModule rec { diff --git a/pkgs/by-name/te/texi2html/package.nix b/pkgs/by-name/te/texi2html/package.nix index 66609d8d17e18b..5d3a09642116cd 100644 --- a/pkgs/by-name/te/texi2html/package.nix +++ b/pkgs/by-name/te/texi2html/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, perl, gettext, buildPackages }: +{ + lib, + stdenv, + fetchurl, + perl, + gettext, + buildPackages, +}: stdenv.mkDerivation rec { pname = "texi2html"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ gettext perl ]; + nativeBuildInputs = [ + gettext + perl + ]; buildInputs = [ perl ]; postPatch = '' diff --git a/pkgs/by-name/te/texi2mdoc/package.nix b/pkgs/by-name/te/texi2mdoc/package.nix index ed9617b0f3433d..ba806fede6a443 100644 --- a/pkgs/by-name/te/texi2mdoc/package.nix +++ b/pkgs/by-name/te/texi2mdoc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "texi2mdoc"; diff --git a/pkgs/by-name/te/text-engine/package.nix b/pkgs/by-name/te/text-engine/package.nix index 120076a7e0d783..434cdbb7832690 100644 --- a/pkgs/by-name/te/text-engine/package.nix +++ b/pkgs/by-name/te/text-engine/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, meson -, ninja -, json-glib -, gtk4 -, libxml2 -, gobject-introspection -, pkg-config -, libadwaita +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + meson, + ninja, + json-glib, + gtk4, + libxml2, + gobject-introspection, + pkg-config, + libadwaita, }: stdenv.mkDerivation rec { @@ -30,15 +31,28 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ gobject-introspection gtk4 meson ninja pkg-config ]; + nativeBuildInputs = [ + gobject-introspection + gtk4 + meson + ninja + pkg-config + ]; - buildInputs = [ libadwaita json-glib libxml2 ]; + buildInputs = [ + libadwaita + json-glib + libxml2 + ]; meta = with lib; { description = "Rich text framework for GTK"; mainProgram = "text-engine-demo"; homepage = "https://github.com/mjakeman/text-engine"; - license = with licenses; [ mpl20 lgpl21Plus ]; + license = with licenses; [ + mpl20 + lgpl21Plus + ]; maintainers = with maintainers; [ foo-dogsquared ]; }; } diff --git a/pkgs/by-name/te/textplots/package.nix b/pkgs/by-name/te/textplots/package.nix index 79787ec7e7d240..add6164cddd14c 100644 --- a/pkgs/by-name/te/textplots/package.nix +++ b/pkgs/by-name/te/textplots/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "textplots"; diff --git a/pkgs/by-name/te/textql/package.nix b/pkgs/by-name/te/textql/package.nix index 182427c4b31768..5fd051922ed724 100644 --- a/pkgs/by-name/te/textql/package.nix +++ b/pkgs/by-name/te/textql/package.nix @@ -1,14 +1,20 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch, sqlite }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + sqlite, +}: buildGoModule rec { pname = "textql"; version = "unstable-2021-07-06"; src = fetchFromGitHub { - owner = "dinedal"; - repo = "textql"; - rev = "fca00ecc76c8d9891b195ad2c1359d39f0213604"; - hash = "sha256-NccRo5YdhwTo2eez5UE5nI3TEqzTL1rjPO1kKfDBNuw="; + owner = "dinedal"; + repo = "textql"; + rev = "fca00ecc76c8d9891b195ad2c1359d39f0213604"; + hash = "sha256-NccRo5YdhwTo2eez5UE5nI3TEqzTL1rjPO1kKfDBNuw="; }; patches = [ diff --git a/pkgs/by-name/te/textsnatcher/package.nix b/pkgs/by-name/te/textsnatcher/package.nix index 670c87faeba534..50f9670d641d92 100644 --- a/pkgs/by-name/te/textsnatcher/package.nix +++ b/pkgs/by-name/te/textsnatcher/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, vala -, wrapGAppsHook3 -, pkg-config -, pantheon -, libhandy -, libportal -, glib -, gtk3 -, desktop-file-utils -, scrot -, tesseract +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + vala, + wrapGAppsHook3, + pkg-config, + pantheon, + libhandy, + libportal, + glib, + gtk3, + desktop-file-utils, + scrot, + tesseract, }: stdenv.mkDerivation (finalAttrs: { @@ -46,7 +47,12 @@ stdenv.mkDerivation (finalAttrs: { preFixup = '' gappsWrapperArgs+=( - --prefix PATH : ${lib.makeBinPath [ scrot tesseract ]} + --prefix PATH : ${ + lib.makeBinPath [ + scrot + tesseract + ] + } ) ''; diff --git a/pkgs/by-name/te/textual-paint/package.nix b/pkgs/by-name/te/textual-paint/package.nix index c59ac7b8140e5d..a512c4e173b713 100644 --- a/pkgs/by-name/te/textual-paint/package.nix +++ b/pkgs/by-name/te/textual-paint/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3 -, fetchFromGitHub -, fetchPypi -, fetchpatch +{ + lib, + python3, + fetchFromGitHub, + fetchPypi, + fetchpatch, }: let diff --git a/pkgs/by-name/te/texture-synthesis/package.nix b/pkgs/by-name/te/texture-synthesis/package.nix index cd7d437c4d416a..d7ff4b6e401bfd 100644 --- a/pkgs/by-name/te/texture-synthesis/package.nix +++ b/pkgs/by-name/te/texture-synthesis/package.nix @@ -1,4 +1,9 @@ -{ lib, rustPlatform, fetchFromGitHub, stdenv }: +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, +}: rustPlatform.buildRustPackage rec { pname = "texture-synthesis"; @@ -24,7 +29,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Example-based texture synthesis written in Rust"; homepage = "https://github.com/embarkstudios/texture-synthesis"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "texture-synthesis"; }; diff --git a/pkgs/by-name/te/tezos-rust-libs/package.nix b/pkgs/by-name/te/tezos-rust-libs/package.nix index 36923aa8026ec9..2bbed03999a388 100644 --- a/pkgs/by-name/te/tezos-rust-libs/package.nix +++ b/pkgs/by-name/te/tezos-rust-libs/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitLab, stdenv, llvmPackages_12, cargo, libiconv }: +{ + lib, + fetchFromGitLab, + stdenv, + llvmPackages_12, + cargo, + libiconv, +}: stdenv.mkDerivation rec { version = "1.5"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-SuCqDZDXmWdGI/GN+3nYcUk66jnW5FQQaeTB76/rvaw="; }; - nativeBuildInputs = [ llvmPackages_12.llvm cargo ]; + nativeBuildInputs = [ + llvmPackages_12.llvm + cargo + ]; propagatedBuildInputs = [ llvmPackages_12.libllvm ]; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; diff --git a/pkgs/by-name/tf/tf-summarize/package.nix b/pkgs/by-name/tf/tf-summarize/package.nix index 16f7ab4946fdde..29da31f6e66b43 100644 --- a/pkgs/by-name/tf/tf-summarize/package.nix +++ b/pkgs/by-name/tf/tf-summarize/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, tf-summarize +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + tf-summarize, }: buildGoModule rec { diff --git a/pkgs/by-name/tf/tf2pulumi/package.nix b/pkgs/by-name/tf/tf2pulumi/package.nix index bc5c92a98f22c8..37b1ac9bfe2e5c 100644 --- a/pkgs/by-name/tf/tf2pulumi/package.nix +++ b/pkgs/by-name/tf/tf2pulumi/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "tf2pulumi"; @@ -14,7 +18,9 @@ buildGoModule rec { vendorHash = "sha256-x7GAkbvhML2VUQ9/zitrTBBiy9lISb3iTx6yn5WbEig="; ldflags = [ - "-s" "-w" "-X=github.com/pulumi/tf2pulumi/version.Version=${src.rev}" + "-s" + "-w" + "-X=github.com/pulumi/tf2pulumi/version.Version=${src.rev}" ]; subPackages = [ "." ]; diff --git a/pkgs/by-name/tf/tfautomv/package.nix b/pkgs/by-name/tf/tfautomv/package.nix index efabad7ed89b0b..97eb4ba2054afd 100644 --- a/pkgs/by-name/tf/tfautomv/package.nix +++ b/pkgs/by-name/tf/tfautomv/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -19,7 +20,10 @@ buildGoModule rec { vendorHash = "sha256-BZ8IhVPxZTPQXBotFBrxV3dfwvst0te8R84I/urq3gY="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/busser/tfautomv"; diff --git a/pkgs/by-name/tf/tfk8s/package.nix b/pkgs/by-name/tf/tfk8s/package.nix index a0bdefde16202a..bbf820716b88d0 100644 --- a/pkgs/by-name/tf/tfk8s/package.nix +++ b/pkgs/by-name/tf/tfk8s/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, callPackage }: +{ + lib, + buildGoModule, + fetchFromGitHub, + callPackage, +}: buildGoModule rec { pname = "tfk8s"; diff --git a/pkgs/by-name/tf/tfk8s/tests/sample1/default.nix b/pkgs/by-name/tf/tfk8s/tests/sample1/default.nix index 6b06dbf323409c..e5edc22fa6e9fe 100644 --- a/pkgs/by-name/tf/tfk8s/tests/sample1/default.nix +++ b/pkgs/by-name/tf/tfk8s/tests/sample1/default.nix @@ -1,6 +1,7 @@ { runCommandCC, tfk8s }: -runCommandCC "tfk8s-test-sample1" { +runCommandCC "tfk8s-test-sample1" + { buildInputs = [ tfk8s ]; diff --git a/pkgs/by-name/tf/tfswitch/package.nix b/pkgs/by-name/tf/tfswitch/package.nix index bb22343091547d..5622d2c5b0d741 100644 --- a/pkgs/by-name/tf/tfswitch/package.nix +++ b/pkgs/by-name/tf/tfswitch/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, lib, fetchFromGitHub }: +{ + buildGoModule, + lib, + fetchFromGitHub, +}: buildGoModule rec { pname = "tfswitch"; version = "1.2.4"; @@ -22,8 +26,7 @@ buildGoModule rec { ''; meta = with lib; { - description = - "A command line tool to switch between different versions of terraform"; + description = "A command line tool to switch between different versions of terraform"; mainProgram = "tfswitch"; homepage = "https://github.com/warrensbox/terraform-switcher"; license = licenses.mit; diff --git a/pkgs/by-name/tf/tftp-hpa/package.nix b/pkgs/by-name/tf/tftp-hpa/package.nix index 15fd0473532709..f9946be7423adb 100644 --- a/pkgs/by-name/tf/tftp-hpa/package.nix +++ b/pkgs/by-name/tf/tftp-hpa/package.nix @@ -1,8 +1,12 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "tftp-hpa"; - version="5.2"; + version = "5.2"; src = fetchurl { url = "mirror://kernel/software/network/tftp/tftp-hpa/${pname}-${version}.tar.xz"; sha256 = "12vidchglhyc20znq5wdsbhi9mqg90jnl7qr9qs8hbvaz4fkdvmg"; diff --git a/pkgs/by-name/tf/tfupdate/package.nix b/pkgs/by-name/tf/tfupdate/package.nix index e28cf36926149a..098510b344fe25 100644 --- a/pkgs/by-name/tf/tfupdate/package.nix +++ b/pkgs/by-name/tf/tfupdate/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "tfupdate"; @@ -23,6 +27,9 @@ buildGoModule rec { homepage = "https://github.com/minamijoyo/tfupdate"; changelog = "https://github.com/minamijoyo/tfupdate/blob/${src.rev}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ Intuinewin qjoly ]; + maintainers = with maintainers; [ + Intuinewin + qjoly + ]; }; } diff --git a/pkgs/by-name/tg/tg-archive/package.nix b/pkgs/by-name/tg/tg-archive/package.nix index 4465fa35cbc75f..0460e34108f34e 100644 --- a/pkgs/by-name/tg/tg-archive/package.nix +++ b/pkgs/by-name/tg/tg-archive/package.nix @@ -1,13 +1,15 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: let pname = "tg-archive"; version = "1.1.3"; -in python3.pkgs.buildPythonApplication { +in +python3.pkgs.buildPythonApplication { inherit pname version; src = fetchFromGitHub { diff --git a/pkgs/by-name/tg/tgpt/package.nix b/pkgs/by-name/tg/tgpt/package.nix index 9c0e87a0562f10..59ac6f59c12b09 100644 --- a/pkgs/by-name/tg/tgpt/package.nix +++ b/pkgs/by-name/tg/tgpt/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/tg/tgswitch/package.nix b/pkgs/by-name/tg/tgswitch/package.nix index 6196eeeac8edaf..bfa533b26815d6 100644 --- a/pkgs/by-name/tg/tgswitch/package.nix +++ b/pkgs/by-name/tg/tgswitch/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, lib, fetchFromGitHub }: +{ + buildGoModule, + lib, + fetchFromGitHub, +}: buildGoModule rec { pname = "tgswitch"; version = "0.6.0"; @@ -12,7 +16,10 @@ buildGoModule rec { vendorHash = "sha256-PlTdbA8Z2I2SWoG7oYG87VQfczx9zP1SCJx70UWOEog="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; # There are many modifications need to be done to make tests run. For example: # 1. Network access @@ -27,4 +34,3 @@ buildGoModule rec { maintainers = with maintainers; [ psibi ]; }; } - diff --git a/pkgs/by-name/tg/tgt/package.nix b/pkgs/by-name/tg/tgt/package.nix index 1fcec8922048c3..52c0ebc3324ba3 100644 --- a/pkgs/by-name/tg/tgt/package.nix +++ b/pkgs/by-name/tg/tgt/package.nix @@ -1,5 +1,16 @@ -{ stdenv, lib, fetchFromGitHub, libxslt, libaio, systemd, perl -, docbook_xsl, coreutils, lsof, makeWrapper, sg3_utils +{ + stdenv, + lib, + fetchFromGitHub, + libxslt, + libaio, + systemd, + perl, + docbook_xsl, + coreutils, + lsof, + makeWrapper, + sg3_utils, }: stdenv.mkDerivation rec { @@ -13,9 +24,16 @@ stdenv.mkDerivation rec { hash = "sha256-4zPTAdAXO8Km8a50ST3mdHW3RlKD1pmLACeFOY48lv0="; }; - nativeBuildInputs = [ libxslt docbook_xsl makeWrapper ]; + nativeBuildInputs = [ + libxslt + docbook_xsl + makeWrapper + ]; - buildInputs = [ systemd libaio ]; + buildInputs = [ + systemd + libaio + ]; makeFlags = [ "PREFIX=${placeholder "out"}" @@ -47,7 +65,11 @@ stdenv.mkDerivation rec { substituteInPlace $out/sbin/tgt-admin \ --replace "#!/usr/bin/perl" "#! ${perl.withPackages (p: [ p.ConfigGeneral ])}/bin/perl" wrapProgram $out/sbin/tgt-admin --prefix PATH : \ - ${lib.makeBinPath [ lsof sg3_utils (placeholder "out") ]} + ${lib.makeBinPath [ + lsof + sg3_utils + (placeholder "out") + ]} install -D scripts/tgtd.service $out/etc/systemd/system/tgtd.service substituteInPlace $out/etc/systemd/system/tgtd.service \ diff --git a/pkgs/by-name/th/thc-hydra/package.nix b/pkgs/by-name/th/thc-hydra/package.nix index 412691d2b9403a..57d059e0b75c7c 100644 --- a/pkgs/by-name/th/thc-hydra/package.nix +++ b/pkgs/by-name/th/thc-hydra/package.nix @@ -1,5 +1,21 @@ -{ stdenv, lib, fetchFromGitHub, zlib, openssl, ncurses, libidn, pcre, libssh, libmysqlclient, postgresql, samba -, withGUI ? false, makeWrapper, pkg-config, gtk2 }: +{ + stdenv, + lib, + fetchFromGitHub, + zlib, + openssl, + ncurses, + libidn, + pcre, + libssh, + libmysqlclient, + postgresql, + samba, + withGUI ? false, + makeWrapper, + pkg-config, + gtk2, +}: stdenv.mkDerivation rec { pname = "thc-hydra"; @@ -12,23 +28,37 @@ stdenv.mkDerivation rec { sha256 = "sha256-gdMxdFrBGVHA1ZBNFW89PBXwACnXTGJ/e/Z5+xVV5F0="; }; - postPatch = let - makeDirs = output: subDir: lib.concatStringsSep " " (map (path: lib.getOutput output path + "/" + subDir) buildInputs); - in '' - substituteInPlace configure \ - --replace-fail '$LIBDIRS' "${makeDirs "lib" "lib"}" \ - --replace-fail '$INCDIRS' "${makeDirs "dev" "include"}" \ - --replace-fail "/usr/include/math.h" "${lib.getDev stdenv.cc.libc}/include/math.h" \ - --replace-fail "libcurses.so" "libncurses.so" \ - --replace-fail "-lcurses" "-lncurses" - ''; + postPatch = + let + makeDirs = + output: subDir: + lib.concatStringsSep " " (map (path: lib.getOutput output path + "/" + subDir) buildInputs); + in + '' + substituteInPlace configure \ + --replace-fail '$LIBDIRS' "${makeDirs "lib" "lib"}" \ + --replace-fail '$INCDIRS' "${makeDirs "dev" "include"}" \ + --replace-fail "/usr/include/math.h" "${lib.getDev stdenv.cc.libc}/include/math.h" \ + --replace-fail "libcurses.so" "libncurses.so" \ + --replace-fail "-lcurses" "-lncurses" + ''; env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-Wno-undef-prefix"; - nativeBuildInputs = lib.optionals withGUI [ pkg-config makeWrapper ]; + nativeBuildInputs = lib.optionals withGUI [ + pkg-config + makeWrapper + ]; buildInputs = [ - zlib openssl ncurses libidn pcre libssh libmysqlclient postgresql + zlib + openssl + ncurses + libidn + pcre + libssh + libmysqlclient + postgresql samba ] ++ lib.optional withGUI gtk2; diff --git a/pkgs/by-name/th/thc-ipv6/package.nix b/pkgs/by-name/th/thc-ipv6/package.nix index 6e7f4fb2891aad..c28e42efb7646d 100644 --- a/pkgs/by-name/th/thc-ipv6/package.nix +++ b/pkgs/by-name/th/thc-ipv6/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libpcap, openssl, libnetfilter_queue, libnfnetlink }: +{ + lib, + stdenv, + fetchFromGitHub, + libpcap, + openssl, + libnetfilter_queue, + libnfnetlink, +}: stdenv.mkDerivation rec { pname = "thc-ipv6"; version = "3.8"; diff --git a/pkgs/by-name/th/thc-secure-delete/package.nix b/pkgs/by-name/th/thc-secure-delete/package.nix index 03539ffcb488ef..b8555efe3b5125 100644 --- a/pkgs/by-name/th/thc-secure-delete/package.nix +++ b/pkgs/by-name/th/thc-secure-delete/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { @@ -16,7 +17,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-hvWuxFkzhOSCplPtyjRtn36bIk6KdPBcpr3lAmiAyfE="; }; - nativeBuildInputs = [ pkg-config installShellFiles ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" diff --git a/pkgs/by-name/th/thcrap-steam-proton-wrapper/package.nix b/pkgs/by-name/th/thcrap-steam-proton-wrapper/package.nix index e8f670f97ad067..ff1aa917abae12 100644 --- a/pkgs/by-name/th/thcrap-steam-proton-wrapper/package.nix +++ b/pkgs/by-name/th/thcrap-steam-proton-wrapper/package.nix @@ -1,11 +1,11 @@ { - lib - , stdenv - , fetchFromGitHub - , makeWrapper - , bash - , subversion - , zenity + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + bash, + subversion, + zenity, }: stdenv.mkDerivation { pname = "thcrap-proton"; diff --git a/pkgs/by-name/th/the-legend-of-edgar/package.nix b/pkgs/by-name/th/the-legend-of-edgar/package.nix index 5ab2fd0858a67e..a068cc6ea1fde3 100644 --- a/pkgs/by-name/th/the-legend-of-edgar/package.nix +++ b/pkgs/by-name/th/the-legend-of-edgar/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL2 -, SDL2_image -, SDL2_mixer -, SDL2_ttf -, gettext -, libpng -, pkg-config -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + SDL2_image, + SDL2_mixer, + SDL2_ttf, + gettext, + libpng, + pkg-config, + zlib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/th/the-neue-black/package.nix b/pkgs/by-name/th/the-neue-black/package.nix index 3288925464fe34..3b1bfb589d45ab 100644 --- a/pkgs/by-name/th/the-neue-black/package.nix +++ b/pkgs/by-name/th/the-neue-black/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchzip, stdenvNoCC }: +{ + lib, + fetchzip, + stdenvNoCC, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "the-neue-black"; diff --git a/pkgs/by-name/th/the-way/package.nix b/pkgs/by-name/th/the-way/package.nix index 2101512886fc3c..e0c590296e356c 100644 --- a/pkgs/by-name/th/the-way/package.nix +++ b/pkgs/by-name/th/the-way/package.nix @@ -1,4 +1,11 @@ -{ lib, rustPlatform, fetchCrate, installShellFiles, stdenv, darwin }: +{ + lib, + rustPlatform, + fetchCrate, + installShellFiles, + stdenv, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "the-way"; @@ -33,6 +40,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/out-of-cheese-error/the-way"; changelog = "https://github.com/out-of-cheese-error/the-way/blob/v${version}/CHANGELOG.md"; license = with licenses; [ mit ]; - maintainers = with maintainers; [ figsoda numkem ]; + maintainers = with maintainers; [ + figsoda + numkem + ]; }; } diff --git a/pkgs/by-name/th/theano/package.nix b/pkgs/by-name/th/theano/package.nix index 08f7c805eda4a0..f3050f15c26061 100644 --- a/pkgs/by-name/th/theano/package.nix +++ b/pkgs/by-name/th/theano/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "theano"; @@ -24,7 +28,10 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { homepage = "https://github.com/akryukov/theano"; description = "Old-style font designed from historic samples"; - maintainers = with maintainers; [ raskin rycee ]; + maintainers = with maintainers; [ + raskin + rycee + ]; license = licenses.ofl; platforms = platforms.all; }; diff --git a/pkgs/by-name/th/thedesk/package.nix b/pkgs/by-name/th/thedesk/package.nix index 9a398494c429e3..139bd4993ace4d 100644 --- a/pkgs/by-name/th/thedesk/package.nix +++ b/pkgs/by-name/th/thedesk/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchurl, dpkg, autoPatchelfHook, makeWrapper, electron -, alsa-lib, gtk3, libxshmfence, mesa, nss }: +{ + lib, + stdenv, + fetchurl, + dpkg, + autoPatchelfHook, + makeWrapper, + electron, + alsa-lib, + gtk3, + libxshmfence, + mesa, + nss, +}: stdenv.mkDerivation rec { pname = "thedesk"; @@ -16,7 +28,13 @@ stdenv.mkDerivation rec { makeWrapper ]; - buildInputs = [ alsa-lib gtk3 libxshmfence mesa nss ]; + buildInputs = [ + alsa-lib + gtk3 + libxshmfence + mesa + nss + ]; dontBuild = true; dontConfigure = true; diff --git a/pkgs/by-name/th/theforceengine/package.nix b/pkgs/by-name/th/theforceengine/package.nix index 4b66b253f9e0e4..dc46c63c080087 100644 --- a/pkgs/by-name/th/theforceengine/package.nix +++ b/pkgs/by-name/th/theforceengine/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL2 -, SDL2_image -, rtaudio -, rtmidi -, glew -, alsa-lib -, cmake -, pkg-config -, zenity +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + SDL2_image, + rtaudio, + rtmidi, + glew, + alsa-lib, + cmake, + pkg-config, + zenity, }: let # package depends on SDL2main static library diff --git a/pkgs/by-name/th/theft/package.nix b/pkgs/by-name/th/theft/package.nix index e053814dddd964..97c56847006a61 100644 --- a/pkgs/by-name/th/theft/package.nix +++ b/pkgs/by-name/th/theft/package.nix @@ -1,13 +1,17 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { version = "0.4.5"; pname = "theft"; src = fetchFromGitHub { - owner = "silentbicycle"; - repo = "theft"; - rev = "v${version}"; + owner = "silentbicycle"; + repo = "theft"; + rev = "v${version}"; sha256 = "1n2mkawfl2bpd4pwy3mdzxwlqjjvb5bdrr2x2gldlyqdwbk7qjhd"; }; @@ -29,9 +33,12 @@ stdenv.mkDerivation rec { meta = with lib; { description = "C library for property-based testing"; - homepage = "https://github.com/silentbicycle/theft/"; - platforms = platforms.unix; - license = licenses.isc; - maintainers = with maintainers; [ kquick thoughtpolice ]; + homepage = "https://github.com/silentbicycle/theft/"; + platforms = platforms.unix; + license = licenses.isc; + maintainers = with maintainers; [ + kquick + thoughtpolice + ]; }; } diff --git a/pkgs/by-name/th/theharvester/package.nix b/pkgs/by-name/th/theharvester/package.nix index 180aa0fd2e7666..e5978667fd0eaa 100644 --- a/pkgs/by-name/th/theharvester/package.nix +++ b/pkgs/by-name/th/theharvester/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -52,7 +53,7 @@ python3.pkgs.buildPythonApplication rec { uvloop ]; - nativeCheckInputs = with python3.pkgs; [ + nativeCheckInputs = with python3.pkgs; [ pytest pytest-asyncio ]; @@ -75,7 +76,11 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://github.com/laramies/theHarvester"; changelog = "https://github.com/laramies/theHarvester/releases/tag/${version}"; license = licenses.gpl2Only; - maintainers = with maintainers; [ c0bw3b fab treemo ]; + maintainers = with maintainers; [ + c0bw3b + fab + treemo + ]; mainProgram = "theHarvester"; }; } diff --git a/pkgs/by-name/th/thelounge/package.nix b/pkgs/by-name/th/thelounge/package.nix index b297ba4e253a09..2c0114da11c18a 100644 --- a/pkgs/by-name/th/thelounge/package.nix +++ b/pkgs/by-name/th/thelounge/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, nodejs -, yarn -, fixup-yarn-lock -, python311 -, npmHooks -, cctools -, sqlite -, srcOnly -, buildPackages -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + nodejs, + yarn, + fixup-yarn-lock, + python311, + npmHooks, + cctools, + sqlite, + srcOnly, + buildPackages, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { @@ -40,7 +41,13 @@ stdenv.mkDerivation (finalAttrs: { # Distutils was deprecated in 3.10, and removed in 3.12. This build needs it. An alternative could be adding # setuptools, but testing with that and 3.12 still fails. - nativeBuildInputs = [ nodejs yarn fixup-yarn-lock python311 npmHooks.npmInstallHook ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools ]; + nativeBuildInputs = [ + nodejs + yarn + fixup-yarn-lock + python311 + npmHooks.npmInstallHook + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools ]; buildInputs = [ sqlite ]; configurePhase = '' @@ -87,7 +94,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Modern, responsive, cross-platform, self-hosted web IRC client"; homepage = "https://thelounge.chat"; changelog = "https://github.com/thelounge/thelounge/releases/tag/v${finalAttrs.version}"; - maintainers = with maintainers; [ winter raitobezarius ]; + maintainers = with maintainers; [ + winter + raitobezarius + ]; license = licenses.mit; inherit (nodejs.meta) platforms; mainProgram = "thelounge"; diff --git a/pkgs/by-name/th/theme-jade1/package.nix b/pkgs/by-name/th/theme-jade1/package.nix index 30857639dd76a4..9486940a6046f0 100644 --- a/pkgs/by-name/th/theme-jade1/package.nix +++ b/pkgs/by-name/th/theme-jade1/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchurl, + gtk-engine-murrine, +}: stdenv.mkDerivation rec { pname = "theme-jade1"; diff --git a/pkgs/by-name/th/theme-obsidian2/package.nix b/pkgs/by-name/th/theme-obsidian2/package.nix index 1d7756e23b0525..25bd7ccbb554ee 100644 --- a/pkgs/by-name/th/theme-obsidian2/package.nix +++ b/pkgs/by-name/th/theme-obsidian2/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, fetchurl -, gtk-engine-murrine -, jdupes -, gitUpdater +{ + lib, + stdenvNoCC, + fetchurl, + gtk-engine-murrine, + jdupes, + gitUpdater, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/th/theme-sh/package.nix b/pkgs/by-name/th/theme-sh/package.nix index e1ebe9b7326672..653bf7b148a600 100644 --- a/pkgs/by-name/th/theme-sh/package.nix +++ b/pkgs/by-name/th/theme-sh/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, coreutils, gawk }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + coreutils, + gawk, +}: stdenv.mkDerivation rec { pname = "theme-sh"; @@ -21,7 +28,12 @@ stdenv.mkDerivation rec { mkdir -p $out/bin install -Dm755 bin/theme.sh $out/bin wrapProgram $out/bin/theme.sh \ - --prefix PATH : ${lib.makeBinPath [ coreutils gawk ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + gawk + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/th/theme-vertex/package.nix b/pkgs/by-name/th/theme-vertex/package.nix index cff886440e3243..7ff73b4cbe8c27 100644 --- a/pkgs/by-name/th/theme-vertex/package.nix +++ b/pkgs/by-name/th/theme-vertex/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + gtk-engine-murrine, +}: stdenv.mkDerivation rec { pname = "theme-vertex"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "0c9mhrs95ahz37djrv176vn41ywvj26ilwmnr1h9171giv6hid98"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; propagatedUserEnvPkgs = [ gtk-engine-murrine ]; diff --git a/pkgs/by-name/th/themechanger/package.nix b/pkgs/by-name/th/themechanger/package.nix index 2f569b4dc90b9b..c62d5a5875ffae 100644 --- a/pkgs/by-name/th/themechanger/package.nix +++ b/pkgs/by-name/th/themechanger/package.nix @@ -1,16 +1,17 @@ -{ lib -, gobject-introspection -, meson -, ninja -, pkg-config -, wrapGAppsHook3 -, desktop-file-utils -, glib -, gtk3 -, python3 -, gsettings-desktop-schemas -, python3Packages -, fetchFromGitHub +{ + lib, + gobject-introspection, + meson, + ninja, + pkg-config, + wrapGAppsHook3, + desktop-file-utils, + glib, + gtk3, + python3, + gsettings-desktop-schemas, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/th/themix-gui/package.nix b/pkgs/by-name/th/themix-gui/package.nix index a70c576cac7564..91bf3f3bf02752 100644 --- a/pkgs/by-name/th/themix-gui/package.nix +++ b/pkgs/by-name/th/themix-gui/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, sassc -, gdk-pixbuf -, glib -, gobject-introspection -, librsvg -, gtk3 -, python3 -, fetchFromGitHub -, wrapGAppsHook3 +{ + lib, + stdenv, + sassc, + gdk-pixbuf, + glib, + gobject-introspection, + librsvg, + gtk3, + python3, + fetchFromGitHub, + wrapGAppsHook3, }: let diff --git a/pkgs/by-name/th/thepeg/package.nix b/pkgs/by-name/th/thepeg/package.nix index d4274b9dbed49a..32d72e288e87e5 100644 --- a/pkgs/by-name/th/thepeg/package.nix +++ b/pkgs/by-name/th/thepeg/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, fetchpatch, autoreconfHook, boost, fastjet, gsl, hepmc3, lhapdf, rivet, zlib }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + boost, + fastjet, + gsl, + hepmc3, + lhapdf, + rivet, + zlib, +}: stdenv.mkDerivation rec { pname = "thepeg"; @@ -19,7 +32,15 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ boost fastjet gsl hepmc3 lhapdf rivet zlib ]; + buildInputs = [ + boost + fastjet + gsl + hepmc3 + lhapdf + rivet + zlib + ]; configureFlags = [ "--with-hepmc=${hepmc3}" diff --git a/pkgs/by-name/th/therion/package.nix b/pkgs/by-name/th/therion/package.nix index 3dd72b9f6829a0..34a51314af2859 100644 --- a/pkgs/by-name/th/therion/package.nix +++ b/pkgs/by-name/th/therion/package.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, perl -, tcl -, tclPackages -, tk -, expat -, python3 -, texliveTeTeX -, survex -, makeWrapper -, fmt -, proj -, wxGTK32 -, vtk -, freetype -, libjpeg -, gettext -, libGL -, libGLU -, sqlite -, libtiff -, curl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + perl, + tcl, + tclPackages, + tk, + expat, + python3, + texliveTeTeX, + survex, + makeWrapper, + fmt, + proj, + wxGTK32, + vtk, + freetype, + libjpeg, + gettext, + libGL, + libGLU, + sqlite, + libtiff, + curl, }: stdenv.mkDerivation rec { @@ -79,7 +80,12 @@ stdenv.mkDerivation rec { fixupPhase = '' runHook preFixup wrapProgram $out/bin/therion \ - --prefix PATH : ${lib.makeBinPath [ survex texliveTeTeX ]} + --prefix PATH : ${ + lib.makeBinPath [ + survex + texliveTeTeX + ] + } wrapProgram $out/bin/xtherion \ --prefix PATH : ${lib.makeBinPath [ tk ]} runHook postFixup diff --git a/pkgs/by-name/th/thermald/package.nix b/pkgs/by-name/th/thermald/package.nix index be44cda075710a..590b813f664415 100644 --- a/pkgs/by-name/th/thermald/package.nix +++ b/pkgs/by-name/th/thermald/package.nix @@ -1,25 +1,30 @@ -{ autoconf -, autoconf-archive -, automake -, dbus -, dbus-glib -, docbook_xml_dtd_412 -, docbook-xsl-nons -, fetchFromGitHub -, gtk-doc -, libevdev -, libtool -, libxml2 -, pkg-config -, lib, stdenv -, upower +{ + autoconf, + autoconf-archive, + automake, + dbus, + dbus-glib, + docbook_xml_dtd_412, + docbook-xsl-nons, + fetchFromGitHub, + gtk-doc, + libevdev, + libtool, + libxml2, + pkg-config, + lib, + stdenv, + upower, }: stdenv.mkDerivation rec { pname = "thermald"; version = "2.5.8"; - outputs = [ "out" "devdoc" ]; + outputs = [ + "out" + "devdoc" + ]; src = fetchFromGitHub { owner = "intel"; @@ -66,7 +71,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/intel/thermal_daemon"; changelog = "https://github.com/intel/thermal_daemon/blob/master/README.txt"; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = with maintainers; [ abbradar ]; mainProgram = "thermald"; }; diff --git a/pkgs/by-name/th/thicket/package.nix b/pkgs/by-name/th/thicket/package.nix index bffad065b15fbf..2388281a9ce881 100644 --- a/pkgs/by-name/th/thicket/package.nix +++ b/pkgs/by-name/th/thicket/package.nix @@ -1,6 +1,7 @@ -{ lib -, crystal -, fetchFromGitHub +{ + lib, + crystal, + fetchFromGitHub, }: crystal.buildCrystalPackage rec { diff --git a/pkgs/by-name/th/thiefmd/package.nix b/pkgs/by-name/th/thiefmd/package.nix index b626ca6fb8a627..45ecb8651d6dfd 100644 --- a/pkgs/by-name/th/thiefmd/package.nix +++ b/pkgs/by-name/th/thiefmd/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, vala -, pkg-config -, wrapGAppsHook3 -, desktop-file-utils -, discount -, glib -, gtk3 -, gtksourceview4 -, gtkspell3 -, json-glib -, libarchive -, libgee -, libhandy -, libsecret -, libxml2 -, link-grammar -, webkitgtk_4_1 +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + vala, + pkg-config, + wrapGAppsHook3, + desktop-file-utils, + discount, + glib, + gtk3, + gtksourceview4, + gtkspell3, + json-glib, + libarchive, + libgee, + libhandy, + libsecret, + libxml2, + link-grammar, + webkitgtk_4_1, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/th/thin-provisioning-tools/package.nix b/pkgs/by-name/th/thin-provisioning-tools/package.nix index a386a46c40f159..10850fdeeb681b 100644 --- a/pkgs/by-name/th/thin-provisioning-tools/package.nix +++ b/pkgs/by-name/th/thin-provisioning-tools/package.nix @@ -1,7 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, nixosTests }: +{ + lib, + rustPlatform, + fetchFromGitHub, + nixosTests, +}: rustPlatform.buildRustPackage rec { pname = "thin-provisioning-tools"; diff --git a/pkgs/by-name/th/thinkfan/package.nix b/pkgs/by-name/th/thinkfan/package.nix index 60f268caca2a50..6d7360a69f3069 100644 --- a/pkgs/by-name/th/thinkfan/package.nix +++ b/pkgs/by-name/th/thinkfan/package.nix @@ -1,12 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, yaml-cpp -, pkg-config -, procps -, coreutils -, smartSupport ? false, libatasmart +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + yaml-cpp, + pkg-config, + procps, + coreutils, + smartSupport ? false, + libatasmart, }: stdenv.mkDerivation rec { @@ -40,7 +42,10 @@ stdenv.mkDerivation rec { "-DSYSTEMD_FOUND=ON" ] ++ lib.optional smartSupport "-DUSE_ATASMART=ON"; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ yaml-cpp ] ++ lib.optional smartSupport libatasmart; @@ -53,7 +58,10 @@ stdenv.mkDerivation rec { ''; license = lib.licenses.gpl3Plus; homepage = "https://github.com/vmatare/thinkfan"; - maintainers = with lib.maintainers; [ domenkozar rnhmjoj ]; + maintainers = with lib.maintainers; [ + domenkozar + rnhmjoj + ]; platforms = lib.platforms.linux; mainProgram = "thinkfan"; }; diff --git a/pkgs/by-name/th/thinkingRock/package.nix b/pkgs/by-name/th/thinkingRock/package.nix index 2c31d2b5725d77..608e59c20f784a 100644 --- a/pkgs/by-name/th/thinkingRock/package.nix +++ b/pkgs/by-name/th/thinkingRock/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, runtimeShell }: +{ + lib, + stdenv, + fetchurl, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "thinkingrock-binary"; @@ -9,12 +14,13 @@ stdenv.mkDerivation rec { sha256 = "0hnwvvyc8miiz8w2g4iy7s4rgfy0kfbncgbgfzpsq6nrzq334kgm"; }; - /* it would be a really bad idea to put thinkingrock tr executable in PATH! - the tr.sh script does use the coreutils tr itself - That's why I've renamed the wrapper and called it thinkingrock - However you may not rename the bin/tr script cause it will notice and throw an - "java.lang.IllegalArgumentException: Malformed branding token: thinkingrock" - exception. I hope that's fine + /* + it would be a really bad idea to put thinkingrock tr executable in PATH! + the tr.sh script does use the coreutils tr itself + That's why I've renamed the wrapper and called it thinkingrock + However you may not rename the bin/tr script cause it will notice and throw an + "java.lang.IllegalArgumentException: Malformed branding token: thinkingrock" + exception. I hope that's fine */ buildPhase = '' diff --git a/pkgs/by-name/th/thokr/package.nix b/pkgs/by-name/th/thokr/package.nix index a0045ffb51529a..584446db00f823 100644 --- a/pkgs/by-name/th/thokr/package.nix +++ b/pkgs/by-name/th/thokr/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "thokr"; diff --git a/pkgs/by-name/th/threatest/package.nix b/pkgs/by-name/th/threatest/package.nix index 88427627938bc4..59f1d45d19c2b5 100644 --- a/pkgs/by-name/th/threatest/package.nix +++ b/pkgs/by-name/th/threatest/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/th/threema-desktop/package.nix b/pkgs/by-name/th/threema-desktop/package.nix index 25878085a30f25..8125a18a2ae752 100644 --- a/pkgs/by-name/th/threema-desktop/package.nix +++ b/pkgs/by-name/th/threema-desktop/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, makeDesktopItem -, copyDesktopItems -, makeWrapper -, electron -, python3 +{ + lib, + buildNpmPackage, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + makeWrapper, + electron, + python3, }: let diff --git a/pkgs/by-name/th/thrift/package.nix b/pkgs/by-name/th/thrift/package.nix index 589f03c68858e9..b659a3b8eb0acd 100644 --- a/pkgs/by-name/th/thrift/package.nix +++ b/pkgs/by-name/th/thrift/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, boost -, zlib -, libevent -, openssl -, python3 -, cmake -, pkg-config -, bison -, flex -, static ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchurl, + fetchpatch, + boost, + zlib, + libevent, + openssl, + python3, + cmake, + pkg-config, + bison, + flex, + static ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { @@ -25,7 +26,7 @@ stdenv.mkDerivation rec { # Workaround to make the Python wrapper not drop this package: # pythonFull.buildEnv.override { extraLibs = [ thrift ]; } - pythonPath = []; + pythonPath = [ ]; nativeBuildInputs = [ bison @@ -36,11 +37,13 @@ stdenv.mkDerivation rec { python3.pkgs.setuptools ]; - buildInputs = [ - boost - ] ++ lib.optionals (!static) [ - (python3.withPackages (ps: [ps.twisted])) - ]; + buildInputs = + [ + boost + ] + ++ lib.optionals (!static) [ + (python3.withPackages (ps: [ ps.twisted ])) + ]; propagatedBuildInputs = [ libevent @@ -88,41 +91,45 @@ stdenv.mkDerivation rec { }) ]; - cmakeFlags = [ - "-DBUILD_JAVASCRIPT:BOOL=OFF" - "-DBUILD_NODEJS:BOOL=OFF" - - # FIXME: Fails to link in static mode with undefined reference to - # `boost::unit_test::unit_test_main(bool (*)(), int, char**)' - "-DBUILD_TESTING:BOOL=${if static then "OFF" else "ON"}" - ] ++ lib.optionals static [ - "-DWITH_STATIC_LIB:BOOL=ON" - "-DOPENSSL_USE_STATIC_LIBS=ON" - ]; - - disabledTests = [ - "PythonTestSSLSocket" - "PythonThriftTNonblockingServer" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # Tests that hang up in the Darwin sandbox - "SecurityTest" - "SecurityFromBufferTest" - "python_test" - - # fails on hydra, passes locally - "concurrency_test" - - # Tests that fail in the Darwin sandbox when trying to use network - "UnitTests" - "TInterruptTest" - "TServerIntegrationTest" - "processor" - "TNonblockingServerTest" - "TNonblockingSSLServerTest" - "StressTest" - "StressTestConcurrent" - "StressTestNonBlocking" - ]; + cmakeFlags = + [ + "-DBUILD_JAVASCRIPT:BOOL=OFF" + "-DBUILD_NODEJS:BOOL=OFF" + + # FIXME: Fails to link in static mode with undefined reference to + # `boost::unit_test::unit_test_main(bool (*)(), int, char**)' + "-DBUILD_TESTING:BOOL=${if static then "OFF" else "ON"}" + ] + ++ lib.optionals static [ + "-DWITH_STATIC_LIB:BOOL=ON" + "-DOPENSSL_USE_STATIC_LIBS=ON" + ]; + + disabledTests = + [ + "PythonTestSSLSocket" + "PythonThriftTNonblockingServer" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # Tests that hang up in the Darwin sandbox + "SecurityTest" + "SecurityFromBufferTest" + "python_test" + + # fails on hydra, passes locally + "concurrency_test" + + # Tests that fail in the Darwin sandbox when trying to use network + "UnitTests" + "TInterruptTest" + "TServerIntegrationTest" + "processor" + "TNonblockingServerTest" + "TNonblockingSSLServerTest" + "StressTest" + "StressTestConcurrent" + "StressTestNonBlocking" + ]; doCheck = !static; diff --git a/pkgs/by-name/th/thttpd/package.nix b/pkgs/by-name/th/thttpd/package.nix index c7a92bbf5f1ca6..66ccfe04bad89b 100644 --- a/pkgs/by-name/th/thttpd/package.nix +++ b/pkgs/by-name/th/thttpd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libxcrypt }: +{ + lib, + stdenv, + fetchurl, + libxcrypt, +}: stdenv.mkDerivation rec { pname = "thttpd"; diff --git a/pkgs/by-name/th/thud/package.nix b/pkgs/by-name/th/thud/package.nix index 5a4d3f68b2a584..6e867d7ce43cbf 100644 --- a/pkgs/by-name/th/thud/package.nix +++ b/pkgs/by-name/th/thud/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, nix-update-script +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + nix-update-script, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/th/thumbs/package.nix b/pkgs/by-name/th/thumbs/package.nix index b4c795bc8cf816..1f8583b81d746e 100644 --- a/pkgs/by-name/th/thumbs/package.nix +++ b/pkgs/by-name/th/thumbs/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "thumbs"; diff --git a/pkgs/by-name/th/thunderbolt/package.nix b/pkgs/by-name/th/thunderbolt/package.nix index e532f9965aa885..9ed40b0d474165 100644 --- a/pkgs/by-name/th/thunderbolt/package.nix +++ b/pkgs/by-name/th/thunderbolt/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, boost -, cmake -, fetchFromGitHub -, pkg-config -, txt2tags +{ + lib, + stdenv, + boost, + cmake, + fetchFromGitHub, + pkg-config, + txt2tags, }: stdenv.mkDerivation rec { @@ -16,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "02w1bfm7xvq0dzkhwqiq0camkzz9kvciyhnsis61c8vzp39cwx0x"; }; - nativeBuildInputs = [ cmake pkg-config txt2tags ]; + nativeBuildInputs = [ + cmake + pkg-config + txt2tags + ]; buildInputs = [ boost ]; cmakeFlags = [ diff --git a/pkgs/by-name/ti/tibetan-machine/package.nix b/pkgs/by-name/ti/tibetan-machine/package.nix index 4731bfcd365d70..c95dd5d670a5d6 100644 --- a/pkgs/by-name/ti/tibetan-machine/package.nix +++ b/pkgs/by-name/ti/tibetan-machine/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "tibetan-machine"; diff --git a/pkgs/by-name/ti/tic-80/package.nix b/pkgs/by-name/ti/tic-80/package.nix index 28839ec7716a2c..a769a50afd15b4 100644 --- a/pkgs/by-name/ti/tic-80/package.nix +++ b/pkgs/by-name/ti/tic-80/package.nix @@ -1,35 +1,36 @@ -{ lib -, stdenv -, cmake -, pkg-config -, python3 -, rake -, curl -, fetchFromGitHub -, libGL -, libGLU -, alsa-lib -, libX11 -, libICE -, libXi -, libXScrnSaver -, libXcursor -, libXinerama -, libXext -, libXxf86vm -, libXrandr -, libxkbcommon -, wayland -, wayland-protocols -, wayland-scanner -, dbus -, udev -, libdecor -, pipewire -, libpulseaudio -# Whether to build TIC-80's "Pro" version, which is an incentive to support the project financially, -# that enables some additional features. It is, however, fully open source. -, withPro ? false +{ + lib, + stdenv, + cmake, + pkg-config, + python3, + rake, + curl, + fetchFromGitHub, + libGL, + libGLU, + alsa-lib, + libX11, + libICE, + libXi, + libXScrnSaver, + libXcursor, + libXinerama, + libXext, + libXxf86vm, + libXrandr, + libxkbcommon, + wayland, + wayland-protocols, + wayland-scanner, + dbus, + udev, + libdecor, + pipewire, + libpulseaudio, + # Whether to build TIC-80's "Pro" version, which is an incentive to support the project financially, + # that enables some additional features. It is, however, fully open source. + withPro ? false, }: let major = "1"; @@ -129,8 +130,7 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = - "A free and open source fantasy computer for making, playing and sharing tiny games"; + description = "A free and open source fantasy computer for making, playing and sharing tiny games"; longDescription = '' TIC-80 is a free and open source fantasy computer for making, playing and sharing tiny games. diff --git a/pkgs/by-name/ti/ticker/package.nix b/pkgs/by-name/ti/ticker/package.nix index 0972c3a05394f9..823f3b13022e33 100644 --- a/pkgs/by-name/ti/ticker/package.nix +++ b/pkgs/by-name/ti/ticker/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -30,7 +31,10 @@ buildGoModule rec { homepage = "https://github.com/achannarasappa/ticker"; changelog = "https://github.com/achannarasappa/ticker/releases/tag/v${version}"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ siraben sarcasticadmin ]; + maintainers = with maintainers; [ + siraben + sarcasticadmin + ]; mainProgram = "ticker"; }; } diff --git a/pkgs/by-name/ti/tickrs/package.nix b/pkgs/by-name/ti/tickrs/package.nix index 4e789f2f8ec7ab..b5f0b3eadf0986 100644 --- a/pkgs/by-name/ti/tickrs/package.nix +++ b/pkgs/by-name/ti/tickrs/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, zlib -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + zlib, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -25,12 +26,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; env = { OPENSSL_NO_VENDOR = true; diff --git a/pkgs/by-name/ti/ticktick/package.nix b/pkgs/by-name/ti/ticktick/package.nix index 6c6797374c5924..718954850104e4 100644 --- a/pkgs/by-name/ti/ticktick/package.nix +++ b/pkgs/by-name/ti/ticktick/package.nix @@ -1,17 +1,18 @@ -{ lib -, fetchurl -, stdenv -, wrapGAppsHook3 -, dpkg -, autoPatchelfHook -, glibc -, gcc-unwrapped -, nss -, libdrm -, mesa -, alsa-lib -, xdg-utils -, systemd +{ + lib, + fetchurl, + stdenv, + wrapGAppsHook3, + dpkg, + autoPatchelfHook, + glibc, + gcc-unwrapped, + nss, + libdrm, + mesa, + alsa-lib, + xdg-utils, + systemd, }: stdenv.mkDerivation (finalAttrs: { pname = "ticktick"; diff --git a/pkgs/by-name/ti/ticpp/package.nix b/pkgs/by-name/ti/ticpp/package.nix index 20de3d7f2b8925..6419d4b977585c 100644 --- a/pkgs/by-name/ti/ticpp/package.nix +++ b/pkgs/by-name/ti/ticpp/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ti/tidb/package.nix b/pkgs/by-name/ti/tidb/package.nix index be1b9d39290ac5..467b03b9636088 100644 --- a/pkgs/by-name/ti/tidb/package.nix +++ b/pkgs/by-name/ti/tidb/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "tidb"; diff --git a/pkgs/by-name/ti/tidgi/package.nix b/pkgs/by-name/ti/tidgi/package.nix index 0717dd8239f444..d3be43a6c325b3 100644 --- a/pkgs/by-name/ti/tidgi/package.nix +++ b/pkgs/by-name/ti/tidgi/package.nix @@ -9,23 +9,20 @@ stdenv.mkDerivation rec { version = "0.9.6"; src = - if stdenv.hostPlatform.isAarch64 - then - fetchurl - { + if stdenv.hostPlatform.isAarch64 then + fetchurl { url = "https://github.com/tiddly-gittly/TidGi-Desktop/releases/download/v${version}/TidGi-darwin-arm64-${version}.zip"; hash = "sha256-1Z9lxZZWrUVQEhBO/Kt2AS/uNs2XfihdL0iGrguPQ5g="; } else - fetchurl - { + fetchurl { url = "https://github.com/tiddly-gittly/TidGi-Desktop/releases/download/v${version}/TidGi-darwin-x64-${version}.zip"; hash = "sha256-5jHW/QrgzsGQfX4LvsRebdOJPzYTvhtC5mczxp2wPI8="; }; dontBuild = true; - nativeBuildInputs = [unzip]; + nativeBuildInputs = [ unzip ]; sourceRoot = "."; @@ -43,8 +40,11 @@ stdenv.mkDerivation rec { description = "Customizable personal knowledge-base and blogging platform with git as backup manager"; homepage = "https://github.com/tiddly-gittly/TidGi-Desktop"; license = lib.licenses.mpl20; - maintainers = with lib.maintainers; [klchen0112]; - platforms = ["aarch64-darwin" "x86_64-darwin"]; - sourceProvenance = with lib.sourceTypes; [binaryNativeCode]; + maintainers = with lib.maintainers; [ klchen0112 ]; + platforms = [ + "aarch64-darwin" + "x86_64-darwin" + ]; + sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; }; } diff --git a/pkgs/by-name/ti/tidy-viewer/package.nix b/pkgs/by-name/ti/tidy-viewer/package.nix index a88960739ae549..2e211df3f50491 100644 --- a/pkgs/by-name/ti/tidy-viewer/package.nix +++ b/pkgs/by-name/ti/tidy-viewer/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "tidy-viewer"; diff --git a/pkgs/by-name/ti/tidyp/package.nix b/pkgs/by-name/ti/tidyp/package.nix index e00eaf632e9732..0bcc6af535abba 100644 --- a/pkgs/by-name/ti/tidyp/package.nix +++ b/pkgs/by-name/ti/tidyp/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "tidyp"; diff --git a/pkgs/by-name/ti/tie/package.nix b/pkgs/by-name/ti/tie/package.nix index 5a50600d47c893..f3a7f06dca1daa 100644 --- a/pkgs/by-name/ti/tie/package.nix +++ b/pkgs/by-name/ti/tie/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "tie"; diff --git a/pkgs/by-name/ti/tig/package.nix b/pkgs/by-name/ti/tig/package.nix index 6c90d24e55bf66..a61389c9b4867e 100644 --- a/pkgs/by-name/ti/tig/package.nix +++ b/pkgs/by-name/ti/tig/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, ncurses, asciidoc, xmlto, docbook_xsl, docbook_xml_dtd_45 -, readline, makeWrapper, git, libiconv, autoreconfHook, findXMLCatalogs, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + asciidoc, + xmlto, + docbook_xsl, + docbook_xml_dtd_45, + readline, + makeWrapper, + git, + libiconv, + autoreconfHook, + findXMLCatalogs, + pkg-config, }: stdenv.mkDerivation rec { @@ -13,16 +27,32 @@ stdenv.mkDerivation rec { sha256 = "sha256-WTrw7WaSqC2fp76fPvfogWTibev0Hg0LW2x4umc3+1Q="; }; - nativeBuildInputs = [ makeWrapper autoreconfHook asciidoc xmlto docbook_xsl docbook_xml_dtd_45 findXMLCatalogs pkg-config ]; + nativeBuildInputs = [ + makeWrapper + autoreconfHook + asciidoc + xmlto + docbook_xsl + docbook_xml_dtd_45 + findXMLCatalogs + pkg-config + ]; - autoreconfFlags = [ "-I" "tools" "-v" ]; + autoreconfFlags = [ + "-I" + "tools" + "-v" + ]; - buildInputs = [ ncurses readline git ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; + buildInputs = [ + ncurses + readline + git + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; # those files are inherently impure, we'll handle the corresponding dependencies. postPatch = '' - rm contrib/config.make-* + rm contrib/config.make-* ''; enableParallelBuilding = true; @@ -49,7 +79,13 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://jonas.github.io/tig/"; description = "Text-mode interface for git"; - maintainers = with maintainers; [ bjornfor domenkozar qknight globin ma27 ]; + maintainers = with maintainers; [ + bjornfor + domenkozar + qknight + globin + ma27 + ]; license = licenses.gpl2Plus; platforms = platforms.unix; mainProgram = "tig"; diff --git a/pkgs/by-name/ti/tigervnc/package.nix b/pkgs/by-name/ti/tigervnc/package.nix index 0e6e1daa66e291..617d901ed5475f 100644 --- a/pkgs/by-name/ti/tigervnc/package.nix +++ b/pkgs/by-name/ti/tigervnc/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, xorg -, xkeyboard_config -, zlib -, libjpeg_turbo -, pixman -, fltk -, cmake -, gettext -, libtool -, libGLU -, gnutls -, gawk -, pam -, nettle -, xterm -, openssh -, perl -, makeWrapper -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + xorg, + xkeyboard_config, + zlib, + libjpeg_turbo, + pixman, + fltk, + cmake, + gettext, + libtool, + libGLU, + gnutls, + gawk, + pam, + nettle, + xterm, + openssh, + perl, + makeWrapper, + nixosTests, }: stdenv.mkDerivation rec { @@ -42,17 +43,19 @@ stdenv.mkDerivation rec { }) ]; - postPatch = lib.optionalString stdenv.hostPlatform.isLinux '' - sed -i -e '/^\$cmd \.= " -pn";/a$cmd .= " -xkbdir ${xkeyboard_config}/etc/X11/xkb";' unix/vncserver/vncserver.in - fontPath= - substituteInPlace vncviewer/vncviewer.cxx \ - --replace '"/usr/bin/ssh' '"${openssh}/bin/ssh' - source_top="$(pwd)" - '' + '' - # On Mac, do not build a .dmg, instead copy the .app to the source dir - gawk -i inplace 'BEGIN { del=0 } /hdiutil/ { del=2 } del<=0 { print } /$VERSION.dmg/ { del -= 1 }' release/makemacapp.in - echo "mv \"\$APPROOT\" \"\$SRCDIR/\"" >> release/makemacapp.in - ''; + postPatch = + lib.optionalString stdenv.hostPlatform.isLinux '' + sed -i -e '/^\$cmd \.= " -pn";/a$cmd .= " -xkbdir ${xkeyboard_config}/etc/X11/xkb";' unix/vncserver/vncserver.in + fontPath= + substituteInPlace vncviewer/vncviewer.cxx \ + --replace '"/usr/bin/ssh' '"${openssh}/bin/ssh' + source_top="$(pwd)" + '' + + '' + # On Mac, do not build a .dmg, instead copy the .app to the source dir + gawk -i inplace 'BEGIN { del=0 } /hdiutil/ { del=2 } del<=0 { print } /$VERSION.dmg/ { del -= 1 }' release/makemacapp.in + echo "mv \"\$APPROOT\" \"\$SRCDIR/\"" >> release/makemacapp.in + ''; dontUseCmakeBuildDir = true; @@ -66,93 +69,118 @@ stdenv.mkDerivation rec { "-Wno-error=array-bounds" ]; - postBuild = lib.optionalString stdenv.hostPlatform.isLinux '' - export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -Wno-error=int-to-pointer-cast -Wno-error=pointer-to-int-cast" - export CXXFLAGS="$CXXFLAGS -fpermissive" - # Build Xvnc - tar xf ${xorg.xorgserver.src} - cp -R xorg*/* unix/xserver - pushd unix/xserver - version=$(echo ${xorg.xorgserver.name} | sed 's/.*-\([0-9]\+\).[0-9]\+.*/\1/g') - patch -p1 < "$source_top/unix/xserver$version.patch" - autoreconf -vfi - ./configure $configureFlags --disable-devel-docs --disable-docs \ - --disable-xorg --disable-xnest --disable-xvfb --disable-dmx \ - --disable-xwin --disable-xephyr --disable-kdrive --with-pic \ - --disable-xorgcfg --disable-xprint --disable-static \ - --enable-composite --disable-xtrap --enable-xcsecurity \ - --disable-{a,c,m}fb \ - --disable-xwayland \ - --disable-config-dbus --disable-config-udev --disable-config-hal \ - --disable-xevie \ - --disable-dri --disable-dri2 --disable-dri3 --enable-glx \ - --enable-install-libxf86config \ - --prefix="$out" --disable-unit-tests \ - --with-xkb-path=${xkeyboard_config}/share/X11/xkb \ - --with-xkb-bin-directory=${xorg.xkbcomp}/bin \ - --with-xkb-output=$out/share/X11/xkb/compiled - make TIGERVNC_SRC=$src TIGERVNC_BUILDDIR=`pwd`/../.. -j$NIX_BUILD_CORES - popd - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - make dmg - ''; + postBuild = + lib.optionalString stdenv.hostPlatform.isLinux '' + export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -Wno-error=int-to-pointer-cast -Wno-error=pointer-to-int-cast" + export CXXFLAGS="$CXXFLAGS -fpermissive" + # Build Xvnc + tar xf ${xorg.xorgserver.src} + cp -R xorg*/* unix/xserver + pushd unix/xserver + version=$(echo ${xorg.xorgserver.name} | sed 's/.*-\([0-9]\+\).[0-9]\+.*/\1/g') + patch -p1 < "$source_top/unix/xserver$version.patch" + autoreconf -vfi + ./configure $configureFlags --disable-devel-docs --disable-docs \ + --disable-xorg --disable-xnest --disable-xvfb --disable-dmx \ + --disable-xwin --disable-xephyr --disable-kdrive --with-pic \ + --disable-xorgcfg --disable-xprint --disable-static \ + --enable-composite --disable-xtrap --enable-xcsecurity \ + --disable-{a,c,m}fb \ + --disable-xwayland \ + --disable-config-dbus --disable-config-udev --disable-config-hal \ + --disable-xevie \ + --disable-dri --disable-dri2 --disable-dri3 --enable-glx \ + --enable-install-libxf86config \ + --prefix="$out" --disable-unit-tests \ + --with-xkb-path=${xkeyboard_config}/share/X11/xkb \ + --with-xkb-bin-directory=${xorg.xkbcomp}/bin \ + --with-xkb-output=$out/share/X11/xkb/compiled + make TIGERVNC_SRC=$src TIGERVNC_BUILDDIR=`pwd`/../.. -j$NIX_BUILD_CORES + popd + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + make dmg + ''; - postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' - pushd unix/xserver/hw/vnc - make TIGERVNC_SRC=$src TIGERVNC_BUILDDIR=`pwd`/../../../.. install - popd - rm -f $out/lib/xorg/protocol.txt + postInstall = + lib.optionalString stdenv.hostPlatform.isLinux '' + pushd unix/xserver/hw/vnc + make TIGERVNC_SRC=$src TIGERVNC_BUILDDIR=`pwd`/../../../.. install + popd + rm -f $out/lib/xorg/protocol.txt - wrapProgram $out/bin/vncserver \ - --prefix PATH : ${lib.makeBinPath (with xorg; [ xterm twm xsetroot xauth ]) } - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/Applications - mv 'TigerVNC Viewer ${version}.app' $out/Applications/ - rm $out/bin/vncviewer - echo "#!/usr/bin/env bash - open $out/Applications/TigerVNC\ Viewer\ ${version}.app --args \$@" >> $out/bin/vncviewer - chmod +x $out/bin/vncviewer - ''; + wrapProgram $out/bin/vncserver \ + --prefix PATH : ${ + lib.makeBinPath ( + with xorg; + [ + xterm + twm + xsetroot + xauth + ] + ) + } + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/Applications + mv 'TigerVNC Viewer ${version}.app' $out/Applications/ + rm $out/bin/vncviewer + echo "#!/usr/bin/env bash + open $out/Applications/TigerVNC\ Viewer\ ${version}.app --args \$@" >> $out/bin/vncviewer + chmod +x $out/bin/vncviewer + ''; - buildInputs = [ - fltk - gnutls - libjpeg_turbo - pixman - gawk - ] ++ lib.optionals stdenv.hostPlatform.isLinux (with xorg; [ - nettle - pam - perl - xorgproto - utilmacros - libXtst - libXext - libX11 - libXext - libICE - libXi - libSM - libXft - libxkbfile - libXfont2 - libpciaccess - libGLU - libXrandr - libXdamage - ] ++ xorg.xorgserver.buildInputs - ); + buildInputs = + [ + fltk + gnutls + libjpeg_turbo + pixman + gawk + ] + ++ lib.optionals stdenv.hostPlatform.isLinux ( + with xorg; + [ + nettle + pam + perl + xorgproto + utilmacros + libXtst + libXext + libX11 + libXext + libICE + libXi + libSM + libXft + libxkbfile + libXfont2 + libpciaccess + libGLU + libXrandr + libXdamage + ] + ++ xorg.xorgserver.buildInputs + ); - nativeBuildInputs = [ - cmake - gettext - ] ++ lib.optionals stdenv.hostPlatform.isLinux (with xorg; [ - fontutil - libtool - makeWrapper - utilmacros - zlib - ] ++ xorg.xorgserver.nativeBuildInputs); + nativeBuildInputs = + [ + cmake + gettext + ] + ++ lib.optionals stdenv.hostPlatform.isLinux ( + with xorg; + [ + fontutil + libtool + makeWrapper + utilmacros + zlib + ] + ++ xorg.xorgserver.nativeBuildInputs + ); propagatedBuildInputs = lib.optional stdenv.hostPlatform.isLinux xorg.xorgserver.propagatedBuildInputs; diff --git a/pkgs/by-name/ti/tijolo/package.nix b/pkgs/by-name/ti/tijolo/package.nix index 49c58a2f90107f..0666c2bed20923 100644 --- a/pkgs/by-name/ti/tijolo/package.nix +++ b/pkgs/by-name/ti/tijolo/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, crystal -, vte-gtk4 -, libgit2 -, gtk4 -, libadwaita -, editorconfig-core-c -, gtksourceview5 -, wrapGAppsHook4 -, gobject-introspection -, desktopToDarwinBundle +{ + stdenv, + lib, + fetchFromGitHub, + crystal, + vte-gtk4, + libgit2, + gtk4, + libadwaita, + editorconfig-core-c, + gtksourceview5, + wrapGAppsHook4, + gobject-introspection, + desktopToDarwinBundle, }: crystal.buildCrystalPackage rec { @@ -37,14 +38,27 @@ crystal.buildCrystalPackage rec { cd ../.. && mkdir bin/ && cp lib/gi-crystal/bin/gi-crystal bin/ ''; - nativeBuildInputs = [ wrapGAppsHook4 gobject-introspection ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; - buildInputs = [ gtk4 libadwaita vte-gtk4 libgit2 gtksourceview5 editorconfig-core-c ]; + nativeBuildInputs = [ + wrapGAppsHook4 + gobject-introspection + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; + buildInputs = [ + gtk4 + libadwaita + vte-gtk4 + libgit2 + gtksourceview5 + editorconfig-core-c + ]; buildTargets = [ "all" ]; doCheck = false; - installTargets = [ "install" "post-install" "install-fonts"]; + installTargets = [ + "install" + "post-install" + "install-fonts" + ]; doInstallCheck = false; meta = with lib; { diff --git a/pkgs/by-name/ti/tilda/package.nix b/pkgs/by-name/ti/tilda/package.nix index 500d9269e0161c..b2b503b9eb5a80 100644 --- a/pkgs/by-name/ti/tilda/package.nix +++ b/pkgs/by-name/ti/tilda/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, expat -, gettext -, gtk3 -, libconfuse -, makeWrapper -, pcre2 -, pkg-config -, vte -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + expat, + gettext, + gtk3, + libconfuse, + makeWrapper, + pcre2, + pkg-config, + vte, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ti/tile38/package.nix b/pkgs/by-name/ti/tile38/package.nix index 66e7704d639025..ba998889c0a34c 100644 --- a/pkgs/by-name/ti/tile38/package.nix +++ b/pkgs/by-name/ti/tile38/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "tile38"; @@ -13,9 +17,16 @@ buildGoModule rec { vendorHash = "sha256-nnamNwowRPWQBKUMg800bFgijv8iHbdh/wUwTfX0NcY="; - subPackages = [ "cmd/tile38-cli" "cmd/tile38-server" ]; + subPackages = [ + "cmd/tile38-cli" + "cmd/tile38-server" + ]; - ldflags = [ "-s" "-w" "-X github.com/tidwall/tile38/core.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/tidwall/tile38/core.Version=${version}" + ]; meta = with lib; { description = "Real-time Geospatial and Geofencing"; diff --git a/pkgs/by-name/ti/tiledb/package.nix b/pkgs/by-name/ti/tiledb/package.nix index 9b834c3a7e586b..89cd19166e228f 100644 --- a/pkgs/by-name/ti/tiledb/package.nix +++ b/pkgs/by-name/ti/tiledb/package.nix @@ -1,32 +1,33 @@ -{ lib -, stdenv -, fetchFromGitHub - -, cmake -, zlib -, lz4 -, bzip2 -, zstd -, spdlog -, tbb -, openssl -, boost -, libpqxx -, clang-tools -, catch2_3 -, python3 -, gtest -, doxygen -, fixDarwinDylibNames -, useAVX2 ? stdenv.hostPlatform.avx2Support +{ + lib, + stdenv, + fetchFromGitHub, + + cmake, + zlib, + lz4, + bzip2, + zstd, + spdlog, + tbb, + openssl, + boost, + libpqxx, + clang-tools, + catch2_3, + python3, + gtest, + doxygen, + fixDarwinDylibNames, + useAVX2 ? stdenv.hostPlatform.avx2Support, }: let # pre-fetch ExternalProject from cmake/Modules/FindMagic_EP.cmake ep-file-windows = fetchFromGitHub { owner = "TileDB-Inc"; - repo = "file-windows"; - rev = "5.38.2.tiledb"; + repo = "file-windows"; + rev = "5.38.2.tiledb"; hash = "sha256-TFn30VCuWZr252VN1T5NNCZe2VEN3xQSomS7XxxKGF8="; fetchSubmodules = true; }; @@ -106,7 +107,10 @@ stdenv.mkDerivation rec { doCheck = true; - installTargets = [ "install-tiledb" "doc" ]; + installTargets = [ + "install-tiledb" + "doc" + ]; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' install_name_tool -add_rpath ${tbb}/lib $out/lib/libtiledb.dylib diff --git a/pkgs/by-name/ti/tilem/package.nix b/pkgs/by-name/ti/tilem/package.nix index 7c98b8d499f1c5..400bcd36923eef 100644 --- a/pkgs/by-name/ti/tilem/package.nix +++ b/pkgs/by-name/ti/tilem/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, fetchurl -, lib -, pkg-config -, glib -, gtk2 -, libticonv -, libtifiles2 -, libticables2 -, libticalcs2 +{ + stdenv, + fetchurl, + lib, + pkg-config, + glib, + gtk2, + libticonv, + libtifiles2, + libticables2, + libticalcs2, }: stdenv.mkDerivation rec { @@ -18,13 +19,23 @@ stdenv.mkDerivation rec { sha256 = "1ba38xzhp3yf21ip3cgql6jzy49jc34sfnjsl4syxyrd81d269zw"; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib gtk2 libticonv libtifiles2 libticables2 libticalcs2 ]; + buildInputs = [ + glib + gtk2 + libticonv + libtifiles2 + libticables2 + libticalcs2 + ]; env.NIX_CFLAGS_COMPILE = toString [ "-lm" ]; meta = with lib; { homepage = "http://lpg.ticalc.org/prj_tilem/"; description = "Emulator and debugger for Texas Instruments Z80-based graphing calculators"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ siraben clevor ]; + maintainers = with maintainers; [ + siraben + clevor + ]; platforms = platforms.linux ++ platforms.darwin; mainProgram = "tilem2"; }; diff --git a/pkgs/by-name/ti/tilemaker/package.nix b/pkgs/by-name/ti/tilemaker/package.nix index 7e7714635c891d..02316a1b9a0c65 100644 --- a/pkgs/by-name/ti/tilemaker/package.nix +++ b/pkgs/by-name/ti/tilemaker/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildPackages -, cmake -, installShellFiles -, boost -, lua -, protobuf_21 -, rapidjson -, shapelib -, sqlite -, zlib -, testers +{ + lib, + stdenv, + fetchFromGitHub, + buildPackages, + cmake, + installShellFiles, + boost, + lua, + protobuf_21, + rapidjson, + shapelib, + sqlite, + zlib, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -33,12 +34,24 @@ stdenv.mkDerivation (finalAttrs: { --replace-fail "default_value(\"static\")" "default_value(\"$out/share/tilemaker/static\")" ''; - nativeBuildInputs = [ cmake installShellFiles ]; + nativeBuildInputs = [ + cmake + installShellFiles + ]; - buildInputs = [ boost lua protobuf_21 rapidjson shapelib sqlite zlib ]; + buildInputs = [ + boost + lua + protobuf_21 + rapidjson + shapelib + sqlite + zlib + ]; - cmakeFlags = lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) - (lib.cmakeFeature "PROTOBUF_PROTOC_EXECUTABLE" "${buildPackages.protobuf}/bin/protoc"); + cmakeFlags = lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) ( + lib.cmakeFeature "PROTOBUF_PROTOC_EXECUTABLE" "${buildPackages.protobuf}/bin/protoc" + ); env.NIX_CFLAGS_COMPILE = toString [ "-DTM_VERSION=${finalAttrs.version}" ]; diff --git a/pkgs/by-name/ti/tilix/package.nix b/pkgs/by-name/ti/tilix/package.nix index 07344d23d87a1f..4ede51c57fcdf7 100644 --- a/pkgs/by-name/ti/tilix/package.nix +++ b/pkgs/by-name/ti/tilix/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, python3 -, pkg-config -, ldc -, dconf -, dbus -, gsettings-desktop-schemas -, desktop-file-utils -, gettext -, gtkd -, libsecret -, wrapGAppsHook3 -, libunwind -, appstream -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + python3, + pkg-config, + ldc, + dconf, + dbus, + gsettings-desktop-schemas, + desktop-file-utils, + gettext, + gtkd, + libsecret, + wrapGAppsHook3, + libunwind, + appstream, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { @@ -67,7 +68,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Tiling terminal emulator following the Gnome Human Interface Guidelines"; homepage = "https://gnunn1.github.io/tilix-web"; license = licenses.mpl20; - maintainers = with maintainers; [ midchildan jtbx ]; + maintainers = with maintainers; [ + midchildan + jtbx + ]; platforms = platforms.linux; mainProgram = "tilix"; }; diff --git a/pkgs/by-name/ti/tilt/assets.nix b/pkgs/by-name/ti/tilt/assets.nix index 11db3253d34f87..2991c2bfcd2740 100644 --- a/pkgs/by-name/ti/tilt/assets.nix +++ b/pkgs/by-name/ti/tilt/assets.nix @@ -1,10 +1,11 @@ -{ lib -, stdenvNoCC -, nodejs -, yarn-berry -, cacert -, version -, src +{ + lib, + stdenvNoCC, + nodejs, + yarn-berry, + cacert, + version, + src, }: stdenvNoCC.mkDerivation { @@ -12,7 +13,10 @@ stdenvNoCC.mkDerivation { src = "${src}/web"; inherit version; - nativeBuildInputs = [ nodejs yarn-berry ]; + nativeBuildInputs = [ + nodejs + yarn-berry + ]; yarnOfflineCache = stdenvNoCC.mkDerivation { name = "tilt-assets-deps"; @@ -21,9 +25,20 @@ stdenvNoCC.mkDerivation { nativeBuildInputs = [ yarn-berry ]; supportedArchitectures = builtins.toJSON { - os = [ "darwin" "linux" ]; - cpu = [ "arm" "arm64" "ia32" "x64" ]; - libc = [ "glibc" "musl" ]; + os = [ + "darwin" + "linux" + ]; + cpu = [ + "arm" + "arm64" + "ia32" + "x64" + ]; + libc = [ + "glibc" + "musl" + ]; }; NODE_EXTRA_CA_CERTS = "${cacert}/etc/ssl/certs/ca-bundle.crt"; diff --git a/pkgs/by-name/ti/tilt/binary.nix b/pkgs/by-name/ti/tilt/binary.nix index ebb7f6e1178913..4c5e70520927f1 100644 --- a/pkgs/by-name/ti/tilt/binary.nix +++ b/pkgs/by-name/ti/tilt/binary.nix @@ -1,14 +1,18 @@ -{ lib -, buildGoModule -, src, version -, tilt-assets +{ + lib, + buildGoModule, + src, + version, + tilt-assets, }: buildGoModule rec { pname = "tilt"; - /* Do not use "dev" as a version. If you do, Tilt will consider itself + /* + Do not use "dev" as a version. If you do, Tilt will consider itself running in development environment and try to serve assets from the - source tree, which is not there once build completes. */ + source tree, which is not there once build completes. + */ inherit src version; vendorHash = null; diff --git a/pkgs/by-name/ti/tilt/package.nix b/pkgs/by-name/ti/tilt/package.nix index 42a493d4ebd56c..77ffc410c05c56 100644 --- a/pkgs/by-name/ti/tilt/package.nix +++ b/pkgs/by-name/ti/tilt/package.nix @@ -1,20 +1,24 @@ -{ fetchFromGitHub -, callPackage +{ + fetchFromGitHub, + callPackage, }: -let args = rec { - /* Do not use "dev" as a version. If you do, Tilt will consider itself - running in development environment and try to serve assets from the - source tree, which is not there once build completes. */ - version = "0.33.21"; +let + args = rec { + /* + Do not use "dev" as a version. If you do, Tilt will consider itself + running in development environment and try to serve assets from the + source tree, which is not there once build completes. + */ + version = "0.33.21"; - src = fetchFromGitHub { - owner = "tilt-dev"; - repo = "tilt"; - rev = "v${version}"; - hash = "sha256-3LFsTaz47QAIDGId/Tl3G7xP5b9gc25X+ZeMaVhXf8w="; - }; + src = fetchFromGitHub { + owner = "tilt-dev"; + repo = "tilt"; + rev = "v${version}"; + hash = "sha256-3LFsTaz47QAIDGId/Tl3G7xP5b9gc25X+ZeMaVhXf8w="; }; + }; tilt-assets = callPackage ./assets.nix args; -in callPackage ./binary.nix (args // { inherit tilt-assets; }) - +in +callPackage ./binary.nix (args // { inherit tilt-assets; }) diff --git a/pkgs/by-name/ti/time-decode/package.nix b/pkgs/by-name/ti/time-decode/package.nix index b208fd3e2ba255..213ad4fc3ff507 100644 --- a/pkgs/by-name/ti/time-decode/package.nix +++ b/pkgs/by-name/ti/time-decode/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ti/time-ghc-modules/package.nix b/pkgs/by-name/ti/time-ghc-modules/package.nix index bbe0e4152fc075..e4dbe40b46cde8 100644 --- a/pkgs/by-name/ti/time-ghc-modules/package.nix +++ b/pkgs/by-name/ti/time-ghc-modules/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, sqlite -, python3 -, coreutils -, findutils -, gnused +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + sqlite, + python3, + coreutils, + findutils, + gnused, }: stdenv.mkDerivation rec { @@ -20,14 +21,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-/PhJAhP3KCWFyeSk8e5JV0cpBueH/eVDwQTMZSnnZCo="; }; - nativeBuildInputs = [makeWrapper]; + nativeBuildInputs = [ makeWrapper ]; buildPhase = '' runHook preBuild mkdir -p $out/bin cp ./time-ghc-modules $out/bin/time-ghc-modules - wrapProgram $out/bin/time-ghc-modules --prefix PATH : ${lib.makeBinPath [ sqlite python3 coreutils findutils gnused ]} \ + wrapProgram $out/bin/time-ghc-modules --prefix PATH : ${ + lib.makeBinPath [ + sqlite + python3 + coreutils + findutils + gnused + ] + } \ --set PROCESS_SCRIPT $out/lib/process \ --set HTML_FILE $out/lib/index.html diff --git a/pkgs/by-name/ti/time/package.nix b/pkgs/by-name/ti/time/package.nix index 2328d03e18704f..dca11222ef2487 100644 --- a/pkgs/by-name/ti/time/package.nix +++ b/pkgs/by-name/ti/time/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation (finalAttrs: { pname = "time"; diff --git a/pkgs/by-name/ti/timelapse-deflicker/package.nix b/pkgs/by-name/ti/timelapse-deflicker/package.nix index 511ed8a0134afb..091ad288ddc267 100644 --- a/pkgs/by-name/ti/timelapse-deflicker/package.nix +++ b/pkgs/by-name/ti/timelapse-deflicker/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, perl, perlPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + perl, + perlPackages, +}: stdenv.mkDerivation rec { pname = "timelapse-deflicker"; @@ -19,8 +26,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; buildInputs = with perlPackages; [ perl - ImageMagick TermProgressBar ImageExifTool - FileType ClassMethodMaker + ImageMagick + TermProgressBar + ImageExifTool + FileType + ClassMethodMaker ]; meta = with lib; { diff --git a/pkgs/by-name/ti/timelens/package.nix b/pkgs/by-name/ti/timelens/package.nix index 7b7b1e0e7211c8..2d2f1947d6fbaf 100644 --- a/pkgs/by-name/ti/timelens/package.nix +++ b/pkgs/by-name/ti/timelens/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, glib -, gst_all_1 -, wrapGAppsHook3 +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + glib, + gst_all_1, + wrapGAppsHook3, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ti/timelimit/package.nix b/pkgs/by-name/ti/timelimit/package.nix index f943c5ee7292b2..feda76a76bc63f 100644 --- a/pkgs/by-name/ti/timelimit/package.nix +++ b/pkgs/by-name/ti/timelimit/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, perl }: +{ + lib, + stdenv, + fetchFromGitLab, + perl, +}: stdenv.mkDerivation rec { pname = "timelimit"; diff --git a/pkgs/by-name/ti/timeline/package.nix b/pkgs/by-name/ti/timeline/package.nix index 8aedc4854006ba..a3ca865e83e692 100644 --- a/pkgs/by-name/ti/timeline/package.nix +++ b/pkgs/by-name/ti/timeline/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchurl -, python3 -, gettext -, makeDesktopItem -, copyDesktopItems -, wrapGAppsHook3 +{ + lib, + fetchurl, + python3, + gettext, + makeDesktopItem, + copyDesktopItems, + wrapGAppsHook3, }: python3.pkgs.buildPythonApplication rec { @@ -17,7 +18,11 @@ python3.pkgs.buildPythonApplication rec { sha256 = "sha256-qwH2mt3Va62QJKJGOpt5WV3QksqQaRGEif4CcPC5F2E="; }; - nativeBuildInputs = [ python3.pkgs.wrapPython copyDesktopItems wrapGAppsHook3 ]; + nativeBuildInputs = [ + python3.pkgs.wrapPython + copyDesktopItems + wrapGAppsHook3 + ]; pythonPath = with python3.pkgs; [ wxpython @@ -38,7 +43,10 @@ python3.pkgs.buildPythonApplication rec { comment = "Display and navigate information on a timeline"; icon = "timeline"; exec = "timeline"; - categories = [ "Office" "Calendar" ]; + categories = [ + "Office" + "Calendar" + ]; }) ]; @@ -88,7 +96,10 @@ python3.pkgs.buildPythonApplication rec { changelog = "https://thetimelineproj.sourceforge.net/changelog.html"; description = "Display and navigate information on a timeline"; mainProgram = "timeline"; - license = with licenses; [ gpl3Only cc-by-sa-30 ]; + license = with licenses; [ + gpl3Only + cc-by-sa-30 + ]; platforms = with platforms; unix; maintainers = with maintainers; [ davidak ]; }; diff --git a/pkgs/by-name/ti/timemachine/package.nix b/pkgs/by-name/ti/timemachine/package.nix index c09a9b1bc00792..c1781aed817192 100644 --- a/pkgs/by-name/ti/timemachine/package.nix +++ b/pkgs/by-name/ti/timemachine/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, pkg-config, gtk2 -, libjack2, libsndfile +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + pkg-config, + gtk2, + libjack2, + libsndfile, }: stdenv.mkDerivation rec { @@ -12,10 +20,16 @@ stdenv.mkDerivation rec { sha256 = "16fgyw6jnscx9279dczv72092dddghwlp53rkfw469kcgvjhwx0z"; }; - nativeBuildInputs = [ pkg-config autoconf automake ]; - buildInputs = [ gtk2 libjack2 - libsndfile - ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; + buildInputs = [ + gtk2 + libjack2 + libsndfile + ]; preConfigure = "./autogen.sh"; @@ -30,4 +44,3 @@ stdenv.mkDerivation rec { mainProgram = "timemachine"; }; } - diff --git a/pkgs/by-name/ti/timer/package.nix b/pkgs/by-name/ti/timer/package.nix index 5b91a765d2c717..c5b78c80b3f02c 100644 --- a/pkgs/by-name/ti/timer/package.nix +++ b/pkgs/by-name/ti/timer/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, timer }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + timer, +}: buildGoModule rec { pname = "timer"; @@ -13,7 +19,11 @@ buildGoModule rec { vendorHash = "sha256-mE/C4S2gqcFGfnmCeMS/VpQwXHrI8SXos0M1+rV3hPo="; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; passthru.tests.version = testers.testVersion { package = timer; }; @@ -21,7 +31,10 @@ buildGoModule rec { description = "`sleep` with progress"; homepage = "https://github.com/caarlos0/timer"; license = licenses.mit; - maintainers = with maintainers; [ zowoq caarlos0 ]; + maintainers = with maintainers; [ + zowoq + caarlos0 + ]; mainProgram = "timer"; }; } diff --git a/pkgs/by-name/ti/times-newer-roman/package.nix b/pkgs/by-name/ti/times-newer-roman/package.nix index a12ba2cbe35746..f30b25165dacec 100644 --- a/pkgs/by-name/ti/times-newer-roman/package.nix +++ b/pkgs/by-name/ti/times-newer-roman/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { pname = "times-newer-roman"; diff --git a/pkgs/by-name/ti/timescaledb-parallel-copy/package.nix b/pkgs/by-name/ti/timescaledb-parallel-copy/package.nix index 37bad3e03d63a4..9d855cbff76eae 100644 --- a/pkgs/by-name/ti/timescaledb-parallel-copy/package.nix +++ b/pkgs/by-name/ti/timescaledb-parallel-copy/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "timescaledb-parallel-copy"; diff --git a/pkgs/by-name/ti/timescaledb-tune/package.nix b/pkgs/by-name/ti/timescaledb-tune/package.nix index 3020886cb30551..1c17f31484dfbc 100644 --- a/pkgs/by-name/ti/timescaledb-tune/package.nix +++ b/pkgs/by-name/ti/timescaledb-tune/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "timescaledb-tune"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-7u3eceVDnzjhGguijJXbm40qyCPO/Q101Zr5vEcGEqs="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Tool for tuning your TimescaleDB for better performance"; diff --git a/pkgs/by-name/ti/timetagger/package.nix b/pkgs/by-name/ti/timetagger/package.nix index 8505a897a675b7..93a6a542a67df1 100644 --- a/pkgs/by-name/ti/timetagger/package.nix +++ b/pkgs/by-name/ti/timetagger/package.nix @@ -1,7 +1,8 @@ -{ python3 +{ + python3, -, addr ? "127.0.0.1" -, port ? 8082 + addr ? "127.0.0.1", + port ? 8082, }: # @@ -11,7 +12,12 @@ # python3.pkgs.buildPythonApplication { - inherit (python3.pkgs.timetagger) pname version src meta; + inherit (python3.pkgs.timetagger) + pname + version + src + meta + ; propagatedBuildInputs = with python3.pkgs; [ setuptools @@ -28,4 +34,3 @@ python3.pkgs.buildPythonApplication { --set TIMETAGGER_BIND "${addr}:${toString port}" ''; } - diff --git a/pkgs/by-name/ti/timetagger_cli/package.nix b/pkgs/by-name/ti/timetagger_cli/package.nix index 576b0b55e57cb1..17da60ad15e8c1 100644 --- a/pkgs/by-name/ti/timetagger_cli/package.nix +++ b/pkgs/by-name/ti/timetagger_cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -31,4 +32,3 @@ python3.pkgs.buildPythonApplication rec { mainProgram = "timetagger"; }; } - diff --git a/pkgs/by-name/ti/timeular/package.nix b/pkgs/by-name/ti/timeular/package.nix index 27227cff027431..e3174edfb4986c 100644 --- a/pkgs/by-name/ti/timeular/package.nix +++ b/pkgs/by-name/ti/timeular/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchurl -, appimageTools +{ + lib, + fetchurl, + appimageTools, }: let @@ -15,7 +16,8 @@ let appimageContents = appimageTools.extractType2 { inherit pname version src; }; -in appimageTools.wrapType2 rec { +in +appimageTools.wrapType2 rec { inherit pname version src; extraPkgs = pkgs: [ pkgs.libsecret ]; diff --git a/pkgs/by-name/ti/timew-sync-server/package.nix b/pkgs/by-name/ti/timew-sync-server/package.nix index fefc25a4879274..54bd274b4c9700 100644 --- a/pkgs/by-name/ti/timew-sync-server/package.nix +++ b/pkgs/by-name/ti/timew-sync-server/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "timew-sync-server"; diff --git a/pkgs/by-name/ti/timewarrior/package.nix b/pkgs/by-name/ti/timewarrior/package.nix index f0cca927f753d7..054a32860248b3 100644 --- a/pkgs/by-name/ti/timewarrior/package.nix +++ b/pkgs/by-name/ti/timewarrior/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, asciidoctor, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + asciidoctor, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "timewarrior"; @@ -12,7 +19,11 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake asciidoctor installShellFiles ]; + nativeBuildInputs = [ + cmake + asciidoctor + installShellFiles + ]; dontUseCmakeBuildDir = true; @@ -25,9 +36,11 @@ stdenv.mkDerivation rec { description = "Command-line time tracker"; homepage = "https://timewarrior.net"; license = licenses.mit; - maintainers = with maintainers; [ matthiasbeyer mrVanDalo ]; + maintainers = with maintainers; [ + matthiasbeyer + mrVanDalo + ]; mainProgram = "timew"; platforms = platforms.linux ++ platforms.darwin; }; } - diff --git a/pkgs/by-name/ti/timezonemap/package.nix b/pkgs/by-name/ti/timezonemap/package.nix index de7915b5f67bdd..e886d8646cbb8d 100644 --- a/pkgs/by-name/ti/timezonemap/package.nix +++ b/pkgs/by-name/ti/timezonemap/package.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, autoreconfHook -, fetchbzr -, fetchpatch -, pkg-config -, gtk3 -, glib -, file -, gobject-introspection -, json-glib -, libsoup_2_4 +{ + stdenv, + lib, + autoreconfHook, + fetchbzr, + fetchpatch, + pkg-config, + gtk3, + glib, + file, + gobject-introspection, + json-glib, + libsoup_2_4, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ti/timg/package.nix b/pkgs/by-name/ti/timg/package.nix index 3138b6daf83199..7eba3a5070791c 100644 --- a/pkgs/by-name/ti/timg/package.nix +++ b/pkgs/by-name/ti/timg/package.nix @@ -1,20 +1,21 @@ -{ cmake -, fetchFromGitHub -, ffmpeg -, graphicsmagick -, lib -, libdeflate -, libexif -, libjpeg -, libsixel -, openslide -, poppler -, librsvg -, cairo -, pkg-config -, stb -, qoi -, stdenv +{ + cmake, + fetchFromGitHub, + ffmpeg, + graphicsmagick, + lib, + libdeflate, + libexif, + libjpeg, + libsixel, + openslide, + poppler, + librsvg, + cairo, + pkg-config, + stb, + qoi, + stdenv, }: stdenv.mkDerivation (finalAttrs: { @@ -43,7 +44,10 @@ stdenv.mkDerivation (finalAttrs: { stb ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; cmakeFlags = [ "-DTIMG_VERSION_FROM_GIT=Off" diff --git a/pkgs/by-name/ti/tini/package.nix b/pkgs/by-name/ti/tini/package.nix index 72d6ecb0594522..0779a1ac627cd4 100644 --- a/pkgs/by-name/ti/tini/package.nix +++ b/pkgs/by-name/ti/tini/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { version = "0.19.0"; @@ -8,7 +13,7 @@ stdenv.mkDerivation rec { owner = "krallin"; repo = "tini"; rev = "v${version}"; - sha256 ="1hnnvjydg7gi5gx6nibjjdnfipblh84qcpajc08nvr44rkzswck4"; + sha256 = "1hnnvjydg7gi5gx6nibjjdnfipblh84qcpajc08nvr44rkzswck4"; }; postPatch = "sed -i /tini-static/d CMakeLists.txt"; diff --git a/pkgs/by-name/ti/tint2/package.nix b/pkgs/by-name/ti/tint2/package.nix index 46c89527c4f0bd..8d13d220a73068 100644 --- a/pkgs/by-name/ti/tint2/package.nix +++ b/pkgs/by-name/ti/tint2/package.nix @@ -1,25 +1,27 @@ -{ lib, stdenv -, fetchFromGitLab -, fetchpatch -, pkg-config -, cmake -, gettext -, cairo -, pango -, glib -, imlib2 -, gtk3 -, libXinerama -, libXrender -, libXcomposite -, libXdamage -, libX11 -, libXrandr -, librsvg -, libpthreadstubs -, libXdmcp -, libstartup_notification -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + pkg-config, + cmake, + gettext, + cairo, + pango, + glib, + imlib2, + gtk3, + libXinerama, + libXrender, + libXcomposite, + libXdamage, + libX11, + libXrandr, + librsvg, + libpthreadstubs, + libXdmcp, + libstartup_notification, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ti/tintin/package.nix b/pkgs/by-name/ti/tintin/package.nix index 6f56512b1da243..2baa14b26a6249 100644 --- a/pkgs/by-name/ti/tintin/package.nix +++ b/pkgs/by-name/ti/tintin/package.nix @@ -1,6 +1,12 @@ -{ stdenv, fetchFromGitHub, lib, zlib, pcre -, memorymappingHook, memstreamHook -, gnutls +{ + stdenv, + fetchFromGitHub, + lib, + zlib, + pcre, + memorymappingHook, + memstreamHook, + gnutls, }: stdenv.mkDerivation rec { @@ -14,8 +20,16 @@ stdenv.mkDerivation rec { hash = "sha256-AfWw9CMBAzTTsrZXDEoOdpvUofIQfLCW7hRgSb7LB00="; }; - buildInputs = [ zlib pcre gnutls ] - ++ lib.optionals (stdenv.system == "x86_64-darwin") [ memorymappingHook memstreamHook ]; + buildInputs = + [ + zlib + pcre + gnutls + ] + ++ lib.optionals (stdenv.system == "x86_64-darwin") [ + memorymappingHook + memstreamHook + ]; preConfigure = '' cd src @@ -23,10 +37,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Free MUD client for macOS, Linux and Windows"; - homepage = "https://tintin.mudhalla.net/index.php"; - license = licenses.gpl3Plus; + homepage = "https://tintin.mudhalla.net/index.php"; + license = licenses.gpl3Plus; maintainers = with maintainers; [ abathur ]; mainProgram = "tt++"; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ti/tiny-cuda-nn/package.nix b/pkgs/by-name/ti/tiny-cuda-nn/package.nix index 74a76d2b9c90f4..e6768fd6b69428 100644 --- a/pkgs/by-name/ti/tiny-cuda-nn/package.nix +++ b/pkgs/by-name/ti/tiny-cuda-nn/package.nix @@ -4,12 +4,13 @@ fetchFromGitHub, lib, ninja, - python3Packages ? {}, + python3Packages ? { }, pythonSupport ? false, stdenv, symlinkJoin, which, -}: let +}: +let inherit (lib) lists strings; inherit (cudaPackages) backendStdenv cudaVersion flags; @@ -27,9 +28,7 @@ cuda-native-redist = symlinkJoin { name = "cuda-redist"; - paths = with cudaPackages; - [cuda_nvcc] - ++ cuda-common-redist; + paths = with cudaPackages; [ cuda_nvcc ] ++ cuda-common-redist; }; cuda-redist = symlinkJoin { @@ -45,134 +44,139 @@ cudaArchitecturesString = strings.concatMapStringsSep ";" flags.dropDot cudaCapabilities; in - stdenv.mkDerivation (finalAttrs: { - pname = "tiny-cuda-nn"; - version = "1.6"; - strictDeps = true; - - format = strings.optionalString pythonSupport "setuptools"; - - src = fetchFromGitHub { - owner = "NVlabs"; - repo = "tiny-cuda-nn"; - rev = "v${finalAttrs.version}"; - fetchSubmodules = true; - hash = "sha256-qW6Fk2GB71fvZSsfu+mykabSxEKvaikZ/pQQZUycOy0="; - }; - - # Remove this once a release is made with - # https://github.com/NVlabs/tiny-cuda-nn/commit/78a14fe8c292a69f54e6d0d47a09f52b777127e1 - postPatch = lib.optionals (strings.versionAtLeast cudaVersion "11.0") '' - substituteInPlace bindings/torch/setup.py --replace-fail \ - "-std=c++14" "-std=c++17" - ''; +stdenv.mkDerivation (finalAttrs: { + pname = "tiny-cuda-nn"; + version = "1.6"; + strictDeps = true; + + format = strings.optionalString pythonSupport "setuptools"; + + src = fetchFromGitHub { + owner = "NVlabs"; + repo = "tiny-cuda-nn"; + rev = "v${finalAttrs.version}"; + fetchSubmodules = true; + hash = "sha256-qW6Fk2GB71fvZSsfu+mykabSxEKvaikZ/pQQZUycOy0="; + }; - nativeBuildInputs = + # Remove this once a release is made with + # https://github.com/NVlabs/tiny-cuda-nn/commit/78a14fe8c292a69f54e6d0d47a09f52b777127e1 + postPatch = lib.optionals (strings.versionAtLeast cudaVersion "11.0") '' + substituteInPlace bindings/torch/setup.py --replace-fail \ + "-std=c++14" "-std=c++17" + ''; + + nativeBuildInputs = + [ + cmake + cuda-native-redist + ninja + which + ] + ++ lists.optionals pythonSupport ( + with python3Packages; [ - cmake - cuda-native-redist - ninja - which - ] - ++ lists.optionals pythonSupport (with python3Packages; [ pip setuptools wheel - ]); + ] + ); - buildInputs = + buildInputs = + [ + cuda-redist + ] + ++ lib.optionals pythonSupport ( + with python3Packages; [ - cuda-redist - ] - ++ lib.optionals pythonSupport ( - with python3Packages; [ - pybind11 - python - ] - ); - - propagatedBuildInputs = lib.optionals pythonSupport ( - with python3Packages; [ - torch + pybind11 + python ] ); - # NOTE: We cannot use pythonImportsCheck for this module because it uses torch to immediately - # initailize CUDA and GPU access is not allowed in the nix build environment. - # NOTE: There are no tests for the C++ library or the python bindings, so we just skip the check - # phase -- we're not missing anything. - doCheck = false; - - preConfigure = '' - export TCNN_CUDA_ARCHITECTURES="${cudaArchitecturesString}" - export CUDA_HOME="${cuda-native-redist}" - export LIBRARY_PATH="${cuda-native-redist}/lib/stubs:$LIBRARY_PATH" - export CC="${backendStdenv.cc}/bin/cc" - export CXX="${backendStdenv.cc}/bin/c++" - ''; - - # When building the python bindings, we cannot re-use the artifacts from the C++ build so we - # skip the CMake confurePhase and the buildPhase. - dontUseCmakeConfigure = pythonSupport; - - # The configurePhase usually puts you in the build directory, so for the python bindings we - # need to change directories to the source directory. - configurePhase = strings.optionalString pythonSupport '' - runHook preConfigure - mkdir -p "$NIX_BUILD_TOP/build" - cd "$NIX_BUILD_TOP/build" - runHook postConfigure - ''; - - buildPhase = strings.optionalString pythonSupport '' - runHook preBuild - python -m pip wheel \ + propagatedBuildInputs = lib.optionals pythonSupport ( + with python3Packages; + [ + torch + ] + ); + + # NOTE: We cannot use pythonImportsCheck for this module because it uses torch to immediately + # initailize CUDA and GPU access is not allowed in the nix build environment. + # NOTE: There are no tests for the C++ library or the python bindings, so we just skip the check + # phase -- we're not missing anything. + doCheck = false; + + preConfigure = '' + export TCNN_CUDA_ARCHITECTURES="${cudaArchitecturesString}" + export CUDA_HOME="${cuda-native-redist}" + export LIBRARY_PATH="${cuda-native-redist}/lib/stubs:$LIBRARY_PATH" + export CC="${backendStdenv.cc}/bin/cc" + export CXX="${backendStdenv.cc}/bin/c++" + ''; + + # When building the python bindings, we cannot re-use the artifacts from the C++ build so we + # skip the CMake confurePhase and the buildPhase. + dontUseCmakeConfigure = pythonSupport; + + # The configurePhase usually puts you in the build directory, so for the python bindings we + # need to change directories to the source directory. + configurePhase = strings.optionalString pythonSupport '' + runHook preConfigure + mkdir -p "$NIX_BUILD_TOP/build" + cd "$NIX_BUILD_TOP/build" + runHook postConfigure + ''; + + buildPhase = strings.optionalString pythonSupport '' + runHook preBuild + python -m pip wheel \ + --no-build-isolation \ + --no-clean \ + --no-deps \ + --no-index \ + --verbose \ + --wheel-dir "$NIX_BUILD_TOP/build" \ + "$NIX_BUILD_TOP/source/bindings/torch" + runHook postBuild + ''; + + installPhase = + '' + runHook preInstall + mkdir -p "$out/lib" + '' + # Installing the C++ library just requires copying the static library to the output directory + + strings.optionalString (!pythonSupport) '' + cp libtiny-cuda-nn.a "$out/lib/" + '' + # Installing the python bindings requires building the wheel and installing it + + strings.optionalString pythonSupport '' + python -m pip install \ --no-build-isolation \ - --no-clean \ + --no-cache-dir \ --no-deps \ --no-index \ + --no-warn-script-location \ + --prefix="$out" \ --verbose \ - --wheel-dir "$NIX_BUILD_TOP/build" \ - "$NIX_BUILD_TOP/source/bindings/torch" - runHook postBuild + ./*.whl + '' + + '' + runHook postInstall ''; - installPhase = - '' - runHook preInstall - mkdir -p "$out/lib" - '' - # Installing the C++ library just requires copying the static library to the output directory - + strings.optionalString (!pythonSupport) '' - cp libtiny-cuda-nn.a "$out/lib/" - '' - # Installing the python bindings requires building the wheel and installing it - + strings.optionalString pythonSupport '' - python -m pip install \ - --no-build-isolation \ - --no-cache-dir \ - --no-deps \ - --no-index \ - --no-warn-script-location \ - --prefix="$out" \ - --verbose \ - ./*.whl - '' - + '' - runHook postInstall - ''; - - passthru = { - inherit cudaPackages; - }; - - meta = with lib; { - description = "Lightning fast C++/CUDA neural network framework"; - homepage = "https://github.com/NVlabs/tiny-cuda-nn"; - license = licenses.bsd3; - maintainers = with maintainers; [connorbaker]; - platforms = platforms.linux; - # g++: error: unrecognized command-line option '-mf16c' - broken = stdenv.hostPlatform.isAarch64; - }; - }) + passthru = { + inherit cudaPackages; + }; + + meta = with lib; { + description = "Lightning fast C++/CUDA neural network framework"; + homepage = "https://github.com/NVlabs/tiny-cuda-nn"; + license = licenses.bsd3; + maintainers = with maintainers; [ connorbaker ]; + platforms = platforms.linux; + # g++: error: unrecognized command-line option '-mf16c' + broken = stdenv.hostPlatform.isAarch64; + }; +}) diff --git a/pkgs/by-name/ti/tiny8086/package.nix b/pkgs/by-name/ti/tiny8086/package.nix index a3dc3c07265c86..94b55902c72d3f 100644 --- a/pkgs/by-name/ti/tiny8086/package.nix +++ b/pkgs/by-name/ti/tiny8086/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, localBios ? true -, nasm -, sdlSupport ? true -, SDL +{ + lib, + stdenv, + fetchFromGitHub, + localBios ? true, + nasm, + sdlSupport ? true, + SDL, }: stdenv.mkDerivation rec { @@ -18,8 +19,7 @@ stdenv.mkDerivation rec { sha256 = "00aydg8f28sgy8l3rd2a7jvp56lx3b63hhak43p7g7vjdikv495w"; }; - buildInputs = lib.optional localBios nasm - ++ lib.optional sdlSupport SDL; + buildInputs = lib.optional localBios nasm ++ lib.optional sdlSupport SDL; makeFlags = [ "8086tiny" ]; diff --git a/pkgs/by-name/ti/tinyalsa/package.nix b/pkgs/by-name/ti/tinyalsa/package.nix index e8a388dbef679b..e21bf9f0b88476 100644 --- a/pkgs/by-name/ti/tinyalsa/package.nix +++ b/pkgs/by-name/ti/tinyalsa/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ti/tinycbor/package.nix b/pkgs/by-name/ti/tinycbor/package.nix index 9f9a060d74d8ee..36add6430e24fa 100644 --- a/pkgs/by-name/ti/tinycbor/package.nix +++ b/pkgs/by-name/ti/tinycbor/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "tinycbor"; diff --git a/pkgs/by-name/ti/tinycdb/package.nix b/pkgs/by-name/ti/tinycdb/package.nix index c13e97e968bfe0..69c6ade37992f1 100644 --- a/pkgs/by-name/ti/tinycdb/package.nix +++ b/pkgs/by-name/ti/tinycdb/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchurl }: +{ + stdenv, + lib, + fetchurl, +}: let isCross = stdenv.buildPlatform != stdenv.hostPlatform; cross = "${stdenv.hostPlatform.config}"; @@ -7,7 +11,8 @@ let cc = if !isCross then "cc" else "${cross}-cc"; ar = if !isCross then "ar" else "${cross}-ar"; ranlib = if !isCross then "ranlib" else "${cross}-ranlib"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { postPatch = '' sed -i 's,set --, set -x; set --,' Makefile ''; @@ -16,22 +21,37 @@ in stdenv.mkDerivation rec { # In general, static library (.a) goes to "dev", shared (.so) to # "lib". In case of static build, there is no .so library, so "lib" # output is useless and empty. - outputs = [ "out" "dev" "man" ] ++ lib.optional (!static) "lib"; + outputs = [ + "out" + "dev" + "man" + ] ++ lib.optional (!static) "lib"; separateDebugInfo = true; - makeFlags = - [ "prefix=$(out)" "CC=${cc}" "AR=${ar}" "RANLIB=${ranlib}" "static" + makeFlags = [ + "prefix=$(out)" + "CC=${cc}" + "AR=${ar}" + "RANLIB=${ranlib}" + "static" ] ++ lib.optional (!static) "shared"; - postInstall = '' - mkdir -p $dev/lib $out/bin - mv $out/lib/libcdb.a $dev/lib - rmdir $out/lib - '' + (if static then '' - cp cdb $out/bin/cdb - '' else '' - mkdir -p $lib/lib - cp libcdb.so* $lib/lib - cp cdb-shared $out/bin/cdb - ''); + postInstall = + '' + mkdir -p $dev/lib $out/bin + mv $out/lib/libcdb.a $dev/lib + rmdir $out/lib + '' + + ( + if static then + '' + cp cdb $out/bin/cdb + '' + else + '' + mkdir -p $lib/lib + cp libcdb.so* $lib/lib + cp cdb-shared $out/bin/cdb + '' + ); src = fetchurl { url = "http://www.corpit.ru/mjt/tinycdb/${pname}-${version}.tar.gz"; diff --git a/pkgs/by-name/ti/tinycompress/package.nix b/pkgs/by-name/ti/tinycompress/package.nix index 3126b4b51c5d07..39398fb79c6bac 100644 --- a/pkgs/by-name/ti/tinycompress/package.nix +++ b/pkgs/by-name/ti/tinycompress/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ti/tinyfecvpn/package.nix b/pkgs/by-name/ti/tinyfecvpn/package.nix index 68e7e31af31664..9907e1f50d2ac6 100644 --- a/pkgs/by-name/ti/tinyfecvpn/package.nix +++ b/pkgs/by-name/ti/tinyfecvpn/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, +}: stdenv.mkDerivation rec { pname = "tinyfecvpn"; diff --git a/pkgs/by-name/ti/tinymembench/package.nix b/pkgs/by-name/ti/tinymembench/package.nix index 3cb444ed334c05..0dc6f5a7fd1021 100644 --- a/pkgs/by-name/ti/tinymembench/package.nix +++ b/pkgs/by-name/ti/tinymembench/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ti/tinyobjloader/package.nix b/pkgs/by-name/ti/tinyobjloader/package.nix index e2fd82732688f0..a48259172c4598 100644 --- a/pkgs/by-name/ti/tinyobjloader/package.nix +++ b/pkgs/by-name/ti/tinyobjloader/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ti/tinyprog/package.nix b/pkgs/by-name/ti/tinyprog/package.nix index 0e962d2f2a2b74..2e2c0776a80ebb 100644 --- a/pkgs/by-name/ti/tinyprog/package.nix +++ b/pkgs/by-name/ti/tinyprog/package.nix @@ -1,9 +1,11 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: -with python3Packages; buildPythonApplication rec { +with python3Packages; +buildPythonApplication rec { pname = "tinyprog"; # `python setup.py --version` from repo checkout version = "1.0.24.dev114+g${lib.substring 0 7 src.rev}"; diff --git a/pkgs/by-name/ti/tinyproxy/package.nix b/pkgs/by-name/ti/tinyproxy/package.nix index b5d45baf998b7c..01c1382afd86a5 100644 --- a/pkgs/by-name/ti/tinyproxy/package.nix +++ b/pkgs/by-name/ti/tinyproxy/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, perl -, nixosTests -, withDebug ? false +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + perl, + nixosTests, + withDebug ? false, }: stdenv.mkDerivation rec { @@ -19,7 +20,10 @@ stdenv.mkDerivation rec { }; # perl is needed for man page generation. - nativeBuildInputs = [ autoreconfHook perl ]; + nativeBuildInputs = [ + autoreconfHook + perl + ]; configureFlags = lib.optionals withDebug [ "--enable-debug" ]; # Enable debugging support code and methods. passthru.tests = { inherit (nixosTests) tinyproxy; }; diff --git a/pkgs/by-name/ti/tinyscheme/package.nix b/pkgs/by-name/ti/tinyscheme/package.nix index e22f74c405992c..4d6f5dca769b49 100644 --- a/pkgs/by-name/ti/tinyscheme/package.nix +++ b/pkgs/by-name/ti/tinyscheme/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, dos2unix -, runCommand -, tinyscheme +{ + lib, + stdenv, + fetchurl, + dos2unix, + runCommand, + tinyscheme, }: stdenv.mkDerivation rec { @@ -18,21 +19,23 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ dos2unix ]; prePatch = "dos2unix makefile"; - patches = [ - # The alternate macOS main makes use of `ccommand` which seems to be - # `MetroWerks CodeWarrier` specific: - # https://ptgmedia.pearsoncmg.com/imprint_downloads/informit/downloads/9780201703535/macfix.html - # - # In any case, this is not needed to build on macOS. - ./01-remove-macOS-main.patch + patches = + [ + # The alternate macOS main makes use of `ccommand` which seems to be + # `MetroWerks CodeWarrier` specific: + # https://ptgmedia.pearsoncmg.com/imprint_downloads/informit/downloads/9780201703535/macfix.html + # + # In any case, this is not needed to build on macOS. + ./01-remove-macOS-main.patch - # We want to have the makefile pick up $CC, etc. so that we don't have - # to unnecessarily tie this package to the GCC stdenv. - ./02-use-toolchain-env-vars.patch - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # On macOS the library suffix is .dylib: - ./03-macOS-SOsuf.patch - ]; + # We want to have the makefile pick up $CC, etc. so that we don't have + # to unnecessarily tie this package to the GCC stdenv. + ./02-use-toolchain-env-vars.patch + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # On macOS the library suffix is .dylib: + ./03-macOS-SOsuf.patch + ]; postPatch = '' substituteInPlace scheme.c --replace "init.scm" "$out/lib/init.scm" ''; @@ -46,11 +49,11 @@ stdenv.mkDerivation rec { passthru.tests = { # Checks that the program can run and exit: - simple = runCommand "${pname}-simple-test" {} '' + simple = runCommand "${pname}-simple-test" { } '' ${tinyscheme}/bin/tinyscheme <<<"(quit 0)" echo "success" > $out ''; - fileIo = runCommand "${pname}-file-io-test" {} '' + fileIo = runCommand "${pname}-file-io-test" { } '' ${tinyscheme}/bin/tinyscheme < $out || : [[ "$(cat $out)" =~ ^Usage: ]] ''; diff --git a/pkgs/by-name/ti/tinysparql/package.nix b/pkgs/by-name/ti/tinysparql/package.nix index 240dbf789f57e9..2a7d30f5d4ab64 100644 --- a/pkgs/by-name/ti/tinysparql/package.nix +++ b/pkgs/by-name/ti/tinysparql/package.nix @@ -1,46 +1,55 @@ -{ stdenv -, lib -, fetchpatch2 -, fetchurl -, gettext -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, asciidoc -, gobject-introspection -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, vala -, python3 -, gi-docgen -, graphviz -, libxml2 -, glib -, wrapGAppsNoGuiHook -, sqlite -, libstemmer -, gnome -, icu -, libuuid -, libsoup_3 -, json-glib -, avahi -, systemd -, dbus -, man-db -, writeText -, testers +{ + stdenv, + lib, + fetchpatch2, + fetchurl, + gettext, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + asciidoc, + gobject-introspection, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + vala, + python3, + gi-docgen, + graphviz, + libxml2, + glib, + wrapGAppsNoGuiHook, + sqlite, + libstemmer, + gnome, + icu, + libuuid, + libsoup_3, + json-glib, + avahi, + systemd, + dbus, + man-db, + writeText, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "tinysparql"; version = "3.8.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { - url = with finalAttrs; "mirror://gnome/sources/tinysparql/${lib.versions.majorMinor version}/tinysparql-${version}.tar.xz"; + url = + with finalAttrs; + "mirror://gnome/sources/tinysparql/${lib.versions.majorMinor version}/tinysparql-${version}.tar.xz"; hash = "sha256-wPzad1IPUxVIsjlRN9zRk+6c3l4iLTydJz8DDRdipQQ="; }; @@ -50,62 +59,70 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - asciidoc - gettext - glib - wrapGAppsNoGuiHook - gi-docgen - graphviz - (python3.pythonOnBuildForHost.withPackages (p: [ p.pygobject3 ])) - ] ++ lib.optionals withIntrospection [ - gobject-introspection - vala - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + asciidoc + gettext + glib + wrapGAppsNoGuiHook + gi-docgen + graphviz + (python3.pythonOnBuildForHost.withPackages (p: [ p.pygobject3 ])) + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + vala + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; - buildInputs = [ - glib - libxml2 - sqlite - icu - libsoup_3 - libuuid - json-glib - avahi - libstemmer - dbus - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - systemd - ]; + buildInputs = + [ + glib + libxml2 + sqlite + icu + libsoup_3 + libuuid + json-glib + avahi + libstemmer + dbus + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + systemd + ]; nativeCheckInputs = [ dbus man-db ]; - mesonFlags = [ - "-Ddocs=true" - (lib.mesonEnable "introspection" withIntrospection) - (lib.mesonEnable "vapi" withIntrospection) - ] ++ ( - let - # https://gitlab.gnome.org/GNOME/tinysparql/-/blob/3.7.3/meson.build#L170 - crossFile = writeText "cross-file.conf" '' - [properties] - sqlite3_has_fts5 = '${lib.boolToString (lib.hasInfix "-DSQLITE_ENABLE_FTS3" sqlite.NIX_CFLAGS_COMPILE)}' - ''; - in + mesonFlags = [ - "--cross-file=${crossFile}" + "-Ddocs=true" + (lib.mesonEnable "introspection" withIntrospection) + (lib.mesonEnable "vapi" withIntrospection) ] - ) ++ lib.optionals (!stdenv.hostPlatform.isLinux) [ - "-Dsystemd_user_services=false" - ]; + ++ ( + let + # https://gitlab.gnome.org/GNOME/tinysparql/-/blob/3.7.3/meson.build#L170 + crossFile = writeText "cross-file.conf" '' + [properties] + sqlite3_has_fts5 = '${lib.boolToString (lib.hasInfix "-DSQLITE_ENABLE_FTS3" sqlite.NIX_CFLAGS_COMPILE)}' + ''; + in + [ + "--cross-file=${crossFile}" + ] + ) + ++ lib.optionals (!stdenv.hostPlatform.isLinux) [ + "-Dsystemd_user_services=false" + ]; patches = [ # https://gitlab.gnome.org/GNOME/tinysparql/-/merge_requests/730 @@ -187,7 +204,10 @@ stdenv.mkDerivation (finalAttrs: { maintainers = teams.gnome.members; license = licenses.gpl2Plus; platforms = platforms.unix; - pkgConfigModules = [ "tracker-sparql-3.0" "tinysparql-3.0" ]; + pkgConfigModules = [ + "tracker-sparql-3.0" + "tinysparql-3.0" + ]; # Not before is properly conditioned. broken = stdenv.hostPlatform.isDarwin; }; diff --git a/pkgs/by-name/ti/tinystatus/package.nix b/pkgs/by-name/ti/tinystatus/package.nix index 59a6dcff9dee3e..f5043e64523889 100644 --- a/pkgs/by-name/ti/tinystatus/package.nix +++ b/pkgs/by-name/ti/tinystatus/package.nix @@ -1,5 +1,18 @@ -{ lib, stdenvNoCC, makeWrapper, netcat, curl, unixtools, coreutils, mktemp -, findutils, gnugrep, fetchFromGitHub, gawk, gnused }: +{ + lib, + stdenvNoCC, + makeWrapper, + netcat, + curl, + unixtools, + coreutils, + mktemp, + findutils, + gnugrep, + fetchFromGitHub, + gawk, + gnused, +}: stdenvNoCC.mkDerivation rec { pname = "tinystatus"; diff --git a/pkgs/by-name/ti/tinywm/package.nix b/pkgs/by-name/ti/tinywm/package.nix index 32c0e2df49c252..6955dd2c2fc018 100644 --- a/pkgs/by-name/ti/tinywm/package.nix +++ b/pkgs/by-name/ti/tinywm/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, libX11 +{ + lib, + stdenv, + fetchFromGitHub, + libX11, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ti/tinyxml-2/package.nix b/pkgs/by-name/ti/tinyxml-2/package.nix index c814cdf570e20d..b601e57a17ebc2 100644 --- a/pkgs/by-name/ti/tinyxml-2/package.nix +++ b/pkgs/by-name/ti/tinyxml-2/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ti/tipa/package.nix b/pkgs/by-name/ti/tipa/package.nix index a0cc7106afe676..d9508e61440de3 100644 --- a/pkgs/by-name/ti/tipa/package.nix +++ b/pkgs/by-name/ti/tipa/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "tipa"; @@ -26,5 +30,3 @@ stdenv.mkDerivation rec { license = lib.licenses.lppl13c; }; } - - diff --git a/pkgs/by-name/ti/tippecanoe/package.nix b/pkgs/by-name/ti/tippecanoe/package.nix index 540e0eb5dc8deb..5d7683e5f934f4 100644 --- a/pkgs/by-name/ti/tippecanoe/package.nix +++ b/pkgs/by-name/ti/tippecanoe/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, sqlite, zlib, perl, testers }: +{ + lib, + stdenv, + fetchFromGitHub, + sqlite, + zlib, + perl, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "tippecanoe"; @@ -11,7 +19,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-5Ox/2K9cls8lZ+C/Fh5VQmgNEtbdMW0mh4fhBl6ecP8="; }; - buildInputs = [ sqlite zlib ]; + buildInputs = [ + sqlite + zlib + ]; nativeCheckInputs = [ perl ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/ti/tiptop/package.nix b/pkgs/by-name/ti/tiptop/package.nix index 919df3bbedfcd6..6ebb3252328800 100644 --- a/pkgs/by-name/ti/tiptop/package.nix +++ b/pkgs/by-name/ti/tiptop/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, fetchpatch, libxml2, ncurses, bison, flex }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libxml2, + ncurses, + bison, + flex, +}: stdenv.mkDerivation rec { pname = "tiptop"; @@ -28,8 +37,14 @@ stdenv.mkDerivation rec { substituteInPlace ./configure --replace -lcurses -lncurses ''; - nativeBuildInputs = [ flex bison ]; - buildInputs = [ libxml2 ncurses ]; + nativeBuildInputs = [ + flex + bison + ]; + buildInputs = [ + libxml2 + ncurses + ]; env.NIX_CFLAGS_COMPILE = "-I${libxml2.dev}/include/libxml2"; @@ -41,4 +56,3 @@ stdenv.mkDerivation rec { maintainers = [ ]; }; } - diff --git a/pkgs/by-name/ti/tiramisu/package.nix b/pkgs/by-name/ti/tiramisu/package.nix index 4a123be328c90c..c4a3c2cad4e546 100644 --- a/pkgs/by-name/ti/tiramisu/package.nix +++ b/pkgs/by-name/ti/tiramisu/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, glib, vala }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + glib, + vala, +}: stdenv.mkDerivation rec { pname = "tiramisu"; @@ -15,7 +22,10 @@ stdenv.mkDerivation rec { buildInputs = [ glib ]; - nativeBuildInputs = [ pkg-config vala ]; + nativeBuildInputs = [ + pkg-config + vala + ]; makeFlags = [ "PREFIX=$(out)" ]; @@ -29,7 +39,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/Sweets/tiramisu"; license = licenses.mit; platforms = platforms.linux; - maintainers = with maintainers; [ wishfort36 moni ]; + maintainers = with maintainers; [ + wishfort36 + moni + ]; mainProgram = "tiramisu"; }; } diff --git a/pkgs/by-name/ti/tiscamera/package.nix b/pkgs/by-name/ti/tiscamera/package.nix index d93eeaff27232c..d3aacec4e45a28 100644 --- a/pkgs/by-name/ti/tiscamera/package.nix +++ b/pkgs/by-name/ti/tiscamera/package.nix @@ -1,34 +1,35 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, runtimeShell -, catch2 -, elfutils -, libselinux -, libsepol -, libunwind -, libusb1 -, libuuid -, libzip -, orc -, pcre -, zstd -, glib -, gobject-introspection -, gst_all_1 -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + runtimeShell, + catch2, + elfutils, + libselinux, + libsepol, + libunwind, + libusb1, + libuuid, + libzip, + orc, + pcre, + zstd, + glib, + gobject-introspection, + gst_all_1, + wrapGAppsHook3, # needs pkg_resources -, withDoc ? false -, sphinx -, graphviz -, withAravis ? true -, aravis -, meson -, withAravisUsbVision ? withAravis -, withGui ? true -, qt5 + withDoc ? false, + sphinx, + graphviz, + withAravis ? true, + aravis, + meson, + withAravisUsbVision ? withAravis, + withGui ? true, + qt5, }: stdenv.mkDerivation rec { @@ -51,42 +52,49 @@ stdenv.mkDerivation rec { --replace "typically /usr/share/theimagingsource/tiscamera/uvc-extension/" "" ''; - nativeBuildInputs = [ - cmake - pkg-config - wrapGAppsHook3 - gobject-introspection - ] ++ lib.optionals withDoc [ - sphinx - graphviz - ] ++ lib.optionals withAravis [ - meson - ] ++ lib.optionals withGui [ - qt5.wrapQtAppsHook - ]; - - buildInputs = [ - elfutils - libselinux - libsepol - libunwind - libusb1 - libuuid - libzip - orc - pcre - zstd - glib - gst_all_1.gstreamer - gst_all_1.gst-plugins-base - gst_all_1.gst-plugins-good - gst_all_1.gst-plugins-bad - gst_all_1.gst-plugins-ugly - ] ++ lib.optionals withAravis [ - aravis - ] ++ lib.optionals withGui [ - qt5.qtbase - ]; + nativeBuildInputs = + [ + cmake + pkg-config + wrapGAppsHook3 + gobject-introspection + ] + ++ lib.optionals withDoc [ + sphinx + graphviz + ] + ++ lib.optionals withAravis [ + meson + ] + ++ lib.optionals withGui [ + qt5.wrapQtAppsHook + ]; + + buildInputs = + [ + elfutils + libselinux + libsepol + libunwind + libusb1 + libuuid + libzip + orc + pcre + zstd + glib + gst_all_1.gstreamer + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-good + gst_all_1.gst-plugins-bad + gst_all_1.gst-plugins-ugly + ] + ++ lib.optionals withAravis [ + aravis + ] + ++ lib.optionals withGui [ + qt5.qtbase + ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/ti/titanion/package.nix b/pkgs/by-name/ti/titanion/package.nix index 6b74eb351dd483..2235d32c514839 100644 --- a/pkgs/by-name/ti/titanion/package.nix +++ b/pkgs/by-name/ti/titanion/package.nix @@ -1,58 +1,46 @@ -{ lib -, stdenv -, fetchpatch -, fetchurl -, unzip -, gdc -, SDL -, SDL_mixer -, bulletml +{ + lib, + stdenv, + fetchpatch, + fetchurl, + unzip, + gdc, + SDL, + SDL_mixer, + bulletml, }: let -debianPatch = patchname: hash: fetchpatch { - name = "${patchname}.patch"; - url = "https://sources.debian.org/data/main/t/titanion/0.3.dfsg1-7/debian/patches/${patchname}"; - sha256 = hash; -}; + debianPatch = + patchname: hash: + fetchpatch { + name = "${patchname}.patch"; + url = "https://sources.debian.org/data/main/t/titanion/0.3.dfsg1-7/debian/patches/${patchname}"; + sha256 = hash; + }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "titanion"; version = "0.3"; src = fetchurl { - url = "http://abagames.sakura.ne.jp/windows/ttn${lib.replaceStrings ["."] ["_"] finalAttrs.version}.zip"; + url = "http://abagames.sakura.ne.jp/windows/ttn${ + lib.replaceStrings [ "." ] [ "_" ] finalAttrs.version + }.zip"; sha256 = "sha256-fR0cufi6dU898wP8KGl/vxbfQJzMmMxlYZ3QNGLajfM="; }; patches = [ - (debianPatch - "imports.patch" - "sha256-kSXpaTpYq6w9e0yLES2QGNQ8+vFIiOpw2P9MA8gZr8s=") - (debianPatch - "fix.diff" - "sha256-0WkkfuhJaAMY46VVyc3ldMQwgOVoQJDw/8zbm6H2sHU=") - (debianPatch - "directories.patch" - "sha256-fhQJuy2+r0YOQNwMqG85Gr7fJehmf00Scran+NPYQrw=") - (debianPatch - "windowed.patch" - "sha256-xouXIuIKfKFGsoOEJqL9jdsdnkX4nqwPGcoB+32Wvgo=") - (debianPatch - "dotfile.patch" - "sha256-sAml53Hh0ltbqN8xZDZuUJcaPfjK56jf4ymFXYD38v0=") - (debianPatch - "window-resize.patch" - "sha256-WwAi1aU4CmaX+O8fw0TfLhNSXFaObExrn7nuhesVkKM=") - (debianPatch - "makefile.patch" - "sha256-g0jDPmc0SWXkTLhiczeTse/WGCtgMUsbyPNZzwK3U+o=") - (debianPatch - "dlang_v2.patch" - "sha256-tfTAAKlPFSjbfAK1EjeB3unj9tbMlNaajJ+VVSMMiYw=") - (debianPatch - "gdc-8.patch" - "sha256-BxkPfSEymq7TDA+yjJHaYsjtGr0Tuu1/sWLwRBAMga4=") + (debianPatch "imports.patch" "sha256-kSXpaTpYq6w9e0yLES2QGNQ8+vFIiOpw2P9MA8gZr8s=") + (debianPatch "fix.diff" "sha256-0WkkfuhJaAMY46VVyc3ldMQwgOVoQJDw/8zbm6H2sHU=") + (debianPatch "directories.patch" "sha256-fhQJuy2+r0YOQNwMqG85Gr7fJehmf00Scran+NPYQrw=") + (debianPatch "windowed.patch" "sha256-xouXIuIKfKFGsoOEJqL9jdsdnkX4nqwPGcoB+32Wvgo=") + (debianPatch "dotfile.patch" "sha256-sAml53Hh0ltbqN8xZDZuUJcaPfjK56jf4ymFXYD38v0=") + (debianPatch "window-resize.patch" "sha256-WwAi1aU4CmaX+O8fw0TfLhNSXFaObExrn7nuhesVkKM=") + (debianPatch "makefile.patch" "sha256-g0jDPmc0SWXkTLhiczeTse/WGCtgMUsbyPNZzwK3U+o=") + (debianPatch "dlang_v2.patch" "sha256-tfTAAKlPFSjbfAK1EjeB3unj9tbMlNaajJ+VVSMMiYw=") + (debianPatch "gdc-8.patch" "sha256-BxkPfSEymq7TDA+yjJHaYsjtGr0Tuu1/sWLwRBAMga4=") ]; postPatch = '' diff --git a/pkgs/by-name/ti/tiv/package.nix b/pkgs/by-name/ti/tiv/package.nix index 4bfb705ae8612a..b2347948d2e833 100644 --- a/pkgs/by-name/ti/tiv/package.nix +++ b/pkgs/by-name/ti/tiv/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, imagemagick +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + imagemagick, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ti/tivodecode/package.nix b/pkgs/by-name/ti/tivodecode/package.nix index c21a0611262da7..0d794b27ae7780 100644 --- a/pkgs/by-name/ti/tivodecode/package.nix +++ b/pkgs/by-name/ti/tivodecode/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let version = "0.2pre4"; diff --git a/pkgs/by-name/tk/tkdiff/package.nix b/pkgs/by-name/tk/tkdiff/package.nix index 3e6fe807b611e9..73e450828c7b2b 100644 --- a/pkgs/by-name/tk/tkdiff/package.nix +++ b/pkgs/by-name/tk/tkdiff/package.nix @@ -1,11 +1,20 @@ -{ diffutils, fetchzip, lib, makeBinaryWrapper, stdenv, tk }: +{ + diffutils, + fetchzip, + lib, + makeBinaryWrapper, + stdenv, + tk, +}: stdenv.mkDerivation (finalAttrs: { pname = "tkdiff"; version = "5.7"; src = fetchzip { - url = "mirror://sourceforge/tkdiff/tkdiff-${builtins.replaceStrings ["."] ["-"] finalAttrs.version}.zip"; + url = "mirror://sourceforge/tkdiff/tkdiff-${ + builtins.replaceStrings [ "." ] [ "-" ] finalAttrs.version + }.zip"; hash = "sha256-ZndpolvaXoCAzR4KF+Bu7DJrXyB/C2H2lWp5FyzOc4M="; }; @@ -16,7 +25,12 @@ stdenv.mkDerivation (finalAttrs: { install -Dm755 -t $out/bin tkdiff wrapProgram $out/bin/tkdiff \ - --prefix PATH : ${lib.makeBinPath [ diffutils tk ]} + --prefix PATH : ${ + lib.makeBinPath [ + diffutils + tk + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/tk/tkey-ssh-agent/package.nix b/pkgs/by-name/tk/tkey-ssh-agent/package.nix index f377f940baa4fb..2ada4ad71cb6e8 100644 --- a/pkgs/by-name/tk/tkey-ssh-agent/package.nix +++ b/pkgs/by-name/tk/tkey-ssh-agent/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, buildGoModule, gitUpdater, testers, tkey-ssh-agent }: +{ + lib, + fetchFromGitHub, + buildGoModule, + gitUpdater, + testers, + tkey-ssh-agent, +}: buildGoModule rec { pname = "tkey-ssh-agent"; @@ -28,9 +35,9 @@ buildGoModule rec { meta = with lib; { description = "SSH Agent for TKey, the flexible open hardware/software USB security key"; - homepage = "https://tillitis.se/app/tkey-ssh-agent/"; - license = licenses.gpl2; + homepage = "https://tillitis.se/app/tkey-ssh-agent/"; + license = licenses.gpl2; maintainers = with maintainers; [ bbigras ]; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/tk/tkman/package.nix b/pkgs/by-name/tk/tkman/package.nix index c51c3564fef8a6..293280fa8e6ab2 100644 --- a/pkgs/by-name/tk/tkman/package.nix +++ b/pkgs/by-name/tk/tkman/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchzip -, fetchpatch -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, tk -, groff -, rman +{ + lib, + stdenv, + fetchzip, + fetchpatch, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + tk, + groff, + rman, }: stdenv.mkDerivation (finalAttrs: { @@ -24,10 +25,12 @@ stdenv.mkDerivation (finalAttrs: { copyDesktopItems ]; - patches = [(fetchpatch { - url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/app-text/tkman/files/tkman-CVE-2008-5137.diff"; - hash = "sha256-l97SY2/YnMgzHYKnVYCVJKV7oGLN1hXNpeHFlLVzTMA="; - })]; + patches = [ + (fetchpatch { + url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/app-text/tkman/files/tkman-CVE-2008-5137.diff"; + hash = "sha256-l97SY2/YnMgzHYKnVYCVJKV7oGLN1hXNpeHFlLVzTMA="; + }) + ]; makeFlags = [ "BINDIR=$(out)/bin" @@ -54,16 +57,18 @@ stdenv.mkDerivation (finalAttrs: { install -Dm644 contrib/TkMan.gif $out/share/icons/hicolor/64x64/apps/tkman.gif ''; - desktopItems = [(makeDesktopItem { - name = "tkman"; - desktopName = "TkMan"; - comment = "Graphical man page and info viewer"; - exec = "tkman %f"; - icon = "tkman"; - terminal = false; - type = "Application"; - categories = [ "Utility" ]; - })]; + desktopItems = [ + (makeDesktopItem { + name = "tkman"; + desktopName = "TkMan"; + comment = "Graphical man page and info viewer"; + exec = "tkman %f"; + icon = "tkman"; + terminal = false; + type = "Application"; + categories = [ "Utility" ]; + }) + ]; meta = with lib; { description = "Graphical, hypertext manual page and Texinfo browser for UNIX"; diff --git a/pkgs/by-name/tk/tkrev/package.nix b/pkgs/by-name/tk/tkrev/package.nix index 66c1aa4d0e12e5..d440bc9693c7aa 100644 --- a/pkgs/by-name/tk/tkrev/package.nix +++ b/pkgs/by-name/tk/tkrev/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, tcl, tk }: +{ + lib, + stdenv, + fetchurl, + tcl, + tk, +}: stdenv.mkDerivation rec { pname = "tkrev"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-WHDZPShEB9Q+Bjbb37mogJLUZk2GuWoO8bz+Zydc7i4="; }; - buildInputs = [ tcl tk ]; + buildInputs = [ + tcl + tk + ]; patchPhase = '' for file in tkrev/tkrev.tcl tkdiff/tkdiff; do diff --git a/pkgs/by-name/tk/tkrzw/package.nix b/pkgs/by-name/tk/tkrzw/package.nix index b79ecec9c623ac..97f2d05efe6689 100644 --- a/pkgs/by-name/tk/tkrzw/package.nix +++ b/pkgs/by-name/tk/tkrzw/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "tkrzw"; diff --git a/pkgs/by-name/tl/tl-expected/package.nix b/pkgs/by-name/tl/tl-expected/package.nix index 078ae201ea2a22..1beac87e9267ec 100644 --- a/pkgs/by-name/tl/tl-expected/package.nix +++ b/pkgs/by-name/tl/tl-expected/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "tl-expected"; diff --git a/pkgs/by-name/tl/tla/package.nix b/pkgs/by-name/tl/tla/package.nix index 146469bbbb3e17..d7d9185cd747ab 100644 --- a/pkgs/by-name/tl/tla/package.nix +++ b/pkgs/by-name/tl/tla/package.nix @@ -1,4 +1,11 @@ -{ stdenv, fetchurl, which, diffutils, gnupatch, gnutar }: +{ + stdenv, + fetchurl, + which, + diffutils, + gnupatch, + gnutar, +}: stdenv.mkDerivation rec { pname = "tla"; @@ -13,7 +20,11 @@ stdenv.mkDerivation rec { buildInputs = [ which ]; - propagatedBuildInputs = [ diffutils gnupatch gnutar ]; + propagatedBuildInputs = [ + diffutils + gnupatch + gnutar + ]; # Instead of GNU Autoconf, tla uses Tom Lord's now # defunct `package-framework'. diff --git a/pkgs/by-name/tl/tldr/package.nix b/pkgs/by-name/tl/tldr/package.nix index 0d4df99a952d8b..fc63b374570e25 100644 --- a/pkgs/by-name/tl/tldr/package.nix +++ b/pkgs/by-name/tl/tldr/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, curl, libzip, pkg-config, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + curl, + libzip, + pkg-config, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "tldr"; @@ -11,10 +19,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-1L9frURnzfq0XvPBs8D+hBikybAw8qkb0DyZZtkZleY="; }; - buildInputs = [ curl libzip ]; - nativeBuildInputs = [ pkg-config installShellFiles ]; + buildInputs = [ + curl + libzip + ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; - makeFlags = ["CC=${stdenv.cc.targetPrefix}cc" "LD=${stdenv.cc.targetPrefix}cc" "CFLAGS="]; + makeFlags = [ + "CC=${stdenv.cc.targetPrefix}cc" + "LD=${stdenv.cc.targetPrefix}cc" + "CFLAGS=" + ]; installFlags = [ "PREFIX=$(out)" ]; @@ -31,7 +49,11 @@ stdenv.mkDerivation rec { homepage = "https://tldr.sh"; changelog = "https://github.com/tldr-pages/tldr-c-client/blob/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ taeer carlosdagos kbdharun]; + maintainers = with maintainers; [ + taeer + carlosdagos + kbdharun + ]; platforms = platforms.all; mainProgram = "tldr"; }; diff --git a/pkgs/by-name/tl/tlf/package.nix b/pkgs/by-name/tl/tlf/package.nix index c6d8920f828d4f..3ad97ad8acaeac 100644 --- a/pkgs/by-name/tl/tlf/package.nix +++ b/pkgs/by-name/tl/tlf/package.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, autoconf, automake, pkg-config, glib -, perl, ncurses5, hamlib, xmlrpc_c }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + autoconf, + automake, + pkg-config, + glib, + perl, + ncurses5, + hamlib, + xmlrpc_c, +}: stdenv.mkDerivation rec { pname = "tlf"; @@ -24,10 +37,24 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook autoconf automake pkg-config perl ]; - buildInputs = [ glib ncurses5 hamlib xmlrpc_c ]; + nativeBuildInputs = [ + autoreconfHook + autoconf + automake + pkg-config + perl + ]; + buildInputs = [ + glib + ncurses5 + hamlib + xmlrpc_c + ]; - configureFlags = [ "--enable-hamlib" "--enable-fldigi-xmlrpc" ]; + configureFlags = [ + "--enable-hamlib" + "--enable-fldigi-xmlrpc" + ]; postInstall = '' mkdir -p $out/lib diff --git a/pkgs/by-name/tl/tllist/package.nix b/pkgs/by-name/tl/tllist/package.nix index d800279a8a4c1c..33b89b6f186ce6 100644 --- a/pkgs/by-name/tl/tllist/package.nix +++ b/pkgs/by-name/tl/tllist/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchFromGitea -, meson -, ninja +{ + stdenv, + lib, + fetchFromGitea, + meson, + ninja, }: stdenv.mkDerivation (finalAttrs: { @@ -17,7 +18,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-4WW0jGavdFO3LX9wtMPzz3Z1APCPgUQOktpmwAM0SQw="; }; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; mesonBuildType = "release"; diff --git a/pkgs/by-name/tl/tlmi-auth/package.nix b/pkgs/by-name/tl/tlmi-auth/package.nix index 8ba738a9710040..8ae56a545fc564 100644 --- a/pkgs/by-name/tl/tlmi-auth/package.nix +++ b/pkgs/by-name/tl/tlmi-auth/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, meson -, ninja -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + meson, + ninja, + openssl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/tl/tlrc/package.nix b/pkgs/by-name/tl/tlrc/package.nix index 86e9fe7861b85c..483d729c1718a1 100644 --- a/pkgs/by-name/tl/tlrc/package.nix +++ b/pkgs/by-name/tl/tlrc/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, installShellFiles -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + installShellFiles, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/tl/tlsclient/package.nix b/pkgs/by-name/tl/tlsclient/package.nix index 5f3633a6c9c767..20bbacd0c27a3c 100644 --- a/pkgs/by-name/tl/tlsclient/package.nix +++ b/pkgs/by-name/tl/tlsclient/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromSourcehut -, pkg-config -, openssl -, gitUpdater +{ + lib, + stdenv, + fetchFromSourcehut, + pkg-config, + openssl, + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/tl/tlwg/package.nix b/pkgs/by-name/tl/tlwg/package.nix index a9216ad0d356ce..d0e7e6c776551e 100644 --- a/pkgs/by-name/tl/tlwg/package.nix +++ b/pkgs/by-name/tl/tlwg/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, autoconf-archive, fontforge }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + autoconf-archive, + fontforge, +}: stdenv.mkDerivation rec { pname = "tlwg"; @@ -11,14 +18,22 @@ stdenv.mkDerivation rec { sha256 = "hWiH5KJnYTdcrm+Kzn9HUQry8ry3SKzjA6/0536kCLQ="; }; - nativeBuildInputs = [ autoreconfHook autoconf-archive ]; + nativeBuildInputs = [ + autoreconfHook + autoconf-archive + ]; buildInputs = [ fontforge ]; meta = with lib; { description = "Collection of Thai scalable fonts available under free licenses"; homepage = "https://linux.thai.net/projects/fonts-tlwg"; - license = with licenses; [ gpl2 publicDomain lppl13c free ]; + license = with licenses; [ + gpl2 + publicDomain + lppl13c + free + ]; maintainers = [ maintainers.yrashk ]; }; } diff --git a/pkgs/by-name/tm/tm/package.nix b/pkgs/by-name/tm/tm/package.nix index e7a08510ca7b12..45208fa3539964 100644 --- a/pkgs/by-name/tm/tm/package.nix +++ b/pkgs/by-name/tm/tm/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/tm/tmate-ssh-server/package.nix b/pkgs/by-name/tm/tmate-ssh-server/package.nix index 09cd26090e1499..9023cb1a48c95c 100644 --- a/pkgs/by-name/tm/tmate-ssh-server/package.nix +++ b/pkgs/by-name/tm/tmate-ssh-server/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, cmake -, libtool -, pkg-config -, zlib -, openssl -, libevent -, ncurses -, ruby -, msgpack-c -, libssh -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + cmake, + libtool, + pkg-config, + zlib, + openssl, + libevent, + ncurses, + ruby, + msgpack-c, + libssh, + nixosTests, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/tm/tmate/package.nix b/pkgs/by-name/tm/tmate/package.nix index 9e1cbdee127746..6966b5072a6676 100644 --- a/pkgs/by-name/tm/tmate/package.nix +++ b/pkgs/by-name/tm/tmate/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, cmake -, libtool -, pkg-config -, zlib -, openssl -, libevent -, ncurses -, ruby -, msgpack-c -, libssh +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + cmake, + libtool, + pkg-config, + zlib, + openssl, + libevent, + ncurses, + ruby, + msgpack-c, + libssh, }: stdenv.mkDerivation { @@ -19,9 +20,9 @@ stdenv.mkDerivation { version = "unstable-2022-08-07"; src = fetchFromGitHub { - owner = "tmate-io"; - repo = "tmate"; - rev = "ac919516f4f1b10ec928e20b3a5034d18f609d68"; + owner = "tmate-io"; + repo = "tmate"; + rev = "ac919516f4f1b10ec928e20b3a5034d18f609d68"; sha256 = "sha256-t96gfmAMcsjkGf8pvbEx2fNx4Sj3W6oYoQswB3Dklb8="; }; @@ -50,10 +51,10 @@ stdenv.mkDerivation { dontUseCmakeConfigure = true; meta = with lib; { - homepage = "https://tmate.io/"; + homepage = "https://tmate.io/"; description = "Instant Terminal Sharing"; - license = licenses.mit; - platforms = platforms.unix; + license = licenses.mit; + platforms = platforms.unix; maintainers = with maintainers; [ ck3d ]; mainProgram = "tmate"; }; diff --git a/pkgs/by-name/tm/tmatrix/package.nix b/pkgs/by-name/tm/tmatrix/package.nix index 802b20c5557690..478f7222fbae42 100644 --- a/pkgs/by-name/tm/tmatrix/package.nix +++ b/pkgs/by-name/tm/tmatrix/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, installShellFiles -, ncurses +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + installShellFiles, + ncurses, }: stdenv.mkDerivation rec { @@ -17,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-G3dg0SWfBjCA66TTxkVAcVrFNJOWE9+GJXYKzCUX34w="; }; - nativeBuildInputs = [ cmake installShellFiles ]; + nativeBuildInputs = [ + cmake + installShellFiles + ]; buildInputs = [ ncurses ]; postInstall = '' diff --git a/pkgs/by-name/tm/tml/package.nix b/pkgs/by-name/tm/tml/package.nix index 244b2d10adc119..af5d73a405243e 100644 --- a/pkgs/by-name/tm/tml/package.nix +++ b/pkgs/by-name/tm/tml/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-CHZS1SpPko8u3tZAYbf+Di882W55X9Q/zd4SmFCRgKM="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Tiny markup language for terminal output"; diff --git a/pkgs/by-name/tm/tmpi/package.nix b/pkgs/by-name/tm/tmpi/package.nix index f745ce52e74858..ce2430a4ed9b43 100644 --- a/pkgs/by-name/tm/tmpi/package.nix +++ b/pkgs/by-name/tm/tmpi/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, mpi -, mpich -, tmux -, reptyr -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + mpi, + mpich, + tmux, + reptyr, + makeWrapper, }: stdenv.mkDerivation rec { @@ -19,7 +20,12 @@ stdenv.mkDerivation rec { hash = "sha256-BaOaMpsF8ho8EIVuHfu4+CiVV3yLoC3tDkLq4R8BYBA="; }; - propagatedBuildInputs = [ mpi mpich reptyr tmux ]; + propagatedBuildInputs = [ + mpi + mpich + reptyr + tmux + ]; nativeBuildInputs = [ makeWrapper ]; @@ -31,7 +37,14 @@ stdenv.mkDerivation rec { install -m755 tmpi $out/bin/tmpi wrapProgram $out/bin/tmpi \ - --prefix PATH : ${lib.makeBinPath [ mpi mpich tmux reptyr ]} + --prefix PATH : ${ + lib.makeBinPath [ + mpi + mpich + tmux + reptyr + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/tm/tmpmail/package.nix b/pkgs/by-name/tm/tmpmail/package.nix index 55a42eebebd27c..a7fe5fe237da80 100644 --- a/pkgs/by-name/tm/tmpmail/package.nix +++ b/pkgs/by-name/tm/tmpmail/package.nix @@ -1,10 +1,20 @@ -{ lib, fetchFromGitHub, stdenvNoCC, w3m, curl, jq, makeWrapper, installShellFiles, xclip }: +{ + lib, + fetchFromGitHub, + stdenvNoCC, + w3m, + curl, + jq, + makeWrapper, + installShellFiles, + xclip, +}: stdenvNoCC.mkDerivation rec { pname = "tmpmail"; version = "1.2.3"; - src = fetchFromGitHub { + src = fetchFromGitHub { owner = "sdushantha"; repo = "tmpmail"; rev = "v${version}"; @@ -15,16 +25,26 @@ stdenvNoCC.mkDerivation rec { dontBuild = true; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; installPhase = '' mkdir -p $out/bin install -Dm755 -t $out/bin tmpmail installManPage tmpmail.1 - wrapProgram $out/bin/tmpmail --prefix PATH : ${lib.makeBinPath [ w3m curl jq xclip ]} + wrapProgram $out/bin/tmpmail --prefix PATH : ${ + lib.makeBinPath [ + w3m + curl + jq + xclip + ] + } ''; - meta = with lib; { + meta = with lib; { homepage = "https://github.com/sdushantha/tmpmail"; description = "Temporary email right from your terminal written in POSIX sh"; license = licenses.mit; diff --git a/pkgs/by-name/tm/tmpwatch/package.nix b/pkgs/by-name/tm/tmpwatch/package.nix index b5b3510dacf62d..f871cc50ae494a 100644 --- a/pkgs/by-name/tm/tmpwatch/package.nix +++ b/pkgs/by-name/tm/tmpwatch/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, psmisc }: +{ + lib, + stdenv, + fetchurl, + psmisc, +}: stdenv.mkDerivation rec { pname = "tmpwatch"; diff --git a/pkgs/by-name/tm/tmux-cssh/package.nix b/pkgs/by-name/tm/tmux-cssh/package.nix index 031acfff33a120..edaa62c8201ef1 100644 --- a/pkgs/by-name/tm/tmux-cssh/package.nix +++ b/pkgs/by-name/tm/tmux-cssh/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, tmux }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + tmux, +}: stdenv.mkDerivation { pname = "tmux-cssh"; @@ -23,8 +29,7 @@ stdenv.mkDerivation { homepage = "https://github.com/dennishafemann/tmux-cssh"; description = "SSH to multiple hosts at the same time using tmux"; - longDescription = - '' + longDescription = '' tmux is a terminal multiplexer, like e.g. screen, which gives you a possibility to use multiple virtual terminal session within one real terminal session. tmux-cssh (tmux-cluster-ssh) sets a comfortable and @@ -32,7 +37,7 @@ stdenv.mkDerivation { tmux-sessions, on top of tmux. No need for a x-server or x-forwarding. tmux-cssh works just with tmux and in an low-level terminal-environment, like most server do. - ''; + ''; license = lib.licenses.asl20; diff --git a/pkgs/by-name/tm/tmux-mem-cpu-load/package.nix b/pkgs/by-name/tm/tmux-mem-cpu-load/package.nix index 012a18911d406c..53fdc8e1be0fbb 100644 --- a/pkgs/by-name/tm/tmux-mem-cpu-load/package.nix +++ b/pkgs/by-name/tm/tmux-mem-cpu-load/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, cmake }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "tmux-mem-cpu-load"; diff --git a/pkgs/by-name/tm/tmux-xpanes/package.nix b/pkgs/by-name/tm/tmux-xpanes/package.nix index 47fce699fb0c89..0c1825c93a41c9 100644 --- a/pkgs/by-name/tm/tmux-xpanes/package.nix +++ b/pkgs/by-name/tm/tmux-xpanes/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, openssl, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + perl, +}: stdenv.mkDerivation rec { pname = "tmux-xpanes"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-PF2K2A49c5djQqSO7ZLFyBwPZaJRK58qZTFpY7n+Z0w="; }; - buildInputs = [ openssl perl ]; + buildInputs = [ + openssl + perl + ]; installPhase = '' # Create directories. diff --git a/pkgs/by-name/tm/tmux/package.nix b/pkgs/by-name/tm/tmux/package.nix index 64618de25dd376..99c0403e35231a 100644 --- a/pkgs/by-name/tm/tmux/package.nix +++ b/pkgs/by-name/tm/tmux/package.nix @@ -1,17 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, bison -, libevent -, ncurses -, pkg-config -, runCommand -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, systemd -, withUtf8proc ? true, utf8proc # gets Unicode updates faster than glibc -, withUtempter ? stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isMusl, libutempter -, withSixel ? true +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + bison, + libevent, + ncurses, + pkg-config, + runCommand, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + withUtf8proc ? true, + utf8proc, # gets Unicode updates faster than glibc + withUtempter ? stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isMusl, + libutempter, + withSixel ? true, }: let @@ -29,7 +33,10 @@ stdenv.mkDerivation (finalAttrs: { pname = "tmux"; version = "3.5a"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchFromGitHub { owner = "tmux"; @@ -44,43 +51,54 @@ stdenv.mkDerivation (finalAttrs: { bison ]; - buildInputs = [ - ncurses - libevent - ] ++ lib.optionals withSystemd [ systemd ] - ++ lib.optionals withUtf8proc [ utf8proc ] - ++ lib.optionals withUtempter [ libutempter ]; + buildInputs = + [ + ncurses + libevent + ] + ++ lib.optionals withSystemd [ systemd ] + ++ lib.optionals withUtf8proc [ utf8proc ] + ++ lib.optionals withUtempter [ libutempter ]; - configureFlags = [ - "--sysconfdir=/etc" - "--localstatedir=/var" - ] ++ lib.optionals withSystemd [ "--enable-systemd" ] - ++ lib.optionals withSixel [ "--enable-sixel" ] - ++ lib.optionals withUtempter [ "--enable-utempter" ] - ++ lib.optionals withUtf8proc [ "--enable-utf8proc" ]; + configureFlags = + [ + "--sysconfdir=/etc" + "--localstatedir=/var" + ] + ++ lib.optionals withSystemd [ "--enable-systemd" ] + ++ lib.optionals withSixel [ "--enable-sixel" ] + ++ lib.optionals withUtempter [ "--enable-utempter" ] + ++ lib.optionals withUtf8proc [ "--enable-utf8proc" ]; enableParallelBuilding = true; - postInstall = '' - mkdir -p $out/share/bash-completion/completions - cp -v ${bashCompletion}/completions/tmux $out/share/bash-completion/completions/tmux - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir $out/nix-support - echo "${finalAttrs.passthru.terminfo}" >> $out/nix-support/propagated-user-env-packages - ''; + postInstall = + '' + mkdir -p $out/share/bash-completion/completions + cp -v ${bashCompletion}/completions/tmux $out/share/bash-completion/completions/tmux + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir $out/nix-support + echo "${finalAttrs.passthru.terminfo}" >> $out/nix-support/propagated-user-env-packages + ''; passthru = { - terminfo = runCommand "tmux-terminfo" { nativeBuildInputs = [ ncurses ]; } (if stdenv.hostPlatform.isDarwin then '' - mkdir -p $out/share/terminfo/74 - cp -v ${ncurses}/share/terminfo/74/tmux $out/share/terminfo/74 - # macOS ships an old version (5.7) of ncurses which does not include tmux-256color so we need to provide it from our ncurses. - # However, due to a bug in ncurses 5.7, we need to first patch the terminfo before we can use it with macOS. - # https://gpanders.com/blog/the-definitive-guide-to-using-tmux-256color-on-macos/ - tic -o $out/share/terminfo -x <(TERMINFO_DIRS=${ncurses}/share/terminfo infocmp -x tmux-256color | sed 's|pairs#0x10000|pairs#32767|') - '' else '' - mkdir -p $out/share/terminfo/t - ln -sv ${ncurses}/share/terminfo/t/{tmux,tmux-256color,tmux-direct} $out/share/terminfo/t - ''); + terminfo = runCommand "tmux-terminfo" { nativeBuildInputs = [ ncurses ]; } ( + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p $out/share/terminfo/74 + cp -v ${ncurses}/share/terminfo/74/tmux $out/share/terminfo/74 + # macOS ships an old version (5.7) of ncurses which does not include tmux-256color so we need to provide it from our ncurses. + # However, due to a bug in ncurses 5.7, we need to first patch the terminfo before we can use it with macOS. + # https://gpanders.com/blog/the-definitive-guide-to-using-tmux-256color-on-macos/ + tic -o $out/share/terminfo -x <(TERMINFO_DIRS=${ncurses}/share/terminfo infocmp -x tmux-256color | sed 's|pairs#0x10000|pairs#32767|') + '' + else + '' + mkdir -p $out/share/terminfo/t + ln -sv ${ncurses}/share/terminfo/t/{tmux,tmux-256color,tmux-direct} $out/share/terminfo/t + '' + ); }; meta = { @@ -102,6 +120,9 @@ stdenv.mkDerivation (finalAttrs: { license = lib.licenses.bsd3; platforms = lib.platforms.unix; mainProgram = "tmux"; - maintainers = with lib.maintainers; [ thammers fpletz ]; + maintainers = with lib.maintainers; [ + thammers + fpletz + ]; }; }) diff --git a/pkgs/by-name/tm/tmuxifier/package.nix b/pkgs/by-name/tm/tmuxifier/package.nix index ef0be1687f43b2..a92d54c7e92b4e 100644 --- a/pkgs/by-name/tm/tmuxifier/package.nix +++ b/pkgs/by-name/tm/tmuxifier/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "tmuxifier"; diff --git a/pkgs/by-name/tn/tnat64/package.nix b/pkgs/by-name/tn/tnat64/package.nix index d22f2b98efd6a2..7cc0d998c408c5 100644 --- a/pkgs/by-name/tn/tnat64/package.nix +++ b/pkgs/by-name/tn/tnat64/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "tnat64"; diff --git a/pkgs/by-name/tn/tncattach/package.nix b/pkgs/by-name/tn/tncattach/package.nix index c536112e63a97d..bc46515c44d038 100644 --- a/pkgs/by-name/tn/tncattach/package.nix +++ b/pkgs/by-name/tn/tncattach/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "tncattach"; diff --git a/pkgs/by-name/tn/tnef/package.nix b/pkgs/by-name/tn/tnef/package.nix index 4c4b67adf96d49..699887888bb9c0 100644 --- a/pkgs/by-name/tn/tnef/package.nix +++ b/pkgs/by-name/tn/tnef/package.nix @@ -1,13 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { version = "1.4.18"; pname = "tnef"; src = fetchFromGitHub { - owner = "verdammelt"; - repo = "tnef"; - rev = version; + owner = "verdammelt"; + repo = "tnef"; + rev = version; sha256 = "104g48mcm00bgiyzas2vf86331w7bnw7h3bc11ib4lp7rz6zqfck"; }; diff --git a/pkgs/by-name/tn/tnt/package.nix b/pkgs/by-name/tn/tnt/package.nix index f4787271c039cd..a2accb895dcd3c 100644 --- a/pkgs/by-name/tn/tnt/package.nix +++ b/pkgs/by-name/tn/tnt/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, unzip}: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation { pname = "tnt"; @@ -12,8 +17,8 @@ stdenv.mkDerivation { nativeBuildInputs = [ unzip ]; installPhase = '' - mkdir -p $out/include - cp *.h $out/include + mkdir -p $out/include + cp *.h $out/include ''; meta = { diff --git a/pkgs/by-name/tn/tntdb/package.nix b/pkgs/by-name/tn/tntdb/package.nix index 9080893d5e4419..a3192d6c2b8cf0 100644 --- a/pkgs/by-name/tn/tntdb/package.nix +++ b/pkgs/by-name/tn/tntdb/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, cxxtools -, postgresql -, libmysqlclient -, sqlite -, zlib -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + cxxtools, + postgresql, + libmysqlclient, + sqlite, + zlib, + openssl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/tn/tntnet/package.nix b/pkgs/by-name/tn/tntnet/package.nix index 03e8558a0c1ee7..2e69aca6bf2ad8 100644 --- a/pkgs/by-name/tn/tntnet/package.nix +++ b/pkgs/by-name/tn/tntnet/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, cxxtools -, zlib -, openssl -, zip +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + cxxtools, + zlib, + openssl, + zip, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/to/to-html/package.nix b/pkgs/by-name/to/to-html/package.nix index cfa80570f50c3e..1d5aeee4dba1ec 100644 --- a/pkgs/by-name/to/to-html/package.nix +++ b/pkgs/by-name/to/to-html/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, installShellFiles -, rustPlatform +{ + lib, + fetchFromGitHub, + installShellFiles, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/to/toast/package.nix b/pkgs/by-name/to/toast/package.nix index a7fa40f035b157..783098ee8be825 100644 --- a/pkgs/by-name/to/toast/package.nix +++ b/pkgs/by-name/to/toast/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/to/tockloader/package.nix b/pkgs/by-name/to/tockloader/package.nix index 90cf25e54772a5..6fcdded82dc5c8 100644 --- a/pkgs/by-name/to/tockloader/package.nix +++ b/pkgs/by-name/to/tockloader/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { @@ -39,4 +40,3 @@ python3.pkgs.buildPythonApplication rec { maintainers = [ ]; }; } - diff --git a/pkgs/by-name/to/todiff/package.nix b/pkgs/by-name/to/todiff/package.nix index b3df5f48e8591e..08af4224fd1ea7 100644 --- a/pkgs/by-name/to/todiff/package.nix +++ b/pkgs/by-name/to/todiff/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "todiff"; diff --git a/pkgs/by-name/to/todo-txt-cli/package.nix b/pkgs/by-name/to/todo-txt-cli/package.nix index fbeea839962785..926264480beb90 100644 --- a/pkgs/by-name/to/todo-txt-cli/package.nix +++ b/pkgs/by-name/to/todo-txt-cli/package.nix @@ -1,7 +1,12 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let version = "2.12.0"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "todo.txt-cli"; inherit version; diff --git a/pkgs/by-name/to/todo/package.nix b/pkgs/by-name/to/todo/package.nix index 4f5789527ae644..222eef329a7d48 100644 --- a/pkgs/by-name/to/todo/package.nix +++ b/pkgs/by-name/to/todo/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, pkg-config, openssl }: +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, +}: rustPlatform.buildRustPackage rec { pname = "todo"; diff --git a/pkgs/by-name/to/todofi-sh/package.nix b/pkgs/by-name/to/todofi-sh/package.nix index 5581c3d4f7dc4e..b00b94bfcd08fc 100644 --- a/pkgs/by-name/to/todofi-sh/package.nix +++ b/pkgs/by-name/to/todofi-sh/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, coreutils -, gawk -, gnugrep -, gnused -, rofi -, todo-txt-cli +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + coreutils, + gawk, + gnugrep, + gnused, + rofi, + todo-txt-cli, }: stdenv.mkDerivation rec { @@ -29,7 +30,16 @@ stdenv.mkDerivation rec { postFixup = '' patchShebangs $out/bin - wrapProgram $out/bin/todofi.sh --prefix PATH : "${lib.makeBinPath [ coreutils gawk gnugrep gnused rofi todo-txt-cli ]}" + wrapProgram $out/bin/todofi.sh --prefix PATH : "${ + lib.makeBinPath [ + coreutils + gawk + gnugrep + gnused + rofi + todo-txt-cli + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/to/todoist-electron/package.nix b/pkgs/by-name/to/todoist-electron/package.nix index b706ff58ca46b1..5c00493166f877 100644 --- a/pkgs/by-name/to/todoist-electron/package.nix +++ b/pkgs/by-name/to/todoist-electron/package.nix @@ -1,4 +1,10 @@ -{ lib, appimageTools, fetchurl, asar }: let +{ + lib, + appimageTools, + fetchurl, + asar, +}: +let pname = "todoist-electron"; version = "9.8.0"; @@ -18,7 +24,8 @@ ''; }); -in appimageTools.wrapAppImage { +in +appimageTools.wrapAppImage { inherit pname version; src = appimageContents; @@ -37,7 +44,10 @@ in appimageTools.wrapAppImage { description = "Official Todoist electron app"; platforms = [ "x86_64-linux" ]; license = licenses.unfree; - maintainers = with maintainers; [ kylesferrazza pokon548 ]; + maintainers = with maintainers; [ + kylesferrazza + pokon548 + ]; mainProgram = "todoist-electron"; }; } diff --git a/pkgs/by-name/to/todoist/package.nix b/pkgs/by-name/to/todoist/package.nix index 0145644de14f39..5f2ab9b20a8803 100644 --- a/pkgs/by-name/to/todoist/package.nix +++ b/pkgs/by-name/to/todoist/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "todoist"; diff --git a/pkgs/by-name/to/tofi/package.nix b/pkgs/by-name/to/tofi/package.nix index c501c7acb5737c..36833e6b807580 100644 --- a/pkgs/by-name/to/tofi/package.nix +++ b/pkgs/by-name/to/tofi/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, ninja -, meson -, scdoc -, wayland-protocols -, wayland-scanner -, freetype -, harfbuzz -, cairo -, pango -, wayland -, libxkbcommon +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + ninja, + meson, + scdoc, + wayland-protocols, + wayland-scanner, + freetype, + harfbuzz, + cairo, + pango, + wayland, + libxkbcommon, }: stdenv.mkDerivation rec { @@ -35,7 +36,14 @@ stdenv.mkDerivation rec { wayland-protocols wayland-scanner ]; - buildInputs = [ freetype harfbuzz cairo pango wayland libxkbcommon ]; + buildInputs = [ + freetype + harfbuzz + cairo + pango + wayland + libxkbcommon + ]; meta = with lib; { description = "Tiny dynamic menu for Wayland"; diff --git a/pkgs/by-name/to/toilet/package.nix b/pkgs/by-name/to/toilet/package.nix index 8e5d51da1add95..42d0b343a69d76 100644 --- a/pkgs/by-name/to/toilet/package.nix +++ b/pkgs/by-name/to/toilet/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, libcaca, toilet, testers }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libcaca, + toilet, + testers, +}: stdenv.mkDerivation rec { pname = "toilet"; diff --git a/pkgs/by-name/to/toipe/package.nix b/pkgs/by-name/to/toipe/package.nix index 32e8825239f2ae..e90142608042ac 100644 --- a/pkgs/by-name/to/toipe/package.nix +++ b/pkgs/by-name/to/toipe/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchCrate, rustPlatform }: +{ + lib, + fetchCrate, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "toipe"; @@ -15,6 +19,9 @@ rustPlatform.buildRustPackage rec { description = "Trusty terminal typing tester"; homepage = "https://github.com/Samyak2/toipe"; license = licenses.mit; - maintainers = with maintainers; [ loicreynier samyak ]; + maintainers = with maintainers; [ + loicreynier + samyak + ]; }; } diff --git a/pkgs/by-name/to/tokio-console/package.nix b/pkgs/by-name/to/tokio-console/package.nix index 00067f8335d46c..98c2707f0d3245 100644 --- a/pkgs/by-name/to/tokio-console/package.nix +++ b/pkgs/by-name/to/tokio-console/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, installShellFiles -, rustPlatform -, protobuf -, stdenv +{ + lib, + fetchFromGitHub, + installShellFiles, + rustPlatform, + protobuf, + stdenv, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/to/tokyocabinet/package.nix b/pkgs/by-name/to/tokyocabinet/package.nix index b3b50ae29b18c7..4ada662d6bf1ab 100644 --- a/pkgs/by-name/to/tokyocabinet/package.nix +++ b/pkgs/by-name/to/tokyocabinet/package.nix @@ -1,4 +1,10 @@ -{ fetchurl, lib, stdenv, zlib, bzip2 }: +{ + fetchurl, + lib, + stdenv, + zlib, + bzip2, +}: stdenv.mkDerivation rec { pname = "tokyocabinet"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "140zvr0n8kvsl0fbn2qn3f2kh3yynfwnizn4dgbj47m975yg80x0"; }; - buildInputs = [ zlib bzip2 ]; + buildInputs = [ + zlib + bzip2 + ]; postInstall = '' sed -i "$out/lib/pkgconfig/tokyocabinet.pc" \ diff --git a/pkgs/by-name/to/tokyotyrant/package.nix b/pkgs/by-name/to/tokyotyrant/package.nix index 2c78c15d87aed5..b82d761db15895 100644 --- a/pkgs/by-name/to/tokyotyrant/package.nix +++ b/pkgs/by-name/to/tokyotyrant/package.nix @@ -1,4 +1,10 @@ -{ fetchurl, lib, stdenv, tokyocabinet, pkg-config }: +{ + fetchurl, + lib, + stdenv, + tokyocabinet, + pkg-config, +}: stdenv.mkDerivation rec { pname = "tokyotyrant"; @@ -18,19 +24,19 @@ stdenv.mkDerivation rec { description = "Network interface of the Tokyo Cabinet DBM"; longDescription = '' - Tokyo Tyrant is a package of network interface to the DBM called - Tokyo Cabinet. Though the DBM has high performance, you might - bother in case that multiple processes share the same database, or - remote processes access the database. Thus, Tokyo Tyrant is - provided for concurrent and remote connections to Tokyo Cabinet. It - is composed of the server process managing a database and its access - library for client applications. - - Tokyo Tyrant is written in the C language, and provided as API of C, - Perl, and Ruby. Tokyo Tyrant is available on platforms which have - API conforming to C99 and POSIX. Tokyo Tyrant is a free software - licensed under the GNU Lesser General Public License. - ''; + Tokyo Tyrant is a package of network interface to the DBM called + Tokyo Cabinet. Though the DBM has high performance, you might + bother in case that multiple processes share the same database, or + remote processes access the database. Thus, Tokyo Tyrant is + provided for concurrent and remote connections to Tokyo Cabinet. It + is composed of the server process managing a database and its access + library for client applications. + + Tokyo Tyrant is written in the C language, and provided as API of C, + Perl, and Ruby. Tokyo Tyrant is available on platforms which have + API conforming to C99 and POSIX. Tokyo Tyrant is a free software + licensed under the GNU Lesser General Public License. + ''; homepage = "https://fallabs.com/tokyotyrant/"; diff --git a/pkgs/by-name/to/tomcat_mysql_jdbc/package.nix b/pkgs/by-name/to/tomcat_mysql_jdbc/package.nix index 9e6f346a0ec4b6..d45f4414ab96f4 100644 --- a/pkgs/by-name/to/tomcat_mysql_jdbc/package.nix +++ b/pkgs/by-name/to/tomcat_mysql_jdbc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, mysql_jdbc }: +{ + lib, + stdenv, + mysql_jdbc, +}: stdenv.mkDerivation { pname = "tomcat-mysql-jdbc"; diff --git a/pkgs/by-name/to/tome2/package.nix b/pkgs/by-name/to/tome2/package.nix index 3440e183515cbb..7d054543c26be7 100644 --- a/pkgs/by-name/to/tome2/package.nix +++ b/pkgs/by-name/to/tome2/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, makeDesktopItem, ncurses, libX11, boost, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + makeDesktopItem, + ncurses, + libX11, + boost, + cmake, +}: let pname = "tome2"; @@ -11,11 +20,15 @@ let icon = pname; comment = description; type = "Application"; - categories = [ "Game" "RolePlaying" ]; + categories = [ + "Game" + "RolePlaying" + ]; genericName = pname; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname; version = "2.4"; @@ -26,7 +39,11 @@ in stdenv.mkDerivation { sha256 = "06bddj55y673d7bnzblk8n01z32l6k2rad3bpzr8dmw464hx4wwf"; }; - buildInputs = [ ncurses libX11 boost ]; + buildInputs = [ + ncurses + libX11 + boost + ]; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/by-name/to/tome4/package.nix b/pkgs/by-name/to/tome4/package.nix index ffb52b01e29163..b65139f8a37413 100644 --- a/pkgs/by-name/to/tome4/package.nix +++ b/pkgs/by-name/to/tome4/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchurl, makeDesktopItem, makeWrapper, premake4, unzip -, openal, libpng, libvorbis, libGLU, SDL2, SDL2_image, SDL2_ttf }: +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + makeWrapper, + premake4, + unzip, + openal, + libpng, + libvorbis, + libGLU, + SDL2, + SDL2_image, + SDL2_ttf, +}: stdenv.mkDerivation rec { pname = "tome4"; @@ -17,7 +31,10 @@ stdenv.mkDerivation rec { icon = pname; comment = "An open-source, single-player, role-playing roguelike game set in the world of Eyal."; type = "Application"; - categories = [ "Game" "RolePlaying" ]; + categories = [ + "Game" + "RolePlaying" + ]; genericName = pname; }; @@ -26,12 +43,22 @@ stdenv.mkDerivation rec { sed -i 's|#include ||' src/tgl.h ''; - nativeBuildInputs = [ makeWrapper unzip premake4 ]; + nativeBuildInputs = [ + makeWrapper + unzip + premake4 + ]; # tome4 vendors quite a few libraries so someone might want to look # into avoiding that... buildInputs = [ - libGLU openal libpng libvorbis SDL2 SDL2_ttf SDL2_image + libGLU + openal + libpng + libvorbis + SDL2 + SDL2_ttf + SDL2_image ]; # disable parallel building as it caused sporadic build failures @@ -72,6 +99,9 @@ stdenv.mkDerivation rec { homepage = "https://te4.org/"; license = licenses.gpl3; maintainers = with maintainers; [ peterhoeg ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/to/toml-cli/package.nix b/pkgs/by-name/to/toml-cli/package.nix index 738e6deba14124..8cb7aacce5cb3a 100644 --- a/pkgs/by-name/to/toml-cli/package.nix +++ b/pkgs/by-name/to/toml-cli/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchCrate, rustPlatform, testers, toml-cli }: +{ + lib, + fetchCrate, + rustPlatform, + testers, + toml-cli, +}: rustPlatform.buildRustPackage rec { pname = "toml-cli"; diff --git a/pkgs/by-name/to/toml-f/package.nix b/pkgs/by-name/to/toml-f/package.nix index 30632e1160db8d..74f0574f1bbde3 100644 --- a/pkgs/by-name/to/toml-f/package.nix +++ b/pkgs/by-name/to/toml-f/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, gfortran -, meson -, ninja -, pkg-config -, test-drive +{ + stdenv, + lib, + fetchFromGitHub, + gfortran, + meson, + ninja, + pkg-config, + test-drive, }: stdenv.mkDerivation rec { @@ -19,18 +20,29 @@ stdenv.mkDerivation rec { hash = "sha256-+cac4rUNpd2w3yBdH1XoCKdJ9IgOHZioZg8AhzGY0FE="; }; - nativeBuildInputs = [ gfortran meson ninja pkg-config ]; + nativeBuildInputs = [ + gfortran + meson + ninja + pkg-config + ]; buildInputs = [ test-drive ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; # tftest-build fails on aarch64-linux doCheck = !stdenv.hostPlatform.isAarch64; meta = with lib; { description = "TOML parser implementation for data serialization and deserialization in Fortran"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; homepage = "https://github.com/toml-f/toml-f"; platforms = platforms.linux; maintainers = [ maintainers.sheepforce ]; diff --git a/pkgs/by-name/to/toml2json/package.nix b/pkgs/by-name/to/toml2json/package.nix index 6d7a8dcf6a3603..5ab7cf5a592e0d 100644 --- a/pkgs/by-name/to/toml2json/package.nix +++ b/pkgs/by-name/to/toml2json/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "toml2json"; diff --git a/pkgs/by-name/to/toml2nix/package.nix b/pkgs/by-name/to/toml2nix/package.nix index b34f40933b767d..d173ad659d4b37 100644 --- a/pkgs/by-name/to/toml2nix/package.nix +++ b/pkgs/by-name/to/toml2nix/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchCrate }: +{ + lib, + rustPlatform, + fetchCrate, +}: rustPlatform.buildRustPackage rec { pname = "toml2nix"; @@ -19,7 +23,10 @@ rustPlatform.buildRustPackage rec { description = "Tool to convert TOML files to Nix expressions"; mainProgram = "toml2nix"; homepage = "https://crates.io/crates/toml2nix"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/to/tomlc99/package.nix b/pkgs/by-name/to/tomlc99/package.nix index 2790e94b7c0dc7..5b38094432a208 100644 --- a/pkgs/by-name/to/tomlc99/package.nix +++ b/pkgs/by-name/to/tomlc99/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/to/tomlcpp/package.nix b/pkgs/by-name/to/tomlcpp/package.nix index 6f77fe1cc763e8..b98b9c6198e80e 100644 --- a/pkgs/by-name/to/tomlcpp/package.nix +++ b/pkgs/by-name/to/tomlcpp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "tomlcpp"; diff --git a/pkgs/by-name/to/ton/package.nix b/pkgs/by-name/to/ton/package.nix index bccdd713aaffd8..22a34bdcc2005e 100644 --- a/pkgs/by-name/to/ton/package.nix +++ b/pkgs/by-name/to/ton/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, git -, pkg-config -, gperf -, libmicrohttpd -, libsodium -, lz4 -, openssl -, readline -, secp256k1 -, zlib -, nix-update-script -, darwinMinVersionHook -, apple-sdk_11 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + git, + pkg-config, + gperf, + libmicrohttpd, + libsodium, + lz4, + openssl, + readline, + secp256k1, + zlib, + nix-update-script, + darwinMinVersionHook, + apple-sdk_11, }: stdenv.mkDerivation rec { @@ -29,7 +30,10 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake @@ -37,20 +41,22 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - gperf - libmicrohttpd - libsodium - lz4 - openssl - readline - secp256k1 - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # error: aligned allocation function of type 'void *(std::size_t, std::align_val_t)' is only available on macOS 10.13 or newer - (darwinMinVersionHook "10.13") - apple-sdk_11 - ]; + buildInputs = + [ + gperf + libmicrohttpd + libsodium + lz4 + openssl + readline + secp256k1 + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # error: aligned allocation function of type 'void *(std::size_t, std::align_val_t)' is only available on macOS 10.13 or newer + (darwinMinVersionHook "10.13") + apple-sdk_11 + ]; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/by-name/to/tone/nuget-deps.nix b/pkgs/by-name/to/tone/nuget-deps.nix index 1af0d0ab91accf..9378473b4a7d45 100644 --- a/pkgs/by-name/to/tone/nuget-deps.nix +++ b/pkgs/by-name/to/tone/nuget-deps.nix @@ -1,54 +1,251 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "CliWrap"; version = "3.6.0"; sha256 = "0x96awy81kn0dr8h5d376cgfzxg5bvmzd610rc017nliv152zkw2"; }) - (fetchNuGet { pname = "CSharp.OperationResult"; version = "0.1.6"; sha256 = "127hjd30vvcks977yxxh59g89dbsf7h1khcr1vignrgk9fanvzyi"; }) - (fetchNuGet { pname = "Esprima"; version = "3.0.0-beta-9"; sha256 = "1gwdi537832z5whyqx58474ys2akgmrkabm51sy7725c91814snz"; }) - (fetchNuGet { pname = "grok.net"; version = "1.1.0"; sha256 = "01vm1b658dwxcxp1l4cpsplg8pwpmbs6v6fbqwg1lvrm7li9bgjz"; }) - (fetchNuGet { pname = "Jint"; version = "3.0.0-beta-2044"; sha256 = "0sy0qy33gn54sszhq4dkiihxd224n58xhcxg46qi4p3i93qn3snl"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "7.0.0"; sha256 = "0n1grglxql9llmrsbbnlz5chx8mxrb5cpvjngm0hfyrkgzcwz90d"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "7.0.0"; sha256 = "1as8cygz0pagg17w22nsf6mb49lr2mcl1x8i3ad1wi8lyzygy1a3"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "2.0.0"; sha256 = "1prvdbma6r18n5agbhhabv6g357p1j70gq4m9g0vs859kf44nrgc"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "7.0.0"; sha256 = "1qifb1pv7s76lih8wnjk418wdk4qwn87q2n6dx54knfvxai410bl"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; version = "7.0.0"; sha256 = "0nhh7rnh45s39x8sjn88czg7nyfpry85pkm0g619j8b468zj8nb4"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.FileExtensions"; version = "7.0.0"; sha256 = "1fk7dcz6gfhd1k1d8ksz22rnjvj1waqjzk29ym4i3dz73rsq8j1i"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Json"; version = "7.0.0"; sha256 = "05zjmrpp99l128wijp1fy8asskc11ls871qaqr4mjnz3gbfycxnj"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "7.0.0"; sha256 = "121zs4jp8iimgbpzm3wsglhjwkc06irg1pxy8c1zcdlsg34cfq1p"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "2.0.0"; sha256 = "1pwrfh9b72k9rq6mb2jab5qhhi225d5rjalzkapiayggmygc8nhz"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "7.0.0"; sha256 = "181d7mp9307fs17lyy42f8cxnjwysddmpsalky4m0pqxcimnr6g7"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyModel"; version = "3.0.0"; sha256 = "1cm0hycgb33mf1ja9q91wxi3gk13d1p462gdq7gndrya23hw2jm5"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "7.0.0"; sha256 = "0ff20yklyjgyjzdyv7sybczgqhgd557m05dbwxzjznr0x41b180d"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Physical"; version = "7.0.0"; sha256 = "1f1h0l47abw0spssd64qkhgd7b54pyzslyb586zp21milimcfmgv"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileSystemGlobbing"; version = "7.0.0"; sha256 = "1812vnkn8n0i4yr3k5azcxcfx1bbpcsmms95rdyxjfrzfksr05ai"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "2.0.0"; sha256 = "1jkwjcq1ld9znz1haazk8ili2g4pzfdp6i7r7rki4hg3jcadn386"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "2.0.0"; sha256 = "1x5isi71z02khikzvm7vaschb006pqqrsv86ky1x08a4hir4s43h"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "2.0.0"; sha256 = "0g4zadlg73f507krilhaaa7h0jdga216syrzjlyf5fdk25gxmjqh"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "7.0.0"; sha256 = "0b90zkrsk5dw3wr749rbynhpxlg4bgqdnd7d5vdlw2g9c7zlhgx6"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; version = "7.0.0"; sha256 = "1liyprh0zha2vgmqh92n8kkjz61zwhr7g16f0gmr297z2rg1j5pj"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "2.0.0"; sha256 = "1xppr5jbny04slyjgngxjdm0maxdh47vq481ps944d7jrfs0p3mb"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "7.0.0"; sha256 = "1b4km9fszid9vp2zb3gya5ni9fn8bq62bzaas2ck2r7gs0sdys80"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.2"; sha256 = "1p9splg1min274dpz7xdfgzrwkyfd3xlkygwpr1xgjvvyjvs6b0i"; }) - (fetchNuGet { pname = "Sandreas.AudioMetadata"; version = "0.1.1"; sha256 = "11ibv23h7qj5qshibmlsqmjca51dqbhib9p1gz66c5kqhk7ci38j"; }) - (fetchNuGet { pname = "Sandreas.Files"; version = "1.1.2"; sha256 = "08qk229q2y1dpdxdnp8xi9mgk8fgpjxrxm4z6ak8n09npp67nhn0"; }) - (fetchNuGet { pname = "Sandreas.SpectreConsoleHelpers"; version = "0.0.2"; sha256 = "1vy2fka11n0smgrbwdxabl6cdcsg6fv1gymxrws8m0sf9qm64nd1"; }) - (fetchNuGet { pname = "Serilog"; version = "2.12.0"; sha256 = "0lqxpc96qcjkv9pr1rln7mi4y7n7jdi4vb36c2fv3845w1vswgr4"; }) - (fetchNuGet { pname = "Serilog.Extensions.Logging"; version = "3.1.0"; sha256 = "0lv370ks2fjdn1nsgkbzbmw6hybnincw3jabr471a5w39pp4fl1c"; }) - (fetchNuGet { pname = "Serilog.Settings.Configuration"; version = "3.4.0"; sha256 = "1l6fyy9y5a168i1mm107aqyrwzhqmpy0cp1v13l2b89yv8dc105j"; }) - (fetchNuGet { pname = "Serilog.Sinks.Console"; version = "4.1.0"; sha256 = "1rpkphmqfh3bv3m7v1zwz88wz4sirj4xqyff9ga0c6bqhblj6wii"; }) - (fetchNuGet { pname = "Serilog.Sinks.File"; version = "5.0.0"; sha256 = "097rngmgcrdfy7jy8j7dq3xaq2qky8ijwg0ws6bfv5lx0f3vvb0q"; }) - (fetchNuGet { pname = "Spectre.Console"; version = "0.46.0"; sha256 = "1fr7090f2s7q9cw1k25m439blgicsbgl9k5nhqql9xvp0b00s4n9"; }) - (fetchNuGet { pname = "Spectre.Console.Cli"; version = "0.46.0"; sha256 = "00clv0mw97z8a9r7zam97prdv4ich33m4dhi7v8mjdqwwhj6q4jr"; }) - (fetchNuGet { pname = "System.IO.Abstractions"; version = "19.0.1"; sha256 = "16dasj8bwsdyl5phgqgfgswkbghzdb3sq7sidigr3b5ykna6n96g"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.5"; sha256 = "08jsfwimcarfzrhlyvjjid61j02irx6xsklf32rv57x2aaikvx0h"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.4.0"; sha256 = "0a6ahgi5b148sl5qyfpyw383p3cb4yrkm802k29fsi4mxkiwir29"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "7.0.0"; sha256 = "1151hbyrcf8kyg1jz8k9awpbic98lwz9x129rg7zk1wrs6vjlpxl"; }) - (fetchNuGet { pname = "System.Text.Json"; version = "4.6.0"; sha256 = "0ism236hwi0k6axssfq58s1d8lihplwiz058pdvl8al71hagri39"; }) - (fetchNuGet { pname = "System.Text.Json"; version = "7.0.0"; sha256 = "0scb0lp7wbgcinaa4kqiqs7b8i5nx4ppfad81138jiwd1sl37pyp"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; sha256 = "0y6ncasgfcgnjrhynaf0lwpkpkmv4a07sswwkwbwb5h7riisj153"; }) - (fetchNuGet { pname = "TestableIO.System.IO.Abstractions"; version = "19.0.1"; sha256 = "01v2wgb6y2z7df4b2dsy0jb4hnhpv5kgyxypzyqdk7h6plad2axd"; }) - (fetchNuGet { pname = "TestableIO.System.IO.Abstractions.Wrappers"; version = "19.0.1"; sha256 = "1ms8wqar5w3z2y2qgxii9pqnsb4f1aikji2vaw01zxvnh2wry42n"; }) - (fetchNuGet { pname = "Ude.NetStandard"; version = "1.2.0"; sha256 = "074yff6g272zpkhk0zvmbfiaaxyp3b05fl24i7ffp2jf9r8bnfpl"; }) - (fetchNuGet { pname = "z440.atl.core"; version = "4.19.0"; sha256 = "16290hcf42yhs69ymjrg2znk7s56nnp4hj8rqwi1i8rdajmfr2v1"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "CliWrap"; + version = "3.6.0"; + sha256 = "0x96awy81kn0dr8h5d376cgfzxg5bvmzd610rc017nliv152zkw2"; + }) + (fetchNuGet { + pname = "CSharp.OperationResult"; + version = "0.1.6"; + sha256 = "127hjd30vvcks977yxxh59g89dbsf7h1khcr1vignrgk9fanvzyi"; + }) + (fetchNuGet { + pname = "Esprima"; + version = "3.0.0-beta-9"; + sha256 = "1gwdi537832z5whyqx58474ys2akgmrkabm51sy7725c91814snz"; + }) + (fetchNuGet { + pname = "grok.net"; + version = "1.1.0"; + sha256 = "01vm1b658dwxcxp1l4cpsplg8pwpmbs6v6fbqwg1lvrm7li9bgjz"; + }) + (fetchNuGet { + pname = "Jint"; + version = "3.0.0-beta-2044"; + sha256 = "0sy0qy33gn54sszhq4dkiihxd224n58xhcxg46qi4p3i93qn3snl"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "7.0.0"; + sha256 = "0n1grglxql9llmrsbbnlz5chx8mxrb5cpvjngm0hfyrkgzcwz90d"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "7.0.0"; + sha256 = "1as8cygz0pagg17w22nsf6mb49lr2mcl1x8i3ad1wi8lyzygy1a3"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "2.0.0"; + sha256 = "1prvdbma6r18n5agbhhabv6g357p1j70gq4m9g0vs859kf44nrgc"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "7.0.0"; + sha256 = "1qifb1pv7s76lih8wnjk418wdk4qwn87q2n6dx54knfvxai410bl"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; + version = "7.0.0"; + sha256 = "0nhh7rnh45s39x8sjn88czg7nyfpry85pkm0g619j8b468zj8nb4"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.FileExtensions"; + version = "7.0.0"; + sha256 = "1fk7dcz6gfhd1k1d8ksz22rnjvj1waqjzk29ym4i3dz73rsq8j1i"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Json"; + version = "7.0.0"; + sha256 = "05zjmrpp99l128wijp1fy8asskc11ls871qaqr4mjnz3gbfycxnj"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "7.0.0"; + sha256 = "121zs4jp8iimgbpzm3wsglhjwkc06irg1pxy8c1zcdlsg34cfq1p"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "2.0.0"; + sha256 = "1pwrfh9b72k9rq6mb2jab5qhhi225d5rjalzkapiayggmygc8nhz"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "7.0.0"; + sha256 = "181d7mp9307fs17lyy42f8cxnjwysddmpsalky4m0pqxcimnr6g7"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyModel"; + version = "3.0.0"; + sha256 = "1cm0hycgb33mf1ja9q91wxi3gk13d1p462gdq7gndrya23hw2jm5"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "7.0.0"; + sha256 = "0ff20yklyjgyjzdyv7sybczgqhgd557m05dbwxzjznr0x41b180d"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Physical"; + version = "7.0.0"; + sha256 = "1f1h0l47abw0spssd64qkhgd7b54pyzslyb586zp21milimcfmgv"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileSystemGlobbing"; + version = "7.0.0"; + sha256 = "1812vnkn8n0i4yr3k5azcxcfx1bbpcsmms95rdyxjfrzfksr05ai"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "2.0.0"; + sha256 = "1jkwjcq1ld9znz1haazk8ili2g4pzfdp6i7r7rki4hg3jcadn386"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "2.0.0"; + sha256 = "1x5isi71z02khikzvm7vaschb006pqqrsv86ky1x08a4hir4s43h"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "2.0.0"; + sha256 = "0g4zadlg73f507krilhaaa7h0jdga216syrzjlyf5fdk25gxmjqh"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "7.0.0"; + sha256 = "0b90zkrsk5dw3wr749rbynhpxlg4bgqdnd7d5vdlw2g9c7zlhgx6"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; + version = "7.0.0"; + sha256 = "1liyprh0zha2vgmqh92n8kkjz61zwhr7g16f0gmr297z2rg1j5pj"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "2.0.0"; + sha256 = "1xppr5jbny04slyjgngxjdm0maxdh47vq481ps944d7jrfs0p3mb"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "7.0.0"; + sha256 = "1b4km9fszid9vp2zb3gya5ni9fn8bq62bzaas2ck2r7gs0sdys80"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.2"; + sha256 = "1p9splg1min274dpz7xdfgzrwkyfd3xlkygwpr1xgjvvyjvs6b0i"; + }) + (fetchNuGet { + pname = "Sandreas.AudioMetadata"; + version = "0.1.1"; + sha256 = "11ibv23h7qj5qshibmlsqmjca51dqbhib9p1gz66c5kqhk7ci38j"; + }) + (fetchNuGet { + pname = "Sandreas.Files"; + version = "1.1.2"; + sha256 = "08qk229q2y1dpdxdnp8xi9mgk8fgpjxrxm4z6ak8n09npp67nhn0"; + }) + (fetchNuGet { + pname = "Sandreas.SpectreConsoleHelpers"; + version = "0.0.2"; + sha256 = "1vy2fka11n0smgrbwdxabl6cdcsg6fv1gymxrws8m0sf9qm64nd1"; + }) + (fetchNuGet { + pname = "Serilog"; + version = "2.12.0"; + sha256 = "0lqxpc96qcjkv9pr1rln7mi4y7n7jdi4vb36c2fv3845w1vswgr4"; + }) + (fetchNuGet { + pname = "Serilog.Extensions.Logging"; + version = "3.1.0"; + sha256 = "0lv370ks2fjdn1nsgkbzbmw6hybnincw3jabr471a5w39pp4fl1c"; + }) + (fetchNuGet { + pname = "Serilog.Settings.Configuration"; + version = "3.4.0"; + sha256 = "1l6fyy9y5a168i1mm107aqyrwzhqmpy0cp1v13l2b89yv8dc105j"; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Console"; + version = "4.1.0"; + sha256 = "1rpkphmqfh3bv3m7v1zwz88wz4sirj4xqyff9ga0c6bqhblj6wii"; + }) + (fetchNuGet { + pname = "Serilog.Sinks.File"; + version = "5.0.0"; + sha256 = "097rngmgcrdfy7jy8j7dq3xaq2qky8ijwg0ws6bfv5lx0f3vvb0q"; + }) + (fetchNuGet { + pname = "Spectre.Console"; + version = "0.46.0"; + sha256 = "1fr7090f2s7q9cw1k25m439blgicsbgl9k5nhqql9xvp0b00s4n9"; + }) + (fetchNuGet { + pname = "Spectre.Console.Cli"; + version = "0.46.0"; + sha256 = "00clv0mw97z8a9r7zam97prdv4ich33m4dhi7v8mjdqwwhj6q4jr"; + }) + (fetchNuGet { + pname = "System.IO.Abstractions"; + version = "19.0.1"; + sha256 = "16dasj8bwsdyl5phgqgfgswkbghzdb3sq7sidigr3b5ykna6n96g"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.5"; + sha256 = "08jsfwimcarfzrhlyvjjid61j02irx6xsklf32rv57x2aaikvx0h"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.4.0"; + sha256 = "0a6ahgi5b148sl5qyfpyw383p3cb4yrkm802k29fsi4mxkiwir29"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "7.0.0"; + sha256 = "1151hbyrcf8kyg1jz8k9awpbic98lwz9x129rg7zk1wrs6vjlpxl"; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "4.6.0"; + sha256 = "0ism236hwi0k6axssfq58s1d8lihplwiz058pdvl8al71hagri39"; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "7.0.0"; + sha256 = "0scb0lp7wbgcinaa4kqiqs7b8i5nx4ppfad81138jiwd1sl37pyp"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + sha256 = "0y6ncasgfcgnjrhynaf0lwpkpkmv4a07sswwkwbwb5h7riisj153"; + }) + (fetchNuGet { + pname = "TestableIO.System.IO.Abstractions"; + version = "19.0.1"; + sha256 = "01v2wgb6y2z7df4b2dsy0jb4hnhpv5kgyxypzyqdk7h6plad2axd"; + }) + (fetchNuGet { + pname = "TestableIO.System.IO.Abstractions.Wrappers"; + version = "19.0.1"; + sha256 = "1ms8wqar5w3z2y2qgxii9pqnsb4f1aikji2vaw01zxvnh2wry42n"; + }) + (fetchNuGet { + pname = "Ude.NetStandard"; + version = "1.2.0"; + sha256 = "074yff6g272zpkhk0zvmbfiaaxyp3b05fl24i7ffp2jf9r8bnfpl"; + }) + (fetchNuGet { + pname = "z440.atl.core"; + version = "4.19.0"; + sha256 = "16290hcf42yhs69ymjrg2znk7s56nnp4hj8rqwi1i8rdajmfr2v1"; + }) ] diff --git a/pkgs/by-name/to/tonelib-jam/package.nix b/pkgs/by-name/to/tonelib-jam/package.nix index 293e8885626ae1..9b57192f1e5284 100644 --- a/pkgs/by-name/to/tonelib-jam/package.nix +++ b/pkgs/by-name/to/tonelib-jam/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, dpkg -, alsa-lib -, freetype -, libglvnd -, curl -, libXcursor -, libXinerama -, libXrandr -, libXrender -, libjack2 +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + dpkg, + alsa-lib, + freetype, + libglvnd, + curl, + libXcursor, + libXinerama, + libXrandr, + libXrender, + libjack2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/to/tonelib-zoom/package.nix b/pkgs/by-name/to/tonelib-zoom/package.nix index 9f07141437fe04..223b338a8063fb 100644 --- a/pkgs/by-name/to/tonelib-zoom/package.nix +++ b/pkgs/by-name/to/tonelib-zoom/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, dpkg -, alsa-lib -, freetype -, libglvnd -, curl -, libXcursor -, libXinerama -, libXrandr -, libXrender -, libjack2 -, webkitgtk_4_0 +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + dpkg, + alsa-lib, + freetype, + libglvnd, + curl, + libXcursor, + libXinerama, + libXrandr, + libXrender, + libjack2, + webkitgtk_4_0, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/to/toolbox/package.nix b/pkgs/by-name/to/toolbox/package.nix index 75b7f41c7e78b4..cb2b136ab9c06a 100644 --- a/pkgs/by-name/to/toolbox/package.nix +++ b/pkgs/by-name/to/toolbox/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, glibc, go-md2man, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + glibc, + go-md2man, + installShellFiles, +}: buildGoModule rec { pname = "toolbox"; @@ -21,7 +28,10 @@ buildGoModule rec { modRoot = "src"; - nativeBuildInputs = [ go-md2man installShellFiles ]; + nativeBuildInputs = [ + go-md2man + installShellFiles + ]; ldflags = [ "-s" diff --git a/pkgs/by-name/to/tootik/package.nix b/pkgs/by-name/to/tootik/package.nix index e0577bed57df6a..031464ed5c06ad 100644 --- a/pkgs/by-name/to/tootik/package.nix +++ b/pkgs/by-name/to/tootik/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, openssl }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + openssl, +}: buildGoModule rec { pname = "tootik"; diff --git a/pkgs/by-name/to/top-git/package.nix b/pkgs/by-name/to/top-git/package.nix index 0a5dd908c663fe..77f034c748c3a6 100644 --- a/pkgs/by-name/to/top-git/package.nix +++ b/pkgs/by-name/to/top-git/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, git, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + git, + perl, +}: stdenv.mkDerivation rec { pname = "topgit"; @@ -13,7 +19,10 @@ stdenv.mkDerivation rec { makeFlags = [ "prefix=${placeholder "out"}" ]; - nativeBuildInputs = [ perl git ]; + nativeBuildInputs = [ + perl + git + ]; postInstall = '' install -Dm644 README -t "$out/share/doc/${pname}-${version}/" diff --git a/pkgs/by-name/to/topfew-rs/package.nix b/pkgs/by-name/to/topfew-rs/package.nix index cb3aca7ab53dfb..8a47b04c45d7b5 100644 --- a/pkgs/by-name/to/topfew-rs/package.nix +++ b/pkgs/by-name/to/topfew-rs/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/to/topfew/package.nix b/pkgs/by-name/to/topfew/package.nix index b908d41b6447d9..a4853fda5d23e0 100644 --- a/pkgs/by-name/to/topfew/package.nix +++ b/pkgs/by-name/to/topfew/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -21,7 +22,10 @@ buildGoModule rec { installShellFiles ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' installManPage doc/tf.1 diff --git a/pkgs/by-name/to/topicctl/package.nix b/pkgs/by-name/to/topicctl/package.nix index 1b19b83edc8aac..06f30390937eb6 100644 --- a/pkgs/by-name/to/topicctl/package.nix +++ b/pkgs/by-name/to/topicctl/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "topicctl"; @@ -26,7 +30,10 @@ buildGoModule rec { description = "Tool for easy, declarative management of Kafka topics"; inherit (src.meta) homepage; license = licenses.mit; - maintainers = with maintainers; [ eskytthe srhb ]; + maintainers = with maintainers; [ + eskytthe + srhb + ]; mainProgram = "topicctl"; }; } diff --git a/pkgs/by-name/to/topydo/package.nix b/pkgs/by-name/to/topydo/package.nix index 92411687ac9c8d..f0a888787dd151 100644 --- a/pkgs/by-name/to/topydo/package.nix +++ b/pkgs/by-name/to/topydo/package.nix @@ -1,4 +1,10 @@ -{ lib, python3, fetchFromGitHub, fetchpatch, glibcLocales }: +{ + lib, + python3, + fetchFromGitHub, + fetchpatch, + glibcLocales, +}: python3.pkgs.buildPythonApplication rec { pname = "topydo"; diff --git a/pkgs/by-name/to/tor-browser/package.nix b/pkgs/by-name/to/tor-browser/package.nix index 6c4c6470865bad..8803c3a05704b6 100644 --- a/pkgs/by-name/to/tor-browser/package.nix +++ b/pkgs/by-name/to/tor-browser/package.nix @@ -1,341 +1,379 @@ -{ lib -, stdenv -, fetchurl -, makeDesktopItem -, copyDesktopItems -, makeWrapper -, writeText -, autoPatchelfHook -, patchelfUnstable # have to use patchelfUnstable to support --no-clobber-old-sections -, wrapGAppsHook3 -, callPackage - -, atk -, cairo -, dbus -, dbus-glib -, fontconfig -, freetype -, gdk-pixbuf -, glib -, gtk3 -, libxcb -, libX11 -, libXext -, libXrender -, libXt -, libXtst -, mesa -, pango -, pciutils -, zlib - -, libnotifySupport ? stdenv.hostPlatform.isLinux -, libnotify - -, waylandSupport ? stdenv.hostPlatform.isLinux -, libxkbcommon -, libdrm -, libGL - -, mediaSupport ? true -, ffmpeg - -, audioSupport ? mediaSupport - -, pipewireSupport ? audioSupport -, pipewire - -, pulseaudioSupport ? audioSupport -, libpulseaudio -, apulse -, alsa-lib - -, libvaSupport ? mediaSupport -, libva - -# Hardening -, graphene-hardened-malloc -# Whether to use graphene-hardened-malloc -, useHardenedMalloc ? null - -# Whether to disable multiprocess support -, disableContentSandbox ? false - -# Extra preferences -, extraPrefs ? "" +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + copyDesktopItems, + makeWrapper, + writeText, + autoPatchelfHook, + patchelfUnstable, # have to use patchelfUnstable to support --no-clobber-old-sections + wrapGAppsHook3, + callPackage, + + atk, + cairo, + dbus, + dbus-glib, + fontconfig, + freetype, + gdk-pixbuf, + glib, + gtk3, + libxcb, + libX11, + libXext, + libXrender, + libXt, + libXtst, + mesa, + pango, + pciutils, + zlib, + + libnotifySupport ? stdenv.hostPlatform.isLinux, + libnotify, + + waylandSupport ? stdenv.hostPlatform.isLinux, + libxkbcommon, + libdrm, + libGL, + + mediaSupport ? true, + ffmpeg, + + audioSupport ? mediaSupport, + + pipewireSupport ? audioSupport, + pipewire, + + pulseaudioSupport ? audioSupport, + libpulseaudio, + apulse, + alsa-lib, + + libvaSupport ? mediaSupport, + libva, + + # Hardening + graphene-hardened-malloc, + # Whether to use graphene-hardened-malloc + useHardenedMalloc ? null, + + # Whether to disable multiprocess support + disableContentSandbox ? false, + + # Extra preferences + extraPrefs ? "", }: lib.warnIf (useHardenedMalloc != null) "tor-browser: useHardenedMalloc is deprecated and enabling it can cause issues" -(let - libPath = lib.makeLibraryPath ( - [ - alsa-lib - atk - cairo - dbus - dbus-glib - fontconfig - freetype - gdk-pixbuf - glib - gtk3 - libxcb - libX11 - libXext - libXrender - libXt - libXtst - mesa # for libgbm - pango - pciutils - stdenv.cc.cc - stdenv.cc.libc - zlib - ] ++ lib.optionals libnotifySupport [ libnotify ] - ++ lib.optionals waylandSupport [ libxkbcommon libdrm libGL ] - ++ lib.optionals pipewireSupport [ pipewire ] - ++ lib.optionals pulseaudioSupport [ libpulseaudio ] - ++ lib.optionals libvaSupport [ libva ] - ++ lib.optionals mediaSupport [ ffmpeg ] - ); - - version = "14.0.3"; - - sources = { - x86_64-linux = fetchurl { - urls = [ - "https://archive.torproject.org/tor-package-archive/torbrowser/${version}/tor-browser-linux-x86_64-${version}.tar.xz" - "https://dist.torproject.org/torbrowser/${version}/tor-browser-linux-x86_64-${version}.tar.xz" - "https://tor.eff.org/dist/torbrowser/${version}/tor-browser-linux-x86_64-${version}.tar.xz" - "https://tor.calyxinstitute.org/dist/torbrowser/${version}/tor-browser-linux-x86_64-${version}.tar.xz" + ( + let + libPath = lib.makeLibraryPath ( + [ + alsa-lib + atk + cairo + dbus + dbus-glib + fontconfig + freetype + gdk-pixbuf + glib + gtk3 + libxcb + libX11 + libXext + libXrender + libXt + libXtst + mesa # for libgbm + pango + pciutils + stdenv.cc.cc + stdenv.cc.libc + zlib + ] + ++ lib.optionals libnotifySupport [ libnotify ] + ++ lib.optionals waylandSupport [ + libxkbcommon + libdrm + libGL + ] + ++ lib.optionals pipewireSupport [ pipewire ] + ++ lib.optionals pulseaudioSupport [ libpulseaudio ] + ++ lib.optionals libvaSupport [ libva ] + ++ lib.optionals mediaSupport [ ffmpeg ] + ); + + version = "14.0.3"; + + sources = { + x86_64-linux = fetchurl { + urls = [ + "https://archive.torproject.org/tor-package-archive/torbrowser/${version}/tor-browser-linux-x86_64-${version}.tar.xz" + "https://dist.torproject.org/torbrowser/${version}/tor-browser-linux-x86_64-${version}.tar.xz" + "https://tor.eff.org/dist/torbrowser/${version}/tor-browser-linux-x86_64-${version}.tar.xz" + "https://tor.calyxinstitute.org/dist/torbrowser/${version}/tor-browser-linux-x86_64-${version}.tar.xz" + ]; + hash = "sha256-WddDs5lQFZde8Qy/7nQhGTrrT9BiVswriqOpPVpgvwY="; + }; + + i686-linux = fetchurl { + urls = [ + "https://archive.torproject.org/tor-package-archive/torbrowser/${version}/tor-browser-linux-i686-${version}.tar.xz" + "https://dist.torproject.org/torbrowser/${version}/tor-browser-linux-i686-${version}.tar.xz" + "https://tor.eff.org/dist/torbrowser/${version}/tor-browser-linux-i686-${version}.tar.xz" + "https://tor.calyxinstitute.org/dist/torbrowser/${version}/tor-browser-linux-i686-${version}.tar.xz" + ]; + hash = "sha256-DsTJiZkw0g4ip/yAwQ9IomZHQ6RP0hFNEzVJ8/fEbyQ="; + }; + }; + + distributionIni = writeText "distribution.ini" ( + lib.generators.toINI { } { + # Some light branding indicating this build uses our distro preferences + Global = { + id = "nixos"; + version = "1.0"; + about = "Tor Browser for NixOS"; + }; + } + ); + + policiesJson = writeText "policies.json" ( + builtins.toJSON { + policies.DisableAppUpdate = true; + } + ); + in + stdenv.mkDerivation rec { + pname = "tor-browser"; + inherit version; + + src = + sources.${stdenv.hostPlatform.system} + or (throw "unsupported system: ${stdenv.hostPlatform.system}"); + + nativeBuildInputs = [ + autoPatchelfHook + patchelfUnstable + copyDesktopItems + makeWrapper + wrapGAppsHook3 ]; - hash = "sha256-WddDs5lQFZde8Qy/7nQhGTrrT9BiVswriqOpPVpgvwY="; - }; - - i686-linux = fetchurl { - urls = [ - "https://archive.torproject.org/tor-package-archive/torbrowser/${version}/tor-browser-linux-i686-${version}.tar.xz" - "https://dist.torproject.org/torbrowser/${version}/tor-browser-linux-i686-${version}.tar.xz" - "https://tor.eff.org/dist/torbrowser/${version}/tor-browser-linux-i686-${version}.tar.xz" - "https://tor.calyxinstitute.org/dist/torbrowser/${version}/tor-browser-linux-i686-${version}.tar.xz" + buildInputs = [ + gtk3 + alsa-lib + dbus-glib + libXtst ]; - hash = "sha256-DsTJiZkw0g4ip/yAwQ9IomZHQ6RP0hFNEzVJ8/fEbyQ="; - }; - }; - - distributionIni = writeText "distribution.ini" (lib.generators.toINI {} { - # Some light branding indicating this build uses our distro preferences - Global = { - id = "nixos"; - version = "1.0"; - about = "Tor Browser for NixOS"; - }; - }); - - policiesJson = writeText "policies.json" (builtins.toJSON { - policies.DisableAppUpdate = true; - }); -in -stdenv.mkDerivation rec { - pname = "tor-browser"; - inherit version; - - src = sources.${stdenv.hostPlatform.system} or (throw "unsupported system: ${stdenv.hostPlatform.system}"); - - nativeBuildInputs = [ - autoPatchelfHook - patchelfUnstable - copyDesktopItems - makeWrapper - wrapGAppsHook3 - ]; - buildInputs = [ - gtk3 - alsa-lib - dbus-glib - libXtst - ]; - - # Firefox uses "relrhack" to manually process relocations from a fixed offset - patchelfFlags = [ "--no-clobber-old-sections" ]; - - preferLocalBuild = true; - allowSubstitutes = false; - - desktopItems = [(makeDesktopItem { - name = "torbrowser"; - exec = "tor-browser %U"; - icon = "tor-browser"; - desktopName = "Tor Browser"; - genericName = "Web Browser"; - comment = meta.description; - categories = [ "Network" "WebBrowser" "Security" ]; - mimeTypes = [ - "text/html" - "text/xml" - "application/xhtml+xml" - "application/vnd.mozilla.xul+xml" - "x-scheme-handler/http" - "x-scheme-handler/https" - ]; - })]; - - buildPhase = '' - runHook preBuild - - # For convenience ... - TBB_IN_STORE=$out/share/tor-browser - - # Unpack & enter - mkdir -p "$TBB_IN_STORE" - tar xf "$src" -C "$TBB_IN_STORE" --strip-components=2 - pushd "$TBB_IN_STORE" - - # Set ELF interpreter - autoPatchelf firefox.real TorBrowser/Tor - - # firefox is a wrapper that checks for a more recent libstdc++ & appends it to the ld path - mv firefox.real firefox - - # store state at `~/.tor browser` instead of relative to executable - touch "$TBB_IN_STORE/system-install" - - # The final libPath. Note, we could split this into firefoxLibPath - # and torLibPath for accuracy, but this is more convenient ... - libPath=${libPath}:$TBB_IN_STORE:$TBB_IN_STORE/TorBrowser/Tor - - # apulse uses a non-standard library path. For now special-case it. - ${lib.optionalString (audioSupport && !pulseaudioSupport) '' - libPath=${apulse}/lib/apulse:$libPath - ''} - - # Fixup paths to pluggable transports. - substituteInPlace TorBrowser/Data/Tor/torrc-defaults \ - --replace-fail './TorBrowser' "$TBB_IN_STORE/TorBrowser" - - # Prepare for autoconfig. - # - # See https://developer.mozilla.org/en-US/Firefox/Enterprise_deployment - cat >defaults/pref/autoconfig.js <mozilla.cfg <fonts' "$TBB_IN_STORE/fonts" - - # Hard-code paths to geoip data files. TBB resolves the geoip files - # relative to torrc-defaults_path but if we do not hard-code them - # here, these paths end up being written to the torrc in the user's - # state dir. - cat >>TorBrowser/Data/Tor/torrc-defaults </dev/null - - echo "Checking tor-browser wrapper ..." - $out/bin/tor-browser --version >/dev/null - - runHook postBuild - ''; - - installPhase = '' - runHook preInstall - - # Install distribution customizations - install -Dvm644 ${distributionIni} $out/share/tor-browser/distribution/distribution.ini - install -Dvm644 ${policiesJson} $out/share/tor-browser/distribution/policies.json - - runHook postInstall - ''; - - passthru = { - inherit sources; - updateScript = callPackage ./update.nix { - inherit pname version meta; - }; - }; - - meta = with lib; { - description = "Privacy-focused browser routing traffic through the Tor network"; - mainProgram = "tor-browser"; - homepage = "https://www.torproject.org/"; - changelog = "https://gitweb.torproject.org/builders/tor-browser-build.git/plain/projects/tor-browser/Bundle-Data/Docs/ChangeLog.txt?h=maint-${version}"; - platforms = attrNames sources; - maintainers = with maintainers; [ felschr panicgh joachifm hax404 ]; - # MPL2.0+, GPL+, &c. While it's not entirely clear whether - # the compound is "libre" in a strict sense (some components place certain - # restrictions on redistribution), it's free enough for our purposes. - license = with licenses; [ mpl20 lgpl21Plus lgpl3Plus free ]; - sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - }; -}) + + # Firefox uses "relrhack" to manually process relocations from a fixed offset + patchelfFlags = [ "--no-clobber-old-sections" ]; + + preferLocalBuild = true; + allowSubstitutes = false; + + desktopItems = [ + (makeDesktopItem { + name = "torbrowser"; + exec = "tor-browser %U"; + icon = "tor-browser"; + desktopName = "Tor Browser"; + genericName = "Web Browser"; + comment = meta.description; + categories = [ + "Network" + "WebBrowser" + "Security" + ]; + mimeTypes = [ + "text/html" + "text/xml" + "application/xhtml+xml" + "application/vnd.mozilla.xul+xml" + "x-scheme-handler/http" + "x-scheme-handler/https" + ]; + }) + ]; + + buildPhase = '' + runHook preBuild + + # For convenience ... + TBB_IN_STORE=$out/share/tor-browser + + # Unpack & enter + mkdir -p "$TBB_IN_STORE" + tar xf "$src" -C "$TBB_IN_STORE" --strip-components=2 + pushd "$TBB_IN_STORE" + + # Set ELF interpreter + autoPatchelf firefox.real TorBrowser/Tor + + # firefox is a wrapper that checks for a more recent libstdc++ & appends it to the ld path + mv firefox.real firefox + + # store state at `~/.tor browser` instead of relative to executable + touch "$TBB_IN_STORE/system-install" + + # The final libPath. Note, we could split this into firefoxLibPath + # and torLibPath for accuracy, but this is more convenient ... + libPath=${libPath}:$TBB_IN_STORE:$TBB_IN_STORE/TorBrowser/Tor + + # apulse uses a non-standard library path. For now special-case it. + ${lib.optionalString (audioSupport && !pulseaudioSupport) '' + libPath=${apulse}/lib/apulse:$libPath + ''} + + # Fixup paths to pluggable transports. + substituteInPlace TorBrowser/Data/Tor/torrc-defaults \ + --replace-fail './TorBrowser' "$TBB_IN_STORE/TorBrowser" + + # Prepare for autoconfig. + # + # See https://developer.mozilla.org/en-US/Firefox/Enterprise_deployment + cat >defaults/pref/autoconfig.js <mozilla.cfg <fonts' "$TBB_IN_STORE/fonts" + + # Hard-code paths to geoip data files. TBB resolves the geoip files + # relative to torrc-defaults_path but if we do not hard-code them + # here, these paths end up being written to the torrc in the user's + # state dir. + cat >>TorBrowser/Data/Tor/torrc-defaults </dev/null + + echo "Checking tor-browser wrapper ..." + $out/bin/tor-browser --version >/dev/null + + runHook postBuild + ''; + + installPhase = '' + runHook preInstall + + # Install distribution customizations + install -Dvm644 ${distributionIni} $out/share/tor-browser/distribution/distribution.ini + install -Dvm644 ${policiesJson} $out/share/tor-browser/distribution/policies.json + + runHook postInstall + ''; + + passthru = { + inherit sources; + updateScript = callPackage ./update.nix { + inherit pname version meta; + }; + }; + + meta = with lib; { + description = "Privacy-focused browser routing traffic through the Tor network"; + mainProgram = "tor-browser"; + homepage = "https://www.torproject.org/"; + changelog = "https://gitweb.torproject.org/builders/tor-browser-build.git/plain/projects/tor-browser/Bundle-Data/Docs/ChangeLog.txt?h=maint-${version}"; + platforms = attrNames sources; + maintainers = with maintainers; [ + felschr + panicgh + joachifm + hax404 + ]; + # MPL2.0+, GPL+, &c. While it's not entirely clear whether + # the compound is "libre" in a strict sense (some components place certain + # restrictions on redistribution), it's free enough for our purposes. + license = with licenses; [ + mpl20 + lgpl21Plus + lgpl3Plus + free + ]; + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; + }; + } + ) diff --git a/pkgs/by-name/to/tor-browser/update.nix b/pkgs/by-name/to/tor-browser/update.nix index 7faf4c31efbf0e..148a8ecc9bcd70 100644 --- a/pkgs/by-name/to/tor-browser/update.nix +++ b/pkgs/by-name/to/tor-browser/update.nix @@ -1,29 +1,39 @@ -{ lib -, writeShellScript -, coreutils -, gnused -, gnugrep -, curl -, gnupg -, nix -, common-updater-scripts +{ + lib, + writeShellScript, + coreutils, + gnused, + gnugrep, + curl, + gnupg, + nix, + common-updater-scripts, -# options -, pname -, version -, meta -, baseUrl ? "https://dist.torproject.org/torbrowser/" -# name used to match published archive -, name ? "tor-browser" -, prerelease ? false + # options + pname, + version, + meta, + baseUrl ? "https://dist.torproject.org/torbrowser/", + # name used to match published archive + name ? "tor-browser", + prerelease ? false, }: let - versionMatch = if prerelease - then ''[0-9]+(\.[0-9]+)*.*'' - else ''[0-9]+(\.[0-9]+)*''; -in writeShellScript "update-${pname}" '' - PATH="${lib.makeBinPath [ coreutils curl gnugrep gnused gnupg nix common-updater-scripts ]}" + versionMatch = if prerelease then ''[0-9]+(\.[0-9]+)*.*'' else ''[0-9]+(\.[0-9]+)*''; +in +writeShellScript "update-${pname}" '' + PATH="${ + lib.makeBinPath [ + coreutils + curl + gnugrep + gnused + gnupg + nix + common-updater-scripts + ] + }" set -euo pipefail trap diff --git a/pkgs/by-name/to/torcs/package.nix b/pkgs/by-name/to/torcs/package.nix index 476495bf883847..4a5b46a7e722e0 100644 --- a/pkgs/by-name/to/torcs/package.nix +++ b/pkgs/by-name/to/torcs/package.nix @@ -1,6 +1,28 @@ -{ fetchpatch, fetchurl, lib, stdenv, libGLU, libglut, libX11, plib, openal, freealut, libXrandr, xorgproto, -libXext, libSM, libICE, libXi, libXt, libXrender, libXxf86vm, libvorbis, -libpng, zlib, makeWrapper }: +{ + fetchpatch, + fetchurl, + lib, + stdenv, + libGLU, + libglut, + libX11, + plib, + openal, + freealut, + libXrandr, + xorgproto, + libXext, + libSM, + libICE, + libXi, + libXt, + libXrender, + libXxf86vm, + libvorbis, + libpng, + zlib, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "torcs"; @@ -40,8 +62,26 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ libGLU libglut libX11 plib openal freealut libXrandr xorgproto - libXext libSM libICE libXi libXt libXrender libXxf86vm libpng zlib libvorbis ]; + buildInputs = [ + libGLU + libglut + libX11 + plib + openal + freealut + libXrandr + xorgproto + libXext + libSM + libICE + libXi + libXt + libXrender + libXxf86vm + libpng + zlib + libvorbis + ]; installTargets = "install datainstall"; @@ -51,6 +91,6 @@ stdenv.mkDerivation rec { license = lib.licenses.gpl2Plus; maintainers = [ ]; platforms = lib.platforms.linux; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/by-name/to/torctl/package.nix b/pkgs/by-name/to/torctl/package.nix index 706ec96a59e040..d184953e8560c6 100644 --- a/pkgs/by-name/to/torctl/package.nix +++ b/pkgs/by-name/to/torctl/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/to/torrent7z/package.nix b/pkgs/by-name/to/torrent7z/package.nix index f18871baae93f5..43a03143bec1b1 100644 --- a/pkgs/by-name/to/torrent7z/package.nix +++ b/pkgs/by-name/to/torrent7z/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + ncurses, +}: stdenv.mkDerivation rec { pname = "torrent7z"; @@ -14,8 +20,7 @@ stdenv.mkDerivation rec { patches = [ (fetchpatch { name = "fix-gcc10-compilation.patch"; # Fix compilation on GCC 10. This patch is included on the latest commit - url = - "https://github.com/paulyc/torrent7z/commit/5958f42a364c430b3ed4ac68911bbbea1f967fc4.patch"; + url = "https://github.com/paulyc/torrent7z/commit/5958f42a364c430b3ed4ac68911bbbea1f967fc4.patch"; sha256 = "vJOv1sG9XwTvvxQiWew0H5ALoUb9wIAouzTsTvKHuPI="; }) ]; diff --git a/pkgs/by-name/to/torrential/package.nix b/pkgs/by-name/to/torrential/package.nix index 2d9028bcc97908..913e1b5c34e8d7 100644 --- a/pkgs/by-name/to/torrential/package.nix +++ b/pkgs/by-name/to/torrential/package.nix @@ -1,27 +1,28 @@ -{ stdenv -, lib -, fetchFromGitHub -, nix-update-script -, desktop-file-utils -, meson -, ninja -, pkg-config -, python3 -, vala -, wrapGAppsHook4 -, curl -, dht -, glib -, gtk4 -, libb64 -, libevent -, libgee -, libnatpmp -, libtransmission_3 -, libutp -, miniupnpc -, openssl -, pantheon +{ + stdenv, + lib, + fetchFromGitHub, + nix-update-script, + desktop-file-utils, + meson, + ninja, + pkg-config, + python3, + vala, + wrapGAppsHook4, + curl, + dht, + glib, + gtk4, + libb64, + libevent, + libgee, + libnatpmp, + libtransmission_3, + libutp, + miniupnpc, + openssl, + pantheon, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/to/torrentstream/deps.nix b/pkgs/by-name/to/torrentstream/deps.nix index b68fcf2d6cabe7..1df1839ed05829 100644 --- a/pkgs/by-name/to/torrentstream/deps.nix +++ b/pkgs/by-name/to/torrentstream/deps.nix @@ -1,43 +1,196 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "dotnet-ef"; version = "8.0.0"; sha256 = "1qh1zwyfgzy2486xvwiblg8algmwi70w2p1sqaiw4pfjz5c6dn21"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "8.0.0"; sha256 = "080kab87qgq2kh0ijry5kfdiq9afyzb8s0k3jqi5zbbi540yq4zl"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "8.0.0"; sha256 = "1jlpa4ggl1gr5fs7fdcw04li3y3iy05w3klr9lrrlc7v8w76kq71"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "8.0.0"; sha256 = "1m0gawiz8f5hc3li9vd5psddlygwgkiw13d7div87kmkf4idza8r"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.CommandLine"; version = "8.0.0"; sha256 = "026f7f2iv6ph2dc5rnslll0bly8qcx5clmh2nn9hgyqjizzc4qvy"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; version = "8.0.0"; sha256 = "13qb8wz3k59ihq0mjcqz1kwrpyzxn5da4dhk2pvcgc42z9kcbf7r"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.FileExtensions"; version = "8.0.0"; sha256 = "1jrmlfzy4h32nzf1nm5q8bhkpx958b0ww9qx1k1zm4pyaf6mqb04"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Json"; version = "8.0.0"; sha256 = "1n3ss26v1lq6b69fxk1vz3kqv9ppxq8ypgdqpd7415xrq66y4bqn"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.UserSecrets"; version = "8.0.0"; sha256 = "1br01zhzhnxjzqx63bxd25x48y9xs69hcs71pjni8y9kl50zja7z"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "8.0.0"; sha256 = "0i7qziz0iqmbk8zzln7kx9vd0lbx1x3va0yi3j1bgkjir13h78ps"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.0"; sha256 = "1zw0bpp5742jzx03wvqc8csnvsbgdqi0ls9jfc5i2vd3cl8b74pg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Diagnostics"; version = "8.0.0"; sha256 = "0ghwkld91k20hcbmzg2137w81mzzdh8hfaapdwckhza0vipya4kw"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Diagnostics.Abstractions"; version = "8.0.0"; sha256 = "15m4j6w9n8h0mj7hlfzb83hd3wn7aq1s7fxbicm16slsjfwzj82i"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "8.0.0"; sha256 = "1idq65fxwcn882c06yci7nscy9i0rgw6mqjrl7362prvvsd9f15r"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Physical"; version = "8.0.0"; sha256 = "05wxjvjbx79ir7vfkri6b28k8zl8fa6bbr0i7gahqrim2ijvkp6v"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileSystemGlobbing"; version = "8.0.0"; sha256 = "1igf2bqism22fxv7km5yv028r4rg12a4lki2jh4xg3brjkagiv7q"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting"; version = "8.0.0"; sha256 = "1f2af5m1yny8b43251gsj75hjd9ixni1clcldy8cg91z1vxxm8dh"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting.Abstractions"; version = "8.0.0"; sha256 = "00d5dwmzw76iy8z40ly01hy9gly49a7rpf7k7m99vrid1kxp346h"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting.Systemd"; version = "8.0.0"; sha256 = "1jhxx8wyk18vspvfp30j5dymv8m85jg9s1iahdkfyin5v5j8g0xq"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting.WindowsServices"; version = "8.0.0"; sha256 = "1xwbk1xa2y888a4qrmxn50l9b2l8vnfq1lmia9xh7zykl9zhmrps"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "8.0.0"; sha256 = "0nppj34nmq25gnrg0wh1q22y4wdqbih4ax493f226azv8mkp9s1i"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "8.0.0"; sha256 = "1klcqhg3hk55hb6vmjiq2wgqidsl81aldw0li2z98lrwx26msrr6"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Configuration"; version = "8.0.0"; sha256 = "1d9b734vnll935661wqkgl7ry60rlh5p876l2bsa930mvfsaqfcv"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Console"; version = "8.0.0"; sha256 = "1mvp3ipw7k33v2qw2yrvc4vl5yzgpk3yxa94gg0gz7wmcmhzvmkd"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Debug"; version = "8.0.0"; sha256 = "1h7mg97lj0ss47kq7zwnihh9c6xcrkwrr8ffhc16qcsrh36sg6q0"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.EventLog"; version = "8.0.0"; sha256 = "05vfrxw7mlwlwhsl6r4yrhxk3sd8dv5sl0hdlcpgw62n53incw5x"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.EventSource"; version = "8.0.0"; sha256 = "0gbjll6p03rmw0cf8fp0p8cxzn9awmzv8hvnyqbczrkax5h7p94i"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "8.0.0"; sha256 = "0p50qn6zhinzyhq9sy5svnmqqwhw2jajs2pbjh9sah504wjvhscz"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; version = "8.0.0"; sha256 = "04nm8v5a3zp0ill7hjnwnja3s2676b4wffdri8hdk2341p7mp403"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "8.0.0"; sha256 = "0aldaz5aapngchgdr7dax9jw5wy7k7hmjgjpfgfv1wfif27jlkqm"; }) - (fetchNuGet { pname = "Mono.Nat"; version = "3.0.0"; sha256 = "17lyjcpwp5j2dwx0gi975x710r7kqkx50c1wmyzwdyqhar3kszi8"; }) - (fetchNuGet { pname = "MonoTorrent"; version = "3.0.0-beta.rev0106"; sha256 = "0zz64nnb02d4pjpffs9x26jvbalm48yaghbgj3vc7j8ff0sm8xr4"; }) - (fetchNuGet { pname = "ReusableTasks"; version = "2.0.2"; sha256 = "0dkyirzspp8spmgd3ad9mak5jhqfmib6m437r2bmmyb3m4mxp5rb"; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "8.0.0"; sha256 = "0nzra1i0mljvmnj1qqqg37xs7bl71fnpl68nwmdajchh65l878zr"; }) - (fetchNuGet { pname = "System.Diagnostics.EventLog"; version = "8.0.0"; sha256 = "1xnvcidh2qf6k7w8ij1rvj0viqkq84cq47biw0c98xhxg5rk3pxf"; }) - (fetchNuGet { pname = "System.ServiceProcess.ServiceController"; version = "8.0.0"; sha256 = "00hlb8vmfgs2kk39mqmij5h3bz5sgkqxpxvpnki4ncayqadx1bws"; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "8.0.0"; sha256 = "1wbypkx0m8dgpsaqgyywz4z760xblnwalb241d5qv9kx8m128i11"; }) - (fetchNuGet { pname = "System.Text.Json"; version = "8.0.0"; sha256 = "134savxw0sq7s448jnzw17bxcijsi1v38mirpbb6zfxmqlf04msw"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "dotnet-ef"; + version = "8.0.0"; + sha256 = "1qh1zwyfgzy2486xvwiblg8algmwi70w2p1sqaiw4pfjz5c6dn21"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "8.0.0"; + sha256 = "080kab87qgq2kh0ijry5kfdiq9afyzb8s0k3jqi5zbbi540yq4zl"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "8.0.0"; + sha256 = "1jlpa4ggl1gr5fs7fdcw04li3y3iy05w3klr9lrrlc7v8w76kq71"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "8.0.0"; + sha256 = "1m0gawiz8f5hc3li9vd5psddlygwgkiw13d7div87kmkf4idza8r"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.CommandLine"; + version = "8.0.0"; + sha256 = "026f7f2iv6ph2dc5rnslll0bly8qcx5clmh2nn9hgyqjizzc4qvy"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; + version = "8.0.0"; + sha256 = "13qb8wz3k59ihq0mjcqz1kwrpyzxn5da4dhk2pvcgc42z9kcbf7r"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.FileExtensions"; + version = "8.0.0"; + sha256 = "1jrmlfzy4h32nzf1nm5q8bhkpx958b0ww9qx1k1zm4pyaf6mqb04"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Json"; + version = "8.0.0"; + sha256 = "1n3ss26v1lq6b69fxk1vz3kqv9ppxq8ypgdqpd7415xrq66y4bqn"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.UserSecrets"; + version = "8.0.0"; + sha256 = "1br01zhzhnxjzqx63bxd25x48y9xs69hcs71pjni8y9kl50zja7z"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "8.0.0"; + sha256 = "0i7qziz0iqmbk8zzln7kx9vd0lbx1x3va0yi3j1bgkjir13h78ps"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.0"; + sha256 = "1zw0bpp5742jzx03wvqc8csnvsbgdqi0ls9jfc5i2vd3cl8b74pg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Diagnostics"; + version = "8.0.0"; + sha256 = "0ghwkld91k20hcbmzg2137w81mzzdh8hfaapdwckhza0vipya4kw"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Diagnostics.Abstractions"; + version = "8.0.0"; + sha256 = "15m4j6w9n8h0mj7hlfzb83hd3wn7aq1s7fxbicm16slsjfwzj82i"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "8.0.0"; + sha256 = "1idq65fxwcn882c06yci7nscy9i0rgw6mqjrl7362prvvsd9f15r"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Physical"; + version = "8.0.0"; + sha256 = "05wxjvjbx79ir7vfkri6b28k8zl8fa6bbr0i7gahqrim2ijvkp6v"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileSystemGlobbing"; + version = "8.0.0"; + sha256 = "1igf2bqism22fxv7km5yv028r4rg12a4lki2jh4xg3brjkagiv7q"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting"; + version = "8.0.0"; + sha256 = "1f2af5m1yny8b43251gsj75hjd9ixni1clcldy8cg91z1vxxm8dh"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting.Abstractions"; + version = "8.0.0"; + sha256 = "00d5dwmzw76iy8z40ly01hy9gly49a7rpf7k7m99vrid1kxp346h"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting.Systemd"; + version = "8.0.0"; + sha256 = "1jhxx8wyk18vspvfp30j5dymv8m85jg9s1iahdkfyin5v5j8g0xq"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting.WindowsServices"; + version = "8.0.0"; + sha256 = "1xwbk1xa2y888a4qrmxn50l9b2l8vnfq1lmia9xh7zykl9zhmrps"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "8.0.0"; + sha256 = "0nppj34nmq25gnrg0wh1q22y4wdqbih4ax493f226azv8mkp9s1i"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "8.0.0"; + sha256 = "1klcqhg3hk55hb6vmjiq2wgqidsl81aldw0li2z98lrwx26msrr6"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Configuration"; + version = "8.0.0"; + sha256 = "1d9b734vnll935661wqkgl7ry60rlh5p876l2bsa930mvfsaqfcv"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Console"; + version = "8.0.0"; + sha256 = "1mvp3ipw7k33v2qw2yrvc4vl5yzgpk3yxa94gg0gz7wmcmhzvmkd"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Debug"; + version = "8.0.0"; + sha256 = "1h7mg97lj0ss47kq7zwnihh9c6xcrkwrr8ffhc16qcsrh36sg6q0"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.EventLog"; + version = "8.0.0"; + sha256 = "05vfrxw7mlwlwhsl6r4yrhxk3sd8dv5sl0hdlcpgw62n53incw5x"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.EventSource"; + version = "8.0.0"; + sha256 = "0gbjll6p03rmw0cf8fp0p8cxzn9awmzv8hvnyqbczrkax5h7p94i"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "8.0.0"; + sha256 = "0p50qn6zhinzyhq9sy5svnmqqwhw2jajs2pbjh9sah504wjvhscz"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; + version = "8.0.0"; + sha256 = "04nm8v5a3zp0ill7hjnwnja3s2676b4wffdri8hdk2341p7mp403"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "8.0.0"; + sha256 = "0aldaz5aapngchgdr7dax9jw5wy7k7hmjgjpfgfv1wfif27jlkqm"; + }) + (fetchNuGet { + pname = "Mono.Nat"; + version = "3.0.0"; + sha256 = "17lyjcpwp5j2dwx0gi975x710r7kqkx50c1wmyzwdyqhar3kszi8"; + }) + (fetchNuGet { + pname = "MonoTorrent"; + version = "3.0.0-beta.rev0106"; + sha256 = "0zz64nnb02d4pjpffs9x26jvbalm48yaghbgj3vc7j8ff0sm8xr4"; + }) + (fetchNuGet { + pname = "ReusableTasks"; + version = "2.0.2"; + sha256 = "0dkyirzspp8spmgd3ad9mak5jhqfmib6m437r2bmmyb3m4mxp5rb"; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "8.0.0"; + sha256 = "0nzra1i0mljvmnj1qqqg37xs7bl71fnpl68nwmdajchh65l878zr"; + }) + (fetchNuGet { + pname = "System.Diagnostics.EventLog"; + version = "8.0.0"; + sha256 = "1xnvcidh2qf6k7w8ij1rvj0viqkq84cq47biw0c98xhxg5rk3pxf"; + }) + (fetchNuGet { + pname = "System.ServiceProcess.ServiceController"; + version = "8.0.0"; + sha256 = "00hlb8vmfgs2kk39mqmij5h3bz5sgkqxpxvpnki4ncayqadx1bws"; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "8.0.0"; + sha256 = "1wbypkx0m8dgpsaqgyywz4z760xblnwalb241d5qv9kx8m128i11"; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "8.0.0"; + sha256 = "134savxw0sq7s448jnzw17bxcijsi1v38mirpbb6zfxmqlf04msw"; + }) ] diff --git a/pkgs/by-name/to/torrentstream/package.nix b/pkgs/by-name/to/torrentstream/package.nix index c07e9d52eeb476..539a293fda51c7 100644 --- a/pkgs/by-name/to/torrentstream/package.nix +++ b/pkgs/by-name/to/torrentstream/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildDotnetModule -, fetchFromGitHub -, dotnetCorePackages +{ + lib, + buildDotnetModule, + fetchFromGitHub, + dotnetCorePackages, }: buildDotnetModule rec { diff --git a/pkgs/by-name/to/tortoisehg/package.nix b/pkgs/by-name/to/tortoisehg/package.nix index e4ad91a8713feb..d1d333cf4519ef 100644 --- a/pkgs/by-name/to/tortoisehg/package.nix +++ b/pkgs/by-name/to/tortoisehg/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchurl -, python3Packages -, mercurial -, qt5 +{ + lib, + fetchurl, + python3Packages, + mercurial, + qt5, }: python3Packages.buildPythonApplication rec { @@ -65,6 +66,9 @@ python3Packages.buildPythonApplication rec { homepage = "https://tortoisehg.bitbucket.io/"; license = lib.licenses.gpl2Only; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ danbst gbtb ]; + maintainers = with lib.maintainers; [ + danbst + gbtb + ]; }; } diff --git a/pkgs/by-name/to/torus-trooper/package.nix b/pkgs/by-name/to/torus-trooper/package.nix index 5715be413b8401..f3a98d48e04fcc 100644 --- a/pkgs/by-name/to/torus-trooper/package.nix +++ b/pkgs/by-name/to/torus-trooper/package.nix @@ -1,73 +1,51 @@ -{ lib -, stdenv -, fetchpatch -, fetchurl -, unzip -, gdc -, SDL -, SDL_mixer -, bulletml +{ + lib, + stdenv, + fetchpatch, + fetchurl, + unzip, + gdc, + SDL, + SDL_mixer, + bulletml, }: let -debianPatch = patchname: hash: fetchpatch { - name = "${patchname}.patch"; - url = "https://sources.debian.org/data/main/t/torus-trooper/0.22.dfsg1-12/debian/patches/${patchname}.patch"; - sha256 = hash; -}; + debianPatch = + patchname: hash: + fetchpatch { + name = "${patchname}.patch"; + url = "https://sources.debian.org/data/main/t/torus-trooper/0.22.dfsg1-12/debian/patches/${patchname}.patch"; + sha256 = hash; + }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "torus-trooper"; version = "0.22"; src = fetchurl { - url = "http://abagames.sakura.ne.jp/windows/tt${lib.replaceStrings ["."] ["_"] finalAttrs.version}.zip"; + url = "http://abagames.sakura.ne.jp/windows/tt${ + lib.replaceStrings [ "." ] [ "_" ] finalAttrs.version + }.zip"; sha256 = "1yhki1fdp3fi4y2iq12vca69f6k38dqjaw9z4lwcxky5kbgb7jvg"; }; patches = [ - (debianPatch - "imports" - "0mifw0mj66zljpq6iqnh0rhkgs2sky8rz0p32k98vxfnsb39ibsf") - (debianPatch - "fixes" - "05f93zq2v14lymq748c9g646ckbh9mqpr5rrahb63s90x8hlcqil") - (debianPatch - "directories" - "0y5xvf26v9fk0rx6ncrxx4czckhjbi891hp3pixlmv568pg9cihd") - (debianPatch - "windowed" - "1d8ghj4shvpb0s8l16kscz4l7rz1fxmfdpddy1ikz3678pw1sc8p") - (debianPatch - "dotfile" - "17yirmnjhbd1clzhmdd2mfdhbxkyinaahd6v3yz5kzbcylvjz2r2") - (debianPatch - "window-resizing" - "1n64gbhabl6vis7s294wxlj2k8s3ypxljpdg71icwz1m9jjx59df") - (debianPatch - "save-score-444372" - "1skny6s3hjxkh8w4fq86vp51j7z40fvn80b8myl4i1zzlwag3x17") - (debianPatch - "level-select-444948" - "008248s55188plggg2kg01nimjgc7w0sqd3c22sl6lzd1fjsflv8") - (debianPatch - "avoid-segfault-when-sdl-fails" - "1yp758gi4i15gqk6wiqp815rqcmlyqx62ir1sw20hn6zb3j97bmc") - (debianPatch - "dlang_v2" - "1lxsbckhvl8a8j43pw2dyl5nlavvdbgxb5zlb2450a0vml55nswd") - (debianPatch - "lowest-level-position-602808" - "19r48wirc9zssjmv57drn2fd0f56dcgyqqaz3j49cvv6yd74qf20") - (debianPatch - "libbulletml0v5-segfault" - "0pad2daz60hswkhkdpssxaqc9p9ca0sw1nraqzr453x0zdwwq0hn") - (debianPatch - "std.math.fabs" - "18xnnqlj20bxv2h9fa8dn4rmxwi3k6y3g50kwvh8i8p3b4hgag3r") - (debianPatch - "gdc-8" - "10z702y75c48hjcnvv8m7f3ka52cj3r3jqafdbby85nb0p2lbssx") + (debianPatch "imports" "0mifw0mj66zljpq6iqnh0rhkgs2sky8rz0p32k98vxfnsb39ibsf") + (debianPatch "fixes" "05f93zq2v14lymq748c9g646ckbh9mqpr5rrahb63s90x8hlcqil") + (debianPatch "directories" "0y5xvf26v9fk0rx6ncrxx4czckhjbi891hp3pixlmv568pg9cihd") + (debianPatch "windowed" "1d8ghj4shvpb0s8l16kscz4l7rz1fxmfdpddy1ikz3678pw1sc8p") + (debianPatch "dotfile" "17yirmnjhbd1clzhmdd2mfdhbxkyinaahd6v3yz5kzbcylvjz2r2") + (debianPatch "window-resizing" "1n64gbhabl6vis7s294wxlj2k8s3ypxljpdg71icwz1m9jjx59df") + (debianPatch "save-score-444372" "1skny6s3hjxkh8w4fq86vp51j7z40fvn80b8myl4i1zzlwag3x17") + (debianPatch "level-select-444948" "008248s55188plggg2kg01nimjgc7w0sqd3c22sl6lzd1fjsflv8") + (debianPatch "avoid-segfault-when-sdl-fails" "1yp758gi4i15gqk6wiqp815rqcmlyqx62ir1sw20hn6zb3j97bmc") + (debianPatch "dlang_v2" "1lxsbckhvl8a8j43pw2dyl5nlavvdbgxb5zlb2450a0vml55nswd") + (debianPatch "lowest-level-position-602808" "19r48wirc9zssjmv57drn2fd0f56dcgyqqaz3j49cvv6yd74qf20") + (debianPatch "libbulletml0v5-segfault" "0pad2daz60hswkhkdpssxaqc9p9ca0sw1nraqzr453x0zdwwq0hn") + (debianPatch "std.math.fabs" "18xnnqlj20bxv2h9fa8dn4rmxwi3k6y3g50kwvh8i8p3b4hgag3r") + (debianPatch "gdc-8" "10z702y75c48hjcnvv8m7f3ka52cj3r3jqafdbby85nb0p2lbssx") ]; postPatch = '' diff --git a/pkgs/by-name/to/toss/package.nix b/pkgs/by-name/to/toss/package.nix index 3c8f72961812f8..a1f877837c71ed 100644 --- a/pkgs/by-name/to/toss/package.nix +++ b/pkgs/by-name/to/toss/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "toss"; @@ -10,8 +14,10 @@ stdenv.mkDerivation rec { sha256 = "05ql0d8wbdhnmh3dw8ch5bi6clfb9h8v21lq2a74iy02slya2y0r"; }; preInstall = "export DESTDIR=$out/bin"; - meta = with lib; - src.meta // { + meta = + with lib; + src.meta + // { description = "Dead simple LAN file transfers from the command line"; license = with licenses; [ mit ]; maintainers = with maintainers; [ ehmry ]; diff --git a/pkgs/by-name/to/totem-pl-parser/package.nix b/pkgs/by-name/to/totem-pl-parser/package.nix index 6598da9a6f8219..bb565d494e897b 100644 --- a/pkgs/by-name/to/totem-pl-parser/package.nix +++ b/pkgs/by-name/to/totem-pl-parser/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchpatch, fetchurl, meson, ninja, pkg-config, gettext, libxml2, gobject-introspection, gnome, glib }: +{ + lib, + stdenv, + fetchpatch, + fetchurl, + meson, + ninja, + pkg-config, + gettext, + libxml2, + gobject-introspection, + gnome, + glib, +}: stdenv.mkDerivation rec { pname = "totem-pl-parser"; @@ -26,8 +39,18 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson ninja pkg-config gettext glib gobject-introspection ]; - buildInputs = [ libxml2 glib ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + gettext + glib + gobject-introspection + ]; + buildInputs = [ + libxml2 + glib + ]; mesonFlags = lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ "-Dintrospection=false" diff --git a/pkgs/by-name/to/totem/package.nix b/pkgs/by-name/to/totem/package.nix index db3e8892fe56ed..6b1eb8c43ac86b 100644 --- a/pkgs/by-name/to/totem/package.nix +++ b/pkgs/by-name/to/totem/package.nix @@ -1,32 +1,33 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, gettext -, gst_all_1 -, python3Packages -, shared-mime-info -, pkg-config -, gtk3 -, glib -, gobject-introspection -, totem-pl-parser -, wrapGAppsHook3 -, itstool -, libxml2 -, vala -, gnome -, grilo -, grilo-plugins -, libpeas -, libportal-gtk3 -, libhandy -, adwaita-icon-theme -, gnome-desktop -, gsettings-desktop-schemas -, gdk-pixbuf -, xvfb-run +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + gettext, + gst_all_1, + python3Packages, + shared-mime-info, + pkg-config, + gtk3, + glib, + gobject-introspection, + totem-pl-parser, + wrapGAppsHook3, + itstool, + libxml2, + vala, + gnome, + grilo, + grilo-plugins, + libpeas, + libportal-gtk3, + libhandy, + adwaita-icon-theme, + gnome-desktop, + gsettings-desktop-schemas, + gdk-pixbuf, + xvfb-run, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/to/touchegg/package.nix b/pkgs/by-name/to/touchegg/package.nix index 32a1b059f2c591..d286414fc51d0a 100644 --- a/pkgs/by-name/to/touchegg/package.nix +++ b/pkgs/by-name/to/touchegg/package.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, nix-update-script -, systemd -, libinput -, pugixml -, cairo -, xorg -, gtk3-x11 -, pcre -, pkg-config -, cmake -, pantheon -, withPantheon ? false +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + nix-update-script, + systemd, + libinput, + pugixml, + cairo, + xorg, + gtk3-x11, + pcre, + pkg-config, + cmake, + pantheon, + withPantheon ? false, }: stdenv.mkDerivation rec { @@ -48,22 +49,24 @@ stdenv.mkDerivation rec { cmake ]; - buildInputs = [ - systemd - libinput - pugixml - cairo - gtk3-x11 - pcre - ] ++ (with xorg; [ - libX11 - libXtst - libXrandr - libXi - libXdmcp - libpthreadstubs - libxcb - ]); + buildInputs = + [ + systemd + libinput + pugixml + cairo + gtk3-x11 + pcre + ] + ++ (with xorg; [ + libX11 + libXtst + libXrandr + libXi + libXdmcp + libpthreadstubs + libxcb + ]); PKG_CONFIG_SYSTEMD_SYSTEMDSYSTEMUNITDIR = "${placeholder "out"}/lib/systemd/system"; diff --git a/pkgs/by-name/to/tox-node/package.nix b/pkgs/by-name/to/tox-node/package.nix index 3f8857fff56982..e09d4fc754e38b 100644 --- a/pkgs/by-name/to/tox-node/package.nix +++ b/pkgs/by-name/to/tox-node/package.nix @@ -1,4 +1,9 @@ -{ lib, rustPlatform, fetchFromGitHub, nix-update-script }: +{ + lib, + rustPlatform, + fetchFromGitHub, + nix-update-script, +}: rustPlatform.buildRustPackage rec { pname = "tox-node"; @@ -22,7 +27,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/tox-rs/tox"; license = [ licenses.gpl3Plus ]; platforms = platforms.linux; - maintainers = with maintainers; [ suhr kurnevsky ]; + maintainers = with maintainers; [ + suhr + kurnevsky + ]; mainProgram = "tox-node"; }; } diff --git a/pkgs/by-name/to/toxic/package.nix b/pkgs/by-name/to/toxic/package.nix index 036c96dd47d538..ffad1f618fbef4 100644 --- a/pkgs/by-name/to/toxic/package.nix +++ b/pkgs/by-name/to/toxic/package.nix @@ -1,27 +1,56 @@ -{ lib, stdenv, fetchFromGitHub, libsodium, ncurses, curl -, libtoxcore, openal, libvpx, freealut, libconfig, pkg-config, libopus -, qrencode, gdk-pixbuf, libnotify }: +{ + lib, + stdenv, + fetchFromGitHub, + libsodium, + ncurses, + curl, + libtoxcore, + openal, + libvpx, + freealut, + libconfig, + pkg-config, + libopus, + qrencode, + gdk-pixbuf, + libnotify, +}: stdenv.mkDerivation rec { pname = "toxic"; version = "0.15.1"; src = fetchFromGitHub { - owner = "TokTok"; - repo = "toxic"; - rev = "v${version}"; + owner = "TokTok"; + repo = "toxic"; + rev = "v${version}"; hash = "sha256-+nOjlQED2pbYwGV6IGeKK1pymBSrDVWCWKjZ42vib7E="; }; - makeFlags = [ "PREFIX=$(out)"]; - installFlags = [ "PREFIX=$(out)"]; + makeFlags = [ "PREFIX=$(out)" ]; + installFlags = [ "PREFIX=$(out)" ]; - buildInputs = [ - libtoxcore libsodium ncurses curl gdk-pixbuf libnotify - ] ++ lib.optionals (!stdenv.hostPlatform.isAarch32) [ - openal libopus libvpx freealut qrencode + buildInputs = + [ + libtoxcore + libsodium + ncurses + curl + gdk-pixbuf + libnotify + ] + ++ lib.optionals (!stdenv.hostPlatform.isAarch32) [ + openal + libopus + libvpx + freealut + qrencode + ]; + nativeBuildInputs = [ + pkg-config + libconfig ]; - nativeBuildInputs = [ pkg-config libconfig ]; meta = src.meta // { description = "Reference CLI for Tox"; diff --git a/pkgs/by-name/to/toxiproxy/package.nix b/pkgs/by-name/to/toxiproxy/package.nix index 0b2aff389dbc2c..104399ce64f15c 100644 --- a/pkgs/by-name/to/toxiproxy/package.nix +++ b/pkgs/by-name/to/toxiproxy/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, toxiproxy +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + toxiproxy, }: buildGoModule rec { @@ -20,7 +21,11 @@ buildGoModule rec { excludedPackages = [ "test/e2e" ]; - ldflags = [ "-s" "-w" "-X github.com/Shopify/toxiproxy/v2.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/Shopify/toxiproxy/v2.Version=${version}" + ]; # Fixes tests on Darwin __darwinAllowLocalNetworking = true; diff --git a/pkgs/by-name/to/toxvpn/package.nix b/pkgs/by-name/to/toxvpn/package.nix index 1053dd0154a625..48063d333ceab2 100644 --- a/pkgs/by-name/to/toxvpn/package.nix +++ b/pkgs/by-name/to/toxvpn/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, nlohmann_json -, libtoxcore -, libsodium -, libcap -, zeromq -, systemd +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + nlohmann_json, + libtoxcore, + libsodium, + libcap, + zeromq, + systemd, }: stdenv.mkDerivation { @@ -21,8 +22,17 @@ stdenv.mkDerivation { sha256 = "sha256-UncU0cpoyy9Z0TCChGmaHpyhW9ctz32gU7n3hgpOEwU="; }; - buildInputs = [ libtoxcore nlohmann_json libsodium zeromq ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libcap systemd ]; + buildInputs = + [ + libtoxcore + nlohmann_json + libsodium + zeromq + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libcap + systemd + ]; nativeBuildInputs = [ cmake ]; @@ -37,7 +47,12 @@ stdenv.mkDerivation { description = "Powerful tool that allows one to make tunneled point to point connections over Tox"; homepage = "https://github.com/cleverca22/toxvpn"; license = licenses.gpl3; - maintainers = with maintainers; [ cleverca22 craigem obadz toonn ]; + maintainers = with maintainers; [ + cleverca22 + craigem + obadz + toonn + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/tp/tp-auto-kbbl/package.nix b/pkgs/by-name/tp/tp-auto-kbbl/package.nix index 15292fad178540..ecfccd0bdc76a2 100644 --- a/pkgs/by-name/tp/tp-auto-kbbl/package.nix +++ b/pkgs/by-name/tp/tp-auto-kbbl/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, dbus -, pkg-config -, openssl -, libevdev +{ + lib, + fetchFromGitHub, + rustPlatform, + dbus, + pkg-config, + openssl, + libevdev, }: rustPlatform.buildRustPackage rec { @@ -21,13 +22,17 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-zBTn3dcKzm5JfL1a31m6ZHXp2JoGObPBciy1BfVmL1Q="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dbus libevdev openssl ]; + buildInputs = [ + dbus + libevdev + openssl + ]; meta = with lib; { description = "Auto toggle keyboard back-lighting on Thinkpads (and maybe other laptops) for Linux"; homepage = "https://github.com/saibotd/tp-auto-kbbl"; license = licenses.mit; - maintainers = with maintainers; []; + maintainers = with maintainers; [ ]; platforms = platforms.linux; mainProgram = "tp-auto-kbbl"; }; diff --git a/pkgs/by-name/tp/tpacpi-bat/package.nix b/pkgs/by-name/tp/tpacpi-bat/package.nix index 42d8a0f9dbcfe3..8a5f8d32e534b9 100644 --- a/pkgs/by-name/tp/tpacpi-bat/package.nix +++ b/pkgs/by-name/tp/tpacpi-bat/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, perl, kmod, coreutils }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, + kmod, + coreutils, +}: # Requires the acpi_call kernel module in order to run. stdenv.mkDerivation rec { @@ -26,7 +33,7 @@ stdenv.mkDerivation rec { ''; meta = { - maintainers = [lib.maintainers.orbekk]; + maintainers = [ lib.maintainers.orbekk ]; platforms = lib.platforms.linux; description = "Tool to set battery charging thresholds on Lenovo Thinkpad"; mainProgram = "tpacpi-bat"; diff --git a/pkgs/by-name/tp/tpm-luks/package.nix b/pkgs/by-name/tp/tpm-luks/package.nix index 16d88c9196b802..185d33fccdf3cc 100644 --- a/pkgs/by-name/tp/tpm-luks/package.nix +++ b/pkgs/by-name/tp/tpm-luks/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, gawk, trousers, cryptsetup, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gawk, + trousers, + cryptsetup, + openssl, +}: stdenv.mkDerivation { pname = "tpm-luks"; @@ -17,7 +26,12 @@ stdenv.mkDerivation { ]; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ gawk trousers cryptsetup openssl ]; + buildInputs = [ + gawk + trousers + cryptsetup + openssl + ]; installPhase = '' mkdir -p $out @@ -34,4 +48,3 @@ stdenv.mkDerivation { platforms = platforms.linux; }; } - diff --git a/pkgs/by-name/tp/tpm-quote-tools/package.nix b/pkgs/by-name/tp/tpm-quote-tools/package.nix index 58ff7160924c6c..dbaa37f5047dc5 100644 --- a/pkgs/by-name/tp/tpm-quote-tools/package.nix +++ b/pkgs/by-name/tp/tpm-quote-tools/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, trousers, openssl }: +{ + lib, + stdenv, + fetchurl, + trousers, + openssl, +}: stdenv.mkDerivation rec { pname = "tpm-quote-tools"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1qjs83xb4np4yn1bhbjfhvkiika410v8icwnjix5ad96w2nlxp0h"; }; - buildInputs = [ trousers openssl ]; + buildInputs = [ + trousers + openssl + ]; postFixup = '' patchelf \ @@ -24,9 +33,9 @@ stdenv.mkDerivation rec { for TPM based attestation using the TPM quote mechanism. The manual page for tpm_quote_tools provides a usage overview. ''; - homepage = "http://tpmquotetools.sourceforge.net/"; - license = licenses.bsd3; + homepage = "http://tpmquotetools.sourceforge.net/"; + license = licenses.bsd3; maintainers = with maintainers; [ ak ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/tp/tpm-tools/package.nix b/pkgs/by-name/tp/tpm-tools/package.nix index c0e2941323a6e3..abfc81a93d59a9 100644 --- a/pkgs/by-name/tp/tpm-tools/package.nix +++ b/pkgs/by-name/tp/tpm-tools/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, trousers, openssl, opencryptoki, perl }: +{ + lib, + stdenv, + fetchurl, + trousers, + openssl, + opencryptoki, + perl, +}: let version = "1.3.9.1"; @@ -22,7 +30,11 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ perl ]; - buildInputs = [ trousers openssl opencryptoki ]; + buildInputs = [ + trousers + openssl + opencryptoki + ]; meta = with lib; { description = "Management tools for TPM hardware"; @@ -31,10 +43,9 @@ stdenv.mkDerivation rec { application enablement of Trusted Computing using a Trusted Platform Module (TPM), similar to a smart card environment. ''; - homepage = "https://sourceforge.net/projects/trousers/files/tpm-tools/"; - license = licenses.cpl10; + homepage = "https://sourceforge.net/projects/trousers/files/tpm-tools/"; + license = licenses.cpl10; maintainers = [ maintainers.ak ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } - diff --git a/pkgs/by-name/tp/tpm2-abrmd/package.nix b/pkgs/by-name/tp/tpm2-abrmd/package.nix index da297f7a5b36c7..52c34e8806813b 100644 --- a/pkgs/by-name/tp/tpm2-abrmd/package.nix +++ b/pkgs/by-name/tp/tpm2-abrmd/package.nix @@ -1,7 +1,16 @@ -{ stdenv, lib, fetchFromGitHub -, autoreconfHook, pkg-config, autoconf-archive, makeWrapper, which -, tpm2-tss, glib, dbus -, cmocka +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + pkg-config, + autoconf-archive, + makeWrapper, + which, + tpm2-tss, + glib, + dbus, + cmocka, }: stdenv.mkDerivation rec { @@ -23,7 +32,11 @@ stdenv.mkDerivation rec { pkg-config which ]; - buildInputs = [ tpm2-tss glib dbus ]; + buildInputs = [ + tpm2-tss + glib + dbus + ]; nativeCheckInputs = [ cmocka ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/tp/tpm2-pkcs11/package.nix b/pkgs/by-name/tp/tpm2-pkcs11/package.nix index 80d9a1c452001b..6d9782c76e5d85 100644 --- a/pkgs/by-name/tp/tpm2-pkcs11/package.nix +++ b/pkgs/by-name/tp/tpm2-pkcs11/package.nix @@ -1,8 +1,24 @@ -{ stdenv, lib, fetchFromGitHub, substituteAll -, pkg-config, autoreconfHook, autoconf-archive, makeWrapper, patchelf -, tpm2-tss, tpm2-tools, opensc, openssl, sqlite, python3, glibc, libyaml -, abrmdSupport ? true, tpm2-abrmd ? null -, fapiSupport ? true +{ + stdenv, + lib, + fetchFromGitHub, + substituteAll, + pkg-config, + autoreconfHook, + autoconf-archive, + makeWrapper, + patchelf, + tpm2-tss, + tpm2-tools, + opensc, + openssl, + sqlite, + python3, + glibc, + libyaml, + abrmdSupport ? true, + tpm2-abrmd ? null, + fapiSupport ? true, }: stdenv.mkDerivation rec { @@ -35,38 +51,61 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ - pkg-config autoreconfHook autoconf-archive makeWrapper patchelf + pkg-config + autoreconfHook + autoconf-archive + makeWrapper + patchelf ]; buildInputs = [ - tpm2-tss tpm2-tools opensc openssl sqlite libyaml - (python3.withPackages (ps: with ps; [ packaging pyyaml cryptography pyasn1-modules tpm2-pytss ])) + tpm2-tss + tpm2-tools + opensc + openssl + sqlite + libyaml + (python3.withPackages ( + ps: with ps; [ + packaging + pyyaml + cryptography + pyasn1-modules + tpm2-pytss + ] + )) ]; - outputs = [ "out" "bin" "dev" ]; + outputs = [ + "out" + "bin" + "dev" + ]; dontStrip = true; dontPatchELF = true; # To be able to use the userspace resource manager, the RUNPATH must # explicitly include the tpm2-abrmd shared libraries. - preFixup = let - rpath = lib.makeLibraryPath ( - (lib.optional abrmdSupport tpm2-abrmd) - ++ [ - tpm2-tss - sqlite - openssl - glibc - libyaml - ] - ); - in '' - patchelf \ - --set-rpath ${rpath} \ - ${lib.optionalString abrmdSupport "--add-needed ${lib.makeLibraryPath [tpm2-abrmd]}/libtss2-tcti-tabrmd.so"} \ - --add-needed ${lib.makeLibraryPath [tpm2-tss]}/libtss2-tcti-device.so \ - $out/lib/libtpm2_pkcs11.so.0.0.0 - ''; + preFixup = + let + rpath = lib.makeLibraryPath ( + (lib.optional abrmdSupport tpm2-abrmd) + ++ [ + tpm2-tss + sqlite + openssl + glibc + libyaml + ] + ); + in + '' + patchelf \ + --set-rpath ${rpath} \ + ${lib.optionalString abrmdSupport "--add-needed ${lib.makeLibraryPath [ tpm2-abrmd ]}/libtss2-tcti-tabrmd.so"} \ + --add-needed ${lib.makeLibraryPath [ tpm2-tss ]}/libtss2-tcti-device.so \ + $out/lib/libtpm2_pkcs11.so.0.0.0 + ''; postInstall = '' mkdir -p $bin/bin/ $bin/share/tpm2_pkcs11/ diff --git a/pkgs/by-name/tp/tpm2-tools/package.nix b/pkgs/by-name/tp/tpm2-tools/package.nix index 2e78257a13e2a1..88a20e99b1d240 100644 --- a/pkgs/by-name/tp/tpm2-tools/package.nix +++ b/pkgs/by-name/tp/tpm2-tools/package.nix @@ -1,6 +1,17 @@ -{ stdenv, fetchurl, lib -, pandoc, pkg-config, makeWrapper, curl, openssl, tpm2-tss, libuuid -, abrmdSupport ? true, tpm2-abrmd ? null }: +{ + stdenv, + fetchurl, + lib, + pandoc, + pkg-config, + makeWrapper, + curl, + openssl, + tpm2-tss, + libuuid, + abrmdSupport ? true, + tpm2-abrmd ? null, +}: stdenv.mkDerivation rec { pname = "tpm2-tools"; @@ -11,20 +22,31 @@ stdenv.mkDerivation rec { sha256 = "sha256-OBDTa1B5JW9PL3zlUuIiE9Q7EDHBMVON+KLbw8VwmDo="; }; - nativeBuildInputs = [ pandoc pkg-config makeWrapper ]; + nativeBuildInputs = [ + pandoc + pkg-config + makeWrapper + ]; buildInputs = [ - curl openssl tpm2-tss libuuid + curl + openssl + tpm2-tss + libuuid ]; - preFixup = let - ldLibraryPath = lib.makeLibraryPath ([ - tpm2-tss - ] ++ (lib.optional abrmdSupport tpm2-abrmd)); - in '' - wrapProgram $out/bin/tpm2 --suffix LD_LIBRARY_PATH : "${ldLibraryPath}" - wrapProgram $out/bin/tss2 --suffix LD_LIBRARY_PATH : "${ldLibraryPath}" - ''; - + preFixup = + let + ldLibraryPath = lib.makeLibraryPath ( + [ + tpm2-tss + ] + ++ (lib.optional abrmdSupport tpm2-abrmd) + ); + in + '' + wrapProgram $out/bin/tpm2 --suffix LD_LIBRARY_PATH : "${ldLibraryPath}" + wrapProgram $out/bin/tss2 --suffix LD_LIBRARY_PATH : "${ldLibraryPath}" + ''; # Unit tests disabled, as they rely on a dbus session #configureFlags = [ "--enable-unit" ]; diff --git a/pkgs/by-name/tp/tpm2-totp/package.nix b/pkgs/by-name/tp/tpm2-totp/package.nix index 766c6e138af64c..4bfea9d1193679 100644 --- a/pkgs/by-name/tp/tpm2-totp/package.nix +++ b/pkgs/by-name/tp/tpm2-totp/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, tpm2-tss -, autoreconfHook -, autoconf-archive -, pkg-config -, qrencode +{ + lib, + stdenv, + fetchFromGitHub, + tpm2-tss, + autoreconfHook, + autoconf-archive, + pkg-config, + qrencode, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/tp/tpnote/package.nix b/pkgs/by-name/tp/tpnote/package.nix index 1efa9e1b61c9fe..76cbda46fc455b 100644 --- a/pkgs/by-name/tp/tpnote/package.nix +++ b/pkgs/by-name/tp/tpnote/package.nix @@ -1,17 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, cmake -, pkg-config -, oniguruma -, darwin -, installShellFiles -, tpnote -, testers +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + cmake, + pkg-config, + oniguruma, + darwin, + installShellFiles, + tpnote, + testers, }: - rustPlatform.buildRustPackage rec { pname = "tpnote"; version = "1.24.10"; @@ -31,13 +31,18 @@ rustPlatform.buildRustPackage rec { installShellFiles ]; - buildInputs = [ - oniguruma - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - AppKit - CoreServices - SystemConfiguration - ]); + buildInputs = + [ + oniguruma + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + AppKit + CoreServices + SystemConfiguration + ] + ); postInstall = '' installManPage docs/build/man/man1/tpnote.1 diff --git a/pkgs/by-name/tp/tptp/package.nix b/pkgs/by-name/tp/tptp/package.nix index 5df511ebaa8e76..a9b89c21362d28 100644 --- a/pkgs/by-name/tp/tptp/package.nix +++ b/pkgs/by-name/tp/tptp/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, yap, tcsh, perl, patchelf }: +{ + lib, + stdenv, + fetchurl, + yap, + tcsh, + perl, + patchelf, +}: stdenv.mkDerivation rec { pname = "TPTP"; @@ -13,7 +21,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ patchelf ]; - buildInputs = [ tcsh yap perl ]; + buildInputs = [ + tcsh + yap + perl + ]; installPhase = '' sharedir=$out/share/tptp @@ -38,11 +50,14 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Thousands of problems for theorem provers and tools"; - maintainers = with maintainers; [ raskin gebner ]; + maintainers = with maintainers; [ + raskin + gebner + ]; # 6.3 GiB of data. Installation is unpacking and editing a few files. # No sense in letting Hydra build it. # Also, it is unclear what is covered by "verbatim" - we will edit configs - hydraPlatforms = []; + hydraPlatforms = [ ]; platforms = platforms.all; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfreeRedistributable; diff --git a/pkgs/by-name/tq/tqsl/package.nix b/pkgs/by-name/tq/tqsl/package.nix index e75cb778803c34..61ea5efac06874 100644 --- a/pkgs/by-name/tq/tqsl/package.nix +++ b/pkgs/by-name/tq/tqsl/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, cmake, expat, openssl, zlib, lmdb, curl, sqlite, wxGTK32, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchurl, + cmake, + expat, + openssl, + zlib, + lmdb, + curl, + sqlite, + wxGTK32, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "tqsl"; @@ -9,7 +22,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-recq2FTyvmt5tDTjZRjQKWf5HgdkmTsMmRTWTfTPGbQ="; }; - nativeBuildInputs = [ cmake wrapGAppsHook3 ]; + nativeBuildInputs = [ + cmake + wrapGAppsHook3 + ]; buildInputs = [ expat openssl diff --git a/pkgs/by-name/tr/tr-patcher/package.nix b/pkgs/by-name/tr/tr-patcher/package.nix index 77788e8f27f237..af6405f2ac083f 100644 --- a/pkgs/by-name/tr/tr-patcher/package.nix +++ b/pkgs/by-name/tr/tr-patcher/package.nix @@ -1,10 +1,17 @@ -{ stdenv, lib, fetchurl, fetchzip, jre, makeWrapper }: +{ + stdenv, + lib, + fetchurl, + fetchzip, + jre, + makeWrapper, +}: let -translation-file = fetchurl { - url = "https://gitlab.com/bmwinger/tr-patcher/-/raw/master/lib/Translation.txt?inline=false"; - sha256 = "136zd2s73b4n1w2n34wxi656bm448748nn3y7a64fd89ysg9n7n8"; -}; + translation-file = fetchurl { + url = "https://gitlab.com/bmwinger/tr-patcher/-/raw/master/lib/Translation.txt?inline=false"; + sha256 = "136zd2s73b4n1w2n34wxi656bm448748nn3y7a64fd89ysg9n7n8"; + }; in stdenv.mkDerivation rec { pname = "tr-patcher"; diff --git a/pkgs/by-name/tr/tracebox/package.nix b/pkgs/by-name/tr/tracebox/package.nix index 1d50aea4756639..7a373f49796e12 100644 --- a/pkgs/by-name/tr/tracebox/package.nix +++ b/pkgs/by-name/tr/tracebox/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, libpcap -, lua5_1 -, json_c -, testers -, tracebox +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libpcap, + lua5_1, + json_c, + testers, + tracebox, }: stdenv.mkDerivation rec { pname = "tracebox"; diff --git a/pkgs/by-name/tr/tracefilegen/package.nix b/pkgs/by-name/tr/tracefilegen/package.nix index 4623c42e819192..5abd2d63032a6c 100644 --- a/pkgs/by-name/tr/tracefilegen/package.nix +++ b/pkgs/by-name/tr/tracefilegen/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/tr/tracefilesim/package.nix b/pkgs/by-name/tr/tracefilesim/package.nix index cd1682a1f5e711..0e135186ace201 100644 --- a/pkgs/by-name/tr/tracefilesim/package.nix +++ b/pkgs/by-name/tr/tracefilesim/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { diff --git a/pkgs/by-name/tr/traceroute/package.nix b/pkgs/by-name/tr/traceroute/package.nix index 3a61c5eacbefe8..6c72db10561f6b 100644 --- a/pkgs/by-name/tr/traceroute/package.nix +++ b/pkgs/by-name/tr/traceroute/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/tr/trackballs/package.nix b/pkgs/by-name/tr/trackballs/package.nix index 3c3d50eafdb1d7..1b21058149a163 100644 --- a/pkgs/by-name/tr/trackballs/package.nix +++ b/pkgs/by-name/tr/trackballs/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, cmake, SDL2, SDL2_ttf, gettext, zlib, SDL2_mixer, SDL2_image, guile, libGLU, libGL }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + SDL2, + SDL2_ttf, + gettext, + zlib, + SDL2_mixer, + SDL2_image, + guile, + libGLU, + libGL, +}: stdenv.mkDerivation rec { pname = "trackballs"; @@ -12,7 +26,17 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ zlib SDL2 SDL2_ttf SDL2_mixer SDL2_image guile gettext libGLU libGL ]; + buildInputs = [ + zlib + SDL2 + SDL2_ttf + SDL2_mixer + SDL2_image + guile + gettext + libGLU + libGL + ]; meta = with lib; { homepage = "https://trackballs.github.io/"; diff --git a/pkgs/by-name/tr/tracy/package.nix b/pkgs/by-name/tr/tracy/package.nix index 5f03796e50acc8..edeefc4d72a45c 100644 --- a/pkgs/by-name/tr/tracy/package.nix +++ b/pkgs/by-name/tr/tracy/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub - -, capstone -, darwin -, dbus -, freetype -, glfw -, hicolor-icon-theme -, pkg-config -, tbb - -, withWayland ? stdenv.hostPlatform.isLinux -, libxkbcommon -, wayland +{ + lib, + stdenv, + fetchFromGitHub, + + capstone, + darwin, + dbus, + freetype, + glfw, + hicolor-icon-theme, + pkg-config, + tbb, + + withWayland ? stdenv.hostPlatform.isLinux, + libxkbcommon, + wayland, }: stdenv.mkDerivation rec { @@ -27,36 +28,49 @@ stdenv.mkDerivation rec { hash = "sha256-DN1ExvQ5wcIUyhMAfiakFbZkDsx+5l8VMtYGvSdboPA="; }; - patches = lib.optionals (stdenv.hostPlatform.isDarwin && !(lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11")) [ - ./0001-remove-unifiedtypeidentifiers-framework - ]; + patches = + lib.optionals + (stdenv.hostPlatform.isDarwin && !(lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11")) + [ + ./0001-remove-unifiedtypeidentifiers-framework + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - capstone - freetype - glfw - ] ++ lib.optionals (stdenv.hostPlatform.isLinux && withWayland) [ - libxkbcommon - wayland - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - dbus - hicolor-icon-theme - tbb - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.AppKit - darwin.apple_sdk.frameworks.Carbon - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11") [ - darwin.apple_sdk.frameworks.UniformTypeIdentifiers - ]; - - env.NIX_CFLAGS_COMPILE = toString ([ ] + buildInputs = + [ + capstone + freetype + glfw + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && withWayland) [ + libxkbcommon + wayland + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + dbus + hicolor-icon-theme + tbb + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.AppKit + darwin.apple_sdk.frameworks.Carbon + ] + ++ + lib.optionals + (stdenv.hostPlatform.isDarwin && lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11") + [ + darwin.apple_sdk.frameworks.UniformTypeIdentifiers + ]; + + env.NIX_CFLAGS_COMPILE = toString ( + [ ] # Apple's compiler finds a format string security error on # ../../../server/TracyView.cpp:649:34, preventing building. ++ lib.optional stdenv.hostPlatform.isDarwin "-Wno-format-security" ++ lib.optional stdenv.hostPlatform.isLinux "-ltbb" - ++ lib.optional stdenv.cc.isClang "-faligned-allocation"); + ++ lib.optional stdenv.cc.isClang "-faligned-allocation" + ); buildPhase = '' runHook preBuild @@ -72,35 +86,38 @@ stdenv.mkDerivation rec { runHook postBuild ''; - installPhase = '' - runHook preInstall - - install -D -m 0755 capture/build/unix/capture-release $out/bin/capture - install -D -m 0755 csvexport/build/unix/csvexport-release $out/bin/tracy-csvexport - install -D -m 0755 import-chrome/build/unix/import-chrome-release $out/bin/import-chrome - install -D -m 0755 library/unix/libtracy-release.so $out/lib/libtracy.so - install -D -m 0755 profiler/build/unix/Tracy-release $out/bin/tracy - install -D -m 0755 update/build/unix/update-release $out/bin/update - - mkdir -p $out/include/Tracy/client - mkdir -p $out/include/Tracy/common - mkdir -p $out/include/Tracy/tracy - - cp -p public/client/*.{h,hpp} $out/include/Tracy/client - cp -p public/common/*.{h,hpp} $out/include/Tracy/common - cp -p public/tracy/*.{h,hpp} $out/include/Tracy/tracy - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace extra/desktop/tracy.desktop \ - --replace Exec=/usr/bin/tracy Exec=tracy - - install -D -m 0644 extra/desktop/application-tracy.xml $out/share/mime/packages/application-tracy.xml - install -D -m 0644 extra/desktop/tracy.desktop $out/share/applications/tracy.desktop - install -D -m 0644 icon/application-tracy.svg $out/share/icons/hicolor/scalable/apps/application-tracy.svg - install -D -m 0644 icon/icon.png $out/share/icons/hicolor/256x256/apps/tracy.png - install -D -m 0644 icon/icon.svg $out/share/icons/hicolor/scalable/apps/tracy.svg - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + + install -D -m 0755 capture/build/unix/capture-release $out/bin/capture + install -D -m 0755 csvexport/build/unix/csvexport-release $out/bin/tracy-csvexport + install -D -m 0755 import-chrome/build/unix/import-chrome-release $out/bin/import-chrome + install -D -m 0755 library/unix/libtracy-release.so $out/lib/libtracy.so + install -D -m 0755 profiler/build/unix/Tracy-release $out/bin/tracy + install -D -m 0755 update/build/unix/update-release $out/bin/update + + mkdir -p $out/include/Tracy/client + mkdir -p $out/include/Tracy/common + mkdir -p $out/include/Tracy/tracy + + cp -p public/client/*.{h,hpp} $out/include/Tracy/client + cp -p public/common/*.{h,hpp} $out/include/Tracy/common + cp -p public/tracy/*.{h,hpp} $out/include/Tracy/tracy + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace extra/desktop/tracy.desktop \ + --replace Exec=/usr/bin/tracy Exec=tracy + + install -D -m 0644 extra/desktop/application-tracy.xml $out/share/mime/packages/application-tracy.xml + install -D -m 0644 extra/desktop/tracy.desktop $out/share/applications/tracy.desktop + install -D -m 0644 icon/application-tracy.svg $out/share/icons/hicolor/scalable/apps/application-tracy.svg + install -D -m 0644 icon/icon.png $out/share/icons/hicolor/256x256/apps/tracy.png + install -D -m 0644 icon/icon.svg $out/share/icons/hicolor/scalable/apps/tracy.svg + '' + + '' + runHook postInstall + ''; postFixup = lib.optionalString stdenv.hostPlatform.isDarwin '' install_name_tool -change libcapstone.4.dylib ${capstone}/lib/libcapstone.4.dylib $out/bin/tracy @@ -112,6 +129,10 @@ stdenv.mkDerivation rec { platforms = platforms.linux ++ platforms.darwin; license = licenses.bsd3; mainProgram = "tracy"; - maintainers = with maintainers; [ mpickering nagisa paveloom ]; + maintainers = with maintainers; [ + mpickering + nagisa + paveloom + ]; }; } diff --git a/pkgs/by-name/tr/tradcpp/package.nix b/pkgs/by-name/tr/tradcpp/package.nix index b26db0d22356d8..bba9e0501e907d 100644 --- a/pkgs/by-name/tr/tradcpp/package.nix +++ b/pkgs/by-name/tr/tradcpp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, autoconf }: +{ + lib, + stdenv, + fetchurl, + autoconf, +}: stdenv.mkDerivation rec { pname = "tradcpp"; diff --git a/pkgs/by-name/tr/tradingview/package.nix b/pkgs/by-name/tr/tradingview/package.nix index 958e0f4135e484..b95cad50fec7cd 100644 --- a/pkgs/by-name/tr/tradingview/package.nix +++ b/pkgs/by-name/tr/tradingview/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, squashfsTools -, makeBinaryWrapper -, alsa-lib -, atk -, at-spi2-atk -, cups -, gtk3 -, libdrm -, libsecret -, libxkbcommon -, mesa -, pango -, sqlite -, systemd -, wayland -, xorg +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + squashfsTools, + makeBinaryWrapper, + alsa-lib, + atk, + at-spi2-atk, + cups, + gtk3, + libdrm, + libsecret, + libxkbcommon, + mesa, + pango, + sqlite, + systemd, + wayland, + xorg, }: stdenv.mkDerivation (finalAttrs: { @@ -76,7 +77,7 @@ stdenv.mkDerivation (finalAttrs: { cp squashfs-root/meta/gui/icon.png $out/share/icons/tradingview.png mkdir $out/bin - makeBinaryWrapper $out/share/tradingview/tradingview $out/bin/tradingview --prefix LD_LIBRARY_PATH : ${ lib.makeLibraryPath finalAttrs.buildInputs } + makeBinaryWrapper $out/share/tradingview/tradingview $out/bin/tradingview --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath finalAttrs.buildInputs} runHook postInstall ''; diff --git a/pkgs/by-name/tr/traefik-certs-dumper/package.nix b/pkgs/by-name/tr/traefik-certs-dumper/package.nix index a9ff5dd7cd96c9..f86409a9e17ce9 100644 --- a/pkgs/by-name/tr/traefik-certs-dumper/package.nix +++ b/pkgs/by-name/tr/traefik-certs-dumper/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, buildGoModule, lib }: +{ + fetchFromGitHub, + buildGoModule, + lib, +}: buildGoModule rec { pname = "traefik-certs-dumper"; diff --git a/pkgs/by-name/tr/trafficserver/package.nix b/pkgs/by-name/tr/trafficserver/package.nix index 56c0d3babbc296..d6cacf5434cf0b 100644 --- a/pkgs/by-name/tr/trafficserver/package.nix +++ b/pkgs/by-name/tr/trafficserver/package.nix @@ -1,48 +1,49 @@ -{ lib -, stdenv -, fetchzip -, autoreconfHook -, makeWrapper -, nixosTests -, pkg-config -, file -, linuxHeaders -, openssl -, pcre -, perlPackages -, python3 -# recommended dependencies -, withHwloc ? true -, hwloc -, withCurl ? true -, curl -, withCurses ? true -, ncurses -, withCap ? stdenv.hostPlatform.isLinux -, libcap -, withUnwind ? stdenv.hostPlatform.isLinux -, libunwind -# optional dependencies -, withBrotli ? false -, brotli -, withCjose ? false -, cjose -, withGeoIP ? false -, geoip -, withHiredis ? false -, hiredis -, withImageMagick ? false -, imagemagick -, withJansson ? false -, jansson -, withKyotoCabinet ? false -, kyotocabinet -, withLuaJIT ? false -, luajit -, withMaxmindDB ? false -, libmaxminddb -# optional features -, enableWCCP ? false +{ + lib, + stdenv, + fetchzip, + autoreconfHook, + makeWrapper, + nixosTests, + pkg-config, + file, + linuxHeaders, + openssl, + pcre, + perlPackages, + python3, + # recommended dependencies + withHwloc ? true, + hwloc, + withCurl ? true, + curl, + withCurses ? true, + ncurses, + withCap ? stdenv.hostPlatform.isLinux, + libcap, + withUnwind ? stdenv.hostPlatform.isLinux, + libunwind, + # optional dependencies + withBrotli ? false, + brotli, + withCjose ? false, + cjose, + withGeoIP ? false, + geoip, + withHiredis ? false, + hiredis, + withImageMagick ? false, + imagemagick, + withJansson ? false, + jansson, + withKyotoCabinet ? false, + kyotocabinet, + withLuaJIT ? false, + luajit, + withMaxmindDB ? false, + libmaxminddb, + # optional features + enableWCCP ? false, }: stdenv.mkDerivation rec { @@ -62,45 +63,63 @@ stdenv.mkDerivation rec { # # [1]: https://github.com/apache/trafficserver/pull/5617 # [2]: https://github.com/apache/trafficserver/blob/3fd2c60/configure.ac#L742-L788 - nativeBuildInputs = [ autoreconfHook makeWrapper pkg-config file python3 ] - ++ (with perlPackages; [ perl ExtUtilsMakeMaker ]) + nativeBuildInputs = + [ + autoreconfHook + makeWrapper + pkg-config + file + python3 + ] + ++ (with perlPackages; [ + perl + ExtUtilsMakeMaker + ]) ++ lib.optionals stdenv.hostPlatform.isLinux [ linuxHeaders ]; - buildInputs = [ - openssl - pcre - perlPackages.perl - ] ++ lib.optional withBrotli brotli - ++ lib.optional withCap libcap - ++ lib.optional withCjose cjose - ++ lib.optional withCurl curl - ++ lib.optional withGeoIP geoip - ++ lib.optional withHiredis hiredis - ++ lib.optional withHwloc hwloc - ++ lib.optional withImageMagick imagemagick - ++ lib.optional withJansson jansson - ++ lib.optional withKyotoCabinet kyotocabinet - ++ lib.optional withCurses ncurses - ++ lib.optional withLuaJIT luajit - ++ lib.optional withUnwind libunwind - ++ lib.optional withMaxmindDB libmaxminddb; - - outputs = [ "out" "man" ]; - - postPatch = '' - patchShebangs \ - iocore/aio/test_AIO.sample \ - src/traffic_via/test_traffic_via \ - src/traffic_logstats/tests \ - tools/check-unused-dependencies - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace configure.ac \ - --replace-fail '/usr/include/linux' '${linuxHeaders}/include/linux' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # 'xcrun leaks' probably requires non-free XCode - substituteInPlace iocore/net/test_certlookup.cc \ - --replace-fail 'xcrun leaks' 'true' - ''; + buildInputs = + [ + openssl + pcre + perlPackages.perl + ] + ++ lib.optional withBrotli brotli + ++ lib.optional withCap libcap + ++ lib.optional withCjose cjose + ++ lib.optional withCurl curl + ++ lib.optional withGeoIP geoip + ++ lib.optional withHiredis hiredis + ++ lib.optional withHwloc hwloc + ++ lib.optional withImageMagick imagemagick + ++ lib.optional withJansson jansson + ++ lib.optional withKyotoCabinet kyotocabinet + ++ lib.optional withCurses ncurses + ++ lib.optional withLuaJIT luajit + ++ lib.optional withUnwind libunwind + ++ lib.optional withMaxmindDB libmaxminddb; + + outputs = [ + "out" + "man" + ]; + + postPatch = + '' + patchShebangs \ + iocore/aio/test_AIO.sample \ + src/traffic_via/test_traffic_via \ + src/traffic_logstats/tests \ + tools/check-unused-dependencies + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace configure.ac \ + --replace-fail '/usr/include/linux' '${linuxHeaders}/include/linux' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # 'xcrun leaks' probably requires non-free XCode + substituteInPlace iocore/net/test_certlookup.cc \ + --replace-fail 'xcrun leaks' 'true' + ''; configureFlags = [ "--enable-layout=NixOS" @@ -133,29 +152,31 @@ stdenv.mkDerivation rec { rmdir $out/.install-trafficserver ''; - installCheckPhase = let - expected = '' - Via header is [uScMsEf p eC:t cCMp sF], Length is 22 - Via Header Details: - Request headers received from client :simple request (not conditional) - Result of Traffic Server cache lookup for URL :miss (a cache "MISS") - Response information received from origin server :error in response - Result of document write-to-cache: :no cache write performed - Proxy operation result :unknown - Error codes (if any) :connection to server failed - Tunnel info :no tunneling - Cache Type :cache - Cache Lookup Result :cache miss (url not in cache) - Parent proxy connection status :no parent proxy or unknown - Origin server connection status :connection open failed + installCheckPhase = + let + expected = '' + Via header is [uScMsEf p eC:t cCMp sF], Length is 22 + Via Header Details: + Request headers received from client :simple request (not conditional) + Result of Traffic Server cache lookup for URL :miss (a cache "MISS") + Response information received from origin server :error in response + Result of document write-to-cache: :no cache write performed + Proxy operation result :unknown + Error codes (if any) :connection to server failed + Tunnel info :no tunneling + Cache Type :cache + Cache Lookup Result :cache miss (url not in cache) + Parent proxy connection status :no parent proxy or unknown + Origin server connection status :connection open failed + ''; + in + '' + runHook preInstallCheck + diff -Naur <($out/bin/traffic_via '[uScMsEf p eC:t cCMp sF]') - < $out/bin/transcrypt-depspathprefix << EOF #!${stdenv.shell} - echo "${lib.makeBinPath [ git openssl coreutils gawk ]}:" + echo "${ + lib.makeBinPath [ + git + openssl + coreutils + gawk + ] + }:" EOF chmod +x $out/bin/transcrypt-depspathprefix ''; diff --git a/pkgs/by-name/tr/transfer-sh/package.nix b/pkgs/by-name/tr/transfer-sh/package.nix index d3b15ae2465bf8..360621b974333d 100644 --- a/pkgs/by-name/tr/transfer-sh/package.nix +++ b/pkgs/by-name/tr/transfer-sh/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, nix-update-script -, nixosTests +{ + lib, + fetchFromGitHub, + buildGoModule, + nix-update-script, + nixosTests, }: buildGoModule rec { @@ -31,6 +32,9 @@ buildGoModule rec { changelog = "https://github.com/dutchcoders/transfer.sh/releases"; mainProgram = "transfer.sh"; license = licenses.mit; - maintainers = with maintainers; [ ocfox pinpox ]; + maintainers = with maintainers; [ + ocfox + pinpox + ]; }; } diff --git a/pkgs/by-name/tr/transgui/package.nix b/pkgs/by-name/tr/transgui/package.nix index 6444bc72df40f3..23286a131448c2 100644 --- a/pkgs/by-name/tr/transgui/package.nix +++ b/pkgs/by-name/tr/transgui/package.nix @@ -1,6 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, makeDesktopItem, unzip -, fpc, lazarus, libX11, glib, gtk2, gdk-pixbuf, pango, atk, cairo, openssl -, unstableGitUpdater }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + makeDesktopItem, + unzip, + fpc, + lazarus, + libX11, + glib, + gtk2, + gdk-pixbuf, + pango, + atk, + cairo, + openssl, + unstableGitUpdater, +}: stdenv.mkDerivation rec { pname = "transgui"; @@ -13,10 +29,22 @@ stdenv.mkDerivation rec { hash = "sha256-8ycivjjPeXBdPbqNNlO2hcre6T9sFhqg6vUfCREtd8k="; }; - nativeBuildInputs = [ pkg-config unzip ]; + nativeBuildInputs = [ + pkg-config + unzip + ]; buildInputs = [ - fpc lazarus stdenv.cc libX11 glib gtk2 gdk-pixbuf - pango atk cairo openssl + fpc + lazarus + stdenv.cc + libX11 + glib + gtk2 + gdk-pixbuf + pango + atk + cairo + openssl ]; NIX_LDFLAGS = '' @@ -34,7 +62,11 @@ stdenv.mkDerivation rec { lazbuild -B transgui.lpr --lazarusdir=${lazarus}/share/lazarus ''; - makeFlags = [ "FPC=fpc" "PP=fpc" "INSTALL_PREFIX=$(out)" ]; + makeFlags = [ + "FPC=fpc" + "PP=fpc" + "INSTALL_PREFIX=$(out)" + ]; LCL_PLATFORM = "gtk2"; @@ -46,9 +78,17 @@ stdenv.mkDerivation rec { comment = meta.description; desktopName = "Transmission Remote GUI"; genericName = "BitTorrent Client"; - categories = [ "Network" "FileTransfer" "P2P" "GTK" ]; + categories = [ + "Network" + "FileTransfer" + "P2P" + "GTK" + ]; startupNotify = true; - mimeTypes = [ "application/x-bittorrent" "x-scheme-handler/magnet" ]; + mimeTypes = [ + "application/x-bittorrent" + "x-scheme-handler/magnet" + ]; }; postInstall = '' @@ -70,6 +110,9 @@ stdenv.mkDerivation rec { license = lib.licenses.gpl2Plus; maintainers = with lib.maintainers; [ ramkromberg ]; mainProgram = "transgui"; - platforms = [ "x86_64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; }; } diff --git a/pkgs/by-name/tr/transifex-cli/package.nix b/pkgs/by-name/tr/transifex-cli/package.nix index da06ce3929184f..a4551be0f8c636 100644 --- a/pkgs/by-name/tr/transifex-cli/package.nix +++ b/pkgs/by-name/tr/transifex-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -17,7 +18,9 @@ buildGoModule rec { vendorHash = "sha256-3gi2ysIb5256CdmtX38oIfeDwNCQojK+YB9aEm8H01Q="; ldflags = [ - "-s" "-w" "-X 'github.com/transifex/cli/internal/txlib.Version=${version}'" + "-s" + "-w" + "-X 'github.com/transifex/cli/internal/txlib.Version=${version}'" ]; postInstall = '' diff --git a/pkgs/by-name/tr/translate-shell/package.nix b/pkgs/by-name/tr/translate-shell/package.nix index 4a92a9d0e79b4d..132ce92697eb05 100644 --- a/pkgs/by-name/tr/translate-shell/package.nix +++ b/pkgs/by-name/tr/translate-shell/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, curl, fribidi, rlwrap, gawk, groff, ncurses, hexdump }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + curl, + fribidi, + rlwrap, + gawk, + groff, + ncurses, + hexdump, +}: stdenv.mkDerivation rec { pname = "translate-shell"; @@ -17,15 +29,17 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/trans \ - --prefix PATH : ${lib.makeBinPath [ - gawk - curl - ncurses - rlwrap - groff - fribidi - hexdump - ]} + --prefix PATH : ${ + lib.makeBinPath [ + gawk + curl + ncurses + rlwrap + groff + fribidi + hexdump + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/tr/translatelocally/package.nix b/pkgs/by-name/tr/translatelocally/package.nix index d99579a5f2a6d2..babc0bfeb3e45d 100644 --- a/pkgs/by-name/tr/translatelocally/package.nix +++ b/pkgs/by-name/tr/translatelocally/package.nix @@ -1,12 +1,24 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, qt6, libarchive, pcre2, protobuf, gperftools, blas -, runCommand, translatelocally, translatelocally-models +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qt6, + libarchive, + pcre2, + protobuf, + gperftools, + blas, + runCommand, + translatelocally, + translatelocally-models, }: let rev = "27771d884d3607cf6331da16b15e27aba819573d"; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "translatelocally"; version = "0-unstable-2024-05-12"; @@ -46,7 +58,7 @@ in stdenv.mkDerivation (finalAttrs: { libarchive pcre2 protobuf - gperftools # provides tcmalloc + gperftools # provides tcmalloc blas ]; @@ -56,16 +68,19 @@ in stdenv.mkDerivation (finalAttrs: { ]; passthru.tests = { - cli-translate = runCommand "${finalAttrs.pname}-test-cli-translate" { - nativeBuildInputs = [ - translatelocally - translatelocally-models.fr-en-tiny - ]; - } '' - export LC_ALL="C.UTF-8" - echo "Bonjour" | translateLocally -m fr-en-tiny > $out - diff "$out" <(echo "Hello") - ''; + cli-translate = + runCommand "${finalAttrs.pname}-test-cli-translate" + { + nativeBuildInputs = [ + translatelocally + translatelocally-models.fr-en-tiny + ]; + } + '' + export LC_ALL="C.UTF-8" + echo "Bonjour" | translateLocally -m fr-en-tiny > $out + diff "$out" <(echo "Hello") + ''; }; meta = with lib; { diff --git a/pkgs/by-name/tr/transmission-remote-gtk/package.nix b/pkgs/by-name/tr/transmission-remote-gtk/package.nix index 059a7371ebbf85..4b22b1bf7f2632 100644 --- a/pkgs/by-name/tr/transmission-remote-gtk/package.nix +++ b/pkgs/by-name/tr/transmission-remote-gtk/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, appstream-glib -, curl -, desktop-file-utils -, fetchFromGitHub -, geoip -, gettext -, glib -, glib-networking -, gtk3 -, json-glib -, libappindicator -, libmrss -, libproxy -, libsoup_3 -, meson -, ninja -, pkg-config -, wrapGAppsHook3 +{ + lib, + stdenv, + appstream-glib, + curl, + desktop-file-utils, + fetchFromGitHub, + geoip, + gettext, + glib, + glib-networking, + gtk3, + json-glib, + libappindicator, + libmrss, + libproxy, + libsoup_3, + meson, + ninja, + pkg-config, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/tr/transmission-rss/package.nix b/pkgs/by-name/tr/transmission-rss/package.nix index 859b8acb5b10d3..7aadbb804d4371 100644 --- a/pkgs/by-name/tr/transmission-rss/package.nix +++ b/pkgs/by-name/tr/transmission-rss/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, rustPlatform, fetchFromGitHub, pkg-config, openssl, darwin }: +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + darwin, +}: rustPlatform.buildRustPackage rec { version = "0.3.1"; @@ -15,12 +23,16 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-QNMdqoxxY8ao2O44hJxZNgLrPwzu9+ieweTPc7pfFY4="; - nativeBuildInputs = [pkg-config]; - buildInputs = [openssl] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - Security - SystemConfiguration - ]); + nativeBuildInputs = [ pkg-config ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Security + SystemConfiguration + ] + ); OPENSSL_NO_VENDOR = 1; diff --git a/pkgs/by-name/tr/transmission_3/package.nix b/pkgs/by-name/tr/transmission_3/package.nix index a97e2cbb3e7f8b..bfe4b98aa2f133 100644 --- a/pkgs/by-name/tr/transmission_3/package.nix +++ b/pkgs/by-name/tr/transmission_3/package.nix @@ -1,34 +1,35 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, openssl -, curl -, libevent -, inotify-tools -, systemd -, zlib -, pcre -, libb64 -, libutp -, miniupnpc -, dht -, libnatpmp -, libiconv +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + openssl, + curl, + libevent, + inotify-tools, + systemd, + zlib, + pcre, + libb64, + libutp, + miniupnpc, + dht, + libnatpmp, + libiconv, # Build options -, enableGTK3 ? false -, gtk3 -, xorg -, wrapGAppsHook3 -, enableQt ? false -, qt5 -, nixosTests -, enableSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, enableDaemon ? true -, enableCli ? true -, installLib ? false -, apparmorRulesFromClosure + enableGTK3 ? false, + gtk3, + xorg, + wrapGAppsHook3, + enableQt ? false, + qt5, + nixosTests, + enableSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + enableDaemon ? true, + enableCli ? true, + installLib ? false, + apparmorRulesFromClosure, }: stdenv.mkDerivation (finalAttrs: { @@ -50,7 +51,10 @@ stdenv.mkDerivation (finalAttrs: { ./transmission-3.00-miniupnpc-2.2.8.patch ]; - outputs = [ "out" "apparmor" ]; + outputs = [ + "out" + "apparmor" + ]; cmakeFlags = let @@ -65,31 +69,38 @@ stdenv.mkDerivation (finalAttrs: { "-DINSTALL_LIB=${mkFlag installLib}" ]; - nativeBuildInputs = [ - pkg-config - cmake - ] - ++ lib.optionals enableGTK3 [ wrapGAppsHook3 ] - ++ lib.optionals enableQt [ qt5.wrapQtAppsHook ] - ; + nativeBuildInputs = + [ + pkg-config + cmake + ] + ++ lib.optionals enableGTK3 [ wrapGAppsHook3 ] + ++ lib.optionals enableQt [ qt5.wrapQtAppsHook ]; - buildInputs = [ - openssl - curl - libevent - zlib - pcre - libb64 - libutp - miniupnpc - dht - libnatpmp - ] - ++ lib.optionals enableQt [ qt5.qttools qt5.qtbase ] - ++ lib.optionals enableGTK3 [ gtk3 xorg.libpthreadstubs ] - ++ lib.optionals enableSystemd [ systemd ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ inotify-tools ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; + buildInputs = + [ + openssl + curl + libevent + zlib + pcre + libb64 + libutp + miniupnpc + dht + libnatpmp + ] + ++ lib.optionals enableQt [ + qt5.qttools + qt5.qtbase + ] + ++ lib.optionals enableGTK3 [ + gtk3 + xorg.libpthreadstubs + ] + ++ lib.optionals enableSystemd [ systemd ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ inotify-tools ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; postInstall = '' mkdir $apparmor @@ -99,11 +110,21 @@ stdenv.mkDerivation (finalAttrs: { include include include - include "${apparmorRulesFromClosure { name = "transmission-daemon"; } ([ - curl libevent openssl pcre zlib libnatpmp miniupnpc - ] ++ lib.optionals enableSystemd [ systemd ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ inotify-tools ] - )}" + include "${ + apparmorRulesFromClosure { name = "transmission-daemon"; } ( + [ + curl + libevent + openssl + pcre + zlib + libnatpmp + miniupnpc + ] + ++ lib.optionals enableSystemd [ systemd ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ inotify-tools ] + ) + }" r @{PROC}/sys/kernel/random/uuid, r @{PROC}/sys/vm/overcommit_memory, r @{PROC}/@{pid}/environ, @@ -124,7 +145,13 @@ stdenv.mkDerivation (finalAttrs: { meta = { description = "Fast, easy and free BitTorrent client (deprecated version 3)"; - mainProgram = if enableQt then "transmission-qt" else if enableGTK3 then "transmission-gtk" else "transmission-cli"; + mainProgram = + if enableQt then + "transmission-qt" + else if enableGTK3 then + "transmission-gtk" + else + "transmission-cli"; longDescription = '' Transmission is a BitTorrent client which features a simple interface on top of a cross-platform back-end. diff --git a/pkgs/by-name/tr/trash-cli/package.nix b/pkgs/by-name/tr/trash-cli/package.nix index e807bff429d99d..c0aa05da5e6cea 100644 --- a/pkgs/by-name/tr/trash-cli/package.nix +++ b/pkgs/by-name/tr/trash-cli/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, installShellFiles, nix-update-script, python3Packages }: +{ + lib, + fetchFromGitHub, + installShellFiles, + nix-update-script, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "trash-cli"; @@ -11,7 +17,10 @@ python3Packages.buildPythonApplication rec { hash = "sha256-ltuMnxtG4jTTSZd6ZHWl8wI0oQMMFqW0HAPetZMfGtc="; }; - propagatedBuildInputs = with python3Packages; [ psutil six ]; + propagatedBuildInputs = with python3Packages; [ + psutil + six + ]; nativeBuildInputs = with python3Packages; [ installShellFiles diff --git a/pkgs/by-name/tr/trashy/package.nix b/pkgs/by-name/tr/trashy/package.nix index 09cbccb13c77aa..8798f7ab5ed7de 100644 --- a/pkgs/by-name/tr/trashy/package.nix +++ b/pkgs/by-name/tr/trashy/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchCrate, installShellFiles, stdenv }: +{ + lib, + rustPlatform, + fetchCrate, + installShellFiles, + stdenv, +}: rustPlatform.buildRustPackage rec { pname = "trashy"; @@ -24,7 +30,10 @@ rustPlatform.buildRustPackage rec { description = "Simple, fast, and featureful alternative to rm and trash-cli"; homepage = "https://github.com/oberblastmeister/trashy"; changelog = "https://github.com/oberblastmeister/trashy/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ oberblastmeister ]; mainProgram = "trash"; # darwin is unsupported due to https://github.com/Byron/trash-rs/issues/8 diff --git a/pkgs/by-name/tr/trayer/package.nix b/pkgs/by-name/tr/trayer/package.nix index 61976edfe96bd3..b48ed167fa6a0a 100644 --- a/pkgs/by-name/tr/trayer/package.nix +++ b/pkgs/by-name/tr/trayer/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, gdk-pixbuf, gtk2 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + gdk-pixbuf, + gtk2, +}: stdenv.mkDerivation rec { pname = "trayer"; @@ -17,7 +24,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gdk-pixbuf gtk2 ]; + buildInputs = [ + gdk-pixbuf + gtk2 + ]; makeFlags = [ "PREFIX=$(out)" ]; @@ -30,4 +40,3 @@ stdenv.mkDerivation rec { mainProgram = "trayer"; }; } - diff --git a/pkgs/by-name/tr/trayscale/package.nix b/pkgs/by-name/tr/trayscale/package.nix index 55b493cd96a1d2..449426e62c53d3 100644 --- a/pkgs/by-name/tr/trayscale/package.nix +++ b/pkgs/by-name/tr/trayscale/package.nix @@ -1,12 +1,13 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, pkg-config -, wrapGAppsHook4 -, tailscale -, gtk4 -, gobject-introspection -, libadwaita +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + wrapGAppsHook4, + tailscale, + gtk4, + gobject-introspection, + libadwaita, }: buildGoModule rec { @@ -30,8 +31,15 @@ buildGoModule rec { "-X=deedles.dev/trayscale/internal/version.version=${version}" ]; - nativeBuildInputs = [ pkg-config gobject-introspection wrapGAppsHook4 ]; - buildInputs = [ gtk4 libadwaita ]; + nativeBuildInputs = [ + pkg-config + gobject-introspection + wrapGAppsHook4 + ]; + buildInputs = [ + gtk4 + libadwaita + ]; # there are no actual tests, and it takes 20 minutes to rebuild doCheck = false; diff --git a/pkgs/by-name/tr/trdl-client/package.nix b/pkgs/by-name/tr/trdl-client/package.nix index e0d92c140ced8b..c64ac876a92af0 100644 --- a/pkgs/by-name/tr/trdl-client/package.nix +++ b/pkgs/by-name/tr/trdl-client/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, trdl-client +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + trdl-client, }: buildGoModule rec { diff --git a/pkgs/by-name/tr/tre-command/package.nix b/pkgs/by-name/tr/tre-command/package.nix index 59cb00e7095f3c..12d76e61e5df8c 100644 --- a/pkgs/by-name/tr/tre-command/package.nix +++ b/pkgs/by-name/tr/tre-command/package.nix @@ -1,4 +1,9 @@ -{ rustPlatform, fetchFromGitHub, lib, installShellFiles }: +{ + rustPlatform, + fetchFromGitHub, + lib, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "tre-command"; @@ -22,7 +27,10 @@ rustPlatform.buildRustPackage rec { ''; # this test requires package to be in a git repo to succeed - checkFlags = [ "--skip" "respect_git_ignore" ]; + checkFlags = [ + "--skip" + "respect_git_ignore" + ]; meta = with lib; { description = "Tree command, improved"; diff --git a/pkgs/by-name/tr/tre/package.nix b/pkgs/by-name/tr/tre/package.nix index 8cd0faf486730d..e016e510e8415e 100644 --- a/pkgs/by-name/tr/tre/package.nix +++ b/pkgs/by-name/tr/tre/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, fetchpatch}: +{ + lib, + stdenv, + fetchurl, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "tre"; diff --git a/pkgs/by-name/tr/tree/package.nix b/pkgs/by-name/tr/tree/package.nix index df510be36e3991..4ddf8f39726303 100644 --- a/pkgs/by-name/tr/tree/package.nix +++ b/pkgs/by-name/tr/tree/package.nix @@ -1,20 +1,27 @@ -{ lib, stdenv, fetchFromGitLab }: +{ + lib, + stdenv, + fetchFromGitLab, +}: let # These settings are found in the Makefile, but there seems to be no # way to select one or the other setting other than editing the file # manually, so we have to duplicate the know how here. - systemFlags = lib.optionalString stdenv.hostPlatform.isDarwin '' - CFLAGS="-O2 -Wall -fomit-frame-pointer -no-cpp-precomp" - LDFLAGS= - '' + lib.optionalString stdenv.hostPlatform.isCygwin '' - CFLAGS="-O2 -Wall -fomit-frame-pointer" - LDFLAGS=-s - TREE_DEST=tree.exe - '' + lib.optionalString (stdenv.hostPlatform.isFreeBSD || stdenv.hostPlatform.isOpenBSD) '' - CFLAGS="-O2 -Wall -fomit-frame-pointer" - LDFLAGS=-s - ''; # use linux flags by default + systemFlags = + lib.optionalString stdenv.hostPlatform.isDarwin '' + CFLAGS="-O2 -Wall -fomit-frame-pointer -no-cpp-precomp" + LDFLAGS= + '' + + lib.optionalString stdenv.hostPlatform.isCygwin '' + CFLAGS="-O2 -Wall -fomit-frame-pointer" + LDFLAGS=-s + TREE_DEST=tree.exe + '' + + lib.optionalString (stdenv.hostPlatform.isFreeBSD || stdenv.hostPlatform.isOpenBSD) '' + CFLAGS="-O2 -Wall -fomit-frame-pointer" + LDFLAGS=-s + ''; # use linux flags by default in stdenv.mkDerivation rec { pname = "tree"; diff --git a/pkgs/by-name/tr/treedome/package.nix b/pkgs/by-name/tr/treedome/package.nix index 64b086fd1733a0..2aa8adfdc5a20f 100644 --- a/pkgs/by-name/tr/treedome/package.nix +++ b/pkgs/by-name/tr/treedome/package.nix @@ -1,23 +1,24 @@ -{ lib -, cargo-tauri_1 -, cmake -, dbus -, fetchgit -, fetchYarnDeps -, freetype -, gsettings-desktop-schemas -, gtk3 -, libsoup_2_4 -, stdenv -, yarnConfigHook -, yarnBuildHook -, nodejs -, openssl -, pkg-config -, rustPlatform -, webkitgtk_4_0 -, wrapGAppsHook3 -, sqlite +{ + lib, + cargo-tauri_1, + cmake, + dbus, + fetchgit, + fetchYarnDeps, + freetype, + gsettings-desktop-schemas, + gtk3, + libsoup_2_4, + stdenv, + yarnConfigHook, + yarnBuildHook, + nodejs, + openssl, + pkg-config, + rustPlatform, + webkitgtk_4_0, + wrapGAppsHook3, + sqlite, }: let diff --git a/pkgs/by-name/tr/treefmt1/package.nix b/pkgs/by-name/tr/treefmt1/package.nix index ab61a50bd955fd..738ae4ef986b38 100644 --- a/pkgs/by-name/tr/treefmt1/package.nix +++ b/pkgs/by-name/tr/treefmt1/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "treefmt"; version = "0.6.1"; diff --git a/pkgs/by-name/tr/treefmt2/package.nix b/pkgs/by-name/tr/treefmt2/package.nix index 46a3913cbadcf0..5e7e568a94acd8 100644 --- a/pkgs/by-name/tr/treefmt2/package.nix +++ b/pkgs/by-name/tr/treefmt2/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "treefmt"; version = "2.1.1"; @@ -27,7 +31,10 @@ buildGoModule rec { description = "one CLI to format the code tree"; homepage = "https://github.com/numtide/treefmt"; license = lib.licenses.mit; - maintainers = [ lib.maintainers.brianmcgee lib.maintainers.zimbatm ]; + maintainers = [ + lib.maintainers.brianmcgee + lib.maintainers.zimbatm + ]; mainProgram = "treefmt"; }; } diff --git a/pkgs/by-name/tr/treemix/package.nix b/pkgs/by-name/tr/treemix/package.nix index 7bf966919a67ef..f9a0fe9adcb17d 100644 --- a/pkgs/by-name/tr/treemix/package.nix +++ b/pkgs/by-name/tr/treemix/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, zlib -, gsl -, boost +{ + lib, + stdenv, + fetchurl, + zlib, + gsl, + boost, }: stdenv.mkDerivation rec { @@ -15,9 +16,13 @@ stdenv.mkDerivation rec { sha256 = "1nd3rzsdgk47r8b8k43mdfvaagln533sm08s1jr0dz8km8nlym7y"; }; - buildInputs = [ zlib gsl boost ]; + buildInputs = [ + zlib + gsl + boost + ]; - meta = with lib ; { + meta = with lib; { description = "Inference of patterns of population splitting and mixing from genome-wide allele frequency data"; homepage = "https://bitbucket.org/nygcresearch/treemix/wiki/Home"; license = licenses.gpl3Only; diff --git a/pkgs/by-name/tr/trellis/package.nix b/pkgs/by-name/tr/trellis/package.nix index 5726465311e54f..f69007967b2deb 100644 --- a/pkgs/by-name/tr/trellis/package.nix +++ b/pkgs/by-name/tr/trellis/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, python3, boost, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + boost, + cmake, +}: let rev = "488f4e71073062de314c55a037ede7cf03a3324c"; @@ -6,30 +13,37 @@ let realVersion = "1.2.1-14-g${builtins.substring 0 7 rev}"; main_src = fetchFromGitHub { - owner = "YosysHQ"; - repo = "prjtrellis"; + owner = "YosysHQ"; + repo = "prjtrellis"; inherit rev; - hash = "sha256-Blbu+0rlM/3izbF0XCvkNpSAND0IclWEwK7anzyrpvw="; - name = "trellis"; + hash = "sha256-Blbu+0rlM/3izbF0XCvkNpSAND0IclWEwK7anzyrpvw="; + name = "trellis"; }; database_src = fetchFromGitHub { - owner = "YosysHQ"; - repo = "prjtrellis-db"; - rev = "35d900a94ff0db152679a67bf6e4fbf40ebc34aa"; - hash = "sha256-r6viR8y9ZjURGNbsa0/YY8lzy9kGzjuu408ntxwpqm0="; - name = "trellis-database"; + owner = "YosysHQ"; + repo = "prjtrellis-db"; + rev = "35d900a94ff0db152679a67bf6e4fbf40ebc34aa"; + hash = "sha256-r6viR8y9ZjURGNbsa0/YY8lzy9kGzjuu408ntxwpqm0="; + name = "trellis-database"; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "trellis"; version = "unstable-2022-09-14"; - srcs = [ main_src database_src ]; + srcs = [ + main_src + database_src + ]; sourceRoot = main_src.name; buildInputs = [ boost ]; - nativeBuildInputs = [ cmake python3 ]; + nativeBuildInputs = [ + cmake + python3 + ]; cmakeFlags = [ "-DCURRENT_GIT_VERSION=${realVersion}" # TODO: should this be in stdenv instead? @@ -55,16 +69,20 @@ in stdenv.mkDerivation rec { ''; meta = with lib; { - description = "Documentation and bitstream tools for Lattice ECP5 FPGAs"; + description = "Documentation and bitstream tools for Lattice ECP5 FPGAs"; longDescription = '' Project Trellis documents the Lattice ECP5 architecture to enable development of open-source tools. Its goal is to provide sufficient information to develop a free and open Verilog to bitstream toolchain for these devices. ''; - homepage = "https://github.com/YosysHQ/prjtrellis"; - license = licenses.isc; - maintainers = with maintainers; [ q3k thoughtpolice rowanG077 ]; - platforms = platforms.all; + homepage = "https://github.com/YosysHQ/prjtrellis"; + license = licenses.isc; + maintainers = with maintainers; [ + q3k + thoughtpolice + rowanG077 + ]; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/tr/tremc/package.nix b/pkgs/by-name/tr/tremc/package.nix index 98ab36dac08a00..adfdebdee73782 100644 --- a/pkgs/by-name/tr/tremc/package.nix +++ b/pkgs/by-name/tr/tremc/package.nix @@ -1,13 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, python3Packages -, x11Support ? !stdenv.hostPlatform.isDarwin -, xclip ? null -, pbcopy ? null -, useGeoIP ? false # Require /var/lib/geoip-databases/GeoIP.dat +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + python3Packages, + x11Support ? !stdenv.hostPlatform.isDarwin, + xclip ? null, + pbcopy ? null, + useGeoIP ? false, # Require /var/lib/geoip-databases/GeoIP.dat }: let wrapperPath = lib.makeBinPath ( - lib.optional x11Support xclip ++ - lib.optional stdenv.hostPlatform.isDarwin pbcopy + lib.optional x11Support xclip ++ lib.optional stdenv.hostPlatform.isDarwin pbcopy ); in python3Packages.buildPythonApplication rec { @@ -36,16 +40,18 @@ python3Packages.buildPythonApplication rec { wrapPython ]; - pythonPath = with python3Packages; [ - ipy - pyperclip - ] ++ - lib.optional useGeoIP geoip; + pythonPath = + with python3Packages; + [ + ipy + pyperclip + ] + ++ lib.optional useGeoIP geoip; dontBuild = true; doCheck = false; - makeWrapperArgs = ["--prefix PATH : ${lib.escapeShellArg wrapperPath}"]; + makeWrapperArgs = [ "--prefix PATH : ${lib.escapeShellArg wrapperPath}" ]; installPhase = '' make DESTDIR=$out install diff --git a/pkgs/by-name/tr/tremor/package.nix b/pkgs/by-name/tr/tremor/package.nix index 0477b6ca6d116f..e8fb12f8ab9ed5 100644 --- a/pkgs/by-name/tr/tremor/package.nix +++ b/pkgs/by-name/tr/tremor/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitLab, autoreconfHook, pkg-config, libogg }: +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + libogg, +}: stdenv.mkDerivation { pname = "tremor"; @@ -12,11 +19,19 @@ stdenv.mkDerivation { sha256 = "0m07gq4zfgigsiz8b518xyb19v7qqp76qmp7lb262825vkqzl3zq"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - configureFlags = lib.optional (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") "LDFLAGS=-Wl,--undefined-version"; + configureFlags = lib.optional ( + stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17" + ) "LDFLAGS=-Wl,--undefined-version"; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; propagatedBuildInputs = [ libogg ]; preConfigure = '' diff --git a/pkgs/by-name/tr/trexio/package.nix b/pkgs/by-name/tr/trexio/package.nix index da9770a6dff6af..d215faec0ab6dc 100644 --- a/pkgs/by-name/tr/trexio/package.nix +++ b/pkgs/by-name/tr/trexio/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, gfortran -, hdf5 -, python3 -, emacs -, swig +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + gfortran, + hdf5, + python3, + emacs, + swig, }: stdenv.mkDerivation rec { @@ -36,7 +37,10 @@ stdenv.mkDerivation rec { hdf5 ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; doCheck = true; diff --git a/pkgs/by-name/tr/trezor-suite/package.nix b/pkgs/by-name/tr/trezor-suite/package.nix index 91e02485833a00..f246c84e768066 100644 --- a/pkgs/by-name/tr/trezor-suite/package.nix +++ b/pkgs/by-name/tr/trezor-suite/package.nix @@ -1,26 +1,32 @@ -{ lib -, stdenv -, fetchurl -, appimageTools -, tor -, trezord +{ + lib, + stdenv, + fetchurl, + appimageTools, + tor, + trezord, }: let pname = "trezor-suite"; version = "24.11.3"; - suffix = { - aarch64-linux = "linux-arm64"; - x86_64-linux = "linux-x86_64"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + suffix = + { + aarch64-linux = "linux-arm64"; + x86_64-linux = "linux-x86_64"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); src = fetchurl { url = "https://github.com/trezor/trezor-suite/releases/download/v${version}/Trezor-Suite-${version}-${suffix}.AppImage"; - hash = { # curl -Lfs https://github.com/trezor/trezor-suite/releases/download/v${version}/latest-linux{-arm64,}.yml | grep ^sha512 | sed 's/: /-/' - aarch64-linux = "sha512-erNWQTaj/WWoqy3TO7wb+ijQkwXjqfCjqvQN6/9gCVjbHswURWHX36P0rJg9vuQu6odi5EKtooDusIxjIUkQzA=="; - x86_64-linux = "sha512-BorpJI0Vi6fFRGo2lATcuBiI1vTLY8vfmnUXKckJkMCBiurs/ZR08ZxKPOTaoS61BzSanUCRwcovev294bcqkA=="; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + hash = + { + # curl -Lfs https://github.com/trezor/trezor-suite/releases/download/v${version}/latest-linux{-arm64,}.yml | grep ^sha512 | sed 's/: /-/' + aarch64-linux = "sha512-erNWQTaj/WWoqy3TO7wb+ijQkwXjqfCjqvQN6/9gCVjbHswURWHX36P0rJg9vuQu6odi5EKtooDusIxjIUkQzA=="; + x86_64-linux = "sha512-BorpJI0Vi6fFRGo2lATcuBiI1vTLY8vfmnUXKckJkMCBiurs/ZR08ZxKPOTaoS61BzSanUCRwcovev294bcqkA=="; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); }; appimageContents = appimageTools.extractType2 { @@ -56,7 +62,10 @@ appimageTools.wrapType2 rec { changelog = "https://github.com/trezor/trezor-suite/releases/tag/v${version}"; license = licenses.unfree; maintainers = with maintainers; [ prusnak ]; - platforms = [ "aarch64-linux" "x86_64-linux" ]; + platforms = [ + "aarch64-linux" + "x86_64-linux" + ]; mainProgram = "trezor-suite"; }; } diff --git a/pkgs/by-name/tr/trezor-udev-rules/package.nix b/pkgs/by-name/tr/trezor-udev-rules/package.nix index c631b571273338..0c7f9871c40567 100644 --- a/pkgs/by-name/tr/trezor-udev-rules/package.nix +++ b/pkgs/by-name/tr/trezor-udev-rules/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, nixosTests }: +{ + lib, + stdenv, + fetchurl, + nixosTests, +}: stdenv.mkDerivation rec { pname = "trezor-udev-rules"; diff --git a/pkgs/by-name/tr/trf/package.nix b/pkgs/by-name/tr/trf/package.nix index f36788eb612c53..3bd1f19bbec6d4 100644 --- a/pkgs/by-name/tr/trf/package.nix +++ b/pkgs/by-name/tr/trf/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "trf"; diff --git a/pkgs/by-name/tr/trickle/package.nix b/pkgs/by-name/tr/trickle/package.nix index c1640a259969d6..2ade49893aca4c 100644 --- a/pkgs/by-name/tr/trickle/package.nix +++ b/pkgs/by-name/tr/trickle/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libevent, libtirpc }: +{ + lib, + stdenv, + fetchurl, + libevent, + libtirpc, +}: stdenv.mkDerivation rec { pname = "trickle"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "0s1qq3k5mpcs9i7ng0l9fvr1f75abpbzfi1jaf3zpzbs1dz50dlx"; }; - buildInputs = [ libevent libtirpc ]; + buildInputs = [ + libevent + libtirpc + ]; preConfigure = '' sed -i 's|libevent.a|libevent.so|' configure @@ -19,7 +28,10 @@ stdenv.mkDerivation rec { sed -i '/#define in_addr_t/ s:^://:' config.h ''; - NIX_LDFLAGS = [ "-levent" "-ltirpc" ]; + NIX_LDFLAGS = [ + "-levent" + "-ltirpc" + ]; env.NIX_CFLAGS_COMPILE = toString [ "-I${libtirpc.dev}/include/tirpc" ]; configureFlags = [ "--with-libevent" ]; diff --git a/pkgs/by-name/tr/tridactyl-native/package.nix b/pkgs/by-name/tr/tridactyl-native/package.nix index cb9e411b1f0df1..c97b8cad336503 100644 --- a/pkgs/by-name/tr/tridactyl-native/package.nix +++ b/pkgs/by-name/tr/tridactyl-native/package.nix @@ -1,4 +1,8 @@ -{ lib, buildNimPackage, fetchFromGitHub }: +{ + lib, + buildNimPackage, + fetchFromGitHub, +}: buildNimPackage { pname = "tridactyl-native"; version = "0.4.1"; @@ -19,12 +23,15 @@ buildNimPackage { ''; meta = with lib; { - description = - "Native messenger for Tridactyl, a vim-like Firefox webextension"; + description = "Native messenger for Tridactyl, a vim-like Firefox webextension"; mainProgram = "native_main"; homepage = "https://github.com/tridactyl/native_messenger"; license = licenses.bsd2; platforms = platforms.all; - maintainers = with maintainers; [ timokau dit7ya kiike ]; + maintainers = with maintainers; [ + timokau + dit7ya + kiike + ]; }; } diff --git a/pkgs/by-name/tr/triehash/package.nix b/pkgs/by-name/tr/triehash/package.nix index e9d8a92e2c2e31..47b1d72d672c65 100644 --- a/pkgs/by-name/tr/triehash/package.nix +++ b/pkgs/by-name/tr/triehash/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, perlPackages +{ + lib, + stdenv, + fetchFromGitHub, + perlPackages, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/tr/trigger-control/package.nix b/pkgs/by-name/tr/trigger-control/package.nix index 838aae472d64e3..ae189e2ca50583 100644 --- a/pkgs/by-name/tr/trigger-control/package.nix +++ b/pkgs/by-name/tr/trigger-control/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, makeWrapper -, pkg-config -, SDL2 -, dbus -, libdecor -, libnotify -, dejavu_fonts -, zenity +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + makeWrapper, + pkg-config, + SDL2, + dbus, + libdecor, + libnotify, + dejavu_fonts, + zenity, }: stdenv.mkDerivation (finalAttrs: { @@ -32,13 +33,15 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = [ - SDL2 - dbus - libnotify - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libdecor - ]; + buildInputs = + [ + SDL2 + dbus + libnotify + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libdecor + ]; patches = [ # Fix build on clang https://github.com/Etaash-mathamsetty/trigger-control/pull/23 diff --git a/pkgs/by-name/tr/trigger/package.nix b/pkgs/by-name/tr/trigger/package.nix index 86b47f554193e9..683f3eaef8e08c 100644 --- a/pkgs/by-name/tr/trigger/package.nix +++ b/pkgs/by-name/tr/trigger/package.nix @@ -1,5 +1,21 @@ -{ lib, fetchurl, stdenv, runtimeShell, SDL2, freealut, SDL2_image, openal, physfs -, zlib, libGLU, libGL, glew, tinyxml-2, copyDesktopItems, makeDesktopItem }: +{ + lib, + fetchurl, + stdenv, + runtimeShell, + SDL2, + freealut, + SDL2_image, + openal, + physfs, + zlib, + libGLU, + libGL, + glew, + tinyxml-2, + copyDesktopItems, + makeDesktopItem, +}: stdenv.mkDerivation rec { pname = "trigger-rally"; @@ -56,7 +72,10 @@ stdenv.mkDerivation rec { icon = "trigger"; desktopName = "Trigger"; comment = "Fast-paced 3D single-player rally racing game"; - categories = [ "Game" "ActionGame" ]; + categories = [ + "Game" + "ActionGame" + ]; }) ]; diff --git a/pkgs/by-name/tr/triggerhappy/package.nix b/pkgs/by-name/tr/triggerhappy/package.nix index d35a6ebf072fb6..a70060e36e6a95 100644 --- a/pkgs/by-name/tr/triggerhappy/package.nix +++ b/pkgs/by-name/tr/triggerhappy/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, perl, systemd }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + perl, + systemd, +}: stdenv.mkDerivation rec { pname = "triggerhappy"; @@ -11,10 +18,16 @@ stdenv.mkDerivation rec { sha256 = "0gb1qhrxwq7i5abd408d01a2dpf28nr1fph1fg7w7n0i5i1nnk90"; }; - nativeBuildInputs = [ pkg-config perl ]; + nativeBuildInputs = [ + pkg-config + perl + ]; buildInputs = [ systemd ]; - makeFlags = [ "PREFIX=$(out)" "BINDIR=$(out)/bin" ]; + makeFlags = [ + "PREFIX=$(out)" + "BINDIR=$(out)/bin" + ]; postInstall = '' install -D -m 644 -t "$out/etc/triggerhappy/triggers.d" "triggerhappy.conf.examples" diff --git a/pkgs/by-name/tr/trillian-im/package.nix b/pkgs/by-name/tr/trillian-im/package.nix index a31adac9568f38..1f89d57294d8d2 100644 --- a/pkgs/by-name/tr/trillian-im/package.nix +++ b/pkgs/by-name/tr/trillian-im/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, dpkg -, atkmm -, cairo -, cairomm -, gtk3 -, gtkmm3 -, libnotify -, libsecret -, pangomm -, xorg -, libpulseaudio -, librsvg -, libzip -, openssl -, webkitgtk_4_0 -, libappindicator-gtk3 +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + dpkg, + atkmm, + cairo, + cairomm, + gtk3, + gtkmm3, + libnotify, + libsecret, + pangomm, + xorg, + libpulseaudio, + librsvg, + libzip, + openssl, + webkitgtk_4_0, + libappindicator-gtk3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/tr/trillian/package.nix b/pkgs/by-name/tr/trillian/package.nix index 90017e2186a523..932edcfbb907fc 100644 --- a/pkgs/by-name/tr/trillian/package.nix +++ b/pkgs/by-name/tr/trillian/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/tr/trimal/package.nix b/pkgs/by-name/tr/trimal/package.nix index f822fe50b16483..43c1730325c613 100644 --- a/pkgs/by-name/tr/trimal/package.nix +++ b/pkgs/by-name/tr/trimal/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "trimal"; diff --git a/pkgs/by-name/tr/trino-cli/package.nix b/pkgs/by-name/tr/trino-cli/package.nix index e52881c6f5f5b3..77231e48edda70 100644 --- a/pkgs/by-name/tr/trino-cli/package.nix +++ b/pkgs/by-name/tr/trino-cli/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre_headless, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre_headless, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "trino-cli"; @@ -31,6 +37,9 @@ stdenv.mkDerivation rec { mainProgram = "trino"; homepage = "https://github.com/trinodb/trino"; license = licenses.asl20; - maintainers = with maintainers; [ regadas cpcloud ]; + maintainers = with maintainers; [ + regadas + cpcloud + ]; }; } diff --git a/pkgs/by-name/tr/triton-llvm/package.nix b/pkgs/by-name/tr/triton-llvm/package.nix index 829f0c912afd24..3d0e1661763ea7 100644 --- a/pkgs/by-name/tr/triton-llvm/package.nix +++ b/pkgs/by-name/tr/triton-llvm/package.nix @@ -1,61 +1,82 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, pkgsBuildBuild -, pkg-config -, cmake -, ninja -, git -, libxml2 -, libxcrypt -, libedit -, libffi -, libpfm -, lit -, mpfr -, zlib -, ncurses -, doxygen -, sphinx -, which -, sysctl -, python3Packages -, buildDocs ? true -, buildMan ? true -, buildTests ? true -, llvmTargetsToBuild ? [ "NATIVE" ] # "NATIVE" resolves into x86 or aarch64 depending on stdenv -, llvmProjectsToBuild ? [ "llvm" "mlir" ] +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkgsBuildBuild, + pkg-config, + cmake, + ninja, + git, + libxml2, + libxcrypt, + libedit, + libffi, + libpfm, + lit, + mpfr, + zlib, + ncurses, + doxygen, + sphinx, + which, + sysctl, + python3Packages, + buildDocs ? true, + buildMan ? true, + buildTests ? true, + llvmTargetsToBuild ? [ "NATIVE" ], # "NATIVE" resolves into x86 or aarch64 depending on stdenv + llvmProjectsToBuild ? [ + "llvm" + "mlir" + ], }: let llvmNativeTarget = - if stdenv.hostPlatform.isx86_64 then "X86" - else if stdenv.hostPlatform.isAarch64 then "AArch64" - else throw "Currently unsupported LLVM platform '${stdenv.hostPlatform.config}'"; + if stdenv.hostPlatform.isx86_64 then + "X86" + else if stdenv.hostPlatform.isAarch64 then + "AArch64" + else + throw "Currently unsupported LLVM platform '${stdenv.hostPlatform.config}'"; inferNativeTarget = t: if t == "NATIVE" then llvmNativeTarget else t; - llvmTargetsToBuild' = [ "AMDGPU" "NVPTX" ] ++ builtins.map inferNativeTarget llvmTargetsToBuild; + llvmTargetsToBuild' = [ + "AMDGPU" + "NVPTX" + ] ++ builtins.map inferNativeTarget llvmTargetsToBuild; # This LLVM version can't seem to find pygments/pyyaml, # but a later update will likely fix this (triton-2.1.0) python = - if buildTests - then python3Packages.python.withPackages (p: with p; [ psutil pygments pyyaml ]) - else python3Packages.python; + if buildTests then + python3Packages.python.withPackages ( + p: with p; [ + psutil + pygments + pyyaml + ] + ) + else + python3Packages.python; isNative = stdenv.hostPlatform == stdenv.buildPlatform; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "triton-llvm"; version = "19.1.0-rc1"; # One of the tags at https://github.com/llvm/llvm-project/commit/10dc3a8e916d73291269e5e2b82dd22681489aa1 - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ] ++ lib.optionals buildMan [ - "man" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ] + ++ lib.optionals buildMan [ + "man" + ]; # See https://github.com/triton-lang/triton/blob/main/python/setup.py # and https://github.com/ptillet/triton-llvm-releases/releases @@ -75,18 +96,20 @@ in stdenv.mkDerivation (finalAttrs: { }) ]; - nativeBuildInputs = [ - pkg-config - cmake - ninja - git - python - ] ++ lib.optionals (buildDocs || buildMan) [ - doxygen - sphinx - python3Packages.recommonmark - python3Packages.myst-parser - ]; + nativeBuildInputs = + [ + pkg-config + cmake + ninja + git + python + ] + ++ lib.optionals (buildDocs || buildMan) [ + doxygen + sphinx + python3Packages.recommonmark + python3Packages.myst-parser + ]; buildInputs = [ libxml2 @@ -106,78 +129,94 @@ in stdenv.mkDerivation (finalAttrs: { cd llvm ''; - cmakeFlags = [ - (lib.cmakeFeature "LLVM_TARGETS_TO_BUILD" (lib.concatStringsSep ";" llvmTargetsToBuild')) - (lib.cmakeFeature "LLVM_ENABLE_PROJECTS" (lib.concatStringsSep ";" llvmProjectsToBuild)) - (lib.cmakeFeature "LLVM_HOST_TRIPLE" stdenv.hostPlatform.config) - (lib.cmakeFeature "LLVM_DEFAULT_TARGET_TRIPLE" stdenv.hostPlatform.config) - (lib.cmakeBool "LLVM_INSTALL_UTILS" true) - (lib.cmakeBool "LLVM_INCLUDE_DOCS" (buildDocs || buildMan)) - (lib.cmakeBool "MLIR_INCLUDE_DOCS" (buildDocs || buildMan)) - (lib.cmakeBool "LLVM_BUILD_DOCS" (buildDocs || buildMan)) - # Way too slow, only uses one core - # (lib.cmakeBool "LLVM_ENABLE_DOXYGEN" (buildDocs || buildMan)) - (lib.cmakeBool "LLVM_ENABLE_SPHINX" (buildDocs || buildMan)) - (lib.cmakeBool "SPHINX_OUTPUT_HTML" buildDocs) - (lib.cmakeBool "SPHINX_OUTPUT_MAN" buildMan) - (lib.cmakeBool "SPHINX_WARNINGS_AS_ERRORS" false) - (lib.cmakeBool "LLVM_INCLUDE_TESTS" buildTests) - (lib.cmakeBool "MLIR_INCLUDE_TESTS" buildTests) - (lib.cmakeBool "LLVM_BUILD_TESTS" buildTests) - # Cross compilation code taken/modified from LLVM 16 derivation - ] ++ lib.optionals (!isNative) (let - nativeToolchainFlags = let - nativeCC = pkgsBuildBuild.targetPackages.stdenv.cc; - nativeBintools = nativeCC.bintools.bintools; - in [ - (lib.cmakeFeature "CMAKE_C_COMPILER" "${nativeCC}/bin/${nativeCC.targetPrefix}cc") - (lib.cmakeFeature "CMAKE_CXX_COMPILER" "${nativeCC}/bin/${nativeCC.targetPrefix}c++") - (lib.cmakeFeature "CMAKE_AR" "${nativeBintools}/bin/${nativeBintools.targetPrefix}ar") - (lib.cmakeFeature "CMAKE_STRIP" "${nativeBintools}/bin/${nativeBintools.targetPrefix}strip") - (lib.cmakeFeature "CMAKE_RANLIB" "${nativeBintools}/bin/${nativeBintools.targetPrefix}ranlib") - ]; - - # We need to repass the custom GNUInstallDirs values, otherwise CMake - # will choose them for us, leading to wrong results in llvm-config-native - nativeInstallFlags = [ - (lib.cmakeFeature "CMAKE_INSTALL_PREFIX" (placeholder "out")) - (lib.cmakeFeature "CMAKE_INSTALL_BINDIR" "${placeholder "out"}/bin") - (lib.cmakeFeature "CMAKE_INSTALL_INCLUDEDIR" "${placeholder "out"}/include") - (lib.cmakeFeature "CMAKE_INSTALL_LIBDIR" "${placeholder "out"}/lib") - (lib.cmakeFeature "CMAKE_INSTALL_LIBEXECDIR" "${placeholder "out"}/libexec") - ]; - in [ - (lib.cmakeBool "CMAKE_CROSSCOMPILING" true) - (lib.cmakeFeature "CROSS_TOOLCHAIN_FLAGS_NATIVE" (lib.concatStringsSep ";" - (lib.concatLists [ nativeToolchainFlags nativeInstallFlags ]))) - ]); - - postPatch = '' - # `CMake Error: cannot write to file "/build/source/llvm/build/lib/cmake/mlir/MLIRTargets.cmake": Permission denied` - chmod +w -R ./mlir - patchShebangs ./mlir/test/mlir-reduce - - # FileSystem permissions tests fail with various special bits - rm llvm/test/tools/llvm-objcopy/ELF/mirror-permissions-unix.test - rm llvm/unittests/Support/Path.cpp - - substituteInPlace llvm/unittests/Support/CMakeLists.txt \ - --replace "Path.cpp" "" - '' + lib.optionalString stdenv.hostPlatform.isAarch64 '' - # Not sure why this fails - rm llvm/test/tools/llvm-exegesis/AArch64/latency-by-opcode-name.s - ''; - - postInstall = '' - cp ${lib.getExe lit} $out/bin/llvm-lit - '' + (lib.optionalString (!isNative) '' - cp -a NATIVE/bin/llvm-config $out/bin/llvm-config-native - ''); + cmakeFlags = + [ + (lib.cmakeFeature "LLVM_TARGETS_TO_BUILD" (lib.concatStringsSep ";" llvmTargetsToBuild')) + (lib.cmakeFeature "LLVM_ENABLE_PROJECTS" (lib.concatStringsSep ";" llvmProjectsToBuild)) + (lib.cmakeFeature "LLVM_HOST_TRIPLE" stdenv.hostPlatform.config) + (lib.cmakeFeature "LLVM_DEFAULT_TARGET_TRIPLE" stdenv.hostPlatform.config) + (lib.cmakeBool "LLVM_INSTALL_UTILS" true) + (lib.cmakeBool "LLVM_INCLUDE_DOCS" (buildDocs || buildMan)) + (lib.cmakeBool "MLIR_INCLUDE_DOCS" (buildDocs || buildMan)) + (lib.cmakeBool "LLVM_BUILD_DOCS" (buildDocs || buildMan)) + # Way too slow, only uses one core + # (lib.cmakeBool "LLVM_ENABLE_DOXYGEN" (buildDocs || buildMan)) + (lib.cmakeBool "LLVM_ENABLE_SPHINX" (buildDocs || buildMan)) + (lib.cmakeBool "SPHINX_OUTPUT_HTML" buildDocs) + (lib.cmakeBool "SPHINX_OUTPUT_MAN" buildMan) + (lib.cmakeBool "SPHINX_WARNINGS_AS_ERRORS" false) + (lib.cmakeBool "LLVM_INCLUDE_TESTS" buildTests) + (lib.cmakeBool "MLIR_INCLUDE_TESTS" buildTests) + (lib.cmakeBool "LLVM_BUILD_TESTS" buildTests) + # Cross compilation code taken/modified from LLVM 16 derivation + ] + ++ lib.optionals (!isNative) ( + let + nativeToolchainFlags = + let + nativeCC = pkgsBuildBuild.targetPackages.stdenv.cc; + nativeBintools = nativeCC.bintools.bintools; + in + [ + (lib.cmakeFeature "CMAKE_C_COMPILER" "${nativeCC}/bin/${nativeCC.targetPrefix}cc") + (lib.cmakeFeature "CMAKE_CXX_COMPILER" "${nativeCC}/bin/${nativeCC.targetPrefix}c++") + (lib.cmakeFeature "CMAKE_AR" "${nativeBintools}/bin/${nativeBintools.targetPrefix}ar") + (lib.cmakeFeature "CMAKE_STRIP" "${nativeBintools}/bin/${nativeBintools.targetPrefix}strip") + (lib.cmakeFeature "CMAKE_RANLIB" "${nativeBintools}/bin/${nativeBintools.targetPrefix}ranlib") + ]; + + # We need to repass the custom GNUInstallDirs values, otherwise CMake + # will choose them for us, leading to wrong results in llvm-config-native + nativeInstallFlags = [ + (lib.cmakeFeature "CMAKE_INSTALL_PREFIX" (placeholder "out")) + (lib.cmakeFeature "CMAKE_INSTALL_BINDIR" "${placeholder "out"}/bin") + (lib.cmakeFeature "CMAKE_INSTALL_INCLUDEDIR" "${placeholder "out"}/include") + (lib.cmakeFeature "CMAKE_INSTALL_LIBDIR" "${placeholder "out"}/lib") + (lib.cmakeFeature "CMAKE_INSTALL_LIBEXECDIR" "${placeholder "out"}/libexec") + ]; + in + [ + (lib.cmakeBool "CMAKE_CROSSCOMPILING" true) + (lib.cmakeFeature "CROSS_TOOLCHAIN_FLAGS_NATIVE" ( + lib.concatStringsSep ";" ( + lib.concatLists [ + nativeToolchainFlags + nativeInstallFlags + ] + ) + )) + ] + ); + + postPatch = + '' + # `CMake Error: cannot write to file "/build/source/llvm/build/lib/cmake/mlir/MLIRTargets.cmake": Permission denied` + chmod +w -R ./mlir + patchShebangs ./mlir/test/mlir-reduce + + # FileSystem permissions tests fail with various special bits + rm llvm/test/tools/llvm-objcopy/ELF/mirror-permissions-unix.test + rm llvm/unittests/Support/Path.cpp + + substituteInPlace llvm/unittests/Support/CMakeLists.txt \ + --replace "Path.cpp" "" + '' + + lib.optionalString stdenv.hostPlatform.isAarch64 '' + # Not sure why this fails + rm llvm/test/tools/llvm-exegesis/AArch64/latency-by-opcode-name.s + ''; + + postInstall = + '' + cp ${lib.getExe lit} $out/bin/llvm-lit + '' + + (lib.optionalString (!isNative) '' + cp -a NATIVE/bin/llvm-config $out/bin/llvm-config-native + ''); doCheck = buildTests; - nativeCheckInputs = [ which ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ sysctl ]; + nativeCheckInputs = [ which ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ sysctl ]; checkTarget = "check-all"; requiredSystemFeatures = [ "big-parallel" ]; @@ -186,7 +225,10 @@ in stdenv.mkDerivation (finalAttrs: { description = "Collection of modular and reusable compiler and toolchain technologies"; homepage = "https://github.com/llvm/llvm-project"; license = with licenses; [ ncsa ]; - maintainers = with maintainers; [ SomeoneSerge Madouura ]; + maintainers = with maintainers; [ + SomeoneSerge + Madouura + ]; platforms = with platforms; aarch64 ++ x86; }; }) diff --git a/pkgs/by-name/tr/triton/package.nix b/pkgs/by-name/tr/triton/package.nix index 38309e94cdee6b..3d3a383bfda07c 100644 --- a/pkgs/by-name/tr/triton/package.nix +++ b/pkgs/by-name/tr/triton/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, installShellFiles -, testers -, triton +{ + lib, + buildNpmPackage, + fetchFromGitHub, + installShellFiles, + testers, + triton, }: buildNpmPackage rec { diff --git a/pkgs/by-name/tr/trompeloeil/package.nix b/pkgs/by-name/tr/trompeloeil/package.nix index 3f6a8bb98c62e5..09098810b63eb7 100644 --- a/pkgs/by-name/tr/trompeloeil/package.nix +++ b/pkgs/by-name/tr/trompeloeil/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "trompeloeil"; diff --git a/pkgs/by-name/tr/troubadix/package.nix b/pkgs/by-name/tr/troubadix/package.nix index 2d4a6fc7f2c140..c46c3b4c1892dc 100644 --- a/pkgs/by-name/tr/troubadix/package.nix +++ b/pkgs/by-name/tr/troubadix/package.nix @@ -21,7 +21,6 @@ python3.pkgs.buildPythonApplication rec { build-system = with python3.pkgs; [ poetry-core ]; - dependencies = with python3.pkgs; [ chardet charset-normalizer diff --git a/pkgs/by-name/tr/trousers/package.nix b/pkgs/by-name/tr/trousers/package.nix index 43d0941b47b698..0cff55be007def 100644 --- a/pkgs/by-name/tr/trousers/package.nix +++ b/pkgs/by-name/tr/trousers/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, openssl, pkg-config, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + openssl, + pkg-config, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "trousers"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "0zy7r9cnr2gvwr2fb1q4fc5xnvx405ymcbrdv7qsqwl3a4zfjnqy"; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; buildInputs = [ openssl ]; patches = [ ./allow-non-tss-config-file-owner.patch ]; @@ -22,9 +32,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Trusted computing software stack"; mainProgram = "tcsd"; - homepage = "https://trousers.sourceforge.net/"; - license = licenses.bsd3; + homepage = "https://trousers.sourceforge.net/"; + license = licenses.bsd3; maintainers = [ maintainers.ak ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/tr/trrntzip/package.nix b/pkgs/by-name/tr/trrntzip/package.nix index 633de93797adb8..d0f5d813deeae1 100644 --- a/pkgs/by-name/tr/trrntzip/package.nix +++ b/pkgs/by-name/tr/trrntzip/package.nix @@ -7,11 +7,12 @@ # Besides the new one is on github instead of sourceforge # which makes life for us easier -{ lib -, stdenv -, fetchFromGitHub -, cmake -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/tr/truecrack/package.nix b/pkgs/by-name/tr/truecrack/package.nix index 06a0d7e4f6b2eb..c8fee97c8e1bd5 100644 --- a/pkgs/by-name/tr/truecrack/package.nix +++ b/pkgs/by-name/tr/truecrack/package.nix @@ -1,7 +1,12 @@ -{ lib, gccStdenv, fetchFromGitLab, cudatoolkit -, config -, cudaSupport ? config.cudaSupport -, pkg-config }: +{ + lib, + gccStdenv, + fetchFromGitLab, + cudatoolkit, + config, + cudaSupport ? config.cudaSupport, + pkg-config, +}: gccStdenv.mkDerivation rec { pname = "truecrack"; @@ -14,11 +19,16 @@ gccStdenv.mkDerivation rec { sha256 = "+Rw9SfaQtO1AJO6UVVDMCo8DT0dYEbv7zX8SI+pHCRQ="; }; - configureFlags = (if cudaSupport then [ - "--with-cuda=${cudatoolkit}" - ] else [ - "--enable-cpu" - ]); + configureFlags = ( + if cudaSupport then + [ + "--with-cuda=${cudatoolkit}" + ] + else + [ + "--enable-cpu" + ] + ); nativeBuildInputs = [ pkg-config diff --git a/pkgs/by-name/tr/trunk-ng/package.nix b/pkgs/by-name/tr/trunk-ng/package.nix index 73af1faaba29e9..8c914af48f3eb6 100644 --- a/pkgs/by-name/tr/trunk-ng/package.nix +++ b/pkgs/by-name/tr/trunk-ng/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, pkg-config -, openssl, libiconv, CoreServices, Security, SystemConfiguration }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + libiconv, + CoreServices, + Security, + SystemConfiguration, +}: rustPlatform.buildRustPackage rec { pname = "trunk-ng"; @@ -13,17 +23,27 @@ rustPlatform.buildRustPackage rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = if stdenv.hostPlatform.isDarwin - then [ libiconv CoreServices Security SystemConfiguration ] - else [ openssl ]; + buildInputs = + if stdenv.hostPlatform.isDarwin then + [ + libiconv + CoreServices + Security + SystemConfiguration + ] + else + [ openssl ]; # requires network checkFlags = [ "--skip=tools::tests::download_and_install_binaries" ]; - cargoHash = { - darwin = "sha256-TwpGw3LH3TmZSbC4DkoOYpQdOpksXXoAoiacyZAefTU="; - linux = "sha256-AivISmT/r8xa/vSXUN8sU7z67t1hcyMQM+t6oXmIOhU="; - }.${stdenv.hostPlatform.parsed.kernel.name} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + cargoHash = + { + darwin = "sha256-TwpGw3LH3TmZSbC4DkoOYpQdOpksXXoAoiacyZAefTU="; + linux = "sha256-AivISmT/r8xa/vSXUN8sU7z67t1hcyMQM+t6oXmIOhU="; + } + .${stdenv.hostPlatform.parsed.kernel.name} + or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); meta = with lib; { homepage = "https://github.com/ctron/trunk"; diff --git a/pkgs/by-name/tr/trunk-recorder/package.nix b/pkgs/by-name/tr/trunk-recorder/package.nix index 59852e783c7e73..f7846b0ac19467 100644 --- a/pkgs/by-name/tr/trunk-recorder/package.nix +++ b/pkgs/by-name/tr/trunk-recorder/package.nix @@ -40,17 +40,20 @@ stdenv.mkDerivation rec { pkg-config makeWrapper ]; - buildInputs = [ - boost - curl - gmp - gnuradio - gnuradioPackages.osmosdr - openssl - spdlog - uhd - volk - ] ++ lib.optionals hackrfSupport [ hackrf ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ mpir ]; + buildInputs = + [ + boost + curl + gmp + gnuradio + gnuradioPackages.osmosdr + openssl + spdlog + uhd + volk + ] + ++ lib.optionals hackrfSupport [ hackrf ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ mpir ]; postFixup = '' wrapProgram $out/bin/trunk-recorder --prefix PATH : ${ diff --git a/pkgs/by-name/tr/trunk/package.nix b/pkgs/by-name/tr/trunk/package.nix index 49f24385e77421..47a2e63112e128 100644 --- a/pkgs/by-name/tr/trunk/package.nix +++ b/pkgs/by-name/tr/trunk/package.nix @@ -1,8 +1,9 @@ -{ lib, -rustPlatform, -fetchFromGitHub, -pkg-config, -openssl, +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, }: rustPlatform.buildRustPackage rec { @@ -27,7 +28,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/trunk-rs/trunk"; description = "Build, bundle & ship your Rust WASM application to the web"; mainProgram = "trunk"; - maintainers = with maintainers; [ freezeboy ctron ]; + maintainers = with maintainers; [ + freezeboy + ctron + ]; license = with licenses; [ asl20 ]; }; } diff --git a/pkgs/by-name/tr/trurl/package.nix b/pkgs/by-name/tr/trurl/package.nix index 1e4bd4404f9c1d..97b9afe8228d2d 100644 --- a/pkgs/by-name/tr/trurl/package.nix +++ b/pkgs/by-name/tr/trurl/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, curl, python3, trurl, testers }: +{ + lib, + stdenv, + fetchFromGitHub, + curl, + python3, + trurl, + testers, +}: stdenv.mkDerivation rec { pname = "trurl"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { hash = "sha256-Og7+FVCBWohVd58GVxFN3KChcG0Kts1MokiOQXZ1OTc="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; separateDebugInfo = stdenv.hostPlatform.isLinux; enableParallelBuilding = true; diff --git a/pkgs/by-name/tr/trx/package.nix b/pkgs/by-name/tr/trx/package.nix index c0b03a83caad2a..726b8e7615e7bf 100644 --- a/pkgs/by-name/tr/trx/package.nix +++ b/pkgs/by-name/tr/trx/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, alsa-lib, libopus, ortp, bctoolbox }: +{ + lib, + stdenv, + fetchurl, + alsa-lib, + libopus, + ortp, + bctoolbox, +}: stdenv.mkDerivation rec { pname = "trx"; @@ -15,7 +23,12 @@ stdenv.mkDerivation rec { ./add_bctoolbox_ldlib.patch ]; - buildInputs = [ alsa-lib libopus ortp bctoolbox ]; + buildInputs = [ + alsa-lib + libopus + ortp + bctoolbox + ]; makeFlags = [ "PREFIX=$(out)" ]; meta = with lib; { diff --git a/pkgs/by-name/tr/try/package.nix b/pkgs/by-name/tr/try/package.nix index a5a6c760a010bf..996bfa12f0e1bd 100644 --- a/pkgs/by-name/tr/try/package.nix +++ b/pkgs/by-name/tr/try/package.nix @@ -1,4 +1,11 @@ -{ stdenvNoCC, lib, fetchFromGitHub, fuse-overlayfs, util-linux, makeWrapper }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, + fuse-overlayfs, + util-linux, + makeWrapper, +}: stdenvNoCC.mkDerivation rec { pname = "try"; version = "0.2.0"; @@ -12,10 +19,15 @@ stdenvNoCC.mkDerivation rec { installPhase = '' runHook preInstall install -Dt $out/bin try - wrapProgram $out/bin/try --prefix PATH : ${lib.makeBinPath [ fuse-overlayfs util-linux ]} + wrapProgram $out/bin/try --prefix PATH : ${ + lib.makeBinPath [ + fuse-overlayfs + util-linux + ] + } runHook postInstall ''; - meta = with lib;{ + meta = with lib; { homepage = "https://github.com/binpash/try"; description = "Lets you run a command and inspect its effects before changing your live system"; mainProgram = "try"; diff --git a/pkgs/by-name/ts/ts/package.nix b/pkgs/by-name/ts/ts/package.nix index 2fa2c90800b9e9..fa1fc15ada5223 100644 --- a/pkgs/by-name/ts/ts/package.nix +++ b/pkgs/by-name/ts/ts/package.nix @@ -1,12 +1,15 @@ -{ lib, stdenv, fetchurl -, sendmailPath ? "/run/wrappers/bin/sendmail" +{ + lib, + stdenv, + fetchurl, + sendmailPath ? "/run/wrappers/bin/sendmail", }: stdenv.mkDerivation rec { pname = "ts"; version = "1.0.3"; - installPhase=''make install "PREFIX=$out"''; + installPhase = ''make install "PREFIX=$out"''; patchPhase = '' sed -i s,/usr/sbin/sendmail,${sendmailPath}, mail.c ts.1 diff --git a/pkgs/by-name/ts/tsduck/package.nix b/pkgs/by-name/ts/tsduck/package.nix index 0da53e2e96ea9d..40183616fd0769 100644 --- a/pkgs/by-name/ts/tsduck/package.nix +++ b/pkgs/by-name/ts/tsduck/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, curl -, jdk -, libedit -, srt +{ + lib, + stdenv, + fetchFromGitHub, + curl, + jdk, + libedit, + srt, }: stdenv.mkDerivation rec { @@ -83,10 +84,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "MPEG Transport Stream Toolkit"; - homepage = "https://github.com/tsduck/tsduck"; - license = licenses.bsd2; + homepage = "https://github.com/tsduck/tsduck"; + license = licenses.bsd2; maintainers = with maintainers; [ siriobalmelli ]; - platforms = platforms.all; + platforms = platforms.all; # never built on aarch64-darwin, x86_64-darwin since first introduction in nixpkgs broken = stdenv.hostPlatform.isDarwin; }; diff --git a/pkgs/by-name/ts/tsid/package.nix b/pkgs/by-name/ts/tsid/package.nix index 0bd4b08b6025e3..988e95a039adc8 100644 --- a/pkgs/by-name/ts/tsid/package.nix +++ b/pkgs/by-name/ts/tsid/package.nix @@ -53,7 +53,8 @@ stdenv.mkDerivation (finalAttrs: { osqp-eigen proxsuite ] - ++ lib.optional (!pythonSupport) pinocchio ++ lib.optional pythonSupport python3Packages.pinocchio; + ++ lib.optional (!pythonSupport) pinocchio + ++ lib.optional pythonSupport python3Packages.pinocchio; doCheck = true; pythonImportsCheck = [ "tsid" ]; diff --git a/pkgs/by-name/ts/tsm-client/package.nix b/pkgs/by-name/ts/tsm-client/package.nix index bf65c8d0cadc4d..4faf16f63af396 100644 --- a/pkgs/by-name/ts/tsm-client/package.nix +++ b/pkgs/by-name/ts/tsm-client/package.nix @@ -1,31 +1,30 @@ -{ lib -, callPackage -, nixosTests -, stdenv -, fetchurl -, autoPatchelfHook -, rpmextract -, libxcrypt-legacy -, zlib -, lvm2 # LVM image backup and restore functions (optional) -, acl # EXT2/EXT3/XFS ACL support (optional) -, gnugrep -, procps -, jdk # Java GUI (needed for `enableGui`) -, buildEnv -, makeWrapper -, enableGui ? false # enables Java GUI `dsmj` -# path to `dsm.sys` configuration files -, dsmSysCli ? "/etc/tsm-client/cli.dsm.sys" -, dsmSysApi ? "/etc/tsm-client/api.dsm.sys" +{ + lib, + callPackage, + nixosTests, + stdenv, + fetchurl, + autoPatchelfHook, + rpmextract, + libxcrypt-legacy, + zlib, + lvm2, # LVM image backup and restore functions (optional) + acl, # EXT2/EXT3/XFS ACL support (optional) + gnugrep, + procps, + jdk, # Java GUI (needed for `enableGui`) + buildEnv, + makeWrapper, + enableGui ? false, # enables Java GUI `dsmj` + # path to `dsm.sys` configuration files + dsmSysCli ? "/etc/tsm-client/cli.dsm.sys", + dsmSysApi ? "/etc/tsm-client/api.dsm.sys", }: - # For an explanation of optional packages # (features provided by them, version limits), see # https://www.ibm.com/support/pages/node/660813#Version%208.1 - # IBM Tivoli Storage Manager Client uses a system-wide # client system-options file `dsm.sys` and expects it # to be located in a directory within the package. @@ -47,7 +46,6 @@ # depending on local configuration or usage; see: # https://www.ibm.com/docs/en/storage-protect/8.1.24?topic=solaris-set-api-environment-variables - # The newest version of TSM client should be discoverable by # going to the `downloadPage` (see `meta` below). # Find the "Backup-archive client" table on that page. @@ -61,7 +59,6 @@ # # (as of 2023-07-01) - let meta = { @@ -89,18 +86,21 @@ let }; passthru.tests = { - test-cli = callPackage ./test-cli.nix {}; + test-cli = callPackage ./test-cli.nix { }; test-gui = nixosTests.tsm-client-gui; }; - mkSrcUrl = version: + mkSrcUrl = + version: let major = lib.versions.major version; minor = lib.versions.minor version; patch = lib.versions.patch version; fixup = lib.lists.elemAt (lib.versions.splitVersion version) 3; in - "https://public.dhe.ibm.com/storage/tivoli-storage-management/${if fixup=="0" then "maintenance" else "patches"}/client/v${major}r${minor}/Linux/LinuxX86/BA/v${major}${minor}${patch}/${version}-TIV-TSMBAC-LinuxX86.tar"; + "https://public.dhe.ibm.com/storage/tivoli-storage-management/${ + if fixup == "0" then "maintenance" else "patches" + }/client/v${major}r${minor}/Linux/LinuxX86/BA/v${major}${minor}${patch}/${version}-TIV-TSMBAC-LinuxX86.tar"; unwrapped = stdenv.mkDerivation (finalAttrs: { name = "tsm-client-${finalAttrs.version}-unwrapped"; @@ -164,17 +164,27 @@ let ''; }); - binPath = lib.makeBinPath ([ acl gnugrep procps ] - ++ lib.optional enableGui jdk); + binPath = lib.makeBinPath ( + [ + acl + gnugrep + procps + ] + ++ lib.optional enableGui jdk + ); in buildEnv { name = "tsm-client-${unwrapped.version}"; - meta = meta // lib.attrsets.optionalAttrs enableGui { - mainProgram = "dsmj"; + meta = + meta + // lib.attrsets.optionalAttrs enableGui { + mainProgram = "dsmj"; + }; + passthru = passthru // { + inherit unwrapped; }; - passthru = passthru // { inherit unwrapped; }; paths = [ unwrapped ]; nativeBuildInputs = [ makeWrapper ]; pathsToLink = [ diff --git a/pkgs/by-name/ts/tsm-client/test-cli.nix b/pkgs/by-name/ts/tsm-client/test-cli.nix index 0858083c9f9046..b8cd94e2b441e1 100644 --- a/pkgs/by-name/ts/tsm-client/test-cli.nix +++ b/pkgs/by-name/ts/tsm-client/test-cli.nix @@ -1,7 +1,8 @@ -{ lib -, writeText -, runCommand -, tsm-client +{ + lib, + writeText, + runCommand, + tsm-client, }: # Let the client try to connect to a server. @@ -30,7 +31,7 @@ let patch = lib.versions.patch version; fixup = lib.lists.elemAt (lib.versions.splitVersion version) 3; in - "Client Version ${major}, Release ${minor}, Level ${patch}.${fixup}"; + "Client Version ${major}, Release ${minor}, Level ${patch}.${fixup}"; in diff --git a/pkgs/by-name/ts/tsocks/package.nix b/pkgs/by-name/ts/tsocks/package.nix index c12f9a44ac6d22..f07947677e3b77 100644 --- a/pkgs/by-name/ts/tsocks/package.nix +++ b/pkgs/by-name/ts/tsocks/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "tsocks"; diff --git a/pkgs/by-name/ts/tsukae/package.nix b/pkgs/by-name/ts/tsukae/package.nix index bf1b2131551328..de4ad64d9ad5a6 100644 --- a/pkgs/by-name/ts/tsukae/package.nix +++ b/pkgs/by-name/ts/tsukae/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "tsukae"; diff --git a/pkgs/by-name/ts/tsung/package.nix b/pkgs/by-name/ts/tsung/package.nix index a9a30859b2178c..a23e464accc17b 100644 --- a/pkgs/by-name/ts/tsung/package.nix +++ b/pkgs/by-name/ts/tsung/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, erlang -, python3 -, python3Packages -, perlPackages -, gnuplot +{ + lib, + stdenv, + fetchurl, + makeWrapper, + erlang, + python3, + python3Packages, + perlPackages, + gnuplot, }: stdenv.mkDerivation rec { @@ -31,7 +32,6 @@ stdenv.mkDerivation rec { python3Packages.matplotlib ]; - postFixup = '' # Make tsung_stats.pl accessible # Leaving .pl at the end since all of tsung documentation is refering to it diff --git a/pkgs/by-name/tt/tt-rss-plugin-auth-ldap/package.nix b/pkgs/by-name/tt/tt-rss-plugin-auth-ldap/package.nix index 6261c1f5f3fd6f..5fc11d572ce3fb 100644 --- a/pkgs/by-name/tt/tt-rss-plugin-auth-ldap/package.nix +++ b/pkgs/by-name/tt/tt-rss-plugin-auth-ldap/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "tt-rss-plugin-auth-ldap"; diff --git a/pkgs/by-name/tt/tt-rss-plugin-feediron/package.nix b/pkgs/by-name/tt/tt-rss-plugin-feediron/package.nix index d7353bf4c439d9..fa2bb41a323b26 100644 --- a/pkgs/by-name/tt/tt-rss-plugin-feediron/package.nix +++ b/pkgs/by-name/tt/tt-rss-plugin-feediron/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, tt-rss }: +{ + lib, + stdenv, + fetchFromGitHub, + tt-rss, +}: stdenv.mkDerivation rec { pname = "tt-rss-plugin-feediron"; diff --git a/pkgs/by-name/tt/tt-rss-plugin-ff-instagram/package.nix b/pkgs/by-name/tt/tt-rss-plugin-ff-instagram/package.nix index 7ef093e3f70d6c..8cbfb42618bfd3 100644 --- a/pkgs/by-name/tt/tt-rss-plugin-ff-instagram/package.nix +++ b/pkgs/by-name/tt/tt-rss-plugin-ff-instagram/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ... }: +{ + lib, + stdenv, + fetchFromGitHub, + ... +}: stdenv.mkDerivation { pname = "tt-rss-plugin-ff-instagram"; diff --git a/pkgs/by-name/tt/tt-rss-theme-feedly/package.nix b/pkgs/by-name/tt/tt-rss-theme-feedly/package.nix index 84ade1ef70aded..18e14aae380d32 100644 --- a/pkgs/by-name/tt/tt-rss-theme-feedly/package.nix +++ b/pkgs/by-name/tt/tt-rss-theme-feedly/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "tt-rss-theme-feedly"; diff --git a/pkgs/by-name/tt/tt/package.nix b/pkgs/by-name/tt/tt/package.nix index f45376aa4caa0d..480b9f245c0538 100644 --- a/pkgs/by-name/tt/tt/package.nix +++ b/pkgs/by-name/tt/tt/package.nix @@ -21,8 +21,8 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; postInstall = '' - mv $out/bin/src $out/bin/tt - installManPage tt.1.gz + mv $out/bin/src $out/bin/tt + installManPage tt.1.gz ''; meta = { diff --git a/pkgs/by-name/tt/tt2020/package.nix b/pkgs/by-name/tt/tt2020/package.nix index a427c4cf14b8ca..3ac3c7ce948f2e 100644 --- a/pkgs/by-name/tt/tt2020/package.nix +++ b/pkgs/by-name/tt/tt2020/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "TT2020"; diff --git a/pkgs/by-name/tt/ttags/package.nix b/pkgs/by-name/tt/ttags/package.nix index c6bee9ae3369d2..3b9ebac943c822 100644 --- a/pkgs/by-name/tt/ttags/package.nix +++ b/pkgs/by-name/tt/ttags/package.nix @@ -1,6 +1,14 @@ -{ lib, fetchFromGitHub, rustPlatform, testers, ttags }: -let version = "0.4.2"; -in rustPlatform.buildRustPackage { +{ + lib, + fetchFromGitHub, + rustPlatform, + testers, + ttags, +}: +let + version = "0.4.2"; +in +rustPlatform.buildRustPackage { pname = "ttags"; inherit version; diff --git a/pkgs/by-name/tt/ttchat/package.nix b/pkgs/by-name/tt/ttchat/package.nix index ec62357cbbedda..893abb63c4f018 100644 --- a/pkgs/by-name/tt/ttchat/package.nix +++ b/pkgs/by-name/tt/ttchat/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ttchat"; diff --git a/pkgs/by-name/tt/ttdl/package.nix b/pkgs/by-name/tt/ttdl/package.nix index 9e283c79ada636..3cac311e475f11 100644 --- a/pkgs/by-name/tt/ttdl/package.nix +++ b/pkgs/by-name/tt/ttdl/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/tt/ttf-envy-code-r/package.nix b/pkgs/by-name/tt/ttf-envy-code-r/package.nix index 673d946a1e9a02..2f3765f8a3b5a7 100644 --- a/pkgs/by-name/tt/ttf-envy-code-r/package.nix +++ b/pkgs/by-name/tt/ttf-envy-code-r/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "ttf-envy-code-r"; diff --git a/pkgs/by-name/tt/ttf-tw-moe/package.nix b/pkgs/by-name/tt/ttf-tw-moe/package.nix index 85b2ec1ce78768..b0ddf0af18b9ad 100644 --- a/pkgs/by-name/tt/ttf-tw-moe/package.nix +++ b/pkgs/by-name/tt/ttf-tw-moe/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "ttf-tw-moe"; diff --git a/pkgs/by-name/tt/ttf2pt1/package.nix b/pkgs/by-name/tt/ttf2pt1/package.nix index 2383a96eedfea8..75b32dc70a2c2d 100644 --- a/pkgs/by-name/tt/ttf2pt1/package.nix +++ b/pkgs/by-name/tt/ttf2pt1/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, perl, freetype }: +{ + lib, + stdenv, + fetchurl, + perl, + freetype, +}: stdenv.mkDerivation rec { pname = "ttf2pt1"; diff --git a/pkgs/by-name/tt/ttf_bitstream_vera/package.nix b/pkgs/by-name/tt/ttf_bitstream_vera/package.nix index e71888969f61e2..ed525dec1cef0b 100644 --- a/pkgs/by-name/tt/ttf_bitstream_vera/package.nix +++ b/pkgs/by-name/tt/ttf_bitstream_vera/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "ttf-bitstream-vera"; diff --git a/pkgs/by-name/tt/ttfb/package.nix b/pkgs/by-name/tt/ttfb/package.nix index 176685a5eed3fc..12b900aacfc742 100644 --- a/pkgs/by-name/tt/ttfb/package.nix +++ b/pkgs/by-name/tt/ttfb/package.nix @@ -1,8 +1,9 @@ -{ darwin -, fetchCrate -, lib -, rustPlatform -, stdenv +{ + darwin, + fetchCrate, + lib, + rustPlatform, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -38,4 +39,3 @@ rustPlatform.buildRustPackage rec { maintainers = with lib.maintainers; [ phip1611 ]; }; } - diff --git a/pkgs/by-name/tt/tthsum/package.nix b/pkgs/by-name/tt/tthsum/package.nix index e2b9d2e570414c..743501fb31e0ff 100644 --- a/pkgs/by-name/tt/tthsum/package.nix +++ b/pkgs/by-name/tt/tthsum/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "tthsum"; diff --git a/pkgs/by-name/tt/ttmkfdir/package.nix b/pkgs/by-name/tt/ttmkfdir/package.nix index 6edf9cc4ef986c..c4d6d162488432 100644 --- a/pkgs/by-name/tt/ttmkfdir/package.nix +++ b/pkgs/by-name/tt/ttmkfdir/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, freetype, libtool, flex, bison, pkg-config }: +{ + lib, + stdenv, + fetchurl, + freetype, + libtool, + flex, + bison, + pkg-config, +}: stdenv.mkDerivation { pname = "ttf-mkfontdir"; @@ -11,14 +20,14 @@ stdenv.mkDerivation { # all the patches up from ttmkfdir-3.0.9/Makefile should be reviewed by someone # who knows more about C/C++ .. - patches = - [ (fetchurl { - url = "http://mirror.fsf.org/trisquel/pool/main/t/ttmkfdir/ttmkfdir_3.0.9-6.diff.gz"; - sha256 = "141kxaf2by8nf87hqyszaxi0n7nnmswr1nh2i5r5bsvxxmaj9633"; - }) + patches = [ + (fetchurl { + url = "http://mirror.fsf.org/trisquel/pool/main/t/ttmkfdir/ttmkfdir_3.0.9-6.diff.gz"; + sha256 = "141kxaf2by8nf87hqyszaxi0n7nnmswr1nh2i5r5bsvxxmaj9633"; + }) - ./cstring.patch # also fixes some other compilation issues (freetype includes) - ]; + ./cstring.patch # also fixes some other compilation issues (freetype includes) + ]; # cross-compilation fixes: # - fix libtool, the reason it does not work in nativeBuildInputs is complicated @@ -31,9 +40,17 @@ stdenv.mkDerivation { --replace "freetype-config" "${stdenv.cc.targetPrefix}pkg-config freetype2" ''; - makeFlags = [ "DESTDIR=${placeholder "out"}" "BINDIR=/bin" "CXX=${stdenv.cc.targetPrefix}c++" ]; - - nativeBuildInputs = [ flex bison pkg-config ]; + makeFlags = [ + "DESTDIR=${placeholder "out"}" + "BINDIR=/bin" + "CXX=${stdenv.cc.targetPrefix}c++" + ]; + + nativeBuildInputs = [ + flex + bison + pkg-config + ]; buildInputs = [ freetype ]; meta = { diff --git a/pkgs/by-name/tt/tts/package.nix b/pkgs/by-name/tt/tts/package.nix index 67552e99e7bfe4..cbaf8aa21f0c15 100644 --- a/pkgs/by-name/tt/tts/package.nix +++ b/pkgs/by-name/tt/tts/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3 -, fetchFromGitHub -, espeak-ng -, tts +{ + lib, + python3, + fetchFromGitHub, + espeak-ng, + tts, }: let @@ -27,34 +28,36 @@ python.pkgs.buildPythonApplication rec { hash = "sha256-1nlSf15IEX1qKfDtR6+jQqskjxIuzaIWatkj9Z1fh8Y="; }; - postPatch = let - relaxedConstraints = [ - "bnunicodenormalizer" - "cython" - "gruut" - "inflect" - "librosa" - "mecab-python3" - "numba" - "numpy" - "unidic-lite" - "trainer" - ]; - in '' - sed -r -i \ - ${lib.concatStringsSep "\n" (map (package: - ''-e 's/${package}\s*[<>=]+.+/${package}/g' \'' - ) relaxedConstraints)} - requirements.txt - - sed -r -i \ - ${lib.concatStringsSep "\n" (map (package: - ''-e 's/${package}\s*[<>=]+[^"]+/${package}/g' \'' - ) relaxedConstraints)} - pyproject.toml - # only used for notebooks and visualization - sed -r -i -e '/umap-learn/d' requirements.txt - ''; + postPatch = + let + relaxedConstraints = [ + "bnunicodenormalizer" + "cython" + "gruut" + "inflect" + "librosa" + "mecab-python3" + "numba" + "numpy" + "unidic-lite" + "trainer" + ]; + in + '' + sed -r -i \ + ${lib.concatStringsSep "\n" ( + map (package: ''-e 's/${package}\s*[<>=]+.+/${package}/g' \'') relaxedConstraints + )} + requirements.txt + + sed -r -i \ + ${lib.concatStringsSep "\n" ( + map (package: ''-e 's/${package}\s*[<>=]+[^"]+/${package}/g' \'') relaxedConstraints + )} + pyproject.toml + # only used for notebooks and visualization + sed -r -i -e '/umap-learn/d' requirements.txt + ''; nativeBuildInputs = with python.pkgs; [ cython @@ -112,7 +115,9 @@ python.pkgs.buildPythonApplication rec { # tests get stuck when run in nixpkgs-review, tested in passthru doCheck = false; - passthru.tests.pytest = tts.overridePythonAttrs (_: { doCheck = true; }); + passthru.tests.pytest = tts.overridePythonAttrs (_: { + doCheck = true; + }); nativeCheckInputs = with python.pkgs; [ espeak-ng diff --git a/pkgs/by-name/tt/ttwatch/package.nix b/pkgs/by-name/tt/ttwatch/package.nix index 273d34ffdb8e49..03913b58134b71 100644 --- a/pkgs/by-name/tt/ttwatch/package.nix +++ b/pkgs/by-name/tt/ttwatch/package.nix @@ -1,7 +1,16 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, perl, pkg-config -, openssl, curl, libusb1, protobufc -, enableUnsafe ? false }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + perl, + pkg-config, + openssl, + curl, + libusb1, + protobufc, + enableUnsafe ? false, +}: stdenv.mkDerivation { pname = "ttwatch"; @@ -14,8 +23,17 @@ stdenv.mkDerivation { sha256 = "0yd2hs9d03gfvwm1vywpg2qga6x5c74zrj665wf9aa8gmn96hv8r"; }; - nativeBuildInputs = [ cmake perl pkg-config ]; - buildInputs = [ openssl curl libusb1 protobufc ]; + nativeBuildInputs = [ + cmake + perl + pkg-config + ]; + buildInputs = [ + openssl + curl + libusb1 + protobufc + ]; cmakeFlags = lib.optionals enableUnsafe [ "-Dunsafe=on" ]; diff --git a/pkgs/by-name/tt/tty-clock/package.nix b/pkgs/by-name/tt/tty-clock/package.nix index f5d70cd2071f39..702e9264cd7f2c 100644 --- a/pkgs/by-name/tt/tty-clock/package.nix +++ b/pkgs/by-name/tt/tty-clock/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, ncurses, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + ncurses, + pkg-config, +}: stdenv.mkDerivation rec { pname = "tty-clock"; diff --git a/pkgs/by-name/tt/tty-share/package.nix b/pkgs/by-name/tt/tty-share/package.nix index 7f2fe8c162a75d..7c653fdfdba7c8 100644 --- a/pkgs/by-name/tt/tty-share/package.nix +++ b/pkgs/by-name/tt/tty-share/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "tty-share"; @@ -14,7 +18,11 @@ buildGoModule rec { # Upstream has a `./vendor` directory with all deps which we rely upon. vendorHash = null; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; meta = with lib; { homepage = "https://tty-share.com"; diff --git a/pkgs/by-name/tt/tty-solitaire/package.nix b/pkgs/by-name/tt/tty-solitaire/package.nix index 137e5653d74f9d..2116103fc09663 100644 --- a/pkgs/by-name/tt/tty-solitaire/package.nix +++ b/pkgs/by-name/tt/tty-solitaire/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + ncurses, +}: stdenv.mkDerivation rec { pname = "tty-solitaire"; @@ -27,7 +33,10 @@ stdenv.mkDerivation rec { buildInputs = [ ncurses ]; - makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "PREFIX=${placeholder "out"}" ]; + makeFlags = [ + "CC=${stdenv.cc.targetPrefix}cc" + "PREFIX=${placeholder "out"}" + ]; meta = with lib; { description = "Klondike Solitaire in your ncurses terminal"; diff --git a/pkgs/by-name/tt/ttyd/package.nix b/pkgs/by-name/tt/ttyd/package.nix index 7cbf0cd77ad9d9..58e33437a120c6 100644 --- a/pkgs/by-name/tt/ttyd/package.nix +++ b/pkgs/by-name/tt/ttyd/package.nix @@ -1,7 +1,16 @@ -{ lib, stdenv, fetchFromGitHub -, pkg-config, cmake, xxd -, openssl, libwebsockets, json_c, libuv, zlib -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + xxd, + openssl, + libwebsockets, + json_c, + libuv, + zlib, + nixosTests, }: with builtins; @@ -16,10 +25,23 @@ stdenv.mkDerivation rec { sha256 = "sha256-7e08oBKU7BMZ8328qCfNynCSe7LVZ88+iQZRRKl2YkY="; }; - nativeBuildInputs = [ pkg-config cmake xxd ]; - buildInputs = [ openssl libwebsockets json_c libuv zlib ]; + nativeBuildInputs = [ + pkg-config + cmake + xxd + ]; + buildInputs = [ + openssl + libwebsockets + json_c + libuv + zlib + ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; passthru.tests = { inherit (nixosTests) ttyd; @@ -27,10 +49,10 @@ stdenv.mkDerivation rec { meta = { description = "Share your terminal over the web"; - homepage = "https://github.com/tsl0922/ttyd"; - license = lib.licenses.mit; + homepage = "https://github.com/tsl0922/ttyd"; + license = lib.licenses.mit; maintainers = [ lib.maintainers.thoughtpolice ]; - platforms = lib.platforms.all; + platforms = lib.platforms.all; mainProgram = "ttyd"; }; } diff --git a/pkgs/by-name/tt/ttygif/package.nix b/pkgs/by-name/tt/ttygif/package.nix index 689138186cb6b8..90989ad99b733f 100644 --- a/pkgs/by-name/tt/ttygif/package.nix +++ b/pkgs/by-name/tt/ttygif/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, imagemagick, xorg }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + imagemagick, + xorg, +}: stdenv.mkDerivation rec { pname = "ttygif"; @@ -11,12 +18,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-GsMeVR2wNivQguZ6B/0v39Td9VGHg+m3RtAG9DYkNmU="; }; - makeFlags = [ "CC:=$(CC)" "PREFIX=${placeholder "out"}" ]; + makeFlags = [ + "CC:=$(CC)" + "PREFIX=${placeholder "out"}" + ]; nativeBuildInputs = [ makeWrapper ]; postInstall = '' wrapProgram $out/bin/ttygif \ - --prefix PATH : ${lib.makeBinPath [ imagemagick xorg.xwd ]} + --prefix PATH : ${ + lib.makeBinPath [ + imagemagick + xorg.xwd + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/tt/ttylog/package.nix b/pkgs/by-name/tt/ttylog/package.nix index ff07ba9761756a..d98e3a27acc705 100644 --- a/pkgs/by-name/tt/ttylog/package.nix +++ b/pkgs/by-name/tt/ttylog/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "ttylog"; diff --git a/pkgs/by-name/tt/ttyper/package.nix b/pkgs/by-name/tt/ttyper/package.nix index aec5b9f083004e..ad0e268d4ef529 100644 --- a/pkgs/by-name/tt/ttyper/package.nix +++ b/pkgs/by-name/tt/ttyper/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "ttyper"; @@ -18,7 +22,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/max-niederman/ttyper"; changelog = "https://github.com/max-niederman/ttyper/releases/tag/${src.rev}"; license = licenses.mit; - maintainers = with maintainers; [ figsoda max-niederman ]; + maintainers = with maintainers; [ + figsoda + max-niederman + ]; mainProgram = "ttyper"; }; } diff --git a/pkgs/by-name/tt/ttyplot/package.nix b/pkgs/by-name/tt/ttyplot/package.nix index 535d374bf2b7e7..3e332e4d9dccbf 100644 --- a/pkgs/by-name/tt/ttyplot/package.nix +++ b/pkgs/by-name/tt/ttyplot/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, ncurses, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + pkg-config, +}: stdenv.mkDerivation rec { pname = "ttyplot"; diff --git a/pkgs/by-name/tu/tuba/package.nix b/pkgs/by-name/tu/tuba/package.nix index 9eeac726a83fca..4c2c293b5d6dd6 100644 --- a/pkgs/by-name/tu/tuba/package.nix +++ b/pkgs/by-name/tu/tuba/package.nix @@ -1,36 +1,37 @@ -{ lib -, stdenv -, fetchFromGitHub -, vala -, meson -, ninja -, python3 -, pkg-config -, wrapGAppsHook4 -, desktop-file-utils -, gtk4 -, libadwaita -, json-glib -, glib -, glib-networking -, gnome -, gobject-introspection -, gtksourceview5 -, libxml2 -, libgee -, librsvg -, libsoup_3 -, libsecret -, libwebp -, libspelling -, webp-pixbuf-loader -, icu -, gst_all_1 -, clapper -# clapper support is still experimental and has bugs. -# See https://github.com/GeopJr/Tuba/pull/931 -, clapperSupport? false -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + vala, + meson, + ninja, + python3, + pkg-config, + wrapGAppsHook4, + desktop-file-utils, + gtk4, + libadwaita, + json-glib, + glib, + glib-networking, + gnome, + gobject-introspection, + gtksourceview5, + libxml2, + libgee, + librsvg, + libsoup_3, + libsecret, + libwebp, + libspelling, + webp-pixbuf-loader, + icu, + gst_all_1, + clapper, + # clapper support is still experimental and has bugs. + # See https://github.com/GeopJr/Tuba/pull/931 + clapperSupport ? false, + nix-update-script, }: stdenv.mkDerivation rec { @@ -55,29 +56,32 @@ stdenv.mkDerivation rec { gobject-introspection ]; - buildInputs = [ - glib - glib-networking - gtksourceview5 - json-glib - libxml2 - libgee - libsoup_3 - gtk4 - libadwaita - libsecret - libwebp - libspelling - icu - ] ++ (with gst_all_1; [ - gstreamer - gst-libav - gst-plugins-base - (gst-plugins-good.override { gtkSupport = true; }) - gst-plugins-bad - ]) ++ lib.optionals clapperSupport [ - clapper - ]; + buildInputs = + [ + glib + glib-networking + gtksourceview5 + json-glib + libxml2 + libgee + libsoup_3 + gtk4 + libadwaita + libsecret + libwebp + libspelling + icu + ] + ++ (with gst_all_1; [ + gstreamer + gst-libav + gst-plugins-base + (gst-plugins-good.override { gtkSupport = true; }) + gst-plugins-bad + ]) + ++ lib.optionals clapperSupport [ + clapper + ]; mesonFlags = [ (lib.mesonBool "clapper" clapperSupport) @@ -92,12 +96,14 @@ stdenv.mkDerivation rec { # Pull in WebP support for avatars from Misskey instances. # In postInstall to run before gappsWrapperArgsHook. postInstall = '' - export GDK_PIXBUF_MODULE_FILE="${gnome._gdkPixbufCacheBuilder_DO_NOT_USE { - extraLoaders = [ - librsvg - webp-pixbuf-loader - ]; - }}" + export GDK_PIXBUF_MODULE_FILE="${ + gnome._gdkPixbufCacheBuilder_DO_NOT_USE { + extraLoaders = [ + librsvg + webp-pixbuf-loader + ]; + } + }" ''; meta = { @@ -106,6 +112,10 @@ stdenv.mkDerivation rec { mainProgram = "dev.geopjr.Tuba"; license = lib.licenses.gpl3Only; changelog = "https://github.com/GeopJr/Tuba/releases/tag/v${version}"; - maintainers = with lib.maintainers; [ chuangzhu aleksana donovanglover ]; + maintainers = with lib.maintainers; [ + chuangzhu + aleksana + donovanglover + ]; }; } diff --git a/pkgs/by-name/tu/tuc/package.nix b/pkgs/by-name/tu/tuc/package.nix index 46e9bb86e57c35..f2e8266f69580b 100644 --- a/pkgs/by-name/tu/tuc/package.nix +++ b/pkgs/by-name/tu/tuc/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "tuc"; version = "1.2.0"; diff --git a/pkgs/by-name/tu/tuckr/package.nix b/pkgs/by-name/tu/tuckr/package.nix index 04a72a8f493b11..94202a3623a9ff 100644 --- a/pkgs/by-name/tu/tuckr/package.nix +++ b/pkgs/by-name/tu/tuckr/package.nix @@ -1,4 +1,8 @@ -{ lib, rustPlatform, fetchFromGitHub }: +{ + lib, + rustPlatform, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "tuckr"; diff --git a/pkgs/by-name/tu/tudu/package.nix b/pkgs/by-name/tu/tudu/package.nix index df1c5420164f03..856d1222d1775c 100644 --- a/pkgs/by-name/tu/tudu/package.nix +++ b/pkgs/by-name/tu/tudu/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "tudu"; diff --git a/pkgs/by-name/tu/tuhi/package.nix b/pkgs/by-name/tu/tuhi/package.nix index 759ad401ede6ce..fa0fb7097139ac 100644 --- a/pkgs/by-name/tu/tuhi/package.nix +++ b/pkgs/by-name/tu/tuhi/package.nix @@ -1,15 +1,16 @@ -{ lib -, pkg-config -, python3Packages -, meson -, ninja -, appstream-glib -, desktop-file-utils -, glib -, gtk3 -, gobject-introspection -, wrapGAppsHook3 -, fetchFromGitHub +{ + lib, + pkg-config, + python3Packages, + meson, + ninja, + appstream-glib, + desktop-file-utils, + glib, + gtk3, + gobject-introspection, + wrapGAppsHook3, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { @@ -31,8 +32,11 @@ python3Packages.buildPythonApplication rec { ''; nativeBuildInputs = [ - pkg-config meson ninja - appstream-glib desktop-file-utils + pkg-config + meson + ninja + appstream-glib + desktop-file-utils wrapGAppsHook3 gobject-introspection ]; @@ -40,9 +44,16 @@ python3Packages.buildPythonApplication rec { gtk3 glib ]; - nativeCheckInputs = with python3Packages; [ flake8 pytest ]; + nativeCheckInputs = with python3Packages; [ + flake8 + pytest + ]; propagatedBuildInputs = with python3Packages; [ - svgwrite pyxdg pycairo pygobject3 setuptools-scm + svgwrite + pyxdg + pycairo + pygobject3 + setuptools-scm ]; strictDeps = false; diff --git a/pkgs/by-name/tu/tuic/package.nix b/pkgs/by-name/tu/tuic/package.nix index a2a0bfc2f0ffee..17fbd99fd0bf39 100644 --- a/pkgs/by-name/tu/tuic/package.nix +++ b/pkgs/by-name/tu/tuic/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, }: -rustPlatform.buildRustPackage rec{ +rustPlatform.buildRustPackage rec { pname = "tuic"; version = "1.0.0"; @@ -16,9 +17,12 @@ rustPlatform.buildRustPackage rec{ hash = "sha256-VoNr91vDqBlt9asT/dwCeYk13UNiDexNNiKwD5DSn8k="; }; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - Security - ]); + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Security + ] + ); postPatch = '' ln -sf ${./Cargo.lock} Cargo.lock diff --git a/pkgs/by-name/tu/tuifimanager/package.nix b/pkgs/by-name/tu/tuifimanager/package.nix index 7d2a68badb691e..d38c9772fa99e9 100644 --- a/pkgs/by-name/tu/tuifimanager/package.nix +++ b/pkgs/by-name/tu/tuifimanager/package.nix @@ -1,77 +1,87 @@ -{ stdenv -, lib -, python3 -, fetchFromGitHub -, kdePackages -, gnome-themes-extra -, qt6 -, makeWrapper -, x11Support ? stdenv.hostPlatform.isLinux -# pypinput is marked as broken for darwin -, pynputSupport ? stdenv.hostPlatform.isLinux -# Experimental Drag & Drop support requires x11 & pyinput suport -, hasDndSupport ? x11Support && pynputSupport -, enableDragAndDrop ? false +{ + stdenv, + lib, + python3, + fetchFromGitHub, + kdePackages, + gnome-themes-extra, + qt6, + makeWrapper, + x11Support ? stdenv.hostPlatform.isLinux, + # pypinput is marked as broken for darwin + pynputSupport ? stdenv.hostPlatform.isLinux, + # Experimental Drag & Drop support requires x11 & pyinput suport + hasDndSupport ? x11Support && pynputSupport, + enableDragAndDrop ? false, }: lib.throwIf (enableDragAndDrop && !hasDndSupport) "Drag and drop support is only available for linux with xorg." -python3.pkgs.buildPythonApplication rec { - pname = "tuifimanager"; - version = "5.0.0"; - format = "pyproject"; + python3.pkgs.buildPythonApplication + rec { + pname = "tuifimanager"; + version = "5.0.0"; + format = "pyproject"; - src = fetchFromGitHub { - owner = "GiorgosXou"; - repo = "TUIFIManager"; - rev = "v.${version}"; - hash = "sha256-2yYD1YFGoN0uj3HzcYxEs3zbwfUIDLLzvfTcZILx5h4="; - }; + src = fetchFromGitHub { + owner = "GiorgosXou"; + repo = "TUIFIManager"; + rev = "v.${version}"; + hash = "sha256-2yYD1YFGoN0uj3HzcYxEs3zbwfUIDLLzvfTcZILx5h4="; + }; - nativeBuildInputs = [ - python3.pkgs.setuptools - python3.pkgs.setuptools-scm - ] ++ (lib.optionals enableDragAndDrop [ - qt6.wrapQtAppsHook - makeWrapper - ]); + nativeBuildInputs = + [ + python3.pkgs.setuptools + python3.pkgs.setuptools-scm + ] + ++ (lib.optionals enableDragAndDrop [ + qt6.wrapQtAppsHook + makeWrapper + ]); - propagatedBuildInputs = [ - python3.pkgs.send2trash - python3.pkgs.unicurses - ] ++ (lib.optionals enableDragAndDrop [ - python3.pkgs.pynput - python3.pkgs.pyside6 - python3.pkgs.requests - python3.pkgs.xlib - kdePackages.qtbase - kdePackages.qt6gtk2 - ]); + propagatedBuildInputs = + [ + python3.pkgs.send2trash + python3.pkgs.unicurses + ] + ++ (lib.optionals enableDragAndDrop [ + python3.pkgs.pynput + python3.pkgs.pyside6 + python3.pkgs.requests + python3.pkgs.xlib + kdePackages.qtbase + kdePackages.qt6gtk2 + ]); - postFixup = let - # fix missing 'adwaita' warning missing with ncurses tui - # see: https://github.com/NixOS/nixpkgs/issues/60918 - theme = gnome-themes-extra; - in - lib.optionalString enableDragAndDrop '' - wrapProgram $out/bin/tuifi \ - --prefix GTK_PATH : "${theme}/lib/gtk-2.0" \ - --set tuifi_synth_dnd True - ''; + postFixup = + let + # fix missing 'adwaita' warning missing with ncurses tui + # see: https://github.com/NixOS/nixpkgs/issues/60918 + theme = gnome-themes-extra; + in + lib.optionalString enableDragAndDrop '' + wrapProgram $out/bin/tuifi \ + --prefix GTK_PATH : "${theme}/lib/gtk-2.0" \ + --set tuifi_synth_dnd True + ''; - pythonImportsCheck = [ "TUIFIManager" ]; + pythonImportsCheck = [ "TUIFIManager" ]; - meta = { - description = "Cross-platform terminal-based termux-oriented file manager"; - longDescription = '' - A cross-platform terminal-based termux-oriented file manager (and component), - meant to be used with a Uni-Curses project or as is. This project is mainly an - attempt to get more attention to the Uni-Curses project. - ''; - homepage = "https://github.com/GiorgosXou/TUIFIManager"; - license = lib.licenses.gpl3Only; - maintainers = with lib.maintainers; [ michaelBelsanti sigmanificient ]; - mainProgram = "tuifi"; - }; -} + meta = { + description = "Cross-platform terminal-based termux-oriented file manager"; + longDescription = '' + A cross-platform terminal-based termux-oriented file manager (and component), + meant to be used with a Uni-Curses project or as is. This project is mainly an + attempt to get more attention to the Uni-Curses project. + ''; + homepage = "https://github.com/GiorgosXou/TUIFIManager"; + license = lib.licenses.gpl3Only; + maintainers = with lib.maintainers; [ + michaelBelsanti + sigmanificient + ]; + mainProgram = "tuifi"; + }; + } diff --git a/pkgs/by-name/tu/tuir/package.nix b/pkgs/by-name/tu/tuir/package.nix index 3cc36bf8ae3c7c..e193ea2d9ecfcb 100644 --- a/pkgs/by-name/tu/tuir/package.nix +++ b/pkgs/by-name/tu/tuir/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitLab, python3Packages }: +{ + lib, + fetchFromGitLab, + python3Packages, +}: with python3Packages; buildPythonApplication rec { @@ -19,15 +23,34 @@ buildPythonApplication rec { py.test ''; - nativeCheckInputs = [ coverage coveralls docopt mock pylint pytest vcrpy ]; + nativeCheckInputs = [ + coverage + coveralls + docopt + mock + pylint + pytest + vcrpy + ]; - propagatedBuildInputs = [ beautifulsoup4 decorator kitchen mailcap-fix requests six ]; + propagatedBuildInputs = [ + beautifulsoup4 + decorator + kitchen + mailcap-fix + requests + six + ]; meta = with lib; { description = "Browse Reddit from your Terminal (fork of rtv)"; mainProgram = "tuir"; homepage = "https://gitlab.com/Chocimier/tuir"; license = licenses.mit; - maintainers = with maintainers; [ Br1ght0ne matthiasbeyer brokenpip3 ]; + maintainers = with maintainers; [ + Br1ght0ne + matthiasbeyer + brokenpip3 + ]; }; } diff --git a/pkgs/by-name/tu/tuleap-cli/package.nix b/pkgs/by-name/tu/tuleap-cli/package.nix index 73abdd14db75f2..daffbbda7cce23 100644 --- a/pkgs/by-name/tu/tuleap-cli/package.nix +++ b/pkgs/by-name/tu/tuleap-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitLab -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitLab, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/tu/tumiki-fighters/package.nix b/pkgs/by-name/tu/tumiki-fighters/package.nix index 0049412b0e6cdf..f89c6f5275b878 100644 --- a/pkgs/by-name/tu/tumiki-fighters/package.nix +++ b/pkgs/by-name/tu/tumiki-fighters/package.nix @@ -1,58 +1,46 @@ -{ lib -, stdenv -, fetchpatch -, fetchurl -, unzip -, gdc -, SDL -, SDL_mixer -, bulletml +{ + lib, + stdenv, + fetchpatch, + fetchurl, + unzip, + gdc, + SDL, + SDL_mixer, + bulletml, }: let -debianPatch = patchname: hash: fetchpatch { - name = "${patchname}.patch"; - url = "https://sources.debian.org/data/main/t/tumiki-fighters/0.2.dfsg1-9/debian/patches/${patchname}.patch"; - sha256 = hash; -}; + debianPatch = + patchname: hash: + fetchpatch { + name = "${patchname}.patch"; + url = "https://sources.debian.org/data/main/t/tumiki-fighters/0.2.dfsg1-9/debian/patches/${patchname}.patch"; + sha256 = hash; + }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "tumiki-fighters"; version = "0.21"; src = fetchurl { - url = "http://abagames.sakura.ne.jp/windows/tf${lib.replaceStrings ["."] ["_"] finalAttrs.version}.zip"; + url = "http://abagames.sakura.ne.jp/windows/tf${ + lib.replaceStrings [ "." ] [ "_" ] finalAttrs.version + }.zip"; sha256 = "0djykfc1r8ysapklm621h89ana1c4qzc1m5nr9bqw4iccnmvwk3p"; }; patches = [ - (debianPatch - "imports" - "1l3kc67b43gdi139cpz5cka1nkn0pjp9mrgrrxlmr0liwx2aryhn") - (debianPatch - "fixes" - "1iy1a5vii6yz9zdlk2bcj6gkj4y25hn9y2fczz15jpqd9r2zm603") - (debianPatch - "directories" - "0kmv0s7jgr693fzrkjsmz4dnicc4w7njanxm2la3cf4vmgdyipmm") - (debianPatch - "windowed" - "1wp74l0bi8wq85pcxnmkwrlfmlf09im95n27pxgz082lhwf2ksy1") - (debianPatch - "dotfile" - "0d8x519bclh41j992qn6ijzfcrgacb79px6zjd1awypkwyc0j2p6") - (debianPatch - "makefile" - "11xf2b31kjyps53jfryv82dv0g6q0smc9xgp8imrbr93mzi51vf0") - (debianPatch - "window-resizing" - "1dm79d0yisa8zs5fr89y3wq2kzd3khcaxs0la8lhncvkqbd4smx8") - (debianPatch - "dlang_v2" - "1isnvbl3bjnpyphji8k3fl0yd1z4869h0lai143vpwgj6518lpg4") - (debianPatch - "gdc-8" - "1md0zwmv50jnak5g9d93bglv9v4z41blinjii6kv3vmgjnajapzj") + (debianPatch "imports" "1l3kc67b43gdi139cpz5cka1nkn0pjp9mrgrrxlmr0liwx2aryhn") + (debianPatch "fixes" "1iy1a5vii6yz9zdlk2bcj6gkj4y25hn9y2fczz15jpqd9r2zm603") + (debianPatch "directories" "0kmv0s7jgr693fzrkjsmz4dnicc4w7njanxm2la3cf4vmgdyipmm") + (debianPatch "windowed" "1wp74l0bi8wq85pcxnmkwrlfmlf09im95n27pxgz082lhwf2ksy1") + (debianPatch "dotfile" "0d8x519bclh41j992qn6ijzfcrgacb79px6zjd1awypkwyc0j2p6") + (debianPatch "makefile" "11xf2b31kjyps53jfryv82dv0g6q0smc9xgp8imrbr93mzi51vf0") + (debianPatch "window-resizing" "1dm79d0yisa8zs5fr89y3wq2kzd3khcaxs0la8lhncvkqbd4smx8") + (debianPatch "dlang_v2" "1isnvbl3bjnpyphji8k3fl0yd1z4869h0lai143vpwgj6518lpg4") + (debianPatch "gdc-8" "1md0zwmv50jnak5g9d93bglv9v4z41blinjii6kv3vmgjnajapzj") ]; postPatch = '' diff --git a/pkgs/by-name/tu/tun2socks/package.nix b/pkgs/by-name/tu/tun2socks/package.nix index a26c2e3f937742..c35c0887baa0f8 100644 --- a/pkgs/by-name/tu/tun2socks/package.nix +++ b/pkgs/by-name/tu/tun2socks/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -17,7 +18,8 @@ buildGoModule rec { vendorHash = "sha256-7x3vVRFFxWhwwelPJ2EV78UTSXIo6bMj3ljVIPTPteg="; ldflags = [ - "-w" "-s" + "-w" + "-s" "-X github.com/xjasonlyu/tun2socks/v2/internal/version.Version=v${version}" "-X github.com/xjasonlyu/tun2socks/v2/internal/version.GitCommit=v${version}" ]; diff --git a/pkgs/by-name/tu/tunctl/package.nix b/pkgs/by-name/tu/tunctl/package.nix index 40d1aa572487aa..bc1b965f4618e2 100644 --- a/pkgs/by-name/tu/tunctl/package.nix +++ b/pkgs/by-name/tu/tunctl/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "tunctl"; diff --git a/pkgs/by-name/tu/tuner/package.nix b/pkgs/by-name/tu/tuner/package.nix index a241bcd408b563..6b09c43515396e 100644 --- a/pkgs/by-name/tu/tuner/package.nix +++ b/pkgs/by-name/tu/tuner/package.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, meson -, ninja -, vala -, glib -, itstool -, wrapGAppsHook3 -, desktop-file-utils -, libsoup_2_4 -, json-glib -, geoclue2 -, geocode-glib -, libgee -, gtk3 -, pantheon -, gst_all_1 +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + meson, + ninja, + vala, + glib, + itstool, + wrapGAppsHook3, + desktop-file-utils, + libsoup_2_4, + json-glib, + geoclue2, + geocode-glib, + libgee, + gtk3, + pantheon, + gst_all_1, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/tu/tunnelx/package.nix b/pkgs/by-name/tu/tunnelx/package.nix index 8209635d8859a5..1abab58ca5b6e4 100644 --- a/pkgs/by-name/tu/tunnelx/package.nix +++ b/pkgs/by-name/tu/tunnelx/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, jdk -, jre -, survex -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + jdk, + jre, + survex, + makeWrapper, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/tu/tuntox/package.nix b/pkgs/by-name/tu/tuntox/package.nix index 07fa3e3160928f..8dd1864b00f8a9 100644 --- a/pkgs/by-name/tu/tuntox/package.nix +++ b/pkgs/by-name/tu/tuntox/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, cscope -, fetchFromGitHub -, fetchpatch -, git -, libevent -, libopus -, libsodium -, libtoxcore -, libvpx -, msgpack -, pkg-config -, python3 -, python3Packages +{ + lib, + stdenv, + cscope, + fetchFromGitHub, + fetchpatch, + git, + libevent, + libopus, + libsodium, + libtoxcore, + libvpx, + msgpack, + pkg-config, + python3, + python3Packages, }: stdenv.mkDerivation rec { @@ -26,9 +27,21 @@ stdenv.mkDerivation rec { sha256 = "sha256-c/0OxUH8iw8nRuVg4Fszf6Z/JiEV+m0B2ofzy81uFu8="; }; - nativeBuildInputs = [ cscope git pkg-config ]; + nativeBuildInputs = [ + cscope + git + pkg-config + ]; - buildInputs = [ libopus libtoxcore libsodium libevent libvpx msgpack python3 ]; + buildInputs = [ + libopus + libtoxcore + libsodium + libevent + libvpx + msgpack + python3 + ]; pythonBuildInputs = with python3Packages; [ jinja2 @@ -43,22 +56,27 @@ stdenv.mkDerivation rec { }) ]; - postPatch = '' + postPatch = + '' substituteInPlace gitversion.h --replace '7d45afdf7d00a95a8c3687175e2b1669fa1f7745' '365d2e5cbc0e3655fb64c204db0515f5f4cdf5a4' - '' + lib.optionalString stdenv.hostPlatform.isLinux '' + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' substituteInPlace Makefile --replace ' -static ' ' ' substituteInPlace Makefile --replace 'CC=gcc' ' ' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' substituteInPlace Makefile.mac --replace '.git/HEAD .git/index' ' ' substituteInPlace Makefile.mac --replace '/usr/local/lib/libtoxcore.a' '${libtoxcore}/lib/libtoxcore.a' substituteInPlace Makefile.mac --replace '/usr/local/lib/libsodium.a' '${libsodium}/lib/libsodium.dylib' substituteInPlace Makefile.mac --replace 'CC=gcc' ' ' ''; - buildPhase = '' - '' + lib.optionalString stdenv.hostPlatform.isLinux '' + buildPhase = + '''' + + lib.optionalString stdenv.hostPlatform.isLinux '' make - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' make -f Makefile.mac tuntox ''; diff --git a/pkgs/by-name/tu/tunwg/package.nix b/pkgs/by-name/tu/tunwg/package.nix index ab43b9e5a419bd..3616c023fea84c 100644 --- a/pkgs/by-name/tu/tunwg/package.nix +++ b/pkgs/by-name/tu/tunwg/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-5BJFAnsmx6lbGQTx/6dIdcsETsllCr6C3wPbB2Gvj5Y="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Secure private tunnel to your local servers"; diff --git a/pkgs/by-name/tu/tup/package.nix b/pkgs/by-name/tu/tup/package.nix index db6a6058a00b53..2b0299e219e106 100644 --- a/pkgs/by-name/tu/tup/package.nix +++ b/pkgs/by-name/tu/tup/package.nix @@ -1,11 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, fuse3, macfuse-stubs, pkg-config, sqlite, pcre2 }: +{ + lib, + stdenv, + fetchFromGitHub, + fuse3, + macfuse-stubs, + pkg-config, + sqlite, + pcre2, +}: let fuse = if stdenv.hostPlatform.isDarwin then macfuse-stubs else fuse3; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "tup"; version = "0.8"; - outputs = [ "bin" "man" "out" ]; + outputs = [ + "bin" + "man" + "out" + ]; src = fetchFromGitHub { owner = "gittup"; @@ -15,7 +29,11 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ fuse pcre2 sqlite ]; + buildInputs = [ + fuse + pcre2 + sqlite + ]; patches = [ ./fusermount-setuid.patch ]; diff --git a/pkgs/by-name/tu/tuptime/package.nix b/pkgs/by-name/tu/tuptime/package.nix index 12027e463ad9e7..02b01ff4a45577 100644 --- a/pkgs/by-name/tu/tuptime/package.nix +++ b/pkgs/by-name/tu/tuptime/package.nix @@ -1,7 +1,12 @@ -{ lib, stdenv, fetchFromGitHub -, makeWrapper, installShellFiles -, python3, sqlite -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + installShellFiles, + python3, + sqlite, + nixosTests, }: stdenv.mkDerivation rec { @@ -15,11 +20,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-pYGtgv9hPBG/URD2nOWg6qJYYLtlqLW+t5mCLpzKlEc="; }; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; buildInputs = [ python3 ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/tu/turses/package.nix b/pkgs/by-name/tu/turses/package.nix index 0df36afc3fdfd7..43008d436c92d5 100644 --- a/pkgs/by-name/tu/turses/package.nix +++ b/pkgs/by-name/tu/turses/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchpatch -, fetchFromGitHub -, fetchPypi -, python3 +{ + lib, + fetchpatch, + fetchFromGitHub, + fetchPypi, + python3, }: let diff --git a/pkgs/by-name/tu/turso-cli/package.nix b/pkgs/by-name/tu/turso-cli/package.nix index d08622783bf5aa..b050c1ef68d7ae 100644 --- a/pkgs/by-name/tu/turso-cli/package.nix +++ b/pkgs/by-name/tu/turso-cli/package.nix @@ -43,6 +43,10 @@ buildGoModule rec { homepage = "https://turso.tech"; mainProgram = "turso"; license = licenses.mit; - maintainers = with maintainers; [ zestsystem kashw2 fryuni ]; + maintainers = with maintainers; [ + zestsystem + kashw2 + fryuni + ]; }; } diff --git a/pkgs/by-name/tu/turtle-build/package.nix b/pkgs/by-name/tu/turtle-build/package.nix index e1fbd6bf12616a..86b153d13f9ac8 100644 --- a/pkgs/by-name/tu/turtle-build/package.nix +++ b/pkgs/by-name/tu/turtle-build/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Ninja-compatible build system for high-level programming languages written in Rust"; homepage = "https://github.com/raviqqe/turtle-build"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "turtle"; }; diff --git a/pkgs/by-name/tu/tusc-sh/package.nix b/pkgs/by-name/tu/tusc-sh/package.nix index f5b1ce36e152e6..08fe5eb9a8952c 100644 --- a/pkgs/by-name/tu/tusc-sh/package.nix +++ b/pkgs/by-name/tu/tusc-sh/package.nix @@ -1,40 +1,46 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, writeShellApplication -, curl -, coreutils -, jq +{ + lib, + stdenvNoCC, + fetchFromGitHub, + writeShellApplication, + curl, + coreutils, + jq, }: let tusc = stdenvNoCC.mkDerivation (finalAttrs: { - pname = "tusc-sh"; - version = "1.1.1"; + pname = "tusc-sh"; + version = "1.1.1"; - src = fetchFromGitHub { - owner = "adhocore"; - repo = "tusc.sh"; - rev = finalAttrs.version; - hash = "sha256-EKlcE+rsVh5lUd8dQzAwXDjiUvrrud5yWfF6JWSZQFE="; - }; + src = fetchFromGitHub { + owner = "adhocore"; + repo = "tusc.sh"; + rev = finalAttrs.version; + hash = "sha256-EKlcE+rsVh5lUd8dQzAwXDjiUvrrud5yWfF6JWSZQFE="; + }; - dontConfigure = true; - dontBuild = true; + dontConfigure = true; + dontBuild = true; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - install -Dm755 tusc.sh -t $out/bin + install -Dm755 tusc.sh -t $out/bin - runHook postInstall - ''; + runHook postInstall + ''; -}); + }); in writeShellApplication { name = "tusc"; - runtimeInputs = [ tusc curl coreutils jq ]; + runtimeInputs = [ + tusc + curl + coreutils + jq + ]; text = '' tusc.sh "$@" ''; diff --git a/pkgs/by-name/tu/tusk/package.nix b/pkgs/by-name/tu/tusk/package.nix index 89a27a770e6fe0..2dc7e6290f60bc 100644 --- a/pkgs/by-name/tu/tusk/package.nix +++ b/pkgs/by-name/tu/tusk/package.nix @@ -1,4 +1,9 @@ -{ appimageTools, fetchurl, lib, makeDesktopItem }: +{ + appimageTools, + fetchurl, + lib, + makeDesktopItem, +}: let pname = "tusk"; @@ -18,7 +23,8 @@ let categories = [ "Application" ]; }; -in appimageTools.wrapType2 rec { +in +appimageTools.wrapType2 rec { inherit pname version; src = fetchurl { @@ -26,7 +32,6 @@ in appimageTools.wrapType2 rec { sha256 = "02q7wsnhlyq8z74avflrm7805ny8fzlmsmz4bmafp4b4pghjh5ky"; }; - profile = '' export LC_ALL=C.UTF-8 ''; diff --git a/pkgs/by-name/tu/tut/package.nix b/pkgs/by-name/tu/tut/package.nix index f6094f516694c0..4e2cc64c3dac94 100644 --- a/pkgs/by-name/tu/tut/package.nix +++ b/pkgs/by-name/tu/tut/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "tut"; diff --git a/pkgs/by-name/tu/tutanota-desktop/package.nix b/pkgs/by-name/tu/tutanota-desktop/package.nix index 30661d875f79e6..87aeccd8c3903a 100644 --- a/pkgs/by-name/tu/tutanota-desktop/package.nix +++ b/pkgs/by-name/tu/tutanota-desktop/package.nix @@ -1,7 +1,8 @@ -{ lib -, appimageTools -, fetchurl -, gitUpdater +{ + lib, + appimageTools, + fetchurl, + gitUpdater, }: appimageTools.wrapType2 rec { @@ -16,8 +17,10 @@ appimageTools.wrapType2 rec { extraPkgs = pkgs: [ pkgs.libsecret ]; extraInstallCommands = - let appimageContents = appimageTools.extract { inherit pname version src; }; - in '' + let + appimageContents = appimageTools.extract { inherit pname version src; }; + in + '' install -Dm 444 ${appimageContents}/tutanota-desktop.desktop -t $out/share/applications install -Dm 444 ${appimageContents}/tutanota-desktop.png -t $out/share/pixmaps diff --git a/pkgs/by-name/tu/tuxclocker-nvidia-plugin/package.nix b/pkgs/by-name/tu/tuxclocker-nvidia-plugin/package.nix index 50f98eb550ab11..8e768064b786a6 100644 --- a/pkgs/by-name/tu/tuxclocker-nvidia-plugin/package.nix +++ b/pkgs/by-name/tu/tuxclocker-nvidia-plugin/package.nix @@ -1,16 +1,22 @@ -{ stdenv -, boost -, libX11 -, libXext -, linuxPackages -, openssl -, tuxclocker-plugins +{ + stdenv, + boost, + libX11, + libXext, + linuxPackages, + openssl, + tuxclocker-plugins, }: stdenv.mkDerivation { pname = "tuxclocker-nvidia-plugin"; - inherit (tuxclocker-plugins) src version meta nativeBuildInputs; + inherit (tuxclocker-plugins) + src + version + meta + nativeBuildInputs + ; buildInputs = [ boost diff --git a/pkgs/by-name/tu/tuxclocker-plugins-with-unfree/package.nix b/pkgs/by-name/tu/tuxclocker-plugins-with-unfree/package.nix index f055cf111fa3b7..2ca6f239e98879 100644 --- a/pkgs/by-name/tu/tuxclocker-plugins-with-unfree/package.nix +++ b/pkgs/by-name/tu/tuxclocker-plugins-with-unfree/package.nix @@ -1,6 +1,7 @@ -{ symlinkJoin -, tuxclocker-nvidia-plugin -, tuxclocker-plugins +{ + symlinkJoin, + tuxclocker-nvidia-plugin, + tuxclocker-plugins, }: symlinkJoin rec { diff --git a/pkgs/by-name/tu/tuxclocker-plugins/package.nix b/pkgs/by-name/tu/tuxclocker-plugins/package.nix index 3cb8ef84d64380..7f01388cdd201c 100644 --- a/pkgs/by-name/tu/tuxclocker-plugins/package.nix +++ b/pkgs/by-name/tu/tuxclocker-plugins/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, boost -, gettext -, libdrm -, meson -, ninja -, openssl -, pkg-config -, python3 -, tuxclocker +{ + stdenv, + boost, + gettext, + libdrm, + meson, + ninja, + openssl, + pkg-config, + python3, + tuxclocker, }: stdenv.mkDerivation { @@ -20,7 +21,7 @@ stdenv.mkDerivation { meson ninja pkg-config - (python3.withPackages(p: [ p.hwdata ])) + (python3.withPackages (p: [ p.hwdata ])) ]; buildInputs = [ diff --git a/pkgs/by-name/tu/tuxedo-rs/package.nix b/pkgs/by-name/tu/tuxedo-rs/package.nix index d6b09df678a8b0..4f9abd7adadc44 100644 --- a/pkgs/by-name/tu/tuxedo-rs/package.nix +++ b/pkgs/by-name/tu/tuxedo-rs/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, testers -, tuxedo-rs +{ + lib, + fetchFromGitHub, + rustPlatform, + testers, + tuxedo-rs, }: rustPlatform.buildRustPackage rec { pname = "tuxedo-rs"; @@ -17,7 +18,6 @@ rustPlatform.buildRustPackage rec { hash = "sha256-+NzwUs8TZsA0us9hI1UmEKdiOo9IqTRmTOHs4xmC7MY="; }; - # Some of the tests are impure and rely on files in /etc/tailord doCheck = false; @@ -44,7 +44,10 @@ rustPlatform.buildRustPackage rec { ''; homepage = "https://github.com/AaronErhardt/tuxedo-rs"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ mrcjkb xaverdh ]; + maintainers = with maintainers; [ + mrcjkb + xaverdh + ]; platforms = platforms.linux; mainProgram = "tailor"; }; diff --git a/pkgs/by-name/tu/tuxmux/package.nix b/pkgs/by-name/tu/tuxmux/package.nix index 49293f49557ade..709ca9d31bee57 100644 --- a/pkgs/by-name/tu/tuxmux/package.nix +++ b/pkgs/by-name/tu/tuxmux/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, libiconv -, pkg-config -, installShellFiles +{ + lib, + fetchFromGitHub, + rustPlatform, + libiconv, + pkg-config, + installShellFiles, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-ZftnJ6SYfPzwgsS44YgL9tbwL8Y+7PahI0EfFbKdlqA="; buildInputs = [ libiconv ]; - nativeBuildInputs = [ pkg-config installShellFiles ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; postInstall = '' installShellCompletion $releaseDir/../completions/tux.{bash,fish} diff --git a/pkgs/by-name/tu/tuxpaint/package.nix b/pkgs/by-name/tu/tuxpaint/package.nix index f0e13bc9be6868..3063332535c759 100644 --- a/pkgs/by-name/tu/tuxpaint/package.nix +++ b/pkgs/by-name/tu/tuxpaint/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchurl -, gettext -, gperf -, imagemagick -, makeWrapper -, pkg-config -, SDL2 -, cairo -, freetype -, fribidi -, libimagequant -, libpaper -, libpng -, librsvg -, pango -, SDL2_gfx -, SDL2_image -, SDL2_mixer -, SDL2_Pango -, SDL2_ttf -, netpbm +{ + lib, + stdenv, + fetchurl, + gettext, + gperf, + imagemagick, + makeWrapper, + pkg-config, + SDL2, + cairo, + freetype, + fribidi, + libimagequant, + libpaper, + libpng, + librsvg, + pango, + SDL2_gfx, + SDL2_image, + SDL2_mixer, + SDL2_Pango, + SDL2_ttf, + netpbm, }: let diff --git a/pkgs/by-name/tu/tuxtype/package.nix b/pkgs/by-name/tu/tuxtype/package.nix index 58a31d46953626..3a30f42e138898 100644 --- a/pkgs/by-name/tu/tuxtype/package.nix +++ b/pkgs/by-name/tu/tuxtype/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, librsvg, libxml2, SDL, SDL_image, SDL_mixer, SDL_net, SDL_ttf, t4kcommon }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + librsvg, + libxml2, + SDL, + SDL_image, + SDL_mixer, + SDL_net, + SDL_ttf, + t4kcommon, +}: stdenv.mkDerivation rec { version = "1.8.3"; @@ -28,8 +42,20 @@ stdenv.mkDerivation rec { --replace 'PKG_CHECK_MODULES([SDL_ttf],' 'PKG_CHECK_MODULES([SDL_TTF],' ''; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ librsvg libxml2 SDL SDL_image SDL_mixer SDL_net SDL_ttf t4kcommon ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + librsvg + libxml2 + SDL + SDL_image + SDL_mixer + SDL_net + SDL_ttf + t4kcommon + ]; configureFlags = [ "--without-sdlpango" ]; diff --git a/pkgs/by-name/tv/tv/package.nix b/pkgs/by-name/tv/tv/package.nix index 154d98b4c592cf..4e42503a4eaab4 100644 --- a/pkgs/by-name/tv/tv/package.nix +++ b/pkgs/by-name/tv/tv/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, lib, rustPlatform }: +{ + fetchFromGitHub, + lib, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "tv"; diff --git a/pkgs/by-name/tv/tvbrowser/package.nix b/pkgs/by-name/tv/tvbrowser/package.nix index f997652c27ecb1..2d33197361932b 100644 --- a/pkgs/by-name/tv/tvbrowser/package.nix +++ b/pkgs/by-name/tv/tvbrowser/package.nix @@ -1,12 +1,13 @@ -{ lib -, fetchurl -, stdenv -, fetchzip -, ant -, jdk -, makeWrapper -, stripJavaArchivesHook -, callPackage +{ + lib, + fetchurl, + stdenv, + fetchzip, + ant, + jdk, + makeWrapper, + stripJavaArchivesHook, + callPackage, }: let @@ -26,7 +27,12 @@ stdenv.mkDerivation rec { hash = "sha256-dmNfI6T0MU7UtMH+C/2hiAeDwZlFCB4JofQViZezoqI="; }; - nativeBuildInputs = [ ant jdk makeWrapper stripJavaArchivesHook ]; + nativeBuildInputs = [ + ant + jdk + makeWrapper + stripJavaArchivesHook + ]; buildPhase = '' runHook preBuild @@ -66,14 +72,17 @@ stdenv.mkDerivation rec { runHook postInstall ''; - passthru.tests.startwindow = callPackage ./test.nix {}; + passthru.tests.startwindow = callPackage ./test.nix { }; meta = with lib; { description = "Electronic TV Program Guide"; downloadPage = "https://www.tvbrowser.org/index.php?id=tv-browser"; homepage = "https://www.tvbrowser.org/"; changelog = "https://www.tvbrowser.org/index.php?id=news"; - sourceProvenance = with sourceTypes; [ binaryBytecode fromSource ]; + sourceProvenance = with sourceTypes; [ + binaryBytecode + fromSource + ]; license = licenses.gpl3Plus; platforms = platforms.linux; mainProgram = "tvbrowser"; diff --git a/pkgs/by-name/tv/tvbrowser/test.nix b/pkgs/by-name/tv/tvbrowser/test.nix index bee843ccbecc81..d7dc2033f6c5e0 100644 --- a/pkgs/by-name/tv/tvbrowser/test.nix +++ b/pkgs/by-name/tv/tvbrowser/test.nix @@ -1,15 +1,19 @@ -{ lib -, xvfb-run -, tvbrowser -, runCommand -, writeShellApplication -, xorg +{ + lib, + xvfb-run, + tvbrowser, + runCommand, + writeShellApplication, + xorg, }: let testScript = writeShellApplication { name = "tvbrowser-test-script"; - runtimeInputs = [ xorg.xwininfo tvbrowser ]; + runtimeInputs = [ + xorg.xwininfo + tvbrowser + ]; text = '' function find_tvbrowser_windows { for window_name in java tvbrowser-TVBrowser 'Setup assistant' ; do @@ -31,10 +35,7 @@ let ''; }; in -runCommand -"tvbrowser-test" -{ buildInputs = [ xvfb-run ]; } -'' +runCommand "tvbrowser-test" { buildInputs = [ xvfb-run ]; } '' HOME=$PWD xvfb-run ${lib.getExe testScript} touch ${placeholder "out"} '' diff --git a/pkgs/by-name/tv/tvm/package.nix b/pkgs/by-name/tv/tvm/package.nix index 45579ad8f16adb..d1d18d891eb090 100644 --- a/pkgs/by-name/tv/tvm/package.nix +++ b/pkgs/by-name/tv/tvm/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "tvm"; diff --git a/pkgs/by-name/tv/tvnamer/package.nix b/pkgs/by-name/tv/tvnamer/package.nix index 5015a5e40b56de..72ef463bd954c8 100644 --- a/pkgs/by-name/tv/tvnamer/package.nix +++ b/pkgs/by-name/tv/tvnamer/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: let diff --git a/pkgs/by-name/tw/twa/package.nix b/pkgs/by-name/tw/twa/package.nix index 909648f8d03c58..02e9dea8eeaf91 100644 --- a/pkgs/by-name/tw/twa/package.nix +++ b/pkgs/by-name/tw/twa/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, bash -, curl -, dnsutils -, gawk -, jq -, ncurses -, netcat +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + bash, + curl, + dnsutils, + gawk, + jq, + ncurses, + netcat, }: stdenv.mkDerivation rec { @@ -26,12 +27,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ bash - curl - dnsutils - gawk - jq - netcat ]; + buildInputs = [ + bash + curl + dnsutils + gawk + jq + netcat + ]; installPhase = '' runHook preInstall @@ -42,12 +45,16 @@ stdenv.mkDerivation rec { install -Dm 0644 README.md "$out/share/doc/twa/README.md" wrapProgram "$out/bin/twa" \ - --prefix PATH : ${lib.makeBinPath [ curl - dnsutils - gawk - jq - ncurses - netcat ]} + --prefix PATH : ${ + lib.makeBinPath [ + curl + dnsutils + gawk + jq + ncurses + netcat + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/tw/tweak/package.nix b/pkgs/by-name/tw/tweak/package.nix index 24d6152e68bb4b..a974d8467d6b03 100644 --- a/pkgs/by-name/tw/tweak/package.nix +++ b/pkgs/by-name/tw/tweak/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "tweak"; @@ -11,7 +16,10 @@ stdenv.mkDerivation rec { buildInputs = [ ncurses ]; preBuild = "substituteInPlace Makefile --replace '$(DESTDIR)/usr/local' $out"; - makeFlags = [ "CC:=$(CC)" "LINK:=$(CC)" ]; + makeFlags = [ + "CC:=$(CC)" + "LINK:=$(CC)" + ]; meta = with lib; { description = "Efficient hex editor"; diff --git a/pkgs/by-name/tw/tweego/package.nix b/pkgs/by-name/tw/tweego/package.nix index 16c01c105265c7..f0e77b801d9de8 100644 --- a/pkgs/by-name/tw/tweego/package.nix +++ b/pkgs/by-name/tw/tweego/package.nix @@ -25,7 +25,7 @@ buildGoModule rec { description = "Free (gratis and libre) command line compiler for Twine/Twee story formats, written in Go"; homepage = "https://www.motoslave.net/tweego"; license = lib.licenses.bsd2; - maintainers = with lib.maintainers; [chrispwill]; + maintainers = with lib.maintainers; [ chrispwill ]; mainProgram = "tweego"; }; } diff --git a/pkgs/by-name/tw/tweeny/package.nix b/pkgs/by-name/tw/tweeny/package.nix index 131cf2194ae85e..e17e0cafe28a65 100644 --- a/pkgs/by-name/tw/tweeny/package.nix +++ b/pkgs/by-name/tw/tweeny/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake +{ + stdenv, + lib, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/tw/twemoji-color-font/package.nix b/pkgs/by-name/tw/twemoji-color-font/package.nix index ca1ecd8f8bf96f..d55af5b4b6e9cc 100644 --- a/pkgs/by-name/tw/twemoji-color-font/package.nix +++ b/pkgs/by-name/tw/twemoji-color-font/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation (finalAttrs: { @@ -36,7 +37,10 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://github.com/eosrei/twemoji-color-font"; downloadPage = "https://github.com/eosrei/twemoji-color-font/releases"; - license = with licenses; [ cc-by-40 mit ]; + license = with licenses; [ + cc-by-40 + mit + ]; maintainers = [ maintainers.fgaz ]; }; }) diff --git a/pkgs/by-name/tw/twiggy/package.nix b/pkgs/by-name/tw/twiggy/package.nix index dd34321c81e679..5c621073915b42 100644 --- a/pkgs/by-name/tw/twiggy/package.nix +++ b/pkgs/by-name/tw/twiggy/package.nix @@ -1,6 +1,8 @@ -{ lib -, fetchCrate -, rustPlatform }: +{ + lib, + fetchCrate, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "twiggy"; @@ -17,7 +19,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://rustwasm.github.io/twiggy/"; description = "Code size profiler for Wasm"; mainProgram = "twiggy"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ lucperkins ]; }; } diff --git a/pkgs/by-name/tw/twilio-cli/package.nix b/pkgs/by-name/tw/twilio-cli/package.nix index 6da86221a807f0..0b4daf98e21a35 100644 --- a/pkgs/by-name/tw/twilio-cli/package.nix +++ b/pkgs/by-name/tw/twilio-cli/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenvNoCC, nodejs-slim, fetchzip, testers }: +{ + lib, + stdenvNoCC, + nodejs-slim, + fetchzip, + testers, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "twilio-cli"; diff --git a/pkgs/by-name/tw/twingate/package.nix b/pkgs/by-name/tw/twingate/package.nix index dfab962499f956..6525bdf0f0e497 100644 --- a/pkgs/by-name/tw/twingate/package.nix +++ b/pkgs/by-name/tw/twingate/package.nix @@ -1,14 +1,15 @@ -{ autoPatchelfHook -, curl -, dpkg -, dbus -, fetchurl -, lib -, libnl -, udev -, cryptsetup -, stdenv -, nixosTests +{ + autoPatchelfHook, + curl, + dpkg, + dbus, + fetchurl, + lib, + libnl, + udev, + cryptsetup, + stdenv, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/tw/twitch-cli/package.nix b/pkgs/by-name/tw/twitch-cli/package.nix index c8dbc9b42d1420..64b0ee6fd24784 100644 --- a/pkgs/by-name/tw/twitch-cli/package.nix +++ b/pkgs/by-name/tw/twitch-cli/package.nix @@ -1,8 +1,9 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, testers -, twitch-cli +{ + buildGoModule, + fetchFromGitHub, + lib, + testers, + twitch-cli, }: buildGoModule rec { diff --git a/pkgs/by-name/tw/twitch-dl/package.nix b/pkgs/by-name/tw/twitch-dl/package.nix index 18c446dcf49872..877683f51fba47 100644 --- a/pkgs/by-name/tw/twitch-dl/package.nix +++ b/pkgs/by-name/tw/twitch-dl/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, python3Packages -, installShellFiles -, scdoc -, ffmpeg +{ + lib, + fetchFromGitHub, + python3Packages, + installShellFiles, + scdoc, + ffmpeg, }: python3Packages.buildPythonApplication rec { @@ -29,7 +30,6 @@ python3Packages.buildPythonApplication rec { scdoc ]; - propagatedBuildInputs = with python3Packages; [ click httpx @@ -61,7 +61,10 @@ python3Packages.buildPythonApplication rec { ]; makeWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath [ ffmpeg ]) + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ ffmpeg ]) ]; postInstall = '' @@ -78,7 +81,10 @@ python3Packages.buildPythonApplication rec { homepage = "https://github.com/ihabunek/twitch-dl"; changelog = "https://github.com/ihabunek/twitch-dl/blob/${src.rev}/CHANGELOG.md"; license = licenses.gpl3Only; - maintainers = with maintainers; [ pbsds hausken ]; + maintainers = with maintainers; [ + pbsds + hausken + ]; mainProgram = "twitch-dl"; }; } diff --git a/pkgs/by-name/tw/twitter-color-emoji/package.nix b/pkgs/by-name/tw/twitter-color-emoji/package.nix index 69aae92d966a02..5ddcb8a7d6130b 100644 --- a/pkgs/by-name/tw/twitter-color-emoji/package.nix +++ b/pkgs/by-name/tw/twitter-color-emoji/package.nix @@ -1,16 +1,18 @@ # Based upon https://src.fedoraproject.org/rpms/twitter-twemoji-fonts # The main difference is that we use “Twitter Color Emoji” name (which is recognized by upstream fontconfig) -{ lib, stdenv -, fetchFromGitHub -, cairo -, imagemagick -, pkg-config -, pngquant -, python3 -, which -, zopfli -, noto-fonts-color-emoji +{ + lib, + stdenv, + fetchFromGitHub, + cairo, + imagemagick, + pkg-config, + pngquant, + python3, + which, + zopfli, + noto-fonts-color-emoji, }: let @@ -24,8 +26,12 @@ let hash = "sha256-FLOqXDpSFyClBlG5u3IRL0EKeu1mckCfRizJh++IWxo="; }; - pythonEnv = - python3.withPackages (ps: with ps; [ fonttools nototools ]); + pythonEnv = python3.withPackages ( + ps: with ps; [ + fonttools + nototools + ] + ); in stdenv.mkDerivation rec { @@ -54,28 +60,30 @@ stdenv.mkDerivation rec { zopfli ]; - postPatch = let - templateSubstitutions = lib.concatStringsSep "; " [ - "s#Noto Color Emoji#Twitter Color Emoji#" - "s#NotoColorEmoji#TwitterColorEmoji#" - ''s#Copyright .* Google Inc\.#Twitter, Inc and other contributors.#'' - "s# Version .*# ${version}#" - "s#.*is a trademark.*##" - ''s#Google, Inc\.#Twitter, Inc and other contributors#'' - "s#http://www.google.com/get/noto/#https://twemoji.twitter.com/#" - "s#.*is licensed under.*# Creative Commons Attribution 4.0 International#" - "s#http://scripts.sil.org/OFL#http://creativecommons.org/licenses/by/4.0/#" - ]; - in '' - ${noto-fonts-color-emoji.postPatch} - - sed '${templateSubstitutions}' NotoColorEmoji.tmpl.ttx.tmpl > TwitterColorEmoji.tmpl.ttx.tmpl - pushd ${twemojiSrc.name}/assets/72x72/ - for png in *.png; do - mv $png emoji_u''${png//-/_} - done - popd - ''; + postPatch = + let + templateSubstitutions = lib.concatStringsSep "; " [ + "s#Noto Color Emoji#Twitter Color Emoji#" + "s#NotoColorEmoji#TwitterColorEmoji#" + ''s#Copyright .* Google Inc\.#Twitter, Inc and other contributors.#'' + "s# Version .*# ${version}#" + "s#.*is a trademark.*##" + ''s#Google, Inc\.#Twitter, Inc and other contributors#'' + "s#http://www.google.com/get/noto/#https://twemoji.twitter.com/#" + "s#.*is licensed under.*# Creative Commons Attribution 4.0 International#" + "s#http://scripts.sil.org/OFL#http://creativecommons.org/licenses/by/4.0/#" + ]; + in + '' + ${noto-fonts-color-emoji.postPatch} + + sed '${templateSubstitutions}' NotoColorEmoji.tmpl.ttx.tmpl > TwitterColorEmoji.tmpl.ttx.tmpl + pushd ${twemojiSrc.name}/assets/72x72/ + for png in *.png; do + mv $png emoji_u''${png//-/_} + done + popd + ''; makeFlags = [ "EMOJI=TwitterColorEmoji" @@ -110,7 +118,12 @@ stdenv.mkDerivation rec { ## Non-artwork is MIT # In Fedora twitter-twemoji-fonts source ## spec files are MIT: https://fedoraproject.org/wiki/Licensing:Main#License_of_Fedora_SPEC_Files - license = with licenses; [ asl20 ofl cc-by-40 mit ]; + license = with licenses; [ + asl20 + ofl + cc-by-40 + mit + ]; maintainers = with maintainers; [ emily ]; }; } diff --git a/pkgs/by-name/tw/twitterBootstrap/package.nix b/pkgs/by-name/tw/twitterBootstrap/package.nix index 328154ef810fab..78f4c77e461755 100644 --- a/pkgs/by-name/tw/twitterBootstrap/package.nix +++ b/pkgs/by-name/tw/twitterBootstrap/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, unzip +{ + lib, + stdenv, + fetchurl, + unzip, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/tw/twm/package.nix b/pkgs/by-name/tw/twm/package.nix index 20e1d9290e44db..273185e90bd862 100644 --- a/pkgs/by-name/tw/twm/package.nix +++ b/pkgs/by-name/tw/twm/package.nix @@ -1,12 +1,13 @@ -{ lib -, darwin -, fetchFromGitHub -, stdenv -, rustPlatform -, openssl -, pkg-config -, nix-update-script -, installShellFiles +{ + lib, + darwin, + fetchFromGitHub, + stdenv, + rustPlatform, + openssl, + pkg-config, + nix-update-script, + installShellFiles, }: rustPlatform.buildRustPackage rec { @@ -22,8 +23,13 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-BjQ7dDXHzX+O/V328TTwl9wGtpOq+NjOMRiZwb9O7ZU="; - nativeBuildInputs = [ pkg-config installShellFiles ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Security ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; + buildInputs = [ + openssl + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Security ]; postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' installShellCompletion --cmd twm \ @@ -42,7 +48,7 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/vinnymeller/twm"; changelog = "https://github.com/vinnymeller/twm/releases/tag/${lib.removePrefix "refs/tags/" src.rev}"; license = lib.licenses.mit; - maintainers = [ lib.maintainers.vinnymeller ]; + maintainers = [ lib.maintainers.vinnymeller ]; mainProgram = "twm"; }; } diff --git a/pkgs/by-name/tw/twolame/package.nix b/pkgs/by-name/tw/twolame/package.nix index eba2fdfe81c5c9..7d7aef89fa83b1 100644 --- a/pkgs/by-name/tw/twolame/package.nix +++ b/pkgs/by-name/tw/twolame/package.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, fetchFromGitHub -, autoreconfHook, pkg-config -, libsndfile }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libsndfile, +}: stdenv.mkDerivation { @@ -14,12 +19,15 @@ stdenv.mkDerivation { sha256 = "1rq3yc8ygzdqid9zk6pixmm4w9sk2vrlx217lhn5bjaglv7iyf7x"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libsndfile ]; doCheck = false; # fails with "../build-scripts/test-driver: line 107: -Mstrict: command not found" - meta = with lib;{ + meta = with lib; { description = "MP2 encoder"; mainProgram = "twolame"; longDescription = '' diff --git a/pkgs/by-name/tw/twspace-crawler/package.nix b/pkgs/by-name/tw/twspace-crawler/package.nix index fa38e636c77ef9..53d936faf81aad 100644 --- a/pkgs/by-name/tw/twspace-crawler/package.nix +++ b/pkgs/by-name/tw/twspace-crawler/package.nix @@ -1,4 +1,8 @@ -{ lib, buildNpmPackage, fetchFromGitHub }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, +}: buildNpmPackage rec { pname = "twspace-crawler"; diff --git a/pkgs/by-name/tw/twspace-dl/package.nix b/pkgs/by-name/tw/twspace-dl/package.nix index 3e22188f5df9ca..32bcf6f2e21ac7 100644 --- a/pkgs/by-name/tw/twspace-dl/package.nix +++ b/pkgs/by-name/tw/twspace-dl/package.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchPypi, ffmpeg-headless }: +{ + lib, + python3Packages, + fetchPypi, + ffmpeg-headless, +}: python3Packages.buildPythonApplication rec { pname = "twspace-dl"; diff --git a/pkgs/by-name/tx/txr/package.nix b/pkgs/by-name/tx/txr/package.nix index 6748b8ee341407..dff76b07be861c 100644 --- a/pkgs/by-name/tx/txr/package.nix +++ b/pkgs/by-name/tx/txr/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, coreutils -, libffi +{ + lib, + stdenv, + fetchurl, + coreutils, + libffi, }: stdenv.mkDerivation (finalAttrs: { @@ -28,16 +29,18 @@ stdenv.mkDerivation (finalAttrs: { substituteInPlace tests/018/process.tl --replace /usr/bin/env ${lib.getBin coreutils}/bin/env ''; - preCheck = let - disabledTests = lib.concatStringsSep " " [ - # - tries to set sticky bits - "tests/018/chmod.tl" - # - warning: unbound function crypt - "tests/018/crypt.tl" - ]; - in '' - rm ${disabledTests} - ''; + preCheck = + let + disabledTests = lib.concatStringsSep " " [ + # - tries to set sticky bits + "tests/018/chmod.tl" + # - warning: unbound function crypt + "tests/018/crypt.tl" + ]; + in + '' + rm ${disabledTests} + ''; postInstall = '' mkdir -p $out/share/vim-plugins/txr/{syntax,ftdetect} @@ -67,7 +70,10 @@ stdenv.mkDerivation (finalAttrs: { ''; changelog = "https://www.kylheku.com/cgit/txr/tree/RELNOTES?h=txr-${finalAttrs.version}"; license = lib.licenses.bsd2; - maintainers = with lib.maintainers; [ AndersonTorres dtzWill ]; + maintainers = with lib.maintainers; [ + AndersonTorres + dtzWill + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/by-name/tx/txt2man/package.nix b/pkgs/by-name/tx/txt2man/package.nix index d5f8159f8a533f..9e80d822649167 100644 --- a/pkgs/by-name/tx/txt2man/package.nix +++ b/pkgs/by-name/tx/txt2man/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, coreutils, gawk }: +{ + lib, + stdenv, + fetchFromGitHub, + coreutils, + gawk, +}: stdenv.mkDerivation rec { pname = "txt2man"; diff --git a/pkgs/by-name/tx/txt2tags/package.nix b/pkgs/by-name/tx/txt2tags/package.nix index 1e48d4c6f3d6f0..e978451b350bba 100644 --- a/pkgs/by-name/tx/txt2tags/package.nix +++ b/pkgs/by-name/tx/txt2tags/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { @@ -32,7 +33,10 @@ python3.pkgs.buildPythonApplication rec { description = "Convert between markup languages"; mainProgram = "txt2tags"; homepage = "https://txt2tags.org/"; - license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ dotlambda kovirobi ]; + license = lib.licenses.gpl2Plus; + maintainers = with lib.maintainers; [ + dotlambda + kovirobi + ]; }; } diff --git a/pkgs/by-name/tx/txtw/package.nix b/pkgs/by-name/tx/txtw/package.nix index 9f8783491b11a7..0268c7b708fb30 100644 --- a/pkgs/by-name/tx/txtw/package.nix +++ b/pkgs/by-name/tx/txtw/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cairo }: +{ + lib, + stdenv, + fetchFromGitHub, + cairo, +}: stdenv.mkDerivation rec { version = "0.4"; diff --git a/pkgs/by-name/ty/tydra/package.nix b/pkgs/by-name/ty/tydra/package.nix index 75c2effedcc689..12b46863c8e762 100644 --- a/pkgs/by-name/ty/tydra/package.nix +++ b/pkgs/by-name/ty/tydra/package.nix @@ -1,4 +1,9 @@ -{ lib, rustPlatform, fetchFromGitHub, installShellFiles }: +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "tydra"; diff --git a/pkgs/by-name/ty/tym/package.nix b/pkgs/by-name/ty/tym/package.nix index 562e06176130cf..2de2c27fd9de0e 100644 --- a/pkgs/by-name/ty/tym/package.nix +++ b/pkgs/by-name/ty/tym/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, autoreconfHook, gtk3, vte, lua5_3, pcre2 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + gtk3, + vte, + lua5_3, + pcre2, +}: stdenv.mkDerivation rec { pname = "tym"; @@ -27,7 +37,10 @@ stdenv.mkDerivation rec { description = "Lua-configurable terminal emulator"; homepage = "https://github.com/endaaman/tym"; license = licenses.mit; - maintainers = with maintainers; [ wesleyjrz kashw2 ]; + maintainers = with maintainers; [ + wesleyjrz + kashw2 + ]; platforms = platforms.linux; mainProgram = "tym"; }; diff --git a/pkgs/by-name/ty/typer/package.nix b/pkgs/by-name/ty/typer/package.nix index 8d41e2168783f3..9ff09b79688ab5 100644 --- a/pkgs/by-name/ty/typer/package.nix +++ b/pkgs/by-name/ty/typer/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule { @@ -16,7 +17,10 @@ buildGoModule { vendorHash = "sha256-t4zim6WhqGAf1zHmmbJbpVvQcE/aoNL7ZLdjU7f3rp8="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Typing test in your terminal"; diff --git a/pkgs/by-name/ty/typescript-language-server/package.nix b/pkgs/by-name/ty/typescript-language-server/package.nix index 8a0c0e8da2d41a..29265f3931a1f3 100644 --- a/pkgs/by-name/ty/typescript-language-server/package.nix +++ b/pkgs/by-name/ty/typescript-language-server/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, fixup-yarn-lock -, makeWrapper -, nodejs -, prefetch-yarn-deps -, substituteAll -, yarn -, testers -, typescript +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + fixup-yarn-lock, + makeWrapper, + nodejs, + prefetch-yarn-deps, + substituteAll, + yarn, + testers, + typescript, }: stdenv.mkDerivation (finalAttrs: { @@ -87,7 +88,10 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://github.com/typescript-language-server/typescript-language-server/releases/tag/v${finalAttrs.version}"; description = "Language Server Protocol implementation for TypeScript using tsserver"; homepage = "https://github.com/typescript-language-server/typescript-language-server"; - license = with lib.licenses; [ asl20 mit ]; + license = with lib.licenses; [ + asl20 + mit + ]; mainProgram = "typescript-language-server"; maintainers = with lib.maintainers; [ marcel ]; }; diff --git a/pkgs/by-name/ty/typespeed/package.nix b/pkgs/by-name/ty/typespeed/package.nix index 088f6803fbcbfa..385a80165babc9 100644 --- a/pkgs/by-name/ty/typespeed/package.nix +++ b/pkgs/by-name/ty/typespeed/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "typespeed"; diff --git a/pkgs/by-name/ty/typical/package.nix b/pkgs/by-name/ty/typical/package.nix index 9eb303065ab8a0..4d962003d02ed7 100644 --- a/pkgs/by-name/ty/typical/package.nix +++ b/pkgs/by-name/ty/typical/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ty/typioca/package.nix b/pkgs/by-name/ty/typioca/package.nix index 572735cf742912..dfc9d61398bb61 100644 --- a/pkgs/by-name/ty/typioca/package.nix +++ b/pkgs/by-name/ty/typioca/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, typioca +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + typioca, }: buildGoModule rec { diff --git a/pkgs/by-name/ty/typora/package.nix b/pkgs/by-name/ty/typora/package.nix index a194dac3b18b2d..3a26a8c82bc4fd 100644 --- a/pkgs/by-name/ty/typora/package.nix +++ b/pkgs/by-name/ty/typora/package.nix @@ -1,22 +1,23 @@ -{ stdenv -, fetchurl -, dpkg -, lib -, glib -, nss -, nspr -, cups -, dbus -, libdrm -, gtk3 -, pango -, cairo -, libxkbcommon -, mesa -, expat -, alsa-lib -, buildFHSEnv -, writeTextFile +{ + stdenv, + fetchurl, + dpkg, + lib, + glib, + nss, + nspr, + cups, + dbus, + libdrm, + gtk3, + pango, + cairo, + libxkbcommon, + mesa, + expat, + alsa-lib, + buildFHSEnv, + writeTextFile, }: let @@ -47,65 +48,69 @@ let typoraFHS = buildFHSEnv { pname = "typora-fhs"; inherit version; - targetPkgs = pkgs: (with pkgs; [ - typoraBase - udev - alsa-lib - glib - nss - nspr - atk - cups - dbus - gtk3 - libdrm - pango - cairo - mesa - libGL - expat - libxkbcommon - ]) ++ (with pkgs.xorg; [ - libX11 - libXcursor - libXrandr - libXcomposite - libXdamage - libXext - libXfixes - libxcb - ]); + targetPkgs = + pkgs: + (with pkgs; [ + typoraBase + udev + alsa-lib + glib + nss + nspr + atk + cups + dbus + gtk3 + libdrm + pango + cairo + mesa + libGL + expat + libxkbcommon + ]) + ++ (with pkgs.xorg; [ + libX11 + libXcursor + libXrandr + libXcomposite + libXdamage + libXext + libXfixes + libxcb + ]); runScript = '' Typora "$@" ''; }; launchScript = writeTextFile { - name = "typora-launcher"; - executable = true; - text = '' - #!${stdenv.shell} + name = "typora-launcher"; + executable = true; + text = '' + #!${stdenv.shell} - # Configuration directory setup - XDG_CONFIG_HOME=''${XDG_CONFIG_HOME:-~/.config} - TYPORA_CONFIG_DIR="$XDG_CONFIG_HOME/Typora" - TYPORA_DICT_DIR="$TYPORA_CONFIG_DIR/typora-dictionaries" + # Configuration directory setup + XDG_CONFIG_HOME=''${XDG_CONFIG_HOME:-~/.config} + TYPORA_CONFIG_DIR="$XDG_CONFIG_HOME/Typora" + TYPORA_DICT_DIR="$TYPORA_CONFIG_DIR/typora-dictionaries" - # Create config directories with proper permissions - mkdir -p "$TYPORA_DICT_DIR" - chmod 755 "$TYPORA_CONFIG_DIR" - chmod 755 "$TYPORA_DICT_DIR" + # Create config directories with proper permissions + mkdir -p "$TYPORA_DICT_DIR" + chmod 755 "$TYPORA_CONFIG_DIR" + chmod 755 "$TYPORA_DICT_DIR" - # Read user flags if they exist - if [ -f "$XDG_CONFIG_HOME/typora-flags.conf" ]; then - TYPORA_USER_FLAGS="$(sed 's/#.*//' "$XDG_CONFIG_HOME/typora-flags.conf" | tr '\n' ' ')" - fi + # Read user flags if they exist + if [ -f "$XDG_CONFIG_HOME/typora-flags.conf" ]; then + TYPORA_USER_FLAGS="$(sed 's/#.*//' "$XDG_CONFIG_HOME/typora-flags.conf" | tr '\n' ' ')" + fi - exec ${typoraFHS}/bin/typora-fhs "$@" $TYPORA_USER_FLAGS - ''; + exec ${typoraFHS}/bin/typora-fhs "$@" $TYPORA_USER_FLAGS + ''; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname version; dontUnpack = true; diff --git a/pkgs/by-name/ty/typstfmt/package.nix b/pkgs/by-name/ty/typstfmt/package.nix index f3cd8fc62e88ea..cb91bdc5bfe3c1 100644 --- a/pkgs/by-name/ty/typstfmt/package.nix +++ b/pkgs/by-name/ty/typstfmt/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -27,6 +28,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/astrale-sharp/typstfmt"; license = lib.licenses.mit; mainProgram = "typstfmt"; - maintainers = with lib.maintainers; [ figsoda geri1701 ]; + maintainers = with lib.maintainers; [ + figsoda + geri1701 + ]; }; } diff --git a/pkgs/by-name/tz/tz/package.nix b/pkgs/by-name/tz/tz/package.nix index c883058a725ec6..7ddeb2d399e1ea 100644 --- a/pkgs/by-name/tz/tz/package.nix +++ b/pkgs/by-name/tz/tz/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "tz"; diff --git a/pkgs/by-name/tz/tzdata/package.nix b/pkgs/by-name/tz/tzdata/package.nix index f21357b4ca09b8..2ee4f60dc940b7 100644 --- a/pkgs/by-name/tz/tzdata/package.nix +++ b/pkgs/by-name/tz/tzdata/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, buildPackages }: +{ + lib, + stdenv, + fetchurl, + buildPackages, +}: stdenv.mkDerivation (finalAttrs: { pname = "tzdata"; @@ -21,30 +26,37 @@ stdenv.mkDerivation (finalAttrs: { ./0001-Add-exe-extension-for-MS-Windows-binaries.patch ]; - outputs = [ "out" "bin" "man" "dev" ]; + outputs = [ + "out" + "bin" + "man" + "dev" + ]; propagatedBuildOutputs = [ ]; - makeFlags = [ - "TOPDIR=${placeholder "out"}" - "TZDIR=${placeholder "out"}/share/zoneinfo" - "BINDIR=${placeholder "bin"}/bin" - "ZICDIR=${placeholder "bin"}/bin" - "ETCDIR=$(TMPDIR)/etc" - "TZDEFAULT=tzdefault-to-remove" - "LIBDIR=${placeholder "dev"}/lib" - "MANDIR=${placeholder "man"}/share/man" - "AWK=awk" - "CURL=:" # disable network access - "CFLAGS=-DHAVE_LINK=0" - "CFLAGS+=-DZIC_BLOAT_DEFAULT=\\\"fat\\\"" - "cc=${stdenv.cc.targetPrefix}cc" - "AR=${stdenv.cc.targetPrefix}ar" - ] ++ lib.optionals stdenv.hostPlatform.isWindows [ - "CFLAGS+=-DHAVE_DIRECT_H" - "CFLAGS+=-DHAVE_SETENV=0" - "CFLAGS+=-DHAVE_SYMLINK=0" - "CFLAGS+=-DRESERVE_STD_EXT_IDS" - ]; + makeFlags = + [ + "TOPDIR=${placeholder "out"}" + "TZDIR=${placeholder "out"}/share/zoneinfo" + "BINDIR=${placeholder "bin"}/bin" + "ZICDIR=${placeholder "bin"}/bin" + "ETCDIR=$(TMPDIR)/etc" + "TZDEFAULT=tzdefault-to-remove" + "LIBDIR=${placeholder "dev"}/lib" + "MANDIR=${placeholder "man"}/share/man" + "AWK=awk" + "CURL=:" # disable network access + "CFLAGS=-DHAVE_LINK=0" + "CFLAGS+=-DZIC_BLOAT_DEFAULT=\\\"fat\\\"" + "cc=${stdenv.cc.targetPrefix}cc" + "AR=${stdenv.cc.targetPrefix}ar" + ] + ++ lib.optionals stdenv.hostPlatform.isWindows [ + "CFLAGS+=-DHAVE_DIRECT_H" + "CFLAGS+=-DHAVE_SETENV=0" + "CFLAGS+=-DHAVE_SYMLINK=0" + "CFLAGS+=-DRESERVE_STD_EXT_IDS" + ]; enableParallelBuilding = true; @@ -55,19 +67,18 @@ stdenv.mkDerivation (finalAttrs: { "zic=${buildPackages.tzdata.bin}/bin/zic" ]; - postInstall = - '' - rm $out/share/zoneinfo-posix - rm $out/share/zoneinfo/tzdefault-to-remove - mkdir $out/share/zoneinfo/posix - ( cd $out/share/zoneinfo/posix; ln -s ../* .; rm posix ) - mv $out/share/zoneinfo-leaps $out/share/zoneinfo/right + postInstall = '' + rm $out/share/zoneinfo-posix + rm $out/share/zoneinfo/tzdefault-to-remove + mkdir $out/share/zoneinfo/posix + ( cd $out/share/zoneinfo/posix; ln -s ../* .; rm posix ) + mv $out/share/zoneinfo-leaps $out/share/zoneinfo/right - cp leap-seconds.list $out/share/zoneinfo + cp leap-seconds.list $out/share/zoneinfo - mkdir -p "$dev/include" - cp tzfile.h "$dev/include/tzfile.h" - ''; + mkdir -p "$dev/include" + cp tzfile.h "$dev/include/tzfile.h" + ''; setupHook = ./tzdata-setup-hook.sh; @@ -80,6 +91,9 @@ stdenv.mkDerivation (finalAttrs: { publicDomain # tzdata ]; platforms = platforms.all; - maintainers = with maintainers; [ ajs124 fpletz ]; + maintainers = with maintainers; [ + ajs124 + fpletz + ]; }; }) diff --git a/pkgs/by-name/u0/u001-font/package.nix b/pkgs/by-name/u0/u001-font/package.nix index 0a1a552ed9cd35..0033dc5442436b 100644 --- a/pkgs/by-name/u0/u001-font/package.nix +++ b/pkgs/by-name/u0/u001-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "u001"; diff --git a/pkgs/by-name/u2/u2ps/package.nix b/pkgs/by-name/u2/u2ps/package.nix index 95d46db42ed28e..6c3089dbf74fb5 100644 --- a/pkgs/by-name/u2/u2ps/package.nix +++ b/pkgs/by-name/u2/u2ps/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, ghostscript_headless +{ + lib, + stdenv, + fetchFromGitHub, + ghostscript_headless, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/u9/u9fs/package.nix b/pkgs/by-name/u9/u9fs/package.nix index cb85a972e034e4..62a2e2777379b5 100644 --- a/pkgs/by-name/u9/u9fs/package.nix +++ b/pkgs/by-name/u9/u9fs/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromBitbucket }: +{ + lib, + stdenv, + fetchFromBitbucket, +}: stdenv.mkDerivation { pname = "u9fs"; @@ -12,9 +16,9 @@ stdenv.mkDerivation { }; installPhase = '' - install -Dm644 u9fs.man "$out/share/man/man4/u9fs.4" - install -Dm755 u9fs -t "$out/bin" - ''; + install -Dm644 u9fs.man "$out/share/man/man4/u9fs.4" + install -Dm755 u9fs -t "$out/bin" + ''; meta = with lib; { description = "Serve 9P from Unix"; diff --git a/pkgs/by-name/ua/ua/package.nix b/pkgs/by-name/ua/ua/package.nix index 425d7b61c4a2c7..441c2e8fc2f4e9 100644 --- a/pkgs/by-name/ua/ua/package.nix +++ b/pkgs/by-name/ua/ua/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, pkg-config, glib, libxml2 }: +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + glib, + libxml2, +}: buildGoModule rec { pname = "ua"; @@ -14,9 +21,15 @@ buildGoModule rec { vendorHash = "sha256-0O80uhxSVsV9N7Z/FgaLwcjZqeb4MqSCE1YW5Zd32ns="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib libxml2 ]; + buildInputs = [ + glib + libxml2 + ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/sloonz/ua"; diff --git a/pkgs/by-name/ua/uacme/package.nix b/pkgs/by-name/ua/uacme/package.nix index 659ca720856b9c..ede36c53a203ef 100644 --- a/pkgs/by-name/ua/uacme/package.nix +++ b/pkgs/by-name/ua/uacme/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, asciidoc -, autoconf-archive -, autoreconfHook -, pkg-config -, curl -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + asciidoc, + autoconf-archive, + autoreconfHook, + pkg-config, + curl, + openssl, }: stdenv.mkDerivation rec { pname = "uacme"; diff --git a/pkgs/by-name/ua/uae/package.nix b/pkgs/by-name/ua/uae/package.nix index bfb8584aa94b48..9ef978a25e7a24 100644 --- a/pkgs/by-name/ua/uae/package.nix +++ b/pkgs/by-name/ua/uae/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchurl, pkg-config, gtk2, alsa-lib, SDL}: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + alsa-lib, + SDL, +}: stdenv.mkDerivation rec { pname = "uae"; @@ -9,10 +17,19 @@ stdenv.mkDerivation rec { sha256 = "05s3cd1rd5a970s938qf4c2xm3l7f54g5iaqw56v8smk355m4qr4"; }; - configureFlags = [ "--with-sdl" "--with-sdl-sound" "--with-sdl-gfx" "--with-alsa" ]; + configureFlags = [ + "--with-sdl" + "--with-sdl-sound" + "--with-sdl-gfx" + "--with-alsa" + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk2 alsa-lib SDL ]; + buildInputs = [ + gtk2 + alsa-lib + SDL + ]; hardeningDisable = [ "format" ]; # Workaround build failure on -fno-common toolchains: diff --git a/pkgs/by-name/ua/uair/package.nix b/pkgs/by-name/ua/uair/package.nix index 4d2cbd0c0a916e..8dcdd62844fe02 100644 --- a/pkgs/by-name/ua/uair/package.nix +++ b/pkgs/by-name/ua/uair/package.nix @@ -1,8 +1,9 @@ -{ fetchFromGitHub -, installShellFiles -, lib -, rustPlatform -, scdoc +{ + fetchFromGitHub, + installShellFiles, + lib, + rustPlatform, + scdoc, }: rustPlatform.buildRustPackage rec { @@ -18,7 +19,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-n7Kaha22Rh/5AGoHUiAxnaZvHtZ+rPsmLHiUYfA0YPE="; - nativeBuildInputs = [ installShellFiles scdoc ]; + nativeBuildInputs = [ + installShellFiles + scdoc + ]; preFixup = '' scdoc < docs/uair.1.scd > docs/uair.1 diff --git a/pkgs/by-name/ua/uarmsolver/package.nix b/pkgs/by-name/ua/uarmsolver/package.nix index 2f24f782927bc1..6c53ae93e32b6f 100644 --- a/pkgs/by-name/ua/uarmsolver/package.nix +++ b/pkgs/by-name/ua/uarmsolver/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { @@ -9,10 +10,10 @@ stdenv.mkDerivation rec { version = "0.3.0"; src = fetchFromGitHub { - owner = "firefly-cpp"; - repo = "uARMSolver"; - rev = version; - sha256 = "sha256-IMlh6Y5iVouMZatR1uxw0gUNZBdh2qm56s+GEjcr1+M="; + owner = "firefly-cpp"; + repo = "uARMSolver"; + rev = version; + sha256 = "sha256-IMlh6Y5iVouMZatR1uxw0gUNZBdh2qm56s+GEjcr1+M="; }; nativeBuildInputs = [ cmake ]; @@ -24,9 +25,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "universal Association Rule Mining Solver"; mainProgram = "uARMSolver"; - homepage = "https://github.com/firefly-cpp/uARMSolver"; - license = licenses.mit; - platforms = platforms.linux; + homepage = "https://github.com/firefly-cpp/uARMSolver"; + license = licenses.mit; + platforms = platforms.linux; maintainers = with maintainers; [ firefly-cpp ]; }; } diff --git a/pkgs/by-name/ua/uasm/package.nix b/pkgs/by-name/ua/uasm/package.nix index 59332fa41f0316..3dc47e5ccbc0f1 100644 --- a/pkgs/by-name/ua/uasm/package.nix +++ b/pkgs/by-name/ua/uasm/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, testers -, uasm +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + testers, + uasm, }: stdenv.mkDerivation rec { @@ -30,11 +31,7 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - makefile = - if stdenv.hostPlatform.isDarwin then - "ClangOSX64.mak" - else - "gccLinux64.mak"; + makefile = if stdenv.hostPlatform.isDarwin then "ClangOSX64.mak" else "gccLinux64.mak"; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; diff --git a/pkgs/by-name/ub/ubertooth/package.nix b/pkgs/by-name/ub/ubertooth/package.nix index 2d8b9f857938d0..f9f22d4db67333 100644 --- a/pkgs/by-name/ub/ubertooth/package.nix +++ b/pkgs/by-name/ub/ubertooth/package.nix @@ -1,5 +1,14 @@ -{ stdenv, lib, fetchFromGitHub, cmake, pkg-config, libbtbb, libpcap , libusb1, bluez -, udevGroup ? "ubertooth" +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + libbtbb, + libpcap, + libusb1, + bluez, + udevGroup ? "ubertooth", }: stdenv.mkDerivation rec { @@ -15,8 +24,16 @@ stdenv.mkDerivation rec { sourceRoot = "${src.name}/host"; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libbtbb libpcap libusb1 bluez ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + libbtbb + libpcap + libusb1 + bluez + ]; cmakeFlags = lib.optionals stdenv.hostPlatform.isLinux [ "-DINSTALL_UDEV_RULES=TRUE" diff --git a/pkgs/by-name/ub/ubuntu-themes/package.nix b/pkgs/by-name/ub/ubuntu-themes/package.nix index 8f945c0d7b8629..b152bcb0501e1f 100644 --- a/pkgs/by-name/ub/ubuntu-themes/package.nix +++ b/pkgs/by-name/ub/ubuntu-themes/package.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, fetchurl -, gnome-icon-theme -, adwaita-icon-theme -, gtk-engine-murrine -, gtk3 -, hicolor-icon-theme -, humanity-icon-theme -, python3Packages +{ + lib, + stdenv, + fetchurl, + gnome-icon-theme, + adwaita-icon-theme, + gtk-engine-murrine, + gtk3, + hicolor-icon-theme, + humanity-icon-theme, + python3Packages, }: stdenv.mkDerivation rec { @@ -69,7 +71,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Ubuntu monochrome and Suru icon themes, Ambiance and Radiance themes, and Ubuntu artwork"; homepage = "https://launchpad.net/ubuntu-themes"; - license = with licenses; [ cc-by-sa-40 gpl3 ]; + license = with licenses; [ + cc-by-sa-40 + gpl3 + ]; platforms = platforms.linux; maintainers = [ maintainers.romildo ]; }; diff --git a/pkgs/by-name/ub/ubus/package.nix b/pkgs/by-name/ub/ubus/package.nix index dede0e55657afb..5c28c5aab3a529 100644 --- a/pkgs/by-name/ub/ubus/package.nix +++ b/pkgs/by-name/ub/ubus/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, cmake, fetchgit, libubox, libjson }: +{ + lib, + stdenv, + cmake, + fetchgit, + libubox, + libjson, +}: stdenv.mkDerivation { pname = "ubus"; @@ -11,12 +18,17 @@ stdenv.mkDerivation { }; cmakeFlags = [ "-DBUILD_LUA=OFF" ]; - buildInputs = [ libubox libjson ]; + buildInputs = [ + libubox + libjson + ]; nativeBuildInputs = [ cmake ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ - "-Wno-error=gnu-folding-constant" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + "-Wno-error=gnu-folding-constant" + ] + ); meta = with lib; { description = "OpenWrt system message/RPC bus"; diff --git a/pkgs/by-name/uc/ucarp/package.nix b/pkgs/by-name/uc/ucarp/package.nix index fc9cdf947515ca..4423e005131443 100644 --- a/pkgs/by-name/uc/ucarp/package.nix +++ b/pkgs/by-name/uc/ucarp/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, libpcap, nixosTests }: +{ + stdenv, + lib, + fetchurl, + libpcap, + nixosTests, +}: stdenv.mkDerivation rec { pname = "ucarp"; @@ -30,7 +36,12 @@ stdenv.mkDerivation rec { Warning: This package has not received any upstream updates for a long time and can be considered as unmaintained. ''; - license = with licenses; [ isc bsdOriginal bsd2 gpl2Plus ]; + license = with licenses; [ + isc + bsdOriginal + bsd2 + gpl2Plus + ]; maintainers = with maintainers; [ oxzi ]; mainProgram = "ucarp"; }; diff --git a/pkgs/by-name/uc/ucblogo/package.nix b/pkgs/by-name/uc/ucblogo/package.nix index 08e3610b6fb222..0bf3a7de28da6f 100644 --- a/pkgs/by-name/uc/ucblogo/package.nix +++ b/pkgs/by-name/uc/ucblogo/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, wxGTK32 -, texinfo -, tetex -, wrapGAppsHook3 -, autoconf-archive -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + wxGTK32, + texinfo, + tetex, + wrapGAppsHook3, + autoconf-archive, + autoreconfHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/uc/ucc/package.nix b/pkgs/by-name/uc/ucc/package.nix index 58dc82e3cb7b53..7c93a36f1b626c 100644 --- a/pkgs/by-name/uc/ucc/package.nix +++ b/pkgs/by-name/uc/ucc/package.nix @@ -1,11 +1,18 @@ -{ stdenv, lib, fetchFromGitHub, libtool, automake, autoconf, ucx -, config -, enableCuda ? config.cudaSupport -, cudaPackages -, enableAvx ? stdenv.hostPlatform.avxSupport -, enableSse41 ? stdenv.hostPlatform.sse4_1Support -, enableSse42 ? stdenv.hostPlatform.sse4_2Support -} : +{ + stdenv, + lib, + fetchFromGitHub, + libtool, + automake, + autoconf, + ucx, + config, + enableCuda ? config.cudaSupport, + cudaPackages, + enableAvx ? stdenv.hostPlatform.avxSupport, + enableSse41 ? stdenv.hostPlatform.sse4_1Support, + enableSse42 ? stdenv.hostPlatform.sse4_2Support, +}: stdenv.mkDerivation rec { pname = "ucc"; @@ -18,7 +25,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-xcJLYktkxNK2ewWRgm8zH/dMaIoI+9JexuswXi7MpAU="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; enableParallelBuilding = true; @@ -30,25 +40,31 @@ stdenv.mkDerivation rec { done ''; - nativeBuildInputs = [ libtool automake autoconf ] - ++ lib.optionals enableCuda [ cudaPackages.cuda_nvcc ]; - buildInputs = [ ucx ] + nativeBuildInputs = [ + libtool + automake + autoconf + ] ++ lib.optionals enableCuda [ cudaPackages.cuda_nvcc ]; + buildInputs = + [ ucx ] ++ lib.optionals enableCuda [ cudaPackages.cuda_cccl cudaPackages.cuda_cudart ]; - - preConfigure = '' - ./autogen.sh - '' + lib.optionalString enableCuda '' - configureFlagsArray+=( "--with-nvcc-gencode=${builtins.concatStringsSep " " cudaPackages.cudaFlags.gencode}" ) - ''; - configureFlags = [ ] - ++ lib.optional enableSse41 "--with-sse41" - ++ lib.optional enableSse42 "--with-sse42" - ++ lib.optional enableAvx "--with-avx" - ++ lib.optional enableCuda "--with-cuda=${cudaPackages.cuda_cudart}"; + preConfigure = + '' + ./autogen.sh + '' + + lib.optionalString enableCuda '' + configureFlagsArray+=( "--with-nvcc-gencode=${builtins.concatStringsSep " " cudaPackages.cudaFlags.gencode}" ) + ''; + configureFlags = + [ ] + ++ lib.optional enableSse41 "--with-sse41" + ++ lib.optional enableSse42 "--with-sse42" + ++ lib.optional enableAvx "--with-avx" + ++ lib.optional enableCuda "--with-cuda=${cudaPackages.cuda_cudart}"; postInstall = '' find $out/lib/ -name "*.la" -exec rm -f \{} \; diff --git a/pkgs/by-name/uc/ucg/package.nix b/pkgs/by-name/uc/ucg/package.nix index 7ac909b2568687..0b8487c312aa38 100644 --- a/pkgs/by-name/uc/ucg/package.nix +++ b/pkgs/by-name/uc/ucg/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, callPackage -, pkg-config -, pcre +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + callPackage, + pkg-config, + pcre, }: stdenv.mkDerivation (finalAttrs: { @@ -18,7 +19,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-Osdyxp8DoEjcr2wQLCPqOQ2zQf/0JWYxaDpZB02ACWo="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; nativeBuildInputs = [ autoreconfHook @@ -35,7 +39,7 @@ stdenv.mkDerivation (finalAttrs: { }; }; - meta = { + meta = { homepage = "https://gvansickle.github.io/ucg/"; description = "Grep-like tool for searching large bodies of source code"; longDescription = '' diff --git a/pkgs/by-name/uc/ucg/tests/simple.nix b/pkgs/by-name/uc/ucg/tests/simple.nix index 033f408ce1b7e8..0d90c2fa15f329 100644 --- a/pkgs/by-name/uc/ucg/tests/simple.nix +++ b/pkgs/by-name/uc/ucg/tests/simple.nix @@ -1,5 +1,6 @@ -{ stdenv -, ucg +{ + stdenv, + ucg, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/uc/uchecker/package.nix b/pkgs/by-name/uc/uchecker/package.nix index e3729be50ece7e..19a627d6b9626f 100644 --- a/pkgs/by-name/uc/uchecker/package.nix +++ b/pkgs/by-name/uc/uchecker/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, fetchpatch +{ + lib, + python3, + fetchFromGitHub, + fetchpatch, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/uc/uchess/package.nix b/pkgs/by-name/uc/uchess/package.nix index fd0884bf6b1846..232262a17a206a 100644 --- a/pkgs/by-name/uc/uchess/package.nix +++ b/pkgs/by-name/uc/uchess/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, makeWrapper, stockfish }: +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + stockfish, +}: buildGoModule rec { pname = "uchess"; diff --git a/pkgs/by-name/uc/uci/package.nix b/pkgs/by-name/uc/uci/package.nix index 55281e78ac744c..d6318106a3fe8a 100644 --- a/pkgs/by-name/uc/uci/package.nix +++ b/pkgs/by-name/uc/uci/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, cmake, fetchgit, pkg-config, libubox }: +{ + lib, + stdenv, + cmake, + fetchgit, + pkg-config, + libubox, +}: stdenv.mkDerivation { pname = "uci"; @@ -13,7 +20,10 @@ stdenv.mkDerivation { hardeningDisable = [ "all" ]; cmakeFlags = [ "-DBUILD_LUA=OFF" ]; buildInputs = [ libubox ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; meta = with lib; { description = "OpenWrt Unified Configuration Interface"; diff --git a/pkgs/by-name/uc/ucl/package.nix b/pkgs/by-name/uc/ucl/package.nix index d8e05e9374bfa3..fed243d117a286 100644 --- a/pkgs/by-name/uc/ucl/package.nix +++ b/pkgs/by-name/uc/ucl/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ucl"; diff --git a/pkgs/by-name/uc/uclibc-ng/package.nix b/pkgs/by-name/uc/uclibc-ng/package.nix index 8869dce9d187e7..96c035e56192c0 100644 --- a/pkgs/by-name/uc/uclibc-ng/package.nix +++ b/pkgs/by-name/uc/uclibc-ng/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenvNoLibc -, buildPackages -, fetchurl -, gitUpdater -, linuxHeaders -, libiconvReal -, extraConfig ? "" +{ + lib, + stdenvNoLibc, + buildPackages, + fetchurl, + gitUpdater, + linuxHeaders, + libiconvReal, + extraConfig ? "", }: let @@ -35,28 +36,31 @@ let ''; # UCLIBC_SUSV4_LEGACY defines 'tmpnam', needed for gcc libstdc++ builds. - nixConfig = '' - RUNTIME_PREFIX "/" - DEVEL_PREFIX "/" - UCLIBC_HAS_WCHAR y - UCLIBC_HAS_FTW y - UCLIBC_HAS_RPC y - DO_C99_MATH y - UCLIBC_HAS_PROGRAM_INVOCATION_NAME y - UCLIBC_HAS_RESOLVER_SUPPORT y - UCLIBC_SUSV4_LEGACY y - UCLIBC_HAS_THREADS_NATIVE y - KERNEL_HEADERS "${linuxHeaders}/include" - '' + lib.optionalString (stdenv.hostPlatform.gcc.float or "" == "soft") '' - UCLIBC_HAS_FPU n - '' + lib.optionalString (stdenv.hostPlatform.isAarch32 && isCross) '' - CONFIG_ARM_EABI y - ARCH_WANTS_BIG_ENDIAN n - ARCH_BIG_ENDIAN n - ARCH_WANTS_LITTLE_ENDIAN y - ARCH_LITTLE_ENDIAN y - UCLIBC_HAS_FPU n - ''; + nixConfig = + '' + RUNTIME_PREFIX "/" + DEVEL_PREFIX "/" + UCLIBC_HAS_WCHAR y + UCLIBC_HAS_FTW y + UCLIBC_HAS_RPC y + DO_C99_MATH y + UCLIBC_HAS_PROGRAM_INVOCATION_NAME y + UCLIBC_HAS_RESOLVER_SUPPORT y + UCLIBC_SUSV4_LEGACY y + UCLIBC_HAS_THREADS_NATIVE y + KERNEL_HEADERS "${linuxHeaders}/include" + '' + + lib.optionalString (stdenv.hostPlatform.gcc.float or "" == "soft") '' + UCLIBC_HAS_FPU n + '' + + lib.optionalString (stdenv.hostPlatform.isAarch32 && isCross) '' + CONFIG_ARM_EABI y + ARCH_WANTS_BIG_ENDIAN n + ARCH_BIG_ENDIAN n + ARCH_WANTS_LITTLE_ENDIAN y + ARCH_LITTLE_ENDIAN y + UCLIBC_HAS_FPU n + ''; in stdenv.mkDerivation (finalAttrs: { pname = "uclibc-ng"; @@ -86,13 +90,15 @@ stdenv.mkDerivation (finalAttrs: { depsBuildBuild = [ buildPackages.stdenv.cc ]; - makeFlags = [ - "ARCH=${stdenv.hostPlatform.linuxArch}" - "TARGET_ARCH=${stdenv.hostPlatform.linuxArch}" - "VERBOSE=1" - ] ++ lib.optionals (isCross) [ - "CROSS=${stdenv.cc.targetPrefix}" - ]; + makeFlags = + [ + "ARCH=${stdenv.hostPlatform.linuxArch}" + "TARGET_ARCH=${stdenv.hostPlatform.linuxArch}" + "VERBOSE=1" + ] + ++ lib.optionals (isCross) [ + "CROSS=${stdenv.cc.targetPrefix}" + ]; # `make libpthread/nptl/sysdeps/unix/sysv/linux/lowlevelrwlock.h`: # error: bits/sysnum.h: No such file or directory @@ -140,7 +146,10 @@ stdenv.mkDerivation (finalAttrs: { experimental and need more testing. ''; license = lib.licenses.lgpl2Plus; - maintainers = with lib.maintainers; [ rasendubi AndersonTorres ]; + maintainers = with lib.maintainers; [ + rasendubi + AndersonTorres + ]; platforms = lib.platforms.linux; badPlatforms = lib.platforms.aarch64; }; diff --git a/pkgs/by-name/uc/uclient/package.nix b/pkgs/by-name/uc/uclient/package.nix index f758c00810edbf..a80896b15c92b7 100644 --- a/pkgs/by-name/uc/uclient/package.nix +++ b/pkgs/by-name/uc/uclient/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchgit, cmake, pkg-config, libubox }: +{ + stdenv, + lib, + fetchgit, + cmake, + pkg-config, + libubox, +}: stdenv.mkDerivation { pname = "uclient"; @@ -10,7 +17,10 @@ stdenv.mkDerivation { hash = "sha256-A47dyVc2MtOL6aImZ0b3SMWH2vzjfAXzRAOF4nfH6S0="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buidInputs = [ libubox ]; preConfigure = '' diff --git a/pkgs/by-name/uc/ucode/package.nix b/pkgs/by-name/uc/ucode/package.nix index 9998b24df08264..8395bff407fc3a 100644 --- a/pkgs/by-name/uc/ucode/package.nix +++ b/pkgs/by-name/uc/ucode/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, json_c +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + json_c, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/uc/ucommon/package.nix b/pkgs/by-name/uc/ucommon/package.nix index 4ee7a90dd31089..b91c0461ed0941 100644 --- a/pkgs/by-name/uc/ucommon/package.nix +++ b/pkgs/by-name/uc/ucommon/package.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, fetchurl, pkg-config -, gnutls +{ + lib, + stdenv, + fetchurl, + pkg-config, + gnutls, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/uc/ucs-fonts/package.nix b/pkgs/by-name/uc/ucs-fonts/package.nix index e9d78dd03a7c8f..6058f6e92eebfa 100644 --- a/pkgs/by-name/uc/ucs-fonts/package.nix +++ b/pkgs/by-name/uc/ucs-fonts/package.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchurl, bdftopcf -, libfaketime, xorg +{ + lib, + stdenv, + fetchurl, + bdftopcf, + libfaketime, + xorg, }: stdenv.mkDerivation { @@ -23,10 +28,12 @@ stdenv.mkDerivation { sourceRoot = "."; - nativeBuildInputs = - [ bdftopcf libfaketime xorg.fonttosfnt - xorg.mkfontscale - ]; + nativeBuildInputs = [ + bdftopcf + libfaketime + xorg.fonttosfnt + xorg.mkfontscale + ]; buildPhase = '' for i in *.bdf; do @@ -49,7 +56,10 @@ stdenv.mkDerivation { mkfontdir "$bdf/share/fonts/misc" ''; - outputs = [ "out" "bdf" ]; + outputs = [ + "out" + "bdf" + ]; meta = with lib; { homepage = "https://www.cl.cam.ac.uk/~mgk25/ucs-fonts.html"; diff --git a/pkgs/by-name/uc/ucspi-tcp/package.nix b/pkgs/by-name/uc/ucspi-tcp/package.nix index 4b307079266b1e..40a5533d332f4f 100644 --- a/pkgs/by-name/uc/ucspi-tcp/package.nix +++ b/pkgs/by-name/uc/ucspi-tcp/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "ucspi-tcp"; diff --git a/pkgs/by-name/uc/ucx/package.nix b/pkgs/by-name/uc/ucx/package.nix index 8f134cd594e3ca..87fb2eaaf824eb 100644 --- a/pkgs/by-name/uc/ucx/package.nix +++ b/pkgs/by-name/uc/ucx/package.nix @@ -1,15 +1,32 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, doxygen, numactl -, rdma-core, libbfd, libiberty, perl, zlib, symlinkJoin, pkg-config -, config -, autoAddDriverRunpath -, enableCuda ? config.cudaSupport -, cudaPackages -, enableRocm ? config.rocmSupport -, rocmPackages +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + doxygen, + numactl, + rdma-core, + libbfd, + libiberty, + perl, + zlib, + symlinkJoin, + pkg-config, + config, + autoAddDriverRunpath, + enableCuda ? config.cudaSupport, + cudaPackages, + enableRocm ? config.rocmSupport, + rocmPackages, }: let - rocmList = with rocmPackages; [ rocm-core rocm-runtime rocm-device-libs clr ]; + rocmList = with rocmPackages; [ + rocm-core + rocm-runtime + rocm-device-libs + clr + ]; rocm = symlinkJoin { name = "rocm"; @@ -28,44 +45,54 @@ stdenv.mkDerivation rec { sha256 = "sha256-Qd3c51LeF04haZA4wK6loNZwX2a3ju+ljwdPYPoUKCQ="; }; - outputs = [ "out" "doc" "dev" ]; - - nativeBuildInputs = [ - autoreconfHook - doxygen - pkg-config - ] - ++ lib.optionals enableCuda [ - cudaPackages.cuda_nvcc - autoAddDriverRunpath + outputs = [ + "out" + "doc" + "dev" ]; - buildInputs = [ - libbfd - libiberty - numactl - perl - rdma-core - zlib - ] ++ lib.optionals enableCuda [ - cudaPackages.cuda_cudart - cudaPackages.cuda_nvml_dev + nativeBuildInputs = + [ + autoreconfHook + doxygen + pkg-config + ] + ++ lib.optionals enableCuda [ + cudaPackages.cuda_nvcc + autoAddDriverRunpath + ]; + + buildInputs = + [ + libbfd + libiberty + numactl + perl + rdma-core + zlib + ] + ++ lib.optionals enableCuda [ + cudaPackages.cuda_cudart + cudaPackages.cuda_nvml_dev - ] ++ lib.optionals enableRocm rocmList; + ] + ++ lib.optionals enableRocm rocmList; LDFLAGS = lib.optionals enableCuda [ # Fake libnvidia-ml.so (the real one is deployed impurely) "-L${lib.getLib cudaPackages.cuda_nvml_dev}/lib/stubs" ]; - configureFlags = [ - "--with-rdmacm=${lib.getDev rdma-core}" - "--with-dc" - "--with-rc" - "--with-dm" - "--with-verbs=${lib.getDev rdma-core}" - ] ++ lib.optionals enableCuda [ "--with-cuda=${cudaPackages.cuda_cudart}" ] - ++ lib.optional enableRocm "--with-rocm=${rocm}"; + configureFlags = + [ + "--with-rdmacm=${lib.getDev rdma-core}" + "--with-dc" + "--with-rc" + "--with-dm" + "--with-verbs=${lib.getDev rdma-core}" + ] + ++ lib.optionals enableCuda [ "--with-cuda=${cudaPackages.cuda_cudart}" ] + ++ lib.optional enableRocm "--with-rocm=${rocm}"; postInstall = '' find $out/lib/ -name "*.la" -exec rm -f \{} \; diff --git a/pkgs/by-name/ud/uddup/package.nix b/pkgs/by-name/ud/uddup/package.nix index 4d850b016f9fce..00045852ee985d 100644 --- a/pkgs/by-name/ud/uddup/package.nix +++ b/pkgs/by-name/ud/uddup/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ud/udebug/package.nix b/pkgs/by-name/ud/udebug/package.nix index d52b713418a68d..eb21aab56c843d 100644 --- a/pkgs/by-name/ud/udebug/package.nix +++ b/pkgs/by-name/ud/udebug/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, cmake -, fetchgit -, pkg-config -, ubus -, libubox -, ucode -, json_c +{ + lib, + stdenv, + cmake, + fetchgit, + pkg-config, + ubus, + libubox, + ucode, + json_c, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ud/udev-gothic-nf/package.nix b/pkgs/by-name/ud/udev-gothic-nf/package.nix index 6b1b744ad2ec74..9e8d24aadb401e 100644 --- a/pkgs/by-name/ud/udev-gothic-nf/package.nix +++ b/pkgs/by-name/ud/udev-gothic-nf/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "udev-gothic-nf"; diff --git a/pkgs/by-name/ud/udev-gothic/package.nix b/pkgs/by-name/ud/udev-gothic/package.nix index 0ec9d58301b844..dfb24eac56d534 100644 --- a/pkgs/by-name/ud/udev-gothic/package.nix +++ b/pkgs/by-name/ud/udev-gothic/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "udev-gothic"; diff --git a/pkgs/by-name/ud/udevil/package.nix b/pkgs/by-name/ud/udevil/package.nix index 0da470f9a99fd6..d30a5b8c767c67 100644 --- a/pkgs/by-name/ud/udevil/package.nix +++ b/pkgs/by-name/ud/udevil/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, acl -, glib -, intltool -, pkg-config -, udev -, util-linux +{ + lib, + stdenv, + fetchFromGitHub, + acl, + glib, + intltool, + pkg-config, + udev, + util-linux, }: stdenv.mkDerivation rec { @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { sha256 = "0nd44r8rbxifx4x4m24z5aji1c6k1fhw8cmf5s43wd5qys0bcdad"; }; - nativeBuildInputs = [ pkg-config intltool ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; buildInputs = [ glib diff --git a/pkgs/by-name/ud/udftools/package.nix b/pkgs/by-name/ud/udftools/package.nix index f50f98d33dc258..4d908eccb03c52 100644 --- a/pkgs/by-name/ud/udftools/package.nix +++ b/pkgs/by-name/ud/udftools/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, ncurses, readline, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + readline, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "udftools"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "0mz04h3rki6ljwfs15z83gf4vv816w7xgz923waiqgmfj9xpvx87"; }; - buildInputs = [ ncurses readline ]; + buildInputs = [ + ncurses + readline + ]; nativeBuildInputs = [ autoreconfHook ]; hardeningDisable = [ "fortify" ]; diff --git a/pkgs/by-name/ud/udict/package.nix b/pkgs/by-name/ud/udict/package.nix index 42f2585ec439b3..121e30e664ed8f 100644 --- a/pkgs/by-name/ud/udict/package.nix +++ b/pkgs/by-name/ud/udict/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, darwin +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + darwin, }: rustPlatform.buildRustPackage rec { @@ -28,12 +29,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreFoundation - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreFoundation + darwin.apple_sdk.frameworks.Security + ]; meta = with lib; { description = "Urban Dictionary CLI - written in Rust"; diff --git a/pkgs/by-name/ud/udig/package.nix b/pkgs/by-name/ud/udig/package.nix index 04740f55b0654c..17696713099adc 100644 --- a/pkgs/by-name/ud/udig/package.nix +++ b/pkgs/by-name/ud/udig/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchurl, unzip, makeWrapper, jre8, libXtst, gdal }: +{ + stdenv, + lib, + fetchurl, + unzip, + makeWrapper, + jre8, + libXtst, + gdal, +}: let pname = "udig"; version = "2.0.0"; @@ -13,29 +22,46 @@ let hash = "sha256-Ihk3InHB3/tEYRqH2ozhokz2GN8Gfig5DJkO/8P1LJs="; }; }; - src = srcs.${stdenv.hostPlatform.system} or (throw "unsupported system ${stdenv.hostPlatform.system}"); + src = + srcs.${stdenv.hostPlatform.system} or (throw "unsupported system ${stdenv.hostPlatform.system}"); meta = with lib; { description = "User-friendly Desktop Internet GIS"; homepage = "http://udig.refractions.net/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = with licenses; [ epl10 bsd3 ]; + license = with licenses; [ + epl10 + bsd3 + ]; maintainers = with maintainers; [ sikmir ]; platforms = builtins.attrNames srcs; mainProgram = "udig"; }; linux = stdenv.mkDerivation { - inherit pname version src meta; + inherit + pname + version + src + meta + ; - nativeBuildInputs = [ unzip makeWrapper ]; + nativeBuildInputs = [ + unzip + makeWrapper + ]; installPhase = '' install -dm755 $out/bin $out/opt/udig cp -r . $out/opt/udig makeWrapper $out/opt/udig/udig.sh $out/bin/udig \ --prefix PATH : ${jre8}/bin \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath ([ libXtst gdal ])} + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath ([ + libXtst + gdal + ]) + } ''; postFixup = '' @@ -46,9 +72,17 @@ let }; darwin = stdenv.mkDerivation { - inherit pname version src meta; + inherit + pname + version + src + meta + ; - nativeBuildInputs = [ unzip makeWrapper ]; + nativeBuildInputs = [ + unzip + makeWrapper + ]; postPatch = '' substituteInPlace configuration/config.ini \ @@ -63,6 +97,4 @@ let ''; }; in -if stdenv.hostPlatform.isDarwin -then darwin -else linux +if stdenv.hostPlatform.isDarwin then darwin else linux diff --git a/pkgs/by-name/ud/udis86/package.nix b/pkgs/by-name/ud/udis86/package.nix index 14a594a827da7d..e0121bbbd84798 100644 --- a/pkgs/by-name/ud/udis86/package.nix +++ b/pkgs/by-name/ud/udis86/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + python3, }: stdenv.mkDerivation rec { @@ -25,13 +26,21 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook python3 ]; + nativeBuildInputs = [ + autoreconfHook + python3 + ]; configureFlags = [ "--enable-shared" ]; - outputs = [ "bin" "out" "dev" "lib" ]; + outputs = [ + "bin" + "out" + "dev" + "lib" + ]; meta = with lib; { homepage = "https://udis86.sourceforge.net"; diff --git a/pkgs/by-name/ud/udiskie/package.nix b/pkgs/by-name/ud/udiskie/package.nix index 50abfb13e57eda..e1d1f0d4304619 100644 --- a/pkgs/by-name/ud/udiskie/package.nix +++ b/pkgs/by-name/ud/udiskie/package.nix @@ -1,17 +1,18 @@ -{ lib -, asciidoc -, fetchFromGitHub -, gobject-introspection -, gtk3 -, installShellFiles -, libappindicator-gtk3 -, libnotify -, librsvg -, python3Packages -, udisks2 -, wrapGAppsHook3 -, testers -, udiskie +{ + lib, + asciidoc, + fetchFromGitHub, + gobject-introspection, + gtk3, + installShellFiles, + libappindicator-gtk3, + libnotify, + librsvg, + python3Packages, + udisks2, + wrapGAppsHook3, + testers, + udiskie, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ud/udns/package.nix b/pkgs/by-name/ud/udns/package.nix index 5dad256063b40e..abc1d21d27f4e1 100644 --- a/pkgs/by-name/ud/udns/package.nix +++ b/pkgs/by-name/ud/udns/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: # this expression is mostly based on debian's packaging # https://tracker.debian.org/media/packages/u/udns/rules-0.6-1 diff --git a/pkgs/by-name/ud/udocker/package.nix b/pkgs/by-name/ud/udocker/package.nix index 25ae2fe9ee33bd..d0c6b6c2a23f14 100644 --- a/pkgs/by-name/ud/udocker/package.nix +++ b/pkgs/by-name/ud/udocker/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, singularity -, python3Packages -, testers -, udocker +{ + lib, + fetchFromGitHub, + singularity, + python3Packages, + testers, + udocker, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ud/udp2raw/package.nix b/pkgs/by-name/ud/udp2raw/package.nix index 8844e375d19e3b..28f7b6bc10c611 100644 --- a/pkgs/by-name/ud/udp2raw/package.nix +++ b/pkgs/by-name/ud/udp2raw/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, makeWrapper -, iptables +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + makeWrapper, + iptables, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ud/udpreplay/package.nix b/pkgs/by-name/ud/udpreplay/package.nix index 53147a9fe7a443..3367597e688c92 100644 --- a/pkgs/by-name/ud/udpreplay/package.nix +++ b/pkgs/by-name/ud/udpreplay/package.nix @@ -1,4 +1,10 @@ -{ stdenv, cmake, libpcap, fetchFromGitHub, lib }: +{ + stdenv, + cmake, + libpcap, + fetchFromGitHub, + lib, +}: stdenv.mkDerivation rec { pname = "updreplay"; version = "1.1.0"; diff --git a/pkgs/by-name/ud/udptunnel/package.nix b/pkgs/by-name/ud/udptunnel/package.nix index e7b2832b40b57f..1bc9c190e7f8b5 100644 --- a/pkgs/by-name/ud/udptunnel/package.nix +++ b/pkgs/by-name/ud/udptunnel/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "udptunnel"; diff --git a/pkgs/by-name/ud/udpx/package.nix b/pkgs/by-name/ud/udpx/package.nix index f240057a2b6d0d..6ae7e7d90f9522 100644 --- a/pkgs/by-name/ud/udpx/package.nix +++ b/pkgs/by-name/ud/udpx/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ud/udunits/package.nix b/pkgs/by-name/ud/udunits/package.nix index 394058a3315c57..c541797022a436 100644 --- a/pkgs/by-name/ud/udunits/package.nix +++ b/pkgs/by-name/ud/udunits/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, bison -, expat -, file -, flex -, texinfo +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + bison, + expat, + file, + flex, + texinfo, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ue/ueberzugpp/package.nix b/pkgs/by-name/ue/ueberzugpp/package.nix index 0422c54a9d16e3..7fcfb6099a40ac 100644 --- a/pkgs/by-name/ue/ueberzugpp/package.nix +++ b/pkgs/by-name/ue/ueberzugpp/package.nix @@ -1,32 +1,33 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, openssl -, zeromq -, cppzmq -, tbb_2021_11 -, spdlog -, libsodium -, fmt -, vips -, nlohmann_json -, libsixel -, microsoft-gsl -, chafa -, cli11 -, libexif -, range-v3 -, enableOpencv ? stdenv.hostPlatform.isLinux -, opencv -, enableWayland ? stdenv.hostPlatform.isLinux -, extra-cmake-modules -, wayland -, wayland-protocols -, wayland-scanner -, enableX11 ? stdenv.hostPlatform.isLinux -, xorg +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + openssl, + zeromq, + cppzmq, + tbb_2021_11, + spdlog, + libsodium, + fmt, + vips, + nlohmann_json, + libsixel, + microsoft-gsl, + chafa, + cli11, + libexif, + range-v3, + enableOpencv ? stdenv.hostPlatform.isLinux, + opencv, + enableWayland ? stdenv.hostPlatform.isLinux, + extra-cmake-modules, + wayland, + wayland-protocols, + wayland-scanner, + enableX11 ? stdenv.hostPlatform.isLinux, + xorg, }: stdenv.mkDerivation rec { @@ -42,58 +43,73 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ - cmake - pkg-config - ] ++ lib.optionals enableWayland [ - wayland-scanner - ]; + nativeBuildInputs = + [ + cmake + pkg-config + ] + ++ lib.optionals enableWayland [ + wayland-scanner + ]; - buildInputs = [ - openssl - zeromq - cppzmq - tbb_2021_11 - spdlog - libsodium - fmt - vips - nlohmann_json - libsixel - microsoft-gsl - chafa - cli11 - libexif - range-v3 - ] ++ lib.optionals enableOpencv [ - opencv - ] ++ lib.optionals enableWayland [ - extra-cmake-modules - wayland - wayland-protocols - ] ++ lib.optionals enableX11 [ - xorg.libX11 - xorg.xcbutilimage - ]; + buildInputs = + [ + openssl + zeromq + cppzmq + tbb_2021_11 + spdlog + libsodium + fmt + vips + nlohmann_json + libsixel + microsoft-gsl + chafa + cli11 + libexif + range-v3 + ] + ++ lib.optionals enableOpencv [ + opencv + ] + ++ lib.optionals enableWayland [ + extra-cmake-modules + wayland + wayland-protocols + ] + ++ lib.optionals enableX11 [ + xorg.libX11 + xorg.xcbutilimage + ]; - cmakeFlags = lib.optionals (!enableOpencv) [ - "-DENABLE_OPENCV=OFF" - ] ++ lib.optionals enableWayland [ - "-DENABLE_WAYLAND=ON" - ] ++ lib.optionals (!enableX11) [ - "-DENABLE_X11=OFF" - ]; + cmakeFlags = + lib.optionals (!enableOpencv) [ + "-DENABLE_OPENCV=OFF" + ] + ++ lib.optionals enableWayland [ + "-DENABLE_WAYLAND=ON" + ] + ++ lib.optionals (!enableX11) [ + "-DENABLE_X11=OFF" + ]; # error: aligned deallocation function of type 'void (void *, std::align_val_t) noexcept' is only available on macOS 10.14 or newer - preBuild = lib.optionalString (stdenv.hostPlatform.isDarwin && lib.versionOlder stdenv.hostPlatform.darwinMinVersion "11.0") '' - export MACOSX_DEPLOYMENT_TARGET=10.14 - ''; + preBuild = + lib.optionalString + (stdenv.hostPlatform.isDarwin && lib.versionOlder stdenv.hostPlatform.darwinMinVersion "11.0") + '' + export MACOSX_DEPLOYMENT_TARGET=10.14 + ''; meta = with lib; { description = "Drop in replacement for ueberzug written in C++"; homepage = "https://github.com/jstkdng/ueberzugpp"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ aleksana wegank ]; + maintainers = with maintainers; [ + aleksana + wegank + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/ue/uefi-run/package.nix b/pkgs/by-name/ue/uefi-run/package.nix index e2e00c513eaacf..ba0650cdcfea7a 100644 --- a/pkgs/by-name/ue/uefi-run/package.nix +++ b/pkgs/by-name/ue/uefi-run/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ue/uefisettings/package.nix b/pkgs/by-name/ue/uefisettings/package.nix index 3315a5da788828..d93f9650dc8fc6 100644 --- a/pkgs/by-name/ue/uefisettings/package.nix +++ b/pkgs/by-name/ue/uefisettings/package.nix @@ -1,6 +1,7 @@ -{ fetchFromGitHub -, lib -, rustPlatform +{ + fetchFromGitHub, + lib, + rustPlatform, }: rustPlatform.buildRustPackage { diff --git a/pkgs/by-name/ue/uemacs/package.nix b/pkgs/by-name/ue/uemacs/package.nix index 4ed609868666a5..f5c92580fc6bbc 100644 --- a/pkgs/by-name/ue/uemacs/package.nix +++ b/pkgs/by-name/ue/uemacs/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchgit -, ncurses +{ + lib, + stdenv, + fetchgit, + ncurses, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ue/ueviewer/package.nix b/pkgs/by-name/ue/ueviewer/package.nix index 7ce9fc3d18dab6..935c638d76e4c2 100644 --- a/pkgs/by-name/ue/ueviewer/package.nix +++ b/pkgs/by-name/ue/ueviewer/package.nix @@ -1,12 +1,13 @@ -{ gccStdenv -, lib -, fetchFromGitHub -, fetchpatch -, unstableGitUpdater -, libpng -, perl -, SDL2 -, zlib +{ + gccStdenv, + lib, + fetchFromGitHub, + fetchpatch, + unstableGitUpdater, + libpng, + perl, + SDL2, + zlib, }: gccStdenv.mkDerivation (finalAttrs: { @@ -55,12 +56,14 @@ gccStdenv.mkDerivation (finalAttrs: { perl ]; - buildInputs = [ - libpng - zlib - ] ++ lib.optionals (!gccStdenv.hostPlatform.isDarwin) [ - SDL2 - ]; + buildInputs = + [ + libpng + zlib + ] + ++ lib.optionals (!gccStdenv.hostPlatform.isDarwin) [ + SDL2 + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/uf/ufiformat/package.nix b/pkgs/by-name/uf/ufiformat/package.nix index 52204a073ae78e..c830b3ac9dfb0c 100644 --- a/pkgs/by-name/uf/ufiformat/package.nix +++ b/pkgs/by-name/uf/ufiformat/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, e2fsprogs -, fetchFromGitHub -, lib +{ + stdenv, + e2fsprogs, + fetchFromGitHub, + lib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/uf/ufoai/package.nix b/pkgs/by-name/uf/ufoai/package.nix index ecaaa26a4d217f..54097f40af1158 100644 --- a/pkgs/by-name/uf/ufoai/package.nix +++ b/pkgs/by-name/uf/ufoai/package.nix @@ -1,5 +1,21 @@ -{ lib, stdenv, fetchurl, libtheora, xvidcore, libGLU, libGL, SDL, SDL_ttf, SDL_mixer -, curl, libjpeg, libpng, gettext, cunit, enableEditor?false }: +{ + lib, + stdenv, + fetchurl, + libtheora, + xvidcore, + libGLU, + libGL, + SDL, + SDL_ttf, + SDL_mixer, + curl, + libjpeg, + libpng, + gettext, + cunit, + enableEditor ? false, +}: stdenv.mkDerivation rec { pname = "ufoai"; @@ -23,12 +39,24 @@ stdenv.mkDerivation rec { preConfigure = ''tar xvf "${srcData}"''; - configureFlags = [ "--enable-release" "--enable-sse" ] - ++ lib.optional enableEditor "--enable-uforadiant"; + configureFlags = [ + "--enable-release" + "--enable-sse" + ] ++ lib.optional enableEditor "--enable-uforadiant"; buildInputs = [ - libtheora xvidcore libGLU libGL SDL SDL_ttf SDL_mixer - curl libjpeg libpng gettext cunit + libtheora + xvidcore + libGLU + libGL + SDL + SDL_ttf + SDL_mixer + curl + libjpeg + libpng + gettext + cunit ]; NIX_CFLAGS_LINK = [ @@ -45,6 +73,6 @@ stdenv.mkDerivation rec { license = lib.licenses.gpl2Plus; maintainers = [ ]; platforms = lib.platforms.linux; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/by-name/uf/uftp/package.nix b/pkgs/by-name/uf/uftp/package.nix index e2251e1a20c8ff..831493a3c622dd 100644 --- a/pkgs/by-name/uf/uftp/package.nix +++ b/pkgs/by-name/uf/uftp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, openssl }: +{ + lib, + stdenv, + fetchurl, + openssl, +}: stdenv.mkDerivation rec { pname = "uftp"; @@ -11,7 +16,10 @@ stdenv.mkDerivation rec { buildInputs = [ openssl ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; patchPhase = '' substituteInPlace makefile --replace gcc cc diff --git a/pkgs/by-name/uf/uftpd/package.nix b/pkgs/by-name/uf/uftpd/package.nix index 34557b955a1362..fd1aa0aad2a712 100644 --- a/pkgs/by-name/uf/uftpd/package.nix +++ b/pkgs/by-name/uf/uftpd/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, autoreconfHook, libuev, libite }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + libuev, + libite, +}: stdenv.mkDerivation rec { pname = "uftpd"; @@ -11,8 +19,14 @@ stdenv.mkDerivation rec { hash = "sha256-+y1eRPUgYf5laRFIDD1XOEfonPP8QMJNCSkmHlXIjdY="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ libuev libite ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + libuev + libite + ]; meta = with lib; { description = "FTP/TFTP server for Linux that just works™"; diff --git a/pkgs/by-name/uf/uftrace/package.nix b/pkgs/by-name/uf/uftrace/package.nix index 8b8f9d80feb182..cf051a23f5b50c 100644 --- a/pkgs/by-name/uf/uftrace/package.nix +++ b/pkgs/by-name/uf/uftrace/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, pandoc -, capstone -, elfutils -, libtraceevent -, ncurses -, withLuaJIT ? false -, luajit -, withPython ? false -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + pandoc, + capstone, + elfutils, + libtraceevent, + ncurses, + withLuaJIT ? false, + luajit, + withPython ? false, + python3, }: stdenv.mkDerivation rec { @@ -24,9 +25,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-JuBwyE6JH3CpJH863LbnWELUIIEKVaAcz8h8beeABGQ="; }; - nativeBuildInputs = [ pkg-config pandoc ]; + nativeBuildInputs = [ + pkg-config + pandoc + ]; buildInputs = - [ capstone elfutils libtraceevent ncurses ] + [ + capstone + elfutils + libtraceevent + ncurses + ] ++ lib.optional withLuaJIT luajit ++ lib.optional withPython python3; diff --git a/pkgs/by-name/ug/uget-integrator/package.nix b/pkgs/by-name/ug/uget-integrator/package.nix index 3ab9a0bafef4db..cda04712302ff5 100644 --- a/pkgs/by-name/ug/uget-integrator/package.nix +++ b/pkgs/by-name/ug/uget-integrator/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, uget, python3Packages }: +{ + lib, + stdenv, + fetchFromGitHub, + uget, + python3Packages, +}: stdenv.mkDerivation rec { pname = "uget-integrator"; @@ -13,7 +19,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ python3Packages.wrapPython ]; - buildInputs = [ uget python3Packages.python ]; + buildInputs = [ + uget + python3Packages.python + ]; installPhase = '' for f in conf/com.ugetdm.{chrome,firefox}.json; do diff --git a/pkgs/by-name/ug/uget/package.nix b/pkgs/by-name/ug/uget/package.nix index a2387f838ff52d..fd90e58161b1e6 100644 --- a/pkgs/by-name/ug/uget/package.nix +++ b/pkgs/by-name/ug/uget/package.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchurl, pkg-config, intltool, openssl, curl, libnotify, - libappindicator-gtk3, gst_all_1, gtk3, dconf, wrapGAppsHook3, aria2 ? null +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + openssl, + curl, + libnotify, + libappindicator-gtk3, + gst_all_1, + gtk3, + dconf, + wrapGAppsHook3, + aria2 ? null, }: stdenv.mkDerivation rec { @@ -24,21 +37,27 @@ stdenv.mkDerivation rec { wrapGAppsHook3 ]; - buildInputs = [ - openssl - curl - libnotify - libappindicator-gtk3 - gtk3 - (lib.getLib dconf) - ] - ++ (with gst_all_1; [ gstreamer gst-plugins-base gst-plugins-good ]) - ++ (lib.optional (aria2 != null) aria2); + buildInputs = + [ + openssl + curl + libnotify + libappindicator-gtk3 + gtk3 + (lib.getLib dconf) + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + ]) + ++ (lib.optional (aria2 != null) aria2); enableParallelBuilding = true; - preFixup = lib.optionalString (aria2 != null) - ''gappsWrapperArgs+=(--suffix PATH : "${aria2}/bin")''; + preFixup = lib.optionalString ( + aria2 != null + ) ''gappsWrapperArgs+=(--suffix PATH : "${aria2}/bin")''; meta = with lib; { description = "Download manager using GTK and libcurl"; diff --git a/pkgs/by-name/ug/ugm/package.nix b/pkgs/by-name/ug/ugm/package.nix index 05881924b4bf65..db5fe787f31900 100644 --- a/pkgs/by-name/ug/ugm/package.nix +++ b/pkgs/by-name/ug/ugm/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, nix-update-script +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + nix-update-script, }: buildGoModule rec { @@ -26,7 +27,7 @@ buildGoModule rec { --set RUNEWIDTH_EASTASIAN 0 ''; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; meta = with lib; { description = "Terminal based UNIX user and group browser"; diff --git a/pkgs/by-name/ug/ugrep-indexer/package.nix b/pkgs/by-name/ug/ugrep-indexer/package.nix index 2dd2cde3a266e7..2ee64420e663d6 100644 --- a/pkgs/by-name/ug/ugrep-indexer/package.nix +++ b/pkgs/by-name/ug/ugrep-indexer/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, brotli -, bzip2 -, lz4 -, xz -, zlib -, zstd +{ + lib, + stdenv, + fetchFromGitHub, + brotli, + bzip2, + lz4, + xz, + zlib, + zstd, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ug/ugrep/package.nix b/pkgs/by-name/ug/ugrep/package.nix index 5b1bce33d9326d..75721981a94339 100644 --- a/pkgs/by-name/ug/ugrep/package.nix +++ b/pkgs/by-name/ug/ugrep/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, boost -, brotli -, bzip2 -, bzip3 -, lz4 -, makeWrapper -, pcre2 -, testers -, xz -, zlib -, zstd +{ + lib, + stdenv, + fetchFromGitHub, + boost, + brotli, + bzip2, + bzip3, + lz4, + makeWrapper, + pcre2, + testers, + xz, + zlib, + zstd, }: stdenv.mkDerivation (finalAttrs: { @@ -55,7 +56,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Ultra fast grep with interactive query UI"; homepage = "https://github.com/Genivia/ugrep"; changelog = "https://github.com/Genivia/ugrep/releases/tag/v${finalAttrs.version}"; - maintainers = with maintainers; [ numkem mikaelfangel ]; + maintainers = with maintainers; [ + numkem + mikaelfangel + ]; license = licenses.bsd3; platforms = platforms.all; mainProgram = "ug"; diff --git a/pkgs/by-name/ug/ugs/package.nix b/pkgs/by-name/ug/ugs/package.nix index caf738f0f2b457..96703d2d4b2e03 100644 --- a/pkgs/by-name/ug/ugs/package.nix +++ b/pkgs/by-name/ug/ugs/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, copyDesktopItems -, makeDesktopItem -, makeWrapper -, jre -, fetchzip +{ + stdenv, + lib, + copyDesktopItems, + makeDesktopItem, + makeWrapper, + jre, + fetchzip, }: let desktopItem = makeDesktopItem { @@ -27,7 +28,10 @@ stdenv.mkDerivation rec { dontUnpack = true; - nativeBuildInputs = [ copyDesktopItems makeWrapper ]; + nativeBuildInputs = [ + copyDesktopItems + makeWrapper + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/ug/ugtrain/package.nix b/pkgs/by-name/ug/ugtrain/package.nix index 868700d6429960..c355dfbb30f18d 100644 --- a/pkgs/by-name/ug/ugtrain/package.nix +++ b/pkgs/by-name/ug/ugtrain/package.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, scanmem +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + scanmem, }: stdenv.mkDerivation rec { @@ -10,13 +12,17 @@ stdenv.mkDerivation rec { pname = "ugtrain"; src = fetchFromGitHub { - owner = "ugtrain"; - repo = "ugtrain"; - rev = "v${version}"; + owner = "ugtrain"; + repo = "ugtrain"; + rev = "v${version}"; sha256 = "0pw9lm8y83mda7x39874ax2147818h1wcibi83pd2x4rp1hjbkkn"; }; - nativeBuildInputs = [ autoreconfHook pkg-config scanmem ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + scanmem + ]; meta = with lib; { homepage = "https://github.com/ugtrain/ugtrain"; diff --git a/pkgs/by-name/uh/uhdm/package.nix b/pkgs/by-name/uh/uhdm/package.nix index 0b647eaafc211f..2bb3722cb2664f 100644 --- a/pkgs/by-name/uh/uhdm/package.nix +++ b/pkgs/by-name/uh/uhdm/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, python3 -, capnproto -, gtest +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, + capnproto, + gtest, }: stdenv.mkDerivation (finalAttrs: { @@ -18,7 +19,7 @@ stdenv.mkDerivation (finalAttrs: { # After we're back on a stable tag, use v${finalAttrs.version} rev = "857f68de3ce5b6f919f3a0f489c93072751b1578"; hash = "sha256-qHcRncsvMiSJji+JLOlfQ87+pfKg+zvlqMTXKpImvTM="; - fetchSubmodules = false; # we use all dependencies from nix + fetchSubmodules = false; # we use all dependencies from nix }; nativeBuildInputs = [ @@ -43,7 +44,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Universal Hardware Data Model"; homepage = "https://github.com/chipsalliance/UHDM"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ matthuszagh hzeller ]; + maintainers = with lib.maintainers; [ + matthuszagh + hzeller + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/by-name/uh/uhexen2/package.nix b/pkgs/by-name/uh/uhexen2/package.nix index a0922a145703d8..4ac7dd2236aeaa 100644 --- a/pkgs/by-name/uh/uhexen2/package.nix +++ b/pkgs/by-name/uh/uhexen2/package.nix @@ -1,4 +1,13 @@ -{ lib, fetchgit, SDL, stdenv, libogg, libvorbis, libmad, xdelta }: +{ + lib, + fetchgit, + SDL, + stdenv, + libogg, + libvorbis, + libmad, + xdelta, +}: stdenv.mkDerivation rec { pname = "uhexen2"; @@ -10,7 +19,13 @@ stdenv.mkDerivation rec { rev = "4ef664bc41e3998b0d2a55ff1166dadf34c936be"; }; - buildInputs = [ SDL libogg libvorbis libmad xdelta ]; + buildInputs = [ + SDL + libogg + libvorbis + libmad + xdelta + ]; preBuild = '' makeFiles=( diff --git a/pkgs/by-name/uh/uhk-udev-rules/package.nix b/pkgs/by-name/uh/uhk-udev-rules/package.nix index 1b68c46b6571f4..d8c9ccaf41252d 100644 --- a/pkgs/by-name/uh/uhk-udev-rules/package.nix +++ b/pkgs/by-name/uh/uhk-udev-rules/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, uhk-agent }: +{ + lib, + stdenv, + uhk-agent, +}: stdenv.mkDerivation { pname = "uhk-udev-rules"; diff --git a/pkgs/by-name/uh/uhttpmock/package.nix b/pkgs/by-name/uh/uhttpmock/package.nix index 6fcee7fb8d5367..191347e72259a4 100644 --- a/pkgs/by-name/uh/uhttpmock/package.nix +++ b/pkgs/by-name/uh/uhttpmock/package.nix @@ -1,23 +1,28 @@ -{ stdenv -, lib -, fetchFromGitLab -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, gobject-introspection -, vala -, gtk-doc -, docbook-xsl-nons -, glib -, libsoup_2_4 +{ + stdenv, + lib, + fetchFromGitLab, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + gobject-introspection, + vala, + gtk-doc, + docbook-xsl-nons, + glib, + libsoup_2_4, }: stdenv.mkDerivation rec { pname = "uhttpmock"; version = "0.5.5"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitLab { domain = "gitlab.freedesktop.org"; @@ -28,17 +33,19 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ - meson - ninja - pkg-config - gobject-introspection - vala - gtk-doc - docbook-xsl-nons - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gobject-introspection + vala + gtk-doc + docbook-xsl-nons + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ glib diff --git a/pkgs/by-name/uh/uhttpmock_1_0/package.nix b/pkgs/by-name/uh/uhttpmock_1_0/package.nix index 755e7a18d5ce41..cab0f0b466f5a2 100644 --- a/pkgs/by-name/uh/uhttpmock_1_0/package.nix +++ b/pkgs/by-name/uh/uhttpmock_1_0/package.nix @@ -1,23 +1,28 @@ -{ stdenv -, lib -, fetchFromGitLab -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, gobject-introspection -, vala -, gtk-doc -, docbook-xsl-nons -, glib -, libsoup_3 +{ + stdenv, + lib, + fetchFromGitLab, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + gobject-introspection, + vala, + gtk-doc, + docbook-xsl-nons, + glib, + libsoup_3, }: stdenv.mkDerivation (finalAttrs: { pname = "uhttpmock"; version = "0.11.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitLab { domain = "gitlab.freedesktop.org"; @@ -29,17 +34,19 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - nativeBuildInputs = [ - meson - ninja - pkg-config - gobject-introspection - vala - gtk-doc - docbook-xsl-nons - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gobject-introspection + vala + gtk-doc + docbook-xsl-nons + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; propagatedBuildInputs = [ glib diff --git a/pkgs/by-name/uh/uhub/package.nix b/pkgs/by-name/uh/uhub/package.nix index 37bddc3759f5d5..44053edfc6d0d1 100644 --- a/pkgs/by-name/uh/uhub/package.nix +++ b/pkgs/by-name/uh/uhub/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, openssl, sqlite, pkg-config -, systemd, tlsSupport ? false }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openssl, + sqlite, + pkg-config, + systemd, + tlsSupport ? false, +}: assert tlsSupport -> openssl != null; @@ -14,8 +23,14 @@ stdenv.mkDerivation rec { hash = "sha256-CdTTf82opnpjd7I9TTY+JDEZSfdGFPE0bq/xsafwm/w="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ sqlite systemd ] ++ lib.optional tlsSupport openssl; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + sqlite + systemd + ] ++ lib.optional tlsSupport openssl; postPatch = '' substituteInPlace CMakeLists.txt \ diff --git a/pkgs/by-name/uh/uhubctl/package.nix b/pkgs/by-name/uh/uhubctl/package.nix index 8feda34f2ad3e3..bd4ce7a1be24cd 100644 --- a/pkgs/by-name/uh/uhubctl/package.nix +++ b/pkgs/by-name/uh/uhubctl/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, which -, pkg-config -, libusb1 +{ + lib, + stdenv, + fetchFromGitHub, + which, + pkg-config, + libusb1, }: stdenv.mkDerivation rec { @@ -17,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-mpeDePHLsa4sGe2+8X9KQ8AYn7wtybDnaZzxnf4oETQ="; }; - nativeBuildInputs = [ which pkg-config ]; + nativeBuildInputs = [ + which + pkg-config + ]; buildInputs = [ libusb1 ]; @@ -27,7 +31,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/mvp/uhubctl"; description = "Utility to control USB power per-port on smart USB hubs"; license = licenses.gpl2Only; - maintainers = with maintainers; [ prusnak carlossless ]; + maintainers = with maintainers; [ + prusnak + carlossless + ]; platforms = with platforms; linux ++ darwin; mainProgram = "uhubctl"; }; diff --git a/pkgs/by-name/ui/uid_wrapper/package.nix b/pkgs/by-name/ui/uid_wrapper/package.nix index f5058237d5e598..c26c7b2e6007c1 100644 --- a/pkgs/by-name/ui/uid_wrapper/package.nix +++ b/pkgs/by-name/ui/uid_wrapper/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, cmake, pkg-config }: +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "uid_wrapper"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-9mB9hketooqW+rg8Sa1y/IPrbTiZHKJ7JJWzWP8Pbew="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; meta = with lib; { description = "Wrapper for the user, group and hosts NSS API"; diff --git a/pkgs/by-name/ui/uif2iso/package.nix b/pkgs/by-name/ui/uif2iso/package.nix index ae1eff26568fb0..fb236b36b3b3de 100644 --- a/pkgs/by-name/ui/uif2iso/package.nix +++ b/pkgs/by-name/ui/uif2iso/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, unzip, zlib }: +{ + lib, + stdenv, + fetchurl, + unzip, + zlib, +}: stdenv.mkDerivation rec { pname = "uif2iso"; @@ -10,7 +16,7 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ unzip ]; - buildInputs = [zlib]; + buildInputs = [ zlib ]; installPhase = '' make -C . prefix="$out" install; diff --git a/pkgs/by-name/ui/uisp/package.nix b/pkgs/by-name/ui/uisp/package.nix index d086781fb1c411..c87b916eed3875 100644 --- a/pkgs/by-name/ui/uisp/package.nix +++ b/pkgs/by-name/ui/uisp/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "uisp"; diff --git a/pkgs/by-name/ui/uiua386/package.nix b/pkgs/by-name/ui/uiua386/package.nix index 198d0a8cea9f36..f06d10f15635e9 100644 --- a/pkgs/by-name/ui/uiua386/package.nix +++ b/pkgs/by-name/ui/uiua386/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, uiua }: +{ + lib, + stdenvNoCC, + uiua, +}: stdenvNoCC.mkDerivation { pname = "uiua386"; diff --git a/pkgs/by-name/ui/uivonim/package.nix b/pkgs/by-name/ui/uivonim/package.nix index a888747d05223f..bb21fb1f45f886 100644 --- a/pkgs/by-name/ui/uivonim/package.nix +++ b/pkgs/by-name/ui/uivonim/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, electron -, makeWrapper +{ + lib, + buildNpmPackage, + fetchFromGitHub, + electron, + makeWrapper, }: buildNpmPackage rec { diff --git a/pkgs/by-name/uk/ukmm/package.nix b/pkgs/by-name/uk/ukmm/package.nix index 9a640b004bf859..5e7e68af879502 100644 --- a/pkgs/by-name/uk/ukmm/package.nix +++ b/pkgs/by-name/uk/ukmm/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, cmake -, pkg-config -, wrapGAppsHook3 -, libglvnd -, libxkbcommon -, openssl -, nix-update-script +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + cmake, + pkg-config, + wrapGAppsHook3, + libglvnd, + libxkbcommon, + openssl, + nix-update-script, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/ul/ulauncher/package.nix b/pkgs/by-name/ul/ulauncher/package.nix index bcad8be29b5843..22c4e096f3de60 100644 --- a/pkgs/by-name/ul/ulauncher/package.nix +++ b/pkgs/by-name/ul/ulauncher/package.nix @@ -1,22 +1,23 @@ -{ lib -, fetchurl -, nix-update-script -, python3Packages -, gdk-pixbuf -, glib -, adwaita-icon-theme -, gobject-introspection -, gtk3 -, wrapGAppsHook3 -, webkitgtk_4_0 -, libnotify -, keybinder3 -, libappindicator -, intltool -, wmctrl -, xvfb-run -, librsvg -, libX11 +{ + lib, + fetchurl, + nix-update-script, + python3Packages, + gdk-pixbuf, + glib, + adwaita-icon-theme, + gobject-introspection, + gtk3, + wrapGAppsHook3, + webkitgtk_4_0, + libnotify, + keybinder3, + libappindicator, + intltool, + wmctrl, + xvfb-run, + librsvg, + libX11, }: python3Packages.buildPythonApplication rec { @@ -115,13 +116,15 @@ python3Packages.buildPythonApplication rec { updateScript = nix-update-script { }; }; - meta = with lib; { description = "Fast application launcher for Linux, written in Python, using GTK"; homepage = "https://ulauncher.io/"; license = licenses.gpl3; platforms = platforms.linux; mainProgram = "ulauncher"; - maintainers = with maintainers; [ aaronjanse sebtm ]; + maintainers = with maintainers; [ + aaronjanse + sebtm + ]; }; } diff --git a/pkgs/by-name/ul/ulid/package.nix b/pkgs/by-name/ul/ulid/package.nix index f2ff23addfe750..e8a4a8c9bd2380 100644 --- a/pkgs/by-name/ul/ulid/package.nix +++ b/pkgs/by-name/ul/ulid/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-s1YkEwFxE1zpUUCgwOAl8i6/9HB2rcGG+4kqnixTit0="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; checkFlags = [ # skip flaky test diff --git a/pkgs/by-name/ul/ulogd/package.nix b/pkgs/by-name/ul/ulogd/package.nix index 291876cc92d24a..dd9bf17e33ad49 100644 --- a/pkgs/by-name/ul/ulogd/package.nix +++ b/pkgs/by-name/ul/ulogd/package.nix @@ -1,7 +1,26 @@ -{ stdenv, lib, fetchurl, gnumake, libnetfilter_acct, libnetfilter_conntrack -, libnetfilter_log, libmnl, libnfnetlink, automake, autoconf, autogen, libtool -, postgresql, libmysqlclient, sqlite -, pkg-config, libpcap, linuxdoc-tools, autoreconfHook, nixosTests }: +{ + stdenv, + lib, + fetchurl, + gnumake, + libnetfilter_acct, + libnetfilter_conntrack, + libnetfilter_log, + libmnl, + libnfnetlink, + automake, + autoconf, + autogen, + libtool, + postgresql, + libmysqlclient, + sqlite, + pkg-config, + libpcap, + linuxdoc-tools, + autoreconfHook, + nixosTests, +}: stdenv.mkDerivation rec { version = "2.0.8"; @@ -12,7 +31,11 @@ stdenv.mkDerivation rec { hash = "sha256-Tq1sOXDD9X+h6J/i18xIO6b+K9GwhwFSHgs6/WZ98pE="; }; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; postPatch = '' substituteInPlace ulogd.8 --replace "/usr/share/doc" "$doc/share/doc" diff --git a/pkgs/by-name/ul/ultimate-oldschool-pc-font-pack/package.nix b/pkgs/by-name/ul/ultimate-oldschool-pc-font-pack/package.nix index 4a1dfa00916a2b..559fd4adfbb1a4 100644 --- a/pkgs/by-name/ul/ultimate-oldschool-pc-font-pack/package.nix +++ b/pkgs/by-name/ul/ultimate-oldschool-pc-font-pack/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "ultimate-oldschool-pc-font-pack"; diff --git a/pkgs/by-name/ul/ultimatestunts/package.nix b/pkgs/by-name/ul/ultimatestunts/package.nix index 66906e5d50f34c..49396e3c34f392 100644 --- a/pkgs/by-name/ul/ultimatestunts/package.nix +++ b/pkgs/by-name/ul/ultimatestunts/package.nix @@ -1,16 +1,37 @@ -{lib, stdenv, fetchurl, SDL, libGLU, libGL, SDL_image, freealut, openal, libvorbis, -pkg-config}: +{ + lib, + stdenv, + fetchurl, + SDL, + libGLU, + libGL, + SDL_image, + freealut, + openal, + libvorbis, + pkg-config, +}: stdenv.mkDerivation rec { pname = "ultimate-stunts"; version = "0.7.7.1"; src = fetchurl { - url = "mirror://sourceforge/ultimatestunts/ultimatestunts-srcdata-${lib.replaceStrings ["."] [""] version}.tar.gz"; + url = "mirror://sourceforge/ultimatestunts/ultimatestunts-srcdata-${ + lib.replaceStrings [ "." ] [ "" ] version + }.tar.gz"; sha256 = "sha256-/MBuSi/yxcG9k3ZwrNsHkUDzzg798AV462VZog67JtM="; }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ SDL libGLU libGL SDL_image freealut openal libvorbis ]; + buildInputs = [ + SDL + libGLU + libGL + SDL_image + freealut + openal + libvorbis + ]; postPatch = '' sed -e '1i#include ' -i $(find . -name '*.c' -o -name '*.cpp') diff --git a/pkgs/by-name/ul/ultrablue-server/package.nix b/pkgs/by-name/ul/ultrablue-server/package.nix index 1d3cc69fae10d4..522601052787dd 100644 --- a/pkgs/by-name/ul/ultrablue-server/package.nix +++ b/pkgs/by-name/ul/ultrablue-server/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { diff --git a/pkgs/by-name/ul/ultralist/package.nix b/pkgs/by-name/ul/ultralist/package.nix index edcc086dbb88d3..c95ca2ec1db683 100644 --- a/pkgs/by-name/ul/ultralist/package.nix +++ b/pkgs/by-name/ul/ultralist/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ultralist"; diff --git a/pkgs/by-name/ul/ultrastardx/package.nix b/pkgs/by-name/ul/ultrastardx/package.nix index 1a8187f7f0e361..4bf46c62e55774 100644 --- a/pkgs/by-name/ul/ultrastardx/package.nix +++ b/pkgs/by-name/ul/ultrastardx/package.nix @@ -1,34 +1,51 @@ -{ lib, stdenv -, autoreconfHook -, fetchFromGitHub -, pkg-config -, lua -, fpc -, pcre -, portaudio -, freetype -, libpng -, SDL2 -, SDL2_image -, SDL2_gfx -, SDL2_mixer -, SDL2_net, SDL2_ttf -, ffmpeg -, sqlite -, zlib -, libX11 -, libGLU -, libGL +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + pkg-config, + lua, + fpc, + pcre, + portaudio, + freetype, + libpng, + SDL2, + SDL2_image, + SDL2_gfx, + SDL2_mixer, + SDL2_net, + SDL2_ttf, + ffmpeg, + sqlite, + zlib, + libX11, + libGLU, + libGL, }: let sharedLibs = [ - pcre portaudio freetype - SDL2 SDL2_image SDL2_gfx SDL2_mixer SDL2_net SDL2_ttf - sqlite lua zlib libX11 libGLU libGL ffmpeg + pcre + portaudio + freetype + SDL2 + SDL2_image + SDL2_gfx + SDL2_mixer + SDL2_net + SDL2_ttf + sqlite + lua + zlib + libX11 + libGLU + libGL + ffmpeg ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "ultrastardx"; version = "2024.10.0"; @@ -39,8 +56,14 @@ in stdenv.mkDerivation rec { hash = "sha256-X5LixPRAI7A8Ns3D2A24T05w0iHag1EJVqt0aW1ZBps="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ fpc libpng ] ++ sharedLibs; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + fpc + libpng + ] ++ sharedLibs; postPatch = '' substituteInPlace src/config.inc.in \ @@ -48,8 +71,10 @@ in stdenv.mkDerivation rec { ''; preBuild = - let items = lib.concatMapStringsSep " " (x: "-rpath ${lib.getLib x}/lib") sharedLibs; - in '' + let + items = lib.concatMapStringsSep " " (x: "-rpath ${lib.getLib x}/lib") sharedLibs; + in + '' export NIX_LDFLAGS="$NIX_LDFLAGS ${items}" ''; diff --git a/pkgs/by-name/um/umlet/package.nix b/pkgs/by-name/um/umlet/package.nix index b9d3e5d3153809..9ef125fcfdd7c8 100644 --- a/pkgs/by-name/um/umlet/package.nix +++ b/pkgs/by-name/um/umlet/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, jre, unzip, runtimeShell }: +{ + lib, + stdenv, + fetchurl, + jre, + unzip, + runtimeShell, +}: stdenv.mkDerivation { pname = "umlet"; diff --git a/pkgs/by-name/um/umoci/package.nix b/pkgs/by-name/um/umoci/package.nix index acf03a96c747d2..8f74acd0dd7050 100644 --- a/pkgs/by-name/um/umoci/package.nix +++ b/pkgs/by-name/um/umoci/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, go-md2man -, installShellFiles +{ + lib, + fetchFromGitHub, + buildGoModule, + go-md2man, + installShellFiles, }: buildGoModule rec { @@ -20,9 +21,16 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; - nativeBuildInputs = [ go-md2man installShellFiles ]; + nativeBuildInputs = [ + go-md2man + installShellFiles + ]; postInstall = '' make docs SHELL="$SHELL" diff --git a/pkgs/by-name/um/umockdev/package.nix b/pkgs/by-name/um/umockdev/package.nix index 662a1237e471bd..ffcb59febd8765 100644 --- a/pkgs/by-name/um/umockdev/package.nix +++ b/pkgs/by-name/um/umockdev/package.nix @@ -1,29 +1,35 @@ -{ stdenv -, lib -, docbook-xsl-nons -, fetchurl -, glib -, gobject-introspection -, gtk-doc -, libgudev -, libpcap -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, python3 -, substituteAll -, systemdMinimal -, usbutils -, vala -, which +{ + stdenv, + lib, + docbook-xsl-nons, + fetchurl, + glib, + gobject-introspection, + gtk-doc, + libgudev, + libpcap, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + python3, + substituteAll, + systemdMinimal, + usbutils, + vala, + which, }: stdenv.mkDerivation (finalAttrs: { pname = "umockdev"; version = "0.18.4"; - outputs = [ "bin" "out" "dev" "devdoc" ]; + outputs = [ + "bin" + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "https://github.com/martinpitt/umockdev/releases/download/${finalAttrs.version}/umockdev-${finalAttrs.version}.tar.xz"; @@ -44,17 +50,19 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - nativeBuildInputs = [ - docbook-xsl-nons - gobject-introspection - gtk-doc - meson - ninja - pkg-config - vala - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + docbook-xsl-nons + gobject-introspection + gtk-doc + meson + ninja + pkg-config + vala + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ glib diff --git a/pkgs/by-name/um/umoria/package.nix b/pkgs/by-name/um/umoria/package.nix index 274aec98e0aa89..9e56a85f1d420b 100644 --- a/pkgs/by-name/um/umoria/package.nix +++ b/pkgs/by-name/um/umoria/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, cmake -, ncurses6 -, runtimeShell +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + cmake, + ncurses6, + runtimeShell, }: let @@ -106,7 +107,10 @@ stdenv.mkDerivation rec { ''; platforms = platforms.unix; badPlatforms = [ "aarch64-darwin" ]; - maintainers = with maintainers; [ aciceri kenran ]; + maintainers = with maintainers; [ + aciceri + kenran + ]; license = licenses.gpl3Plus; }; } diff --git a/pkgs/by-name/um/umpire/package.nix b/pkgs/by-name/um/umpire/package.nix index 54340d3fdeca1c..6ba2b7027d67d4 100644 --- a/pkgs/by-name/um/umpire/package.nix +++ b/pkgs/by-name/um/umpire/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, config -, cudaSupport ? config.cudaSupport -, cudaPackages ? null +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + config, + cudaSupport ? config.cudaSupport, + cudaPackages ? null, }: assert cudaSupport -> cudaPackages != null; @@ -21,16 +22,21 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ - cmake - ] ++ lib.optionals cudaSupport [ - cudaPackages.cuda_nvcc - ]; + nativeBuildInputs = + [ + cmake + ] + ++ lib.optionals cudaSupport [ + cudaPackages.cuda_nvcc + ]; - buildInputs = lib.optionals cudaSupport (with cudaPackages; [ - cudatoolkit - cuda_cudart - ]); + buildInputs = lib.optionals cudaSupport ( + with cudaPackages; + [ + cudatoolkit + cuda_cudart + ] + ); cmakeFlags = lib.optionals cudaSupport [ "-DCUDA_TOOLKIT_ROOT_DIR=${cudaPackages.cudatoolkit}" diff --git a/pkgs/by-name/um/umr/package.nix b/pkgs/by-name/um/umr/package.nix index 8325fe4f3654df..416051d36c2894 100644 --- a/pkgs/by-name/um/umr/package.nix +++ b/pkgs/by-name/um/umr/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv +{ + lib, + stdenv, -, fetchFromGitLab + fetchFromGitLab, -, cmake -, pkg-config + cmake, + pkg-config, -, libdrm -, mesa # libgbm -, libpciaccess -, llvmPackages -, nanomsg -, ncurses -, SDL2 -, bash-completion + libdrm, + mesa, # libgbm + libpciaccess, + llvmPackages, + nanomsg, + ncurses, + SDL2, + bash-completion, -, nix-update-script + nix-update-script, }: stdenv.mkDerivation rec { @@ -55,5 +56,5 @@ stdenv.mkDerivation rec { license = licenses.mit; maintainers = with maintainers; [ Flakebi ]; platforms = platforms.linux; - }; + }; } diff --git a/pkgs/by-name/um/ums/package.nix b/pkgs/by-name/um/ums/package.nix index bfed80373746e6..43a52adbab86c9 100644 --- a/pkgs/by-name/um/ums/package.nix +++ b/pkgs/by-name/um/ums/package.nix @@ -1,21 +1,35 @@ -{ lib, stdenv, fetchurl, makeWrapper -, libzen, libmediainfo , jre8 +{ + lib, + stdenv, + fetchurl, + makeWrapper, + libzen, + libmediainfo, + jre8, }: stdenv.mkDerivation rec { pname = "ums"; version = "10.12.0"; - src = { - i686-linux = fetchurl { - url = "mirror://sourceforge/project/unimediaserver/${version}/" + lib.toUpper "${pname}-${version}" + "-x86.tgz"; - sha256 = "0j3d5zcwwswlcr2vicmvnnr7n8cg3q46svz0mbmga4j3da4473i6"; - }; - x86_64-linux = fetchurl { - url = "mirror://sourceforge/project/unimediaserver/${version}/" + lib.toUpper "${pname}-${version}" + "-x86_64.tgz"; - sha256 = "06f96vkf593aasyfw458fa4x3rnai2k83vpgzc83hlwr0rw70qfn"; - }; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + { + i686-linux = fetchurl { + url = + "mirror://sourceforge/project/unimediaserver/${version}/" + + lib.toUpper "${pname}-${version}" + + "-x86.tgz"; + sha256 = "0j3d5zcwwswlcr2vicmvnnr7n8cg3q46svz0mbmga4j3da4473i6"; + }; + x86_64-linux = fetchurl { + url = + "mirror://sourceforge/project/unimediaserver/${version}/" + + lib.toUpper "${pname}-${version}" + + "-x86_64.tgz"; + sha256 = "06f96vkf593aasyfw458fa4x3rnai2k83vpgzc83hlwr0rw70qfn"; + }; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); nativeBuildInputs = [ makeWrapper ]; @@ -29,15 +43,23 @@ stdenv.mkDerivation rec { rm -rf $out/jre8 makeWrapper "$out/UMS.sh" "$out/bin/ums" \ - --prefix LD_LIBRARY_PATH ":" "${lib.makeLibraryPath [ libzen libmediainfo] }" \ + --prefix LD_LIBRARY_PATH ":" "${ + lib.makeLibraryPath [ + libzen + libmediainfo + ] + }" \ --set JAVA_HOME "${jre8}" ''; meta = { - description = "Universal Media Server: a DLNA-compliant UPnP Media Server"; - license = lib.licenses.gpl2Only; - platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ thall snicket2100 ]; - mainProgram = "ums"; + description = "Universal Media Server: a DLNA-compliant UPnP Media Server"; + license = lib.licenses.gpl2Only; + platforms = lib.platforms.linux; + maintainers = with lib.maintainers; [ + thall + snicket2100 + ]; + mainProgram = "ums"; }; } diff --git a/pkgs/by-name/um/umurmur/package.nix b/pkgs/by-name/um/umurmur/package.nix index 5f87a739546290..d2e5aa04989693 100644 --- a/pkgs/by-name/um/umurmur/package.nix +++ b/pkgs/by-name/um/umurmur/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, openssl, protobufc, libconfig }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + openssl, + protobufc, + libconfig, +}: stdenv.mkDerivation rec { pname = "umurmur"; @@ -12,7 +20,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ openssl protobufc libconfig ]; + buildInputs = [ + openssl + protobufc + libconfig + ]; # https://github.com/umurmur/umurmur/issues/176 postPatch = '' diff --git a/pkgs/by-name/un/unciv/package.nix b/pkgs/by-name/un/unciv/package.nix index 4357cb4bd97d77..4a656b676559e5 100644 --- a/pkgs/by-name/un/unciv/package.nix +++ b/pkgs/by-name/un/unciv/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchurl -, copyDesktopItems -, makeDesktopItem -, makeWrapper -, jre -, libGL -, libpulseaudio -, libXxf86vm +{ + stdenv, + lib, + fetchurl, + copyDesktopItems, + makeDesktopItem, + makeWrapper, + jre, + libGL, + libpulseaudio, + libXxf86vm, }: let version = "4.14.9"; @@ -26,11 +27,13 @@ let hash = "sha256-Zuz+HGfxjGviGBKTiHdIFXF8UMRLEIfM8f+LIB/xonk="; }; - envLibPath = lib.makeLibraryPath (lib.optionals stdenv.hostPlatform.isLinux [ - libGL - libpulseaudio - libXxf86vm - ]); + envLibPath = lib.makeLibraryPath ( + lib.optionals stdenv.hostPlatform.isLinux [ + libGL + libpulseaudio + libXxf86vm + ] + ); in stdenv.mkDerivation rec { @@ -44,7 +47,10 @@ stdenv.mkDerivation rec { dontUnpack = true; - nativeBuildInputs = [ copyDesktopItems makeWrapper ]; + nativeBuildInputs = [ + copyDesktopItems + makeWrapper + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/un/unclutter-xfixes/package.nix b/pkgs/by-name/un/unclutter-xfixes/package.nix index 81db6449eb14ef..4c04befe01c167 100644 --- a/pkgs/by-name/un/unclutter-xfixes/package.nix +++ b/pkgs/by-name/un/unclutter-xfixes/package.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, - libev, libX11, libXext, libXi, libXfixes, - pkg-config, asciidoc, libxslt, docbook_xsl }: +{ + lib, + stdenv, + fetchFromGitHub, + libev, + libX11, + libXext, + libXi, + libXfixes, + pkg-config, + asciidoc, + libxslt, + docbook_xsl, +}: stdenv.mkDerivation rec { pname = "unclutter-xfixes"; @@ -13,8 +24,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-suKmaoJq0PBHZc7NzBQ60JGwJkAtWmvzPtTHWOPJEdc="; }; - nativeBuildInputs = [ pkg-config asciidoc libxslt docbook_xsl ]; - buildInputs = [ libev libX11 libXext libXi libXfixes ]; + nativeBuildInputs = [ + pkg-config + asciidoc + libxslt + docbook_xsl + ]; + buildInputs = [ + libev + libX11 + libXext + libXi + libXfixes + ]; prePatch = '' substituteInPlace Makefile --replace 'PKG_CONFIG =' 'PKG_CONFIG ?=' diff --git a/pkgs/by-name/un/unclutter/package.nix b/pkgs/by-name/un/unclutter/package.nix index 5d711c5fd03d00..6d2193e42d7e81 100644 --- a/pkgs/by-name/un/unclutter/package.nix +++ b/pkgs/by-name/un/unclutter/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, libX11 +{ + lib, + stdenv, + fetchurl, + libX11, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/un/unconvert/package.nix b/pkgs/by-name/un/unconvert/package.nix index 478a111555a61a..aab3ac49168fd2 100644 --- a/pkgs/by-name/un/unconvert/package.nix +++ b/pkgs/by-name/un/unconvert/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "unconvert"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-vZDk+ZNCMP5RRNrgeIowdOKPot7rqM84JhlbfvcQbB4="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Remove unnecessary type conversions from Go source"; diff --git a/pkgs/by-name/un/uncrustify/package.nix b/pkgs/by-name/un/uncrustify/package.nix index be41234132df82..8d9c67b7c2f27d 100644 --- a/pkgs/by-name/un/uncrustify/package.nix +++ b/pkgs/by-name/un/uncrustify/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, +}: stdenv.mkDerivation rec { pname = "uncrustify"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-SsPuqPyv3IFjYtAqANjzK8cdTGsyGBXVLzGWEUl28dg="; }; - nativeBuildInputs = [ cmake python3 ]; + nativeBuildInputs = [ + cmake + python3 + ]; meta = with lib; { description = "Source code beautifier for C, C++, C#, ObjectiveC, D, Java, Pawn and VALA"; diff --git a/pkgs/by-name/un/undaemonize/package.nix b/pkgs/by-name/un/undaemonize/package.nix index 83007db867dc38..a0978214441257 100644 --- a/pkgs/by-name/un/undaemonize/package.nix +++ b/pkgs/by-name/un/undaemonize/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "undaemonize"; @@ -22,4 +26,3 @@ stdenv.mkDerivation { mainProgram = "undaemonize"; }; } - diff --git a/pkgs/by-name/un/undbx/package.nix b/pkgs/by-name/un/undbx/package.nix index 269abccdbdf218..6eef53d3b98b57 100644 --- a/pkgs/by-name/un/undbx/package.nix +++ b/pkgs/by-name/un/undbx/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/un/undefined-medium/package.nix b/pkgs/by-name/un/undefined-medium/package.nix index 8dd3cc71ac27d2..93a358db67fbe1 100644 --- a/pkgs/by-name/un/undefined-medium/package.nix +++ b/pkgs/by-name/un/undefined-medium/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "undefined-medium"; diff --git a/pkgs/by-name/un/undertime/package.nix b/pkgs/by-name/un/undertime/package.nix index a754229f4d1713..309e00ea2e2348 100644 --- a/pkgs/by-name/un/undertime/package.nix +++ b/pkgs/by-name/un/undertime/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitLab +{ + lib, + python3Packages, + fetchFromGitLab, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/un/undervolt/package.nix b/pkgs/by-name/un/undervolt/package.nix index 045667c3e3a444..57a7cb8828558f 100644 --- a/pkgs/by-name/un/undervolt/package.nix +++ b/pkgs/by-name/un/undervolt/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { version = "0.4.0"; diff --git a/pkgs/by-name/un/undistract-me/package.nix b/pkgs/by-name/un/undistract-me/package.nix index b15903e779ea92..2bc59f15d3b0af 100644 --- a/pkgs/by-name/un/undistract-me/package.nix +++ b/pkgs/by-name/un/undistract-me/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, fetchpatch -, coreutils -, gnused -, libnotify -, pulseaudio -, sound-theme-freedesktop -, xprop +{ + lib, + stdenvNoCC, + fetchFromGitHub, + fetchpatch, + coreutils, + gnused, + libnotify, + pulseaudio, + sound-theme-freedesktop, + xprop, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/un/undocker/package.nix b/pkgs/by-name/un/undocker/package.nix index 0cc9deb74df386..47d58a552366c9 100644 --- a/pkgs/by-name/un/undocker/package.nix +++ b/pkgs/by-name/un/undocker/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitea -, gnumake +{ + lib, + buildGoModule, + fetchFromGitea, + gnumake, }: let version = "1.2.3"; @@ -30,7 +31,10 @@ buildGoModule { homepage = "https://git.jakstys.lt/motiejus/undocker"; description = "CLI tool to convert a Docker image to a flattened rootfs tarball"; license = licenses.asl20; - maintainers = with maintainers; [ jordanisaacs motiejus ]; + maintainers = with maintainers; [ + jordanisaacs + motiejus + ]; mainProgram = "undocker"; }; } diff --git a/pkgs/by-name/un/undollar/package.nix b/pkgs/by-name/un/undollar/package.nix index 633d095df9d8c9..d1f6df488b2841 100644 --- a/pkgs/by-name/un/undollar/package.nix +++ b/pkgs/by-name/un/undollar/package.nix @@ -2,7 +2,7 @@ lib, fetchFromGitHub, stdenvNoCC, - nodejs + nodejs, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/un/unflac/package.nix b/pkgs/by-name/un/unflac/package.nix index e29e9161cf2f44..2d5d1b3d1b9e0a 100644 --- a/pkgs/by-name/un/unflac/package.nix +++ b/pkgs/by-name/un/unflac/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromSourcehut -, ffmpeg -, makeWrapper +{ + lib, + buildGoModule, + fetchFromSourcehut, + ffmpeg, + makeWrapper, }: buildGoModule rec { @@ -20,12 +21,11 @@ buildGoModule rec { nativeBuildInputs = [ makeWrapper ]; postFixup = '' - wrapProgram $out/bin/unflac --prefix PATH : "${lib.makeBinPath [ffmpeg]}" + wrapProgram $out/bin/unflac --prefix PATH : "${lib.makeBinPath [ ffmpeg ]}" ''; meta = with lib; { - description = - "A command line tool for fast frame accurate audio image + cue sheet splitting"; + description = "A command line tool for fast frame accurate audio image + cue sheet splitting"; homepage = "https://sr.ht/~ft/unflac/"; license = licenses.mit; platforms = platforms.all; diff --git a/pkgs/by-name/un/unfonts-core/package.nix b/pkgs/by-name/un/unfonts-core/package.nix index 5756a948f6984a..0b983085c94772 100644 --- a/pkgs/by-name/un/unfonts-core/package.nix +++ b/pkgs/by-name/un/unfonts-core/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "unfonts-core"; diff --git a/pkgs/by-name/un/unfs3/package.nix b/pkgs/by-name/un/unfs3/package.nix index 448f7a2ca86fa6..0548512aa40045 100644 --- a/pkgs/by-name/un/unfs3/package.nix +++ b/pkgs/by-name/un/unfs3/package.nix @@ -1,11 +1,12 @@ -{ fetchFromGitHub -, lib -, stdenv -, flex -, bison -, autoreconfHook -, pkg-config -, libtirpc +{ + fetchFromGitHub, + lib, + stdenv, + flex, + bison, + autoreconfHook, + pkg-config, + libtirpc, }: stdenv.mkDerivation rec { @@ -19,13 +20,18 @@ stdenv.mkDerivation rec { hash = "sha256-5iAriIutBhwyZVS7AG2fnkrHOI7pNAKfYv062Cy0WXw="; }; - nativeBuildInputs = [ flex bison autoreconfHook pkg-config ]; + nativeBuildInputs = [ + flex + bison + autoreconfHook + pkg-config + ]; buildInputs = [ libtirpc ]; configureFlags = [ "--disable-shared" ]; - doCheck = false; # no test suite + doCheck = false; # no test suite meta = { description = "User-space NFSv3 file system server"; diff --git a/pkgs/by-name/un/unfurl/package.nix b/pkgs/by-name/un/unfurl/package.nix index 0d9ae3b01992b1..ccca02140d70df 100644 --- a/pkgs/by-name/un/unfurl/package.nix +++ b/pkgs/by-name/un/unfurl/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-Kpd916+jjGvw56N122Ej4CXVcv1/xr1THkjsrhkIy+U="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; # tests tries to download a list of tlds from the internet postPatch = '' diff --git a/pkgs/by-name/un/ungit/package.nix b/pkgs/by-name/un/ungit/package.nix index 215c9c2b758129..c5eedfb02c7315 100644 --- a/pkgs/by-name/un/ungit/package.nix +++ b/pkgs/by-name/un/ungit/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/un/uni-sync/package.nix b/pkgs/by-name/un/uni-sync/package.nix index de58c54deb4b7d..3625fcf2d57808 100644 --- a/pkgs/by-name/un/uni-sync/package.nix +++ b/pkgs/by-name/un/uni-sync/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, libudev-zero +{ + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + libudev-zero, }: rustPlatform.buildRustPackage rec { pname = "uni-sync"; diff --git a/pkgs/by-name/un/uni-vga/package.nix b/pkgs/by-name/un/uni-vga/package.nix index 5be5a817b8570d..7c3aa2a186bd6f 100644 --- a/pkgs/by-name/un/uni-vga/package.nix +++ b/pkgs/by-name/un/uni-vga/package.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchurl, perl, kbd, bdftopcf -, libfaketime, xorg +{ + lib, + stdenv, + fetchurl, + perl, + kbd, + bdftopcf, + libfaketime, + xorg, }: stdenv.mkDerivation { @@ -11,41 +18,55 @@ stdenv.mkDerivation { }; nativeBuildInputs = - [ bdftopcf libfaketime - xorg.fonttosfnt xorg.mkfontscale - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ perl kbd ]; + [ + bdftopcf + libfaketime + xorg.fonttosfnt + xorg.mkfontscale + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + perl + kbd + ]; postPatch = "patchShebangs ."; - buildPhase = '' - # convert font to compressed pcf - bdftopcf u_vga16.bdf | gzip -c -9 -n > u_vga16.pcf.gz - - # convert bdf font to otb - faketime -f "1970-01-01 00:00:01" \ - fonttosfnt -v -o u_vga16.otb u_vga16.bdf - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - # convert font to compressed psf - ./bdf2psf.pl -s UniCyrX.sfm u_vga16.bdf \ - | psfaddtable - UniCyrX.sfm - \ - | gzip -c -9 -n > u_vga16.psf.gz - ''; - - installPhase = '' - # install pcf and otb (for X11 and GTK applications) - install -m 644 -D *.otb *.pcf.gz -t "$out/share/fonts" - mkfontdir "$out/share/fonts" - - # install bdf font - install -m 644 -D *.bdf -t "$bdf/share/fonts" - mkfontdir "$bdf/share/fonts" - - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - # install psf (for linux virtual terminal) - install -m 644 -D *.psf.gz -t "$out/share/consolefonts" - ''; - - outputs = [ "out" "bdf" ]; + buildPhase = + '' + # convert font to compressed pcf + bdftopcf u_vga16.bdf | gzip -c -9 -n > u_vga16.pcf.gz + + # convert bdf font to otb + faketime -f "1970-01-01 00:00:01" \ + fonttosfnt -v -o u_vga16.otb u_vga16.bdf + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + # convert font to compressed psf + ./bdf2psf.pl -s UniCyrX.sfm u_vga16.bdf \ + | psfaddtable - UniCyrX.sfm - \ + | gzip -c -9 -n > u_vga16.psf.gz + ''; + + installPhase = + '' + # install pcf and otb (for X11 and GTK applications) + install -m 644 -D *.otb *.pcf.gz -t "$out/share/fonts" + mkfontdir "$out/share/fonts" + + # install bdf font + install -m 644 -D *.bdf -t "$bdf/share/fonts" + mkfontdir "$bdf/share/fonts" + + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + # install psf (for linux virtual terminal) + install -m 644 -D *.psf.gz -t "$out/share/consolefonts" + ''; + + outputs = [ + "out" + "bdf" + ]; meta = with lib; { description = "Unicode VGA font"; diff --git a/pkgs/by-name/un/uni/package.nix b/pkgs/by-name/un/uni/package.nix index 04ffa390d4b390..11ce3795e754b7 100644 --- a/pkgs/by-name/un/uni/package.nix +++ b/pkgs/by-name/un/uni/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/un/uni2ascii/package.nix b/pkgs/by-name/un/uni2ascii/package.nix index a853a5de7775f0..e121d4a9cfa0b2 100644 --- a/pkgs/by-name/un/uni2ascii/package.nix +++ b/pkgs/by-name/un/uni2ascii/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "uni2ascii"; @@ -22,25 +26,25 @@ stdenv.mkDerivation rec { description = "Converts between UTF-8 and many 7-bit ASCII equivalents and back"; longDescription = '' - This package provides conversion in both directions between UTF-8 - Unicode and more than thirty 7-bit ASCII equivalents, including - RFC 2396 URI format and RFC 2045 Quoted Printable format, the - representations used in HTML, SGML, XML, OOXML, the Unicode - standard, Rich Text Format, POSIX portable charmaps, POSIX locale - specifications, and Apache log files, and the escapes used for - including Unicode in Ada, C, Common Lisp, Java, Pascal, Perl, - Postscript, Python, Scheme, and Tcl. + This package provides conversion in both directions between UTF-8 + Unicode and more than thirty 7-bit ASCII equivalents, including + RFC 2396 URI format and RFC 2045 Quoted Printable format, the + representations used in HTML, SGML, XML, OOXML, the Unicode + standard, Rich Text Format, POSIX portable charmaps, POSIX locale + specifications, and Apache log files, and the escapes used for + including Unicode in Ada, C, Common Lisp, Java, Pascal, Perl, + Postscript, Python, Scheme, and Tcl. - Such ASCII equivalents are useful when including Unicode text in - program source, when debugging, and when entering text into web - programs that can handle the Unicode character set but are not - 8-bit safe. For example, MovableType, the blog software, truncates - posts as soon as it encounters a byte with the high bit - set. However, if Unicode is entered in the form of HTML numeric - character entities, Movable Type will not garble the post. + Such ASCII equivalents are useful when including Unicode text in + program source, when debugging, and when entering text into web + programs that can handle the Unicode character set but are not + 8-bit safe. For example, MovableType, the blog software, truncates + posts as soon as it encounters a byte with the high bit + set. However, if Unicode is entered in the form of HTML numeric + character entities, Movable Type will not garble the post. - It also provides ways of converting non-ASCII characters to - similar ASCII characters, e.g. by stripping diacritics. + It also provides ways of converting non-ASCII characters to + similar ASCII characters, e.g. by stripping diacritics. ''; maintainers = [ ]; platforms = lib.platforms.all; diff --git a/pkgs/by-name/un/unibilium/package.nix b/pkgs/by-name/un/unibilium/package.nix index 66e7a8d3843f8f..597cea810c220b 100644 --- a/pkgs/by-name/un/unibilium/package.nix +++ b/pkgs/by-name/un/unibilium/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchFromGitHub, libtool, pkg-config, perl, ncurses, autoreconfHook }: +{ + stdenv, + lib, + fetchFromGitHub, + libtool, + pkg-config, + perl, + ncurses, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "unibilium"; @@ -14,7 +23,12 @@ stdenv.mkDerivation rec { strictDeps = true; enableParallelBuilding = true; - nativeBuildInputs = [ autoreconfHook pkg-config perl libtool ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + perl + libtool + ]; buildInputs = [ ncurses ]; meta = with lib; { diff --git a/pkgs/by-name/un/unicap/package.nix b/pkgs/by-name/un/unicap/package.nix index f26365fa8e6322..4dac2248ebf642 100644 --- a/pkgs/by-name/un/unicap/package.nix +++ b/pkgs/by-name/un/unicap/package.nix @@ -1,8 +1,18 @@ -{ lib, stdenv, fetchurl, libusb-compat-0_1, libraw1394, dcraw, intltool, perl, v4l-utils }: +{ + lib, + stdenv, + fetchurl, + libusb-compat-0_1, + libraw1394, + dcraw, + intltool, + perl, + v4l-utils, +}: stdenv.mkDerivation rec { pname = "libunicap"; - version="0.9.12"; + version = "0.9.12"; src = fetchurl { url = "https://www.unicap-imaging.org/downloads/${pname}-${version}.tar.gz"; @@ -10,7 +20,13 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ intltool ]; - buildInputs = [ libusb-compat-0_1 libraw1394 dcraw perl v4l-utils ]; + buildInputs = [ + libusb-compat-0_1 + libraw1394 + dcraw + perl + v4l-utils + ]; patches = [ # Debian has a patch that fixes the build. diff --git a/pkgs/by-name/un/unicode-character-database/package.nix b/pkgs/by-name/un/unicode-character-database/package.nix index cf61d30108f44c..48e17bdd6654c1 100644 --- a/pkgs/by-name/un/unicode-character-database/package.nix +++ b/pkgs/by-name/un/unicode-character-database/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenvNoCC -, fetchurl -, unzip +{ + lib, + stdenvNoCC, + fetchurl, + unzip, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/un/unicode-emoji/package.nix b/pkgs/by-name/un/unicode-emoji/package.nix index b32cdc45d1d5c1..7751b455393a42 100644 --- a/pkgs/by-name/un/unicode-emoji/package.nix +++ b/pkgs/by-name/un/unicode-emoji/package.nix @@ -1,33 +1,36 @@ -{ lib -, stdenvNoCC -, fetchurl -, symlinkJoin +{ + lib, + stdenvNoCC, + fetchurl, + symlinkJoin, }: let version = "16.0"; - fetchData = { suffix, hash }: stdenvNoCC.mkDerivation { - pname = "unicode-emoji-${suffix}"; - inherit version; + fetchData = + { suffix, hash }: + stdenvNoCC.mkDerivation { + pname = "unicode-emoji-${suffix}"; + inherit version; - src = fetchurl { - url = "https://www.unicode.org/Public/emoji/${version}/emoji-${suffix}.txt"; - inherit hash; - }; + src = fetchurl { + url = "https://www.unicode.org/Public/emoji/${version}/emoji-${suffix}.txt"; + inherit hash; + }; - dontUnpack = true; + dontUnpack = true; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - installDir="$out/share/unicode/emoji" - mkdir -p "$installDir" - cp "$src" "$installDir/emoji-${suffix}.txt" + installDir="$out/share/unicode/emoji" + mkdir -p "$installDir" + cp "$src" "$installDir/emoji-${suffix}.txt" - runHook postInstall - ''; - }; + runHook postInstall + ''; + }; srcs = { emoji-sequences = fetchData { diff --git a/pkgs/by-name/un/unicode-paracode/package.nix b/pkgs/by-name/un/unicode-paracode/package.nix index 012ab2fc6cb733..f2d6e7cb8d29ce 100644 --- a/pkgs/by-name/un/unicode-paracode/package.nix +++ b/pkgs/by-name/un/unicode-paracode/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, fetchurl, python3Packages, installShellFiles, gitUpdater }: +{ + lib, + fetchFromGitHub, + fetchurl, + python3Packages, + installShellFiles, + gitUpdater, +}: python3Packages.buildPythonApplication rec { pname = "unicode"; diff --git a/pkgs/by-name/un/unicon-lang/package.nix b/pkgs/by-name/un/unicon-lang/package.nix index 4435b9c02925b3..21352007c9744a 100644 --- a/pkgs/by-name/un/unicon-lang/package.nix +++ b/pkgs/by-name/un/unicon-lang/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, unzip, libX11, libXt, libnsl, libxcrypt }: +{ + lib, + stdenv, + fetchurl, + unzip, + libX11, + libXt, + libnsl, + libxcrypt, +}: stdenv.mkDerivation { pname = "unicon-lang"; @@ -8,7 +17,12 @@ stdenv.mkDerivation { sha256 = "1g9l2dfp99dqih2ir2limqfjgagh3v9aqly6x0l3qavx3qkkwf61"; }; nativeBuildInputs = [ unzip ]; - buildInputs = [ libnsl libX11 libXt libxcrypt ]; + buildInputs = [ + libnsl + libX11 + libXt + libxcrypt + ]; hardeningDisable = [ "fortify" ]; diff --git a/pkgs/by-name/un/unifdef/package.nix b/pkgs/by-name/un/unifdef/package.nix index 76c3b7346011f3..d3a8bf96ae7435 100644 --- a/pkgs/by-name/un/unifdef/package.nix +++ b/pkgs/by-name/un/unifdef/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "unifdef"; diff --git a/pkgs/by-name/un/unifiedpush-common-proxies/package.nix b/pkgs/by-name/un/unifiedpush-common-proxies/package.nix index 0c0910893b9e5b..14952cad65667a 100644 --- a/pkgs/by-name/un/unifiedpush-common-proxies/package.nix +++ b/pkgs/by-name/un/unifiedpush-common-proxies/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { diff --git a/pkgs/by-name/un/unifont/package.nix b/pkgs/by-name/un/unifont/package.nix index 9eab69f1d33e97..91706d6b8464b1 100644 --- a/pkgs/by-name/un/unifont/package.nix +++ b/pkgs/by-name/un/unifont/package.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, fetchurl, xorg -, libfaketime +{ + lib, + stdenv, + fetchurl, + xorg, + libfaketime, }: stdenv.mkDerivation rec { @@ -16,30 +20,32 @@ stdenv.mkDerivation rec { hash = "sha256-51YEW6CJPuLoNpsnr8AkNr7ZApnbThZyznZuBHDNmCU="; }; - nativeBuildInputs = [ libfaketime xorg.fonttosfnt xorg.mkfontscale ]; + nativeBuildInputs = [ + libfaketime + xorg.fonttosfnt + xorg.mkfontscale + ]; dontUnpack = true; - buildPhase = - '' - # convert pcf font to otb - faketime -f "1970-01-01 00:00:01" \ - fonttosfnt -g 2 -m 2 -v -o "unifont.otb" "${pcf}" - ''; - - installPhase = - '' - # install otb fonts - install -m 644 -D unifont.otb "$out/share/fonts/unifont.otb" - mkfontdir "$out/share/fonts" - - # install pcf and otf fonts - install -m 644 -D ${pcf} $out/share/fonts/unifont.pcf.gz - install -m 644 -D ${otf} $out/share/fonts/opentype/unifont.otf - cd "$out/share/fonts" - mkfontdir - mkfontscale - ''; + buildPhase = '' + # convert pcf font to otb + faketime -f "1970-01-01 00:00:01" \ + fonttosfnt -g 2 -m 2 -v -o "unifont.otb" "${pcf}" + ''; + + installPhase = '' + # install otb fonts + install -m 644 -D unifont.otb "$out/share/fonts/unifont.otb" + mkfontdir "$out/share/fonts" + + # install pcf and otf fonts + install -m 644 -D ${pcf} $out/share/fonts/unifont.pcf.gz + install -m 644 -D ${otf} $out/share/fonts/opentype/unifont.otf + cd "$out/share/fonts" + mkfontdir + mkfontscale + ''; meta = with lib; { description = "Unicode font for Base Multilingual Plane"; diff --git a/pkgs/by-name/un/unifont_upper/package.nix b/pkgs/by-name/un/unifont_upper/package.nix index 0c2ac5e1603998..6b574dc9635870 100644 --- a/pkgs/by-name/un/unifont_upper/package.nix +++ b/pkgs/by-name/un/unifont_upper/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "unifont_upper"; diff --git a/pkgs/by-name/un/unigine-heaven/package.nix b/pkgs/by-name/un/unigine-heaven/package.nix index 96492ef9e61aa4..54557ca0631df6 100644 --- a/pkgs/by-name/un/unigine-heaven/package.nix +++ b/pkgs/by-name/un/unigine-heaven/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, libX11 -, libXext -, libXrandr -, freetype -, fontconfig -, libXrender -, libXinerama -, autoPatchelfHook -, libglvnd -, openal -, imagemagick -, makeDesktopItem +{ + lib, + stdenv, + fetchurl, + makeWrapper, + libX11, + libXext, + libXrandr, + freetype, + fontconfig, + libXrender, + libXinerama, + autoPatchelfHook, + libglvnd, + openal, + imagemagick, + makeDesktopItem, }: let version = "4.0"; @@ -34,8 +35,7 @@ let desktopName = "Heaven Benchmark"; }; in -stdenv.mkDerivation -{ +stdenv.mkDerivation { pname = "unigine-heaven"; inherit version; @@ -44,66 +44,65 @@ stdenv.mkDerivation sha256 = "19rndwwxnb9k2nw9h004hyrmr419471s0fp25yzvvc6rkd521c0v"; }; - installPhase = - '' - sh $src --target $name + installPhase = '' + sh $src --target $name - mkdir -p $out/lib/unigine/heaven/bin - mkdir -p $out/bin - mkdir -p $out/share/applications/ - mkdir -p $out/share/icons/hicolor + mkdir -p $out/lib/unigine/heaven/bin + mkdir -p $out/bin + mkdir -p $out/share/applications/ + mkdir -p $out/share/icons/hicolor - install -m 0755 $name/bin/browser_${arch} $out/lib/unigine/heaven/bin - install -m 0755 $name/bin/libApp{Stereo,Surround,Wall}_${arch}.so $out/lib/unigine/heaven/bin - install -m 0755 $name/bin/libGPUMonitor_${arch}.so $out/lib/unigine/heaven/bin - install -m 0755 $name/bin/libQt{Core,Gui,Network,WebKit,Xml}Unigine_${arch}.so.4 $out/lib/unigine/heaven/bin - install -m 0755 $name/bin/libUnigine_${arch}.so $out/lib/unigine/heaven/bin - install -m 0755 $name/bin/heaven_${arch} $out/lib/unigine/heaven/bin - install -m 0755 $name/heaven $out/bin/heaven + install -m 0755 $name/bin/browser_${arch} $out/lib/unigine/heaven/bin + install -m 0755 $name/bin/libApp{Stereo,Surround,Wall}_${arch}.so $out/lib/unigine/heaven/bin + install -m 0755 $name/bin/libGPUMonitor_${arch}.so $out/lib/unigine/heaven/bin + install -m 0755 $name/bin/libQt{Core,Gui,Network,WebKit,Xml}Unigine_${arch}.so.4 $out/lib/unigine/heaven/bin + install -m 0755 $name/bin/libUnigine_${arch}.so $out/lib/unigine/heaven/bin + install -m 0755 $name/bin/heaven_${arch} $out/lib/unigine/heaven/bin + install -m 0755 $name/heaven $out/bin/heaven - cp -R $name/data $name/documentation $out/lib/unigine/heaven + cp -R $name/data $name/documentation $out/lib/unigine/heaven - wrapProgram $out/bin/heaven --prefix LD_LIBRARY_PATH : ${libglvnd}/lib:$out/bin:${openal}/lib --run "cd $out/lib/unigine/heaven/" + wrapProgram $out/bin/heaven --prefix LD_LIBRARY_PATH : ${libglvnd}/lib:$out/bin:${openal}/lib --run "cd $out/lib/unigine/heaven/" - convert $out/lib/unigine/heaven/data/launcher/icon.png -resize 128x128 $out/share/icons/Heaven.png - for RES in 16 24 32 48 64 128 256 - do - mkdir -p $out/share/icons/hicolor/"$RES"x"$RES"/apps - convert $out/lib/unigine/heaven/data/launcher/icon.png -resize "$RES"x"$RES" $out/share/icons/hicolor/"$RES"x"$RES"/apps/Heaven.png - done + convert $out/lib/unigine/heaven/data/launcher/icon.png -resize 128x128 $out/share/icons/Heaven.png + for RES in 16 24 32 48 64 128 256 + do + mkdir -p $out/share/icons/hicolor/"$RES"x"$RES"/apps + convert $out/lib/unigine/heaven/data/launcher/icon.png -resize "$RES"x"$RES" $out/share/icons/hicolor/"$RES"x"$RES"/apps/Heaven.png + done - ln -s ${desktopItem}/share/applications/* $out/share/applications - ''; + ln -s ${desktopItem}/share/applications/* $out/share/applications + ''; - nativeBuildInputs = - [ - autoPatchelfHook - makeWrapper - imagemagick - ]; + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + imagemagick + ]; - buildInputs = - [ - libX11 - stdenv.cc.cc - libXext - libXrandr - freetype - fontconfig - libXrender - libXinerama - ]; + buildInputs = [ + libX11 + stdenv.cc.cc + libXext + libXrandr + freetype + fontconfig + libXrender + libXinerama + ]; dontUnpack = true; - meta = - { - description = "Unigine Heaven GPU benchmarking tool"; - homepage = "https://benchmark.unigine.com/heaven"; - sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; - license = lib.licenses.unfree; - maintainers = [ lib.maintainers.BarinovMaxim ]; - platforms = [ "x86_64-linux" "i686-linux" ]; - mainProgram = "heaven"; - }; + meta = { + description = "Unigine Heaven GPU benchmarking tool"; + homepage = "https://benchmark.unigine.com/heaven"; + sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; + license = lib.licenses.unfree; + maintainers = [ lib.maintainers.BarinovMaxim ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; + mainProgram = "heaven"; + }; } diff --git a/pkgs/by-name/un/unigine-valley/package.nix b/pkgs/by-name/un/unigine-valley/package.nix index b64f136629eddd..1d6625cbc727ad 100644 --- a/pkgs/by-name/un/unigine-valley/package.nix +++ b/pkgs/by-name/un/unigine-valley/package.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, # Build-time dependencies -, makeWrapper -, file -, makeDesktopItem -, imagemagick -, copyDesktopItems + makeWrapper, + file, + makeDesktopItem, + imagemagick, + copyDesktopItems, # Runtime dependencies -, fontconfig -, freetype -, libX11 -, libXext -, libXinerama -, libXrandr -, libXrender -, libglvnd -, openal + fontconfig, + freetype, + libX11, + libXext, + libXinerama, + libXrandr, + libXrender, + libglvnd, + openal, }: let @@ -45,7 +46,12 @@ stdenv.mkDerivation rec { sourceRoot = "Unigine_Valley-${version}"; instPath = "lib/unigine/valley"; - nativeBuildInputs = [ file makeWrapper imagemagick copyDesktopItems ]; + nativeBuildInputs = [ + file + makeWrapper + imagemagick + copyDesktopItems + ]; libPath = lib.makeLibraryPath [ stdenv.cc.cc # libstdc++.so.6 @@ -131,8 +137,10 @@ stdenv.mkDerivation rec { sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; license = lib.licenses.unfree; # see also: $out/$instPath/documentation/License.pdf maintainers = [ ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; mainProgram = "valley"; }; } - diff --git a/pkgs/by-name/un/unihan-database/package.nix b/pkgs/by-name/un/unihan-database/package.nix index 362507fc5cbaf9..1cabda4b99ddc6 100644 --- a/pkgs/by-name/un/unihan-database/package.nix +++ b/pkgs/by-name/un/unihan-database/package.nix @@ -1,6 +1,8 @@ -{ lib, stdenv -, fetchurl -, unzip +{ + lib, + stdenv, + fetchurl, + unzip, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/un/unimap/package.nix b/pkgs/by-name/un/unimap/package.nix index eafe26962cec12..497158b1ce6b42 100644 --- a/pkgs/by-name/un/unimap/package.nix +++ b/pkgs/by-name/un/unimap/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, makeBinaryWrapper -, stdenv -, pkg-config -, openssl -, nmap +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + makeBinaryWrapper, + stdenv, + pkg-config, + openssl, + nmap, }: rustPlatform.buildRustPackage rec { @@ -27,12 +28,14 @@ rustPlatform.buildRustPackage rec { }; }; - nativeBuildInputs = [ - installShellFiles - makeBinaryWrapper - ] ++ lib.optionals (stdenv.hostPlatform.isAarch && stdenv.hostPlatform.isLinux) [ - pkg-config - ]; + nativeBuildInputs = + [ + installShellFiles + makeBinaryWrapper + ] + ++ lib.optionals (stdenv.hostPlatform.isAarch && stdenv.hostPlatform.isLinux) [ + pkg-config + ]; # only depends on openssl on aarch/arm linux buildInputs = lib.optionals (stdenv.hostPlatform.isAarch && stdenv.hostPlatform.isLinux) [ diff --git a/pkgs/by-name/un/unimatrix/package.nix b/pkgs/by-name/un/unimatrix/package.nix index 0b57d915cefb7e..69ff40f2c2f023 100644 --- a/pkgs/by-name/un/unimatrix/package.nix +++ b/pkgs/by-name/un/unimatrix/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/un/unionfs-fuse/package.nix b/pkgs/by-name/un/unionfs-fuse/package.nix index 6f55dbe426a69f..fe9b3ff7fd331a 100644 --- a/pkgs/by-name/un/unionfs-fuse/package.nix +++ b/pkgs/by-name/un/unionfs-fuse/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, fuse }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fuse, +}: stdenv.mkDerivation rec { pname = "unionfs-fuse"; diff --git a/pkgs/by-name/un/unison-ucm/package.nix b/pkgs/by-name/un/unison-ucm/package.nix index 9926677fe2a2e2..088da637033363 100644 --- a/pkgs/by-name/un/unison-ucm/package.nix +++ b/pkgs/by-name/un/unison-ucm/package.nix @@ -1,43 +1,51 @@ -{ lib -, autoPatchelfHook -, fetchurl -, gmp -, less -, makeWrapper -, libb2 -, ncurses6 -, openssl -, stdenv -, zlib +{ + lib, + autoPatchelfHook, + fetchurl, + gmp, + less, + makeWrapper, + libb2, + ncurses6, + openssl, + stdenv, + zlib, }: stdenv.mkDerivation (finalAttrs: { pname = "unison-code-manager"; version = "0.5.29"; - src = { - aarch64-darwin = fetchurl { - url = "https://github.com/unisonweb/unison/releases/download/release/${finalAttrs.version}/ucm-macos-arm64.tar.gz"; - hash = "sha256-iSyhPCn8+u/kKW1NVorUaRXaP0Q771m6G1ICsHp1/Rs="; - }; - x86_64-darwin = fetchurl { - url = "https://github.com/unisonweb/unison/releases/download/release/${finalAttrs.version}/ucm-macos-x64.tar.gz"; - hash = "sha256-Rukx1I67jq78xvDB7eYP6TvZZBZtWisOv2WZe6/KlHE="; - }; - x86_64-linux = fetchurl { - url = "https://github.com/unisonweb/unison/releases/download/release/${finalAttrs.version}/ucm-linux-x64.tar.gz"; - hash = "sha256-fVsKPTi9j+LVWDPhuHYb7NKD2JXJz7nRE6yuE7rQ3e0="; - }; - }.${stdenv.hostPlatform.system} or (throw "Unsupported platform ${stdenv.hostPlatform.system}"); + src = + { + aarch64-darwin = fetchurl { + url = "https://github.com/unisonweb/unison/releases/download/release/${finalAttrs.version}/ucm-macos-arm64.tar.gz"; + hash = "sha256-iSyhPCn8+u/kKW1NVorUaRXaP0Q771m6G1ICsHp1/Rs="; + }; + x86_64-darwin = fetchurl { + url = "https://github.com/unisonweb/unison/releases/download/release/${finalAttrs.version}/ucm-macos-x64.tar.gz"; + hash = "sha256-Rukx1I67jq78xvDB7eYP6TvZZBZtWisOv2WZe6/KlHE="; + }; + x86_64-linux = fetchurl { + url = "https://github.com/unisonweb/unison/releases/download/release/${finalAttrs.version}/ucm-linux-x64.tar.gz"; + hash = "sha256-fVsKPTi9j+LVWDPhuHYb7NKD2JXJz7nRE6yuE7rQ3e0="; + }; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported platform ${stdenv.hostPlatform.system}"); # The tarball is just the prebuilt binary, in the archive root. sourceRoot = "."; dontBuild = true; dontConfigure = true; - nativeBuildInputs = [ makeWrapper ] - ++ lib.optional (!stdenv.hostPlatform.isDarwin) autoPatchelfHook; - buildInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ gmp ncurses6 zlib ]; + nativeBuildInputs = [ + makeWrapper + ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) autoPatchelfHook; + buildInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ + gmp + ncurses6 + zlib + ]; installPhase = '' mkdir -p $out/{bin,lib} @@ -45,7 +53,12 @@ stdenv.mkDerivation (finalAttrs: { mv ui $out/ui mv unison $out/unison makeWrapper $out/unison/unison $out/bin/ucm \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ libb2 openssl ]} \ + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + libb2 + openssl + ] + } \ --prefix PATH ":" "${lib.makeBinPath [ less ]}" \ --add-flags "--runtime-path $out/lib/runtime/bin/unison-runtime" \ --set UCM_WEB_UI "$out/ui" @@ -54,10 +67,21 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Modern, statically-typed purely functional language"; homepage = "https://unisonweb.org/"; - license = with licenses; [ mit bsd3 ]; + license = with licenses; [ + mit + bsd3 + ]; mainProgram = "ucm"; - maintainers = with maintainers; [ ceedubs sellout virusdave ]; - platforms = [ "x86_64-darwin" "x86_64-linux" "aarch64-darwin" ]; + maintainers = with maintainers; [ + ceedubs + sellout + virusdave + ]; + platforms = [ + "x86_64-darwin" + "x86_64-linux" + "aarch64-darwin" + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; }) diff --git a/pkgs/by-name/un/unit/package.nix b/pkgs/by-name/un/unit/package.nix index 266687920ce87a..94247dc399bbdf 100644 --- a/pkgs/by-name/un/unit/package.nix +++ b/pkgs/by-name/un/unit/package.nix @@ -1,14 +1,27 @@ -{ lib, stdenv, fetchFromGitHub, nixosTests, which -, pcre2 -, withPython3 ? true, python3, ncurses -, withPHP81 ? true, php81 -, withPHP82 ? false, php82 -, withPerl ? true, perl -, withRuby_3_1 ? true, ruby_3_1 -, withRuby_3_2 ? false, ruby_3_2 -, withSSL ? true, openssl ? null -, withIPv6 ? true -, withDebug ? false +{ + lib, + stdenv, + fetchFromGitHub, + nixosTests, + which, + pcre2, + withPython3 ? true, + python3, + ncurses, + withPHP81 ? true, + php81, + withPHP82 ? false, + php82, + withPerl ? true, + perl, + withRuby_3_1 ? true, + ruby_3_1, + withRuby_3_2 ? false, + ruby_3_2, + withSSL ? true, + openssl ? null, + withIPv6 ? true, + withDebug ? false, }: let @@ -25,7 +38,8 @@ let php82-unit = php82.override phpConfig; inherit (lib) optional optionals optionalString; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { version = "1.33.0"; pname = "unit"; @@ -38,8 +52,12 @@ in stdenv.mkDerivation rec { nativeBuildInputs = [ which ]; - buildInputs = [ pcre2.dev ] - ++ optionals withPython3 [ python3 ncurses ] + buildInputs = + [ pcre2.dev ] + ++ optionals withPython3 [ + python3 + ncurses + ] ++ optional withPHP81 php81-unit ++ optional withPHP82 php82-unit ++ optional withPerl perl @@ -47,25 +65,27 @@ in stdenv.mkDerivation rec { ++ optional withRuby_3_2 ruby_3_2 ++ optional withSSL openssl; - configureFlags = [ - "--control=unix:/run/unit/control.unit.sock" - "--pid=/run/unit/unit.pid" - "--user=unit" - "--group=unit" - ] ++ optional withSSL "--openssl" + configureFlags = + [ + "--control=unix:/run/unit/control.unit.sock" + "--pid=/run/unit/unit.pid" + "--user=unit" + "--group=unit" + ] + ++ optional withSSL "--openssl" ++ optional (!withIPv6) "--no-ipv6" - ++ optional withDebug "--debug"; + ++ optional withDebug "--debug"; # Optionally add the PHP derivations used so they can be addressed in the configs usedPhp81 = optionals withPHP81 php81-unit; postConfigure = '' - ${optionalString withPython3 "./configure python --module=python3 --config=python3-config --lib-path=${python3}/lib"} - ${optionalString withPHP81 "./configure php --module=php81 --config=${php81-unit.unwrapped.dev}/bin/php-config --lib-path=${php81-unit}/lib"} - ${optionalString withPHP82 "./configure php --module=php82 --config=${php82-unit.unwrapped.dev}/bin/php-config --lib-path=${php82-unit}/lib"} - ${optionalString withPerl "./configure perl --module=perl --perl=${perl}/bin/perl"} - ${optionalString withRuby_3_1 "./configure ruby --module=ruby31 --ruby=${ruby_3_1}/bin/ruby"} - ${optionalString withRuby_3_2 "./configure ruby --module=ruby32 --ruby=${ruby_3_2}/bin/ruby"} + ${optionalString withPython3 "./configure python --module=python3 --config=python3-config --lib-path=${python3}/lib"} + ${optionalString withPHP81 "./configure php --module=php81 --config=${php81-unit.unwrapped.dev}/bin/php-config --lib-path=${php81-unit}/lib"} + ${optionalString withPHP82 "./configure php --module=php82 --config=${php82-unit.unwrapped.dev}/bin/php-config --lib-path=${php82-unit}/lib"} + ${optionalString withPerl "./configure perl --module=perl --perl=${perl}/bin/perl"} + ${optionalString withRuby_3_1 "./configure ruby --module=ruby31 --ruby=${ruby_3_1}/bin/ruby"} + ${optionalString withRuby_3_2 "./configure ruby --module=ruby32 --ruby=${ruby_3_2}/bin/ruby"} ''; passthru.tests = { @@ -76,9 +96,9 @@ in stdenv.mkDerivation rec { meta = with lib; { description = "Dynamic web and application server, designed to run applications in multiple languages"; mainProgram = "unitd"; - homepage = "https://unit.nginx.org/"; - license = licenses.asl20; - platforms = platforms.linux; + homepage = "https://unit.nginx.org/"; + license = licenses.asl20; + platforms = platforms.linux; maintainers = with maintainers; [ izorkin ]; }; } diff --git a/pkgs/by-name/un/units/package.nix b/pkgs/by-name/un/units/package.nix index dde43648cd7305..3166ab7097efe9 100644 --- a/pkgs/by-name/un/units/package.nix +++ b/pkgs/by-name/un/units/package.nix @@ -1,16 +1,18 @@ -{ lib -, fetchurl -, python3 -, readline -, stdenv -, enableCurrenciesUpdater ? true +{ + lib, + fetchurl, + python3, + readline, + stdenv, + enableCurrenciesUpdater ? true, }: let - pythonEnv = python3.withPackages(p: [ + pythonEnv = python3.withPackages (p: [ p.requests ]); -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "units"; version = "2.23"; @@ -19,14 +21,20 @@ in stdenv.mkDerivation (finalAttrs: { hash = "sha256-2Ve0USRZJcnmFMRRM5dEljDq+SvWK4SVugm741Ghc3A="; }; - outputs = [ "out" "info" "man" ]; - - buildInputs = [ - readline - ] ++ lib.optionals enableCurrenciesUpdater [ - pythonEnv + outputs = [ + "out" + "info" + "man" ]; + buildInputs = + [ + readline + ] + ++ lib.optionals enableCurrenciesUpdater [ + pythonEnv + ]; + prePatch = lib.optionalString enableCurrenciesUpdater '' substituteInPlace units_cur \ --replace "#!/usr/bin/env python" ${pythonEnv}/bin/python diff --git a/pkgs/by-name/un/unittest-cpp/package.nix b/pkgs/by-name/un/unittest-cpp/package.nix index 04d33b66e5a993..58f859ae43eabf 100644 --- a/pkgs/by-name/un/unittest-cpp/package.nix +++ b/pkgs/by-name/un/unittest-cpp/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/un/universal-ctags/package.nix b/pkgs/by-name/un/universal-ctags/package.nix index eda2fc6a817632..abc808c3ba45a8 100644 --- a/pkgs/by-name/un/universal-ctags/package.nix +++ b/pkgs/by-name/un/universal-ctags/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, autoreconfHook -, buildPackages -, coreutils -, fetchFromGitHub -, jansson -, libiconv -, perl -, pkg-config -, python3 -, libseccomp -, libyaml -, pcre2 -, libxml2 +{ + lib, + stdenv, + autoreconfHook, + buildPackages, + coreutils, + fetchFromGitHub, + jansson, + libiconv, + perl, + pkg-config, + python3, + libseccomp, + libyaml, + pcre2, + libxml2, }: stdenv.mkDerivation (finalAttrs: { @@ -37,14 +38,15 @@ stdenv.mkDerivation (finalAttrs: { (python3.withPackages (p: [ p.docutils ])) ]; - buildInputs = [ - libyaml - pcre2 - libxml2 - jansson - ] - ++ lib.optional stdenv.hostPlatform.isDarwin libiconv - ++ lib.optional stdenv.hostPlatform.isLinux libseccomp; + buildInputs = + [ + libyaml + pcre2 + libxml2 + jansson + ] + ++ lib.optional stdenv.hostPlatform.isDarwin libiconv + ++ lib.optional stdenv.hostPlatform.isLinux libseccomp; configureFlags = [ "--enable-tmpdir=/tmp" ]; @@ -68,7 +70,11 @@ stdenv.mkDerivation (finalAttrs: { doCheck = true; checkFlags = [ - "man-test" "tlib" "tmain" "tutil" "units" + "man-test" + "tlib" + "tmain" + "tutil" + "units" ]; meta = with lib; { diff --git a/pkgs/by-name/un/unix-privesc-check/package.nix b/pkgs/by-name/un/unix-privesc-check/package.nix index 5ac7a6d29de1ab..aacd8e29394f2d 100644 --- a/pkgs/by-name/un/unix-privesc-check/package.nix +++ b/pkgs/by-name/un/unix-privesc-check/package.nix @@ -1,21 +1,22 @@ -{ lib -, resholve -, fetchurl -, gawk -, bash -, binutils -, coreutils -, file -, findutils -, glibc -, gnugrep -, gnused -, nettools -, openssh -, postgresql -, ps -, util-linux -, which +{ + lib, + resholve, + fetchurl, + gawk, + bash, + binutils, + coreutils, + file, + findutils, + glibc, + gnugrep, + gnused, + nettools, + openssh, + postgresql, + ps, + util-linux, + which, }: # resholve does not yet support `finalAttrs` call pattern hence `rec` @@ -44,7 +45,7 @@ resholve.mkDerivation rec { coreutils file findutils # for xargs command - glibc # for ldd command + glibc # for ldd command gnugrep gnused nettools @@ -56,9 +57,9 @@ resholve.mkDerivation rec { ]; fake = { external = [ - "lanscan" # lanscan exists only for HP-UX OS - "mount" # Getting same error described in https://github.com/abathur/resholve/issues/29 - "passwd" # Getting same error described in https://github.com/abathur/resholve/issues/29 + "lanscan" # lanscan exists only for HP-UX OS + "mount" # Getting same error described in https://github.com/abathur/resholve/issues/29 + "passwd" # Getting same error described in https://github.com/abathur/resholve/issues/29 ]; }; execer = [ diff --git a/pkgs/by-name/un/unixODBC/package.nix b/pkgs/by-name/un/unixODBC/package.nix index 8587ad6d2c3c17..62787cb2228b8f 100644 --- a/pkgs/by-name/un/unixODBC/package.nix +++ b/pkgs/by-name/un/unixODBC/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "unixODBC"; @@ -12,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-8hBQFEXOIb9ge6Ue+MEl4Q4i3/3/7Dd2RkYt9fAZFew="; }; - configureFlags = [ "--disable-gui" "--sysconfdir=/etc" ]; + configureFlags = [ + "--disable-gui" + "--sysconfdir=/etc" + ]; meta = with lib; { description = "ODBC driver manager for Unix"; diff --git a/pkgs/by-name/un/unixbench/package.nix b/pkgs/by-name/un/unixbench/package.nix index 7721a2648b359c..52ccbc26a416d5 100644 --- a/pkgs/by-name/un/unixbench/package.nix +++ b/pkgs/by-name/un/unixbench/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, pandoc -, installShellFiles -, perl -, xorg -, libGLX -, coreutils -, unixtools -, runtimeShell -, targetPackages -, gnugrep -, gawk -, withGL? true -, withX11perf? true +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + pandoc, + installShellFiles, + perl, + xorg, + libGLX, + coreutils, + unixtools, + runtimeShell, + targetPackages, + gnugrep, + gawk, + withGL ? true, + withX11perf ? true, }: stdenv.mkDerivation rec { @@ -47,28 +48,34 @@ stdenv.mkDerivation rec { installShellFiles ]; - buildInputs = [ perl ] ++ lib.optionals withGL [ - xorg.libX11 - xorg.libXext - libGLX - ]; - - runtimeDependencies = [ - coreutils - unixtools.nettools - unixtools.locale - targetPackages.stdenv.cc - gnugrep - gawk - ] ++ lib.optionals withX11perf [ - xorg.x11perf - ]; - - makeFlags = [ - "CC=${stdenv.cc.targetPrefix}cc" - ] ++ lib.optionals withGL [ - "GRAPHIC_TESTS=defined" - ]; + buildInputs = + [ perl ] + ++ lib.optionals withGL [ + xorg.libX11 + xorg.libXext + libGLX + ]; + + runtimeDependencies = + [ + coreutils + unixtools.nettools + unixtools.locale + targetPackages.stdenv.cc + gnugrep + gawk + ] + ++ lib.optionals withX11perf [ + xorg.x11perf + ]; + + makeFlags = + [ + "CC=${stdenv.cc.targetPrefix}cc" + ] + ++ lib.optionals withGL [ + "GRAPHIC_TESTS=defined" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/un/unnaturalscrollwheels/package.nix b/pkgs/by-name/un/unnaturalscrollwheels/package.nix index e47d550538657c..99645317ce2326 100644 --- a/pkgs/by-name/un/unnaturalscrollwheels/package.nix +++ b/pkgs/by-name/un/unnaturalscrollwheels/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, _7zz +{ + lib, + stdenvNoCC, + fetchurl, + _7zz, }: stdenvNoCC.mkDerivation (finalAttrs: { pname = "unnaturalscrollwheels"; diff --git a/pkgs/by-name/un/unnethack/package.nix b/pkgs/by-name/un/unnethack/package.nix index 15c5b1a81ebc05..892f29b8227261 100644 --- a/pkgs/by-name/un/unnethack/package.nix +++ b/pkgs/by-name/un/unnethack/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, util-linux, ncurses, flex, bison }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + util-linux, + ncurses, + flex, + bison, +}: stdenv.mkDerivation rec { pname = "unnethack"; @@ -14,14 +23,19 @@ stdenv.mkDerivation rec { buildInputs = [ ncurses ]; - nativeBuildInputs = [ util-linux flex bison ]; + nativeBuildInputs = [ + util-linux + flex + bison + ]; - configureFlags = [ "--enable-curses-graphics" - "--disable-tty-graphics" - "--with-owner=no" - "--with-group=no" - "--with-gamesdir=/tmp/unnethack" - ]; + configureFlags = [ + "--enable-curses-graphics" + "--disable-tty-graphics" + "--with-owner=no" + "--with-group=no" + "--with-gamesdir=/tmp/unnethack" + ]; makeFlags = [ "GAMEPERM=744" ]; patches = [ diff --git a/pkgs/by-name/un/unoconv/package.nix b/pkgs/by-name/un/unoconv/package.nix index 81e97d1a13fdec..0291fc19c1dd7a 100644 --- a/pkgs/by-name/un/unoconv/package.nix +++ b/pkgs/by-name/un/unoconv/package.nix @@ -1,6 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libreoffice-unwrapped, asciidoc, makeWrapper -# whether to install odt2pdf/odt2doc/... symlinks to unoconv -, installSymlinks ? true +{ + lib, + stdenv, + fetchFromGitHub, + libreoffice-unwrapped, + asciidoc, + makeWrapper, + # whether to install odt2pdf/odt2doc/... symlinks to unoconv + installSymlinks ? true, }: stdenv.mkDerivation rec { @@ -14,19 +20,24 @@ stdenv.mkDerivation rec { sha256 = "1akx64686in8j8arl6vsgp2n3bv770q48pfv283c6fz6wf9p8fvr"; }; - nativeBuildInputs = [ asciidoc makeWrapper ]; + nativeBuildInputs = [ + asciidoc + makeWrapper + ]; preBuild = '' makeFlags=prefix="$out" ''; - postInstall = '' - sed -i "s|/usr/bin/env python.*|${libreoffice-unwrapped.python.interpreter}|" "$out/bin/unoconv" - wrapProgram "$out/bin/unoconv" \ - --set-default UNO_PATH "${libreoffice-unwrapped}/lib/libreoffice/program/" - '' + lib.optionalString installSymlinks '' - make install-links prefix="$out" - ''; + postInstall = + '' + sed -i "s|/usr/bin/env python.*|${libreoffice-unwrapped.python.interpreter}|" "$out/bin/unoconv" + wrapProgram "$out/bin/unoconv" \ + --set-default UNO_PATH "${libreoffice-unwrapped}/lib/libreoffice/program/" + '' + + lib.optionalString installSymlinks '' + make install-links prefix="$out" + ''; meta = with lib; { description = "Convert between any document format supported by LibreOffice/OpenOffice"; diff --git a/pkgs/by-name/un/unp/package.nix b/pkgs/by-name/un/unp/package.nix index c11a21d05968fb..8c5f1e48c2a479 100644 --- a/pkgs/by-name/un/unp/package.nix +++ b/pkgs/by-name/un/unp/package.nix @@ -1,13 +1,25 @@ -{ stdenv, lib, fetchurl, makeWrapper, perl -, unzip, gzip, file -# extractors which are added to unp’s PATH -, extraBackends ? [] +{ + stdenv, + lib, + fetchurl, + makeWrapper, + perl, + unzip, + gzip, + file, + # extractors which are added to unp’s PATH + extraBackends ? [ ], }: let - runtime_bins = [ file unzip gzip ] ++ extraBackends; + runtime_bins = [ + file + unzip + gzip + ] ++ extraBackends; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "unp"; version = "2.0-pre9"; nativeBuildInputs = [ makeWrapper ]; @@ -22,16 +34,16 @@ in stdenv.mkDerivation { dontConfigure = true; dontBuild = true; installPhase = '' - mkdir -p $out/bin - mkdir -p $out/share/man/man1 - install ./unp $out/bin/unp - install ./ucat $out/bin/ucat - cp debian/unp.1 $out/share/man/man1 + mkdir -p $out/bin + mkdir -p $out/share/man/man1 + install ./unp $out/bin/unp + install ./ucat $out/bin/ucat + cp debian/unp.1 $out/share/man/man1 - wrapProgram $out/bin/unp \ - --prefix PATH : ${lib.makeBinPath runtime_bins} - wrapProgram $out/bin/ucat \ - --prefix PATH : ${lib.makeBinPath runtime_bins} + wrapProgram $out/bin/unp \ + --prefix PATH : ${lib.makeBinPath runtime_bins} + wrapProgram $out/bin/ucat \ + --prefix PATH : ${lib.makeBinPath runtime_bins} ''; meta = with lib; { diff --git a/pkgs/by-name/un/unpaper/package.nix b/pkgs/by-name/un/unpaper/package.nix index dc38c55397a2d7..d88104d2f37968 100644 --- a/pkgs/by-name/un/unpaper/package.nix +++ b/pkgs/by-name/un/unpaper/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, -# build -, meson -, ninja -, pkg-config + # build + meson, + ninja, + pkg-config, -# docs -, sphinx + # docs + sphinx, -# runtime -, buildPackages -, ffmpeg-headless + # runtime + buildPackages, + ffmpeg-headless, -# tests -, nixosTests + # tests + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/un/unparam/package.nix b/pkgs/by-name/un/unparam/package.nix index 535617b1f12ea6..2f36ffff605cb5 100644 --- a/pkgs/by-name/un/unparam/package.nix +++ b/pkgs/by-name/un/unparam/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/un/unpfs/package.nix b/pkgs/by-name/un/unpfs/package.nix index 4c879a14c9e332..575bb15f1bc251 100644 --- a/pkgs/by-name/un/unpfs/package.nix +++ b/pkgs/by-name/un/unpfs/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "unpfs"; diff --git a/pkgs/by-name/un/unpoller/package.nix b/pkgs/by-name/un/unpoller/package.nix index 5cae8fbc7982ba..78ce18cb6eeaa3 100644 --- a/pkgs/by-name/un/unpoller/package.nix +++ b/pkgs/by-name/un/unpoller/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { @@ -18,7 +19,8 @@ buildGoModule rec { vendorHash = "sha256-d7kkdiGMT3bN1dfNo8m+zp3VY8kaZM2BWO3B3iAdUQY="; ldflags = [ - "-w" "-s" + "-w" + "-s" "-X github.com/prometheus/common/version.Branch=master" "-X github.com/prometheus/common/version.BuildDate=unknown" "-X github.com/prometheus/common/version.Revision=${src.rev}" diff --git a/pkgs/by-name/un/unrar-free/package.nix b/pkgs/by-name/un/unrar-free/package.nix index de058108efaecd..87cfafc7468e04 100644 --- a/pkgs/by-name/un/unrar-free/package.nix +++ b/pkgs/by-name/un/unrar-free/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitLab -, autoreconfHook -, libarchive -, pkg-config +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + libarchive, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { @@ -17,7 +18,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-Dg+KGZcqbE1nBPaemZlWQPaUQQJmaSe0nyDQRXJzwuE="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libarchive ]; diff --git a/pkgs/by-name/un/unrar_6/package.nix b/pkgs/by-name/un/unrar_6/package.nix index 5f2248ce847e0b..7df1d865d9cdd2 100644 --- a/pkgs/by-name/un/unrar_6/package.nix +++ b/pkgs/by-name/un/unrar_6/package.nix @@ -1,15 +1,18 @@ -{ unrar -, fetchzip +{ + unrar, + fetchzip, }: -unrar.overrideAttrs (finalAttrs: _: { - version = "6.2.12"; +unrar.overrideAttrs ( + finalAttrs: _: { + version = "6.2.12"; - src = fetchzip { - url = "https://www.rarlab.com/rar/unrarsrc-${finalAttrs.version}.tar.gz"; - stripRoot = false; - hash = "sha256-VAL3o9JGmkAcEssa/P/SL9nyxnigb7dX9YZBHrG9f0A="; - }; + src = fetchzip { + url = "https://www.rarlab.com/rar/unrarsrc-${finalAttrs.version}.tar.gz"; + stripRoot = false; + hash = "sha256-VAL3o9JGmkAcEssa/P/SL9nyxnigb7dX9YZBHrG9f0A="; + }; - sourceRoot = finalAttrs.src.name; -}) + sourceRoot = finalAttrs.src.name; + } +) diff --git a/pkgs/by-name/un/unrtf/package.nix b/pkgs/by-name/un/unrtf/package.nix index 5e6766e4db9425..0359448a9c6061 100644 --- a/pkgs/by-name/un/unrtf/package.nix +++ b/pkgs/by-name/un/unrtf/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, autoconf, automake, libiconv }: +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + libiconv, +}: stdenv.mkDerivation rec { pname = "unrtf"; @@ -9,13 +16,19 @@ stdenv.mkDerivation rec { sha256 = "1bil6z4niydz9gqm2j861dkxmqnpc8m7hvidsjbzz7x63whj17xl"; }; - nativeBuildInputs = [ autoconf automake ]; + nativeBuildInputs = [ + autoconf + automake + ]; buildInputs = [ libiconv ]; preConfigure = "./bootstrap"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; meta = with lib; { description = "Converter from Rich Text Format to other formats"; diff --git a/pkgs/by-name/un/unscd/package.nix b/pkgs/by-name/un/unscd/package.nix index e38421071422da..422f9e9d3199b8 100644 --- a/pkgs/by-name/un/unscd/package.nix +++ b/pkgs/by-name/un/unscd/package.nix @@ -1,4 +1,10 @@ -{ fetchurl, fetchpatch, stdenv, systemd, lib }: +{ + fetchurl, + fetchpatch, + stdenv, + systemd, + lib, +}: stdenv.mkDerivation rec { pname = "unscd"; diff --git a/pkgs/by-name/un/unscii/package.nix b/pkgs/by-name/un/unscii/package.nix index 1b723cd313da0a..b622a5fd95cc1e 100644 --- a/pkgs/by-name/un/unscii/package.nix +++ b/pkgs/by-name/un/unscii/package.nix @@ -1,11 +1,21 @@ -{ lib, stdenv, fetchurl, perl, bdftopcf -, fontforge, SDL, SDL_image, mkfontscale +{ + lib, + stdenv, + fetchurl, + perl, + bdftopcf, + fontforge, + SDL, + SDL_image, + mkfontscale, }: let - perlenv = perl.withPackages (p: with p; [ - TextCharWidth - ]); + perlenv = perl.withPackages ( + p: with p; [ + TextCharWidth + ] + ); in stdenv.mkDerivation rec { pname = "unscii"; @@ -16,11 +26,14 @@ stdenv.mkDerivation rec { sha256 = "0msvqrq7x36p76a2n5bzkadh95z954ayqa08wxd017g4jpa1a4jd"; }; - nativeBuildInputs = - [ perlenv - bdftopcf fontforge SDL SDL_image - mkfontscale - ]; + nativeBuildInputs = [ + perlenv + bdftopcf + fontforge + SDL + SDL_image + mkfontscale + ]; # Fixes shebang -> wrapper problem on Darwin postPatch = '' @@ -58,7 +71,10 @@ stdenv.mkDerivation rec { mkfontscale "$extra"/share/fonts/* ''; - outputs = [ "out" "extra" ]; + outputs = [ + "out" + "extra" + ]; meta = { description = "Bitmapped character-art-friendly Unicode fonts"; diff --git a/pkgs/by-name/un/unshield/package.nix b/pkgs/by-name/un/unshield/package.nix index 50d93fea99ff22..e3f2ff9be84513 100644 --- a/pkgs/by-name/un/unshield/package.nix +++ b/pkgs/by-name/un/unshield/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, zlib, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, + openssl, +}: stdenv.mkDerivation rec { pname = "unshield"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ zlib openssl ]; + buildInputs = [ + zlib + openssl + ]; meta = with lib; { description = "Tool and library to extract CAB files from InstallShield installers"; diff --git a/pkgs/by-name/un/unsilence/package.nix b/pkgs/by-name/un/unsilence/package.nix index d8bc2237e2d51d..a746adf6bd92f4 100644 --- a/pkgs/by-name/un/unsilence/package.nix +++ b/pkgs/by-name/un/unsilence/package.nix @@ -1,8 +1,8 @@ -{ lib -, fetchFromGitHub -, python3Packages -, ffmpeg -, +{ + lib, + fetchFromGitHub, + python3Packages, + ffmpeg, }: python3Packages.buildPythonPackage rec { pname = "unsilence"; diff --git a/pkgs/by-name/un/unstick/package.nix b/pkgs/by-name/un/unstick/package.nix index 3c61e26b335ba2..91eb9616a2c6a4 100644 --- a/pkgs/by-name/un/unstick/package.nix +++ b/pkgs/by-name/un/unstick/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, meson, ninja, pkg-config, libseccomp }: +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + libseccomp, +}: stdenv.mkDerivation rec { pname = "unstick"; @@ -13,7 +21,11 @@ stdenv.mkDerivation rec { sourceRoot = "${src.name}/src"; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; buildInputs = [ libseccomp ]; meta = { diff --git a/pkgs/by-name/un/untex/package.nix b/pkgs/by-name/un/untex/package.nix index cb4c0e4fcb9e66..282c5e13eb350f 100644 --- a/pkgs/by-name/un/untex/package.nix +++ b/pkgs/by-name/un/untex/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "untex"; @@ -12,8 +16,14 @@ stdenv.mkDerivation rec { hardeningDisable = [ "format" ]; unpackPhase = "tar xf $src"; - installTargets = [ "install" "install.man" ]; - installFlags = [ "BINDIR=$(out)/bin" "MANDIR=$(out)/share/man/man1" ]; + installTargets = [ + "install" + "install.man" + ]; + installFlags = [ + "BINDIR=$(out)/bin" + "MANDIR=$(out)/share/man/man1" + ]; preBuild = '' sed -i '1i#include \n#include ' untex.c mkdir -p $out/bin $out/share/man/man1 diff --git a/pkgs/by-name/un/untie/package.nix b/pkgs/by-name/un/untie/package.nix index 356416832cc9ac..9dee6d7e422da4 100644 --- a/pkgs/by-name/un/untie/package.nix +++ b/pkgs/by-name/un/untie/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "untie"; diff --git a/pkgs/by-name/un/untrunc-anthwlock/package.nix b/pkgs/by-name/un/untrunc-anthwlock/package.nix index 9598e9a7b15f62..547dc69cb65ec1 100644 --- a/pkgs/by-name/un/untrunc-anthwlock/package.nix +++ b/pkgs/by-name/un/untrunc-anthwlock/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, ffmpeg, libui, unstableGitUpdater, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + ffmpeg, + libui, + unstableGitUpdater, + wrapGAppsHook3, +}: stdenv.mkDerivation { pname = "untrunc-anthwlock"; @@ -13,7 +21,10 @@ stdenv.mkDerivation { nativeBuildInputs = [ wrapGAppsHook3 ]; - buildInputs = [ ffmpeg libui ]; + buildInputs = [ + ffmpeg + libui + ]; buildPhase = '' runHook preBuild diff --git a/pkgs/by-name/un/unused/package.nix b/pkgs/by-name/un/unused/package.nix index 9c7875146690d8..3d8fd5c8f7a58a 100644 --- a/pkgs/by-name/un/unused/package.nix +++ b/pkgs/by-name/un/unused/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, rustPlatform, cmake }: +{ + lib, + fetchFromGitHub, + rustPlatform, + cmake, +}: rustPlatform.buildRustPackage rec { pname = "unused"; version = "0.4.0"; diff --git a/pkgs/by-name/un/unzip/package.nix b/pkgs/by-name/un/unzip/package.nix index 50e2261aa7d4ea..a5b84b81353828 100644 --- a/pkgs/by-name/un/unzip/package.nix +++ b/pkgs/by-name/un/unzip/package.nix @@ -1,6 +1,10 @@ -{ lib, stdenv, fetchurl -, bzip2 -, enableNLS ? false, libnatspec +{ + lib, + stdenv, + fetchurl, + bzip2, + enableNLS ? false, + libnatspec, }: stdenv.mkDerivation rec { @@ -8,74 +12,77 @@ stdenv.mkDerivation rec { version = "6.0"; src = fetchurl { - url = "mirror://sourceforge/infozip/unzip${lib.replaceStrings ["."] [""] version}.tar.gz"; + url = "mirror://sourceforge/infozip/unzip${lib.replaceStrings [ "." ] [ "" ] version}.tar.gz"; sha256 = "0dxx11knh3nk95p2gg2ak777dd11pr7jx5das2g49l262scrcv83"; }; hardeningDisable = [ "format" ]; - patchFlags = [ "-p1" "-F3" ]; - - patches = [ - ./CVE-2014-8139.diff - ./CVE-2014-8140.diff - ./CVE-2014-8141.diff - ./CVE-2014-9636.diff - ./CVE-2015-7696.diff - ./CVE-2015-7697.diff - ./CVE-2014-9913.patch - ./CVE-2016-9844.patch - ./CVE-2018-18384.patch - ./dont-hardcode-cc.patch - (fetchurl { - url = "https://github.com/madler/unzip/commit/41beb477c5744bc396fa1162ee0c14218ec12213.patch"; - name = "CVE-2019-13232-1.patch"; - sha256 = "04jzd6chg9fw4l5zadkfsrfm5llrd7vhd1dgdjjd29nrvkrjyn14"; - }) - (fetchurl { - url = "https://github.com/madler/unzip/commit/47b3ceae397d21bf822bc2ac73052a4b1daf8e1c.patch"; - name = "CVE-2019-13232-2.patch"; - sha256 = "0iy2wcjyvzwrjk02iszwcpg85fkjxs1bvb9isvdiywszav4yjs32"; - }) - (fetchurl { - url = "https://github.com/madler/unzip/commit/6d351831be705cc26d897db44f878a978f4138fc.patch"; - name = "CVE-2019-13232-3.patch"; - sha256 = "1jvs7dkdqs97qnsqc6hk088alhv8j4c638k65dbib9chh40jd7pf"; - }) - (fetchurl { - urls = [ - # original link (will be dead eventually): - "https://sources.debian.org/data/main/u/unzip/6.0-26%2Bdeb11u1/debian/patches/06-initialize-the-symlink-flag.patch" - - "https://gist.github.com/veprbl/41261bb781571e2246ea42d3f37795f5/raw/d8533d8c6223150f76b0f31aec03e185fcde3579/06-initialize-the-symlink-flag.patch" - ]; - sha256 = "1h00djdvgjhwfb60wl4qrxbyfsbbnn1qw6l2hkldnif4m8f8r1zj"; - }) - (fetchurl { - urls = [ - # original link (will be dead eventually): - "https://sources.debian.org/data/main/u/unzip/6.0-27/debian/patches/28-cve-2022-0529-and-cve-2022-0530.patch" + patchFlags = [ + "-p1" + "-F3" + ]; - "https://web.archive.org/web/20230106200319/https://sources.debian.org/data/main/u/unzip/6.0-27/debian/patches/28-cve-2022-0529-and-cve-2022-0530.patch" - ]; - sha256 = "sha256-on79jElQ+z2ULWAq14RpluAqr9d6itHiZwDkKubBzTc="; - }) - # Clang 16 makes implicit declarations an error by default for C99 and newer, causing the - # configure script to fail to detect errno and the directory libraries on Darwin. - ./implicit-declarations-fix.patch - (fetchurl { - name = "CVE-2021-4217.patch"; - url = "https://git.launchpad.net/ubuntu/+source/unzip/plain/debian/patches/CVE-2021-4217.patch?id=94a790fcbb5d6c53cdf5d786bcaa0b8dc10309b6"; - hash = "sha256-YKE4jVNSlrHLbszXNYYRtAQs0ly4AsodEz6tadMIVqE="; - }) - ] ++ lib.optional enableNLS - (fetchurl { + patches = + [ + ./CVE-2014-8139.diff + ./CVE-2014-8140.diff + ./CVE-2014-8141.diff + ./CVE-2014-9636.diff + ./CVE-2015-7696.diff + ./CVE-2015-7697.diff + ./CVE-2014-9913.patch + ./CVE-2016-9844.patch + ./CVE-2018-18384.patch + ./dont-hardcode-cc.patch + (fetchurl { + url = "https://github.com/madler/unzip/commit/41beb477c5744bc396fa1162ee0c14218ec12213.patch"; + name = "CVE-2019-13232-1.patch"; + sha256 = "04jzd6chg9fw4l5zadkfsrfm5llrd7vhd1dgdjjd29nrvkrjyn14"; + }) + (fetchurl { + url = "https://github.com/madler/unzip/commit/47b3ceae397d21bf822bc2ac73052a4b1daf8e1c.patch"; + name = "CVE-2019-13232-2.patch"; + sha256 = "0iy2wcjyvzwrjk02iszwcpg85fkjxs1bvb9isvdiywszav4yjs32"; + }) + (fetchurl { + url = "https://github.com/madler/unzip/commit/6d351831be705cc26d897db44f878a978f4138fc.patch"; + name = "CVE-2019-13232-3.patch"; + sha256 = "1jvs7dkdqs97qnsqc6hk088alhv8j4c638k65dbib9chh40jd7pf"; + }) + (fetchurl { + urls = [ + # original link (will be dead eventually): + "https://sources.debian.org/data/main/u/unzip/6.0-26%2Bdeb11u1/debian/patches/06-initialize-the-symlink-flag.patch" + + "https://gist.github.com/veprbl/41261bb781571e2246ea42d3f37795f5/raw/d8533d8c6223150f76b0f31aec03e185fcde3579/06-initialize-the-symlink-flag.patch" + ]; + sha256 = "1h00djdvgjhwfb60wl4qrxbyfsbbnn1qw6l2hkldnif4m8f8r1zj"; + }) + (fetchurl { + urls = [ + # original link (will be dead eventually): + "https://sources.debian.org/data/main/u/unzip/6.0-27/debian/patches/28-cve-2022-0529-and-cve-2022-0530.patch" + + "https://web.archive.org/web/20230106200319/https://sources.debian.org/data/main/u/unzip/6.0-27/debian/patches/28-cve-2022-0529-and-cve-2022-0530.patch" + ]; + sha256 = "sha256-on79jElQ+z2ULWAq14RpluAqr9d6itHiZwDkKubBzTc="; + }) + # Clang 16 makes implicit declarations an error by default for C99 and newer, causing the + # configure script to fail to detect errno and the directory libraries on Darwin. + ./implicit-declarations-fix.patch + (fetchurl { + name = "CVE-2021-4217.patch"; + url = "https://git.launchpad.net/ubuntu/+source/unzip/plain/debian/patches/CVE-2021-4217.patch?id=94a790fcbb5d6c53cdf5d786bcaa0b8dc10309b6"; + hash = "sha256-YKE4jVNSlrHLbszXNYYRtAQs0ly4AsodEz6tadMIVqE="; + }) + ] + ++ lib.optional enableNLS (fetchurl { url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/app-arch/unzip/files/unzip-6.0-natspec.patch?id=56bd759df1d0c750a065b8c845e93d5dfa6b549d"; name = "unzip-6.0-natspec.patch"; sha256 = "67ab260ae6adf8e7c5eda2d1d7846929b43562943ec4aff629bd7018954058b1"; }); - nativeBuildInputs = [ bzip2 ]; buildInputs = [ bzip2 ] ++ lib.optional enableNLS libnatspec; @@ -83,14 +90,15 @@ stdenv.mkDerivation rec { NIX_LDFLAGS = "-lbz2" + lib.optionalString enableNLS " -lnatspec"; - buildFlags = [ - "generic" - "D_USE_BZ2=-DUSE_BZIP2" - "L_BZ2=-lbz2" - ] - # `lchmod` is not available on Linux, so we remove it to fix "not supported" errors (when the zip file contains symlinks). - # Alpine (musl) and Debian (glibc) also add this flag. - ++ lib.optionals stdenv.hostPlatform.isLinux [ "LOCAL_UNZIP=-DNO_LCHMOD" ]; + buildFlags = + [ + "generic" + "D_USE_BZ2=-DUSE_BZIP2" + "L_BZ2=-lbz2" + ] + # `lchmod` is not available on Linux, so we remove it to fix "not supported" errors (when the zip file contains symlinks). + # Alpine (musl) and Debian (glibc) also add this flag. + ++ lib.optionals stdenv.hostPlatform.isLinux [ "LOCAL_UNZIP=-DNO_LCHMOD" ]; preConfigure = '' sed -i -e 's@CF="-O3 -Wall -I. -DASM_CRC $(LOC)"@CF="-O3 -Wall -I. -DASM_CRC -DLARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 $(LOC)"@' unix/Makefile diff --git a/pkgs/by-name/un/unzoo/package.nix b/pkgs/by-name/un/unzoo/package.nix index b02d010ac0c9ad..0b2fb186b629e3 100644 --- a/pkgs/by-name/un/unzoo/package.nix +++ b/pkgs/by-name/un/unzoo/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { @@ -14,7 +15,10 @@ stdenv.mkDerivation rec { hash = "sha256-oPq1I7EsvHaJ7anHbm/KWrYrxJkM79rLhgRfSAdoLtk="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; buildPhase = '' runHook preBuild diff --git a/pkgs/by-name/un/unzrip/package.nix b/pkgs/by-name/un/unzrip/package.nix index 2e92fadd39a912..fbd233b6006794 100644 --- a/pkgs/by-name/un/unzrip/package.nix +++ b/pkgs/by-name/un/unzrip/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, zstd +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + zstd, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/up/up/package.nix b/pkgs/by-name/up/up/package.nix index 9fa0c700b8c37f..a25f1406e436e2 100644 --- a/pkgs/by-name/up/up/package.nix +++ b/pkgs/by-name/up/up/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "up"; diff --git a/pkgs/by-name/up/update-python-libraries/package.nix b/pkgs/by-name/up/update-python-libraries/package.nix index f7dfdf0a8b457a..46e0e3b7f7729f 100644 --- a/pkgs/by-name/up/update-python-libraries/package.nix +++ b/pkgs/by-name/up/update-python-libraries/package.nix @@ -1,14 +1,28 @@ -{ python3, runCommand, git, nix, nix-prefetch-git }: +{ + python3, + runCommand, + git, + nix, + nix-prefetch-git, +}: -runCommand "update-python-libraries" { - buildInputs = [ - nix - nix-prefetch-git - (python3.withPackages(ps: with ps; [ packaging requests toolz ])) - git - ]; -} '' - cp ${./update-python-libraries.py} $out - patchShebangs $out - substituteInPlace $out --replace 'GIT = "git"' 'GIT = "${git}/bin/git"' -'' +runCommand "update-python-libraries" + { + buildInputs = [ + nix + nix-prefetch-git + (python3.withPackages ( + ps: with ps; [ + packaging + requests + toolz + ] + )) + git + ]; + } + '' + cp ${./update-python-libraries.py} $out + patchShebangs $out + substituteInPlace $out --replace 'GIT = "git"' 'GIT = "${git}/bin/git"' + '' diff --git a/pkgs/by-name/up/updfparser/package.nix b/pkgs/by-name/up/updfparser/package.nix index 6eb4e65e657aee..93f6143964b094 100644 --- a/pkgs/by-name/up/updfparser/package.nix +++ b/pkgs/by-name/up/updfparser/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: stdenv.mkDerivation rec { name = "updfparser"; @@ -11,7 +15,10 @@ stdenv.mkDerivation rec { extension = "zip"; }; - makeFlags = [ "BUILD_STATIC=1" "BUILD_SHARED=1" ]; + makeFlags = [ + "BUILD_STATIC=1" + "BUILD_SHARED=1" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/up/updog/package.nix b/pkgs/by-name/up/updog/package.nix index c5cccac026ba8e..772dcf8b87881e 100644 --- a/pkgs/by-name/up/updog/package.nix +++ b/pkgs/by-name/up/updog/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "updog"; @@ -10,7 +14,11 @@ python3Packages.buildPythonApplication rec { }; propagatedBuildInputs = with python3Packages; [ - colorama flask flask-httpauth werkzeug pyopenssl + colorama + flask + flask-httpauth + werkzeug + pyopenssl ]; checkPhase = '' diff --git a/pkgs/by-name/up/upiano/package.nix b/pkgs/by-name/up/upiano/package.nix index 4ad1456fc96e9c..035423dbbdb718 100644 --- a/pkgs/by-name/up/upiano/package.nix +++ b/pkgs/by-name/up/upiano/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/up/upnp-router-control/package.nix b/pkgs/by-name/up/upnp-router-control/package.nix index 8991e66b7c24f8..a837a922b060ab 100644 --- a/pkgs/by-name/up/upnp-router-control/package.nix +++ b/pkgs/by-name/up/upnp-router-control/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchzip -, desktop-file-utils -, intltool -, meson -, ninja -, pkg-config -, wrapGAppsHook3 -, gssdp_1_6 -, gtk3 -, gupnp_1_6 +{ + lib, + stdenv, + fetchzip, + desktop-file-utils, + intltool, + meson, + ninja, + pkg-config, + wrapGAppsHook3, + gssdp_1_6, + gtk3, + gupnp_1_6, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/up/ups/package.nix b/pkgs/by-name/up/ups/package.nix index 4da9d2f9f3ae05..f563ea93a17008 100644 --- a/pkgs/by-name/up/ups/package.nix +++ b/pkgs/by-name/up/ups/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { pname = "ups"; diff --git a/pkgs/by-name/up/upspin/package.nix b/pkgs/by-name/up/upspin/package.nix index d0ad20a66a77e3..4148d30da9f15c 100644 --- a/pkgs/by-name/up/upspin/package.nix +++ b/pkgs/by-name/up/upspin/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "upspin"; diff --git a/pkgs/by-name/up/upsun/package.nix b/pkgs/by-name/up/upsun/package.nix index fd1242e593307a..7b177fa84b5956 100644 --- a/pkgs/by-name/up/upsun/package.nix +++ b/pkgs/by-name/up/upsun/package.nix @@ -4,18 +4,27 @@ fetchurl, testers, installShellFiles, - upsun + upsun, }: -let versions = lib.importJSON ./versions.json; - arch = if stdenvNoCC.hostPlatform.isx86_64 then "amd64" - else if stdenvNoCC.hostPlatform.isAarch64 then "arm64" - else throw "Unsupported architecture"; - os = if stdenvNoCC.hostPlatform.isLinux then "linux" - else if stdenvNoCC.hostPlatform.isDarwin then "darwin" - else throw "Unsupported os"; - versionInfo = versions."${os}-${arch}"; - inherit (versionInfo) hash url; +let + versions = lib.importJSON ./versions.json; + arch = + if stdenvNoCC.hostPlatform.isx86_64 then + "amd64" + else if stdenvNoCC.hostPlatform.isAarch64 then + "arm64" + else + throw "Unsupported architecture"; + os = + if stdenvNoCC.hostPlatform.isLinux then + "linux" + else if stdenvNoCC.hostPlatform.isDarwin then + "darwin" + else + throw "Unsupported os"; + versionInfo = versions."${os}-${arch}"; + inherit (versionInfo) hash url; in stdenvNoCC.mkDerivation (finalAttrs: { @@ -56,7 +65,12 @@ stdenvNoCC.mkDerivation (finalAttrs: { license = lib.licenses.mit; mainProgram = "upsun"; maintainers = with lib.maintainers; [ spk ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; }; }) diff --git a/pkgs/by-name/up/upterm/package.nix b/pkgs/by-name/up/upterm/package.nix index 50383a1c3eebc6..3c9b76021c1700 100644 --- a/pkgs/by-name/up/upterm/package.nix +++ b/pkgs/by-name/up/upterm/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + nixosTests, }: buildGoModule rec { @@ -18,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-PUcfE7LQQh2ftiOiOoucSfxYnTI4zRNmmSqqmvvvs7g="; - subPackages = [ "cmd/upterm" "cmd/uptermd" ]; + subPackages = [ + "cmd/upterm" + "cmd/uptermd" + ]; nativeBuildInputs = [ installShellFiles ]; diff --git a/pkgs/by-name/up/uptime-kuma/package.nix b/pkgs/by-name/up/uptime-kuma/package.nix index d7e03ab16cd45c..8682db20ad4535 100644 --- a/pkgs/by-name/up/uptime-kuma/package.nix +++ b/pkgs/by-name/up/uptime-kuma/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, buildNpmPackage, python3, nodejs, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + buildNpmPackage, + python3, + nodejs, + nixosTests, +}: buildNpmPackage rec { pname = "uptime-kuma"; diff --git a/pkgs/by-name/up/uptimed/package.nix b/pkgs/by-name/up/uptimed/package.nix index 26e536618d6ea9..af792b1b793676 100644 --- a/pkgs/by-name/up/uptimed/package.nix +++ b/pkgs/by-name/up/uptimed/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "uptimed"; @@ -28,7 +33,10 @@ stdenv.mkDerivation rec { which can also easily be used to show your records on a web page. ''; homepage = "https://github.com/rpodgorny/uptimed/"; - license = with licenses; [ gpl2Only lgpl21Plus ]; + license = with licenses; [ + gpl2Only + lgpl21Plus + ]; maintainers = [ ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/up/upwork/package.nix b/pkgs/by-name/up/upwork/package.nix index 6062be7b720071..722cdb0a6bf7b8 100644 --- a/pkgs/by-name/up/upwork/package.nix +++ b/pkgs/by-name/up/upwork/package.nix @@ -1,8 +1,47 @@ -{ lib, stdenv, requireFile, dpkg, wrapGAppsHook3, autoPatchelfHook -, alsa-lib, atk, at-spi2-atk, at-spi2-core, cairo, cups, dbus, expat, fontconfig, freetype -, gdk-pixbuf, glib, gtk3, libcxx, libdrm, libnotify, libpulseaudio, libuuid, libX11, libxcb -, libXcomposite, libXcursor, libXdamage, libXext, libXfixes, libXi, libXrandr, libXrender -, libXScrnSaver, libXtst, mesa, nspr, nss, openssl, pango, systemd }: +{ + lib, + stdenv, + requireFile, + dpkg, + wrapGAppsHook3, + autoPatchelfHook, + alsa-lib, + atk, + at-spi2-atk, + at-spi2-core, + cairo, + cups, + dbus, + expat, + fontconfig, + freetype, + gdk-pixbuf, + glib, + gtk3, + libcxx, + libdrm, + libnotify, + libpulseaudio, + libuuid, + libX11, + libxcb, + libXcomposite, + libXcursor, + libXdamage, + libXext, + libXfixes, + libXi, + libXrandr, + libXrender, + libXScrnSaver, + libXtst, + mesa, + nspr, + nss, + openssl, + pango, + systemd, +}: stdenv.mkDerivation rec { pname = "upwork"; @@ -21,11 +60,43 @@ stdenv.mkDerivation rec { ]; buildInputs = [ - libcxx systemd libpulseaudio - stdenv.cc.cc alsa-lib atk at-spi2-atk at-spi2-core cairo cups - dbus expat fontconfig freetype gdk-pixbuf glib gtk3 libdrm libnotify - libuuid libX11 libxcb libXcomposite libXcursor libXdamage libXext libXfixes - libXi libXrandr libXrender libXScrnSaver libXtst mesa nspr nss pango systemd + libcxx + systemd + libpulseaudio + stdenv.cc.cc + alsa-lib + atk + at-spi2-atk + at-spi2-core + cairo + cups + dbus + expat + fontconfig + freetype + gdk-pixbuf + glib + gtk3 + libdrm + libnotify + libuuid + libX11 + libxcb + libXcomposite + libXcursor + libXdamage + libXext + libXfixes + libXi + libXrandr + libXrender + libXScrnSaver + libXtst + mesa + nspr + nss + pango + systemd ]; libPath = lib.makeLibraryPath buildInputs; diff --git a/pkgs/by-name/up/upx/package.nix b/pkgs/by-name/up/upx/package.nix index 280e1425ef5377..6063ceb136222c 100644 --- a/pkgs/by-name/up/upx/package.nix +++ b/pkgs/by-name/up/upx/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, nix-update-script -, testers +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + nix-update-script, + testers, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/uq/uq/package.nix b/pkgs/by-name/uq/uq/package.nix index 414403d81ef9db..79410592095554 100644 --- a/pkgs/by-name/uq/uq/package.nix +++ b/pkgs/by-name/uq/uq/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,10 @@ rustPlatform.buildRustPackage rec { description = "Simple, user-friendly alternative to sort | uniq"; homepage = "https://github.com/lostutils/uq"; license = licenses.mit; - maintainers = with maintainers; [ doronbehar matthiasbeyer ]; + maintainers = with maintainers; [ + doronbehar + matthiasbeyer + ]; mainProgram = "uq"; }; } diff --git a/pkgs/by-name/uq/uqm/3dovideo.nix b/pkgs/by-name/uq/uqm/3dovideo.nix index 2281688949c876..78b42ae2c1dfdc 100644 --- a/pkgs/by-name/uq/uqm/3dovideo.nix +++ b/pkgs/by-name/uq/uqm/3dovideo.nix @@ -1,39 +1,61 @@ -{ stdenv, lib, requireFile, writeText, fetchFromGitHub, haskellPackages }: +{ + stdenv, + lib, + requireFile, + writeText, + fetchFromGitHub, + haskellPackages, +}: let - makeSpin = num: let - padded = (lib.optionalString (lib.lessThan num 10) "0") + toString num; - in "slides.spins.${padded} = 3DOVID:" + - "addons/3dovideo/spins/ship${padded}.duk:" + - "addons/3dovideo/spins/spin.aif:" + - "addons/3dovideo/spins/ship${padded}.aif:89"; - - videoRMP = writeText "3dovideo.rmp" ('' - slides.ending = 3DOVID:addons/3dovideo/ending/victory.duk - slides.intro = 3DOVID:addons/3dovideo/intro/intro.duk - '' + lib.concatMapStrings makeSpin (lib.range 0 24)); - - helper = with haskellPackages; mkDerivation rec { - pname = "uqm3donix"; - version = "0.1.0.0"; - - src = fetchFromGitHub { - owner = "aszlig"; - repo = "uqm3donix"; - rev = "v${version}"; - hash = "sha256-rK30u2PBysiSGSA9829F1Nom/wtoVN6rGTBneRKeWEw="; - }; + makeSpin = + num: + let + padded = (lib.optionalString (lib.lessThan num 10) "0") + toString num; + in + "slides.spins.${padded} = 3DOVID:" + + "addons/3dovideo/spins/ship${padded}.duk:" + + "addons/3dovideo/spins/spin.aif:" + + "addons/3dovideo/spins/ship${padded}.aif:89"; - isLibrary = false; - isExecutable = true; + videoRMP = writeText "3dovideo.rmp" ( + '' + slides.ending = 3DOVID:addons/3dovideo/ending/victory.duk + slides.intro = 3DOVID:addons/3dovideo/intro/intro.duk + '' + + lib.concatMapStrings makeSpin (lib.range 0 24) + ); - buildDepends = [ base binary bytestring filepath tar ]; + helper = + with haskellPackages; + mkDerivation rec { + pname = "uqm3donix"; + version = "0.1.0.0"; - description = "Extract video files from a Star Control II 3DO image"; - license = lib.licenses.bsd3; - }; + src = fetchFromGitHub { + owner = "aszlig"; + repo = "uqm3donix"; + rev = "v${version}"; + hash = "sha256-rK30u2PBysiSGSA9829F1Nom/wtoVN6rGTBneRKeWEw="; + }; + + isLibrary = false; + isExecutable = true; + + buildDepends = [ + base + binary + bytestring + filepath + tar + ]; + + description = "Extract video files from a Star Control II 3DO image"; + license = lib.licenses.bsd3; + }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { name = "uqm-3dovideo"; src = requireFile rec { diff --git a/pkgs/by-name/uq/uqm/package.nix b/pkgs/by-name/uq/uqm/package.nix index eb5fabf47dfae0..03ac250257f759 100644 --- a/pkgs/by-name/uq/uqm/package.nix +++ b/pkgs/by-name/uq/uqm/package.nix @@ -1,32 +1,58 @@ -{ stdenv, lib, fetchurl, fetchFromGitHub, pkg-config, libGLU, libGL -, SDL2, libpng, libvorbis, libogg, libmikmod - -, use3DOVideos ? false, requireFile ? null, writeText ? null -, haskellPackages ? null - -, useRemixPacks ? false +{ + stdenv, + lib, + fetchurl, + fetchFromGitHub, + pkg-config, + libGLU, + libGL, + SDL2, + libpng, + libvorbis, + libogg, + libmikmod, + + use3DOVideos ? false, + requireFile ? null, + writeText ? null, + haskellPackages ? null, + + useRemixPacks ? false, }: -assert use3DOVideos -> requireFile != null && writeText != null - && haskellPackages != null; +assert use3DOVideos -> requireFile != null && writeText != null && haskellPackages != null; let videos = import ./3dovideo.nix { - inherit stdenv lib requireFile writeText fetchFromGitHub haskellPackages; + inherit + stdenv + lib + requireFile + writeText + fetchFromGitHub + haskellPackages + ; }; - remixPacks = lib.imap1 (num: sha256: fetchurl rec { - name = "uqm-remix-disc${toString num}.uqm"; - url = "mirror://sourceforge/sc2/${name}"; - inherit sha256; - }) [ - "1s470i6hm53l214f2rkrbp111q4jyvnxbzdziqg32ffr8m3nk5xn" - "1pmsq65k8gk4jcbyk3qjgi9yqlm0dlaimc2r8hz2fc9f2124gfvz" - "07g966ylvw9k5q9jdzqdczp7c5qv4s91xjlg4z5z27fgcs7rzn76" - "1l46k9aqlcp7d3fjkjb3n05cjfkxx8rjlypgqy0jmdx529vikj54" - ]; - -in stdenv.mkDerivation rec { + remixPacks = + lib.imap1 + ( + num: sha256: + fetchurl rec { + name = "uqm-remix-disc${toString num}.uqm"; + url = "mirror://sourceforge/sc2/${name}"; + inherit sha256; + } + ) + [ + "1s470i6hm53l214f2rkrbp111q4jyvnxbzdziqg32ffr8m3nk5xn" + "1pmsq65k8gk4jcbyk3qjgi9yqlm0dlaimc2r8hz2fc9f2124gfvz" + "07g966ylvw9k5q9jdzqdczp7c5qv4s91xjlg4z5z27fgcs7rzn76" + "1l46k9aqlcp7d3fjkjb3n05cjfkxx8rjlypgqy0jmdx529vikj54" + ]; + +in +stdenv.mkDerivation rec { pname = "uqm"; version = "0.8.0"; @@ -51,19 +77,32 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ SDL2 libpng libvorbis libogg libmikmod libGLU libGL ]; - - postUnpack = '' - mkdir -p uqm-${version}/content/packages - mkdir -p uqm-${version}/content/addons - ln -s "$content" "uqm-${version}/content/packages/uqm-${version}-content.uqm" - ln -s "$music" "uqm-${version}/content/addons/uqm-${version}-3domusic.uqm" - ln -s "$voice" "uqm-${version}/content/addons/uqm-${version}-voice.uqm" - '' + lib.optionalString useRemixPacks (lib.concatMapStrings (disc: '' - ln -s "${disc}" "uqm-$version/content/addons/${disc.name}" - '') remixPacks) + lib.optionalString use3DOVideos '' - ln -s "${videos}" "uqm-${version}/content/addons/3dovideo" - ''; + buildInputs = [ + SDL2 + libpng + libvorbis + libogg + libmikmod + libGLU + libGL + ]; + + postUnpack = + '' + mkdir -p uqm-${version}/content/packages + mkdir -p uqm-${version}/content/addons + ln -s "$content" "uqm-${version}/content/packages/uqm-${version}-content.uqm" + ln -s "$music" "uqm-${version}/content/addons/uqm-${version}-3domusic.uqm" + ln -s "$voice" "uqm-${version}/content/addons/uqm-${version}-voice.uqm" + '' + + lib.optionalString useRemixPacks ( + lib.concatMapStrings (disc: '' + ln -s "${disc}" "uqm-$version/content/addons/${disc.name}" + '') remixPacks + ) + + lib.optionalString use3DOVideos '' + ln -s "${videos}" "uqm-${version}/content/addons/3dovideo" + ''; postPatch = '' # Using _STRINGS_H as include guard conflicts with glibc. @@ -104,7 +143,10 @@ in stdenv.mkDerivation rec { ''; homepage = "https://sc2.sourceforge.net/"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ jcumming aszlig ]; + maintainers = with lib.maintainers; [ + jcumming + aszlig + ]; platforms = with lib.platforms; linux; }; } diff --git a/pkgs/by-name/uq/uqmi/package.nix b/pkgs/by-name/uq/uqmi/package.nix index 37540cd4502406..6ee2d0f28f0442 100644 --- a/pkgs/by-name/uq/uqmi/package.nix +++ b/pkgs/by-name/uq/uqmi/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchgit, cmake, perl, libubox, json_c }: +{ + stdenv, + lib, + fetchgit, + cmake, + perl, + libubox, + json_c, +}: stdenv.mkDerivation { pname = "uqmi"; @@ -15,23 +23,35 @@ stdenv.mkDerivation { patchShebangs . ''; - nativeBuildInputs = [ cmake perl ]; - buildInputs = [ libubox json_c ]; + nativeBuildInputs = [ + cmake + perl + ]; + buildInputs = [ + libubox + json_c + ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ - # Needed with GCC 12 but breaks on darwin (with clang) or older gcc - "-Wno-error=dangling-pointer" - "-Wno-error=maybe-uninitialized" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-error=sometimes-uninitialized" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ + # Needed with GCC 12 but breaks on darwin (with clang) or older gcc + "-Wno-error=dangling-pointer" + "-Wno-error=maybe-uninitialized" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-error=sometimes-uninitialized" + ] + ); meta = with lib; { description = "Tiny QMI command line utility"; homepage = "https://git.openwrt.org/?p=project/uqmi.git;a=summary"; license = licenses.gpl2Plus; platforms = platforms.all; - maintainers = with maintainers; [ fpletz mkg20001 ]; + maintainers = with maintainers; [ + fpletz + mkg20001 + ]; mainProgram = "uqmi"; }; } diff --git a/pkgs/by-name/ur/urbackup-client/package.nix b/pkgs/by-name/ur/urbackup-client/package.nix index 1b714bdccb2af5..6ba24343cee2ce 100644 --- a/pkgs/by-name/ur/urbackup-client/package.nix +++ b/pkgs/by-name/ur/urbackup-client/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchzip -, wxGTK32 -, zlib -, zstd +{ + stdenv, + lib, + fetchzip, + wxGTK32, + zlib, + zstd, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ur/urbanterror/package.nix b/pkgs/by-name/ur/urbanterror/package.nix index cce5deaac246d8..fc54bcfc090181 100644 --- a/pkgs/by-name/ur/urbanterror/package.nix +++ b/pkgs/by-name/ur/urbanterror/package.nix @@ -1,17 +1,18 @@ -{ lib -, fetchzip -, stdenv -, copyDesktopItems -, imagemagick -, libicns -, makeBinaryWrapper -, curl -, libGL -, libGLU -, openal -, libXxf86vm -, SDL -, makeDesktopItem +{ + lib, + fetchzip, + stdenv, + copyDesktopItems, + imagemagick, + libicns, + makeBinaryWrapper, + curl, + libGL, + libGLU, + openal, + libXxf86vm, + SDL, + makeDesktopItem, }: let @@ -19,7 +20,9 @@ let urbanterror-maps = fetchzip { name = "urbanterror-maps"; - url = "http://cdn.urbanterror.info/urt/43/releases/zips/UrbanTerror${builtins.replaceStrings ["."] [""] version}_full.zip"; + url = "http://cdn.urbanterror.info/urt/43/releases/zips/UrbanTerror${ + builtins.replaceStrings [ "." ] [ "" ] version + }_full.zip"; hash = "sha256-C6Gb5PPECAOjQhmkrzkV6dpY/zHVtUj9oq3507o2PUI="; }; @@ -93,7 +96,10 @@ stdenv.mkDerivation { icon = "urbanterror"; comment = "A multiplayer tactical FPS on top of Quake 3 engine"; desktopName = "Urban Terror"; - categories = [ "Game" "ActionGame" ]; + categories = [ + "Game" + "ActionGame" + ]; }) ]; @@ -109,7 +115,10 @@ stdenv.mkDerivation { realism". This results in a very unique, enjoyable and addictive game. ''; mainProgram = "urbanterror"; - maintainers = with lib.maintainers; [ astsmtl drupol ]; + maintainers = with lib.maintainers; [ + astsmtl + drupol + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/ur/urdfdom-headers/package.nix b/pkgs/by-name/ur/urdfdom-headers/package.nix index 7809355cb30154..e1d0ed250c2d46 100644 --- a/pkgs/by-name/ur/urdfdom-headers/package.nix +++ b/pkgs/by-name/ur/urdfdom-headers/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, validatePkgConfig }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + validatePkgConfig, +}: stdenv.mkDerivation rec { pname = "urdfdom-headers"; @@ -19,7 +26,10 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake validatePkgConfig ]; + nativeBuildInputs = [ + cmake + validatePkgConfig + ]; meta = with lib; { description = "URDF (U-Robot Description Format) headers provides core data structure headers for URDF"; diff --git a/pkgs/by-name/ur/urdfdom/package.nix b/pkgs/by-name/ur/urdfdom/package.nix index f26162ac8c83be..6407c1b42d2f2a 100644 --- a/pkgs/by-name/ur/urdfdom/package.nix +++ b/pkgs/by-name/ur/urdfdom/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, pkg-config, validatePkgConfig -, tinyxml-2, console-bridge, urdfdom-headers }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + validatePkgConfig, + tinyxml-2, + console-bridge, + urdfdom-headers, +}: stdenv.mkDerivation rec { pname = "urdfdom"; @@ -20,8 +30,15 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config validatePkgConfig ]; - buildInputs = [ tinyxml-2 console-bridge ]; + nativeBuildInputs = [ + cmake + pkg-config + validatePkgConfig + ]; + buildInputs = [ + tinyxml-2 + console-bridge + ]; propagatedBuildInputs = [ urdfdom-headers ]; meta = with lib; { diff --git a/pkgs/by-name/ur/urh/package.nix b/pkgs/by-name/ur/urh/package.nix index 8643ca9e7607bb..047abf6f7596df 100644 --- a/pkgs/by-name/ur/urh/package.nix +++ b/pkgs/by-name/ur/urh/package.nix @@ -1,12 +1,22 @@ -{ stdenv, lib, fetchFromGitHub, python3Packages -, hackrf, rtl-sdr, airspy, limesuite, libiio -, libbladeRF -, imagemagick -, makeDesktopItem -, copyDesktopItems -, qt5 -, wrapGAppsHook3 -, USRPSupport ? false, uhd }: +{ + stdenv, + lib, + fetchFromGitHub, + python3Packages, + hackrf, + rtl-sdr, + airspy, + limesuite, + libiio, + libbladeRF, + imagemagick, + makeDesktopItem, + copyDesktopItems, + qt5, + wrapGAppsHook3, + USRPSupport ? false, + uhd, +}: python3Packages.buildPythonApplication rec { pname = "urh"; @@ -19,13 +29,31 @@ python3Packages.buildPythonApplication rec { hash = "sha256-r3d80dzGwgf5Tuwt1IWGcmNbblwBNKTKKm+GGx1r2HE="; }; - nativeBuildInputs = [ qt5.wrapQtAppsHook wrapGAppsHook3 copyDesktopItems ]; - buildInputs = [ hackrf rtl-sdr airspy limesuite libiio libbladeRF ] + nativeBuildInputs = [ + qt5.wrapQtAppsHook + wrapGAppsHook3 + copyDesktopItems + ]; + buildInputs = + [ + hackrf + rtl-sdr + airspy + limesuite + libiio + libbladeRF + ] ++ lib.optional USRPSupport uhd ++ lib.optional stdenv.hostPlatform.isLinux qt5.qtwayland; propagatedBuildInputs = with python3Packages; [ - pyqt5 numpy psutil cython pyzmq pyaudio setuptools + pyqt5 + numpy + psutil + cython + pyzmq + pyaudio + setuptools ]; # dont double wrap @@ -47,7 +75,10 @@ python3Packages.buildPythonApplication rec { exec = "urh"; icon = "urh"; desktopName = "Universal Radio Hacker"; - categories = [ "Network" "HamRadio" ]; + categories = [ + "Network" + "HamRadio" + ]; comment = meta.description; }) ]; diff --git a/pkgs/by-name/ur/uri/package.nix b/pkgs/by-name/ur/uri/package.nix index 039db93926717c..5b788d8d424afa 100644 --- a/pkgs/by-name/ur/uri/package.nix +++ b/pkgs/by-name/ur/uri/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, doxygen }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + doxygen, +}: stdenv.mkDerivation rec { pname = "uri"; @@ -11,20 +17,28 @@ stdenv.mkDerivation rec { sha256 = "148361pixrm94q6v04k13s1msa04bx9yc3djb0lxpa7dlw19vhcd"; }; - env.NIX_CFLAGS_COMPILE = toString ([ - "-Wno-error=parentheses" - # Needed with GCC 12 - "-Wno-error=deprecated-declarations" - "-Wno-error=nonnull" - ] ++ lib.optionals stdenv.cc.isClang [ - # Needed with Clang 16 - "-Wno-error=deprecated-builtins" - ]); - - nativeBuildInputs = [ cmake doxygen ]; + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-Wno-error=parentheses" + # Needed with GCC 12 + "-Wno-error=deprecated-declarations" + "-Wno-error=nonnull" + ] + ++ lib.optionals stdenv.cc.isClang [ + # Needed with Clang 16 + "-Wno-error=deprecated-builtins" + ] + ); + + nativeBuildInputs = [ + cmake + doxygen + ]; cmakeFlags = [ - "-DUri_BUILD_TESTS=OFF" "-DUri_BUILD_DOCS=ON" "-DBUILD_SHARED_LIBS=ON" + "-DUri_BUILD_TESTS=OFF" + "-DUri_BUILD_DOCS=ON" + "-DBUILD_SHARED_LIBS=ON" ]; postBuild = "make doc"; diff --git a/pkgs/by-name/ur/uriparser/package.nix b/pkgs/by-name/ur/uriparser/package.nix index 370a1dfe4ea933..721ea8182dc6bf 100644 --- a/pkgs/by-name/ur/uriparser/package.nix +++ b/pkgs/by-name/ur/uriparser/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, cmake, gtest }: +{ + lib, + stdenv, + fetchurl, + cmake, + gtest, +}: stdenv.mkDerivation rec { pname = "uriparser"; diff --git a/pkgs/by-name/ur/urjtag/package.nix b/pkgs/by-name/ur/urjtag/package.nix index dae7cf2ba64039..31ab0029653995 100644 --- a/pkgs/by-name/ur/urjtag/package.nix +++ b/pkgs/by-name/ur/urjtag/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, gettext -, libftdi1 -, libtool -, libusb-compat-0_1 -, pkg-config -, readline -, which -, bsdlSupport ? true -, jedecSupport ? true -, staplSupport ? true -, svfSupport ? true +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + gettext, + libftdi1, + libtool, + libusb-compat-0_1, + pkg-config, + readline, + which, + bsdlSupport ? true, + jedecSupport ? true, + staplSupport ? true, + svfSupport ? true, }: stdenv.mkDerivation rec { @@ -38,16 +39,19 @@ stdenv.mkDerivation rec { ]; configureFlags = [ - (lib.enableFeature bsdlSupport "bsdl") + (lib.enableFeature bsdlSupport "bsdl") (lib.enableFeature jedecSupport "jedec-exp") (lib.enableFeature staplSupport "stapl") - (lib.enableFeature svfSupport "svf") + (lib.enableFeature svfSupport "svf") ]; meta = with lib; { homepage = "http://urjtag.org/"; description = "Universal JTAG library, server and tools"; - license = with licenses; [ gpl2Plus lgpl21Plus ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + ]; maintainers = with maintainers; [ AndersonTorres ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/ur/url-parser/package.nix b/pkgs/by-name/ur/url-parser/package.nix index c3b8a37b1103da..5faa2118370c77 100644 --- a/pkgs/by-name/ur/url-parser/package.nix +++ b/pkgs/by-name/ur/url-parser/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -19,8 +20,10 @@ buildGoModule rec { ldflags = [ "-s" "-w" - "-X" "main.BuildVersion=${version}" - "-X" "main.BuildDate=1970-01-01" + "-X" + "main.BuildVersion=${version}" + "-X" + "main.BuildDate=1970-01-01" ]; meta = with lib; { diff --git a/pkgs/by-name/ur/urlencode/package.nix b/pkgs/by-name/ur/urlencode/package.nix index da7066adc88236..54c89485d1c7d3 100644 --- a/pkgs/by-name/ur/urlencode/package.nix +++ b/pkgs/by-name/ur/urlencode/package.nix @@ -1,6 +1,7 @@ -{ fetchFromGitHub -, lib -, rustPlatform +{ + fetchFromGitHub, + lib, + rustPlatform, }: rustPlatform.buildRustPackage rec { pname = "urlencode"; diff --git a/pkgs/by-name/ur/urlhunter/package.nix b/pkgs/by-name/ur/urlhunter/package.nix index 9f3f6b5a09b0c9..315ce0d1634387 100644 --- a/pkgs/by-name/ur/urlhunter/package.nix +++ b/pkgs/by-name/ur/urlhunter/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/ur/urlwatch/package.nix b/pkgs/by-name/ur/urlwatch/package.nix index 1eec3cf0653d61..b484e07e2e5d04 100644 --- a/pkgs/by-name/ur/urlwatch/package.nix +++ b/pkgs/by-name/ur/urlwatch/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3Packages +{ + lib, + fetchFromGitHub, + python3Packages, }: python3Packages.buildPythonApplication rec { @@ -38,6 +39,9 @@ python3Packages.buildPythonApplication rec { mainProgram = "urlwatch"; homepage = "https://thp.io/2008/urlwatch/"; license = licenses.bsd3; - maintainers = with maintainers; [ kmein tv ]; + maintainers = with maintainers; [ + kmein + tv + ]; }; } diff --git a/pkgs/by-name/ur/urn-timer/package.nix b/pkgs/by-name/ur/urn-timer/package.nix index ad0c271fda6678..20bbf66a86ebaa 100644 --- a/pkgs/by-name/ur/urn-timer/package.nix +++ b/pkgs/by-name/ur/urn-timer/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, unstableGitUpdater -, xxd -, pkg-config -, imagemagick -, wrapGAppsHook3 -, gtk3 -, jansson -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + unstableGitUpdater, + xxd, + pkg-config, + imagemagick, + wrapGAppsHook3, + gtk3, + jansson, + nixosTests, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ur/urn/package.nix b/pkgs/by-name/ur/urn/package.nix index 87e28d9672daea..9f1ee36f59a679 100644 --- a/pkgs/by-name/ur/urn/package.nix +++ b/pkgs/by-name/ur/urn/package.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchFromGitLab, buildEnv, makeWrapper, lua, luajit, readline -, useLuaJit ? false -, extraLibraries ? [] +{ + lib, + stdenv, + fetchFromGitLab, + buildEnv, + makeWrapper, + lua, + luajit, + readline, + useLuaJit ? false, + extraLibraries ? [ ], }: let @@ -11,17 +19,21 @@ let urn-rt = buildEnv { name = "urn-rt-${version}"; ignoreCollisions = true; - paths = if useLuaJit then - [ luajit readline ] - else - [ lua ]; + paths = + if useLuaJit then + [ + luajit + readline + ] + else + [ lua ]; }; inherit (lib) optionalString concatMapStringsSep; in stdenv.mkDerivation { - pname = "urn${optionalString (extraLibraries != []) "-with-libraries"}"; + pname = "urn${optionalString (extraLibraries != [ ]) "-with-libraries"}"; inherit version; src = fetchFromGitLab { @@ -36,7 +48,7 @@ stdenv.mkDerivation { # dependency on the Urn runtime support. propagatedBuildInputs = [ urn-rt ]; - makeFlags = ["-B"]; + makeFlags = [ "-B" ]; installPhase = '' mkdir -p $out/bin $out/lib diff --git a/pkgs/by-name/ur/uroboros/package.nix b/pkgs/by-name/ur/uroboros/package.nix index f7d5ec0ac133df..c798631aaf5eae 100644 --- a/pkgs/by-name/ur/uroboros/package.nix +++ b/pkgs/by-name/ur/uroboros/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ur/ursadb/package.nix b/pkgs/by-name/ur/ursadb/package.nix index e9bb8149812558..38b623f3f93582 100644 --- a/pkgs/by-name/ur/ursadb/package.nix +++ b/pkgs/by-name/ur/ursadb/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation (finalAttrs: { pname = "ursadb"; diff --git a/pkgs/by-name/ur/urserver/package.nix b/pkgs/by-name/ur/urserver/package.nix index 1df9c40aee32a3..dc80ea77942d77 100644 --- a/pkgs/by-name/ur/urserver/package.nix +++ b/pkgs/by-name/ur/urserver/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchurl -, autoPatchelfHook -, bluez -, libX11 -, libXtst -, makeWrapper +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + bluez, + libX11, + libXtst, + makeWrapper, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/us/usb-reset/package.nix b/pkgs/by-name/us/usb-reset/package.nix index a5bb2061ed502c..bbe78a56a5ba85 100644 --- a/pkgs/by-name/us/usb-reset/package.nix +++ b/pkgs/by-name/us/usb-reset/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, libusb1 +{ + lib, + stdenv, + fetchFromGitHub, + libusb1, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/us/usbguard-notifier/package.nix b/pkgs/by-name/us/usbguard-notifier/package.nix index a9eaa6651f99bf..d9507d159d9aa0 100644 --- a/pkgs/by-name/us/usbguard-notifier/package.nix +++ b/pkgs/by-name/us/usbguard-notifier/package.nix @@ -34,8 +34,17 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config asciidoc ]; - buildInputs = [ libqb usbguard librsvg libnotify ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + asciidoc + ]; + buildInputs = [ + libqb + usbguard + librsvg + libnotify + ]; configureFlags = [ "CPPFLAGS=-I${catch2}/include/catch2" ]; diff --git a/pkgs/by-name/us/usbguard/package.nix b/pkgs/by-name/us/usbguard/package.nix index dfa31dd3a97cbd..9c2c6a2a495b65 100644 --- a/pkgs/by-name/us/usbguard/package.nix +++ b/pkgs/by-name/us/usbguard/package.nix @@ -1,23 +1,24 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, installShellFiles -, nixosTests -, asciidoc -, pkg-config -, libxslt -, libxml2 -, docbook_xml_dtd_45 -, docbook_xsl -, dbus-glib -, libcap_ng -, libqb -, libseccomp -, polkit -, protobuf -, audit -, libsodium +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + installShellFiles, + nixosTests, + asciidoc, + pkg-config, + libxslt, + libxml2, + docbook_xml_dtd_45, + docbook_xsl, + dbus-glib, + libcap_ng, + libqb, + libseccomp, + polkit, + protobuf, + audit, + libsodium, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/us/usbimager/package.nix b/pkgs/by-name/us/usbimager/package.nix index 11a9162af2f233..4dee81432a0cae 100644 --- a/pkgs/by-name/us/usbimager/package.nix +++ b/pkgs/by-name/us/usbimager/package.nix @@ -1,7 +1,16 @@ -{ lib, stdenv, fetchFromGitLab, pkg-config, wrapGAppsHook3 -, withLibui ? true, gtk3 -, withUdisks ? stdenv.hostPlatform.isLinux, udisks, glib -, libX11 }: +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + wrapGAppsHook3, + withLibui ? true, + gtk3, + withUdisks ? stdenv.hostPlatform.isLinux, + udisks, + glib, + libX11, +}: stdenv.mkDerivation rec { pname = "usbimager"; @@ -16,11 +25,18 @@ stdenv.mkDerivation rec { sourceRoot = "${src.name}/src"; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; - buildInputs = lib.optionals withUdisks [ udisks glib ] + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; + buildInputs = + lib.optionals withUdisks [ + udisks + glib + ] ++ lib.optional (!withLibui) libX11 ++ lib.optional withLibui gtk3; - # libui is bundled with the source of usbimager as a compiled static library + # libui is bundled with the source of usbimager as a compiled static library postPatch = '' sed -i \ @@ -36,7 +52,8 @@ stdenv.mkDerivation rec { dontConfigure = true; - makeFlags = [ "PREFIX=$(out)" ] + makeFlags = + [ "PREFIX=$(out)" ] ++ lib.optional withLibui "USE_LIBUI=yes" ++ lib.optional withUdisks "USE_UDISKS2=yes"; diff --git a/pkgs/by-name/us/usbmuxd/package.nix b/pkgs/by-name/us/usbmuxd/package.nix index 6901767c9cf8a8..bf0ac9051ef274 100644 --- a/pkgs/by-name/us/usbmuxd/package.nix +++ b/pkgs/by-name/us/usbmuxd/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libimobiledevice -, libusb1 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libimobiledevice, + libusb1, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/us/usbmuxd2/package.nix b/pkgs/by-name/us/usbmuxd2/package.nix index e4674eb386f15f..4d3ac3daa3d515 100644 --- a/pkgs/by-name/us/usbmuxd2/package.nix +++ b/pkgs/by-name/us/usbmuxd2/package.nix @@ -1,14 +1,16 @@ -{ lib -, clangStdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libimobiledevice -, libusb1 -, avahi -, clang -, git -}: let +{ + lib, + clangStdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libimobiledevice, + libusb1, + avahi, + clang, + git, +}: +let libgeneral = clangStdenv.mkDerivation rec { pname = "libgeneral"; diff --git a/pkgs/by-name/us/usbredir/package.nix b/pkgs/by-name/us/usbredir/package.nix index 55feb41bec8a4f..d6642ad20b0109 100644 --- a/pkgs/by-name/us/usbredir/package.nix +++ b/pkgs/by-name/us/usbredir/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitLab -, pkg-config -, meson -, ninja -, glib -, libusb1 +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + meson, + ninja, + glib, + libusb1, }: stdenv.mkDerivation rec { @@ -40,7 +41,10 @@ stdenv.mkDerivation rec { "-Dfuzzing=disabled" ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = with lib; { description = "USB traffic redirection protocol"; diff --git a/pkgs/by-name/us/usbrip/package.nix b/pkgs/by-name/us/usbrip/package.nix index 219a4315fd1478..703c8e4deb55d0 100644 --- a/pkgs/by-name/us/usbrip/package.nix +++ b/pkgs/by-name/us/usbrip/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/us/usbsdmux/package.nix b/pkgs/by-name/us/usbsdmux/package.nix index 7794cf06d77d28..d50dff5fe10f8b 100644 --- a/pkgs/by-name/us/usbsdmux/package.nix +++ b/pkgs/by-name/us/usbsdmux/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "usbsdmux"; diff --git a/pkgs/by-name/us/usbtop/package.nix b/pkgs/by-name/us/usbtop/package.nix index af16a701383a99..0db9ee630354e6 100644 --- a/pkgs/by-name/us/usbtop/package.nix +++ b/pkgs/by-name/us/usbtop/package.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, fetchFromGitHub -, cmake -, libpcap, boost }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libpcap, + boost, +}: stdenv.mkDerivation rec { pname = "usbtop"; @@ -14,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libpcap boost ]; + buildInputs = [ + libpcap + boost + ]; meta = with lib; { homepage = "https://github.com/aguinet/usbtop"; diff --git a/pkgs/by-name/us/usbutils/package.nix b/pkgs/by-name/us/usbutils/package.nix index f55c4e9833674e..3ffd5fe88a6608 100644 --- a/pkgs/by-name/us/usbutils/package.nix +++ b/pkgs/by-name/us/usbutils/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, substituteAll, autoreconfHook, pkg-config, libusb1, hwdata, python3 }: +{ + lib, + stdenv, + fetchurl, + substituteAll, + autoreconfHook, + pkg-config, + libusb1, + hwdata, + python3, +}: stdenv.mkDerivation rec { pname = "usbutils"; @@ -16,10 +26,20 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libusb1 python3 ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libusb1 + python3 + ]; - outputs = [ "out" "man" "python" ]; + outputs = [ + "out" + "man" + "python" + ]; postBuild = '' $CC $NIX_CFLAGS -o usbreset usbreset.c @@ -37,7 +57,7 @@ stdenv.mkDerivation rec { license = with lib.licenses; [ gpl2Only # manpages, usbreset gpl2Plus # most of the code - ]; + ]; platforms = lib.platforms.linux; mainProgram = "lsusb"; }; diff --git a/pkgs/by-name/us/usbview/package.nix b/pkgs/by-name/us/usbview/package.nix index 17402fe76120ce..2fa506a18b8219 100644 --- a/pkgs/by-name/us/usbview/package.nix +++ b/pkgs/by-name/us/usbview/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, imagemagick -, gtk3 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + imagemagick, + gtk3, }: stdenv.mkDerivation rec { @@ -32,7 +33,10 @@ stdenv.mkDerivation rec { description = "USB viewer for Linux"; license = licenses.gpl2Only; homepage = "http://www.kroah.com/linux-usb/"; - maintainers = with maintainers; [ shamilton h7x4 ]; + maintainers = with maintainers; [ + shamilton + h7x4 + ]; platforms = platforms.linux; mainProgram = "usbview"; }; diff --git a/pkgs/by-name/us/userhosts/package.nix b/pkgs/by-name/us/userhosts/package.nix index 1433e0dd28ac72..bf6c1b58f8dbc9 100644 --- a/pkgs/by-name/us/userhosts/package.nix +++ b/pkgs/by-name/us/userhosts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "userhosts"; diff --git a/pkgs/by-name/us/usermount/package.nix b/pkgs/by-name/us/usermount/package.nix index 883e927444beec..3c847800003712 100644 --- a/pkgs/by-name/us/usermount/package.nix +++ b/pkgs/by-name/us/usermount/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, dbus, libnotify, udisks2, gdk-pixbuf }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + dbus, + libnotify, + udisks2, + gdk-pixbuf, +}: stdenv.mkDerivation { pname = "usermount"; @@ -12,7 +21,12 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dbus libnotify udisks2 gdk-pixbuf ]; + buildInputs = [ + dbus + libnotify + udisks2 + gdk-pixbuf + ]; env.NIX_CFLAGS_COMPILE = "-DENABLE_NOTIFICATIONS"; diff --git a/pkgs/by-name/us/usql/package.nix b/pkgs/by-name/us/usql/package.nix index 8122dd98137953..c30d608c292c01 100644 --- a/pkgs/by-name/us/usql/package.nix +++ b/pkgs/by-name/us/usql/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, unixODBC -, icu -, nix-update-script -, testers -, usql +{ + lib, + fetchFromGitHub, + buildGoModule, + unixODBC, + icu, + nix-update-script, + testers, + usql, }: buildGoModule rec { @@ -19,7 +20,10 @@ buildGoModule rec { hash = "sha256-gutAb6GkaHtZK0uw9+If/luIUn8jiGfruWtAV3nQJvE="; }; - buildInputs = [ unixODBC icu ]; + buildInputs = [ + unixODBC + icu + ]; vendorHash = "sha256-32tl3mXpFqthXMRERDvMsocfMW0ltSvnm8/+NKiSjmE="; proxyVendor = true; @@ -69,7 +73,10 @@ buildGoModule rec { changelog = "https://github.com/xo/usql/releases/tag/v${version}"; license = licenses.mit; mainProgram = "usql"; - maintainers = with maintainers; [ georgyo anthonyroussel ]; + maintainers = with maintainers; [ + georgyo + anthonyroussel + ]; platforms = with platforms; linux ++ darwin; }; } diff --git a/pkgs/by-name/us/usrsctp/package.nix b/pkgs/by-name/us/usrsctp/package.nix index 58448d0a453d7a..9d5e72f1f2c65b 100644 --- a/pkgs/by-name/us/usrsctp/package.nix +++ b/pkgs/by-name/us/usrsctp/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, cmake }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, +}: stdenv.mkDerivation rec { pname = "usrsctp"; diff --git a/pkgs/by-name/us/ustreamer/package.nix b/pkgs/by-name/us/ustreamer/package.nix index 512e6e8515c81f..58dce6de7c9a45 100644 --- a/pkgs/by-name/us/ustreamer/package.nix +++ b/pkgs/by-name/us/ustreamer/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, libbsd -, libevent -, libjpeg -, libdrm -, pkg-config -, janus-gateway -, glib -, alsa-lib -, speex -, jansson -, libopus -, nixosTests -, withJanus ? true +{ + lib, + stdenv, + fetchFromGitHub, + libbsd, + libevent, + libjpeg, + libdrm, + pkg-config, + janus-gateway, + glib, + alsa-lib, + speex, + jansson, + libopus, + nixosTests, + withJanus ? true, }: stdenv.mkDerivation rec { pname = "ustreamer"; @@ -26,31 +27,35 @@ stdenv.mkDerivation rec { hash = "sha256-iaCgPHgklk7tbhJhQmyjKggb1bMWBD+Zurgfk9sCQ3E="; }; - buildInputs = [ - libbsd - libevent - libjpeg - libdrm - ] ++ lib.optionals withJanus [ - janus-gateway - glib - alsa-lib - jansson - speex - libopus - ]; + buildInputs = + [ + libbsd + libevent + libjpeg + libdrm + ] + ++ lib.optionals withJanus [ + janus-gateway + glib + alsa-lib + jansson + speex + libopus + ]; nativeBuildInputs = [ pkg-config ]; - makeFlags = [ - "PREFIX=${placeholder "out"}" - "WITH_V4P=1" - ] ++ lib.optionals withJanus [ - "WITH_JANUS=1" - # Workaround issues with Janus C Headers - # https://github.com/pikvm/ustreamer/blob/793f24c4/docs/h264.md#fixing-janus-c-headers - "CFLAGS=-I${lib.getDev janus-gateway}/include/janus" - ]; + makeFlags = + [ + "PREFIX=${placeholder "out"}" + "WITH_V4P=1" + ] + ++ lib.optionals withJanus [ + "WITH_JANUS=1" + # Workaround issues with Janus C Headers + # https://github.com/pikvm/ustreamer/blob/793f24c4/docs/h264.md#fixing-janus-c-headers + "CFLAGS=-I${lib.getDev janus-gateway}/include/janus" + ]; enableParallelBuilding = true; @@ -67,7 +72,10 @@ stdenv.mkDerivation rec { screencast hardware data with the highest resolution and FPS possible. ''; license = licenses.gpl3Plus; - maintainers = with maintainers; [ tfc matthewcroughan ]; + maintainers = with maintainers; [ + tfc + matthewcroughan + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/us/usync/package.nix b/pkgs/by-name/us/usync/package.nix index 7a5abda593029f..872aa26187b7d0 100644 --- a/pkgs/by-name/us/usync/package.nix +++ b/pkgs/by-name/us/usync/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, scsh, rsync, unison }: +{ + lib, + stdenv, + fetchFromGitHub, + scsh, + rsync, + unison, +}: stdenv.mkDerivation rec { pname = "usync"; diff --git a/pkgs/by-name/ut/ut/package.nix b/pkgs/by-name/ut/ut/package.nix index 9ee03e9c98ff7d..9ec4f95c712171 100644 --- a/pkgs/by-name/ut/ut/package.nix +++ b/pkgs/by-name/ut/ut/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, }: stdenv.mkDerivation (finalAttrs: { pname = "ut"; @@ -32,4 +33,3 @@ stdenv.mkDerivation (finalAttrs: { platforms = platforms.all; }; }) - diff --git a/pkgs/by-name/ut/ut1999/package.nix b/pkgs/by-name/ut/ut1999/package.nix index db063696996f14..fd9e1b5e97ee21 100644 --- a/pkgs/by-name/ut/ut1999/package.nix +++ b/pkgs/by-name/ut/ut1999/package.nix @@ -1,5 +1,23 @@ -{ lib, stdenv, requireFile, autoPatchelfHook, undmg, fetchurl, makeDesktopItem, copyDesktopItems, imagemagick -, runCommand, libgcc, wxGTK32, innoextract, libGL, SDL2, openal, libmpg123, libxmp }: +{ + lib, + stdenv, + requireFile, + autoPatchelfHook, + undmg, + fetchurl, + makeDesktopItem, + copyDesktopItems, + imagemagick, + runCommand, + libgcc, + wxGTK32, + innoextract, + libGL, + SDL2, + openal, + libmpg123, + libxmp, +}: let version = "469d"; @@ -21,36 +39,43 @@ let hash = "sha256-TbhJbOH4E5WOb6XR9dmqLkXziK3/CzhNjd1ypBkkmvw="; }; }; - unpackGog = runCommand "ut1999-gog" { - src = requireFile rec { - name = "setup_ut_goty_2.0.0.5.exe"; - hash = "sha256-TMJX1U2XZZxQYvK/GG0KjGlZVh0R5C2Pzy6sB/GSaAM="; - message = '' - Unreal Tournament 1999 requires the official GOG package, version 2.0.0.5. + unpackGog = + runCommand "ut1999-gog" + { + src = requireFile rec { + name = "setup_ut_goty_2.0.0.5.exe"; + hash = "sha256-TMJX1U2XZZxQYvK/GG0KjGlZVh0R5C2Pzy6sB/GSaAM="; + message = '' + Unreal Tournament 1999 requires the official GOG package, version 2.0.0.5. - Once you download the file, run the following command: + Once you download the file, run the following command: - nix-prefetch-url file://\$PWD/${name} - ''; - }; + nix-prefetch-url file://\$PWD/${name} + ''; + }; - nativeBuildInputs = [ innoextract ]; - } '' - innoextract --extract --exclude-temp "$src" - mkdir $out - cp -r app/* $out - ''; - systemDir = { - x86_64-linux = "System64"; - aarch64-linux = "SystemARM64"; - x86_64-darwin = "System"; - i686-linux = "System"; - }.${stdenv.hostPlatform.system} or (throw "unsupported system: ${stdenv.hostPlatform.system}"); -in stdenv.mkDerivation { + nativeBuildInputs = [ innoextract ]; + } + '' + innoextract --extract --exclude-temp "$src" + mkdir $out + cp -r app/* $out + ''; + systemDir = + { + x86_64-linux = "System64"; + aarch64-linux = "SystemARM64"; + x86_64-darwin = "System"; + i686-linux = "System"; + } + .${stdenv.hostPlatform.system} or (throw "unsupported system: ${stdenv.hostPlatform.system}"); +in +stdenv.mkDerivation { name = "ut1999"; inherit version; sourceRoot = "."; - src = srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); buildInputs = [ libgcc @@ -63,44 +88,51 @@ in stdenv.mkDerivation { stdenv.cc.cc ]; - nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - copyDesktopItems - autoPatchelfHook - imagemagick - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - undmg - ]; + nativeBuildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + copyDesktopItems + autoPatchelfHook + imagemagick + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + undmg + ]; - installPhase = let - outPrefix = if stdenv.hostPlatform.isDarwin then "$out/UnrealTournament.app/Contents/MacOS" else "$out"; - in '' - runHook preInstall + installPhase = + let + outPrefix = + if stdenv.hostPlatform.isDarwin then "$out/UnrealTournament.app/Contents/MacOS" else "$out"; + in + '' + runHook preInstall - mkdir -p $out/bin - cp -r ${if stdenv.hostPlatform.isDarwin then "UnrealTournament.app" else "./*"} $out - chmod -R 755 $out - cd ${outPrefix} + mkdir -p $out/bin + cp -r ${if stdenv.hostPlatform.isDarwin then "UnrealTournament.app" else "./*"} $out + chmod -R 755 $out + cd ${outPrefix} - rm -rf ./{Music,Sounds,Maps} - ln -s ${unpackGog}/{Music,Sounds,Maps} . + rm -rf ./{Music,Sounds,Maps} + ln -s ${unpackGog}/{Music,Sounds,Maps} . - cp -n ${unpackGog}/Textures/* ./Textures || true - cp -n ${unpackGog}/System/*.{u,int} ./System || true - '' + lib.optionalString (stdenv.hostPlatform.isLinux) '' - ln -s "$out/${systemDir}/ut-bin" "$out/bin/ut1999" - ln -s "$out/${systemDir}/ucc-bin" "$out/bin/ut1999-ucc" + cp -n ${unpackGog}/Textures/* ./Textures || true + cp -n ${unpackGog}/System/*.{u,int} ./System || true + '' + + lib.optionalString (stdenv.hostPlatform.isLinux) '' + ln -s "$out/${systemDir}/ut-bin" "$out/bin/ut1999" + ln -s "$out/${systemDir}/ucc-bin" "$out/bin/ut1999-ucc" - convert "${unpackGog}/gfw_high.ico" "ut1999.png" - install -D ut1999-5.png "$out/share/icons/hicolor/256x256/apps/ut1999.png" + convert "${unpackGog}/gfw_high.ico" "ut1999.png" + install -D ut1999-5.png "$out/share/icons/hicolor/256x256/apps/ut1999.png" - # Remove bundled libraries to use native versions instead - rm $out/${systemDir}/libmpg123.so* \ - $out/${systemDir}/libopenal.so* \ - $out/${systemDir}/libSDL2* \ - $out/${systemDir}/libxmp.so* - '' + '' - runHook postInstall - ''; + # Remove bundled libraries to use native versions instead + rm $out/${systemDir}/libmpg123.so* \ + $out/${systemDir}/libopenal.so* \ + $out/${systemDir}/libSDL2* \ + $out/${systemDir}/libxmp.so* + '' + + '' + runHook postInstall + ''; # Bring in game's .so files into lookup. Otherwise game fails to start # as: `Object not found: Class Render.Render` diff --git a/pkgs/by-name/ut/utf8cpp/package.nix b/pkgs/by-name/ut/utf8cpp/package.nix index 18c253cc5c618b..4ab4fe494edc1a 100644 --- a/pkgs/by-name/ut/utf8cpp/package.nix +++ b/pkgs/by-name/ut/utf8cpp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "utf8cpp"; diff --git a/pkgs/by-name/ut/utf8proc/package.nix b/pkgs/by-name/ut/utf8proc/package.nix index f248d6d9722551..3d849a5417a9e2 100644 --- a/pkgs/by-name/ut/utf8proc/package.nix +++ b/pkgs/by-name/ut/utf8proc/package.nix @@ -1,8 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, # passthru.tests -, tmux -, fcft -, arrow-cpp + tmux, + fcft, + arrow-cpp, }: stdenv.mkDerivation rec { @@ -34,6 +38,9 @@ stdenv.mkDerivation rec { homepage = "https://juliastrings.github.io/utf8proc/"; license = licenses.mit; platforms = platforms.all; - maintainers = [ maintainers.ftrvxmtrx maintainers.sternenseemann ]; + maintainers = [ + maintainers.ftrvxmtrx + maintainers.sternenseemann + ]; }; } diff --git a/pkgs/by-name/ut/uthash/package.nix b/pkgs/by-name/ut/uthash/package.nix index 98c5200fcc2c67..439324f8c009dc 100644 --- a/pkgs/by-name/ut/uthash/package.nix +++ b/pkgs/by-name/ut/uthash/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation rec { pname = "uthash"; @@ -22,8 +27,8 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Hash table for C structures"; - homepage = "http://troydhanson.github.io/uthash"; - license = licenses.bsd2; # it's one-clause, actually, as it's source-only - platforms = platforms.all; + homepage = "http://troydhanson.github.io/uthash"; + license = licenses.bsd2; # it's one-clause, actually, as it's source-only + platforms = platforms.all; }; } diff --git a/pkgs/by-name/ut/uthenticode/package.nix b/pkgs/by-name/ut/uthenticode/package.nix index e8d08745de8f2a..85e1e65086b894 100644 --- a/pkgs/by-name/ut/uthenticode/package.nix +++ b/pkgs/by-name/ut/uthenticode/package.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, cmake, gtest, openssl, pe-parse }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + gtest, + openssl, + pe-parse, +}: stdenv.mkDerivation rec { pname = "uthenticode"; @@ -11,11 +19,17 @@ stdenv.mkDerivation rec { hash = "sha256-NGVOGXMRlgpSRw56jr63rJc/5/qCmPjtAFa0D21ogd4="; }; - cmakeFlags = [ "-DBUILD_TESTS=1" "-DUSE_EXTERNAL_GTEST=1" ]; + cmakeFlags = [ + "-DBUILD_TESTS=1" + "-DUSE_EXTERNAL_GTEST=1" + ]; nativeBuildInputs = [ cmake ]; nativeCheckInputs = [ gtest ]; - buildInputs = [ pe-parse openssl ]; + buildInputs = [ + pe-parse + openssl + ]; doCheck = true; checkPhase = "test/uthenticode_test"; diff --git a/pkgs/by-name/ut/util-linux/package.nix b/pkgs/by-name/ut/util-linux/package.nix index 83c0789a15ea59..b852ad01981095 100644 --- a/pkgs/by-name/ut/util-linux/package.nix +++ b/pkgs/by-name/ut/util-linux/package.nix @@ -1,25 +1,33 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, zlib, shadow -, capabilitiesSupport ? stdenv.hostPlatform.isLinux -, libcap_ng -, libxcrypt -, ncursesSupport ? true -, ncurses -, pamSupport ? true -, pam -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd -, systemd -, nlsSupport ? true -, translateManpages ? true -, po4a -, installShellFiles -, writeSupport ? stdenv.hostPlatform.isLinux -, shadowSupport ? stdenv.hostPlatform.isLinux -, memstreamHook -, gitUpdater +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + zlib, + shadow, + capabilitiesSupport ? stdenv.hostPlatform.isLinux, + libcap_ng, + libxcrypt, + ncursesSupport ? true, + ncurses, + pamSupport ? true, + pam, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + nlsSupport ? true, + translateManpages ? true, + po4a, + installShellFiles, + writeSupport ? stdenv.hostPlatform.isLinux, + shadowSupport ? stdenv.hostPlatform.isLinux, + memstreamHook, + gitUpdater, }: stdenv.mkDerivation rec { - pname = "util-linux" + lib.optionalString (!nlsSupport && !ncursesSupport && !systemdSupport) "-minimal"; + pname = + "util-linux" + lib.optionalString (!nlsSupport && !ncursesSupport && !systemdSupport) "-minimal"; version = "2.39.4"; src = fetchurl { @@ -42,49 +50,62 @@ stdenv.mkDerivation rec { # the greater util-linux toolset. # Compatibility is maintained by symlinking the binaries from the # smaller outputs in the bin output. - outputs = [ "bin" "dev" "out" "lib" "man" ] ++ lib.optionals stdenv.hostPlatform.isLinux [ "mount" ] ++ [ "login" ] ++ lib.optionals stdenv.hostPlatform.isLinux [ "swap" ]; + outputs = + [ + "bin" + "dev" + "out" + "lib" + "man" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ "mount" ] + ++ [ "login" ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ "swap" ]; separateDebugInfo = true; - postPatch = '' - patchShebangs tests/run.sh - - substituteInPlace sys-utils/eject.c \ - --replace "/bin/umount" "$bin/bin/umount" - '' + lib.optionalString shadowSupport '' - substituteInPlace include/pathnames.h \ - --replace "/bin/login" "${shadow}/bin/login" - '' + lib.optionalString stdenv.hostPlatform.isFreeBSD '' - substituteInPlace lib/c_strtod.c --replace-fail __APPLE__ __FreeBSD__ - sed -E -i -e '/_POSIX_C_SOURCE/d' -e '/_XOPEN_SOURCE/d' misc-utils/hardlink.c - ''; + postPatch = + '' + patchShebangs tests/run.sh + + substituteInPlace sys-utils/eject.c \ + --replace "/bin/umount" "$bin/bin/umount" + '' + + lib.optionalString shadowSupport '' + substituteInPlace include/pathnames.h \ + --replace "/bin/login" "${shadow}/bin/login" + '' + + lib.optionalString stdenv.hostPlatform.isFreeBSD '' + substituteInPlace lib/c_strtod.c --replace-fail __APPLE__ __FreeBSD__ + sed -E -i -e '/_POSIX_C_SOURCE/d' -e '/_XOPEN_SOURCE/d' misc-utils/hardlink.c + ''; # !!! It would be better to obtain the path to the mount helpers # (/sbin/mount.*) through an environment variable, but that's # somewhat risky because we have to consider that mount can setuid # root... - configureFlags = [ - "--localstatedir=/var" - "--disable-use-tty-group" - "--enable-fs-paths-default=/run/wrappers/bin:/run/current-system/sw/bin:/sbin" - "--disable-makeinstall-setuid" "--disable-makeinstall-chown" - "--disable-su" # provided by shadow - (lib.enableFeature writeSupport "write") - (lib.enableFeature nlsSupport "nls") - (lib.withFeature ncursesSupport "ncursesw") - (lib.withFeature systemdSupport "systemd") - (lib.withFeatureAs systemdSupport - "systemdsystemunitdir" "${placeholder "bin"}/lib/systemd/system/") - (lib.enableFeature translateManpages "poman") - "SYSCONFSTATICDIR=${placeholder "lib"}/lib" - ] ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) - "scanf_cv_type_modifier=ms" - ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ - # These features are all disabled in the freebsd-ports distribution - "--disable-nls" - "--disable-ipcrm" - "--disable-ipcs" - ] - ; + configureFlags = + [ + "--localstatedir=/var" + "--disable-use-tty-group" + "--enable-fs-paths-default=/run/wrappers/bin:/run/current-system/sw/bin:/sbin" + "--disable-makeinstall-setuid" + "--disable-makeinstall-chown" + "--disable-su" # provided by shadow + (lib.enableFeature writeSupport "write") + (lib.enableFeature nlsSupport "nls") + (lib.withFeature ncursesSupport "ncursesw") + (lib.withFeature systemdSupport "systemd") + (lib.withFeatureAs systemdSupport "systemdsystemunitdir" "${placeholder "bin"}/lib/systemd/system/") + (lib.enableFeature translateManpages "poman") + "SYSCONFSTATICDIR=${placeholder "lib"}/lib" + ] + ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "scanf_cv_type_modifier=ms" + ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ + # These features are all disabled in the freebsd-ports distribution + "--disable-nls" + "--disable-ipcrm" + "--disable-ipcs" + ]; makeFlags = [ "usrbin_execdir=${placeholder "bin"}/bin" @@ -92,10 +113,16 @@ stdenv.mkDerivation rec { "usrsbin_execdir=${placeholder "bin"}/sbin" ]; - nativeBuildInputs = [ pkg-config installShellFiles ] - ++ lib.optionals translateManpages [ po4a ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ] ++ lib.optionals translateManpages [ po4a ]; - buildInputs = [ zlib libxcrypt ] + buildInputs = + [ + zlib + libxcrypt + ] ++ lib.optionals pamSupport [ pam ] ++ lib.optionals capabilitiesSupport [ libcap_ng ] ++ lib.optionals ncursesSupport [ ncurses ] @@ -106,29 +133,33 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' - moveToOutput bin/mount "$mount" - moveToOutput bin/umount "$mount" - ln -svf "$mount/bin/"* $bin/bin/ - '' + '' - - moveToOutput sbin/nologin "$login" - moveToOutput sbin/sulogin "$login" - prefix=$login _moveSbin - ln -svf "$login/bin/"* $bin/bin/ - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - - moveToOutput sbin/swapon "$swap" - moveToOutput sbin/swapoff "$swap" - prefix=$swap _moveSbin - ln -svf "$swap/bin/"* $bin/bin/ - '' + '' - - ln -svf "$bin/bin/hexdump" "$bin/bin/hd" - ln -svf "$man/share/man/man1/hexdump.1" "$man/share/man/man1/hd.1" - - installShellCompletion --bash bash-completion/* - ''; + postInstall = + lib.optionalString stdenv.hostPlatform.isLinux '' + moveToOutput bin/mount "$mount" + moveToOutput bin/umount "$mount" + ln -svf "$mount/bin/"* $bin/bin/ + '' + + '' + + moveToOutput sbin/nologin "$login" + moveToOutput sbin/sulogin "$login" + prefix=$login _moveSbin + ln -svf "$login/bin/"* $bin/bin/ + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + + moveToOutput sbin/swapon "$swap" + moveToOutput sbin/swapoff "$swap" + prefix=$swap _moveSbin + ln -svf "$swap/bin/"* $bin/bin/ + '' + + '' + + ln -svf "$bin/bin/hexdump" "$bin/bin/hd" + ln -svf "$man/share/man/man1/hexdump.1" "$man/share/man/man1/hd.1" + + installShellCompletion --bash bash-completion/* + ''; passthru = { updateScript = gitUpdater { @@ -144,7 +175,15 @@ stdenv.mkDerivation rec { description = "Set of system utilities for Linux"; changelog = "https://mirrors.edge.kernel.org/pub/linux/utils/util-linux/v${lib.versions.majorMinor version}/v${version}-ReleaseNotes"; # https://git.kernel.org/pub/scm/utils/util-linux/util-linux.git/tree/README.licensing - license = with licenses; [ gpl2Only gpl2Plus gpl3Plus lgpl21Plus bsd3 bsdOriginalUC publicDomain ]; + license = with licenses; [ + gpl2Only + gpl2Plus + gpl3Plus + lgpl21Plus + bsd3 + bsdOriginalUC + publicDomain + ]; platforms = platforms.unix; pkgConfigModules = [ "blkid" diff --git a/pkgs/by-name/ut/utox/package.nix b/pkgs/by-name/ut/utox/package.nix index 259735919cd5d0..58aff9b45cf041 100644 --- a/pkgs/by-name/ut/utox/package.nix +++ b/pkgs/by-name/ut/utox/package.nix @@ -1,6 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, check, cmake, pkg-config -, libtoxcore, filter-audio, dbus, libvpx, libX11, openal, freetype, libv4l -, libXrender, fontconfig, libXext, libXft, libsodium, libopus }: +{ + lib, + stdenv, + fetchFromGitHub, + check, + cmake, + pkg-config, + libtoxcore, + filter-audio, + dbus, + libvpx, + libX11, + openal, + freetype, + libv4l, + libXrender, + fontconfig, + libXext, + libXft, + libsodium, + libopus, +}: stdenv.mkDerivation rec { pname = "utox"; @@ -8,21 +27,33 @@ stdenv.mkDerivation rec { version = "0.18.1"; src = fetchFromGitHub { - owner = "uTox"; - repo = "uTox"; - rev = "v${version}"; + owner = "uTox"; + repo = "uTox"; + rev = "v${version}"; hash = "sha256-DxnolxUTn+CL6TbZHKLHOUMTHhtTSWufzzOTRpKjOwc="; fetchSubmodules = true; }; buildInputs = [ - libtoxcore dbus libvpx libX11 openal freetype - libv4l libXrender fontconfig libXext libXft filter-audio - libsodium libopus + libtoxcore + dbus + libvpx + libX11 + openal + freetype + libv4l + libXrender + fontconfig + libXext + libXft + filter-audio + libsodium + libopus ]; nativeBuildInputs = [ - cmake pkg-config + cmake + pkg-config ]; cmakeFlags = [ diff --git a/pkgs/by-name/ut/utterly-round-plasma-style/package.nix b/pkgs/by-name/ut/utterly-round-plasma-style/package.nix index 7510183b10f356..60137219288c91 100644 --- a/pkgs/by-name/ut/utterly-round-plasma-style/package.nix +++ b/pkgs/by-name/ut/utterly-round-plasma-style/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/uu/uucp/package.nix b/pkgs/by-name/uu/uucp/package.nix index 35bc7a2721001a..f94b84b646d662 100644 --- a/pkgs/by-name/uu/uucp/package.nix +++ b/pkgs/by-name/uu/uucp/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, autoreconfHook, testers }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "uucp"; diff --git a/pkgs/by-name/uu/uudeview/package.nix b/pkgs/by-name/uu/uudeview/package.nix index 19481670217695..511ccd0efd1be8 100644 --- a/pkgs/by-name/uu/uudeview/package.nix +++ b/pkgs/by-name/uu/uudeview/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, tcl -, tk +{ + lib, + stdenv, + fetchurl, + fetchpatch, + tcl, + tk, }: stdenv.mkDerivation rec { @@ -15,9 +16,15 @@ stdenv.mkDerivation rec { sha256 = "0dg4v888fxhmf51vxq1z1gd57fslsidn15jf42pj4817vw6m36p4"; }; - buildInputs = [ tcl tk ]; + buildInputs = [ + tcl + tk + ]; - configureFlags = [ "--enable-tk=${tk.dev}" "--enable-tcl=${tcl}" ]; + configureFlags = [ + "--enable-tk=${tk.dev}" + "--enable-tcl=${tcl}" + ]; patches = [ # https://wiki.tcl.tk/3577 diff --git a/pkgs/by-name/uu/uuu/package.nix b/pkgs/by-name/uu/uuu/package.nix index b7e2ba41239acf..6ddf35a37b2f2f 100644 --- a/pkgs/by-name/uu/uuu/package.nix +++ b/pkgs/by-name/uu/uuu/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, -, cmake -, installShellFiles -, pkg-config + cmake, + installShellFiles, + pkg-config, -, bzip2 -, libusb1 -, openssl -, tinyxml-2 -, zlib -, zstd + bzip2, + libusb1, + openssl, + tinyxml-2, + zlib, + zstd, }: stdenv.mkDerivation (finalAttrs: { @@ -27,7 +28,10 @@ stdenv.mkDerivation (finalAttrs: { }; passthru.updateScript = nix-update-script { - extraArgs = [ "--version-regex" "uuu_\([0-9.]+\)" ]; + extraArgs = [ + "--version-regex" + "uuu_\([0-9.]+\)" + ]; }; nativeBuildInputs = [ diff --git a/pkgs/by-name/uv/uvccapture/package.nix b/pkgs/by-name/uv/uvccapture/package.nix index f7067c8dd71a3a..8d2132a762c85a 100644 --- a/pkgs/by-name/uv/uvccapture/package.nix +++ b/pkgs/by-name/uv/uvccapture/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libjpeg }: +{ + lib, + stdenv, + fetchurl, + libjpeg, +}: let debianPatches = fetchurl { diff --git a/pkgs/by-name/uv/uvcdynctrl/package.nix b/pkgs/by-name/uv/uvcdynctrl/package.nix index c8e3fc385fdf5c..91fa8a0eabf4a9 100644 --- a/pkgs/by-name/uv/uvcdynctrl/package.nix +++ b/pkgs/by-name/uv/uvcdynctrl/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, libxml2 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libxml2, +}: stdenv.mkDerivation { version = "0.3.0"; @@ -11,7 +18,10 @@ stdenv.mkDerivation { sha256 = "0s15xxgdx8lnka7vi8llbf6b0j4rhbjl6yp0qxaihysf890xj73s"; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libxml2 ]; prePatch = '' diff --git a/pkgs/by-name/uw/uw-ttyp0/package.nix b/pkgs/by-name/uw/uw-ttyp0/package.nix index f8006516e27636..eb5df76c90c2b0 100644 --- a/pkgs/by-name/uw/uw-ttyp0/package.nix +++ b/pkgs/by-name/uw/uw-ttyp0/package.nix @@ -1,7 +1,13 @@ -{ lib, stdenv, fetchurl, perl -, bdftopcf, bdf2psf, xorg -, targetsDat ? null -, variantsDat ? null +{ + lib, + stdenv, + fetchurl, + perl, + bdftopcf, + bdf2psf, + xorg, + targetsDat ? null, + variantsDat ? null, }: stdenv.mkDerivation rec { @@ -16,28 +22,40 @@ stdenv.mkDerivation rec { # remove for version >1.3 patches = [ ./determinism.patch ]; - nativeBuildInputs = [ perl bdftopcf bdf2psf xorg.fonttosfnt xorg.mkfontdir ]; + nativeBuildInputs = [ + perl + bdftopcf + bdf2psf + xorg.fonttosfnt + xorg.mkfontdir + ]; # configure sizes, encodings and variants preConfigure = - (if targetsDat == null - then '' - cat << EOF > TARGETS.dat - SIZES = 11 12 13 14 15 16 17 18 22 \ - 11b 12b 13b 14b 15b 16b 17b 18b 22b 15i 16i 17i 18i - ENCODINGS = uni - EOF - '' - else ''cp "${targetsDat}" TARGETS.dat'') + - (if variantsDat == null - then '' - cat << EOF > VARIANTS.dat - COPYTO AccStress PApostropheAscii - COPYTO PAmComma AccGraveAscii - COPYTO Digit0Slashed Digit0 - EOF - '' - else ''cp "${variantsDat}" VARIANTS.dat''); + ( + if targetsDat == null then + '' + cat << EOF > TARGETS.dat + SIZES = 11 12 13 14 15 16 17 18 22 \ + 11b 12b 13b 14b 15b 16b 17b 18b 22b 15i 16i 17i 18i + ENCODINGS = uni + EOF + '' + else + ''cp "${targetsDat}" TARGETS.dat'' + ) + + ( + if variantsDat == null then + '' + cat << EOF > VARIANTS.dat + COPYTO AccStress PApostropheAscii + COPYTO PAmComma AccGraveAscii + COPYTO Digit0Slashed Digit0 + EOF + '' + else + ''cp "${variantsDat}" VARIANTS.dat'' + ); postBuild = '' # convert bdf fonts to psf @@ -82,7 +100,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Monospace bitmap screen fonts for X11"; homepage = "https://people.mpi-inf.mpg.de/~uwe/misc/uw-ttyp0/"; - license = with licenses; [ free mit ]; + license = with licenses; [ + free + mit + ]; maintainers = with maintainers; [ rnhmjoj ]; }; diff --git a/pkgs/by-name/uw/uwc/package.nix b/pkgs/by-name/uw/uwc/package.nix index db6868f161d13f..5a6fe1960b891d 100644 --- a/pkgs/by-name/uw/uwc/package.nix +++ b/pkgs/by-name/uw/uwc/package.nix @@ -1,4 +1,8 @@ -{ rustPlatform, lib, fetchFromGitHub }: +{ + rustPlatform, + lib, + fetchFromGitHub, +}: rustPlatform.buildRustPackage rec { pname = "uwc"; diff --git a/pkgs/by-name/uw/uwhoisd/package.nix b/pkgs/by-name/uw/uwhoisd/package.nix index 81080d476e8e35..3eac31c31aeed3 100644 --- a/pkgs/by-name/uw/uwhoisd/package.nix +++ b/pkgs/by-name/uw/uwhoisd/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { @@ -24,12 +25,15 @@ python3.pkgs.buildPythonApplication rec { poetry-core ]; - propagatedBuildInputs = with python3.pkgs; [ - beautifulsoup4 - publicsuffix2 - redis - tornado - ] ++ redis.optional-dependencies.hiredis; + propagatedBuildInputs = + with python3.pkgs; + [ + beautifulsoup4 + publicsuffix2 + redis + tornado + ] + ++ redis.optional-dependencies.hiredis; # Project has no tests doCheck = false; diff --git a/pkgs/by-name/uw/uwimap/package.nix b/pkgs/by-name/uw/uwimap/package.nix index a359e7677ac2a4..86a6e1b0cee786 100644 --- a/pkgs/by-name/uw/uwimap/package.nix +++ b/pkgs/by-name/uw/uwimap/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchpatch, pam, openssl, libkrb5 }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pam, + openssl, + libkrb5, +}: stdenv.mkDerivation rec { pname = "uw-imap"; @@ -12,17 +20,14 @@ stdenv.mkDerivation rec { makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "RANLIB=${stdenv.cc.targetPrefix}ranlib" - (if stdenv.hostPlatform.isDarwin - then "osx" - else "lnp") # Linux with PAM modules; + (if stdenv.hostPlatform.isDarwin then "osx" else "lnp") # Linux with PAM modules; ] ++ lib.optional stdenv.hostPlatform.isx86_64 "EXTRACFLAGS=-fPIC"; # -fPIC is required to compile php with imap on x86_64 systems - hardeningDisable = [ "format" ]; buildInputs = [ openssl - (if stdenv.hostPlatform.isDarwin then libkrb5 else pam) # Matches the make target. + (if stdenv.hostPlatform.isDarwin then libkrb5 else pam) # Matches the make target. ]; patches = [ @@ -45,8 +50,7 @@ stdenv.mkDerivation rec { makeFlagsArray+=("ARRC=${stdenv.cc.targetPrefix}ar rc") ''; - env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin - "-I${openssl.dev}/include/openssl"; + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-I${openssl.dev}/include/openssl"; installPhase = '' mkdir -p $out/bin $out/lib $out/include/c-client diff --git a/pkgs/by-name/uw/uwsgi/package.nix b/pkgs/by-name/uw/uwsgi/package.nix index f677ace2b79312..2bd995ad5a4aea 100644 --- a/pkgs/by-name/uw/uwsgi/package.nix +++ b/pkgs/by-name/uw/uwsgi/package.nix @@ -1,20 +1,28 @@ -{ stdenv -, nixosTests -, lib -, pkg-config -, jansson -, pcre -, libxcrypt -, expat -, zlib -# plugins: list of strings, eg. [ "python2" "python3" ] -, plugins ? [] -, pam, withPAM ? stdenv.hostPlatform.isLinux -, systemd, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, libcap, withCap ? stdenv.hostPlatform.isLinux -, python2, python3, ncurses -, ruby, php -, makeWrapper, fetchFromGitHub +{ + stdenv, + nixosTests, + lib, + pkg-config, + jansson, + pcre, + libxcrypt, + expat, + zlib, + # plugins: list of strings, eg. [ "python2" "python3" ] + plugins ? [ ], + pam, + withPAM ? stdenv.hostPlatform.isLinux, + systemd, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + libcap, + withCap ? stdenv.hostPlatform.isLinux, + python2, + python3, + ncurses, + ruby, + php, + makeWrapper, + fetchFromGitHub, }: let @@ -23,16 +31,21 @@ let apxs2Support = false; }; - pythonPlugin = pkg : lib.nameValuePair "python${if pkg.isPy2 then "2" else "3"}" { - interpreter = pkg.pythonOnBuildForHost.interpreter; - path = "plugins/python"; - inputs = [ pkg ncurses ]; - install = '' - install -Dm644 uwsgidecorators.py $out/${pkg.sitePackages}/uwsgidecorators.py - ${pkg.pythonOnBuildForHost.executable} -m compileall $out/${pkg.sitePackages}/ - ${pkg.pythonOnBuildForHost.executable} -O -m compileall $out/${pkg.sitePackages}/ - ''; - }; + pythonPlugin = + pkg: + lib.nameValuePair "python${if pkg.isPy2 then "2" else "3"}" { + interpreter = pkg.pythonOnBuildForHost.interpreter; + path = "plugins/python"; + inputs = [ + pkg + ncurses + ]; + install = '' + install -Dm644 uwsgidecorators.py $out/${pkg.sitePackages}/uwsgidecorators.py + ${pkg.pythonOnBuildForHost.executable} -m compileall $out/${pkg.sitePackages}/ + ${pkg.pythonOnBuildForHost.executable} -O -m compileall $out/${pkg.sitePackages}/ + ''; + }; available = lib.listToAttrs [ (pythonPlugin python2) @@ -50,21 +63,23 @@ let # usage: https://uwsgi-docs.readthedocs.io/en/latest/PHP.html#running-php-apps-with-nginx path = "plugins/php"; inputs = [ - php-embed - php-embed.extensions.session - php-embed.extensions.session.dev - php-embed.unwrapped.dev + php-embed + php-embed.extensions.session + php-embed.extensions.session.dev + php-embed.unwrapped.dev ] ++ php-embed.unwrapped.buildInputs; }) ]; - getPlugin = name: + getPlugin = + name: let all = lib.concatStringsSep ", " (lib.attrNames available); in - if lib.hasAttr name available - then lib.getAttr name available // { inherit name; } - else throw "Unknown UWSGI plugin ${name}, available : ${all}"; + if lib.hasAttr name available then + lib.getAttr name available // { inherit name; } + else + throw "Unknown UWSGI plugin ${name}, available : ${all}"; needed = builtins.map getPlugin plugins; in @@ -91,17 +106,24 @@ stdenv.mkDerivation (finalAttrs: { python3 ]; - buildInputs = [ jansson pcre libxcrypt ] - ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ expat zlib ] + buildInputs = + [ + jansson + pcre + libxcrypt + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + expat + zlib + ] ++ lib.optional withPAM pam ++ lib.optional withSystemd systemd ++ lib.optional withCap libcap ++ lib.concatMap (x: x.inputs) needed; - basePlugins = lib.concatStringsSep "," - ( lib.optional withPAM "pam" - ++ lib.optional withSystemd "systemd_logger" - ); + basePlugins = lib.concatStringsSep "," ( + lib.optional withPAM "pam" ++ lib.optional withSystemd "systemd_logger" + ); UWSGI_INCLUDES = lib.optionalString withCap "${libcap.dev}/include"; @@ -129,21 +151,24 @@ stdenv.mkDerivation (finalAttrs: { # this is a hack to make the php plugin link with session.so (which on nixos is a separate package) # the hack works in coordination with ./additional-php-ldflags.patch - UWSGICONFIG_PHP_LDFLAGS = lib.optionalString - (builtins.any (x: x.name == "php") needed) - (lib.concatStringsSep "," [ + UWSGICONFIG_PHP_LDFLAGS = lib.optionalString (builtins.any (x: x.name == "php") needed) ( + lib.concatStringsSep "," [ "-Wl" "-rpath=${php-embed.extensions.session}/lib/php/extensions/" "--library-path=${php-embed.extensions.session}/lib/php/extensions/" "-l:session.so" - ]); + ] + ); buildPhase = '' runHook preBuild mkdir -p $pluginDir python3 uwsgiconfig.py --build nixos - ${lib.concatMapStringsSep ";" (x: "${x.preBuild or ""}\n ${x.interpreter or "python3"} uwsgiconfig.py --plugin ${x.path} nixos ${x.name}") needed} + ${lib.concatMapStringsSep ";" ( + x: + "${x.preBuild or ""}\n ${x.interpreter or "python3"} uwsgiconfig.py --plugin ${x.path} nixos ${x.name}" + ) needed} runHook postBuild ''; @@ -157,8 +182,7 @@ stdenv.mkDerivation (finalAttrs: { runHook postInstall ''; - postFixup = lib.optionalString (builtins.any (x: x.name == "php") needed) - '' + postFixup = lib.optionalString (builtins.any (x: x.name == "php") needed) '' wrapProgram $out/bin/uwsgi --set PHP_INI_SCAN_DIR ${php-embed}/lib ''; @@ -166,7 +190,11 @@ stdenv.mkDerivation (finalAttrs: { description = "Fast, self-healing and developer/sysadmin-friendly application container server coded in pure C"; homepage = "https://uwsgi-docs.readthedocs.org/en/latest/"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ abbradar schneefux globin ]; + maintainers = with lib.maintainers; [ + abbradar + schneefux + globin + ]; platforms = lib.platforms.unix; mainProgram = "uwsgi"; }; diff --git a/pkgs/by-name/uw/uwufetch/package.nix b/pkgs/by-name/uw/uwufetch/package.nix index ce5e378b9ac7d4..16e8b2315face5 100644 --- a/pkgs/by-name/uw/uwufetch/package.nix +++ b/pkgs/by-name/uw/uwufetch/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, viu }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + viu, +}: stdenv.mkDerivation rec { pname = "uwufetch"; @@ -11,21 +17,23 @@ stdenv.mkDerivation rec { hash = "sha256-cA8sajh+puswyKikr0Jp9ei+EpVkH+vhEp+pTerkUqA="; }; - postPatch = '' - substituteInPlace uwufetch.c \ - --replace "/usr/lib/uwufetch" "$out/lib/uwufetch" \ - --replace "/usr/local/lib/uwufetch" "$out/lib/uwufetch" \ - --replace "/etc/uwufetch/config" "$out/etc/uwufetch/config" - # fix command_path for package manager (nix-store) - substituteInPlace fetch.c \ - --replace "/usr/bin" "/run/current-system/sw/bin" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace Makefile \ - --replace "local/bin" "bin" \ - --replace "local/lib" "lib" \ - --replace "local/include" "include" \ - --replace "local/share" "share" - ''; + postPatch = + '' + substituteInPlace uwufetch.c \ + --replace "/usr/lib/uwufetch" "$out/lib/uwufetch" \ + --replace "/usr/local/lib/uwufetch" "$out/lib/uwufetch" \ + --replace "/etc/uwufetch/config" "$out/etc/uwufetch/config" + # fix command_path for package manager (nix-store) + substituteInPlace fetch.c \ + --replace "/usr/bin" "/run/current-system/sw/bin" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace Makefile \ + --replace "local/bin" "bin" \ + --replace "local/lib" "lib" \ + --replace "local/include" "include" \ + --replace "local/share" "share" + ''; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/by-name/uw/uwuify/package.nix b/pkgs/by-name/uw/uwuify/package.nix index a7380bc8b1f76a..128b590ee80ba5 100644 --- a/pkgs/by-name/uw/uwuify/package.nix +++ b/pkgs/by-name/uw/uwuify/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, libiconv }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + libiconv, +}: rustPlatform.buildRustPackage rec { pname = "uwuify"; diff --git a/pkgs/by-name/ux/uxn/package.nix b/pkgs/by-name/ux/uxn/package.nix index 48e3fbe6a854ac..2fc2a961b7a275 100644 --- a/pkgs/by-name/ux/uxn/package.nix +++ b/pkgs/by-name/ux/uxn/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromSourcehut -, SDL2 -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromSourcehut, + SDL2, + unstableGitUpdater, }: stdenv.mkDerivation (finalAttrs: { @@ -16,7 +17,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-YHRdELTVf6BNa7HFu1buAG9HKRdpx++XjU60P2huY/Q="; }; - outputs = [ "out" "projects" ]; + outputs = [ + "out" + "projects" + ]; nativeBuildInputs = [ SDL2 diff --git a/pkgs/by-name/v2/v2ray-domain-list-community/package.nix b/pkgs/by-name/v2/v2ray-domain-list-community/package.nix index 45bd9515106e1c..5373233bd890be 100644 --- a/pkgs/by-name/v2/v2ray-domain-list-community/package.nix +++ b/pkgs/by-name/v2/v2ray-domain-list-community/package.nix @@ -1,4 +1,10 @@ -{ stdenv, pkgsBuildBuild, fetchFromGitHub, lib, nix-update-script }: +{ + stdenv, + pkgsBuildBuild, + fetchFromGitHub, + lib, + nix-update-script, +}: let generator = pkgsBuildBuild.buildGoModule rec { @@ -20,7 +26,12 @@ let }; in stdenv.mkDerivation { - inherit (generator) pname version src meta; + inherit (generator) + pname + version + src + meta + ; buildPhase = '' runHook preBuild ${generator}/bin/domain-list-community -datapath $src/data diff --git a/pkgs/by-name/v2/v2ray-geoip/package.nix b/pkgs/by-name/v2/v2ray-geoip/package.nix index f250040167957d..8c17c7395b98c5 100644 --- a/pkgs/by-name/v2/v2ray-geoip/package.nix +++ b/pkgs/by-name/v2/v2ray-geoip/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, pkgsBuildBuild -, jq -, moreutils -, dbip-country-lite +{ + lib, + stdenvNoCC, + fetchFromGitHub, + pkgsBuildBuild, + jq, + moreutils, + dbip-country-lite, }: let diff --git a/pkgs/by-name/v2/v2ray/package.nix b/pkgs/by-name/v2/v2ray/package.nix index 075575e7bb527e..fd435aea9f2d0b 100644 --- a/pkgs/by-name/v2/v2ray/package.nix +++ b/pkgs/by-name/v2/v2ray/package.nix @@ -1,7 +1,17 @@ -{ lib, fetchFromGitHub, symlinkJoin, buildGoModule, makeWrapper, nixosTests -, nix-update-script -, v2ray-geoip, v2ray-domain-list-community -, assets ? [ v2ray-geoip v2ray-domain-list-community ] +{ + lib, + fetchFromGitHub, + symlinkJoin, + buildGoModule, + makeWrapper, + nixosTests, + nix-update-script, + v2ray-geoip, + v2ray-domain-list-community, + assets ? [ + v2ray-geoip + v2ray-domain-list-community + ], }: buildGoModule rec { @@ -19,7 +29,10 @@ buildGoModule rec { # https://github.com/Mic92/nix-update/pull/95 vendorHash = "sha256-9JJjpAvmeXBAauu58eQuE262XN1TIK2SwLUlPQBbwYA="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; subPackages = [ "main" ]; diff --git a/pkgs/by-name/v4/v4l2-relayd/package.nix b/pkgs/by-name/v4/v4l2-relayd/package.nix index c1d48f30940951..f836590afc5a72 100644 --- a/pkgs/by-name/v4/v4l2-relayd/package.nix +++ b/pkgs/by-name/v4/v4l2-relayd/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchgit -, autoreconfHook -, glib -, gst_all_1 -, libtool -, pkg-config -, which +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + glib, + gst_all_1, + libtool, + pkg-config, + which, }: stdenv.mkDerivation rec { pname = "v4l2-relayd"; diff --git a/pkgs/by-name/va/vaapi-intel-hybrid/package.nix b/pkgs/by-name/va/vaapi-intel-hybrid/package.nix index aec3bcc6af2e0f..564460b104bc0b 100644 --- a/pkgs/by-name/va/vaapi-intel-hybrid/package.nix +++ b/pkgs/by-name/va/vaapi-intel-hybrid/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, fetchFromGitHub, autoreconfHook, pkg-config, cmrt, libdrm, libva, libX11, libGL, wayland }: +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + autoreconfHook, + pkg-config, + cmrt, + libdrm, + libva, + libX11, + libGL, + wayland, +}: stdenv.mkDerivation rec { pname = "intel-hybrid-driver"; @@ -19,9 +32,19 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ cmrt libdrm libva libX11 libGL wayland ]; + buildInputs = [ + cmrt + libdrm + libva + libX11 + libGL + wayland + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/va/vacuum-go/package.nix b/pkgs/by-name/va/vacuum-go/package.nix index a08673af7f33fd..dd6cf1f4357e3f 100644 --- a/pkgs/by-name/va/vacuum-go/package.nix +++ b/pkgs/by-name/va/vacuum-go/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, vacuum-go }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + vacuum-go, +}: buildGoModule rec { pname = "vacuum-go"; diff --git a/pkgs/by-name/va/vagrant/gemset.nix b/pkgs/by-name/va/vagrant/gemset.nix index bb44c6feeb73cd..9958730f0e5c75 100644 --- a/pkgs/by-name/va/vagrant/gemset.nix +++ b/pkgs/by-name/va/vagrant/gemset.nix @@ -1,730 +1,802 @@ { base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bcrypt_pbkdf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04rb3rp9bdxn1y3qiflfpj7ccwb8ghrfbydh5vfz1l9px3fpg41g"; type = "gem"; }; version = "1.1.1"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; builder = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pw3r2lyagsxkm71bf44v5b74f7l9r7di22brbyji9fwz791hya9"; type = "gem"; }; version = "3.3.0"; }; childprocess = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1lvcp8bsd35g57f7wz4jigcw2sryzzwrpcgjwwf3chmjrjcww5in"; type = "gem"; }; version = "4.1.0"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; date = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kz6mc4b9m49iaans6cbx031j9y7ldghpi5fzsdh0n3ixwa8w9mz"; type = "gem"; }; version = "3.4.1"; }; diff-lcs = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znxccz83m4xgpd239nyqxlifdb7m8rlfayk6s259186nkgj6ci7"; type = "gem"; }; version = "1.5.1"; }; ed25519 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zb2dr2ihb1qiknn5iaj1ha1w9p7lj9yq5waasndlfadz225ajji"; type = "gem"; }; version = "1.3.0"; }; erubi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qnd6ff4az22ysnmni3730c41b979xinilahzg86bn7gv93ip9pw"; type = "gem"; }; version = "1.13.0"; }; excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00p5fww0bakph4p9skc7ypjqbqc8crnw31nrmpdm8j4rr5kp4jb0"; type = "gem"; }; version = "1.2.2"; }; fake_ftp = { - groups = ["development"]; - platforms = []; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zl9q9m4x7lz9890g0h1qqj7hcxnwzpjfnfbxadjblps7b5054q4"; type = "gem"; }; version = "0.3.0"; }; faraday = { - dependencies = ["faraday-net_http" "json" "logger"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-net_http" + "json" + "logger" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0vxaw0mg8avqivdj0lzj19nxf652ri208grsdf0361flyn5i5wi3"; type = "gem"; }; version = "2.12.1"; }; faraday-net_http = { - dependencies = ["net-http"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-http" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jp5ci6g40d6i50bsywp35l97nc2fpi9a592r2cibwicdb6y9wd1"; type = "gem"; }; version = "3.4.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; google-protobuf = { - dependencies = ["bigdecimal" "rake"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bigdecimal" + "rake" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zzlmsv7djpgn6hxp5r1jg7f4nx368j0ccq6pipq1ncplnvbffij"; type = "gem"; }; version = "4.29.1"; }; googleapis-common-protos-types = { - dependencies = ["google-protobuf"]; - groups = ["default"]; - platforms = []; + dependencies = [ "google-protobuf" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xyinc2zaw25r3x774mni66im1b22l9zpbsqdgdb4g4zxcd5srcl"; type = "gem"; }; version = "1.16.0"; }; grpc = { - dependencies = ["google-protobuf" "googleapis-common-protos-types"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "google-protobuf" + "googleapis-common-protos-types" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0z5x8f9k2m656imi59jrd49d8inbnzpcnylz0ijj1ly0ihdi3apd"; type = "gem"; }; version = "1.68.1"; }; grpc-tools = { - groups = ["development"]; - platforms = []; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12wbiq7s1qc6dv35p8c5vay627c6mqm9p1dimv2nz2m6r5f1057v"; type = "gem"; }; version = "1.68.1"; }; gssapi = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qdfhj12aq8v0y961v4xv96a1y2z80h3xhvzrs9vsfgf884g6765"; type = "gem"; }; version = "1.3.1"; }; gyoku = { - dependencies = ["builder" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "builder" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kd2q59xpm39hpvmmvyi6g3f1fr05xjbnxwkrdqz4xy7hirqi79q"; type = "gem"; }; version = "1.4.0"; }; hashicorp-checkpoint = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1z6mwzvd7p2wqhmk07dwrhvm0ncgqm7pxn0pr2k025rwsspp9bsd"; type = "gem"; }; version = "0.1.5"; }; hashie = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nh3arcrbz1rc1cr59qm53sdhqm137b258y8rcb4cvd3y98lwv4x"; type = "gem"; }; version = "5.0.0"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k31wcgnvcvd14snz0pfqj976zv6drfsnq6x8acz10fiyms9l8nw"; type = "gem"; }; version = "1.14.6"; }; ipaddr = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wmgwqv6c1kq8cxbxddllnrlh5jjmjw73i1sqbnvq55zzn3l0zyb"; type = "gem"; }; version = "1.2.7"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kvbzh8530pp3qf63zvx9hnb708x7plv9wfn5ibns3h3knnvs3kw"; type = "gem"; }; version = "2.9.0"; }; jwt = { - dependencies = ["base64"]; - groups = ["default"]; - platforms = []; + dependencies = [ "base64" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rba9mji57sfa1kjhj0bwff1377vj0i8yx2rd39j5ik4vp60gzam"; type = "gem"; }; version = "2.9.3"; }; listen = { - dependencies = ["rb-fsevent" "rb-inotify"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rb-fsevent" + "rb-inotify" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0rwwsmvq79qwzl6324yc53py02kbrcww35si720490z5w0j497nv"; type = "gem"; }; version = "3.9.0"; }; little-plugger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1frilv82dyxnlg8k1jhrvyd73l6k17mxc5vwxx080r4x1p04gwym"; type = "gem"; }; version = "1.1.4"; }; log4r = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ri90q0frfmigkirqv5ihyrj59xm8pq5zcmf156cbdv4r4l2jicv"; type = "gem"; }; version = "1.1.10"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0q9jm4pzqxk92dq9a1y7gjwcw3dcsm1mnsdhi9ms5hw1dpnprzlx"; type = "gem"; }; version = "1.6.2"; }; logging = { - dependencies = ["little-plugger" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "little-plugger" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1jqcq2yxh973f3aw63nd3wxhqyhkncz3pf8v2gs3df0iqair725s"; type = "gem"; }; version = "2.4.0"; }; mime-types = { - dependencies = ["logger" "mime-types-data"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "logger" + "mime-types-data" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0r34mc3n7sxsbm9mzyzy8m3dvq7pwbryyc8m452axkj0g2axnwbg"; type = "gem"; }; version = "3.6.0"; }; mime-types-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a7fq0wn2fdv57dsxfmjyzsjhxprh56k0zg3c4nm9il4s3v0mzig"; type = "gem"; }; version = "3.2024.1203"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; multi_xml = { - dependencies = ["bigdecimal"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bigdecimal" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06x61ca5j84nyhr1mwh9r436yiphnc5hmacb3gwqyn5gd0611kjg"; type = "gem"; }; version = "0.7.1"; }; net-ftp = { - dependencies = ["net-protocol" "time"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "net-protocol" + "time" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0kw7g0j35fla8438s90m72b3xr0mqnpgm910qcwrgnvyg903xmi8"; type = "gem"; }; version = "0.3.8"; }; net-http = { - dependencies = ["uri"]; - groups = ["default"]; - platforms = []; + dependencies = [ "uri" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ysrwaabhf0sn24jrp0nnp51cdv0jf688mh5i6fsz63q2c6b48cn"; type = "gem"; }; version = "0.6.0"; }; net-protocol = { - dependencies = ["timeout"]; - groups = ["default"]; - platforms = []; + dependencies = [ "timeout" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a32l4x73hz200cm587bc29q8q9az278syw3x6fkc9d1lv5y0wxa"; type = "gem"; }; version = "0.2.2"; }; net-scp = { - dependencies = ["net-ssh"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-ssh" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1si2nq9l6jy5n2zw1q59a5gaji7v9vhy8qx08h4fg368906ysbdk"; type = "gem"; }; version = "4.0.0"; }; net-sftp = { - dependencies = ["net-ssh"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-ssh" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0r33aa2d61hv1psm0l0mm6ik3ycsnq8symv7h84kpyf2b7493fv5"; type = "gem"; }; version = "4.0.0"; }; net-ssh = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1w1ypxa3n6mskkwb00b489314km19l61p5h3bar6zr8cng27c80p"; type = "gem"; }; version = "7.3.0"; }; nori = { - dependencies = ["bigdecimal"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bigdecimal" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qb84bbi74q0zgs09sdkq750jf2ri3lblbry0xi4g1ard4rwsrk1"; type = "gem"; }; version = "2.7.1"; }; oauth2 = { - dependencies = ["faraday" "jwt" "multi_xml" "rack" "snaky_hash" "version_gem"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "jwt" + "multi_xml" + "rack" + "snaky_hash" + "version_gem" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yzpaghh8kwzgmvmrlbzf36ks5s2hf34rayzw081dp2jrzprs7xj"; type = "gem"; }; version = "2.0.9"; }; ostruct = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05xqijcf80sza5pnlp1c8whdaay8x5dc13214ngh790zrizgp8q9"; type = "gem"; }; version = "0.6.1"; }; pairing_heap = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "059kqpw53cancnp0bp7y1s74y1955riw33w3lqfbnms4b4mdh5zj"; type = "gem"; }; version = "3.1.0"; }; rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cd13019gnnh2c0a3kj27ij5ibk72v0bmpypqv4l6ayw8g5cpyyk"; type = "gem"; }; version = "3.1.8"; }; rake = { - groups = ["development"]; - platforms = []; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17850wcwkgi30p7yqh60960ypn7yibacjjha0av78zaxwvd3ijs6"; type = "gem"; }; version = "13.2.1"; }; rake-compiler = { - dependencies = ["rake"]; - groups = ["development"]; - platforms = []; + dependencies = [ "rake" ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xlifh25mhlrigj020nya10s37dbkhc0rlqlf0ld88rxrdg1057k"; type = "gem"; }; version = "1.2.8"; }; rb-fsevent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zmf31rnpm8553lqwibvv3kkx0v7majm1f341xbxc0bk5sbhp423"; type = "gem"; }; version = "0.11.2"; }; rb-inotify = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vmy8xgahixcz6hzwy4zdcyn2y6d6ri8dqv5xccgzc1r292019x0"; type = "gem"; }; version = "0.11.1"; }; rb-kqueue = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vpq1dmmlbggfk399s7jq2rrnjp6r8774amfli75bqhjn1sk2bxg"; type = "gem"; }; version = "0.2.8"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j9p66pmfgxnzp76ksssyfyqqrg7281dyi3xyknl3wwraaw7a66p"; type = "gem"; }; version = "3.3.9"; }; rgl = { - dependencies = ["pairing_heap" "rexml" "stream"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pairing_heap" + "rexml" + "stream" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0jjc2v9hg42bzg6w5yg3azrsdr31qmc6ff93xb5adfjqg337vzz3"; type = "gem"; }; version = "0.5.10"; }; rspec = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14xrp8vq6i9zx37vh0yp4h9m0anx9paw200l1r5ad9fmq559346l"; type = "gem"; }; version = "3.13.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rspec-support" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "001kazj244cb6fbkmh7ap74csbr78717qaskqzqpir1q8xpdmywl"; type = "gem"; }; version = "3.13.2"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0n3cyrhsa75x5wwvskrrqk56jbjgdi2q1zx0irllf0chkgsmlsqf"; type = "gem"; }; version = "3.13.3"; }; rspec-its = { - dependencies = ["rspec-core" "rspec-expectations"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1xjikikx2sn9b7nbaza60xq7livjw9kp3a6gwbv5xz9zjd7k2164"; type = "gem"; }; version = "1.3.1"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vxxkb2sf2b36d8ca2nq84kjf85fz4x7wqcvb8r6a5hfxxfk69r3"; type = "gem"; }; version = "3.13.2"; }; rspec-support = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1v6v6xvxcpkrrsrv7v1xgf7sl0d71vcfz1cnrjflpf6r7x3a58yf"; type = "gem"; }; version = "3.13.2"; }; rubyntlm = { - dependencies = ["base64"]; - groups = ["default"]; - platforms = []; + dependencies = [ "base64" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x8l0d1v88m40mby4jvgal46137cv8gga2lk7zlrxqlsp41380a7"; type = "gem"; }; version = "0.6.5"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; snaky_hash = { - dependencies = ["hashie" "version_gem"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "hashie" + "version_gem" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cfwvdcr46pk0c7m5aw2w3izbrp1iba0q7l21r37mzpwaz0pxj0s"; type = "gem"; }; version = "2.0.1"; }; stream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "016m9v81vpj14d8g5ins91zc4pzl7vf5f1gxl7jhfsfy601k7cv2"; type = "gem"; }; version = "0.5.5"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0d1g37j6sc7fkidf8rqlm3wh9zgyg3g7y8h2x1y34hmil5ywa8c3"; type = "gem"; }; version = "0.18.1"; }; time = { - dependencies = ["date"]; - groups = ["default"]; - platforms = []; + dependencies = [ "date" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qgarmdyqypzsaanf4w9vqrd9axrcrjqilxwrfmxp954102kcpq3"; type = "gem"; }; version = "0.4.1"; }; timeout = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06fcniirx82hrljzfn5wb3634n8648v8qgy006jzgclfz5gjvjla"; type = "gem"; }; version = "0.4.2"; }; uri = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09qyg6a29cfgd46qid8qvx4sjbv596v19ym73xvhanbyxd6500xk"; type = "gem"; }; version = "1.0.2"; }; vagrant-spec = { - dependencies = ["childprocess" "log4r" "rspec" "thor"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "childprocess" + "log4r" + "rspec" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { fetchSubmodules = false; rev = "2a5afa7512753288b4ec1e26ec13bc6479b2fabb"; @@ -735,74 +807,98 @@ version = "0.0.1"; }; vagrant_cloud = { - dependencies = ["excon" "log4r" "oauth2" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "excon" + "log4r" + "oauth2" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07w7zv93pzpxjsq16z2d15irkl117x2h572bmd0gqhqd50da3lc6"; type = "gem"; }; version = "3.1.2"; }; version_gem = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08a6agx7xk1f6cr9a95dq42vl45si2ln21h33b96li59sv3555y6"; type = "gem"; }; version = "1.1.4"; }; wdm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0x5l2pn4x92734k6i2wcjbn2klmwgkiqaajvxadh35k74dgnyh18"; type = "gem"; }; version = "0.1.1"; }; webrick = { - groups = ["development"]; - platforms = []; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12d9n8hll67j737ym2zw4v23cn4vxyfkb6vyv1rzpwv6y6a3qbdl"; type = "gem"; }; version = "1.9.1"; }; winrm = { - dependencies = ["builder" "erubi" "gssapi" "gyoku" "httpclient" "logging" "nori" "rexml" "rubyntlm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "builder" + "erubi" + "gssapi" + "gyoku" + "httpclient" + "logging" + "nori" + "rexml" + "rubyntlm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "01jxpshw5kx5ha21ymaaj14vibv5bvm0dd80ccc6xl3jaxy7cszg"; type = "gem"; }; version = "2.3.9"; }; winrm-elevated = { - dependencies = ["erubi" "winrm" "winrm-fs"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "erubi" + "winrm" + "winrm-fs" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1lmlaii8qapn84wxdg5d82gbailracgk67d0qsnbdnffcg8kswzd"; type = "gem"; }; version = "1.2.3"; }; winrm-fs = { - dependencies = ["erubi" "logging" "rubyzip" "winrm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "erubi" + "logging" + "rubyzip" + "winrm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gb91k6s1yjqw387x4w1nkpnxblq3pjdqckayl0qvz5n3ygdsb0d"; type = "gem"; }; diff --git a/pkgs/by-name/va/vagrant/gemset_libvirt.nix b/pkgs/by-name/va/vagrant/gemset_libvirt.nix index cc9b49f42d9f0b..90de5d0bc8b9ec 100644 --- a/pkgs/by-name/va/vagrant/gemset_libvirt.nix +++ b/pkgs/by-name/va/vagrant/gemset_libvirt.nix @@ -1,291 +1,411 @@ { builder = { - groups = ["default" "plugins"]; - platforms = []; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pw3r2lyagsxkm71bf44v5b74f7l9r7di22brbyji9fwz791hya9"; type = "gem"; }; version = "3.3.0"; }; diff-lcs = { - groups = ["default" "development" "plugins"]; - platforms = []; + groups = [ + "default" + "development" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znxccz83m4xgpd239nyqxlifdb7m8rlfayk6s259186nkgj6ci7"; type = "gem"; }; version = "1.5.1"; }; diffy = { - groups = ["default" "plugins"]; - platforms = []; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19xaz5qmw0kg1rdsjh13vk7674bpcmjy6cnddx1cvl80vgkvjr22"; type = "gem"; }; version = "3.4.3"; }; excon = { - groups = ["default" "plugins"]; - platforms = []; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00p5fww0bakph4p9skc7ypjqbqc8crnw31nrmpdm8j4rr5kp4jb0"; type = "gem"; }; version = "1.2.2"; }; fog-core = { - dependencies = ["builder" "excon" "formatador" "mime-types"]; - groups = ["default" "plugins"]; - platforms = []; + dependencies = [ + "builder" + "excon" + "formatador" + "mime-types" + ]; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rjv4iqr64arxv07bh84zzbr1y081h21592b5zjdrk937al8mq1z"; type = "gem"; }; version = "2.6.0"; }; fog-json = { - dependencies = ["fog-core" "multi_json"]; - groups = ["default" "plugins"]; - platforms = []; + dependencies = [ + "fog-core" + "multi_json" + ]; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zj8llzc119zafbmfa4ai3z5s7c4vp9akfs0f9l2piyvcarmlkyx"; type = "gem"; }; version = "1.2.0"; }; fog-libvirt = { - dependencies = ["fog-core" "fog-json" "fog-xml" "json" "ruby-libvirt"]; - groups = ["default" "plugins"]; - platforms = []; + dependencies = [ + "fog-core" + "fog-json" + "fog-xml" + "json" + "ruby-libvirt" + ]; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "036ajdyj4fxnhqf108jgzjkpiknnr6dg7mrapn8jsagqdr2a2k21"; type = "gem"; }; version = "0.13.1"; }; fog-xml = { - dependencies = ["fog-core" "nokogiri"]; - groups = ["default" "plugins"]; - platforms = []; + dependencies = [ + "fog-core" + "nokogiri" + ]; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vyyb2429xqzys39xyk2r3fal80qqn397aj2kqsjrgg2y6m59i41"; type = "gem"; }; version = "0.1.4"; }; formatador = { - groups = ["default" "plugins"]; - platforms = []; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l06bv4avphbdmr1y4g0rqlczr38k6r65b3zghrbj2ynyhm3xqjl"; type = "gem"; }; version = "1.1.0"; }; json = { - groups = ["default" "plugins"]; - platforms = []; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kvbzh8530pp3qf63zvx9hnb708x7plv9wfn5ibns3h3knnvs3kw"; type = "gem"; }; version = "2.9.0"; }; logger = { - groups = ["default" "plugins"]; - platforms = []; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0q9jm4pzqxk92dq9a1y7gjwcw3dcsm1mnsdhi9ms5hw1dpnprzlx"; type = "gem"; }; version = "1.6.2"; }; mime-types = { - dependencies = ["logger" "mime-types-data"]; - groups = ["default" "plugins"]; - platforms = []; + dependencies = [ + "logger" + "mime-types-data" + ]; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0r34mc3n7sxsbm9mzyzy8m3dvq7pwbryyc8m452axkj0g2axnwbg"; type = "gem"; }; version = "3.6.0"; }; mime-types-data = { - groups = ["default" "plugins"]; - platforms = []; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a7fq0wn2fdv57dsxfmjyzsjhxprh56k0zg3c4nm9il4s3v0mzig"; type = "gem"; }; version = "3.2024.1203"; }; mini_portile2 = { - groups = ["default" "plugins"]; - platforms = []; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0x8asxl83msn815lwmb2d7q5p29p7drhjv5va0byhk60v9n16iwf"; type = "gem"; }; version = "2.8.8"; }; multi_json = { - groups = ["default" "plugins"]; - platforms = []; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default" "plugins"]; - platforms = []; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18ajyy4d16q4ahnrfmj6d6z9ak21mnbn4wblx2vddck3lvwlpkny"; type = "gem"; }; version = "1.16.8"; }; parallel = { - groups = ["default" "development" "test"]; - platforms = []; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vy7sjs2pgz4i96v5yk9b7aafbffnvq7nn419fgvw55qlavsnsyq"; type = "gem"; }; version = "1.26.3"; }; parallel_tests = { - dependencies = ["parallel"]; - groups = ["development" "test"]; - platforms = []; + dependencies = [ "parallel" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04i61bkra454var9dc79ak3yffl13mbqx8xv2rvidx9n7ins9cyn"; type = "gem"; }; version = "4.7.2"; }; racc = { - groups = ["default" "plugins"]; - platforms = []; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0byn0c9nkahsl93y9ln5bysq4j31q8xkf2ws42swighxd4lnjzsa"; type = "gem"; }; version = "1.8.1"; }; rake = { - groups = ["development" "plugins"]; - platforms = []; + groups = [ + "development" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17850wcwkgi30p7yqh60960ypn7yibacjjha0av78zaxwvd3ijs6"; type = "gem"; }; version = "13.2.1"; }; rexml = { - groups = ["default" "plugins"]; - platforms = []; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j9p66pmfgxnzp76ksssyfyqqrg7281dyi3xyknl3wwraaw7a66p"; type = "gem"; }; version = "3.3.9"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["development" "plugins"]; - platforms = []; + dependencies = [ "rspec-support" ]; + groups = [ + "development" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "001kazj244cb6fbkmh7ap74csbr78717qaskqzqpir1q8xpdmywl"; type = "gem"; }; version = "3.13.2"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["development" "plugins"]; - platforms = []; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "development" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0n3cyrhsa75x5wwvskrrqk56jbjgdi2q1zx0irllf0chkgsmlsqf"; type = "gem"; }; version = "3.13.3"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["development" "plugins"]; - platforms = []; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "development" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vxxkb2sf2b36d8ca2nq84kjf85fz4x7wqcvb8r6a5hfxxfk69r3"; type = "gem"; }; version = "3.13.2"; }; rspec-support = { - groups = ["default" "development" "plugins"]; - platforms = []; + groups = [ + "default" + "development" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1v6v6xvxcpkrrsrv7v1xgf7sl0d71vcfz1cnrjflpf6r7x3a58yf"; type = "gem"; }; version = "3.13.2"; }; ruby-libvirt = { - groups = ["default" "plugins"]; - platforms = []; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0r0igmwr22pi3dkkg1p79hjf8mr178qnz83q8fnaj87x7zk3qfyg"; type = "gem"; }; version = "0.8.4"; }; vagrant-libvirt = { - dependencies = ["diffy" "fog-core" "fog-libvirt" "nokogiri" "rexml" "xml-simple"]; - groups = ["plugins"]; - platforms = []; + dependencies = [ + "diffy" + "fog-core" + "fog-libvirt" + "nokogiri" + "rexml" + "xml-simple" + ]; + groups = [ "plugins" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "sha256-NMiRjrVQo2Ui9nOJwpDmNJUk+95gsT85pwFMIiw3bwQ="; type = "gem"; }; version = "0.12.2"; }; xml-simple = { - dependencies = ["rexml"]; - groups = ["default" "plugins"]; - platforms = []; + dependencies = [ "rexml" ]; + groups = [ + "default" + "plugins" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb9plyl71mdbjr4kllfy53qx6g68ryxblmnq9dilvy837jk24fj"; type = "gem"; }; diff --git a/pkgs/by-name/va/vagrant/package.nix b/pkgs/by-name/va/vagrant/package.nix index 6754a39fad4e38..fb52d3ebc0c9c1 100644 --- a/pkgs/by-name/va/vagrant/package.nix +++ b/pkgs/by-name/va/vagrant/package.nix @@ -1,6 +1,16 @@ -{ stdenv, lib, fetchurl, buildRubyGem, bundlerEnv, ruby, libarchive -, libguestfs, qemu, writeText, withLibvirt ? stdenv.hostPlatform.isLinux -, openssl +{ + stdenv, + lib, + fetchurl, + buildRubyGem, + bundlerEnv, + ruby, + libarchive, + libguestfs, + qemu, + writeText, + withLibvirt ? stdenv.hostPlatform.isLinux, + openssl, }: let @@ -18,15 +28,18 @@ let inherit ruby; gemfile = writeText "Gemfile" ""; lockfile = writeText "Gemfile.lock" ""; - gemset = lib.recursiveUpdate (import ./gemset.nix) ({ - vagrant = { - source = { - type = "url"; - inherit url hash; + gemset = lib.recursiveUpdate (import ./gemset.nix) ( + { + vagrant = { + source = { + type = "url"; + inherit url hash; + }; + inherit version; }; - inherit version; - }; - } // lib.optionalAttrs withLibvirt (import ./gemset_libvirt.nix)); + } + // lib.optionalAttrs withLibvirt (import ./gemset_libvirt.nix) + ); # This replaces the gem symlinks with directories, resolving this # error when running vagrant (I have no idea why): @@ -42,7 +55,8 @@ let ''; }; -in buildRubyGem rec { +in +buildRubyGem rec { name = "${gemName}-${version}"; gemName = "vagrant"; inherit version; @@ -75,34 +89,39 @@ in buildRubyGem rec { # - qemu: Make 'qemu-img' available for 'vagrant package' postInstall = let - pathAdditions = lib.makeSearchPath "bin" - (map (x: lib.getBin x) ([ - libarchive - ] ++ lib.optionals withLibvirt [ - libguestfs - qemu - ])); - in '' - wrapProgram "$out/bin/vagrant" \ - --set GEM_PATH "${deps}/lib/ruby/gems/${ruby.version.libDir}" \ - --prefix PATH ':' ${pathAdditions} \ - --set-default VAGRANT_CHECKPOINT_DISABLE 1 + pathAdditions = lib.makeSearchPath "bin" ( + map (x: lib.getBin x) ( + [ + libarchive + ] + ++ lib.optionals withLibvirt [ + libguestfs + qemu + ] + ) + ); + in + '' + wrapProgram "$out/bin/vagrant" \ + --set GEM_PATH "${deps}/lib/ruby/gems/${ruby.version.libDir}" \ + --prefix PATH ':' ${pathAdditions} \ + --set-default VAGRANT_CHECKPOINT_DISABLE 1 - mkdir -p "$out/vagrant-plugins/plugins.d" - echo '{}' > "$out/vagrant-plugins/plugins.json" + mkdir -p "$out/vagrant-plugins/plugins.d" + echo '{}' > "$out/vagrant-plugins/plugins.json" - # install bash completion - mkdir -p $out/share/bash-completion/completions/ - cp -av contrib/bash/completion.sh $out/share/bash-completion/completions/vagrant - # install zsh completion - mkdir -p $out/share/zsh/site-functions/ - cp -av contrib/zsh/_vagrant $out/share/zsh/site-functions/ - '' + - lib.optionalString withLibvirt '' - substitute ${./vagrant-libvirt.json.in} $out/vagrant-plugins/plugins.d/vagrant-libvirt.json \ - --subst-var-by ruby_version ${ruby.version} \ - --subst-var-by vagrant_version ${version} - ''; + # install bash completion + mkdir -p $out/share/bash-completion/completions/ + cp -av contrib/bash/completion.sh $out/share/bash-completion/completions/vagrant + # install zsh completion + mkdir -p $out/share/zsh/site-functions/ + cp -av contrib/zsh/_vagrant $out/share/zsh/site-functions/ + '' + + lib.optionalString withLibvirt '' + substitute ${./vagrant-libvirt.json.in} $out/vagrant-plugins/plugins.d/vagrant-libvirt.json \ + --subst-var-by ruby_version ${ruby.version} \ + --subst-var-by vagrant_version ${version} + ''; installCheckPhase = '' HOME="$(mktemp -d)" $out/bin/vagrant init --output - > /dev/null diff --git a/pkgs/by-name/va/vala-language-server/package.nix b/pkgs/by-name/va/vala-language-server/package.nix index 9faf60024c5dc7..87d67a44acf483 100644 --- a/pkgs/by-name/va/vala-language-server/package.nix +++ b/pkgs/by-name/va/vala-language-server/package.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, scdoc -, gnome-builder -, glib -, libgee -, json-glib -, jsonrpc-glib -, vala +{ + stdenv, + lib, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + scdoc, + gnome-builder, + glib, + libgee, + json-glib, + jsonrpc-glib, + vala, }: stdenv.mkDerivation rec { @@ -29,15 +30,17 @@ stdenv.mkDerivation rec { updateScript = nix-update-script { }; }; - nativeBuildInputs = [ - meson - ninja - pkg-config - scdoc - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - # GNOME Builder Plugin - gnome-builder - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + scdoc + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + # GNOME Builder Plugin + gnome-builder + ]; buildInputs = [ glib diff --git a/pkgs/by-name/va/vala-lint/package.nix b/pkgs/by-name/va/vala-lint/package.nix index d47e7c22470aa8..8a2d5d2220d8ac 100644 --- a/pkgs/by-name/va/vala-lint/package.nix +++ b/pkgs/by-name/va/vala-lint/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, glib -, json-glib -, meson -, ninja -, pantheon -, pkg-config -, vala -, gettext -, wrapGAppsHook3 -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + glib, + json-glib, + meson, + ninja, + pantheon, + pkg-config, + vala, + gettext, + wrapGAppsHook3, + unstableGitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/va/vale-ls/package.nix b/pkgs/by-name/va/vale-ls/package.nix index 0a09952d51afaf..f0775366e02e3a 100644 --- a/pkgs/by-name/va/vale-ls/package.nix +++ b/pkgs/by-name/va/vale-ls/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, rustPlatform -, pkg-config -, openssl -, darwin -, vale +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + rustPlatform, + pkg-config, + openssl, + darwin, + vale, }: rustPlatform.buildRustPackage rec { @@ -26,20 +27,27 @@ rustPlatform.buildRustPackage rec { makeWrapper ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - SystemConfiguration - ]); - - checkFlags = [ - # The following tests are reaching to the network. - "--skip=vale::tests" - ] ++ lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) [ - # This test does not account for the existence of aarch64-linux machines, - # despite upstream shipping artifacts for that architecture - "--skip=utils::tests::arch" - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + SystemConfiguration + ] + ); + + checkFlags = + [ + # The following tests are reaching to the network. + "--skip=vale::tests" + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) [ + # This test does not account for the existence of aarch64-linux machines, + # despite upstream shipping artifacts for that architecture + "--skip=utils::tests::arch" + ]; env.OPENSSL_NO_VENDOR = true; @@ -55,7 +63,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/errata-ai/vale-ls"; license = licenses.mit; mainProgram = "vale-ls"; - maintainers = with maintainers; [ foo-dogsquared jansol ]; + maintainers = with maintainers; [ + foo-dogsquared + jansol + ]; }; } - diff --git a/pkgs/by-name/va/validator-nu/package.nix b/pkgs/by-name/va/validator-nu/package.nix index d52c87e4186bac..45450844e09d18 100644 --- a/pkgs/by-name/va/validator-nu/package.nix +++ b/pkgs/by-name/va/validator-nu/package.nix @@ -1,12 +1,13 @@ -{ fetchFromGitHub -, git -, jdk_headless -, jre_headless -, makeWrapper -, python3 -, stdenvNoCC -, lib -, testers +{ + fetchFromGitHub, + git, + jdk_headless, + jre_headless, + makeWrapper, + python3, + stdenvNoCC, + lib, + testers, }: let @@ -25,7 +26,12 @@ let pname = "${pname}-deps"; inherit version src; - nativeBuildInputs = [ git jdk_headless python3 python3.pkgs.certifi ]; + nativeBuildInputs = [ + git + jdk_headless + python3 + python3.pkgs.certifi + ]; buildPhase = '' python checker.py dldeps @@ -44,7 +50,12 @@ in stdenvNoCC.mkDerivation (finalAttrs: { inherit pname version src; - nativeBuildInputs = [ git jdk_headless makeWrapper python3 ]; + nativeBuildInputs = [ + git + jdk_headless + makeWrapper + python3 + ]; postPatch = '' substituteInPlace build/build.py --replace-warn \ @@ -76,9 +87,15 @@ stdenvNoCC.mkDerivation (finalAttrs: { description = "Helps you catch problems in your HTML/CSS/SVG"; homepage = "https://validator.github.io/validator/"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ andersk ivan ]; + maintainers = with lib.maintainers; [ + andersk + ivan + ]; mainProgram = "vnu"; platforms = lib.platforms.all; - sourceProvenance = with lib.sourceTypes; [ binaryBytecode fromSource ]; + sourceProvenance = with lib.sourceTypes; [ + binaryBytecode + fromSource + ]; }; }) diff --git a/pkgs/by-name/va/valijson/package.nix b/pkgs/by-name/va/valijson/package.nix index 05da39c37475e9..0c928e81f08b1b 100644 --- a/pkgs/by-name/va/valijson/package.nix +++ b/pkgs/by-name/va/valijson/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/va/valkey/package.nix b/pkgs/by-name/va/valkey/package.nix index 6f1f74cea49bee..8eca5d228869e5 100644 --- a/pkgs/by-name/va/valkey/package.nix +++ b/pkgs/by-name/va/valkey/package.nix @@ -1,13 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, lua, jemalloc, pkg-config -, tcl, which, ps, getconf -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, systemd -# dependency ordering is broken at the moment when building with openssl -, tlsSupport ? !stdenv.hostPlatform.isStatic, openssl - -# Using system jemalloc fixes cross-compilation and various setups. -# However the experimental 'active defragmentation' feature of valkey requires -# their custom patched version of jemalloc. -, useSystemJemalloc ? true +{ + lib, + stdenv, + fetchFromGitHub, + lua, + jemalloc, + pkg-config, + tcl, + which, + ps, + getconf, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + # dependency ordering is broken at the moment when building with openssl + tlsSupport ? !stdenv.hostPlatform.isStatic, + openssl, + + # Using system jemalloc fixes cross-compilation and various setups. + # However the experimental 'active defragmentation' feature of valkey requires + # their custom patched version of jemalloc. + useSystemJemalloc ? true, }: stdenv.mkDerivation (finalAttrs: { @@ -25,7 +36,8 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ lua ] + buildInputs = + [ lua ] ++ lib.optional useSystemJemalloc jemalloc ++ lib.optional withSystemd systemd ++ lib.optional tlsSupport openssl; @@ -37,8 +49,12 @@ stdenv.mkDerivation (finalAttrs: { ''; # More cross-compiling fixes. - makeFlags = [ "PREFIX=${placeholder "out"}" ] - ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ "AR=${stdenv.cc.targetPrefix}ar" "RANLIB=${stdenv.cc.targetPrefix}ranlib" ] + makeFlags = + [ "PREFIX=${placeholder "out"}" ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "AR=${stdenv.cc.targetPrefix}ar" + "RANLIB=${stdenv.cc.targetPrefix}ranlib" + ] ++ lib.optionals withSystemd [ "USE_SYSTEMD=yes" ] ++ lib.optionals tlsSupport [ "BUILD_TLS=yes" ]; @@ -50,7 +66,11 @@ stdenv.mkDerivation (finalAttrs: { # darwin currently lacks a pure `pgrep` which is extensively used here doCheck = !stdenv.hostPlatform.isDarwin; - nativeCheckInputs = [ which tcl ps ] ++ lib.optionals stdenv.hostPlatform.isStatic [ getconf ]; + nativeCheckInputs = [ + which + tcl + ps + ] ++ lib.optionals stdenv.hostPlatform.isStatic [ getconf ]; checkPhase = '' runHook preCheck diff --git a/pkgs/by-name/va/vals/package.nix b/pkgs/by-name/va/vals/package.nix index 07248d814d14e3..60a38a03734865 100644 --- a/pkgs/by-name/va/vals/package.nix +++ b/pkgs/by-name/va/vals/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, vals }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + vals, +}: buildGoModule rec { pname = "vals"; diff --git a/pkgs/by-name/va/valum/package.nix b/pkgs/by-name/va/valum/package.nix index 2602324e89239d..e2dec1824b57cf 100644 --- a/pkgs/by-name/va/valum/package.nix +++ b/pkgs/by-name/va/valum/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, meson, ninja, pkg-config, fetchFromGitHub, glib, vala, ctpl -, libgee, libsoup_2_4, fcgi }: +{ + lib, + stdenv, + meson, + ninja, + pkg-config, + fetchFromGitHub, + glib, + vala, + ctpl, + libgee, + libsoup_2_4, + fcgi, +}: stdenv.mkDerivation rec { pname = "valum"; @@ -12,8 +24,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-baAv83YiX8HdBm/t++ktB7pmTVlt4aWZ5xnsAs/NrTI="; }; - nativeBuildInputs = [ meson ninja pkg-config ]; - buildInputs = [ glib vala ctpl libgee libsoup_2_4 fcgi ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; + buildInputs = [ + glib + vala + ctpl + libgee + libsoup_2_4 + fcgi + ]; meta = with lib; { homepage = "https://github.com/valum-framework/valum"; diff --git a/pkgs/by-name/va/valuta/package.nix b/pkgs/by-name/va/valuta/package.nix index a9ea0aeda8cd50..d69fb50dcb4340 100644 --- a/pkgs/by-name/va/valuta/package.nix +++ b/pkgs/by-name/va/valuta/package.nix @@ -1,16 +1,17 @@ -{ lib -, python3Packages -, fetchFromGitHub -, meson -, ninja -, pkg-config -, blueprint-compiler -, desktop-file-utils -, gtk4 -, gst_all_1 -, libsoup_3 -, libadwaita -, wrapGAppsHook4 +{ + lib, + python3Packages, + fetchFromGitHub, + meson, + ninja, + pkg-config, + blueprint-compiler, + desktop-file-utils, + gtk4, + gst_all_1, + libsoup_3, + libadwaita, + wrapGAppsHook4, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/va/vamp-plugin-sdk/package.nix b/pkgs/by-name/va/vamp-plugin-sdk/package.nix index a483f7023d0451..e7d538d1af06c5 100644 --- a/pkgs/by-name/va/vamp-plugin-sdk/package.nix +++ b/pkgs/by-name/va/vamp-plugin-sdk/package.nix @@ -1,7 +1,13 @@ # set VAMP_PATH ? # plugins availible on sourceforge and http://www.vamp-plugins.org/download.html (various licenses) -{ lib, stdenv, fetchFromGitHub, pkg-config, libsndfile }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libsndfile, +}: stdenv.mkDerivation rec { pname = "vamp-plugin-sdk"; diff --git a/pkgs/by-name/va/vanilla-dmz/package.nix b/pkgs/by-name/va/vanilla-dmz/package.nix index 23253eef72c2f7..b6ff58b83557d7 100644 --- a/pkgs/by-name/va/vanilla-dmz/package.nix +++ b/pkgs/by-name/va/vanilla-dmz/package.nix @@ -1,8 +1,9 @@ -{ stdenvNoCC -, lib -, fetchzip -, xorg -, hicolor-icon-theme +{ + stdenvNoCC, + lib, + fetchzip, + xorg, + hicolor-icon-theme, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/va/varia/package.nix b/pkgs/by-name/va/varia/package.nix index e4ad34d407762a..fd331c451800a2 100644 --- a/pkgs/by-name/va/varia/package.nix +++ b/pkgs/by-name/va/varia/package.nix @@ -1,14 +1,15 @@ -{ lib -, python3Packages -, fetchFromGitHub -, aria2 -, meson -, ninja -, pkg-config -, gobject-introspection -, wrapGAppsHook4 -, desktop-file-utils -, libadwaita +{ + lib, + python3Packages, + fetchFromGitHub, + aria2, + meson, + ninja, + pkg-config, + gobject-introspection, + wrapGAppsHook4, + desktop-file-utils, + libadwaita, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/va/variety/package.nix b/pkgs/by-name/va/variety/package.nix index ddfa2f9ea85109..81ec12631f1ecb 100644 --- a/pkgs/by-name/va/variety/package.nix +++ b/pkgs/by-name/va/variety/package.nix @@ -1,21 +1,22 @@ -{ lib -, fetchFromGitHub -, gexiv2 -, gobject-introspection -, gtk3 -, hicolor-icon-theme -, intltool -, libnotify -, librsvg -, python3 -, runtimeShell -, wrapGAppsHook3 -, fehSupport ? false -, feh -, imagemagickSupport ? true -, imagemagick -, appindicatorSupport ? true -, libayatana-appindicator +{ + lib, + fetchFromGitHub, + gexiv2, + gobject-introspection, + gtk3, + hicolor-icon-theme, + intltool, + libnotify, + librsvg, + python3, + runtimeShell, + wrapGAppsHook3, + fehSupport ? false, + feh, + imagemagickSupport ? true, + imagemagick, + appindicatorSupport ? true, + libayatana-appindicator, }: python3.pkgs.buildPythonApplication rec { @@ -41,24 +42,25 @@ python3.pkgs.buildPythonApplication rec { hicolor-icon-theme libnotify librsvg - ] - ++ lib.optional appindicatorSupport libayatana-appindicator; + ] ++ lib.optional appindicatorSupport libayatana-appindicator; - propagatedBuildInputs = with python3.pkgs; [ - beautifulsoup4 - configobj - dbus-python - distutils-extra - httplib2 - lxml - pillow - pycairo - pygobject3 - requests - setuptools - ] - ++ lib.optional fehSupport feh - ++ lib.optional imagemagickSupport imagemagick; + propagatedBuildInputs = + with python3.pkgs; + [ + beautifulsoup4 + configobj + dbus-python + distutils-extra + httplib2 + lxml + pillow + pycairo + pygobject3 + requests + setuptools + ] + ++ lib.optional fehSupport feh + ++ lib.optional imagemagickSupport imagemagick; doCheck = false; @@ -95,6 +97,9 @@ python3.pkgs.buildPythonApplication rec { blur, as well as options to layer quotes and a clock onto the background. ''; license = licenses.gpl3Plus; - maintainers = with maintainers; [ p3psi zfnmxt ]; + maintainers = with maintainers; [ + p3psi + zfnmxt + ]; }; } diff --git a/pkgs/by-name/va/varscan/package.nix b/pkgs/by-name/va/varscan/package.nix index bf6d16c3701d28..6532d60820e4ca 100644 --- a/pkgs/by-name/va/varscan/package.nix +++ b/pkgs/by-name/va/varscan/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, jre, makeWrapper}: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "varscan"; diff --git a/pkgs/by-name/va/vassal/package.nix b/pkgs/by-name/va/vassal/package.nix index a15c581ffc0b8e..fc362fb3f874ed 100644 --- a/pkgs/by-name/va/vassal/package.nix +++ b/pkgs/by-name/va/vassal/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchzip -, glib -, jre -, makeWrapper -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchzip, + glib, + jre, + makeWrapper, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -42,15 +43,18 @@ stdenv.mkDerivation rec { ''; # Don't move doc to share/, VASSAL expects it to be in the root - forceShare = [ "man" "info" ]; + forceShare = [ + "man" + "info" + ]; meta = with lib; { - description = "Free, open-source boardgame engine"; - homepage = "https://vassalengine.org/"; - sourceProvenance = with sourceTypes; [ binaryBytecode ]; - license = licenses.lgpl21Only; - maintainers = with maintainers; [ tvestelind ]; - platforms = platforms.unix; - mainProgram = "vassal"; + description = "Free, open-source boardgame engine"; + homepage = "https://vassalengine.org/"; + sourceProvenance = with sourceTypes; [ binaryBytecode ]; + license = licenses.lgpl21Only; + maintainers = with maintainers; [ tvestelind ]; + platforms = platforms.unix; + mainProgram = "vassal"; }; } diff --git a/pkgs/by-name/va/vault-medusa/package.nix b/pkgs/by-name/va/vault-medusa/package.nix index 2995d4b9cd0b3b..00b599fb4af183 100644 --- a/pkgs/by-name/va/vault-medusa/package.nix +++ b/pkgs/by-name/va/vault-medusa/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "vault-medusa"; diff --git a/pkgs/by-name/va/vault-ssh-plus/package.nix b/pkgs/by-name/va/vault-ssh-plus/package.nix index 908d5abb8eecdc..f0b472b4f20dbd 100644 --- a/pkgs/by-name/va/vault-ssh-plus/package.nix +++ b/pkgs/by-name/va/vault-ssh-plus/package.nix @@ -1,10 +1,11 @@ -{ buildGoModule -, fetchFromGitHub -, makeWrapper -, lib -, openssh -, testers -, vault-ssh-plus +{ + buildGoModule, + fetchFromGitHub, + makeWrapper, + lib, + openssh, + testers, + vault-ssh-plus, }: buildGoModule rec { pname = "vault-ssh-plus"; diff --git a/pkgs/by-name/va/vault-unseal/package.nix b/pkgs/by-name/va/vault-unseal/package.nix index 0014d995b9cd65..e6952c5814c416 100644 --- a/pkgs/by-name/va/vault-unseal/package.nix +++ b/pkgs/by-name/va/vault-unseal/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: let diff --git a/pkgs/by-name/va/vaults/package.nix b/pkgs/by-name/va/vaults/package.nix index 64b2a1c1be6df4..1079eaa602a2de 100644 --- a/pkgs/by-name/va/vaults/package.nix +++ b/pkgs/by-name/va/vaults/package.nix @@ -1,22 +1,23 @@ -{ fetchFromGitHub -, lib -, stdenv -, appstream-glib -, desktop-file-utils -, meson -, ninja -, pkg-config -, python3 -, rustPlatform -, rustc -, cargo -, wrapGAppsHook3 -, glib -, gtk4 -, libadwaita -, wayland -, gocryptfs -, cryfs +{ + fetchFromGitHub, + lib, + stdenv, + appstream-glib, + desktop-file-utils, + meson, + ninja, + pkg-config, + python3, + rustPlatform, + rustc, + cargo, + wrapGAppsHook3, + glib, + gtk4, + libadwaita, + wayland, + gocryptfs, + cryfs, }: stdenv.mkDerivation rec { @@ -46,7 +47,12 @@ stdenv.mkDerivation rec { preFixup = '' gappsWrapperArgs+=( - --prefix PATH : "${lib.makeBinPath [ gocryptfs cryfs ]}" + --prefix PATH : "${ + lib.makeBinPath [ + gocryptfs + cryfs + ] + }" ) ''; diff --git a/pkgs/by-name/va/vazir-code-font/package.nix b/pkgs/by-name/va/vazir-code-font/package.nix index 6c76f4c6d50309..5b81c36426b3c6 100644 --- a/pkgs/by-name/va/vazir-code-font/package.nix +++ b/pkgs/by-name/va/vazir-code-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "vazir-code-font"; diff --git a/pkgs/by-name/va/vazir-fonts/package.nix b/pkgs/by-name/va/vazir-fonts/package.nix index 11b991306a0a82..3aa6170f57b16a 100644 --- a/pkgs/by-name/va/vazir-fonts/package.nix +++ b/pkgs/by-name/va/vazir-fonts/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "vazir-fonts"; diff --git a/pkgs/by-name/vb/vbam/package.nix b/pkgs/by-name/vb/vbam/package.nix index b1916a86867a64..a52c273ec56f23 100644 --- a/pkgs/by-name/vb/vbam/package.nix +++ b/pkgs/by-name/vb/vbam/package.nix @@ -1,20 +1,23 @@ -{ lib, stdenv -, cairo -, cmake -, fetchFromGitHub -, ffmpeg -, gettext -, wxGTK32 -, gtk3 -, libGLU, libGL -, openal -, pkg-config -, SDL2 -, sfml -, zip -, zlib -, wrapGAppsHook3 -, gsettings-desktop-schemas +{ + lib, + stdenv, + cairo, + cmake, + fetchFromGitHub, + ffmpeg, + gettext, + wxGTK32, + gtk3, + libGLU, + libGL, + openal, + pkg-config, + SDL2, + sfml, + zip, + zlib, + wrapGAppsHook3, + gsettings-desktop-schemas, }: stdenv.mkDerivation rec { @@ -27,7 +30,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-OtJ632H449kPRY1i4Ydlcc1tgG00Mv622KrCyJ80OF4="; }; - nativeBuildInputs = [ cmake pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapGAppsHook3 + ]; buildInputs = [ cairo @@ -52,10 +59,13 @@ stdenv.mkDerivation rec { "-DENABLE_SDL='true'" ]; - meta = with lib; { + meta = with lib; { description = "Merge of the original Visual Boy Advance forks"; license = licenses.gpl2; - maintainers = with maintainers; [ lassulus netali ]; + maintainers = with maintainers; [ + lassulus + netali + ]; homepage = "https://vba-m.com/"; platforms = lib.platforms.linux; mainProgram = "visualboyadvance-m"; diff --git a/pkgs/by-name/vb/vbetool/package.nix b/pkgs/by-name/vb/vbetool/package.nix index d969d2f61a1c01..9cf71be3c85293 100644 --- a/pkgs/by-name/vb/vbetool/package.nix +++ b/pkgs/by-name/vb/vbetool/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pciutils, libx86, zlib }: +{ + lib, + stdenv, + fetchurl, + pciutils, + libx86, + zlib, +}: stdenv.mkDerivation rec { pname = "vbetool"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "0m7rc9v8nz6w9x4x96maza139kin6lg4hscy6i13fna4672ds9jd"; }; - buildInputs = [ pciutils libx86 zlib ]; + buildInputs = [ + pciutils + libx86 + zlib + ]; patchPhase = '' substituteInPlace Makefile.in --replace '$(libdir)/libpci.a' "" diff --git a/pkgs/by-name/vb/vbindiff/package.nix b/pkgs/by-name/vb/vbindiff/package.nix index 6a9f745a779471..57aa940b41eb67 100644 --- a/pkgs/by-name/vb/vbindiff/package.nix +++ b/pkgs/by-name/vb/vbindiff/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "vbindiff"; diff --git a/pkgs/by-name/vb/vboot_reference/package.nix b/pkgs/by-name/vb/vboot_reference/package.nix index e790048ebcb5e7..3489f6c20ef757 100644 --- a/pkgs/by-name/vb/vboot_reference/package.nix +++ b/pkgs/by-name/vb/vboot_reference/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitiles, pkg-config, libuuid, openssl, libyaml, xz }: +{ + lib, + stdenv, + fetchFromGitiles, + pkg-config, + libuuid, + openssl, + libyaml, + xz, +}: stdenv.mkDerivation rec { version = "111.15329"; @@ -12,7 +21,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libuuid libyaml openssl xz ]; + buildInputs = [ + libuuid + libyaml + openssl + xz + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/vc/vcal/package.nix b/pkgs/by-name/vc/vcal/package.nix index 6b882e2710a613..1efc9ee6af6bb8 100644 --- a/pkgs/by-name/vc/vcal/package.nix +++ b/pkgs/by-name/vc/vcal/package.nix @@ -1,11 +1,16 @@ -{ stdenv, lib, fetchurl, perl }: +{ + stdenv, + lib, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "vcal"; version = "2.8"; src = fetchurl { - url = "https://waynemorrison.com/software/vcal"; + url = "https://waynemorrison.com/software/vcal"; sha256 = "0jrm0jzqxb1xjp24hwbzlxsh22gjssay9gj4zszljzdm68r5afvc"; }; diff --git a/pkgs/by-name/vc/vcdimager/package.nix b/pkgs/by-name/vc/vcdimager/package.nix index 02f959cf74edc5..af77f7532c3099 100644 --- a/pkgs/by-name/vc/vcdimager/package.nix +++ b/pkgs/by-name/vc/vcdimager/package.nix @@ -1,5 +1,14 @@ -{ stdenv, lib, fetchurl, pkg-config, libcdio, libxml2, popt -, libiconv, darwin }: +{ + stdenv, + lib, + fetchurl, + pkg-config, + libcdio, + libxml2, + popt, + libiconv, + darwin, +}: stdenv.mkDerivation rec { pname = "vcdimager"; @@ -12,8 +21,19 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libxml2 popt libiconv ] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ IOKit DiskArbitration ]); + buildInputs = + [ + libxml2 + popt + libiconv + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + IOKit + DiskArbitration + ] + ); propagatedBuildInputs = [ libcdio ]; diff --git a/pkgs/by-name/vc/vcftools/package.nix b/pkgs/by-name/vc/vcftools/package.nix index 644c7eb2bd37bc..d3b1bb1301ec0a 100644 --- a/pkgs/by-name/vc/vcftools/package.nix +++ b/pkgs/by-name/vc/vcftools/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, zlib, autoreconfHook, pkg-config, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + autoreconfHook, + pkg-config, + perl, +}: stdenv.mkDerivation rec { pname = "vcftools"; @@ -11,8 +19,14 @@ stdenv.mkDerivation rec { sha256 = "0msb09d2cnm8rlpg8bsc1lhjddvp3kf3i9dsj1qs4qgsdlzhxkyx"; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ zlib perl ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + zlib + perl + ]; meta = with lib; { description = "Set of tools written in Perl and C++ for working with VCF files, such as those generated by the 1000 Genomes Project"; diff --git a/pkgs/by-name/vc/vcg/package.nix b/pkgs/by-name/vc/vcg/package.nix index 62b39c05395e71..7fe6f3832f8694 100644 --- a/pkgs/by-name/vc/vcg/package.nix +++ b/pkgs/by-name/vc/vcg/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, eigen }: +{ + lib, + stdenv, + fetchFromGitHub, + eigen, +}: stdenv.mkDerivation rec { pname = "vcg"; diff --git a/pkgs/by-name/vc/vcpkg-tool/package.nix b/pkgs/by-name/vc/vcpkg-tool/package.nix index 04dadbcdc25bba..2f776cb3c3af09 100644 --- a/pkgs/by-name/vc/vcpkg-tool/package.nix +++ b/pkgs/by-name/vc/vcpkg-tool/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitHub -, runtimeShell -, apple-sdk_11 -, cacert -, cmake -, cmakerc -, curl -, fmt -, git -, gzip -, meson -, ninja -, openssh -, python3 -, unzip -, zip -, zstd -, runCommand -, writeText -, extraRuntimeDeps ? [] -, doWrap ? true +{ + lib, + stdenv, + fetchFromGitHub, + runtimeShell, + apple-sdk_11, + cacert, + cmake, + cmakerc, + curl, + fmt, + git, + gzip, + meson, + ninja, + openssh, + python3, + unzip, + zip, + zstd, + runCommand, + writeText, + extraRuntimeDeps ? [ ], + doWrap ? true, }: stdenv.mkDerivation (finalAttrs: { pname = "vcpkg-tool"; @@ -53,112 +54,122 @@ stdenv.mkDerivation (finalAttrs: { "-DVCPKG_DEPENDENCY_CMAKERC=ON" ]; - passAsFile = [ "vcpkgWrapper" ]; - vcpkgWrapper = let - # These are the most common binaries used by vcpkg - # Extra binaries can be added through override when needed - runtimeDeps = [ - cacert - cmake - curl - git - gzip - meson - ninja - openssh - python3 - unzip - zip - zstd - ] ++ extraRuntimeDeps; - - # Apart from adding the runtime dependencies to $PATH, - # the wrapper will also override these arguments by default. - # This is to ensure that the executable does not try to - # write to the nix store. If the user tries to set any of the - # arguments themself, the wrapper will detect that the - # arguments are present, and prefer the user-provided value. - # - # It is also possible to override the cli arguments by - # settings either of the nix-specific environment variables. - argsWithDefault = [ - { - arg = "--downloads-root"; - env = "NIX_VCPKG_DOWNLOADS_ROOT"; - default = "$NIX_VCPKG_WRITABLE_PATH/downloads"; - } - { - arg = "--x-buildtrees-root"; - env = "NIX_VCPKG_BUILDTREES_ROOT"; - default = "$NIX_VCPKG_WRITABLE_PATH/buildtrees"; - } - { - arg = "--x-packages-root"; - env = "NIX_VCPKG_PACKAGES_ROOT"; - default = "$NIX_VCPKG_WRITABLE_PATH/packages"; + vcpkgWrapper = + let + # These are the most common binaries used by vcpkg + # Extra binaries can be added through override when needed + runtimeDeps = [ + cacert + cmake + curl + git + gzip + meson + ninja + openssh + python3 + unzip + zip + zstd + ] ++ extraRuntimeDeps; + + # Apart from adding the runtime dependencies to $PATH, + # the wrapper will also override these arguments by default. + # This is to ensure that the executable does not try to + # write to the nix store. If the user tries to set any of the + # arguments themself, the wrapper will detect that the + # arguments are present, and prefer the user-provided value. + # + # It is also possible to override the cli arguments by + # settings either of the nix-specific environment variables. + argsWithDefault = [ + { + arg = "--downloads-root"; + env = "NIX_VCPKG_DOWNLOADS_ROOT"; + default = "$NIX_VCPKG_WRITABLE_PATH/downloads"; + } + { + arg = "--x-buildtrees-root"; + env = "NIX_VCPKG_BUILDTREES_ROOT"; + default = "$NIX_VCPKG_WRITABLE_PATH/buildtrees"; + } + { + arg = "--x-packages-root"; + env = "NIX_VCPKG_PACKAGES_ROOT"; + default = "$NIX_VCPKG_WRITABLE_PATH/packages"; + } + { + arg = "--x-install-root"; + env = "NIX_VCPKG_INSTALL_ROOT"; + default = "$NIX_VCPKG_WRITABLE_PATH/installed"; + } + ]; + in + '' + #!${runtimeShell} + + get_vcpkg_path() { + if [[ -n $NIX_VCPKG_WRITABLE_PATH ]]; then + echo "$NIX_VCPKG_WRITABLE_PATH" + elif [[ -n $XDG_CACHE_HOME ]]; then + echo "$XDG_CACHE_HOME/vcpkg" + elif [[ -n $HOME ]]; then + echo "$HOME/.vcpkg/root" + elif [[ -n $TMP ]]; then + echo "$TMP" + else + echo "/tmp" + fi } - { - arg = "--x-install-root"; - env = "NIX_VCPKG_INSTALL_ROOT"; - default = "$NIX_VCPKG_WRITABLE_PATH/installed"; - } - ]; - in '' - #!${runtimeShell} - - get_vcpkg_path() { - if [[ -n $NIX_VCPKG_WRITABLE_PATH ]]; then - echo "$NIX_VCPKG_WRITABLE_PATH" - elif [[ -n $XDG_CACHE_HOME ]]; then - echo "$XDG_CACHE_HOME/vcpkg" - elif [[ -n $HOME ]]; then - echo "$HOME/.vcpkg/root" - elif [[ -n $TMP ]]; then - echo "$TMP" - else - echo "/tmp" + + NIX_VCPKG_WRITABLE_PATH=$(get_vcpkg_path) + + ${lib.concatMapStringsSep "\n" ( + { env, default, ... }: ''${env}=''${${env}-"${default}"}'' + ) argsWithDefault} + + export PATH="${lib.makeBinPath runtimeDeps}''${PATH:+":$PATH"}" + + ARGS=( "$@" ) + FINAL_NONMODIFIED_ARGS=() + + for (( i=0; i<''${#ARGS[@]}; i++ )); + do + case "''${ARGS[i]%%=*}" in + ${ + let + f = + { arg, env, ... }: + '' + '${arg}') + ${env}="''${ARGS[i]#*=}" + if [ "''$${env}" = '${arg}' ]; then + ${env}="''${ARGS[i+1]}" + ((i++)) + fi + ;; + ''; + in + lib.concatMapStringsSep "\n" f argsWithDefault + } + *) + FINAL_NONMODIFIED_ARGS+=(''${ARGS[i]}) + ;; + esac + done + + if [ "''${NIX_VCPKG_DEBUG_PRINT_ENVVARS-'false'}" = 'true' ]; then + ${lib.concatMapStringsSep "\n" ( + { env, ... }: " " + ''echo "${env} = ''$${env}"'' + ) argsWithDefault} + echo "" fi - } - - NIX_VCPKG_WRITABLE_PATH=$(get_vcpkg_path) - - ${lib.concatMapStringsSep "\n" ({ env, default, ... }: ''${env}=''${${env}-"${default}"}'') argsWithDefault} - - export PATH="${lib.makeBinPath runtimeDeps}''${PATH:+":$PATH"}" - - ARGS=( "$@" ) - FINAL_NONMODIFIED_ARGS=() - - for (( i=0; i<''${#ARGS[@]}; i++ )); - do - case "''${ARGS[i]%%=*}" in - ${let - f = { arg, env, ... }: '' - '${arg}') - ${env}="''${ARGS[i]#*=}" - if [ "''$${env}" = '${arg}' ]; then - ${env}="''${ARGS[i+1]}" - ((i++)) - fi - ;; - ''; - in lib.concatMapStringsSep "\n" f argsWithDefault} - *) - FINAL_NONMODIFIED_ARGS+=(''${ARGS[i]}) - ;; - esac - done - - if [ "''${NIX_VCPKG_DEBUG_PRINT_ENVVARS-'false'}" = 'true' ]; then - ${lib.concatMapStringsSep "\n" ({ env, ... }: " " + ''echo "${env} = ''$${env}"'') argsWithDefault} - echo "" - fi - - exec -a "$0" "${placeholder "out"}/bin/.vcpkg-wrapped" \ - ${lib.concatMapStringsSep "\n" ({ arg, env, ... }: " " + ''${arg}="''$${env}" \'') argsWithDefault} - "''${FINAL_NONMODIFIED_ARGS[@]}" - ''; + + exec -a "$0" "${placeholder "out"}/bin/.vcpkg-wrapped" \ + ${lib.concatMapStringsSep "\n" ({ arg, env, ... }: " " + ''${arg}="''$${env}" \'') argsWithDefault} + "''${FINAL_NONMODIFIED_ARGS[@]}" + ''; postFixup = lib.optionalString doWrap '' mv "$out/bin/vcpkg" "$out/bin/.vcpkg-wrapped" @@ -166,7 +177,7 @@ stdenv.mkDerivation (finalAttrs: { ''; passthru.tests = { - testWrapper = runCommand "vcpkg-tool-test-wrapper" { buildInputs = [ finalAttrs.finalPackage ]; } '' + testWrapper = runCommand "vcpkg-tool-test-wrapper" { buildInputs = [ finalAttrs.finalPackage ]; } '' export NIX_VCPKG_DEBUG_PRINT_ENVVARS=true vcpkg --x-packages-root="test" --x-install-root="test2" contact > "$out" @@ -185,7 +196,11 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/microsoft/vcpkg-tool"; changelog = "https://github.com/microsoft/vcpkg-tool/releases/tag/${finalAttrs.src.rev}"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ guekka gracicot h7x4 ]; + maintainers = with lib.maintainers; [ + guekka + gracicot + h7x4 + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/by-name/vc/vcpkg/package.nix b/pkgs/by-name/vc/vcpkg/package.nix index fdad425713d31d..9d9313a33ca954 100644 --- a/pkgs/by-name/vc/vcpkg/package.nix +++ b/pkgs/by-name/vc/vcpkg/package.nix @@ -1,9 +1,10 @@ -{ fetchFromGitHub -, stdenvNoCC -, lib -, vcpkg-tool -, makeWrapper -, doWrap ? true +{ + fetchFromGitHub, + stdenvNoCC, + lib, + vcpkg-tool, + makeWrapper, + doWrap ? true, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -50,28 +51,32 @@ stdenvNoCC.mkDerivation (finalAttrs: { ''; installPhase = '' - runHook preInstall + runHook preInstall - mkdir -p "$out/bin" "$out/share/vcpkg/scripts/buildsystems" - cp --preserve=mode -r ./{docs,ports,triplets,scripts,.vcpkg-root,versions,LICENSE.txt,vcpkg-bundle.json} "$out/share/vcpkg/" + mkdir -p "$out/bin" "$out/share/vcpkg/scripts/buildsystems" + cp --preserve=mode -r ./{docs,ports,triplets,scripts,.vcpkg-root,versions,LICENSE.txt,vcpkg-bundle.json} "$out/share/vcpkg/" - ${lib.optionalString doWrap '' - makeWrapper "${vcpkg-tool}/bin/vcpkg" "$out/bin/vcpkg" \ - --set-default VCPKG_ROOT "$out/share/vcpkg" - ''} + ${lib.optionalString doWrap '' + makeWrapper "${vcpkg-tool}/bin/vcpkg" "$out/bin/vcpkg" \ + --set-default VCPKG_ROOT "$out/share/vcpkg" + ''} - ln -s "$out/bin/vcpkg" "$out/share/vcpkg/vcpkg" - touch "$out/share/vcpkg/vcpkg.disable-metrics" + ln -s "$out/bin/vcpkg" "$out/share/vcpkg/vcpkg" + touch "$out/share/vcpkg/vcpkg.disable-metrics" - runHook postInstall - ''; + runHook postInstall + ''; meta = { description = "C++ Library Manager for Windows, Linux, and macOS"; mainProgram = "vcpkg"; homepage = "https://vcpkg.io/"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ guekka gracicot h7x4 ]; + maintainers = with lib.maintainers; [ + guekka + gracicot + h7x4 + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/by-name/vc/vcs/package.nix b/pkgs/by-name/vc/vcs/package.nix index 91a966bd1f4eaa..0536fbe8e956ac 100644 --- a/pkgs/by-name/vc/vcs/package.nix +++ b/pkgs/by-name/vc/vcs/package.nix @@ -1,13 +1,31 @@ -{ lib, stdenv, fetchurl, makeWrapper -, coreutils, ffmpeg, gawk, gnugrep, gnused, imagemagick, mplayer -, util-linux, getopt -, dejavu_fonts +{ + lib, + stdenv, + fetchurl, + makeWrapper, + coreutils, + ffmpeg, + gawk, + gnugrep, + gnused, + imagemagick, + mplayer, + util-linux, + getopt, + dejavu_fonts, }: let version = "1.13.4"; gopt = if stdenv.hostPlatform.isLinux then util-linux else getopt; runtimeDeps = [ - coreutils ffmpeg gawk gnugrep gnused imagemagick mplayer gopt + coreutils + ffmpeg + gawk + gnugrep + gnused + imagemagick + mplayer + gopt ]; in stdenv.mkDerivation { diff --git a/pkgs/by-name/vc/vcs_query/package.nix b/pkgs/by-name/vc/vcs_query/package.nix index ccfdc62b12968f..0449f3eac05e7d 100644 --- a/pkgs/by-name/vc/vcs_query/package.nix +++ b/pkgs/by-name/vc/vcs_query/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, python3, fetchFromGitHub }: +{ + lib, + stdenv, + python3, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "vcs_query"; @@ -11,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "05va0na9yxkpqhm9v0x3k58148qcf2bbcv5bnmj7vn9r7fwyjrlx"; }; - nativeBuildInputs = [ python3 python3.pkgs.wrapPython ]; + nativeBuildInputs = [ + python3 + python3.pkgs.wrapPython + ]; dontBuild = true; diff --git a/pkgs/by-name/vc/vcsh/package.nix b/pkgs/by-name/vc/vcsh/package.nix index 1477695506e643..7e1af72cbfd542 100644 --- a/pkgs/by-name/vc/vcsh/package.nix +++ b/pkgs/by-name/vc/vcsh/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchurl -, makeWrapper -, pkg-config -, git -, perlPackages +{ + lib, + stdenv, + fetchurl, + makeWrapper, + pkg-config, + git, + perlPackages, }: stdenv.mkDerivation rec { @@ -22,17 +24,29 @@ stdenv.mkDerivation rec { buildInputs = [ git ]; - nativeCheckInputs = [] - ++ (with perlPackages; [ perl ShellCommand TestMost ]); + nativeCheckInputs = + [ ] + ++ (with perlPackages; [ + perl + ShellCommand + TestMost + ]); - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; meta = with lib; { description = "Version Control System for $HOME"; homepage = "https://github.com/RichiH/vcsh"; changelog = "https://github.com/RichiH/vcsh/blob/v${version}/changelog"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ ttuegel alerque ]; + maintainers = with maintainers; [ + ttuegel + alerque + ]; platforms = platforms.unix; mainProgram = "vcsh"; }; diff --git a/pkgs/by-name/vc/vcsi/package.nix b/pkgs/by-name/vc/vcsi/package.nix index 7db0fdd6962e0e..1e424382c7676a 100644 --- a/pkgs/by-name/vc/vcsi/package.nix +++ b/pkgs/by-name/vc/vcsi/package.nix @@ -1,4 +1,9 @@ -{ lib, python3Packages, fetchFromGitHub, ffmpeg }: +{ + lib, + python3Packages, + fetchFromGitHub, + ffmpeg, +}: python3Packages.buildPythonApplication rec { pname = "vcsi"; @@ -32,7 +37,10 @@ python3Packages.buildPythonApplication rec { description = "Create video contact sheets"; homepage = "https://github.com/amietn/vcsi"; license = licenses.mit; - maintainers = with maintainers; [ dandellion zopieux ]; + maintainers = with maintainers; [ + dandellion + zopieux + ]; mainProgram = "vcsi"; }; } diff --git a/pkgs/by-name/vc/vcstool/package.nix b/pkgs/by-name/vc/vcstool/package.nix index 0350c7296fde80..0402ca5135e628 100644 --- a/pkgs/by-name/vc/vcstool/package.nix +++ b/pkgs/by-name/vc/vcstool/package.nix @@ -1,5 +1,11 @@ -{ lib, python3Packages, fetchPypi -, git, breezy, subversion }: +{ + lib, + python3Packages, + fetchPypi, + git, + breezy, + subversion, +}: with python3Packages; @@ -12,9 +18,21 @@ buildPythonApplication rec { sha256 = "04b3a963e15386660f139e5b95d293e43e3cb414e3b13e14ee36f5223032ee2c"; }; - propagatedBuildInputs = [ pyyaml setuptools ]; + propagatedBuildInputs = [ + pyyaml + setuptools + ]; - makeWrapperArgs = ["--prefix" "PATH" ":" (lib.makeBinPath [ git breezy subversion ])]; + makeWrapperArgs = [ + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ + git + breezy + subversion + ]) + ]; doCheck = false; # requires network diff --git a/pkgs/by-name/vc/vcv-rack/package.nix b/pkgs/by-name/vc/vcv-rack/package.nix index db7cdf11ba9cde..16ec47c31c5d09 100644 --- a/pkgs/by-name/vc/vcv-rack/package.nix +++ b/pkgs/by-name/vc/vcv-rack/package.nix @@ -1,31 +1,32 @@ -{ alsa-lib -, cmake -, copyDesktopItems -, curl -, fetchFromBitbucket -, fetchFromGitHub -, ghc_filesystem -, glew -, glfw -, zenity -, gtk3-x11 -, imagemagick -, jansson -, jq -, lib -, libarchive -, libicns -, libjack2 -, libpulseaudio -, libsamplerate -, makeDesktopItem -, makeWrapper -, pkg-config -, rtmidi -, speexdsp -, stdenv -, wrapGAppsHook3 -, zstd +{ + alsa-lib, + cmake, + copyDesktopItems, + curl, + fetchFromBitbucket, + fetchFromGitHub, + ghc_filesystem, + glew, + glfw, + zenity, + gtk3-x11, + imagemagick, + jansson, + jq, + lib, + libarchive, + libicns, + libjack2, + libpulseaudio, + libsamplerate, + makeDesktopItem, + makeWrapper, + pkg-config, + rtmidi, + speexdsp, + stdenv, + wrapGAppsHook3, + zstd, }: let @@ -98,9 +99,16 @@ let sha256 = "11gpl0ak757ilrq4fi0brj0chmlcr1hihc32yd7qza4fxjw2yx2v"; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ alsa-lib libjack2 libpulseaudio ]; + buildInputs = [ + alsa-lib + libjack2 + libpulseaudio + ]; cmakeFlags = [ "-DRTAUDIO_API_ALSA=ON" @@ -123,7 +131,11 @@ stdenv.mkDerivation rec { comment = "Create music by patching together virtual synthesizer modules"; exec = "Rack"; icon = "Rack"; - categories = [ "AudioVideo" "AudioVideoEditing" "Audio" ]; + categories = [ + "AudioVideo" + "AudioVideoEditing" + "Audio" + ]; keywords = [ "music" ]; }) ]; @@ -204,12 +216,14 @@ stdenv.mkDerivation rec { zstd ]; - makeFlags = lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ - "CROSS_COMPILE=${stdenv.cc.targetPrefix}" - ] ++ [ - "all" - "plugins" - ]; + makeFlags = + lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "CROSS_COMPILE=${stdenv.cc.targetPrefix}" + ] + ++ [ + "all" + "plugins" + ]; installPhase = '' runHook preInstall @@ -248,8 +262,16 @@ stdenv.mkDerivation rec { homepage = "https://vcvrack.com/"; # The source is GPL3+ licensed, some of the art is CC-BY-NC 4.0 or under a # no-derivatives clause - license = with licenses; [ gpl3Plus cc-by-nc-40 unfreeRedistributable ]; - maintainers = with maintainers; [ nathyong jpotier ddelabru ]; + license = with licenses; [ + gpl3Plus + cc-by-nc-40 + unfreeRedistributable + ]; + maintainers = with maintainers; [ + nathyong + jpotier + ddelabru + ]; mainProgram = "Rack"; platforms = platforms.linux; }; diff --git a/pkgs/by-name/vd/vde2/package.nix b/pkgs/by-name/vd/vde2/package.nix index 0d86c56378663b..695940bee37e8a 100644 --- a/pkgs/by-name/vd/vde2/package.nix +++ b/pkgs/by-name/vd/vde2/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, autoreconfHook, libpcap, wolfssl }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + libpcap, + wolfssl, +}: stdenv.mkDerivation rec { pname = "vde2"; @@ -24,7 +32,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ libpcap wolfssl ]; + buildInputs = [ + libpcap + wolfssl + ]; meta = with lib; { homepage = "https://github.com/virtualsquare/vde-2"; diff --git a/pkgs/by-name/vd/vdhcoapp/filepicker.nix b/pkgs/by-name/vd/vdhcoapp/filepicker.nix index 7aec0f9e2838f6..3a8b145a8c90e1 100644 --- a/pkgs/by-name/vd/vdhcoapp/filepicker.nix +++ b/pkgs/by-name/vd/vdhcoapp/filepicker.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, atk -, gtk3 -, glib +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + atk, + gtk3, + glib, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/vd/vdhcoapp/package.nix b/pkgs/by-name/vd/vdhcoapp/package.nix index ad61515b9ecbab..64465bd2cc08d4 100644 --- a/pkgs/by-name/vd/vdhcoapp/package.nix +++ b/pkgs/by-name/vd/vdhcoapp/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, buildNpmPackage -, nodejs -, ffmpeg -, callPackage -, substituteAll -, makeWrapper -, toml2json -, jq +{ + lib, + fetchFromGitHub, + buildNpmPackage, + nodejs, + ffmpeg, + callPackage, + substituteAll, + makeWrapper, + toml2json, + jq, }: buildNpmPackage rec { pname = "vdhcoapp"; @@ -34,7 +35,7 @@ buildNpmPackage rec { (substituteAll { src = ./ffmpeg-filepicker.patch; inherit ffmpeg; - filepicker = lib.getExe (callPackage ./filepicker.nix {}); + filepicker = lib.getExe (callPackage ./filepicker.nix { }); }) ]; diff --git a/pkgs/by-name/vd/vdmfec/package.nix b/pkgs/by-name/vd/vdmfec/package.nix index 20dda868a66436..6b9f4387be87d8 100644 --- a/pkgs/by-name/vd/vdmfec/package.nix +++ b/pkgs/by-name/vd/vdmfec/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "vdmfec"; @@ -13,7 +17,10 @@ stdenv.mkDerivation rec { description = "Program that adds error correction blocks"; homepage = "http://members.tripod.com/professor_tom/archives/index.html"; maintainers = [ maintainers.ar1a ]; - license = with licenses; [ gpl2 /* for vdmfec */ bsd2 /* for fec */ ]; + license = with licenses; [ + gpl2 # for vdmfec + bsd2 # for fec + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/vd/vdo/package.nix b/pkgs/by-name/vd/vdo/package.nix index bbfb8c36d725b0..f705dd6f8d186b 100644 --- a/pkgs/by-name/vd/vdo/package.nix +++ b/pkgs/by-name/vd/vdo/package.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchFromGitHub -, installShellFiles -, libuuid -, lvm2_dmeventd # -, zlib -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + libuuid, + lvm2_dmeventd, # + zlib, + python3, }: stdenv.mkDerivation rec { @@ -58,7 +60,13 @@ stdenv.mkDerivation rec { homepage = "https://github.com/dm-vdo/vdo"; description = "Set of userspace tools for managing pools of deduplicated and/or compressed block storage"; # platforms are defined in https://github.com/dm-vdo/vdo/blob/master/utils/uds/atomicDefs.h - platforms = [ "x86_64-linux" "aarch64-linux" "s390-linux" "powerpc64-linux" "powerpc64le-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "s390-linux" + "powerpc64-linux" + "powerpc64le-linux" + ]; license = with licenses; [ gpl2Plus ]; maintainers = [ ]; }; diff --git a/pkgs/by-name/vd/vdpauinfo/package.nix b/pkgs/by-name/vd/vdpauinfo/package.nix index 0ca3354433dce9..0fd03c29d68f0d 100644 --- a/pkgs/by-name/vd/vdpauinfo/package.nix +++ b/pkgs/by-name/vd/vdpauinfo/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pkg-config, libvdpau }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + libvdpau, +}: stdenv.mkDerivation rec { pname = "vdpauinfo"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { hash = "sha256-uOs/r8Ow7KvSpY1NhD2A+D4Qs6iWJe4fZGfVj6nIiCw="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libvdpau ]; diff --git a/pkgs/by-name/vd/vdrift/package.nix b/pkgs/by-name/vd/vdrift/package.nix index 7f10560b5341e1..98771524fb5de4 100644 --- a/pkgs/by-name/vd/vdrift/package.nix +++ b/pkgs/by-name/vd/vdrift/package.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchsvn -, pkg-config -, scons -, libGLU -, libGL -, SDL2 -, SDL2_image -, libvorbis -, bullet -, curl -, gettext -, writeShellScriptBin +{ + lib, + stdenv, + fetchFromGitHub, + fetchsvn, + pkg-config, + scons, + libGLU, + libGL, + SDL2, + SDL2_image, + libvorbis, + bullet, + curl, + gettext, + writeShellScriptBin, -, data ? fetchsvn { + data ? fetchsvn { url = "svn://svn.code.sf.net/p/vdrift/code/vdrift-data"; rev = "1446"; sha256 = "sha256-KEu49GAOfenPyuaUItt6W9pkuqUNpXgmTSFuc7ThljQ="; - } + }, }: let version = "unstable-2021-09-05"; @@ -33,8 +34,20 @@ let sha256 = "sha256-DrzRF4WzwEXCNALq0jz8nHWZ1oYTEsdrvSYVYI1WkTI="; }; - nativeBuildInputs = [ pkg-config scons ]; - buildInputs = [ libGLU libGL SDL2 SDL2_image libvorbis bullet curl gettext ]; + nativeBuildInputs = [ + pkg-config + scons + ]; + buildInputs = [ + libGLU + libGL + SDL2 + SDL2_image + libvorbis + bullet + curl + gettext + ]; patches = [ ./0001-Ignore-missing-data-for-installation.patch @@ -58,14 +71,15 @@ let }; wrappedName = "vdrift-${version}-with-data-${toString data.rev}"; in -(writeShellScriptBin "vdrift" '' +(writeShellScriptBin "vdrift" '' export VDRIFT_DATA_DIRECTORY="${data}" exec ${bin}/bin/vdrift "$@" -'').overrideAttrs (_: { - name = wrappedName; - meta = bin.meta // { - hydraPlatforms = [ ]; - }; - unwrapped = bin; - inherit bin data; -}) +'').overrideAttrs + (_: { + name = wrappedName; + meta = bin.meta // { + hydraPlatforms = [ ]; + }; + unwrapped = bin; + inherit bin data; + }) diff --git a/pkgs/by-name/vd/vdrsymbols/package.nix b/pkgs/by-name/vd/vdrsymbols/package.nix index fd7aba9ec063f0..253d8fa9629136 100644 --- a/pkgs/by-name/vd/vdrsymbols/package.nix +++ b/pkgs/by-name/vd/vdrsymbols/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "vdrsymbols"; @@ -27,6 +31,9 @@ stdenvNoCC.mkDerivation rec { # Copyright (c) 2006 by Tavmjong Bah. All Rights Reserved. # DejaVu changes are in public domain # See https://dejavu-fonts.github.io/License.html for details - license = with licenses; [ bitstreamVera publicDomain ]; + license = with licenses; [ + bitstreamVera + publicDomain + ]; }; } diff --git a/pkgs/by-name/ve/vectoroids/package.nix b/pkgs/by-name/ve/vectoroids/package.nix index c3e383a84b6407..9d3bc9f943ff29 100644 --- a/pkgs/by-name/ve/vectoroids/package.nix +++ b/pkgs/by-name/ve/vectoroids/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, SDL -, SDL_image -, SDL_mixer +{ + lib, + stdenv, + fetchurl, + SDL, + SDL_image, + SDL_mixer, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ve/vegeta/package.nix b/pkgs/by-name/ve/vegeta/package.nix index 17f0dcc37e55a5..950ddd96b297af 100644 --- a/pkgs/by-name/ve/vegeta/package.nix +++ b/pkgs/by-name/ve/vegeta/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: buildGoModule rec { @@ -19,11 +20,17 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = (lib.mapAttrsToList (n: v: "-X main.${n}=${v}") { - Version = version; - Commit = rev; - Date = "1970-01-01T00:00:00Z"; - }) ++ [ "-s" "-w" "-extldflags '-static'" ]; + ldflags = + (lib.mapAttrsToList (n: v: "-X main.${n}=${v}") { + Version = version; + Commit = rev; + Date = "1970-01-01T00:00:00Z"; + }) + ++ [ + "-s" + "-w" + "-extldflags '-static'" + ]; meta = with lib; { description = "Versatile HTTP load testing tool"; diff --git a/pkgs/by-name/ve/vegur/package.nix b/pkgs/by-name/ve/vegur/package.nix index bfcf3f6e80090e..316a7c4ee01c18 100644 --- a/pkgs/by-name/ve/vegur/package.nix +++ b/pkgs/by-name/ve/vegur/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let majorVersion = "0"; diff --git a/pkgs/by-name/ve/velero/package.nix b/pkgs/by-name/ve/velero/package.nix index 5c47803841d954..8624c801db9ae0 100644 --- a/pkgs/by-name/ve/velero/package.nix +++ b/pkgs/by-name/ve/velero/package.nix @@ -1,10 +1,15 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "velero"; version = "1.15.0"; - src = fetchFromGitHub { owner = "vmware-tanzu"; repo = "velero"; @@ -13,7 +18,8 @@ buildGoModule rec { }; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X github.com/vmware-tanzu/velero/pkg/buildinfo.Version=v${version}" "-X github.com/vmware-tanzu/velero/pkg/buildinfo.ImageRegistry=velero" "-X github.com/vmware-tanzu/velero/pkg/buildinfo.GitTreeState=clean" @@ -22,7 +28,12 @@ buildGoModule rec { vendorHash = "sha256-FcyqCnOZSdoyOjBIrEC1AKM5KqWSkNxbgvXeG3Y0CO4="; - excludedPackages = [ "issue-template-gen" "release-tools" "v1" "velero-restic-restore-helper" ]; + excludedPackages = [ + "issue-template-gen" + "release-tools" + "v1" + "velero-restic-restore-helper" + ]; doCheck = false; # Tests expect a running cluster see https://github.com/vmware-tanzu/velero/tree/main/test/e2e doInstallCheck = true; @@ -38,12 +49,13 @@ buildGoModule rec { ''; meta = with lib; { - description = - "A utility for managing disaster recovery, specifically for your Kubernetes cluster resources and persistent volumes"; + description = "A utility for managing disaster recovery, specifically for your Kubernetes cluster resources and persistent volumes"; homepage = "https://velero.io/"; - changelog = - "https://github.com/vmware-tanzu/velero/releases/tag/v${version}"; + changelog = "https://github.com/vmware-tanzu/velero/releases/tag/v${version}"; license = licenses.asl20; - maintainers = [ maintainers.mbode maintainers.bryanasdev000 ]; + maintainers = [ + maintainers.mbode + maintainers.bryanasdev000 + ]; }; } diff --git a/pkgs/by-name/ve/veloren/package.nix b/pkgs/by-name/ve/veloren/package.nix index fff47f2583fa35..689abae0bc7094 100644 --- a/pkgs/by-name/ve/veloren/package.nix +++ b/pkgs/by-name/ve/veloren/package.nix @@ -120,6 +120,9 @@ rustPlatform.buildRustPackage { license = licenses.gpl3; mainProgram = "veloren-voxygen"; platforms = platforms.linux; - maintainers = with maintainers; [ rnhmjoj tomodachi94 ]; + maintainers = with maintainers; [ + rnhmjoj + tomodachi94 + ]; }; } diff --git a/pkgs/by-name/ve/vendir/package.nix b/pkgs/by-name/ve/vendir/package.nix index 1bb96595d853a8..78e9e658a1778c 100644 --- a/pkgs/by-name/ve/vendir/package.nix +++ b/pkgs/by-name/ve/vendir/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "vendir"; diff --git a/pkgs/by-name/ve/venta/package.nix b/pkgs/by-name/ve/venta/package.nix index 1f739c66006065..733f0aacac5946 100644 --- a/pkgs/by-name/ve/venta/package.nix +++ b/pkgs/by-name/ve/venta/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, gdk-pixbuf -, gtk-engine-murrine -, gtk_engines -, librsvg +{ + lib, + stdenv, + fetchFromGitHub, + gdk-pixbuf, + gtk-engine-murrine, + gtk_engines, + librsvg, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ve/ventoy/package.nix b/pkgs/by-name/ve/ventoy/package.nix index a4794f534e1164..85af9e0bcbf8f6 100644 --- a/pkgs/by-name/ve/ventoy/package.nix +++ b/pkgs/by-name/ve/ventoy/package.nix @@ -1,52 +1,58 @@ -{ lib -, autoPatchelfHook -, bash -, copyDesktopItems -, coreutils -, cryptsetup -, dosfstools -, e2fsprogs -, exfat -, fetchurl -, gawk -, gnugrep -, gnused -, gtk3 -, hexdump -, makeDesktopItem -, makeWrapper -, ntfs3g -, parted -, procps -, stdenv -, util-linux -, which -, xfsprogs -, xz -, defaultGuiType ? "" -, withCryptsetup ? false -, withXfs ? false -, withExt4 ? false -, withNtfs ? false -, withGtk3 ? defaultGuiType == "gtk3" -, withQt5 ? defaultGuiType == "qt5" -, libsForQt5 +{ + lib, + autoPatchelfHook, + bash, + copyDesktopItems, + coreutils, + cryptsetup, + dosfstools, + e2fsprogs, + exfat, + fetchurl, + gawk, + gnugrep, + gnused, + gtk3, + hexdump, + makeDesktopItem, + makeWrapper, + ntfs3g, + parted, + procps, + stdenv, + util-linux, + which, + xfsprogs, + xz, + defaultGuiType ? "", + withCryptsetup ? false, + withXfs ? false, + withExt4 ? false, + withNtfs ? false, + withGtk3 ? defaultGuiType == "gtk3", + withQt5 ? defaultGuiType == "qt5", + libsForQt5, }: -assert lib.elem defaultGuiType [ "" "gtk3" "qt5" ]; +assert lib.elem defaultGuiType [ + "" + "gtk3" + "qt5" +]; assert defaultGuiType == "gtk3" -> withGtk3; assert defaultGuiType == "qt5" -> withQt5; let inherit (lib) optionals optionalString; inherit (libsForQt5) qtbase wrapQtAppsHook; - arch = { - x86_64-linux = "x86_64"; - i686-linux = "i386"; - aarch64-linux = "aarch64"; - mipsel-linux = "mips64el"; - }.${stdenv.hostPlatform.system} - or (throw "Unsupported platform: ${stdenv.hostPlatform.system}"); + arch = + { + x86_64-linux = "x86_64"; + i686-linux = "i386"; + aarch64-linux = "aarch64"; + mipsel-linux = "mips64el"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported platform: ${stdenv.hostPlatform.system}"); in stdenv.mkDerivation (finalAttrs: { pname = "ventoy"; @@ -70,34 +76,36 @@ stdenv.mkDerivation (finalAttrs: { WebUI/static/js/languages.js tool/languages.json ''; - nativeBuildInputs = [ - autoPatchelfHook - makeWrapper - ] - ++ optionals (withQt5 || withGtk3) [ copyDesktopItems ] - ++ optionals withQt5 [ wrapQtAppsHook ]; - - buildInputs = [ - bash - coreutils - dosfstools - exfat - gawk - gnugrep - gnused - hexdump - parted - procps - util-linux - which - xz - ] - ++ optionals withCryptsetup [ cryptsetup ] - ++ optionals withExt4 [ e2fsprogs ] - ++ optionals withGtk3 [ gtk3 ] - ++ optionals withNtfs [ ntfs3g ] - ++ optionals withXfs [ xfsprogs ] - ++ optionals withQt5 [ qtbase ]; + nativeBuildInputs = + [ + autoPatchelfHook + makeWrapper + ] + ++ optionals (withQt5 || withGtk3) [ copyDesktopItems ] + ++ optionals withQt5 [ wrapQtAppsHook ]; + + buildInputs = + [ + bash + coreutils + dosfstools + exfat + gawk + gnugrep + gnused + hexdump + parted + procps + util-linux + which + xz + ] + ++ optionals withCryptsetup [ cryptsetup ] + ++ optionals withExt4 [ e2fsprogs ] + ++ optionals withGtk3 [ gtk3 ] + ++ optionals withNtfs [ ntfs3g ] + ++ optionals withXfs [ xfsprogs ] + ++ optionals withQt5 [ qtbase ]; strictDeps = true; @@ -117,71 +125,72 @@ stdenv.mkDerivation (finalAttrs: { dontConfigure = true; dontBuild = true; - installPhase = '' - runHook preInstall - - # Setup variables - local VENTOY_PATH="$out"/share/ventoy - local ARCH='${arch}' - - # Prepare - cd tool/"$ARCH" - rm ash* hexdump* mkexfatfs* mount.exfat-fuse* xzcat* - for archive in *.xz; do - xzcat "$archive" > "''${archive%.xz}" - rm "$archive" - done - chmod a+x * - cd - - - # Cleanup. - case "$ARCH" in - x86_64) rm -r {tool/,VentoyGUI.}{i386,aarch64,mips64el};; - i386) rm -r {tool/,VentoyGUI.}{x86_64,aarch64,mips64el};; - aarch64) rm -r {tool/,VentoyGUI.}{x86_64,i386,mips64el};; - mips64el) rm -r {tool/,VentoyGUI.}{x86_64,i386,aarch64};; - esac - rm README - rm tool/"$ARCH"/Ventoy2Disk.gtk2 || true # For aarch64 and mips64el. - - # Copy from "$src" to "$out" - mkdir -p "$out"/bin "$VENTOY_PATH" - cp -r . "$VENTOY_PATH" - - # Fill bin dir - for f in Ventoy2Disk.sh_ventoy VentoyWeb.sh_ventoy-web \ - CreatePersistentImg.sh_ventoy-persistent \ - ExtendPersistentImg.sh_ventoy-extend-persistent \ - VentoyPlugson.sh_ventoy-plugson; do - local bin="''${f%_*}" wrapper="''${f#*_}" - makeWrapper "$VENTOY_PATH/$bin" "$out/bin/$wrapper" \ - --prefix PATH : "${lib.makeBinPath finalAttrs.buildInputs}" \ - --chdir "$VENTOY_PATH" - done - '' - # VentoGUI uses the `ventoy_gui_type` file to determine the type of GUI. - # See: https://github.com/ventoy/Ventoy/blob/v1.0.78/LinuxGUI/Ventoy2Disk/ventoy_gui.c#L1096 - + optionalString (withGtk3 || withQt5) '' - echo "${defaultGuiType}" > "$VENTOY_PATH/ventoy_gui_type" - makeWrapper "$VENTOY_PATH/VentoyGUI.$ARCH" "$out/bin/ventoy-gui" \ - --prefix PATH : "${lib.makeBinPath finalAttrs.buildInputs}" \ - --chdir "$VENTOY_PATH" - mkdir "$out"/share/{applications,pixmaps} - ln -s "$VENTOY_PATH"/WebUI/static/img/VentoyLogo.png "$out"/share/pixmaps/ - '' - + optionalString (!withGtk3) '' - rm "$VENTOY_PATH"/tool/{"$ARCH"/Ventoy2Disk.gtk3,VentoyGTK.glade} - '' - + optionalString (!withQt5) '' - rm "$VENTOY_PATH/tool/$ARCH/Ventoy2Disk.qt5" - '' - + optionalString (!withGtk3 && !withQt5) '' - rm "$VENTOY_PATH"/VentoyGUI.* - '' + - '' - - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + + # Setup variables + local VENTOY_PATH="$out"/share/ventoy + local ARCH='${arch}' + + # Prepare + cd tool/"$ARCH" + rm ash* hexdump* mkexfatfs* mount.exfat-fuse* xzcat* + for archive in *.xz; do + xzcat "$archive" > "''${archive%.xz}" + rm "$archive" + done + chmod a+x * + cd - + + # Cleanup. + case "$ARCH" in + x86_64) rm -r {tool/,VentoyGUI.}{i386,aarch64,mips64el};; + i386) rm -r {tool/,VentoyGUI.}{x86_64,aarch64,mips64el};; + aarch64) rm -r {tool/,VentoyGUI.}{x86_64,i386,mips64el};; + mips64el) rm -r {tool/,VentoyGUI.}{x86_64,i386,aarch64};; + esac + rm README + rm tool/"$ARCH"/Ventoy2Disk.gtk2 || true # For aarch64 and mips64el. + + # Copy from "$src" to "$out" + mkdir -p "$out"/bin "$VENTOY_PATH" + cp -r . "$VENTOY_PATH" + + # Fill bin dir + for f in Ventoy2Disk.sh_ventoy VentoyWeb.sh_ventoy-web \ + CreatePersistentImg.sh_ventoy-persistent \ + ExtendPersistentImg.sh_ventoy-extend-persistent \ + VentoyPlugson.sh_ventoy-plugson; do + local bin="''${f%_*}" wrapper="''${f#*_}" + makeWrapper "$VENTOY_PATH/$bin" "$out/bin/$wrapper" \ + --prefix PATH : "${lib.makeBinPath finalAttrs.buildInputs}" \ + --chdir "$VENTOY_PATH" + done + '' + # VentoGUI uses the `ventoy_gui_type` file to determine the type of GUI. + # See: https://github.com/ventoy/Ventoy/blob/v1.0.78/LinuxGUI/Ventoy2Disk/ventoy_gui.c#L1096 + + optionalString (withGtk3 || withQt5) '' + echo "${defaultGuiType}" > "$VENTOY_PATH/ventoy_gui_type" + makeWrapper "$VENTOY_PATH/VentoyGUI.$ARCH" "$out/bin/ventoy-gui" \ + --prefix PATH : "${lib.makeBinPath finalAttrs.buildInputs}" \ + --chdir "$VENTOY_PATH" + mkdir "$out"/share/{applications,pixmaps} + ln -s "$VENTOY_PATH"/WebUI/static/img/VentoyLogo.png "$out"/share/pixmaps/ + '' + + optionalString (!withGtk3) '' + rm "$VENTOY_PATH"/tool/{"$ARCH"/Ventoy2Disk.gtk3,VentoyGTK.glade} + '' + + optionalString (!withQt5) '' + rm "$VENTOY_PATH/tool/$ARCH/Ventoy2Disk.qt5" + '' + + optionalString (!withGtk3 && !withQt5) '' + rm "$VENTOY_PATH"/VentoyGUI.* + '' + + '' + + runHook postInstall + ''; meta = { homepage = "https://www.ventoy.net"; @@ -203,7 +212,12 @@ stdenv.mkDerivation (finalAttrs: { license = lib.licenses.gpl3Plus; mainProgram = "ventoy"; maintainers = with lib.maintainers; [ AndersonTorres ]; - platforms = [ "x86_64-linux" "i686-linux" "aarch64-linux" "mipsel-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + "aarch64-linux" + "mipsel-linux" + ]; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; }; }) diff --git a/pkgs/by-name/ve/verbiste/package.nix b/pkgs/by-name/ve/verbiste/package.nix index 2793ffcd0c639b..8a249adb1f2ce2 100644 --- a/pkgs/by-name/ve/verbiste/package.nix +++ b/pkgs/by-name/ve/verbiste/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, gtk2, libxml2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + libxml2, +}: stdenv.mkDerivation rec { pname = "verbiste"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk2 libxml2 ]; + buildInputs = [ + gtk2 + libxml2 + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/ve/vercel-pkg/package.nix b/pkgs/by-name/ve/vercel-pkg/package.nix index c27d6699ed71d3..ab8f4fbb0498a9 100644 --- a/pkgs/by-name/ve/vercel-pkg/package.nix +++ b/pkgs/by-name/ve/vercel-pkg/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, makeWrapper -, nodejs -, fixup-yarn-lock -, yarn +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + makeWrapper, + nodejs, + fixup-yarn-lock, + yarn, }: stdenv.mkDerivation rec { @@ -24,7 +25,7 @@ stdenv.mkDerivation rec { hash = "sha256-KesP3X7LwZ7KSIxcCPXdn/sWcX9TJlwT9z/SdotS2ZQ="; }; - nativeBuildInputs = [ + nativeBuildInputs = [ makeWrapper nodejs fixup-yarn-lock diff --git a/pkgs/by-name/ve/verco/package.nix b/pkgs/by-name/ve/verco/package.nix index 079b10d2f5dd83..8af24bfa90bde0 100644 --- a/pkgs/by-name/ve/verco/package.nix +++ b/pkgs/by-name/ve/verco/package.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, lib, rustPlatform }: +{ + fetchFromGitHub, + lib, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "verco"; diff --git a/pkgs/by-name/ve/verdict/package.nix b/pkgs/by-name/ve/verdict/package.nix index 5083d6a793fb80..34d895e88054ee 100644 --- a/pkgs/by-name/ve/verdict/package.nix +++ b/pkgs/by-name/ve/verdict/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gtest +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gtest, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ve/verifpal/package.nix b/pkgs/by-name/ve/verifpal/package.nix index 41172aab28bb13..95fa4763a0f9cb 100644 --- a/pkgs/by-name/ve/verifpal/package.nix +++ b/pkgs/by-name/ve/verifpal/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, pigeon +{ + lib, + fetchFromGitHub, + buildGoModule, + pigeon, }: buildGoModule rec { diff --git a/pkgs/by-name/ve/versus/package.nix b/pkgs/by-name/ve/versus/package.nix index 4e2ca164fda119..668178b438db8f 100644 --- a/pkgs/by-name/ve/versus/package.nix +++ b/pkgs/by-name/ve/versus/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "versus"; diff --git a/pkgs/by-name/ve/veryfasttree/package.nix b/pkgs/by-name/ve/veryfasttree/package.nix index 27c34f67d952ad..3f493f01dcbb19 100644 --- a/pkgs/by-name/ve/veryfasttree/package.nix +++ b/pkgs/by-name/ve/veryfasttree/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, llvmPackages +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + llvmPackages, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ve/vexctl/package.nix b/pkgs/by-name/ve/vexctl/package.nix index cc1d18ab74d68c..a20cbca28007d4 100644 --- a/pkgs/by-name/ve/vexctl/package.nix +++ b/pkgs/by-name/ve/vexctl/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/vg/vgmplay-libvgm/package.nix b/pkgs/by-name/vg/vgmplay-libvgm/package.nix index ebf227d21074ca..1a8dbf8c9de859 100644 --- a/pkgs/by-name/vg/vgmplay-libvgm/package.nix +++ b/pkgs/by-name/vg/vgmplay-libvgm/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchFromGitHub -, unstableGitUpdater -, cmake -, pkg-config -, zlib -, libvgm -, inih +{ + stdenv, + lib, + fetchFromGitHub, + unstableGitUpdater, + cmake, + pkg-config, + zlib, + libvgm, + inih, }: stdenv.mkDerivation { @@ -20,9 +21,16 @@ stdenv.mkDerivation { hash = "sha256-GjBwu8Y/lOI8SLO4SrAWcntQIwKe/hXuh9tKbOPHQiA="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ zlib libvgm inih ]; + buildInputs = [ + zlib + libvgm + inih + ]; postInstall = '' install -Dm644 ../VGMPlay.ini $out/share/vgmplay/VGMPlay.ini diff --git a/pkgs/by-name/vg/vgmtools/package.nix b/pkgs/by-name/vg/vgmtools/package.nix index 63cb11e55ac7fc..114706dd074b10 100644 --- a/pkgs/by-name/vg/vgmtools/package.nix +++ b/pkgs/by-name/vg/vgmtools/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, unstableGitUpdater -, cmake -, zlib +{ + stdenv, + lib, + fetchFromGitHub, + unstableGitUpdater, + cmake, + zlib, }: stdenv.mkDerivation rec { @@ -27,7 +28,9 @@ stdenv.mkDerivation rec { # Some targets are not enabled by default makeFlags = [ - "all" "optdac" "optvgm32" + "all" + "optdac" + "optvgm32" ]; passthru.updateScript = unstableGitUpdater { diff --git a/pkgs/by-name/vg/vgrep/package.nix b/pkgs/by-name/vg/vgrep/package.nix index 9f2f906e935500..e24a35769773f7 100644 --- a/pkgs/by-name/vg/vgrep/package.nix +++ b/pkgs/by-name/vg/vgrep/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, go-md2man, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + go-md2man, + installShellFiles, +}: buildGoModule rec { pname = "vgrep"; @@ -13,9 +19,16 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; - nativeBuildInputs = [ go-md2man installShellFiles ]; + nativeBuildInputs = [ + go-md2man + installShellFiles + ]; postBuild = '' sed -i '/SHELL= /d' Makefile diff --git a/pkgs/by-name/vh/vhd2vl/package.nix b/pkgs/by-name/vh/vhd2vl/package.nix index 28656fe6e1216c..f4bf6f5f4b885a 100644 --- a/pkgs/by-name/vh/vhd2vl/package.nix +++ b/pkgs/by-name/vh/vhd2vl/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, bison -, flex -, iverilog -, which +{ + lib, + stdenv, + fetchFromGitHub, + bison, + flex, + iverilog, + which, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/vh/vhdl-ls/package.nix b/pkgs/by-name/vh/vhdl-ls/package.nix index 34ba70c683d945..a03fd2d3a90509 100644 --- a/pkgs/by-name/vh/vhdl-ls/package.nix +++ b/pkgs/by-name/vh/vhdl-ls/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/vh/vhs/package.nix b/pkgs/by-name/vh/vhs/package.nix index 12e14f212f7d74..b68f95947b3b33 100644 --- a/pkgs/by-name/vh/vhs/package.nix +++ b/pkgs/by-name/vh/vhs/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, buildGoModule, installShellFiles, fetchFromGitHub, ffmpeg, ttyd, chromium, makeWrapper }: +{ + lib, + stdenv, + buildGoModule, + installShellFiles, + fetchFromGitHub, + ffmpeg, + ttyd, + chromium, + makeWrapper, +}: buildGoModule rec { pname = "vhs"; @@ -13,12 +23,27 @@ buildGoModule rec { vendorHash = "sha256-1UBhiRemJ+dQNm20+8pbOJus5abvTwVcuzxNMzrniN8="; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; postInstall = '' - wrapProgram $out/bin/vhs --prefix PATH : ${lib.makeBinPath (lib.optionals stdenv.hostPlatform.isLinux [ chromium ] ++ [ ffmpeg ttyd ])} + wrapProgram $out/bin/vhs --prefix PATH : ${ + lib.makeBinPath ( + lib.optionals stdenv.hostPlatform.isLinux [ chromium ] + ++ [ + ffmpeg + ttyd + ] + ) + } $out/bin/vhs man > vhs.1 installManPage vhs.1 installShellCompletion --cmd vhs \ @@ -33,6 +58,9 @@ buildGoModule rec { homepage = "https://github.com/charmbracelet/vhs"; changelog = "https://github.com/charmbracelet/vhs/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ maaslalani penguwin ]; + maintainers = with maintainers; [ + maaslalani + penguwin + ]; }; } diff --git a/pkgs/by-name/vi/via/package.nix b/pkgs/by-name/vi/via/package.nix index ffcd456e75fff4..32497ea010734f 100644 --- a/pkgs/by-name/vi/via/package.nix +++ b/pkgs/by-name/vi/via/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools }: +{ + lib, + fetchurl, + appimageTools, +}: let pname = "via"; diff --git a/pkgs/by-name/vi/vial/package.nix b/pkgs/by-name/vi/vial/package.nix index 77cf03500207ac..327da518da95d3 100644 --- a/pkgs/by-name/vi/vial/package.nix +++ b/pkgs/by-name/vi/vial/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools }: +{ + lib, + fetchurl, + appimageTools, +}: let version = "0.7.1"; pname = "Vial"; diff --git a/pkgs/by-name/vi/vice/package.nix b/pkgs/by-name/vi/vice/package.nix index cea0f48d016689..349bc4cb798b3e 100644 --- a/pkgs/by-name/vi/vice/package.nix +++ b/pkgs/by-name/vi/vice/package.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, fetchurl -, bison -, flex -, perl -, curl -, libpng -, giflib -, alsa-lib -, readline -, libGLU -, libGL -, pkg-config -, gtk3 -, glew -, SDL -, SDL_image -, dos2unix -, runtimeShell -, xa -, file -, wrapGAppsHook3 -, xdg-utils +{ + lib, + stdenv, + fetchurl, + bison, + flex, + perl, + curl, + libpng, + giflib, + alsa-lib, + readline, + libGLU, + libGL, + pkg-config, + gtk3, + glew, + SDL, + SDL_image, + dos2unix, + runtimeShell, + xa, + file, + wrapGAppsHook3, + xdg-utils, }: stdenv.mkDerivation rec { @@ -59,7 +60,13 @@ stdenv.mkDerivation rec { xdg-utils ]; dontDisableStatic = true; - configureFlags = [ "--enable-sdl2ui" "--enable-gtk3ui" "--enable-desktop-files" "--disable-pdf-docs" "--with-gif" ]; + configureFlags = [ + "--enable-sdl2ui" + "--enable-gtk3ui" + "--enable-desktop-files" + "--disable-pdf-docs" + "--with-gif" + ]; LIBS = "-lGL"; diff --git a/pkgs/by-name/vi/victor-mono/package.nix b/pkgs/by-name/vi/victor-mono/package.nix index f5319c008b550e..9ae2a77db05c36 100644 --- a/pkgs/by-name/vi/victor-mono/package.nix +++ b/pkgs/by-name/vi/victor-mono/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "victor-mono"; diff --git a/pkgs/by-name/vi/vidmerger/package.nix b/pkgs/by-name/vi/vidmerger/package.nix index cf0412b42929d2..28f5fdff031ad8 100644 --- a/pkgs/by-name/vi/vidmerger/package.nix +++ b/pkgs/by-name/vi/vidmerger/package.nix @@ -1,7 +1,8 @@ -{ lib -, ffmpeg -, rustPlatform -, fetchFromGitHub +{ + lib, + ffmpeg, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -33,7 +34,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Merge video & audio files via CLI"; homepage = "https://github.com/TGotwig/vidmerger"; - license = with licenses; [ mit commons-clause ]; + license = with licenses; [ + mit + commons-clause + ]; maintainers = with maintainers; [ ByteSudoer ]; mainProgram = "vidmerger"; }; diff --git a/pkgs/by-name/vi/vieb/package.nix b/pkgs/by-name/vi/vieb/package.nix index 56e72cbad681c5..da81409bafa7a2 100644 --- a/pkgs/by-name/vi/vieb/package.nix +++ b/pkgs/by-name/vi/vieb/package.nix @@ -1,4 +1,13 @@ -{ stdenv, buildNpmPackage, fetchFromGitHub, electron, makeWrapper, python3, makeDesktopItem, lib }: +{ + stdenv, + buildNpmPackage, + fetchFromGitHub, + electron, + makeWrapper, + python3, + makeDesktopItem, + lib, +}: buildNpmPackage rec { pname = "vieb"; @@ -28,7 +37,10 @@ buildNpmPackage rec { icon = "vieb"; desktopName = "Web Browser"; genericName = "Web Browser"; - categories = [ "Network" "WebBrowser" ]; + categories = [ + "Network" + "WebBrowser" + ]; mimeTypes = [ "text/html" "application/xhtml+xml" @@ -58,7 +70,10 @@ buildNpmPackage rec { changelog = "https://github.com/Jelmerro/Vieb/releases/tag/${version}"; description = "Vim Inspired Electron Browser"; mainProgram = "vieb"; - maintainers = with maintainers; [ gebner tejing ]; + maintainers = with maintainers; [ + gebner + tejing + ]; platforms = platforms.unix; license = licenses.gpl3Plus; }; diff --git a/pkgs/by-name/vi/viennarna/package.nix b/pkgs/by-name/vi/viennarna/package.nix index f292cbb378c9a1..6219ac9a591a47 100644 --- a/pkgs/by-name/vi/viennarna/package.nix +++ b/pkgs/by-name/vi/viennarna/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, gsl -, mpfr -, perl -, python3 +{ + lib, + stdenv, + fetchurl, + gsl, + mpfr, + perl, + python3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/vi/viewnior/package.nix b/pkgs/by-name/vi/viewnior/package.nix index 166f5c785dd4f3..308a4d9a3fdd90 100644 --- a/pkgs/by-name/vi/viewnior/package.nix +++ b/pkgs/by-name/vi/viewnior/package.nix @@ -1,5 +1,27 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, meson, ninja, pkg-config, desktop-file-utils, gtk3, libpng, exiv2, lcms -, intltool, gettext, shared-mime-info, glib, gdk-pixbuf, perl, wrapGAppsHook3, webp-pixbuf-loader, gnome, librsvg}: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + meson, + ninja, + pkg-config, + desktop-file-utils, + gtk3, + libpng, + exiv2, + lcms, + intltool, + gettext, + shared-mime-info, + glib, + gdk-pixbuf, + perl, + wrapGAppsHook3, + webp-pixbuf-loader, + gnome, + librsvg, +}: stdenv.mkDerivation rec { pname = "viewnior-gtk3"; @@ -64,7 +86,10 @@ stdenv.mkDerivation rec { ''; license = licenses.gpl3; homepage = "https://siyanpanayotov.com/project/viewnior/"; - maintainers = with maintainers; [ smironov artturin ]; + maintainers = with maintainers; [ + smironov + artturin + ]; platforms = platforms.gnu ++ platforms.linux; mainProgram = "viewnior"; }; diff --git a/pkgs/by-name/vi/vifm/package.nix b/pkgs/by-name/vi/vifm/package.nix index f58768593c8f76..01c841050cadd2 100644 --- a/pkgs/by-name/vi/vifm/package.nix +++ b/pkgs/by-name/vi/vifm/package.nix @@ -1,16 +1,27 @@ -{ stdenv, fetchurl, makeWrapper -, perl # used to generate help tags -, pkg-config -, ncurses, libX11 -, file, which, groff +{ + stdenv, + fetchurl, + makeWrapper, + perl, # used to generate help tags + pkg-config, + ncurses, + libX11, + file, + which, + groff, # adds support for handling removable media (vifm-media). Linux only! -, mediaSupport ? false, python3 ? null, udisks2 ? null, lib ? null -, gitUpdater + mediaSupport ? false, + python3 ? null, + udisks2 ? null, + lib ? null, + gitUpdater, }: -let isFullPackage = mediaSupport; -in stdenv.mkDerivation rec { +let + isFullPackage = mediaSupport; +in +stdenv.mkDerivation rec { pname = if isFullPackage then "vifm-full" else "vifm"; version = "0.13"; @@ -19,24 +30,36 @@ in stdenv.mkDerivation rec { hash = "sha256-DZKTdJp5QHat6Wfs3EfRQdheRQNwWUdlORvfGpvUUHU="; }; - nativeBuildInputs = [ perl pkg-config makeWrapper ]; - buildInputs = [ ncurses libX11 file which groff ]; + nativeBuildInputs = [ + perl + pkg-config + makeWrapper + ]; + buildInputs = [ + ncurses + libX11 + file + which + groff + ]; postPatch = '' # Avoid '#!/usr/bin/env perl' references to build help. patchShebangs --build src/helpztags ''; - postFixup = let - path = lib.makeBinPath - [ udisks2 - (python3.withPackages (p: [p.dbus-python])) + postFixup = + let + path = lib.makeBinPath [ + udisks2 + (python3.withPackages (p: [ p.dbus-python ])) ]; - wrapVifmMedia = "wrapProgram $out/share/vifm/vifm-media --prefix PATH : ${path}"; - in '' - ${lib.optionalString mediaSupport wrapVifmMedia} - ''; + wrapVifmMedia = "wrapProgram $out/share/vifm/vifm-media --prefix PATH : ${path}"; + in + '' + ${lib.optionalString mediaSupport wrapVifmMedia} + ''; passthru.updateScript = gitUpdater { url = "https://github.com/vifm/vifm.git"; diff --git a/pkgs/by-name/vi/viking/package.nix b/pkgs/by-name/vi/viking/package.nix index cb3ab09e31bcbe..6b40ded8b652d4 100644 --- a/pkgs/by-name/vi/viking/package.nix +++ b/pkgs/by-name/vi/viking/package.nix @@ -1,16 +1,39 @@ -{ lib, stdenv, fetchurl, fetchpatch -, desktopToDarwinBundle -, docbook_xml_dtd_45, docbook_xsl, intltool, itstool, libxslt, pkg-config, wrapGAppsHook3, yelp-tools -, curl, gdk-pixbuf, gtk3, json-glib, libxml2 -, gpsbabel -, withGeoClue ? true, geoclue2 -, withGeoTag ? true, gexiv2 -, withMagic ? true, file -, withMapnik ? false, mapnik -, withMBTiles ? true, sqlite -, withMd5Hash ? true, nettle -, withOAuth ? true, liboauth -, withRealtimeGPSTracking ? (!stdenv.hostPlatform.isDarwin), gpsd +{ + lib, + stdenv, + fetchurl, + fetchpatch, + desktopToDarwinBundle, + docbook_xml_dtd_45, + docbook_xsl, + intltool, + itstool, + libxslt, + pkg-config, + wrapGAppsHook3, + yelp-tools, + curl, + gdk-pixbuf, + gtk3, + json-glib, + libxml2, + gpsbabel, + withGeoClue ? true, + geoclue2, + withGeoTag ? true, + gexiv2, + withMagic ? true, + file, + withMapnik ? false, + mapnik, + withMBTiles ? true, + sqlite, + withMd5Hash ? true, + nettle, + withOAuth ? true, + liboauth, + withRealtimeGPSTracking ? (!stdenv.hostPlatform.isDarwin), + gpsd, }: stdenv.mkDerivation rec { @@ -30,27 +53,42 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ docbook_xml_dtd_45 docbook_xsl intltool itstool libxslt pkg-config wrapGAppsHook3 yelp-tools ] - ++ lib.optional stdenv.hostPlatform.isDarwin desktopToDarwinBundle; + nativeBuildInputs = [ + docbook_xml_dtd_45 + docbook_xsl + intltool + itstool + libxslt + pkg-config + wrapGAppsHook3 + yelp-tools + ] ++ lib.optional stdenv.hostPlatform.isDarwin desktopToDarwinBundle; - buildInputs = [ curl gdk-pixbuf gtk3 json-glib libxml2 ] + buildInputs = + [ + curl + gdk-pixbuf + gtk3 + json-glib + libxml2 + ] ++ lib.optional withGeoClue geoclue2 - ++ lib.optional withGeoTag gexiv2 - ++ lib.optional withMagic file - ++ lib.optional withMapnik mapnik + ++ lib.optional withGeoTag gexiv2 + ++ lib.optional withMagic file + ++ lib.optional withMapnik mapnik ++ lib.optional withMBTiles sqlite ++ lib.optional withMd5Hash nettle - ++ lib.optional withOAuth liboauth + ++ lib.optional withOAuth liboauth ++ lib.optional withRealtimeGPSTracking gpsd; configureFlags = [ (lib.enableFeature withGeoClue "geoclue") - (lib.enableFeature withGeoTag "geotag") - (lib.enableFeature withMagic "magic") - (lib.enableFeature withMapnik "mapnik") + (lib.enableFeature withGeoTag "geotag") + (lib.enableFeature withMagic "magic") + (lib.enableFeature withMapnik "mapnik") (lib.enableFeature withMBTiles "mbtiles") (lib.enableFeature withMd5Hash "nettle") - (lib.enableFeature withOAuth "oauth") + (lib.enableFeature withOAuth "oauth") (lib.enableFeature withRealtimeGPSTracking "realtime-gps-tracking") ]; @@ -76,7 +114,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://sourceforge.net/projects/viking/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ pSub sikmir ]; + maintainers = with maintainers; [ + pSub + sikmir + ]; platforms = with platforms; unix; }; } diff --git a/pkgs/by-name/vi/vikunja/package.nix b/pkgs/by-name/vi/vikunja/package.nix index 939b8e32f9dcda..421a8d52d333a3 100644 --- a/pkgs/by-name/vi/vikunja/package.nix +++ b/pkgs/by-name/vi/vikunja/package.nix @@ -1,4 +1,14 @@ -{ lib, fetchFromGitHub, stdenv, nodejs, pnpm, buildGoModule, mage, writeShellScriptBin, nixosTests }: +{ + lib, + fetchFromGitHub, + stdenv, + nodejs, + pnpm, + buildGoModule, + mage, + writeShellScriptBin, + nixosTests, +}: let version = "0.24.5"; @@ -16,7 +26,12 @@ let sourceRoot = "${finalAttrs.src.name}/frontend"; pnpmDeps = pnpm.fetchDeps { - inherit (finalAttrs) pname version src sourceRoot; + inherit (finalAttrs) + pname + version + src + sourceRoot + ; hash = "sha256-D2dOyYsdsNV1ZSQdjpy6rfoix7yBACEHj/2XyHb7HWE="; }; @@ -41,10 +56,12 @@ let }); # Injects a `t.Skip()` into a given test since there's apparently no other way to skip tests here. - skipTest = lineOffset: testCase: file: + skipTest = + lineOffset: testCase: file: let jumpAndAppend = lib.concatStringsSep ";" (lib.replicate (lineOffset - 1) "n" ++ [ "a" ]); - in '' + in + '' sed -i -e '/${testCase}/{ ${jumpAndAppend} t.Skip(); }' ${file} @@ -65,7 +82,10 @@ buildGoModule { fi ''; in - [ fakeGit mage ]; + [ + fakeGit + mage + ]; vendorHash = "sha256-OsKejno8QGg7HzRsrftngiWGiWHFc1jDLi5mQ9/NjI4="; diff --git a/pkgs/by-name/vi/vim-language-server/package.nix b/pkgs/by-name/vi/vim-language-server/package.nix index 3d60dd1ca5fbe7..7e192164ffa449 100644 --- a/pkgs/by-name/vi/vim-language-server/package.nix +++ b/pkgs/by-name/vi/vim-language-server/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchYarnDeps -, yarnConfigHook -, yarnBuildHook -, nodejs -, npmHooks +{ + lib, + stdenv, + fetchFromGitHub, + fetchYarnDeps, + yarnConfigHook, + yarnBuildHook, + nodejs, + npmHooks, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/vi/vim-startuptime/package.nix b/pkgs/by-name/vi/vim-startuptime/package.nix index 545cb27e43e2c2..e3b58b92316d7d 100644 --- a/pkgs/by-name/vi/vim-startuptime/package.nix +++ b/pkgs/by-name/vi/vim-startuptime/package.nix @@ -2,7 +2,7 @@ pkgs, lib, buildGoModule, - fetchFromGitHub + fetchFromGitHub, }: let pname = "vim-startuptime"; diff --git a/pkgs/by-name/vi/vim-vint/package.nix b/pkgs/by-name/vi/vim-vint/package.nix index 9ff37be205122b..52edbdf0d289e1 100644 --- a/pkgs/by-name/vi/vim-vint/package.nix +++ b/pkgs/by-name/vi/vim-vint/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: with python3Packages; @@ -12,10 +16,18 @@ buildPythonApplication rec { }; # For python 3.5 > version > 2.7 , a nested dependency (pythonPackages.hypothesis) fails. - disabled = ! pythonAtLeast "3.5"; + disabled = !pythonAtLeast "3.5"; - nativeCheckInputs = [ pytest pytest-cov ]; - propagatedBuildInputs = [ ansicolor chardet pyyaml setuptools ]; + nativeCheckInputs = [ + pytest + pytest-cov + ]; + propagatedBuildInputs = [ + ansicolor + chardet + pyyaml + setuptools + ]; # Unpin test dependency versions. This is fixed in master but not yet released. preCheck = '' diff --git a/pkgs/by-name/vi/vimb-unwrapped/package.nix b/pkgs/by-name/vi/vimb-unwrapped/package.nix index 0a629030f21071..21436d224e98ca 100644 --- a/pkgs/by-name/vi/vimb-unwrapped/package.nix +++ b/pkgs/by-name/vi/vimb-unwrapped/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, libsoup_2_4, webkitgtk_4_0, gtk3, glib-networking -, gsettings-desktop-schemas, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libsoup_2_4, + webkitgtk_4_0, + gtk3, + glib-networking, + gsettings-desktop-schemas, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -13,8 +22,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-Eq4riJSznKpkW9JJDnTCLxZ9oMJTmWkIoGphOiCcSAg="; }; - nativeBuildInputs = [ wrapGAppsHook3 pkg-config ]; - buildInputs = [ gtk3 libsoup_2_4 webkitgtk_4_0 glib-networking gsettings-desktop-schemas ]; + nativeBuildInputs = [ + wrapGAppsHook3 + pkg-config + ]; + buildInputs = [ + gtk3 + libsoup_2_4 + webkitgtk_4_0 + glib-networking + gsettings-desktop-schemas + ]; passthru = { inherit gtk3; diff --git a/pkgs/by-name/vi/vimer/package.nix b/pkgs/by-name/vi/vimer/package.nix index 684ecfc5fe3876..e131eb0e044f9c 100644 --- a/pkgs/by-name/vi/vimer/package.nix +++ b/pkgs/by-name/vi/vimer/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { version = "0.2.0"; @@ -30,4 +34,3 @@ stdenv.mkDerivation rec { }; } - diff --git a/pkgs/by-name/vi/vimiv-qt/package.nix b/pkgs/by-name/vi/vimiv-qt/package.nix index 75a0b88fba4e4f..f11716993ce533 100644 --- a/pkgs/by-name/vi/vimiv-qt/package.nix +++ b/pkgs/by-name/vi/vimiv-qt/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, python3 -, qt5 -, stdenv -, installShellFiles +{ + lib, + fetchFromGitHub, + python3, + qt5, + stdenv, + installShellFiles, }: python3.pkgs.buildPythonApplication rec { @@ -17,9 +18,16 @@ python3.pkgs.buildPythonApplication rec { sha256 = "sha256-28sk5qDVmrgXYX2wm5G8zv564vG6GwxNp+gjrFHCRfU="; }; - nativeBuildInputs = [ installShellFiles qt5.wrapQtAppsHook python3.pkgs.setuptools ]; + nativeBuildInputs = [ + installShellFiles + qt5.wrapQtAppsHook + python3.pkgs.setuptools + ]; - propagatedBuildInputs = with python3.pkgs; [ pyqt5 py3exiv2 ]; + propagatedBuildInputs = with python3.pkgs; [ + pyqt5 + py3exiv2 + ]; buildInputs = [ qt5.qtsvg ] ++ lib.optionals stdenv.hostPlatform.isLinux [ qt5.qtwayland ]; diff --git a/pkgs/by-name/vi/vimix-cursor-theme/package.nix b/pkgs/by-name/vi/vimix-cursor-theme/package.nix index a276ae1ea24535..a030580e7ff449 100644 --- a/pkgs/by-name/vi/vimix-cursor-theme/package.nix +++ b/pkgs/by-name/vi/vimix-cursor-theme/package.nix @@ -1,6 +1,7 @@ -{ stdenvNoCC -, fetchFromGitHub -, lib +{ + stdenvNoCC, + fetchFromGitHub, + lib, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/vi/vimix-cursors/package.nix b/pkgs/by-name/vi/vimix-cursors/package.nix index b42d053be6ae38..665938ae02e47f 100644 --- a/pkgs/by-name/vi/vimix-cursors/package.nix +++ b/pkgs/by-name/vi/vimix-cursors/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, stdenvNoCC -, inkscape -, python3Packages -, xcursorgen +{ + lib, + fetchFromGitHub, + stdenvNoCC, + inkscape, + python3Packages, + xcursorgen, }: stdenvNoCC.mkDerivation { pname = "vimix-cursors"; diff --git a/pkgs/by-name/vi/vimix-gtk-themes/package.nix b/pkgs/by-name/vi/vimix-gtk-themes/package.nix index 18a5b2c893e738..30da5f31cb41ca 100644 --- a/pkgs/by-name/vi/vimix-gtk-themes/package.nix +++ b/pkgs/by-name/vi/vimix-gtk-themes/package.nix @@ -1,77 +1,98 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gnome-shell -, gtk-engine-murrine -, gtk_engines -, jdupes -, sassc -, gitUpdater -, themeVariants ? [] # default: doder (blue) -, colorVariants ? [] # default: all -, sizeVariants ? [] # default: standard -, tweaks ? [] +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gnome-shell, + gtk-engine-murrine, + gtk_engines, + jdupes, + sassc, + gitUpdater, + themeVariants ? [ ], # default: doder (blue) + colorVariants ? [ ], # default: all + sizeVariants ? [ ], # default: standard + tweaks ? [ ], }: let pname = "vimix-gtk-themes"; in -lib.checkListOfEnum "${pname}: theme variants" [ "doder" "beryl" "ruby" "amethyst" "jade" "grey" "all" ] themeVariants -lib.checkListOfEnum "${pname}: color variants" [ "standard" "light" "dark" ] colorVariants -lib.checkListOfEnum "${pname}: size variants" [ "standard" "compact" "all" ] sizeVariants -lib.checkListOfEnum "${pname}: tweaks" [ "flat" "grey" "mix" "translucent" ] tweaks +lib.checkListOfEnum "${pname}: theme variants" + [ + "doder" + "beryl" + "ruby" + "amethyst" + "jade" + "grey" + "all" + ] + themeVariants + lib.checkListOfEnum + "${pname}: color variants" + [ "standard" "light" "dark" ] + colorVariants + lib.checkListOfEnum + "${pname}: size variants" + [ "standard" "compact" "all" ] + sizeVariants + lib.checkListOfEnum + "${pname}: tweaks" + [ "flat" "grey" "mix" "translucent" ] + tweaks -stdenvNoCC.mkDerivation rec { - inherit pname; - version = "2024-04-20"; + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "2024-04-20"; - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = version; - sha256 = "RbAdoix+UWKiLB+04YiPa0UwzO1fFLy56IG1MipmE+E="; - }; + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = version; + sha256 = "RbAdoix+UWKiLB+04YiPa0UwzO1fFLy56IG1MipmE+E="; + }; - nativeBuildInputs = [ - gnome-shell # needed to determine the gnome-shell version - jdupes - sassc - ]; + nativeBuildInputs = [ + gnome-shell # needed to determine the gnome-shell version + jdupes + sassc + ]; - buildInputs = [ - gtk_engines - ]; + buildInputs = [ + gtk_engines + ]; - propagatedUserEnvPkgs = [ - gtk-engine-murrine - ]; + propagatedUserEnvPkgs = [ + gtk-engine-murrine + ]; - postPatch = '' - patchShebangs install.sh - ''; + postPatch = '' + patchShebangs install.sh + ''; - installPhase = '' - runHook preInstall - mkdir -p $out/share/themes - name= HOME="$TMPDIR" ./install.sh \ - ${lib.optionalString (themeVariants != []) "--theme " + builtins.toString themeVariants} \ - ${lib.optionalString (colorVariants != []) "--color " + builtins.toString colorVariants} \ - ${lib.optionalString (sizeVariants != []) "--size " + builtins.toString sizeVariants} \ - ${lib.optionalString (tweaks != []) "--tweaks " + builtins.toString tweaks} \ - --dest $out/share/themes - rm $out/share/themes/*/{AUTHORS,LICENSE} - jdupes --quiet --link-soft --recurse $out/share - runHook postInstall - ''; + installPhase = '' + runHook preInstall + mkdir -p $out/share/themes + name= HOME="$TMPDIR" ./install.sh \ + ${lib.optionalString (themeVariants != [ ]) "--theme " + builtins.toString themeVariants} \ + ${lib.optionalString (colorVariants != [ ]) "--color " + builtins.toString colorVariants} \ + ${lib.optionalString (sizeVariants != [ ]) "--size " + builtins.toString sizeVariants} \ + ${lib.optionalString (tweaks != [ ]) "--tweaks " + builtins.toString tweaks} \ + --dest $out/share/themes + rm $out/share/themes/*/{AUTHORS,LICENSE} + jdupes --quiet --link-soft --recurse $out/share + runHook postInstall + ''; - passthru.updateScript = gitUpdater { }; + passthru.updateScript = gitUpdater { }; - meta = with lib; { - description = "Flat Material Design theme for GTK based desktop environments"; - homepage = "https://github.com/vinceliuice/vimix-gtk-themes"; - license = licenses.gpl3Only; - platforms = platforms.unix; - maintainers = [ maintainers.romildo ]; - }; -} + meta = with lib; { + description = "Flat Material Design theme for GTK based desktop environments"; + homepage = "https://github.com/vinceliuice/vimix-gtk-themes"; + license = licenses.gpl3Only; + platforms = platforms.unix; + maintainers = [ maintainers.romildo ]; + }; + } diff --git a/pkgs/by-name/vi/vimix-icon-theme/package.nix b/pkgs/by-name/vi/vimix-icon-theme/package.nix index 822b710e32b00f..9c0e0d9b9f7f33 100644 --- a/pkgs/by-name/vi/vimix-icon-theme/package.nix +++ b/pkgs/by-name/vi/vimix-icon-theme/package.nix @@ -1,69 +1,82 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gitUpdater -, gtk3 -, hicolor-icon-theme -, jdupes -, colorVariants ? [] # default: all +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gitUpdater, + gtk3, + hicolor-icon-theme, + jdupes, + colorVariants ? [ ], # default: all }: let pname = "vimix-icon-theme"; in -lib.checkListOfEnum "${pname}: color variants" [ "standard" "Amethyst" "Beryl" "Doder" "Ruby" "Jade" "Black" "White" ] colorVariants +lib.checkListOfEnum "${pname}: color variants" + [ + "standard" + "Amethyst" + "Beryl" + "Doder" + "Ruby" + "Jade" + "Black" + "White" + ] + colorVariants -stdenvNoCC.mkDerivation rec { - inherit pname; - version = "2023-06-26"; + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "2023-06-26"; - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = version; - sha256 = "5pTYsWdmjSDyrEK+Jbg/9dQ1FHI2rdnr1n0Ysd5mg/U="; - }; + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = version; + sha256 = "5pTYsWdmjSDyrEK+Jbg/9dQ1FHI2rdnr1n0Ysd5mg/U="; + }; - nativeBuildInputs = [ - gtk3 - jdupes - ]; + nativeBuildInputs = [ + gtk3 + jdupes + ]; - propagatedBuildInputs = [ - hicolor-icon-theme - ]; + propagatedBuildInputs = [ + hicolor-icon-theme + ]; - dontDropIconThemeCache = true; + dontDropIconThemeCache = true; - # These fixup steps are slow and unnecessary for this package - dontPatchELF = true; - dontRewriteSymlinks = true; + # These fixup steps are slow and unnecessary for this package + dontPatchELF = true; + dontRewriteSymlinks = true; - postPatch = '' - patchShebangs install.sh - ''; + postPatch = '' + patchShebangs install.sh + ''; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - ./install.sh \ - ${if colorVariants != [] then builtins.toString colorVariants else "-a"} \ - -d $out/share/icons + ./install.sh \ + ${if colorVariants != [ ] then builtins.toString colorVariants else "-a"} \ + -d $out/share/icons - # replace duplicate files with symlinks - jdupes --quiet --link-soft --recurse $out/share + # replace duplicate files with symlinks + jdupes --quiet --link-soft --recurse $out/share - runHook postInstall - ''; + runHook postInstall + ''; - passthru.updateScript = gitUpdater { }; + passthru.updateScript = gitUpdater { }; - meta = with lib; { - description = "Material Design icon theme based on Paper icon theme"; - homepage = "https://github.com/vinceliuice/vimix-icon-theme"; - license = with licenses; [ cc-by-sa-40 ]; - platforms = platforms.linux; - maintainers = with maintainers; [ romildo ]; - }; -} + meta = with lib; { + description = "Material Design icon theme based on Paper icon theme"; + homepage = "https://github.com/vinceliuice/vimix-icon-theme"; + license = with licenses; [ cc-by-sa-40 ]; + platforms = platforms.linux; + maintainers = with maintainers; [ romildo ]; + }; + } diff --git a/pkgs/by-name/vi/vimpc/package.nix b/pkgs/by-name/vi/vimpc/package.nix index f85bf4ebd86724..3a546b764f97dc 100644 --- a/pkgs/by-name/vi/vimpc/package.nix +++ b/pkgs/by-name/vi/vimpc/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, libmpdclient -, ncurses -, pcre -, pkg-config -, taglib -, curl +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + libmpdclient, + ncurses, + pcre, + pkg-config, + taglib, + curl, }: stdenv.mkDerivation rec { @@ -32,8 +33,17 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libmpdclient ncurses pcre taglib curl ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libmpdclient + ncurses + pcre + taglib + curl + ]; postInstall = '' mkdir -p $out/etc diff --git a/pkgs/by-name/vi/vimv-rs/package.nix b/pkgs/by-name/vi/vimv-rs/package.nix index ebd812c3f76296..ec0a0c3d4c3b15 100644 --- a/pkgs/by-name/vi/vimv-rs/package.nix +++ b/pkgs/by-name/vi/vimv-rs/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchCrate, stdenv, apple-sdk_11 }: +{ + lib, + rustPlatform, + fetchCrate, + stdenv, + apple-sdk_11, +}: rustPlatform.buildRustPackage rec { pname = "vimv-rs"; diff --git a/pkgs/by-name/vi/vimv/package.nix b/pkgs/by-name/vi/vimv/package.nix index 46753688ec73fe..a402a54fac89fa 100644 --- a/pkgs/by-name/vi/vimv/package.nix +++ b/pkgs/by-name/vi/vimv/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation { pname = "vimv"; diff --git a/pkgs/by-name/vi/vintagestory/package.nix b/pkgs/by-name/vi/vintagestory/package.nix index 75df4dd045c2f7..361550405f88fd 100644 --- a/pkgs/by-name/vi/vintagestory/package.nix +++ b/pkgs/by-name/vi/vintagestory/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, xorg -, gtk2 -, sqlite -, openal -, cairo -, libGLU -, SDL2 -, freealut -, libglvnd -, pipewire -, libpulseaudio -, dotnet-runtime_7 +{ + lib, + stdenv, + fetchurl, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + xorg, + gtk2, + sqlite, + openal, + cairo, + libGLU, + SDL2, + freealut, + libglvnd, + pipewire, + libpulseaudio, + dotnet-runtime_7, }: stdenv.mkDerivation rec { @@ -27,27 +28,32 @@ stdenv.mkDerivation rec { hash = "sha256-R6J+ACYDQpOzJZFBizsQGOexR7lMyeoZqz9TnWxfwyM="; }; - - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; buildInputs = [ dotnet-runtime_7 ]; - runtimeLibs = lib.makeLibraryPath ([ - gtk2 - sqlite - openal - cairo - libGLU - SDL2 - freealut - libglvnd - pipewire - libpulseaudio - ] ++ (with xorg; [ - libX11 - libXi - libXcursor - ])); + runtimeLibs = lib.makeLibraryPath ( + [ + gtk2 + sqlite + openal + cairo + libGLU + SDL2 + freealut + libglvnd + pipewire + libpulseaudio + ] + ++ (with xorg; [ + libX11 + libXi + libXcursor + ]) + ); desktopItems = [ (makeDesktopItem { @@ -71,24 +77,29 @@ stdenv.mkDerivation rec { runHook postInstall ''; - preFixup = '' - makeWrapper ${dotnet-runtime_7}/bin/dotnet $out/bin/vintagestory \ - --prefix LD_LIBRARY_PATH : "${runtimeLibs}" \ - --add-flags $out/share/vintagestory/Vintagestory.dll - makeWrapper ${dotnet-runtime_7}/bin/dotnet $out/bin/vintagestory-server \ - --prefix LD_LIBRARY_PATH : "${runtimeLibs}" \ - --add-flags $out/share/vintagestory/VintagestoryServer.dll - '' + '' - find "$out/share/vintagestory/assets/" -not -path "*/fonts/*" -regex ".*/.*[A-Z].*" | while read -r file; do - local filename="$(basename -- "$file")" - ln -sf "$filename" "''${file%/*}"/"''${filename,,}" - done - ''; + preFixup = + '' + makeWrapper ${dotnet-runtime_7}/bin/dotnet $out/bin/vintagestory \ + --prefix LD_LIBRARY_PATH : "${runtimeLibs}" \ + --add-flags $out/share/vintagestory/Vintagestory.dll + makeWrapper ${dotnet-runtime_7}/bin/dotnet $out/bin/vintagestory-server \ + --prefix LD_LIBRARY_PATH : "${runtimeLibs}" \ + --add-flags $out/share/vintagestory/VintagestoryServer.dll + '' + + '' + find "$out/share/vintagestory/assets/" -not -path "*/fonts/*" -regex ".*/.*[A-Z].*" | while read -r file; do + local filename="$(basename -- "$file")" + ln -sf "$filename" "''${file%/*}"/"''${filename,,}" + done + ''; meta = with lib; { description = "In-development indie sandbox game about innovation and exploration"; homepage = "https://www.vintagestory.at/"; license = licenses.unfree; - maintainers = with maintainers; [ artturin gigglesquid ]; + maintainers = with maintainers; [ + artturin + gigglesquid + ]; }; } diff --git a/pkgs/by-name/vi/viper4linux/package.nix b/pkgs/by-name/vi/viper4linux/package.nix index 134e535a783421..4beaf47ef7b639 100644 --- a/pkgs/by-name/vi/viper4linux/package.nix +++ b/pkgs/by-name/vi/viper4linux/package.nix @@ -1,12 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, gst_all_1 -, libviperfx -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + gst_all_1, + libviperfx, + makeWrapper, }: let - gstPluginPath = lib.makeSearchPathOutput "lib" "lib/gstreamer-1.0" (with gst_all_1; [ gstreamer gst-plugins-viperfx gst-plugins-base gst-plugins-good ]); + gstPluginPath = lib.makeSearchPathOutput "lib" "lib/gstreamer-1.0" ( + with gst_all_1; + [ + gstreamer + gst-plugins-viperfx + gst-plugins-base + gst-plugins-good + ] + ); in stdenv.mkDerivation rec { pname = "viper4linux"; diff --git a/pkgs/by-name/vi/vipsdisp/package.nix b/pkgs/by-name/vi/vipsdisp/package.nix index fdfb17d205426c..80dcef083886d4 100644 --- a/pkgs/by-name/vi/vipsdisp/package.nix +++ b/pkgs/by-name/vi/vipsdisp/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch2 -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, vips -, gtk4 -, python3 +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch2, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + vips, + gtk4, + python3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/vi/virglrenderer/package.nix b/pkgs/by-name/vi/virglrenderer/package.nix index e23285511afadf..88cf039ef6c846 100644 --- a/pkgs/by-name/vi/virglrenderer/package.nix +++ b/pkgs/by-name/vi/virglrenderer/package.nix @@ -1,7 +1,19 @@ -{ lib, stdenv, fetchurl, meson, ninja, pkg-config, python3 -, libGLU, libepoxy, libX11, libdrm, mesa -, vaapiSupport ? true, libva -, gitUpdater +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + python3, + libGLU, + libepoxy, + libX11, + libdrm, + mesa, + vaapiSupport ? true, + libva, + gitUpdater, }: stdenv.mkDerivation rec { @@ -15,12 +27,22 @@ stdenv.mkDerivation rec { separateDebugInfo = true; - buildInputs = [ libGLU libepoxy libX11 libdrm mesa ] - ++ lib.optionals vaapiSupport [ libva ]; + buildInputs = [ + libGLU + libepoxy + libX11 + libdrm + mesa + ] ++ lib.optionals vaapiSupport [ libva ]; - nativeBuildInputs = [ meson ninja pkg-config python3 ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + python3 + ]; - mesonFlags= [ + mesonFlags = [ (lib.mesonBool "video" vaapiSupport) ]; diff --git a/pkgs/by-name/vi/virt-viewer/package.nix b/pkgs/by-name/vi/virt-viewer/package.nix index 2c368db8da9452..253c5fab2e91ee 100644 --- a/pkgs/by-name/vi/virt-viewer/package.nix +++ b/pkgs/by-name/vi/virt-viewer/package.nix @@ -1,36 +1,37 @@ -{ lib -, stdenv -, bash-completion -, fetchurl -, fetchpatch -, gdbm -, glib -, gst_all_1 -, gsettings-desktop-schemas -, gtk-vnc -, gtk3 -, intltool -, libcap -, libgovirt +{ + lib, + stdenv, + bash-completion, + fetchurl, + fetchpatch, + gdbm, + glib, + gst_all_1, + gsettings-desktop-schemas, + gtk-vnc, + gtk3, + intltool, + libcap, + libgovirt, # Currently unsupported. According to upstream, libgovirt is for a very narrow # use-case and we don't currently cover it in Nixpkgs. It's safe to disable. # https://gitlab.com/virt-viewer/virt-viewer/-/issues/100#note_1265011223 # Can be enabled again once this is merged: # https://gitlab.com/virt-viewer/virt-viewer/-/merge_requests/129 -, ovirtSupport ? false -, libvirt -, libvirt-glib -, libxml2 -, meson -, ninja -, pkg-config -, python3 -, shared-mime-info -, spice-gtk -, spice-protocol -, spiceSupport ? true -, vte -, wrapGAppsHook3 + ovirtSupport ? false, + libvirt, + libvirt-glib, + libxml2, + meson, + ninja, + pkg-config, + python3, + shared-mime-info, + spice-gtk, + spice-protocol, + spiceSupport ? true, + vte, + wrapGAppsHook3, }: stdenv.mkDerivation rec { pname = "virt-viewer"; @@ -61,27 +62,33 @@ stdenv.mkDerivation rec { wrapGAppsHook3 ]; - buildInputs = [ - gst_all_1.gst-plugins-base - gst_all_1.gst-plugins-good - bash-completion - glib - gsettings-desktop-schemas - gtk-vnc - gtk3 - libvirt - libvirt-glib - libxml2 - vte - ] ++ lib.optionals ovirtSupport [ - libgovirt - ] ++ lib.optionals spiceSupport ([ - gdbm - spice-gtk - spice-protocol - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libcap - ]); + buildInputs = + [ + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-good + bash-completion + glib + gsettings-desktop-schemas + gtk-vnc + gtk3 + libvirt + libvirt-glib + libxml2 + vte + ] + ++ lib.optionals ovirtSupport [ + libgovirt + ] + ++ lib.optionals spiceSupport ( + [ + gdbm + spice-gtk + spice-protocol + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libcap + ] + ); # Required for USB redirection PolicyKit rules file propagatedUserEnvPkgs = lib.optional spiceSupport spice-gtk; @@ -98,7 +105,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Viewer for remote virtual machines"; - maintainers = with maintainers; [ raskin atemu ]; + maintainers = with maintainers; [ + raskin + atemu + ]; platforms = with platforms; linux ++ darwin; license = licenses.gpl2; }; diff --git a/pkgs/by-name/vi/virt-what/package.nix b/pkgs/by-name/vi/virt-what/package.nix index 05c5268b087e93..b06b0761a24be0 100644 --- a/pkgs/by-name/vi/virt-what/package.nix +++ b/pkgs/by-name/vi/virt-what/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchurl }: +{ + stdenv, + lib, + fetchurl, +}: stdenv.mkDerivation rec { pname = "virt-what"; diff --git a/pkgs/by-name/vi/virter/package.nix b/pkgs/by-name/vi/virter/package.nix index 0e0dc349d01fc3..b645ec2746913d 100644 --- a/pkgs/by-name/vi/virter/package.nix +++ b/pkgs/by-name/vi/virter/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/vi/virtio-win/package.nix b/pkgs/by-name/vi/virtio-win/package.nix index d1d1757c90bda5..8e81a5c611e0b6 100644 --- a/pkgs/by-name/vi/virtio-win/package.nix +++ b/pkgs/by-name/vi/virtio-win/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libarchive }: +{ + lib, + stdenv, + fetchurl, + libarchive, +}: stdenv.mkDerivation rec { pname = "virtio-win"; diff --git a/pkgs/by-name/vi/virtualpg/package.nix b/pkgs/by-name/vi/virtualpg/package.nix index e15961437002df..79b184516650fb 100644 --- a/pkgs/by-name/vi/virtualpg/package.nix +++ b/pkgs/by-name/vi/virtualpg/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, validatePkgConfig, postgresql, sqlite, darwin }: +{ + lib, + stdenv, + fetchurl, + validatePkgConfig, + postgresql, + sqlite, + darwin, +}: stdenv.mkDerivation rec { pname = "virtualpg"; @@ -11,16 +19,22 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ validatePkgConfig - postgresql # for pg_config + postgresql # for pg_config ]; - buildInputs = [ postgresql sqlite ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Kerberos ]; + buildInputs = [ + postgresql + sqlite + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Kerberos ]; meta = with lib; { description = "Loadable dynamic extension to both SQLite and SpatiaLite"; homepage = "https://www.gaia-gis.it/fossil/virtualpg"; - license = with licenses; [ mpl11 gpl2Plus lgpl21Plus ]; + license = with licenses; [ + mpl11 + gpl2Plus + lgpl21Plus + ]; platforms = platforms.unix; maintainers = with maintainers; [ sikmir ]; }; diff --git a/pkgs/by-name/vi/vis/package.nix b/pkgs/by-name/vi/vis/package.nix index 7d37d022a86aa3..edf173026d9019 100644 --- a/pkgs/by-name/vi/vis/package.nix +++ b/pkgs/by-name/vi/vis/package.nix @@ -1,15 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, makeWrapper -, copyDesktopItems, makeDesktopItem -, ncurses, libtermkey, lua, tre -, acl, libselinux +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + makeWrapper, + copyDesktopItems, + makeDesktopItem, + ncurses, + libtermkey, + lua, + tre, + acl, + libselinux, }: let - luaEnv = lua.withPackages(ps: [ ps.lpeg ]); + luaEnv = lua.withPackages (ps: [ ps.lpeg ]); in stdenv.mkDerivation rec { pname = "vis"; - version = "0.9"; + version = "0.9"; src = fetchFromGitHub { rev = "v${version}"; @@ -18,18 +28,24 @@ stdenv.mkDerivation rec { owner = "martanne"; }; - nativeBuildInputs = [ pkg-config makeWrapper copyDesktopItems ]; - - buildInputs = [ - ncurses - libtermkey - luaEnv - tre - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - acl - libselinux + nativeBuildInputs = [ + pkg-config + makeWrapper + copyDesktopItems ]; + buildInputs = + [ + ncurses + libtermkey + luaEnv + tre + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + acl + libselinux + ]; + postInstall = '' wrapProgram $out/bin/vis \ --prefix LUA_CPATH ';' "${luaEnv}/lib/lua/${lua.luaversion}/?.so" \ @@ -46,8 +62,15 @@ stdenv.mkDerivation rec { comment = meta.description; desktopName = "vis"; genericName = "Text editor"; - categories = [ "Application" "Development" "IDE" ]; - mimeTypes = [ "text/plain" "application/octet-stream" ]; + categories = [ + "Application" + "Development" + "IDE" + ]; + mimeTypes = [ + "text/plain" + "application/octet-stream" + ]; startupNotify = false; terminal = true; }) diff --git a/pkgs/by-name/vi/vistafonts-chs/package.nix b/pkgs/by-name/vi/vistafonts-chs/package.nix index 66274c667a04b4..70491300ea7401 100644 --- a/pkgs/by-name/vi/vistafonts-chs/package.nix +++ b/pkgs/by-name/vi/vistafonts-chs/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchurl, cabextract }: +{ + lib, + stdenvNoCC, + fetchurl, + cabextract, +}: stdenvNoCC.mkDerivation { pname = "vista-fonts-chs"; diff --git a/pkgs/by-name/vi/vistafonts-cht/package.nix b/pkgs/by-name/vi/vistafonts-cht/package.nix index 78271e2f1e93de..593df81676f2b0 100644 --- a/pkgs/by-name/vi/vistafonts-cht/package.nix +++ b/pkgs/by-name/vi/vistafonts-cht/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchurl, cabextract }: +{ + lib, + stdenvNoCC, + fetchurl, + cabextract, +}: stdenvNoCC.mkDerivation { pname = "vista-fonts-cht"; @@ -26,7 +31,6 @@ stdenvNoCC.mkDerivation { --subst-var-by fontname "Microsoft JhengHei" ''; - meta = with lib; { description = "TrueType fonts from Microsoft Windows Vista For Traditional Chinese (Microsoft JhengHei)"; homepage = "https://www.microsoft.com/typography/fonts/family.aspx"; diff --git a/pkgs/by-name/vi/vistafonts/package.nix b/pkgs/by-name/vi/vistafonts/package.nix index fa8308b8c9720d..d6f88cc1771060 100644 --- a/pkgs/by-name/vi/vistafonts/package.nix +++ b/pkgs/by-name/vi/vistafonts/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchurl, cabextract }: +{ + lib, + stdenvNoCC, + fetchurl, + cabextract, +}: stdenvNoCC.mkDerivation { pname = "vista-fonts"; diff --git a/pkgs/by-name/vi/visualvm/package.nix b/pkgs/by-name/vi/visualvm/package.nix index 5f7dc106663fc7..4f9be9a5654f9c 100644 --- a/pkgs/by-name/vi/visualvm/package.nix +++ b/pkgs/by-name/vi/visualvm/package.nix @@ -1,21 +1,30 @@ -{ stdenv, fetchzip, lib, makeWrapper, makeDesktopItem, jdk }: +{ + stdenv, + fetchzip, + lib, + makeWrapper, + makeDesktopItem, + jdk, +}: stdenv.mkDerivation rec { version = "2.1.10"; pname = "visualvm"; src = fetchzip { - url = "https://github.com/visualvm/visualvm.src/releases/download/${version}/visualvm_${builtins.replaceStrings ["."] [""] version}.zip"; + url = "https://github.com/visualvm/visualvm.src/releases/download/${version}/visualvm_${ + builtins.replaceStrings [ "." ] [ "" ] version + }.zip"; sha256 = "sha256-CmbAYJzhzPIgUfo1M0JuwhNz6Bmymb0Fr1ERdmgQ95I="; }; desktopItem = makeDesktopItem { - name = "visualvm"; - exec = "visualvm"; - comment = "Java Troubleshooting Tool"; - desktopName = "VisualVM"; - genericName = "Java Troubleshooting Tool"; - categories = [ "Development" ]; + name = "visualvm"; + exec = "visualvm"; + comment = "Java Troubleshooting Tool"; + desktopName = "VisualVM"; + genericName = "Java Troubleshooting Tool"; + categories = [ "Development" ]; }; nativeBuildInputs = [ makeWrapper ]; @@ -43,6 +52,9 @@ stdenv.mkDerivation rec { homepage = "https://visualvm.github.io"; license = licenses.gpl2ClasspathPlus; platforms = platforms.all; - maintainers = with maintainers; [ michalrus moaxcp ]; + maintainers = with maintainers; [ + michalrus + moaxcp + ]; }; } diff --git a/pkgs/by-name/vi/vit/package.nix b/pkgs/by-name/vi/vit/package.nix index 020be3eabf262a..c95140f48fead7 100644 --- a/pkgs/by-name/vi/vit/package.nix +++ b/pkgs/by-name/vi/vit/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3Packages -, fetchPypi -, taskwarrior2 -, glibcLocales +{ + lib, + python3Packages, + fetchPypi, + taskwarrior2, + glibcLocales, }: with python3Packages; @@ -24,7 +25,12 @@ buildPythonApplication rec { nativeCheckInputs = [ glibcLocales ]; - makeWrapperArgs = [ "--suffix" "PATH" ":" "${taskwarrior2}/bin" ]; + makeWrapperArgs = [ + "--suffix" + "PATH" + ":" + "${taskwarrior2}/bin" + ]; preCheck = '' export TERM=''${TERM-linux} diff --git a/pkgs/by-name/vi/vital/package.nix b/pkgs/by-name/vi/vital/package.nix index 8a794925a7f320..fb103ddaec7de1 100644 --- a/pkgs/by-name/vi/vital/package.nix +++ b/pkgs/by-name/vi/vital/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchzip -, autoPatchelfHook -, makeBinaryWrapper +{ + lib, + stdenv, + fetchzip, + autoPatchelfHook, + makeBinaryWrapper, -, alsa-lib -, libjack2 -, curl -, xorg -, libGL -, freetype + alsa-lib, + libjack2, + curl, + xorg, + libGL, + freetype, }: stdenv.mkDerivation (finalAttrs: { @@ -17,7 +18,9 @@ stdenv.mkDerivation (finalAttrs: { version = "1.5.5"; src = fetchzip { - url = "https://builds.vital.audio/VitalAudio/vital/${builtins.replaceStrings ["."] ["_"] finalAttrs.version}/VitalInstaller.zip"; + url = "https://builds.vital.audio/VitalAudio/vital/${ + builtins.replaceStrings [ "." ] [ "_" ] finalAttrs.version + }/VitalInstaller.zip"; hash = "sha256-hCwXSUiBB0YpQ1oN6adLprwAoel6f72tBG5fEb61OCI="; }; @@ -49,17 +52,24 @@ stdenv.mkDerivation (finalAttrs: { done wrapProgram $out/bin/Vital \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ curl libjack2 ]}" + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + curl + libjack2 + ] + }" runHook postInstall ''; - meta = with lib; { description = "Spectral warping wavetable synth"; homepage = "https://vital.audio/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = with licenses; [ unfree gpl3Plus ]; + license = with licenses; [ + unfree + gpl3Plus + ]; platforms = [ "x86_64-linux" ]; maintainers = with maintainers; [ PowerUser64 ]; mainProgram = "Vital"; diff --git a/pkgs/by-name/vi/vitetris/package.nix b/pkgs/by-name/vi/vitetris/package.nix index 67358134e66907..ce96940699e049 100644 --- a/pkgs/by-name/vi/vitetris/package.nix +++ b/pkgs/by-name/vi/vitetris/package.nix @@ -1,4 +1,8 @@ -{ stdenv, fetchFromGitHub, lib }: +{ + stdenv, + fetchFromGitHub, + lib, +}: stdenv.mkDerivation rec { pname = "vitetris"; @@ -13,7 +17,10 @@ stdenv.mkDerivation rec { hardeningDisable = [ "format" ]; - makeFlags = [ "INSTALL=install" "CPPFLAGS=-Wno-implicit-int" ]; + makeFlags = [ + "INSTALL=install" + "CPPFLAGS=-Wno-implicit-int" + ]; meta = { description = "Terminal-based Tetris clone by Victor Nilsson"; diff --git a/pkgs/by-name/vi/viu/package.nix b/pkgs/by-name/vi/viu/package.nix index a81a48341afeef..ef28b02e8c1d93 100644 --- a/pkgs/by-name/vi/viu/package.nix +++ b/pkgs/by-name/vi/viu/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, libsixel -, withSixel ? false +{ + lib, + rustPlatform, + fetchFromGitHub, + libsixel, + withSixel ? false, }: rustPlatform.buildRustPackage rec { @@ -28,7 +29,10 @@ rustPlatform.buildRustPackage rec { description = "Command-line application to view images from the terminal written in Rust"; homepage = "https://github.com/atanunq/viu"; license = licenses.mit; - maintainers = with maintainers; [ chuangzhu sigmanificient ]; + maintainers = with maintainers; [ + chuangzhu + sigmanificient + ]; mainProgram = "viu"; }; } diff --git a/pkgs/by-name/vi/vivictpp/package.nix b/pkgs/by-name/vi/vivictpp/package.nix index 5dd777995ba2ad..97bba1a68e7a80 100644 --- a/pkgs/by-name/vi/vivictpp/package.nix +++ b/pkgs/by-name/vi/vivictpp/package.nix @@ -1,11 +1,21 @@ -{ lib, stdenv, fetchFromGitHub -, meson, cmake, ninja, pkg-config -, python3, git -, SDL2, SDL2_ttf -, freetype, harfbuzz -, ffmpeg -, cacert -, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + cmake, + ninja, + pkg-config, + python3, + git, + SDL2, + SDL2_ttf, + freetype, + harfbuzz, + ffmpeg, + cacert, + zlib, +}: let version = "1.1.0"; @@ -36,7 +46,8 @@ let outputHashMode = "recursive"; outputHash = "sha256-/6nuTKjQEXfJlHkTkeX/A4PeGb8SOk6Q801gjx1SB6M="; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "vivictpp"; inherit version; diff --git a/pkgs/by-name/vi/vivid/package.nix b/pkgs/by-name/vi/vivid/package.nix index 4ec34be94f4ead..6696abe9bc21d9 100644 --- a/pkgs/by-name/vi/vivid/package.nix +++ b/pkgs/by-name/vi/vivid/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "vivid"; @@ -16,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Generator for LS_COLORS with support for multiple color themes"; homepage = "https://github.com/sharkdp/vivid"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = [ maintainers.dtzWill ]; platforms = platforms.unix; mainProgram = "vivid"; diff --git a/pkgs/by-name/vi/viw/package.nix b/pkgs/by-name/vi/viw/package.nix index ad47edfe83e4d3..63cbc2615b6b49 100644 --- a/pkgs/by-name/vi/viw/package.nix +++ b/pkgs/by-name/vi/viw/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { pname = "viw"; @@ -14,7 +19,11 @@ stdenv.mkDerivation rec { buildInputs = [ ncurses ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; - checkFlags = [ "test-command" "test-buffer" "test-state" ]; + checkFlags = [ + "test-command" + "test-buffer" + "test-state" + ]; installPhase = '' install -Dm 755 -t $out/bin viw diff --git a/pkgs/by-name/vi/vix/package.nix b/pkgs/by-name/vi/vix/package.nix index 8b6eeb912fcce4..84cebdb170177c 100644 --- a/pkgs/by-name/vi/vix/package.nix +++ b/pkgs/by-name/vi/vix/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, SDL }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + SDL, +}: stdenv.mkDerivation { pname = "vix"; diff --git a/pkgs/by-name/vk/vk-bootstrap/package.nix b/pkgs/by-name/vk/vk-bootstrap/package.nix index bc43da3567d8d0..dad17ce802c83b 100644 --- a/pkgs/by-name/vk/vk-bootstrap/package.nix +++ b/pkgs/by-name/vk/vk-bootstrap/package.nix @@ -1,16 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, vulkan-headers -, glfw -, catch2 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + vulkan-headers, + glfw, + catch2, }: stdenv.mkDerivation rec { pname = "vk-bootstrap"; version = "0.7"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "charles-lunarg"; @@ -27,7 +31,11 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ cmake ]; - buildInputs = [ vulkan-headers glfw catch2 ]; + buildInputs = [ + vulkan-headers + glfw + catch2 + ]; cmakeFlags = [ "-DVK_BOOTSTRAP_VULKAN_HEADER_DIR=${vulkan-headers}/include" diff --git a/pkgs/by-name/vk/vk-cli/package.nix b/pkgs/by-name/vk/vk-cli/package.nix index b3425dcfb6f640..aaf91887ed0f15 100644 --- a/pkgs/by-name/vk/vk-cli/package.nix +++ b/pkgs/by-name/vk/vk-cli/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchurl -, curl -, p7zip -, glibc -, ncurses -, openssl +{ + stdenv, + lib, + fetchurl, + curl, + p7zip, + glibc, + ncurses, + openssl, }: stdenv.mkDerivation rec { @@ -41,7 +42,12 @@ stdenv.mkDerivation rec { postFixup = '' patchelf $out/bin/vk-cli \ --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath "${lib.makeLibraryPath [ curl glibc ]}" + --set-rpath "${ + lib.makeLibraryPath [ + curl + glibc + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/vk/vk-messenger/package.nix b/pkgs/by-name/vk/vk-messenger/package.nix index 60ed9d60b1e12d..c63aaf1527e3fb 100644 --- a/pkgs/by-name/vk/vk-messenger/package.nix +++ b/pkgs/by-name/vk/vk-messenger/package.nix @@ -1,25 +1,39 @@ -{ stdenv, lib, fetchurl, rpmextract, undmg, autoPatchelfHook -, xorg, gtk3, nss, alsa-lib, udev, libnotify -, wrapGAppsHook3 }: +{ + stdenv, + lib, + fetchurl, + rpmextract, + undmg, + autoPatchelfHook, + xorg, + gtk3, + nss, + alsa-lib, + udev, + libnotify, + wrapGAppsHook3, +}: let pname = "vk-messenger"; version = "5.3.2"; - src = { - i686-linux = fetchurl { - url = "https://desktop.userapi.com/rpm/master/vk-${version}.i686.rpm"; - sha256 = "L0nE0zW4LP8udcE8uPy+cH9lLuQsUSq7cF13Gv7w2rI="; - }; - x86_64-linux = fetchurl { - url = "https://desktop.userapi.com/rpm/master/vk-${version}.x86_64.rpm"; - sha256 = "spDw9cfDSlIuCwOqREsqXC19tx62TiAz9fjIS9lYjSQ="; - }; - x86_64-darwin = fetchurl { - url = "https://web.archive.org/web/20220302083827/https://desktop.userapi.com/mac/master/vk.dmg"; - sha256 = "hxK8I9sF6njfCxSs1KBCHfnG81JGKUgHKAeFLtuCNe0="; - }; - }.${stdenv.system} or (throw "Unsupported system: ${stdenv.system}"); + src = + { + i686-linux = fetchurl { + url = "https://desktop.userapi.com/rpm/master/vk-${version}.i686.rpm"; + sha256 = "L0nE0zW4LP8udcE8uPy+cH9lLuQsUSq7cF13Gv7w2rI="; + }; + x86_64-linux = fetchurl { + url = "https://desktop.userapi.com/rpm/master/vk-${version}.x86_64.rpm"; + sha256 = "spDw9cfDSlIuCwOqREsqXC19tx62TiAz9fjIS9lYjSQ="; + }; + x86_64-darwin = fetchurl { + url = "https://web.archive.org/web/20220302083827/https://desktop.userapi.com/mac/master/vk.dmg"; + sha256 = "hxK8I9sF6njfCxSs1KBCHfnG81JGKUgHKAeFLtuCNe0="; + }; + } + .${stdenv.system} or (throw "Unsupported system: ${stdenv.system}"); meta = with lib; { description = "Simple and Convenient Messaging App for VK"; @@ -27,18 +41,43 @@ let sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; maintainers = [ ]; - platforms = ["i686-linux" "x86_64-linux" "x86_64-darwin"]; + platforms = [ + "i686-linux" + "x86_64-linux" + "x86_64-darwin" + ]; }; linux = stdenv.mkDerivation { - inherit pname version src meta; + inherit + pname + version + src + meta + ; - nativeBuildInputs = [ rpmextract autoPatchelfHook wrapGAppsHook3 ]; - buildInputs = (with xorg; [ - libXdamage libXtst libXScrnSaver libxkbfile - ]) ++ [ gtk3 nss alsa-lib ]; + nativeBuildInputs = [ + rpmextract + autoPatchelfHook + wrapGAppsHook3 + ]; + buildInputs = + (with xorg; [ + libXdamage + libXtst + libXScrnSaver + libxkbfile + ]) + ++ [ + gtk3 + nss + alsa-lib + ]; - runtimeDependencies = [ (lib.getLib udev) libnotify ]; + runtimeDependencies = [ + (lib.getLib udev) + libnotify + ]; unpackPhase = '' rpmextract $src @@ -60,7 +99,12 @@ let }; darwin = stdenv.mkDerivation { - inherit pname version src meta; + inherit + pname + version + src + meta + ; nativeBuildInputs = [ undmg ]; @@ -71,4 +115,5 @@ let cp -r *.app $out/Applications ''; }; -in if stdenv.hostPlatform.isDarwin then darwin else linux +in +if stdenv.hostPlatform.isDarwin then darwin else linux diff --git a/pkgs/by-name/vk/vkbasalt-cli/package.nix b/pkgs/by-name/vk/vkbasalt-cli/package.nix index 855daf39ccee73..3c66ba9c0781c8 100644 --- a/pkgs/by-name/vk/vkbasalt-cli/package.nix +++ b/pkgs/by-name/vk/vkbasalt-cli/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3Packages -, fetchFromGitLab -, vkbasalt +{ + lib, + python3Packages, + fetchFromGitLab, + vkbasalt, }: python3Packages.buildPythonApplication rec { @@ -25,7 +26,10 @@ python3Packages.buildPythonApplication rec { meta = with lib; { description = "Command-line utility for vkBasalt"; homepage = "https://gitlab.com/TheEvilSkeleton/vkbasalt-cli"; - license = with licenses; [ lgpl3Only gpl3Only ]; + license = with licenses; [ + lgpl3Only + gpl3Only + ]; maintainers = [ ]; mainProgram = "vkbasalt"; }; diff --git a/pkgs/by-name/vk/vkd3d/package.nix b/pkgs/by-name/vk/vkd3d/package.nix index 801103fa8ce64a..f95ce0d0543d6c 100644 --- a/pkgs/by-name/vk/vkd3d/package.nix +++ b/pkgs/by-name/vk/vkd3d/package.nix @@ -24,7 +24,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-puYsDKFNkml2JCEhwpx9rlMsFJuz0LGCNlnpyEv/W4g="; }; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; nativeBuildInputs = [ autoreconfHook diff --git a/pkgs/by-name/vk/vkdisplayinfo/package.nix b/pkgs/by-name/vk/vkdisplayinfo/package.nix index 3a88b2e21147ec..85047758ca29d8 100644 --- a/pkgs/by-name/vk/vkdisplayinfo/package.nix +++ b/pkgs/by-name/vk/vkdisplayinfo/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, meson -, ninja -, vulkan-loader -, vulkan-headers -, fetchFromGitHub +{ + lib, + stdenv, + meson, + ninja, + vulkan-loader, + vulkan-headers, + fetchFromGitHub, }: stdenv.mkDerivation rec { pname = "vkdisplayinfo"; diff --git a/pkgs/by-name/vk/vkdt/package.nix b/pkgs/by-name/vk/vkdt/package.nix index acaf09e439771f..08b964d2a53a18 100644 --- a/pkgs/by-name/vk/vkdt/package.nix +++ b/pkgs/by-name/vk/vkdt/package.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchurl -, vulkan-headers -, vulkan-tools -, vulkan-loader -, glslang -, glfw -, libjpeg -, pkg-config -, rsync -, cmake -, clang -, llvm -, llvmPackages -, pugixml -, freetype -, exiv2 -, ffmpeg -, libvorbis -, libmad -, testers -, vkdt -, xxd -, alsa-lib -, cargo -, rustPlatform +{ + lib, + stdenv, + fetchurl, + vulkan-headers, + vulkan-tools, + vulkan-loader, + glslang, + glfw, + libjpeg, + pkg-config, + rsync, + cmake, + clang, + llvm, + llvmPackages, + pugixml, + freetype, + exiv2, + ffmpeg, + libvorbis, + libmad, + testers, + vkdt, + xxd, + alsa-lib, + cargo, + rustPlatform, }: stdenv.mkDerivation rec { @@ -77,7 +78,10 @@ stdenv.mkDerivation rec { dontUseCmakeConfigure = true; - makeFlags = [ "DESTDIR=$(out)" "prefix=" ]; + makeFlags = [ + "DESTDIR=$(out)" + "prefix=" + ]; passthru.tests.version = testers.testVersion { package = vkdt; diff --git a/pkgs/by-name/vk/vkeybd/package.nix b/pkgs/by-name/vk/vkeybd/package.nix index 1afac1aba55835..faf940bfc06295 100644 --- a/pkgs/by-name/vk/vkeybd/package.nix +++ b/pkgs/by-name/vk/vkeybd/package.nix @@ -1,6 +1,15 @@ -{ lib, stdenv, fetchurl, alsa-lib, libX11, makeWrapper, tcl, tk }: +{ + lib, + stdenv, + fetchurl, + alsa-lib, + libX11, + makeWrapper, + tcl, + tk, +}: -stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "vkeybd"; version = "0.1.18d"; @@ -10,14 +19,22 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ alsa-lib libX11 tcl tk ]; + buildInputs = [ + alsa-lib + libX11 + tcl + tk + ]; configurePhase = '' mkdir -p $out/bin sed -e "s@/usr/local@$out@" -i Makefile ''; - makeFlags = [ "TKLIB=-l${tk.libPrefix}" "TCLLIB=-l${tcl.libPrefix}" ]; + makeFlags = [ + "TKLIB=-l${tk.libPrefix}" + "TCLLIB=-l${tcl.libPrefix}" + ]; meta = with lib; { description = "Virtual MIDI keyboard"; diff --git a/pkgs/by-name/vk/vkmark/package.nix b/pkgs/by-name/vk/vkmark/package.nix index 4d5d665570cfd1..f3733e2033b95f 100644 --- a/pkgs/by-name/vk/vkmark/package.nix +++ b/pkgs/by-name/vk/vkmark/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, meson -, ninja -, vulkan-headers -, vulkan-loader -, mesa -, wayland-protocols -, wayland -, glm -, assimp -, libxcb -, xcbutilwm -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + meson, + ninja, + vulkan-headers, + vulkan-loader, + mesa, + wayland-protocols, + wayland, + glm, + assimp, + libxcb, + xcbutilwm, + unstableGitUpdater, }: stdenv.mkDerivation rec { @@ -27,7 +28,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-X1Y2U1aJymKrv3crJLN7tvXHG2W+w0W5gB2g00y4yvc="; }; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; buildInputs = [ vulkan-headers vulkan-loader diff --git a/pkgs/by-name/vl/vlan/package.nix b/pkgs/by-name/vl/vlan/package.nix index d93c61bda547bb..f2aee7bad060d9 100644 --- a/pkgs/by-name/vl/vlan/package.nix +++ b/pkgs/by-name/vl/vlan/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "vlan"; @@ -11,20 +15,18 @@ stdenv.mkDerivation rec { hardeningDisable = [ "format" ]; - preBuild = - '' - # Ouch, the tarball contains pre-compiled binaries. - make clean - ''; + preBuild = '' + # Ouch, the tarball contains pre-compiled binaries. + make clean + ''; - installPhase = - '' - mkdir -p $out/sbin - cp vconfig $out/sbin/ + installPhase = '' + mkdir -p $out/sbin + cp vconfig $out/sbin/ - mkdir -p $out/share/man/man8 - cp vconfig.8 $out/share/man/man8/ - ''; + mkdir -p $out/share/man/man8 + cp vconfig.8 $out/share/man/man8/ + ''; meta = with lib; { description = "User mode programs to enable VLANs on Ethernet devices"; diff --git a/pkgs/by-name/vl/vlang/package.nix b/pkgs/by-name/vl/vlang/package.nix index 62077a7e4f8553..44cd0ab758ba05 100644 --- a/pkgs/by-name/vl/vlang/package.nix +++ b/pkgs/by-name/vl/vlang/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, glfw, freetype, openssl, makeWrapper, upx, boehmgc, xorg, binaryen, darwin }: +{ + lib, + stdenv, + fetchFromGitHub, + glfw, + freetype, + openssl, + makeWrapper, + upx, + boehmgc, + xorg, + binaryen, + darwin, +}: let version = "0.4.8"; @@ -19,13 +32,15 @@ let }; # patch the ptrace reference for darwin - installPhase = lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace v.c \ - --replace "#include " "${ptraceSubstitution}" - '' + '' - mkdir -p $out - cp v.c $out/ - ''; + installPhase = + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace v.c \ + --replace "#include " "${ptraceSubstitution}" + '' + + '' + mkdir -p $out + cp v.c $out/ + ''; }; # Required for vdoc. markdown = fetchFromGitHub { @@ -49,21 +64,27 @@ stdenv.mkDerivation { hash = "sha256-V4f14TcuKW8unzlo6i/tE6MzSb3HAll478OU2LxiTPQ="; }; - propagatedBuildInputs = [ glfw freetype openssl ] - ++ lib.optional stdenv.hostPlatform.isUnix upx; + propagatedBuildInputs = [ + glfw + freetype + openssl + ] ++ lib.optional stdenv.hostPlatform.isUnix upx; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ - binaryen - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Cocoa - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - xorg.libX11 - xorg.libXau - xorg.libXdmcp - xorg.xorgproto - ]; + buildInputs = + [ + binaryen + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Cocoa + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + xorg.libX11 + xorg.libXau + xorg.libXdmcp + xorg.xorgproto + ]; makeFlags = [ "local=1" @@ -102,7 +123,10 @@ stdenv.mkDerivation { homepage = "https://vlang.io/"; description = "Simple, fast, safe, compiled language for developing maintainable software"; license = licenses.mit; - maintainers = with maintainers; [ Madouura delta231 ]; + maintainers = with maintainers; [ + Madouura + delta231 + ]; mainProgram = "v"; platforms = platforms.all; }; diff --git a/pkgs/by-name/vl/vlc-bin/package.nix b/pkgs/by-name/vl/vlc-bin/package.nix index 9e496883ccb8c3..6aed05b571ca3f 100644 --- a/pkgs/by-name/vl/vlc-bin/package.nix +++ b/pkgs/by-name/vl/vlc-bin/package.nix @@ -1,28 +1,36 @@ -{ lib -, fetchurl -, makeWrapper -, stdenv -, undmg -, variant ? - if (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) - then "arm64" - else if (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) - then "intel64" - else "universal" # not reachable by normal means +{ + lib, + fetchurl, + makeWrapper, + stdenv, + undmg, + variant ? + if (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) then + "arm64" + else if (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) then + "intel64" + else + "universal", # not reachable by normal means }: -assert builtins.elem variant [ "arm64" "intel64" "universal" ]; +assert builtins.elem variant [ + "arm64" + "intel64" + "universal" +]; stdenv.mkDerivation (finalAttrs: { pname = "vlc-bin-${variant}"; version = "3.0.21"; src = fetchurl { url = "http://get.videolan.org/vlc/${finalAttrs.version}/macosx/vlc-${finalAttrs.version}-${variant}.dmg"; - hash = { - "arm64" = "sha256-Fd1lv2SJ2p7Gpn9VhcdMQKWJk6z/QagpWKkW3XQXgEQ="; - "intel64" = "sha256-1DH9BRw9x68CvTE8bQXZDPYEtw7T7Fu6b9TEnvPmONk="; - "universal" = "sha256-UDgOVvgdYw41MUJqJlq/iz3ubAgiu3yeMLUyx9aaZcA="; - }.${variant}; + hash = + { + "arm64" = "sha256-Fd1lv2SJ2p7Gpn9VhcdMQKWJk6z/QagpWKkW3XQXgEQ="; + "intel64" = "sha256-1DH9BRw9x68CvTE8bQXZDPYEtw7T7Fu6b9TEnvPmONk="; + "universal" = "sha256-UDgOVvgdYw41MUJqJlq/iz3ubAgiu3yeMLUyx9aaZcA="; + } + .${variant}; }; sourceRoot = "."; @@ -49,13 +57,13 @@ stdenv.mkDerivation (finalAttrs: { license = lib.licenses.lgpl21Plus; mainProgram = "vlc"; maintainers = with lib.maintainers; [ pcasaretto ]; - platforms = lib.systems.inspect.patternLogicalAnd - (lib.systems.inspect.patterns.isDarwin) - (({ + platforms = lib.systems.inspect.patternLogicalAnd (lib.systems.inspect.patterns.isDarwin) ( + ({ "arm64" = lib.systems.inspect.patterns.isAarch64; "intel64" = lib.systems.inspect.patterns.isx86_64; "universal" = lib.systems.inspect.patterns.isDarwin; - }).${variant}); + }).${variant} + ); sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; }; }) diff --git a/pkgs/by-name/vl/vlc-bittorrent/package.nix b/pkgs/by-name/vl/vlc-bittorrent/package.nix index d6c0efa2c750e0..40081ec71fd765 100644 --- a/pkgs/by-name/vl/vlc-bittorrent/package.nix +++ b/pkgs/by-name/vl/vlc-bittorrent/package.nix @@ -1,13 +1,14 @@ -{ lib -, autoconf-archive -, autoreconfHook -, boost -, fetchFromGitHub -, libtorrent-rasterbar -, libvlc -, openssl -, pkg-config -, stdenv +{ + lib, + autoconf-archive, + autoreconfHook, + boost, + fetchFromGitHub, + libtorrent-rasterbar, + libvlc, + openssl, + pkg-config, + stdenv, }: # VLC does not know where the vlc-bittorrent package is installed. diff --git a/pkgs/by-name/vl/vlc/package.nix b/pkgs/by-name/vl/vlc/package.nix index 2c005cbfa43420..96541566536491 100644 --- a/pkgs/by-name/vl/vlc/package.nix +++ b/pkgs/by-name/vl/vlc/package.nix @@ -1,97 +1,98 @@ -{ lib -, SDL -, SDL_image -, a52dec -, alsa-lib -, autoreconfHook -, avahi -, curl -, dbus -, faad2 -, fetchpatch -, fetchurl -# Please unpin FFmpeg on the next upstream release. -, ffmpeg_6 -, flac -, fluidsynth -, freefont_ttf -, freetype -, fribidi -, genericUpdater -, gnutls -, libSM -, libXext -, libXinerama -, libXpm -, libXv -, libXvMC -, libarchive -, libass -, libbluray -, libcaca -, libcddb -, libdc1394 -, libdvbpsi -, libdvdnav -, libebml -, libgcrypt -, libgpg-error -, libjack2 -, libkate -, libmad -, libmatroska -, libmicrodns -, libmodplug -, libmtp -, liboggz -, libopus -, libplacebo_5 -, libpulseaudio -, libraw1394 -, librsvg -, libsForQt5 -, libsamplerate -, libspatialaudio -, libssh2 -, libtheora -, libtiger -, libupnp -, libv4l -, libva -, libvdpau -, libvorbis -, libxml2 -, live555 -, lua5 -, mpeg2dec -, ncurses -, perl -, pkg-config -, pkgsBuildBuild -, protobuf -, removeReferencesTo -, samba -, schroedinger -, speex -, srt -, stdenv -, systemd -, taglib -, unzip -, wayland -, wayland-protocols -, wayland-scanner -, wrapGAppsHook3 -, writeShellScript -, xcbutilkeysyms -, zlib +{ + lib, + SDL, + SDL_image, + a52dec, + alsa-lib, + autoreconfHook, + avahi, + curl, + dbus, + faad2, + fetchpatch, + fetchurl, + # Please unpin FFmpeg on the next upstream release. + ffmpeg_6, + flac, + fluidsynth, + freefont_ttf, + freetype, + fribidi, + genericUpdater, + gnutls, + libSM, + libXext, + libXinerama, + libXpm, + libXv, + libXvMC, + libarchive, + libass, + libbluray, + libcaca, + libcddb, + libdc1394, + libdvbpsi, + libdvdnav, + libebml, + libgcrypt, + libgpg-error, + libjack2, + libkate, + libmad, + libmatroska, + libmicrodns, + libmodplug, + libmtp, + liboggz, + libopus, + libplacebo_5, + libpulseaudio, + libraw1394, + librsvg, + libsForQt5, + libsamplerate, + libspatialaudio, + libssh2, + libtheora, + libtiger, + libupnp, + libv4l, + libva, + libvdpau, + libvorbis, + libxml2, + live555, + lua5, + mpeg2dec, + ncurses, + perl, + pkg-config, + pkgsBuildBuild, + protobuf, + removeReferencesTo, + samba, + schroedinger, + speex, + srt, + stdenv, + systemd, + taglib, + unzip, + wayland, + wayland-protocols, + wayland-scanner, + wrapGAppsHook3, + writeShellScript, + xcbutilkeysyms, + zlib, -, chromecastSupport ? true -, jackSupport ? false -, onlyLibVLC ? false -, skins2Support ? !onlyLibVLC -, waylandSupport ? true -, withQt5 ? true + chromecastSupport ? true, + jackSupport ? false, + onlyLibVLC ? false, + skins2Support ? !onlyLibVLC, + waylandSupport ? true, + withQt5 ? true, }: # chromecastSupport requires TCP port 8010 to be open for it to work. @@ -110,114 +111,128 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-JNu+HX367qCZTV3vC73iABdzRxNtv+Vz9bakzuJa+7A="; }; - nativeBuildInputs = [ - autoreconfHook - lua5 - perl - pkg-config - removeReferencesTo - unzip - wrapGAppsHook3 - ] - ++ optionals chromecastSupport [ protobuf ] - ++ optionals withQt5 [ libsForQt5.wrapQtAppsHook ] - ++ optionals waylandSupport [ - wayland-scanner - ]; + nativeBuildInputs = + [ + autoreconfHook + lua5 + perl + pkg-config + removeReferencesTo + unzip + wrapGAppsHook3 + ] + ++ optionals chromecastSupport [ protobuf ] + ++ optionals withQt5 [ libsForQt5.wrapQtAppsHook ] + ++ optionals waylandSupport [ + wayland-scanner + ]; # VLC uses a *ton* of libraries for various pieces of functionality, many of # which are not included here for no other reason that nobody has mentioned # needing them - buildInputs = [ - SDL - SDL_image - a52dec - alsa-lib - avahi - dbus - faad2 - ffmpeg_6 - flac - fluidsynth - fribidi - gnutls - libSM - libXpm - libXv - libXvMC - libarchive - libass - libbluray - libcaca - libcddb - libdc1394 - libdvbpsi - libdvdnav - libdvdnav.libdvdread - libebml - libgcrypt - libgpg-error - libkate - libmad - libmatroska - libmodplug - libmtp - liboggz - libopus - libplacebo_5 - libpulseaudio - libraw1394 - librsvg - libsamplerate - libspatialaudio - libssh2 - libtheora - libtiger - libupnp - libv4l - libva - libvdpau - libvorbis - libxml2 - lua5 - mpeg2dec - ncurses - samba - schroedinger - speex - srt - systemd - taglib - xcbutilkeysyms - zlib - ] - ++ optionals (!stdenv.hostPlatform.isAarch && !onlyLibVLC) [ live555 ] - ++ optionals jackSupport [ libjack2 ] - ++ optionals chromecastSupport [ libmicrodns protobuf ] - ++ optionals skins2Support [ - freetype - libXext - libXinerama - libXpm - ] - ++ optionals waylandSupport [ wayland wayland-protocols ] - ++ optionals withQt5 (with libsForQt5; [ - qtbase - qtsvg - qtx11extras - ]) - ++ optionals (waylandSupport && withQt5) [ libsForQt5.qtwayland ]; + buildInputs = + [ + SDL + SDL_image + a52dec + alsa-lib + avahi + dbus + faad2 + ffmpeg_6 + flac + fluidsynth + fribidi + gnutls + libSM + libXpm + libXv + libXvMC + libarchive + libass + libbluray + libcaca + libcddb + libdc1394 + libdvbpsi + libdvdnav + libdvdnav.libdvdread + libebml + libgcrypt + libgpg-error + libkate + libmad + libmatroska + libmodplug + libmtp + liboggz + libopus + libplacebo_5 + libpulseaudio + libraw1394 + librsvg + libsamplerate + libspatialaudio + libssh2 + libtheora + libtiger + libupnp + libv4l + libva + libvdpau + libvorbis + libxml2 + lua5 + mpeg2dec + ncurses + samba + schroedinger + speex + srt + systemd + taglib + xcbutilkeysyms + zlib + ] + ++ optionals (!stdenv.hostPlatform.isAarch && !onlyLibVLC) [ live555 ] + ++ optionals jackSupport [ libjack2 ] + ++ optionals chromecastSupport [ + libmicrodns + protobuf + ] + ++ optionals skins2Support [ + freetype + libXext + libXinerama + libXpm + ] + ++ optionals waylandSupport [ + wayland + wayland-protocols + ] + ++ optionals withQt5 ( + with libsForQt5; + [ + qtbase + qtsvg + qtx11extras + ] + ) + ++ optionals (waylandSupport && withQt5) [ libsForQt5.qtwayland ]; - env = { - # vlc depends on a c11-gcc wrapper script which we don't have so we need to - # set the path to the compiler - BUILDCC = "${pkgsBuildBuild.stdenv.cc}/bin/gcc"; - PKG_CONFIG_WAYLAND_SCANNER_WAYLAND_SCANNER = "wayland-scanner"; - } // lib.optionalAttrs stdenv.cc.isGNU { - NIX_CFLAGS_COMPILE = "-Wno-error=incompatible-pointer-types"; - } // lib.optionalAttrs (!stdenv.hostPlatform.isAarch) { - LIVE555_PREFIX = live555; - }; + env = + { + # vlc depends on a c11-gcc wrapper script which we don't have so we need to + # set the path to the compiler + BUILDCC = "${pkgsBuildBuild.stdenv.cc}/bin/gcc"; + PKG_CONFIG_WAYLAND_SCANNER_WAYLAND_SCANNER = "wayland-scanner"; + } + // lib.optionalAttrs stdenv.cc.isGNU { + NIX_CFLAGS_COMPILE = "-Wno-error=incompatible-pointer-types"; + } + // lib.optionalAttrs (!stdenv.hostPlatform.isAarch) { + LIVE555_PREFIX = live555; + }; patches = [ # patch to build with recent live555 @@ -228,19 +243,20 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - postPatch = '' - substituteInPlace modules/text_renderer/freetype/platform_fonts.h \ - --replace \ - /usr/share/fonts/truetype/freefont \ - ${freefont_ttf}/share/fonts/truetype - '' - # Upstream luac can't cross compile, so we have to install the lua sources - # instead of bytecode: - # https://www.lua.org/wshop13/Jericke.pdf#page=39 - + lib.optionalString (!stdenv.hostPlatform.canExecute stdenv.buildPlatform) '' + postPatch = + '' + substituteInPlace modules/text_renderer/freetype/platform_fonts.h \ + --replace \ + /usr/share/fonts/truetype/freefont \ + ${freefont_ttf}/share/fonts/truetype + '' + # Upstream luac can't cross compile, so we have to install the lua sources + # instead of bytecode: + # https://www.lua.org/wshop13/Jericke.pdf#page=39 + + lib.optionalString (!stdenv.hostPlatform.canExecute stdenv.buildPlatform) '' substituteInPlace share/Makefile.am \ --replace $'.luac \\\n' $'.lua \\\n' - ''; + ''; enableParallelBuilding = true; @@ -248,18 +264,19 @@ stdenv.mkDerivation (finalAttrs: { # Most of the libraries are auto-detected so we don't need to set a bunch of # "--enable-foo" flags here - configureFlags = [ - "--enable-srt" # Explicit enable srt to ensure the patch is applied. - "--with-kde-solid=$out/share/apps/solid/actions" - ] - ++ optionals onlyLibVLC [ "--disable-vlc" ] - ++ optionals skins2Support [ "--enable-skins2" ] - ++ optionals waylandSupport [ "--enable-wayland" ] - ++ optionals chromecastSupport [ - "--enable-sout" - "--enable-chromecast" - "--enable-microdns" - ]; + configureFlags = + [ + "--enable-srt" # Explicit enable srt to ensure the patch is applied. + "--with-kde-solid=$out/share/apps/solid/actions" + ] + ++ optionals onlyLibVLC [ "--disable-vlc" ] + ++ optionals skins2Support [ "--enable-skins2" ] + ++ optionals waylandSupport [ "--enable-wayland" ] + ++ optionals chromecastSupport [ + "--enable-sout" + "--enable-chromecast" + "--enable-microdns" + ]; # Remove runtime dependencies on libraries postConfigure = '' @@ -288,12 +305,16 @@ stdenv.mkDerivation (finalAttrs: { # pkgsBuildBuild is used here because buildPackages.libvlc somehow # depends on a qt5.qttranslations that doesn't build, even though it # should be the same as pkgsBuildBuild.qt5.qttranslations. - postFixup = '' - find $out/lib/vlc/plugins -exec touch -d @1 '{}' ';' - ${if stdenv.buildPlatform.canExecute stdenv.hostPlatform then "$out" else pkgsBuildBuild.libvlc}/lib/vlc/vlc-cache-gen $out/vlc/plugins - '' + optionalString withQt5 '' - remove-references-to -t "${libsForQt5.qtbase.dev}" $out/lib/vlc/plugins/gui/libqt_plugin.so - ''; + postFixup = + '' + find $out/lib/vlc/plugins -exec touch -d @1 '{}' ';' + ${ + if stdenv.buildPlatform.canExecute stdenv.hostPlatform then "$out" else pkgsBuildBuild.libvlc + }/lib/vlc/vlc-cache-gen $out/vlc/plugins + '' + + optionalString withQt5 '' + remove-references-to -t "${libsForQt5.qtbase.dev}" $out/lib/vlc/plugins/gui/libqt_plugin.so + ''; passthru.updateScript = genericUpdater { versionLister = writeShellScript "vlc-versionLister" '' diff --git a/pkgs/by-name/vl/vlock/package.nix b/pkgs/by-name/vl/vlock/package.nix index 4596f707f344e9..a0d13df609a3c0 100644 --- a/pkgs/by-name/vl/vlock/package.nix +++ b/pkgs/by-name/vl/vlock/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, pam }: +{ + lib, + stdenv, + fetchurl, + pam, +}: stdenv.mkDerivation rec { pname = "vlock"; @@ -17,7 +22,10 @@ stdenv.mkDerivation rec { patches = [ ./eintr.patch ]; - configureFlags = [ "VLOCK_GROUP=root" "ROOT_GROUP=root" ]; + configureFlags = [ + "VLOCK_GROUP=root" + "ROOT_GROUP=root" + ]; buildInputs = [ pam ]; diff --git a/pkgs/by-name/vm/vmfs-tools/package.nix b/pkgs/by-name/vm/vmfs-tools/package.nix index e9dafd11b88811..9a0507089d02ed 100644 --- a/pkgs/by-name/vm/vmfs-tools/package.nix +++ b/pkgs/by-name/vm/vmfs-tools/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config -, asciidoc -, docbook_xsl -, fuse -, libuuid -, libxslt +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + asciidoc, + docbook_xsl, + fuse, + libuuid, + libxslt, }: stdenv.mkDerivation rec { @@ -19,9 +21,17 @@ stdenv.mkDerivation rec { sha256 = "14y412ww5hxk336ils62s3fwykfh6mx1j0iiaa5cwc615pi6qvi4"; }; - nativeBuildInputs = [ asciidoc docbook_xsl libxslt pkg-config ]; + nativeBuildInputs = [ + asciidoc + docbook_xsl + libxslt + pkg-config + ]; - buildInputs = [ fuse libuuid ]; + buildInputs = [ + fuse + libuuid + ]; enableParallelBuilding = true; diff --git a/pkgs/by-name/vm/vmime/package.nix b/pkgs/by-name/vm/vmime/package.nix index 909a9fcbab3b42..b67aed419d5c20 100644 --- a/pkgs/by-name/vm/vmime/package.nix +++ b/pkgs/by-name/vm/vmime/package.nix @@ -1,7 +1,17 @@ -{lib, stdenv, fetchFromGitHub -, gsasl, gnutls, pkg-config, cmake, zlib, libtasn1, libgcrypt, gtk3 -# this will not work on non-nixos systems -, sendmailPath ? "/run/wrappers/bin/sendmail" +{ + lib, + stdenv, + fetchFromGitHub, + gsasl, + gnutls, + pkg-config, + cmake, + zlib, + libtasn1, + libgcrypt, + gtk3, + # this will not work on non-nixos systems + sendmailPath ? "/run/wrappers/bin/sendmail", }: stdenv.mkDerivation rec { @@ -16,8 +26,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-DUcGQcT7hp5Rs2Z5C8wo+3BYwWqED0KrF3h3vgLiiow="; }; - buildInputs = [ gsasl gnutls zlib libtasn1 libgcrypt gtk3 ]; - nativeBuildInputs = [ pkg-config cmake ]; + buildInputs = [ + gsasl + gnutls + zlib + libtasn1 + libgcrypt + gtk3 + ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; cmakeFlags = [ "-DVMIME_SENDMAIL_PATH=${sendmailPath}" diff --git a/pkgs/by-name/vm/vms-empire/package.nix b/pkgs/by-name/vm/vms-empire/package.nix index a1d565b18a0378..d0d8bc5e47e76e 100644 --- a/pkgs/by-name/vm/vms-empire/package.nix +++ b/pkgs/by-name/vm/vms-empire/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, ncurses -, xmlto -, docbook_xml_dtd_44 -, docbook_xsl -, installShellFiles +{ + lib, + stdenv, + fetchurl, + ncurses, + xmlto, + docbook_xml_dtd_44, + docbook_xsl, + installShellFiles, }: stdenv.mkDerivation (finalAttrs: { pname = "vms-empire"; version = "1.18"; - src = fetchurl{ + src = fetchurl { url = "http://www.catb.org/~esr/vms-empire/vms-empire-${finalAttrs.version}.tar.gz"; hash = "sha256-JWCmrGS4jClSi6MCcGNiq8zUH+92fiqMtk58B+wMKQk="; }; diff --git a/pkgs/by-name/vm/vmtouch/package.nix b/pkgs/by-name/vm/vmtouch/package.nix index 120012019a72af..a49750e59ffd2f 100644 --- a/pkgs/by-name/vm/vmtouch/package.nix +++ b/pkgs/by-name/vm/vmtouch/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchFromGitHub, perl}: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation rec { pname = "vmtouch"; @@ -11,7 +16,7 @@ stdenv.mkDerivation rec { sha256 = "08da6apzfkfjwasn4dxrlfxqfx7arl28apdzac5nvm0fhvws0dxk"; }; - buildInputs = [perl]; + buildInputs = [ perl ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/vn/vncrec/package.nix b/pkgs/by-name/vn/vncrec/package.nix index 983bf16e100d84..8b20aeb546d91b 100644 --- a/pkgs/by-name/vn/vncrec/package.nix +++ b/pkgs/by-name/vn/vncrec/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchurl, libX11, xorgproto, imake, gccmakedep, libXt, libXmu -, libXaw, libXext, libSM, libICE, libXpm, libXp +{ + lib, + stdenv, + fetchurl, + libX11, + xorgproto, + imake, + gccmakedep, + libXt, + libXmu, + libXaw, + libXext, + libSM, + libICE, + libXpm, + libXp, }: stdenv.mkDerivation { @@ -13,17 +27,31 @@ stdenv.mkDerivation { hardeningDisable = [ "format" ]; - nativeBuildInputs = [ imake gccmakedep ]; + nativeBuildInputs = [ + imake + gccmakedep + ]; buildInputs = [ - libX11 xorgproto libXt libXmu libXaw - libXext libSM libICE libXpm libXp + libX11 + xorgproto + libXt + libXmu + libXaw + libXext + libSM + libICE + libXpm + libXp ]; makeFlags = [ "BINDIR=${placeholder "out"}/bin" "MANDIR=${placeholder "out"}/share/man" ]; - installTargets = [ "install" "install.man" ]; + installTargets = [ + "install" + "install.man" + ]; meta = { description = "VNC recorder"; diff --git a/pkgs/by-name/vn/vndr/package.nix b/pkgs/by-name/vn/vndr/package.nix index 9e8f57b4e6effd..1633baf9f29127 100644 --- a/pkgs/by-name/vn/vndr/package.nix +++ b/pkgs/by-name/vn/vndr/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule { @@ -27,7 +28,10 @@ buildGoModule { description = "Stupid golang vendoring tool, inspired by docker vendor script"; mainProgram = "vndr"; homepage = "https://github.com/LK4D4/vndr"; - maintainers = with lib.maintainers; [ vdemeester rvolosatovs ]; + maintainers = with lib.maintainers; [ + vdemeester + rvolosatovs + ]; license = lib.licenses.asl20; }; } diff --git a/pkgs/by-name/vn/vnote/package.nix b/pkgs/by-name/vn/vnote/package.nix index 7808c02dba34f9..7b96dc26e94f01 100644 --- a/pkgs/by-name/vn/vnote/package.nix +++ b/pkgs/by-name/vn/vnote/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qt6 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qt6, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/vn/vnstat/package.nix b/pkgs/by-name/vn/vnstat/package.nix index 828a2514c7666c..77635f2fd991fe 100644 --- a/pkgs/by-name/vn/vnstat/package.nix +++ b/pkgs/by-name/vn/vnstat/package.nix @@ -1,9 +1,12 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config -, gd, ncurses -, sqlite -, check +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + gd, + ncurses, + sqlite, + check, }: stdenv.mkDerivation rec { @@ -22,7 +25,11 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gd ncurses sqlite ]; + buildInputs = [ + gd + ncurses + sqlite + ]; nativeCheckInputs = [ check ]; diff --git a/pkgs/by-name/vo/vo-aacenc/package.nix b/pkgs/by-name/vo/vo-aacenc/package.nix index fb8dd43fe03249..62560180785f92 100644 --- a/pkgs/by-name/vo/vo-aacenc/package.nix +++ b/pkgs/by-name/vo/vo-aacenc/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "vo-aacenc"; @@ -11,9 +15,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "VisualOn AAC encoder library"; - homepage = "https://sourceforge.net/projects/opencore-amr/"; - license = licenses.asl20; + homepage = "https://sourceforge.net/projects/opencore-amr/"; + license = licenses.asl20; maintainers = [ maintainers.baloo ]; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/by-name/vo/vo-amrwbenc/package.nix b/pkgs/by-name/vo/vo-amrwbenc/package.nix index e07b8cb7688dcf..4fcf5c2b1fe3fb 100644 --- a/pkgs/by-name/vo/vo-amrwbenc/package.nix +++ b/pkgs/by-name/vo/vo-amrwbenc/package.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: -stdenv.mkDerivation rec{ +stdenv.mkDerivation rec { pname = "vo-amrwbenc"; version = "0.1.3"; diff --git a/pkgs/by-name/vo/vobcopy/package.nix b/pkgs/by-name/vo/vobcopy/package.nix index 4b74ffbc8ad29a..3ad1ccb30de247 100644 --- a/pkgs/by-name/vo/vobcopy/package.nix +++ b/pkgs/by-name/vo/vobcopy/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libdvdread, libdvdcss }: +{ + lib, + stdenv, + fetchurl, + libdvdread, + libdvdcss, +}: stdenv.mkDerivation rec { pname = "vobcopy"; @@ -9,8 +15,14 @@ stdenv.mkDerivation rec { sha256 = "01l1yihbd73srzghzzx5dgfg3yfb5kml5dix52mq0snhjp8h89c9"; }; - buildInputs = [libdvdread libdvdcss]; - makeFlags = [ "DESTDIR=$(out)" "PREFIX=/" ]; + buildInputs = [ + libdvdread + libdvdcss + ]; + makeFlags = [ + "DESTDIR=$(out)" + "PREFIX=/" + ]; meta = { description = "Copies DVD .vob files to harddisk, decrypting them on the way"; diff --git a/pkgs/by-name/vo/vobsub2srt/package.nix b/pkgs/by-name/vo/vobsub2srt/package.nix index 2847c68899fedd..3fdd398bd5fe9d 100644 --- a/pkgs/by-name/vo/vobsub2srt/package.nix +++ b/pkgs/by-name/vo/vobsub2srt/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libtiff, pkg-config, tesseract3 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libtiff, + pkg-config, + tesseract3, +}: stdenv.mkDerivation rec { pname = "vobsub2srt"; @@ -13,7 +21,10 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isGNU [ "-std=c++11" ]); - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libtiff ]; propagatedBuildInputs = [ tesseract3 ]; diff --git a/pkgs/by-name/vo/vocal/package.nix b/pkgs/by-name/vo/vocal/package.nix index 7633ab22e26a78..dd43e0263909c4 100644 --- a/pkgs/by-name/vo/vocal/package.nix +++ b/pkgs/by-name/vo/vocal/package.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, nix-update-script -, cmake -, ninja -, vala -, pkg-config -, pantheon -, gtk3 -, glib -, glib-networking -, libxml2 -, webkitgtk_4_0 -, clutter-gtk -, clutter-gst -, libunity -, libnotify -, sqlite -, gst_all_1 -, json-glib -, libgee -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + nix-update-script, + cmake, + ninja, + vala, + pkg-config, + pantheon, + gtk3, + glib, + glib-networking, + libxml2, + webkitgtk_4_0, + clutter-gtk, + clutter-gst, + libunity, + libnotify, + sqlite, + gst_all_1, + json-glib, + libgee, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/vo/vocproc/package.nix b/pkgs/by-name/vo/vocproc/package.nix index e7dd5cc8716ca8..2bc9e4db4f12c5 100644 --- a/pkgs/by-name/vo/vocproc/package.nix +++ b/pkgs/by-name/vo/vocproc/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchzip, pkg-config, lv2, fftw, lv2-cpp-tools, gtkmm2 }: +{ + lib, + stdenv, + fetchzip, + pkg-config, + lv2, + fftw, + lv2-cpp-tools, + gtkmm2, +}: stdenv.mkDerivation rec { pname = "vocproc"; @@ -11,7 +20,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ lv2 fftw lv2-cpp-tools gtkmm2 ]; + buildInputs = [ + lv2 + fftw + lv2-cpp-tools + gtkmm2 + ]; makeFlags = [ "INSTALL_DIR=$(out)/lib/lv2" diff --git a/pkgs/by-name/vo/void/package.nix b/pkgs/by-name/vo/void/package.nix index 8ead979eed8040..9f45138b2d29f3 100644 --- a/pkgs/by-name/vo/void/package.nix +++ b/pkgs/by-name/vo/void/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "void"; diff --git a/pkgs/by-name/vo/voidmap/package.nix b/pkgs/by-name/vo/voidmap/package.nix index e3f538220dd127..f55a2ddf8811ef 100644 --- a/pkgs/by-name/vo/voidmap/package.nix +++ b/pkgs/by-name/vo/voidmap/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "voidmap"; diff --git a/pkgs/by-name/vo/volantes-cursors/package.nix b/pkgs/by-name/vo/volantes-cursors/package.nix index d76a0eda4cf09c..026d4bf3ae935b 100644 --- a/pkgs/by-name/vo/volantes-cursors/package.nix +++ b/pkgs/by-name/vo/volantes-cursors/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, inkscape -, xcursorgen +{ + lib, + stdenv, + fetchFromGitHub, + inkscape, + xcursorgen, }: stdenv.mkDerivation { pname = "volantes-cursors"; @@ -16,11 +17,17 @@ stdenv.mkDerivation { }; strictDeps = true; - nativeBuildInputs = [ inkscape xcursorgen ]; + nativeBuildInputs = [ + inkscape + xcursorgen + ]; makeTargets = [ "build" ]; - makeFlags = [ "DESTDIR=$(out)" "PREFIX=" ]; + makeFlags = [ + "DESTDIR=$(out)" + "PREFIX=" + ]; meta = with lib; { homepage = "https://www.pling.com/p/1356095/"; diff --git a/pkgs/by-name/vo/volatility3/package.nix b/pkgs/by-name/vo/volatility3/package.nix index 1a65ba132af5cd..c2a067334a619e 100644 --- a/pkgs/by-name/vo/volatility3/package.nix +++ b/pkgs/by-name/vo/volatility3/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/vo/volctl/package.nix b/pkgs/by-name/vo/volctl/package.nix index b5df120aad35a4..9be2580032c4b0 100644 --- a/pkgs/by-name/vo/volctl/package.nix +++ b/pkgs/by-name/vo/volctl/package.nix @@ -1,4 +1,15 @@ -{ lib, python3Packages, fetchFromGitHub, wrapGAppsHook3, gobject-introspection, libpulseaudio, glib, gtk3, pango, xorg }: +{ + lib, + python3Packages, + fetchFromGitHub, + wrapGAppsHook3, + gobject-introspection, + libpulseaudio, + glib, + gtk3, + pango, + xorg, +}: python3Packages.buildPythonApplication rec { pname = "volctl"; @@ -26,13 +37,18 @@ python3Packages.buildPythonApplication rec { wrapGAppsHook3 ]; - propagatedBuildInputs = [ pango gtk3 ] ++ (with python3Packages; [ - pulsectl - click - pycairo - pygobject3 - pyyaml - ]); + propagatedBuildInputs = + [ + pango + gtk3 + ] + ++ (with python3Packages; [ + pulsectl + click + pycairo + pygobject3 + pyyaml + ]); # with strictDeps importing "gi.repository.Gtk" fails with "gi.RepositoryError: Typelib file for namespace 'Pango', version '1.0' not found" strictDeps = false; diff --git a/pkgs/by-name/vo/vollkorn/package.nix b/pkgs/by-name/vo/vollkorn/package.nix index 466d16b086a422..d0c780d687bad5 100644 --- a/pkgs/by-name/vo/vollkorn/package.nix +++ b/pkgs/by-name/vo/vollkorn/package.nix @@ -1,11 +1,17 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "vollkorn"; version = "4.105"; src = fetchzip { - url = "http://vollkorn-typeface.com/download/vollkorn-${builtins.replaceStrings ["."] ["-"] version}.zip"; + url = "http://vollkorn-typeface.com/download/vollkorn-${ + builtins.replaceStrings [ "." ] [ "-" ] version + }.zip"; stripRoot = false; hash = "sha256-oG79GgCwCavbMFAPakza08IPmt13Gwujrkc/NKTai7g="; }; diff --git a/pkgs/by-name/vo/volta/package.nix b/pkgs/by-name/vo/volta/package.nix index c49145e0a9d628..fd9b22836f5540 100644 --- a/pkgs/by-name/vo/volta/package.nix +++ b/pkgs/by-name/vo/volta/package.nix @@ -27,8 +27,12 @@ rustPlatform.buildRustPackage rec { }; }; - buildInputs = [ installShellFiles ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Security libiconv ]; + buildInputs = + [ installShellFiles ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + libiconv + ]; HOME = "$TMPDIR"; diff --git a/pkgs/by-name/vo/volume_key/package.nix b/pkgs/by-name/vo/volume_key/package.nix index 931eaf1d67489e..b798445a71ba81 100644 --- a/pkgs/by-name/vo/volume_key/package.nix +++ b/pkgs/by-name/vo/volume_key/package.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchgit, autoreconfHook, pkg-config, gettext, python3 -, ncurses, swig, glib, util-linux, cryptsetup, nss, gpgme -, buildPackages +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + pkg-config, + gettext, + python3, + ncurses, + swig, + glib, + util-linux, + cryptsetup, + nss, + gpgme, + buildPackages, }: stdenv.mkDerivation rec { @@ -13,13 +26,30 @@ stdenv.mkDerivation rec { sha256 = "1sqdbcih1c39bjiv4mm1m7acc3lfh2i2hf2r9i7rk8adfzq8awma"; }; - outputs = [ "out" "man" "dev" "py" ]; + outputs = [ + "out" + "man" + "dev" + "py" + ]; strictDeps = true; - nativeBuildInputs = [ autoreconfHook gettext gpgme pkg-config swig ]; + nativeBuildInputs = [ + autoreconfHook + gettext + gpgme + pkg-config + swig + ]; - buildInputs = [ glib cryptsetup nss util-linux ncurses ]; + buildInputs = [ + glib + cryptsetup + nss + util-linux + ncurses + ]; configureFlags = [ "--with-gpgme-prefix=${gpgme.dev}" diff --git a/pkgs/by-name/vo/volumeicon/package.nix b/pkgs/by-name/vo/volumeicon/package.nix index 7157ad437d131a..78df43f50add4e 100644 --- a/pkgs/by-name/vo/volumeicon/package.nix +++ b/pkgs/by-name/vo/volumeicon/package.nix @@ -1,6 +1,12 @@ -{ fetchFromGitHub, lib, stdenv -, autoreconfHook, intltool, pkg-config -, gtk3, alsa-lib +{ + fetchFromGitHub, + lib, + stdenv, + autoreconfHook, + intltool, + pkg-config, + gtk3, + alsa-lib, }: stdenv.mkDerivation rec { @@ -34,4 +40,3 @@ stdenv.mkDerivation rec { mainProgram = "volumeicon"; }; } - diff --git a/pkgs/by-name/vo/vopono/package.nix b/pkgs/by-name/vo/vopono/package.nix index 9e62a465bb6953..85070ac840cd39 100644 --- a/pkgs/by-name/vo/vopono/package.nix +++ b/pkgs/by-name/vo/vopono/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchCrate -, rustPlatform +{ + lib, + fetchCrate, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/vo/vorbisgain/package.nix b/pkgs/by-name/vo/vorbisgain/package.nix index 80307144fd9ad4..ca7b62c7715b3e 100644 --- a/pkgs/by-name/vo/vorbisgain/package.nix +++ b/pkgs/by-name/vo/vorbisgain/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libogg, libvorbis }: +{ + lib, + stdenv, + fetchurl, + libogg, + libvorbis, +}: stdenv.mkDerivation rec { pname = "vorbisgain"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { hardeningDisable = [ "format" ]; - buildInputs = [ libogg libvorbis ]; + buildInputs = [ + libogg + libvorbis + ]; patchPhase = '' chmod -v +x configure diff --git a/pkgs/by-name/vo/vouch-proxy/package.nix b/pkgs/by-name/vo/vouch-proxy/package.nix index bae680cf78bc46..2784cad0837989 100644 --- a/pkgs/by-name/vo/vouch-proxy/package.nix +++ b/pkgs/by-name/vo/vouch-proxy/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -31,7 +32,10 @@ buildGoModule rec { description = "SSO and OAuth / OIDC login solution for NGINX using the auth_request module"; changelog = "https://github.com/vouch/vouch-proxy/blob/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ leona erictapen ]; + maintainers = with maintainers; [ + leona + erictapen + ]; platforms = platforms.linux; mainProgram = "vouch-proxy"; }; diff --git a/pkgs/by-name/vo/vowpal-wabbit/package.nix b/pkgs/by-name/vo/vowpal-wabbit/package.nix index ed0c6bf679d90b..dec53f1606100a 100644 --- a/pkgs/by-name/vo/vowpal-wabbit/package.nix +++ b/pkgs/by-name/vo/vowpal-wabbit/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, boost, eigen, rapidjson, spdlog, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + boost, + eigen, + rapidjson, + spdlog, + zlib, +}: stdenv.mkDerivation rec { pname = "vowpal-wabbit"; diff --git a/pkgs/by-name/vp/vp/package.nix b/pkgs/by-name/vp/vp/package.nix index 0420ed79f9a19e..de8a7334dc2a60 100644 --- a/pkgs/by-name/vp/vp/package.nix +++ b/pkgs/by-name/vp/vp/package.nix @@ -28,7 +28,10 @@ stdenv.mkDerivation (finalAttrs: { SDL_image ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; strictDeps = true; @@ -40,7 +43,7 @@ stdenv.mkDerivation (finalAttrs: { meta = { homepage = "https://github.com/erikg/vp"; description = "SDL based picture viewer/slideshow"; - license = lib.licenses.gpl3Plus; + license = lib.licenses.gpl3Plus; mainProgram = "vp"; maintainers = with lib.maintainers; [ AndersonTorres ]; inherit (SDL.meta) platforms; diff --git a/pkgs/by-name/vp/vpnc-scripts/package.nix b/pkgs/by-name/vp/vpnc-scripts/package.nix index 9a757c73cf55ec..4ff2b6d355e247 100644 --- a/pkgs/by-name/vp/vpnc-scripts/package.nix +++ b/pkgs/by-name/vp/vpnc-scripts/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchgit -, coreutils -, gawk -, gnugrep -, iproute2 -, makeWrapper -, nettools -, openresolv -, systemd +{ + lib, + stdenv, + fetchgit, + coreutils, + gawk, + gnugrep, + iproute2, + makeWrapper, + nettools, + openresolv, + systemd, }: stdenv.mkDerivation { @@ -28,17 +29,33 @@ stdenv.mkDerivation { cp vpnc-script $out/bin ''; - preFixup = '' - substituteInPlace $out/bin/vpnc-script \ - --replace "which" "type -P" - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace $out/bin/vpnc-script \ - --replace "/sbin/resolvconf" "${openresolv}/bin/resolvconf" \ - --replace "/usr/bin/resolvectl" "${systemd}/bin/resolvectl" - '' + '' - wrapProgram $out/bin/vpnc-script \ - --prefix PATH : "${lib.makeBinPath ([ nettools gawk coreutils gnugrep ] ++ lib.optionals stdenv.hostPlatform.isLinux [ openresolv iproute2 ])}" - ''; + preFixup = + '' + substituteInPlace $out/bin/vpnc-script \ + --replace "which" "type -P" + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace $out/bin/vpnc-script \ + --replace "/sbin/resolvconf" "${openresolv}/bin/resolvconf" \ + --replace "/usr/bin/resolvectl" "${systemd}/bin/resolvectl" + '' + + '' + wrapProgram $out/bin/vpnc-script \ + --prefix PATH : "${ + lib.makeBinPath ( + [ + nettools + gawk + coreutils + gnugrep + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + openresolv + iproute2 + ] + ) + }" + ''; meta = with lib; { homepage = "https://www.infradead.org/openconnect/"; diff --git a/pkgs/by-name/vp/vpnc/package.nix b/pkgs/by-name/vp/vpnc/package.nix index 7a8a6c2b9c5d90..3ffd36234aeba0 100644 --- a/pkgs/by-name/vp/vpnc/package.nix +++ b/pkgs/by-name/vp/vpnc/package.nix @@ -1,7 +1,15 @@ -{ lib, stdenv, fetchFromGitHub -, makeWrapper, pkg-config, perl -, gnutls, libgcrypt, vpnc-scripts -, opensslSupport ? false, openssl # Distributing this is a GPL violation. +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + pkg-config, + perl, + gnutls, + libgcrypt, + vpnc-scripts, + opensslSupport ? false, + openssl, # Distributing this is a GPL violation. }: stdenv.mkDerivation { @@ -16,10 +24,11 @@ stdenv.mkDerivation { fetchSubmodules = true; }; - nativeBuildInputs = [ makeWrapper ] - ++ lib.optional (!opensslSupport) pkg-config; - buildInputs = [ libgcrypt perl ] - ++ (if opensslSupport then [ openssl ] else [ gnutls ]); + nativeBuildInputs = [ makeWrapper ] ++ lib.optional (!opensslSupport) pkg-config; + buildInputs = [ + libgcrypt + perl + ] ++ (if opensslSupport then [ openssl ] else [ gnutls ]); makeFlags = [ "PREFIX=$(out)" diff --git a/pkgs/by-name/vp/vpsfree-client/gemset.nix b/pkgs/by-name/vp/vpsfree-client/gemset.nix index e19de26f922808..6d48890408481e 100644 --- a/pkgs/by-name/vp/vpsfree-client/gemset.nix +++ b/pkgs/by-name/vp/vpsfree-client/gemset.nix @@ -1,290 +1,317 @@ { activesupport = { - dependencies = ["base64" "bigdecimal" "concurrent-ruby" "connection_pool" "drb" "i18n" "logger" "minitest" "securerandom" "tzinfo"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "base64" + "bigdecimal" + "concurrent-ruby" + "connection_pool" + "drb" + "i18n" + "logger" + "minitest" + "securerandom" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "094cv9kxa8hwlsw3c0njkvvayd0wszcz9b6xywv4yajrg83zlmvm"; type = "gem"; }; version = "7.2.1"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; connection_pool = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; curses = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15pj04v9m06lj7xcq5xjk6b0nqfpq3kiaisjmh2pysmi6nvsg9ly"; type = "gem"; }; version = "1.4.6"; }; domain_name = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cyr2xm576gqhqicsyqnhanni47408w2pgvrfi8pd13h2li3nsaz"; type = "gem"; }; version = "0.6.20240107"; }; drb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h5kbj9hvg5hb3c7l425zpds0vb42phvln2knab8nmazg2zp5m79"; type = "gem"; }; version = "2.2.1"; }; haveapi-client = { - dependencies = ["activesupport" "highline" "json" "require_all" "rest-client" "ruby-progressbar"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "activesupport" + "highline" + "json" + "require_all" + "rest-client" + "ruby-progressbar" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a6k0milq4rfybf1pc8gzikpr18dmnzpz1wi2avzdkp0dpqkvaw3"; type = "gem"; }; version = "0.23.7"; }; highline = { - dependencies = ["reline"]; - groups = ["default"]; - platforms = []; + dependencies = [ "reline" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q0f7izfi542sp93gl276spm0xyws1kpqxm0alrwwmz06mz4i0ks"; type = "gem"; }; version = "3.1.1"; }; http-accept = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09m1facypsdjynfwrcv19xcb1mqg8z6kk31g8r33pfxzh838c9n6"; type = "gem"; }; version = "1.7.0"; }; http-cookie = { - dependencies = ["domain_name"]; - groups = ["default"]; - platforms = []; + dependencies = [ "domain_name" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lr2yk5g5vvf9nzlmkn3p7mhh9mn55gpdc7kl2w21xs46fgkjynb"; type = "gem"; }; version = "1.0.7"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ffix518y7976qih9k1lgnc17i3v6yrlh0a3mckpxdb4wc2vrp16"; type = "gem"; }; version = "1.14.5"; }; io-console = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08d2lx42pa8jjav0lcjbzfzmw61b8imxr9041pva8xzqabrczp7h"; type = "gem"; }; version = "0.7.2"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b4qsi8gay7ncmigr0pnbxyb17y3h8kavdyhsh7nrlqwr35vb60q"; type = "gem"; }; version = "2.7.2"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; mime-types = { - dependencies = ["mime-types-data"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mime-types-data" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1r64z0m5zrn4k37wabfnv43wa6yivgdfk6cf2rpmmirlz889yaf1"; type = "gem"; }; version = "3.5.2"; }; mime-types-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0d5bmxcq87nj6h5rx6b1fkdzq8256yba97s2vlkszpwhc47m9rfs"; type = "gem"; }; version = "3.2024.0903"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n1akmc6bibkbxkzm1p1wmfb4n9vv397knkgz0ffykb3h1d7kdix"; type = "gem"; }; version = "5.25.1"; }; netrc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gzfmcywp1da8nzfqsql2zqi648mfnx6qwkig3cv36n9m0yy676y"; type = "gem"; }; version = "0.11.0"; }; reline = { - dependencies = ["io-console"]; - groups = ["default"]; - platforms = []; + dependencies = [ "io-console" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rl1jmxs7pay58l7lkxkrn6nkdpk52k8rvnfwqsd1swjlxlwjq0n"; type = "gem"; }; version = "0.5.10"; }; require_all = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sjf2vigdg4wq7z0xlw14zyhcz4992s05wgr2s58kjgin12bkmv8"; type = "gem"; }; version = "2.0.0"; }; rest-client = { - dependencies = ["http-accept" "http-cookie" "mime-types" "netrc"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "http-accept" + "http-cookie" + "mime-types" + "netrc" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qs74yzl58agzx9dgjhcpgmzfn61fqkk33k1js2y5yhlvc5l19im"; type = "gem"; }; version = "2.1.0"; }; ruby-progressbar = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cwvyb7j47m7wihpfaq7rc47zwwx9k4v7iqd9s1xch5nm53rrz40"; type = "gem"; }; version = "1.13.0"; }; securerandom = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1phv6kh417vkanhssbjr960c0gfqvf8z7d3d9fd2yvd41q64bw4q"; type = "gem"; }; version = "0.3.1"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; vpsadmin-client = { - dependencies = ["curses" "haveapi-client" "json"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "curses" + "haveapi-client" + "json" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qy0l0gyhsyz9hdbqdb324l4zlgs78hml1cnp3gx1jl5ndj62znc"; type = "gem"; }; version = "4.0.0"; }; vpsfree-client = { - dependencies = ["vpsadmin-client"]; - groups = ["default"]; - platforms = []; + dependencies = [ "vpsadmin-client" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl6r20r7hksd3g6sjqrgi9x21ykbvv170vszf2l06a8ifrrqlk7"; type = "gem"; }; diff --git a/pkgs/by-name/vp/vpsfree-client/package.nix b/pkgs/by-name/vp/vpsfree-client/package.nix index cffdc267e53c18..65da8d4c03184c 100644 --- a/pkgs/by-name/vp/vpsfree-client/package.nix +++ b/pkgs/by-name/vp/vpsfree-client/package.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "vpsfree-client"; @@ -10,7 +14,10 @@ bundlerApp { meta = with lib; { description = "Ruby API and CLI for the vpsFree.cz API"; homepage = "https://github.com/vpsfreecz/vpsfree-client"; - maintainers = with maintainers; [ aither64 zimbatm ]; + maintainers = with maintainers; [ + aither64 + zimbatm + ]; license = licenses.gpl3; platforms = platforms.unix; mainProgram = "vpsfreectl"; diff --git a/pkgs/by-name/vp/vpv/package.nix b/pkgs/by-name/vp/vpv/package.nix index 7f80ff24a3ce1f..89631f60af51a9 100644 --- a/pkgs/by-name/vp/vpv/package.nix +++ b/pkgs/by-name/vp/vpv/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, libpng -, libtiff -, libjpeg -, SDL2 -, gdal -, octave -, rustPlatform -, cargo +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libpng, + libtiff, + libjpeg, + SDL2, + gdal, + octave, + rustPlatform, + cargo, }: stdenv.mkDerivation (finalAttrs: { pname = "vpv"; diff --git a/pkgs/by-name/vr/vrb/package.nix b/pkgs/by-name/vr/vrb/package.nix index f6ab54dba0304f..4f24c8cd9d258d 100644 --- a/pkgs/by-name/vr/vrb/package.nix +++ b/pkgs/by-name/vr/vrb/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "vrb"; @@ -26,10 +30,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Virtual ring buffer library written in C"; mainProgram = "vbuf"; - license = licenses.lgpl21; - homepage = "http://vrb.sourceforge.net/"; + license = licenses.lgpl21; + homepage = "http://vrb.sourceforge.net/"; maintainers = [ maintainers.bobvanderlinden ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } - diff --git a/pkgs/by-name/vr/vrpn/package.nix b/pkgs/by-name/vr/vrpn/package.nix index 3272a4bbd14704..6351f7d1ae6e74 100644 --- a/pkgs/by-name/vr/vrpn/package.nix +++ b/pkgs/by-name/vr/vrpn/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, unzip -, cmake -, darwin -, libGLU -, libGL +{ + lib, + stdenv, + fetchFromGitHub, + unzip, + cmake, + darwin, + libGLU, + libGL, }: stdenv.mkDerivation rec { @@ -24,15 +25,17 @@ stdenv.mkDerivation rec { unzip ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreFoundation - darwin.apple_sdk.frameworks.GLUT - darwin.apple_sdk.frameworks.IOKit - darwin.apple_sdk.frameworks.OpenGL - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libGLU - libGL - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreFoundation + darwin.apple_sdk.frameworks.GLUT + darwin.apple_sdk.frameworks.IOKit + darwin.apple_sdk.frameworks.OpenGL + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libGLU + libGL + ]; meta = with lib; { description = "Virtual Reality Peripheral Network"; diff --git a/pkgs/by-name/vr/vrrtest/package.nix b/pkgs/by-name/vr/vrrtest/package.nix index 7a8e93a4f373dd..c1ee21a55e7ec9 100644 --- a/pkgs/by-name/vr/vrrtest/package.nix +++ b/pkgs/by-name/vr/vrrtest/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, zip -, love +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + zip, + love, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/vs/vsc-leetcode-cli/package.nix b/pkgs/by-name/vs/vsc-leetcode-cli/package.nix index 6cc544a4361ebb..8427013f45b22b 100644 --- a/pkgs/by-name/vs/vsc-leetcode-cli/package.nix +++ b/pkgs/by-name/vs/vsc-leetcode-cli/package.nix @@ -1,6 +1,7 @@ -{ buildNpmPackage -, fetchFromGitHub -, lib +{ + buildNpmPackage, + fetchFromGitHub, + lib, }: buildNpmPackage { diff --git a/pkgs/by-name/vs/vsce/package.nix b/pkgs/by-name/vs/vsce/package.nix index 1ecf3d9204d609..920213bc3c7aa1 100644 --- a/pkgs/by-name/vs/vsce/package.nix +++ b/pkgs/by-name/vs/vsce/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, buildNpmPackage -, fetchFromGitHub -, pkg-config -, libsecret -, darwin -, python3 -, testers -, vsce +{ + lib, + stdenv, + buildNpmPackage, + fetchFromGitHub, + pkg-config, + libsecret, + darwin, + python3, + testers, + vsce, }: buildNpmPackage rec { @@ -27,10 +28,20 @@ buildNpmPackage rec { substituteInPlace package.json --replace '"version": "0.0.0"' '"version": "${version}"' ''; - nativeBuildInputs = [ pkg-config python3 ]; - - buildInputs = [ libsecret ] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ AppKit Security ]); + nativeBuildInputs = [ + pkg-config + python3 + ]; + + buildInputs = + [ libsecret ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + AppKit + Security + ] + ); makeCacheWritable = true; npmFlags = [ "--legacy-peer-deps" ]; diff --git a/pkgs/by-name/vs/vscode-js-debug/package.nix b/pkgs/by-name/vs/vscode-js-debug/package.nix index 25b2ed8ecb7961..9434ae1e361e2b 100644 --- a/pkgs/by-name/vs/vscode-js-debug/package.nix +++ b/pkgs/by-name/vs/vscode-js-debug/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, buildNpmPackage -, fetchFromGitHub -, buildPackages -, libsecret -, xcbuild -, Security -, AppKit -, pkg-config -, node-gyp -, runCommand -, vscode-js-debug -, nix-update-script +{ + lib, + stdenv, + buildNpmPackage, + fetchFromGitHub, + buildPackages, + libsecret, + xcbuild, + Security, + AppKit, + pkg-config, + node-gyp, + runCommand, + vscode-js-debug, + nix-update-script, }: buildNpmPackage rec { @@ -56,24 +57,29 @@ buildNpmPackage rec { ''; passthru.updateScript = nix-update-script { - extraArgs = [ "--version-regex" "v((?!\d{4}\.\d\.\d{3}).*)" ]; + extraArgs = [ + "--version-regex" + "v((?!\d{4}\.\d\.\d{3}).*)" + ]; }; - passthru.tests.test = runCommand "${pname}-test" - { - nativeBuildInputs = [ vscode-js-debug ]; - meta.timeout = 60; - } '' - output=$(js-debug --help 2>&1) - if grep -Fw -- "Usage: dapDebugServer.js [port|socket path=8123] [host=localhost]" - <<< "$output"; then - touch $out - else - echo "Expected help output was not found!" >&2 - echo "The output was:" >&2 - echo "$output" >&2 - exit 1 - fi - ''; + passthru.tests.test = + runCommand "${pname}-test" + { + nativeBuildInputs = [ vscode-js-debug ]; + meta.timeout = 60; + } + '' + output=$(js-debug --help 2>&1) + if grep -Fw -- "Usage: dapDebugServer.js [port|socket path=8123] [host=localhost]" - <<< "$output"; then + touch $out + else + echo "Expected help output was not found!" >&2 + echo "The output was:" >&2 + echo "$output" >&2 + exit 1 + fi + ''; meta = with lib; { description = "A DAP-compatible JavaScript debugger"; @@ -85,8 +91,7 @@ buildNpmPackage rec { Studio proper. ''; homepage = "https://github.com/microsoft/vscode-js-debug"; - changelog = - "https://github.com/microsoft/vscode-js-debug/blob/v${version}/CHANGELOG.md"; + changelog = "https://github.com/microsoft/vscode-js-debug/blob/v${version}/CHANGELOG.md"; mainProgram = "js-debug"; license = licenses.mit; maintainers = with maintainers; [ zeorin ]; diff --git a/pkgs/by-name/vs/vscode-langservers-extracted/package.nix b/pkgs/by-name/vs/vscode-langservers-extracted/package.nix index 03dec7c8c2fb40..228cf96966a4c2 100644 --- a/pkgs/by-name/vs/vscode-langservers-extracted/package.nix +++ b/pkgs/by-name/vs/vscode-langservers-extracted/package.nix @@ -1,10 +1,18 @@ -{ lib, stdenv, buildNpmPackage, fetchFromGitHub, unzip, vscodium, vscode-extensions }: +{ + lib, + stdenv, + buildNpmPackage, + fetchFromGitHub, + unzip, + vscodium, + vscode-extensions, +}: buildNpmPackage rec { pname = "vscode-langservers-extracted"; version = "4.10.0"; - srcs = [ + srcs = [ (fetchFromGitHub { owner = "hrsh7th"; repo = "vscode-langservers-extracted"; @@ -23,9 +31,10 @@ buildNpmPackage rec { buildPhase = let extensions = - if stdenv.hostPlatform.isDarwin - then "../VSCodium.app/Contents/Resources/app/extensions" - else "../resources/app/extensions"; + if stdenv.hostPlatform.isDarwin then + "../VSCodium.app/Contents/Resources/app/extensions" + else + "../resources/app/extensions"; in '' npx babel ${extensions}/css-language-features/server/dist/node \ diff --git a/pkgs/by-name/vs/vsftpd/package.nix b/pkgs/by-name/vs/vsftpd/package.nix index a20935e6dc1935..aed7cb2317340c 100644 --- a/pkgs/by-name/vs/vsftpd/package.nix +++ b/pkgs/by-name/vs/vsftpd/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, libcap, libseccomp, openssl, pam, libxcrypt, nixosTests }: +{ + lib, + stdenv, + fetchurl, + libcap, + libseccomp, + openssl, + pam, + libxcrypt, + nixosTests, +}: stdenv.mkDerivation rec { pname = "vsftpd"; @@ -9,7 +19,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-JrYCrkVLC6bZnvRKCba54N+n9nIoEGc23x8njHC8kdM="; }; - buildInputs = [ libcap openssl libseccomp pam libxcrypt ]; + buildInputs = [ + libcap + openssl + libseccomp + pam + libxcrypt + ]; patches = [ ./CVE-2015-1419.patch ]; diff --git a/pkgs/by-name/vs/vsh/package.nix b/pkgs/by-name/vs/vsh/package.nix index 9cfd9af7fc68a2..a5fce89e1c4c8d 100644 --- a/pkgs/by-name/vs/vsh/package.nix +++ b/pkgs/by-name/vs/vsh/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "vsh"; @@ -15,7 +19,11 @@ buildGoModule rec { vendorHash = null; # make sure version gets set at compile time - ldflags = [ "-s" "-w" "-X main.vshVersion=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.vshVersion=v${version}" + ]; meta = with lib; { description = "HashiCorp Vault interactive shell"; diff --git a/pkgs/by-name/vs/vsqlite/package.nix b/pkgs/by-name/vs/vsqlite/package.nix index 029e4c617f46c2..ed8db651f8b4df 100644 --- a/pkgs/by-name/vs/vsqlite/package.nix +++ b/pkgs/by-name/vs/vsqlite/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, boost, sqlite }: +{ + lib, + stdenv, + fetchurl, + boost, + sqlite, +}: stdenv.mkDerivation rec { pname = "vsqlite"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "17fkj0d2jh0xkjpcayhs1xvbnh1d69f026i7vs1zqnbiwbkpz237"; }; - buildInputs = [ boost sqlite ]; + buildInputs = [ + boost + sqlite + ]; prePatch = lib.optionalString stdenv.hostPlatform.isDarwin '' substituteInPlace Makefile.in \ diff --git a/pkgs/by-name/vt/vt-cli/package.nix b/pkgs/by-name/vt/vt-cli/package.nix index 83e88ed925a62b..7a377bbfb74b30 100644 --- a/pkgs/by-name/vt/vt-cli/package.nix +++ b/pkgs/by-name/vt/vt-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/vt/vtable-dumper/package.nix b/pkgs/by-name/vt/vtable-dumper/package.nix index 1bb01240a2a88c..ba63b8d51be2db 100644 --- a/pkgs/by-name/vt/vtable-dumper/package.nix +++ b/pkgs/by-name/vt/vtable-dumper/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libelf }: +{ + lib, + stdenv, + fetchFromGitHub, + libelf, +}: stdenv.mkDerivation rec { pname = "vtable-dumper"; diff --git a/pkgs/by-name/vt/vte/package.nix b/pkgs/by-name/vt/vte/package.nix index 84f3f9bc54a579..8d19671fc6c487 100644 --- a/pkgs/by-name/vt/vte/package.nix +++ b/pkgs/by-name/vt/vte/package.nix @@ -1,42 +1,45 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, gettext -, pkg-config -, meson -, ninja -, gnome -, glib -, gtk3 -, gtk4 -, gtkVersion ? "3" -, gobject-introspection -, vala -, python3 -, gi-docgen -, libxml2 -, gnutls -, gperf -, pango -, pcre2 -, cairo -, fribidi -, lz4 -, icu -, systemd -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd -, fast-float -, nixosTests -, blackbox-terminal +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + gettext, + pkg-config, + meson, + ninja, + gnome, + glib, + gtk3, + gtk4, + gtkVersion ? "3", + gobject-introspection, + vala, + python3, + gi-docgen, + libxml2, + gnutls, + gperf, + pango, + pcre2, + cairo, + fribidi, + lz4, + icu, + systemd, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, + fast-float, + nixosTests, + blackbox-terminal, }: stdenv.mkDerivation (finalAttrs: { pname = "vte"; version = "0.78.2"; - outputs = [ "out" "dev" ] - ++ lib.optional (gtkVersion != null) "devdoc"; + outputs = [ + "out" + "dev" + ] ++ lib.optional (gtkVersion != null) "devdoc"; src = fetchFromGitLab { domain = "gitlab.gnome.org"; @@ -87,41 +90,50 @@ stdenv.mkDerivation (finalAttrs: { gi-docgen ]; - buildInputs = [ - cairo - fribidi - gnutls - pango # duplicated with propagatedBuildInputs to support gtkVersion == null - pcre2 - lz4 - icu - fast-float - ] ++ lib.optionals systemdSupport [ - systemd - ]; + buildInputs = + [ + cairo + fribidi + gnutls + pango # duplicated with propagatedBuildInputs to support gtkVersion == null + pcre2 + lz4 + icu + fast-float + ] + ++ lib.optionals systemdSupport [ + systemd + ]; # Required by vte-2.91.pc. propagatedBuildInputs = lib.optionals (gtkVersion != null) [ - (assert (gtkVersion == "3" || gtkVersion == "4"); - if gtkVersion == "3" then gtk3 else gtk4) + ( + assert (gtkVersion == "3" || gtkVersion == "4"); + if gtkVersion == "3" then gtk3 else gtk4 + ) glib pango ]; - mesonFlags = [ - "-Ddocs=true" - (lib.mesonBool "gtk3" (gtkVersion == "3")) - (lib.mesonBool "gtk4" (gtkVersion == "4")) - ] ++ lib.optionals (!systemdSupport) [ - "-D_systemd=false" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # -Bsymbolic-functions is not supported on darwin - "-D_b_symbolic_functions=false" - ]; + mesonFlags = + [ + "-Ddocs=true" + (lib.mesonBool "gtk3" (gtkVersion == "3")) + (lib.mesonBool "gtk4" (gtkVersion == "4")) + ] + ++ lib.optionals (!systemdSupport) [ + "-D_systemd=false" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # -Bsymbolic-functions is not supported on darwin + "-D_b_symbolic_functions=false" + ]; # error: argument unused during compilation: '-pie' [-Werror,-Wunused-command-line-argument] - env.NIX_CFLAGS_COMPILE = toString (lib.optional stdenv.hostPlatform.isMusl "-Wno-unused-command-line-argument" - ++ lib.optional stdenv.cc.isClang "-Wno-cast-function-type-strict"); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optional stdenv.hostPlatform.isMusl "-Wno-unused-command-line-argument" + ++ lib.optional stdenv.cc.isClang "-Wno-cast-function-type-strict" + ); postPatch = '' patchShebangs perf/* @@ -141,7 +153,17 @@ stdenv.mkDerivation (finalAttrs: { versionPolicy = "odd-unstable"; }; tests = { - inherit (nixosTests.terminal-emulators) gnome-terminal lxterminal mlterm roxterm sakura stupidterm terminator termite xfce4-terminal; + inherit (nixosTests.terminal-emulators) + gnome-terminal + lxterminal + mlterm + roxterm + sakura + stupidterm + terminator + termite + xfce4-terminal + ; blackbox-terminal = blackbox-terminal.override { sixelSupport = true; }; }; }; @@ -158,7 +180,13 @@ stdenv.mkDerivation (finalAttrs: { the system's terminfo database. ''; license = licenses.lgpl3Plus; - maintainers = with maintainers; [ astsmtl antono ] ++ teams.gnome.members; + maintainers = + with maintainers; + [ + astsmtl + antono + ] + ++ teams.gnome.members; platforms = platforms.unix; }; }) diff --git a/pkgs/by-name/vt/vtm/package.nix b/pkgs/by-name/vt/vtm/package.nix index ce9c41638e16dc..9e321cf70845f2 100644 --- a/pkgs/by-name/vt/vtm/package.nix +++ b/pkgs/by-name/vt/vtm/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/vu/vue/package.nix b/pkgs/by-name/vu/vue/package.nix index 678aa886ce90f7..fc4b9bb4556469 100644 --- a/pkgs/by-name/vu/vue/package.nix +++ b/pkgs/by-name/vu/vue/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre, runtimeShell }: +{ + lib, + stdenv, + fetchurl, + jre, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "vue"; diff --git a/pkgs/by-name/vu/vul/package.nix b/pkgs/by-name/vu/vul/package.nix index 0e9b52e82d312a..de32d100994064 100644 --- a/pkgs/by-name/vu/vul/package.nix +++ b/pkgs/by-name/vu/vul/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "vul"; @@ -19,7 +23,10 @@ stdenv.mkDerivation rec { description = "Latin Vulgate Bible on the Command Line"; homepage = "https://github.com/LukeSmithxyz/vul"; license = licenses.publicDomain; - maintainers = [ maintainers.j0hax maintainers.cafkafk ]; + maintainers = [ + maintainers.j0hax + maintainers.cafkafk + ]; mainProgram = "vul"; }; } diff --git a/pkgs/by-name/vu/vulkan-extension-layer/package.nix b/pkgs/by-name/vu/vulkan-extension-layer/package.nix index 4b03e4e098f239..5abe48cbf00aa0 100644 --- a/pkgs/by-name/vu/vulkan-extension-layer/package.nix +++ b/pkgs/by-name/vu/vulkan-extension-layer/package.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, writeText, vulkan-headers, vulkan-utility-libraries, jq, libX11, libXrandr, libxcb, wayland }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + writeText, + vulkan-headers, + vulkan-utility-libraries, + jq, + libX11, + libXrandr, + libxcb, + wayland, +}: stdenv.mkDerivation rec { pname = "vulkan-extension-layer"; @@ -11,9 +25,20 @@ stdenv.mkDerivation rec { hash = "sha256-pBpHYxJq36FrHsvpaMJvX0IKTvAh0R86qR7/vn6EBCw="; }; - nativeBuildInputs = [ cmake pkg-config jq ]; + nativeBuildInputs = [ + cmake + pkg-config + jq + ]; - buildInputs = [ vulkan-headers vulkan-utility-libraries libX11 libXrandr libxcb wayland ]; + buildInputs = [ + vulkan-headers + vulkan-utility-libraries + libX11 + libXrandr + libxcb + wayland + ]; # Help vulkan-loader find the validation layers setupHook = writeText "setup-hook" '' @@ -39,6 +64,6 @@ stdenv.mkDerivation rec { homepage = "https://github.com/KhronosGroup/Vulkan-ExtensionLayer/"; platforms = platforms.linux; license = licenses.asl20; - maintainers = []; + maintainers = [ ]; }; } diff --git a/pkgs/by-name/vu/vulkan-helper/package.nix b/pkgs/by-name/vu/vulkan-helper/package.nix index 19e1d173499e3c..30dc0250943bc7 100644 --- a/pkgs/by-name/vu/vulkan-helper/package.nix +++ b/pkgs/by-name/vu/vulkan-helper/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, vulkan-loader -, addDriverRunpath +{ + lib, + rustPlatform, + fetchFromGitHub, + vulkan-loader, + addDriverRunpath, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/vu/vulkan-memory-allocator/package.nix b/pkgs/by-name/vu/vulkan-memory-allocator/package.nix index 41489f3b945856..a4205b5db8344b 100644 --- a/pkgs/by-name/vu/vulkan-memory-allocator/package.nix +++ b/pkgs/by-name/vu/vulkan-memory-allocator/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, fetchpatch -, cmake +{ + lib, + stdenvNoCC, + fetchFromGitHub, + fetchpatch, + cmake, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/vu/vulkan-tools-lunarg/package.nix b/pkgs/by-name/vu/vulkan-tools-lunarg/package.nix index 08236ab39a2c18..e8bac27836ebdc 100644 --- a/pkgs/by-name/vu/vulkan-tools-lunarg/package.nix +++ b/pkgs/by-name/vu/vulkan-tools-lunarg/package.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, python3 -, jq -, expat -, jsoncpp -, libX11 -, libXdmcp -, libXrandr -, libffi -, libxcb -, pkg-config -, wayland -, which -, xcbutilkeysyms -, xcbutilwm -, valijson -, vulkan-headers -, vulkan-loader -, vulkan-utility-libraries -, writeText -, libsForQt5 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, + jq, + expat, + jsoncpp, + libX11, + libXdmcp, + libXrandr, + libffi, + libxcb, + pkg-config, + wayland, + which, + xcbutilkeysyms, + xcbutilwm, + valijson, + vulkan-headers, + vulkan-loader, + vulkan-utility-libraries, + writeText, + libsForQt5, }: stdenv.mkDerivation rec { @@ -29,13 +30,20 @@ stdenv.mkDerivation rec { version = "1.3.296.0"; src = fetchFromGitHub { - owner = "LunarG"; - repo = "VulkanTools"; - rev = "vulkan-sdk-${version}"; - hash = "sha256-RaL7sqy5Rc8syPoM3SedZ6UilV9JUAA96JZh5/gIfPU="; - }; + owner = "LunarG"; + repo = "VulkanTools"; + rev = "vulkan-sdk-${version}"; + hash = "sha256-RaL7sqy5Rc8syPoM3SedZ6UilV9JUAA96JZh5/gIfPU="; + }; - nativeBuildInputs = [ cmake python3 jq which pkg-config libsForQt5.qt5.wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + python3 + jq + which + pkg-config + libsForQt5.qt5.wrapQtAppsHook + ]; buildInputs = [ expat @@ -88,6 +96,6 @@ stdenv.mkDerivation rec { homepage = "https://github.com/LunarG/VulkanTools"; platforms = platforms.linux; license = licenses.asl20; - maintainers = []; + maintainers = [ ]; }; } diff --git a/pkgs/by-name/vu/vulkan-utility-libraries/package.nix b/pkgs/by-name/vu/vulkan-utility-libraries/package.nix index 4c31f09958deb6..6d966b41716c61 100644 --- a/pkgs/by-name/vu/vulkan-utility-libraries/package.nix +++ b/pkgs/by-name/vu/vulkan-utility-libraries/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, python3, vulkan-headers }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, + vulkan-headers, +}: stdenv.mkDerivation (finalAttrs: { pname = "vulkan-utility-libraries"; @@ -11,7 +18,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-WDRDpUOZN/akUA6gsJMlC2GKolVt3g1NerKqe7aLhek="; }; - nativeBuildInputs = [ cmake python3 ]; + nativeBuildInputs = [ + cmake + python3 + ]; buildInputs = [ vulkan-headers ]; meta = with lib; { diff --git a/pkgs/by-name/vu/vulkan-validation-layers/package.nix b/pkgs/by-name/vu/vulkan-validation-layers/package.nix index ccf00646f57fee..9aaebeb5b4ed57 100644 --- a/pkgs/by-name/vu/vulkan-validation-layers/package.nix +++ b/pkgs/by-name/vu/vulkan-validation-layers/package.nix @@ -1,26 +1,27 @@ -{ lib -, callPackage -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, jq -, glslang -, libffi -, libX11 -, libXau -, libxcb -, libXdmcp -, libXrandr -, spirv-headers -, spirv-tools -, vulkan-headers -, vulkan-utility-libraries -, wayland +{ + lib, + callPackage, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + jq, + glslang, + libffi, + libX11, + libXau, + libxcb, + libXdmcp, + libXrandr, + spirv-headers, + spirv-tools, + vulkan-headers, + vulkan-utility-libraries, + wayland, }: let - robin-hood-hashing = callPackage ./robin-hood-hashing.nix {}; + robin-hood-hashing = callPackage ./robin-hood-hashing.nix { }; in stdenv.mkDerivation rec { pname = "vulkan-validation-layers"; @@ -80,9 +81,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Official Khronos Vulkan validation layers"; - homepage = "https://github.com/KhronosGroup/Vulkan-ValidationLayers"; - platforms = platforms.linux; - license = licenses.asl20; + homepage = "https://github.com/KhronosGroup/Vulkan-ValidationLayers"; + platforms = platforms.linux; + license = licenses.asl20; maintainers = [ maintainers.ralith ]; }; } diff --git a/pkgs/by-name/vu/vulkan-validation-layers/robin-hood-hashing.nix b/pkgs/by-name/vu/vulkan-validation-layers/robin-hood-hashing.nix index 9951d63b019cdc..3b36912bc5f7b8 100644 --- a/pkgs/by-name/vu/vulkan-validation-layers/robin-hood-hashing.nix +++ b/pkgs/by-name/vu/vulkan-validation-layers/robin-hood-hashing.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake +{ + stdenv, + lib, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { @@ -25,9 +26,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Faster, more efficient replacement for std::unordered_map / std::unordered_set"; - homepage = "https://github.com/martinus/robin-hood-hashing"; - platforms = platforms.linux; - license = licenses.mit; + homepage = "https://github.com/martinus/robin-hood-hashing"; + platforms = platforms.linux; + license = licenses.mit; maintainers = [ ]; }; } diff --git a/pkgs/by-name/vu/vulkan-volk/package.nix b/pkgs/by-name/vu/vulkan-volk/package.nix index 53f8b8b802d679..8e511707dd96aa 100644 --- a/pkgs/by-name/vu/vulkan-volk/package.nix +++ b/pkgs/by-name/vu/vulkan-volk/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, vulkan-headers }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + vulkan-headers, +}: stdenv.mkDerivation (finalAttrs: { pname = "volk"; @@ -14,7 +20,7 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ cmake ]; buildInputs = [ vulkan-headers ]; - cmakeFlags = ["-DVOLK_INSTALL=1"]; + cmakeFlags = [ "-DVOLK_INSTALL=1" ]; meta = with lib; { description = " Meta loader for Vulkan API"; diff --git a/pkgs/by-name/vu/vulnix/package.nix b/pkgs/by-name/vu/vulnix/package.nix index 7388d8278ed06c..e124fffbbe074c 100644 --- a/pkgs/by-name/vu/vulnix/package.nix +++ b/pkgs/by-name/vu/vulnix/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3Packages -, fetchFromGitHub -, nix -, ronn +{ + lib, + python3Packages, + fetchFromGitHub, + nix, + ronn, }: python3Packages.buildPythonApplication rec { @@ -21,7 +22,11 @@ python3Packages.buildPythonApplication rec { --replace "--flake8" "" ''; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; nativeBuildInputs = [ ronn ]; nativeCheckInputs = with python3Packages; [ @@ -30,17 +35,19 @@ python3Packages.buildPythonApplication rec { pytest-cov ]; - propagatedBuildInputs = [ - nix - ] ++ (with python3Packages; [ - click - colorama - pyyaml - requests - setuptools - toml - zodb - ]); + propagatedBuildInputs = + [ + nix + ] + ++ (with python3Packages; [ + click + colorama + pyyaml + requests + setuptools + toml + zodb + ]); postBuild = "make -C doc"; diff --git a/pkgs/by-name/vu/vultr-cli/package.nix b/pkgs/by-name/vu/vultr-cli/package.nix index b312ac66e3f027..a69bce393302ad 100644 --- a/pkgs/by-name/vu/vultr-cli/package.nix +++ b/pkgs/by-name/vu/vultr-cli/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "vultr-cli"; @@ -15,7 +21,10 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' installShellCompletion --cmd vultr-cli \ diff --git a/pkgs/by-name/vu/vultr/package.nix b/pkgs/by-name/vu/vultr/package.nix index e7f600b9765fcb..705382d7dea9dd 100644 --- a/pkgs/by-name/vu/vultr/package.nix +++ b/pkgs/by-name/vu/vultr/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/vv/vvvvvv/package.nix b/pkgs/by-name/vv/vvvvvv/package.nix index 471a84eecb892a..9b6cf47c8fdf65 100644 --- a/pkgs/by-name/vv/vvvvvv/package.nix +++ b/pkgs/by-name/vv/vvvvvv/package.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchurl -, cmake -, makeWrapper -, copyDesktopItems -, makeDesktopItem -, faudio -, physfs -, SDL2 -, tinyxml-2 -, Foundation -, IOKit -, makeAndPlay ? false +{ + stdenv, + lib, + fetchFromGitHub, + fetchurl, + cmake, + makeWrapper, + copyDesktopItems, + makeDesktopItem, + faudio, + physfs, + SDL2, + tinyxml-2, + Foundation, + IOKit, + makeAndPlay ? false, }: stdenv.mkDerivation rec { @@ -40,12 +41,17 @@ stdenv.mkDerivation rec { copyDesktopItems ]; - buildInputs = [ - faudio - physfs - SDL2 - tinyxml-2 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Foundation IOKit ]; + buildInputs = + [ + faudio + physfs + SDL2 + tinyxml-2 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Foundation + IOKit + ]; cmakeDir = "../desktop_version"; @@ -83,13 +89,17 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = "A retro-styled platform game" + lib.optionalString makeAndPlay " (redistributable, without original levels)"; - longDescription = '' - VVVVVV is a platform game all about exploring one simple mechanical - idea - what if you reversed gravity instead of jumping? - '' + lib.optionalString makeAndPlay '' - (Redistributable version, doesn't include the original levels.) - ''; + description = + "A retro-styled platform game" + + lib.optionalString makeAndPlay " (redistributable, without original levels)"; + longDescription = + '' + VVVVVV is a platform game all about exploring one simple mechanical + idea - what if you reversed gravity instead of jumping? + '' + + lib.optionalString makeAndPlay '' + (Redistributable version, doesn't include the original levels.) + ''; homepage = "https://thelettervsixtim.es"; changelog = "https://github.com/TerryCavanagh/VVVVVV/releases/tag/${src.rev}"; license = licenses.unfree; diff --git a/pkgs/by-name/vw/vwm/package.nix b/pkgs/by-name/vw/vwm/package.nix index 0560bb214ba2fe..3bd8bedd80876b 100644 --- a/pkgs/by-name/vw/vwm/package.nix +++ b/pkgs/by-name/vw/vwm/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, ncurses -, pkg-config -, glib -, libviper -, libpseudo -, gpm -, libvterm +{ + lib, + stdenv, + fetchurl, + ncurses, + pkg-config, + glib, + libviper, + libpseudo, + gpm, + libvterm, }: stdenv.mkDerivation rec { @@ -36,7 +37,14 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ ncurses glib libviper libpseudo gpm libvterm ]; + buildInputs = [ + ncurses + glib + libviper + libpseudo + gpm + libvterm + ]; meta = with lib; { homepage = "https://vwm.sourceforge.net/"; diff --git a/pkgs/by-name/vx/vxl/package.nix b/pkgs/by-name/vx/vxl/package.nix index 9ee55b47d4574b..f652dc421c20fe 100644 --- a/pkgs/by-name/vx/vxl/package.nix +++ b/pkgs/by-name/vx/vxl/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, unzip -, cmake -, libtiff -, expat -, zlib -, libpng -, libjpeg +{ + lib, + stdenv, + fetchFromGitHub, + unzip, + cmake, + libtiff, + expat, + zlib, + libpng, + libjpeg, }: stdenv.mkDerivation (finalAttrs: { @@ -34,7 +35,9 @@ stdenv.mkDerivation (finalAttrs: { ]; # test failure on aarch64-linux; unknown reason: - cmakeFlags = lib.optionals stdenv.hostPlatform.isAarch64 [ "-DCMAKE_CTEST_ARGUMENTS='-E vgl_test_frustum_3d'" ]; + cmakeFlags = lib.optionals stdenv.hostPlatform.isAarch64 [ + "-DCMAKE_CTEST_ARGUMENTS='-E vgl_test_frustum_3d'" + ]; doCheck = true; diff --git a/pkgs/by-name/w3/w3m/package.nix b/pkgs/by-name/w3/w3m/package.nix index 8ea48ffbad9941..fab906a9f194a1 100644 --- a/pkgs/by-name/w3/w3m/package.nix +++ b/pkgs/by-name/w3/w3m/package.nix @@ -1,24 +1,44 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, ncurses, boehmgc, gettext, zlib -, sslSupport ? true, openssl -, graphicsSupport ? !stdenv.hostPlatform.isDarwin, imlib2 -, x11Support ? graphicsSupport, libX11 -, mouseSupport ? !stdenv.hostPlatform.isDarwin, gpm-ncurses -, perl, man, pkg-config, buildPackages, w3m -, testers, updateAutotoolsGnuConfigScriptsHook +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + ncurses, + boehmgc, + gettext, + zlib, + sslSupport ? true, + openssl, + graphicsSupport ? !stdenv.hostPlatform.isDarwin, + imlib2, + x11Support ? graphicsSupport, + libX11, + mouseSupport ? !stdenv.hostPlatform.isDarwin, + gpm-ncurses, + perl, + man, + pkg-config, + buildPackages, + w3m, + testers, + updateAutotoolsGnuConfigScriptsHook, }: let mktable = buildPackages.stdenv.mkDerivation { name = "w3m-mktable"; inherit (w3m) src; - nativeBuildInputs = [ pkg-config boehmgc ]; + nativeBuildInputs = [ + pkg-config + boehmgc + ]; makeFlags = [ "mktable" ]; installPhase = '' install -D mktable $out/bin/mktable ''; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "w3m"; version = "0.5.3+git20230121"; @@ -55,8 +75,17 @@ in stdenv.mkDerivation rec { # updateAutotoolsGnuConfigScriptsHook necessary to build on FreeBSD native pending inclusion of # https://git.savannah.gnu.org/cgit/config.git/commit/?id=e4786449e1c26716e3f9ea182caf472e4dbc96e0 - nativeBuildInputs = [ pkg-config gettext updateAutotoolsGnuConfigScriptsHook ]; - buildInputs = [ ncurses boehmgc zlib ] + nativeBuildInputs = [ + pkg-config + gettext + updateAutotoolsGnuConfigScriptsHook + ]; + buildInputs = + [ + ncurses + boehmgc + zlib + ] ++ lib.optional sslSupport openssl ++ lib.optional mouseSupport gpm-ncurses ++ lib.optional graphicsSupport imlib2 @@ -69,7 +98,10 @@ in stdenv.mkDerivation rec { hardeningDisable = [ "format" ]; configureFlags = - [ "--with-ssl=${openssl.dev}" "--with-gc=${boehmgc.dev}" ] + [ + "--with-ssl=${openssl.dev}" + "--with-gc=${boehmgc.dev}" + ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ "ac_cv_func_setpgrp_void=yes" ] diff --git a/pkgs/by-name/w_/w_scan/package.nix b/pkgs/by-name/w_/w_scan/package.nix index 4dedf71d39bf25..8e55ea37627756 100644 --- a/pkgs/by-name/w_/w_scan/package.nix +++ b/pkgs/by-name/w_/w_scan/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "w_scan"; @@ -18,7 +22,7 @@ stdenv.mkDerivation rec { description = "Small CLI utility to scan DVB and ATSC transmissions"; homepage = "http://wirbel.htpc-forum.de/w_scan/index_en.html"; platforms = lib.platforms.linux; - maintainers = [ lib.maintainers.nico202 ] ; + maintainers = [ lib.maintainers.nico202 ]; license = lib.licenses.gpl2; mainProgram = "w_scan"; }; diff --git a/pkgs/by-name/w_/w_scan2/package.nix b/pkgs/by-name/w_/w_scan2/package.nix index e20330d0ea3b8d..d852059bc19e3a 100644 --- a/pkgs/by-name/w_/w_scan2/package.nix +++ b/pkgs/by-name/w_/w_scan2/package.nix @@ -19,7 +19,7 @@ stdenv.mkDerivation rec { description = "Small channel scan tool which generates ATSC, DVB-C, DVB-S/S2 and DVB-T/T2 channels.conf files"; homepage = "https://github.com/stefantalpalaru/w_scan2"; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ _0x4A6F ] ; + maintainers = with lib.maintainers; [ _0x4A6F ]; license = lib.licenses.gpl2Only; mainProgram = "w_scan2"; }; diff --git a/pkgs/by-name/wa/wabt/package.nix b/pkgs/by-name/wa/wabt/package.nix index f2be63608b6974..fd764b2b29cf1e 100644 --- a/pkgs/by-name/wa/wabt/package.nix +++ b/pkgs/by-name/wa/wabt/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "wabt"; @@ -13,7 +18,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - cmakeFlags = [ "-DBUILD_TESTS=OFF" "-DCMAKE_PROJECT_VERSION=${version}" ]; + cmakeFlags = [ + "-DBUILD_TESTS=OFF" + "-DCMAKE_PROJECT_VERSION=${version}" + ]; meta = with lib; { description = "WebAssembly Binary Toolkit"; diff --git a/pkgs/by-name/wa/wad/package.nix b/pkgs/by-name/wa/wad/package.nix index 348a35ccbe10d3..c1e21ab8261afb 100644 --- a/pkgs/by-name/wa/wad/package.nix +++ b/pkgs/by-name/wa/wad/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -39,7 +40,10 @@ python3.pkgs.buildPythonApplication rec { ''; homepage = "https://github.com/CERN-CERT/WAD"; # wad is GPLv3+, wappalyzer source is MIT - license = with licenses; [ gpl3Plus mit ]; + license = with licenses; [ + gpl3Plus + mit + ]; maintainers = with maintainers; [ fab ]; }; } diff --git a/pkgs/by-name/wa/waf-tester/package.nix b/pkgs/by-name/wa/waf-tester/package.nix index 47e5c2fbb5fb47..c74f0af8b151df 100644 --- a/pkgs/by-name/wa/waf-tester/package.nix +++ b/pkgs/by-name/wa/waf-tester/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, waf-tester +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + waf-tester, }: buildGoModule rec { diff --git a/pkgs/by-name/wa/waf/hook.nix b/pkgs/by-name/wa/waf/hook.nix index 37757aec18888b..0855f0ce0a3199 100644 --- a/pkgs/by-name/wa/waf/hook.nix +++ b/pkgs/by-name/wa/waf/hook.nix @@ -1,5 +1,6 @@ -{ makeSetupHook -, waf +{ + makeSetupHook, + waf, }: makeSetupHook { diff --git a/pkgs/by-name/wa/waffle/package.nix b/pkgs/by-name/wa/waffle/package.nix index b92011c967df9f..4433e4c057c0d5 100644 --- a/pkgs/by-name/wa/waffle/package.nix +++ b/pkgs/by-name/wa/waffle/package.nix @@ -1,18 +1,26 @@ -{ stdenv -, fetchFromGitLab -, lib -, cmake -, meson -, ninja -, bash-completion -, libGL -, libglvnd -, makeWrapper -, pkg-config -, python3 -, x11Support ? true, libxcb, libX11 -, waylandSupport ? true, wayland, wayland-protocols, wayland-scanner -, useGbm ? true, mesa, udev +{ + stdenv, + fetchFromGitLab, + lib, + cmake, + meson, + ninja, + bash-completion, + libGL, + libglvnd, + makeWrapper, + pkg-config, + python3, + x11Support ? true, + libxcb, + libX11, + waylandSupport ? true, + wayland, + wayland-protocols, + wayland-scanner, + useGbm ? true, + mesa, + udev, }: stdenv.mkDerivation rec { @@ -27,42 +35,54 @@ stdenv.mkDerivation rec { sha256 = "sha256-Y7GRYLqSO572qA1eZ3jS8QlZ1X9xKpDtScaySTuPK/U="; }; - buildInputs = [ - bash-completion - libGL - ] ++ lib.optionals (with stdenv.hostPlatform; isUnix && !isDarwin) [ - libglvnd - ] ++ lib.optionals x11Support [ - libX11 - libxcb - ] ++ lib.optionals waylandSupport [ - wayland - wayland-protocols - ] ++ lib.optionals useGbm [ - udev - mesa - ]; + buildInputs = + [ + bash-completion + libGL + ] + ++ lib.optionals (with stdenv.hostPlatform; isUnix && !isDarwin) [ + libglvnd + ] + ++ lib.optionals x11Support [ + libX11 + libxcb + ] + ++ lib.optionals waylandSupport [ + wayland + wayland-protocols + ] + ++ lib.optionals useGbm [ + udev + mesa + ]; depsBuildBuild = [ pkg-config ]; dontUseCmakeConfigure = true; - nativeBuildInputs = [ - cmake - makeWrapper - meson - ninja - pkg-config - python3 - ] ++ lib.optionals waylandSupport [ - wayland-scanner - ]; + nativeBuildInputs = + [ + cmake + makeWrapper + meson + ninja + pkg-config + python3 + ] + ++ lib.optionals waylandSupport [ + wayland-scanner + ]; - PKG_CONFIG_BASH_COMPLETION_COMPLETIONSDIR= "${placeholder "out"}/share/bash-completion/completions"; + PKG_CONFIG_BASH_COMPLETION_COMPLETIONSDIR = "${placeholder "out"}/share/bash-completion/completions"; postInstall = '' wrapProgram $out/bin/wflinfo \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ libGL libglvnd ]} + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + libGL + libglvnd + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/wa/wait4x/package.nix b/pkgs/by-name/wa/wait4x/package.nix index ab8176d6d42fb3..53be1b07c4fa75 100644 --- a/pkgs/by-name/wa/wait4x/package.nix +++ b/pkgs/by-name/wa/wait4x/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: let pname = "wait4x"; diff --git a/pkgs/by-name/wa/waitron/package.nix b/pkgs/by-name/wa/waitron/package.nix index d0dd8a6a17dedd..c72a117c772cc8 100644 --- a/pkgs/by-name/wa/waitron/package.nix +++ b/pkgs/by-name/wa/waitron/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -31,7 +32,7 @@ buildGoModule rec { specified inventory sources. ''; homepage = "https://github.com/ns1/waitron"; - license = licenses.asl20; + license = licenses.asl20; maintainers = with maintainers; [ guibert ]; platforms = platforms.linux; broken = true; # vendor isn't reproducible with go > 1.17: nix-build -A $name.goModules --check diff --git a/pkgs/by-name/wa/wakelan/package.nix b/pkgs/by-name/wa/wakelan/package.nix index a0c4f832fc08c0..674c8270004ac8 100644 --- a/pkgs/by-name/wa/wakelan/package.nix +++ b/pkgs/by-name/wa/wakelan/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "wakelan"; @@ -22,7 +26,7 @@ stdenv.mkDerivation rec { WakeLan sends a properly formatted UDP packet across the network which will cause a wake-on-lan enabled computer to power on. - ''; + ''; license = lib.licenses.gpl2Plus; maintainers = [ ]; platforms = lib.platforms.unix; diff --git a/pkgs/by-name/wa/wakeonlan/package.nix b/pkgs/by-name/wa/wakeonlan/package.nix index f3f222d5ad6419..7a5c51ed39957b 100644 --- a/pkgs/by-name/wa/wakeonlan/package.nix +++ b/pkgs/by-name/wa/wakeonlan/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, perlPackages, fetchFromGitHub, installShellFiles, shortenPerlShebang }: +{ + lib, + stdenv, + perlPackages, + fetchFromGitHub, + installShellFiles, + shortenPerlShebang, +}: perlPackages.buildPerlPackage rec { pname = "wakeonlan"; @@ -13,20 +20,28 @@ perlPackages.buildPerlPackage rec { outputs = [ "out" ]; - nativeBuildInputs = [ installShellFiles ] ++ lib.optional stdenv.hostPlatform.isDarwin shortenPerlShebang; + nativeBuildInputs = [ + installShellFiles + ] ++ lib.optional stdenv.hostPlatform.isDarwin shortenPerlShebang; - nativeCheckInputs = [ perlPackages.TestPerlCritic perlPackages.TestPod perlPackages.TestPodCoverage ]; + nativeCheckInputs = [ + perlPackages.TestPerlCritic + perlPackages.TestPod + perlPackages.TestPodCoverage + ]; # Linting and formatting checks are of no interest for us. preCheck = '' rm -f t/93_pod_spell.t ''; - installPhase = '' - install -Dt $out/bin wakeonlan - installManPage blib/man1/wakeonlan.1 - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - shortenPerlShebang $out/bin/wakeonlan - ''; + installPhase = + '' + install -Dt $out/bin wakeonlan + installManPage blib/man1/wakeonlan.1 + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + shortenPerlShebang $out/bin/wakeonlan + ''; meta = with lib; { description = "Perl script for waking up computers via Wake-On-LAN magic packets"; diff --git a/pkgs/by-name/wa/wal-g/package.nix b/pkgs/by-name/wa/wal-g/package.nix index 203a5cbc26f5cc..2a01a12c273483 100644 --- a/pkgs/by-name/wa/wal-g/package.nix +++ b/pkgs/by-name/wa/wal-g/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, brotli, libsodium, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + brotli, + libsodium, + installShellFiles, +}: buildGoModule rec { pname = "wal-g"; @@ -15,13 +22,24 @@ buildGoModule rec { nativeBuildInputs = [ installShellFiles ]; - buildInputs = [ brotli libsodium ]; + buildInputs = [ + brotli + libsodium + ]; subPackages = [ "main/pg" ]; - tags = [ "brotli" "libsodium" ]; - - ldflags = [ "-s" "-w" "-X github.com/wal-g/wal-g/cmd/pg.walgVersion=${version}" "-X github.com/wal-g/wal-g/cmd/pg.gitRevision=${src.rev}" ]; + tags = [ + "brotli" + "libsodium" + ]; + + ldflags = [ + "-s" + "-w" + "-X github.com/wal-g/wal-g/cmd/pg.walgVersion=${version}" + "-X github.com/wal-g/wal-g/cmd/pg.gitRevision=${src.rev}" + ]; postInstall = '' mv $out/bin/pg $out/bin/wal-g diff --git a/pkgs/by-name/wa/walk/package.nix b/pkgs/by-name/wa/walk/package.nix index 6e5e69a1062264..46d9d91300e9ea 100644 --- a/pkgs/by-name/wa/walk/package.nix +++ b/pkgs/by-name/wa/walk/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "walk"; @@ -17,7 +21,10 @@ buildGoModule rec { description = "Terminal file manager"; homepage = "https://github.com/antonmedv/walk"; license = licenses.mit; - maintainers = with maintainers; [ portothree surfaceflinger ]; + maintainers = with maintainers; [ + portothree + surfaceflinger + ]; mainProgram = "walk"; }; } diff --git a/pkgs/by-name/wa/wallust/package.nix b/pkgs/by-name/wa/wallust/package.nix index adb5c25302c081..d61c2e153e4bb1 100644 --- a/pkgs/by-name/wa/wallust/package.nix +++ b/pkgs/by-name/wa/wallust/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitea -, rustPlatform -, nix-update-script -, imagemagick -, makeWrapper -, installShellFiles +{ + lib, + fetchFromGitea, + rustPlatform, + nix-update-script, + imagemagick, + makeWrapper, + installShellFiles, }: let version = "3.1.0"; @@ -23,7 +24,10 @@ rustPlatform.buildRustPackage { cargoHash = "sha256-SEaq0qeWuDeIeCqz9imb5nV4WK44CF5wIwG62nhyqlU="; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; postInstall = '' installManPage man/wallust* @@ -44,7 +48,10 @@ rustPlatform.buildRustPackage { description = "Better pywal"; homepage = "https://codeberg.org/explosion-mental/wallust"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ onemoresuza iynaix ]; + maintainers = with lib.maintainers; [ + onemoresuza + iynaix + ]; downloadPage = "https://codeberg.org/explosion-mental/wallust/releases/tag/${version}"; mainProgram = "wallust"; }; diff --git a/pkgs/by-name/wa/wallutils/package.nix b/pkgs/by-name/wa/wallutils/package.nix index 1877832b59cc30..798bb88277365f 100644 --- a/pkgs/by-name/wa/wallutils/package.nix +++ b/pkgs/by-name/wa/wallutils/package.nix @@ -1,14 +1,15 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, libX11 -, libXcursor -, libXmu -, libXpm -, libheif -, pkg-config -, wayland -, xbitmaps +{ + lib, + buildGoModule, + fetchFromGitHub, + libX11, + libXcursor, + libXmu, + libXpm, + libheif, + pkg-config, + wayland, + xbitmaps, }: buildGoModule rec { @@ -46,7 +47,10 @@ buildGoModule rec { xbitmaps ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; preCheck = '' export XDG_RUNTIME_DIR=$(mktemp -d) diff --git a/pkgs/by-name/wa/wally-cli/package.nix b/pkgs/by-name/wa/wally-cli/package.nix index a608b42dc0d571..6d65c6c5ea4cb2 100644 --- a/pkgs/by-name/wa/wally-cli/package.nix +++ b/pkgs/by-name/wa/wally-cli/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, pkg-config, libusb1 }: +{ + lib, + buildGoModule, + fetchFromGitHub, + pkg-config, + libusb1, +}: buildGoModule rec { pname = "wally-cli"; @@ -25,6 +31,9 @@ buildGoModule rec { homepage = "https://ergodox-ez.com/pages/wally-planck"; platforms = with platforms; linux ++ darwin; license = licenses.mit; - maintainers = with maintainers; [ spacekookie r-burns ]; + maintainers = with maintainers; [ + spacekookie + r-burns + ]; }; } diff --git a/pkgs/by-name/wa/wambo/package.nix b/pkgs/by-name/wa/wambo/package.nix index e700bdbbeb2a28..086ac05656e0f3 100644 --- a/pkgs/by-name/wa/wambo/package.nix +++ b/pkgs/by-name/wa/wambo/package.nix @@ -1,6 +1,7 @@ -{ fetchCrate -, lib -, rustPlatform +{ + fetchCrate, + lib, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/wa/wander/package.nix b/pkgs/by-name/wa/wander/package.nix index 6ad6854fc23250..db55f3ce2c27b1 100644 --- a/pkgs/by-name/wa/wander/package.nix +++ b/pkgs/by-name/wa/wander/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "wander"; @@ -13,7 +18,10 @@ buildGoModule rec { vendorHash = "sha256-0S8tzP5yNUrH6fp+v7nbUPTMWzYXyGw+ZNcXkSN+tWY="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeBuildInputs = [ installShellFiles ]; diff --git a/pkgs/by-name/wa/wannier90/package.nix b/pkgs/by-name/wa/wannier90/package.nix index 9a06bc5faabf68..631fcd276de426 100644 --- a/pkgs/by-name/wa/wannier90/package.nix +++ b/pkgs/by-name/wa/wannier90/package.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, gfortran -, blas -, lapack -, python3 -, fetchFromGitHub +{ + stdenv, + lib, + gfortran, + blas, + lapack, + python3, + fetchFromGitHub, }: assert (!blas.isILP64); assert blas.isILP64 == lapack.isILP64; @@ -37,7 +38,10 @@ stdenv.mkDerivation rec { cp config/make.inc.gfort make.inc ''; - buildFlags = [ "all" "dynlib" ]; + buildFlags = [ + "all" + "dynlib" + ]; preInstall = '' installFlagsArray+=( diff --git a/pkgs/by-name/wa/waon/package.nix b/pkgs/by-name/wa/waon/package.nix index b1f66798dd9c74..b84487479af251 100644 --- a/pkgs/by-name/wa/waon/package.nix +++ b/pkgs/by-name/wa/waon/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fftw, gtk2, libao, libsamplerate -, libsndfile, ncurses, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + fftw, + gtk2, + libao, + libsamplerate, + libsndfile, + ncurses, + pkg-config, }: stdenv.mkDerivation rec { @@ -14,7 +23,14 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ fftw gtk2 libao libsamplerate libsndfile ncurses ]; + buildInputs = [ + fftw + gtk2 + libao + libsamplerate + libsndfile + ncurses + ]; installPhase = '' install -Dt $out/bin waon pv gwaon diff --git a/pkgs/by-name/wa/wapm/package.nix b/pkgs/by-name/wa/wapm/package.nix index 420baa5baeb353..017928c610bdeb 100644 --- a/pkgs/by-name/wa/wapm/package.nix +++ b/pkgs/by-name/wa/wapm/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, perl -, libiconv -, openssl -, rustPlatform -, stdenv -, darwin +{ + lib, + fetchFromGitHub, + perl, + libiconv, + openssl, + rustPlatform, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -23,8 +24,18 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ perl ]; - buildInputs = [ libiconv openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ Security SystemConfiguration ]); + buildInputs = + [ + libiconv + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Security + SystemConfiguration + ] + ); doCheck = false; diff --git a/pkgs/by-name/wa/wargus/package.nix b/pkgs/by-name/wa/wargus/package.nix index ca4b70923eca58..7618dff32643b1 100644 --- a/pkgs/by-name/wa/wargus/package.nix +++ b/pkgs/by-name/wa/wargus/package.nix @@ -1,29 +1,51 @@ -{ stdenv, lib, callPackage, fetchFromGitHub -, fetchurl, runCommand, unzip, bchunk, p7zip -, cmake, pkg-config, makeWrapper -, zlib, bzip2, libpng -, dialog, python3, cdparanoia, ffmpeg +{ + stdenv, + lib, + callPackage, + fetchFromGitHub, + fetchurl, + runCommand, + unzip, + bchunk, + p7zip, + cmake, + pkg-config, + makeWrapper, + zlib, + bzip2, + libpng, + dialog, + python3, + cdparanoia, + ffmpeg, }: let - stratagus = callPackage ./stratagus.nix {}; + stratagus = callPackage ./stratagus.nix { }; dataDownload = fetchurl { url = "https://archive.org/download/warcraft-ii-tides-of-darkness_202105/Warcess.zip"; sha256 = "0yxgvf8xpv1w2bjmny4a38pa3xcdgqckk9abj21ilkc5zqzqmm9b"; }; - data = runCommand "warcraft2" { - buildInputs = [ unzip bchunk p7zip ]; - meta.license = lib.licenses.unfree; - } '' - unzip ${dataDownload} "Warcraft.II.Tides.of.Darkness/Warcraft II - Tides of Darkness (1995)/games/WarcrafD/cd/"{WC2BTDP.img,WC2BTDP.cue} - bchunk "Warcraft.II.Tides.of.Darkness/Warcraft II - Tides of Darkness (1995)/games/WarcrafD/cd/"{WC2BTDP.img,WC2BTDP.cue} WC2BTDP - rm -r Warcraft.II.Tides.of.Darkness - 7z x WC2BTDP01.iso - rm WC2BTDP*.{iso,cdr} - cp -r DATA $out - ''; + data = + runCommand "warcraft2" + { + buildInputs = [ + unzip + bchunk + p7zip + ]; + meta.license = lib.licenses.unfree; + } + '' + unzip ${dataDownload} "Warcraft.II.Tides.of.Darkness/Warcraft II - Tides of Darkness (1995)/games/WarcrafD/cd/"{WC2BTDP.img,WC2BTDP.cue} + bchunk "Warcraft.II.Tides.of.Darkness/Warcraft II - Tides of Darkness (1995)/games/WarcrafD/cd/"{WC2BTDP.img,WC2BTDP.cue} WC2BTDP + rm -r Warcraft.II.Tides.of.Darkness + 7z x WC2BTDP01.iso + rm WC2BTDP*.{iso,cdr} + cp -r DATA $out + ''; in stdenv.mkDerivation rec { @@ -37,8 +59,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-yJeMFxCD0ikwVPQApf+IBuMQ6eOjn1fVKNmqh6r760c="; }; - nativeBuildInputs = [ cmake pkg-config makeWrapper ffmpeg ]; - buildInputs = [ zlib bzip2 libpng ]; + nativeBuildInputs = [ + cmake + pkg-config + makeWrapper + ffmpeg + ]; + buildInputs = [ + zlib + bzip2 + libpng + ]; cmakeFlags = [ "-DSTRATAGUS=${stratagus}/games/stratagus" "-DSTRATAGUS_INCLUDE_DIR=${stratagus.src}/gameheaders" diff --git a/pkgs/by-name/wa/wargus/stratagus.nix b/pkgs/by-name/wa/wargus/stratagus.nix index fc4f2342799450..69baa283fa046d 100644 --- a/pkgs/by-name/wa/wargus/stratagus.nix +++ b/pkgs/by-name/wa/wargus/stratagus.nix @@ -1,7 +1,19 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, pkg-config, makeWrapper -, zlib, bzip2, libpng, lua5_1, toluapp -, SDL2, SDL2_mixer, SDL2_image, libGL +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + makeWrapper, + zlib, + bzip2, + libpng, + lua5_1, + toluapp, + SDL2, + SDL2_mixer, + SDL2_image, + libGL, }: stdenv.mkDerivation rec { @@ -15,11 +27,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-q8AvIWr/bOzI0wV0D2emxIXYEKDYmFxbtwr2BS+xYfA="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ - zlib bzip2 libpng - lua5_1 toluapp - (lib.getDev SDL2) SDL2_image SDL2_mixer libGL + zlib + bzip2 + libpng + lua5_1 + toluapp + (lib.getDev SDL2) + SDL2_image + SDL2_mixer + libGL ]; cmakeFlags = [ "-DCMAKE_CXX_FLAGS=-Wno-error=format-overflow" diff --git a/pkgs/by-name/wa/warmux/package.nix b/pkgs/by-name/wa/warmux/package.nix index 368f0d39e9c29d..c3115ad02d7e79 100644 --- a/pkgs/by-name/wa/warmux/package.nix +++ b/pkgs/by-name/wa/warmux/package.nix @@ -1,7 +1,29 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake -, zlib, curl, gnutls, fribidi, libpng, SDL, SDL_gfx, SDL_image, SDL_mixer -, SDL_net, SDL_ttf, libunwind, libX11, xorgproto, libxml2, pkg-config -, gettext, intltool, libtool, perl +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + zlib, + curl, + gnutls, + fribidi, + libpng, + SDL, + SDL_gfx, + SDL_image, + SDL_mixer, + SDL_net, + SDL_ttf, + libunwind, + libX11, + xorgproto, + libxml2, + pkg-config, + gettext, + intltool, + libtool, + perl, }: stdenv.mkDerivation { @@ -18,14 +40,33 @@ stdenv.mkDerivation { __structuredAttrs = true; preConfigure = "patchShebangs autogen.sh && ./autogen.sh"; - configureFlags = ["CFLAGS=-include ${zlib.dev}/include/zlib.h"]; + configureFlags = [ "CFLAGS=-include ${zlib.dev}/include/zlib.h" ]; nativeBuildInputs = [ - autoconf automake gettext intltool libtool pkg-config + autoconf + automake + gettext + intltool + libtool + pkg-config ]; buildInputs = [ - zlib curl gnutls fribidi libpng SDL SDL_gfx SDL_image SDL_mixer - SDL_net SDL_ttf libunwind libX11 xorgproto libxml2 perl + zlib + curl + gnutls + fribidi + libpng + SDL + SDL_gfx + SDL_image + SDL_mixer + SDL_net + SDL_ttf + libunwind + libX11 + xorgproto + libxml2 + perl ]; enableParallelBuilding = true; @@ -33,7 +74,10 @@ stdenv.mkDerivation { description = "Ballistics turn-based battle game between teams - unofficial copy"; maintainers = with maintainers; [ raskin ]; platforms = platforms.linux; - license = with licenses; [ gpl2Plus ufl ]; + license = with licenses; [ + gpl2Plus + ufl + ]; homepage = "https://github.com/fluxer/warmux"; }; } diff --git a/pkgs/by-name/wa/warp-terminal/package.nix b/pkgs/by-name/wa/warp-terminal/package.nix index 646750978bc9ee..41d4a1cbe2e6dc 100644 --- a/pkgs/by-name/wa/warp-terminal/package.nix +++ b/pkgs/by-name/wa/warp-terminal/package.nix @@ -1,114 +1,125 @@ -{ lib -, stdenvNoCC -, stdenv -, fetchurl -, autoPatchelfHook -, undmg -, zstd -, curl -, fontconfig -, libglvnd -, libxkbcommon -, vulkan-loader -, wayland -, xdg-utils -, xorg -, zlib -, makeWrapper -, waylandSupport ? false +{ + lib, + stdenvNoCC, + stdenv, + fetchurl, + autoPatchelfHook, + undmg, + zstd, + curl, + fontconfig, + libglvnd, + libxkbcommon, + vulkan-loader, + wayland, + xdg-utils, + xorg, + zlib, + makeWrapper, + waylandSupport ? false, }: let -pname = "warp-terminal"; -versions = lib.importJSON ./versions.json; -passthru.updateScript = ./update.sh; - -linux_arch = - if stdenv.hostPlatform.system == "x86_64-linux" - then "x86_64" - else "aarch64"; - -linux = stdenv.mkDerivation (finalAttrs: { - inherit pname meta passthru; - inherit (versions."linux_${linux_arch}") version; - src = fetchurl { - inherit (versions."linux_${linux_arch}") hash; - url = "https://releases.warp.dev/stable/v${finalAttrs.version}/warp-terminal-v${finalAttrs.version}-1-${linux_arch}.pkg.tar.zst"; + pname = "warp-terminal"; + versions = lib.importJSON ./versions.json; + passthru.updateScript = ./update.sh; + + linux_arch = if stdenv.hostPlatform.system == "x86_64-linux" then "x86_64" else "aarch64"; + + linux = stdenv.mkDerivation (finalAttrs: { + inherit pname meta passthru; + inherit (versions."linux_${linux_arch}") version; + src = fetchurl { + inherit (versions."linux_${linux_arch}") hash; + url = "https://releases.warp.dev/stable/v${finalAttrs.version}/warp-terminal-v${finalAttrs.version}-1-${linux_arch}.pkg.tar.zst"; + }; + + sourceRoot = "."; + + postPatch = '' + substituteInPlace usr/bin/warp-terminal \ + --replace-fail /opt/ $out/opt/ + ''; + + nativeBuildInputs = [ + autoPatchelfHook + zstd + makeWrapper + ]; + + buildInputs = [ + curl + fontconfig + (lib.getLib stdenv.cc.cc) # libstdc++.so libgcc_s.so + zlib + ]; + + runtimeDependencies = [ + libglvnd # for libegl + libxkbcommon + stdenv.cc.libc + vulkan-loader + xdg-utils + xorg.libX11 + xorg.libxcb + xorg.libXcursor + xorg.libXi + ] ++ lib.optionals waylandSupport [ wayland ]; + + installPhase = + '' + runHook preInstall + + mkdir $out + cp -r opt usr/* $out + + '' + + lib.optionalString waylandSupport '' + wrapProgram $out/bin/warp-terminal --set WARP_ENABLE_WAYLAND 1 + '' + + '' + runHook postInstall + ''; + }); + + darwin = stdenvNoCC.mkDerivation (finalAttrs: { + inherit pname meta passthru; + inherit (versions.darwin) version; + src = fetchurl { + inherit (versions.darwin) hash; + url = "https://releases.warp.dev/stable/v${finalAttrs.version}/Warp.dmg"; + }; + + sourceRoot = "."; + + nativeBuildInputs = [ undmg ]; + + installPhase = '' + runHook preInstall + + mkdir -p $out/Applications + cp -r *.app $out/Applications + + runHook postInstall + ''; + }); + + meta = with lib; { + description = "Rust-based terminal"; + homepage = "https://www.warp.dev"; + license = licenses.unfree; + sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; + maintainers = with maintainers; [ + emilytrau + imadnyc + donteatoreo + johnrtitor + ]; + platforms = platforms.darwin ++ [ + "x86_64-linux" + "aarch64-linux" + ]; }; - sourceRoot = "."; - - postPatch = '' - substituteInPlace usr/bin/warp-terminal \ - --replace-fail /opt/ $out/opt/ - ''; - - nativeBuildInputs = [ autoPatchelfHook zstd makeWrapper ]; - - buildInputs = [ - curl - fontconfig - (lib.getLib stdenv.cc.cc) # libstdc++.so libgcc_s.so - zlib - ]; - - runtimeDependencies = [ - libglvnd # for libegl - libxkbcommon - stdenv.cc.libc - vulkan-loader - xdg-utils - xorg.libX11 - xorg.libxcb - xorg.libXcursor - xorg.libXi - ] ++ lib.optionals waylandSupport [wayland]; - - installPhase = '' - runHook preInstall - - mkdir $out - cp -r opt usr/* $out - - '' + lib.optionalString waylandSupport '' - wrapProgram $out/bin/warp-terminal --set WARP_ENABLE_WAYLAND 1 - '' + '' - runHook postInstall - ''; -}); - -darwin = stdenvNoCC.mkDerivation (finalAttrs: { - inherit pname meta passthru; - inherit (versions.darwin) version; - src = fetchurl { - inherit (versions.darwin) hash; - url = "https://releases.warp.dev/stable/v${finalAttrs.version}/Warp.dmg"; - }; - - sourceRoot = "."; - - nativeBuildInputs = [ undmg ]; - - installPhase = '' - runHook preInstall - - mkdir -p $out/Applications - cp -r *.app $out/Applications - - runHook postInstall - ''; -}); - -meta = with lib; { - description = "Rust-based terminal"; - homepage = "https://www.warp.dev"; - license = licenses.unfree; - sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; - maintainers = with maintainers; [ emilytrau imadnyc donteatoreo johnrtitor ]; - platforms = platforms.darwin ++ [ "x86_64-linux" "aarch64-linux" ]; -}; - in -if stdenvNoCC.hostPlatform.isDarwin -then darwin -else linux +if stdenvNoCC.hostPlatform.isDarwin then darwin else linux diff --git a/pkgs/by-name/wa/warp/package.nix b/pkgs/by-name/wa/warp/package.nix index ad80b7cf796bec..286de8acbea3dd 100644 --- a/pkgs/by-name/wa/warp/package.nix +++ b/pkgs/by-name/wa/warp/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch2 -, appstream-glib -, cargo -, desktop-file-utils -, itstool -, meson -, ninja -, pkg-config -, python3 -, rustPlatform -, rustc -, wrapGAppsHook4 -, glib -, gtk4 -, libadwaita -, zbar -, gst_all_1 +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch2, + appstream-glib, + cargo, + desktop-file-utils, + itstool, + meson, + ninja, + pkg-config, + python3, + rustPlatform, + rustc, + wrapGAppsHook4, + glib, + gtk4, + libadwaita, + zbar, + gst_all_1, }: stdenv.mkDerivation rec { @@ -56,16 +57,18 @@ stdenv.mkDerivation rec { rustc ]; - buildInputs = [ - glib - gtk4 - libadwaita - zbar - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-bad - ]); + buildInputs = + [ + glib + gtk4 + libadwaita + zbar + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-bad + ]); meta = { description = "Fast and secure file transfer"; diff --git a/pkgs/by-name/wa/warpd/package.nix b/pkgs/by-name/wa/warpd/package.nix index a2957a4edb6ee8..3c1fb984c2d4da 100644 --- a/pkgs/by-name/wa/warpd/package.nix +++ b/pkgs/by-name/wa/warpd/package.nix @@ -1,9 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, git -, withWayland ? true, cairo, libxkbcommon, wayland -, withX ? true, libXi, libXinerama, libXft, libXfixes, libXtst, libX11, libXext +{ + lib, + stdenv, + fetchFromGitHub, + git, + withWayland ? true, + cairo, + libxkbcommon, + wayland, + withX ? true, + libXi, + libXinerama, + libXft, + libXfixes, + libXtst, + libX11, + libXext, }: stdenv.mkDerivation rec { @@ -20,21 +31,24 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ git ]; - buildInputs = lib.optionals withWayland [ - cairo - libxkbcommon - wayland - ] ++ lib.optionals withX [ - libXi - libXinerama - libXft - libXfixes - libXtst - libX11 - libXext - ]; + buildInputs = + lib.optionals withWayland [ + cairo + libxkbcommon + wayland + ] + ++ lib.optionals withX [ + libXi + libXinerama + libXft + libXfixes + libXtst + libX11 + libXext + ]; - makeFlags = [ "PREFIX=$(out)" ] + makeFlags = + [ "PREFIX=$(out)" ] ++ lib.optional (!withWayland) "DISABLE_WAYLAND=y" ++ lib.optional (!withX) "DISABLE_X=y"; diff --git a/pkgs/by-name/wa/warpinator/package.nix b/pkgs/by-name/wa/warpinator/package.nix index bb7b97b8b38d34..627f7ea4f52f1e 100644 --- a/pkgs/by-name/wa/warpinator/package.nix +++ b/pkgs/by-name/wa/warpinator/package.nix @@ -1,38 +1,41 @@ -{ stdenv -, fetchFromGitHub -, lib -, gobject-introspection -, meson -, ninja -, python3 -, gtk3 -, gdk-pixbuf -, xapp -, wrapGAppsHook3 -, gettext -, polkit -, glib -, gitUpdater -, bubblewrap +{ + stdenv, + fetchFromGitHub, + lib, + gobject-introspection, + meson, + ninja, + python3, + gtk3, + gdk-pixbuf, + xapp, + wrapGAppsHook3, + gettext, + polkit, + glib, + gitUpdater, + bubblewrap, }: let - pythonEnv = python3.withPackages (pp: with pp; [ - grpcio-tools - protobuf - pygobject3 - setproctitle - python-xapp - zeroconf - grpcio - setuptools - cryptography - pynacl - netifaces - netaddr - ifaddr - qrcode - ]); + pythonEnv = python3.withPackages ( + pp: with pp; [ + grpcio-tools + protobuf + pygobject3 + setproctitle + python-xapp + zeroconf + grpcio + setuptools + cryptography + pynacl + netifaces + netaddr + ifaddr + qrcode + ] + ); in stdenv.mkDerivation rec { pname = "warpinator"; diff --git a/pkgs/by-name/wa/warzone2100/package.nix b/pkgs/by-name/wa/warzone2100/package.nix index 8f860afcb34404..972c3a4e2505b0 100644 --- a/pkgs/by-name/wa/warzone2100/package.nix +++ b/pkgs/by-name/wa/warzone2100/package.nix @@ -1,39 +1,40 @@ -{ lib -, stdenv -, fetchurl -, cmake -, ninja -, p7zip -, pkg-config -, asciidoctor -, gettext +{ + lib, + stdenv, + fetchurl, + cmake, + ninja, + p7zip, + pkg-config, + asciidoctor, + gettext, -, SDL2 -, libtheora -, libvorbis -, libopus -, openal -, openalSoft -, physfs -, miniupnpc -, libsodium -, curl -, libpng -, freetype -, harfbuzz -, sqlite -, which -, vulkan-headers -, vulkan-loader -, shaderc + SDL2, + libtheora, + libvorbis, + libopus, + openal, + openalSoft, + physfs, + miniupnpc, + libsodium, + curl, + libpng, + freetype, + harfbuzz, + sqlite, + which, + vulkan-headers, + vulkan-loader, + shaderc, -, testers -, warzone2100 -, nixosTests + testers, + warzone2100, + nixosTests, -, gitUpdater + gitUpdater, -, withVideos ? false + withVideos ? false, }: let @@ -46,32 +47,34 @@ in stdenv.mkDerivation (finalAttrs: { inherit pname; - version = "4.5.5"; + version = "4.5.5"; src = fetchurl { url = "mirror://sourceforge/project/warzone2100/releases/${finalAttrs.version}/warzone2100_src.tar.xz"; hash = "sha256-B/YbrnIWh+3rYtpId+hQMKA6BTpZPWRRlPxld44EgP8="; }; - buildInputs = [ - SDL2 - libtheora - libvorbis - libopus - openal - openalSoft - physfs - miniupnpc - libsodium - curl - libpng - freetype - harfbuzz - sqlite - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - vulkan-headers - vulkan-loader - ]; + buildInputs = + [ + SDL2 + libtheora + libvorbis + libopus + openal + openalSoft + physfs + miniupnpc + libsodium + curl + libpng + freetype + harfbuzz + sqlite + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + vulkan-headers + vulkan-loader + ]; nativeBuildInputs = [ pkg-config @@ -137,7 +140,10 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://wz2100.net"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ astsmtl fgaz ]; + maintainers = with maintainers; [ + astsmtl + fgaz + ]; platforms = platforms.all; # configure_mac.cmake tries to download stuff # https://github.com/Warzone2100/warzone2100/blob/master/macosx/README.md diff --git a/pkgs/by-name/wa/wasabiwallet/package.nix b/pkgs/by-name/wa/wasabiwallet/package.nix index ad05e27385a6f1..bb3d0ea440fff0 100644 --- a/pkgs/by-name/wa/wasabiwallet/package.nix +++ b/pkgs/by-name/wa/wasabiwallet/package.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, autoPatchelfHook -, makeWrapper -, fetchurl -, makeDesktopItem -, lttng-ust_2_12 -, fontconfig -, openssl -, xorg -, zlib +{ + lib, + stdenv, + autoPatchelfHook, + makeWrapper, + fetchurl, + makeDesktopItem, + lttng-ust_2_12, + fontconfig, + openssl, + xorg, + zlib, }: let @@ -40,10 +42,16 @@ stdenv.mkDerivation rec { desktopName = "Wasabi"; genericName = "Bitcoin wallet"; comment = meta.description; - categories = [ "Network" "Utility" ]; + categories = [ + "Network" + "Utility" + ]; }; - nativeBuildInputs = [ autoPatchelfHook makeWrapper ]; + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + ]; buildInputs = runtimeLibs ++ [ lttng-ust_2_12 ]; diff --git a/pkgs/by-name/wa/wash-cli/package.nix b/pkgs/by-name/wa/wash-cli/package.nix index 663273e54e4bb0..aed9801132d013 100644 --- a/pkgs/by-name/wa/wash-cli/package.nix +++ b/pkgs/by-name/wa/wash-cli/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchCrate, rustPlatform, pkg-config, openssl, darwin, fetchurl }: +{ + lib, + stdenv, + fetchCrate, + rustPlatform, + pkg-config, + openssl, + darwin, + fetchurl, +}: let wasiPreviewCommandComponentAdapter = fetchurl { @@ -10,20 +19,22 @@ let hash = "sha256-oE53IRMZgysSWT7RhrpZJjdaIyzCRf0h4d1yjqj/PSk="; }; -in rustPlatform.buildRustPackage rec { +in +rustPlatform.buildRustPackage rec { pname = "wash-cli"; version = "0.29.2"; src = fetchCrate { inherit version pname; - hash = "sha256-A66KSDYFbByguhnlzzU5nf8pE3lhnYQjI3h73SKB2Zo="; + hash = "sha256-A66KSDYFbByguhnlzzU5nf8pE3lhnYQjI3h73SKB2Zo="; }; cargoHash = "sha256-2mo30xHQ3aCExdI0ITDY9g/C5peN48PdUNFVVxM//+c="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] + buildInputs = + [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration darwin.apple_sdk.frameworks.CoreServices diff --git a/pkgs/by-name/wa/wasm-tools/package.nix b/pkgs/by-name/wa/wasm-tools/package.nix index ba84d6383e294a..a9980c2e6cfe71 100644 --- a/pkgs/by-name/wa/wasm-tools/package.nix +++ b/pkgs/by-name/wa/wasm-tools/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -18,10 +19,18 @@ rustPlatform.buildRustPackage rec { # Disable cargo-auditable until https://github.com/rust-secure-code/cargo-auditable/issues/124 is solved. auditable = false; cargoHash = "sha256-il9Zdj50XBMCxiOyQwyToOtaP34hcklOwlDuVGEmyVY="; - cargoBuildFlags = [ "--package" "wasm-tools" ]; - cargoTestFlags = [ "--all" ] ++ + cargoBuildFlags = [ + "--package" + "wasm-tools" + ]; + cargoTestFlags = + [ "--all" ] + ++ # Due to https://github.com/bytecodealliance/wasm-tools/issues/1820 - [ "--" "--test-threads=1" ]; + [ + "--" + "--test-threads=1" + ]; meta = with lib; { description = "Low level tooling for WebAssembly in Rust"; diff --git a/pkgs/by-name/wa/wasm3/package.nix b/pkgs/by-name/wa/wasm3/package.nix index ab7ed45dcc7118..0f820505e78ae8 100644 --- a/pkgs/by-name/wa/wasm3/package.nix +++ b/pkgs/by-name/wa/wasm3/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, cmake, fetchFromGitHub }: +{ + lib, + stdenv, + cmake, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "wasm3"; diff --git a/pkgs/by-name/wa/wasmer-pack/package.nix b/pkgs/by-name/wa/wasmer-pack/package.nix index f1216ae12416a3..e372640c9d4b3c 100644 --- a/pkgs/by-name/wa/wasmer-pack/package.nix +++ b/pkgs/by-name/wa/wasmer-pack/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/wa/wasmi/package.nix b/pkgs/by-name/wa/wasmi/package.nix index 558a27cce29ae0..430e9cf7276da9 100644 --- a/pkgs/by-name/wa/wasmi/package.nix +++ b/pkgs/by-name/wa/wasmi/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { @@ -27,7 +28,10 @@ rustPlatform.buildRustPackage rec { description = "Efficient WebAssembly interpreter"; homepage = "https://github.com/paritytech/wasmi"; changelog = "https://github.com/paritytech/wasmi/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; mainProgram = "wasmi_cli"; maintainers = with maintainers; [ dit7ya ]; }; diff --git a/pkgs/by-name/wa/wastebin/package.nix b/pkgs/by-name/wa/wastebin/package.nix index f63429bff2488d..82bf03f601f385 100644 --- a/pkgs/by-name/wa/wastebin/package.nix +++ b/pkgs/by-name/wa/wastebin/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, sqlite -, zstd -, stdenv -, darwin -, nixosTests +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + sqlite, + zstd, + stdenv, + darwin, + nixosTests, }: rustPlatform.buildRustPackage rec { @@ -26,12 +27,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - sqlite - zstd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + sqlite + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; env = { ZSTD_SYS_USE_PKG_CONFIG = true; @@ -46,7 +49,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/matze/wastebin"; changelog = "https://github.com/matze/wastebin/blob/${src.rev}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ pinpox matthiasbeyer ]; + maintainers = with maintainers; [ + pinpox + matthiasbeyer + ]; mainProgram = "wastebin"; }; } diff --git a/pkgs/by-name/wa/wasynth/package.nix b/pkgs/by-name/wa/wasynth/package.nix index bf7f0250f4059e..7f3f132cceb4cf 100644 --- a/pkgs/by-name/wa/wasynth/package.nix +++ b/pkgs/by-name/wa/wasynth/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/wa/watchdogd/package.nix b/pkgs/by-name/wa/watchdogd/package.nix index 4781257c88f9db..a725a78f7278e8 100644 --- a/pkgs/by-name/wa/watchdogd/package.nix +++ b/pkgs/by-name/wa/watchdogd/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, autoreconfHook -, libite -, libuev -, libconfuse -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + libite, + libuev, + libconfuse, + nixosTests, }: stdenv.mkDerivation rec { pname = "watchdogd"; @@ -19,8 +20,15 @@ stdenv.mkDerivation rec { hash = "sha256-JNJj0CJGJXuIRpob2RXYqDRrU4Cn20PRxOjQ6TFsVYQ="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ libite libuev libconfuse ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + libite + libuev + libconfuse + ]; passthru.tests = { inherit (nixosTests) watchdogd; }; diff --git a/pkgs/by-name/wa/watchmate/package.nix b/pkgs/by-name/wa/watchmate/package.nix index eebcc3cce01187..f7be89bed47eaf 100644 --- a/pkgs/by-name/wa/watchmate/package.nix +++ b/pkgs/by-name/wa/watchmate/package.nix @@ -10,57 +10,58 @@ openssl, wrapGAppsHook4, glib, -}: let +}: +let releaseVersion = "0.5.2"; in - rustPlatform.buildRustPackage rec { - pname = "watchmate"; - version = "${releaseVersion}-unstable-2024-08-13"; +rustPlatform.buildRustPackage rec { + pname = "watchmate"; + version = "${releaseVersion}-unstable-2024-08-13"; - src = fetchFromGitHub { - owner = "azymohliad"; - repo = "watchmate"; - rev = "e05edfae94a1973110c6f40f25133d5979f485ab"; - hash = "sha256-fHWxn7hFx/9cnLlCHIC6hIJaLd1U3Ii9mJgTJ+Hw63M="; - }; + src = fetchFromGitHub { + owner = "azymohliad"; + repo = "watchmate"; + rev = "e05edfae94a1973110c6f40f25133d5979f485ab"; + hash = "sha256-fHWxn7hFx/9cnLlCHIC6hIJaLd1U3Ii9mJgTJ+Hw63M="; + }; - cargoLock = { - lockFile = ./Cargo.lock; - outputHashes = { - "mpris2-zbus-0.1.0" = "sha256-a/cvbB0M9cUd8RP5XxgHRbJ/i/UKAEK4DTwwUU69IuY="; - }; + cargoLock = { + lockFile = ./Cargo.lock; + outputHashes = { + "mpris2-zbus-0.1.0" = "sha256-a/cvbB0M9cUd8RP5XxgHRbJ/i/UKAEK4DTwwUU69IuY="; }; + }; - nativeBuildInputs = [ - pkg-config - wrapGAppsHook4 - glib - ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook4 + glib + ]; - buildInputs = [ - gtk4 - libadwaita - bluez - dbus - openssl - ]; + buildInputs = [ + gtk4 + libadwaita + bluez + dbus + openssl + ]; - postInstall = '' - install -Dm444 assets/io.gitlab.azymohliad.WatchMate.desktop -t $out/share/applications/ - install -Dm444 assets/io.gitlab.azymohliad.WatchMate.metainfo.xml -t $out/share/metainfo/ - install -Dm444 assets/io.gitlab.azymohliad.WatchMate.gschema.xml -t $out/share/glib-2.0/schemas/ - glib-compile-schemas $out/share/glib-2.0/schemas/ - install -Dm444 assets/icons/io.gitlab.azymohliad.WatchMate.svg -t $out/share/icons/hicolor/scalable/apps/ - install -Dm444 assets/icons/io.gitlab.azymohliad.WatchMate-symbolic.svg -t $out/share/icons/hicolor/scalable/apps/ - ''; + postInstall = '' + install -Dm444 assets/io.gitlab.azymohliad.WatchMate.desktop -t $out/share/applications/ + install -Dm444 assets/io.gitlab.azymohliad.WatchMate.metainfo.xml -t $out/share/metainfo/ + install -Dm444 assets/io.gitlab.azymohliad.WatchMate.gschema.xml -t $out/share/glib-2.0/schemas/ + glib-compile-schemas $out/share/glib-2.0/schemas/ + install -Dm444 assets/icons/io.gitlab.azymohliad.WatchMate.svg -t $out/share/icons/hicolor/scalable/apps/ + install -Dm444 assets/icons/io.gitlab.azymohliad.WatchMate-symbolic.svg -t $out/share/icons/hicolor/scalable/apps/ + ''; - meta = with lib; { - description = "PineTime smart watch companion app for Linux phone and desktop"; - mainProgram = "watchmate"; - homepage = "https://github.com/azymohliad/watchmate"; - changelog = "https://github.com/azymohliad/watchmate/raw/v${releaseVersion}/CHANGELOG.md"; - license = licenses.gpl3Plus; - maintainers = with maintainers; [chuangzhu]; - platforms = platforms.linux; - }; - } + meta = with lib; { + description = "PineTime smart watch companion app for Linux phone and desktop"; + mainProgram = "watchmate"; + homepage = "https://github.com/azymohliad/watchmate"; + changelog = "https://github.com/azymohliad/watchmate/raw/v${releaseVersion}/CHANGELOG.md"; + license = licenses.gpl3Plus; + maintainers = with maintainers; [ chuangzhu ]; + platforms = platforms.linux; + }; +} diff --git a/pkgs/by-name/wa/watershot/package.nix b/pkgs/by-name/wa/watershot/package.nix index 3935b3ef211c35..074cc182fa32a8 100644 --- a/pkgs/by-name/wa/watershot/package.nix +++ b/pkgs/by-name/wa/watershot/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, wayland -, libxkbcommon -, fontconfig -, makeWrapper -, grim +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + wayland, + libxkbcommon, + fontconfig, + makeWrapper, + grim, }: rustPlatform.buildRustPackage rec { pname = "watershot"; @@ -21,9 +22,17 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-481E5/mUeeoaZ0N//tRWCyV8/sRRP6VdB06gB1whgzU="; - nativeBuildInputs = [ pkg-config wayland makeWrapper ]; + nativeBuildInputs = [ + pkg-config + wayland + makeWrapper + ]; - buildInputs = [ wayland fontconfig libxkbcommon ]; + buildInputs = [ + wayland + fontconfig + libxkbcommon + ]; postInstall = '' wrapProgram $out/bin/watershot \ diff --git a/pkgs/by-name/wa/watson/package.nix b/pkgs/by-name/wa/watson/package.nix index 8cf348020c4377..93c5974e7bdfdf 100644 --- a/pkgs/by-name/wa/watson/package.nix +++ b/pkgs/by-name/wa/watson/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, python3, installShellFiles, fetchpatch }: +{ + lib, + fetchFromGitHub, + python3, + installShellFiles, + fetchpatch, +}: with python3.pkgs; @@ -28,8 +34,18 @@ buildPythonApplication rec { installShellCompletion --fish watson.fish ''; - nativeCheckInputs = [ pytestCheckHook pytest-mock mock pytest-datafiles ]; - propagatedBuildInputs = [ arrow click click-didyoumean requests ]; + nativeCheckInputs = [ + pytestCheckHook + pytest-mock + mock + pytest-datafiles + ]; + propagatedBuildInputs = [ + arrow + click + click-didyoumean + requests + ]; nativeBuildInputs = [ installShellFiles ]; meta = with lib; { @@ -37,6 +53,10 @@ buildPythonApplication rec { description = "Wonderful CLI to track your time!"; mainProgram = "watson"; license = licenses.mit; - maintainers = with maintainers; [ mguentner nathyong oxzi ]; + maintainers = with maintainers; [ + mguentner + nathyong + oxzi + ]; }; } diff --git a/pkgs/by-name/wa/wavefunctioncollapse/package.nix b/pkgs/by-name/wa/wavefunctioncollapse/package.nix index 0aabe83542706a..82e289116149f5 100644 --- a/pkgs/by-name/wa/wavefunctioncollapse/package.nix +++ b/pkgs/by-name/wa/wavefunctioncollapse/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchFromGitHub, mono}: +{ + lib, + stdenv, + fetchFromGitHub, + mono, +}: stdenv.mkDerivation rec { pname = "wavefunctioncollapse"; version = "0.0pre20170130"; @@ -23,11 +28,11 @@ stdenv.mkDerivation rec { echo "'${mono}/bin/mono' '$out/bin/wavefunctioncollapse.exe' \"\$@\"" >> "$out/bin/wavefunctioncollapse" chmod a+x "$out/bin/wavefunctioncollapse" ''; - buildInputs = [mono]; + buildInputs = [ mono ]; meta = { description = "Generator of bitmaps that are locally similar to the input bitmap"; license = lib.licenses.mit; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/by-name/wa/wavegain/package.nix b/pkgs/by-name/wa/wavegain/package.nix index 49c66b07a91c61..355a80166ed9f2 100644 --- a/pkgs/by-name/wa/wavegain/package.nix +++ b/pkgs/by-name/wa/wavegain/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation { pname = "wavegain"; diff --git a/pkgs/by-name/wa/wavemon/package.nix b/pkgs/by-name/wa/wavemon/package.nix index 6d05569de8ad79..d5da2ca88f7f22 100644 --- a/pkgs/by-name/wa/wavemon/package.nix +++ b/pkgs/by-name/wa/wavemon/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, libnl -, ncurses -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + libnl, + ncurses, + pkg-config, }: stdenv.mkDerivation rec { @@ -30,7 +31,10 @@ stdenv.mkDerivation rec { description = "Ncurses-based monitoring application for wireless network devices"; homepage = "https://github.com/uoaerg/wavemon"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ raskin fpletz ]; + maintainers = with maintainers; [ + raskin + fpletz + ]; platforms = platforms.linux; mainProgram = "wavemon"; }; diff --git a/pkgs/by-name/wa/wavpack/package.nix b/pkgs/by-name/wa/wavpack/package.nix index 4cd3007043cfbd..906521e602dd09 100644 --- a/pkgs/by-name/wa/wavpack/package.nix +++ b/pkgs/by-name/wa/wavpack/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, gettext, autoreconfHook, libiconv }: +{ + lib, + stdenv, + fetchFromGitHub, + gettext, + autoreconfHook, + libiconv, +}: stdenv.mkDerivation rec { pname = "wavpack"; @@ -19,14 +26,19 @@ stdenv.mkDerivation rec { hash = "sha256-vFZxg1mVqE7Kp38vEGA5V8m2tjqhssFsUZURixhlfk0="; }; - outputs = [ "out" "dev" "doc" "man" ]; + outputs = [ + "out" + "dev" + "doc" + "man" + ]; meta = with lib; { description = "Hybrid audio compression format"; - homepage = "https://www.wavpack.com/"; - changelog = "https://github.com/dbry/WavPack/releases/tag/${version}"; - license = licenses.bsd3; - platforms = platforms.unix; + homepage = "https://www.wavpack.com/"; + changelog = "https://github.com/dbry/WavPack/releases/tag/${version}"; + license = licenses.bsd3; + platforms = platforms.unix; maintainers = with maintainers; [ codyopel ]; }; } diff --git a/pkgs/by-name/wa/wavrsocvt/package.nix b/pkgs/by-name/wa/wavrsocvt/package.nix index 7b805496c2d8c4..5844537db25262 100644 --- a/pkgs/by-name/wa/wavrsocvt/package.nix +++ b/pkgs/by-name/wa/wavrsocvt/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation { pname = "wavrsocvt"; diff --git a/pkgs/by-name/wa/way-displays/package.nix b/pkgs/by-name/wa/way-displays/package.nix index 0d694bc5029aba..7bb884ee0a9b30 100644 --- a/pkgs/by-name/wa/way-displays/package.nix +++ b/pkgs/by-name/wa/way-displays/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, wayland-scanner -, wayland -, libinput -, yaml-cpp +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + wayland-scanner, + wayland, + libinput, + yaml-cpp, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/wa/wayback-machine-archiver/package.nix b/pkgs/by-name/wa/wayback-machine-archiver/package.nix index 034cc303e6eddc..cf7e7da82f90ef 100644 --- a/pkgs/by-name/wa/wayback-machine-archiver/package.nix +++ b/pkgs/by-name/wa/wayback-machine-archiver/package.nix @@ -1,4 +1,8 @@ -{ lib, python3, fetchFromGitHub }: +{ + lib, + python3, + fetchFromGitHub, +}: python3.pkgs.buildPythonApplication rec { pname = "wayback-machine-archiver"; @@ -13,7 +17,10 @@ python3.pkgs.buildPythonApplication rec { nativeBuildInputs = with python3.pkgs; [ pypandoc ]; propagatedBuildInputs = with python3.pkgs; [ requests ]; - nativeCheckInputs = with python3.pkgs; [ pytestCheckHook requests-mock ]; + nativeCheckInputs = with python3.pkgs; [ + pytestCheckHook + requests-mock + ]; postPatch = '' substituteInPlace setup.py \ diff --git a/pkgs/by-name/wa/wayback/package.nix b/pkgs/by-name/wa/wayback/package.nix index 7d7068e7a4180e..3750a15b05b27b 100644 --- a/pkgs/by-name/wa/wayback/package.nix +++ b/pkgs/by-name/wa/wayback/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, chromium +{ + lib, + fetchFromGitHub, + buildGoModule, + chromium, }: buildGoModule rec { diff --git a/pkgs/by-name/wa/waybar/package.nix b/pkgs/by-name/wa/waybar/package.nix index 8fcd8869a28208..e6d004a801bd8c 100644 --- a/pkgs/by-name/wa/waybar/package.nix +++ b/pkgs/by-name/wa/waybar/package.nix @@ -113,13 +113,16 @@ stdenv.mkDerivation (finalAttrs: { popd ''; - nativeBuildInputs = [ - meson - ninja - pkg-config - wayland-scanner - wrapGAppsHook3 - ] ++ lib.optional withMediaPlayer gobject-introspection ++ lib.optional enableManpages scdoc; + nativeBuildInputs = + [ + meson + ninja + pkg-config + wayland-scanner + wrapGAppsHook3 + ] + ++ lib.optional withMediaPlayer gobject-introspection + ++ lib.optional enableManpages scdoc; propagatedBuildInputs = lib.optionals withMediaPlayer [ glib diff --git a/pkgs/by-name/wa/waybox/package.nix b/pkgs/by-name/wa/waybox/package.nix index 28b055546ca7c3..4908afd37caa10 100644 --- a/pkgs/by-name/wa/waybox/package.nix +++ b/pkgs/by-name/wa/waybox/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libGL -, libxkbcommon -, libxml2 -, libevdev -, libinput -, mesa -, meson -, ninja -, pixman -, pkg-config -, udev -, wayland -, wayland-protocols -, wayland-scanner -, wlroots +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libGL, + libxkbcommon, + libxml2, + libevdev, + libinput, + mesa, + meson, + ninja, + pixman, + pkg-config, + udev, + wayland, + wayland-protocols, + wayland-scanner, + wlroots, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/wa/wayfarer/package.nix b/pkgs/by-name/wa/wayfarer/package.nix index cbfb7c149744e3..d9d03e709e6d87 100644 --- a/pkgs/by-name/wa/wayfarer/package.nix +++ b/pkgs/by-name/wa/wayfarer/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, blueprint-compiler -, desktop-file-utils -, gst_all_1 -, gtk4 -, libpulseaudio -, meson -, ninja -, pipewire -, pkg-config -, vala -, wrapGAppsHook4 +{ + lib, + stdenv, + fetchFromGitHub, + blueprint-compiler, + desktop-file-utils, + gst_all_1, + gtk4, + libpulseaudio, + meson, + ninja, + pipewire, + pkg-config, + vala, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/wa/wayfreeze/package.nix b/pkgs/by-name/wa/wayfreeze/package.nix index 7a53a49f6fb734..8766250eb1ddbd 100644 --- a/pkgs/by-name/wa/wayfreeze/package.nix +++ b/pkgs/by-name/wa/wayfreeze/package.nix @@ -31,7 +31,7 @@ rustPlatform.buildRustPackage { license = licenses.agpl3Only; maintainers = with lib.maintainers; [ purrpurrn - jappie3 /* upstream dev */ + jappie3 # upstream dev ]; mainProgram = "wayfreeze"; platforms = platforms.linux; diff --git a/pkgs/by-name/wa/wayidle/package.nix b/pkgs/by-name/wa/wayidle/package.nix index 693459de045bc8..ebe51dd5e100a0 100644 --- a/pkgs/by-name/wa/wayidle/package.nix +++ b/pkgs/by-name/wa/wayidle/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromSourcehut +{ + lib, + rustPlatform, + fetchFromSourcehut, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/wa/wayland-logout/package.nix b/pkgs/by-name/wa/wayland-logout/package.nix index 272b3dfbe06fcf..0292b42e5a5b34 100644 --- a/pkgs/by-name/wa/wayland-logout/package.nix +++ b/pkgs/by-name/wa/wayland-logout/package.nix @@ -14,15 +14,18 @@ stdenv.mkDerivation rec { rev = "v${version}"; hash = "sha256-VSAw6go4v937HWazXfMz8OdHgOnUtrlDXkslsV4eDIg="; }; - nativeBuildInputs = [meson ninja]; + nativeBuildInputs = [ + meson + ninja + ]; meta = with lib; { description = '' A utility designed to kill a single instance of a wayland compositor ''; mainProgram = "wayland-logout"; homepage = "https://github.com/soreau/wayland-logout"; - maintainers = with maintainers; [quantenzitrone]; - license = with licenses; [mit]; + maintainers = with maintainers; [ quantenzitrone ]; + license = with licenses; [ mit ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/wa/wayland-pipewire-idle-inhibit/package.nix b/pkgs/by-name/wa/wayland-pipewire-idle-inhibit/package.nix index ac49b80c5833ed..60e20ed60d018d 100644 --- a/pkgs/by-name/wa/wayland-pipewire-idle-inhibit/package.nix +++ b/pkgs/by-name/wa/wayland-pipewire-idle-inhibit/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, pipewire -, pkg-config -, rustPlatform -, wayland -, wayland-protocols +{ + lib, + fetchFromGitHub, + pipewire, + pkg-config, + rustPlatform, + wayland, + wayland-protocols, }: rustPlatform.buildRustPackage rec { pname = "wayland-pipewire-idle-inhibit"; @@ -39,4 +40,3 @@ rustPlatform.buildRustPackage rec { mainProgram = "wayland-pipewire-idle-inhibit"; }; } - diff --git a/pkgs/by-name/wa/wayland-proxy-virtwl/package.nix b/pkgs/by-name/wa/wayland-proxy-virtwl/package.nix index cd24af3217c47f..8af6fb0672936d 100644 --- a/pkgs/by-name/wa/wayland-proxy-virtwl/package.nix +++ b/pkgs/by-name/wa/wayland-proxy-virtwl/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, ocamlPackages -, pkg-config -, libdrm -, unstableGitUpdater +{ + lib, + fetchFromGitHub, + ocamlPackages, + pkg-config, + libdrm, + unstableGitUpdater, }: ocamlPackages.buildDunePackage rec { @@ -23,15 +24,17 @@ ocamlPackages.buildDunePackage rec { pkg-config ]; - buildInputs = [ libdrm ] ++ (with ocamlPackages; [ - dune-configurator - eio_main - ppx_cstruct - wayland - cmdliner - logs - ppx_cstruct - ]); + buildInputs = + [ libdrm ] + ++ (with ocamlPackages; [ + dune-configurator + eio_main + ppx_cstruct + wayland + cmdliner + logs + ppx_cstruct + ]); doCheck = true; @@ -42,7 +45,10 @@ ocamlPackages.buildDunePackage rec { description = "Proxy Wayland connections across a VM boundary"; license = licenses.asl20; mainProgram = "wayland-proxy-virtwl"; - maintainers = [ maintainers.qyliss maintainers.sternenseemann ]; + maintainers = [ + maintainers.qyliss + maintainers.sternenseemann + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/wa/wayland-utils/package.nix b/pkgs/by-name/wa/wayland-utils/package.nix index 948bb758110b0a..c938f9a0dfa122 100644 --- a/pkgs/by-name/wa/wayland-utils/package.nix +++ b/pkgs/by-name/wa/wayland-utils/package.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchurl -, meson, pkg-config, ninja, wayland-scanner -, libdrm, wayland, wayland-protocols +{ + lib, + stdenv, + fetchurl, + meson, + pkg-config, + ninja, + wayland-scanner, + libdrm, + wayland, + wayland-protocols, }: stdenv.mkDerivation rec { @@ -14,8 +22,17 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson pkg-config ninja wayland-scanner ]; - buildInputs = [ libdrm wayland wayland-protocols ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + wayland-scanner + ]; + buildInputs = [ + libdrm + wayland + wayland-protocols + ]; meta = with lib; { description = "Wayland utilities (wayland-info)"; diff --git a/pkgs/by-name/wa/waylevel/package.nix b/pkgs/by-name/wa/waylevel/package.nix index f0688ebf47eeb7..615f22f92bf907 100644 --- a/pkgs/by-name/wa/waylevel/package.nix +++ b/pkgs/by-name/wa/waylevel/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromSourcehut -, rustPlatform -, wayland +{ + lib, + fetchFromSourcehut, + rustPlatform, + wayland, }: rustPlatform.buildRustPackage rec { pname = "waylevel"; @@ -17,7 +18,7 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-gw5m1/btJ5zZP04C7BCnHqEOUBoeu0whK8W7xA+xSQo="; postFixup = '' - patchelf --set-rpath ${lib.makeLibraryPath [wayland]} $out/bin/waylevel + patchelf --set-rpath ${lib.makeLibraryPath [ wayland ]} $out/bin/waylevel ''; meta = with lib; { diff --git a/pkgs/by-name/wa/waylogout/package.nix b/pkgs/by-name/wa/waylogout/package.nix index 7aceb80e2d46b4..c201f0a63e6876 100644 --- a/pkgs/by-name/wa/waylogout/package.nix +++ b/pkgs/by-name/wa/waylogout/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, wayland -, wayland-protocols -, wayland-scanner -, libxkbcommon -, cairo -, gdk-pixbuf -, scdoc +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + wayland, + wayland-protocols, + wayland-scanner, + libxkbcommon, + cairo, + gdk-pixbuf, + scdoc, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/wa/waylyrics/package.nix b/pkgs/by-name/wa/waylyrics/package.nix index dac4db24559ea1..d7d6bad52b1070 100644 --- a/pkgs/by-name/wa/waylyrics/package.nix +++ b/pkgs/by-name/wa/waylyrics/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, wrapGAppsHook4 -, openssl -, dbus +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + wrapGAppsHook4, + openssl, + dbus, }: rustPlatform.buildRustPackage rec { @@ -20,8 +21,14 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Os7djeTDChNWXWbmDuJWJnf7E+U/V14Jg4cLOMAKhu4="; - nativeBuildInputs = [ pkg-config wrapGAppsHook4 ]; - buildInputs = [ openssl dbus ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook4 + ]; + buildInputs = [ + openssl + dbus + ]; checkFlags = [ "--skip=tests::netease_lyric::get_netease_lyric" # Requires network access @@ -57,8 +64,14 @@ rustPlatform.buildRustPackage rec { description = "Desktop lyrics with QQ and NetEase Music source"; mainProgram = "waylyrics"; homepage = "https://github.com/waylyrics/waylyrics"; - license = with licenses; [ mit cc-by-40 ]; - maintainers = with maintainers; [ shadowrz aleksana ]; + license = with licenses; [ + mit + cc-by-40 + ]; + maintainers = with maintainers; [ + shadowrz + aleksana + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/wa/waynergy/package.nix b/pkgs/by-name/wa/waynergy/package.nix index 434303c45b7374..bbb3cf9bc11db4 100644 --- a/pkgs/by-name/wa/waynergy/package.nix +++ b/pkgs/by-name/wa/waynergy/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, pkg-config -, ninja -, wayland-scanner -, libdrm -, wayland -, wayland-protocols -, wl-clipboard -, libxkbcommon -, libressl +{ + lib, + stdenv, + fetchFromGitHub, + meson, + pkg-config, + ninja, + wayland-scanner, + libdrm, + wayland, + wayland-protocols, + wl-clipboard, + libxkbcommon, + libressl, }: stdenv.mkDerivation rec { pname = "waynergy"; @@ -24,8 +25,20 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ pkg-config meson ninja wayland-scanner ]; - buildInputs = [ libdrm wayland wayland-protocols wl-clipboard libxkbcommon libressl ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + wayland-scanner + ]; + buildInputs = [ + libdrm + wayland + wayland-protocols + wl-clipboard + libxkbcommon + libressl + ]; postPatch = '' substituteInPlace waynergy.desktop --replace "Exec=/usr/bin/waynergy" "Exec=$out/bin/waynergy" diff --git a/pkgs/by-name/wa/wayout/package.nix b/pkgs/by-name/wa/wayout/package.nix index 7bd9f3a644820b..c9cde3d6f35318 100644 --- a/pkgs/by-name/wa/wayout/package.nix +++ b/pkgs/by-name/wa/wayout/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromSourcehut +{ + lib, + rustPlatform, + fetchFromSourcehut, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/wa/waypaper/package.nix b/pkgs/by-name/wa/waypaper/package.nix index 924a7e766a70d9..cae8f1f7c5b5d7 100644 --- a/pkgs/by-name/wa/waypaper/package.nix +++ b/pkgs/by-name/wa/waypaper/package.nix @@ -1,9 +1,10 @@ -{ lib -, python3 -, fetchFromGitHub -, gobject-introspection -, wrapGAppsHook3 -, killall +{ + lib, + python3, + fetchFromGitHub, + gobject-introspection, + wrapGAppsHook3, + killall, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/wa/waypipe/package.nix b/pkgs/by-name/wa/waypipe/package.nix index cef986ddae012c..53c1ceabb2e010 100644 --- a/pkgs/by-name/wa/waypipe/package.nix +++ b/pkgs/by-name/wa/waypipe/package.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, fetchFromGitLab -, meson, ninja, pkg-config, scdoc -, mesa, lz4, zstd, ffmpeg, libva -, wayland, wayland-scanner +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + scdoc, + mesa, + lz4, + zstd, + ffmpeg, + libva, + wayland, + wayland-scanner, }: stdenv.mkDerivation rec { @@ -18,10 +29,20 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson ninja pkg-config scdoc wayland-scanner ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + scdoc + wayland-scanner + ]; buildInputs = [ # Optional dependencies: - mesa lz4 zstd ffmpeg libva + mesa + lz4 + zstd + ffmpeg + libva wayland ]; diff --git a/pkgs/by-name/wa/wayshot/package.nix b/pkgs/by-name/wa/wayshot/package.nix index 0f46dc85a1cf9f..43100b4f1a6494 100644 --- a/pkgs/by-name/wa/wayshot/package.nix +++ b/pkgs/by-name/wa/wayshot/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { pname = "wayshot"; @@ -22,7 +23,10 @@ rustPlatform.buildRustPackage rec { description = "Native, blazing-fast screenshot tool for wlroots based compositors such as sway and river"; homepage = "https://github.com/waycrate/wayshot"; license = licenses.bsd2; - maintainers = with maintainers; [ dit7ya id3v1669 ]; + maintainers = with maintainers; [ + dit7ya + id3v1669 + ]; platforms = platforms.linux; mainProgram = "wayshot"; }; diff --git a/pkgs/by-name/wa/wayst/package.nix b/pkgs/by-name/wa/wayst/package.nix index e1522450a1dc41..4c2c10049bceb8 100644 --- a/pkgs/by-name/wa/wayst/package.nix +++ b/pkgs/by-name/wa/wayst/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, nixosTests -, freetype -, fontconfig -, libGL -, libX11 -, libXrandr -, libxcb -, libxkbcommon -, utf8proc -, wayland +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + nixosTests, + freetype, + fontconfig, + libGL, + libX11, + libXrandr, + libxcb, + libxkbcommon, + utf8proc, + wayland, -, libnotify -, xdg-utils -, makeDesktopItem + libnotify, + xdg-utils, + makeDesktopItem, }: let @@ -25,8 +26,14 @@ let genericName = "Terminal"; exec = "wayst"; icon = "wayst"; - categories = [ "System" "TerminalEmulator" ]; - keywords = [ "wayst" "terminal" ]; + categories = [ + "System" + "TerminalEmulator" + ]; + keywords = [ + "wayst" + "terminal" + ]; comment = "A simple terminal emulator"; }; in diff --git a/pkgs/by-name/wa/wayv/package.nix b/pkgs/by-name/wa/wayv/package.nix index 3070748f0109e7..55a58681a2462e 100644 --- a/pkgs/by-name/wa/wayv/package.nix +++ b/pkgs/by-name/wa/wayv/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchFromGitHub, fetchpatch, libX11}: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + libX11, +}: stdenv.mkDerivation rec { pname = "wayv"; version = "0.3"; @@ -33,8 +39,8 @@ stdenv.mkDerivation rec { meta = { description = "Gesture control for X11"; - license = lib.licenses.gpl2Plus ; - maintainers = [lib.maintainers.raskin]; + license = lib.licenses.gpl2Plus; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; homepage = "https://github.com/mikemb/wayV"; mainProgram = "wayv"; diff --git a/pkgs/by-name/wa/wazero/package.nix b/pkgs/by-name/wa/wazero/package.nix index f6f780e20d3fd8..4515449e5b67f4 100644 --- a/pkgs/by-name/wa/wazero/package.nix +++ b/pkgs/by-name/wa/wazero/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, wazero +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + wazero, }: buildGoModule rec { diff --git a/pkgs/by-name/wb/wb32-dfu-updater/package.nix b/pkgs/by-name/wb/wb32-dfu-updater/package.nix index d8b9dc75b5307c..91c9f24b9dbb1e 100644 --- a/pkgs/by-name/wb/wb32-dfu-updater/package.nix +++ b/pkgs/by-name/wb/wb32-dfu-updater/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libusb1 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libusb1, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/wb/wbg/package.nix b/pkgs/by-name/wb/wbg/package.nix index 65ce5cfff4834d..4cc65f09df6f59 100644 --- a/pkgs/by-name/wb/wbg/package.nix +++ b/pkgs/by-name/wb/wbg/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitea -, pkg-config -, meson -, ninja -, pixman -, tllist -, wayland -, wayland-scanner -, wayland-protocols -, enablePNG ? true -, enableJPEG ? true -, enableWebp ? true -# Optional dependencies -, libpng -, libjpeg -, libwebp +{ + stdenv, + lib, + fetchFromGitea, + pkg-config, + meson, + ninja, + pixman, + tllist, + wayland, + wayland-scanner, + wayland-protocols, + enablePNG ? true, + enableJPEG ? true, + enableWebp ? true, + # Optional dependencies + libpng, + libjpeg, + libwebp, }: stdenv.mkDerivation rec { @@ -37,12 +38,14 @@ stdenv.mkDerivation rec { wayland-scanner ]; - buildInputs = [ - pixman - tllist - wayland - wayland-protocols - ] ++ lib.optional enablePNG libpng + buildInputs = + [ + pixman + tllist + wayland + wayland-protocols + ] + ++ lib.optional enablePNG libpng ++ lib.optional enableJPEG libjpeg ++ lib.optional enableWebp libwebp; diff --git a/pkgs/by-name/wb/wbox/package.nix b/pkgs/by-name/wb/wbox/package.nix index dad3f374f7ae9e..80785d4c4d9d12 100644 --- a/pkgs/by-name/wb/wbox/package.nix +++ b/pkgs/by-name/wb/wbox/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "wbox"; diff --git a/pkgs/by-name/wc/wcalc/package.nix b/pkgs/by-name/wc/wcalc/package.nix index 92d53989ded8ea..eb3a0655f8058d 100644 --- a/pkgs/by-name/wc/wcalc/package.nix +++ b/pkgs/by-name/wc/wcalc/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, mpfr, readline }: +{ + lib, + stdenv, + fetchurl, + mpfr, + readline, +}: stdenv.mkDerivation rec { pname = "wcalc"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1vi8dl6rccqiq1apmpwawyg2ywx6a1ic1d3cvkf2hlwk1z11fb0f"; }; - buildInputs = [ mpfr readline ]; + buildInputs = [ + mpfr + readline + ]; meta = with lib; { description = "Command line calculator"; diff --git a/pkgs/by-name/wc/wcc/package.nix b/pkgs/by-name/wc/wcc/package.nix index 644e9ad646a808..3754246df189c8 100644 --- a/pkgs/by-name/wc/wcc/package.nix +++ b/pkgs/by-name/wc/wcc/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, capstone, libbfd, libelf, libiberty, readline }: +{ + lib, + stdenv, + fetchFromGitHub, + capstone, + libbfd, + libelf, + libiberty, + readline, +}: stdenv.mkDerivation { pname = "wcc-unstable"; @@ -12,7 +21,13 @@ stdenv.mkDerivation { fetchSubmodules = true; }; - buildInputs = [ capstone libbfd libelf libiberty readline ]; + buildInputs = [ + capstone + libbfd + libelf + libiberty + readline + ]; postPatch = '' sed -i src/wsh/include/libwitch/wsh.h src/wsh/scripts/INDEX \ diff --git a/pkgs/by-name/wc/wch-isp/package.nix b/pkgs/by-name/wc/wch-isp/package.nix index 3021c875f08bdc..9161e960cbf829 100644 --- a/pkgs/by-name/wc/wch-isp/package.nix +++ b/pkgs/by-name/wc/wch-isp/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromSourcehut, pkg-config, libusb1 }: +{ + lib, + stdenv, + fetchFromSourcehut, + pkg-config, + libusb1, +}: stdenv.mkDerivation rec { pname = "wch-isp"; @@ -14,8 +20,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ libusb1 ]; - installFlags = [ "DESTDIR=$(out)" "PREFIX=" ]; - installTargets = [ "install" "install-rules" ]; + installFlags = [ + "DESTDIR=$(out)" + "PREFIX=" + ]; + installTargets = [ + "install" + "install-rules" + ]; meta = { description = "Firmware programmer for WCH microcontrollers over USB"; diff --git a/pkgs/by-name/wc/wcpg/package.nix b/pkgs/by-name/wc/wcpg/package.nix index 8f14b940f3834e..f905a6373b343d 100644 --- a/pkgs/by-name/wc/wcpg/package.nix +++ b/pkgs/by-name/wc/wcpg/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, blas -, gmp -, lapack -, libf2c -, mpfi -, mpfr +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + blas, + gmp, + lapack, + libf2c, + mpfi, + mpfr, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/wc/wcslib/package.nix b/pkgs/by-name/wc/wcslib/package.nix index 4d25e981d55d08..66374aab784ae0 100644 --- a/pkgs/by-name/wc/wcslib/package.nix +++ b/pkgs/by-name/wc/wcslib/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, flex }: +{ + lib, + stdenv, + fetchurl, + flex, +}: stdenv.mkDerivation rec { pname = "wcslib"; @@ -13,7 +18,10 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; meta = with lib; { homepage = "https://www.atnf.csiro.au/people/mcalabre/WCS/"; diff --git a/pkgs/by-name/wd/wdfs/package.nix b/pkgs/by-name/wd/wdfs/package.nix index 9c1b68cc63072e..72c81823fcb9ae 100644 --- a/pkgs/by-name/wd/wdfs/package.nix +++ b/pkgs/by-name/wd/wdfs/package.nix @@ -1,4 +1,13 @@ -{lib, stdenv, fetchurl, glib, neon, fuse, autoreconfHook, pkg-config}: +{ + lib, + stdenv, + fetchurl, + glib, + neon, + fuse, + autoreconfHook, + pkg-config, +}: stdenv.mkDerivation rec { pname = "wdfs-fuse"; @@ -8,8 +17,15 @@ stdenv.mkDerivation rec { url = "http://noedler.de/projekte/wdfs/wdfs-${version}.tar.gz"; sha256 = "fcf2e1584568b07c7f3683a983a9be26fae6534b8109e09167e5dff9114ba2e5"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [fuse glib neon]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + fuse + glib + neon + ]; postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' # Fix the build on macOS with macFUSE installed. Needs autoreconfHook to diff --git a/pkgs/by-name/wd/wdiff/package.nix b/pkgs/by-name/wd/wdiff/package.nix index 767e02059a5db9..52751e243336e5 100644 --- a/pkgs/by-name/wd/wdiff/package.nix +++ b/pkgs/by-name/wd/wdiff/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, texinfo, which }: +{ + lib, + stdenv, + fetchurl, + texinfo, + which, +}: stdenv.mkDerivation rec { pname = "wdiff"; diff --git a/pkgs/by-name/wd/wdisplays/package.nix b/pkgs/by-name/wd/wdisplays/package.nix index 0f1cef974cc478..0f74c294abfa3b 100644 --- a/pkgs/by-name/wd/wdisplays/package.nix +++ b/pkgs/by-name/wd/wdisplays/package.nix @@ -1,14 +1,34 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, pkg-config, gtk3, libepoxy -, wayland, wayland-scanner, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + gtk3, + libepoxy, + wayland, + wayland-scanner, + wrapGAppsHook3, }: stdenv.mkDerivation (finalAttrs: { pname = "wdisplays"; version = "1.1.1"; - nativeBuildInputs = [ meson ninja pkg-config wrapGAppsHook3 wayland-scanner ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + wrapGAppsHook3 + wayland-scanner + ]; - buildInputs = [ gtk3 libepoxy wayland ]; + buildInputs = [ + gtk3 + libepoxy + wayland + ]; src = fetchFromGitHub { owner = "artizirk"; diff --git a/pkgs/by-name/wd/wdomirror/package.nix b/pkgs/by-name/wd/wdomirror/package.nix index 8796b2036dd5db..d7e96d6513785d 100644 --- a/pkgs/by-name/wd/wdomirror/package.nix +++ b/pkgs/by-name/wd/wdomirror/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, wayland -, wayland-protocols -, fetchpatch -, wayland-scanner +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + wayland, + wayland-protocols, + fetchpatch, + wayland-scanner, }: stdenv.mkDerivation { @@ -30,9 +31,17 @@ stdenv.mkDerivation { ]; strictDeps = true; - nativeBuildInputs = [ meson ninja pkg-config wayland-scanner ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + wayland-scanner + ]; - buildInputs = [ wayland wayland-protocols ]; + buildInputs = [ + wayland + wayland-protocols + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/wd/wdt/package.nix b/pkgs/by-name/wd/wdt/package.nix index f8ff82167704c9..0a7671a6725f99 100644 --- a/pkgs/by-name/wd/wdt/package.nix +++ b/pkgs/by-name/wd/wdt/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, folly -, gflags -, glog -, openssl -, double-conversion -, unstableGitUpdater +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + folly, + gflags, + glog, + openssl, + double-conversion, + unstableGitUpdater, }: stdenv.mkDerivation { @@ -22,7 +23,13 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ folly gflags glog openssl double-conversion ]; + buildInputs = [ + folly + gflags + glog + openssl + double-conversion + ]; # source is expected to be named wdt # https://github.com/facebook/wdt/blob/43319e59d0c77092468367cdadab37d12d7a2383/CMakeLists.txt#L238 diff --git a/pkgs/by-name/we/weasis/package.nix b/pkgs/by-name/we/weasis/package.nix index 999d815186228c..579996b1be6823 100644 --- a/pkgs/by-name/we/weasis/package.nix +++ b/pkgs/by-name/we/weasis/package.nix @@ -1,18 +1,22 @@ -{ lib -, stdenv -, fetchzip -, jre -, copyDesktopItems -, makeDesktopItem +{ + lib, + stdenv, + fetchzip, + jre, + copyDesktopItems, + makeDesktopItem, }: let throwSystem = throw "Unsupported system: ${stdenv.system}"; - platform = { - "x86_64-linux" = "linux-x86-64"; - }.${stdenv.system} or throwSystem; + platform = + { + "x86_64-linux" = "linux-x86-64"; + } + .${stdenv.system} or throwSystem; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "weasis"; version = "4.4.0"; @@ -72,7 +76,10 @@ in stdenv.mkDerivation rec { homepage = "https://weasis.org"; # Using changelog from releases as it is more accurate changelog = "https://github.com/nroduit/Weasis/releases/tag/v${version}"; - license = with lib.licenses; [ asl20 epl20 ]; + license = with lib.licenses; [ + asl20 + epl20 + ]; maintainers = [ ]; platforms = [ "x86_64-linux" ]; mainProgram = "Weasis"; diff --git a/pkgs/by-name/we/weather-icons/package.nix b/pkgs/by-name/we/weather-icons/package.nix index 00f9cebac121f1..ccafa275f0b7f5 100644 --- a/pkgs/by-name/we/weather-icons/package.nix +++ b/pkgs/by-name/we/weather-icons/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "weather-icons"; diff --git a/pkgs/by-name/we/weather/package.nix b/pkgs/by-name/we/weather/package.nix index 6f2d2045dd29fd..8f11d236ecba3f 100644 --- a/pkgs/by-name/we/weather/package.nix +++ b/pkgs/by-name/we/weather/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, python3, installShellFiles }: +{ + lib, + stdenv, + fetchurl, + python3, + installShellFiles, +}: stdenv.mkDerivation rec { version = "2.5.0"; diff --git a/pkgs/by-name/we/weave-gitops/package.nix b/pkgs/by-name/we/weave-gitops/package.nix index f26371d6471170..b70aa20dba6a49 100644 --- a/pkgs/by-name/we/weave-gitops/package.nix +++ b/pkgs/by-name/we/weave-gitops/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildGoModule, stdenv, installShellFiles }: +{ + lib, + fetchFromGitHub, + buildGoModule, + stdenv, + installShellFiles, +}: buildGoModule rec { pname = "weave-gitops"; @@ -11,7 +17,11 @@ buildGoModule rec { sha256 = "sha256-Gm4DIQK8T+dTwB5swdrD+SjGgy/wFQ/fJYdSqNDSy9c="; }; - ldflags = [ "-s" "-w" "-X github.com/weaveworks/weave-gitops/cmd/gitops/version.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/weaveworks/weave-gitops/cmd/gitops/version.Version=${version}" + ]; vendorHash = "sha256-RiPBlpEQ69fhVf3B0qHQ+zEtPIet/Y/Jp/HfaTrIssE="; diff --git a/pkgs/by-name/we/weaviate/package.nix b/pkgs/by-name/we/weaviate/package.nix index cef923a2411615..d0342f3146a632 100644 --- a/pkgs/by-name/we/weaviate/package.nix +++ b/pkgs/by-name/we/weaviate/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -18,7 +19,11 @@ buildGoModule rec { subPackages = [ "cmd/weaviate-server" ]; - ldflags = [ "-w" "-extldflags" "-static" ]; + ldflags = [ + "-w" + "-extldflags" + "-static" + ]; postInstall = '' ln -s $out/bin/weaviate-server $out/bin/weaviate diff --git a/pkgs/by-name/we/web-ext/package.nix b/pkgs/by-name/we/web-ext/package.nix index 5789d1e11ee2cd..5123992e38c650 100644 --- a/pkgs/by-name/we/web-ext/package.nix +++ b/pkgs/by-name/we/web-ext/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, runCommand -, web-ext +{ + lib, + buildNpmPackage, + fetchFromGitHub, + runCommand, + web-ext, }: buildNpmPackage rec { diff --git a/pkgs/by-name/we/webalizer/package.nix b/pkgs/by-name/we/webalizer/package.nix index 0ea806f29d3c97..8ce9dd3dd3a2bb 100644 --- a/pkgs/by-name/we/webalizer/package.nix +++ b/pkgs/by-name/we/webalizer/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, zlib, libpng, gd, geoip, db }: +{ + lib, + stdenv, + fetchurl, + zlib, + libpng, + gd, + geoip, + db, +}: stdenv.mkDerivation rec { pname = "webalizer"; @@ -15,13 +24,18 @@ stdenv.mkDerivation rec { installFlags = [ "MANDIR=\${out}/share/man/man1" ]; - preConfigure = - '' - substituteInPlace ./configure \ - --replace "--static" "" - ''; - - buildInputs = [ zlib libpng gd geoip db ]; + preConfigure = '' + substituteInPlace ./configure \ + --replace "--static" "" + ''; + + buildInputs = [ + zlib + libpng + gd + geoip + db + ]; configureFlags = [ "--enable-dns" diff --git a/pkgs/by-name/we/webanalyze/package.nix b/pkgs/by-name/we/webanalyze/package.nix index 427d84c5282db6..59582a061e3d3b 100644 --- a/pkgs/by-name/we/webanalyze/package.nix +++ b/pkgs/by-name/we/webanalyze/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/we/webcat/package.nix b/pkgs/by-name/we/webcat/package.nix index 2fff1266eb9cd1..b9af1445722691 100644 --- a/pkgs/by-name/we/webcat/package.nix +++ b/pkgs/by-name/we/webcat/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, asciidoctor, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + asciidoctor, + installShellFiles, +}: buildGoModule rec { pname = "webcat"; @@ -13,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-duVp/obT+5M4Dl3BAdSgRaP3+LKmS0y51loMMdoGysw="; - nativeBuildInputs = [ asciidoctor installShellFiles ]; + nativeBuildInputs = [ + asciidoctor + installShellFiles + ]; postInstall = '' make -C man man diff --git a/pkgs/by-name/we/webdav-server-rs/package.nix b/pkgs/by-name/we/webdav-server-rs/package.nix index e7e5b6a0edb809..c89dbded735c66 100644 --- a/pkgs/by-name/we/webdav-server-rs/package.nix +++ b/pkgs/by-name/we/webdav-server-rs/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, libtirpc -, pam -, rpcsvc-proto -, enablePAM ? stdenv.hostPlatform.isLinux +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + libtirpc, + pam, + rpcsvc-proto, + enablePAM ? stdenv.hostPlatform.isLinux, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/we/webex/package.nix b/pkgs/by-name/we/webex/package.nix index 3a03bef180a9a2..0b878d9004f9b8 100644 --- a/pkgs/by-name/we/webex/package.nix +++ b/pkgs/by-name/we/webex/package.nix @@ -1,57 +1,58 @@ -{ lib -, writeScript -, stdenv -, fetchurl -, alsa-lib -, at-spi2-atk -, at-spi2-core -, atk -, cairo -, cups -, dbus -, expat -, fontconfig -, freetype -, gdk-pixbuf -, glib -, gtk3 -, harfbuzz -, libdrm -, libgcrypt -, libglvnd -, libkrb5 -, libpulseaudio -, libsecret -, udev -, libxcb -, libxkbcommon -, libxcrypt-legacy -, lshw -, mesa -, nspr -, nss -, pango -, zlib -, libX11 -, libXcomposite -, libXcursor -, libXdamage -, libXext -, libXfixes -, libXi -, libXrandr -, libXrender -, libXtst -, libxshmfence -, xcbutil -, xcbutilimage -, xcbutilkeysyms -, xcbutilrenderutil -, xcbutilwm -, p7zip -, tbb -, wayland -, libXScrnSaver +{ + lib, + writeScript, + stdenv, + fetchurl, + alsa-lib, + at-spi2-atk, + at-spi2-core, + atk, + cairo, + cups, + dbus, + expat, + fontconfig, + freetype, + gdk-pixbuf, + glib, + gtk3, + harfbuzz, + libdrm, + libgcrypt, + libglvnd, + libkrb5, + libpulseaudio, + libsecret, + udev, + libxcb, + libxkbcommon, + libxcrypt-legacy, + lshw, + mesa, + nspr, + nss, + pango, + zlib, + libX11, + libXcomposite, + libXcursor, + libXdamage, + libXext, + libXfixes, + libXi, + libXrandr, + libXrender, + libXtst, + libxshmfence, + xcbutil, + xcbutilimage, + xcbutilkeysyms, + xcbutilrenderutil, + xcbutilwm, + p7zip, + tbb, + wayland, + libXScrnSaver, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/we/webfontkitgenerator/package.nix b/pkgs/by-name/we/webfontkitgenerator/package.nix index 22f2e5e77b84f8..9a807f3da04efb 100644 --- a/pkgs/by-name/we/webfontkitgenerator/package.nix +++ b/pkgs/by-name/we/webfontkitgenerator/package.nix @@ -1,22 +1,23 @@ -{ appstream-glib -, blueprint-compiler -, desktop-file-utils -, fetchFromGitHub -, gettext -, glib-networking -, gobject-introspection -, gtk4 -, gtksourceview5 -, lib -, libadwaita -, libsoup_3 -, meson -, ninja -, pkg-config -, python3 -, python3Packages -, stdenv -, wrapGAppsHook4 +{ + appstream-glib, + blueprint-compiler, + desktop-file-utils, + fetchFromGitHub, + gettext, + glib-networking, + gobject-introspection, + gtk4, + gtksourceview5, + lib, + libadwaita, + libsoup_3, + meson, + ninja, + pkg-config, + python3, + python3Packages, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { pname = "webfont-kit-generator"; @@ -48,11 +49,13 @@ stdenv.mkDerivation (finalAttrs: { gtksourceview5 libadwaita libsoup_3 - (python3.withPackages (ps: with ps; [ - brotli - fonttools - pygobject3 - ])) + (python3.withPackages ( + ps: with ps; [ + brotli + fonttools + pygobject3 + ] + )) ]; propagatedBuildInputs = [ diff --git a/pkgs/by-name/we/webfs/package.nix b/pkgs/by-name/we/webfs/package.nix index e3eb19a5d3490e..02862c43e02756 100644 --- a/pkgs/by-name/we/webfs/package.nix +++ b/pkgs/by-name/we/webfs/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, mailcap, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + mailcap, + openssl, +}: stdenv.mkDerivation { pname = "webfs"; diff --git a/pkgs/by-name/we/webhook/package.nix b/pkgs/by-name/we/webhook/package.nix index 2b61d877f0bc8f..d9ed2bb27b02f7 100644 --- a/pkgs/by-name/we/webhook/package.nix +++ b/pkgs/by-name/we/webhook/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/by-name/we/webmesh/package.nix b/pkgs/by-name/we/webmesh/package.nix index 25b51d29e73479..85ca63bd85095c 100644 --- a/pkgs/by-name/we/webmesh/package.nix +++ b/pkgs/by-name/we/webmesh/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, gitUpdater -, testers -, webmesh +{ + lib, + buildGoModule, + fetchFromGitHub, + gitUpdater, + testers, + webmesh, }: buildGoModule rec { @@ -21,7 +22,11 @@ buildGoModule rec { CGO_ENABLED = 0; - subPackages = [ "cmd/webmesh-node" "cmd/webmeshd" "cmd/wmctl" ]; + subPackages = [ + "cmd/webmesh-node" + "cmd/webmeshd" + "cmd/wmctl" + ]; ldflags = [ "-w" diff --git a/pkgs/by-name/we/webmetro/package.nix b/pkgs/by-name/we/webmetro/package.nix index f738c9e5040351..12c60fe2805005 100644 --- a/pkgs/by-name/we/webmetro/package.nix +++ b/pkgs/by-name/we/webmetro/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "webmetro"; @@ -16,12 +20,12 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Simple relay server for broadcasting a WebM stream"; longDescription = '' - Webmetro is a simple relay server for broadcasting a WebM stream - from one uploader to many downloaders, via HTTP. - The initialization segment is remembered, so that viewers can join - mid-stream. Cluster timestamps are rewritten to be monotonic, so multiple - (compatibly-encoded) webm files can be chained together without - clients needing to reconnect. + Webmetro is a simple relay server for broadcasting a WebM stream + from one uploader to many downloaders, via HTTP. + The initialization segment is remembered, so that viewers can join + mid-stream. Cluster timestamps are rewritten to be monotonic, so multiple + (compatibly-encoded) webm files can be chained together without + clients needing to reconnect. ''; license = with licenses; [ mit ]; maintainers = with maintainers; [ leenaars ]; diff --git a/pkgs/by-name/we/webp-pixbuf-loader/package.nix b/pkgs/by-name/we/webp-pixbuf-loader/package.nix index 78496c0e919e30..9448088c08c6c4 100644 --- a/pkgs/by-name/we/webp-pixbuf-loader/package.nix +++ b/pkgs/by-name/we/webp-pixbuf-loader/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, makeWrapper -, gdk-pixbuf -, libwebp +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + makeWrapper, + gdk-pixbuf, + libwebp, }: let @@ -47,20 +48,22 @@ stdenv.mkDerivation rec { --replace "@bindir@/gdk-pixbuf-thumbnailer" "$out/libexec/gdk-pixbuf-thumbnailer-webp" ''; - postInstall = '' - GDK_PIXBUF_MODULE_FILE="$out/${loadersPath}" \ - GDK_PIXBUF_MODULEDIR="$out/${moduleDir}" \ - gdk-pixbuf-query-loaders --update-cache + postInstall = + '' + GDK_PIXBUF_MODULE_FILE="$out/${loadersPath}" \ + GDK_PIXBUF_MODULEDIR="$out/${moduleDir}" \ + gdk-pixbuf-query-loaders --update-cache - # gdk-pixbuf disables the thumbnailer in cross-builds (https://gitlab.gnome.org/GNOME/gdk-pixbuf/-/commit/fc37708313a5fc52083cf10c9326f3509d67701f) - # and therefore makeWrapper will fail because 'gdk-pixbuf-thumbnailer' the executable does not exist. - '' + lib.optionalString (stdenv.hostPlatform == stdenv.buildPlatform) '' - # It assumes gdk-pixbuf-thumbnailer can find the webp loader in the loaders.cache referenced by environment variable, breaking containment. - # So we replace it with a wrapped executable. - mkdir -p "$out/bin" - makeWrapper "${gdk-pixbuf}/bin/gdk-pixbuf-thumbnailer" "$out/libexec/gdk-pixbuf-thumbnailer-webp" \ - --set GDK_PIXBUF_MODULE_FILE "$out/${loadersPath}" - ''; + # gdk-pixbuf disables the thumbnailer in cross-builds (https://gitlab.gnome.org/GNOME/gdk-pixbuf/-/commit/fc37708313a5fc52083cf10c9326f3509d67701f) + # and therefore makeWrapper will fail because 'gdk-pixbuf-thumbnailer' the executable does not exist. + '' + + lib.optionalString (stdenv.hostPlatform == stdenv.buildPlatform) '' + # It assumes gdk-pixbuf-thumbnailer can find the webp loader in the loaders.cache referenced by environment variable, breaking containment. + # So we replace it with a wrapped executable. + mkdir -p "$out/bin" + makeWrapper "${gdk-pixbuf}/bin/gdk-pixbuf-thumbnailer" "$out/libexec/gdk-pixbuf-thumbnailer-webp" \ + --set GDK_PIXBUF_MODULE_FILE "$out/${loadersPath}" + ''; meta = with lib; { description = "WebP GDK Pixbuf Loader library"; diff --git a/pkgs/by-name/we/websocketd/package.nix b/pkgs/by-name/we/websocketd/package.nix index 92a65320b8c56a..78e5db1f1ed927 100644 --- a/pkgs/by-name/we/websocketd/package.nix +++ b/pkgs/by-name/we/websocketd/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "websocketd"; diff --git a/pkgs/by-name/we/websocketpp/package.nix b/pkgs/by-name/we/websocketpp/package.nix index c325ade26e5ce7..6b933480b0ba84 100644 --- a/pkgs/by-name/we/websocketpp/package.nix +++ b/pkgs/by-name/we/websocketpp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "websocket++"; diff --git a/pkgs/by-name/we/websploit/package.nix b/pkgs/by-name/we/websploit/package.nix index c653b15658c083..a868762e58e83f 100644 --- a/pkgs/by-name/we/websploit/package.nix +++ b/pkgs/by-name/we/websploit/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/we/webtorrent_desktop/package.nix b/pkgs/by-name/we/webtorrent_desktop/package.nix index 9fd34a1eed1fcd..ad5d289f727a99 100644 --- a/pkgs/by-name/we/webtorrent_desktop/package.nix +++ b/pkgs/by-name/we/webtorrent_desktop/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, electron, buildNpmPackage, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + electron, + buildNpmPackage, + fetchFromGitHub, + fetchpatch, +}: buildNpmPackage { pname = "webtorrent-desktop"; diff --git a/pkgs/by-name/we/webwormhole/package.nix b/pkgs/by-name/we/webwormhole/package.nix index 7e1fe8cbfb27df..f5a7f58a99803b 100644 --- a/pkgs/by-name/we/webwormhole/package.nix +++ b/pkgs/by-name/we/webwormhole/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "webwormhole"; diff --git a/pkgs/by-name/we/wechat-uos/package.nix b/pkgs/by-name/we/wechat-uos/package.nix index 0ff4edb5cd3b49..c505dac72b2827 100644 --- a/pkgs/by-name/we/wechat-uos/package.nix +++ b/pkgs/by-name/we/wechat-uos/package.nix @@ -1,49 +1,50 @@ -{ stdenvNoCC -, stdenv -, lib -, fetchurl -, dpkg -, nss -, nspr -, xorg -, pango -, zlib -, atkmm -, libdrm -, libxkbcommon -, xcbutilwm -, xcbutilimage -, xcbutilkeysyms -, xcbutilrenderutil -, mesa -, alsa-lib -, wayland -, atk -, qt6 -, at-spi2-atk -, at-spi2-core -, dbus -, cups -, gtk3 -, libxml2 -, cairo -, freetype -, fontconfig -, vulkan-loader -, gdk-pixbuf -, libexif -, ffmpeg -, pulseaudio -, systemd -, libuuid -, expat -, bzip2 -, glib -, libva -, libGL -, libnotify -, buildFHSEnv -, writeShellScript +{ + stdenvNoCC, + stdenv, + lib, + fetchurl, + dpkg, + nss, + nspr, + xorg, + pango, + zlib, + atkmm, + libdrm, + libxkbcommon, + xcbutilwm, + xcbutilimage, + xcbutilkeysyms, + xcbutilrenderutil, + mesa, + alsa-lib, + wayland, + atk, + qt6, + at-spi2-atk, + at-spi2-core, + dbus, + cups, + gtk3, + libxml2, + cairo, + freetype, + fontconfig, + vulkan-loader, + gdk-pixbuf, + libexif, + ffmpeg, + pulseaudio, + systemd, + libuuid, + expat, + bzip2, + glib, + libva, + libGL, + libnotify, + buildFHSEnv, + writeShellScript, }: let # zerocallusedregs hardening breaks WeChat @@ -132,12 +133,12 @@ let sources = import ./sources.nix; - wechat = stdenvNoCC.mkDerivation - rec { - pname = "wechat-uos"; - version = sources.version; + wechat = stdenvNoCC.mkDerivation rec { + pname = "wechat-uos"; + version = sources.version; - src = { + src = + { x86_64-linux = fetchurl { url = sources.amd64_url; hash = sources.amd64_hash; @@ -150,38 +151,46 @@ let url = sources.loongarch64_url; hash = sources.loongarch64_hash; }; - }.${stdenv.system} or (throw "${pname}-${version}: ${stdenv.system} is unsupported."); + } + .${stdenv.system} or (throw "${pname}-${version}: ${stdenv.system} is unsupported."); - nativeBuildInputs = [ dpkg ]; + nativeBuildInputs = [ dpkg ]; - unpackPhase = '' - runHook preUnpack + unpackPhase = '' + runHook preUnpack - dpkg -x $src ./wechat-uos + dpkg -x $src ./wechat-uos - runHook postUnpack - ''; + runHook postUnpack + ''; - # Use ln for license to prevent being garbage collection - installPhase = '' - runHook preInstall - mkdir -p $out + # Use ln for license to prevent being garbage collection + installPhase = '' + runHook preInstall + mkdir -p $out - cp -r wechat-uos/* $out + cp -r wechat-uos/* $out - runHook postInstall - ''; + runHook postInstall + ''; - meta = with lib; { - description = "Messaging app"; - homepage = "https://weixin.qq.com/"; - license = licenses.unfree; - platforms = [ "x86_64-linux" "aarch64-linux" "loongarch64-linux" ]; - sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - maintainers = with maintainers; [ pokon548 xddxdd ]; - mainProgram = "wechat-uos"; - }; + meta = with lib; { + description = "Messaging app"; + homepage = "https://weixin.qq.com/"; + license = licenses.unfree; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "loongarch64-linux" + ]; + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; + maintainers = with maintainers; [ + pokon548 + xddxdd + ]; + mainProgram = "wechat-uos"; }; + }; in buildFHSEnv { inherit (wechat) pname version meta; @@ -214,5 +223,10 @@ buildFHSEnv { passthru.updateScript = ./update.sh; - extraOutputsToInstall = [ "usr" "var/lib/uos" "var/uos" "etc" ]; + extraOutputsToInstall = [ + "usr" + "var/lib/uos" + "var/uos" + "etc" + ]; } diff --git a/pkgs/by-name/we/weevely/package.nix b/pkgs/by-name/we/weevely/package.nix index bd640b2723b6be..ba72ac83cfb56e 100644 --- a/pkgs/by-name/we/weevely/package.nix +++ b/pkgs/by-name/we/weevely/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, python3 -, python3Packages -, makeWrapper -, installShellFiles +{ + lib, + fetchFromGitHub, + python3, + python3Packages, + makeWrapper, + installShellFiles, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/we/weggli/package.nix b/pkgs/by-name/we/weggli/package.nix index 63f9ddd0f2071c..a80fd37cc09917 100644 --- a/pkgs/by-name/we/weggli/package.nix +++ b/pkgs/by-name/we/weggli/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, testers -, weggli +{ + lib, + rustPlatform, + fetchFromGitHub, + testers, + weggli, }: rustPlatform.buildRustPackage rec { @@ -30,6 +31,9 @@ rustPlatform.buildRustPackage rec { changelog = "https://github.com/weggli-rs/weggli/releases/tag/v${version}"; mainProgram = "weggli"; license = licenses.asl20; - maintainers = with maintainers; [ arturcygan mfrw ]; + maintainers = with maintainers; [ + arturcygan + mfrw + ]; }; } diff --git a/pkgs/by-name/we/wego/package.nix b/pkgs/by-name/we/wego/package.nix index ab7debc5d22e78..107ff1421bc71e 100644 --- a/pkgs/by-name/we/wego/package.nix +++ b/pkgs/by-name/we/wego/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "wego"; diff --git a/pkgs/by-name/we/weidu/package.nix b/pkgs/by-name/we/weidu/package.nix index 580eea0670317c..a8ca4c2422dee0 100644 --- a/pkgs/by-name/we/weidu/package.nix +++ b/pkgs/by-name/we/weidu/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, elkhound -, ocaml-ng -, perl -, which -, gnumake42 +{ + stdenv, + lib, + fetchFromGitHub, + elkhound, + ocaml-ng, + perl, + which, + gnumake42, }: let @@ -37,9 +38,19 @@ stdenv.mkDerivation rec { sed -i "20,21d;s/old_hash_param/hash_param/" hashtbl-4.03.0/myhashtbl.ml ''; - nativeBuildInputs = [ elkhound ocaml' perl which gnumake42 ]; + nativeBuildInputs = [ + elkhound + ocaml' + perl + which + gnumake42 + ]; - buildFlags = [ "weidu" "weinstall" "tolower" ]; + buildFlags = [ + "weidu" + "weinstall" + "tolower" + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/we/welkin/package.nix b/pkgs/by-name/we/welkin/package.nix index a35d4c48ee37ac..8ccb5fb7de7da5 100644 --- a/pkgs/by-name/we/welkin/package.nix +++ b/pkgs/by-name/we/welkin/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchsvn, jre, makeWrapper }: +{ + lib, + stdenv, + fetchsvn, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "welkin"; @@ -30,7 +36,7 @@ stdenv.mkDerivation rec { maintainers = with lib.maintainers; [ raskin ]; - hydraPlatforms = []; + hydraPlatforms = [ ]; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; license = lib.licenses.bsd3; platforms = with lib.platforms; unix; diff --git a/pkgs/by-name/we/wemux/package.nix b/pkgs/by-name/we/wemux/package.nix index 99adf8bb0823d6..af160816c27f00 100644 --- a/pkgs/by-name/we/wemux/package.nix +++ b/pkgs/by-name/we/wemux/package.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, tmux, installShellFiles }: +{ + stdenv, + lib, + fetchFromGitHub, + tmux, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "wemux"; diff --git a/pkgs/by-name/we/wesher/package.nix b/pkgs/by-name/we/wesher/package.nix index e9b243e325e481..0d25f819d5b684 100644 --- a/pkgs/by-name/we/wesher/package.nix +++ b/pkgs/by-name/we/wesher/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -17,7 +18,9 @@ buildGoModule rec { vendorHash = "sha256-BZzhBC4C0OoAxUEDROkggCQF35C9Z4+0/Jk0ZD8Hz1s="; ldflags = [ - "-s" "-w" "-X main.version=${version}" + "-s" + "-w" + "-X main.version=${version}" ]; meta = with lib; { @@ -25,7 +28,7 @@ buildGoModule rec { homepage = "https://github.com/costela/wesher"; license = licenses.gpl3Only; maintainers = with maintainers; [ tylerjl ]; - platforms = platforms.linux; + platforms = platforms.linux; mainProgram = "wesher"; }; } diff --git a/pkgs/by-name/we/weston/package.nix b/pkgs/by-name/we/weston/package.nix index 8cd8ba35e31b33..6d3029025e559b 100644 --- a/pkgs/by-name/we/weston/package.nix +++ b/pkgs/by-name/we/weston/package.nix @@ -1,19 +1,49 @@ -{ lib, stdenv, fetchurl -, meson, ninja, pkg-config, python3, wayland-scanner -, cairo, libGL, libdisplay-info, libdrm, libevdev, libinput, libxkbcommon, mesa -, seatd, wayland, wayland-protocols, xcbutilcursor +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + python3, + wayland-scanner, + cairo, + libGL, + libdisplay-info, + libdrm, + libevdev, + libinput, + libxkbcommon, + mesa, + seatd, + wayland, + wayland-protocols, + xcbutilcursor, -, demoSupport ? true -, jpegSupport ? true, libjpeg -, lcmsSupport ? true, lcms2 -, pangoSupport ? true, pango -, pipewireSupport ? true, pipewire -, rdpSupport ? true, freerdp -, remotingSupport ? true, gst_all_1 -, vaapiSupport ? true, libva -, vncSupport ? true, aml, neatvnc, pam -, webpSupport ? true, libwebp -, xwaylandSupport ? true, libXcursor, xwayland + demoSupport ? true, + jpegSupport ? true, + libjpeg, + lcmsSupport ? true, + lcms2, + pangoSupport ? true, + pango, + pipewireSupport ? true, + pipewire, + rdpSupport ? true, + freerdp, + remotingSupport ? true, + gst_all_1, + vaapiSupport ? true, + libva, + vncSupport ? true, + aml, + neatvnc, + pam, + webpSupport ? true, + libwebp, + xwaylandSupport ? true, + libXcursor, + xwayland, }: stdenv.mkDerivation rec { @@ -26,38 +56,68 @@ stdenv.mkDerivation rec { }; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson ninja pkg-config python3 wayland-scanner ]; - buildInputs = [ - cairo libGL libdisplay-info libdrm libevdev libinput libxkbcommon mesa seatd - wayland wayland-protocols - ] ++ lib.optional jpegSupport libjpeg + nativeBuildInputs = [ + meson + ninja + pkg-config + python3 + wayland-scanner + ]; + buildInputs = + [ + cairo + libGL + libdisplay-info + libdrm + libevdev + libinput + libxkbcommon + mesa + seatd + wayland + wayland-protocols + ] + ++ lib.optional jpegSupport libjpeg ++ lib.optional lcmsSupport lcms2 ++ lib.optional pangoSupport pango ++ lib.optional pipewireSupport pipewire ++ lib.optional rdpSupport freerdp - ++ lib.optionals remotingSupport [ gst_all_1.gstreamer gst_all_1.gst-plugins-base ] + ++ lib.optionals remotingSupport [ + gst_all_1.gstreamer + gst_all_1.gst-plugins-base + ] ++ lib.optional vaapiSupport libva - ++ lib.optionals vncSupport [ aml neatvnc pam ] + ++ lib.optionals vncSupport [ + aml + neatvnc + pam + ] ++ lib.optional webpSupport libwebp - ++ lib.optionals xwaylandSupport [ libXcursor xcbutilcursor xwayland ]; + ++ lib.optionals xwaylandSupport [ + libXcursor + xcbutilcursor + xwayland + ]; - mesonFlags= [ - (lib.mesonBool "backend-drm-screencast-vaapi" vaapiSupport) - (lib.mesonBool "backend-pipewire" pipewireSupport) - (lib.mesonBool "backend-rdp" rdpSupport) - (lib.mesonBool "backend-vnc" vncSupport) - (lib.mesonBool "color-management-lcms" lcmsSupport) - (lib.mesonBool "demo-clients" demoSupport) - (lib.mesonBool "image-jpeg" jpegSupport) - (lib.mesonBool "image-webp" webpSupport) - (lib.mesonBool "pipewire" pipewireSupport) - (lib.mesonBool "remoting" remotingSupport) - (lib.mesonOption "simple-clients" "") - (lib.mesonBool "test-junit-xml" false) - (lib.mesonBool "xwayland" xwaylandSupport) - ] ++ lib.optionals xwaylandSupport [ - (lib.mesonOption "xwayland-path" (lib.getExe xwayland)) - ]; + mesonFlags = + [ + (lib.mesonBool "backend-drm-screencast-vaapi" vaapiSupport) + (lib.mesonBool "backend-pipewire" pipewireSupport) + (lib.mesonBool "backend-rdp" rdpSupport) + (lib.mesonBool "backend-vnc" vncSupport) + (lib.mesonBool "color-management-lcms" lcmsSupport) + (lib.mesonBool "demo-clients" demoSupport) + (lib.mesonBool "image-jpeg" jpegSupport) + (lib.mesonBool "image-webp" webpSupport) + (lib.mesonBool "pipewire" pipewireSupport) + (lib.mesonBool "remoting" remotingSupport) + (lib.mesonOption "simple-clients" "") + (lib.mesonBool "test-junit-xml" false) + (lib.mesonBool "xwayland" xwaylandSupport) + ] + ++ lib.optionals xwaylandSupport [ + (lib.mesonOption "xwayland-path" (lib.getExe xwayland)) + ]; passthru.providedSessions = [ "weston" ]; @@ -77,6 +137,9 @@ stdenv.mkDerivation rec { license = licenses.mit; # Expat version platforms = platforms.linux; mainProgram = "weston"; - maintainers = with maintainers; [ primeos qyliss ]; + maintainers = with maintainers; [ + primeos + qyliss + ]; }; } diff --git a/pkgs/by-name/we/wev/package.nix b/pkgs/by-name/we/wev/package.nix index c4913e6f75f50c..b758b17d0744ae 100644 --- a/pkgs/by-name/we/wev/package.nix +++ b/pkgs/by-name/we/wev/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromSourcehut -, pkg-config -, scdoc -, wayland-scanner -, wayland -, wayland-protocols -, libxkbcommon +{ + lib, + stdenv, + fetchFromSourcehut, + pkg-config, + scdoc, + wayland-scanner, + wayland, + wayland-protocols, + libxkbcommon, }: stdenv.mkDerivation rec { @@ -25,8 +26,16 @@ stdenv.mkDerivation rec { depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ pkg-config scdoc wayland-scanner ]; - buildInputs = [ wayland wayland-protocols libxkbcommon ]; + nativeBuildInputs = [ + pkg-config + scdoc + wayland-scanner + ]; + buildInputs = [ + wayland + wayland-protocols + libxkbcommon + ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/wf/wfa2-lib/package.nix b/pkgs/by-name/wf/wfa2-lib/package.nix index 519343ff5a2070..eae3514a8d5dda 100644 --- a/pkgs/by-name/wf/wfa2-lib/package.nix +++ b/pkgs/by-name/wf/wfa2-lib/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, llvmPackages -, enableOpenMP ? true +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + llvmPackages, + enableOpenMP ? true, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/wg/wg-access-server/package.nix b/pkgs/by-name/wg/wg-access-server/package.nix index e10210f31da4c6..a8eceabe9a6d09 100644 --- a/pkgs/by-name/wg/wg-access-server/package.nix +++ b/pkgs/by-name/wg/wg-access-server/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, buildNpmPackage -, fetchFromGitHub -, makeWrapper -, iptables -, nixosTests +{ + lib, + buildGoModule, + buildNpmPackage, + fetchFromGitHub, + makeWrapper, + iptables, + nixosTests, }: buildGoModule rec { @@ -23,7 +24,10 @@ buildGoModule rec { CGO_ENABLED = 1; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/by-name/wg/wg-bond/package.nix b/pkgs/by-name/wg/wg-bond/package.nix index 88e30976b307e7..ab5c3eb3273937 100644 --- a/pkgs/by-name/wg/wg-bond/package.nix +++ b/pkgs/by-name/wg/wg-bond/package.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitLab, wireguard-tools, makeWrapper }: +{ + lib, + rustPlatform, + fetchFromGitLab, + wireguard-tools, + makeWrapper, +}: rustPlatform.buildRustPackage rec { pname = "wg-bond"; version = "0.2.0"; @@ -14,9 +20,7 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ makeWrapper ]; postInstall = '' - wrapProgram $out/bin/wg-bond --set PATH ${ - lib.makeBinPath [ wireguard-tools ] - } + wrapProgram $out/bin/wg-bond --set PATH ${lib.makeBinPath [ wireguard-tools ]} ''; meta = with lib; { diff --git a/pkgs/by-name/wg/wg-friendly-peer-names/package.nix b/pkgs/by-name/wg/wg-friendly-peer-names/package.nix index ebbd898576d37e..e37780f3ac4ae8 100644 --- a/pkgs/by-name/wg/wg-friendly-peer-names/package.nix +++ b/pkgs/by-name/wg/wg-friendly-peer-names/package.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, wireguard-tools +{ + stdenv, + lib, + fetchFromGitHub, + wireguard-tools, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/wg/wgautomesh/package.nix b/pkgs/by-name/wg/wgautomesh/package.nix index ed4f2b7d3cd98b..f3b80cfd5b23a9 100644 --- a/pkgs/by-name/wg/wgautomesh/package.nix +++ b/pkgs/by-name/wg/wgautomesh/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitea -, rustPlatform +{ + lib, + fetchFromGitea, + rustPlatform, }: rustPlatform.buildRustPackage rec { pname = "wgautomesh"; diff --git a/pkgs/by-name/wg/wgcf/package.nix b/pkgs/by-name/wg/wgcf/package.nix index f5dbd07861fe47..361083c5bfb35b 100644 --- a/pkgs/by-name/wg/wgcf/package.nix +++ b/pkgs/by-name/wg/wgcf/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "wgcf"; diff --git a/pkgs/by-name/wg/wget2/package.nix b/pkgs/by-name/wg/wget2/package.nix index 7445b425f034a0..07f3a999ee6ce6 100644 --- a/pkgs/by-name/wg/wget2/package.nix +++ b/pkgs/by-name/wg/wget2/package.nix @@ -1,35 +1,40 @@ -{ lib -, stdenv -, fetchFromGitLab +{ + lib, + stdenv, + fetchFromGitLab, # build support -, autoreconfHook -, flex -, gnulib -, pkg-config -, texinfo + autoreconfHook, + flex, + gnulib, + pkg-config, + texinfo, # libraries -, brotli -, bzip2 -, darwin -, gpgme -, libhsts -, libidn2 -, libpsl -, lzip -, nghttp2 -, openssl -, pcre2 -, sslSupport ? true -, xz -, zlib -, zstd + brotli, + bzip2, + darwin, + gpgme, + libhsts, + libidn2, + libpsl, + lzip, + nghttp2, + openssl, + pcre2, + sslSupport ? true, + xz, + zlib, + zstd, }: stdenv.mkDerivation rec { pname = "wget2"; version = "2.1.0"; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; src = fetchFromGitLab { owner = "gnuwget"; @@ -54,23 +59,26 @@ stdenv.mkDerivation rec { texinfo ]; - buildInputs = [ - brotli - bzip2 - gpgme - libhsts - libidn2 - libpsl - nghttp2 - pcre2 - xz - zlib - zstd - ] ++ lib.optionals sslSupport [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreServices - ]; + buildInputs = + [ + brotli + bzip2 + gpgme + libhsts + libidn2 + libpsl + nghttp2 + pcre2 + xz + zlib + zstd + ] + ++ lib.optionals sslSupport [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreServices + ]; # TODO: include translation files autoreconfPhase = '' @@ -100,7 +108,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://gitlab.com/gnuwget/wget2"; # wget2 GPLv3+; libwget LGPLv3+ - license = with licenses; [ gpl3Plus lgpl3Plus ]; + license = with licenses; [ + gpl3Plus + lgpl3Plus + ]; maintainers = with maintainers; [ SuperSandro2000 ]; mainProgram = "wget2"; }; diff --git a/pkgs/by-name/wg/wgetpaste/package.nix b/pkgs/by-name/wg/wgetpaste/package.nix index 8ca014e0d5f586..e08de62dd14ab7 100644 --- a/pkgs/by-name/wg/wgetpaste/package.nix +++ b/pkgs/by-name/wg/wgetpaste/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, wget, bash }: +{ + lib, + stdenv, + fetchurl, + wget, + bash, +}: stdenv.mkDerivation rec { pname = "wgetpaste"; @@ -25,7 +31,10 @@ stdenv.mkDerivation rec { mainProgram = "wgetpaste"; homepage = "https://github.com/zlin/wgetpaste"; license = lib.licenses.publicDomain; - maintainers = with lib.maintainers; [ qknight domenkozar ]; + maintainers = with lib.maintainers; [ + qknight + domenkozar + ]; platforms = lib.platforms.all; }; } diff --git a/pkgs/by-name/wg/wgo/package.nix b/pkgs/by-name/wg/wgo/package.nix index 135f11ca125cff..c6c007e6e33987 100644 --- a/pkgs/by-name/wg/wgo/package.nix +++ b/pkgs/by-name/wg/wgo/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: let @@ -19,7 +20,10 @@ buildGoModule { vendorHash = "sha256-w6UJxZToHbbQmuXkyqFzyssFcE+7uVNqOuIF/XKdEsU="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; subPackages = [ "." ]; diff --git a/pkgs/by-name/wh/whatfiles/package.nix b/pkgs/by-name/wh/whatfiles/package.nix index 73289f95f7aa58..ff4b74ad483534 100644 --- a/pkgs/by-name/wh/whatfiles/package.nix +++ b/pkgs/by-name/wh/whatfiles/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/wh/whatip/package.nix b/pkgs/by-name/wh/whatip/package.nix index 85a2fdf3f7b370..7acf9236830dc3 100644 --- a/pkgs/by-name/wh/whatip/package.nix +++ b/pkgs/by-name/wh/whatip/package.nix @@ -1,18 +1,19 @@ -{ lib -, fetchFromGitLab -, python3 -, meson -, ninja -, pkg-config -, glib -, gtk4 -, libadwaita -, librsvg -, blueprint-compiler -, gobject-introspection -, wrapGAppsHook4 -, appstream-glib -, desktop-file-utils +{ + lib, + fetchFromGitLab, + python3, + meson, + ninja, + pkg-config, + glib, + gtk4, + libadwaita, + librsvg, + blueprint-compiler, + gobject-introspection, + wrapGAppsHook4, + appstream-glib, + desktop-file-utils, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/wh/whatsapp-chat-exporter/package.nix b/pkgs/by-name/wh/whatsapp-chat-exporter/package.nix index 289fdeec7bf70f..2e2662d80a354a 100644 --- a/pkgs/by-name/wh/whatsapp-chat-exporter/package.nix +++ b/pkgs/by-name/wh/whatsapp-chat-exporter/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/wh/whatsapp-emoji-font/package.nix b/pkgs/by-name/wh/whatsapp-emoji-font/package.nix index bf70c0271c9322..711d03d5151616 100644 --- a/pkgs/by-name/wh/whatsapp-emoji-font/package.nix +++ b/pkgs/by-name/wh/whatsapp-emoji-font/package.nix @@ -1,12 +1,13 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, imagemagick -, nix-update-script -, pngquant -, python3Packages -, which -, zopfli +{ + stdenvNoCC, + lib, + fetchFromGitHub, + imagemagick, + nix-update-script, + pngquant, + python3Packages, + which, + zopfli, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/wh/whatsapp-for-linux/package.nix b/pkgs/by-name/wh/whatsapp-for-linux/package.nix index e82fa4f676139b..b7bd51e94a111f 100644 --- a/pkgs/by-name/wh/whatsapp-for-linux/package.nix +++ b/pkgs/by-name/wh/whatsapp-for-linux/package.nix @@ -1,28 +1,29 @@ -{ fetchFromGitHub -, lib -, stdenv -, cmake -, glib-networking -, gst_all_1 -, gtkmm3 -, libayatana-appindicator -, libcanberra -, libepoxy -, libpsl -, libdatrie -, libdeflate -, libselinux -, libsepol -, libsysprof-capture -, libthai -, libxkbcommon -, sqlite -, pcre -, pcre2 -, pkg-config -, webkitgtk_4_0 -, wrapGAppsHook3 -, xorg +{ + fetchFromGitHub, + lib, + stdenv, + cmake, + glib-networking, + gst_all_1, + gtkmm3, + libayatana-appindicator, + libcanberra, + libepoxy, + libpsl, + libdatrie, + libdeflate, + libselinux, + libsepol, + libsysprof-capture, + libthai, + libxkbcommon, + sqlite, + pcre, + pcre2, + pkg-config, + webkitgtk_4_0, + wrapGAppsHook3, + xorg, }: stdenv.mkDerivation (finalAttrs: { @@ -74,6 +75,9 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "whatsapp-for-linux"; license = lib.licenses.gpl3Only; maintainers = with lib.maintainers; [ bartuka ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; }; }) diff --git a/pkgs/by-name/wh/when/package.nix b/pkgs/by-name/wh/when/package.nix index 91f480255d6c70..d52a42fdf01afa 100644 --- a/pkgs/by-name/wh/when/package.nix +++ b/pkgs/by-name/wh/when/package.nix @@ -1,19 +1,20 @@ -{ lib -, stdenvNoCC -, perl -, installShellFiles -, fetchFromBitbucket +{ + lib, + stdenvNoCC, + perl, + installShellFiles, + fetchFromBitbucket, }: stdenvNoCC.mkDerivation (finalAttrs: { - pname = "when"; + pname = "when"; version = "1.1.45"; src = fetchFromBitbucket { - repo = "when"; + repo = "when"; owner = "ben-crowell"; - rev = finalAttrs.version; - hash = "sha256-+ggYjY6/aTUrdvREn0TTQ4Pu/VR4QTjflDaicRXuOMs="; + rev = finalAttrs.version; + hash = "sha256-+ggYjY6/aTUrdvREn0TTQ4Pu/VR4QTjflDaicRXuOMs="; }; buildInputs = [ perl ]; @@ -21,24 +22,24 @@ stdenvNoCC.mkDerivation (finalAttrs: { nativeBuildInputs = [ installShellFiles ]; postBuild = '' - pod2man $src/when when.1 + pod2man $src/when when.1 ''; installPhase = '' - runHook preInstall + runHook preInstall - install -Dm755 when $out/bin/when - installManPage when.1 + install -Dm755 when $out/bin/when + installManPage when.1 - runHook postInstall + runHook postInstall ''; meta = with lib; { description = "Extremely simple personal calendar program"; - homepage = "https://www.lightandmatter.com/when/when.html"; - license = licenses.gpl2Only; + homepage = "https://www.lightandmatter.com/when/when.html"; + license = licenses.gpl2Only; mainProgram = "when"; maintainers = with maintainers; [ vonixxx ]; - platforms = platforms.all; + platforms = platforms.all; }; }) diff --git a/pkgs/by-name/wh/whereami/package.nix b/pkgs/by-name/wh/whereami/package.nix index f68895ca17d034..5758abeccc66e1 100644 --- a/pkgs/by-name/wh/whereami/package.nix +++ b/pkgs/by-name/wh/whereami/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, fixDarwinDylibNames +{ + lib, + stdenv, + fetchFromGitHub, + fixDarwinDylibNames, }: let libExt = stdenv.hostPlatform.extensions.sharedLibrary; @@ -40,7 +41,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Locate the current executable and running module/library"; homepage = "https://github.com/gpakosz/whereami"; - license = with licenses; [ mit wtfpl ]; + license = with licenses; [ + mit + wtfpl + ]; maintainers = with maintainers; [ emilytrau ]; platforms = platforms.all; }; diff --git a/pkgs/by-name/wh/which/package.nix b/pkgs/by-name/wh/which/package.nix index 831791a2f8be6c..ae9deecdec54a8 100644 --- a/pkgs/by-name/wh/which/package.nix +++ b/pkgs/by-name/wh/which/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "which"; diff --git a/pkgs/by-name/wh/whipper/package.nix b/pkgs/by-name/wh/whipper/package.nix index b6ff1f45440c7c..1d9019d97773ff 100644 --- a/pkgs/by-name/wh/whipper/package.nix +++ b/pkgs/by-name/wh/whipper/package.nix @@ -1,24 +1,32 @@ -{ lib -, python3 -, fetchFromGitHub -, fetchpatch -, installShellFiles -, wrapGAppsNoGuiHook -, gobject-introspection -, libcdio-paranoia -, cdrdao -, libsndfile -, glib -, flac -, sox -, util-linux -, testers -, whipper +{ + lib, + python3, + fetchFromGitHub, + fetchpatch, + installShellFiles, + wrapGAppsNoGuiHook, + gobject-introspection, + libcdio-paranoia, + cdrdao, + libsndfile, + glib, + flac, + sox, + util-linux, + testers, + whipper, }: let - bins = [ libcdio-paranoia cdrdao flac sox util-linux ]; -in python3.pkgs.buildPythonApplication rec { + bins = [ + libcdio-paranoia + cdrdao + flac + sox + util-linux + ]; +in +python3.pkgs.buildPythonApplication rec { pname = "whipper"; version = "0.10.0"; pyproject = true; @@ -61,21 +69,33 @@ in python3.pkgs.buildPythonApplication rec { setuptools ]; - buildInputs = [ libsndfile glib ]; + buildInputs = [ + libsndfile + glib + ]; - nativeCheckInputs = with python3.pkgs; [ - twisted - pytestCheckHook - ] ++ bins; + nativeCheckInputs = + with python3.pkgs; + [ + twisted + pytestCheckHook + ] + ++ bins; makeWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath bins) + "--prefix" + "PATH" + ":" + (lib.makeBinPath bins) "\${gappsWrapperArgs[@]}" ]; dontWrapGApps = true; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; postBuild = '' make -C man ''; diff --git a/pkgs/by-name/wh/whisper/package.nix b/pkgs/by-name/wh/whisper/package.nix index 6c8bb21df6a527..1e274675e1e636 100644 --- a/pkgs/by-name/wh/whisper/package.nix +++ b/pkgs/by-name/wh/whisper/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "whisper"; diff --git a/pkgs/by-name/wh/whitebophir/package.nix b/pkgs/by-name/wh/whitebophir/package.nix index b3401ff78fc742..5457e64f5267e9 100644 --- a/pkgs/by-name/wh/whitebophir/package.nix +++ b/pkgs/by-name/wh/whitebophir/package.nix @@ -1,13 +1,15 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, nodejs_20 -, runtimeShell +{ + lib, + buildNpmPackage, + fetchFromGitHub, + nodejs_20, + runtimeShell, }: let nodejs = nodejs_20; -in buildNpmPackage rec { +in +buildNpmPackage rec { pname = "whitebophir"; version = "1.19.1"; diff --git a/pkgs/by-name/wh/whitesur-gtk-theme/package.nix b/pkgs/by-name/wh/whitesur-gtk-theme/package.nix index d461bebcf5b6a5..a79e58a143c584 100644 --- a/pkgs/by-name/wh/whitesur-gtk-theme/package.nix +++ b/pkgs/by-name/wh/whitesur-gtk-theme/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchFromGitHub -, gitUpdater -, dialog -, glib -, gnome-themes-extra -, jdupes -, libxml2 -, sassc -, util-linux -, altVariants ? [] # default: normal -, colorVariants ? [] # default: all -, opacityVariants ? [] # default: all -, themeVariants ? [] # default: default (BigSur-like theme) -, schemeVariants ? [] # default: standard -, iconVariant ? null # default: standard (Apple logo) -, nautilusStyle ? null # default: stable (BigSur-like style) -, panelOpacity ? null # default: 15% -, panelSize ? null # default: 32px -, roundedMaxWindow ? false # default: false -, darkerColor ? false # default = false +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + dialog, + glib, + gnome-themes-extra, + jdupes, + libxml2, + sassc, + util-linux, + altVariants ? [ ], # default: normal + colorVariants ? [ ], # default: all + opacityVariants ? [ ], # default: all + themeVariants ? [ ], # default: default (BigSur-like theme) + schemeVariants ? [ ], # default: standard + iconVariant ? null, # default: standard (Apple logo) + nautilusStyle ? null, # default: stable (BigSur-like style) + panelOpacity ? null, # default: 15% + panelSize ? null, # default: 32px + roundedMaxWindow ? false, # default: false + darkerColor ? false, # default = false }: let @@ -28,84 +29,138 @@ let in lib.checkListOfEnum "${pname}: window control buttons variants" [ "normal" "alt" "all" ] altVariants -lib.checkListOfEnum "${pname}: color variants" [ "light" "dark" ] colorVariants -lib.checkListOfEnum "${pname}: opacity variants" [ "normal" "solid" ] opacityVariants -lib.checkListOfEnum "${pname}: accent color variants" [ "default" "blue" "purple" "pink" "red" "orange" "yellow" "green" "grey" "all" ] themeVariants -lib.checkListOfEnum "${pname}: colorscheme style variants" [ "standard" "nord" ] schemeVariants -lib.checkListOfEnum "${pname}: activities icon variants" [ "standard" "apple" "simple" "gnome" "ubuntu" "tux" "arch" "manjaro" "fedora" "debian" "void" "opensuse" "popos" "mxlinux" "zorin" "budgie" "gentoo" ] (single iconVariant) -lib.checkListOfEnum "${pname}: nautilus style" [ "stable" "normal" "mojave" "glassy" "right" ] (single nautilusStyle) -lib.checkListOfEnum "${pname}: panel opacity" [ "default" "30" "45" "60" "75" ] (single panelOpacity) -lib.checkListOfEnum "${pname}: panel size" [ "default" "smaller" "bigger" ] (single panelSize) - -stdenv.mkDerivation rec { - pname = "whitesur-gtk-theme"; - version = "2024-11-18"; - - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = version; - hash = "sha256-SSGb7EdJN8E4N8b98VO7oFTeOmhKEo/0qhso9410ihg="; - }; - - nativeBuildInputs = [ - dialog - glib - jdupes - libxml2 - sassc - util-linux - ]; - - buildInputs = [ - gnome-themes-extra # adwaita engine for Gtk2 - ]; - - postPatch = '' - find -name "*.sh" -print0 | while IFS= read -r -d ''' file; do - patchShebangs "$file" - done - - # Do not provide `sudo`, as it is not needed in our use case of the install script - substituteInPlace libs/lib-core.sh --replace-fail '$(which sudo)' false - - # Provides a dummy home directory - substituteInPlace libs/lib-core.sh --replace-fail 'MY_HOME=$(getent passwd "''${MY_USERNAME}" | cut -d: -f6)' 'MY_HOME=/tmp' - ''; - - dontBuild = true; - - installPhase = '' - runHook preInstall - - mkdir -p $out/share/themes - - ./install.sh \ - ${toString (map (x: "--alt " + x) altVariants)} \ - ${toString (map (x: "--color " + x) colorVariants)} \ - ${toString (map (x: "--opacity " + x) opacityVariants)} \ - ${toString (map (x: "--theme " + x) themeVariants)} \ - ${toString (map (x: "--scheme " + x) schemeVariants)} \ - ${lib.optionalString (nautilusStyle != null) ("--nautilus " + nautilusStyle)} \ - ${lib.optionalString roundedMaxWindow "--roundedmaxwindow"} \ - ${lib.optionalString darkerColor "--darkercolor"} \ - ${lib.optionalString (iconVariant != null) ("--gnome-shell -i " + iconVariant)} \ - ${lib.optionalString (panelSize != null) ("--gnome-shell -panelheight " + panelSize)} \ - ${lib.optionalString (panelOpacity != null) ("--gnome-shell -panelopacity " + panelOpacity)} \ - --dest $out/share/themes - - jdupes --quiet --link-soft --recurse $out/share - - runHook postInstall - ''; - - passthru.updateScript = gitUpdater { }; - - meta = { - description = "MacOS BigSur like Gtk+ theme based on Elegant Design"; - homepage = "https://github.com/vinceliuice/WhiteSur-gtk-theme"; - license = lib.licenses.mit; - platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ romildo ]; - }; -} + lib.checkListOfEnum + "${pname}: color variants" + [ "light" "dark" ] + colorVariants + lib.checkListOfEnum + "${pname}: opacity variants" + [ "normal" "solid" ] + opacityVariants + lib.checkListOfEnum + "${pname}: accent color variants" + [ + "default" + "blue" + "purple" + "pink" + "red" + "orange" + "yellow" + "green" + "grey" + "all" + ] + themeVariants + lib.checkListOfEnum + "${pname}: colorscheme style variants" + [ "standard" "nord" ] + schemeVariants + lib.checkListOfEnum + "${pname}: activities icon variants" + [ + "standard" + "apple" + "simple" + "gnome" + "ubuntu" + "tux" + "arch" + "manjaro" + "fedora" + "debian" + "void" + "opensuse" + "popos" + "mxlinux" + "zorin" + "budgie" + "gentoo" + ] + (single iconVariant) + lib.checkListOfEnum + "${pname}: nautilus style" + [ "stable" "normal" "mojave" "glassy" "right" ] + (single nautilusStyle) + lib.checkListOfEnum + "${pname}: panel opacity" + [ "default" "30" "45" "60" "75" ] + (single panelOpacity) + lib.checkListOfEnum + "${pname}: panel size" + [ "default" "smaller" "bigger" ] + (single panelSize) + + stdenv.mkDerivation + rec { + pname = "whitesur-gtk-theme"; + version = "2024-11-18"; + + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = version; + hash = "sha256-SSGb7EdJN8E4N8b98VO7oFTeOmhKEo/0qhso9410ihg="; + }; + + nativeBuildInputs = [ + dialog + glib + jdupes + libxml2 + sassc + util-linux + ]; + + buildInputs = [ + gnome-themes-extra # adwaita engine for Gtk2 + ]; + + postPatch = '' + find -name "*.sh" -print0 | while IFS= read -r -d ''' file; do + patchShebangs "$file" + done + + # Do not provide `sudo`, as it is not needed in our use case of the install script + substituteInPlace libs/lib-core.sh --replace-fail '$(which sudo)' false + + # Provides a dummy home directory + substituteInPlace libs/lib-core.sh --replace-fail 'MY_HOME=$(getent passwd "''${MY_USERNAME}" | cut -d: -f6)' 'MY_HOME=/tmp' + ''; + + dontBuild = true; + + installPhase = '' + runHook preInstall + + mkdir -p $out/share/themes + + ./install.sh \ + ${toString (map (x: "--alt " + x) altVariants)} \ + ${toString (map (x: "--color " + x) colorVariants)} \ + ${toString (map (x: "--opacity " + x) opacityVariants)} \ + ${toString (map (x: "--theme " + x) themeVariants)} \ + ${toString (map (x: "--scheme " + x) schemeVariants)} \ + ${lib.optionalString (nautilusStyle != null) ("--nautilus " + nautilusStyle)} \ + ${lib.optionalString roundedMaxWindow "--roundedmaxwindow"} \ + ${lib.optionalString darkerColor "--darkercolor"} \ + ${lib.optionalString (iconVariant != null) ("--gnome-shell -i " + iconVariant)} \ + ${lib.optionalString (panelSize != null) ("--gnome-shell -panelheight " + panelSize)} \ + ${lib.optionalString (panelOpacity != null) ("--gnome-shell -panelopacity " + panelOpacity)} \ + --dest $out/share/themes + + jdupes --quiet --link-soft --recurse $out/share + + runHook postInstall + ''; + + passthru.updateScript = gitUpdater { }; + + meta = { + description = "MacOS BigSur like Gtk+ theme based on Elegant Design"; + homepage = "https://github.com/vinceliuice/WhiteSur-gtk-theme"; + license = lib.licenses.mit; + platforms = lib.platforms.unix; + maintainers = with lib.maintainers; [ romildo ]; + }; + } diff --git a/pkgs/by-name/wh/whitesur-icon-theme/package.nix b/pkgs/by-name/wh/whitesur-icon-theme/package.nix index 09c54a72287a81..4eae52fabac3a1 100644 --- a/pkgs/by-name/wh/whitesur-icon-theme/package.nix +++ b/pkgs/by-name/wh/whitesur-icon-theme/package.nix @@ -1,75 +1,83 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gtk3 -, hicolor-icon-theme -, jdupes -, boldPanelIcons ? false -, blackPanelIcons ? false -, alternativeIcons ? false -, themeVariants ? [] +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + hicolor-icon-theme, + jdupes, + boldPanelIcons ? false, + blackPanelIcons ? false, + alternativeIcons ? false, + themeVariants ? [ ], }: -let pname = "Whitesur-icon-theme"; +let + pname = "Whitesur-icon-theme"; in -lib.checkListOfEnum "${pname}: theme variants" [ - "default" - "purple" - "pink" - "red" - "orange" - "yellow" - "green" - "grey" - "nord" - "all" -] themeVariants +lib.checkListOfEnum "${pname}: theme variants" + [ + "default" + "purple" + "pink" + "red" + "orange" + "yellow" + "green" + "grey" + "nord" + "all" + ] + themeVariants -stdenvNoCC.mkDerivation rec { - inherit pname; - version = "2024-09-07"; + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "2024-09-07"; - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = version; - hash = "sha256-/cW/ymT9MjB07Sw7ifpr6x8oaaeI4PSyaOdLci7AncY="; - }; + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = version; + hash = "sha256-/cW/ymT9MjB07Sw7ifpr6x8oaaeI4PSyaOdLci7AncY="; + }; - nativeBuildInputs = [ gtk3 jdupes ]; + nativeBuildInputs = [ + gtk3 + jdupes + ]; - buildInputs = [ hicolor-icon-theme ]; + buildInputs = [ hicolor-icon-theme ]; - # These fixup steps are slow and unnecessary - dontPatchELF = true; - dontRewriteSymlinks = true; - dontDropIconThemeCache = true; + # These fixup steps are slow and unnecessary + dontPatchELF = true; + dontRewriteSymlinks = true; + dontDropIconThemeCache = true; - postPatch = '' - patchShebangs install.sh - ''; + postPatch = '' + patchShebangs install.sh + ''; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - ./install.sh --dest $out/share/icons \ - --name WhiteSur \ - --theme ${builtins.toString themeVariants} \ - ${lib.optionalString alternativeIcons "--alternative"} \ - ${lib.optionalString boldPanelIcons "--bold"} \ - ${lib.optionalString blackPanelIcons "--black"} + ./install.sh --dest $out/share/icons \ + --name WhiteSur \ + --theme ${builtins.toString themeVariants} \ + ${lib.optionalString alternativeIcons "--alternative"} \ + ${lib.optionalString boldPanelIcons "--bold"} \ + ${lib.optionalString blackPanelIcons "--black"} - jdupes --link-soft --recurse $out/share + jdupes --link-soft --recurse $out/share - runHook postInstall - ''; + runHook postInstall + ''; - meta = with lib; { - description = "MacOS Big Sur style icon theme for Linux desktops"; - homepage = "https://github.com/vinceliuice/WhiteSur-icon-theme"; - license = licenses.gpl3Plus; - platforms = platforms.linux; - maintainers = with maintainers; [ icy-thought ]; - }; + meta = with lib; { + description = "MacOS Big Sur style icon theme for Linux desktops"; + homepage = "https://github.com/vinceliuice/WhiteSur-icon-theme"; + license = licenses.gpl3Plus; + platforms = platforms.linux; + maintainers = with maintainers; [ icy-thought ]; + }; -} + } diff --git a/pkgs/by-name/wh/whois/package.nix b/pkgs/by-name/wh/whois/package.nix index fc122ebd2f76a2..7b12b26ecf9e06 100644 --- a/pkgs/by-name/wh/whois/package.nix +++ b/pkgs/by-name/wh/whois/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, perl, gettext, pkg-config, libidn2, libiconv }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + perl, + gettext, + pkg-config, + libidn2, + libiconv, +}: stdenv.mkDerivation rec { version = "5.5.23"; @@ -24,8 +34,15 @@ stdenv.mkDerivation rec { NIX_LDFLAGS = "-liconv"; }; - nativeBuildInputs = [ perl gettext pkg-config ]; - buildInputs = [ libidn2 libiconv ]; + nativeBuildInputs = [ + perl + gettext + pkg-config + ]; + buildInputs = [ + libidn2 + libiconv + ]; preConfigure = '' for i in Makefile po/Makefile; do diff --git a/pkgs/by-name/wh/whsniff/package.nix b/pkgs/by-name/wh/whsniff/package.nix index da50fe39a5e0de..b1f19f2bbb0a5d 100644 --- a/pkgs/by-name/wh/whsniff/package.nix +++ b/pkgs/by-name/wh/whsniff/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libusb1 }: +{ + lib, + stdenv, + fetchFromGitHub, + libusb1, +}: stdenv.mkDerivation rec { pname = "whsniff"; diff --git a/pkgs/by-name/wi/widelands/package.nix b/pkgs/by-name/wi/widelands/package.nix index bac5a99838846a..917c1f2d437018 100644 --- a/pkgs/by-name/wi/widelands/package.nix +++ b/pkgs/by-name/wi/widelands/package.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config # needed to find minizip -, SDL2 -, SDL2_image -, SDL2_mixer -, SDL2_net -, SDL2_ttf -, cmake -, curl -, doxygen -, gettext -, glew -, graphviz -, icu -, installShellFiles -, libpng -, lua -, python3 -, zlib -, minizip -, asio -, libSM -, libICE -, libXext -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, # needed to find minizip + SDL2, + SDL2_image, + SDL2_mixer, + SDL2_net, + SDL2_ttf, + cmake, + curl, + doxygen, + gettext, + glew, + graphviz, + icu, + installShellFiles, + libpng, + lua, + python3, + zlib, + minizip, + asio, + libSM, + libICE, + libXext, + darwin, }: stdenv.mkDerivation rec { @@ -50,42 +51,55 @@ stdenv.mkDerivation rec { "-DWL_INSTALL_BINDIR=${placeholder "out"}/bin" ]; - nativeBuildInputs = [ cmake doxygen gettext graphviz installShellFiles pkg-config ]; + nativeBuildInputs = [ + cmake + doxygen + gettext + graphviz + installShellFiles + pkg-config + ]; enableParallelBuilding = true; - buildInputs = [ - SDL2 - SDL2_image - SDL2_mixer - SDL2_net - SDL2_ttf - curl - glew - icu - libpng - lua - python3 - zlib - minizip - asio - libSM # XXX: these should be propagated by SDL2? - libICE - ] - ++ lib.optional stdenv.hostPlatform.isLinux libXext - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - Cocoa - ]); + buildInputs = + [ + SDL2 + SDL2_image + SDL2_mixer + SDL2_net + SDL2_ttf + curl + glew + icu + libpng + lua + python3 + zlib + minizip + asio + libSM # XXX: these should be propagated by SDL2? + libICE + ] + ++ lib.optional stdenv.hostPlatform.isLinux libXext + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Cocoa + ] + ); - postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' - install -Dm444 -t $out/share/applications ../xdg/org.widelands.Widelands.desktop + postInstall = + lib.optionalString stdenv.hostPlatform.isLinux '' + install -Dm444 -t $out/share/applications ../xdg/org.widelands.Widelands.desktop - for s in 16 32 48 64 128; do - install -Dm444 ../data/images/logos/wl-ico-''${s}.png $out/share/icons/hicolor/''${s}x''${s}/org.widelands.Widelands.png - done - '' + '' - installManPage ../xdg/widelands.6 - ''; + for s in 16 32 48 64 128; do + install -Dm444 ../data/images/logos/wl-ico-''${s}.png $out/share/icons/hicolor/''${s}x''${s}/org.widelands.Widelands.png + done + '' + + '' + installManPage ../xdg/widelands.6 + ''; meta = with lib; { description = "RTS with multiple-goods economy"; @@ -98,7 +112,10 @@ stdenv.mkDerivation rec { changelog = "https://github.com/widelands/widelands/releases/tag/v${version}"; mainProgram = "widelands"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ raskin jcumming ]; + maintainers = with maintainers; [ + raskin + jcumming + ]; platforms = platforms.linux ++ platforms.darwin; hydraPlatforms = [ ]; }; diff --git a/pkgs/by-name/wi/wifi-password/package.nix b/pkgs/by-name/wi/wifi-password/package.nix index f66af1ddfb56f7..83c9d79371391c 100644 --- a/pkgs/by-name/wi/wifi-password/package.nix +++ b/pkgs/by-name/wi/wifi-password/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { version = "0.1.0"; diff --git a/pkgs/by-name/wi/wifi-qr/package.nix b/pkgs/by-name/wi/wifi-qr/package.nix index 3c5a37b071b881..dcd90f5767584a 100644 --- a/pkgs/by-name/wi/wifi-qr/package.nix +++ b/pkgs/by-name/wi/wifi-qr/package.nix @@ -1,22 +1,26 @@ -{ lib -, fetchFromGitHub -, installShellFiles -, makeWrapper -, zenity -, ncurses -, networkmanager -, patsh -, procps -, qrencode -, stdenvNoCC -, xdg-utils -, zbar +{ + lib, + fetchFromGitHub, + installShellFiles, + makeWrapper, + zenity, + ncurses, + networkmanager, + patsh, + procps, + qrencode, + stdenvNoCC, + xdg-utils, + zbar, }: stdenvNoCC.mkDerivation { pname = "wifi-qr"; version = "0.3-unstable-2023-09-30"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchFromGitHub { owner = "kokoye2007"; diff --git a/pkgs/by-name/wi/wifish/package.nix b/pkgs/by-name/wi/wifish/package.nix index 7f474bc9844243..33a3e994954e03 100644 --- a/pkgs/by-name/wi/wifish/package.nix +++ b/pkgs/by-name/wi/wifish/package.nix @@ -1,15 +1,18 @@ -{ lib, stdenv, fetchFromGitHub -, dialog -, gawk -, wpa_supplicant -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + dialog, + gawk, + wpa_supplicant, + makeWrapper, }: stdenv.mkDerivation rec { pname = "wifish"; version = "1.1.4"; - src = fetchFromGitHub{ + src = fetchFromGitHub { owner = "bougyman"; repo = "wifish"; rev = version; @@ -34,7 +37,13 @@ stdenv.mkDerivation rec { postFixup = '' wrapProgram ${placeholder "out"}/bin/wifish \ - --prefix PATH ":" ${lib.makeBinPath [ dialog gawk wpa_supplicant ]} + --prefix PATH ":" ${ + lib.makeBinPath [ + dialog + gawk + wpa_supplicant + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/wi/wifite2/package.nix b/pkgs/by-name/wi/wifite2/package.nix index 250caa468ba598..9fc4fd21db4786 100644 --- a/pkgs/by-name/wi/wifite2/package.nix +++ b/pkgs/by-name/wi/wifite2/package.nix @@ -1,22 +1,23 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, python3 -, python3Packages -, wirelesstools -, aircrack-ng -, wireshark-cli -, reaverwps-t6x -, cowpatty -, hashcat -, hcxtools -, hcxdumptool -, which -, bully -, pixiewps -, john -, iw -, macchanger +{ + lib, + fetchFromGitHub, + fetchpatch, + python3, + python3Packages, + wirelesstools, + aircrack-ng, + wireshark-cli, + reaverwps-t6x, + cowpatty, + hashcat, + hcxtools, + hcxdumptool, + which, + bully, + pixiewps, + john, + iw, + macchanger, }: let @@ -76,6 +77,10 @@ python3.pkgs.buildPythonApplication rec { mainProgram = "wifite"; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ lassulus danielfullmer d3vil0p3r ]; + maintainers = with maintainers; [ + lassulus + danielfullmer + d3vil0p3r + ]; }; } diff --git a/pkgs/by-name/wi/wiggle/package.nix b/pkgs/by-name/wi/wiggle/package.nix index bb2ea266574943..f1c97794c71441 100644 --- a/pkgs/by-name/wi/wiggle/package.nix +++ b/pkgs/by-name/wi/wiggle/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, ncurses, groff }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + groff, +}: stdenv.mkDerivation rec { pname = "wiggle"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "18ilzr9sbal1j8p1d94ilm1j5blac5cngvcvjpdmgmpw6diy2ldf"; }; - buildInputs = [ ncurses groff ]; + buildInputs = [ + ncurses + groff + ]; configurePhase = '' makeFlagsArray=( CFLAGS="-I. -O3" diff --git a/pkgs/by-name/wi/wiiload/package.nix b/pkgs/by-name/wi/wiiload/package.nix index f2ff285cb745de..54ca0efb8d18f9 100644 --- a/pkgs/by-name/wi/wiiload/package.nix +++ b/pkgs/by-name/wi/wiiload/package.nix @@ -1,14 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + zlib, +}: stdenv.mkDerivation rec { version = "0.5.3"; pname = "wiiload"; - nativeBuildInputs = [ autoconf automake ]; + nativeBuildInputs = [ + autoconf + automake + ]; buildInputs = [ zlib ]; src = fetchFromGitHub { owner = "devkitPro"; - repo = "wiiload"; + repo = "wiiload"; rev = "v${version}"; sha256 = "sha256-pZdZzCAPfAVucuiV/q/ROY3cz/wxQWep6dCTGNn2fSo="; }; diff --git a/pkgs/by-name/wi/wiimms-iso-tools/package.nix b/pkgs/by-name/wi/wiimms-iso-tools/package.nix index 59d846324b6503..4fa1dddaf12a66 100644 --- a/pkgs/by-name/wi/wiimms-iso-tools/package.nix +++ b/pkgs/by-name/wi/wiimms-iso-tools/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchpatch, zlib, ncurses, fuse }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + zlib, + ncurses, + fuse, +}: stdenv.mkDerivation rec { pname = "wiimms-iso-tools"; @@ -9,7 +17,11 @@ stdenv.mkDerivation rec { hash = "sha256-5aikiPJkZf9OwD8QmQ7ijhBOtFQpkIErvb6gOvEu2L0="; }; - buildInputs = [ zlib ncurses fuse ]; + buildInputs = [ + zlib + ncurses + fuse + ]; patches = [ ./fix-paths.diff diff --git a/pkgs/by-name/wi/wike/package.nix b/pkgs/by-name/wi/wike/package.nix index a22f51c1607474..158a2cd5adb512 100644 --- a/pkgs/by-name/wi/wike/package.nix +++ b/pkgs/by-name/wi/wike/package.nix @@ -1,20 +1,21 @@ -{ lib -, fetchFromGitHub -, python3 -, meson -, ninja -, pkg-config -, pkgsCross -, appstream-glib -, desktop-file-utils -, gobject-introspection -, wrapGAppsHook4 -, glib -, gtk4 -, librsvg -, libadwaita -, glib-networking -, webkitgtk_6_0 +{ + lib, + fetchFromGitHub, + python3, + meson, + ninja, + pkg-config, + pkgsCross, + appstream-glib, + desktop-file-utils, + gobject-introspection, + wrapGAppsHook4, + glib, + gtk4, + librsvg, + libadwaita, + glib-networking, + webkitgtk_6_0, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/wi/wildcard/package.nix b/pkgs/by-name/wi/wildcard/package.nix index e263cb72155622..ada2cffde23f80 100644 --- a/pkgs/by-name/wi/wildcard/package.nix +++ b/pkgs/by-name/wi/wildcard/package.nix @@ -1,16 +1,17 @@ -{ lib -, blueprint-compiler -, cargo -, desktop-file-utils -, fetchFromGitLab -, libadwaita -, meson -, ninja -, pkg-config -, rustPlatform -, rustc -, stdenv -, wrapGAppsHook4 +{ + lib, + blueprint-compiler, + cargo, + desktop-file-utils, + fetchFromGitLab, + libadwaita, + meson, + ninja, + pkg-config, + rustPlatform, + rustc, + stdenv, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/wi/wiliwili/package.nix b/pkgs/by-name/wi/wiliwili/package.nix index 3bd64a0da20e57..29bb44015ec0fc 100644 --- a/pkgs/by-name/wi/wiliwili/package.nix +++ b/pkgs/by-name/wi/wiliwili/package.nix @@ -28,29 +28,33 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-IHGUNnBSwCi+DU7K2yjRLUFRjeysiMojyGXMVecNyu4="; }; - nativeBuildInputs = [ - cmake - pkg-config - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - wayland-scanner - ]; + nativeBuildInputs = + [ + cmake + pkg-config + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + wayland-scanner + ]; - buildInputs = [ - mpv-unwrapped - openssl - curl - libxkbcommon - dbus - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libffi # needed for wayland - wayland - egl-wayland - xorg.libX11 - xorg.libXrandr - xorg.libXinerama - xorg.libXcursor - xorg.libXi - ]; + buildInputs = + [ + mpv-unwrapped + openssl + curl + libxkbcommon + dbus + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libffi # needed for wayland + wayland + egl-wayland + xorg.libX11 + xorg.libXrandr + xorg.libXinerama + xorg.libXcursor + xorg.libXi + ]; cmakeFlags = [ (lib.cmakeBool "PLATFORM_DESKTOP" true) diff --git a/pkgs/by-name/wi/wily/package.nix b/pkgs/by-name/wi/wily/package.nix index a344f93bf241f6..eb2ed523fee331 100644 --- a/pkgs/by-name/wi/wily/package.nix +++ b/pkgs/by-name/wi/wily/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libX11, libXt } : +{ + lib, + stdenv, + fetchurl, + libX11, + libXt, +}: stdenv.mkDerivation rec { version = "0.13.42"; @@ -9,13 +15,18 @@ stdenv.mkDerivation rec { sha256 = "1jy4czk39sh365b0mjpj4d5wmymj98x163vmwzyx3j183jqrhm2z"; }; - buildInputs = [ libX11 libXt ]; + buildInputs = [ + libX11 + libXt + ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-error=implicit-int" - "-Wno-error=implicit-function-declaration" - "-Wno-error=incompatible-function-pointer-types" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-error=implicit-int" + "-Wno-error=implicit-function-declaration" + "-Wno-error=incompatible-function-pointer-types" + ] + ); preInstall = '' mkdir -p $out/bin diff --git a/pkgs/by-name/wi/wimboot/package.nix b/pkgs/by-name/wi/wimboot/package.nix index 4212e96586be79..1dc0a55cbdfbdf 100644 --- a/pkgs/by-name/wi/wimboot/package.nix +++ b/pkgs/by-name/wi/wimboot/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, libbfd, zlib, libiberty }: +{ + lib, + stdenv, + fetchFromGitHub, + libbfd, + zlib, + libiberty, +}: stdenv.mkDerivation rec { pname = "wimboot"; @@ -13,7 +20,11 @@ stdenv.mkDerivation rec { sourceRoot = "${src.name}/src"; - buildInputs = [ libbfd zlib libiberty ]; + buildInputs = [ + libbfd + zlib + libiberty + ]; makeFlags = [ "wimboot.x86_64.efi" ]; env.NIX_CFLAGS_COMPILE = toString [ diff --git a/pkgs/by-name/wi/wimlib/package.nix b/pkgs/by-name/wi/wimlib/package.nix index 18013b39015e90..3f62c7d4351e28 100644 --- a/pkgs/by-name/wi/wimlib/package.nix +++ b/pkgs/by-name/wi/wimlib/package.nix @@ -1,18 +1,25 @@ -{ lib, stdenv, fetchurl, makeWrapper -, pkg-config -, cabextract ? null -, cdrkit ? null -, mtools ? null -, fuse3 ? null -, ntfs3g ? null -, syslinux ? null +{ + lib, + stdenv, + fetchurl, + makeWrapper, + pkg-config, + cabextract ? null, + cdrkit ? null, + mtools ? null, + fuse3 ? null, + ntfs3g ? null, + syslinux ? null, }: stdenv.mkDerivation rec { version = "1.14.4"; pname = "wimlib"; - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; buildInputs = [ ntfs3g ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ fuse3 ]; src = fetchurl { @@ -27,13 +34,26 @@ stdenv.mkDerivation rec { --replace '/usr/lib/syslinux' "${syslinux}/share/syslinux" ''; - postInstall = let - path = lib.makeBinPath ([ cabextract mtools ntfs3g ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ cdrkit syslinux fuse3 ]); - in '' - for prog in $out/bin/*; do - wrapProgram $prog --prefix PATH : $out/bin:${path} - done - ''; + postInstall = + let + path = lib.makeBinPath ( + [ + cabextract + mtools + ntfs3g + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + cdrkit + syslinux + fuse3 + ] + ); + in + '' + for prog in $out/bin/*; do + wrapProgram $prog --prefix PATH : $out/bin:${path} + done + ''; doCheck = (!stdenv.hostPlatform.isDarwin); @@ -46,6 +66,10 @@ stdenv.mkDerivation rec { description = "Library and program to extract, create, and modify WIM files"; platforms = platforms.unix; maintainers = [ ]; - license = with licenses; [ gpl3 lgpl3 mit ]; + license = with licenses; [ + gpl3 + lgpl3 + mit + ]; }; } diff --git a/pkgs/by-name/wi/win-spice/package.nix b/pkgs/by-name/wi/win-spice/package.nix index ff3364b1ae923f..9f6420682a206e 100644 --- a/pkgs/by-name/wi/win-spice/package.nix +++ b/pkgs/by-name/wi/win-spice/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, p7zip, virtio-win }: +{ + lib, + stdenv, + fetchurl, + p7zip, + virtio-win, +}: let version_usbdk = "1.0.22"; @@ -28,7 +34,7 @@ let }; in -stdenv.mkDerivation { +stdenv.mkDerivation { # use version number of qxlwddm as qxlwddm is the most important component pname = "win-spice"; version = version_qxlwddm; @@ -54,15 +60,22 @@ stdenv.mkDerivation { installPhase = let - copy_qxl = arch: version: "mkdir -p $out/${arch}/qxl; cp qxlwddm/${version}/${arch}/* $out/${arch}/qxl/. \n"; + copy_qxl = + arch: version: "mkdir -p $out/${arch}/qxl; cp qxlwddm/${version}/${arch}/* $out/${arch}/qxl/. \n"; copy_usbdk = arch: "mkdir -p $out/${arch}/usbdk; cp usbdk/${arch}/* $out/${arch}/usbdk/. \n"; - copy_vdagent = arch: "mkdir -p $out/${arch}/vdagent; cp vdagent/${arch}/* $out/${arch}/vdagent/. \n"; + copy_vdagent = + arch: "mkdir -p $out/${arch}/vdagent; cp vdagent/${arch}/* $out/${arch}/vdagent/. \n"; # SPICE needs vioserial # TODO: Link windows version in win-spice (here) to version used in virtio-win. # That way it would never matter whether vioserial is installed from virtio-win or win-spice. - copy_vioserial = arch: version: "mkdir -p $out/${arch}/vioserial; cp ${virtio-win}/vioserial/${version}/${arch}/* $out/${arch}/vioserial/. \n"; - copy = arch: version: (copy_qxl arch version) + (copy_usbdk arch) + (copy_vdagent arch) + (copy_vioserial arch version); - in '' + copy_vioserial = + arch: version: + "mkdir -p $out/${arch}/vioserial; cp ${virtio-win}/vioserial/${version}/${arch}/* $out/${arch}/vioserial/. \n"; + copy = + arch: version: + (copy_qxl arch version) + (copy_usbdk arch) + (copy_vdagent arch) + (copy_vioserial arch version); + in + '' runHook preInstall ${(copy "amd64" "w10") + (copy "x86" "w10")} runHook postInstall diff --git a/pkgs/by-name/wi/win2xcur/package.nix b/pkgs/by-name/wi/win2xcur/package.nix index ee4ab9875a449b..f93b064d00e621 100644 --- a/pkgs/by-name/wi/win2xcur/package.nix +++ b/pkgs/by-name/wi/win2xcur/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonPackage rec { pname = "win2xcur"; @@ -11,7 +15,10 @@ python3Packages.buildPythonPackage rec { hash = "sha256-OjLj+QYg8YOJzDq3Y6/uyEXlNWbPm8VA/b1yP9jT6Jo="; }; - propagatedBuildInputs = with python3Packages; [ numpy wand ]; + propagatedBuildInputs = with python3Packages; [ + numpy + wand + ]; meta = with lib; { description = "Tools that convert cursors between the Windows (*.cur, *.ani) and Xcursor format"; diff --git a/pkgs/by-name/wi/windowchef/package.nix b/pkgs/by-name/wi/windowchef/package.nix index bf1a7c305dcd15..e74e4c063751d2 100644 --- a/pkgs/by-name/wi/windowchef/package.nix +++ b/pkgs/by-name/wi/windowchef/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, libxcb, libXrandr -, xcbutil, xcbutilkeysyms, xcbutilwm, xcbproto +{ + lib, + stdenv, + fetchFromGitHub, + libxcb, + libXrandr, + xcbutil, + xcbutilkeysyms, + xcbutilwm, + xcbproto, }: stdenv.mkDerivation rec { @@ -7,13 +15,20 @@ stdenv.mkDerivation rec { version = "0.5.2"; src = fetchFromGitHub { - owner = "tudurom"; - repo = "windowchef"; - rev = "v${version}"; + owner = "tudurom"; + repo = "windowchef"; + rev = "v${version}"; sha256 = "1m4vly7w2f28lrj26rhh3x9xsp3d97m5cxj91fafgh5rds4ygyhp"; }; - buildInputs = [ libxcb libXrandr xcbutil xcbutilkeysyms xcbutilwm xcbproto]; + buildInputs = [ + libxcb + libXrandr + xcbutil + xcbutilkeysyms + xcbutilwm + xcbproto + ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/wi/windowlab/package.nix b/pkgs/by-name/wi/windowlab/package.nix index 80900d0639b1aa..c6eeaced25097a 100644 --- a/pkgs/by-name/wi/windowlab/package.nix +++ b/pkgs/by-name/wi/windowlab/package.nix @@ -1,7 +1,16 @@ -{ lib, stdenv, fetchurl, pkg-config -, libX11, libXext, libXft }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libX11, + libXext, + libXft, +}: -let version = "1.40"; in +let + version = "1.40"; +in stdenv.mkDerivation { pname = "windowlab"; inherit version; @@ -12,26 +21,29 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libX11 libXext libXft ]; + buildInputs = [ + libX11 + libXext + libXft + ]; - postPatch = - '' - mv Makefile Makefile.orig - echo \ - " - DEFINES += -DXFT - EXTRA_INC += $(pkg-config --cflags xft) - EXTRA_LIBS += $(pkg-config --libs xft) - " > Makefile - sed "s|/usr/local|$out|g" Makefile.orig >> Makefile - ''; + postPatch = '' + mv Makefile Makefile.orig + echo \ + " + DEFINES += -DXFT + EXTRA_INC += $(pkg-config --cflags xft) + EXTRA_LIBS += $(pkg-config --libs xft) + " > Makefile + sed "s|/usr/local|$out|g" Makefile.orig >> Makefile + ''; - meta = with lib; - { description = "Small and simple stacking window manager"; - homepage = "http://nickgravgaard.com/windowlab/"; - license = licenses.gpl2; - maintainers = with maintainers; [ ehmry ]; - platforms = platforms.linux; - mainProgram = "windowlab"; - }; + meta = with lib; { + description = "Small and simple stacking window manager"; + homepage = "http://nickgravgaard.com/windowlab/"; + license = licenses.gpl2; + maintainers = with maintainers; [ ehmry ]; + platforms = platforms.linux; + mainProgram = "windowlab"; + }; } diff --git a/pkgs/by-name/wi/windowmaker/dockapps/AlsaMixer-app.nix b/pkgs/by-name/wi/windowmaker/dockapps/AlsaMixer-app.nix index a6b78b70b2443a..f9f435b845b58a 100644 --- a/pkgs/by-name/wi/windowmaker/dockapps/AlsaMixer-app.nix +++ b/pkgs/by-name/wi/windowmaker/dockapps/AlsaMixer-app.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, alsa-lib -, dockapps-sources -, libX11 -, libXext -, libXpm -, pkg-config +{ + lib, + stdenv, + alsa-lib, + dockapps-sources, + libX11, + libXext, + libXpm, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/wi/windowmaker/dockapps/cputnik.nix b/pkgs/by-name/wi/windowmaker/dockapps/cputnik.nix index 0c969bf1c10528..206d3eba4d3a12 100644 --- a/pkgs/by-name/wi/windowmaker/dockapps/cputnik.nix +++ b/pkgs/by-name/wi/windowmaker/dockapps/cputnik.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, dockapps-sources -, libX11 -, libXext -, libXpm +{ + lib, + stdenv, + dockapps-sources, + libX11, + libXext, + libXpm, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/wi/windowmaker/dockapps/libdockapp.nix b/pkgs/by-name/wi/windowmaker/dockapps/libdockapp.nix index 73c1571ff9584c..44a61008c9a392 100644 --- a/pkgs/by-name/wi/windowmaker/dockapps/libdockapp.nix +++ b/pkgs/by-name/wi/windowmaker/dockapps/libdockapp.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, autoreconfHook -, dockapps-sources -, fontutil -, libX11 -, libXext -, libXpm -, mkfontdir -, pkg-config +{ + lib, + stdenv, + autoreconfHook, + dockapps-sources, + fontutil, + libX11, + libXext, + libXpm, + mkfontdir, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { @@ -17,9 +18,18 @@ stdenv.mkDerivation (finalAttrs: { sourceRoot = "${finalAttrs.src.name}/libdockapp"; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ libX11 libXext libXpm fontutil mkfontdir ]; + buildInputs = [ + libX11 + libXext + libXpm + fontutil + mkfontdir + ]; # There is a bug on --with-font configureFlags = [ diff --git a/pkgs/by-name/wi/windowmaker/dockapps/wmCalClock.nix b/pkgs/by-name/wi/windowmaker/dockapps/wmCalClock.nix index fd46af14acc75e..de423fc01ff178 100644 --- a/pkgs/by-name/wi/windowmaker/dockapps/wmCalClock.nix +++ b/pkgs/by-name/wi/windowmaker/dockapps/wmCalClock.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, dockapps-sources -, libX11 -, libXext -, libXpm +{ + lib, + stdenv, + dockapps-sources, + libX11, + libXext, + libXpm, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/wi/windowmaker/dockapps/wmcube.nix b/pkgs/by-name/wi/windowmaker/dockapps/wmcube.nix index 5aaa00e23e344b..93bb86503226f3 100644 --- a/pkgs/by-name/wi/windowmaker/dockapps/wmcube.nix +++ b/pkgs/by-name/wi/windowmaker/dockapps/wmcube.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, dockapps-sources -, libX11 -, libXpm -, libXext -, libdockapp +{ + lib, + stdenv, + dockapps-sources, + libX11, + libXpm, + libXext, + libdockapp, }: stdenv.mkDerivation (finalAttrs: { @@ -24,16 +25,16 @@ stdenv.mkDerivation (finalAttrs: { env.NIX_CFLAGS_COMPILE = "-std=gnu89"; preBuild = '' - makeFlagsArray=( - CC="${stdenv.cc.targetPrefix}cc" - PREFIX="${placeholder "out"}" - VERSION="${finalAttrs.version}" - LIBDIR="-L${lib.getLib libX11}/lib -L${lib.getLib libXext}/lib \ --L${lib.getLib libXpm}/lib -L${lib.getLib libdockapp}/lib" - INCDIR="-I${lib.getDev libX11}/lib -I${lib.getDev libXext}/lib \ --I${lib.getDev libXpm}/lib -I${lib.getDev libdockapp}/lib" - LIBS="-lm -lXpm -lXext -lX11 -ldockapp" - ) + makeFlagsArray=( + CC="${stdenv.cc.targetPrefix}cc" + PREFIX="${placeholder "out"}" + VERSION="${finalAttrs.version}" + LIBDIR="-L${lib.getLib libX11}/lib -L${lib.getLib libXext}/lib \ + -L${lib.getLib libXpm}/lib -L${lib.getLib libdockapp}/lib" + INCDIR="-I${lib.getDev libX11}/lib -I${lib.getDev libXext}/lib \ + -I${lib.getDev libXpm}/lib -I${lib.getDev libdockapp}/lib" + LIBS="-lm -lXpm -lXext -lX11 -ldockapp" + ) ''; preInstall = '' diff --git a/pkgs/by-name/wi/windowmaker/dockapps/wmsm-app.nix b/pkgs/by-name/wi/windowmaker/dockapps/wmsm-app.nix index 36b555a81dd4fa..0782c4ffbbeabf 100644 --- a/pkgs/by-name/wi/windowmaker/dockapps/wmsm-app.nix +++ b/pkgs/by-name/wi/windowmaker/dockapps/wmsm-app.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, dockapps-sources -, libX11 -, libXpm -, libXext -, libdockapp +{ + lib, + stdenv, + dockapps-sources, + libX11, + libXpm, + libXext, + libdockapp, }: -stdenv.mkDerivation (finalAttrs: { +stdenv.mkDerivation (finalAttrs: { pname = "wmsm.app"; inherit (dockapps-sources) version src; diff --git a/pkgs/by-name/wi/windowmaker/dockapps/wmsystemtray.nix b/pkgs/by-name/wi/windowmaker/dockapps/wmsystemtray.nix index 440c35ce6449fc..4d59166b2c8ce1 100644 --- a/pkgs/by-name/wi/windowmaker/dockapps/wmsystemtray.nix +++ b/pkgs/by-name/wi/windowmaker/dockapps/wmsystemtray.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, libX11 -, libXext -, libXfixes -, libXmu -, libXpm -, pkg-config +{ + lib, + stdenv, + fetchurl, + libX11, + libXext, + libXfixes, + libXmu, + libXpm, + pkg-config, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/wi/windowmaker/package.nix b/pkgs/by-name/wi/windowmaker/package.nix index 6c39eadeb05b5d..57490959f0f7b2 100644 --- a/pkgs/by-name/wi/windowmaker/package.nix +++ b/pkgs/by-name/wi/windowmaker/package.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchFromRepoOrCz -, autoreconfHook -, callPackage -, pkg-config -, imagemagick -, libX11 -, libXext -, libXft -, libXinerama -, libXmu -, libXpm -, libXrandr -, libXres -, libexif -, libjpeg -, libpng -, libtiff -, giflib -, libwebp -, pango +{ + lib, + stdenv, + fetchFromRepoOrCz, + autoreconfHook, + callPackage, + pkg-config, + imagemagick, + libX11, + libXext, + libXft, + libXinerama, + libXmu, + libXpm, + libXrandr, + libXres, + libexif, + libjpeg, + libpng, + libtiff, + giflib, + libwebp, + pango, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/wi/windows10-icons/package.nix b/pkgs/by-name/wi/windows10-icons/package.nix index 8609aa7508afa0..7cdda913ff2f71 100644 --- a/pkgs/by-name/wi/windows10-icons/package.nix +++ b/pkgs/by-name/wi/windows10-icons/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "windows10-icons"; diff --git a/pkgs/by-name/wi/wineasio/package.nix b/pkgs/by-name/wi/wineasio/package.nix index 5c95f7f828ff3e..9152b850216c4c 100644 --- a/pkgs/by-name/wi/wineasio/package.nix +++ b/pkgs/by-name/wi/wineasio/package.nix @@ -1,10 +1,11 @@ -{ multiStdenv -, lib -, fetchFromGitHub -, libjack2 -, pkg-config -, wineWowPackages -, pkgsi686Linux +{ + multiStdenv, + lib, + fetchFromGitHub, + libjack2, + pkg-config, + wineWowPackages, + pkgsi686Linux, }: multiStdenv.mkDerivation rec { @@ -19,9 +20,15 @@ multiStdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ pkg-config wineWowPackages.stable ]; + nativeBuildInputs = [ + pkg-config + wineWowPackages.stable + ]; - buildInputs = [ pkgsi686Linux.libjack2 libjack2 ]; + buildInputs = [ + pkgsi686Linux.libjack2 + libjack2 + ]; dontConfigure = true; @@ -46,7 +53,10 @@ multiStdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/wineasio/wineasio"; description = "ASIO to JACK driver for WINE"; - license = with licenses; [ gpl2 lgpl21 ]; + license = with licenses; [ + gpl2 + lgpl21 + ]; maintainers = with maintainers; [ lovesegfault ]; platforms = platforms.linux; }; diff --git a/pkgs/by-name/wi/wingpanel-indicator-ayatana/package.nix b/pkgs/by-name/wi/wingpanel-indicator-ayatana/package.nix index c3c24b02401aac..e5e97bede0c43d 100644 --- a/pkgs/by-name/wi/wingpanel-indicator-ayatana/package.nix +++ b/pkgs/by-name/wi/wingpanel-indicator-ayatana/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, unstableGitUpdater -, substituteAll -, meson -, ninja -, pkg-config -, vala -, gtk3 -, libindicator-gtk3 -, pantheon -, indicator-application-gtk3 +{ + lib, + stdenv, + fetchFromGitHub, + unstableGitUpdater, + substituteAll, + meson, + ninja, + pkg-config, + vala, + gtk3, + libindicator-gtk3, + pantheon, + indicator-application-gtk3, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/wi/winhelpcgi/package.nix b/pkgs/by-name/wi/winhelpcgi/package.nix index 51383b5b792dcb..19141ca03382e4 100644 --- a/pkgs/by-name/wi/winhelpcgi/package.nix +++ b/pkgs/by-name/wi/winhelpcgi/package.nix @@ -1,4 +1,12 @@ -{ stdenv, fetchurl, libwmf, libpng12, pkg-config, lib }: stdenv.mkDerivation { +{ + stdenv, + fetchurl, + libwmf, + libpng12, + pkg-config, + lib, +}: +stdenv.mkDerivation { pname = "winhelpcgi"; version = "1.0-rc3"; @@ -10,7 +18,10 @@ nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libwmf libpng12 ]; + buildInputs = [ + libwmf + libpng12 + ]; meta = { description = "CGI module for Linux, Solaris, MacOS X and AIX to read Windows Help Files"; diff --git a/pkgs/by-name/wi/wio/package.nix b/pkgs/by-name/wi/wio/package.nix index b41db6fcf2a3ef..7cc758e21ebb1a 100644 --- a/pkgs/by-name/wi/wio/package.nix +++ b/pkgs/by-name/wi/wio/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, alacritty -, cage -, cairo -, libxkbcommon -, makeWrapper -, mesa -, meson -, ninja -, pkg-config -, wayland-scanner -, udev -, unstableGitUpdater -, wayland -, wayland-protocols -, wlroots -, xwayland +{ + lib, + stdenv, + fetchFromGitHub, + alacritty, + cage, + cairo, + libxkbcommon, + makeWrapper, + mesa, + meson, + ninja, + pkg-config, + wayland-scanner, + udev, + unstableGitUpdater, + wayland, + wayland-protocols, + wlroots, + xwayland, }: stdenv.mkDerivation (finalAttrs: { @@ -55,7 +56,12 @@ stdenv.mkDerivation (finalAttrs: { postInstall = '' wrapProgram $out/bin/wio \ - --prefix PATH ":" "${lib.makeBinPath [ alacritty cage ]}" + --prefix PATH ":" "${ + lib.makeBinPath [ + alacritty + cage + ] + }" ''; passthru = { diff --git a/pkgs/by-name/wi/wipe/package.nix b/pkgs/by-name/wi/wipe/package.nix index e41e22c3a25dba..98d7226e6f7e86 100644 --- a/pkgs/by-name/wi/wipe/package.nix +++ b/pkgs/by-name/wi/wipe/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "wipe"; @@ -14,9 +18,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Secure file wiping utility"; mainProgram = "wipe"; - homepage = "https://wipe.sourceforge.net/"; - license = licenses.gpl2Plus; - platforms = platforms.all; + homepage = "https://wipe.sourceforge.net/"; + license = licenses.gpl2Plus; + platforms = platforms.all; maintainers = [ maintainers.abbradar ]; }; } diff --git a/pkgs/by-name/wi/wipefreespace/package.nix b/pkgs/by-name/wi/wipefreespace/package.nix index 74798631424863..111453bc576563 100644 --- a/pkgs/by-name/wi/wipefreespace/package.nix +++ b/pkgs/by-name/wi/wipefreespace/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchurl -, e2fsprogs -, ntfs3g -, xfsprogs -, reiser4progs -, libaal -, jfsutils -, libuuid -, texinfo +{ + stdenv, + lib, + fetchurl, + e2fsprogs, + ntfs3g, + xfsprogs, + reiser4progs, + libaal, + jfsutils, + libuuid, + texinfo, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/wi/wire-desktop/package.nix b/pkgs/by-name/wi/wire-desktop/package.nix index 4959b6fdd2eeb6..def50167494708 100644 --- a/pkgs/by-name/wi/wire-desktop/package.nix +++ b/pkgs/by-name/wi/wire-desktop/package.nix @@ -1,20 +1,21 @@ -{ autoPatchelfHook -, dpkg -, fetchurl -, makeDesktopItem -, makeWrapper -, stdenv -, lib -, udev -, buildPackages -, cpio -, xar -, libdbusmenu -, alsa-lib -, mesa -, nss -, nspr -, systemd +{ + autoPatchelfHook, + dpkg, + fetchurl, + makeDesktopItem, + makeWrapper, + stdenv, + lib, + udev, + buildPackages, + cpio, + xar, + libdbusmenu, + alsa-lib, + mesa, + nss, + nspr, + systemd, }: let @@ -25,21 +26,27 @@ let pname = "wire-desktop"; - version = let - x86_64-darwin = "3.35.4861"; - in { - inherit x86_64-darwin; - aarch64-darwin = x86_64-darwin; - x86_64-linux = "3.36.3462"; - }.${system} or throwSystem; - - hash = let - x86_64-darwin = "sha256-QPxslMEz1jOH2LceFOdCyVDtpya1SfJ8GWMIAIhie4U="; - in { - inherit x86_64-darwin; - aarch64-darwin = x86_64-darwin; - x86_64-linux = "sha256-tlX15AT4PcrmD2Vna99TGqo0b/8xv2YOAt03aCqSeXg="; - }.${system} or throwSystem; + version = + let + x86_64-darwin = "3.35.4861"; + in + { + inherit x86_64-darwin; + aarch64-darwin = x86_64-darwin; + x86_64-linux = "3.36.3462"; + } + .${system} or throwSystem; + + hash = + let + x86_64-darwin = "sha256-QPxslMEz1jOH2LceFOdCyVDtpya1SfJ8GWMIAIhie4U="; + in + { + inherit x86_64-darwin; + aarch64-darwin = x86_64-darwin; + x86_64-linux = "sha256-tlX15AT4PcrmD2Vna99TGqo0b/8xv2YOAt03aCqSeXg="; + } + .${system} or throwSystem; meta = with lib; { description = "Modern, secure messenger for everyone"; @@ -66,7 +73,7 @@ let platforms = platforms.darwin ++ [ "x86_64-linux" ]; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; linux = stdenv.mkDerivation rec { @@ -78,7 +85,12 @@ let }; desktopItem = makeDesktopItem { - categories = [ "Network" "InstantMessaging" "Chat" "VideoConference" ]; + categories = [ + "Network" + "InstantMessaging" + "Chat" + "VideoConference" + ]; comment = "Secure messenger for everyone"; desktopName = "Wire"; exec = "wire-desktop %U"; @@ -180,6 +192,4 @@ let }; in -if stdenv.hostPlatform.isDarwin -then darwin -else linux +if stdenv.hostPlatform.isDarwin then darwin else linux diff --git a/pkgs/by-name/wi/wire/package.nix b/pkgs/by-name/wi/wire/package.nix index c1099d0691696d..de9274ebed3515 100644 --- a/pkgs/by-name/wi/wire/package.nix +++ b/pkgs/by-name/wi/wire/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "wire"; @@ -21,7 +25,10 @@ buildGoModule rec { subPackages = [ "cmd/wire" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/google/wire"; diff --git a/pkgs/by-name/wi/wiredtiger/package.nix b/pkgs/by-name/wi/wiredtiger/package.nix index a87afd7ee09fc1..0d5b4e3203ee68 100644 --- a/pkgs/by-name/wi/wiredtiger/package.nix +++ b/pkgs/by-name/wi/wiredtiger/package.nix @@ -1,12 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, automake, autoconf, libtool +{ + lib, + stdenv, + fetchFromGitHub, + automake, + autoconf, + libtool, -# Optional Dependencies -, lz4 ? null, snappy ? null, zlib ? null, bzip2 ? null, db ? null -, gperftools ? null, leveldb ? null + # Optional Dependencies + lz4 ? null, + snappy ? null, + zlib ? null, + bzip2 ? null, + db ? null, + gperftools ? null, + leveldb ? null, }: let - shouldUsePkg = pkg: if pkg != null && lib.meta.availableOn stdenv.hostPlatform pkg then pkg else null; + shouldUsePkg = + pkg: if pkg != null && lib.meta.availableOn stdenv.hostPlatform pkg then pkg else null; optLz4 = shouldUsePkg lz4; optSnappy = shouldUsePkg snappy; @@ -27,23 +39,35 @@ stdenv.mkDerivation rec { sha256 = "04j2zw8b9jym43r682rh4kpdippxx7iw3ry16nxlbybzar9kgk83"; }; - nativeBuildInputs = [ automake autoconf libtool ]; - buildInputs = [ optLz4 optSnappy optZlib optBzip2 optDb optGperftools optLeveldb ]; + nativeBuildInputs = [ + automake + autoconf + libtool + ]; + buildInputs = [ + optLz4 + optSnappy + optZlib + optBzip2 + optDb + optGperftools + optLeveldb + ]; configureFlags = [ - (lib.withFeature false "attach") - (lib.withFeatureAs true "builtins" "") - (lib.enableFeature (optBzip2 != null) "bzip2") - (lib.enableFeature false "diagnostic") - (lib.enableFeature false "java") - (lib.enableFeature (optLeveldb != null) "leveldb") - (lib.enableFeature false "python") - (lib.enableFeature (optSnappy != null) "snappy") - (lib.enableFeature (optLz4 != null) "lz4") + (lib.withFeature false "attach") + (lib.withFeatureAs true "builtins" "") + (lib.enableFeature (optBzip2 != null) "bzip2") + (lib.enableFeature false "diagnostic") + (lib.enableFeature false "java") + (lib.enableFeature (optLeveldb != null) "leveldb") + (lib.enableFeature false "python") + (lib.enableFeature (optSnappy != null) "snappy") + (lib.enableFeature (optLz4 != null) "lz4") (lib.enableFeature (optGperftools != null) "tcmalloc") - (lib.enableFeature (optZlib != null) "zlib") - (lib.withFeatureAs (optDb != null) "berkeleydb" optDb) - (lib.withFeature false "helium") + (lib.enableFeature (optZlib != null) "zlib") + (lib.withFeatureAs (optDb != null) "berkeleydb" optDb) + (lib.withFeature false "helium") ]; preConfigure = '' diff --git a/pkgs/by-name/wi/wireguard-vanity-keygen/package.nix b/pkgs/by-name/wi/wireguard-vanity-keygen/package.nix index 3f9d5054ed6b06..c596fb9eeb4a59 100644 --- a/pkgs/by-name/wi/wireguard-vanity-keygen/package.nix +++ b/pkgs/by-name/wi/wireguard-vanity-keygen/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,12 +17,18 @@ buildGoModule rec { vendorHash = "sha256-kAPw5M9o99NijCC9BzYhIpzHK/8fSAJxvckaj8iRby0="; - ldflags = [ "-s" "-w" "-X main.appVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.appVersion=${version}" + ]; meta = with lib; { - changelog = let - versionWithoutDots = concatStrings (splitString "." version); - in "https://github.com/axllent/wireguard-vanity-keygen/blob/develop/CHANGELOG.md#${versionWithoutDots}"; + changelog = + let + versionWithoutDots = concatStrings (splitString "." version); + in + "https://github.com/axllent/wireguard-vanity-keygen/blob/develop/CHANGELOG.md#${versionWithoutDots}"; description = "WireGuard vanity key generator"; homepage = "https://github.com/axllent/wireguard-vanity-keygen"; license = licenses.mit; diff --git a/pkgs/by-name/wi/wireless-regdb/package.nix b/pkgs/by-name/wi/wireless-regdb/package.nix index e331433a0e674f..38a358121d7131 100644 --- a/pkgs/by-name/wi/wireless-regdb/package.nix +++ b/pkgs/by-name/wi/wireless-regdb/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchurl, directoryListingUpdater }: +{ + lib, + stdenvNoCC, + fetchurl, + directoryListingUpdater, +}: stdenvNoCC.mkDerivation rec { pname = "wireless-regdb"; diff --git a/pkgs/by-name/wi/wirelesstools/package.nix b/pkgs/by-name/wi/wirelesstools/package.nix index 33318b16bb8191..e95eb87ce59822 100644 --- a/pkgs/by-name/wi/wirelesstools/package.nix +++ b/pkgs/by-name/wi/wirelesstools/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "wireless-tools"; diff --git a/pkgs/by-name/wi/wireproxy/package.nix b/pkgs/by-name/wi/wireproxy/package.nix index b244364c8c9bf7..3ded4b7f2bfea3 100644 --- a/pkgs/by-name/wi/wireproxy/package.nix +++ b/pkgs/by-name/wi/wireproxy/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, wireproxy +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + wireproxy, }: buildGoModule rec { diff --git a/pkgs/by-name/wi/wireviz/package.nix b/pkgs/by-name/wi/wireviz/package.nix index cce72213b66b28..5f62939d111101 100644 --- a/pkgs/by-name/wi/wireviz/package.nix +++ b/pkgs/by-name/wi/wireviz/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/wi/wireworld/package.nix b/pkgs/by-name/wi/wireworld/package.nix index 2b23144c00b510..7e487a528a14db 100644 --- a/pkgs/by-name/wi/wireworld/package.nix +++ b/pkgs/by-name/wi/wireworld/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitLab -, zip -, love -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, strip-nondeterminism +{ + lib, + stdenv, + fetchFromGitLab, + zip, + love, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + strip-nondeterminism, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/wi/wishbone-tool/package.nix b/pkgs/by-name/wi/wishbone-tool/package.nix index 7cda9afee89813..2281e124ce393b 100644 --- a/pkgs/by-name/wi/wishbone-tool/package.nix +++ b/pkgs/by-name/wi/wishbone-tool/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, rustPlatform, libusb-compat-0_1 }: +{ + lib, + fetchFromGitHub, + rustPlatform, + libusb-compat-0_1, +}: let version = "0.7.9"; diff --git a/pkgs/by-name/wi/wishlist/package.nix b/pkgs/by-name/wi/wishlist/package.nix index f2a2912649968d..460e7fe227f5c5 100644 --- a/pkgs/by-name/wi/wishlist/package.nix +++ b/pkgs/by-name/wi/wishlist/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "wishlist"; @@ -15,14 +19,21 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X=main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X=main.Version=${version}" + ]; meta = with lib; { description = "Single entrypoint for multiple SSH endpoints"; homepage = "https://github.com/charmbracelet/wishlist"; changelog = "https://github.com/charmbracelet/wishlist/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ caarlos0 penguwin ]; + maintainers = with maintainers; [ + caarlos0 + penguwin + ]; mainProgram = "wishlist"; }; } diff --git a/pkgs/by-name/wi/wit-bindgen/package.nix b/pkgs/by-name/wi/wit-bindgen/package.nix index 7435199df8b33c..8f4a9e1ef21960 100644 --- a/pkgs/by-name/wi/wit-bindgen/package.nix +++ b/pkgs/by-name/wi/wit-bindgen/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/wi/with-shell/package.nix b/pkgs/by-name/wi/with-shell/package.nix index acfe547f1470aa..e8b5fc506416f6 100644 --- a/pkgs/by-name/wi/with-shell/package.nix +++ b/pkgs/by-name/wi/with-shell/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/wi/witness/package.nix b/pkgs/by-name/wi/witness/package.nix index 50e347a091241a..d52ea85af158f4 100644 --- a/pkgs/by-name/wi/witness/package.nix +++ b/pkgs/by-name/wi/witness/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, -# testing -, testers -, witness + # testing + testers, + witness, }: buildGoModule rec { @@ -66,6 +67,9 @@ buildGoModule rec { homepage = "https://github.com/testifysec/witness"; changelog = "https://github.com/testifysec/witness/releases/tag/v${version}"; license = licenses.asl20; - maintainers = with maintainers; [ fkautz jk ]; + maintainers = with maintainers; [ + fkautz + jk + ]; }; } diff --git a/pkgs/by-name/wi/witnessme/package.nix b/pkgs/by-name/wi/witnessme/package.nix index de83d1475360af..4f2ca939af4c33 100644 --- a/pkgs/by-name/wi/witnessme/package.nix +++ b/pkgs/by-name/wi/witnessme/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, python3 +{ + lib, + fetchFromGitHub, + fetchpatch, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/wi/wizer/package.nix b/pkgs/by-name/wi/wizer/package.nix index 4aaad29db5669d..aff80e1cb0b578 100644 --- a/pkgs/by-name/wi/wizer/package.nix +++ b/pkgs/by-name/wi/wizer/package.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, testers -, wizer +{ + lib, + rustPlatform, + fetchFromGitHub, + testers, + wizer, }: rustPlatform.buildRustPackage rec { @@ -20,9 +21,15 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-8iQ6ULdle8tJDPgIoPT9R3jfS32tBBfs4vZNQcV8vfs="; - cargoBuildFlags = [ "--bin" pname ]; + cargoBuildFlags = [ + "--bin" + pname + ]; - buildFeatures = [ "env_logger" "structopt" ]; + buildFeatures = [ + "env_logger" + "structopt" + ]; # Setting $HOME to a temporary directory is necessary to prevent checks from failing, as # the test suite creates a cache directory at $HOME/Library/Caches/BytecodeAlliance.wasmtime. @@ -39,6 +46,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "wizer"; homepage = "https://github.com/bytecodealliance/wizer"; license = licenses.asl20; - maintainers = with maintainers; [ lucperkins amesgen ]; + maintainers = with maintainers; [ + lucperkins + amesgen + ]; }; } diff --git a/pkgs/by-name/wk/wkhtmltopdf/package.nix b/pkgs/by-name/wk/wkhtmltopdf/package.nix index 430648cb8a6e61..030f6610cbad76 100644 --- a/pkgs/by-name/wk/wkhtmltopdf/package.nix +++ b/pkgs/by-name/wk/wkhtmltopdf/package.nix @@ -1,18 +1,19 @@ -{ lib -, autoPatchelfHook -, cpio -, freetype -, zlib -, openssl -, fetchurl -, dpkg -, gcc-unwrapped -, libjpeg -, libpng -, fontconfig -, stdenv -, xar -, xorg +{ + lib, + autoPatchelfHook, + cpio, + freetype, + zlib, + openssl, + fetchurl, + dpkg, + gcc-unwrapped, + libjpeg, + libpng, + fontconfig, + stdenv, + xar, + xorg, }: let @@ -23,7 +24,10 @@ let sha256 = "sha256-gaZrd7UI/t6NvKpnEnIDdIN2Vos2c6F/ZhG21R6YlPg="; }; - nativeBuildInputs = [ xar cpio ]; + nativeBuildInputs = [ + xar + cpio + ]; unpackPhase = '' xar -xf $src @@ -40,7 +44,10 @@ let }; _linuxAttrs = { - nativeBuildInputs = [ dpkg autoPatchelfHook ]; + nativeBuildInputs = [ + dpkg + autoPatchelfHook + ]; buildInputs = [ xorg.libXext @@ -81,34 +88,41 @@ let }; } // _linuxAttrs; in -stdenv.mkDerivation ({ - pname = "wkhtmltopdf"; - - dontStrip = true; - - doInstallCheck = true; +stdenv.mkDerivation ( + { + pname = "wkhtmltopdf"; - installCheckPhase = '' - $out/bin/wkhtmltopdf --version - ''; + dontStrip = true; - meta = with lib; { - homepage = "https://wkhtmltopdf.org/"; - description = - "Tools for rendering web pages to PDF or images (binary package)"; - longDescription = '' - wkhtmltopdf and wkhtmltoimage are open source (LGPL) command line tools - to render HTML into PDF and various image formats using the QT Webkit - rendering engine. These run entirely "headless" and do not require a - display or display service. + doInstallCheck = true; - There is also a C library, if you're into that kind of thing. + installCheckPhase = '' + $out/bin/wkhtmltopdf --version ''; - license = licenses.gpl3Plus; - maintainers = with maintainers; [ nbr kalbasit ]; - platforms = [ "x86_64-darwin" "x86_64-linux" "aarch64-linux" ]; - }; -} -// lib.optionalAttrs (stdenv.hostPlatform.isDarwin) darwinAttrs -// lib.optionalAttrs (stdenv.hostPlatform.isLinux) linuxAttrs.${stdenv.system} + + meta = with lib; { + homepage = "https://wkhtmltopdf.org/"; + description = "Tools for rendering web pages to PDF or images (binary package)"; + longDescription = '' + wkhtmltopdf and wkhtmltoimage are open source (LGPL) command line tools + to render HTML into PDF and various image formats using the QT Webkit + rendering engine. These run entirely "headless" and do not require a + display or display service. + + There is also a C library, if you're into that kind of thing. + ''; + license = licenses.gpl3Plus; + maintainers = with maintainers; [ + nbr + kalbasit + ]; + platforms = [ + "x86_64-darwin" + "x86_64-linux" + "aarch64-linux" + ]; + }; + } + // lib.optionalAttrs (stdenv.hostPlatform.isDarwin) darwinAttrs + // lib.optionalAttrs (stdenv.hostPlatform.isLinux) linuxAttrs.${stdenv.system} ) diff --git a/pkgs/by-name/wl/wl-clipboard-rs/package.nix b/pkgs/by-name/wl/wl-clipboard-rs/package.nix index 2483c485be0636..e11744ea8c32d4 100644 --- a/pkgs/by-name/wl/wl-clipboard-rs/package.nix +++ b/pkgs/by-name/wl/wl-clipboard-rs/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, wayland -, withNativeLibs ? false +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + wayland, + withNativeLibs ? false, }: rustPlatform.buildRustPackage rec { @@ -20,24 +21,30 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-P0WLYHNLN8ZqoDRszsgfQTiWeVpfBpFHiEWpQMBjNJM="; - cargoBuildFlags = [ - "--package=wl-clipboard-rs" - "--package=wl-clipboard-rs-tools" - ] ++ lib.optionals withNativeLibs [ - "--features=native_lib" - ]; + cargoBuildFlags = + [ + "--package=wl-clipboard-rs" + "--package=wl-clipboard-rs-tools" + ] + ++ lib.optionals withNativeLibs [ + "--features=native_lib" + ]; - nativeBuildInputs = [ - installShellFiles - ] ++ lib.optionals withNativeLibs [ - pkg-config - ]; + nativeBuildInputs = + [ + installShellFiles + ] + ++ lib.optionals withNativeLibs [ + pkg-config + ]; - buildInputs = [ - installShellFiles - ]++ lib.optionals withNativeLibs [ - wayland - ]; + buildInputs = + [ + installShellFiles + ] + ++ lib.optionals withNativeLibs [ + wayland + ]; preCheck = '' export XDG_RUNTIME_DIR=$(mktemp -d) @@ -72,8 +79,14 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/YaLTeR/wl-clipboard-rs"; changelog = "https://github.com/YaLTeR/wl-clipboard-rs/blob/v${version}/CHANGELOG.md"; platforms = platforms.linux; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; mainProgram = "wl-clip"; - maintainers = with maintainers; [ thiagokokada donovanglover ]; + maintainers = with maintainers; [ + thiagokokada + donovanglover + ]; }; } diff --git a/pkgs/by-name/wl/wl-clipboard-x11/package.nix b/pkgs/by-name/wl/wl-clipboard-x11/package.nix index e7cdb9a554a514..02366c77c095a0 100644 --- a/pkgs/by-name/wl/wl-clipboard-x11/package.nix +++ b/pkgs/by-name/wl/wl-clipboard-x11/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, wl-clipboard, bash }: +{ + lib, + stdenv, + fetchFromGitHub, + wl-clipboard, + bash, +}: stdenv.mkDerivation rec { pname = "wl-clipboard-x11"; diff --git a/pkgs/by-name/wl/wl-clipboard/package.nix b/pkgs/by-name/wl/wl-clipboard/package.nix index dc5b9ed900de44..45e310684489f0 100644 --- a/pkgs/by-name/wl/wl-clipboard/package.nix +++ b/pkgs/by-name/wl/wl-clipboard/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, wayland -, wayland-protocols -, wayland-scanner -, xdg-utils -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + wayland, + wayland-protocols, + wayland-scanner, + xdg-utils, + makeWrapper, }: stdenv.mkDerivation rec { @@ -23,8 +24,17 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ meson ninja pkg-config wayland-scanner makeWrapper ]; - buildInputs = [ wayland wayland-protocols ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + wayland-scanner + makeWrapper + ]; + buildInputs = [ + wayland + wayland-protocols + ]; mesonFlags = [ "-Dfishcompletiondir=share/fish/vendor_completions.d" @@ -40,7 +50,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/bugaevc/wl-clipboard"; description = "Command-line copy/paste utilities for Wayland"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ dywedir kashw2 ]; + maintainers = with maintainers; [ + dywedir + kashw2 + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/wl/wl-color-picker/package.nix b/pkgs/by-name/wl/wl-color-picker/package.nix index 22f6821a10223e..3f128e6bdd67e0 100644 --- a/pkgs/by-name/wl/wl-color-picker/package.nix +++ b/pkgs/by-name/wl/wl-color-picker/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, slurp -, grim -, zenity -, wl-clipboard -, imagemagick -, makeWrapper -, bash +{ + lib, + stdenv, + fetchFromGitHub, + slurp, + grim, + zenity, + wl-clipboard, + imagemagick, + makeWrapper, + bash, }: stdenv.mkDerivation rec { @@ -41,13 +42,15 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/usr/bin/wl-color-picker \ - --prefix PATH : ${lib.makeBinPath [ - grim - slurp - imagemagick - zenity - wl-clipboard - ]} + --prefix PATH : ${ + lib.makeBinPath [ + grim + slurp + imagemagick + zenity + wl-clipboard + ] + } mkdir -p $out/bin ln -s $out/usr/bin/wl-color-picker $out/bin/wl-color-picker ''; diff --git a/pkgs/by-name/wl/wl-gammactl/package.nix b/pkgs/by-name/wl/wl-gammactl/package.nix index 7cb8eb6e7fb6ef..dc9e38a531c3e1 100644 --- a/pkgs/by-name/wl/wl-gammactl/package.nix +++ b/pkgs/by-name/wl/wl-gammactl/package.nix @@ -1,6 +1,15 @@ -{ lib, stdenv, fetchFromGitHub -, meson, pkg-config, ninja -, wayland, wayland-scanner, wlr-protocols, gtk3, glib +{ + lib, + stdenv, + fetchFromGitHub, + meson, + pkg-config, + ninja, + wayland, + wayland-scanner, + wlr-protocols, + gtk3, + glib, }: stdenv.mkDerivation rec { @@ -15,8 +24,17 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ meson pkg-config ninja glib wayland-scanner ]; - buildInputs = [ wayland gtk3 ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + glib + wayland-scanner + ]; + buildInputs = [ + wayland + gtk3 + ]; postUnpack = '' rmdir source/wlr-protocols diff --git a/pkgs/by-name/wl/wl-mirror/package.nix b/pkgs/by-name/wl/wl-mirror/package.nix index 6ca73104b4c53d..2f6f15f5badb29 100644 --- a/pkgs/by-name/wl/wl-mirror/package.nix +++ b/pkgs/by-name/wl/wl-mirror/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, wayland -, wayland-protocols -, wayland-scanner -, wlr-protocols -, libGL -, bash -, installExampleScripts ? true -, makeWrapper -, pipectl -, slurp -, rofi -, scdoc +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + wayland, + wayland-protocols, + wayland-scanner, + wlr-protocols, + libGL, + bash, + installExampleScripts ? true, + makeWrapper, + pipectl, + slurp, + rofi, + scdoc, }: let @@ -39,8 +40,20 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ cmake pkg-config wayland-scanner scdoc makeWrapper ]; - buildInputs = [ libGL wayland wayland-protocols wlr-protocols bash ]; + nativeBuildInputs = [ + cmake + pkg-config + wayland-scanner + scdoc + makeWrapper + ]; + buildInputs = [ + libGL + wayland + wayland-protocols + wlr-protocols + bash + ]; postPatch = '' echo 'v${version}' > version.txt diff --git a/pkgs/by-name/wl/wl-screenrec/package.nix b/pkgs/by-name/wl/wl-screenrec/package.nix index 5bba48bd9b4639..8091a3f3d7efda 100644 --- a/pkgs/by-name/wl/wl-screenrec/package.nix +++ b/pkgs/by-name/wl/wl-screenrec/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libdrm -, ffmpeg_6 -, wayland +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libdrm, + ffmpeg_6, + wayland, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/wl/wla-dx/package.nix b/pkgs/by-name/wl/wla-dx/package.nix index b80b460d4def2c..c0e871b853b04f 100644 --- a/pkgs/by-name/wl/wla-dx/package.nix +++ b/pkgs/by-name/wl/wla-dx/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchFromGitHub, cmake}: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "wla-dx"; diff --git a/pkgs/by-name/wl/wlay/package.nix b/pkgs/by-name/wl/wlay/package.nix index c2330de5f7dad0..f1bf8dedc1c10f 100644 --- a/pkgs/by-name/wl/wlay/package.nix +++ b/pkgs/by-name/wl/wlay/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, glfw3 -, libX11 -, libXau -, libXdmcp -, libepoxy -, libffi -, libxcb -, pkg-config -, wayland -, wayland-scanner +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + glfw3, + libX11, + libXau, + libXdmcp, + libepoxy, + libffi, + libxcb, + pkg-config, + wayland, + wayland-scanner, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/wl/wlc/package.nix b/pkgs/by-name/wl/wlc/package.nix index 29eda8696d12fe..bcd091840c5a1f 100644 --- a/pkgs/by-name/wl/wlc/package.nix +++ b/pkgs/by-name/wl/wlc/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: with python3.pkgs; diff --git a/pkgs/by-name/wl/wlclock/package.nix b/pkgs/by-name/wl/wlclock/package.nix index d79a81788c7acb..3fb526f199e630 100644 --- a/pkgs/by-name/wl/wlclock/package.nix +++ b/pkgs/by-name/wl/wlclock/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromSourcehut -, meson -, ninja -, cmake -, pkg-config -, wayland-scanner -, wayland-protocols -, wayland -, cairo -, scdoc +{ + lib, + stdenv, + fetchFromSourcehut, + meson, + ninja, + cmake, + pkg-config, + wayland-scanner, + wayland-protocols, + wayland, + cairo, + scdoc, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/wl/wlcs/package.nix b/pkgs/by-name/wl/wlcs/package.nix index 453da9b06be716..260f312ac28150 100644 --- a/pkgs/by-name/wl/wlcs/package.nix +++ b/pkgs/by-name/wl/wlcs/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, gitUpdater -, fetchFromGitHub -, testers -, cmake -, pkg-config -, boost -, gtest -, wayland -, wayland-scanner +{ + stdenv, + lib, + gitUpdater, + fetchFromGitHub, + testers, + cmake, + pkg-config, + boost, + gtest, + wayland, + wayland-scanner, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/wl/wleave/package.nix b/pkgs/by-name/wl/wleave/package.nix index d4fb46142d5975..9defe3798e249f 100644 --- a/pkgs/by-name/wl/wleave/package.nix +++ b/pkgs/by-name/wl/wleave/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, at-spi2-atk -, pkg-config -, glib -, gtk3 -, gtk-layer-shell -, installShellFiles -, scdoc +{ + lib, + fetchFromGitHub, + rustPlatform, + at-spi2-atk, + pkg-config, + glib, + gtk3, + gtk-layer-shell, + installShellFiles, + scdoc, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/wl/wlinhibit/package.nix b/pkgs/by-name/wl/wlinhibit/package.nix index fbf59eeca52284..1d787f7871937a 100644 --- a/pkgs/by-name/wl/wlinhibit/package.nix +++ b/pkgs/by-name/wl/wlinhibit/package.nix @@ -39,6 +39,6 @@ stdenv.mkDerivation rec { license = lib.licenses.mit; homepage = "https://github.com/0x5a4/wlinhibit"; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [_0x5a4]; + maintainers = with lib.maintainers; [ _0x5a4 ]; }; } diff --git a/pkgs/by-name/wl/wljoywake/package.nix b/pkgs/by-name/wl/wljoywake/package.nix index 209e61e9d1841e..00899a219751ec 100644 --- a/pkgs/by-name/wl/wljoywake/package.nix +++ b/pkgs/by-name/wl/wljoywake/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, udev -, wayland -, wayland-protocols -, wayland-scanner +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + udev, + wayland, + wayland-protocols, + wayland-scanner, }: let diff --git a/pkgs/by-name/wl/wllvm/package.nix b/pkgs/by-name/wl/wllvm/package.nix index 38e10f726160ce..a01b20da36c92d 100644 --- a/pkgs/by-name/wl/wllvm/package.nix +++ b/pkgs/by-name/wl/wllvm/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { version = "1.3.1"; diff --git a/pkgs/by-name/wl/wlogout/package.nix b/pkgs/by-name/wl/wlogout/package.nix index 63a537f6e3e2db..3eaf5022eb8369 100644 --- a/pkgs/by-name/wl/wlogout/package.nix +++ b/pkgs/by-name/wl/wlogout/package.nix @@ -1,21 +1,22 @@ -{ lib -, fetchFromGitHub -, gitUpdater -, gtk-layer-shell -, gtk3 -, libxkbcommon -, meson -, ninja -, pkg-config -, scdoc -, stdenv -, wayland -, wayland-protocols -# gtk-layer-shell fails to cross-compile due to a hard dependency -# on gobject-introspection. -# Disable it when cross-compiling since it's an optional dependency. -# This disables transparency support. -, withGtkLayerShell ? (stdenv.buildPlatform == stdenv.hostPlatform) +{ + lib, + fetchFromGitHub, + gitUpdater, + gtk-layer-shell, + gtk3, + libxkbcommon, + meson, + ninja, + pkg-config, + scdoc, + stdenv, + wayland, + wayland-protocols, + # gtk-layer-shell fails to cross-compile due to a hard dependency + # on gobject-introspection. + # Disable it when cross-compiling since it's an optional dependency. + # This disables transparency support. + withGtkLayerShell ? (stdenv.buildPlatform == stdenv.hostPlatform), }: stdenv.mkDerivation (finalAttrs: { @@ -29,7 +30,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-/tYZy56ku68ziSOhy6Dex9RGy+blkU6CN2ze76y7718="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; depsBuildBuild = [ pkg-config @@ -42,14 +46,16 @@ stdenv.mkDerivation (finalAttrs: { scdoc ]; - buildInputs = [ - gtk3 - libxkbcommon - wayland - wayland-protocols - ] ++ lib.optionals withGtkLayerShell [ - gtk-layer-shell - ]; + buildInputs = + [ + gtk3 + libxkbcommon + wayland + wayland-protocols + ] + ++ lib.optionals withGtkLayerShell [ + gtk-layer-shell + ]; strictDeps = true; diff --git a/pkgs/by-name/wl/wlopm/package.nix b/pkgs/by-name/wl/wlopm/package.nix index aa0b9ae4bcfc19..b1b746120c792e 100644 --- a/pkgs/by-name/wl/wlopm/package.nix +++ b/pkgs/by-name/wl/wlopm/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromSourcehut, wayland, wayland-scanner }: +{ + lib, + stdenv, + fetchFromSourcehut, + wayland, + wayland-scanner, +}: stdenv.mkDerivation rec { pname = "wlopm"; diff --git a/pkgs/by-name/wl/wlprop/package.nix b/pkgs/by-name/wl/wlprop/package.nix index f46a9a965533be..b6c0dd2d613ae8 100644 --- a/pkgs/by-name/wl/wlprop/package.nix +++ b/pkgs/by-name/wl/wlprop/package.nix @@ -1,4 +1,14 @@ -{ fetchgit, gawk, jq, lib, makeWrapper, slurp, stdenv, sway, bash }: +{ + fetchgit, + gawk, + jq, + lib, + makeWrapper, + slurp, + stdenv, + sway, + bash, +}: stdenv.mkDerivation rec { pname = "wlprop"; @@ -20,7 +30,14 @@ stdenv.mkDerivation rec { install -Dm755 wlprop.sh $out/bin/wlprop wrapProgram "$out/bin/wlprop" \ - --prefix PATH : "$out/bin:${lib.makeBinPath [ gawk jq slurp sway ]}" + --prefix PATH : "$out/bin:${ + lib.makeBinPath [ + gawk + jq + slurp + sway + ] + }" runHook postInstall ''; @@ -30,7 +47,7 @@ stdenv.mkDerivation rec { description = "Xprop clone for wlroots based compositors"; homepage = "https://gist.github.com/crispyricepc/f313386043395ff06570e02af2d9a8e0"; license = licenses.mit; - maintainers = with maintainers; []; + maintainers = with maintainers; [ ]; platforms = platforms.linux; mainProgram = "wlprop"; }; diff --git a/pkgs/by-name/wl/wlr-layout-ui/package.nix b/pkgs/by-name/wl/wlr-layout-ui/package.nix index 2cf571540f6896..084c316b7bf95e 100644 --- a/pkgs/by-name/wl/wlr-layout-ui/package.nix +++ b/pkgs/by-name/wl/wlr-layout-ui/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/wl/wlr-randr/package.nix b/pkgs/by-name/wl/wlr-randr/package.nix index 6c284fdf2b15b5..4064d5538bbfcd 100644 --- a/pkgs/by-name/wl/wlr-randr/package.nix +++ b/pkgs/by-name/wl/wlr-randr/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromSourcehut -, meson -, ninja -, pkg-config -, wayland -, wayland-scanner +{ + lib, + stdenv, + fetchFromSourcehut, + meson, + ninja, + pkg-config, + wayland, + wayland-scanner, }: stdenv.mkDerivation rec { @@ -20,7 +21,12 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ meson ninja pkg-config wayland-scanner ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + wayland-scanner + ]; buildInputs = [ wayland ]; depsBuildBuild = [ pkg-config diff --git a/pkgs/by-name/wl/wlr-which-key/package.nix b/pkgs/by-name/wl/wlr-which-key/package.nix index 4bb349e3c30138..f81e73c5463d03 100644 --- a/pkgs/by-name/wl/wlr-which-key/package.nix +++ b/pkgs/by-name/wl/wlr-which-key/package.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, cairo -, glib -, libxkbcommon -, pango +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + cairo, + glib, + libxkbcommon, + pango, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/wl/wlrctl/package.nix b/pkgs/by-name/wl/wlrctl/package.nix index 130c54731eaa34..810c196e8a7d97 100644 --- a/pkgs/by-name/wl/wlrctl/package.nix +++ b/pkgs/by-name/wl/wlrctl/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromSourcehut, meson, pkg-config, scdoc, ninja, libxkbcommon, wayland, wayland-scanner }: +{ + lib, + stdenv, + fetchFromSourcehut, + meson, + pkg-config, + scdoc, + ninja, + libxkbcommon, + wayland, + wayland-scanner, +}: stdenv.mkDerivation rec { pname = "wlrctl"; @@ -15,8 +26,17 @@ stdenv.mkDerivation rec { depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson pkg-config scdoc ninja wayland-scanner ]; - buildInputs = [ libxkbcommon wayland ]; + nativeBuildInputs = [ + meson + pkg-config + scdoc + ninja + wayland-scanner + ]; + buildInputs = [ + libxkbcommon + wayland + ]; env.NIX_CFLAGS_COMPILE = "-Wno-error=type-limits"; @@ -24,7 +44,10 @@ stdenv.mkDerivation rec { description = "Command line utility for miscellaneous wlroots Wayland extensions"; homepage = "https://git.sr.ht/~brocellous/wlrctl"; license = licenses.mit; - maintainers = with maintainers; [ puffnfresh artturin ]; + maintainers = with maintainers; [ + puffnfresh + artturin + ]; platforms = platforms.linux; mainProgram = "wlrctl"; }; diff --git a/pkgs/by-name/wl/wlsunset/package.nix b/pkgs/by-name/wl/wlsunset/package.nix index 72edfb9c6f4877..2feb362354ae0a 100644 --- a/pkgs/by-name/wl/wlsunset/package.nix +++ b/pkgs/by-name/wl/wlsunset/package.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchFromSourcehut -, meson, pkg-config, ninja, wayland-scanner, scdoc -, wayland, wayland-protocols +{ + lib, + stdenv, + fetchFromSourcehut, + meson, + pkg-config, + ninja, + wayland-scanner, + scdoc, + wayland, + wayland-protocols, }: stdenv.mkDerivation rec { @@ -18,8 +26,17 @@ stdenv.mkDerivation rec { depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson pkg-config ninja wayland-scanner scdoc ]; - buildInputs = [ wayland wayland-protocols ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + wayland-scanner + scdoc + ]; + buildInputs = [ + wayland + wayland-protocols + ]; meta = with lib; { description = "Day/night gamma adjustments for Wayland"; diff --git a/pkgs/by-name/wl/wluma/package.nix b/pkgs/by-name/wl/wluma/package.nix index b1b92cb797b8ce..0b782bf296a62c 100644 --- a/pkgs/by-name/wl/wluma/package.nix +++ b/pkgs/by-name/wl/wluma/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, rustPlatform -, marked-man -, coreutils -, vulkan-loader -, wayland -, pkg-config -, udev -, v4l-utils -, dbus -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + rustPlatform, + marked-man, + coreutils, + vulkan-loader, + wayland, + pkg-config, + udev, + v4l-utils, + dbus, + nix-update-script, }: rustPlatform.buildRustPackage rec { @@ -72,7 +73,11 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/maximbaz/wluma"; changelog = "https://github.com/maximbaz/wluma/releases/tag/${version}"; license = licenses.isc; - maintainers = with maintainers; [ yshym jmc-figueira atemu ]; + maintainers = with maintainers; [ + yshym + jmc-figueira + atemu + ]; platforms = platforms.linux; mainProgram = "wluma"; }; diff --git a/pkgs/by-name/wl/wlvncc/package.nix b/pkgs/by-name/wl/wlvncc/package.nix index 0e0e64a658d2d4..58feac19a8f508 100644 --- a/pkgs/by-name/wl/wlvncc/package.nix +++ b/pkgs/by-name/wl/wlvncc/package.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitHub -, aml -, cyrus_sasl -, ffmpeg -, gnutls -, libGL -, libdrm -, libgcrypt -, libjpeg -, libpng -, libxkbcommon -, lzo -, mesa -, meson -, ninja -, openssl -, pkg-config -, pixman -, wayland -, wayland-scanner -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + aml, + cyrus_sasl, + ffmpeg, + gnutls, + libGL, + libdrm, + libgcrypt, + libjpeg, + libpng, + libxkbcommon, + lzo, + mesa, + meson, + ninja, + openssl, + pkg-config, + pixman, + wayland, + wayland-scanner, + zlib, }: stdenv.mkDerivation { pname = "wlvncc"; diff --git a/pkgs/by-name/wm/wmctrl/package.nix b/pkgs/by-name/wm/wmctrl/package.nix index b15b1eb6b4255e..3d115059ffd777 100644 --- a/pkgs/by-name/wm/wmctrl/package.nix +++ b/pkgs/by-name/wm/wmctrl/package.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchurl -, libX11 -, glib -, pkg-config -, libXmu +{ + lib, + stdenv, + fetchurl, + libX11, + glib, + pkg-config, + libXmu, }: stdenv.mkDerivation rec { @@ -20,7 +22,11 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ pkg-config ]; nativeBuildInputs = [ glib.dev ]; - buildInputs = [ libX11 libXmu glib ]; + buildInputs = [ + libX11 + libXmu + glib + ]; patches = [ ./64-bit-data.patch ]; diff --git a/pkgs/by-name/wm/wmderland/package.nix b/pkgs/by-name/wm/wmderland/package.nix index 322906d5657fa3..557813a56980cf 100644 --- a/pkgs/by-name/wm/wmderland/package.nix +++ b/pkgs/by-name/wm/wmderland/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libnotify, libX11, xorgproto, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libnotify, + libX11, + xorgproto, + nixosTests, +}: stdenv.mkDerivation { pname = "wmderland"; diff --git a/pkgs/by-name/wm/wmderlandc/package.nix b/pkgs/by-name/wm/wmderlandc/package.nix index 3bb8f2364ef6fa..f1ce7beb9552a0 100644 --- a/pkgs/by-name/wm/wmderlandc/package.nix +++ b/pkgs/by-name/wm/wmderlandc/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libX11, xorgproto }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libX11, + xorgproto, +}: stdenv.mkDerivation (finalAttrs: { pname = "wmderlandc"; diff --git a/pkgs/by-name/wm/wmenu/package.nix b/pkgs/by-name/wm/wmenu/package.nix index ada289ad496149..faa58a57799ad2 100644 --- a/pkgs/by-name/wm/wmenu/package.nix +++ b/pkgs/by-name/wm/wmenu/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitea -, pkg-config -, meson -, ninja -, cairo -, pango -, wayland -, wayland-protocols -, wayland-scanner -, libxkbcommon -, scdoc +{ + lib, + stdenv, + fetchFromGitea, + pkg-config, + meson, + ninja, + cairo, + pango, + wayland, + wayland-protocols, + wayland-scanner, + libxkbcommon, + scdoc, }: stdenv.mkDerivation rec { @@ -27,8 +28,20 @@ stdenv.mkDerivation rec { hash = "sha256-TF5BvgThvTOqxyfz5Zt/Z1cqjFJwvla+dgdyvz7Zhrg="; }; - nativeBuildInputs = [ pkg-config meson ninja wayland-scanner ]; - buildInputs = [ cairo pango wayland libxkbcommon wayland-protocols scdoc ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + wayland-scanner + ]; + buildInputs = [ + cairo + pango + wayland + libxkbcommon + wayland-protocols + scdoc + ]; meta = with lib; { description = "Efficient dynamic menu for Sway and wlroots based Wayland compositors"; @@ -39,4 +52,3 @@ stdenv.mkDerivation rec { mainProgram = "wmenu"; }; } - diff --git a/pkgs/by-name/wm/wmfs/package.nix b/pkgs/by-name/wm/wmfs/package.nix index 6c850278b337f8..fafac60f1c21d5 100644 --- a/pkgs/by-name/wm/wmfs/package.nix +++ b/pkgs/by-name/wm/wmfs/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, - libX11, libXinerama, libXrandr, libXpm, libXft, imlib2 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + libX11, + libXinerama, + libXrandr, + libXpm, + libXft, + imlib2, +}: stdenv.mkDerivation { pname = "wmfs"; diff --git a/pkgs/by-name/wm/wmic-bin/package.nix b/pkgs/by-name/wm/wmic-bin/package.nix index 64cf171afea1ca..e557ffd76764be 100644 --- a/pkgs/by-name/wm/wmic-bin/package.nix +++ b/pkgs/by-name/wm/wmic-bin/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, autoPatchelfHook, popt, libxcrypt-legacy }: +{ + stdenv, + lib, + fetchFromGitHub, + autoPatchelfHook, + popt, + libxcrypt-legacy, +}: stdenv.mkDerivation rec { pname = "wmic-bin"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "1w1mdbiwz37wzry1q38h8dyjaa6iggmsb9wcyhhlawwm1vj50w48"; }; - buildInputs = [ popt libxcrypt-legacy ]; + buildInputs = [ + popt + libxcrypt-legacy + ]; nativeBuildInputs = [ autoPatchelfHook ]; @@ -39,10 +49,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "WMI client for Linux (binary)"; mainProgram = "wmic"; - homepage = "https://www.openvas.org"; + homepage = "https://www.openvas.org"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = licenses.mit; + license = licenses.mit; maintainers = with maintainers; [ peterhoeg ]; - platforms = [ "x86_64-linux" ]; + platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/by-name/wm/wml/package.nix b/pkgs/by-name/wm/wml/package.nix index 13295edd310a01..3ad1b6c6922f21 100644 --- a/pkgs/by-name/wm/wml/package.nix +++ b/pkgs/by-name/wm/wml/package.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, perlPackages, ncurses, lynx, makeWrapper }: +{ + lib, + fetchurl, + perlPackages, + ncurses, + lynx, + makeWrapper, +}: perlPackages.buildPerlPackage { pname = "wml"; @@ -24,10 +31,21 @@ perlPackages.buildPerlPackage { ''; nativeBuildInputs = [ makeWrapper ]; - buildInputs = with perlPackages; - [ perl TermReadKey GD BitVector ncurses lynx ImageSize ]; + buildInputs = with perlPackages; [ + perl + TermReadKey + GD + BitVector + ncurses + lynx + ImageSize + ]; - patches = [ ./redhat-with-thr.patch ./dynaloader.patch ./no_bitvector.patch ]; + patches = [ + ./redhat-with-thr.patch + ./dynaloader.patch + ./no_bitvector.patch + ]; # Workaround build failure on -fno-common toolchains: # ld: iselect_browse.o:(.bss+0x2020): multiple definition of `Line'; iselect_main.o:(.bss+0x100000): first defined here @@ -51,9 +69,14 @@ perlPackages.buildPerlPackage { preFixup = '' wrapProgram $out/bin/wml \ - --set PERL5LIB ${with perlPackages; makePerlPath [ - BitVector TermReadKey ImageSize - ]} + --set PERL5LIB ${ + with perlPackages; + makePerlPath [ + BitVector + TermReadKey + ImageSize + ] + } ''; enableParallelBuilding = false; diff --git a/pkgs/by-name/wm/wmname/package.nix b/pkgs/by-name/wm/wmname/package.nix index b64e714e081b09..6b33f04f9dd2f4 100644 --- a/pkgs/by-name/wm/wmname/package.nix +++ b/pkgs/by-name/wm/wmname/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libX11 }: +{ + lib, + stdenv, + fetchurl, + libX11, +}: stdenv.mkDerivation rec { pname = "wmname"; diff --git a/pkgs/by-name/wm/wmutils-core/package.nix b/pkgs/by-name/wm/wmutils-core/package.nix index 5620dcb8420f8d..5f35c29dbb4272 100644 --- a/pkgs/by-name/wm/wmutils-core/package.nix +++ b/pkgs/by-name/wm/wmutils-core/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, libxcb, xcbutil, xcb-util-cursor }: +{ + lib, + stdenv, + fetchFromGitHub, + libxcb, + xcbutil, + xcb-util-cursor, +}: stdenv.mkDerivation rec { pname = "wmutils-core"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-OKAvJovGu9rMxEe5g4kdL7Foj41kl3zUYIJa04jf0dI="; }; - buildInputs = [ libxcb xcbutil xcb-util-cursor ]; + buildInputs = [ + libxcb + xcbutil + xcb-util-cursor + ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/wm/wmutils-libwm/package.nix b/pkgs/by-name/wm/wmutils-libwm/package.nix index 84d08c9e2b66b8..723e78772e8888 100644 --- a/pkgs/by-name/wm/wmutils-libwm/package.nix +++ b/pkgs/by-name/wm/wmutils-libwm/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libxcb }: +{ + lib, + stdenv, + fetchFromGitHub, + libxcb, +}: stdenv.mkDerivation rec { pname = "wmutils-libwm"; diff --git a/pkgs/by-name/wm/wmutils-opt/package.nix b/pkgs/by-name/wm/wmutils-opt/package.nix index 0d847262ea5872..00142588d2e768 100644 --- a/pkgs/by-name/wm/wmutils-opt/package.nix +++ b/pkgs/by-name/wm/wmutils-opt/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libxcb }: +{ + lib, + stdenv, + fetchFromGitHub, + libxcb, +}: stdenv.mkDerivation rec { pname = "wmutils-opt"; diff --git a/pkgs/by-name/wo/wob/package.nix b/pkgs/by-name/wo/wob/package.nix index e670c5fce4de86..d45068b7ce8271 100644 --- a/pkgs/by-name/wo/wob/package.nix +++ b/pkgs/by-name/wo/wob/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, inih -, meson -, ninja -, pkg-config -, cmocka -, scdoc -, wayland-scanner -, wayland -, wayland-protocols -, libseccomp +{ + lib, + stdenv, + fetchFromGitHub, + inih, + meson, + ninja, + pkg-config, + cmocka, + scdoc, + wayland-scanner, + wayland, + wayland-protocols, + libseccomp, }: stdenv.mkDerivation rec { @@ -28,9 +29,19 @@ stdenv.mkDerivation rec { depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson ninja pkg-config scdoc wayland-scanner ]; - buildInputs = [ cmocka inih wayland wayland-protocols ] - ++ lib.optional stdenv.hostPlatform.isLinux libseccomp; + nativeBuildInputs = [ + meson + ninja + pkg-config + scdoc + wayland-scanner + ]; + buildInputs = [ + cmocka + inih + wayland + wayland-protocols + ] ++ lib.optional stdenv.hostPlatform.isLinux libseccomp; mesonFlags = lib.optional stdenv.hostPlatform.isLinux "-Dseccomp=enabled"; diff --git a/pkgs/by-name/wo/woeusb-ng/package.nix b/pkgs/by-name/wo/woeusb-ng/package.nix index 0858422be3a0c4..408440e0f8be33 100644 --- a/pkgs/by-name/wo/woeusb-ng/package.nix +++ b/pkgs/by-name/wo/woeusb-ng/package.nix @@ -1,10 +1,11 @@ -{ lib -, python3Packages -, fetchFromGitHub -, wrapGAppsHook3 -, p7zip -, parted -, grub2 +{ + lib, + python3Packages, + fetchFromGitHub, + wrapGAppsHook3, + p7zip, + parted, + grub2, }: with python3Packages; diff --git a/pkgs/by-name/wo/woeusb/package.nix b/pkgs/by-name/wo/woeusb/package.nix index 9add255896f757..8382ad157ec9c4 100644 --- a/pkgs/by-name/wo/woeusb/package.nix +++ b/pkgs/by-name/wo/woeusb/package.nix @@ -1,5 +1,23 @@ -{ lib, stdenv, fetchFromGitHub, installShellFiles, makeWrapper -, coreutils, dosfstools, findutils, gawk, gnugrep, grub2_light, ncurses, ntfs3g, parted, p7zip, util-linux, wimlib, wget }: +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + makeWrapper, + coreutils, + dosfstools, + findutils, + gawk, + gnugrep, + grub2_light, + ncurses, + ntfs3g, + parted, + p7zip, + util-linux, + wimlib, + wget, +}: stdenv.mkDerivation rec { version = "5.2.4"; @@ -12,7 +30,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-HB1E7rP/U58dyL3j6YnhF5AOGAcHqmA/ZZ5JNBDibco="; }; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; postPatch = '' # Emulate version smudge filter (see .gitattributes, .gitconfig). @@ -30,7 +51,23 @@ stdenv.mkDerivation rec { installManPage share/man/man1/woeusb.1 wrapProgram "$out/bin/woeusb" \ - --set PATH '${lib.makeBinPath [ coreutils dosfstools findutils gawk gnugrep grub2_light ncurses ntfs3g parted p7zip util-linux wget wimlib ]}' + --set PATH '${ + lib.makeBinPath [ + coreutils + dosfstools + findutils + gawk + gnugrep + grub2_light + ncurses + ntfs3g + parted + p7zip + util-linux + wget + wimlib + ] + }' runHook postInstall ''; diff --git a/pkgs/by-name/wo/woff2/package.nix b/pkgs/by-name/wo/woff2/package.nix index 2f186344498093..ef5a9a5e006c15 100644 --- a/pkgs/by-name/wo/woff2/package.nix +++ b/pkgs/by-name/wo/woff2/package.nix @@ -1,5 +1,11 @@ -{ brotli, cmake, pkg-config, fetchFromGitHub, lib, stdenv -, static ? stdenv.hostPlatform.isStatic +{ + brotli, + cmake, + pkg-config, + fetchFromGitHub, + lib, + stdenv, + static ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { @@ -13,12 +19,19 @@ stdenv.mkDerivation rec { sha256 = "13l4g536h0pr84ww4wxs2za439s0xp1va55g6l478rfbb1spp44y"; }; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; # Need to explicitly link to brotlicommon patches = lib.optional static ./brotli-static.patch; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; cmakeFlags = [ "-DCANONICAL_PREFIXES=ON" diff --git a/pkgs/by-name/wo/wofi-emoji/package.nix b/pkgs/by-name/wo/wofi-emoji/package.nix index 81ba584cc2464e..cef2eb0f4780a3 100644 --- a/pkgs/by-name/wo/wofi-emoji/package.nix +++ b/pkgs/by-name/wo/wofi-emoji/package.nix @@ -63,7 +63,10 @@ stdenv.mkDerivation rec { description = "Simple emoji selector for Wayland using wofi and wl-clipboard"; homepage = "https://github.com/Zeioth/wofi-emoji"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ johnrtitor ymarkus ]; + maintainers = with lib.maintainers; [ + johnrtitor + ymarkus + ]; platforms = lib.platforms.all; mainProgram = "wofi-emoji"; }; diff --git a/pkgs/by-name/wo/wofi/package.nix b/pkgs/by-name/wo/wofi/package.nix index 2884f0072a08cc..0dba9c4add9a93 100644 --- a/pkgs/by-name/wo/wofi/package.nix +++ b/pkgs/by-name/wo/wofi/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromSourcehut -, pkg-config -, meson -, ninja -, wayland -, gtk3 -, wrapGAppsHook3 -, installShellFiles +{ + stdenv, + lib, + fetchFromSourcehut, + pkg-config, + meson, + ninja, + wayland, + gtk3, + wrapGAppsHook3, + installShellFiles, }: stdenv.mkDerivation rec { pname = "wofi"; @@ -21,8 +22,17 @@ stdenv.mkDerivation rec { vc = "hg"; }; - nativeBuildInputs = [ pkg-config meson ninja wrapGAppsHook3 installShellFiles ]; - buildInputs = [ wayland gtk3 ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + wrapGAppsHook3 + installShellFiles + ]; + buildInputs = [ + wayland + gtk3 + ]; patches = [ # https://todo.sr.ht/~scoopta/wofi/121 diff --git a/pkgs/by-name/wo/wol/package.nix b/pkgs/by-name/wo/wol/package.nix index 0d1abbf33544d9..31d64c88f06bab 100644 --- a/pkgs/by-name/wo/wol/package.nix +++ b/pkgs/by-name/wo/wol/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "wol"; diff --git a/pkgs/by-name/wo/wolf-shaper/package.nix b/pkgs/by-name/wo/wolf-shaper/package.nix index a3c08e92b72347..d4e234fc6173fd 100644 --- a/pkgs/by-name/wo/wolf-shaper/package.nix +++ b/pkgs/by-name/wo/wolf-shaper/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, libjack2, lv2, xorg, liblo, libGL, libXcursor, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + libjack2, + lv2, + xorg, + liblo, + libGL, + libXcursor, + pkg-config, +}: stdenv.mkDerivation rec { pname = "wolf-shaper"; @@ -13,7 +24,14 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libjack2 lv2 xorg.libX11 liblo libGL libXcursor ]; + buildInputs = [ + libjack2 + lv2 + xorg.libX11 + liblo + libGL + libXcursor + ]; makeFlags = [ "BUILD_LV2=true" @@ -42,7 +60,10 @@ stdenv.mkDerivation rec { description = "Waveshaper plugin with spline-based graph editor"; license = licenses.gpl3Plus; maintainers = [ maintainers.magnetophon ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; mainProgram = "wolf-shaper"; }; } diff --git a/pkgs/by-name/wo/wolfebin/package.nix b/pkgs/by-name/wo/wolfebin/package.nix index 47babc4ceb9aaf..e44f30213899f9 100644 --- a/pkgs/by-name/wo/wolfebin/package.nix +++ b/pkgs/by-name/wo/wolfebin/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation rec { pname = "wolfebin"; diff --git a/pkgs/by-name/wo/wolfstoneextract/package.nix b/pkgs/by-name/wo/wolfstoneextract/package.nix index b2d76e41d57c33..75f55a6ca475bb 100644 --- a/pkgs/by-name/wo/wolfstoneextract/package.nix +++ b/pkgs/by-name/wo/wolfstoneextract/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromBitbucket -, cmake +{ + lib, + stdenv, + fetchFromBitbucket, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -24,7 +25,10 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "wolfstoneextract"; homepage = "https://bitbucket.org/ecwolf/wolfstoneextract/src/master/"; platforms = [ "x86_64-linux" ]; - license = with licenses; [ gpl3Only bsd3 ]; + license = with licenses; [ + gpl3Only + bsd3 + ]; maintainers = with maintainers; [ keenanweaver ]; }; }) diff --git a/pkgs/by-name/wo/wonderdraft/package.nix b/pkgs/by-name/wo/wonderdraft/package.nix index c6cf971b9beaee..431ede5440bd8e 100644 --- a/pkgs/by-name/wo/wonderdraft/package.nix +++ b/pkgs/by-name/wo/wonderdraft/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, requireFile -, dpkg -, xorg -, libGL -, alsa-lib -, pulseaudio +{ + lib, + stdenv, + requireFile, + dpkg, + xorg, + libGL, + alsa-lib, + pulseaudio, }: stdenv.mkDerivation rec { @@ -35,23 +36,25 @@ stdenv.mkDerivation rec { ln -s $out/opt/Wonderdraft/Wonderdraft.x86_64 $out/bin/Wonderdraft.x86_64 runHook postInstall ''; - preFixup = let - libPath = lib.makeLibraryPath [ - xorg.libXcursor - xorg.libXinerama - xorg.libXrandr - xorg.libX11 - xorg.libXi - libGL - alsa-lib - pulseaudio - ]; - in '' - patchelf \ - --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath "${libPath}" \ - $out/opt/Wonderdraft/Wonderdraft.x86_64 - ''; + preFixup = + let + libPath = lib.makeLibraryPath [ + xorg.libXcursor + xorg.libXinerama + xorg.libXrandr + xorg.libX11 + xorg.libXi + libGL + alsa-lib + pulseaudio + ]; + in + '' + patchelf \ + --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ + --set-rpath "${libPath}" \ + $out/opt/Wonderdraft/Wonderdraft.x86_64 + ''; meta = with lib; { homepage = "https://wonderdraft.net/"; diff --git a/pkgs/by-name/wo/woodpecker-plugin-git/package.nix b/pkgs/by-name/wo/woodpecker-plugin-git/package.nix index c8d28fa69dd27c..ef9538e05dd389 100644 --- a/pkgs/by-name/wo/woodpecker-plugin-git/package.nix +++ b/pkgs/by-name/wo/woodpecker-plugin-git/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, woodpecker-plugin-git +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + woodpecker-plugin-git, }: buildGoModule rec { diff --git a/pkgs/by-name/wo/woof/package.nix b/pkgs/by-name/wo/woof/package.nix index b73ad5615dd09a..054ff86e56234a 100644 --- a/pkgs/by-name/wo/woof/package.nix +++ b/pkgs/by-name/wo/woof/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation { pname = "woof"; diff --git a/pkgs/by-name/wo/wordgrinder/package.nix b/pkgs/by-name/wo/wordgrinder/package.nix index c3b2aaf42a0717..9f7d84c9bb37d8 100644 --- a/pkgs/by-name/wo/wordgrinder/package.nix +++ b/pkgs/by-name/wo/wordgrinder/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, makeWrapper -, lua52Packages, libXft, ncurses, ninja, readline, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + makeWrapper, + lua52Packages, + libXft, + ncurses, + ninja, + readline, + zlib, +}: stdenv.mkDerivation rec { pname = "wordgrinder"; @@ -33,24 +44,28 @@ stdenv.mkDerivation rec { ninja ]; - buildInputs = [ - lua52Packages.lua - ncurses - readline - zlib - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libXft - ]; + buildInputs = + [ + lua52Packages.lua + ncurses + readline + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libXft + ]; # To be able to find env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isLinux "-I${libXft.dev}/include/X11"; # Binaries look for LuaFileSystem library (lfs.so) at runtime - postInstall = '' - wrapProgram $out/bin/wordgrinder --set LUA_CPATH "${lua52Packages.luafilesystem}/lib/lua/5.2/lfs.so"; - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - wrapProgram $out/bin/xwordgrinder --set LUA_CPATH "${lua52Packages.luafilesystem}/lib/lua/5.2/lfs.so"; - ''; + postInstall = + '' + wrapProgram $out/bin/wordgrinder --set LUA_CPATH "${lua52Packages.luafilesystem}/lib/lua/5.2/lfs.so"; + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + wrapProgram $out/bin/xwordgrinder --set LUA_CPATH "${lua52Packages.luafilesystem}/lib/lua/5.2/lfs.so"; + ''; meta = with lib; { description = "Text-based word processor"; diff --git a/pkgs/by-name/wo/wordlists/package.nix b/pkgs/by-name/wo/wordlists/package.nix index 2d7b43b3894fd9..7913b182671ca8 100644 --- a/pkgs/by-name/wo/wordlists/package.nix +++ b/pkgs/by-name/wo/wordlists/package.nix @@ -1,17 +1,18 @@ -{ lib -, symlinkJoin -, nmap -, rockyou -, seclists -, wfuzz -, lists ? [ +{ + lib, + symlinkJoin, + nmap, + rockyou, + seclists, + wfuzz, + lists ? [ nmap rockyou seclists wfuzz - ] -, writeShellScriptBin -, tree + ], + writeShellScriptBin, + tree, }: let wordlistsCollection = symlinkJoin { @@ -35,7 +36,8 @@ let printf "${wordlistsCollection}/share/wordlists\n" ''; -in symlinkJoin { +in +symlinkJoin { name = "wordlists"; paths = [ @@ -68,6 +70,9 @@ in symlinkJoin { If you want to add a new package that provides wordlist/s the convention is to copy it to {file}`$out/share/wordlists/myNewWordlist`. ''; - maintainers = with maintainers; [ pamplemousse h7x4 ]; + maintainers = with maintainers; [ + pamplemousse + h7x4 + ]; }; } diff --git a/pkgs/by-name/wo/work-sans/package.nix b/pkgs/by-name/wo/work-sans/package.nix index 071c6bafb18288..34fb1f8ae9e62f 100644 --- a/pkgs/by-name/wo/work-sans/package.nix +++ b/pkgs/by-name/wo/work-sans/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "work-sans"; diff --git a/pkgs/by-name/wo/workcraft/package.nix b/pkgs/by-name/wo/workcraft/package.nix index f1159f3c06875d..cec867c8bd55a5 100644 --- a/pkgs/by-name/wo/workcraft/package.nix +++ b/pkgs/by-name/wo/workcraft/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "workcraft"; @@ -14,12 +20,12 @@ stdenv.mkDerivation rec { dontConfigure = true; installPhase = '' - mkdir -p $out/share - cp -r * $out/share - mkdir $out/bin - makeWrapper $out/share/workcraft $out/bin/workcraft \ - --set JAVA_HOME "${jre}" \ - --set _JAVA_OPTIONS '-Dawt.useSystemAAFontSettings=gasp'; + mkdir -p $out/share + cp -r * $out/share + mkdir $out/bin + makeWrapper $out/share/workcraft $out/bin/workcraft \ + --set JAVA_HOME "${jre}" \ + --set _JAVA_OPTIONS '-Dawt.useSystemAAFontSettings=gasp'; ''; meta = { diff --git a/pkgs/by-name/wo/worker/package.nix b/pkgs/by-name/wo/worker/package.nix index 7df631e14b9e2d..710e621eaa9e6b 100644 --- a/pkgs/by-name/wo/worker/package.nix +++ b/pkgs/by-name/wo/worker/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, libX11 +{ + lib, + stdenv, + fetchurl, + libX11, }: stdenv.mkDerivation (finalAttrs: { @@ -15,7 +16,10 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ libX11 ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; strictDeps = true; diff --git a/pkgs/by-name/wo/world-serpant-search/package.nix b/pkgs/by-name/wo/world-serpant-search/package.nix index a1aedf9cb724d3..91dcb00d9e1427 100644 --- a/pkgs/by-name/wo/world-serpant-search/package.nix +++ b/pkgs/by-name/wo/world-serpant-search/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -33,7 +34,7 @@ python3.pkgs.buildPythonApplication rec { description = "Command-line tool for vulnerability detection"; homepage = "https://github.com/Latrodect/wss-repo-vulnerability-search-manager"; license = licenses.mit; - maintainers = with maintainers; [ fab]; + maintainers = with maintainers; [ fab ]; mainProgram = "serpant"; }; } diff --git a/pkgs/by-name/wo/worldofgoo/package.nix b/pkgs/by-name/wo/worldofgoo/package.nix index 963d9ab1d288a1..e4b3ddf5a5b2a7 100644 --- a/pkgs/by-name/wo/worldofgoo/package.nix +++ b/pkgs/by-name/wo/worldofgoo/package.nix @@ -1,9 +1,17 @@ -{ lib, stdenv, requireFile, unzip, makeDesktopItem, SDL2, SDL2_mixer, libogg, libvorbis }: +{ + lib, + stdenv, + requireFile, + unzip, + makeDesktopItem, + SDL2, + SDL2_mixer, + libogg, + libvorbis, +}: let - arch = if stdenv.system == "x86_64-linux" - then "x86_64" - else "x86"; + arch = if stdenv.system == "x86_64-linux" then "x86_64" else "x86"; desktopItem = makeDesktopItem { desktopName = "World of Goo"; @@ -36,8 +44,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ unzip ]; sourceRoot = pname; - libPath = lib.makeLibraryPath [ stdenv.cc.cc stdenv.cc.libc SDL2 SDL2_mixer - libogg libvorbis ]; + libPath = lib.makeLibraryPath [ + stdenv.cc.cc + stdenv.cc.libc + SDL2 + SDL2_mixer + libogg + libvorbis + ]; unpackPhase = '' # The game is distributed as a shell script, with a tar of mojosetup, and a @@ -68,7 +82,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://worldofgoo.com"; license = licenses.unfree; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; maintainers = with maintainers; [ jcumming ]; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; }; diff --git a/pkgs/by-name/wo/wormhole-william/package.nix b/pkgs/by-name/wo/wormhole-william/package.nix index eaf637ea3843a5..52dc3783c262ea 100644 --- a/pkgs/by-name/wo/wormhole-william/package.nix +++ b/pkgs/by-name/wo/wormhole-william/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "wormhole-william"; diff --git a/pkgs/by-name/wo/wownero/package.nix b/pkgs/by-name/wo/wownero/package.nix index 7ec9f8d83ed827..04efa59e6d4308 100644 --- a/pkgs/by-name/wo/wownero/package.nix +++ b/pkgs/by-name/wo/wownero/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, boost -, libsodium -, openssl -, rapidjson -, readline -, unbound -, zeromq -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + boost, + libsodium, + openssl, + rapidjson, + readline, + unbound, + zeromq, + darwin, }: let @@ -59,17 +60,19 @@ stdenv.mkDerivation rec { cmake ]; - buildInputs = [ - boost - libsodium - openssl - rapidjson - readline - unbound - zeromq - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.IOKit - ]; + buildInputs = + [ + boost + libsodium + openssl + rapidjson + readline + unbound + zeromq + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.IOKit + ]; postUnpack = '' rm -r $sourceRoot/external/miniupnp diff --git a/pkgs/by-name/wo/wowup-cf/package.nix b/pkgs/by-name/wo/wowup-cf/package.nix index 8e793c01833a65..92846b3de798d4 100644 --- a/pkgs/by-name/wo/wowup-cf/package.nix +++ b/pkgs/by-name/wo/wowup-cf/package.nix @@ -1,4 +1,8 @@ -{ lib, appimageTools, fetchurl }: +{ + lib, + appimageTools, + fetchurl, +}: let version = "2.20.0"; @@ -10,7 +14,8 @@ let }; appimageContents = appimageTools.extractType1 { inherit pname version src; }; -in appimageTools.wrapType1 { +in +appimageTools.wrapType1 { inherit pname version src; extraInstallCommands = '' @@ -23,7 +28,7 @@ in appimageTools.wrapType1 { meta = with lib; { description = "World of Warcraft addon updater with CurseForge support"; longDescription = '' - WowUp is the community centered World of Warcraft addon updater. We attempt to bring the addon community together in an easy to use updater application. We have an ever growing list of supported features. + WowUp is the community centered World of Warcraft addon updater. We attempt to bring the addon community together in an easy to use updater application. We have an ever growing list of supported features. ''; mainProgram = "wowup-cf"; homepage = "https://wowup.io/"; diff --git a/pkgs/by-name/wp/wp-cli/package.nix b/pkgs/by-name/wp/wp-cli/package.nix index f0bb1e9ee7b786..c2ce0e6a9d3f8c 100644 --- a/pkgs/by-name/wp/wp-cli/package.nix +++ b/pkgs/by-name/wp/wp-cli/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchurl -, formats -, installShellFiles -, makeWrapper -, php -, phpIniFile ? null +{ + stdenv, + lib, + fetchurl, + formats, + installShellFiles, + makeWrapper, + php, + phpIniFile ? null, }: let @@ -17,14 +18,13 @@ let }; ini = - if phpIniFile == null - then - (formats.ini { }).generate "php.ini" - { - PHP.memory_limit = -1; # no limit as composer uses a lot of memory - Phar."phar.readonly" = "Off"; - } - else phpIniFile; + if phpIniFile == null then + (formats.ini { }).generate "php.ini" { + PHP.memory_limit = -1; # no limit as composer uses a lot of memory + Phar."phar.readonly" = "Off"; + } + else + phpIniFile; in stdenv.mkDerivation (finalAttrs: { @@ -40,7 +40,10 @@ stdenv.mkDerivation (finalAttrs: { dontConfigure = true; dontBuild = true; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; # Usually --set-default is used to set default environment variables. # But the value is wrapped in single-quotes so our variables would be used literally instead diff --git a/pkgs/by-name/wp/wp4nix/package.nix b/pkgs/by-name/wp/wp4nix/package.nix index 6a829b4ae26727..25810bd6d318e4 100644 --- a/pkgs/by-name/wp/wp4nix/package.nix +++ b/pkgs/by-name/wp/wp4nix/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitLab -, nix -, subversion -, makeWrapper +{ + lib, + buildGoModule, + fetchFromGitLab, + nix, + subversion, + makeWrapper, }: buildGoModule rec { @@ -26,7 +27,12 @@ buildGoModule rec { postInstall = '' wrapProgram $out/bin/wp4nix \ - --prefix PATH : ${lib.makeBinPath [ nix subversion ]} + --prefix PATH : ${ + lib.makeBinPath [ + nix + subversion + ] + } ''; meta = with lib; { @@ -38,4 +44,3 @@ buildGoModule rec { platforms = platforms.unix; }; } - diff --git a/pkgs/by-name/wp/wpaperd/package.nix b/pkgs/by-name/wp/wpaperd/package.nix index 4c90e058a706a7..e6a8e1dd3ad793 100644 --- a/pkgs/by-name/wp/wpaperd/package.nix +++ b/pkgs/by-name/wp/wpaperd/package.nix @@ -1,4 +1,12 @@ -{ lib, rustPlatform, fetchFromGitHub, pkg-config, libxkbcommon, wayland, libGL }: +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libxkbcommon, + wayland, + libGL, +}: rustPlatform.buildRustPackage rec { pname = "wpaperd"; @@ -33,7 +41,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/danyspin97/wpaperd"; license = licenses.gpl3Plus; platforms = platforms.linux; - maintainers = with maintainers; [ DPDmancul fsnkty ]; + maintainers = with maintainers; [ + DPDmancul + fsnkty + ]; mainProgram = "wpaperd"; }; } diff --git a/pkgs/by-name/wp/wpgtk/package.nix b/pkgs/by-name/wp/wpgtk/package.nix index 0223c088c81745..4cf918c52012f7 100644 --- a/pkgs/by-name/wp/wpgtk/package.nix +++ b/pkgs/by-name/wp/wpgtk/package.nix @@ -1,5 +1,13 @@ -{ lib, python3Packages, fetchFromGitHub, libxslt, - gobject-introspection, gtk3, wrapGAppsHook3, adwaita-icon-theme }: +{ + lib, + python3Packages, + fetchFromGitHub, + libxslt, + gobject-introspection, + gtk3, + wrapGAppsHook3, + adwaita-icon-theme, +}: python3Packages.buildPythonApplication rec { pname = "wpgtk"; @@ -31,7 +39,7 @@ python3Packages.buildPythonApplication rec { # The $HOME variable must be set to build the package. A "permission denied" error will occur otherwise preBuild = '' - export HOME=$(pwd) + export HOME=$(pwd) ''; # No test exist @@ -40,16 +48,19 @@ python3Packages.buildPythonApplication rec { meta = with lib; { description = "Template based wallpaper/colorscheme generator and manager"; longDescription = '' - In short, wpgtk is a colorscheme/wallpaper manager with a template system attached which lets you create templates from any textfile and will replace keywords on it on the fly, allowing for great styling and theming possibilities. + In short, wpgtk is a colorscheme/wallpaper manager with a template system attached which lets you create templates from any textfile and will replace keywords on it on the fly, allowing for great styling and theming possibilities. - wpgtk uses pywal as its colorscheme generator, but builds upon it with a UI and other features, such as the abilty to mix and edit the colorschemes generated and save them with their respective wallpapers, having light and dark themes, hackable and fast GTK theme made specifically for wpgtk and custom keywords and values to replace in templates. + wpgtk uses pywal as its colorscheme generator, but builds upon it with a UI and other features, such as the abilty to mix and edit the colorschemes generated and save them with their respective wallpapers, having light and dark themes, hackable and fast GTK theme made specifically for wpgtk and custom keywords and values to replace in templates. - INFO: To work properly, this tool needs "programs.dconf.enable = true" on nixos or dconf installed. A reboot may be required after installing dconf. - ''; + INFO: To work properly, this tool needs "programs.dconf.enable = true" on nixos or dconf installed. A reboot may be required after installing dconf. + ''; homepage = "https://github.com/deviantfero/wpgtk"; license = licenses.gpl2Only; platforms = platforms.linux; - maintainers = with maintainers; [ melkor333 cafkafk ]; + maintainers = with maintainers; [ + melkor333 + cafkafk + ]; mainProgram = "wpg"; }; } diff --git a/pkgs/by-name/wp/wpm/package.nix b/pkgs/by-name/wp/wpm/package.nix index f7786471839a5c..63e9a06d3da9ac 100644 --- a/pkgs/by-name/wp/wpm/package.nix +++ b/pkgs/by-name/wp/wpm/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/wp/wprecon/package.nix b/pkgs/by-name/wp/wprecon/package.nix index 3cb301d34d303c..c6aedc564b4c73 100644 --- a/pkgs/by-name/wp/wprecon/package.nix +++ b/pkgs/by-name/wp/wprecon/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/wq/wqy_microhei/package.nix b/pkgs/by-name/wq/wqy_microhei/package.nix index ced2c4a3a41d6a..aa2569ec0e456f 100644 --- a/pkgs/by-name/wq/wqy_microhei/package.nix +++ b/pkgs/by-name/wq/wqy_microhei/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "wqy-microhei"; diff --git a/pkgs/by-name/wq/wqy_zenhei/package.nix b/pkgs/by-name/wq/wqy_zenhei/package.nix index 50ab5d81a305d6..e03ec3aa4d63ec 100644 --- a/pkgs/by-name/wq/wqy_zenhei/package.nix +++ b/pkgs/by-name/wq/wqy_zenhei/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: stdenvNoCC.mkDerivation rec { pname = "wqy-zenhei"; diff --git a/pkgs/by-name/wr/wrap/package.nix b/pkgs/by-name/wr/wrap/package.nix index 959c78608db1c9..946c41e15ddac5 100644 --- a/pkgs/by-name/wr/wrap/package.nix +++ b/pkgs/by-name/wr/wrap/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch, makeWrapper, courier-prime }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, + makeWrapper, + courier-prime, +}: buildGoModule rec { pname = "wrap"; diff --git a/pkgs/by-name/wr/write-good/package.nix b/pkgs/by-name/wr/write-good/package.nix index 99105ce649d5db..96799b30e91000 100644 --- a/pkgs/by-name/wr/write-good/package.nix +++ b/pkgs/by-name/wr/write-good/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/wr/writedisk/package.nix b/pkgs/by-name/wr/writedisk/package.nix index 6cc8e03fd5e81a..0e22b8c651efbe 100644 --- a/pkgs/by-name/wr/writedisk/package.nix +++ b/pkgs/by-name/wr/writedisk/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/wr/wrk/package.nix b/pkgs/by-name/wr/wrk/package.nix index 082497ad7d28d7..46b3433bf845fc 100644 --- a/pkgs/by-name/wr/wrk/package.nix +++ b/pkgs/by-name/wr/wrk/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, luajit, openssl, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + luajit, + openssl, + perl, +}: stdenv.mkDerivation rec { pname = "wrk"; @@ -11,9 +18,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-nCfA444p7krXOB3qRtDKWxWj9tsrDZsGf03ThtE1dXM="; }; - buildInputs = [ luajit openssl perl ]; - - makeFlags = [ "WITH_LUAJIT=${luajit}" "WITH_OPENSSL=${openssl.dev}" "VER=${version}" ]; + buildInputs = [ + luajit + openssl + perl + ]; + + makeFlags = [ + "WITH_LUAJIT=${luajit}" + "WITH_OPENSSL=${openssl.dev}" + "VER=${version}" + ]; preBuild = '' for f in src/*.h; do diff --git a/pkgs/by-name/wr/wrk2/package.nix b/pkgs/by-name/wr/wrk2/package.nix index 9bc8401efa6616..6e80ff026b1ed1 100644 --- a/pkgs/by-name/wr/wrk2/package.nix +++ b/pkgs/by-name/wr/wrk2/package.nix @@ -1,17 +1,28 @@ -{ lib, stdenv, fetchFromGitHub, luajit, openssl, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + luajit, + openssl, + zlib, +}: stdenv.mkDerivation rec { pname = "wrk2"; version = "4.0.0-${builtins.substring 0 7 src.rev}"; src = fetchFromGitHub { - owner = "giltene"; - repo = "wrk2"; - rev = "e0109df5b9de09251adb5f5848f223fbee2aa9f5"; + owner = "giltene"; + repo = "wrk2"; + rev = "e0109df5b9de09251adb5f5848f223fbee2aa9f5"; sha256 = "1aqdwmgdd74wq73f1zp28yqj91gd6p6nf9nbdfibl7mlklbzvak8"; }; - buildInputs = [ luajit openssl zlib ]; + buildInputs = [ + luajit + openssl + zlib + ]; patchPhase = '' rm -rf deps/luajit && mkdir deps/luajit @@ -34,9 +45,9 @@ stdenv.mkDerivation rec { meta = { description = "Constant throughput, correct latency recording variant of wrk"; - homepage = "https://github.com/giltene/wrk2"; - license = lib.licenses.bsd3; - platforms = lib.platforms.linux; + homepage = "https://github.com/giltene/wrk2"; + license = lib.licenses.bsd3; + platforms = lib.platforms.linux; maintainers = with lib.maintainers; [ thoughtpolice ]; # never built on aarch64-linux since first introduction in nixpkgs broken = stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64; diff --git a/pkgs/by-name/ws/wsdd/package.nix b/pkgs/by-name/ws/wsdd/package.nix index d408706f4ee3f7..2db79f2e9c336a 100644 --- a/pkgs/by-name/ws/wsdd/package.nix +++ b/pkgs/by-name/ws/wsdd/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, installShellFiles, makeWrapper, nixosTests, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + makeWrapper, + nixosTests, + python3, +}: stdenv.mkDerivation rec { pname = "wsdd"; @@ -11,9 +19,15 @@ stdenv.mkDerivation rec { hash = "sha256-T8/XlQpx4CtNy8LuLwOQBG9muFe9pp5583tDaCT4ReI="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; buildInputs = [ python3 ]; diff --git a/pkgs/by-name/ws/wshowkeys/package.nix b/pkgs/by-name/ws/wshowkeys/package.nix index ef0c6fd6cd3473..72777ca9e575fd 100644 --- a/pkgs/by-name/ws/wshowkeys/package.nix +++ b/pkgs/by-name/ws/wshowkeys/package.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, fetchFromGitHub -, meson, pkg-config, wayland-scanner, ninja -, cairo, libinput, pango, wayland, wayland-protocols, libxkbcommon +{ + lib, + stdenv, + fetchFromGitHub, + meson, + pkg-config, + wayland-scanner, + ninja, + cairo, + libinput, + pango, + wayland, + wayland-protocols, + libxkbcommon, }: stdenv.mkDerivation rec { @@ -15,8 +26,20 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ meson pkg-config wayland-scanner ninja ]; - buildInputs = [ cairo libinput pango wayland wayland-protocols libxkbcommon ]; + nativeBuildInputs = [ + meson + pkg-config + wayland-scanner + ninja + ]; + buildInputs = [ + cairo + libinput + pango + wayland + wayland-protocols + libxkbcommon + ]; meta = with lib; { description = "Displays keys being pressed on a Wayland session"; @@ -28,11 +51,17 @@ stdenv.mkDerivation rec { setuid binary (use "programs.wshowkeys.enable = true;"). ''; homepage = "https://github.com/ammgws/wshowkeys"; - license = with licenses; [ gpl3Only mit ]; + license = with licenses; [ + gpl3Only + mit + ]; # Some portions of the code are taken from Sway which is MIT licensed. # TODO: gpl3Only or gpl3Plus (ask upstream)? platforms = platforms.linux; - maintainers = with maintainers; [ primeos berbiche ]; + maintainers = with maintainers; [ + primeos + berbiche + ]; mainProgram = "wshowkeys"; }; } diff --git a/pkgs/by-name/ws/wsl-open/package.nix b/pkgs/by-name/ws/wsl-open/package.nix index e4698ccbabd04c..bf92ea0b305817 100644 --- a/pkgs/by-name/ws/wsl-open/package.nix +++ b/pkgs/by-name/ws/wsl-open/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "wsl-open"; diff --git a/pkgs/by-name/ws/wsl-vpnkit/package.nix b/pkgs/by-name/ws/wsl-vpnkit/package.nix index b9b25747a50f53..22d4b341d496a4 100644 --- a/pkgs/by-name/ws/wsl-vpnkit/package.nix +++ b/pkgs/by-name/ws/wsl-vpnkit/package.nix @@ -1,17 +1,18 @@ -{ lib -, resholve -, fetchFromGitHub +{ + lib, + resholve, + fetchFromGitHub, # Runtime dependencies -, coreutils -, dnsutils -, gawk -, gnugrep -, gvproxy -, iproute2 -, iptables -, iputils -, wget + coreutils, + dnsutils, + gawk, + gnugrep, + gvproxy, + iproute2, + iptables, + iputils, + wget, }: let diff --git a/pkgs/by-name/ws/wslu/package.nix b/pkgs/by-name/ws/wslu/package.nix index 3ef601b0e123c3..52ea85c4c7b9f0 100644 --- a/pkgs/by-name/ws/wslu/package.nix +++ b/pkgs/by-name/ws/wslu/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, copyDesktopItems +{ + lib, + stdenv, + fetchFromGitHub, + copyDesktopItems, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ws/wsmancli/package.nix b/pkgs/by-name/ws/wsmancli/package.nix index c9c07c81bcae4e..4f2ac4aaf3a9c3 100644 --- a/pkgs/by-name/ws/wsmancli/package.nix +++ b/pkgs/by-name/ws/wsmancli/package.nix @@ -1,20 +1,33 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config -, openssl, openwsman }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + openssl, + openwsman, +}: stdenv.mkDerivation rec { pname = "wsmancli"; version = "2.6.2"; src = fetchFromGitHub { - owner = "Openwsman"; - repo = "wsmancli"; - rev = "v${version}"; + owner = "Openwsman"; + repo = "wsmancli"; + rev = "v${version}"; sha256 = "sha256-A2PVhQuKVTZ/nDKyy+vZVBNLB/3xujBYBzUEWcTIYYg="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ openwsman openssl ]; + buildInputs = [ + openwsman + openssl + ]; postPatch = '' touch AUTHORS NEWS README @@ -30,6 +43,11 @@ stdenv.mkDerivation rec { WS-Management specification and Testing. ''; downloadPage = "https://github.com/Openwsman/wsmancli/releases"; - inherit (openwsman.meta) homepage license maintainers platforms; + inherit (openwsman.meta) + homepage + license + maintainers + platforms + ; }; } diff --git a/pkgs/by-name/ws/wsrepl/package.nix b/pkgs/by-name/ws/wsrepl/package.nix index 9557fec2210c60..6198287b18fcea 100644 --- a/pkgs/by-name/ws/wsrepl/package.nix +++ b/pkgs/by-name/ws/wsrepl/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/wt/wtf/package.nix b/pkgs/by-name/wt/wtf/package.nix index e75ae315a557c4..6bb27c9f932cf2 100644 --- a/pkgs/by-name/wt/wtf/package.nix +++ b/pkgs/by-name/wt/wtf/package.nix @@ -1,8 +1,9 @@ -{ buildGoModule -, fetchFromGitHub -, lib -, makeWrapper -, ncurses +{ + buildGoModule, + fetchFromGitHub, + lib, + makeWrapper, + ncurses, }: buildGoModule rec { @@ -21,7 +22,11 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; subPackages = [ "." ]; diff --git a/pkgs/by-name/wt/wtfis/package.nix b/pkgs/by-name/wt/wtfis/package.nix index 80e500ba726e8e..b92f2f01960b52 100644 --- a/pkgs/by-name/wt/wtfis/package.nix +++ b/pkgs/by-name/wt/wtfis/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: let @@ -12,7 +13,8 @@ let rev = "refs/tags/v${version}"; hash = "sha256-+BJmAFjmj3z/sKJ/L/y6hTClesulpQTpDL9cUNRi6e8="; }; -in python3.pkgs.buildPythonApplication { +in +python3.pkgs.buildPythonApplication { inherit pname version src; format = "pyproject"; diff --git a/pkgs/by-name/wt/wthrr/package.nix b/pkgs/by-name/wt/wthrr/package.nix index 28072763b8ca50..0ce0b98357b954 100644 --- a/pkgs/by-name/wt/wthrr/package.nix +++ b/pkgs/by-name/wt/wthrr/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -24,13 +25,15 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreFoundation - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreFoundation + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + ]; checkFlags = [ # requires internet access diff --git a/pkgs/by-name/wt/wtk/package.nix b/pkgs/by-name/wt/wtk/package.nix index 1360895942a460..a66ab691fd091d 100644 --- a/pkgs/by-name/wt/wtk/package.nix +++ b/pkgs/by-name/wt/wtk/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, requireFile, unzip, xorg }: +{ + lib, + stdenv, + requireFile, + unzip, + xorg, +}: stdenv.mkDerivation rec { pname = "sun-java-wtk"; @@ -14,7 +20,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ unzip ]; - libraries = [ xorg.libXpm xorg.libXt xorg.libX11 xorg.libICE xorg.libSM stdenv.cc.cc ]; + libraries = [ + xorg.libXpm + xorg.libXt + xorg.libX11 + xorg.libICE + xorg.libSM + stdenv.cc.cc + ]; meta = { homepage = "http://java.sun.com/products/sjwtoolkit/download.html"; diff --git a/pkgs/by-name/wt/wttrbar/package.nix b/pkgs/by-name/wt/wttrbar/package.nix index 4bf6b601249883..075d5acdc5bfa7 100644 --- a/pkgs/by-name/wt/wttrbar/package.nix +++ b/pkgs/by-name/wt/wttrbar/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, darwin -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, + nix-update-script, }: rustPlatform.buildRustPackage rec { @@ -17,7 +18,13 @@ rustPlatform.buildRustPackage rec { hash = "sha256-FJexqBzsLeaF7iWWwcenRINpMRtkpThxLWlMEectjfQ="; }; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk_11_0.frameworks; [ Security SystemConfiguration ]); + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk_11_0.frameworks; + [ + Security + SystemConfiguration + ] + ); cargoHash = "sha256-4pcMcCxidNY4EIvYWGa/cfovRGHMEIcVfJWiMG/8aog="; diff --git a/pkgs/by-name/wt/wtwitch/package.nix b/pkgs/by-name/wt/wtwitch/package.nix index 73bfe1c3fd6265..cf9d1987785774 100644 --- a/pkgs/by-name/wt/wtwitch/package.nix +++ b/pkgs/by-name/wt/wtwitch/package.nix @@ -1,20 +1,21 @@ -{ bash -, coreutils-prefixed -, curl -, fetchFromGitHub -, gnused -, gnugrep -, installShellFiles -, jq -, lib -, makeWrapper -, mplayer -, mpv -, procps -, scdoc -, stdenv -, streamlink -, vlc +{ + bash, + coreutils-prefixed, + curl, + fetchFromGitHub, + gnused, + gnugrep, + installShellFiles, + jq, + lib, + makeWrapper, + mplayer, + mpv, + procps, + scdoc, + stdenv, + streamlink, + vlc, }: stdenv.mkDerivation rec { @@ -37,7 +38,11 @@ stdenv.mkDerivation rec { scdoc < src/wtwitch.1.scd > wtwitch.1 ''; - nativeBuildInputs = [ scdoc installShellFiles makeWrapper ]; + nativeBuildInputs = [ + scdoc + installShellFiles + makeWrapper + ]; installPhase = '' installManPage wtwitch.1 @@ -47,18 +52,23 @@ stdenv.mkDerivation rec { install -Dm755 src/wtwitch $out/bin/wtwitch wrapProgram $out/bin/wtwitch \ --set-default LANG en_US.UTF-8 \ - --prefix PATH : ${lib.makeBinPath (lib.optionals stdenv.hostPlatform.isLinux [ vlc ] ++ [ - bash - coreutils-prefixed - curl - gnused - gnugrep - jq - mplayer - mpv - procps - streamlink - ])} + --prefix PATH : ${ + lib.makeBinPath ( + lib.optionals stdenv.hostPlatform.isLinux [ vlc ] + ++ [ + bash + coreutils-prefixed + curl + gnused + gnugrep + jq + mplayer + mpv + procps + streamlink + ] + ) + } ''; meta = with lib; { diff --git a/pkgs/by-name/wt/wtype/package.nix b/pkgs/by-name/wt/wtype/package.nix index d3e85d1c3c25be..e1ebaf728d3a43 100644 --- a/pkgs/by-name/wt/wtype/package.nix +++ b/pkgs/by-name/wt/wtype/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, -, meson -, ninja -, pkg-config + meson, + ninja, + pkg-config, -, libxkbcommon -, wayland -, wayland-scanner + libxkbcommon, + wayland, + wayland-scanner, }: stdenv.mkDerivation rec { @@ -23,8 +24,16 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ meson ninja pkg-config wayland-scanner ]; - buildInputs = [ libxkbcommon wayland ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + wayland-scanner + ]; + buildInputs = [ + libxkbcommon + wayland + ]; meta = with lib; { description = "xdotool type for wayland"; diff --git a/pkgs/by-name/wu/wuzz/package.nix b/pkgs/by-name/wu/wuzz/package.nix index c428b40547f11e..d672360512503b 100644 --- a/pkgs/by-name/wu/wuzz/package.nix +++ b/pkgs/by-name/wu/wuzz/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, fetchpatch }: +{ + lib, + buildGoModule, + fetchFromGitHub, + fetchpatch, +}: buildGoModule rec { pname = "wuzz"; diff --git a/pkgs/by-name/wv/wv/package.nix b/pkgs/by-name/wv/wv/package.nix index f05465ac1475ef..befbfe6a22e67f 100644 --- a/pkgs/by-name/wv/wv/package.nix +++ b/pkgs/by-name/wv/wv/package.nix @@ -1,7 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, zlib, imagemagick, libpng, glib, pkg-config, libgsf -, libxml2, bzip2 -, autoreconfHook -, buildPackages +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + imagemagick, + libpng, + glib, + pkg-config, + libgsf, + libxml2, + bzip2, + autoreconfHook, + buildPackages, }: stdenv.mkDerivation (finalAttrs: { @@ -11,12 +21,23 @@ stdenv.mkDerivation (finalAttrs: { src = fetchFromGitHub { owner = "AbiWord"; repo = "wv"; - rev = "wv-${builtins.replaceStrings ["."] ["-"] finalAttrs.version}"; + rev = "wv-${builtins.replaceStrings [ "." ] [ "-" ] finalAttrs.version}"; hash = "sha256-xcC+/M1EzFqQFeF5Dw9qd8VIy7r8JdKMp2X/GHkFiPA="; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ zlib imagemagick libpng glib libgsf libxml2 bzip2 ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + zlib + imagemagick + libpng + glib + libgsf + libxml2 + bzip2 + ]; configureFlags = [ "PKG_CONFIG=${buildPackages.pkg-config}/bin/${buildPackages.pkg-config.targetPrefix}pkg-config" @@ -24,7 +45,8 @@ stdenv.mkDerivation (finalAttrs: { env.NIX_CFLAGS_COMPILE = # Suppress incompatible function pointer and int conversion errors when building with newer versions of clang 16. - lib.optionalString stdenv.cc.isClang "-Wno-error=incompatible-function-pointer-types -Wno-error=int-conversion"; + lib.optionalString stdenv.cc.isClang + "-Wno-error=incompatible-function-pointer-types -Wno-error=int-conversion"; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/wv/wv2/package.nix b/pkgs/by-name/wv/wv2/package.nix index 8a4ccaed896c15..1908fdf4e4bef0 100644 --- a/pkgs/by-name/wv/wv2/package.nix +++ b/pkgs/by-name/wv/wv2/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, cmake, libgsf, glib, libxml2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + cmake, + libgsf, + glib, + libxml2, +}: stdenv.mkDerivation rec { pname = "wv2"; @@ -19,8 +28,15 @@ stdenv.mkDerivation rec { export NIX_LDFLAGS+=" $(pkg-config gobject-2.0 --libs)" ''; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libgsf glib libxml2 ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + libgsf + glib + libxml2 + ]; env.NIX_CFLAGS_COMPILE = "-I${libxml2.dev}/include/libxml2"; diff --git a/pkgs/by-name/wv/wvkbd/package.nix b/pkgs/by-name/wv/wvkbd/package.nix index ff8e5626f63aca..0901ee9bf69e47 100644 --- a/pkgs/by-name/wv/wvkbd/package.nix +++ b/pkgs/by-name/wv/wvkbd/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, wayland-scanner -, wayland -, pango -, glib -, harfbuzz -, cairo -, pkg-config -, libxkbcommon +{ + stdenv, + lib, + fetchFromGitHub, + wayland-scanner, + wayland, + pango, + glib, + harfbuzz, + cairo, + pkg-config, + libxkbcommon, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ww/wwcd/package.nix b/pkgs/by-name/ww/wwcd/package.nix index 0e83ada195b0bb..82c3aaca384bbf 100644 --- a/pkgs/by-name/ww/wwcd/package.nix +++ b/pkgs/by-name/ww/wwcd/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromSourcehut -, autoreconfHook -, pkg-config -, check +{ + stdenv, + lib, + fetchFromSourcehut, + autoreconfHook, + pkg-config, + check, }: stdenv.mkDerivation rec { @@ -18,7 +19,9 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - autoreconfHook pkg-config check + autoreconfHook + pkg-config + check ]; autoreconfFlags = [ "-if" ]; diff --git a/pkgs/by-name/wx/wxc/package.nix b/pkgs/by-name/wx/wxc/package.nix index 42de45ecfcf174..e7c2f0e9e5f39a 100644 --- a/pkgs/by-name/wx/wxc/package.nix +++ b/pkgs/by-name/wx/wxc/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitea -, cmake -, libGL -, wxGTK32 +{ + lib, + stdenv, + fetchFromGitea, + cmake, + libGL, + wxGTK32, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/wx/wxformbuilder/package.nix b/pkgs/by-name/wx/wxformbuilder/package.nix index 7a5d7a933216e5..3a90c0d8e22d8c 100644 --- a/pkgs/by-name/wx/wxformbuilder/package.nix +++ b/pkgs/by-name/wx/wxformbuilder/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, darwin -, makeWrapper -, shared-mime-info -, boost -, wxGTK32 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + darwin, + makeWrapper, + shared-mime-info, + boost, + wxGTK32, }: stdenv.mkDerivation (finalAttrs: { @@ -35,21 +36,26 @@ stdenv.mkDerivation (finalAttrs: { sed -i '/fixup_bundle/d' cmake/macros.cmake ''; - nativeBuildInputs = [ - cmake - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.sigtool - makeWrapper - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - shared-mime-info - ]; + nativeBuildInputs = + [ + cmake + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.sigtool + makeWrapper + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + shared-mime-info + ]; - buildInputs = [ - boost - wxGTK32 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Cocoa - ]; + buildInputs = + [ + boost + wxGTK32 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Cocoa + ]; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' mkdir -p $out/{Applications,bin} @@ -62,7 +68,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/wxFormBuilder/wxFormBuilder"; license = licenses.gpl2Only; mainProgram = "wxformbuilder"; - maintainers = with maintainers; [ matthuszagh wegank ]; + maintainers = with maintainers; [ + matthuszagh + wegank + ]; platforms = platforms.unix; }; }) diff --git a/pkgs/by-name/wx/wxmacmolplt/package.nix b/pkgs/by-name/wx/wxmacmolplt/package.nix index 0ec45053bf67c2..6252ff7d5f247b 100644 --- a/pkgs/by-name/wx/wxmacmolplt/package.nix +++ b/pkgs/by-name/wx/wxmacmolplt/package.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, wxGTK32 -, libGL -, libGLU -, pkg-config -, xorg -, autoreconfHook -, wrapGAppsHook4 +{ + stdenv, + lib, + fetchFromGitHub, + wxGTK32, + libGL, + libGLU, + pkg-config, + xorg, + autoreconfHook, + wrapGAppsHook4, }: stdenv.mkDerivation rec { @@ -21,7 +22,11 @@ stdenv.mkDerivation rec { hash = "sha256-gFGstyq9bMmBaIS4QE6N3EIC9GxRvyJYUr8DUvwRQBc="; }; - nativeBuildInputs = [ pkg-config autoreconfHook wrapGAppsHook4 ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + wrapGAppsHook4 + ]; buildInputs = [ wxGTK32 libGL @@ -40,6 +45,9 @@ stdenv.mkDerivation rec { homepage = "https://brettbode.github.io/wxmacmolplt/"; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ sheepforce markuskowa ]; + maintainers = with maintainers; [ + sheepforce + markuskowa + ]; }; } diff --git a/pkgs/by-name/wy/wyoming-satellite/package.nix b/pkgs/by-name/wy/wyoming-satellite/package.nix index bfd0e49f6f7113..7d1589e99ee4d2 100644 --- a/pkgs/by-name/wy/wyoming-satellite/package.nix +++ b/pkgs/by-name/wy/wyoming-satellite/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { @@ -48,7 +49,6 @@ python3Packages.buildPythonApplication rec { pytestCheckHook ]; - meta = with lib; { description = "Remote voice satellite using Wyoming protocol"; homepage = "https://github.com/rhasspy/wyoming-satellite"; diff --git a/pkgs/by-name/wy/wyvern/package.nix b/pkgs/by-name/wy/wyvern/package.nix index 5afee81c6c0c8c..53f50ca8090319 100644 --- a/pkgs/by-name/wy/wyvern/package.nix +++ b/pkgs/by-name/wy/wyvern/package.nix @@ -1,9 +1,10 @@ -{ lib -, fetchCrate -, rustPlatform -, cmake -, pkg-config -, openssl +{ + lib, + fetchCrate, + rustPlatform, + cmake, + pkg-config, + openssl, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-cwk8yFt8JrYkYlNUW9n/bgMUA6jyOpG0TSh5C+eERLY="; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ openssl ]; meta = with lib; { diff --git a/pkgs/by-name/x-/x-create-mouse-void/package.nix b/pkgs/by-name/x-/x-create-mouse-void/package.nix index 86ae59a6152cab..4be1a04606347f 100644 --- a/pkgs/by-name/x-/x-create-mouse-void/package.nix +++ b/pkgs/by-name/x-/x-create-mouse-void/package.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, xorg, fetchFromGitHub }: +{ + stdenv, + lib, + xorg, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "x-create-mouse-void"; diff --git a/pkgs/by-name/x1/x11_ssh_askpass/package.nix b/pkgs/by-name/x1/x11_ssh_askpass/package.nix index 049154d64413ff..86a17d34cb0c96 100644 --- a/pkgs/by-name/x1/x11_ssh_askpass/package.nix +++ b/pkgs/by-name/x1/x11_ssh_askpass/package.nix @@ -1,18 +1,36 @@ -{ lib, stdenv, fetchurl, xorg, imake, gccmakedep }: +{ + lib, + stdenv, + fetchurl, + xorg, + imake, + gccmakedep, +}: stdenv.mkDerivation rec { pname = "x11-ssh-askpass"; version = "1.2.4.1"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; src = fetchurl { url = "http://pkgs.fedoraproject.org/repo/pkgs/openssh/x11-ssh-askpass-${version}.tar.gz/8f2e41f3f7eaa8543a2440454637f3c3/x11-ssh-askpass-${version}.tar.gz"; sha256 = "620de3c32ae72185a2c9aeaec03af24242b9621964e38eb625afb6cdb30b8c88"; }; - nativeBuildInputs = [ imake gccmakedep ]; - buildInputs = [ xorg.libX11 xorg.libXt xorg.libICE xorg.libSM ]; + nativeBuildInputs = [ + imake + gccmakedep + ]; + buildInputs = [ + xorg.libX11 + xorg.libXt + xorg.libICE + xorg.libSM + ]; configureFlags = [ "--with-app-defaults-dir=$out/etc/X11/app-defaults" @@ -23,7 +41,10 @@ stdenv.mkDerivation rec { xmkmf -a ''; - installTargets = [ "install" "install.man" ]; + installTargets = [ + "install" + "install.man" + ]; meta = with lib; { homepage = "https://github.com/sigmavirus24/x11-ssh-askpass"; diff --git a/pkgs/by-name/x1/x11docker/package.nix b/pkgs/by-name/x1/x11docker/package.nix index 1e400088693b30..56bedfc7e5e627 100644 --- a/pkgs/by-name/x1/x11docker/package.nix +++ b/pkgs/by-name/x1/x11docker/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, nx-libs, xorg, getopt, gnugrep, gawk, ps, mount, iproute2 }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + nx-libs, + xorg, + getopt, + gnugrep, + gawk, + ps, + mount, + iproute2, +}: stdenv.mkDerivation rec { pname = "x11docker"; version = "7.6.0"; @@ -16,7 +29,20 @@ stdenv.mkDerivation rec { installPhase = '' install -D x11docker "$out/bin/x11docker"; wrapProgram "$out/bin/x11docker" \ - --prefix PATH : "${lib.makeBinPath [ getopt gnugrep gawk ps mount iproute2 nx-libs xorg.xdpyinfo xorg.xhost xorg.xinit ]}" + --prefix PATH : "${ + lib.makeBinPath [ + getopt + gnugrep + gawk + ps + mount + iproute2 + nx-libs + xorg.xdpyinfo + xorg.xhost + xorg.xinit + ] + }" ''; meta = { diff --git a/pkgs/by-name/x1/x11idle/package.nix b/pkgs/by-name/x1/x11idle/package.nix index e349b54eecae5b..3bafab5b6a48ab 100644 --- a/pkgs/by-name/x1/x11idle/package.nix +++ b/pkgs/by-name/x1/x11idle/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libXScrnSaver, libX11 }: +{ + lib, + stdenv, + fetchurl, + libXScrnSaver, + libX11, +}: stdenv.mkDerivation rec { version = "9.2.4"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "0fc5g57xd6bmghyl214gcff0ni3idv33i3gkr339kgn1mdjljv5g"; }; - buildInputs = [ libXScrnSaver libX11 ]; + buildInputs = [ + libXScrnSaver + libX11 + ]; dontUnpack = true; diff --git a/pkgs/by-name/x1/x11spice/package.nix b/pkgs/by-name/x1/x11spice/package.nix index 4facc365c1ede7..d4d4fb272cc4f5 100644 --- a/pkgs/by-name/x1/x11spice/package.nix +++ b/pkgs/by-name/x1/x11spice/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitLab, autoreconfHook, pkg-config -, xorg, gtk2, spice, spice-protocol +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + xorg, + gtk2, + spice, + spice-protocol, }: stdenv.mkDerivation rec { @@ -14,11 +22,18 @@ stdenv.mkDerivation rec { sha256 = "0va5ix14vnqch59gq8wvrhw6q0w0n27sy70xx5kvfj2cl0h1xpg8"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ - xorg.libxcb xorg.xcbutil xorg.utilmacros - gtk2 spice spice-protocol + xorg.libxcb + xorg.xcbutil + xorg.utilmacros + gtk2 + spice + spice-protocol ]; NIX_LDFLAGS = "-lpthread"; diff --git a/pkgs/by-name/x1/x11vnc/package.nix b/pkgs/by-name/x1/x11vnc/package.nix index 463daf17cc88ae..5331f43e37d9ea 100644 --- a/pkgs/by-name/x1/x11vnc/package.nix +++ b/pkgs/by-name/x1/x11vnc/package.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, - openssl, zlib, libjpeg, xorg, coreutils, libvncserver, - autoreconfHook, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + openssl, + zlib, + libjpeg, + xorg, + coreutils, + libvncserver, + autoreconfHook, + pkg-config, +}: stdenv.mkDerivation rec { pname = "x11vnc"; @@ -29,16 +40,27 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = - [ xorg.libXfixes xorg.xorgproto openssl xorg.libXdamage - zlib xorg.libX11 libjpeg - xorg.libXtst xorg.libXinerama xorg.libXrandr - xorg.libXext - xorg.libXi xorg.libXrender - libvncserver - ]; + buildInputs = [ + xorg.libXfixes + xorg.xorgproto + openssl + xorg.libXdamage + zlib + xorg.libX11 + libjpeg + xorg.libXtst + xorg.libXinerama + xorg.libXrandr + xorg.libXext + xorg.libXi + xorg.libXrender + libvncserver + ]; postPatch = '' substituteInPlace src/unixpw.c \ diff --git a/pkgs/by-name/x1/x16/package.nix b/pkgs/by-name/x1/x16/package.nix index 26a12e480e7fc1..457cc3a3b3b9ee 100644 --- a/pkgs/by-name/x1/x16/package.nix +++ b/pkgs/by-name/x1/x16/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL2 -, callPackage -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + callPackage, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -44,7 +45,7 @@ stdenv.mkDerivation (finalAttrs: { inherit (finalAttrs) version; emulator = finalAttrs.finalPackage; rom = callPackage ./rom.nix { }; - run = (callPackage ./run.nix { }){ + run = (callPackage ./run.nix { }) { inherit (finalAttrs.finalPackage) emulator rom; }; }; diff --git a/pkgs/by-name/x1/x16/rom.nix b/pkgs/by-name/x1/x16/rom.nix index ed85dd5108acee..6caefd021fc3cb 100644 --- a/pkgs/by-name/x1/x16/rom.nix +++ b/pkgs/by-name/x1/x16/rom.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cc65 -, lzsa -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + cc65, + lzsa, + python3, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/x1/x16/run.nix b/pkgs/by-name/x1/x16/run.nix index a9f72da4d32c5e..f88e5f181f2736 100644 --- a/pkgs/by-name/x1/x16/run.nix +++ b/pkgs/by-name/x1/x16/run.nix @@ -1,6 +1,7 @@ -{ runtimeShell -, symlinkJoin -, writeTextFile +{ + runtimeShell, + symlinkJoin, + writeTextFile, }: { emulator, rom }: diff --git a/pkgs/by-name/x2/x2goserver/package.nix b/pkgs/by-name/x2/x2goserver/package.nix index 44e16e378f5594..bac2b554aee355 100644 --- a/pkgs/by-name/x2/x2goserver/package.nix +++ b/pkgs/by-name/x2/x2goserver/package.nix @@ -1,6 +1,30 @@ -{ stdenv, lib, fetchurl, perlPackages, makeWrapper, perl, which, nx-libs -, util-linux, coreutils, glibc, gawk, gnused, gnugrep, findutils, xorg -, nettools, iproute2, bc, procps, psmisc, lsof, pwgen, openssh, sshfs, bash +{ + stdenv, + lib, + fetchurl, + perlPackages, + makeWrapper, + perl, + which, + nx-libs, + util-linux, + coreutils, + glibc, + gawk, + gnused, + gnugrep, + findutils, + xorg, + nettools, + iproute2, + bc, + procps, + psmisc, + lsof, + pwgen, + openssh, + sshfs, + bash, }: let @@ -15,7 +39,10 @@ let x2go-perl = perlPackages.buildPerlPackage rec { pname = "X2Go"; inherit version src; - makeFlags = [ "-f" "Makefile.perl" ]; + makeFlags = [ + "-f" + "Makefile.perl" + ]; patchPhase = '' substituteInPlace X2Go/Config.pm --replace '/etc/x2go' '/var/lib/x2go/conf' substituteInPlace X2Go/Server/DB.pm \ @@ -25,21 +52,57 @@ let ''; }; - perlEnv = perl.withPackages (p: with p; [ - x2go-perl DBI DBDSQLite FileBaseDir TryTiny CaptureTiny ConfigSimple Switch FileWhich - ]); + perlEnv = perl.withPackages ( + p: with p; [ + x2go-perl + DBI + DBDSQLite + FileBaseDir + TryTiny + CaptureTiny + ConfigSimple + Switch + FileWhich + ] + ); binaryDeps = [ - perlEnv which nx-libs util-linux coreutils glibc.bin gawk gnused gnugrep - findutils nettools iproute2 bc procps psmisc lsof pwgen openssh sshfs - xorg.xauth xorg.xinit xorg.xrandr xorg.xmodmap xorg.xwininfo xorg.fontutil - xorg.xkbcomp xorg.setxkbmap + perlEnv + which + nx-libs + util-linux + coreutils + glibc.bin + gawk + gnused + gnugrep + findutils + nettools + iproute2 + bc + procps + psmisc + lsof + pwgen + openssh + sshfs + xorg.xauth + xorg.xinit + xorg.xrandr + xorg.xmodmap + xorg.xwininfo + xorg.fontutil + xorg.xkbcomp + xorg.setxkbmap ]; in stdenv.mkDerivation rec { inherit pname version src; - buildInputs = [ perlEnv bash ]; + buildInputs = [ + perlEnv + bash + ]; nativeBuildInputs = [ makeWrapper ]; @@ -62,7 +125,10 @@ stdenv.mkDerivation rec { --replace "[ -f /etc/redhat-release ]" "[ -d /etc/nix ] || [ -f /etc/redhat-release ]" ''; - makeFlags = [ "PREFIX=/" "NXLIBDIR=${nx-libs}/lib/nx" ]; + makeFlags = [ + "PREFIX=/" + "NXLIBDIR=${nx-libs}/lib/nx" + ]; installFlags = [ "DESTDIR=$(out)" ]; diff --git a/pkgs/by-name/x2/x2vnc/package.nix b/pkgs/by-name/x2/x2vnc/package.nix index 2d06c8e6303fb3..436066e5f7bfa8 100644 --- a/pkgs/by-name/x2/x2vnc/package.nix +++ b/pkgs/by-name/x2/x2vnc/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, xorg }: +{ + lib, + stdenv, + fetchurl, + xorg, +}: stdenv.mkDerivation rec { pname = "x2vnc"; @@ -12,7 +17,10 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = "-std=gnu89"; buildInputs = with xorg; [ - libX11 xorgproto libXext libXrandr + libX11 + xorgproto + libXext + libXrandr ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/x2/x2x/package.nix b/pkgs/by-name/x2/x2x/package.nix index 061f1d190318aa..93ccc98b2d524a 100644 --- a/pkgs/by-name/x2/x2x/package.nix +++ b/pkgs/by-name/x2/x2x/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, libX11, libXtst, libXext, fetchFromGitHub, autoreconfHook, pkg-config, libXi }: +{ + lib, + stdenv, + libX11, + libXtst, + libXext, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libXi, +}: stdenv.mkDerivation rec { pname = "x2x"; @@ -11,8 +21,16 @@ stdenv.mkDerivation rec { hash = "sha256-FUl2z/Yz9uZlUu79LHdsXZ6hAwSlqwFV35N+GYDNvlQ="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libX11 libXtst libXext libXi ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libX11 + libXtst + libXext + libXi + ]; meta = with lib; { description = "Allows the keyboard, mouse on one X display to be used to control another X display"; diff --git a/pkgs/by-name/x3/x3270/package.nix b/pkgs/by-name/x3/x3270/package.nix index 45b08bd10f6647..39399f5a83ce9d 100644 --- a/pkgs/by-name/x3/x3270/package.nix +++ b/pkgs/by-name/x3/x3270/package.nix @@ -1,25 +1,26 @@ -{ stdenv -, darwin -, lib -, libiconv -, fetchurl -, m4 -, expat -, libX11 -, libXt -, libXaw -, libXmu -, bdftopcf -, mkfontdir -, fontadobe100dpi -, fontadobeutopia100dpi -, fontbh100dpi -, fontbhlucidatypewriter100dpi -, fontbitstream100dpi -, tcl -, ncurses -, openssl -, readline +{ + stdenv, + darwin, + lib, + libiconv, + fetchurl, + m4, + expat, + libX11, + libXt, + libXaw, + libXmu, + bdftopcf, + mkfontdir, + fontadobe100dpi, + fontadobeutopia100dpi, + fontbh100dpi, + fontbhlucidatypewriter100dpi, + fontbitstream100dpi, + tcl, + ncurses, + openssl, + readline, }: let majorVersion = "4"; @@ -31,8 +32,7 @@ stdenv.mkDerivation rec { version = "${majorVersion}.${minorVersion}${versionSuffix}"; src = fetchurl { - url = - "http://x3270.bgp.nu/download/0${majorVersion}.0${minorVersion}/suite3270-${version}-src.tgz"; + url = "http://x3270.bgp.nu/download/0${majorVersion}.0${minorVersion}/suite3270-${version}-src.tgz"; sha256 = "sha256-gcC6REfZentIPEDhGznUSYu8mvVfpPeMz/Bks+N43Fk="; }; @@ -52,25 +52,30 @@ stdenv.mkDerivation rec { pathsToLink = [ "/share/man" ]; nativeBuildInputs = [ m4 ]; - buildInputs = [ - expat - libX11 - libXt - libXaw - libXmu - bdftopcf - mkfontdir - fontadobe100dpi - fontadobeutopia100dpi - fontbh100dpi - fontbhlucidatypewriter100dpi - fontbitstream100dpi - tcl - ncurses - expat - openssl - readline - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv darwin.apple_sdk.frameworks.Security ]; + buildInputs = + [ + expat + libX11 + libXt + libXaw + libXmu + bdftopcf + mkfontdir + fontadobe100dpi + fontadobeutopia100dpi + fontbh100dpi + fontbhlucidatypewriter100dpi + fontbitstream100dpi + tcl + ncurses + expat + openssl + readline + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + darwin.apple_sdk.frameworks.Security + ]; meta = with lib; { description = "IBM 3270 terminal emulator for the X Window System"; diff --git a/pkgs/by-name/x4/x42-avldrums/package.nix b/pkgs/by-name/x4/x42-avldrums/package.nix index 4a802a324e8a00..b17474141d7dbe 100644 --- a/pkgs/by-name/x4/x42-avldrums/package.nix +++ b/pkgs/by-name/x4/x42-avldrums/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, cairo, glib, libGLU, lv2, pango }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cairo, + glib, + libGLU, + lv2, + pango, +}: stdenv.mkDerivation rec { pname = "x42-avldrums"; @@ -13,7 +23,13 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ cairo glib libGLU lv2 pango ]; + buildInputs = [ + cairo + glib + libGLU + lv2 + pango + ]; makeFlags = [ "PREFIX=$(out)" @@ -25,7 +41,10 @@ stdenv.mkDerivation rec { broken = (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64); description = "Drum sample player LV2 plugin dedicated to Glen MacArthur's AVLdrums"; homepage = "https://x42-plugins.com/x42/x42-avldrums"; - maintainers = with maintainers; [ magnetophon orivej ]; + maintainers = with maintainers; [ + magnetophon + orivej + ]; license = licenses.gpl2Plus; platforms = platforms.linux; }; diff --git a/pkgs/by-name/x4/x42-gmsynth/package.nix b/pkgs/by-name/x4/x42-gmsynth/package.nix index 1d31211ec80d61..9ac13dc8614617 100644 --- a/pkgs/by-name/x4/x42-gmsynth/package.nix +++ b/pkgs/by-name/x4/x42-gmsynth/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, glib, lv2 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + glib, + lv2, +}: stdenv.mkDerivation rec { pname = "x42-gmsynth"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib lv2 ]; + buildInputs = [ + glib + lv2 + ]; makeFlags = [ "PREFIX=$(out)" diff --git a/pkgs/by-name/x4/x42-plugins/package.nix b/pkgs/by-name/x4/x42-plugins/package.nix index 49b2b2525f2f27..d327058c33d129 100644 --- a/pkgs/by-name/x4/x42-plugins/package.nix +++ b/pkgs/by-name/x4/x42-plugins/package.nix @@ -1,6 +1,22 @@ -{ lib, stdenv, fetchurl, pkg-config -, libltc, libsndfile, libsamplerate, ftgl, freefont_ttf, libjack2 -, libGLU, lv2, gtk2, cairo, pango, fftwFloat, zita-convolver }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libltc, + libsndfile, + libsamplerate, + ftgl, + freefont_ttf, + libjack2, + libGLU, + lv2, + gtk2, + cairo, + pango, + fftwFloat, + zita-convolver, +}: stdenv.mkDerivation rec { pname = "x42-plugins"; @@ -12,7 +28,21 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libGLU ftgl freefont_ttf libjack2 libltc libsndfile libsamplerate lv2 gtk2 cairo pango fftwFloat zita-convolver ]; + buildInputs = [ + libGLU + ftgl + freefont_ttf + libjack2 + libltc + libsndfile + libsamplerate + lv2 + gtk2 + cairo + pango + fftwFloat + zita-convolver + ]; # Don't remove this. The default fails with 'do not know how to unpack source archive' # every now and then on Hydra. No idea why. @@ -22,7 +52,10 @@ stdenv.mkDerivation rec { chmod -R u+w $sourceRoot ''; - makeFlags = [ "PREFIX=$(out)" "FONTFILE=${freefont_ttf}/share/fonts/truetype/FreeSansBold.ttf" ]; + makeFlags = [ + "PREFIX=$(out)" + "FONTFILE=${freefont_ttf}/share/fonts/truetype/FreeSansBold.ttf" + ]; patchPhase = '' patchShebangs ./stepseq.lv2/gridgen.sh @@ -32,11 +65,17 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - meta = with lib; - { description = "Collection of LV2 plugins by Robin Gareus"; - homepage = "https://github.com/x42/x42-plugins"; - maintainers = with maintainers; [ magnetophon orivej ]; - license = licenses.gpl2; - platforms = [ "i686-linux" "x86_64-linux" ]; - }; + meta = with lib; { + description = "Collection of LV2 plugins by Robin Gareus"; + homepage = "https://github.com/x42/x42-plugins"; + maintainers = with maintainers; [ + magnetophon + orivej + ]; + license = licenses.gpl2; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; + }; } diff --git a/pkgs/by-name/x8/x86info/package.nix b/pkgs/by-name/x8/x86info/package.nix index 86830c851e55de..c15f58de92494e 100644 --- a/pkgs/by-name/x8/x86info/package.nix +++ b/pkgs/by-name/x8/x86info/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, pciutils -, pkg-config -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + pciutils, + pkg-config, + python3, }: stdenv.mkDerivation rec { @@ -48,7 +49,10 @@ stdenv.mkDerivation rec { registers (MSRs) via the msr kernel module. it will approximate processor frequency, and identify the cache sizes and layout. ''; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; license = lib.licenses.gpl2Only; homepage = "https://github.com/kernelslacker/x86info"; maintainers = with lib.maintainers; [ jcumming ]; diff --git a/pkgs/by-name/xa/Xaw3d/package.nix b/pkgs/by-name/xa/Xaw3d/package.nix index 83237060312f11..3f20b207094dec 100644 --- a/pkgs/by-name/xa/Xaw3d/package.nix +++ b/pkgs/by-name/xa/Xaw3d/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, imake -, gccmakedep -, bison -, flex -, pkg-config -, libXext -, libXmu -, libXpm -, libXp -, libXt -, xorgproto +{ + lib, + stdenv, + fetchurl, + imake, + gccmakedep, + bison, + flex, + pkg-config, + libXext, + libXmu, + libXpm, + libXp, + libXt, + xorgproto, }: stdenv.mkDerivation rec { @@ -23,9 +24,23 @@ stdenv.mkDerivation rec { sha256 = "sha256-pBw+NxNa1hax8ou95wACr788tZow3zQUH4KdMurchkY="; }; dontUseImakeConfigure = true; - nativeBuildInputs = [ pkg-config bison flex imake gccmakedep ]; - buildInputs = [ libXext libXpm libXp ]; - propagatedBuildInputs = [ libXmu libXt xorgproto ]; + nativeBuildInputs = [ + pkg-config + bison + flex + imake + gccmakedep + ]; + buildInputs = [ + libXext + libXpm + libXp + ]; + propagatedBuildInputs = [ + libXmu + libXt + xorgproto + ]; meta = with lib; { description = "3D widget set based on the Athena Widget set"; diff --git a/pkgs/by-name/xa/xa/package.nix b/pkgs/by-name/xa/xa/package.nix index 52be6de0812df9..e79418d5e288ef 100644 --- a/pkgs/by-name/xa/xa/package.nix +++ b/pkgs/by-name/xa/xa/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, perl +{ + lib, + stdenv, + fetchurl, + perl, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/xa/xalanc/package.nix b/pkgs/by-name/xa/xalanc/package.nix index ccf914b46ee1e4..aaaa0779305456 100644 --- a/pkgs/by-name/xa/xalanc/package.nix +++ b/pkgs/by-name/xa/xalanc/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, xercesc, getopt, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + xercesc, + getopt, + cmake, +}: stdenv.mkDerivation rec { pname = "xalan-c"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ xercesc getopt ]; + buildInputs = [ + xercesc + getopt + ]; meta = { homepage = "https://xalan.apache.org/"; diff --git a/pkgs/by-name/xa/xannotate/package.nix b/pkgs/by-name/xa/xannotate/package.nix index 9c2a4ce3533471..8b580b66ea5eea 100644 --- a/pkgs/by-name/xa/xannotate/package.nix +++ b/pkgs/by-name/xa/xannotate/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchFromBitbucket, fetchpatch, libX11}: +{ + lib, + stdenv, + fetchFromBitbucket, + fetchpatch, + libX11, +}: stdenv.mkDerivation rec { pname = "xannotate"; version = "20150301"; @@ -24,8 +30,8 @@ stdenv.mkDerivation rec { meta = { description = "Tool to scribble over X windows"; - license = lib.licenses.gpl2Plus ; - maintainers = [lib.maintainers.raskin]; + license = lib.licenses.gpl2Plus; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; homepage = "https://github.com/blais/xannotate"; mainProgram = "xannotate"; diff --git a/pkgs/by-name/xa/xapp/package.nix b/pkgs/by-name/xa/xapp/package.nix index 75abb95960bca7..965ff41031ae2f 100644 --- a/pkgs/by-name/xa/xapp/package.nix +++ b/pkgs/by-name/xa/xapp/package.nix @@ -1,31 +1,35 @@ -{ fetchFromGitHub -, glib -, gobject-introspection -, gtk3 -, libgnomekbd -, gdk-pixbuf -, cairo -, xorg -, meson -, ninja -, pkg-config -, python3 -, lib -, stdenv -, vala -, wrapGAppsHook3 -, file -, inxi -, mate -, dbus -, libdbusmenu-gtk3 +{ + fetchFromGitHub, + glib, + gobject-introspection, + gtk3, + libgnomekbd, + gdk-pixbuf, + cairo, + xorg, + meson, + ninja, + pkg-config, + python3, + lib, + stdenv, + vala, + wrapGAppsHook3, + file, + inxi, + mate, + dbus, + libdbusmenu-gtk3, }: stdenv.mkDerivation rec { pname = "xapp"; version = "2.8.7"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "linuxmint"; @@ -49,10 +53,12 @@ stdenv.mkDerivation rec { ]; buildInputs = [ - (python3.withPackages (ps: with ps; [ - pygobject3 - setproctitle # mate applet - ])) + (python3.withPackages ( + ps: with ps; [ + pygobject3 + setproctitle # mate applet + ] + )) libgnomekbd gdk-pixbuf xorg.libxkbfile diff --git a/pkgs/by-name/xa/xar/package.nix b/pkgs/by-name/xa/xar/package.nix index 455576526dd591..46eb43c0099b05 100644 --- a/pkgs/by-name/xa/xar/package.nix +++ b/pkgs/by-name/xa/xar/package.nix @@ -84,7 +84,8 @@ stdenv.mkDerivation (finalAttrs: { xz e2fsprogs ] - ++ lib.optional stdenv.hostPlatform.isLinux acl ++ lib.optional stdenv.hostPlatform.isMusl musl-fts; + ++ lib.optional stdenv.hostPlatform.isLinux acl + ++ lib.optional stdenv.hostPlatform.isMusl musl-fts; passthru = let diff --git a/pkgs/by-name/xa/xarcan/package.nix b/pkgs/by-name/xa/xarcan/package.nix index 325d05327367c1..5a57e1efb1276d 100644 --- a/pkgs/by-name/xa/xarcan/package.nix +++ b/pkgs/by-name/xa/xarcan/package.nix @@ -1,40 +1,41 @@ -{ lib -, stdenv -, fetchFromGitHub -, arcan -, audit -, dbus -, libepoxy -, fontutil -, libGL -, libX11 -, libXau -, libXdmcp -, libXfont2 -, libdrm -, libgcrypt -, libmd -, libselinux -, libtirpc -, libxcb -, libxkbfile -, libxshmfence -, mesa -, meson -, nettle -, ninja -, openssl -, pixman -, pkg-config -, systemd -, xcbutil -, xcbutilwm -, xcbutilimage -, xkbcomp -, xkeyboard_config -, xorgproto -, xtrans -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + arcan, + audit, + dbus, + libepoxy, + fontutil, + libGL, + libX11, + libXau, + libXdmcp, + libXfont2, + libdrm, + libgcrypt, + libmd, + libselinux, + libtirpc, + libxcb, + libxkbfile, + libxshmfence, + mesa, + meson, + nettle, + ninja, + openssl, + pixman, + pkg-config, + systemd, + xcbutil, + xcbutilwm, + xcbutilimage, + xkbcomp, + xkeyboard_config, + xorgproto, + xtrans, + unstableGitUpdater, }: stdenv.mkDerivation (finalPackages: { @@ -106,9 +107,9 @@ stdenv.mkDerivation (finalPackages: { "--with-xkb-path=${xkeyboard_config}/share/X11/xkb" ]; - passthru.updateScript = unstableGitUpdater {}; + passthru.updateScript = unstableGitUpdater { }; - meta = { + meta = { homepage = "https://github.com/letoram/letoram"; description = "Patched Xserver that bridges connections to Arcan"; mainProgram = "Xarcan"; diff --git a/pkgs/by-name/xa/xarchiver/package.nix b/pkgs/by-name/xa/xarchiver/package.nix index a1604f707846f3..e8814895aa32fb 100644 --- a/pkgs/by-name/xa/xarchiver/package.nix +++ b/pkgs/by-name/xa/xarchiver/package.nix @@ -1,5 +1,23 @@ -{ lib, stdenv, fetchFromGitHub, gtk3, pkg-config, intltool, libxslt, makeWrapper, - coreutils, zip, unzip, p7zip, unar, gnutar, bzip2, gzip, lhasa, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + gtk3, + pkg-config, + intltool, + libxslt, + makeWrapper, + coreutils, + zip, + unzip, + p7zip, + unar, + gnutar, + bzip2, + gzip, + lhasa, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { version = "0.5.4.23"; @@ -12,12 +30,32 @@ stdenv.mkDerivation rec { hash = "sha256-aNUpuePU6nmrralp+j8GgVPuxv9ayRVoKicPZkC4nTE="; }; - nativeBuildInputs = [ intltool pkg-config makeWrapper wrapGAppsHook3 ]; - buildInputs = [ gtk3 libxslt ]; + nativeBuildInputs = [ + intltool + pkg-config + makeWrapper + wrapGAppsHook3 + ]; + buildInputs = [ + gtk3 + libxslt + ]; postFixup = '' wrapProgram $out/bin/xarchiver \ - --prefix PATH : ${lib.makeBinPath [ zip unzip p7zip unar gnutar bzip2 gzip lhasa coreutils ]} + --prefix PATH : ${ + lib.makeBinPath [ + zip + unzip + p7zip + unar + gnutar + bzip2 + gzip + lhasa + coreutils + ] + } ''; meta = { diff --git a/pkgs/by-name/xa/xastir/package.nix b/pkgs/by-name/xa/xastir/package.nix index 21990075183ddb..60310fd119ad68 100644 --- a/pkgs/by-name/xa/xastir/package.nix +++ b/pkgs/by-name/xa/xastir/package.nix @@ -1,8 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config -, curl, db, libgeotiff -, xorg, motif, pcre -, perl, proj, graphicsmagick, shapelib -, libax25 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + curl, + db, + libgeotiff, + xorg, + motif, + pcre, + perl, + proj, + graphicsmagick, + shapelib, + libax25, }: stdenv.mkDerivation rec { @@ -22,9 +34,17 @@ stdenv.mkDerivation rec { ]; buildInputs = [ - curl db libgeotiff - xorg.libXpm xorg.libXt motif pcre - perl proj graphicsmagick shapelib + curl + db + libgeotiff + xorg.libXpm + xorg.libXt + motif + pcre + perl + proj + graphicsmagick + shapelib libax25 ]; @@ -37,6 +57,6 @@ stdenv.mkDerivation rec { homepage = "https://xastir.org"; license = licenses.gpl2; maintainers = [ maintainers.ehmry ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/by-name/xa/xautoclick/package.nix b/pkgs/by-name/xa/xautoclick/package.nix index 68daf189fc9b28..fb1861842d1741 100644 --- a/pkgs/by-name/xa/xautoclick/package.nix +++ b/pkgs/by-name/xa/xautoclick/package.nix @@ -1,8 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, xorg, pkg-config -, cmake, libevdev -, gtkSupport ? true, gtk3, pcre, glib, wrapGAppsHook3 -, fltkSupport ? true, fltk -, qtSupport ? true, qt5 +{ + lib, + stdenv, + fetchFromGitHub, + xorg, + pkg-config, + cmake, + libevdev, + gtkSupport ? true, + gtk3, + pcre, + glib, + wrapGAppsHook3, + fltkSupport ? true, + fltk, + qtSupport ? true, + qt5, }: stdenv.mkDerivation rec { @@ -16,11 +28,26 @@ stdenv.mkDerivation rec { sha256 = "GN3zI5LQnVmRC0KWffzUTHKrxcqnstiL55hopwTTwpE="; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libevdev xorg.libXtst ] - ++ lib.optionals gtkSupport [ gtk3 pcre glib wrapGAppsHook3 ] + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = + [ + libevdev + xorg.libXtst + ] + ++ lib.optionals gtkSupport [ + gtk3 + pcre + glib + wrapGAppsHook3 + ] ++ lib.optionals fltkSupport [ fltk ] - ++ lib.optionals qtSupport [ qt5.qtbase qt5.wrapQtAppsHook ]; + ++ lib.optionals qtSupport [ + qt5.qtbase + qt5.wrapQtAppsHook + ]; meta = with lib; { description = "Autoclicker application, which enables you to automatically click the left mousebutton"; diff --git a/pkgs/by-name/xa/xautolock/package.nix b/pkgs/by-name/xa/xautolock/package.nix index e0fd83897e80df..d24eebb80fe7c1 100644 --- a/pkgs/by-name/xa/xautolock/package.nix +++ b/pkgs/by-name/xa/xautolock/package.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchFromGitHub -, imake, gccmakedep, libX11, libXext, libXScrnSaver, xorgproto -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + imake, + gccmakedep, + libX11, + libXext, + libXScrnSaver, + xorgproto, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { @@ -16,15 +24,26 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-T2zAbRqSTxRp9u6EdZmIZfVxaGveeZkJgjp1DWgORoI="; }; - nativeBuildInputs = [ imake gccmakedep ]; - buildInputs = [ libX11 libXext libXScrnSaver xorgproto ]; + nativeBuildInputs = [ + imake + gccmakedep + ]; + buildInputs = [ + libX11 + libXext + libXScrnSaver + xorgproto + ]; makeFlags = [ "BINDIR=$(out)/bin" "MANPATH=$(out)/share/man" ]; - installTargets = [ "install" "install.man" ]; + installTargets = [ + "install" + "install.man" + ]; passthru.tests = { inherit (nixosTests) xautolock; }; diff --git a/pkgs/by-name/xa/xautomation/package.nix b/pkgs/by-name/xa/xautomation/package.nix index a1fb8817632562..e79aa9e14e6fa5 100644 --- a/pkgs/by-name/xa/xautomation/package.nix +++ b/pkgs/by-name/xa/xautomation/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, pkg-config, libpng, libX11, libXext, libXi, libXtst }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libpng, + libX11, + libXext, + libXi, + libXtst, +}: stdenv.mkDerivation rec { pname = "xautomation"; @@ -9,7 +19,13 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libpng libX11 libXext libXi libXtst ]; + buildInputs = [ + libpng + libX11 + libXext + libXi + libXtst + ]; meta = { homepage = "https://www.hoopajoo.net/projects/xautomation.html"; diff --git a/pkgs/by-name/xa/xavs/package.nix b/pkgs/by-name/xa/xavs/package.nix index 14c4b0a7e5886e..a4116ab1f807c0 100644 --- a/pkgs/by-name/xa/xavs/package.nix +++ b/pkgs/by-name/xa/xavs/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchsvn }: +{ + lib, + stdenv, + fetchsvn, +}: stdenv.mkDerivation rec { pname = "xavs"; @@ -12,23 +16,25 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - patchPhase = '' - patchShebangs configure - patchShebangs config.sub - patchShebangs version.sh - patchShebangs tools/countquant_xavs.pl - patchShebangs tools/patcheck - patchShebangs tools/regression-test.pl - patchShebangs tools/xavs-format - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace config.guess --replace 'uname -p' 'uname -m' - substituteInPlace configure \ - --replace '-O4' '-O3' \ - --replace ' -s ' ' ' \ - --replace 'LDFLAGS -s' 'LDFLAGS' \ - --replace '-dynamiclib' ' ' \ - --replace '-falign-loops=16' ' ' - substituteInPlace Makefile --replace '-Wl,-soname,' ' ' + patchPhase = + '' + patchShebangs configure + patchShebangs config.sub + patchShebangs version.sh + patchShebangs tools/countquant_xavs.pl + patchShebangs tools/patcheck + patchShebangs tools/regression-test.pl + patchShebangs tools/xavs-format + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace config.guess --replace 'uname -p' 'uname -m' + substituteInPlace configure \ + --replace '-O4' '-O3' \ + --replace ' -s ' ' ' \ + --replace 'LDFLAGS -s' 'LDFLAGS' \ + --replace '-dynamiclib' ' ' \ + --replace '-falign-loops=16' ' ' + substituteInPlace Makefile --replace '-Wl,-soname,' ' ' ''; configureFlags = [ @@ -41,9 +47,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "AVS encoder and decoder"; mainProgram = "xavs"; - homepage = "https://xavs.sourceforge.net/"; - license = licenses.lgpl2; - platforms = platforms.linux ++ platforms.darwin; + homepage = "https://xavs.sourceforge.net/"; + license = licenses.lgpl2; + platforms = platforms.linux ++ platforms.darwin; maintainers = with maintainers; [ codyopel ]; }; } diff --git a/pkgs/by-name/xa/xawtv/package.nix b/pkgs/by-name/xa/xawtv/package.nix index d52feb8a66b055..3a4da5eb0eaa2f 100644 --- a/pkgs/by-name/xa/xawtv/package.nix +++ b/pkgs/by-name/xa/xawtv/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchurl -, ncurses -, libjpeg -, libX11 -, libXt -, alsa-lib -, aalib -, libXft -, xorgproto -, libv4l -, libFS -, libXaw -, libXpm -, libXext -, libSM -, libICE -, perl +{ + lib, + stdenv, + fetchurl, + ncurses, + libjpeg, + libX11, + libXt, + alsa-lib, + aalib, + libXft, + xorgproto, + libv4l, + libFS, + libXaw, + libXpm, + libXext, + libSM, + libICE, + perl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xb/xbanish/package.nix b/pkgs/by-name/xb/xbanish/package.nix index 9a8780324b84e6..0e6536592b4c4b 100644 --- a/pkgs/by-name/xb/xbanish/package.nix +++ b/pkgs/by-name/xb/xbanish/package.nix @@ -1,11 +1,24 @@ -{lib, stdenv, fetchFromGitHub, libX11, libXi, libXt, libXfixes, libXext}: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + libXi, + libXt, + libXfixes, + libXext, +}: stdenv.mkDerivation rec { version = "1.8"; pname = "xbanish"; buildInputs = [ - libX11 libXi libXt libXfixes libXext + libX11 + libXi + libXt + libXfixes + libXext ]; src = fetchFromGitHub { @@ -15,7 +28,7 @@ stdenv.mkDerivation rec { sha256 = "sha256-jwCoJ2shFGuJHhmXmlw/paFpMl5ARD6e5zDnDZHlsoo="; }; - makeFlags=[ "PREFIX=$(out)" ]; + makeFlags = [ "PREFIX=$(out)" ]; preInstall = '' mkdir -p $out/bin $out/man/man1 @@ -36,7 +49,7 @@ stdenv.mkDerivation rec { corner of the screen. ''; license = lib.licenses.bsd3; - maintainers = [lib.maintainers.choochootrain]; + maintainers = [ lib.maintainers.choochootrain ]; platforms = lib.platforms.linux; mainProgram = "xbanish"; }; diff --git a/pkgs/by-name/xb/xbase/package.nix b/pkgs/by-name/xb/xbase/package.nix index d87bcac9829f89..7f3afa0b159b7a 100644 --- a/pkgs/by-name/xb/xbase/package.nix +++ b/pkgs/by-name/xb/xbase/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "xbase"; diff --git a/pkgs/by-name/xb/xbattbar/package.nix b/pkgs/by-name/xb/xbattbar/package.nix index 0ddb06b62acee7..1775107fc74496 100644 --- a/pkgs/by-name/xb/xbattbar/package.nix +++ b/pkgs/by-name/xb/xbattbar/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchgit, libX11, perl, ... }: +{ + lib, + stdenv, + fetchgit, + libX11, + perl, + ... +}: stdenv.mkDerivation rec { pname = "xbattbar"; @@ -12,7 +19,7 @@ stdenv.mkDerivation rec { sha256 = "10w7gs0l4hzhdn38yqyr3az7n4ncmfnd6hhhly6lk5dg7k441ck6"; }; - buildInputs = [ libX11 ]; + buildInputs = [ libX11 ]; # The following patches are applied: # - sys-by-default: remove the APM checker binary, make the sys checker diff --git a/pkgs/by-name/xb/xbill/package.nix b/pkgs/by-name/xb/xbill/package.nix index 05314e6911b947..031f63141907fe 100644 --- a/pkgs/by-name/xb/xbill/package.nix +++ b/pkgs/by-name/xb/xbill/package.nix @@ -1,11 +1,27 @@ -{ stdenv, lib, makeDesktopItem, copyDesktopItems, fetchurl, libX11, libXpm, libXt, motif, ... }: +{ + stdenv, + lib, + makeDesktopItem, + copyDesktopItems, + fetchurl, + libX11, + libXpm, + libXt, + motif, + ... +}: stdenv.mkDerivation rec { pname = "xbill"; version = "2.1"; nativeBuildInputs = [ copyDesktopItems ]; - buildInputs = [ libX11 libXpm libXt motif ]; + buildInputs = [ + libX11 + libXpm + libXt + motif + ]; NIX_CFLAGS_LINK = "-lXpm"; @@ -19,14 +35,19 @@ stdenv.mkDerivation rec { sha256 = "13b08lli2gvppmvyhy0xs8cbjbkvrn4b87302mx0pxrdrvqzzz8f"; }; - desktopItems = [ (makeDesktopItem { - name = "xbill"; - exec = "xbill"; - icon = "xbill"; - desktopName = "XBill"; - comment = "Get rid of those Wingdows viruses!"; - categories = [ "Game" "ArcadeGame" ]; - }) ]; + desktopItems = [ + (makeDesktopItem { + name = "xbill"; + exec = "xbill"; + icon = "xbill"; + desktopName = "XBill"; + comment = "Get rid of those Wingdows viruses!"; + categories = [ + "Game" + "ArcadeGame" + ]; + }) + ]; postInstall = '' install -Dm644 pixmaps/icon.xpm $out/share/pixmaps/xbill.xpm diff --git a/pkgs/by-name/xb/xbindkeys/package.nix b/pkgs/by-name/xb/xbindkeys/package.nix index d3c514970515c0..1dd877e85d0ea5 100644 --- a/pkgs/by-name/xb/xbindkeys/package.nix +++ b/pkgs/by-name/xb/xbindkeys/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pkg-config, libX11, guile }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + libX11, + guile, +}: stdenv.mkDerivation rec { pname = "xbindkeys"; @@ -8,8 +16,14 @@ stdenv.mkDerivation rec { sha256 = "1wl2vc5alisiwyk8m07y1ryq8w3ll9ym83j27g4apm4ixjl8d6x2"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libX11 guile ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libX11 + guile + ]; meta = { homepage = "https://www.nongnu.org/xbindkeys/xbindkeys.html"; diff --git a/pkgs/by-name/xb/xboard/package.nix b/pkgs/by-name/xb/xboard/package.nix index ac8ae684f1df6c..fd12bb7f053f55 100644 --- a/pkgs/by-name/xb/xboard/package.nix +++ b/pkgs/by-name/xb/xboard/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, libX11 -, xorgproto -, libXt -, libXaw -, libSM -, libICE -, libXmu -, libXext -, gnuchess -, texinfo -, libXpm -, pkg-config -, librsvg -, cairo -, pango -, gtk2 +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libX11, + xorgproto, + libXt, + libXaw, + libSM, + libICE, + libXmu, + libXext, + gnuchess, + texinfo, + libXpm, + pkg-config, + librsvg, + cairo, + pango, + gtk2, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xb/xbomb/package.nix b/pkgs/by-name/xb/xbomb/package.nix index 92227ec1ebd180..92a31720ad9507 100644 --- a/pkgs/by-name/xb/xbomb/package.nix +++ b/pkgs/by-name/xb/xbomb/package.nix @@ -1,14 +1,23 @@ -{ lib, stdenv, fetchurl, libX11, libXaw }: +{ + lib, + stdenv, + fetchurl, + libX11, + libXaw, +}: stdenv.mkDerivation rec { pname = "xbomb"; version = "2.2b"; src = fetchurl { - url = "https://www.gedanken.org.uk/software/xbomb/download/xbomb-${version}.tgz"; + url = "https://www.gedanken.org.uk/software/xbomb/download/xbomb-${version}.tgz"; sha256 = "0692gjw28qvh8wj9l58scjw6kxj7jdyb3yzgcgs9wcznq11q839m"; }; - buildInputs = [ libX11 libXaw ]; + buildInputs = [ + libX11 + libXaw + ]; makeFlags = [ "INSTDIR=${placeholder "out"}" diff --git a/pkgs/by-name/xb/xborders/package.nix b/pkgs/by-name/xb/xborders/package.nix index a9fa6318dffbf4..b61315d9d6a2ce 100644 --- a/pkgs/by-name/xb/xborders/package.nix +++ b/pkgs/by-name/xb/xborders/package.nix @@ -1,12 +1,13 @@ -{ lib -, python3Packages -, fetchFromGitHub -, libwnck -, gtk3 -, libnotify -, wrapGAppsHook3 -, gobject-introspection -, substituteAll +{ + lib, + python3Packages, + fetchFromGitHub, + libwnck, + gtk3, + libnotify, + wrapGAppsHook3, + gobject-introspection, + substituteAll, }: python3Packages.buildPythonPackage rec { @@ -37,15 +38,17 @@ python3Packages.buildPythonPackage rec { pygobject3 ]; - postPatch = let - setup = substituteAll { - src = ./setup.py; - desc = meta.description; # "description" is reserved - inherit pname version; - }; - in '' - ln -s ${setup} setup.py - ''; + postPatch = + let + setup = substituteAll { + src = ./setup.py; + desc = meta.description; # "description" is reserved + inherit pname version; + }; + in + '' + ln -s ${setup} setup.py + ''; meta = with lib; { description = "Active window border replacement for window managers"; diff --git a/pkgs/by-name/xb/xboxdrv/package.nix b/pkgs/by-name/xb/xboxdrv/package.nix index f81e81ecbea02f..98c79cd7f80a04 100644 --- a/pkgs/by-name/xb/xboxdrv/package.nix +++ b/pkgs/by-name/xb/xboxdrv/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, scons -, libX11 -, pkg-config -, libusb1 -, boost -, glib -, dbus-glib +{ + lib, + stdenv, + fetchFromGitHub, + scons, + libX11, + pkg-config, + libusb1, + boost, + glib, + dbus-glib, }: stdenv.mkDerivation rec { @@ -22,8 +23,17 @@ stdenv.mkDerivation rec { }; makeFlags = [ "PREFIX=$(out)" ]; - nativeBuildInputs = [ pkg-config scons ]; - buildInputs = [ libX11 libusb1 boost glib dbus-glib ]; + nativeBuildInputs = [ + pkg-config + scons + ]; + buildInputs = [ + libX11 + libusb1 + boost + glib + dbus-glib + ]; enableParallelBuilding = true; dontUseSconsInstall = true; diff --git a/pkgs/by-name/xb/xbps/package.nix b/pkgs/by-name/xb/xbps/package.nix index e5ada2e10268d8..75668a5b8bb300 100644 --- a/pkgs/by-name/xb/xbps/package.nix +++ b/pkgs/by-name/xb/xbps/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, which, zlib, openssl, libarchive }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + which, + zlib, + openssl, + libarchive, +}: stdenv.mkDerivation rec { pname = "xbps"; @@ -11,9 +20,16 @@ stdenv.mkDerivation rec { hash = "sha256-3+LzFLDZ1zfRPBETMlpEn66zsfHRHQLlgeZPdMtmA14="; }; - nativeBuildInputs = [ pkg-config which ]; + nativeBuildInputs = [ + pkg-config + which + ]; - buildInputs = [ zlib openssl libarchive ]; + buildInputs = [ + zlib + openssl + libarchive + ]; patches = [ ./cert-paths.patch diff --git a/pkgs/by-name/xb/xbrightness/package.nix b/pkgs/by-name/xb/xbrightness/package.nix index c022371c01d981..33aec02c43fefa 100644 --- a/pkgs/by-name/xb/xbrightness/package.nix +++ b/pkgs/by-name/xb/xbrightness/package.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchurl, imake, gccmakedep -, libX11, libXaw, libXext, libXmu, libXpm, libXxf86vm }: +{ + lib, + stdenv, + fetchurl, + imake, + gccmakedep, + libX11, + libXaw, + libXext, + libXmu, + libXpm, + libXxf86vm, +}: stdenv.mkDerivation rec { pname = "xbrightness"; @@ -10,11 +21,27 @@ stdenv.mkDerivation rec { sha256 = "2564dbd393544657cdabe4cbf535d9cfb9abe8edddb1b8cdb1ed4d12f358626e"; }; - nativeBuildInputs = [ imake gccmakedep ]; - buildInputs = [ libX11 libXaw libXext libXmu libXpm libXxf86vm ]; + nativeBuildInputs = [ + imake + gccmakedep + ]; + buildInputs = [ + libX11 + libXaw + libXext + libXmu + libXpm + libXxf86vm + ]; - makeFlags = [ "BINDIR=$(out)/bin" "MANPATH=$(out)/share/man" ]; - installTargets = [ "install" "install.man" ]; + makeFlags = [ + "BINDIR=$(out)/bin" + "MANPATH=$(out)/share/man" + ]; + installTargets = [ + "install" + "install.man" + ]; meta = { description = "X11 brigthness and gamma software control"; diff --git a/pkgs/by-name/xc/xc/package.nix b/pkgs/by-name/xc/xc/package.nix index 9acf27ca3c3388..95ee1c8f1e3a06 100644 --- a/pkgs/by-name/xc/xc/package.nix +++ b/pkgs/by-name/xc/xc/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "xc"; @@ -25,6 +29,9 @@ buildGoModule rec { homepage = "https://xcfile.dev/"; changelog = "https://github.com/joerdav/xc/releases/tag/${src.rev}"; license = licenses.mit; - maintainers = with maintainers; [ figsoda joerdav ]; + maintainers = with maintainers; [ + figsoda + joerdav + ]; }; } diff --git a/pkgs/by-name/xc/xc3sprog/package.nix b/pkgs/by-name/xc/xc3sprog/package.nix index fa9ceffafbbb20..52bc70ebad811f 100644 --- a/pkgs/by-name/xc/xc3sprog/package.nix +++ b/pkgs/by-name/xc/xc3sprog/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchsvn, cmake, libusb-compat-0_1, libftdi }: +{ + lib, + stdenv, + fetchsvn, + cmake, + libusb-compat-0_1, + libftdi, +}: # The xc3sprog project doesn't seem to make proper releases, they only put out # prebuilt binary subversion snapshots on sourceforge. @@ -14,7 +21,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libusb-compat-0_1 libftdi ]; + buildInputs = [ + libusb-compat-0_1 + libftdi + ]; cmakeFlags = [ # file RPATH_CHANGE could not write new RPATH diff --git a/pkgs/by-name/xc/xcaddy/package.nix b/pkgs/by-name/xc/xcaddy/package.nix index b2df908b3e07ea..907ac80b0d0e35 100644 --- a/pkgs/by-name/xc/xcaddy/package.nix +++ b/pkgs/by-name/xc/xcaddy/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "xcaddy"; @@ -31,6 +35,9 @@ buildGoModule rec { description = "Build Caddy with plugins"; mainProgram = "xcaddy"; license = licenses.asl20; - maintainers = with maintainers; [ tjni emilylange ]; + maintainers = with maintainers; [ + tjni + emilylange + ]; }; } diff --git a/pkgs/by-name/xc/xcalib/package.nix b/pkgs/by-name/xc/xcalib/package.nix index cb3ac66284a166..a1c789fef49a09 100644 --- a/pkgs/by-name/xc/xcalib/package.nix +++ b/pkgs/by-name/xc/xcalib/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libX11, libXxf86vm, libXext, libXrandr }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + libXxf86vm, + libXext, + libXrandr, +}: stdenv.mkDerivation rec { pname = "xcalib"; @@ -11,7 +19,12 @@ stdenv.mkDerivation rec { sha256 = "05fzdjmhiafgi2jf0k41i3nm0837a78sb6yv59cwc23nla8g0bhr"; }; - buildInputs = [ libX11 libXxf86vm libXext libXrandr ]; + buildInputs = [ + libX11 + libXxf86vm + libXext + libXrandr + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/xc/xcape/package.nix b/pkgs/by-name/xc/xcape/package.nix index c62e29cedc154e..698bab9bfeec8b 100644 --- a/pkgs/by-name/xc/xcape/package.nix +++ b/pkgs/by-name/xc/xcape/package.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, libX11, libXtst, xorgproto, -libXi }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libX11, + libXtst, + xorgproto, + libXi, +}: stdenv.mkDerivation rec { pname = "xcape"; @@ -14,7 +22,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libX11 libXtst xorgproto libXi ]; + buildInputs = [ + libX11 + libXtst + xorgproto + libXi + ]; makeFlags = [ "PREFIX=$(out)" @@ -34,7 +47,7 @@ stdenv.mkDerivation rec { released on its own. ''; homepage = "https://github.com/alols/xcape"; - license = licenses.gpl3 ; + license = licenses.gpl3; maintainers = with maintainers; [ raskin ]; platforms = platforms.linux; mainProgram = "xcape"; diff --git a/pkgs/by-name/xc/xcat/package.nix b/pkgs/by-name/xc/xcat/package.nix index 54219f1e1ac4e6..fcca8ee73cdd52 100644 --- a/pkgs/by-name/xc/xcat/package.nix +++ b/pkgs/by-name/xc/xcat/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/xc/xcb-imdkit/package.nix b/pkgs/by-name/xc/xcb-imdkit/package.nix index 41710d5ca3dcce..7dbce20bd1e469 100644 --- a/pkgs/by-name/xc/xcb-imdkit/package.nix +++ b/pkgs/by-name/xc/xcb-imdkit/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, uthash -, xcbutil -, xcbutilkeysyms -, xorgproto +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + uthash, + xcbutil, + xcbutilkeysyms, + xorgproto, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xc/xcbeautify/package.nix b/pkgs/by-name/xc/xcbeautify/package.nix index fb0cea9846708c..c5eaecb4917ed4 100644 --- a/pkgs/by-name/xc/xcbeautify/package.nix +++ b/pkgs/by-name/xc/xcbeautify/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, unzip +{ + lib, + stdenv, + fetchurl, + unzip, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xc/xcd/package.nix b/pkgs/by-name/xc/xcd/package.nix index 1c2e65f86bf960..b31b06cb73ec7b 100644 --- a/pkgs/by-name/xc/xcd/package.nix +++ b/pkgs/by-name/xc/xcd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "xcd"; diff --git a/pkgs/by-name/xc/xcftools/package.nix b/pkgs/by-name/xc/xcftools/package.nix index 077f016b9e90ba..aa4cf0519aa0f0 100644 --- a/pkgs/by-name/xc/xcftools/package.nix +++ b/pkgs/by-name/xc/xcftools/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchpatch, fetchurl, libpng, perl, gettext }: +{ + lib, + stdenv, + fetchpatch, + fetchurl, + libpng, + perl, + gettext, +}: stdenv.mkDerivation rec { pname = "xcftools"; @@ -9,7 +17,11 @@ stdenv.mkDerivation rec { sha256 = "19i0x7yhlw6hd2gp013884zchg63yzjdj4hpany011il0n26vgqy"; }; - buildInputs = [ libpng perl gettext ]; + buildInputs = [ + libpng + perl + gettext + ]; patches = [ (fetchpatch { diff --git a/pkgs/by-name/xc/xcfun/package.nix b/pkgs/by-name/xc/xcfun/package.nix index cac389333e49c3..72e5a0172580a4 100644 --- a/pkgs/by-name/xc/xcfun/package.nix +++ b/pkgs/by-name/xc/xcfun/package.nix @@ -1,10 +1,17 @@ -{ stdenv, lib, fetchFromGitHub, cmake, gfortran, python3 } : +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + gfortran, + python3, +}: stdenv.mkDerivation rec { pname = "xcfun"; version = "2.1.1"; - src = fetchFromGitHub { + src = fetchFromGitHub { owner = "dftlibs"; repo = pname; rev = "v${version}"; diff --git a/pkgs/by-name/xc/xchainkeys/package.nix b/pkgs/by-name/xc/xchainkeys/package.nix index ee1b10bca63c09..dfe0c036e4b20c 100644 --- a/pkgs/by-name/xc/xchainkeys/package.nix +++ b/pkgs/by-name/xc/xchainkeys/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libX11 }: +{ + lib, + stdenv, + fetchurl, + libX11, +}: stdenv.mkDerivation rec { pname = "xchainkeys"; diff --git a/pkgs/by-name/xc/xchm/package.nix b/pkgs/by-name/xc/xchm/package.nix index fe94ac94ba418e..3472dbfa0d57c2 100644 --- a/pkgs/by-name/xc/xchm/package.nix +++ b/pkgs/by-name/xc/xchm/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, wxGTK32 -, chmlib +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + wxGTK32, + chmlib, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xc/xcircuit/package.nix b/pkgs/by-name/xc/xcircuit/package.nix index c51156d2c1ab11..9aab3b301def42 100644 --- a/pkgs/by-name/xc/xcircuit/package.nix +++ b/pkgs/by-name/xc/xcircuit/package.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, automake, pkg-config -, cairo, ghostscript, ngspice, tcl, tk, xorg, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + automake, + pkg-config, + cairo, + ghostscript, + ngspice, + tcl, + tk, + xorg, + zlib, +}: stdenv.mkDerivation rec { version = "3.10.37"; @@ -12,7 +25,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-LXU5VEkLF1aKYz9ynI1qQjJUwt/zKFMPYj153OgJOOI="; }; - nativeBuildInputs = [ autoreconfHook automake pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + automake + pkg-config + ]; hardeningDisable = [ "format" ]; configureFlags = [ @@ -21,7 +38,18 @@ stdenv.mkDerivation rec { "--with-ngspice=${lib.getBin ngspice}/bin/ngspice" ]; - buildInputs = with xorg; [ cairo ghostscript libSM libXt libICE libX11 libXpm tcl tk zlib ]; + buildInputs = with xorg; [ + cairo + ghostscript + libSM + libXt + libICE + libX11 + libXpm + tcl + tk + zlib + ]; meta = with lib; { description = "Generic drawing program tailored to circuit diagrams"; @@ -29,6 +57,10 @@ stdenv.mkDerivation rec { homepage = "http://opencircuitdesign.com/xcircuit"; license = licenses.gpl2; platforms = platforms.linux; - maintainers = with maintainers; [ john-shaffer spacefrogg thoughtpolice ]; + maintainers = with maintainers; [ + john-shaffer + spacefrogg + thoughtpolice + ]; }; } diff --git a/pkgs/by-name/xc/xclicker/package.nix b/pkgs/by-name/xc/xclicker/package.nix index e61c86c2b320b3..2a1e05350083c7 100644 --- a/pkgs/by-name/xc/xclicker/package.nix +++ b/pkgs/by-name/xc/xclicker/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, wrapGAppsHook3 -, gtk3 -, libXtst +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + wrapGAppsHook3, + gtk3, + libXtst, }: stdenv.mkDerivation (finalAttrs: { @@ -48,7 +49,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://xclicker.xyz/"; license = lib.licenses.gpl3Only; mainProgram = "xclicker"; - maintainers = with lib.maintainers; [ gepbird tomasajt ]; + maintainers = with lib.maintainers; [ + gepbird + tomasajt + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/by-name/xc/xclip/package.nix b/pkgs/by-name/xc/xclip/package.nix index e56382879d59c4..5b3383dae99c7b 100644 --- a/pkgs/by-name/xc/xclip/package.nix +++ b/pkgs/by-name/xc/xclip/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, libXmu }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libXmu, +}: stdenv.mkDerivation rec { pname = "xclip"; diff --git a/pkgs/by-name/xc/xcolor/package.nix b/pkgs/by-name/xc/xcolor/package.nix index f9ba3627f78746..84997af2c336a6 100644 --- a/pkgs/by-name/xc/xcolor/package.nix +++ b/pkgs/by-name/xc/xcolor/package.nix @@ -1,5 +1,16 @@ -{ lib, rustPlatform, fetchFromGitHub, pkg-config, libX11, libXcursor -, libxcb, python3, installShellFiles, makeDesktopItem, copyDesktopItems }: +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libX11, + libXcursor, + libxcb, + python3, + installShellFiles, + makeDesktopItem, + copyDesktopItems, +}: rustPlatform.buildRustPackage rec { pname = "xcolor"; @@ -14,9 +25,18 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Zh73+FJ63SkusSavCqSCLbHVnU++4ZFSMFUIM7TnOj0="; - nativeBuildInputs = [ pkg-config python3 installShellFiles copyDesktopItems ]; + nativeBuildInputs = [ + pkg-config + python3 + installShellFiles + copyDesktopItems + ]; - buildInputs = [ libX11 libXcursor libxcb ]; + buildInputs = [ + libX11 + libXcursor + libxcb + ]; desktopItems = [ (makeDesktopItem { diff --git a/pkgs/by-name/xc/xconq/package.nix b/pkgs/by-name/xc/xconq/package.nix index 345ddbcad49b1f..057996ceb73731 100644 --- a/pkgs/by-name/xc/xconq/package.nix +++ b/pkgs/by-name/xc/xconq/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchurl, cpio, xorgproto, libX11, libXmu, libXaw, libXt, tcl, tk -, libXext, fontconfig, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + cpio, + xorgproto, + libX11, + libXmu, + libXaw, + libXt, + tcl, + tk, + libXext, + fontconfig, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "xconq"; @@ -11,7 +25,18 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ cpio xorgproto libX11 libXmu libXaw libXt tcl tk libXext fontconfig ]; + buildInputs = [ + cpio + xorgproto + libX11 + libXmu + libXaw + libXt + tcl + tk + libXext + fontconfig + ]; configureFlags = [ "--enable-alternate-scoresdir=scores" diff --git a/pkgs/by-name/xc/xcowsay/package.nix b/pkgs/by-name/xc/xcowsay/package.nix index 52569e044f06e1..0802fe96c8776a 100644 --- a/pkgs/by-name/xc/xcowsay/package.nix +++ b/pkgs/by-name/xc/xcowsay/package.nix @@ -1,6 +1,15 @@ -{ lib, stdenv, fetchurl, makeWrapper, pkg-config -, dbus, dbus-glib, gtk3, gdk-pixbuf, librsvg -, fortune +{ + lib, + stdenv, + fetchurl, + makeWrapper, + pkg-config, + dbus, + dbus-glib, + gtk3, + gdk-pixbuf, + librsvg, + fortune, }: stdenv.mkDerivation rec { @@ -19,7 +28,10 @@ stdenv.mkDerivation rec { gdk-pixbuf # loading cow images librsvg # dreaming SVG images ]; - nativeBuildInputs = [ makeWrapper pkg-config ]; + nativeBuildInputs = [ + makeWrapper + pkg-config + ]; configureFlags = [ "--enable-dbus" ]; diff --git a/pkgs/by-name/xc/xcp/package.nix b/pkgs/by-name/xc/xcp/package.nix index 1aea623b20a908..347ecef141c184 100644 --- a/pkgs/by-name/xc/xcp/package.nix +++ b/pkgs/by-name/xc/xcp/package.nix @@ -1,4 +1,8 @@ -{ rustPlatform, fetchFromGitHub, lib }: +{ + rustPlatform, + fetchFromGitHub, + lib, +}: rustPlatform.buildRustPackage rec { pname = "xcp"; diff --git a/pkgs/by-name/xc/xcpc/package.nix b/pkgs/by-name/xc/xcpc/package.nix index d5a2a6a50fe1f1..9bcd3f53178559 100644 --- a/pkgs/by-name/xc/xcpc/package.nix +++ b/pkgs/by-name/xc/xcpc/package.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, libXaw, libX11, libXext - , libDSKSupport ? true, libdsk - , motifSupport ? false, lesstif +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + libXaw, + libX11, + libXext, + libDSKSupport ? true, + libdsk, + motifSupport ? false, + lesstif, }: stdenv.mkDerivation rec { @@ -14,7 +24,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib libdsk libXaw libX11 libXext ] + buildInputs = + [ + glib + libdsk + libXaw + libX11 + libXext + ] ++ lib.optional libDSKSupport libdsk ++ lib.optional motifSupport lesstif; diff --git a/pkgs/by-name/xc/xcrawl3r/package.nix b/pkgs/by-name/xc/xcrawl3r/package.nix index fd3a33eaac2b51..af65667f7660d2 100644 --- a/pkgs/by-name/xc/xcrawl3r/package.nix +++ b/pkgs/by-name/xc/xcrawl3r/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/xc/xcruiser/package.nix b/pkgs/by-name/xc/xcruiser/package.nix index 3f1277f24a83a0..c85ccb8cd124cc 100644 --- a/pkgs/by-name/xc/xcruiser/package.nix +++ b/pkgs/by-name/xc/xcruiser/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, gccmakedep, imake, libXt, libXaw, libXpm, libXext, copyDesktopItems, makeDesktopItem }: +{ + lib, + stdenv, + fetchurl, + gccmakedep, + imake, + libXt, + libXaw, + libXpm, + libXext, + copyDesktopItems, + makeDesktopItem, +}: stdenv.mkDerivation rec { pname = "xcruiser"; @@ -9,8 +21,17 @@ stdenv.mkDerivation rec { sha256 = "1r8whva38xizqdh7jmn6wcmfmsndc67pkw22wzfzr6rq0vf6hywi"; }; - nativeBuildInputs = [ gccmakedep imake copyDesktopItems ]; - buildInputs = [ libXt libXaw libXpm libXext ]; + nativeBuildInputs = [ + gccmakedep + imake + copyDesktopItems + ]; + buildInputs = [ + libXt + libXaw + libXpm + libXext + ]; makeFlags = [ "BINDIR=${placeholder "out"}/bin" diff --git a/pkgs/by-name/xc/xcwd/package.nix b/pkgs/by-name/xc/xcwd/package.nix index 897c4af95edc89..58808c9ec96270 100644 --- a/pkgs/by-name/xc/xcwd/package.nix +++ b/pkgs/by-name/xc/xcwd/package.nix @@ -1,14 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, libX11 }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, +}: stdenv.mkDerivation (finalAttrs: { pname = "xcwd"; version = "1.0"; src = fetchFromGitHub { - owner = "schischi"; - repo = "xcwd"; - rev = "v${finalAttrs.version}"; - hash = "sha256-M6/1H6hI50Cvx40RTKzZXoUui0FGZfwe1IwdaxMJIQo="; + owner = "schischi"; + repo = "xcwd"; + rev = "v${finalAttrs.version}"; + hash = "sha256-M6/1H6hI50Cvx40RTKzZXoUui0FGZfwe1IwdaxMJIQo="; }; buildInputs = [ libX11 ]; diff --git a/pkgs/by-name/xd/xd/package.nix b/pkgs/by-name/xd/xd/package.nix index 2974fe3935792f..eb4c9292541105 100644 --- a/pkgs/by-name/xd/xd/package.nix +++ b/pkgs/by-name/xd/xd/package.nix @@ -1,4 +1,9 @@ -{ buildGoModule, fetchFromGitHub, lib, perl }: +{ + buildGoModule, + fetchFromGitHub, + lib, + perl, +}: buildGoModule rec { pname = "XD"; diff --git a/pkgs/by-name/xd/xdaliclock/package.nix b/pkgs/by-name/xd/xdaliclock/package.nix index 9a5f348f15244d..5ddf7b01e1d0ff 100644 --- a/pkgs/by-name/xd/xdaliclock/package.nix +++ b/pkgs/by-name/xd/xdaliclock/package.nix @@ -1,7 +1,11 @@ -{ lib, stdenv, fetchurl -, gtk3 -, wrapGAppsHook3 -, pkg-config }: +{ + lib, + stdenv, + fetchurl, + gtk3, + wrapGAppsHook3, + pkg-config, +}: stdenv.mkDerivation rec { pname = "xdaliclock"; @@ -40,7 +44,7 @@ stdenv.mkDerivation rec { description = "Clock application that morphs digits when they are changed"; maintainers = with maintainers; [ raskin ]; platforms = with platforms; linux ++ freebsd; - license = licenses.free; #TODO BSD on Gentoo, looks like MIT + license = licenses.free; # TODO BSD on Gentoo, looks like MIT downloadPage = "http://www.jwz.org/xdaliclock/"; mainProgram = "xdaliclock"; }; diff --git a/pkgs/by-name/xd/xdg-dbus-proxy/package.nix b/pkgs/by-name/xd/xdg-dbus-proxy/package.nix index ef5a3abd973094..9c661cd0dc0b59 100644 --- a/pkgs/by-name/xd/xdg-dbus-proxy/package.nix +++ b/pkgs/by-name/xd/xdg-dbus-proxy/package.nix @@ -1,14 +1,15 @@ -{ dbus -, docbook-xsl-nons -, docbook_xml_dtd_43 -, fetchurl -, glib -, lib -, libxslt -, meson -, ninja -, pkg-config -, stdenv +{ + dbus, + docbook-xsl-nons, + docbook_xml_dtd_43, + fetchurl, + glib, + lib, + libxslt, + meson, + ninja, + pkg-config, + stdenv, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/xd/xdg-desktop-portal-cosmic/package.nix b/pkgs/by-name/xd/xdg-desktop-portal-cosmic/package.nix index 613400dcd7d230..8c640acd7f5577 100644 --- a/pkgs/by-name/xd/xdg-desktop-portal-cosmic/package.nix +++ b/pkgs/by-name/xd/xdg-desktop-portal-cosmic/package.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, gst_all_1 -, mesa -, pkg-config -, libglvnd -, libxkbcommon -, pipewire -, wayland +{ + lib, + rustPlatform, + fetchFromGitHub, + gst_all_1, + mesa, + pkg-config, + libglvnd, + libxkbcommon, + pipewire, + wayland, }: rustPlatform.buildRustPackage rec { @@ -29,8 +30,17 @@ rustPlatform.buildRustPackage rec { separateDebugInfo = true; - nativeBuildInputs = [ rustPlatform.bindgenHook pkg-config ]; - buildInputs = [ libglvnd libxkbcommon mesa pipewire wayland ]; + nativeBuildInputs = [ + rustPlatform.bindgenHook + pkg-config + ]; + buildInputs = [ + libglvnd + libxkbcommon + mesa + pipewire + wayland + ]; checkInputs = [ gst_all_1.gstreamer ]; # Force linking to libEGL, which is always dlopen()ed, and to diff --git a/pkgs/by-name/xd/xdg-desktop-portal-gtk/package.nix b/pkgs/by-name/xd/xdg-desktop-portal-gtk/package.nix index db06dc75624868..7797d01fc96b32 100644 --- a/pkgs/by-name/xd/xdg-desktop-portal-gtk/package.nix +++ b/pkgs/by-name/xd/xdg-desktop-portal-gtk/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, xdg-desktop-portal -, gtk3 -, gnome-settings-daemon -, gnome-desktop -, glib -, wrapGAppsHook3 -, gsettings-desktop-schemas +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + xdg-desktop-portal, + gtk3, + gnome-settings-daemon, + gnome-desktop, + glib, + wrapGAppsHook3, + gsettings-desktop-schemas, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/xd/xdg-desktop-portal-shana/package.nix b/pkgs/by-name/xd/xdg-desktop-portal-shana/package.nix index bed9ef313acd26..c4d898b6bbf9e6 100644 --- a/pkgs/by-name/xd/xdg-desktop-portal-shana/package.nix +++ b/pkgs/by-name/xd/xdg-desktop-portal-shana/package.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, meson -, ninja -, xdg-desktop-portal +{ + lib, + rustPlatform, + fetchFromGitHub, + meson, + ninja, + xdg-desktop-portal, }: rustPlatform.buildRustPackage rec { @@ -38,7 +39,7 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/Decodetalkers/xdg-desktop-portal-shana"; license = licenses.mit; platforms = platforms.linux; - maintainers = [ maintainers.samuelefacenda ]; + maintainers = [ maintainers.samuelefacenda ]; }; } diff --git a/pkgs/by-name/xd/xdg-desktop-portal-wlr/package.nix b/pkgs/by-name/xd/xdg-desktop-portal-wlr/package.nix index e215028d735201..cb6f6ec5add32b 100644 --- a/pkgs/by-name/xd/xdg-desktop-portal-wlr/package.nix +++ b/pkgs/by-name/xd/xdg-desktop-portal-wlr/package.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, bash -, fetchFromGitHub -, makeWrapper -, meson -, ninja -, pkg-config -, wayland-protocols -, wayland-scanner -, grim -, inih -, libdrm -, mesa -, pipewire -, scdoc -, slurp -, systemd -, wayland +{ + lib, + stdenv, + bash, + fetchFromGitHub, + makeWrapper, + meson, + ninja, + pkg-config, + wayland-protocols, + wayland-scanner, + grim, + inih, + libdrm, + mesa, + pipewire, + scdoc, + slurp, + systemd, + wayland, }: stdenv.mkDerivation rec { @@ -32,15 +33,36 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson ninja pkg-config scdoc wayland-scanner makeWrapper ]; - buildInputs = [ inih libdrm mesa pipewire systemd wayland wayland-protocols ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + scdoc + wayland-scanner + makeWrapper + ]; + buildInputs = [ + inih + libdrm + mesa + pipewire + systemd + wayland + wayland-protocols + ]; mesonFlags = [ "-Dsd-bus-provider=libsystemd" ]; postInstall = '' - wrapProgram $out/libexec/xdg-desktop-portal-wlr --prefix PATH ":" ${lib.makeBinPath [ bash grim slurp ]} + wrapProgram $out/libexec/xdg-desktop-portal-wlr --prefix PATH ":" ${ + lib.makeBinPath [ + bash + grim + slurp + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/xd/xdg-desktop-portal-xapp/package.nix b/pkgs/by-name/xd/xdg-desktop-portal-xapp/package.nix index 3adb978f0d4e2b..36d80571c5eaba 100644 --- a/pkgs/by-name/xd/xdg-desktop-portal-xapp/package.nix +++ b/pkgs/by-name/xd/xdg-desktop-portal-xapp/package.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, meson -, ninja -, pkg-config -, wrapGAppsNoGuiHook -, cinnamon-desktop -, glib -, gsettings-desktop-schemas -, mate -, xdg-desktop-portal -, xapp +{ + stdenv, + lib, + fetchFromGitHub, + meson, + ninja, + pkg-config, + wrapGAppsNoGuiHook, + cinnamon-desktop, + glib, + gsettings-desktop-schemas, + mate, + xdg-desktop-portal, + xapp, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xd/xdg-launch/package.nix b/pkgs/by-name/xd/xdg-launch/package.nix index 4a61839c7d8c9f..4c8b74f67486be 100644 --- a/pkgs/by-name/xd/xdg-launch/package.nix +++ b/pkgs/by-name/xd/xdg-launch/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoconf -, automake -, gettext -, libtool -, perl -, pkg-config -, glib -, xorg +{ + stdenv, + lib, + fetchFromGitHub, + autoconf, + automake, + gettext, + libtool, + perl, + pkg-config, + glib, + xorg, }: stdenv.mkDerivation rec { pname = "xdg-launch"; diff --git a/pkgs/by-name/xd/xdg-ninja/package.nix b/pkgs/by-name/xd/xdg-ninja/package.nix index e30b7602d1c8cb..0de1ec79c3890f 100644 --- a/pkgs/by-name/xd/xdg-ninja/package.nix +++ b/pkgs/by-name/xd/xdg-ninja/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenvNoCC, fetchFromGitHub, makeWrapper, jq, glow }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + makeWrapper, + jq, + glow, +}: stdenvNoCC.mkDerivation rec { pname = "xdg-ninja"; @@ -22,7 +29,12 @@ stdenvNoCC.mkDerivation rec { ln -s "$out/share/xdg-ninja/xdg-ninja.sh" "$out/bin/xdg-ninja" wrapProgram "$out/bin/xdg-ninja" \ - --prefix PATH : "${lib.makeBinPath [ glow jq ]}" + --prefix PATH : "${ + lib.makeBinPath [ + glow + jq + ] + }" runHook postInstall ''; diff --git a/pkgs/by-name/xd/xdg-utils/package.nix b/pkgs/by-name/xd/xdg-utils/package.nix index 5b3a1a5367c07b..86c09d82954ba3 100644 --- a/pkgs/by-name/xd/xdg-utils/package.nix +++ b/pkgs/by-name/xd/xdg-utils/package.nix @@ -1,16 +1,48 @@ -{ lib, stdenv, fetchurl, fetchFromGitLab, fetchFromGitHub, runCommand, writeText -# docs deps -, libxslt, docbook_xml_dtd_412, docbook_xml_dtd_43, docbook_xsl, xmlto -# runtime deps -, resholve, bash, coreutils, dbus, file, gawk, glib, gnugrep, gnused, jq, nettools, procmail, procps, which, xdg-user-dirs -, shared-mime-info -, perl, perlPackages -, withXdgOpenUsePortalPatch ? true }: +{ + lib, + stdenv, + fetchurl, + fetchFromGitLab, + fetchFromGitHub, + runCommand, + writeText, + # docs deps + libxslt, + docbook_xml_dtd_412, + docbook_xml_dtd_43, + docbook_xsl, + xmlto, + # runtime deps + resholve, + bash, + coreutils, + dbus, + file, + gawk, + glib, + gnugrep, + gnused, + jq, + nettools, + procmail, + procps, + which, + xdg-user-dirs, + shared-mime-info, + perl, + perlPackages, + withXdgOpenUsePortalPatch ? true, +}: let # Required by the common desktop detection code - commonDeps = [ dbus coreutils gnugrep gnused ]; + commonDeps = [ + dbus + coreutils + gnugrep + gnused + ]; # These are all faked because the current desktop is detected # based on their presence, so we want them to be missing by default. commonFakes = [ @@ -36,7 +68,7 @@ let # These are desktop-specific, so we don't want xdg-utils to be able to # call them when in a different setup. fake.external = commonFakes ++ [ - "gconftool-2" # GNOME2 + "gconftool-2" # GNOME2 ]; keep."$KDE_SESSION_VERSION" = true; prologue = commonPrologue; @@ -54,7 +86,11 @@ let { scripts = [ "bin/xdg-email" ]; interpreter = "${bash}/bin/bash"; - inputs = commonDeps ++ [ gawk glib.bin "${placeholder "out"}/bin" ]; + inputs = commonDeps ++ [ + gawk + glib.bin + "${placeholder "out"}/bin" + ]; execer = [ "cannot:${placeholder "out"}/bin/xdg-mime" "cannot:${placeholder "out"}/bin/xdg-open" @@ -62,13 +98,13 @@ let # These are desktop-specific, so we don't want xdg-utils to be able to # call them when in a different setup. fake.external = commonFakes ++ [ - "exo-open" # XFCE - "gconftool-2" # GNOME - "gio" # GNOME (new) - "gnome-open" # GNOME (very old) - "gvfs-open" # GNOME (old) - "qtxdg-mat" # LXQT - "xdg-email-hook.sh" # user-defined hook that may be available ambiently + "exo-open" # XFCE + "gconftool-2" # GNOME + "gio" # GNOME (new) + "gnome-open" # GNOME (very old) + "gvfs-open" # GNOME (old) + "qtxdg-mat" # LXQT + "xdg-email-hook.sh" # user-defined hook that may be available ambiently ]; fix."/bin/echo" = true; keep = { @@ -91,22 +127,25 @@ let { scripts = [ "bin/xdg-mime" ]; interpreter = "${bash}/bin/bash"; - inputs = commonDeps ++ [ file gawk ]; + inputs = commonDeps ++ [ + file + gawk + ]; # These are desktop-specific, so we don't want xdg-utils to be able to # call them when in a different setup. fake.external = commonFakes ++ [ - "gio" # GNOME (new) - "gnomevfs-info" # GNOME (very old) - "gvfs-info" # GNOME (old) - "kde4-config" # Plasma 4 - "kfile" # KDE 3 - "kmimetypefinder" # Plasma (generic) - "kmimetypefinder5" # Plasma 5 - "ktraderclient" # KDE 3 - "ktradertest" # KDE 3 - "mimetype" # alternative tool for file, pulls in perl, avoid - "qtpaths" # Plasma - "qtxdg-mat" # LXQT + "gio" # GNOME (new) + "gnomevfs-info" # GNOME (very old) + "gvfs-info" # GNOME (old) + "kde4-config" # Plasma 4 + "kfile" # KDE 3 + "kmimetypefinder" # Plasma (generic) + "kmimetypefinder5" # Plasma 5 + "ktraderclient" # KDE 3 + "ktradertest" # KDE 3 + "mimetype" # alternative tool for file, pulls in perl, avoid + "qtpaths" # Plasma + "qtxdg-mat" # LXQT ]; fix."/usr/bin/file" = true; keep = { @@ -116,37 +155,46 @@ let prologue = "${writeText "xdg-mime-prologue" '' export XDG_DATA_DIRS="$XDG_DATA_DIRS''${XDG_DATA_DIRS:+:}${shared-mime-info}/share" export PERL5LIB=${with perlPackages; makePerlPath [ FileMimeInfo ]} - export PATH=$PATH:${lib.makeBinPath [ coreutils perlPackages.FileMimeInfo ]} + export PATH=$PATH:${ + lib.makeBinPath [ + coreutils + perlPackages.FileMimeInfo + ] + } ''}"; } { scripts = [ "bin/xdg-open" ]; interpreter = "${bash}/bin/bash"; - inputs = commonDeps ++ [ nettools glib.bin "${placeholder "out"}/bin" ]; + inputs = commonDeps ++ [ + nettools + glib.bin + "${placeholder "out"}/bin" + ]; execer = [ "cannot:${placeholder "out"}/bin/xdg-mime" ]; # These are desktop-specific, so we don't want xdg-utils to be able to # call them when in a different setup. fake.external = commonFakes ++ [ - "cygstart" # Cygwin - "dde-open" # Deepin - "enlightenment_open" # Enlightenment - "exo-open" # XFCE - "gio" # GNOME (new) - "gnome-open" # GNOME (very old) - "gvfs-open" # GNOME (old) - "kde-open" # Plasma - "kfmclient" # KDE3 - "mate-open" # MATE - "mimeopen" # alternative tool for file, pulls in perl, avoid - "open" # macOS - "pcmanfm" # LXDE - "qtxdg-mat" # LXQT - "run-mailcap" # generic - "rundll32.exe" # WSL - "wslpath" # WSL + "cygstart" # Cygwin + "dde-open" # Deepin + "enlightenment_open" # Enlightenment + "exo-open" # XFCE + "gio" # GNOME (new) + "gnome-open" # GNOME (very old) + "gvfs-open" # GNOME (old) + "kde-open" # Plasma + "kfmclient" # KDE3 + "mate-open" # MATE + "mimeopen" # alternative tool for file, pulls in perl, avoid + "open" # macOS + "pcmanfm" # LXDE + "qtxdg-mat" # LXQT + "run-mailcap" # generic + "rundll32.exe" # WSL + "wslpath" # WSL ]; fix."$printf" = [ "printf" ]; keep = { @@ -159,19 +207,28 @@ let { scripts = [ "bin/xdg-screensaver" ]; interpreter = "${bash}/bin/bash"; - inputs = commonDeps ++ [ nettools perl procps ] + inputs = + commonDeps + ++ [ + nettools + perl + procps + ] # procmail's funky build system is currently broken in cross-build. # xdg-screensaver will gracefully degrade if it's not available. ++ lib.optional (stdenv.hostPlatform == stdenv.buildPlatform) procmail; # These are desktop-specific, so we don't want xdg-utils to be able to # call them when in a different setup. - fake.external = commonFakes ++ [ - "dcop" # KDE3 - "mate-screensaver-command" # MATE - "xautolock" # Xautolock - "xscreensaver-command" # Xscreensaver - "xset" # generic-ish X - ] ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "lockfile"; # procmail + fake.external = + commonFakes + ++ [ + "dcop" # KDE3 + "mate-screensaver-command" # MATE + "xautolock" # Xautolock + "xscreensaver-command" # Xscreensaver + "xset" # generic-ish X + ] + ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "lockfile"; # procmail keep = { "$MV" = true; "$XPROP" = true; @@ -181,7 +238,15 @@ let "cannot:${perl}/bin/perl" ]; prologue = "${writeText "xdg-screensaver-prologue" '' - export PERL5LIB=${with perlPackages; makePerlPath [ NetDBus XMLTwig XMLParser X11Protocol ]} + export PERL5LIB=${ + with perlPackages; + makePerlPath [ + NetDBus + XMLTwig + XMLParser + X11Protocol + ] + } export PATH=$PATH:${coreutils}/bin ''}"; } @@ -189,22 +254,25 @@ let { scripts = [ "bin/xdg-settings" ]; interpreter = "${bash}/bin/bash"; - inputs = commonDeps ++ [ jq "${placeholder "out"}/bin" ]; + inputs = commonDeps ++ [ + jq + "${placeholder "out"}/bin" + ]; execer = [ "cannot:${placeholder "out"}/bin/xdg-mime" ]; # These are desktop-specific, so we don't want xdg-utils to be able to # call them when in a different setup. fake.external = commonFakes ++ [ - "gconftool-2" # GNOME - "kreadconfig" # Plasma (generic) - "kreadconfig5" # Plasma 5 - "kreadconfig6" # Plasma 6 - "ktradertest" # KDE3 - "kwriteconfig" # Plasma (generic) - "kwriteconfig5" # Plasma 5 - "kwriteconfig6" # Plasma 6 - "qtxdg-mat" # LXQT + "gconftool-2" # GNOME + "kreadconfig" # Plasma (generic) + "kreadconfig5" # Plasma 5 + "kreadconfig6" # Plasma 6 + "ktradertest" # KDE3 + "kwriteconfig" # Plasma (generic) + "kwriteconfig5" # Plasma 5 + "kwriteconfig6" # Plasma 6 + "qtxdg-mat" # LXQT ]; keep = { "$KDE_SESSION_VERSION" = true; @@ -216,13 +284,17 @@ let { scripts = [ "bin/xdg-terminal" ]; interpreter = "${bash}/bin/bash"; - inputs = commonDeps ++ [ bash glib.bin which ]; + inputs = commonDeps ++ [ + bash + glib.bin + which + ]; fake.external = commonFakes ++ [ - "gconftool-2" # GNOME - "exo-open" # XFCE - "lxterminal" # LXQT - "qterminal" # LXQT - "terminology" # Englightenment + "gconftool-2" # GNOME + "exo-open" # XFCE + "lxterminal" # LXQT + "qterminal" # LXQT + "terminology" # Englightenment ]; keep = { "$command" = true; @@ -255,40 +327,51 @@ stdenv.mkDerivation (self: { ]; # just needed when built from git - nativeBuildInputs = [ libxslt docbook_xml_dtd_412 docbook_xml_dtd_43 docbook_xsl xmlto ]; + nativeBuildInputs = [ + libxslt + docbook_xml_dtd_412 + docbook_xml_dtd_43 + docbook_xsl + xmlto + ]; # explicitly provide a runtime shell so patchShebangs is consistent across build platforms buildInputs = [ bash ]; - preFixup = lib.concatStringsSep "\n" (map (resholve.phraseSolution "xdg-utils-resholved") solutions); + preFixup = lib.concatStringsSep "\n" ( + map (resholve.phraseSolution "xdg-utils-resholved") solutions + ); - passthru.tests.xdg-mime = runCommand "xdg-mime-test" { - nativeBuildInputs = [ self.finalPackage ]; - preferLocalBuild = true; - xenias = lib.mapAttrsToList (hash: urls: fetchurl { inherit hash urls; }) { - "sha256-SL95tM1AjOi7vDnCyT10s0tvQvc+ZSZBbkNOYXfbOy0=" = [ - "https://staging.cohostcdn.org/attachment/0f5d9832-0cda-4d07-b35f-832b287feb6c/kernelkisser.png" - "https://static1.e621.net/data/0e/76/0e7672980d48e48c2d1373eb2505db5a.png" - ]; - "sha256-Si9AtB7J9o6rK/oftv+saST77CNaeWomWU5ECfbRioM=" = [ - "https://static1.e621.net/data/25/3d/253dc77fbc60d7214bc60e4a647d1c32.jpg" - ]; - "sha256-Z+onQRY5zlDWPp5/y4E6crLz3TaMCNipcxEEMSHuLkM=" = [ - "https://d.furaffinity.net/art/neotheta/1691409857/1691409857.neotheta_quickmakeanentry_by_neotheta-sig.png" - "https://static1.e621.net/data/bf/e4/bfe43ba264ad68e5d8a101ecef69c03e.png" - ]; - }; - } '' - for x in $xenias; do - ext=''${x##*.} - type="$(xdg-mime query filetype $x)" - [ $? -eq 0 ] && [ "$type" = "image/''${ext/jpg/jpeg}" ] || { - echo "Incorrect MIME type '$type' for '$x'" >&2 - exit 1 + passthru.tests.xdg-mime = + runCommand "xdg-mime-test" + { + nativeBuildInputs = [ self.finalPackage ]; + preferLocalBuild = true; + xenias = lib.mapAttrsToList (hash: urls: fetchurl { inherit hash urls; }) { + "sha256-SL95tM1AjOi7vDnCyT10s0tvQvc+ZSZBbkNOYXfbOy0=" = [ + "https://staging.cohostcdn.org/attachment/0f5d9832-0cda-4d07-b35f-832b287feb6c/kernelkisser.png" + "https://static1.e621.net/data/0e/76/0e7672980d48e48c2d1373eb2505db5a.png" + ]; + "sha256-Si9AtB7J9o6rK/oftv+saST77CNaeWomWU5ECfbRioM=" = [ + "https://static1.e621.net/data/25/3d/253dc77fbc60d7214bc60e4a647d1c32.jpg" + ]; + "sha256-Z+onQRY5zlDWPp5/y4E6crLz3TaMCNipcxEEMSHuLkM=" = [ + "https://d.furaffinity.net/art/neotheta/1691409857/1691409857.neotheta_quickmakeanentry_by_neotheta-sig.png" + "https://static1.e621.net/data/bf/e4/bfe43ba264ad68e5d8a101ecef69c03e.png" + ]; + }; } - done - touch $out - ''; + '' + for x in $xenias; do + ext=''${x##*.} + type="$(xdg-mime query filetype $x)" + [ $? -eq 0 ] && [ "$type" = "image/''${ext/jpg/jpeg}" ] || { + echo "Incorrect MIME type '$type' for '$x'" >&2 + exit 1 + } + done + touch $out + ''; meta = with lib; { homepage = "https://www.freedesktop.org/wiki/Software/xdg-utils/"; diff --git a/pkgs/by-name/xd/xdgmenumaker/package.nix b/pkgs/by-name/xd/xdgmenumaker/package.nix index 52a7b95bb80397..c4aee53b34d2bf 100644 --- a/pkgs/by-name/xd/xdgmenumaker/package.nix +++ b/pkgs/by-name/xd/xdgmenumaker/package.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, atk -, gdk-pixbuf -, gobject-introspection -, pango -, python3Packages -, txt2tags -, wrapGAppsHook3 -, gitUpdater +{ + lib, + fetchFromGitHub, + atk, + gdk-pixbuf, + gobject-introspection, + pango, + python3Packages, + txt2tags, + wrapGAppsHook3, + gitUpdater, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/xd/xdiskusage/package.nix b/pkgs/by-name/xd/xdiskusage/package.nix index 9db3563ca247bc..e5f2ded9efb770 100644 --- a/pkgs/by-name/xd/xdiskusage/package.nix +++ b/pkgs/by-name/xd/xdiskusage/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fltk }: +{ + lib, + stdenv, + fetchurl, + fltk, +}: stdenv.mkDerivation (finalAttrs: { pname = "xdiskusage"; diff --git a/pkgs/by-name/xd/xdo/package.nix b/pkgs/by-name/xd/xdo/package.nix index 268dfcd66e0414..dfb804c030e4b3 100644 --- a/pkgs/by-name/xd/xdo/package.nix +++ b/pkgs/by-name/xd/xdo/package.nix @@ -1,26 +1,37 @@ -{ lib, stdenv, fetchFromGitHub, libxcb, xcbutil, xcbutilwm }: +{ + lib, + stdenv, + fetchFromGitHub, + libxcb, + xcbutil, + xcbutilwm, +}: stdenv.mkDerivation rec { - pname = "xdo"; - version = "0.5.7"; + pname = "xdo"; + version = "0.5.7"; - src = fetchFromGitHub { - owner = "baskerville"; - repo = "xdo"; - rev = version; - sha256 = "1h3jrygcjjbavdbkpx2hscsf0yf97gk487lzjdlvymd7dxdv9hy9"; - }; + src = fetchFromGitHub { + owner = "baskerville"; + repo = "xdo"; + rev = version; + sha256 = "1h3jrygcjjbavdbkpx2hscsf0yf97gk487lzjdlvymd7dxdv9hy9"; + }; - makeFlags = [ "PREFIX=$(out)" ]; + makeFlags = [ "PREFIX=$(out)" ]; - buildInputs = [ libxcb xcbutilwm xcbutil ]; + buildInputs = [ + libxcb + xcbutilwm + xcbutil + ]; - meta = with lib; { - description = "Small X utility to perform elementary actions on windows"; - homepage = "https://github.com/baskerville/xdo"; - maintainers = with maintainers; [ meisternu ]; - license = licenses.bsd2; - platforms = platforms.linux; - mainProgram = "xdo"; - }; + meta = with lib; { + description = "Small X utility to perform elementary actions on windows"; + homepage = "https://github.com/baskerville/xdo"; + maintainers = with maintainers; [ meisternu ]; + license = licenses.bsd2; + platforms = platforms.linux; + mainProgram = "xdo"; + }; } diff --git a/pkgs/by-name/xd/xdotool/package.nix b/pkgs/by-name/xd/xdotool/package.nix index 55714f10f59ca3..d6b44562a4f174 100644 --- a/pkgs/by-name/xd/xdotool/package.nix +++ b/pkgs/by-name/xd/xdotool/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, libX11, perl, libXtst, xorgproto, libXi, libXinerama, libxkbcommon, libXext }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + libX11, + perl, + libXtst, + xorgproto, + libXi, + libXinerama, + libxkbcommon, + libXext, +}: stdenv.mkDerivation rec { pname = "xdotool"; @@ -11,8 +24,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-XFiaiHHtUSNFw+xhUR29+2RUHOa+Eyj1HHfjCUjwd9k="; }; - nativeBuildInputs = [ pkg-config perl ]; - buildInputs = [ libX11 libXtst xorgproto libXi libXinerama libxkbcommon libXext ]; + nativeBuildInputs = [ + pkg-config + perl + ]; + buildInputs = [ + libX11 + libXtst + xorgproto + libXi + libXinerama + libxkbcommon + libXext + ]; preBuild = '' mkdir -p $out/lib diff --git a/pkgs/by-name/xd/xdummy/package.nix b/pkgs/by-name/xd/xdummy/package.nix index 227829346cd08d..399226c7fc85ff 100644 --- a/pkgs/by-name/xd/xdummy/package.nix +++ b/pkgs/by-name/xd/xdummy/package.nix @@ -1,5 +1,12 @@ -{ writeText, writeScriptBin, xorg, xkeyboard_config, runtimeShell -, unfreeFonts ? false, lib}: +{ + writeText, + writeScriptBin, + xorg, + xkeyboard_config, + runtimeShell, + unfreeFonts ? false, + lib, +}: let xorgConfig = writeText "dummy-xorg.conf" '' @@ -75,7 +82,8 @@ let EndSection ''; -in writeScriptBin "xdummy" '' +in +writeScriptBin "xdummy" '' #!${runtimeShell} exec ${xorg.xorgserver.out}/bin/Xorg \ -noreset \ diff --git a/pkgs/by-name/xd/xdxf2slob/package.nix b/pkgs/by-name/xd/xdxf2slob/package.nix index e23d68f8fccb6c..6d1ad03f9f8754 100644 --- a/pkgs/by-name/xd/xdxf2slob/package.nix +++ b/pkgs/by-name/xd/xdxf2slob/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication { pname = "xdxf2slob"; @@ -11,7 +15,10 @@ python3Packages.buildPythonApplication { sha256 = "0m3dnc3816ja3kmik1wabb706dkqdf5sxvabwgf2rcrq891xcddd"; }; - propagatedBuildInputs = [ python3Packages.pyicu python3Packages.slob ]; + propagatedBuildInputs = [ + python3Packages.pyicu + python3Packages.slob + ]; meta = with lib; { description = "Tool to convert XDXF dictionary files to slob format"; diff --git a/pkgs/by-name/xe/xe-guest-utilities/package.nix b/pkgs/by-name/xe/xe-guest-utilities/package.nix index 9ed390bc444896..4d63c8660ac39d 100644 --- a/pkgs/by-name/xe/xe-guest-utilities/package.nix +++ b/pkgs/by-name/xe/xe-guest-utilities/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, runtimeShell +{ + lib, + buildGoModule, + fetchFromGitHub, + runtimeShell, }: buildGoModule rec { diff --git a/pkgs/by-name/xe/xe/package.nix b/pkgs/by-name/xe/xe/package.nix index 2d8fb2e98aea4d..fc17f5411a7c45 100644 --- a/pkgs/by-name/xe/xe/package.nix +++ b/pkgs/by-name/xe/xe/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "xe"; diff --git a/pkgs/by-name/xe/xearth/package.nix b/pkgs/by-name/xe/xearth/package.nix index 206f7110fff963..d8b096e6558061 100644 --- a/pkgs/by-name/xe/xearth/package.nix +++ b/pkgs/by-name/xe/xearth/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, imake, gccmakedep, libXt, libXext }: +{ + lib, + stdenv, + fetchurl, + imake, + gccmakedep, + libXt, + libXext, +}: stdenv.mkDerivation rec { pname = "xearth"; @@ -9,11 +17,24 @@ stdenv.mkDerivation rec { sha256 = "bcb1407cc35b3f6dd3606b2c6072273b6a912cbd9ed1ae22fb2d26694541309c"; }; - nativeBuildInputs = [ imake gccmakedep ]; - buildInputs = [ libXt libXext ]; + nativeBuildInputs = [ + imake + gccmakedep + ]; + buildInputs = [ + libXt + libXext + ]; - installFlags = [ "DESTDIR=$(out)/" "BINDIR=bin" "MANDIR=man/man1"]; - installTargets = [ "install" "install.man" ]; + installFlags = [ + "DESTDIR=$(out)/" + "BINDIR=bin" + "MANDIR=man/man1" + ]; + installTargets = [ + "install" + "install.man" + ]; meta = with lib; { description = "sets the X root window to an image of the Earth"; @@ -25,12 +46,12 @@ stdenv.mkDerivation rec { By default, xearth updates the displayed image every five minutes. ''; maintainers = [ maintainers.mafo ]; - license = { + license = { fullName = "xearth license"; url = "https://xearth.org/copyright.html"; free = true; }; - platforms=platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/xe/xed-editor/package.nix b/pkgs/by-name/xe/xed-editor/package.nix index 2a2093f7da855e..ac50149c8ad1c4 100644 --- a/pkgs/by-name/xe/xed-editor/package.nix +++ b/pkgs/by-name/xe/xed-editor/package.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitHub -, libxml2 -, libpeas -, glib -, gtk3 -, gtksourceview4 -, gspell -, xapp -, pkg-config -, python3 -, meson -, ninja -, versionCheckHook -, wrapGAppsHook3 -, intltool -, itstool +{ + stdenv, + lib, + fetchFromGitHub, + libxml2, + libpeas, + glib, + gtk3, + gtksourceview4, + gspell, + xapp, + pkg-config, + python3, + meson, + ninja, + versionCheckHook, + wrapGAppsHook3, + intltool, + itstool, }: stdenv.mkDerivation rec { @@ -64,7 +65,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/linuxmint/xed"; license = licenses.gpl2Only; platforms = platforms.linux; - maintainers = with maintainers; [ tu-maurice bobby285271 ]; + maintainers = with maintainers; [ + tu-maurice + bobby285271 + ]; mainProgram = "xed"; }; } diff --git a/pkgs/by-name/xe/xed/package.nix b/pkgs/by-name/xe/xed/package.nix index 2918ae7f3fe822..1bb99548bb5eea 100644 --- a/pkgs/by-name/xe/xed/package.nix +++ b/pkgs/by-name/xe/xed/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, python3Packages, llvmPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + python3Packages, + llvmPackages, +}: let # mbuild is a custom build system used only to build xed @@ -14,7 +20,8 @@ let }; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "xed"; version = "2024.02.22"; @@ -25,7 +32,9 @@ in stdenv.mkDerivation rec { sha256 = "sha256-LF4iJ1/Z3OifCiir/kU3ufZqtiRLeaJeAwuBqP2BCF4="; }; - nativeBuildInputs = [ mbuild ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ llvmPackages.bintools ]; + nativeBuildInputs = [ + mbuild + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ llvmPackages.bintools ]; buildPhase = '' patchShebangs mfile.py @@ -42,9 +51,9 @@ in stdenv.mkDerivation rec { meta = with lib; { broken = stdenv.hostPlatform.isAarch64; description = "Intel X86 Encoder Decoder (Intel XED)"; - homepage = "https://intelxed.github.io/"; - license = licenses.asl20; - platforms = platforms.unix; + homepage = "https://intelxed.github.io/"; + license = licenses.asl20; + platforms = platforms.unix; maintainers = with maintainers; [ arturcygan ]; }; } diff --git a/pkgs/by-name/xe/xedit/package.nix b/pkgs/by-name/xe/xedit/package.nix index eb8f2ee9259266..e2d2997cf38fe4 100644 --- a/pkgs/by-name/xe/xedit/package.nix +++ b/pkgs/by-name/xe/xedit/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitLab -, autoreconfHook -, pkg-config -, utilmacros -, libX11 -, libXaw -, libXmu -, libXt +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + utilmacros, + libX11, + libXaw, + libXmu, + libXt, }: stdenv.mkDerivation rec { @@ -29,7 +30,11 @@ stdenv.mkDerivation rec { done ''; - nativeBuildInputs = [ autoreconfHook pkg-config utilmacros ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + utilmacros + ]; buildInputs = [ libX11 libXaw diff --git a/pkgs/by-name/xe/xenomapper/package.nix b/pkgs/by-name/xe/xenomapper/package.nix index 98ee7c2819bec6..212b5c7ef9ddae 100644 --- a/pkgs/by-name/xe/xenomapper/package.nix +++ b/pkgs/by-name/xe/xenomapper/package.nix @@ -1,4 +1,8 @@ -{ python3, lib, fetchFromGitHub }: +{ + python3, + lib, + fetchFromGitHub, +}: python3.pkgs.buildPythonApplication rec { pname = "xenomapper"; diff --git a/pkgs/by-name/xe/xenon/package.nix b/pkgs/by-name/xe/xenon/package.nix index 2ecff603e71433..583036442ec3ca 100644 --- a/pkgs/by-name/xe/xenon/package.nix +++ b/pkgs/by-name/xe/xenon/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchPypi -, python3 +{ + lib, + fetchPypi, + python3, }: let @@ -19,7 +20,11 @@ python3.pkgs.buildPythonApplication { doCheck = false; - propagatedBuildInputs = with python3.pkgs; [ requests radon pyaml ]; + propagatedBuildInputs = with python3.pkgs; [ + requests + radon + pyaml + ]; meta = with lib; { description = "Monitoring tool based on radon"; diff --git a/pkgs/by-name/xe/xeus-zmq/package.nix b/pkgs/by-name/xe/xeus-zmq/package.nix index 0e27aa511de2b0..ae437416345813 100644 --- a/pkgs/by-name/xe/xeus-zmq/package.nix +++ b/pkgs/by-name/xe/xeus-zmq/package.nix @@ -1,14 +1,15 @@ -{ lib -, clangStdenv -, fetchFromGitHub -, cmake -, cppzmq -, libuuid -, nlohmann_json -, openssl -, xeus -, xtl -, zeromq +{ + lib, + clangStdenv, + fetchFromGitHub, + cmake, + cppzmq, + libuuid, + nlohmann_json, + openssl, + xeus, + xtl, + zeromq, }: clangStdenv.mkDerivation rec { diff --git a/pkgs/by-name/xe/xeus/package.nix b/pkgs/by-name/xe/xeus/package.nix index 9283f20c335f7a..31d66347ee8eac 100644 --- a/pkgs/by-name/xe/xeus/package.nix +++ b/pkgs/by-name/xe/xeus/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, doctest -, nlohmann_json -, libuuid -, xtl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + doctest, + nlohmann_json, + libuuid, + xtl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xf/xf86_input_cmt/package.nix b/pkgs/by-name/xf/xf86_input_cmt/package.nix index a973f844fd4a08..80c8f895aa3d22 100644 --- a/pkgs/by-name/xf/xf86_input_cmt/package.nix +++ b/pkgs/by-name/xf/xf86_input_cmt/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, xorgserver, xorgproto, - utilmacros, libgestures, libevdevc }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + xorgserver, + xorgproto, + utilmacros, + libgestures, + libevdevc, +}: stdenv.mkDerivation rec { pname = "xf86-input-cmt"; @@ -18,8 +27,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - xorgserver xorgproto utilmacros - libgestures libevdevc + xorgserver + xorgproto + utilmacros + libgestures + libevdevc ]; configureFlags = [ diff --git a/pkgs/by-name/xf/xf86_input_wacom/package.nix b/pkgs/by-name/xf/xf86_input_wacom/package.nix index 6ffa743aa01eba..311c918aadcc2d 100644 --- a/pkgs/by-name/xf/xf86_input_wacom/package.nix +++ b/pkgs/by-name/xf/xf86_input_wacom/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, xorgproto -, libX11 -, libXext -, libXi -, libXinerama -, libXrandr -, libXrender -, ncurses -, pixman -, pkg-config -, udev -, utilmacros -, xorgserver +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + xorgproto, + libX11, + libXext, + libXi, + libXinerama, + libXrandr, + libXrender, + ncurses, + pixman, + pkg-config, + udev, + utilmacros, + xorgserver, }: stdenv.mkDerivation rec { @@ -28,7 +29,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-0eDik4fhsg1HAL6lCZMll/0VAghpzMSHY0RoKxSOIbc="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libX11 diff --git a/pkgs/by-name/xf/xf86_video_nested/package.nix b/pkgs/by-name/xf/xf86_video_nested/package.nix index e922e182386135..46574326b3b68c 100644 --- a/pkgs/by-name/xf/xf86_video_nested/package.nix +++ b/pkgs/by-name/xf/xf86_video_nested/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchgit, autoreconfHook, xorgproto, libX11, libXext -, pixman, pkg-config, utilmacros, xorgserver +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + xorgproto, + libX11, + libXext, + pixman, + pkg-config, + utilmacros, + xorgserver, }: stdenv.mkDerivation { @@ -12,12 +22,19 @@ stdenv.mkDerivation { sha256 = "133rd2kvr2q2wmwpx82bb93qbi8wm8qp1vlmbhgc7aslz0j4cqqv"; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; - buildInputs = - [ xorgproto libX11 libXext pixman - utilmacros xorgserver - ]; + buildInputs = [ + xorgproto + libX11 + libXext + pixman + utilmacros + xorgserver + ]; hardeningDisable = [ "fortify" ]; diff --git a/pkgs/by-name/xf/xfig/package.nix b/pkgs/by-name/xf/xfig/package.nix index 1929bff925fbac..990bb00b1f61db 100644 --- a/pkgs/by-name/xf/xfig/package.nix +++ b/pkgs/by-name/xf/xfig/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, imagemagick -, libXpm -, libXmu -, libXi -, libXp -, Xaw3d -, libXaw -, libXft -, fig2dev +{ + lib, + stdenv, + fetchurl, + makeWrapper, + imagemagick, + libXpm, + libXmu, + libXi, + libXp, + Xaw3d, + libXaw, + libXft, + fig2dev, }: stdenv.mkDerivation rec { @@ -22,7 +23,10 @@ stdenv.mkDerivation rec { hash = "sha256-E+2dBNG7wt7AnafvSc7sJ4OC0pD2zZJkdMLy0Bb+wvc="; }; - nativeBuildInputs = [ imagemagick makeWrapper ]; + nativeBuildInputs = [ + imagemagick + makeWrapper + ]; buildInputs = [ libXpm @@ -66,6 +70,11 @@ stdenv.mkDerivation rec { Note that you need to have the netpbm tools in your path to export bitmaps. ''; - inherit (fig2dev.meta) license homepage platforms maintainers; + inherit (fig2dev.meta) + license + homepage + platforms + maintainers + ; }; } diff --git a/pkgs/by-name/xf/xfitter/package.nix b/pkgs/by-name/xf/xfitter/package.nix index e509f3a005f7e4..7a5b9f902d3143 100644 --- a/pkgs/by-name/xf/xfitter/package.nix +++ b/pkgs/by-name/xf/xfitter/package.nix @@ -1,24 +1,26 @@ -{ lib -, stdenv -, fetchurl -, apfel -, apfelgrid -, applgrid -, blas -, ceres-solver -, cmake -, gfortran -, gsl -, lapack -, lhapdf -, libtirpc -, libyaml -, yaml-cpp -, pkg-config -, qcdnum -, root -, zlib -, memorymappingHook, memstreamHook +{ + lib, + stdenv, + fetchurl, + apfel, + apfelgrid, + applgrid, + blas, + ceres-solver, + cmake, + gfortran, + gsl, + lapack, + lhapdf, + libtirpc, + libyaml, + yaml-cpp, + pkg-config, + qcdnum, + root, + zlib, + memorymappingHook, + memstreamHook, }: stdenv.mkDerivation rec { @@ -36,15 +38,38 @@ stdenv.mkDerivation rec { ./0001-src-GetChisquare.f-use-correct-types-in-calls-to-DSY.patch ]; - nativeBuildInputs = [ cmake gfortran pkg-config ]; + nativeBuildInputs = [ + cmake + gfortran + pkg-config + ]; buildInputs = - [ apfel blas ceres-solver lhapdf lapack libyaml root qcdnum gsl yaml-cpp zlib ] - ++ lib.optionals ("5" == lib.versions.major root.version) [ apfelgrid applgrid ] - ++ lib.optionals (stdenv.system == "x86_64-darwin") [ memorymappingHook memstreamHook ] - ++ lib.optional (stdenv.hostPlatform.libc == "glibc") libtirpc - ; + [ + apfel + blas + ceres-solver + lhapdf + lapack + libyaml + root + qcdnum + gsl + yaml-cpp + zlib + ] + ++ lib.optionals ("5" == lib.versions.major root.version) [ + apfelgrid + applgrid + ] + ++ lib.optionals (stdenv.system == "x86_64-darwin") [ + memorymappingHook + memstreamHook + ] + ++ lib.optional (stdenv.hostPlatform.libc == "glibc") libtirpc; - env.NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.hostPlatform.libc == "glibc") "-I${libtirpc.dev}/include/tirpc"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.hostPlatform.libc == "glibc" + ) "-I${libtirpc.dev}/include/tirpc"; NIX_LDFLAGS = lib.optional (stdenv.hostPlatform.libc == "glibc") "-ltirpc"; hardeningDisable = [ "format" ]; @@ -56,9 +81,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "XFitter project is an open source QCD fit framework ready to extract PDFs and assess the impact of new data"; - license = licenses.gpl3; - homepage = "https://www.xfitter.org/xFitter"; - platforms = platforms.unix; + license = licenses.gpl3; + homepage = "https://www.xfitter.org/xFitter"; + platforms = platforms.unix; maintainers = with maintainers; [ veprbl ]; }; } diff --git a/pkgs/by-name/xf/xfontsel/package.nix b/pkgs/by-name/xf/xfontsel/package.nix index 203b94b0845fa4..0b01c7f0cfc640 100644 --- a/pkgs/by-name/xf/xfontsel/package.nix +++ b/pkgs/by-name/xf/xfontsel/package.nix @@ -2,7 +2,14 @@ # at https://www.x.org/releases/individual/. # That is why this expression is not inside pkgs.xorg -{ lib, stdenv, fetchurl, makeWrapper, xorg, pkg-config }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + xorg, + pkg-config, +}: stdenv.mkDerivation rec { pname = "xfontsel"; @@ -13,9 +20,15 @@ stdenv.mkDerivation rec { sha256 = "0700lf6hx7dg88wq1yll7zjvf9gbwh06xff20yffkxb289y0pai5"; }; - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; - buildInputs = [ xorg.libX11 xorg.libXaw ]; + buildInputs = [ + xorg.libX11 + xorg.libXaw + ]; # Without this, it gets Xmu as a dependency, but without rpath entry NIX_LDFLAGS = "-lXmu"; @@ -33,7 +46,11 @@ stdenv.mkDerivation rec { homepage = "https://www.x.org/"; description = "Allows testing the fonts available in an X server"; mainProgram = "xfontsel"; - license = with licenses; [ x11 smlnj mit ]; + license = with licenses; [ + x11 + smlnj + mit + ]; maintainers = [ ]; platforms = platforms.unix; }; diff --git a/pkgs/by-name/xf/xfractint/package.nix b/pkgs/by-name/xf/xfractint/package.nix index d4873dd926894b..bd3c45d299b237 100644 --- a/pkgs/by-name/xf/xfractint/package.nix +++ b/pkgs/by-name/xf/xfractint/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, libX11, libXft}: +{ + lib, + stdenv, + fetchurl, + libX11, + libXft, +}: stdenv.mkDerivation rec { pname = "xfractint"; version = "20.04p16"; @@ -8,20 +14,23 @@ stdenv.mkDerivation rec { sha256 = "1ba77jifxv8jql044mdydh4p4ms4w5vw3qrqmcfzlvqfxk7h2m2f"; }; - buildInputs = [libX11 libXft]; + buildInputs = [ + libX11 + libXft + ]; configurePhase = '' sed -e 's@/usr/bin/@@' -i Makefile ''; - makeFlags = ["PREFIX=$(out)"]; + makeFlags = [ "PREFIX=$(out)" ]; meta = { description = ""; # Code cannot be used in commercial programs # Looks like the definition hinges on the price, not license license = lib.licenses.unfree; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; homepage = "https://www.fractint.net/"; mainProgram = "xfractint"; diff --git a/pkgs/by-name/xf/xfs-undelete/package.nix b/pkgs/by-name/xf/xfs-undelete/package.nix index 030f3324fc59cf..18d0b9070ae4fd 100644 --- a/pkgs/by-name/xf/xfs-undelete/package.nix +++ b/pkgs/by-name/xf/xfs-undelete/package.nix @@ -1,28 +1,42 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, coreutils -, tcl-8_6 -, tclPackages -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + coreutils, + tcl-8_6, + tclPackages, + installShellFiles, }: stdenv.mkDerivation { pname = "xfs_undelete"; version = "unstable-2023-04-12"; - src = fetchFromGitHub { + src = fetchFromGitHub { repo = "xfs_undelete"; owner = "ianka"; rev = "9e2f7abf0d3a466328e335d251c567ce4194e473"; hash = "sha256-ENa/r3+o7abW8iun6V/2LhTVmFVSwVM6v46KXBcKJ1g="; }; - buildInputs = [ tcl-8_6 tclPackages.tcllib coreutils ]; - nativeBuildInputs = [ makeWrapper tcl-8_6.tclPackageHook installShellFiles ]; - - tclWrapperArgs = [ "--prefix" "PATH" ":" (lib.makeBinPath [ tcl-8_6 ]) ]; + buildInputs = [ + tcl-8_6 + tclPackages.tcllib + coreutils + ]; + nativeBuildInputs = [ + makeWrapper + tcl-8_6.tclPackageHook + installShellFiles + ]; + + tclWrapperArgs = [ + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ tcl-8_6 ]) + ]; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/xf/xfsdump/package.nix b/pkgs/by-name/xf/xfsdump/package.nix index a6867e3c0a5fe8..0ba301046c30ed 100644 --- a/pkgs/by-name/xf/xfsdump/package.nix +++ b/pkgs/by-name/xf/xfsdump/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, attr -, gettext -, autoconf -, automake -, ncurses -, libtool -, libuuid -, libxfs +{ + lib, + stdenv, + fetchurl, + attr, + gettext, + autoconf, + automake, + ncurses, + libtool, + libuuid, + libxfs, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xf/xfsprogs/package.nix b/pkgs/by-name/xf/xfsprogs/package.nix index 9ac968d7a76e7b..86cc97764b9f28 100644 --- a/pkgs/by-name/xf/xfsprogs/package.nix +++ b/pkgs/by-name/xf/xfsprogs/package.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, buildPackages, fetchurl, gettext, pkg-config -, icu, libuuid, readline, inih, liburcu -, nixosTests +{ + lib, + stdenv, + buildPackages, + fetchurl, + gettext, + pkg-config, + icu, + libuuid, + readline, + inih, + liburcu, + nixosTests, }: stdenv.mkDerivation rec { @@ -12,15 +22,26 @@ stdenv.mkDerivation rec { hash = "sha256-CDJAckfbeRzHDe+W5+JUvW7fBD3ISoCmLzzNbj3/0yk="; }; - outputs = [ "bin" "dev" "out" "doc" ]; + outputs = [ + "bin" + "dev" + "out" + "doc" + ]; depsBuildBuild = [ buildPackages.stdenv.cc ]; nativeBuildInputs = [ - gettext pkg-config + gettext + pkg-config libuuid # codegen tool uses libuuid liburcu # required by crc32selftest ]; - buildInputs = [ readline icu inih liburcu ]; + buildInputs = [ + readline + icu + inih + liburcu + ]; propagatedBuildInputs = [ libuuid ]; # Dev headers include enableParallelBuilding = true; @@ -59,8 +80,15 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://xfs.wiki.kernel.org"; description = "SGI XFS utilities"; - license = with licenses; [ gpl2Only lgpl21 gpl3Plus ]; # see https://git.kernel.org/pub/scm/fs/xfs/xfsprogs-dev.git/tree/debian/copyright + license = with licenses; [ + gpl2Only + lgpl21 + gpl3Plus + ]; # see https://git.kernel.org/pub/scm/fs/xfs/xfsprogs-dev.git/tree/debian/copyright platforms = platforms.linux; - maintainers = with maintainers; [ dezgeg ajs124 ]; + maintainers = with maintainers; [ + dezgeg + ajs124 + ]; }; } diff --git a/pkgs/by-name/xf/xfstests/package.nix b/pkgs/by-name/xf/xfstests/package.nix index aed576f7d34afa..6e3fa6fdb48489 100644 --- a/pkgs/by-name/xf/xfstests/package.nix +++ b/pkgs/by-name/xf/xfstests/package.nix @@ -1,7 +1,36 @@ -{ stdenv, acl, attr, autoconf, automake, bash, bc, coreutils, e2fsprogs -, fetchzip, fio, gawk, keyutils, killall, lib, libaio, libcap, libtool -, libuuid, libxfs, lvm2, openssl, perl, procps, quota -, time, util-linux, which, writeScript, xfsprogs, runtimeShell }: +{ + stdenv, + acl, + attr, + autoconf, + automake, + bash, + bc, + coreutils, + e2fsprogs, + fetchzip, + fio, + gawk, + keyutils, + killall, + lib, + libaio, + libcap, + libtool, + libuuid, + libxfs, + lvm2, + openssl, + perl, + procps, + quota, + time, + util-linux, + which, + writeScript, + xfsprogs, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "xfstests"; @@ -13,10 +42,19 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - autoconf automake libtool + autoconf + automake + libtool ]; buildInputs = [ - acl attr gawk libaio libuuid libxfs openssl perl + acl + attr + gawk + libaio + libuuid + libxfs + openssl + perl ]; hardeningDisable = [ "format" ]; @@ -94,9 +132,26 @@ stdenv.mkDerivation rec { ln -s @out@/lib/xfstests/$f $f done - export PATH=${lib.makeBinPath [acl attr bc e2fsprogs fio gawk keyutils - libcap lvm2 perl procps killall quota - util-linux which xfsprogs]}:$PATH + export PATH=${ + lib.makeBinPath [ + acl + attr + bc + e2fsprogs + fio + gawk + keyutils + libcap + lvm2 + perl + procps + killall + quota + util-linux + which + xfsprogs + ] + }:$PATH exec ./check "$@" ''; diff --git a/pkgs/by-name/xg/xgalagapp/package.nix b/pkgs/by-name/xg/xgalagapp/package.nix index 9b2bd5a9af736f..8afd7f29f069dd 100644 --- a/pkgs/by-name/xg/xgalagapp/package.nix +++ b/pkgs/by-name/xg/xgalagapp/package.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, libX11 -, libXpm +{ + lib, + stdenv, + fetchurl, + libX11, + libXpm, }: stdenv.mkDerivation rec { pname = "xgalaga++"; version = "0.9"; src = fetchurl { - url = "https://marc.mongenet.ch/OSS/XGalaga/xgalaga++_${version}.tar.gz"; + url = "https://marc.mongenet.ch/OSS/XGalaga/xgalaga++_${version}.tar.gz"; sha256 = "sha256-yNtLuYCMHLvQAVM7CDGPardrh3q27TE9l31qhUbMf8k="; }; diff --git a/pkgs/by-name/xg/xgboost/package.nix b/pkgs/by-name/xg/xgboost/package.nix index c294551eef50a9..ef167e4f6770d9 100644 --- a/pkgs/by-name/xg/xgboost/package.nix +++ b/pkgs/by-name/xg/xgboost/package.nix @@ -1,19 +1,20 @@ -{ config -, stdenv -, lib -, fetchFromGitHub -, fetchpatch -, cmake -, gtest -, doCheck ? true -, autoAddDriverRunpath -, cudaSupport ? config.cudaSupport -, ncclSupport ? false -, rLibrary ? false -, cudaPackages -, llvmPackages -, R -, rPackages +{ + config, + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, + gtest, + doCheck ? true, + autoAddDriverRunpath, + cudaSupport ? config.cudaSupport, + ncclSupport ? false, + rLibrary ? false, + cudaPackages, + llvmPackages, + R, + rPackages, }@inputs: assert ncclSupport -> (cudaSupport && !cudaPackages.nccl.meta.unsupported); @@ -59,19 +60,23 @@ effectiveStdenv.mkDerivation rec { }; patches = lib.optionals (cudaSupport && cudaPackages.cudaMajorMinorVersion == "12.4") [ - (fetchpatch { # https://github.com/dmlc/xgboost/pull/10123 + (fetchpatch { + # https://github.com/dmlc/xgboost/pull/10123 name = "Fix compilation with the ctk 12.4."; url = "https://github.com/dmlc/xgboost/commit/c760f85db0bc7bd6379901fbfb67ceccc2b37700.patch"; hash = "sha256-iP9mll9pg8T2ztCR7dBPnLP17/x3ImJFrr5G3e2dqHo="; }) ]; - nativeBuildInputs = [ cmake ] + nativeBuildInputs = + [ cmake ] ++ lib.optionals effectiveStdenv.hostPlatform.isDarwin [ llvmPackages.openmp ] ++ lib.optionals cudaSupport [ autoAddDriverRunpath ] ++ lib.optionals rLibrary [ R ]; - buildInputs = [ gtest ] ++ lib.optional cudaSupport cudaPackages.cudatoolkit + buildInputs = + [ gtest ] + ++ lib.optional cudaSupport cudaPackages.cudatoolkit ++ lib.optional ncclSupport cudaPackages.nccl; propagatedBuildInputs = lib.optionals rLibrary [ @@ -80,14 +85,16 @@ effectiveStdenv.mkDerivation rec { rPackages.Matrix ]; - cmakeFlags = lib.optionals doCheck [ "-DGOOGLE_TEST=ON" ] + cmakeFlags = + lib.optionals doCheck [ "-DGOOGLE_TEST=ON" ] ++ lib.optionals cudaSupport [ - "-DUSE_CUDA=ON" - # Their CMakeLists.txt does not respect CUDA_HOST_COMPILER, instead using the CXX compiler. - # https://github.com/dmlc/xgboost/blob/ccf43d4ba0a94e2f0a3cc5a526197539ae46f410/CMakeLists.txt#L145 - "-DCMAKE_C_COMPILER=${effectiveStdenv.cc}/bin/gcc" - "-DCMAKE_CXX_COMPILER=${effectiveStdenv.cc}/bin/g++" - ] ++ lib.optionals ncclSupport [ "-DUSE_NCCL=ON" ] + "-DUSE_CUDA=ON" + # Their CMakeLists.txt does not respect CUDA_HOST_COMPILER, instead using the CXX compiler. + # https://github.com/dmlc/xgboost/blob/ccf43d4ba0a94e2f0a3cc5a526197539ae46f410/CMakeLists.txt#L145 + "-DCMAKE_C_COMPILER=${effectiveStdenv.cc}/bin/gcc" + "-DCMAKE_CXX_COMPILER=${effectiveStdenv.cc}/bin/g++" + ] + ++ lib.optionals ncclSupport [ "-DUSE_NCCL=ON" ] ++ lib.optionals rLibrary [ "-DR_LIB=ON" ]; preConfigure = lib.optionals rLibrary '' @@ -100,9 +107,7 @@ effectiveStdenv.mkDerivation rec { # By default, cmake build will run ctests with all checks enabled # If we're building with cuda, we run ctest manually so that we can skip the GPU tests checkPhase = lib.optionalString cudaSupport '' - ctest --force-new-ctest-process ${ - lib.optionalString cudaSupport "-E TestXGBoostLib" - } + ctest --force-new-ctest-process ${lib.optionalString cudaSupport "-E TestXGBoostLib"} ''; # Disable finicky tests from dmlc core that fail in Hydra. XGboost team @@ -126,7 +131,8 @@ effectiveStdenv.mkDerivation rec { + lib.optionalString rLibrary '' mkdir -p $out/library export R_LIBS_SITE="$out/library:$R_LIBS_SITE''${R_LIBS_SITE:+:}" - '' + '' + '' + + '' cmake --install . cp -r ../rabit/include/rabit $out/include runHook postInstall @@ -139,13 +145,15 @@ effectiveStdenv.mkDerivation rec { ''; meta = with lib; { - description = - "Scalable, Portable and Distributed Gradient Boosting (GBDT, GBRT or GBM) Library"; + description = "Scalable, Portable and Distributed Gradient Boosting (GBDT, GBRT or GBM) Library"; homepage = "https://github.com/dmlc/xgboost"; broken = cudaSupport && cudaPackages.cudaOlder "11.4"; license = licenses.asl20; mainProgram = "xgboost"; platforms = platforms.unix; - maintainers = with maintainers; [ abbradar nviets ]; + maintainers = with maintainers; [ + abbradar + nviets + ]; }; } diff --git a/pkgs/by-name/xg/xgeometry-select/package.nix b/pkgs/by-name/xg/xgeometry-select/package.nix index 005bf302cc3429..8021917d8e505a 100644 --- a/pkgs/by-name/xg/xgeometry-select/package.nix +++ b/pkgs/by-name/xg/xgeometry-select/package.nix @@ -1,11 +1,16 @@ -{ lib, stdenv, fetchurl, libX11 }: +{ + lib, + stdenv, + fetchurl, + libX11, +}: stdenv.mkDerivation rec { pname = "xgeometry-select"; - version = "0.1"; + version = "0.1"; src = fetchurl { - url = "https://gist.githubusercontent.com/obadz/7e008b1f803c4cdcfaf7321c78bcbe92/raw/7e7361e71ff0f74655ee92bd6d2c042f8586f2ae/xgeometry-select.c"; + url = "https://gist.githubusercontent.com/obadz/7e008b1f803c4cdcfaf7321c78bcbe92/raw/7e7361e71ff0f74655ee92bd6d2c042f8586f2ae/xgeometry-select.c"; sha256 = "0s7kirgh5iz91m3qy8xiq0j4gljy8zrcnylf4szl5h0lrsaqj7ya"; }; @@ -24,9 +29,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Select a region with mouse and prints geometry information (x/y/w/h)"; - homepage = "https://bbs.archlinux.org/viewtopic.php?pid=660837"; + homepage = "https://bbs.archlinux.org/viewtopic.php?pid=660837"; maintainers = with maintainers; [ obadz ]; - platforms = platforms.linux; + platforms = platforms.linux; mainProgram = "xgeometry-select"; }; } diff --git a/pkgs/by-name/xh/xh/package.nix b/pkgs/by-name/xh/xh/package.nix index 679a162a54e2d6..eea4a464476e93 100644 --- a/pkgs/by-name/xh/xh/package.nix +++ b/pkgs/by-name/xh/xh/package.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, withNativeTls ? true -, stdenv -, darwin -, openssl +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + withNativeTls ? true, + stdenv, + darwin, + openssl, }: rustPlatform.buildRustPackage rec { @@ -24,10 +25,17 @@ rustPlatform.buildRustPackage rec { buildFeatures = lib.optional withNativeTls "native-tls"; - nativeBuildInputs = [ installShellFiles pkg-config ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + ]; - buildInputs = lib.optionals withNativeTls - (if stdenv.hostPlatform.isDarwin then [ darwin.apple_sdk.frameworks.SystemConfiguration ] else [ openssl ]); + buildInputs = lib.optionals withNativeTls ( + if stdenv.hostPlatform.isDarwin then + [ darwin.apple_sdk.frameworks.SystemConfiguration ] + else + [ openssl ] + ); # Get openssl-sys to use pkg-config OPENSSL_NO_VENDOR = 1; @@ -59,7 +67,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/ducaale/xh"; changelog = "https://github.com/ducaale/xh/blob/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ figsoda aaronjheng ]; + maintainers = with maintainers; [ + figsoda + aaronjheng + ]; mainProgram = "xh"; }; } diff --git a/pkgs/by-name/xh/xhosts/package.nix b/pkgs/by-name/xh/xhosts/package.nix index ba6b5a184d3f76..c3974cbd0344fd 100644 --- a/pkgs/by-name/xh/xhosts/package.nix +++ b/pkgs/by-name/xh/xhosts/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage { diff --git a/pkgs/by-name/xh/xhtml1/package.nix b/pkgs/by-name/xh/xhtml1/package.nix index 9a81fbb6e1b446..6de0a0e3369d54 100644 --- a/pkgs/by-name/xh/xhtml1/package.nix +++ b/pkgs/by-name/xh/xhtml1/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libxml2 }: +{ + lib, + stdenv, + fetchurl, + libxml2, +}: stdenv.mkDerivation { pname = "xhtml1"; @@ -11,19 +16,18 @@ stdenv.mkDerivation { nativeBuildInputs = [ libxml2 ]; - installPhase = - '' - mkdir -p $out/xml/dtd/xhtml1 - cp DTD/*.ent DTD/*.dtd $out/xml/dtd/xhtml1 + installPhase = '' + mkdir -p $out/xml/dtd/xhtml1 + cp DTD/*.ent DTD/*.dtd $out/xml/dtd/xhtml1 - # Generate an XML catalog. - cat=$out/xml/dtd/xhtml1/catalog.xml - xmlcatalog --noout --create $cat - grep PUBLIC DTD/*.soc | while read x; do - eval a=($x) - xmlcatalog --noout --add public "''${a[1]}" "''${a[2]}" $cat - done - ''; # */ + # Generate an XML catalog. + cat=$out/xml/dtd/xhtml1/catalog.xml + xmlcatalog --noout --create $cat + grep PUBLIC DTD/*.soc | while read x; do + eval a=($x) + xmlcatalog --noout --add public "''${a[1]}" "''${a[2]}" $cat + done + ''; # */ meta = { homepage = "https://www.w3.org/TR/xhtml1/"; diff --git a/pkgs/by-name/xi/xib2nib/package.nix b/pkgs/by-name/xi/xib2nib/package.nix index 56f1e287834344..8fee6dbfd1a737 100644 --- a/pkgs/by-name/xi/xib2nib/package.nix +++ b/pkgs/by-name/xi/xib2nib/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, boost -, plistcpp -, pugixml +{ + lib, + stdenv, + fetchFromGitHub, + boost, + plistcpp, + pugixml, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/xi/xiccd/package.nix b/pkgs/by-name/xi/xiccd/package.nix index 4ffb5b689e3bad..30fa495d71a032 100644 --- a/pkgs/by-name/xi/xiccd/package.nix +++ b/pkgs/by-name/xi/xiccd/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, libX11, libXrandr, glib, colord }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libX11, + libXrandr, + glib, + colord, +}: stdenv.mkDerivation rec { pname = "xiccd"; @@ -11,8 +21,16 @@ stdenv.mkDerivation rec { sha256 = "159fyz5535lcabi5bzmxgmjdgxlqcjaiqgzr00mi3ax0i5fdldwn"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libX11 libXrandr glib colord ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libX11 + libXrandr + glib + colord + ]; meta = with lib; { description = "X color profile daemon"; diff --git a/pkgs/by-name/xi/xidel/package.nix b/pkgs/by-name/xi/xidel/package.nix index 6119151e5294d0..1edaab585d00a7 100644 --- a/pkgs/by-name/xi/xidel/package.nix +++ b/pkgs/by-name/xi/xidel/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, fpc, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + fpc, + openssl, +}: let flreSrc = fetchFromGitHub { @@ -31,7 +37,8 @@ let rev = "1696f0a2b822fef26c8992f96620f1be129cfa99"; hash = "sha256-x0AjOTa1g7gJOR2iBO76yBt1kzcRNujHRUsq5QOlfP0="; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "xidel"; version = "unstable-2022-11-01"; diff --git a/pkgs/by-name/xi/xilinx-bootgen/package.nix b/pkgs/by-name/xi/xilinx-bootgen/package.nix index 9190d87986a1c3..eb0bd3f025cafd 100644 --- a/pkgs/by-name/xi/xilinx-bootgen/package.nix +++ b/pkgs/by-name/xi/xilinx-bootgen/package.nix @@ -37,7 +37,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/Xilinx/bootgen"; license = lib.licenses.asl20; platforms = lib.platforms.linux; - maintainers = [ lib.maintainers.flokli lib.maintainers.jmbaur ]; + maintainers = [ + lib.maintainers.flokli + lib.maintainers.jmbaur + ]; mainProgram = "bootgen"; }; }) diff --git a/pkgs/by-name/xi/xinetd/package.nix b/pkgs/by-name/xi/xinetd/package.nix index 9abef85bde2975..9deff58cf1d21f 100644 --- a/pkgs/by-name/xi/xinetd/package.nix +++ b/pkgs/by-name/xi/xinetd/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, libtirpc +{ + lib, + stdenv, + fetchurl, + pkg-config, + libtirpc, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/xi/xinput_calibrator/package.nix b/pkgs/by-name/xi/xinput_calibrator/package.nix index aee42ac6a09226..e54ab099c87493 100644 --- a/pkgs/by-name/xi/xinput_calibrator/package.nix +++ b/pkgs/by-name/xi/xinput_calibrator/package.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, libXi, xorgproto, autoconf, automake, libtool, m4, pkg-config, xorg }: +{ + lib, + stdenv, + fetchFromGitHub, + libXi, + xorgproto, + autoconf, + automake, + libtool, + m4, + pkg-config, + xorg, +}: stdenv.mkDerivation rec { pname = "xinput_calibrator"; @@ -13,8 +25,19 @@ stdenv.mkDerivation rec { preConfigure = "./autogen.sh --with-gui=X11"; - nativeBuildInputs = [ pkg-config autoconf automake ]; - buildInputs = [ xorgproto libXi libtool m4 xorg.libX11 xorg.libXext ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; + buildInputs = [ + xorgproto + libXi + libtool + m4 + xorg.libX11 + xorg.libXext + ]; meta = { homepage = "https://github.com/tias/xinput_calibrator"; diff --git a/pkgs/by-name/xi/xiphos/package.nix b/pkgs/by-name/xi/xiphos/package.nix index b6b01ae0770f66..79d713ddb2fb00 100644 --- a/pkgs/by-name/xi/xiphos/package.nix +++ b/pkgs/by-name/xi/xiphos/package.nix @@ -1,31 +1,32 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, appstream-glib -, biblesync -, cmake -, dbus-glib -, desktop-file-utils -, docbook2x -, docbook_xml_dtd_412 -, enchant2 -, glib -, gtk3 -, gtkhtml -, icu -, intltool -, isocodes -, itstool -, libuuid -, libxslt -, minizip -, pkg-config -, sword -, webkitgtk_4_0 -, wrapGAppsHook3 -, yelp-tools -, zip +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + appstream-glib, + biblesync, + cmake, + dbus-glib, + desktop-file-utils, + docbook2x, + docbook_xml_dtd_412, + enchant2, + glib, + gtk3, + gtkhtml, + icu, + intltool, + isocodes, + itstool, + libuuid, + libxslt, + minizip, + pkg-config, + sword, + webkitgtk_4_0, + wrapGAppsHook3, + yelp-tools, + zip, }: stdenv.mkDerivation rec { @@ -43,7 +44,7 @@ stdenv.mkDerivation rec { # GLIB_VERSION_MIN_REQUIRED is not defined. # https://github.com/crosswire/xiphos/issues/1083#issuecomment-820304874 (fetchpatch { - name ="xiphos-glibc.patch"; + name = "xiphos-glibc.patch"; url = "https://aur.archlinux.org/cgit/aur.git/plain/xiphos-glibc.patch?h=xiphos&id=bb816f43ba764ffac1287ab1e2a649c2443e3ce8"; sha256 = "he3U7phU2/QCrZidHviupA7YwzudnQ9Jbb8eMZw6/ck="; extraPrefix = ""; @@ -89,7 +90,7 @@ stdenv.mkDerivation rec { "-DGTKHTML=ON" ]; - preConfigure = '' + preConfigure = '' # The build script won't continue without the version saved locally. echo "${version}" > cmake/source_version.txt diff --git a/pkgs/by-name/xi/xits-math/package.nix b/pkgs/by-name/xi/xits-math/package.nix index 9e3c013f44ded0..d997fad5d11fb4 100644 --- a/pkgs/by-name/xi/xits-math/package.nix +++ b/pkgs/by-name/xi/xits-math/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3Packages}: +{ + lib, + stdenv, + fetchFromGitHub, + python3Packages, +}: stdenv.mkDerivation rec { pname = "xits-math"; @@ -11,7 +16,14 @@ stdenv.mkDerivation rec { sha256 = "1x3r505dylz9rz8dj98h5n9d0zixyxmvvhnjnms9qxdrz9bxy9g1"; }; - nativeBuildInputs = (with python3Packages; [ python fonttools fontforge ]); + nativeBuildInputs = ( + with python3Packages; + [ + python + fonttools + fontforge + ] + ); postPatch = '' rm *.otf diff --git a/pkgs/by-name/xi/xiu/package.nix b/pkgs/by-name/xi/xiu/package.nix index fe5ab564e9f71a..2d24acd34efb48 100644 --- a/pkgs/by-name/xi/xiu/package.nix +++ b/pkgs/by-name/xi/xiu/package.nix @@ -1,12 +1,13 @@ -{ lib -, cmake -, darwin -, fetchFromGitHub -, libopus -, openssl -, pkg-config -, rustPlatform -, stdenv +{ + lib, + cmake, + darwin, + fetchFromGitHub, + libopus, + openssl, + pkg-config, + rustPlatform, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -27,13 +28,16 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - libopus - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + libopus + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.SystemConfiguration + ]; OPENSSL_NO_VENDOR = 1; diff --git a/pkgs/by-name/xi/xivlauncher/deps.nix b/pkgs/by-name/xi/xivlauncher/deps.nix index fa65ff3a7d1f35..b15c62316984b2 100644 --- a/pkgs/by-name/xi/xivlauncher/deps.nix +++ b/pkgs/by-name/xi/xivlauncher/deps.nix @@ -1,233 +1,1146 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Castle.Core"; version = "4.4.1"; sha256 = "13dja1jxl5zwhi0ghkgvgmqdrixn57f9hk52jy5vpaaakzr550r7"; }) - (fetchNuGet { pname = "CheapLoc"; version = "1.1.6"; sha256 = "1m6cgx9yh7h3vrq2d4f99xyvsxc9jvz8zjq1q14qgylfmyq4hx4l"; }) - (fetchNuGet { pname = "CommandLineParser"; version = "2.9.1"; sha256 = "1sldkj8lakggn4hnyabjj1fppqh50fkdrr1k99d4gswpbk5kv582"; }) - (fetchNuGet { pname = "Config.Net"; version = "4.19.0"; sha256 = "17iv0vy0693s6d8626lbz3w1ppn5abn77aaki7h4qi4izysizgim"; }) - (fetchNuGet { pname = "Downloader"; version = "2.2.8"; sha256 = "0farwh3pc6m8hsgqywigdpcb4gr2m9myyxm2idzjmhhkzfqghj28"; }) - (fetchNuGet { pname = "goaaats.Steamworks"; version = "2.3.4"; sha256 = "1khxkkjvh6af60rxc13bacxn85amdfzr8z0b9a6gfg6m1fnmlkss"; }) - (fetchNuGet { pname = "ImGui.NET"; version = "1.87.2"; sha256 = "0rv0n18fvz1gbh45crhzn1f8xw8zkc8qyiyj91vajjcry8mq1x7q"; }) - (fetchNuGet { pname = "KeySharp"; version = "1.0.5"; sha256 = "1ic10v0a174fw6w89iyg4yzji36bsj15573y676cj5n09n6s75d4"; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "6.0.0"; sha256 = "15gqy2m14fdlvy1g59207h5kisznm355kbw010gy19vh47z8gpz3"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.3.3"; sha256 = "09m4cpry8ivm9ga1abrxmvw16sslxhy2k5sl14zckhqb1j164im6"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.BannedApiAnalyzers"; version = "3.3.3"; sha256 = "1z6x0d8lpcfjr3sxy25493i17vvcg5bsay6c03qan6mnj5aqzw2k"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "4.0.1"; sha256 = "0axjv1nhk1z9d4c51d9yxdp09l8yqqnqaifhqcwnxnv0r4y5cka9"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "4.0.1"; sha256 = "1h6jfifg7pw2vacpdds4v4jqnaydg9b108irf315wzx6rh8yv9cb"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.NetAnalyzers"; version = "6.0.0"; sha256 = "06zy947m5lrbwb684g42ijb07r5jsqycvfnphc6cqfdrfnzqv6k9"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.NetAnalyzers"; version = "7.0.0"; sha256 = "1rl5zi8s213g70nvqfacf50ff8vqvaj8i7jxv0gjw2hkz73dg4h1"; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.0.1"; sha256 = "0zxc0apx1gcx361jlq8smc9pfdgmyjh6hpka8dypc9w23nlsh6yj"; }) - (fetchNuGet { pname = "Microsoft.DotNet.PlatformAbstractions"; version = "2.0.3"; sha256 = "020214swxm0hip1d9gjskrzmqzjnji7c6l5b3xcch8vp166066m9"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyModel"; version = "2.0.3"; sha256 = "0dpyjp0hy9kkvk2dd4dclfmb10yq5avsw2a6v8nra9g6ii2p1nla"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.0.1"; sha256 = "01al6cfxp68dscl15z7rxfw9zvhm64dncsw09a1vmdkacsa2v6lr"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.0.1"; sha256 = "0ppdkwy6s9p7x9jix3v4402wb171cdiibq7js7i13nxpdky7074p"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.3.0"; sha256 = "0j0c1wj4ndj21zsgivsc24whiya605603kxrbiw6wkfdync464wq"; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "6.0.0-preview.5.21301.5"; sha256 = "02712s86n2i8s5j6vxdayqwcc7r538yw3frhf1gfrc6ah6hvqnzc"; }) - (fetchNuGet { pname = "Microsoft.Win32.SystemEvents"; version = "6.0.0"; sha256 = "0c6pcj088g1yd1vs529q3ybgsd2vjlk5y1ic6dkmbhvrp5jibl9p"; }) - (fetchNuGet { pname = "Mono.Cecil"; version = "0.9.6.1"; sha256 = "1fr7969h5q611l5227xw6nvv5rzap76vbpk0wg9hxbcxk3hn7szf"; }) - (fetchNuGet { pname = "NativeLibraryLoader"; version = "1.0.13"; sha256 = "18vi5gpa243jvz8cixyhbbrccj4js5sc8g4gy10ldjy50szrpnqh"; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "1.6.1"; sha256 = "1z70wvsx2d847a2cjfii7b83pjfs34q05gb037fdjikv5kbagml8"; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; sha256 = "1fn9fxppfcg4jgypp2pmrpr6awl3qz1xmnri0cygpkwvyx27df1y"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "12.0.2"; sha256 = "0w2fbji1smd2y7x25qqibf1qrznmv4s6s0jvrbvr6alb7mfyqvh5"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "9.0.1"; sha256 = "0mcy0i7pnfpqm4pcaiyzzji4g0c8i3a5gjz28rrr28110np8304r"; }) - (fetchNuGet { pname = "PInvoke.Kernel32"; version = "0.7.124"; sha256 = "0n1245s2p5735n8xgmahrx7g8mw32pxdn4rr9dydb9r6mvgm9bhk"; }) - (fetchNuGet { pname = "PInvoke.Windows.Core"; version = "0.7.124"; sha256 = "16qkn91gh3aiab2330q5j1vlx2ni4m4kkz04dvsqlm8lr7ldizlz"; }) - (fetchNuGet { pname = "PolySharp"; version = "1.10.0"; sha256 = "06qici3hhk6a0jmy0nyvspcnmhbapnic6iin3i28pkdvrii02hnz"; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tools"; version = "4.3.0"; sha256 = "1wl76vk12zhdh66vmagni66h5xbhgqq7zkdpgw21jhxhvlbcl8pk"; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tracing"; version = "4.3.0"; sha256 = "00j6nv2xgmd3bi347k00m7wr542wjlig53rmj28pmw7ddcn97jbn"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization.Calendars"; version = "4.3.0"; sha256 = "1ghhhk5psqxcg6w88sxkqrc35bxcz27zbqm2y5p5298pv3v7g201"; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Extensions"; version = "4.3.0"; sha256 = "0zyri97dfc5vyaz9ba65hjj1zbcrzaffhsdlpxc9bh09wy22fq33"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Timer"; version = "4.3.0"; sha256 = "0aw4phrhwqz9m61r79vyfl5la64bjxj8l34qnrcwb28v49fg2086"; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "16rnxzpk5dpbbl1x354yrlsbvwylrq456xzpsha1n9y3glnhyx9d"; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0hkg03sgm2wyq8nqk6dbm9jh5vcq57ry42lkqdmfklrw89lsmr59"; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0c2p354hjx58xhhz7wv6div8xpi90sc6ibdm40qin21bvi7ymcaa"; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.0.0"; sha256 = "1ppk69xk59ggacj9n7g6fyxvzmk1g5p4fkijm0d7xqfkig98qrkf"; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; }) - (fetchNuGet { pname = "runtime.native.System.IO.Compression"; version = "4.3.0"; sha256 = "1vvivbqsk6y4hzcid27pqpm5bsi6sc50hvqwbcx8aap5ifrxfs8d"; }) - (fetchNuGet { pname = "runtime.native.System.Net.Http"; version = "4.3.0"; sha256 = "1n6rgz5132lcibbch1qlf0g9jk60r0kqv087hxc0lisy50zpm7kk"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; sha256 = "1b61p6gw1m02cc1ry996fl49liiwky6181dzr873g9ds92zl326q"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "18pzfdlwsg2nb1jjjjzyb5qlgy6xjxzmhnfaijq5s2jw3cm3ab97"; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0qyynf9nz5i7pc26cwhgi8j62ps27sqmf78ijcfgzab50z9g8ay3"; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "1klrs545awhayryma6l7g2pvnp9xy4z0r1i40r80zb45q3i9nbyf"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; sha256 = "10yc8jdrwgcl44b4g93f1ds76b176bajd3zqi2faf5rvh1vy9smi"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0zcxjv5pckplvkg0r6mw3asggm7aqzbdjimhvsasb0cgm59x09l3"; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0vhynn79ih7hw7cwjazn87rm9z9fj0rvxgzlab36jybgcpcgphsn"; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "160p68l2c7cqmyqjwxydcvgw7lvl1cr0znkw8fp24d1by9mqc8p3"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "15zrc8fgd8zx28hdghcj5f5i34wf3l6bq5177075m2bc2j34jrqy"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "1p4dgxax6p7rlgj4q73k73rslcnz4wdcv8q2flg1s8ygwcm58ld5"; }) - (fetchNuGet { pname = "runtime.unix.Microsoft.Win32.Primitives"; version = "4.3.0"; sha256 = "0y61k9zbxhdi0glg154v30kkq7f8646nif8lnnxbvkjpakggd5id"; }) - (fetchNuGet { pname = "runtime.unix.System.Console"; version = "4.3.0"; sha256 = "1pfpkvc6x2if8zbdzg9rnc5fx51yllprl8zkm5npni2k50lisy80"; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; }) - (fetchNuGet { pname = "runtime.unix.System.IO.FileSystem"; version = "4.3.0"; sha256 = "14nbkhvs7sji5r1saj2x8daz82rnf9kx28d3v2qss34qbr32dzix"; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Primitives"; version = "4.3.0"; sha256 = "0bdnglg59pzx9394sy4ic66kmxhqp8q8bvmykdxcbs5mm0ipwwm4"; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Sockets"; version = "4.3.0"; sha256 = "03npdxzy8gfv035bv1b9rz7c7hv0rxl5904wjz51if491mw0xy12"; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; }) - (fetchNuGet { pname = "Serilog"; version = "2.12.0"; sha256 = "0lqxpc96qcjkv9pr1rln7mi4y7n7jdi4vb36c2fv3845w1vswgr4"; }) - (fetchNuGet { pname = "Serilog.Enrichers.Sensitive"; version = "1.7.2"; sha256 = "1f3r4jrfiz47vnvy7m0w6d8280nhhna67xwbagx1i557m9qvjssg"; }) - (fetchNuGet { pname = "Serilog.Enrichers.Thread"; version = "3.1.0"; sha256 = "1y75aiv2k1sxnh012ixkx92fq1yl8srqggy8l439igg4p223hcqi"; }) - (fetchNuGet { pname = "Serilog.Sinks.Async"; version = "1.5.0"; sha256 = "0bcb3n6lmg5wfj806mziybfmbb8gyiszrivs3swf0msy8w505gyg"; }) - (fetchNuGet { pname = "Serilog.Sinks.Console"; version = "3.1.1"; sha256 = "0j99as641y1k6havwwkhyr0n08vibiblmfjj6nz051mz8g3864fn"; }) - (fetchNuGet { pname = "Serilog.Sinks.Console"; version = "4.0.1"; sha256 = "080vh9kcyn9lx4j7p34146kp9byvhqlaz5jn9wzx70ql9cwd0hlz"; }) - (fetchNuGet { pname = "Serilog.Sinks.Debug"; version = "1.0.1"; sha256 = "0969mb254kr59bgkq01ybyzca89z3f4n9ng5mdj8m53d5653zf22"; }) - (fetchNuGet { pname = "Serilog.Sinks.File"; version = "5.0.0"; sha256 = "097rngmgcrdfy7jy8j7dq3xaq2qky8ijwg0ws6bfv5lx0f3vvb0q"; }) - (fetchNuGet { pname = "SharedMemory"; version = "2.3.2"; sha256 = "078qaab0j8p2fjcc9n7r4sr5pr7567a9bspfiikkc85bsx7vfm8w"; }) - (fetchNuGet { pname = "SharpGen.Runtime"; version = "2.0.0-beta.13"; sha256 = "1250z6sa9ghf84czlkzvaysb29c0n229z1f0vh5qls89akrkl7h8"; }) - (fetchNuGet { pname = "SharpGen.Runtime.COM"; version = "2.0.0-beta.13"; sha256 = "1lmv3jp2g7mgy9j23pd3j0wr3p89qiq8v6c6qxqf688izyni1166"; }) - (fetchNuGet { pname = "SixLabors.ImageSharp"; version = "1.0.4"; sha256 = "0fmgn414my76gjgp89qlc210a0lqvnvkvk2fcwnpwxdhqpfvyilr"; }) - (fetchNuGet { pname = "System.AppContext"; version = "4.1.0"; sha256 = "0fv3cma1jp4vgj7a8hqc9n7hr1f1kjp541s6z0q1r6nazb4iz9mz"; }) - (fetchNuGet { pname = "System.AppContext"; version = "4.3.0"; sha256 = "1649qvy3dar900z3g817h17nl8jp4ka5vcfmsr05kh0fshn7j3ya"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.3.0"; sha256 = "0fgns20ispwrfqll4q1zc1waqcmylb3zc50ys9x8zlwxh9pmd9jy"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.4.0"; sha256 = "183f8063w8zqn99pv0ni0nnwh7fgx46qzxamwnans55hhs2l0g19"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.0.11"; sha256 = "1ga40f5lrwldiyw6vy67d0sg7jd7ww6kgwbksm19wrvq9hr0bsm6"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.3.0"; sha256 = "0wi10md9aq33jrkh2c24wr2n9hrpyamsdhsxdcnf43b7y86kkii8"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "5.0.0"; sha256 = "1kvcllagxz2q92g81zkz81djkn2lid25ayjfgjalncyc68i15p0r"; }) - (fetchNuGet { pname = "System.Collections.NonGeneric"; version = "4.3.0"; sha256 = "07q3k0hf3mrcjzwj8fwk6gv3n51cb513w4mgkfxzm3i37sc9kz7k"; }) - (fetchNuGet { pname = "System.Collections.Specialized"; version = "4.3.0"; sha256 = "1sdwkma4f6j85m3dpb53v9vcgd0zyc9jb33f8g63byvijcj39n20"; }) - (fetchNuGet { pname = "System.ComponentModel"; version = "4.3.0"; sha256 = "0986b10ww3nshy30x9sjyzm0jx339dkjxjj3401r3q0f6fx2wkcb"; }) - (fetchNuGet { pname = "System.ComponentModel.Primitives"; version = "4.3.0"; sha256 = "1svfmcmgs0w0z9xdw2f2ps05rdxmkxxhf0l17xk9l1l8xfahkqr0"; }) - (fetchNuGet { pname = "System.ComponentModel.TypeConverter"; version = "4.3.0"; sha256 = "17ng0p7v3nbrg3kycz10aqrrlw4lz9hzhws09pfh8gkwicyy481x"; }) - (fetchNuGet { pname = "System.Configuration.ConfigurationManager"; version = "6.0.0"; sha256 = "0sqapr697jbb4ljkq46msg0xx1qpmc31ivva6llyz2wzq3mpmxbw"; }) - (fetchNuGet { pname = "System.Console"; version = "4.3.0"; sha256 = "1flr7a9x920mr5cjsqmsy9wgnv3lvd0h1g521pdr1lkb2qycy7ay"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.0.11"; sha256 = "0gmjghrqmlgzxivd2xl50ncbglb7ljzb66rlx8ws6dv8jm0d5siz"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "4.3.0"; sha256 = "0z6m3pbiy0qw6rn3n209rrzf9x1k4002zh90vwcrsym09ipm2liq"; }) - (fetchNuGet { pname = "System.Diagnostics.Tools"; version = "4.0.1"; sha256 = "19cknvg07yhakcvpxg3cxa0bwadplin6kyxd8mpjjpwnp56nl85x"; }) - (fetchNuGet { pname = "System.Diagnostics.Tools"; version = "4.3.0"; sha256 = "0in3pic3s2ddyibi8cvgl102zmvp9r9mchh82ns9f0ms4basylw1"; }) - (fetchNuGet { pname = "System.Diagnostics.TraceSource"; version = "4.3.0"; sha256 = "1kyw4d7dpjczhw6634nrmg7yyyzq72k75x38y0l0nwhigdlp1766"; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; sha256 = "1m3bx6c2s958qligl67q7grkwfz3w53hpy7nc97mh6f7j5k168c4"; }) - (fetchNuGet { pname = "System.Drawing.Common"; version = "6.0.0"; sha256 = "02n8rzm58dac2np8b3xw8ychbvylja4nh6938l5k2fhyn40imlgz"; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.0.11"; sha256 = "1pla2dx8gkidf7xkciig6nifdsb494axjvzvann8g2lp3dbqasm9"; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.3.0"; sha256 = "1d951hrvrpndk7insiag80qxjbf2y0y39y8h5hnq9612ws661glk"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.0.11"; sha256 = "070c5jbas2v7smm660zaf1gh0489xanjqymkvafcs4f8cdrs1d5d"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.3.0"; sha256 = "1xwl230bkakzzkrggy1l1lxmm3xlhk4bq2pkv790j5lm8g887lxq"; }) - (fetchNuGet { pname = "System.Globalization.Extensions"; version = "4.3.0"; sha256 = "02a5zfxavhv3jd437bsncbhd2fp1zv4gxzakp1an9l6kdq1mcqls"; }) - (fetchNuGet { pname = "System.IO"; version = "4.1.0"; sha256 = "1g0yb8p11vfd0kbkyzlfsbsp5z44lwsvyc0h3dpw6vqnbi035ajp"; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; }) - (fetchNuGet { pname = "System.IO.Compression"; version = "4.3.0"; sha256 = "084zc82yi6yllgda0zkgl2ys48sypiswbiwrv7irb3r0ai1fp4vz"; }) - (fetchNuGet { pname = "System.IO.Compression.ZipFile"; version = "4.3.0"; sha256 = "1yxy5pq4dnsm9hlkg9ysh5f6bf3fahqqb6p8668ndy5c0lk7w2ar"; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.0.1"; sha256 = "0kgfpw6w4djqra3w5crrg8xivbanh1w9dh3qapb28q060wb9flp1"; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; sha256 = "0z2dfrbra9i6y16mm9v1v6k47f0fm617vlb7s5iybjjsz6g1ilmw"; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.0.1"; sha256 = "1s0mniajj3lvbyf7vfb5shp4ink5yibsx945k6lvxa96r8la1612"; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; }) - (fetchNuGet { pname = "System.Linq"; version = "4.1.0"; sha256 = "1ppg83svb39hj4hpp5k7kcryzrf3sfnm08vxd5sm2drrijsla2k5"; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.1.0"; sha256 = "1gpdxl6ip06cnab7n3zlcg6mqp7kknf73s8wjinzi4p0apw82fpg"; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.3.0"; sha256 = "0ky2nrcvh70rqq88m9a5yqabsl4fyd17bpr63iy2mbivjs2nyypv"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; }) - (fetchNuGet { pname = "System.Net.Http"; version = "4.3.0"; sha256 = "1i4gc757xqrzflbk7kc5ksn20kwwfjhw9w7pgdkn19y3cgnl302j"; }) - (fetchNuGet { pname = "System.Net.NameResolution"; version = "4.3.0"; sha256 = "15r75pwc0rm3vvwsn8rvm2krf929mjfwliv0mpicjnii24470rkq"; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.3.0"; sha256 = "0c87k50rmdgmxx7df2khd9qj7q35j9rzdmm2572cc55dygmdk3ii"; }) - (fetchNuGet { pname = "System.Net.Sockets"; version = "4.3.0"; sha256 = "1ssa65k6chcgi6mfmzrznvqaxk8jp0gvl77xhf1hbzakjnpxspla"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.4.0"; sha256 = "0rdvma399070b0i46c4qq1h2yvjj3k013sqzkilz4bz5cwmx1rba"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; sha256 = "1kzrj37yzawf1b19jq0253rcs8hsq1l2q8g69d7ipnhzb0h97m59"; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.0.12"; sha256 = "1sybkfi60a4588xn34nd9a58png36i0xr4y4v4kqpg8wlvy5krrj"; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.3.0"; sha256 = "191p63zy5rpqx7dnrb3h7prvgixmk168fhvvkkvhlazncf8r3nc2"; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.1.0"; sha256 = "1js89429pfw79mxvbzp8p3q93il6rdff332hddhzi5wqglc4gml9"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.0.1"; sha256 = "0ydqcsvh6smi41gyaakglnv252625hf29f7kywy2c70nhii2ylqp"; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.3.0"; sha256 = "11f8y3qfysfcrscjpjym9msk7lsfxkk4fmz9qq95kn3jd0769f74"; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.0.1"; sha256 = "1pcd2ig6bg144y10w7yxgc9d22r7c7ww7qn1frdfwgxr24j9wvv0"; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.3.0"; sha256 = "0w1n67glpv8241vnpz1kl14sy7zlnw414aqwj4hcx5nd86f6994q"; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.7.0"; sha256 = "0l8jpxhpgjlf1nkz5lvp61r4kfdbhr29qi8aapcxn3izd9wd0j8r"; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.0.1"; sha256 = "1s4b043zdbx9k39lfhvsk68msv1nxbidhkq6nbm27q7sf8xcsnxr"; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.3.0"; sha256 = "0ql7lcakycrvzgi9kxz1b3lljd990az1x6c4jsiwcacrvimpib5c"; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.7.0"; sha256 = "0mbjfajmafkca47zr8v36brvknzks5a7pgb49kfq2d188pyv6iap"; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.0.1"; sha256 = "0m7wqwq0zqq9gbpiqvgk3sr92cbrw7cp3xn53xvw7zj6rz6fdirn"; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.3.0"; sha256 = "02bly8bdc98gs22lqsfx9xicblszr2yan7v2mmw3g7hy6miq5hwq"; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "5.0.0"; sha256 = "17qsl5nanlqk9iz0l5wijdn6ka632fs1m1fvx18dfgswm258r3ss"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.0.1"; sha256 = "1bangaabhsl4k9fg8khn83wm6yial8ik1sza7401621jc6jrym28"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.1.0"; sha256 = "1bjli8a7sc7jlxqgcagl9nh8axzfl11f4ld3rjqsyxc516iijij7"; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.3.0"; sha256 = "0y2ssg08d817p0vdag98vn238gyrrynjdj4181hdg780sif3ykp1"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.0.1"; sha256 = "0b4i7mncaf8cnai85jv3wnw6hps140cxz8vylv2bik6wyzgvz7bi"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.1.0"; sha256 = "02hdkgk13rvsd6r9yafbwzss8kr55wnj8d5c7xjnp8gqrwc8sn0m"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.4.0"; sha256 = "0a6ahgi5b148sl5qyfpyw383p3cb4yrkm802k29fsi4mxkiwir29"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.0"; sha256 = "17labczwqk3jng3kkky73m0jhi8wc21vbl7cz5c0hj2p1dswin43"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.3"; sha256 = "1afi6s2r1mh1kygbjmfba6l4f87pi5sg13p4a48idqafli94qxln"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "5.0.0"; sha256 = "02k25ivn50dmqx5jn8hawwmz24yf0454fjd823qk6lygj9513q4x"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.1.0"; sha256 = "0rw4rm4vsm3h3szxp9iijc3ksyviwsv6f63dng3vhqyg4vjdkc2z"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.0.1"; sha256 = "1g0zrdi5508v49pfm3iii2hn6nm00bgvfpjq1zxknfjrxxa20r4g"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.1.0"; sha256 = "01kxqppx3dr3b6b286xafqilv4s2n0gqvfgzfd4z943ga9i81is1"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices.RuntimeInformation"; version = "4.0.0"; sha256 = "0glmvarf3jz5xh22iy3w9v3wyragcm4hfdr17v90vs7vcrm7fgp6"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices.RuntimeInformation"; version = "4.3.0"; sha256 = "0q18r1sh4vn7bvqgd6dmqlw5v28flbpj349mkdish2vjyvmnb2ii"; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.3.0"; sha256 = "19rav39sr5dky7afygh309qamqqmi9kcwvz3i0c5700v0c5cg61z"; }) - (fetchNuGet { pname = "System.Runtime.Serialization.Primitives"; version = "4.1.1"; sha256 = "042rfjixknlr6r10vx2pgf56yming8lkjikamg3g4v29ikk78h7k"; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "6.0.0"; sha256 = "0a678bzj8yxxiffyzy60z2w1nczzpi8v97igr4ip3byd2q89dv58"; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "6.0.0-preview.5.21301.5"; sha256 = "131f3z3ikv3n8442chr11nj4x46amq00mb53pb2ds42dabldkdgy"; }) - (fetchNuGet { pname = "System.Security.Claims"; version = "4.3.0"; sha256 = "0jvfn7j22l3mm28qjy3rcw287y9h65ha4m940waaxah07jnbzrhn"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.3.0"; sha256 = "03sq183pfl5kp7gkvq77myv7kbpdnq3y0xj7vi4q1kaw54sny0ml"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.3.0"; sha256 = "1k468aswafdgf56ab6yrn7649kfqx2wm9aslywjam1hdmk5yypmv"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Csp"; version = "4.3.0"; sha256 = "1x5wcrddf2s3hb8j78cry7yalca4lb5vfnkrysagbn6r9x6xvrx1"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.3.0"; sha256 = "1jr6w70igqn07k5zs1ph6xja97hxnb3mqbspdrff6cvssgrixs32"; }) - (fetchNuGet { pname = "System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0givpvvj8yc7gv4lhb6s1prq6p2c4147204a0wib89inqzd87gqc"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.3.0"; sha256 = "0pyzncsv48zwly3lw4f2dayqswcfvdwq2nz0dgwmi7fj3pn64wby"; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "6.0.0"; sha256 = "05kd3a8w7658hjxq9vvszxip30a479fjmfq4bq1r95nrsvs4hbss"; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.3.0"; sha256 = "0valjcz5wksbvijylxijjxb1mp38mdhv03r533vnx1q3ikzdav9h"; }) - (fetchNuGet { pname = "System.Security.Permissions"; version = "6.0.0"; sha256 = "0jsl4xdrkqi11iwmisi1r2f2qn5pbvl79mzq877gndw6ans2zhzw"; }) - (fetchNuGet { pname = "System.Security.Principal"; version = "4.3.0"; sha256 = "12cm2zws06z4lfc4dn31iqv7072zyi4m910d4r6wm8yx85arsfxf"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.3.0"; sha256 = "00a0a7c40i3v4cb20s2cmh9csb5jv2l0frvnlzyfxh848xalpdwr"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; sha256 = "1mpk7xj76lxgz97a5yg93wi8lj0l8p157a5d50mmjy3gbz1904q8"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "6.0.0-preview.5.21301.5"; sha256 = "1q3iikvjcfrm5p89p1j7qlw1szvryq680qypk023wgy9phmlwi57"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.0.11"; sha256 = "1dyqv0hijg265dwxg6l7aiv74102d6xjiwplh2ar1ly6xfaa4iiw"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "4.5.1"; sha256 = "1z21qyfs6sg76rp68qdx0c9iy57naan89pg7p6i3qpj8kyzn921w"; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.0.11"; sha256 = "08nsfrpiwsg9x5ml4xyl3zyvjfdi4mvbqf93kjdh11j4fwkznizs"; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "6.0.0"; sha256 = "06n9ql3fmhpjl32g3492sj181zjml5dlcc5l76xq2h38c4f87sai"; }) - (fetchNuGet { pname = "System.Text.Json"; version = "6.0.6"; sha256 = "0bkfrnr9618brbl1gvhyqrf5720syawf9dvpk8xfvkxbg7imlpjx"; }) - (fetchNuGet { pname = "System.Text.RegularExpressions"; version = "4.1.0"; sha256 = "1mw7vfkkyd04yn2fbhm38msk7dz2xwvib14ygjsb8dq2lcvr18y7"; }) - (fetchNuGet { pname = "System.Text.RegularExpressions"; version = "4.3.0"; sha256 = "1bgq51k7fwld0njylfn7qc5fmwrk2137gdq7djqdsw347paa9c2l"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.0.11"; sha256 = "19x946h926bzvbsgj28csn46gak2crv2skpwsx80hbgazmkgb1ls"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.0.11"; sha256 = "0nr1r41rak82qfa5m0lhk9mp0k93bvfd7bbd9sdzwx9mb36g28p5"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.0.0"; sha256 = "1cb51z062mvc2i8blpzmpn9d9mm4y307xrwi65di8ri18cz5r1zr"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.3.0"; sha256 = "1xxcx2xh8jin360yjwm4x4cf5y3a2bwpn2ygkfkwkicz7zk50s2z"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; sha256 = "0y6ncasgfcgnjrhynaf0lwpkpkmv4a07sswwkwbwb5h7riisj153"; }) - (fetchNuGet { pname = "System.Threading.ThreadPool"; version = "4.3.0"; sha256 = "027s1f4sbx0y1xqw2irqn6x161lzj8qwvnh2gn78ciiczdv10vf1"; }) - (fetchNuGet { pname = "System.Threading.Timer"; version = "4.3.0"; sha256 = "1nx773nsx6z5whv8kaa1wjh037id2f1cxhb69pvgv12hd2b6qs56"; }) - (fetchNuGet { pname = "System.Windows.Extensions"; version = "6.0.0"; sha256 = "1wy9pq9vn1bqg5qnv53iqrbx04yzdmjw4x5yyi09y3459vaa1sip"; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.0.11"; sha256 = "0c6ky1jk5ada9m94wcadih98l6k1fvf6vi7vhn1msjixaha419l5"; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.3.0"; sha256 = "0c47yllxifzmh8gq6rq6l36zzvw4kjvlszkqa9wq3fr59n0hl3s1"; }) - (fetchNuGet { pname = "System.Xml.XDocument"; version = "4.0.11"; sha256 = "0n4lvpqzy9kc7qy1a4acwwd7b7pnvygv895az5640idl2y9zbz18"; }) - (fetchNuGet { pname = "System.Xml.XDocument"; version = "4.3.0"; sha256 = "08h8fm4l77n0nd4i4fk2386y809bfbwqb7ih9d7564ifcxr5ssxd"; }) - (fetchNuGet { pname = "System.Xml.XmlDocument"; version = "4.3.0"; sha256 = "0bmz1l06dihx52jxjr22dyv5mxv6pj4852lx68grjm7bivhrbfwi"; }) - (fetchNuGet { pname = "Veldrid"; version = "4.9.0"; sha256 = "0l1sqz0jinw6d5rxhjaavckgmv1b8cc909crjjc9wvf7hp70gzmg"; }) - (fetchNuGet { pname = "Veldrid.ImageSharp"; version = "4.9.0"; sha256 = "0w1wvfhkf85c81chpcqlln41kzi2rk49pw6imyypqhpvsi1nw9n6"; }) - (fetchNuGet { pname = "Veldrid.MetalBindings"; version = "4.9.0"; sha256 = "1zd04q70fdlxsy045yk4pj499n8vl9qdcr86vj9wj4qq1jmd8pr3"; }) - (fetchNuGet { pname = "Veldrid.OpenGLBindings"; version = "4.9.0"; sha256 = "06cjfrzig75lms930861339v35y96n421236318pjad9jmwhac74"; }) - (fetchNuGet { pname = "Veldrid.SDL2"; version = "4.9.0"; sha256 = "0cm5jx24wvzk88mip68n34sfg7psdjiyng7pf01g67blz56rlzhl"; }) - (fetchNuGet { pname = "Veldrid.StartupUtilities"; version = "4.9.0"; sha256 = "10b62ni8ihbnb213rkpw38n1gpk0blli9cb8agihml7za41x3b4y"; }) - (fetchNuGet { pname = "Vk"; version = "1.0.25"; sha256 = "18kx3g088215803yznnmf6621wgwvgakj8hlmrb726b7zwb3x53l"; }) - (fetchNuGet { pname = "Vortice.D3DCompiler"; version = "2.3.0"; sha256 = "08an0z9xk6vqz2cdyhmbvvg7nzk7r1vcn0jp4c986s2sqk9jv5dj"; }) - (fetchNuGet { pname = "Vortice.Direct3D11"; version = "2.3.0"; sha256 = "05lgnkjslcsyrxg206cy9s33qlxj7cb3v47x4accp4p7f6v7k6lr"; }) - (fetchNuGet { pname = "Vortice.DirectX"; version = "2.3.0"; sha256 = "07inc3msd3baizx03is5djbw6jg9ihzx7dxvalsdz4n7b61lli3h"; }) - (fetchNuGet { pname = "Vortice.DXGI"; version = "2.3.0"; sha256 = "0j47ywcs1rq8q4hjj0axchjv08dnvyd33yy4nxilz4synyiidf77"; }) - (fetchNuGet { pname = "Vortice.Mathematics"; version = "1.4.25"; sha256 = "0vl6g087disxyzskvkbnwym74s47lkza0ly3nk4y0y88zibcggrj"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Castle.Core"; + version = "4.4.1"; + sha256 = "13dja1jxl5zwhi0ghkgvgmqdrixn57f9hk52jy5vpaaakzr550r7"; + }) + (fetchNuGet { + pname = "CheapLoc"; + version = "1.1.6"; + sha256 = "1m6cgx9yh7h3vrq2d4f99xyvsxc9jvz8zjq1q14qgylfmyq4hx4l"; + }) + (fetchNuGet { + pname = "CommandLineParser"; + version = "2.9.1"; + sha256 = "1sldkj8lakggn4hnyabjj1fppqh50fkdrr1k99d4gswpbk5kv582"; + }) + (fetchNuGet { + pname = "Config.Net"; + version = "4.19.0"; + sha256 = "17iv0vy0693s6d8626lbz3w1ppn5abn77aaki7h4qi4izysizgim"; + }) + (fetchNuGet { + pname = "Downloader"; + version = "2.2.8"; + sha256 = "0farwh3pc6m8hsgqywigdpcb4gr2m9myyxm2idzjmhhkzfqghj28"; + }) + (fetchNuGet { + pname = "goaaats.Steamworks"; + version = "2.3.4"; + sha256 = "1khxkkjvh6af60rxc13bacxn85amdfzr8z0b9a6gfg6m1fnmlkss"; + }) + (fetchNuGet { + pname = "ImGui.NET"; + version = "1.87.2"; + sha256 = "0rv0n18fvz1gbh45crhzn1f8xw8zkc8qyiyj91vajjcry8mq1x7q"; + }) + (fetchNuGet { + pname = "KeySharp"; + version = "1.0.5"; + sha256 = "1ic10v0a174fw6w89iyg4yzji36bsj15573y676cj5n09n6s75d4"; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "6.0.0"; + sha256 = "15gqy2m14fdlvy1g59207h5kisznm355kbw010gy19vh47z8gpz3"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.3.3"; + sha256 = "09m4cpry8ivm9ga1abrxmvw16sslxhy2k5sl14zckhqb1j164im6"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.BannedApiAnalyzers"; + version = "3.3.3"; + sha256 = "1z6x0d8lpcfjr3sxy25493i17vvcg5bsay6c03qan6mnj5aqzw2k"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "4.0.1"; + sha256 = "0axjv1nhk1z9d4c51d9yxdp09l8yqqnqaifhqcwnxnv0r4y5cka9"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "4.0.1"; + sha256 = "1h6jfifg7pw2vacpdds4v4jqnaydg9b108irf315wzx6rh8yv9cb"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.NetAnalyzers"; + version = "6.0.0"; + sha256 = "06zy947m5lrbwb684g42ijb07r5jsqycvfnphc6cqfdrfnzqv6k9"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.NetAnalyzers"; + version = "7.0.0"; + sha256 = "1rl5zi8s213g70nvqfacf50ff8vqvaj8i7jxv0gjw2hkz73dg4h1"; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.0.1"; + sha256 = "0zxc0apx1gcx361jlq8smc9pfdgmyjh6hpka8dypc9w23nlsh6yj"; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.PlatformAbstractions"; + version = "2.0.3"; + sha256 = "020214swxm0hip1d9gjskrzmqzjnji7c6l5b3xcch8vp166066m9"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyModel"; + version = "2.0.3"; + sha256 = "0dpyjp0hy9kkvk2dd4dclfmb10yq5avsw2a6v8nra9g6ii2p1nla"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.0.1"; + sha256 = "01al6cfxp68dscl15z7rxfw9zvhm64dncsw09a1vmdkacsa2v6lr"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.0.1"; + sha256 = "0ppdkwy6s9p7x9jix3v4402wb171cdiibq7js7i13nxpdky7074p"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.3.0"; + sha256 = "0j0c1wj4ndj21zsgivsc24whiya605603kxrbiw6wkfdync464wq"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "6.0.0-preview.5.21301.5"; + sha256 = "02712s86n2i8s5j6vxdayqwcc7r538yw3frhf1gfrc6ah6hvqnzc"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.SystemEvents"; + version = "6.0.0"; + sha256 = "0c6pcj088g1yd1vs529q3ybgsd2vjlk5y1ic6dkmbhvrp5jibl9p"; + }) + (fetchNuGet { + pname = "Mono.Cecil"; + version = "0.9.6.1"; + sha256 = "1fr7969h5q611l5227xw6nvv5rzap76vbpk0wg9hxbcxk3hn7szf"; + }) + (fetchNuGet { + pname = "NativeLibraryLoader"; + version = "1.0.13"; + sha256 = "18vi5gpa243jvz8cixyhbbrccj4js5sc8g4gy10ldjy50szrpnqh"; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "1.6.1"; + sha256 = "1z70wvsx2d847a2cjfii7b83pjfs34q05gb037fdjikv5kbagml8"; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + sha256 = "1fn9fxppfcg4jgypp2pmrpr6awl3qz1xmnri0cygpkwvyx27df1y"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "12.0.2"; + sha256 = "0w2fbji1smd2y7x25qqibf1qrznmv4s6s0jvrbvr6alb7mfyqvh5"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "9.0.1"; + sha256 = "0mcy0i7pnfpqm4pcaiyzzji4g0c8i3a5gjz28rrr28110np8304r"; + }) + (fetchNuGet { + pname = "PInvoke.Kernel32"; + version = "0.7.124"; + sha256 = "0n1245s2p5735n8xgmahrx7g8mw32pxdn4rr9dydb9r6mvgm9bhk"; + }) + (fetchNuGet { + pname = "PInvoke.Windows.Core"; + version = "0.7.124"; + sha256 = "16qkn91gh3aiab2330q5j1vlx2ni4m4kkz04dvsqlm8lr7ldizlz"; + }) + (fetchNuGet { + pname = "PolySharp"; + version = "1.10.0"; + sha256 = "06qici3hhk6a0jmy0nyvspcnmhbapnic6iin3i28pkdvrii02hnz"; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tools"; + version = "4.3.0"; + sha256 = "1wl76vk12zhdh66vmagni66h5xbhgqq7zkdpgw21jhxhvlbcl8pk"; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tracing"; + version = "4.3.0"; + sha256 = "00j6nv2xgmd3bi347k00m7wr542wjlig53rmj28pmw7ddcn97jbn"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization.Calendars"; + version = "4.3.0"; + sha256 = "1ghhhk5psqxcg6w88sxkqrc35bxcz27zbqm2y5p5298pv3v7g201"; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Extensions"; + version = "4.3.0"; + sha256 = "0zyri97dfc5vyaz9ba65hjj1zbcrzaffhsdlpxc9bh09wy22fq33"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Timer"; + version = "4.3.0"; + sha256 = "0aw4phrhwqz9m61r79vyfl5la64bjxj8l34qnrcwb28v49fg2086"; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "16rnxzpk5dpbbl1x354yrlsbvwylrq456xzpsha1n9y3glnhyx9d"; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0hkg03sgm2wyq8nqk6dbm9jh5vcq57ry42lkqdmfklrw89lsmr59"; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0c2p354hjx58xhhz7wv6div8xpi90sc6ibdm40qin21bvi7ymcaa"; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.0.0"; + sha256 = "1ppk69xk59ggacj9n7g6fyxvzmk1g5p4fkijm0d7xqfkig98qrkf"; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; + }) + (fetchNuGet { + pname = "runtime.native.System.IO.Compression"; + version = "4.3.0"; + sha256 = "1vvivbqsk6y4hzcid27pqpm5bsi6sc50hvqwbcx8aap5ifrxfs8d"; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Http"; + version = "4.3.0"; + sha256 = "1n6rgz5132lcibbch1qlf0g9jk60r0kqv087hxc0lisy50zpm7kk"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + sha256 = "1b61p6gw1m02cc1ry996fl49liiwky6181dzr873g9ds92zl326q"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "18pzfdlwsg2nb1jjjjzyb5qlgy6xjxzmhnfaijq5s2jw3cm3ab97"; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0qyynf9nz5i7pc26cwhgi8j62ps27sqmf78ijcfgzab50z9g8ay3"; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "1klrs545awhayryma6l7g2pvnp9xy4z0r1i40r80zb45q3i9nbyf"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + sha256 = "10yc8jdrwgcl44b4g93f1ds76b176bajd3zqi2faf5rvh1vy9smi"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0zcxjv5pckplvkg0r6mw3asggm7aqzbdjimhvsasb0cgm59x09l3"; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0vhynn79ih7hw7cwjazn87rm9z9fj0rvxgzlab36jybgcpcgphsn"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "160p68l2c7cqmyqjwxydcvgw7lvl1cr0znkw8fp24d1by9mqc8p3"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "15zrc8fgd8zx28hdghcj5f5i34wf3l6bq5177075m2bc2j34jrqy"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "1p4dgxax6p7rlgj4q73k73rslcnz4wdcv8q2flg1s8ygwcm58ld5"; + }) + (fetchNuGet { + pname = "runtime.unix.Microsoft.Win32.Primitives"; + version = "4.3.0"; + sha256 = "0y61k9zbxhdi0glg154v30kkq7f8646nif8lnnxbvkjpakggd5id"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Console"; + version = "4.3.0"; + sha256 = "1pfpkvc6x2if8zbdzg9rnc5fx51yllprl8zkm5npni2k50lisy80"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; + }) + (fetchNuGet { + pname = "runtime.unix.System.IO.FileSystem"; + version = "4.3.0"; + sha256 = "14nbkhvs7sji5r1saj2x8daz82rnf9kx28d3v2qss34qbr32dzix"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Primitives"; + version = "4.3.0"; + sha256 = "0bdnglg59pzx9394sy4ic66kmxhqp8q8bvmykdxcbs5mm0ipwwm4"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Sockets"; + version = "4.3.0"; + sha256 = "03npdxzy8gfv035bv1b9rz7c7hv0rxl5904wjz51if491mw0xy12"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; + }) + (fetchNuGet { + pname = "Serilog"; + version = "2.12.0"; + sha256 = "0lqxpc96qcjkv9pr1rln7mi4y7n7jdi4vb36c2fv3845w1vswgr4"; + }) + (fetchNuGet { + pname = "Serilog.Enrichers.Sensitive"; + version = "1.7.2"; + sha256 = "1f3r4jrfiz47vnvy7m0w6d8280nhhna67xwbagx1i557m9qvjssg"; + }) + (fetchNuGet { + pname = "Serilog.Enrichers.Thread"; + version = "3.1.0"; + sha256 = "1y75aiv2k1sxnh012ixkx92fq1yl8srqggy8l439igg4p223hcqi"; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Async"; + version = "1.5.0"; + sha256 = "0bcb3n6lmg5wfj806mziybfmbb8gyiszrivs3swf0msy8w505gyg"; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Console"; + version = "3.1.1"; + sha256 = "0j99as641y1k6havwwkhyr0n08vibiblmfjj6nz051mz8g3864fn"; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Console"; + version = "4.0.1"; + sha256 = "080vh9kcyn9lx4j7p34146kp9byvhqlaz5jn9wzx70ql9cwd0hlz"; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Debug"; + version = "1.0.1"; + sha256 = "0969mb254kr59bgkq01ybyzca89z3f4n9ng5mdj8m53d5653zf22"; + }) + (fetchNuGet { + pname = "Serilog.Sinks.File"; + version = "5.0.0"; + sha256 = "097rngmgcrdfy7jy8j7dq3xaq2qky8ijwg0ws6bfv5lx0f3vvb0q"; + }) + (fetchNuGet { + pname = "SharedMemory"; + version = "2.3.2"; + sha256 = "078qaab0j8p2fjcc9n7r4sr5pr7567a9bspfiikkc85bsx7vfm8w"; + }) + (fetchNuGet { + pname = "SharpGen.Runtime"; + version = "2.0.0-beta.13"; + sha256 = "1250z6sa9ghf84czlkzvaysb29c0n229z1f0vh5qls89akrkl7h8"; + }) + (fetchNuGet { + pname = "SharpGen.Runtime.COM"; + version = "2.0.0-beta.13"; + sha256 = "1lmv3jp2g7mgy9j23pd3j0wr3p89qiq8v6c6qxqf688izyni1166"; + }) + (fetchNuGet { + pname = "SixLabors.ImageSharp"; + version = "1.0.4"; + sha256 = "0fmgn414my76gjgp89qlc210a0lqvnvkvk2fcwnpwxdhqpfvyilr"; + }) + (fetchNuGet { + pname = "System.AppContext"; + version = "4.1.0"; + sha256 = "0fv3cma1jp4vgj7a8hqc9n7hr1f1kjp541s6z0q1r6nazb4iz9mz"; + }) + (fetchNuGet { + pname = "System.AppContext"; + version = "4.3.0"; + sha256 = "1649qvy3dar900z3g817h17nl8jp4ka5vcfmsr05kh0fshn7j3ya"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.3.0"; + sha256 = "0fgns20ispwrfqll4q1zc1waqcmylb3zc50ys9x8zlwxh9pmd9jy"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.4.0"; + sha256 = "183f8063w8zqn99pv0ni0nnwh7fgx46qzxamwnans55hhs2l0g19"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.0.11"; + sha256 = "1ga40f5lrwldiyw6vy67d0sg7jd7ww6kgwbksm19wrvq9hr0bsm6"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.3.0"; + sha256 = "0wi10md9aq33jrkh2c24wr2n9hrpyamsdhsxdcnf43b7y86kkii8"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "5.0.0"; + sha256 = "1kvcllagxz2q92g81zkz81djkn2lid25ayjfgjalncyc68i15p0r"; + }) + (fetchNuGet { + pname = "System.Collections.NonGeneric"; + version = "4.3.0"; + sha256 = "07q3k0hf3mrcjzwj8fwk6gv3n51cb513w4mgkfxzm3i37sc9kz7k"; + }) + (fetchNuGet { + pname = "System.Collections.Specialized"; + version = "4.3.0"; + sha256 = "1sdwkma4f6j85m3dpb53v9vcgd0zyc9jb33f8g63byvijcj39n20"; + }) + (fetchNuGet { + pname = "System.ComponentModel"; + version = "4.3.0"; + sha256 = "0986b10ww3nshy30x9sjyzm0jx339dkjxjj3401r3q0f6fx2wkcb"; + }) + (fetchNuGet { + pname = "System.ComponentModel.Primitives"; + version = "4.3.0"; + sha256 = "1svfmcmgs0w0z9xdw2f2ps05rdxmkxxhf0l17xk9l1l8xfahkqr0"; + }) + (fetchNuGet { + pname = "System.ComponentModel.TypeConverter"; + version = "4.3.0"; + sha256 = "17ng0p7v3nbrg3kycz10aqrrlw4lz9hzhws09pfh8gkwicyy481x"; + }) + (fetchNuGet { + pname = "System.Configuration.ConfigurationManager"; + version = "6.0.0"; + sha256 = "0sqapr697jbb4ljkq46msg0xx1qpmc31ivva6llyz2wzq3mpmxbw"; + }) + (fetchNuGet { + pname = "System.Console"; + version = "4.3.0"; + sha256 = "1flr7a9x920mr5cjsqmsy9wgnv3lvd0h1g521pdr1lkb2qycy7ay"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.0.11"; + sha256 = "0gmjghrqmlgzxivd2xl50ncbglb7ljzb66rlx8ws6dv8jm0d5siz"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "4.3.0"; + sha256 = "0z6m3pbiy0qw6rn3n209rrzf9x1k4002zh90vwcrsym09ipm2liq"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tools"; + version = "4.0.1"; + sha256 = "19cknvg07yhakcvpxg3cxa0bwadplin6kyxd8mpjjpwnp56nl85x"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tools"; + version = "4.3.0"; + sha256 = "0in3pic3s2ddyibi8cvgl102zmvp9r9mchh82ns9f0ms4basylw1"; + }) + (fetchNuGet { + pname = "System.Diagnostics.TraceSource"; + version = "4.3.0"; + sha256 = "1kyw4d7dpjczhw6634nrmg7yyyzq72k75x38y0l0nwhigdlp1766"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + sha256 = "1m3bx6c2s958qligl67q7grkwfz3w53hpy7nc97mh6f7j5k168c4"; + }) + (fetchNuGet { + pname = "System.Drawing.Common"; + version = "6.0.0"; + sha256 = "02n8rzm58dac2np8b3xw8ychbvylja4nh6938l5k2fhyn40imlgz"; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.0.11"; + sha256 = "1pla2dx8gkidf7xkciig6nifdsb494axjvzvann8g2lp3dbqasm9"; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.3.0"; + sha256 = "1d951hrvrpndk7insiag80qxjbf2y0y39y8h5hnq9612ws661glk"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.0.11"; + sha256 = "070c5jbas2v7smm660zaf1gh0489xanjqymkvafcs4f8cdrs1d5d"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.3.0"; + sha256 = "1xwl230bkakzzkrggy1l1lxmm3xlhk4bq2pkv790j5lm8g887lxq"; + }) + (fetchNuGet { + pname = "System.Globalization.Extensions"; + version = "4.3.0"; + sha256 = "02a5zfxavhv3jd437bsncbhd2fp1zv4gxzakp1an9l6kdq1mcqls"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.1.0"; + sha256 = "1g0yb8p11vfd0kbkyzlfsbsp5z44lwsvyc0h3dpw6vqnbi035ajp"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; + }) + (fetchNuGet { + pname = "System.IO.Compression"; + version = "4.3.0"; + sha256 = "084zc82yi6yllgda0zkgl2ys48sypiswbiwrv7irb3r0ai1fp4vz"; + }) + (fetchNuGet { + pname = "System.IO.Compression.ZipFile"; + version = "4.3.0"; + sha256 = "1yxy5pq4dnsm9hlkg9ysh5f6bf3fahqqb6p8668ndy5c0lk7w2ar"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.0.1"; + sha256 = "0kgfpw6w4djqra3w5crrg8xivbanh1w9dh3qapb28q060wb9flp1"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + sha256 = "0z2dfrbra9i6y16mm9v1v6k47f0fm617vlb7s5iybjjsz6g1ilmw"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.0.1"; + sha256 = "1s0mniajj3lvbyf7vfb5shp4ink5yibsx945k6lvxa96r8la1612"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.1.0"; + sha256 = "1ppg83svb39hj4hpp5k7kcryzrf3sfnm08vxd5sm2drrijsla2k5"; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.1.0"; + sha256 = "1gpdxl6ip06cnab7n3zlcg6mqp7kknf73s8wjinzi4p0apw82fpg"; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.3.0"; + sha256 = "0ky2nrcvh70rqq88m9a5yqabsl4fyd17bpr63iy2mbivjs2nyypv"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; + }) + (fetchNuGet { + pname = "System.Net.Http"; + version = "4.3.0"; + sha256 = "1i4gc757xqrzflbk7kc5ksn20kwwfjhw9w7pgdkn19y3cgnl302j"; + }) + (fetchNuGet { + pname = "System.Net.NameResolution"; + version = "4.3.0"; + sha256 = "15r75pwc0rm3vvwsn8rvm2krf929mjfwliv0mpicjnii24470rkq"; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.3.0"; + sha256 = "0c87k50rmdgmxx7df2khd9qj7q35j9rzdmm2572cc55dygmdk3ii"; + }) + (fetchNuGet { + pname = "System.Net.Sockets"; + version = "4.3.0"; + sha256 = "1ssa65k6chcgi6mfmzrznvqaxk8jp0gvl77xhf1hbzakjnpxspla"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.4.0"; + sha256 = "0rdvma399070b0i46c4qq1h2yvjj3k013sqzkilz4bz5cwmx1rba"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + sha256 = "1kzrj37yzawf1b19jq0253rcs8hsq1l2q8g69d7ipnhzb0h97m59"; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.0.12"; + sha256 = "1sybkfi60a4588xn34nd9a58png36i0xr4y4v4kqpg8wlvy5krrj"; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.3.0"; + sha256 = "191p63zy5rpqx7dnrb3h7prvgixmk168fhvvkkvhlazncf8r3nc2"; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.1.0"; + sha256 = "1js89429pfw79mxvbzp8p3q93il6rdff332hddhzi5wqglc4gml9"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.0.1"; + sha256 = "0ydqcsvh6smi41gyaakglnv252625hf29f7kywy2c70nhii2ylqp"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.3.0"; + sha256 = "11f8y3qfysfcrscjpjym9msk7lsfxkk4fmz9qq95kn3jd0769f74"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.0.1"; + sha256 = "1pcd2ig6bg144y10w7yxgc9d22r7c7ww7qn1frdfwgxr24j9wvv0"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.3.0"; + sha256 = "0w1n67glpv8241vnpz1kl14sy7zlnw414aqwj4hcx5nd86f6994q"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.7.0"; + sha256 = "0l8jpxhpgjlf1nkz5lvp61r4kfdbhr29qi8aapcxn3izd9wd0j8r"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.0.1"; + sha256 = "1s4b043zdbx9k39lfhvsk68msv1nxbidhkq6nbm27q7sf8xcsnxr"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.3.0"; + sha256 = "0ql7lcakycrvzgi9kxz1b3lljd990az1x6c4jsiwcacrvimpib5c"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.7.0"; + sha256 = "0mbjfajmafkca47zr8v36brvknzks5a7pgb49kfq2d188pyv6iap"; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.0.1"; + sha256 = "0m7wqwq0zqq9gbpiqvgk3sr92cbrw7cp3xn53xvw7zj6rz6fdirn"; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.3.0"; + sha256 = "02bly8bdc98gs22lqsfx9xicblszr2yan7v2mmw3g7hy6miq5hwq"; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "5.0.0"; + sha256 = "17qsl5nanlqk9iz0l5wijdn6ka632fs1m1fvx18dfgswm258r3ss"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.0.1"; + sha256 = "1bangaabhsl4k9fg8khn83wm6yial8ik1sza7401621jc6jrym28"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.1.0"; + sha256 = "1bjli8a7sc7jlxqgcagl9nh8axzfl11f4ld3rjqsyxc516iijij7"; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.3.0"; + sha256 = "0y2ssg08d817p0vdag98vn238gyrrynjdj4181hdg780sif3ykp1"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.0.1"; + sha256 = "0b4i7mncaf8cnai85jv3wnw6hps140cxz8vylv2bik6wyzgvz7bi"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.1.0"; + sha256 = "02hdkgk13rvsd6r9yafbwzss8kr55wnj8d5c7xjnp8gqrwc8sn0m"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.4.0"; + sha256 = "0a6ahgi5b148sl5qyfpyw383p3cb4yrkm802k29fsi4mxkiwir29"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.0"; + sha256 = "17labczwqk3jng3kkky73m0jhi8wc21vbl7cz5c0hj2p1dswin43"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.3"; + sha256 = "1afi6s2r1mh1kygbjmfba6l4f87pi5sg13p4a48idqafli94qxln"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "5.0.0"; + sha256 = "02k25ivn50dmqx5jn8hawwmz24yf0454fjd823qk6lygj9513q4x"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.1.0"; + sha256 = "0rw4rm4vsm3h3szxp9iijc3ksyviwsv6f63dng3vhqyg4vjdkc2z"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.0.1"; + sha256 = "1g0zrdi5508v49pfm3iii2hn6nm00bgvfpjq1zxknfjrxxa20r4g"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.1.0"; + sha256 = "01kxqppx3dr3b6b286xafqilv4s2n0gqvfgzfd4z943ga9i81is1"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices.RuntimeInformation"; + version = "4.0.0"; + sha256 = "0glmvarf3jz5xh22iy3w9v3wyragcm4hfdr17v90vs7vcrm7fgp6"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices.RuntimeInformation"; + version = "4.3.0"; + sha256 = "0q18r1sh4vn7bvqgd6dmqlw5v28flbpj349mkdish2vjyvmnb2ii"; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.3.0"; + sha256 = "19rav39sr5dky7afygh309qamqqmi9kcwvz3i0c5700v0c5cg61z"; + }) + (fetchNuGet { + pname = "System.Runtime.Serialization.Primitives"; + version = "4.1.1"; + sha256 = "042rfjixknlr6r10vx2pgf56yming8lkjikamg3g4v29ikk78h7k"; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "6.0.0"; + sha256 = "0a678bzj8yxxiffyzy60z2w1nczzpi8v97igr4ip3byd2q89dv58"; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "6.0.0-preview.5.21301.5"; + sha256 = "131f3z3ikv3n8442chr11nj4x46amq00mb53pb2ds42dabldkdgy"; + }) + (fetchNuGet { + pname = "System.Security.Claims"; + version = "4.3.0"; + sha256 = "0jvfn7j22l3mm28qjy3rcw287y9h65ha4m940waaxah07jnbzrhn"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.3.0"; + sha256 = "03sq183pfl5kp7gkvq77myv7kbpdnq3y0xj7vi4q1kaw54sny0ml"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.3.0"; + sha256 = "1k468aswafdgf56ab6yrn7649kfqx2wm9aslywjam1hdmk5yypmv"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Csp"; + version = "4.3.0"; + sha256 = "1x5wcrddf2s3hb8j78cry7yalca4lb5vfnkrysagbn6r9x6xvrx1"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.3.0"; + sha256 = "1jr6w70igqn07k5zs1ph6xja97hxnb3mqbspdrff6cvssgrixs32"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0givpvvj8yc7gv4lhb6s1prq6p2c4147204a0wib89inqzd87gqc"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.3.0"; + sha256 = "0pyzncsv48zwly3lw4f2dayqswcfvdwq2nz0dgwmi7fj3pn64wby"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "6.0.0"; + sha256 = "05kd3a8w7658hjxq9vvszxip30a479fjmfq4bq1r95nrsvs4hbss"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.3.0"; + sha256 = "0valjcz5wksbvijylxijjxb1mp38mdhv03r533vnx1q3ikzdav9h"; + }) + (fetchNuGet { + pname = "System.Security.Permissions"; + version = "6.0.0"; + sha256 = "0jsl4xdrkqi11iwmisi1r2f2qn5pbvl79mzq877gndw6ans2zhzw"; + }) + (fetchNuGet { + pname = "System.Security.Principal"; + version = "4.3.0"; + sha256 = "12cm2zws06z4lfc4dn31iqv7072zyi4m910d4r6wm8yx85arsfxf"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.3.0"; + sha256 = "00a0a7c40i3v4cb20s2cmh9csb5jv2l0frvnlzyfxh848xalpdwr"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + sha256 = "1mpk7xj76lxgz97a5yg93wi8lj0l8p157a5d50mmjy3gbz1904q8"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "6.0.0-preview.5.21301.5"; + sha256 = "1q3iikvjcfrm5p89p1j7qlw1szvryq680qypk023wgy9phmlwi57"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.0.11"; + sha256 = "1dyqv0hijg265dwxg6l7aiv74102d6xjiwplh2ar1ly6xfaa4iiw"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "4.5.1"; + sha256 = "1z21qyfs6sg76rp68qdx0c9iy57naan89pg7p6i3qpj8kyzn921w"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.0.11"; + sha256 = "08nsfrpiwsg9x5ml4xyl3zyvjfdi4mvbqf93kjdh11j4fwkznizs"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "6.0.0"; + sha256 = "06n9ql3fmhpjl32g3492sj181zjml5dlcc5l76xq2h38c4f87sai"; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "6.0.6"; + sha256 = "0bkfrnr9618brbl1gvhyqrf5720syawf9dvpk8xfvkxbg7imlpjx"; + }) + (fetchNuGet { + pname = "System.Text.RegularExpressions"; + version = "4.1.0"; + sha256 = "1mw7vfkkyd04yn2fbhm38msk7dz2xwvib14ygjsb8dq2lcvr18y7"; + }) + (fetchNuGet { + pname = "System.Text.RegularExpressions"; + version = "4.3.0"; + sha256 = "1bgq51k7fwld0njylfn7qc5fmwrk2137gdq7djqdsw347paa9c2l"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.0.11"; + sha256 = "19x946h926bzvbsgj28csn46gak2crv2skpwsx80hbgazmkgb1ls"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.0.11"; + sha256 = "0nr1r41rak82qfa5m0lhk9mp0k93bvfd7bbd9sdzwx9mb36g28p5"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.0.0"; + sha256 = "1cb51z062mvc2i8blpzmpn9d9mm4y307xrwi65di8ri18cz5r1zr"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.3.0"; + sha256 = "1xxcx2xh8jin360yjwm4x4cf5y3a2bwpn2ygkfkwkicz7zk50s2z"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + sha256 = "0y6ncasgfcgnjrhynaf0lwpkpkmv4a07sswwkwbwb5h7riisj153"; + }) + (fetchNuGet { + pname = "System.Threading.ThreadPool"; + version = "4.3.0"; + sha256 = "027s1f4sbx0y1xqw2irqn6x161lzj8qwvnh2gn78ciiczdv10vf1"; + }) + (fetchNuGet { + pname = "System.Threading.Timer"; + version = "4.3.0"; + sha256 = "1nx773nsx6z5whv8kaa1wjh037id2f1cxhb69pvgv12hd2b6qs56"; + }) + (fetchNuGet { + pname = "System.Windows.Extensions"; + version = "6.0.0"; + sha256 = "1wy9pq9vn1bqg5qnv53iqrbx04yzdmjw4x5yyi09y3459vaa1sip"; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.0.11"; + sha256 = "0c6ky1jk5ada9m94wcadih98l6k1fvf6vi7vhn1msjixaha419l5"; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.3.0"; + sha256 = "0c47yllxifzmh8gq6rq6l36zzvw4kjvlszkqa9wq3fr59n0hl3s1"; + }) + (fetchNuGet { + pname = "System.Xml.XDocument"; + version = "4.0.11"; + sha256 = "0n4lvpqzy9kc7qy1a4acwwd7b7pnvygv895az5640idl2y9zbz18"; + }) + (fetchNuGet { + pname = "System.Xml.XDocument"; + version = "4.3.0"; + sha256 = "08h8fm4l77n0nd4i4fk2386y809bfbwqb7ih9d7564ifcxr5ssxd"; + }) + (fetchNuGet { + pname = "System.Xml.XmlDocument"; + version = "4.3.0"; + sha256 = "0bmz1l06dihx52jxjr22dyv5mxv6pj4852lx68grjm7bivhrbfwi"; + }) + (fetchNuGet { + pname = "Veldrid"; + version = "4.9.0"; + sha256 = "0l1sqz0jinw6d5rxhjaavckgmv1b8cc909crjjc9wvf7hp70gzmg"; + }) + (fetchNuGet { + pname = "Veldrid.ImageSharp"; + version = "4.9.0"; + sha256 = "0w1wvfhkf85c81chpcqlln41kzi2rk49pw6imyypqhpvsi1nw9n6"; + }) + (fetchNuGet { + pname = "Veldrid.MetalBindings"; + version = "4.9.0"; + sha256 = "1zd04q70fdlxsy045yk4pj499n8vl9qdcr86vj9wj4qq1jmd8pr3"; + }) + (fetchNuGet { + pname = "Veldrid.OpenGLBindings"; + version = "4.9.0"; + sha256 = "06cjfrzig75lms930861339v35y96n421236318pjad9jmwhac74"; + }) + (fetchNuGet { + pname = "Veldrid.SDL2"; + version = "4.9.0"; + sha256 = "0cm5jx24wvzk88mip68n34sfg7psdjiyng7pf01g67blz56rlzhl"; + }) + (fetchNuGet { + pname = "Veldrid.StartupUtilities"; + version = "4.9.0"; + sha256 = "10b62ni8ihbnb213rkpw38n1gpk0blli9cb8agihml7za41x3b4y"; + }) + (fetchNuGet { + pname = "Vk"; + version = "1.0.25"; + sha256 = "18kx3g088215803yznnmf6621wgwvgakj8hlmrb726b7zwb3x53l"; + }) + (fetchNuGet { + pname = "Vortice.D3DCompiler"; + version = "2.3.0"; + sha256 = "08an0z9xk6vqz2cdyhmbvvg7nzk7r1vcn0jp4c986s2sqk9jv5dj"; + }) + (fetchNuGet { + pname = "Vortice.Direct3D11"; + version = "2.3.0"; + sha256 = "05lgnkjslcsyrxg206cy9s33qlxj7cb3v47x4accp4p7f6v7k6lr"; + }) + (fetchNuGet { + pname = "Vortice.DirectX"; + version = "2.3.0"; + sha256 = "07inc3msd3baizx03is5djbw6jg9ihzx7dxvalsdz4n7b61lli3h"; + }) + (fetchNuGet { + pname = "Vortice.DXGI"; + version = "2.3.0"; + sha256 = "0j47ywcs1rq8q4hjj0axchjv08dnvyd33yy4nxilz4synyiidf77"; + }) + (fetchNuGet { + pname = "Vortice.Mathematics"; + version = "1.4.25"; + sha256 = "0vl6g087disxyzskvkbnwym74s47lkza0ly3nk4y0y88zibcggrj"; + }) ] diff --git a/pkgs/by-name/xi/xivlauncher/package.nix b/pkgs/by-name/xi/xivlauncher/package.nix index 5eeb5fb5738be7..444f186926ab03 100644 --- a/pkgs/by-name/xi/xivlauncher/package.nix +++ b/pkgs/by-name/xi/xivlauncher/package.nix @@ -1,87 +1,125 @@ -{ lib, buildDotnetModule, fetchFromGitHub, dotnetCorePackages, SDL2, libsecret, glib, gnutls, aria2, steam, gst_all_1 -, copyDesktopItems, makeDesktopItem, makeWrapper -, useSteamRun ? true }: +{ + lib, + buildDotnetModule, + fetchFromGitHub, + dotnetCorePackages, + SDL2, + libsecret, + glib, + gnutls, + aria2, + steam, + gst_all_1, + copyDesktopItems, + makeDesktopItem, + makeWrapper, + useSteamRun ? true, +}: let rev = "1.1.1"; in - buildDotnetModule rec { - pname = "XIVLauncher"; - version = rev; +buildDotnetModule rec { + pname = "XIVLauncher"; + version = rev; - src = fetchFromGitHub { - owner = "goatcorp"; - repo = "XIVLauncher.Core"; - inherit rev; - hash = "sha256-gXec5Btnm/9M7jgPdrnLn8im0jCdLCJjsEBPpuCNz2I="; - fetchSubmodules = true; - }; + src = fetchFromGitHub { + owner = "goatcorp"; + repo = "XIVLauncher.Core"; + inherit rev; + hash = "sha256-gXec5Btnm/9M7jgPdrnLn8im0jCdLCJjsEBPpuCNz2I="; + fetchSubmodules = true; + }; - nativeBuildInputs = [ copyDesktopItems makeWrapper ]; + nativeBuildInputs = [ + copyDesktopItems + makeWrapper + ]; - buildInputs = with gst_all_1; [ gstreamer gst-plugins-base gst-plugins-good gst-plugins-bad gst-plugins-ugly gst-libav ]; + buildInputs = with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + gst-plugins-ugly + gst-libav + ]; - projectFile = "src/XIVLauncher.Core/XIVLauncher.Core.csproj"; - nugetDeps = ./deps.nix; # File generated with `nix-build -A xivlauncher.passthru.fetch-deps` + projectFile = "src/XIVLauncher.Core/XIVLauncher.Core.csproj"; + nugetDeps = ./deps.nix; # File generated with `nix-build -A xivlauncher.passthru.fetch-deps` - # please do not unpin these even if they match the defaults, xivlauncher is sensitive to .NET versions - dotnet-sdk = dotnetCorePackages.sdk_8_0; - dotnet-runtime = dotnetCorePackages.runtime_8_0; + # please do not unpin these even if they match the defaults, xivlauncher is sensitive to .NET versions + dotnet-sdk = dotnetCorePackages.sdk_8_0; + dotnet-runtime = dotnetCorePackages.runtime_8_0; - dotnetFlags = [ - "-p:BuildHash=${rev}" - "-p:PublishSingleFile=false" - ]; + dotnetFlags = [ + "-p:BuildHash=${rev}" + "-p:PublishSingleFile=false" + ]; - postPatch = '' - substituteInPlace lib/FFXIVQuickLauncher/src/XIVLauncher.Common/Game/Patch/Acquisition/Aria/AriaHttpPatchAcquisition.cs \ - --replace-fail 'ariaPath = "aria2c"' 'ariaPath = "${aria2}/bin/aria2c"' - ''; + postPatch = '' + substituteInPlace lib/FFXIVQuickLauncher/src/XIVLauncher.Common/Game/Patch/Acquisition/Aria/AriaHttpPatchAcquisition.cs \ + --replace-fail 'ariaPath = "aria2c"' 'ariaPath = "${aria2}/bin/aria2c"' + ''; - postInstall = '' - mkdir -p $out/share/pixmaps - cp src/XIVLauncher.Core/Resources/logo.png $out/share/pixmaps/xivlauncher.png - ''; + postInstall = '' + mkdir -p $out/share/pixmaps + cp src/XIVLauncher.Core/Resources/logo.png $out/share/pixmaps/xivlauncher.png + ''; - postFixup = lib.optionalString useSteamRun (let - steam-run = (steam.override { - extraPkgs = pkgs: [ pkgs.libunwind ]; - extraProfile = '' - unset TZ - ''; - }).run; - in '' - substituteInPlace $out/bin/XIVLauncher.Core \ - --replace-fail 'exec' 'exec ${steam-run}/bin/steam-run' - '') + '' + postFixup = + lib.optionalString useSteamRun ( + let + steam-run = + (steam.override { + extraPkgs = pkgs: [ pkgs.libunwind ]; + extraProfile = '' + unset TZ + ''; + }).run; + in + '' + substituteInPlace $out/bin/XIVLauncher.Core \ + --replace-fail 'exec' 'exec ${steam-run}/bin/steam-run' + '' + ) + + '' wrapProgram $out/bin/XIVLauncher.Core --prefix GST_PLUGIN_SYSTEM_PATH_1_0 ":" "$GST_PLUGIN_SYSTEM_PATH_1_0" # the reference to aria2 gets mangled as UTF-16LE and isn't detectable by nix: https://github.com/NixOS/nixpkgs/issues/220065 mkdir -p $out/nix-support echo ${aria2} >> $out/nix-support/depends ''; - executables = [ "XIVLauncher.Core" ]; + executables = [ "XIVLauncher.Core" ]; - runtimeDeps = [ SDL2 libsecret glib gnutls ]; + runtimeDeps = [ + SDL2 + libsecret + glib + gnutls + ]; - desktopItems = [ - (makeDesktopItem { - name = "xivlauncher"; - exec = "XIVLauncher.Core"; - icon = "xivlauncher"; - desktopName = "XIVLauncher"; - comment = meta.description; - categories = [ "Game" ]; - startupWMClass = "XIVLauncher.Core"; - }) - ]; + desktopItems = [ + (makeDesktopItem { + name = "xivlauncher"; + exec = "XIVLauncher.Core"; + icon = "xivlauncher"; + desktopName = "XIVLauncher"; + comment = meta.description; + categories = [ "Game" ]; + startupWMClass = "XIVLauncher.Core"; + }) + ]; - meta = with lib; { - description = "Custom launcher for FFXIV"; - homepage = "https://github.com/goatcorp/XIVLauncher.Core"; - license = licenses.gpl3; - maintainers = with maintainers; [ sersorrel witchof0x20 ]; - platforms = [ "x86_64-linux" ]; - mainProgram = "XIVLauncher.Core"; - }; - } + meta = with lib; { + description = "Custom launcher for FFXIV"; + homepage = "https://github.com/goatcorp/XIVLauncher.Core"; + license = licenses.gpl3; + maintainers = with maintainers; [ + sersorrel + witchof0x20 + ]; + platforms = [ "x86_64-linux" ]; + mainProgram = "XIVLauncher.Core"; + }; +} diff --git a/pkgs/by-name/xj/xjadeo/package.nix b/pkgs/by-name/xj/xjadeo/package.nix index 7abb717f00cd00..6ba651e7244aec 100644 --- a/pkgs/by-name/xj/xjadeo/package.nix +++ b/pkgs/by-name/xj/xjadeo/package.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, autoreconfHook, fetchFromGitHub, ffmpeg, freetype, libGLU -, libjack2, liblo, libX11, libXv, pkg-config, portmidi, xorg }: +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + ffmpeg, + freetype, + libGLU, + libjack2, + liblo, + libX11, + libXv, + pkg-config, + portmidi, + xorg, +}: stdenv.mkDerivation rec { pname = "xjadeo"; @@ -12,7 +26,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-GTg0W3D0BRSxsmeVsB4On3MfwncScEGFJGVJK7wflCM="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ ffmpeg diff --git a/pkgs/by-name/xj/xjobs/package.nix b/pkgs/by-name/xj/xjobs/package.nix index d2c5a44df52142..da6cbc28858035 100644 --- a/pkgs/by-name/xj/xjobs/package.nix +++ b/pkgs/by-name/xj/xjobs/package.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchurl -, flex, installShellFiles, ncurses, which +{ + lib, + stdenv, + fetchurl, + flex, + installShellFiles, + ncurses, + which, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xj/xjump/package.nix b/pkgs/by-name/xj/xjump/package.nix index 4d7e9fe717594a..aed50689aedafe 100644 --- a/pkgs/by-name/xj/xjump/package.nix +++ b/pkgs/by-name/xj/xjump/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libX11, libXt, libXpm, libXaw, localStateDir?null }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libX11, + libXt, + libXpm, + libXaw, + localStateDir ? null, +}: stdenv.mkDerivation { pname = "xjump"; @@ -9,11 +20,19 @@ stdenv.mkDerivation { rev = "e7f20fb8c2c456bed70abb046c1a966462192b80"; sha256 = "0hq4739cvi5a47pxdc0wwkj2lmlqbf1xigq0v85qs5bq3ixmq2f7"; }; - nativeBuildInputs = [ autoconf automake ]; - buildInputs = [ libX11 libXt libXpm libXaw ]; + nativeBuildInputs = [ + autoconf + automake + ]; + buildInputs = [ + libX11 + libXt + libXpm + libXaw + ]; preConfigure = "autoreconf --install"; patches = lib.optionals stdenv.buildPlatform.isDarwin [ ./darwin.patch ]; - configureFlags = lib.optionals (localStateDir != null) ["--localstatedir=${localStateDir}"]; + configureFlags = lib.optionals (localStateDir != null) [ "--localstatedir=${localStateDir}" ]; meta = with lib; { description = "Falling tower game"; diff --git a/pkgs/by-name/xk/xkb-switch-i3/package.nix b/pkgs/by-name/xk/xkb-switch-i3/package.nix index 3e7fc33c72d17d..bf7954c782b71d 100644 --- a/pkgs/by-name/xk/xkb-switch-i3/package.nix +++ b/pkgs/by-name/xk/xkb-switch-i3/package.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, cmake -, fetchFromGitHub -, i3 -, jsoncpp -, libsigcxx -, libX11 -, libxkbfile -, pkg-config +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + i3, + jsoncpp, + libsigcxx, + libX11, + libxkbfile, + pkg-config, }: stdenv.mkDerivation rec { @@ -21,8 +23,17 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ i3 jsoncpp libsigcxx libX11 libxkbfile ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + i3 + jsoncpp + libsigcxx + libX11 + libxkbfile + ]; meta = with lib; { description = "Switch your X keyboard layouts from the command line(i3 edition)"; diff --git a/pkgs/by-name/xk/xkb-switch/package.nix b/pkgs/by-name/xk/xkb-switch/package.nix index 7db5925322346c..8ecfe8d4ef5f6d 100644 --- a/pkgs/by-name/xk/xkb-switch/package.nix +++ b/pkgs/by-name/xk/xkb-switch/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libX11, libxkbfile }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libX11, + libxkbfile, +}: stdenv.mkDerivation rec { pname = "xkb-switch"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libX11 libxkbfile ]; + buildInputs = [ + libX11 + libxkbfile + ]; meta = with lib; { description = "Switch your X keyboard layouts from the command line"; diff --git a/pkgs/by-name/xk/xkbd/package.nix b/pkgs/by-name/xk/xkbd/package.nix index df7d0f0e61cc5f..ef41440659a664 100644 --- a/pkgs/by-name/xk/xkbd/package.nix +++ b/pkgs/by-name/xk/xkbd/package.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, freetype, libXrender, libXft, xorgproto -, xinput, libXi, libXext, libXtst, libXpm, libX11, autoreconfHook +{ + lib, + stdenv, + fetchFromGitHub, + freetype, + libXrender, + libXft, + xorgproto, + xinput, + libXi, + libXext, + libXtst, + libXpm, + libX11, + autoreconfHook, }: stdenv.mkDerivation rec { @@ -14,8 +27,16 @@ stdenv.mkDerivation rec { }; buildInputs = [ - freetype libXrender libXft libXext libXtst libXpm libX11 - libXi xorgproto xinput + freetype + libXrender + libXft + libXext + libXtst + libXpm + libX11 + libXi + xorgproto + xinput ]; nativeBuildInputs = [ autoreconfHook ]; diff --git a/pkgs/by-name/xk/xkblayout-state/package.nix b/pkgs/by-name/xk/xkblayout-state/package.nix index 10bd1961f09c18..85798f90218478 100644 --- a/pkgs/by-name/xk/xkblayout-state/package.nix +++ b/pkgs/by-name/xk/xkblayout-state/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libX11 }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, +}: stdenv.mkDerivation rec { pname = "xkblayout-state"; diff --git a/pkgs/by-name/xk/xkbmon/package.nix b/pkgs/by-name/xk/xkbmon/package.nix index f9394c45342cbd..a6cef8a63a077d 100644 --- a/pkgs/by-name/xk/xkbmon/package.nix +++ b/pkgs/by-name/xk/xkbmon/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libX11 }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, +}: stdenv.mkDerivation rec { pname = "xkbmon"; diff --git a/pkgs/by-name/xk/xkbset/package.nix b/pkgs/by-name/xk/xkbset/package.nix index 9c4bc81744fa51..668c801acd548a 100644 --- a/pkgs/by-name/xk/xkbset/package.nix +++ b/pkgs/by-name/xk/xkbset/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, perl, libX11 }: +{ + lib, + stdenv, + fetchurl, + perl, + libX11, +}: stdenv.mkDerivation rec { pname = "xkbset"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-rAMv7EnExPDyMY0/RhiXDFFBkbFC4GxRpmH+I0KlNaU="; }; - buildInputs = [ perl libX11 ]; + buildInputs = [ + perl + libX11 + ]; postPatch = '' sed "s:^X11PREFIX=.*:X11PREFIX=$out:" -i Makefile diff --git a/pkgs/by-name/xk/xkbvalidate/package.nix b/pkgs/by-name/xk/xkbvalidate/package.nix index b39e697f774144..b12390c1baa295 100644 --- a/pkgs/by-name/xk/xkbvalidate/package.nix +++ b/pkgs/by-name/xk/xkbvalidate/package.nix @@ -1,16 +1,22 @@ -{ lib, runCommandCC, libxkbcommon }: +{ + lib, + runCommandCC, + libxkbcommon, +}: -runCommandCC "xkbvalidate" { - buildInputs = [ libxkbcommon ]; - meta = { - description = "NixOS tool to validate X keyboard configuration"; - license = lib.licenses.mit; - platforms = lib.platforms.unix; - maintainers = [ lib.maintainers.aszlig ]; - mainProgram = "xkbvalidate"; - }; -} '' - mkdir -p "$out/bin" - $CC -std=c11 -Wall -pedantic -lxkbcommon ${./xkbvalidate.c} \ - -o "$out/bin/xkbvalidate" -'' +runCommandCC "xkbvalidate" + { + buildInputs = [ libxkbcommon ]; + meta = { + description = "NixOS tool to validate X keyboard configuration"; + license = lib.licenses.mit; + platforms = lib.platforms.unix; + maintainers = [ lib.maintainers.aszlig ]; + mainProgram = "xkbvalidate"; + }; + } + '' + mkdir -p "$out/bin" + $CC -std=c11 -Wall -pedantic -lxkbcommon ${./xkbvalidate.c} \ + -o "$out/bin/xkbvalidate" + '' diff --git a/pkgs/by-name/xk/xkcd-font/package.nix b/pkgs/by-name/xk/xkcd-font/package.nix index 003ddcc7da90f1..8e7d5be28f2f55 100644 --- a/pkgs/by-name/xk/xkcd-font/package.nix +++ b/pkgs/by-name/xk/xkcd-font/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "xkcd-font"; diff --git a/pkgs/by-name/xk/xkeysnail/package.nix b/pkgs/by-name/xk/xkeysnail/package.nix index 2d66405904f664..3ab9d84f54810c 100644 --- a/pkgs/by-name/xk/xkeysnail/package.nix +++ b/pkgs/by-name/xk/xkeysnail/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, makeWrapper, python3Packages }: +{ + lib, + fetchFromGitHub, + makeWrapper, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "xkeysnail"; diff --git a/pkgs/by-name/xl/xl2tpd/package.nix b/pkgs/by-name/xl/xl2tpd/package.nix index 3b0ee699ff3204..9921812ed5cc53 100644 --- a/pkgs/by-name/xl/xl2tpd/package.nix +++ b/pkgs/by-name/xl/xl2tpd/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, libpcap, ppp }: +{ + lib, + stdenv, + fetchFromGitHub, + libpcap, + ppp, +}: stdenv.mkDerivation rec { pname = "xl2tpd"; diff --git a/pkgs/by-name/xl/xlayoutdisplay/package.nix b/pkgs/by-name/xl/xlayoutdisplay/package.nix index 5ab9ca0b86ff11..ada51548336252 100644 --- a/pkgs/by-name/xl/xlayoutdisplay/package.nix +++ b/pkgs/by-name/xl/xlayoutdisplay/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, xorg, boost, gtest }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + xorg, + boost, + gtest, +}: stdenv.mkDerivation rec { pname = "xlayoutdisplay"; @@ -12,7 +20,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = with xorg; [ libX11 libXrandr libXcursor boost ]; + buildInputs = with xorg; [ + libX11 + libXrandr + libXcursor + boost + ]; nativeCheckInputs = [ gtest ]; doCheck = true; diff --git a/pkgs/by-name/xl/xld/package.nix b/pkgs/by-name/xl/xld/package.nix index 2567e377a886bb..54941de427c3d2 100644 --- a/pkgs/by-name/xl/xld/package.nix +++ b/pkgs/by-name/xl/xld/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenvNoCC -, fetchurl -, undmg -, writeShellApplication -, curl -, xmlstarlet -, common-updater-scripts +{ + lib, + stdenvNoCC, + fetchurl, + undmg, + writeShellApplication, + curl, + xmlstarlet, + common-updater-scripts, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -22,13 +23,13 @@ stdenvNoCC.mkDerivation (finalAttrs: { sourceRoot = "."; installPhase = '' - runHook preInstall + runHook preInstall - mkdir -p "$out/Applications" "$out/bin" - cp -r *.app "$out/Applications" - cp -r CLI/xld "$out/bin" + mkdir -p "$out/Applications" "$out/bin" + cp -r *.app "$out/Applications" + cp -r CLI/xld "$out/bin" - runHook postInstall + runHook postInstall ''; postPatch = '' diff --git a/pkgs/by-name/xl/xlibinput-calibrator/package.nix b/pkgs/by-name/xl/xlibinput-calibrator/package.nix index 3d5faba1c63c25..2fc3a5640d01a2 100644 --- a/pkgs/by-name/xl/xlibinput-calibrator/package.nix +++ b/pkgs/by-name/xl/xlibinput-calibrator/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, libX11 -, libXi -, libXrandr -, txt2man +{ + lib, + stdenv, + fetchFromGitHub, + libX11, + libXi, + libXrandr, + txt2man, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xl/xlife/package.nix b/pkgs/by-name/xl/xlife/package.nix index 482134269d2b2e..e6f58c5da24a77 100644 --- a/pkgs/by-name/xl/xlife/package.nix +++ b/pkgs/by-name/xl/xlife/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchsvn, xorg }: +{ + lib, + stdenv, + fetchsvn, + xorg, +}: stdenv.mkDerivation { pname = "xlife"; @@ -10,7 +15,10 @@ stdenv.mkDerivation { sha256 = "1gadlcp32s179kd7ypxr8cymd6s060p6z4c2vnx94i8bmiw3nn8h"; }; - nativeBuildInputs = with xorg; [ imake gccmakedep ]; + nativeBuildInputs = with xorg; [ + imake + gccmakedep + ]; buildInputs = [ xorg.libX11 ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/xl/xlights/package.nix b/pkgs/by-name/xl/xlights/package.nix index 173e47248b8ece..81f6b886d83cc9 100644 --- a/pkgs/by-name/xl/xlights/package.nix +++ b/pkgs/by-name/xl/xlights/package.nix @@ -1,4 +1,8 @@ -{ lib, appimageTools, fetchurl }: +{ + lib, + appimageTools, + fetchurl, +}: appimageTools.wrapType2 rec { pname = "xlights"; diff --git a/pkgs/by-name/xl/xloadimage/package.nix b/pkgs/by-name/xl/xloadimage/package.nix index c3ef05b0a77454..cc83ec9b3c74cc 100644 --- a/pkgs/by-name/xl/xloadimage/package.nix +++ b/pkgs/by-name/xl/xloadimage/package.nix @@ -1,15 +1,17 @@ -{ lib, stdenv -, fetchurl -, libX11 -, libXt - -, libjpeg ? null -, libpng ? null -, libtiff ? null - -, withJpegSupport ? true -, withPngSupport ? true -, withTiffSupport ? true +{ + lib, + stdenv, + fetchurl, + libX11, + libXt, + + libjpeg ? null, + libpng ? null, + libtiff ? null, + + withJpegSupport ? true, + withPngSupport ? true, + withTiffSupport ? true, }: assert withJpegSupport -> libjpeg != null; @@ -33,15 +35,20 @@ stdenv.mkDerivation rec { sha256 = "17k518vrdrya5c9dqhpmm4g0h2vlkq1iy87sg2ngzygypbli1xvn"; }; - buildInputs = [ - libX11 libXt - ] ++ lib.optionals withJpegSupport [ - libjpeg - ] ++ lib.optionals withPngSupport [ - libpng - ] ++ lib.optionals withTiffSupport [ - libtiff - ]; + buildInputs = + [ + libX11 + libXt + ] + ++ lib.optionals withJpegSupport [ + libjpeg + ] + ++ lib.optionals withPngSupport [ + libpng + ] + ++ lib.optionals withTiffSupport [ + libtiff + ]; # NOTE: we patch the build-info script so that it never detects the utilities # it's trying to find; one of the Debian patches adds support for @@ -83,6 +90,6 @@ stdenv.mkDerivation rec { license = lib.licenses.gpl2Plus; maintainers = [ ]; - platforms = lib.platforms.linux; # arbitrary choice + platforms = lib.platforms.linux; # arbitrary choice }; } diff --git a/pkgs/by-name/xl/xlog/package.nix b/pkgs/by-name/xl/xlog/package.nix index 7c7d5f574a3fb7..5b3d66411233e9 100644 --- a/pkgs/by-name/xl/xlog/package.nix +++ b/pkgs/by-name/xl/xlog/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, glib, gtk2, pkg-config, hamlib }: +{ + lib, + stdenv, + fetchurl, + glib, + gtk2, + pkg-config, + hamlib, +}: stdenv.mkDerivation rec { pname = "xlog"; version = "2.0.25"; @@ -12,7 +20,11 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = "-DGLIB_DISABLE_DEPRECATION_WARNINGS"; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib gtk2 hamlib ]; + buildInputs = [ + glib + gtk2 + hamlib + ]; meta = with lib; { description = "Amateur radio logging program"; diff --git a/pkgs/by-name/xl/xlogo/package.nix b/pkgs/by-name/xl/xlogo/package.nix index 8ca1bbb30d8bb1..0650a184bdd1ba 100644 --- a/pkgs/by-name/xl/xlogo/package.nix +++ b/pkgs/by-name/xl/xlogo/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitLab -, xorg -, autoreconfHook -, pkg-config -, xorg-autoconf +{ + lib, + stdenv, + fetchFromGitLab, + xorg, + autoreconfHook, + pkg-config, + xorg-autoconf, }: stdenv.mkDerivation rec { @@ -20,11 +21,22 @@ stdenv.mkDerivation rec { hash = "sha256-KjJhuiFVn34vEZbC7ds4MrcXCHq9PcIpAuaCGBX/EXc="; }; - nativeBuildInputs = [ xorg-autoconf autoreconfHook pkg-config ]; + nativeBuildInputs = [ + xorg-autoconf + autoreconfHook + pkg-config + ]; configureFlags = [ "--with-appdefaultdir=$out/share/X11/app-defaults" ]; - buildInputs = [ xorg.libX11 xorg.libXext xorg.libSM xorg.libXmu xorg.libXaw xorg.libXt ]; + buildInputs = [ + xorg.libX11 + xorg.libXext + xorg.libSM + xorg.libXmu + xorg.libXaw + xorg.libXt + ]; meta = with lib; { description = "X Window System logo display demo"; diff --git a/pkgs/by-name/xl/xlslib/package.nix b/pkgs/by-name/xl/xlslib/package.nix index 77a11b5311007f..175e91617bd369 100644 --- a/pkgs/by-name/xl/xlslib/package.nix +++ b/pkgs/by-name/xl/xlslib/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, autoreconfHook, unzip }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + unzip, +}: stdenv.mkDerivation rec { pname = "xlslib"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1wx3jbpkz2rvgs45x6mwawamd1b2llb0vn29b5sr0rfxzx9d1985"; }; - nativeBuildInputs = [ unzip autoreconfHook ]; + nativeBuildInputs = [ + unzip + autoreconfHook + ]; setSourceRoot = "export sourceRoot=xlslib/xlslib"; diff --git a/pkgs/by-name/xm/xmacro/package.nix b/pkgs/by-name/xm/xmacro/package.nix index a3f97cccad31f3..abfa4fca97e924 100644 --- a/pkgs/by-name/xm/xmacro/package.nix +++ b/pkgs/by-name/xm/xmacro/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, libX11, libXtst, xorgproto, libXi }: +{ + lib, + stdenv, + fetchurl, + libX11, + libXtst, + xorgproto, + libXi, +}: stdenv.mkDerivation rec { pname = "xmacro"; @@ -11,7 +19,12 @@ stdenv.mkDerivation rec { preInstall = "echo -e 'install:\n mkdir \${out}/bin;\n cp xmacrorec2 xmacroplay \${out}/bin;' >>Makefile; "; - buildInputs = [ libX11 libXtst xorgproto libXi ]; + buildInputs = [ + libX11 + libXtst + xorgproto + libXi + ]; meta = { platforms = lib.platforms.linux; diff --git a/pkgs/by-name/xm/xmage/package.nix b/pkgs/by-name/xm/xmage/package.nix index 656eee3ce6171a..31b4b0aa883c31 100644 --- a/pkgs/by-name/xm/xmage/package.nix +++ b/pkgs/by-name/xm/xmage/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, jdk8 -, unzrip +{ + lib, + stdenv, + fetchurl, + jdk8, + unzrip, }: stdenv.mkDerivation (finalAttrs: { @@ -20,30 +21,34 @@ stdenv.mkDerivation (finalAttrs: { ${unzrip}/bin/unzrip $src ''; - installPhase = let - # upstream maintainers forgot to update version, so manual override for now - # strVersion = lib.substring 0 6 finalAttrs.version; - strVersion = "1.4.50"; + installPhase = + let + # upstream maintainers forgot to update version, so manual override for now + # strVersion = lib.substring 0 6 finalAttrs.version; + strVersion = "1.4.50"; - in '' - mkdir -p $out/bin - cp -rv ./* $out + in + '' + mkdir -p $out/bin + cp -rv ./* $out - cat << EOS > $out/bin/xmage - exec ${jdk8}/bin/java -Xms256m -Xmx1024m -XX:MaxPermSize=384m -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar $out/xmage/mage-client/lib/mage-client-${strVersion}.jar - EOS + cat << EOS > $out/bin/xmage + exec ${jdk8}/bin/java -Xms256m -Xmx1024m -XX:MaxPermSize=384m -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -jar $out/xmage/mage-client/lib/mage-client-${strVersion}.jar + EOS - chmod +x $out/bin/xmage - ''; + chmod +x $out/bin/xmage + ''; meta = with lib; { description = "Magic Another Game Engine"; mainProgram = "xmage"; sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.mit; - maintainers = with maintainers; [ matthiasbeyer abueide ]; + maintainers = with maintainers; [ + matthiasbeyer + abueide + ]; homepage = "http://xmage.de/"; }; }) - diff --git a/pkgs/by-name/xm/xmagnify/package.nix b/pkgs/by-name/xm/xmagnify/package.nix index 38450c745ee28d..d5703b46c2272b 100644 --- a/pkgs/by-name/xm/xmagnify/package.nix +++ b/pkgs/by-name/xm/xmagnify/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitLab, libX11, xorgproto }: +{ + lib, + stdenv, + fetchFromGitLab, + libX11, + xorgproto, +}: stdenv.mkDerivation rec { pname = "xmagnify"; @@ -13,12 +19,15 @@ stdenv.mkDerivation rec { prePatch = "substituteInPlace ./Makefile --replace /usr $out"; - buildInputs = [ libX11 xorgproto ]; + buildInputs = [ + libX11 + xorgproto + ]; meta = with lib; { description = "Tiny screen magnifier for X11"; homepage = "https://gitlab.com/amiloradovsky/magnify"; - license = licenses.mit; # or GPL2+, optionally + license = licenses.mit; # or GPL2+, optionally maintainers = with maintainers; [ amiloradovsky ]; mainProgram = "magnify"; platforms = platforms.all; diff --git a/pkgs/by-name/xm/xmcp/package.nix b/pkgs/by-name/xm/xmcp/package.nix index 228d502c4b7c2b..17ae3413f968a5 100644 --- a/pkgs/by-name/xm/xmcp/package.nix +++ b/pkgs/by-name/xm/xmcp/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, libX11 +{ + lib, + stdenv, + fetchFromGitHub, + libX11, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xm/xmenu/package.nix b/pkgs/by-name/xm/xmenu/package.nix index 59058f3f53bd59..23569e6a12c748 100644 --- a/pkgs/by-name/xm/xmenu/package.nix +++ b/pkgs/by-name/xm/xmenu/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, imlib2, libX11, libXft, libXinerama }: +{ + lib, + stdenv, + fetchFromGitHub, + imlib2, + libX11, + libXft, + libXinerama, +}: stdenv.mkDerivation rec { pname = "xmenu"; @@ -11,7 +19,12 @@ stdenv.mkDerivation rec { sha256 = "sha256-Gg4hSBBVBOB/wlY44C5bJOuOnLoA/tPvcNZamXae/WE="; }; - buildInputs = [ imlib2 libX11 libXft libXinerama ]; + buildInputs = [ + imlib2 + libX11 + libXft + libXinerama + ]; postPatch = "sed -i \"s:/usr/local:$out:\" config.mk"; diff --git a/pkgs/by-name/xm/xmind/package.nix b/pkgs/by-name/xm/xmind/package.nix index 58b46208e510d8..d40709c05ea0cd 100644 --- a/pkgs/by-name/xm/xmind/package.nix +++ b/pkgs/by-name/xm/xmind/package.nix @@ -1,4 +1,15 @@ -{ stdenv, lib, fetchzip, fetchurl, gtk3, jre8, libXtst, makeWrapper, makeDesktopItem, runtimeShell }: +{ + stdenv, + lib, + fetchzip, + fetchurl, + gtk3, + jre8, + libXtst, + makeWrapper, + makeDesktopItem, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "xmind"; @@ -25,7 +36,10 @@ stdenv.mkDerivation rec { dontPatchELF = true; dontStrip = true; - libPath = lib.makeLibraryPath [ gtk3 libXtst ]; + libPath = lib.makeLibraryPath [ + gtk3 + libXtst + ]; desktopItem = makeDesktopItem { name = "XMind"; @@ -34,41 +48,44 @@ stdenv.mkDerivation rec { desktopName = "XMind"; comment = meta.description; categories = [ "Office" ]; - mimeTypes = [ "application/xmind" "x-scheme-handler/xmind" ]; + mimeTypes = [ + "application/xmind" + "x-scheme-handler/xmind" + ]; }; - installPhase = let - targetDir = if stdenv.hostPlatform.system == "i686-linux" - then "XMind_i386" - else "XMind_amd64"; - in '' - mkdir -p $out/{bin,libexec/configuration/,share/{applications/,fonts/,icons/hicolor/scalable/apps/}} - cp -r ${targetDir}/{configuration,p2,XMind{,.ini}} $out/libexec - cp -r {plugins,features} $out/libexec/ - cp -r fonts $out/share/fonts/ - cp "${desktopItem}/share/applications/XMind.desktop" $out/share/applications/XMind.desktop - cp ${srcIcon} $out/share/icons/hicolor/scalable/apps/xmind.png - - patchelf --set-interpreter $(cat ${stdenv.cc}/nix-support/dynamic-linker) \ - $out/libexec/XMind - - wrapProgram $out/libexec/XMind \ - --prefix LD_LIBRARY_PATH : "${libPath}" - - # Inspired by https://aur.archlinux.org/cgit/aur.git/tree/?h=xmind - cat >$out/bin/XMind <$out/bin/XMind <&2 exit $ret fi - '').overrideAttrs (finalAttrs: -if (pname != "" && version != "") then { - inherit pname version; - name = "${pname}-${version}"; -} else { - name = if (name != "") then name else (baseNameOf finalAttrs.url); -}) + '' +).overrideAttrs + ( + finalAttrs: + if (pname != "" && version != "") then + { + inherit pname version; + name = "${pname}-${version}"; + } + else + { + name = if (name != "") then name else (baseNameOf finalAttrs.url); + } + ) diff --git a/pkgs/by-name/xr/xrq/package.nix b/pkgs/by-name/xr/xrq/package.nix index c37696c5f19d10..2b2cba3f9c2440 100644 --- a/pkgs/by-name/xr/xrq/package.nix +++ b/pkgs/by-name/xr/xrq/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, libX11 }: +{ + lib, + stdenv, + fetchFromGitHub, + libX11, +}: stdenv.mkDerivation { pname = "xrq"; @@ -15,7 +20,10 @@ stdenv.mkDerivation { make PREFIX=$out install ''; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; buildInputs = [ libX11 ]; diff --git a/pkgs/by-name/xs/xscast/package.nix b/pkgs/by-name/xs/xscast/package.nix index 71b22201e9dd9f..fb770d5d0f83d6 100644 --- a/pkgs/by-name/xs/xscast/package.nix +++ b/pkgs/by-name/xs/xscast/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, ffmpeg, imagemagick, dzen2, xorg }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + ffmpeg, + imagemagick, + dzen2, + xorg, +}: stdenv.mkDerivation { pname = "xscast-unstable"; @@ -21,7 +30,16 @@ stdenv.mkDerivation { patchShebangs $out/bin wrapProgram "$out/bin/xscast" \ - --prefix PATH : ${lib.makeBinPath [ ffmpeg dzen2 xorg.xwininfo xorg.xinput xorg.xmodmap imagemagick ]} + --prefix PATH : ${ + lib.makeBinPath [ + ffmpeg + dzen2 + xorg.xwininfo + xorg.xinput + xorg.xmodmap + imagemagick + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/xs/xschem/package.nix b/pkgs/by-name/xs/xschem/package.nix index c5146b61011a88..0cd6d92c16c74e 100644 --- a/pkgs/by-name/xs/xschem/package.nix +++ b/pkgs/by-name/xs/xschem/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, fetchFromGitHub -, lib -, bison -, cairo -, flex -, libX11 -, libXpm -, pkg-config -, tcl -, tk +{ + stdenv, + fetchFromGitHub, + lib, + bison, + cairo, + flex, + libX11, + libXpm, + pkg-config, + tcl, + tk, }: stdenv.mkDerivation rec { @@ -22,9 +23,19 @@ stdenv.mkDerivation rec { hash = "sha256-+ygwHkQOXmkoNgcuofwuaZcpYTAV6sOmvO4xeE+8DXE="; }; - nativeBuildInputs = [ bison flex pkg-config ]; + nativeBuildInputs = [ + bison + flex + pkg-config + ]; - buildInputs = [ cairo libX11 libXpm tcl tk ]; + buildInputs = [ + cairo + libX11 + libXpm + tcl + tk + ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/by-name/xs/xscope/package.nix b/pkgs/by-name/xs/xscope/package.nix index ed66ebc59313b1..792a5412cd39b6 100644 --- a/pkgs/by-name/xs/xscope/package.nix +++ b/pkgs/by-name/xs/xscope/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pkg-config, libXt }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libXt, +}: stdenv.mkDerivation rec { pname = "xscope"; @@ -21,4 +27,3 @@ stdenv.mkDerivation rec { mainProgram = "xscope"; }; } - diff --git a/pkgs/by-name/xs/xscreensaver/package.nix b/pkgs/by-name/xs/xscreensaver/package.nix index 3820409511e10b..f3528d816090b4 100644 --- a/pkgs/by-name/xs/xscreensaver/package.nix +++ b/pkgs/by-name/xs/xscreensaver/package.nix @@ -1,35 +1,36 @@ -{ lib -, stdenv -, fetchurl -, coreutils -, gdk-pixbuf -, gdk-pixbuf-xlib -, gettext -, gle -, gtk3 -, intltool -, libGL -, libGLU -, libX11 -, libXext -, libXft -, libXi -, libXinerama -, libXrandr -, libXt -, libXxf86vm -, libxml2 -, makeWrapper -, pam -, perlPackages -, xorg -, pkg-config -, systemd -, forceInstallAllHacks ? true -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, nixosTests -, substituteAll -, wrapperPrefix ? "/run/wrappers/bin" +{ + lib, + stdenv, + fetchurl, + coreutils, + gdk-pixbuf, + gdk-pixbuf-xlib, + gettext, + gle, + gtk3, + intltool, + libGL, + libGLU, + libX11, + libXext, + libXft, + libXi, + libXinerama, + libXrandr, + libXt, + libXxf86vm, + libxml2, + makeWrapper, + pam, + perlPackages, + xorg, + pkg-config, + systemd, + forceInstallAllHacks ? true, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + nixosTests, + substituteAll, + wrapperPrefix ? "/run/wrappers/bin", }: stdenv.mkDerivation (finalAttrs: { @@ -41,7 +42,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-9GZ3Ba24zEP9LzlzqIobVLFvIBkK/pOyHiIfL1cyCwU="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; nativeBuildInputs = [ intltool @@ -70,8 +74,7 @@ stdenv.mkDerivation (finalAttrs: { perlPackages.LWPProtocolHttps perlPackages.MozillaCA perlPackages.perl - ] - ++ lib.optionals withSystemd [ systemd ]; + ] ++ lib.optionals withSystemd [ systemd ]; postPatch = '' pushd hacks @@ -99,22 +102,29 @@ stdenv.mkDerivation (finalAttrs: { # "marbling" has NEON code that mixes signed and unsigned vector types env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isAarch "-flax-vector-conversions"; - postInstall = '' - for bin in $out/bin/*; do - wrapProgram "$bin" \ - --prefix PATH : "$out/libexec/xscreensaver" \ - --prefix PATH : "${lib.makeBinPath [ coreutils perlPackages.perl xorg.appres ]}" \ - --prefix PERL5LIB ':' $PERL5LIB - done - '' - + lib.optionalString forceInstallAllHacks '' - make -j$NIX_BUILD_CORES -C hacks/glx dnalogo - cat hacks/Makefile.in \ - | grep -E '([a-z0-9]+):[[:space:]]*\1[.]o' | cut -d : -f 1 | xargs make -j$NIX_BUILD_CORES -C hacks - cat hacks/glx/Makefile.in \ - | grep -E '([a-z0-9]+):[[:space:]]*\1[.]o' | cut -d : -f 1 | xargs make -j$NIX_BUILD_CORES -C hacks/glx - cp -f $(find hacks -type f -perm -111 "!" -name "*.*" ) "$out/libexec/xscreensaver" - ''; + postInstall = + '' + for bin in $out/bin/*; do + wrapProgram "$bin" \ + --prefix PATH : "$out/libexec/xscreensaver" \ + --prefix PATH : "${ + lib.makeBinPath [ + coreutils + perlPackages.perl + xorg.appres + ] + }" \ + --prefix PERL5LIB ':' $PERL5LIB + done + '' + + lib.optionalString forceInstallAllHacks '' + make -j$NIX_BUILD_CORES -C hacks/glx dnalogo + cat hacks/Makefile.in \ + | grep -E '([a-z0-9]+):[[:space:]]*\1[.]o' | cut -d : -f 1 | xargs make -j$NIX_BUILD_CORES -C hacks + cat hacks/glx/Makefile.in \ + | grep -E '([a-z0-9]+):[[:space:]]*\1[.]o' | cut -d : -f 1 | xargs make -j$NIX_BUILD_CORES -C hacks/glx + cp -f $(find hacks -type f -perm -111 "!" -name "*.*" ) "$out/libexec/xscreensaver" + ''; passthru.tests = { xscreensaver = nixosTests.xscreensaver; @@ -125,7 +135,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Set of screensavers"; downloadPage = "https://www.jwz.org/xscreensaver/download.html"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ raskin AndersonTorres ]; + maintainers = with lib.maintainers; [ + raskin + AndersonTorres + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/by-name/xs/xsct/package.nix b/pkgs/by-name/xs/xsct/package.nix index 20bcbd76f71ed5..ea1e793b692a41 100644 --- a/pkgs/by-name/xs/xsct/package.nix +++ b/pkgs/by-name/xs/xsct/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, gitUpdater -, libX11 -, libXrandr +{ + stdenv, + lib, + fetchFromGitHub, + gitUpdater, + libX11, + libXrandr, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/xs/xsecurelock/package.nix b/pkgs/by-name/xs/xsecurelock/package.nix index c011aa8aa4991e..28dc1c642ef5aa 100644 --- a/pkgs/by-name/xs/xsecurelock/package.nix +++ b/pkgs/by-name/xs/xsecurelock/package.nix @@ -1,6 +1,23 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config -, libX11, libXcomposite, libXft, libXmu, libXrandr, libXext, libXScrnSaver -, pam, apacheHttpd, pamtester, xscreensaver, coreutils, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libX11, + libXcomposite, + libXft, + libXmu, + libXrandr, + libXext, + libXScrnSaver, + pam, + apacheHttpd, + pamtester, + xscreensaver, + coreutils, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "xsecurelock"; @@ -14,12 +31,22 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - autoreconfHook pkg-config makeWrapper + autoreconfHook + pkg-config + makeWrapper ]; buildInputs = [ - libX11 libXcomposite libXft libXmu libXrandr libXext libXScrnSaver - pam apacheHttpd pamtester + libX11 + libXcomposite + libXft + libXmu + libXrandr + libXext + libXScrnSaver + pam + apacheHttpd + pamtester ]; configureFlags = [ diff --git a/pkgs/by-name/xs/xsel/package.nix b/pkgs/by-name/xs/xsel/package.nix index f32d0a81a61efa..d929ae66915519 100644 --- a/pkgs/by-name/xs/xsel/package.nix +++ b/pkgs/by-name/xs/xsel/package.nix @@ -5,7 +5,7 @@ pkg-config, autoreconfHook, libX11, - libXt + libXt, }: stdenv.mkDerivation (finalAttrs: { @@ -19,15 +19,21 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-F2w/Ad8IWxJNH90/0a9+1M8bLfn1M3m4TH3PNpQmEFI="; }; - nativeBuildInputs = [pkg-config autoreconfHook]; - buildInputs = [libX11 libXt]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + libX11 + libXt + ]; meta = with lib; { description = "Command-line program for getting and setting the contents of the X selection"; homepage = "http://www.kfish.org/software/xsel"; changelog = "https://github.com/kfish/xsel/releases/tag/${finalAttrs.version}"; license = licenses.mit; - maintainers = with maintainers; [cafkafk]; + maintainers = with maintainers; [ cafkafk ]; platforms = lib.platforms.unix; mainProgram = "xsel"; }; diff --git a/pkgs/by-name/xs/xsensors/package.nix b/pkgs/by-name/xs/xsensors/package.nix index a67dcc9e716e1a..d90fc67d40306a 100644 --- a/pkgs/by-name/xs/xsensors/package.nix +++ b/pkgs/by-name/xs/xsensors/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchurl, gtk2, pkg-config, lm_sensors }: +{ + stdenv, + lib, + fetchurl, + gtk2, + pkg-config, + lm_sensors, +}: stdenv.mkDerivation rec { pname = "xsensors"; @@ -9,7 +16,8 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; buildInputs = [ - gtk2 lm_sensors + gtk2 + lm_sensors ]; patches = [ ./remove-unused-variables.patch diff --git a/pkgs/by-name/xs/xsettingsd/package.nix b/pkgs/by-name/xs/xsettingsd/package.nix index d0b7c61e710de0..ac54cd7f77c708 100644 --- a/pkgs/by-name/xs/xsettingsd/package.nix +++ b/pkgs/by-name/xs/xsettingsd/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, libX11 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libX11, +}: stdenv.mkDerivation rec { pname = "xsettingsd"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-CIYshZqJICuL8adKHIN4R6nudaqWOCK2UPrGhsKf9pE="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ libX11 ]; diff --git a/pkgs/by-name/xs/xsimd/package.nix b/pkgs/by-name/xs/xsimd/package.nix index 622f11f400bc6e..befc92f7522cad 100644 --- a/pkgs/by-name/xs/xsimd/package.nix +++ b/pkgs/by-name/xs/xsimd/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, doctest +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + doctest, }: stdenv.mkDerivation (finalAttrs: { @@ -15,18 +16,20 @@ stdenv.mkDerivation (finalAttrs: { rev = finalAttrs.version; hash = "sha256-qElJYW5QDj3s59L3NgZj5zkhnUMzIP2mBa1sPks3/CE="; }; - patches = [ - # Fix of https://github.com/xtensor-stack/xsimd/pull/1024 for - # https://github.com/xtensor-stack/xsimd/issues/456 and - # https://github.com/xtensor-stack/xsimd/issues/807, - (fetchpatch { - url = "https://github.com/xtensor-stack/xsimd/commit/c8a87ed6e04b6782f48f94713adfb0cad6c11ddf.patch"; - hash = "sha256-2/FvBGdqTPcayD7rdHPSzL+F8IYKAfMW0WBJ0cW9EZ0="; - }) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # https://github.com/xtensor-stack/xsimd/issues/1030 - ./disable-test_error_gamma.patch - ]; + patches = + [ + # Fix of https://github.com/xtensor-stack/xsimd/pull/1024 for + # https://github.com/xtensor-stack/xsimd/issues/456 and + # https://github.com/xtensor-stack/xsimd/issues/807, + (fetchpatch { + url = "https://github.com/xtensor-stack/xsimd/commit/c8a87ed6e04b6782f48f94713adfb0cad6c11ddf.patch"; + hash = "sha256-2/FvBGdqTPcayD7rdHPSzL+F8IYKAfMW0WBJ0cW9EZ0="; + }) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # https://github.com/xtensor-stack/xsimd/issues/1030 + ./disable-test_error_gamma.patch + ]; # strictDeps raises the chance that xsimd will be able to be cross compiled strictDeps = true; @@ -55,7 +58,10 @@ stdenv.mkDerivation (finalAttrs: { description = "C++ wrappers for SIMD intrinsics"; homepage = "https://github.com/xtensor-stack/xsimd"; license = licenses.bsd3; - maintainers = with maintainers; [ tobim doronbehar ]; + maintainers = with maintainers; [ + tobim + doronbehar + ]; platforms = platforms.all; }; }) diff --git a/pkgs/by-name/xs/xskat/package.nix b/pkgs/by-name/xs/xskat/package.nix index 993070c89c96cc..8325ba5352ba56 100644 --- a/pkgs/by-name/xs/xskat/package.nix +++ b/pkgs/by-name/xs/xskat/package.nix @@ -1,11 +1,21 @@ -{lib, stdenv, fetchurl, libX11, imake, gccmakedep}: +{ + lib, + stdenv, + fetchurl, + libX11, + imake, + gccmakedep, +}: stdenv.mkDerivation rec { pname = "xskat"; version = "4.0"; nativeBuildInputs = [ gccmakedep ]; - buildInputs = [ libX11 imake ]; + buildInputs = [ + libX11 + imake + ]; src = fetchurl { url = "https://web.archive.org/web/20220331112433if_/https://www.xskat.de/xskat-${version}.tar.gz"; @@ -20,7 +30,10 @@ stdenv.mkDerivation rec { -e "s|.* MANPATH .*| MANPATH = $out/man|" ''; - installTargets = [ "install" "install.man" ]; + installTargets = [ + "install" + "install.man" + ]; meta = with lib; { description = "Famous german card game"; diff --git a/pkgs/by-name/xs/xsok/package.nix b/pkgs/by-name/xs/xsok/package.nix index a89d74f33a159f..90f312db099011 100644 --- a/pkgs/by-name/xs/xsok/package.nix +++ b/pkgs/by-name/xs/xsok/package.nix @@ -1,5 +1,14 @@ -{lib, stdenv, fetchurl, libX11, imake, libXt, libXaw, libXpm, libXext -, withNethackLevels ? true +{ + lib, + stdenv, + fetchurl, + libX11, + imake, + libXt, + libXaw, + libXpm, + libXext, + withNethackLevels ? true, }: stdenv.mkDerivation rec { pname = "xsok"; @@ -15,8 +24,14 @@ stdenv.mkDerivation rec { sha256 = "057ircp13hfpy513c7wpyp986hsvhqs7km98w4k39f5wkvp3dj02"; }; - buildInputs = [libX11 libXt libXaw libXpm libXext]; - nativeBuildInputs = [imake]; + buildInputs = [ + libX11 + libXt + libXaw + libXpm + libXext + ]; + nativeBuildInputs = [ imake ]; env.NIX_CFLAGS_COMPILE = " -isystem ${libXpm.dev}/include/X11 "; @@ -29,7 +44,7 @@ stdenv.mkDerivation rec { sed -e 's/CC = gcc/CC = cc/g' -i src/Imakefile ''; - makeFlags = ["BINDIR=$(out)/bin"]; + makeFlags = [ "BINDIR=$(out)/bin" ]; postInstall = lib.optionalString withNethackLevels '' gzip < ${nethackLevels} > "$out/share/games/lib/xsok/Nethack.def.gz" @@ -40,7 +55,7 @@ stdenv.mkDerivation rec { description = "Generic Sokoban game for X11"; mainProgram = "xsok"; license = lib.licenses.gpl2Plus; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.unix; homepage = "https://tracker.debian.org/pkg/xsok"; }; diff --git a/pkgs/by-name/xs/xsokoban/package.nix b/pkgs/by-name/xs/xsokoban/package.nix index 51de995af4bc41..e0ff0a30f15c67 100644 --- a/pkgs/by-name/xs/xsokoban/package.nix +++ b/pkgs/by-name/xs/xsokoban/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, libX11, xorgproto, libXpm, libXt }: +{ + lib, + stdenv, + fetchurl, + libX11, + xorgproto, + libXpm, + libXt, +}: stdenv.mkDerivation rec { pname = "xsokoban"; @@ -9,7 +17,12 @@ stdenv.mkDerivation rec { sha256 = "006lp8y22b9pi81x1a9ldfgkl1fbmkdzfw0lqw5y9svmisbafbr9"; }; - buildInputs = [ libX11 xorgproto libXpm libXt ]; + buildInputs = [ + libX11 + xorgproto + libXpm + libXt + ]; env.NIX_CFLAGS_COMPILE = "-I${libXpm.dev}/include/X11"; diff --git a/pkgs/by-name/xs/xsos/package.nix b/pkgs/by-name/xs/xsos/package.nix index 6681c375d9669d..9583dadd9e8af7 100644 --- a/pkgs/by-name/xs/xsos/package.nix +++ b/pkgs/by-name/xs/xsos/package.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, makeWrapper -, installShellFiles -, dmidecode -, ethtool -, pciutils -, multipath-tools -, iproute2 -, sysvinit +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + installShellFiles, + dmidecode, + ethtool, + pciutils, + multipath-tools, + iproute2, + sysvinit, }: let binPath = [ @@ -33,7 +34,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-VEOY422/+4veMlN9HOtPB/THDiFLNnRfbUJpKjc/cqE="; }; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; installPhase = '' mkdir -p $out/bin @@ -47,7 +51,10 @@ stdenv.mkDerivation rec { mainProgram = "xsos"; homepage = "https://github.com/ryran/xsos"; license = licenses.gpl3; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; maintainers = [ maintainers.nixinator ]; }; } diff --git a/pkgs/by-name/xs/xspim/package.nix b/pkgs/by-name/xs/xspim/package.nix index 4a040e41ab66be..2b00919d714e78 100644 --- a/pkgs/by-name/xs/xspim/package.nix +++ b/pkgs/by-name/xs/xspim/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchsvn, imake, bison, flex, xorg }: +{ + lib, + stdenv, + fetchsvn, + imake, + bison, + flex, + xorg, +}: stdenv.mkDerivation rec { pname = "xspim"; @@ -10,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "1kazfgrbmi4xq7nrkmnqw1280rhdyc1hmr82flrsa3g1b1rlmj1s"; }; - nativeBuildInputs = [ imake bison flex ]; + nativeBuildInputs = [ + imake + bison + flex + ]; buildInputs = [ xorg.libICE xorg.libSM diff --git a/pkgs/by-name/xs/xss-lock/package.nix b/pkgs/by-name/xs/xss-lock/package.nix index dfadfedaee9a0f..4e8931f6e06860 100644 --- a/pkgs/by-name/xs/xss-lock/package.nix +++ b/pkgs/by-name/xs/xss-lock/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, cmake, docutils, pkg-config, glib, libpthreadstubs -, libXau, libXdmcp, xcbutil, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + docutils, + pkg-config, + glib, + libpthreadstubs, + libXau, + libXdmcp, + xcbutil, + nixosTests, +}: stdenv.mkDerivation { pname = "xss-lock"; @@ -12,8 +24,18 @@ stdenv.mkDerivation { sha256 = "040nqgfh564frvqkrkmak3x3h0yadz6kzk81jkfvd9vd20a9drh7"; }; - nativeBuildInputs = [ cmake pkg-config docutils ]; - buildInputs = [ glib libpthreadstubs libXau libXdmcp xcbutil ]; + nativeBuildInputs = [ + cmake + pkg-config + docutils + ]; + buildInputs = [ + glib + libpthreadstubs + libXau + libXdmcp + xcbutil + ]; passthru.tests = { inherit (nixosTests) xss-lock; }; @@ -21,7 +43,10 @@ stdenv.mkDerivation { description = "Use external locker (such as i3lock) as X screen saver"; license = licenses.mit; mainProgram = "xss-lock"; - maintainers = with maintainers; [ malyn offline ]; + maintainers = with maintainers; [ + malyn + offline + ]; platforms = platforms.linux; }; } diff --git a/pkgs/by-name/xs/xssproxy/package.nix b/pkgs/by-name/xs/xssproxy/package.nix index 2ec28be876490c..cf80c18f1c0df4 100644 --- a/pkgs/by-name/xs/xssproxy/package.nix +++ b/pkgs/by-name/xs/xssproxy/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, glib, pkg-config, xorg, dbus }: +{ + lib, + stdenv, + fetchFromGitHub, + glib, + pkg-config, + xorg, + dbus, +}: stdenv.mkDerivation rec { pname = "xssproxy"; @@ -12,7 +20,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib xorg.libX11 xorg.libXScrnSaver dbus ]; + buildInputs = [ + glib + xorg.libX11 + xorg.libXScrnSaver + dbus + ]; makeFlags = [ "bindir=$(out)/bin" diff --git a/pkgs/by-name/xs/xssstate/package.nix b/pkgs/by-name/xs/xssstate/package.nix index d4ec63a7166800..ab51ee2544d661 100644 --- a/pkgs/by-name/xs/xssstate/package.nix +++ b/pkgs/by-name/xs/xssstate/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchgit -, libX11 -, libXScrnSaver +{ + lib, + stdenv, + fetchgit, + libX11, + libXScrnSaver, }: stdenv.mkDerivation (finalAttrs: { pname = "xssstate"; diff --git a/pkgs/by-name/xs/xstow/package.nix b/pkgs/by-name/xs/xstow/package.nix index 96e569fe26b0be..83957658f8528e 100644 --- a/pkgs/by-name/xs/xstow/package.nix +++ b/pkgs/by-name/xs/xstow/package.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchFromGitHub -, ncurses -, autoreconfHook +{ + stdenv, + lib, + fetchFromGitHub, + ncurses, + autoreconfHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xs/xsuspender/package.nix b/pkgs/by-name/xs/xsuspender/package.nix index 178522fbf518c0..2d4c230ee71236 100644 --- a/pkgs/by-name/xs/xsuspender/package.nix +++ b/pkgs/by-name/xs/xsuspender/package.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, makeWrapper, pkg-config -, glib, libwnck, procps }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + makeWrapper, + pkg-config, + glib, + libwnck, + procps, +}: stdenv.mkDerivation rec { pname = "xsuspender"; @@ -12,10 +21,21 @@ stdenv.mkDerivation rec { sha256 = "1c6ab1s9bbkjbmcfv2mny273r66dlz7sgxsmzfwi0fm2vcb2lwim"; }; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; - nativeBuildInputs = [ cmake pkg-config makeWrapper ]; - buildInputs = [ glib libwnck ]; + nativeBuildInputs = [ + cmake + pkg-config + makeWrapper + ]; + buildInputs = [ + glib + libwnck + ]; postInstall = '' wrapProgram $out/bin/xsuspender \ diff --git a/pkgs/by-name/xs/xsynth_dssi/package.nix b/pkgs/by-name/xs/xsynth_dssi/package.nix index 788453f51955f0..ac0bb27bad0560 100644 --- a/pkgs/by-name/xs/xsynth_dssi/package.nix +++ b/pkgs/by-name/xs/xsynth_dssi/package.nix @@ -1,7 +1,20 @@ -{ lib, stdenv, fetchurl, alsa-lib, autoconf, automake, dssi, gtk2, libjack2, -ladspaH, ladspaPlugins, liblo, pkg-config }: +{ + lib, + stdenv, + fetchurl, + alsa-lib, + autoconf, + automake, + dssi, + gtk2, + libjack2, + ladspaH, + ladspaPlugins, + liblo, + pkg-config, +}: -stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "xsynth-dssi"; version = "0.9.4"; @@ -10,9 +23,20 @@ stdenv.mkDerivation rec { sha256 = "00nwv2pqjbmxqdc6xdm0cljq6z05lv4y6bibmhz1kih9lm0lklnk"; }; - nativeBuildInputs = [ autoconf automake pkg-config ]; - buildInputs = [ alsa-lib dssi gtk2 libjack2 ladspaH - ladspaPlugins liblo ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + ]; + buildInputs = [ + alsa-lib + dssi + gtk2 + libjack2 + ladspaH + ladspaPlugins + liblo + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/by-name/xt/xteddy/package.nix b/pkgs/by-name/xt/xteddy/package.nix index 481255393472d5..81a8e46a898976 100644 --- a/pkgs/by-name/xt/xteddy/package.nix +++ b/pkgs/by-name/xt/xteddy/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitLab, pkg-config, xorg, imlib2, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + xorg, + imlib2, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "xteddy"; @@ -11,10 +19,20 @@ stdenv.mkDerivation rec { sha256 = "0rm7w78d6qajq4fvi4agyqm0c70f3c1i0cy2jdb6kqql2k8w78qy"; }; - nativeBuildInputs = [ pkg-config makeWrapper ]; - buildInputs = [ imlib2 xorg.libX11 xorg.libXext ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; + buildInputs = [ + imlib2 + xorg.libX11 + xorg.libXext + ]; - patches = [ "${src}/debian/patches/10_libXext.patch" "${src}/debian/patches/wrong-man-page-section.patch" ]; + patches = [ + "${src}/debian/patches/10_libXext.patch" + "${src}/debian/patches/wrong-man-page-section.patch" + ]; postPatch = '' sed -i "s:/usr/games/xteddy:$out/bin/xteddy:" xtoys diff --git a/pkgs/by-name/xt/xtensor/package.nix b/pkgs/by-name/xt/xtensor/package.nix index 03ac854187101f..9256db73dff265 100644 --- a/pkgs/by-name/xt/xtensor/package.nix +++ b/pkgs/by-name/xt/xtensor/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, doctest -, enableAssertions ? false -, enableBoundChecks ? false # Broadcasts don't pass bound checks -, nlohmann_json -, xtl -, xsimd +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + doctest, + enableAssertions ? false, + enableBoundChecks ? false, # Broadcasts don't pass bound checks + nlohmann_json, + xtl, + xsimd, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/xt/xtermcontrol/package.nix b/pkgs/by-name/xt/xtermcontrol/package.nix index f0c7203fd9cee5..eb0cfbf743297b 100644 --- a/pkgs/by-name/xt/xtermcontrol/package.nix +++ b/pkgs/by-name/xt/xtermcontrol/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { version = "3.8"; diff --git a/pkgs/by-name/xt/xteve/package.nix b/pkgs/by-name/xt/xteve/package.nix index 75591ddfbc1477..39c60136d205ff 100644 --- a/pkgs/by-name/xt/xteve/package.nix +++ b/pkgs/by-name/xt/xteve/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "xteve"; diff --git a/pkgs/by-name/xt/xtitle/package.nix b/pkgs/by-name/xt/xtitle/package.nix index 94e650144956ad..ec4e3867ad9ae2 100644 --- a/pkgs/by-name/xt/xtitle/package.nix +++ b/pkgs/by-name/xt/xtitle/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libxcb, xcbutil, xcbutilwm, git }: +{ + lib, + stdenv, + fetchFromGitHub, + libxcb, + xcbutil, + xcbutilwm, + git, +}: stdenv.mkDerivation rec { pname = "xtitle"; @@ -15,7 +23,12 @@ stdenv.mkDerivation rec { sed -i "s|/usr/local|$out|" Makefile ''; - buildInputs = [ libxcb git xcbutil xcbutilwm ]; + buildInputs = [ + libxcb + git + xcbutil + xcbutilwm + ]; meta = with lib; { description = "Outputs X window titles"; diff --git a/pkgs/by-name/xt/xtl/package.nix b/pkgs/by-name/xt/xtl/package.nix index 208aceb3e35b4b..2ca5932ac7937a 100644 --- a/pkgs/by-name/xt/xtl/package.nix +++ b/pkgs/by-name/xt/xtl/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, doctest +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + doctest, }: stdenv.mkDerivation rec { pname = "xtl"; diff --git a/pkgs/by-name/xt/xtrace/package.nix b/pkgs/by-name/xt/xtrace/package.nix index 7360603cb790a0..0250507d8de4c0 100644 --- a/pkgs/by-name/xt/xtrace/package.nix +++ b/pkgs/by-name/xt/xtrace/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, autoreconfHook, fetchFromGitLab, libX11, xauth, makeWrapper }: +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitLab, + libX11, + xauth, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "xtrace"; @@ -12,7 +20,10 @@ stdenv.mkDerivation rec { sha256 = "1yff6x847nksciail9jly41mv70sl8sadh0m5d847ypbjmxcwjpq"; }; - nativeBuildInputs = [ autoreconfHook makeWrapper ]; + nativeBuildInputs = [ + autoreconfHook + makeWrapper + ]; buildInputs = [ libX11 ]; postInstall = '' diff --git a/pkgs/by-name/xt/xtris/package.nix b/pkgs/by-name/xt/xtris/package.nix index b9492ad11edadc..cf467bec037f60 100644 --- a/pkgs/by-name/xt/xtris/package.nix +++ b/pkgs/by-name/xt/xtris/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchzip, xorg }: +{ + lib, + stdenv, + fetchzip, + xorg, +}: stdenv.mkDerivation rec { pname = "xtris"; version = "1.15"; diff --git a/pkgs/by-name/xt/xtrlock-pam/package.nix b/pkgs/by-name/xt/xtrlock-pam/package.nix index 7c3bba246cb724..0136fbc5c287b6 100644 --- a/pkgs/by-name/xt/xtrlock-pam/package.nix +++ b/pkgs/by-name/xt/xtrlock-pam/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, python39, pkg-config, pam, xorg }: +{ + lib, + stdenv, + fetchFromGitHub, + python39, + pkg-config, + pam, + xorg, +}: stdenv.mkDerivation { pname = "xtrlock-pam"; @@ -12,7 +20,11 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ python39 pam xorg.libX11 ]; + buildInputs = [ + python39 + pam + xorg.libX11 + ]; configurePhase = '' substituteInPlace .config/options.py --replace /usr/include/security/pam_appl.h ${pam}/include/security/pam_appl.h diff --git a/pkgs/by-name/xt/xtruss/package.nix b/pkgs/by-name/xt/xtruss/package.nix index 790312335ab21e..18ef84029ac1c8 100644 --- a/pkgs/by-name/xt/xtruss/package.nix +++ b/pkgs/by-name/xt/xtruss/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, cmake, halibut }: +{ + lib, + stdenv, + fetchurl, + cmake, + halibut, +}: stdenv.mkDerivation rec { pname = "xtruss"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-ikuKHtXEn2UVLE62l7qD9qc9ZUk6jiAqj5ru36vgdHk="; }; - nativeBuildInputs = [ cmake halibut ]; + nativeBuildInputs = [ + cmake + halibut + ]; meta = with lib; { description = "easy-to-use X protocol tracing program"; diff --git a/pkgs/by-name/xt/xtuner/package.nix b/pkgs/by-name/xt/xtuner/package.nix index 2db4256ee87fcd..a2199f49e70d39 100644 --- a/pkgs/by-name/xt/xtuner/package.nix +++ b/pkgs/by-name/xt/xtuner/package.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, pkg-config -, cairo -, libX11 -, libjack2 -, liblo -, libsigcxx -, zita-resampler -, fftwFloat +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + cairo, + libX11, + libjack2, + liblo, + libsigcxx, + zita-resampler, + fftwFloat, }: stdenv.mkDerivation rec { @@ -35,7 +37,15 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ cairo libX11 libjack2 liblo libsigcxx zita-resampler fftwFloat ]; + buildInputs = [ + cairo + libX11 + libjack2 + liblo + libsigcxx + zita-resampler + fftwFloat + ]; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/by-name/xu/xunit-viewer/package.nix b/pkgs/by-name/xu/xunit-viewer/package.nix index 7c31b82aac7b3b..4e3ccd52d7bae4 100644 --- a/pkgs/by-name/xu/xunit-viewer/package.nix +++ b/pkgs/by-name/xu/xunit-viewer/package.nix @@ -4,7 +4,8 @@ fetchFromGitHub, nix-update-script, callPackage, - testers, xunit-viewer, + testers, + xunit-viewer, }: let version = "10.6.1"; diff --git a/pkgs/by-name/xu/xunit-viewer/test/example.nix b/pkgs/by-name/xu/xunit-viewer/test/example.nix index 574b9d784951e4..86079e8cf03514 100644 --- a/pkgs/by-name/xu/xunit-viewer/test/example.nix +++ b/pkgs/by-name/xu/xunit-viewer/test/example.nix @@ -1,16 +1,18 @@ { xunit-viewer, runCommand, ... }: -runCommand "test-xunit-viewer" { - nativeBuildInputs = [ xunit-viewer ]; -} '' - mkdir $out - xunit-viewer -r ${./example.junit.xml} -o $out/index.html - ( set -x - grep ' throw '' - You must accept the XMLmind XML Editor Personal Edition License at - https://www.xmlmind.com/xmleditor/license_xxe_perso.html - by setting nixpkgs config option `xxe-pe.acceptLicense = true;` - or by using `xxe-pe.override { acceptLicense = true; }` package. - ''; - fetchurl { - url = "https://www.xmlmind.com/xmleditor/_download/xxe-perso-${builtins.replaceStrings [ "." ] [ "_" ] version}.zip"; - sha256 = "sha256-JZ9nQwMrQL/1HKGwvXoWlnTx55ZK/UYjMJAddCtm0rw="; - }; + assert + !acceptLicense + -> throw '' + You must accept the XMLmind XML Editor Personal Edition License at + https://www.xmlmind.com/xmleditor/license_xxe_perso.html + by setting nixpkgs config option `xxe-pe.acceptLicense = true;` + or by using `xxe-pe.override { acceptLicense = true; }` package. + ''; + fetchurl { + url = "https://www.xmlmind.com/xmleditor/_download/xxe-perso-${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.zip"; + sha256 = "sha256-JZ9nQwMrQL/1HKGwvXoWlnTx55ZK/UYjMJAddCtm0rw="; + }; nativeBuildInputs = [ unzip diff --git a/pkgs/by-name/xx/xxgdb/package.nix b/pkgs/by-name/xx/xxgdb/package.nix index 5ba3b74a5a3d58..3eac7f58c30e01 100644 --- a/pkgs/by-name/xx/xxgdb/package.nix +++ b/pkgs/by-name/xx/xxgdb/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, imake -, gccmakedep -, libX11 -, libXaw -, libXext -, libXmu -, libXt +{ + lib, + stdenv, + fetchurl, + imake, + gccmakedep, + libX11, + libXaw, + libXext, + libXmu, + libXt, }: stdenv.mkDerivation rec { @@ -24,8 +25,17 @@ stdenv.mkDerivation rec { ./xxgdb-pty.patch ]; - nativeBuildInputs = [ imake gccmakedep ]; - buildInputs = [ libX11 libXaw libXext libXmu libXt ]; + nativeBuildInputs = [ + imake + gccmakedep + ]; + buildInputs = [ + libX11 + libXaw + libXext + libXmu + libXt + ]; preConfigure = '' mkdir build diff --git a/pkgs/by-name/xx/xxh/package.nix b/pkgs/by-name/xx/xxh/package.nix index eba8abbf790595..1bd9b9d36e0072 100644 --- a/pkgs/by-name/xx/xxh/package.nix +++ b/pkgs/by-name/xx/xxh/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, python3 -, openssh -, nixosTests +{ + lib, + fetchFromGitHub, + python3, + openssh, + nixosTests, }: -python3.pkgs.buildPythonApplication rec{ +python3.pkgs.buildPythonApplication rec { pname = "xxh"; version = "0.8.12"; format = "setuptools"; diff --git a/pkgs/by-name/xx/xxkb/package.nix b/pkgs/by-name/xx/xxkb/package.nix index 022abdb5ae18e8..a0c7d4752508e3 100644 --- a/pkgs/by-name/xx/xxkb/package.nix +++ b/pkgs/by-name/xx/xxkb/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, libX11 -, libXt -, libXext -, libXpm -, imake -, gccmakedep -, svgSupport ? false -, librsvg -, glib -, gdk-pixbuf -, pkg-config +{ + lib, + stdenv, + fetchurl, + libX11, + libXt, + libXext, + libXpm, + imake, + gccmakedep, + svgSupport ? false, + librsvg, + glib, + gdk-pixbuf, + pkg-config, }: stdenv.mkDerivation rec { @@ -23,16 +24,29 @@ stdenv.mkDerivation rec { sha256 = "0hl1i38z9xnbgfjkaz04vv1n8xbgfg88g5z8fyzyb2hxv2z37anf"; }; - nativeBuildInputs = [ imake gccmakedep pkg-config ]; + nativeBuildInputs = [ + imake + gccmakedep + pkg-config + ]; - buildInputs = [ - libX11 - libXt - libXext - libXpm - ] ++ lib.optionals svgSupport [ librsvg glib gdk-pixbuf ]; + buildInputs = + [ + libX11 + libXt + libXext + libXpm + ] + ++ lib.optionals svgSupport [ + librsvg + glib + gdk-pixbuf + ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; imakeFlags = lib.optionalString svgSupport "-DWITH_SVG_SUPPORT"; @@ -45,7 +59,10 @@ stdenv.mkDerivation rec { "MANDIR=${placeholder "man"}/share/man" ]; - installTargets = [ "install" "install.man" ]; + installTargets = [ + "install" + "install.man" + ]; meta = with lib; { description = "Keyboard layout indicator and switcher"; diff --git a/pkgs/by-name/xx/xxv/package.nix b/pkgs/by-name/xx/xxv/package.nix index eaa27e34d9d33b..c5a5515f961346 100644 --- a/pkgs/by-name/xx/xxv/package.nix +++ b/pkgs/by-name/xx/xxv/package.nix @@ -1,27 +1,34 @@ -{ stdenv, lib, fetchFromGitHub, rustPlatform -, ncurses ? null -, darwin ? null }: - -let useNcurses = !stdenv.hostPlatform.isWindows; in +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + ncurses ? null, + darwin ? null, +}: + +let + useNcurses = !stdenv.hostPlatform.isWindows; +in assert useNcurses -> ncurses != null; rustPlatform.buildRustPackage rec { - pname = "xxv"; + pname = "xxv"; version = "0.1.2"; src = fetchFromGitHub { - owner = "chrisvest"; - repo = pname; - rev = version; + owner = "chrisvest"; + repo = pname; + rev = version; sha256 = "0ppfsgdigza2jppbkg4qanjhlkpnq7p115c4471vc6vpikpfrlk3"; }; cargoHash = "sha256-S8IKBXREJ+0z4Qz9i3RH52btg1Mpk6GjKIJf4ivdt14="; - buildInputs = lib.optionals useNcurses [ ncurses ] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ Security ]) - ; + buildInputs = + lib.optionals useNcurses [ ncurses ] + ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ Security ]); # I'm picking pancurses for Windows simply because that's the example given in Cursive's # documentation for picking an alternative backend. We could just as easily pick crossterm. @@ -33,8 +40,8 @@ rustPlatform.buildRustPackage rec { longDescription = '' XXV is a terminal hex viewer with a text user interface, written in 100% safe Rust. ''; - homepage = "https://chrisvest.github.io/xxv/"; - license = with licenses; [ gpl3 ]; + homepage = "https://chrisvest.github.io/xxv/"; + license = with licenses; [ gpl3 ]; maintainers = [ ]; mainProgram = "xxv"; }; diff --git a/pkgs/by-name/xy/xylib/package.nix b/pkgs/by-name/xy/xylib/package.nix index ab2e3792eeabf3..50ac7586546a1a 100644 --- a/pkgs/by-name/xy/xylib/package.nix +++ b/pkgs/by-name/xy/xylib/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, boost -, zlib -, bzip2 -, wxGTK32 +{ + lib, + stdenv, + fetchurl, + boost, + zlib, + bzip2, + wxGTK32, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/xz/xzgv/package.nix b/pkgs/by-name/xz/xzgv/package.nix index 1617b6459d331e..1a782f83cff292 100644 --- a/pkgs/by-name/xz/xzgv/package.nix +++ b/pkgs/by-name/xz/xzgv/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, gtk2, libexif, pkg-config, texinfo }: +{ + lib, + stdenv, + fetchurl, + gtk2, + libexif, + pkg-config, + texinfo, +}: stdenv.mkDerivation rec { pname = "xzgv"; @@ -7,8 +15,14 @@ stdenv.mkDerivation rec { url = "mirror://sourceforge/xzgv/xzgv-${version}.tar.gz"; sha256 = "17l1xr9v07ggwga3vn0z1i4lnwjrr20rr8z1kjbw71aaijxl18i5"; }; - nativeBuildInputs = [ pkg-config texinfo ]; - buildInputs = [ gtk2 libexif ]; + nativeBuildInputs = [ + pkg-config + texinfo + ]; + buildInputs = [ + gtk2 + libexif + ]; postPatch = '' substituteInPlace config.mk \ --replace /usr/local $out diff --git a/pkgs/by-name/xz/xzoom/package.nix b/pkgs/by-name/xz/xzoom/package.nix index 0d32e509a139b9..6f456b8d8129d9 100644 --- a/pkgs/by-name/xz/xzoom/package.nix +++ b/pkgs/by-name/xz/xzoom/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, libX11, libXext, libXt, imake, gccmakedep}: +{ + lib, + stdenv, + fetchurl, + libX11, + libXext, + libXt, + imake, + gccmakedep, +}: stdenv.mkDerivation rec { pname = "xzoom"; @@ -12,25 +21,35 @@ stdenv.mkDerivation rec { }; patches = [ (fetchurl { - url = "http://http.debian.net/debian/pool/main/x/xzoom/xzoom_${version}-${patch}.diff.gz"; - sha256 = "0zhc06whbvaz987bzzzi2bz6h9jp6rv812qs7b71drivvd820qbh"; + url = "http://http.debian.net/debian/pool/main/x/xzoom/xzoom_${version}-${patch}.diff.gz"; + sha256 = "0zhc06whbvaz987bzzzi2bz6h9jp6rv812qs7b71drivvd820qbh"; }) ]; - nativeBuildInputs = [ imake gccmakedep ]; - buildInputs = [ libX11 libXext libXt ]; + nativeBuildInputs = [ + imake + gccmakedep + ]; + buildInputs = [ + libX11 + libXext + libXt + ]; makeFlags = [ "PREFIX=$(out)" "BINDIR=$(out)/bin" "MANPATH=$(out)/share/man" ]; - installTargets = [ "install" "install.man" ]; + installTargets = [ + "install" + "install.man" + ]; meta = { description = "X11 screen zoom tool"; - license = lib.licenses.free ; - maintainers = [lib.maintainers.raskin]; + license = lib.licenses.free; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; mainProgram = "xzoom"; }; diff --git a/pkgs/by-name/ya/yabasic/package.nix b/pkgs/by-name/ya/yabasic/package.nix index d5c2dbf2e4e979..677ac5be4b749c 100644 --- a/pkgs/by-name/ya/yabasic/package.nix +++ b/pkgs/by-name/ya/yabasic/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, libSM -, libX11 -, libXt -, libffi -, ncurses +{ + lib, + stdenv, + fetchurl, + libSM, + libX11, + libXt, + libffi, + ncurses, }: stdenv.mkDerivation (finalAttrs: { @@ -36,7 +37,7 @@ stdenv.mkDerivation (finalAttrs: { allows to create standalone programs. Yabasic runs under Unix and Windows and has a comprehensive documentation; it is small, simple, open-source and free. - ''; + ''; changelog = "https://2484.de/yabasic/whatsnew.html"; license = lib.licenses.mit; maintainers = with lib.maintainers; [ AndersonTorres ]; diff --git a/pkgs/by-name/ya/yad/package.nix b/pkgs/by-name/ya/yad/package.nix index 1a7d07ed510490..7b1bf736bcd004 100644 --- a/pkgs/by-name/ya/yad/package.nix +++ b/pkgs/by-name/ya/yad/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, intltool, autoreconfHook, wrapGAppsHook3 -, gtk3, hicolor-icon-theme, netpbm }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + intltool, + autoreconfHook, + wrapGAppsHook3, + gtk3, + hicolor-icon-theme, + netpbm, +}: stdenv.mkDerivation rec { pname = "yad"; @@ -18,9 +28,17 @@ stdenv.mkDerivation rec { "--with-rgb=${placeholder "out"}/share/yad/rgb.txt" ]; - buildInputs = [ gtk3 hicolor-icon-theme ]; + buildInputs = [ + gtk3 + hicolor-icon-theme + ]; - nativeBuildInputs = [ autoreconfHook pkg-config intltool wrapGAppsHook3 ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + intltool + wrapGAppsHook3 + ]; postPatch = '' sed -i src/file.c -e '21i#include ' diff --git a/pkgs/by-name/ya/yadm/package.nix b/pkgs/by-name/ya/yadm/package.nix index 0f3c4ef1db8e9c..b7bd0d18da74b3 100644 --- a/pkgs/by-name/ya/yadm/package.nix +++ b/pkgs/by-name/ya/yadm/package.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, resholve -, fetchFromGitHub -, git -, bash -, openssl -, gawk -/* -TODO: yadm can use git-crypt and transcrypt -but it does so in a way that resholve 0.6.0 -can't yet do anything smart about. It looks -like these are for interactive use, so the -main impact should just be that users still -need both of these packages in their profile -to support their use in yadm. -*/ -# , git-crypt -# , transcrypt -, j2cli -, esh -, gnupg -, coreutils -, gnutar -, installShellFiles -, runCommand -, yadm +{ + lib, + stdenv, + resholve, + fetchFromGitHub, + git, + bash, + openssl, + gawk, + /* + TODO: yadm can use git-crypt and transcrypt + but it does so in a way that resholve 0.6.0 + can't yet do anything smart about. It looks + like these are for interactive use, so the + main impact should just be that users still + need both of these packages in their profile + to support their use in yadm. + */ + # , git-crypt + # , transcrypt + j2cli, + esh, + gnupg, + coreutils, + gnutar, + installShellFiles, + runCommand, + yadm, }: resholve.mkDerivation rec { @@ -34,10 +35,10 @@ resholve.mkDerivation rec { nativeBuildInputs = [ installShellFiles ]; src = fetchFromGitHub { - owner = "TheLocehiliosan"; - repo = "yadm"; - rev = version; - hash = "sha256-VQhfRtg9wtquJGjhB8fFQqHIJ5GViMfNQQep13ZH5SE="; + owner = "TheLocehiliosan"; + repo = "yadm"; + rev = version; + hash = "sha256-VQhfRtg9wtquJGjhB8fFQqHIJ5GViMfNQQep13ZH5SE="; }; dontConfigure = true; @@ -103,8 +104,8 @@ resholve.mkDerivation rec { "$LSB_RELEASE_PROGRAM" = true; }; /* - TODO: these should be dropped as fast as they can be dealt - with properly in binlore and/or resholve. + TODO: these should be dropped as fast as they can be dealt + with properly in binlore and/or resholve. */ execer = [ "cannot:${j2cli}/bin/j2" @@ -116,7 +117,7 @@ resholve.mkDerivation rec { }; passthru.tests = { - minimal = runCommand "${pname}-test" {} '' + minimal = runCommand "${pname}-test" { } '' export HOME=$out ${yadm}/bin/yadm init ''; diff --git a/pkgs/by-name/ya/yaegi/package.nix b/pkgs/by-name/ya/yaegi/package.nix index 1721417e7ec910..50426b5d7946bd 100644 --- a/pkgs/by-name/ya/yaegi/package.nix +++ b/pkgs/by-name/ya/yaegi/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, yaegi +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + yaegi, }: buildGoModule rec { diff --git a/pkgs/by-name/ya/yaft/package.nix b/pkgs/by-name/ya/yaft/package.nix index c38d90bd4043b2..ceab3d6d8610d8 100644 --- a/pkgs/by-name/ya/yaft/package.nix +++ b/pkgs/by-name/ya/yaft/package.nix @@ -1,10 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, +}: stdenv.mkDerivation rec { version = "0.2.9"; pname = "yaft"; - outputs = [ "out" "terminfo" ]; + outputs = [ + "out" + "terminfo" + ]; src = fetchFromGitHub { owner = "uobikiemukot"; @@ -15,7 +23,10 @@ stdenv.mkDerivation rec { buildInputs = [ ncurses ]; - installFlags = [ "PREFIX=$(out)" "MANPREFIX=$(out)/share/man" ]; + installFlags = [ + "PREFIX=$(out)" + "MANPREFIX=$(out)/share/man" + ]; postInstall = '' mkdir -p $out/nix-support $terminfo/share diff --git a/pkgs/by-name/ya/yai/package.nix b/pkgs/by-name/ya/yai/package.nix index 958b88bc22976a..cad6fe75f8be5c 100644 --- a/pkgs/by-name/ya/yai/package.nix +++ b/pkgs/by-name/ya/yai/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { pname = "yai"; diff --git a/pkgs/by-name/ya/yajl/package.nix b/pkgs/by-name/ya/yajl/package.nix index 83aedce31ff854..e665ae8e662677 100644 --- a/pkgs/by-name/ya/yajl/package.nix +++ b/pkgs/by-name/ya/yajl/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, which, testers }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + which, + testers, +}: stdenv.mkDerivation (finalAttrs: { pname = "yajl"; diff --git a/pkgs/by-name/ya/yajsv/package.nix b/pkgs/by-name/ya/yajsv/package.nix index d6293c74399d29..6d08a5d87f269f 100644 --- a/pkgs/by-name/ya/yajsv/package.nix +++ b/pkgs/by-name/ya/yajsv/package.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: let version = "1.4.1"; @@ -16,7 +20,10 @@ buildGoModule { vendorHash = "sha256-f45climGKl7HxD+1vz2TGqW/d0dqJ0RfvgJoRRM6lUk="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; doInstallCheck = true; diff --git a/pkgs/by-name/ya/yallback/package.nix b/pkgs/by-name/ya/yallback/package.nix index 19ad53d038df66..b1b221fce7eccb 100644 --- a/pkgs/by-name/ya/yallback/package.nix +++ b/pkgs/by-name/ya/yallback/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, coreutils -, bashInteractive +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + coreutils, + bashInteractive, }: stdenv.mkDerivation rec { @@ -16,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-t+fdnDJMFiFqN23dSY3TnsZsIDcravtwdNKJ5MiZosE="; }; - buildInputs = [ coreutils bashInteractive ]; + buildInputs = [ + coreutils + bashInteractive + ]; nativeBuildInputs = [ makeWrapper ]; installPhase = '' diff --git a/pkgs/by-name/ya/yambar-hyprland-wses/package.nix b/pkgs/by-name/ya/yambar-hyprland-wses/package.nix index e64e8e13dec1ff..871c4cecf5f49b 100644 --- a/pkgs/by-name/ya/yambar-hyprland-wses/package.nix +++ b/pkgs/by-name/ya/yambar-hyprland-wses/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { meta = { description = "Enable Yambar to show Hyprland workspaces"; homepage = "https://github.com/jonhoo/yambar-hyprland-wses"; - license = with lib.licenses; [ asl20 mit ]; + license = with lib.licenses; [ + asl20 + mit + ]; maintainers = with lib.maintainers; [ ludovicopiero ]; mainProgram = "yambar-hyprland-wses"; platforms = lib.platforms.linux; diff --git a/pkgs/by-name/ya/yambar/package.nix b/pkgs/by-name/ya/yambar/package.nix index 776f5fdab24917..c87215b84b6627 100644 --- a/pkgs/by-name/ya/yambar/package.nix +++ b/pkgs/by-name/ya/yambar/package.nix @@ -1,31 +1,32 @@ -{ lib -, stdenv -, fetchFromGitea -, alsa-lib -, bison -, fcft -, flex -, json_c -, libmpdclient -, libyaml -, meson -, ninja -, pipewire -, pixman -, pkg-config -, pulseaudio -, scdoc -, tllist -, udev -, wayland -, wayland-protocols -, wayland-scanner -, xcbutil -, xcbutilcursor -, xcbutilerrors -, xcbutilwm -, waylandSupport ? true -, x11Support ? true +{ + lib, + stdenv, + fetchFromGitea, + alsa-lib, + bison, + fcft, + flex, + json_c, + libmpdclient, + libyaml, + meson, + ninja, + pipewire, + pixman, + pkg-config, + pulseaudio, + scdoc, + tllist, + udev, + wayland, + wayland-protocols, + wayland-scanner, + xcbutil, + xcbutilcursor, + xcbutilerrors, + xcbutilwm, + waylandSupport ? true, + x11Support ? true, }: assert (x11Support || waylandSupport); @@ -41,7 +42,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-QCwwMpBYuMWYqxE2ugPFpG/QtZDW7VsSBYs5EqKYejA="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; depsBuildBuild = [ pkg-config ]; @@ -55,26 +59,29 @@ stdenv.mkDerivation (finalAttrs: { wayland-scanner ]; - buildInputs = [ - alsa-lib - fcft - json_c - libmpdclient - libyaml - pipewire - pixman - pulseaudio - tllist - udev - ] ++ lib.optionals (waylandSupport) [ - wayland - wayland-protocols - ] ++ lib.optionals (x11Support) [ - xcbutil - xcbutilcursor - xcbutilerrors - xcbutilwm - ]; + buildInputs = + [ + alsa-lib + fcft + json_c + libmpdclient + libyaml + pipewire + pixman + pulseaudio + tllist + udev + ] + ++ lib.optionals (waylandSupport) [ + wayland + wayland-protocols + ] + ++ lib.optionals (x11Support) [ + xcbutil + xcbutilcursor + xcbutilerrors + xcbutilwm + ]; strictDeps = true; diff --git a/pkgs/by-name/ya/yamdi/package.nix b/pkgs/by-name/ya/yamdi/package.nix index 1bcfffb9290367..7c52cc4cccf96d 100644 --- a/pkgs/by-name/ya/yamdi/package.nix +++ b/pkgs/by-name/ya/yamdi/package.nix @@ -1,5 +1,6 @@ { - lib, stdenv, + lib, + stdenv, fetchurl, }: diff --git a/pkgs/by-name/ya/yaml-language-server/package.nix b/pkgs/by-name/ya/yaml-language-server/package.nix index 585ea255ef7d53..740c525f06b034 100644 --- a/pkgs/by-name/ya/yaml-language-server/package.nix +++ b/pkgs/by-name/ya/yaml-language-server/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, fetchYarnDeps -, fixup-yarn-lock -, makeWrapper -, nodejs -, stdenv -, yarn +{ + lib, + fetchFromGitHub, + fetchYarnDeps, + fixup-yarn-lock, + makeWrapper, + nodejs, + stdenv, + yarn, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ya/yaml-merge/package.nix b/pkgs/by-name/ya/yaml-merge/package.nix index a5113a92f7021c..c7983acbd2ac80 100644 --- a/pkgs/by-name/ya/yaml-merge/package.nix +++ b/pkgs/by-name/ya/yaml-merge/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3Packages }: +{ + lib, + stdenv, + fetchFromGitHub, + python3Packages, +}: stdenv.mkDerivation { pname = "yaml-merge"; @@ -12,7 +17,7 @@ stdenv.mkDerivation { }; pythonPath = with python3Packages; [ pyyaml ]; - nativeBuildInputs = with python3Packages; [ wrapPython ]; + nativeBuildInputs = with python3Packages; [ wrapPython ]; installPhase = '' install -Dm755 yaml-merge.py $out/bin/yaml-merge diff --git a/pkgs/by-name/ya/yaml2json/package.nix b/pkgs/by-name/ya/yaml2json/package.nix index 74775dd605f4f3..c77b88f3d2a308 100644 --- a/pkgs/by-name/ya/yaml2json/package.nix +++ b/pkgs/by-name/ya/yaml2json/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "yaml2json"; @@ -15,7 +19,10 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://github.com/bronze1man/yaml2json"; diff --git a/pkgs/by-name/ya/yamlpath/package.nix b/pkgs/by-name/ya/yamlpath/package.nix index 8bb0fcc8311c96..3d3c047bb228cb 100644 --- a/pkgs/by-name/ya/yamlpath/package.nix +++ b/pkgs/by-name/ya/yamlpath/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, hiera-eyaml -, python3 +{ + lib, + fetchFromGitHub, + hiera-eyaml, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -43,12 +44,12 @@ python3.pkgs.buildPythonApplication rec { longDescription = '' Command-line get/set/merge/validate/scan/convert/diff processors for YAML/JSON/Compatible data using powerful, intuitive, command-line friendly syntax - ''; + ''; license = licenses.isc; maintainers = with maintainers; [ Flakebi ]; - # No support for ruamel.yaml > 0.17.21 - # https://github.com/wwkimball/yamlpath/issues/217 + # No support for ruamel.yaml > 0.17.21 + # https://github.com/wwkimball/yamlpath/issues/217 broken = true; }; } diff --git a/pkgs/by-name/ya/yams/package.nix b/pkgs/by-name/ya/yams/package.nix index e4afe4ad2729ca..713d8a96b76288 100644 --- a/pkgs/by-name/ya/yams/package.nix +++ b/pkgs/by-name/ya/yams/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonPackage rec { pname = "yams"; diff --git a/pkgs/by-name/ya/yanic/package.nix b/pkgs/by-name/ya/yanic/package.nix index 459963c1930325..5ac0ff685481d1 100644 --- a/pkgs/by-name/ya/yanic/package.nix +++ b/pkgs/by-name/ya/yanic/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/by-name/ya/yank/package.nix b/pkgs/by-name/ya/yank/package.nix index 50d883759130fb..8cdc1dc8aeb700 100644 --- a/pkgs/by-name/ya/yank/package.nix +++ b/pkgs/by-name/ya/yank/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, xsel }: +{ + lib, + stdenv, + fetchFromGitHub, + xsel, +}: stdenv.mkDerivation rec { pname = "yank"; diff --git a/pkgs/by-name/ya/yanone-kaffeesatz/package.nix b/pkgs/by-name/ya/yanone-kaffeesatz/package.nix index 8fced0b73a63da..0c68556eb0123c 100644 --- a/pkgs/by-name/ya/yanone-kaffeesatz/package.nix +++ b/pkgs/by-name/ya/yanone-kaffeesatz/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "yanone-kaffeesatz"; diff --git a/pkgs/by-name/ya/yap/package.nix b/pkgs/by-name/ya/yap/package.nix index d58f2e9d728db3..28fd6dabcd929c 100644 --- a/pkgs/by-name/ya/yap/package.nix +++ b/pkgs/by-name/ya/yap/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, readline, gmp, zlib }: +{ + lib, + stdenv, + fetchurl, + readline, + gmp, + zlib, +}: stdenv.mkDerivation rec { version = "6.3.3"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "0y7sjwimadqsvgx9daz28c9mxcx9n1znxklih9xg16k6n54v9qxf"; }; - buildInputs = [ readline gmp zlib ]; + buildInputs = [ + readline + gmp + zlib + ]; configureFlags = [ "--enable-tabling=yes" ]; @@ -21,7 +32,8 @@ stdenv.mkDerivation rec { meta = { # the linux 32 bit build fails. - broken = (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) || !stdenv.hostPlatform.is64bit; + broken = + (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) || !stdenv.hostPlatform.is64bit; homepage = "http://www.dcc.fc.up.pt/~vsc/Yap/"; description = "ISO-compatible high-performance Prolog compiler"; license = lib.licenses.artistic2; diff --git a/pkgs/by-name/ya/yapesdl/package.nix b/pkgs/by-name/ya/yapesdl/package.nix index 9b974c3eebe258..5a3bc20c131152 100644 --- a/pkgs/by-name/ya/yapesdl/package.nix +++ b/pkgs/by-name/ya/yapesdl/package.nix @@ -28,7 +28,10 @@ stdenv.mkDerivation (finalAttrs: { makeFlags = [ "CC=${stdenv.cc.targetPrefix}c++" ]; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; strictDeps = true; diff --git a/pkgs/by-name/ya/yarGen/package.nix b/pkgs/by-name/ya/yarGen/package.nix index d1bc8a864721ac..0c3bb3b5eeff43 100644 --- a/pkgs/by-name/ya/yarGen/package.nix +++ b/pkgs/by-name/ya/yarGen/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchFromGitHub -, fetchpatch +{ + lib, + python3, + fetchFromGitHub, + fetchpatch, }: python3.pkgs.buildPythonApplication rec { pname = "yarGen"; diff --git a/pkgs/by-name/ya/yara-x/package.nix b/pkgs/by-name/ya/yara-x/package.nix index 88d9b32bcf165b..ba34ef4c1d4ff0 100644 --- a/pkgs/by-name/ya/yara-x/package.nix +++ b/pkgs/by-name/ya/yara-x/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, cmake -, installShellFiles -, testers -, yara-x +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + cmake, + installShellFiles, + testers, + yara-x, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-iWgfI5jiEbBHkew82Ej7Ku17JDVI4O0iiOxs9lxEJS4="; - nativeBuildInputs = [ cmake installShellFiles ]; + nativeBuildInputs = [ + cmake + installShellFiles + ]; postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' installShellCompletion --cmd yr \ @@ -39,7 +43,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://virustotal.github.io/yara-x/"; changelog = "https://github.com/VirusTotal/yara-x/releases/tag/v${version}"; license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [ fab lesuisse ]; + maintainers = with lib.maintainers; [ + fab + lesuisse + ]; mainProgram = "yr"; }; } diff --git a/pkgs/by-name/ya/yaralyzer/package.nix b/pkgs/by-name/ya/yaralyzer/package.nix index 9854a696ac991f..fe97dc6ec303f8 100644 --- a/pkgs/by-name/ya/yaralyzer/package.nix +++ b/pkgs/by-name/ya/yaralyzer/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ya/yarn-bash-completion/package.nix b/pkgs/by-name/ya/yarn-bash-completion/package.nix index 48d1f42b5cedbd..748db1f186f0dc 100644 --- a/pkgs/by-name/ya/yarn-bash-completion/package.nix +++ b/pkgs/by-name/ya/yarn-bash-completion/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ya/yarn/package.nix b/pkgs/by-name/ya/yarn/package.nix index e8bf911a708118..417af7120d421b 100644 --- a/pkgs/by-name/ya/yarn/package.nix +++ b/pkgs/by-name/ya/yarn/package.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, fetchzip -, nodejs -, stdenvNoCC -, testers -, gitUpdater -, withNode ? true +{ + lib, + fetchFromGitHub, + fetchzip, + nodejs, + stdenvNoCC, + testers, + gitUpdater, + withNode ? true, }: let @@ -36,9 +37,11 @@ stdenvNoCC.mkDerivation (finalAttrs: { ''; passthru = { - tests.version = lib.optionalAttrs withNode (testers.testVersion { - package = finalAttrs.finalPackage; - }); + tests.version = lib.optionalAttrs withNode ( + testers.testVersion { + package = finalAttrs.finalPackage; + } + ); updateScript = gitUpdater { url = "https://github.com/yarnpkg/yarn.git"; @@ -51,7 +54,10 @@ stdenvNoCC.mkDerivation (finalAttrs: { homepage = "https://classic.yarnpkg.com/"; changelog = "https://github.com/yarnpkg/yarn/blob/v${finalAttrs.version}/CHANGELOG.md"; license = licenses.bsd2; - maintainers = with maintainers; [ offline screendriver ]; + maintainers = with maintainers; [ + offline + screendriver + ]; platforms = platforms.all; mainProgram = "yarn"; }; diff --git a/pkgs/by-name/ya/yarp/package.nix b/pkgs/by-name/ya/yarp/package.nix index 4f2e45384b76cc..f14e40f931fa85 100644 --- a/pkgs/by-name/ya/yarp/package.nix +++ b/pkgs/by-name/ya/yarp/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake, ace +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ace, }: stdenv.mkDerivation rec { @@ -31,4 +36,3 @@ stdenv.mkDerivation rec { maintainers = [ lib.maintainers.nico202 ]; }; } - diff --git a/pkgs/by-name/ya/yarr/package.nix b/pkgs/by-name/ya/yarr/package.nix index 205e52012cd7db..e8f39fb3cc1a71 100644 --- a/pkgs/by-name/ya/yarr/package.nix +++ b/pkgs/by-name/ya/yarr/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, yarr }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + yarr, +}: buildGoModule rec { pname = "yarr"; @@ -15,9 +21,17 @@ buildGoModule rec { subPackages = [ "src" ]; - ldflags = [ "-s" "-w" "-X main.Version=${version}" "-X main.GitHash=none" ]; - - tags = [ "sqlite_foreign_keys" "release" ]; + ldflags = [ + "-s" + "-w" + "-X main.Version=${version}" + "-X main.GitHash=none" + ]; + + tags = [ + "sqlite_foreign_keys" + "release" + ]; postInstall = '' mv $out/bin/{src,yarr} diff --git a/pkgs/by-name/ya/yaru-remix-theme/package.nix b/pkgs/by-name/ya/yaru-remix-theme/package.nix index b49236d36e9b61..281ada4dac3581 100644 --- a/pkgs/by-name/ya/yaru-remix-theme/package.nix +++ b/pkgs/by-name/ya/yaru-remix-theme/package.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, meson, sassc, pkg-config, glib, ninja, python3, gtk3, gnome, gnome-themes-extra }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + sassc, + pkg-config, + glib, + ninja, + python3, + gtk3, + gnome, + gnome-themes-extra, +}: stdenv.mkDerivation rec { pname = "yaru-remix"; @@ -11,8 +24,18 @@ stdenv.mkDerivation rec { sha256 = "0xilhw5gbxsyy80ixxgj0nw6w782lz9dsinhi24026li1xny804c"; }; - nativeBuildInputs = [ meson sassc pkg-config glib ninja python3 ]; - buildInputs = [ gtk3 gnome-themes-extra ]; + nativeBuildInputs = [ + meson + sassc + pkg-config + glib + ninja + python3 + ]; + buildInputs = [ + gtk3 + gnome-themes-extra + ]; dontDropIconThemeCache = true; @@ -21,7 +44,12 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Fork of the Yaru GTK theme"; homepage = "https://github.com/Muqtxdir/yaru-remix"; - license = with licenses; [ cc-by-sa-40 gpl3Plus lgpl21Only lgpl3Only ]; + license = with licenses; [ + cc-by-sa-40 + gpl3Plus + lgpl21Only + lgpl3Only + ]; platforms = platforms.linux; maintainers = with maintainers; [ hoppla20 ]; }; diff --git a/pkgs/by-name/ya/yaru-theme/package.nix b/pkgs/by-name/ya/yaru-theme/package.nix index 9a059aa9dcc13e..8f19ee0b55b09e 100644 --- a/pkgs/by-name/ya/yaru-theme/package.nix +++ b/pkgs/by-name/ya/yaru-theme/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, sassc -, pkg-config -, glib -, ninja -, python3 -, gtk3 -, gnome-themes-extra -, gtk-engine-murrine -, humanity-icon-theme -, hicolor-icon-theme +{ + lib, + stdenv, + fetchFromGitHub, + meson, + sassc, + pkg-config, + glib, + ninja, + python3, + gtk3, + gnome-themes-extra, + gtk-engine-murrine, + humanity-icon-theme, + hicolor-icon-theme, }: stdenv.mkDerivation rec { @@ -25,9 +26,22 @@ stdenv.mkDerivation rec { hash = "sha256-ioBni/prc2HzrXd6zBgZQQsfQDWxlfWOphtY0o/8uM0="; }; - nativeBuildInputs = [ meson sassc pkg-config glib ninja python3 ]; - buildInputs = [ gtk3 gnome-themes-extra ]; - propagatedBuildInputs = [ humanity-icon-theme hicolor-icon-theme ]; + nativeBuildInputs = [ + meson + sassc + pkg-config + glib + ninja + python3 + ]; + buildInputs = [ + gtk3 + gnome-themes-extra + ]; + propagatedBuildInputs = [ + humanity-icon-theme + hicolor-icon-theme + ]; propagatedUserEnvPkgs = [ gtk-engine-murrine ]; dontDropIconThemeCache = true; @@ -37,7 +51,12 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Ubuntu community theme 'yaru' - default Ubuntu theme since 18.10"; homepage = "https://github.com/ubuntu/yaru"; - license = with licenses; [ cc-by-sa-40 gpl3Plus lgpl21Only lgpl3Only ]; + license = with licenses; [ + cc-by-sa-40 + gpl3Plus + lgpl21Only + lgpl3Only + ]; platforms = platforms.linux; maintainers = with maintainers; [ moni ]; }; diff --git a/pkgs/by-name/ya/yas/package.nix b/pkgs/by-name/ya/yas/package.nix index 0dad3fbf76dd07..e394d342a5020b 100644 --- a/pkgs/by-name/ya/yas/package.nix +++ b/pkgs/by-name/ya/yas/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "yas"; diff --git a/pkgs/by-name/ya/yasashisa-gothic/package.nix b/pkgs/by-name/ya/yasashisa-gothic/package.nix index 20a629707f8dde..84771fd9d3158f 100644 --- a/pkgs/by-name/ya/yasashisa-gothic/package.nix +++ b/pkgs/by-name/ya/yasashisa-gothic/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, unzrip +{ + lib, + stdenvNoCC, + fetchurl, + unzrip, }: stdenvNoCC.mkDerivation { @@ -33,7 +34,10 @@ stdenvNoCC.mkDerivation { meta = with lib; { description = "Free gothic style font by Fontna"; homepage = "http://www.fontna.com/blog/379/"; - license = with licenses; [ ipa mplus ]; + license = with licenses; [ + ipa + mplus + ]; platforms = platforms.all; maintainers = with maintainers; [ h7x4 ]; }; diff --git a/pkgs/by-name/ya/yascreen/package.nix b/pkgs/by-name/ya/yascreen/package.nix index d1b96ac3ebe3d8..5a83c9b8884cd7 100644 --- a/pkgs/by-name/ya/yascreen/package.nix +++ b/pkgs/by-name/ya/yascreen/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, go-md2man, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + go-md2man, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "yascreen"; diff --git a/pkgs/by-name/ya/yash/package.nix b/pkgs/by-name/ya/yash/package.nix index 3e57b7b9a0fb2a..d3196034f355b2 100644 --- a/pkgs/by-name/ya/yash/package.nix +++ b/pkgs/by-name/ya/yash/package.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, gettext, ncurses, asciidoc }: +{ + stdenv, + lib, + fetchFromGitHub, + gettext, + ncurses, + asciidoc, +}: stdenv.mkDerivation rec { pname = "yash"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ asciidoc gettext ]; + nativeBuildInputs = [ + asciidoc + gettext + ]; buildInputs = [ ncurses ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ gettext ]; meta = with lib; { diff --git a/pkgs/by-name/ya/yasm/package.nix b/pkgs/by-name/ya/yasm/package.nix index 58b8252729a7d3..3577781c9818fd 100644 --- a/pkgs/by-name/ya/yasm/package.nix +++ b/pkgs/by-name/ya/yasm/package.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, buildPackages}: +{ + lib, + stdenv, + fetchurl, + buildPackages, +}: stdenv.mkDerivation rec { pname = "yasm"; diff --git a/pkgs/by-name/ya/yasr/package.nix b/pkgs/by-name/ya/yasr/package.nix index da18f0cc825e61..604bb3691a2ed8 100644 --- a/pkgs/by-name/ya/yasr/package.nix +++ b/pkgs/by-name/ya/yasr/package.nix @@ -1,4 +1,8 @@ -{lib, stdenv,fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "yasr"; diff --git a/pkgs/by-name/ya/yatas/package.nix b/pkgs/by-name/ya/yatas/package.nix index e351ea244f5de5..987fac48d0a779 100644 --- a/pkgs/by-name/ya/yatas/package.nix +++ b/pkgs/by-name/ya/yatas/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ya/yate/package.nix b/pkgs/by-name/ya/yate/package.nix index 76eb27a624cc64..afa83f56807356 100644 --- a/pkgs/by-name/ya/yate/package.nix +++ b/pkgs/by-name/ya/yate/package.nix @@ -1,4 +1,10 @@ -{ stdenv, fetchurl, lib, openssl, pkg-config }: +{ + stdenv, + fetchurl, + lib, + openssl, + pkg-config, +}: stdenv.mkDerivation rec { pname = "yate"; @@ -14,22 +20,20 @@ stdenv.mkDerivation rec { buildInputs = [ openssl ]; # /dev/null is used when linking which is a impure path for the wrapper - postPatch = - '' - patchShebangs configure - substituteInPlace configure --replace ",/dev/null" "" - ''; + postPatch = '' + patchShebangs configure + substituteInPlace configure --replace ",/dev/null" "" + ''; enableParallelBuilding = false; # fails to build if true # --unresolved-symbols=ignore-in-shared-libs makes ld no longer find --library=yate? Why? - preBuild = - '' - export NIX_LDFLAGS="-L$TMP/yate $NIX_LDFLAGS" - find . -type f -iname Makefile | xargs sed -i \ - -e 's@-Wl,--unresolved-symbols=ignore-in-shared-libs@@' \ - -e 's@-Wl,--retain-symbols-file@@' - ''; + preBuild = '' + export NIX_LDFLAGS="-L$TMP/yate $NIX_LDFLAGS" + find . -type f -iname Makefile | xargs sed -i \ + -e 's@-Wl,--unresolved-symbols=ignore-in-shared-libs@@' \ + -e 's@-Wl,--retain-symbols-file@@' + ''; meta = { description = "Yet another telephony engine"; @@ -38,7 +42,10 @@ stdenv.mkDerivation rec { # OpenH323 and PWlib (licensed under MPL). license = lib.licenses.gpl2Only; maintainers = [ lib.maintainers.marcweber ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/by-name/ya/yaup/package.nix b/pkgs/by-name/ya/yaup/package.nix index d2fa2778fc8759..367af835faa9a7 100644 --- a/pkgs/by-name/ya/yaup/package.nix +++ b/pkgs/by-name/ya/yaup/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch2 -, intltool -, pkg-config -, wrapGAppsHook3 -, gtk3 -, miniupnpc +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch2, + intltool, + pkg-config, + wrapGAppsHook3, + gtk3, + miniupnpc, }: stdenv.mkDerivation { diff --git a/pkgs/by-name/ya/yaws/package.nix b/pkgs/by-name/ya/yaws/package.nix index f92db7be0852a2..db34b0e9201409 100644 --- a/pkgs/by-name/ya/yaws/package.nix +++ b/pkgs/by-name/ya/yaws/package.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchFromGitHub, erlang, pam, perl, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + erlang, + pam, + perl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "yaws"; @@ -14,7 +22,11 @@ stdenv.mkDerivation rec { configureFlags = [ "--with-extrainclude=${pam}/include/security" ]; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ erlang pam perl ]; + buildInputs = [ + erlang + pam + perl + ]; postInstall = '' sed -i "s#which #type -P #" $out/bin/yaws diff --git a/pkgs/by-name/ya/yaxg/package.nix b/pkgs/by-name/ya/yaxg/package.nix index dd428ae0c427f9..22e81b3b2268c1 100644 --- a/pkgs/by-name/ya/yaxg/package.nix +++ b/pkgs/by-name/ya/yaxg/package.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, - maim, slop, ffmpeg, byzanz, libnotify, xdpyinfo }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + maim, + slop, + ffmpeg, + byzanz, + libnotify, + xdpyinfo, +}: stdenv.mkDerivation rec { pname = "yaxg"; @@ -13,13 +23,29 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ maim slop ffmpeg byzanz libnotify xdpyinfo ]; + buildInputs = [ + maim + slop + ffmpeg + byzanz + libnotify + xdpyinfo + ]; installPhase = '' mkdir -p $out/bin/ mv yaxg $out/bin/ chmod +x $out/bin/yaxg - wrapProgram $out/bin/yaxg --prefix PATH : ${ lib.makeBinPath [ maim slop ffmpeg byzanz libnotify xdpyinfo ]} + wrapProgram $out/bin/yaxg --prefix PATH : ${ + lib.makeBinPath [ + maim + slop + ffmpeg + byzanz + libnotify + xdpyinfo + ] + } ''; meta = with lib; { diff --git a/pkgs/by-name/yd/yder/package.nix b/pkgs/by-name/yd/yder/package.nix index 70105872ba7733..6fed9bfee532bd 100644 --- a/pkgs/by-name/yd/yder/package.nix +++ b/pkgs/by-name/yd/yder/package.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, orcania -, systemd -, check -, subunit -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + orcania, + systemd, + check, + subunit, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, }: stdenv.mkDerivation rec { @@ -28,10 +29,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ orcania ] - ++ lib.optional withSystemd systemd; + buildInputs = [ orcania ] ++ lib.optional withSystemd systemd; - nativeCheckInputs = [ check subunit ]; + nativeCheckInputs = [ + check + subunit + ]; cmakeFlags = [ "-DBUILD_YDER_TESTING=on" diff --git a/pkgs/by-name/yd/ydict/package.nix b/pkgs/by-name/yd/ydict/package.nix index 0d52c230a423a2..9ceb25b0d99bb8 100644 --- a/pkgs/by-name/yd/ydict/package.nix +++ b/pkgs/by-name/yd/ydict/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, makeWrapper -, mpg123 +{ + lib, + fetchFromGitHub, + buildGoModule, + makeWrapper, + mpg123, }: buildGoModule rec { diff --git a/pkgs/by-name/ye/yeahwm/package.nix b/pkgs/by-name/ye/yeahwm/package.nix index 7198447f40c7e9..15cb8e7f852961 100644 --- a/pkgs/by-name/ye/yeahwm/package.nix +++ b/pkgs/by-name/ye/yeahwm/package.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, installShellFiles -, lesstif -, libX11 -, libXext -, libXinerama -, libXmu +{ + lib, + stdenv, + fetchurl, + installShellFiles, + lesstif, + libX11, + libXext, + libXinerama, + libXmu, }: stdenv.mkDerivation (finalAttrs: { @@ -32,20 +33,22 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - preBuild = let - includes = builtins.concatStringsSep " " - (builtins.map (l: "-I${lib.getDev l}/include") - finalAttrs.buildInputs); - ldpath = builtins.concatStringsSep " " - (builtins.map (l: "-L${lib.getLib l}/lib") - finalAttrs.buildInputs); - in '' - makeFlagsArray+=( CC="${stdenv.cc}/bin/cc" \ - XROOT="${libX11}" \ - INCLUDES="${includes}" \ - LDPATH="${ldpath}" \ - prefix="${placeholder "out"}" ) - ''; + preBuild = + let + includes = builtins.concatStringsSep " " ( + builtins.map (l: "-I${lib.getDev l}/include") finalAttrs.buildInputs + ); + ldpath = builtins.concatStringsSep " " ( + builtins.map (l: "-L${lib.getLib l}/lib") finalAttrs.buildInputs + ); + in + '' + makeFlagsArray+=( CC="${stdenv.cc}/bin/cc" \ + XROOT="${libX11}" \ + INCLUDES="${includes}" \ + LDPATH="${ldpath}" \ + prefix="${placeholder "out"}" ) + ''; # Workaround build failure on -fno-common toolchains like upstream gcc-10. # Otherwise build fails as: diff --git a/pkgs/by-name/ye/yed/package.nix b/pkgs/by-name/ye/yed/package.nix index ee4030053b6771..39f81c9221400f 100644 --- a/pkgs/by-name/ye/yed/package.nix +++ b/pkgs/by-name/ye/yed/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchzip, makeWrapper, unzip, jre, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchzip, + makeWrapper, + unzip, + jre, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "yEd"; @@ -9,7 +17,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-4aotsOippuKUucweWERtqm/5pz2gwW1Sue48KPisQ0I="; }; - nativeBuildInputs = [ makeWrapper unzip wrapGAppsHook3 ]; + nativeBuildInputs = [ + makeWrapper + unzip + wrapGAppsHook3 + ]; # For wrapGAppsHook3 setup hook buildInputs = [ (jre.gtk3 or null) ]; diff --git a/pkgs/by-name/ye/yeetgif/package.nix b/pkgs/by-name/ye/yeetgif/package.nix index 6e3b7ecee39fa6..42395ceaa54d74 100644 --- a/pkgs/by-name/ye/yeetgif/package.nix +++ b/pkgs/by-name/ye/yeetgif/package.nix @@ -1,4 +1,9 @@ -{ buildGoModule, fetchFromGitHub, fetchpatch, lib }: +{ + buildGoModule, + fetchFromGitHub, + fetchpatch, + lib, +}: buildGoModule rec { pname = "yeetgif"; @@ -22,12 +27,19 @@ buildGoModule rec { }) ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "gif effects CLI. single binary, no dependencies. linux, osx, windows. #1 workplace productivity booster. #yeetgif #eggplant #golang"; homepage = "https://github.com/sgreben/yeetgif"; - license = with licenses; [ mit asl20 cc-by-nc-sa-40 ]; + license = with licenses; [ + mit + asl20 + cc-by-nc-sa-40 + ]; maintainers = with maintainers; [ ajs124 ]; mainProgram = "gif"; }; diff --git a/pkgs/by-name/ye/yelp-tools/package.nix b/pkgs/by-name/ye/yelp-tools/package.nix index 4ad4b4e806ffb3..3d94ad56622db6 100644 --- a/pkgs/by-name/ye/yelp-tools/package.nix +++ b/pkgs/by-name/ye/yelp-tools/package.nix @@ -1,14 +1,15 @@ -{ lib -, fetchurl -, libxml2 -, libxslt -, itstool -, gnome -, pkg-config -, meson -, ninja -, python3 -, yelp-xsl +{ + lib, + fetchurl, + libxml2, + libxslt, + itstool, + gnome, + pkg-config, + meson, + ninja, + python3, + yelp-xsl, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/ye/yelp-xsl/package.nix b/pkgs/by-name/ye/yelp-xsl/package.nix index 7f255d9c5671fe..613e12f0a561cc 100644 --- a/pkgs/by-name/ye/yelp-xsl/package.nix +++ b/pkgs/by-name/ye/yelp-xsl/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, gettext -, fetchurl -, pkg-config -, itstool -, libxml2 -, libxslt -, gnome +{ + lib, + stdenv, + gettext, + fetchurl, + pkg-config, + itstool, + libxml2, + libxslt, + gnome, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ye/yelp/package.nix b/pkgs/by-name/ye/yelp/package.nix index 4e95d25991427e..652cc277ae9a78 100644 --- a/pkgs/by-name/ye/yelp/package.nix +++ b/pkgs/by-name/ye/yelp/package.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, gettext -, fetchurl -, webkitgtk_4_1 -, pkg-config -, gtk3 -, libhandy -, glib -, gnome -, adwaita-icon-theme -, sqlite -, itstool -, libxml2 -, libxslt -, gst_all_1 -, wrapGAppsHook3 -, yelp-xsl +{ + lib, + stdenv, + gettext, + fetchurl, + webkitgtk_4_1, + pkg-config, + gtk3, + libhandy, + glib, + gnome, + adwaita-icon-theme, + sqlite, + itstool, + libxml2, + libxslt, + gst_all_1, + wrapGAppsHook3, + yelp-xsl, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/ye/yersinia/package.nix b/pkgs/by-name/ye/yersinia/package.nix index cc17452a969242..487e93078564e7 100644 --- a/pkgs/by-name/ye/yersinia/package.nix +++ b/pkgs/by-name/ye/yersinia/package.nix @@ -1,9 +1,17 @@ -{ stdenv, lib, fetchFromGitHub, autoreconfHook, pkg-config -, ncurses, libpcap, libnet -# alpha version of GTK interface -, withGtk ? false, gtk2 -# enable remote admin interface -, enableAdmin ? false +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + pkg-config, + ncurses, + libpcap, + libnet, + # alpha version of GTK interface + withGtk ? false, + gtk2, + # enable remote admin interface + enableAdmin ? false, }: stdenv.mkDerivation rec { @@ -17,18 +25,25 @@ stdenv.mkDerivation rec { sha256 = "sha256-VShg9Nzd8dzUNiqYnKcDzRgqjwar/8XRGEJCJL25aR0="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libpcap libnet ncurses ] - ++ lib.optional withGtk gtk2; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + libpcap + libnet + ncurses + ] ++ lib.optional withGtk gtk2; autoreconfPhase = "./autogen.sh"; - configureFlags = [ - "--with-pcap-includes=${libpcap}/include" - "--with-libnet-includes=${libnet}/include" - ] - ++ lib.optional (!enableAdmin) "--disable-admin" - ++ lib.optional (!withGtk) "--disable-gtk"; + configureFlags = + [ + "--with-pcap-includes=${libpcap}/include" + "--with-libnet-includes=${libnet}/include" + ] + ++ lib.optional (!enableAdmin) "--disable-admin" + ++ lib.optional (!withGtk) "--disable-gtk"; makeFlags = [ "LDFLAGS=-lncurses" ]; diff --git a/pkgs/by-name/ye/yeshup/package.nix b/pkgs/by-name/ye/yeshup/package.nix index 723021d0ee74a9..6d3e5168badd27 100644 --- a/pkgs/by-name/ye/yeshup/package.nix +++ b/pkgs/by-name/ye/yeshup/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "yeshup"; @@ -6,7 +10,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "RhysU"; - repo = "yeshup"; + repo = "yeshup"; rev = "5461a8f957c686ccd0240be3f0fd8124d7381b08"; sha256 = "1wwbc158y46jsmdi1lp0m3dlbr9kvzvwxfvzj6646cpy9d6h21v9"; }; diff --git a/pkgs/by-name/ye/yesplaymusic/package.nix b/pkgs/by-name/ye/yesplaymusic/package.nix index c10184161f934f..78b47a99ac9966 100644 --- a/pkgs/by-name/ye/yesplaymusic/package.nix +++ b/pkgs/by-name/ye/yesplaymusic/package.nix @@ -1,51 +1,55 @@ -{ lib -, stdenv -, fetchurl -, _7zz -, dpkg -, autoPatchelfHook -, wrapGAppsHook3 -, makeWrapper -, alsa-lib -, at-spi2-atk -, cups -, nspr -, nss -, mesa # for libgbm -, xorg -, xdg-utils -, libdrm -, libnotify -, libsecret -, libuuid -, gtk3 -, systemd +{ + lib, + stdenv, + fetchurl, + _7zz, + dpkg, + autoPatchelfHook, + wrapGAppsHook3, + makeWrapper, + alsa-lib, + at-spi2-atk, + cups, + nspr, + nss, + mesa, # for libgbm + xorg, + xdg-utils, + libdrm, + libnotify, + libsecret, + libuuid, + gtk3, + systemd, }: let pname = "yesplaymusic"; version = "0.4.8-2"; - srcs = let - version' = lib.head (lib.splitString "-" version); - in { - x86_64-linux = fetchurl { - url = "https://github.com/qier222/YesPlayMusic/releases/download/v${version}/yesplaymusic_${version'}_amd64.deb"; - hash = "sha256-iTWi+tZGUQU7J1mcmMdlWXSKpYGy4mMAeq9CN9fhnZ8="; + srcs = + let + version' = lib.head (lib.splitString "-" version); + in + { + x86_64-linux = fetchurl { + url = "https://github.com/qier222/YesPlayMusic/releases/download/v${version}/yesplaymusic_${version'}_amd64.deb"; + hash = "sha256-iTWi+tZGUQU7J1mcmMdlWXSKpYGy4mMAeq9CN9fhnZ8="; + }; + aarch64-linux = fetchurl { + url = "https://github.com/qier222/YesPlayMusic/releases/download/v${version}/yesplaymusic_${version'}_arm64.deb"; + hash = "sha256-PP0apybSORqleOBogldgIV1tYZqao8kZ474muAEDpd0"; + }; + x86_64-darwin = fetchurl { + url = "https://github.com/qier222/YesPlayMusic/releases/download/v${version}/YesPlayMusic-mac-${version'}-x64.dmg"; + hash = "sha256-UHnEdoXT/vArSRKXPlfDYUUUMDyF2mnDsmJEjACW2vo="; + }; + aarch64-darwin = fetchurl { + url = "https://github.com/qier222/YesPlayMusic/releases/download/v${version}/YesPlayMusic-mac-${version'}-arm64.dmg"; + hash = "sha256-FaeumNmkPQYj9Ae2Xw/eKUuezR4bEdni8li+NRU9i1k="; + }; }; - aarch64-linux = fetchurl { - url = "https://github.com/qier222/YesPlayMusic/releases/download/v${version}/yesplaymusic_${version'}_arm64.deb"; - hash = "sha256-PP0apybSORqleOBogldgIV1tYZqao8kZ474muAEDpd0"; - }; - x86_64-darwin = fetchurl { - url = "https://github.com/qier222/YesPlayMusic/releases/download/v${version}/YesPlayMusic-mac-${version'}-x64.dmg"; - hash = "sha256-UHnEdoXT/vArSRKXPlfDYUUUMDyF2mnDsmJEjACW2vo="; - }; - aarch64-darwin = fetchurl { - url = "https://github.com/qier222/YesPlayMusic/releases/download/v${version}/YesPlayMusic-mac-${version'}-arm64.dmg"; - hash = "sha256-FaeumNmkPQYj9Ae2Xw/eKUuezR4bEdni8li+NRU9i1k="; - }; - }; - src = srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + srcs.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); libraries = [ alsa-lib @@ -74,53 +78,67 @@ let platforms = builtins.attrNames srcs; }; in -if stdenv.hostPlatform.isDarwin -then stdenv.mkDerivation { - inherit pname version src meta; +if stdenv.hostPlatform.isDarwin then + stdenv.mkDerivation { + inherit + pname + version + src + meta + ; - nativeBuildInputs = [ _7zz makeWrapper ]; + nativeBuildInputs = [ + _7zz + makeWrapper + ]; - sourceRoot = "."; + sourceRoot = "."; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $out/Applications - cp -r *.app $out/Applications + mkdir -p $out/Applications + cp -r *.app $out/Applications - makeWrapper $out/Applications/YesPlayMusic.app/Contents/MacOS/YesPlayMusic $out/bin/yesplaymusic + makeWrapper $out/Applications/YesPlayMusic.app/Contents/MacOS/YesPlayMusic $out/bin/yesplaymusic - runHook postInstall - ''; -} -else stdenv.mkDerivation { - inherit pname version src meta; + runHook postInstall + ''; + } +else + stdenv.mkDerivation { + inherit + pname + version + src + meta + ; - nativeBuildInputs = [ - autoPatchelfHook - wrapGAppsHook3 - makeWrapper - dpkg - ]; + nativeBuildInputs = [ + autoPatchelfHook + wrapGAppsHook3 + makeWrapper + dpkg + ]; - buildInputs = libraries; + buildInputs = libraries; - runtimeDependencies = [ - (lib.getLib systemd) - ]; + runtimeDependencies = [ + (lib.getLib systemd) + ]; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $out/bin - cp -r opt $out/opt - cp -r usr/share $out/share - substituteInPlace $out/share/applications/yesplaymusic.desktop \ - --replace "/opt/YesPlayMusic/yesplaymusic" "$out/bin/yesplaymusic" - makeWrapper $out/opt/YesPlayMusic/yesplaymusic $out/bin/yesplaymusic \ - --argv0 "yesplaymusic" \ - --add-flags "$out/opt/YesPlayMusic/resources/app.asar" + mkdir -p $out/bin + cp -r opt $out/opt + cp -r usr/share $out/share + substituteInPlace $out/share/applications/yesplaymusic.desktop \ + --replace "/opt/YesPlayMusic/yesplaymusic" "$out/bin/yesplaymusic" + makeWrapper $out/opt/YesPlayMusic/yesplaymusic $out/bin/yesplaymusic \ + --argv0 "yesplaymusic" \ + --add-flags "$out/opt/YesPlayMusic/resources/app.asar" - runHook postInstall - ''; -} + runHook postInstall + ''; + } diff --git a/pkgs/by-name/ye/yeswiki/package.nix b/pkgs/by-name/ye/yeswiki/package.nix index 0e0562eaf52aed..6dd92d78f53fae 100644 --- a/pkgs/by-name/ye/yeswiki/package.nix +++ b/pkgs/by-name/ye/yeswiki/package.nix @@ -5,7 +5,8 @@ }: let version = "4.4.2"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "yeswiki"; inherit version; diff --git a/pkgs/by-name/ye/yewtube/package.nix b/pkgs/by-name/ye/yewtube/package.nix index b9ec7f323b3702..e457699cb7ec07 100644 --- a/pkgs/by-name/ye/yewtube/package.nix +++ b/pkgs/by-name/ye/yewtube/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "yewtube"; @@ -43,6 +47,9 @@ python3Packages.buildPythonApplication rec { mainProgram = "yt"; homepage = "https://github.com/mps-youtube/yewtube"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ fgaz koral ]; + maintainers = with maintainers; [ + fgaz + koral + ]; }; } diff --git a/pkgs/by-name/ye/yex-lang/package.nix b/pkgs/by-name/ye/yex-lang/package.nix index 87719884a06ece..2950aa864f2a83 100644 --- a/pkgs/by-name/ye/yex-lang/package.nix +++ b/pkgs/by-name/ye/yex-lang/package.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/yg/yggdrasil/package.nix b/pkgs/by-name/yg/yggdrasil/package.nix index 8a43e444e87570..f88bf5d11ac806 100644 --- a/pkgs/by-name/yg/yggdrasil/package.nix +++ b/pkgs/by-name/yg/yggdrasil/package.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "yggdrasil"; @@ -13,7 +18,11 @@ buildGoModule rec { vendorHash = "sha256-1N9PCzK203gO/BM5toMNF+XaYwDPyoE6FGxwk5HmRhY="; - subPackages = [ "cmd/genkeys" "cmd/yggdrasil" "cmd/yggdrasilctl" ]; + subPackages = [ + "cmd/genkeys" + "cmd/yggdrasil" + "cmd/yggdrasilctl" + ]; ldflags = [ "-X github.com/yggdrasil-network/yggdrasil-go/src/version.buildVersion=${version}" @@ -26,10 +35,14 @@ buildGoModule rec { passthru.tests.basic = nixosTests.yggdrasil; meta = with lib; { - description = - "An experiment in scalable routing as an encrypted IPv6 overlay network"; + description = "An experiment in scalable routing as an encrypted IPv6 overlay network"; homepage = "https://yggdrasil-network.github.io/"; license = licenses.lgpl3; - maintainers = with maintainers; [ ehmry gazally lassulus peigongdsd ]; + maintainers = with maintainers; [ + ehmry + gazally + lassulus + peigongdsd + ]; }; } diff --git a/pkgs/by-name/yg/yggstack/package.nix b/pkgs/by-name/yg/yggstack/package.nix index f2dff7cf9e525d..1dd155c7bd42eb 100644 --- a/pkgs/by-name/yg/yggstack/package.nix +++ b/pkgs/by-name/yg/yggstack/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "yggstack"; @@ -26,6 +30,9 @@ buildGoModule rec { description = "Yggdrasil as SOCKS proxy / port forwarder"; homepage = "https://yggdrasil-network.github.io/"; license = licenses.lgpl3; - maintainers = with maintainers; [ ehmry peigongdsd ]; + maintainers = with maintainers; [ + ehmry + peigongdsd + ]; }; } diff --git a/pkgs/by-name/yj/yj/package.nix b/pkgs/by-name/yj/yj/package.nix index ae459761958360..bb6f8372c31267 100644 --- a/pkgs/by-name/yj/yj/package.nix +++ b/pkgs/by-name/yj/yj/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "yj"; @@ -13,7 +17,11 @@ buildGoModule rec { vendorHash = "sha256-NeSOoL9wtFzq6ba8ghseB6D+Qq8Z5holQExcAUbtYrs="; - ldflags = [ "-s" "-w" "-X main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.Version=${version}" + ]; meta = with lib; { description = "Convert YAML <=> TOML <=> JSON <=> HCL"; diff --git a/pkgs/by-name/yl/yle-dl/package.nix b/pkgs/by-name/yl/yle-dl/package.nix index 514bb441fd9780..0094b450cff987 100644 --- a/pkgs/by-name/yl/yle-dl/package.nix +++ b/pkgs/by-name/yl/yle-dl/package.nix @@ -1,5 +1,13 @@ -{ lib, fetchFromGitHub, rtmpdump, php, wget, python3Packages, ffmpeg -, testers, yle-dl +{ + lib, + fetchFromGitHub, + rtmpdump, + php, + wget, + python3Packages, + ffmpeg, + testers, + yle-dl, }: python3Packages.buildPythonApplication rec { @@ -14,9 +22,18 @@ python3Packages.buildPythonApplication rec { }; propagatedBuildInputs = with python3Packages; [ - attrs configargparse ffmpeg future lxml requests + attrs + configargparse + ffmpeg + future + lxml + requests + ]; + pythonPath = [ + rtmpdump + php + wget ]; - pythonPath = [ rtmpdump php wget ]; doCheck = false; # tests require network access nativeCheckInputs = with python3Packages; [ pytestCheckHook ]; diff --git a/pkgs/by-name/ym/ympd/package.nix b/pkgs/by-name/ym/ympd/package.nix index 9921bb6dfada3d..89bb628e8c2f2a 100644 --- a/pkgs/by-name/ym/ympd/package.nix +++ b/pkgs/by-name/ym/ympd/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, libmpdclient -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libmpdclient, + openssl, }: stdenv.mkDerivation rec { @@ -25,8 +26,14 @@ stdenv.mkDerivation rec { # Should be fixed by pending https://github.com/notandy/ympd/pull/191 (does not apply as is). env.NIX_CFLAGS_COMPILE = "-fcommon"; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ libmpdclient openssl ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + libmpdclient + openssl + ]; meta = with lib; { homepage = "https://github.com/notandy/ympd"; diff --git a/pkgs/by-name/ym/ymuse/package.nix b/pkgs/by-name/ym/ymuse/package.nix index 19859a1d819d9b..1795f9f427912b 100644 --- a/pkgs/by-name/ym/ymuse/package.nix +++ b/pkgs/by-name/ym/ymuse/package.nix @@ -1,14 +1,15 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, wrapGAppsHook3 -, pkg-config -, glib -, gobject-introspection -, gtk3 -, gdk-pixbuf -, gettext -, librsvg +{ + lib, + fetchFromGitHub, + buildGoModule, + wrapGAppsHook3, + pkg-config, + glib, + gobject-introspection, + gtk3, + gdk-pixbuf, + gettext, + librsvg, }: buildGoModule rec { diff --git a/pkgs/by-name/yo/yo/package.nix b/pkgs/by-name/yo/yo/package.nix index b3857d44a470ff..58b48ff2b93996 100644 --- a/pkgs/by-name/yo/yo/package.nix +++ b/pkgs/by-name/yo/yo/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/by-name/yo/yodl/package.nix b/pkgs/by-name/yo/yodl/package.nix index d8e5bd26b39da0..cf967a7893b27e 100644 --- a/pkgs/by-name/yo/yodl/package.nix +++ b/pkgs/by-name/yo/yodl/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitLab, perl, icmake, util-linux }: +{ + lib, + stdenv, + fetchFromGitLab, + perl, + icmake, + util-linux, +}: stdenv.mkDerivation rec { pname = "yodl"; diff --git a/pkgs/by-name/yo/yoink/package.nix b/pkgs/by-name/yo/yoink/package.nix index 83c767fe0c1742..8a816e104506de 100644 --- a/pkgs/by-name/yo/yoink/package.nix +++ b/pkgs/by-name/yo/yoink/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildGoModule +{ + lib, + fetchFromGitHub, + buildGoModule, }: let diff --git a/pkgs/by-name/yo/yojimbo/package.nix b/pkgs/by-name/yo/yojimbo/package.nix index 6d9856fd61a917..a89e356752a01d 100644 --- a/pkgs/by-name/yo/yojimbo/package.nix +++ b/pkgs/by-name/yo/yojimbo/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, premake5, doxygen, libsodium, mbedtls_2 }: +{ + lib, + stdenv, + fetchFromGitHub, + premake5, + doxygen, + libsodium, + mbedtls_2, +}: stdenv.mkDerivation { pname = "yojimbo"; @@ -12,8 +20,14 @@ stdenv.mkDerivation { fetchSubmodules = true; }; - nativeBuildInputs = [ premake5 doxygen ]; - propagatedBuildInputs = [ libsodium mbedtls_2 ]; + nativeBuildInputs = [ + premake5 + doxygen + ]; + propagatedBuildInputs = [ + libsodium + mbedtls_2 + ]; postBuild = '' premake5 docs diff --git a/pkgs/by-name/yo/yor/package.nix b/pkgs/by-name/yo/yor/package.nix index 27e875c76c316d..bfedb9d25a9b27 100644 --- a/pkgs/by-name/yo/yor/package.nix +++ b/pkgs/by-name/yo/yor/package.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { diff --git a/pkgs/by-name/yo/yoshimi/package.nix b/pkgs/by-name/yo/yoshimi/package.nix index ee983726f7f513..8b0744a2ad86bd 100644 --- a/pkgs/by-name/yo/yoshimi/package.nix +++ b/pkgs/by-name/yo/yoshimi/package.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, alsa-lib -, boost -, cairo -, cmake -, fftwSinglePrec -, fltk -, libGLU -, libjack2 -, libsndfile -, libXdmcp -, lv2 -, minixml -, pcre -, pkg-config -, readline -, xorg -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + alsa-lib, + boost, + cairo, + cmake, + fftwSinglePrec, + fltk, + libGLU, + libjack2, + libsndfile, + libXdmcp, + lv2, + minixml, + pcre, + pkg-config, + readline, + xorg, + zlib, }: stdenv.mkDerivation rec { @@ -38,7 +39,10 @@ stdenv.mkDerivation rec { substituteInPlace Misc/Bank.cpp --replace /usr $out ''; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ alsa-lib diff --git a/pkgs/by-name/yo/you-get/package.nix b/pkgs/by-name/yo/you-get/package.nix index 6f11442c496c0e..cabd00e67b380c 100644 --- a/pkgs/by-name/yo/you-get/package.nix +++ b/pkgs/by-name/yo/you-get/package.nix @@ -1,9 +1,10 @@ -{ lib -, python3 -, fetchPypi -, substituteAll -, ffmpeg -, installShellFiles +{ + lib, + python3, + fetchPypi, + substituteAll, + ffmpeg, + installShellFiles, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/yo/youplot/package.nix b/pkgs/by-name/yo/youplot/package.nix index b1fcb76795ad4f..9abca91753f0b7 100644 --- a/pkgs/by-name/yo/youplot/package.nix +++ b/pkgs/by-name/yo/youplot/package.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "youplot"; @@ -10,10 +14,10 @@ bundlerApp { meta = with lib; { description = "Command line tool that draws plots on the terminal"; - homepage = "https://github.com/red-data-tools/YouPlot"; + homepage = "https://github.com/red-data-tools/YouPlot"; mainProgram = "uplot"; - license = licenses.mit; + license = licenses.mit; maintainers = with maintainers; [ purcell ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/by-name/yo/your_spotify/client.nix b/pkgs/by-name/yo/your_spotify/client.nix index 4453d398862169..afdad50b7409c2 100644 --- a/pkgs/by-name/yo/your_spotify/client.nix +++ b/pkgs/by-name/yo/your_spotify/client.nix @@ -7,7 +7,7 @@ apiEndpoint ? "http://localhost:3000", yarnConfigHook, yarnBuildHook, - nodejs + nodejs, }: stdenv.mkDerivation (finalAttrs: { @@ -20,7 +20,7 @@ stdenv.mkDerivation (finalAttrs: { nodejs ]; - API_ENDPOINT="${apiEndpoint}"; + API_ENDPOINT = "${apiEndpoint}"; preBuild = '' pushd ./apps/client/ ''; diff --git a/pkgs/by-name/yo/yourkit-java/package.nix b/pkgs/by-name/yo/yourkit-java/package.nix index 2e109a36811af8..0f7a40e4aded4e 100644 --- a/pkgs/by-name/yo/yourkit-java/package.nix +++ b/pkgs/by-name/yo/yourkit-java/package.nix @@ -1,10 +1,11 @@ -{ fetchzip -, lib -, stdenvNoCC -, copyDesktopItems -, imagemagick -, makeDesktopItem -, jre +{ + fetchzip, + lib, + stdenvNoCC, + copyDesktopItems, + imagemagick, + makeDesktopItem, + jre, }: let vPath = v: lib.elemAt (lib.splitString "-" v) 0; @@ -16,8 +17,7 @@ let x86_64-linux = "x64"; }; - arch = - arches.${stdenvNoCC.targetPlatform.system} or (throw "Unsupported system"); + arch = arches.${stdenvNoCC.targetPlatform.system} or (throw "Unsupported system"); hashes = { arm64 = "sha256-IPgWoHLUEeMZR3kPabUeFuMLSJhhgO8BA6zTw+D3+ks="; @@ -30,7 +30,11 @@ let type = "Application"; exec = "yourkit-java-profiler %f"; icon = "yourkit-java-profiler"; - categories = [ "Development" "Java" "Profiling" ]; + categories = [ + "Development" + "Java" + "Profiling" + ]; terminal = false; startupWMClass = "YourKit Java Profiler"; }; @@ -45,7 +49,10 @@ stdenvNoCC.mkDerivation { hash = hashes.${arch}; }; - nativeBuildInputs = [ copyDesktopItems imagemagick ]; + nativeBuildInputs = [ + copyDesktopItems + imagemagick + ]; buildInputs = [ jre ]; diff --git a/pkgs/by-name/yo/youtrack/package.nix b/pkgs/by-name/yo/youtrack/package.nix index 430e5d94d5c893..bd577d54ddfe41 100644 --- a/pkgs/by-name/yo/youtrack/package.nix +++ b/pkgs/by-name/yo/youtrack/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenvNoCC, fetchzip, makeBinaryWrapper, jdk21_headless, gawk, statePath ? "/var/lib/youtrack" }: +{ + lib, + stdenvNoCC, + fetchzip, + makeBinaryWrapper, + jdk21_headless, + gawk, + statePath ? "/var/lib/youtrack", +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "youtrack"; diff --git a/pkgs/by-name/yq/yq-go/package.nix b/pkgs/by-name/yq/yq-go/package.nix index abaf4cde3cf91a..0a057378fdc354 100644 --- a/pkgs/by-name/yq/yq-go/package.nix +++ b/pkgs/by-name/yq/yq-go/package.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, runCommand, yq-go }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + runCommand, + yq-go, +}: buildGoModule rec { pname = "yq-go"; @@ -35,6 +42,9 @@ buildGoModule rec { changelog = "https://github.com/mikefarah/yq/raw/v${version}/release_notes.txt"; mainProgram = "yq"; license = [ licenses.mit ]; - maintainers = with maintainers; [ lewo SuperSandro2000 ]; + maintainers = with maintainers; [ + lewo + SuperSandro2000 + ]; }; } diff --git a/pkgs/by-name/ys/ysfx/package.nix b/pkgs/by-name/ys/ysfx/package.nix index ac7807df8cd549..606cc37a15806c 100644 --- a/pkgs/by-name/ys/ysfx/package.nix +++ b/pkgs/by-name/ys/ysfx/package.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config -, freetype, juce, libX11, libXcursor, libXext, libXinerama, libXrandr, libglvnd +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + freetype, + juce, + libX11, + libXcursor, + libXext, + libXinerama, + libXrandr, + libglvnd, }: stdenv.mkDerivation rec { @@ -26,7 +38,10 @@ stdenv.mkDerivation rec { ln -s ${dr_libs} thirdparty/dr_libs ''; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ freetype diff --git a/pkgs/by-name/yt/ytalk/package.nix b/pkgs/by-name/yt/ytalk/package.nix index bb284a84b022a7..28840545b50682 100644 --- a/pkgs/by-name/yt/ytalk/package.nix +++ b/pkgs/by-name/yt/ytalk/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "ytalk"; @@ -12,11 +17,11 @@ stdenv.mkDerivation rec { buildInputs = [ ncurses ]; meta = { - homepage = "http://ytalk.ourproject.org"; + homepage = "http://ytalk.ourproject.org"; description = "Terminal based talk client"; mainProgram = "ytalk"; - platforms = lib.platforms.unix; + platforms = lib.platforms.unix; maintainers = with lib.maintainers; [ taeer ]; - license = lib.licenses.gpl2Plus; + license = lib.licenses.gpl2Plus; }; } diff --git a/pkgs/by-name/yt/ytarchive/package.nix b/pkgs/by-name/yt/ytarchive/package.nix index 9f16680759a2ba..283f4258df18e8 100644 --- a/pkgs/by-name/yt/ytarchive/package.nix +++ b/pkgs/by-name/yt/ytarchive/package.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, makeBinaryWrapper, ffmpeg-headless }: +{ + lib, + buildGoModule, + fetchFromGitHub, + makeBinaryWrapper, + ffmpeg-headless, +}: buildGoModule rec { pname = "ytarchive"; @@ -15,7 +21,11 @@ buildGoModule rec { nativeBuildInputs = [ makeBinaryWrapper ]; - ldflags = [ "-s" "-w" "-X main.Commit=-${src.rev}" ]; + ldflags = [ + "-s" + "-w" + "-X main.Commit=-${src.rev}" + ]; postInstall = '' wrapProgram $out/bin/ytarchive --prefix PATH : ${lib.makeBinPath [ ffmpeg-headless ]} diff --git a/pkgs/by-name/yt/ytcast/package.nix b/pkgs/by-name/yt/ytcast/package.nix index 74664145769559..9a1caccc1f2271 100644 --- a/pkgs/by-name/yt/ytcast/package.nix +++ b/pkgs/by-name/yt/ytcast/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub, }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ytcast"; diff --git a/pkgs/by-name/yt/ytcc/package.nix b/pkgs/by-name/yt/ytcc/package.nix index 5e326316817aff..4fb2f6db939948 100644 --- a/pkgs/by-name/yt/ytcc/package.nix +++ b/pkgs/by-name/yt/ytcc/package.nix @@ -1,4 +1,10 @@ -{ lib, python3Packages, fetchFromGitHub, gettext, installShellFiles }: +{ + lib, + python3Packages, + fetchFromGitHub, + gettext, + installShellFiles, +}: python3Packages.buildPythonApplication rec { pname = "ytcc"; @@ -12,12 +18,14 @@ python3Packages.buildPythonApplication rec { hash = "sha256-pC2uoog+nev/Xa6UbXX4vX00VQQLHtZzbVkxrxO/Pg8="; }; - nativeBuildInputs = [ - gettext - installShellFiles - ] ++ (with python3Packages; [ - setuptools - ]); + nativeBuildInputs = + [ + gettext + installShellFiles + ] + ++ (with python3Packages; [ + setuptools + ]); propagatedBuildInputs = with python3Packages; [ yt-dlp diff --git a/pkgs/by-name/yt/ytfzf/package.nix b/pkgs/by-name/yt/ytfzf/package.nix index c3887972a4ca44..333dad2174de96 100644 --- a/pkgs/by-name/yt/ytfzf/package.nix +++ b/pkgs/by-name/yt/ytfzf/package.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, coreutils -, curl -, dmenu -, fzf -, gnused -, jq -, mpv -, ueberzugpp -, yt-dlp +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + coreutils, + curl, + dmenu, + fzf, + gnused, + jq, + mpv, + ueberzugpp, + yt-dlp, }: stdenv.mkDerivation rec { @@ -37,9 +38,19 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram "$out/bin/ytfzf" \ - --prefix PATH : ${lib.makeBinPath [ - coreutils curl dmenu fzf gnused jq mpv ueberzugpp yt-dlp - ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + curl + dmenu + fzf + gnused + jq + mpv + ueberzugpp + yt-dlp + ] + } \ --set YTFZF_SYSTEM_ADDON_DIR "$out/share/ytfzf/addons" ''; diff --git a/pkgs/by-name/yt/ytmdl/package.nix b/pkgs/by-name/yt/ytmdl/package.nix index 3acaac1b35198d..b73ccd6c8c867e 100644 --- a/pkgs/by-name/yt/ytmdl/package.nix +++ b/pkgs/by-name/yt/ytmdl/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3Packages -, fetchPypi -, yt-dlp -, ffmpeg +{ + lib, + python3Packages, + fetchPypi, + yt-dlp, + ffmpeg, }: python3Packages.buildPythonApplication rec { @@ -43,7 +44,10 @@ python3Packages.buildPythonApplication rec { ]; makeWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath [ ffmpeg ]) + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ ffmpeg ]) ]; # This application has no tests diff --git a/pkgs/by-name/yt/ytree/package.nix b/pkgs/by-name/yt/ytree/package.nix index e61a5f2b971d49..6e8846302e5886 100644 --- a/pkgs/by-name/yt/ytree/package.nix +++ b/pkgs/by-name/yt/ytree/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, ncurses -, readline +{ + lib, + stdenv, + fetchurl, + ncurses, + readline, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/yt/ytui-music/package.nix b/pkgs/by-name/yt/ytui-music/package.nix index 0e520955e057cb..6cf472a3d27f99 100644 --- a/pkgs/by-name/yt/ytui-music/package.nix +++ b/pkgs/by-name/yt/ytui-music/package.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, sqlite -, stdenv -, darwin -, mpv -, youtube-dl -, makeBinaryWrapper +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + sqlite, + stdenv, + darwin, + mpv, + youtube-dl, + makeBinaryWrapper, }: rustPlatform.buildRustPackage rec { @@ -34,14 +35,16 @@ rustPlatform.buildRustPackage rec { makeBinaryWrapper ]; - buildInputs = [ - openssl - sqlite - mpv - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreFoundation - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + openssl + sqlite + mpv + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreFoundation + darwin.apple_sdk.frameworks.Security + ]; postInstall = '' wrapProgram $out/bin/ytui_music \ diff --git a/pkgs/by-name/yu/yubihsm-connector/package.nix b/pkgs/by-name/yu/yubihsm-connector/package.nix index 6f7918347b726b..0b0299fdcc8f16 100644 --- a/pkgs/by-name/yu/yubihsm-connector/package.nix +++ b/pkgs/by-name/yu/yubihsm-connector/package.nix @@ -1,4 +1,10 @@ -{ lib, libusb1, buildGoModule, fetchFromGitHub, pkg-config }: +{ + lib, + libusb1, + buildGoModule, + fetchFromGitHub, + pkg-config, +}: buildGoModule rec { pname = "yubihsm-connector"; @@ -21,7 +27,10 @@ buildGoModule rec { libusb1 ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; preBuild = '' GOOS= GOARCH= go generate diff --git a/pkgs/by-name/yu/yubihsm-shell/package.nix b/pkgs/by-name/yu/yubihsm-shell/package.nix index 107053ca00a71d..58358991c087aa 100644 --- a/pkgs/by-name/yu/yubihsm-shell/package.nix +++ b/pkgs/by-name/yu/yubihsm-shell/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, openssl -, libusb1 -, libedit -, curl -, gengetopt -, pkg-config -, pcsclite -, help2man -, darwin -, libiconv +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openssl, + libusb1, + libedit, + curl, + gengetopt, + pkg-config, + pcsclite, + help2man, + darwin, + libiconv, }: stdenv.mkDerivation rec { @@ -42,17 +43,20 @@ stdenv.mkDerivation rec { gengetopt ]; - buildInputs = [ - libusb1 - libedit - curl - openssl - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - pcsclite.dev - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.PCSC - libiconv - ]; + buildInputs = + [ + libusb1 + libedit + curl + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + pcsclite.dev + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.PCSC + libiconv + ]; preBuild = lib.optionalString stdenv.hostPlatform.isLinux '' NIX_CFLAGS_COMPILE="$(pkg-config --cflags libpcsclite) $NIX_CFLAGS_COMPILE" diff --git a/pkgs/by-name/yu/yubikey-agent/package.nix b/pkgs/by-name/yu/yubikey-agent/package.nix index f2e290ade6db8c..98a97dab94bf18 100644 --- a/pkgs/by-name/yu/yubikey-agent/package.nix +++ b/pkgs/by-name/yu/yubikey-agent/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchFromGitHub, buildGoModule, libnotify, pcsclite, pkg-config, darwin }: +{ + stdenv, + lib, + fetchFromGitHub, + buildGoModule, + libnotify, + pcsclite, + pkg-config, + darwin, +}: buildGoModule rec { pname = "yubikey-agent"; @@ -27,7 +36,11 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" "-X main.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.Version=${version}" + ]; postInstall = lib.optionalString stdenv.hostPlatform.isLinux '' mkdir -p $out/lib/systemd/user @@ -40,7 +53,10 @@ buildGoModule rec { mainProgram = "yubikey-agent"; license = licenses.bsd3; homepage = "https://filippo.io/yubikey-agent"; - maintainers = with lib.maintainers; [ philandstuff rawkode ]; + maintainers = with lib.maintainers; [ + philandstuff + rawkode + ]; platforms = platforms.darwin ++ platforms.linux; }; } diff --git a/pkgs/by-name/yu/yubikey-manager/package.nix b/pkgs/by-name/yu/yubikey-manager/package.nix index 5523b6468969ac..43e8490686305b 100644 --- a/pkgs/by-name/yu/yubikey-manager/package.nix +++ b/pkgs/by-name/yu/yubikey-manager/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3Packages -, installShellFiles -, procps +{ + lib, + stdenv, + fetchFromGitHub, + python3Packages, + installShellFiles, + procps, }: python3Packages.buildPythonPackage rec { @@ -61,7 +62,12 @@ python3Packages.buildPythonPackage rec { license = lib.licenses.bsd2; platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ benley lassulus pinpox nickcao ]; + maintainers = with lib.maintainers; [ + benley + lassulus + pinpox + nickcao + ]; mainProgram = "ykman"; }; } diff --git a/pkgs/by-name/yu/yubikey-personalization/package.nix b/pkgs/by-name/yu/yubikey-personalization/package.nix index 13a1cc36119736..135279a27b0ef2 100644 --- a/pkgs/by-name/yu/yubikey-personalization/package.nix +++ b/pkgs/by-name/yu/yubikey-personalization/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, libusb1, libyubikey, json_c }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + libusb1, + libyubikey, + json_c, +}: stdenv.mkDerivation rec { pname = "yubikey-personalization"; @@ -27,7 +36,11 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libusb1 libyubikey json_c ]; + buildInputs = [ + libusb1 + libyubikey + json_c + ]; configureFlags = [ "--with-backend=libusb-1.0" diff --git a/pkgs/by-name/yu/yubikey-touch-detector/package.nix b/pkgs/by-name/yu/yubikey-touch-detector/package.nix index 13c7e73f2dcd07..f7fd9937ccf596 100644 --- a/pkgs/by-name/yu/yubikey-touch-detector/package.nix +++ b/pkgs/by-name/yu/yubikey-touch-detector/package.nix @@ -1,4 +1,11 @@ -{ lib, libnotify, gpgme, buildGoModule, fetchFromGitHub, pkg-config }: +{ + lib, + libnotify, + gpgme, + buildGoModule, + fetchFromGitHub, + pkg-config, +}: buildGoModule rec { pname = "yubikey-touch-detector"; @@ -14,7 +21,10 @@ buildGoModule rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libnotify gpgme ]; + buildInputs = [ + libnotify + gpgme + ]; postInstall = '' install -Dm444 -t $out/share/doc/${pname} *.{md,example} diff --git a/pkgs/by-name/yu/yubioath-flutter/helper.nix b/pkgs/by-name/yu/yubioath-flutter/helper.nix index 378981ae84107e..d0c814a339e842 100644 --- a/pkgs/by-name/yu/yubioath-flutter/helper.nix +++ b/pkgs/by-name/yu/yubioath-flutter/helper.nix @@ -1,13 +1,14 @@ -{ buildPythonApplication -, yubikey-manager -, mss -, zxing-cpp -, pillow -, poetry-core - -, src -, version -, meta +{ + buildPythonApplication, + yubikey-manager, + mss, + zxing-cpp, + pillow, + poetry-core, + + src, + version, + meta, }: buildPythonApplication { diff --git a/pkgs/by-name/yu/yubioath-flutter/package.nix b/pkgs/by-name/yu/yubioath-flutter/package.nix index a13c6e623da66b..e22005d905ceee 100644 --- a/pkgs/by-name/yu/yubioath-flutter/package.nix +++ b/pkgs/by-name/yu/yubioath-flutter/package.nix @@ -1,14 +1,15 @@ -{ lib -, flutter324 -, python3 -, fetchFromGitHub -, pcre2 -, libnotify -, libappindicator -, pkg-config -, gnome-screenshot -, makeWrapper -, removeReferencesTo +{ + lib, + flutter324, + python3, + fetchFromGitHub, + pcre2, + libnotify, + libappindicator, + pkg-config, + gnome-screenshot, + makeWrapper, + removeReferencesTo, }: flutter324.buildFlutterApplication rec { @@ -88,6 +89,9 @@ flutter324.buildFlutterApplication rec { homepage = "https://github.com/Yubico/yubioath-flutter"; license = licenses.asl20; maintainers = with maintainers; [ lukegb ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; }; } diff --git a/pkgs/by-name/yu/yuicompressor/package.nix b/pkgs/by-name/yu/yuicompressor/package.nix index e865160fb7141b..a2d32b65fd5021 100644 --- a/pkgs/by-name/yu/yuicompressor/package.nix +++ b/pkgs/by-name/yu/yuicompressor/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, jre }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { pname = "yuicompressor"; diff --git a/pkgs/by-name/yu/yunfaavatar/package.nix b/pkgs/by-name/yu/yunfaavatar/package.nix index 410893df44d14d..c3456673e1ef37 100644 --- a/pkgs/by-name/yu/yunfaavatar/package.nix +++ b/pkgs/by-name/yu/yunfaavatar/package.nix @@ -17,7 +17,7 @@ stdenvNoCC.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [makeWrapper]; + nativeBuildInputs = [ makeWrapper ]; makeFlags = [ "PREFIX=${placeholder "out"}" @@ -25,7 +25,7 @@ stdenvNoCC.mkDerivation rec { postInstall = '' wrapProgram "$out/bin/yunfaavatar" \ - --prefix PATH : "${lib.makeBinPath [imagemagick]}" + --prefix PATH : "${lib.makeBinPath [ imagemagick ]}" ''; meta = with lib; { @@ -33,7 +33,7 @@ stdenvNoCC.mkDerivation rec { homepage = "https://github.com/yunfachi/yunfaAvatar"; license = licenses.mit; platforms = platforms.all; - maintainers = with maintainers; [yunfachi]; + maintainers = with maintainers; [ yunfachi ]; mainProgram = "yunfaavatar"; }; } diff --git a/pkgs/by-name/yx/yx/package.nix b/pkgs/by-name/yx/yx/package.nix index f773ca66a00007..ae50e55184db80 100644 --- a/pkgs/by-name/yx/yx/package.nix +++ b/pkgs/by-name/yx/yx/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, libyaml -, testers -, yx +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + libyaml, + testers, + yx, }: stdenv.mkDerivation rec { pname = "yx"; diff --git a/pkgs/by-name/yy/yyjson/package.nix b/pkgs/by-name/yy/yyjson/package.nix index f60329028ead51..6799d3adf5fe2e 100644 --- a/pkgs/by-name/yy/yyjson/package.nix +++ b/pkgs/by-name/yy/yyjson/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/z-/z-lua/package.nix b/pkgs/by-name/z-/z-lua/package.nix index c7ed329106cb8c..4c6c1130387267 100644 --- a/pkgs/by-name/z-/z-lua/package.nix +++ b/pkgs/by-name/z-/z-lua/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, lua52Packages, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + lua52Packages, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "z-lua"; diff --git a/pkgs/by-name/z8/z88dk/package.nix b/pkgs/by-name/z8/z88dk/package.nix index c2b36703d51d4b..68bd1d1ff469e3 100644 --- a/pkgs/by-name/z8/z88dk/package.nix +++ b/pkgs/by-name/z8/z88dk/package.nix @@ -26,7 +26,10 @@ let }; meta = { description = "A date object with as little code as possible (and rw accessors)"; - license = with lib.licenses; [ artistic1 gpl1Plus ]; + license = with lib.licenses; [ + artistic1 + gpl1Plus + ]; }; }; @@ -38,11 +41,15 @@ let hash = "sha256-FmPE1xdU8LAXS21+H4DJaQ87qDi4Q4UkLawsUAqseZw="; }; propagatedBuildInputs = with perlPackages; [ - ClassAccessor IteratorSimple + ClassAccessor + IteratorSimple ]; meta = { description = "Simple iterator with lookahead and unget"; - license = with lib.licenses; [ artistic1 gpl2Only ]; + license = with lib.licenses; [ + artistic1 + gpl2Only + ]; }; }; @@ -53,9 +60,11 @@ let url = "mirror://cpan/authors/id/P/PS/PSCUST/Asm-Preproc-1.03.tar.gz"; hash = "sha256-pVTpIqGxZpBxZlAbXuGDapuOxsp3uM/AM5dKUxlej1M="; }; - propagatedBuildInputs = [ + propagatedBuildInputs = + [ IteratorSimpleLookahead - ] ++ (with perlPackages; [ + ] + ++ (with perlPackages; [ IteratorSimple TextTemplate DataDump @@ -63,7 +72,10 @@ let ]); meta = { description = "Preprocessor to be called from an assembler"; - license = with lib.licenses; [ artistic1 gpl2Only ]; + license = with lib.licenses; [ + artistic1 + gpl2Only + ]; }; }; @@ -74,7 +86,9 @@ let url = "mirror://cpan/authors/id/P/PS/PSCUST/CPU-Z80-Assembler-2.25.tar.gz"; hash = "sha256-cJ8Fl2KZw9/bnBDUzFuwwdw9x23OUvcftk78kw7abdU="; }; - buildInputs = [ AsmPreproc ] ++ (with perlPackages; [ + buildInputs = + [ AsmPreproc ] + ++ (with perlPackages; [ CaptureTiny RegexpTrie PathTiny @@ -82,7 +96,10 @@ let ]); meta = { description = "Functions to assemble a set of Z80 assembly instructions"; - license = with lib.licenses; [ artistic1 gpl2Only ]; + license = with lib.licenses; [ + artistic1 + gpl2Only + ]; }; }; in @@ -139,27 +156,29 @@ stdenv.mkDerivation (finalAttrs: { "git_count=0" ]; - nativeBuildInputs = [ - which - unzip - m4 - perl - pkg-config - - # Local perl packages - AsmPreproc - CPUZ80Assembler - ObjectTinyRW - ] ++ (with perlPackages; [ - CaptureTiny - DataHexDump - ModernPerl - PathTiny - RegexpCommon - TestHexDifferences - TextDiff - RegexpTrie - ]); + nativeBuildInputs = + [ + which + unzip + m4 + perl + pkg-config + + # Local perl packages + AsmPreproc + CPUZ80Assembler + ObjectTinyRW + ] + ++ (with perlPackages; [ + CaptureTiny + DataHexDump + ModernPerl + PathTiny + RegexpCommon + TestHexDifferences + TextDiff + RegexpTrie + ]); buildInputs = [ libxml2 diff --git a/pkgs/by-name/za/zabbixctl/package.nix b/pkgs/by-name/za/zabbixctl/package.nix index ce45196fdba737..4fdca75b17d2bf 100644 --- a/pkgs/by-name/za/zabbixctl/package.nix +++ b/pkgs/by-name/za/zabbixctl/package.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "zabbixctl"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-BphQcPPmeNU7RDtaHJQxIoW8xxD86xWgqLBsLR08Tag="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Most effective way for operating in Zabbix Server"; diff --git a/pkgs/by-name/za/zalgo/package.nix b/pkgs/by-name/za/zalgo/package.nix index 0ca9f3366ce40a..7d47bf5bc292d2 100644 --- a/pkgs/by-name/za/zalgo/package.nix +++ b/pkgs/by-name/za/zalgo/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zalgo"; diff --git a/pkgs/by-name/za/zam-plugins/package.nix b/pkgs/by-name/za/zam-plugins/package.nix index dc27db5ca8b3f3..34f37b465c42a9 100644 --- a/pkgs/by-name/za/zam-plugins/package.nix +++ b/pkgs/by-name/za/zam-plugins/package.nix @@ -1,4 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, boost, libX11, libGL, liblo, libjack2, ladspaH, lv2, pkg-config, rubberband, libsndfile, fftwFloat, libsamplerate }: +{ + lib, + stdenv, + fetchFromGitHub, + boost, + libX11, + libGL, + liblo, + libjack2, + ladspaH, + lv2, + pkg-config, + rubberband, + libsndfile, + fftwFloat, + libsamplerate, +}: stdenv.mkDerivation rec { pname = "zam-plugins"; @@ -13,7 +29,19 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ boost libX11 libGL liblo libjack2 ladspaH lv2 rubberband libsndfile fftwFloat libsamplerate ]; + buildInputs = [ + boost + libX11 + libGL + liblo + libjack2 + ladspaH + lv2 + rubberband + libsndfile + fftwFloat + libsamplerate + ]; postPatch = '' patchShebangs ./dpf/utils/generate-ttl.sh diff --git a/pkgs/by-name/za/zammad/gemset.nix b/pkgs/by-name/za/zammad/gemset.nix index 43650bb5ad33d7..c04ecf56161c74 100644 --- a/pkgs/by-name/za/zammad/gemset.nix +++ b/pkgs/by-name/za/zammad/gemset.nix @@ -1,215 +1,328 @@ { aasm = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xnhpdpi11f7kkyngfspvd9jkkncqfpirz4sylzq32rh47kcd8p3"; type = "gem"; }; version = "5.5.0"; }; actioncable = { - dependencies = ["actionpack" "activesupport" "nio4r" "websocket-driver" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "nio4r" + "websocket-driver" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1mfb5x6kwxwprprhzj2a1hff7vw37v1wd9hl70nqq23xr82w20wx"; type = "gem"; }; version = "7.1.4.1"; }; actionmailbox = { - dependencies = ["actionpack" "activejob" "activerecord" "activestorage" "activesupport" "mail" "net-imap" "net-pop" "net-smtp"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activejob" + "activerecord" + "activestorage" + "activesupport" + "mail" + "net-imap" + "net-pop" + "net-smtp" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1z95jcq4cmk7zzy4jjgxjbigk0zaxm2gpf8p0s0jn3b5px0k3ljk"; type = "gem"; }; version = "7.1.4.1"; }; actionmailer = { - dependencies = ["actionpack" "actionview" "activejob" "activesupport" "mail" "net-imap" "net-pop" "net-smtp" "rails-dom-testing"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "actionview" + "activejob" + "activesupport" + "mail" + "net-imap" + "net-pop" + "net-smtp" + "rails-dom-testing" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1h39ffp0zs0r46bfm8bbgvc8icwamq4icsf1qn32xskdssnb8xyr"; type = "gem"; }; version = "7.1.4.1"; }; actionpack = { - dependencies = ["actionview" "activesupport" "nokogiri" "racc" "rack" "rack-session" "rack-test" "rails-dom-testing" "rails-html-sanitizer"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionview" + "activesupport" + "nokogiri" + "racc" + "rack" + "rack-session" + "rack-test" + "rails-dom-testing" + "rails-html-sanitizer" + ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1mrdaql56iqnqcg7n3frc0r48bca8b4g9f2ifc69f15dpps2wfsx"; type = "gem"; }; version = "7.1.4.1"; }; actiontext = { - dependencies = ["actionpack" "activerecord" "activestorage" "activesupport" "globalid" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activerecord" + "activestorage" + "activesupport" + "globalid" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "06az0qalnvz0hv1wq8nn5q70gak9r50b6b95avmkz860lhbpx70d"; type = "gem"; }; version = "7.1.4.1"; }; actionview = { - dependencies = ["activesupport" "builder" "erubi" "rails-dom-testing" "rails-html-sanitizer"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "builder" + "erubi" + "rails-dom-testing" + "rails-html-sanitizer" + ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "02zrp7x6k6sgd4rrpsh2b9k2h0qhx538fsb1grsw25ss8d9k2b2j"; type = "gem"; }; version = "7.1.4.1"; }; activejob = { - dependencies = ["activesupport" "globalid"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "globalid" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1r0i34jrsibwkbg61kjm1xjbc8ppy8r91bnach8rv7jgjrid4dyl"; type = "gem"; }; version = "7.1.4.1"; }; activemodel = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dpdfa132zsfw5l754p2iwialbscvhp9dblq9fg65ww306s3g0pl"; type = "gem"; }; version = "7.1.4.1"; }; activerecord = { - dependencies = ["activemodel" "activesupport" "timeout"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activemodel" + "activesupport" + "timeout" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1cwx0a7pbl2shm0jc0m7aylacb84j2p4f3h0v7f6aas2b8s6lkf1"; type = "gem"; }; version = "7.1.4.1"; }; activerecord-import = { - dependencies = ["activerecord"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activerecord" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g16yn1ixfixd979yfqbxp9y71ryr4a6wakbr6dmpq4s7glm6366"; type = "gem"; }; version = "1.8.1"; }; activerecord-session_store = { - dependencies = ["actionpack" "activerecord" "cgi" "multi_json" "rack" "railties"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activerecord" + "cgi" + "multi_json" + "rack" + "railties" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0x13crb9f6yxk5i320c3a29rl760lkyhh21zd128f34dc4fknigq"; type = "gem"; }; version = "2.1.0"; }; activestorage = { - dependencies = ["actionpack" "activejob" "activerecord" "activesupport" "marcel"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activejob" + "activerecord" + "activesupport" + "marcel" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07zw4r8n3ag3d8jfynngpk0cxjwwlh7pxg3hrz1fdww2fnl6nan8"; type = "gem"; }; version = "7.1.4.1"; }; activesupport = { - dependencies = ["base64" "bigdecimal" "concurrent-ruby" "connection_pool" "drb" "i18n" "minitest" "mutex_m" "tzinfo"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "bigdecimal" + "concurrent-ruby" + "connection_pool" + "drb" + "i18n" + "minitest" + "mutex_m" + "tzinfo" + ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0p3167vw7csidyfl731hbp27xaz90w0v31l3fqzrsipci69p7qw0"; type = "gem"; }; version = "7.1.4.1"; }; acts_as_list = { - dependencies = ["activerecord" "activesupport"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activerecord" + "activesupport" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0jbzjf6344a0m083d69qgx55xqqsxxrli8g1ark9d16fbcayi0j6"; type = "gem"; }; version = "1.2.2"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "public_suffix" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; android_key_attestation = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02spc1sh7zsljl02v9d5rdb717b628vw2k7jkkplifyjk4db0zj6"; type = "gem"; }; version = "0.3.0"; }; argon2 = { - dependencies = ["ffi" "ffi-compiler"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ffi" + "ffi-compiler" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0mwmrqfpwljp0pkv8zbamg66s2zlxrhhvfvcgg9jlldzf98zc3lq"; type = "gem"; }; version = "2.3.0"; }; ast = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "04nc8x27hlzlrr5c2gn7mar4vdr0apw5xg22wp6m8dx3wqr04a0y"; type = "gem"; }; version = "2.4.2"; }; autodiscover = { - dependencies = ["httpclient" "logging" "nokogiri" "nori"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "httpclient" + "logging" + "nokogiri" + "nori" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { fetchSubmodules = false; rev = "ee9b53dfa797ce6d4f970b82beea7fbdd2df56bb"; @@ -220,1065 +333,1318 @@ version = "1.0.2"; }; autoprefixer-rails = { - dependencies = ["execjs"]; - groups = ["assets"]; - platforms = []; + dependencies = [ "execjs" ]; + groups = [ "assets" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kjzcvz1in424gvhcvp94mc00snhv3h2b413glf5hym0wm3izlnc"; type = "gem"; }; version = "10.4.19.0"; }; awrence = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gj8f8c54r9cabkm41s59sa1ca5wpbipw7gq3sfl87x9296227fx"; type = "gem"; }; version = "1.2.1"; }; aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gvdg4yx4p9av2glmp7vsxhs0n8fj1ga9kq2xdb8f95j7b04qhzi"; type = "gem"; }; version = "1.3.0"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l3rkiqvlmh3bgq6447s2d398z43slk3swz0cvgjprvm6182ici4"; type = "gem"; }; version = "1.984.0"; }; aws-sdk-core = { - dependencies = ["aws-eventstream" "aws-partitions" "aws-sigv4" "jmespath"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-eventstream" + "aws-partitions" + "aws-sigv4" + "jmespath" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "06mrp7g24ndg55w85ndyrvxfx2v6hnkh5fj32w9s6w3xsc8v5kqq"; type = "gem"; }; version = "3.209.1"; }; aws-sdk-kms = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1acx3bhqkhni3kbl7xnjdgy8raq5y7p0zyniq61bsihzkwcj7imh"; type = "gem"; }; version = "1.94.0"; }; aws-sdk-s3 = { - dependencies = ["aws-sdk-core" "aws-sdk-kms" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sdk-kms" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kln41q23a6rxj1r9wj972z4jaxiqn7fm64y9ry6qkbzn1ibgam6"; type = "gem"; }; version = "1.167.0"; }; aws-sigv4 = { - dependencies = ["aws-eventstream"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-eventstream" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "176zh13m1vhwgys0drlqiw79ljmmx84vva036shsb7rzr4yi36qm"; type = "gem"; }; version = "1.10.0"; }; base64 = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bigdecimal = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; bindata = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08r67nglsqnxrbn803szf5bdnqhchhq8kf2by94f37fcl65wpp19"; type = "gem"; }; version = "2.5.0"; }; binding_of_caller = { - dependencies = ["debug_inspector"]; - groups = ["default"]; - platforms = []; + dependencies = [ "debug_inspector" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16mjj15ks5ws53v2y31hxcmf46d0qjdvdaadpk7xsij2zymh4a9b"; type = "gem"; }; version = "1.0.1"; }; biz = { - dependencies = ["clavius" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "clavius" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1n2d7cs9jlnpi75nbssv77qlw0jsqnixaikpxsrbxz154q43gvlc"; type = "gem"; }; version = "1.8.2"; }; bootsnap = { - dependencies = ["msgpack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "msgpack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mdgj9yw1hmx3xh2qxyjc31y8igmxzd9h0c245ay2zkz76pl4k5c"; type = "gem"; }; version = "1.18.4"; }; brakeman = { - dependencies = ["racc"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "racc" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "078syvjnnkbair5ffyvchxj9yd2c8215c1271kfh1gqsmaf70bl6"; type = "gem"; }; version = "6.2.1"; }; browser = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "083rx0jjlzbh9fxiy967l87f1123hairdc4mm6d54plj5kqz1683"; type = "gem"; }; version = "6.0.0"; }; buftok = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rzsy1vy50v55x9z0nivf23y0r9jkmq6i130xa75pq9i8qrn1mxs"; type = "gem"; }; version = "0.2.0"; }; builder = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0pw3r2lyagsxkm71bf44v5b74f7l9r7di22brbyji9fwz791hya9"; type = "gem"; }; version = "3.3.0"; }; byebug = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nx3yjf4xzdgb8jkmk2344081gqr22pgjqnmjg2q64mj5d6r9194"; type = "gem"; }; version = "11.1.3"; }; byk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cw26m1977kk6awns8h3d10f9bq9j467s0a4srdvkhgy6ar2jagn"; type = "gem"; }; version = "1.1.0"; }; capybara = { - dependencies = ["addressable" "matrix" "mini_mime" "nokogiri" "rack" "rack-test" "regexp_parser" "xpath"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "matrix" + "mini_mime" + "nokogiri" + "rack" + "rack-test" + "regexp_parser" + "xpath" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vxfah83j6zpw3v5hic0j70h519nvmix2hbszmjwm8cfawhagns2"; type = "gem"; }; version = "3.40.0"; }; cbor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dsf9gjc2cj79vrnz2vgq573biqjw7ad4b0idm05xg6rb3y9gq4y"; type = "gem"; }; version = "0.5.9.8"; }; cgi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0c5494n3n6l51n1w1vc118zckbqdzk7r6b656hswg72w0bif2ja3"; type = "gem"; }; version = "0.4.1"; }; childprocess = { - dependencies = ["logger"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "logger" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1v5nalaarxnfdm6rxb7q6fmc6nx097jd630ax6h9ch7xw95li3cs"; type = "gem"; }; version = "5.1.0"; }; chunky_png = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znw5x86hmm9vfhidwdsijz8m38pqgmv98l9ryilvky0aldv7mc9"; type = "gem"; }; version = "1.4.0"; }; clavius = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0y58v8k860vafm1psm69f2ndcqmcifyvswsjdy8bxbxy30zrgad1"; type = "gem"; }; version = "1.0.4"; }; clearbit = { - dependencies = ["nestful"]; - groups = ["default"]; - platforms = []; + dependencies = [ "nestful" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ccgvxzgpll1wr5i9wjm1h0m2z600j6c4yf6pww423qhg8a25lbl"; type = "gem"; }; version = "0.3.3"; }; coderay = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0jvxqxzply1lwp7ysn94zjhh57vc14mcshw1ygw14ib8lhc00lyw"; type = "gem"; }; version = "1.1.3"; }; coffee-rails = { - dependencies = ["coffee-script" "railties"]; - groups = ["assets"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "coffee-script" + "railties" + ]; + groups = [ "assets" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "170sp4y82bf6nsczkkkzypzv368sgjg6lfrkib4hfjgxa6xa3ajx"; type = "gem"; }; version = "5.0.0"; }; coffee-script = { - dependencies = ["coffee-script-source" "execjs"]; - groups = ["assets" "default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "coffee-script-source" + "execjs" + ]; + groups = [ + "assets" + "default" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0rc7scyk7mnpfxqv5yy4y5q1hx3i7q3ahplcp4bq2g5r24g2izl2"; type = "gem"; }; version = "2.4.1"; }; coffee-script-source = { - groups = ["assets" "default"]; - platforms = []; + groups = [ + "assets" + "default" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1907v9q1zcqmmyqzhzych5l7qifgls2rlbnbhy5vzyr7i7yicaz1"; type = "gem"; }; version = "1.12.2"; }; concurrent-ruby = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; connection_pool = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; cose = { - dependencies = ["cbor" "openssl-signature_algorithm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "cbor" + "openssl-signature_algorithm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1rbdzl9n8ppyp38y75hw06s17kp922ybj6jfvhz52p83dg6xpm6m"; type = "gem"; }; version = "1.3.1"; }; crack = { - dependencies = ["bigdecimal" "rexml"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bigdecimal" + "rexml" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0jaa7is4fw1cxigm8vlyhg05bw4nqy4f91zjqxk7pp4c8bdyyfn8"; type = "gem"; }; version = "1.0.0"; }; crass = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0pfl5c0pyqaparxaqxi6s4gfl21bdldwiawrc0aknyvflli60lfw"; type = "gem"; }; version = "1.0.6"; }; csv = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zfn40dvgjk1xv1z8l11hr9jfg3jncwsc9yhzsz4l4rivkpivg8b"; type = "gem"; }; version = "3.3.0"; }; daemons = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07cszb0zl8mqmwhc8a2yfg36vi6lbgrp4pa5bvmryrpcz9v6viwg"; type = "gem"; }; version = "1.4.1"; }; dalli = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19daxf5n5gr3pr57k4wqg701c3zwsk2h4jjialkaw7yrhi85jqrf"; type = "gem"; }; version = "3.2.8"; }; date = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "149jknsq999gnhy865n33fkk22s0r447k76x9pmcnnwldfv2q7wp"; type = "gem"; }; version = "3.3.4"; }; debug_inspector = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18k8x9viqlkh7dbmjzh8crbjy8w480arpa766cw1dnn3xcpa1pwv"; type = "gem"; }; version = "1.2.0"; }; delayed_job = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zyjp3yfchfw1jynvxk3147hzmchwq8cnqh16gjii557nd0z0mhx"; type = "gem"; }; version = "4.1.12"; }; delayed_job_active_record = { - dependencies = ["activerecord" "delayed_job"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activerecord" + "delayed_job" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08dl21wbrhb5ynk23dqv71wmm3s0zcz1xa0hmmmwk3yh48irza6j"; type = "gem"; }; version = "4.1.10"; }; deprecation_toolkit = { - dependencies = ["activesupport"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "activesupport" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0f37k15bsq6aq8bikkvlg5bi96ic8z7hwyxxcz8mx3xgkgfdhzx0"; type = "gem"; }; version = "2.2.1"; }; diff-lcs = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1znxccz83m4xgpd239nyqxlifdb7m8rlfayk6s259186nkgj6ci7"; type = "gem"; }; version = "1.5.1"; }; diffy = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qcsv29ljfhy76gq4xi8zpn6dc6nv15c41r131bdr38kwpxjzd1n"; type = "gem"; }; version = "3.4.2"; }; domain_name = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cyr2xm576gqhqicsyqnhanni47408w2pgvrfi8pd13h2li3nsaz"; type = "gem"; }; version = "0.6.20240107"; }; doorkeeper = { - dependencies = ["railties"]; - groups = ["default"]; - platforms = []; + dependencies = [ "railties" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a6nbc12nfz355am2vwm1ql2p8zck7mr941glghmnl32djaga24b"; type = "gem"; }; version = "5.7.1"; }; drb = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0h5kbj9hvg5hb3c7l425zpds0vb42phvln2knab8nmazg2zp5m79"; type = "gem"; }; version = "2.2.1"; }; dry-cli = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18cxi596f5x1vglnma4hhm6z15m7yma6yparsybyfz3a2z0iqc08"; type = "gem"; }; version = "1.1.0"; }; dry-core = { - dependencies = ["concurrent-ruby" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "03a5qn74c4lk2rpy6wlhv66synjlyzc4wn086xzphkpmw12l4bzk"; type = "gem"; }; version = "1.0.1"; }; dry-inflector = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14k7q3jvzphkbkd4i1s3ika6kz4p9pcqy78z0yimahwvnsqvj3rl"; type = "gem"; }; version = "1.1.0"; }; dry-logic = { - dependencies = ["concurrent-ruby" "dry-core" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "dry-core" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05nldkc154r0qzlhss7n5klfiyyz05x2fkq08y13s34py6023vcr"; type = "gem"; }; version = "1.5.0"; }; dry-struct = { - dependencies = ["dry-core" "dry-types" "ice_nine" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "dry-core" + "dry-types" + "ice_nine" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1rnlgn4wif0dvkvi10xwh1vd1q6mp35q6a7lwva0zmbc79dh4drp"; type = "gem"; }; version = "1.6.0"; }; dry-types = { - dependencies = ["bigdecimal" "concurrent-ruby" "dry-core" "dry-inflector" "dry-logic" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bigdecimal" + "concurrent-ruby" + "dry-core" + "dry-inflector" + "dry-logic" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0sn4n13jj8x27n07yv2s7zp0c5cdlwsbh21laqm5f7ikhp10y67z"; type = "gem"; }; version = "1.7.2"; }; eco = { - dependencies = ["coffee-script" "eco-source" "execjs"]; - groups = ["assets"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "coffee-script" + "eco-source" + "execjs" + ]; + groups = [ "assets" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "09jiwb7pkg0sxk730maxahra4whqw5l47zd7yg7fvd71pikdwdr0"; type = "gem"; }; version = "1.0.0"; }; eco-source = { - groups = ["assets" "default"]; - platforms = []; + groups = [ + "assets" + "default" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ccxrvaac6mw5kdj1i490b5xb1wdka3a5q4jhvn8dvg41594yba1"; type = "gem"; }; version = "1.1.0.rc.1"; }; em-websocket = { - dependencies = ["eventmachine" "http_parser.rb"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "eventmachine" + "http_parser.rb" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1a66b0kjk6jx7pai9gc7i27zd0a128gy73nmas98gjz6wjyr4spm"; type = "gem"; }; version = "0.5.3"; }; email_address = { - dependencies = ["simpleidn"]; - groups = ["default"]; - platforms = []; + dependencies = [ "simpleidn" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09clyyp65ry2dqg4kwr4lbyi40c9nci282qxpfgmvq75z8clia8y"; type = "gem"; }; version = "0.2.4"; }; equalizer = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kjmx3fygx8njxfrwcmn7clfhjhb6bvv3scy2lyyi0wqyi3brra4"; type = "gem"; }; version = "0.0.11"; }; erubi = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0qnd6ff4az22ysnmni3730c41b979xinilahzg86bn7gv93ip9pw"; type = "gem"; }; version = "1.13.0"; }; eventmachine = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wh9aqb0skz80fhfn66lbpr4f86ya2z5rx6gm5xlfhd05bj1ch4r"; type = "gem"; }; version = "1.2.7"; }; execjs = { - groups = ["assets"]; - platforms = []; + groups = [ "assets" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yywajqlpjhrj1m43s3lfg3i4lkb6pxwccmwps7qw37ndmphdzg8"; type = "gem"; }; version = "2.9.1"; }; factory_bot = { - dependencies = ["activesupport"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "activesupport" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0q927lvgjqj0xaplxhicj5xv8xadx3957mank3p7g01vb6iv6x33"; type = "gem"; }; version = "6.5.0"; }; factory_bot_rails = { - dependencies = ["factory_bot" "railties"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "factory_bot" + "railties" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1j6w4rr2cb5wng9yrn2ya9k40q52m0pbz47kzw8xrwqg3jncwwza"; type = "gem"; }; version = "6.4.3"; }; faker = { - dependencies = ["i18n"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "i18n" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1xj0xx2snnxzjipxpxwiki7053441jkdg10h0rmjiri040s5lssi"; type = "gem"; }; version = "3.4.2"; }; faraday = { - dependencies = ["faraday-net_http" "json" "logger"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-net_http" + "json" + "logger" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05s5pyxh7y68jphb0lgrh0ksxbp4lmbsc6a6qg0ahj15pjqx01ni"; type = "gem"; }; version = "2.12.0"; }; faraday-mashify = { - dependencies = ["faraday" "hashie"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "hashie" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1fiy1bqwx7sj3dmydlyqzj4lapkb2p84pmp4f6i2g0ypj1wbrcml"; type = "gem"; }; version = "0.1.1"; }; faraday-multipart = { - dependencies = ["multipart-post"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "multipart-post" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "09871c4hd7s5ws1wl4gs7js1k2wlby6v947m2bbzg43pnld044lh"; type = "gem"; }; version = "1.0.4"; }; faraday-net_http = { - dependencies = ["net-http"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "net-http" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0rg54k4skaz8z7j358p6pdzc9pr84fjq7sdlpicf7s5ig7vb1rlk"; type = "gem"; }; version = "3.3.0"; }; ffi = { - groups = ["assets" "default"]; - platforms = []; + groups = [ + "assets" + "default" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; ffi-compiler = { - dependencies = ["ffi" "rake"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ffi" + "rake" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1844j58cdg2q6g0rqfwg4rrambnhf059h4yg9rfmrbrcs60kskx9"; type = "gem"; }; version = "1.3.2"; }; fiber-storage = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zxblmxwdpj3587wji5325y53gjdcmzxzm6126dyg58b3qzk42mq"; type = "gem"; }; version = "1.0.0"; }; gli = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1fd4blr0pa0b4dd9pzqqpzh49m3p1ff4aa0bys4wpk1jniisl7vy"; type = "gem"; }; version = "2.21.5"; }; globalid = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sbw6b66r7cwdx3jhs46s4lr991969hvigkjpbdl7y3i31qpdgvh"; type = "gem"; }; version = "1.2.1"; }; graphql = { - dependencies = ["base64" "fiber-storage"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "fiber-storage" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1is9rr5l0lw9z12h9v064fpp1nrnv42p2z2j1r3mnk4ik1lrdjba"; type = "gem"; }; version = "2.3.16"; }; graphql-batch = { - dependencies = ["graphql" "promise.rb"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "graphql" + "promise.rb" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0mxy2m24y7adnz2dw4466jzp47yfcmbm1pmmrljqmrafmjmils8p"; type = "gem"; }; version = "0.6.0"; }; hashdiff = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0slky0n6n12gjgimzdbdigpwyg5wgq8fysjwkzzfw33ff8b675n7"; type = "gem"; }; version = "1.1.1"; }; hashie = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1nh3arcrbz1rc1cr59qm53sdhqm137b258y8rcb4cvd3y98lwv4x"; type = "gem"; }; version = "5.0.0"; }; hiredis = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04jj8k7lxqxw24sp0jiravigdkgsyrpprxpxm71ba93x1wr2w1bz"; type = "gem"; }; version = "0.6.3"; }; htmlentities = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nkklqsn8ir8wizzlakncfv42i32wc0w9hxp00hvdlgjr7376nhj"; type = "gem"; }; version = "4.3.4"; }; http = { - dependencies = ["addressable" "http-cookie" "http-form_data" "http-parser"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "http-cookie" + "http-form_data" + "http-parser" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0z8vmvnkrllkpzsxi94284di9r63g9v561a16an35izwak8g245y"; type = "gem"; }; version = "4.4.1"; }; http-cookie = { - dependencies = ["domain_name"]; - groups = ["default"]; - platforms = []; + dependencies = [ "domain_name" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lr2yk5g5vvf9nzlmkn3p7mhh9mn55gpdc7kl2w21xs46fgkjynb"; type = "gem"; }; version = "1.0.7"; }; http-form_data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wx591jdhy84901pklh1n9sgh74gnvq1qyqxwchni1yrc49ynknc"; type = "gem"; }; version = "2.3.0"; }; http-parser = { - dependencies = ["ffi-compiler"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi-compiler" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18qqvckvqjffh88hfib6c8pl9qwk9gp89w89hl3f2s1x8hgyqka1"; type = "gem"; }; version = "1.2.3"; }; "http_parser.rb" = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15nidriy0v5yqfjsgsra51wmknxci2n2grliz78sf9pga3n0l7gi"; type = "gem"; }; version = "0.6.0"; }; httparty = { - dependencies = ["mini_mime" "multi_xml"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_mime" + "multi_xml" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "050jzsa6fbfvy2rldhk7mf1sigildaqvbplfz2zs6c0zlzwppvq0"; type = "gem"; }; version = "0.21.0"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "concurrent-ruby" ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k31wcgnvcvd14snz0pfqj976zv6drfsnq6x8acz10fiyms9l8nw"; type = "gem"; }; version = "1.14.6"; }; icalendar = { - dependencies = ["ice_cube" "ostruct"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ice_cube" + "ostruct" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "11fl1kfqvgnh0vnryc9kbbaal693kdgf5h6qnj37p9wz5xkw5gqf"; type = "gem"; }; version = "2.10.3"; }; icalendar-recurrence = { - dependencies = ["icalendar" "ice_cube" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "icalendar" + "ice_cube" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "01226l14p9wys5vla2l36a51cjffp96i4dk01frffd042qjgmf2x"; type = "gem"; }; version = "1.2.0"; }; ice_cube = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gpwlpshsjlld53h1f999p0azd9jdlgmhbswa19wqjjbv9fv9pij"; type = "gem"; }; version = "0.17.0"; }; ice_nine = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nv35qg1rps9fsis28hz2cq2fx1i96795f91q4nmkm934xynll2x"; type = "gem"; }; version = "0.11.2"; }; inflection = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mfkk0j0dway3p4gwzk8fnpi4hwaywl2v0iywf1azf98zhk9pfnf"; type = "gem"; }; version = "1.0.0"; }; iniparse = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1wb1qy4i2xrrd92dc34pi7q7ibrjpapzk9y465v0n9caiplnb89n"; type = "gem"; }; version = "1.5.0"; }; interception = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01vrkn28psdx1ysh5js3hn17nfp1nvvv46wc1pwqsakm6vb1hf55"; type = "gem"; }; version = "0.5"; }; io-console = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08d2lx42pa8jjav0lcjbzfzmw61b8imxr9041pva8xzqabrczp7h"; type = "gem"; }; version = "0.7.2"; }; irb = { - dependencies = ["rdoc" "reline"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rdoc" + "reline" + ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1y40dv3caswr81dlsyln6vnmmpzf5jcal2rqjbsglvnkb0xh0xar"; type = "gem"; }; version = "1.14.1"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cdw9vw2qly7q7r41s7phnac264rbsdqgj4l0h4nqgbjb157g393"; type = "gem"; }; version = "1.6.2"; }; json = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0b4qsi8gay7ncmigr0pnbxyb17y3h8kavdyhsh7nrlqwr35vb60q"; type = "gem"; }; version = "2.7.2"; }; jwt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bg8pjx0mpvl10k6d8a6gc8dzlv2z5jkqcjbjcirnk032iriq838"; type = "gem"; }; version = "2.3.0"; }; keycloak-admin = { - dependencies = ["hashie" "httparty"]; - groups = ["development" "test"]; - platforms = []; + dependencies = [ + "hashie" + "httparty" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { fetchSubmodules = false; rev = "7ea4e62d77fad93fc2da840c3f8bd5c45588d131"; @@ -1289,582 +1655,729 @@ version = "23.0.7"; }; koala = { - dependencies = ["addressable" "base64" "faraday" "faraday-multipart" "json" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "base64" + "faraday" + "faraday-multipart" + "json" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0z40pvvwbr95b0kk92rgimvhma0ahiv07ihxkvglm6jwi9cbxp42"; type = "gem"; }; version = "3.6.0"; }; language_server-protocol = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gvb1j8xsqxms9mww01rmdl78zkd72zgxaap56bhv8j45z05hp1x"; type = "gem"; }; version = "3.17.0.3"; }; listen = { - dependencies = ["rb-fsevent" "rb-inotify"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rb-fsevent" + "rb-inotify" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0rwwsmvq79qwzl6324yc53py02kbrcww35si720490z5w0j497nv"; type = "gem"; }; version = "3.9.0"; }; little-plugger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1frilv82dyxnlg8k1jhrvyd73l6k17mxc5vwxx080r4x1p04gwym"; type = "gem"; }; version = "1.1.4"; }; localhost = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1621bz9zyjkgcpgsqyf8xww72jhv3q8lbjxlzq28xcnqkkcailzw"; type = "gem"; }; version = "1.3.1"; }; logger = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; logging = { - dependencies = ["little-plugger" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "little-plugger" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1jqcq2yxh973f3aw63nd3wxhqyhkncz3pf8v2gs3df0iqair725s"; type = "gem"; }; version = "2.4.0"; }; loofah = { - dependencies = ["crass" "nokogiri"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "crass" + "nokogiri" + ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zkjqf37v2d7s11176cb35cl83wls5gm3adnfkn2zcc61h3nxmqh"; type = "gem"; }; version = "2.22.0"; }; macaddr = { - dependencies = ["systemu"]; - groups = ["default"]; - platforms = []; + dependencies = [ "systemu" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10nzvbp3raa93afisa870005acmv2vlrka82pxh13g4bjq4phdys"; type = "gem"; }; version = "1.7.2"; }; mail = { - dependencies = ["mini_mime" "net-imap" "net-pop" "net-smtp"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_mime" + "net-imap" + "net-pop" + "net-smtp" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1bf9pysw1jfgynv692hhaycfxa8ckay1gjw5hz3madrbrynryfzc"; type = "gem"; }; version = "2.8.1"; }; marcel = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "190n2mk8m1l708kr88fh6mip9sdsh339d2s6sgrik3sbnvz4jmhd"; type = "gem"; }; version = "1.0.4"; }; matrix = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1h2cgkpzkh3dd0flnnwfq6f3nl2b1zff9lvqz8xs853ssv5kq23i"; type = "gem"; }; version = "0.4.2"; }; memoizable = { - dependencies = ["thread_safe"]; - groups = ["default"]; - platforms = []; + dependencies = [ "thread_safe" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0v42bvghsvfpzybfazl14qhkrjvx0xlmxz0wwqc960ga1wld5x5c"; type = "gem"; }; version = "0.4.2"; }; messagebird-rest = { - dependencies = ["jwt"]; - groups = ["default"]; - platforms = []; + dependencies = [ "jwt" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zghnl12l22adm6lgswj4im3qm70lfnsyl9gg6gd9c89hj467hsk"; type = "gem"; }; version = "4.0.0"; }; method_source = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1igmc3sq9ay90f8xjvfnswd1dybj1s3fi0dwd53inwsvqk4h24qq"; type = "gem"; }; version = "1.1.0"; }; mime-types = { - dependencies = ["logger" "mime-types-data"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "logger" + "mime-types-data" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0r34mc3n7sxsbm9mzyzy8m3dvq7pwbryyc8m452axkj0g2axnwbg"; type = "gem"; }; version = "3.6.0"; }; mime-types-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06dbn0j13jwdrmlvrjd50mxqrjlkh3lvxp0afh4glyzbliqvqpsd"; type = "gem"; }; version = "3.2024.1001"; }; mini_mime = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vycif7pjzkr29mfk4dlqv3disc5dn0va04lkwajlpr1wkibg0c6"; type = "gem"; }; version = "1.1.5"; }; mini_portile2 = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1q1f2sdw3y3y9mnym9dhjgsjr72sq975cfg5c4yx7gwv8nmzbvhk"; type = "gem"; }; version = "2.8.7"; }; minitest = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1n1akmc6bibkbxkzm1p1wmfb4n9vv397knkgz0ffykb3h1d7kdix"; type = "gem"; }; version = "5.25.1"; }; msgpack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a5adcb7bwan09mqhj3wi9ib52hmdzmqg7q08pggn3adibyn5asr"; type = "gem"; }; version = "1.7.2"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; multi_xml = { - dependencies = ["bigdecimal"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "bigdecimal" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "06x61ca5j84nyhr1mwh9r436yiphnc5hmacb3gwqyn5gd0611kjg"; type = "gem"; }; version = "0.7.1"; }; multipart-post = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1a5lrlvmg2kb2dhw3lxcsv6x276bwgsxpnka1752082miqxd0wlq"; type = "gem"; }; version = "2.4.1"; }; mutex_m = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ma093ayps1m92q845hmpk0dmadicvifkbf05rpq9pifhin0rvxn"; type = "gem"; }; version = "0.2.0"; }; mysql2 = { - groups = ["mysql"]; - platforms = []; + groups = [ "mysql" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cysv1wdfdbizwkd0d9s16s832khdwv31pgp01mw2g3bbpa4gx3h"; type = "gem"; }; version = "0.5.6"; }; naught = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wwjx35zgbc0nplp8a866iafk4zsrbhwwz4pav5gydr2wm26nksg"; type = "gem"; }; version = "1.1.0"; }; nestful = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sn7lrdhp1dwn9xkqwkarby5bxx1g30givy3fi1dwp1xvqbrqikw"; type = "gem"; }; version = "1.1.4"; }; net-ftp = { - dependencies = ["net-protocol" "time"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "net-protocol" + "time" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0kw7g0j35fla8438s90m72b3xr0mqnpgm910qcwrgnvyg903xmi8"; type = "gem"; }; version = "0.3.8"; }; net-http = { - dependencies = ["uri"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "uri" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "10n2n9aq00ih8v881af88l1zyrqgs5cl3njdw8argjwbl5ggqvm9"; type = "gem"; }; version = "0.4.1"; }; net-imap = { - dependencies = ["date" "net-protocol"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "date" + "net-protocol" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "160mfk4gnpwfc7j4kpchxgzfkml54h94q7vfzjw061flrkrclyqj"; type = "gem"; }; version = "0.4.17"; }; net-ldap = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0g9gz39bs2iy4ky4fhjphimqd9m9wdsaz50anxgwg3yjrff3famy"; type = "gem"; }; version = "0.19.0"; }; net-pop = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wyz41jd4zpjn0v1xsf9j778qx1vfrl24yc20cpmph8k42c4x2w4"; type = "gem"; }; version = "0.1.2"; }; net-protocol = { - dependencies = ["timeout"]; - groups = ["default"]; - platforms = []; + dependencies = [ "timeout" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a32l4x73hz200cm587bc29q8q9az278syw3x6fkc9d1lv5y0wxa"; type = "gem"; }; version = "0.2.2"; }; net-smtp = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0amlhz8fhnjfmsiqcjajip57ici2xhw089x7zqyhpk51drg43h2z"; type = "gem"; }; version = "0.5.0"; }; nio4r = { - groups = ["default" "puma"]; - platforms = []; + groups = [ + "default" + "puma" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "017nbw87dpr4wyk81cgj8kxkxqgsgblrkxnmmadc77cg9gflrfal"; type = "gem"; }; version = "2.7.3"; }; nkf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09piyp2pd74klb9wcn0zw4mb5l0k9wzwppxggxi1yi95l2ym3hgv"; type = "gem"; }; version = "0.2.0"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15gysw8rassqgdq3kwgl4mhqmrgh7nk2qvrcqp4ijyqazgywn6gq"; type = "gem"; }; version = "1.16.7"; }; nori = { - dependencies = ["bigdecimal"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bigdecimal" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qb84bbi74q0zgs09sdkq750jf2ri3lblbry0xi4g1ard4rwsrk1"; type = "gem"; }; version = "2.7.1"; }; oauth = { - dependencies = ["oauth-tty" "snaky_hash" "version_gem"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "oauth-tty" + "snaky_hash" + "version_gem" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1syx3hfimaqycy21kn8gmal1cb3bw3hzalv3in2ixnay1xzjp41q"; type = "gem"; }; version = "1.1.0"; }; oauth-tty = { - dependencies = ["version_gem"]; - groups = ["default"]; - platforms = []; + dependencies = [ "version_gem" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05wb5n36i4h23hh9dx2m2cwjxx5vj0vgyrn2xr6rsl54glq5rqil"; type = "gem"; }; version = "1.0.5"; }; oauth2 = { - dependencies = ["faraday" "jwt" "multi_xml" "rack" "snaky_hash" "version_gem"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "jwt" + "multi_xml" + "rack" + "snaky_hash" + "version_gem" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yzpaghh8kwzgmvmrlbzf36ks5s2hf34rayzw081dp2jrzprs7xj"; type = "gem"; }; version = "2.0.9"; }; omniauth = { - dependencies = ["hashie" "rack" "rack-protection"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "hashie" + "rack" + "rack-protection" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1km0wqx9pj609jidvrqfsvzbzfgdnlpdnv7i7xfqm3wb55vk5w6y"; type = "gem"; }; version = "2.1.2"; }; omniauth-facebook = { - dependencies = ["bigdecimal" "omniauth-oauth2"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bigdecimal" + "omniauth-oauth2" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1qdrziqfa4sqpqf77i0nzbwq4qyg8qaqd127alnmg1skvax6rp6z"; type = "gem"; }; version = "10.0.0"; }; omniauth-github = { - dependencies = ["omniauth" "omniauth-oauth2"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "omniauth" + "omniauth-oauth2" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1m6a7kg3lxz2nm96prln2ja8r4wlm37m5vsy9199vnynqq5fgy4g"; type = "gem"; }; version = "2.0.1"; }; omniauth-gitlab = { - dependencies = ["omniauth" "omniauth-oauth2"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "omniauth" + "omniauth-oauth2" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "04wnjnapgwsnyd3dfnp8dp1jjnsg64zkls5xharj10j822kiygsl"; type = "gem"; }; version = "4.1.0"; }; omniauth-google-oauth2 = { - dependencies = ["jwt" "oauth2" "omniauth" "omniauth-oauth2"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "jwt" + "oauth2" + "omniauth" + "omniauth-oauth2" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0h7gcihxnnc1xc123g3frvj524j6x3axi9blfn44kj9m7hxn5b9i"; type = "gem"; }; version = "1.1.3"; }; omniauth-linkedin-oauth2 = { - dependencies = ["omniauth-oauth2"]; - groups = ["default"]; - platforms = []; + dependencies = [ "omniauth-oauth2" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xai5k6xzinc4d67n64y1acffs8p7xi2hikz493dz6jx8qv9b2g3"; type = "gem"; }; version = "1.0.1"; }; omniauth-microsoft-office365 = { - dependencies = ["omniauth" "omniauth-oauth2"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "omniauth" + "omniauth-oauth2" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vw6418gykxqd9z32ddq0mr6wa737la1zwppb1ilw9sgii24rg1v"; type = "gem"; }; version = "0.0.8"; }; omniauth-oauth = { - dependencies = ["oauth" "omniauth" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "oauth" + "omniauth" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1a4dqmlv3if6hb4ddyx4y5v7vkpi7zq901104nl0ya1l0b4j5gr5"; type = "gem"; }; version = "1.2.1"; }; omniauth-oauth2 = { - dependencies = ["oauth2" "omniauth"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "oauth2" + "omniauth" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0y4y122xm8zgrxn5nnzwg6w39dnjss8pcq2ppbpx9qn7kiayky5j"; type = "gem"; }; version = "1.8.0"; }; omniauth-rails_csrf_protection = { - dependencies = ["actionpack" "omniauth"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "omniauth" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1q2zvkw34vk1vyhn5kp30783w1wzam9i9g5ygsdjn2gz59kzsw0i"; type = "gem"; }; version = "1.0.2"; }; omniauth-saml = { - dependencies = ["omniauth" "ruby-saml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "omniauth" + "ruby-saml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00nn24s74miy7p65y8lwpjfwgcn7fwld61f9ghngal4asgw6pfwa"; type = "gem"; }; version = "2.2.1"; }; omniauth-twitter = { - dependencies = ["omniauth-oauth" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "omniauth-oauth" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0r5j65hkpgzhvvbs90id3nfsjgsad6ymzggbm7zlaxvnrmvnrk65"; type = "gem"; }; version = "1.4.0"; }; omniauth-weibo-oauth2 = { - dependencies = ["omniauth" "omniauth-oauth2"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "omniauth" + "omniauth-oauth2" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { fetchSubmodules = false; rev = "06803ef97f822ede854322587db8049cc67dcfa6"; @@ -1875,1278 +2388,1738 @@ version = "0.5.2"; }; openssl = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "054d6ybgjdzxw567m7rbnd46yp6gkdbc5ihr536vxd3p15vbhjrw"; type = "gem"; }; version = "3.2.0"; }; openssl-signature_algorithm = { - dependencies = ["openssl"]; - groups = ["default"]; - platforms = []; + dependencies = [ "openssl" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "103yjl68wqhl5kxaciir5jdnyi7iv9yckishdr52s5knh9g0pd53"; type = "gem"; }; version = "1.3.0"; }; ostruct = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11dsv71gfbhy92yzj3xkckjzdai2bsz5a4fydgimv62dkz4kc5rv"; type = "gem"; }; version = "0.6.0"; }; overcommit = { - dependencies = ["childprocess" "iniparse" "rexml"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "childprocess" + "iniparse" + "rexml" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0lpl1ppjrqwsmywsb4srfjfm31dna30jrjyx2lkmws7s2jchy94v"; type = "gem"; }; version = "0.64.0"; }; parallel = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vy7sjs2pgz4i96v5yk9b7aafbffnvq7nn419fgvw55qlavsnsyq"; type = "gem"; }; version = "1.26.3"; }; parser = { - dependencies = ["ast" "racc"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ast" + "racc" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1cqs31cyg2zp8yx2zzm3zkih0j93q870wasbviy2w343nxqvn3pk"; type = "gem"; }; version = "3.3.5.0"; }; pg = { - groups = ["postgres"]; - platforms = []; + groups = [ "postgres" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dsgcmzc55w7i9cpghfkzhmiskzndvp1vijd8c5ryv8xvlwikmzg"; type = "gem"; }; version = "1.5.8"; }; PoParser = { - dependencies = ["simple_po_parser"]; - groups = ["default"]; - platforms = []; + dependencies = [ "simple_po_parser" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rl8vkqhdxzk416q898drqinmfji13wjnbxbqbzjkz3wvd7pikzm"; type = "gem"; }; version = "3.2.8"; }; power_assert = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1y2c5mvkq7zc5vh4ijs1wc9hc0yn4mwsbrjch34jf11pcz116pnd"; type = "gem"; }; version = "2.0.3"; }; "promise.rb" = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a819sikcqvhi8hck1y10d1nv2qkjvmmm553626fmrh51h2i089d"; type = "gem"; }; version = "0.7.4"; }; pry = { - dependencies = ["coderay" "method_source"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "coderay" + "method_source" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k9kqkd9nps1w1r1rb7wjr31hqzkka2bhi8b518x78dcxppm9zn4"; type = "gem"; }; version = "0.14.2"; }; pry-byebug = { - dependencies = ["byebug" "pry"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "byebug" + "pry" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1y41al94ks07166qbp2200yzyr5y60hm7xaiw4lxpgsm4b1pbyf8"; type = "gem"; }; version = "3.10.1"; }; pry-doc = { - dependencies = ["pry" "yard"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pry" + "yard" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0xgsr1agv754709fb7x11zn07skmbwlds88sa5s57d7x1apswmkd"; type = "gem"; }; version = "1.5.0"; }; pry-rails = { - dependencies = ["pry"]; - groups = ["default"]; - platforms = []; + dependencies = [ "pry" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0garafb0lxbm3sx2r9pqgs7ky9al58cl3wmwc0gmvmrl9bi2i7m6"; type = "gem"; }; version = "0.3.11"; }; pry-remote = { - dependencies = ["pry" "slop"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pry" + "slop" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "10g1wrkcy5v5qyg9fpw1cag6g5rlcl1i66kn00r7kwqkzrdhd7nm"; type = "gem"; }; version = "0.1.8"; }; pry-rescue = { - dependencies = ["interception" "pry"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "interception" + "pry" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1nx6mf97vv11bgy2giljgwds8rjj8kw0qyc6zn3varlqdm8gsnwq"; type = "gem"; }; version = "1.6.0"; }; pry-stack_explorer = { - dependencies = ["binding_of_caller" "pry"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "binding_of_caller" + "pry" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0h7kp99r8vpvpbvia079i58932qjz2ci9qhwbk7h1bf48ydymnx2"; type = "gem"; }; version = "0.6.1"; }; pry-theme = { - dependencies = ["coderay"]; - groups = ["default"]; - platforms = []; + dependencies = [ "coderay" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qhs1qmv6zhl45zhpv5qj6vkwm0nkdc37dqd49fwl8ph6f0sfh8h"; type = "gem"; }; version = "1.3.1"; }; psych = { - dependencies = ["stringio"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "stringio" ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0s5383m6004q76xm3lb732bp4sjzb6mxb6rbgn129gy2izsj4wrk"; type = "gem"; }; version = "5.1.2"; }; public_suffix = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0vqcw3iwby3yc6avs1vb3gfd0vcp2v7q310665dvxfswmcf4xm31"; type = "gem"; }; version = "6.0.1"; }; puma = { - dependencies = ["nio4r"]; - groups = ["puma"]; - platforms = []; + dependencies = [ "nio4r" ]; + groups = [ "puma" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gml1rixrfb0naciq3mrnqkpcvm9ahgps1c04hzxh4b801f69914"; type = "gem"; }; version = "6.4.3"; }; pundit = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wkm850z17gy5gph5lbmaz62wx7nvkj9r690017w10phkmxd5rj3"; type = "gem"; }; version = "2.4.0"; }; pundit-matchers = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks" "rspec-support"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + "rspec-support" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gmvppwknijhy013azyws85bkyck8x9ly7yh2162kxa59z1kbsgq"; type = "gem"; }; version = "3.1.2"; }; racc = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0byn0c9nkahsl93y9ln5bysq4j31q8xkf2ws42swighxd4lnjzsa"; type = "gem"; }; version = "1.8.1"; }; rack = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ax778fsfvlhj7c11n0d1wdcb8bxvkb190a9lha5d91biwzyx9g4"; type = "gem"; }; version = "2.2.10"; }; rack-attack = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0z6pj5vjgl6swq7a33gssf795k958mss8gpmdb4v4cydcs7px91w"; type = "gem"; }; version = "6.7.0"; }; rack-protection = { - dependencies = ["base64" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zzvivmdb4dkscc58i3gmcyrnypynsjwp6xgc4ylarlhqmzvlx1w"; type = "gem"; }; version = "3.2.0"; }; rack-proxy = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12jw7401j543fj8cc83lmw72d8k6bxvkp9rvbifi88hh01blnsj4"; type = "gem"; }; version = "0.7.7"; }; rack-session = { - dependencies = ["rack"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rack" ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0xhxhlsz6shh8nm44jsmd9276zcnyzii364vhcvf0k8b8bjia8d0"; type = "gem"; }; version = "1.0.2"; }; rack-test = { - dependencies = ["rack"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rack" ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ysx29gk9k14a14zsp5a8czys140wacvp91fja8xcja0j1hzqq8c"; type = "gem"; }; version = "2.1.0"; }; rackup = { - dependencies = ["rack" "webrick"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rack" + "webrick" + ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1wbr03334ba9ilcq25wh9913xciwj0j117zs60vsqm0zgwdkwpp9"; type = "gem"; }; version = "1.0.0"; }; rails = { - dependencies = ["actioncable" "actionmailbox" "actionmailer" "actionpack" "actiontext" "actionview" "activejob" "activemodel" "activerecord" "activestorage" "activesupport" "railties"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actioncable" + "actionmailbox" + "actionmailer" + "actionpack" + "actiontext" + "actionview" + "activejob" + "activemodel" + "activerecord" + "activestorage" + "activesupport" + "railties" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fa7maxd1ydbnws0fym43pv8j2c6k5dkg0z0fkq31j8jr1aqk7ja"; type = "gem"; }; version = "7.1.4.1"; }; rails-controller-testing = { - dependencies = ["actionpack" "actionview" "activesupport"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "actionview" + "activesupport" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "151f303jcvs8s149mhx2g5mn67487x0blrf9dzl76q1nb7dlh53l"; type = "gem"; }; version = "1.0.5"; }; rails-dom-testing = { - dependencies = ["activesupport" "minitest" "nokogiri"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "minitest" + "nokogiri" + ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fx9dx1ag0s1lr6lfr34lbx5i1bvn3bhyf3w3mx6h7yz90p725g5"; type = "gem"; }; version = "2.2.0"; }; rails-html-sanitizer = { - dependencies = ["loofah" "nokogiri"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "loofah" + "nokogiri" + ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1pm4z853nyz1bhhqr7fzl44alnx4bjachcr6rh6qjj375sfz3sc6"; type = "gem"; }; version = "1.6.0"; }; railties = { - dependencies = ["actionpack" "activesupport" "irb" "rackup" "rake" "thor" "zeitwerk"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "irb" + "rackup" + "rake" + "thor" + "zeitwerk" + ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ypihpilhxdz5p3sb5g37jn2sbfjhf2ydkxj097kkn7ri7a7702x"; type = "gem"; }; version = "7.1.4.1"; }; rainbow = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0smwg4mii0fm38pyb5fddbmrdpifwv22zv3d3px2xx497am93503"; type = "gem"; }; version = "3.1.1"; }; rake = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "17850wcwkgi30p7yqh60960ypn7yibacjjha0av78zaxwvd3ijs6"; type = "gem"; }; version = "13.2.1"; }; rb-fsevent = { - groups = ["assets" "default"]; - platforms = []; + groups = [ + "assets" + "default" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zmf31rnpm8553lqwibvv3kkx0v7majm1f341xbxc0bk5sbhp423"; type = "gem"; }; version = "0.11.2"; }; rb-inotify = { - dependencies = ["ffi"]; - groups = ["assets" "default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "ffi" ]; + groups = [ + "assets" + "default" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0vmy8xgahixcz6hzwy4zdcyn2y6d6ri8dqv5xccgzc1r292019x0"; type = "gem"; }; version = "0.11.1"; }; rchardet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1isj1b3ywgg2m1vdlnr41lpvpm3dbyarf1lla4dfibfmad9csfk9"; type = "gem"; }; version = "1.8.0"; }; rdoc = { - dependencies = ["psych"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "psych" ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ygk2zk0ky3d88v3ll7qh6xqvbvw5jin0hqdi1xkv1dhaw7myzdi"; type = "gem"; }; version = "6.7.0"; }; redis = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fikjg6j12ka6hh36dxzhfkpqqmilzjfzcdf59iwkzsgd63f0ziq"; type = "gem"; }; version = "4.8.1"; }; regexp_parser = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ik40vcv7mqigsfpqpca36hpmnx0536xa825ai5qlkv3mmkyf9ss"; type = "gem"; }; version = "2.9.2"; }; reline = { - dependencies = ["io-console"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "io-console" ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0rl1jmxs7pay58l7lkxkrn6nkdpk52k8rvnfwqsd1swjlxlwjq0n"; type = "gem"; }; version = "0.5.10"; }; rexml = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1j9p66pmfgxnzp76ksssyfyqqrg7281dyi3xyknl3wwraaw7a66p"; type = "gem"; }; version = "3.3.9"; }; rotp = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0m48hv6wpmmm6cjr6q92q78h1i610riml19k5h1dil2yws3h1m3m"; type = "gem"; }; version = "6.3.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rspec-support" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0s688wfw77fjldzayvczg8bgwcgh6bh552dw7qcj1rhjk3r4zalx"; type = "gem"; }; version = "3.13.1"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0n3cyrhsa75x5wwvskrrqk56jbjgdi2q1zx0irllf0chkgsmlsqf"; type = "gem"; }; version = "3.13.3"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0f3vgp43hajw716vmgjv6f4ar6f97zf50snny6y3fy9kkj4qjw88"; type = "gem"; }; version = "3.13.1"; }; rspec-rails = { - dependencies = ["actionpack" "activesupport" "railties" "rspec-core" "rspec-expectations" "rspec-mocks" "rspec-support"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "railties" + "rspec-core" + "rspec-expectations" + "rspec-mocks" + "rspec-support" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ycjggcmzbgrfjk04v26b43c3fj5jq2qic911qk7585wvav2qaxd"; type = "gem"; }; version = "7.0.1"; }; rspec-retry = { - dependencies = ["rspec-core"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rspec-core" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0n6qc0d16h6bgh1xarmc8vc58728mgjcsjj8wcd822c8lcivl0b1"; type = "gem"; }; version = "0.6.2"; }; rspec-support = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "03z7gpqz5xkw9rf53835pa8a9vgj4lic54rnix9vfwmp2m7pv1s8"; type = "gem"; }; version = "3.13.1"; }; rszr = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1642s4w153pbfk98h9hv94wdylgp8nv6my3as75wvfpd7yl2ykjh"; type = "gem"; }; version = "1.5.0"; }; rubocop = { - dependencies = ["json" "language_server-protocol" "parallel" "parser" "rainbow" "regexp_parser" "rubocop-ast" "ruby-progressbar" "unicode-display_width"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "json" + "language_server-protocol" + "parallel" + "parser" + "rainbow" + "regexp_parser" + "rubocop-ast" + "ruby-progressbar" + "unicode-display_width" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1rsyxrl647bz49gpa4flh8igg6wy7qxyh2jrp01x0kqnn5iw4y86"; type = "gem"; }; version = "1.66.1"; }; rubocop-ast = { - dependencies = ["parser"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "parser" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "03zywfpm4540q6hw8srhi8pzp0gg51w65ir8jkaw58vk3j31w820"; type = "gem"; }; version = "1.32.3"; }; rubocop-capybara = { - dependencies = ["rubocop"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rubocop" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1aw0n8jwhsr39r9q2k90xjmcz8ai2k7xx2a87ld0iixnv3ylw9jx"; type = "gem"; }; version = "2.21.0"; }; rubocop-factory_bot = { - dependencies = ["rubocop"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rubocop" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1aljadsjx7affcarzbhz7pydpy6fgqb8hl951y0cmrffxpa3rqcd"; type = "gem"; }; version = "2.26.1"; }; rubocop-faker = { - dependencies = ["faker" "rubocop"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faker" + "rubocop" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05d2mpi8xq50xh1s53h75hgvdhcz76lv9cnfn4jg35nbg67j1pdz"; type = "gem"; }; version = "1.1.0"; }; rubocop-graphql = { - dependencies = ["rubocop"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rubocop" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14j14ld5d3w141r5lgaljcd8q1g3w4xn592cwzqxlxw5n108v21d"; type = "gem"; }; version = "1.5.4"; }; rubocop-inflector = { - dependencies = ["activesupport" "rubocop" "rubocop-rspec"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "rubocop" + "rubocop-rspec" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1qdhwixqiix90a4n52g2b26mi66mrkx8b91pf7yda60m331jfbfr"; type = "gem"; }; version = "0.2.1"; }; rubocop-performance = { - dependencies = ["rubocop" "rubocop-ast"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rubocop" + "rubocop-ast" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0yd616imfjvlpwsk7lw5kq9h4iz6qkmf10xlaib6b47fy5x77ncy"; type = "gem"; }; version = "1.22.1"; }; rubocop-rails = { - dependencies = ["activesupport" "rack" "rubocop" "rubocop-ast"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "rack" + "rubocop" + "rubocop-ast" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1bc4xpyx0gldjdmbl9aaqav5bjiqfc2zdw7k2r1zblmgsq4ilmpm"; type = "gem"; }; version = "2.26.2"; }; rubocop-rspec = { - dependencies = ["rubocop"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rubocop" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1nwbi4j22gs1x559dyhpsdllz3vy2i1pw3cb9mpbpszynkdx9p0y"; type = "gem"; }; version = "3.1.0"; }; rubocop-rspec_rails = { - dependencies = ["rubocop" "rubocop-rspec"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rubocop" + "rubocop-rspec" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ijc1kw81884k0wjq1sgwaxa854n1fdddscp4fnzfzlx7zl150c8"; type = "gem"; }; version = "2.30.0"; }; ruby-progressbar = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cwvyb7j47m7wihpfaq7rc47zwwx9k4v7iqd9s1xch5nm53rrz40"; type = "gem"; }; version = "1.13.0"; }; ruby-saml = { - dependencies = ["nokogiri" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "nokogiri" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1adq06m684gnpjp6qyb8shgj8jjy2npcfg7y6mg2ab9ilfdq6684"; type = "gem"; }; version = "1.17.0"; }; rubyntlm = { - dependencies = ["base64"]; - groups = ["default"]; - platforms = []; + dependencies = [ "base64" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x8l0d1v88m40mby4jvgal46137cv8gga2lk7zlrxqlsp41380a7"; type = "gem"; }; version = "0.6.5"; }; rubyzip = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; safety_net_attestation = { - dependencies = ["jwt"]; - groups = ["default"]; - platforms = []; + dependencies = [ "jwt" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1khq0y5w7lf2b9a220298hphf3pakd216jc9a4x4a9pdwxs2vgln"; type = "gem"; }; version = "0.4.0"; }; sass = { - dependencies = ["sass-listen"]; - groups = ["assets" "default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "sass-listen" ]; + groups = [ + "assets" + "default" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0p95lhs0jza5l7hqci1isflxakz83xkj97lkvxl919is0lwhv2w0"; type = "gem"; }; version = "3.7.4"; }; sass-listen = { - dependencies = ["rb-fsevent" "rb-inotify"]; - groups = ["assets" "default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rb-fsevent" + "rb-inotify" + ]; + groups = [ + "assets" + "default" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0xw3q46cmahkgyldid5hwyiwacp590zj2vmswlll68ryvmvcp7df"; type = "gem"; }; version = "4.0.0"; }; sass-rails = { - dependencies = ["railties" "sass" "sprockets" "sprockets-rails" "tilt"]; - groups = ["assets"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "railties" + "sass" + "sprockets" + "sprockets-rails" + "tilt" + ]; + groups = [ "assets" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14vlfwdwzn308xhzgicwmhhryigis43gxfxlwb1d3mcixj3aqa4p"; type = "gem"; }; version = "5.1.0"; }; selenium-webdriver = { - dependencies = ["base64" "logger" "rexml" "rubyzip" "websocket"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "logger" + "rexml" + "rubyzip" + "websocket" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1md0sixm8dq8a7riv50x4q1z273q47b5jvcbv5hxympxn3ran4by"; type = "gem"; }; version = "4.25.0"; }; shoulda-matchers = { - dependencies = ["activesupport"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "activesupport" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1c082vpfdf3865xq6xayxw2hwqswhnc9g030p1gi4hmk9dzvnmch"; type = "gem"; }; version = "6.4.0"; }; simple_oauth = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dw9ii6m7wckml100xhjc6vxpjcry174lbi9jz5v7ibjr3i94y8l"; type = "gem"; }; version = "0.3.1"; }; simple_po_parser = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wybcipkfawg4pragmayiig03xc084x3hbwywsh1dr9x9pa8f9hj"; type = "gem"; }; version = "1.1.6"; }; simpleidn = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a9c1mdy12y81ck7mcn9f9i2s2wwzjh1nr92ps354q517zq9dkh8"; type = "gem"; }; version = "0.2.3"; }; slack-notifier = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "001bipchr45sny33nlavqgxca9y1qqxa7xpi7pvjfqiybwzvm6nd"; type = "gem"; }; version = "2.4.0"; }; slack-ruby-client = { - dependencies = ["faraday" "faraday-mashify" "faraday-multipart" "gli" "hashie"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "faraday-mashify" + "faraday-multipart" + "gli" + "hashie" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "03nq74m0d31wic05ldrdvn5n9inn60p9n78b9x8yh4dx32caj3ic"; type = "gem"; }; version = "2.4.0"; }; slop = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00w8g3j7k7kl8ri2cf1m58ckxk8rn350gp4chfscmgv6pq1spk3n"; type = "gem"; }; version = "3.6.0"; }; snaky_hash = { - dependencies = ["hashie" "version_gem"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "hashie" + "version_gem" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cfwvdcr46pk0c7m5aw2w3izbrp1iba0q7l21r37mzpwaz0pxj0s"; type = "gem"; }; version = "2.0.1"; }; sprockets = { - dependencies = ["base64" "concurrent-ruby" "rack"]; - groups = ["assets"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "concurrent-ruby" + "rack" + ]; + groups = [ "assets" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "10ykzsa76cf8kvbfkszlvbyn4ckcx1mxjhfvwxzs7y28cljhzhkj"; type = "gem"; }; version = "3.7.5"; }; sprockets-rails = { - dependencies = ["actionpack" "activesupport" "sprockets"]; - groups = ["assets" "default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "sprockets" + ]; + groups = [ + "assets" + "default" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "17hiqkdpcjyyhlm997mgdcr45v35j5802m5a979i5jgqx5n8xs59"; type = "gem"; }; version = "3.5.2"; }; stringio = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07mfqb40b2wh53k33h91zva78f9zwcdnl85jiq74wnaw2wa6wiak"; type = "gem"; }; version = "3.1.1"; }; systemu = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gmkbakhfci5wnmbfx5i54f25j9zsvbw858yg3jjhfs5n4ad1xq1"; type = "gem"; }; version = "2.6.5"; }; tcr = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fq1dxyc34fzyi9ivjb4wb3b4cs5pjh1cl44jn7rbzb8qdg6hp3p"; type = "gem"; }; version = "0.4.0"; }; telegram-bot-ruby = { - dependencies = ["dry-struct" "faraday" "faraday-multipart" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "dry-struct" + "faraday" + "faraday-multipart" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1flwm4206d2x56gmhqyvrvy4q4y57xnilj5j9f7hgp30b1h8p019"; type = "gem"; }; version = "2.0.0"; }; telephone_number = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zaqvxl4a4184pyjadayski818p4s5n4sh65yiy8w4n0liqxl3zm"; type = "gem"; }; version = "1.4.21"; }; terser = { - dependencies = ["execjs"]; - groups = ["assets"]; - platforms = []; + dependencies = [ "execjs" ]; + groups = [ "assets" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "176swgmwq0cc4z2134x12j9vjvx5y3nrlpbb8p6p0zhsn2wi2cf0"; type = "gem"; }; version = "1.2.3"; }; test-unit = { - dependencies = ["power_assert"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "power_assert" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fb0ya3w6cwl1xnvilggdhr223jn5az1jrhd7x551jlh77181r1w"; type = "gem"; }; version = "3.6.2"; }; thor = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1nmymd86a0vb39pzj2cwv57avdrl6pl3lf5bsz58q594kqxjkw7f"; type = "gem"; }; version = "1.3.2"; }; thread_safe = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nmhcgq6cgz44srylra07bmaw99f5271l0dpsvl5f75m44l0gmwy"; type = "gem"; }; version = "0.3.6"; }; tilt = { - groups = ["assets" "default"]; - platforms = []; + groups = [ + "assets" + "default" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kds7wkxmb038cwp6ravnwn8k65ixc68wpm8j5jx5bhx8ndg4x6z"; type = "gem"; }; version = "2.4.0"; }; time = { - dependencies = ["date"]; - groups = ["default"]; - platforms = []; + dependencies = [ "date" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pk1dwyvx3qvl9zqch4zcfm0h21ny4r0w67mh3wv5hgma173fj8r"; type = "gem"; }; version = "0.4.0"; }; timeout = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16mvvsmx90023wrhf8dxc1lpqh0m8alk65shb7xcya6a9gflw7vg"; type = "gem"; }; version = "0.4.1"; }; tpm-key_attestation = { - dependencies = ["bindata" "openssl" "openssl-signature_algorithm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bindata" + "openssl" + "openssl-signature_algorithm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "18xc7hyasg5ja2i2vb23d9c5pd6rf316kzwqxqx5d8vbs2z1a4rw"; type = "gem"; }; version = "0.12.1"; }; twilio-ruby = { - dependencies = ["faraday" "jwt" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "jwt" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kc065bbl85nz0ana0b9c92w88b3wch2kz81pn96sgrba2p442q2"; type = "gem"; }; version = "7.3.3"; }; twitter = { - dependencies = ["addressable" "buftok" "equalizer" "http" "http-form_data" "http_parser.rb" "memoizable" "multipart-post" "naught" "simple_oauth"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "buftok" + "equalizer" + "http" + "http-form_data" + "http_parser.rb" + "memoizable" + "multipart-post" + "naught" + "simple_oauth" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "13dmkjgsnym1avym9f7y2i2h3mlk8crqvc87drrzr4f0sf9l8g2y"; type = "gem"; }; version = "7.0.0"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "concurrent-ruby" ]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; tzinfo-data = { - dependencies = ["tzinfo"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tzinfo" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cw6xv9a525mcs7202bq9768aic1dwx353prm1bss4fp2nq24a3j"; type = "gem"; }; version = "1.2024.2"; }; unicode-display_width = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0nkz7fadlrdbkf37m0x7sw8bnz8r355q3vwcfb9f9md6pds9h9qj"; type = "gem"; }; version = "2.6.0"; }; uri = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07ndgxyhzd02cg94s6rnfhkb9rwx9z72lzk368sa9j78wc9qnbfz"; type = "gem"; }; version = "0.13.1"; }; vcr = { - dependencies = ["base64"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "base64" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1v83xjgj5y1fzp7nm4s5dixwpy5yr8crklyjyjilc13jgqanxd9p"; type = "gem"; }; version = "6.3.1"; }; version_gem = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08a6agx7xk1f6cr9a95dq42vl45si2ln21h33b96li59sv3555y6"; type = "gem"; }; version = "1.1.4"; }; viewpoint = { - dependencies = ["httpclient" "logging" "nokogiri" "rubyntlm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "httpclient" + "logging" + "nokogiri" + "rubyntlm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14bvihfs0gzmam680xqqs07isxjk677yi3ph2pdvyyhhkbfys0l0"; type = "gem"; }; version = "1.1.1"; }; vite_rails = { - dependencies = ["railties" "vite_ruby"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "railties" + "vite_ruby" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1k4bllg0zpmpkjfmk1gybc2ygca4v40l2fmlplf9h0jqwniqa3mr"; type = "gem"; }; version = "3.0.17"; }; vite_ruby = { - dependencies = ["dry-cli" "rack-proxy" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "dry-cli" + "rack-proxy" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1fcharh45xwi2cx96m695v9gccny3hgvdkkhcbkhplk1bc6ldwgk"; type = "gem"; }; version = "3.8.2"; }; webauthn = { - dependencies = ["android_key_attestation" "awrence" "bindata" "cbor" "cose" "openssl" "safety_net_attestation" "tpm-key_attestation"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "android_key_attestation" + "awrence" + "bindata" + "cbor" + "cose" + "openssl" + "safety_net_attestation" + "tpm-key_attestation" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1dwh2xrpwhbzyncb1wvgzz8fmln3r15iqz53c48q4swagpqzqig5"; type = "gem"; }; version = "3.1.0"; }; webmock = { - dependencies = ["addressable" "crack" "hashdiff"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "crack" + "hashdiff" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08kixkdp41dw39kqfxf2wp5m4z9b6fxg6yfa6xin0wy7dxzka0dy"; type = "gem"; }; version = "3.24.0"; }; webrick = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "089gy5494j560b242vi173wnbj2913hwlwnjkpzld58r96ilc5s3"; type = "gem"; }; version = "1.8.2"; }; websocket = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0dr78vh3ag0d1q5gfd8960g1ca9g6arjd2w54mffid8h4i7agrxp"; type = "gem"; }; version = "1.2.11"; }; websocket-driver = { - dependencies = ["websocket-extensions"]; - groups = ["default"]; - platforms = []; + dependencies = [ "websocket-extensions" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nyh873w4lvahcl8kzbjfca26656d5c6z3md4sbqg5y1gfz0157n"; type = "gem"; }; version = "0.7.6"; }; websocket-extensions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hc2g9qps8lmhibl5baa91b4qx8wqw872rgwagml78ydj8qacsqw"; type = "gem"; }; version = "0.1.5"; }; whatsapp_sdk = { - dependencies = ["faraday" "faraday-multipart" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "faraday-multipart" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0v5wgs11qqdhjpkmhchac35f3rfb3p44xqybxdgmsawc4mns8srl"; type = "gem"; }; version = "0.13.0"; }; write_xlsx = { - dependencies = ["nkf" "rubyzip"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "nkf" + "rubyzip" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1qln4i0yv2fg5mb0n8aam3kjn5lhrb0s80f6ahmdsldkj08jli7x"; type = "gem"; }; version = "1.12.1"; }; xpath = { - dependencies = ["nokogiri"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "nokogiri" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0bh8lk9hvlpn7vmi6h4hkcwjzvs2y0cmkk3yjjdr8fxvj6fsgzbd"; type = "gem"; }; version = "3.2.0"; }; yard = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14k9lb9a60r9z2zcqg08by9iljrrgjxdkbd91gw17rkqkqwi1sd6"; type = "gem"; }; version = "0.9.37"; }; zeitwerk = { - groups = ["assets" "default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "assets" + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "10cpfdswql21vildiin0q7drg5zfzf2sahnk9hv3nyzzjqwj2bdx"; type = "gem"; }; version = "2.6.18"; }; zendesk_api = { - dependencies = ["faraday" "faraday-multipart" "hashie" "inflection" "mini_mime" "multipart-post"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "faraday-multipart" + "hashie" + "inflection" + "mini_mime" + "multipart-post" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cjiqm50zc4gpsn456235k8x0prafbmz921yqjgava4rp706467d"; type = "gem"; }; diff --git a/pkgs/by-name/za/zapret/package.nix b/pkgs/by-name/za/zapret/package.nix index 63d4e4f47e7c63..f24357b98a04b5 100644 --- a/pkgs/by-name/za/zapret/package.nix +++ b/pkgs/by-name/za/zapret/package.nix @@ -11,7 +11,7 @@ iptables, nftables, - gawk + gawk, }: stdenv.mkDerivation (finalAttrs: { @@ -25,8 +25,17 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-3wFNXtx9Yt40ahlikHbQWh2fUtJZrCNkqgJF1C+fsDo="; }; - buildInputs = [ libcap zlib libnetfilter_queue libnfnetlink ]; - nativeBuildInputs = [ iptables nftables gawk ]; + buildInputs = [ + libcap + zlib + libnetfilter_queue + libnfnetlink + ]; + nativeBuildInputs = [ + iptables + nftables + gawk + ]; makeFlags = [ "TGT=${placeholder "out"}/bin" ]; diff --git a/pkgs/by-name/za/zapzap/package.nix b/pkgs/by-name/za/zapzap/package.nix index bce45dcd14860e..0bdc455493e537 100644 --- a/pkgs/by-name/za/zapzap/package.nix +++ b/pkgs/by-name/za/zapzap/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3Packages -, qt6 +{ + lib, + fetchFromGitHub, + python3Packages, + qt6, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/za/zarchive/package.nix b/pkgs/by-name/za/zarchive/package.nix index 3ef68ae8b71eb4..2efece44cadbf2 100644 --- a/pkgs/by-name/za/zarchive/package.nix +++ b/pkgs/by-name/za/zarchive/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, zstd }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zstd, +}: stdenv.mkDerivation rec { pname = "zarchive"; diff --git a/pkgs/by-name/za/zarf/package.nix b/pkgs/by-name/za/zarf/package.nix index c030a86e0a93ee..328b64a53e991a 100644 --- a/pkgs/by-name/za/zarf/package.nix +++ b/pkgs/by-name/za/zarf/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles -, stdenv +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + stdenv, }: buildGoModule rec { @@ -28,7 +29,18 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X" "github.com/defenseunicorns/zarf/src/config.CLIVersion=${src.rev}" "-X" "k8s.io/component-base/version.gitVersion=v0.0.0+zarf${src.rev}" "-X" "k8s.io/component-base/version.gitCommit=${src.rev}" "-X" "k8s.io/component-base/version.buildDate=1970-01-01T00:00:00Z" ]; + ldflags = [ + "-s" + "-w" + "-X" + "github.com/defenseunicorns/zarf/src/config.CLIVersion=${src.rev}" + "-X" + "k8s.io/component-base/version.gitVersion=v0.0.0+zarf${src.rev}" + "-X" + "k8s.io/component-base/version.gitCommit=${src.rev}" + "-X" + "k8s.io/component-base/version.buildDate=1970-01-01T00:00:00Z" + ]; postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' export K9S_LOGS_DIR=$(mktemp -d) diff --git a/pkgs/by-name/za/zasm/package.nix b/pkgs/by-name/za/zasm/package.nix index bd98622edf3fd2..0eaf0992e6f62d 100644 --- a/pkgs/by-name/za/zasm/package.nix +++ b/pkgs/by-name/za/zasm/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + zlib, +}: let libs-src = fetchFromGitHub { owner = "megatokio"; diff --git a/pkgs/by-name/za/zaz/package.nix b/pkgs/by-name/za/zaz/package.nix index dca1d74a43ff18..455b10a9974998 100644 --- a/pkgs/by-name/za/zaz/package.nix +++ b/pkgs/by-name/za/zaz/package.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, fetchurl -, pkg-config -, SDL -, SDL_image -, mesa -, libtheora -, libvorbis -, libogg -, ftgl -, freetype +{ + lib, + stdenv, + fetchurl, + pkg-config, + SDL, + SDL_image, + mesa, + libtheora, + libvorbis, + libogg, + ftgl, + freetype, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/zb/zbctl/package.nix b/pkgs/by-name/zb/zbctl/package.nix index 0ec6598a8b8e7e..f5c72fb60ffc31 100644 --- a/pkgs/by-name/zb/zbctl/package.nix +++ b/pkgs/by-name/zb/zbctl/package.nix @@ -1,19 +1,26 @@ -{ lib -, stdenvNoCC -, fetchurl +{ + lib, + stdenvNoCC, + fetchurl, }: stdenvNoCC.mkDerivation rec { pname = "zbctl"; version = "8.2.11"; - src = if stdenvNoCC.hostPlatform.system == "x86_64-darwin" then fetchurl { - url = "https://github.com/camunda/zeebe/releases/download/${version}/zbctl.darwin"; - sha256 = "0390n6wmlmfwqf6fvw6wqg6hbrs7bm9x2cdaajlw87377lklypkf"; - } else if stdenvNoCC.hostPlatform.system == "x86_64-linux" then fetchurl { - url = "https://github.com/camunda/zeebe/releases/download/${version}/zbctl"; - sha256 = "081hc0nynwg014lhsxxyin4rc2i9z6wh8q9i98cjjd8kgr41h096"; - } else throw "Unsupported platform ${stdenvNoCC.hostPlatform.system}"; + src = + if stdenvNoCC.hostPlatform.system == "x86_64-darwin" then + fetchurl { + url = "https://github.com/camunda/zeebe/releases/download/${version}/zbctl.darwin"; + sha256 = "0390n6wmlmfwqf6fvw6wqg6hbrs7bm9x2cdaajlw87377lklypkf"; + } + else if stdenvNoCC.hostPlatform.system == "x86_64-linux" then + fetchurl { + url = "https://github.com/camunda/zeebe/releases/download/${version}/zbctl"; + sha256 = "081hc0nynwg014lhsxxyin4rc2i9z6wh8q9i98cjjd8kgr41h096"; + } + else + throw "Unsupported platform ${stdenvNoCC.hostPlatform.system}"; dontUnpack = true; dontConfigure = true; @@ -34,7 +41,10 @@ stdenvNoCC.mkDerivation rec { changelog = "https://github.com/camunda/zeebe/releases/tag/${version}"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.asl20; - platforms = [ "x86_64-darwin" "x86_64-linux" ]; + platforms = [ + "x86_64-darwin" + "x86_64-linux" + ]; maintainers = with maintainers; [ thetallestjj ]; longDescription = '' A command line interface for Camunda Platform 8 designed to create and read resources inside a Zeebe broker. diff --git a/pkgs/by-name/zc/zcfan/package.nix b/pkgs/by-name/zc/zcfan/package.nix index 430026d16f12c9..b4dfef55272e9a 100644 --- a/pkgs/by-name/zc/zcfan/package.nix +++ b/pkgs/by-name/zc/zcfan/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: # Testing this requires a Thinkpad or the presence of /proc/acpi/ibm/fan diff --git a/pkgs/by-name/zc/zchaff/package.nix b/pkgs/by-name/zc/zchaff/package.nix index 5e22ff448ed376..4e486c5a951224 100644 --- a/pkgs/by-name/zc/zchaff/package.nix +++ b/pkgs/by-name/zc/zchaff/package.nix @@ -1,4 +1,8 @@ -{ lib, clangStdenv, fetchzip }: +{ + lib, + clangStdenv, + fetchzip, +}: clangStdenv.mkDerivation rec { pname = "zchaff"; @@ -15,7 +19,7 @@ clangStdenv.mkDerivation rec { ''; makeFlags = [ "CC=${clangStdenv.cc.targetPrefix}c++" ]; - installPhase= '' + installPhase = '' runHook preInstall install -Dm755 -t $out/bin zchaff runHook postInstall diff --git a/pkgs/by-name/zd/zd1211fw/package.nix b/pkgs/by-name/zd/zd1211fw/package.nix index ecf131effd40a6..632a5c60ff883a 100644 --- a/pkgs/by-name/zd/zd1211fw/package.nix +++ b/pkgs/by-name/zd/zd1211fw/package.nix @@ -1,6 +1,7 @@ -{ stdenvNoCC -, lib -, fetchurl +{ + stdenvNoCC, + lib, + fetchurl, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/by-name/zd/zdelta/package.nix b/pkgs/by-name/zd/zdelta/package.nix index b30a43f33c13ab..c84cd85f679c0d 100644 --- a/pkgs/by-name/zd/zdelta/package.nix +++ b/pkgs/by-name/zd/zdelta/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "zdelta"; diff --git a/pkgs/by-name/zd/zdns/package.nix b/pkgs/by-name/zd/zdns/package.nix index d67bb6d8e4c72e..dfa2fecc48fb51 100644 --- a/pkgs/by-name/zd/zdns/package.nix +++ b/pkgs/by-name/zd/zdns/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/ze/zecwallet-lite/package.nix b/pkgs/by-name/ze/zecwallet-lite/package.nix index 1659bae052b937..28b1b5085d2bc6 100644 --- a/pkgs/by-name/ze/zecwallet-lite/package.nix +++ b/pkgs/by-name/ze/zecwallet-lite/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, appimageTools }: +{ + lib, + fetchurl, + appimageTools, +}: appimageTools.wrapType2 rec { pname = "zecwallet-lite"; @@ -10,8 +14,10 @@ appimageTools.wrapType2 rec { }; extraInstallCommands = - let contents = appimageTools.extract { inherit pname version src; }; - in '' + let + contents = appimageTools.extract { inherit pname version src; }; + in + '' install -m 444 -D ${contents}/zecwallet-lite.desktop -t $out/share/applications substituteInPlace $out/share/applications/zecwallet-lite.desktop \ --replace 'Exec=AppRun' "Exec=$out/bin/zecwallet-lite" diff --git a/pkgs/by-name/ze/zed/package.nix b/pkgs/by-name/ze/zed/package.nix index a567ce7f474b29..3f49bdec0d5b60 100644 --- a/pkgs/by-name/ze/zed/package.nix +++ b/pkgs/by-name/ze/zed/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, zed +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + zed, }: buildGoModule rec { @@ -18,7 +19,10 @@ buildGoModule rec { vendorHash = "sha256-E9CXS3BQAglJV36BPgwhkb9SswxAj/yBcGqJ+XXwTmE="; - subPackages = [ "cmd/zed" "cmd/zq" ]; + subPackages = [ + "cmd/zed" + "cmd/zq" + ]; ldflags = [ "-s" @@ -41,6 +45,9 @@ buildGoModule rec { homepage = "https://zed.brimdata.io"; changelog = "https://github.com/brimdata/zed/blob/v${version}/CHANGELOG.md"; license = licenses.bsd3; - maintainers = with maintainers; [ dit7ya knl ]; + maintainers = with maintainers; [ + dit7ya + knl + ]; }; } diff --git a/pkgs/by-name/ze/zeekscript/package.nix b/pkgs/by-name/ze/zeekscript/package.nix index 9cca3fdaac51a8..476fc11018a776 100644 --- a/pkgs/by-name/ze/zeekscript/package.nix +++ b/pkgs/by-name/ze/zeekscript/package.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { @@ -35,7 +36,10 @@ python3.pkgs.buildPythonApplication rec { homepage = "https://github.com/zeek/zeekscript"; changelog = "https://github.com/zeek/zeekscript/blob/v${version}/CHANGES"; license = licenses.bsd3; - maintainers = with maintainers; [ fab tobim ]; + maintainers = with maintainers; [ + fab + tobim + ]; # Incompatible with tree-sitter > 0.21. broken = true; }; diff --git a/pkgs/by-name/ze/zeitgeist/package.nix b/pkgs/by-name/ze/zeitgeist/package.nix index a198b1b6046ec3..7c6db745fe11c0 100644 --- a/pkgs/by-name/ze/zeitgeist/package.nix +++ b/pkgs/by-name/ze/zeitgeist/package.nix @@ -1,28 +1,34 @@ -{ stdenv -, lib -, fetchFromGitLab -, pkg-config -, glib -, sqlite -, gobject-introspection -, vala -, autoconf -, automake -, libtool -, gettext -, dbus -, gtk3 -, json-glib -, librdf_raptor2 -, pythonSupport ? true -, python3 +{ + stdenv, + lib, + fetchFromGitLab, + pkg-config, + glib, + sqlite, + gobject-introspection, + vala, + autoconf, + automake, + libtool, + gettext, + dbus, + gtk3, + json-glib, + librdf_raptor2, + pythonSupport ? true, + python3, }: stdenv.mkDerivation rec { pname = "zeitgeist"; version = "1.0.4"; - outputs = [ "out" "lib" "dev" "man" ] ++ lib.optional pythonSupport "py"; + outputs = [ + "out" + "lib" + "dev" + "man" + ] ++ lib.optional pythonSupport "py"; src = fetchFromGitLab { domain = "gitlab.freedesktop.org"; diff --git a/pkgs/by-name/ze/zenity/package.nix b/pkgs/by-name/ze/zenity/package.nix index 2e907a48eb1ff4..b6f4efdd3c94d2 100644 --- a/pkgs/by-name/ze/zenity/package.nix +++ b/pkgs/by-name/ze/zenity/package.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchurl -, help2man -, meson -, ninja -, pkg-config -, libxml2 -, gnome -, gtk4 -, gettext -, libadwaita -, itstool -, wrapGAppsHook4 +{ + stdenv, + lib, + fetchurl, + help2man, + meson, + ninja, + pkg-config, + libxml2, + gnome, + gtk4, + gettext, + libadwaita, + itstool, + wrapGAppsHook4, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ze/zenmonitor/package.nix b/pkgs/by-name/ze/zenmonitor/package.nix index 837785c4d5a229..648e0e96d720fc 100644 --- a/pkgs/by-name/ze/zenmonitor/package.nix +++ b/pkgs/by-name/ze/zenmonitor/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitea, pkg-config, gtk3, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitea, + pkg-config, + gtk3, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "zenmonitor"; @@ -13,7 +20,10 @@ stdenv.mkDerivation rec { }; buildInputs = [ gtk3 ]; - nativeBuildInputs = [ pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + wrapGAppsHook3 + ]; makeFlags = [ "PREFIX=${placeholder "out"}" ]; @@ -22,7 +32,13 @@ stdenv.mkDerivation rec { description = "Monitoring software for AMD Zen-based CPUs"; mainProgram = "zenmonitor"; license = licenses.mit; - platforms = [ "i686-linux" "x86_64-linux" ]; - maintainers = with maintainers; [ alexbakker artturin ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; + maintainers = with maintainers; [ + alexbakker + artturin + ]; }; } diff --git a/pkgs/by-name/ze/zenstates/package.nix b/pkgs/by-name/ze/zenstates/package.nix index a320e959f02108..b824fbc74ceac7 100644 --- a/pkgs/by-name/ze/zenstates/package.nix +++ b/pkgs/by-name/ze/zenstates/package.nix @@ -21,7 +21,12 @@ # before = [ "sleep.target" ]; # }; -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation rec { pname = "zenstates"; version = "0.0.1"; @@ -40,7 +45,7 @@ stdenv.mkDerivation rec { cp $src/zenstates.py $out/bin/zenstates chmod +x $out/bin/zenstates patchShebangs --build $out/bin/zenstates - ''; + ''; meta = with lib; { description = "Linux utility for Ryzen processors and motherboards"; diff --git a/pkgs/by-name/ze/zerobin/package.nix b/pkgs/by-name/ze/zerobin/package.nix index 62201ba6ca0890..5a826ccec891bf 100644 --- a/pkgs/by-name/ze/zerobin/package.nix +++ b/pkgs/by-name/ze/zerobin/package.nix @@ -1,7 +1,8 @@ -{ lib -, python3Packages -, fetchFromGitHub -, uglify-js +{ + lib, + python3Packages, + fetchFromGitHub, + uglify-js, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/ze/zeroc-ice/package.nix b/pkgs/by-name/ze/zeroc-ice/package.nix index 5c6a0ba9bbe12d..2bcd6e85f3995e 100644 --- a/pkgs/by-name/ze/zeroc-ice/package.nix +++ b/pkgs/by-name/ze/zeroc-ice/package.nix @@ -1,7 +1,15 @@ -{ stdenv, lib, fetchFromGitHub -, bzip2, expat, libedit, lmdb, openssl, libxcrypt -, python3 # for tests only -, cpp11 ? false +{ + stdenv, + lib, + fetchFromGitHub, + bzip2, + expat, + libedit, + lmdb, + openssl, + libxcrypt, + python3, # for tests only + cpp11 ? false, }: let @@ -20,7 +28,8 @@ let installFlags = [ "PREFIX=$(out)" ]; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "zeroc-ice"; version = "3.7.10"; @@ -31,7 +40,15 @@ in stdenv.mkDerivation rec { hash = "sha256-l3cKsR8HSdtFGw1S12xueQOu/U9ABlOxQQtbHBj2izs="; }; - buildInputs = [ zeroc_mcpp bzip2 expat libedit lmdb openssl libxcrypt ]; + buildInputs = [ + zeroc_mcpp + bzip2 + expat + libedit + lmdb + openssl + libxcrypt + ]; preBuild = '' makeFlagsArray+=( @@ -46,25 +63,35 @@ in stdenv.mkDerivation rec { enableParallelBuilding = true; - outputs = [ "out" "bin" "dev" ]; + outputs = [ + "out" + "bin" + "dev" + ]; doCheck = true; nativeCheckInputs = with python3.pkgs; [ passlib ]; - checkPhase = let - # these tests require network access so we need to skip them. - brokenTests = map lib.escapeRegex [ - "Ice/udp" "Glacier2" "IceGrid/simple" "IceStorm" "IceDiscovery/simple" + checkPhase = + let + # these tests require network access so we need to skip them. + brokenTests = map lib.escapeRegex [ + "Ice/udp" + "Glacier2" + "IceGrid/simple" + "IceStorm" + "IceDiscovery/simple" - # FIXME: certificate expired, remove for next release? - "IceSSL/configuration" - ]; - # matches CONFIGS flag in makeFlagsArray - configFlag = lib.optionalString cpp11 "--config=cpp11-shared"; - in '' - runHook preCheck - ${python3.interpreter} ./cpp/allTests.py ${configFlag} --rfilter='${lib.concatStringsSep "|" brokenTests}' - runHook postCheck - ''; + # FIXME: certificate expired, remove for next release? + "IceSSL/configuration" + ]; + # matches CONFIGS flag in makeFlagsArray + configFlag = lib.optionalString cpp11 "--config=cpp11-shared"; + in + '' + runHook preCheck + ${python3.interpreter} ./cpp/allTests.py ${configFlag} --rfilter='${lib.concatStringsSep "|" brokenTests}' + runHook postCheck + ''; postInstall = '' mkdir -p $bin $dev/share diff --git a/pkgs/by-name/ze/zerofree/package.nix b/pkgs/by-name/ze/zerofree/package.nix index 77099a01e44f66..e85c947b4618f6 100644 --- a/pkgs/by-name/ze/zerofree/package.nix +++ b/pkgs/by-name/ze/zerofree/package.nix @@ -1,11 +1,18 @@ -{ lib, stdenv, fetchurl, installShellFiles, e2fsprogs }: +{ + lib, + stdenv, + fetchurl, + installShellFiles, + e2fsprogs, +}: let manpage = fetchurl { url = "https://manpages.ubuntu.com/manpages.gz/xenial/man8/zerofree.8.gz"; sha256 = "0y132xmjl02vw41k794psa4nmjpdyky9f6sf0h4f7rvf83z3zy4k"; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "zerofree"; version = "1.1.1"; @@ -14,7 +21,10 @@ in stdenv.mkDerivation rec { sha256 = "0rrqfa5z103ws89vi8kfvbks1cfs74ix6n1wb6vs582vnmhwhswm"; }; - buildInputs = [ e2fsprogs installShellFiles ]; + buildInputs = [ + e2fsprogs + installShellFiles + ]; installPhase = '' mkdir -p $out/bin $out/share/zerofree diff --git a/pkgs/by-name/ze/zeronet-conservancy/package.nix b/pkgs/by-name/ze/zeronet-conservancy/package.nix index 0477684142c145..8f62e053f78fc3 100644 --- a/pkgs/by-name/ze/zeronet-conservancy/package.nix +++ b/pkgs/by-name/ze/zeronet-conservancy/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3Packages -, nixosTests +{ + lib, + fetchFromGitHub, + python3Packages, + nixosTests, }: python3Packages.buildPythonApplication rec { @@ -17,9 +18,23 @@ python3Packages.buildPythonApplication rec { }; propagatedBuildInputs = with python3Packages; [ - gevent msgpack base58 merkletools rsa pysocks pyasn1 websocket-client - gevent-websocket rencode python-bitcoinlib maxminddb pyopenssl rich defusedxml - pyaes coincurve + gevent + msgpack + base58 + merkletools + rsa + pysocks + pyasn1 + websocket-client + gevent-websocket + rencode + python-bitcoinlib + maxminddb + pyopenssl + rich + defusedxml + pyaes + coincurve ]; buildPhase = '' diff --git a/pkgs/by-name/ze/zeronet/package.nix b/pkgs/by-name/ze/zeronet/package.nix index d3ffcf81a889a3..e74133b7635808 100644 --- a/pkgs/by-name/ze/zeronet/package.nix +++ b/pkgs/by-name/ze/zeronet/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "zeronet"; @@ -13,8 +17,19 @@ python3Packages.buildPythonApplication rec { }; propagatedBuildInputs = with python3Packages; [ - gevent msgpack base58 merkletools rsa pysocks pyasn1 websocket-client - gevent-websocket rencode python-bitcoinlib maxminddb pyopenssl + gevent + msgpack + base58 + merkletools + rsa + pysocks + pyasn1 + websocket-client + gevent-websocket + rencode + python-bitcoinlib + maxminddb + pyopenssl ]; buildPhase = '' @@ -37,9 +52,11 @@ python3Packages.buildPythonApplication rec { homepage = "https://zeronet.io/"; license = licenses.gpl2; maintainers = with maintainers; [ fgaz ]; - knownVulnerabilities = [ '' - Unmaintained. Probable XSS/code injection vulnerability. - Switching to the maintained zeronet-conservancy package is recommended - '' ]; + knownVulnerabilities = [ + '' + Unmaintained. Probable XSS/code injection vulnerability. + Switching to the maintained zeronet-conservancy package is recommended + '' + ]; }; } diff --git a/pkgs/by-name/ze/zerotierone/package.nix b/pkgs/by-name/ze/zerotierone/package.nix index 3252cce49d6060..8f5f2dcb1422a8 100644 --- a/pkgs/by-name/ze/zerotierone/package.nix +++ b/pkgs/by-name/ze/zerotierone/package.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, buildPackages -, cargo -, lzo -, openssl -, pkg-config -, ronn -, rustc -, zlib -, libiconv -, darwin -, fetchpatch +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + buildPackages, + cargo, + lzo, + openssl, + pkg-config, + ronn, + rustc, + zlib, + libiconv, + darwin, + fetchpatch, }: let @@ -26,7 +27,8 @@ let hash = "sha256-YWcqALUB3ZEukL4er2FKcyNdEbuaf//QU5hRbKAfxDA="; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname version src; cargoDeps = rustPlatform.importCargoLock { @@ -49,7 +51,6 @@ in stdenv.mkDerivation { cp ${./Cargo.lock} rustybits/Cargo.lock ''; - preConfigure = '' cmp ./Cargo.lock ./rustybits/Cargo.lock || { echo 1>&2 "Please make sure that the derivation's Cargo.lock is identical to ./rustybits/Cargo.lock!" @@ -73,47 +74,56 @@ in stdenv.mkDerivation { rustc ]; - buildInputs = [ - lzo - openssl - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - darwin.apple_sdk.frameworks.SystemConfiguration - darwin.apple_sdk.frameworks.CoreServices - ]; + buildInputs = + [ + lzo + openssl + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + darwin.apple_sdk.frameworks.SystemConfiguration + darwin.apple_sdk.frameworks.CoreServices + ]; enableParallelBuilding = true; # Ensure Rust compiles for the right target env.CARGO_BUILD_TARGET = stdenv.hostPlatform.rust.rustcTarget; - preBuild = if stdenv.hostPlatform.isDarwin then '' - makeFlagsArray+=("ARCH_FLAGS=") # disable multi-arch build - if ! grep -q MACOS_VERSION_MIN=10.13 make-mac.mk; then - echo "You may need to update MACOSX_DEPLOYMENT_TARGET to match the value in make-mac.mk" - exit 1 - fi - (cd rustybits && MACOSX_DEPLOYMENT_TARGET=10.13 cargo build -p zeroidc --release) - - cp \ - ./rustybits/target/${stdenv.hostPlatform.rust.rustcTarget}/release/libzeroidc.a \ - ./rustybits/target - - # zerotier uses the "FORCE" target as a phony target to force rebuilds. - # We don't want to rebuild libzeroidc.a as we build want to build this library ourself for a single architecture - touch FORCE - '' else '' - # Cargo won't compile to target/release but to target//release when a target is - # explicitly defined. The build-system however expects target/release. Hence we just symlink from - # the latter to the former. - mkdir -p rustybits/target/release - ln -rs \ - ./rustybits/target/${stdenv.hostPlatform.rust.rustcTarget}/release/libzeroidc.a \ - ./rustybits/target/release/ - ''; - - buildFlags = [ "all" "selftest" ]; + preBuild = + if stdenv.hostPlatform.isDarwin then + '' + makeFlagsArray+=("ARCH_FLAGS=") # disable multi-arch build + if ! grep -q MACOS_VERSION_MIN=10.13 make-mac.mk; then + echo "You may need to update MACOSX_DEPLOYMENT_TARGET to match the value in make-mac.mk" + exit 1 + fi + (cd rustybits && MACOSX_DEPLOYMENT_TARGET=10.13 cargo build -p zeroidc --release) + + cp \ + ./rustybits/target/${stdenv.hostPlatform.rust.rustcTarget}/release/libzeroidc.a \ + ./rustybits/target + + # zerotier uses the "FORCE" target as a phony target to force rebuilds. + # We don't want to rebuild libzeroidc.a as we build want to build this library ourself for a single architecture + touch FORCE + '' + else + '' + # Cargo won't compile to target/release but to target//release when a target is + # explicitly defined. The build-system however expects target/release. Hence we just symlink from + # the latter to the former. + mkdir -p rustybits/target/release + ln -rs \ + ./rustybits/target/${stdenv.hostPlatform.rust.rustcTarget}/release/libzeroidc.a \ + ./rustybits/target/release/ + ''; + + buildFlags = [ + "all" + "selftest" + ]; doCheck = stdenv.buildPlatform.canExecute stdenv.hostPlatform; checkPhase = '' @@ -124,7 +134,8 @@ in stdenv.mkDerivation { installFlags = [ # only linux has an install target, we borrow this for macOS as well - "-f" "make-linux.mk" + "-f" + "make-linux.mk" "DESTDIR=$$out/upstream" ]; @@ -137,7 +148,10 @@ in stdenv.mkDerivation { rm -rf $out/upstream ''; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; passthru.updateScript = ./update.sh; @@ -146,7 +160,11 @@ in stdenv.mkDerivation { homepage = "https://www.zerotier.com"; license = licenses.bsl11; maintainers = with maintainers; [ - sjmackenzie zimbatm ehmry obadz danielfullmer + sjmackenzie + zimbatm + ehmry + obadz + danielfullmer mic92 # also can test darwin ]; platforms = platforms.unix; diff --git a/pkgs/by-name/ze/zesarux/package.nix b/pkgs/by-name/ze/zesarux/package.nix index b75e4ade88ebf3..a06d19251b4012 100644 --- a/pkgs/by-name/ze/zesarux/package.nix +++ b/pkgs/by-name/ze/zesarux/package.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL2 -, aalib -, alsa-lib -, libXext -, libXxf86vm -, libcaca -, libpulseaudio -, libsndfile -, ncurses -, openssl -, which +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + aalib, + alsa-lib, + libXext, + libXxf86vm, + libcaca, + libpulseaudio, + libsndfile, + ncurses, + openssl, + which, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/ze/zet/package.nix b/pkgs/by-name/ze/zet/package.nix index c94380047d1acf..e1fa08c94162f8 100644 --- a/pkgs/by-name/ze/zet/package.nix +++ b/pkgs/by-name/ze/zet/package.nix @@ -1,7 +1,8 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, fetchpatch2 +{ + lib, + rustPlatform, + fetchFromGitHub, + fetchpatch2, }: rustPlatform.buildRustPackage rec { @@ -35,7 +36,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "zet"; homepage = "https://github.com/yarrow/zet"; changelog = "https://github.com/yarrow/zet/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with maintainers; [ figsoda ]; }; } diff --git a/pkgs/by-name/ze/zeyple/package.nix b/pkgs/by-name/ze/zeyple/package.nix index fd5f628676aebc..48f3109b278db1 100644 --- a/pkgs/by-name/ze/zeyple/package.nix +++ b/pkgs/by-name/ze/zeyple/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "zeyple"; diff --git a/pkgs/by-name/zf/zfs-autobackup/package.nix b/pkgs/by-name/zf/zfs-autobackup/package.nix index fcb3bf7dce964c..4ff4839a7aaae0 100644 --- a/pkgs/by-name/zf/zfs-autobackup/package.nix +++ b/pkgs/by-name/zf/zfs-autobackup/package.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchPypi }: +{ + lib, + python3Packages, + fetchPypi, +}: python3Packages.buildPythonApplication rec { pname = "zfs-autobackup"; @@ -10,7 +14,6 @@ python3Packages.buildPythonApplication rec { hash = "sha256-rvtY7fsn2K2hueAsQkaPXcwxUAgE8j+GsQFF3eJKG2o="; }; - propagatedBuildInputs = with python3Packages; [ colorama ]; pythonRemoveDeps = [ "argparse" ]; diff --git a/pkgs/by-name/zf/zfs-prune-snapshots/package.nix b/pkgs/by-name/zf/zfs-prune-snapshots/package.nix index 18ddacd4d55fda..a272cb93cdb8ce 100644 --- a/pkgs/by-name/zf/zfs-prune-snapshots/package.nix +++ b/pkgs/by-name/zf/zfs-prune-snapshots/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, go-md2man }: +{ + lib, + stdenv, + fetchFromGitHub, + go-md2man, +}: stdenv.mkDerivation rec { version = "1.5.0"; diff --git a/pkgs/by-name/zf/zfsbackup/package.nix b/pkgs/by-name/zf/zfsbackup/package.nix index 6be570fadd22d8..00262004855a60 100644 --- a/pkgs/by-name/zf/zfsbackup/package.nix +++ b/pkgs/by-name/zf/zfsbackup/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -17,7 +18,10 @@ buildGoModule rec { vendorHash = "sha256-aYAficUFYYhZygfQZyczP49CeouAKKZJW8IFlkFh9lI="; - ldflags = [ "-w" "-s" ]; + ldflags = [ + "-w" + "-s" + ]; # Tests require loading the zfs kernel module. doCheck = false; diff --git a/pkgs/by-name/zf/zfsnap/package.nix b/pkgs/by-name/zf/zfsnap/package.nix index 7c78fc8f17208b..0b7fd9b2048bed 100644 --- a/pkgs/by-name/zf/zfsnap/package.nix +++ b/pkgs/by-name/zf/zfsnap/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, coreutils, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + coreutils, + installShellFiles, +}: stdenv.mkDerivation rec { version = "2.0.0-beta3"; diff --git a/pkgs/by-name/zf/zfstools/package.nix b/pkgs/by-name/zf/zfstools/package.nix index 0a4447bacc4f3e..49b34961841c9a 100644 --- a/pkgs/by-name/zf/zfstools/package.nix +++ b/pkgs/by-name/zf/zfstools/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, ruby, zfs, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + ruby, + zfs, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "zfstools"; diff --git a/pkgs/by-name/zf/zfxtop/package.nix b/pkgs/by-name/zf/zfxtop/package.nix index 5c216c7ca0cbe2..71ac3b1e773fc7 100644 --- a/pkgs/by-name/zf/zfxtop/package.nix +++ b/pkgs/by-name/zf/zfxtop/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/by-name/zg/zgrab2/package.nix b/pkgs/by-name/zg/zgrab2/package.nix index 155a6a28e721e3..9651c9ee54faf7 100644 --- a/pkgs/by-name/zg/zgrab2/package.nix +++ b/pkgs/by-name/zg/zgrab2/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -31,7 +32,13 @@ buildGoModule rec { description = "Web application scanner"; mainProgram = "zgrab2"; homepage = "https://github.com/zmap/zgrab2"; - license = with licenses; [ asl20 isc ]; - maintainers = with maintainers; [ fab juliusrickert ]; + license = with licenses; [ + asl20 + isc + ]; + maintainers = with maintainers; [ + fab + juliusrickert + ]; }; } diff --git a/pkgs/by-name/zg/zgrviewer/package.nix b/pkgs/by-name/zg/zgrviewer/package.nix index 980e631ad41f58..2acac587ebc569 100644 --- a/pkgs/by-name/zg/zgrviewer/package.nix +++ b/pkgs/by-name/zg/zgrviewer/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, jre, unzip, runtimeShell }: +{ + lib, + stdenv, + fetchurl, + jre, + unzip, + runtimeShell, +}: stdenv.mkDerivation rec { version = "0.9.0"; pname = "zgrviewer"; @@ -7,7 +14,7 @@ stdenv.mkDerivation rec { sha256 = "1yg2rck81sqqrgfi5kn6c1bz42dr7d0zqpcsdjhicssi1y159f23"; }; nativeBuildInputs = [ unzip ]; - buildInputs = [jre]; + buildInputs = [ jre ]; buildPhase = ""; installPhase = '' mkdir -p "$out"/{bin,share/java/zvtm/plugins,share/doc/zvtm} @@ -22,8 +29,8 @@ stdenv.mkDerivation rec { ''; meta = { # Quicker to unpack locally than load Hydra - hydraPlatforms = []; - maintainers = with lib.maintainers; [raskin]; + hydraPlatforms = [ ]; + maintainers = with lib.maintainers; [ raskin ]; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; license = lib.licenses.lgpl21Plus; description = "GraphViz graph viewer/navigator"; diff --git a/pkgs/by-name/zi/zi/package.nix b/pkgs/by-name/zi/zi/package.nix index 1649a6a7fe88f2..9458af8f90e8cf 100644 --- a/pkgs/by-name/zi/zi/package.nix +++ b/pkgs/by-name/zi/zi/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, installShellFiles, stdenvNoCC }: +{ + lib, + fetchFromGitHub, + installShellFiles, + stdenvNoCC, +}: stdenvNoCC.mkDerivation rec { pname = "zi"; diff --git a/pkgs/by-name/zi/zigbee2mqtt/package.nix b/pkgs/by-name/zi/zigbee2mqtt/package.nix index 80073eede9aa6e..71d7e9501db895 100644 --- a/pkgs/by-name/zi/zigbee2mqtt/package.nix +++ b/pkgs/by-name/zi/zigbee2mqtt/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, buildNpmPackage -, fetchFromGitHub -, systemdMinimal -, nixosTests -, nix-update-script -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemdMinimal +{ + lib, + stdenv, + buildNpmPackage, + fetchFromGitHub, + systemdMinimal, + nixosTests, + nix-update-script, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemdMinimal, }: buildNpmPackage rec { @@ -41,7 +42,10 @@ buildNpmPackage rec { It bridges events and allows you to control your Zigbee devices via MQTT. In this way you can integrate your Zigbee devices with whatever smart home infrastructure you are using. ''; - maintainers = with maintainers; [ sweber hexa ]; + maintainers = with maintainers; [ + sweber + hexa + ]; mainProgram = "zigbee2mqtt"; }; } diff --git a/pkgs/by-name/zi/zigpy-cli/package.nix b/pkgs/by-name/zi/zigpy-cli/package.nix index 69b4eaed661a48..dcca95a3df595f 100644 --- a/pkgs/by-name/zi/zigpy-cli/package.nix +++ b/pkgs/by-name/zi/zigpy-cli/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/zi/zile/package.nix b/pkgs/by-name/zi/zile/package.nix index 26f0f3484d4443..8cfc73832c6cda 100644 --- a/pkgs/by-name/zi/zile/package.nix +++ b/pkgs/by-name/zi/zile/package.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, boehmgc -, glib -, help2man -, libgee -, ncurses -, perl -, pkg-config -, vala +{ + lib, + stdenv, + fetchurl, + boehmgc, + glib, + help2man, + libgee, + ncurses, + perl, + pkg-config, + vala, }: stdenv.mkDerivation rec { @@ -26,14 +27,15 @@ stdenv.mkDerivation rec { libgee ncurses ]; - nativeBuildInputs = [ - perl - pkg-config - vala - ] - # `help2man' wants to run Zile, which won't work when the - # newly-produced binary can't be run at build-time. - ++ lib.optional (stdenv.hostPlatform == stdenv.buildPlatform) help2man; + nativeBuildInputs = + [ + perl + pkg-config + vala + ] + # `help2man' wants to run Zile, which won't work when the + # newly-produced binary can't be run at build-time. + ++ lib.optional (stdenv.hostPlatform == stdenv.buildPlatform) help2man; # Tests can't be run because most of them rely on the ability to # fiddle with the terminal. @@ -42,7 +44,7 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-error=incompatible-function-pointer-types"; # XXX: Work around cross-compilation-unfriendly `gl_FUNC_FSTATAT' macro. - gl_cv_func_fstatat_zero_flag="yes"; + gl_cv_func_fstatat_zero_flag = "yes"; meta = with lib; { homepage = "https://www.gnu.org/software/zile/"; diff --git a/pkgs/by-name/zi/zilla-slab/package.nix b/pkgs/by-name/zi/zilla-slab/package.nix index 886362d78e9909..333db7d2248ef2 100644 --- a/pkgs/by-name/zi/zilla-slab/package.nix +++ b/pkgs/by-name/zi/zilla-slab/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "zilla-slab"; diff --git a/pkgs/by-name/zi/zim-tools/package.nix b/pkgs/by-name/zi/zim-tools/package.nix index 100c9e706ff780..b4eef262ce543b 100644 --- a/pkgs/by-name/zi/zim-tools/package.nix +++ b/pkgs/by-name/zi/zim-tools/package.nix @@ -1,7 +1,17 @@ -{ lib, stdenv, fetchFromGitHub -, meson, ninja, pkg-config -, docopt_cpp, file, gumbo, mustache-hpp, zimlib, zlib -, gtest +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + docopt_cpp, + file, + gumbo, + mustache-hpp, + zimlib, + zlib, + gtest, }: stdenv.mkDerivation rec { @@ -15,8 +25,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-A1A0Ri2OwPyqpx0f5CPJL3zAwo2I/AiRKpmk3r4DeTc="; }; - nativeBuildInputs = [ meson ninja pkg-config ]; - buildInputs = [ docopt_cpp file gumbo mustache-hpp zimlib zlib ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; + buildInputs = [ + docopt_cpp + file + gumbo + mustache-hpp + zimlib + zlib + ]; nativeCheckInputs = [ gtest ]; doCheck = true; diff --git a/pkgs/by-name/zi/zim/package.nix b/pkgs/by-name/zi/zim/package.nix index 77eaaa16b9929b..066afeffae8b15 100644 --- a/pkgs/by-name/zi/zim/package.nix +++ b/pkgs/by-name/zi/zim/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, python3Packages, gtk3, gobject-introspection, wrapGAppsHook3, adwaita-icon-theme }: +{ + lib, + stdenv, + fetchurl, + python3Packages, + gtk3, + gobject-introspection, + wrapGAppsHook3, + adwaita-icon-theme, +}: # TODO: Declare configuration options for the following optional dependencies: # - File stores: hg, git, bzr @@ -14,9 +23,18 @@ python3Packages.buildPythonApplication rec { hash = "sha256-QIkNsFsWeNHEcXhGHHZyJDMMW2lNvdwMJLGxeCZaLdI="; }; - buildInputs = [ gtk3 adwaita-icon-theme ]; - propagatedBuildInputs = with python3Packages; [ pyxdg pygobject3 ]; - nativeBuildInputs = [ gobject-introspection wrapGAppsHook3 ]; + buildInputs = [ + gtk3 + adwaita-icon-theme + ]; + propagatedBuildInputs = with python3Packages; [ + pyxdg + pygobject3 + ]; + nativeBuildInputs = [ + gobject-introspection + wrapGAppsHook3 + ]; dontWrapGApps = true; diff --git a/pkgs/by-name/zi/zimfw/package.nix b/pkgs/by-name/zi/zimfw/package.nix index 85a176ea332d98..7ceafd8d3374fe 100644 --- a/pkgs/by-name/zi/zimfw/package.nix +++ b/pkgs/by-name/zi/zimfw/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zimfw"; @@ -25,8 +29,7 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = - "The Zsh configuration framework with blazing speed and modular extensions"; + description = "The Zsh configuration framework with blazing speed and modular extensions"; homepage = "https://zimfw.sh"; license = licenses.mit; maintainers = [ maintainers.joedevivo ]; diff --git a/pkgs/by-name/zi/zimg/package.nix b/pkgs/by-name/zi/zimg/package.nix index dbd6c9582dd71d..cc49026b01d252 100644 --- a/pkgs/by-name/zi/zimg/package.nix +++ b/pkgs/by-name/zi/zimg/package.nix @@ -1,17 +1,26 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "zimg"; version = "3.0.5"; src = fetchFromGitHub { - owner = "sekrit-twc"; - repo = "zimg"; - rev = "release-${version}"; + owner = "sekrit-twc"; + repo = "zimg"; + rev = "release-${version}"; sha256 = "sha256-DCSqHCnOyIvKtIAfprb8tgtzLn67Ix6BWyeIliu0HO4="; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; nativeBuildInputs = [ autoreconfHook ]; @@ -19,9 +28,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Scaling, colorspace conversion and dithering library"; - homepage = "https://github.com/sekrit-twc/zimg"; - license = licenses.wtfpl; - platforms = with platforms; unix ++ windows; + homepage = "https://github.com/sekrit-twc/zimg"; + license = licenses.wtfpl; + platforms = with platforms; unix ++ windows; maintainers = with maintainers; [ rnhmjoj ]; }; } diff --git a/pkgs/by-name/zi/zimlib/package.nix b/pkgs/by-name/zi/zimlib/package.nix index a118c51ff136fc..f1ab313018ddf5 100644 --- a/pkgs/by-name/zi/zimlib/package.nix +++ b/pkgs/by-name/zi/zimlib/package.nix @@ -1,12 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, fetchzip -, meson, ninja, pkg-config -, python3 -, icu -, libuuid -, xapian -, xz -, zstd -, gtest +{ + lib, + stdenv, + fetchFromGitHub, + fetchzip, + meson, + ninja, + pkg-config, + python3, + icu, + libuuid, + xapian, + xz, + zstd, + gtest, }: stdenv.mkDerivation rec { @@ -45,7 +51,7 @@ stdenv.mkDerivation rec { patchShebangs scripts ''; - mesonFlags = [ "-Dtest_data_dir=${testData}" ]; + mesonFlags = [ "-Dtest_data_dir=${testData}" ]; env.NIX_CFLAGS_COMPILE = toString ( lib.optionals (stdenv.cc.isGNU) [ @@ -61,7 +67,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Library for reading and writing ZIM files"; - homepage = "https://www.openzim.org/wiki/Zimlib"; + homepage = "https://www.openzim.org/wiki/Zimlib"; license = licenses.gpl2; maintainers = with maintainers; [ greg ]; platforms = platforms.unix; diff --git a/pkgs/by-name/zi/zine/package.nix b/pkgs/by-name/zi/zine/package.nix index 95d4b1963ebd03..fab0f769d6ce7f 100644 --- a/pkgs/by-name/zi/zine/package.nix +++ b/pkgs/by-name/zi/zine/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, openssl -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + openssl, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -27,18 +28,23 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.CoreServices - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.CoreServices + ]; meta = with lib; { description = "Simple and opinionated tool to build your own magazine"; homepage = "https://github.com/zineland/zine"; changelog = "https://github.com/zineland/zine/releases/tag/v${version}"; license = licenses.asl20; - maintainers = with maintainers; [ dit7ya figsoda ]; + maintainers = with maintainers; [ + dit7ya + figsoda + ]; mainProgram = "zine"; }; } diff --git a/pkgs/by-name/zi/zinnia/package.nix b/pkgs/by-name/zi/zinnia/package.nix index 8070dbc66ba897..1b15281e52a80f 100644 --- a/pkgs/by-name/zi/zinnia/package.nix +++ b/pkgs/by-name/zi/zinnia/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "zinnia"; diff --git a/pkgs/by-name/zi/zip/package.nix b/pkgs/by-name/zi/zip/package.nix index 2c225489a34628..003f8dfb4df5d2 100644 --- a/pkgs/by-name/zi/zip/package.nix +++ b/pkgs/by-name/zi/zip/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, enableNLS ? false, libnatspec ? null, libiconv }: +{ + lib, + stdenv, + fetchurl, + enableNLS ? false, + libnatspec ? null, + libiconv, +}: assert enableNLS -> libnatspec != null; @@ -8,7 +15,7 @@ stdenv.mkDerivation rec { src = fetchurl { urls = [ - "ftp://ftp.info-zip.org/pub/infozip/src/zip${lib.replaceStrings ["."] [""] version}.tgz" + "ftp://ftp.info-zip.org/pub/infozip/src/zip${lib.replaceStrings [ "." ] [ "" ] version}.tgz" "https://src.fedoraproject.org/repo/pkgs/zip/zip30.tar.gz/7b74551e63f8ee6aab6fbc86676c0d37/zip30.tar.gz" ]; sha256 = "0sb3h3067pzf3a7mlxn1hikpcjrsvycjcnj9hl9b1c3ykcgvps7h"; @@ -40,7 +47,8 @@ stdenv.mkDerivation rec { ./fix-time.h-not-included.patch ] ++ lib.optionals (enableNLS && !stdenv.hostPlatform.isCygwin) [ ./natspec-gentoo.patch.bz2 ]; - buildInputs = lib.optional enableNLS libnatspec + buildInputs = + lib.optional enableNLS libnatspec ++ lib.optional stdenv.hostPlatform.isCygwin libiconv; meta = with lib; { diff --git a/pkgs/by-name/zi/zipkin/package.nix b/pkgs/by-name/zi/zipkin/package.nix index 97ccf1a18e2b8d..3549578deb393c 100644 --- a/pkgs/by-name/zi/zipkin/package.nix +++ b/pkgs/by-name/zi/zipkin/package.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, makeWrapper, jre}: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jre, +}: stdenv.mkDerivation rec { version = "1.28.1"; pname = "zipkin-server"; @@ -8,8 +14,7 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildCommand = - '' + buildCommand = '' mkdir -p $out/share/java cp ${src} $out/share/java/zipkin-server-${version}-exec.jar mkdir -p $out/bin diff --git a/pkgs/by-name/zi/zircolite/package.nix b/pkgs/by-name/zi/zircolite/package.nix index 9032e37e8a5dc5..d70c664061c520 100644 --- a/pkgs/by-name/zi/zircolite/package.nix +++ b/pkgs/by-name/zi/zircolite/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, makeWrapper -, python3 +{ + lib, + fetchFromGitHub, + makeWrapper, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -22,20 +23,23 @@ python3.pkgs.buildPythonApplication rec { makeWrapper ]; - dependencies = with python3.pkgs; [ - aiohttp - colorama - elastic-transport - elasticsearch - evtx - jinja2 - lxml - orjson - requests - tqdm - urllib3 - xxhash - ] ++ elasticsearch.optional-dependencies.async; + dependencies = + with python3.pkgs; + [ + aiohttp + colorama + elastic-transport + elasticsearch + evtx + jinja2 + lxml + orjson + requests + tqdm + urllib3 + xxhash + ] + ++ elasticsearch.optional-dependencies.async; installPhase = '' runHook preInstall diff --git a/pkgs/by-name/zi/zita-ajbridge/package.nix b/pkgs/by-name/zi/zita-ajbridge/package.nix index 873a294540ddcb..f3b78a8204fdaa 100644 --- a/pkgs/by-name/zi/zita-ajbridge/package.nix +++ b/pkgs/by-name/zi/zita-ajbridge/package.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, alsa-lib, libjack2, zita-alsa-pcmi, zita-resampler }: +{ + lib, + stdenv, + fetchurl, + alsa-lib, + libjack2, + zita-alsa-pcmi, + zita-resampler, +}: stdenv.mkDerivation rec { pname = "zita-ajbridge"; @@ -9,7 +17,12 @@ stdenv.mkDerivation rec { sha256 = "0g5v0l0zmqh049mhv62n8s5bpm0yrlby7mkxxhs5qwadp8v4w9mw"; }; - buildInputs = [ alsa-lib libjack2 zita-alsa-pcmi zita-resampler ]; + buildInputs = [ + alsa-lib + libjack2 + zita-alsa-pcmi + zita-resampler + ]; preConfigure = '' cd ./source/ diff --git a/pkgs/by-name/zi/zita-alsa-pcmi/package.nix b/pkgs/by-name/zi/zita-alsa-pcmi/package.nix index 64113993f1eaa6..506ea72b194c10 100644 --- a/pkgs/by-name/zi/zita-alsa-pcmi/package.nix +++ b/pkgs/by-name/zi/zita-alsa-pcmi/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl , alsa-lib, }: +{ + lib, + stdenv, + fetchurl, + alsa-lib, +}: stdenv.mkDerivation rec { pname = "zita-alsa-pcmi"; diff --git a/pkgs/by-name/zi/zita-at1/package.nix b/pkgs/by-name/zi/zita-at1/package.nix index d55942368f8fe2..4f87f23d484b76 100644 --- a/pkgs/by-name/zi/zita-at1/package.nix +++ b/pkgs/by-name/zi/zita-at1/package.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchurl -, cairo, fftwSinglePrec, libX11, libXft, libclthreads, libclxclient, libjack2 -, xorgproto, zita-resampler +{ + lib, + stdenv, + fetchurl, + cairo, + fftwSinglePrec, + libX11, + libXft, + libclthreads, + libclxclient, + libjack2, + xorgproto, + zita-resampler, }: stdenv.mkDerivation rec { @@ -13,8 +23,15 @@ stdenv.mkDerivation rec { }; buildInputs = [ - cairo fftwSinglePrec libX11 libXft libclthreads libclxclient libjack2 - xorgproto zita-resampler + cairo + fftwSinglePrec + libX11 + libXft + libclthreads + libclxclient + libjack2 + xorgproto + zita-resampler ]; preConfigure = '' diff --git a/pkgs/by-name/zi/zita-convolver/package.nix b/pkgs/by-name/zi/zita-convolver/package.nix index 3b77bf549ca6e5..6320c11050b8e2 100644 --- a/pkgs/by-name/zi/zita-convolver/package.nix +++ b/pkgs/by-name/zi/zita-convolver/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, fftwFloat }: +{ + lib, + stdenv, + fetchurl, + fftwFloat, +}: stdenv.mkDerivation rec { pname = "zita-convolver"; diff --git a/pkgs/by-name/zi/zita-njbridge/package.nix b/pkgs/by-name/zi/zita-njbridge/package.nix index 01a2ddf47b52ed..0b4ae3c7f9fc44 100644 --- a/pkgs/by-name/zi/zita-njbridge/package.nix +++ b/pkgs/by-name/zi/zita-njbridge/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libjack2, zita-resampler }: +{ + lib, + stdenv, + fetchurl, + libjack2, + zita-resampler, +}: stdenv.mkDerivation rec { version = "0.4.8"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-EBF2oL1AfKt7/9Mm6NaIbBtlshK8M/LvuXsD+SbEeQc="; }; - buildInputs = [ libjack2 zita-resampler ]; + buildInputs = [ + libjack2 + zita-resampler + ]; preConfigure = '' cd ./source/ @@ -21,7 +30,6 @@ stdenv.mkDerivation rec { "SUFFIX=''" ]; - meta = with lib; { description = "command line Jack clients to transmit full quality multichannel audio over a local IP network"; homepage = "http://kokkinizita.linuxaudio.org/linuxaudio/index.html"; diff --git a/pkgs/by-name/zi/zita-resampler/package.nix b/pkgs/by-name/zi/zita-resampler/package.nix index 70054134767aeb..3f812c4703508b 100644 --- a/pkgs/by-name/zi/zita-resampler/package.nix +++ b/pkgs/by-name/zi/zita-resampler/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "zita-resampler"; @@ -14,14 +18,16 @@ stdenv.mkDerivation rec { "SUFFIX=" ]; - postPatch = '' - cd source - substituteInPlace Makefile \ - --replace 'ldconfig' "" - '' + lib.optionalString (!stdenv.hostPlatform.isx86_64) '' - substituteInPlace Makefile \ - --replace '-DENABLE_SSE2' "" - ''; + postPatch = + '' + cd source + substituteInPlace Makefile \ + --replace 'ldconfig' "" + '' + + lib.optionalString (!stdenv.hostPlatform.isx86_64) '' + substituteInPlace Makefile \ + --replace '-DENABLE_SSE2' "" + ''; fixupPhase = '' ln -s $out/lib/libzita-resampler.so.$version $out/lib/libzita-resampler.so.1 diff --git a/pkgs/by-name/zi/zitadel-tools/package.nix b/pkgs/by-name/zi/zitadel-tools/package.nix index 1837280f97576d..bf8f21fccd324a 100644 --- a/pkgs/by-name/zi/zitadel-tools/package.nix +++ b/pkgs/by-name/zi/zitadel-tools/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { @@ -20,7 +21,8 @@ buildGoModule rec { vendorHash = "sha256-ql5Qw5Va/wLBKsb9bCmPciuVrgORU8nndRkhjoJBIgs="; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X main.version=${version}" ]; diff --git a/pkgs/by-name/zi/zitadel/package.nix b/pkgs/by-name/zi/zitadel/package.nix index d4181af0434028..5267a9ecc16e43 100644 --- a/pkgs/by-name/zi/zitadel/package.nix +++ b/pkgs/by-name/zi/zitadel/package.nix @@ -1,17 +1,18 @@ -{ stdenv -, buildGoModule -, callPackage -, fetchFromGitHub -, lib - -, buf -, cacert -, grpc-gateway -, protoc-gen-go -, protoc-gen-go-grpc -, protoc-gen-validate -, sass -, statik +{ + stdenv, + buildGoModule, + callPackage, + fetchFromGitHub, + lib, + + buf, + cacert, + grpc-gateway, + protoc-gen-go, + protoc-gen-go-grpc, + protoc-gen-validate, + sass, + statik, }: let @@ -24,7 +25,8 @@ let }; goModulesHash = "sha256-gp17dP67HX7Tx3Gq+kEu9xCYkfs/rGpqLFiKT7cKlrc="; - buildZitadelProtocGen = name: + buildZitadelProtocGen = + name: buildGoModule { pname = "protoc-gen-${name}"; inherit version; @@ -51,12 +53,13 @@ let # can download what it needs, and output the relevant generated code for use # during the main build. generateProtobufCode = - { pname - , nativeBuildInputs ? [ ] - , bufArgs ? "" - , workDir ? "." - , outputPath - , hash + { + pname, + nativeBuildInputs ? [ ], + bufArgs ? "", + workDir ? ".", + outputPath, + hash, }: stdenv.mkDerivation { name = "${pname}-buf-generated"; @@ -64,7 +67,10 @@ let src = zitadelRepo; patches = [ ./console-use-local-protobuf-plugins.patch ]; - nativeBuildInputs = nativeBuildInputs ++ [ buf cacert ]; + nativeBuildInputs = nativeBuildInputs ++ [ + buf + cacert + ]; buildPhase = '' cd ${workDir} @@ -100,7 +106,10 @@ buildGoModule rec { src = zitadelRepo; - nativeBuildInputs = [ sass statik ]; + nativeBuildInputs = [ + sass + statik + ]; proxyVendor = true; vendorHash = goModulesHash; @@ -133,11 +142,9 @@ buildGoModule rec { ''; passthru = { - console = callPackage - (import ./console.nix { - inherit generateProtobufCode version zitadelRepo; - }) - { }; + console = callPackage (import ./console.nix { + inherit generateProtobufCode version zitadelRepo; + }) { }; }; meta = with lib; { diff --git a/pkgs/by-name/zi/zix/package.nix b/pkgs/by-name/zi/zix/package.nix index f2824fa793906a..10f37090f8c5ec 100644 --- a/pkgs/by-name/zi/zix/package.nix +++ b/pkgs/by-name/zi/zix/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, meson -, ninja -, pkg-config +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + meson, + ninja, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/zk/zk/package.nix b/pkgs/by-name/zk/zk/package.nix index e491e9b95fcb95..b04c676308466a 100644 --- a/pkgs/by-name/zk/zk/package.nix +++ b/pkgs/by-name/zk/zk/package.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildGoModule }: +{ + lib, + fetchFromGitHub, + buildGoModule, +}: buildGoModule rec { pname = "zk"; @@ -17,7 +21,12 @@ buildGoModule rec { CGO_ENABLED = 1; - ldflags = [ "-s" "-w" "-X=main.Build=${version}" "-X=main.Version=${version}"]; + ldflags = [ + "-s" + "-w" + "-X=main.Build=${version}" + "-X=main.Version=${version}" + ]; tags = [ "fts5" ]; diff --git a/pkgs/by-name/zk/zkar/package.nix b/pkgs/by-name/zk/zkar/package.nix index 53d67fb1f371da..65b846afa961b7 100644 --- a/pkgs/by-name/zk/zkar/package.nix +++ b/pkgs/by-name/zk/zkar/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -16,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-Eyi22d6RkIsg6S5pHXOqn6kULQ/mLeoaxSxxJJkMgIQ="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Java serialization protocol analysis tool"; diff --git a/pkgs/by-name/zk/zkfuse/package.nix b/pkgs/by-name/zk/zkfuse/package.nix index 00d78af0146fdd..b880a0f5dce7e9 100644 --- a/pkgs/by-name/zk/zkfuse/package.nix +++ b/pkgs/by-name/zk/zkfuse/package.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, autoreconfHook -, boost -, fuse -, log4cxx -, zookeeper -, zookeeper_mt +{ + stdenv, + lib, + autoreconfHook, + boost, + fuse, + log4cxx, + zookeeper, + zookeeper_mt, }: stdenv.mkDerivation rec { @@ -15,7 +16,12 @@ stdenv.mkDerivation rec { sourceRoot = "apache-${zookeeper.pname}-${version}/zookeeper-contrib/zookeeper-contrib-zkfuse"; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ zookeeper_mt log4cxx boost fuse ]; + buildInputs = [ + zookeeper_mt + log4cxx + boost + fuse + ]; postPatch = '' # Make the async API accessible, and use the proper include path. diff --git a/pkgs/by-name/zk/zktree/package.nix b/pkgs/by-name/zk/zktree/package.nix index 71b8806ae070df..f2bcf64da04802 100644 --- a/pkgs/by-name/zk/zktree/package.nix +++ b/pkgs/by-name/zk/zktree/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/by-name/zl/zld/package.nix b/pkgs/by-name/zl/zld/package.nix index af8509103067fb..74887641e26f30 100644 --- a/pkgs/by-name/zl/zld/package.nix +++ b/pkgs/by-name/zl/zld/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchzip }: +{ + stdenv, + lib, + fetchzip, +}: stdenv.mkDerivation rec { pname = "zld"; @@ -19,6 +23,6 @@ stdenv.mkDerivation rec { license = licenses.mit; maintainers = [ maintainers.rgnns ]; platforms = platforms.darwin; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/by-name/zl/zlib-ng/package.nix b/pkgs/by-name/zl/zlib-ng/package.nix index add675efae850d..1beba7163aeb6f 100644 --- a/pkgs/by-name/zl/zlib-ng/package.nix +++ b/pkgs/by-name/zl/zlib-ng/package.nix @@ -1,6 +1,11 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, pkg-config, gtest -, withZlibCompat ? false +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + gtest, + withZlibCompat ? false, }: stdenv.mkDerivation rec { @@ -14,11 +19,18 @@ stdenv.mkDerivation rec { hash = "sha256-FeOIFlFMDDd+5EDyr8KKW3G03UDM2xx4QF/wyKyDjq4="; }; - outputs = [ "out" "dev" "bin" ]; + outputs = [ + "out" + "dev" + "bin" + ]; strictDeps = true; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ gtest ]; @@ -30,9 +42,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "zlib data compression library for the next generation systems"; - homepage = "https://github.com/zlib-ng/zlib-ng"; - license = licenses.zlib; - platforms = platforms.all; + homepage = "https://github.com/zlib-ng/zlib-ng"; + license = licenses.zlib; + platforms = platforms.all; maintainers = with maintainers; [ izorkin ]; }; } diff --git a/pkgs/by-name/zl/zlint/package.nix b/pkgs/by-name/zl/zlint/package.nix index f2b370d65b5e2f..f80f752b3d56d0 100644 --- a/pkgs/by-name/zl/zlint/package.nix +++ b/pkgs/by-name/zl/zlint/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, zlint +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + zlint, }: buildGoModule rec { diff --git a/pkgs/by-name/zl/zlog/package.nix b/pkgs/by-name/zl/zlog/package.nix index 3273a0d5ff63a6..9054ae1a6a5497 100644 --- a/pkgs/by-name/zl/zlog/package.nix +++ b/pkgs/by-name/zl/zlog/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, +}: stdenv.mkDerivation rec { version = "1.2.17"; @@ -25,9 +30,8 @@ stdenv.mkDerivation rec { makeFlagsArray+=(CFLAGS="-Wno-pointer-to-int-cast -Wno-newline-eof") ''; - meta = with lib; { - description= "Reliable, high-performance, thread safe, flexible, clear-model, pure C logging library"; + description = "Reliable, high-performance, thread safe, flexible, clear-model, pure C logging library"; homepage = "https://hardysimpson.github.io/zlog/"; license = licenses.lgpl21; maintainers = [ maintainers.matthiasbeyer ]; diff --git a/pkgs/by-name/zl/zls/package.nix b/pkgs/by-name/zl/zls/package.nix index c9aec483df8c1a..8c6c3a90310ff5 100644 --- a/pkgs/by-name/zl/zls/package.nix +++ b/pkgs/by-name/zl/zls/package.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, zig_0_13 -, callPackage -, apple-sdk_11, +{ + lib, + stdenv, + fetchFromGitHub, + zig_0_13, + callPackage, + apple-sdk_11, }: stdenv.mkDerivation (finalAttrs: { @@ -36,7 +37,11 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://github.com/zigtools/zls/releases/tag/${finalAttrs.version}"; homepage = "https://github.com/zigtools/zls"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ figsoda moni _0x5a4 ]; + maintainers = with lib.maintainers; [ + figsoda + moni + _0x5a4 + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/by-name/zl/zluda/package.nix b/pkgs/by-name/zl/zluda/package.nix index c2b7d745040b32..731bc55d885f74 100644 --- a/pkgs/by-name/zl/zluda/package.nix +++ b/pkgs/by-name/zl/zluda/package.nix @@ -1,4 +1,18 @@ -{ lib, fetchFromGitHub, rocmPackages, python3, cargo, rustc, cmake, clang, zlib, libxml2, libedit, rustPlatform, stdenv }: +{ + lib, + fetchFromGitHub, + rocmPackages, + python3, + cargo, + rustc, + cmake, + clang, + zlib, + libxml2, + libedit, + rustPlatform, + stdenv, +}: rustPlatform.buildRustPackage rec { pname = "zluda"; diff --git a/pkgs/by-name/zm/zmap/package.nix b/pkgs/by-name/zm/zmap/package.nix index b7a9986434ebc2..fe856c2c27dcc0 100644 --- a/pkgs/by-name/zm/zmap/package.nix +++ b/pkgs/by-name/zm/zmap/package.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, libjson, json_c, gengetopt, flex, byacc, gmp -, libpcap, libunistring, judy +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libjson, + json_c, + gengetopt, + flex, + byacc, + gmp, + libpcap, + libunistring, + judy, }: stdenv.mkDerivation rec { @@ -15,10 +28,26 @@ stdenv.mkDerivation rec { cmakeFlags = [ "-DRESPECT_INSTALL_PREFIX_CONFIG=ON" ]; - nativeBuildInputs = [ cmake pkg-config gengetopt flex byacc ]; - buildInputs = [ libjson json_c gmp libpcap libunistring judy ]; + nativeBuildInputs = [ + cmake + pkg-config + gengetopt + flex + byacc + ]; + buildInputs = [ + libjson + json_c + gmp + libpcap + libunistring + judy + ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; meta = with lib; { homepage = "https://zmap.io/"; diff --git a/pkgs/by-name/zm/zmqpp/package.nix b/pkgs/by-name/zm/zmqpp/package.nix index 733573b3e23772..02a46f02e98204 100644 --- a/pkgs/by-name/zm/zmqpp/package.nix +++ b/pkgs/by-name/zm/zmqpp/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, zeromq }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + zeromq, +}: stdenv.mkDerivation rec { pname = "zmqpp"; @@ -11,9 +18,15 @@ stdenv.mkDerivation rec { sha256 = "08v34q3sd8g1b95k73n7jwryb0xzwca8ib9dz8ngczqf26j8k72i"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; propagatedBuildInputs = [ zeromq ]; diff --git a/pkgs/by-name/zn/zn_poly/package.nix b/pkgs/by-name/zn/zn_poly/package.nix index 1c61bb07471bef..2150cef6d4cd26 100644 --- a/pkgs/by-name/zn/zn_poly/package.nix +++ b/pkgs/by-name/zn/zn_poly/package.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitLab -, gmp -, python3 -, tune ? false # tune to hardware, impure +{ + stdenv, + lib, + fetchFromGitLab, + gmp, + python3, + tune ? false, # tune to hardware, impure }: stdenv.mkDerivation rec { @@ -37,7 +38,10 @@ stdenv.mkDerivation rec { # Tuning (either autotuning or with hand-written parameters) is possible # but not implemented here. # It seems buggy anyways (see homepage). - buildFlags = [ "all" "${libbasename}${libext}" ]; + buildFlags = [ + "all" + "${libbasename}${libext}" + ]; configureFlags = lib.optionals (!tune) [ "--disable-tuning" diff --git a/pkgs/by-name/zn/znapzend/package.nix b/pkgs/by-name/zn/znapzend/package.nix index a31406dd5f499f..4480b2ceaba475 100644 --- a/pkgs/by-name/zn/znapzend/package.nix +++ b/pkgs/by-name/zn/znapzend/package.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl, perl, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + perl, + autoreconfHook, +}: let # when upgrade znapzend, check versions of Perl libs here: https://github.com/oetiker/znapzend/blob/master/cpanfile @@ -12,11 +19,15 @@ let hash = "sha256-guBqKdWemc4mC/xp77Wd7qeV2iRqY4wrQ5NRsHtsCnI="; }; buildInputs = with perl.pkgs; [ ModuleBuildTiny ]; - propagatedBuildInputs = with perl.pkgs; [ Mojolicious RoleTiny ClassMethodModifiers ]; + propagatedBuildInputs = with perl.pkgs; [ + Mojolicious + RoleTiny + ClassMethodModifiers + ]; }; - perl' = perl.withPackages (p: - with p; [ + perl' = perl.withPackages ( + p: with p; [ ClassMethodModifiers ExtUtilsConfig ExtUtilsHelpers @@ -25,7 +36,8 @@ let MojoLogClearable Mojolicious RoleTiny - ]); + ] + ); in stdenv.mkDerivation (finalAttrs: { pname = "znapzend"; @@ -41,7 +53,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-UvaYzzV+5mZAAwSSMzq4fjCu/mzjeSyQdwQRTZGNktM="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; buildInputs = [ perl' ]; nativeBuildInputs = [ autoreconfHook ]; @@ -57,9 +72,12 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "High performance open source ZFS backup with mbuffer and ssh support"; - homepage = "https://www.znapzend.org"; - license = licenses.gpl3; - maintainers = with maintainers; [ otwieracz ma27 ]; - platforms = platforms.all; + homepage = "https://www.znapzend.org"; + license = licenses.gpl3; + maintainers = with maintainers; [ + otwieracz + ma27 + ]; + platforms = platforms.all; }; }) diff --git a/pkgs/by-name/zo/zod/package.nix b/pkgs/by-name/zo/zod/package.nix index f4add7f46c0abd..c3a296662be6f7 100644 --- a/pkgs/by-name/zo/zod/package.nix +++ b/pkgs/by-name/zo/zod/package.nix @@ -1,19 +1,20 @@ -{ lib -, config -, fetchzip -, stdenv -, SDL -, SDL_image -, SDL_ttf -, SDL_mixer -, libmysqlclient -, wxGTK32 -, symlinkJoin -, runCommandLocal -, makeWrapper -, coreutils -, scalingFactor ? 2 # this is to resize the fixed-size zod_launcher window -, substituteAll +{ + lib, + config, + fetchzip, + stdenv, + SDL, + SDL_image, + SDL_ttf, + SDL_mixer, + libmysqlclient, + wxGTK32, + symlinkJoin, + runCommandLocal, + makeWrapper, + coreutils, + scalingFactor ? 2, # this is to resize the fixed-size zod_launcher window + substituteAll, }: let pname = "zod-engine"; @@ -40,7 +41,15 @@ let hardeningDisable = [ "format" ]; NIX_LDFLAGS = "-L${libmysqlclient}/lib/mysql"; zod_engine = stdenv.mkDerivation { - inherit version src postPatch nativeBuildInputs buildInputs hardeningDisable NIX_LDFLAGS; + inherit + version + src + postPatch + nativeBuildInputs + buildInputs + hardeningDisable + NIX_LDFLAGS + ; pname = "${pname}-engine"; enableParallelBuilding = true; preBuild = "cd zod_src"; @@ -51,7 +60,15 @@ let ''; }; zod_map_editor = stdenv.mkDerivation { - inherit version src postPatch nativeBuildInputs buildInputs hardeningDisable NIX_LDFLAGS; + inherit + version + src + postPatch + nativeBuildInputs + buildInputs + hardeningDisable + NIX_LDFLAGS + ; pname = "${pname}-map_editor"; enableParallelBuilding = true; preBuild = "cd zod_src"; @@ -63,30 +80,37 @@ let ''; }; zod_launcher = stdenv.mkDerivation { - inherit version src nativeBuildInputs buildInputs zod_engine zod_map_editor; - pname = "${pname}-launcher"; - # This is necessary because the zod_launcher has terrible fixed-width window - # the Idea is to apply the scalingFactor to all positions and sizes and I tested 1,2,3 and 4 - # 2,3,4 look acceptable on my 4k monitor and 1 is unreadable. - # also the ./ in the run command is removed to have easier time starting the game - patches = [ - (substituteAll { - inherit scalingFactor; - src=./0002-add-scaling-factor-to-source.patch; - }) - ]; - postPatch = '' - substituteInPlace zod_launcher_src/zod_launcherFrm.cpp \ - --replace 'message = wxT("./zod");' 'message = wxT("zod");' \ - --replace "check.replace(i,1,1,'_');" "check.replace(i,1,1,(wxUniChar)'_');" - ''; - preBuild = "cd zod_launcher_src"; - installPhase = '' - mkdir -p $out/bin - install -m755 zod_launcher $out/bin - ''; + inherit + version + src + nativeBuildInputs + buildInputs + zod_engine + zod_map_editor + ; + pname = "${pname}-launcher"; + # This is necessary because the zod_launcher has terrible fixed-width window + # the Idea is to apply the scalingFactor to all positions and sizes and I tested 1,2,3 and 4 + # 2,3,4 look acceptable on my 4k monitor and 1 is unreadable. + # also the ./ in the run command is removed to have easier time starting the game + patches = [ + (substituteAll { + inherit scalingFactor; + src = ./0002-add-scaling-factor-to-source.patch; + }) + ]; + postPatch = '' + substituteInPlace zod_launcher_src/zod_launcherFrm.cpp \ + --replace 'message = wxT("./zod");' 'message = wxT("zod");' \ + --replace "check.replace(i,1,1,'_');" "check.replace(i,1,1,(wxUniChar)'_');" + ''; + preBuild = "cd zod_launcher_src"; + installPhase = '' + mkdir -p $out/bin + install -m755 zod_launcher $out/bin + ''; }; - zod_assets = runCommandLocal "${pname}-assets" {} '' + zod_assets = runCommandLocal "${pname}-assets" { } '' mkdir -p $out/usr/lib/commander-zod{,blank_maps} cp -r ${src}/assets $out/usr/lib/commander-zod/assets for i in ${src}/*.map ${src}/*.txt; do @@ -97,19 +121,19 @@ let done ''; in - symlinkJoin { - inherit pname version; - paths = [ - zod_engine - zod_launcher - zod_map_editor - zod_assets - ]; - meta = with lib; { - description = "Multiplayer remake of ZED"; - homepage = "http://zod.sourceforge.net/"; - maintainers = with maintainers; [ zeri ]; - license = licenses.gpl3Plus; /* Says the website */ - platforms = platforms.linux; - }; - } +symlinkJoin { + inherit pname version; + paths = [ + zod_engine + zod_launcher + zod_map_editor + zod_assets + ]; + meta = with lib; { + description = "Multiplayer remake of ZED"; + homepage = "http://zod.sourceforge.net/"; + maintainers = with maintainers; [ zeri ]; + license = licenses.gpl3Plus; # Says the website + platforms = platforms.linux; + }; +} diff --git a/pkgs/by-name/zo/zola/package.nix b/pkgs/by-name/zo/zola/package.nix index 5f658eed396043..7d45fbb2a5f966 100644 --- a/pkgs/by-name/zo/zola/package.nix +++ b/pkgs/by-name/zo/zola/package.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, pkg-config -, oniguruma -, darwin -, installShellFiles -, zola -, testers +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + oniguruma, + darwin, + installShellFiles, + zola, + testers, }: rustPlatform.buildRustPackage rec { @@ -28,11 +29,17 @@ rustPlatform.buildRustPackage rec { installShellFiles ]; - buildInputs = [ - oniguruma - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - CoreServices SystemConfiguration - ]); + buildInputs = + [ + oniguruma + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + CoreServices + SystemConfiguration + ] + ); RUSTONIG_SYSTEM_LIBONIG = true; @@ -51,6 +58,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://www.getzola.org/"; changelog = "https://github.com/getzola/zola/raw/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ dandellion dywedir _0x4A6F ]; + maintainers = with maintainers; [ + dandellion + dywedir + _0x4A6F + ]; }; } diff --git a/pkgs/by-name/zo/zon2nix/package.nix b/pkgs/by-name/zo/zon2nix/package.nix index d3f0bd6ce54a2d..82135e9ddd2bf5 100644 --- a/pkgs/by-name/zo/zon2nix/package.nix +++ b/pkgs/by-name/zo/zon2nix/package.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, zig_0_11 -, nix +{ + lib, + stdenv, + fetchFromGitHub, + zig_0_11, + nix, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/zo/zoneminder/package.nix b/pkgs/by-name/zo/zoneminder/package.nix index 766c42c8b742ed..f58c5e7de804a8 100644 --- a/pkgs/by-name/zo/zoneminder/package.nix +++ b/pkgs/by-name/zo/zoneminder/package.nix @@ -1,7 +1,32 @@ -{ stdenv, lib, fetchFromGitHub, fetchurl, cmake, makeWrapper, pkg-config -, curl, ffmpeg, glib, libjpeg, libselinux, libsepol, mp4v2, libmysqlclient, mariadb, pcre, perl, perlPackages -, polkit, util-linuxMinimal, x264, zlib -, coreutils, procps, psmisc, nixosTests }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchurl, + cmake, + makeWrapper, + pkg-config, + curl, + ffmpeg, + glib, + libjpeg, + libselinux, + libsepol, + mp4v2, + libmysqlclient, + mariadb, + pcre, + perl, + perlPackages, + polkit, + util-linuxMinimal, + x264, + zlib, + coreutils, + procps, + psmisc, + nixosTests, +}: # NOTES: # @@ -51,18 +76,19 @@ let } ]; - user = "zoneminder"; + user = "zoneminder"; dirName = "zoneminder"; perlBin = "${perl}/bin/perl"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "zoneminder"; version = "1.36.35"; src = fetchFromGitHub { - owner = "ZoneMinder"; - repo = "zoneminder"; - rev = version; + owner = "ZoneMinder"; + repo = "zoneminder"; + rev = version; hash = "sha256-0mpT3qjF8zlcsd6OlNIvrabDsz+oJPPy9Vn2TQSuHAI="; fetchSubmodules = true; }; @@ -75,9 +101,11 @@ in stdenv.mkDerivation rec { postPatch = '' rm -rf web/api/lib/Cake/Test - ${lib.concatStringsSep "\n" (map (e: '' - cp ${e.src} ${e.path} - '') addons)} + ${lib.concatStringsSep "\n" ( + map (e: '' + cp ${e.src} ${e.path} + '') addons + )} for d in scripts/ZoneMinder onvif/{modules,proxy} ; do substituteInPlace $d/CMakeLists.txt \ @@ -93,7 +121,13 @@ in stdenv.mkDerivation rec { scripts/ZoneMinder/lib/ZoneMinder/Memory.pm.in ; do substituteInPlace $f \ --replace '/usr/bin/perl' '${perlBin}' \ - --replace '/bin:/usr/bin' "$out/bin:${lib.makeBinPath [ coreutils procps psmisc ]}" + --replace '/bin:/usr/bin' "$out/bin:${ + lib.makeBinPath [ + coreutils + procps + psmisc + ] + }" done substituteInPlace scripts/zmdbbackup.in \ @@ -127,18 +161,50 @@ in stdenv.mkDerivation rec { --subst-var-by srcHash "`basename $out`" ''; - buildInputs = [ - curl ffmpeg glib libjpeg libselinux libsepol mp4v2 libmysqlclient mariadb pcre perl polkit x264 zlib - util-linuxMinimal # for libmount - ] ++ (with perlPackages; [ - # build-time dependencies - DateManip DBI DBDmysql LWP SysMmap - # run-time dependencies not checked at build-time - ClassStdFast DataDump DeviceSerialPort JSONMaybeXS LWPProtocolHttps NumberBytesHuman SysCPU SysMemInfo TimeDate - CryptEksblowfish DataEntropy # zmupdate.pl - ]); - - nativeBuildInputs = [ cmake makeWrapper pkg-config ]; + buildInputs = + [ + curl + ffmpeg + glib + libjpeg + libselinux + libsepol + mp4v2 + libmysqlclient + mariadb + pcre + perl + polkit + x264 + zlib + util-linuxMinimal # for libmount + ] + ++ (with perlPackages; [ + # build-time dependencies + DateManip + DBI + DBDmysql + LWP + SysMmap + # run-time dependencies not checked at build-time + ClassStdFast + DataDump + DeviceSerialPort + JSONMaybeXS + LWPProtocolHttps + NumberBytesHuman + SysCPU + SysMemInfo + TimeDate + CryptEksblowfish + DataEntropy # zmupdate.pl + ]); + + nativeBuildInputs = [ + cmake + makeWrapper + pkg-config + ]; cmakeFlags = [ "-DWITH_SYSTEMD=ON" diff --git a/pkgs/by-name/zo/zookeeper/package.nix b/pkgs/by-name/zo/zookeeper/package.nix index f230b9d8d21e17..192cba33efcd2b 100644 --- a/pkgs/by-name/zo/zookeeper/package.nix +++ b/pkgs/by-name/zo/zookeeper/package.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, jdk11_headless, makeWrapper, nixosTests, bash, coreutils }: +{ + lib, + stdenv, + fetchurl, + jdk11_headless, + makeWrapper, + nixosTests, + bash, + coreutils, +}: let # Latest supported LTS JDK for Zookeeper 3.9: # https://zookeeper.apache.org/doc/r3.9.2/zookeeperAdmin.html#sc_requiredSoftware @@ -46,7 +55,11 @@ stdenv.mkDerivation rec { description = "Apache Zookeeper"; changelog = "https://zookeeper.apache.org/doc/r${version}/releasenotes.html"; license = licenses.asl20; - maintainers = with maintainers; [ nathan-gs pradeepchhetri ztzg ]; + maintainers = with maintainers; [ + nathan-gs + pradeepchhetri + ztzg + ]; platforms = platforms.unix; sourceProvenance = with sourceTypes; [ binaryBytecode ]; }; diff --git a/pkgs/by-name/zo/zookeeper_mt/package.nix b/pkgs/by-name/zo/zookeeper_mt/package.nix index 953559dbecb579..fcb0c9404a6058 100644 --- a/pkgs/by-name/zo/zookeeper_mt/package.nix +++ b/pkgs/by-name/zo/zookeeper_mt/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchurl -, autoreconfHook -, jre -, openssl -, pkg-config -# We depend on ZooKeeper for the Jute compiler. -, zookeeper +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + jre, + openssl, + pkg-config, + # We depend on ZooKeeper for the Jute compiler. + zookeeper, }: stdenv.mkDerivation rec { @@ -50,7 +52,10 @@ stdenv.mkDerivation rec { homepage = "https://zookeeper.apache.org"; description = "Apache Zookeeper"; license = licenses.asl20; - maintainers = with maintainers; [ commandodev ztzg ]; + maintainers = with maintainers; [ + commandodev + ztzg + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/zo/zoom-us/package.nix b/pkgs/by-name/zo/zoom-us/package.nix index 8cc0e23c6a8c12..dc381e35094770 100644 --- a/pkgs/by-name/zo/zoom-us/package.nix +++ b/pkgs/by-name/zo/zoom-us/package.nix @@ -1,44 +1,45 @@ -{ stdenv -, lib -, fetchurl -, pipewire -, makeWrapper -, xar -, cpio +{ + stdenv, + lib, + fetchurl, + pipewire, + makeWrapper, + xar, + cpio, # Dynamic libraries -, alsa-lib -, atk -, at-spi2-atk -, at-spi2-core -, cairo -, cups -, dbus -, expat -, libdrm -, libGL -, fontconfig -, freetype -, gtk3 -, gdk-pixbuf -, glib -, mesa -, nspr -, nss -, pango -, wayland -, xorg -, libxkbcommon -, udev -, zlib -, libkrb5 + alsa-lib, + atk, + at-spi2-atk, + at-spi2-core, + cairo, + cups, + dbus, + expat, + libdrm, + libGL, + fontconfig, + freetype, + gtk3, + gdk-pixbuf, + glib, + mesa, + nspr, + nss, + pango, + wayland, + xorg, + libxkbcommon, + udev, + zlib, + libkrb5, # Runtime -, coreutils -, pciutils -, procps -, util-linux -, pulseaudioSupport ? true -, libpulseaudio -, pulseaudio + coreutils, + pciutils, + procps, + util-linux, + pulseaudioSupport ? true, + libpulseaudio, + pulseaudio, }: let @@ -69,51 +70,63 @@ let }; }; - libs = lib.makeLibraryPath ([ - # $ LD_LIBRARY_PATH=$NIX_LD_LIBRARY_PATH:$PWD ldd zoom | grep 'not found' - alsa-lib - atk - at-spi2-atk - at-spi2-core - cairo - cups - dbus - expat - libdrm - libGL - pipewire - fontconfig - freetype - gtk3 - gdk-pixbuf - glib - mesa - nspr - nss - pango - stdenv.cc.cc - wayland - xorg.libX11 - xorg.libxcb - xorg.libXcomposite - xorg.libXdamage - xorg.libXext - libxkbcommon - xorg.libXrandr - xorg.libXrender - xorg.libxshmfence - xorg.xcbutilimage - xorg.xcbutilkeysyms - xorg.xcbutilrenderutil - xorg.xcbutilwm - xorg.libXfixes - xorg.libXtst - udev - zlib - libkrb5 - ] ++ lib.optional (pulseaudioSupport) libpulseaudio); - - binPath = lib.makeBinPath ([ coreutils glib.dev pciutils procps util-linux ] ++ lib.optional pulseaudioSupport pulseaudio); + libs = lib.makeLibraryPath ( + [ + # $ LD_LIBRARY_PATH=$NIX_LD_LIBRARY_PATH:$PWD ldd zoom | grep 'not found' + alsa-lib + atk + at-spi2-atk + at-spi2-core + cairo + cups + dbus + expat + libdrm + libGL + pipewire + fontconfig + freetype + gtk3 + gdk-pixbuf + glib + mesa + nspr + nss + pango + stdenv.cc.cc + wayland + xorg.libX11 + xorg.libxcb + xorg.libXcomposite + xorg.libXdamage + xorg.libXext + libxkbcommon + xorg.libXrandr + xorg.libXrender + xorg.libxshmfence + xorg.xcbutilimage + xorg.xcbutilkeysyms + xorg.xcbutilrenderutil + xorg.xcbutilwm + xorg.libXfixes + xorg.libXtst + udev + zlib + libkrb5 + ] + ++ lib.optional (pulseaudioSupport) libpulseaudio + ); + + binPath = lib.makeBinPath ( + [ + coreutils + glib.dev + pciutils + procps + util-linux + ] + ++ lib.optional pulseaudioSupport pulseaudio + ); in stdenv.mkDerivation { pname = "zoom"; @@ -127,75 +140,81 @@ stdenv.mkDerivation { zcat < zoomus.pkg/Payload | cpio -i ''; - nativeBuildInputs = [ - makeWrapper - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - xar - cpio - ]; + nativeBuildInputs = + [ + makeWrapper + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + xar + cpio + ]; installPhase = '' runHook preInstall - ${rec { - aarch64-darwin = '' - mkdir -p $out/Applications - cp -R zoom.us.app $out/Applications/ - ''; - # darwin steps same on both architectures - x86_64-darwin = aarch64-darwin; - x86_64-linux = '' - mkdir $out - tar -C $out -xf $src - mv $out/usr/* $out/ - ''; - }.${system} or throwSystem} + ${ + rec { + aarch64-darwin = '' + mkdir -p $out/Applications + cp -R zoom.us.app $out/Applications/ + ''; + # darwin steps same on both architectures + x86_64-darwin = aarch64-darwin; + x86_64-linux = '' + mkdir $out + tar -C $out -xf $src + mv $out/usr/* $out/ + ''; + } + .${system} or throwSystem + } runHook postInstall ''; - postFixup = lib.optionalString stdenv.hostPlatform.isDarwin '' - makeWrapper $out/Applications/zoom.us.app/Contents/MacOS/zoom.us $out/bin/zoom - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - # Desktop File - substituteInPlace $out/share/applications/Zoom.desktop \ - --replace-fail "Exec=/usr/bin/zoom" "Exec=$out/bin/zoom" + postFixup = + lib.optionalString stdenv.hostPlatform.isDarwin '' + makeWrapper $out/Applications/zoom.us.app/Contents/MacOS/zoom.us $out/bin/zoom + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + # Desktop File + substituteInPlace $out/share/applications/Zoom.desktop \ + --replace-fail "Exec=/usr/bin/zoom" "Exec=$out/bin/zoom" + + for i in aomhost zopen zoom ZoomLauncher ZoomWebviewHost; do + if [ -f $out/opt/zoom/$i ]; then + patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" $out/opt/zoom/$i + fi + done + + # ZoomLauncher sets LD_LIBRARY_PATH before execing zoom + # IPC breaks if the executable name does not end in 'zoom' + mv $out/opt/zoom/zoom $out/opt/zoom/.zoom + makeWrapper $out/opt/zoom/.zoom $out/opt/zoom/zoom \ + --prefix LD_LIBRARY_PATH ":" ${libs} - for i in aomhost zopen zoom ZoomLauncher ZoomWebviewHost; do - if [ -f $out/opt/zoom/$i ]; then - patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" $out/opt/zoom/$i - fi - done - - # ZoomLauncher sets LD_LIBRARY_PATH before execing zoom - # IPC breaks if the executable name does not end in 'zoom' - mv $out/opt/zoom/zoom $out/opt/zoom/.zoom - makeWrapper $out/opt/zoom/.zoom $out/opt/zoom/zoom \ - --prefix LD_LIBRARY_PATH ":" ${libs} - - rm $out/bin/zoom - # Zoom expects "zopen" executable (needed for web login) to be present in CWD. Or does it expect - # everybody runs Zoom only after cd to Zoom package directory? Anyway, :facepalm: - # Clear Qt paths to prevent tripping over "foreign" Qt resources. - # Clear Qt screen scaling settings to prevent over-scaling. - makeWrapper $out/opt/zoom/ZoomLauncher $out/bin/zoom \ - --chdir "$out/opt/zoom" \ - --unset QML2_IMPORT_PATH \ - --unset QT_PLUGIN_PATH \ - --unset QT_SCREEN_SCALE_FACTORS \ - --prefix PATH : ${binPath} \ - --prefix LD_LIBRARY_PATH ":" ${libs} - - if [ -f $out/opt/zoom/ZoomWebviewHost ]; then - wrapProgram $out/opt/zoom/ZoomWebviewHost \ + rm $out/bin/zoom + # Zoom expects "zopen" executable (needed for web login) to be present in CWD. Or does it expect + # everybody runs Zoom only after cd to Zoom package directory? Anyway, :facepalm: + # Clear Qt paths to prevent tripping over "foreign" Qt resources. + # Clear Qt screen scaling settings to prevent over-scaling. + makeWrapper $out/opt/zoom/ZoomLauncher $out/bin/zoom \ + --chdir "$out/opt/zoom" \ --unset QML2_IMPORT_PATH \ --unset QT_PLUGIN_PATH \ --unset QT_SCREEN_SCALE_FACTORS \ + --prefix PATH : ${binPath} \ --prefix LD_LIBRARY_PATH ":" ${libs} - fi - # Backwards compatibility: we used to call it zoom-us - ln -s $out/bin/{zoom,zoom-us} - ''; + if [ -f $out/opt/zoom/ZoomWebviewHost ]; then + wrapProgram $out/opt/zoom/ZoomWebviewHost \ + --unset QML2_IMPORT_PATH \ + --unset QT_PLUGIN_PATH \ + --unset QT_SCREEN_SCALE_FACTORS \ + --prefix LD_LIBRARY_PATH ":" ${libs} + fi + + # Backwards compatibility: we used to call it zoom-us + ln -s $out/bin/{zoom,zoom-us} + ''; # already done dontPatchELF = true; @@ -209,7 +228,10 @@ stdenv.mkDerivation { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; platforms = builtins.attrNames srcs; - maintainers = with maintainers; [ danbst tadfisher ]; + maintainers = with maintainers; [ + danbst + tadfisher + ]; mainProgram = "zoom"; }; } diff --git a/pkgs/by-name/zo/zoom/package.nix b/pkgs/by-name/zo/zoom/package.nix index 275aca235209da..d1eaaa815563b7 100644 --- a/pkgs/by-name/zo/zoom/package.nix +++ b/pkgs/by-name/zo/zoom/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, perl -, expat -, fontconfig -, freetype -, xorg +{ + lib, + stdenv, + fetchurl, + perl, + expat, + fontconfig, + freetype, + xorg, }: # !!! assert freetype == xorg.freetype diff --git a/pkgs/by-name/zo/zopfli/package.nix b/pkgs/by-name/zo/zopfli/package.nix index 8d8813e2eda4f1..903061699dd499 100644 --- a/pkgs/by-name/zo/zopfli/package.nix +++ b/pkgs/by-name/zo/zopfli/package.nix @@ -1,9 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "zopfli"; version = "1.0.3"; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; src = fetchFromGitHub { owner = "google"; @@ -15,7 +24,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - cmakeFlags = [ "-DBUILD_SHARED_LIBS=ON" "-DCMAKE_BUILD_WITH_INSTALL_RPATH=ON" ]; + cmakeFlags = [ + "-DBUILD_SHARED_LIBS=ON" + "-DCMAKE_BUILD_WITH_INSTALL_RPATH=ON" + ]; postInstall = '' install -Dm444 -t $out/share/doc/zopfli ../README* @@ -35,6 +47,9 @@ stdenv.mkDerivation rec { platforms = platforms.unix; license = licenses.asl20; mainProgram = "zopfli"; - maintainers = with maintainers; [ bobvanderlinden edef ]; + maintainers = with maintainers; [ + bobvanderlinden + edef + ]; }; } diff --git a/pkgs/by-name/zo/zotero-beta/package.nix b/pkgs/by-name/zo/zotero-beta/package.nix index e8da30471190d7..f96296b4fc66aa 100644 --- a/pkgs/by-name/zo/zotero-beta/package.nix +++ b/pkgs/by-name/zo/zotero-beta/package.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchurl -, wrapGAppsHook3 -, makeDesktopItem -, alsa-lib -, atk -, cairo -, dbus-glib -, gdk-pixbuf -, glib -, gtk3 -, libGL -, xorg -, mesa -, pango -, pciutils +{ + lib, + stdenv, + fetchurl, + wrapGAppsHook3, + makeDesktopItem, + alsa-lib, + atk, + cairo, + dbus-glib, + gdk-pixbuf, + glib, + gtk3, + libGL, + xorg, + mesa, + pango, + pciutils, }: stdenv.mkDerivation rec { @@ -23,7 +24,7 @@ stdenv.mkDerivation rec { src = let - escapedVersion = lib.replaceStrings ["+"] ["%2B"] version; + escapedVersion = lib.replaceStrings [ "+" ] [ "%2B" ] version; in fetchurl { url = "https://download.zotero.org/client/beta/${escapedVersion}/Zotero-${escapedVersion}_linux-x86_64.tar.bz2"; @@ -33,29 +34,32 @@ stdenv.mkDerivation rec { dontPatchELF = true; nativeBuildInputs = [ wrapGAppsHook3 ]; - libPath = lib.makeLibraryPath [ - alsa-lib - atk - cairo - dbus-glib - gdk-pixbuf - glib - gtk3 - libGL - xorg.libX11 - xorg.libXcomposite - xorg.libXcursor - xorg.libXdamage - xorg.libXext - xorg.libXfixes - xorg.libXi - xorg.libXrandr - xorg.libXtst - xorg.libxcb - mesa - pango - pciutils - ] + ":" + lib.makeSearchPathOutput "lib" "lib64" [ stdenv.cc.cc ]; + libPath = + lib.makeLibraryPath [ + alsa-lib + atk + cairo + dbus-glib + gdk-pixbuf + glib + gtk3 + libGL + xorg.libX11 + xorg.libXcomposite + xorg.libXcursor + xorg.libXdamage + xorg.libXext + xorg.libXfixes + xorg.libXi + xorg.libXrandr + xorg.libXtst + xorg.libxcb + mesa + pango + pciutils + ] + + ":" + + lib.makeSearchPathOutput "lib" "lib64" [ stdenv.cc.cc ]; desktopItem = makeDesktopItem { name = "zotero"; @@ -64,9 +68,15 @@ stdenv.mkDerivation rec { comment = meta.description; desktopName = "Zotero"; genericName = "Reference Management"; - categories = [ "Office" "Database" ]; + categories = [ + "Office" + "Database" + ]; startupNotify = true; - mimeTypes = [ "x-scheme-handler/zotero" "text/plain" ]; + mimeTypes = [ + "x-scheme-handler/zotero" + "text/plain" + ]; }; installPhase = '' @@ -113,6 +123,9 @@ stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.agpl3Only; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ atila justanotherariel ]; + maintainers = with maintainers; [ + atila + justanotherariel + ]; }; } diff --git a/pkgs/by-name/zo/zotero-translation-server/package.nix b/pkgs/by-name/zo/zotero-translation-server/package.nix index 923d9d4de8fb14..b6c5f45be9d74e 100644 --- a/pkgs/by-name/zo/zotero-translation-server/package.nix +++ b/pkgs/by-name/zo/zotero-translation-server/package.nix @@ -1,4 +1,9 @@ -{ lib, buildNpmPackage, fetchFromGitHub, nodejs }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, + nodejs, +}: buildNpmPackage rec { pname = "zotero-translation-server"; diff --git a/pkgs/by-name/zo/zoxide/package.nix b/pkgs/by-name/zo/zoxide/package.nix index 5c1ba44d156dcd..c4573028ddec54 100644 --- a/pkgs/by-name/zo/zoxide/package.nix +++ b/pkgs/by-name/zo/zoxide/package.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, withFzf ? true -, fzf -, installShellFiles -, libiconv +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + withFzf ? true, + fzf, + installShellFiles, + libiconv, }: rustPlatform.buildRustPackage rec { @@ -43,7 +44,11 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/ajeetdsouza/zoxide"; changelog = "https://github.com/ajeetdsouza/zoxide/blob/v${version}/CHANGELOG.md"; license = with licenses; [ mit ]; - maintainers = with maintainers; [ ysndr cole-h SuperSandro2000 ]; + maintainers = with maintainers; [ + ysndr + cole-h + SuperSandro2000 + ]; mainProgram = "zoxide"; }; } diff --git a/pkgs/by-name/zp/zpaqfranz/package.nix b/pkgs/by-name/zp/zpaqfranz/package.nix index 0e759d6d559d36..ca0675c1be5ba7 100644 --- a/pkgs/by-name/zp/zpaqfranz/package.nix +++ b/pkgs/by-name/zp/zpaqfranz/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/zp/zpix-pixel-font/package.nix b/pkgs/by-name/zp/zpix-pixel-font/package.nix index 50f3dd352ca13d..26b429a1655b08 100644 --- a/pkgs/by-name/zp/zpix-pixel-font/package.nix +++ b/pkgs/by-name/zp/zpix-pixel-font/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchurl +{ + lib, + stdenvNoCC, + fetchurl, }: stdenvNoCC.mkDerivation rec { pname = "zpix-pixel-font"; diff --git a/pkgs/by-name/zp/zplug/package.nix b/pkgs/by-name/zp/zplug/package.nix index 4f6231d1411036..01d41d2e464ed7 100644 --- a/pkgs/by-name/zp/zplug/package.nix +++ b/pkgs/by-name/zp/zplug/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zplug"; diff --git a/pkgs/by-name/zp/zpool-auto-expand-partitions/package.nix b/pkgs/by-name/zp/zpool-auto-expand-partitions/package.nix index d2cf39e2a5df96..3edc4b7b2594a3 100644 --- a/pkgs/by-name/zp/zpool-auto-expand-partitions/package.nix +++ b/pkgs/by-name/zp/zpool-auto-expand-partitions/package.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, cloud-utils -, fetchFromGitHub -, pkg-config -, util-linux -, zfs +{ + lib, + rustPlatform, + cloud-utils, + fetchFromGitHub, + pkg-config, + util-linux, + zfs, }: rustPlatform.buildRustPackage rec { pname = "zpool-auto-expand-partitions"; diff --git a/pkgs/by-name/zp/zpool-iostat-viz/package.nix b/pkgs/by-name/zp/zpool-iostat-viz/package.nix index 4f546e544e66c2..772660bddce772 100644 --- a/pkgs/by-name/zp/zpool-iostat-viz/package.nix +++ b/pkgs/by-name/zp/zpool-iostat-viz/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, python3Packages -, installShellFiles +{ + lib, + fetchFromGitHub, + python3Packages, + installShellFiles, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/by-name/zp/zprint/package.nix b/pkgs/by-name/zp/zprint/package.nix index 0d8f66d436f82b..d1e41f5bb1f2e7 100644 --- a/pkgs/by-name/zp/zprint/package.nix +++ b/pkgs/by-name/zp/zprint/package.nix @@ -1,8 +1,9 @@ -{ lib -, buildGraalvmNativeImage -, fetchurl -, testers -, zprint +{ + lib, + buildGraalvmNativeImage, + fetchurl, + testers, + zprint, }: buildGraalvmNativeImage rec { diff --git a/pkgs/by-name/zp/zps/package.nix b/pkgs/by-name/zp/zps/package.nix index 62a9efe7d7d937..9408d844e349c5 100644 --- a/pkgs/by-name/zp/zps/package.nix +++ b/pkgs/by-name/zp/zps/package.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/by-name/zr/zrepl/package.nix b/pkgs/by-name/zr/zrepl/package.nix index b04d23fc372a06..7748db7cf48462 100644 --- a/pkgs/by-name/zr/zrepl/package.nix +++ b/pkgs/by-name/zr/zrepl/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, nixosTests -, openssh +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + nixosTests, + openssh, }: buildGoModule rec { pname = "zrepl"; @@ -24,7 +25,11 @@ buildGoModule rec { makeWrapper ]; - ldflags = [ "-s" "-w" "-X github.com/zrepl/zrepl/version.zreplVersion=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X github.com/zrepl/zrepl/version.zreplVersion=${version}" + ]; postInstall = '' mkdir -p $out/lib/systemd/system @@ -44,7 +49,10 @@ buildGoModule rec { description = "One-stop, integrated solution for ZFS replication"; platforms = platforms.linux; license = licenses.mit; - maintainers = with maintainers; [ cole-h mdlayher ]; + maintainers = with maintainers; [ + cole-h + mdlayher + ]; mainProgram = "zrepl"; }; } diff --git a/pkgs/by-name/zs/zs-apc-spdu-ctl/package.nix b/pkgs/by-name/zs/zs-apc-spdu-ctl/package.nix index bb523aa707c35a..7211f4448283f8 100644 --- a/pkgs/by-name/zs/zs-apc-spdu-ctl/package.nix +++ b/pkgs/by-name/zs/zs-apc-spdu-ctl/package.nix @@ -1,10 +1,11 @@ -{ cmake -, fetchFromGitHub -, fping -, lib -, libowlevelzs -, net-snmp -, stdenv +{ + cmake, + fetchFromGitHub, + fping, + lib, + libowlevelzs, + net-snmp, + stdenv, }: # TODO: add a services entry for the /etc/zs-apc-spdu.conf file @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ libowlevelzs net-snmp ]; + buildInputs = [ + libowlevelzs + net-snmp + ]; postPatch = '' substituteInPlace src/confent.cxx \ diff --git a/pkgs/by-name/zs/zs-wait4host/package.nix b/pkgs/by-name/zs/zs-wait4host/package.nix index 96d200382b3560..ed04b8a7852b2c 100644 --- a/pkgs/by-name/zs/zs-wait4host/package.nix +++ b/pkgs/by-name/zs/zs-wait4host/package.nix @@ -1,4 +1,10 @@ -{ coreutils, fetchurl, fping, lib, stdenvNoCC }: +{ + coreutils, + fetchurl, + fping, + lib, + stdenvNoCC, +}: stdenvNoCC.mkDerivation rec { pname = "zs-wait4host"; diff --git a/pkgs/by-name/zs/zs/package.nix b/pkgs/by-name/zs/zs/package.nix index 7aec860bafa0f3..9f6a293f0381bc 100644 --- a/pkgs/by-name/zs/zs/package.nix +++ b/pkgs/by-name/zs/zs/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitea, buildGoModule, installShellFiles }: +{ + lib, + fetchFromGitea, + buildGoModule, + installShellFiles, +}: buildGoModule rec { pname = "zs"; diff --git a/pkgs/by-name/zs/zsa-udev-rules/package.nix b/pkgs/by-name/zs/zsa-udev-rules/package.nix index 66485ab51dd82f..cb54d4a83321c4 100644 --- a/pkgs/by-name/zs/zsa-udev-rules/package.nix +++ b/pkgs/by-name/zs/zsa-udev-rules/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zsa-udev-rules"; diff --git a/pkgs/by-name/zs/zscroll/package.nix b/pkgs/by-name/zs/zscroll/package.nix index 79a5c72ddc8f79..f52784ea8676c7 100644 --- a/pkgs/by-name/zs/zscroll/package.nix +++ b/pkgs/by-name/zs/zscroll/package.nix @@ -1,4 +1,9 @@ -{ lib, python3, python3Packages, fetchFromGitHub }: +{ + lib, + python3, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "zscroll"; diff --git a/pkgs/by-name/zs/zsh-autocomplete/package.nix b/pkgs/by-name/zs/zsh-autocomplete/package.nix index bd265a3868baec..286b7174b715ae 100644 --- a/pkgs/by-name/zs/zsh-autocomplete/package.nix +++ b/pkgs/by-name/zs/zsh-autocomplete/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "zsh-autocomplete"; diff --git a/pkgs/by-name/zs/zsh-autoenv/package.nix b/pkgs/by-name/zs/zsh-autoenv/package.nix index d16410c3153852..4242b74f4cf8d8 100644 --- a/pkgs/by-name/zs/zsh-autoenv/package.nix +++ b/pkgs/by-name/zs/zsh-autoenv/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, runtimeShell }: +{ + lib, + stdenv, + fetchFromGitHub, + runtimeShell, +}: stdenv.mkDerivation { pname = "zsh-autoenv"; diff --git a/pkgs/by-name/zs/zsh-bd/package.nix b/pkgs/by-name/zs/zsh-bd/package.nix index b0704065901b14..6f1aa03dee680a 100644 --- a/pkgs/by-name/zs/zsh-bd/package.nix +++ b/pkgs/by-name/zs/zsh-bd/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub}: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zsh-bd"; diff --git a/pkgs/by-name/zs/zsh-better-npm-completion/package.nix b/pkgs/by-name/zs/zsh-better-npm-completion/package.nix index d9a813bbbfdd6b..fd9e87b6772261 100644 --- a/pkgs/by-name/zs/zsh-better-npm-completion/package.nix +++ b/pkgs/by-name/zs/zsh-better-npm-completion/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zsh-better-npm-completion"; diff --git a/pkgs/by-name/zs/zsh-command-time/package.nix b/pkgs/by-name/zs/zsh-command-time/package.nix index cfdb48104a5bcd..957ab9b352b3bb 100644 --- a/pkgs/by-name/zs/zsh-command-time/package.nix +++ b/pkgs/by-name/zs/zsh-command-time/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: # To make use of this plugin, need to add # programs.zsh.interactiveShellInit = '' diff --git a/pkgs/by-name/zs/zsh-completions/package.nix b/pkgs/by-name/zs/zsh-completions/package.nix index 0bb2c87267190e..193c78210bdfd9 100644 --- a/pkgs/by-name/zs/zsh-completions/package.nix +++ b/pkgs/by-name/zs/zsh-completions/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zsh-completions"; diff --git a/pkgs/by-name/zs/zsh-defer/package.nix b/pkgs/by-name/zs/zsh-defer/package.nix index e21a254af52a3f..b256e19d539ddd 100644 --- a/pkgs/by-name/zs/zsh-defer/package.nix +++ b/pkgs/by-name/zs/zsh-defer/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zsh-defer"; diff --git a/pkgs/by-name/zs/zsh-edit/package.nix b/pkgs/by-name/zs/zsh-edit/package.nix index b1ca81e30ce854..4d7924ac186f58 100644 --- a/pkgs/by-name/zs/zsh-edit/package.nix +++ b/pkgs/by-name/zs/zsh-edit/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zsh-edit"; diff --git a/pkgs/by-name/zs/zsh-f-sy-h/package.nix b/pkgs/by-name/zs/zsh-f-sy-h/package.nix index 0e18eaa95838dd..be92c8e667d848 100644 --- a/pkgs/by-name/zs/zsh-f-sy-h/package.nix +++ b/pkgs/by-name/zs/zsh-f-sy-h/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchFromGitHub }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "zsh-f-sy-h"; diff --git a/pkgs/by-name/zs/zsh-fast-syntax-highlighting/package.nix b/pkgs/by-name/zs/zsh-fast-syntax-highlighting/package.nix index 68f09828b45624..7daf234f0102d7 100644 --- a/pkgs/by-name/zs/zsh-fast-syntax-highlighting/package.nix +++ b/pkgs/by-name/zs/zsh-fast-syntax-highlighting/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchFromGitHub }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "zsh-fast-syntax-highlighting"; diff --git a/pkgs/by-name/zs/zsh-forgit/package.nix b/pkgs/by-name/zs/zsh-forgit/package.nix index f63496d0df7e91..4eb6f8eb889cea 100644 --- a/pkgs/by-name/zs/zsh-forgit/package.nix +++ b/pkgs/by-name/zs/zsh-forgit/package.nix @@ -1,15 +1,16 @@ -{ stdenvNoCC -, lib -, bash -, coreutils -, findutils -, fetchFromGitHub -, fzf -, gawk -, git -, gnugrep -, gnused -, makeWrapper +{ + stdenvNoCC, + lib, + bash, + coreutils, + findutils, + fetchFromGitHub, + fzf, + gawk, + git, + gnugrep, + gnused, + makeWrapper, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -41,7 +42,18 @@ stdenvNoCC.mkDerivation (finalAttrs: { install -D completions/_git-forgit $out/share/zsh/site-functions/_git-forgit install -D forgit.plugin.zsh $out/share/zsh/${finalAttrs.pname}/forgit.plugin.zsh wrapProgram $out/bin/git-forgit \ - --prefix PATH : ${lib.makeBinPath [ bash coreutils findutils fzf gawk git gnugrep gnused ]} + --prefix PATH : ${ + lib.makeBinPath [ + bash + coreutils + findutils + fzf + gawk + git + gnugrep + gnused + ] + } runHook postInstall ''; diff --git a/pkgs/by-name/zs/zsh-fzf-history-search/package.nix b/pkgs/by-name/zs/zsh-fzf-history-search/package.nix index d85171530a6ae5..c852da674a9b4d 100644 --- a/pkgs/by-name/zs/zsh-fzf-history-search/package.nix +++ b/pkgs/by-name/zs/zsh-fzf-history-search/package.nix @@ -1,6 +1,7 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub +{ + lib, + stdenvNoCC, + fetchFromGitHub, }: stdenvNoCC.mkDerivation { diff --git a/pkgs/by-name/zs/zsh-fzf-tab/package.nix b/pkgs/by-name/zs/zsh-fzf-tab/package.nix index 1b96c5224d0eb8..41c9dacef43a1d 100644 --- a/pkgs/by-name/zs/zsh-fzf-tab/package.nix +++ b/pkgs/by-name/zs/zsh-fzf-tab/package.nix @@ -1,8 +1,16 @@ -{ stdenv, lib, fetchFromGitHub, zsh, ncurses, nix-update-script }: +{ + stdenv, + lib, + fetchFromGitHub, + zsh, + ncurses, + nix-update-script, +}: let - INSTALL_PATH="${placeholder "out"}/share/fzf-tab"; -in stdenv.mkDerivation rec { + INSTALL_PATH = "${placeholder "out"}/share/fzf-tab"; +in +stdenv.mkDerivation rec { pname = "zsh-fzf-tab"; version = "1.1.2"; diff --git a/pkgs/by-name/zs/zsh-git-prompt/package.nix b/pkgs/by-name/zs/zsh-git-prompt/package.nix index f9e5633476ab97..d78768336d0f7b 100644 --- a/pkgs/by-name/zs/zsh-git-prompt/package.nix +++ b/pkgs/by-name/zs/zsh-git-prompt/package.nix @@ -24,47 +24,61 @@ # More details are in share/doc/zsh-git-prompt/README.md, once # installed. # -{ fetchFromGitHub -, python3 -, git -, lib -, haskellPackages +{ + fetchFromGitHub, + python3, + git, + lib, + haskellPackages, }: -haskellPackages.callPackage - ({ mkDerivation, base, HUnit, parsec, process, QuickCheck }: - mkDerivation rec { - pname = "zsh-git-prompt"; - version = "0.4z"; # While we await a real 0.5 release. - src = fetchFromGitHub { - owner = "starcraftman"; - repo = "zsh-git-prompt"; - rev = "11b83ba3b85d14c66cf2ab79faefab6d838da28e"; - sha256 = "04aylsjfb03ckw219plkzpyiq4j9g66bjxa5pa56h1p7df6pjssb"; - }; - prePatch = '' - substituteInPlace zshrc.sh \ - --replace ':-"python"' ':-"haskell"' \ - --replace 'python ' '${python3.interpreter} ' \ - --replace 'git ' '${git}/bin/git ' - ''; - preCompileBuildDriver = "cd src"; - postInstall = '' - cd .. - gpshare=$out/share/${pname} - gpdoc=$out/share/doc/${pname} - mkdir -p $gpshare/src $gpdoc - cp README.md $gpdoc - cp zshrc.sh gitstatus.py $gpshare - mv $out/bin $gpshare/src/.bin - ''; - isLibrary = false; - isExecutable = true; - libraryHaskellDepends = [ base parsec process QuickCheck ]; - executableHaskellDepends = libraryHaskellDepends; - testHaskellDepends = [HUnit] ++ libraryHaskellDepends; - homepage = "https://github.com/olivierverdier/zsh-git-prompt#readme"; - description = "Informative git prompt for zsh"; - license = lib.licenses.mit; - maintainers = [lib.maintainers.league]; - }) {} +haskellPackages.callPackage ( + { + mkDerivation, + base, + HUnit, + parsec, + process, + QuickCheck, + }: + mkDerivation rec { + pname = "zsh-git-prompt"; + version = "0.4z"; # While we await a real 0.5 release. + src = fetchFromGitHub { + owner = "starcraftman"; + repo = "zsh-git-prompt"; + rev = "11b83ba3b85d14c66cf2ab79faefab6d838da28e"; + sha256 = "04aylsjfb03ckw219plkzpyiq4j9g66bjxa5pa56h1p7df6pjssb"; + }; + prePatch = '' + substituteInPlace zshrc.sh \ + --replace ':-"python"' ':-"haskell"' \ + --replace 'python ' '${python3.interpreter} ' \ + --replace 'git ' '${git}/bin/git ' + ''; + preCompileBuildDriver = "cd src"; + postInstall = '' + cd .. + gpshare=$out/share/${pname} + gpdoc=$out/share/doc/${pname} + mkdir -p $gpshare/src $gpdoc + cp README.md $gpdoc + cp zshrc.sh gitstatus.py $gpshare + mv $out/bin $gpshare/src/.bin + ''; + isLibrary = false; + isExecutable = true; + libraryHaskellDepends = [ + base + parsec + process + QuickCheck + ]; + executableHaskellDepends = libraryHaskellDepends; + testHaskellDepends = [ HUnit ] ++ libraryHaskellDepends; + homepage = "https://github.com/olivierverdier/zsh-git-prompt#readme"; + description = "Informative git prompt for zsh"; + license = lib.licenses.mit; + maintainers = [ lib.maintainers.league ]; + } +) { } diff --git a/pkgs/by-name/zs/zsh-history-search-multi-word/package.nix b/pkgs/by-name/zs/zsh-history-search-multi-word/package.nix index 30d26c96766213..51ffd564d8f24b 100644 --- a/pkgs/by-name/zs/zsh-history-search-multi-word/package.nix +++ b/pkgs/by-name/zs/zsh-history-search-multi-word/package.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchFromGitHub }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "zsh-history-search-multi-word"; @@ -25,7 +29,10 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { description = "Multi-word, syntax highlighted history searching for Zsh"; homepage = "https://github.com/zdharma-continuum/history-search-multi-word"; - license = with licenses; [ gpl3 mit ]; + license = with licenses; [ + gpl3 + mit + ]; platforms = platforms.unix; }; } diff --git a/pkgs/by-name/zs/zsh-history-substring-search/package.nix b/pkgs/by-name/zs/zsh-history-substring-search/package.nix index 4b2aea76a7b7ca..e291025f6ee1a4 100644 --- a/pkgs/by-name/zs/zsh-history-substring-search/package.nix +++ b/pkgs/by-name/zs/zsh-history-substring-search/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zsh-history-substring-search"; diff --git a/pkgs/by-name/zs/zsh-history-to-fish/package.nix b/pkgs/by-name/zs/zsh-history-to-fish/package.nix index 4e8da001f83508..b158ab4fc1a8f9 100644 --- a/pkgs/by-name/zs/zsh-history-to-fish/package.nix +++ b/pkgs/by-name/zs/zsh-history-to-fish/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchPypi -, python3 +{ + lib, + fetchPypi, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/zs/zsh-history/package.nix b/pkgs/by-name/zs/zsh-history/package.nix index f2afd98de60a55..2d8b12bc35c7de 100644 --- a/pkgs/by-name/zs/zsh-history/package.nix +++ b/pkgs/by-name/zs/zsh-history/package.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildGoModule, installShellFiles, nixosTests }: +{ + lib, + fetchFromGitHub, + buildGoModule, + installShellFiles, + nixosTests, +}: buildGoModule rec { pname = "zsh-history"; diff --git a/pkgs/by-name/zs/zsh-navigation-tools/package.nix b/pkgs/by-name/zs/zsh-navigation-tools/package.nix index f719fe3b692256..e208c65891d260 100644 --- a/pkgs/by-name/zs/zsh-navigation-tools/package.nix +++ b/pkgs/by-name/zs/zsh-navigation-tools/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zsh-navigation-tools"; diff --git a/pkgs/by-name/zs/zsh-nix-shell/package.nix b/pkgs/by-name/zs/zsh-nix-shell/package.nix index ddd21683d3b13c..243c35949fd01d 100644 --- a/pkgs/by-name/zs/zsh-nix-shell/package.nix +++ b/pkgs/by-name/zs/zsh-nix-shell/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, bash }: +{ + lib, + stdenv, + fetchFromGitHub, + bash, +}: # To make use of this derivation, use # `programs.zsh.interactiveShellInit = "source ${pkgs.zsh-nix-shell}/share/zsh-nix-shell/nix-shell.plugin.zsh";` diff --git a/pkgs/by-name/zs/zsh-powerlevel10k/package.nix b/pkgs/by-name/zs/zsh-powerlevel10k/package.nix index c9f610471f5757..2ca1cc0c4e0d3c 100644 --- a/pkgs/by-name/zs/zsh-powerlevel10k/package.nix +++ b/pkgs/by-name/zs/zsh-powerlevel10k/package.nix @@ -1,12 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, substituteAll -, gitstatus -, bash +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + gitstatus, + bash, }: - let # match gitstatus version with given `gitstatus_version`: # https://github.com/romkatv/powerlevel10k/blob/master/gitstatus/build.info diff --git a/pkgs/by-name/zs/zsh-powerlevel9k/package.nix b/pkgs/by-name/zs/zsh-powerlevel9k/package.nix index 4a0b0bd02dd686..a9ec9e8d1a0070 100644 --- a/pkgs/by-name/zs/zsh-powerlevel9k/package.nix +++ b/pkgs/by-name/zs/zsh-powerlevel9k/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "powerlevel9k"; @@ -11,7 +15,7 @@ stdenv.mkDerivation { }; strictDeps = true; - installPhase= '' + installPhase = '' install -D powerlevel9k.zsh-theme --target-directory=$out/share/zsh-powerlevel9k install -D functions/* --target-directory=$out/share/zsh-powerlevel9k/functions ''; diff --git a/pkgs/by-name/zs/zsh-prezto/package.nix b/pkgs/by-name/zs/zsh-prezto/package.nix index ff79e8ea1a761b..7fce5d1f10cf5c 100644 --- a/pkgs/by-name/zs/zsh-prezto/package.nix +++ b/pkgs/by-name/zs/zsh-prezto/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, unstableGitUpdater, bash }: +{ + lib, + stdenv, + fetchFromGitHub, + unstableGitUpdater, + bash, +}: stdenv.mkDerivation rec { pname = "zsh-prezto"; @@ -25,7 +31,7 @@ stdenv.mkDerivation rec { cp -R ./ $out/share/zsh-prezto ''; - passthru.updateScript = unstableGitUpdater {}; + passthru.updateScript = unstableGitUpdater { }; meta = with lib; { description = "Configuration framework for Zsh"; diff --git a/pkgs/by-name/zs/zsh-syntax-highlighting/package.nix b/pkgs/by-name/zs/zsh-syntax-highlighting/package.nix index 518a9658083bae..dba2adb6c37d5f 100644 --- a/pkgs/by-name/zs/zsh-syntax-highlighting/package.nix +++ b/pkgs/by-name/zs/zsh-syntax-highlighting/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, zsh }: +{ + lib, + stdenv, + fetchFromGitHub, + zsh, +}: # To make use of this derivation, use the `programs.zsh.enableSyntaxHighlighting` option @@ -23,6 +28,9 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/zsh-users/zsh-syntax-highlighting"; license = licenses.bsd3; platforms = platforms.unix; - maintainers = with maintainers; [ gepbird loskutov ]; + maintainers = with maintainers; [ + gepbird + loskutov + ]; }; }) diff --git a/pkgs/by-name/zs/zsh-system-clipboard/package.nix b/pkgs/by-name/zs/zsh-system-clipboard/package.nix index 3cfe47e77f707f..ae389956037ecc 100644 --- a/pkgs/by-name/zs/zsh-system-clipboard/package.nix +++ b/pkgs/by-name/zs/zsh-system-clipboard/package.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zsh-system-clipboard"; @@ -20,7 +24,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/kutsan/zsh-system-clipboard"; description = "Plugin that adds key bindings support for ZLE (Zsh Line Editor) clipboard operations for vi emulation keymaps"; license = licenses.gpl3Only; - maintainers = with maintainers; [ _0qq satoqz ]; + maintainers = with maintainers; [ + _0qq + satoqz + ]; platforms = platforms.all; }; } diff --git a/pkgs/by-name/zs/zsh-vi-mode/package.nix b/pkgs/by-name/zs/zsh-vi-mode/package.nix index b29dc4a344d173..f10473fab229ec 100644 --- a/pkgs/by-name/zs/zsh-vi-mode/package.nix +++ b/pkgs/by-name/zs/zsh-vi-mode/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zsh-vi-mode"; diff --git a/pkgs/by-name/zs/zsh-wd/package.nix b/pkgs/by-name/zs/zsh-wd/package.nix index 7f8d8a5e0a65f4..0fdc451b4f5ab9 100644 --- a/pkgs/by-name/zs/zsh-wd/package.nix +++ b/pkgs/by-name/zs/zsh-wd/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchFromGitHub, installShellFiles }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + installShellFiles, +}: stdenvNoCC.mkDerivation rec { pname = "wd"; diff --git a/pkgs/by-name/zs/zsh-z/package.nix b/pkgs/by-name/zs/zsh-z/package.nix index a03b81cb6bfd2e..84efc5ee2ba1ef 100644 --- a/pkgs/by-name/zs/zsh-z/package.nix +++ b/pkgs/by-name/zs/zsh-z/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "zsh-z"; diff --git a/pkgs/by-name/zs/zssh/package.nix b/pkgs/by-name/zs/zssh/package.nix index b64d2c959a1afb..3720976f055f61 100644 --- a/pkgs/by-name/zs/zssh/package.nix +++ b/pkgs/by-name/zs/zssh/package.nix @@ -1,8 +1,14 @@ -{ lib, stdenv, fetchurl, readline }: +{ + lib, + stdenv, + fetchurl, + readline, +}: let version = "1.5c"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "zssh"; inherit version; diff --git a/pkgs/by-name/zs/zstxtns-utils/package.nix b/pkgs/by-name/zs/zstxtns-utils/package.nix index 485a8b3a40d9d4..fce8532a0fe452 100644 --- a/pkgs/by-name/zs/zstxtns-utils/package.nix +++ b/pkgs/by-name/zs/zstxtns-utils/package.nix @@ -1,10 +1,11 @@ -{ coreutils -, fetchurl -, gnugrep -, lib -, makeWrapper -, moreutils -, stdenvNoCC +{ + coreutils, + fetchurl, + gnugrep, + lib, + makeWrapper, + moreutils, + stdenvNoCC, }: stdenvNoCC.mkDerivation rec { @@ -25,8 +26,19 @@ stdenvNoCC.mkDerivation rec { ''; postInstall = '' - wrapProgram $out/bin/zstxtns-merge --set PATH "${lib.makeBinPath [coreutils gnugrep moreutils]}" - wrapProgram $out/bin/zstxtns-unmerge --set PATH "${lib.makeBinPath [coreutils gnugrep]}" + wrapProgram $out/bin/zstxtns-merge --set PATH "${ + lib.makeBinPath [ + coreutils + gnugrep + moreutils + ] + }" + wrapProgram $out/bin/zstxtns-unmerge --set PATH "${ + lib.makeBinPath [ + coreutils + gnugrep + ] + }" ''; meta = with lib; { diff --git a/pkgs/by-name/zs/zsv/package.nix b/pkgs/by-name/zs/zsv/package.nix index 0cfc77d010743e..0413b032601c1f 100644 --- a/pkgs/by-name/zs/zsv/package.nix +++ b/pkgs/by-name/zs/zsv/package.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, perl, jq }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, + jq, +}: stdenv.mkDerivation rec { pname = "zsv"; diff --git a/pkgs/by-name/zs/zsync/package.nix b/pkgs/by-name/zs/zsync/package.nix index e925d1c8419b4f..d4f57f0a750ca4 100644 --- a/pkgs/by-name/zs/zsync/package.nix +++ b/pkgs/by-name/zs/zsync/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "zsync"; diff --git a/pkgs/by-name/zt/zthrottle/package.nix b/pkgs/by-name/zt/zthrottle/package.nix index aa1d3c1c4fbf46..3b4cef67f5e18c 100644 --- a/pkgs/by-name/zt/zthrottle/package.nix +++ b/pkgs/by-name/zt/zthrottle/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, zsh }: +{ + lib, + stdenv, + fetchFromGitHub, + zsh, +}: stdenv.mkDerivation rec { pname = "zthrottle"; diff --git a/pkgs/by-name/zu/zug/package.nix b/pkgs/by-name/zu/zug/package.nix index 509545c1ffa97d..6f87be40e1e60c 100644 --- a/pkgs/by-name/zu/zug/package.nix +++ b/pkgs/by-name/zu/zug/package.nix @@ -1,11 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, boost +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, }: - stdenv.mkDerivation rec { pname = "zug"; version = "0.1.0"; @@ -28,9 +28,9 @@ stdenv.mkDerivation rec { rm BUILD ''; meta = with lib; { - homepage = "https://github.com/arximboldi/zug"; + homepage = "https://github.com/arximboldi/zug"; description = "library for functional interactive c++ programs"; maintainers = with maintainers; [ nek0 ]; - license = licenses.boost; + license = licenses.boost; }; } diff --git a/pkgs/by-name/zu/zuki-themes/package.nix b/pkgs/by-name/zu/zuki-themes/package.nix index d557e151d26400..03a99c4e3f28c7 100644 --- a/pkgs/by-name/zu/zuki-themes/package.nix +++ b/pkgs/by-name/zu/zuki-themes/package.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, sassc, gdk-pixbuf, librsvg, gtk_engines, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + sassc, + gdk-pixbuf, + librsvg, + gtk_engines, + gtk-engine-murrine, +}: stdenv.mkDerivation rec { pname = "zuki-themes"; @@ -11,9 +22,17 @@ stdenv.mkDerivation rec { sha256 = "1q026wa8xgyb6f5k7pqpm5zav30dbnm3b8w59as3sh8rhfgpbf80"; }; - nativeBuildInputs = [ meson ninja sassc ]; + nativeBuildInputs = [ + meson + ninja + sassc + ]; - buildInputs = [ gdk-pixbuf librsvg gtk_engines ]; + buildInputs = [ + gdk-pixbuf + librsvg + gtk_engines + ]; propagatedUserEnvPkgs = [ gtk-engine-murrine ]; diff --git a/pkgs/by-name/zu/zulip-term/package.nix b/pkgs/by-name/zu/zulip-term/package.nix index 7c741216df11ad..45b1a8a565daab 100644 --- a/pkgs/by-name/zu/zulip-term/package.nix +++ b/pkgs/by-name/zu/zulip-term/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3 -, fetchFromGitHub -, glibcLocales -, libnotify +{ + lib, + python3, + fetchFromGitHub, + glibcLocales, + libnotify, }: let @@ -60,16 +61,21 @@ buildPythonApplication rec { zulip ]; - nativeCheckInputs = [ - glibcLocales - ] ++ (with python3.pkgs; [ - pytestCheckHook - pytest-cov - pytest-mock - ]); + nativeCheckInputs = + [ + glibcLocales + ] + ++ (with python3.pkgs; [ + pytestCheckHook + pytest-cov + pytest-mock + ]); makeWrapperArgs = [ - "--prefix" "PATH" ":" (lib.makeBinPath [ libnotify ]) + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ libnotify ]) ]; meta = with lib; { diff --git a/pkgs/by-name/zu/zuo/package.nix b/pkgs/by-name/zu/zuo/package.nix index 9bfb925586c4a4..00b4ece29cd2e3 100644 --- a/pkgs/by-name/zu/zuo/package.nix +++ b/pkgs/by-name/zu/zuo/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zuo"; diff --git a/pkgs/by-name/zx/zxcvbn-c/package.nix b/pkgs/by-name/zx/zxcvbn-c/package.nix index edd62ed3340bd3..3fc9d2ae509051 100644 --- a/pkgs/by-name/zx/zxcvbn-c/package.nix +++ b/pkgs/by-name/zx/zxcvbn-c/package.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "zxcvbn-c"; version = "2.5"; diff --git a/pkgs/by-name/zx/zxfer/package.nix b/pkgs/by-name/zx/zxfer/package.nix index 802688cad5837e..2591d69eb38527 100644 --- a/pkgs/by-name/zx/zxfer/package.nix +++ b/pkgs/by-name/zx/zxfer/package.nix @@ -1,16 +1,17 @@ -{ lib -, bash -, fetchFromGitHub -, installShellFiles -, coreutils -, gawk -, gnugrep -, gnused -, openssh -, resholve -, rsync -, which -, zfs +{ + lib, + bash, + fetchFromGitHub, + installShellFiles, + coreutils, + gawk, + gnugrep, + gnused, + openssh, + resholve, + rsync, + which, + zfs, }: resholve.mkDerivation rec { diff --git a/pkgs/by-name/zx/zxing-cpp/package.nix b/pkgs/by-name/zx/zxing-cpp/package.nix index 30a304867d585a..cc1a3caa939bc4 100644 --- a/pkgs/by-name/zx/zxing-cpp/package.nix +++ b/pkgs/by-name/zx/zxing-cpp/package.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, python3 -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + python3, + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/by-name/zx/zxing/package.nix b/pkgs/by-name/zx/zxing/package.nix index 175b15b22aecb4..eae4b10a7be436 100644 --- a/pkgs/by-name/zx/zxing/package.nix +++ b/pkgs/by-name/zx/zxing/package.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, jre }: +{ + lib, + stdenv, + fetchurl, + jre, +}: stdenv.mkDerivation rec { pname = "zxing"; version = "3.1.0"; @@ -27,7 +32,7 @@ stdenv.mkDerivation rec { description = "1D and 2D code reading library"; sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; license = lib.licenses.asl20; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; homepage = "https://github.com/zxing/zxing"; }; diff --git a/pkgs/by-name/zx/zxpy/package.nix b/pkgs/by-name/zx/zxpy/package.nix index 650a220250cb71..4c731b863602fd 100644 --- a/pkgs/by-name/zx/zxpy/package.nix +++ b/pkgs/by-name/zx/zxpy/package.nix @@ -1,8 +1,9 @@ -{ lib -, python3 -, fetchFromGitHub -, fetchpatch -, deterministic-uname +{ + lib, + python3, + fetchFromGitHub, + fetchpatch, + deterministic-uname, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/by-name/zx/zxtune/package.nix b/pkgs/by-name/zx/zxtune/package.nix index 56b62844af843d..f9187633340fc4 100644 --- a/pkgs/by-name/zx/zxtune/package.nix +++ b/pkgs/by-name/zx/zxtune/package.nix @@ -1,35 +1,37 @@ -{ lib -, stdenv -, fetchFromBitbucket -, nix-update-script -, boost -, zlib -# File backends (for decoding and encoding) -, withMp3 ? true -, lame -, withOgg ? true -, libvorbis -, withFlac ? true -, flac -# Audio backends (for playback) -, withOpenal ? false -, openal -, withSDL ? false -, SDL -, withOss ? false -, withAlsa ? stdenv.hostPlatform.isLinux -, alsa-lib -, withPulse ? stdenv.hostPlatform.isLinux -, libpulseaudio -# GUI audio player -, withQt ? true -, qt5 -, zip -, makeDesktopItem -, copyDesktopItems +{ + lib, + stdenv, + fetchFromBitbucket, + nix-update-script, + boost, + zlib, + # File backends (for decoding and encoding) + withMp3 ? true, + lame, + withOgg ? true, + libvorbis, + withFlac ? true, + flac, + # Audio backends (for playback) + withOpenal ? false, + openal, + withSDL ? false, + SDL, + withOss ? false, + withAlsa ? stdenv.hostPlatform.isLinux, + alsa-lib, + withPulse ? stdenv.hostPlatform.isLinux, + libpulseaudio, + # GUI audio player + withQt ? true, + qt5, + zip, + makeDesktopItem, + copyDesktopItems, }: let - dlopenBuildInputs = [] + dlopenBuildInputs = + [ ] ++ lib.optional withMp3 lame ++ lib.optional withOgg libvorbis ++ lib.optional withFlac flac @@ -39,9 +41,12 @@ let ++ lib.optional withPulse libpulseaudio; supportWayland = (!stdenv.hostPlatform.isDarwin); platformName = "linux"; - staticBuildInputs = [ boost zlib ] - ++ lib.optional withQt (if (supportWayland) then qt5.qtwayland else qt5.qtbase); -in stdenv.mkDerivation rec { + staticBuildInputs = [ + boost + zlib + ] ++ lib.optional withQt (if (supportWayland) then qt5.qtwayland else qt5.qtbase); +in +stdenv.mkDerivation rec { pname = "zxtune"; version = "5075"; @@ -55,7 +60,10 @@ in stdenv.mkDerivation rec { }; passthru.updateScript = nix-update-script { - extraArgs = [ "--version-regex" "r([0-9]+)" ]; + extraArgs = [ + "--version-regex" + "r([0-9]+)" + ]; }; strictDeps = true; @@ -78,56 +86,62 @@ in stdenv.mkDerivation rec { --replace "#include String */ - escapeShellArgs' = lib.concatMapStringsSep " " (arg: if arg ? __rawShell then arg.__rawShell else lib.escapeShellArg arg); + escapeShellArgs' = lib.concatMapStringsSep " " ( + arg: if arg ? __rawShell then arg.__rawShell else lib.escapeShellArg arg + ); /* processArg : { maxArgIndex : Int, args : [ShellArg], paths : [FilePath] } → (String|FilePath) → { maxArgIndex : Int, args : [ShellArg], paths : [FilePath] } Helper reducer function for building a command arguments where file paths are replaced with argv[x] reference. */ processArg = - { maxArgIndex, args, paths }: + { + maxArgIndex, + args, + paths, + }: arg: - if builtins.isPath arg then { - args = args ++ [ { __rawShell = "\"\$${builtins.toString maxArgIndex}\""; } ]; - maxArgIndex = maxArgIndex + 1; - paths = paths ++ [ arg ]; - } else { - args = args ++ [ arg ]; - inherit maxArgIndex paths; - }; + if builtins.isPath arg then + { + args = args ++ [ { __rawShell = "\"\$${builtins.toString maxArgIndex}\""; } ]; + maxArgIndex = maxArgIndex + 1; + paths = paths ++ [ arg ]; + } + else + { + args = args ++ [ arg ]; + inherit maxArgIndex paths; + }; /* extractPaths : Int → [ (String|FilePath) ] → { maxArgIndex : Int, args : [ShellArg], paths : [FilePath] } Helper function that extracts file paths from command arguments and replaces them with argv[x] references. */ - extractPaths = maxArgIndex: command: builtins.foldl' processArg { inherit maxArgIndex; args = [ ]; paths = [ ]; } command; + extractPaths = + maxArgIndex: command: + builtins.foldl' processArg { + inherit maxArgIndex; + args = [ ]; + paths = [ ]; + } command; /* processCommand : { maxArgIndex : Int, commands : [[ShellArg]], paths : [FilePath] } → [ (String|FilePath) ] → { maxArgIndex : Int, commands : [[ShellArg]], paths : [FilePath] } Helper reducer function for extracting file paths from individual commands. */ processCommand = - { maxArgIndex, commands, paths }: + { + maxArgIndex, + commands, + paths, + }: command: let new = extractPaths maxArgIndex command; @@ -77,13 +95,20 @@ let extractCommands : Int → [[ (String|FilePath) ]] → { maxArgIndex : Int, commands : [[ShellArg]], paths : [FilePath] } Helper function for extracting file paths from a list of commands and replacing them with argv[x] references. */ - extractCommands = maxArgIndex: commands: builtins.foldl' processCommand { inherit maxArgIndex; commands = [ ]; paths = [ ]; } commands; + extractCommands = + maxArgIndex: commands: + builtins.foldl' processCommand { + inherit maxArgIndex; + commands = [ ]; + paths = [ ]; + } commands; /* commandsToShellInvocation : [[ (String|FilePath) ]] → [ (String|FilePath) ] Converts a list of commands into a single command by turning them into a shell script and passing them to `sh -c`. */ - commandsToShellInvocation = commands: + commandsToShellInvocation = + commands: let extracted = extractCommands 0 commands; in @@ -93,19 +118,23 @@ let (lib.concatMapStringsSep ";" escapeShellArgs' extracted.commands) # We need paths as separate arguments so that update.nix can ensure they refer to the local directory # rather than a store path. - ] ++ extracted.paths; + ] + ++ extracted.paths; in rec { /* normalize : UpdateScript → UpdateScript EXPERIMENTAL! Converts a basic update script to the experimental attribute set form. */ - normalize = updateScript: { - command = lib.toList (updateScript.command or updateScript); - supportedFeatures = updateScript.supportedFeatures or [ ]; - } // lib.optionalAttrs (updateScript ? attrPath) { - inherit (updateScript) attrPath; - }; + normalize = + updateScript: + { + command = lib.toList (updateScript.command or updateScript); + supportedFeatures = updateScript.supportedFeatures or [ ]; + } + // lib.optionalAttrs (updateScript ? attrPath) { + inherit (updateScript) attrPath; + }; /* sequence : [UpdateScript] → UpdateScript @@ -119,8 +148,11 @@ rec { in let scripts = scriptsNormalized; - hasCommitSupport = lib.findSingle ({ supportedFeatures, ... }: supportedFeatures == [ "commit" ]) null null scripts != null; - hasSilentSupport = lib.findFirst ({ supportedFeatures, ... }: supportedFeatures == [ "silent" ]) null scripts != null; + hasCommitSupport = + lib.findSingle ({ supportedFeatures, ... }: supportedFeatures == [ "commit" ]) null null scripts + != null; + hasSilentSupport = + lib.findFirst ({ supportedFeatures, ... }: supportedFeatures == [ "silent" ]) null scripts != null; # Supported features currently only describe the format of the standard output of the update script. # Here we ensure that the standard output of the combined update script is well formed. validateFeatures = @@ -135,8 +167,21 @@ rec { ({ supportedFeatures, ... }: supportedFeatures == [ ]); in - assert lib.assertMsg (lib.all validateFeatures scripts) "Combining update scripts with features enabled (other than “silent” scripts and an optional single script with “commit”) is currently unsupported."; - assert lib.assertMsg (builtins.length (lib.unique (builtins.map ({ attrPath ? null, ... }: attrPath) scripts)) == 1) "Combining update scripts with different attr paths is currently unsupported."; + assert lib.assertMsg (lib.all validateFeatures scripts) + "Combining update scripts with features enabled (other than “silent” scripts and an optional single script with “commit”) is currently unsupported."; + assert lib.assertMsg ( + builtins.length ( + lib.unique ( + builtins.map ( + { + attrPath ? null, + ... + }: + attrPath + ) scripts + ) + ) == 1 + ) "Combining update scripts with different attr paths is currently unsupported."; { command = commandsToShellInvocation (builtins.map ({ command, ... }: command) scripts); @@ -154,8 +199,7 @@ rec { EXPERIMENTAL! Simple update script that copies the output of Nix derivation built by `attr` to `path`. */ copyAttrOutputToFile = - attr: - path: + attr: path: { command = [ diff --git a/pkgs/common-updater/directory-listing-updater.nix b/pkgs/common-updater/directory-listing-updater.nix index b717213fc3a79b..39e3f66339ef0f 100644 --- a/pkgs/common-updater/directory-listing-updater.nix +++ b/pkgs/common-updater/directory-listing-updater.nix @@ -1,21 +1,34 @@ -{ lib -, genericUpdater -, common-updater-scripts +{ + lib, + genericUpdater, + common-updater-scripts, }: -{ pname ? null -, version ? null -, attrPath ? null -, allowedVersions ? "" -, ignoredVersions ? "" -, rev-prefix ? "" -, odd-unstable ? false -, patchlevel-unstable ? false -, url ? null -, extraRegex ? null +{ + pname ? null, + version ? null, + attrPath ? null, + allowedVersions ? "", + ignoredVersions ? "", + rev-prefix ? "", + odd-unstable ? false, + patchlevel-unstable ? false, + url ? null, + extraRegex ? null, }: genericUpdater { - inherit pname version attrPath allowedVersions ignoredVersions rev-prefix odd-unstable patchlevel-unstable; - versionLister = "${common-updater-scripts}/bin/list-directory-versions ${lib.optionalString (url != null) "--url=${lib.escapeShellArg url}"} ${lib.optionalString (extraRegex != null) "--extra-regex=${lib.escapeShellArg extraRegex}"}"; + inherit + pname + version + attrPath + allowedVersions + ignoredVersions + rev-prefix + odd-unstable + patchlevel-unstable + ; + versionLister = "${common-updater-scripts}/bin/list-directory-versions ${ + lib.optionalString (url != null) "--url=${lib.escapeShellArg url}" + } ${lib.optionalString (extraRegex != null) "--extra-regex=${lib.escapeShellArg extraRegex}"}"; } diff --git a/pkgs/common-updater/generic-updater.nix b/pkgs/common-updater/generic-updater.nix index bc7affea173f4f..02dec34e7976fd 100644 --- a/pkgs/common-updater/generic-updater.nix +++ b/pkgs/common-updater/generic-updater.nix @@ -1,23 +1,25 @@ -{ lib -, stdenv -, common-updater-scripts -, coreutils -, gnugrep -, gnused -, nix -, writeScript +{ + lib, + stdenv, + common-updater-scripts, + coreutils, + gnugrep, + gnused, + nix, + writeScript, }: -{ name ? null -, pname ? null -, version ? null -, attrPath ? null -, versionLister -, allowedVersions ? "" -, ignoredVersions ? "" -, rev-prefix ? "" -, odd-unstable ? false -, patchlevel-unstable ? false +{ + name ? null, + pname ? null, + version ? null, + attrPath ? null, + versionLister, + allowedVersions ? "", + ignoredVersions ? "", + rev-prefix ? "", + odd-unstable ? false, + patchlevel-unstable ? false, }: let @@ -130,9 +132,22 @@ let echo "" >> ${fileForGitCommands} ''; -in { +in +{ name = "generic-update-script"; - command = [ updateScript name pname version attrPath versionLister allowedVersions ignoredVersions rev-prefix odd-unstable patchlevel-unstable ]; + command = [ + updateScript + name + pname + version + attrPath + versionLister + allowedVersions + ignoredVersions + rev-prefix + odd-unstable + patchlevel-unstable + ]; supportedFeatures = [ # Stdout must contain output according to the updateScript commit protocol when the update script finishes with a non-zero exit code. "commit" diff --git a/pkgs/common-updater/git-updater.nix b/pkgs/common-updater/git-updater.nix index 314799c23f2818..155c7e37dca972 100644 --- a/pkgs/common-updater/git-updater.nix +++ b/pkgs/common-updater/git-updater.nix @@ -1,22 +1,35 @@ -{ lib -, genericUpdater -, common-updater-scripts +{ + lib, + genericUpdater, + common-updater-scripts, }: -{ pname ? null -, version ? null -, attrPath ? null -, allowedVersions ? "" -, ignoredVersions ? "" -, rev-prefix ? "" -, odd-unstable ? false -, patchlevel-unstable ? false -# an explicit url is needed when src.meta.homepage or src.url don't -# point to a git repo (eg. when using fetchurl, fetchzip, ...) -, url ? null +{ + pname ? null, + version ? null, + attrPath ? null, + allowedVersions ? "", + ignoredVersions ? "", + rev-prefix ? "", + odd-unstable ? false, + patchlevel-unstable ? false, + # an explicit url is needed when src.meta.homepage or src.url don't + # point to a git repo (eg. when using fetchurl, fetchzip, ...) + url ? null, }: genericUpdater { - inherit pname version attrPath allowedVersions ignoredVersions rev-prefix odd-unstable patchlevel-unstable; - versionLister = "${common-updater-scripts}/bin/list-git-tags ${lib.optionalString (url != null) "--url=${url}"}"; + inherit + pname + version + attrPath + allowedVersions + ignoredVersions + rev-prefix + odd-unstable + patchlevel-unstable + ; + versionLister = "${common-updater-scripts}/bin/list-git-tags ${ + lib.optionalString (url != null) "--url=${url}" + }"; } diff --git a/pkgs/common-updater/http-two-levels-updater.nix b/pkgs/common-updater/http-two-levels-updater.nix index 77594fc8a112ec..861f1c92ce8985 100644 --- a/pkgs/common-updater/http-two-levels-updater.nix +++ b/pkgs/common-updater/http-two-levels-updater.nix @@ -1,20 +1,33 @@ -{ lib -, genericUpdater -, common-updater-scripts +{ + lib, + genericUpdater, + common-updater-scripts, }: -{ pname ? null -, version ? null -, attrPath ? null -, allowedVersions ? "" -, ignoredVersions ? "" -, rev-prefix ? "" -, odd-unstable ? false -, patchlevel-unstable ? false -, url ? null +{ + pname ? null, + version ? null, + attrPath ? null, + allowedVersions ? "", + ignoredVersions ? "", + rev-prefix ? "", + odd-unstable ? false, + patchlevel-unstable ? false, + url ? null, }: genericUpdater { - inherit pname version attrPath allowedVersions ignoredVersions rev-prefix odd-unstable patchlevel-unstable; - versionLister = "${common-updater-scripts}/bin/list-archive-two-levels-versions ${lib.optionalString (url != null) "--url=${lib.escapeShellArg url}"}"; + inherit + pname + version + attrPath + allowedVersions + ignoredVersions + rev-prefix + odd-unstable + patchlevel-unstable + ; + versionLister = "${common-updater-scripts}/bin/list-archive-two-levels-versions ${ + lib.optionalString (url != null) "--url=${lib.escapeShellArg url}" + }"; } diff --git a/pkgs/common-updater/scripts.nix b/pkgs/common-updater/scripts.nix index d5ee3b58c504b2..c84eced0a007a3 100644 --- a/pkgs/common-updater/scripts.nix +++ b/pkgs/common-updater/scripts.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, makeWrapper -, coreutils -, diffutils -, git -, gnugrep -, gnused -, jq -, nix -, python3Packages +{ + lib, + stdenv, + makeWrapper, + coreutils, + diffutils, + git, + gnugrep, + gnused, + jq, + nix, + python3Packages, }: stdenv.mkDerivation { @@ -33,7 +34,17 @@ stdenv.mkDerivation { # wrap non python scripts for f in $out/bin/*; do if ! (head -n1 "$f" | grep -q '#!.*/env.*\(python\|pypy\)'); then - wrapProgram $f --prefix PATH : ${lib.makeBinPath [ coreutils diffutils git gnugrep gnused jq nix ]} + wrapProgram $f --prefix PATH : ${ + lib.makeBinPath [ + coreutils + diffutils + git + gnugrep + gnused + jq + nix + ] + } fi done diff --git a/pkgs/common-updater/unstable-updater.nix b/pkgs/common-updater/unstable-updater.nix index e6981f633534bb..9727fabd00969d 100644 --- a/pkgs/common-updater/unstable-updater.nix +++ b/pkgs/common-updater/unstable-updater.nix @@ -1,9 +1,10 @@ -{ lib -, writeShellApplication -, coreutils -, git -, nix -, common-updater-scripts +{ + lib, + writeShellApplication, + coreutils, + git, + nix, + common-updater-scripts, }: # This is an updater for unstable packages that should always use the latest @@ -12,16 +13,19 @@ # passthru.updateScript = unstableGitUpdater { }; # relevant attributes can be passed as below: -{ url ? null # The git url, if empty it will be set to src.gitRepoUrl -, branch ? null -, hardcodeZeroVersion ? false # Use a made-up version "0" instead of latest tag. Use when the project's tagging system is incompatible with what we expect from versions -, tagFormat ? "*" # A `git describe --tags --match ''` pattern that tags must match to be considered -, tagPrefix ? null # strip this prefix from a tag name -, tagConverter ? null # A command to convert more complex tag formats. It receives the git tag via stdin and should convert it into x.y.z format to stdout -, shallowClone ? true +{ + url ? null, # The git url, if empty it will be set to src.gitRepoUrl + branch ? null, + hardcodeZeroVersion ? false, # Use a made-up version "0" instead of latest tag. Use when the project's tagging system is incompatible with what we expect from versions + tagFormat ? "*", # A `git describe --tags --match ''` pattern that tags must match to be considered + tagPrefix ? null, # strip this prefix from a tag name + tagConverter ? null, # A command to convert more complex tag formats. It receives the git tag via stdin and should convert it into x.y.z format to stdout + shallowClone ? true, }: -assert lib.asserts.assertMsg (tagPrefix == null || tagConverter == null) "Can only use either tagPrefix or tagConverter!"; +assert lib.asserts.assertMsg ( + tagPrefix == null || tagConverter == null +) "Can only use either tagPrefix or tagConverter!"; let updateScript = writeShellApplication { @@ -162,14 +166,19 @@ in (lib.getExe updateScript) "--url=${builtins.toString url}" "--tag-format=${tagFormat}" -] ++ lib.optionals (branch != null) [ +] +++ lib.optionals (branch != null) [ "--branch=${branch}" -] ++ lib.optionals (tagPrefix != null) [ +] +++ lib.optionals (tagPrefix != null) [ "--tag-prefix=${tagPrefix}" -] ++ lib.optionals (tagConverter != null) [ +] +++ lib.optionals (tagConverter != null) [ "--tag-converter=${tagConverter}" -] ++ lib.optionals hardcodeZeroVersion [ +] +++ lib.optionals hardcodeZeroVersion [ "--hardcode-zero-version" -] ++ lib.optionals shallowClone [ +] +++ lib.optionals shallowClone [ "--shallow-clone" ] diff --git a/pkgs/data/documentation/zeal/default.nix b/pkgs/data/documentation/zeal/default.nix index bb65f91ee1c31c..44f0aee804d57c 100644 --- a/pkgs/data/documentation/zeal/default.nix +++ b/pkgs/data/documentation/zeal/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, pkg-config -, httplib -, qtbase -, qtimageformats -, qtwebengine -, qtx11extras -, libarchive -, libXdmcp -, libpthreadstubs -, wrapQtAppsHook -, xcbutilkeysyms +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + pkg-config, + httplib, + qtbase, + qtimageformats, + qtwebengine, + qtx11extras, + libarchive, + libXdmcp, + libpthreadstubs, + wrapQtAppsHook, + xcbutilkeysyms, }: let @@ -47,8 +48,7 @@ stdenv.mkDerivation (finalAttrs: { qtimageformats qtwebengine xcbutilkeysyms - ] - ++ lib.optionals isQt5 [ qtx11extras ]; + ] ++ lib.optionals isQt5 [ qtx11extras ]; cmakeFlags = [ (lib.cmakeBool "ZEAL_RELEASE_BUILD" true) @@ -63,7 +63,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://zealdocs.org/"; changelog = "https://github.com/zealdocs/zeal/releases/tag/v${finalAttrs.version}"; license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ peterhoeg AndersonTorres ]; + maintainers = with lib.maintainers; [ + peterhoeg + AndersonTorres + ]; mainProgram = "zeal"; inherit (qtbase.meta) platforms; }; diff --git a/pkgs/data/fonts/ankacoder/condensed.nix b/pkgs/data/fonts/ankacoder/condensed.nix index 891e0e3c0e0a79..ebcd69d68ee0f3 100644 --- a/pkgs/data/fonts/ankacoder/condensed.nix +++ b/pkgs/data/fonts/ankacoder/condensed.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "ankacoder-condensed"; @@ -27,4 +31,3 @@ stdenvNoCC.mkDerivation rec { platforms = platforms.all; }; } - diff --git a/pkgs/data/fonts/ankacoder/default.nix b/pkgs/data/fonts/ankacoder/default.nix index 12a953f72dcab6..f11a8dda67c5de 100644 --- a/pkgs/data/fonts/ankacoder/default.nix +++ b/pkgs/data/fonts/ankacoder/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "ankacoder"; diff --git a/pkgs/data/fonts/arphic/default.nix b/pkgs/data/fonts/arphic/default.nix index ed55855e4347de..e658dcb713ff30 100644 --- a/pkgs/data/fonts/arphic/default.nix +++ b/pkgs/data/fonts/arphic/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenvNoCC, fetchurl, mkfontdir, mkfontscale }: +{ + lib, + stdenvNoCC, + fetchurl, + mkfontdir, + mkfontscale, +}: let version = "0.2.20080216.2"; diff --git a/pkgs/data/fonts/catamaran/default.nix b/pkgs/data/fonts/catamaran/default.nix index 253f458bc4b600..1b66f827db9b6d 100644 --- a/pkgs/data/fonts/catamaran/default.nix +++ b/pkgs/data/fonts/catamaran/default.nix @@ -37,7 +37,6 @@ stdenvNoCC.mkDerivation rec { ''; license = licenses.ofl; platforms = platforms.all; - maintainers = with maintainers; [wyred50]; + maintainers = with maintainers; [ wyred50 ]; }; } - diff --git a/pkgs/data/fonts/dejavu-fonts/default.nix b/pkgs/data/fonts/dejavu-fonts/default.nix index 1fdb20ff3ced52..e7998696db04b3 100644 --- a/pkgs/data/fonts/dejavu-fonts/default.nix +++ b/pkgs/data/fonts/dejavu-fonts/default.nix @@ -1,4 +1,11 @@ -{ fetchFromGitHub, lib, stdenv, fontforge, perl, perlPackages }: +{ + fetchFromGitHub, + lib, + stdenv, + fontforge, + perl, + perlPackages, +}: let version = "2.37"; @@ -26,12 +33,17 @@ let full-ttf = stdenv.mkDerivation { pname = "dejavu-fonts-full"; inherit version; - nativeBuildInputs = [fontforge perl perlPackages.IOString perlPackages.FontTTF]; + nativeBuildInputs = [ + fontforge + perl + perlPackages.IOString + perlPackages.FontTTF + ]; src = fetchFromGitHub { owner = "dejavu-fonts"; repo = "dejavu-fonts"; - rev = "version_${lib.replaceStrings ["."] ["_"] version}"; + rev = "version_${lib.replaceStrings [ "." ] [ "_" ] version}"; sha256 = "1xknlg2h287dx34v2n5r33bpcl4biqf0cv7nak657rjki7s0k4bk"; }; @@ -52,7 +64,8 @@ let ''; inherit meta; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "dejavu-fonts"; inherit version; buildCommand = '' diff --git a/pkgs/data/fonts/emojione/default.nix b/pkgs/data/fonts/emojione/default.nix index 629e46fe79711f..d46325f6a81c74 100644 --- a/pkgs/data/fonts/emojione/default.nix +++ b/pkgs/data/fonts/emojione/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, inkscape, imagemagick, potrace, svgo, scfbuild }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + inkscape, + imagemagick, + potrace, + svgo, + scfbuild, +}: stdenv.mkDerivation rec { pname = "emojione"; @@ -33,7 +43,13 @@ stdenv.mkDerivation rec { export HOME="$NIX_BUILD_ROOT" ''; - nativeBuildInputs = [ inkscape imagemagick potrace svgo scfbuild ]; + nativeBuildInputs = [ + inkscape + imagemagick + potrace + svgo + scfbuild + ]; enableParallelBuilding = true; diff --git a/pkgs/data/fonts/fira-code/default.nix b/pkgs/data/fonts/fira-code/default.nix index 553a2d58098836..66ca9f0050a20c 100644 --- a/pkgs/data/fonts/fira-code/default.nix +++ b/pkgs/data/fonts/fira-code/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchzip, useVariableFont ? true }: +{ + lib, + stdenvNoCC, + fetchzip, + useVariableFont ? true, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "fira-code"; @@ -14,7 +19,9 @@ stdenvNoCC.mkDerivation (finalAttrs: { installPhase = '' runHook preInstall - install -Dm644 -t $out/share/fonts/truetype ${if useVariableFont then "variable_ttf/*-VF.ttf" else "ttf/*.ttf"} + install -Dm644 -t $out/share/fonts/truetype ${ + if useVariableFont then "variable_ttf/*-VF.ttf" else "ttf/*.ttf" + } runHook postInstall ''; diff --git a/pkgs/data/fonts/fira-code/symbols.nix b/pkgs/data/fonts/fira-code/symbols.nix index b31885b3714bb7..09c9fc8125909a 100644 --- a/pkgs/data/fonts/fira-code/symbols.nix +++ b/pkgs/data/fonts/fira-code/symbols.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation { pname = "fira-code-symbols"; diff --git a/pkgs/data/fonts/gdouros/default.nix b/pkgs/data/fonts/gdouros/default.nix index e407d5de6d85f6..9e47b342c86b07 100644 --- a/pkgs/data/fonts/gdouros/default.nix +++ b/pkgs/data/fonts/gdouros/default.nix @@ -1,46 +1,103 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let fonts = { - aegan = { version = "13.00"; file = "Aegean.zip"; hash = "sha256-3HmCqCMZLN6zF1N/EirQOPnHKTGHoc4aHKoZxFYTB34="; description = "Aegean"; }; - aegyptus = { version = "13.00"; file = "Aegyptus.zip"; hash = "sha256-SSAK707xhpsUTq8tSBcrzNGunCYad58amtCqAWuevnY="; description = "Egyptian Hieroglyphs, Coptic, Meroitic"; }; - akkadian = { version = "13.00"; file = "Akkadian.zip"; hash = "sha256-wXiDYyfujAs6fklOCqXq7Ms7wP5RbPlpNVwkUy7CV4k="; description = "Sumero-Akkadian Cuneiform"; }; - assyrian = { version = "13.00"; file = "Assyrian.zip"; hash = "sha256-CZj1sc89OexQ0INb7pbEu5GfE/w2E5JmhjT8cosoLSg="; description = "Neo-Assyrian in Unicode with OpenType"; }; - eemusic = { version = "13.00"; file = "EEMusic.zip"; hash = "sha256-LxOcQOPEImw0wosxJotbOJRbe0qlK5dR+kazuhm99Kg="; description = "Byzantine Musical Notation in Unicode with OpenType"; }; - maya = { version = "13.00"; file = "Maya%20Hieroglyphs.zip"; hash = "sha256-PAwF1lGqm6XVf4NQCA8AFLGU40N0Xsn5Q8x9ikHJDhY="; description = "Maya Hieroglyphs"; }; - symbola = { version = "13.00"; file = "Symbola.zip"; hash = "sha256-TsHWmzkEyMa8JOZDyjvk7PDhm239oH/FNllizNFf398="; description = "Basic Latin, Greek, Cyrillic and many Symbol blocks of Unicode"; }; - textfonts = { version = "13.00"; file = "Textfonts.zip"; hash = "sha256-7S3NiiyDvyYoDrLPt2z3P9bEEFOEZACv2sIHG1Tn6yI="; description = "Aroania, Anaktoria, Alexander, Avdira and Asea"; }; - unidings = { version = "13.00"; file = "Unidings.zip"; hash = "sha256-WUY+Ylphep6WuzqLQ3Owv+vK5Yuu/aAkn4GOFXL0uQY="; description = "Glyphs and Icons for blocks of The Unicode Standard"; }; + aegan = { + version = "13.00"; + file = "Aegean.zip"; + hash = "sha256-3HmCqCMZLN6zF1N/EirQOPnHKTGHoc4aHKoZxFYTB34="; + description = "Aegean"; + }; + aegyptus = { + version = "13.00"; + file = "Aegyptus.zip"; + hash = "sha256-SSAK707xhpsUTq8tSBcrzNGunCYad58amtCqAWuevnY="; + description = "Egyptian Hieroglyphs, Coptic, Meroitic"; + }; + akkadian = { + version = "13.00"; + file = "Akkadian.zip"; + hash = "sha256-wXiDYyfujAs6fklOCqXq7Ms7wP5RbPlpNVwkUy7CV4k="; + description = "Sumero-Akkadian Cuneiform"; + }; + assyrian = { + version = "13.00"; + file = "Assyrian.zip"; + hash = "sha256-CZj1sc89OexQ0INb7pbEu5GfE/w2E5JmhjT8cosoLSg="; + description = "Neo-Assyrian in Unicode with OpenType"; + }; + eemusic = { + version = "13.00"; + file = "EEMusic.zip"; + hash = "sha256-LxOcQOPEImw0wosxJotbOJRbe0qlK5dR+kazuhm99Kg="; + description = "Byzantine Musical Notation in Unicode with OpenType"; + }; + maya = { + version = "13.00"; + file = "Maya%20Hieroglyphs.zip"; + hash = "sha256-PAwF1lGqm6XVf4NQCA8AFLGU40N0Xsn5Q8x9ikHJDhY="; + description = "Maya Hieroglyphs"; + }; + symbola = { + version = "13.00"; + file = "Symbola.zip"; + hash = "sha256-TsHWmzkEyMa8JOZDyjvk7PDhm239oH/FNllizNFf398="; + description = "Basic Latin, Greek, Cyrillic and many Symbol blocks of Unicode"; + }; + textfonts = { + version = "13.00"; + file = "Textfonts.zip"; + hash = "sha256-7S3NiiyDvyYoDrLPt2z3P9bEEFOEZACv2sIHG1Tn6yI="; + description = "Aroania, Anaktoria, Alexander, Avdira and Asea"; + }; + unidings = { + version = "13.00"; + file = "Unidings.zip"; + hash = "sha256-WUY+Ylphep6WuzqLQ3Owv+vK5Yuu/aAkn4GOFXL0uQY="; + description = "Glyphs and Icons for blocks of The Unicode Standard"; + }; }; - mkpkg = pname: { version, file, hash, description }: stdenvNoCC.mkDerivation rec { - inherit pname version; + mkpkg = + pname: + { + version, + file, + hash, + description, + }: + stdenvNoCC.mkDerivation rec { + inherit pname version; - src = fetchzip { - url = "https://web.archive.org/web/20240212172059/https://dn-works.com/wp-content/uploads/2020/UFAS-Fonts/${file}"; - stripRoot = false; - inherit hash; - }; + src = fetchzip { + url = "https://web.archive.org/web/20240212172059/https://dn-works.com/wp-content/uploads/2020/UFAS-Fonts/${file}"; + stripRoot = false; + inherit hash; + }; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $out/share/{fonts/opentype,doc/${pname}} - mv *.otf -t "$out/share/fonts/opentype" - mv *.{odt,ods,pdf,xlsx} -t "$out/share/doc/${pname}" || true # install docs if any + mkdir -p $out/share/{fonts/opentype,doc/${pname}} + mv *.otf -t "$out/share/fonts/opentype" + mv *.{odt,ods,pdf,xlsx} -t "$out/share/doc/${pname}" || true # install docs if any - runHook postInstall - ''; + runHook postInstall + ''; - meta = { - inherit description; - # see https://web.archive.org/web/20240212172059/https://dn-works.com/wp-content/uploads/2020/UFAS-Docs/License.pdf - # quite draconian: non-commercial, no modifications, - # no redistribution, "a single instantiation and no - # network installation" - license = lib.licenses.unfree; - homepage = "https://web.archive.org/web/20240212172059/https://dn-works.com/ufas/"; + meta = { + inherit description; + # see https://web.archive.org/web/20240212172059/https://dn-works.com/wp-content/uploads/2020/UFAS-Docs/License.pdf + # quite draconian: non-commercial, no modifications, + # no redistribution, "a single instantiation and no + # network installation" + license = lib.licenses.unfree; + homepage = "https://web.archive.org/web/20240212172059/https://dn-works.com/ufas/"; + }; }; - }; in lib.mapAttrs mkpkg fonts diff --git a/pkgs/data/fonts/hackgen/default.nix b/pkgs/data/fonts/hackgen/default.nix index 14e9c22a571bf4..56e3af5976d096 100644 --- a/pkgs/data/fonts/hackgen/default.nix +++ b/pkgs/data/fonts/hackgen/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "hackgen-font"; diff --git a/pkgs/data/fonts/hackgen/nerdfont.nix b/pkgs/data/fonts/hackgen/nerdfont.nix index 7dfd028b25bf3f..187c34a8b653c8 100644 --- a/pkgs/data/fonts/hackgen/nerdfont.nix +++ b/pkgs/data/fonts/hackgen/nerdfont.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "hackgen-nf-font"; diff --git a/pkgs/data/fonts/inconsolata/default.nix b/pkgs/data/fonts/inconsolata/default.nix index 79431995a496c4..a2493ed2d22716 100644 --- a/pkgs/data/fonts/inconsolata/default.nix +++ b/pkgs/data/fonts/inconsolata/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "inconsolata"; @@ -18,7 +22,11 @@ stdenv.mkDerivation { meta = with lib; { homepage = "https://www.levien.com/type/myfonts/inconsolata.html"; description = "Monospace font for both screen and print"; - maintainers = with maintainers; [ appsforartists mikoim raskin ]; + maintainers = with maintainers; [ + appsforartists + mikoim + raskin + ]; license = licenses.ofl; platforms = platforms.all; }; diff --git a/pkgs/data/fonts/inconsolata/lgc.nix b/pkgs/data/fonts/inconsolata/lgc.nix index 945fafcfcc52aa..a32b0247cefdb1 100644 --- a/pkgs/data/fonts/inconsolata/lgc.nix +++ b/pkgs/data/fonts/inconsolata/lgc.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchFromGitHub, fontforge}: +{ + lib, + stdenv, + fetchFromGitHub, + fontforge, +}: stdenv.mkDerivation rec { pname = "inconsolata-lgc"; @@ -47,6 +52,9 @@ stdenv.mkDerivation rec { # See `License.txt' for details. license = licenses.ofl; homepage = "https://github.com/MihailJP/Inconsolata-LGC"; - maintainers = with maintainers; [ avnik rht ]; + maintainers = with maintainers; [ + avnik + rht + ]; }; } diff --git a/pkgs/data/fonts/input-fonts/default.nix b/pkgs/data/fonts/input-fonts/default.nix index dc990b6e42db7d..93d32978296778 100644 --- a/pkgs/data/fonts/input-fonts/default.nix +++ b/pkgs/data/fonts/input-fonts/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchzip -, python3 -, config -, acceptLicense ? config.input-fonts.acceptLicense or false -, parallel -, writeShellApplication +{ + lib, + stdenv, + fetchzip, + python3, + config, + acceptLicense ? config.input-fonts.acceptLicense or false, + parallel, + writeShellApplication, }: let @@ -47,28 +48,30 @@ stdenv.mkDerivation rec { stripRoot = false; # Reset the timestamp to release date for determinism. - postFetch = let - ttf-fixup = writeShellApplication { - name = "ttf-fixup"; - runtimeInputs = [ python3.pkgs.fonttools ]; - text = '' - if [ $# != 1 ]; then - echo "Usage: $0 : Resets timestamp on for determinism" >&2 - exit 1 - fi - - ttf_file="$1" - ttx_file=$(dirname "$ttf_file")/$(basename "$ttf_file" .ttf).ttx - ttx "$ttf_file" - rm "$ttf_file" - touch -m -t ${builtins.replaceStrings [ "-" ] [ "" ] releaseDate}0000 "$ttx_file" - ttx --recalc-timestamp "$ttx_file" - rm "$ttx_file" - ''; - }; - in '' - find $out/Input_Fonts -type f -name '*.ttf' -print0 | ${lib.getExe parallel} -0 -j $NIX_BUILD_CORES ${lib.getExe ttf-fixup} {} - ''; + postFetch = + let + ttf-fixup = writeShellApplication { + name = "ttf-fixup"; + runtimeInputs = [ python3.pkgs.fonttools ]; + text = '' + if [ $# != 1 ]; then + echo "Usage: $0 : Resets timestamp on for determinism" >&2 + exit 1 + fi + + ttf_file="$1" + ttx_file=$(dirname "$ttf_file")/$(basename "$ttf_file" .ttf).ttx + ttx "$ttf_file" + rm "$ttf_file" + touch -m -t ${builtins.replaceStrings [ "-" ] [ "" ] releaseDate}0000 "$ttx_file" + ttx --recalc-timestamp "$ttx_file" + rm "$ttx_file" + ''; + }; + in + '' + find $out/Input_Fonts -type f -name '*.ttf' -print0 | ${lib.getExe parallel} -0 -j $NIX_BUILD_CORES ${lib.getExe ttf-fixup} {} + ''; }; dontConfigure = true; diff --git a/pkgs/data/fonts/iosevka/comfy.nix b/pkgs/data/fonts/iosevka/comfy.nix index c920a5c677d60f..52974e657f9d95 100644 --- a/pkgs/data/fonts/iosevka/comfy.nix +++ b/pkgs/data/fonts/iosevka/comfy.nix @@ -1,22 +1,27 @@ -{ lib, iosevka, fetchFromGitHub, buildNpmPackage }: +{ + lib, + iosevka, + fetchFromGitHub, + buildNpmPackage, +}: let sets = [ # Family | Shapes | Spacing | Style | Ligatures | # ------------------------+--------+---------+------------+-----------| - "comfy" # | Sans | Compact | Monospaced | Yes | - "comfy-fixed" # | Sans | Compact | Monospaced | No | - "comfy-duo" # | Sans | Compact | Duospaced | Yes | + "comfy" # | Sans | Compact | Monospaced | Yes | + "comfy-fixed" # | Sans | Compact | Monospaced | No | + "comfy-duo" # | Sans | Compact | Duospaced | Yes | # ------------------------+--------+---------+------------+-----------| - "comfy-motion" # | Slab | Compact | Monospaced | Yes | - "comfy-motion-fixed" # | Slab | Compact | Monospaced | No | - "comfy-motion-duo" # | Slab | Compact | Duospaced | Yes | + "comfy-motion" # | Slab | Compact | Monospaced | Yes | + "comfy-motion-fixed" # | Slab | Compact | Monospaced | No | + "comfy-motion-duo" # | Slab | Compact | Duospaced | Yes | # ------------------------+--------+---------+------------+-----------| - "comfy-wide" # | Sans | Wide | Monospaced | Yes | - "comfy-wide-fixed" # | Sans | Wide | Monospaced | No | - "comfy-wide-duo" # | Sans | Wide | Duospaced | Yes | + "comfy-wide" # | Sans | Wide | Monospaced | Yes | + "comfy-wide-fixed" # | Sans | Wide | Monospaced | No | + "comfy-wide-duo" # | Sans | Wide | Duospaced | Yes | # ------------------------+--------+---------+------------+-----------| - "comfy-wide-motion" # | Slab | Wide | Monospaced | Yes | + "comfy-wide-motion" # | Slab | Wide | Monospaced | Yes | "comfy-wide-motion-fixed" # Slab | Wide | Monospaced | No | "comfy-wide-motion-duo" # | Slab | Wide | Duospaced | Yes | ]; @@ -28,41 +33,48 @@ let sha256 = "sha256-z9OlxeD88HuPJF88CsAy3vd1SFpJF1qh5c/0AIeMA7o="; }; privateBuildPlan = src.outPath + "/private-build-plans.toml"; - makeIosevkaFont = set: - let superBuildNpmPackage = buildNpmPackage; in + makeIosevkaFont = + set: + let + superBuildNpmPackage = buildNpmPackage; + in (iosevka.override { inherit set privateBuildPlan; - buildNpmPackage = args: superBuildNpmPackage - (args // { - pname = "iosevka-${set}"; - inherit version; + buildNpmPackage = + args: + superBuildNpmPackage ( + args + // { + pname = "iosevka-${set}"; + inherit version; - src = fetchFromGitHub { - owner = "be5invis"; - repo = "iosevka"; - rev = "v31.9.1"; - hash = "sha256-eAC4afBfHfiteYCzBNGFG2U/oCA7C5CdUlQVSO9Dg6E="; - }; + src = fetchFromGitHub { + owner = "be5invis"; + repo = "iosevka"; + rev = "v31.9.1"; + hash = "sha256-eAC4afBfHfiteYCzBNGFG2U/oCA7C5CdUlQVSO9Dg6E="; + }; - npmDepsHash = "sha256-xwGR21+CpZRFdZYz8SQrSf1tkp3fjGudoMmP5TGgEe8="; + npmDepsHash = "sha256-xwGR21+CpZRFdZYz8SQrSf1tkp3fjGudoMmP5TGgEe8="; - meta = with lib; { - inherit (src.meta) homepage; - description = '' - Customised build of the Iosevka typeface, with a consistent - rounded style and overrides for almost all individual glyphs - in both roman (upright) and italic (slanted) variants. - ''; - license = licenses.ofl; - platforms = iosevka.meta.platforms; - maintainers = [ maintainers.DamienCassou ]; - }; - }); + meta = with lib; { + inherit (src.meta) homepage; + description = '' + Customised build of the Iosevka typeface, with a consistent + rounded style and overrides for almost all individual glyphs + in both roman (upright) and italic (slanted) variants. + ''; + license = licenses.ofl; + platforms = iosevka.meta.platforms; + maintainers = [ maintainers.DamienCassou ]; + }; + } + ); }); in -builtins.listToAttrs (builtins.map - (set: { +builtins.listToAttrs ( + builtins.map (set: { name = set; value = makeIosevkaFont set; - }) - sets) + }) sets +) diff --git a/pkgs/data/fonts/iosevka/default.nix b/pkgs/data/fonts/iosevka/default.nix index ab55ea039d1560..842b241626417a 100644 --- a/pkgs/data/fonts/iosevka/default.nix +++ b/pkgs/data/fonts/iosevka/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, buildNpmPackage -, fetchFromGitHub -, cctools -, remarshal -, ttfautohint-nox +{ + stdenv, + lib, + buildNpmPackage, + fetchFromGitHub, + cctools, + remarshal, + ttfautohint-nox, # Custom font set options. # See https://typeof.net/Iosevka/customizer # Can be a raw TOML string, or a Nix attrset. @@ -34,7 +35,7 @@ # italic.i = "tailed"; # }; # } -, privateBuildPlan ? null + privateBuildPlan ? null, # Extra parameters. Can be used for ligature mapping. # It must be a raw TOML string. @@ -45,9 +46,9 @@ # featureTag = 'XHS0' # sequence = "+>" # ''; -, extraParameters ? null + extraParameters ? null, # Custom font set name. Required if any custom settings above. -, set ? null + set ? null, }: assert (privateBuildPlan != null) -> set != null; @@ -66,13 +67,15 @@ buildNpmPackage rec { npmDepsHash = "sha256-lBLz/BsSVh6szJxunoTj31oxB/3yqd1oWjSzTmQFGv8="; - nativeBuildInputs = [ - remarshal - ttfautohint-nox - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # libtool - cctools - ]; + nativeBuildInputs = + [ + remarshal + ttfautohint-nox + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # libtool + cctools + ]; buildPlan = if builtins.isAttrs privateBuildPlan then @@ -81,30 +84,34 @@ buildNpmPackage rec { privateBuildPlan; inherit extraParameters; - passAsFile = [ "extraParameters" ] ++ lib.optionals - ( - !(builtins.isString privateBuildPlan - && lib.hasPrefix builtins.storeDir privateBuildPlan) + passAsFile = + [ "extraParameters" ] + ++ lib.optionals ( + !(builtins.isString privateBuildPlan && lib.hasPrefix builtins.storeDir privateBuildPlan) ) [ "buildPlan" ]; configurePhase = '' - runHook preConfigure - ${lib.optionalString (builtins.isAttrs privateBuildPlan) '' - remarshal -i "$buildPlanPath" -o private-build-plans.toml -if json -of toml - ''} - ${lib.optionalString (builtins.isString privateBuildPlan - && (!lib.hasPrefix builtins.storeDir privateBuildPlan)) '' - cp "$buildPlanPath" private-build-plans.toml - ''} - ${lib.optionalString (builtins.isString privateBuildPlan - && (lib.hasPrefix builtins.storeDir privateBuildPlan)) '' - cp "$buildPlan" private-build-plans.toml - ''} - ${lib.optionalString (extraParameters != null) '' - echo -e "\n" >> params/parameters.toml - cat "$extraParametersPath" >> params/parameters.toml - ''} - runHook postConfigure + runHook preConfigure + ${lib.optionalString (builtins.isAttrs privateBuildPlan) '' + remarshal -i "$buildPlanPath" -o private-build-plans.toml -if json -of toml + ''} + ${lib.optionalString + (builtins.isString privateBuildPlan && (!lib.hasPrefix builtins.storeDir privateBuildPlan)) + '' + cp "$buildPlanPath" private-build-plans.toml + '' + } + ${lib.optionalString + (builtins.isString privateBuildPlan && (lib.hasPrefix builtins.storeDir privateBuildPlan)) + '' + cp "$buildPlan" private-build-plans.toml + '' + } + ${lib.optionalString (extraParameters != null) '' + echo -e "\n" >> params/parameters.toml + cat "$extraParametersPath" >> params/parameters.toml + ''} + runHook postConfigure ''; buildPhase = '' diff --git a/pkgs/data/fonts/joypixels/default.nix b/pkgs/data/fonts/joypixels/default.nix index 4cbf704bb86f42..a10092eecd5714 100644 --- a/pkgs/data/fonts/joypixels/default.nix +++ b/pkgs/data/fonts/joypixels/default.nix @@ -1,23 +1,27 @@ -{ lib, stdenv -, fetchurl -, config -, acceptLicense ? config.joypixels.acceptLicense or false +{ + lib, + stdenv, + fetchurl, + config, + acceptLicense ? config.joypixels.acceptLicense or false, }: let inherit (stdenv.hostPlatform.parsed) kernel; - systemSpecific = { - darwin = rec { - systemTag = "nix-darwin"; - capitalized = systemTag; - fontFile = "JoyPixels-SBIX.ttf"; + systemSpecific = + { + darwin = rec { + systemTag = "nix-darwin"; + capitalized = systemTag; + fontFile = "JoyPixels-SBIX.ttf"; + }; + } + .${kernel.name} or rec { + systemTag = "nixos"; + capitalized = "NixOS"; + fontFile = "joypixels-android.ttf"; }; - }.${kernel.name} or rec { - systemTag = "nixos"; - capitalized = "NixOS"; - fontFile = "joypixels-android.ttf"; - }; joypixels-free-license = with systemSpecific; { spdxId = "LicenseRef-JoyPixels-Free"; @@ -65,13 +69,17 @@ stdenv.mkDerivation rec { pname = "joypixels"; version = "9.0.0"; - src = assert !acceptLicense -> throwLicense; - with systemSpecific; fetchurl { + src = + assert !acceptLicense -> throwLicense; + with systemSpecific; + fetchurl { name = fontFile; url = "https://cdn.joypixels.com/distributions/${systemTag}/font/${version}/${fontFile}"; - sha256 = { - darwin = "sha256-muUxXzz8BePyPsiZocYvM0ebM1H+u84ysN5YUvsMLiU="; - }.${kernel.name} or "sha256-pmGsVgYSK/c5OlhOXhNlRBs/XppMXmsHcZeSmIkuED4="; + sha256 = + { + darwin = "sha256-muUxXzz8BePyPsiZocYvM0ebM1H+u84ysN5YUvsMLiU="; + } + .${kernel.name} or "sha256-pmGsVgYSK/c5OlhOXhNlRBs/XppMXmsHcZeSmIkuED4="; }; dontUnpack = true; @@ -93,12 +101,14 @@ stdenv.mkDerivation rec { available upon request). ''; homepage = "https://www.joypixels.com/fonts"; - hydraPlatforms = []; # Just a binary file download, nothing to cache. + hydraPlatforms = [ ]; # Just a binary file download, nothing to cache. license = let free-license = joypixels-free-license; appendix = joypixels-license-appendix; - in with systemSpecific; { + in + with systemSpecific; + { spdxId = "LicenseRef-JoyPixels-Free-with-${capitalized}-Appendix"; fullName = "${free-license.fullName} with ${appendix.fullName}"; url = free-license.url; @@ -106,7 +116,10 @@ stdenv.mkDerivation rec { free = false; redistributable = true; }; - maintainers = with maintainers; [ toonn jtojnar ]; + maintainers = with maintainers; [ + toonn + jtojnar + ]; # Not quite accurate since it's a font, not a program, but clearly # indicates we're not actually building it from source. sourceProvenance = [ sourceTypes.binaryNativeCode ]; diff --git a/pkgs/data/fonts/liberation-fonts/default.nix b/pkgs/data/fonts/liberation-fonts/default.nix index 0160ebfdc4500a..2e1e0e68cae37e 100644 --- a/pkgs/data/fonts/liberation-fonts/default.nix +++ b/pkgs/data/fonts/liberation-fonts/default.nix @@ -1,63 +1,90 @@ -{ lib, stdenv, fetchFromGitHub, fontforge, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + fontforge, + python3, +}: let inherit (python3.pkgs) fonttools; - commonNativeBuildInputs = [ fontforge python3 ]; + commonNativeBuildInputs = [ + fontforge + python3 + ]; common = - { version, repo, sha256, docsToInstall, nativeBuildInputs, postPatch ? null }: - stdenv.mkDerivation rec { - pname = "liberation-fonts"; - inherit version; + { + version, + repo, + sha256, + docsToInstall, + nativeBuildInputs, + postPatch ? null, + }: + stdenv.mkDerivation rec { + pname = "liberation-fonts"; + inherit version; - src = fetchFromGitHub { - owner = "liberationfonts"; - rev = version; - inherit repo sha256; - }; + src = fetchFromGitHub { + owner = "liberationfonts"; + rev = version; + inherit repo sha256; + }; - inherit nativeBuildInputs postPatch; + inherit nativeBuildInputs postPatch; - installPhase = '' - find . -name '*.ttf' -exec install -m444 -Dt $out/share/fonts/truetype {} \; + installPhase = '' + find . -name '*.ttf' -exec install -m444 -Dt $out/share/fonts/truetype {} \; - for i in ${toString docsToInstall}; do - # not all docs exist in all versions - install -m444 -Dt $out/share/doc/${pname}-${version} $i || true - done - ''; + for i in ${toString docsToInstall}; do + # not all docs exist in all versions + install -m444 -Dt $out/share/doc/${pname}-${version} $i || true + done + ''; - meta = with lib; { - description = "Liberation Fonts, replacements for Times New Roman, Arial, and Courier New"; - longDescription = '' - The Liberation Fonts are intended to be replacements for the three most - commonly used fonts on Microsoft systems: Times New Roman, Arial, and - Courier New. Since 2012 they are based on croscore fonts. + meta = with lib; { + description = "Liberation Fonts, replacements for Times New Roman, Arial, and Courier New"; + longDescription = '' + The Liberation Fonts are intended to be replacements for the three most + commonly used fonts on Microsoft systems: Times New Roman, Arial, and + Courier New. Since 2012 they are based on croscore fonts. - There are three sets: Sans (a substitute for Arial, Albany, Helvetica, - Nimbus Sans L, and Bitstream Vera Sans), Serif (a substitute for Times - New Roman, Thorndale, Nimbus Roman, and Bitstream Vera Serif) and Mono - (a substitute for Courier New, Cumberland, Courier, Nimbus Mono L, and - Bitstream Vera Sans Mono). - ''; + There are three sets: Sans (a substitute for Arial, Albany, Helvetica, + Nimbus Sans L, and Bitstream Vera Sans), Serif (a substitute for Times + New Roman, Thorndale, Nimbus Roman, and Bitstream Vera Serif) and Mono + (a substitute for Courier New, Cumberland, Courier, Nimbus Mono L, and + Bitstream Vera Sans Mono). + ''; - license = licenses.ofl; - homepage = "https://github.com/liberationfonts"; - maintainers = with maintainers; [ raskin ]; - }; + license = licenses.ofl; + homepage = "https://github.com/liberationfonts"; + maintainers = with maintainers; [ raskin ]; }; + }; in { liberation_ttf_v1 = common { repo = "liberation-1.7-fonts"; version = "1.07.5"; - docsToInstall = [ "AUTHORS" "ChangeLog" "COPYING" "License.txt" "README" ]; + docsToInstall = [ + "AUTHORS" + "ChangeLog" + "COPYING" + "License.txt" + "README" + ]; nativeBuildInputs = commonNativeBuildInputs; sha256 = "1ffl10mf78hx598sy9qr5m6q2b8n3mpnsj73bwixnd4985gsz56v"; }; liberation_ttf_v2 = common { repo = "liberation-fonts"; version = "2.1.5"; - docsToInstall = [ "AUTHORS" "ChangeLog" "LICENSE" "README.md" ]; + docsToInstall = [ + "AUTHORS" + "ChangeLog" + "LICENSE" + "README.md" + ]; nativeBuildInputs = commonNativeBuildInputs ++ [ fonttools ]; postPatch = '' substituteInPlace scripts/setisFixedPitch-fonttools.py --replace \ diff --git a/pkgs/data/fonts/lohit-fonts/default.nix b/pkgs/data/fonts/lohit-fonts/default.nix index 53bccc4a40a7ce..58c83ec56640ba 100644 --- a/pkgs/data/fonts/lohit-fonts/default.nix +++ b/pkgs/data/fonts/lohit-fonts/default.nix @@ -1,63 +1,144 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: let fonts = { - assamese = { label = "Assamese"; version = "2.91.5"; hash = "sha256-Oo/hHHFg/Nu3eaZLMdBclY90lKU2AMFUclyXHxGaAgg="; }; - bengali = { label = "Bengali"; version = "2.91.5"; hash = "sha256-QGf94TdQS2c9+wSSDK4Mknw5ubCGTuvg0xoNaJdirBc="; }; - devanagari = { label = "Devanagari script"; version = "2.95.4"; hash = "sha256-6CbOCqOei5eO1zwNQZvB+fFDkqxvJnK82z+zmClhRAE="; }; - gujarati = { label = "Gujarati"; version = "2.92.4"; hash = "sha256-BpwibF0/HXDvXpDEek0fj73cxo2QC1hSfQ49Q/ZOZg8="; }; - gurmukhi = { label = "Gurmukhi script"; version = "2.91.2"; hash = "sha256-5iLFW2FEE5LBqoALi+3sUjwC0ADntsp259TP+bYwR9g="; }; # renamed from Punjabi - kannada = { label = "Kannada"; version = "2.5.4" ; hash = "sha256-7y2u0tBdNYCeY7Y+aqhxXP7Qv6GglJeVO1wvM9CzyIQ="; }; - malayalam = { label = "Malayalam"; version = "2.92.2"; hash = "sha256-SzM38vuAlP9OMC8kUuHQylmH8TUjCeg1y/Zcu2I2bjA="; }; - marathi = { label = "Marathi"; version = "2.94.2"; hash = "sha256-jK1Gwcr5gqzRNkbIxs4V/OYgUlUEpU0OYzKDTkiMlqM="; }; - nepali = { label = "Nepali"; version = "2.94.2"; hash = "sha256-OX1ekxeSbVGOrdbZ3Jvu4nii0zkgbuij10JIzqRcFx4="; }; - odia = { label = "Odia"; version = "2.91.2"; hash = "sha256-3/eczBGGZj4QPs7KY0as9zk5HaBfhgz6YgU0qmwpVcA="; }; # renamed from Oriya - tamil-classical = { label = "Classical Tamil"; version = "2.5.4" ; hash = "sha256-6SsddTCEUHMoF7X4+i7eXimmMuktfFAl8uz95RwM+yg="; }; - tamil = { label = "Tamil"; version = "2.91.3"; hash = "sha256-8lcNw87o9lhQsKwCqwBSfx7rhcrH/eEqac7EsA9/w/E="; }; - telugu = { label = "Telugu"; version = "2.5.5" ; hash = "sha256-cZh93NfEB+5S1JeEowtBMJ0nbZsFGpbEp2WAtzxrA8A="; }; + assamese = { + label = "Assamese"; + version = "2.91.5"; + hash = "sha256-Oo/hHHFg/Nu3eaZLMdBclY90lKU2AMFUclyXHxGaAgg="; + }; + bengali = { + label = "Bengali"; + version = "2.91.5"; + hash = "sha256-QGf94TdQS2c9+wSSDK4Mknw5ubCGTuvg0xoNaJdirBc="; + }; + devanagari = { + label = "Devanagari script"; + version = "2.95.4"; + hash = "sha256-6CbOCqOei5eO1zwNQZvB+fFDkqxvJnK82z+zmClhRAE="; + }; + gujarati = { + label = "Gujarati"; + version = "2.92.4"; + hash = "sha256-BpwibF0/HXDvXpDEek0fj73cxo2QC1hSfQ49Q/ZOZg8="; + }; + gurmukhi = { + label = "Gurmukhi script"; + version = "2.91.2"; + hash = "sha256-5iLFW2FEE5LBqoALi+3sUjwC0ADntsp259TP+bYwR9g="; + }; # renamed from Punjabi + kannada = { + label = "Kannada"; + version = "2.5.4"; + hash = "sha256-7y2u0tBdNYCeY7Y+aqhxXP7Qv6GglJeVO1wvM9CzyIQ="; + }; + malayalam = { + label = "Malayalam"; + version = "2.92.2"; + hash = "sha256-SzM38vuAlP9OMC8kUuHQylmH8TUjCeg1y/Zcu2I2bjA="; + }; + marathi = { + label = "Marathi"; + version = "2.94.2"; + hash = "sha256-jK1Gwcr5gqzRNkbIxs4V/OYgUlUEpU0OYzKDTkiMlqM="; + }; + nepali = { + label = "Nepali"; + version = "2.94.2"; + hash = "sha256-OX1ekxeSbVGOrdbZ3Jvu4nii0zkgbuij10JIzqRcFx4="; + }; + odia = { + label = "Odia"; + version = "2.91.2"; + hash = "sha256-3/eczBGGZj4QPs7KY0as9zk5HaBfhgz6YgU0qmwpVcA="; + }; # renamed from Oriya + tamil-classical = { + label = "Classical Tamil"; + version = "2.5.4"; + hash = "sha256-6SsddTCEUHMoF7X4+i7eXimmMuktfFAl8uz95RwM+yg="; + }; + tamil = { + label = "Tamil"; + version = "2.91.3"; + hash = "sha256-8lcNw87o9lhQsKwCqwBSfx7rhcrH/eEqac7EsA9/w/E="; + }; + telugu = { + label = "Telugu"; + version = "2.5.5"; + hash = "sha256-cZh93NfEB+5S1JeEowtBMJ0nbZsFGpbEp2WAtzxrA8A="; + }; }; gplfonts = { # GPL fonts removed from later releases - kashmiri = { label = "Kashmiri"; version = "2.4.3" ; hash = "sha256-6T2QaWnt3+e5nr4vbk44FouqmeWKzia1lSf8S/bvqCs="; }; - konkani = { label = "Konkani"; version = "2.4.3" ; hash = "sha256-hVy2rxrUTPDeNnugi3Bk7z0JqGmk4/yeUsAoI/4R7A8="; }; - maithili = { label = "Maithili"; version = "2.4.3" ; hash = "sha256-ikDcpJqdizAYRpgoebzqxOEeodJ6C3fO2rsqGzC0HCs="; }; - sindhi = { label = "Sindhi"; version = "2.4.3" ; hash = "sha256-wU3B9fh+8E1bFBMnakzmajY7eNKzed9+eYL5AOxyNQI="; }; + kashmiri = { + label = "Kashmiri"; + version = "2.4.3"; + hash = "sha256-6T2QaWnt3+e5nr4vbk44FouqmeWKzia1lSf8S/bvqCs="; + }; + konkani = { + label = "Konkani"; + version = "2.4.3"; + hash = "sha256-hVy2rxrUTPDeNnugi3Bk7z0JqGmk4/yeUsAoI/4R7A8="; + }; + maithili = { + label = "Maithili"; + version = "2.4.3"; + hash = "sha256-ikDcpJqdizAYRpgoebzqxOEeodJ6C3fO2rsqGzC0HCs="; + }; + sindhi = { + label = "Sindhi"; + version = "2.4.3"; + hash = "sha256-wU3B9fh+8E1bFBMnakzmajY7eNKzed9+eYL5AOxyNQI="; + }; }; - mkpkg = license: pname: {label, version, hash}: stdenvNoCC.mkDerivation { - inherit pname version; + mkpkg = + license: pname: + { + label, + version, + hash, + }: + stdenvNoCC.mkDerivation { + inherit pname version; - src = fetchurl { - url = "https://releases.pagure.org/lohit/lohit-${pname}-ttf-${version}.tar.gz"; - inherit hash; - }; + src = fetchurl { + url = "https://releases.pagure.org/lohit/lohit-${pname}-ttf-${version}.tar.gz"; + inherit hash; + }; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $out/share/fonts/truetype - cp -v *.ttf $out/share/fonts/truetype/ + mkdir -p $out/share/fonts/truetype + cp -v *.ttf $out/share/fonts/truetype/ - mkdir -p $out/etc/fonts/conf.d - cp -v *.conf $out/etc/fonts/conf.d + mkdir -p $out/etc/fonts/conf.d + cp -v *.conf $out/etc/fonts/conf.d - mkdir -p "$out/share/doc/lohit-${pname}" - cp -v ChangeLog* COPYRIGHT* "$out/share/doc/lohit-${pname}/" + mkdir -p "$out/share/doc/lohit-${pname}" + cp -v ChangeLog* COPYRIGHT* "$out/share/doc/lohit-${pname}/" - runHook postInstall - ''; + runHook postInstall + ''; - meta = { - inherit license; - description = "Free and open source fonts for Indian languages (" + label + ")"; - homepage = "https://pagure.io/lohit"; - maintainers = [ lib.maintainers.mathnerd314 lib.maintainers.ttuegel ]; - # Set a non-zero priority to allow easy overriding of the - # fontconfig configuration files. - priority = 5; + meta = { + inherit license; + description = "Free and open source fonts for Indian languages (" + label + ")"; + homepage = "https://pagure.io/lohit"; + maintainers = [ + lib.maintainers.mathnerd314 + lib.maintainers.ttuegel + ]; + # Set a non-zero priority to allow easy overriding of the + # fontconfig configuration files. + priority = 5; + }; }; - }; in # Technically, GPLv2 with usage exceptions -lib.mapAttrs (mkpkg lib.licenses.gpl2) gplfonts // -lib.mapAttrs (mkpkg lib.licenses.ofl) fonts +lib.mapAttrs (mkpkg lib.licenses.gpl2) gplfonts // lib.mapAttrs (mkpkg lib.licenses.ofl) fonts diff --git a/pkgs/data/fonts/maple-font/default.nix b/pkgs/data/fonts/maple-font/default.nix index a90a1e830171c3..fbaeaa59a1a830 100644 --- a/pkgs/data/fonts/maple-font/default.nix +++ b/pkgs/data/fonts/maple-font/default.nix @@ -1,12 +1,18 @@ -{ lib -, stdenv -, unzip -, fetchurl +{ + lib, + stdenv, + unzip, + fetchurl, }: let - maple-font = { pname, sha256, desc }: - stdenv.mkDerivation rec{ + maple-font = + { + pname, + sha256, + desc, + }: + stdenv.mkDerivation rec { inherit pname; version = "6.4"; src = fetchurl { @@ -73,5 +79,3 @@ in desc = "ttf autohint"; }; } - - diff --git a/pkgs/data/fonts/mplus-outline-fonts/default.nix b/pkgs/data/fonts/mplus-outline-fonts/default.nix index 401295dda1b31d..9c2404822a82e3 100644 --- a/pkgs/data/fonts/mplus-outline-fonts/default.nix +++ b/pkgs/data/fonts/mplus-outline-fonts/default.nix @@ -1,6 +1,12 @@ -{ lib, stdenvNoCC, fetchurl, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchurl, + fetchFromGitHub, +}: -let pname = "mplus-outline-fonts"; +let + pname = "mplus-outline-fonts"; in { osdnRelease = stdenvNoCC.mkDerivation { diff --git a/pkgs/data/fonts/navilu/default.nix b/pkgs/data/fonts/navilu/default.nix index 8aaf36e60ed111..e796bebd3bf1df 100644 --- a/pkgs/data/fonts/navilu/default.nix +++ b/pkgs/data/fonts/navilu/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, fontforge }: +{ + lib, + stdenv, + fetchFromGitHub, + fontforge, +}: stdenv.mkDerivation rec { pname = "navilu-font"; @@ -19,10 +24,13 @@ stdenv.mkDerivation rec { installPhase = "install -Dm444 -t $out/share/fonts/truetype/ Navilu.ttf"; - meta = with lib; src.meta // { - description = "Kannada handwriting font"; - license = licenses.gpl3Plus; - platforms = platforms.all; - maintainers = with maintainers; [ ehmry ]; - }; + meta = + with lib; + src.meta + // { + description = "Kannada handwriting font"; + license = licenses.gpl3Plus; + platforms = platforms.all; + maintainers = with maintainers; [ ehmry ]; + }; } diff --git a/pkgs/data/fonts/openmoji/default.nix b/pkgs/data/fonts/openmoji/default.nix index 3f19bbe91f3383..7fee65331d13a3 100644 --- a/pkgs/data/fonts/openmoji/default.nix +++ b/pkgs/data/fonts/openmoji/default.nix @@ -1,27 +1,44 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, nanoemoji -, python3Packages -, woff2 -, xmlstarlet +{ + lib, + stdenvNoCC, + fetchFromGitHub, + nanoemoji, + python3Packages, + woff2, + xmlstarlet, # available color formats: ["cbdt" "glyf_colr_0" "glyf_colr_1" "sbix" "picosvgz" "untouchedsvgz"] # available black formats: ["glyf"] -, fontFormats ? [ "glyf" "cbdt" "glyf_colr_0" "glyf_colr_1" ] + fontFormats ? [ + "glyf" + "cbdt" + "glyf_colr_0" + "glyf_colr_1" + ], # when at least one of the glyf_colr_0/1 formats is specified, whether to build maximum color fonts # "none" to not build any, "svg" to build colr+svg, "bitmap" to build cbdt+colr+svg fonts -, buildMaximumColorFonts ? "bitmap" + buildMaximumColorFonts ? "bitmap", }: let # all available methods methods = { black = [ "glyf" ]; - color = [ "cbdt" "glyf_colr_0" "glyf_colr_1" "sbix" "picosvgz" "untouchedsvgz" ]; + color = [ + "cbdt" + "glyf_colr_0" + "glyf_colr_1" + "sbix" + "picosvgz" + "untouchedsvgz" + ]; }; in assert lib.asserts.assertEachOneOf "fontFormats" fontFormats (methods.black ++ methods.color); -assert lib.asserts.assertOneOf "buildMaximumColorFonts" buildMaximumColorFonts [ "none" "bitmap" "svg" ]; +assert lib.asserts.assertOneOf "buildMaximumColorFonts" buildMaximumColorFonts [ + "none" + "bitmap" + "svg" +]; stdenvNoCC.mkDerivation rec { pname = "openmoji"; @@ -48,7 +65,9 @@ stdenvNoCC.mkDerivation rec { methods_black = builtins.filter (m: builtins.elem m fontFormats) methods.black; methods_color = builtins.filter (m: builtins.elem m fontFormats) methods.color; - saturations = lib.optional (methods_black != [ ]) "black" ++ lib.optional (methods_color != [ ]) "color"; + saturations = + lib.optional (methods_black != [ ]) "black" + ++ lib.optional (methods_color != [ ]) "color"; maximumColorVersions = lib.optionals (buildMaximumColorFonts != "none") ( lib.optional (builtins.elem "glyf_colr_0" fontFormats) "0" ++ lib.optional (builtins.elem "glyf_colr_1" fontFormats) "1" @@ -79,7 +98,10 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { license = licenses.cc-by-sa-40; - maintainers = with maintainers; [ _999eagle fgaz ]; + maintainers = with maintainers; [ + _999eagle + fgaz + ]; platforms = platforms.all; homepage = "https://openmoji.org/"; downloadPage = "https://github.com/hfg-gmuend/openmoji/releases"; diff --git a/pkgs/data/fonts/paratype-pt/mono.nix b/pkgs/data/fonts/paratype-pt/mono.nix index 91132642b2a7d7..f42b680b174f83 100644 --- a/pkgs/data/fonts/paratype-pt/mono.nix +++ b/pkgs/data/fonts/paratype-pt/mono.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "paratype-pt-mono"; diff --git a/pkgs/data/fonts/paratype-pt/sans.nix b/pkgs/data/fonts/paratype-pt/sans.nix index 90d90a56d454df..ee5dbaa08811ad 100644 --- a/pkgs/data/fonts/paratype-pt/sans.nix +++ b/pkgs/data/fonts/paratype-pt/sans.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "paratype-pt-sans"; diff --git a/pkgs/data/fonts/paratype-pt/serif.nix b/pkgs/data/fonts/paratype-pt/serif.nix index 4430d94cd7f150..cd825742c71c37 100644 --- a/pkgs/data/fonts/paratype-pt/serif.nix +++ b/pkgs/data/fonts/paratype-pt/serif.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: stdenvNoCC.mkDerivation rec { pname = "paratype-pt-serif"; diff --git a/pkgs/data/fonts/pretendard/default.nix b/pkgs/data/fonts/pretendard/default.nix index b01b298879cf39..b51de3cfd627ec 100644 --- a/pkgs/data/fonts/pretendard/default.nix +++ b/pkgs/data/fonts/pretendard/default.nix @@ -1,9 +1,18 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let version = "1.3.9"; - mkPretendard = { pname, typeface, hash }: + mkPretendard = + { + pname, + typeface, + hash, + }: stdenvNoCC.mkDerivation { inherit pname version; diff --git a/pkgs/data/fonts/profont/default.nix b/pkgs/data/fonts/profont/default.nix index a617d61cc98fa5..ed264c41f247be 100644 --- a/pkgs/data/fonts/profont/default.nix +++ b/pkgs/data/fonts/profont/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchzip, xorg }: +{ + lib, + stdenv, + fetchzip, + xorg, +}: stdenv.mkDerivation { pname = "profont"; @@ -6,17 +11,21 @@ stdenv.mkDerivation { # Note: stripRoot doesn't work because the archive # contains the metadata directory `__MACOSX`. - src = fetchzip { - url = "https://tobiasjung.name/downloadfile.php?file=profont-x11.zip"; - sha256 = "12dbm87wvcpmn7nzgzwlk45cybp091diara8blqm6129ps27z6kb"; - stripRoot = false; - } + /profont-x11; - - srcOtb = fetchzip { - url = "https://tobiasjung.name/downloadfile.php?file=profont-otb.zip"; - sha256 = "18rfhfqrsj3510by0w1a7ak5as6r2cxh8xv02xc1y30mfa6g24x6"; - stripRoot = false; - } + /profont-otb; + src = + fetchzip { + url = "https://tobiasjung.name/downloadfile.php?file=profont-x11.zip"; + sha256 = "12dbm87wvcpmn7nzgzwlk45cybp091diara8blqm6129ps27z6kb"; + stripRoot = false; + } + + /profont-x11; + + srcOtb = + fetchzip { + url = "https://tobiasjung.name/downloadfile.php?file=profont-otb.zip"; + sha256 = "18rfhfqrsj3510by0w1a7ak5as6r2cxh8xv02xc1y30mfa6g24x6"; + stripRoot = false; + } + + /profont-otb; dontBuild = true; diff --git a/pkgs/data/fonts/scheherazade/default.nix b/pkgs/data/fonts/scheherazade/default.nix index 0ef80fb9ef99f1..20381b9ad63dd2 100644 --- a/pkgs/data/fonts/scheherazade/default.nix +++ b/pkgs/data/fonts/scheherazade/default.nix @@ -1,13 +1,20 @@ -{ lib, stdenvNoCC, fetchzip, version ? "4.300" }: +{ + lib, + stdenvNoCC, + fetchzip, + version ? "4.300", +}: let new = lib.versionAtLeast version "3.000"; - hash = { - "2.100" = "sha256-d2UyOOOnmE1afCwyIrM1bL3lQC7XRwh03hzetk/4V30="; - "3.300" = "sha256-LaaA6DWAE2dcwVVX4go9cJaiuwI6efYbPk82ym3W3IY="; - "4.000" = "sha256-FhgHlHCfojIl3Y11EDYhNTmLYwQ60OrwnA9nbZbZGJE="; - "4.300" = "sha256-djUZyBJaX6cFG4SYn+HIldNhRQ4Hg+Jt3uDfYzo9H5o="; - }."${version}"; + hash = + { + "2.100" = "sha256-d2UyOOOnmE1afCwyIrM1bL3lQC7XRwh03hzetk/4V30="; + "3.300" = "sha256-LaaA6DWAE2dcwVVX4go9cJaiuwI6efYbPk82ym3W3IY="; + "4.000" = "sha256-FhgHlHCfojIl3Y11EDYhNTmLYwQ60OrwnA9nbZbZGJE="; + "4.300" = "sha256-djUZyBJaX6cFG4SYn+HIldNhRQ4Hg+Jt3uDfYzo9H5o="; + } + ."${version}"; pname = "scheherazade${lib.optionalString new "-new"}"; in stdenvNoCC.mkDerivation rec { diff --git a/pkgs/data/fonts/source-han/default.nix b/pkgs/data/fonts/source-han/default.nix index 2f177160da991c..a9bed1b2a12fb0 100644 --- a/pkgs/data/fonts/source-han/default.nix +++ b/pkgs/data/fonts/source-han/default.nix @@ -1,22 +1,22 @@ -{ lib -, stdenvNoCC -, fetchurl -, unzip +{ + lib, + stdenvNoCC, + fetchurl, + unzip, }: let makeSuperOTC = - { family - , description - , rev - , hash - , zip ? "" - , prefix ? "" + { + family, + description, + rev, + hash, + zip ? "", + prefix ? "", }: let - Family = - lib.toUpper (lib.substring 0 1 family) + - lib.substring 1 (lib.stringLength family) family; + Family = lib.toUpper (lib.substring 0 1 family) + lib.substring 1 (lib.stringLength family) family; in stdenvNoCC.mkDerivation rec { pname = "source-han-${family}"; @@ -29,11 +29,13 @@ let nativeBuildInputs = lib.optionals (zip == ".zip") [ unzip ]; - unpackPhase = lib.optionalString (zip == "") '' - cp $src SourceHan${Family}.ttc${zip} - '' + lib.optionalString (zip == ".zip") '' - unzip $src - ''; + unpackPhase = + lib.optionalString (zip == "") '' + cp $src SourceHan${Family}.ttc${zip} + '' + + lib.optionalString (zip == ".zip") '' + unzip $src + ''; installPhase = '' runHook preInstall @@ -47,20 +49,22 @@ let description = "Open source Pan-CJK ${description} typeface"; homepage = "https://github.com/adobe-fonts/source-han-${family}"; license = lib.licenses.ofl; - maintainers = with lib.maintainers; [ taku0 emily ]; + maintainers = with lib.maintainers; [ + taku0 + emily + ]; }; }; makeVariable = - { family - , version - , hash - , format + { + family, + version, + hash, + format, }: let - Family = - lib.toUpper (lib.substring 0 1 family) + - lib.substring 1 (lib.stringLength family) family; + Family = lib.toUpper (lib.substring 0 1 family) + lib.substring 1 (lib.stringLength family) family; in fetchurl { pname = "source-han-${family}-vf-${format}"; @@ -74,7 +78,10 @@ let description = "Open source Pan-CJK ${Family} typeface"; homepage = "https://github.com/adobe-fonts/source-han-${family}"; license = lib.licenses.ofl; - maintainers = with lib.maintainers; [ taku0 emily ]; + maintainers = with lib.maintainers; [ + taku0 + emily + ]; }; }; in diff --git a/pkgs/data/fonts/tai-languages/default.nix b/pkgs/data/fonts/tai-languages/default.nix index 4e4c689b6ac6db..97acb492061072 100644 --- a/pkgs/data/fonts/tai-languages/default.nix +++ b/pkgs/data/fonts/tai-languages/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: { tai-ahom = stdenvNoCC.mkDerivation rec { diff --git a/pkgs/data/fonts/tex-gyre-math/default.nix b/pkgs/data/fonts/tex-gyre-math/default.nix index 95038d3f9cfe6c..fbed169a7e0391 100644 --- a/pkgs/data/fonts/tex-gyre-math/default.nix +++ b/pkgs/data/fonts/tex-gyre-math/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: let variants = { @@ -28,8 +32,17 @@ let }; }; - mkVariant = variant: {displayName, version, sha256, outputHash}: - let dotless_version = builtins.replaceStrings ["."] [""] version; in + mkVariant = + variant: + { + displayName, + version, + sha256, + outputHash, + }: + let + dotless_version = builtins.replaceStrings [ "." ] [ "" ] version; + in stdenv.mkDerivation rec { name = "tex-gyre-${variant}-math-${version}"; inherit version; @@ -64,4 +77,4 @@ let }; }; in - lib.mapAttrs mkVariant variants +lib.mapAttrs mkVariant variants diff --git a/pkgs/data/fonts/tex-gyre/default.nix b/pkgs/data/fonts/tex-gyre/default.nix index a93beaccb0714b..a0b7b01cff6bea 100644 --- a/pkgs/data/fonts/tex-gyre/default.nix +++ b/pkgs/data/fonts/tex-gyre/default.nix @@ -1,38 +1,51 @@ -{ lib, stdenv, fetchzip }: +{ + lib, + stdenv, + fetchzip, +}: let - mkVariant = variant: { version, abbreviation, sha256, outputHash }: stdenv.mkDerivation { - name = "tex-gyre-${variant}-${version}"; - inherit version; + mkVariant = + variant: + { + version, + abbreviation, + sha256, + outputHash, + }: + stdenv.mkDerivation { + name = "tex-gyre-${variant}-${version}"; + inherit version; - src = fetchzip { - url = "http://www.gust.org.pl/projects/e-foundry/tex-gyre/${variant}/${abbreviation}${version}otf.zip"; - stripRoot = false; - inherit sha256; - }; + src = fetchzip { + url = "http://www.gust.org.pl/projects/e-foundry/tex-gyre/${variant}/${abbreviation}${version}otf.zip"; + stripRoot = false; + inherit sha256; + }; - installPhase = '' - mkdir -p $out/share/fonts/opentype/ - # Pagella & Adventor are not flat archives - test -d "${abbreviation}${version}otf" && cd "${abbreviation}${version}otf" - cp -v *.otf $out/share/fonts/opentype/ - ''; + installPhase = '' + mkdir -p $out/share/fonts/opentype/ + # Pagella & Adventor are not flat archives + test -d "${abbreviation}${version}otf" && cd "${abbreviation}${version}otf" + cp -v *.otf $out/share/fonts/opentype/ + ''; - outputHashAlgo = "sha256"; - outputHashMode = "recursive"; - inherit outputHash; + outputHashAlgo = "sha256"; + outputHashMode = "recursive"; + inherit outputHash; - meta = with lib; { - homepage = "http://www.gust.org.pl/projects/e-foundry/tex-gyre"; - # "The TeX Gyre fonts are licensed under the GUST Font License (GFL), - # which is a free license, legally equivalent to the LaTeX Project Public - # License (LPPL), version 1.3c or later." - GUST website - license = licenses.lppl13c; - maintainers = [ ]; - platforms = platforms.all; + meta = with lib; { + homepage = "http://www.gust.org.pl/projects/e-foundry/tex-gyre"; + # "The TeX Gyre fonts are licensed under the GUST Font License (GFL), + # which is a free license, legally equivalent to the LaTeX Project Public + # License (LPPL), version 1.3c or later." - GUST website + license = licenses.lppl13c; + maintainers = [ ]; + platforms = platforms.all; + }; }; - }; -in lib.mapAttrs mkVariant { +in +lib.mapAttrs mkVariant { adventor = { version = "2_501"; sha256 = "0qjg3x0adfppyx3x33cm07ww9i9sl88xaq07m7wfip8rmyp567fn"; @@ -64,7 +77,7 @@ in lib.mapAttrs mkVariant { abbreviation = "qhv"; }; pagella = { - version ="2_501"; + version = "2_501"; sha256 = "1kccaxs3vk93la2pz4nv05hx1x3diyla49cz4l33zifdcp2zgg9d"; outputHash = "1nnjsgplimh29502pkd19rvfg93x31svxxmx4x7h51njrx1j8qa8"; abbreviation = "qpl"; diff --git a/pkgs/data/icons/beauty-line-icon-theme/default.nix b/pkgs/data/icons/beauty-line-icon-theme/default.nix index c46eddf5c356c3..d1bea8dfd6bdfa 100644 --- a/pkgs/data/icons/beauty-line-icon-theme/default.nix +++ b/pkgs/data/icons/beauty-line-icon-theme/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, breeze-icons -, gtk3 -, gnome-icon-theme -, hicolor-icon-theme -, mint-x-icons -, pantheon -, jdupes +{ + lib, + stdenvNoCC, + fetchFromGitHub, + breeze-icons, + gtk3, + gnome-icon-theme, + hicolor-icon-theme, + mint-x-icons, + pantheon, + jdupes, }: stdenvNoCC.mkDerivation rec { @@ -26,7 +27,10 @@ stdenvNoCC.mkDerivation rec { sourceRoot = "${src.name}/BeautyLine-V3"; - nativeBuildInputs = [ jdupes gtk3 ]; + nativeBuildInputs = [ + jdupes + gtk3 + ]; # ubuntu-mono is also required but missing in ubuntu-themes (please add it if it is packaged at some point) propagatedBuildInputs = [ diff --git a/pkgs/data/icons/bibata-cursors/translucent.nix b/pkgs/data/icons/bibata-cursors/translucent.nix index 7cae52a3e4de85..ac7e8c2ce67784 100644 --- a/pkgs/data/icons/bibata-cursors/translucent.nix +++ b/pkgs/data/icons/bibata-cursors/translucent.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, fetchFromGitHub }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, +}: stdenvNoCC.mkDerivation rec { pname = "bibata-cursors-translucent"; diff --git a/pkgs/data/icons/flat-remix-icon-theme/default.nix b/pkgs/data/icons/flat-remix-icon-theme/default.nix index d8d36e6a8ee374..ad9d166a5a6b27 100644 --- a/pkgs/data/icons/flat-remix-icon-theme/default.nix +++ b/pkgs/data/icons/flat-remix-icon-theme/default.nix @@ -1,6 +1,15 @@ -{ lib, stdenvNoCC, fetchFromGitHub, gtk3, breeze-icons, pantheon, gnome-icon-theme, hicolor-icon-theme }: - -stdenvNoCC.mkDerivation rec { +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + breeze-icons, + pantheon, + gnome-icon-theme, + hicolor-icon-theme, +}: + +stdenvNoCC.mkDerivation rec { pname = "flat-remix-icon-theme"; version = "20240201"; diff --git a/pkgs/data/icons/gruvbox-dark-icons-gtk/default.nix b/pkgs/data/icons/gruvbox-dark-icons-gtk/default.nix index 972b5dfba56254..ad03691639dacf 100644 --- a/pkgs/data/icons/gruvbox-dark-icons-gtk/default.nix +++ b/pkgs/data/icons/gruvbox-dark-icons-gtk/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenvNoCC, fetchFromGitHub, gtk3, breeze-icons, gnome-icon-theme, hicolor-icon-theme }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + breeze-icons, + gnome-icon-theme, + hicolor-icon-theme, +}: stdenvNoCC.mkDerivation rec { pname = "gruvbox-dark-icons-gtk"; @@ -13,7 +21,11 @@ stdenvNoCC.mkDerivation rec { nativeBuildInputs = [ gtk3 ]; - propagatedBuildInputs = [ breeze-icons gnome-icon-theme hicolor-icon-theme ]; + propagatedBuildInputs = [ + breeze-icons + gnome-icon-theme + hicolor-icon-theme + ]; installPhase = '' mkdir -p $out/share/icons/oomox-gruvbox-dark diff --git a/pkgs/data/icons/la-capitaine-icon-theme/default.nix b/pkgs/data/icons/la-capitaine-icon-theme/default.nix index 01e2a3ea478120..6b215636bffbe2 100644 --- a/pkgs/data/icons/la-capitaine-icon-theme/default.nix +++ b/pkgs/data/icons/la-capitaine-icon-theme/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, breeze-icons -, elementary-icon-theme -, gnome-icon-theme -, hicolor-icon-theme +{ + lib, + stdenvNoCC, + fetchFromGitHub, + breeze-icons, + elementary-icon-theme, + gnome-icon-theme, + hicolor-icon-theme, }: stdenvNoCC.mkDerivation rec { @@ -45,7 +46,10 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { description = "Icon theme inspired by macOS and Google's Material Design"; homepage = "https://github.com/keeferrourke/la-capitaine-icon-theme"; - license = with licenses; [ gpl3Plus mit ]; + license = with licenses; [ + gpl3Plus + mit + ]; platforms = platforms.linux; maintainers = with maintainers; [ romildo ]; }; diff --git a/pkgs/data/icons/maia-icon-theme/default.nix b/pkgs/data/icons/maia-icon-theme/default.nix index 32365b70184bec..e0558ce70c38b8 100644 --- a/pkgs/data/icons/maia-icon-theme/default.nix +++ b/pkgs/data/icons/maia-icon-theme/default.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitLab -, cmake -, extra-cmake-modules -, gtk3 -, plasma-framework -, kwindowsystem -, hicolor-icon-theme +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + extra-cmake-modules, + gtk3, + plasma-framework, + kwindowsystem, + hicolor-icon-theme, }: stdenv.mkDerivation { diff --git a/pkgs/data/icons/numix-icon-theme/default.nix b/pkgs/data/icons/numix-icon-theme/default.nix index 88d2240408552c..79333e3da20e00 100644 --- a/pkgs/data/icons/numix-icon-theme/default.nix +++ b/pkgs/data/icons/numix-icon-theme/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gtk3 -, adwaita-icon-theme -, breeze-icons -, gnome-icon-theme -, hicolor-icon-theme -, gitUpdater +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + adwaita-icon-theme, + breeze-icons, + gnome-icon-theme, + hicolor-icon-theme, + gitUpdater, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/data/icons/papirus-icon-theme/default.nix b/pkgs/data/icons/papirus-icon-theme/default.nix index fd1603e08d28a7..22898dd77162bf 100644 --- a/pkgs/data/icons/papirus-icon-theme/default.nix +++ b/pkgs/data/icons/papirus-icon-theme/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gtk3 -, breeze-icons -, elementary-icon-theme -, hicolor-icon-theme -, papirus-folders -, color ? null -, withElementary ? false -, gitUpdater +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + breeze-icons, + elementary-icon-theme, + hicolor-icon-theme, + papirus-folders, + color ? null, + withElementary ? false, + gitUpdater, }: stdenvNoCC.mkDerivation rec { @@ -27,12 +28,14 @@ stdenvNoCC.mkDerivation rec { papirus-folders ]; - propagatedBuildInputs = [ - breeze-icons - hicolor-icon-theme - ] ++ lib.optional withElementary [ - elementary-icon-theme - ]; + propagatedBuildInputs = + [ + breeze-icons + hicolor-icon-theme + ] + ++ lib.optional withElementary [ + elementary-icon-theme + ]; dontDropIconThemeCache = true; @@ -43,7 +46,9 @@ stdenvNoCC.mkDerivation rec { mv ${lib.optionalString withElementary "{,e}"}Papirus* $out/share/icons for theme in $out/share/icons/*; do - ${lib.optionalString (color != null) "${papirus-folders}/bin/papirus-folders -t $theme -o -C ${color}"} + ${lib.optionalString ( + color != null + ) "${papirus-folders}/bin/papirus-folders -t $theme -o -C ${color}"} gtk-update-icon-cache --force $theme done @@ -58,6 +63,9 @@ stdenvNoCC.mkDerivation rec { license = licenses.gpl3Only; # darwin gives hash mismatch in source, probably because of file names differing only in case platforms = platforms.linux; - maintainers = with maintainers; [ romildo moni ]; + maintainers = with maintainers; [ + romildo + moni + ]; }; } diff --git a/pkgs/data/icons/papirus-maia-icon-theme/default.nix b/pkgs/data/icons/papirus-maia-icon-theme/default.nix index 814d9ced017bc9..3375f5668da876 100644 --- a/pkgs/data/icons/papirus-maia-icon-theme/default.nix +++ b/pkgs/data/icons/papirus-maia-icon-theme/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, gtk3, breeze-icons, gnome-icon-theme, papirus-icon-theme, hicolor-icon-theme }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gtk3, + breeze-icons, + gnome-icon-theme, + papirus-icon-theme, + hicolor-icon-theme, +}: stdenv.mkDerivation rec { pname = "papirus-maia-icon-theme"; diff --git a/pkgs/data/icons/tango-icon-theme/default.nix b/pkgs/data/icons/tango-icon-theme/default.nix index cd981421396f7c..6d4da143a828df 100644 --- a/pkgs/data/icons/tango-icon-theme/default.nix +++ b/pkgs/data/icons/tango-icon-theme/default.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchurl, intltool, pkg-config, iconnamingutils, imagemagick, librsvg -, gtk/*any version*/, gnome-icon-theme, hicolor-icon-theme +{ + lib, + stdenv, + fetchurl, + intltool, + pkg-config, + iconnamingutils, + imagemagick, + librsvg, + gtk, # any version + gnome-icon-theme, + hicolor-icon-theme, }: stdenv.mkDerivation rec { @@ -13,9 +23,19 @@ stdenv.mkDerivation rec { patches = [ ./rsvg-convert.patch ]; - nativeBuildInputs = [ pkg-config intltool ]; - buildInputs = [ iconnamingutils imagemagick librsvg ]; - propagatedBuildInputs = [ gnome-icon-theme hicolor-icon-theme ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; + buildInputs = [ + iconnamingutils + imagemagick + librsvg + ]; + propagatedBuildInputs = [ + gnome-icon-theme + hicolor-icon-theme + ]; # still missing parent icon themes: cristalsvg dontDropIconThemeCache = true; diff --git a/pkgs/data/icons/tela-circle-icon-theme/default.nix b/pkgs/data/icons/tela-circle-icon-theme/default.nix index f9fa03f0aa5bcc..db58831f062408 100644 --- a/pkgs/data/icons/tela-circle-icon-theme/default.nix +++ b/pkgs/data/icons/tela-circle-icon-theme/default.nix @@ -1,74 +1,94 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, adwaita-icon-theme -, breeze-icons -, gtk3 -, hicolor-icon-theme -, jdupes -, gitUpdater -, allColorVariants ? false -, circularFolder ? false -, colorVariants ? [] # default is standard +{ + lib, + stdenvNoCC, + fetchFromGitHub, + adwaita-icon-theme, + breeze-icons, + gtk3, + hicolor-icon-theme, + jdupes, + gitUpdater, + allColorVariants ? false, + circularFolder ? false, + colorVariants ? [ ], # default is standard }: let pname = "tela-circle-icon-theme"; in -lib.checkListOfEnum "${pname}: color variants" [ "standard" "black" "blue" "brown" "green" "grey" "orange" "pink" "purple" "red" "yellow" "manjaro" "ubuntu" "dracula" "nord" ] colorVariants +lib.checkListOfEnum "${pname}: color variants" + [ + "standard" + "black" + "blue" + "brown" + "green" + "grey" + "orange" + "pink" + "purple" + "red" + "yellow" + "manjaro" + "ubuntu" + "dracula" + "nord" + ] + colorVariants -stdenvNoCC.mkDerivation rec { - inherit pname; - version = "2024-11-15"; + stdenvNoCC.mkDerivation + rec { + inherit pname; + version = "2024-11-15"; - src = fetchFromGitHub { - owner = "vinceliuice"; - repo = pname; - rev = version; - hash = "sha256-+eylAssnZK0H1ifBahnj+E+uCkukeGMXg00YT0Dg7dc="; - }; + src = fetchFromGitHub { + owner = "vinceliuice"; + repo = pname; + rev = version; + hash = "sha256-+eylAssnZK0H1ifBahnj+E+uCkukeGMXg00YT0Dg7dc="; + }; - nativeBuildInputs = [ - gtk3 - jdupes - ]; + nativeBuildInputs = [ + gtk3 + jdupes + ]; - propagatedBuildInputs = [ - adwaita-icon-theme - breeze-icons - hicolor-icon-theme - ]; + propagatedBuildInputs = [ + adwaita-icon-theme + breeze-icons + hicolor-icon-theme + ]; - dontDropIconThemeCache = true; + dontDropIconThemeCache = true; - # These fixup steps are slow and unnecessary for this package. - # Package may install almost 400 000 small files. - dontPatchELF = true; - dontRewriteSymlinks = true; + # These fixup steps are slow and unnecessary for this package. + # Package may install almost 400 000 small files. + dontPatchELF = true; + dontRewriteSymlinks = true; - postPatch = '' - patchShebangs install.sh - ''; + postPatch = '' + patchShebangs install.sh + ''; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - ./install.sh -d $out/share/icons \ - ${lib.optionalString circularFolder "-c"} \ - ${if allColorVariants then "-a" else builtins.toString colorVariants} + ./install.sh -d $out/share/icons \ + ${lib.optionalString circularFolder "-c"} \ + ${if allColorVariants then "-a" else builtins.toString colorVariants} - jdupes --quiet --link-soft --recurse $out/share + jdupes --quiet --link-soft --recurse $out/share - runHook postInstall - ''; + runHook postInstall + ''; - passthru.updateScript = gitUpdater { }; + passthru.updateScript = gitUpdater { }; - meta = with lib; { - description = "Flat and colorful personality icon theme"; - homepage = "https://github.com/vinceliuice/Tela-circle-icon-theme"; - license = licenses.gpl3Only; - platforms = platforms.linux; # darwin use case-insensitive filesystems that cause hash mismatches - maintainers = with maintainers; [ romildo ]; - }; -} + meta = with lib; { + description = "Flat and colorful personality icon theme"; + homepage = "https://github.com/vinceliuice/Tela-circle-icon-theme"; + license = licenses.gpl3Only; + platforms = platforms.linux; # darwin use case-insensitive filesystems that cause hash mismatches + maintainers = with maintainers; [ romildo ]; + }; + } diff --git a/pkgs/data/icons/zafiro-icons/default.nix b/pkgs/data/icons/zafiro-icons/default.nix index 2f0c03220daf1f..44858afeb9e342 100644 --- a/pkgs/data/icons/zafiro-icons/default.nix +++ b/pkgs/data/icons/zafiro-icons/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gtk3 -, breeze-icons -, gnome-icon-theme -, numix-icon-theme -, numix-icon-theme-circle -, hicolor-icon-theme -, jdupes -, gitUpdater +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk3, + breeze-icons, + gnome-icon-theme, + numix-icon-theme, + numix-icon-theme-circle, + hicolor-icon-theme, + jdupes, + gitUpdater, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/data/misc/cacert/default.nix b/pkgs/data/misc/cacert/default.nix index 2ae890496affcf..d3f4c4f2eb606b 100644 --- a/pkgs/data/misc/cacert/default.nix +++ b/pkgs/data/misc/cacert/default.nix @@ -1,24 +1,27 @@ -{ lib -, stdenv -, writeText -, fetchFromGitHub -, buildcatrust -, blacklist ? [] -, extraCertificateFiles ? [] -, extraCertificateStrings ? [] - -# Used by update.sh -, nssOverride ? null - -# Used for tests only -, runCommand -, cacert -, openssl +{ + lib, + stdenv, + writeText, + fetchFromGitHub, + buildcatrust, + blacklist ? [ ], + extraCertificateFiles ? [ ], + extraCertificateStrings ? [ ], + + # Used by update.sh + nssOverride ? null, + + # Used for tests only + runCommand, + cacert, + openssl, }: let blocklist = writeText "cacert-blocklist.txt" (lib.concatStringsSep "\n" blacklist); - extraCertificatesBundle = writeText "cacert-extra-certificates-bundle.crt" (lib.concatStringsSep "\n\n" extraCertificateStrings); + extraCertificatesBundle = writeText "cacert-extra-certificates-bundle.crt" ( + lib.concatStringsSep "\n\n" extraCertificateStrings + ); srcVersion = "3.107"; version = if nssOverride != null then nssOverride.version else srcVersion; @@ -26,19 +29,26 @@ let homepage = "https://curl.haxx.se/docs/caextract.html"; description = "Bundle of X.509 certificates of public Certificate Authorities (CA)"; platforms = platforms.all; - maintainers = with maintainers; [ fpletz lukegb ]; + maintainers = with maintainers; [ + fpletz + lukegb + ]; license = licenses.mpl20; }; certdata = stdenv.mkDerivation { pname = "nss-cacert-certdata"; inherit version; - src = if nssOverride != null then nssOverride.src else fetchFromGitHub { - owner = "nss-dev"; - repo = "nss"; - rev = "NSS_${lib.replaceStrings ["."] ["_"] version}_RTM"; - hash = "sha256-c6ks/pBvZHipNkmBy784s96zMYP+D9q3VlVrPVSohLw="; - }; + src = + if nssOverride != null then + nssOverride.src + else + fetchFromGitHub { + owner = "nss-dev"; + repo = "nss"; + rev = "NSS_${lib.replaceStrings [ "." ] [ "_" ] version}_RTM"; + hash = "sha256-c6ks/pBvZHipNkmBy784s96zMYP+D9q3VlVrPVSohLw="; + }; dontBuild = true; @@ -60,7 +70,11 @@ stdenv.mkDerivation rec { src = certdata; - outputs = [ "out" "unbundled" "p11kit" ]; + outputs = [ + "out" + "unbundled" + "p11kit" + ]; nativeBuildInputs = [ buildcatrust ]; @@ -68,7 +82,9 @@ stdenv.mkDerivation rec { mkdir unbundled buildcatrust \ --certdata_input certdata.txt \ - --ca_bundle_input "${extraCertificatesBundle}" ${lib.escapeShellArgs (map (arg: "${arg}") extraCertificateFiles)} \ + --ca_bundle_input "${extraCertificatesBundle}" ${ + lib.escapeShellArgs (map (arg: "${arg}") extraCertificateFiles) + } \ --blocklist "${blocklist}" \ --ca_bundle_output ca-bundle.crt \ --ca_standard_bundle_output ca-no-trust-rules-bundle.crt \ @@ -93,120 +109,144 @@ stdenv.mkDerivation rec { passthru = { updateScript = ./update.sh; - tests = let - isTrusted = '' - isTrusted() { - # isTrusted - for f in $1/etc/ssl/certs/*.crt; do - if ! [[ -s "$f" ]]; then continue; fi - fingerprint="$(openssl x509 -in "$f" -noout -fingerprint -sha256 | cut -f2 -d=)" - if [[ "x$fingerprint" == "x$3" ]]; then - # If the certificate is treated as rejected for TLS Web Server, then we consider it untrusted. - if openssl x509 -in "$f" -noout -text | grep -q '^Rejected Uses:'; then - if openssl x509 -in "$f" -noout -text | grep -A1 '^Rejected Uses:' | grep -q 'TLS Web Server'; then - return 1 + tests = + let + isTrusted = '' + isTrusted() { + # isTrusted + for f in $1/etc/ssl/certs/*.crt; do + if ! [[ -s "$f" ]]; then continue; fi + fingerprint="$(openssl x509 -in "$f" -noout -fingerprint -sha256 | cut -f2 -d=)" + if [[ "x$fingerprint" == "x$3" ]]; then + # If the certificate is treated as rejected for TLS Web Server, then we consider it untrusted. + if openssl x509 -in "$f" -noout -text | grep -q '^Rejected Uses:'; then + if openssl x509 -in "$f" -noout -text | grep -A1 '^Rejected Uses:' | grep -q 'TLS Web Server'; then + return 1 + fi fi + return 0 fi - return 0 - fi - done - return 1 - } - ''; - in { - # Test that building this derivation with a blacklist works, and that UTF-8 is supported. - blacklist-utf8 = let - blacklistCAToFingerprint = { - # "blacklist" uses the CA name from the NSS bundle, but we check for presence using the SHA256 fingerprint. - "CFCA EV ROOT" = "5C:C3:D7:8E:4E:1D:5E:45:54:7A:04:E6:87:3E:64:F9:0C:F9:53:6D:1C:CC:2E:F8:00:F3:55:C4:C5:FD:70:FD"; - "NetLock Arany (Class Gold) Főtanúsítvány" = "6C:61:DA:C3:A2:DE:F0:31:50:6B:E0:36:D2:A6:FE:40:19:94:FB:D1:3D:F9:C8:D4:66:59:92:74:C4:46:EC:98"; - }; - mapBlacklist = f: lib.concatStringsSep "\n" (lib.mapAttrsToList f blacklistCAToFingerprint); - in runCommand "verify-the-cacert-filter-output" { - cacert = cacert.unbundled; - cacertWithExcludes = (cacert.override { - blacklist = builtins.attrNames blacklistCAToFingerprint; - }).unbundled; - - nativeBuildInputs = [ openssl ]; - } '' - ${isTrusted} - - # Ensure that each certificate is in the main "cacert". - ${mapBlacklist (caName: caFingerprint: '' - isTrusted "$cacert" "${caName}" "${caFingerprint}" || ({ - echo "CA fingerprint ${caFingerprint} (${caName}) is missing from the CA bundle. Consider picking a different CA for the blacklist test." >&2 - exit 1 - }) - '')} - - # Ensure that each certificate is NOT in the "cacertWithExcludes". - ${mapBlacklist (caName: caFingerprint: '' - isTrusted "$cacertWithExcludes" "${caName}" "${caFingerprint}" && ({ - echo "CA fingerprint ${caFingerprint} (${caName}) is present in the cacertWithExcludes bundle." >&2 - exit 1 - }) - '')} - - touch "$out" - ''; - - # Test that we can add additional certificates to the store, and have them be trusted. - extra-certificates = let - extraCertificateStr = '' - -----BEGIN CERTIFICATE----- - MIIB5DCCAWqgAwIBAgIUItvsAYEIdYDkOIo5sdDYMcUaNuIwCgYIKoZIzj0EAwIw - KTEnMCUGA1UEAwweTml4T1MgY2FjZXJ0IGV4dHJhIGNlcnRpZmljYXRlMB4XDTIx - MDYxMjE5MDQzMFoXDTIyMDYxMjE5MDQzMFowKTEnMCUGA1UEAwweTml4T1MgY2Fj - ZXJ0IGV4dHJhIGNlcnRpZmljYXRlMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAEuP8y - lAm6ZyQt9v/P6gTlV/a9R+D61WjucW04kaegOhg8csiluimYodiSv0Pbgymu+Zxm - A3Bz9QGmytaYTiJ16083rJkwwIhqoYl7kWsLzreSTaLz87KH+rdeol59+H0Oo1Mw - UTAdBgNVHQ4EFgQUCxuHfvqI4YVU5M+A0+aKvd1LrdswHwYDVR0jBBgwFoAUCxuH - fvqI4YVU5M+A0+aKvd1LrdswDwYDVR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAgNo - ADBlAjEArgxgjdNmRlSEuai0dzlktmBEDZKy2Iiul+ttSoce9ohfEVYESwO602HW - keVvI56vAjBCro3dc3m2TuktiKO6lQV56PUEyxko4H/sR5pnHlduCGRDlFzQKXf/ - pMMmtj7cVb8= - -----END CERTIFICATE----- + done + return 1 + } ''; - extraCertificateFile = ./test-cert-file.crt; - extraCertificatesToFingerprint = { - # String above - "NixOS cacert extra certificate string" = "A3:20:D0:84:96:97:25:FF:98:B8:A9:6D:A3:7C:89:95:6E:7A:77:21:92:F3:33:E9:31:AF:5E:03:CE:A9:E5:EE"; - - # File - "NixOS cacert extra certificate file" = "88:B8:BE:A7:57:AC:F1:FE:D6:98:8B:50:E0:BD:0A:AE:88:C7:DF:70:26:E1:67:5E:F5:F6:91:27:FF:02:D4:A5"; - }; - mapExtra = f: lib.concatStringsSep "\n" (lib.mapAttrsToList f extraCertificatesToFingerprint); - in runCommand "verify-the-cacert-extra-output" { - cacert = cacert.unbundled; - cacertWithExtras = (cacert.override { - extraCertificateStrings = [ extraCertificateStr ]; - extraCertificateFiles = [ extraCertificateFile ]; - }).unbundled; - - nativeBuildInputs = [ openssl ]; - } '' - ${isTrusted} - - # Ensure that the extra certificate is not in the main "cacert". - ${mapExtra (extraName: extraFingerprint: '' - isTrusted "$cacert" "${extraName}" "${extraFingerprint}" && ({ - echo "'extra' CA fingerprint ${extraFingerprint} (${extraName}) is present in the main CA bundle." >&2 - exit 1 - }) - '')} - - # Ensure that the extra certificates ARE in the "cacertWithExtras". - ${mapExtra (extraName: extraFingerprint: '' - isTrusted "$cacertWithExtras" "${extraName}" "${extraFingerprint}" || ({ - echo "CA fingerprint ${extraFingerprint} (${extraName}) is not present in the cacertWithExtras bundle." >&2 - exit 1 - }) - '')} - - touch "$out" - ''; - }; + in + { + # Test that building this derivation with a blacklist works, and that UTF-8 is supported. + blacklist-utf8 = + let + blacklistCAToFingerprint = { + # "blacklist" uses the CA name from the NSS bundle, but we check for presence using the SHA256 fingerprint. + "CFCA EV ROOT" = + "5C:C3:D7:8E:4E:1D:5E:45:54:7A:04:E6:87:3E:64:F9:0C:F9:53:6D:1C:CC:2E:F8:00:F3:55:C4:C5:FD:70:FD"; + "NetLock Arany (Class Gold) Főtanúsítvány" = + "6C:61:DA:C3:A2:DE:F0:31:50:6B:E0:36:D2:A6:FE:40:19:94:FB:D1:3D:F9:C8:D4:66:59:92:74:C4:46:EC:98"; + }; + mapBlacklist = f: lib.concatStringsSep "\n" (lib.mapAttrsToList f blacklistCAToFingerprint); + in + runCommand "verify-the-cacert-filter-output" + { + cacert = cacert.unbundled; + cacertWithExcludes = + (cacert.override { + blacklist = builtins.attrNames blacklistCAToFingerprint; + }).unbundled; + + nativeBuildInputs = [ openssl ]; + } + '' + ${isTrusted} + + # Ensure that each certificate is in the main "cacert". + ${mapBlacklist ( + caName: caFingerprint: '' + isTrusted "$cacert" "${caName}" "${caFingerprint}" || ({ + echo "CA fingerprint ${caFingerprint} (${caName}) is missing from the CA bundle. Consider picking a different CA for the blacklist test." >&2 + exit 1 + }) + '' + )} + + # Ensure that each certificate is NOT in the "cacertWithExcludes". + ${mapBlacklist ( + caName: caFingerprint: '' + isTrusted "$cacertWithExcludes" "${caName}" "${caFingerprint}" && ({ + echo "CA fingerprint ${caFingerprint} (${caName}) is present in the cacertWithExcludes bundle." >&2 + exit 1 + }) + '' + )} + + touch "$out" + ''; + + # Test that we can add additional certificates to the store, and have them be trusted. + extra-certificates = + let + extraCertificateStr = '' + -----BEGIN CERTIFICATE----- + MIIB5DCCAWqgAwIBAgIUItvsAYEIdYDkOIo5sdDYMcUaNuIwCgYIKoZIzj0EAwIw + KTEnMCUGA1UEAwweTml4T1MgY2FjZXJ0IGV4dHJhIGNlcnRpZmljYXRlMB4XDTIx + MDYxMjE5MDQzMFoXDTIyMDYxMjE5MDQzMFowKTEnMCUGA1UEAwweTml4T1MgY2Fj + ZXJ0IGV4dHJhIGNlcnRpZmljYXRlMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAEuP8y + lAm6ZyQt9v/P6gTlV/a9R+D61WjucW04kaegOhg8csiluimYodiSv0Pbgymu+Zxm + A3Bz9QGmytaYTiJ16083rJkwwIhqoYl7kWsLzreSTaLz87KH+rdeol59+H0Oo1Mw + UTAdBgNVHQ4EFgQUCxuHfvqI4YVU5M+A0+aKvd1LrdswHwYDVR0jBBgwFoAUCxuH + fvqI4YVU5M+A0+aKvd1LrdswDwYDVR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAgNo + ADBlAjEArgxgjdNmRlSEuai0dzlktmBEDZKy2Iiul+ttSoce9ohfEVYESwO602HW + keVvI56vAjBCro3dc3m2TuktiKO6lQV56PUEyxko4H/sR5pnHlduCGRDlFzQKXf/ + pMMmtj7cVb8= + -----END CERTIFICATE----- + ''; + extraCertificateFile = ./test-cert-file.crt; + extraCertificatesToFingerprint = { + # String above + "NixOS cacert extra certificate string" = + "A3:20:D0:84:96:97:25:FF:98:B8:A9:6D:A3:7C:89:95:6E:7A:77:21:92:F3:33:E9:31:AF:5E:03:CE:A9:E5:EE"; + + # File + "NixOS cacert extra certificate file" = + "88:B8:BE:A7:57:AC:F1:FE:D6:98:8B:50:E0:BD:0A:AE:88:C7:DF:70:26:E1:67:5E:F5:F6:91:27:FF:02:D4:A5"; + }; + mapExtra = f: lib.concatStringsSep "\n" (lib.mapAttrsToList f extraCertificatesToFingerprint); + in + runCommand "verify-the-cacert-extra-output" + { + cacert = cacert.unbundled; + cacertWithExtras = + (cacert.override { + extraCertificateStrings = [ extraCertificateStr ]; + extraCertificateFiles = [ extraCertificateFile ]; + }).unbundled; + + nativeBuildInputs = [ openssl ]; + } + '' + ${isTrusted} + + # Ensure that the extra certificate is not in the main "cacert". + ${mapExtra ( + extraName: extraFingerprint: '' + isTrusted "$cacert" "${extraName}" "${extraFingerprint}" && ({ + echo "'extra' CA fingerprint ${extraFingerprint} (${extraName}) is present in the main CA bundle." >&2 + exit 1 + }) + '' + )} + + # Ensure that the extra certificates ARE in the "cacertWithExtras". + ${mapExtra ( + extraName: extraFingerprint: '' + isTrusted "$cacertWithExtras" "${extraName}" "${extraFingerprint}" || ({ + echo "CA fingerprint ${extraFingerprint} (${extraName}) is not present in the cacertWithExtras bundle." >&2 + exit 1 + }) + '' + )} + + touch "$out" + ''; + }; }; inherit meta; diff --git a/pkgs/data/misc/fedora-backgrounds/default.nix b/pkgs/data/misc/fedora-backgrounds/default.nix index 59bb95b00978cd..ca569e3eb16b43 100644 --- a/pkgs/data/misc/fedora-backgrounds/default.nix +++ b/pkgs/data/misc/fedora-backgrounds/default.nix @@ -1,8 +1,13 @@ -{ callPackage, lib, fetchurl }: +{ + callPackage, + lib, + fetchurl, +}: let fedoraBackground = callPackage ./generic.nix { }; -in { +in +{ f32 = fedoraBackground rec { version = "32.2.2"; src = fetchurl { diff --git a/pkgs/data/misc/fedora-backgrounds/generic.nix b/pkgs/data/misc/fedora-backgrounds/generic.nix index 716fe1d0601713..dd75ea9e88b106 100644 --- a/pkgs/data/misc/fedora-backgrounds/generic.nix +++ b/pkgs/data/misc/fedora-backgrounds/generic.nix @@ -1,11 +1,13 @@ -{ lib -, stdenvNoCC -, coreutils +{ + lib, + stdenvNoCC, + coreutils, }: -{ version -, src -, patches ? [ ] +{ + version, + src, + patches ? [ ], }: stdenvNoCC.mkDerivation { diff --git a/pkgs/data/misc/nixos-artwork/grub2-theme.nix b/pkgs/data/misc/nixos-artwork/grub2-theme.nix index 0a5717ba3b2743..57f53c5d59803f 100644 --- a/pkgs/data/misc/nixos-artwork/grub2-theme.nix +++ b/pkgs/data/misc/nixos-artwork/grub2-theme.nix @@ -1,4 +1,4 @@ -{fetchzip}: +{ fetchzip }: fetchzip { url = "https://github.com/NixOS/nixos-artwork/releases/download/bootloader-18.09-pre/grub2-installer.tar.bz2"; sha256 = "0rhh061m1hpgadm7587inw3fxfacnd53xjc53w3vzghlck56djq5"; diff --git a/pkgs/data/misc/nixos-artwork/icons.nix b/pkgs/data/misc/nixos-artwork/icons.nix index 89af4e552e1cf1..8a9ed3d40a847e 100644 --- a/pkgs/data/misc/nixos-artwork/icons.nix +++ b/pkgs/data/misc/nixos-artwork/icons.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, fetchFromGitHub -, imagemagick +{ + stdenv, + lib, + fetchFromGitHub, + imagemagick, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/data/misc/nixos-artwork/wallpapers.nix b/pkgs/data/misc/nixos-artwork/wallpapers.nix index 4cc128c15f1558..117a58c8176968 100644 --- a/pkgs/data/misc/nixos-artwork/wallpapers.nix +++ b/pkgs/data/misc/nixos-artwork/wallpapers.nix @@ -1,70 +1,76 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let - mkNixBackground = { - name, - src, - description, - license ? lib.licenses.free - }: - - let - pkg = stdenv.mkDerivation { - inherit name src; - - dontUnpack = true; - - installPhase = '' - runHook preInstall - - # GNOME - mkdir -p $out/share/backgrounds/nixos - ln -s $src $out/share/backgrounds/nixos/${src.name} - - mkdir -p $out/share/gnome-background-properties/ - cat < $out/share/gnome-background-properties/${name}.xml - - - - - ${name} - ${src} - zoom - solid - #ffffff - #000000 - - -EOF - - # TODO: is this path still needed? - mkdir -p $out/share/artwork/gnome - ln -s $src $out/share/artwork/gnome/${src.name} - - # KDE - mkdir -p $out/share/wallpapers/${name}/contents/images - ln -s $src $out/share/wallpapers/${name}/contents/images/${src.name} - cat >>$out/share/wallpapers/${name}/metadata.desktop <<_EOF -[Desktop Entry] -Name=${name} -X-KDE-PluginInfo-Name=${name} -_EOF - - runHook postInstall - ''; - - passthru = { - gnomeFilePath = "${pkg}/share/backgrounds/nixos/${src.name}"; - kdeFilePath = "${pkg}/share/wallpapers/${name}/contents/images/${src.name}"; + mkNixBackground = + { + name, + src, + description, + license ? lib.licenses.free, + }: + + let + pkg = stdenv.mkDerivation { + inherit name src; + + dontUnpack = true; + + installPhase = '' + runHook preInstall + + # GNOME + mkdir -p $out/share/backgrounds/nixos + ln -s $src $out/share/backgrounds/nixos/${src.name} + + mkdir -p $out/share/gnome-background-properties/ + cat < $out/share/gnome-background-properties/${name}.xml + + + + + ${name} + ${src} + zoom + solid + #ffffff + #000000 + + + EOF + + # TODO: is this path still needed? + mkdir -p $out/share/artwork/gnome + ln -s $src $out/share/artwork/gnome/${src.name} + + # KDE + mkdir -p $out/share/wallpapers/${name}/contents/images + ln -s $src $out/share/wallpapers/${name}/contents/images/${src.name} + cat >>$out/share/wallpapers/${name}/metadata.desktop <<_EOF + [Desktop Entry] + Name=${name} + X-KDE-PluginInfo-Name=${name} + _EOF + + runHook postInstall + ''; + + passthru = { + gnomeFilePath = "${pkg}/share/backgrounds/nixos/${src.name}"; + kdeFilePath = "${pkg}/share/wallpapers/${name}/contents/images/${src.name}"; + }; + + meta = with lib; { + inherit description license; + homepage = "https://github.com/NixOS/nixos-artwork"; + platforms = platforms.all; + }; }; - - meta = with lib; { - inherit description license; - homepage = "https://github.com/NixOS/nixos-artwork"; - platforms = platforms.all; - }; - }; -in pkg; + in + pkg; in diff --git a/pkgs/data/sgml+xml/stylesheets/xslt/docbook-xsl/default.nix b/pkgs/data/sgml+xml/stylesheets/xslt/docbook-xsl/default.nix index 8798d11fb0cd8e..8d839427a2fe70 100644 --- a/pkgs/data/sgml+xml/stylesheets/xslt/docbook-xsl/default.nix +++ b/pkgs/data/sgml+xml/stylesheets/xslt/docbook-xsl/default.nix @@ -1,82 +1,102 @@ -{ lib, stdenv, substituteAll, fetchurl, fetchpatch, findXMLCatalogs, writeScriptBin, ruby, bash, withManOptDedupPatch ? false }: +{ + lib, + stdenv, + substituteAll, + fetchurl, + fetchpatch, + findXMLCatalogs, + writeScriptBin, + ruby, + bash, + withManOptDedupPatch ? false, +}: let - common = { pname, sha256, suffix ? "" }: let - legacySuffix = lib.optionalString (suffix != "-nons") "-ns"; - self = stdenv.mkDerivation rec { - inherit pname; - version = "1.79.2"; - - src = fetchurl { - url = "https://github.com/docbook/xslt10-stylesheets/releases/download/release%2F${version}/docbook-xsl${suffix}-${version}.tar.bz2"; - inherit sha256; - }; + common = + { + pname, + sha256, + suffix ? "", + }: + let + legacySuffix = lib.optionalString (suffix != "-nons") "-ns"; + self = stdenv.mkDerivation rec { + inherit pname; + version = "1.79.2"; + + src = fetchurl { + url = "https://github.com/docbook/xslt10-stylesheets/releases/download/release%2F${version}/docbook-xsl${suffix}-${version}.tar.bz2"; + inherit sha256; + }; + + patches = + [ + # Prevent a potential stack overflow + # https://github.com/docbook/xslt10-stylesheets/pull/37 + (fetchpatch { + url = "https://src.fedoraproject.org/rpms/docbook-style-xsl/raw/e3ae7a97ed1d185594dd35954e1a02196afb205a/f/docbook-style-xsl-non-recursive-string-subst.patch"; + sha256 = "0lrjjg5kpwwmbhkxzz6i5zmimb6lsvrrdhzc2qgjmb3r6jnsmii3"; + stripLen = "1"; + }) + + # Fix reproducibility by respecting generate.consistent.ids in indexes + # https://github.com/docbook/xslt10-stylesheets/pull/88 + # https://sourceforge.net/p/docbook/bugs/1385/ + (fetchpatch { + url = "https://github.com/docbook/xslt10-stylesheets/commit/07631601e6602bc49b8eac3aab9d2b35968d3e7a.patch"; + sha256 = "0igfhcr6hzcydqsnjsd181h5yl3drjnrwdmxcybr236m8255vkq3"; + stripLen = "1"; + }) + + # Add legacy sourceforge.net URIs to the catalog + (substituteAll { + src = ./catalog-legacy-uris.patch; + inherit legacySuffix suffix version; + }) + ] + ++ lib.optionals withManOptDedupPatch [ + # Fixes https://github.com/NixOS/nixpkgs/issues/166304 + # https://github.com/docbook/xslt10-stylesheets/pull/241 + ./fix-man-options-duplication.patch + ]; + + propagatedBuildInputs = [ findXMLCatalogs ]; + + dontBuild = true; + + installPhase = '' + dst=$out/share/xml/${pname} + mkdir -p $dst + rm -rf RELEASE* README* INSTALL TODO NEWS* BUGS install.sh tools Makefile tests extensions webhelp + mv * $dst/ + + # Backwards compatibility. Will remove eventually. + mkdir -p $out/xml/xsl + ln -s $dst $out/xml/xsl/docbook + + # More backwards compatibility + ln -s $dst $out/share/xml/docbook-xsl${legacySuffix} + ''; - patches = [ - # Prevent a potential stack overflow - # https://github.com/docbook/xslt10-stylesheets/pull/37 - (fetchpatch { - url = "https://src.fedoraproject.org/rpms/docbook-style-xsl/raw/e3ae7a97ed1d185594dd35954e1a02196afb205a/f/docbook-style-xsl-non-recursive-string-subst.patch"; - sha256 = "0lrjjg5kpwwmbhkxzz6i5zmimb6lsvrrdhzc2qgjmb3r6jnsmii3"; - stripLen = "1"; - }) - - # Fix reproducibility by respecting generate.consistent.ids in indexes - # https://github.com/docbook/xslt10-stylesheets/pull/88 - # https://sourceforge.net/p/docbook/bugs/1385/ - (fetchpatch { - url = "https://github.com/docbook/xslt10-stylesheets/commit/07631601e6602bc49b8eac3aab9d2b35968d3e7a.patch"; - sha256 = "0igfhcr6hzcydqsnjsd181h5yl3drjnrwdmxcybr236m8255vkq3"; - stripLen = "1"; - }) - - # Add legacy sourceforge.net URIs to the catalog - (substituteAll { - src = ./catalog-legacy-uris.patch; - inherit legacySuffix suffix version; - }) - ] ++ lib.optionals withManOptDedupPatch [ - # Fixes https://github.com/NixOS/nixpkgs/issues/166304 - # https://github.com/docbook/xslt10-stylesheets/pull/241 - ./fix-man-options-duplication.patch - ]; - - propagatedBuildInputs = [ findXMLCatalogs ]; - - dontBuild = true; - - installPhase = '' - dst=$out/share/xml/${pname} - mkdir -p $dst - rm -rf RELEASE* README* INSTALL TODO NEWS* BUGS install.sh tools Makefile tests extensions webhelp - mv * $dst/ - - # Backwards compatibility. Will remove eventually. - mkdir -p $out/xml/xsl - ln -s $dst $out/xml/xsl/docbook - - # More backwards compatibility - ln -s $dst $out/share/xml/docbook-xsl${legacySuffix} - ''; - - passthru.dbtoepub = writeScriptBin "dbtoepub" - '' + passthru.dbtoepub = writeScriptBin "dbtoepub" '' #!${bash}/bin/bash exec -a dbtoepub ${ruby}/bin/ruby ${self}/share/xml/${pname}/epub/bin/dbtoepub "$@" ''; - meta = { - homepage = "https://github.com/docbook/wiki/wiki/DocBookXslStylesheets"; - description = "XSL stylesheets for transforming DocBook documents into HTML and various other formats"; - license = lib.licenses.mit; - maintainers = [ ]; - platforms = lib.platforms.all; + meta = { + homepage = "https://github.com/docbook/wiki/wiki/DocBookXslStylesheets"; + description = "XSL stylesheets for transforming DocBook documents into HTML and various other formats"; + license = lib.licenses.mit; + maintainers = [ ]; + platforms = lib.platforms.all; + }; }; - }; - in self; + in + self; -in { +in +{ docbook-xsl-nons = common { pname = "docbook-xsl-nons"; diff --git a/pkgs/data/themes/adwaita-qt/default.nix b/pkgs/data/themes/adwaita-qt/default.nix index 90069dc48c356e..704d49af1cb01b 100644 --- a/pkgs/data/themes/adwaita-qt/default.nix +++ b/pkgs/data/themes/adwaita-qt/default.nix @@ -1,21 +1,25 @@ -{ stdenv -, lib -, fetchFromGitHub -, nix-update-script -, cmake -, ninja -, qtbase -, qtwayland -, qt5 -, xorg -, useQt6 ? false +{ + stdenv, + lib, + fetchFromGitHub, + nix-update-script, + cmake, + ninja, + qtbase, + qtwayland, + qt5, + xorg, + useQt6 ? false, }: stdenv.mkDerivation rec { pname = "adwaita-qt"; version = "1.4.2"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "FedoraQt"; @@ -29,15 +33,19 @@ stdenv.mkDerivation rec { ninja ]; - buildInputs = [ - qtbase - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - xorg.libxcb - ] ++ lib.optionals (!useQt6) [ - qt5.qtx11extras - ] ++ lib.optionals useQt6 [ - qtwayland - ]; + buildInputs = + [ + qtbase + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + xorg.libxcb + ] + ++ lib.optionals (!useQt6) [ + qt5.qtx11extras + ] + ++ lib.optionals useQt6 [ + qtwayland + ]; # Qt setup hook complains about missing `wrapQtAppsHook` otherwise. dontWrapQtApps = true; diff --git a/pkgs/data/themes/andromeda-gtk-theme/default.nix b/pkgs/data/themes/andromeda-gtk-theme/default.nix index fa2785a8db8644..da49e70adeba2c 100644 --- a/pkgs/data/themes/andromeda-gtk-theme/default.nix +++ b/pkgs/data/themes/andromeda-gtk-theme/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchFromGitHub, gtk-engine-murrine }: +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gtk-engine-murrine, +}: stdenvNoCC.mkDerivation { pname = "andromeda-gtk-theme"; @@ -56,6 +61,9 @@ stdenvNoCC.mkDerivation { homepage = "https://github.com/EliverLara/Andromeda-gtk"; license = licenses.gpl3Only; platforms = platforms.linux; - maintainers = with maintainers; [ jakedevs romildo ]; + maintainers = with maintainers; [ + jakedevs + romildo + ]; }; } diff --git a/pkgs/data/themes/ant-theme/ant-bloody.nix b/pkgs/data/themes/ant-theme/ant-bloody.nix index 66cd3e247a729a..b00455b79a67c2 100644 --- a/pkgs/data/themes/ant-theme/ant-bloody.nix +++ b/pkgs/data/themes/ant-theme/ant-bloody.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchurl, + gtk-engine-murrine, +}: let themeName = "Ant-Bloody"; diff --git a/pkgs/data/themes/ant-theme/ant-nebula.nix b/pkgs/data/themes/ant-theme/ant-nebula.nix index a62791572352b8..3e7a31902cc20e 100644 --- a/pkgs/data/themes/ant-theme/ant-nebula.nix +++ b/pkgs/data/themes/ant-theme/ant-nebula.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchurl, + gtk-engine-murrine, +}: let themeName = "Ant-Nebula"; diff --git a/pkgs/data/themes/ant-theme/ant.nix b/pkgs/data/themes/ant-theme/ant.nix index 2cb6961de1f730..e6bc0f848681b8 100644 --- a/pkgs/data/themes/ant-theme/ant.nix +++ b/pkgs/data/themes/ant-theme/ant.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gtk-engine-murrine }: +{ + lib, + stdenv, + fetchurl, + gtk-engine-murrine, +}: let themeName = "Ant"; diff --git a/pkgs/data/themes/breath-theme/default.nix b/pkgs/data/themes/breath-theme/default.nix index 79bca7720207ee..1c320651509940 100644 --- a/pkgs/data/themes/breath-theme/default.nix +++ b/pkgs/data/themes/breath-theme/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitLab -, cmake -, extra-cmake-modules -, kdecoration -, plasma-workspace -, qtbase +{ + lib, + stdenv, + fetchFromGitLab, + cmake, + extra-cmake-modules, + kdecoration, + plasma-workspace, + qtbase, }: stdenv.mkDerivation { @@ -32,7 +33,10 @@ stdenv.mkDerivation { dontWrapQtApps = true; - cmakeFlags = [ "-DBUILD_PLASMA_THEMES=ON" "-DBUILD_SDDM_THEME=ON" ]; + cmakeFlags = [ + "-DBUILD_PLASMA_THEMES=ON" + "-DBUILD_SDDM_THEME=ON" + ]; meta = with lib; { description = "Manjaro KDE default theme"; diff --git a/pkgs/data/themes/chili-sddm/default.nix b/pkgs/data/themes/chili-sddm/default.nix index ccbbbfba5bf513..cb6939b3d3e4d9 100644 --- a/pkgs/data/themes/chili-sddm/default.nix +++ b/pkgs/data/themes/chili-sddm/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, qtgraphicaleffects -, themeConfig ? { } +{ + lib, + stdenv, + fetchFromGitHub, + qtgraphicaleffects, + themeConfig ? { }, }: let customToString = x: if builtins.isBool x then lib.boolToString x else toString x; configLines = lib.mapAttrsToList (name: value: lib.nameValuePair name value) themeConfig; - configureTheme = "cp theme.conf theme.conf.orig \n" + - (lib.concatMapStringsSep "\n" - (configLine: - "grep -q '^${configLine.name}=' theme.conf || echo '${configLine.name}=' >> \"$1\"\n" + - "sed -i -e 's/^${configLine.name}=.*$/${configLine.name}=${ - lib.escape [ "/" "&" "\\"] (customToString configLine.value) + configureTheme = + "cp theme.conf theme.conf.orig \n" + + (lib.concatMapStringsSep "\n" ( + configLine: + "grep -q '^${configLine.name}=' theme.conf || echo '${configLine.name}=' >> \"$1\"\n" + + "sed -i -e 's/^${configLine.name}=.*$/${configLine.name}=${ + lib.escape [ "/" "&" "\\" ] (customToString configLine.value) }/' theme.conf" - ) - configLines); + ) configLines); in stdenv.mkDerivation { pname = "sddm-chili-theme"; diff --git a/pkgs/data/themes/colloid-kde/default.nix b/pkgs/data/themes/colloid-kde/default.nix index 4e1e05f359d706..ef620f4e327098 100644 --- a/pkgs/data/themes/colloid-kde/default.nix +++ b/pkgs/data/themes/colloid-kde/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, kdeclarative -, plasma-framework -, plasma-workspace -, gitUpdater +{ + lib, + stdenvNoCC, + fetchFromGitHub, + kdeclarative, + plasma-framework, + plasma-workspace, + gitUpdater, }: stdenvNoCC.mkDerivation rec { @@ -18,7 +19,10 @@ stdenvNoCC.mkDerivation rec { hash = "sha256-AYH9fW20/p+mq6lxR1lcCV1BQ/kgcsjHncpMvYWXnWA="; }; - outputs = [ "out" "sddm" ]; + outputs = [ + "out" + "sddm" + ]; postPatch = '' patchShebangs install.sh diff --git a/pkgs/data/themes/elegant-sddm/default.nix b/pkgs/data/themes/elegant-sddm/default.nix index eaf435089d71d5..c4d297884194ff 100644 --- a/pkgs/data/themes/elegant-sddm/default.nix +++ b/pkgs/data/themes/elegant-sddm/default.nix @@ -1,19 +1,21 @@ -{ lib -, formats -, stdenvNoCC -, fetchFromGitHub -, qtgraphicaleffects - /* An example of how you can override the background with a NixOS wallpaper - * - * environment.systemPackages = [ - * (pkgs.elegant-sddm.override { - * themeConfig.General = { - background = "${pkgs.nixos-artwork.wallpapers.simple-dark-gray-bottom.gnomeFilePath}"; - * }; - * }) - * ]; +{ + lib, + formats, + stdenvNoCC, + fetchFromGitHub, + qtgraphicaleffects, + /* + An example of how you can override the background with a NixOS wallpaper + * + * environment.systemPackages = [ + * (pkgs.elegant-sddm.override { + * themeConfig.General = { + background = "${pkgs.nixos-artwork.wallpapers.simple-dark-gray-bottom.gnomeFilePath}"; + * }; + * }) + * ]; */ -, themeConfig ? null + themeConfig ? null, }: let @@ -37,16 +39,19 @@ stdenvNoCC.mkDerivation { dontWrapQtApps = true; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - mkdir -p "$out/share/sddm/themes" - cp -r Elegant/ "$out/share/sddm/themes/Elegant" - '' + (lib.optionalString (lib.isAttrs themeConfig) '' - ln -sf ${user-cfg} $out/share/sddm/themes/Elegant/theme.conf.user - '') + '' - runHook postInstall - ''; + mkdir -p "$out/share/sddm/themes" + cp -r Elegant/ "$out/share/sddm/themes/Elegant" + '' + + (lib.optionalString (lib.isAttrs themeConfig) '' + ln -sf ${user-cfg} $out/share/sddm/themes/Elegant/theme.conf.user + '') + + '' + runHook postInstall + ''; postFixup = '' mkdir -p $out/nix-support diff --git a/pkgs/data/themes/graphite-kde-theme/default.nix b/pkgs/data/themes/graphite-kde-theme/default.nix index 8cf3d065666f12..7d1d548f9031b4 100644 --- a/pkgs/data/themes/graphite-kde-theme/default.nix +++ b/pkgs/data/themes/graphite-kde-theme/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, kdeclarative -, plasma-framework -, plasma-workspace -, gitUpdater +{ + stdenv, + lib, + fetchFromGitHub, + kdeclarative, + plasma-framework, + plasma-workspace, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/data/themes/gtk-theme-framework/default.nix b/pkgs/data/themes/gtk-theme-framework/default.nix index 9d71e18f037fd9..1ae655fe8c3723 100644 --- a/pkgs/data/themes/gtk-theme-framework/default.nix +++ b/pkgs/data/themes/gtk-theme-framework/default.nix @@ -1,4 +1,9 @@ -{ stdenv, fetchFromGitHub, theme, lib }: +{ + stdenv, + fetchFromGitHub, + theme, + lib, +}: stdenv.mkDerivation rec { pname = "gtk-theme-framework"; diff --git a/pkgs/data/themes/kde2/default.nix b/pkgs/data/themes/kde2/default.nix index 9c883b51340ee0..4eab649978119c 100644 --- a/pkgs/data/themes/kde2/default.nix +++ b/pkgs/data/themes/kde2/default.nix @@ -1,6 +1,12 @@ -{ lib, fetchFromGitHub, mkDerivation -, cmake, extra-cmake-modules -, qtbase, kcoreaddons, kdecoration +{ + lib, + fetchFromGitHub, + mkDerivation, + cmake, + extra-cmake-modules, + qtbase, + kcoreaddons, + kdecoration, }: mkDerivation rec { @@ -14,11 +20,21 @@ mkDerivation rec { sha256 = "y2q1j36EURJc7k1huqhEH1Z82PnVSKlfx20bpQWY28c="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ cmake extra-cmake-modules ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; - buildInputs = [ qtbase kcoreaddons kdecoration ]; + buildInputs = [ + qtbase + kcoreaddons + kdecoration + ]; meta = with lib; { description = "KDE 2 window decoration ported to Plasma 5"; diff --git a/pkgs/data/themes/kwin-decorations/kde-rounded-corners/default.nix b/pkgs/data/themes/kwin-decorations/kde-rounded-corners/default.nix index e75376dea794f7..2fa58b4dfb1e5a 100644 --- a/pkgs/data/themes/kwin-decorations/kde-rounded-corners/default.nix +++ b/pkgs/data/themes/kwin-decorations/kde-rounded-corners/default.nix @@ -1,14 +1,15 @@ -{ stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, wrapQtAppsHook -, qtbase -, kwin -, kcmutils -, libepoxy -, libxcb -, lib +{ + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + wrapQtAppsHook, + qtbase, + kwin, + kcmutils, + libepoxy, + libxcb, + lib, }: stdenv.mkDerivation rec { @@ -22,8 +23,18 @@ stdenv.mkDerivation rec { hash = "sha256-xzs5eTNOO27//vfkax4cpKO3xnsjavSNU6tyt8H/dF0="; }; - nativeBuildInputs = [ cmake extra-cmake-modules wrapQtAppsHook ]; - buildInputs = [ kcmutils kwin libepoxy libxcb qtbase ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + wrapQtAppsHook + ]; + buildInputs = [ + kcmutils + kwin + libepoxy + libxcb + qtbase + ]; meta = with lib; { description = "Rounds the corners of your windows"; diff --git a/pkgs/data/themes/kwin-decorations/sierra-breeze-enhanced/default.nix b/pkgs/data/themes/kwin-decorations/sierra-breeze-enhanced/default.nix index 156d8aaaf90730..4eaaabd1954c2c 100644 --- a/pkgs/data/themes/kwin-decorations/sierra-breeze-enhanced/default.nix +++ b/pkgs/data/themes/kwin-decorations/sierra-breeze-enhanced/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, wrapQtAppsHook -, kwin -, lib -, useQt5 ? false +{ + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + wrapQtAppsHook, + kwin, + lib, + useQt5 ? false, }: let latestVersion = "2.0.1"; @@ -25,7 +26,11 @@ stdenv.mkDerivation rec { sha256 = if useQt5 then qt5Sha256 else latestSha256; }; - nativeBuildInputs = [ cmake extra-cmake-modules wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + wrapQtAppsHook + ]; buildInputs = [ kwin ]; cmakeFlags = [ diff --git a/pkgs/data/themes/layan-kde/default.nix b/pkgs/data/themes/layan-kde/default.nix index a0cf318d33bdc1..2f08b5ccdcaa98 100644 --- a/pkgs/data/themes/layan-kde/default.nix +++ b/pkgs/data/themes/layan-kde/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, kdeclarative -, plasma-framework -, plasma-workspace -, gitUpdater +{ + stdenv, + lib, + fetchFromGitHub, + kdeclarative, + plasma-framework, + plasma-workspace, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/data/themes/lightly-boehs/default.nix b/pkgs/data/themes/lightly-boehs/default.nix index e226fd31a3d880..521736858752e1 100644 --- a/pkgs/data/themes/lightly-boehs/default.nix +++ b/pkgs/data/themes/lightly-boehs/default.nix @@ -1,12 +1,13 @@ -{ mkDerivation -, lib -, kdecoration -, fetchFromGitHub -, cmake -, extra-cmake-modules -, plasma-workspace -, qtbase -, qt5 +{ + mkDerivation, + lib, + kdecoration, + fetchFromGitHub, + cmake, + extra-cmake-modules, + plasma-workspace, + qtbase, + qt5, }: mkDerivation rec { diff --git a/pkgs/data/themes/lightly-qt/default.nix b/pkgs/data/themes/lightly-qt/default.nix index cb238a3f745ec7..6b6729c9cbb758 100644 --- a/pkgs/data/themes/lightly-qt/default.nix +++ b/pkgs/data/themes/lightly-qt/default.nix @@ -1,12 +1,13 @@ -{ mkDerivation -, lib -, fetchFromGitHub -, cmake -, extra-cmake-modules -, kdecoration -, plasma-workspace -, qtbase -, qt5 +{ + mkDerivation, + lib, + fetchFromGitHub, + cmake, + extra-cmake-modules, + kdecoration, + plasma-workspace, + qtbase, + qt5, }: mkDerivation rec { diff --git a/pkgs/data/themes/material-kwin-decoration/default.nix b/pkgs/data/themes/material-kwin-decoration/default.nix index 85bf37cc7892aa..a32eb8766e46a7 100644 --- a/pkgs/data/themes/material-kwin-decoration/default.nix +++ b/pkgs/data/themes/material-kwin-decoration/default.nix @@ -1,18 +1,19 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, cmake -, extra-cmake-modules -, qtx11extras -, kcoreaddons -, kguiaddons -, kconfig -, kdecoration -, kconfigwidgets -, kwindowsystem -, kiconthemes -, kwayland -, unstableGitUpdater +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + extra-cmake-modules, + qtx11extras, + kcoreaddons, + kguiaddons, + kconfig, + kdecoration, + kconfigwidgets, + kwindowsystem, + kiconthemes, + kwayland, + unstableGitUpdater, }: mkDerivation rec { @@ -32,7 +33,10 @@ mkDerivation rec { --replace "add_definitions (-Wall -Werror)" "add_definitions (-Wall)" ''; - nativeBuildInputs = [ cmake extra-cmake-modules ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; buildInputs = [ qtx11extras diff --git a/pkgs/data/themes/nordic/default.nix b/pkgs/data/themes/nordic/default.nix index e7c4648e555a09..5281f455ca1181 100644 --- a/pkgs/data/themes/nordic/default.nix +++ b/pkgs/data/themes/nordic/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, breeze-icons -, gtk-engine-murrine -, jdupes -, plasma-framework -, plasma-workspace +{ + lib, + stdenvNoCC, + fetchFromGitHub, + breeze-icons, + gtk-engine-murrine, + jdupes, + plasma-framework, + plasma-workspace, }: stdenvNoCC.mkDerivation rec { @@ -80,7 +81,10 @@ stdenvNoCC.mkDerivation rec { sourceRoot = "."; - outputs = [ "out" "sddm" ]; + outputs = [ + "out" + "sddm" + ]; nativeBuildInputs = [ jdupes ]; diff --git a/pkgs/data/themes/plata/default.nix b/pkgs/data/themes/plata/default.nix index 0400ba5b3c3546..cdcd080e165701 100644 --- a/pkgs/data/themes/plata/default.nix +++ b/pkgs/data/themes/plata/default.nix @@ -1,20 +1,34 @@ -{ lib, stdenv, fetchFromGitLab, autoreconfHook, pkg-config, parallel -, sassc, inkscape, libxml2, glib, gtk_engines, gtk-engine-murrine -, cinnamonSupport ? true -, gnomeFlashbackSupport ? true -, gnomeShellSupport ? true -, openboxSupport ? true -, xfceSupport ? true -, mateSupport ? true, gtk3, marco -, gtkNextSupport ? false -, plankSupport ? false -, steamSupport ? false -, telegramSupport ? false, zip -, tweetdeckSupport ? false -, selectionColor ? null # Primary color for 'selected-items' (Default: #3F51B5 = Indigo500) -, accentColor ? null # Secondary color for notifications and OSDs (Default: #7986CB = Indigo300) -, suggestionColor ? null # Secondary color for 'suggested' buttons (Default: #673AB7 = DPurple500) -, destructionColor ? null # Tertiary color for 'destructive' buttons (Default: #F44336 = Red500) +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + parallel, + sassc, + inkscape, + libxml2, + glib, + gtk_engines, + gtk-engine-murrine, + cinnamonSupport ? true, + gnomeFlashbackSupport ? true, + gnomeShellSupport ? true, + openboxSupport ? true, + xfceSupport ? true, + mateSupport ? true, + gtk3, + marco, + gtkNextSupport ? false, + plankSupport ? false, + steamSupport ? false, + telegramSupport ? false, + zip, + tweetdeckSupport ? false, + selectionColor ? null, # Primary color for 'selected-items' (Default: #3F51B5 = Indigo500) + accentColor ? null, # Secondary color for notifications and OSDs (Default: #7986CB = Indigo300) + suggestionColor ? null, # Secondary color for 'suggested' buttons (Default: #673AB7 = DPurple500) + destructionColor ? null, # Tertiary color for 'destructive' buttons (Default: #F44336 = Red500) }: stdenv.mkDerivation rec { @@ -28,17 +42,21 @@ stdenv.mkDerivation rec { sha256 = "1iwvlv9qcrjyfbzab00vjqafmp3vdybz1hi02r6lwbgvwyfyrifk"; }; - nativeBuildInputs = [ - autoreconfHook - pkg-config - parallel - sassc - inkscape - libxml2 - glib - ] - ++ lib.optionals mateSupport [ gtk3 marco ] - ++ lib.optional telegramSupport zip; + nativeBuildInputs = + [ + autoreconfHook + pkg-config + parallel + sassc + inkscape + libxml2 + glib + ] + ++ lib.optionals mateSupport [ + gtk3 + marco + ] + ++ lib.optional telegramSupport zip; buildInputs = [ gtk_engines ]; @@ -52,7 +70,8 @@ stdenv.mkDerivation rec { let inherit (lib) enableFeature optional; withOptional = value: feat: optional (value != null) "--with-${feat}=${value}"; - in [ + in + [ "--enable-parallel" (enableFeature cinnamonSupport "cinnamon") (enableFeature gnomeFlashbackSupport "flashback") @@ -81,7 +100,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "GTK theme based on Material Design Refresh"; homepage = "https://gitlab.com/tista500/plata-theme"; - license = with licenses; [ gpl2 cc-by-sa-40 ]; + license = with licenses; [ + gpl2 + cc-by-sa-40 + ]; platforms = platforms.linux; maintainers = [ maintainers.tadfisher ]; }; diff --git a/pkgs/data/themes/qogir-kde/default.nix b/pkgs/data/themes/qogir-kde/default.nix index 6c404d8c534e89..235f4cc3cd455d 100644 --- a/pkgs/data/themes/qogir-kde/default.nix +++ b/pkgs/data/themes/qogir-kde/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, unstableGitUpdater +{ + lib, + stdenvNoCC, + fetchFromGitHub, + unstableGitUpdater, }: # NOTE: diff --git a/pkgs/data/themes/qtcurve/default.nix b/pkgs/data/themes/qtcurve/default.nix index 0b639133a4a7eb..dd2aaeed7d35ef 100644 --- a/pkgs/data/themes/qtcurve/default.nix +++ b/pkgs/data/themes/qtcurve/default.nix @@ -1,10 +1,31 @@ -{ lib, fetchFromGitHub, cmake, extra-cmake-modules, pkg-config, mkDerivation -, gtk2Support ? true, gtk2 -, qtbase, qtsvg, qtx11extras # Toolkit dependencies -, karchive, kconfig, kconfigwidgets, kio, frameworkintegration -, kguiaddons, ki18n, kwindowsystem, kdelibs4support, kiconthemes -, libpthreadstubs, pcre, libXdmcp, libX11, libXau # X11 dependencies -, fetchpatch +{ + lib, + fetchFromGitHub, + cmake, + extra-cmake-modules, + pkg-config, + mkDerivation, + gtk2Support ? true, + gtk2, + qtbase, + qtsvg, + qtx11extras, # Toolkit dependencies + karchive, + kconfig, + kconfigwidgets, + kio, + frameworkintegration, + kguiaddons, + ki18n, + kwindowsystem, + kdelibs4support, + kiconthemes, + libpthreadstubs, + pcre, + libXdmcp, + libX11, + libXau, # X11 dependencies + fetchpatch, }: mkDerivation rec { @@ -30,15 +51,31 @@ mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake extra-cmake-modules pkg-config ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + pkg-config + ]; buildInputs = [ - qtbase qtsvg qtx11extras - karchive kconfig kconfigwidgets kio kiconthemes kguiaddons ki18n - kwindowsystem kdelibs4support frameworkintegration + qtbase + qtsvg + qtx11extras + karchive + kconfig + kconfigwidgets + kio + kiconthemes + kguiaddons + ki18n + kwindowsystem + kdelibs4support + frameworkintegration libpthreadstubs pcre - libXdmcp libX11 libXau + libXdmcp + libX11 + libXau ] ++ lib.optional gtk2Support gtk2; preConfigure = '' diff --git a/pkgs/data/themes/sddm-astronaut/default.nix b/pkgs/data/themes/sddm-astronaut/default.nix index 39064b3c7a8e85..e636c05ff3282e 100644 --- a/pkgs/data/themes/sddm-astronaut/default.nix +++ b/pkgs/data/themes/sddm-astronaut/default.nix @@ -1,4 +1,9 @@ -{ pkgs, lib, stdenvNoCC, themeConfig ? null }: +{ + pkgs, + lib, + stdenvNoCC, + themeConfig ? null, +}: stdenvNoCC.mkDerivation rec { pname = "sddm-astronaut"; version = "1.0"; @@ -11,7 +16,10 @@ stdenvNoCC.mkDerivation rec { }; dontWrapQtApps = true; - propagatedBuildInputs = with pkgs.kdePackages; [ qt5compat qtsvg ]; + propagatedBuildInputs = with pkgs.kdePackages; [ + qt5compat + qtsvg + ]; installPhase = let @@ -23,7 +31,8 @@ stdenvNoCC.mkDerivation rec { '' mkdir -p ${basePath} cp -r $src/* ${basePath} - '' + lib.optionalString (themeConfig != null) '' + '' + + lib.optionalString (themeConfig != null) '' ln -sf ${configFile} ${basePath}/theme.conf.user ''; diff --git a/pkgs/data/themes/sddm-sugar-dark/default.nix b/pkgs/data/themes/sddm-sugar-dark/default.nix index 7cbc1c121e3d71..0f10a916cf9502 100644 --- a/pkgs/data/themes/sddm-sugar-dark/default.nix +++ b/pkgs/data/themes/sddm-sugar-dark/default.nix @@ -1,4 +1,9 @@ -{ pkgs, lib, stdenvNoCC, themeConfig ? null }: +{ + pkgs, + lib, + stdenvNoCC, + themeConfig ? null, +}: stdenvNoCC.mkDerivation rec { pname = "sddm-sugar-dark"; @@ -25,7 +30,8 @@ stdenvNoCC.mkDerivation rec { '' mkdir -p ${basePath} cp -r $src/* ${basePath} - '' + lib.optionalString (themeConfig != null) '' + '' + + lib.optionalString (themeConfig != null) '' ln -sf ${configFile} ${basePath}/theme.conf.user ''; diff --git a/pkgs/data/themes/utterly-nord-plasma/default.nix b/pkgs/data/themes/utterly-nord-plasma/default.nix index c35f919aedd460..b181ca18c56633 100644 --- a/pkgs/data/themes/utterly-nord-plasma/default.nix +++ b/pkgs/data/themes/utterly-nord-plasma/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, breeze-icons -, kdeclarative -, kirigami -, plasma-framework -, plasma-workspace +{ + lib, + stdenv, + fetchFromGitHub, + breeze-icons, + kdeclarative, + kirigami, + plasma-framework, + plasma-workspace, }: stdenv.mkDerivation rec { diff --git a/pkgs/data/themes/whitesur-kde/default.nix b/pkgs/data/themes/whitesur-kde/default.nix index b85767e631b36d..3c42179c86a0a5 100644 --- a/pkgs/data/themes/whitesur-kde/default.nix +++ b/pkgs/data/themes/whitesur-kde/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, gitUpdater +{ + lib, + stdenvNoCC, + fetchFromGitHub, + gitUpdater, }: # NOTE: diff --git a/pkgs/desktops/deepin/core/dde-gsettings-schemas/default.nix b/pkgs/desktops/deepin/core/dde-gsettings-schemas/default.nix index 459306bd1c76e8..799714d98ec213 100644 --- a/pkgs/desktops/deepin/core/dde-gsettings-schemas/default.nix +++ b/pkgs/desktops/deepin/core/dde-gsettings-schemas/default.nix @@ -28,20 +28,21 @@ let in # TODO: Having https://github.com/NixOS/nixpkgs/issues/54150 would supersede this -runCommand "nixos-gsettings-desktop-schemas" { preferLocalBuild = true; } -'' - data_dir="$out/share/gsettings-schemas/nixos-gsettings-overrides" - schema_dir="$data_dir/glib-2.0/schemas" +runCommand "nixos-gsettings-desktop-schemas" { preferLocalBuild = true; } '' + data_dir="$out/share/gsettings-schemas/nixos-gsettings-overrides" + schema_dir="$data_dir/glib-2.0/schemas" - mkdir -p $schema_dir + mkdir -p $schema_dir - ${lib.concatMapStringsSep "\n" (pkg: "cp -rf \"${glib.getSchemaPath pkg}\"/*.xml \"$schema_dir\"") gsettingsOverridePackages} + ${lib.concatMapStringsSep "\n" ( + pkg: "cp -rf \"${glib.getSchemaPath pkg}\"/*.xml \"$schema_dir\"" + ) gsettingsOverridePackages} - chmod -R a+w "$data_dir" + chmod -R a+w "$data_dir" - cat - > "$schema_dir/nixos-defaults.gschema.override" <<- EOF - ${extraGSettingsOverrides} - EOF + cat - > "$schema_dir/nixos-defaults.gschema.override" <<- EOF + ${extraGSettingsOverrides} + EOF - ${glib.dev}/bin/glib-compile-schemas $schema_dir - '' + ${glib.dev}/bin/glib-compile-schemas $schema_dir +'' diff --git a/pkgs/desktops/enlightenment/default.nix b/pkgs/desktops/enlightenment/default.nix index 76c6cc58953aa4..c4ddb4440c3c2b 100644 --- a/pkgs/desktops/enlightenment/default.nix +++ b/pkgs/desktops/enlightenment/default.nix @@ -1,19 +1,21 @@ { lib, pkgs }: -lib.makeScope pkgs.newScope (self: with self; { +lib.makeScope pkgs.newScope ( + self: with self; { - #### CORE EFL - efl = callPackage ./efl { }; + #### CORE EFL + efl = callPackage ./efl { }; - #### WINDOW MANAGER - enlightenment = callPackage ./enlightenment { }; + #### WINDOW MANAGER + enlightenment = callPackage ./enlightenment { }; - #### APPLICATIONS - econnman = callPackage ./econnman { }; - ecrire = callPackage ./ecrire { }; - ephoto = callPackage ./ephoto { }; - evisum = callPackage ./evisum { }; - rage = callPackage ./rage { }; - terminology = callPackage ./terminology { }; + #### APPLICATIONS + econnman = callPackage ./econnman { }; + ecrire = callPackage ./ecrire { }; + ephoto = callPackage ./ephoto { }; + evisum = callPackage ./evisum { }; + rage = callPackage ./rage { }; + terminology = callPackage ./terminology { }; -}) + } +) diff --git a/pkgs/desktops/enlightenment/econnman/default.nix b/pkgs/desktops/enlightenment/econnman/default.nix index b7f3f926d7f692..eba9183f32018e 100644 --- a/pkgs/desktops/enlightenment/econnman/default.nix +++ b/pkgs/desktops/enlightenment/econnman/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, pkg-config -, dbus -, efl -, python3Packages -, directoryListingUpdater +{ + lib, + stdenv, + fetchurl, + makeWrapper, + pkg-config, + dbus, + efl, + python3Packages, + directoryListingUpdater, }: stdenv.mkDerivation rec { @@ -47,6 +48,12 @@ stdenv.mkDerivation rec { homepage = "https://enlightenment.org/"; license = licenses.lgpl3; platforms = platforms.linux; - maintainers = with lib.maintainers; [ matejc ftrvxmtrx ] ++ teams.enlightenment.members; + maintainers = + with lib.maintainers; + [ + matejc + ftrvxmtrx + ] + ++ teams.enlightenment.members; }; } diff --git a/pkgs/desktops/enlightenment/ecrire/default.nix b/pkgs/desktops/enlightenment/ecrire/default.nix index 3f511c3a79d086..20cedff0fc21f1 100644 --- a/pkgs/desktops/enlightenment/ecrire/default.nix +++ b/pkgs/desktops/enlightenment/ecrire/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, efl -, directoryListingUpdater +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + efl, + directoryListingUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/enlightenment/efl/default.nix b/pkgs/desktops/enlightenment/efl/default.nix index ce6f7753786349..8b9d3ccdc692fe 100644 --- a/pkgs/desktops/enlightenment/efl/default.nix +++ b/pkgs/desktops/enlightenment/efl/default.nix @@ -1,59 +1,60 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, SDL2 -, alsa-lib -, bullet -, check -, curl -, dbus -, doxygen -, expat -, fontconfig -, freetype -, fribidi -, ghostscript -, giflib -, glib -, gst_all_1 -, gtk3 -, harfbuzz -, hicolor-icon-theme -, ibus -, jbig2dec -, libGL -, libdrm -, libinput -, libjpeg -, libpng -, libpulseaudio -, libraw -, librsvg -, libsndfile -, libspectre -, libtiff -, libwebp -, libxkbcommon -, luajit -, lz4 -, mesa -, mint-x-icons -, openjpeg -, openssl -, poppler -, systemd -, udev -, util-linux -, wayland -, wayland-protocols -, wayland-scanner -, writeText -, xorg -, zlib -, directoryListingUpdater +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + SDL2, + alsa-lib, + bullet, + check, + curl, + dbus, + doxygen, + expat, + fontconfig, + freetype, + fribidi, + ghostscript, + giflib, + glib, + gst_all_1, + gtk3, + harfbuzz, + hicolor-icon-theme, + ibus, + jbig2dec, + libGL, + libdrm, + libinput, + libjpeg, + libpng, + libpulseaudio, + libraw, + librsvg, + libsndfile, + libspectre, + libtiff, + libwebp, + libxkbcommon, + luajit, + lz4, + mesa, + mint-x-icons, + openjpeg, + openssl, + poppler, + systemd, + udev, + util-linux, + wayland, + wayland-protocols, + wayland-scanner, + writeText, + xorg, + zlib, + directoryListingUpdater, }: stdenv.mkDerivation rec { @@ -211,8 +212,18 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Enlightenment foundation libraries"; homepage = "https://enlightenment.org/"; - license = with licenses; [ bsd2 lgpl2Only licenses.zlib ]; + license = with licenses; [ + bsd2 + lgpl2Only + licenses.zlib + ]; platforms = platforms.linux; - maintainers = with maintainers; [ matejc ftrvxmtrx ] ++ teams.enlightenment.members; + maintainers = + with maintainers; + [ + matejc + ftrvxmtrx + ] + ++ teams.enlightenment.members; }; } diff --git a/pkgs/desktops/enlightenment/enlightenment/default.nix b/pkgs/desktops/enlightenment/enlightenment/default.nix index 198dae282dfae6..f3c61f2e61f2a0 100644 --- a/pkgs/desktops/enlightenment/enlightenment/default.nix +++ b/pkgs/desktops/enlightenment/enlightenment/default.nix @@ -1,23 +1,28 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, gettext -, alsa-lib -, acpid -, bc -, ddcutil -, efl -, libexif -, pam -, xkeyboard_config -, udisks2 -, waylandSupport ? false, wayland-protocols, xwayland -, bluetoothSupport ? true, bluez5 -, pulseSupport ? !stdenv.hostPlatform.isDarwin, libpulseaudio -, directoryListingUpdater +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + gettext, + alsa-lib, + acpid, + bc, + ddcutil, + efl, + libexif, + pam, + xkeyboard_config, + udisks2, + waylandSupport ? false, + wayland-protocols, + xwayland, + bluetoothSupport ? true, + bluez5, + pulseSupport ? !stdenv.hostPlatform.isDarwin, + libpulseaudio, + directoryListingUpdater, }: stdenv.mkDerivation rec { @@ -36,21 +41,24 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - alsa-lib - acpid # for systems with ACPI for lid events, AC/Battery plug in/out etc - bc # for the Everything module calculator mode - ddcutil # specifically libddcutil.so.2 for backlight control - efl - libexif - pam - xkeyboard_config - udisks2 # for removable storage mounting/unmounting - ] - ++ lib.optional bluetoothSupport bluez5 # for bluetooth configuration and control - ++ lib.optional pulseSupport libpulseaudio # for proper audio device control and redirection - ++ lib.optionals waylandSupport [ wayland-protocols xwayland ] - ; + buildInputs = + [ + alsa-lib + acpid # for systems with ACPI for lid events, AC/Battery plug in/out etc + bc # for the Everything module calculator mode + ddcutil # specifically libddcutil.so.2 for backlight control + efl + libexif + pam + xkeyboard_config + udisks2 # for removable storage mounting/unmounting + ] + ++ lib.optional bluetoothSupport bluez5 # for bluetooth configuration and control + ++ lib.optional pulseSupport libpulseaudio # for proper audio device control and redirection + ++ lib.optionals waylandSupport [ + wayland-protocols + xwayland + ]; patches = [ # Executables cannot be made setuid in nix store. They should be @@ -78,6 +86,12 @@ stdenv.mkDerivation rec { homepage = "https://www.enlightenment.org"; license = licenses.bsd2; platforms = platforms.linux; - maintainers = with maintainers; [ matejc ftrvxmtrx ] ++ teams.enlightenment.members; + maintainers = + with maintainers; + [ + matejc + ftrvxmtrx + ] + ++ teams.enlightenment.members; }; } diff --git a/pkgs/desktops/enlightenment/ephoto/default.nix b/pkgs/desktops/enlightenment/ephoto/default.nix index 1fff72fdb7bd6d..7aba3c2c5b9fa6 100644 --- a/pkgs/desktops/enlightenment/ephoto/default.nix +++ b/pkgs/desktops/enlightenment/ephoto/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, efl -, directoryListingUpdater +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + efl, + directoryListingUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/enlightenment/evisum/default.nix b/pkgs/desktops/enlightenment/evisum/default.nix index 93472b6d7dbb88..63e8ab41780bc1 100644 --- a/pkgs/desktops/enlightenment/evisum/default.nix +++ b/pkgs/desktops/enlightenment/evisum/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, efl -, directoryListingUpdater +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + efl, + directoryListingUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/enlightenment/rage/default.nix b/pkgs/desktops/enlightenment/rage/default.nix index afe70fd9e327ea..8b3e3747828b59 100644 --- a/pkgs/desktops/enlightenment/rage/default.nix +++ b/pkgs/desktops/enlightenment/rage/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, efl -, gst_all_1 -, wrapGAppsHook3 -, directoryListingUpdater +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + efl, + gst_all_1, + wrapGAppsHook3, + directoryListingUpdater, }: stdenv.mkDerivation rec { @@ -43,6 +44,12 @@ stdenv.mkDerivation rec { homepage = "https://enlightenment.org/"; license = licenses.bsd2; platforms = platforms.linux; - maintainers = with maintainers; [ matejc ftrvxmtrx ] ++ teams.enlightenment.members; + maintainers = + with maintainers; + [ + matejc + ftrvxmtrx + ] + ++ teams.enlightenment.members; }; } diff --git a/pkgs/desktops/enlightenment/terminology/default.nix b/pkgs/desktops/enlightenment/terminology/default.nix index 9c2cabe7e8f004..1187ca2427e10d 100644 --- a/pkgs/desktops/enlightenment/terminology/default.nix +++ b/pkgs/desktops/enlightenment/terminology/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, python3 -, efl -, nixosTests -, directoryListingUpdater +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + python3, + efl, + nixosTests, + directoryListingUpdater, }: stdenv.mkDerivation rec { @@ -43,6 +44,12 @@ stdenv.mkDerivation rec { homepage = "https://www.enlightenment.org/about-terminology"; license = licenses.bsd2; platforms = platforms.linux; - maintainers = with maintainers; [ matejc ftrvxmtrx ] ++ teams.enlightenment.members; + maintainers = + with maintainers; + [ + matejc + ftrvxmtrx + ] + ++ teams.enlightenment.members; }; } diff --git a/pkgs/desktops/expidus/calculator/default.nix b/pkgs/desktops/expidus/calculator/default.nix index 98328b8874c6aa..528d77648b5f3f 100644 --- a/pkgs/desktops/expidus/calculator/default.nix +++ b/pkgs/desktops/expidus/calculator/default.nix @@ -1,4 +1,8 @@ -{ lib, flutter, fetchFromGitHub }: +{ + lib, + flutter, + fetchFromGitHub, +}: flutter.buildFlutterApplication rec { pname = "expidus-calculator"; version = "0.1.1-alpha"; @@ -44,7 +48,10 @@ flutter.buildFlutterApplication rec { homepage = "https://expidusos.com"; license = licenses.gpl3Only; maintainers = with maintainers; [ RossComputerGuy ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; mainProgram = "expidus-calculator"; }; } diff --git a/pkgs/desktops/expidus/file-manager/default.nix b/pkgs/desktops/expidus/file-manager/default.nix index 8de6262d86baed..b32b84d109993b 100644 --- a/pkgs/desktops/expidus/file-manager/default.nix +++ b/pkgs/desktops/expidus/file-manager/default.nix @@ -1,4 +1,8 @@ -{ lib, flutter, fetchFromGitHub }: +{ + lib, + flutter, + fetchFromGitHub, +}: flutter.buildFlutterApplication rec { pname = "expidus-file-manager"; version = "0.2.1"; @@ -44,7 +48,10 @@ flutter.buildFlutterApplication rec { homepage = "https://expidusos.com"; license = licenses.gpl3; maintainers = with maintainers; [ RossComputerGuy ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; mainProgram = "expidus-file-manager"; }; } diff --git a/pkgs/desktops/gnome-2/default.nix b/pkgs/desktops/gnome-2/default.nix index 83a163f4e36cf2..14d8ac23b6b5a9 100644 --- a/pkgs/desktops/gnome-2/default.nix +++ b/pkgs/desktops/gnome-2/default.nix @@ -1,37 +1,45 @@ -{ config, stdenv, pkgs, lib }: +{ + config, + stdenv, + pkgs, + lib, +}: -lib.makeScope pkgs.newScope (self: with self; { +lib.makeScope pkgs.newScope ( + self: with self; { -#### PLATFORM + #### PLATFORM - libIDL = callPackage ./platform/libIDL { - gettext = if stdenv.hostPlatform.isDarwin then pkgs.gettext else null; - }; + libIDL = callPackage ./platform/libIDL { + gettext = if stdenv.hostPlatform.isDarwin then pkgs.gettext else null; + }; - ORBit2 = callPackage ./platform/ORBit2 { }; + ORBit2 = callPackage ./platform/ORBit2 { }; - libart_lgpl = callPackage ./platform/libart_lgpl { }; + libart_lgpl = callPackage ./platform/libart_lgpl { }; - libglade = callPackage ./platform/libglade { }; + libglade = callPackage ./platform/libglade { }; - GConf = callPackage ./platform/GConf { }; + GConf = callPackage ./platform/GConf { }; - libgnomecanvas = callPackage ./platform/libgnomecanvas { }; + libgnomecanvas = callPackage ./platform/libgnomecanvas { }; - # for git-head builds - gnome-common = callPackage platform/gnome-common { }; + # for git-head builds + gnome-common = callPackage platform/gnome-common { }; - gnome_mime_data = callPackage ./platform/gnome-mime-data { }; + gnome_mime_data = callPackage ./platform/gnome-mime-data { }; - gtkglext = callPackage ./platform/gtkglext { }; + gtkglext = callPackage ./platform/gtkglext { }; -#### DESKTOP + #### DESKTOP - gtksourceview = callPackage ./desktop/gtksourceview { - autoreconfHook = pkgs.autoreconfHook269; - }; + gtksourceview = callPackage ./desktop/gtksourceview { + autoreconfHook = pkgs.autoreconfHook269; + }; -}) // lib.optionalAttrs config.allowAliases { + } +) +// lib.optionalAttrs config.allowAliases { # added 2024-12-02 glib = throw "gnome2.glib has been removed, please use top-level glib"; glibmm = throw "gnome2.glibmm has been removed, please use top-level glibmm"; diff --git a/pkgs/desktops/gnome-2/desktop/gtksourceview/default.nix b/pkgs/desktops/gnome-2/desktop/gtksourceview/default.nix index 94c3d49a97e0f9..95455d76db79a3 100644 --- a/pkgs/desktops/gnome-2/desktop/gtksourceview/default.nix +++ b/pkgs/desktops/gnome-2/desktop/gtksourceview/default.nix @@ -1,19 +1,36 @@ -{lib, stdenv, fetchpatch, fetchurl, autoreconfHook, pkg-config, atk, cairo, glib -, gnome-common, gtk2, pango -, libxml2Python, perl, intltool, gettext, gtk-mac-integration-gtk2 -, testers +{ + lib, + stdenv, + fetchpatch, + fetchurl, + autoreconfHook, + pkg-config, + atk, + cairo, + glib, + gnome-common, + gtk2, + pango, + libxml2Python, + perl, + intltool, + gettext, + gtk-mac-integration-gtk2, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "gtksourceview"; version = "2.10.5"; - src = let - inherit (finalAttrs) pname version; - in fetchurl { - url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.bz2"; - sha256 = "c585773743b1df8a04b1be7f7d90eecdf22681490d6810be54c81a7ae152191e"; - }; + src = + let + inherit (finalAttrs) pname version; + in + fetchurl { + url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.bz2"; + sha256 = "c585773743b1df8a04b1be7f7d90eecdf22681490d6810be54c81a7ae152191e"; + }; patches = lib.optionals stdenv.hostPlatform.isDarwin [ (fetchpatch { @@ -28,14 +45,25 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - nativeBuildInputs = [ pkg-config intltool ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ autoreconfHook ]; - buildInputs = [ - atk cairo glib gtk2 - pango libxml2Python perl - gettext - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - gnome-common gtk-mac-integration-gtk2 - ]; + nativeBuildInputs = [ + pkg-config + intltool + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ autoreconfHook ]; + buildInputs = + [ + atk + cairo + glib + gtk2 + pango + libxml2Python + perl + gettext + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + gnome-common + gtk-mac-integration-gtk2 + ]; preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin '' intltoolize --force diff --git a/pkgs/desktops/gnome-2/platform/GConf/default.nix b/pkgs/desktops/gnome-2/platform/GConf/default.nix index ea6730f88e2ee5..b2d6986e776cef 100644 --- a/pkgs/desktops/gnome-2/platform/GConf/default.nix +++ b/pkgs/desktops/gnome-2/platform/GConf/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, pkg-config, dbus-glib, glib, ORBit2, libxml2, polkit, python3, intltool }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + dbus-glib, + glib, + ORBit2, + libxml2, + polkit, + python3, + intltool, +}: stdenv.mkDerivation rec { pname = "gconf"; @@ -9,18 +21,34 @@ stdenv.mkDerivation rec { sha256 = "0k3q9nh53yhc9qxf1zaicz4sk8p3kzq4ndjdsgpaa2db0ccbj4hr"; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; strictDeps = true; - buildInputs = [ ORBit2 libxml2 ] + buildInputs = + [ + ORBit2 + libxml2 + ] # polkit requires pam, which requires shadow.h, which is not available on # darwin ++ lib.optional (!stdenv.hostPlatform.isDarwin) polkit; - propagatedBuildInputs = [ glib dbus-glib ]; + propagatedBuildInputs = [ + glib + dbus-glib + ]; - nativeBuildInputs = [ pkg-config intltool python3 glib ]; + nativeBuildInputs = [ + pkg-config + intltool + python3 + glib + ]; configureFlags = # fixes the "libgconfbackend-oldxml.so is not portable" error on darwin diff --git a/pkgs/desktops/gnome-2/platform/ORBit2/default.nix b/pkgs/desktops/gnome-2/platform/ORBit2/default.nix index 67208b6d2cdefd..566767d2fc40fd 100644 --- a/pkgs/desktops/gnome-2/platform/ORBit2/default.nix +++ b/pkgs/desktops/gnome-2/platform/ORBit2/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, libIDL, libintl, buildPackages }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + libIDL, + libintl, + buildPackages, +}: stdenv.mkDerivation rec { pname = "ORBit2"; @@ -15,10 +24,19 @@ stdenv.mkDerivation rec { # sh: gcc: not found # output does not contain binaries for build depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ pkg-config libintl ]; - propagatedBuildInputs = [ glib libIDL ]; + nativeBuildInputs = [ + pkg-config + libintl + ]; + propagatedBuildInputs = [ + glib + libIDL + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; configureFlags = lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ "--with-idl-compiler=${lib.getExe' buildPackages.gnome2.ORBit2 "orbit-idl-2"}" @@ -54,9 +72,9 @@ stdenv.mkDerivation rec { enableParallelBuilding = false; meta = with lib; { - homepage = "https://developer-old.gnome.org/ORBit2/"; + homepage = "https://developer-old.gnome.org/ORBit2/"; description = "CORBA 2.4-compliant Object Request Broker"; - platforms = platforms.unix; + platforms = platforms.unix; maintainers = with maintainers; [ lovek323 ]; longDescription = '' diff --git a/pkgs/desktops/gnome-2/platform/gnome-common/default.nix b/pkgs/desktops/gnome-2/platform/gnome-common/default.nix index eba913c80c2d9c..8fc9d7a51a307b 100644 --- a/pkgs/desktops/gnome-2/platform/gnome-common/default.nix +++ b/pkgs/desktops/gnome-2/platform/gnome-common/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, which }: +{ + lib, + stdenv, + fetchurl, + which, +}: stdenv.mkDerivation rec { pname = "gnome-common"; @@ -11,9 +16,11 @@ stdenv.mkDerivation rec { propagatedBuildInputs = [ which ]; # autogen.sh which is using gnome-common tends to require which - patches = [(fetchurl { - name = "gnome-common-patch"; - url = "https://bug697543.bugzilla-attachments.gnome.org/attachment.cgi?id=240935"; - sha256 = "17abp7czfzirjm7qsn2czd03hdv9kbyhk3lkjxg2xsf5fky7z7jl"; - })]; + patches = [ + (fetchurl { + name = "gnome-common-patch"; + url = "https://bug697543.bugzilla-attachments.gnome.org/attachment.cgi?id=240935"; + sha256 = "17abp7czfzirjm7qsn2czd03hdv9kbyhk3lkjxg2xsf5fky7z7jl"; + }) + ]; } diff --git a/pkgs/desktops/gnome-2/platform/gnome-mime-data/default.nix b/pkgs/desktops/gnome-2/platform/gnome-mime-data/default.nix index 1604dbe0cf08f8..5335842f1fe32a 100644 --- a/pkgs/desktops/gnome-2/platform/gnome-mime-data/default.nix +++ b/pkgs/desktops/gnome-2/platform/gnome-mime-data/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, intltool }: +{ + lib, + stdenv, + fetchurl, + intltool, +}: stdenv.mkDerivation rec { pname = "gnome-mime-data"; diff --git a/pkgs/desktops/gnome-2/platform/gtkglext/default.nix b/pkgs/desktops/gnome-2/platform/gtkglext/default.nix index ed0971b7131b46..c2632ec9e51b0f 100644 --- a/pkgs/desktops/gnome-2/platform/gtkglext/default.nix +++ b/pkgs/desktops/gnome-2/platform/gtkglext/default.nix @@ -1,18 +1,20 @@ -{ lib, stdenv -, fetchFromGitLab -, pkg-config -, gtk-doc -, autoconf -, automake -, which -, libtool -, gobject-introspection -, glib -, gtk2 -, libGLU -, libGL -, pango -, xorg +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + gtk-doc, + autoconf, + automake, + which, + libtool, + gobject-introspection, + glib, + gtk2, + libGLU, + libGL, + pango, + xorg, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/gnome-2/platform/libIDL/default.nix b/pkgs/desktops/gnome-2/platform/libIDL/default.nix index 81f8e6d08e1709..620dae7ce46419 100644 --- a/pkgs/desktops/gnome-2/platform/libIDL/default.nix +++ b/pkgs/desktops/gnome-2/platform/libIDL/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, flex, bison, pkg-config, glib, gettext }: +{ + lib, + stdenv, + fetchurl, + flex, + bison, + pkg-config, + glib, + gettext, +}: stdenv.mkDerivation rec { pname = "libIDL"; @@ -11,9 +20,16 @@ stdenv.mkDerivation rec { strictDeps = true; - buildInputs = [ glib gettext ]; + buildInputs = [ + glib + gettext + ]; - nativeBuildInputs = [ flex bison pkg-config ]; + nativeBuildInputs = [ + flex + bison + pkg-config + ]; configureFlags = lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ # before openembedded removed libIDL diff --git a/pkgs/desktops/gnome-2/platform/libart_lgpl/default.nix b/pkgs/desktops/gnome-2/platform/libart_lgpl/default.nix index 5f21e59a4c5230..6cc2d5ceab6a53 100644 --- a/pkgs/desktops/gnome-2/platform/libart_lgpl/default.nix +++ b/pkgs/desktops/gnome-2/platform/libart_lgpl/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libart_lgpl"; diff --git a/pkgs/desktops/gnome-2/platform/libglade/default.nix b/pkgs/desktops/gnome-2/platform/libglade/default.nix index dc6e192ed1616e..73a94741479483 100644 --- a/pkgs/desktops/gnome-2/platform/libglade/default.nix +++ b/pkgs/desktops/gnome-2/platform/libglade/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, gtk2, libxml2, gettext }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + libxml2, + gettext, +}: stdenv.mkDerivation rec { pname = "libglade"; @@ -9,11 +17,17 @@ stdenv.mkDerivation rec { sha256 = "1v2x2s04jry4gpabws92i0wq2ghd47yr5n9nhgnkd7c38xv1wdk4"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; strictDeps = true; - nativeBuildInputs = [ pkg-config gettext ]; + nativeBuildInputs = [ + pkg-config + gettext + ]; buildInputs = [ gtk2 ]; propagatedBuildInputs = [ libxml2 ]; diff --git a/pkgs/desktops/gnome-2/platform/libgnomecanvas/default.nix b/pkgs/desktops/gnome-2/platform/libgnomecanvas/default.nix index 529e73b8747871..2c6b6e2a546f1b 100644 --- a/pkgs/desktops/gnome-2/platform/libgnomecanvas/default.nix +++ b/pkgs/desktops/gnome-2/platform/libgnomecanvas/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, pkg-config, gtk2, intltool, libart_lgpl, libglade, glib }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + intltool, + libart_lgpl, + libglade, + glib, +}: stdenv.mkDerivation rec { pname = "libgnomecanvas"; @@ -9,11 +19,21 @@ stdenv.mkDerivation rec { sha256 = "0h6xvswbqspdifnyh5pm2pqq55yp3kn6yrswq7ay9z49hkh7i6w5"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; strictDeps = true; buildInputs = [ libglade ]; - nativeBuildInputs = [ pkg-config intltool glib ]; - propagatedBuildInputs = [ libart_lgpl gtk2 ]; + nativeBuildInputs = [ + pkg-config + intltool + glib + ]; + propagatedBuildInputs = [ + libart_lgpl + gtk2 + ]; } diff --git a/pkgs/desktops/gnome/extensions/EasyScreenCast/default.nix b/pkgs/desktops/gnome/extensions/EasyScreenCast/default.nix index 8feb342638c9ab..d331f1eae6a6c4 100644 --- a/pkgs/desktops/gnome/extensions/EasyScreenCast/default.nix +++ b/pkgs/desktops/gnome/extensions/EasyScreenCast/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, substituteAll, glib, gnome-shell, gettext, jq, intltool }: +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + glib, + gnome-shell, + gettext, + jq, + intltool, +}: stdenv.mkDerivation (finalAttrs: { pname = "gnome-shell-extension-EasyScreenCast"; @@ -19,7 +29,10 @@ stdenv.mkDerivation (finalAttrs: { ]; nativeBuildInputs = [ - glib gettext jq intltool + glib + gettext + jq + intltool ]; makeFlags = [ "INSTALLBASE=$(out)/share/gnome-shell/extensions" ]; diff --git a/pkgs/desktops/gnome/extensions/arcmenu/default.nix b/pkgs/desktops/gnome/extensions/arcmenu/default.nix index 157dd3edf38ae2..9e78ddc152257f 100644 --- a/pkgs/desktops/gnome/extensions/arcmenu/default.nix +++ b/pkgs/desktops/gnome/extensions/arcmenu/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitLab, glib, gettext, substituteAll, gnome-menus }: +{ + lib, + stdenv, + fetchFromGitLab, + glib, + gettext, + substituteAll, + gnome-menus, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-arcmenu"; @@ -19,7 +27,8 @@ stdenv.mkDerivation rec { ]; buildInputs = [ - glib gettext + glib + gettext ]; makeFlags = [ "INSTALLBASE=${placeholder "out"}/share/gnome-shell/extensions" ]; diff --git a/pkgs/desktops/gnome/extensions/argos/default.nix b/pkgs/desktops/gnome/extensions/argos/default.nix index 9f4719a3226e4e..f74bfb6773d3cc 100644 --- a/pkgs/desktops/gnome/extensions/argos/default.nix +++ b/pkgs/desktops/gnome/extensions/argos/default.nix @@ -1,4 +1,9 @@ -{ fetchFromGitHub, lib, stdenv, unstableGitUpdater }: +{ + fetchFromGitHub, + lib, + stdenv, + unstableGitUpdater, +}: stdenv.mkDerivation rec { pname = "argos"; diff --git a/pkgs/desktops/gnome/extensions/clock-override/default.nix b/pkgs/desktops/gnome/extensions/clock-override/default.nix index 919dfb68de0467..4da95c4fc18414 100644 --- a/pkgs/desktops/gnome/extensions/clock-override/default.nix +++ b/pkgs/desktops/gnome/extensions/clock-override/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchzip, gnome-shell, gettext, glib }: +{ + lib, + stdenv, + fetchzip, + gnome-shell, + gettext, + glib, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-clock-override"; @@ -15,7 +22,10 @@ stdenv.mkDerivation rec { extensionPortalSlug = "clock-override"; }; - nativeBuildInputs = [ gettext glib ]; + nativeBuildInputs = [ + gettext + glib + ]; buildPhase = '' runHook preBuild diff --git a/pkgs/desktops/gnome/extensions/default.nix b/pkgs/desktops/gnome/extensions/default.nix index 4e7b3c75e8b77b..39f784225b4f4b 100644 --- a/pkgs/desktops/gnome/extensions/default.nix +++ b/pkgs/desktops/gnome/extensions/default.nix @@ -1,6 +1,7 @@ -{ lib -, callPackage -, config +{ + lib, + callPackage, + config, }: let buildShellExtension = callPackage ./buildGnomeExtension.nix { }; @@ -12,25 +13,29 @@ let extensionRenames = import ./extensionRenames.nix; # Take all extensions from the index that match the gnome version, build them and put them into a list of derivations - produceExtensionsList = shell-version: + produceExtensionsList = + shell-version: lib.trivial.pipe extensionsIndex [ # Does a given extension match our current shell version? - (builtins.filter - (extension: (builtins.hasAttr shell-version extension."shell_version_map")) - ) + (builtins.filter (extension: (builtins.hasAttr shell-version extension."shell_version_map"))) # Take in an `extension` object from the JSON and transform it into the correct args to call `buildShellExtension` - (map - (extension: { - inherit (extension) uuid name description link pname; - inherit (extension.shell_version_map.${shell-version}) version sha256 metadata; - }) - ) + (map (extension: { + inherit (extension) + uuid + name + description + link + pname + ; + inherit (extension.shell_version_map.${shell-version}) version sha256 metadata; + })) # Build them (map buildShellExtension) ]; # Map the list of extensions to an attrset based on the UUID as key - mapUuidNames = extensions: + mapUuidNames = + extensions: lib.trivial.pipe extensions [ (map (extension: lib.nameValuePair extension.extensionUuid extension)) builtins.listToAttrs @@ -39,22 +44,28 @@ let # Map the list of extensions to an attrset based on the pname as key, which is more human readable than the UUID # We also take care of conflict renaming in here - mapReadableNames = extensionsList: lib.trivial.pipe extensionsList [ - # Filter out all extensions that map to null - (lib.filter (extension: - !( - (builtins.hasAttr extension.extensionUuid extensionRenames) - && ((builtins.getAttr extension.extensionUuid extensionRenames) == null) - ) - )) - # Map all extensions to their pname, with potential overwrites - (map (extension: - lib.nameValuePair (extensionRenames.${extension.extensionUuid} or extension.extensionPortalSlug) extension - )) - builtins.listToAttrs - ]; + mapReadableNames = + extensionsList: + lib.trivial.pipe extensionsList [ + # Filter out all extensions that map to null + (lib.filter ( + extension: + !( + (builtins.hasAttr extension.extensionUuid extensionRenames) + && ((builtins.getAttr extension.extensionUuid extensionRenames) == null) + ) + )) + # Map all extensions to their pname, with potential overwrites + (map ( + extension: + lib.nameValuePair (extensionRenames.${extension.extensionUuid} or extension.extensionPortalSlug + ) extension + )) + builtins.listToAttrs + ]; -in rec { +in +rec { # Remember to import all these in all-packages.nix gnome38Extensions = mapUuidNames (produceExtensionsList "38"); gnome40Extensions = mapUuidNames (produceExtensionsList "40"); @@ -70,23 +81,27 @@ in rec { gnomeExtensions = lib.trivial.pipe (gnome45Extensions // gnome46Extensions // gnome47Extensions) [ (v: builtins.removeAttrs v [ "__attrsFailEvaluation" ]) # Apply some custom patches for automatically packaged extensions - (callPackage ./extensionOverrides.nix {}) + (callPackage ./extensionOverrides.nix { }) # Add all manually packaged extensions (extensions: extensions // (import ./manuallyPackaged.nix { inherit callPackage; })) # Map the extension UUIDs to readable names (lib.attrValues) (mapReadableNames) # Add some aliases - (extensions: extensions // lib.optionalAttrs config.allowAliases { - unite-shell = gnomeExtensions.unite; # added 2021-01-19 - arc-menu = gnomeExtensions.arcmenu; # added 2021-02-14 - disable-unredirect = gnomeExtensions.disable-unredirect-fullscreen-windows; # added 2021-11-20 + ( + extensions: + extensions + // lib.optionalAttrs config.allowAliases { + unite-shell = gnomeExtensions.unite; # added 2021-01-19 + arc-menu = gnomeExtensions.arcmenu; # added 2021-02-14 + disable-unredirect = gnomeExtensions.disable-unredirect-fullscreen-windows; # added 2021-11-20 - icon-hider = throw "gnomeExtensions.icon-hider was removed on 2024-03-15. The extension has not received any updates since 2020/3.34."; - nohotcorner = throw "gnomeExtensions.nohotcorner removed since 2019-10-09: Since 3.34, it is a part of GNOME Shell configurable through GNOME Tweaks."; - mediaplayer = throw "gnomeExtensions.mediaplayer deprecated since 2019-09-23: retired upstream https://github.com/JasonLG1979/gnome-shell-extensions-mediaplayer/blob/master/README.md"; - remove-dropdown-arrows = throw "gnomeExtensions.remove-dropdown-arrows removed since 2021-05-25: The extensions has not seen an update sine GNOME 3.34. Furthermore, the functionality it provides is obsolete as of GNOME 40."; - }) + icon-hider = throw "gnomeExtensions.icon-hider was removed on 2024-03-15. The extension has not received any updates since 2020/3.34."; + nohotcorner = throw "gnomeExtensions.nohotcorner removed since 2019-10-09: Since 3.34, it is a part of GNOME Shell configurable through GNOME Tweaks."; + mediaplayer = throw "gnomeExtensions.mediaplayer deprecated since 2019-09-23: retired upstream https://github.com/JasonLG1979/gnome-shell-extensions-mediaplayer/blob/master/README.md"; + remove-dropdown-arrows = throw "gnomeExtensions.remove-dropdown-arrows removed since 2021-05-25: The extensions has not seen an update sine GNOME 3.34. Furthermore, the functionality it provides is obsolete as of GNOME 40."; + } + ) # Export buildShellExtension function (extensions: extensions // { inherit buildShellExtension; }) # Make the set "public" diff --git a/pkgs/desktops/gnome/extensions/drop-down-terminal/default.nix b/pkgs/desktops/gnome/extensions/drop-down-terminal/default.nix index ebcf918df10393..e5302645d5605c 100644 --- a/pkgs/desktops/gnome/extensions/drop-down-terminal/default.nix +++ b/pkgs/desktops/gnome/extensions/drop-down-terminal/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, substituteAll, gjs, vte, gnome }: +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + gjs, + vte, + gnome, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-drop-down-terminal"; diff --git a/pkgs/desktops/gnome/extensions/icon-hider/default.nix b/pkgs/desktops/gnome/extensions/icon-hider/default.nix index f93c96f30191f4..d55f097134fab7 100644 --- a/pkgs/desktops/gnome/extensions/icon-hider/default.nix +++ b/pkgs/desktops/gnome/extensions/icon-hider/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, gnome-shell }: +{ + lib, + stdenv, + fetchFromGitHub, + gnome-shell, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-icon-hider"; diff --git a/pkgs/desktops/gnome/extensions/impatience/default.nix b/pkgs/desktops/gnome/extensions/impatience/default.nix index dfef4a3a7262a3..aa96fad5c4c08b 100644 --- a/pkgs/desktops/gnome/extensions/impatience/default.nix +++ b/pkgs/desktops/gnome/extensions/impatience/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, glib }: +{ + lib, + stdenv, + fetchFromGitHub, + glib, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-impatience"; @@ -36,7 +41,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Speed up builtin gnome-shell animations"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ timbertson tiramiseb ]; + maintainers = with maintainers; [ + timbertson + tiramiseb + ]; homepage = "http://gfxmonk.net/dist/0install/gnome-shell-impatience.xml"; }; } diff --git a/pkgs/desktops/gnome/extensions/no-title-bar/default.nix b/pkgs/desktops/gnome/extensions/no-title-bar/default.nix index 6e4530817f909c..f8a2ef12b80fae 100644 --- a/pkgs/desktops/gnome/extensions/no-title-bar/default.nix +++ b/pkgs/desktops/gnome/extensions/no-title-bar/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, substituteAll, glib, gettext, xorg }: +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + glib, + gettext, + xorg, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-no-title-bar"; @@ -11,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "07ddw47binlsbyvgy4xkdjvd40zyp7nwd17r6k7w54d50vmnwhvb"; }; - nativeBuildInputs = [ glib gettext ]; + nativeBuildInputs = [ + glib + gettext + ]; patches = [ (substituteAll { diff --git a/pkgs/desktops/gnome/extensions/pidgin-im-integration/default.nix b/pkgs/desktops/gnome/extensions/pidgin-im-integration/default.nix index 3dc9fa61b7473c..c46a1b7447c45a 100644 --- a/pkgs/desktops/gnome/extensions/pidgin-im-integration/default.nix +++ b/pkgs/desktops/gnome/extensions/pidgin-im-integration/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, glib, gnome-shell }: +{ + lib, + stdenv, + fetchFromGitHub, + glib, + gnome-shell, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-pidgin-im-integration"; diff --git a/pkgs/desktops/gnome/extensions/pop-shell/default.nix b/pkgs/desktops/gnome/extensions/pop-shell/default.nix index a391784e7f3888..8419bf2a9f061b 100644 --- a/pkgs/desktops/gnome/extensions/pop-shell/default.nix +++ b/pkgs/desktops/gnome/extensions/pop-shell/default.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, glib, gjs, typescript, unstableGitUpdater }: +{ + stdenv, + lib, + fetchFromGitHub, + glib, + gjs, + typescript, + unstableGitUpdater, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-pop-shell"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { hash = "sha256-PPJofRzzbH1zcnKtQ/3ulErvN4pAJMo/igzdq1zT06s="; }; - nativeBuildInputs = [ glib gjs typescript ]; + nativeBuildInputs = [ + glib + gjs + typescript + ]; buildInputs = [ gjs ]; diff --git a/pkgs/desktops/gnome/extensions/sound-output-device-chooser/default.nix b/pkgs/desktops/gnome/extensions/sound-output-device-chooser/default.nix index f3026744ea6e89..431784e78d9c68 100644 --- a/pkgs/desktops/gnome/extensions/sound-output-device-chooser/default.nix +++ b/pkgs/desktops/gnome/extensions/sound-output-device-chooser/default.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, substituteAll -, fetchFromGitHub -, libpulseaudio -, python3 +{ + lib, + stdenv, + substituteAll, + fetchFromGitHub, + libpulseaudio, + python3, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/gnome/extensions/taskwhisperer/default.nix b/pkgs/desktops/gnome/extensions/taskwhisperer/default.nix index f4e50f46bb2576..fc37e6875820c5 100644 --- a/pkgs/desktops/gnome/extensions/taskwhisperer/default.nix +++ b/pkgs/desktops/gnome/extensions/taskwhisperer/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, substituteAll, fetchFromGitHub, taskwarrior2, gettext, runtimeShell }: +{ + lib, + stdenv, + substituteAll, + fetchFromGitHub, + taskwarrior2, + gettext, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-taskwhisperer"; diff --git a/pkgs/desktops/gnome/extensions/tilingnome/default.nix b/pkgs/desktops/gnome/extensions/tilingnome/default.nix index 3e6a2efb990fb0..516d85ce378e45 100644 --- a/pkgs/desktops/gnome/extensions/tilingnome/default.nix +++ b/pkgs/desktops/gnome/extensions/tilingnome/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, glib, gnome-shell }: +{ + stdenv, + lib, + fetchFromGitHub, + glib, + gnome-shell, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-tilingnome"; diff --git a/pkgs/desktops/gnome/extensions/topicons-plus/default.nix b/pkgs/desktops/gnome/extensions/topicons-plus/default.nix index eedfeb098c033f..b216a6ae451fcf 100644 --- a/pkgs/desktops/gnome/extensions/topicons-plus/default.nix +++ b/pkgs/desktops/gnome/extensions/topicons-plus/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, glib, gettext }: +{ + lib, + stdenv, + fetchFromGitHub, + glib, + gettext, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-topicons-plus"; diff --git a/pkgs/desktops/gnome/extensions/unite/default.nix b/pkgs/desktops/gnome/extensions/unite/default.nix index dbc7e96df3eea6..a514d8a02bd279 100644 --- a/pkgs/desktops/gnome/extensions/unite/default.nix +++ b/pkgs/desktops/gnome/extensions/unite/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, gnome-shell, fetchFromGitHub, xprop, glib }: +{ + lib, + stdenv, + gnome-shell, + fetchFromGitHub, + xprop, + glib, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-unite"; diff --git a/pkgs/desktops/gnome/extensions/window-corner-preview/default.nix b/pkgs/desktops/gnome/extensions/window-corner-preview/default.nix index e8d43bb158312f..82692ae90f42ed 100644 --- a/pkgs/desktops/gnome/extensions/window-corner-preview/default.nix +++ b/pkgs/desktops/gnome/extensions/window-corner-preview/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, gnome-shell }: +{ + lib, + stdenv, + fetchFromGitHub, + gnome-shell, +}: stdenv.mkDerivation rec { pname = "gnome-shell-extension-window-corner-preview"; diff --git a/pkgs/desktops/gnome/gdk-pixbuf-cache-builder.nix b/pkgs/desktops/gnome/gdk-pixbuf-cache-builder.nix index 398e9144e2448b..8f4313e92d2f66 100644 --- a/pkgs/desktops/gnome/gdk-pixbuf-cache-builder.nix +++ b/pkgs/desktops/gnome/gdk-pixbuf-cache-builder.nix @@ -19,18 +19,20 @@ in # Generate the cache file by running gdk-pixbuf-query-loaders for each # package and concatenating the results. -runCommand "gdk-pixbuf-loaders.cache" { - preferLocalBuild = true; -} '' - ( - for package in ${lib.escapeShellArgs loaderPackages}; do - module_dir="$package/${gdk-pixbuf.moduleDir}" - if [[ ! -d "$module_dir" ]]; then - echo "Error: gdkPixbufCacheBuilder: Passed package “''${package}” does not contain GdkPixbuf loaders in “${gdk-pixbuf.moduleDir}”." 1>&2 - exit 1 - fi - GDK_PIXBUF_MODULEDIR="$module_dir" \ - ${stdenv.hostPlatform.emulator buildPackages} ${gdk-pixbuf.dev}/bin/gdk-pixbuf-query-loaders - done - ) > "$out" -'' +runCommand "gdk-pixbuf-loaders.cache" + { + preferLocalBuild = true; + } + '' + ( + for package in ${lib.escapeShellArgs loaderPackages}; do + module_dir="$package/${gdk-pixbuf.moduleDir}" + if [[ ! -d "$module_dir" ]]; then + echo "Error: gdkPixbufCacheBuilder: Passed package “''${package}” does not contain GdkPixbuf loaders in “${gdk-pixbuf.moduleDir}”." 1>&2 + exit 1 + fi + GDK_PIXBUF_MODULEDIR="$module_dir" \ + ${stdenv.hostPlatform.emulator buildPackages} ${gdk-pixbuf.dev}/bin/gdk-pixbuf-query-loaders + done + ) > "$out" + '' diff --git a/pkgs/desktops/gnome/misc/gnome-extensions-cli/default.nix b/pkgs/desktops/gnome/misc/gnome-extensions-cli/default.nix index 9c84bb4e342a03..c26a40c003dcc8 100644 --- a/pkgs/desktops/gnome/misc/gnome-extensions-cli/default.nix +++ b/pkgs/desktops/gnome/misc/gnome-extensions-cli/default.nix @@ -1,15 +1,16 @@ -{ lib -, fetchPypi -, buildPythonApplication -, poetry-core -, colorama -, packaging -, pydantic -, requests -, pygobject3 -, tqdm -, gobject-introspection -, wrapGAppsNoGuiHook +{ + lib, + fetchPypi, + buildPythonApplication, + poetry-core, + colorama, + packaging, + pydantic, + requests, + pygobject3, + tqdm, + gobject-introspection, + wrapGAppsNoGuiHook, }: buildPythonApplication rec { diff --git a/pkgs/desktops/gnome/nixos/gsettings-overrides/default.nix b/pkgs/desktops/gnome/nixos/gsettings-overrides/default.nix index fbe08a93d89db1..dd1bca40366a5a 100644 --- a/pkgs/desktops/gnome/nixos/gsettings-overrides/default.nix +++ b/pkgs/desktops/gnome/nixos/gsettings-overrides/default.nix @@ -1,28 +1,32 @@ -{ lib -, runCommand -, gsettings-desktop-schemas -, gnome-shell -, glib -, gnome-flashback -, nixos-artwork -, nixos-background-light ? nixos-artwork.wallpapers.simple-blue -, nixos-background-dark ? nixos-artwork.wallpapers.simple-dark-gray -, extraGSettingsOverrides ? "" -, extraGSettingsOverridePackages ? [ ] -, favoriteAppsOverride ? "" -, flashbackEnabled ? false +{ + lib, + runCommand, + gsettings-desktop-schemas, + gnome-shell, + glib, + gnome-flashback, + nixos-artwork, + nixos-background-light ? nixos-artwork.wallpapers.simple-blue, + nixos-background-dark ? nixos-artwork.wallpapers.simple-dark-gray, + extraGSettingsOverrides ? "", + extraGSettingsOverridePackages ? [ ], + favoriteAppsOverride ? "", + flashbackEnabled ? false, }: let inherit (lib) concatMapStringsSep; - gsettingsOverridePackages = [ - gsettings-desktop-schemas - gnome-shell - ] ++ lib.optionals flashbackEnabled [ - gnome-flashback - ] ++ extraGSettingsOverridePackages; + gsettingsOverridePackages = + [ + gsettings-desktop-schemas + gnome-shell + ] + ++ lib.optionals flashbackEnabled [ + gnome-flashback + ] + ++ extraGSettingsOverridePackages; gsettingsOverrides = '' [org.gnome.desktop.background] @@ -44,7 +48,10 @@ runCommand "gnome-gsettings-overrides" { preferLocalBuild = true; } '' schema_dir="$data_dir/glib-2.0/schemas" mkdir -p "$schema_dir" - ${concatMapStringsSep "\n" (pkg: "cp -rf \"${glib.getSchemaPath pkg}\"/*.xml \"${glib.getSchemaPath pkg}\"/*.gschema.override \"$schema_dir\"") gsettingsOverridePackages} + ${concatMapStringsSep "\n" ( + pkg: + "cp -rf \"${glib.getSchemaPath pkg}\"/*.xml \"${glib.getSchemaPath pkg}\"/*.gschema.override \"$schema_dir\"" + ) gsettingsOverridePackages} chmod -R a+w "$data_dir" cat - > "$schema_dir/zz-nixos-defaults.gschema.override" <<- EOF diff --git a/pkgs/desktops/gnome/update.nix b/pkgs/desktops/gnome/update.nix index ce8ed07a5ae3c7..d6b92b0e77cc2e 100644 --- a/pkgs/desktops/gnome/update.nix +++ b/pkgs/desktops/gnome/update.nix @@ -1,15 +1,33 @@ -{ stdenv, pkgs, lib, writeScript, python3, common-updater-scripts }: -{ packageName, attrPath ? packageName, versionPolicy ? "tagged", freeze ? false }: +{ + stdenv, + pkgs, + lib, + writeScript, + python3, + common-updater-scripts, +}: +{ + packageName, + attrPath ? packageName, + versionPolicy ? "tagged", + freeze ? false, +}: let - python = python3.withPackages (p: [ p.requests p.libversion ]); - package = lib.attrByPath (lib.splitString "." attrPath) (throw "Cannot find attribute ‘${attrPath}’.") pkgs; + python = python3.withPackages (p: [ + p.requests + p.libversion + ]); + package = + lib.attrByPath (lib.splitString "." attrPath) (throw "Cannot find attribute ‘${attrPath}’.") + pkgs; packageVersion = lib.getVersion package; upperBound = let versionComponents = lib.versions.splitVersion packageVersion; minorVersion = lib.versions.minor packageVersion; - minorAvailable = builtins.length versionComponents > 1 && builtins.match "[0-9]+" minorVersion != null; + minorAvailable = + builtins.length versionComponents > 1 && builtins.match "[0-9]+" minorVersion != null; nextMinor = builtins.fromJSON minorVersion + 1; upperBound = "${lib.versions.major packageVersion}.${builtins.toString nextMinor}"; in @@ -77,9 +95,16 @@ let print(json.dumps(report)) ''; -in { +in +{ name = "gnome-update-script"; - command = [ updateScript attrPath packageName packageVersion versionPolicy ] ++ upperBound; + command = [ + updateScript + attrPath + packageName + packageVersion + versionPolicy + ] ++ upperBound; supportedFeatures = [ "commit" ]; diff --git a/pkgs/desktops/gnustep/base/default.nix b/pkgs/desktops/gnustep/base/default.nix index 9d47bb7ee95469..bab6487cc988e3 100644 --- a/pkgs/desktops/gnustep/base/default.nix +++ b/pkgs/desktops/gnustep/base/default.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, aspell -, audiofile -, make -, wrapGNUstepAppsHook -, cups -, fetchzip -, fetchpatch -, gmp -, gnutls -, libffi -, binutils-unwrapped -, libjpeg -, libtiff -, libpng -, giflib -, libxml2 -, libxslt -, libiconv -, libobjc -, libgcrypt -, icu -, pkg-config -, portaudio -, libiberty +{ + lib, + stdenv, + aspell, + audiofile, + make, + wrapGNUstepAppsHook, + cups, + fetchzip, + fetchpatch, + gmp, + gnutls, + libffi, + binutils-unwrapped, + libjpeg, + libtiff, + libpng, + giflib, + libxml2, + libxslt, + libiconv, + libobjc, + libgcrypt, + icu, + pkg-config, + portaudio, + libiberty, }: stdenv.mkDerivation (finalAttrs: { @@ -33,16 +34,33 @@ stdenv.mkDerivation (finalAttrs: { url = "ftp://ftp.gnustep.org/pub/gnustep/core/gnustep-base-${finalAttrs.version}.tar.gz"; hash = "sha256-4fjdsLBsYEDxLOFrq17dKii2sLKvOaFCu0cw3qQtM5U="; }; - outputs = [ "out" "dev" "lib" ]; - nativeBuildInputs = [ pkg-config make wrapGNUstepAppsHook ]; + outputs = [ + "out" + "dev" + "lib" + ]; + nativeBuildInputs = [ + pkg-config + make + wrapGNUstepAppsHook + ]; propagatedBuildInputs = [ - aspell audiofile + aspell + audiofile cups - gmp gnutls - libffi binutils-unwrapped - libjpeg libtiff libpng giflib - libxml2 libxslt libiconv - libobjc libgcrypt + gmp + gnutls + libffi + binutils-unwrapped + libjpeg + libtiff + libpng + giflib + libxml2 + libxslt + libiconv + libobjc + libgcrypt icu portaudio libiberty @@ -69,11 +87,17 @@ stdenv.mkDerivation (finalAttrs: { ]; meta = { - changelog = "https://github.com/gnustep/libs-base/releases/tag/base-${builtins.replaceStrings [ "." ] [ "_" ] finalAttrs.version}"; + changelog = "https://github.com/gnustep/libs-base/releases/tag/base-${ + builtins.replaceStrings [ "." ] [ "_" ] finalAttrs.version + }"; description = "Implementation of AppKit and Foundation libraries of OPENSTEP and Cocoa"; homepage = "https://gnustep.github.io/"; license = lib.licenses.lgpl2Plus; - maintainers = with lib.maintainers; [ ashalkhakov matthewbauer dblsaiko ]; + maintainers = with lib.maintainers; [ + ashalkhakov + matthewbauer + dblsaiko + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/desktops/gnustep/gorm/default.nix b/pkgs/desktops/gnustep/gorm/default.nix index e71cc124451d85..59c9c729f8bef4 100644 --- a/pkgs/desktops/gnustep/gorm/default.nix +++ b/pkgs/desktops/gnustep/gorm/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchzip -, base -, back -, make -, wrapGNUstepAppsHook -, gui +{ + lib, + stdenv, + fetchzip, + base, + back, + make, + wrapGNUstepAppsHook, + gui, }: stdenv.mkDerivation (finalAttrs: { @@ -17,15 +18,26 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-B7NNRA3qA2PFbb03m58EBBONuIciLf6eU+YSR0qvaCo="; }; - nativeBuildInputs = [ make wrapGNUstepAppsHook ]; - buildInputs = [ base back gui ]; + nativeBuildInputs = [ + make + wrapGNUstepAppsHook + ]; + buildInputs = [ + base + back + gui + ]; meta = { description = "Graphical Object Relationship Modeller is an easy-to-use interface designer for GNUstep"; homepage = "https://gnustep.github.io/"; license = lib.licenses.lgpl2Plus; mainProgram = "Gorm"; - maintainers = with lib.maintainers; [ ashalkhakov matthewbauer dblsaiko ]; + maintainers = with lib.maintainers; [ + ashalkhakov + matthewbauer + dblsaiko + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/desktops/gnustep/gui/default.nix b/pkgs/desktops/gnustep/gui/default.nix index 498b120adea49a..34694caf310a09 100644 --- a/pkgs/desktops/gnustep/gui/default.nix +++ b/pkgs/desktops/gnustep/gui/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, make -, wrapGNUstepAppsHook -, fetchzip -, base +{ + lib, + stdenv, + make, + wrapGNUstepAppsHook, + fetchzip, + base, }: stdenv.mkDerivation (finalAttrs: { @@ -15,18 +16,27 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-+4XEJ6PKpantbIbyNroFMaNBTFffkuW/ajSocGQO9Mo="; }; - nativeBuildInputs = [ make wrapGNUstepAppsHook ]; + nativeBuildInputs = [ + make + wrapGNUstepAppsHook + ]; buildInputs = [ base ]; patches = [ ./fixup-all.patch ]; meta = { - changelog = "https://github.com/gnustep/libs-gui/releases/tag/gui-${builtins.replaceStrings [ "." ] [ "_" ] finalAttrs.version}"; + changelog = "https://github.com/gnustep/libs-gui/releases/tag/gui-${ + builtins.replaceStrings [ "." ] [ "_" ] finalAttrs.version + }"; description = "GUI class library of GNUstep"; homepage = "https://gnustep.github.io/"; license = lib.licenses.lgpl2Plus; - maintainers = with lib.maintainers; [ ashalkhakov matthewbauer dblsaiko ]; + maintainers = with lib.maintainers; [ + ashalkhakov + matthewbauer + dblsaiko + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/desktops/gnustep/gworkspace/default.nix b/pkgs/desktops/gnustep/gworkspace/default.nix index 5e4877706ec8a3..92f60105d1c8f4 100644 --- a/pkgs/desktops/gnustep/gworkspace/default.nix +++ b/pkgs/desktops/gnustep/gworkspace/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, back -, base -, gui -, make -, wrapGNUstepAppsHook -, fetchurl -, system_preferences +{ + lib, + stdenv, + back, + base, + gui, + make, + wrapGNUstepAppsHook, + fetchurl, + system_preferences, }: stdenv.mkDerivation (finalAttrs: { @@ -21,8 +22,16 @@ stdenv.mkDerivation (finalAttrs: { # additional dependencies: # - PDFKit framework from http://gap.nongnu.org/ # - TODO: to --enable-gwmetadata, need libDBKit as well as sqlite! - nativeBuildInputs = [ make wrapGNUstepAppsHook ]; - buildInputs = [ back base gui system_preferences ]; + nativeBuildInputs = [ + make + wrapGNUstepAppsHook + ]; + buildInputs = [ + back + base + gui + system_preferences + ]; configureFlags = [ "--with-inotify" ]; meta = { @@ -30,7 +39,11 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://gnustep.github.io/"; license = lib.licenses.lgpl2Plus; mainProgram = "GWorkspace"; - maintainers = with lib.maintainers; [ ashalkhakov matthewbauer dblsaiko ]; + maintainers = with lib.maintainers; [ + ashalkhakov + matthewbauer + dblsaiko + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/desktops/gnustep/libobjc2/default.nix b/pkgs/desktops/gnustep/libobjc2/default.nix index ccbbdec13ac0fc..06e0b45095c081 100644 --- a/pkgs/desktops/gnustep/libobjc2/default.nix +++ b/pkgs/desktops/gnustep/libobjc2/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, robin-map +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + robin-map, }: stdenv.mkDerivation (finalAttrs: { @@ -27,7 +28,11 @@ stdenv.mkDerivation (finalAttrs: { description = "Objective-C runtime for use with GNUstep"; homepage = "https://gnustep.github.io/"; license = licenses.mit; - maintainers = with lib.maintainers; [ ashalkhakov matthewbauer dblsaiko ]; + maintainers = with lib.maintainers; [ + ashalkhakov + matthewbauer + dblsaiko + ]; platforms = platforms.unix; }; }) diff --git a/pkgs/desktops/gnustep/make/default.nix b/pkgs/desktops/gnustep/make/default.nix index 32dda5f648389d..06aa0a59bd39af 100644 --- a/pkgs/desktops/gnustep/make/default.nix +++ b/pkgs/desktops/gnustep/make/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, which -, libobjc +{ + lib, + stdenv, + fetchurl, + which, + libobjc, }: stdenv.mkDerivation (finalAttrs: { @@ -35,11 +36,17 @@ stdenv.mkDerivation (finalAttrs: { setupHook = ./setup-hook.sh; meta = { - changelog = "https://github.com/gnustep/tools-make/releases/tag/make-${builtins.replaceStrings [ "." ] [ "_" ] finalAttrs.version}"; + changelog = "https://github.com/gnustep/tools-make/releases/tag/make-${ + builtins.replaceStrings [ "." ] [ "_" ] finalAttrs.version + }"; description = "Build manager for GNUstep"; homepage = "https://gnustep.github.io/"; license = lib.licenses.lgpl2Plus; - maintainers = with lib.maintainers; [ ashalkhakov matthewbauer dblsaiko ]; + maintainers = with lib.maintainers; [ + ashalkhakov + matthewbauer + dblsaiko + ]; platforms = lib.platforms.unix; }; }) diff --git a/pkgs/desktops/gnustep/projectcenter/default.nix b/pkgs/desktops/gnustep/projectcenter/default.nix index 89f2e769a0664f..b93b5f073b6a5f 100644 --- a/pkgs/desktops/gnustep/projectcenter/default.nix +++ b/pkgs/desktops/gnustep/projectcenter/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, make -, wrapGNUstepAppsHook -, base -, back -, gui -, gorm -, gnumake -, gdb +{ + lib, + stdenv, + fetchFromGitHub, + make, + wrapGNUstepAppsHook, + base, + back, + gui, + gorm, + gnumake, + gdb, }: stdenv.mkDerivation (finalAttrs: { @@ -22,19 +23,33 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-uXT2UUvMZNc6Fqi2BUXQimbZk8b3IqXzB+A2btBOmms="; }; - nativeBuildInputs = [ make wrapGNUstepAppsHook ]; + nativeBuildInputs = [ + make + wrapGNUstepAppsHook + ]; # NOTE: need a patch for ProjectCenter to help it locate some necessary tools: # 1. Framework/PCProjectLauncher.m, locate gdb (say among NIX_GNUSTEP_SYSTEM_TOOLS) # 2. Framework/PCProjectBuilder.m, locate gmake (similar) - propagatedBuildInputs = [ base back gui gnumake gdb gorm ]; + propagatedBuildInputs = [ + base + back + gui + gnumake + gdb + gorm + ]; meta = { description = "GNUstep's integrated development environment"; homepage = "https://gnustep.github.io/"; license = lib.licenses.lgpl2Plus; mainProgram = "ProjectCenter"; - maintainers = with lib.maintainers; [ ashalkhakov matthewbauer dblsaiko ]; + maintainers = with lib.maintainers; [ + ashalkhakov + matthewbauer + dblsaiko + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/desktops/gnustep/systempreferences/default.nix b/pkgs/desktops/gnustep/systempreferences/default.nix index 079653c1983b2b..d9262af3619186 100644 --- a/pkgs/desktops/gnustep/systempreferences/default.nix +++ b/pkgs/desktops/gnustep/systempreferences/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, make -, wrapGNUstepAppsHook -, back -, base -, gui +{ + lib, + stdenv, + fetchurl, + make, + wrapGNUstepAppsHook, + back, + base, + gui, }: stdenv.mkDerivation (finalAttrs: { @@ -17,15 +18,26 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "1fg7c3ihfgvl6n21rd17fs9ivx3l8ps874m80vz86n1callgs339"; }; - nativeBuildInputs = [ make wrapGNUstepAppsHook ]; - buildInputs = [ back base gui ]; + nativeBuildInputs = [ + make + wrapGNUstepAppsHook + ]; + buildInputs = [ + back + base + gui + ]; meta = { description = "Settings manager for the GNUstep environment and its applications"; homepage = "https://gnustep.github.io/"; license = lib.licenses.lgpl2Plus; mainProgram = "SystemPreferences"; - maintainers = with lib.maintainers; [ ashalkhakov matthewbauer dblsaiko ]; + maintainers = with lib.maintainers; [ + ashalkhakov + matthewbauer + dblsaiko + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/desktops/lomiri/applications/lomiri-terminal-app/default.nix b/pkgs/desktops/lomiri/applications/lomiri-terminal-app/default.nix index a6bf2877ef581c..6701f56b35ec61 100644 --- a/pkgs/desktops/lomiri/applications/lomiri-terminal-app/default.nix +++ b/pkgs/desktops/lomiri/applications/lomiri-terminal-app/default.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitLab -, gitUpdater -, nixosTests -, cmake -, gsettings-qt -, lomiri-ui-extras -, lomiri-ui-toolkit -, pkg-config -, qmltermwidget -, qtbase -, qtdeclarative -, qtsystems -, wrapQtAppsHook +{ + stdenv, + lib, + fetchFromGitLab, + gitUpdater, + nixosTests, + cmake, + gsettings-qt, + lomiri-ui-extras, + lomiri-ui-toolkit, + pkg-config, + qmltermwidget, + qtbase, + qtdeclarative, + qtsystems, + wrapQtAppsHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/desktops/lomiri/applications/morph-browser/default.nix b/pkgs/desktops/lomiri/applications/morph-browser/default.nix index ff636197d738ab..40646d439901e0 100644 --- a/pkgs/desktops/lomiri/applications/morph-browser/default.nix +++ b/pkgs/desktops/lomiri/applications/morph-browser/default.nix @@ -1,25 +1,26 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, gitUpdater -, nixosTests -, cmake -, gettext -, libapparmor -, lomiri-action-api -, lomiri-content-hub -, lomiri-ui-extras -, lomiri-ui-toolkit -, pkg-config -, qqc2-suru-style -, qtbase -, qtdeclarative -, qtquickcontrols2 -, qtsystems -, qtwebengine -, wrapQtAppsHook -, xvfb-run +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + gitUpdater, + nixosTests, + cmake, + gettext, + libapparmor, + lomiri-action-api, + lomiri-content-hub, + lomiri-ui-extras, + lomiri-ui-toolkit, + pkg-config, + qqc2-suru-style, + qtbase, + qtdeclarative, + qtquickcontrols2, + qtsystems, + qtwebengine, + wrapQtAppsHook, + xvfb-run, }: let @@ -45,21 +46,23 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - postPatch = '' - substituteInPlace src/{Morph,Ubuntu}/CMakeLists.txt \ - --replace '/usr/lib/''${CMAKE_LIBRARY_ARCHITECTURE}/qt5/qml' "\''${CMAKE_INSTALL_PREFIX}/${qtbase.qtQmlPrefix}" - - # We normally don't want to use absolute paths in desktop file, but this one is special - # There appears to be some issue in lomiri-app-launch's lookup of relative Icon entries (while lomiri is starting up?) - # that makes the session segfault. - # As a compromise, hardcode /run/current-system - substituteInPlace src/app/webbrowser/morph-browser.desktop.in.in \ - --replace 'Icon=@CMAKE_INSTALL_FULL_DATADIR@/morph-browser/morph-browser.svg' 'Icon=/run/current-system/sw/share/icons/hicolor/scalable/apps/morph-browser.svg' \ - --replace 'X-Lomiri-Splash-Image=@CMAKE_INSTALL_FULL_DATADIR@/morph-browser/morph-browser-splash.svg' 'X-Lomiri-Splash-Image=lomiri-app-launch/splash/morph-browser.svg' - '' + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' - substituteInPlace CMakeLists.txt \ - --replace 'add_subdirectory(tests)' "" - ''; + postPatch = + '' + substituteInPlace src/{Morph,Ubuntu}/CMakeLists.txt \ + --replace '/usr/lib/''${CMAKE_LIBRARY_ARCHITECTURE}/qt5/qml' "\''${CMAKE_INSTALL_PREFIX}/${qtbase.qtQmlPrefix}" + + # We normally don't want to use absolute paths in desktop file, but this one is special + # There appears to be some issue in lomiri-app-launch's lookup of relative Icon entries (while lomiri is starting up?) + # that makes the session segfault. + # As a compromise, hardcode /run/current-system + substituteInPlace src/app/webbrowser/morph-browser.desktop.in.in \ + --replace 'Icon=@CMAKE_INSTALL_FULL_DATADIR@/morph-browser/morph-browser.svg' 'Icon=/run/current-system/sw/share/icons/hicolor/scalable/apps/morph-browser.svg' \ + --replace 'X-Lomiri-Splash-Image=@CMAKE_INSTALL_FULL_DATADIR@/morph-browser/morph-browser-splash.svg' 'X-Lomiri-Splash-Image=lomiri-app-launch/splash/morph-browser.svg' + '' + + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' + substituteInPlace CMakeLists.txt \ + --replace 'add_subdirectory(tests)' "" + ''; strictDeps = true; @@ -91,16 +94,21 @@ stdenv.mkDerivation (finalAttrs: { ]; cmakeFlags = [ - (lib.cmakeFeature "CMAKE_CTEST_ARGUMENTS" (lib.concatStringsSep ";" [ - # Exclude tests - "-E" (lib.strings.escapeShellArg "(${lib.concatStringsSep "|" [ - # Don't care about linter failures - "^flake8" - - # Runs into ShapeMaterial codepath in lomiri-ui-toolkit which needs OpenGL, see LUITK for details - "^tst_QmlTests" - ]})") - ])) + (lib.cmakeFeature "CMAKE_CTEST_ARGUMENTS" ( + lib.concatStringsSep ";" [ + # Exclude tests + "-E" + (lib.strings.escapeShellArg "(${ + lib.concatStringsSep "|" [ + # Don't care about linter failures + "^flake8" + + # Runs into ShapeMaterial codepath in lomiri-ui-toolkit which needs OpenGL, see LUITK for details + "^tst_QmlTests" + ] + })") + ] + )) ]; doCheck = stdenv.buildPlatform.canExecute stdenv.hostPlatform; @@ -108,7 +116,18 @@ stdenv.mkDerivation (finalAttrs: { preCheck = '' export HOME=$TMPDIR export QT_PLUGIN_PATH=${listToQtVar qtbase.qtPluginPrefix [ qtbase ]} - export QML2_IMPORT_PATH=${listToQtVar qtbase.qtQmlPrefix ([ lomiri-ui-toolkit qtwebengine qtdeclarative qtquickcontrols2 qtsystems ] ++ lomiri-ui-toolkit.propagatedBuildInputs)} + export QML2_IMPORT_PATH=${ + listToQtVar qtbase.qtQmlPrefix ( + [ + lomiri-ui-toolkit + qtwebengine + qtdeclarative + qtquickcontrols2 + qtsystems + ] + ++ lomiri-ui-toolkit.propagatedBuildInputs + ) + } ''; postInstall = '' @@ -134,7 +153,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Lightweight web browser tailored for Ubuntu Touch"; homepage = "https://gitlab.com/ubports/development/core/morph-browser"; changelog = "https://gitlab.com/ubports/development/core/morph-browser/-/blob/${finalAttrs.version}/ChangeLog"; - license = with licenses; [ gpl3Only cc-by-sa-30 ]; + license = with licenses; [ + gpl3Only + cc-by-sa-30 + ]; mainProgram = "morph-browser"; maintainers = teams.lomiri.members; platforms = platforms.linux; diff --git a/pkgs/desktops/lomiri/data/lomiri-schemas/default.nix b/pkgs/desktops/lomiri/data/lomiri-schemas/default.nix index c754ee22b70c88..31d96388487773 100644 --- a/pkgs/desktops/lomiri/data/lomiri-schemas/default.nix +++ b/pkgs/desktops/lomiri/data/lomiri-schemas/default.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitLab -, gitUpdater -, testers -, cmake -, cmake-extras -, glib -, intltool -, pkg-config -, validatePkgConfig +{ + stdenv, + lib, + fetchFromGitLab, + gitUpdater, + testers, + cmake, + cmake-extras, + glib, + intltool, + pkg-config, + validatePkgConfig, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/desktops/lomiri/data/lomiri-sounds/default.nix b/pkgs/desktops/lomiri/data/lomiri-sounds/default.nix index 1b54723b2925e7..37cdf3a4a1d113 100644 --- a/pkgs/desktops/lomiri/data/lomiri-sounds/default.nix +++ b/pkgs/desktops/lomiri/data/lomiri-sounds/default.nix @@ -1,9 +1,10 @@ -{ stdenvNoCC -, lib -, fetchFromGitLab -, gitUpdater -, testers -, cmake +{ + stdenvNoCC, + lib, + fetchFromGitLab, + gitUpdater, + testers, + cmake, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -37,7 +38,12 @@ stdenvNoCC.mkDerivation (finalAttrs: { meta = with lib; { description = "Notification and ringtone sound effects for Lomiri"; homepage = "https://gitlab.com/ubports/development/core/lomiri-sounds"; - license = with licenses; [ cc-by-30 cc0 cc-by-sa-30 cc-by-40 ]; + license = with licenses; [ + cc-by-30 + cc0 + cc-by-sa-30 + cc-by-40 + ]; maintainers = teams.lomiri.members; platforms = platforms.all; pkgConfigModules = [ diff --git a/pkgs/desktops/lomiri/data/lomiri-wallpapers/default.nix b/pkgs/desktops/lomiri/data/lomiri-wallpapers/default.nix index 9cdb7887ee88bb..b45868c2808bd6 100644 --- a/pkgs/desktops/lomiri/data/lomiri-wallpapers/default.nix +++ b/pkgs/desktops/lomiri/data/lomiri-wallpapers/default.nix @@ -1,7 +1,8 @@ -{ stdenvNoCC -, lib -, fetchFromGitLab -, gitUpdater +{ + stdenvNoCC, + lib, + fetchFromGitLab, + gitUpdater, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/desktops/lomiri/development/cmake-extras/default.nix b/pkgs/desktops/lomiri/development/cmake-extras/default.nix index 7c0a1cbc0d5b94..21dc05dd12f467 100644 --- a/pkgs/desktops/lomiri/development/cmake-extras/default.nix +++ b/pkgs/desktops/lomiri/development/cmake-extras/default.nix @@ -1,8 +1,9 @@ -{ stdenvNoCC -, lib -, fetchFromGitLab -, cmake -, qtbase +{ + stdenvNoCC, + lib, + fetchFromGitLab, + cmake, + qtbase, }: stdenvNoCC.mkDerivation (finalAttrs: { diff --git a/pkgs/desktops/lomiri/development/deviceinfo/default.nix b/pkgs/desktops/lomiri/development/deviceinfo/default.nix index 6b05a4adddcf3c..0ceae216c9dde3 100644 --- a/pkgs/desktops/lomiri/development/deviceinfo/default.nix +++ b/pkgs/desktops/lomiri/development/deviceinfo/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitLab -, gitUpdater -, testers -, cmake -, pkg-config -, cmake-extras -, gtest -, yaml-cpp +{ + stdenv, + lib, + fetchFromGitLab, + gitUpdater, + testers, + cmake, + pkg-config, + cmake-extras, + gtest, + yaml-cpp, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/desktops/lomiri/development/geonames/default.nix b/pkgs/desktops/lomiri/development/geonames/default.nix index ce77bca6bc41ca..d2fff65bf5f836 100644 --- a/pkgs/desktops/lomiri/development/geonames/default.nix +++ b/pkgs/desktops/lomiri/development/geonames/default.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchFromGitLab -, gitUpdater -, testers -, buildPackages -, cmake -, docbook-xsl-nons -, docbook_xml_dtd_45 -, gettext -, glib -, glibcLocales -, withExamples ? true -, gtk3 -# Uses gtkdoc-scan* tools, which produces a binary linked against lib for hostPlatform and executes it to generate docs -, withDocumentation ? stdenv.buildPlatform.canExecute stdenv.hostPlatform -, gtk-doc -, pkg-config -, validatePkgConfig +{ + stdenv, + lib, + fetchFromGitLab, + gitUpdater, + testers, + buildPackages, + cmake, + docbook-xsl-nons, + docbook_xml_dtd_45, + gettext, + glib, + glibcLocales, + withExamples ? true, + gtk3, + # Uses gtkdoc-scan* tools, which produces a binary linked against lib for hostPlatform and executes it to generate docs + withDocumentation ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, + gtk-doc, + pkg-config, + validatePkgConfig, }: stdenv.mkDerivation (finalAttrs: { @@ -30,14 +31,17 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-AhRnUoku17kVY0UciHQXFDa6eCH6HQ4ZGIOobCaGTKQ="; }; - outputs = [ - "out" - "dev" - ] ++ lib.optionals withExamples [ - "bin" - ] ++ lib.optionals withDocumentation [ - "devdoc" - ]; + outputs = + [ + "out" + "dev" + ] + ++ lib.optionals withExamples [ + "bin" + ] + ++ lib.optionals withDocumentation [ + "devdoc" + ]; postPatch = '' patchShebangs src/generate-locales.sh tests/setup-test-env.sh @@ -45,23 +49,27 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - nativeBuildInputs = [ - cmake - gettext - glib # glib-compile-resources - pkg-config - validatePkgConfig - ] ++ lib.optionals withDocumentation [ - docbook-xsl-nons - docbook_xml_dtd_45 - gtk-doc - ]; + nativeBuildInputs = + [ + cmake + gettext + glib # glib-compile-resources + pkg-config + validatePkgConfig + ] + ++ lib.optionals withDocumentation [ + docbook-xsl-nons + docbook_xml_dtd_45 + gtk-doc + ]; - buildInputs = [ - glib - ] ++ lib.optionals withExamples [ - gtk3 - ]; + buildInputs = + [ + glib + ] + ++ lib.optionals withExamples [ + gtk3 + ]; # Tests need to be able to check locale LC_ALL = lib.optionalString finalAttrs.finalPackage.doCheck "en_US.UTF-8"; @@ -74,16 +82,18 @@ stdenv.mkDerivation (finalAttrs: { "LD=${stdenv.cc.targetPrefix}cc" ]; - cmakeFlags = [ - (lib.cmakeBool "WANT_DOC" withDocumentation) - (lib.cmakeBool "WANT_DEMO" withExamples) - (lib.cmakeBool "WANT_TESTS" finalAttrs.finalPackage.doCheck) - # Keeps finding & using glib-compile-resources from buildInputs otherwise - (lib.cmakeFeature "CMAKE_PROGRAM_PATH" (lib.makeBinPath [ buildPackages.glib.dev ])) - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - # only for cross without native execute support because the canExecute "emulator" call has a format that I can't get CMake to accept - (lib.cmakeFeature "CMAKE_CROSSCOMPILING_EMULATOR" (stdenv.hostPlatform.emulator buildPackages)) - ]; + cmakeFlags = + [ + (lib.cmakeBool "WANT_DOC" withDocumentation) + (lib.cmakeBool "WANT_DEMO" withExamples) + (lib.cmakeBool "WANT_TESTS" finalAttrs.finalPackage.doCheck) + # Keeps finding & using glib-compile-resources from buildInputs otherwise + (lib.cmakeFeature "CMAKE_PROGRAM_PATH" (lib.makeBinPath [ buildPackages.glib.dev ])) + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + # only for cross without native execute support because the canExecute "emulator" call has a format that I can't get CMake to accept + (lib.cmakeFeature "CMAKE_CROSSCOMPILING_EMULATOR" (stdenv.hostPlatform.emulator buildPackages)) + ]; preInstall = lib.optionalString withDocumentation '' # gtkdoc-mkhtml generates images without write permissions, errors out during install @@ -107,7 +117,8 @@ stdenv.mkDerivation (finalAttrs: { platforms = platforms.all; # Cross requires hostPlatform emulation during build # https://gitlab.com/ubports/development/core/geonames/-/issues/1 - broken = stdenv.buildPlatform != stdenv.hostPlatform && !stdenv.hostPlatform.emulatorAvailable buildPackages; + broken = + stdenv.buildPlatform != stdenv.hostPlatform && !stdenv.hostPlatform.emulatorAvailable buildPackages; pkgConfigModules = [ "geonames" ]; diff --git a/pkgs/desktops/lomiri/development/gmenuharness/default.nix b/pkgs/desktops/lomiri/development/gmenuharness/default.nix index 101b6e21677746..e9b4cca04120ea 100644 --- a/pkgs/desktops/lomiri/development/gmenuharness/default.nix +++ b/pkgs/desktops/lomiri/development/gmenuharness/default.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, gitUpdater -, testers -, cmake -, cmake-extras -, dbus -, dbus-test-runner -, glib -, gtest -, libqtdbustest -, lomiri-api -, pkg-config -, qtbase +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + gitUpdater, + testers, + cmake, + cmake-extras, + dbus, + dbus-test-runner, + glib, + gtest, + libqtdbustest, + lomiri-api, + pkg-config, + qtbase, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/desktops/lomiri/development/lomiri-api/default.nix b/pkgs/desktops/lomiri/development/lomiri-api/default.nix index 491b95d22a456a..847569744a8236 100644 --- a/pkgs/desktops/lomiri/development/lomiri-api/default.nix +++ b/pkgs/desktops/lomiri/development/lomiri-api/default.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, gitUpdater -, makeFontsConf -, testers -, cmake -, cmake-extras -, dbus -, doxygen -, glib -, graphviz -, gtest -, libqtdbustest -, pkg-config -, python3 -, qtbase -, qtdeclarative +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + gitUpdater, + makeFontsConf, + testers, + cmake, + cmake-extras, + dbus, + doxygen, + glib, + graphviz, + gtest, + libqtdbustest, + pkg-config, + python3, + qtbase, + qtdeclarative, }: stdenv.mkDerivation (finalAttrs: { @@ -30,7 +31,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-UTl0vObSlEvHuLmDt7vS3yEqZWGklJ9tVwlUAtRSTlU="; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; patches = [ (fetchpatch { @@ -102,7 +107,10 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Lomiri API Library for integrating with the Lomiri shell"; homepage = "https://gitlab.com/ubports/development/core/lomiri-api"; - license = with licenses; [ lgpl3Only gpl3Only ]; + license = with licenses; [ + lgpl3Only + gpl3Only + ]; maintainers = teams.lomiri.members; platforms = platforms.linux; pkgConfigModules = [ diff --git a/pkgs/desktops/lomiri/development/lomiri-app-launch/default.nix b/pkgs/desktops/lomiri/development/lomiri-app-launch/default.nix index ab19623356bd9c..a095aee3d09285 100644 --- a/pkgs/desktops/lomiri/development/lomiri-app-launch/default.nix +++ b/pkgs/desktops/lomiri/development/lomiri-app-launch/default.nix @@ -1,44 +1,47 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, gitUpdater -, testers -, cmake -, cmake-extras -, curl -, dbus -, dbus-test-runner -, dpkg -, gobject-introspection -, gtest -, json-glib -, libxkbcommon -, lomiri-api -, lttng-ust -, pkg-config -, properties-cpp -, python3 -, systemd -, ubports-click -, validatePkgConfig -, zeitgeist -, withDocumentation ? true -, doxygen -, python3Packages -, sphinx +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + gitUpdater, + testers, + cmake, + cmake-extras, + curl, + dbus, + dbus-test-runner, + dpkg, + gobject-introspection, + gtest, + json-glib, + libxkbcommon, + lomiri-api, + lttng-ust, + pkg-config, + properties-cpp, + python3, + systemd, + ubports-click, + validatePkgConfig, + zeitgeist, + withDocumentation ? true, + doxygen, + python3Packages, + sphinx, }: stdenv.mkDerivation (finalAttrs: { pname = "lomiri-app-launch"; version = "0.1.9"; - outputs = [ - "out" - "dev" - ] ++ lib.optionals withDocumentation [ - "doc" - ]; + outputs = + [ + "out" + "dev" + ] + ++ lib.optionals withDocumentation [ + "doc" + ]; src = fetchFromGitLab { owner = "ubports"; @@ -72,18 +75,20 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - nativeBuildInputs = [ - cmake - dpkg # for setting LOMIRI_APP_LAUNCH_ARCH - gobject-introspection - lttng-ust - pkg-config - validatePkgConfig - ] ++ lib.optionals withDocumentation [ - doxygen - python3Packages.breathe - sphinx - ]; + nativeBuildInputs = + [ + cmake + dpkg # for setting LOMIRI_APP_LAUNCH_ARCH + gobject-introspection + lttng-ust + pkg-config + validatePkgConfig + ] + ++ lib.optionals withDocumentation [ + doxygen + python3Packages.breathe + sphinx + ]; buildInputs = [ cmake-extras @@ -101,9 +106,11 @@ stdenv.mkDerivation (finalAttrs: { nativeCheckInputs = [ dbus - (python3.withPackages (ps: with ps; [ - python-dbusmock - ])) + (python3.withPackages ( + ps: with ps; [ + python-dbusmock + ] + )) ]; checkInputs = [ @@ -114,14 +121,19 @@ stdenv.mkDerivation (finalAttrs: { cmakeFlags = [ (lib.cmakeBool "ENABLE_MIRCLIENT" false) (lib.cmakeBool "ENABLE_TESTS" finalAttrs.finalPackage.doCheck) - (lib.cmakeFeature "CMAKE_CTEST_ARGUMENTS" (lib.concatStringsSep ";" [ - # Exclude tests - "-E" (lib.strings.escapeShellArg "(${lib.concatStringsSep "|" [ - # Flaky, randomly hangs - # https://gitlab.com/ubports/development/core/lomiri-app-launch/-/issues/19 - "^helper-handshake-test" - ]})") - ])) + (lib.cmakeFeature "CMAKE_CTEST_ARGUMENTS" ( + lib.concatStringsSep ";" [ + # Exclude tests + "-E" + (lib.strings.escapeShellArg "(${ + lib.concatStringsSep "|" [ + # Flaky, randomly hangs + # https://gitlab.com/ubports/development/core/lomiri-app-launch/-/issues/19 + "^helper-handshake-test" + ] + })") + ] + )) ]; postBuild = lib.optionalString withDocumentation '' diff --git a/pkgs/desktops/lomiri/development/trust-store/default.nix b/pkgs/desktops/lomiri/development/trust-store/default.nix index 0e86eac2d61018..1c3b2e9bfc5c44 100644 --- a/pkgs/desktops/lomiri/development/trust-store/default.nix +++ b/pkgs/desktops/lomiri/development/trust-store/default.nix @@ -1,26 +1,27 @@ -{ stdenv -, lib -, fetchFromGitLab -, gitUpdater -, testers -, boost -, cmake -, cmake-extras -, dbus -, dbus-cpp -, doxygen -, gettext -, glog -, graphviz -, gtest -, libapparmor -, newt -, pkg-config -, process-cpp -, properties-cpp -, qtbase -, qtdeclarative -, validatePkgConfig +{ + stdenv, + lib, + fetchFromGitLab, + gitUpdater, + testers, + boost, + cmake, + cmake-extras, + dbus, + dbus-cpp, + doxygen, + gettext, + glog, + graphviz, + gtest, + libapparmor, + newt, + pkg-config, + process-cpp, + properties-cpp, + qtbase, + qtdeclarative, + validatePkgConfig, }: stdenv.mkDerivation (finalAttrs: { @@ -41,18 +42,20 @@ stdenv.mkDerivation (finalAttrs: { "bin" ]; - postPatch = '' - # pkg-config patching hook expects prefix variable - substituteInPlace data/trust-store.pc.in \ - --replace-fail 'libdir=''${exec_prefix}' 'libdir=''${prefix}' \ - --replace-fail 'includedir=''${exec_prefix}' 'includedir=''${prefix}' - - substituteInPlace src/core/trust/terminal_agent.h \ - --replace-fail '/bin/whiptail' '${lib.getExe' newt "whiptail"}' - '' + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' - substituteInPlace CMakeLists.txt \ - --replace-fail 'add_subdirectory(tests)' "" - ''; + postPatch = + '' + # pkg-config patching hook expects prefix variable + substituteInPlace data/trust-store.pc.in \ + --replace-fail 'libdir=''${exec_prefix}' 'libdir=''${prefix}' \ + --replace-fail 'includedir=''${exec_prefix}' 'includedir=''${prefix}' + + substituteInPlace src/core/trust/terminal_agent.h \ + --replace-fail '/bin/whiptail' '${lib.getExe' newt "whiptail"}' + '' + + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' + substituteInPlace CMakeLists.txt \ + --replace-fail 'add_subdirectory(tests)' "" + ''; strictDeps = true; diff --git a/pkgs/desktops/lomiri/qml/lomiri-notifications/default.nix b/pkgs/desktops/lomiri/qml/lomiri-notifications/default.nix index 56b86eaa39185e..353eb1a30b86dd 100644 --- a/pkgs/desktops/lomiri/qml/lomiri-notifications/default.nix +++ b/pkgs/desktops/lomiri/qml/lomiri-notifications/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, gitUpdater -, cmake -, dbus -, libqtdbustest -, lomiri-api -, pkg-config -, qtbase -, qtdeclarative +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + gitUpdater, + cmake, + dbus, + libqtdbustest, + lomiri-api, + pkg-config, + qtbase, + qtdeclarative, }: stdenv.mkDerivation (finalAttrs: { @@ -32,16 +33,18 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - postPatch = '' - substituteInPlace CMakeLists.txt \ - --replace "\''${CMAKE_INSTALL_LIBDIR}/qt5/qml" "\''${CMAKE_INSTALL_PREFIX}/${qtbase.qtQmlPrefix}" - - # Need to replace prefix to not try to install into lomiri-api prefix - substituteInPlace src/CMakeLists.txt \ - --replace '--variable=plugindir' '--define-variable=prefix=''${CMAKE_INSTALL_PREFIX} --variable=plugindir' - '' + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' - sed -i CMakeLists.txt -e '/add_subdirectory(test)/d' - ''; + postPatch = + '' + substituteInPlace CMakeLists.txt \ + --replace "\''${CMAKE_INSTALL_LIBDIR}/qt5/qml" "\''${CMAKE_INSTALL_PREFIX}/${qtbase.qtQmlPrefix}" + + # Need to replace prefix to not try to install into lomiri-api prefix + substituteInPlace src/CMakeLists.txt \ + --replace '--variable=plugindir' '--define-variable=prefix=''${CMAKE_INSTALL_PREFIX} --variable=plugindir' + '' + + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' + sed -i CMakeLists.txt -e '/add_subdirectory(test)/d' + ''; strictDeps = true; diff --git a/pkgs/desktops/lomiri/qml/lomiri-push-qml/default.nix b/pkgs/desktops/lomiri/qml/lomiri-push-qml/default.nix index 5fba0809887937..1482cb770efdf7 100644 --- a/pkgs/desktops/lomiri/qml/lomiri-push-qml/default.nix +++ b/pkgs/desktops/lomiri/qml/lomiri-push-qml/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, cmake -, lomiri-api -, lomiri-indicator-network -, pkg-config -, qtbase -, qtdeclarative +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + cmake, + lomiri-api, + lomiri-indicator-network, + pkg-config, + qtbase, + qtdeclarative, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/desktops/lomiri/qml/lomiri-settings-components/default.nix b/pkgs/desktops/lomiri/qml/lomiri-settings-components/default.nix index 09fbe7d9b6eb52..4f1ee61b2623b4 100644 --- a/pkgs/desktops/lomiri/qml/lomiri-settings-components/default.nix +++ b/pkgs/desktops/lomiri/qml/lomiri-settings-components/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitLab -, gitUpdater -, cmake -, cmake-extras -, pkg-config -, python3 -, qtbase -, qtdeclarative +{ + stdenv, + lib, + fetchFromGitLab, + gitUpdater, + cmake, + cmake-extras, + pkg-config, + python3, + qtbase, + qtdeclarative, }: stdenv.mkDerivation (finalAttrs: { @@ -21,15 +22,17 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-2Wyh+2AW6EeKRv26D4l+GIoH5sWC9SmOODNHOveFZPg="; }; - postPatch = '' - patchShebangs tests/imports/check_imports.py + postPatch = + '' + patchShebangs tests/imports/check_imports.py - substituteInPlace CMakeLists.txt \ - --replace "\''${CMAKE_INSTALL_LIBDIR}/qt5/qml" '${placeholder "out"}/${qtbase.qtQmlPrefix}' - '' + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' - sed -i CMakeLists.txt \ - -e '/add_subdirectory(tests)/d' - ''; + substituteInPlace CMakeLists.txt \ + --replace "\''${CMAKE_INSTALL_LIBDIR}/qt5/qml" '${placeholder "out"}/${qtbase.qtQmlPrefix}' + '' + + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' + sed -i CMakeLists.txt \ + -e '/add_subdirectory(tests)/d' + ''; strictDeps = true; diff --git a/pkgs/desktops/lomiri/qml/lomiri-ui-extras/default.nix b/pkgs/desktops/lomiri/qml/lomiri-ui-extras/default.nix index 5a2097f476571e..b76ec5eca94fc0 100644 --- a/pkgs/desktops/lomiri/qml/lomiri-ui-extras/default.nix +++ b/pkgs/desktops/lomiri/qml/lomiri-ui-extras/default.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchFromGitLab -, gitUpdater -, cmake -, cmake-extras -, cups -, exiv2 -, lomiri-ui-toolkit -, pam -, pkg-config -, qtbase -, qtdeclarative -, xvfb-run +{ + stdenv, + lib, + fetchFromGitLab, + gitUpdater, + cmake, + cmake-extras, + cups, + exiv2, + lomiri-ui-toolkit, + pam, + pkg-config, + qtbase, + qtdeclarative, + xvfb-run, }: stdenv.mkDerivation (finalAttrs: { @@ -59,15 +60,20 @@ stdenv.mkDerivation (finalAttrs: { cmakeFlags = [ (lib.cmakeBool "ENABLE_TESTS" finalAttrs.finalPackage.doCheck) - (lib.cmakeFeature "CMAKE_CTEST_ARGUMENTS" (lib.concatStringsSep ";" [ - # Exclude tests - "-E" (lib.strings.escapeShellArg "(${lib.concatStringsSep "|" [ - # tst_busy_indicator runs into a codepath in lomiri-ui-toolkit that expects a working GL context - "^tst_busy_indicator" - # Photo & PhotoImageProvider Randomly fail, unsure why - "^tst_PhotoEditorPhoto" - ]})") - ])) + (lib.cmakeFeature "CMAKE_CTEST_ARGUMENTS" ( + lib.concatStringsSep ";" [ + # Exclude tests + "-E" + (lib.strings.escapeShellArg "(${ + lib.concatStringsSep "|" [ + # tst_busy_indicator runs into a codepath in lomiri-ui-toolkit that expects a working GL context + "^tst_busy_indicator" + # Photo & PhotoImageProvider Randomly fail, unsure why + "^tst_PhotoEditorPhoto" + ] + })") + ] + )) ]; doCheck = stdenv.buildPlatform.canExecute stdenv.hostPlatform; @@ -75,13 +81,23 @@ stdenv.mkDerivation (finalAttrs: { # Parallelism breaks xvfb-run-launched script for QML tests enableParallelChecking = false; - preCheck = let - listToQtVar = suffix: lib.makeSearchPathOutput "bin" suffix; - in '' - export QT_PLUGIN_PATH=${listToQtVar qtbase.qtPluginPrefix [ qtbase ]} - export QML2_IMPORT_PATH=${listToQtVar qtbase.qtQmlPrefix ([ qtdeclarative lomiri-ui-toolkit ] ++ lomiri-ui-toolkit.propagatedBuildInputs)} - export XDG_RUNTIME_DIR=$PWD - ''; + preCheck = + let + listToQtVar = suffix: lib.makeSearchPathOutput "bin" suffix; + in + '' + export QT_PLUGIN_PATH=${listToQtVar qtbase.qtPluginPrefix [ qtbase ]} + export QML2_IMPORT_PATH=${ + listToQtVar qtbase.qtQmlPrefix ( + [ + qtdeclarative + lomiri-ui-toolkit + ] + ++ lomiri-ui-toolkit.propagatedBuildInputs + ) + } + export XDG_RUNTIME_DIR=$PWD + ''; passthru = { updateScript = gitUpdater { }; diff --git a/pkgs/desktops/lomiri/services/biometryd/default.nix b/pkgs/desktops/lomiri/services/biometryd/default.nix index d8f65fea41a7f4..fba0305124b969 100644 --- a/pkgs/desktops/lomiri/services/biometryd/default.nix +++ b/pkgs/desktops/lomiri/services/biometryd/default.nix @@ -1,23 +1,24 @@ -{ stdenv -, lib -, fetchFromGitLab -, gitUpdater -, testers -, boost -, cmake -, cmake-extras -, dbus -, dbus-cpp -, gtest -, libapparmor -, libelf -, pkg-config -, process-cpp -, properties-cpp -, qtbase -, qtdeclarative -, sqlite -, validatePkgConfig +{ + stdenv, + lib, + fetchFromGitLab, + gitUpdater, + testers, + boost, + cmake, + cmake-extras, + dbus, + dbus-cpp, + gtest, + libapparmor, + libelf, + pkg-config, + process-cpp, + properties-cpp, + qtbase, + qtdeclarative, + sqlite, + validatePkgConfig, }: stdenv.mkDerivation (finalAttrs: { @@ -36,21 +37,23 @@ stdenv.mkDerivation (finalAttrs: { "dev" ]; - postPatch = '' - # Substitute systemd's prefix in pkg-config call - substituteInPlace data/CMakeLists.txt \ - --replace-fail 'pkg_get_variable(SYSTEMD_SYSTEM_UNIT_DIR systemd systemdsystemunitdir)' 'pkg_get_variable(SYSTEMD_SYSTEM_UNIT_DIR systemd systemdsystemunitdir DEFINE_VARIABLES prefix=''${CMAKE_INSTALL_PREFIX})' - - substituteInPlace src/biometry/qml/Biometryd/CMakeLists.txt \ - --replace-fail "\''${CMAKE_INSTALL_LIBDIR}/qt5/qml" "\''${CMAKE_INSTALL_PREFIX}/${qtbase.qtQmlPrefix}" - - # For our automatic pkg-config output patcher to work, prefix must be used here - substituteInPlace data/biometryd.pc.in \ - --replace-fail 'libdir=''${exec_prefix}' 'libdir=''${prefix}' \ - --replace-fail 'includedir=''${exec_prefix}' 'includedir=''${prefix}' \ - '' + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' - sed -i -e '/add_subdirectory(tests)/d' CMakeLists.txt - ''; + postPatch = + '' + # Substitute systemd's prefix in pkg-config call + substituteInPlace data/CMakeLists.txt \ + --replace-fail 'pkg_get_variable(SYSTEMD_SYSTEM_UNIT_DIR systemd systemdsystemunitdir)' 'pkg_get_variable(SYSTEMD_SYSTEM_UNIT_DIR systemd systemdsystemunitdir DEFINE_VARIABLES prefix=''${CMAKE_INSTALL_PREFIX})' + + substituteInPlace src/biometry/qml/Biometryd/CMakeLists.txt \ + --replace-fail "\''${CMAKE_INSTALL_LIBDIR}/qt5/qml" "\''${CMAKE_INSTALL_PREFIX}/${qtbase.qtQmlPrefix}" + + # For our automatic pkg-config output patcher to work, prefix must be used here + substituteInPlace data/biometryd.pc.in \ + --replace-fail 'libdir=''${exec_prefix}' 'libdir=''${prefix}' \ + --replace-fail 'includedir=''${exec_prefix}' 'includedir=''${prefix}' \ + '' + + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' + sed -i -e '/add_subdirectory(tests)/d' CMakeLists.txt + ''; strictDeps = true; diff --git a/pkgs/desktops/lomiri/services/hfd-service/default.nix b/pkgs/desktops/lomiri/services/hfd-service/default.nix index ff5f34abc2947b..51b5d99237528b 100644 --- a/pkgs/desktops/lomiri/services/hfd-service/default.nix +++ b/pkgs/desktops/lomiri/services/hfd-service/default.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchFromGitLab -, gitUpdater -, accountsservice -, cmake -, cmake-extras -, deviceinfo -, libgbinder -, libglibutil -, pkg-config -, qtbase -, qtdeclarative -, qtfeedback +{ + stdenv, + lib, + fetchFromGitLab, + gitUpdater, + accountsservice, + cmake, + cmake-extras, + deviceinfo, + libgbinder, + libglibutil, + pkg-config, + qtbase, + qtdeclarative, + qtfeedback, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/desktops/lomiri/services/lomiri-thumbnailer/default.nix b/pkgs/desktops/lomiri/services/lomiri-thumbnailer/default.nix index b6e07f20831dc8..f7a18d5a07263a 100644 --- a/pkgs/desktops/lomiri/services/lomiri-thumbnailer/default.nix +++ b/pkgs/desktops/lomiri/services/lomiri-thumbnailer/default.nix @@ -1,32 +1,33 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, gitUpdater -, testers -, boost -, cmake -, cmake-extras -, doxygen -, gst_all_1 -, gdk-pixbuf -, gtest -, makeFontsConf -, libapparmor -, libexif -, libqtdbustest -, librsvg -, lomiri-api -, persistent-cache-cpp -, pkg-config -, python3 -, qtbase -, qtdeclarative -, shared-mime-info -, taglib -, validatePkgConfig -, wrapGAppsHook3 -, xvfb-run +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + gitUpdater, + testers, + boost, + cmake, + cmake-extras, + doxygen, + gst_all_1, + gdk-pixbuf, + gtest, + makeFontsConf, + libapparmor, + libexif, + libqtdbustest, + librsvg, + lomiri-api, + persistent-cache-cpp, + pkg-config, + python3, + qtbase, + qtdeclarative, + shared-mime-info, + taglib, + validatePkgConfig, + wrapGAppsHook3, + xvfb-run, }: stdenv.mkDerivation (finalAttrs: { @@ -124,34 +125,40 @@ stdenv.mkDerivation (finalAttrs: { doxygen gdk-pixbuf # setup hook pkg-config - (python3.withPackages (ps: with ps; lib.optionals finalAttrs.finalPackage.doCheck [ - python-dbusmock - tornado - ])) + (python3.withPackages ( + ps: + with ps; + lib.optionals finalAttrs.finalPackage.doCheck [ + python-dbusmock + tornado + ] + )) validatePkgConfig wrapGAppsHook3 ]; - buildInputs = [ - boost - cmake-extras - gdk-pixbuf - libapparmor - libexif - librsvg - lomiri-api - persistent-cache-cpp - qtbase - qtdeclarative - shared-mime-info - taglib - ] ++ (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-good - gst-plugins-bad - # maybe add ugly to cover all kinds of formats? - ]); + buildInputs = + [ + boost + cmake-extras + gdk-pixbuf + libapparmor + libexif + librsvg + lomiri-api + persistent-cache-cpp + qtbase + qtdeclarative + shared-mime-info + taglib + ] + ++ (with gst_all_1; [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + # maybe add ugly to cover all kinds of formats? + ]); nativeCheckInputs = [ shared-mime-info @@ -170,10 +177,13 @@ stdenv.mkDerivation (finalAttrs: { (lib.cmakeBool "GSETTINGS_COMPILE" true) # error: use of old-style cast to 'std::remove_reference<_GstElement*>::type' {aka 'struct _GstElement*'} (lib.cmakeBool "Werror" false) - (lib.cmakeFeature "CMAKE_CTEST_ARGUMENTS" (lib.concatStringsSep ";" [ - # QSignalSpy tests in QML suite always fail, pass when running interactively - "-E" "^qml" - ])) + (lib.cmakeFeature "CMAKE_CTEST_ARGUMENTS" ( + lib.concatStringsSep ";" [ + # QSignalSpy tests in QML suite always fail, pass when running interactively + "-E" + "^qml" + ] + )) ]; doCheck = stdenv.buildPlatform.canExecute stdenv.hostPlatform; @@ -182,7 +192,7 @@ stdenv.mkDerivation (finalAttrs: { preCheck = '' # Fontconfig warnings breaks some tests - export FONTCONFIG_FILE=${makeFontsConf { fontDirectories = []; }} + export FONTCONFIG_FILE=${makeFontsConf { fontDirectories = [ ]; }} export HOME=$TMPDIR # Some tests need Qt plugins @@ -208,7 +218,10 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "lomiri-thumbnailer-admin"; homepage = "https://gitlab.com/ubports/development/core/lomiri-thumbnailer"; changelog = "https://gitlab.com/ubports/development/core/lomiri-thumbnailer/-/blob/${finalAttrs.version}/ChangeLog"; - license = with licenses; [ gpl3Only lgpl3Only ]; + license = with licenses; [ + gpl3Only + lgpl3Only + ]; maintainers = teams.lomiri.members; platforms = platforms.linux; pkgConfigModules = [ diff --git a/pkgs/desktops/lumina/default.nix b/pkgs/desktops/lumina/default.nix index 10e75eea38f027..8efde941304a89 100644 --- a/pkgs/desktops/lumina/default.nix +++ b/pkgs/desktops/lumina/default.nix @@ -1,26 +1,28 @@ { pkgs, libsForQt5 }: let - packages = self: with self; { + packages = + self: with self; { - lumina = callPackage ./lumina { }; - lumina-calculator = callPackage ./lumina-calculator { }; - lumina-pdf = callPackage ./lumina-pdf { }; + lumina = callPackage ./lumina { }; + lumina-calculator = callPackage ./lumina-calculator { }; + lumina-pdf = callPackage ./lumina-pdf { }; - preRequisitePackages = [ - pkgs.fluxbox - pkgs.libsForQt5.kwindowsystem - pkgs.numlockx - pkgs.qt5.qtsvg - pkgs.xscreensaver - ]; + preRequisitePackages = [ + pkgs.fluxbox + pkgs.libsForQt5.kwindowsystem + pkgs.numlockx + pkgs.qt5.qtsvg + pkgs.xscreensaver + ]; - corePackages = [ - lumina - lumina-calculator - lumina-pdf - ]; + corePackages = [ + lumina + lumina-calculator + lumina-pdf + ]; - }; + }; -in pkgs.lib.makeScope libsForQt5.newScope packages +in +pkgs.lib.makeScope libsForQt5.newScope packages diff --git a/pkgs/desktops/lumina/lumina-calculator/default.nix b/pkgs/desktops/lumina/lumina-calculator/default.nix index 758bbf70d851f5..98ed2a4fadeb89 100644 --- a/pkgs/desktops/lumina/lumina-calculator/default.nix +++ b/pkgs/desktops/lumina/lumina-calculator/default.nix @@ -1,4 +1,11 @@ -{ lib, mkDerivation, fetchFromGitHub, qmake, qtbase, qttools }: +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qtbase, + qttools, +}: mkDerivation rec { pname = "lumina-calculator"; @@ -13,7 +20,10 @@ mkDerivation rec { sourceRoot = "${src.name}/src-qt5"; - nativeBuildInputs = [ qmake qttools ]; + nativeBuildInputs = [ + qmake + qttools + ]; buildInputs = [ qtbase ]; diff --git a/pkgs/desktops/lumina/lumina-pdf/default.nix b/pkgs/desktops/lumina/lumina-pdf/default.nix index cc9bd48c9de15d..04117d7f4cce4b 100644 --- a/pkgs/desktops/lumina/lumina-pdf/default.nix +++ b/pkgs/desktops/lumina/lumina-pdf/default.nix @@ -1,4 +1,12 @@ -{ lib, mkDerivation, fetchFromGitHub, qmake, qtbase, qttools, poppler }: +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qtbase, + qttools, + poppler, +}: mkDerivation rec { pname = "lumina-pdf"; @@ -13,9 +21,15 @@ mkDerivation rec { sourceRoot = "${src.name}/src-qt5"; - nativeBuildInputs = [ qmake qttools ]; + nativeBuildInputs = [ + qmake + qttools + ]; - buildInputs = [ qtbase poppler ]; + buildInputs = [ + qtbase + poppler + ]; postPatch = '' sed -i '1i\#include \' Renderer-poppler.cpp diff --git a/pkgs/desktops/lumina/lumina/default.nix b/pkgs/desktops/lumina/lumina/default.nix index de3d17571d6415..280885b07cae1d 100644 --- a/pkgs/desktops/lumina/lumina/default.nix +++ b/pkgs/desktops/lumina/lumina/default.nix @@ -1,19 +1,20 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, fluxbox -, hicolor-icon-theme -, libarchive -, numlockx -, qmake -, qtbase -, qtmultimedia -, qtsvg -, qttools -, qtx11extras -, xorg -, xscreensaver -, wrapGAppsHook3 +{ + lib, + mkDerivation, + fetchFromGitHub, + fluxbox, + hicolor-icon-theme, + libarchive, + numlockx, + qmake, + qtbase, + qtmultimedia, + qtsvg, + qttools, + qtx11extras, + xorg, + xscreensaver, + wrapGAppsHook3, }: mkDerivation rec { diff --git a/pkgs/desktops/lxde/core/lxappearance/default.nix b/pkgs/desktops/lxde/core/lxappearance/default.nix index 0143ab595e68ea..f7d297f0f423a7 100644 --- a/pkgs/desktops/lxde/core/lxappearance/default.nix +++ b/pkgs/desktops/lxde/core/lxappearance/default.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, fetchurl -, intltool -, pkg-config -, libX11 -, gtk2 -, gtk3 -, wrapGAppsHook3 -, withGtk3 ? true +{ + lib, + stdenv, + fetchurl, + intltool, + pkg-config, + libX11, + gtk2, + gtk3, + wrapGAppsHook3, + withGtk3 ? true, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxde/core/lxmenu-data/default.nix b/pkgs/desktops/lxde/core/lxmenu-data/default.nix index fc00c4cdad1e90..a53885f33ed744 100644 --- a/pkgs/desktops/lxde/core/lxmenu-data/default.nix +++ b/pkgs/desktops/lxde/core/lxmenu-data/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, intltool }: +{ + lib, + stdenv, + fetchurl, + intltool, +}: stdenv.mkDerivation rec { pname = "lxmenu-data"; diff --git a/pkgs/desktops/lxde/core/lxpanel/default.nix b/pkgs/desktops/lxde/core/lxpanel/default.nix index 3fc8f0b06cd8f7..9c47504405666d 100644 --- a/pkgs/desktops/lxde/core/lxpanel/default.nix +++ b/pkgs/desktops/lxde/core/lxpanel/default.nix @@ -1,30 +1,32 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, m4 -, intltool -, libxmlxx -, keybinder -, keybinder3 -, gtk2 -, gtk3 -, libX11 -, libfm -, libwnck -, libwnck2 -, libXmu -, libXpm -, cairo -, gdk-pixbuf -, gdk-pixbuf-xlib -, menu-cache -, lxmenu-data -, wirelesstools -, curl -, supportAlsa ? false, alsa-lib -, withGtk3 ? true +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + m4, + intltool, + libxmlxx, + keybinder, + keybinder3, + gtk2, + gtk3, + libX11, + libfm, + libwnck, + libwnck2, + libXmu, + libXpm, + cairo, + gdk-pixbuf, + gdk-pixbuf-xlib, + menu-cache, + lxmenu-data, + wirelesstools, + curl, + supportAlsa ? false, + alsa-lib, + withGtk3 ? true, }: stdenv.mkDerivation rec { @@ -36,7 +38,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-HjGPV9fja2HCOlBNA9JDDHja0ULBgERRBh8bPqVEHug="; }; - nativeBuildInputs = [ pkg-config gettext m4 intltool libxmlxx ]; + nativeBuildInputs = [ + pkg-config + gettext + m4 + intltool + libxmlxx + ]; buildInputs = [ (if withGtk3 then keybinder3 else keybinder) (if withGtk3 then gtk3 else gtk2) diff --git a/pkgs/desktops/lxde/core/lxrandr/default.nix b/pkgs/desktops/lxde/core/lxrandr/default.nix index 791540468f3aab..2e395e8c10faac 100644 --- a/pkgs/desktops/lxde/core/lxrandr/default.nix +++ b/pkgs/desktops/lxde/core/lxrandr/default.nix @@ -1,12 +1,14 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, intltool -, gtk2 -, libX11 -, xrandr -, withGtk3 ? false, gtk3 +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + gtk2, + libX11, + xrandr, + withGtk3 ? false, + gtk3, }: stdenv.mkDerivation rec { @@ -20,7 +22,10 @@ stdenv.mkDerivation rec { configureFlags = lib.optional withGtk3 "--enable-gtk3"; - nativeBuildInputs = [ pkg-config intltool ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; buildInputs = [ libX11 xrandr diff --git a/pkgs/desktops/lxde/core/lxsession/default.nix b/pkgs/desktops/lxde/core/lxsession/default.nix index 056651e0390eb3..74e49b6bb273a4 100644 --- a/pkgs/desktops/lxde/core/lxsession/default.nix +++ b/pkgs/desktops/lxde/core/lxsession/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, docbook_xml_dtd_412 -, docbook_xsl -, intltool -, libxml2 -, libxslt -, pkg-config -, wrapGAppsHook3 -, gtk2-x11 -, libX11 -, polkit -, vala +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + docbook_xml_dtd_412, + docbook_xsl, + intltool, + libxml2, + libxslt, + pkg-config, + wrapGAppsHook3, + gtk2-x11, + libX11, + polkit, + vala, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxde/core/lxtask/default.nix b/pkgs/desktops/lxde/core/lxtask/default.nix index b29581dfe5fa4c..0d765e5d45131c 100644 --- a/pkgs/desktops/lxde/core/lxtask/default.nix +++ b/pkgs/desktops/lxde/core/lxtask/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, gtk3 -, intltool -, libintl -, pkg-config -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gtk3, + intltool, + libintl, + pkg-config, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxde/default.nix b/pkgs/desktops/lxde/default.nix index 8421bc5dac62df..3b701cadd12bd2 100644 --- a/pkgs/desktops/lxde/default.nix +++ b/pkgs/desktops/lxde/default.nix @@ -1,25 +1,31 @@ -{ config, lib, pkgs }: +{ + config, + lib, + pkgs, +}: -lib.makeScope pkgs.newScope (self: with self; { +lib.makeScope pkgs.newScope ( + self: with self; { - inherit (pkgs) gtk2-x11; + inherit (pkgs) gtk2-x11; - lxappearance = callPackage ./core/lxappearance { }; + lxappearance = callPackage ./core/lxappearance { }; - lxappearance-gtk2 = callPackage ./core/lxappearance { - gtk2 = gtk2-x11; - withGtk3 = false; - }; + lxappearance-gtk2 = callPackage ./core/lxappearance { + gtk2 = gtk2-x11; + withGtk3 = false; + }; - lxmenu-data = callPackage ./core/lxmenu-data { }; + lxmenu-data = callPackage ./core/lxmenu-data { }; - lxpanel = callPackage ./core/lxpanel { - gtk2 = gtk2-x11; - }; + lxpanel = callPackage ./core/lxpanel { + gtk2 = gtk2-x11; + }; - lxrandr = callPackage ./core/lxrandr { }; + lxrandr = callPackage ./core/lxrandr { }; - lxsession = callPackage ./core/lxsession { }; + lxsession = callPackage ./core/lxsession { }; - lxtask = callPackage ./core/lxtask { }; -}) + lxtask = callPackage ./core/lxtask { }; + } +) diff --git a/pkgs/desktops/lxqt/compton-conf/default.nix b/pkgs/desktops/lxqt/compton-conf/default.nix index 2403975b481b77..3db308a08c7c12 100644 --- a/pkgs/desktops/lxqt/compton-conf/default.nix +++ b/pkgs/desktops/lxqt/compton-conf/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libconfig -, lxqt-build-tools -, pkg-config -, qtbase -, qttools -, qtx11extras -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libconfig, + lxqt-build-tools, + pkg-config, + qtbase, + qttools, + qtx11extras, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/libdbusmenu-lxqt/default.nix b/pkgs/desktops/lxqt/libdbusmenu-lxqt/default.nix index 5c4ac79a2d826f..3c71e8d3268dff 100644 --- a/pkgs/desktops/lxqt/libdbusmenu-lxqt/default.nix +++ b/pkgs/desktops/lxqt/libdbusmenu-lxqt/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, qtbase -, wrapQtAppsHook -, gitUpdater +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + qtbase, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/libfm-qt/default.nix b/pkgs/desktops/lxqt/libfm-qt/default.nix index 6bfd1bafb5368f..734818687e4d78 100644 --- a/pkgs/desktops/lxqt/libfm-qt/default.nix +++ b/pkgs/desktops/lxqt/libfm-qt/default.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libXdmcp -, libexif -, libfm -, libpthreadstubs -, libxcb -, lxqt-build-tools -, lxqt-menu-data -, menu-cache -, pcre -, pkg-config -, qttools -, wrapQtAppsHook -, gitUpdater -, version ? "2.1.0" -, qtx11extras ? null +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libXdmcp, + libexif, + libfm, + libpthreadstubs, + libxcb, + lxqt-build-tools, + lxqt-menu-data, + menu-cache, + pcre, + pkg-config, + qttools, + wrapQtAppsHook, + gitUpdater, + version ? "2.1.0", + qtx11extras ? null, }: stdenv.mkDerivation rec { @@ -27,10 +28,12 @@ stdenv.mkDerivation rec { owner = "lxqt"; repo = "libfm-qt"; rev = version; - hash = { - "1.4.0" = "sha256-QxPYSA7537K+/dRTxIYyg+Q/kj75rZOdzlUsmSdQcn4="; - "2.1.0" = "sha256-yH3lyOpmDWjA3bV6msjw7fShs1HnAFOmkGer2Z9N/Tg="; - }."${version}"; + hash = + { + "1.4.0" = "sha256-QxPYSA7537K+/dRTxIYyg+Q/kj75rZOdzlUsmSdQcn4="; + "2.1.0" = "sha256-yH3lyOpmDWjA3bV6msjw7fShs1HnAFOmkGer2Z9N/Tg="; + } + ."${version}"; }; nativeBuildInputs = [ @@ -50,8 +53,7 @@ stdenv.mkDerivation rec { lxqt-menu-data menu-cache pcre - ] ++ (lib.optionals (lib.versionAtLeast "2.0.0" version) [qtx11extras]) - ; + ] ++ (lib.optionals (lib.versionAtLeast "2.0.0" version) [ qtx11extras ]); passthru.updateScript = gitUpdater { }; diff --git a/pkgs/desktops/lxqt/liblxqt/default.nix b/pkgs/desktops/lxqt/liblxqt/default.nix index 83ed1106ff4085..2e884006e2a78c 100644 --- a/pkgs/desktops/lxqt/liblxqt/default.nix +++ b/pkgs/desktops/lxqt/liblxqt/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gitUpdater -, kwindowsystem -, libXScrnSaver -, libqtxdg -, lxqt-build-tools -, polkit-qt-1 -, qtsvg -, qttools -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gitUpdater, + kwindowsystem, + libXScrnSaver, + libqtxdg, + lxqt-build-tools, + polkit-qt-1, + qtsvg, + qttools, + wrapQtAppsHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/libqtxdg/default.nix b/pkgs/desktops/lxqt/libqtxdg/default.nix index ebb4baa05ddda7..89ae2a9318658a 100644 --- a/pkgs/desktops/lxqt/libqtxdg/default.nix +++ b/pkgs/desktops/lxqt/libqtxdg/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qtbase -, qtsvg -, lxqt-build-tools -, wrapQtAppsHook -, gitUpdater -, version ? "4.1.0" +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtbase, + qtsvg, + lxqt-build-tools, + wrapQtAppsHook, + gitUpdater, + version ? "4.1.0", }: stdenv.mkDerivation rec { @@ -18,10 +19,12 @@ stdenv.mkDerivation rec { owner = "lxqt"; repo = pname; rev = version; - hash = { - "3.12.0" = "sha256-y+3noaHubZnwUUs8vbMVvZPk+6Fhv37QXUb//reedCU="; - "4.1.0" = "sha256-Efn08a8MkR459Ww0WiEb5GXKgQzJwKupIdL2TySpivE="; - }."${version}"; + hash = + { + "3.12.0" = "sha256-y+3noaHubZnwUUs8vbMVvZPk+6Fhv37QXUb//reedCU="; + "4.1.0" = "sha256-Efn08a8MkR459Ww0WiEb5GXKgQzJwKupIdL2TySpivE="; + } + ."${version}"; }; nativeBuildInputs = [ diff --git a/pkgs/desktops/lxqt/libsysstat/default.nix b/pkgs/desktops/lxqt/libsysstat/default.nix index 09b8450740adf6..2030d5579e32da 100644 --- a/pkgs/desktops/lxqt/libsysstat/default.nix +++ b/pkgs/desktops/lxqt/libsysstat/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, qtbase -, lxqt-build-tools -, wrapQtAppsHook -, gitUpdater +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + qtbase, + lxqt-build-tools, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lximage-qt/default.nix b/pkgs/desktops/lxqt/lximage-qt/default.nix index 4a6013f6eb1a12..b7d7792aef0915 100644 --- a/pkgs/desktops/lxqt/lximage-qt/default.nix +++ b/pkgs/desktops/lxqt/lximage-qt/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, libXdmcp -, libexif -, libfm-qt -, libpthreadstubs -, lxqt-build-tools -, menu-cache -, qtbase -, qtimageformats -, qtsvg -, qttools -, qtwayland -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libXdmcp, + libexif, + libfm-qt, + libpthreadstubs, + lxqt-build-tools, + menu-cache, + qtbase, + qtimageformats, + qtsvg, + qttools, + qtwayland, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-about/default.nix b/pkgs/desktops/lxqt/lxqt-about/default.nix index eaf0d808df08dc..08103ae0f946aa 100644 --- a/pkgs/desktops/lxqt/lxqt-about/default.nix +++ b/pkgs/desktops/lxqt/lxqt-about/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, kwindowsystem -, liblxqt -, libqtxdg -, lxqt-build-tools -, qtsvg -, qttools -, qtwayland -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + kwindowsystem, + liblxqt, + libqtxdg, + lxqt-build-tools, + qtsvg, + qttools, + qtwayland, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-admin/default.nix b/pkgs/desktops/lxqt/lxqt-admin/default.nix index b194f6e09f6a44..12fca14d95bf83 100644 --- a/pkgs/desktops/lxqt/lxqt-admin/default.nix +++ b/pkgs/desktops/lxqt/lxqt-admin/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, kwindowsystem -, liblxqt -, libqtxdg -, lxqt-build-tools -, polkit-qt-1 -, qtsvg -, qttools -, qtwayland -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + kwindowsystem, + liblxqt, + libqtxdg, + lxqt-build-tools, + polkit-qt-1, + qtsvg, + qttools, + qtwayland, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-archiver/default.nix b/pkgs/desktops/lxqt/lxqt-archiver/default.nix index 0dabe275542c9b..144c819a177e6c 100644 --- a/pkgs/desktops/lxqt/lxqt-archiver/default.nix +++ b/pkgs/desktops/lxqt/lxqt-archiver/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, lxqt-build-tools -, json-glib -, libexif -, libfm-qt -, menu-cache -, qtbase -, qttools -, qtwayland -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + lxqt-build-tools, + json-glib, + libexif, + libfm-qt, + menu-cache, + qtbase, + qttools, + qtwayland, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-build-tools/default.nix b/pkgs/desktops/lxqt/lxqt-build-tools/default.nix index 7c1a96cfe78410..15c2a73c9f0f83 100644 --- a/pkgs/desktops/lxqt/lxqt-build-tools/default.nix +++ b/pkgs/desktops/lxqt/lxqt-build-tools/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, pcre -, qtbase -, glib -, perl -, wrapQtAppsHook -, gitUpdater -, version ? "2.1.0" +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + pcre, + qtbase, + glib, + perl, + wrapQtAppsHook, + gitUpdater, + version ? "2.1.0", }: stdenv.mkDerivation rec { @@ -20,10 +21,12 @@ stdenv.mkDerivation rec { owner = "lxqt"; repo = pname; rev = version; - hash = { - "0.13.0" = "sha256-4/hVlEdqqqd6CNitCRkIzsS1R941vPJdirIklp4acXA="; - "2.1.0" = "sha256-fZ5DbXnYm6oWDZdwiw2DpWFQMYd7VZ4oKkGIzQkaV94="; - }."${version}"; + hash = + { + "0.13.0" = "sha256-4/hVlEdqqqd6CNitCRkIzsS1R941vPJdirIklp4acXA="; + "2.1.0" = "sha256-fZ5DbXnYm6oWDZdwiw2DpWFQMYd7VZ4oKkGIzQkaV94="; + } + ."${version}"; }; postPatch = '' diff --git a/pkgs/desktops/lxqt/lxqt-config/default.nix b/pkgs/desktops/lxqt/lxqt-config/default.nix index a7a5d7df719174..4215ce43fde525 100644 --- a/pkgs/desktops/lxqt/lxqt-config/default.nix +++ b/pkgs/desktops/lxqt/lxqt-config/default.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, glib -, kwindowsystem -, libXScrnSaver -, libXcursor -, libXdmcp -, libkscreen -, liblxqt -, libpthreadstubs -, libqtxdg -, libxcb -, lxqt-build-tools -, lxqt-menu-data -, pkg-config -, qtbase -, qtsvg -, qttools -, qtwayland -, wrapQtAppsHook -, xf86inputlibinput -, xkeyboard_config -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + glib, + kwindowsystem, + libXScrnSaver, + libXcursor, + libXdmcp, + libkscreen, + liblxqt, + libpthreadstubs, + libqtxdg, + libxcb, + lxqt-build-tools, + lxqt-menu-data, + pkg-config, + qtbase, + qtsvg, + qttools, + qtwayland, + wrapQtAppsHook, + xf86inputlibinput, + xkeyboard_config, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-globalkeys/default.nix b/pkgs/desktops/lxqt/lxqt-globalkeys/default.nix index 8079df71267eeb..4e2cb1a8c705f8 100644 --- a/pkgs/desktops/lxqt/lxqt-globalkeys/default.nix +++ b/pkgs/desktops/lxqt/lxqt-globalkeys/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, lxqt-build-tools -, qtbase -, qttools -, qtsvg -, kwindowsystem -, liblxqt -, libqtxdg -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + lxqt-build-tools, + qtbase, + qttools, + qtsvg, + kwindowsystem, + liblxqt, + libqtxdg, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-menu-data/default.nix b/pkgs/desktops/lxqt/lxqt-menu-data/default.nix index da2e7610593951..ccb89df6fd59f4 100644 --- a/pkgs/desktops/lxqt/lxqt-menu-data/default.nix +++ b/pkgs/desktops/lxqt/lxqt-menu-data/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, lxqt-build-tools -, qttools -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + lxqt-build-tools, + qttools, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-notificationd/default.nix b/pkgs/desktops/lxqt/lxqt-notificationd/default.nix index 4f01a9d7114ab3..df05f4664e66cf 100644 --- a/pkgs/desktops/lxqt/lxqt-notificationd/default.nix +++ b/pkgs/desktops/lxqt/lxqt-notificationd/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, kwindowsystem -, layer-shell-qt -, liblxqt -, libqtxdg -, lxqt-build-tools -, qtbase -, qtsvg -, qttools -, qtwayland -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + kwindowsystem, + layer-shell-qt, + liblxqt, + libqtxdg, + lxqt-build-tools, + qtbase, + qtsvg, + qttools, + qtwayland, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-openssh-askpass/default.nix b/pkgs/desktops/lxqt/lxqt-openssh-askpass/default.nix index 2a42933d5c497a..e496260b7fe4e1 100644 --- a/pkgs/desktops/lxqt/lxqt-openssh-askpass/default.nix +++ b/pkgs/desktops/lxqt/lxqt-openssh-askpass/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, kwindowsystem -, liblxqt -, libqtxdg -, lxqt-build-tools -, qtbase -, qtsvg -, qttools -, qtwayland -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + kwindowsystem, + liblxqt, + libqtxdg, + lxqt-build-tools, + qtbase, + qtsvg, + qttools, + qtwayland, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-panel/default.nix b/pkgs/desktops/lxqt/lxqt-panel/default.nix index bee22f7405f5a4..eed744d1c01518 100644 --- a/pkgs/desktops/lxqt/lxqt-panel/default.nix +++ b/pkgs/desktops/lxqt/lxqt-panel/default.nix @@ -1,36 +1,37 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, alsa-lib -, libdbusmenu-lxqt -, kguiaddons -, kwindowsystem -, layer-shell-qt -, libXdamage -, libXdmcp -, libXtst -, libdbusmenu -, liblxqt -, libpthreadstubs -, libpulseaudio -, libqtxdg -, libstatgrab -, libsysstat -, lm_sensors -, lxqt-build-tools -, lxqt-globalkeys -, lxqt-menu-data -, menu-cache -, pcre -, qtbase -, qtsvg -, qttools -, qtwayland -, solid -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + alsa-lib, + libdbusmenu-lxqt, + kguiaddons, + kwindowsystem, + layer-shell-qt, + libXdamage, + libXdmcp, + libXtst, + libdbusmenu, + liblxqt, + libpthreadstubs, + libpulseaudio, + libqtxdg, + libstatgrab, + libsysstat, + lm_sensors, + lxqt-build-tools, + lxqt-globalkeys, + lxqt-menu-data, + menu-cache, + pcre, + qtbase, + qtsvg, + qttools, + qtwayland, + solid, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-policykit/default.nix b/pkgs/desktops/lxqt/lxqt-policykit/default.nix index 3d7ca3ec68a7ef..5a632594dde5d6 100644 --- a/pkgs/desktops/lxqt/lxqt-policykit/default.nix +++ b/pkgs/desktops/lxqt/lxqt-policykit/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, kwindowsystem -, liblxqt -, libqtxdg -, lxqt-build-tools -, pcre -, pkg-config -, polkit -, polkit-qt-1 -, qtbase -, qtsvg -, qttools -, qtwayland -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + kwindowsystem, + liblxqt, + libqtxdg, + lxqt-build-tools, + pcre, + pkg-config, + polkit, + polkit-qt-1, + qtbase, + qtsvg, + qttools, + qtwayland, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-powermanagement/default.nix b/pkgs/desktops/lxqt/lxqt-powermanagement/default.nix index dd46c72fdd90b7..f24d1d62f02e2b 100644 --- a/pkgs/desktops/lxqt/lxqt-powermanagement/default.nix +++ b/pkgs/desktops/lxqt/lxqt-powermanagement/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, kidletime -, kwindowsystem -, liblxqt -, libqtxdg -, lxqt-build-tools -, lxqt-globalkeys -, qtbase -, qtsvg -, qttools -, qtwayland -, solid -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + kidletime, + kwindowsystem, + liblxqt, + libqtxdg, + lxqt-build-tools, + lxqt-globalkeys, + qtbase, + qtsvg, + qttools, + qtwayland, + solid, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-qtplugin/default.nix b/pkgs/desktops/lxqt/lxqt-qtplugin/default.nix index 687846ba2e256b..7efceeb7dad8ad 100644 --- a/pkgs/desktops/lxqt/lxqt-qtplugin/default.nix +++ b/pkgs/desktops/lxqt/lxqt-qtplugin/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libdbusmenu-lxqt -, libdbusmenu ? null -, libfm-qt -, libqtxdg -, lxqt-build-tools -, gitUpdater -, qtbase -, qtsvg -, qttools -, wrapQtAppsHook -, version ? "2.1.0" +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libdbusmenu-lxqt, + libdbusmenu ? null, + libfm-qt, + libqtxdg, + lxqt-build-tools, + gitUpdater, + qtbase, + qtsvg, + qttools, + wrapQtAppsHook, + version ? "2.1.0", }: stdenv.mkDerivation rec { @@ -23,10 +24,12 @@ stdenv.mkDerivation rec { owner = "lxqt"; repo = pname; rev = version; - hash = { - "1.4.1" = "sha256-sp/LvQNfodMYQ4kNbBv4PTNfs38XjYLezuxRltZd4kc="; - "2.1.0" = "sha256-F171IgAhRXJ9sTt8VVDVO9hrmyHbCElsskdDmFr3HB0="; - }."${version}"; + hash = + { + "1.4.1" = "sha256-sp/LvQNfodMYQ4kNbBv4PTNfs38XjYLezuxRltZd4kc="; + "2.1.0" = "sha256-F171IgAhRXJ9sTt8VVDVO9hrmyHbCElsskdDmFr3HB0="; + } + ."${version}"; }; nativeBuildInputs = [ diff --git a/pkgs/desktops/lxqt/lxqt-runner/default.nix b/pkgs/desktops/lxqt/lxqt-runner/default.nix index fd2b586778a5e5..49bb815f1eb247 100644 --- a/pkgs/desktops/lxqt/lxqt-runner/default.nix +++ b/pkgs/desktops/lxqt/lxqt-runner/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, kwindowsystem -, layer-shell-qt -, liblxqt -, libqtxdg -, lxqt-build-tools -, lxqt-globalkeys -, menu-cache -, muparser -, pcre -, pkg-config -, qtbase -, qtsvg -, qttools -, qtwayland -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + kwindowsystem, + layer-shell-qt, + liblxqt, + libqtxdg, + lxqt-build-tools, + lxqt-globalkeys, + menu-cache, + muparser, + pcre, + pkg-config, + qtbase, + qtsvg, + qttools, + qtwayland, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-session/default.nix b/pkgs/desktops/lxqt/lxqt-session/default.nix index 2519954c9dca27..e01b14f3088888 100644 --- a/pkgs/desktops/lxqt/lxqt-session/default.nix +++ b/pkgs/desktops/lxqt/lxqt-session/default.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, kwindowsystem -, layer-shell-qt -, libXdmcp -, liblxqt -, libpthreadstubs -, libqtxdg -, lxqt-build-tools -, pkg-config -, procps -, qtbase -, qtsvg -, qttools -, qtwayland -, qtxdg-tools -, wrapQtAppsHook -, xdg-user-dirs -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + kwindowsystem, + layer-shell-qt, + libXdmcp, + liblxqt, + libpthreadstubs, + libqtxdg, + lxqt-build-tools, + pkg-config, + procps, + qtbase, + qtsvg, + qttools, + qtwayland, + qtxdg-tools, + wrapQtAppsHook, + xdg-user-dirs, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-sudo/default.nix b/pkgs/desktops/lxqt/lxqt-sudo/default.nix index 91fd56c211f78e..0db1cefbafb813 100644 --- a/pkgs/desktops/lxqt/lxqt-sudo/default.nix +++ b/pkgs/desktops/lxqt/lxqt-sudo/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, kwindowsystem -, liblxqt -, libqtxdg -, lxqt-build-tools -, qtbase -, qtsvg -, qttools -, qtwayland -, sudo -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + kwindowsystem, + liblxqt, + libqtxdg, + lxqt-build-tools, + qtbase, + qtsvg, + qttools, + qtwayland, + sudo, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/lxqt-themes/default.nix b/pkgs/desktops/lxqt/lxqt-themes/default.nix index 50b814724c5111..0b90cbfd4a8f69 100644 --- a/pkgs/desktops/lxqt/lxqt-themes/default.nix +++ b/pkgs/desktops/lxqt/lxqt-themes/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, lxqt-build-tools -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + lxqt-build-tools, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/obconf-qt/default.nix b/pkgs/desktops/lxqt/obconf-qt/default.nix index 254ab75ed92124..7ab69bbdd9738f 100644 --- a/pkgs/desktops/lxqt/obconf-qt/default.nix +++ b/pkgs/desktops/lxqt/obconf-qt/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libSM -, libXdmcp -, libpthreadstubs -, lxqt-build-tools -, openbox -, pcre -, pkg-config -, qtbase -, qttools -, qtwayland -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libSM, + libXdmcp, + libpthreadstubs, + lxqt-build-tools, + openbox, + pcre, + pkg-config, + qtbase, + qttools, + qtwayland, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/pcmanfm-qt/default.nix b/pkgs/desktops/lxqt/pcmanfm-qt/default.nix index e375c20791c70a..4b23fb6e37d554 100644 --- a/pkgs/desktops/lxqt/pcmanfm-qt/default.nix +++ b/pkgs/desktops/lxqt/pcmanfm-qt/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, layer-shell-qt -, libexif -, libfm-qt -, lxqt-build-tools -, lxqt-menu-data -, menu-cache -, pkg-config -, qtbase -, qtimageformats -, qttools -, qtwayland -, qtsvg -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + layer-shell-qt, + libexif, + libfm-qt, + lxqt-build-tools, + lxqt-menu-data, + menu-cache, + pkg-config, + qtbase, + qtimageformats, + qttools, + qtwayland, + qtsvg, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/qlipper/default.nix b/pkgs/desktops/lxqt/qlipper/default.nix index 7ae58dadd84f35..e958658f3c9c57 100644 --- a/pkgs/desktops/lxqt/qlipper/default.nix +++ b/pkgs/desktops/lxqt/qlipper/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qtbase -, qttools -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtbase, + qttools, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/qps/default.nix b/pkgs/desktops/lxqt/qps/default.nix index c3cb608538a54b..ea9da54dfb64a5 100644 --- a/pkgs/desktops/lxqt/qps/default.nix +++ b/pkgs/desktops/lxqt/qps/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, kwindowsystem -, liblxqt -, libqtxdg -, lxqt-build-tools -, qtbase -, qtsvg -, qttools -, qtwayland -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + kwindowsystem, + liblxqt, + libqtxdg, + lxqt-build-tools, + qtbase, + qtsvg, + qttools, + qtwayland, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/qterminal/default.nix b/pkgs/desktops/lxqt/qterminal/default.nix index 1ca75acdc36ce7..823a3b09cc9e9c 100644 --- a/pkgs/desktops/lxqt/qterminal/default.nix +++ b/pkgs/desktops/lxqt/qterminal/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, layer-shell-qt -, lxqt-build-tools -, qtbase -, qtermwidget -, qttools -, qtwayland -, wrapQtAppsHook -, gitUpdater -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + layer-shell-qt, + lxqt-build-tools, + qtbase, + qtermwidget, + qttools, + qtwayland, + wrapQtAppsHook, + gitUpdater, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/qtermwidget/default.nix b/pkgs/desktops/lxqt/qtermwidget/default.nix index 90b1a561bdf280..ac06cab1d0539a 100644 --- a/pkgs/desktops/lxqt/qtermwidget/default.nix +++ b/pkgs/desktops/lxqt/qtermwidget/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, qtbase -, qttools -, lxqt-build-tools -, wrapQtAppsHook -, gitUpdater -, version ? "2.1.0" +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + qtbase, + qttools, + lxqt-build-tools, + wrapQtAppsHook, + gitUpdater, + version ? "2.1.0", }: stdenv.mkDerivation rec { @@ -18,10 +19,12 @@ stdenv.mkDerivation rec { owner = "lxqt"; repo = pname; rev = version; - hash = { - "1.4.0" = "sha256-wYUOqAiBjnupX1ITbFMw7sAk42V37yDz9SrjVhE4FgU="; - "2.1.0" = "sha256-I8fVggCi9qN+Jpqb/EC5/DfwuhGF55trbPESZQWPZ5M="; - }."${version}"; + hash = + { + "1.4.0" = "sha256-wYUOqAiBjnupX1ITbFMw7sAk42V37yDz9SrjVhE4FgU="; + "2.1.0" = "sha256-I8fVggCi9qN+Jpqb/EC5/DfwuhGF55trbPESZQWPZ5M="; + } + ."${version}"; }; nativeBuildInputs = [ diff --git a/pkgs/desktops/lxqt/qtxdg-tools/default.nix b/pkgs/desktops/lxqt/qtxdg-tools/default.nix index 4e1b5b4144d841..8971a3aa1fe000 100644 --- a/pkgs/desktops/lxqt/qtxdg-tools/default.nix +++ b/pkgs/desktops/lxqt/qtxdg-tools/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libqtxdg -, lxqt-build-tools -, qtbase -, qtsvg -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libqtxdg, + lxqt-build-tools, + qtbase, + qtsvg, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/screengrab/default.nix b/pkgs/desktops/lxqt/screengrab/default.nix index fa132756edcf0c..ac14483f1cea5a 100644 --- a/pkgs/desktops/lxqt/screengrab/default.nix +++ b/pkgs/desktops/lxqt/screengrab/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, autoPatchelfHook -, gitUpdater -, kwindowsystem -, libXdmcp -, libpthreadstubs -, libqtxdg -, perl -, pkg-config -, qtbase -, qtsvg -, qttools -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + autoPatchelfHook, + gitUpdater, + kwindowsystem, + libXdmcp, + libpthreadstubs, + libqtxdg, + perl, + pkg-config, + qtbase, + qtsvg, + qttools, + wrapQtAppsHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/lxqt/xdg-desktop-portal-lxqt/default.nix b/pkgs/desktops/lxqt/xdg-desktop-portal-lxqt/default.nix index 4e63d967ffbce6..1f31a200f7a7e5 100644 --- a/pkgs/desktops/lxqt/xdg-desktop-portal-lxqt/default.nix +++ b/pkgs/desktops/lxqt/xdg-desktop-portal-lxqt/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, kwindowsystem -, libexif -, libfm-qt -, lxqt-qtplugin -, menu-cache -, qtbase -, wrapQtAppsHook -, gitUpdater -, extraQtStyles ? [] +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + kwindowsystem, + libexif, + libfm-qt, + lxqt-qtplugin, + menu-cache, + qtbase, + wrapQtAppsHook, + gitUpdater, + extraQtStyles ? [ ], }: stdenv.mkDerivation rec { @@ -36,8 +37,7 @@ stdenv.mkDerivation rec { lxqt-qtplugin menu-cache qtbase - ] - ++ extraQtStyles; + ] ++ extraQtStyles; passthru.updateScript = gitUpdater { }; diff --git a/pkgs/desktops/mate/atril/default.nix b/pkgs/desktops/mate/atril/default.nix index c8f6f89b2c6be0..f457772b4d2dcf 100644 --- a/pkgs/desktops/mate/atril/default.nix +++ b/pkgs/desktops/mate/atril/default.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, caja -, gtk3 -, glib -, libxml2 -, libarchive -, libsecret -, poppler -, mate-desktop -, itstool -, hicolor-icon-theme -, texlive -, wrapGAppsHook3 -, enableEpub ? true -, webkitgtk_4_1 -, enableDjvu ? true -, djvulibre -, enablePostScript ? true -, libspectre -, enableXps ? true -, libgxps -, enableImages ? false -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + caja, + gtk3, + glib, + libxml2, + libarchive, + libsecret, + poppler, + mate-desktop, + itstool, + hicolor-icon-theme, + texlive, + wrapGAppsHook3, + enableEpub ? true, + webkitgtk_4_1, + enableDjvu ? true, + djvulibre, + enablePostScript ? true, + libspectre, + enableXps ? true, + libgxps, + enableImages ? false, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -42,26 +43,27 @@ stdenv.mkDerivation rec { wrapGAppsHook3 ]; - buildInputs = [ - caja - gtk3 - glib - itstool - libarchive - libsecret - libxml2 - poppler - mate-desktop - hicolor-icon-theme - texlive.bin.core # for synctex, used by the pdf back-end - ] - ++ lib.optionals enableDjvu [ djvulibre ] - ++ lib.optionals enableEpub [ webkitgtk_4_1 ] - ++ lib.optionals enablePostScript [ libspectre ] - ++ lib.optionals enableXps [ libgxps ] - ; + buildInputs = + [ + caja + gtk3 + glib + itstool + libarchive + libsecret + libxml2 + poppler + mate-desktop + hicolor-icon-theme + texlive.bin.core # for synctex, used by the pdf back-end + ] + ++ lib.optionals enableDjvu [ djvulibre ] + ++ lib.optionals enableEpub [ webkitgtk_4_1 ] + ++ lib.optionals enablePostScript [ libspectre ] + ++ lib.optionals enableXps [ libgxps ]; - configureFlags = [ ] + configureFlags = + [ ] ++ lib.optionals (enableDjvu) [ "--enable-djvu" ] ++ lib.optionals (enableEpub) [ "--enable-epub" ] ++ lib.optionals (enablePostScript) [ "--enable-ps" ] diff --git a/pkgs/desktops/mate/caja-dropbox/default.nix b/pkgs/desktops/mate/caja-dropbox/default.nix index 7841d0769a3696..00ee3189837636 100644 --- a/pkgs/desktops/mate/caja-dropbox/default.nix +++ b/pkgs/desktops/mate/caja-dropbox/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, substituteAll -, pkg-config -, gobject-introspection -, gdk-pixbuf -, caja -, gtk3 -, python3 -, dropbox -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + substituteAll, + pkg-config, + gobject-introspection, + gdk-pixbuf, + caja, + gtk3, + python3, + dropbox, + mateUpdateScript, }: let @@ -37,10 +38,12 @@ stdenv.mkDerivation rec { pkg-config gobject-introspection gdk-pixbuf - (python3.withPackages (ps: with ps; [ - docutils - pygobject3 - ])) + (python3.withPackages ( + ps: with ps; [ + docutils + pygobject3 + ] + )) ]; buildInputs = [ @@ -58,7 +61,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Dropbox extension for Caja file manager"; homepage = "https://github.com/mate-desktop/caja-dropbox"; - license = with licenses; [ gpl3Plus cc-by-nd-30 ]; + license = with licenses; [ + gpl3Plus + cc-by-nd-30 + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/caja-extensions/default.nix b/pkgs/desktops/mate/caja-extensions/default.nix index 205dae5e8592f8..f51e57229436ae 100644 --- a/pkgs/desktops/mate/caja-extensions/default.nix +++ b/pkgs/desktops/mate/caja-extensions/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, caja -, glib -, gst_all_1 -, gtk3 -, gupnp -, imagemagick -, mate-desktop -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + caja, + glib, + gst_all_1, + gtk3, + gupnp, + imagemagick, + mate-desktop, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/mate/caja/default.nix b/pkgs/desktops/mate/caja/default.nix index 59474ac8920f41..b39f302274a333 100644 --- a/pkgs/desktops/mate/caja/default.nix +++ b/pkgs/desktops/mate/caja/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, gtk-layer-shell -, gtk3 -, libnotify -, libxml2 -, libexif -, exempi -, mate-desktop -, hicolor-icon-theme -, wayland -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + gtk-layer-shell, + gtk3, + libnotify, + libxml2, + libexif, + exempi, + mate-desktop, + hicolor-icon-theme, + wayland, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -52,7 +53,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "File manager for the MATE desktop"; homepage = "https://mate-desktop.org"; - license = with licenses; [ gpl2Plus lgpl2Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/caja/with-extensions.nix b/pkgs/desktops/mate/caja/with-extensions.nix index a66840ca94a0cf..b3ccc7c00c3569 100644 --- a/pkgs/desktops/mate/caja/with-extensions.nix +++ b/pkgs/desktops/mate/caja/with-extensions.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, glib -, wrapGAppsHook3 -, xorg -, caja -, cajaExtensions -, extensions ? [ ] -, useDefaultExtensions ? true +{ + stdenv, + lib, + glib, + wrapGAppsHook3, + xorg, + caja, + cajaExtensions, + extensions ? [ ], + useDefaultExtensions ? true, }: let @@ -23,8 +24,11 @@ stdenv.mkDerivation { wrapGAppsHook3 ]; - buildInputs = lib.forEach selectedExtensions (x: x.buildInputs) ++ selectedExtensions - ++ [ caja ] ++ caja.buildInputs; + buildInputs = + lib.forEach selectedExtensions (x: x.buildInputs) + ++ selectedExtensions + ++ [ caja ] + ++ caja.buildInputs; dontUnpack = true; dontConfigure = true; @@ -53,9 +57,11 @@ stdenv.mkDerivation { preFixup = lib.optionalString (selectedExtensions != [ ]) '' gappsWrapperArgs+=( - --set CAJA_EXTENSION_DIRS ${lib.concatMapStringsSep ":" (x: "${x.outPath}/lib/caja/extensions-2.0") selectedExtensions} + --set CAJA_EXTENSION_DIRS ${ + lib.concatMapStringsSep ":" (x: "${x.outPath}/lib/caja/extensions-2.0") selectedExtensions + } ) ''; - inherit (caja.meta); + inherit (caja.meta) ; } diff --git a/pkgs/desktops/mate/default.nix b/pkgs/desktops/mate/default.nix index da8c8e065789a6..1ba36fe6051ddd 100644 --- a/pkgs/desktops/mate/default.nix +++ b/pkgs/desktops/mate/default.nix @@ -1,116 +1,124 @@ { pkgs, lib }: let - packages = self: with self; { + packages = + self: with self; { - # Update script tailored to mate packages from git repository - mateUpdateScript = { pname, odd-unstable ? true, rev-prefix ? "v", url ? null }: - pkgs.gitUpdater { - inherit odd-unstable rev-prefix; - url = if url == null then "https://git.mate-desktop.org/${pname}" else url; - }; + # Update script tailored to mate packages from git repository + mateUpdateScript = + { + pname, + odd-unstable ? true, + rev-prefix ? "v", + url ? null, + }: + pkgs.gitUpdater { + inherit odd-unstable rev-prefix; + url = if url == null then "https://git.mate-desktop.org/${pname}" else url; + }; - atril = callPackage ./atril { }; - caja = callPackage ./caja { }; - caja-dropbox = callPackage ./caja-dropbox { }; - caja-extensions = callPackage ./caja-extensions { }; - caja-with-extensions = callPackage ./caja/with-extensions.nix { }; - engrampa = callPackage ./engrampa { }; - eom = callPackage ./eom { }; - libmatekbd = callPackage ./libmatekbd { }; - libmatemixer = callPackage ./libmatemixer { }; - libmateweather = callPackage ./libmateweather { }; - marco = callPackage ./marco { }; - mate-applets = callPackage ./mate-applets { }; - mate-backgrounds = callPackage ./mate-backgrounds { }; - mate-calc = callPackage ./mate-calc { }; - mate-common = callPackage ./mate-common { }; - mate-control-center = callPackage ./mate-control-center { }; - mate-desktop = callPackage ./mate-desktop { }; - mate-gsettings-overrides = callPackage ./mate-gsettings-overrides { }; - mate-icon-theme = callPackage ./mate-icon-theme { }; - mate-icon-theme-faenza = callPackage ./mate-icon-theme-faenza { }; - mate-indicator-applet = callPackage ./mate-indicator-applet { }; - mate-media = callPackage ./mate-media { }; - mate-menus = callPackage ./mate-menus { }; - mate-netbook = callPackage ./mate-netbook { }; - mate-notification-daemon = callPackage ./mate-notification-daemon { }; - mate-panel = callPackage ./mate-panel { }; - mate-panel-with-applets = callPackage ./mate-panel/with-applets.nix { }; - mate-polkit = callPackage ./mate-polkit { }; - mate-power-manager = callPackage ./mate-power-manager { }; - mate-sensors-applet = callPackage ./mate-sensors-applet { }; - mate-session-manager = callPackage ./mate-session-manager { }; - mate-settings-daemon = callPackage ./mate-settings-daemon { }; - mate-settings-daemon-wrapped = callPackage ./mate-settings-daemon/wrapped.nix { }; - mate-screensaver = callPackage ./mate-screensaver { }; - mate-system-monitor = callPackage ./mate-system-monitor { }; - mate-terminal = callPackage ./mate-terminal { }; - mate-themes = callPackage ./mate-themes { }; - mate-tweak = callPackage ./mate-tweak { }; - mate-user-guide = callPackage ./mate-user-guide { }; - mate-user-share = callPackage ./mate-user-share { }; - mate-utils = callPackage ./mate-utils { }; - mate-wayland-session = callPackage ./mate-wayland-session { }; - mozo = callPackage ./mozo { }; - pluma = callPackage ./pluma { }; - python-caja = callPackage ./python-caja { }; + atril = callPackage ./atril { }; + caja = callPackage ./caja { }; + caja-dropbox = callPackage ./caja-dropbox { }; + caja-extensions = callPackage ./caja-extensions { }; + caja-with-extensions = callPackage ./caja/with-extensions.nix { }; + engrampa = callPackage ./engrampa { }; + eom = callPackage ./eom { }; + libmatekbd = callPackage ./libmatekbd { }; + libmatemixer = callPackage ./libmatemixer { }; + libmateweather = callPackage ./libmateweather { }; + marco = callPackage ./marco { }; + mate-applets = callPackage ./mate-applets { }; + mate-backgrounds = callPackage ./mate-backgrounds { }; + mate-calc = callPackage ./mate-calc { }; + mate-common = callPackage ./mate-common { }; + mate-control-center = callPackage ./mate-control-center { }; + mate-desktop = callPackage ./mate-desktop { }; + mate-gsettings-overrides = callPackage ./mate-gsettings-overrides { }; + mate-icon-theme = callPackage ./mate-icon-theme { }; + mate-icon-theme-faenza = callPackage ./mate-icon-theme-faenza { }; + mate-indicator-applet = callPackage ./mate-indicator-applet { }; + mate-media = callPackage ./mate-media { }; + mate-menus = callPackage ./mate-menus { }; + mate-netbook = callPackage ./mate-netbook { }; + mate-notification-daemon = callPackage ./mate-notification-daemon { }; + mate-panel = callPackage ./mate-panel { }; + mate-panel-with-applets = callPackage ./mate-panel/with-applets.nix { }; + mate-polkit = callPackage ./mate-polkit { }; + mate-power-manager = callPackage ./mate-power-manager { }; + mate-sensors-applet = callPackage ./mate-sensors-applet { }; + mate-session-manager = callPackage ./mate-session-manager { }; + mate-settings-daemon = callPackage ./mate-settings-daemon { }; + mate-settings-daemon-wrapped = callPackage ./mate-settings-daemon/wrapped.nix { }; + mate-screensaver = callPackage ./mate-screensaver { }; + mate-system-monitor = callPackage ./mate-system-monitor { }; + mate-terminal = callPackage ./mate-terminal { }; + mate-themes = callPackage ./mate-themes { }; + mate-tweak = callPackage ./mate-tweak { }; + mate-user-guide = callPackage ./mate-user-guide { }; + mate-user-share = callPackage ./mate-user-share { }; + mate-utils = callPackage ./mate-utils { }; + mate-wayland-session = callPackage ./mate-wayland-session { }; + mozo = callPackage ./mozo { }; + pluma = callPackage ./pluma { }; + python-caja = callPackage ./python-caja { }; - # Caja and mate-panel are managed in NixOS module. - basePackages = [ - libmatekbd - libmatemixer - libmateweather - marco - mate-common - mate-control-center - mate-desktop - mate-icon-theme - mate-menus - mate-notification-daemon - mate-polkit - mate-session-manager - mate-settings-daemon - mate-settings-daemon-wrapped - mate-themes - ]; + # Caja and mate-panel are managed in NixOS module. + basePackages = [ + libmatekbd + libmatemixer + libmateweather + marco + mate-common + mate-control-center + mate-desktop + mate-icon-theme + mate-menus + mate-notification-daemon + mate-polkit + mate-session-manager + mate-settings-daemon + mate-settings-daemon-wrapped + mate-themes + ]; - extraPackages = [ - atril - caja-extensions # for caja-sendto - engrampa - eom - mate-applets - mate-backgrounds - mate-calc - mate-indicator-applet - mate-media - mate-netbook - mate-power-manager - mate-screensaver - mate-system-monitor - mate-terminal - mate-user-guide - # mate-user-share - mate-utils - mozo - pluma - ]; + extraPackages = [ + atril + caja-extensions # for caja-sendto + engrampa + eom + mate-applets + mate-backgrounds + mate-calc + mate-indicator-applet + mate-media + mate-netbook + mate-power-manager + mate-screensaver + mate-system-monitor + mate-terminal + mate-user-guide + # mate-user-share + mate-utils + mozo + pluma + ]; - cajaExtensions = [ - caja-extensions - ]; + cajaExtensions = [ + caja-extensions + ]; - panelApplets = [ - mate-applets - mate-indicator-applet - mate-netbook - mate-notification-daemon - mate-media - mate-power-manager - mate-sensors-applet - mate-utils - ]; - }; + panelApplets = [ + mate-applets + mate-indicator-applet + mate-netbook + mate-notification-daemon + mate-media + mate-power-manager + mate-sensors-applet + mate-utils + ]; + }; -in lib.makeScope pkgs.newScope packages +in +lib.makeScope pkgs.newScope packages diff --git a/pkgs/desktops/mate/engrampa/default.nix b/pkgs/desktops/mate/engrampa/default.nix index dd4bfe0ef968d6..2b7f8a266dd700 100644 --- a/pkgs/desktops/mate/engrampa/default.nix +++ b/pkgs/desktops/mate/engrampa/default.nix @@ -1,19 +1,21 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, itstool -, libxml2 -, caja -, gtk3 -, hicolor-icon-theme -, json-glib -, mate-desktop -, wrapGAppsHook3 -, mateUpdateScript -# can be defaulted to true once switch to meson -, withMagic ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, file +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + itstool, + libxml2, + caja, + gtk3, + hicolor-icon-theme, + json-glib, + mate-desktop, + wrapGAppsHook3, + mateUpdateScript, + # can be defaulted to true once switch to meson + withMagic ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, + file, }: stdenv.mkDerivation rec { @@ -29,25 +31,29 @@ stdenv.mkDerivation rec { pkg-config gettext itstool - libxml2 # for xmllint + libxml2 # for xmllint wrapGAppsHook3 ]; - buildInputs = [ - caja - gtk3 - hicolor-icon-theme - json-glib - mate-desktop - ] ++ lib.optionals withMagic [ - file - ]; + buildInputs = + [ + caja + gtk3 + hicolor-icon-theme + json-glib + mate-desktop + ] + ++ lib.optionals withMagic [ + file + ]; - configureFlags = [ - "--with-cajadir=$$out/lib/caja/extensions-2.0" - ] ++ lib.optionals withMagic [ - "--enable-magic" - ]; + configureFlags = + [ + "--with-cajadir=$$out/lib/caja/extensions-2.0" + ] + ++ lib.optionals withMagic [ + "--enable-magic" + ]; enableParallelBuilding = true; @@ -57,7 +63,11 @@ stdenv.mkDerivation rec { description = "Archive Manager for MATE"; mainProgram = "engrampa"; homepage = "https://mate-desktop.org"; - license = with licenses; [ gpl2Plus lgpl2Plus fdl11Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + fdl11Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/eom/default.nix b/pkgs/desktops/mate/eom/default.nix index 197a6aee9e0216..01566f483a6b9a 100644 --- a/pkgs/desktops/mate/eom/default.nix +++ b/pkgs/desktops/mate/eom/default.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, itstool -, exempi -, lcms2 -, libexif -, libjpeg -, librsvg -, libxml2 -, libpeas -, shared-mime-info -, gtk3 -, mate-desktop -, hicolor-icon-theme -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + itstool, + exempi, + lcms2, + libexif, + libjpeg, + librsvg, + libxml2, + libpeas, + shared-mime-info, + gtk3, + mate-desktop, + hicolor-icon-theme, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/mate/libmatemixer/default.nix b/pkgs/desktops/mate/libmatemixer/default.nix index 25b99584429f6b..c5d1f280eaf94f 100644 --- a/pkgs/desktops/mate/libmatemixer/default.nix +++ b/pkgs/desktops/mate/libmatemixer/default.nix @@ -1,17 +1,18 @@ -{ config -, lib -, stdenv -, fetchurl -, pkg-config -, gettext -, glib -, alsaSupport ? stdenv.hostPlatform.isLinux -, alsa-lib -, udev -, pulseaudioSupport ? config.pulseaudio or true -, libpulseaudio -, ossSupport ? false -, mateUpdateScript +{ + config, + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + glib, + alsaSupport ? stdenv.hostPlatform.isLinux, + alsa-lib, + udev, + pulseaudioSupport ? config.pulseaudio or true, + libpulseaudio, + ossSupport ? false, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -28,14 +29,17 @@ stdenv.mkDerivation rec { gettext ]; - buildInputs = [ - glib - ] ++ lib.optionals alsaSupport [ - alsa-lib - udev - ] ++ lib.optionals pulseaudioSupport [ - libpulseaudio - ]; + buildInputs = + [ + glib + ] + ++ lib.optionals alsaSupport [ + alsa-lib + udev + ] + ++ lib.optionals pulseaudioSupport [ + libpulseaudio + ]; configureFlags = lib.optional ossSupport "--enable-oss"; diff --git a/pkgs/desktops/mate/libmateweather/default.nix b/pkgs/desktops/mate/libmateweather/default.nix index 68cf463f759460..d65549ba123a88 100644 --- a/pkgs/desktops/mate/libmateweather/default.nix +++ b/pkgs/desktops/mate/libmateweather/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, glib -, glib-networking -, libxml2 -, gtk3 -, libsoup_2_4 -, tzdata -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + glib, + glib-networking, + libxml2, + gtk3, + libsoup_2_4, + tzdata, + mateUpdateScript, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/mate/marco/default.nix b/pkgs/desktops/mate/marco/default.nix index 4baa57b6c8c106..6e4a65ee02c911 100644 --- a/pkgs/desktops/mate/marco/default.nix +++ b/pkgs/desktops/mate/marco/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, itstool -, libxml2 -, libcanberra-gtk3 -, libgtop -, libXdamage -, libXpresent -, libXres -, libstartup_notification -, zenity -, glib -, gtk3 -, mate-desktop -, mate-settings-daemon -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + itstool, + libxml2, + libcanberra-gtk3, + libgtop, + libXdamage, + libXpresent, + libXres, + libstartup_notification, + zenity, + glib, + gtk3, + mate-desktop, + mate-settings-daemon, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/mate/mate-applets/default.nix b/pkgs/desktops/mate/mate-applets/default.nix index b598e453a95a6d..4b58224535f46b 100644 --- a/pkgs/desktops/mate/mate-applets/default.nix +++ b/pkgs/desktops/mate/mate-applets/default.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, itstool -, dbus-glib -, glib -, gtk3 -, gucharmap -, libmateweather -, libnl -, libwnck -, libgtop -, libxml2 -, libnotify -, mate-desktop -, mate-panel -, polkit -, upower -, wirelesstools -, hicolor-icon-theme -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + itstool, + dbus-glib, + glib, + gtk3, + gucharmap, + libmateweather, + libnl, + libwnck, + libgtop, + libxml2, + libnotify, + mate-desktop, + mate-panel, + polkit, + upower, + wirelesstools, + hicolor-icon-theme, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -58,7 +59,10 @@ stdenv.mkDerivation rec { wirelesstools ]; - configureFlags = [ "--enable-suid=no" "--enable-in-process" ]; + configureFlags = [ + "--enable-suid=no" + "--enable-in-process" + ]; env.NIX_CFLAGS_COMPILE = "-I${glib.dev}/include/gio-unix-2.0"; @@ -70,7 +74,10 @@ stdenv.mkDerivation rec { description = "Applets for use with the MATE panel"; mainProgram = "mate-cpufreq-selector"; homepage = "https://mate-desktop.org"; - license = with licenses; [ gpl2Plus lgpl2Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + ]; platforms = platforms.linux; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-backgrounds/default.nix b/pkgs/desktops/mate/mate-backgrounds/default.nix index 0d512260d30390..191c74b32325f2 100644 --- a/pkgs/desktops/mate/mate-backgrounds/default.nix +++ b/pkgs/desktops/mate/mate-backgrounds/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenvNoCC -, fetchurl -, meson -, ninja -, gettext -, mateUpdateScript +{ + lib, + stdenvNoCC, + fetchurl, + meson, + ninja, + gettext, + mateUpdateScript, }: stdenvNoCC.mkDerivation rec { @@ -27,7 +28,10 @@ stdenvNoCC.mkDerivation rec { meta = with lib; { description = "Background images and data for MATE"; homepage = "https://mate-desktop.org"; - license = with licenses; [ gpl2Plus cc-by-sa-40 ]; + license = with licenses; [ + gpl2Plus + cc-by-sa-40 + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-common/default.nix b/pkgs/desktops/mate/mate-common/default.nix index fac27474e32a3e..ece5fbc9b47a00 100644 --- a/pkgs/desktops/mate/mate-common/default.nix +++ b/pkgs/desktops/mate/mate-common/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenvNoCC -, fetchurl -, mateUpdateScript +{ + lib, + stdenvNoCC, + fetchurl, + mateUpdateScript, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/desktops/mate/mate-control-center/default.nix b/pkgs/desktops/mate/mate-control-center/default.nix index 3a052549a7d1da..6d123dc7c4d28b 100644 --- a/pkgs/desktops/mate/mate-control-center/default.nix +++ b/pkgs/desktops/mate/mate-control-center/default.nix @@ -1,34 +1,35 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, itstool -, libxml2 -, accountsservice -, caja -, dbus-glib -, libxklavier -, libcanberra-gtk3 -, libgtop -, libmatekbd -, librsvg -, libayatana-appindicator -, glib -, desktop-file-utils -, dconf -, gtk3 -, polkit -, marco -, mate-desktop -, mate-menus -, mate-panel -, mate-settings-daemon -, udisks2 -, systemd -, hicolor-icon-theme -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + itstool, + libxml2, + accountsservice, + caja, + dbus-glib, + libxklavier, + libcanberra-gtk3, + libgtop, + libmatekbd, + librsvg, + libayatana-appindicator, + glib, + desktop-file-utils, + dconf, + gtk3, + polkit, + marco, + mate-desktop, + mate-menus, + mate-panel, + mate-settings-daemon, + udisks2, + systemd, + hicolor-icon-theme, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/mate/mate-desktop/default.nix b/pkgs/desktops/mate/mate-desktop/default.nix index a60e56cae8461f..83dc816bb9b040 100644 --- a/pkgs/desktops/mate/mate-desktop/default.nix +++ b/pkgs/desktops/mate/mate-desktop/default.nix @@ -1,21 +1,25 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, isocodes -, libstartup_notification -, gtk3 -, dconf -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + isocodes, + libstartup_notification, + gtk3, + dconf, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { pname = "mate-desktop"; version = "1.28.2"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "https://pub.mate-desktop.org/releases/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/desktops/mate/mate-gsettings-overrides/default.nix b/pkgs/desktops/mate/mate-gsettings-overrides/default.nix index e9e2c3c3b0b9b2..1945bf53103dac 100644 --- a/pkgs/desktops/mate/mate-gsettings-overrides/default.nix +++ b/pkgs/desktops/mate/mate-gsettings-overrides/default.nix @@ -1,8 +1,9 @@ -{ lib -, runCommand -, gsettings-desktop-schemas -, mate-wayland-session -, glib +{ + lib, + runCommand, + gsettings-desktop-schemas, + mate-wayland-session, + glib, }: let @@ -16,7 +17,10 @@ runCommand "mate-gsettings-overrides" { preferLocalBuild = true; } '' schema_dir="$data_dir/glib-2.0/schemas" mkdir -p "$schema_dir" - ${lib.concatMapStringsSep "\n" (pkg: "cp -rf \"${glib.getSchemaPath pkg}\"/*.xml \"${glib.getSchemaPath pkg}\"/*.gschema.override \"$schema_dir\"") gsettingsOverridePackages} + ${lib.concatMapStringsSep "\n" ( + pkg: + "cp -rf \"${glib.getSchemaPath pkg}\"/*.xml \"${glib.getSchemaPath pkg}\"/*.gschema.override \"$schema_dir\"" + ) gsettingsOverridePackages} chmod -R a+w "$data_dir" diff --git a/pkgs/desktops/mate/mate-icon-theme-faenza/default.nix b/pkgs/desktops/mate/mate-icon-theme-faenza/default.nix index d6d96a33ac1419..9ebf5f62e33a93 100644 --- a/pkgs/desktops/mate/mate-icon-theme-faenza/default.nix +++ b/pkgs/desktops/mate/mate-icon-theme-faenza/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, gtk3 -, mate -, hicolor-icon-theme -, gitUpdater +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + gtk3, + mate, + hicolor-icon-theme, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/mate/mate-icon-theme/default.nix b/pkgs/desktops/mate/mate-icon-theme/default.nix index b951d929bb06c0..51f1b1f0587bdc 100644 --- a/pkgs/desktops/mate/mate-icon-theme/default.nix +++ b/pkgs/desktops/mate/mate-icon-theme/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, iconnamingutils -, librsvg -, gtk3 -, hicolor-icon-theme -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + iconnamingutils, + librsvg, + gtk3, + hicolor-icon-theme, + mateUpdateScript, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/mate/mate-indicator-applet/default.nix b/pkgs/desktops/mate/mate-indicator-applet/default.nix index ecbe0e8bfc4d7a..0dd67f799fa7a3 100644 --- a/pkgs/desktops/mate/mate-indicator-applet/default.nix +++ b/pkgs/desktops/mate/mate-indicator-applet/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, gtk3 -, libayatana-indicator -, mate-panel -, hicolor-icon-theme -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + gtk3, + libayatana-indicator, + mate-panel, + hicolor-icon-theme, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -59,7 +60,10 @@ stdenv.mkDerivation rec { Existing indicators include the Message Menu, Battery Menu and Sound menu. ''; - license = with licenses; [ gpl3Plus lgpl2Plus ]; + license = with licenses; [ + gpl3Plus + lgpl2Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-media/default.nix b/pkgs/desktops/mate/mate-media/default.nix index 51dcc29f8990a8..e541aee18f2dd7 100644 --- a/pkgs/desktops/mate/mate-media/default.nix +++ b/pkgs/desktops/mate/mate-media/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, libtool -, gtk-layer-shell -, gtk3 -, libcanberra-gtk3 -, libmatemixer -, libxml2 -, mate-desktop -, mate-panel -, wayland -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + libtool, + gtk-layer-shell, + gtk3, + libcanberra-gtk3, + libmatemixer, + libxml2, + mate-desktop, + mate-panel, + wayland, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/mate/mate-menus/default.nix b/pkgs/desktops/mate/mate-menus/default.nix index 31854538fb5eea..10377df569a3ea 100644 --- a/pkgs/desktops/mate/mate-menus/default.nix +++ b/pkgs/desktops/mate/mate-menus/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, glib -, gobject-introspection -, python3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + glib, + gobject-introspection, + python3, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -42,7 +43,10 @@ stdenv.mkDerivation rec { broken = stdenv.hostPlatform.isDarwin; description = "Menu system for MATE"; homepage = "https://github.com/mate-desktop/mate-menus"; - license = with licenses; [ gpl2Plus lgpl2Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-netbook/default.nix b/pkgs/desktops/mate/mate-netbook/default.nix index 0b1c5a74792360..5bda4e307c9271 100644 --- a/pkgs/desktops/mate/mate-netbook/default.nix +++ b/pkgs/desktops/mate/mate-netbook/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, gtk3 -, libwnck -, libfakekey -, libXtst -, mate -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + gtk3, + libwnck, + libfakekey, + libXtst, + mate, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -50,7 +51,10 @@ stdenv.mkDerivation rec { devices with low resolution displays. ''; homepage = "https://mate-desktop.org"; - license = with licenses; [ gpl3Only lgpl2Plus ]; + license = with licenses; [ + gpl3Only + lgpl2Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-notification-daemon/default.nix b/pkgs/desktops/mate/mate-notification-daemon/default.nix index ed3773873a1149..2f1b83ad5c3ee1 100644 --- a/pkgs/desktops/mate/mate-notification-daemon/default.nix +++ b/pkgs/desktops/mate/mate-notification-daemon/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, glib -, libcanberra-gtk3 -, libnotify -, libwnck -, gtk-layer-shell -, gtk3 -, libxml2 -, mate-desktop -, mate-panel -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + glib, + libcanberra-gtk3, + libnotify, + libwnck, + gtk-layer-shell, + gtk3, + libxml2, + mate-desktop, + mate-panel, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -54,7 +55,10 @@ stdenv.mkDerivation rec { description = "Notification daemon for MATE Desktop"; mainProgram = "mate-notification-properties"; homepage = "https://github.com/mate-desktop/mate-notification-daemon"; - license = with licenses; [ gpl2Plus gpl3Plus ]; + license = with licenses; [ + gpl2Plus + gpl3Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-panel/default.nix b/pkgs/desktops/mate/mate-panel/default.nix index 305c9e50ca78dd..f351965af1d160 100644 --- a/pkgs/desktops/mate/mate-panel/default.nix +++ b/pkgs/desktops/mate/mate-panel/default.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, itstool -, glib -, gtk-layer-shell -, gtk3 -, libmateweather -, libwnck -, librsvg -, libxml2 -, dconf -, dconf-editor -, mate-desktop -, mate-menus -, hicolor-icon-theme -, wayland -, gobject-introspection -, wrapGAppsHook3 -, marco -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + itstool, + glib, + gtk-layer-shell, + gtk3, + libmateweather, + libwnck, + librsvg, + libxml2, + dconf, + dconf-editor, + mate-desktop, + mate-menus, + hicolor-icon-theme, + wayland, + gobject-introspection, + wrapGAppsHook3, + marco, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -85,7 +86,11 @@ stdenv.mkDerivation rec { meta = with lib; { description = "MATE panel"; homepage = "https://github.com/mate-desktop/mate-panel"; - license = with licenses; [ gpl2Plus lgpl2Plus fdl11Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + fdl11Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-panel/with-applets.nix b/pkgs/desktops/mate/mate-panel/with-applets.nix index dd6f8a6c58b817..422f60e5d84cec 100644 --- a/pkgs/desktops/mate/mate-panel/with-applets.nix +++ b/pkgs/desktops/mate/mate-panel/with-applets.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, glib -, wrapGAppsHook3 -, xorg -, marco -, mate-panel -, panelApplets -, applets ? [ ] -, useDefaultApplets ? true +{ + stdenv, + lib, + glib, + wrapGAppsHook3, + xorg, + marco, + mate-panel, + panelApplets, + applets ? [ ], + useDefaultApplets ? true, }: let @@ -27,8 +28,12 @@ stdenv.mkDerivation { wrapGAppsHook3 ]; - buildInputs = lib.forEach selectedApplets (x: x.buildInputs) ++ selectedApplets - ++ [ mate-panel ] ++ mate-panel.buildInputs ++ mate-panel.propagatedBuildInputs; + buildInputs = + lib.forEach selectedApplets (x: x.buildInputs) + ++ selectedApplets + ++ [ mate-panel ] + ++ mate-panel.buildInputs + ++ mate-panel.propagatedBuildInputs; dontUnpack = true; dontConfigure = true; @@ -57,5 +62,5 @@ stdenv.mkDerivation { ) ''; - inherit (mate-panel.meta); + inherit (mate-panel.meta) ; } diff --git a/pkgs/desktops/mate/mate-polkit/default.nix b/pkgs/desktops/mate/mate-polkit/default.nix index 827a641d39671d..2322e81d513e7b 100644 --- a/pkgs/desktops/mate/mate-polkit/default.nix +++ b/pkgs/desktops/mate/mate-polkit/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, gtk3 -, gobject-introspection -, libayatana-appindicator -, polkit -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + gtk3, + gobject-introspection, + libayatana-appindicator, + polkit, + mateUpdateScript, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/mate/mate-power-manager/default.nix b/pkgs/desktops/mate/mate-power-manager/default.nix index e4f59428f400c5..4ab93fe630247a 100644 --- a/pkgs/desktops/mate/mate-power-manager/default.nix +++ b/pkgs/desktops/mate/mate-power-manager/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, glib -, itstool -, libxml2 -, mate-desktop -, mate-panel -, libnotify -, libcanberra-gtk3 -, libsecret -, dbus-glib -, upower -, gtk3 -, libtool -, polkit -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + glib, + itstool, + libxml2, + mate-desktop, + mate-panel, + libnotify, + libcanberra-gtk3, + libsecret, + dbus-glib, + upower, + gtk3, + libtool, + polkit, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -60,7 +61,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "MATE Power Manager"; homepage = "https://mate-desktop.org"; - license = with licenses; [ gpl2Plus fdl11Plus ]; + license = with licenses; [ + gpl2Plus + fdl11Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members ++ (with maintainers; [ chpatrick ]); }; diff --git a/pkgs/desktops/mate/mate-screensaver/default.nix b/pkgs/desktops/mate/mate-screensaver/default.nix index 930b6d8d814eac..0f1682198a1ee5 100644 --- a/pkgs/desktops/mate/mate-screensaver/default.nix +++ b/pkgs/desktops/mate/mate-screensaver/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, gtk3 -, dbus-glib -, libXScrnSaver -, libnotify -, libxml2 -, mate-desktop -, mate-menus -, mate-panel -, pam -, systemd -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + gtk3, + dbus-glib, + libXScrnSaver, + libnotify, + libxml2, + mate-desktop, + mate-menus, + mate-panel, + pam, + systemd, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -56,7 +57,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Screen saver and locker for the MATE desktop"; homepage = "https://mate-desktop.org"; - license = with licenses; [ gpl2Plus lgpl2Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-sensors-applet/default.nix b/pkgs/desktops/mate/mate-sensors-applet/default.nix index 88fc966edb5600..e6de3cd6f00635 100644 --- a/pkgs/desktops/mate/mate-sensors-applet/default.nix +++ b/pkgs/desktops/mate/mate-sensors-applet/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, itstool -, gtk3 -, libxml2 -, libxslt -, libatasmart -, libnotify -, lm_sensors -, mate-panel -, hicolor-icon-theme -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + itstool, + gtk3, + libxml2, + libxslt, + libatasmart, + libnotify, + lm_sensors, + mate-panel, + hicolor-icon-theme, + mateUpdateScript, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/mate/mate-session-manager/default.nix b/pkgs/desktops/mate/mate-session-manager/default.nix index 1ae3a0690e3387..e71cc1b76ea46f 100644 --- a/pkgs/desktops/mate/mate-session-manager/default.nix +++ b/pkgs/desktops/mate/mate-session-manager/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, xtrans -, dbus-glib -, systemd -, libSM -, libXtst -, glib -, gtk3 -, libepoxy -, polkit -, hicolor-icon-theme -, mate-desktop -, mate-screensaver -, wrapGAppsHook3 -, fetchpatch -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + xtrans, + dbus-glib, + systemd, + libSM, + libXtst, + glib, + gtk3, + libepoxy, + polkit, + hicolor-icon-theme, + mate-desktop, + mate-screensaver, + wrapGAppsHook3, + fetchpatch, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -73,7 +74,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "MATE Desktop session manager"; homepage = "https://github.com/mate-desktop/mate-session-manager"; - license = with licenses; [ gpl2Plus lgpl2Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-settings-daemon/default.nix b/pkgs/desktops/mate/mate-settings-daemon/default.nix index 425d23c660f2dd..64bb4b0fc07d6c 100644 --- a/pkgs/desktops/mate/mate-settings-daemon/default.nix +++ b/pkgs/desktops/mate/mate-settings-daemon/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, glib -, libxklavier -, libcanberra-gtk3 -, libnotify -, libmatekbd -, libmatemixer -, nss -, polkit -, dconf -, gtk3 -, mate-desktop -, pulseaudioSupport ? stdenv.config.pulseaudio or true -, libpulseaudio -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + glib, + libxklavier, + libcanberra-gtk3, + libnotify, + libmatekbd, + libmatemixer, + nss, + polkit, + dconf, + gtk3, + mate-desktop, + pulseaudioSupport ? stdenv.config.pulseaudio or true, + libpulseaudio, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -59,7 +60,12 @@ stdenv.mkDerivation rec { meta = with lib; { description = "MATE settings daemon"; homepage = "https://github.com/mate-desktop/mate-settings-daemon"; - license = with licenses; [ gpl2Plus gpl3Plus lgpl2Plus mit ]; + license = with licenses; [ + gpl2Plus + gpl3Plus + lgpl2Plus + mit + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-settings-daemon/wrapped.nix b/pkgs/desktops/mate/mate-settings-daemon/wrapped.nix index 6031b7f7341f67..b8ad5e984845ea 100644 --- a/pkgs/desktops/mate/mate-settings-daemon/wrapped.nix +++ b/pkgs/desktops/mate/mate-settings-daemon/wrapped.nix @@ -1,7 +1,8 @@ -{ stdenv -, mate -, glib -, wrapGAppsHook3 +{ + stdenv, + mate, + glib, + wrapGAppsHook3, }: stdenv.mkDerivation { @@ -34,5 +35,7 @@ stdenv.mkDerivation { --replace "${mate.mate-settings-daemon}/libexec/mate-settings-daemon" "$out/libexec/mate-settings-daemon" ''; - meta = mate.mate-settings-daemon.meta // { priority = -10; }; + meta = mate.mate-settings-daemon.meta // { + priority = -10; + }; } diff --git a/pkgs/desktops/mate/mate-themes/default.nix b/pkgs/desktops/mate/mate-themes/default.nix index 3ca512dfb53c84..ed203cc7d3e67c 100644 --- a/pkgs/desktops/mate/mate-themes/default.nix +++ b/pkgs/desktops/mate/mate-themes/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, mate-icon-theme -, gtk2 -, gtk3 -, gtk_engines -, gtk-engine-murrine -, gdk-pixbuf -, librsvg -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + mate-icon-theme, + gtk2, + gtk3, + gtk_engines, + gtk-engine-murrine, + gdk-pixbuf, + librsvg, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -53,7 +54,11 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Set of themes from MATE"; homepage = "https://mate-desktop.org"; - license = with licenses; [ lgpl21Plus lgpl3Only gpl3Plus ]; + license = with licenses; [ + lgpl21Plus + lgpl3Only + gpl3Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-tweak/default.nix b/pkgs/desktops/mate/mate-tweak/default.nix index 057f30f5f86860..a3b32f0ede7735 100644 --- a/pkgs/desktops/mate/mate-tweak/default.nix +++ b/pkgs/desktops/mate/mate-tweak/default.nix @@ -1,15 +1,16 @@ -{ lib -, fetchFromGitHub -, python3Packages -, intltool -, mate -, libnotify -, gtk3 -, gdk-pixbuf -, gobject-introspection -, wrapGAppsHook3 -, glib -, gitUpdater +{ + lib, + fetchFromGitHub, + python3Packages, + intltool, + mate, + libnotify, + gtk3, + gdk-pixbuf, + gobject-introspection, + wrapGAppsHook3, + glib, + gitUpdater, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/desktops/mate/mate-user-guide/default.nix b/pkgs/desktops/mate/mate-user-guide/default.nix index 7dc2e9ad4221ba..3a8377e5e05879 100644 --- a/pkgs/desktops/mate/mate-user-guide/default.nix +++ b/pkgs/desktops/mate/mate-user-guide/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, gettext -, itstool -, libxml2 -, yelp -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + gettext, + itstool, + libxml2, + yelp, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -39,7 +40,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "MATE User Guide"; homepage = "https://mate-desktop.org"; - license = with licenses; [ gpl2Plus fdl11Plus ]; + license = with licenses; [ + gpl2Plus + fdl11Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-user-share/default.nix b/pkgs/desktops/mate/mate-user-share/default.nix index 3ecfc8a34e9039..c6b3544b9074dd 100644 --- a/pkgs/desktops/mate/mate-user-share/default.nix +++ b/pkgs/desktops/mate/mate-user-share/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, itstool -, gtk3 -, caja -, dbus-glib -, libnotify -, libxml2 -, libcanberra-gtk3 -, apacheHttpdPackages -, hicolor-icon-theme -, mate -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + itstool, + gtk3, + caja, + dbus-glib, + libnotify, + libxml2, + libcanberra-gtk3, + apacheHttpdPackages, + hicolor-icon-theme, + mate, + wrapGAppsHook3, + mateUpdateScript, }: let diff --git a/pkgs/desktops/mate/mate-utils/default.nix b/pkgs/desktops/mate/mate-utils/default.nix index 7763e2960eda6d..e40f2760d83755 100644 --- a/pkgs/desktops/mate/mate-utils/default.nix +++ b/pkgs/desktops/mate/mate-utils/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, itstool -, glib -, gtk-layer-shell -, gtk3 -, libxml2 -, libgtop -, libcanberra-gtk3 -, inkscape -, udisks2 -, mate-desktop -, mate-panel -, hicolor-icon-theme -, wayland -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + itstool, + glib, + gtk-layer-shell, + gtk3, + libxml2, + libgtop, + libcanberra-gtk3, + inkscape, + udisks2, + mate-desktop, + mate-panel, + hicolor-icon-theme, + wayland, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -69,7 +70,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Utilities for the MATE desktop"; homepage = "https://mate-desktop.org"; - license = with licenses; [ gpl2Plus lgpl2Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/mate-wayland-session/default.nix b/pkgs/desktops/mate/mate-wayland-session/default.nix index b803caa7048f52..1900c0b7107e4b 100644 --- a/pkgs/desktops/mate/mate-wayland-session/default.nix +++ b/pkgs/desktops/mate/mate-wayland-session/default.nix @@ -1,14 +1,15 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, meson -, ninja -, glib -, mate-polkit -, mate-notification-daemon -, wayfire -, wayfirePlugins -, gitUpdater +{ + stdenvNoCC, + lib, + fetchFromGitHub, + meson, + ninja, + glib, + mate-polkit, + mate-notification-daemon, + wayfire, + wayfirePlugins, + gitUpdater, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/desktops/mate/mozo/default.nix b/pkgs/desktops/mate/mozo/default.nix index c402cf039300fa..5e2f3502a59d16 100644 --- a/pkgs/desktops/mate/mozo/default.nix +++ b/pkgs/desktops/mate/mozo/default.nix @@ -1,14 +1,15 @@ -{ lib -, python3 -, fetchurl -, pkg-config -, gettext -, mate-menus -, gtk3 -, glib -, wrapGAppsHook3 -, gobject-introspection -, mateUpdateScript +{ + lib, + python3, + fetchurl, + pkg-config, + gettext, + mate-menus, + gtk3, + glib, + wrapGAppsHook3, + gobject-introspection, + mateUpdateScript, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/desktops/mate/pluma/default.nix b/pkgs/desktops/mate/pluma/default.nix index 87eca7161f760e..033b6bf4763b39 100644 --- a/pkgs/desktops/mate/pluma/default.nix +++ b/pkgs/desktops/mate/pluma/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, perl -, itstool -, isocodes -, enchant -, libxml2 -, python3 -, gtksourceview4 -, libpeas -, mate-desktop -, wrapGAppsHook3 -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + perl, + itstool, + isocodes, + enchant, + libxml2, + python3, + gtksourceview4, + libpeas, + mate-desktop, + wrapGAppsHook3, + mateUpdateScript, }: stdenv.mkDerivation rec { @@ -62,7 +63,11 @@ stdenv.mkDerivation rec { description = "Powerful text editor for the MATE desktop"; mainProgram = "pluma"; homepage = "https://mate-desktop.org"; - license = with licenses; [ gpl2Plus lgpl2Plus fdl11Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + fdl11Plus + ]; platforms = platforms.unix; maintainers = teams.mate.members; }; diff --git a/pkgs/desktops/mate/python-caja/default.nix b/pkgs/desktops/mate/python-caja/default.nix index 7f668cdde9966b..ada4bc1b5e353a 100644 --- a/pkgs/desktops/mate/python-caja/default.nix +++ b/pkgs/desktops/mate/python-caja/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, caja -, gtk3 -, python3Packages -, mateUpdateScript +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + caja, + gtk3, + python3Packages, + mateUpdateScript, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/elementary-calculator/default.nix b/pkgs/desktops/pantheon/apps/elementary-calculator/default.nix index 12857b8946a7a7..af8c515326b789 100644 --- a/pkgs/desktops/pantheon/apps/elementary-calculator/default.nix +++ b/pkgs/desktops/pantheon/apps/elementary-calculator/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, wrapGAppsHook4 -, elementary-gtk-theme -, elementary-icon-theme -, granite7 -, gtk4 -, libgee +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + wrapGAppsHook4, + elementary-gtk-theme, + elementary-icon-theme, + granite7, + gtk4, + libgee, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/elementary-calendar/default.nix b/pkgs/desktops/pantheon/apps/elementary-calendar/default.nix index 43a49528df08b5..fba7602500e839 100644 --- a/pkgs/desktops/pantheon/apps/elementary-calendar/default.nix +++ b/pkgs/desktops/pantheon/apps/elementary-calendar/default.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, wrapGAppsHook3 -, clutter -, evolution-data-server -, folks -, geoclue2 -, geocode-glib_2 -, granite -, gtk3 -, libchamplain_libsoup3 -, libgee -, libhandy -, libical -, libportal-gtk3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + wrapGAppsHook3, + clutter, + evolution-data-server, + folks, + geoclue2, + geocode-glib_2, + granite, + gtk3, + libchamplain_libsoup3, + libgee, + libhandy, + libical, + libportal-gtk3, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/elementary-code/default.nix b/pkgs/desktops/pantheon/apps/elementary-code/default.nix index 29404706ac67df..513121a336b0a1 100644 --- a/pkgs/desktops/pantheon/apps/elementary-code/default.nix +++ b/pkgs/desktops/pantheon/apps/elementary-code/default.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, appstream -, desktop-file-utils -, meson -, ninja -, pkg-config -, polkit -, vala -, wrapGAppsHook3 -, editorconfig-core-c -, granite -, gtk3 -, gtksourceview4 -, gtkspell3 -, libgee -, libgit2-glib -, libhandy -, libpeas -, libsoup_2_4 -, vte -, ctags +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + appstream, + desktop-file-utils, + meson, + ninja, + pkg-config, + polkit, + vala, + wrapGAppsHook3, + editorconfig-core-c, + granite, + gtk3, + gtksourceview4, + gtkspell3, + libgee, + libgit2-glib, + libhandy, + libpeas, + libsoup_2_4, + vte, + ctags, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/elementary-feedback/default.nix b/pkgs/desktops/pantheon/apps/elementary-feedback/default.nix index 39e95a5fe36478..636a3bf93dddc2 100644 --- a/pkgs/desktops/pantheon/apps/elementary-feedback/default.nix +++ b/pkgs/desktops/pantheon/apps/elementary-feedback/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pkg-config -, meson -, ninja -, vala -, gtk4 -, glib -, granite7 -, libadwaita -, libgee -, wrapGAppsHook4 -, appstream +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pkg-config, + meson, + ninja, + vala, + gtk4, + glib, + granite7, + libadwaita, + libgee, + wrapGAppsHook4, + appstream, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/elementary-iconbrowser/default.nix b/pkgs/desktops/pantheon/apps/elementary-iconbrowser/default.nix index cfcf4b8e8a607c..ff865688c4fe6e 100644 --- a/pkgs/desktops/pantheon/apps/elementary-iconbrowser/default.nix +++ b/pkgs/desktops/pantheon/apps/elementary-iconbrowser/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, wrapGAppsHook4 -, elementary-gtk-theme -, elementary-icon-theme -, glib -, granite7 -, gtk4 -, gtksourceview5 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + wrapGAppsHook4, + elementary-gtk-theme, + elementary-icon-theme, + glib, + granite7, + gtk4, + gtksourceview5, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/elementary-mail/default.nix b/pkgs/desktops/pantheon/apps/elementary-mail/default.nix index ee4d259d18e1b2..33d4af9363055f 100644 --- a/pkgs/desktops/pantheon/apps/elementary-mail/default.nix +++ b/pkgs/desktops/pantheon/apps/elementary-mail/default.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pkg-config -, meson -, ninja -, vala -, gtk3 -, libxml2 -, libhandy -, libportal-gtk3 -, webkitgtk_4_1 -, elementary-gtk-theme -, elementary-icon-theme -, folks -, glib-networking -, granite -, evolution-data-server -, wrapGAppsHook3 -, libgee +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pkg-config, + meson, + ninja, + vala, + gtk3, + libxml2, + libhandy, + libportal-gtk3, + webkitgtk_4_1, + elementary-gtk-theme, + elementary-icon-theme, + folks, + glib-networking, + granite, + evolution-data-server, + wrapGAppsHook3, + libgee, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/elementary-music/default.nix b/pkgs/desktops/pantheon/apps/elementary-music/default.nix index 49cc2c2e42bcf1..a0a9b1a719fbaf 100644 --- a/pkgs/desktops/pantheon/apps/elementary-music/default.nix +++ b/pkgs/desktops/pantheon/apps/elementary-music/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, wrapGAppsHook4 -, elementary-gtk-theme -, elementary-icon-theme -, glib -, granite7 -, gst_all_1 -, gtk4 -, libadwaita +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + wrapGAppsHook4, + elementary-gtk-theme, + elementary-icon-theme, + glib, + granite7, + gst_all_1, + gtk4, + libadwaita, }: stdenv.mkDerivation rec { @@ -35,19 +36,21 @@ stdenv.mkDerivation rec { wrapGAppsHook4 ]; - buildInputs = [ - elementary-icon-theme - glib - granite7 - gtk4 - libadwaita - ] ++ (with gst_all_1; [ - gst-plugins-bad - gst-plugins-base - gst-plugins-good - gst-plugins-ugly - gstreamer - ]); + buildInputs = + [ + elementary-icon-theme + glib + granite7 + gtk4 + libadwaita + ] + ++ (with gst_all_1; [ + gst-plugins-bad + gst-plugins-base + gst-plugins-good + gst-plugins-ugly + gstreamer + ]); preFixup = '' gappsWrapperArgs+=( diff --git a/pkgs/desktops/pantheon/apps/elementary-photos/default.nix b/pkgs/desktops/pantheon/apps/elementary-photos/default.nix index 7e3794083f3470..bfda13868f2f4f 100644 --- a/pkgs/desktops/pantheon/apps/elementary-photos/default.nix +++ b/pkgs/desktops/pantheon/apps/elementary-photos/default.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, gtk3 -, libexif -, libgee -, libhandy -, libportal-gtk3 -, geocode-glib_2 -, gexiv2 -, libgphoto2 -, granite -, gst_all_1 -, libgudev -, libraw -, sqlite -, libwebp -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + gtk3, + libexif, + libgee, + libhandy, + libportal-gtk3, + geocode-glib_2, + gexiv2, + libgphoto2, + granite, + gst_all_1, + libgudev, + libraw, + sqlite, + libwebp, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -42,27 +43,29 @@ stdenv.mkDerivation rec { wrapGAppsHook3 ]; - buildInputs = [ - geocode-glib_2 - gexiv2 - granite - gtk3 - libexif - libgee - libgphoto2 - libgudev - libhandy - libportal-gtk3 - libraw - libwebp - sqlite - ] ++ (with gst_all_1; [ - gst-plugins-bad - gst-plugins-base - gst-plugins-good - gst-plugins-ugly - gstreamer - ]); + buildInputs = + [ + geocode-glib_2 + gexiv2 + granite + gtk3 + libexif + libgee + libgphoto2 + libgudev + libhandy + libportal-gtk3 + libraw + libwebp + sqlite + ] + ++ (with gst_all_1; [ + gst-plugins-bad + gst-plugins-base + gst-plugins-good + gst-plugins-ugly + gstreamer + ]); passthru = { updateScript = nix-update-script { }; diff --git a/pkgs/desktops/pantheon/apps/elementary-tasks/default.nix b/pkgs/desktops/pantheon/apps/elementary-tasks/default.nix index 7c79252e38a8b1..41d5244aeeff2b 100644 --- a/pkgs/desktops/pantheon/apps/elementary-tasks/default.nix +++ b/pkgs/desktops/pantheon/apps/elementary-tasks/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, wrapGAppsHook3 -, clutter-gtk -, evolution-data-server -, granite -, geoclue2 -, geocode-glib_2 -, gtk3 -, libchamplain_libsoup3 -, libgee -, libhandy -, libical -, libportal-gtk3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + wrapGAppsHook3, + clutter-gtk, + evolution-data-server, + granite, + geoclue2, + geocode-glib_2, + gtk3, + libchamplain_libsoup3, + libgee, + libhandy, + libical, + libportal-gtk3, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/elementary-terminal/default.nix b/pkgs/desktops/pantheon/apps/elementary-terminal/default.nix index a0efe94329659a..eef3b4facca7cd 100644 --- a/pkgs/desktops/pantheon/apps/elementary-terminal/default.nix +++ b/pkgs/desktops/pantheon/apps/elementary-terminal/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pkg-config -, meson -, ninja -, vala -, desktop-file-utils -, gtk3 -, granite -, libhandy -, libnotify -, vte -, libgee -, pcre2 -, wrapGAppsHook3 -, xvfb-run +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pkg-config, + meson, + ninja, + vala, + desktop-file-utils, + gtk3, + granite, + libhandy, + libnotify, + vte, + libgee, + pcre2, + wrapGAppsHook3, + xvfb-run, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/sideload/default.nix b/pkgs/desktops/pantheon/apps/sideload/default.nix index 8aec7fbb386813..dbcf1d2ea45497 100644 --- a/pkgs/desktops/pantheon/apps/sideload/default.nix +++ b/pkgs/desktops/pantheon/apps/sideload/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, desktop-file-utils -, nix-update-script -, fetchFromGitHub -, flatpak -, gettext -, glib -, granite7 -, gtk4 -, meson -, ninja -, pkg-config -, vala -, libxml2 -, wrapGAppsHook4 +{ + lib, + stdenv, + desktop-file-utils, + nix-update-script, + fetchFromGitHub, + flatpak, + gettext, + glib, + granite7, + gtk4, + meson, + ninja, + pkg-config, + vala, + libxml2, + wrapGAppsHook4, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/about/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/about/default.nix index d4683e87899bab..d2fc9ed07eecfd 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/about/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/about/default.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, libadwaita -, libgee -, libgtop -, libgudev -, granite7 -, gtk4 -, packagekit -, polkit -, switchboard -, udisks2 -, fwupd -, appstream -, elementary-settings-daemon +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + libadwaita, + libgee, + libgtop, + libgudev, + granite7, + gtk4, + packagekit, + polkit, + switchboard, + udisks2, + fwupd, + appstream, + elementary-settings-daemon, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/applications/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/applications/default.nix index 6842a72f873146..f8d5db7c8b8ae4 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/applications/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/applications/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, libadwaita -, libgee -, granite7 -, gtk4 -, switchboard -, flatpak +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + libadwaita, + libgee, + granite7, + gtk4, + switchboard, + flatpak, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/bluetooth/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/bluetooth/default.nix index eaca490740e72b..3366a34e73af83 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/bluetooth/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/bluetooth/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, libadwaita -, libgee -, granite7 -, gtk4 -, bluez -, switchboard -, wingpanel-indicator-bluetooth +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + libadwaita, + libgee, + granite7, + gtk4, + bluez, + switchboard, + wingpanel-indicator-bluetooth, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/datetime/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/datetime/default.nix index 5f6874f49b9be1..e72aed12a73a89 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/datetime/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/datetime/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, substituteAll -, pkg-config -, vala -, libadwaita -, libgee -, libical -, granite7 -, gtk4 -, libxml2 -, switchboard -, tzdata +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + substituteAll, + pkg-config, + vala, + libadwaita, + libgee, + libical, + granite7, + gtk4, + libxml2, + switchboard, + tzdata, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/display/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/display/default.nix index 266e992806d499..08b4bb5488b538 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/display/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/display/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, libadwaita -, libgee -, granite7 -, gtk4 -, switchboard +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + libadwaita, + libgee, + granite7, + gtk4, + switchboard, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/mouse-touchpad/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/mouse-touchpad/default.nix index 9084297c05b1a9..2780d98dd38efc 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/mouse-touchpad/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/mouse-touchpad/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, substituteAll -, meson -, ninja -, pkg-config -, vala -, libgee -, libxml2 -, granite7 -, gtk4 -, switchboard -, gnome-settings-daemon -, glib -, gala # needed for gestures support -, touchegg +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + substituteAll, + meson, + ninja, + pkg-config, + vala, + libgee, + libxml2, + granite7, + gtk4, + switchboard, + gnome-settings-daemon, + glib, + gala, # needed for gestures support + touchegg, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/network/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/network/default.nix index 68abe51b4c02e0..3c58ca7ef4d4d4 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/network/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/network/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, substituteAll -, vala -, libadwaita -, libgee -, gettext -, granite7 -, gtk4 -, networkmanager -, networkmanagerapplet -, libnma-gtk4 -, switchboard +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + substituteAll, + vala, + libadwaita, + libgee, + gettext, + granite7, + gtk4, + networkmanager, + networkmanagerapplet, + libnma-gtk4, + switchboard, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/notifications/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/notifications/default.nix index c244592fd1cc40..b90f64057557b3 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/notifications/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/notifications/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, libadwaita -, libgee -, granite7 -, gtk4 -, switchboard -, elementary-notifications +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + libadwaita, + libgee, + granite7, + gtk4, + switchboard, + elementary-notifications, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/onlineaccounts/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/onlineaccounts/default.nix index 7aa683b029eaeb..51074196553b54 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/onlineaccounts/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/onlineaccounts/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, evolution-data-server-gtk4 -, glib -, granite7 -, gtk4 -, libadwaita -, switchboard +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + evolution-data-server-gtk4, + glib, + granite7, + gtk4, + libadwaita, + switchboard, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/power/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/power/default.nix index db147f7ff9da4a..228dfe5cfe6042 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/power/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/power/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, libadwaita -, libgee -, gnome-settings-daemon -, granite7 -, gtk4 -, glib -, dbus -, polkit -, switchboard -, wingpanel-indicator-power +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + libadwaita, + libgee, + gnome-settings-daemon, + granite7, + gtk4, + glib, + dbus, + polkit, + switchboard, + wingpanel-indicator-power, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/printers/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/printers/default.nix index d4195f246a8a22..278cbfbeec122c 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/printers/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/printers/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, libadwaita -, libgee -, granite7 -, gtk4 -, cups -, switchboard +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + libadwaita, + libgee, + granite7, + gtk4, + cups, + switchboard, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/security-privacy/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/security-privacy/default.nix index f407e720ff2c32..ae53ab3add3289 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/security-privacy/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/security-privacy/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, elementary-settings-daemon -, libgee -, granite7 -, gsettings-desktop-schemas -, gala -, gtk4 -, glib -, polkit -, zeitgeist -, switchboard +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + elementary-settings-daemon, + libgee, + granite7, + gsettings-desktop-schemas, + gala, + gtk4, + glib, + polkit, + zeitgeist, + switchboard, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/sharing/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/sharing/default.nix index 0992ded96ad545..2578ce6e3dabb7 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/sharing/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/sharing/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, elementary-bluetooth-daemon -, libgee -, granite7 -, gtk4 -, switchboard +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + elementary-bluetooth-daemon, + libgee, + granite7, + gtk4, + switchboard, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/sound/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/sound/default.nix index 9a20aa7a99067e..45ca8bcc48f5b7 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/sound/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/sound/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, libadwaita -, libcanberra -, libgee -, glib -, granite7 -, gtk4 -, pulseaudio -, switchboard +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + libadwaita, + libcanberra, + libgee, + glib, + granite7, + gtk4, + pulseaudio, + switchboard, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard-plugs/wacom/default.nix b/pkgs/desktops/pantheon/apps/switchboard-plugs/wacom/default.nix index 67088c38635c92..9fb0562e02fa52 100644 --- a/pkgs/desktops/pantheon/apps/switchboard-plugs/wacom/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard-plugs/wacom/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, glib -, granite7 -, gtk4 -, libadwaita -, libgee -, libgudev -, libwacom -, switchboard -, xorg +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + glib, + granite7, + gtk4, + libadwaita, + libgee, + libgudev, + libwacom, + switchboard, + xorg, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard/default.nix b/pkgs/desktops/pantheon/apps/switchboard/default.nix index 02a1b0fd31c2ff..02eaeae906d9e5 100644 --- a/pkgs/desktops/pantheon/apps/switchboard/default.nix +++ b/pkgs/desktops/pantheon/apps/switchboard/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pkg-config -, meson -, ninja -, sassc -, vala -, glib -, gtk4 -, libadwaita -, libgee -, granite7 -, wrapGAppsHook4 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pkg-config, + meson, + ninja, + sassc, + vala, + glib, + gtk4, + libadwaita, + libgee, + granite7, + wrapGAppsHook4, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/apps/switchboard/wrapper.nix b/pkgs/desktops/pantheon/apps/switchboard/wrapper.nix index b27f8135409704..0a1f24780ab1b1 100644 --- a/pkgs/desktops/pantheon/apps/switchboard/wrapper.nix +++ b/pkgs/desktops/pantheon/apps/switchboard/wrapper.nix @@ -1,20 +1,23 @@ -{ wrapGAppsHook4 -, glib -, lib -, stdenv -, xorg -, switchboard -, switchboardPlugs -, plugs +{ + wrapGAppsHook4, + glib, + lib, + stdenv, + xorg, + switchboard, + switchboardPlugs, + plugs, # Only useful to disable for development testing. -, useDefaultPlugs ? true -, testName ? null + useDefaultPlugs ? true, + testName ? null, }: let selectedPlugs = - if plugs == null then switchboardPlugs - else plugs ++ (lib.optionals useDefaultPlugs switchboardPlugs); + if plugs == null then + switchboardPlugs + else + plugs ++ (lib.optionals useDefaultPlugs switchboardPlugs); testingName = lib.optionalString (testName != null) "${testName}-"; in @@ -35,8 +38,7 @@ stdenv.mkDerivation rec { wrapGAppsHook4 ]; - buildInputs = lib.forEach selectedPlugs (x: x.buildInputs) - ++ selectedPlugs; + buildInputs = lib.forEach selectedPlugs (x: x.buildInputs) ++ selectedPlugs; dontUnpack = true; dontConfigure = true; @@ -60,4 +62,3 @@ stdenv.mkDerivation rec { inherit (switchboard) meta; } - diff --git a/pkgs/desktops/pantheon/artwork/elementary-gtk-theme/default.nix b/pkgs/desktops/pantheon/artwork/elementary-gtk-theme/default.nix index 91b7ce32a30527..408046979745a6 100644 --- a/pkgs/desktops/pantheon/artwork/elementary-gtk-theme/default.nix +++ b/pkgs/desktops/pantheon/artwork/elementary-gtk-theme/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, nix-update-script -, gettext -, meson -, ninja -, python3 -, sassc +{ + lib, + stdenvNoCC, + fetchFromGitHub, + nix-update-script, + gettext, + meson, + ninja, + python3, + sassc, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/artwork/elementary-icon-theme/default.nix b/pkgs/desktops/pantheon/artwork/elementary-icon-theme/default.nix index c37ad542b77808..7a3ba9f0020f2c 100644 --- a/pkgs/desktops/pantheon/artwork/elementary-icon-theme/default.nix +++ b/pkgs/desktops/pantheon/artwork/elementary-icon-theme/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, hicolor-icon-theme -, gtk3 -, xcursorgen -, librsvg +{ + lib, + stdenvNoCC, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + hicolor-icon-theme, + gtk3, + xcursorgen, + librsvg, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/artwork/elementary-redacted-script/default.nix b/pkgs/desktops/pantheon/artwork/elementary-redacted-script/default.nix index 66c02d73f71d4b..9aa511fc35b64a 100644 --- a/pkgs/desktops/pantheon/artwork/elementary-redacted-script/default.nix +++ b/pkgs/desktops/pantheon/artwork/elementary-redacted-script/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/artwork/elementary-sound-theme/default.nix b/pkgs/desktops/pantheon/artwork/elementary-sound-theme/default.nix index 7f7279a9df1f08..d9e01a191b8e9a 100644 --- a/pkgs/desktops/pantheon/artwork/elementary-sound-theme/default.nix +++ b/pkgs/desktops/pantheon/artwork/elementary-sound-theme/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/artwork/elementary-wallpapers/default.nix b/pkgs/desktops/pantheon/artwork/elementary-wallpapers/default.nix index 1264eee4152ba2..0579a6048caedb 100644 --- a/pkgs/desktops/pantheon/artwork/elementary-wallpapers/default.nix +++ b/pkgs/desktops/pantheon/artwork/elementary-wallpapers/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, gettext -, meson -, ninja -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + gettext, + meson, + ninja, + python3, }: stdenv.mkDerivation rec { @@ -43,4 +44,3 @@ stdenv.mkDerivation rec { maintainers = teams.pantheon.members; }; } - diff --git a/pkgs/desktops/pantheon/desktop/elementary-onboarding/default.nix b/pkgs/desktops/pantheon/desktop/elementary-onboarding/default.nix index 7c410237e1da32..cac0298c6048e5 100644 --- a/pkgs/desktops/pantheon/desktop/elementary-onboarding/default.nix +++ b/pkgs/desktops/pantheon/desktop/elementary-onboarding/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, wrapGAppsHook4 -, appcenter -, elementary-settings-daemon -, glib -, gnome-settings-daemon -, granite7 -, gtk4 -, libadwaita -, libgee +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + wrapGAppsHook4, + appcenter, + elementary-settings-daemon, + glib, + gnome-settings-daemon, + granite7, + gtk4, + libadwaita, + libgee, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/desktop/elementary-print-shim/default.nix b/pkgs/desktops/pantheon/desktop/elementary-print-shim/default.nix index 816374c24ce278..66bd35ff64011d 100644 --- a/pkgs/desktops/pantheon/desktop/elementary-print-shim/default.nix +++ b/pkgs/desktops/pantheon/desktop/elementary-print-shim/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, gtk3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + gtk3, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/desktop/file-roller-contract/default.nix b/pkgs/desktops/pantheon/desktop/file-roller-contract/default.nix index 6a2a22ddf83a67..3ac8f42b87abf0 100644 --- a/pkgs/desktops/pantheon/desktop/file-roller-contract/default.nix +++ b/pkgs/desktops/pantheon/desktop/file-roller-contract/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, unstableGitUpdater -, substituteAll -, file-roller +{ + lib, + stdenv, + fetchFromGitHub, + unstableGitUpdater, + substituteAll, + file-roller, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/a11y/default.nix b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/a11y/default.nix index a5a011fbaa1968..8c7a2d63047bd2 100644 --- a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/a11y/default.nix +++ b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/a11y/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, pkg-config -, python3 -, vala -, granite -, gtk3 -, libgee -, wingpanel +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + pkg-config, + python3, + vala, + granite, + gtk3, + libgee, + wingpanel, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/bluetooth/default.nix b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/bluetooth/default.nix index edc35f1469086c..5b20d161f7b5b8 100644 --- a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/bluetooth/default.nix +++ b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/bluetooth/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pkg-config -, meson -, ninja -, vala -, gtk3 -, glib -, granite -, libnotify -, wingpanel -, libgee -, libxml2 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pkg-config, + meson, + ninja, + vala, + gtk3, + glib, + granite, + libnotify, + wingpanel, + libgee, + libxml2, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/datetime/default.nix b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/datetime/default.nix index bd87eef9115dac..ba30fb48469f7a 100644 --- a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/datetime/default.nix +++ b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/datetime/default.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, substituteAll -, pkg-config -, meson -, ninja -, vala -, gtk3 -, granite -, wingpanel -, evolution-data-server -, libical -, libgee -, libhandy -, libxml2 -, libsoup_2_4 -, elementary-calendar +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + substituteAll, + pkg-config, + meson, + ninja, + vala, + gtk3, + granite, + wingpanel, + evolution-data-server, + libical, + libgee, + libhandy, + libxml2, + libsoup_2_4, + elementary-calendar, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/keyboard/default.nix b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/keyboard/default.nix index a714b1de065d5e..24ab81ba006817 100644 --- a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/keyboard/default.nix +++ b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/keyboard/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pkg-config -, meson -, ninja -, substituteAll -, vala -, gtk3 -, granite -, libxml2 -, wingpanel -, libgee -, xorg -, libgnomekbd -, ibus +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pkg-config, + meson, + ninja, + substituteAll, + vala, + gtk3, + granite, + libxml2, + wingpanel, + libgee, + xorg, + libgnomekbd, + ibus, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/network/default.nix b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/network/default.nix index 5b66bc1de6f38c..10d0da9acb9cdf 100644 --- a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/network/default.nix +++ b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/network/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pkg-config -, meson -, ninja -, vala -, gtk3 -, granite -, networkmanager -, polkit -, libnma -, wingpanel -, libgee +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pkg-config, + meson, + ninja, + vala, + gtk3, + granite, + networkmanager, + polkit, + libnma, + wingpanel, + libgee, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/nightlight/default.nix b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/nightlight/default.nix index ca7459d07dfe52..209cb7f220273a 100644 --- a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/nightlight/default.nix +++ b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/nightlight/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pkg-config -, meson -, ninja -, vala -, gtk3 -, granite -, wingpanel -, libgee -, libxml2 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pkg-config, + meson, + ninja, + vala, + gtk3, + granite, + wingpanel, + libgee, + libxml2, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/notifications/default.nix b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/notifications/default.nix index 37101f298453be..5181cb1797beb2 100644 --- a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/notifications/default.nix +++ b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/notifications/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pkg-config -, meson -, ninja -, vala -, gtk3 -, granite -, wingpanel -, libgee -, libhandy -, elementary-notifications +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pkg-config, + meson, + ninja, + vala, + gtk3, + granite, + wingpanel, + libgee, + libhandy, + elementary-notifications, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/power/default.nix b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/power/default.nix index 7c4e18d7bebb96..895615d37426dd 100644 --- a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/power/default.nix +++ b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/power/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, substituteAll -, nix-update-script -, gnome-power-manager -, pkg-config -, meson -, ninja -, vala -, elementary-settings-daemon -, gtk3 -, granite -, libgtop -, libnotify -, udev -, wingpanel -, libgee +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + nix-update-script, + gnome-power-manager, + pkg-config, + meson, + ninja, + vala, + elementary-settings-daemon, + gtk3, + granite, + libgtop, + libnotify, + udev, + wingpanel, + libgee, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/sound/default.nix b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/sound/default.nix index eb4133d7082777..b5e567b47f7c32 100644 --- a/pkgs/desktops/pantheon/desktop/wingpanel-indicators/sound/default.nix +++ b/pkgs/desktops/pantheon/desktop/wingpanel-indicators/sound/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pkg-config -, meson -, ninja -, vala -, gnome-settings-daemon -, gtk3 -, granite -, wingpanel -, libnotify -, pulseaudio -, libcanberra-gtk3 -, libgee -, libxml2 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pkg-config, + meson, + ninja, + vala, + gnome-settings-daemon, + gtk3, + granite, + wingpanel, + libnotify, + pulseaudio, + libcanberra-gtk3, + libgee, + libxml2, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/desktop/wingpanel/wrapper.nix b/pkgs/desktops/pantheon/desktop/wingpanel/wrapper.nix index 1642bffb44baa8..fb65b6f3162e06 100644 --- a/pkgs/desktops/pantheon/desktop/wingpanel/wrapper.nix +++ b/pkgs/desktops/pantheon/desktop/wingpanel/wrapper.nix @@ -1,20 +1,23 @@ -{ lib -, wrapGAppsHook3 -, glib -, stdenv -, xorg -, wingpanel -, wingpanelIndicators -, switchboard-with-plugs -, indicators ? null +{ + lib, + wrapGAppsHook3, + glib, + stdenv, + xorg, + wingpanel, + wingpanelIndicators, + switchboard-with-plugs, + indicators ? null, # Only useful to disable for development testing. -, useDefaultIndicators ? true + useDefaultIndicators ? true, }: let selectedIndicators = - if indicators == null then wingpanelIndicators - else indicators ++ (lib.optionals useDefaultIndicators wingpanelIndicators); + if indicators == null then + wingpanelIndicators + else + indicators ++ (lib.optionals useDefaultIndicators wingpanelIndicators); in stdenv.mkDerivation rec { pname = "${wingpanel.pname}-with-indicators"; @@ -33,8 +36,7 @@ stdenv.mkDerivation rec { wrapGAppsHook3 ]; - buildInputs = lib.forEach selectedIndicators (x: x.buildInputs) - ++ selectedIndicators; + buildInputs = lib.forEach selectedIndicators (x: x.buildInputs) ++ selectedIndicators; dontUnpack = true; dontConfigure = true; diff --git a/pkgs/desktops/pantheon/granite/7/default.nix b/pkgs/desktops/pantheon/granite/7/default.nix index 1d7bddbc068776..7e64ff2f181050 100644 --- a/pkgs/desktops/pantheon/granite/7/default.nix +++ b/pkgs/desktops/pantheon/granite/7/default.nix @@ -1,26 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, ninja -, sassc -, vala -, pkg-config -, libgee -, gtk4 -, glib -, gettext -, gsettings-desktop-schemas -, gobject-introspection -, wrapGAppsHook4 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + ninja, + sassc, + vala, + pkg-config, + libgee, + gtk4, + glib, + gettext, + gsettings-desktop-schemas, + gobject-introspection, + wrapGAppsHook4, }: stdenv.mkDerivation rec { pname = "granite"; version = "7.6.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "elementary"; diff --git a/pkgs/desktops/pantheon/granite/default.nix b/pkgs/desktops/pantheon/granite/default.nix index 52eb6602efff34..ffbbca7b44c4a0 100644 --- a/pkgs/desktops/pantheon/granite/default.nix +++ b/pkgs/desktops/pantheon/granite/default.nix @@ -1,25 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 -, meson -, ninja -, vala -, pkg-config -, libgee -, gtk3 -, glib -, gettext -, gsettings-desktop-schemas -, gobject-introspection -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + python3, + meson, + ninja, + vala, + pkg-config, + libgee, + gtk3, + glib, + gettext, + gsettings-desktop-schemas, + gobject-introspection, + wrapGAppsHook3, }: stdenv.mkDerivation rec { pname = "granite"; version = "6.2.0"; # nixpkgs-update: no auto update - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "elementary"; diff --git a/pkgs/desktops/pantheon/services/contractor/default.nix b/pkgs/desktops/pantheon/services/contractor/default.nix index eed8755143c6c2..d5fbc656361979 100644 --- a/pkgs/desktops/pantheon/services/contractor/default.nix +++ b/pkgs/desktops/pantheon/services/contractor/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, meson -, python3 -, ninja -, pkg-config -, vala -, glib -, libgee -, dbus -, glib-networking -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + meson, + python3, + ninja, + pkg-config, + vala, + glib, + libgee, + dbus, + glib-networking, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/services/elementary-capnet-assist/default.nix b/pkgs/desktops/pantheon/services/elementary-capnet-assist/default.nix index 62bf5c5b8dee66..d0447169ef83b5 100644 --- a/pkgs/desktops/pantheon/services/elementary-capnet-assist/default.nix +++ b/pkgs/desktops/pantheon/services/elementary-capnet-assist/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pkg-config -, meson -, ninja -, vala -, gtk4 -, granite7 -, libadwaita -, libgee -, gcr_4 -, webkitgtk_6_0 -, wrapGAppsHook4 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pkg-config, + meson, + ninja, + vala, + gtk4, + granite7, + libadwaita, + libgee, + gcr_4, + webkitgtk_6_0, + wrapGAppsHook4, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/services/elementary-settings-daemon/default.nix b/pkgs/desktops/pantheon/services/elementary-settings-daemon/default.nix index 5c84dffec72a00..3252834c8433c9 100644 --- a/pkgs/desktops/pantheon/services/elementary-settings-daemon/default.nix +++ b/pkgs/desktops/pantheon/services/elementary-settings-daemon/default.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, nix-update-script -, meson -, ninja -, pkg-config -, vala -, accountsservice -, dbus -, desktop-file-utils -, fwupd -, gdk-pixbuf -, geoclue2 -, gexiv2 -, glib -, gobject-introspection -, gtk3 -, granite -, libgee -, packagekit -, systemd -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + nix-update-script, + meson, + ninja, + pkg-config, + vala, + accountsservice, + dbus, + desktop-file-utils, + fwupd, + gdk-pixbuf, + geoclue2, + gexiv2, + glib, + gobject-introspection, + gtk3, + granite, + libgee, + packagekit, + systemd, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/pantheon/services/pantheon-agent-geoclue2/default.nix b/pkgs/desktops/pantheon/services/pantheon-agent-geoclue2/default.nix index 20c28133d234b3..9dd3e6d7217d04 100644 --- a/pkgs/desktops/pantheon/services/pantheon-agent-geoclue2/default.nix +++ b/pkgs/desktops/pantheon/services/pantheon-agent-geoclue2/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, pkg-config -, meson -, ninja -, vala -, glib -, gtk3 -, libgee -, desktop-file-utils -, geoclue2 -, granite -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + pkg-config, + meson, + ninja, + vala, + glib, + gtk3, + libgee, + desktop-file-utils, + geoclue2, + granite, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/plasma-5/3rdparty/addons/bismuth/default.nix b/pkgs/desktops/plasma-5/3rdparty/addons/bismuth/default.nix index bd41ce79873424..56e68479481781 100644 --- a/pkgs/desktops/plasma-5/3rdparty/addons/bismuth/default.nix +++ b/pkgs/desktops/plasma-5/3rdparty/addons/bismuth/default.nix @@ -1,13 +1,14 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, kcoreaddons -, kwindowsystem -, plasma-framework -, systemsettings -, cmake -, extra-cmake-modules -, esbuild +{ + lib, + mkDerivation, + fetchFromGitHub, + kcoreaddons, + kwindowsystem, + plasma-framework, + systemsettings, + cmake, + extra-cmake-modules, + esbuild, }: mkDerivation rec { diff --git a/pkgs/desktops/plasma-5/3rdparty/addons/caffeine-plus.nix b/pkgs/desktops/plasma-5/3rdparty/addons/caffeine-plus.nix index 1a18e1a89de166..7f85fa9f0fc7ec 100644 --- a/pkgs/desktops/plasma-5/3rdparty/addons/caffeine-plus.nix +++ b/pkgs/desktops/plasma-5/3rdparty/addons/caffeine-plus.nix @@ -1,9 +1,10 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, extra-cmake-modules -, kwindowsystem -, plasma-framework +{ + lib, + mkDerivation, + fetchFromGitHub, + extra-cmake-modules, + kwindowsystem, + plasma-framework, }: mkDerivation rec { diff --git a/pkgs/desktops/plasma-5/3rdparty/addons/krunner-ssh.nix b/pkgs/desktops/plasma-5/3rdparty/addons/krunner-ssh.nix index 9e90d8f1204b69..17c4f36cd1b660 100644 --- a/pkgs/desktops/plasma-5/3rdparty/addons/krunner-ssh.nix +++ b/pkgs/desktops/plasma-5/3rdparty/addons/krunner-ssh.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchFromGitLab, python3 }: +{ + lib, + stdenv, + fetchFromGitLab, + python3, +}: let - pythonEnv = python3.withPackages (p: with p; [ dbus-python pygobject3 ]); + pythonEnv = python3.withPackages ( + p: with p; [ + dbus-python + pygobject3 + ] + ); in stdenv.mkDerivation rec { pname = "krunner-ssh"; diff --git a/pkgs/desktops/plasma-5/3rdparty/addons/krunner-symbols.nix b/pkgs/desktops/plasma-5/3rdparty/addons/krunner-symbols.nix index 620d56f8e2c100..6703944b01ffeb 100644 --- a/pkgs/desktops/plasma-5/3rdparty/addons/krunner-symbols.nix +++ b/pkgs/desktops/plasma-5/3rdparty/addons/krunner-symbols.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, extra-cmake-modules -, qtbase -, wrapQtAppsHook -, ki18n -, kdelibs4support -, krunner +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + extra-cmake-modules, + qtbase, + wrapQtAppsHook, + ki18n, + kdelibs4support, + krunner, }: stdenv.mkDerivation rec { @@ -21,8 +22,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-YsoZdPTWpk3/YERwerrVEcaf2IfGVJwpq32onhP8Exo="; }; - buildInputs = [ qtbase ki18n kdelibs4support krunner ]; - nativeBuildInputs = [ cmake wrapQtAppsHook extra-cmake-modules ]; + buildInputs = [ + qtbase + ki18n + kdelibs4support + krunner + ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + extra-cmake-modules + ]; postPatch = '' # symbols.cpp hardcodes the location of configuration files diff --git a/pkgs/desktops/plasma-5/3rdparty/addons/virtual-desktop-bar.nix b/pkgs/desktops/plasma-5/3rdparty/addons/virtual-desktop-bar.nix index 5e4ac584047cfe..873b7cc2ceed41 100644 --- a/pkgs/desktops/plasma-5/3rdparty/addons/virtual-desktop-bar.nix +++ b/pkgs/desktops/plasma-5/3rdparty/addons/virtual-desktop-bar.nix @@ -1,10 +1,11 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, extra-cmake-modules -, kwindowsystem -, plasma-framework -, qtx11extras +{ + lib, + mkDerivation, + fetchFromGitHub, + extra-cmake-modules, + kwindowsystem, + plasma-framework, + qtx11extras, }: mkDerivation rec { diff --git a/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/dynamic-workspaces.nix b/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/dynamic-workspaces.nix index 10133b9bf3f834..676ea18d2e9fbc 100644 --- a/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/dynamic-workspaces.nix +++ b/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/dynamic-workspaces.nix @@ -1,10 +1,11 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, kcoreaddons -, kwindowsystem -, plasma-framework -, systemsettings +{ + lib, + mkDerivation, + fetchFromGitHub, + kcoreaddons, + kwindowsystem, + plasma-framework, + systemsettings, }: mkDerivation rec { diff --git a/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/krohnkite.nix b/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/krohnkite.nix index b55c34c4d248ef..0d62bdf3286937 100644 --- a/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/krohnkite.nix +++ b/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/krohnkite.nix @@ -1,10 +1,11 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, kcoreaddons -, kwindowsystem -, plasma-framework -, systemsettings +{ + lib, + mkDerivation, + fetchFromGitHub, + kcoreaddons, + kwindowsystem, + plasma-framework, + systemsettings, }: mkDerivation rec { diff --git a/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/kzones.nix b/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/kzones.nix index f35ce8f1d0bd25..813ff8d335a77b 100644 --- a/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/kzones.nix +++ b/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/kzones.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, kcoreaddons -, kwindowsystem -, plasma-framework -, systemsettings +{ + lib, + stdenv, + fetchFromGitHub, + kcoreaddons, + kwindowsystem, + plasma-framework, + systemsettings, }: -stdenv.mkDerivation(finalAttrs: { +stdenv.mkDerivation (finalAttrs: { pname = "kzones"; version = "0.6"; diff --git a/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/parachute.nix b/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/parachute.nix index 63ed7a86fe303e..698af1cadd0045 100644 --- a/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/parachute.nix +++ b/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/parachute.nix @@ -1,10 +1,11 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, kcoreaddons -, kwindowsystem -, plasma-framework -, systemsettings +{ + lib, + mkDerivation, + fetchFromGitHub, + kcoreaddons, + kwindowsystem, + plasma-framework, + systemsettings, }: mkDerivation rec { diff --git a/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/tiling.nix b/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/tiling.nix index 5f13a95ce081cd..384635ad94237e 100644 --- a/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/tiling.nix +++ b/pkgs/desktops/plasma-5/3rdparty/kwin/scripts/tiling.nix @@ -1,10 +1,11 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, kcoreaddons -, kwindowsystem -, plasma-framework -, systemsettings +{ + lib, + mkDerivation, + fetchFromGitHub, + kcoreaddons, + kwindowsystem, + plasma-framework, + systemsettings, }: mkDerivation rec { diff --git a/pkgs/desktops/plasma-5/3rdparty/lightly/default.nix b/pkgs/desktops/plasma-5/3rdparty/lightly/default.nix index b3830d06d1efcb..cb8189b994ea94 100644 --- a/pkgs/desktops/plasma-5/3rdparty/lightly/default.nix +++ b/pkgs/desktops/plasma-5/3rdparty/lightly/default.nix @@ -1,18 +1,19 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, cmake -, extra-cmake-modules -, kdecoration -, kcoreaddons -, kguiaddons -, kconfigwidgets -, kwindowsystem -, kiconthemes -, qtx11extras +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + extra-cmake-modules, + kdecoration, + kcoreaddons, + kguiaddons, + kconfigwidgets, + kwindowsystem, + kiconthemes, + qtx11extras, }: -mkDerivation rec{ +mkDerivation rec { pname = "lightly"; version = "0.4.1"; src = fetchFromGitHub { @@ -24,7 +25,10 @@ mkDerivation rec{ extraCmakeFlags = [ "-DBUILD_TESTING=OFF" ]; - nativeBuildInputs = [ cmake extra-cmake-modules ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; buildInputs = [ kcoreaddons diff --git a/pkgs/desktops/plasma-5/aura-browser.nix b/pkgs/desktops/plasma-5/aura-browser.nix index 67af48b2bcb95f..b012417a6bc756 100644 --- a/pkgs/desktops/plasma-5/aura-browser.nix +++ b/pkgs/desktops/plasma-5/aura-browser.nix @@ -1,9 +1,10 @@ -{ mkDerivation -, extra-cmake-modules -, qtwebengine -, qtquickcontrols2 -, kirigami2 -, ki18n +{ + mkDerivation, + extra-cmake-modules, + qtwebengine, + qtquickcontrols2, + kirigami2, + ki18n, }: mkDerivation { pname = "aura-browser"; diff --git a/pkgs/desktops/plasma-5/bluedevil.nix b/pkgs/desktops/plasma-5/bluedevil.nix index a7574cdc655f56..0ad806520c5319 100644 --- a/pkgs/desktops/plasma-5/bluedevil.nix +++ b/pkgs/desktops/plasma-5/bluedevil.nix @@ -1,25 +1,29 @@ -{ mkDerivation -, extra-cmake-modules -, shared-mime-info -, qtbase -, qtdeclarative -, bluez-qt -, kcoreaddons -, kcmutils -, kdbusaddons -, kded -, ki18n -, kiconthemes -, kio -, knotifications -, kwidgetsaddons -, kwindowsystem -, plasma-framework +{ + mkDerivation, + extra-cmake-modules, + shared-mime-info, + qtbase, + qtdeclarative, + bluez-qt, + kcoreaddons, + kcmutils, + kdbusaddons, + kded, + ki18n, + kiconthemes, + kio, + knotifications, + kwidgetsaddons, + kwindowsystem, + plasma-framework, }: mkDerivation { pname = "bluedevil"; - nativeBuildInputs = [ extra-cmake-modules shared-mime-info ]; + nativeBuildInputs = [ + extra-cmake-modules + shared-mime-info + ]; buildInputs = [ qtbase qtdeclarative diff --git a/pkgs/desktops/plasma-5/breeze-grub.nix b/pkgs/desktops/plasma-5/breeze-grub.nix index 86ce3dc112d05a..cbfb47efade772 100644 --- a/pkgs/desktops/plasma-5/breeze-grub.nix +++ b/pkgs/desktops/plasma-5/breeze-grub.nix @@ -1,4 +1,5 @@ -{ mkDerivation +{ + mkDerivation, }: mkDerivation { diff --git a/pkgs/desktops/plasma-5/breeze-gtk.nix b/pkgs/desktops/plasma-5/breeze-gtk.nix index 3ecc5d5e5b0d1f..2974ff51798ac5 100644 --- a/pkgs/desktops/plasma-5/breeze-gtk.nix +++ b/pkgs/desktops/plasma-5/breeze-gtk.nix @@ -1,8 +1,21 @@ -{ mkDerivation, extra-cmake-modules, qtbase, sassc, python3, breeze-qt5 }: +{ + mkDerivation, + extra-cmake-modules, + qtbase, + sassc, + python3, + breeze-qt5, +}: mkDerivation { pname = "breeze-gtk"; - nativeBuildInputs = [ extra-cmake-modules sassc python3 python3.pkgs.pycairo breeze-qt5 ]; + nativeBuildInputs = [ + extra-cmake-modules + sassc + python3 + python3.pkgs.pycairo + breeze-qt5 + ]; buildInputs = [ qtbase ]; patches = [ ./patches/0001-fix-add-executable-bit.patch diff --git a/pkgs/desktops/plasma-5/breeze-plymouth/default.nix b/pkgs/desktops/plasma-5/breeze-plymouth/default.nix index 8aefcbbe03be60..a4b3b8b429917b 100644 --- a/pkgs/desktops/plasma-5/breeze-plymouth/default.nix +++ b/pkgs/desktops/plasma-5/breeze-plymouth/default.nix @@ -1,48 +1,69 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, plymouth -, imagemagick -, netpbm -, perl -, logoName ? null -, logoFile ? null -, osName ? null -, osVersion ? null -, topColor ? "black" -, bottomColor ? "black" +{ + mkDerivation, + lib, + extra-cmake-modules, + plymouth, + imagemagick, + netpbm, + perl, + logoName ? null, + logoFile ? null, + osName ? null, + osVersion ? null, + topColor ? "black", + bottomColor ? "black", }: let - validColors = [ "black" "cardboard_grey" "charcoal_grey" "icon_blue" "paper_white" "plasma_blue" "neon_blue" "neon_green" ]; - resolvedLogoName = if (logoFile != null && logoName == null) then lib.strings.removeSuffix ".png" (baseNameOf (toString logoFile)) else logoName; + validColors = [ + "black" + "cardboard_grey" + "charcoal_grey" + "icon_blue" + "paper_white" + "plasma_blue" + "neon_blue" + "neon_green" + ]; + resolvedLogoName = + if (logoFile != null && logoName == null) then + lib.strings.removeSuffix ".png" (baseNameOf (toString logoFile)) + else + logoName; in assert lib.asserts.assertOneOf "topColor" topColor validColors; assert lib.asserts.assertOneOf "bottomColor" bottomColor validColors; - mkDerivation { pname = "breeze-plymouth"; - nativeBuildInputs = [ extra-cmake-modules ] ++ lib.optionals (logoFile != null) [ imagemagick netpbm perl ]; + nativeBuildInputs = + [ extra-cmake-modules ] + ++ lib.optionals (logoFile != null) [ + imagemagick + netpbm + perl + ]; buildInputs = [ plymouth ]; patches = [ ./install-paths.patch ]; - cmakeFlags = [ ] + cmakeFlags = + [ ] ++ lib.optional (osName != null) "-DDISTRO_NAME=${osName}" ++ lib.optional (osVersion != null) "-DDISTRO_VERSION=${osVersion}" ++ lib.optional (logoName != null) "-DDISTRO_LOGO=${logoName}" ++ lib.optional (topColor != null) "-DBACKGROUND_TOP_COLOR=${topColor}" - ++ lib.optional (bottomColor != null) "-DBACKGROUND_BOTTOM_COLOR=${bottomColor}" - ; + ++ lib.optional (bottomColor != null) "-DBACKGROUND_BOTTOM_COLOR=${bottomColor}"; - postPatch = '' - substituteInPlace cmake/FindPlymouth.cmake --subst-var out - '' + lib.optionalString (logoFile != null) '' - cp ${logoFile} breeze/images/${resolvedLogoName}.logo.png + postPatch = + '' + substituteInPlace cmake/FindPlymouth.cmake --subst-var out + '' + + lib.optionalString (logoFile != null) '' + cp ${logoFile} breeze/images/${resolvedLogoName}.logo.png - # conversion for 16bit taken from the breeze-plymouth readme - convert ${logoFile} -alpha Background -background "#000000" -fill "#000000" -flatten tmp.png - pngtopnm tmp.png | pnmquant 16 | pnmtopng > breeze/images/16bit/${resolvedLogoName}.logo.png - ''; + # conversion for 16bit taken from the breeze-plymouth readme + convert ${logoFile} -alpha Background -background "#000000" -fill "#000000" -flatten tmp.png + pngtopnm tmp.png | pnmquant 16 | pnmtopng > breeze/images/16bit/${resolvedLogoName}.logo.png + ''; } diff --git a/pkgs/desktops/plasma-5/breeze-qt5.nix b/pkgs/desktops/plasma-5/breeze-qt5.nix index bcabd31eea644a..2d50f89e1d39bd 100644 --- a/pkgs/desktops/plasma-5/breeze-qt5.nix +++ b/pkgs/desktops/plasma-5/breeze-qt5.nix @@ -1,18 +1,19 @@ -{ mkDerivation -, extra-cmake-modules -, frameworkintegration -, kcmutils -, kconfigwidgets -, kcoreaddons -, kdecoration -, kguiaddons -, ki18n -, kwayland -, kwindowsystem -, plasma-framework -, qtdeclarative -, qtx11extras -, fftw +{ + mkDerivation, + extra-cmake-modules, + frameworkintegration, + kcmutils, + kconfigwidgets, + kcoreaddons, + kdecoration, + kguiaddons, + ki18n, + kwayland, + kwindowsystem, + plasma-framework, + qtdeclarative, + qtx11extras, + fftw, }: mkDerivation { @@ -34,6 +35,10 @@ mkDerivation { qtx11extras fftw ]; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; cmakeFlags = [ "-DUSE_Qt4=OFF" ]; } diff --git a/pkgs/desktops/plasma-5/default.nix b/pkgs/desktops/plasma-5/default.nix index 20c7904f9c0abb..93a02955b5f169 100644 --- a/pkgs/desktops/plasma-5/default.nix +++ b/pkgs/desktops/plasma-5/default.nix @@ -1,5 +1,4 @@ /* - # New packages READ THIS FIRST @@ -21,18 +20,21 @@ from the top of the Nixpkgs tree. 3. Use `nox-review wip` to check that everything builds. 4. Commit the changes and open a pull request. - */ -{ libsForQt5 -, lib -, config -, fetchurl -, gsettings-desktop-schemas +{ + libsForQt5, + lib, + config, + fetchurl, + gsettings-desktop-schemas, }: let - maintainers = with lib.maintainers; [ ttuegel nyanloutre ]; + maintainers = with lib.maintainers; [ + ttuegel + nyanloutre + ]; license = with lib.licenses; [ lgpl21Plus lgpl3Plus @@ -50,12 +52,15 @@ let qtStdenv = libsForQt5.callPackage ({ stdenv }: stdenv) { }; - packages = self: + packages = + self: let - propagate = out: + propagate = + out: let - setupHook = { writeScript }: + setupHook = + { writeScript }: writeScript "setup-hook" '' if [[ "''${hookName-}" != postHook ]]; then postHooks+=("source @dev@/nix-support/setup-hook") @@ -83,7 +88,8 @@ let callPackage = self.newScope { inherit propagate propagateBin; - mkDerivation = args: + mkDerivation = + args: let inherit (args) pname; sname = args.sname or pname; @@ -98,17 +104,31 @@ let nativeBuildInputs = (args.nativeBuildInputs or [ ]) ++ [ libsForQt5.wrapQtAppsHook ]; meta = - let meta = args.meta or { }; in - meta // { + let + meta = args.meta or { }; + in + meta + // { homepage = meta.homepage or "http://www.kde.org"; license = meta.license or license; maintainers = (meta.maintainers or [ ]) ++ maintainers; platforms = meta.platforms or lib.platforms.linux; }; in - qtStdenv.mkDerivation (args // { - inherit pname version meta outputs setupHook src nativeBuildInputs; - }); + qtStdenv.mkDerivation ( + args + // { + inherit + pname + version + meta + outputs + setupHook + src + nativeBuildInputs + ; + } + ); }; in @@ -171,21 +191,26 @@ let systemsettings = callPackage ./systemsettings.nix { }; xdg-desktop-portal-kde = callPackage ./xdg-desktop-portal-kde.nix { }; - thirdParty = let inherit (libsForQt5) callPackage; in { - plasma-applet-caffeine-plus = callPackage ./3rdparty/addons/caffeine-plus.nix { }; - plasma-applet-virtual-desktop-bar = callPackage ./3rdparty/addons/virtual-desktop-bar.nix { }; - bismuth = callPackage ./3rdparty/addons/bismuth { }; - kwin-dynamic-workspaces = callPackage ./3rdparty/kwin/scripts/dynamic-workspaces.nix { }; - kwin-tiling = callPackage ./3rdparty/kwin/scripts/tiling.nix { }; - krohnkite = callPackage ./3rdparty/kwin/scripts/krohnkite.nix { }; - krunner-ssh = callPackage ./3rdparty/addons/krunner-ssh.nix { }; - krunner-symbols = callPackage ./3rdparty/addons/krunner-symbols.nix { }; - kzones = callPackage ./3rdparty/kwin/scripts/kzones.nix { }; - lightly = callPackage ./3rdparty/lightly { }; - parachute = callPackage ./3rdparty/kwin/scripts/parachute.nix { }; - }; - - } // lib.optionalAttrs config.allowAliases { + thirdParty = + let + inherit (libsForQt5) callPackage; + in + { + plasma-applet-caffeine-plus = callPackage ./3rdparty/addons/caffeine-plus.nix { }; + plasma-applet-virtual-desktop-bar = callPackage ./3rdparty/addons/virtual-desktop-bar.nix { }; + bismuth = callPackage ./3rdparty/addons/bismuth { }; + kwin-dynamic-workspaces = callPackage ./3rdparty/kwin/scripts/dynamic-workspaces.nix { }; + kwin-tiling = callPackage ./3rdparty/kwin/scripts/tiling.nix { }; + krohnkite = callPackage ./3rdparty/kwin/scripts/krohnkite.nix { }; + krunner-ssh = callPackage ./3rdparty/addons/krunner-ssh.nix { }; + krunner-symbols = callPackage ./3rdparty/addons/krunner-symbols.nix { }; + kzones = callPackage ./3rdparty/kwin/scripts/kzones.nix { }; + lightly = callPackage ./3rdparty/lightly { }; + parachute = callPackage ./3rdparty/kwin/scripts/parachute.nix { }; + }; + + } + // lib.optionalAttrs config.allowAliases { ksysguard = throw "ksysguard has been replaced with plasma-systemmonitor"; plasma-phone-components = throw "'plasma-phone-components' has been renamed to/replaced by 'plasma-mobile'"; }; diff --git a/pkgs/desktops/plasma-5/discover.nix b/pkgs/desktops/plasma-5/discover.nix index 2c2600845b246e..aa0d51c00f9317 100644 --- a/pkgs/desktops/plasma-5/discover.nix +++ b/pkgs/desktops/plasma-5/discover.nix @@ -1,39 +1,45 @@ -{ mkDerivation -, extra-cmake-modules -, gettext -, kdoctools -, python3 -, appstream-qt -, discount -, flatpak -, fwupd -, ostree -, pcre -, util-linux -, qtquickcontrols2 -, qtwebview -, qtx11extras -, karchive -, kcmutils -, kconfig -, kcrash -, kdbusaddons -, kdeclarative -, kidletime -, kio -, kirigami2 -, kitemmodels -, knewstuff -, kpurpose -, kuserfeedback -, kwindowsystem -, kxmlgui -, plasma-framework +{ + mkDerivation, + extra-cmake-modules, + gettext, + kdoctools, + python3, + appstream-qt, + discount, + flatpak, + fwupd, + ostree, + pcre, + util-linux, + qtquickcontrols2, + qtwebview, + qtx11extras, + karchive, + kcmutils, + kconfig, + kcrash, + kdbusaddons, + kdeclarative, + kidletime, + kio, + kirigami2, + kitemmodels, + knewstuff, + kpurpose, + kuserfeedback, + kwindowsystem, + kxmlgui, + plasma-framework, }: mkDerivation { pname = "discover"; - nativeBuildInputs = [ extra-cmake-modules gettext kdoctools python3 ]; + nativeBuildInputs = [ + extra-cmake-modules + gettext + kdoctools + python3 + ]; buildInputs = [ # discount is needed for libmarkdown appstream-qt diff --git a/pkgs/desktops/plasma-5/flatpak-kcm.nix b/pkgs/desktops/plasma-5/flatpak-kcm.nix index 0a94b085232fdc..3cf54431898c94 100644 --- a/pkgs/desktops/plasma-5/flatpak-kcm.nix +++ b/pkgs/desktops/plasma-5/flatpak-kcm.nix @@ -1,10 +1,11 @@ -{ mkDerivation -, extra-cmake-modules -, flatpak -, kcmutils -, kconfig -, kdeclarative -, kitemmodels +{ + mkDerivation, + extra-cmake-modules, + flatpak, + kcmutils, + kconfig, + kdeclarative, + kitemmodels, }: mkDerivation { diff --git a/pkgs/desktops/plasma-5/kactivitymanagerd.nix b/pkgs/desktops/plasma-5/kactivitymanagerd.nix index 195e575756081e..8fa5be590a2083 100644 --- a/pkgs/desktops/plasma-5/kactivitymanagerd.nix +++ b/pkgs/desktops/plasma-5/kactivitymanagerd.nix @@ -1,16 +1,17 @@ -{ mkDerivation -, extra-cmake-modules -, boost -, kconfig -, kcoreaddons -, kdbusaddons -, ki18n -, kio -, kglobalaccel -, kwindowsystem -, kxmlgui -, kcrash -, qtbase +{ + mkDerivation, + extra-cmake-modules, + boost, + kconfig, + kcoreaddons, + kdbusaddons, + ki18n, + kio, + kglobalaccel, + kwindowsystem, + kxmlgui, + kcrash, + qtbase, }: mkDerivation { diff --git a/pkgs/desktops/plasma-5/kde-cli-tools.nix b/pkgs/desktops/plasma-5/kde-cli-tools.nix index e02f1297c012e2..506d20318067cd 100644 --- a/pkgs/desktops/plasma-5/kde-cli-tools.nix +++ b/pkgs/desktops/plasma-5/kde-cli-tools.nix @@ -1,24 +1,28 @@ -{ lib -, mkDerivation -, extra-cmake-modules -, kdoctools -, kcmutils -, kconfig -, kdesu -, ki18n -, kiconthemes -, kinit -, kio -, kwindowsystem -, qtsvg -, qtx11extras -, kactivities -, plasma-workspace +{ + lib, + mkDerivation, + extra-cmake-modules, + kdoctools, + kcmutils, + kconfig, + kdesu, + ki18n, + kiconthemes, + kinit, + kio, + kwindowsystem, + qtsvg, + qtx11extras, + kactivities, + plasma-workspace, }: mkDerivation { pname = "kde-cli-tools"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ kcmutils kconfig diff --git a/pkgs/desktops/plasma-5/kde-gtk-config/default.nix b/pkgs/desktops/plasma-5/kde-gtk-config/default.nix index fd3c5e71a3d69f..83442c3359aeae 100644 --- a/pkgs/desktops/plasma-5/kde-gtk-config/default.nix +++ b/pkgs/desktops/plasma-5/kde-gtk-config/default.nix @@ -1,24 +1,28 @@ -{ mkDerivation -, extra-cmake-modules -, wrapGAppsHook3 -, glib -, gtk3 -, karchive -, kcmutils -, kconfigwidgets -, ki18n -, kiconthemes -, kio -, knewstuff -, gsettings-desktop-schemas -, xsettingsd -, kdecoration -, sass +{ + mkDerivation, + extra-cmake-modules, + wrapGAppsHook3, + glib, + gtk3, + karchive, + kcmutils, + kconfigwidgets, + ki18n, + kiconthemes, + kio, + knewstuff, + gsettings-desktop-schemas, + xsettingsd, + kdecoration, + sass, }: mkDerivation { pname = "kde-gtk-config"; - nativeBuildInputs = [ extra-cmake-modules wrapGAppsHook3 ]; + nativeBuildInputs = [ + extra-cmake-modules + wrapGAppsHook3 + ]; dontWrapGApps = true; # There is nothing to wrap buildInputs = [ ki18n diff --git a/pkgs/desktops/plasma-5/kdecoration.nix b/pkgs/desktops/plasma-5/kdecoration.nix index b3cb961e6d5b08..e1290656352cf4 100644 --- a/pkgs/desktops/plasma-5/kdecoration.nix +++ b/pkgs/desktops/plasma-5/kdecoration.nix @@ -1,8 +1,21 @@ -{ mkDerivation, extra-cmake-modules, qtbase, ki18n, kcoreaddons }: +{ + mkDerivation, + extra-cmake-modules, + qtbase, + ki18n, + kcoreaddons, +}: mkDerivation { pname = "kdecoration"; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ qtbase ki18n kcoreaddons ]; - outputs = [ "out" "dev" ]; + buildInputs = [ + qtbase + ki18n + kcoreaddons + ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/desktops/plasma-5/kdeplasma-addons.nix b/pkgs/desktops/plasma-5/kdeplasma-addons.nix index b8461fbd108d9f..1f737ec8dedf97 100644 --- a/pkgs/desktops/plasma-5/kdeplasma-addons.nix +++ b/pkgs/desktops/plasma-5/kdeplasma-addons.nix @@ -1,29 +1,33 @@ -{ mkDerivation -, extra-cmake-modules -, kdoctools -, kconfig -, kconfigwidgets -, kcoreaddons -, kcmutils -, kholidays -, kio -, knewstuff -, kpurpose -, kross -, krunner -, kservice -, kunitconversion -, ibus -, plasma-framework -, plasma-workspace -, qtdeclarative -, qtwebengine -, qtx11extras +{ + mkDerivation, + extra-cmake-modules, + kdoctools, + kconfig, + kconfigwidgets, + kcoreaddons, + kcmutils, + kholidays, + kio, + knewstuff, + kpurpose, + kross, + krunner, + kservice, + kunitconversion, + ibus, + plasma-framework, + plasma-workspace, + qtdeclarative, + qtwebengine, + qtx11extras, }: mkDerivation { pname = "kdeplasma-addons"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ kconfig kconfigwidgets diff --git a/pkgs/desktops/plasma-5/kgamma5.nix b/pkgs/desktops/plasma-5/kgamma5.nix index df552e1c87a8be..80a8ebb880f115 100644 --- a/pkgs/desktops/plasma-5/kgamma5.nix +++ b/pkgs/desktops/plasma-5/kgamma5.nix @@ -1,15 +1,25 @@ -{ mkDerivation -, extra-cmake-modules -, kdoctools -, kconfig -, kconfigwidgets -, ki18n -, qtx11extras -, libXxf86vm +{ + mkDerivation, + extra-cmake-modules, + kdoctools, + kconfig, + kconfigwidgets, + ki18n, + qtx11extras, + libXxf86vm, }: mkDerivation { pname = "kgamma5"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ kconfig kconfigwidgets ki18n qtx11extras libXxf86vm ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + kconfig + kconfigwidgets + ki18n + qtx11extras + libXxf86vm + ]; } diff --git a/pkgs/desktops/plasma-5/khotkeys.nix b/pkgs/desktops/plasma-5/khotkeys.nix index 244756ec80177b..af2299c1adeb12 100644 --- a/pkgs/desktops/plasma-5/khotkeys.nix +++ b/pkgs/desktops/plasma-5/khotkeys.nix @@ -1,21 +1,25 @@ -{ mkDerivation -, extra-cmake-modules -, kdoctools -, kcmutils -, kdbusaddons -, kdelibs4support -, kglobalaccel -, ki18n -, kio -, kxmlgui -, plasma-framework -, plasma-workspace -, qtx11extras +{ + mkDerivation, + extra-cmake-modules, + kdoctools, + kcmutils, + kdbusaddons, + kdelibs4support, + kglobalaccel, + ki18n, + kio, + kxmlgui, + plasma-framework, + plasma-workspace, + qtx11extras, }: mkDerivation { pname = "khotkeys"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ kcmutils kdbusaddons @@ -28,5 +32,9 @@ mkDerivation { plasma-workspace qtx11extras ]; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; } diff --git a/pkgs/desktops/plasma-5/kinfocenter/default.nix b/pkgs/desktops/plasma-5/kinfocenter/default.nix index bbc8c03f37c19b..ac9964eb4315af 100644 --- a/pkgs/desktops/plasma-5/kinfocenter/default.nix +++ b/pkgs/desktops/plasma-5/kinfocenter/default.nix @@ -1,37 +1,38 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, qttools -, kcmutils -, kcompletion -, kconfig -, kconfigwidgets -, kcoreaddons -, kdbusaddons -, kdeclarative -, ki18n -, kiconthemes -, kio -, kirigami2 -, kpackage -, kservice -, kwayland -, kwidgetsaddons -, kxmlgui -, solid -, systemsettings -, dmidecode -, fwupd -, libraw1394 -, libusb1 -, libGLU -, pciutils -, smartmontools -, util-linux -, vulkan-tools -, wayland-utils -, xdpyinfo +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + qttools, + kcmutils, + kcompletion, + kconfig, + kconfigwidgets, + kcoreaddons, + kdbusaddons, + kdeclarative, + ki18n, + kiconthemes, + kio, + kirigami2, + kpackage, + kservice, + kwayland, + kwidgetsaddons, + kxmlgui, + solid, + systemsettings, + dmidecode, + fwupd, + libraw1394, + libusb1, + libGLU, + pciutils, + smartmontools, + util-linux, + vulkan-tools, + wayland-utils, + xdpyinfo, }: let @@ -43,7 +44,10 @@ in mkDerivation { pname = "kinfocenter"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ kcmutils diff --git a/pkgs/desktops/plasma-5/kmenuedit.nix b/pkgs/desktops/plasma-5/kmenuedit.nix index 57b327a7cdc408..d22002f3ebcff5 100644 --- a/pkgs/desktops/plasma-5/kmenuedit.nix +++ b/pkgs/desktops/plasma-5/kmenuedit.nix @@ -1,18 +1,22 @@ -{ mkDerivation -, extra-cmake-modules -, kdoctools -, kdbusaddons -, khotkeys -, ki18n -, kiconthemes -, kio -, kxmlgui -, sonnet +{ + mkDerivation, + extra-cmake-modules, + kdoctools, + kdbusaddons, + khotkeys, + ki18n, + kiconthemes, + kio, + kxmlgui, + sonnet, }: mkDerivation { pname = "kmenuedit"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ kdbusaddons khotkeys diff --git a/pkgs/desktops/plasma-5/kpipewire.nix b/pkgs/desktops/plasma-5/kpipewire.nix index 59169cd510c82e..c24dd55e3ff9ba 100644 --- a/pkgs/desktops/plasma-5/kpipewire.nix +++ b/pkgs/desktops/plasma-5/kpipewire.nix @@ -1,14 +1,15 @@ -{ mkDerivation -, extra-cmake-modules -, kwayland -, ki18n -, kcoreaddons -, plasma-wayland-protocols -, libepoxy -, ffmpeg -, mesa -, pipewire -, wayland +{ + mkDerivation, + extra-cmake-modules, + kwayland, + ki18n, + kcoreaddons, + plasma-wayland-protocols, + libepoxy, + ffmpeg, + mesa, + pipewire, + wayland, }: mkDerivation { diff --git a/pkgs/desktops/plasma-5/kscreen.nix b/pkgs/desktops/plasma-5/kscreen.nix index ca5ad59072f06e..a731051096dd12 100644 --- a/pkgs/desktops/plasma-5/kscreen.nix +++ b/pkgs/desktops/plasma-5/kscreen.nix @@ -1,22 +1,23 @@ -{ mkDerivation -, extra-cmake-modules -, kconfig -, kcmutils -, kconfigwidgets -, kdbusaddons -, kglobalaccel -, ki18n -, kwidgetsaddons -, kxmlgui -, libkscreen -, qtdeclarative -, qtgraphicaleffects -, qtsensors -, kwindowsystem -, kdeclarative -, plasma-framework -, qtx11extras -, layer-shell-qt +{ + mkDerivation, + extra-cmake-modules, + kconfig, + kcmutils, + kconfigwidgets, + kdbusaddons, + kglobalaccel, + ki18n, + kwidgetsaddons, + kxmlgui, + libkscreen, + qtdeclarative, + qtgraphicaleffects, + qtsensors, + kwindowsystem, + kdeclarative, + plasma-framework, + qtx11extras, + layer-shell-qt, }: mkDerivation { diff --git a/pkgs/desktops/plasma-5/kscreenlocker.nix b/pkgs/desktops/plasma-5/kscreenlocker.nix index 68bedb5e468028..98212a45df7919 100644 --- a/pkgs/desktops/plasma-5/kscreenlocker.nix +++ b/pkgs/desktops/plasma-5/kscreenlocker.nix @@ -1,26 +1,31 @@ -{ mkDerivation -, extra-cmake-modules -, kdoctools -, wayland-scanner -, kcmutils -, kcrash -, kdeclarative -, kglobalaccel -, kidletime -, libkscreen -, kwayland -, libXcursor -, pam -, plasma-framework -, qtdeclarative -, qtx11extras -, wayland -, layer-shell-qt +{ + mkDerivation, + extra-cmake-modules, + kdoctools, + wayland-scanner, + kcmutils, + kcrash, + kdeclarative, + kglobalaccel, + kidletime, + libkscreen, + kwayland, + libXcursor, + pam, + plasma-framework, + qtdeclarative, + qtx11extras, + wayland, + layer-shell-qt, }: mkDerivation { pname = "kscreenlocker"; - nativeBuildInputs = [ extra-cmake-modules kdoctools wayland-scanner ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wayland-scanner + ]; buildInputs = [ kcmutils kcrash @@ -37,5 +42,8 @@ mkDerivation { wayland layer-shell-qt ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/desktops/plasma-5/ksshaskpass.nix b/pkgs/desktops/plasma-5/ksshaskpass.nix index 072b78f53d6bab..d112a257945781 100644 --- a/pkgs/desktops/plasma-5/ksshaskpass.nix +++ b/pkgs/desktops/plasma-5/ksshaskpass.nix @@ -1,15 +1,25 @@ -{ mkDerivation -, extra-cmake-modules -, kdoctools -, kcoreaddons -, ki18n -, kwallet -, kwidgetsaddons -, qtbase +{ + mkDerivation, + extra-cmake-modules, + kdoctools, + kcoreaddons, + ki18n, + kwallet, + kwidgetsaddons, + qtbase, }: mkDerivation { pname = "ksshaskpass"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - buildInputs = [ kcoreaddons ki18n kwallet kwidgetsaddons qtbase ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + buildInputs = [ + kcoreaddons + ki18n + kwallet + kwidgetsaddons + qtbase + ]; } diff --git a/pkgs/desktops/plasma-5/ksystemstats.nix b/pkgs/desktops/plasma-5/ksystemstats.nix index 5b552a1f786055..97591f6cdb146d 100644 --- a/pkgs/desktops/plasma-5/ksystemstats.nix +++ b/pkgs/desktops/plasma-5/ksystemstats.nix @@ -1,15 +1,21 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, libksysguard -, libnl -, lm_sensors -, networkmanager-qt +{ + mkDerivation, + lib, + extra-cmake-modules, + libksysguard, + libnl, + lm_sensors, + networkmanager-qt, }: mkDerivation { pname = "ksystemstats"; env.NIX_CFLAGS_COMPILE = toString [ "-I${lib.getBin libksysguard}/share" ]; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ libksysguard libnl lm_sensors networkmanager-qt ]; + buildInputs = [ + libksysguard + libnl + lm_sensors + networkmanager-qt + ]; } diff --git a/pkgs/desktops/plasma-5/kwallet-pam.nix b/pkgs/desktops/plasma-5/kwallet-pam.nix index dcc139bcafdf05..629b64f79b9e9a 100644 --- a/pkgs/desktops/plasma-5/kwallet-pam.nix +++ b/pkgs/desktops/plasma-5/kwallet-pam.nix @@ -1,9 +1,24 @@ -{ mkDerivation, lib, extra-cmake-modules, pam, socat, libgcrypt, qtbase, kwallet, }: +{ + mkDerivation, + lib, + extra-cmake-modules, + pam, + socat, + libgcrypt, + qtbase, + kwallet, +}: mkDerivation { pname = "kwallet-pam"; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ pam socat libgcrypt qtbase kwallet ]; + buildInputs = [ + pam + socat + libgcrypt + qtbase + kwallet + ]; postPatch = '' sed -i pam_kwallet_init -e "s|socat|${lib.getBin socat}/bin/socat|" ''; diff --git a/pkgs/desktops/plasma-5/kwayland-integration.nix b/pkgs/desktops/plasma-5/kwayland-integration.nix index abe1c866671b96..e97bdf5c0ec47e 100644 --- a/pkgs/desktops/plasma-5/kwayland-integration.nix +++ b/pkgs/desktops/plasma-5/kwayland-integration.nix @@ -1,19 +1,31 @@ -{ mkDerivation -, extra-cmake-modules -, kguiaddons -, kidletime -, kwayland -, kwindowsystem -, qtbase -, wayland-protocols -, wayland-scanner -, wayland +{ + mkDerivation, + extra-cmake-modules, + kguiaddons, + kidletime, + kwayland, + kwindowsystem, + qtbase, + wayland-protocols, + wayland-scanner, + wayland, }: mkDerivation { pname = "kwayland-integration"; - nativeBuildInputs = [ extra-cmake-modules wayland-scanner ]; - buildInputs = [ kguiaddons kidletime kwindowsystem kwayland qtbase wayland-protocols wayland ]; + nativeBuildInputs = [ + extra-cmake-modules + wayland-scanner + ]; + buildInputs = [ + kguiaddons + kidletime + kwindowsystem + kwayland + qtbase + wayland-protocols + wayland + ]; meta = { description = "Integration plugins for various KDE frameworks for the Wayland windowing system"; diff --git a/pkgs/desktops/plasma-5/kwin/default.nix b/pkgs/desktops/plasma-5/kwin/default.nix index 81f588b4d703f4..d271ec0e0b2eea 100644 --- a/pkgs/desktops/plasma-5/kwin/default.nix +++ b/pkgs/desktops/plasma-5/kwin/default.nix @@ -1,68 +1,73 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, wayland-scanner -, fetchpatch -, libepoxy -, lcms2 -, libICE -, libSM -, libcap -, libdrm -, libinput -, libxkbcommon -, mesa -, pipewire -, udev -, wayland -, xcb-util-cursor -, xwayland -, plasma-wayland-protocols -, wayland-protocols -, libxcvt -, qtdeclarative -, qtmultimedia -, qtquickcontrols2 -, qtscript -, qtsensors -, qtvirtualkeyboard -, qtx11extras -, breeze-qt5 -, kactivities -, kcompletion -, kcmutils -, kconfig -, kconfigwidgets -, kcoreaddons -, kcrash -, kdeclarative -, kdecoration -, kglobalaccel -, ki18n -, kiconthemes -, kidletime -, kinit -, kio -, knewstuff -, knotifications -, kpackage -, krunner -, kscreenlocker -, kservice -, kwayland -, kwidgetsaddons -, kwindowsystem -, kxmlgui -, plasma-framework -, libqaccessibilityclient +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + wayland-scanner, + fetchpatch, + libepoxy, + lcms2, + libICE, + libSM, + libcap, + libdrm, + libinput, + libxkbcommon, + mesa, + pipewire, + udev, + wayland, + xcb-util-cursor, + xwayland, + plasma-wayland-protocols, + wayland-protocols, + libxcvt, + qtdeclarative, + qtmultimedia, + qtquickcontrols2, + qtscript, + qtsensors, + qtvirtualkeyboard, + qtx11extras, + breeze-qt5, + kactivities, + kcompletion, + kcmutils, + kconfig, + kconfigwidgets, + kcoreaddons, + kcrash, + kdeclarative, + kdecoration, + kglobalaccel, + ki18n, + kiconthemes, + kidletime, + kinit, + kio, + knewstuff, + knotifications, + kpackage, + krunner, + kscreenlocker, + kservice, + kwayland, + kwidgetsaddons, + kwindowsystem, + kxmlgui, + plasma-framework, + libqaccessibilityclient, }: # TODO (ttuegel): investigate qmlplugindump failure mkDerivation { pname = "kwin"; - nativeBuildInputs = [ extra-cmake-modules kdoctools wayland-scanner ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wayland-scanner + ]; buildInputs = [ libepoxy lcms2 @@ -120,7 +125,10 @@ mkDerivation { libqaccessibilityclient ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postPatch = '' patchShebangs src/effects/strip-effect-metadata.py diff --git a/pkgs/desktops/plasma-5/kwrited.nix b/pkgs/desktops/plasma-5/kwrited.nix index 2ce029be9de8be..02375111f93d66 100644 --- a/pkgs/desktops/plasma-5/kwrited.nix +++ b/pkgs/desktops/plasma-5/kwrited.nix @@ -1,15 +1,23 @@ -{ mkDerivation -, extra-cmake-modules -, kcoreaddons -, kdbusaddons -, ki18n -, knotifications -, kpty -, qtbase +{ + mkDerivation, + extra-cmake-modules, + kcoreaddons, + kdbusaddons, + ki18n, + knotifications, + kpty, + qtbase, }: mkDerivation { pname = "kwrited"; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ kcoreaddons kdbusaddons ki18n knotifications kpty qtbase ]; + buildInputs = [ + kcoreaddons + kdbusaddons + ki18n + knotifications + kpty + qtbase + ]; } diff --git a/pkgs/desktops/plasma-5/layer-shell-qt.nix b/pkgs/desktops/plasma-5/layer-shell-qt.nix index d437c4cf0b75b8..17ea2317c8ad69 100644 --- a/pkgs/desktops/plasma-5/layer-shell-qt.nix +++ b/pkgs/desktops/plasma-5/layer-shell-qt.nix @@ -1,17 +1,27 @@ -{ mkDerivation -, extra-cmake-modules -, kguiaddons -, kidletime -, kwayland -, kwindowsystem -, qtbase -, wayland-scanner -, wayland -, wayland-protocols +{ + mkDerivation, + extra-cmake-modules, + kguiaddons, + kidletime, + kwayland, + kwindowsystem, + qtbase, + wayland-scanner, + wayland, + wayland-protocols, }: mkDerivation { pname = "layer-shell-qt"; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ kguiaddons kidletime kwindowsystem kwayland qtbase wayland-scanner wayland wayland-protocols ]; + buildInputs = [ + kguiaddons + kidletime + kwindowsystem + kwayland + qtbase + wayland-scanner + wayland + wayland-protocols + ]; } diff --git a/pkgs/desktops/plasma-5/libkscreen/default.nix b/pkgs/desktops/plasma-5/libkscreen/default.nix index 961b56736ae5b5..93c17f96e3ef86 100644 --- a/pkgs/desktops/plasma-5/libkscreen/default.nix +++ b/pkgs/desktops/plasma-5/libkscreen/default.nix @@ -1,21 +1,36 @@ -{ mkDerivation -, propagate -, extra-cmake-modules -, wayland-scanner -, kconfig -, kwayland -, plasma-wayland-protocols -, wayland -, libXrandr -, qtx11extras -, qttools +{ + mkDerivation, + propagate, + extra-cmake-modules, + wayland-scanner, + kconfig, + kwayland, + plasma-wayland-protocols, + wayland, + libXrandr, + qtx11extras, + qttools, }: mkDerivation { pname = "libkscreen"; - nativeBuildInputs = [ extra-cmake-modules wayland-scanner ]; - buildInputs = [ kconfig kwayland plasma-wayland-protocols wayland libXrandr qtx11extras qttools ]; - outputs = [ "out" "dev" ]; + nativeBuildInputs = [ + extra-cmake-modules + wayland-scanner + ]; + buildInputs = [ + kconfig + kwayland + plasma-wayland-protocols + wayland + libXrandr + qtx11extras + qttools + ]; + outputs = [ + "out" + "dev" + ]; patches = [ ./libkscreen-backends-path.patch ]; diff --git a/pkgs/desktops/plasma-5/libksysguard/default.nix b/pkgs/desktops/plasma-5/libksysguard/default.nix index 17e9decf454977..1ebd1c38c5a212 100644 --- a/pkgs/desktops/plasma-5/libksysguard/default.nix +++ b/pkgs/desktops/plasma-5/libksysguard/default.nix @@ -1,24 +1,25 @@ -{ mkDerivation -, extra-cmake-modules -, kauth -, kcompletion -, kconfig -, kconfigwidgets -, kcoreaddons -, ki18n -, kiconthemes -, knewstuff -, kservice -, kwidgetsaddons -, kwindowsystem -, plasma-framework -, qtscript -, qtwebengine -, qtx11extras -, libnl -, libpcap -, qtsensors -, lm_sensors +{ + mkDerivation, + extra-cmake-modules, + kauth, + kcompletion, + kconfig, + kconfigwidgets, + kcoreaddons, + ki18n, + kiconthemes, + knewstuff, + kservice, + kwidgetsaddons, + kwindowsystem, + plasma-framework, + qtscript, + qtwebengine, + qtx11extras, + libnl, + libpcap, + qtsensors, + lm_sensors, }: mkDerivation { @@ -48,5 +49,9 @@ mkDerivation { qtsensors lm_sensors ]; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; } diff --git a/pkgs/desktops/plasma-5/milou.nix b/pkgs/desktops/plasma-5/milou.nix index 1045e5f68e522f..faf8352400d029 100644 --- a/pkgs/desktops/plasma-5/milou.nix +++ b/pkgs/desktops/plasma-5/milou.nix @@ -1,14 +1,15 @@ -{ mkDerivation -, extra-cmake-modules -, kcoreaddons -, kdeclarative -, ki18n -, kitemmodels -, krunner -, kservice -, plasma-framework -, qtscript -, qtdeclarative +{ + mkDerivation, + extra-cmake-modules, + kcoreaddons, + kdeclarative, + ki18n, + kitemmodels, + krunner, + kservice, + plasma-framework, + qtscript, + qtdeclarative, }: mkDerivation { diff --git a/pkgs/desktops/plasma-5/oxygen-sounds.nix b/pkgs/desktops/plasma-5/oxygen-sounds.nix index 78fdebc416c8e3..ddb5be869bea94 100644 --- a/pkgs/desktops/plasma-5/oxygen-sounds.nix +++ b/pkgs/desktops/plasma-5/oxygen-sounds.nix @@ -1,5 +1,6 @@ -{ mkDerivation -, extra-cmake-modules +{ + mkDerivation, + extra-cmake-modules, }: mkDerivation { diff --git a/pkgs/desktops/plasma-5/oxygen.nix b/pkgs/desktops/plasma-5/oxygen.nix index a9e4eb18820b97..8308cc82759186 100644 --- a/pkgs/desktops/plasma-5/oxygen.nix +++ b/pkgs/desktops/plasma-5/oxygen.nix @@ -1,19 +1,20 @@ -{ mkDerivation -, extra-cmake-modules -, frameworkintegration -, kcmutils -, kcompletion -, kconfig -, kdecoration -, kguiaddons -, ki18n -, kwidgetsaddons -, kservice -, kwayland -, kwindowsystem -, qtdeclarative -, qtx11extras -, libXdmcp +{ + mkDerivation, + extra-cmake-modules, + frameworkintegration, + kcmutils, + kcompletion, + kconfig, + kdecoration, + kguiaddons, + ki18n, + kwidgetsaddons, + kservice, + kwayland, + kwindowsystem, + qtdeclarative, + qtx11extras, + libXdmcp, }: mkDerivation { @@ -35,5 +36,9 @@ mkDerivation { qtx11extras libXdmcp ]; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; } diff --git a/pkgs/desktops/plasma-5/plank-player.nix b/pkgs/desktops/plasma-5/plank-player.nix index f67cd8728ee7e0..536db96ef3c3d2 100644 --- a/pkgs/desktops/plasma-5/plank-player.nix +++ b/pkgs/desktops/plasma-5/plank-player.nix @@ -1,9 +1,10 @@ -{ mkDerivation -, extra-cmake-modules -, qtquickcontrols2 -, qtmultimedia -, kirigami2 -, ki18n +{ + mkDerivation, + extra-cmake-modules, + qtquickcontrols2, + qtmultimedia, + kirigami2, + ki18n, }: mkDerivation { pname = "plank-player"; diff --git a/pkgs/desktops/plasma-5/plasma-bigscreen.nix b/pkgs/desktops/plasma-5/plasma-bigscreen.nix index f94b49efabc79e..dc6024a1e21038 100644 --- a/pkgs/desktops/plasma-5/plasma-bigscreen.nix +++ b/pkgs/desktops/plasma-5/plasma-bigscreen.nix @@ -1,18 +1,19 @@ -{ mkDerivation -, extra-cmake-modules -, kactivities -, kactivities-stats -, plasma-framework -, ki18n -, kirigami2 -, kdeclarative -, kcmutils -, knotifications -, kio -, kwayland -, kwindowsystem -, plasma-workspace -, qtmultimedia +{ + mkDerivation, + extra-cmake-modules, + kactivities, + kactivities-stats, + plasma-framework, + ki18n, + kirigami2, + kdeclarative, + kcmutils, + knotifications, + kio, + kwayland, + kwindowsystem, + plasma-workspace, + qtmultimedia, }: mkDerivation { pname = "plasma-bigscreen"; @@ -43,5 +44,8 @@ mkDerivation { wrapQtApp $out/bin/plasma-bigscreen-wayland ''; - passthru.providedSessions = [ "plasma-bigscreen-x11" "plasma-bigscreen-wayland" ]; + passthru.providedSessions = [ + "plasma-bigscreen-x11" + "plasma-bigscreen-wayland" + ]; } diff --git a/pkgs/desktops/plasma-5/plasma-browser-integration.nix b/pkgs/desktops/plasma-5/plasma-browser-integration.nix index c951f359c54823..3694282ce348aa 100644 --- a/pkgs/desktops/plasma-5/plasma-browser-integration.nix +++ b/pkgs/desktops/plasma-5/plasma-browser-integration.nix @@ -1,17 +1,18 @@ -{ mkDerivation -, extra-cmake-modules -, qtbase -, kfilemetadata -, kio -, ki18n -, kconfig -, kdbusaddons -, knotifications -, kpurpose -, krunner -, kwindowsystem -, kactivities -, plasma-workspace +{ + mkDerivation, + extra-cmake-modules, + qtbase, + kfilemetadata, + kio, + ki18n, + kconfig, + kdbusaddons, + knotifications, + kpurpose, + krunner, + kwindowsystem, + kactivities, + plasma-workspace, }: mkDerivation { diff --git a/pkgs/desktops/plasma-5/plasma-desktop/default.nix b/pkgs/desktops/plasma-5/plasma-desktop/default.nix index aaf1519ceaeb31..616c52b886e853 100644 --- a/pkgs/desktops/plasma-5/plasma-desktop/default.nix +++ b/pkgs/desktops/plasma-5/plasma-desktop/default.nix @@ -1,62 +1,63 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, wayland-scanner -, boost -, fontconfig -, ibus -, libXcursor -, libXft -, libcanberra_kde -, libpulseaudio -, libxkbfile -, xf86inputevdev -, xf86inputsynaptics -, xinput -, xkeyboard_config -, xorgserver -, util-linux -, wayland -, wayland-protocols -, accounts-qt -, qtdeclarative -, qtquickcontrols -, qtquickcontrols2 -, qtsvg -, qtx11extras -, attica -, baloo -, kaccounts-integration -, kactivities -, kactivities-stats -, kauth -, kcmutils -, kdbusaddons -, kdeclarative -, kded -, kdelibs4support -, kemoticons -, kglobalaccel -, ki18n -, kitemmodels -, knewstuff -, knotifications -, knotifyconfig -, kpeople -, krunner -, kscreenlocker -, kwallet -, kwin -, phonon -, plasma-framework -, plasma-workspace -, qqc2-desktop-style -, xf86inputlibinput -, glib -, gsettings-desktop-schemas -, runCommandLocal -, makeWrapper +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + wayland-scanner, + boost, + fontconfig, + ibus, + libXcursor, + libXft, + libcanberra_kde, + libpulseaudio, + libxkbfile, + xf86inputevdev, + xf86inputsynaptics, + xinput, + xkeyboard_config, + xorgserver, + util-linux, + wayland, + wayland-protocols, + accounts-qt, + qtdeclarative, + qtquickcontrols, + qtquickcontrols2, + qtsvg, + qtx11extras, + attica, + baloo, + kaccounts-integration, + kactivities, + kactivities-stats, + kauth, + kcmutils, + kdbusaddons, + kdeclarative, + kded, + kdelibs4support, + kemoticons, + kglobalaccel, + ki18n, + kitemmodels, + knewstuff, + knotifications, + knotifyconfig, + kpeople, + krunner, + kscreenlocker, + kwallet, + kwin, + phonon, + plasma-framework, + plasma-workspace, + qqc2-desktop-style, + xf86inputlibinput, + glib, + gsettings-desktop-schemas, + runCommandLocal, + makeWrapper, }: let # run gsettings with desktop schemas for using in "kcm_access" kcm @@ -68,7 +69,11 @@ let in mkDerivation { pname = "plasma-desktop"; - nativeBuildInputs = [ extra-cmake-modules kdoctools wayland-scanner ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wayland-scanner + ]; buildInputs = [ boost fontconfig @@ -129,11 +134,10 @@ mkDerivation { ./kcm-access.patch ./no-discover-shortcut.patch ]; - CXXFLAGS = - [ - ''-DNIXPKGS_HWCLOCK=\"${lib.getBin util-linux}/bin/hwclock\"'' - ''-DNIXPKGS_GSETTINGS=\"${gsettings-wrapper}/bin/gsettings\"'' - ]; + CXXFLAGS = [ + ''-DNIXPKGS_HWCLOCK=\"${lib.getBin util-linux}/bin/hwclock\"'' + ''-DNIXPKGS_GSETTINGS=\"${gsettings-wrapper}/bin/gsettings\"'' + ]; postInstall = '' # Display ~/Desktop contents on the desktop by default. sed -i "''${!outputBin}/share/plasma/shells/org.kde.plasma.desktop/contents/defaults" \ diff --git a/pkgs/desktops/plasma-5/plasma-disks.nix b/pkgs/desktops/plasma-5/plasma-disks.nix index 801bf4d978b3b3..8f179c9da1320b 100644 --- a/pkgs/desktops/plasma-5/plasma-disks.nix +++ b/pkgs/desktops/plasma-5/plasma-disks.nix @@ -1,30 +1,34 @@ -{ mkDerivation -, extra-cmake-modules -, kdoctools -, kcmutils -, kconfig -, kdbusaddons -, khtml -, ki18n -, kiconthemes -, kio -, kitemviews -, kservice -, kwindowsystem -, kxmlgui -, qtquickcontrols -, qtquickcontrols2 -, kactivities -, kactivities-stats -, kirigami2 -, kcrash -, plasma-workspace -, systemsettings +{ + mkDerivation, + extra-cmake-modules, + kdoctools, + kcmutils, + kconfig, + kdbusaddons, + khtml, + ki18n, + kiconthemes, + kio, + kitemviews, + kservice, + kwindowsystem, + kxmlgui, + qtquickcontrols, + qtquickcontrols2, + kactivities, + kactivities-stats, + kirigami2, + kcrash, + plasma-workspace, + systemsettings, }: mkDerivation { pname = "plasma-disks"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ kcmutils kconfig @@ -46,5 +50,9 @@ mkDerivation { plasma-workspace systemsettings ]; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; } diff --git a/pkgs/desktops/plasma-5/plasma-firewall.nix b/pkgs/desktops/plasma-5/plasma-firewall.nix index e290b5ed0dc12f..2f19a9c86789db 100644 --- a/pkgs/desktops/plasma-5/plasma-firewall.nix +++ b/pkgs/desktops/plasma-5/plasma-firewall.nix @@ -1,8 +1,9 @@ -{ mkDerivation -, extra-cmake-modules -, python3 -, plasma-framework -, kcmutils +{ + mkDerivation, + extra-cmake-modules, + python3, + plasma-framework, + kcmutils, }: mkDerivation { pname = "plasma-firewall"; diff --git a/pkgs/desktops/plasma-5/plasma-integration/default.nix b/pkgs/desktops/plasma-5/plasma-integration/default.nix index 51a66bcc0d8c83..79390b6ed53c02 100644 --- a/pkgs/desktops/plasma-5/plasma-integration/default.nix +++ b/pkgs/desktops/plasma-5/plasma-integration/default.nix @@ -1,25 +1,29 @@ -{ mkDerivation -, extra-cmake-modules -, wayland-scanner -, breeze-qt5 -, kconfig -, kconfigwidgets -, kiconthemes -, kio -, knotifications -, kwayland -, libXcursor -, qtquickcontrols2 -, wayland -, wayland-protocols -, plasma-wayland-protocols +{ + mkDerivation, + extra-cmake-modules, + wayland-scanner, + breeze-qt5, + kconfig, + kconfigwidgets, + kiconthemes, + kio, + knotifications, + kwayland, + libXcursor, + qtquickcontrols2, + wayland, + wayland-protocols, + plasma-wayland-protocols, }: # TODO: install Noto Sans and Oxygen Mono fonts with plasma-integration mkDerivation { pname = "plasma-integration"; - nativeBuildInputs = [ extra-cmake-modules wayland-scanner ]; + nativeBuildInputs = [ + extra-cmake-modules + wayland-scanner + ]; buildInputs = [ breeze-qt5 kconfig diff --git a/pkgs/desktops/plasma-5/plasma-mobile/default.nix b/pkgs/desktops/plasma-5/plasma-mobile/default.nix index 7409cf2d54dbcf..90acebb762c5a0 100644 --- a/pkgs/desktops/plasma-5/plasma-mobile/default.nix +++ b/pkgs/desktops/plasma-5/plasma-mobile/default.nix @@ -1,37 +1,41 @@ -{ mkDerivation -, extra-cmake-modules -, kdoctools -, libdbusmenu -, pam -, wayland -, appstream -, kdeclarative -, kdelibs4support -, kpeople -, kconfig -, krunner -, kinit -, kirigami-addons -, kwayland -, kwin -, plasma-framework -, telepathy -, libphonenumber -, protobuf -, libqofono -, modemmanager-qt -, networkmanager-qt -, plasma-workspace -, maliit-framework -, maliit-keyboard -, qtfeedback -, qttools +{ + mkDerivation, + extra-cmake-modules, + kdoctools, + libdbusmenu, + pam, + wayland, + appstream, + kdeclarative, + kdelibs4support, + kpeople, + kconfig, + krunner, + kinit, + kirigami-addons, + kwayland, + kwin, + plasma-framework, + telepathy, + libphonenumber, + protobuf, + libqofono, + modemmanager-qt, + networkmanager-qt, + plasma-workspace, + maliit-framework, + maliit-keyboard, + qtfeedback, + qttools, }: mkDerivation { pname = "plasma-mobile"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ appstream libdbusmenu diff --git a/pkgs/desktops/plasma-5/plasma-nano/default.nix b/pkgs/desktops/plasma-5/plasma-nano/default.nix index 50f0d321b394e4..f66163104d6124 100644 --- a/pkgs/desktops/plasma-5/plasma-nano/default.nix +++ b/pkgs/desktops/plasma-5/plasma-nano/default.nix @@ -1,6 +1,7 @@ -{ mkDerivation -, extra-cmake-modules -, plasma-framework +{ + mkDerivation, + extra-cmake-modules, + plasma-framework, }: mkDerivation { diff --git a/pkgs/desktops/plasma-5/plasma-nm/default.nix b/pkgs/desktops/plasma-5/plasma-nm/default.nix index 1915196e4949dc..dc7e8259eeb68e 100644 --- a/pkgs/desktops/plasma-5/plasma-nm/default.nix +++ b/pkgs/desktops/plasma-5/plasma-nm/default.nix @@ -1,40 +1,45 @@ -{ mkDerivation -, substituteAll -, extra-cmake-modules -, kdoctools -, kcmutils -, kcompletion -, kconfigwidgets -, kcoreaddons -, kdbusaddons -, kdeclarative -, ki18n -, kiconthemes -, kinit -, kio -, kitemviews -, knotifications -, kservice -, kwallet -, kwidgetsaddons -, kwindowsystem -, kxmlgui -, plasma-framework -, prison -, solid -, mobile-broadband-provider-info -, openconnect -, openvpn -, modemmanager-qt -, networkmanager-qt -, qca-qt5 -, qtdeclarative -, qttools +{ + mkDerivation, + substituteAll, + extra-cmake-modules, + kdoctools, + kcmutils, + kcompletion, + kconfigwidgets, + kcoreaddons, + kdbusaddons, + kdeclarative, + ki18n, + kiconthemes, + kinit, + kio, + kitemviews, + knotifications, + kservice, + kwallet, + kwidgetsaddons, + kwindowsystem, + kxmlgui, + plasma-framework, + prison, + solid, + mobile-broadband-provider-info, + openconnect, + openvpn, + modemmanager-qt, + networkmanager-qt, + qca-qt5, + qtdeclarative, + qttools, }: mkDerivation { pname = "plasma-nm"; - nativeBuildInputs = [ extra-cmake-modules kdoctools qttools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + qttools + ]; buildInputs = [ kdeclarative ki18n diff --git a/pkgs/desktops/plasma-5/plasma-pa.nix b/pkgs/desktops/plasma-5/plasma-pa.nix index 40a05ed6fe14f8..7b37c98f83375a 100644 --- a/pkgs/desktops/plasma-5/plasma-pa.nix +++ b/pkgs/desktops/plasma-5/plasma-pa.nix @@ -1,25 +1,29 @@ -{ mkDerivation -, extra-cmake-modules -, kdoctools -, kcmutils -, kconfigwidgets -, kcoreaddons -, kdeclarative -, kglobalaccel -, ki18n -, kwindowsystem -, plasma-framework -, qtbase -, qtdeclarative -, glib -, libcanberra-gtk3 -, libpulseaudio -, sound-theme-freedesktop +{ + mkDerivation, + extra-cmake-modules, + kdoctools, + kcmutils, + kconfigwidgets, + kcoreaddons, + kdeclarative, + kglobalaccel, + ki18n, + kwindowsystem, + plasma-framework, + qtbase, + qtdeclarative, + glib, + libcanberra-gtk3, + libpulseaudio, + sound-theme-freedesktop, }: mkDerivation { pname = "plasma-pa"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ glib libcanberra-gtk3 diff --git a/pkgs/desktops/plasma-5/plasma-remotecontrollers.nix b/pkgs/desktops/plasma-5/plasma-remotecontrollers.nix index 46f52a6635afe1..8d52140a00221d 100644 --- a/pkgs/desktops/plasma-5/plasma-remotecontrollers.nix +++ b/pkgs/desktops/plasma-5/plasma-remotecontrollers.nix @@ -1,27 +1,32 @@ -{ mkDerivation -, extra-cmake-modules -, kconfig -, knotifications -, ki18n -, solid -, kcoreaddons -, kdeclarative -, kcmutils -, kpackage -, kscreenlocker -, kwindowsystem -, wayland -, wayland-scanner -, pkg-config -, libcec -, libcec_platform -, libevdev -, plasma-workspace -, plasma-wayland-protocols +{ + mkDerivation, + extra-cmake-modules, + kconfig, + knotifications, + ki18n, + solid, + kcoreaddons, + kdeclarative, + kcmutils, + kpackage, + kscreenlocker, + kwindowsystem, + wayland, + wayland-scanner, + pkg-config, + libcec, + libcec_platform, + libevdev, + plasma-workspace, + plasma-wayland-protocols, }: mkDerivation { pname = "plasma-remotecontrollers"; - nativeBuildInputs = [ extra-cmake-modules pkg-config wayland-scanner ]; + nativeBuildInputs = [ + extra-cmake-modules + pkg-config + wayland-scanner + ]; buildInputs = [ kconfig knotifications diff --git a/pkgs/desktops/plasma-5/plasma-sdk.nix b/pkgs/desktops/plasma-5/plasma-sdk.nix index 88a1968d9d63fe..465284aca798ad 100644 --- a/pkgs/desktops/plasma-5/plasma-sdk.nix +++ b/pkgs/desktops/plasma-5/plasma-sdk.nix @@ -1,27 +1,31 @@ -{ mkDerivation -, extra-cmake-modules -, karchive -, kcompletion -, kconfig -, kconfigwidgets -, kcoreaddons -, kdbusaddons -, kdeclarative -, ki18n -, kiconthemes -, kio -, kitemmodels -, plasma-framework -, kservice -, ktexteditor -, kwidgetsaddons -, kdoctools +{ + mkDerivation, + extra-cmake-modules, + karchive, + kcompletion, + kconfig, + kconfigwidgets, + kcoreaddons, + kdbusaddons, + kdeclarative, + ki18n, + kiconthemes, + kio, + kitemmodels, + plasma-framework, + kservice, + ktexteditor, + kwidgetsaddons, + kdoctools, }: mkDerivation { pname = "plasma-sdk"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ karchive kcompletion diff --git a/pkgs/desktops/plasma-5/plasma-systemmonitor.nix b/pkgs/desktops/plasma-5/plasma-systemmonitor.nix index 44f69995a15dcd..a9d9e9f1596c47 100644 --- a/pkgs/desktops/plasma-5/plasma-systemmonitor.nix +++ b/pkgs/desktops/plasma-5/plasma-systemmonitor.nix @@ -1,24 +1,28 @@ -{ mkDerivation -, extra-cmake-modules -, kdoctools -, qtquickcontrols2 -, kconfig -, kcoreaddons -, ki18n -, kiconthemes -, kitemmodels -, kitemviews -, knewstuff -, libksysguard -, kquickcharts -, ksystemstats -, qqc2-desktop-style -, qtbase +{ + mkDerivation, + extra-cmake-modules, + kdoctools, + qtquickcontrols2, + kconfig, + kcoreaddons, + ki18n, + kiconthemes, + kitemmodels, + kitemviews, + knewstuff, + libksysguard, + kquickcharts, + ksystemstats, + qqc2-desktop-style, + qtbase, }: mkDerivation { pname = "plasma-systemmonitor"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ qtquickcontrols2 kconfig diff --git a/pkgs/desktops/plasma-5/plasma-thunderbolt.nix b/pkgs/desktops/plasma-5/plasma-thunderbolt.nix index c35f1bf097017b..f9908439e9922c 100644 --- a/pkgs/desktops/plasma-5/plasma-thunderbolt.nix +++ b/pkgs/desktops/plasma-5/plasma-thunderbolt.nix @@ -1,8 +1,9 @@ -{ mkDerivation -, extra-cmake-modules -, kcmutils -, kcoreaddons -, bolt +{ + mkDerivation, + extra-cmake-modules, + kcmutils, + kcoreaddons, + bolt, }: mkDerivation { diff --git a/pkgs/desktops/plasma-5/plasma-vault/default.nix b/pkgs/desktops/plasma-5/plasma-vault/default.nix index 3bc432b0d50958..20408af392a907 100644 --- a/pkgs/desktops/plasma-5/plasma-vault/default.nix +++ b/pkgs/desktops/plasma-5/plasma-vault/default.nix @@ -1,15 +1,16 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kactivities -, plasma-framework -, kwindowsystem -, networkmanager-qt -, libksysguard -, encfs -, cryfs -, fuse -, gocryptfs +{ + mkDerivation, + lib, + extra-cmake-modules, + kactivities, + plasma-framework, + kwindowsystem, + networkmanager-qt, + libksysguard, + encfs, + cryfs, + fuse, + gocryptfs, }: mkDerivation { diff --git a/pkgs/desktops/plasma-5/plasma-welcome.nix b/pkgs/desktops/plasma-5/plasma-welcome.nix index 1ae778b3282a92..219db4ea756b29 100644 --- a/pkgs/desktops/plasma-5/plasma-welcome.nix +++ b/pkgs/desktops/plasma-5/plasma-welcome.nix @@ -1,22 +1,23 @@ -{ mkDerivation -, extra-cmake-modules -, qtquickcontrols2 -, accounts-qt -, kaccounts-integration -, kcoreaddons -, kconfigwidgets -, kdbusaddons -, kdeclarative -, ki18n -, kio -, kirigami2 -, knewstuff -, knotifications -, kservice -, kuserfeedback -, kwindowsystem -, plasma-framework -, signond +{ + mkDerivation, + extra-cmake-modules, + qtquickcontrols2, + accounts-qt, + kaccounts-integration, + kcoreaddons, + kconfigwidgets, + kdbusaddons, + kdeclarative, + ki18n, + kio, + kirigami2, + knewstuff, + knotifications, + kservice, + kuserfeedback, + kwindowsystem, + plasma-framework, + signond, }: mkDerivation { diff --git a/pkgs/desktops/plasma-5/plasma-workspace/default.nix b/pkgs/desktops/plasma-5/plasma-workspace/default.nix index 70922f31557c63..41263142c5bd6a 100644 --- a/pkgs/desktops/plasma-5/plasma-workspace/default.nix +++ b/pkgs/desktops/plasma-5/plasma-workspace/default.nix @@ -1,81 +1,91 @@ -{ mkDerivation -, lib -, extra-cmake-modules -, kdoctools -, wayland-scanner -, isocodes -, libdbusmenu -, libSM -, libXcursor -, libXtst -, libXft -, pam -, wayland -, xmessage -, xsetroot -, baloo -, breeze-qt5 -, kactivities -, kactivities-stats -, kcmutils -, kconfig -, kcrash -, kdbusaddons -, kdeclarative -, kdelibs4support -, kdesu -, kglobalaccel -, kidletime -, kinit -, kjsembed -, knewstuff -, knotifyconfig -, kpackage -, kpeople -, krunner -, kscreenlocker -, ktexteditor -, ktextwidgets -, kwallet -, kwayland -, kwin -, kxmlrpcclient -, libkscreen -, libksysguard -, libqalculate -, networkmanager-qt -, phonon -, plasma-framework -, prison -, solid -, kholidays -, kquickcharts -, appstream-qt -, plasma-wayland-protocols -, kpipewire -, libkexiv2 -, kuserfeedback -, qtgraphicaleffects -, qtquickcontrols -, qtquickcontrols2 -, qtscript -, qttools -, qtwayland -, qtx11extras -, qqc2-desktop-style -, polkit-qt -, pipewire -, libdrm -, fetchpatch +{ + mkDerivation, + lib, + extra-cmake-modules, + kdoctools, + wayland-scanner, + isocodes, + libdbusmenu, + libSM, + libXcursor, + libXtst, + libXft, + pam, + wayland, + xmessage, + xsetroot, + baloo, + breeze-qt5, + kactivities, + kactivities-stats, + kcmutils, + kconfig, + kcrash, + kdbusaddons, + kdeclarative, + kdelibs4support, + kdesu, + kglobalaccel, + kidletime, + kinit, + kjsembed, + knewstuff, + knotifyconfig, + kpackage, + kpeople, + krunner, + kscreenlocker, + ktexteditor, + ktextwidgets, + kwallet, + kwayland, + kwin, + kxmlrpcclient, + libkscreen, + libksysguard, + libqalculate, + networkmanager-qt, + phonon, + plasma-framework, + prison, + solid, + kholidays, + kquickcharts, + appstream-qt, + plasma-wayland-protocols, + kpipewire, + libkexiv2, + kuserfeedback, + qtgraphicaleffects, + qtquickcontrols, + qtquickcontrols2, + qtscript, + qttools, + qtwayland, + qtx11extras, + qqc2-desktop-style, + polkit-qt, + pipewire, + libdrm, + fetchpatch, }: -let inherit (lib) getBin getLib; in +let + inherit (lib) getBin getLib; +in mkDerivation { pname = "plasma-workspace"; - passthru.providedSessions = [ "plasma" "plasmawayland" ]; + passthru.providedSessions = [ + "plasma" + "plasmawayland" + ]; - nativeBuildInputs = [ extra-cmake-modules kdoctools wayland-scanner ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wayland-scanner + ]; buildInputs = [ isocodes libdbusmenu @@ -140,7 +150,10 @@ mkDerivation { libdrm ]; propagatedUserEnvPkgs = [ qtgraphicaleffects ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; cmakeFlags = [ ''-DNIXPKGS_BREEZE_WALLPAPERS=${getBin breeze-qt5}/share/wallpapers'' diff --git a/pkgs/desktops/plasma-5/polkit-kde-agent.nix b/pkgs/desktops/plasma-5/polkit-kde-agent.nix index f96c642f7b2879..5f35fc7e4cacee 100644 --- a/pkgs/desktops/plasma-5/polkit-kde-agent.nix +++ b/pkgs/desktops/plasma-5/polkit-kde-agent.nix @@ -1,15 +1,16 @@ -{ mkDerivation -, extra-cmake-modules -, kcoreaddons -, kconfig -, kcrash -, kdbusaddons -, ki18n -, kiconthemes -, knotifications -, kwidgetsaddons -, kwindowsystem -, polkit-qt +{ + mkDerivation, + extra-cmake-modules, + kcoreaddons, + kconfig, + kcrash, + kdbusaddons, + ki18n, + kiconthemes, + knotifications, + kwidgetsaddons, + kwindowsystem, + polkit-qt, }: mkDerivation { @@ -27,5 +28,8 @@ mkDerivation { kwindowsystem polkit-qt ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; } diff --git a/pkgs/desktops/plasma-5/powerdevil.nix b/pkgs/desktops/plasma-5/powerdevil.nix index d60f9701dee6fa..fe24fdf01f0941 100644 --- a/pkgs/desktops/plasma-5/powerdevil.nix +++ b/pkgs/desktops/plasma-5/powerdevil.nix @@ -1,28 +1,32 @@ -{ mkDerivation -, extra-cmake-modules -, kdoctools -, bluez-qt -, kactivities -, kauth -, kconfig -, kdbusaddons -, kglobalaccel -, ki18n -, kidletime -, kio -, knotifyconfig -, kwayland -, libkscreen -, networkmanager-qt -, plasma-workspace -, qtx11extras -, solid -, udev +{ + mkDerivation, + extra-cmake-modules, + kdoctools, + bluez-qt, + kactivities, + kauth, + kconfig, + kdbusaddons, + kglobalaccel, + ki18n, + kidletime, + kio, + knotifyconfig, + kwayland, + libkscreen, + networkmanager-qt, + plasma-workspace, + qtx11extras, + solid, + udev, }: mkDerivation { pname = "powerdevil"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ kconfig kdbusaddons diff --git a/pkgs/desktops/plasma-5/qqc2-breeze-style.nix b/pkgs/desktops/plasma-5/qqc2-breeze-style.nix index fbaf65bf0cf288..36bd9382ad1d14 100644 --- a/pkgs/desktops/plasma-5/qqc2-breeze-style.nix +++ b/pkgs/desktops/plasma-5/qqc2-breeze-style.nix @@ -1,18 +1,22 @@ -{ mkDerivation -, extra-cmake-modules -, kconfig -, kconfigwidgets -, kdoctools -, kguiaddons -, kiconthemes -, kirigami2 -, qtquickcontrols2 -, qtx11extras +{ + mkDerivation, + extra-cmake-modules, + kconfig, + kconfigwidgets, + kdoctools, + kguiaddons, + kiconthemes, + kirigami2, + qtquickcontrols2, + qtx11extras, }: mkDerivation { pname = "qqc2-breeze-style"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ kconfig kconfigwidgets diff --git a/pkgs/desktops/plasma-5/sddm-kcm.nix b/pkgs/desktops/plasma-5/sddm-kcm.nix index 55f934587d0d88..a89ba50418e488 100644 --- a/pkgs/desktops/plasma-5/sddm-kcm.nix +++ b/pkgs/desktops/plasma-5/sddm-kcm.nix @@ -1,22 +1,26 @@ -{ mkDerivation -, extra-cmake-modules -, shared-mime-info -, libpthreadstubs -, libXcursor -, libXdmcp -, qtquickcontrols2 -, qtx11extras -, karchive -, kcmutils -, kdeclarative -, ki18n -, kio -, knewstuff +{ + mkDerivation, + extra-cmake-modules, + shared-mime-info, + libpthreadstubs, + libXcursor, + libXdmcp, + qtquickcontrols2, + qtx11extras, + karchive, + kcmutils, + kdeclarative, + ki18n, + kio, + knewstuff, }: mkDerivation { pname = "sddm-kcm"; - nativeBuildInputs = [ extra-cmake-modules shared-mime-info ]; + nativeBuildInputs = [ + extra-cmake-modules + shared-mime-info + ]; buildInputs = [ libpthreadstubs libXcursor diff --git a/pkgs/desktops/plasma-5/systemsettings.nix b/pkgs/desktops/plasma-5/systemsettings.nix index b12720811483f9..36303874418616 100644 --- a/pkgs/desktops/plasma-5/systemsettings.nix +++ b/pkgs/desktops/plasma-5/systemsettings.nix @@ -1,30 +1,34 @@ -{ mkDerivation -, extra-cmake-modules -, kdoctools -, kcmutils -, kconfig -, kdbusaddons -, khtml -, ki18n -, kiconthemes -, kio -, kitemviews -, kservice -, kwindowsystem -, kxmlgui -, qtquickcontrols -, qtquickcontrols2 -, kactivities -, kactivities-stats -, kirigami2 -, kirigami-addons -, kcrash -, plasma-workspace +{ + mkDerivation, + extra-cmake-modules, + kdoctools, + kcmutils, + kconfig, + kdbusaddons, + khtml, + ki18n, + kiconthemes, + kio, + kitemviews, + kservice, + kwindowsystem, + kxmlgui, + qtquickcontrols, + qtquickcontrols2, + kactivities, + kactivities-stats, + kirigami2, + kirigami-addons, + kcrash, + plasma-workspace, }: mkDerivation { pname = "systemsettings"; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; buildInputs = [ kcmutils kconfig @@ -46,6 +50,10 @@ mkDerivation { kcrash plasma-workspace ]; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; meta.mainProgram = "systemsettings5"; } diff --git a/pkgs/desktops/plasma-5/xdg-desktop-portal-kde.nix b/pkgs/desktops/plasma-5/xdg-desktop-portal-kde.nix index e5822cb898032f..4c218b24592d6e 100644 --- a/pkgs/desktops/plasma-5/xdg-desktop-portal-kde.nix +++ b/pkgs/desktops/plasma-5/xdg-desktop-portal-kde.nix @@ -1,32 +1,38 @@ -{ mkDerivation -, extra-cmake-modules -, gettext -, kdoctools -, wayland-scanner -, cups -, libepoxy -, mesa -, pcre -, pipewire -, wayland -, wayland-protocols -, kcoreaddons -, knotifications -, kwayland -, kwidgetsaddons -, kwindowsystem -, kirigami2 -, kdeclarative -, plasma-framework -, plasma-wayland-protocols -, plasma-workspace -, kio -, qtbase +{ + mkDerivation, + extra-cmake-modules, + gettext, + kdoctools, + wayland-scanner, + cups, + libepoxy, + mesa, + pcre, + pipewire, + wayland, + wayland-protocols, + kcoreaddons, + knotifications, + kwayland, + kwidgetsaddons, + kwindowsystem, + kirigami2, + kdeclarative, + plasma-framework, + plasma-wayland-protocols, + plasma-workspace, + kio, + qtbase, }: mkDerivation { pname = "xdg-desktop-portal-kde"; - nativeBuildInputs = [ extra-cmake-modules gettext kdoctools wayland-scanner ]; + nativeBuildInputs = [ + extra-cmake-modules + gettext + kdoctools + wayland-scanner + ]; buildInputs = [ cups libepoxy diff --git a/pkgs/desktops/rox/rox-filer/default.nix b/pkgs/desktops/rox/rox-filer/default.nix index 0d7b0acaff5786..b8d0b1c5b3cc73 100644 --- a/pkgs/desktops/rox/rox-filer/default.nix +++ b/pkgs/desktops/rox/rox-filer/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, pkg-config -, wrapGAppsHook3 -, libxml2 -, gtk -, libSM -, shared-mime-info +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + wrapGAppsHook3, + libxml2, + gtk, + libSM, + shared-mime-info, }: stdenv.mkDerivation rec { @@ -23,7 +24,12 @@ stdenv.mkDerivation rec { pkg-config wrapGAppsHook3 ]; - buildInputs = [ libxml2 gtk shared-mime-info libSM ]; + buildInputs = [ + libxml2 + gtk + shared-mime-info + libSM + ]; NIX_LDFLAGS = "-lm"; patches = [ @@ -91,7 +97,10 @@ stdenv.mkDerivation rec { description = "Fast, lightweight, gtk2 file manager"; mainProgram = "rox"; homepage = "http://rox.sourceforge.net/desktop"; - license = with licenses; [ gpl2 lgpl2 ]; + license = with licenses; [ + gpl2 + lgpl2 + ]; platforms = platforms.linux; maintainers = [ maintainers.eleanor ]; }; diff --git a/pkgs/desktops/xfce/applications/catfish/default.nix b/pkgs/desktops/xfce/applications/catfish/default.nix index 520835bf80d73d..5eeec6ccfa1e27 100644 --- a/pkgs/desktops/xfce/applications/catfish/default.nix +++ b/pkgs/desktops/xfce/applications/catfish/default.nix @@ -1,17 +1,18 @@ -{ lib -, fetchFromGitLab -, gitUpdater -, file -, which -, intltool -, gobject-introspection -, findutils -, xdg-utils -, dconf -, gtk3 -, python3Packages -, xfconf -, wrapGAppsHook3 +{ + lib, + fetchFromGitLab, + gitUpdater, + file, + which, + intltool, + gobject-introspection, + findutils, + xdg-utils, + dconf, + gtk3, + python3Packages, + xfconf, + wrapGAppsHook3, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/desktops/xfce/applications/gigolo/default.nix b/pkgs/desktops/xfce/applications/gigolo/default.nix index cb885ad3fde48c..4a2edb70f230ca 100644 --- a/pkgs/desktops/xfce/applications/gigolo/default.nix +++ b/pkgs/desktops/xfce/applications/gigolo/default.nix @@ -1,4 +1,9 @@ -{ lib, mkXfceDerivation, gtk3, glib }: +{ + lib, + mkXfceDerivation, + gtk3, + glib, +}: mkXfceDerivation { category = "apps"; @@ -8,7 +13,10 @@ mkXfceDerivation { sha256 = "sha256-dxaFuKbSqhj/l5JV31cI+XzgdghfbcVwVtwmRiZeff8="; - buildInputs = [ gtk3 glib ]; + buildInputs = [ + gtk3 + glib + ]; meta = with lib; { description = "Frontend to easily manage connections to remote filesystems"; diff --git a/pkgs/desktops/xfce/applications/mousepad/default.nix b/pkgs/desktops/xfce/applications/mousepad/default.nix index 3bb9389c1e25c2..310f863b865897 100644 --- a/pkgs/desktops/xfce/applications/mousepad/default.nix +++ b/pkgs/desktops/xfce/applications/mousepad/default.nix @@ -1,14 +1,15 @@ -{ lib -, mkXfceDerivation -, gobject-introspection -, glib -, gtk3 -, gtksourceview4 -, gspell -, libxfce4ui -, xfconf -, enablePolkit ? true -, polkit +{ + lib, + mkXfceDerivation, + gobject-introspection, + glib, + gtk3, + gtksourceview4, + gspell, + libxfce4ui, + xfconf, + enablePolkit ? true, + polkit, }: mkXfceDerivation { @@ -21,16 +22,18 @@ mkXfceDerivation { nativeBuildInputs = [ gobject-introspection ]; - buildInputs = [ - glib - gtk3 - gtksourceview4 - gspell - libxfce4ui # for shortcut plugin - xfconf # required by libxfce4kbd-private-3 - ] ++ lib.optionals enablePolkit [ - polkit - ]; + buildInputs = + [ + glib + gtk3 + gtksourceview4 + gspell + libxfce4ui # for shortcut plugin + xfconf # required by libxfce4kbd-private-3 + ] + ++ lib.optionals enablePolkit [ + polkit + ]; # Use the GSettings keyfile backend rather than DConf configureFlags = [ "--enable-keyfile-settings" ]; diff --git a/pkgs/desktops/xfce/applications/orage/default.nix b/pkgs/desktops/xfce/applications/orage/default.nix index 130eb8464aeb26..d5ca6ec37c4c42 100644 --- a/pkgs/desktops/xfce/applications/orage/default.nix +++ b/pkgs/desktops/xfce/applications/orage/default.nix @@ -1,11 +1,12 @@ -{ lib -, mkXfceDerivation -, gtk3 -, libical -, libnotify -, libxfce4ui -, popt -, tzdata +{ + lib, + mkXfceDerivation, + gtk3, + libical, + libnotify, + libxfce4ui, + popt, + tzdata, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/applications/parole/default.nix b/pkgs/desktops/xfce/applications/parole/default.nix index 41286052db41a6..4d2f5bfe80bf82 100644 --- a/pkgs/desktops/xfce/applications/parole/default.nix +++ b/pkgs/desktops/xfce/applications/parole/default.nix @@ -1,15 +1,16 @@ -{ lib -, mkXfceDerivation -, dbus -, dbus-glib -, gst_all_1 -, gtk3 -, libnotify -, libX11 -, libxfce4ui -, libxfce4util -, taglib -, xfconf +{ + lib, + mkXfceDerivation, + dbus, + dbus-glib, + gst_all_1, + gtk3, + libnotify, + libX11, + libxfce4ui, + libxfce4util, + taglib, + xfconf, }: # Doesn't seem to find H.264 codec even though built with gst-plugins-bad. diff --git a/pkgs/desktops/xfce/applications/ristretto/default.nix b/pkgs/desktops/xfce/applications/ristretto/default.nix index 0a6a622e777cef..389fe02773bee3 100644 --- a/pkgs/desktops/xfce/applications/ristretto/default.nix +++ b/pkgs/desktops/xfce/applications/ristretto/default.nix @@ -1,15 +1,16 @@ -{ lib -, mkXfceDerivation -, gtk3 -, glib -, gnome -, libexif -, libjxl -, librsvg -, libxfce4ui -, libxfce4util -, webp-pixbuf-loader -, xfconf +{ + lib, + mkXfceDerivation, + gtk3, + glib, + gnome, + libexif, + libjxl, + librsvg, + libxfce4ui, + libxfce4util, + webp-pixbuf-loader, + xfconf, }: mkXfceDerivation { @@ -34,13 +35,15 @@ mkXfceDerivation { postInstall = '' # Pull in JXL and WebP support for ristretto. # In postInstall to run before gappsWrapperArgsHook. - export GDK_PIXBUF_MODULE_FILE="${gnome._gdkPixbufCacheBuilder_DO_NOT_USE { - extraLoaders = [ - libjxl - librsvg - webp-pixbuf-loader - ]; - }}" + export GDK_PIXBUF_MODULE_FILE="${ + gnome._gdkPixbufCacheBuilder_DO_NOT_USE { + extraLoaders = [ + libjxl + librsvg + webp-pixbuf-loader + ]; + } + }" ''; meta = with lib; { diff --git a/pkgs/desktops/xfce/applications/xfce4-dict/default.nix b/pkgs/desktops/xfce/applications/xfce4-dict/default.nix index b8a9f1f68277df..40d9478f155983 100644 --- a/pkgs/desktops/xfce/applications/xfce4-dict/default.nix +++ b/pkgs/desktops/xfce/applications/xfce4-dict/default.nix @@ -1,10 +1,11 @@ -{ lib -, mkXfceDerivation -, glib -, gtk3 -, libxfce4ui -, libxfce4util -, xfce4-panel +{ + lib, + mkXfceDerivation, + glib, + gtk3, + libxfce4ui, + libxfce4util, + xfce4-panel, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/applications/xfce4-notifyd/default.nix b/pkgs/desktops/xfce/applications/xfce4-notifyd/default.nix index 1ef2a37f7b8c78..f0259878430a9b 100644 --- a/pkgs/desktops/xfce/applications/xfce4-notifyd/default.nix +++ b/pkgs/desktops/xfce/applications/xfce4-notifyd/default.nix @@ -1,17 +1,18 @@ -{ lib -, mkXfceDerivation -, dbus -, glib -, gtk3 -, gtk-layer-shell -, libcanberra-gtk3 -, libnotify -, libX11 -, libxfce4ui -, libxfce4util -, sqlite -, xfce4-panel -, xfconf +{ + lib, + mkXfceDerivation, + dbus, + glib, + gtk3, + gtk-layer-shell, + libcanberra-gtk3, + libnotify, + libX11, + libxfce4ui, + libxfce4util, + sqlite, + xfce4-panel, + xfconf, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/applications/xfce4-panel-profiles/default.nix b/pkgs/desktops/xfce/applications/xfce4-panel-profiles/default.nix index 2e25e686ccd561..b11057c5b56616 100644 --- a/pkgs/desktops/xfce/applications/xfce4-panel-profiles/default.nix +++ b/pkgs/desktops/xfce/applications/xfce4-panel-profiles/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitLab -, gettext -, gobject-introspection -, intltool -, wrapGAppsHook3 -, glib -, gtk3 -, libxfce4ui -, python3 -, gitUpdater +{ + stdenv, + lib, + fetchFromGitLab, + gettext, + gobject-introspection, + intltool, + wrapGAppsHook3, + glib, + gtk3, + libxfce4ui, + python3, + gitUpdater, }: let diff --git a/pkgs/desktops/xfce/applications/xfce4-screensaver/default.nix b/pkgs/desktops/xfce/applications/xfce4-screensaver/default.nix index 8422f6661e02f5..6d956e14b29aad 100644 --- a/pkgs/desktops/xfce/applications/xfce4-screensaver/default.nix +++ b/pkgs/desktops/xfce/applications/xfce4-screensaver/default.nix @@ -1,21 +1,22 @@ -{ mkXfceDerivation -, gobject-introspection -, dbus-glib -, garcon -, glib -, gtk3 -, libX11 -, libXScrnSaver -, libXrandr -, libwnck -, libxfce4ui -, libxfce4util -, libxklavier -, pam -, python3 -, systemd -, xfconf -, lib +{ + mkXfceDerivation, + gobject-introspection, + dbus-glib, + garcon, + glib, + gtk3, + libX11, + libXScrnSaver, + libXrandr, + libwnck, + libxfce4ui, + libxfce4util, + libxklavier, + pam, + python3, + systemd, + xfconf, + lib, }: let diff --git a/pkgs/desktops/xfce/applications/xfce4-screenshooter/default.nix b/pkgs/desktops/xfce/applications/xfce4-screenshooter/default.nix index 675e2b6891b442..bf7994ffe3ea62 100644 --- a/pkgs/desktops/xfce/applications/xfce4-screenshooter/default.nix +++ b/pkgs/desktops/xfce/applications/xfce4-screenshooter/default.nix @@ -1,22 +1,23 @@ -{ lib -, mkXfceDerivation -, wayland-scanner -, exo -, gtk3 -, libX11 -, libXext -, libXfixes -, libXtst -, libxfce4ui -, libxfce4util -, wayland -, wlr-protocols -, xfce4-panel -, xfconf -, curl -, zenity -, jq -, xclip +{ + lib, + mkXfceDerivation, + wayland-scanner, + exo, + gtk3, + libX11, + libXext, + libXfixes, + libXtst, + libxfce4ui, + libxfce4util, + wayland, + wlr-protocols, + xfce4-panel, + xfconf, + curl, + zenity, + jq, + xclip, }: mkXfceDerivation { @@ -50,7 +51,14 @@ mkXfceDerivation { # For Imgur upload action # https://gitlab.xfce.org/apps/xfce4-screenshooter/-/merge_requests/51 gappsWrapperArgs+=( - --prefix PATH : ${lib.makeBinPath [ curl zenity jq xclip ]} + --prefix PATH : ${ + lib.makeBinPath [ + curl + zenity + jq + xclip + ] + } ) ''; diff --git a/pkgs/desktops/xfce/applications/xfce4-taskmanager/default.nix b/pkgs/desktops/xfce/applications/xfce4-taskmanager/default.nix index f6dfcec8be7fcf..f4f65792ea93ae 100644 --- a/pkgs/desktops/xfce/applications/xfce4-taskmanager/default.nix +++ b/pkgs/desktops/xfce/applications/xfce4-taskmanager/default.nix @@ -1,13 +1,14 @@ -{ lib -, mkXfceDerivation -, exo -, glib -, gtk3 -, libxfce4ui -, xfconf -, libwnck -, libX11 -, libXmu +{ + lib, + mkXfceDerivation, + exo, + glib, + gtk3, + libxfce4ui, + xfconf, + libwnck, + libX11, + libXmu, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/applications/xfce4-terminal/default.nix b/pkgs/desktops/xfce/applications/xfce4-terminal/default.nix index d20bfd4c28e1e9..3cab5bcf8ddc77 100644 --- a/pkgs/desktops/xfce/applications/xfce4-terminal/default.nix +++ b/pkgs/desktops/xfce/applications/xfce4-terminal/default.nix @@ -1,17 +1,18 @@ -{ lib -, mkXfceDerivation -, glib -, gtk3 -, gtk-layer-shell -, libX11 -, libxfce4ui -, vte -, xfconf -, pcre2 -, libxslt -, docbook_xml_dtd_45 -, docbook_xsl -, nixosTests +{ + lib, + mkXfceDerivation, + glib, + gtk3, + gtk-layer-shell, + libX11, + libxfce4ui, + vte, + xfconf, + pcre2, + libxslt, + docbook_xml_dtd_45, + docbook_xsl, + nixosTests, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/applications/xfce4-volumed-pulse/default.nix b/pkgs/desktops/xfce/applications/xfce4-volumed-pulse/default.nix index 3ae96bed983f51..3195b0b33c762b 100644 --- a/pkgs/desktops/xfce/applications/xfce4-volumed-pulse/default.nix +++ b/pkgs/desktops/xfce/applications/xfce4-volumed-pulse/default.nix @@ -1,4 +1,12 @@ -{ lib, mkXfceDerivation, gtk3, libnotify, libpulseaudio, keybinder3, xfconf }: +{ + lib, + mkXfceDerivation, + gtk3, + libnotify, + libpulseaudio, + keybinder3, + xfconf, +}: mkXfceDerivation { category = "apps"; @@ -7,7 +15,13 @@ mkXfceDerivation { sha256 = "sha256-NDIJRjKV5aoM2sLhZ6WmoynOc4yz55KpuiTJDMLMA5Y="; - buildInputs = [ gtk3 libnotify libpulseaudio keybinder3 xfconf ]; + buildInputs = [ + gtk3 + libnotify + libpulseaudio + keybinder3 + xfconf + ]; meta = with lib; { description = "Volume keys control daemon for Xfce using pulseaudio"; diff --git a/pkgs/desktops/xfce/applications/xfdashboard/default.nix b/pkgs/desktops/xfce/applications/xfdashboard/default.nix index fd92e2c92e8f7e..697df1247e4cc6 100644 --- a/pkgs/desktops/xfce/applications/xfdashboard/default.nix +++ b/pkgs/desktops/xfce/applications/xfdashboard/default.nix @@ -1,18 +1,19 @@ -{ lib -, mkXfceDerivation -, clutter -, libXcomposite -, libXinerama -, libXdamage -, libX11 -, libwnck -, libxfce4ui -, libxfce4util -, garcon -, xfconf -, gtk3 -, glib -, dbus-glib +{ + lib, + mkXfceDerivation, + clutter, + libXcomposite, + libXinerama, + libXdamage, + libX11, + libwnck, + libxfce4ui, + libxfce4util, + garcon, + xfconf, + gtk3, + glib, + dbus-glib, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/applications/xfmpc/default.nix b/pkgs/desktops/xfce/applications/xfmpc/default.nix index a8322c7e51bf10..85088a61937e65 100644 --- a/pkgs/desktops/xfce/applications/xfmpc/default.nix +++ b/pkgs/desktops/xfce/applications/xfmpc/default.nix @@ -1,11 +1,12 @@ -{ lib -, mkXfceDerivation -, vala -, libxfce4util -, libxfce4ui -, gtk3 -, glib -, libmpd +{ + lib, + mkXfceDerivation, + vala, + libxfce4util, + libxfce4ui, + gtk3, + glib, + libmpd, }: mkXfceDerivation rec { diff --git a/pkgs/desktops/xfce/art/xfce4-icon-theme/default.nix b/pkgs/desktops/xfce/art/xfce4-icon-theme/default.nix index 2e0b23f5c848a1..721218c47d90bd 100644 --- a/pkgs/desktops/xfce/art/xfce4-icon-theme/default.nix +++ b/pkgs/desktops/xfce/art/xfce4-icon-theme/default.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, fetchurl, pkg-config, intltool, gtk3, gnome-icon-theme, tango-icon-theme, hicolor-icon-theme, httpTwoLevelsUpdater }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + gtk3, + gnome-icon-theme, + tango-icon-theme, + hicolor-icon-theme, + httpTwoLevelsUpdater, +}: stdenv.mkDerivation rec { - pname = "xfce4-icon-theme"; + pname = "xfce4-icon-theme"; version = "4.4.3"; src = fetchurl { diff --git a/pkgs/desktops/xfce/art/xfwm4-themes/default.nix b/pkgs/desktops/xfce/art/xfwm4-themes/default.nix index 6eda846ee3116f..61ee66a3b5c98e 100644 --- a/pkgs/desktops/xfce/art/xfwm4-themes/default.nix +++ b/pkgs/desktops/xfce/art/xfwm4-themes/default.nix @@ -1,7 +1,12 @@ -{ lib, stdenv, fetchurl, httpTwoLevelsUpdater }: +{ + lib, + stdenv, + fetchurl, + httpTwoLevelsUpdater, +}: stdenv.mkDerivation rec { - pname = "xfwm4-themes"; + pname = "xfwm4-themes"; version = "4.10.0"; src = fetchurl { diff --git a/pkgs/desktops/xfce/core/thunar/wrapper.nix b/pkgs/desktops/xfce/core/thunar/wrapper.nix index 43531f20123292..925f8487ee0b3b 100644 --- a/pkgs/desktops/xfce/core/thunar/wrapper.nix +++ b/pkgs/desktops/xfce/core/thunar/wrapper.nix @@ -1,4 +1,10 @@ -{ lib, makeWrapper, symlinkJoin, thunar, thunarPlugins }: +{ + lib, + makeWrapper, + symlinkJoin, + thunar, + thunarPlugins, +}: symlinkJoin { name = "thunar-with-plugins-${thunar.version}"; @@ -32,10 +38,17 @@ symlinkJoin { ''; meta = with lib; { - inherit (thunar.meta) homepage license platforms maintainers; - - description = thunar.meta.description + optionalString - (0 != length thunarPlugins) - " (with plugins: ${concatStringsSep ", " (map (x: x.name) thunarPlugins)})"; + inherit (thunar.meta) + homepage + license + platforms + maintainers + ; + + description = + thunar.meta.description + + + optionalString (0 != length thunarPlugins) + " (with plugins: ${concatStringsSep ", " (map (x: x.name) thunarPlugins)})"; }; } diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-battery-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-battery-plugin/default.nix index e2a28c8bad8bee..24b1d3e81e5cf9 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-battery-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-battery-plugin/default.nix @@ -1,11 +1,12 @@ -{ lib -, mkXfceDerivation -, glib -, gtk3 -, libxfce4ui -, libxfce4util -, xfce4-panel -, xfconf +{ + lib, + mkXfceDerivation, + glib, + gtk3, + libxfce4ui, + libxfce4util, + xfce4-panel, + xfconf, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-clipman-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-clipman-plugin/default.nix index 74ff2d171044b4..6f64560ac37026 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-clipman-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-clipman-plugin/default.nix @@ -1,17 +1,18 @@ -{ lib -, mkXfceDerivation -, wayland-scanner -, glib -, gtk3 -, libX11 -, libXtst -, libxfce4ui -, libxfce4util -, qrencode -, xfce4-panel -, xfconf -, wayland -, wlr-protocols +{ + lib, + mkXfceDerivation, + wayland-scanner, + glib, + gtk3, + libX11, + libXtst, + libxfce4ui, + libxfce4util, + qrencode, + xfce4-panel, + xfconf, + wayland, + wlr-protocols, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-cpufreq-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-cpufreq-plugin/default.nix index bba028bfe5368e..b65538b57b5c2a 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-cpufreq-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-cpufreq-plugin/default.nix @@ -1,4 +1,12 @@ -{ lib, mkXfceDerivation, gtk3, libxfce4ui, libxfce4util, xfce4-panel, xfconf }: +{ + lib, + mkXfceDerivation, + gtk3, + libxfce4ui, + libxfce4util, + xfce4-panel, + xfconf, +}: mkXfceDerivation { category = "panel-plugins"; @@ -6,7 +14,13 @@ mkXfceDerivation { version = "1.2.8"; sha256 = "sha256-wEVv3zBS9PRLOMusFPzTnffVDvTaBnTCyGjstJRQRCo="; - buildInputs = [ gtk3 libxfce4ui libxfce4util xfce4-panel xfconf ]; + buildInputs = [ + gtk3 + libxfce4ui + libxfce4util + xfce4-panel + xfconf + ]; meta = with lib; { description = "CPU Freq load plugin for Xfce panel"; diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-cpugraph-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-cpugraph-plugin/default.nix index f138d84189666f..080a287997fe22 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-cpugraph-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-cpugraph-plugin/default.nix @@ -1,19 +1,20 @@ -{ lib -, mkXfceDerivation -, exo -, glib -, gtk3 -, libXtst -, libxfce4ui -, libxfce4util -, xfce4-panel -, xfconf -, xorgproto +{ + lib, + mkXfceDerivation, + exo, + glib, + gtk3, + libXtst, + libxfce4ui, + libxfce4util, + xfce4-panel, + xfconf, + xorgproto, }: mkXfceDerivation rec { category = "panel-plugins"; - pname = "xfce4-cpugraph-plugin"; + pname = "xfce4-cpugraph-plugin"; version = "1.2.10"; rev-prefix = "xfce4-cpugraph-plugin-"; odd-unstable = false; diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-datetime-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-datetime-plugin/default.nix index eaf090c348cff9..641ea795329ec7 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-datetime-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-datetime-plugin/default.nix @@ -1,9 +1,10 @@ -{ mkXfceDerivation -, lib -, intltool -, libxfce4ui -, xfce4-panel -, gettext +{ + mkXfceDerivation, + lib, + intltool, + libxfce4ui, + xfce4-panel, + gettext, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-dockbarx-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-dockbarx-plugin/default.nix index 8e8da34856386a..3f0d0e559318da 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-dockbarx-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-dockbarx-plugin/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, bash -, cmake -, dockbarx -, gobject-introspection -, keybinder3 -, pkg-config -, python3Packages -, wrapGAppsHook3 -, xfce +{ + lib, + stdenv, + fetchFromGitHub, + bash, + cmake, + dockbarx, + gobject-introspection, + keybinder3, + pkg-config, + python3Packages, + wrapGAppsHook3, + xfce, }: stdenv.mkDerivation rec { @@ -41,8 +42,7 @@ stdenv.mkDerivation rec { python3Packages.python xfce.xfce4-panel xfce.xfconf - ] - ++ pythonPath; + ] ++ pythonPath; postPatch = '' # We execute the wrapped xfce4-panel-plug directly. diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-eyes-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-eyes-plugin/default.nix index cbf526e3d98be3..646027ad2bb304 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-eyes-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-eyes-plugin/default.nix @@ -1,20 +1,22 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, intltool -, libxfce4util -, xfce4-panel -, libxfce4ui -, xfconf -, gtk3 -, gitUpdater +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + libxfce4util, + xfce4-panel, + libxfce4ui, + xfconf, + gtk3, + gitUpdater, }: let category = "panel-plugins"; -in stdenv.mkDerivation rec { - pname = "xfce4-eyes-plugin"; +in +stdenv.mkDerivation rec { + pname = "xfce4-eyes-plugin"; version = "4.6.0"; src = fetchurl { diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-fsguard-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-fsguard-plugin/default.nix index 3abc25669e6be9..7b0b5efd4a5dc0 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-fsguard-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-fsguard-plugin/default.nix @@ -1,20 +1,22 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, intltool -, libxfce4util -, xfce4-panel -, libxfce4ui -, xfconf -, glib -, gtk3 -, gitUpdater +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + libxfce4util, + xfce4-panel, + libxfce4ui, + xfconf, + glib, + gtk3, + gitUpdater, }: let category = "panel-plugins"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "xfce4-fsguard-plugin"; version = "1.1.3"; diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-genmon-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-genmon-plugin/default.nix index 2219ce754af8b7..09d07cfef3140e 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-genmon-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-genmon-plugin/default.nix @@ -1,20 +1,22 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, intltool -, libxfce4util -, xfce4-panel -, xfconf -, libxfce4ui -, gtk3 -, gitUpdater +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + libxfce4util, + xfce4-panel, + xfconf, + libxfce4ui, + gtk3, + gitUpdater, }: let category = "panel-plugins"; -in stdenv.mkDerivation rec { - pname = "xfce4-genmon-plugin"; +in +stdenv.mkDerivation rec { + pname = "xfce4-genmon-plugin"; version = "4.2.0"; src = fetchurl { diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-i3-workspaces-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-i3-workspaces-plugin/default.nix index 5a6794bf79af24..a1812ca7dffe5c 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-i3-workspaces-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-i3-workspaces-plugin/default.nix @@ -1,6 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, intltool, gtk3 -, libxfce4ui, libxfce4util, xfce4-dev-tools, xfce4-panel -, i3ipc-glib +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + intltool, + gtk3, + libxfce4ui, + libxfce4util, + xfce4-dev-tools, + xfce4-panel, + i3ipc-glib, }: stdenv.mkDerivation rec { @@ -26,7 +35,7 @@ stdenv.mkDerivation rec { libxfce4util xfce4-panel i3ipc-glib - ]; + ]; enableParallelBuilding = true; diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-mailwatch-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-mailwatch-plugin/default.nix index 0a3e4029b347ac..56c1a1ed732fc9 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-mailwatch-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-mailwatch-plugin/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, intltool -, xfce4-panel -, libxfce4ui -, libxfce4util -, exo -, glib -, gtk3 -, gnutls -, libgcrypt -, gitUpdater +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + xfce4-panel, + libxfce4ui, + libxfce4util, + exo, + glib, + gtk3, + gnutls, + libgcrypt, + gitUpdater, }: let diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-mpc-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-mpc-plugin/default.nix index 6a1a750096f955..e46b06be6ac423 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-mpc-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-mpc-plugin/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, intltool -, libxfce4util -, xfce4-panel -, libxfce4ui -, glib -, gtk3 -, gitUpdater +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + libxfce4util, + xfce4-panel, + libxfce4ui, + glib, + gtk3, + gitUpdater, }: let diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-netload-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-netload-plugin/default.nix index e1baf7137e4b1f..d27bb2517f1d2c 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-netload-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-netload-plugin/default.nix @@ -1,10 +1,11 @@ -{ lib -, mkXfceDerivation -, glib -, gtk3 -, libxfce4ui -, libxfce4util -, xfce4-panel +{ + lib, + mkXfceDerivation, + glib, + gtk3, + libxfce4ui, + libxfce4util, + xfce4-panel, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-systemload-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-systemload-plugin/default.nix index 9e1518f7be0a25..245391eb4f5789 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-systemload-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-systemload-plugin/default.nix @@ -1,18 +1,20 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, intltool -, xfce4-panel -, libxfce4ui -, xfconf -, gitUpdater +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + xfce4-panel, + libxfce4ui, + xfconf, + gitUpdater, }: let category = "panel-plugins"; -in stdenv.mkDerivation rec { - pname = "xfce4-systemload-plugin"; +in +stdenv.mkDerivation rec { + pname = "xfce4-systemload-plugin"; version = "1.3.2"; src = fetchurl { diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-time-out-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-time-out-plugin/default.nix index a5b656650170af..9b3c6b0c558fd6 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-time-out-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-time-out-plugin/default.nix @@ -1,11 +1,12 @@ -{ lib -, mkXfceDerivation -, glib -, gtk3 -, libxfce4ui -, libxfce4util -, xfce4-panel -, xfconf +{ + lib, + mkXfceDerivation, + glib, + gtk3, + libxfce4ui, + libxfce4util, + xfce4-panel, + xfconf, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-timer-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-timer-plugin/default.nix index 997377f42b3e2e..e7cec4e64ccbef 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-timer-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-timer-plugin/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, intltool -, libxfce4util -, xfce4-panel -, libxfce4ui -, glib -, gtk3 -, hicolor-icon-theme -, gitUpdater +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + libxfce4util, + xfce4-panel, + libxfce4ui, + glib, + gtk3, + hicolor-icon-theme, + gitUpdater, }: let diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-verve-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-verve-plugin/default.nix index 8683c8cb209184..4fd508b900099a 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-verve-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-verve-plugin/default.nix @@ -1,11 +1,12 @@ -{ lib -, mkXfceDerivation -, glib -, gtk3 -, libxfce4ui -, libxfce4util -, pcre2 -, xfce4-panel +{ + lib, + mkXfceDerivation, + glib, + gtk3, + libxfce4ui, + libxfce4util, + pcre2, + xfce4-panel, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-weather-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-weather-plugin/default.nix index 9d8d80fed1069c..7a56ed84fc61ba 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-weather-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-weather-plugin/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, intltool -, glib -, gtk3 -, json_c -, libxml2 -, libsoup_2_4 -, upower -, libxfce4ui -, libxfce4util -, xfce4-panel -, xfconf -, hicolor-icon-theme -, gitUpdater +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + glib, + gtk3, + json_c, + libxml2, + libsoup_2_4, + upower, + libxfce4ui, + libxfce4util, + xfce4-panel, + xfconf, + hicolor-icon-theme, + gitUpdater, }: let diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-whiskermenu-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-whiskermenu-plugin/default.nix index b1b068eaa55ff4..bbb7a29df86346 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-whiskermenu-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-whiskermenu-plugin/default.nix @@ -1,17 +1,18 @@ -{ mkXfceDerivation -, lib -, cmake -, accountsservice -, exo -, garcon -, gettext -, glib -, gtk-layer-shell -, gtk3 -, libxfce4ui -, libxfce4util -, xfce4-panel -, xfconf +{ + mkXfceDerivation, + lib, + cmake, + accountsservice, + exo, + garcon, + gettext, + glib, + gtk-layer-shell, + gtk3, + libxfce4ui, + libxfce4util, + xfce4-panel, + xfconf, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-windowck-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-windowck-plugin/default.nix index 6c0a7bafe39ec6..970ad85a4199c8 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-windowck-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-windowck-plugin/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchurl -, intltool -, pkg-config -, libwnck -, libxfce4ui -, xfce4-panel -, xfconf -, gitUpdater +{ + stdenv, + lib, + fetchurl, + intltool, + pkg-config, + libwnck, + libxfce4ui, + xfce4-panel, + xfconf, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/desktops/xfce/panel-plugins/xfce4-xkb-plugin/default.nix b/pkgs/desktops/xfce/panel-plugins/xfce4-xkb-plugin/default.nix index 40ac161879b7d7..b4c33dad670122 100644 --- a/pkgs/desktops/xfce/panel-plugins/xfce4-xkb-plugin/default.nix +++ b/pkgs/desktops/xfce/panel-plugins/xfce4-xkb-plugin/default.nix @@ -1,15 +1,16 @@ -{ lib -, mkXfceDerivation -, gtk3 -, libnotify -, librsvg -, libwnck -, libxklavier -, garcon -, libxfce4ui -, libxfce4util -, xfce4-panel -, xfconf +{ + lib, + mkXfceDerivation, + gtk3, + libnotify, + librsvg, + libwnck, + libxklavier, + garcon, + libxfce4ui, + libxfce4util, + xfce4-panel, + xfconf, }: mkXfceDerivation { diff --git a/pkgs/desktops/xfce/thunar-plugins/archive/default.nix b/pkgs/desktops/xfce/thunar-plugins/archive/default.nix index 99285b53cb6187..bdcca89a918eaf 100644 --- a/pkgs/desktops/xfce/thunar-plugins/archive/default.nix +++ b/pkgs/desktops/xfce/thunar-plugins/archive/default.nix @@ -1,16 +1,17 @@ -{ lib -, mkXfceDerivation -, gtk3 -, thunar -, exo -, libxfce4util -, intltool -, gettext +{ + lib, + mkXfceDerivation, + gtk3, + thunar, + exo, + libxfce4util, + intltool, + gettext, }: mkXfceDerivation { category = "thunar-plugins"; - pname = "thunar-archive-plugin"; + pname = "thunar-archive-plugin"; version = "0.5.2"; odd-unstable = false; diff --git a/pkgs/desktops/xfce/thunar-plugins/dropbox/default.nix b/pkgs/desktops/xfce/thunar-plugins/dropbox/default.nix index 150db52bb5b26e..8a379d6c8f3ae6 100644 --- a/pkgs/desktops/xfce/thunar-plugins/dropbox/default.nix +++ b/pkgs/desktops/xfce/thunar-plugins/dropbox/default.nix @@ -1,16 +1,18 @@ -{ lib, stdenv -, fetchFromGitHub -, pkg-config -, gtk3 -, thunar -, cmake -, ninja -, xfce -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + gtk3, + thunar, + cmake, + ninja, + xfce, + gitUpdater, }: stdenv.mkDerivation rec { - pname = "thunar-dropbox"; + pname = "thunar-dropbox"; version = "0.3.1"; src = fetchFromGitHub { diff --git a/pkgs/desktops/xfce/thunar-plugins/media-tags/default.nix b/pkgs/desktops/xfce/thunar-plugins/media-tags/default.nix index 570f0aeafcfe81..a69eb7cd1e86a0 100644 --- a/pkgs/desktops/xfce/thunar-plugins/media-tags/default.nix +++ b/pkgs/desktops/xfce/thunar-plugins/media-tags/default.nix @@ -1,12 +1,13 @@ -{ lib -, mkXfceDerivation -, glib -, gtk3 -, thunar -, libxfce4util -, intltool -, gettext -, taglib +{ + lib, + mkXfceDerivation, + glib, + gtk3, + thunar, + libxfce4util, + intltool, + gettext, + taglib, }: mkXfceDerivation { diff --git a/pkgs/development/ada-modules/gprbuild/default.nix b/pkgs/development/ada-modules/gprbuild/default.nix index 3965789d742e22..2d661abd43253a 100644 --- a/pkgs/development/ada-modules/gprbuild/default.nix +++ b/pkgs/development/ada-modules/gprbuild/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, gprbuild-boot -, which -, gnat -, xmlada +{ + lib, + stdenv, + gprbuild-boot, + which, + gnat, + xmlada, }: stdenv.mkDerivation { @@ -29,15 +30,17 @@ stdenv.mkDerivation { xmlada ]; - makeFlags = [ - "ENABLE_SHARED=${if stdenv.hostPlatform.isStatic then "no" else "yes"}" - "PROCESSORS=$(NIX_BUILD_CORES)" - # confusingly, for gprbuild --target is autoconf --host - "TARGET=${stdenv.hostPlatform.config}" - "prefix=${placeholder "out"}" - ] ++ lib.optionals (!stdenv.hostPlatform.isStatic) [ - "LIBRARY_TYPE=relocatable" - ]; + makeFlags = + [ + "ENABLE_SHARED=${if stdenv.hostPlatform.isStatic then "no" else "yes"}" + "PROCESSORS=$(NIX_BUILD_CORES)" + # confusingly, for gprbuild --target is autoconf --host + "TARGET=${stdenv.hostPlatform.config}" + "prefix=${placeholder "out"}" + ] + ++ lib.optionals (!stdenv.hostPlatform.isStatic) [ + "LIBRARY_TYPE=relocatable" + ]; env = lib.optionalAttrs stdenv.hostPlatform.isDarwin { # Ensure that there is enough space for the `fixDarwinDylibNames` hook to @@ -51,9 +54,15 @@ stdenv.mkDerivation { ./gprbuild-relocatable-build.patch ]; - buildFlags = [ "all" "libgpr.build" ]; + buildFlags = [ + "all" + "libgpr.build" + ]; - installFlags = [ "all" "libgpr.install" ]; + installFlags = [ + "all" + "libgpr.install" + ]; # link gprconfig_kb db from gprbuild-boot into build dir, # the install process copies its contents to $out diff --git a/pkgs/development/androidndk-pkgs/androidndk-pkgs.nix b/pkgs/development/androidndk-pkgs/androidndk-pkgs.nix index 1355323d93fd17..9e743db9fcc514 100644 --- a/pkgs/development/androidndk-pkgs/androidndk-pkgs.nix +++ b/pkgs/development/androidndk-pkgs/androidndk-pkgs.nix @@ -1,6 +1,15 @@ -{ lib, stdenv, makeWrapper -, runCommand, wrapBintoolsWith, wrapCCWith, autoPatchelfHook -, llvmPackages, buildAndroidndk, androidndk, targetAndroidndkPkgs +{ + lib, + stdenv, + makeWrapper, + runCommand, + wrapBintoolsWith, + wrapCCWith, + autoPatchelfHook, + llvmPackages, + buildAndroidndk, + androidndk, + targetAndroidndkPkgs, }: let @@ -11,46 +20,58 @@ let # than we do. We don't just use theirs because ours are less ambiguous and # some builds need that clarity. # - ndkBuildInfoFun = { config, ... }: { - x86_64-apple-darwin = { - double = "darwin-x86_64"; - }; - x86_64-unknown-linux-gnu = { - double = "linux-x86_64"; - }; - }.${config} or - (throw "Android NDK doesn't support building on ${config}, as far as we know"); - - ndkTargetInfoFun = { config, ... }: { - i686-unknown-linux-android = { - triple = "i686-linux-android"; - arch = "x86"; - }; - x86_64-unknown-linux-android = { - triple = "x86_64-linux-android"; - arch = "x86_64"; - }; - armv7a-unknown-linux-androideabi = { - arch = "arm"; - triple = "arm-linux-androideabi"; - }; - aarch64-unknown-linux-android = { - arch = "arm64"; - triple = "aarch64-linux-android"; - }; - }.${config} or - (throw "Android NDK doesn't support targetting ${config}, as far as we know"); + ndkBuildInfoFun = + { config, ... }: + { + x86_64-apple-darwin = { + double = "darwin-x86_64"; + }; + x86_64-unknown-linux-gnu = { + double = "linux-x86_64"; + }; + } + .${config} or (throw "Android NDK doesn't support building on ${config}, as far as we know"); + + ndkTargetInfoFun = + { config, ... }: + { + i686-unknown-linux-android = { + triple = "i686-linux-android"; + arch = "x86"; + }; + x86_64-unknown-linux-android = { + triple = "x86_64-linux-android"; + arch = "x86_64"; + }; + armv7a-unknown-linux-androideabi = { + arch = "arm"; + triple = "arm-linux-androideabi"; + }; + aarch64-unknown-linux-android = { + arch = "arm64"; + triple = "aarch64-linux-android"; + }; + } + .${config} or (throw "Android NDK doesn't support targetting ${config}, as far as we know"); buildInfo = ndkBuildInfoFun stdenv.buildPlatform; targetInfo = ndkTargetInfoFun stdenv.targetPlatform; - androidSdkVersion = if (stdenv.targetPlatform ? androidSdkVersion && stdenv.targetPlatform.androidSdkVersion != null) then stdenv.targetPlatform.androidSdkVersion else (throw "`androidSdkVersion` is not set during the importing of nixpkgs"); - suffixSalt = lib.replaceStrings ["-" "."] ["_" "_"] stdenv.targetPlatform.config; + androidSdkVersion = + if + (stdenv.targetPlatform ? androidSdkVersion && stdenv.targetPlatform.androidSdkVersion != null) + then + stdenv.targetPlatform.androidSdkVersion + else + (throw "`androidSdkVersion` is not set during the importing of nixpkgs"); + suffixSalt = lib.replaceStrings [ "-" "." ] [ "_" "_" ] stdenv.targetPlatform.config; # targetInfo.triple is what Google thinks the toolchain should be, this is a little # different from what we use. We make it four parts to conform with the existing # standard more properly. - targetPrefix = lib.optionalString (stdenv.targetPlatform != stdenv.hostPlatform) (stdenv.targetPlatform.config + "-"); + targetPrefix = lib.optionalString (stdenv.targetPlatform != stdenv.hostPlatform) ( + stdenv.targetPlatform.config + "-" + ); in rec { @@ -58,7 +79,10 @@ rec { binaries = stdenv.mkDerivation { pname = "${targetPrefix}ndk-toolchain"; inherit (androidndk) version; - nativeBuildInputs = [ makeWrapper autoPatchelfHook ]; + nativeBuildInputs = [ + makeWrapper + autoPatchelfHook + ]; propagatedBuildInputs = [ androidndk ]; passthru = { inherit targetPrefix; @@ -150,7 +174,7 @@ rec { # We use androidndk from the previous stage, else we waste time or get cycles # cross-compiling packages to wrap incorrectly wrap binaries we don't include # anyways. - libraries = runCommand "bionic-prebuilt" {} '' + libraries = runCommand "bionic-prebuilt" { } '' lpath=${buildAndroidndk}/libexec/android-sdk/ndk-bundle/toolchains/llvm/prebuilt/${buildInfo.double}/sysroot/usr/lib/${targetInfo.triple}/${androidSdkVersion} if [ ! -d $lpath ]; then echo "NDK does not contain libraries for SDK version ${androidSdkVersion} <$lpath>" diff --git a/pkgs/development/androidndk-pkgs/default.nix b/pkgs/development/androidndk-pkgs/default.nix index 93af59a859330f..f7ffb07450709b 100644 --- a/pkgs/development/androidndk-pkgs/default.nix +++ b/pkgs/development/androidndk-pkgs/default.nix @@ -1,8 +1,16 @@ -{ lib, androidenv, buildPackages, pkgs, targetPackages, androidndkPkgs_23, config +{ + lib, + androidenv, + buildPackages, + pkgs, + targetPackages, + androidndkPkgs_23, + config, }: let - makeNdkPkgs = ndkVersion: llvmPackages: + makeNdkPkgs = + ndkVersion: llvmPackages: let buildAndroidComposition = buildPackages.buildPackages.androidenv.composeAndroidPackages { includeNDK = true; @@ -18,10 +26,15 @@ let import ./androidndk-pkgs.nix { inherit lib; inherit (buildPackages) - makeWrapper autoPatchelfHook; + makeWrapper + autoPatchelfHook + ; inherit (pkgs) stdenv - runCommand wrapBintoolsWith wrapCCWith; + runCommand + wrapBintoolsWith + wrapCCWith + ; # For hardeningUnsupportedFlagsByTargetPlatform inherit llvmPackages; @@ -32,7 +45,11 @@ let # these two really are the same. buildAndroidndk = buildAndroidComposition.ndk-bundle; androidndk = androidComposition.ndk-bundle; - targetAndroidndkPkgs = if targetPackages ? "androidndkPkgs_${majorVersion}" then targetPackages."androidndkPkgs_${majorVersion}" else throw "androidndkPkgs_${majorVersion}: no targetPackages, use `buildPackages.androidndkPkgs_${majorVersion}"; + targetAndroidndkPkgs = + if targetPackages ? "androidndkPkgs_${majorVersion}" then + targetPackages."androidndkPkgs_${majorVersion}" + else + throw "androidndkPkgs_${majorVersion}: no targetPackages, use `buildPackages.androidndkPkgs_${majorVersion}"; }; in diff --git a/pkgs/development/beam-modules/build-erlang-mk.nix b/pkgs/development/beam-modules/build-erlang-mk.nix index eb70517c82ec89..c5e8e6b5ad185a 100644 --- a/pkgs/development/beam-modules/build-erlang-mk.nix +++ b/pkgs/development/beam-modules/build-erlang-mk.nix @@ -1,108 +1,135 @@ -{ stdenv, writeText, erlang, perl, which, gitMinimal, wget, lib }: - -{ name -, version -, src -, setupHook ? null -, buildInputs ? [ ] -, beamDeps ? [ ] -, postPatch ? "" -, compilePorts ? false -, installPhase ? null -, buildPhase ? null -, configurePhase ? null -, meta ? { } -, enableDebugInfo ? false -, buildFlags ? [ ] -, ... +{ + stdenv, + writeText, + erlang, + perl, + which, + gitMinimal, + wget, + lib, +}: + +{ + name, + version, + src, + setupHook ? null, + buildInputs ? [ ], + beamDeps ? [ ], + postPatch ? "", + compilePorts ? false, + installPhase ? null, + buildPhase ? null, + configurePhase ? null, + meta ? { }, + enableDebugInfo ? false, + buildFlags ? [ ], + ... }@attrs: let debugInfoFlag = lib.optionalString (enableDebugInfo || erlang.debugInfo) "+debug_info"; - shell = drv: stdenv.mkDerivation { - name = "interactive-shell-${drv.name}"; - buildInputs = [ drv ]; - }; - - pkg = self: stdenv.mkDerivation (attrs // { - app_name = name; - name = "${name}-${version}"; - inherit version; - - dontStrip = true; - - inherit src; - - setupHook = - if setupHook == null - then - writeText "setupHook.sh" '' - addToSearchPath ERL_LIBS "$1/lib/erlang/lib" - '' - else setupHook; - - buildInputs = buildInputs ++ [ erlang perl which gitMinimal wget ]; - propagatedBuildInputs = beamDeps; - - buildFlags = [ "SKIP_DEPS=1" ] - ++ lib.optional (enableDebugInfo || erlang.debugInfo) ''ERL_OPTS="$ERL_OPTS +debug_info"'' - ++ buildFlags; - - configurePhase = - if configurePhase == null - then '' - runHook preConfigure - - # We shouldnt need to do this, but it seems at times there is a *.app in - # the repo/package. This ensures we start from a clean slate - make SKIP_DEPS=1 clean - - runHook postConfigure - '' - else configurePhase; - - buildPhase = - if buildPhase == null - then '' - runHook preBuild - - make $buildFlags "''${buildFlagsArray[@]}" - - runHook postBuild - '' - else buildPhase; - - installPhase = - if installPhase == null - then '' - runHook preInstall - - mkdir -p $out/lib/erlang/lib/${name} - cp -r ebin $out/lib/erlang/lib/${name}/ - cp -r src $out/lib/erlang/lib/${name}/ - - if [ -d include ]; then - cp -r include $out/lib/erlang/lib/${name}/ - fi - - if [ -d priv ]; then - cp -r priv $out/lib/erlang/lib/${name}/ - fi - - if [ -d doc ]; then - cp -r doc $out/lib/erlang/lib/${name}/ - fi - - runHook postInstall - '' - else installPhase; - - passthru = { - packageName = name; - env = shell self; - inherit beamDeps; + shell = + drv: + stdenv.mkDerivation { + name = "interactive-shell-${drv.name}"; + buildInputs = [ drv ]; }; - }); + + pkg = + self: + stdenv.mkDerivation ( + attrs + // { + app_name = name; + name = "${name}-${version}"; + inherit version; + + dontStrip = true; + + inherit src; + + setupHook = + if setupHook == null then + writeText "setupHook.sh" '' + addToSearchPath ERL_LIBS "$1/lib/erlang/lib" + '' + else + setupHook; + + buildInputs = buildInputs ++ [ + erlang + perl + which + gitMinimal + wget + ]; + propagatedBuildInputs = beamDeps; + + buildFlags = + [ "SKIP_DEPS=1" ] + ++ lib.optional (enableDebugInfo || erlang.debugInfo) ''ERL_OPTS="$ERL_OPTS +debug_info"'' + ++ buildFlags; + + configurePhase = + if configurePhase == null then + '' + runHook preConfigure + + # We shouldnt need to do this, but it seems at times there is a *.app in + # the repo/package. This ensures we start from a clean slate + make SKIP_DEPS=1 clean + + runHook postConfigure + '' + else + configurePhase; + + buildPhase = + if buildPhase == null then + '' + runHook preBuild + + make $buildFlags "''${buildFlagsArray[@]}" + + runHook postBuild + '' + else + buildPhase; + + installPhase = + if installPhase == null then + '' + runHook preInstall + + mkdir -p $out/lib/erlang/lib/${name} + cp -r ebin $out/lib/erlang/lib/${name}/ + cp -r src $out/lib/erlang/lib/${name}/ + + if [ -d include ]; then + cp -r include $out/lib/erlang/lib/${name}/ + fi + + if [ -d priv ]; then + cp -r priv $out/lib/erlang/lib/${name}/ + fi + + if [ -d doc ]; then + cp -r doc $out/lib/erlang/lib/${name}/ + fi + + runHook postInstall + '' + else + installPhase; + + passthru = { + packageName = name; + env = shell self; + inherit beamDeps; + }; + } + ); in lib.fix pkg diff --git a/pkgs/development/beam-modules/build-hex.nix b/pkgs/development/beam-modules/build-hex.nix index b5d20fa97783a8..fa70b16ca659f3 100644 --- a/pkgs/development/beam-modules/build-hex.nix +++ b/pkgs/development/beam-modules/build-hex.nix @@ -1,18 +1,31 @@ -{ lib, buildRebar3, fetchHex }: +{ + lib, + buildRebar3, + fetchHex, +}: -{ name, version, sha256 -, builder ? buildRebar3 -, hexPkg ? name -, ... }@attrs: +{ + name, + version, + sha256, + builder ? buildRebar3, + hexPkg ? name, + ... +}@attrs: let - pkg = self: builder (attrs // { + pkg = + self: + builder ( + attrs + // { - src = fetchHex { - pkg = hexPkg; - inherit version; - inherit sha256; - }; - }); + src = fetchHex { + pkg = hexPkg; + inherit version; + inherit sha256; + }; + } + ); in - lib.fix pkg +lib.fix pkg diff --git a/pkgs/development/beam-modules/build-mix.nix b/pkgs/development/beam-modules/build-mix.nix index d61b5e91556bd1..ed286c4c2bd1e0 100644 --- a/pkgs/development/beam-modules/build-mix.nix +++ b/pkgs/development/beam-modules/build-mix.nix @@ -1,122 +1,143 @@ -{ stdenv, writeText, elixir, erlang, hex, lib }: - -{ name -, version -, src -, buildInputs ? [ ] -, nativeBuildInputs ? [ ] -, erlangCompilerOptions ? [ ] +{ + stdenv, + writeText, + elixir, + erlang, + hex, + lib, +}: + +{ + name, + version, + src, + buildInputs ? [ ], + nativeBuildInputs ? [ ], + erlangCompilerOptions ? [ ], # Deterministic Erlang builds remove full system paths from debug information # among other things to keep builds more reproducible. See their docs for more: # https://www.erlang.org/doc/man/compile -, erlangDeterministicBuilds ? true -, beamDeps ? [ ] -, propagatedBuildInputs ? [ ] -, postPatch ? "" -, compilePorts ? false -, meta ? { } -, enableDebugInfo ? false -, mixEnv ? "prod" -# A config directory that is considered for all the dependencies of an app, typically in $src/config/ -# This was initially added, as some of Mobilizon's dependencies need to access the config at build time. -, appConfigPath ? null -, ... + erlangDeterministicBuilds ? true, + beamDeps ? [ ], + propagatedBuildInputs ? [ ], + postPatch ? "", + compilePorts ? false, + meta ? { }, + enableDebugInfo ? false, + mixEnv ? "prod", + # A config directory that is considered for all the dependencies of an app, typically in $src/config/ + # This was initially added, as some of Mobilizon's dependencies need to access the config at build time. + appConfigPath ? null, + ... }@attrs: let - shell = drv: stdenv.mkDerivation { - name = "interactive-shell-${drv.name}"; - buildInputs = [ drv ]; - }; - - pkg = self: stdenv.mkDerivation (attrs // { - name = "${name}-${version}"; - inherit version src; - - MIX_ENV = mixEnv; - MIX_DEBUG = if enableDebugInfo then 1 else 0; - HEX_OFFLINE = 1; - - ERL_COMPILER_OPTIONS = - let - options = erlangCompilerOptions ++ lib.optionals erlangDeterministicBuilds [ "deterministic" ]; - in - "[${lib.concatStringsSep "," options}]"; - - LC_ALL = "C.UTF-8"; - - # add to ERL_LIBS so other modules can find at runtime. - # http://erlang.org/doc/man/code.html#code-path - # Mix also searches the code path when compiling with the --no-deps-check flag - setupHook = attrs.setupHook or - writeText "setupHook.sh" '' - addToSearchPath ERL_LIBS "$1/lib/erlang/lib" - ''; - - buildInputs = buildInputs ++ [ ]; - nativeBuildInputs = nativeBuildInputs ++ [ elixir hex ]; - propagatedBuildInputs = propagatedBuildInputs ++ beamDeps; - - configurePhase = attrs.configurePhase or '' - runHook preConfigure - - ${./mix-configure-hook.sh} - ${lib.optionalString (!isNull appConfigPath) - # Due to https://hexdocs.pm/elixir/main/Config.html the config directory - # of a library seems to be not considered, as config is always - # application specific. So we can safely delete it. - '' - rm -rf config - cp -r ${appConfigPath} config - ''} - - runHook postConfigure - ''; - - buildPhase = attrs.buildPhase or '' - runHook preBuild - export HEX_HOME="$TEMPDIR/hex" - export MIX_HOME="$TEMPDIR/mix" - mix compile --no-deps-check - runHook postBuild - ''; - - installPhase = attrs.installPhase or '' - runHook preInstall - - # This uses the install path convention established by nixpkgs maintainers - # for all beam packages. Changing this will break compatibility with other - # builder functions like buildRebar3 and buildErlangMk. - mkdir -p "$out/lib/erlang/lib/${name}-${version}" - - # Some packages like db_connection will use _build/shared instead of - # honoring the $MIX_ENV variable. - for reldir in _build/{$MIX_ENV,shared}/lib/${name}/{src,ebin,priv,include} ; do - if test -d $reldir ; then - # Some builds produce symlinks (eg: phoenix priv dircetory). They must - # be followed with -H flag. - cp -Hrt "$out/lib/erlang/lib/${name}-${version}" "$reldir" - fi - done - - # Copy the source so it can be used by dependent packages. For example, - # phoenix applications need the source of phoenix and phoenix_html to - # build javascript and css assets. - mkdir -p $out/src - cp -r $src/* "$out/src" - - runHook postInstall - ''; - - # stripping does not have any effect on beam files - # it is however needed for dependencies with NIFs like bcrypt for example - dontStrip = false; - - passthru = { - packageName = name; - env = shell self; - inherit beamDeps; + shell = + drv: + stdenv.mkDerivation { + name = "interactive-shell-${drv.name}"; + buildInputs = [ drv ]; }; - }); + + pkg = + self: + stdenv.mkDerivation ( + attrs + // { + name = "${name}-${version}"; + inherit version src; + + MIX_ENV = mixEnv; + MIX_DEBUG = if enableDebugInfo then 1 else 0; + HEX_OFFLINE = 1; + + ERL_COMPILER_OPTIONS = + let + options = erlangCompilerOptions ++ lib.optionals erlangDeterministicBuilds [ "deterministic" ]; + in + "[${lib.concatStringsSep "," options}]"; + + LC_ALL = "C.UTF-8"; + + # add to ERL_LIBS so other modules can find at runtime. + # http://erlang.org/doc/man/code.html#code-path + # Mix also searches the code path when compiling with the --no-deps-check flag + setupHook = attrs.setupHook or writeText "setupHook.sh" '' + addToSearchPath ERL_LIBS "$1/lib/erlang/lib" + ''; + + buildInputs = buildInputs ++ [ ]; + nativeBuildInputs = nativeBuildInputs ++ [ + elixir + hex + ]; + propagatedBuildInputs = propagatedBuildInputs ++ beamDeps; + + configurePhase = + attrs.configurePhase or '' + runHook preConfigure + + ${./mix-configure-hook.sh} + ${lib.optionalString (!isNull appConfigPath) + # Due to https://hexdocs.pm/elixir/main/Config.html the config directory + # of a library seems to be not considered, as config is always + # application specific. So we can safely delete it. + '' + rm -rf config + cp -r ${appConfigPath} config + '' + } + + runHook postConfigure + ''; + + buildPhase = + attrs.buildPhase or '' + runHook preBuild + export HEX_HOME="$TEMPDIR/hex" + export MIX_HOME="$TEMPDIR/mix" + mix compile --no-deps-check + runHook postBuild + ''; + + installPhase = + attrs.installPhase or '' + runHook preInstall + + # This uses the install path convention established by nixpkgs maintainers + # for all beam packages. Changing this will break compatibility with other + # builder functions like buildRebar3 and buildErlangMk. + mkdir -p "$out/lib/erlang/lib/${name}-${version}" + + # Some packages like db_connection will use _build/shared instead of + # honoring the $MIX_ENV variable. + for reldir in _build/{$MIX_ENV,shared}/lib/${name}/{src,ebin,priv,include} ; do + if test -d $reldir ; then + # Some builds produce symlinks (eg: phoenix priv dircetory). They must + # be followed with -H flag. + cp -Hrt "$out/lib/erlang/lib/${name}-${version}" "$reldir" + fi + done + + # Copy the source so it can be used by dependent packages. For example, + # phoenix applications need the source of phoenix and phoenix_html to + # build javascript and css assets. + mkdir -p $out/src + cp -r $src/* "$out/src" + + runHook postInstall + ''; + + # stripping does not have any effect on beam files + # it is however needed for dependencies with NIFs like bcrypt for example + dontStrip = false; + + passthru = { + packageName = name; + env = shell self; + inherit beamDeps; + }; + } + ); in lib.fix pkg diff --git a/pkgs/development/beam-modules/build-rebar3.nix b/pkgs/development/beam-modules/build-rebar3.nix index 43d613d072ee12..781b6a7a78fe0d 100644 --- a/pkgs/development/beam-modules/build-rebar3.nix +++ b/pkgs/development/beam-modules/build-rebar3.nix @@ -1,19 +1,28 @@ -{ stdenv, writeText, erlang, rebar3WithPlugins, openssl, libyaml, lib }: - -{ name -, version -, src -, setupHook ? null -, buildInputs ? [ ] -, beamDeps ? [ ] -, buildPlugins ? [ ] -, postPatch ? "" -, installPhase ? null -, buildPhase ? null -, configurePhase ? null -, meta ? { } -, enableDebugInfo ? false -, ... +{ + stdenv, + writeText, + erlang, + rebar3WithPlugins, + openssl, + libyaml, + lib, +}: + +{ + name, + version, + src, + setupHook ? null, + buildInputs ? [ ], + beamDeps ? [ ], + buildPlugins ? [ ], + postPatch ? "", + installPhase ? null, + buildPhase ? null, + configurePhase ? null, + meta ? { }, + enableDebugInfo ? false, + ... }@attrs: let @@ -23,64 +32,84 @@ let plugins = buildPlugins; }; - shell = drv: stdenv.mkDerivation { - name = "interactive-shell-${drv.name}"; - buildInputs = [ drv ]; + shell = + drv: + stdenv.mkDerivation { + name = "interactive-shell-${drv.name}"; + buildInputs = [ drv ]; + }; + + customPhases = lib.filterAttrs (_: v: v != null) { + inherit + setupHook + configurePhase + buildPhase + installPhase + ; }; - customPhases = lib.filterAttrs - (_: v: v != null) - { inherit setupHook configurePhase buildPhase installPhase; }; - - pkg = self: stdenv.mkDerivation (attrs // { - - name = "${name}-${version}"; - inherit version; - - buildInputs = buildInputs ++ [ erlang rebar3 openssl libyaml ]; - propagatedBuildInputs = lib.unique beamDeps; - - inherit src; - - # stripping does not have any effect on beam files - # it is however needed for dependencies with NIFs - # false is the default but we keep this for readability - dontStrip = false; - - setupHook = writeText "setupHook.sh" '' - addToSearchPath ERL_LIBS "$1/lib/erlang/lib/" - ''; - - postPatch = '' - rm -f rebar rebar3 - '' + postPatch; - - buildPhase = '' - runHook preBuild - HOME=. rebar3 bare compile -path "" - runHook postBuild - ''; - - installPhase = '' - runHook preInstall - mkdir -p "$out/lib/erlang/lib/${name}-${version}" - for reldir in src ebin priv include; do - [ -d "$reldir" ] || continue - # $out/lib/erlang/lib is a convention used in nixpkgs for compiled BEAM packages - cp -Hrt "$out/lib/erlang/lib/${name}-${version}" "$reldir" - done - runHook postInstall - ''; - - meta = { - inherit (erlang.meta) platforms; - } // meta; - - passthru = { - packageName = name; - env = shell self; - inherit beamDeps; - }; - } // customPhases); + pkg = + self: + stdenv.mkDerivation ( + attrs + // { + + name = "${name}-${version}"; + inherit version; + + buildInputs = buildInputs ++ [ + erlang + rebar3 + openssl + libyaml + ]; + propagatedBuildInputs = lib.unique beamDeps; + + inherit src; + + # stripping does not have any effect on beam files + # it is however needed for dependencies with NIFs + # false is the default but we keep this for readability + dontStrip = false; + + setupHook = writeText "setupHook.sh" '' + addToSearchPath ERL_LIBS "$1/lib/erlang/lib/" + ''; + + postPatch = + '' + rm -f rebar rebar3 + '' + + postPatch; + + buildPhase = '' + runHook preBuild + HOME=. rebar3 bare compile -path "" + runHook postBuild + ''; + + installPhase = '' + runHook preInstall + mkdir -p "$out/lib/erlang/lib/${name}-${version}" + for reldir in src ebin priv include; do + [ -d "$reldir" ] || continue + # $out/lib/erlang/lib is a convention used in nixpkgs for compiled BEAM packages + cp -Hrt "$out/lib/erlang/lib/${name}-${version}" "$reldir" + done + runHook postInstall + ''; + + meta = { + inherit (erlang.meta) platforms; + } // meta; + + passthru = { + packageName = name; + env = shell self; + inherit beamDeps; + }; + } + // customPhases + ); in lib.fix pkg diff --git a/pkgs/development/beam-modules/elixir-ls/default.nix b/pkgs/development/beam-modules/elixir-ls/default.nix index 3bf8c57b75437a..e5da3296b71c93 100644 --- a/pkgs/development/beam-modules/elixir-ls/default.nix +++ b/pkgs/development/beam-modules/elixir-ls/default.nix @@ -1,4 +1,11 @@ -{ lib, elixir, fetchFromGitHub, fetchMixDeps, mixRelease, nix-update-script }: +{ + lib, + elixir, + fetchFromGitHub, + fetchMixDeps, + mixRelease, + nix-update-script, +}: # Based on the work of Hauleth # None of this would have happened without him @@ -13,7 +20,12 @@ let }; in mixRelease { - inherit pname version src elixir; + inherit + pname + version + src + elixir + ; stripDebug = true; diff --git a/pkgs/development/beam-modules/elvis-erlang/default.nix b/pkgs/development/beam-modules/elvis-erlang/default.nix index 2d9475e72fbb23..c9b2deaeea420d 100644 --- a/pkgs/development/beam-modules/elvis-erlang/default.nix +++ b/pkgs/development/beam-modules/elvis-erlang/default.nix @@ -1,10 +1,18 @@ -{ fetchFromGitHub, fetchgit, fetchHex, rebar3Relx -, buildRebar3, writeScript, lib }: +{ + fetchFromGitHub, + fetchgit, + fetchHex, + rebar3Relx, + buildRebar3, + writeScript, + lib, +}: let owner = "inaka"; repo = "elvis"; -in rebar3Relx rec { +in +rebar3Relx rec { releaseType = "escript"; # The package name "elvis" is already taken pname = "elvis-erlang"; @@ -14,10 +22,12 @@ in rebar3Relx rec { sha256 = "13QM6UbH+1PxzhY/ufi5PEP2pKqSl5+g6tMvKmOUMb0="; rev = version; }; - beamDeps = builtins.attrValues (import ./rebar-deps.nix { - inherit fetchHex fetchgit fetchFromGitHub; - builder = buildRebar3; - }); + beamDeps = builtins.attrValues ( + import ./rebar-deps.nix { + inherit fetchHex fetchgit fetchFromGitHub; + builder = buildRebar3; + } + ); passthru.updateScript = writeScript "update.sh" '' #!/usr/bin/env nix-shell #!nix-shell -i bash -p bash common-updater-scripts git nix-prefetch-git gnutar gzip "rebar3WithPlugins {globalPlugins = [beamPackages.rebar3-nix];}" diff --git a/pkgs/development/beam-modules/elvis-erlang/rebar-deps.nix b/pkgs/development/beam-modules/elvis-erlang/rebar-deps.nix index a71d0e5d77141d..7b54b5231b9090 100644 --- a/pkgs/development/beam-modules/elvis-erlang/rebar-deps.nix +++ b/pkgs/development/beam-modules/elvis-erlang/rebar-deps.nix @@ -1,6 +1,14 @@ # Generated by rebar3_nix -let fetchOnly = { src, ... }: src; -in { builder ? fetchOnly, fetchHex, fetchgit, fetchFromGitHub, overrides ? (x: y: { }) }: +let + fetchOnly = { src, ... }: src; +in +{ + builder ? fetchOnly, + fetchHex, + fetchgit, + fetchFromGitHub, + overrides ? (x: y: { }), +}: let self = packages // (overrides self packages); packages = with self; { @@ -122,7 +130,15 @@ let version = "1.17.1"; sha256 = "sha256-0sup48gQOtAyBiPp8cM+jTeKFeqr4u6K5EGJjz01oYw="; }; - beamDeps = [ certifi idna metrics mimerl parse_trans ssl_verify_fun unicode_util_compat ]; + beamDeps = [ + certifi + idna + metrics + mimerl + parse_trans + ssl_verify_fun + unicode_util_compat + ]; }; goldrush = builder { name = "goldrush"; @@ -152,7 +168,10 @@ let version = "3.2.3"; sha256 = "sha256-oPDWgczZNVoWXDWXNnVVHxAhaHz5kvFcW/9mtmZO3gQ="; }; - beamDeps = [ katana_code zipper ]; + beamDeps = [ + katana_code + zipper + ]; }; egithub = builder { name = "egithub"; @@ -162,7 +181,13 @@ let version = "0.7.0"; sha256 = "sha256-4AnOEe/YAI0PntWdnEiOPpq+MCoPLNbWY+TMJnVvzEw="; }; - beamDeps = [ goldrush hackney jsx lager ]; + beamDeps = [ + goldrush + hackney + jsx + lager + ]; }; }; -in self +in +self diff --git a/pkgs/development/beam-modules/erlang-ls/default.nix b/pkgs/development/beam-modules/erlang-ls/default.nix index 6fa2eb007134bd..f815d2fa8b365a 100644 --- a/pkgs/development/beam-modules/erlang-ls/default.nix +++ b/pkgs/development/beam-modules/erlang-ls/default.nix @@ -1,5 +1,14 @@ -{ fetchFromGitHub, fetchgit, fetchHex, rebar3Relx, buildRebar3, rebar3-proper -, stdenv, writeScript, lib }: +{ + fetchFromGitHub, + fetchgit, + fetchHex, + rebar3Relx, + buildRebar3, + rebar3-proper, + stdenv, + writeScript, + lib, +}: let version = "1.1.0"; owner = "erlang-ls"; @@ -7,25 +16,27 @@ let deps = import ./rebar-deps.nix { inherit fetchHex fetchFromGitHub fetchgit; builder = buildRebar3; - overrides = (self: super: { - proper = super.proper.overrideAttrs (_: { - configurePhase = "true"; - }); - redbug = super.redbug.overrideAttrs (_: { - patchPhase = '' - substituteInPlace rebar.config --replace ", warnings_as_errors" "" + overrides = ( + self: super: { + proper = super.proper.overrideAttrs (_: { + configurePhase = "true"; + }); + redbug = super.redbug.overrideAttrs (_: { + patchPhase = '' + substituteInPlace rebar.config --replace ", warnings_as_errors" "" ''; - }); - json_polyfill = super.json_polyfill.overrideAttrs (_: { - # When compiling with erlang >= 27, the json_polyfill rebar script will - # delete the json.beam file as it's not needed. However, we need to - # adjust this path as the nix build will put the beam file under `ebin` - # instead of `$REBAR_DEPS_DIR/json_polyfill/ebin`. - postPatch = '' - substituteInPlace rebar.config.script --replace "{erlc_compile, \"rm \\\"\$REBAR_DEPS_DIR/json_polyfill/ebin/json.beam\\\"\"}" "{erlc_compile, \"rm \\\"ebin/json.beam\\\"\"}" + }); + json_polyfill = super.json_polyfill.overrideAttrs (_: { + # When compiling with erlang >= 27, the json_polyfill rebar script will + # delete the json.beam file as it's not needed. However, we need to + # adjust this path as the nix build will put the beam file under `ebin` + # instead of `$REBAR_DEPS_DIR/json_polyfill/ebin`. + postPatch = '' + substituteInPlace rebar.config.script --replace "{erlc_compile, \"rm \\\"\$REBAR_DEPS_DIR/json_polyfill/ebin/json.beam\\\"\"}" "{erlc_compile, \"rm \\\"ebin/json.beam\\\"\"}" ''; - }); - }); + }); + } + ); }; in rebar3Relx { @@ -40,7 +51,7 @@ rebar3Relx { beamDeps = builtins.attrValues deps; # https://github.com/erlang-ls/erlang_ls/issues/1429 - postPatch = '' + postPatch = '' rm apps/els_lsp/test/els_diagnostics_SUITE.erl ''; diff --git a/pkgs/development/beam-modules/erlang-ls/rebar-deps.nix b/pkgs/development/beam-modules/erlang-ls/rebar-deps.nix index 76ac0b9581bd74..b468a39edcd726 100644 --- a/pkgs/development/beam-modules/erlang-ls/rebar-deps.nix +++ b/pkgs/development/beam-modules/erlang-ls/rebar-deps.nix @@ -1,6 +1,14 @@ # Generated by rebar3_nix -let fetchOnly = { src, ... }: src; -in { builder ? fetchOnly, fetchHex, fetchgit, fetchFromGitHub, overrides ? (x: y: { }) }: +let + fetchOnly = { src, ... }: src; +in +{ + builder ? fetchOnly, + fetchHex, + fetchgit, + fetchFromGitHub, + overrides ? (x: y: { }), +}: let self = packages // (overrides self packages); packages = with self; { @@ -174,7 +182,10 @@ let version = "3.2.5"; sha256 = "sha256-NNkhjwuAclEZA79sy/WesXZd7Pxz/MaDO6XIlZ2384M="; }; - beamDeps = [ katana_code zipper ]; + beamDeps = [ + katana_code + zipper + ]; }; docsh = builder { name = "docsh"; @@ -227,4 +238,5 @@ let beamDeps = [ jsx ]; }; }; -in self +in +self diff --git a/pkgs/development/beam-modules/erlfmt/default.nix b/pkgs/development/beam-modules/erlfmt/default.nix index 11307e37cf5e96..49c687afd4596e 100644 --- a/pkgs/development/beam-modules/erlfmt/default.nix +++ b/pkgs/development/beam-modules/erlfmt/default.nix @@ -1,4 +1,8 @@ -{ fetchFromGitHub, rebar3Relx, lib }: +{ + fetchFromGitHub, + rebar3Relx, + lib, +}: rebar3Relx rec { pname = "erlfmt"; diff --git a/pkgs/development/beam-modules/fetch-hex.nix b/pkgs/development/beam-modules/fetch-hex.nix index a8241892ee0ca8..8b8024a31b2b24 100644 --- a/pkgs/development/beam-modules/fetch-hex.nix +++ b/pkgs/development/beam-modules/fetch-hex.nix @@ -1,9 +1,14 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: -{ pkg -, version -, sha256 -, meta ? { } +{ + pkg, + version, + sha256, + meta ? { }, }: stdenv.mkDerivation ({ diff --git a/pkgs/development/beam-modules/fetch-mix-deps.nix b/pkgs/development/beam-modules/fetch-mix-deps.nix index b9a1add3c7d161..867410e4f0a0d0 100644 --- a/pkgs/development/beam-modules/fetch-mix-deps.nix +++ b/pkgs/development/beam-modules/fetch-mix-deps.nix @@ -1,65 +1,98 @@ -{ stdenvNoCC, lib, elixir, hex, rebar, rebar3, cacert, git }@inputs: +{ + stdenvNoCC, + lib, + elixir, + hex, + rebar, + rebar3, + cacert, + git, +}@inputs: -{ pname -, version -, hash ? "" -, sha256 ? "" -, src -, mixEnv ? "prod" -, debug ? false -, meta ? { } -, patches ? [] -, elixir ? inputs.elixir -, hex ? inputs.hex.override { inherit elixir; } -, ... +{ + pname, + version, + hash ? "", + sha256 ? "", + src, + mixEnv ? "prod", + debug ? false, + meta ? { }, + patches ? [ ], + elixir ? inputs.elixir, + hex ? inputs.hex.override { inherit elixir; }, + ... }@attrs: let hash_ = - if hash != "" then { outputHashAlgo = null; outputHash = hash; } - else if sha256 != "" then { outputHashAlgo = "sha256"; outputHash = sha256; } - else { outputHashAlgo = "sha256"; outputHash = lib.fakeSha256; }; + if hash != "" then + { + outputHashAlgo = null; + outputHash = hash; + } + else if sha256 != "" then + { + outputHashAlgo = "sha256"; + outputHash = sha256; + } + else + { + outputHashAlgo = "sha256"; + outputHash = lib.fakeSha256; + }; in -stdenvNoCC.mkDerivation (attrs // { - nativeBuildInputs = [ elixir hex cacert git ]; +stdenvNoCC.mkDerivation ( + attrs + // { + nativeBuildInputs = [ + elixir + hex + cacert + git + ]; - MIX_ENV = mixEnv; - MIX_DEBUG = if debug then 1 else 0; - DEBUG = if debug then 1 else 0; # for rebar3 - # the api with `mix local.rebar rebar path` makes a copy of the binary - MIX_REBAR = "${rebar}/bin/rebar"; - MIX_REBAR3 = "${rebar3}/bin/rebar3"; - # there is a persistent download failure with absinthe 1.6.3 - # those defaults reduce the failure rate - HEX_HTTP_CONCURRENCY = 1; - HEX_HTTP_TIMEOUT = 120; + MIX_ENV = mixEnv; + MIX_DEBUG = if debug then 1 else 0; + DEBUG = if debug then 1 else 0; # for rebar3 + # the api with `mix local.rebar rebar path` makes a copy of the binary + MIX_REBAR = "${rebar}/bin/rebar"; + MIX_REBAR3 = "${rebar3}/bin/rebar3"; + # there is a persistent download failure with absinthe 1.6.3 + # those defaults reduce the failure rate + HEX_HTTP_CONCURRENCY = 1; + HEX_HTTP_TIMEOUT = 120; - configurePhase = attrs.configurePhase or '' - runHook preConfigure - export HEX_HOME="$TEMPDIR/.hex"; - export MIX_HOME="$TEMPDIR/.mix"; - export MIX_DEPS_PATH="$TEMPDIR/deps"; + configurePhase = + attrs.configurePhase or '' + runHook preConfigure + export HEX_HOME="$TEMPDIR/.hex"; + export MIX_HOME="$TEMPDIR/.mix"; + export MIX_DEPS_PATH="$TEMPDIR/deps"; - # Rebar - export REBAR_GLOBAL_CONFIG_DIR="$TMPDIR/rebar3" - export REBAR_CACHE_DIR="$TMPDIR/rebar3.cache" - runHook postConfigure - ''; + # Rebar + export REBAR_GLOBAL_CONFIG_DIR="$TMPDIR/rebar3" + export REBAR_CACHE_DIR="$TMPDIR/rebar3.cache" + runHook postConfigure + ''; - inherit patches; + inherit patches; - dontBuild = true; + dontBuild = true; - installPhase = attrs.installPhase or '' - runHook preInstall - mix deps.get ''${MIX_ENV:+--only $MIX_ENV} - find "$TEMPDIR/deps" -path '*/.git/*' -a ! -name HEAD -exec rm -rf {} + - cp -r --no-preserve=mode,ownership,timestamps $TEMPDIR/deps $out - runHook postInstall - ''; + installPhase = + attrs.installPhase or '' + runHook preInstall + mix deps.get ''${MIX_ENV:+--only $MIX_ENV} + find "$TEMPDIR/deps" -path '*/.git/*' -a ! -name HEAD -exec rm -rf {} + + cp -r --no-preserve=mode,ownership,timestamps $TEMPDIR/deps $out + runHook postInstall + ''; - outputHashMode = "recursive"; + outputHashMode = "recursive"; - impureEnvVars = lib.fetchers.proxyImpureEnvVars; - inherit meta; -} // hash_) + impureEnvVars = lib.fetchers.proxyImpureEnvVars; + inherit meta; + } + // hash_ +) diff --git a/pkgs/development/beam-modules/fetch-rebar-deps.nix b/pkgs/development/beam-modules/fetch-rebar-deps.nix index b253e16761ba0d..644dd1470ea774 100644 --- a/pkgs/development/beam-modules/fetch-rebar-deps.nix +++ b/pkgs/development/beam-modules/fetch-rebar-deps.nix @@ -1,10 +1,15 @@ -{ lib, stdenv, rebar3 }: +{ + lib, + stdenv, + rebar3, +}: -{ name -, version -, sha256 -, src -, meta ? { } +{ + name, + version, + sha256, + src, + meta ? { }, }: stdenv.mkDerivation ({ diff --git a/pkgs/development/beam-modules/hex/default.nix b/pkgs/development/beam-modules/hex/default.nix index 66462f639f1ef7..74de36b9269eb3 100644 --- a/pkgs/development/beam-modules/hex/default.nix +++ b/pkgs/development/beam-modules/hex/default.nix @@ -1,57 +1,68 @@ -{ lib, stdenv, fetchFromGitHub, writeText, elixir }: +{ + lib, + stdenv, + fetchFromGitHub, + writeText, + elixir, +}: let - shell = drv: stdenv.mkDerivation { - name = "interactive-shell-${drv.name}"; - buildInputs = [ drv ]; - }; - - pkg = self: stdenv.mkDerivation rec { - pname = "hex"; - version = "2.1.1"; - - src = fetchFromGitHub { - owner = "hexpm"; - repo = "hex"; - rev = "v${version}"; - sha256 = "sha256-pEfd2BqkVwZVbnka98MafJ/NRn94BHh+wM0i2Q5duTo="; + shell = + drv: + stdenv.mkDerivation { + name = "interactive-shell-${drv.name}"; + buildInputs = [ drv ]; }; - setupHook = writeText "setupHook.sh" '' - addToSearchPath ERL_LIBS "$1/lib/erlang/lib/" - ''; + pkg = + self: + stdenv.mkDerivation rec { + pname = "hex"; + version = "2.1.1"; - dontStrip = true; + src = fetchFromGitHub { + owner = "hexpm"; + repo = "hex"; + rev = "v${version}"; + sha256 = "sha256-pEfd2BqkVwZVbnka98MafJ/NRn94BHh+wM0i2Q5duTo="; + }; - buildInputs = [ elixir ]; + setupHook = writeText "setupHook.sh" '' + addToSearchPath ERL_LIBS "$1/lib/erlang/lib/" + ''; - buildPhase = '' - runHook preBuild - export HEX_OFFLINE=1 - export HEX_HOME=./ - export MIX_ENV=prod - mix compile - runHook postBuild - ''; + dontStrip = true; - installPhase = '' - runHook preInstall + buildInputs = [ elixir ]; - mkdir -p $out/lib/erlang/lib - cp -r ./_build/prod/lib/hex $out/lib/erlang/lib/ + buildPhase = '' + runHook preBuild + export HEX_OFFLINE=1 + export HEX_HOME=./ + export MIX_ENV=prod + mix compile + runHook postBuild + ''; - runHook postInstall - ''; + installPhase = '' + runHook preInstall - meta = { - description = "Package manager for the Erlang VM https://hex.pm"; - license = lib.licenses.mit; - homepage = "https://github.com/hexpm/hex"; - maintainers = with lib.maintainers; [ ericbmerritt ]; - }; + mkdir -p $out/lib/erlang/lib + cp -r ./_build/prod/lib/hex $out/lib/erlang/lib/ + + runHook postInstall + ''; + + meta = { + description = "Package manager for the Erlang VM https://hex.pm"; + license = lib.licenses.mit; + homepage = "https://github.com/hexpm/hex"; + maintainers = with lib.maintainers; [ ericbmerritt ]; + }; - passthru = { - env = shell self; + passthru = { + env = shell self; + }; }; -}; -in lib.fix pkg +in +lib.fix pkg diff --git a/pkgs/development/beam-modules/pgsql/default.nix b/pkgs/development/beam-modules/pgsql/default.nix index df6561b7cf1892..a6bd2e955e81a2 100644 --- a/pkgs/development/beam-modules/pgsql/default.nix +++ b/pkgs/development/beam-modules/pgsql/default.nix @@ -1,34 +1,44 @@ -{ lib, stdenv, fetchFromGitHub, buildRebar3 }: +{ + lib, + stdenv, + fetchFromGitHub, + buildRebar3, +}: let - shell = drv: stdenv.mkDerivation { - name = "interactive-shell-${drv.name}"; - buildInputs = [ drv ]; + shell = + drv: + stdenv.mkDerivation { + name = "interactive-shell-${drv.name}"; + buildInputs = [ drv ]; }; - pkg = self: buildRebar3 { - name = "pgsql"; - version = "25+beta.2"; + pkg = + self: + buildRebar3 { + name = "pgsql"; + version = "25+beta.2"; - src = fetchFromGitHub { + src = fetchFromGitHub { owner = "semiocast"; repo = "pgsql"; rev = "14f632bc89e464d82ce3ef12a67ed8c2adb5b60c"; sha256 = "17dcahiwlw61zhy8aq9rn46lwb35fb9q3372s4wmz01czm8c348w"; - }; + }; - dontStrip = true; + dontStrip = true; - meta = { - description = "Erlang PostgreSQL Driver"; - license = lib.licenses.mit; - homepage = "https://github.com/semiocast/pgsql"; - maintainers = with lib.maintainers; [ ericbmerritt ]; - }; + meta = { + description = "Erlang PostgreSQL Driver"; + license = lib.licenses.mit; + homepage = "https://github.com/semiocast/pgsql"; + maintainers = with lib.maintainers; [ ericbmerritt ]; + }; - passthru = { - env = shell self; - }; + passthru = { + env = shell self; + }; -}; -in lib.fix pkg + }; +in +lib.fix pkg diff --git a/pkgs/development/beam-modules/rebar3-nix/default.nix b/pkgs/development/beam-modules/rebar3-nix/default.nix index 50bd296583541a..f4c19515987369 100644 --- a/pkgs/development/beam-modules/rebar3-nix/default.nix +++ b/pkgs/development/beam-modules/rebar3-nix/default.nix @@ -1,4 +1,8 @@ -{ lib, buildRebar3, fetchFromGitHub }: +{ + lib, + buildRebar3, + fetchFromGitHub, +}: buildRebar3 rec { name = "rebar3_nix"; version = "0.1.1"; @@ -13,6 +17,9 @@ buildRebar3 rec { description = "nix integration for rebar3"; license = lib.licenses.bsd3; homepage = "https://github.com/erlang-nix/rebar3_nix"; - maintainers = with lib.maintainers; [ dlesl gleber ]; + maintainers = with lib.maintainers; [ + dlesl + gleber + ]; }; } diff --git a/pkgs/development/beam-modules/rebar3-release.nix b/pkgs/development/beam-modules/rebar3-release.nix index 621887d6cd124d..17f8bac62e48a8 100644 --- a/pkgs/development/beam-modules/rebar3-release.nix +++ b/pkgs/development/beam-modules/rebar3-release.nix @@ -1,37 +1,46 @@ -{ stdenv -, erlang -, rebar3WithPlugins -, openssl -, lib +{ + stdenv, + erlang, + rebar3WithPlugins, + openssl, + lib, }: -{ pname -, version -, src -, beamDeps ? [ ] -, buildPlugins ? [ ] -, checkouts ? null -, releaseType -, buildInputs ? [ ] -, setupHook ? null -, profile ? "default" -, installPhase ? null -, buildPhase ? null -, configurePhase ? null -, meta ? { } -, ... +{ + pname, + version, + src, + beamDeps ? [ ], + buildPlugins ? [ ], + checkouts ? null, + releaseType, + buildInputs ? [ ], + setupHook ? null, + profile ? "default", + installPhase ? null, + buildPhase ? null, + configurePhase ? null, + meta ? { }, + ... }@attrs: let - shell = drv: stdenv.mkDerivation { - name = "interactive-shell-${drv.pname}"; - buildInputs = [ drv ]; + shell = + drv: + stdenv.mkDerivation { + name = "interactive-shell-${drv.pname}"; + buildInputs = [ drv ]; + }; + + customPhases = lib.filterAttrs (_: v: v != null) { + inherit + setupHook + configurePhase + buildPhase + installPhase + ; }; - customPhases = lib.filterAttrs - (_: v: v != null) - { inherit setupHook configurePhase buildPhase installPhase; }; - # When using the `beamDeps` argument, it is important that we use # `rebar3WithPlugins` here even when there are no plugins. The vanilla # `rebar3` package is an escript archive with bundled dependencies which can @@ -43,65 +52,76 @@ let pkg = assert beamDeps != [ ] -> checkouts == null; - self: stdenv.mkDerivation (attrs // { - - name = "${pname}-${version}"; - inherit version pname; - - buildInputs = buildInputs ++ [ erlang rebar3 openssl ] ++ beamDeps; - - # ensure we strip any native binaries (eg. NIFs, ports) - stripDebugList = lib.optional (releaseType == "release") "rel"; - - inherit src; - - REBAR_IGNORE_DEPS = beamDeps != [ ]; - - configurePhase = '' - runHook preConfigure - ${lib.optionalString (checkouts != null) - "cp --no-preserve=all -R ${checkouts}/_checkouts ."} - runHook postConfigure - ''; - - buildPhase = '' - runHook preBuild - HOME=. DEBUG=1 rebar3 as ${profile} ${if releaseType == "escript" - then "escriptize" - else "release"} - runHook postBuild - ''; - - installPhase = '' - runHook preInstall - dir=${if releaseType == "escript" - then "bin" - else "rel"} - mkdir -p "$out/$dir" "$out/bin" - cp -R --preserve=mode "_build/${profile}/$dir" "$out" - ${lib.optionalString (releaseType == "release") - "find $out/rel/*/bin -type f -executable -exec ln -s -t $out/bin {} \\;"} - runHook postInstall - ''; - - # Release will generate a binary which will cause a read null byte failure, see #261354 - postInstall = lib.optionalString (releaseType == "escript") '' - for dir in $out/rel/*/erts-*; do - echo "ERTS found in $dir - removing references to erlang to reduce closure size" - for f in $dir/bin/{erl,start}; do - substituteInPlace "$f" --replace "${erlang}/lib/erlang" "''${dir/\/erts-*/}" + self: + stdenv.mkDerivation ( + attrs + // { + + name = "${pname}-${version}"; + inherit version pname; + + buildInputs = + buildInputs + ++ [ + erlang + rebar3 + openssl + ] + ++ beamDeps; + + # ensure we strip any native binaries (eg. NIFs, ports) + stripDebugList = lib.optional (releaseType == "release") "rel"; + + inherit src; + + REBAR_IGNORE_DEPS = beamDeps != [ ]; + + configurePhase = '' + runHook preConfigure + ${lib.optionalString (checkouts != null) "cp --no-preserve=all -R ${checkouts}/_checkouts ."} + runHook postConfigure + ''; + + buildPhase = '' + runHook preBuild + HOME=. DEBUG=1 rebar3 as ${profile} ${if releaseType == "escript" then "escriptize" else "release"} + runHook postBuild + ''; + + installPhase = '' + runHook preInstall + dir=${if releaseType == "escript" then "bin" else "rel"} + mkdir -p "$out/$dir" "$out/bin" + cp -R --preserve=mode "_build/${profile}/$dir" "$out" + ${lib.optionalString ( + releaseType == "release" + ) "find $out/rel/*/bin -type f -executable -exec ln -s -t $out/bin {} \\;"} + runHook postInstall + ''; + + # Release will generate a binary which will cause a read null byte failure, see #261354 + postInstall = lib.optionalString (releaseType == "escript") '' + for dir in $out/rel/*/erts-*; do + echo "ERTS found in $dir - removing references to erlang to reduce closure size" + for f in $dir/bin/{erl,start}; do + substituteInPlace "$f" --replace "${erlang}/lib/erlang" "''${dir/\/erts-*/}" + done done - done - ''; - - meta = { - inherit (erlang.meta) platforms; - } // meta; - - passthru = ({ - packageName = pname; - env = shell self; - } // (if attrs ? passthru then attrs.passthru else { })); - } // customPhases); + ''; + + meta = { + inherit (erlang.meta) platforms; + } // meta; + + passthru = ( + { + packageName = pname; + env = shell self; + } + // (if attrs ? passthru then attrs.passthru else { }) + ); + } + // customPhases + ); in lib.fix pkg diff --git a/pkgs/development/beam-modules/webdriver/default.nix b/pkgs/development/beam-modules/webdriver/default.nix index 131fd03d86dc7e..f8abc24c14eddd 100644 --- a/pkgs/development/beam-modules/webdriver/default.nix +++ b/pkgs/development/beam-modules/webdriver/default.nix @@ -1,40 +1,51 @@ -{ lib, stdenv, fetchFromGitHub, writeText, erlang }: +{ + lib, + stdenv, + fetchFromGitHub, + writeText, + erlang, +}: let - shell = drv: stdenv.mkDerivation { - name = "interactive-shell-${drv.name}"; - buildInputs = [ drv ]; - }; - - pkg = self: stdenv.mkDerivation { - pname = "webdriver"; - version = "0.pre+unstable=2015-02-08"; - - src = fetchFromGitHub { - owner = "Quviq"; - repo = "webdrv"; - rev = "7ceaf1f67d834e841ca0133b4bf899a9fa2db6bb"; - sha256 = "1pq6pmlr6xb4hv2fvmlrvzd8c70kdcidlgjv4p8n9pwvkif0cb87"; + shell = + drv: + stdenv.mkDerivation { + name = "interactive-shell-${drv.name}"; + buildInputs = [ drv ]; }; - setupHook = writeText "setupHook.sh" '' - addToSearchPath ERL_LIBS "$1/lib/erlang/lib/" - ''; + pkg = + self: + stdenv.mkDerivation { + pname = "webdriver"; + version = "0.pre+unstable=2015-02-08"; - buildInputs = [ erlang ]; + src = fetchFromGitHub { + owner = "Quviq"; + repo = "webdrv"; + rev = "7ceaf1f67d834e841ca0133b4bf899a9fa2db6bb"; + sha256 = "1pq6pmlr6xb4hv2fvmlrvzd8c70kdcidlgjv4p8n9pwvkif0cb87"; + }; - installFlags = [ "PREFIX=$(out)/lib/erlang/lib" ]; + setupHook = writeText "setupHook.sh" '' + addToSearchPath ERL_LIBS "$1/lib/erlang/lib/" + ''; - meta = { - description = "WebDriver implementation in Erlang"; - license = lib.licenses.mit; - homepage = "https://github.com/Quviq/webdrv"; - maintainers = with lib.maintainers; [ ericbmerritt ]; - }; + buildInputs = [ erlang ]; - passthru = { - env = shell self; - }; + installFlags = [ "PREFIX=$(out)/lib/erlang/lib" ]; + + meta = { + description = "WebDriver implementation in Erlang"; + license = lib.licenses.mit; + homepage = "https://github.com/Quviq/webdrv"; + maintainers = with lib.maintainers; [ ericbmerritt ]; + }; - }; -in lib.fix pkg + passthru = { + env = shell self; + }; + + }; +in +lib.fix pkg diff --git a/pkgs/development/compilers/abcl/default.nix b/pkgs/development/compilers/abcl/default.nix index 343363332bf60d..a90e948926a29d 100644 --- a/pkgs/development/compilers/abcl/default.nix +++ b/pkgs/development/compilers/abcl/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, writeShellScriptBin -, fetchurl -, ant -, jdk -, makeWrapper -, stripJavaArchivesHook +{ + lib, + stdenv, + writeShellScriptBin, + fetchurl, + ant, + jdk, + makeWrapper, + stripJavaArchivesHook, }: let diff --git a/pkgs/development/compilers/adoptopenjdk-icedtea-web/default.nix b/pkgs/development/compilers/adoptopenjdk-icedtea-web/default.nix index f5645f563de32f..0db3e41bafac2a 100644 --- a/pkgs/development/compilers/adoptopenjdk-icedtea-web/default.nix +++ b/pkgs/development/compilers/adoptopenjdk-icedtea-web/default.nix @@ -1,4 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, cargo, rustc, autoreconfHook, jdk, glib, firefox-unwrapped, zip, pkg-config, npapi_sdk, bash, bc }: +{ + lib, + stdenv, + fetchFromGitHub, + cargo, + rustc, + autoreconfHook, + jdk, + glib, + firefox-unwrapped, + zip, + pkg-config, + npapi_sdk, + bash, + bc, +}: stdenv.mkDerivation rec { pname = "adoptopenjdk-icedtea-web"; @@ -12,8 +27,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-hpEVWG9ltNDL/0EFJjgQRRce+BLcCO4ZERULYZxyC1o="; }; - nativeBuildInputs = [ autoreconfHook pkg-config bc ]; - buildInputs = [ cargo rustc glib firefox-unwrapped zip npapi_sdk ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + bc + ]; + buildInputs = [ + cargo + rustc + glib + firefox-unwrapped + zip + npapi_sdk + ]; preConfigure = '' configureFlagsArray+=("BIN_BASH=${bash}/bin/bash") diff --git a/pkgs/development/compilers/alan/2.nix b/pkgs/development/compilers/alan/2.nix index ce175dba687a3b..b05415b629bb40 100644 --- a/pkgs/development/compilers/alan/2.nix +++ b/pkgs/development/compilers/alan/2.nix @@ -1,4 +1,7 @@ -{ stdenv, lib, fetchFromGitHub +{ + stdenv, + lib, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/compilers/alan/default.nix b/pkgs/development/compilers/alan/default.nix index 296f9331c81520..3a3fcfef81f2ab 100644 --- a/pkgs/development/compilers/alan/default.nix +++ b/pkgs/development/compilers/alan/default.nix @@ -1,5 +1,11 @@ -{ stdenv, lib, fetchFromGitHub -, cgreen, openjdk, pkg-config, which +{ + stdenv, + lib, + fetchFromGitHub, + cgreen, + openjdk, + pkg-config, + which, }: stdenv.mkDerivation rec { @@ -35,7 +41,9 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cgreen - openjdk pkg-config which + openjdk + pkg-config + which ]; meta = with lib; { diff --git a/pkgs/development/compilers/armips/default.nix b/pkgs/development/compilers/armips/default.nix index 1f0094a203cf94..c8386845b35abe 100644 --- a/pkgs/development/compilers/armips/default.nix +++ b/pkgs/development/compilers/armips/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, cmake }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "armips"; diff --git a/pkgs/development/compilers/ballerina/default.nix b/pkgs/development/compilers/ballerina/default.nix index 5081ba45ca8b13..9fa4dcbfdd23bd 100644 --- a/pkgs/development/compilers/ballerina/default.nix +++ b/pkgs/development/compilers/ballerina/default.nix @@ -1,8 +1,18 @@ -{ ballerina, lib, writeText, runCommand, makeWrapper, fetchzip, stdenv, openjdk }: +{ + ballerina, + lib, + writeText, + runCommand, + makeWrapper, + fetchzip, + stdenv, + openjdk, +}: let version = "2201.10.3"; codeName = "swan-lake"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "ballerina"; inherit version; @@ -22,18 +32,20 @@ in stdenv.mkDerivation { wrapProgram $out/bin/bal --set JAVA_HOME ${openjdk} ''; - passthru.tests.smokeTest = let - helloWorld = writeText "hello-world.bal" '' - import ballerina/io; - public function main() { - io:println("Hello, World!"); - } + passthru.tests.smokeTest = + let + helloWorld = writeText "hello-world.bal" '' + import ballerina/io; + public function main() { + io:println("Hello, World!"); + } + ''; + in + runCommand "ballerina-${version}-smoketest" { } '' + ${ballerina}/bin/bal run ${helloWorld} >$out + read result <$out + [[ $result = "Hello, World!" ]] ''; - in runCommand "ballerina-${version}-smoketest" { } '' - ${ballerina}/bin/bal run ${helloWorld} >$out - read result <$out - [[ $result = "Hello, World!" ]] - ''; meta = with lib; { description = "Open-source programming language for the cloud"; diff --git a/pkgs/development/compilers/binaryen/default.nix b/pkgs/development/compilers/binaryen/default.nix index c12c62ab45ca12..d014a6cfd1fdfc 100644 --- a/pkgs/development/compilers/binaryen/default.nix +++ b/pkgs/development/compilers/binaryen/default.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, cmake, python3, fetchFromGitHub, emscripten, - gtest, lit, nodejs, filecheck +{ + lib, + stdenv, + cmake, + python3, + fetchFromGitHub, + emscripten, + gtest, + lit, + nodejs, + filecheck, }: let testsuite = fetchFromGitHub { @@ -9,53 +18,74 @@ let hash = "sha256-yvZ5AZTPUA6nsD3xpFC0VLthiu2CxVto66RTXBXXeJM="; }; in - stdenv.mkDerivation rec { - pname = "binaryen"; - version = "119"; +stdenv.mkDerivation rec { + pname = "binaryen"; + version = "119"; - src = fetchFromGitHub { - owner = "WebAssembly"; - repo = "binaryen"; - rev = "version_${version}"; - hash = "sha256-JYXtN3CW4qm/nnjGRvv3GxQ0x9O9wHtNYQLqHIYTTOA="; - }; + src = fetchFromGitHub { + owner = "WebAssembly"; + repo = "binaryen"; + rev = "version_${version}"; + hash = "sha256-JYXtN3CW4qm/nnjGRvv3GxQ0x9O9wHtNYQLqHIYTTOA="; + }; - nativeBuildInputs = [ cmake python3 ]; + nativeBuildInputs = [ + cmake + python3 + ]; - preConfigure = '' - if [ $doCheck -eq 1 ]; then - sed -i '/googletest/d' third_party/CMakeLists.txt - rmdir test/spec/testsuite - ln -s ${testsuite} test/spec/testsuite - else - cmakeFlagsArray=($cmakeFlagsArray -DBUILD_TESTS=0) - fi - ''; + preConfigure = '' + if [ $doCheck -eq 1 ]; then + sed -i '/googletest/d' third_party/CMakeLists.txt + rmdir test/spec/testsuite + ln -s ${testsuite} test/spec/testsuite + else + cmakeFlagsArray=($cmakeFlagsArray -DBUILD_TESTS=0) + fi + ''; - nativeCheckInputs = [ gtest lit nodejs filecheck ]; - checkPhase = '' - LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$PWD/lib python3 ../check.py $tests - ''; + nativeCheckInputs = [ + gtest + lit + nodejs + filecheck + ]; + checkPhase = '' + LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$PWD/lib python3 ../check.py $tests + ''; - tests = [ - "version" "wasm-opt" "wasm-dis" - "crash" "dylink" "ctor-eval" - "wasm-metadce" "wasm-reduce" "spec" - "lld" "wasm2js" "validator" - "example" "unit" - # "binaryenjs" "binaryenjs_wasm" # not building this - "lit" "gtest" - ]; - doCheck = stdenv.isLinux; + tests = [ + "version" + "wasm-opt" + "wasm-dis" + "crash" + "dylink" + "ctor-eval" + "wasm-metadce" + "wasm-reduce" + "spec" + "lld" + "wasm2js" + "validator" + "example" + "unit" + # "binaryenjs" "binaryenjs_wasm" # not building this + "lit" + "gtest" + ]; + doCheck = stdenv.isLinux; - meta = with lib; { - homepage = "https://github.com/WebAssembly/binaryen"; - description = "Compiler infrastructure and toolchain library for WebAssembly, in C++"; - platforms = platforms.all; - maintainers = with maintainers; [ asppsa willcohen ]; - license = licenses.asl20; - }; - passthru.tests = { - inherit emscripten; - }; - } + meta = with lib; { + homepage = "https://github.com/WebAssembly/binaryen"; + description = "Compiler infrastructure and toolchain library for WebAssembly, in C++"; + platforms = platforms.all; + maintainers = with maintainers; [ + asppsa + willcohen + ]; + license = licenses.asl20; + }; + passthru.tests = { + inherit emscripten; + }; +} diff --git a/pkgs/development/compilers/c0/default.nix b/pkgs/development/compilers/c0/default.nix index 8dbb1627db3a7c..4f82e9cf2ed2e8 100644 --- a/pkgs/development/compilers/c0/default.nix +++ b/pkgs/development/compilers/c0/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromBitbucket -, mlton -, pkg-config -, getopt -, boehmgc -, darwin -, libbacktrace -, libpng -, ncurses -, readline -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromBitbucket, + mlton, + pkg-config, + getopt, + boehmgc, + darwin, + libbacktrace, + libpng, + ncurses, + readline, + unstableGitUpdater, }: stdenv.mkDerivation rec { @@ -28,18 +29,20 @@ stdenv.mkDerivation rec { ./use-system-libraries.patch ]; - postPatch = '' - substituteInPlace cc0/Makefile \ - --replace '$(shell ./get_version.sh)' '${version}' - substituteInPlace cc0/compiler/bin/buildid \ - --replace '`../get_version.sh`' '${version}' \ - --replace '`date`' '1970-01-01T00:00:00Z' \ - --replace '`hostname`' 'nixpkgs' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - for f in cc0/compiler/bin/coin-o0-support cc0/compiler/bin/cc0-o0-support; do - substituteInPlace $f --replace '$(brew --prefix gnu-getopt)' '${getopt}' - done - ''; + postPatch = + '' + substituteInPlace cc0/Makefile \ + --replace '$(shell ./get_version.sh)' '${version}' + substituteInPlace cc0/compiler/bin/buildid \ + --replace '`../get_version.sh`' '${version}' \ + --replace '`date`' '1970-01-01T00:00:00Z' \ + --replace '`hostname`' 'nixpkgs' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + for f in cc0/compiler/bin/coin-o0-support cc0/compiler/bin/cc0-o0-support; do + substituteInPlace $f --replace '$(brew --prefix gnu-getopt)' '${getopt}' + done + ''; preConfigure = '' cd cc0/ diff --git a/pkgs/development/compilers/ccl/default.nix b/pkgs/development/compilers/ccl/default.nix index 7e7f6004c466a4..f76167f0697d0d 100644 --- a/pkgs/development/compilers/ccl/default.nix +++ b/pkgs/development/compilers/ccl/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, bootstrap_cmds, coreutils, glibc, m4, runtimeShell }: +{ + lib, + stdenv, + fetchurl, + bootstrap_cmds, + coreutils, + glibc, + m4, + runtimeShell, +}: let options = rec { @@ -29,9 +38,12 @@ let }; armv6l-linux = armv7l-linux; }; - cfg = options.${stdenv.hostPlatform.system} or (throw "missing source url for platform ${stdenv.hostPlatform.system}"); + cfg = + options.${stdenv.hostPlatform.system} + or (throw "missing source url for platform ${stdenv.hostPlatform.system}"); -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "ccl"; version = "1.12.2"; @@ -40,28 +52,42 @@ in stdenv.mkDerivation rec { sha256 = cfg.sha256; }; - buildInputs = if stdenv.hostPlatform.isDarwin then [ bootstrap_cmds m4 ] else [ glibc m4 ]; + buildInputs = + if stdenv.hostPlatform.isDarwin then + [ + bootstrap_cmds + m4 + ] + else + [ + glibc + m4 + ]; CCL_RUNTIME = cfg.runtime; CCL_KERNEL = cfg.kernel; - postPatch = if stdenv.hostPlatform.isDarwin then '' - substituteInPlace lisp-kernel/${CCL_KERNEL}/Makefile \ - --replace "M4 = gm4" "M4 = m4" \ - --replace "dtrace" "/usr/sbin/dtrace" \ - --replace "/bin/rm" "${coreutils}/bin/rm" \ - --replace "/bin/echo" "${coreutils}/bin/echo" + postPatch = + if stdenv.hostPlatform.isDarwin then + '' + substituteInPlace lisp-kernel/${CCL_KERNEL}/Makefile \ + --replace "M4 = gm4" "M4 = m4" \ + --replace "dtrace" "/usr/sbin/dtrace" \ + --replace "/bin/rm" "${coreutils}/bin/rm" \ + --replace "/bin/echo" "${coreutils}/bin/echo" - substituteInPlace lisp-kernel/m4macros.m4 \ - --replace "/bin/pwd" "${coreutils}/bin/pwd" - '' else '' - substituteInPlace lisp-kernel/${CCL_KERNEL}/Makefile \ - --replace "/bin/rm" "${coreutils}/bin/rm" \ - --replace "/bin/echo" "${coreutils}/bin/echo" + substituteInPlace lisp-kernel/m4macros.m4 \ + --replace "/bin/pwd" "${coreutils}/bin/pwd" + '' + else + '' + substituteInPlace lisp-kernel/${CCL_KERNEL}/Makefile \ + --replace "/bin/rm" "${coreutils}/bin/rm" \ + --replace "/bin/echo" "${coreutils}/bin/echo" - substituteInPlace lisp-kernel/m4macros.m4 \ - --replace "/bin/pwd" "${coreutils}/bin/pwd" - ''; + substituteInPlace lisp-kernel/m4macros.m4 \ + --replace "/bin/pwd" "${coreutils}/bin/pwd" + ''; buildPhase = '' make -C lisp-kernel/${CCL_KERNEL} clean @@ -84,12 +110,12 @@ in stdenv.mkDerivation rec { meta = with lib; { # assembler failures during build, x86_64-darwin broken since 2020-10-14 - broken = (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64); + broken = (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64); description = "Clozure Common Lisp"; - homepage = "https://ccl.clozure.com/"; - license = licenses.asl20; + homepage = "https://ccl.clozure.com/"; + license = licenses.asl20; mainProgram = "ccl"; maintainers = lib.teams.lisp.members; - platforms = attrNames options; + platforms = attrNames options; }; } diff --git a/pkgs/development/compilers/chicken/4/chicken.nix b/pkgs/development/compilers/chicken/4/chicken.nix index a36ef4569e3051..3ac84e1fdbe0e5 100644 --- a/pkgs/development/compilers/chicken/4/chicken.nix +++ b/pkgs/development/compilers/chicken/4/chicken.nix @@ -1,13 +1,26 @@ -{ lib, stdenv, fetchurl, makeWrapper, darwin, bootstrap-chicken ? null }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + darwin, + bootstrap-chicken ? null, +}: let version = "4.13.0"; - platform = with stdenv; - if isDarwin then "macosx" - else if isCygwin then "cygwin" - else if (isFreeBSD || isOpenBSD) then "bsd" - else if isSunOS then "solaris" - else "linux"; # Should be a sane default + platform = + with stdenv; + if isDarwin then + "macosx" + else if isCygwin then + "cygwin" + else if (isFreeBSD || isOpenBSD) then + "bsd" + else if isSunOS then + "solaris" + else + "linux"; # Should be a sane default in stdenv.mkDerivation { pname = "chicken"; @@ -30,16 +43,19 @@ stdenv.mkDerivation { setupHook = lib.optional (bootstrap-chicken != null) ./setup-hook.sh; # -fno-strict-overflow is not a supported argument in clang on darwin - hardeningDisable = lib.optionals stdenv.hostPlatform.isDarwin ["strictoverflow"]; - - makeFlags = [ - "PLATFORM=${platform}" "PREFIX=$(out)" - "VARDIR=$(out)/var/lib" - ] ++ (lib.optionals stdenv.hostPlatform.isDarwin [ - "XCODE_TOOL_PATH=${darwin.binutils.bintools}/bin" - "C_COMPILER=$(CC)" - "POSTINSTALL_PROGRAM=${stdenv.cc.targetPrefix}install_name_tool" - ]); + hardeningDisable = lib.optionals stdenv.hostPlatform.isDarwin [ "strictoverflow" ]; + + makeFlags = + [ + "PLATFORM=${platform}" + "PREFIX=$(out)" + "VARDIR=$(out)/var/lib" + ] + ++ (lib.optionals stdenv.hostPlatform.isDarwin [ + "XCODE_TOOL_PATH=${darwin.binutils.bintools}/bin" + "C_COMPILER=$(CC)" + "POSTINSTALL_PROGRAM=${stdenv.cc.targetPrefix}install_name_tool" + ]); # We need a bootstrap-chicken to regenerate the c-files after # applying a patch to add support for CHICKEN_REPOSITORY_EXTRA @@ -47,11 +63,13 @@ stdenv.mkDerivation { ./0001-Introduce-CHICKEN_REPOSITORY_EXTRA.patch ]; - nativeBuildInputs = [ - makeWrapper - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - darwin.autoSignDarwinBinariesHook - ]; + nativeBuildInputs = + [ + makeWrapper + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + darwin.autoSignDarwinBinariesHook + ]; buildInputs = lib.optionals (bootstrap-chicken != null) [ bootstrap-chicken diff --git a/pkgs/development/compilers/chicken/4/default.nix b/pkgs/development/compilers/chicken/4/default.nix index 7502a7a9f1e723..bb86fe0ed3c73f 100644 --- a/pkgs/development/compilers/chicken/4/default.nix +++ b/pkgs/development/compilers/chicken/4/default.nix @@ -1,9 +1,11 @@ -{ lib, newScope } : +{ lib, newScope }: let callPackage = newScope self; self = { - pkgs = self // { recurseForDerivations = false; }; + pkgs = self // { + recurseForDerivations = false; + }; fetchegg = callPackage ./fetchegg { }; @@ -18,4 +20,5 @@ let egg2nix = callPackage ./egg2nix.nix { }; }; -in self +in +self diff --git a/pkgs/development/compilers/chicken/4/egg2nix.nix b/pkgs/development/compilers/chicken/4/egg2nix.nix index e175f17e1ab7e9..2adb096e209970 100644 --- a/pkgs/development/compilers/chicken/4/egg2nix.nix +++ b/pkgs/development/compilers/chicken/4/egg2nix.nix @@ -1,4 +1,9 @@ -{ lib, eggDerivation, fetchFromGitHub, chickenEggs }: +{ + lib, + eggDerivation, + fetchFromGitHub, + chickenEggs, +}: # Note: This mostly reimplements the default.nix already contained in # the tarball. Is there a nicer way than duplicating code? @@ -15,7 +20,8 @@ eggDerivation rec { }; buildInputs = with chickenEggs; [ - matchable http-client + matchable + http-client ]; meta = { diff --git a/pkgs/development/compilers/chicken/4/eggDerivation.nix b/pkgs/development/compilers/chicken/4/eggDerivation.nix index 96b3612b34bafa..b36cfce94d843b 100644 --- a/pkgs/development/compilers/chicken/4/eggDerivation.nix +++ b/pkgs/development/compilers/chicken/4/eggDerivation.nix @@ -1,49 +1,61 @@ -{ lib, stdenv, chicken, makeWrapper }: -{ name, src -, buildInputs ? [] -, chickenInstallFlags ? [] -, cscOptions ? [] -, ...} @ args: +{ + lib, + stdenv, + chicken, + makeWrapper, +}: +{ + name, + src, + buildInputs ? [ ], + chickenInstallFlags ? [ ], + cscOptions ? [ ], + ... +}@args: let libPath = "${chicken}/var/lib/chicken/${toString chicken.binaryVersion}/"; overrides = import ./overrides.nix; baseName = lib.getName name; - override = if builtins.hasAttr baseName overrides - then - builtins.getAttr baseName overrides - else - {}; + override = if builtins.hasAttr baseName overrides then builtins.getAttr baseName overrides else { }; in -stdenv.mkDerivation ({ - name = "chicken-${name}"; - propagatedBuildInputs = buildInputs; - nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ chicken ]; - - CSC_OPTIONS = lib.concatStringsSep " " cscOptions; - - CHICKEN_REPOSITORY = libPath; - CHICKEN_INSTALL_PREFIX = "$out"; - - installPhase = '' - runHook preInstall - - chicken-install -p $out ${lib.concatStringsSep " " chickenInstallFlags} - - for f in $out/bin/* - do - wrapProgram $f \ - --set CHICKEN_REPOSITORY $CHICKEN_REPOSITORY \ - --prefix CHICKEN_REPOSITORY_EXTRA : "$out/lib/chicken/${toString chicken.binaryVersion}/:$CHICKEN_REPOSITORY_EXTRA" \ - --prefix CHICKEN_INCLUDE_PATH \; "$CHICKEN_INCLUDE_PATH;$out/share/" \ - --prefix PATH : "$out/bin:${chicken}/bin:$CHICKEN_REPOSITORY_EXTRA:$CHICKEN_REPOSITORY" - done - - runHook postInstall - ''; - - meta = { - inherit (chicken.meta) platforms; - } // args.meta or {}; -} // (builtins.removeAttrs args ["name" "buildInputs" "meta"]) // override) +stdenv.mkDerivation ( + { + name = "chicken-${name}"; + propagatedBuildInputs = buildInputs; + nativeBuildInputs = [ makeWrapper ]; + buildInputs = [ chicken ]; + + CSC_OPTIONS = lib.concatStringsSep " " cscOptions; + + CHICKEN_REPOSITORY = libPath; + CHICKEN_INSTALL_PREFIX = "$out"; + + installPhase = '' + runHook preInstall + + chicken-install -p $out ${lib.concatStringsSep " " chickenInstallFlags} + + for f in $out/bin/* + do + wrapProgram $f \ + --set CHICKEN_REPOSITORY $CHICKEN_REPOSITORY \ + --prefix CHICKEN_REPOSITORY_EXTRA : "$out/lib/chicken/${toString chicken.binaryVersion}/:$CHICKEN_REPOSITORY_EXTRA" \ + --prefix CHICKEN_INCLUDE_PATH \; "$CHICKEN_INCLUDE_PATH;$out/share/" \ + --prefix PATH : "$out/bin:${chicken}/bin:$CHICKEN_REPOSITORY_EXTRA:$CHICKEN_REPOSITORY" + done + + runHook postInstall + ''; + + meta = { + inherit (chicken.meta) platforms; + } // args.meta or { }; + } + // (builtins.removeAttrs args [ + "name" + "buildInputs" + "meta" + ]) + // override +) diff --git a/pkgs/development/compilers/chicken/4/eggs.nix b/pkgs/development/compilers/chicken/4/eggs.nix index 8c96caca262363..ea952b844d8b4f 100644 --- a/pkgs/development/compilers/chicken/4/eggs.nix +++ b/pkgs/development/compilers/chicken/4/eggs.nix @@ -12,7 +12,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -26,7 +26,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -73,7 +73,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -87,7 +87,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -101,7 +101,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -135,4 +135,3 @@ rec { ]; }; } - diff --git a/pkgs/development/compilers/chicken/4/fetchegg/default.nix b/pkgs/development/compilers/chicken/4/fetchegg/default.nix index 23c5760b4bce4a..5d51a5cd0fa556 100644 --- a/pkgs/development/compilers/chicken/4/fetchegg/default.nix +++ b/pkgs/development/compilers/chicken/4/fetchegg/default.nix @@ -1,25 +1,33 @@ # Fetches a chicken egg from henrietta using `chicken-install -r' # See: http://wiki.call-cc.org/chicken-projects/egg-index-4.html -{ lib, stdenvNoCC, chicken }: -{ name, version, md5 ? "", sha256 ? "" }: +{ + lib, + stdenvNoCC, + chicken, +}: +{ + name, + version, + md5 ? "", + sha256 ? "", +}: if md5 != "" then throw "fetchegg does not support md5 anymore, please use sha256" else -stdenvNoCC.mkDerivation { - name = "chicken-${name}-export-${version}"; - builder = ./builder.sh; - nativeBuildInputs = [ chicken ]; + stdenvNoCC.mkDerivation { + name = "chicken-${name}-export-${version}"; + builder = ./builder.sh; + nativeBuildInputs = [ chicken ]; - outputHashAlgo = "sha256"; - outputHashMode = "recursive"; - outputHash = sha256; + outputHashAlgo = "sha256"; + outputHashMode = "recursive"; + outputHash = sha256; - inherit version; + inherit version; - eggName = name; - - impureEnvVars = lib.fetchers.proxyImpureEnvVars; -} + eggName = name; + impureEnvVars = lib.fetchers.proxyImpureEnvVars; + } diff --git a/pkgs/development/compilers/chicken/5/chicken.nix b/pkgs/development/compilers/chicken/5/chicken.nix index 53b4cc9024d55a..4d1871fb52f5b9 100644 --- a/pkgs/development/compilers/chicken/5/chicken.nix +++ b/pkgs/development/compilers/chicken/5/chicken.nix @@ -1,12 +1,26 @@ -{ lib, stdenv, fetchurl, makeWrapper, darwin, bootstrap-chicken ? null, testers }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + darwin, + bootstrap-chicken ? null, + testers, +}: let - platform = with stdenv; - if isDarwin then "macosx" - else if isCygwin then "cygwin" - else if (isFreeBSD || isOpenBSD) then "bsd" - else if isSunOS then "solaris" - else "linux"; # Should be a sane default + platform = + with stdenv; + if isDarwin then + "macosx" + else if isCygwin then + "cygwin" + else if (isFreeBSD || isOpenBSD) then + "bsd" + else if isSunOS then + "solaris" + else + "linux"; # Should be a sane default in stdenv.mkDerivation (finalAttrs: { pname = "chicken"; @@ -30,26 +44,31 @@ stdenv.mkDerivation (finalAttrs: { # -fno-strict-overflow is not a supported argument in clang hardeningDisable = lib.optionals stdenv.cc.isClang [ "strictoverflow" ]; - makeFlags = [ - "PLATFORM=${platform}" - "PREFIX=$(out)" - "C_COMPILER=$(CC)" - "CXX_COMPILER=$(CXX)" - ] ++ (lib.optionals stdenv.hostPlatform.isDarwin [ - "XCODE_TOOL_PATH=${darwin.binutils.bintools}/bin" - "LINKER_OPTIONS=-headerpad_max_install_names" - "POSTINSTALL_PROGRAM=install_name_tool" - ]) ++ (lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "HOSTSYSTEM=${stdenv.hostPlatform.config}" - "TARGET_C_COMPILER=${stdenv.cc}/bin/${stdenv.cc.targetPrefix}cc" - "TARGET_CXX_COMPILER=${stdenv.cc}/bin/${stdenv.cc.targetPrefix}c++" - ]); + makeFlags = + [ + "PLATFORM=${platform}" + "PREFIX=$(out)" + "C_COMPILER=$(CC)" + "CXX_COMPILER=$(CXX)" + ] + ++ (lib.optionals stdenv.hostPlatform.isDarwin [ + "XCODE_TOOL_PATH=${darwin.binutils.bintools}/bin" + "LINKER_OPTIONS=-headerpad_max_install_names" + "POSTINSTALL_PROGRAM=install_name_tool" + ]) + ++ (lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "HOSTSYSTEM=${stdenv.hostPlatform.config}" + "TARGET_C_COMPILER=${stdenv.cc}/bin/${stdenv.cc.targetPrefix}cc" + "TARGET_CXX_COMPILER=${stdenv.cc}/bin/${stdenv.cc.targetPrefix}c++" + ]); - nativeBuildInputs = [ - makeWrapper - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - darwin.autoSignDarwinBinariesHook - ]; + nativeBuildInputs = + [ + makeWrapper + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + darwin.autoSignDarwinBinariesHook + ]; buildInputs = lib.optionals (bootstrap-chicken != null) [ bootstrap-chicken @@ -69,7 +88,11 @@ stdenv.mkDerivation (finalAttrs: { meta = { homepage = "https://call-cc.org/"; license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [ corngood nagy konst-aa ]; + maintainers = with lib.maintainers; [ + corngood + nagy + konst-aa + ]; platforms = lib.platforms.unix; description = "Portable compiler for the Scheme programming language"; longDescription = '' diff --git a/pkgs/development/compilers/chicken/5/default.nix b/pkgs/development/compilers/chicken/5/default.nix index 61bf45dd54ac7a..a3fe5a6da5acfd 100644 --- a/pkgs/development/compilers/chicken/5/default.nix +++ b/pkgs/development/compilers/chicken/5/default.nix @@ -1,12 +1,21 @@ -{ lib, newScope, fetchurl }: +{ + lib, + newScope, + fetchurl, +}: lib.makeScope newScope (self: { - fetchegg = { pname, version, sha256, ... }: + fetchegg = + { + pname, + version, + sha256, + ... + }: fetchurl { inherit sha256; - url = - "https://code.call-cc.org/egg-tarballs/5/${pname}/${pname}-${version}.tar.gz"; + url = "https://code.call-cc.org/egg-tarballs/5/${pname}/${pname}-${version}.tar.gz"; }; eggDerivation = self.callPackage ./eggDerivation.nix { }; @@ -15,44 +24,57 @@ lib.makeScope newScope (self: { bootstrap-chicken = self.chicken.override { bootstrap-chicken = null; }; }; - chickenEggs = lib.recurseIntoAttrs (lib.makeScope self.newScope (eggself: - (lib.mapAttrs - (pname: - eggData@{ version, synopsis, dependencies, license, ... }: + chickenEggs = lib.recurseIntoAttrs ( + lib.makeScope self.newScope ( + eggself: + (lib.mapAttrs ( + pname: + eggData@{ + version, + synopsis, + dependencies, + license, + ... + }: self.eggDerivation { name = "${pname}-${version}"; src = self.fetchegg (eggData // { inherit pname; }); buildInputs = map (x: eggself.${x}) dependencies; - meta.homepage = - "https://code.call-cc.org/cgi-bin/gitweb.cgi?p=eggs-5-latest.git;a=tree;f=${pname}/${version}"; + meta.homepage = "https://code.call-cc.org/cgi-bin/gitweb.cgi?p=eggs-5-latest.git;a=tree;f=${pname}/${version}"; meta.description = synopsis; - meta.license = (lib.licenses // { - "agpl" = lib.licenses.agpl3Only; - "artistic" = lib.licenses.artistic2; - "bsd" = lib.licenses.bsd3; - "bsd-1-clause" = lib.licenses.bsd1; - "bsd-2-clause" = lib.licenses.bsd2; - "bsd-3-clause" = lib.licenses.bsd3; - "gpl" = lib.licenses.gpl3Only; - "gpl-2" = lib.licenses.gpl2Only; - "gplv2" = lib.licenses.gpl2Only; - "gpl-3" = lib.licenses.gpl3Only; - "gpl-3.0" = lib.licenses.gpl3Only; - "gplv3" = lib.licenses.gpl3Only; - "lgpl" = lib.licenses.lgpl3Only; - "lgpl-2" = lib.licenses.lgpl2Only; - "lgpl-2.0+" = lib.licenses.lgpl2Plus; - "lgpl-2.1" = lib.licenses.lgpl21Only; - "lgpl-2.1-or-later" = lib.licenses.lgpl21Plus; - "lgpl-3" = lib.licenses.lgpl3Only; - "lgplv3" = lib.licenses.lgpl3Only; - "public-domain" = lib.licenses.publicDomain; - "srfi" = lib.licenses.bsd3; - "unicode" = lib.licenses.ucd; - "zlib-acknowledgement" = lib.licenses.zlib; - }).${license} or license; - }) - (lib.importTOML ./deps.toml)))); + meta.license = + ( + lib.licenses + // { + "agpl" = lib.licenses.agpl3Only; + "artistic" = lib.licenses.artistic2; + "bsd" = lib.licenses.bsd3; + "bsd-1-clause" = lib.licenses.bsd1; + "bsd-2-clause" = lib.licenses.bsd2; + "bsd-3-clause" = lib.licenses.bsd3; + "gpl" = lib.licenses.gpl3Only; + "gpl-2" = lib.licenses.gpl2Only; + "gplv2" = lib.licenses.gpl2Only; + "gpl-3" = lib.licenses.gpl3Only; + "gpl-3.0" = lib.licenses.gpl3Only; + "gplv3" = lib.licenses.gpl3Only; + "lgpl" = lib.licenses.lgpl3Only; + "lgpl-2" = lib.licenses.lgpl2Only; + "lgpl-2.0+" = lib.licenses.lgpl2Plus; + "lgpl-2.1" = lib.licenses.lgpl21Only; + "lgpl-2.1-or-later" = lib.licenses.lgpl21Plus; + "lgpl-3" = lib.licenses.lgpl3Only; + "lgplv3" = lib.licenses.lgpl3Only; + "public-domain" = lib.licenses.publicDomain; + "srfi" = lib.licenses.bsd3; + "unicode" = lib.licenses.ucd; + "zlib-acknowledgement" = lib.licenses.zlib; + } + ).${license} or license; + } + ) (lib.importTOML ./deps.toml)) + ) + ); egg2nix = self.callPackage ./egg2nix.nix { }; diff --git a/pkgs/development/compilers/chicken/5/egg2nix.nix b/pkgs/development/compilers/chicken/5/egg2nix.nix index dfef7c6cd236a5..64393bff217328 100644 --- a/pkgs/development/compilers/chicken/5/egg2nix.nix +++ b/pkgs/development/compilers/chicken/5/egg2nix.nix @@ -1,4 +1,9 @@ -{ lib, eggDerivation, fetchFromGitHub, chickenEggs }: +{ + lib, + eggDerivation, + fetchFromGitHub, + chickenEggs, +}: # Note: This mostly reimplements the default.nix already contained in # the tarball. Is there a nicer way than duplicating code? diff --git a/pkgs/development/compilers/chicken/5/eggDerivation.nix b/pkgs/development/compilers/chicken/5/eggDerivation.nix index 05a51f7bf91ac0..623e1ab5560fe3 100644 --- a/pkgs/development/compilers/chicken/5/eggDerivation.nix +++ b/pkgs/development/compilers/chicken/5/eggDerivation.nix @@ -1,59 +1,73 @@ -{ callPackage, lib, stdenv, chicken, makeWrapper }: -{ name -, src -, buildInputs ? [ ] -, chickenInstallFlags ? [ ] -, cscOptions ? [ ] -, ... -} @ args: +{ + callPackage, + lib, + stdenv, + chicken, + makeWrapper, +}: +{ + name, + src, + buildInputs ? [ ], + chickenInstallFlags ? [ ], + cscOptions ? [ ], + ... +}@args: let overrides = callPackage ./overrides.nix { }; baseName = lib.getName name; override = - if builtins.hasAttr baseName overrides - then - builtins.getAttr baseName overrides - else - lib.id; + if builtins.hasAttr baseName overrides then builtins.getAttr baseName overrides else lib.id; in -(stdenv.mkDerivation ({ - name = "chicken-${name}"; - propagatedBuildInputs = buildInputs; - nativeBuildInputs = [ chicken makeWrapper ]; - buildInputs = [ chicken ]; - - strictDeps = true; - - CSC_OPTIONS = lib.concatStringsSep " " cscOptions; - - buildPhase = '' - runHook preBuild - chicken-install -cached -no-install -host ${lib.escapeShellArgs chickenInstallFlags} - runHook postBuild - ''; - - installPhase = '' - runHook preInstall - - export CHICKEN_INSTALL_PREFIX=$out - export CHICKEN_INSTALL_REPOSITORY=$out/lib/chicken/${toString chicken.binaryVersion} - chicken-install -cached -host ${lib.escapeShellArgs chickenInstallFlags} - - for f in $out/bin/* - do - wrapProgram $f \ - --prefix CHICKEN_REPOSITORY_PATH : "$out/lib/chicken/${toString chicken.binaryVersion}:$CHICKEN_REPOSITORY_PATH" \ - --prefix CHICKEN_INCLUDE_PATH : "$CHICKEN_INCLUDE_PATH:$out/share" \ - --prefix PATH : "$out/bin:${chicken}/bin:$CHICKEN_REPOSITORY_PATH" - done - - runHook postInstall - ''; - - dontConfigure = true; - - meta = { - inherit (chicken.meta) platforms; - } // args.meta or { }; -} // builtins.removeAttrs args [ "name" "buildInputs" "meta" ])).overrideAttrs override +(stdenv.mkDerivation ( + { + name = "chicken-${name}"; + propagatedBuildInputs = buildInputs; + nativeBuildInputs = [ + chicken + makeWrapper + ]; + buildInputs = [ chicken ]; + + strictDeps = true; + + CSC_OPTIONS = lib.concatStringsSep " " cscOptions; + + buildPhase = '' + runHook preBuild + chicken-install -cached -no-install -host ${lib.escapeShellArgs chickenInstallFlags} + runHook postBuild + ''; + + installPhase = '' + runHook preInstall + + export CHICKEN_INSTALL_PREFIX=$out + export CHICKEN_INSTALL_REPOSITORY=$out/lib/chicken/${toString chicken.binaryVersion} + chicken-install -cached -host ${lib.escapeShellArgs chickenInstallFlags} + + for f in $out/bin/* + do + wrapProgram $f \ + --prefix CHICKEN_REPOSITORY_PATH : "$out/lib/chicken/${toString chicken.binaryVersion}:$CHICKEN_REPOSITORY_PATH" \ + --prefix CHICKEN_INCLUDE_PATH : "$CHICKEN_INCLUDE_PATH:$out/share" \ + --prefix PATH : "$out/bin:${chicken}/bin:$CHICKEN_REPOSITORY_PATH" + done + + runHook postInstall + ''; + + dontConfigure = true; + + meta = { + inherit (chicken.meta) platforms; + } // args.meta or { }; + } + // builtins.removeAttrs args [ + "name" + "buildInputs" + "meta" + ] +)).overrideAttrs + override diff --git a/pkgs/development/compilers/chicken/5/overrides.nix b/pkgs/development/compilers/chicken/5/overrides.nix index 586abb37b2969d..0e683d8cf8f5a3 100644 --- a/pkgs/development/compilers/chicken/5/overrides.nix +++ b/pkgs/development/compilers/chicken/5/overrides.nix @@ -1,4 +1,9 @@ -{ stdenv, pkgs, lib, chickenEggs }: +{ + stdenv, + pkgs, + lib, + chickenEggs, +}: let inherit (lib) addMetaAttrs; addToNativeBuildInputs = pkg: old: { @@ -8,16 +13,14 @@ let buildInputs = (old.buildInputs or [ ]) ++ lib.toList pkg; }; addToPropagatedBuildInputs = pkg: old: { - propagatedBuildInputs = (old.propagatedBuildInputs or [ ]) - ++ lib.toList pkg; + propagatedBuildInputs = (old.propagatedBuildInputs or [ ]) ++ lib.toList pkg; }; addPkgConfig = old: { nativeBuildInputs = (old.nativeBuildInputs or [ ]) ++ [ pkgs.pkg-config ]; }; - addToBuildInputsWithPkgConfig = pkg: old: - (addPkgConfig old) // (addToBuildInputs pkg old); - addToPropagatedBuildInputsWithPkgConfig = pkg: old: - (addPkgConfig old) // (addToPropagatedBuildInputs pkg old); + addToBuildInputsWithPkgConfig = pkg: old: (addPkgConfig old) // (addToBuildInputs pkg old); + addToPropagatedBuildInputsWithPkgConfig = + pkg: old: (addPkgConfig old) // (addToPropagatedBuildInputs pkg old); broken = addMetaAttrs { broken = true; }; brokenOnDarwin = addMetaAttrs { broken = stdenv.hostPlatform.isDarwin; }; addToCscOptions = opt: old: { @@ -25,10 +28,21 @@ let }; in { - allegro = old: - ((addToBuildInputsWithPkgConfig ([ pkgs.allegro5 pkgs.libglvnd pkgs.libGLU ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ pkgs.darwin.apple_sdk.frameworks.OpenGL ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ pkgs.xorg.libX11 ])) old) // { + allegro = + old: + ( + (addToBuildInputsWithPkgConfig ( + [ + pkgs.allegro5 + pkgs.libglvnd + pkgs.libGLU + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ pkgs.darwin.apple_sdk.frameworks.OpenGL ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ pkgs.xorg.libX11 ] + )) + old + ) + // { # depends on 'chicken' egg, which doesn't exist, # so we specify all the deps here propagatedBuildInputs = [ @@ -39,9 +53,13 @@ in blas = addToBuildInputsWithPkgConfig pkgs.blas; blosc = addToBuildInputs pkgs.c-blosc; botan = addToBuildInputsWithPkgConfig pkgs.botan2; - cairo = old: + cairo = + old: (addToBuildInputsWithPkgConfig pkgs.cairo old) - // (addToPropagatedBuildInputs (with chickenEggs; [ srfi-1 srfi-13 ]) old); + // (addToPropagatedBuildInputs (with chickenEggs; [ + srfi-1 + srfi-13 + ]) old); cmark = addToBuildInputs pkgs.cmark; comparse = old: { # For some reason lazy-seq 2 gets interpreted as lazy-seq 0.0.0?? @@ -50,7 +68,8 @@ in --replace-fail 'lazy-seq "0.1.0"' 'lazy-seq "0.0.0"' ''; }; - epoxy = old: + epoxy = + old: (addToPropagatedBuildInputsWithPkgConfig pkgs.libepoxy old) // lib.optionalAttrs stdenv.cc.isClang { env.NIX_CFLAGS_COMPILE = toString [ @@ -60,14 +79,16 @@ in }; espeak = addToBuildInputsWithPkgConfig pkgs.espeak-ng; exif = addToBuildInputsWithPkgConfig pkgs.libexif; - expat = old: + expat = + old: (addToBuildInputsWithPkgConfig pkgs.expat old) // lib.optionalAttrs stdenv.cc.isClang { env.NIX_CFLAGS_COMPILE = toString [ "-Wno-error=incompatible-function-pointer-types" ]; }; - ezxdisp = old: + ezxdisp = + old: (addToBuildInputsWithPkgConfig pkgs.xorg.libX11 old) // lib.optionalAttrs stdenv.cc.isClang { env.NIX_CFLAGS_COMPILE = toString [ @@ -82,7 +103,8 @@ in iconv = addToBuildInputs (lib.optional stdenv.hostPlatform.isDarwin pkgs.libiconv); icu = addToBuildInputsWithPkgConfig pkgs.icu; imlib2 = addToBuildInputsWithPkgConfig pkgs.imlib2; - inotify = old: + inotify = + old: (addToBuildInputs (lib.optional stdenv.hostPlatform.isDarwin pkgs.libinotify-kqueue) old) // lib.optionalAttrs stdenv.hostPlatform.isDarwin (addToCscOptions "-L -linotify" old); leveldb = addToBuildInputs pkgs.leveldb; @@ -94,7 +116,8 @@ in ''; }; magic = addToBuildInputs pkgs.file; - mdh = old: + mdh = + old: (addToBuildInputs pkgs.pcre old) // lib.optionalAttrs stdenv.cc.isClang { env.NIX_CFLAGS_COMPILE = toString [ @@ -114,41 +137,63 @@ in mosquitto = addToPropagatedBuildInputs ([ pkgs.mosquitto ]); nanomsg = addToBuildInputs pkgs.nanomsg; ncurses = addToBuildInputsWithPkgConfig [ pkgs.ncurses ]; - opencl = addToBuildInputs ([ pkgs.opencl-headers pkgs.ocl-icd ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ pkgs.darwin.apple_sdk.frameworks.OpenCL ]); + opencl = addToBuildInputs ( + [ + pkgs.opencl-headers + pkgs.ocl-icd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ pkgs.darwin.apple_sdk.frameworks.OpenCL ] + ); openssl = addToBuildInputs pkgs.openssl; plot = addToBuildInputs pkgs.plotutils; postgresql = addToBuildInputsWithPkgConfig pkgs.postgresql; rocksdb = addToBuildInputs pkgs.rocksdb_8_3; - scheme2c-compatibility = old: - addToNativeBuildInputs (lib.optionals (stdenv.system == "x86_64-darwin") [ pkgs.memorymappingHook ]) - (addPkgConfig old); - sdl-base = old: - ((addToPropagatedBuildInputsWithPkgConfig pkgs.SDL old) // - # needed for sdl-config to be in PATH - (addToNativeBuildInputs pkgs.SDL old)); - sdl2 = old: - ((addToPropagatedBuildInputsWithPkgConfig pkgs.SDL2 old) // - # needed for sdl2-config to be in PATH - (addToNativeBuildInputs pkgs.SDL2 old)); - sdl2-image = old: - ((addToPropagatedBuildInputsWithPkgConfig pkgs.SDL2_image old) // - # needed for sdl2-config to be in PATH - (addToNativeBuildInputs pkgs.SDL2 old)); - sdl2-ttf = old: - ((addToPropagatedBuildInputsWithPkgConfig pkgs.SDL2_ttf old) // - # needed for sdl2-config to be in PATH - (addToNativeBuildInputs pkgs.SDL2 old)); + scheme2c-compatibility = + old: + addToNativeBuildInputs (lib.optionals (stdenv.system == "x86_64-darwin") [ + pkgs.memorymappingHook + ]) (addPkgConfig old); + sdl-base = + old: + ( + (addToPropagatedBuildInputsWithPkgConfig pkgs.SDL old) + // + # needed for sdl-config to be in PATH + (addToNativeBuildInputs pkgs.SDL old) + ); + sdl2 = + old: + ( + (addToPropagatedBuildInputsWithPkgConfig pkgs.SDL2 old) + // + # needed for sdl2-config to be in PATH + (addToNativeBuildInputs pkgs.SDL2 old) + ); + sdl2-image = + old: + ( + (addToPropagatedBuildInputsWithPkgConfig pkgs.SDL2_image old) + // + # needed for sdl2-config to be in PATH + (addToNativeBuildInputs pkgs.SDL2 old) + ); + sdl2-ttf = + old: + ( + (addToPropagatedBuildInputsWithPkgConfig pkgs.SDL2_ttf old) + // + # needed for sdl2-config to be in PATH + (addToNativeBuildInputs pkgs.SDL2 old) + ); soil = addToPropagatedBuildInputsWithPkgConfig pkgs.libepoxy; sqlite3 = addToBuildInputs pkgs.sqlite; - stemmer = old: - (addToBuildInputs pkgs.libstemmer old) - // (addToCscOptions "-L -lstemmer" old); - stfl = old: - (addToBuildInputs [ pkgs.ncurses pkgs.stfl ] old) - // (addToCscOptions "-L -lncurses" old); - taglib = old: - (addToBuildInputs [ pkgs.zlib pkgs.taglib ] old) // ( + stemmer = old: (addToBuildInputs pkgs.libstemmer old) // (addToCscOptions "-L -lstemmer" old); + stfl = + old: (addToBuildInputs [ pkgs.ncurses pkgs.stfl ] old) // (addToCscOptions "-L -lncurses" old); + taglib = + old: + (addToBuildInputs [ pkgs.zlib pkgs.taglib ] old) + // ( # needed for tablib-config to be in PATH addToNativeBuildInputs pkgs.taglib old ); @@ -162,23 +207,36 @@ in zstd = addToBuildInputs pkgs.zstd; # less trivial fixes, should be upstreamed - git = old: (addToBuildInputsWithPkgConfig pkgs.libgit2 old) // { - postPatch = '' - substituteInPlace libgit2.scm \ - --replace "asize" "reserved" - ''; - }; - lazy-ffi = old: (addToBuildInputs pkgs.libffi old) // { - postPatch = '' - substituteInPlace lazy-ffi.scm \ - --replace "ffi/ffi.h" "ffi.h" - ''; - }; - opengl = old: - (addToBuildInputsWithPkgConfig - (lib.optionals (!stdenv.hostPlatform.isDarwin) [ pkgs.libGL pkgs.libGLU ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ pkgs.darwin.apple_sdk.frameworks.Foundation pkgs.darwin.apple_sdk.frameworks.OpenGL ]) - old) + git = + old: + (addToBuildInputsWithPkgConfig pkgs.libgit2 old) + // { + postPatch = '' + substituteInPlace libgit2.scm \ + --replace "asize" "reserved" + ''; + }; + lazy-ffi = + old: + (addToBuildInputs pkgs.libffi old) + // { + postPatch = '' + substituteInPlace lazy-ffi.scm \ + --replace "ffi/ffi.h" "ffi.h" + ''; + }; + opengl = + old: + (addToBuildInputsWithPkgConfig ( + lib.optionals (!stdenv.hostPlatform.isDarwin) [ + pkgs.libGL + pkgs.libGLU + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + pkgs.darwin.apple_sdk.frameworks.Foundation + pkgs.darwin.apple_sdk.frameworks.OpenGL + ] + ) old) // { postPatch = '' substituteInPlace opengl.egg \ @@ -197,8 +255,10 @@ in unveil = addMetaAttrs { platforms = lib.platforms.openbsd; }; # overrides for chicken 5.4 - dbus = old: - (addToBuildInputsWithPkgConfig [ pkgs.dbus ] old) // { + dbus = + old: + (addToBuildInputsWithPkgConfig [ pkgs.dbus ] old) + // { # backticks in compiler options # aren't supported anymore as of chicken 5.4, it seems. preBuild = '' diff --git a/pkgs/development/compilers/clasp/default.nix b/pkgs/development/compilers/clasp/default.nix index 4613357ded3b78..abf1083cc1c3f3 100644 --- a/pkgs/development/compilers/clasp/default.nix +++ b/pkgs/development/compilers/clasp/default.nix @@ -1,14 +1,15 @@ -{ lib -, llvmPackages_15 -, fetchzip -, sbcl -, pkg-config -, fmt_9 -, gmpxx -, libelf -, boost -, libunwind -, ninja +{ + lib, + llvmPackages_15, + fetchzip, + sbcl, + pkg-config, + fmt_9, + gmpxx, + libelf, + boost, + libunwind, + ninja, }: let @@ -46,7 +47,10 @@ stdenv.mkDerivation rec { libclang ]; - ninjaFlags = [ "-C" "build" ]; + ninjaFlags = [ + "-C" + "build" + ]; configurePhase = '' export SOURCE_DATE_EPOCH=1 @@ -65,9 +69,12 @@ stdenv.mkDerivation rec { meta = { description = "Common Lisp implementation based on LLVM with C++ integration"; - license = lib.licenses.lgpl21Plus ; + license = lib.licenses.lgpl21Plus; maintainers = lib.teams.lisp.members; - platforms = ["x86_64-linux" "x86_64-darwin"]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + ]; # Upstream claims support, but breaks with: # error: use of undeclared identifier 'aligned_alloc' broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/development/compilers/cmucl/binary.nix b/pkgs/development/compilers/cmucl/binary.nix index 9a186beaf00d8f..eac9f1af818eb2 100644 --- a/pkgs/development/compilers/cmucl/binary.nix +++ b/pkgs/development/compilers/cmucl/binary.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, installShellFiles +{ + lib, + stdenv, + fetchurl, + installShellFiles, }: stdenv.mkDerivation (finalAttrs: { @@ -10,19 +11,28 @@ stdenv.mkDerivation (finalAttrs: { srcs = [ (fetchurl { - url = "http://common-lisp.net/project/cmucl/downloads/release/" - + finalAttrs.version + "/cmucl-${finalAttrs.version}-x86-linux.tar.bz2"; + url = + "http://common-lisp.net/project/cmucl/downloads/release/" + + finalAttrs.version + + "/cmucl-${finalAttrs.version}-x86-linux.tar.bz2"; hash = "sha256-RdctcqPTtQh1Yb3BrpQ8jtRFQn85OcwOt1l90H6xDZs="; }) (fetchurl { - url = "http://common-lisp.net/project/cmucl/downloads/release/" - + finalAttrs.version + "/cmucl-${finalAttrs.version}-x86-linux.extra.tar.bz2"; + url = + "http://common-lisp.net/project/cmucl/downloads/release/" + + finalAttrs.version + + "/cmucl-${finalAttrs.version}-x86-linux.extra.tar.bz2"; hash = "sha256-zEmiW3m5VPpFgPxV1WJNCqgYRlHMovtaMXcgXyNukls="; - })]; + }) + ]; sourceRoot = "."; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; nativeBuildInputs = [ installShellFiles @@ -58,6 +68,9 @@ stdenv.mkDerivation (finalAttrs: { ''; mainProgram = "lisp"; maintainers = lib.teams.lisp.members; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; }) diff --git a/pkgs/development/compilers/codon/default.nix b/pkgs/development/compilers/codon/default.nix index f274011a910eef..491f38f2606af2 100644 --- a/pkgs/development/compilers/codon/default.nix +++ b/pkgs/development/compilers/codon/default.nix @@ -1,14 +1,15 @@ -{ cacert -, cmake -, fetchFromGitHub -, git -, lib -, lld -, ninja -, nix-update-script -, perl -, python3 -, stdenv +{ + cacert, + cmake, + fetchFromGitHub, + git, + lib, + lld, + ninja, + nix-update-script, + perl, + python3, + stdenv, }: let diff --git a/pkgs/development/compilers/cone/default.nix b/pkgs/development/compilers/cone/default.nix index 4b2871ddc6f964..0e95fdbc6ae531 100644 --- a/pkgs/development/compilers/cone/default.nix +++ b/pkgs/development/compilers/cone/default.nix @@ -1,7 +1,8 @@ -{ llvmPackages -, lib -, fetchFromGitHub -, cmake +{ + llvmPackages, + lib, + fetchFromGitHub, + cmake, }: llvmPackages.stdenv.mkDerivation rec { diff --git a/pkgs/development/compilers/crystal/build-package.nix b/pkgs/development/compilers/crystal/build-package.nix index 536ad3acda7b51..c7c29f12caa473 100644 --- a/pkgs/development/compilers/crystal/build-package.nix +++ b/pkgs/development/compilers/crystal/build-package.nix @@ -1,38 +1,45 @@ -{ stdenv -, lib -, crystal -, pcre2 -, shards -, git -, pkg-config -, which -, linkFarm -, fetchgit -, fetchFromGitHub -, installShellFiles -, removeReferencesTo +{ + stdenv, + lib, + crystal, + pcre2, + shards, + git, + pkg-config, + which, + linkFarm, + fetchgit, + fetchFromGitHub, + installShellFiles, + removeReferencesTo, }: { # Some projects do not include a lock file, so you can pass one - lockFile ? null + lockFile ? null, # Generate shards.nix with `nix-shell -p crystal2nix --run crystal2nix` in the projects root -, shardsFile ? null + shardsFile ? null, # We support different builders. To make things more straight forward, make it # user selectable instead of trying to autodetect -, format ? "make" -, installManPages ? true + format ? "make", + installManPages ? true, # Specify binaries to build in the form { foo.src = "src/foo.cr"; } # The default `crystal build` options can be overridden with { foo.options = [ "--optionname" ]; } -, crystalBinaries ? { } -, enableParallelBuilding ? true + crystalBinaries ? { }, + enableParallelBuilding ? true, # Copy all shards dependencies instead of symlinking and add write permissions # to make environment more local-like -, copyShardDeps ? false -, ... + copyShardDeps ? false, + ... }@args: -assert (builtins.elem format [ "make" "crystal" "shards" ]); +assert ( + builtins.elem format [ + "make" + "crystal" + "shards" + ] +); let mkDerivationArgs = builtins.removeAttrs args [ "format" @@ -42,127 +49,162 @@ let "crystalBinaries" ]; - crystalLib = linkFarm "crystal-lib" (lib.mapAttrsToList - (name: value: { + crystalLib = linkFarm "crystal-lib" ( + lib.mapAttrsToList (name: value: { inherit name; - path = - if (builtins.hasAttr "url" value) - then fetchgit value - else fetchFromGitHub value; - }) - (import shardsFile)); + path = if (builtins.hasAttr "url" value) then fetchgit value else fetchFromGitHub value; + }) (import shardsFile) + ); # We no longer use --no-debug in accordance with upstream's recommendation - defaultOptions = [ "--release" "--progress" "--verbose" ]; + defaultOptions = [ + "--release" + "--progress" + "--verbose" + ]; buildDirectly = shardsFile == null || crystalBinaries != { }; - mkCrystalBuildArgs = bin: attrs: - lib.concatStringsSep " " ([ - "crystal" - "build" - ] ++ lib.optionals enableParallelBuilding [ - "--threads" - "$NIX_BUILD_CORES" - ] ++ [ - "-o" - bin - (attrs.src or (throw "No source file for crystal binary ${bin} provided")) - (lib.concatStringsSep " " (attrs.options or defaultOptions)) - ]); - -in -stdenv.mkDerivation (mkDerivationArgs // { - - configurePhase = args.configurePhase or (lib.concatStringsSep "\n" ( + mkCrystalBuildArgs = + bin: attrs: + lib.concatStringsSep " " ( [ - "runHook preConfigure" + "crystal" + "build" ] - ++ lib.optional (lockFile != null) "cp ${lockFile} ./shard.lock" - ++ lib.optionals (shardsFile != null) [ - "test -e lib || mkdir lib" - (if copyShardDeps then "for d in ${crystalLib}/*; do cp -r $d/ lib/; done; chmod -R +w lib/" - else "for d in ${crystalLib}/*; do ln -s $d lib/; done") - "cp shard.lock lib/.shards.info" + ++ lib.optionals enableParallelBuilding [ + "--threads" + "$NIX_BUILD_CORES" + ] + ++ [ + "-o" + bin + (attrs.src or (throw "No source file for crystal binary ${bin} provided")) + (lib.concatStringsSep " " (attrs.options or defaultOptions)) + ] + ); + +in +stdenv.mkDerivation ( + mkDerivationArgs + // { + + configurePhase = + args.configurePhase or (lib.concatStringsSep "\n" ( + [ + "runHook preConfigure" + ] + ++ lib.optional (lockFile != null) "cp ${lockFile} ./shard.lock" + ++ lib.optionals (shardsFile != null) [ + "test -e lib || mkdir lib" + ( + if copyShardDeps then + "for d in ${crystalLib}/*; do cp -r $d/ lib/; done; chmod -R +w lib/" + else + "for d in ${crystalLib}/*; do ln -s $d lib/; done" + ) + "cp shard.lock lib/.shards.info" + ] + ++ [ "runHook postConfigure" ] + )); + + CRFLAGS = lib.concatStringsSep " " defaultOptions; + + PREFIX = placeholder "out"; + + inherit enableParallelBuilding; + strictDeps = true; + buildInputs = + args.buildInputs or [ ] + ++ [ crystal ] + ++ lib.optional (lib.versionAtLeast crystal.version "1.8") pcre2; + + nativeBuildInputs = + args.nativeBuildInputs or [ ] + ++ [ + crystal + git + installShellFiles + removeReferencesTo + pkg-config + which ] - ++ [ "runHook postConfigure" ] - )); - - CRFLAGS = lib.concatStringsSep " " defaultOptions; - - PREFIX = placeholder "out"; - - inherit enableParallelBuilding; - strictDeps = true; - buildInputs = args.buildInputs or [ ] ++ [ crystal ] - ++ lib.optional (lib.versionAtLeast crystal.version "1.8") pcre2; - - nativeBuildInputs = args.nativeBuildInputs or [ ] ++ [ - crystal - git - installShellFiles - removeReferencesTo - pkg-config - which - ] ++ lib.optional (format != "crystal") shards; - - buildPhase = args.buildPhase or (lib.concatStringsSep "\n" ([ - "runHook preBuild" - ] ++ lib.optional (format == "make") - "make \${buildTargets:-build} $makeFlags" - ++ lib.optionals (format == "crystal") (lib.mapAttrsToList mkCrystalBuildArgs crystalBinaries) - ++ lib.optional (format == "shards") - "shards build --local --production ${lib.concatStringsSep " " (args.options or defaultOptions)}" - ++ [ "runHook postBuild" ])); - - installPhase = args.installPhase or (lib.concatStringsSep "\n" ([ - "runHook preInstall" - ] ++ lib.optional (format == "make") - "make \${installTargets:-install} $installFlags" - ++ lib.optionals (format == "crystal") (map - (bin: '' - install -Dm555 ${lib.escapeShellArgs [ bin "${placeholder "out"}/bin/${bin}" ]} - '') - (lib.attrNames crystalBinaries)) - ++ lib.optional (format == "shards") - "install -Dm555 bin/* -t $out/bin" - ++ [ - '' - for f in README* *.md LICENSE; do - test -f $f && install -Dm444 $f -t $out/share/doc/${args.pname} - done - '' - ] ++ (lib.optional installManPages '' - if [ -d man ]; then - installManPage man/*.? - fi - '') ++ [ - "remove-references-to -t ${lib.getLib crystal} $out/bin/*" - "runHook postInstall" - ])); - - doCheck = args.doCheck or true; - - checkPhase = args.checkPhase or (lib.concatStringsSep "\n" ([ - "runHook preCheck" - ] ++ lib.optional (format == "make") - "make \${checkTarget:-test} $checkFlags" - ++ lib.optional (format != "make") - "crystal \${checkTarget:-spec} $checkFlags" - ++ [ "runHook postCheck" ])); - - doInstallCheck = args.doInstallCheck or true; - - installCheckPhase = args.installCheckPhase or '' - for f in $out/bin/*; do - if [ $f == $out/bin/*.dwarf ]; then - continue - fi - $f --help > /dev/null - done - ''; - - meta = args.meta or { } // { - platforms = args.meta.platforms or crystal.meta.platforms; - }; -}) + ++ lib.optional (format != "crystal") shards; + + buildPhase = + args.buildPhase or (lib.concatStringsSep "\n" ( + [ + "runHook preBuild" + ] + ++ lib.optional (format == "make") "make \${buildTargets:-build} $makeFlags" + ++ lib.optionals (format == "crystal") (lib.mapAttrsToList mkCrystalBuildArgs crystalBinaries) + ++ + lib.optional (format == "shards") + "shards build --local --production ${lib.concatStringsSep " " (args.options or defaultOptions)}" + ++ [ "runHook postBuild" ] + )); + + installPhase = + args.installPhase or (lib.concatStringsSep "\n" ( + [ + "runHook preInstall" + ] + ++ lib.optional (format == "make") "make \${installTargets:-install} $installFlags" + ++ lib.optionals (format == "crystal") ( + map (bin: '' + install -Dm555 ${ + lib.escapeShellArgs [ + bin + "${placeholder "out"}/bin/${bin}" + ] + } + '') (lib.attrNames crystalBinaries) + ) + ++ lib.optional (format == "shards") "install -Dm555 bin/* -t $out/bin" + ++ [ + '' + for f in README* *.md LICENSE; do + test -f $f && install -Dm444 $f -t $out/share/doc/${args.pname} + done + '' + ] + ++ (lib.optional installManPages '' + if [ -d man ]; then + installManPage man/*.? + fi + '') + ++ [ + "remove-references-to -t ${lib.getLib crystal} $out/bin/*" + "runHook postInstall" + ] + )); + + doCheck = args.doCheck or true; + + checkPhase = + args.checkPhase or (lib.concatStringsSep "\n" ( + [ + "runHook preCheck" + ] + ++ lib.optional (format == "make") "make \${checkTarget:-test} $checkFlags" + ++ lib.optional (format != "make") "crystal \${checkTarget:-spec} $checkFlags" + ++ [ "runHook postCheck" ] + )); + + doInstallCheck = args.doInstallCheck or true; + + installCheckPhase = + args.installCheckPhase or '' + for f in $out/bin/*; do + if [ $f == $out/bin/*.dwarf ]; then + continue + fi + $f --help > /dev/null + done + ''; + + meta = args.meta or { } // { + platforms = args.meta.platforms or crystal.meta.platforms; + }; + } +) diff --git a/pkgs/development/compilers/dart/default.nix b/pkgs/development/compilers/dart/default.nix index d6d538d5c844c9..a97cb6f9aa8230 100644 --- a/pkgs/development/compilers/dart/default.nix +++ b/pkgs/development/compilers/dart/default.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchurl -, unzip -, runCommand -, cctools -, darwin -, sources ? import ./sources.nix {inherit fetchurl;} -, version ? sources.versionUsed +{ + stdenv, + lib, + fetchurl, + unzip, + runCommand, + cctools, + darwin, + sources ? import ./sources.nix { inherit fetchurl; }, + version ? sources.versionUsed, }: assert sources != null && (builtins.isAttrs sources); @@ -16,15 +17,19 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ unzip ]; - src = sources."${version}-${stdenv.hostPlatform.system}" or (throw "unsupported version/system: ${version}/${stdenv.hostPlatform.system}"); + src = + sources."${version}-${stdenv.hostPlatform.system}" + or (throw "unsupported version/system: ${version}/${stdenv.hostPlatform.system}"); - installPhase = '' - mkdir -p $out - cp -R * $out/ - echo $libPath - '' + lib.optionalString (stdenv.hostPlatform.isLinux) '' - find $out/bin -executable -type f -exec patchelf --set-interpreter $(cat $NIX_CC/nix-support/dynamic-linker) {} \; - ''; + installPhase = + '' + mkdir -p $out + cp -R * $out/ + echo $libPath + '' + + lib.optionalString (stdenv.hostPlatform.isLinux) '' + find $out/bin -executable -type f -exec patchelf --set-interpreter $(cat $NIX_CC/nix-support/dynamic-linker) {} \; + ''; libPath = lib.makeLibraryPath [ stdenv.cc.cc ]; dontStrip = true; @@ -40,18 +45,25 @@ stdenv.mkDerivation (finalAttrs: { touch $out ''; - testCompile = runCommand "dart-test-compile" { - nativeBuildInputs = [ finalAttrs.finalPackage ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools darwin.sigtool ]; - } '' - HELLO_MESSAGE="Hello, world!" - echo "void main() => print('$HELLO_MESSAGE');" > hello.dart - dart compile exe hello.dart - PROGRAM_OUT=$(./hello.exe) + testCompile = + runCommand "dart-test-compile" + { + nativeBuildInputs = + [ finalAttrs.finalPackage ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + cctools + darwin.sigtool + ]; + } + '' + HELLO_MESSAGE="Hello, world!" + echo "void main() => print('$HELLO_MESSAGE');" > hello.dart + dart compile exe hello.dart + PROGRAM_OUT=$(./hello.exe) - [[ "$PROGRAM_OUT" == "$HELLO_MESSAGE" ]] - touch $out - ''; + [[ "$PROGRAM_OUT" == "$HELLO_MESSAGE" ]] + touch $out + ''; }; }; @@ -65,7 +77,13 @@ stdenv.mkDerivation (finalAttrs: { mixins, abstract classes, reified generics, and optional typing. ''; mainProgram = "dart"; - platforms = [ "x86_64-linux" "i686-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.bsd3; }; diff --git a/pkgs/development/compilers/dart/package-source-builders/flutter-secure-storage-linux/default.nix b/pkgs/development/compilers/dart/package-source-builders/flutter-secure-storage-linux/default.nix index c111a73646569a..d58226cbadcd5f 100644 --- a/pkgs/development/compilers/dart/package-source-builders/flutter-secure-storage-linux/default.nix +++ b/pkgs/development/compilers/dart/package-source-builders/flutter-secure-storage-linux/default.nix @@ -1,6 +1,7 @@ -{ stdenv -, libsecret -, jsoncpp +{ + stdenv, + libsecret, + jsoncpp, }: { version, src, ... }: @@ -10,7 +11,10 @@ stdenv.mkDerivation { inherit version src; inherit (src) passthru; - propagatedBuildInputs = [ libsecret jsoncpp ]; + propagatedBuildInputs = [ + libsecret + jsoncpp + ]; installPhase = '' runHook preInstall diff --git a/pkgs/development/compilers/dart/package-source-builders/handy-window/default.nix b/pkgs/development/compilers/dart/package-source-builders/handy-window/default.nix index bd43e0ed947f8e..134a0ddad20c14 100644 --- a/pkgs/development/compilers/dart/package-source-builders/handy-window/default.nix +++ b/pkgs/development/compilers/dart/package-source-builders/handy-window/default.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, writeScript -, cairo -, fribidi +{ + stdenv, + lib, + writeScript, + cairo, + fribidi, }: { version, src, ... }: diff --git a/pkgs/development/compilers/dart/package-source-builders/matrix/default.nix b/pkgs/development/compilers/dart/package-source-builders/matrix/default.nix index 1e2c3fea80e700..fcf12a7110abad 100644 --- a/pkgs/development/compilers/dart/package-source-builders/matrix/default.nix +++ b/pkgs/development/compilers/dart/package-source-builders/matrix/default.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, writeScript -, openssl +{ + stdenv, + lib, + writeScript, + openssl, }: { version, src, ... }: diff --git a/pkgs/development/compilers/dart/package-source-builders/media_kit_libs_linux/default.nix b/pkgs/development/compilers/dart/package-source-builders/media_kit_libs_linux/default.nix index 92bfc7e7fa60bd..60fe8cd5b47844 100644 --- a/pkgs/development/compilers/dart/package-source-builders/media_kit_libs_linux/default.nix +++ b/pkgs/development/compilers/dart/package-source-builders/media_kit_libs_linux/default.nix @@ -1,4 +1,5 @@ -{ stdenv +{ + stdenv, }: # Implementation notes @@ -9,7 +10,7 @@ # Direct link for the original CMakeLists.txt: https://raw.githubusercontent.com/media-kit/media-kit/main/libs/linux/media_kit_libs_linux/linux/CMakeLists.txt -{version, src, ...}: +{ version, src, ... }: stdenv.mkDerivation { pname = "media_kit_libs_linux"; diff --git a/pkgs/development/compilers/dart/package-source-builders/olm/default.nix b/pkgs/development/compilers/dart/package-source-builders/olm/default.nix index 8d715ff190fc45..069ee346481709 100644 --- a/pkgs/development/compilers/dart/package-source-builders/olm/default.nix +++ b/pkgs/development/compilers/dart/package-source-builders/olm/default.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, writeScript -, olm +{ + stdenv, + lib, + writeScript, + olm, }: { version, src, ... }: diff --git a/pkgs/development/compilers/dart/package-source-builders/sqlcipher_flutter_libs/default.nix b/pkgs/development/compilers/dart/package-source-builders/sqlcipher_flutter_libs/default.nix index 9810140339287d..2d8bc799e68605 100644 --- a/pkgs/development/compilers/dart/package-source-builders/sqlcipher_flutter_libs/default.nix +++ b/pkgs/development/compilers/dart/package-source-builders/sqlcipher_flutter_libs/default.nix @@ -1,20 +1,25 @@ -{ stdenv -, fetchurl -, lib +{ + stdenv, + fetchurl, + lib, }: { version, src, ... }: let - artifacts = lib.mapAttrs (version: sha512: - fetchurl { - url = "https://storage.googleapis.com/simon-public-euw3/assets/sqlcipher/${version}.c"; - inherit sha512; - }) - { - v4_5_7 = "11bb454d761b994f7e44f35dabd3fc8ac3b40499d6fdc29d58a38fb9b4dcdd6eb14ff3978ceb7c6f3bd5eee4a5abeec5f0453b944268f9aaf942b0366df1e73d"; - v4_5_6 = "939ae692239adc0581211a37ed9ffa8b37c8f771c830977ecb06dc6accc4c3db767ce6abeaf91133815e2ae837785affa92f4c95b2e68cb6d563bd761f3e0cb1"; - }; + artifacts = + lib.mapAttrs + ( + version: sha512: + fetchurl { + url = "https://storage.googleapis.com/simon-public-euw3/assets/sqlcipher/${version}.c"; + inherit sha512; + } + ) + { + v4_5_7 = "11bb454d761b994f7e44f35dabd3fc8ac3b40499d6fdc29d58a38fb9b4dcdd6eb14ff3978ceb7c6f3bd5eee4a5abeec5f0453b944268f9aaf942b0366df1e73d"; + v4_5_6 = "939ae692239adc0581211a37ed9ffa8b37c8f771c830977ecb06dc6accc4c3db767ce6abeaf91133815e2ae837785affa92f4c95b2e68cb6d563bd761f3e0cb1"; + }; in stdenv.mkDerivation rec { pname = "sqlcipher_flutter_libs"; diff --git a/pkgs/development/compilers/dart/package-source-builders/sqlite3/default.nix b/pkgs/development/compilers/dart/package-source-builders/sqlite3/default.nix index 579bc1732cc443..ff3ce563c45abd 100644 --- a/pkgs/development/compilers/dart/package-source-builders/sqlite3/default.nix +++ b/pkgs/development/compilers/dart/package-source-builders/sqlite3/default.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, writeScript -, sqlite +{ + stdenv, + lib, + writeScript, + sqlite, }: { version, src, ... }: diff --git a/pkgs/development/compilers/dart/package-source-builders/system-tray/default.nix b/pkgs/development/compilers/dart/package-source-builders/system-tray/default.nix index 81dc88ab2f52fe..48370fe50440a5 100644 --- a/pkgs/development/compilers/dart/package-source-builders/system-tray/default.nix +++ b/pkgs/development/compilers/dart/package-source-builders/system-tray/default.nix @@ -1,5 +1,6 @@ -{ stdenv -, libayatana-appindicator +{ + stdenv, + libayatana-appindicator, }: { version, src, ... }: diff --git a/pkgs/development/compilers/dart/sources.nix b/pkgs/development/compilers/dart/sources.nix index b2fc4fdc01eea1..b9b5b5baf18af4 100644 --- a/pkgs/development/compilers/dart/sources.nix +++ b/pkgs/development/compilers/dart/sources.nix @@ -1,5 +1,8 @@ -let version = "3.5.4"; in -{ fetchurl }: { +let + version = "3.5.4"; +in +{ fetchurl }: +{ versionUsed = version; "${version}-x86_64-darwin" = fetchurl { url = "https://storage.googleapis.com/dart-archive/channels/stable/release/${version}/sdk/dartsdk-macos-x64-release.zip"; diff --git a/pkgs/development/compilers/djgpp/default.nix b/pkgs/development/compilers/djgpp/default.nix index f212e419840ea4..9b901b9beecac0 100644 --- a/pkgs/development/compilers/djgpp/default.nix +++ b/pkgs/development/compilers/djgpp/default.nix @@ -1,45 +1,51 @@ -{ bison -, buildPackages -, curl -, fetchFromGitHub -, fetchurl -, file -, flex -, targetArchitecture ? "i586" -, lib -, makeWrapper -, perl -, stdenv -, texinfo -, unzip -, which }: +{ + bison, + buildPackages, + curl, + fetchFromGitHub, + fetchurl, + file, + flex, + targetArchitecture ? "i586", + lib, + makeWrapper, + perl, + stdenv, + texinfo, + unzip, + which, +}: let s = import ./sources.nix { inherit fetchurl fetchFromGitHub; }; in -assert lib.elem targetArchitecture [ "i586" "i686" ]; +assert lib.elem targetArchitecture [ + "i586" + "i686" +]; stdenv.mkDerivation rec { pname = "djgpp"; version = s.gccVersion; src = s.src; - patchPhase = '' - runHook prePatch - for f in "build-djgpp.sh" "script/${version}" "setenv/copyfile.sh"; do - substituteInPlace "$f" --replace '/usr/bin/env' '${buildPackages.coreutils}/bin/env' - done - '' - # i686 patches from https://github.com/andrewwutw/build-djgpp/issues/45#issuecomment-1484010755 - # The build script unpacks some files so we can't patch ahead of time, instead patch the script - # to patch after it extracts + patchPhase = + '' + runHook prePatch + for f in "build-djgpp.sh" "script/${version}" "setenv/copyfile.sh"; do + substituteInPlace "$f" --replace '/usr/bin/env' '${buildPackages.coreutils}/bin/env' + done + '' + # i686 patches from https://github.com/andrewwutw/build-djgpp/issues/45#issuecomment-1484010755 + # The build script unpacks some files so we can't patch ahead of time, instead patch the script + # to patch after it extracts - + lib.optionalString (targetArchitecture == "i686") '' - sed -i 's/i586/i686/g' setenv/setenv script/${version} - sed -i '/Building DXE tools./a sed -i "s/i586/i686/g" src/makefile.def src/dxe/makefile.dxe' script/${version} - '' - + '' - runHook postPatch - ''; + + lib.optionalString (targetArchitecture == "i686") '' + sed -i 's/i586/i686/g' setenv/setenv script/${version} + sed -i '/Building DXE tools./a sed -i "s/i586/i686/g" src/makefile.def src/dxe/makefile.dxe' script/${version} + '' + + '' + runHook postPatch + ''; nativeBuildInputs = [ makeWrapper diff --git a/pkgs/development/compilers/djgpp/sources.nix b/pkgs/development/compilers/djgpp/sources.nix index 8ae440409b26d9..a17e34132506ab 100644 --- a/pkgs/development/compilers/djgpp/sources.nix +++ b/pkgs/development/compilers/djgpp/sources.nix @@ -13,7 +13,8 @@ let djgppFtpMirror = "https://www.mirrorservice.org/sites/ftp.delorie.com/pub"; gnuFtpMirror = "https://www.mirrorservice.org/sites/ftp.gnu.org/gnu"; in -{ fetchFromGitHub, fetchurl }: { +{ fetchFromGitHub, fetchurl }: +{ inherit gccVersion; src = fetchFromGitHub { diff --git a/pkgs/development/compilers/dotnet/8/bootstrap-sdk.nix b/pkgs/development/compilers/dotnet/8/bootstrap-sdk.nix index 5b4df9e7c494bb..7a970cb4e5c84f 100644 --- a/pkgs/development/compilers/dotnet/8/bootstrap-sdk.nix +++ b/pkgs/development/compilers/dotnet/8/bootstrap-sdk.nix @@ -1,174 +1,628 @@ -{ buildAspNetCore, buildNetRuntime, buildNetSdk, fetchNupkg }: +{ + buildAspNetCore, + buildNetRuntime, + buildNetSdk, + fetchNupkg, +}: # v8.0 (active) let commonPackages = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Ref"; version = "8.0.10"; hash = "sha512-jTH9mOX8W/5tZiOc2PUFxyePfG2PrkLbzfQc56BKUdPMz0HVnh4NI8XzzXXVb8xuBsi3vt99IKxAAJ7rjxvkoA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetAppHost"; version = "8.0.10"; hash = "sha512-wm6HQmklISelRc3fmi+wrOtsd0MOLZ+gmXUPBydF8pJuEeYatSSBMkcNOJqjGLdXuuMkM/Ub8T1qSNOUviutUg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Ref"; version = "8.0.10"; hash = "sha512-62Hc/ZoMyaMlUfO2WLhRIZYCbcfqo7ArXMIwevBwDf0wW+aceaSD11iS601gBcGwp/Q1Hz/ZCTUfeYvyYeSNoA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetHost"; version = "8.0.10"; hash = "sha512-6nQwLH8px/6F8XmHGicLZ6Bnx9clOmEbnXj6JLzKp6TkZCVdMlulIO8wVrsIfYn9UUgZ5M0FjEivcooilyvmdw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.10"; hash = "sha512-v9n7AjgX/3+9siDoUnzaaOo4WiceOTu0P1DtD1WKD63g1HRB7X6SgjmEULG6wUhY73HuWu/mxGvRg/oMXyCCKw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetHostResolver"; version = "8.0.10"; hash = "sha512-dQn8Z1iypqdntr/hfuuEt2qCdJZywJtociOEnl+jRp2wyEJcQNGBtNQfDT2LWqNj/tJjSY+a+ncuXT3UnnQvjQ=="; }) - (fetchNupkg { pname = "Microsoft.DotNet.ILCompiler"; version = "8.0.10"; hash = "sha512-cA9+iEQ0AikuCnRJ0ASaZbPPpVAINzbEbwR5I4fx2wrch2cdARdSwP3CQK1OAeR8IfA2EEm1jKpgT5fLJ7emHQ=="; }) - (fetchNupkg { pname = "Microsoft.NET.ILLink.Tasks"; version = "8.0.10"; hash = "sha512-N3VO3kok4zHBI6gQC0+x6e/36ebf6xa6dIEzxMnuF/GGEgjseDNBSRI6/Ta/ACRR2LzwDE1CcLp5leBzxMkyAw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Ref"; + version = "8.0.10"; + hash = "sha512-jTH9mOX8W/5tZiOc2PUFxyePfG2PrkLbzfQc56BKUdPMz0HVnh4NI8XzzXXVb8xuBsi3vt99IKxAAJ7rjxvkoA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetAppHost"; + version = "8.0.10"; + hash = "sha512-wm6HQmklISelRc3fmi+wrOtsd0MOLZ+gmXUPBydF8pJuEeYatSSBMkcNOJqjGLdXuuMkM/Ub8T1qSNOUviutUg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Ref"; + version = "8.0.10"; + hash = "sha512-62Hc/ZoMyaMlUfO2WLhRIZYCbcfqo7ArXMIwevBwDf0wW+aceaSD11iS601gBcGwp/Q1Hz/ZCTUfeYvyYeSNoA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetHost"; + version = "8.0.10"; + hash = "sha512-6nQwLH8px/6F8XmHGicLZ6Bnx9clOmEbnXj6JLzKp6TkZCVdMlulIO8wVrsIfYn9UUgZ5M0FjEivcooilyvmdw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.10"; + hash = "sha512-v9n7AjgX/3+9siDoUnzaaOo4WiceOTu0P1DtD1WKD63g1HRB7X6SgjmEULG6wUhY73HuWu/mxGvRg/oMXyCCKw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.10"; + hash = "sha512-dQn8Z1iypqdntr/hfuuEt2qCdJZywJtociOEnl+jRp2wyEJcQNGBtNQfDT2LWqNj/tJjSY+a+ncuXT3UnnQvjQ=="; + }) + (fetchNupkg { + pname = "Microsoft.DotNet.ILCompiler"; + version = "8.0.10"; + hash = "sha512-cA9+iEQ0AikuCnRJ0ASaZbPPpVAINzbEbwR5I4fx2wrch2cdARdSwP3CQK1OAeR8IfA2EEm1jKpgT5fLJ7emHQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NET.ILLink.Tasks"; + version = "8.0.10"; + hash = "sha512-N3VO3kok4zHBI6gQC0+x6e/36ebf6xa6dIEzxMnuF/GGEgjseDNBSRI6/Ta/ACRR2LzwDE1CcLp5leBzxMkyAw=="; + }) ]; hostPackages = { linux-arm = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-arm"; version = "8.0.10"; hash = "sha512-BtkyaCDhxkQs7ibV9jQlAhkjlxwOzBr03rdEfhihGgYthOiTwkoqqzeB7vxrvP+H/uJgwysggwzwSQpaNGlJlw=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-arm"; + version = "8.0.10"; + hash = "sha512-BtkyaCDhxkQs7ibV9jQlAhkjlxwOzBr03rdEfhihGgYthOiTwkoqqzeB7vxrvP+H/uJgwysggwzwSQpaNGlJlw=="; + }) ]; linux-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-arm64"; version = "8.0.10"; hash = "sha512-Jt7crQk/OPyv1hiNDqUHiSoqZnujYPBSbU8sZ1bYWRTtxzw7g6lv8SqdrYmUbAfsfleC0gC+tCi4By2VY0IWhA=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.DotNet.ILCompiler"; version = "8.0.10"; hash = "sha512-MncgNrn5CKRG+3XKUXgoNl7dM+5RyxMp+rPD5AGBf/6o2KNLp6bdKLXGjuuDaVnbmkH8YKSJUc6lGpxuqOT4Yg=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-arm64"; + version = "8.0.10"; + hash = "sha512-Jt7crQk/OPyv1hiNDqUHiSoqZnujYPBSbU8sZ1bYWRTtxzw7g6lv8SqdrYmUbAfsfleC0gC+tCi4By2VY0IWhA=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.DotNet.ILCompiler"; + version = "8.0.10"; + hash = "sha512-MncgNrn5CKRG+3XKUXgoNl7dM+5RyxMp+rPD5AGBf/6o2KNLp6bdKLXGjuuDaVnbmkH8YKSJUc6lGpxuqOT4Yg=="; + }) ]; linux-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-x64"; version = "8.0.10"; hash = "sha512-l/BeXXBHSRwffmPVdY6ASNqL1Ny+WC8Ej+SQoEz3JVON9p4Ybl9xcVXx5UlMiEiwwVT+TnUH3mEjv9/cc+Qu4Q=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.DotNet.ILCompiler"; version = "8.0.10"; hash = "sha512-sGuQ8KR1T/iSkmIiULw8qIhjh3jXdGtEfXQPFpV90k1mfXAtjg28mbmCZxx369QU9c4X805AftOHZwth6m810g=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-x64"; + version = "8.0.10"; + hash = "sha512-l/BeXXBHSRwffmPVdY6ASNqL1Ny+WC8Ej+SQoEz3JVON9p4Ybl9xcVXx5UlMiEiwwVT+TnUH3mEjv9/cc+Qu4Q=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.DotNet.ILCompiler"; + version = "8.0.10"; + hash = "sha512-sGuQ8KR1T/iSkmIiULw8qIhjh3jXdGtEfXQPFpV90k1mfXAtjg28mbmCZxx369QU9c4X805AftOHZwth6m810g=="; + }) ]; linux-musl-arm = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm"; version = "8.0.10"; hash = "sha512-VeIp8DjQwmiW178AWs50+zRjFlh9PiVy5soW8tqapgGq7PiBxerD0si3xAnXugU7jHx0Ok8hNKPIa2AeaERWiw=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm"; + version = "8.0.10"; + hash = "sha512-VeIp8DjQwmiW178AWs50+zRjFlh9PiVy5soW8tqapgGq7PiBxerD0si3xAnXugU7jHx0Ok8hNKPIa2AeaERWiw=="; + }) ]; linux-musl-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm64"; version = "8.0.10"; hash = "sha512-JNztsZCLyTsk8IIl9FGwHIXJOhFFa3OAWD6wQfGykGw8e18hnNrm8BZT/TkV+1npHkNRltsgC+pilCvGTFS0kw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.DotNet.ILCompiler"; version = "8.0.10"; hash = "sha512-+z/hbOCAXri5KZHR/9r13ekpE5Yd3X0N/yIOK+ktBGXvWLdo4cZEnPL3tihsP4dAbUw6opzenRnFMu85FN7jwQ=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm64"; + version = "8.0.10"; + hash = "sha512-JNztsZCLyTsk8IIl9FGwHIXJOhFFa3OAWD6wQfGykGw8e18hnNrm8BZT/TkV+1npHkNRltsgC+pilCvGTFS0kw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.DotNet.ILCompiler"; + version = "8.0.10"; + hash = "sha512-+z/hbOCAXri5KZHR/9r13ekpE5Yd3X0N/yIOK+ktBGXvWLdo4cZEnPL3tihsP4dAbUw6opzenRnFMu85FN7jwQ=="; + }) ]; linux-musl-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-x64"; version = "8.0.10"; hash = "sha512-f9fD4rStb9clC4Kdw2oBtCR8a6UKHrGQwexldthR9K56vUbJfytX3YYwMqfyLNhpTpDuFrKRQ8lmtudeReykvw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.DotNet.ILCompiler"; version = "8.0.10"; hash = "sha512-RycMOl0s4egWecGU0EPcbtRrk1+rccsYFsELZQK0P+x5TGJC9aaBYf32E+hOz4RV0bFg0MGdrwTSIXig2xK65w=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-x64"; + version = "8.0.10"; + hash = "sha512-f9fD4rStb9clC4Kdw2oBtCR8a6UKHrGQwexldthR9K56vUbJfytX3YYwMqfyLNhpTpDuFrKRQ8lmtudeReykvw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.DotNet.ILCompiler"; + version = "8.0.10"; + hash = "sha512-RycMOl0s4egWecGU0EPcbtRrk1+rccsYFsELZQK0P+x5TGJC9aaBYf32E+hOz4RV0bFg0MGdrwTSIXig2xK65w=="; + }) ]; osx-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.osx-arm64"; version = "8.0.10"; hash = "sha512-4pNmDP63npARYQmw+lIhDQOI99Euog/rynCfABdSCVj6vB1FP0puZuml+pwawbGnIoKd7ZgaBYf4bjfIj1RHPQ=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.DotNet.ILCompiler"; version = "8.0.10"; hash = "sha512-ZNKweMNFH6zFDFs6Hc7cuu6FPDqI1eg9b6H2ztmpR7Sw5b1mp7pR0tEohWuT8fuFC6cSZpuxLwJ3LvG68fGrhw=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.osx-arm64"; + version = "8.0.10"; + hash = "sha512-4pNmDP63npARYQmw+lIhDQOI99Euog/rynCfABdSCVj6vB1FP0puZuml+pwawbGnIoKd7ZgaBYf4bjfIj1RHPQ=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.DotNet.ILCompiler"; + version = "8.0.10"; + hash = "sha512-ZNKweMNFH6zFDFs6Hc7cuu6FPDqI1eg9b6H2ztmpR7Sw5b1mp7pR0tEohWuT8fuFC6cSZpuxLwJ3LvG68fGrhw=="; + }) ]; osx-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.osx-x64"; version = "8.0.10"; hash = "sha512-eGKkNO23lblqy1iU2tBS3RfOSY7C0+sgcxutwg9ewIs6ZnwkbR9Y4supxsWW4RJHkOFjs96az654VUlhd0gEOA=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.DotNet.ILCompiler"; version = "8.0.10"; hash = "sha512-KdCyl/S7WpbK4gw/E+Y32fvbrW0GnYm+gfWMqLvrVyS7tImpnyn3MXR6aI5KtQWSRSPieZ0agSSlb+lCmeq5Og=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.osx-x64"; + version = "8.0.10"; + hash = "sha512-eGKkNO23lblqy1iU2tBS3RfOSY7C0+sgcxutwg9ewIs6ZnwkbR9Y4supxsWW4RJHkOFjs96az654VUlhd0gEOA=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.DotNet.ILCompiler"; + version = "8.0.10"; + hash = "sha512-KdCyl/S7WpbK4gw/E+Y32fvbrW0GnYm+gfWMqLvrVyS7tImpnyn3MXR6aI5KtQWSRSPieZ0agSSlb+lCmeq5Og=="; + }) ]; win-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-arm64"; version = "8.0.10"; hash = "sha512-k1mXRb5ot1WesCpIbswWPJ93CyhGlrIr+AlVVnWnjuo2h1n5blsiUssuzlymZFHCJBsWlrEsIi+AF1QQwYMxzA=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.DotNet.ILCompiler"; version = "8.0.10"; hash = "sha512-AhBOcNnE54H0zeADnWjsQYnNmEGXO0uUeW3Tb/si2hH4FVsEEj45VcL72bkQwOkg/GvpC3QIhKbhJcpWvHPBAg=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-arm64"; + version = "8.0.10"; + hash = "sha512-k1mXRb5ot1WesCpIbswWPJ93CyhGlrIr+AlVVnWnjuo2h1n5blsiUssuzlymZFHCJBsWlrEsIi+AF1QQwYMxzA=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.DotNet.ILCompiler"; + version = "8.0.10"; + hash = "sha512-AhBOcNnE54H0zeADnWjsQYnNmEGXO0uUeW3Tb/si2hH4FVsEEj45VcL72bkQwOkg/GvpC3QIhKbhJcpWvHPBAg=="; + }) ]; win-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-x64"; version = "8.0.10"; hash = "sha512-piu7U8YtQkilUXLBckW6DK3V/WOYafIpcbuska49JEND7LOcJnwhHsurx/5E2mbYKNhw/4mSQ7mRg6gGg3cDkg=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.DotNet.ILCompiler"; version = "8.0.10"; hash = "sha512-sYBKVezo3wUeONOGX1gsLIcIbAS2gTGy1Qq5iNYhlCoBsFA0VGI5+vWOc3Y4XCoDAT/T3us23Sa1qaz0J1qkcQ=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-x64"; + version = "8.0.10"; + hash = "sha512-piu7U8YtQkilUXLBckW6DK3V/WOYafIpcbuska49JEND7LOcJnwhHsurx/5E2mbYKNhw/4mSQ7mRg6gGg3cDkg=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.DotNet.ILCompiler"; + version = "8.0.10"; + hash = "sha512-sYBKVezo3wUeONOGX1gsLIcIbAS2gTGy1Qq5iNYhlCoBsFA0VGI5+vWOc3Y4XCoDAT/T3us23Sa1qaz0J1qkcQ=="; + }) ]; win-x86 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-x86"; version = "8.0.10"; hash = "sha512-clDN1mYknwk1TDvCjCSw0MxF6TCXq37UNPfdwlIJ8IRballtIFNT8nAXE21a2uE+tyQvRRb2WmB1l8EK5Q0/OQ=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-x86"; + version = "8.0.10"; + hash = "sha512-clDN1mYknwk1TDvCjCSw0MxF6TCXq37UNPfdwlIJ8IRballtIFNT8nAXE21a2uE+tyQvRRb2WmB1l8EK5Q0/OQ=="; + }) ]; }; targetPackages = { linux-arm = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm"; version = "8.0.10"; hash = "sha512-77QAZ3kJguh0yopM0rw9amHyGt5pC7fX4mS1A+U5h86xIFAqVO3EwIf/M6rewj0n2TYxjf26zm4dbdCnR9WOjw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-arm"; version = "8.0.10"; hash = "sha512-DSJF9/jWOVIqnutDo8qHKjZS7zJA0z/ijonXqbYByMIPXR1IlLDw1imPafynCC0fOjBgR5y4R4/6xeY+lfC3Gw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-arm"; version = "8.0.10"; hash = "sha512-+xARA3uXnKDW2XIArDA1qXNfYTGeV5bKtRPexvH1zU7sHS9+mt9IaQ6zPu96Z+gAhlmqEqcKozLMgVAJlpsFDg=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetAppHost"; version = "8.0.10"; hash = "sha512-jKI1C5RudJ7/WkxRkfF6NLRdFyQwc6OBpssmO6L3PLRRIWOiF9LZT8kIqAFlvEI4RnMWT7l3a18ZYGAbZWQo0w=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHost"; version = "8.0.10"; hash = "sha512-nafxACk5Z3jdOB8CzxJF4PA65DPRdsjdpFghiTxSfRzAoPNk+WHe1YEV1lTC36O1HePQxy0p/Gv7S+xv+g/Rgg=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.10"; hash = "sha512-zm8yoWBRxlUlLr/6e9rqJNWJCofDnv0/eAobltr/tSo8rjsZVPb9vzczdqCSPLELreqnhT6Z7wmdFpOAESQfxQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.10"; hash = "sha512-fTMFwna/qdY28Pzg4YEGtTeduuOqzAhkEDOVOkh7sQe/VyO6E/TGIRXjenOMxZqACKGowe4lNlVwd5saBAMKfA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm"; version = "8.0.10"; hash = "sha512-5dk1ER7hl9myUCaaKSGFODmsnM/XSr3Cyo13ti+yipttv/UDy5xand7/2vH+YLrasRo8lFkA269DKrRgaFUibw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm"; + version = "8.0.10"; + hash = "sha512-77QAZ3kJguh0yopM0rw9amHyGt5pC7fX4mS1A+U5h86xIFAqVO3EwIf/M6rewj0n2TYxjf26zm4dbdCnR9WOjw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-arm"; + version = "8.0.10"; + hash = "sha512-DSJF9/jWOVIqnutDo8qHKjZS7zJA0z/ijonXqbYByMIPXR1IlLDw1imPafynCC0fOjBgR5y4R4/6xeY+lfC3Gw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-arm"; + version = "8.0.10"; + hash = "sha512-+xARA3uXnKDW2XIArDA1qXNfYTGeV5bKtRPexvH1zU7sHS9+mt9IaQ6zPu96Z+gAhlmqEqcKozLMgVAJlpsFDg=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.10"; + hash = "sha512-jKI1C5RudJ7/WkxRkfF6NLRdFyQwc6OBpssmO6L3PLRRIWOiF9LZT8kIqAFlvEI4RnMWT7l3a18ZYGAbZWQo0w=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHost"; + version = "8.0.10"; + hash = "sha512-nafxACk5Z3jdOB8CzxJF4PA65DPRdsjdpFghiTxSfRzAoPNk+WHe1YEV1lTC36O1HePQxy0p/Gv7S+xv+g/Rgg=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.10"; + hash = "sha512-zm8yoWBRxlUlLr/6e9rqJNWJCofDnv0/eAobltr/tSo8rjsZVPb9vzczdqCSPLELreqnhT6Z7wmdFpOAESQfxQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.10"; + hash = "sha512-fTMFwna/qdY28Pzg4YEGtTeduuOqzAhkEDOVOkh7sQe/VyO6E/TGIRXjenOMxZqACKGowe4lNlVwd5saBAMKfA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm"; + version = "8.0.10"; + hash = "sha512-5dk1ER7hl9myUCaaKSGFODmsnM/XSr3Cyo13ti+yipttv/UDy5xand7/2vH+YLrasRo8lFkA269DKrRgaFUibw=="; + }) ]; linux-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; version = "8.0.10"; hash = "sha512-gFxz2UvSnulSNGn/XlmCrDwY2jUkd7UtYV9vghVoaog3jCwjji4Kfd1YFTiLKYy+A5+sgIhBqala54lwo8sRKQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-arm64"; version = "8.0.10"; hash = "sha512-VEhpJyS8wwmP6rtuzobmU06QFzLyMcGfA5a9GbhC46fn84+z70nMBl15gvZPWMmcqB5VZei+DohpLlOnkX/JHg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; version = "8.0.10"; hash = "sha512-y4+rLKkFKGFew6c5UIkXPeraVqhsnA2qNeEgEWnbYnPwLjAEORDw09peAjdxAwakHwlv/j12F7UdGs2tjCuayA=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.10"; hash = "sha512-fC4zeYX85f4NvC8uns2wEpqU1FxuWpB3FZQySCnvy1PrrUeO5q1v82xAXYoS5PwyT+esJBOcn8zv4odLLDnOsw=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHost"; version = "8.0.10"; hash = "sha512-HO31muFMnV7wl7wCJi+vIyWpDCZETjL0Nrkyq6AflGhb19jOCOUn/+lIkERWrvbpcMtnpxO+D1MvGg72VWxVeA=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.10"; hash = "sha512-dEFPSx0rf3e1cb7FQnpczaWQdtY2MZ3so4p3PDXq+c6nJoHzQ5Go9PiDTfJInErvuHndCkgnDGPtEOXWPZXjhA=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.10"; hash = "sha512-qJTYIaLNTVDzJDH6MuRJcF28TEiid4YGSCd7E9tLxhWtafn0N3SBOxvPkG43X8U/VAqRlnef2IZwacIBjM89cg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm64"; version = "8.0.10"; hash = "sha512-f1GHDkwqIUdn6QmM/daaVG7L6/LLT/kKT9TlIn4SkspwbAbhCdoMSIuii9fT6rhpKvSgM0/N1cej5p457knIjg=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; + version = "8.0.10"; + hash = "sha512-gFxz2UvSnulSNGn/XlmCrDwY2jUkd7UtYV9vghVoaog3jCwjji4Kfd1YFTiLKYy+A5+sgIhBqala54lwo8sRKQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-arm64"; + version = "8.0.10"; + hash = "sha512-VEhpJyS8wwmP6rtuzobmU06QFzLyMcGfA5a9GbhC46fn84+z70nMBl15gvZPWMmcqB5VZei+DohpLlOnkX/JHg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; + version = "8.0.10"; + hash = "sha512-y4+rLKkFKGFew6c5UIkXPeraVqhsnA2qNeEgEWnbYnPwLjAEORDw09peAjdxAwakHwlv/j12F7UdGs2tjCuayA=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.10"; + hash = "sha512-fC4zeYX85f4NvC8uns2wEpqU1FxuWpB3FZQySCnvy1PrrUeO5q1v82xAXYoS5PwyT+esJBOcn8zv4odLLDnOsw=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHost"; + version = "8.0.10"; + hash = "sha512-HO31muFMnV7wl7wCJi+vIyWpDCZETjL0Nrkyq6AflGhb19jOCOUn/+lIkERWrvbpcMtnpxO+D1MvGg72VWxVeA=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.10"; + hash = "sha512-dEFPSx0rf3e1cb7FQnpczaWQdtY2MZ3so4p3PDXq+c6nJoHzQ5Go9PiDTfJInErvuHndCkgnDGPtEOXWPZXjhA=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.10"; + hash = "sha512-qJTYIaLNTVDzJDH6MuRJcF28TEiid4YGSCd7E9tLxhWtafn0N3SBOxvPkG43X8U/VAqRlnef2IZwacIBjM89cg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm64"; + version = "8.0.10"; + hash = "sha512-f1GHDkwqIUdn6QmM/daaVG7L6/LLT/kKT9TlIn4SkspwbAbhCdoMSIuii9fT6rhpKvSgM0/N1cej5p457knIjg=="; + }) ]; linux-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; version = "8.0.10"; hash = "sha512-FBW0xpiJK6Fwb6qlxNEYaMJ2klUNGCDihrW7pjr4Ly/vZLCWbN3+fvOBhr744KBFkMwzcWY+RVzlPxxKPx+H+A=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-x64"; version = "8.0.10"; hash = "sha512-m5RTYSvHMDhhekHIBOpE+ydjVh+yYZ2TCSFNXTSDHf/E/jntSL3ICXO4SU9t4iBNU/KH1hxOaZ4sEA0NBVHg4Q=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-x64"; version = "8.0.10"; hash = "sha512-uh3DqyNvqgqSYYGQsZ9msABaT6DfWyxWVbXoo1aJx5+Aoph2HMd4hASlVwFK8kV7Hfxw274MOuj9X6rd6wLS3g=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.10"; hash = "sha512-J20ErWVUMXDz6bQIkyrmKbGLcTpvgVTwxm0Ps7iFkK7LaAQL8ZWYkDzubuRu0VXRcfcnmHlxB3ccCPuUBulKWw=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHost"; version = "8.0.10"; hash = "sha512-+7RMvtudiKm56zOQ21SqpdT3kX51BC7a+wOaK6weEtQEbLHFZO+G054gneIjc0o4roUkYdqdq/etuM7Bkob+OQ=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.10"; hash = "sha512-nn4uNK3/AZQ74RImi9vUF92sm4zFxkgH6bSNioaZ0v1z2BG4ZUZPazGAO7+mvi3CzBqblwy/+6T/IaBcPslQFg=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.10"; hash = "sha512-k3DgtNRobU6eWPriLb/jLm3dknw3HZHRh6lXLIAiquV12FdOhUfvGJG68r3YVo2tb4dOCUFKfBLElyeTho+RLQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-x64"; version = "8.0.10"; hash = "sha512-QWgbs/CSdrSsncROqEtmkdiXBE5xLkCoF766Qv/SN9egO9TBiQ4LfMaVsoqpMPrzuUdNQ4oL0JEqz1Zi48oqYw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; + version = "8.0.10"; + hash = "sha512-FBW0xpiJK6Fwb6qlxNEYaMJ2klUNGCDihrW7pjr4Ly/vZLCWbN3+fvOBhr744KBFkMwzcWY+RVzlPxxKPx+H+A=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-x64"; + version = "8.0.10"; + hash = "sha512-m5RTYSvHMDhhekHIBOpE+ydjVh+yYZ2TCSFNXTSDHf/E/jntSL3ICXO4SU9t4iBNU/KH1hxOaZ4sEA0NBVHg4Q=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-x64"; + version = "8.0.10"; + hash = "sha512-uh3DqyNvqgqSYYGQsZ9msABaT6DfWyxWVbXoo1aJx5+Aoph2HMd4hASlVwFK8kV7Hfxw274MOuj9X6rd6wLS3g=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.10"; + hash = "sha512-J20ErWVUMXDz6bQIkyrmKbGLcTpvgVTwxm0Ps7iFkK7LaAQL8ZWYkDzubuRu0VXRcfcnmHlxB3ccCPuUBulKWw=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHost"; + version = "8.0.10"; + hash = "sha512-+7RMvtudiKm56zOQ21SqpdT3kX51BC7a+wOaK6weEtQEbLHFZO+G054gneIjc0o4roUkYdqdq/etuM7Bkob+OQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.10"; + hash = "sha512-nn4uNK3/AZQ74RImi9vUF92sm4zFxkgH6bSNioaZ0v1z2BG4ZUZPazGAO7+mvi3CzBqblwy/+6T/IaBcPslQFg=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.10"; + hash = "sha512-k3DgtNRobU6eWPriLb/jLm3dknw3HZHRh6lXLIAiquV12FdOhUfvGJG68r3YVo2tb4dOCUFKfBLElyeTho+RLQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-x64"; + version = "8.0.10"; + hash = "sha512-QWgbs/CSdrSsncROqEtmkdiXBE5xLkCoF766Qv/SN9egO9TBiQ4LfMaVsoqpMPrzuUdNQ4oL0JEqz1Zi48oqYw=="; + }) ]; linux-musl-arm = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm"; version = "8.0.10"; hash = "sha512-2uLQry2nFKlbvUp6F2WQkB03xdFE3dto/Qc/jifCS3RnBT8/Qp6xNvdlRypjlqfyKIiia6ry0ymLhGRfa3qUOQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-arm"; version = "8.0.10"; hash = "sha512-UukhmPFuE7OSVQ+pLHZKFE5LDPUWnXMpbi3RZXebCU7xvQMUvV2px+qNkprefvFxZqq/8akyqZnNawhR2y80Sw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm"; version = "8.0.10"; hash = "sha512-Oim+j+EbgEgFeOxyEZp6QlLGeVzr8Yn/hXM5Xcx/xR3fj8FrMzQlHTRYVrxuiYCqhieZap6MDBSPS6Rj9O6OGA=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetAppHost"; version = "8.0.10"; hash = "sha512-h8FumxGXn+dVTj/uj++rAcp/qfmxHAL6doMtFnw+0KYYt+tbsGVdoeSBu2XkZOA9IfJrHzgDft55uTBstrjttQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHost"; version = "8.0.10"; hash = "sha512-ttV8As1u0LjTs82nFDIclwpzV9M4MN59PKvSHEZ9PSmxOLXISK1Yu6pPUGn1T5zEud5oSTBZ1pwfhyeKuIxDrw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.10"; hash = "sha512-JjoooPntqOXl6Sl4/3Vx1MtLJSsqeDqOvMXomX5qF11W8D81lk0VgJYy7OyOPhIUbsl3GIKLthrVGHcT8NnL1Q=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.10"; hash = "sha512-WMPivnrgK8ebUiDo5kreJmZifJs32mC1w/gm5uH/1wA+N4sfBHP/5uiLKYjuLCUHWSOUDVFcnTs8SUyOVnFpCA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm"; + version = "8.0.10"; + hash = "sha512-2uLQry2nFKlbvUp6F2WQkB03xdFE3dto/Qc/jifCS3RnBT8/Qp6xNvdlRypjlqfyKIiia6ry0ymLhGRfa3qUOQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-arm"; + version = "8.0.10"; + hash = "sha512-UukhmPFuE7OSVQ+pLHZKFE5LDPUWnXMpbi3RZXebCU7xvQMUvV2px+qNkprefvFxZqq/8akyqZnNawhR2y80Sw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm"; + version = "8.0.10"; + hash = "sha512-Oim+j+EbgEgFeOxyEZp6QlLGeVzr8Yn/hXM5Xcx/xR3fj8FrMzQlHTRYVrxuiYCqhieZap6MDBSPS6Rj9O6OGA=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.10"; + hash = "sha512-h8FumxGXn+dVTj/uj++rAcp/qfmxHAL6doMtFnw+0KYYt+tbsGVdoeSBu2XkZOA9IfJrHzgDft55uTBstrjttQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHost"; + version = "8.0.10"; + hash = "sha512-ttV8As1u0LjTs82nFDIclwpzV9M4MN59PKvSHEZ9PSmxOLXISK1Yu6pPUGn1T5zEud5oSTBZ1pwfhyeKuIxDrw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.10"; + hash = "sha512-JjoooPntqOXl6Sl4/3Vx1MtLJSsqeDqOvMXomX5qF11W8D81lk0VgJYy7OyOPhIUbsl3GIKLthrVGHcT8NnL1Q=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.10"; + hash = "sha512-WMPivnrgK8ebUiDo5kreJmZifJs32mC1w/gm5uH/1wA+N4sfBHP/5uiLKYjuLCUHWSOUDVFcnTs8SUyOVnFpCA=="; + }) ]; linux-musl-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm64"; version = "8.0.10"; hash = "sha512-fzenqK18er5hw7LvJZOyoDwYbRod1v0b69czJcoGA/6REoqumLnXDgl+4glhg4aFgyam1UZeSGhuz/i+Sm4Dug=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-arm64"; version = "8.0.10"; hash = "sha512-4yUt757dCovjB9pWFOJLCSy13j8+X0nWLHbIWXIBZr3rFViTDmb1/Ee5Rmojgp47voK2BvRkDsauR79MCDXJSQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm64"; version = "8.0.10"; hash = "sha512-v+y1PesLbNKveNdln9wbtzXEH//rlpPTTmISuoHBJSTEvqvkQYcPAHA75FA3ZJfAHoerAZ0MilhJMQCyFyq5Vw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.10"; hash = "sha512-v+vutaIctLzqgAslzdnF0jvajbHfCAtLwm/gKWNFP7iuSHiokMwiasxTKpiw/uBv+VUdNGmKOgViIAzYqAmCJA=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHost"; version = "8.0.10"; hash = "sha512-Thf8u0x5rRf+/1IRBo8HZUVLgHMN5mY97dB0x3DNeHcbWs4MM/S+1BvF7zzNueP1s2+fKci5pKNSM/PszrxS3Q=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.10"; hash = "sha512-/FOMmkX2AagTyyP+pT3gn8LvWxvlg7pKI+kG4PvUJNbUtyB9bbkt16AmtjZUjMKcn1WVA/IhYM52cXnJbI7gsA=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.10"; hash = "sha512-5ReoWUX4NhoT/fLcdxncsFucSrAf9qml43Xmh8qOYzpj/cXqX8Jp8vmcXuyXW5SRL5IeaxROA1pekkmy1dRt0w=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm64"; + version = "8.0.10"; + hash = "sha512-fzenqK18er5hw7LvJZOyoDwYbRod1v0b69czJcoGA/6REoqumLnXDgl+4glhg4aFgyam1UZeSGhuz/i+Sm4Dug=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-arm64"; + version = "8.0.10"; + hash = "sha512-4yUt757dCovjB9pWFOJLCSy13j8+X0nWLHbIWXIBZr3rFViTDmb1/Ee5Rmojgp47voK2BvRkDsauR79MCDXJSQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm64"; + version = "8.0.10"; + hash = "sha512-v+y1PesLbNKveNdln9wbtzXEH//rlpPTTmISuoHBJSTEvqvkQYcPAHA75FA3ZJfAHoerAZ0MilhJMQCyFyq5Vw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.10"; + hash = "sha512-v+vutaIctLzqgAslzdnF0jvajbHfCAtLwm/gKWNFP7iuSHiokMwiasxTKpiw/uBv+VUdNGmKOgViIAzYqAmCJA=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHost"; + version = "8.0.10"; + hash = "sha512-Thf8u0x5rRf+/1IRBo8HZUVLgHMN5mY97dB0x3DNeHcbWs4MM/S+1BvF7zzNueP1s2+fKci5pKNSM/PszrxS3Q=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.10"; + hash = "sha512-/FOMmkX2AagTyyP+pT3gn8LvWxvlg7pKI+kG4PvUJNbUtyB9bbkt16AmtjZUjMKcn1WVA/IhYM52cXnJbI7gsA=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.10"; + hash = "sha512-5ReoWUX4NhoT/fLcdxncsFucSrAf9qml43Xmh8qOYzpj/cXqX8Jp8vmcXuyXW5SRL5IeaxROA1pekkmy1dRt0w=="; + }) ]; linux-musl-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-x64"; version = "8.0.10"; hash = "sha512-E5qJsr0MBnG2omiOk5GmeBBCRCized/HmpmSIAC3SGztKuz6eMSbOUcuk35kD2iH+ZVPmaRXDKClE1Qj4WMCrg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-x64"; version = "8.0.10"; hash = "sha512-sNHnfGMGDqK6dtlnronOc2D2OteJpnTC+An+9LJy7tzNSH1IiRfD5PX0OY5DAmbpglAQ5dbIbp86M/42SVq8eQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-x64"; version = "8.0.10"; hash = "sha512-Yb1UypJH+Vvhnlkybw1gzS4WS9tAWxQ/psn/MnRb3qf0KjQARVEYauHz3rmu3/DKS1y5LZvAcm19ek995qFoGw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.10"; hash = "sha512-JbuWO4IcmZM3zAYbx31XOdaJkf86tD+HbgwotStsfnc67XpWywjJpIgRvTFEVA1D/qZJ7E8fxjwdKXpm3b0Gsw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHost"; version = "8.0.10"; hash = "sha512-OGjSti6J8Yu+DPOeiFrzTH9yFf+W9V10gbFVExSN3YwXK+TLbx6BDqqoQXtkClPtFHVqI95dDcpOnRBfaLsTxw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.10"; hash = "sha512-bzc9oXoUm+LJUTaU7KhPJn1mOG2diT0Tj1u+lY1P26jJmW14N5gTj7q5wyv/JQ8XkYuPnbakMyqX634+Ewqc7w=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.10"; hash = "sha512-UkDXcCKtEP+85Px6PqnaAWBof0NmrMj+r5TntwdfCvyipcf0xQAWT6ykYzy1YXiIJB/Xdp+8W0WVPKiTcgpVfQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-musl-x64"; version = "8.0.10"; hash = "sha512-OgApkkQ0tw49zUlL1Zn0W5T4OmlZwXV33vtRIx48D3mjezPhYczFX2Dj8W6OCLeu3kkryKSPFb4GaMTRN1BHRQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-x64"; + version = "8.0.10"; + hash = "sha512-E5qJsr0MBnG2omiOk5GmeBBCRCized/HmpmSIAC3SGztKuz6eMSbOUcuk35kD2iH+ZVPmaRXDKClE1Qj4WMCrg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-x64"; + version = "8.0.10"; + hash = "sha512-sNHnfGMGDqK6dtlnronOc2D2OteJpnTC+An+9LJy7tzNSH1IiRfD5PX0OY5DAmbpglAQ5dbIbp86M/42SVq8eQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-x64"; + version = "8.0.10"; + hash = "sha512-Yb1UypJH+Vvhnlkybw1gzS4WS9tAWxQ/psn/MnRb3qf0KjQARVEYauHz3rmu3/DKS1y5LZvAcm19ek995qFoGw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.10"; + hash = "sha512-JbuWO4IcmZM3zAYbx31XOdaJkf86tD+HbgwotStsfnc67XpWywjJpIgRvTFEVA1D/qZJ7E8fxjwdKXpm3b0Gsw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHost"; + version = "8.0.10"; + hash = "sha512-OGjSti6J8Yu+DPOeiFrzTH9yFf+W9V10gbFVExSN3YwXK+TLbx6BDqqoQXtkClPtFHVqI95dDcpOnRBfaLsTxw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.10"; + hash = "sha512-bzc9oXoUm+LJUTaU7KhPJn1mOG2diT0Tj1u+lY1P26jJmW14N5gTj7q5wyv/JQ8XkYuPnbakMyqX634+Ewqc7w=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.10"; + hash = "sha512-UkDXcCKtEP+85Px6PqnaAWBof0NmrMj+r5TntwdfCvyipcf0xQAWT6ykYzy1YXiIJB/Xdp+8W0WVPKiTcgpVfQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-musl-x64"; + version = "8.0.10"; + hash = "sha512-OgApkkQ0tw49zUlL1Zn0W5T4OmlZwXV33vtRIx48D3mjezPhYczFX2Dj8W6OCLeu3kkryKSPFb4GaMTRN1BHRQ=="; + }) ]; osx-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.osx-arm64"; version = "8.0.10"; hash = "sha512-KmQrSBWHmNOd0xDMsM0oDKhT5zJ5gNJDDjV5F+S+FFTmImGI1O8PkXuHwJ4N7ff9553e0c1kIwiwt5dfS9R1yQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.osx-arm64"; version = "8.0.10"; hash = "sha512-ZPrFs66uEZbdHkaAbv2ODqjuLROFtCEGnu0AmbCCvNfPh9dI35ywmDboEKE4urYeMqdi+EAPq2VjpG0N3PMy3A=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.osx-arm64"; version = "8.0.10"; hash = "sha512-0QqgTnNYbvhM5g/aMTh1epbCexRZdzQyQwmgfGJcWiqddsQ9yUfuo9dKE6jSZO4Cia5jbUDJYsZmvicblGzukg=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.10"; hash = "sha512-F6vhh3lgBpYEEGVz4Ob0751nXU1XJdJcZQYldOk1rfteUGD5vwjLRlUz/FNF998TrLslNAef8QfGRcwK4yDbgg=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHost"; version = "8.0.10"; hash = "sha512-GM7wSReWJRO9UllnTFdm4iFOJ8S6gLKD1/HeCQQScF/XfpZuvmU+V3nbxPoeOi3o6ror6UDgAoLzpZawawi0NQ=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.10"; hash = "sha512-DgMv3ag+oB3rLUs2/9zu6Abpv/KvZCfNRbWNtefs8zjEEDT4NVD85dDNfXulmG5ZNKymYh/oE4SK/u+5eTBGMw=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.10"; hash = "sha512-3N45wLtwOancsvOEeku4zntYb5Atmp3+t/E2u08mkVzJ4M+kfB5t4NHlx2myd79Ur/xfNjtTUb8f9S3pNBtRRg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.osx-arm64"; version = "8.0.10"; hash = "sha512-ctCNTU+ne/ll5/U00OXHcnsn3pnaPduJ1QR4ulihU9Jz5LzURFsOU1DyoBaRlhkpmCAjkel7boRt9wXLZkxRog=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.osx-arm64"; + version = "8.0.10"; + hash = "sha512-KmQrSBWHmNOd0xDMsM0oDKhT5zJ5gNJDDjV5F+S+FFTmImGI1O8PkXuHwJ4N7ff9553e0c1kIwiwt5dfS9R1yQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.osx-arm64"; + version = "8.0.10"; + hash = "sha512-ZPrFs66uEZbdHkaAbv2ODqjuLROFtCEGnu0AmbCCvNfPh9dI35ywmDboEKE4urYeMqdi+EAPq2VjpG0N3PMy3A=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.osx-arm64"; + version = "8.0.10"; + hash = "sha512-0QqgTnNYbvhM5g/aMTh1epbCexRZdzQyQwmgfGJcWiqddsQ9yUfuo9dKE6jSZO4Cia5jbUDJYsZmvicblGzukg=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.10"; + hash = "sha512-F6vhh3lgBpYEEGVz4Ob0751nXU1XJdJcZQYldOk1rfteUGD5vwjLRlUz/FNF998TrLslNAef8QfGRcwK4yDbgg=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHost"; + version = "8.0.10"; + hash = "sha512-GM7wSReWJRO9UllnTFdm4iFOJ8S6gLKD1/HeCQQScF/XfpZuvmU+V3nbxPoeOi3o6ror6UDgAoLzpZawawi0NQ=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.10"; + hash = "sha512-DgMv3ag+oB3rLUs2/9zu6Abpv/KvZCfNRbWNtefs8zjEEDT4NVD85dDNfXulmG5ZNKymYh/oE4SK/u+5eTBGMw=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.10"; + hash = "sha512-3N45wLtwOancsvOEeku4zntYb5Atmp3+t/E2u08mkVzJ4M+kfB5t4NHlx2myd79Ur/xfNjtTUb8f9S3pNBtRRg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.osx-arm64"; + version = "8.0.10"; + hash = "sha512-ctCNTU+ne/ll5/U00OXHcnsn3pnaPduJ1QR4ulihU9Jz5LzURFsOU1DyoBaRlhkpmCAjkel7boRt9wXLZkxRog=="; + }) ]; osx-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; version = "8.0.10"; hash = "sha512-LtLLJ5VE1kal9aZjf8WT8ZEnpJHHCt2wgYlcIGIiFg48MhKjS8NRgZnfLuZilk6u8lQ6vJVB3FwD+fL1wS2clQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.osx-x64"; version = "8.0.10"; hash = "sha512-ge/ZgANVduHB/8zdvHYmzv13y7OzkVEGmdABYC9NamGnNGNYvBhfQT2a1GX0pDzu2w5OmRJBLH3DBQFctOPABw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.osx-x64"; version = "8.0.10"; hash = "sha512-2x7tsitjwPXMZ5xQgme+CX8x/kpfS+P1t9nXFFl8CL/pVWE0Fj7ChZ4dwkSPFA/zky+3oNftJ7SdFjs6yzP6rw=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.10"; hash = "sha512-reEJfxHqrChAilKFnbuxd7kH8iiLndgSsMuHq/NCB1RSuxRnG35WMv4SHO1gXbPcjJRez5wSVfdGDyj2dBioCg=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHost"; version = "8.0.10"; hash = "sha512-dDyiYntefAD7AMq2ZCRRJbFwiPN8OdQ4jfPCe2GBnFKBIGnWhR4Hx8BHTNwuoLvqLL09JJ+lae9uDAGk/5+M3A=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.10"; hash = "sha512-Zudv1u+dN0JadwODnB6MrdyOnBiog+IHnIEWvUanhgv4mfVTwNvZib8pSf16LIn20HHVC6tJNPu6YpWXWYehIA=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.10"; hash = "sha512-9Y1TCB2W7h/2GYoxI0C9SU09VBcjijiUyWA+Dwi1Kw9CvWfqruwPI5qhbFBdWifKTyOmMUqoLnYQEfftp+JIaQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.osx-x64"; version = "8.0.10"; hash = "sha512-rSStQsUWxolcgt/P7rMj+WtUWImPMHbknL017a7Tda84khR2mibZkOYR9uF44xO7j7uoLKwWVSHrriS0yC/CGA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; + version = "8.0.10"; + hash = "sha512-LtLLJ5VE1kal9aZjf8WT8ZEnpJHHCt2wgYlcIGIiFg48MhKjS8NRgZnfLuZilk6u8lQ6vJVB3FwD+fL1wS2clQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.osx-x64"; + version = "8.0.10"; + hash = "sha512-ge/ZgANVduHB/8zdvHYmzv13y7OzkVEGmdABYC9NamGnNGNYvBhfQT2a1GX0pDzu2w5OmRJBLH3DBQFctOPABw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.osx-x64"; + version = "8.0.10"; + hash = "sha512-2x7tsitjwPXMZ5xQgme+CX8x/kpfS+P1t9nXFFl8CL/pVWE0Fj7ChZ4dwkSPFA/zky+3oNftJ7SdFjs6yzP6rw=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.10"; + hash = "sha512-reEJfxHqrChAilKFnbuxd7kH8iiLndgSsMuHq/NCB1RSuxRnG35WMv4SHO1gXbPcjJRez5wSVfdGDyj2dBioCg=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHost"; + version = "8.0.10"; + hash = "sha512-dDyiYntefAD7AMq2ZCRRJbFwiPN8OdQ4jfPCe2GBnFKBIGnWhR4Hx8BHTNwuoLvqLL09JJ+lae9uDAGk/5+M3A=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.10"; + hash = "sha512-Zudv1u+dN0JadwODnB6MrdyOnBiog+IHnIEWvUanhgv4mfVTwNvZib8pSf16LIn20HHVC6tJNPu6YpWXWYehIA=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.10"; + hash = "sha512-9Y1TCB2W7h/2GYoxI0C9SU09VBcjijiUyWA+Dwi1Kw9CvWfqruwPI5qhbFBdWifKTyOmMUqoLnYQEfftp+JIaQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.osx-x64"; + version = "8.0.10"; + hash = "sha512-rSStQsUWxolcgt/P7rMj+WtUWImPMHbknL017a7Tda84khR2mibZkOYR9uF44xO7j7uoLKwWVSHrriS0yC/CGA=="; + }) ]; win-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-arm64"; version = "8.0.10"; hash = "sha512-OgL6i82BRwnTG5kaUOdx1waAjw0rVL1/KqHldtRfsgo6+gsyAC2sCA8WXbXAJg/eq9/wW6IjV0a6qdfMobpk1w=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-arm64"; version = "8.0.10"; hash = "sha512-5ugZdamA3a1q5PxWouxCTgZt0v5faqXzpSXFJWU+yNjT7RsRmDjKrYMg2/IYIPSJoadB+DVk4gizIlApkDrIMw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-arm64"; version = "8.0.10"; hash = "sha512-KGRJ/C2p81Q9NlUHIP98NcYUT0hxrckxWZoE8cJzp9dNPWaMfAO7OemuPBU1HsnBNEDrFRvbI2T6chw0gBRIqQ=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.10"; hash = "sha512-OFP6LhDSxCwQZtkPtQpAg1kZO5tyrrw+eNziRR2hQntADHk2euR5trvSKR37Ah5fLU/hWbBDxa5nlYF5BiKbMA=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHost"; version = "8.0.10"; hash = "sha512-D3hpY5NnpvIg4fNVKcJYYUwxfaFY8AHTvYzwT0D0tb0qcXKIMsJEm7lRM2vsENuhHn02tWTvsyRuo5h9XmmG/g=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.10"; hash = "sha512-pMagTteRJ2XwPeJnonPRvA5A4v3f4F+X1iu08RxPwTXVDsS4xemkm1LfZgiyPADIrAsY6DBFLXvK5fZ0uaBigA=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.10"; hash = "sha512-fprLJDM1dWKqI3n2DjCVSY8l7zBngdjnLid8HZxdHn1Hr9m57k4wcbFc/otHfnTHcYF0MXPrC6VO4CgRYFtIkA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-arm64"; + version = "8.0.10"; + hash = "sha512-OgL6i82BRwnTG5kaUOdx1waAjw0rVL1/KqHldtRfsgo6+gsyAC2sCA8WXbXAJg/eq9/wW6IjV0a6qdfMobpk1w=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-arm64"; + version = "8.0.10"; + hash = "sha512-5ugZdamA3a1q5PxWouxCTgZt0v5faqXzpSXFJWU+yNjT7RsRmDjKrYMg2/IYIPSJoadB+DVk4gizIlApkDrIMw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-arm64"; + version = "8.0.10"; + hash = "sha512-KGRJ/C2p81Q9NlUHIP98NcYUT0hxrckxWZoE8cJzp9dNPWaMfAO7OemuPBU1HsnBNEDrFRvbI2T6chw0gBRIqQ=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.10"; + hash = "sha512-OFP6LhDSxCwQZtkPtQpAg1kZO5tyrrw+eNziRR2hQntADHk2euR5trvSKR37Ah5fLU/hWbBDxa5nlYF5BiKbMA=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHost"; + version = "8.0.10"; + hash = "sha512-D3hpY5NnpvIg4fNVKcJYYUwxfaFY8AHTvYzwT0D0tb0qcXKIMsJEm7lRM2vsENuhHn02tWTvsyRuo5h9XmmG/g=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.10"; + hash = "sha512-pMagTteRJ2XwPeJnonPRvA5A4v3f4F+X1iu08RxPwTXVDsS4xemkm1LfZgiyPADIrAsY6DBFLXvK5fZ0uaBigA=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.10"; + hash = "sha512-fprLJDM1dWKqI3n2DjCVSY8l7zBngdjnLid8HZxdHn1Hr9m57k4wcbFc/otHfnTHcYF0MXPrC6VO4CgRYFtIkA=="; + }) ]; win-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-x64"; version = "8.0.10"; hash = "sha512-aBIdHUFn4vBEIN/v9+8ix+C/7Ljrb9zgFp6naPO37XlvGTuOgYm4tc2hfs1wbjc3VxaC2Gzc2smzUwahicAM6A=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-x64"; version = "8.0.10"; hash = "sha512-auvgyTucWFrK3TZnC6T4RfCLfePpms/UOnJks1b8hErIVOHlfTHZmsLMECKJKl3wVeFrEYfVDbzE9Ac8PDeFgw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-x64"; version = "8.0.10"; hash = "sha512-8B6BJexY8yGK9sB6/tKWoGfqCIdOJ2NtnaoHFKB4j07VHSaNYaHrzh5HEynC4pFF6kbMsyJqs9sU9T/YGZRigw=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.10"; hash = "sha512-ltjs90IokeIj6/Y8SdJ+IUXPYBJiruJDxYvnayPJKtDVdDUGRQNfpI9YFflgSWkoztqPN5H2OELUAiowOdxOhw=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetHost"; version = "8.0.10"; hash = "sha512-a1jTRbxRVMMxi0wsqlnMLEoWYm0p1T04atL0QeMe+VS78G959Thde1GckB7e6aX4tv291/br62ELG7O0yUXR4w=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.10"; hash = "sha512-VY6rMwR9QzRKhuUVBCFSVwPBPIqH20C+F4W2R6KP0GajGfu6h1/AdtnJS0op+76fIg0qia8JFuW6DUhc3UmSLQ=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.10"; hash = "sha512-yWJ8LOGQ1/pKyT/qHjGkU+RuWmCy9OsUe/ANtHA5kTHmY4g4RNwP8+eDW1K3+g5BESfaENlJiNiTnWwTn2CFQQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.win-x64"; version = "8.0.10"; hash = "sha512-qrxC9S51t2w84jLBttmTmLmS1KjHscP31REqw8I117VnX/R7861Aabj7gg0cVz6YiGaeBqgzuUt/yBiHu18xeQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-x64"; + version = "8.0.10"; + hash = "sha512-aBIdHUFn4vBEIN/v9+8ix+C/7Ljrb9zgFp6naPO37XlvGTuOgYm4tc2hfs1wbjc3VxaC2Gzc2smzUwahicAM6A=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-x64"; + version = "8.0.10"; + hash = "sha512-auvgyTucWFrK3TZnC6T4RfCLfePpms/UOnJks1b8hErIVOHlfTHZmsLMECKJKl3wVeFrEYfVDbzE9Ac8PDeFgw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-x64"; + version = "8.0.10"; + hash = "sha512-8B6BJexY8yGK9sB6/tKWoGfqCIdOJ2NtnaoHFKB4j07VHSaNYaHrzh5HEynC4pFF6kbMsyJqs9sU9T/YGZRigw=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.10"; + hash = "sha512-ltjs90IokeIj6/Y8SdJ+IUXPYBJiruJDxYvnayPJKtDVdDUGRQNfpI9YFflgSWkoztqPN5H2OELUAiowOdxOhw=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetHost"; + version = "8.0.10"; + hash = "sha512-a1jTRbxRVMMxi0wsqlnMLEoWYm0p1T04atL0QeMe+VS78G959Thde1GckB7e6aX4tv291/br62ELG7O0yUXR4w=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.10"; + hash = "sha512-VY6rMwR9QzRKhuUVBCFSVwPBPIqH20C+F4W2R6KP0GajGfu6h1/AdtnJS0op+76fIg0qia8JFuW6DUhc3UmSLQ=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.10"; + hash = "sha512-yWJ8LOGQ1/pKyT/qHjGkU+RuWmCy9OsUe/ANtHA5kTHmY4g4RNwP8+eDW1K3+g5BESfaENlJiNiTnWwTn2CFQQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.win-x64"; + version = "8.0.10"; + hash = "sha512-qrxC9S51t2w84jLBttmTmLmS1KjHscP31REqw8I117VnX/R7861Aabj7gg0cVz6YiGaeBqgzuUt/yBiHu18xeQ=="; + }) ]; win-x86 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-x86"; version = "8.0.10"; hash = "sha512-NGl4nsuWJgLBQobSkbOxJgkT04uyetP/Kv8JXz7qN6MV0q+MjyhYQY29H8ODQgSMi4viOBL9KHbrTc6K+oSD7w=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-x86"; version = "8.0.10"; hash = "sha512-Fdc4ceK2VvksnIYLF7SFO6mtr3A6Ktsw8Xu46ja3BxawnHTLmgV7dY9mh0R1JgiandksQMOS6AOSjz0D9Ce78g=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-x86"; version = "8.0.10"; hash = "sha512-PmrjkpJyXstmNJCyaHwOS3WdQTGYZa3Ik/ayjg+APgNSBbcP/TBnEGg91esUmgZ5k2Gz+WGCQS6wQxATTTJcKw=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetAppHost"; version = "8.0.10"; hash = "sha512-feQLgFQlSHP+zSIjLXq+n4zC3jKYRAiXPJ8iY90nk2xAfRWYIb6redRB4dUhqhv5uaCrfi8W2r0AXZX8/GEkjg=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetHost"; version = "8.0.10"; hash = "sha512-P97h50G0e61YXisIsZOWFcE/ldXH2R5gbX+SD+6t7FgmNQwaIl80xQMjEICfJ2uk9CoYKw2jWiwjQEdqoa9g1Q=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.10"; hash = "sha512-Mp2Scz97QbDE1CKZli/Z4zDSeQGSjN4vuylZUqvLukTTGTM1xB89a0TLf5ooz6rZefyNecAY2WOP0fr+oOjpPg=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.10"; hash = "sha512-Voo3Y/uZNEaiWfePrWjKkpsgZBR1dmgwuCf/8sxMCSQ2MvVG5jYlb0z+LqQdWQnF35fPHDFOCKeXIek20hPFtA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.win-x86"; version = "8.0.10"; hash = "sha512-00BocEhDPtq4wrrkK4TN4uC0JLQvLn+JZpEAanMEQzN/ZOb8pP8c4RX/jNpPP40MqNNnsNOSFh9C2LE/HPgjHA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-x86"; + version = "8.0.10"; + hash = "sha512-NGl4nsuWJgLBQobSkbOxJgkT04uyetP/Kv8JXz7qN6MV0q+MjyhYQY29H8ODQgSMi4viOBL9KHbrTc6K+oSD7w=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-x86"; + version = "8.0.10"; + hash = "sha512-Fdc4ceK2VvksnIYLF7SFO6mtr3A6Ktsw8Xu46ja3BxawnHTLmgV7dY9mh0R1JgiandksQMOS6AOSjz0D9Ce78g=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-x86"; + version = "8.0.10"; + hash = "sha512-PmrjkpJyXstmNJCyaHwOS3WdQTGYZa3Ik/ayjg+APgNSBbcP/TBnEGg91esUmgZ5k2Gz+WGCQS6wQxATTTJcKw=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.10"; + hash = "sha512-feQLgFQlSHP+zSIjLXq+n4zC3jKYRAiXPJ8iY90nk2xAfRWYIb6redRB4dUhqhv5uaCrfi8W2r0AXZX8/GEkjg=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetHost"; + version = "8.0.10"; + hash = "sha512-P97h50G0e61YXisIsZOWFcE/ldXH2R5gbX+SD+6t7FgmNQwaIl80xQMjEICfJ2uk9CoYKw2jWiwjQEdqoa9g1Q=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.10"; + hash = "sha512-Mp2Scz97QbDE1CKZli/Z4zDSeQGSjN4vuylZUqvLukTTGTM1xB89a0TLf5ooz6rZefyNecAY2WOP0fr+oOjpPg=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.10"; + hash = "sha512-Voo3Y/uZNEaiWfePrWjKkpsgZBR1dmgwuCf/8sxMCSQ2MvVG5jYlb0z+LqQdWQnF35fPHDFOCKeXIek20hPFtA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.win-x86"; + version = "8.0.10"; + hash = "sha512-00BocEhDPtq4wrrkK4TN4uC0JLQvLn+JZpEAanMEQzN/ZOb8pP8c4RX/jNpPP40MqNNnsNOSFh9C2LE/HPgjHA=="; + }) ]; }; -in rec { +in +rec { release_8_0 = "8.0.10"; aspnetcore_8_0 = buildAspNetCore { @@ -290,6 +744,5 @@ in rec { sdk = sdk_8_0; - sdk_8_0 = sdk_8_0_1xx; } diff --git a/pkgs/development/compilers/dotnet/8/deps.nix b/pkgs/development/compilers/dotnet/8/deps.nix index 0da151f706c453..b0c95c3c29eb20 100644 --- a/pkgs/development/compilers/dotnet/8/deps.nix +++ b/pkgs/development/compilers/dotnet/8/deps.nix @@ -1,12 +1,63 @@ -{ fetchNuGet }: [ - (fetchNuGet { hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; pname = "Newtonsoft.Json"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/newtonsoft.json/13.0.1/newtonsoft.json.13.0.1.nupkg"; version = "13.0.1"; }) - (fetchNuGet { hash = "sha256-dQGC30JauIDWNWXMrSNOJncVa1umR1sijazYwUDdSIE="; pname = "System.Reflection.Metadata"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadata/8.0.0/system.reflection.metadata.8.0.0.nupkg"; version = "8.0.0"; }) - (fetchNuGet { pname = "runtime.linux-arm64.Microsoft.NETCore.ILAsm"; sha256 = "27f0c91cca043b5aaeff96a3f7899aba3c20355dcace30db1620fdef8807bab0"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.linux-arm64.microsoft.netcore.ilasm/8.0.10-servicing.24466.10/runtime.linux-arm64.microsoft.netcore.ilasm.8.0.10-servicing.24466.10.nupkg"; version = "8.0.10-servicing.24466.10"; }) - (fetchNuGet { pname = "runtime.linux-arm64.Microsoft.NETCore.ILDAsm"; sha256 = "f93c9cdea2f00ebb2bb61ea5cf3efebabd457b36c128dfdfa810f2f3f7666ffa"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.linux-arm64.microsoft.netcore.ildasm/8.0.10-servicing.24466.10/runtime.linux-arm64.microsoft.netcore.ildasm.8.0.10-servicing.24466.10.nupkg"; version = "8.0.10-servicing.24466.10"; }) - (fetchNuGet { hash = "sha256-mNRwvNOxuOtD8F0U6Alc6220T1BAP28lC2AeyjDW2NI="; pname = "runtime.linux-x64.Microsoft.NETCore.ILAsm"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.linux-x64.microsoft.netcore.ilasm/8.0.10-servicing.24466.10/runtime.linux-x64.microsoft.netcore.ilasm.8.0.10-servicing.24466.10.nupkg"; version = "8.0.10-servicing.24466.10"; }) - (fetchNuGet { hash = "sha256-i8rOlWki4EH5fm+cmUPdIivF/xnpayygHCX+Wa/FOsg="; pname = "runtime.linux-x64.Microsoft.NETCore.ILDAsm"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.linux-x64.microsoft.netcore.ildasm/8.0.10-servicing.24466.10/runtime.linux-x64.microsoft.netcore.ildasm.8.0.10-servicing.24466.10.nupkg"; version = "8.0.10-servicing.24466.10"; }) - (fetchNuGet { pname = "runtime.osx-arm64.Microsoft.NETCore.ILAsm"; sha256 = "f933bfbf0d41b6b2073ce605e4fb081c6d7253fd4ddac1bbbc542152b264ab06"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.osx-arm64.microsoft.netcore.ilasm/8.0.10-servicing.24466.10/runtime.osx-arm64.microsoft.netcore.ilasm.8.0.10-servicing.24466.10.nupkg"; version = "8.0.10-servicing.24466.10"; }) - (fetchNuGet { pname = "runtime.osx-arm64.Microsoft.NETCore.ILDAsm"; sha256 = "321d0579df8fe28cf7b7a6e75d816e5e0ac076d96eb9591c2db0e2141f5d8e36"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.osx-arm64.microsoft.netcore.ildasm/8.0.10-servicing.24466.10/runtime.osx-arm64.microsoft.netcore.ildasm.8.0.10-servicing.24466.10.nupkg"; version = "8.0.10-servicing.24466.10"; }) - (fetchNuGet { pname = "runtime.osx-x64.Microsoft.NETCore.ILAsm"; sha256 = "b43894455f4d6eef539f64b21eb22d54dda72afe6da0d11526c7aa1c02b179ee"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.osx-x64.microsoft.netcore.ilasm/8.0.10-servicing.24466.10/runtime.osx-x64.microsoft.netcore.ilasm.8.0.10-servicing.24466.10.nupkg"; version = "8.0.10-servicing.24466.10"; }) - (fetchNuGet { pname = "runtime.osx-x64.Microsoft.NETCore.ILDAsm"; sha256 = "f0be4d7d4eed4cd405e55e5a0628adf0a60bf56d7dd390b2d34d699b7ce054c6"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.osx-x64.microsoft.netcore.ildasm/8.0.10-servicing.24466.10/runtime.osx-x64.microsoft.netcore.ildasm.8.0.10-servicing.24466.10.nupkg"; version = "8.0.10-servicing.24466.10"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; + pname = "Newtonsoft.Json"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/newtonsoft.json/13.0.1/newtonsoft.json.13.0.1.nupkg"; + version = "13.0.1"; + }) + (fetchNuGet { + hash = "sha256-dQGC30JauIDWNWXMrSNOJncVa1umR1sijazYwUDdSIE="; + pname = "System.Reflection.Metadata"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/system.reflection.metadata/8.0.0/system.reflection.metadata.8.0.0.nupkg"; + version = "8.0.0"; + }) + (fetchNuGet { + pname = "runtime.linux-arm64.Microsoft.NETCore.ILAsm"; + sha256 = "27f0c91cca043b5aaeff96a3f7899aba3c20355dcace30db1620fdef8807bab0"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.linux-arm64.microsoft.netcore.ilasm/8.0.10-servicing.24466.10/runtime.linux-arm64.microsoft.netcore.ilasm.8.0.10-servicing.24466.10.nupkg"; + version = "8.0.10-servicing.24466.10"; + }) + (fetchNuGet { + pname = "runtime.linux-arm64.Microsoft.NETCore.ILDAsm"; + sha256 = "f93c9cdea2f00ebb2bb61ea5cf3efebabd457b36c128dfdfa810f2f3f7666ffa"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.linux-arm64.microsoft.netcore.ildasm/8.0.10-servicing.24466.10/runtime.linux-arm64.microsoft.netcore.ildasm.8.0.10-servicing.24466.10.nupkg"; + version = "8.0.10-servicing.24466.10"; + }) + (fetchNuGet { + hash = "sha256-mNRwvNOxuOtD8F0U6Alc6220T1BAP28lC2AeyjDW2NI="; + pname = "runtime.linux-x64.Microsoft.NETCore.ILAsm"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.linux-x64.microsoft.netcore.ilasm/8.0.10-servicing.24466.10/runtime.linux-x64.microsoft.netcore.ilasm.8.0.10-servicing.24466.10.nupkg"; + version = "8.0.10-servicing.24466.10"; + }) + (fetchNuGet { + hash = "sha256-i8rOlWki4EH5fm+cmUPdIivF/xnpayygHCX+Wa/FOsg="; + pname = "runtime.linux-x64.Microsoft.NETCore.ILDAsm"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.linux-x64.microsoft.netcore.ildasm/8.0.10-servicing.24466.10/runtime.linux-x64.microsoft.netcore.ildasm.8.0.10-servicing.24466.10.nupkg"; + version = "8.0.10-servicing.24466.10"; + }) + (fetchNuGet { + pname = "runtime.osx-arm64.Microsoft.NETCore.ILAsm"; + sha256 = "f933bfbf0d41b6b2073ce605e4fb081c6d7253fd4ddac1bbbc542152b264ab06"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.osx-arm64.microsoft.netcore.ilasm/8.0.10-servicing.24466.10/runtime.osx-arm64.microsoft.netcore.ilasm.8.0.10-servicing.24466.10.nupkg"; + version = "8.0.10-servicing.24466.10"; + }) + (fetchNuGet { + pname = "runtime.osx-arm64.Microsoft.NETCore.ILDAsm"; + sha256 = "321d0579df8fe28cf7b7a6e75d816e5e0ac076d96eb9591c2db0e2141f5d8e36"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.osx-arm64.microsoft.netcore.ildasm/8.0.10-servicing.24466.10/runtime.osx-arm64.microsoft.netcore.ildasm.8.0.10-servicing.24466.10.nupkg"; + version = "8.0.10-servicing.24466.10"; + }) + (fetchNuGet { + pname = "runtime.osx-x64.Microsoft.NETCore.ILAsm"; + sha256 = "b43894455f4d6eef539f64b21eb22d54dda72afe6da0d11526c7aa1c02b179ee"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.osx-x64.microsoft.netcore.ilasm/8.0.10-servicing.24466.10/runtime.osx-x64.microsoft.netcore.ilasm.8.0.10-servicing.24466.10.nupkg"; + version = "8.0.10-servicing.24466.10"; + }) + (fetchNuGet { + pname = "runtime.osx-x64.Microsoft.NETCore.ILDAsm"; + sha256 = "f0be4d7d4eed4cd405e55e5a0628adf0a60bf56d7dd390b2d34d699b7ce054c6"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/a65e5cb4-26c0-410f-9457-06db3c5254be/nuget/v3/flat2/runtime.osx-x64.microsoft.netcore.ildasm/8.0.10-servicing.24466.10/runtime.osx-x64.microsoft.netcore.ildasm.8.0.10-servicing.24466.10.nupkg"; + version = "8.0.10-servicing.24466.10"; + }) ] diff --git a/pkgs/development/compilers/dotnet/9/bootstrap-sdk.nix b/pkgs/development/compilers/dotnet/9/bootstrap-sdk.nix index 1c9f412d4f9109..48cc0ce458c853 100644 --- a/pkgs/development/compilers/dotnet/9/bootstrap-sdk.nix +++ b/pkgs/development/compilers/dotnet/9/bootstrap-sdk.nix @@ -1,130 +1,408 @@ -{ buildAspNetCore, buildNetRuntime, buildNetSdk, fetchNupkg }: +{ + buildAspNetCore, + buildNetRuntime, + buildNetSdk, + fetchNupkg, +}: # v9.0 (active) let commonPackages = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Ref"; version = "9.0.0-rc.2.24474.3"; hash = "sha512-VYoUXb/87RzxdErwwqfVb8WJLl+7YL4PBxI8QY9cer25Zg85yOUxaPHLnX45QgveH1iNcEHyEr7vJW52LkyYZQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetAppHost"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-va/LQIocBU7wyw4EXStwGTdHnrcyBSBVuRaRlNd3I2IZrFZ5QhRSEKwW2jFvSYWowt2P4nL4e/YvweFnWs8DiQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Ref"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-tJYYbEootDwmS23jQtXRN/HrkN57sLdcpjYuKjqzgOsWVhVYr+5Yq5vcuYa03RiRv/PnoOmWB6pMhQ69qfIhcA=="; }) - (fetchNupkg { pname = "Microsoft.DotNet.ILCompiler"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-7gm4DUCtrapDZxO1aKiPGm/danAxKvGiCyj16+4zdgD69S0UJ0mwQw5Mn7xIhrz3/YSC/yK7ihvZ4oqc4I00aQ=="; }) - (fetchNupkg { pname = "Microsoft.NET.ILLink.Tasks"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-h08RQolDzXy4ihvbyEb0E75pozEG/tyZgPaKEfWGtEM1Byvbe4SDrQlu0G4f97h5I49L6Czy+RQ+rdnyL/XwjQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Ref"; + version = "9.0.0-rc.2.24474.3"; + hash = "sha512-VYoUXb/87RzxdErwwqfVb8WJLl+7YL4PBxI8QY9cer25Zg85yOUxaPHLnX45QgveH1iNcEHyEr7vJW52LkyYZQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-va/LQIocBU7wyw4EXStwGTdHnrcyBSBVuRaRlNd3I2IZrFZ5QhRSEKwW2jFvSYWowt2P4nL4e/YvweFnWs8DiQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Ref"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-tJYYbEootDwmS23jQtXRN/HrkN57sLdcpjYuKjqzgOsWVhVYr+5Yq5vcuYa03RiRv/PnoOmWB6pMhQ69qfIhcA=="; + }) + (fetchNupkg { + pname = "Microsoft.DotNet.ILCompiler"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-7gm4DUCtrapDZxO1aKiPGm/danAxKvGiCyj16+4zdgD69S0UJ0mwQw5Mn7xIhrz3/YSC/yK7ihvZ4oqc4I00aQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NET.ILLink.Tasks"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-h08RQolDzXy4ihvbyEb0E75pozEG/tyZgPaKEfWGtEM1Byvbe4SDrQlu0G4f97h5I49L6Czy+RQ+rdnyL/XwjQ=="; + }) ]; hostPackages = { linux-arm = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-arm"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-a0w9cqInj6szGJ+gdJsOendvS4xW2ZiXsYXRfPBHexbwYec2bFD/wFcuoPQ3n87XSdnyUk6cv3w7Njcb/wU1ew=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-arm"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-a0w9cqInj6szGJ+gdJsOendvS4xW2ZiXsYXRfPBHexbwYec2bFD/wFcuoPQ3n87XSdnyUk6cv3w7Njcb/wU1ew=="; + }) ]; linux-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-arm64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-9QO5gJi33NuIawkG0H7LlE9yeHtDABCLniQzsf21x6qKBI1DtGlVPEEq05mHW4NxkV6DQlDjycifukN8UY5GzQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.DotNet.ILCompiler"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-aQZ+KhAuSb8x2DvsFJwvZTCkmyPvd/pu2XU4uVHuaRQ2A9wejpdCTtXeOETWkZBR42qBXmzoZiMO4JnlmwDjGA=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-arm64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-9QO5gJi33NuIawkG0H7LlE9yeHtDABCLniQzsf21x6qKBI1DtGlVPEEq05mHW4NxkV6DQlDjycifukN8UY5GzQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-aQZ+KhAuSb8x2DvsFJwvZTCkmyPvd/pu2XU4uVHuaRQ2A9wejpdCTtXeOETWkZBR42qBXmzoZiMO4JnlmwDjGA=="; + }) ]; linux-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-x64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-SCiUPToHRHRVcUVV0GbyKj7kENAEKfhrdlZgPxwQNxbBHbTpg+pUtwdmZHXd4ALEx7yUYKH+gZ0NgvaxnnkA1w=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.DotNet.ILCompiler"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-V5hJqjyfqdo6JH0n30SZ85vdsw2ZkTeFen+N4B7Oh93PCK7GNOvW9FsjI1VPoIvygjOoPek5fQMyj6hKXbzYKQ=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-x64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-SCiUPToHRHRVcUVV0GbyKj7kENAEKfhrdlZgPxwQNxbBHbTpg+pUtwdmZHXd4ALEx7yUYKH+gZ0NgvaxnnkA1w=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-V5hJqjyfqdo6JH0n30SZ85vdsw2ZkTeFen+N4B7Oh93PCK7GNOvW9FsjI1VPoIvygjOoPek5fQMyj6hKXbzYKQ=="; + }) ]; linux-musl-arm = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-dYeGj3yq0iyv0ynhzCnzYPTX6NzOzarCR7KJp4TvIRmAIRzQNyR3wmajXCcmA+zbxopVvPuWdV6vE2TR2gJTug=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-dYeGj3yq0iyv0ynhzCnzYPTX6NzOzarCR7KJp4TvIRmAIRzQNyR3wmajXCcmA+zbxopVvPuWdV6vE2TR2gJTug=="; + }) ]; linux-musl-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-H8XU5iqkZLCJYnI3BoQFSipnD4np8QV6UgG9aoF1OU7ePQ3QLbqwIrWdk2SISXJGyRWwtcZCmw0DkGU283y3Fw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.DotNet.ILCompiler"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-wj9IJOdrWrBcDC9edJtjIkItXcd62C/Izhq1jS1IvqBWeUSekwtKBvBxVEeKrVrSI2gdabcnUqzZDo8mF0UemQ=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-H8XU5iqkZLCJYnI3BoQFSipnD4np8QV6UgG9aoF1OU7ePQ3QLbqwIrWdk2SISXJGyRWwtcZCmw0DkGU283y3Fw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-wj9IJOdrWrBcDC9edJtjIkItXcd62C/Izhq1jS1IvqBWeUSekwtKBvBxVEeKrVrSI2gdabcnUqzZDo8mF0UemQ=="; + }) ]; linux-musl-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-x64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-Gu5AC44xJKFxLVBtQm+/aK8aXeTJadqwNlG0RiJe26u+kzZps7SU/WgCWSi5JQeMdS5tN4xOq2mDbNMx1Euzpw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.DotNet.ILCompiler"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-nDxzSmkIR8M33A40nE3t7Ocokyr7kwjE/20HDix5/jSqDrVXkuwrpE0RAbxlqV5m2SsQ/46vnGj8pv/z6pTfpg=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-x64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-Gu5AC44xJKFxLVBtQm+/aK8aXeTJadqwNlG0RiJe26u+kzZps7SU/WgCWSi5JQeMdS5tN4xOq2mDbNMx1Euzpw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-nDxzSmkIR8M33A40nE3t7Ocokyr7kwjE/20HDix5/jSqDrVXkuwrpE0RAbxlqV5m2SsQ/46vnGj8pv/z6pTfpg=="; + }) ]; osx-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.osx-arm64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-eGaMRTh44mmuFIsExzJmPoNk6FgM3pMsHXXcZK5x3yfj+s5Q8GiW+uQsPQvvEI/vAxqQXecaWpHNSsl95s1HCw=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.DotNet.ILCompiler"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-94YWNVgdISC20qj+68bRSiG53bCoH0xz3LMdHPm3hl1kU0sXYIJV3m4H1MHvTIMWaDFQMChEACeTfQ4lmFe33A=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.osx-arm64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-eGaMRTh44mmuFIsExzJmPoNk6FgM3pMsHXXcZK5x3yfj+s5Q8GiW+uQsPQvvEI/vAxqQXecaWpHNSsl95s1HCw=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-94YWNVgdISC20qj+68bRSiG53bCoH0xz3LMdHPm3hl1kU0sXYIJV3m4H1MHvTIMWaDFQMChEACeTfQ4lmFe33A=="; + }) ]; osx-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.osx-x64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-gy6X1t3U0o4TaLq95HG7+KYm1OJc3GPQBYI887/H/is64cR2uMb+05vKKWO/LWpjjk3R2G6AxIh7yIor/LrV3g=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.DotNet.ILCompiler"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-XlvuVxf0NHsLBNTALgTTaUgP0gdjayrZJ/5fIcY/WjfxBS/k4LTYtEPCrWHHgfSwQRtf88zxy68wU0YYNqmnOg=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.osx-x64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-gy6X1t3U0o4TaLq95HG7+KYm1OJc3GPQBYI887/H/is64cR2uMb+05vKKWO/LWpjjk3R2G6AxIh7yIor/LrV3g=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-XlvuVxf0NHsLBNTALgTTaUgP0gdjayrZJ/5fIcY/WjfxBS/k4LTYtEPCrWHHgfSwQRtf88zxy68wU0YYNqmnOg=="; + }) ]; win-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-arm64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-uZPRPhjW7mFUVrgNo9bkD7IV/mi51JhN+tmctCClPbMvojpwwBCwRVHm+FZvuRGnohEmhulP+437gWfebKHD4Q=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.DotNet.ILCompiler"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-1kJfPoFkc1h1vLn8eXVYWDxGnLZgcU2QoQ+SL1FxMiUDz9jpgjS/ED5Lue28S1eqEvORhsq0hCPb5rd+hrqAJw=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-arm64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-uZPRPhjW7mFUVrgNo9bkD7IV/mi51JhN+tmctCClPbMvojpwwBCwRVHm+FZvuRGnohEmhulP+437gWfebKHD4Q=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-1kJfPoFkc1h1vLn8eXVYWDxGnLZgcU2QoQ+SL1FxMiUDz9jpgjS/ED5Lue28S1eqEvORhsq0hCPb5rd+hrqAJw=="; + }) ]; win-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-x64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-Qf8fsjuJicTADESM1q7jb/2mmd2wfz4UJwOaYm0LF3cbfxJeJ1R4Nz573lDvyzG5EpZvhqgdbIvi+Js9yPvR+w=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.DotNet.ILCompiler"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-uM+ZHRZaPZF9/9mPB+B1r9+p+ejsJWrZeAmS++441xiTI2WcnacgOCASqA3PaBceGHHAbWdICPJtkM8zb6cu6g=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-x64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-Qf8fsjuJicTADESM1q7jb/2mmd2wfz4UJwOaYm0LF3cbfxJeJ1R4Nz573lDvyzG5EpZvhqgdbIvi+Js9yPvR+w=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-uM+ZHRZaPZF9/9mPB+B1r9+p+ejsJWrZeAmS++441xiTI2WcnacgOCASqA3PaBceGHHAbWdICPJtkM8zb6cu6g=="; + }) ]; win-x86 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-x86"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-6oqxcjiVqyYQ2epUGRbWD3SFA+crSFp5htpAQPyBFN6WQCj0vuwvM15RhSTqb1J1weQ3Y4nq6sEI9FMuULbF+A=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-x86"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-6oqxcjiVqyYQ2epUGRbWD3SFA+crSFp5htpAQPyBFN6WQCj0vuwvM15RhSTqb1J1weQ3Y4nq6sEI9FMuULbF+A=="; + }) ]; }; targetPackages = { linux-arm = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm"; version = "9.0.0-rc.2.24474.3"; hash = "sha512-9hLr5fWmk2ePIVEPV2Jf1BdERtIuoAm3hTs78cBAee2BMwTlFjJCBVxpCIIlIGRG2SA5iJGm5PlBg+IXe/e7Fg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-arm"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-hYVPnToTQZtSZyafuFYAkvGQCkoNhjyyhbedOhNQQbKaT+OpTHEwRI78DG+E+n7+pKU2uGqzVErP79K66Dhvaw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-arm"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-dvFWAmiDhmOLa7yA9uMpXOWPG+S3+OQ3uv/u8kk6EsFnjI+GqpauqwghGVamf5Sf9jMXViNJ3I3cGuGKbtQ3eQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-jnnJ7m79tcpT0KyMD5FA9Hvcju7PqO8VrtDSkrhCydJKq6f1j2tQukH4L5bx4bxdH6L7AbtZU1W6a2tOjWavjA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm"; + version = "9.0.0-rc.2.24474.3"; + hash = "sha512-9hLr5fWmk2ePIVEPV2Jf1BdERtIuoAm3hTs78cBAee2BMwTlFjJCBVxpCIIlIGRG2SA5iJGm5PlBg+IXe/e7Fg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-arm"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-hYVPnToTQZtSZyafuFYAkvGQCkoNhjyyhbedOhNQQbKaT+OpTHEwRI78DG+E+n7+pKU2uGqzVErP79K66Dhvaw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-arm"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-dvFWAmiDhmOLa7yA9uMpXOWPG+S3+OQ3uv/u8kk6EsFnjI+GqpauqwghGVamf5Sf9jMXViNJ3I3cGuGKbtQ3eQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-jnnJ7m79tcpT0KyMD5FA9Hvcju7PqO8VrtDSkrhCydJKq6f1j2tQukH4L5bx4bxdH6L7AbtZU1W6a2tOjWavjA=="; + }) ]; linux-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; version = "9.0.0-rc.2.24474.3"; hash = "sha512-8P8kT37mZIlcBLFJ+ybg3IEYl0LwYxa1EHCJmqiI7BGsEMc7Bmo9V1Qu04rbXtsltQroWC5OeIb6UkvM3Q7L/g=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-arm64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-ittiMXCbVOvfF3Wx3wUVeRRGYkr9c4gVhFWWKNl4ESCigotKCym6/wuZ4Yh7q1CmHOzorxuuKWeW59qL6+Dmnw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-u4ST10PMetmuDLzRIrQrG4G22zKJDjTbQjHfg8GvAVrGorWb8XjeuBDRcAggo72LzqeI5O6rVyLGARoe4ozQTA=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-I4kfngubXUj0Z/2PedYhOuS7MdcgVeymGS9BSLAVwZkjxJq21YxK3B+VWqPPtjvn5CnNTx1PKWbchd8HbZ/u7g=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; + version = "9.0.0-rc.2.24474.3"; + hash = "sha512-8P8kT37mZIlcBLFJ+ybg3IEYl0LwYxa1EHCJmqiI7BGsEMc7Bmo9V1Qu04rbXtsltQroWC5OeIb6UkvM3Q7L/g=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-arm64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-ittiMXCbVOvfF3Wx3wUVeRRGYkr9c4gVhFWWKNl4ESCigotKCym6/wuZ4Yh7q1CmHOzorxuuKWeW59qL6+Dmnw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-u4ST10PMetmuDLzRIrQrG4G22zKJDjTbQjHfg8GvAVrGorWb8XjeuBDRcAggo72LzqeI5O6rVyLGARoe4ozQTA=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-I4kfngubXUj0Z/2PedYhOuS7MdcgVeymGS9BSLAVwZkjxJq21YxK3B+VWqPPtjvn5CnNTx1PKWbchd8HbZ/u7g=="; + }) ]; linux-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; version = "9.0.0-rc.2.24474.3"; hash = "sha512-lFkrconTLamWAmhwMmFGHlFVvznCfXUYAxj1UUEcAzRd2B09iX5+mJL7OdZSatJO+FwJEdLy4DJL3w/nOY344A=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-x64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-x+r8ICKAP4sAZrG5eSUg1wqb5XCaSusaa8v4RtAWF3lYrlnRHPMtK4K9BUgr9D8M8Gwiy8swVXTcd95NggIJaQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-x64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-1Bz9FeS67p5Rc1h+H54fMfSb6l8uhpx1c4pdjTnU3DwVWZ+e3UE8cGi9Vj0ICDmClvKWx8WvcbkWr3yEFn6Oiw=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-EBQcA5874itepp6PYbW9kXKl6JBL9dtNTpDWyCWOv6iUZgt+coVbOVHEbBFh3keqMB5J9P1G61AW4E8TJANvIA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; + version = "9.0.0-rc.2.24474.3"; + hash = "sha512-lFkrconTLamWAmhwMmFGHlFVvznCfXUYAxj1UUEcAzRd2B09iX5+mJL7OdZSatJO+FwJEdLy4DJL3w/nOY344A=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-x64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-x+r8ICKAP4sAZrG5eSUg1wqb5XCaSusaa8v4RtAWF3lYrlnRHPMtK4K9BUgr9D8M8Gwiy8swVXTcd95NggIJaQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-x64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-1Bz9FeS67p5Rc1h+H54fMfSb6l8uhpx1c4pdjTnU3DwVWZ+e3UE8cGi9Vj0ICDmClvKWx8WvcbkWr3yEFn6Oiw=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-EBQcA5874itepp6PYbW9kXKl6JBL9dtNTpDWyCWOv6iUZgt+coVbOVHEbBFh3keqMB5J9P1G61AW4E8TJANvIA=="; + }) ]; linux-musl-arm = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm"; version = "9.0.0-rc.2.24474.3"; hash = "sha512-Chm/DOH8nmg/bL/OAMWcfSAT/7c5W/DW5909fpNgCRHJhztTrT61AhmDCV7Sbj9aCwp7H92lZW1Ov+jtKtJWvw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-arm"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-NbqCc0FaVX/rhUe0TYnMBNjL3fqnptO6bdSfjlpjP5cfOV5c7vNcwhwl3IY3a82pFUblXOT5Ltw1s9meRlRHeQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-i7inuXamQxuvqTbjO7Ex3BWN1lambOO9LRhgomSxiRbmRj/vnArzlrIZo3XLcK+j4pvWFatzLeJ9iGSj1e3vwA=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-J0fbjcCjNNxSHgGuxaV2900dDskw9YkcmHNPx3TRrj68lkrGHdOd5ArzahOGAkUT/zlrklwMFFAWfSgpl5j8TQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm"; + version = "9.0.0-rc.2.24474.3"; + hash = "sha512-Chm/DOH8nmg/bL/OAMWcfSAT/7c5W/DW5909fpNgCRHJhztTrT61AhmDCV7Sbj9aCwp7H92lZW1Ov+jtKtJWvw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-arm"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-NbqCc0FaVX/rhUe0TYnMBNjL3fqnptO6bdSfjlpjP5cfOV5c7vNcwhwl3IY3a82pFUblXOT5Ltw1s9meRlRHeQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-i7inuXamQxuvqTbjO7Ex3BWN1lambOO9LRhgomSxiRbmRj/vnArzlrIZo3XLcK+j4pvWFatzLeJ9iGSj1e3vwA=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-J0fbjcCjNNxSHgGuxaV2900dDskw9YkcmHNPx3TRrj68lkrGHdOd5ArzahOGAkUT/zlrklwMFFAWfSgpl5j8TQ=="; + }) ]; linux-musl-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm64"; version = "9.0.0-rc.2.24474.3"; hash = "sha512-wCBrrChR7n5Lz9FvHLoCcZ8/bMBjEK35Oy5EEsKqrrLp3NM9IhPeklNnEQF5lm05i9u8fx+24faoH9bA8Eucnw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-arm64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-3d3UJgKT9fT8WEceC8h8iAz3kwPIJXYNfSQykPYShUr3bpbt2lWS8Vz9eWSB2Quadi6fyMX9w4M6bDsChMO1Mw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-gVEHwf9wUNgxS2C/jd0f4xHZYHmRAmUB1A1tY1RL0fpphw/6p7ytXsQ89eh2sG1SquhznZhPPblEBfOGcs5mtw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-hUok62DuWaFEtEtQCHnOaA+T1F4IhS6DxMdJDgCF/PQ5lQlPy4T2FyYg7VFDWQbM2xm0BhD/Dc9X4fvDJDW0sw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm64"; + version = "9.0.0-rc.2.24474.3"; + hash = "sha512-wCBrrChR7n5Lz9FvHLoCcZ8/bMBjEK35Oy5EEsKqrrLp3NM9IhPeklNnEQF5lm05i9u8fx+24faoH9bA8Eucnw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-arm64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-3d3UJgKT9fT8WEceC8h8iAz3kwPIJXYNfSQykPYShUr3bpbt2lWS8Vz9eWSB2Quadi6fyMX9w4M6bDsChMO1Mw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-gVEHwf9wUNgxS2C/jd0f4xHZYHmRAmUB1A1tY1RL0fpphw/6p7ytXsQ89eh2sG1SquhznZhPPblEBfOGcs5mtw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-hUok62DuWaFEtEtQCHnOaA+T1F4IhS6DxMdJDgCF/PQ5lQlPy4T2FyYg7VFDWQbM2xm0BhD/Dc9X4fvDJDW0sw=="; + }) ]; linux-musl-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-x64"; version = "9.0.0-rc.2.24474.3"; hash = "sha512-OQoLmTaSSDEOE5AyaMaxcPyZan0jl0sBYqzL0VKX03hrDW5TU6TRwhV3IWLuMHw88+JammuRX6V8PGEL2KL0aw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-x64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-EUSs0bkXWUk9Me7Lo9ZCF4Ellid9cPKQbXv4l2+378I5pgJzL9vuz4orzyfO5W26drSXknU/zm0BEAOJU3pAmg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-x64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-3pVBqaNKhDhsAdJSd6V40vdHcQ0jZ1bH+AEWkm840yskYN1AIqA8sfFPiOdWLZnblbHG7P7Y+l25hhx4/mg0IQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-n9svtainSSp0E+pHYxg6me3qXTT0vY89OmdLFLRP1PW2/iJYUx65If9J1NzOsoBy6wnrTpiSbmODYuS5YGfU3w=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-x64"; + version = "9.0.0-rc.2.24474.3"; + hash = "sha512-OQoLmTaSSDEOE5AyaMaxcPyZan0jl0sBYqzL0VKX03hrDW5TU6TRwhV3IWLuMHw88+JammuRX6V8PGEL2KL0aw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-x64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-EUSs0bkXWUk9Me7Lo9ZCF4Ellid9cPKQbXv4l2+378I5pgJzL9vuz4orzyfO5W26drSXknU/zm0BEAOJU3pAmg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-x64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-3pVBqaNKhDhsAdJSd6V40vdHcQ0jZ1bH+AEWkm840yskYN1AIqA8sfFPiOdWLZnblbHG7P7Y+l25hhx4/mg0IQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-n9svtainSSp0E+pHYxg6me3qXTT0vY89OmdLFLRP1PW2/iJYUx65If9J1NzOsoBy6wnrTpiSbmODYuS5YGfU3w=="; + }) ]; osx-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.osx-arm64"; version = "9.0.0-rc.2.24474.3"; hash = "sha512-60vE1xNjUGDvGaFFyaQGAX/uboU0dG9/VU+3GbX1120S2o/WvNM5VW3zXR2yBnhjcK2kpgg6DMvOrl0MEZtBUQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.osx-arm64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-yJgKcAx5jtS0oFtIklA6H4OwDSFEhsJaorGyrIAui+z/tTl81y7i9jy3kgSMQ34dJUflZ6QwpGdUn1GAh/vfng=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.osx-arm64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-a9aDzwnog+KG4OXmxW1//6k2VNrqbNjiYxLSqp5P3DLZyY+1t4+rT4XiMt10haxouEECDQwOM52LAcjBhKhZwg=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-sGYv1THJ2s16u0s+zcavMFEj+VGjPI+CYmUqM9MnUW3SRHsMyKkCj+Iy25HAmmTNLv/q3hqF/URE/rWdJvJkhQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.osx-arm64"; + version = "9.0.0-rc.2.24474.3"; + hash = "sha512-60vE1xNjUGDvGaFFyaQGAX/uboU0dG9/VU+3GbX1120S2o/WvNM5VW3zXR2yBnhjcK2kpgg6DMvOrl0MEZtBUQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.osx-arm64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-yJgKcAx5jtS0oFtIklA6H4OwDSFEhsJaorGyrIAui+z/tTl81y7i9jy3kgSMQ34dJUflZ6QwpGdUn1GAh/vfng=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.osx-arm64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-a9aDzwnog+KG4OXmxW1//6k2VNrqbNjiYxLSqp5P3DLZyY+1t4+rT4XiMt10haxouEECDQwOM52LAcjBhKhZwg=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-sGYv1THJ2s16u0s+zcavMFEj+VGjPI+CYmUqM9MnUW3SRHsMyKkCj+Iy25HAmmTNLv/q3hqF/URE/rWdJvJkhQ=="; + }) ]; osx-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; version = "9.0.0-rc.2.24474.3"; hash = "sha512-cK0x+Lxe3lEylQnijK9K/I9o6p4yHYI9qtrSMRAqSCoUxaRoBFLHwljaumRvCyejqRCMmYosda7z9S2rDxjBXA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.osx-x64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-WTctjwwzqXX0zDxVkFlK4k+bhEDAUzMv1/5ikvqhfVF8uNQUHnZFTx9sXTN0msVJ5FHWuNIKrD1k06YhvVuV5A=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.osx-x64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-0LUUXfBkZ2S/5GgCl3gEPbh+fyJOipdcnyYkOKrCwZn68fMHY247FFLKthdauXsEOU5RWV4PQbjELvwD543rGA=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-Kx+gvcTQmO9X35eSE9z7vOlrG2J2FFC3Uv6zOXoCtJugJqW74S6AbUP8JRMnZCNzv2cNnEK6xswyDg1Mf34sTw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; + version = "9.0.0-rc.2.24474.3"; + hash = "sha512-cK0x+Lxe3lEylQnijK9K/I9o6p4yHYI9qtrSMRAqSCoUxaRoBFLHwljaumRvCyejqRCMmYosda7z9S2rDxjBXA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.osx-x64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-WTctjwwzqXX0zDxVkFlK4k+bhEDAUzMv1/5ikvqhfVF8uNQUHnZFTx9sXTN0msVJ5FHWuNIKrD1k06YhvVuV5A=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.osx-x64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-0LUUXfBkZ2S/5GgCl3gEPbh+fyJOipdcnyYkOKrCwZn68fMHY247FFLKthdauXsEOU5RWV4PQbjELvwD543rGA=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-Kx+gvcTQmO9X35eSE9z7vOlrG2J2FFC3Uv6zOXoCtJugJqW74S6AbUP8JRMnZCNzv2cNnEK6xswyDg1Mf34sTw=="; + }) ]; win-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-arm64"; version = "9.0.0-rc.2.24474.3"; hash = "sha512-2ByJFpaf+Dm+saB+NniupfwHJVbCNuaLNX+K4pH7Bz6dUYXlcWh1ja3l6G80PYJRNziyJY8fNsLhNFBnSCA39A=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-arm64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-tKSRJQ4E/PndHyAEKnDitBvgTnJCtzIBiw4MAim7mmdO3T3xCq3N1PP/WRST+JEMDy19tkLwClR3SqziiXPAag=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-arm64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-gNMyW8t/1pBYNWwZpW7Gk4GArSEVrJOCBz8YvaHpzwk9iuVYeka4lOIvudA9drCxY5EUU1I20EJvCSycNffgsg=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-FiXMi1dtVF47L4ITblPzzCbgLY9noHwV0ZvEL30bgm4hQPSSNdELFbDAgNuAktieV3/XV7KSOQPPxlc6KEZi2w=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-arm64"; + version = "9.0.0-rc.2.24474.3"; + hash = "sha512-2ByJFpaf+Dm+saB+NniupfwHJVbCNuaLNX+K4pH7Bz6dUYXlcWh1ja3l6G80PYJRNziyJY8fNsLhNFBnSCA39A=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-arm64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-tKSRJQ4E/PndHyAEKnDitBvgTnJCtzIBiw4MAim7mmdO3T3xCq3N1PP/WRST+JEMDy19tkLwClR3SqziiXPAag=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-arm64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-gNMyW8t/1pBYNWwZpW7Gk4GArSEVrJOCBz8YvaHpzwk9iuVYeka4lOIvudA9drCxY5EUU1I20EJvCSycNffgsg=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-FiXMi1dtVF47L4ITblPzzCbgLY9noHwV0ZvEL30bgm4hQPSSNdELFbDAgNuAktieV3/XV7KSOQPPxlc6KEZi2w=="; + }) ]; win-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-x64"; version = "9.0.0-rc.2.24474.3"; hash = "sha512-8FXl5YY++/bGTAOoAS7lK53CXyc7vzLAzfmXQ3q2s4vLvrKI3720ECDnDQS9Of9P8ZLDdMwX6SeHd4RbsLMaBg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-x64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-P4A/HDIrDVLJBtBD9Eoy2DxofmLXji5zzOBA9ZEWioXurCU5ujFw2VhUiKY6qDedFsq6/1IyVGDNcesd42jgmQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-x64"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-lCAvZbxLspyp1LgfAE8uCvd9muUNGK1XRAo62v7cxhMDrCopNPF4F36nRQq+LBbyijlCbXzHmB7FJ5SfcQYhfA=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-UUoAim2OxX0npr5wF3z9mLunFVVNyfadk5EyE8dkTAhiSULv4mzQhAMRLirPlnOOcvytVgrixBWmE+unUrjJrA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-x64"; + version = "9.0.0-rc.2.24474.3"; + hash = "sha512-8FXl5YY++/bGTAOoAS7lK53CXyc7vzLAzfmXQ3q2s4vLvrKI3720ECDnDQS9Of9P8ZLDdMwX6SeHd4RbsLMaBg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-x64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-P4A/HDIrDVLJBtBD9Eoy2DxofmLXji5zzOBA9ZEWioXurCU5ujFw2VhUiKY6qDedFsq6/1IyVGDNcesd42jgmQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-x64"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-lCAvZbxLspyp1LgfAE8uCvd9muUNGK1XRAo62v7cxhMDrCopNPF4F36nRQq+LBbyijlCbXzHmB7FJ5SfcQYhfA=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-UUoAim2OxX0npr5wF3z9mLunFVVNyfadk5EyE8dkTAhiSULv4mzQhAMRLirPlnOOcvytVgrixBWmE+unUrjJrA=="; + }) ]; win-x86 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-x86"; version = "9.0.0-rc.2.24474.3"; hash = "sha512-xuLmBBnsSd915EIhwY4x8UP6LKvVrbTP5Stx6zn12ZE9wf0mzrp92o4zs9xdS+XFjV4sXgPdJ00ayj8vRtqaew=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-x86"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-e0Rk0Kg5yGi/gv6pBGuGca860xeOTOMjx+A+5xvB6NLaPS7bdAuGgFRhiI0Bs1s8KcuEhnWK4EP8Z9127BR54A=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-x86"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-BU8bppDcPbtBi0WtF8WpGPDf10l+LwB/i/sBYmvmKtGymDkUTZ1Cx535oPA7c0vRfTYFbPZPNEZwlmtQj+gaRQ=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0-rc.2.24473.5"; hash = "sha512-zIGe6kxRaO8J+OU5LLvxUO1BMu3+GuTcS87aUggVNulwyHFjm60YS69VSpQ0JyWy5/m2cNTcTgcwRNAmU6He/g=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-x86"; + version = "9.0.0-rc.2.24474.3"; + hash = "sha512-xuLmBBnsSd915EIhwY4x8UP6LKvVrbTP5Stx6zn12ZE9wf0mzrp92o4zs9xdS+XFjV4sXgPdJ00ayj8vRtqaew=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-x86"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-e0Rk0Kg5yGi/gv6pBGuGca860xeOTOMjx+A+5xvB6NLaPS7bdAuGgFRhiI0Bs1s8KcuEhnWK4EP8Z9127BR54A=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-x86"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-BU8bppDcPbtBi0WtF8WpGPDf10l+LwB/i/sBYmvmKtGymDkUTZ1Cx535oPA7c0vRfTYFbPZPNEZwlmtQj+gaRQ=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0-rc.2.24473.5"; + hash = "sha512-zIGe6kxRaO8J+OU5LLvxUO1BMu3+GuTcS87aUggVNulwyHFjm60YS69VSpQ0JyWy5/m2cNTcTgcwRNAmU6He/g=="; + }) ]; }; -in rec { +in +rec { release_9_0 = "9.0.0-rc.2"; aspnetcore_9_0 = buildAspNetCore { @@ -246,6 +524,5 @@ in rec { sdk = sdk_9_0; - sdk_9_0 = sdk_9_0_1xx; } diff --git a/pkgs/development/compilers/dotnet/9/deps.nix b/pkgs/development/compilers/dotnet/9/deps.nix index 9985dd10ebad54..a798d1687b7eac 100644 --- a/pkgs/development/compilers/dotnet/9/deps.nix +++ b/pkgs/development/compilers/dotnet/9/deps.nix @@ -1,10 +1,51 @@ -{ fetchNuGet }: [ - (fetchNuGet { pname = "runtime.linux-arm64.Microsoft.NETCore.ILAsm"; sha256 = "e4b53e790874d2c549fcf7564c55b6f57ccc6bcf4b1c02e9fb346bebaf48e786"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.linux-arm64.microsoft.netcore.ilasm/9.0.0-rc.2.24473.5/runtime.linux-arm64.microsoft.netcore.ilasm.9.0.0-rc.2.24473.5.nupkg"; version = "9.0.0-rc.2.24473.5"; }) - (fetchNuGet { pname = "runtime.linux-arm64.Microsoft.NETCore.ILDAsm"; sha256 = "691680bd52ebda543f25439eb7752bc991cb1ea1989876248a4b7f147cd9ed97"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.linux-arm64.microsoft.netcore.ildasm/9.0.0-rc.2.24473.5/runtime.linux-arm64.microsoft.netcore.ildasm.9.0.0-rc.2.24473.5.nupkg"; version = "9.0.0-rc.2.24473.5"; }) - (fetchNuGet { hash = "sha256-1eNeVt7gITpoDCFaDOZGoD+3l6L94YhND7wJQGrFNM8="; pname = "runtime.linux-x64.Microsoft.NETCore.ILAsm"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.linux-x64.microsoft.netcore.ilasm/9.0.0-rc.2.24473.5/runtime.linux-x64.microsoft.netcore.ilasm.9.0.0-rc.2.24473.5.nupkg"; version = "9.0.0-rc.2.24473.5"; }) - (fetchNuGet { hash = "sha256-NWPAJfFZom8WniWFENXLMTRFCPxFIFhRDYwqHvAPlHM="; pname = "runtime.linux-x64.Microsoft.NETCore.ILDAsm"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.linux-x64.microsoft.netcore.ildasm/9.0.0-rc.2.24473.5/runtime.linux-x64.microsoft.netcore.ildasm.9.0.0-rc.2.24473.5.nupkg"; version = "9.0.0-rc.2.24473.5"; }) - (fetchNuGet { pname = "runtime.osx-arm64.Microsoft.NETCore.ILAsm"; sha256 = "1623300e5c7a63414cd09d22175b7c9bee2501aaefdd91f4dc6f3b280b32b875"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx-arm64.microsoft.netcore.ilasm/9.0.0-rc.2.24473.5/runtime.osx-arm64.microsoft.netcore.ilasm.9.0.0-rc.2.24473.5.nupkg"; version = "9.0.0-rc.2.24473.5"; }) - (fetchNuGet { pname = "runtime.osx-arm64.Microsoft.NETCore.ILDAsm"; sha256 = "9ee98379a6b8516014bc09a1b46d346a0de2668dbe6eab9b66b303ab69254f78"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx-arm64.microsoft.netcore.ildasm/9.0.0-rc.2.24473.5/runtime.osx-arm64.microsoft.netcore.ildasm.9.0.0-rc.2.24473.5.nupkg"; version = "9.0.0-rc.2.24473.5"; }) - (fetchNuGet { pname = "runtime.osx-x64.Microsoft.NETCore.ILAsm"; sha256 = "79514cc63414bbe8a67c97909643ae00b7b4d3d8043f7b32441137f1528ed959"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx-x64.microsoft.netcore.ilasm/9.0.0-rc.2.24473.5/runtime.osx-x64.microsoft.netcore.ilasm.9.0.0-rc.2.24473.5.nupkg"; version = "9.0.0-rc.2.24473.5"; }) - (fetchNuGet { pname = "runtime.osx-x64.Microsoft.NETCore.ILDAsm"; sha256 = "44b03353bb109721f900eb30f148002a1333ddf53961111be4fa54c3cfff26c7"; url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx-x64.microsoft.netcore.ildasm/9.0.0-rc.2.24473.5/runtime.osx-x64.microsoft.netcore.ildasm.9.0.0-rc.2.24473.5.nupkg"; version = "9.0.0-rc.2.24473.5"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "runtime.linux-arm64.Microsoft.NETCore.ILAsm"; + sha256 = "e4b53e790874d2c549fcf7564c55b6f57ccc6bcf4b1c02e9fb346bebaf48e786"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.linux-arm64.microsoft.netcore.ilasm/9.0.0-rc.2.24473.5/runtime.linux-arm64.microsoft.netcore.ilasm.9.0.0-rc.2.24473.5.nupkg"; + version = "9.0.0-rc.2.24473.5"; + }) + (fetchNuGet { + pname = "runtime.linux-arm64.Microsoft.NETCore.ILDAsm"; + sha256 = "691680bd52ebda543f25439eb7752bc991cb1ea1989876248a4b7f147cd9ed97"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.linux-arm64.microsoft.netcore.ildasm/9.0.0-rc.2.24473.5/runtime.linux-arm64.microsoft.netcore.ildasm.9.0.0-rc.2.24473.5.nupkg"; + version = "9.0.0-rc.2.24473.5"; + }) + (fetchNuGet { + hash = "sha256-1eNeVt7gITpoDCFaDOZGoD+3l6L94YhND7wJQGrFNM8="; + pname = "runtime.linux-x64.Microsoft.NETCore.ILAsm"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.linux-x64.microsoft.netcore.ilasm/9.0.0-rc.2.24473.5/runtime.linux-x64.microsoft.netcore.ilasm.9.0.0-rc.2.24473.5.nupkg"; + version = "9.0.0-rc.2.24473.5"; + }) + (fetchNuGet { + hash = "sha256-NWPAJfFZom8WniWFENXLMTRFCPxFIFhRDYwqHvAPlHM="; + pname = "runtime.linux-x64.Microsoft.NETCore.ILDAsm"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.linux-x64.microsoft.netcore.ildasm/9.0.0-rc.2.24473.5/runtime.linux-x64.microsoft.netcore.ildasm.9.0.0-rc.2.24473.5.nupkg"; + version = "9.0.0-rc.2.24473.5"; + }) + (fetchNuGet { + pname = "runtime.osx-arm64.Microsoft.NETCore.ILAsm"; + sha256 = "1623300e5c7a63414cd09d22175b7c9bee2501aaefdd91f4dc6f3b280b32b875"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx-arm64.microsoft.netcore.ilasm/9.0.0-rc.2.24473.5/runtime.osx-arm64.microsoft.netcore.ilasm.9.0.0-rc.2.24473.5.nupkg"; + version = "9.0.0-rc.2.24473.5"; + }) + (fetchNuGet { + pname = "runtime.osx-arm64.Microsoft.NETCore.ILDAsm"; + sha256 = "9ee98379a6b8516014bc09a1b46d346a0de2668dbe6eab9b66b303ab69254f78"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx-arm64.microsoft.netcore.ildasm/9.0.0-rc.2.24473.5/runtime.osx-arm64.microsoft.netcore.ildasm.9.0.0-rc.2.24473.5.nupkg"; + version = "9.0.0-rc.2.24473.5"; + }) + (fetchNuGet { + pname = "runtime.osx-x64.Microsoft.NETCore.ILAsm"; + sha256 = "79514cc63414bbe8a67c97909643ae00b7b4d3d8043f7b32441137f1528ed959"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx-x64.microsoft.netcore.ilasm/9.0.0-rc.2.24473.5/runtime.osx-x64.microsoft.netcore.ilasm.9.0.0-rc.2.24473.5.nupkg"; + version = "9.0.0-rc.2.24473.5"; + }) + (fetchNuGet { + pname = "runtime.osx-x64.Microsoft.NETCore.ILDAsm"; + sha256 = "44b03353bb109721f900eb30f148002a1333ddf53961111be4fa54c3cfff26c7"; + url = "https://pkgs.dev.azure.com/dnceng/9ee6d478-d288-47f7-aacc-f6e6d082ae6d/_packaging/45bacae2-5efb-47c8-91e5-8ec20c22b4f8/nuget/v3/flat2/runtime.osx-x64.microsoft.netcore.ildasm/9.0.0-rc.2.24473.5/runtime.osx-x64.microsoft.netcore.ildasm.9.0.0-rc.2.24473.5.nupkg"; + version = "9.0.0-rc.2.24473.5"; + }) ] diff --git a/pkgs/development/compilers/dotnet/versions/6.0.nix b/pkgs/development/compilers/dotnet/versions/6.0.nix index 7ad40963664373..43a3d7782fe060 100644 --- a/pkgs/development/compilers/dotnet/versions/6.0.nix +++ b/pkgs/development/compilers/dotnet/versions/6.0.nix @@ -1,164 +1,578 @@ -{ buildAspNetCore, buildNetRuntime, buildNetSdk, fetchNupkg }: +{ + buildAspNetCore, + buildNetRuntime, + buildNetSdk, + fetchNupkg, +}: # v6.0 (maintenance) let commonPackages = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Ref"; version = "6.0.36"; hash = "sha512-7hUCPQ2cFc920o+IO1kkTolILrJ1ozLiH1ppUQVFxSQ94z2A8t41KCxUOYxEHwoaDqKWJ0LKjDMSGuU113DVzA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetAppHost"; version = "6.0.36"; hash = "sha512-Ms0jj1SKpzOiIhmjRyvD5guCt7y/tU3cTjMqmiaJSEo3JPZvJXScyAOaKjcMXbCR5eAvAmfE4Gn2hnSzkh90dw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Ref"; version = "6.0.36"; hash = "sha512-qAcjjw2vDNJrTIw7R4UWLQuvslJbUpXxTrd1ckfDpWPqE0cEehOd9CvwizbD7HADjewzVv+LKvB5aOWYnpNmKA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetHost"; version = "6.0.36"; hash = "sha512-CPrQHhIPxgLjXv+SYqmCrtTrcarX5vol33mjalvNDb2z7Vml7LFT7oJk/Cf+GXZq6uBeNt/GOwXnvIaYe/1chQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetHostPolicy"; version = "6.0.36"; hash = "sha512-cBd1pSGW7JD53svFRupX19RDqToI/p+ZVwoWW6CYmgoFcDc1Ms9JQObfO2Pam4s41xrc1hABjpwl8VVMXU9Erw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetHostResolver"; version = "6.0.36"; hash = "sha512-Qv57NzPUsP3MPleNrUhisnnSaKf3EyHoiEpObs9jy/ohgo3seMDbjOq8EA1hifx5Dxiw0P3DSbVpaiCwNF5sJQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Ref"; + version = "6.0.36"; + hash = "sha512-7hUCPQ2cFc920o+IO1kkTolILrJ1ozLiH1ppUQVFxSQ94z2A8t41KCxUOYxEHwoaDqKWJ0LKjDMSGuU113DVzA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetAppHost"; + version = "6.0.36"; + hash = "sha512-Ms0jj1SKpzOiIhmjRyvD5guCt7y/tU3cTjMqmiaJSEo3JPZvJXScyAOaKjcMXbCR5eAvAmfE4Gn2hnSzkh90dw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Ref"; + version = "6.0.36"; + hash = "sha512-qAcjjw2vDNJrTIw7R4UWLQuvslJbUpXxTrd1ckfDpWPqE0cEehOd9CvwizbD7HADjewzVv+LKvB5aOWYnpNmKA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetHost"; + version = "6.0.36"; + hash = "sha512-CPrQHhIPxgLjXv+SYqmCrtTrcarX5vol33mjalvNDb2z7Vml7LFT7oJk/Cf+GXZq6uBeNt/GOwXnvIaYe/1chQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetHostPolicy"; + version = "6.0.36"; + hash = "sha512-cBd1pSGW7JD53svFRupX19RDqToI/p+ZVwoWW6CYmgoFcDc1Ms9JQObfO2Pam4s41xrc1hABjpwl8VVMXU9Erw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetHostResolver"; + version = "6.0.36"; + hash = "sha512-Qv57NzPUsP3MPleNrUhisnnSaKf3EyHoiEpObs9jy/ohgo3seMDbjOq8EA1hifx5Dxiw0P3DSbVpaiCwNF5sJQ=="; + }) ]; hostPackages = { linux-arm = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-arm"; version = "6.0.36"; hash = "sha512-VFKuhQzHyTnjdsv1Rmyg9HQteLw2//afI/g8OCyTesNZWSWRO4bDsrD78uZMD3y4vEbLoOP0qc+vgCe3YdbSbQ=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-arm"; + version = "6.0.36"; + hash = "sha512-VFKuhQzHyTnjdsv1Rmyg9HQteLw2//afI/g8OCyTesNZWSWRO4bDsrD78uZMD3y4vEbLoOP0qc+vgCe3YdbSbQ=="; + }) ]; linux-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-arm64"; version = "6.0.36"; hash = "sha512-xdAL8+k9u+N9DzTzeALpng5956ntAzSS+/dYsXmAowVuxdlMlbiOmfDyh0V67YB87qqE08y0wBzdq+Hw3yUkaw=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-arm64"; + version = "6.0.36"; + hash = "sha512-xdAL8+k9u+N9DzTzeALpng5956ntAzSS+/dYsXmAowVuxdlMlbiOmfDyh0V67YB87qqE08y0wBzdq+Hw3yUkaw=="; + }) ]; linux-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-x64"; version = "6.0.36"; hash = "sha512-Iyu9ynAcIOoiBMLm0j/9nSl0PWQGNW/ba+87hmu90vH/8Dx02waeAcFJj+jN5xNZ4NesUCLiYt1xDyh+QeQyaw=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-x64"; + version = "6.0.36"; + hash = "sha512-Iyu9ynAcIOoiBMLm0j/9nSl0PWQGNW/ba+87hmu90vH/8Dx02waeAcFJj+jN5xNZ4NesUCLiYt1xDyh+QeQyaw=="; + }) ]; linux-musl-arm = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm"; version = "6.0.36"; hash = "sha512-LSe8MkWFnKy7/GAYjXjtyT+hpqjspUlnppbajPw6XY5qniMzgeMMoxPs6bLaAr78/Ag9sgmDNmO/NXFCIFty6A=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm"; + version = "6.0.36"; + hash = "sha512-LSe8MkWFnKy7/GAYjXjtyT+hpqjspUlnppbajPw6XY5qniMzgeMMoxPs6bLaAr78/Ag9sgmDNmO/NXFCIFty6A=="; + }) ]; linux-musl-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm64"; version = "6.0.36"; hash = "sha512-O9utOLvrmAs3rsQyDxcr0c6G1PfzDRu6t+9poZRyHV0PT05Ro/MApDKgbRpVpnpczJZtxjrvyphRusKv1+Jolg=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm64"; + version = "6.0.36"; + hash = "sha512-O9utOLvrmAs3rsQyDxcr0c6G1PfzDRu6t+9poZRyHV0PT05Ro/MApDKgbRpVpnpczJZtxjrvyphRusKv1+Jolg=="; + }) ]; linux-musl-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-x64"; version = "6.0.36"; hash = "sha512-Y5ChGWMkky/EUeu4GK6RmagCdmjR8HY049Tsz+HxdkO/ShOEGY6Z7KVOkRoZG/Q0vt+kmCrNDjqlZy4Bgu5QSA=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-x64"; + version = "6.0.36"; + hash = "sha512-Y5ChGWMkky/EUeu4GK6RmagCdmjR8HY049Tsz+HxdkO/ShOEGY6Z7KVOkRoZG/Q0vt+kmCrNDjqlZy4Bgu5QSA=="; + }) ]; osx-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.osx-arm64"; version = "6.0.36"; hash = "sha512-7NLa+YPCk3zh+LGMla5Ffl2Sslis5MvHG0Ngjq1jVXHqIMukzM0FgWkhTDC5NaGM/foQOL9poMm0+v+I9ozTuA=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.osx-arm64"; + version = "6.0.36"; + hash = "sha512-7NLa+YPCk3zh+LGMla5Ffl2Sslis5MvHG0Ngjq1jVXHqIMukzM0FgWkhTDC5NaGM/foQOL9poMm0+v+I9ozTuA=="; + }) ]; osx-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.osx-x64"; version = "6.0.36"; hash = "sha512-fmv0OenPlfWVvYHaH8Lbe9ReSJB/X1pdxgyVqS1d8LSrRVtuCrL7Q2Xc+SqTzBCwQUSK+3kFQoS/jyVeddTyPA=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.osx-x64"; + version = "6.0.36"; + hash = "sha512-fmv0OenPlfWVvYHaH8Lbe9ReSJB/X1pdxgyVqS1d8LSrRVtuCrL7Q2Xc+SqTzBCwQUSK+3kFQoS/jyVeddTyPA=="; + }) ]; win-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-arm64"; version = "6.0.36"; hash = "sha512-igD8pT3ADrTJnXem+aFYUvjYUVPY57YnSpeAtwbqkika0VOWMriD29pFqMFV7tM6fEiQOerRV0aE9eIhLiM+dw=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-arm64"; + version = "6.0.36"; + hash = "sha512-igD8pT3ADrTJnXem+aFYUvjYUVPY57YnSpeAtwbqkika0VOWMriD29pFqMFV7tM6fEiQOerRV0aE9eIhLiM+dw=="; + }) ]; win-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-x64"; version = "6.0.36"; hash = "sha512-LnFU9J+ymzkZnTt3Q5/zDTH3q3dNhe+HP/OT24m7Zz8q2UURRF6KRYYhpdaxVyq+P+6y2Bg+2xJedfK+LHWwMQ=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-x64"; + version = "6.0.36"; + hash = "sha512-LnFU9J+ymzkZnTt3Q5/zDTH3q3dNhe+HP/OT24m7Zz8q2UURRF6KRYYhpdaxVyq+P+6y2Bg+2xJedfK+LHWwMQ=="; + }) ]; win-x86 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-x86"; version = "6.0.36"; hash = "sha512-GSewyPSzLVQki2kaWJ9WznyOc3+qKauTbd4M0cY3dS9Y0jlkeMMx9JvsSdUr3b9ZbcoFHs+d7800+MMbIvAWbg=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-x86"; + version = "6.0.36"; + hash = "sha512-GSewyPSzLVQki2kaWJ9WznyOc3+qKauTbd4M0cY3dS9Y0jlkeMMx9JvsSdUr3b9ZbcoFHs+d7800+MMbIvAWbg=="; + }) ]; }; targetPackages = { linux-arm = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm"; version = "6.0.36"; hash = "sha512-Zatdf57Zy27a4L6+Qd99a7BbPsV/gPKdEzULIICB/AhKka0Bq1CSJvpuLWihQwtnHBwuJi4tfKi3Ztk993Jidg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-arm"; version = "6.0.36"; hash = "sha512-vThEWkCQrp8GzhkoeTOgU1GNlaplLcysZk1GHjbSVEHZJP/mTNjmsBL0/LHW8iorZrNbEP57qTsD7Jtk0xnxyg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-arm"; version = "6.0.36"; hash = "sha512-Ymv7zgfCheRYpYjY6nGNM/90W8VEE6vw+gixSHhFdu5rszgqII+rwpBCBKcc5MOzYPp879wi759oy9jug2HvIg=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetAppHost"; version = "6.0.36"; hash = "sha512-/xMvX3PnWlvV03Nxt7TaWZDT8XNErkt2sE6jIYasJ9gcxzGr+bai8pj4H8ArvPjj3HsRawcsN4owkesy/9L9EQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHost"; version = "6.0.36"; hash = "sha512-X8lW/sHbRXQt9uKwfOy2S6NaO0RuZF+8Ov476amVVtDEu+U0diOB1JxoilTLJcoRn9O29EISVzzA1OFgwF2KnQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostPolicy"; version = "6.0.36"; hash = "sha512-owEMJ45fgXynGJKD14wNmyVr6KfYZtLpp6Z7GQORGPibOKW/Dq5MiLdo2nKSoHPSf5KUJaRqhb+JawhoK68rXA=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostResolver"; version = "6.0.36"; hash = "sha512-dJAjWxCDxspFxWKihDHxwl9cRZ4xWWMjCnRKDFn8KNHVdrMrtlhqhhS1iRBW9iQS/gapfsOL05dzq5eWAoaDFg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm"; version = "6.0.36"; hash = "sha512-6OwlxDkPLmWojyYtMvYmqr1+b3XCo/F2vqQvkeyOXb0ix1y6qHbKNnjfcc4HPgQbeeToq4lhlp1Jvj3uY7ncJg=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm"; + version = "6.0.36"; + hash = "sha512-Zatdf57Zy27a4L6+Qd99a7BbPsV/gPKdEzULIICB/AhKka0Bq1CSJvpuLWihQwtnHBwuJi4tfKi3Ztk993Jidg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-arm"; + version = "6.0.36"; + hash = "sha512-vThEWkCQrp8GzhkoeTOgU1GNlaplLcysZk1GHjbSVEHZJP/mTNjmsBL0/LHW8iorZrNbEP57qTsD7Jtk0xnxyg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-arm"; + version = "6.0.36"; + hash = "sha512-Ymv7zgfCheRYpYjY6nGNM/90W8VEE6vw+gixSHhFdu5rszgqII+rwpBCBKcc5MOzYPp879wi759oy9jug2HvIg=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetAppHost"; + version = "6.0.36"; + hash = "sha512-/xMvX3PnWlvV03Nxt7TaWZDT8XNErkt2sE6jIYasJ9gcxzGr+bai8pj4H8ArvPjj3HsRawcsN4owkesy/9L9EQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHost"; + version = "6.0.36"; + hash = "sha512-X8lW/sHbRXQt9uKwfOy2S6NaO0RuZF+8Ov476amVVtDEu+U0diOB1JxoilTLJcoRn9O29EISVzzA1OFgwF2KnQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostPolicy"; + version = "6.0.36"; + hash = "sha512-owEMJ45fgXynGJKD14wNmyVr6KfYZtLpp6Z7GQORGPibOKW/Dq5MiLdo2nKSoHPSf5KUJaRqhb+JawhoK68rXA=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostResolver"; + version = "6.0.36"; + hash = "sha512-dJAjWxCDxspFxWKihDHxwl9cRZ4xWWMjCnRKDFn8KNHVdrMrtlhqhhS1iRBW9iQS/gapfsOL05dzq5eWAoaDFg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm"; + version = "6.0.36"; + hash = "sha512-6OwlxDkPLmWojyYtMvYmqr1+b3XCo/F2vqQvkeyOXb0ix1y6qHbKNnjfcc4HPgQbeeToq4lhlp1Jvj3uY7ncJg=="; + }) ]; linux-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; version = "6.0.36"; hash = "sha512-lAAx+xfzVq7nByfQlRKcVTRElpBk6Q2RF7ulx600kH0mk1Dy0J5/0IxEkwi+K5pEgjjCrGs37Uhc82mVwF8iUQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-arm64"; version = "6.0.36"; hash = "sha512-OlDeI3Y7Po0mhbfmb2zVCxaKXhPUIFGBIqRlbv5vnC7OQohief/31EPBNC0RCaEaayRjTv7P3CckkX403Y8Ncw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; version = "6.0.36"; hash = "sha512-B3ZtzUpX1lR7XjfLrMh+rsZr5lRlVx4r2jK0eJQCyqt/V0Imw2ebQjieoQJra5sb5VQZZcS9LxNGhC5RZOrIbQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; version = "6.0.36"; hash = "sha512-uFRU9M+2sbznLG5zJDONtdh+e6MzkduoEUgmE1EjHULpw25JtICwRtNOe2pIb1HmaAhqnIhFixbfBMzMCh0iBg=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHost"; version = "6.0.36"; hash = "sha512-p9JqRzIRhqEzt8rUvKkX/LHks0wAX28+vmRwzI3Izvw2m1DkTulC/4/YE8kFRiZYu5qyVu3J7eQjeQJlZ9w8rw=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "6.0.36"; hash = "sha512-h1wEpa6TXlNPyfrHw3XlGKQs8BIbKyKKEYiXfvXGnvIFReBocZ1GoL+rBG+AqB9UxwKi/ZTMyFC3edRBDKIJSg=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "6.0.36"; hash = "sha512-nkc+N/yxkFrne90qBwWvMGqZGauty39r+pFyJL24KMm6KUNLrnn/aR+abM2Sas/B/nAhjKtxLXUU0paFR2jQUA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm64"; version = "6.0.36"; hash = "sha512-HDuYQ8oIFLpSfscZ9YcXp5rFifZKA6QJpFQAl6RAXE7GXs8a+hjBUPH5goI/Ms1L11T2WgpyGfap2wTJKsusUQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; + version = "6.0.36"; + hash = "sha512-lAAx+xfzVq7nByfQlRKcVTRElpBk6Q2RF7ulx600kH0mk1Dy0J5/0IxEkwi+K5pEgjjCrGs37Uhc82mVwF8iUQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-arm64"; + version = "6.0.36"; + hash = "sha512-OlDeI3Y7Po0mhbfmb2zVCxaKXhPUIFGBIqRlbv5vnC7OQohief/31EPBNC0RCaEaayRjTv7P3CckkX403Y8Ncw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; + version = "6.0.36"; + hash = "sha512-B3ZtzUpX1lR7XjfLrMh+rsZr5lRlVx4r2jK0eJQCyqt/V0Imw2ebQjieoQJra5sb5VQZZcS9LxNGhC5RZOrIbQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "6.0.36"; + hash = "sha512-uFRU9M+2sbznLG5zJDONtdh+e6MzkduoEUgmE1EjHULpw25JtICwRtNOe2pIb1HmaAhqnIhFixbfBMzMCh0iBg=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHost"; + version = "6.0.36"; + hash = "sha512-p9JqRzIRhqEzt8rUvKkX/LHks0wAX28+vmRwzI3Izvw2m1DkTulC/4/YE8kFRiZYu5qyVu3J7eQjeQJlZ9w8rw=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "6.0.36"; + hash = "sha512-h1wEpa6TXlNPyfrHw3XlGKQs8BIbKyKKEYiXfvXGnvIFReBocZ1GoL+rBG+AqB9UxwKi/ZTMyFC3edRBDKIJSg=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "6.0.36"; + hash = "sha512-nkc+N/yxkFrne90qBwWvMGqZGauty39r+pFyJL24KMm6KUNLrnn/aR+abM2Sas/B/nAhjKtxLXUU0paFR2jQUA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm64"; + version = "6.0.36"; + hash = "sha512-HDuYQ8oIFLpSfscZ9YcXp5rFifZKA6QJpFQAl6RAXE7GXs8a+hjBUPH5goI/Ms1L11T2WgpyGfap2wTJKsusUQ=="; + }) ]; linux-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; version = "6.0.36"; hash = "sha512-c/rCzvHPIQ7Es9YECSisSXAS67S+T5BWp8AgwSGxwpEgr7z3mShbhKNsMtWE+F6kxncIwzyCFAvdKKV5zuGoOw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-x64"; version = "6.0.36"; hash = "sha512-WRPkqMdz5pLsZTxXah0LgKwrGwDVc1jLxov4XKyqeCW1uAtPCTgf7UEAkFaFZufxmW8d+B0UbAD2u4PBCKYkJA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-x64"; version = "6.0.36"; hash = "sha512-QOBu74LANKrjgQI6NMSSHZkungzGW+79tlOSv04HuGkphqCf330pMeCFvQn7U/i+egShqpFVZiFZDuzoTnCNjg=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; version = "6.0.36"; hash = "sha512-sSwbBQbY3e2ZesyIYmIfWkZtqCXCDd8SQ0s9bqHzw9eVqe+/Vic5lejXtUhjseT9WlVFezemHXVLKycKwOKZiw=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHost"; version = "6.0.36"; hash = "sha512-PbQTcTomq+6jhG5Ya8EjVjhZ8mA4eeyRzIob4vhVtIuvQd+N29xaBSWLj7Ym3XqXVvw5ZYrV62Hq/DwOk8Lwlw=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "6.0.36"; hash = "sha512-1SCZQotM+MemoSipVniSbLf2vL0G7MeGOgziY4yLNCc1G69FRbIEXKEojyUcL0vfo/iR7P0Yr2IiheUpTJUMgQ=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostResolver"; version = "6.0.36"; hash = "sha512-Go50A8OXzH/v00zL1QaTW3Un9Ul9ks5RpdG1GN0gZFOt4p5kkmpaNcgCvdEH9Y0sTK5r2HLzqxqULUnbp89lIw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-x64"; version = "6.0.36"; hash = "sha512-lb1/8FBLqS937W6BHeX/5sW7CeE+Ey8dt8O1+uwFaTBQHWVpN/DqNkVHlHfJw7gYJsp80I8imfQ7F5p47iEfxQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; + version = "6.0.36"; + hash = "sha512-c/rCzvHPIQ7Es9YECSisSXAS67S+T5BWp8AgwSGxwpEgr7z3mShbhKNsMtWE+F6kxncIwzyCFAvdKKV5zuGoOw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-x64"; + version = "6.0.36"; + hash = "sha512-WRPkqMdz5pLsZTxXah0LgKwrGwDVc1jLxov4XKyqeCW1uAtPCTgf7UEAkFaFZufxmW8d+B0UbAD2u4PBCKYkJA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-x64"; + version = "6.0.36"; + hash = "sha512-QOBu74LANKrjgQI6NMSSHZkungzGW+79tlOSv04HuGkphqCf330pMeCFvQn7U/i+egShqpFVZiFZDuzoTnCNjg=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; + version = "6.0.36"; + hash = "sha512-sSwbBQbY3e2ZesyIYmIfWkZtqCXCDd8SQ0s9bqHzw9eVqe+/Vic5lejXtUhjseT9WlVFezemHXVLKycKwOKZiw=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHost"; + version = "6.0.36"; + hash = "sha512-PbQTcTomq+6jhG5Ya8EjVjhZ8mA4eeyRzIob4vhVtIuvQd+N29xaBSWLj7Ym3XqXVvw5ZYrV62Hq/DwOk8Lwlw=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "6.0.36"; + hash = "sha512-1SCZQotM+MemoSipVniSbLf2vL0G7MeGOgziY4yLNCc1G69FRbIEXKEojyUcL0vfo/iR7P0Yr2IiheUpTJUMgQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "6.0.36"; + hash = "sha512-Go50A8OXzH/v00zL1QaTW3Un9Ul9ks5RpdG1GN0gZFOt4p5kkmpaNcgCvdEH9Y0sTK5r2HLzqxqULUnbp89lIw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-x64"; + version = "6.0.36"; + hash = "sha512-lb1/8FBLqS937W6BHeX/5sW7CeE+Ey8dt8O1+uwFaTBQHWVpN/DqNkVHlHfJw7gYJsp80I8imfQ7F5p47iEfxQ=="; + }) ]; linux-musl-arm = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm"; version = "6.0.36"; hash = "sha512-xw8ONhkE2N0dRp1POSN34sOM75txFYmLhFuPMld1K7M9OO/Itv6l7ERLMlseta0mSxOg7pY+iaTUCKY5Oo9+8g=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-arm"; version = "6.0.36"; hash = "sha512-TGc7LuVvkAvUdwxaUHi9/m+PfLmatTTrlmlD+5o5XuKV0WUhfDZf2nuUjUhuIsx/0tnvV2ydwNhA8ajzeOWTCg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm"; version = "6.0.36"; hash = "sha512-cwzTB77RuMKHyaACQQPiLkQys4d//jY1Y5UZvHYU+nm5m7OKUKPa3AXn1LfCoCvi9viDd8isi87hIil/AsPfng=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetAppHost"; version = "6.0.36"; hash = "sha512-3H7KYk8BOQIQarVFAZsFL+FJ9R3OW4E6dtnw+M0YruK0rc64IBJHFHdxDjBk4Bud8auS1QG3tjflxWcMDvsgew=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHost"; version = "6.0.36"; hash = "sha512-nJ06DFHdbbvLBYCuAso3uJu1lC5SK6yk3Xtd8DDzxlPMhflblOZwMhEGzpNeyivAvAubbu57nLB4l/XMn+9aAQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostPolicy"; version = "6.0.36"; hash = "sha512-8xQWPhhZg/dxehVpWvl0gIkFOW43ZimP2KDAi/v9uerAXXG0NgAsHuWOCDi61gQ8LGHLX460KX1VE+VABQFHpA=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostResolver"; version = "6.0.36"; hash = "sha512-JVTMB8tANHOJikofW1YWgBZTVLYgZTWrvoUMNQLV71mrSVAC7z+6yyJnu89FuMEw4wmCYUTyI8RWklNqE+3fFA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm"; + version = "6.0.36"; + hash = "sha512-xw8ONhkE2N0dRp1POSN34sOM75txFYmLhFuPMld1K7M9OO/Itv6l7ERLMlseta0mSxOg7pY+iaTUCKY5Oo9+8g=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-arm"; + version = "6.0.36"; + hash = "sha512-TGc7LuVvkAvUdwxaUHi9/m+PfLmatTTrlmlD+5o5XuKV0WUhfDZf2nuUjUhuIsx/0tnvV2ydwNhA8ajzeOWTCg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm"; + version = "6.0.36"; + hash = "sha512-cwzTB77RuMKHyaACQQPiLkQys4d//jY1Y5UZvHYU+nm5m7OKUKPa3AXn1LfCoCvi9viDd8isi87hIil/AsPfng=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetAppHost"; + version = "6.0.36"; + hash = "sha512-3H7KYk8BOQIQarVFAZsFL+FJ9R3OW4E6dtnw+M0YruK0rc64IBJHFHdxDjBk4Bud8auS1QG3tjflxWcMDvsgew=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHost"; + version = "6.0.36"; + hash = "sha512-nJ06DFHdbbvLBYCuAso3uJu1lC5SK6yk3Xtd8DDzxlPMhflblOZwMhEGzpNeyivAvAubbu57nLB4l/XMn+9aAQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostPolicy"; + version = "6.0.36"; + hash = "sha512-8xQWPhhZg/dxehVpWvl0gIkFOW43ZimP2KDAi/v9uerAXXG0NgAsHuWOCDi61gQ8LGHLX460KX1VE+VABQFHpA=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostResolver"; + version = "6.0.36"; + hash = "sha512-JVTMB8tANHOJikofW1YWgBZTVLYgZTWrvoUMNQLV71mrSVAC7z+6yyJnu89FuMEw4wmCYUTyI8RWklNqE+3fFA=="; + }) ]; linux-musl-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm64"; version = "6.0.36"; hash = "sha512-9jbPtXNsHUDyCWC11sWWyv6ao9aLRvdKpM57sxvhjWeOiLt93QwAagV8uDQ+1ymXkL9IfautWREGntn6KaW62w=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-arm64"; version = "6.0.36"; hash = "sha512-8BXWNjvA7BkhZD2dGx00Rfz7+FvjprTUnJKp3uLze83Wet0D/CcMn/22NSMq0JcG+DxulQgyQ8U88QadyQagMQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm64"; version = "6.0.36"; hash = "sha512-8SzE6VIFgq87LipNuj1chTzR93v1Wu5Xun7Om1tvKCIUk98ZjXhIaqtWr6r7mwm/KFiBthCDsgq26n0ffM7wrw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetAppHost"; version = "6.0.36"; hash = "sha512-QYX3vB6w0fNrSeoZrEZpm9uiKUEwDlny+yAy97mn4EA0TV0OJMPhHzbqwu/sGYtLQXki3pPPQwc0sH25px+FFQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHost"; version = "6.0.36"; hash = "sha512-pdmyxOhfzGGOCgvjAqjIVHwIpaSCYqkDJ3sbAVI6Zmc4mlHp9MmiFJmQuM5HJaS0HBajhkchOPHwZ3Izf5EhBw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "6.0.36"; hash = "sha512-7oFw+NpJU4tS+MtAODx4b3GINCxbDlEWcZsyPrlsP1dUhhKWy5Wk1f9r1253vnStUfx+UsvcMN753N/HTDq2nw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "6.0.36"; hash = "sha512-upZ6lhYYPq5/3qAHUmQe+unfrkDqtYwWRLLwfEWsuTK6RHSkiLIkZbJ0SG9rPLFqAm4ZdxJ5AlylAjVTSYXWCw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm64"; + version = "6.0.36"; + hash = "sha512-9jbPtXNsHUDyCWC11sWWyv6ao9aLRvdKpM57sxvhjWeOiLt93QwAagV8uDQ+1ymXkL9IfautWREGntn6KaW62w=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-arm64"; + version = "6.0.36"; + hash = "sha512-8BXWNjvA7BkhZD2dGx00Rfz7+FvjprTUnJKp3uLze83Wet0D/CcMn/22NSMq0JcG+DxulQgyQ8U88QadyQagMQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm64"; + version = "6.0.36"; + hash = "sha512-8SzE6VIFgq87LipNuj1chTzR93v1Wu5Xun7Om1tvKCIUk98ZjXhIaqtWr6r7mwm/KFiBthCDsgq26n0ffM7wrw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "6.0.36"; + hash = "sha512-QYX3vB6w0fNrSeoZrEZpm9uiKUEwDlny+yAy97mn4EA0TV0OJMPhHzbqwu/sGYtLQXki3pPPQwc0sH25px+FFQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHost"; + version = "6.0.36"; + hash = "sha512-pdmyxOhfzGGOCgvjAqjIVHwIpaSCYqkDJ3sbAVI6Zmc4mlHp9MmiFJmQuM5HJaS0HBajhkchOPHwZ3Izf5EhBw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "6.0.36"; + hash = "sha512-7oFw+NpJU4tS+MtAODx4b3GINCxbDlEWcZsyPrlsP1dUhhKWy5Wk1f9r1253vnStUfx+UsvcMN753N/HTDq2nw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "6.0.36"; + hash = "sha512-upZ6lhYYPq5/3qAHUmQe+unfrkDqtYwWRLLwfEWsuTK6RHSkiLIkZbJ0SG9rPLFqAm4ZdxJ5AlylAjVTSYXWCw=="; + }) ]; linux-musl-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-x64"; version = "6.0.36"; hash = "sha512-dWFq/5WE7bNe+fYJrpzWihcBkNGM4cR4bRv23bYxmzdTV2pngiDXu1XBwUWpDgCNeL8eP0BgFOQ4Ra9NNXaLpw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-x64"; version = "6.0.36"; hash = "sha512-V/yoD7xpW/R1jW3DDBLl7q7KCiSspzT4rCRgkMNf6CBFDEf1HzeoeHprpNbBz7NNMYKOWlG28Fm4uZ84LGX9MQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-x64"; version = "6.0.36"; hash = "sha512-dYTLwgPcI9x7oexhWy+b/vsLfq4sBTgGKKdtWOYgAZFCXkKLOeWCtLySNSMmITrs7MtGgRyEwDpc5XIENc7U3A=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetAppHost"; version = "6.0.36"; hash = "sha512-l+iUoIzGLGskdR8tE58M6yLcvFQiuh6zl1y4xZ0NHiFMfxsprg495YAUhdRG9S+kkS099X8cj52YpfIirB2MjA=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHost"; version = "6.0.36"; hash = "sha512-od+3cWk88mKDInSQSI+TMuyfSjNnjv28xdQ/5QVyskE7lR+c2+Tf/z6qSsdJwNAPBvoCfbcNXf28qKVnIntvMA=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "6.0.36"; hash = "sha512-4RVDjn5CXgAA0CvavXrNNuBCvXa4awm4ZC+Fn0+G2lmmJaakN7NhhCg519M3n4CZm74pL8kZ7Kyc4ZbM/wcurA=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostResolver"; version = "6.0.36"; hash = "sha512-SrAbz7L/nFt+U9UmVs7irCspL7efzWM2x0MuCv6Yo+reF8scoSkVp6ZHfUrtG3oASJlgSUQI6nohmFZVF+q7DQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-musl-x64"; version = "6.0.36"; hash = "sha512-ZAhA9FAERM/iRLRBfZLCdA8BnRbH/Hh0CEe3EvmJb71gWUn7y+jMZX1zE32SiFS6HroMjvhAozyqMbdcqtF/ZA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-x64"; + version = "6.0.36"; + hash = "sha512-dWFq/5WE7bNe+fYJrpzWihcBkNGM4cR4bRv23bYxmzdTV2pngiDXu1XBwUWpDgCNeL8eP0BgFOQ4Ra9NNXaLpw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-x64"; + version = "6.0.36"; + hash = "sha512-V/yoD7xpW/R1jW3DDBLl7q7KCiSspzT4rCRgkMNf6CBFDEf1HzeoeHprpNbBz7NNMYKOWlG28Fm4uZ84LGX9MQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-x64"; + version = "6.0.36"; + hash = "sha512-dYTLwgPcI9x7oexhWy+b/vsLfq4sBTgGKKdtWOYgAZFCXkKLOeWCtLySNSMmITrs7MtGgRyEwDpc5XIENc7U3A=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetAppHost"; + version = "6.0.36"; + hash = "sha512-l+iUoIzGLGskdR8tE58M6yLcvFQiuh6zl1y4xZ0NHiFMfxsprg495YAUhdRG9S+kkS099X8cj52YpfIirB2MjA=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHost"; + version = "6.0.36"; + hash = "sha512-od+3cWk88mKDInSQSI+TMuyfSjNnjv28xdQ/5QVyskE7lR+c2+Tf/z6qSsdJwNAPBvoCfbcNXf28qKVnIntvMA=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "6.0.36"; + hash = "sha512-4RVDjn5CXgAA0CvavXrNNuBCvXa4awm4ZC+Fn0+G2lmmJaakN7NhhCg519M3n4CZm74pL8kZ7Kyc4ZbM/wcurA=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "6.0.36"; + hash = "sha512-SrAbz7L/nFt+U9UmVs7irCspL7efzWM2x0MuCv6Yo+reF8scoSkVp6ZHfUrtG3oASJlgSUQI6nohmFZVF+q7DQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-musl-x64"; + version = "6.0.36"; + hash = "sha512-ZAhA9FAERM/iRLRBfZLCdA8BnRbH/Hh0CEe3EvmJb71gWUn7y+jMZX1zE32SiFS6HroMjvhAozyqMbdcqtF/ZA=="; + }) ]; osx-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.osx-arm64"; version = "6.0.36"; hash = "sha512-bBaPwnTViUOUer+qW9IB5Gzrv6Ha47od8DMiCho/6GtFjUi8NeDtj8/HFjApo3JZWBzBAW3xkK1MD5QFthDJCw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.osx-arm64"; version = "6.0.36"; hash = "sha512-TRU5D6v6pHYNgtnGe9nH7XQnhKE/FdBcxvhWUkS8rcm7ZEYP2RYiOBXQvamgKqH3Tx04+i+2y/HurX0IlMaF0Q=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.osx-arm64"; version = "6.0.36"; hash = "sha512-zPyKnjYA4/HHBEKgPPl+AvPBi61273ub52yfTNE1Pb4WkI0Xlc7Vg8aPtoux3kO+jS5IVs2MM3uCjOVLJKwD2g=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetAppHost"; version = "6.0.36"; hash = "sha512-yZfWNHUZyGFvLNxR2Mhtf9m5Z7B2ERTrTAGyGr38Zla2zcOIqbGlW6azyKvPhUGOmRfPOHdHtORocN8PQ4JTMg=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHost"; version = "6.0.36"; hash = "sha512-c9EQxxMOZVnRxb7t2mKquAV96q9AbGIzkXbS8/stkcWvTjdhJscPzwph07EZnjd/9l54iSjqZBgrFcAHGK7yqQ=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "6.0.36"; hash = "sha512-vT9WNvH/Vjx8FlfMb65oL1hVuHAnXPC2ClcFMg9I+97tyGBNI2wwgp+zY3hicW410kP4oG/UbzImJaUuG+wi/A=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "6.0.36"; hash = "sha512-s6wb85RmUkvDGhLy/E8ZSqmq2ghUKcRP36TVFWUD8j8Sv5Tf812BrW18lrqh/MvVZC2XRLoZNNmlQ5t1YoRcIg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.osx-arm64"; version = "6.0.36"; hash = "sha512-hcK5PGxMmsIigqtDPCvC5b2YgPXJoUgw6NqFl6WR+TkMYqvpBG0MNByQGEfuVjuuIEMyRdKOYjigovg03FGTdg=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.osx-arm64"; + version = "6.0.36"; + hash = "sha512-bBaPwnTViUOUer+qW9IB5Gzrv6Ha47od8DMiCho/6GtFjUi8NeDtj8/HFjApo3JZWBzBAW3xkK1MD5QFthDJCw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.osx-arm64"; + version = "6.0.36"; + hash = "sha512-TRU5D6v6pHYNgtnGe9nH7XQnhKE/FdBcxvhWUkS8rcm7ZEYP2RYiOBXQvamgKqH3Tx04+i+2y/HurX0IlMaF0Q=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.osx-arm64"; + version = "6.0.36"; + hash = "sha512-zPyKnjYA4/HHBEKgPPl+AvPBi61273ub52yfTNE1Pb4WkI0Xlc7Vg8aPtoux3kO+jS5IVs2MM3uCjOVLJKwD2g=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "6.0.36"; + hash = "sha512-yZfWNHUZyGFvLNxR2Mhtf9m5Z7B2ERTrTAGyGr38Zla2zcOIqbGlW6azyKvPhUGOmRfPOHdHtORocN8PQ4JTMg=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHost"; + version = "6.0.36"; + hash = "sha512-c9EQxxMOZVnRxb7t2mKquAV96q9AbGIzkXbS8/stkcWvTjdhJscPzwph07EZnjd/9l54iSjqZBgrFcAHGK7yqQ=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "6.0.36"; + hash = "sha512-vT9WNvH/Vjx8FlfMb65oL1hVuHAnXPC2ClcFMg9I+97tyGBNI2wwgp+zY3hicW410kP4oG/UbzImJaUuG+wi/A=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "6.0.36"; + hash = "sha512-s6wb85RmUkvDGhLy/E8ZSqmq2ghUKcRP36TVFWUD8j8Sv5Tf812BrW18lrqh/MvVZC2XRLoZNNmlQ5t1YoRcIg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.osx-arm64"; + version = "6.0.36"; + hash = "sha512-hcK5PGxMmsIigqtDPCvC5b2YgPXJoUgw6NqFl6WR+TkMYqvpBG0MNByQGEfuVjuuIEMyRdKOYjigovg03FGTdg=="; + }) ]; osx-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; version = "6.0.36"; hash = "sha512-YJRtVo8VZ/K6qwuyGHlGrPfqVhBZAZ4fk6+tLNZPREZM3l3EjjcrjWat2QL2WZF71aFioZVQScTzKEMfIjOZlQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.osx-x64"; version = "6.0.36"; hash = "sha512-XylVsSjl1387Mz1g23ZUtPWGz/u1YBX2fd2Fldv2B6WteiIIdoLzHOmP+JeBR67WtVSUcEMrTT4NWj7xOr02Ww=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.osx-x64"; version = "6.0.36"; hash = "sha512-M6IcgiyppQQ5GUkSwCaOXGh7y9qOugLj+ePi4Ooi4qMqolXB56ciPZ7XJ2HxWsXg9OHmFcOYtu/7mDPGy2uodQ=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetAppHost"; version = "6.0.36"; hash = "sha512-GY7b2ozZJe0iiZ7l7qAp4xF09ZUe1Tk6EA35qnIFAEA0X3MjdRM2iU8iM6TZFXEaGycWX2FsydTKmYCGTHwTzQ=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHost"; version = "6.0.36"; hash = "sha512-xuLTiyLCUp1xR+4gUhccwCedkFW94n1uQOlnlo9objTXX9GjPxpNik0UJ84zYKOnd5xxWS9zbBWxuoCVZcijBQ=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "6.0.36"; hash = "sha512-CCVx2PYEhxrrN1SOLc7ls3Vf83zKCm707pSFjiwba/pj39BmRQNjDaLwaSl5s/HeSPnkSZ0Hz9KQpvkTmxUmvg=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostResolver"; version = "6.0.36"; hash = "sha512-F0lCmbajEZCsNiYh7+FA3TGJjWwPq9hKWUZfnabKnMNqx8gzh+jeTWLW7t1/ab1jWvO3yhEKMQMQJXMBBfBhsg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.osx-x64"; version = "6.0.36"; hash = "sha512-bLfQElXz9BFta1qvXqjviTOeCenMh5S97vsdySMRP/IOMFifop+hE40LqUb5eKYoCyB3xkHFwlOKA1zlyKhz0A=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; + version = "6.0.36"; + hash = "sha512-YJRtVo8VZ/K6qwuyGHlGrPfqVhBZAZ4fk6+tLNZPREZM3l3EjjcrjWat2QL2WZF71aFioZVQScTzKEMfIjOZlQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.osx-x64"; + version = "6.0.36"; + hash = "sha512-XylVsSjl1387Mz1g23ZUtPWGz/u1YBX2fd2Fldv2B6WteiIIdoLzHOmP+JeBR67WtVSUcEMrTT4NWj7xOr02Ww=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.osx-x64"; + version = "6.0.36"; + hash = "sha512-M6IcgiyppQQ5GUkSwCaOXGh7y9qOugLj+ePi4Ooi4qMqolXB56ciPZ7XJ2HxWsXg9OHmFcOYtu/7mDPGy2uodQ=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetAppHost"; + version = "6.0.36"; + hash = "sha512-GY7b2ozZJe0iiZ7l7qAp4xF09ZUe1Tk6EA35qnIFAEA0X3MjdRM2iU8iM6TZFXEaGycWX2FsydTKmYCGTHwTzQ=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHost"; + version = "6.0.36"; + hash = "sha512-xuLTiyLCUp1xR+4gUhccwCedkFW94n1uQOlnlo9objTXX9GjPxpNik0UJ84zYKOnd5xxWS9zbBWxuoCVZcijBQ=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "6.0.36"; + hash = "sha512-CCVx2PYEhxrrN1SOLc7ls3Vf83zKCm707pSFjiwba/pj39BmRQNjDaLwaSl5s/HeSPnkSZ0Hz9KQpvkTmxUmvg=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "6.0.36"; + hash = "sha512-F0lCmbajEZCsNiYh7+FA3TGJjWwPq9hKWUZfnabKnMNqx8gzh+jeTWLW7t1/ab1jWvO3yhEKMQMQJXMBBfBhsg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.osx-x64"; + version = "6.0.36"; + hash = "sha512-bLfQElXz9BFta1qvXqjviTOeCenMh5S97vsdySMRP/IOMFifop+hE40LqUb5eKYoCyB3xkHFwlOKA1zlyKhz0A=="; + }) ]; win-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-arm64"; version = "6.0.36"; hash = "sha512-oqI1Ilt03mR/4Y4VDNMeYkr5hP3YafBi0h6piSLMXPTCaOgkMHsU6xSpJW5CMTwOCEwREfMZxr22g/meL0uJmg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-arm64"; version = "6.0.36"; hash = "sha512-isiVFlAPxOJDR3pbWTrdfoy7ZbLTmg4YHgg1Vzzo0S3M35mSUU4Ere286J0lrA5s/jAe6JhBSmuvCUELIfvegw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-arm64"; version = "6.0.36"; hash = "sha512-9duYa7xbMuNJG3vsFO+TNLA8Fcvs7OPonbvH812od/ujnfbeoKPsPVPxOcgJhdUbTiRS9AMTLh3R8v491smQ0A=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetAppHost"; version = "6.0.36"; hash = "sha512-2o8Lnw37R8wev0dpNIbdxlyRzCE+0nAeFXdzctGp+C9ieshr8Or6pnF1Yb4/Bscqmue+KjBbVpWqEuHyyRHP9A=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHost"; version = "6.0.36"; hash = "sha512-SxUYXhhM/fGkb08i21KbXT2hyedzb+Mf3wcBmFg4NTteRdbt5KWuUD+DCe9Z6Bbmr50H8T7EgOS/QIW96HZzIA=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "6.0.36"; hash = "sha512-RRKTjZYWik95UGSRROy5BvwfpBYd+gAQi4XQUuc3vi90TQGxrz/OlPjD9bPPZ4Pr8H/PB7Y3bUrfKnmcs8OOJQ=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "6.0.36"; hash = "sha512-SewnE02UhqILbpoLxVkL+FLaCCu+EJ/SmR3DwFhAwFPX+47mPB1tLYW5IBDIcT/jbo9JCQaQ+DWdaW2Ghq7m5w=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-arm64"; + version = "6.0.36"; + hash = "sha512-oqI1Ilt03mR/4Y4VDNMeYkr5hP3YafBi0h6piSLMXPTCaOgkMHsU6xSpJW5CMTwOCEwREfMZxr22g/meL0uJmg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-arm64"; + version = "6.0.36"; + hash = "sha512-isiVFlAPxOJDR3pbWTrdfoy7ZbLTmg4YHgg1Vzzo0S3M35mSUU4Ere286J0lrA5s/jAe6JhBSmuvCUELIfvegw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-arm64"; + version = "6.0.36"; + hash = "sha512-9duYa7xbMuNJG3vsFO+TNLA8Fcvs7OPonbvH812od/ujnfbeoKPsPVPxOcgJhdUbTiRS9AMTLh3R8v491smQ0A=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "6.0.36"; + hash = "sha512-2o8Lnw37R8wev0dpNIbdxlyRzCE+0nAeFXdzctGp+C9ieshr8Or6pnF1Yb4/Bscqmue+KjBbVpWqEuHyyRHP9A=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHost"; + version = "6.0.36"; + hash = "sha512-SxUYXhhM/fGkb08i21KbXT2hyedzb+Mf3wcBmFg4NTteRdbt5KWuUD+DCe9Z6Bbmr50H8T7EgOS/QIW96HZzIA=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "6.0.36"; + hash = "sha512-RRKTjZYWik95UGSRROy5BvwfpBYd+gAQi4XQUuc3vi90TQGxrz/OlPjD9bPPZ4Pr8H/PB7Y3bUrfKnmcs8OOJQ=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "6.0.36"; + hash = "sha512-SewnE02UhqILbpoLxVkL+FLaCCu+EJ/SmR3DwFhAwFPX+47mPB1tLYW5IBDIcT/jbo9JCQaQ+DWdaW2Ghq7m5w=="; + }) ]; win-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-x64"; version = "6.0.36"; hash = "sha512-XS0rzgotxL8fojceQ7zeYlmVRqSqRuP3SMJymXpIS45R8dnlpEooDfjjWRMAvyWkscmAmXQRI4f/UItGsTND5g=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-x64"; version = "6.0.36"; hash = "sha512-Qpsf4A+J0o0VZk/CQ7zvIvUIv6x+g3l2SVko2K33GcMaBj44CTT9giuHIRkTkcc2mQ5t9cFZLMeWiUuBRxoPBg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-x64"; version = "6.0.36"; hash = "sha512-SjnCMVnWxee70G6D0Pkd4ku/hkPgs6z/nK7ivfLSk12fIWb7aMtM3umXjWjDs8f0aBH8MIw+JTDObDpAKsbCKA=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetAppHost"; version = "6.0.36"; hash = "sha512-xEyxlFIb5REDd3hUOmHafhSQh1BlL9WkbZS9FWdeqPQBhA3b22Du7DJCIv0HKjEqYZIM52+bSYZP7xWM0ZAQgg=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetHost"; version = "6.0.36"; hash = "sha512-BUuU3zZPYIofbnQR2NLQvD4sYorgexmMGpr+I0OweCOg07wxjLRR4R6Y5e5FHcsYC43rqLVe9Aef/+8+kcH9nw=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "6.0.36"; hash = "sha512-mgAXyAMIdlx09SyTLILzYHZBKJKpLdhGAsfhftLTkjV7dLqMa1hLeI0L4z5L0Qh45+kySfWirfLCrbXYPCoHbw=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostResolver"; version = "6.0.36"; hash = "sha512-LUx67cKuFJR2rKoTmb/GCwSmSYFX0ZitgjxacIfkZvhcsqOu1Sj1MYNmDiNURK/tA6nAxyYd5oeLZQUd2zQJ4w=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.win-x64"; version = "6.0.36"; hash = "sha512-E9hCzeTTHxb8LxfTRQNcG5rXhlgsSvNDOm1c8oUjJIMG1dJkKs9x47oSQccnbhvAdoMoDUV8xKxohlFjsFPiMg=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-x64"; + version = "6.0.36"; + hash = "sha512-XS0rzgotxL8fojceQ7zeYlmVRqSqRuP3SMJymXpIS45R8dnlpEooDfjjWRMAvyWkscmAmXQRI4f/UItGsTND5g=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-x64"; + version = "6.0.36"; + hash = "sha512-Qpsf4A+J0o0VZk/CQ7zvIvUIv6x+g3l2SVko2K33GcMaBj44CTT9giuHIRkTkcc2mQ5t9cFZLMeWiUuBRxoPBg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-x64"; + version = "6.0.36"; + hash = "sha512-SjnCMVnWxee70G6D0Pkd4ku/hkPgs6z/nK7ivfLSk12fIWb7aMtM3umXjWjDs8f0aBH8MIw+JTDObDpAKsbCKA=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetAppHost"; + version = "6.0.36"; + hash = "sha512-xEyxlFIb5REDd3hUOmHafhSQh1BlL9WkbZS9FWdeqPQBhA3b22Du7DJCIv0HKjEqYZIM52+bSYZP7xWM0ZAQgg=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetHost"; + version = "6.0.36"; + hash = "sha512-BUuU3zZPYIofbnQR2NLQvD4sYorgexmMGpr+I0OweCOg07wxjLRR4R6Y5e5FHcsYC43rqLVe9Aef/+8+kcH9nw=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "6.0.36"; + hash = "sha512-mgAXyAMIdlx09SyTLILzYHZBKJKpLdhGAsfhftLTkjV7dLqMa1hLeI0L4z5L0Qh45+kySfWirfLCrbXYPCoHbw=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "6.0.36"; + hash = "sha512-LUx67cKuFJR2rKoTmb/GCwSmSYFX0ZitgjxacIfkZvhcsqOu1Sj1MYNmDiNURK/tA6nAxyYd5oeLZQUd2zQJ4w=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.win-x64"; + version = "6.0.36"; + hash = "sha512-E9hCzeTTHxb8LxfTRQNcG5rXhlgsSvNDOm1c8oUjJIMG1dJkKs9x47oSQccnbhvAdoMoDUV8xKxohlFjsFPiMg=="; + }) ]; win-x86 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-x86"; version = "6.0.36"; hash = "sha512-YKC7Jv9kh1dVCQkIGfEX4ZVk/DC+6l/X5dtWP2EFDaIJsjVZm9g+BZxL2YuD9rpuKFHevJDqliDtAq95SQxE7A=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-x86"; version = "6.0.36"; hash = "sha512-RnD5u/QM5m9s8eiI6x6b00curwmLWiubt0bp8gEKC94EHDMoziuTRLWws8TObmmqqgXNomVkWgmIFSHdMem21g=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-x86"; version = "6.0.36"; hash = "sha512-ADrfJxNefOr1UwTwblK9R+zbwgj1U79y3DFUemrjfInsM0YW5B1r/bEumz0UDeYmwkRvMbwgtBNyLEGg0d1kwQ=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetAppHost"; version = "6.0.36"; hash = "sha512-cKF0mL4WOq5RnrfKNynpo3Nnjcbq5gz0yJEuJuvJMi9UILvBe1R2YKY4pgsQSMPMkZlukq1pjKQz1R8PLVewuw=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetHost"; version = "6.0.36"; hash = "sha512-dpxFo7/E7fSsPuX9XOvN365fBjwzisqWmpRu8RJC3hT/VBWkwIlmVm/r+xFlPFDvimlSwNFsbSkRLX+1YIcEMA=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostPolicy"; version = "6.0.36"; hash = "sha512-nuzHFGpbwv2owK6F/uJuj0m70BAG1NAj+ANbHyt7VKCktSI1bXLi/Fn6/7xiB7scXLcdMC6ay5cZrAlC6kSUDQ=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostResolver"; version = "6.0.36"; hash = "sha512-6myLyhUePahDenH3ew+QXNkBjBWjIs5vKI34OqGlE6Yqg+MiG9G6WkC/UnNX539C/ymgDapWqmucLUq4zUX2HA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.win-x86"; version = "6.0.36"; hash = "sha512-05QcCR4RZ4ntU+Epf8Pj+6Jk0hPYtOwsw7YE0pn1TsGKA9F2eodaXyhh8Ppyq8nrnI6DqxIiNrVJX+JFPhTfZQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-x86"; + version = "6.0.36"; + hash = "sha512-YKC7Jv9kh1dVCQkIGfEX4ZVk/DC+6l/X5dtWP2EFDaIJsjVZm9g+BZxL2YuD9rpuKFHevJDqliDtAq95SQxE7A=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-x86"; + version = "6.0.36"; + hash = "sha512-RnD5u/QM5m9s8eiI6x6b00curwmLWiubt0bp8gEKC94EHDMoziuTRLWws8TObmmqqgXNomVkWgmIFSHdMem21g=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-x86"; + version = "6.0.36"; + hash = "sha512-ADrfJxNefOr1UwTwblK9R+zbwgj1U79y3DFUemrjfInsM0YW5B1r/bEumz0UDeYmwkRvMbwgtBNyLEGg0d1kwQ=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetAppHost"; + version = "6.0.36"; + hash = "sha512-cKF0mL4WOq5RnrfKNynpo3Nnjcbq5gz0yJEuJuvJMi9UILvBe1R2YKY4pgsQSMPMkZlukq1pjKQz1R8PLVewuw=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetHost"; + version = "6.0.36"; + hash = "sha512-dpxFo7/E7fSsPuX9XOvN365fBjwzisqWmpRu8RJC3hT/VBWkwIlmVm/r+xFlPFDvimlSwNFsbSkRLX+1YIcEMA=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostPolicy"; + version = "6.0.36"; + hash = "sha512-nuzHFGpbwv2owK6F/uJuj0m70BAG1NAj+ANbHyt7VKCktSI1bXLi/Fn6/7xiB7scXLcdMC6ay5cZrAlC6kSUDQ=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostResolver"; + version = "6.0.36"; + hash = "sha512-6myLyhUePahDenH3ew+QXNkBjBWjIs5vKI34OqGlE6Yqg+MiG9G6WkC/UnNX539C/ymgDapWqmucLUq4zUX2HA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.win-x86"; + version = "6.0.36"; + hash = "sha512-05QcCR4RZ4ntU+Epf8Pj+6Jk0hPYtOwsw7YE0pn1TsGKA9F2eodaXyhh8Ppyq8nrnI6DqxIiNrVJX+JFPhTfZQ=="; + }) ]; }; -in rec { +in +rec { release_6_0 = "6.0.36"; aspnetcore_6_0 = buildAspNetCore { diff --git a/pkgs/development/compilers/dotnet/versions/7.0.nix b/pkgs/development/compilers/dotnet/versions/7.0.nix index 3ab08496f8ae90..2b3f6dfff45708 100644 --- a/pkgs/development/compilers/dotnet/versions/7.0.nix +++ b/pkgs/development/compilers/dotnet/versions/7.0.nix @@ -1,172 +1,618 @@ -{ buildAspNetCore, buildNetRuntime, buildNetSdk, fetchNupkg }: +{ + buildAspNetCore, + buildNetRuntime, + buildNetSdk, + fetchNupkg, +}: # v7.0 (eol) let commonPackages = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Ref"; version = "7.0.20"; hash = "sha512-ySX6TZFi1eSJj3c3JIroCLzHbZkLmr+fgeQ78AUYsOUhjKKw7qliqRoMKx9Uqc/qMMkyRpSBcwfJ7X7vWYbPeQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetAppHost"; version = "7.0.20"; hash = "sha512-zIPVUsCfS9EbdvNxJ0tkV7Insj7CTpIMA+ILK9y6Tr7qqG56sgMIW+0KOJg/UPlWH/2epqsIhMWoBZWt8bZtuA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Ref"; version = "7.0.20"; hash = "sha512-dk6z/ZqMpZ4lxVisgnPX1H+MwiUTRQHhwq3e9VMSIRL5loVdqHlZ9fRFfAejEz3U8EbvGV43Vp3OwF5R7mlTTw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetHost"; version = "7.0.20"; hash = "sha512-H4RtRdwUQpBk7tJFT3C/c9WNGGdAVDq9S3Mz6qYP5Sasov7NPcR2rkoTNIoo4jTt3p26vsNcb5lAiQBBptaveA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetHostPolicy"; version = "7.0.20"; hash = "sha512-puv59sewO3+HudFk/Fpt8x3IJuEDk5TvTSJdn/EM00P8j5AmA3WyjHA1bSSUOuyGwjxPDe9t5iYoaYDysa97mw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetHostResolver"; version = "7.0.20"; hash = "sha512-7xdJGNmwiuEV8vRizwuX34ETFRuxNZZk4t+o8JmGrGDecZ1JNgzip8CUz44/AYaLztUdXv3O7xZB7OQO8AO5Kg=="; }) - (fetchNupkg { pname = "Microsoft.DotNet.ILCompiler"; version = "7.0.20"; hash = "sha512-4WZbJ4WKpN7BzXKIQhzNz3Srp3zhDHiv98SFGQlAzFiYp+viQ6nzD4jzax9yOkx6mDCuOsJfscEq2U/pXL+2dw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Ref"; + version = "7.0.20"; + hash = "sha512-ySX6TZFi1eSJj3c3JIroCLzHbZkLmr+fgeQ78AUYsOUhjKKw7qliqRoMKx9Uqc/qMMkyRpSBcwfJ7X7vWYbPeQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetAppHost"; + version = "7.0.20"; + hash = "sha512-zIPVUsCfS9EbdvNxJ0tkV7Insj7CTpIMA+ILK9y6Tr7qqG56sgMIW+0KOJg/UPlWH/2epqsIhMWoBZWt8bZtuA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Ref"; + version = "7.0.20"; + hash = "sha512-dk6z/ZqMpZ4lxVisgnPX1H+MwiUTRQHhwq3e9VMSIRL5loVdqHlZ9fRFfAejEz3U8EbvGV43Vp3OwF5R7mlTTw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetHost"; + version = "7.0.20"; + hash = "sha512-H4RtRdwUQpBk7tJFT3C/c9WNGGdAVDq9S3Mz6qYP5Sasov7NPcR2rkoTNIoo4jTt3p26vsNcb5lAiQBBptaveA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetHostPolicy"; + version = "7.0.20"; + hash = "sha512-puv59sewO3+HudFk/Fpt8x3IJuEDk5TvTSJdn/EM00P8j5AmA3WyjHA1bSSUOuyGwjxPDe9t5iYoaYDysa97mw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetHostResolver"; + version = "7.0.20"; + hash = "sha512-7xdJGNmwiuEV8vRizwuX34ETFRuxNZZk4t+o8JmGrGDecZ1JNgzip8CUz44/AYaLztUdXv3O7xZB7OQO8AO5Kg=="; + }) + (fetchNupkg { + pname = "Microsoft.DotNet.ILCompiler"; + version = "7.0.20"; + hash = "sha512-4WZbJ4WKpN7BzXKIQhzNz3Srp3zhDHiv98SFGQlAzFiYp+viQ6nzD4jzax9yOkx6mDCuOsJfscEq2U/pXL+2dw=="; + }) ]; hostPackages = { linux-arm = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-arm"; version = "7.0.20"; hash = "sha512-GJMG2UNQPuSxxStN/x1Seee4JUXwhYmn4h6/dV7xuCg7zexC6S350W5GEBqKc1kU92rD2oV75UdUkqZGimU4ug=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-arm"; + version = "7.0.20"; + hash = "sha512-GJMG2UNQPuSxxStN/x1Seee4JUXwhYmn4h6/dV7xuCg7zexC6S350W5GEBqKc1kU92rD2oV75UdUkqZGimU4ug=="; + }) ]; linux-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-arm64"; version = "7.0.20"; hash = "sha512-hR6BQ19osMSIzMMaBC/XF9VU4yKhjjAwEp9nEBwNmOrAQfkVRwG5Td+gLhRiOMW0pY5/GjXLlwziiFQ2ksZqaQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.DotNet.ILCompiler"; version = "7.0.20"; hash = "sha512-oGiO7TutJZb4JVoPyqGLMaDQ9oWMYg6rp+dughnnNhD4bU3xy189hWfxfMYTHZbct2vlPbSX1OlTCkhjENgpww=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-arm64"; + version = "7.0.20"; + hash = "sha512-hR6BQ19osMSIzMMaBC/XF9VU4yKhjjAwEp9nEBwNmOrAQfkVRwG5Td+gLhRiOMW0pY5/GjXLlwziiFQ2ksZqaQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.DotNet.ILCompiler"; + version = "7.0.20"; + hash = "sha512-oGiO7TutJZb4JVoPyqGLMaDQ9oWMYg6rp+dughnnNhD4bU3xy189hWfxfMYTHZbct2vlPbSX1OlTCkhjENgpww=="; + }) ]; linux-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-x64"; version = "7.0.20"; hash = "sha512-Ydi2yUhYl//LrXMYWtr4YKxwbz/M+qNI4VJG1zgLRBBu2ZLvHULKOMMtiUJYYHV692jbkENGGFUUu3E6JiCrYQ=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.DotNet.ILCompiler"; version = "7.0.20"; hash = "sha512-sOSigEu2JZ8SuVT/34zUHiw0xiDxjsX+pRvbvXa8aXWAJwfy/CFOow2S7wD6foZA/WCg0wPeaV3ny8vWE8Nt1g=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-x64"; + version = "7.0.20"; + hash = "sha512-Ydi2yUhYl//LrXMYWtr4YKxwbz/M+qNI4VJG1zgLRBBu2ZLvHULKOMMtiUJYYHV692jbkENGGFUUu3E6JiCrYQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.DotNet.ILCompiler"; + version = "7.0.20"; + hash = "sha512-sOSigEu2JZ8SuVT/34zUHiw0xiDxjsX+pRvbvXa8aXWAJwfy/CFOow2S7wD6foZA/WCg0wPeaV3ny8vWE8Nt1g=="; + }) ]; linux-musl-arm = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm"; version = "7.0.20"; hash = "sha512-s1fmr6tneGoM1Kx6Bd3ZXHpCBP5L24uZStqZpstEamz9SLzWAYouDgclk2hS1vrxkTEbM3tzHUtMPzBGaB0FWg=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm"; + version = "7.0.20"; + hash = "sha512-s1fmr6tneGoM1Kx6Bd3ZXHpCBP5L24uZStqZpstEamz9SLzWAYouDgclk2hS1vrxkTEbM3tzHUtMPzBGaB0FWg=="; + }) ]; linux-musl-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm64"; version = "7.0.20"; hash = "sha512-O1I5IR+Bn3zADNEc3H6mG48hW934vx6qDb09UlBVuDHlOjkQorm99IEktZZNaWxcuOqhtEi8+1eIAVmyBy3maw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.DotNet.ILCompiler"; version = "7.0.20"; hash = "sha512-Cf37Af+mBJseV7N6gV1mVPVu5ldPF9jkQUsu+EZNwDCrzKLslkQz06E3UiEIM3LHWh/TtIYZe393Y7M7OwKUQA=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm64"; + version = "7.0.20"; + hash = "sha512-O1I5IR+Bn3zADNEc3H6mG48hW934vx6qDb09UlBVuDHlOjkQorm99IEktZZNaWxcuOqhtEi8+1eIAVmyBy3maw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.DotNet.ILCompiler"; + version = "7.0.20"; + hash = "sha512-Cf37Af+mBJseV7N6gV1mVPVu5ldPF9jkQUsu+EZNwDCrzKLslkQz06E3UiEIM3LHWh/TtIYZe393Y7M7OwKUQA=="; + }) ]; linux-musl-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-x64"; version = "7.0.20"; hash = "sha512-3yOYRm4dt6x8CM9xQ153CVLQc/f5tWJSKs6t/Shq9Q8E4kE0S1hYP3i90zorOlrvwHO08wcb8pxYOo2l6PPYxw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.DotNet.ILCompiler"; version = "7.0.20"; hash = "sha512-GYaw401lDpfW87lbZzoLiZmEG+WjCXnxkEfFi4Gs8+5YHZBAxJLV67r4ifCGt0n/TdXbxDZbZCXBT/lLzij8Pg=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-x64"; + version = "7.0.20"; + hash = "sha512-3yOYRm4dt6x8CM9xQ153CVLQc/f5tWJSKs6t/Shq9Q8E4kE0S1hYP3i90zorOlrvwHO08wcb8pxYOo2l6PPYxw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.DotNet.ILCompiler"; + version = "7.0.20"; + hash = "sha512-GYaw401lDpfW87lbZzoLiZmEG+WjCXnxkEfFi4Gs8+5YHZBAxJLV67r4ifCGt0n/TdXbxDZbZCXBT/lLzij8Pg=="; + }) ]; osx-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.osx-arm64"; version = "7.0.20"; hash = "sha512-Qzruh84k89DwZQaHiIrK5WqRD+ScoNGbX0xvG1d5OPO0fnJod/nmPhdYo/9AXobTpY9WYpfEVTcGGMjGncwfMg=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.osx-arm64"; + version = "7.0.20"; + hash = "sha512-Qzruh84k89DwZQaHiIrK5WqRD+ScoNGbX0xvG1d5OPO0fnJod/nmPhdYo/9AXobTpY9WYpfEVTcGGMjGncwfMg=="; + }) ]; osx-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.osx-x64"; version = "7.0.20"; hash = "sha512-H2xNMKpVvdUDRDGnEecDq84wPWhhjL+ls4W6QUOGwp6hoSMDOIXqUMPKm7gYlO4O0VCy93DYXx5aRXf9tVMVlA=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.DotNet.ILCompiler"; version = "7.0.20"; hash = "sha512-sa86jqaVkMxX80lCyNczLAs7MlIp6ZEba7kdWL3WUviPzfG38NT+KGuG4ruV0NEQZSIlrCrQzeu6iHhirIhDhA=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.osx-x64"; + version = "7.0.20"; + hash = "sha512-H2xNMKpVvdUDRDGnEecDq84wPWhhjL+ls4W6QUOGwp6hoSMDOIXqUMPKm7gYlO4O0VCy93DYXx5aRXf9tVMVlA=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.DotNet.ILCompiler"; + version = "7.0.20"; + hash = "sha512-sa86jqaVkMxX80lCyNczLAs7MlIp6ZEba7kdWL3WUviPzfG38NT+KGuG4ruV0NEQZSIlrCrQzeu6iHhirIhDhA=="; + }) ]; win-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-arm64"; version = "7.0.20"; hash = "sha512-jbKk+MEWwNJ4l/ueJ8xoc/WOAnYawTohaMuRI67dMMldbsFMjtjNJXBqANioRgEJ/6648fiysvgat39io0KlBQ=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.DotNet.ILCompiler"; version = "7.0.20"; hash = "sha512-38BRd1Vma9n8ggDVTJOVgJwNvLhnwvy3fOgdeLeDtwtEZ1QhE+CAgQwzuH6VNi8H10WGCP9D18f1+dw+/Wegnw=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-arm64"; + version = "7.0.20"; + hash = "sha512-jbKk+MEWwNJ4l/ueJ8xoc/WOAnYawTohaMuRI67dMMldbsFMjtjNJXBqANioRgEJ/6648fiysvgat39io0KlBQ=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.DotNet.ILCompiler"; + version = "7.0.20"; + hash = "sha512-38BRd1Vma9n8ggDVTJOVgJwNvLhnwvy3fOgdeLeDtwtEZ1QhE+CAgQwzuH6VNi8H10WGCP9D18f1+dw+/Wegnw=="; + }) ]; win-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-x64"; version = "7.0.20"; hash = "sha512-3xM+swE86Z5Adp4LM+CeadMROSgoCdQ3i+aiiwKv5JwXESeN/1cFQgIJjuXtZAmSeaop3eu64Om1+poD2YtWbA=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.DotNet.ILCompiler"; version = "7.0.20"; hash = "sha512-aoVzNoDMrYlaBnBqsdXzpHFgzPR88j5foFnqa9w2VWyeQqqSxvBv7PCOc7yWSU+2yr5tIIr4fa1h8Ahn4+9uZQ=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-x64"; + version = "7.0.20"; + hash = "sha512-3xM+swE86Z5Adp4LM+CeadMROSgoCdQ3i+aiiwKv5JwXESeN/1cFQgIJjuXtZAmSeaop3eu64Om1+poD2YtWbA=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.DotNet.ILCompiler"; + version = "7.0.20"; + hash = "sha512-aoVzNoDMrYlaBnBqsdXzpHFgzPR88j5foFnqa9w2VWyeQqqSxvBv7PCOc7yWSU+2yr5tIIr4fa1h8Ahn4+9uZQ=="; + }) ]; win-x86 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-x86"; version = "7.0.20"; hash = "sha512-/ikA96hY3FQhOkrO7lcWmlry8e2Dq0gvDMSJ5M8A7lFFTshHL8+maXxitWXb/JGRWmA2F7s8NlIkUZOXmblV3Q=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-x86"; + version = "7.0.20"; + hash = "sha512-/ikA96hY3FQhOkrO7lcWmlry8e2Dq0gvDMSJ5M8A7lFFTshHL8+maXxitWXb/JGRWmA2F7s8NlIkUZOXmblV3Q=="; + }) ]; }; targetPackages = { linux-arm = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm"; version = "7.0.20"; hash = "sha512-XHwBlrABxZA5+Fny0zs0gQa8OLHqWU2dCT5gtj0B3O9B5696yiH0WjSu4Af1cf9q9zBTfVOPkVh4h5etf3VUOg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-arm"; version = "7.0.20"; hash = "sha512-c+P8/CGPeinx/ch69USopX0t4nux/JvSExuJzhlcgNoraYWJd+qfR44qZN0gdYBKIwCPem/xATze8FwxKcG4cQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-arm"; version = "7.0.20"; hash = "sha512-y9Egnw0qVXdKRNOPKZ0amu0B0ojk95f838nEmt0A0jGyTXHHo5uXCK+DOGH7pCbeiaaZifWo5Va8CtDXSH64Qg=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetAppHost"; version = "7.0.20"; hash = "sha512-XhbUBpTDP+MVdtwLWCcTRJlhuJBHQYMvDpBAt5TvSlkZgUNeTnGTKGRjaehrA9refSi440eYlR20fDONE3RcGg=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHost"; version = "7.0.20"; hash = "sha512-oRBtuytqfo8feMpWAIajol/mp0Q5clXtccQ5YiGDOvhf/OKzDquVKuLWXnoLUBPrz3wdJyfcPa/hGZZjbexKWQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostPolicy"; version = "7.0.20"; hash = "sha512-m7921DXQMDfqRICavvcOYnH+LEAS3JqE6+jOlI9lST624PLO8oWac0GrljwKkhA2QPPjNZEw8+QtACkiJ0KnYQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostResolver"; version = "7.0.20"; hash = "sha512-JL9ppjzSerw1dmYJ1SDJ92Hfbg6G/kBRFZ3r0H+JMo0fjE03TSPmmMRPNbeaWbqeBLEOsoD9CnvVg6djdOEvTA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm"; version = "7.0.20"; hash = "sha512-V6EHnxIh8o/MG/VEtWYF5yKGB4ZoXZsgMg9oSfummwThV/qP4vclU68HtoINgpJsjl01/D6q2e9eccElLCPt0A=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm"; + version = "7.0.20"; + hash = "sha512-XHwBlrABxZA5+Fny0zs0gQa8OLHqWU2dCT5gtj0B3O9B5696yiH0WjSu4Af1cf9q9zBTfVOPkVh4h5etf3VUOg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-arm"; + version = "7.0.20"; + hash = "sha512-c+P8/CGPeinx/ch69USopX0t4nux/JvSExuJzhlcgNoraYWJd+qfR44qZN0gdYBKIwCPem/xATze8FwxKcG4cQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-arm"; + version = "7.0.20"; + hash = "sha512-y9Egnw0qVXdKRNOPKZ0amu0B0ojk95f838nEmt0A0jGyTXHHo5uXCK+DOGH7pCbeiaaZifWo5Va8CtDXSH64Qg=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetAppHost"; + version = "7.0.20"; + hash = "sha512-XhbUBpTDP+MVdtwLWCcTRJlhuJBHQYMvDpBAt5TvSlkZgUNeTnGTKGRjaehrA9refSi440eYlR20fDONE3RcGg=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHost"; + version = "7.0.20"; + hash = "sha512-oRBtuytqfo8feMpWAIajol/mp0Q5clXtccQ5YiGDOvhf/OKzDquVKuLWXnoLUBPrz3wdJyfcPa/hGZZjbexKWQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostPolicy"; + version = "7.0.20"; + hash = "sha512-m7921DXQMDfqRICavvcOYnH+LEAS3JqE6+jOlI9lST624PLO8oWac0GrljwKkhA2QPPjNZEw8+QtACkiJ0KnYQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostResolver"; + version = "7.0.20"; + hash = "sha512-JL9ppjzSerw1dmYJ1SDJ92Hfbg6G/kBRFZ3r0H+JMo0fjE03TSPmmMRPNbeaWbqeBLEOsoD9CnvVg6djdOEvTA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm"; + version = "7.0.20"; + hash = "sha512-V6EHnxIh8o/MG/VEtWYF5yKGB4ZoXZsgMg9oSfummwThV/qP4vclU68HtoINgpJsjl01/D6q2e9eccElLCPt0A=="; + }) ]; linux-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; version = "7.0.20"; hash = "sha512-7alEgdaS+JmhsfvgZWcOGEOWfL20TFShwkbpbRtiyXjXzMV6JHVER8s3n+tV+Bep85ME+FRwZh21YK+Nx33aZg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-arm64"; version = "7.0.20"; hash = "sha512-a+SvJNNVQMGWbTKKmDRS4Dc83WzP4REEk2doI3UjEMkFdsLbEm2Lep3vCUpb7mkkFvjYPMiFqNiNG6OGTuVaVA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; version = "7.0.20"; hash = "sha512-gxR7jFMvYM0IDe77zAE9OnCveUM5eW2poCOayo88FD82f//4/BK6sHY/gked0cu5cUMhygTmXEwr3klKrRnxgA=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; version = "7.0.20"; hash = "sha512-4q9Mo/KPoOkeX2gvUbgIR5Oyo+YCozXFd0rLk1+uJrZabBrzyxqs1Wdx9Iya2KrM4b5X+rSqjEZcLPZ2h2KpEQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHost"; version = "7.0.20"; hash = "sha512-wB7JHQS6vd0aRwFVsLGwzjMs4n6nmt/Z5EhmESdrOoFAtRm0e3UI8nerzUa+JGInlCrZ5RT+1VAtwNNoUJ1yEg=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "7.0.20"; hash = "sha512-krhZ6dclekB1enWxYcCeboGgk2yaJEBV5Cn5thj6Lv6KTMfpcqkIJobtAxcb6eg8qJVqRTN0DebTedR4lSFQKw=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "7.0.20"; hash = "sha512-2gAdw0/KO7sqhe4B5bcs++sJQhv5DlNK8QFXehXVjd3P8u2wse8nSuquN9iYi/P3ztnFaJAi5yJvzNEwF+fRQw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm64"; version = "7.0.20"; hash = "sha512-s3xEcytFnFKyBXUWrh5GehbZ/kG5thQKn9Q6J1iNaigIEzxbaNO5vrtPSb0patwnrsltzHC7e1ETrkY6E9/jGA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; + version = "7.0.20"; + hash = "sha512-7alEgdaS+JmhsfvgZWcOGEOWfL20TFShwkbpbRtiyXjXzMV6JHVER8s3n+tV+Bep85ME+FRwZh21YK+Nx33aZg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-arm64"; + version = "7.0.20"; + hash = "sha512-a+SvJNNVQMGWbTKKmDRS4Dc83WzP4REEk2doI3UjEMkFdsLbEm2Lep3vCUpb7mkkFvjYPMiFqNiNG6OGTuVaVA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; + version = "7.0.20"; + hash = "sha512-gxR7jFMvYM0IDe77zAE9OnCveUM5eW2poCOayo88FD82f//4/BK6sHY/gked0cu5cUMhygTmXEwr3klKrRnxgA=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "7.0.20"; + hash = "sha512-4q9Mo/KPoOkeX2gvUbgIR5Oyo+YCozXFd0rLk1+uJrZabBrzyxqs1Wdx9Iya2KrM4b5X+rSqjEZcLPZ2h2KpEQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHost"; + version = "7.0.20"; + hash = "sha512-wB7JHQS6vd0aRwFVsLGwzjMs4n6nmt/Z5EhmESdrOoFAtRm0e3UI8nerzUa+JGInlCrZ5RT+1VAtwNNoUJ1yEg=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "7.0.20"; + hash = "sha512-krhZ6dclekB1enWxYcCeboGgk2yaJEBV5Cn5thj6Lv6KTMfpcqkIJobtAxcb6eg8qJVqRTN0DebTedR4lSFQKw=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "7.0.20"; + hash = "sha512-2gAdw0/KO7sqhe4B5bcs++sJQhv5DlNK8QFXehXVjd3P8u2wse8nSuquN9iYi/P3ztnFaJAi5yJvzNEwF+fRQw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm64"; + version = "7.0.20"; + hash = "sha512-s3xEcytFnFKyBXUWrh5GehbZ/kG5thQKn9Q6J1iNaigIEzxbaNO5vrtPSb0patwnrsltzHC7e1ETrkY6E9/jGA=="; + }) ]; linux-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; version = "7.0.20"; hash = "sha512-DC+IasSvYfnFkrcT3gnq08t0iVKmIPmxEFrvITw3qdwH9Y5kz9ZEI4xgcQBIbrzUcE+z/5rwWVhATcxNHgaAWw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-x64"; version = "7.0.20"; hash = "sha512-abPlEkse/tu8w/F9YPG7fzIP+NbtfhfBrkTjCgnRUnL+HXRkn7ysrUQJ63zWlhVYWilzwTAmUlnjqBsZ+Psnzg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-x64"; version = "7.0.20"; hash = "sha512-swLcwMoZuUvAWukwmEbjr+YXYtRyeDR/hiYALZ5SVFjtyfS/FSE3IY/xbVtkEyfMFPEcRdErlDVYcJEEq0kPaQ=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; version = "7.0.20"; hash = "sha512-6VO37nmADf3894eVUQDS2rK2+pNC2QMgWaeVrKL4iKexXDPqa8NC+Qy+FeU2j0Ugp3+V13WFrl1+MXDXIDflcg=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHost"; version = "7.0.20"; hash = "sha512-HMRw00L72Ey4bWder1PBZ9VePtd4pJThOMv2bobZrnwzav5s3dlgGjxYc1xxbhmUq0vRZVJrjNkjcM0sAVxIeA=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "7.0.20"; hash = "sha512-1CHk19oIgLW9RKP3LX8M7SoMhdYVsQP7nnA5iuKryGeBPvpGsxGcuB50nzQgUc++PfKfKS9CNPfVGrwKhGGo6g=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostResolver"; version = "7.0.20"; hash = "sha512-lKM4wOtXytPXxf6kQ+68Xmp2WNddKsnJw40MPuWgSYki2SnTccCaP/jI2s+9A78wqx2ycoSOhMTXM37Ee8v6wA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-x64"; version = "7.0.20"; hash = "sha512-Co4sV6mPzPF3nh5YFe5RMDmcW7x2nluyN9hAP5zBd4w0lmyeLRxc4BxUH6aq+vgtOjjoS96nV2p2c+zS/MSiZw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; + version = "7.0.20"; + hash = "sha512-DC+IasSvYfnFkrcT3gnq08t0iVKmIPmxEFrvITw3qdwH9Y5kz9ZEI4xgcQBIbrzUcE+z/5rwWVhATcxNHgaAWw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-x64"; + version = "7.0.20"; + hash = "sha512-abPlEkse/tu8w/F9YPG7fzIP+NbtfhfBrkTjCgnRUnL+HXRkn7ysrUQJ63zWlhVYWilzwTAmUlnjqBsZ+Psnzg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-x64"; + version = "7.0.20"; + hash = "sha512-swLcwMoZuUvAWukwmEbjr+YXYtRyeDR/hiYALZ5SVFjtyfS/FSE3IY/xbVtkEyfMFPEcRdErlDVYcJEEq0kPaQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; + version = "7.0.20"; + hash = "sha512-6VO37nmADf3894eVUQDS2rK2+pNC2QMgWaeVrKL4iKexXDPqa8NC+Qy+FeU2j0Ugp3+V13WFrl1+MXDXIDflcg=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHost"; + version = "7.0.20"; + hash = "sha512-HMRw00L72Ey4bWder1PBZ9VePtd4pJThOMv2bobZrnwzav5s3dlgGjxYc1xxbhmUq0vRZVJrjNkjcM0sAVxIeA=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "7.0.20"; + hash = "sha512-1CHk19oIgLW9RKP3LX8M7SoMhdYVsQP7nnA5iuKryGeBPvpGsxGcuB50nzQgUc++PfKfKS9CNPfVGrwKhGGo6g=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "7.0.20"; + hash = "sha512-lKM4wOtXytPXxf6kQ+68Xmp2WNddKsnJw40MPuWgSYki2SnTccCaP/jI2s+9A78wqx2ycoSOhMTXM37Ee8v6wA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-x64"; + version = "7.0.20"; + hash = "sha512-Co4sV6mPzPF3nh5YFe5RMDmcW7x2nluyN9hAP5zBd4w0lmyeLRxc4BxUH6aq+vgtOjjoS96nV2p2c+zS/MSiZw=="; + }) ]; linux-musl-arm = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm"; version = "7.0.20"; hash = "sha512-MEK4A+6U5zcx4iE+D6iBWHoIX/kJSSUXlXMeWNfMrE8kz2y0Rzck5/zeIXyj39vPCJmuNgmkNqJ0Bd98k94sfg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-arm"; version = "7.0.20"; hash = "sha512-vLWNiWcEUx2WSIcM5U5kHDzxm+ITpE746cIzFc0IXY2UgLac2MNEMxmyNC+kI6rXYGwUEJwygIjZhugGanvDsA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm"; version = "7.0.20"; hash = "sha512-U0enhz5LmGi8FK4Zue36ikxFnoUeBM9nH3ZUmrnyWSYT9m5+wp8Bd8I6ubebW1j8K5d744I9b5oUnNWeGLVkow=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetAppHost"; version = "7.0.20"; hash = "sha512-+mXIZIE4bpGkhlJjBKKCBIm3dJzP4n4LXpsT5Kz3WuasxdNhJ5TVVthIuLz6KKoWEpuRyplrf/rJp0RU8FqmdA=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHost"; version = "7.0.20"; hash = "sha512-ywvN5Qmbl94w5ZEAllIpzfHbKLdrjDz626vnr1gaocQNE3BQOi2gt8v3KgOGxevGLrQOocJ+zb1U8GYmxl/g/Q=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostPolicy"; version = "7.0.20"; hash = "sha512-5HVoAWI+7YnneMvF5n62Hp0V45YKONOvHInBQ6gw9TP89Ykf1gjwEE6zQHlpu8+lX1qcTfqWu1iC/GOoo3BshA=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostResolver"; version = "7.0.20"; hash = "sha512-Ji7Q25uFyIEAk8/+4sOmPFDa1UQmnM9bv8ROtH91vyPCZ/RHxU7qo9APSqQAkkK64jHVIDe+BSM2jlowvoGMEg=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm"; + version = "7.0.20"; + hash = "sha512-MEK4A+6U5zcx4iE+D6iBWHoIX/kJSSUXlXMeWNfMrE8kz2y0Rzck5/zeIXyj39vPCJmuNgmkNqJ0Bd98k94sfg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-arm"; + version = "7.0.20"; + hash = "sha512-vLWNiWcEUx2WSIcM5U5kHDzxm+ITpE746cIzFc0IXY2UgLac2MNEMxmyNC+kI6rXYGwUEJwygIjZhugGanvDsA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm"; + version = "7.0.20"; + hash = "sha512-U0enhz5LmGi8FK4Zue36ikxFnoUeBM9nH3ZUmrnyWSYT9m5+wp8Bd8I6ubebW1j8K5d744I9b5oUnNWeGLVkow=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetAppHost"; + version = "7.0.20"; + hash = "sha512-+mXIZIE4bpGkhlJjBKKCBIm3dJzP4n4LXpsT5Kz3WuasxdNhJ5TVVthIuLz6KKoWEpuRyplrf/rJp0RU8FqmdA=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHost"; + version = "7.0.20"; + hash = "sha512-ywvN5Qmbl94w5ZEAllIpzfHbKLdrjDz626vnr1gaocQNE3BQOi2gt8v3KgOGxevGLrQOocJ+zb1U8GYmxl/g/Q=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostPolicy"; + version = "7.0.20"; + hash = "sha512-5HVoAWI+7YnneMvF5n62Hp0V45YKONOvHInBQ6gw9TP89Ykf1gjwEE6zQHlpu8+lX1qcTfqWu1iC/GOoo3BshA=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostResolver"; + version = "7.0.20"; + hash = "sha512-Ji7Q25uFyIEAk8/+4sOmPFDa1UQmnM9bv8ROtH91vyPCZ/RHxU7qo9APSqQAkkK64jHVIDe+BSM2jlowvoGMEg=="; + }) ]; linux-musl-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm64"; version = "7.0.20"; hash = "sha512-/Ht9KgYt/xsW8cgzCbvFjsjGElx24r55BVGsrQSA6VLJMRvrZLwU6lLFuY1x0CfF5ALs0Uva/jCxTtt+zggaYA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-arm64"; version = "7.0.20"; hash = "sha512-bCcmlaXLBmlScQ/HXkkLf1DYQtOjqet/dI8y2sNx1hu89BwEQc28inzi24PZ9GjYo3KyKvy7U17aldK8b2uYAw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm64"; version = "7.0.20"; hash = "sha512-4Ok+e3bc2OJ2YisrmLCMFXKZ/WD5Gyxchryl5clC4s2w2ci/kiDnKI83WL1ibNvEk5wIDRsrCQ5KXA7vYn8wyw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetAppHost"; version = "7.0.20"; hash = "sha512-itRU+NUtQU4Oe1o11E4jRkbR/DWYKn6XK52n3f50WyblkBk/wCj6C3fxZ6mMbXqcJhARy5p8X2Zs5sFJJmv43A=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHost"; version = "7.0.20"; hash = "sha512-IztYZXvLb2W4eC9foR4RFkGujR/LUdDx4UEh1Dab4ImDGj4qO4eZ7OnVCYUONTudFpLGakcQj7Faaq8rA0ye5g=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "7.0.20"; hash = "sha512-DfsYyPXF4XSnyvxsoPUsKc4S2hM3c11WxUGMJJoxuD/5AaMcaAvhkObqxXSfTXhUPHj4Jat7CxIqPMQatVLTcw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "7.0.20"; hash = "sha512-/aMTfk42LwVNm6HxNk8ZR6yPPjIyDdNH5/zWs6uHdGL9/9U9Tx2P0ZaKmk9azt5NwDtWZqMpqyDVDb1HJbxyIg=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm64"; + version = "7.0.20"; + hash = "sha512-/Ht9KgYt/xsW8cgzCbvFjsjGElx24r55BVGsrQSA6VLJMRvrZLwU6lLFuY1x0CfF5ALs0Uva/jCxTtt+zggaYA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-arm64"; + version = "7.0.20"; + hash = "sha512-bCcmlaXLBmlScQ/HXkkLf1DYQtOjqet/dI8y2sNx1hu89BwEQc28inzi24PZ9GjYo3KyKvy7U17aldK8b2uYAw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm64"; + version = "7.0.20"; + hash = "sha512-4Ok+e3bc2OJ2YisrmLCMFXKZ/WD5Gyxchryl5clC4s2w2ci/kiDnKI83WL1ibNvEk5wIDRsrCQ5KXA7vYn8wyw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "7.0.20"; + hash = "sha512-itRU+NUtQU4Oe1o11E4jRkbR/DWYKn6XK52n3f50WyblkBk/wCj6C3fxZ6mMbXqcJhARy5p8X2Zs5sFJJmv43A=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHost"; + version = "7.0.20"; + hash = "sha512-IztYZXvLb2W4eC9foR4RFkGujR/LUdDx4UEh1Dab4ImDGj4qO4eZ7OnVCYUONTudFpLGakcQj7Faaq8rA0ye5g=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "7.0.20"; + hash = "sha512-DfsYyPXF4XSnyvxsoPUsKc4S2hM3c11WxUGMJJoxuD/5AaMcaAvhkObqxXSfTXhUPHj4Jat7CxIqPMQatVLTcw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "7.0.20"; + hash = "sha512-/aMTfk42LwVNm6HxNk8ZR6yPPjIyDdNH5/zWs6uHdGL9/9U9Tx2P0ZaKmk9azt5NwDtWZqMpqyDVDb1HJbxyIg=="; + }) ]; linux-musl-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-x64"; version = "7.0.20"; hash = "sha512-wh25bBNZosflPj2pcbIMB/fttuSFCvWn4N8XmDYd6XA91RpRk4GkZx505PmC+kpfU2FgM0N4zWgqnjcrifp6Ng=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-x64"; version = "7.0.20"; hash = "sha512-9k+5qHlL2/uiC5/crfn+Shv/93FV1E9oLFFK6nAs+/tUXL0olwsqpyEMUAdKdAoCgiTv50GnBjX/7jlp9bMmlg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-x64"; version = "7.0.20"; hash = "sha512-J/bFX9ai9i8S0ux0ZdnBhN+s+IFLosIBgnFvTBHuNfblPQ6R1YFsfYww5LQFI+plL8A2NcIdnBxLACrN22jwNQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetAppHost"; version = "7.0.20"; hash = "sha512-IAhdRGfxbYD1lF51SqBfDWIEvsysVWLPWELOpYPyY1CvmTPlGBh5QNanw2TLPu29eKb8k/peSVHJSOLKL8EF0w=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHost"; version = "7.0.20"; hash = "sha512-LuFx7q7tmDBcHce9C460IbL6Dp78jqsxUvSUC00XfB0D4uFhBVroWhHv4BPfFQ+cU3+/XEAOgW+H388kXuwEEA=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "7.0.20"; hash = "sha512-TexO+i9DBf7QLW+JVnraEDFa3/7szqJWq5jLOskvEUBn/jrC7rLodIBr9Xm9qYeyPy2K6b31oXmVlGkPplX8PQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostResolver"; version = "7.0.20"; hash = "sha512-Y2Jlv9Eq2tk2V7cyHW2uqVDxFlDFwANAtp0Ue3b1zxIOmI51bnXOh5d5Pjd8MYqNOsEF+Vq2xD1Sk79T/iiQZg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-musl-x64"; version = "7.0.20"; hash = "sha512-wIQ8KfpMjg7QOZapQ8FvJeqgzI8iyyvvdlBoibsQeuYJP9p7jc9O2BmDBolbn9fgdtKfyCIiwY2vf60Iz5SHtQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-x64"; + version = "7.0.20"; + hash = "sha512-wh25bBNZosflPj2pcbIMB/fttuSFCvWn4N8XmDYd6XA91RpRk4GkZx505PmC+kpfU2FgM0N4zWgqnjcrifp6Ng=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-x64"; + version = "7.0.20"; + hash = "sha512-9k+5qHlL2/uiC5/crfn+Shv/93FV1E9oLFFK6nAs+/tUXL0olwsqpyEMUAdKdAoCgiTv50GnBjX/7jlp9bMmlg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-x64"; + version = "7.0.20"; + hash = "sha512-J/bFX9ai9i8S0ux0ZdnBhN+s+IFLosIBgnFvTBHuNfblPQ6R1YFsfYww5LQFI+plL8A2NcIdnBxLACrN22jwNQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetAppHost"; + version = "7.0.20"; + hash = "sha512-IAhdRGfxbYD1lF51SqBfDWIEvsysVWLPWELOpYPyY1CvmTPlGBh5QNanw2TLPu29eKb8k/peSVHJSOLKL8EF0w=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHost"; + version = "7.0.20"; + hash = "sha512-LuFx7q7tmDBcHce9C460IbL6Dp78jqsxUvSUC00XfB0D4uFhBVroWhHv4BPfFQ+cU3+/XEAOgW+H388kXuwEEA=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "7.0.20"; + hash = "sha512-TexO+i9DBf7QLW+JVnraEDFa3/7szqJWq5jLOskvEUBn/jrC7rLodIBr9Xm9qYeyPy2K6b31oXmVlGkPplX8PQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "7.0.20"; + hash = "sha512-Y2Jlv9Eq2tk2V7cyHW2uqVDxFlDFwANAtp0Ue3b1zxIOmI51bnXOh5d5Pjd8MYqNOsEF+Vq2xD1Sk79T/iiQZg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-musl-x64"; + version = "7.0.20"; + hash = "sha512-wIQ8KfpMjg7QOZapQ8FvJeqgzI8iyyvvdlBoibsQeuYJP9p7jc9O2BmDBolbn9fgdtKfyCIiwY2vf60Iz5SHtQ=="; + }) ]; osx-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.osx-arm64"; version = "7.0.20"; hash = "sha512-PnxpVZP/vcYJrJFxyAafetPeEcG+jzyT7LnKkWPPDLK7geSktcfefPYsZ96AIMhs8MUeOXYUrQd3luOZUo2tJw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.osx-arm64"; version = "7.0.20"; hash = "sha512-zskULQ4seV5+Aqj/hG1VQ5RKqGcjZi7T1ceCUHbfAJOxcVQOOcSzxGxy7+Ys2wQnhQsIjWYNIji58c5tnv/6vA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.osx-arm64"; version = "7.0.20"; hash = "sha512-+fCP5RM7V7wOodSFtnIzEsrnJUAwnVsySDZ3rR8QTn71r9L8e04rlDicaFiphr5j537pMbGvLttPBt8NbIdCgw=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetAppHost"; version = "7.0.20"; hash = "sha512-aMnnB6pgXohUYPJAkZ2tZeDVrawKTjMINz618Hcj+4m7WBYvwc31/LYIhKZ0Zb3Z/6VJkmtBvKalfbkgyDGcjA=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHost"; version = "7.0.20"; hash = "sha512-YYVXKrKtuFfQSnxBvrNgvWpe2FGcazsEt8P2EsyjJC7JN9DfhJtXsFz8UXCtxMlKDBYylB6UN2ROoskPQ6M+Xg=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "7.0.20"; hash = "sha512-W6XgW92qL2uwiD+JhS7BnepRaFzm4HfbzjPKGZMjtNsBzzkVKmZe0eKsTsIdS2D+eBGy9bmM610rFxyzFSLDRw=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "7.0.20"; hash = "sha512-8JJEwVHZRNmd+kiXA3lazbouUa4Y7TavnB3yjY3xHwYl+XKpCqD5OrLc5lKz49viVatasmUVfAfruCbmBxepOw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.osx-arm64"; version = "7.0.20"; hash = "sha512-SWxn7D93qwCx9OGmKmXZu0YZ8h2hLgLyHme6dpwje1u2N3M0qffP6kHgGzR7o1ynFh/GEbkuCe0CTqbNDcHWKQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.osx-arm64"; + version = "7.0.20"; + hash = "sha512-PnxpVZP/vcYJrJFxyAafetPeEcG+jzyT7LnKkWPPDLK7geSktcfefPYsZ96AIMhs8MUeOXYUrQd3luOZUo2tJw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.osx-arm64"; + version = "7.0.20"; + hash = "sha512-zskULQ4seV5+Aqj/hG1VQ5RKqGcjZi7T1ceCUHbfAJOxcVQOOcSzxGxy7+Ys2wQnhQsIjWYNIji58c5tnv/6vA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.osx-arm64"; + version = "7.0.20"; + hash = "sha512-+fCP5RM7V7wOodSFtnIzEsrnJUAwnVsySDZ3rR8QTn71r9L8e04rlDicaFiphr5j537pMbGvLttPBt8NbIdCgw=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "7.0.20"; + hash = "sha512-aMnnB6pgXohUYPJAkZ2tZeDVrawKTjMINz618Hcj+4m7WBYvwc31/LYIhKZ0Zb3Z/6VJkmtBvKalfbkgyDGcjA=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHost"; + version = "7.0.20"; + hash = "sha512-YYVXKrKtuFfQSnxBvrNgvWpe2FGcazsEt8P2EsyjJC7JN9DfhJtXsFz8UXCtxMlKDBYylB6UN2ROoskPQ6M+Xg=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "7.0.20"; + hash = "sha512-W6XgW92qL2uwiD+JhS7BnepRaFzm4HfbzjPKGZMjtNsBzzkVKmZe0eKsTsIdS2D+eBGy9bmM610rFxyzFSLDRw=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "7.0.20"; + hash = "sha512-8JJEwVHZRNmd+kiXA3lazbouUa4Y7TavnB3yjY3xHwYl+XKpCqD5OrLc5lKz49viVatasmUVfAfruCbmBxepOw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.osx-arm64"; + version = "7.0.20"; + hash = "sha512-SWxn7D93qwCx9OGmKmXZu0YZ8h2hLgLyHme6dpwje1u2N3M0qffP6kHgGzR7o1ynFh/GEbkuCe0CTqbNDcHWKQ=="; + }) ]; osx-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; version = "7.0.20"; hash = "sha512-MJkvhC9b1UXuA2C546UKTJ+wIV5z7QQk+lsXLe8R6g9BjVvN/NUItu9H3hylGkL5Yf/oBLmlPYVUjYuy3x5/1Q=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.osx-x64"; version = "7.0.20"; hash = "sha512-aQuov94b4ppO3l5CVG0z+VDCFVNHeklnwLS7XT/AbvSyBJ6+9BFqoSWg2uZz0MGjRl0tSA9eK9A6bkoVkPi1bQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.osx-x64"; version = "7.0.20"; hash = "sha512-+wNTFv4sHMdAc6G9qlx0GaRNbBhwW/DmN4OMQVkEDgTVCiCWg+DiFON2mffojexy7trJUl6Y3MoxYMJV9/1TUw=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetAppHost"; version = "7.0.20"; hash = "sha512-h3/RxhzpnpcVMNTHQ3hsprK/SrMMirLmyY2ynnUKJ6qAXEP8EUiHl8nlZ1bNGvansSbCltdRPO7pogiNJAEFZw=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHost"; version = "7.0.20"; hash = "sha512-moo/V26Rwf4Hq3/NH6NpWy8Y5BPHVhv7V9KILHZphxM11RpKMMAsKxGkiuNWlva6l38+W8SCIP1oBePe6FBOvA=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "7.0.20"; hash = "sha512-QxXZyylVqNbTBD5uUkrxJyHPz+qylX7xXnYuiE21UqCEVG0lI78O0X/dHYY8+35sRdU13rr0vmTszB2T1soSYg=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostResolver"; version = "7.0.20"; hash = "sha512-RICnRJ9rjyZ6ng3mQCTzKL898luIl24sUw+tm7Up27j5vieglx1gey6a1PLUBfcIVrQie9uM7tYD4oKxwn6HDw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.osx-x64"; version = "7.0.20"; hash = "sha512-QYu8SGNtLOlj3PKOgSOml4qLadJnfv0hG1jH2m+Si1TewLmQKjpvI0ZljoqTAOoe8U7vpSumiyqB+bPFiRvhmQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; + version = "7.0.20"; + hash = "sha512-MJkvhC9b1UXuA2C546UKTJ+wIV5z7QQk+lsXLe8R6g9BjVvN/NUItu9H3hylGkL5Yf/oBLmlPYVUjYuy3x5/1Q=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.osx-x64"; + version = "7.0.20"; + hash = "sha512-aQuov94b4ppO3l5CVG0z+VDCFVNHeklnwLS7XT/AbvSyBJ6+9BFqoSWg2uZz0MGjRl0tSA9eK9A6bkoVkPi1bQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.osx-x64"; + version = "7.0.20"; + hash = "sha512-+wNTFv4sHMdAc6G9qlx0GaRNbBhwW/DmN4OMQVkEDgTVCiCWg+DiFON2mffojexy7trJUl6Y3MoxYMJV9/1TUw=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetAppHost"; + version = "7.0.20"; + hash = "sha512-h3/RxhzpnpcVMNTHQ3hsprK/SrMMirLmyY2ynnUKJ6qAXEP8EUiHl8nlZ1bNGvansSbCltdRPO7pogiNJAEFZw=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHost"; + version = "7.0.20"; + hash = "sha512-moo/V26Rwf4Hq3/NH6NpWy8Y5BPHVhv7V9KILHZphxM11RpKMMAsKxGkiuNWlva6l38+W8SCIP1oBePe6FBOvA=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "7.0.20"; + hash = "sha512-QxXZyylVqNbTBD5uUkrxJyHPz+qylX7xXnYuiE21UqCEVG0lI78O0X/dHYY8+35sRdU13rr0vmTszB2T1soSYg=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "7.0.20"; + hash = "sha512-RICnRJ9rjyZ6ng3mQCTzKL898luIl24sUw+tm7Up27j5vieglx1gey6a1PLUBfcIVrQie9uM7tYD4oKxwn6HDw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.osx-x64"; + version = "7.0.20"; + hash = "sha512-QYu8SGNtLOlj3PKOgSOml4qLadJnfv0hG1jH2m+Si1TewLmQKjpvI0ZljoqTAOoe8U7vpSumiyqB+bPFiRvhmQ=="; + }) ]; win-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-arm64"; version = "7.0.20"; hash = "sha512-tt3EyI0qpyqwaFqtbG9+4BP7sukzjjheZ9/Cb/uO+CXxcep/LrKJW/Wc/wBKmkkIY/NnhJQ+Kwdjs6xcHVVO+w=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-arm64"; version = "7.0.20"; hash = "sha512-15hmpDKa0ap3bWF4rvM01Dy+Zn09h2h2MgeOj609P5iNZlsh7Eu8J7mQDdband/jPFZXWCV9CM4GYGPFEtKTIg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-arm64"; version = "7.0.20"; hash = "sha512-qpAjc0CKz+vt3d0eoeZsjmcnb6S6IQmGnXXjv/sfqYqkYErDlBFq448CYOcLUYWdEotInD2Qc6V7wnhs9hVgoQ=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetAppHost"; version = "7.0.20"; hash = "sha512-na9EJ1Gk0qpCwiDQaIWFuA3n3fhav5phIoCfN9u9WKg2TQCPGigJ5qfopqb1iHeo8q/G0CT7QtV/DdoILZFqaw=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHost"; version = "7.0.20"; hash = "sha512-MuLMyS3eKS2ajo5L971Lfd2vwq7X/oFd8gAZFvPCyHGBkvCwsgJacNhujz+vIdgq3nSVqTullR03BSRPGZNddg=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "7.0.20"; hash = "sha512-Di92c6M5r+E9UYkOhKsdPYV+w/QjmTrdS4CIooRlsSjfm3h75AsS5+0nApBnct/GJYQ4t9ZVVnbP+njoyhTXeA=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "7.0.20"; hash = "sha512-Qds42bScEWkFo+bHjyFG1PcsU8/n0phSa4LMAQBMT2CTs1/kW2o5uvPdQvnwIJ2m2qNY6vL7J/W/oePh6hGmFw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-arm64"; + version = "7.0.20"; + hash = "sha512-tt3EyI0qpyqwaFqtbG9+4BP7sukzjjheZ9/Cb/uO+CXxcep/LrKJW/Wc/wBKmkkIY/NnhJQ+Kwdjs6xcHVVO+w=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-arm64"; + version = "7.0.20"; + hash = "sha512-15hmpDKa0ap3bWF4rvM01Dy+Zn09h2h2MgeOj609P5iNZlsh7Eu8J7mQDdband/jPFZXWCV9CM4GYGPFEtKTIg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-arm64"; + version = "7.0.20"; + hash = "sha512-qpAjc0CKz+vt3d0eoeZsjmcnb6S6IQmGnXXjv/sfqYqkYErDlBFq448CYOcLUYWdEotInD2Qc6V7wnhs9hVgoQ=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "7.0.20"; + hash = "sha512-na9EJ1Gk0qpCwiDQaIWFuA3n3fhav5phIoCfN9u9WKg2TQCPGigJ5qfopqb1iHeo8q/G0CT7QtV/DdoILZFqaw=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHost"; + version = "7.0.20"; + hash = "sha512-MuLMyS3eKS2ajo5L971Lfd2vwq7X/oFd8gAZFvPCyHGBkvCwsgJacNhujz+vIdgq3nSVqTullR03BSRPGZNddg=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "7.0.20"; + hash = "sha512-Di92c6M5r+E9UYkOhKsdPYV+w/QjmTrdS4CIooRlsSjfm3h75AsS5+0nApBnct/GJYQ4t9ZVVnbP+njoyhTXeA=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "7.0.20"; + hash = "sha512-Qds42bScEWkFo+bHjyFG1PcsU8/n0phSa4LMAQBMT2CTs1/kW2o5uvPdQvnwIJ2m2qNY6vL7J/W/oePh6hGmFw=="; + }) ]; win-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-x64"; version = "7.0.20"; hash = "sha512-H9YZkbflMTqW04B9XpumTZwyNaFgtNnBxCTzM93XYNFPZbE6nbhuCUz7c2bdF9M3cZJzbm/4ITWFqBLoTMrqbg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-x64"; version = "7.0.20"; hash = "sha512-j7IIiyW2m2BNTt0MgcmhX3f4rl3F98mnStnY+13nlMzr+YC7ewI9khfIXv+bzUA3R2lyz7KghSZx9SaQGPuRbQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-x64"; version = "7.0.20"; hash = "sha512-eiJuU57LsGAsxxkbDS4iDsSWKIJH08FcJtEIiSfPtUVN4aExj1IoLp+MWFa60QA4+hkNpqs49R+g92ye8oGoxQ=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetAppHost"; version = "7.0.20"; hash = "sha512-d54yoCNVF93swJiCHU2Kc8yD1TLZKPBcnQAgfF1+BOXkUw3nr7uKC+pwqiaWtXXwBXBiVev0lL/qmjCxBG2p/Q=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetHost"; version = "7.0.20"; hash = "sha512-BUi8cUz+UpLC8fZmN4qhXHHvn7FaA6iTWXHtnXodSmN3ZsNtYHbB19F5ra+LfoJZ61zThEy3Nsf6/9qY4E3qew=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "7.0.20"; hash = "sha512-yiA3VeELW4zI+7yetMzUWkTiW+pb1nLjJY3hEZXDpVBxSgHcxdkvS4pWnBK97tS9Hujt6tfQOqDbWIj1XfBEfw=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostResolver"; version = "7.0.20"; hash = "sha512-Q0NF8q0UKGD3V+95GvErCff7jyJPuyk8/EO3T72PNCfPr2AIGPZtqCuDYTt4xnLyXoYUxyKEqALn2mmVvO+t0w=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.win-x64"; version = "7.0.20"; hash = "sha512-BLtlpQCuwfaoMmOYG1VUb16L1DX+ZrKFpJ5eQ0MW36MqrzR8Id9nkyZ161xneeyhxBUfi/m5zXfP20AFQQ1uXg=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-x64"; + version = "7.0.20"; + hash = "sha512-H9YZkbflMTqW04B9XpumTZwyNaFgtNnBxCTzM93XYNFPZbE6nbhuCUz7c2bdF9M3cZJzbm/4ITWFqBLoTMrqbg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-x64"; + version = "7.0.20"; + hash = "sha512-j7IIiyW2m2BNTt0MgcmhX3f4rl3F98mnStnY+13nlMzr+YC7ewI9khfIXv+bzUA3R2lyz7KghSZx9SaQGPuRbQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-x64"; + version = "7.0.20"; + hash = "sha512-eiJuU57LsGAsxxkbDS4iDsSWKIJH08FcJtEIiSfPtUVN4aExj1IoLp+MWFa60QA4+hkNpqs49R+g92ye8oGoxQ=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetAppHost"; + version = "7.0.20"; + hash = "sha512-d54yoCNVF93swJiCHU2Kc8yD1TLZKPBcnQAgfF1+BOXkUw3nr7uKC+pwqiaWtXXwBXBiVev0lL/qmjCxBG2p/Q=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetHost"; + version = "7.0.20"; + hash = "sha512-BUi8cUz+UpLC8fZmN4qhXHHvn7FaA6iTWXHtnXodSmN3ZsNtYHbB19F5ra+LfoJZ61zThEy3Nsf6/9qY4E3qew=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "7.0.20"; + hash = "sha512-yiA3VeELW4zI+7yetMzUWkTiW+pb1nLjJY3hEZXDpVBxSgHcxdkvS4pWnBK97tS9Hujt6tfQOqDbWIj1XfBEfw=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "7.0.20"; + hash = "sha512-Q0NF8q0UKGD3V+95GvErCff7jyJPuyk8/EO3T72PNCfPr2AIGPZtqCuDYTt4xnLyXoYUxyKEqALn2mmVvO+t0w=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.win-x64"; + version = "7.0.20"; + hash = "sha512-BLtlpQCuwfaoMmOYG1VUb16L1DX+ZrKFpJ5eQ0MW36MqrzR8Id9nkyZ161xneeyhxBUfi/m5zXfP20AFQQ1uXg=="; + }) ]; win-x86 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-x86"; version = "7.0.20"; hash = "sha512-s9lK1tQca5Qb4aZjEBPSGHZhDSksvfp/aj3xv8q39UqBKGtWdIAdrtcgq8qgM5nWavaCiWWW+CAEgmzFRIRpOw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-x86"; version = "7.0.20"; hash = "sha512-/TLX02L88IqbQDFZlGVPb/KKkGf43Q7wMGTscU1LNtNSd3YNSlj+K9E8bWY+bzFSaf05qJ7Oru0npYB+5opnGg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-x86"; version = "7.0.20"; hash = "sha512-RHIstT/YHVs1wHxZIPl16RicfJChzChOOqIdGP+UDC3Uc55E4IQ+aEJgrHTXi3xOw4RLp5zman0G0MmXCl5q3A=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetAppHost"; version = "7.0.20"; hash = "sha512-x5KTZwR2UaFx+IvULmbSwEuiXfvpCZUYlm5KtRltd+M3yeFCJDqK+sLPUDnB2kywKDCJYwOdasfzjAhRa1yAeg=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetHost"; version = "7.0.20"; hash = "sha512-CiWFBDlRFKu8sXeXrij7oLRTd2KcGkADb5MVGG+7xt5TIgiXZSfDEummipoK3v15cK3Z6eecVSulFZgEySVbwQ=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostPolicy"; version = "7.0.20"; hash = "sha512-1ly66dLhrDCgk8BiO/rxDRwUT+DbOXH3kIwnO+TiMJfID+dyqfpw3ZIbeHbIxW1A5Ukexh3mcv6ndMTkbnZgog=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostResolver"; version = "7.0.20"; hash = "sha512-DrzZfs6NkL7Kqnnq3HTcl8oGnvfu6oYPKVoAgA4eXdrEIWuiDIalaD/c7lSfg13ei53tzACUTlKSy1dHGErXiA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.win-x86"; version = "7.0.20"; hash = "sha512-GLCsBKRie1giQ6YrjELcvSmdEG1eeKFKn5YweCEm0e67DSZuqtJX2RxIojRV+TUvWObRPhZMM708CZ258qMr9g=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-x86"; + version = "7.0.20"; + hash = "sha512-s9lK1tQca5Qb4aZjEBPSGHZhDSksvfp/aj3xv8q39UqBKGtWdIAdrtcgq8qgM5nWavaCiWWW+CAEgmzFRIRpOw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-x86"; + version = "7.0.20"; + hash = "sha512-/TLX02L88IqbQDFZlGVPb/KKkGf43Q7wMGTscU1LNtNSd3YNSlj+K9E8bWY+bzFSaf05qJ7Oru0npYB+5opnGg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-x86"; + version = "7.0.20"; + hash = "sha512-RHIstT/YHVs1wHxZIPl16RicfJChzChOOqIdGP+UDC3Uc55E4IQ+aEJgrHTXi3xOw4RLp5zman0G0MmXCl5q3A=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetAppHost"; + version = "7.0.20"; + hash = "sha512-x5KTZwR2UaFx+IvULmbSwEuiXfvpCZUYlm5KtRltd+M3yeFCJDqK+sLPUDnB2kywKDCJYwOdasfzjAhRa1yAeg=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetHost"; + version = "7.0.20"; + hash = "sha512-CiWFBDlRFKu8sXeXrij7oLRTd2KcGkADb5MVGG+7xt5TIgiXZSfDEummipoK3v15cK3Z6eecVSulFZgEySVbwQ=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostPolicy"; + version = "7.0.20"; + hash = "sha512-1ly66dLhrDCgk8BiO/rxDRwUT+DbOXH3kIwnO+TiMJfID+dyqfpw3ZIbeHbIxW1A5Ukexh3mcv6ndMTkbnZgog=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostResolver"; + version = "7.0.20"; + hash = "sha512-DrzZfs6NkL7Kqnnq3HTcl8oGnvfu6oYPKVoAgA4eXdrEIWuiDIalaD/c7lSfg13ei53tzACUTlKSy1dHGErXiA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.win-x86"; + version = "7.0.20"; + hash = "sha512-GLCsBKRie1giQ6YrjELcvSmdEG1eeKFKn5YweCEm0e67DSZuqtJX2RxIojRV+TUvWObRPhZMM708CZ258qMr9g=="; + }) ]; }; -in rec { +in +rec { release_7_0 = "7.0.20"; aspnetcore_7_0 = buildAspNetCore { diff --git a/pkgs/development/compilers/dotnet/versions/8.0.nix b/pkgs/development/compilers/dotnet/versions/8.0.nix index 39f5f8e4365353..f705bb1da8c243 100644 --- a/pkgs/development/compilers/dotnet/versions/8.0.nix +++ b/pkgs/development/compilers/dotnet/versions/8.0.nix @@ -1,174 +1,628 @@ -{ buildAspNetCore, buildNetRuntime, buildNetSdk, fetchNupkg }: +{ + buildAspNetCore, + buildNetRuntime, + buildNetSdk, + fetchNupkg, +}: # v8.0 (active) let commonPackages = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Ref"; version = "8.0.11"; hash = "sha512-0ow+3BClZm2xlEXC7g+vr7vxmBkXnNwxjCSqhxCcPqRHkXYNW1rdHmzrCLmGYRzGFxk7wktqOUkRV0ipgSQXOw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetAppHost"; version = "8.0.11"; hash = "sha512-hRfXvd55c2xE9g3qOegrES0SkqFFKFid/wScWpANLT/yf6wEV6bn7c7cPrE/fyuw6MiaT86noYsGzj4WWezYuA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Ref"; version = "8.0.11"; hash = "sha512-oMIPTmsRuaFIosXYWzEHFCu2pQK0JdtkuQdT4j1szfZ8BVTHtYsBqWdjGV3u9uaWiJld6V7FanVVU+Z8HWFQ6Q=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetHost"; version = "8.0.11"; hash = "sha512-bknpGqBWIN0R0hiUU6VhrrCEY4T0P2F953t1AyPlt2LfzRij921w+I+zPhAlA3CRWDgq8ppX5iJTPhabnjrBSg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.11"; hash = "sha512-QRSkkJ5ECtxL/pOBwqS2h+WY01Z5SYOLnL82cP6li8jpeP/h9TnClUjovMa5hk/ny3FM79J1cwIIwuSTGgv6kA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetHostResolver"; version = "8.0.11"; hash = "sha512-mOgsZb1/yibFbb4nwVCvPk7KCa7S671zqjKdQGvwBxwr2vF20SW4Yw9me7bo9XMXHgR+25GlMnf3nKXkO/jgaw=="; }) - (fetchNupkg { pname = "Microsoft.DotNet.ILCompiler"; version = "8.0.11"; hash = "sha512-MrWOJYbQCVUn4yAcAfRBekLNhAs/UPNlPOUCXq/HwTX0wLqT4Rcgg5MIlzA6w3QIGmLWHMh60QOmEFdUXjwghw=="; }) - (fetchNupkg { pname = "Microsoft.NET.ILLink.Tasks"; version = "8.0.11"; hash = "sha512-BDUnx2LSv8CWK3WAbPnNWt7deVdLBn4VZ5ZNUSRg4WN/Wi1x+M4WQgd2yrW+qnSSR5ll9AKhWNUsiGVWf+OsaQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Ref"; + version = "8.0.11"; + hash = "sha512-0ow+3BClZm2xlEXC7g+vr7vxmBkXnNwxjCSqhxCcPqRHkXYNW1rdHmzrCLmGYRzGFxk7wktqOUkRV0ipgSQXOw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetAppHost"; + version = "8.0.11"; + hash = "sha512-hRfXvd55c2xE9g3qOegrES0SkqFFKFid/wScWpANLT/yf6wEV6bn7c7cPrE/fyuw6MiaT86noYsGzj4WWezYuA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Ref"; + version = "8.0.11"; + hash = "sha512-oMIPTmsRuaFIosXYWzEHFCu2pQK0JdtkuQdT4j1szfZ8BVTHtYsBqWdjGV3u9uaWiJld6V7FanVVU+Z8HWFQ6Q=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetHost"; + version = "8.0.11"; + hash = "sha512-bknpGqBWIN0R0hiUU6VhrrCEY4T0P2F953t1AyPlt2LfzRij921w+I+zPhAlA3CRWDgq8ppX5iJTPhabnjrBSg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.11"; + hash = "sha512-QRSkkJ5ECtxL/pOBwqS2h+WY01Z5SYOLnL82cP6li8jpeP/h9TnClUjovMa5hk/ny3FM79J1cwIIwuSTGgv6kA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.11"; + hash = "sha512-mOgsZb1/yibFbb4nwVCvPk7KCa7S671zqjKdQGvwBxwr2vF20SW4Yw9me7bo9XMXHgR+25GlMnf3nKXkO/jgaw=="; + }) + (fetchNupkg { + pname = "Microsoft.DotNet.ILCompiler"; + version = "8.0.11"; + hash = "sha512-MrWOJYbQCVUn4yAcAfRBekLNhAs/UPNlPOUCXq/HwTX0wLqT4Rcgg5MIlzA6w3QIGmLWHMh60QOmEFdUXjwghw=="; + }) + (fetchNupkg { + pname = "Microsoft.NET.ILLink.Tasks"; + version = "8.0.11"; + hash = "sha512-BDUnx2LSv8CWK3WAbPnNWt7deVdLBn4VZ5ZNUSRg4WN/Wi1x+M4WQgd2yrW+qnSSR5ll9AKhWNUsiGVWf+OsaQ=="; + }) ]; hostPackages = { linux-arm = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-arm"; version = "8.0.11"; hash = "sha512-vNLg/on8vgsoDhsYxvU724nX9g1vmD8/GaaTHpNr9953L3/hkmoyuXU6V4BL0iZsz/IDcRNs1cFlMqVHaDWzSw=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-arm"; + version = "8.0.11"; + hash = "sha512-vNLg/on8vgsoDhsYxvU724nX9g1vmD8/GaaTHpNr9953L3/hkmoyuXU6V4BL0iZsz/IDcRNs1cFlMqVHaDWzSw=="; + }) ]; linux-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-arm64"; version = "8.0.11"; hash = "sha512-Fwm4IFjRnNtoHDEhwHcK5esu8kxznT+aZYRe7T5/7HHwaHOZYwnwVAb+1yG9zmpWsQAwVCy2Dy98T/KuraxY2Q=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.DotNet.ILCompiler"; version = "8.0.11"; hash = "sha512-HCYA8CKNlcAdvJ7xJYPVMFyG2ZklrC/j7HJA5iNm0yI7IOtsBbrWbYbz8glc8h6gT4FrOAPu71IUot9Iika0EQ=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-arm64"; + version = "8.0.11"; + hash = "sha512-Fwm4IFjRnNtoHDEhwHcK5esu8kxznT+aZYRe7T5/7HHwaHOZYwnwVAb+1yG9zmpWsQAwVCy2Dy98T/KuraxY2Q=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.DotNet.ILCompiler"; + version = "8.0.11"; + hash = "sha512-HCYA8CKNlcAdvJ7xJYPVMFyG2ZklrC/j7HJA5iNm0yI7IOtsBbrWbYbz8glc8h6gT4FrOAPu71IUot9Iika0EQ=="; + }) ]; linux-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-x64"; version = "8.0.11"; hash = "sha512-JuZSeAmow4Xx9+VUnm7TYfSUU/p7l/SjSVoQKdoLdpOHSMm/pnSEOjHc4pKmAr4G6OS3dUgVY/IZyGxtS5g9VA=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.DotNet.ILCompiler"; version = "8.0.11"; hash = "sha512-9epOV/0PK9EYPPXLif6YwQo4O51muFM5iMVZOvOtTDYKN3MYlZcvwKMirJaAkvAhp5o71oRcfQcZc5srkvy4ZA=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-x64"; + version = "8.0.11"; + hash = "sha512-JuZSeAmow4Xx9+VUnm7TYfSUU/p7l/SjSVoQKdoLdpOHSMm/pnSEOjHc4pKmAr4G6OS3dUgVY/IZyGxtS5g9VA=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.DotNet.ILCompiler"; + version = "8.0.11"; + hash = "sha512-9epOV/0PK9EYPPXLif6YwQo4O51muFM5iMVZOvOtTDYKN3MYlZcvwKMirJaAkvAhp5o71oRcfQcZc5srkvy4ZA=="; + }) ]; linux-musl-arm = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm"; version = "8.0.11"; hash = "sha512-Cm/rntnyMTnImcRzuL5VRpgN5AaoRElhyVi9Q+askyi0GnKX0Y6YPX/xmUIQcCCTOOzz6+i8xLBb85+oemUvGA=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm"; + version = "8.0.11"; + hash = "sha512-Cm/rntnyMTnImcRzuL5VRpgN5AaoRElhyVi9Q+askyi0GnKX0Y6YPX/xmUIQcCCTOOzz6+i8xLBb85+oemUvGA=="; + }) ]; linux-musl-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm64"; version = "8.0.11"; hash = "sha512-BSaP3Yvv5DGh/fuoefbPtstxzyz0meQ6F3p33+3HO8YJwX34hSpuINdzUVsRKNoqWbCm4pHy8DmFh0dftCEwyQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.DotNet.ILCompiler"; version = "8.0.11"; hash = "sha512-XJDQvhTRCV/7UTck+0WHM/YdGuXqvfYXBKv6pvvy7fOqrgv96ozy6XhkAZB1FT/ernqM7C4tBviPKg6u9sWfMw=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm64"; + version = "8.0.11"; + hash = "sha512-BSaP3Yvv5DGh/fuoefbPtstxzyz0meQ6F3p33+3HO8YJwX34hSpuINdzUVsRKNoqWbCm4pHy8DmFh0dftCEwyQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.DotNet.ILCompiler"; + version = "8.0.11"; + hash = "sha512-XJDQvhTRCV/7UTck+0WHM/YdGuXqvfYXBKv6pvvy7fOqrgv96ozy6XhkAZB1FT/ernqM7C4tBviPKg6u9sWfMw=="; + }) ]; linux-musl-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-x64"; version = "8.0.11"; hash = "sha512-uOEs8EvkUOrCae/OGKy4Ek6zeY6HrjN0ppOK2VmcMsiwogP3XkkLjg6/grLiGvhMXbEpXUReSSGPd1wo48W/cg=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.DotNet.ILCompiler"; version = "8.0.11"; hash = "sha512-AjkGqrKxLuz0v+29koSdfx8l+9g8l7GCAe45nLvno1BWQaRJp0YZ0watG3Cs5UBQuOHz6QBTpxrtv21ABCn5AQ=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-x64"; + version = "8.0.11"; + hash = "sha512-uOEs8EvkUOrCae/OGKy4Ek6zeY6HrjN0ppOK2VmcMsiwogP3XkkLjg6/grLiGvhMXbEpXUReSSGPd1wo48W/cg=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.DotNet.ILCompiler"; + version = "8.0.11"; + hash = "sha512-AjkGqrKxLuz0v+29koSdfx8l+9g8l7GCAe45nLvno1BWQaRJp0YZ0watG3Cs5UBQuOHz6QBTpxrtv21ABCn5AQ=="; + }) ]; osx-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.osx-arm64"; version = "8.0.11"; hash = "sha512-+ONYpLs/Awwr0JhKj0uTlzV7Dz/w8JDcMWZn/IaODTyboFafxTcQx9zBvZGs2U8pAuDig5jA19tihfZfxtqPSg=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.DotNet.ILCompiler"; version = "8.0.11"; hash = "sha512-ICRHCPlohKZNi2Kxdy7VfHVDcY8GaWg9zapIvVwPbp8y+LIjEHSYBx920gftF+3+eNlOi0Vw4WIYGkBAKhgwzA=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.osx-arm64"; + version = "8.0.11"; + hash = "sha512-+ONYpLs/Awwr0JhKj0uTlzV7Dz/w8JDcMWZn/IaODTyboFafxTcQx9zBvZGs2U8pAuDig5jA19tihfZfxtqPSg=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.DotNet.ILCompiler"; + version = "8.0.11"; + hash = "sha512-ICRHCPlohKZNi2Kxdy7VfHVDcY8GaWg9zapIvVwPbp8y+LIjEHSYBx920gftF+3+eNlOi0Vw4WIYGkBAKhgwzA=="; + }) ]; osx-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.osx-x64"; version = "8.0.11"; hash = "sha512-9UR5zvygPAvdP92H+iGKqWRyUu1xawnnDo8p1N58mUpt67y6kPdDW4lHZzZg1nn61bgDvS/Wp+jQjmb2+x7ybQ=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.DotNet.ILCompiler"; version = "8.0.11"; hash = "sha512-sOg03F0H7CjWTTFGDNfTsPq5pkziy6GcsAqdaANeh4sGRsRAeANFBp11ewAfk8P0fZVeWoRTaPtGjCZQ9dRpoQ=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.osx-x64"; + version = "8.0.11"; + hash = "sha512-9UR5zvygPAvdP92H+iGKqWRyUu1xawnnDo8p1N58mUpt67y6kPdDW4lHZzZg1nn61bgDvS/Wp+jQjmb2+x7ybQ=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.DotNet.ILCompiler"; + version = "8.0.11"; + hash = "sha512-sOg03F0H7CjWTTFGDNfTsPq5pkziy6GcsAqdaANeh4sGRsRAeANFBp11ewAfk8P0fZVeWoRTaPtGjCZQ9dRpoQ=="; + }) ]; win-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-arm64"; version = "8.0.11"; hash = "sha512-NXHH++Pg3fpeFWTISDya9f8JZIvxqdfE3Ebj6tWxmBu/pR5OpDiD6mEwyK6BKuANMYpEAD/mzo/tFzc51IOZEQ=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.DotNet.ILCompiler"; version = "8.0.11"; hash = "sha512-NALt9Nbl6bu/f5ke11Cmc5tF8e3JkUXEzkJAfClel5zW6462xe/0WeqRrTg4MaaiDTga+ve/GYB7AXGrenyB/w=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-arm64"; + version = "8.0.11"; + hash = "sha512-NXHH++Pg3fpeFWTISDya9f8JZIvxqdfE3Ebj6tWxmBu/pR5OpDiD6mEwyK6BKuANMYpEAD/mzo/tFzc51IOZEQ=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.DotNet.ILCompiler"; + version = "8.0.11"; + hash = "sha512-NALt9Nbl6bu/f5ke11Cmc5tF8e3JkUXEzkJAfClel5zW6462xe/0WeqRrTg4MaaiDTga+ve/GYB7AXGrenyB/w=="; + }) ]; win-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-x64"; version = "8.0.11"; hash = "sha512-d+8q1xYCNc1PNYfHHzJJXRNHCRM/LnQlfs36LzxeaJzgx2LbBFRzxO/mUKSnDWMAP4i1P4BqqjZ7idjcIxV7uQ=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.DotNet.ILCompiler"; version = "8.0.11"; hash = "sha512-ZDOVXgkXU+RSEV7lB/WSXkUpdczXANpMGuFToyVZJCuA41DwQwCZoJfVI9cXHStQUaEGn81HOfS6GQsRmEdjGg=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-x64"; + version = "8.0.11"; + hash = "sha512-d+8q1xYCNc1PNYfHHzJJXRNHCRM/LnQlfs36LzxeaJzgx2LbBFRzxO/mUKSnDWMAP4i1P4BqqjZ7idjcIxV7uQ=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.DotNet.ILCompiler"; + version = "8.0.11"; + hash = "sha512-ZDOVXgkXU+RSEV7lB/WSXkUpdczXANpMGuFToyVZJCuA41DwQwCZoJfVI9cXHStQUaEGn81HOfS6GQsRmEdjGg=="; + }) ]; win-x86 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-x86"; version = "8.0.11"; hash = "sha512-uEV87iNIuLAont7ESYEPOoF42ZmAlhmU20U3Lx5mwH7iaKt11VjuLeqvhxZKuSkL/ds1+ZzvLHhzAn0c2Z6JPA=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-x86"; + version = "8.0.11"; + hash = "sha512-uEV87iNIuLAont7ESYEPOoF42ZmAlhmU20U3Lx5mwH7iaKt11VjuLeqvhxZKuSkL/ds1+ZzvLHhzAn0c2Z6JPA=="; + }) ]; }; targetPackages = { linux-arm = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm"; version = "8.0.11"; hash = "sha512-qiP7GkxUqsROiAZ4NCgYbxP1PrvsTEyiNZZ1WC/MEexzj95xwTioAMbihGOzaB5neB3byZ1aZn9KZ8NA4wn6hQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-arm"; version = "8.0.11"; hash = "sha512-ukSAJJxyz+arYNuzXsP2om0or3f+d2cu1kHvWfe79JmaBzAmT3kBObCa3tYVsrtNZ4ck2g9fN4JnV8zsFvw/bg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-arm"; version = "8.0.11"; hash = "sha512-nATBKJ9/Suku621bOi+AVmQTRcVyyjGFOZattJROHnv3FsvrhY4hmuZXf8jNbKAgSgqYdHxLvgLX2bqBqzwKHQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetAppHost"; version = "8.0.11"; hash = "sha512-TI00Komhy29vOUv8/UC8RJNnSro7/X7rQ2J/8b4cCaVyRCYr7URV3cuuJYANasSV/lkjSoEuhpRXtnDCIUIYPQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHost"; version = "8.0.11"; hash = "sha512-eLPVwuPLnr4PZagAVBlVJOH/P5QYCdb0nwbq+Y8N6pePLzeexQmKs8FrXjdWEdtDQOtsgm5Rvw/2Y9eWCXUYFA=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.11"; hash = "sha512-FqZlpdIhuhfAgzy7VC/r7xtiMML3hERUGXQ2rWxPgTArAo7puYXfPBjROmU1JYCXiaTd7uXBbrkSaFIbl9srwQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.11"; hash = "sha512-rs+Z0i4ZMj/9oacyL3hyKgNm/2qRtC6NfAciF+vdaG9HxmAdGTooCOYZEJutKs8KByZn80eVKtxwtPNuRV/5wQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm"; version = "8.0.11"; hash = "sha512-TEN2ZHFkIvbQwl/tu7cskgdRzzrqEvhzB1zhkmtN3FKO9h2KvtQqEuOc3+sEZj2RHGqUYGFvT5JyiEp2jfK0xA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm"; + version = "8.0.11"; + hash = "sha512-qiP7GkxUqsROiAZ4NCgYbxP1PrvsTEyiNZZ1WC/MEexzj95xwTioAMbihGOzaB5neB3byZ1aZn9KZ8NA4wn6hQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-arm"; + version = "8.0.11"; + hash = "sha512-ukSAJJxyz+arYNuzXsP2om0or3f+d2cu1kHvWfe79JmaBzAmT3kBObCa3tYVsrtNZ4ck2g9fN4JnV8zsFvw/bg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-arm"; + version = "8.0.11"; + hash = "sha512-nATBKJ9/Suku621bOi+AVmQTRcVyyjGFOZattJROHnv3FsvrhY4hmuZXf8jNbKAgSgqYdHxLvgLX2bqBqzwKHQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.11"; + hash = "sha512-TI00Komhy29vOUv8/UC8RJNnSro7/X7rQ2J/8b4cCaVyRCYr7URV3cuuJYANasSV/lkjSoEuhpRXtnDCIUIYPQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHost"; + version = "8.0.11"; + hash = "sha512-eLPVwuPLnr4PZagAVBlVJOH/P5QYCdb0nwbq+Y8N6pePLzeexQmKs8FrXjdWEdtDQOtsgm5Rvw/2Y9eWCXUYFA=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.11"; + hash = "sha512-FqZlpdIhuhfAgzy7VC/r7xtiMML3hERUGXQ2rWxPgTArAo7puYXfPBjROmU1JYCXiaTd7uXBbrkSaFIbl9srwQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.11"; + hash = "sha512-rs+Z0i4ZMj/9oacyL3hyKgNm/2qRtC6NfAciF+vdaG9HxmAdGTooCOYZEJutKs8KByZn80eVKtxwtPNuRV/5wQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm"; + version = "8.0.11"; + hash = "sha512-TEN2ZHFkIvbQwl/tu7cskgdRzzrqEvhzB1zhkmtN3FKO9h2KvtQqEuOc3+sEZj2RHGqUYGFvT5JyiEp2jfK0xA=="; + }) ]; linux-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; version = "8.0.11"; hash = "sha512-z6lwljPpEYS90GGVG/SA5m2oYXU4Tjo1zMnrvHaPIHeFgHvEhij9QQHs9jNqlJX7ycsCrqPAuVQ8Auc/uW+0+A=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-arm64"; version = "8.0.11"; hash = "sha512-YpkUhlr8il3zMSVx/7Q9ZFl7CS3x/tcgdSI2wAXyoKxIw6NOj1l7ilEBdq2qJ1nPZFbgc5JfTUJTBMG6ahSzsA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; version = "8.0.11"; hash = "sha512-1A65EZfcbAjJ4sxycI+rke3saNMiWglG6NTxhZ5TEDRhlHy4l8Ft/GPnwofFBD5y8sDs5Hbs318q5XVbpqEL2A=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.11"; hash = "sha512-J2Yd5bSkcY7V1wRXmkR8pDxbiZBoPp9NOs1j9TJbJ0fDKaGxCq0pAneU7OXt+F57BM+4ZGbF9VaYCYw9M8h1dw=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHost"; version = "8.0.11"; hash = "sha512-k4fuLpGJEZF/X3kuUffTXMOUeq0JyANojJn63IpTeODTkXg17UhFgPy4CpnpHqfL+7PJYn5JHRY5WI5DZqG9vQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.11"; hash = "sha512-RSuEuq0f1sjyXMQLoCykoFakvuztp0XsVwp1r5xTSvtUq1e5sYEIN5DK7hqFhVXCfb0TM7GkwsaHCmIAjgW7dQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.11"; hash = "sha512-Uro1N0GVumpdj0SLieARjzuvnw+94i1TVK6jOmRZd4EZx3eJlHPD+d/HXjT4FOanVRg3LqlzjLZuMk5nNfJzHQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm64"; version = "8.0.11"; hash = "sha512-qB2NfZk+EYPkLCRSXhVh6xnVsTAsXGBXcB55e7nKxB8d3+LDYOcYWy0L/njBZi/3oBbEFPhwTrTfVpiHLrmigA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; + version = "8.0.11"; + hash = "sha512-z6lwljPpEYS90GGVG/SA5m2oYXU4Tjo1zMnrvHaPIHeFgHvEhij9QQHs9jNqlJX7ycsCrqPAuVQ8Auc/uW+0+A=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-arm64"; + version = "8.0.11"; + hash = "sha512-YpkUhlr8il3zMSVx/7Q9ZFl7CS3x/tcgdSI2wAXyoKxIw6NOj1l7ilEBdq2qJ1nPZFbgc5JfTUJTBMG6ahSzsA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; + version = "8.0.11"; + hash = "sha512-1A65EZfcbAjJ4sxycI+rke3saNMiWglG6NTxhZ5TEDRhlHy4l8Ft/GPnwofFBD5y8sDs5Hbs318q5XVbpqEL2A=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.11"; + hash = "sha512-J2Yd5bSkcY7V1wRXmkR8pDxbiZBoPp9NOs1j9TJbJ0fDKaGxCq0pAneU7OXt+F57BM+4ZGbF9VaYCYw9M8h1dw=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHost"; + version = "8.0.11"; + hash = "sha512-k4fuLpGJEZF/X3kuUffTXMOUeq0JyANojJn63IpTeODTkXg17UhFgPy4CpnpHqfL+7PJYn5JHRY5WI5DZqG9vQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.11"; + hash = "sha512-RSuEuq0f1sjyXMQLoCykoFakvuztp0XsVwp1r5xTSvtUq1e5sYEIN5DK7hqFhVXCfb0TM7GkwsaHCmIAjgW7dQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.11"; + hash = "sha512-Uro1N0GVumpdj0SLieARjzuvnw+94i1TVK6jOmRZd4EZx3eJlHPD+d/HXjT4FOanVRg3LqlzjLZuMk5nNfJzHQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-arm64"; + version = "8.0.11"; + hash = "sha512-qB2NfZk+EYPkLCRSXhVh6xnVsTAsXGBXcB55e7nKxB8d3+LDYOcYWy0L/njBZi/3oBbEFPhwTrTfVpiHLrmigA=="; + }) ]; linux-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; version = "8.0.11"; hash = "sha512-U3PF933HdVRLctSZQQHKwGGMqIVRikS5KM2IgIb5KH9zoXrzZCprAXJCvrZQDoOtaKOn+euyF+gy69CveB+gOw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-x64"; version = "8.0.11"; hash = "sha512-CYyQU33vn02h5xowEBEfRXIcLYm6GyXGhLmrDUJiHjJOZkAca1mbJZ39Fal/pEhzosnSN53Ld+HRGxe+9yijWg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-x64"; version = "8.0.11"; hash = "sha512-gQyj1KtYGgFJWTn4tTM1bH4xvTyVyk5pLCYZHlkYmfXwo1oDVvLrXiOC3rKdHxA+c8tRePJsNDIQKIAlJlmgAg=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.11"; hash = "sha512-bH0iaT0WlU2WXpStLFzqv2BsG8kVt5znYQ5S+7PGzZjTN8OSo9VfacgwL+NrP4yGZEir/RCqx5YRymm/ttKZUA=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHost"; version = "8.0.11"; hash = "sha512-RUhpon8Kanv+g0dP7DvXMIbJbxcQCrxgZZA8C4w/eRHvprvldOW9laat2DdF+c5Yxkz4gs1rarfX5Hys3hLCqw=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.11"; hash = "sha512-J2l2TxZcxtK8dHPdT0BZVlsf2dkPUvfq/PnkzprQBrePbvtTbpaGv6HYfShUHzUS6lAb8oPx8E36fj25T2TzYg=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.11"; hash = "sha512-Z8yrkHD415e1ZTpXvPTG19DkfR9DBafXwx2Bqmy6adx6maWlzZqrppk7IgfmCobas4nNnI1INBKXvDxxYm4Ziw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-x64"; version = "8.0.11"; hash = "sha512-rDMKYcBghoj2gWaUeWYZXNuNuO1HWbu9vEaHjyl6Y0o/OSIy2T3em3NZdc38OfG9dykCz4pgT9tdD6BZ7Ivwhw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; + version = "8.0.11"; + hash = "sha512-U3PF933HdVRLctSZQQHKwGGMqIVRikS5KM2IgIb5KH9zoXrzZCprAXJCvrZQDoOtaKOn+euyF+gy69CveB+gOw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-x64"; + version = "8.0.11"; + hash = "sha512-CYyQU33vn02h5xowEBEfRXIcLYm6GyXGhLmrDUJiHjJOZkAca1mbJZ39Fal/pEhzosnSN53Ld+HRGxe+9yijWg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-x64"; + version = "8.0.11"; + hash = "sha512-gQyj1KtYGgFJWTn4tTM1bH4xvTyVyk5pLCYZHlkYmfXwo1oDVvLrXiOC3rKdHxA+c8tRePJsNDIQKIAlJlmgAg=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.11"; + hash = "sha512-bH0iaT0WlU2WXpStLFzqv2BsG8kVt5znYQ5S+7PGzZjTN8OSo9VfacgwL+NrP4yGZEir/RCqx5YRymm/ttKZUA=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHost"; + version = "8.0.11"; + hash = "sha512-RUhpon8Kanv+g0dP7DvXMIbJbxcQCrxgZZA8C4w/eRHvprvldOW9laat2DdF+c5Yxkz4gs1rarfX5Hys3hLCqw=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.11"; + hash = "sha512-J2l2TxZcxtK8dHPdT0BZVlsf2dkPUvfq/PnkzprQBrePbvtTbpaGv6HYfShUHzUS6lAb8oPx8E36fj25T2TzYg=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.11"; + hash = "sha512-Z8yrkHD415e1ZTpXvPTG19DkfR9DBafXwx2Bqmy6adx6maWlzZqrppk7IgfmCobas4nNnI1INBKXvDxxYm4Ziw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-x64"; + version = "8.0.11"; + hash = "sha512-rDMKYcBghoj2gWaUeWYZXNuNuO1HWbu9vEaHjyl6Y0o/OSIy2T3em3NZdc38OfG9dykCz4pgT9tdD6BZ7Ivwhw=="; + }) ]; linux-musl-arm = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm"; version = "8.0.11"; hash = "sha512-ensFnmyolPu1SHBFsxfnxrI+ldHqN6n62eS0+MXZ+kaMAfnyQtYT3u3NXWanHZHgXKdlV8+9+T2KvOpQUXdu3g=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-arm"; version = "8.0.11"; hash = "sha512-DioWImEMGjRM4UN+7on+2VK7D/kv3vVGGaPAIoLNw3JYhJylj1Y2AqSd1uwQ9a3WGU/7amRAcTMX2p1/NMxWCQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm"; version = "8.0.11"; hash = "sha512-AB/BBjg1QmNjKix97nGsnyYALk3ABZAtqbkLTxKlC/GVuITZ05cQOKfKbbHLgYAiKZQtDPG/XMiEt7UTpm8BFQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetAppHost"; version = "8.0.11"; hash = "sha512-znw0LiorYDW0fCWwYQHiEwTRx5JrKrBfbPlwAKURJWq1YaLDy2eygO3hXlMdSLdMWkJlDPZpjcbqt5+mx7dBnQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHost"; version = "8.0.11"; hash = "sha512-4lNoHmvKzqUpCZhUofSMITLANHj1UrAHtMHzUtcA9rHUuqi8WKOG6hAyVXp7qhNPaWTPWlwkwG1vyp89fhsqAg=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.11"; hash = "sha512-7wyt+/TT0T2EoPpqdLUbjvoVzGyzDtArThboeX7hYdx2J0Wh2O7821XIo/1XZoGUVI72wEVxX/mvylUgsNyrWQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.11"; hash = "sha512-O1Kw599sjBL7neUB2rQU5fNveeFLm0QbBTIvzupfmKSPpON7MI9Ir28LJqwjFbSqhdO/9SYmpeTUzAJqsbGQjw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm"; + version = "8.0.11"; + hash = "sha512-ensFnmyolPu1SHBFsxfnxrI+ldHqN6n62eS0+MXZ+kaMAfnyQtYT3u3NXWanHZHgXKdlV8+9+T2KvOpQUXdu3g=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-arm"; + version = "8.0.11"; + hash = "sha512-DioWImEMGjRM4UN+7on+2VK7D/kv3vVGGaPAIoLNw3JYhJylj1Y2AqSd1uwQ9a3WGU/7amRAcTMX2p1/NMxWCQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm"; + version = "8.0.11"; + hash = "sha512-AB/BBjg1QmNjKix97nGsnyYALk3ABZAtqbkLTxKlC/GVuITZ05cQOKfKbbHLgYAiKZQtDPG/XMiEt7UTpm8BFQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.11"; + hash = "sha512-znw0LiorYDW0fCWwYQHiEwTRx5JrKrBfbPlwAKURJWq1YaLDy2eygO3hXlMdSLdMWkJlDPZpjcbqt5+mx7dBnQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHost"; + version = "8.0.11"; + hash = "sha512-4lNoHmvKzqUpCZhUofSMITLANHj1UrAHtMHzUtcA9rHUuqi8WKOG6hAyVXp7qhNPaWTPWlwkwG1vyp89fhsqAg=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.11"; + hash = "sha512-7wyt+/TT0T2EoPpqdLUbjvoVzGyzDtArThboeX7hYdx2J0Wh2O7821XIo/1XZoGUVI72wEVxX/mvylUgsNyrWQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.11"; + hash = "sha512-O1Kw599sjBL7neUB2rQU5fNveeFLm0QbBTIvzupfmKSPpON7MI9Ir28LJqwjFbSqhdO/9SYmpeTUzAJqsbGQjw=="; + }) ]; linux-musl-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm64"; version = "8.0.11"; hash = "sha512-KvNikPRuWtyDgZkbneySfA6MjX5VUfOwfq22GK5tRKc8xOtlsv08he6zx33Q8SW4ldu8f4K4uzMkO71EdQQmkQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-arm64"; version = "8.0.11"; hash = "sha512-lPAmNTIsRdMcvaN7rjnkvVc9a56RuNrDMi3H6rKo0ZS06Njoee1BFDeQ5wuUDWnvaMxnAwxZH5wPKAvt6LdT3Q=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm64"; version = "8.0.11"; hash = "sha512-+lz9eo9eSsaPNisaAeaUM7GtSaBilFyXnOFsVqt8nIn3tR/azvXAgzNj00Zy4QLJLiDMcr27eeNp8E7LKVI1mQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.11"; hash = "sha512-9faK+Tt1Lh0cttVCwWxL3KTW8gPyi6uGBRGtEuexwB1HlyPuiHDlXXOWMCzDKTg4Bsj2NkkgZQ6R7KlWB/0xGQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHost"; version = "8.0.11"; hash = "sha512-WpEunjmasr6EtDwl/Pts5pWq4XcgdOOX+qPtXrY5h+AnvEbagGGu7yTetroVy1yWkAXfWRxC2jp1KcPq+5b1Qg=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.11"; hash = "sha512-Wjx3q+xYAF1D62cjLodPV8k/i72yTKkQwYAUhXvlfdzddZvnkW18dWlw1twZm8TUx33JRbPAl8jokhEfnwPMQg=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.11"; hash = "sha512-1lU3Ir0DjkJyog5r/JZrFxzhSgQh/Mgt9fA216ixJyB3hwrDoi5H6mM49ORl6Y1K5gsFZFrYgT0ieB9y7B84KQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm64"; + version = "8.0.11"; + hash = "sha512-KvNikPRuWtyDgZkbneySfA6MjX5VUfOwfq22GK5tRKc8xOtlsv08he6zx33Q8SW4ldu8f4K4uzMkO71EdQQmkQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-arm64"; + version = "8.0.11"; + hash = "sha512-lPAmNTIsRdMcvaN7rjnkvVc9a56RuNrDMi3H6rKo0ZS06Njoee1BFDeQ5wuUDWnvaMxnAwxZH5wPKAvt6LdT3Q=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm64"; + version = "8.0.11"; + hash = "sha512-+lz9eo9eSsaPNisaAeaUM7GtSaBilFyXnOFsVqt8nIn3tR/azvXAgzNj00Zy4QLJLiDMcr27eeNp8E7LKVI1mQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.11"; + hash = "sha512-9faK+Tt1Lh0cttVCwWxL3KTW8gPyi6uGBRGtEuexwB1HlyPuiHDlXXOWMCzDKTg4Bsj2NkkgZQ6R7KlWB/0xGQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHost"; + version = "8.0.11"; + hash = "sha512-WpEunjmasr6EtDwl/Pts5pWq4XcgdOOX+qPtXrY5h+AnvEbagGGu7yTetroVy1yWkAXfWRxC2jp1KcPq+5b1Qg=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.11"; + hash = "sha512-Wjx3q+xYAF1D62cjLodPV8k/i72yTKkQwYAUhXvlfdzddZvnkW18dWlw1twZm8TUx33JRbPAl8jokhEfnwPMQg=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.11"; + hash = "sha512-1lU3Ir0DjkJyog5r/JZrFxzhSgQh/Mgt9fA216ixJyB3hwrDoi5H6mM49ORl6Y1K5gsFZFrYgT0ieB9y7B84KQ=="; + }) ]; linux-musl-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-x64"; version = "8.0.11"; hash = "sha512-SgTHU/z8LNomJAGsKH5HUvx5OizjB1WeqKsMzymgOubaRY7SgwH3mzrkO1ApZriU4UdDqr97pciMbxhlfaw89g=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-x64"; version = "8.0.11"; hash = "sha512-2H8/Pdrzex0K/3zI1TMciRlgz7Z7od83gC9qk9Fm6UI8cElOjfd1uFP8Fry4hd77cfAFEGLOH08nhSYVnpMFnw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-x64"; version = "8.0.11"; hash = "sha512-IH1SXwkdekKugXK6ODphFR1MhQKkrBjFgt4zvCeKqL38sv7pfXLmGQOYBmstdxsSbV47VXcKzoi28E2TbOVi+g=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.11"; hash = "sha512-V4y3EK0FOhOJ0gNCgkH1zb0jajXi3G/1fTRLFjmHYwHJN1xLnEyBFcQxZ/iKXSl8KhDJIoCZhq6PgXxy5FCw6w=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHost"; version = "8.0.11"; hash = "sha512-HZojWDGgsYfjMvNvwOqSI7BQrH0nn8CqHNJH29z2kv2Xf95wqAZAxOeWoURYiPINHi9MC2/zgxYOQ/OvBOHhYQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.11"; hash = "sha512-4ejFZQ55fKOR4efL+0zdjJNJgDsMbdLq/yahNWtaowMpVaIwCkb8crxZ5GnOFJbXm1QQ6iEWfw2n8PfHhXEbDA=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.11"; hash = "sha512-ZsS4BXtP1sl8vT9w4Zg4F1lnukUytSXjHALELUasI7tt5DthDPKfWb0ZPWxPOBIjqicx+fC6DrRlm5bLXxiAcQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.linux-musl-x64"; version = "8.0.11"; hash = "sha512-ieQVL36ljos0aLxaEUEZiVcNbpHFI0jXxkN6b5PEgl7FgI23wK21DfKCDjzLmSsq5Sc9KWTsjhGVZ113gRcT6g=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-x64"; + version = "8.0.11"; + hash = "sha512-SgTHU/z8LNomJAGsKH5HUvx5OizjB1WeqKsMzymgOubaRY7SgwH3mzrkO1ApZriU4UdDqr97pciMbxhlfaw89g=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-x64"; + version = "8.0.11"; + hash = "sha512-2H8/Pdrzex0K/3zI1TMciRlgz7Z7od83gC9qk9Fm6UI8cElOjfd1uFP8Fry4hd77cfAFEGLOH08nhSYVnpMFnw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-x64"; + version = "8.0.11"; + hash = "sha512-IH1SXwkdekKugXK6ODphFR1MhQKkrBjFgt4zvCeKqL38sv7pfXLmGQOYBmstdxsSbV47VXcKzoi28E2TbOVi+g=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.11"; + hash = "sha512-V4y3EK0FOhOJ0gNCgkH1zb0jajXi3G/1fTRLFjmHYwHJN1xLnEyBFcQxZ/iKXSl8KhDJIoCZhq6PgXxy5FCw6w=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHost"; + version = "8.0.11"; + hash = "sha512-HZojWDGgsYfjMvNvwOqSI7BQrH0nn8CqHNJH29z2kv2Xf95wqAZAxOeWoURYiPINHi9MC2/zgxYOQ/OvBOHhYQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.11"; + hash = "sha512-4ejFZQ55fKOR4efL+0zdjJNJgDsMbdLq/yahNWtaowMpVaIwCkb8crxZ5GnOFJbXm1QQ6iEWfw2n8PfHhXEbDA=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.11"; + hash = "sha512-ZsS4BXtP1sl8vT9w4Zg4F1lnukUytSXjHALELUasI7tt5DthDPKfWb0ZPWxPOBIjqicx+fC6DrRlm5bLXxiAcQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.linux-musl-x64"; + version = "8.0.11"; + hash = "sha512-ieQVL36ljos0aLxaEUEZiVcNbpHFI0jXxkN6b5PEgl7FgI23wK21DfKCDjzLmSsq5Sc9KWTsjhGVZ113gRcT6g=="; + }) ]; osx-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.osx-arm64"; version = "8.0.11"; hash = "sha512-djBsHftYzC802MFtYmZLn82/XcjKzVY+mV12PrfxrTqcyjw46HlY1ii5uJVQ0Bm4cbX7Oz1dHdzfDnpgAmQkYg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.osx-arm64"; version = "8.0.11"; hash = "sha512-Z7XeUhut6aToHi/cclEUICL45EdVBHv/rFjSPbz3/SARoDFoKia7wl3H61vKxpodTB2HmzFVmABTrdEF8N5uoA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.osx-arm64"; version = "8.0.11"; hash = "sha512-O0fvdSX/MwFSsueeQ7pM/jDagmwDi4V+J/utor3emVDtI8xjabav11icQJdM9HE0L62vppg1uT8IMUx9wuH1mg=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.11"; hash = "sha512-gjmmfG6V7HTSaVNvu06+NG+6/rH4Dpj7a4EM57MkRCEy3bNNVJ0S5DO8l6YveX3Ocx2k9XJtf8d2sRd9y+wyFQ=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHost"; version = "8.0.11"; hash = "sha512-1in90CWWJXmQ25lJs8WLsmLTNqGhCg38qd7n1PcaJ+hGZbJDloeoxvrYgDMib94G7zkMUSCCpNQkLWdS+AZZcg=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.11"; hash = "sha512-rqZJszTVrJ1AKSMLpg8o0lvFeJv9sYlfMWu2VGlsxnVJ7bXhx3zUTdPizpkfXLEkumsJHIyzA0dAU9JxG4aGBw=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.11"; hash = "sha512-54Y0CX4mpsMWF9gybFTYSPlRY0yp5N27pCidIxZwh1QNZRJgRadMS2J6uYKSBP5UNHxX4CZ2bP3mg/VU2YGixQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.osx-arm64"; version = "8.0.11"; hash = "sha512-5fNhWcWZf6r9dQe/gv1nAxgyBPyXZ8I3ta8C86R3oz2+6tv2hxYDioVgnQ3/pfY2RbaRXz/bv6s3/dK6+rtQ+w=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.osx-arm64"; + version = "8.0.11"; + hash = "sha512-djBsHftYzC802MFtYmZLn82/XcjKzVY+mV12PrfxrTqcyjw46HlY1ii5uJVQ0Bm4cbX7Oz1dHdzfDnpgAmQkYg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.osx-arm64"; + version = "8.0.11"; + hash = "sha512-Z7XeUhut6aToHi/cclEUICL45EdVBHv/rFjSPbz3/SARoDFoKia7wl3H61vKxpodTB2HmzFVmABTrdEF8N5uoA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.osx-arm64"; + version = "8.0.11"; + hash = "sha512-O0fvdSX/MwFSsueeQ7pM/jDagmwDi4V+J/utor3emVDtI8xjabav11icQJdM9HE0L62vppg1uT8IMUx9wuH1mg=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.11"; + hash = "sha512-gjmmfG6V7HTSaVNvu06+NG+6/rH4Dpj7a4EM57MkRCEy3bNNVJ0S5DO8l6YveX3Ocx2k9XJtf8d2sRd9y+wyFQ=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHost"; + version = "8.0.11"; + hash = "sha512-1in90CWWJXmQ25lJs8WLsmLTNqGhCg38qd7n1PcaJ+hGZbJDloeoxvrYgDMib94G7zkMUSCCpNQkLWdS+AZZcg=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.11"; + hash = "sha512-rqZJszTVrJ1AKSMLpg8o0lvFeJv9sYlfMWu2VGlsxnVJ7bXhx3zUTdPizpkfXLEkumsJHIyzA0dAU9JxG4aGBw=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.11"; + hash = "sha512-54Y0CX4mpsMWF9gybFTYSPlRY0yp5N27pCidIxZwh1QNZRJgRadMS2J6uYKSBP5UNHxX4CZ2bP3mg/VU2YGixQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.osx-arm64"; + version = "8.0.11"; + hash = "sha512-5fNhWcWZf6r9dQe/gv1nAxgyBPyXZ8I3ta8C86R3oz2+6tv2hxYDioVgnQ3/pfY2RbaRXz/bv6s3/dK6+rtQ+w=="; + }) ]; osx-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; version = "8.0.11"; hash = "sha512-XCnfmeGZy/faPQMhAa6ZSm2ij3s7poqYEhGdbWEds1LjqO6WBB0KkqtMiYGotZ9jJRXFbzMBXaTmAFE65iOGYA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.osx-x64"; version = "8.0.11"; hash = "sha512-zt3fmvA9clYIVjPsuFXfcB2nDpEkWYU2+5GsNPzTQSiyGfhWkXygGCLpbYvkpbXCH1q57Ax5Bxk/e1FR0Iipig=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.osx-x64"; version = "8.0.11"; hash = "sha512-dvh/3bJAzZEwKTxzhLojdmFebW/iu/+AAAJH1FiYlZsT9684etdqWWn9vfuYPwqUBBXUTNLkPMH9iRJNPtPP1g=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.11"; hash = "sha512-IcNYQJJ/wyqMjoib08W0Rgcnk841akaWAwesG28QIElxSNC8z5yh1dSM3QtatbyOALhckoWkI5ymTyzn9SDGrA=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHost"; version = "8.0.11"; hash = "sha512-p4QIeC7fy4fjphQIKSQ5+ykhfVE3/b+QS1/UmVqVnU5z7ch9eUjvxlliqwTDjpqCCW0yOXuvNhw/AFPH677LTA=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.11"; hash = "sha512-Q7F6ADk8beaPyGTlVSBIRJLujUmrFOqZ9P4qnnXSUFLiOAZRTHv59KRT1en0P5L+sf0hNjI2ngDkZJ9+BwfHgw=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.11"; hash = "sha512-grFkU1QmSjuqeclCBBPjkw/SHMIHjie0khK010q6E7GpMzmHDNas3sB/hfEeheJ9q0hkuV9eFlGkHp5abHp1kw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.osx-x64"; version = "8.0.11"; hash = "sha512-ha4JEhQExJugVmd4qMLi3Oot+NO5u9Vfqg5Cj/ndFoBq+qBQF88rsw0SqbmPbkpDJ9AW14sqgrWs1p4ixMIN6g=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; + version = "8.0.11"; + hash = "sha512-XCnfmeGZy/faPQMhAa6ZSm2ij3s7poqYEhGdbWEds1LjqO6WBB0KkqtMiYGotZ9jJRXFbzMBXaTmAFE65iOGYA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.osx-x64"; + version = "8.0.11"; + hash = "sha512-zt3fmvA9clYIVjPsuFXfcB2nDpEkWYU2+5GsNPzTQSiyGfhWkXygGCLpbYvkpbXCH1q57Ax5Bxk/e1FR0Iipig=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.osx-x64"; + version = "8.0.11"; + hash = "sha512-dvh/3bJAzZEwKTxzhLojdmFebW/iu/+AAAJH1FiYlZsT9684etdqWWn9vfuYPwqUBBXUTNLkPMH9iRJNPtPP1g=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.11"; + hash = "sha512-IcNYQJJ/wyqMjoib08W0Rgcnk841akaWAwesG28QIElxSNC8z5yh1dSM3QtatbyOALhckoWkI5ymTyzn9SDGrA=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHost"; + version = "8.0.11"; + hash = "sha512-p4QIeC7fy4fjphQIKSQ5+ykhfVE3/b+QS1/UmVqVnU5z7ch9eUjvxlliqwTDjpqCCW0yOXuvNhw/AFPH677LTA=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.11"; + hash = "sha512-Q7F6ADk8beaPyGTlVSBIRJLujUmrFOqZ9P4qnnXSUFLiOAZRTHv59KRT1en0P5L+sf0hNjI2ngDkZJ9+BwfHgw=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.11"; + hash = "sha512-grFkU1QmSjuqeclCBBPjkw/SHMIHjie0khK010q6E7GpMzmHDNas3sB/hfEeheJ9q0hkuV9eFlGkHp5abHp1kw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.osx-x64"; + version = "8.0.11"; + hash = "sha512-ha4JEhQExJugVmd4qMLi3Oot+NO5u9Vfqg5Cj/ndFoBq+qBQF88rsw0SqbmPbkpDJ9AW14sqgrWs1p4ixMIN6g=="; + }) ]; win-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-arm64"; version = "8.0.11"; hash = "sha512-Z1yy2Lm+mF/pNfun1zTI4WcWfkB5J80pRbRY+Bi3zpVcuTYARaCIqqYCcs+RSsdGZyIsyxY5GCVtNnnS/Mr2gw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-arm64"; version = "8.0.11"; hash = "sha512-UwOxMcccBMa+nayzQINw98K8TdOe2gtInabbUhAtPglu9mn5KFplImezdd5ZctE1YPuVrsa79abrTnY+eHdsXg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-arm64"; version = "8.0.11"; hash = "sha512-afq9u/kUUNRlECwgdngwlaCEIJVYzdKzJZfjklHK9UBoK61OpmrIhXYfhSIAr6/yOlkoWeq5Hn7uPoLEDWxwnA=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.11"; hash = "sha512-0HUP7epr4Szr5mgx0UHtU/B5o1PcC4SuJPUrmCFVkua4gZ7liNd5In0GE5Tmbt53+bqT1C3NyD6v3Rqhqzi7EQ=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHost"; version = "8.0.11"; hash = "sha512-8m49BIg9HtqZLxXt9N8rT/NlcUlLTaQMPHYzs2LbHMrlAXDatTVxZHW9lF312BBWjn1zQfAJqMtyibQtfmVKrg=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.11"; hash = "sha512-rCM/d2VWCY+GpW6nTlFPICc1rMyw+qM+67X7r5yJDOwGrNSqYz3xeqi7ewP+aXYmIoQV71Od+Jb86oqOB2SDXg=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.11"; hash = "sha512-PfwwvgpVmN83swqQhY4feqInM34XqsVbOeiXlKJEOgmwyKUj0cjHVidiu4HYBhy6jcOKla2uK25KTYebKqTx2Q=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-arm64"; + version = "8.0.11"; + hash = "sha512-Z1yy2Lm+mF/pNfun1zTI4WcWfkB5J80pRbRY+Bi3zpVcuTYARaCIqqYCcs+RSsdGZyIsyxY5GCVtNnnS/Mr2gw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-arm64"; + version = "8.0.11"; + hash = "sha512-UwOxMcccBMa+nayzQINw98K8TdOe2gtInabbUhAtPglu9mn5KFplImezdd5ZctE1YPuVrsa79abrTnY+eHdsXg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-arm64"; + version = "8.0.11"; + hash = "sha512-afq9u/kUUNRlECwgdngwlaCEIJVYzdKzJZfjklHK9UBoK61OpmrIhXYfhSIAr6/yOlkoWeq5Hn7uPoLEDWxwnA=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.11"; + hash = "sha512-0HUP7epr4Szr5mgx0UHtU/B5o1PcC4SuJPUrmCFVkua4gZ7liNd5In0GE5Tmbt53+bqT1C3NyD6v3Rqhqzi7EQ=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHost"; + version = "8.0.11"; + hash = "sha512-8m49BIg9HtqZLxXt9N8rT/NlcUlLTaQMPHYzs2LbHMrlAXDatTVxZHW9lF312BBWjn1zQfAJqMtyibQtfmVKrg=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.11"; + hash = "sha512-rCM/d2VWCY+GpW6nTlFPICc1rMyw+qM+67X7r5yJDOwGrNSqYz3xeqi7ewP+aXYmIoQV71Od+Jb86oqOB2SDXg=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.11"; + hash = "sha512-PfwwvgpVmN83swqQhY4feqInM34XqsVbOeiXlKJEOgmwyKUj0cjHVidiu4HYBhy6jcOKla2uK25KTYebKqTx2Q=="; + }) ]; win-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-x64"; version = "8.0.11"; hash = "sha512-VkSu/oOIMPemlIf5ARuFXmmndocYjub5ut3/5JXAz5sSBKrpeWciGnsUDnnshaWHP3jK4JCj3TBds7heldom3Q=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-x64"; version = "8.0.11"; hash = "sha512-MmTlraMVCA4AWhuhG0ceYMOOjzCFLM5sydkoAUCLh43VoQOgzHMCa6BhxSzdXdcOuJ6VTHukMG72+NEm4TvL5w=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-x64"; version = "8.0.11"; hash = "sha512-9gYW5whLNQolY5oTcOSv9cQxfHujDOOUXjorA/GMlOhTM1iXvzrBbPuWnDjFywYznZBkE0ZiYc1jVKQUKJ2D7w=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetAppHost"; version = "8.0.11"; hash = "sha512-+rAOixUutqpDATvg/QBxT1Wr5kAG0GOUWR1f3d7QjwTnzz2rQI7I2e+oDa+RYy0yMv0+Ih6AhHFuBC+52H2ZCA=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetHost"; version = "8.0.11"; hash = "sha512-bhY1zLDtLxQf/DRCLy/V4/tXZGeBI0rWA7epKyItxfvlhEh77GOnmIc9VGyLH4B+WXNJFfWB/rTUhWGaJyzpww=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.11"; hash = "sha512-NOZYMy4egQP04ohvziFDIRDEm1tHyMme4SCxWKh6y3BVHZ0BoENVryLq2Ko/DqoBuMF4tDjUFPi1bcofEl7Xtg=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.11"; hash = "sha512-wDwiNdA0vNfgwZgCe+a7FpbAiUENRcOoy3CUW7Y/5Kfc25qYWNONz9v2BfyBDLRYExth534ZpILww3QkPmsiaQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.win-x64"; version = "8.0.11"; hash = "sha512-eEgNGyaapr2MeHDmvfJuVPMavmtS7XdBd8xSgKWF64Yuo7mXoCtcgWzagG7BGDg65mW2vyFKE1iidZ9viVNbAQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-x64"; + version = "8.0.11"; + hash = "sha512-VkSu/oOIMPemlIf5ARuFXmmndocYjub5ut3/5JXAz5sSBKrpeWciGnsUDnnshaWHP3jK4JCj3TBds7heldom3Q=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-x64"; + version = "8.0.11"; + hash = "sha512-MmTlraMVCA4AWhuhG0ceYMOOjzCFLM5sydkoAUCLh43VoQOgzHMCa6BhxSzdXdcOuJ6VTHukMG72+NEm4TvL5w=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-x64"; + version = "8.0.11"; + hash = "sha512-9gYW5whLNQolY5oTcOSv9cQxfHujDOOUXjorA/GMlOhTM1iXvzrBbPuWnDjFywYznZBkE0ZiYc1jVKQUKJ2D7w=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.11"; + hash = "sha512-+rAOixUutqpDATvg/QBxT1Wr5kAG0GOUWR1f3d7QjwTnzz2rQI7I2e+oDa+RYy0yMv0+Ih6AhHFuBC+52H2ZCA=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetHost"; + version = "8.0.11"; + hash = "sha512-bhY1zLDtLxQf/DRCLy/V4/tXZGeBI0rWA7epKyItxfvlhEh77GOnmIc9VGyLH4B+WXNJFfWB/rTUhWGaJyzpww=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.11"; + hash = "sha512-NOZYMy4egQP04ohvziFDIRDEm1tHyMme4SCxWKh6y3BVHZ0BoENVryLq2Ko/DqoBuMF4tDjUFPi1bcofEl7Xtg=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.11"; + hash = "sha512-wDwiNdA0vNfgwZgCe+a7FpbAiUENRcOoy3CUW7Y/5Kfc25qYWNONz9v2BfyBDLRYExth534ZpILww3QkPmsiaQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.win-x64"; + version = "8.0.11"; + hash = "sha512-eEgNGyaapr2MeHDmvfJuVPMavmtS7XdBd8xSgKWF64Yuo7mXoCtcgWzagG7BGDg65mW2vyFKE1iidZ9viVNbAQ=="; + }) ]; win-x86 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-x86"; version = "8.0.11"; hash = "sha512-OPIUdM0ZFxcAzoVqJIy1qr4X6Tc8jQw8J1rsjrUL5iR24YGPT1kcSyC78G4S5F7kIRykjg8bnMRgLxiJ2B3THA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-x86"; version = "8.0.11"; hash = "sha512-KF5x+GlRfAUjPvNz02f4UrwuyWydvu8kSlKpZCxH0EArR1rOX+8jgpEZGJQxl7NzPSpbkPoRcvwTicX+s5jLrQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-x86"; version = "8.0.11"; hash = "sha512-BlTSt0qIs80/SxvdNEtiGl+kLn1ThEcKroQtc4gqoK3FPRIOyMFBfp9qEJZnVZdcDHVt7hGN1mPKUup+Qbesxw=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetAppHost"; version = "8.0.11"; hash = "sha512-gGiAe5PJBNcmIRevQZnyBBM4KOgR+oLvMPGQxOvb5nGRxCXO41LnBtTQO+iZY8A6C4nBfD5pmis4+kluDbgxuA=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetHost"; version = "8.0.11"; hash = "sha512-hZJfqP/8rnKc3jKJVLnAvcdsJzFIkFh80eBVatyeAGjUpp1I+lbmqGgnMbsWmA0Av4kBtylpmrv09ZId1g0GjA=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostPolicy"; version = "8.0.11"; hash = "sha512-UW/jpK2X+Wvpj/lymy/31jZBQK+Q7oTSeNUxMZxEiv/1sk740ah4kGYsxVSlQmx+D6M2T+Yn/JCYgCBEDaTfug=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostResolver"; version = "8.0.11"; hash = "sha512-Zxw2Fnc7jzpqT0M36wTYAeqJ1qZKXrStOBfjKY3OYMfGIsLd10dEwiHYcNAKbDlzmOFxU7UlZoxWcBCz1pMFag=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.Mono.win-x86"; version = "8.0.11"; hash = "sha512-Kr/G3KP5rXMURU82OJ0jSTCweYg3vnCcUXk6D+SvR64JYEC0DC5x5nDnMLnbTulB4S4NRJvFClVwFUzTJyzc6g=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-x86"; + version = "8.0.11"; + hash = "sha512-OPIUdM0ZFxcAzoVqJIy1qr4X6Tc8jQw8J1rsjrUL5iR24YGPT1kcSyC78G4S5F7kIRykjg8bnMRgLxiJ2B3THA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-x86"; + version = "8.0.11"; + hash = "sha512-KF5x+GlRfAUjPvNz02f4UrwuyWydvu8kSlKpZCxH0EArR1rOX+8jgpEZGJQxl7NzPSpbkPoRcvwTicX+s5jLrQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-x86"; + version = "8.0.11"; + hash = "sha512-BlTSt0qIs80/SxvdNEtiGl+kLn1ThEcKroQtc4gqoK3FPRIOyMFBfp9qEJZnVZdcDHVt7hGN1mPKUup+Qbesxw=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetAppHost"; + version = "8.0.11"; + hash = "sha512-gGiAe5PJBNcmIRevQZnyBBM4KOgR+oLvMPGQxOvb5nGRxCXO41LnBtTQO+iZY8A6C4nBfD5pmis4+kluDbgxuA=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetHost"; + version = "8.0.11"; + hash = "sha512-hZJfqP/8rnKc3jKJVLnAvcdsJzFIkFh80eBVatyeAGjUpp1I+lbmqGgnMbsWmA0Av4kBtylpmrv09ZId1g0GjA=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostPolicy"; + version = "8.0.11"; + hash = "sha512-UW/jpK2X+Wvpj/lymy/31jZBQK+Q7oTSeNUxMZxEiv/1sk740ah4kGYsxVSlQmx+D6M2T+Yn/JCYgCBEDaTfug=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetHostResolver"; + version = "8.0.11"; + hash = "sha512-Zxw2Fnc7jzpqT0M36wTYAeqJ1qZKXrStOBfjKY3OYMfGIsLd10dEwiHYcNAKbDlzmOFxU7UlZoxWcBCz1pMFag=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.Mono.win-x86"; + version = "8.0.11"; + hash = "sha512-Kr/G3KP5rXMURU82OJ0jSTCweYg3vnCcUXk6D+SvR64JYEC0DC5x5nDnMLnbTulB4S4NRJvFClVwFUzTJyzc6g=="; + }) ]; }; -in rec { +in +rec { release_8_0 = "8.0.11"; aspnetcore_8_0 = buildAspNetCore { diff --git a/pkgs/development/compilers/dotnet/versions/9.0.nix b/pkgs/development/compilers/dotnet/versions/9.0.nix index 3afb110ccbd792..2676b78f949155 100644 --- a/pkgs/development/compilers/dotnet/versions/9.0.nix +++ b/pkgs/development/compilers/dotnet/versions/9.0.nix @@ -1,130 +1,408 @@ -{ buildAspNetCore, buildNetRuntime, buildNetSdk, fetchNupkg }: +{ + buildAspNetCore, + buildNetRuntime, + buildNetSdk, + fetchNupkg, +}: # v9.0 (active) let commonPackages = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Ref"; version = "9.0.0"; hash = "sha512-Gw0hOfzWemlJgdGucGfWdU0H7kFmE57x1lFLNJddRzbGi6r5Dv4T9+ySMXHj5MEU09iBRUig6rxsGu0XDsB1ZQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.DotNetAppHost"; version = "9.0.0"; hash = "sha512-pJWUhSWVDFIk8Cq/lWdBuedQk2m+uWBqKvGCmkpTXrx+22s/qE+D5gNvqMNX55QyyERg8hK3L3wMpbFkf2Mjyw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Ref"; version = "9.0.0"; hash = "sha512-s9us2abMLwrWpH1glRbjlMhbwCLvq6MhVBwcAjCqeD36kgBT6rx8PA9Ro8W6715QvRz9luJPJLUd1A1Im5QjAA=="; }) - (fetchNupkg { pname = "Microsoft.DotNet.ILCompiler"; version = "9.0.0"; hash = "sha512-VlXpaCL4/ZBq1vlW/58bwm9hNd2MXRiwPXhvfclsLMJ2j6fJaaX2AmB3XsgIWYlageW0FY1v+QmyhrIfmKJGxg=="; }) - (fetchNupkg { pname = "Microsoft.NET.ILLink.Tasks"; version = "9.0.0"; hash = "sha512-xg196uBfnUmJlc5aizfTi588MyruI9Hlvaqj3mMbx1J9GfpF+t3gdWR6uKbH0lVW9oxzJ7FgX7NWZEZj33j0ag=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Ref"; + version = "9.0.0"; + hash = "sha512-Gw0hOfzWemlJgdGucGfWdU0H7kFmE57x1lFLNJddRzbGi6r5Dv4T9+ySMXHj5MEU09iBRUig6rxsGu0XDsB1ZQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0"; + hash = "sha512-pJWUhSWVDFIk8Cq/lWdBuedQk2m+uWBqKvGCmkpTXrx+22s/qE+D5gNvqMNX55QyyERg8hK3L3wMpbFkf2Mjyw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Ref"; + version = "9.0.0"; + hash = "sha512-s9us2abMLwrWpH1glRbjlMhbwCLvq6MhVBwcAjCqeD36kgBT6rx8PA9Ro8W6715QvRz9luJPJLUd1A1Im5QjAA=="; + }) + (fetchNupkg { + pname = "Microsoft.DotNet.ILCompiler"; + version = "9.0.0"; + hash = "sha512-VlXpaCL4/ZBq1vlW/58bwm9hNd2MXRiwPXhvfclsLMJ2j6fJaaX2AmB3XsgIWYlageW0FY1v+QmyhrIfmKJGxg=="; + }) + (fetchNupkg { + pname = "Microsoft.NET.ILLink.Tasks"; + version = "9.0.0"; + hash = "sha512-xg196uBfnUmJlc5aizfTi588MyruI9Hlvaqj3mMbx1J9GfpF+t3gdWR6uKbH0lVW9oxzJ7FgX7NWZEZj33j0ag=="; + }) ]; hostPackages = { linux-arm = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-arm"; version = "9.0.0"; hash = "sha512-MkXLF7urjdN5Qk0oFktLozf9TlM4q7WP+6z4eHa2Cwu3YWWnsbkxjTg+z04nNZA9OI0LLMRrxrJyVEg5HuIrTg=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-arm"; + version = "9.0.0"; + hash = "sha512-MkXLF7urjdN5Qk0oFktLozf9TlM4q7WP+6z4eHa2Cwu3YWWnsbkxjTg+z04nNZA9OI0LLMRrxrJyVEg5HuIrTg=="; + }) ]; linux-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-arm64"; version = "9.0.0"; hash = "sha512-Dn/V8lDW3q3C/U13fkAn1wJLNgwZ6XaMcb0vOXZROW32Ae1mEk9jFOnpRNbzCpFKQUGJX6Sg8/ift5ltX3/4dQ=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.DotNet.ILCompiler"; version = "9.0.0"; hash = "sha512-3FZilMq21HAH5zXmB0KL7WnMdqHitJLkzqw/FgEiVdG3rECHttxo09htp+jIenDs8J8HitoYW/Xw2Drm7UaU0g=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-arm64"; + version = "9.0.0"; + hash = "sha512-Dn/V8lDW3q3C/U13fkAn1wJLNgwZ6XaMcb0vOXZROW32Ae1mEk9jFOnpRNbzCpFKQUGJX6Sg8/ift5ltX3/4dQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0"; + hash = "sha512-3FZilMq21HAH5zXmB0KL7WnMdqHitJLkzqw/FgEiVdG3rECHttxo09htp+jIenDs8J8HitoYW/Xw2Drm7UaU0g=="; + }) ]; linux-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-x64"; version = "9.0.0"; hash = "sha512-tnBxVIvOo6DjRViwBjJcyljpsMZnM46Y1vBqM8AbMM1fO0BcKPbJS88GmnQ3q0rNWmi6G2VY7UYHl/+9phcGCA=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.DotNet.ILCompiler"; version = "9.0.0"; hash = "sha512-m9rQyHa8k6tmG9ZV2JyXYqG8o1gEFw8uh8mP7lRKWetA1ceXjPfZUEwKBXMxa+749G2ELibL696YL2YY+Z+C0A=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-x64"; + version = "9.0.0"; + hash = "sha512-tnBxVIvOo6DjRViwBjJcyljpsMZnM46Y1vBqM8AbMM1fO0BcKPbJS88GmnQ3q0rNWmi6G2VY7UYHl/+9phcGCA=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0"; + hash = "sha512-m9rQyHa8k6tmG9ZV2JyXYqG8o1gEFw8uh8mP7lRKWetA1ceXjPfZUEwKBXMxa+749G2ELibL696YL2YY+Z+C0A=="; + }) ]; linux-musl-arm = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm"; version = "9.0.0"; hash = "sha512-URG+5zlHdvC03qzMEzlb8i8bYaY5j5BaVm3u9+6qDE/1xcb0SZrzvJK2TS5UjszUmCEyYeloFDBx6FQtEk4bag=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm"; + version = "9.0.0"; + hash = "sha512-URG+5zlHdvC03qzMEzlb8i8bYaY5j5BaVm3u9+6qDE/1xcb0SZrzvJK2TS5UjszUmCEyYeloFDBx6FQtEk4bag=="; + }) ]; linux-musl-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm64"; version = "9.0.0"; hash = "sha512-Ycj0j/VDvek7/rM8hYldSVHtkk3UBntDz/D+iwHVF3oc3QkEyEwPQFhM9uINEFTHIR9vwRE4DdhQfTgdsvlong=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.DotNet.ILCompiler"; version = "9.0.0"; hash = "sha512-+64gZ7mG3UKNt0ijOiYcyfVBGsFTM0n2Buyf6EFJNTExqfyaH1G/YjrVO8XM4q2KTV5MrWLSYyhIVvl/ZhaitA=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-arm64"; + version = "9.0.0"; + hash = "sha512-Ycj0j/VDvek7/rM8hYldSVHtkk3UBntDz/D+iwHVF3oc3QkEyEwPQFhM9uINEFTHIR9vwRE4DdhQfTgdsvlong=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0"; + hash = "sha512-+64gZ7mG3UKNt0ijOiYcyfVBGsFTM0n2Buyf6EFJNTExqfyaH1G/YjrVO8XM4q2KTV5MrWLSYyhIVvl/ZhaitA=="; + }) ]; linux-musl-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-x64"; version = "9.0.0"; hash = "sha512-kdpajBOhxRjilUH7obuBN8Vj4yTlZlhemNTJ6FTHp60hNv4cINCs7IEnvzkC9TNuDAJNJyP543y+61QpIie4Cg=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.DotNet.ILCompiler"; version = "9.0.0"; hash = "sha512-S3FR1/F/xxAA/LkqaPT+v8lWXxFvTJsCqyhMtFgYLKlAseXtZx7KE6t6a8xEgRJ5mdjA2d+MJFijfPw7ZKfaPQ=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.linux-musl-x64"; + version = "9.0.0"; + hash = "sha512-kdpajBOhxRjilUH7obuBN8Vj4yTlZlhemNTJ6FTHp60hNv4cINCs7IEnvzkC9TNuDAJNJyP543y+61QpIie4Cg=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0"; + hash = "sha512-S3FR1/F/xxAA/LkqaPT+v8lWXxFvTJsCqyhMtFgYLKlAseXtZx7KE6t6a8xEgRJ5mdjA2d+MJFijfPw7ZKfaPQ=="; + }) ]; osx-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.osx-arm64"; version = "9.0.0"; hash = "sha512-2xbup0BwwwyAl9zH8U4WFrs0lh+24/WOoVn3xCaFZ4dzCpScFzE0qLZNhlBkY/EuDrbpVS1xf1toWbsZGju7xw=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.DotNet.ILCompiler"; version = "9.0.0"; hash = "sha512-wMon7mG3IkoRuzmtu/XSaUA7k93y7zUp84/cIzbRPHn2kc3bpBf1ICBgEibi+buNAsicGXgDa28hEjlI9ij/vA=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.osx-arm64"; + version = "9.0.0"; + hash = "sha512-2xbup0BwwwyAl9zH8U4WFrs0lh+24/WOoVn3xCaFZ4dzCpScFzE0qLZNhlBkY/EuDrbpVS1xf1toWbsZGju7xw=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0"; + hash = "sha512-wMon7mG3IkoRuzmtu/XSaUA7k93y7zUp84/cIzbRPHn2kc3bpBf1ICBgEibi+buNAsicGXgDa28hEjlI9ij/vA=="; + }) ]; osx-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.osx-x64"; version = "9.0.0"; hash = "sha512-KsYxh+x62uTiWcHcFPoB4inYAShiQoORJf8mUtqdpI1CEDgUNtnCM5jFiBiuCAekMfA9xNfy0lsU4yHyg8MjzA=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.DotNet.ILCompiler"; version = "9.0.0"; hash = "sha512-l4xnwu5ZQc+J++LyO+cMojdjQw48IdkVqgmUc+SF/U+A6t0Apj0RCtB07XLDtpFzTR9HPY5RaE38+AZhE15Uqg=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.osx-x64"; + version = "9.0.0"; + hash = "sha512-KsYxh+x62uTiWcHcFPoB4inYAShiQoORJf8mUtqdpI1CEDgUNtnCM5jFiBiuCAekMfA9xNfy0lsU4yHyg8MjzA=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0"; + hash = "sha512-l4xnwu5ZQc+J++LyO+cMojdjQw48IdkVqgmUc+SF/U+A6t0Apj0RCtB07XLDtpFzTR9HPY5RaE38+AZhE15Uqg=="; + }) ]; win-arm64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-arm64"; version = "9.0.0"; hash = "sha512-JQxa7mSZVVL9H6s/R8/5UOZSe8EekbTE4u4FFVydSyxi+mqryNTGC2Cf7YgbfFzWasDEqNtoSOhqXA7MJFHlDA=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.DotNet.ILCompiler"; version = "9.0.0"; hash = "sha512-xrNYFUC3PWZuZxiKKBF4Re/zsyrA81uLMTnEENkqPdYI6eNabAvcGsBi7wP5mfaFtRWPbete5k5S+kOlpCpw/Q=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-arm64"; + version = "9.0.0"; + hash = "sha512-JQxa7mSZVVL9H6s/R8/5UOZSe8EekbTE4u4FFVydSyxi+mqryNTGC2Cf7YgbfFzWasDEqNtoSOhqXA7MJFHlDA=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0"; + hash = "sha512-xrNYFUC3PWZuZxiKKBF4Re/zsyrA81uLMTnEENkqPdYI6eNabAvcGsBi7wP5mfaFtRWPbete5k5S+kOlpCpw/Q=="; + }) ]; win-x64 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-x64"; version = "9.0.0"; hash = "sha512-B6Noyuo7Nx6lH+scXSUE0J8IxteoJWzpdgXkb2CO3MhSeaL06KLg51q8ATxmx5gs7emHV4sHxBq87k8U7KZxuw=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.DotNet.ILCompiler"; version = "9.0.0"; hash = "sha512-P59aR9VD9GjI7ONAAK1SVjEJfZEJCpLFo9CVLe8raRdmq1MWg/eQ1sXR2AR50GPmciSCBpIq8rDAYZLsCiLx6w=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-x64"; + version = "9.0.0"; + hash = "sha512-B6Noyuo7Nx6lH+scXSUE0J8IxteoJWzpdgXkb2CO3MhSeaL06KLg51q8ATxmx5gs7emHV4sHxBq87k8U7KZxuw=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.DotNet.ILCompiler"; + version = "9.0.0"; + hash = "sha512-P59aR9VD9GjI7ONAAK1SVjEJfZEJCpLFo9CVLe8raRdmq1MWg/eQ1sXR2AR50GPmciSCBpIq8rDAYZLsCiLx6w=="; + }) ]; win-x86 = [ - (fetchNupkg { pname = "Microsoft.NETCore.App.Crossgen2.win-x86"; version = "9.0.0"; hash = "sha512-19GSA4/P5CMvqjkInp7rBySTKmE1i0KjtYtYCv5TAesvFbyY+tJRQjUJsHUB1LxYqdi7MNXR6jvcW1O6x67K3g=="; }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Crossgen2.win-x86"; + version = "9.0.0"; + hash = "sha512-19GSA4/P5CMvqjkInp7rBySTKmE1i0KjtYtYCv5TAesvFbyY+tJRQjUJsHUB1LxYqdi7MNXR6jvcW1O6x67K3g=="; + }) ]; }; targetPackages = { linux-arm = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm"; version = "9.0.0"; hash = "sha512-yNSYhFO714aiRTgQz+NSxmZ8KaXGYi8MtTyP9pG8H3Q7tQOPvhd3EhJothBasIjNGHeVoedQRBGXLHWLlHr8sQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-arm"; version = "9.0.0"; hash = "sha512-doUaAKbTQQTvU+5c0WvENx822NekyJqKlfzLhNDh7v7lC/syq9RUApQxyOffWpLa7a11L9r7yf02ZdKACXgeyA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-arm"; version = "9.0.0"; hash = "sha512-mDuNiquAA808YwpS+Z3RKbGYnnx7VCINSEYWYNUE55HBfR+lSe7NxRB+Ed4XxVOaBbeG2aP/yqzJjKEYP7kNew=="; }) - (fetchNupkg { pname = "runtime.linux-arm.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0"; hash = "sha512-VLRDQ84utnUvatZO4YTkHJCwdWgHm7zxxNEZ0xtp52dDBye2UVcwXY1ZNrKx2vRfKi5zTLHbOi0fGTAbK+TLOw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm"; + version = "9.0.0"; + hash = "sha512-yNSYhFO714aiRTgQz+NSxmZ8KaXGYi8MtTyP9pG8H3Q7tQOPvhd3EhJothBasIjNGHeVoedQRBGXLHWLlHr8sQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-arm"; + version = "9.0.0"; + hash = "sha512-doUaAKbTQQTvU+5c0WvENx822NekyJqKlfzLhNDh7v7lC/syq9RUApQxyOffWpLa7a11L9r7yf02ZdKACXgeyA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-arm"; + version = "9.0.0"; + hash = "sha512-mDuNiquAA808YwpS+Z3RKbGYnnx7VCINSEYWYNUE55HBfR+lSe7NxRB+Ed4XxVOaBbeG2aP/yqzJjKEYP7kNew=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0"; + hash = "sha512-VLRDQ84utnUvatZO4YTkHJCwdWgHm7zxxNEZ0xtp52dDBye2UVcwXY1ZNrKx2vRfKi5zTLHbOi0fGTAbK+TLOw=="; + }) ]; linux-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; version = "9.0.0"; hash = "sha512-DyQUA+74c4fjGgqGpTnXXkT5r03GSndeem3J7F2O+WsHg7nn87KHi2LR9y8RJWXHD9ceSOVMBvTLulM+VvRuOg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-arm64"; version = "9.0.0"; hash = "sha512-f7cPFLvJA1v08v1EtfcC8bKE1WFM6AU2YhhKrid5HZLDD1e71TXFMT2eLawwsoOJxnKG+rD1ERtySgvMYPWh8Q=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; version = "9.0.0"; hash = "sha512-0v/YP+0hkr7yzvzGKhNzS9/wAknQtH6uH9k04NfIp5inCjq9LxWsL+S4YCINDwVX1oVeUS//AVv2T4sDuhIzjg=="; }) - (fetchNupkg { pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0"; hash = "sha512-J0HoXQwGxVap8DLmheMeYu+Gr7UR4k51wV+q30A9rfaT33WJoWVe/aheXdYDgkxmGnKK/Cr8ScEDtD6oS+yb/w=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-arm64"; + version = "9.0.0"; + hash = "sha512-DyQUA+74c4fjGgqGpTnXXkT5r03GSndeem3J7F2O+WsHg7nn87KHi2LR9y8RJWXHD9ceSOVMBvTLulM+VvRuOg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-arm64"; + version = "9.0.0"; + hash = "sha512-f7cPFLvJA1v08v1EtfcC8bKE1WFM6AU2YhhKrid5HZLDD1e71TXFMT2eLawwsoOJxnKG+rD1ERtySgvMYPWh8Q=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-arm64"; + version = "9.0.0"; + hash = "sha512-0v/YP+0hkr7yzvzGKhNzS9/wAknQtH6uH9k04NfIp5inCjq9LxWsL+S4YCINDwVX1oVeUS//AVv2T4sDuhIzjg=="; + }) + (fetchNupkg { + pname = "runtime.linux-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0"; + hash = "sha512-J0HoXQwGxVap8DLmheMeYu+Gr7UR4k51wV+q30A9rfaT33WJoWVe/aheXdYDgkxmGnKK/Cr8ScEDtD6oS+yb/w=="; + }) ]; linux-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; version = "9.0.0"; hash = "sha512-ah1ir1EEeGSshjAkKp8lfdl44WOYXFZmcydvORnQIs3IeKCkwhQTZNkgZOwieT1NtGB0TLbc0h1FSV6sURlnuQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-x64"; version = "9.0.0"; hash = "sha512-va4ruzadg4nK1wM8PzDoqLFTNypO0kgVVkiV7+3wKWuYflwdYwWNpae5qKjmsLB0uLNrljBT3JSErksU6YpfkQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-x64"; version = "9.0.0"; hash = "sha512-tT2j+X8saJn9J+3iM6MoJwv5kEAhWyuwPeZZipq266YDIlwEaW2FDjoWCJJVLC3vCDidHlnTT6IKUv/LMKKpWA=="; }) - (fetchNupkg { pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0"; hash = "sha512-DEuteVFMIIUgkI55r+/kTQq2PMcaxj0iGxLs6CG9YFbfwvHqduq7MA2pqdonhL/6Emg1qFASw9LafjaIIfBqJA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-x64"; + version = "9.0.0"; + hash = "sha512-ah1ir1EEeGSshjAkKp8lfdl44WOYXFZmcydvORnQIs3IeKCkwhQTZNkgZOwieT1NtGB0TLbc0h1FSV6sURlnuQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-x64"; + version = "9.0.0"; + hash = "sha512-va4ruzadg4nK1wM8PzDoqLFTNypO0kgVVkiV7+3wKWuYflwdYwWNpae5qKjmsLB0uLNrljBT3JSErksU6YpfkQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-x64"; + version = "9.0.0"; + hash = "sha512-tT2j+X8saJn9J+3iM6MoJwv5kEAhWyuwPeZZipq266YDIlwEaW2FDjoWCJJVLC3vCDidHlnTT6IKUv/LMKKpWA=="; + }) + (fetchNupkg { + pname = "runtime.linux-x64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0"; + hash = "sha512-DEuteVFMIIUgkI55r+/kTQq2PMcaxj0iGxLs6CG9YFbfwvHqduq7MA2pqdonhL/6Emg1qFASw9LafjaIIfBqJA=="; + }) ]; linux-musl-arm = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm"; version = "9.0.0"; hash = "sha512-cjxki6OzyNfxncBFL1NjgXruHitIQjlyxjwXewOqkNqYU2EOxyKWhcxxOzavgw00x/izuvooDrvpNari5cSJng=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-arm"; version = "9.0.0"; hash = "sha512-PkTgJhN3fhoJuynpjWPi7JZyGgOJ5EpwKWtOUPRiXLJj2Tqp3gKMdYvZz4pjEJm6KK+T6iWyUZRUr/WYRme+UQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm"; version = "9.0.0"; hash = "sha512-SgafbwsE40tFUABR9rlfA+9YQenUei89fakk0SlNHUZPX9tkhHo0A5gXY3/Sdt88HlLOUCD+pmM7Nn8R2CdbBQ=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0"; hash = "sha512-aLoTcH9BTv7AuFML2fiqFdha09b8ETG+OJTP5mx7ER7taT9quMoUu7WJk2L8r0k/QdBoxh5qcqLKYjRVCoQ6IQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm"; + version = "9.0.0"; + hash = "sha512-cjxki6OzyNfxncBFL1NjgXruHitIQjlyxjwXewOqkNqYU2EOxyKWhcxxOzavgw00x/izuvooDrvpNari5cSJng=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-arm"; + version = "9.0.0"; + hash = "sha512-PkTgJhN3fhoJuynpjWPi7JZyGgOJ5EpwKWtOUPRiXLJj2Tqp3gKMdYvZz4pjEJm6KK+T6iWyUZRUr/WYRme+UQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm"; + version = "9.0.0"; + hash = "sha512-SgafbwsE40tFUABR9rlfA+9YQenUei89fakk0SlNHUZPX9tkhHo0A5gXY3/Sdt88HlLOUCD+pmM7Nn8R2CdbBQ=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0"; + hash = "sha512-aLoTcH9BTv7AuFML2fiqFdha09b8ETG+OJTP5mx7ER7taT9quMoUu7WJk2L8r0k/QdBoxh5qcqLKYjRVCoQ6IQ=="; + }) ]; linux-musl-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm64"; version = "9.0.0"; hash = "sha512-penFoYejLCetGFWNXlUma/LbCZKXQMzGjKaoTMLupQtvjc3ZKM/i+n7uBXbRPTd3o9kYus7fCPtNnjk9lI5cPA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-arm64"; version = "9.0.0"; hash = "sha512-nVvMcj58prH57guq7lLE6de9KgTjAt18JTu9wXTsnNwQrOyAgZevzM3OpB4clZ1aqkqCKZZ8fuMgpPEbfyaTCw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm64"; version = "9.0.0"; hash = "sha512-jqfZ0ZboGYYa0KWArvYaO4Ddw0TMnLDkYVHtgKVfdFlaVon+KpM96yykbqmHLr1UUkDXDHNNFtHwnpVXmbmUOw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0"; hash = "sha512-h/AXFI687hBz7iO1okAoLFG/r6WNvjqMvwu2IFFN+FtweYjH0MOXVR05fG5Gzqi+RhiNkcF63b6IZDcPvEBKhA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-arm64"; + version = "9.0.0"; + hash = "sha512-penFoYejLCetGFWNXlUma/LbCZKXQMzGjKaoTMLupQtvjc3ZKM/i+n7uBXbRPTd3o9kYus7fCPtNnjk9lI5cPA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-arm64"; + version = "9.0.0"; + hash = "sha512-nVvMcj58prH57guq7lLE6de9KgTjAt18JTu9wXTsnNwQrOyAgZevzM3OpB4clZ1aqkqCKZZ8fuMgpPEbfyaTCw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-arm64"; + version = "9.0.0"; + hash = "sha512-jqfZ0ZboGYYa0KWArvYaO4Ddw0TMnLDkYVHtgKVfdFlaVon+KpM96yykbqmHLr1UUkDXDHNNFtHwnpVXmbmUOw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0"; + hash = "sha512-h/AXFI687hBz7iO1okAoLFG/r6WNvjqMvwu2IFFN+FtweYjH0MOXVR05fG5Gzqi+RhiNkcF63b6IZDcPvEBKhA=="; + }) ]; linux-musl-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-x64"; version = "9.0.0"; hash = "sha512-LQmhF/z9n7Bp8ygYDpY261u3BU7QscyXfLwX52TFAXaMGNCvryVW5+92TeK5wK9zorlAdZMK5+T4sEeOMMa2PA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.linux-musl-x64"; version = "9.0.0"; hash = "sha512-2qPiXsxgMn//ucG3xnTJX+kkpL7/cSF6ve6G+9voJk4Y0abbr3kaJqnmuSRIFoRi6gQt73FBEB7U5mcopeidSA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.linux-musl-x64"; version = "9.0.0"; hash = "sha512-7+1WIq+1cod9u6RBu0c5nxIyYhZs4PHPQ7xvFu7u67JiSk6yGZqYStoYSwphme7D6VPqsyzzSUG/92zgwNg+Bw=="; }) - (fetchNupkg { pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0"; hash = "sha512-fYyTxX42IGf6v3qvEsIwnmFjfPCYO/yQFQizbZ64Y1GejNl6o6pwqS8BMkOQ7gV4WTaO0aQwPigPWboyCp139w=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.linux-musl-x64"; + version = "9.0.0"; + hash = "sha512-LQmhF/z9n7Bp8ygYDpY261u3BU7QscyXfLwX52TFAXaMGNCvryVW5+92TeK5wK9zorlAdZMK5+T4sEeOMMa2PA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.linux-musl-x64"; + version = "9.0.0"; + hash = "sha512-2qPiXsxgMn//ucG3xnTJX+kkpL7/cSF6ve6G+9voJk4Y0abbr3kaJqnmuSRIFoRi6gQt73FBEB7U5mcopeidSA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.linux-musl-x64"; + version = "9.0.0"; + hash = "sha512-7+1WIq+1cod9u6RBu0c5nxIyYhZs4PHPQ7xvFu7u67JiSk6yGZqYStoYSwphme7D6VPqsyzzSUG/92zgwNg+Bw=="; + }) + (fetchNupkg { + pname = "runtime.linux-musl-x64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0"; + hash = "sha512-fYyTxX42IGf6v3qvEsIwnmFjfPCYO/yQFQizbZ64Y1GejNl6o6pwqS8BMkOQ7gV4WTaO0aQwPigPWboyCp139w=="; + }) ]; osx-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.osx-arm64"; version = "9.0.0"; hash = "sha512-x0yxetXr1TKLDGONxhE/xl9726Q9T/iVQALK0wtZMdIEES4J7XehHnzA2+jGK3vEK5ZkevAN9EE6Hoijf6+iGA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.osx-arm64"; version = "9.0.0"; hash = "sha512-SmhcN8JXFuVkmM32zgDtMWP9GFM3kimGr5R3FqzvlLXc1LVndmdsEcvCsLhmYhjr69hPBZtIv6av/LAxiIoKMw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.osx-arm64"; version = "9.0.0"; hash = "sha512-pc7A8emc9Rl25slknnQyYSMAyHG48JXAissa9EaOSX8xojisl/GU0sDJnWkZkrd4RERyhekpaSoHGS3znLcUUw=="; }) - (fetchNupkg { pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0"; hash = "sha512-Zruhm/0uRZ4036v182pLQ/SvqdQ/taJ5zxErdP9LsLypFFCRLWODpQBaYX/UZgQLFtsvv5ri81UZQZboRv4TNg=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.osx-arm64"; + version = "9.0.0"; + hash = "sha512-x0yxetXr1TKLDGONxhE/xl9726Q9T/iVQALK0wtZMdIEES4J7XehHnzA2+jGK3vEK5ZkevAN9EE6Hoijf6+iGA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.osx-arm64"; + version = "9.0.0"; + hash = "sha512-SmhcN8JXFuVkmM32zgDtMWP9GFM3kimGr5R3FqzvlLXc1LVndmdsEcvCsLhmYhjr69hPBZtIv6av/LAxiIoKMw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.osx-arm64"; + version = "9.0.0"; + hash = "sha512-pc7A8emc9Rl25slknnQyYSMAyHG48JXAissa9EaOSX8xojisl/GU0sDJnWkZkrd4RERyhekpaSoHGS3znLcUUw=="; + }) + (fetchNupkg { + pname = "runtime.osx-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0"; + hash = "sha512-Zruhm/0uRZ4036v182pLQ/SvqdQ/taJ5zxErdP9LsLypFFCRLWODpQBaYX/UZgQLFtsvv5ri81UZQZboRv4TNg=="; + }) ]; osx-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; version = "9.0.0"; hash = "sha512-8sJ5cWWtGGMG+NFNOqzzObgaBKAXrewTLMh5b0iHYIgyJ5KoVCpEQHAAe3Fa+zxdVyrmhXsRTekazgEqDKrSJA=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.osx-x64"; version = "9.0.0"; hash = "sha512-DryrXoJ1Y5LAwNfU06r75aak+/raphHgkNwD1Ejy1b5bIPuUDD3VJRfAl0JfWw5e8hsidiA4WEVRdl1gy5LU5w=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.osx-x64"; version = "9.0.0"; hash = "sha512-SyLkZqTEzTI9rWVbdLeM6F2EuhImVo3HzCaqu7JrFHwRxjFvc6TYa/BxmPhbOiA0wZbIAk7B70EWPeXe/jxzVA=="; }) - (fetchNupkg { pname = "runtime.osx-x64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0"; hash = "sha512-9hG3q82Dfu/5HDoWxGHenwMHk10wZYCXAVzxySS+yJwaM2DPhXutXNIxgzSMVGnBD3umYfzrBHUjynvei3gPPQ=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.osx-x64"; + version = "9.0.0"; + hash = "sha512-8sJ5cWWtGGMG+NFNOqzzObgaBKAXrewTLMh5b0iHYIgyJ5KoVCpEQHAAe3Fa+zxdVyrmhXsRTekazgEqDKrSJA=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.osx-x64"; + version = "9.0.0"; + hash = "sha512-DryrXoJ1Y5LAwNfU06r75aak+/raphHgkNwD1Ejy1b5bIPuUDD3VJRfAl0JfWw5e8hsidiA4WEVRdl1gy5LU5w=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.osx-x64"; + version = "9.0.0"; + hash = "sha512-SyLkZqTEzTI9rWVbdLeM6F2EuhImVo3HzCaqu7JrFHwRxjFvc6TYa/BxmPhbOiA0wZbIAk7B70EWPeXe/jxzVA=="; + }) + (fetchNupkg { + pname = "runtime.osx-x64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0"; + hash = "sha512-9hG3q82Dfu/5HDoWxGHenwMHk10wZYCXAVzxySS+yJwaM2DPhXutXNIxgzSMVGnBD3umYfzrBHUjynvei3gPPQ=="; + }) ]; win-arm64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-arm64"; version = "9.0.0"; hash = "sha512-APQNj5uwHVbZ28Zvrx7CLEciJrNMTHOh78lvSNp/gpXgHkD4G5yoQSC7sj/B0AqSshrDs006WaCbp3PuTrKIqw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-arm64"; version = "9.0.0"; hash = "sha512-2MkdFDpDUQFBNJsytmLbyv51Jeyl7vG4NoO1ekWAhNa+ZzwVOtgl3VJNlHgsgwGqyYc8VPmbT5ZAFrBNSR3hoQ=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-arm64"; version = "9.0.0"; hash = "sha512-mEW0ITYKnBCRuXQDvFkasb4FaeV1GHobQGb6r/DRZED/u4b7qK9QMA8jDr29LzHdfGlZJL7dsBVyUfjOAvhuxQ=="; }) - (fetchNupkg { pname = "runtime.win-arm64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0"; hash = "sha512-w5DtpHfp82nsMcSM9lyOCEj7pxohn4b8/m4MShhA87WigKB6tVdA9j6xnjC6eX16OvKkhbQ4xJhVfzt3G1d4ng=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-arm64"; + version = "9.0.0"; + hash = "sha512-APQNj5uwHVbZ28Zvrx7CLEciJrNMTHOh78lvSNp/gpXgHkD4G5yoQSC7sj/B0AqSshrDs006WaCbp3PuTrKIqw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-arm64"; + version = "9.0.0"; + hash = "sha512-2MkdFDpDUQFBNJsytmLbyv51Jeyl7vG4NoO1ekWAhNa+ZzwVOtgl3VJNlHgsgwGqyYc8VPmbT5ZAFrBNSR3hoQ=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-arm64"; + version = "9.0.0"; + hash = "sha512-mEW0ITYKnBCRuXQDvFkasb4FaeV1GHobQGb6r/DRZED/u4b7qK9QMA8jDr29LzHdfGlZJL7dsBVyUfjOAvhuxQ=="; + }) + (fetchNupkg { + pname = "runtime.win-arm64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0"; + hash = "sha512-w5DtpHfp82nsMcSM9lyOCEj7pxohn4b8/m4MShhA87WigKB6tVdA9j6xnjC6eX16OvKkhbQ4xJhVfzt3G1d4ng=="; + }) ]; win-x64 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-x64"; version = "9.0.0"; hash = "sha512-BSXo3XZLsboJN72at4TMCxsZL5vjW5p3dMVtqedpXkmovGakcW0loYY22aCt40JC18i6QbsqzII+/jtTFqRoJg=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-x64"; version = "9.0.0"; hash = "sha512-7SEHvvDPaYhWyNhUAurZou1oPrTgibn2k9RBW+falSlmXPq5AIqNi4EODJUbydc1QyyD2vQjRVgXvhF6aJ9s1Q=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-x64"; version = "9.0.0"; hash = "sha512-ugVn1CngjzNdGzUNJjzukCwrV9MDZ7DhwIQJMHjFPrF9e0SMHTx9BnY1VDqM24AByFrsyymvm1S4Vj540TpGag=="; }) - (fetchNupkg { pname = "runtime.win-x64.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0"; hash = "sha512-ELSZhNXrn/PdJ/NBJYdDIVR3fhHY3k4y3gbRDqWwQZioJS3q9g26bvRMLC2dlXC5FhFRFuCTg4vGuK7f6JPPYw=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-x64"; + version = "9.0.0"; + hash = "sha512-BSXo3XZLsboJN72at4TMCxsZL5vjW5p3dMVtqedpXkmovGakcW0loYY22aCt40JC18i6QbsqzII+/jtTFqRoJg=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-x64"; + version = "9.0.0"; + hash = "sha512-7SEHvvDPaYhWyNhUAurZou1oPrTgibn2k9RBW+falSlmXPq5AIqNi4EODJUbydc1QyyD2vQjRVgXvhF6aJ9s1Q=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-x64"; + version = "9.0.0"; + hash = "sha512-ugVn1CngjzNdGzUNJjzukCwrV9MDZ7DhwIQJMHjFPrF9e0SMHTx9BnY1VDqM24AByFrsyymvm1S4Vj540TpGag=="; + }) + (fetchNupkg { + pname = "runtime.win-x64.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0"; + hash = "sha512-ELSZhNXrn/PdJ/NBJYdDIVR3fhHY3k4y3gbRDqWwQZioJS3q9g26bvRMLC2dlXC5FhFRFuCTg4vGuK7f6JPPYw=="; + }) ]; win-x86 = [ - (fetchNupkg { pname = "Microsoft.AspNetCore.App.Runtime.win-x86"; version = "9.0.0"; hash = "sha512-eG/2FruILBj/2d1Viu/9gbYuwXIHGL61UKvvRCUGWIgS72E8LQgqSntuGO83LOk+aLUHVn5cXrFkb4bVTCGB7w=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Host.win-x86"; version = "9.0.0"; hash = "sha512-mohCLeSgM6dCZB79u9Uz6qgnp7yLyEPszlHPPXI7R66mrot29ApMwDyVjFYNDv3eK/pcCHOroQKcH5qbnVr6pw=="; }) - (fetchNupkg { pname = "Microsoft.NETCore.App.Runtime.win-x86"; version = "9.0.0"; hash = "sha512-CsjUwZKARvTkcPSQuMIQwaMnKnH40SJVS3F6LTWKSHvy3BXMAdnXAeB1DbAegKZyIaRrqjnIlBv9OJ7/G6V5Xw=="; }) - (fetchNupkg { pname = "runtime.win-x86.Microsoft.NETCore.DotNetAppHost"; version = "9.0.0"; hash = "sha512-PatJv/4NYdABL0jlheOf7mNhMUXgIH79pdhQz4lKFWgLnP7dmiGF102MbFwPs5X7jc1bbPAYhr5wVeLhukN7WA=="; }) + (fetchNupkg { + pname = "Microsoft.AspNetCore.App.Runtime.win-x86"; + version = "9.0.0"; + hash = "sha512-eG/2FruILBj/2d1Viu/9gbYuwXIHGL61UKvvRCUGWIgS72E8LQgqSntuGO83LOk+aLUHVn5cXrFkb4bVTCGB7w=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Host.win-x86"; + version = "9.0.0"; + hash = "sha512-mohCLeSgM6dCZB79u9Uz6qgnp7yLyEPszlHPPXI7R66mrot29ApMwDyVjFYNDv3eK/pcCHOroQKcH5qbnVr6pw=="; + }) + (fetchNupkg { + pname = "Microsoft.NETCore.App.Runtime.win-x86"; + version = "9.0.0"; + hash = "sha512-CsjUwZKARvTkcPSQuMIQwaMnKnH40SJVS3F6LTWKSHvy3BXMAdnXAeB1DbAegKZyIaRrqjnIlBv9OJ7/G6V5Xw=="; + }) + (fetchNupkg { + pname = "runtime.win-x86.Microsoft.NETCore.DotNetAppHost"; + version = "9.0.0"; + hash = "sha512-PatJv/4NYdABL0jlheOf7mNhMUXgIH79pdhQz4lKFWgLnP7dmiGF102MbFwPs5X7jc1bbPAYhr5wVeLhukN7WA=="; + }) ]; }; -in rec { +in +rec { release_9_0 = "9.0.0"; aspnetcore_9_0 = buildAspNetCore { diff --git a/pkgs/development/compilers/ecl/16.1.2.nix b/pkgs/development/compilers/ecl/16.1.2.nix index 121935df5f0554..57ae172518d3d1 100644 --- a/pkgs/development/compilers/ecl/16.1.2.nix +++ b/pkgs/development/compilers/ecl/16.1.2.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, libtool -, autoconf -, automake -, gmp -, mpfr -, libffi -, makeWrapper -, noUnicode ? false -, gcc -, threadSupport ? false -, useBoehmgc ? true -, boehmgc +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libtool, + autoconf, + automake, + gmp, + mpfr, + libffi, + makeWrapper, + noUnicode ? false, + gcc, + threadSupport ? false, + useBoehmgc ? true, + boehmgc, }: stdenv.mkDerivation rec { @@ -25,16 +26,23 @@ stdenv.mkDerivation rec { sha256 = "sha256-LUgrGgpPvV2IFDRRcDInnYCMtkBeIt2R721zNTRGS5k="; }; - nativeBuildInputs = [ autoconf automake makeWrapper libtool ]; - propagatedBuildInputs = [ - libffi - gmp - mpfr - gcc - ] ++ lib.optionals useBoehmgc [ - # replaces ecl's own gc which other packages can depend on, thus propagated - boehmgc + nativeBuildInputs = [ + autoconf + automake + makeWrapper + libtool ]; + propagatedBuildInputs = + [ + libffi + gmp + mpfr + gcc + ] + ++ lib.optionals useBoehmgc [ + # replaces ecl's own gc which other packages can depend on, thus propagated + boehmgc + ]; configureFlags = [ (if threadSupport then "--enable-threads" else "--disable-threads") @@ -42,8 +50,7 @@ stdenv.mkDerivation rec { "--with-gmp-libdir=${lib.getLib gmp}/lib" # -incdir, -libdir doesn't seem to be supported for libffi "--with-libffi-prefix=${lib.getDev libffi}" - ] ++ lib.optional (! noUnicode) "--enable-unicode" - ; + ] ++ lib.optional (!noUnicode) "--enable-unicode"; patches = [ (fetchpatch { @@ -65,28 +72,30 @@ stdenv.mkDerivation rec { hardeningDisable = [ "format" ]; - postInstall = '' - sed -e 's/@[-a-zA-Z_]*@//g' -i $out/bin/ecl-config - wrapProgram "$out/bin/ecl" \ - --prefix PATH ':' "${ - lib.makeBinPath [ - gcc # for the C compiler - gcc.bintools.bintools # for ar - ] - }" \ - '' - # ecl 16.1.2 is too old to have -libdir for libffi and boehmgc, so we need to - # use NIX_LDFLAGS_BEFORE to make gcc find these particular libraries. - # Since it is missing even the prefix flag for boehmgc we also need to inject - # the correct -I flag via NIX_CFLAGS_COMPILE. Since we have access to it, we - # create the variables with suffixSalt (which seems to be necessary for - # NIX_CFLAGS_COMPILE even). - + lib.optionalString useBoehmgc '' - --prefix NIX_CFLAGS_COMPILE_${gcc.suffixSalt} ' ' "-I${lib.getDev boehmgc}/include" \ - --prefix NIX_LDFLAGS_BEFORE_${gcc.bintools.suffixSalt} ' ' "-L${lib.getLib boehmgc}/lib" \ - '' + '' - --prefix NIX_LDFLAGS_BEFORE_${gcc.bintools.suffixSalt} ' ' "-L${lib.getLib libffi}/lib" - ''; + postInstall = + '' + sed -e 's/@[-a-zA-Z_]*@//g' -i $out/bin/ecl-config + wrapProgram "$out/bin/ecl" \ + --prefix PATH ':' "${ + lib.makeBinPath [ + gcc # for the C compiler + gcc.bintools.bintools # for ar + ] + }" \ + '' + # ecl 16.1.2 is too old to have -libdir for libffi and boehmgc, so we need to + # use NIX_LDFLAGS_BEFORE to make gcc find these particular libraries. + # Since it is missing even the prefix flag for boehmgc we also need to inject + # the correct -I flag via NIX_CFLAGS_COMPILE. Since we have access to it, we + # create the variables with suffixSalt (which seems to be necessary for + # NIX_CFLAGS_COMPILE even). + + lib.optionalString useBoehmgc '' + --prefix NIX_CFLAGS_COMPILE_${gcc.suffixSalt} ' ' "-I${lib.getDev boehmgc}/include" \ + --prefix NIX_LDFLAGS_BEFORE_${gcc.bintools.suffixSalt} ' ' "-L${lib.getLib boehmgc}/lib" \ + '' + + '' + --prefix NIX_LDFLAGS_BEFORE_${gcc.bintools.suffixSalt} ' ' "-L${lib.getLib libffi}/lib" + ''; meta = with lib; { description = "Lisp implementation aiming to be small, fast and easy to embed"; diff --git a/pkgs/development/compilers/ecl/default.nix b/pkgs/development/compilers/ecl/default.nix index c11f471641dada..3f74941adb7252 100644 --- a/pkgs/development/compilers/ecl/default.nix +++ b/pkgs/development/compilers/ecl/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, libtool -, autoconf -, automake -, texinfo -, gmp -, mpfr -, libffi -, makeWrapper -, noUnicode ? false -, gcc -, threadSupport ? true -, useBoehmgc ? false -, boehmgc +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libtool, + autoconf, + automake, + texinfo, + gmp, + mpfr, + libffi, + makeWrapper, + noUnicode ? false, + gcc, + threadSupport ? true, + useBoehmgc ? false, + boehmgc, }: stdenv.mkDerivation rec { @@ -33,16 +34,18 @@ stdenv.mkDerivation rec { texinfo makeWrapper ]; - propagatedBuildInputs = [ - libffi - gmp - mpfr - gcc - # replaces ecl's own gc which other packages can depend on, thus propagated - ] ++ lib.optionals useBoehmgc [ - # replaces ecl's own gc which other packages can depend on, thus propagated - boehmgc - ]; + propagatedBuildInputs = + [ + libffi + gmp + mpfr + gcc + # replaces ecl's own gc which other packages can depend on, thus propagated + ] + ++ lib.optionals useBoehmgc [ + # replaces ecl's own gc which other packages can depend on, thus propagated + boehmgc + ]; patches = [ # https://gitlab.com/embeddable-common-lisp/ecl/-/merge_requests/1 @@ -52,16 +55,19 @@ stdenv.mkDerivation rec { }) ]; - configureFlags = [ - (if threadSupport then "--enable-threads" else "--disable-threads") - "--with-gmp-incdir=${lib.getDev gmp}/include" - "--with-gmp-libdir=${lib.getLib gmp}/lib" - "--with-libffi-incdir=${lib.getDev libffi}/include" - "--with-libffi-libdir=${lib.getLib libffi}/lib" - ] ++ lib.optionals useBoehmgc [ - "--with-libgc-incdir=${lib.getDev boehmgc}/include" - "--with-libgc-libdir=${lib.getLib boehmgc}/lib" - ] ++ lib.optional (!noUnicode) "--enable-unicode"; + configureFlags = + [ + (if threadSupport then "--enable-threads" else "--disable-threads") + "--with-gmp-incdir=${lib.getDev gmp}/include" + "--with-gmp-libdir=${lib.getLib gmp}/lib" + "--with-libffi-incdir=${lib.getDev libffi}/include" + "--with-libffi-libdir=${lib.getLib libffi}/lib" + ] + ++ lib.optionals useBoehmgc [ + "--with-libgc-incdir=${lib.getDev boehmgc}/include" + "--with-libgc-libdir=${lib.getLib boehmgc}/lib" + ] + ++ lib.optional (!noUnicode) "--enable-unicode"; hardeningDisable = [ "format" ]; @@ -74,7 +80,7 @@ stdenv.mkDerivation rec { sed -e 's/@[-a-zA-Z_]*@//g' -i $out/bin/ecl-config wrapProgram "$out/bin/ecl" --prefix PATH ':' "${ lib.makeBinPath [ - gcc # for the C compiler + gcc # for the C compiler gcc.bintools.bintools # for ar ] }" diff --git a/pkgs/development/compilers/elm/lib/default.nix b/pkgs/development/compilers/elm/lib/default.nix index 12e0600dc23107..3b119737832262 100644 --- a/pkgs/development/compilers/elm/lib/default.nix +++ b/pkgs/development/compilers/elm/lib/default.nix @@ -1,4 +1,9 @@ -{ writeScriptBin, stdenv, lib, elm }: +{ + writeScriptBin, + stdenv, + lib, + elm, +}: let patchBinwrap = let @@ -12,32 +17,48 @@ let #! ${stdenv.shell} echo "binwrap-install called: Doing nothing" ''; - in targets: pkg: - pkg.override (old: { - nativeBuildInputs = (old.nativeBuildInputs or []) ++ [ binwrap binwrap-install ]; + in + targets: pkg: + pkg.override (old: { + nativeBuildInputs = (old.nativeBuildInputs or [ ]) ++ [ + binwrap + binwrap-install + ]; - # Manually install targets - # by symlinking binaries into `node_modules` - postInstall = let + # Manually install targets + # by symlinking binaries into `node_modules` + postInstall = + let binFile = module: lib.strings.removeSuffix ("-" + module.version) module.name; - in (old.postInstall or "") + '' - ${lib.concatStrings (map (module: '' + in + (old.postInstall or "") + + '' + ${lib.concatStrings ( + map (module: '' echo "linking ${binFile module}" ln -sf ${module}/bin/${binFile module} \ node_modules/${binFile module}/bin/${binFile module} - '') targets)} + '') targets + )} ''; - }); + }); - patchNpmElm = pkg: + patchNpmElm = + pkg: pkg.override (old: { - preRebuild = (old.preRebuild or "") + '' - rm node_modules/elm/install.js - echo "console.log('Nixpkgs\' version of Elm will be used');" > node_modules/elm/install.js - ''; - postInstall = (old.postInstall or "") + '' - ln -sf ${elm}/bin/elm node_modules/elm/bin/elm - ''; + preRebuild = + (old.preRebuild or "") + + '' + rm node_modules/elm/install.js + echo "console.log('Nixpkgs\' version of Elm will be used');" > node_modules/elm/install.js + ''; + postInstall = + (old.postInstall or "") + + '' + ln -sf ${elm}/bin/elm node_modules/elm/bin/elm + ''; }); in -{ inherit patchBinwrap patchNpmElm; } +{ + inherit patchBinwrap patchNpmElm; +} diff --git a/pkgs/development/compilers/elm/lib/fetchElmDeps.nix b/pkgs/development/compilers/elm/lib/fetchElmDeps.nix index 9715bfbe037d44..d1102551247d22 100644 --- a/pkgs/development/compilers/elm/lib/fetchElmDeps.nix +++ b/pkgs/development/compilers/elm/lib/fetchElmDeps.nix @@ -1,10 +1,26 @@ -{stdenv, lib, fetchurl}: +{ + stdenv, + lib, + fetchurl, +}: -{elmPackages, registryDat, elmVersion}: +{ + elmPackages, + registryDat, + elmVersion, +}: let - makeDotElm = import ./makeDotElm.nix { inherit stdenv lib fetchurl registryDat; }; + makeDotElm = import ./makeDotElm.nix { + inherit + stdenv + lib + fetchurl + registryDat + ; + }; in '' export ELM_HOME=`pwd`/.elm -'' + (makeDotElm elmVersion elmPackages) +'' ++ (makeDotElm elmVersion elmPackages) diff --git a/pkgs/development/compilers/elm/lib/makeDotElm.nix b/pkgs/development/compilers/elm/lib/makeDotElm.nix index ab62eb88e2202e..9c3ea00b431ef1 100644 --- a/pkgs/development/compilers/elm/lib/makeDotElm.nix +++ b/pkgs/development/compilers/elm/lib/makeDotElm.nix @@ -1,35 +1,41 @@ -{ stdenv, lib, fetchurl, registryDat }: +{ + stdenv, + lib, + fetchurl, + registryDat, +}: ver: deps: let - cmds = lib.mapAttrsToList - (name: info: - let - pkg = stdenv.mkDerivation { - name = lib.replaceStrings [ "/" ] [ "-" ] name + "-${info.version}"; + cmds = lib.mapAttrsToList ( + name: info: + let + pkg = stdenv.mkDerivation { + name = lib.replaceStrings [ "/" ] [ "-" ] name + "-${info.version}"; - src = fetchurl { - url = "https://github.com/${name}/archive/${info.version}.tar.gz"; - meta.homepage = "https://github.com/${name}/"; - inherit (info) sha256; - }; + src = fetchurl { + url = "https://github.com/${name}/archive/${info.version}.tar.gz"; + meta.homepage = "https://github.com/${name}/"; + inherit (info) sha256; + }; - dontConfigure = true; - dontBuild = true; + dontConfigure = true; + dontBuild = true; - installPhase = '' - mkdir -p $out - cp -r * $out - ''; - }; - in - '' - mkdir -p .elm/${ver}/packages/${name} - cp -R ${pkg} .elm/${ver}/packages/${name}/${info.version} - '') - deps; + installPhase = '' + mkdir -p $out + cp -r * $out + ''; + }; + in + '' + mkdir -p .elm/${ver}/packages/${name} + cp -R ${pkg} .elm/${ver}/packages/${name}/${info.version} + '' + ) deps; in -(lib.concatStrings cmds) + '' +(lib.concatStrings cmds) ++ '' mkdir -p .elm/${ver}/packages; cp ${registryDat} .elm/${ver}/packages/registry.dat; chmod -R +w .elm diff --git a/pkgs/development/compilers/elm/packages/elm-json/default.nix b/pkgs/development/compilers/elm/packages/elm-json/default.nix index bc456d2479c198..a306669f065171 100644 --- a/pkgs/development/compilers/elm/packages/elm-json/default.nix +++ b/pkgs/development/compilers/elm/packages/elm-json/default.nix @@ -1,11 +1,12 @@ -{ lib -, curl -, rustPlatform -, fetchurl -, openssl -, stdenv -, pkg-config -, darwin +{ + lib, + curl, + rustPlatform, + fetchurl, + openssl, + stdenv, + pkg-config, + darwin, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/development/compilers/elm/packages/elm-srcs.nix b/pkgs/development/compilers/elm/packages/elm-srcs.nix index 708d81455d6937..02bb4ca70cdd7a 100644 --- a/pkgs/development/compilers/elm/packages/elm-srcs.nix +++ b/pkgs/development/compilers/elm/packages/elm-srcs.nix @@ -1,72 +1,72 @@ { - "elm-explorations/markdown" = { - sha256 = "0k3110ixa4wwf3vkkdplagwah9ypr965qxr1y147rnsc1xsxmr6y"; - version = "1.0.0"; - }; + "elm-explorations/markdown" = { + sha256 = "0k3110ixa4wwf3vkkdplagwah9ypr965qxr1y147rnsc1xsxmr6y"; + version = "1.0.0"; + }; - "elm/browser" = { - sha256 = "1zlmx672glg7fdgkvh5jm47y85pv7pdfr5mkhg6x7ar6k000vyka"; - version = "1.0.1"; - }; + "elm/browser" = { + sha256 = "1zlmx672glg7fdgkvh5jm47y85pv7pdfr5mkhg6x7ar6k000vyka"; + version = "1.0.1"; + }; - "elm/core" = { - sha256 = "1l0qdbczw91kzz8sx5d5zwz9x662bspy7p21dsr3f2rigxiix2as"; - version = "1.0.2"; - }; + "elm/core" = { + sha256 = "1l0qdbczw91kzz8sx5d5zwz9x662bspy7p21dsr3f2rigxiix2as"; + version = "1.0.2"; + }; - "elm/html" = { - sha256 = "1n3gpzmpqqdsldys4ipgyl1zacn0kbpc3g4v3hdpiyfjlgh8bf3k"; - version = "1.0.0"; - }; + "elm/html" = { + sha256 = "1n3gpzmpqqdsldys4ipgyl1zacn0kbpc3g4v3hdpiyfjlgh8bf3k"; + version = "1.0.0"; + }; - "elm/http" = { - sha256 = "008bs76mnp48b4dw8qwjj4fyvzbxvlrl4xpa2qh1gg2kfwyw56v1"; - version = "2.0.0"; - }; + "elm/http" = { + sha256 = "008bs76mnp48b4dw8qwjj4fyvzbxvlrl4xpa2qh1gg2kfwyw56v1"; + version = "2.0.0"; + }; - "elm/json" = { - sha256 = "1a107nmm905dih4w4mjjkkpdcjbgaf5qjvr7fl30kkpkckfjjnrw"; - version = "1.1.2"; - }; + "elm/json" = { + sha256 = "1a107nmm905dih4w4mjjkkpdcjbgaf5qjvr7fl30kkpkckfjjnrw"; + version = "1.1.2"; + }; - "elm/project-metadata-utils" = { - sha256 = "1d4rd4grrnbdvj9gf00h7dr6hbkjzawgkzpizfrkp1z1pyr3mvq9"; - version = "1.0.0"; - }; + "elm/project-metadata-utils" = { + sha256 = "1d4rd4grrnbdvj9gf00h7dr6hbkjzawgkzpizfrkp1z1pyr3mvq9"; + version = "1.0.0"; + }; - "elm/svg" = { - sha256 = "1cwcj73p61q45wqwgqvrvz3aypjyy3fw732xyxdyj6s256hwkn0k"; - version = "1.0.1"; - }; + "elm/svg" = { + sha256 = "1cwcj73p61q45wqwgqvrvz3aypjyy3fw732xyxdyj6s256hwkn0k"; + version = "1.0.1"; + }; - "elm/bytes" = { - sha256 = "040d7irrawcbnq9jxhzx8p9qacdlw5bncy6lgndd6inm53rvvwbp"; - version = "1.0.7"; - }; + "elm/bytes" = { + sha256 = "040d7irrawcbnq9jxhzx8p9qacdlw5bncy6lgndd6inm53rvvwbp"; + version = "1.0.7"; + }; - "elm/file" = { - sha256 = "15vw1ilbg0msimq2k9magwigp8lwqrgvz3vk6qia6b3ldahvw8jr"; - version = "1.0.1"; - }; + "elm/file" = { + sha256 = "15vw1ilbg0msimq2k9magwigp8lwqrgvz3vk6qia6b3ldahvw8jr"; + version = "1.0.1"; + }; - "elm/parser" = { - sha256 = "0a3cxrvbm7mwg9ykynhp7vjid58zsw03r63qxipxp3z09qks7512"; - version = "1.1.0"; - }; + "elm/parser" = { + sha256 = "0a3cxrvbm7mwg9ykynhp7vjid58zsw03r63qxipxp3z09qks7512"; + version = "1.1.0"; + }; - "elm/time" = { - sha256 = "0vch7i86vn0x8b850w1p69vplll1bnbkp8s383z7pinyg94cm2z1"; - version = "1.0.0"; - }; + "elm/time" = { + sha256 = "0vch7i86vn0x8b850w1p69vplll1bnbkp8s383z7pinyg94cm2z1"; + version = "1.0.0"; + }; - "elm/url" = { - sha256 = "0av8x5syid40sgpl5vd7pry2rq0q4pga28b4yykn9gd9v12rs3l4"; - version = "1.0.0"; - }; + "elm/url" = { + sha256 = "0av8x5syid40sgpl5vd7pry2rq0q4pga28b4yykn9gd9v12rs3l4"; + version = "1.0.0"; + }; - "elm/virtual-dom" = { - sha256 = "0q1v5gi4g336bzz1lgwpn5b1639lrn63d8y6k6pimcyismp2i1yg"; - version = "1.0.2"; - }; + "elm/virtual-dom" = { + sha256 = "0q1v5gi4g336bzz1lgwpn5b1639lrn63d8y6k6pimcyismp2i1yg"; + version = "1.0.2"; + }; } diff --git a/pkgs/development/compilers/elm/packages/elm-test/default.nix b/pkgs/development/compilers/elm/packages/elm-test/default.nix index eca45395c3df2d..47beae2c4918b2 100644 --- a/pkgs/development/compilers/elm/packages/elm-test/default.nix +++ b/pkgs/development/compilers/elm/packages/elm-test/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/development/compilers/elm/packages/ghc8_10/default.nix b/pkgs/development/compilers/elm/packages/ghc8_10/default.nix index ef6e5142b2f1e4..ff866eab7e81f4 100644 --- a/pkgs/development/compilers/elm/packages/ghc8_10/default.nix +++ b/pkgs/development/compilers/elm/packages/ghc8_10/default.nix @@ -1,12 +1,14 @@ { pkgs, lib }: -self: pkgs.haskell.packages.ghc810.override { - overrides = self: super: +self: +pkgs.haskell.packages.ghc810.override { + overrides = + self: super: let inherit (pkgs.haskell.lib.compose) justStaticExecutables overrideCabal doJailbreak; elmPkgs = rec { - elmi-to-json = justStaticExecutables (overrideCabal - (drv: { + elmi-to-json = justStaticExecutables ( + overrideCabal (drv: { version = "unstable-2021-07-19"; src = pkgs.fetchgit { url = "https://github.com/stoeffel/elmi-to-json"; @@ -25,11 +27,11 @@ self: pkgs.haskell.packages.ghc810.override { homepage = "https://github.com/stoeffel/elmi-to-json"; license = lib.licenses.bsd3; maintainers = [ lib.maintainers.turbomack ]; - }) - (self.callPackage ./elmi-to-json { })); + }) (self.callPackage ./elmi-to-json { }) + ); - elm-instrument = justStaticExecutables (overrideCabal - (drv: { + elm-instrument = justStaticExecutables ( + overrideCabal (drv: { version = "unstable-2020-03-16"; src = pkgs.fetchgit { url = "https://github.com/zwilias/elm-instrument"; @@ -58,11 +60,12 @@ self: pkgs.haskell.packages.ghc810.override { homepage = "https://github.com/zwilias/elm-instrument"; license = lib.licenses.bsd3; maintainers = [ lib.maintainers.turbomack ]; - }) - (self.callPackage ./elm-instrument { })); + }) (self.callPackage ./elm-instrument { }) + ); }; in - elmPkgs // { + elmPkgs + // { inherit elmPkgs; # We need attoparsec < 0.14 to build elm for now diff --git a/pkgs/development/compilers/elm/packages/ghc8_10/elm-instrument/default.nix b/pkgs/development/compilers/elm/packages/ghc8_10/elm-instrument/default.nix index 7f6a25905e36f2..efcab21123d644 100644 --- a/pkgs/development/compilers/elm/packages/ghc8_10/elm-instrument/default.nix +++ b/pkgs/development/compilers/elm/packages/ghc8_10/elm-instrument/default.nix @@ -1,8 +1,34 @@ -{ mkDerivation, ansi-terminal, ansi-wl-pprint, base, binary -, bytestring, Cabal, cmark, containers, directory, elm-format -, fetchgit, filepath, free, HUnit, indents, json, lib, mtl -, optparse-applicative, parsec, process, QuickCheck, quickcheck-io -, split, tasty, tasty-golden, tasty-hunit, tasty-quickcheck, text +{ + mkDerivation, + ansi-terminal, + ansi-wl-pprint, + base, + binary, + bytestring, + Cabal, + cmark, + containers, + directory, + elm-format, + fetchgit, + filepath, + free, + HUnit, + indents, + json, + lib, + mtl, + optparse-applicative, + parsec, + process, + QuickCheck, + quickcheck-io, + split, + tasty, + tasty-golden, + tasty-hunit, + tasty-quickcheck, + text, }: mkDerivation { pname = "elm-instrument"; @@ -15,16 +41,48 @@ mkDerivation { }; isLibrary = true; isExecutable = true; - setupHaskellDepends = [ base Cabal directory filepath process ]; + setupHaskellDepends = [ + base + Cabal + directory + filepath + process + ]; libraryHaskellDepends = [ - ansi-terminal ansi-wl-pprint base binary bytestring containers - directory filepath free indents json mtl optparse-applicative - parsec process split text + ansi-terminal + ansi-wl-pprint + base + binary + bytestring + containers + directory + filepath + free + indents + json + mtl + optparse-applicative + parsec + process + split + text ]; executableHaskellDepends = [ base ]; testHaskellDepends = [ - base cmark containers elm-format HUnit mtl parsec QuickCheck - quickcheck-io split tasty tasty-golden tasty-hunit tasty-quickcheck + base + cmark + containers + elm-format + HUnit + mtl + parsec + QuickCheck + quickcheck-io + split + tasty + tasty-golden + tasty-hunit + tasty-quickcheck text ]; homepage = "http://elm-lang.org"; diff --git a/pkgs/development/compilers/elm/packages/ghc8_10/elmi-to-json/default.nix b/pkgs/development/compilers/elm/packages/ghc8_10/elmi-to-json/default.nix index fc2c76149a1a5b..5e9ba62daf331d 100644 --- a/pkgs/development/compilers/elm/packages/ghc8_10/elmi-to-json/default.nix +++ b/pkgs/development/compilers/elm/packages/ghc8_10/elmi-to-json/default.nix @@ -1,6 +1,20 @@ -{ mkDerivation, aeson, base, binary, bytestring, containers -, directory, fetchgit, filepath, ghc-prim, hpack, lib -, optparse-applicative, text, unliftio, unordered-containers +{ + mkDerivation, + aeson, + base, + binary, + bytestring, + containers, + directory, + fetchgit, + filepath, + ghc-prim, + hpack, + lib, + optparse-applicative, + text, + unliftio, + unordered-containers, }: mkDerivation { pname = "elmi-to-json"; @@ -14,8 +28,18 @@ mkDerivation { isLibrary = true; isExecutable = true; libraryHaskellDepends = [ - aeson base binary bytestring containers directory filepath ghc-prim - optparse-applicative text unliftio unordered-containers + aeson + base + binary + bytestring + containers + directory + filepath + ghc-prim + optparse-applicative + text + unliftio + unordered-containers ]; libraryToolDepends = [ hpack ]; executableHaskellDepends = [ base ]; diff --git a/pkgs/development/compilers/elm/packages/ghc8_10/indents/default.nix b/pkgs/development/compilers/elm/packages/ghc8_10/indents/default.nix index 85e765db3e50bf..239ca059f71049 100644 --- a/pkgs/development/compilers/elm/packages/ghc8_10/indents/default.nix +++ b/pkgs/development/compilers/elm/packages/ghc8_10/indents/default.nix @@ -1,9 +1,21 @@ -{ mkDerivation, base, concatenative, lib, mtl, parsec }: +{ + mkDerivation, + base, + concatenative, + lib, + mtl, + parsec, +}: mkDerivation { pname = "indents"; version = "0.3.3"; sha256 = "b61f51ac894609cb5571cc3ded12db5de97185a8de236c69ec24c87457109f9a"; - libraryHaskellDepends = [ base concatenative mtl parsec ]; + libraryHaskellDepends = [ + base + concatenative + mtl + parsec + ]; doCheck = false; homepage = "http://patch-tag.com/r/salazar/indents"; description = "indentation sensitive parser-combinators for parsec"; diff --git a/pkgs/development/compilers/elm/packages/ghc9_2/default.nix b/pkgs/development/compilers/elm/packages/ghc9_2/default.nix index 6c3e23460c220b..e823ea2c344380 100644 --- a/pkgs/development/compilers/elm/packages/ghc9_2/default.nix +++ b/pkgs/development/compilers/elm/packages/ghc9_2/default.nix @@ -1,7 +1,9 @@ { pkgs, lib }: -self: pkgs.haskell.packages.ghc92.override { - overrides = self: super: +self: +pkgs.haskell.packages.ghc92.override { + overrides = + self: super: let inherit (pkgs.haskell.lib.compose) justStaticExecutables overrideCabal doJailbreak; elmPkgs = rec { @@ -9,8 +11,8 @@ self: pkgs.haskell.packages.ghc92.override { The elm-format expression is updated via a script in the https://github.com/avh4/elm-format repo: `package/nix/build.sh` */ - elm-format = justStaticExecutables (overrideCabal - (drv: { + elm-format = justStaticExecutables ( + overrideCabal (drv: { jailbreak = true; doHaddock = false; postPatch = '' @@ -25,9 +27,12 @@ self: pkgs.haskell.packages.ghc92.override { description = "Formats Elm source code according to a standard set of rules based on the official Elm Style Guide"; homepage = "https://github.com/avh4/elm-format"; license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [ avh4 turbomack ]; - }) - (self.callPackage ./elm-format/elm-format.nix { })); + maintainers = with lib.maintainers; [ + avh4 + turbomack + ]; + }) (self.callPackage ./elm-format/elm-format.nix { }) + ); }; fixHaddock = overrideCabal (_: { @@ -35,12 +40,13 @@ self: pkgs.haskell.packages.ghc92.override { doHaddock = false; }); in - elmPkgs // { + elmPkgs + // { inherit elmPkgs; # Needed for elm-format avh4-lib = fixHaddock (doJailbreak (self.callPackage ./elm-format/avh4-lib.nix { })); - elm-format-lib = fixHaddock (doJailbreak (self.callPackage ./elm-format/elm-format-lib.nix { })); + elm-format-lib = fixHaddock (doJailbreak (self.callPackage ./elm-format/elm-format-lib.nix { })); elm-format-test-lib = fixHaddock (self.callPackage ./elm-format/elm-format-test-lib.nix { }); elm-format-markdown = fixHaddock (self.callPackage ./elm-format/elm-format-markdown.nix { }); diff --git a/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/avh4-lib.nix b/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/avh4-lib.nix index e320edfd116230..472afd58b6e86a 100644 --- a/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/avh4-lib.nix +++ b/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/avh4-lib.nix @@ -1,6 +1,21 @@ -{ mkDerivation, array, base, bytestring, directory, fetchgit -, filepath, lib, mtl, pooled-io, process, relude, tasty -, tasty-discover, tasty-hspec, tasty-hunit, text +{ + mkDerivation, + array, + base, + bytestring, + directory, + fetchgit, + filepath, + lib, + mtl, + pooled-io, + process, + relude, + tasty, + tasty-discover, + tasty-hspec, + tasty-hunit, + text, }: mkDerivation { pname = "avh4-lib"; @@ -13,12 +28,31 @@ mkDerivation { }; postUnpack = "sourceRoot+=/avh4-lib; echo source root reset to $sourceRoot"; libraryHaskellDepends = [ - array base bytestring directory filepath mtl pooled-io process - relude text + array + base + bytestring + directory + filepath + mtl + pooled-io + process + relude + text ]; testHaskellDepends = [ - array base bytestring directory filepath mtl pooled-io process - relude tasty tasty-hspec tasty-hunit text + array + base + bytestring + directory + filepath + mtl + pooled-io + process + relude + tasty + tasty-hspec + tasty-hunit + text ]; testToolDepends = [ tasty-discover ]; description = "Common code for haskell projects"; diff --git a/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format-lib.nix b/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format-lib.nix index 290534bbea9a54..823c2c3f272917 100644 --- a/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format-lib.nix +++ b/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format-lib.nix @@ -1,7 +1,26 @@ -{ mkDerivation, aeson, avh4-lib, base, bimap, binary, bytestring -, containers, elm-format-markdown, elm-format-test-lib, fetchgit -, hspec, lib, mtl, optparse-applicative, relude, split, tasty -, tasty-discover, tasty-hspec, tasty-hunit, text +{ + mkDerivation, + aeson, + avh4-lib, + base, + bimap, + binary, + bytestring, + containers, + elm-format-markdown, + elm-format-test-lib, + fetchgit, + hspec, + lib, + mtl, + optparse-applicative, + relude, + split, + tasty, + tasty-discover, + tasty-hspec, + tasty-hunit, + text, }: mkDerivation { pname = "elm-format-lib"; @@ -14,13 +33,37 @@ mkDerivation { }; postUnpack = "sourceRoot+=/elm-format-lib; echo source root reset to $sourceRoot"; libraryHaskellDepends = [ - aeson avh4-lib base bimap binary bytestring containers - elm-format-markdown mtl optparse-applicative relude text + aeson + avh4-lib + base + bimap + binary + bytestring + containers + elm-format-markdown + mtl + optparse-applicative + relude + text ]; testHaskellDepends = [ - aeson avh4-lib base bimap binary bytestring containers - elm-format-markdown elm-format-test-lib hspec mtl - optparse-applicative relude split tasty tasty-hspec tasty-hunit + aeson + avh4-lib + base + bimap + binary + bytestring + containers + elm-format-markdown + elm-format-test-lib + hspec + mtl + optparse-applicative + relude + split + tasty + tasty-hspec + tasty-hunit text ]; testToolDepends = [ tasty-discover ]; diff --git a/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format-markdown.nix b/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format-markdown.nix index e57d2127822e76..4d3420da3f6cc9 100644 --- a/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format-markdown.nix +++ b/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format-markdown.nix @@ -1,4 +1,12 @@ -{ mkDerivation, base, containers, fetchgit, lib, mtl, text }: +{ + mkDerivation, + base, + containers, + fetchgit, + lib, + mtl, + text, +}: mkDerivation { pname = "elm-format-markdown"; version = "0.0.0.1"; @@ -9,7 +17,12 @@ mkDerivation { fetchSubmodules = true; }; postUnpack = "sourceRoot+=/elm-format-markdown; echo source root reset to $sourceRoot"; - libraryHaskellDepends = [ base containers mtl text ]; + libraryHaskellDepends = [ + base + containers + mtl + text + ]; description = "Markdown parsing for Elm documentation comments"; license = lib.licenses.bsd3; } diff --git a/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format-test-lib.nix b/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format-test-lib.nix index 43090abbeae495..c9ddc2b25293ac 100644 --- a/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format-test-lib.nix +++ b/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format-test-lib.nix @@ -1,6 +1,21 @@ -{ mkDerivation, avh4-lib, base, containers, fetchgit, filepath -, hspec, hspec-core, hspec-golden, lib, mtl, split, tasty -, tasty-discover, tasty-hspec, tasty-hunit, text +{ + mkDerivation, + avh4-lib, + base, + containers, + fetchgit, + filepath, + hspec, + hspec-core, + hspec-golden, + lib, + mtl, + split, + tasty, + tasty-discover, + tasty-hspec, + tasty-hunit, + text, }: mkDerivation { pname = "elm-format-test-lib"; @@ -13,12 +28,32 @@ mkDerivation { }; postUnpack = "sourceRoot+=/elm-format-test-lib; echo source root reset to $sourceRoot"; libraryHaskellDepends = [ - avh4-lib base containers filepath hspec hspec-core hspec-golden mtl - split tasty-hunit text + avh4-lib + base + containers + filepath + hspec + hspec-core + hspec-golden + mtl + split + tasty-hunit + text ]; testHaskellDepends = [ - avh4-lib base containers filepath hspec hspec-core hspec-golden mtl - split tasty tasty-hspec tasty-hunit text + avh4-lib + base + containers + filepath + hspec + hspec-core + hspec-golden + mtl + split + tasty + tasty-hspec + tasty-hunit + text ]; testToolDepends = [ tasty-discover ]; description = "Test helpers used by elm-format-tests and elm-refactor-tests"; diff --git a/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format.nix b/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format.nix index 9389a4cbb64023..7a8cf08f644d14 100644 --- a/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format.nix +++ b/pkgs/development/compilers/elm/packages/ghc9_2/elm-format/elm-format.nix @@ -1,7 +1,24 @@ -{ mkDerivation, aeson, ansi-wl-pprint, avh4-lib, base, bytestring -, elm-format-lib, elm-format-test-lib, fetchgit, hspec, lib -, optparse-applicative, QuickCheck, quickcheck-io, relude, tasty -, tasty-hspec, tasty-hunit, tasty-quickcheck, text +{ + mkDerivation, + aeson, + ansi-wl-pprint, + avh4-lib, + base, + bytestring, + elm-format-lib, + elm-format-test-lib, + fetchgit, + hspec, + lib, + optparse-applicative, + QuickCheck, + quickcheck-io, + relude, + tasty, + tasty-hspec, + tasty-hunit, + tasty-quickcheck, + text, }: mkDerivation { pname = "elm-format"; @@ -15,13 +32,33 @@ mkDerivation { isLibrary = false; isExecutable = true; executableHaskellDepends = [ - aeson ansi-wl-pprint avh4-lib base bytestring elm-format-lib - optparse-applicative relude text + aeson + ansi-wl-pprint + avh4-lib + base + bytestring + elm-format-lib + optparse-applicative + relude + text ]; testHaskellDepends = [ - aeson ansi-wl-pprint avh4-lib base bytestring elm-format-lib - elm-format-test-lib hspec optparse-applicative QuickCheck - quickcheck-io relude tasty tasty-hspec tasty-hunit tasty-quickcheck + aeson + ansi-wl-pprint + avh4-lib + base + bytestring + elm-format-lib + elm-format-test-lib + hspec + optparse-applicative + QuickCheck + quickcheck-io + relude + tasty + tasty-hspec + tasty-hunit + tasty-quickcheck text ]; homepage = "https://elm-lang.org"; diff --git a/pkgs/development/compilers/elm/packages/ghc9_6/ansi-wl-pprint/default.nix b/pkgs/development/compilers/elm/packages/ghc9_6/ansi-wl-pprint/default.nix index 272f0c520e5268..53b9b6865f891d 100644 --- a/pkgs/development/compilers/elm/packages/ghc9_6/ansi-wl-pprint/default.nix +++ b/pkgs/development/compilers/elm/packages/ghc9_6/ansi-wl-pprint/default.nix @@ -1,4 +1,10 @@ -{ mkDerivation, ansi-terminal, base, fetchgit, lib }: +{ + mkDerivation, + ansi-terminal, + base, + fetchgit, + lib, +}: mkDerivation { pname = "ansi-wl-pprint"; version = "0.6.8.1"; @@ -10,7 +16,10 @@ mkDerivation { }; isLibrary = true; isExecutable = true; - libraryHaskellDepends = [ ansi-terminal base ]; + libraryHaskellDepends = [ + ansi-terminal + base + ]; homepage = "http://github.com/ekmett/ansi-wl-pprint"; description = "Wadler/Leijen Pretty Printer for colored ANSI terminal output"; license = lib.licenses.bsd3; diff --git a/pkgs/development/compilers/elm/packages/ghc9_6/default.nix b/pkgs/development/compilers/elm/packages/ghc9_6/default.nix index 9fdc0e72f1272b..c9ad34e70a811d 100644 --- a/pkgs/development/compilers/elm/packages/ghc9_6/default.nix +++ b/pkgs/development/compilers/elm/packages/ghc9_6/default.nix @@ -1,43 +1,51 @@ -{ pkgs, lib, makeWrapper, nodejs, fetchElmDeps }: +{ + pkgs, + lib, + makeWrapper, + nodejs, + fetchElmDeps, +}: -self: pkgs.haskell.packages.ghc96.override { - overrides = self: super: +self: +pkgs.haskell.packages.ghc96.override { + overrides = + self: super: let inherit (pkgs.haskell.lib.compose) overrideCabal; elmPkgs = rec { - elm = overrideCabal - (drv: { - # sadly with parallelism most of the time breaks compilation - enableParallelBuilding = false; - preConfigure = fetchElmDeps { - elmPackages = (import ../elm-srcs.nix); - elmVersion = drv.version; - registryDat = ../../registry.dat; - }; - buildTools = drv.buildTools or [ ] ++ [ makeWrapper ]; - postInstall = '' - wrapProgram $out/bin/elm \ - --prefix PATH ':' ${lib.makeBinPath [ nodejs ]} - ''; + elm = overrideCabal (drv: { + # sadly with parallelism most of the time breaks compilation + enableParallelBuilding = false; + preConfigure = fetchElmDeps { + elmPackages = (import ../elm-srcs.nix); + elmVersion = drv.version; + registryDat = ../../registry.dat; + }; + buildTools = drv.buildTools or [ ] ++ [ makeWrapper ]; + postInstall = '' + wrapProgram $out/bin/elm \ + --prefix PATH ':' ${lib.makeBinPath [ nodejs ]} + ''; - description = "Delightful language for reliable webapps"; - homepage = "https://elm-lang.org/"; - license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [ domenkozar turbomack ]; - }) - (self.callPackage ./elm { }); + description = "Delightful language for reliable webapps"; + homepage = "https://elm-lang.org/"; + license = lib.licenses.bsd3; + maintainers = with lib.maintainers; [ + domenkozar + turbomack + ]; + }) (self.callPackage ./elm { }); inherit fetchElmDeps; elmVersion = elmPkgs.elm.version; }; in - elmPkgs // { + elmPkgs + // { inherit elmPkgs; - ansi-wl-pprint = overrideCabal - (drv: { - jailbreak = true; - }) - (self.callPackage ./ansi-wl-pprint { }); + ansi-wl-pprint = overrideCabal (drv: { + jailbreak = true; + }) (self.callPackage ./ansi-wl-pprint { }); }; } diff --git a/pkgs/development/compilers/elm/packages/ghc9_6/elm/default.nix b/pkgs/development/compilers/elm/packages/ghc9_6/elm/default.nix index 65f9ffe40bda42..954d15f92e7414 100644 --- a/pkgs/development/compilers/elm/packages/ghc9_6/elm/default.nix +++ b/pkgs/development/compilers/elm/packages/ghc9_6/elm/default.nix @@ -1,10 +1,40 @@ -{ mkDerivation, ansi-terminal, ansi-wl-pprint, base, binary -, bytestring, containers, directory, edit-distance, fetchgit -, file-embed, filelock, filepath, ghc-prim, haskeline, HTTP -, http-client, http-client-tls, http-types, language-glsl, lib, mtl -, network, parsec, process, raw-strings-qq, scientific, SHA -, snap-core, snap-server, template-haskell, time -, unordered-containers, utf8-string, vector, zip-archive +{ + mkDerivation, + ansi-terminal, + ansi-wl-pprint, + base, + binary, + bytestring, + containers, + directory, + edit-distance, + fetchgit, + file-embed, + filelock, + filepath, + ghc-prim, + haskeline, + HTTP, + http-client, + http-client-tls, + http-types, + language-glsl, + lib, + mtl, + network, + parsec, + process, + raw-strings-qq, + scientific, + SHA, + snap-core, + snap-server, + template-haskell, + time, + unordered-containers, + utf8-string, + vector, + zip-archive, }: mkDerivation { pname = "elm"; @@ -18,12 +48,39 @@ mkDerivation { isLibrary = false; isExecutable = true; executableHaskellDepends = [ - ansi-terminal ansi-wl-pprint base binary bytestring containers - directory edit-distance file-embed filelock filepath ghc-prim - haskeline HTTP http-client http-client-tls http-types language-glsl - mtl network parsec process raw-strings-qq scientific SHA snap-core - snap-server template-haskell time unordered-containers utf8-string - vector zip-archive + ansi-terminal + ansi-wl-pprint + base + binary + bytestring + containers + directory + edit-distance + file-embed + filelock + filepath + ghc-prim + haskeline + HTTP + http-client + http-client-tls + http-types + language-glsl + mtl + network + parsec + process + raw-strings-qq + scientific + SHA + snap-core + snap-server + template-haskell + time + unordered-containers + utf8-string + vector + zip-archive ]; homepage = "https://elm-lang.org"; description = "`elm` command line interface"; diff --git a/pkgs/development/compilers/elm/packages/lamdera/default.nix b/pkgs/development/compilers/elm/packages/lamdera/default.nix index 60c72eb623fa45..2deac822a95a5c 100644 --- a/pkgs/development/compilers/elm/packages/lamdera/default.nix +++ b/pkgs/development/compilers/elm/packages/lamdera/default.nix @@ -1,18 +1,18 @@ -{ stdenv -, lib -, fetchurl +{ + stdenv, + lib, + fetchurl, }: let os = if stdenv.hostPlatform.isDarwin then "macos" else "linux"; arch = if stdenv.hostPlatform.isAarch64 then "arm64" else "x86_64"; - hashes = - { - "x86_64-linux" = "15a69bfa98155651749e31c68d05a04fcf48bdccb86bce77b7c8872f545cecfa"; - "aarch64-linux" = "68a16bbbd2ed0ee19c36112a4c2d0abca66cf17465747e55adf2596b0921f8d7"; - "x86_64-darwin" = "af2c63a60a689091a01bfd212e0ce141a6d7ba61d34a585d8f83159d0ed39c6f"; - "aarch64-darwin" = "06f9f7fdcbb392a0a8a5034baf915d2b95b2876255aa8df8397ddafd1e540b7a"; - }; + hashes = { + "x86_64-linux" = "15a69bfa98155651749e31c68d05a04fcf48bdccb86bce77b7c8872f545cecfa"; + "aarch64-linux" = "68a16bbbd2ed0ee19c36112a4c2d0abca66cf17465747e55adf2596b0921f8d7"; + "x86_64-darwin" = "af2c63a60a689091a01bfd212e0ce141a6d7ba61d34a585d8f83159d0ed39c6f"; + "aarch64-darwin" = "06f9f7fdcbb392a0a8a5034baf915d2b95b2876255aa8df8397ddafd1e540b7a"; + }; in stdenv.mkDerivation rec { @@ -34,7 +34,12 @@ stdenv.mkDerivation rec { homepage = "https://lamdera.com"; license = licenses.unfree; description = "Delightful platform for full-stack web apps"; - platforms = [ "aarch64-linux" "x86_64-linux" "aarch64-darwin" "x86_64-darwin" ]; + platforms = [ + "aarch64-linux" + "x86_64-linux" + "aarch64-darwin" + "x86_64-darwin" + ]; maintainers = with maintainers; [ Zimmi48 ]; }; } diff --git a/pkgs/development/compilers/elm/packages/node/elm-pages/default.nix b/pkgs/development/compilers/elm/packages/node/elm-pages/default.nix index d3f48ae8350538..45d9079105fab5 100644 --- a/pkgs/development/compilers/elm/packages/node/elm-pages/default.nix +++ b/pkgs/development/compilers/elm/packages/node/elm-pages/default.nix @@ -1,48 +1,71 @@ -{ nodePkgs, pkgs, lib, makeWrapper }: +{ + nodePkgs, + pkgs, + lib, + makeWrapper, +}: let ESBUILD_BINARY_PATH = lib.getExe ( - pkgs.esbuild.override { - buildGoModule = args: pkgs.buildGoModule (args // rec { - version = "0.21.5"; - src = pkgs.fetchFromGitHub { - owner = "evanw"; - repo = "esbuild"; - rev = "v${version}"; - hash = "sha256-FpvXWIlt67G8w3pBKZo/mcp57LunxDmRUaCU/Ne89B8="; - }; - vendorHash = "sha256-+BfxCyg0KkDQpHt/wycy/8CTG6YBA/VJvJFhhzUnSiQ="; - }); - } - ); -in nodePkgs."elm-pages".overrideAttrs ( - old: { - inherit ESBUILD_BINARY_PATH; - nativeBuildInputs = (old.nativeBuildInputs or [ ]) ++ [ makeWrapper old.nodejs.pkgs.node-gyp-build ]; + pkgs.esbuild.override { + buildGoModule = + args: + pkgs.buildGoModule ( + args + // rec { + version = "0.21.5"; + src = pkgs.fetchFromGitHub { + owner = "evanw"; + repo = "esbuild"; + rev = "v${version}"; + hash = "sha256-FpvXWIlt67G8w3pBKZo/mcp57LunxDmRUaCU/Ne89B8="; + }; + vendorHash = "sha256-+BfxCyg0KkDQpHt/wycy/8CTG6YBA/VJvJFhhzUnSiQ="; + } + ); + } + ); +in +nodePkgs."elm-pages".overrideAttrs (old: { + inherit ESBUILD_BINARY_PATH; + nativeBuildInputs = (old.nativeBuildInputs or [ ]) ++ [ + makeWrapper + old.nodejs.pkgs.node-gyp-build + ]; - preRebuild = '' - sed -i 's/"esbuild": "0\.19\.12"/"esbuild": "0.21.5"/' package.json - ''; + preRebuild = '' + sed -i 's/"esbuild": "0\.19\.12"/"esbuild": "0.21.5"/' package.json + ''; - # can't use `patches = [ ]` with a nodePkgs derivation; - # need to patch in one of the build phases instead. - # see upstream issue https://github.com/dillonkearns/elm-pages/issues/305 for dealing with the read-only problem - preFixup = '' - patch $out/lib/node_modules/elm-pages/generator/src/codegen.js ${./fix-read-only.patch} - patch $out/lib/node_modules/elm-pages/generator/src/init.js ${./fix-init-read-only.patch} - ''; + # can't use `patches = [ ]` with a nodePkgs derivation; + # need to patch in one of the build phases instead. + # see upstream issue https://github.com/dillonkearns/elm-pages/issues/305 for dealing with the read-only problem + preFixup = '' + patch $out/lib/node_modules/elm-pages/generator/src/codegen.js ${./fix-read-only.patch} + patch $out/lib/node_modules/elm-pages/generator/src/init.js ${./fix-init-read-only.patch} + ''; - postFixup = '' - wrapProgram $out/bin/elm-pages --prefix PATH : ${ - with pkgs.elmPackages; lib.makeBinPath [ elm elm-review elm-optimize-level-2 ] - } - ''; + postFixup = '' + wrapProgram $out/bin/elm-pages --prefix PATH : ${ + with pkgs.elmPackages; + lib.makeBinPath [ + elm + elm-review + elm-optimize-level-2 + ] + } + ''; - meta = with lib; nodePkgs."elm-pages".meta // { + meta = + with lib; + nodePkgs."elm-pages".meta + // { description = "Statically typed site generator for Elm"; homepage = "https://github.com/dillonkearns/elm-pages"; license = licenses.bsd3; - maintainers = [ maintainers.turbomack maintainers.jali-clarke ]; + maintainers = [ + maintainers.turbomack + maintainers.jali-clarke + ]; }; - } -) +}) diff --git a/pkgs/development/compilers/elm/packages/node/node-composition.nix b/pkgs/development/compilers/elm/packages/node/node-composition.nix index 0ab5a28046c29c..4b9205c7508d62 100644 --- a/pkgs/development/compilers/elm/packages/node/node-composition.nix +++ b/pkgs/development/compilers/elm/packages/node/node-composition.nix @@ -1,17 +1,34 @@ # This file has been generated by node2nix 1.11.1. Do not edit! -{pkgs ? import { +{ + pkgs ? import { inherit system; - }, system ? builtins.currentSystem, nodejs ? pkgs."nodejs_18"}: + }, + system ? builtins.currentSystem, + nodejs ? pkgs."nodejs_18", +}: let nodeEnv = import ../../../../node-packages/node-env.nix { - inherit (pkgs) stdenv lib python2 runCommand writeTextFile writeShellScript; + inherit (pkgs) + stdenv + lib + python2 + runCommand + writeTextFile + writeShellScript + ; inherit pkgs nodejs; libtool = if pkgs.stdenv.hostPlatform.isDarwin then pkgs.cctools or pkgs.darwin.cctools else null; }; in import ./node-packages.nix { - inherit (pkgs) fetchurl nix-gitignore stdenv lib fetchgit; + inherit (pkgs) + fetchurl + nix-gitignore + stdenv + lib + fetchgit + ; inherit nodeEnv; } diff --git a/pkgs/development/compilers/elm/packages/node/node-packages.nix b/pkgs/development/compilers/elm/packages/node/node-packages.nix index a542d0e7ec4b83..da5ddb377d4df0 100644 --- a/pkgs/development/compilers/elm/packages/node/node-packages.nix +++ b/pkgs/development/compilers/elm/packages/node/node-packages.nix @@ -1,6 +1,14 @@ # This file has been generated by node2nix 1.11.1. Do not edit! -{nodeEnv, fetchurl, fetchgit, nix-gitignore, stdenv, lib, globalBuildInputs ? []}: +{ + nodeEnv, + fetchurl, + fetchgit, + nix-gitignore, + stdenv, + lib, + globalBuildInputs ? [ ], +}: let sources = { @@ -14736,38 +14744,50 @@ in sources."encodeurl-1.0.2" sources."escape-html-1.0.3" sources."etag-1.8.1" - (sources."express-4.16.3" // { - dependencies = [ - sources."body-parser-1.18.2" - sources."bytes-3.0.0" - sources."http-errors-1.6.3" - sources."iconv-lite-0.4.19" - sources."qs-6.5.1" - (sources."raw-body-2.3.2" // { - dependencies = [ - sources."depd-1.1.1" - sources."http-errors-1.6.2" - sources."setprototypeof-1.0.3" - ]; - }) - sources."setprototypeof-1.1.0" - sources."statuses-1.4.0" - ]; - }) - (sources."express-ws-2.0.0" // { - dependencies = [ - sources."ws-1.1.5" - ]; - }) + ( + sources."express-4.16.3" + // { + dependencies = [ + sources."body-parser-1.18.2" + sources."bytes-3.0.0" + sources."http-errors-1.6.3" + sources."iconv-lite-0.4.19" + sources."qs-6.5.1" + ( + sources."raw-body-2.3.2" + // { + dependencies = [ + sources."depd-1.1.1" + sources."http-errors-1.6.2" + sources."setprototypeof-1.0.3" + ]; + } + ) + sources."setprototypeof-1.1.0" + sources."statuses-1.4.0" + ]; + } + ) + ( + sources."express-ws-2.0.0" + // { + dependencies = [ + sources."ws-1.1.5" + ]; + } + ) sources."extend-3.0.2" sources."extsprintf-1.3.0" sources."fast-deep-equal-3.1.3" sources."fast-json-stable-stringify-2.1.0" - (sources."finalhandler-1.1.1" // { - dependencies = [ - sources."statuses-1.4.0" - ]; - }) + ( + sources."finalhandler-1.1.1" + // { + dependencies = [ + sources."statuses-1.4.0" + ]; + } + ) sources."find-0.2.7" sources."forever-agent-0.6.1" sources."form-data-2.3.3" @@ -14823,21 +14843,27 @@ in sources."raw-body-2.4.0" sources."readable-stream-2.0.6" sources."regenerator-runtime-0.9.6" - (sources."request-2.88.0" // { - dependencies = [ - sources."qs-6.5.3" - sources."safe-buffer-5.2.1" - ]; - }) + ( + sources."request-2.88.0" + // { + dependencies = [ + sources."qs-6.5.3" + sources."safe-buffer-5.2.1" + ]; + } + ) sources."safe-buffer-5.1.1" sources."safer-buffer-2.1.2" - (sources."send-0.16.2" // { - dependencies = [ - sources."http-errors-1.6.3" - sources."setprototypeof-1.1.0" - sources."statuses-1.4.0" - ]; - }) + ( + sources."send-0.16.2" + // { + dependencies = [ + sources."http-errors-1.6.3" + sources."setprototypeof-1.1.0" + sources."statuses-1.4.0" + ]; + } + ) sources."serve-static-1.13.2" sources."setprototypeof-1.1.1" sources."sshpk-1.18.0" @@ -14855,21 +14881,27 @@ in sources."typedarray-0.0.7" sources."ultron-1.0.2" sources."unpipe-1.0.0" - (sources."uri-js-4.4.1" // { - dependencies = [ - sources."punycode-2.3.1" - ]; - }) + ( + sources."uri-js-4.4.1" + // { + dependencies = [ + sources."punycode-2.3.1" + ]; + } + ) sources."util-deprecate-1.0.2" sources."utils-merge-1.0.1" sources."uuid-3.4.0" sources."vary-1.1.2" sources."verror-1.10.0" - (sources."ws-3.3.1" // { - dependencies = [ - sources."ultron-1.1.1" - ]; - }) + ( + sources."ws-3.3.1" + // { + dependencies = [ + sources."ultron-1.1.1" + ]; + } + ) sources."xtend-4.0.2" ]; buildInputs = globalBuildInputs; @@ -14912,11 +14944,14 @@ in sources."camelcase-5.3.1" sources."caseless-0.12.0" sources."chainsaw-0.1.0" - (sources."chalk-2.4.2" // { - dependencies = [ - sources."supports-color-5.5.0" - ]; - }) + ( + sources."chalk-2.4.2" + // { + dependencies = [ + sources."supports-color-5.5.0" + ]; + } + ) sources."chokidar-3.2.1" sources."chownr-2.0.0" sources."cliui-6.0.0" @@ -14931,30 +14966,39 @@ in sources."delayed-stream-1.0.0" sources."ecc-jsbn-0.1.2" sources."elm-0.19.1" - (sources."elm-test-0.19.1" // { - dependencies = [ - (sources."cross-spawn-7.0.0" // { - dependencies = [ - sources."which-1.3.1" - ]; - }) - sources."fs-extra-8.1.0" - sources."lodash-4.17.15" - sources."which-2.0.1" - ]; - }) - (sources."elmi-to-json-1.2.0" // { - dependencies = [ - sources."binwrap-0.2.2" - sources."chownr-1.1.4" - sources."fs-minipass-1.2.7" - sources."minipass-2.9.0" - sources."minizlib-1.3.3" - sources."mkdirp-0.5.6" - sources."tar-4.4.19" - sources."yallist-3.1.1" - ]; - }) + ( + sources."elm-test-0.19.1" + // { + dependencies = [ + ( + sources."cross-spawn-7.0.0" + // { + dependencies = [ + sources."which-1.3.1" + ]; + } + ) + sources."fs-extra-8.1.0" + sources."lodash-4.17.15" + sources."which-2.0.1" + ]; + } + ) + ( + sources."elmi-to-json-1.2.0" + // { + dependencies = [ + sources."binwrap-0.2.2" + sources."chownr-1.1.4" + sources."fs-minipass-1.2.7" + sources."minipass-2.9.0" + sources."minizlib-1.3.3" + sources."mkdirp-0.5.6" + sources."tar-4.4.19" + sources."yallist-3.1.1" + ]; + } + ) sources."emoji-regex-8.0.0" sources."escape-string-regexp-1.0.5" sources."extend-3.0.2" @@ -14964,23 +15008,29 @@ in sources."fast-uri-3.0.2" sources."fill-range-7.1.1" sources."find-0.2.9" - (sources."find-elm-dependencies-2.0.2" // { - dependencies = [ - sources."firstline-1.2.0" - sources."lodash-4.17.15" - ]; - }) + ( + sources."find-elm-dependencies-2.0.2" + // { + dependencies = [ + sources."firstline-1.2.0" + sources."lodash-4.17.15" + ]; + } + ) sources."find-parent-dir-0.3.1" sources."find-up-4.1.0" sources."firstline-2.0.2" sources."forever-agent-0.6.1" sources."form-data-2.3.3" sources."fs-extra-4.0.3" - (sources."fs-minipass-2.1.0" // { - dependencies = [ - sources."minipass-3.3.6" - ]; - }) + ( + sources."fs-minipass-2.1.0" + // { + dependencies = [ + sources."minipass-3.3.6" + ]; + } + ) sources."fs.realpath-1.0.0" sources."fsevents-2.1.3" sources."get-caller-file-2.0.5" @@ -15012,33 +15062,42 @@ in sources."locate-path-5.0.0" sources."lodash-4.17.21" sources."lodash.truncate-4.4.2" - (sources."lru-cache-4.1.5" // { - dependencies = [ - sources."yallist-2.1.2" - ]; - }) + ( + sources."lru-cache-4.1.5" + // { + dependencies = [ + sources."yallist-2.1.2" + ]; + } + ) sources."mime-db-1.52.0" sources."mime-types-2.1.35" sources."minimatch-3.1.2" sources."minimist-1.2.8" sources."minipass-5.0.0" - (sources."minizlib-2.1.2" // { - dependencies = [ - sources."minipass-3.3.6" - ]; - }) + ( + sources."minizlib-2.1.2" + // { + dependencies = [ + sources."minipass-3.3.6" + ]; + } + ) sources."mkdirp-1.0.4" sources."moment-2.30.1" sources."murmur-hash-js-1.0.0" sources."mustache-3.2.1" sources."nice-try-1.0.5" - (sources."node-elm-compiler-5.0.4" // { - dependencies = [ - sources."cross-spawn-6.0.5" - sources."lodash-4.17.15" - sources."path-key-2.0.1" - ]; - }) + ( + sources."node-elm-compiler-5.0.4" + // { + dependencies = [ + sources."cross-spawn-6.0.5" + sources."lodash-4.17.15" + sources."path-key-2.0.1" + ]; + } + ) sources."normalize-path-3.0.0" sources."oauth-sign-0.9.0" sources."once-1.4.0" @@ -15070,29 +15129,38 @@ in sources."set-blocking-2.0.0" sources."shebang-command-1.2.0" sources."shebang-regex-1.0.0" - (sources."slice-ansi-4.0.0" // { - dependencies = [ - sources."ansi-styles-4.3.0" - sources."color-convert-2.0.1" - sources."color-name-1.1.4" - ]; - }) + ( + sources."slice-ansi-4.0.0" + // { + dependencies = [ + sources."ansi-styles-4.3.0" + sources."color-convert-2.0.1" + sources."color-name-1.1.4" + ]; + } + ) sources."split-1.0.1" sources."sshpk-1.18.0" sources."stealthy-require-1.1.1" sources."string-width-4.2.3" sources."strip-ansi-6.0.1" - (sources."supports-color-7.1.0" // { - dependencies = [ - sources."has-flag-4.0.0" - ]; - }) - (sources."table-6.8.2" // { - dependencies = [ - sources."ajv-8.17.1" - sources."json-schema-traverse-1.0.0" - ]; - }) + ( + sources."supports-color-7.1.0" + // { + dependencies = [ + sources."has-flag-4.0.0" + ]; + } + ) + ( + sources."table-6.8.2" + // { + dependencies = [ + sources."ajv-8.17.1" + sources."json-schema-traverse-1.0.0" + ]; + } + ) sources."tar-6.2.1" sources."temp-0.9.0" sources."through-2.3.8" @@ -15105,24 +15173,30 @@ in sources."tunnel-agent-0.6.0" sources."tweetnacl-0.14.5" sources."universalify-0.1.2" - (sources."unzip-stream-0.3.4" // { - dependencies = [ - sources."mkdirp-0.5.6" - ]; - }) + ( + sources."unzip-stream-0.3.4" + // { + dependencies = [ + sources."mkdirp-0.5.6" + ]; + } + ) sources."upgrade-1.1.0" sources."uri-js-4.4.1" sources."uuid-3.4.0" sources."verror-1.10.0" sources."which-1.3.1" sources."which-module-2.0.1" - (sources."wrap-ansi-6.2.0" // { - dependencies = [ - sources."ansi-styles-4.3.0" - sources."color-convert-2.0.1" - sources."color-name-1.1.4" - ]; - }) + ( + sources."wrap-ansi-6.2.0" + // { + dependencies = [ + sources."ansi-styles-4.3.0" + sources."color-convert-2.0.1" + sources."color-name-1.1.4" + ]; + } + ) sources."wrappy-1.0.2" sources."xmlbuilder-13.0.2" sources."y18n-4.0.3" @@ -15164,12 +15238,15 @@ in sources."braces-3.0.3" sources."bufferutil-4.0.8" sources."bytes-3.1.2" - (sources."cacheable-request-6.1.0" // { - dependencies = [ - sources."get-stream-5.2.0" - sources."lowercase-keys-2.0.0" - ]; - }) + ( + sources."cacheable-request-6.1.0" + // { + dependencies = [ + sources."get-stream-5.2.0" + sources."lowercase-keys-2.0.0" + ]; + } + ) sources."call-bind-1.0.7" sources."chalk-3.0.0" sources."chokidar-3.6.0" @@ -15183,11 +15260,14 @@ in sources."cookie-0.6.0" sources."cookie-signature-1.0.6" sources."cross-spawn-7.0.3" - (sources."debug-2.6.9" // { - dependencies = [ - sources."ms-2.0.0" - ]; - }) + ( + sources."debug-2.6.9" + // { + dependencies = [ + sources."ms-2.0.0" + ]; + } + ) sources."decompress-response-3.3.0" sources."deep-extend-0.6.0" sources."defer-to-connect-1.1.3" @@ -15203,11 +15283,14 @@ in sources."escape-html-1.0.3" sources."etag-1.8.1" sources."express-4.21.0" - (sources."express-ws-4.0.0" // { - dependencies = [ - sources."ws-5.2.4" - ]; - }) + ( + sources."express-ws-4.0.0" + // { + dependencies = [ + sources."ws-5.2.4" + ]; + } + ) sources."fill-range-7.1.1" sources."finalhandler-1.3.1" sources."forwarded-0.2.0" @@ -15283,20 +15366,26 @@ in sources."safe-buffer-5.2.1" sources."safer-buffer-2.1.2" sources."semver-6.3.1" - (sources."send-0.19.0" // { - dependencies = [ - sources."encodeurl-1.0.2" - ]; - }) - (sources."serve-index-1.9.1" // { - dependencies = [ - sources."depd-1.1.2" - sources."http-errors-1.6.3" - sources."inherits-2.0.3" - sources."setprototypeof-1.1.0" - sources."statuses-1.5.0" - ]; - }) + ( + sources."send-0.19.0" + // { + dependencies = [ + sources."encodeurl-1.0.2" + ]; + } + ) + ( + sources."serve-index-1.9.1" + // { + dependencies = [ + sources."depd-1.1.2" + sources."http-errors-1.6.3" + sources."inherits-2.0.3" + sources."setprototypeof-1.1.0" + sources."statuses-1.5.0" + ]; + } + ) sources."serve-static-1.16.2" sources."set-function-length-1.2.2" sources."setprototypeof-1.2.0" @@ -15492,12 +15581,15 @@ in sources."readdirp-3.6.0" sources."rollup-4.22.5" sources."safer-buffer-2.1.2" - (sources."sass-1.79.3" // { - dependencies = [ - sources."chokidar-4.0.1" - sources."readdirp-4.0.1" - ]; - }) + ( + sources."sass-1.79.3" + // { + dependencies = [ + sources."chokidar-4.0.1" + sources."readdirp-4.0.1" + ]; + } + ) sources."sax-1.4.1" sources."semver-5.7.2" sources."shebang-command-2.0.0" @@ -15506,12 +15598,15 @@ in sources."source-map-0.6.1" sources."source-map-js-1.2.1" sources."source-map-support-0.5.21" - (sources."stylus-0.63.0" // { - dependencies = [ - sources."sax-1.3.0" - sources."source-map-0.7.4" - ]; - }) + ( + sources."stylus-0.63.0" + // { + dependencies = [ + sources."sax-1.3.0" + sources."source-map-0.7.4" + ]; + } + ) sources."sugarss-4.0.1" sources."terser-5.15.1" sources."tiny-decoders-7.0.1" @@ -15520,11 +15615,14 @@ in sources."typescript-4.9.3" sources."undici-types-6.19.8" sources."vite-5.2.8" - (sources."vite-plugin-elm-watch-1.3.3" // { - dependencies = [ - sources."terser-5.26.0" - ]; - }) + ( + sources."vite-plugin-elm-watch-1.3.3" + // { + dependencies = [ + sources."terser-5.26.0" + ]; + } + ) sources."which-2.0.2" sources."wrappy-1.0.2" ]; @@ -15573,11 +15671,14 @@ in sources."escape-string-regexp-1.0.5" sources."etag-1.8.1" sources."eventemitter3-3.1.2" - (sources."execa-1.0.0" // { - dependencies = [ - sources."cross-spawn-6.0.5" - ]; - }) + ( + sources."execa-1.0.0" + // { + dependencies = [ + sources."cross-spawn-6.0.5" + ]; + } + ) sources."fill-range-7.1.1" sources."finalhandler-1.1.2" sources."follow-redirects-1.15.9" @@ -15622,12 +15723,15 @@ in sources."readdirp-3.6.0" sources."requires-port-1.0.0" sources."semver-5.7.2" - (sources."send-0.17.1" // { - dependencies = [ - sources."mime-1.6.0" - sources."ms-2.1.1" - ]; - }) + ( + sources."send-0.17.1" + // { + dependencies = [ + sources."mime-1.6.0" + sources."ms-2.1.1" + ]; + } + ) sources."serve-static-1.14.1" sources."setprototypeof-1.1.1" sources."shebang-command-1.2.0" @@ -15719,11 +15823,14 @@ in sources."shebang-command-1.2.0" sources."shebang-regex-1.0.0" sources."source-map-0.7.4" - (sources."source-map-support-0.5.21" // { - dependencies = [ - sources."source-map-0.6.1" - ]; - }) + ( + sources."source-map-support-0.5.21" + // { + dependencies = [ + sources."source-map-0.6.1" + ]; + } + ) sources."temp-0.9.4" sources."terser-5.3.8" sources."to-regex-range-5.0.1" @@ -15825,11 +15932,14 @@ in sources."cacheable-lookup-2.0.1" sources."cacheable-request-7.0.4" sources."caw-2.0.1" - (sources."clone-response-1.0.3" // { - dependencies = [ - sources."mimic-response-1.0.1" - ]; - }) + ( + sources."clone-response-1.0.3" + // { + dependencies = [ + sources."mimic-response-1.0.1" + ]; + } + ) sources."config-chain-1.1.13" sources."decompress-response-5.0.0" sources."defer-to-connect-2.0.1" @@ -15901,14 +16011,17 @@ in sources."balanced-match-1.0.2" sources."brace-expansion-2.0.1" sources."chalk-4.1.2" - (sources."cliui-8.0.1" // { - dependencies = [ - sources."emoji-regex-8.0.0" - sources."string-width-4.2.3" - sources."strip-ansi-6.0.1" - sources."wrap-ansi-7.0.0" - ]; - }) + ( + sources."cliui-8.0.1" + // { + dependencies = [ + sources."emoji-regex-8.0.0" + sources."string-width-4.2.3" + sources."strip-ansi-6.0.1" + sources."wrap-ansi-7.0.0" + ]; + } + ) sources."color-convert-2.0.1" sources."color-name-1.1.4" sources."cross-spawn-7.0.3" @@ -15938,41 +16051,56 @@ in sources."shebang-regex-3.0.0" sources."signal-exit-4.1.0" sources."string-width-5.1.2" - (sources."string-width-cjs-4.2.3" // { - dependencies = [ - sources."emoji-regex-8.0.0" - sources."strip-ansi-6.0.1" - ]; - }) - (sources."strip-ansi-7.1.0" // { - dependencies = [ - sources."ansi-regex-6.1.0" - ]; - }) + ( + sources."string-width-cjs-4.2.3" + // { + dependencies = [ + sources."emoji-regex-8.0.0" + sources."strip-ansi-6.0.1" + ]; + } + ) + ( + sources."strip-ansi-7.1.0" + // { + dependencies = [ + sources."ansi-regex-6.1.0" + ]; + } + ) sources."strip-ansi-cjs-6.0.1" sources."supports-color-7.2.0" sources."universalify-2.0.1" sources."which-2.0.2" - (sources."wrap-ansi-8.1.0" // { - dependencies = [ - sources."ansi-styles-6.2.1" - ]; - }) - (sources."wrap-ansi-cjs-7.0.0" // { - dependencies = [ - sources."emoji-regex-8.0.0" - sources."string-width-4.2.3" - sources."strip-ansi-6.0.1" - ]; - }) + ( + sources."wrap-ansi-8.1.0" + // { + dependencies = [ + sources."ansi-styles-6.2.1" + ]; + } + ) + ( + sources."wrap-ansi-cjs-7.0.0" + // { + dependencies = [ + sources."emoji-regex-8.0.0" + sources."string-width-4.2.3" + sources."strip-ansi-6.0.1" + ]; + } + ) sources."y18n-5.0.8" - (sources."yargs-17.7.2" // { - dependencies = [ - sources."emoji-regex-8.0.0" - sources."string-width-4.2.3" - sources."strip-ansi-6.0.1" - ]; - }) + ( + sources."yargs-17.7.2" + // { + dependencies = [ + sources."emoji-regex-8.0.0" + sources."string-width-4.2.3" + sources."strip-ansi-6.0.1" + ]; + } + ) sources."yargs-parser-21.1.1" ]; buildInputs = globalBuildInputs; @@ -16008,11 +16136,14 @@ in sources."safe-buffer-5.1.2" sources."semver-6.3.1" sources."semver-regex-3.1.4" - (sources."semver-sort-1.0.0" // { - dependencies = [ - sources."semver-5.7.2" - ]; - }) + ( + sources."semver-sort-1.0.0" + // { + dependencies = [ + sources."semver-5.7.2" + ]; + } + ) sources."string_decoder-1.1.1" sources."through2-2.0.5" sources."universalify-0.1.2" @@ -16045,21 +16176,30 @@ in sources."@babel/generator-7.25.6" sources."@babel/helper-annotate-as-pure-7.24.7" sources."@babel/helper-builder-binary-assignment-operator-visitor-7.24.7" - (sources."@babel/helper-compilation-targets-7.25.2" // { - dependencies = [ - sources."semver-6.3.1" - ]; - }) - (sources."@babel/helper-create-class-features-plugin-7.25.4" // { - dependencies = [ - sources."semver-6.3.1" - ]; - }) - (sources."@babel/helper-create-regexp-features-plugin-7.25.2" // { - dependencies = [ - sources."semver-6.3.1" - ]; - }) + ( + sources."@babel/helper-compilation-targets-7.25.2" + // { + dependencies = [ + sources."semver-6.3.1" + ]; + } + ) + ( + sources."@babel/helper-create-class-features-plugin-7.25.4" + // { + dependencies = [ + sources."semver-6.3.1" + ]; + } + ) + ( + sources."@babel/helper-create-regexp-features-plugin-7.25.2" + // { + dependencies = [ + sources."semver-6.3.1" + ]; + } + ) sources."@babel/helper-environment-visitor-7.24.7" sources."@babel/helper-member-expression-to-functions-7.24.8" sources."@babel/helper-module-imports-7.24.7" @@ -16164,21 +16304,30 @@ in sources."@types/q-1.5.8" sources."@types/source-list-map-0.1.6" sources."@types/tapable-1.0.12" - (sources."@types/uglify-js-3.17.5" // { - dependencies = [ - sources."source-map-0.6.1" - ]; - }) - (sources."@types/webpack-4.41.39" // { - dependencies = [ - sources."source-map-0.6.1" - ]; - }) - (sources."@types/webpack-sources-3.2.3" // { - dependencies = [ - sources."source-map-0.7.4" - ]; - }) + ( + sources."@types/uglify-js-3.17.5" + // { + dependencies = [ + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."@types/webpack-4.41.39" + // { + dependencies = [ + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."@types/webpack-sources-3.2.3" + // { + dependencies = [ + sources."source-map-0.7.4" + ]; + } + ) sources."@webassemblyjs/ast-1.9.0" sources."@webassemblyjs/floating-point-hex-parser-1.9.0" sources."@webassemblyjs/helper-api-error-1.9.0" @@ -16229,23 +16378,32 @@ in sources."arraybuffer.prototype.slice-1.0.3" sources."asap-2.0.6" sources."asn1-0.2.6" - (sources."asn1.js-4.10.1" // { - dependencies = [ - sources."bn.js-4.12.0" - ]; - }) - (sources."assert-1.5.1" // { - dependencies = [ - sources."inherits-2.0.3" - sources."util-0.10.4" - ]; - }) + ( + sources."asn1.js-4.10.1" + // { + dependencies = [ + sources."bn.js-4.12.0" + ]; + } + ) + ( + sources."assert-1.5.1" + // { + dependencies = [ + sources."inherits-2.0.3" + sources."util-0.10.4" + ]; + } + ) sources."assert-plus-1.0.0" - (sources."assets-webpack-plugin-3.9.12" // { - dependencies = [ - sources."lodash-4.17.15" - ]; - }) + ( + sources."assets-webpack-plugin-3.9.12" + // { + dependencies = [ + sources."lodash-4.17.15" + ]; + } + ) sources."assign-symbols-1.0.0" sources."async-0.9.2" sources."async-each-1.0.6" @@ -16257,26 +16415,35 @@ in sources."aws-sign2-0.7.0" sources."aws4-1.13.2" sources."babel-extract-comments-1.0.0" - (sources."babel-loader-8.2.2" // { - dependencies = [ - sources."make-dir-3.1.0" - sources."semver-6.3.1" - ]; - }) + ( + sources."babel-loader-8.2.2" + // { + dependencies = [ + sources."make-dir-3.1.0" + sources."semver-6.3.1" + ]; + } + ) sources."babel-plugin-syntax-object-rest-spread-6.13.0" sources."babel-plugin-transform-object-rest-spread-6.26.0" - (sources."babel-runtime-6.26.0" // { - dependencies = [ - sources."regenerator-runtime-0.11.1" - ]; - }) + ( + sources."babel-runtime-6.26.0" + // { + dependencies = [ + sources."regenerator-runtime-0.11.1" + ]; + } + ) sources."babylon-6.18.0" sources."balanced-match-1.0.2" - (sources."base-0.11.2" // { - dependencies = [ - sources."define-property-1.0.0" - ]; - }) + ( + sources."base-0.11.2" + // { + dependencies = [ + sources."define-property-1.0.0" + ]; + } + ) sources."base64-js-1.5.1" sources."batch-0.6.1" sources."bcrypt-pbkdf-1.0.2" @@ -16285,18 +16452,24 @@ in sources."bindings-1.5.0" sources."bluebird-3.7.2" sources."bn.js-5.2.1" - (sources."body-parser-1.20.3" // { - dependencies = [ - sources."debug-2.6.9" - sources."ms-2.0.0" - sources."qs-6.13.0" - ]; - }) - (sources."bonjour-3.5.0" // { - dependencies = [ - sources."deep-equal-1.1.2" - ]; - }) + ( + sources."body-parser-1.20.3" + // { + dependencies = [ + sources."debug-2.6.9" + sources."ms-2.0.0" + sources."qs-6.13.0" + ]; + } + ) + ( + sources."bonjour-3.5.0" + // { + dependencies = [ + sources."deep-equal-1.1.2" + ]; + } + ) sources."boolbase-1.0.0" sources."brace-expansion-1.1.11" sources."braces-3.0.3" @@ -16304,17 +16477,23 @@ in sources."browserify-aes-1.2.0" sources."browserify-cipher-1.0.1" sources."browserify-des-1.0.2" - (sources."browserify-rsa-4.1.1" // { - dependencies = [ - sources."safe-buffer-5.2.1" - ]; - }) - (sources."browserify-sign-4.2.3" // { - dependencies = [ - sources."hash-base-3.0.4" - sources."safe-buffer-5.2.1" - ]; - }) + ( + sources."browserify-rsa-4.1.1" + // { + dependencies = [ + sources."safe-buffer-5.2.1" + ]; + } + ) + ( + sources."browserify-sign-4.2.3" + // { + dependencies = [ + sources."hash-base-3.0.4" + sources."safe-buffer-5.2.1" + ]; + } + ) sources."browserify-zlib-0.2.0" sources."browserslist-4.24.0" sources."buffer-4.9.2" @@ -16336,42 +16515,57 @@ in sources."caniuse-lite-1.0.30001664" sources."case-sensitive-paths-webpack-plugin-2.3.0" sources."caseless-0.12.0" - (sources."chalk-2.4.2" // { - dependencies = [ - sources."escape-string-regexp-1.0.5" - ]; - }) + ( + sources."chalk-2.4.2" + // { + dependencies = [ + sources."escape-string-regexp-1.0.5" + ]; + } + ) sources."chardet-0.7.0" - (sources."chokidar-3.6.0" // { - dependencies = [ - sources."glob-parent-5.1.2" - ]; - }) + ( + sources."chokidar-3.6.0" + // { + dependencies = [ + sources."glob-parent-5.1.2" + ]; + } + ) sources."chownr-1.1.4" sources."chrome-trace-event-1.0.4" sources."cipher-base-1.0.4" - (sources."class-utils-0.3.6" // { - dependencies = [ - sources."define-property-0.2.5" - sources."is-descriptor-0.1.7" - ]; - }) - (sources."clean-css-4.2.4" // { - dependencies = [ - sources."source-map-0.6.1" - ]; - }) + ( + sources."class-utils-0.3.6" + // { + dependencies = [ + sources."define-property-0.2.5" + sources."is-descriptor-0.1.7" + ]; + } + ) + ( + sources."clean-css-4.2.4" + // { + dependencies = [ + sources."source-map-0.6.1" + ]; + } + ) sources."cli-cursor-2.1.0" sources."cli-table-0.3.4" sources."cli-width-2.2.1" - (sources."cliui-3.2.0" // { - dependencies = [ - sources."ansi-regex-2.1.1" - sources."is-fullwidth-code-point-1.0.0" - sources."string-width-1.0.2" - sources."strip-ansi-3.0.1" - ]; - }) + ( + sources."cliui-3.2.0" + // { + dependencies = [ + sources."ansi-regex-2.1.1" + sources."is-fullwidth-code-point-1.0.0" + sources."string-width-1.0.2" + sources."strip-ansi-3.0.1" + ]; + } + ) sources."coa-2.0.2" sources."code-point-at-1.1.0" sources."collection-visit-1.0.0" @@ -16387,111 +16581,144 @@ in sources."commondir-1.0.1" sources."component-emitter-1.3.1" sources."compressible-2.0.18" - (sources."compression-1.7.4" // { - dependencies = [ - sources."bytes-3.0.0" - sources."debug-2.6.9" - sources."ms-2.0.0" - ]; - }) + ( + sources."compression-1.7.4" + // { + dependencies = [ + sources."bytes-3.0.0" + sources."debug-2.6.9" + sources."ms-2.0.0" + ]; + } + ) sources."concat-map-0.0.1" sources."concat-stream-1.6.2" sources."connect-history-api-fallback-1.6.0" sources."console-browserify-1.2.0" sources."constants-browserify-1.0.0" - (sources."content-disposition-0.5.4" // { - dependencies = [ - sources."safe-buffer-5.2.1" - ]; - }) + ( + sources."content-disposition-0.5.4" + // { + dependencies = [ + sources."safe-buffer-5.2.1" + ]; + } + ) sources."content-type-1.0.5" sources."convert-source-map-1.9.0" sources."cookie-0.6.0" sources."cookie-signature-1.0.6" sources."copy-concurrently-1.0.5" sources."copy-descriptor-0.1.1" - (sources."copy-webpack-plugin-5.1.2" // { - dependencies = [ - sources."find-cache-dir-2.1.0" - sources."find-up-3.0.0" - sources."locate-path-3.0.0" - sources."p-locate-3.0.0" - sources."path-exists-3.0.0" - sources."pkg-dir-3.0.0" - sources."schema-utils-1.0.0" - ]; - }) + ( + sources."copy-webpack-plugin-5.1.2" + // { + dependencies = [ + sources."find-cache-dir-2.1.0" + sources."find-up-3.0.0" + sources."locate-path-3.0.0" + sources."p-locate-3.0.0" + sources."path-exists-3.0.0" + sources."pkg-dir-3.0.0" + sources."schema-utils-1.0.0" + ]; + } + ) sources."core-js-2.6.12" sources."core-js-compat-3.38.1" sources."core-util-is-1.0.3" sources."cosmiconfig-5.2.1" - (sources."create-ecdh-4.0.4" // { - dependencies = [ - sources."bn.js-4.12.0" - ]; - }) + ( + sources."create-ecdh-4.0.4" + // { + dependencies = [ + sources."bn.js-4.12.0" + ]; + } + ) sources."create-hash-1.2.0" sources."create-hmac-1.1.7" sources."cross-spawn-7.0.3" sources."crypto-browserify-3.12.0" sources."css-color-names-0.0.4" - (sources."css-declaration-sorter-4.0.1" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."css-loader-4.3.0" // { - dependencies = [ - sources."camelcase-6.3.0" - sources."loader-utils-2.0.4" - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."semver-7.6.3" - sources."source-map-0.6.1" - ]; - }) + ( + sources."css-declaration-sorter-4.0.1" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."css-loader-4.3.0" + // { + dependencies = [ + sources."camelcase-6.3.0" + sources."loader-utils-2.0.4" + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."semver-7.6.3" + sources."source-map-0.6.1" + ]; + } + ) sources."css-select-4.3.0" sources."css-select-base-adapter-0.1.1" - (sources."css-tree-1.0.0-alpha.37" // { - dependencies = [ - sources."mdn-data-2.0.4" - sources."source-map-0.6.1" - ]; - }) + ( + sources."css-tree-1.0.0-alpha.37" + // { + dependencies = [ + sources."mdn-data-2.0.4" + sources."source-map-0.6.1" + ]; + } + ) sources."css-what-6.1.0" sources."cssesc-3.0.0" - (sources."cssnano-4.1.11" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."cssnano-preset-default-4.0.8" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) + ( + sources."cssnano-4.1.11" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."cssnano-preset-default-4.0.8" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) sources."cssnano-util-get-arguments-4.0.0" sources."cssnano-util-get-match-4.0.0" - (sources."cssnano-util-raw-cache-4.0.1" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) + ( + sources."cssnano-util-raw-cache-4.0.1" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) sources."cssnano-util-same-parent-4.0.1" - (sources."csso-4.2.0" // { - dependencies = [ - sources."css-tree-1.1.3" - sources."source-map-0.6.1" - ]; - }) + ( + sources."csso-4.2.0" + // { + dependencies = [ + sources."css-tree-1.1.3" + sources."source-map-0.6.1" + ]; + } + ) sources."cycle-1.0.3" sources."cyclist-1.0.2" sources."dashdash-1.14.1" @@ -16506,31 +16733,43 @@ in sources."define-data-property-1.1.4" sources."define-properties-1.2.1" sources."define-property-2.0.2" - (sources."del-4.1.1" // { - dependencies = [ - (sources."globby-6.1.0" // { - dependencies = [ - sources."pify-2.3.0" - ]; - }) - ]; - }) + ( + sources."del-4.1.1" + // { + dependencies = [ + ( + sources."globby-6.1.0" + // { + dependencies = [ + sources."pify-2.3.0" + ]; + } + ) + ]; + } + ) sources."delayed-stream-1.0.0" sources."depd-2.0.0" sources."des.js-1.1.0" sources."destroy-1.2.0" sources."detect-node-2.1.0" - (sources."detect-port-alt-1.1.6" // { - dependencies = [ - sources."debug-2.6.9" - sources."ms-2.0.0" - ]; - }) - (sources."diffie-hellman-5.0.3" // { - dependencies = [ - sources."bn.js-4.12.0" - ]; - }) + ( + sources."detect-port-alt-1.1.6" + // { + dependencies = [ + sources."debug-2.6.9" + sources."ms-2.0.0" + ]; + } + ) + ( + sources."diffie-hellman-5.0.3" + // { + dependencies = [ + sources."bn.js-4.12.0" + ]; + } + ) sources."dir-glob-2.2.2" sources."dns-equal-1.0.0" sources."dns-packet-1.3.4" @@ -16549,40 +16788,49 @@ in sources."ecc-jsbn-0.1.2" sources."ee-first-1.1.1" sources."electron-to-chromium-1.5.29" - (sources."elliptic-6.5.7" // { - dependencies = [ - sources."bn.js-4.12.0" - ]; - }) + ( + sources."elliptic-6.5.7" + // { + dependencies = [ + sources."bn.js-4.12.0" + ]; + } + ) sources."elm-0.19.1-5" sources."elm-asset-webpack-loader-1.1.2" sources."elm-hot-1.1.6" sources."elm-hot-webpack-loader-1.1.7" sources."elm-solve-deps-wasm-1.0.2" - (sources."elm-test-0.19.1-revision12" // { - dependencies = [ - sources."ansi-styles-4.3.0" - sources."brace-expansion-2.0.1" - sources."chalk-4.1.2" - sources."color-convert-2.0.1" - sources."color-name-1.1.4" - sources."commander-9.5.0" - sources."glob-8.1.0" - sources."has-flag-4.0.0" - sources."minimatch-5.1.6" - sources."supports-color-7.2.0" - ]; - }) + ( + sources."elm-test-0.19.1-revision12" + // { + dependencies = [ + sources."ansi-styles-4.3.0" + sources."brace-expansion-2.0.1" + sources."chalk-4.1.2" + sources."color-convert-2.0.1" + sources."color-name-1.1.4" + sources."commander-9.5.0" + sources."glob-8.1.0" + sources."has-flag-4.0.0" + sources."minimatch-5.1.6" + sources."supports-color-7.2.0" + ]; + } + ) sources."elm-webpack-loader-6.0.1" sources."emoji-regex-8.0.0" sources."emojis-list-3.0.0" sources."encodeurl-2.0.0" sources."end-of-stream-1.4.4" - (sources."enhanced-resolve-4.5.0" // { - dependencies = [ - sources."memory-fs-0.5.0" - ]; - }) + ( + sources."enhanced-resolve-4.5.0" + // { + dependencies = [ + sources."memory-fs-0.5.0" + ]; + } + ) sources."entities-2.2.0" sources."errno-0.1.8" sources."error-ex-1.3.2" @@ -16598,11 +16846,14 @@ in sources."escape-string-regexp-2.0.0" sources."eslint-scope-4.0.3" sources."esprima-4.0.1" - (sources."esrecurse-4.3.0" // { - dependencies = [ - sources."estraverse-5.3.0" - ]; - }) + ( + sources."esrecurse-4.3.0" + // { + dependencies = [ + sources."estraverse-5.3.0" + ]; + } + ) sources."estraverse-4.3.0" sources."esutils-2.0.3" sources."etag-1.8.1" @@ -16610,100 +16861,139 @@ in sources."events-3.3.0" sources."eventsource-0.1.6" sources."evp_bytestokey-1.0.3" - (sources."execa-1.0.0" // { - dependencies = [ - sources."cross-spawn-6.0.5" - sources."path-key-2.0.1" - sources."shebang-command-1.2.0" - sources."shebang-regex-1.0.0" - sources."which-1.3.1" - ]; - }) - (sources."expand-brackets-2.1.4" // { - dependencies = [ - sources."debug-2.6.9" - sources."define-property-0.2.5" - sources."extend-shallow-2.0.1" - sources."is-descriptor-0.1.7" - sources."ms-2.0.0" - ]; - }) + ( + sources."execa-1.0.0" + // { + dependencies = [ + sources."cross-spawn-6.0.5" + sources."path-key-2.0.1" + sources."shebang-command-1.2.0" + sources."shebang-regex-1.0.0" + sources."which-1.3.1" + ]; + } + ) + ( + sources."expand-brackets-2.1.4" + // { + dependencies = [ + sources."debug-2.6.9" + sources."define-property-0.2.5" + sources."extend-shallow-2.0.1" + sources."is-descriptor-0.1.7" + sources."ms-2.0.0" + ]; + } + ) sources."expand-tilde-2.0.2" - (sources."express-4.21.0" // { - dependencies = [ - sources."array-flatten-1.1.1" - sources."debug-2.6.9" - sources."ms-2.0.0" - sources."qs-6.13.0" - sources."safe-buffer-5.2.1" - ]; - }) + ( + sources."express-4.21.0" + // { + dependencies = [ + sources."array-flatten-1.1.1" + sources."debug-2.6.9" + sources."ms-2.0.0" + sources."qs-6.13.0" + sources."safe-buffer-5.2.1" + ]; + } + ) sources."extend-3.0.2" - (sources."extend-shallow-3.0.2" // { - dependencies = [ - sources."is-extendable-1.0.1" - ]; - }) + ( + sources."extend-shallow-3.0.2" + // { + dependencies = [ + sources."is-extendable-1.0.1" + ]; + } + ) sources."external-editor-3.1.0" - (sources."extglob-2.0.4" // { - dependencies = [ - sources."define-property-1.0.0" - sources."extend-shallow-2.0.1" - ]; - }) + ( + sources."extglob-2.0.4" + // { + dependencies = [ + sources."define-property-1.0.0" + sources."extend-shallow-2.0.1" + ]; + } + ) sources."extsprintf-1.3.0" sources."eyes-0.1.8" sources."fast-deep-equal-3.1.3" - (sources."fast-glob-2.2.7" // { - dependencies = [ - (sources."braces-2.3.2" // { - dependencies = [ - sources."extend-shallow-2.0.1" - ]; - }) - (sources."fill-range-4.0.0" // { - dependencies = [ - sources."extend-shallow-2.0.1" - ]; - }) - (sources."is-number-3.0.0" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) - sources."micromatch-3.1.10" - sources."to-regex-range-2.1.1" - ]; - }) + ( + sources."fast-glob-2.2.7" + // { + dependencies = [ + ( + sources."braces-2.3.2" + // { + dependencies = [ + sources."extend-shallow-2.0.1" + ]; + } + ) + ( + sources."fill-range-4.0.0" + // { + dependencies = [ + sources."extend-shallow-2.0.1" + ]; + } + ) + ( + sources."is-number-3.0.0" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) + sources."micromatch-3.1.10" + sources."to-regex-range-2.1.1" + ]; + } + ) sources."fast-json-stable-stringify-2.1.0" sources."faye-websocket-0.11.4" sources."figgy-pudding-3.5.2" - (sources."figures-2.0.0" // { - dependencies = [ - sources."escape-string-regexp-1.0.5" - ]; - }) - (sources."file-loader-6.2.0" // { - dependencies = [ - sources."loader-utils-2.0.4" - sources."schema-utils-3.3.0" - ]; - }) + ( + sources."figures-2.0.0" + // { + dependencies = [ + sources."escape-string-regexp-1.0.5" + ]; + } + ) + ( + sources."file-loader-6.2.0" + // { + dependencies = [ + sources."loader-utils-2.0.4" + sources."schema-utils-3.3.0" + ]; + } + ) sources."file-uri-to-path-1.0.0" sources."filesize-3.6.1" sources."fill-range-7.1.1" - (sources."finalhandler-1.3.1" // { - dependencies = [ - sources."debug-2.6.9" - sources."ms-2.0.0" - ]; - }) - (sources."find-cache-dir-3.3.2" // { - dependencies = [ - sources."make-dir-3.1.0" - sources."semver-6.3.1" - ]; - }) + ( + sources."finalhandler-1.3.1" + // { + dependencies = [ + sources."debug-2.6.9" + sources."ms-2.0.0" + ]; + } + ) + ( + sources."find-cache-dir-3.3.2" + // { + dependencies = [ + sources."make-dir-3.1.0" + sources."semver-6.3.1" + ]; + } + ) sources."find-elm-dependencies-2.0.4" sources."find-up-4.1.0" sources."firstline-1.3.1" @@ -16735,33 +17025,45 @@ in sources."get-value-2.0.6" sources."getpass-0.1.7" sources."glob-7.2.3" - (sources."glob-parent-3.1.0" // { - dependencies = [ - sources."is-glob-3.1.0" - ]; - }) + ( + sources."glob-parent-3.1.0" + // { + dependencies = [ + sources."is-glob-3.1.0" + ]; + } + ) sources."glob-to-regexp-0.3.0" sources."global-modules-1.0.0" - (sources."global-prefix-1.0.2" // { - dependencies = [ - sources."which-1.3.1" - ]; - }) + ( + sources."global-prefix-1.0.2" + // { + dependencies = [ + sources."which-1.3.1" + ]; + } + ) sources."globals-11.12.0" sources."globalthis-1.0.4" - (sources."globby-7.1.1" // { - dependencies = [ - sources."pify-3.0.0" - sources."slash-1.0.0" - ]; - }) + ( + sources."globby-7.1.1" + // { + dependencies = [ + sources."pify-3.0.0" + sources."slash-1.0.0" + ]; + } + ) sources."gopd-1.0.1" sources."graceful-fs-4.2.11" - (sources."gzip-size-5.0.0" // { - dependencies = [ - sources."pify-3.0.0" - ]; - }) + ( + sources."gzip-size-5.0.0" + // { + dependencies = [ + sources."pify-3.0.0" + ]; + } + ) sources."handle-thing-2.0.1" sources."har-schema-2.0.0" sources."har-validator-5.1.5" @@ -16773,22 +17075,31 @@ in sources."has-symbols-1.0.3" sources."has-tostringtag-1.0.2" sources."has-value-1.0.0" - (sources."has-values-1.0.0" // { - dependencies = [ - (sources."is-number-3.0.0" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) - sources."kind-of-4.0.0" - ]; - }) - (sources."hash-base-3.1.0" // { - dependencies = [ - sources."readable-stream-3.6.2" - sources."safe-buffer-5.2.1" - ]; - }) + ( + sources."has-values-1.0.0" + // { + dependencies = [ + ( + sources."is-number-3.0.0" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) + sources."kind-of-4.0.0" + ]; + } + ) + ( + sources."hash-base-3.1.0" + // { + dependencies = [ + sources."readable-stream-3.6.2" + sources."safe-buffer-5.2.1" + ]; + } + ) sources."hash.js-1.1.7" sources."hasown-2.0.2" sources."he-1.2.0" @@ -16812,42 +17123,51 @@ in sources."https-browserify-1.0.0" sources."i-0.3.7" sources."iconv-lite-0.4.24" - (sources."icss-utils-4.1.1" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) + ( + sources."icss-utils-4.1.1" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) sources."ieee754-1.2.1" sources."iferr-0.1.5" sources."ignore-3.3.10" sources."immer-1.7.2" sources."import-fresh-2.0.0" - (sources."import-local-2.0.0" // { - dependencies = [ - sources."find-up-3.0.0" - sources."locate-path-3.0.0" - sources."p-locate-3.0.0" - sources."path-exists-3.0.0" - sources."pkg-dir-3.0.0" - ]; - }) + ( + sources."import-local-2.0.0" + // { + dependencies = [ + sources."find-up-3.0.0" + sources."locate-path-3.0.0" + sources."p-locate-3.0.0" + sources."path-exists-3.0.0" + sources."pkg-dir-3.0.0" + ]; + } + ) sources."imurmurhash-0.1.4" sources."indexes-of-1.0.1" sources."infer-owner-1.0.4" sources."inflight-1.0.6" sources."inherits-2.0.4" sources."ini-1.3.8" - (sources."inquirer-6.2.0" // { - dependencies = [ - sources."ansi-regex-3.0.1" - sources."is-fullwidth-code-point-2.0.0" - sources."mute-stream-0.0.7" - sources."string-width-2.1.1" - sources."strip-ansi-4.0.0" - ]; - }) + ( + sources."inquirer-6.2.0" + // { + dependencies = [ + sources."ansi-regex-3.0.1" + sources."is-fullwidth-code-point-2.0.0" + sources."mute-stream-0.0.7" + sources."string-width-2.1.1" + sources."strip-ansi-4.0.0" + ]; + } + ) sources."internal-ip-4.3.0" sources."internal-slot-1.0.7" sources."invert-kv-1.0.0" @@ -16910,11 +17230,14 @@ in sources."json-parse-even-better-errors-2.3.1" sources."json-schema-0.4.0" sources."json-schema-traverse-0.4.1" - (sources."json-stable-stringify-1.1.1" // { - dependencies = [ - sources."isarray-2.0.5" - ]; - }) + ( + sources."json-stable-stringify-1.1.1" + // { + dependencies = [ + sources."isarray-2.0.5" + ]; + } + ) sources."json-stringify-safe-5.0.1" sources."json3-3.3.3" sources."json5-2.2.3" @@ -16927,18 +17250,24 @@ in sources."last-call-webpack-plugin-3.0.0" sources."lcid-1.0.0" sources."lines-and-columns-1.2.4" - (sources."load-json-file-1.1.0" // { - dependencies = [ - sources."parse-json-2.2.0" - sources."pify-2.3.0" - ]; - }) + ( + sources."load-json-file-1.1.0" + // { + dependencies = [ + sources."parse-json-2.2.0" + sources."pify-2.3.0" + ]; + } + ) sources."loader-runner-2.4.0" - (sources."loader-utils-1.4.2" // { - dependencies = [ - sources."json5-1.0.2" - ]; - }) + ( + sources."loader-utils-1.4.2" + // { + dependencies = [ + sources."json5-1.0.2" + ]; + } + ) sources."locate-path-5.0.0" sources."lodash-4.17.21" sources."lodash._reinterpolate-3.0.0" @@ -16960,30 +17289,39 @@ in sources."merge2-1.4.1" sources."methods-1.1.2" sources."micromatch-4.0.8" - (sources."miller-rabin-4.0.1" // { - dependencies = [ - sources."bn.js-4.12.0" - ]; - }) + ( + sources."miller-rabin-4.0.1" + // { + dependencies = [ + sources."bn.js-4.12.0" + ]; + } + ) sources."mime-1.6.0" sources."mime-db-1.52.0" sources."mime-types-2.1.35" sources."mimic-fn-1.2.0" - (sources."mini-css-extract-plugin-0.12.0" // { - dependencies = [ - sources."schema-utils-1.0.0" - ]; - }) + ( + sources."mini-css-extract-plugin-0.12.0" + // { + dependencies = [ + sources."schema-utils-1.0.0" + ]; + } + ) sources."minimalistic-assert-1.0.1" sources."minimalistic-crypto-utils-1.0.1" sources."minimatch-3.1.2" sources."minimist-1.2.5" sources."mississippi-3.0.0" - (sources."mixin-deep-1.3.2" // { - dependencies = [ - sources."is-extendable-1.0.1" - ]; - }) + ( + sources."mixin-deep-1.3.2" + // { + dependencies = [ + sources."is-extendable-1.0.1" + ]; + } + ) sources."mkdirp-0.5.3" sources."move-concurrently-1.0.1" sources."ms-2.1.3" @@ -16998,42 +17336,54 @@ in sources."neo-async-2.6.2" sources."nice-try-1.0.5" sources."no-case-3.0.4" - (sources."node-elm-compiler-5.0.6" // { - dependencies = [ - sources."cross-spawn-6.0.5" - sources."path-key-2.0.1" - sources."shebang-command-1.2.0" - sources."shebang-regex-1.0.0" - sources."which-1.3.1" - ]; - }) + ( + sources."node-elm-compiler-5.0.6" + // { + dependencies = [ + sources."cross-spawn-6.0.5" + sources."path-key-2.0.1" + sources."shebang-command-1.2.0" + sources."shebang-regex-1.0.0" + sources."which-1.3.1" + ]; + } + ) sources."node-forge-0.10.0" - (sources."node-libs-browser-2.2.1" // { - dependencies = [ - sources."punycode-1.4.1" - ]; - }) + ( + sources."node-libs-browser-2.2.1" + // { + dependencies = [ + sources."punycode-1.4.1" + ]; + } + ) sources."node-releases-2.0.18" sources."normalize-package-data-2.5.0" sources."normalize-path-3.0.0" sources."normalize-range-0.1.2" sources."normalize-url-1.9.1" - (sources."npm-run-path-2.0.2" // { - dependencies = [ - sources."path-key-2.0.1" - ]; - }) + ( + sources."npm-run-path-2.0.2" + // { + dependencies = [ + sources."path-key-2.0.1" + ]; + } + ) sources."nth-check-2.1.1" sources."number-is-nan-1.0.1" sources."oauth-sign-0.9.0" sources."object-assign-4.1.1" - (sources."object-copy-0.1.0" // { - dependencies = [ - sources."define-property-0.2.5" - sources."is-descriptor-0.1.7" - sources."kind-of-3.2.2" - ]; - }) + ( + sources."object-copy-0.1.0" + // { + dependencies = [ + sources."define-property-0.2.5" + sources."is-descriptor-0.1.7" + sources."kind-of-3.2.2" + ]; + } + ) sources."object-inspect-1.13.2" sources."object-is-1.1.6" sources."object-keys-1.1.1" @@ -17063,17 +17413,23 @@ in sources."pako-1.0.11" sources."parallel-transform-1.2.0" sources."param-case-3.0.4" - (sources."parent-module-1.0.1" // { - dependencies = [ - sources."callsites-3.1.0" - ]; - }) - (sources."parse-asn1-5.1.7" // { - dependencies = [ - sources."hash-base-3.0.4" - sources."safe-buffer-5.2.1" - ]; - }) + ( + sources."parent-module-1.0.1" + // { + dependencies = [ + sources."callsites-3.1.0" + ]; + } + ) + ( + sources."parse-asn1-5.1.7" + // { + dependencies = [ + sources."hash-base-3.0.4" + sources."safe-buffer-5.2.1" + ]; + } + ) sources."parse-json-4.0.0" sources."parse-passwd-1.0.0" sources."parseurl-1.3.3" @@ -17087,11 +17443,14 @@ in sources."path-key-3.1.1" sources."path-parse-1.0.7" sources."path-to-regexp-0.1.10" - (sources."path-type-3.0.0" // { - dependencies = [ - sources."pify-3.0.0" - ]; - }) + ( + sources."path-type-3.0.0" + // { + dependencies = [ + sources."pify-3.0.0" + ]; + } + ) sources."pbkdf2-3.1.2" sources."performance-now-2.1.0" sources."picocolors-1.1.0" @@ -17100,286 +17459,391 @@ in sources."pinkie-2.0.4" sources."pinkie-promise-2.0.1" sources."pkg-dir-4.2.0" - (sources."pkg-up-2.0.0" // { - dependencies = [ - sources."find-up-2.1.0" - sources."locate-path-2.0.0" - sources."p-limit-1.3.0" - sources."p-locate-2.0.0" - sources."p-try-1.0.0" - sources."path-exists-3.0.0" - ]; - }) + ( + sources."pkg-up-2.0.0" + // { + dependencies = [ + sources."find-up-2.1.0" + sources."locate-path-2.0.0" + sources."p-limit-1.3.0" + sources."p-locate-2.0.0" + sources."p-try-1.0.0" + sources."path-exists-3.0.0" + ]; + } + ) sources."pkginfo-0.4.1" - (sources."portfinder-1.0.32" // { - dependencies = [ - sources."async-2.6.4" - sources."debug-3.2.7" - sources."minimist-1.2.8" - sources."mkdirp-0.5.6" - ]; - }) + ( + sources."portfinder-1.0.32" + // { + dependencies = [ + sources."async-2.6.4" + sources."debug-3.2.7" + sources."minimist-1.2.8" + sources."mkdirp-0.5.6" + ]; + } + ) sources."posix-character-classes-0.1.1" sources."possible-typed-array-names-1.0.0" sources."postcss-8.4.47" - (sources."postcss-calc-7.0.5" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-colormin-4.0.3" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-convert-values-4.0.1" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-discard-comments-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-discard-duplicates-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-discard-empty-4.0.1" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-discard-overridden-4.0.1" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-flexbugs-fixes-4.2.1" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-loader-4.1.0" // { - dependencies = [ - sources."cosmiconfig-7.1.0" - sources."import-fresh-3.3.0" - sources."loader-utils-2.0.4" - sources."parse-json-5.2.0" - sources."path-type-4.0.0" - sources."resolve-from-4.0.0" - sources."schema-utils-3.3.0" - sources."semver-7.6.3" - ]; - }) - (sources."postcss-merge-longhand-4.0.11" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-merge-rules-4.0.3" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-selector-parser-3.1.2" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-minify-font-values-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-minify-gradients-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-minify-params-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-minify-selectors-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-selector-parser-3.1.2" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-modules-extract-imports-2.0.0" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-modules-local-by-default-3.0.3" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-modules-scope-2.2.0" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-modules-values-3.0.0" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-normalize-charset-4.0.1" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-normalize-display-values-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-normalize-positions-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-normalize-repeat-style-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-normalize-string-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-normalize-timing-functions-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-normalize-unicode-4.0.1" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-normalize-url-4.0.1" // { - dependencies = [ - sources."normalize-url-3.3.0" - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-normalize-whitespace-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-ordered-values-4.1.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-reduce-initial-4.0.3" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-reduce-transforms-4.0.2" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) + ( + sources."postcss-calc-7.0.5" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-colormin-4.0.3" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-convert-values-4.0.1" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-discard-comments-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-discard-duplicates-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-discard-empty-4.0.1" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-discard-overridden-4.0.1" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-flexbugs-fixes-4.2.1" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-loader-4.1.0" + // { + dependencies = [ + sources."cosmiconfig-7.1.0" + sources."import-fresh-3.3.0" + sources."loader-utils-2.0.4" + sources."parse-json-5.2.0" + sources."path-type-4.0.0" + sources."resolve-from-4.0.0" + sources."schema-utils-3.3.0" + sources."semver-7.6.3" + ]; + } + ) + ( + sources."postcss-merge-longhand-4.0.11" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-merge-rules-4.0.3" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-selector-parser-3.1.2" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-minify-font-values-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-minify-gradients-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-minify-params-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-minify-selectors-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-selector-parser-3.1.2" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-modules-extract-imports-2.0.0" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-modules-local-by-default-3.0.3" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-modules-scope-2.2.0" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-modules-values-3.0.0" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-normalize-charset-4.0.1" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-normalize-display-values-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-normalize-positions-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-normalize-repeat-style-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-normalize-string-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-normalize-timing-functions-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-normalize-unicode-4.0.1" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-normalize-url-4.0.1" + // { + dependencies = [ + sources."normalize-url-3.3.0" + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-normalize-whitespace-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-ordered-values-4.1.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-reduce-initial-4.0.3" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-reduce-transforms-4.0.2" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) sources."postcss-safe-parser-5.0.2" sources."postcss-selector-parser-6.1.2" - (sources."postcss-svgo-4.0.3" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-value-parser-3.3.1" - sources."source-map-0.6.1" - ]; - }) - (sources."postcss-unique-selectors-4.0.1" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."source-map-0.6.1" - ]; - }) + ( + sources."postcss-svgo-4.0.3" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-value-parser-3.3.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."postcss-unique-selectors-4.0.1" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."source-map-0.6.1" + ]; + } + ) sources."postcss-value-parser-4.2.0" sources."prepend-http-1.0.4" sources."pretty-bytes-5.6.0" @@ -17393,17 +17857,23 @@ in sources."prr-1.0.1" sources."pseudomap-1.0.2" sources."psl-1.9.0" - (sources."public-encrypt-4.0.3" // { - dependencies = [ - sources."bn.js-4.12.0" - ]; - }) + ( + sources."public-encrypt-4.0.3" + // { + dependencies = [ + sources."bn.js-4.12.0" + ]; + } + ) sources."pump-3.0.2" - (sources."pumpify-1.5.1" // { - dependencies = [ - sources."pump-2.0.1" - ]; - }) + ( + sources."pumpify-1.5.1" + // { + dependencies = [ + sources."pump-2.0.1" + ]; + } + ) sources."punycode-2.3.1" sources."q-1.5.1" sources."qs-6.5.3" @@ -17414,58 +17884,70 @@ in sources."randomfill-1.0.4" sources."range-parser-1.2.1" sources."raw-body-2.5.2" - (sources."react-dev-utils-6.1.1" // { - dependencies = [ - sources."@babel/code-frame-7.0.0" - sources."ansi-regex-3.0.1" - sources."big.js-3.2.0" - sources."browserslist-4.1.1" - sources."chalk-2.4.1" - sources."cross-spawn-6.0.5" - sources."debug-2.6.9" - sources."emojis-list-2.1.0" - sources."escape-string-regexp-1.0.5" - sources."find-up-3.0.0" - sources."globby-8.0.1" - sources."json5-0.5.1" - sources."loader-utils-1.1.0" - sources."locate-path-3.0.0" - sources."ms-2.0.0" - sources."node-releases-1.1.77" - sources."p-locate-3.0.0" - sources."path-exists-3.0.0" - sources."path-key-2.0.1" - sources."pify-3.0.0" - sources."react-error-overlay-5.1.6" - sources."shebang-command-1.2.0" - sources."shebang-regex-1.0.0" - sources."slash-1.0.0" - sources."sockjs-client-1.1.5" - sources."strip-ansi-4.0.0" - sources."which-1.3.1" - ]; - }) + ( + sources."react-dev-utils-6.1.1" + // { + dependencies = [ + sources."@babel/code-frame-7.0.0" + sources."ansi-regex-3.0.1" + sources."big.js-3.2.0" + sources."browserslist-4.1.1" + sources."chalk-2.4.1" + sources."cross-spawn-6.0.5" + sources."debug-2.6.9" + sources."emojis-list-2.1.0" + sources."escape-string-regexp-1.0.5" + sources."find-up-3.0.0" + sources."globby-8.0.1" + sources."json5-0.5.1" + sources."loader-utils-1.1.0" + sources."locate-path-3.0.0" + sources."ms-2.0.0" + sources."node-releases-1.1.77" + sources."p-locate-3.0.0" + sources."path-exists-3.0.0" + sources."path-key-2.0.1" + sources."pify-3.0.0" + sources."react-error-overlay-5.1.6" + sources."shebang-command-1.2.0" + sources."shebang-regex-1.0.0" + sources."slash-1.0.0" + sources."sockjs-client-1.1.5" + sources."strip-ansi-4.0.0" + sources."which-1.3.1" + ]; + } + ) sources."react-error-overlay-4.0.1" sources."read-1.0.7" - (sources."read-pkg-1.1.0" // { - dependencies = [ - sources."path-type-1.1.0" - sources."pify-2.3.0" - ]; - }) - (sources."read-pkg-up-1.0.1" // { - dependencies = [ - sources."find-up-1.1.2" - sources."path-exists-2.1.0" - ]; - }) + ( + sources."read-pkg-1.1.0" + // { + dependencies = [ + sources."path-type-1.1.0" + sources."pify-2.3.0" + ]; + } + ) + ( + sources."read-pkg-up-1.0.1" + // { + dependencies = [ + sources."find-up-1.1.2" + sources."path-exists-2.1.0" + ]; + } + ) sources."readable-stream-2.3.8" sources."readdirp-3.6.0" - (sources."recursive-readdir-2.2.2" // { - dependencies = [ - sources."minimatch-3.0.4" - ]; - }) + ( + sources."recursive-readdir-2.2.2" + // { + dependencies = [ + sources."minimatch-3.0.4" + ]; + } + ) sources."regenerate-1.4.2" sources."regenerate-unicode-properties-10.2.0" sources."regenerator-runtime-0.13.11" @@ -17473,19 +17955,25 @@ in sources."regex-not-1.0.2" sources."regexp.prototype.flags-1.5.2" sources."regexpu-core-5.3.2" - (sources."regjsparser-0.9.1" // { - dependencies = [ - sources."jsesc-0.5.0" - ]; - }) + ( + sources."regjsparser-0.9.1" + // { + dependencies = [ + sources."jsesc-0.5.0" + ]; + } + ) sources."relateurl-0.2.7" sources."remove-trailing-separator-1.1.0" - (sources."renderkid-2.0.7" // { - dependencies = [ - sources."ansi-regex-2.1.1" - sources."strip-ansi-3.0.1" - ]; - }) + ( + sources."renderkid-2.0.7" + // { + dependencies = [ + sources."ansi-regex-2.1.1" + sources."strip-ansi-3.0.1" + ]; + } + ) sources."repeat-element-1.1.4" sources."repeat-string-1.6.1" sources."request-2.88.2" @@ -17507,16 +17995,22 @@ in sources."ripemd160-2.0.2" sources."run-async-2.4.1" sources."run-queue-1.0.3" - (sources."rxjs-6.6.7" // { - dependencies = [ - sources."tslib-1.14.1" - ]; - }) - (sources."safe-array-concat-1.1.2" // { - dependencies = [ - sources."isarray-2.0.5" - ]; - }) + ( + sources."rxjs-6.6.7" + // { + dependencies = [ + sources."tslib-1.14.1" + ]; + } + ) + ( + sources."safe-array-concat-1.1.2" + // { + dependencies = [ + sources."isarray-2.0.5" + ]; + } + ) sources."safe-buffer-5.1.2" sources."safe-regex-1.1.0" sources."safe-regex-test-1.0.3" @@ -17526,37 +18020,49 @@ in sources."select-hose-2.0.0" sources."selfsigned-1.10.14" sources."semver-5.7.2" - (sources."send-0.19.0" // { - dependencies = [ - (sources."debug-2.6.9" // { - dependencies = [ - sources."ms-2.0.0" - ]; - }) - sources."encodeurl-1.0.2" - ]; - }) + ( + sources."send-0.19.0" + // { + dependencies = [ + ( + sources."debug-2.6.9" + // { + dependencies = [ + sources."ms-2.0.0" + ]; + } + ) + sources."encodeurl-1.0.2" + ]; + } + ) sources."serialize-javascript-4.0.0" - (sources."serve-index-1.9.1" // { - dependencies = [ - sources."debug-2.6.9" - sources."depd-1.1.2" - sources."http-errors-1.6.3" - sources."inherits-2.0.3" - sources."ms-2.0.0" - sources."setprototypeof-1.1.0" - sources."statuses-1.5.0" - ]; - }) + ( + sources."serve-index-1.9.1" + // { + dependencies = [ + sources."debug-2.6.9" + sources."depd-1.1.2" + sources."http-errors-1.6.3" + sources."inherits-2.0.3" + sources."ms-2.0.0" + sources."setprototypeof-1.1.0" + sources."statuses-1.5.0" + ]; + } + ) sources."serve-static-1.16.2" sources."set-blocking-2.0.0" sources."set-function-length-1.2.2" sources."set-function-name-2.0.2" - (sources."set-value-2.0.1" // { - dependencies = [ - sources."extend-shallow-2.0.1" - ]; - }) + ( + sources."set-value-2.0.1" + // { + dependencies = [ + sources."extend-shallow-2.0.1" + ]; + } + ) sources."setimmediate-1.0.5" sources."setprototypeof-1.2.0" sources."sha.js-2.4.11" @@ -17565,64 +18071,88 @@ in sources."shell-quote-1.6.1" sources."side-channel-1.0.6" sources."signal-exit-3.0.7" - (sources."simple-swizzle-0.2.2" // { - dependencies = [ - sources."is-arrayish-0.3.2" - ]; - }) + ( + sources."simple-swizzle-0.2.2" + // { + dependencies = [ + sources."is-arrayish-0.3.2" + ]; + } + ) sources."slash-2.0.0" - (sources."snapdragon-0.8.2" // { - dependencies = [ - sources."debug-2.6.9" - sources."define-property-0.2.5" - sources."extend-shallow-2.0.1" - sources."is-descriptor-0.1.7" - sources."ms-2.0.0" - ]; - }) - (sources."snapdragon-node-2.1.1" // { - dependencies = [ - sources."define-property-1.0.0" - ]; - }) - (sources."snapdragon-util-3.0.1" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) - (sources."sockjs-0.3.20" // { - dependencies = [ - sources."faye-websocket-0.10.0" - sources."websocket-driver-0.6.5" - ]; - }) - (sources."sockjs-client-1.4.0" // { - dependencies = [ - sources."debug-3.2.7" - sources."eventsource-1.1.2" - ]; - }) + ( + sources."snapdragon-0.8.2" + // { + dependencies = [ + sources."debug-2.6.9" + sources."define-property-0.2.5" + sources."extend-shallow-2.0.1" + sources."is-descriptor-0.1.7" + sources."ms-2.0.0" + ]; + } + ) + ( + sources."snapdragon-node-2.1.1" + // { + dependencies = [ + sources."define-property-1.0.0" + ]; + } + ) + ( + sources."snapdragon-util-3.0.1" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) + ( + sources."sockjs-0.3.20" + // { + dependencies = [ + sources."faye-websocket-0.10.0" + sources."websocket-driver-0.6.5" + ]; + } + ) + ( + sources."sockjs-client-1.4.0" + // { + dependencies = [ + sources."debug-3.2.7" + sources."eventsource-1.1.2" + ]; + } + ) sources."sort-keys-1.1.2" sources."source-list-map-2.0.1" sources."source-map-0.5.7" sources."source-map-js-1.2.1" sources."source-map-resolve-0.5.3" - (sources."source-map-support-0.5.21" // { - dependencies = [ - sources."source-map-0.6.1" - ]; - }) + ( + sources."source-map-support-0.5.21" + // { + dependencies = [ + sources."source-map-0.6.1" + ]; + } + ) sources."source-map-url-0.4.1" sources."spdx-correct-3.2.0" sources."spdx-exceptions-2.5.0" sources."spdx-expression-parse-3.0.1" sources."spdx-license-ids-3.0.20" sources."spdy-4.0.2" - (sources."spdy-transport-3.0.0" // { - dependencies = [ - sources."readable-stream-3.6.2" - ]; - }) + ( + sources."spdy-transport-3.0.0" + // { + dependencies = [ + sources."readable-stream-3.6.2" + ]; + } + ) sources."split-1.0.1" sources."split-string-3.1.0" sources."sprintf-js-1.0.3" @@ -17630,12 +18160,15 @@ in sources."ssri-6.0.2" sources."stable-0.1.8" sources."stack-trace-0.0.10" - (sources."static-extend-0.1.2" // { - dependencies = [ - sources."define-property-0.2.5" - sources."is-descriptor-0.1.7" - ]; - }) + ( + sources."static-extend-0.1.2" + // { + dependencies = [ + sources."define-property-0.2.5" + sources."is-descriptor-0.1.7" + ]; + } + ) sources."statuses-2.0.1" sources."stream-browserify-2.0.2" sources."stream-each-1.2.3" @@ -17643,77 +18176,104 @@ in sources."stream-shift-1.0.3" sources."strict-uri-encode-1.1.0" sources."string-replace-loader-2.3.0" - (sources."string-width-4.2.3" // { - dependencies = [ - sources."strip-ansi-6.0.1" - ]; - }) + ( + sources."string-width-4.2.3" + // { + dependencies = [ + sources."strip-ansi-6.0.1" + ]; + } + ) sources."string.prototype.trim-1.2.9" sources."string.prototype.trimend-1.0.8" sources."string.prototype.trimstart-1.0.8" sources."string_decoder-1.1.1" - (sources."stringify-object-3.3.0" // { - dependencies = [ - sources."is-obj-1.0.1" - ]; - }) + ( + sources."stringify-object-3.3.0" + // { + dependencies = [ + sources."is-obj-1.0.1" + ]; + } + ) sources."strip-ansi-6.0.0" sources."strip-bom-2.0.0" sources."strip-comments-1.0.2" sources."strip-eof-1.0.0" - (sources."style-loader-1.3.0" // { - dependencies = [ - sources."loader-utils-2.0.4" - ]; - }) - (sources."stylehacks-4.0.3" // { - dependencies = [ - sources."picocolors-0.2.1" - sources."postcss-7.0.39" - sources."postcss-selector-parser-3.1.2" - sources."source-map-0.6.1" - ]; - }) + ( + sources."style-loader-1.3.0" + // { + dependencies = [ + sources."loader-utils-2.0.4" + ]; + } + ) + ( + sources."stylehacks-4.0.3" + // { + dependencies = [ + sources."picocolors-0.2.1" + sources."postcss-7.0.39" + sources."postcss-selector-parser-3.1.2" + sources."source-map-0.6.1" + ]; + } + ) sources."supports-color-5.5.0" sources."supports-preserve-symlinks-flag-1.0.0" - (sources."svgo-1.3.2" // { - dependencies = [ - sources."css-select-2.1.0" - sources."css-what-3.4.2" - (sources."dom-serializer-0.2.2" // { - dependencies = [ - sources."domelementtype-2.3.0" - ]; - }) - sources."domelementtype-1.3.1" - sources."domutils-1.7.0" - sources."nth-check-1.0.2" - ]; - }) + ( + sources."svgo-1.3.2" + // { + dependencies = [ + sources."css-select-2.1.0" + sources."css-what-3.4.2" + ( + sources."dom-serializer-0.2.2" + // { + dependencies = [ + sources."domelementtype-2.3.0" + ]; + } + ) + sources."domelementtype-1.3.1" + sources."domutils-1.7.0" + sources."nth-check-1.0.2" + ]; + } + ) sources."tapable-1.1.3" - (sources."temp-0.9.4" // { - dependencies = [ - sources."rimraf-2.6.3" - ]; - }) - (sources."terser-4.8.1" // { - dependencies = [ - sources."commander-2.20.3" - sources."source-map-0.6.1" - ]; - }) - (sources."terser-webpack-plugin-1.4.6" // { - dependencies = [ - sources."find-cache-dir-2.1.0" - sources."find-up-3.0.0" - sources."locate-path-3.0.0" - sources."p-locate-3.0.0" - sources."path-exists-3.0.0" - sources."pkg-dir-3.0.0" - sources."schema-utils-1.0.0" - sources."source-map-0.6.1" - ]; - }) + ( + sources."temp-0.9.4" + // { + dependencies = [ + sources."rimraf-2.6.3" + ]; + } + ) + ( + sources."terser-4.8.1" + // { + dependencies = [ + sources."commander-2.20.3" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."terser-webpack-plugin-1.4.6" + // { + dependencies = [ + sources."find-cache-dir-2.1.0" + sources."find-up-3.0.0" + sources."locate-path-3.0.0" + sources."p-locate-3.0.0" + sources."path-exists-3.0.0" + sources."pkg-dir-3.0.0" + sources."schema-utils-1.0.0" + sources."source-map-0.6.1" + ]; + } + ) sources."text-table-0.2.0" sources."through-2.3.8" sources."through2-2.0.5" @@ -17723,11 +18283,14 @@ in sources."tmp-0.0.33" sources."to-arraybuffer-1.0.1" sources."to-fast-properties-2.0.0" - (sources."to-object-path-0.3.0" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) + ( + sources."to-object-path-0.3.0" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) sources."to-regex-3.0.2" sources."to-regex-range-5.0.1" sources."toidentifier-1.0.1" @@ -17742,35 +18305,41 @@ in sources."typed-array-byte-offset-1.0.2" sources."typed-array-length-1.0.6" sources."typedarray-0.0.6" - (sources."uglify-es-3.3.10" // { - dependencies = [ - sources."commander-2.14.1" - sources."source-map-0.6.1" - ]; - }) - (sources."uglifyjs-webpack-plugin-1.3.0" // { - dependencies = [ - sources."cacache-10.0.4" - sources."find-cache-dir-1.0.0" - sources."find-up-2.1.0" - sources."locate-path-2.0.0" - sources."lru-cache-4.1.5" - sources."make-dir-1.3.0" - sources."mississippi-2.0.0" - sources."p-limit-1.3.0" - sources."p-locate-2.0.0" - sources."p-try-1.0.0" - sources."path-exists-3.0.0" - sources."pify-3.0.0" - sources."pkg-dir-2.0.0" - sources."pump-2.0.1" - sources."schema-utils-0.4.7" - sources."serialize-javascript-1.9.1" - sources."source-map-0.6.1" - sources."ssri-5.3.0" - sources."yallist-2.1.2" - ]; - }) + ( + sources."uglify-es-3.3.10" + // { + dependencies = [ + sources."commander-2.14.1" + sources."source-map-0.6.1" + ]; + } + ) + ( + sources."uglifyjs-webpack-plugin-1.3.0" + // { + dependencies = [ + sources."cacache-10.0.4" + sources."find-cache-dir-1.0.0" + sources."find-up-2.1.0" + sources."locate-path-2.0.0" + sources."lru-cache-4.1.5" + sources."make-dir-1.3.0" + sources."mississippi-2.0.0" + sources."p-limit-1.3.0" + sources."p-locate-2.0.0" + sources."p-try-1.0.0" + sources."path-exists-3.0.0" + sources."pify-3.0.0" + sources."pkg-dir-2.0.0" + sources."pump-2.0.1" + sources."schema-utils-0.4.7" + sources."serialize-javascript-1.9.1" + sources."source-map-0.6.1" + sources."ssri-5.3.0" + sources."yallist-2.1.2" + ]; + } + ) sources."unbox-primitive-1.0.2" sources."undici-types-6.19.8" sources."unicode-canonical-property-names-ecmascript-2.0.1" @@ -17785,39 +18354,54 @@ in sources."universalify-0.1.2" sources."unpipe-1.0.0" sources."unquote-1.1.1" - (sources."unset-value-1.0.0" // { - dependencies = [ - (sources."has-value-0.3.1" // { - dependencies = [ - sources."isobject-2.1.0" - ]; - }) - sources."has-values-0.1.4" - ]; - }) + ( + sources."unset-value-1.0.0" + // { + dependencies = [ + ( + sources."has-value-0.3.1" + // { + dependencies = [ + sources."isobject-2.1.0" + ]; + } + ) + sources."has-values-0.1.4" + ]; + } + ) sources."upath-1.2.0" sources."update-browserslist-db-1.1.1" sources."uri-js-4.4.1" sources."urix-0.1.0" - (sources."url-0.11.4" // { - dependencies = [ - sources."punycode-1.4.1" - sources."qs-6.13.0" - ]; - }) - (sources."url-loader-4.1.1" // { - dependencies = [ - sources."loader-utils-2.0.4" - sources."schema-utils-3.3.0" - ]; - }) + ( + sources."url-0.11.4" + // { + dependencies = [ + sources."punycode-1.4.1" + sources."qs-6.13.0" + ]; + } + ) + ( + sources."url-loader-4.1.1" + // { + dependencies = [ + sources."loader-utils-2.0.4" + sources."schema-utils-3.3.0" + ]; + } + ) sources."url-parse-1.5.10" sources."use-3.1.1" - (sources."util-0.11.1" // { - dependencies = [ - sources."inherits-2.0.3" - ]; - }) + ( + sources."util-0.11.1" + // { + dependencies = [ + sources."inherits-2.0.3" + ]; + } + ) sources."util-deprecate-1.0.2" sources."util.promisify-1.0.0" sources."utila-0.4.0" @@ -17827,126 +18411,165 @@ in sources."validate-npm-package-license-3.0.4" sources."vary-1.1.2" sources."vendors-1.0.4" - (sources."verror-1.10.0" // { - dependencies = [ - sources."core-util-is-1.0.2" - ]; - }) + ( + sources."verror-1.10.0" + // { + dependencies = [ + sources."core-util-is-1.0.2" + ]; + } + ) sources."vm-browserify-1.1.2" sources."watchpack-1.7.5" - (sources."watchpack-chokidar2-2.0.1" // { - dependencies = [ - sources."anymatch-2.0.0" - sources."binary-extensions-1.13.1" - sources."braces-2.3.2" - sources."chokidar-2.1.8" - sources."extend-shallow-2.0.1" - sources."fill-range-4.0.0" - sources."is-binary-path-1.0.1" - sources."is-extendable-1.0.1" - sources."is-number-3.0.0" - sources."kind-of-3.2.2" - (sources."micromatch-3.1.10" // { - dependencies = [ - sources."extend-shallow-3.0.2" - sources."kind-of-6.0.3" - ]; - }) - sources."normalize-path-2.1.1" - sources."readdirp-2.2.1" - sources."to-regex-range-2.1.1" - ]; - }) + ( + sources."watchpack-chokidar2-2.0.1" + // { + dependencies = [ + sources."anymatch-2.0.0" + sources."binary-extensions-1.13.1" + sources."braces-2.3.2" + sources."chokidar-2.1.8" + sources."extend-shallow-2.0.1" + sources."fill-range-4.0.0" + sources."is-binary-path-1.0.1" + sources."is-extendable-1.0.1" + sources."is-number-3.0.0" + sources."kind-of-3.2.2" + ( + sources."micromatch-3.1.10" + // { + dependencies = [ + sources."extend-shallow-3.0.2" + sources."kind-of-6.0.3" + ]; + } + ) + sources."normalize-path-2.1.1" + sources."readdirp-2.2.1" + sources."to-regex-range-2.1.1" + ]; + } + ) sources."wbuf-1.7.3" - (sources."webpack-4.44.2" // { - dependencies = [ - sources."braces-2.3.2" - sources."extend-shallow-2.0.1" - sources."fill-range-4.0.0" - sources."is-number-3.0.0" - sources."kind-of-3.2.2" - sources."micromatch-3.1.10" - sources."schema-utils-1.0.0" - sources."to-regex-range-2.1.1" - ]; - }) - (sources."webpack-dev-middleware-3.7.3" // { - dependencies = [ - sources."mime-2.6.0" - ]; - }) - (sources."webpack-dev-server-3.11.0" // { - dependencies = [ - sources."ansi-regex-4.1.1" - sources."anymatch-2.0.0" - sources."binary-extensions-1.13.1" - sources."braces-2.3.2" - sources."chokidar-2.1.8" - (sources."cliui-5.0.0" // { - dependencies = [ - sources."strip-ansi-5.2.0" - ]; - }) - sources."emoji-regex-7.0.3" - sources."extend-shallow-2.0.1" - sources."fill-range-4.0.0" - sources."find-up-3.0.0" - sources."get-caller-file-2.0.5" - sources."http-proxy-middleware-0.19.1" - sources."is-absolute-url-3.0.3" - sources."is-binary-path-1.0.1" - sources."is-extendable-1.0.1" - sources."is-fullwidth-code-point-2.0.0" - sources."is-number-3.0.0" - sources."kind-of-3.2.2" - sources."locate-path-3.0.0" - (sources."micromatch-3.1.10" // { - dependencies = [ - sources."extend-shallow-3.0.2" - sources."kind-of-6.0.3" - ]; - }) - sources."normalize-path-2.1.1" - sources."opn-5.5.0" - sources."p-locate-3.0.0" - sources."path-exists-3.0.0" - sources."readdirp-2.2.1" - sources."require-main-filename-2.0.0" - sources."schema-utils-1.0.0" - sources."semver-6.3.1" - (sources."string-width-3.1.0" // { - dependencies = [ - sources."strip-ansi-5.2.0" - ]; - }) - (sources."strip-ansi-3.0.1" // { - dependencies = [ - sources."ansi-regex-2.1.1" - ]; - }) - sources."supports-color-6.1.0" - sources."to-regex-range-2.1.1" - sources."which-module-2.0.1" - (sources."wrap-ansi-5.1.0" // { - dependencies = [ - sources."strip-ansi-5.2.0" - ]; - }) - sources."yargs-13.3.2" - sources."yargs-parser-13.1.2" - ]; - }) + ( + sources."webpack-4.44.2" + // { + dependencies = [ + sources."braces-2.3.2" + sources."extend-shallow-2.0.1" + sources."fill-range-4.0.0" + sources."is-number-3.0.0" + sources."kind-of-3.2.2" + sources."micromatch-3.1.10" + sources."schema-utils-1.0.0" + sources."to-regex-range-2.1.1" + ]; + } + ) + ( + sources."webpack-dev-middleware-3.7.3" + // { + dependencies = [ + sources."mime-2.6.0" + ]; + } + ) + ( + sources."webpack-dev-server-3.11.0" + // { + dependencies = [ + sources."ansi-regex-4.1.1" + sources."anymatch-2.0.0" + sources."binary-extensions-1.13.1" + sources."braces-2.3.2" + sources."chokidar-2.1.8" + ( + sources."cliui-5.0.0" + // { + dependencies = [ + sources."strip-ansi-5.2.0" + ]; + } + ) + sources."emoji-regex-7.0.3" + sources."extend-shallow-2.0.1" + sources."fill-range-4.0.0" + sources."find-up-3.0.0" + sources."get-caller-file-2.0.5" + sources."http-proxy-middleware-0.19.1" + sources."is-absolute-url-3.0.3" + sources."is-binary-path-1.0.1" + sources."is-extendable-1.0.1" + sources."is-fullwidth-code-point-2.0.0" + sources."is-number-3.0.0" + sources."kind-of-3.2.2" + sources."locate-path-3.0.0" + ( + sources."micromatch-3.1.10" + // { + dependencies = [ + sources."extend-shallow-3.0.2" + sources."kind-of-6.0.3" + ]; + } + ) + sources."normalize-path-2.1.1" + sources."opn-5.5.0" + sources."p-locate-3.0.0" + sources."path-exists-3.0.0" + sources."readdirp-2.2.1" + sources."require-main-filename-2.0.0" + sources."schema-utils-1.0.0" + sources."semver-6.3.1" + ( + sources."string-width-3.1.0" + // { + dependencies = [ + sources."strip-ansi-5.2.0" + ]; + } + ) + ( + sources."strip-ansi-3.0.1" + // { + dependencies = [ + sources."ansi-regex-2.1.1" + ]; + } + ) + sources."supports-color-6.1.0" + sources."to-regex-range-2.1.1" + sources."which-module-2.0.1" + ( + sources."wrap-ansi-5.1.0" + // { + dependencies = [ + sources."strip-ansi-5.2.0" + ]; + } + ) + sources."yargs-13.3.2" + sources."yargs-parser-13.1.2" + ]; + } + ) sources."webpack-log-2.0.0" - (sources."webpack-manifest-plugin-2.2.0" // { - dependencies = [ - sources."fs-extra-7.0.1" - ]; - }) - (sources."webpack-sources-1.4.3" // { - dependencies = [ - sources."source-map-0.6.1" - ]; - }) + ( + sources."webpack-manifest-plugin-2.2.0" + // { + dependencies = [ + sources."fs-extra-7.0.1" + ]; + } + ) + ( + sources."webpack-sources-1.4.3" + // { + dependencies = [ + sources."source-map-0.6.1" + ]; + } + ) sources."websocket-driver-0.7.4" sources."websocket-extensions-0.1.4" sources."whatwg-fetch-3.5.0" @@ -17954,20 +18577,26 @@ in sources."which-boxed-primitive-1.0.2" sources."which-module-1.0.0" sources."which-typed-array-1.1.15" - (sources."winston-2.1.1" // { - dependencies = [ - sources."async-1.0.0" - sources."colors-1.0.3" - sources."pkginfo-0.3.1" - ]; - }) + ( + sources."winston-2.1.1" + // { + dependencies = [ + sources."async-1.0.0" + sources."colors-1.0.3" + sources."pkginfo-0.3.1" + ]; + } + ) sources."workbox-background-sync-4.3.1" sources."workbox-broadcast-update-4.3.1" - (sources."workbox-build-4.3.1" // { - dependencies = [ - sources."fs-extra-4.0.3" - ]; - }) + ( + sources."workbox-build-4.3.1" + // { + dependencies = [ + sources."fs-extra-4.0.3" + ]; + } + ) sources."workbox-cacheable-response-4.3.1" sources."workbox-core-4.3.1" sources."workbox-expiration-4.3.1" @@ -17982,14 +18611,17 @@ in sources."workbox-webpack-plugin-4.3.1" sources."workbox-window-4.3.1" sources."worker-farm-1.7.0" - (sources."wrap-ansi-2.1.0" // { - dependencies = [ - sources."ansi-regex-2.1.1" - sources."is-fullwidth-code-point-1.0.0" - sources."string-width-1.0.2" - sources."strip-ansi-3.0.1" - ]; - }) + ( + sources."wrap-ansi-2.1.0" + // { + dependencies = [ + sources."ansi-regex-2.1.1" + sources."is-fullwidth-code-point-1.0.0" + sources."string-width-1.0.2" + sources."strip-ansi-3.0.1" + ]; + } + ) sources."wrappy-1.0.2" sources."ws-6.2.3" sources."xmlbuilder-15.1.1" @@ -17997,21 +18629,27 @@ in sources."y18n-4.0.3" sources."yallist-3.1.1" sources."yaml-1.10.2" - (sources."yargs-6.6.0" // { - dependencies = [ - sources."ansi-regex-2.1.1" - sources."camelcase-3.0.0" - sources."is-fullwidth-code-point-1.0.0" - sources."string-width-1.0.2" - sources."strip-ansi-3.0.1" - sources."y18n-3.2.2" - ]; - }) - (sources."yargs-parser-4.2.1" // { - dependencies = [ - sources."camelcase-3.0.0" - ]; - }) + ( + sources."yargs-6.6.0" + // { + dependencies = [ + sources."ansi-regex-2.1.1" + sources."camelcase-3.0.0" + sources."is-fullwidth-code-point-1.0.0" + sources."string-width-1.0.2" + sources."strip-ansi-3.0.1" + sources."y18n-3.2.2" + ]; + } + ) + ( + sources."yargs-parser-4.2.1" + // { + dependencies = [ + sources."camelcase-3.0.0" + ]; + } + ) ]; buildInputs = globalBuildInputs; meta = { @@ -18037,11 +18675,14 @@ in sources."ansi-styles-5.2.0" sources."balanced-match-1.0.2" sources."brace-expansion-1.1.11" - (sources."chalk-4.1.2" // { - dependencies = [ - sources."ansi-styles-4.3.0" - ]; - }) + ( + sources."chalk-4.1.2" + // { + dependencies = [ + sources."ansi-styles-4.3.0" + ]; + } + ) sources."color-convert-2.0.1" sources."color-name-1.1.4" sources."commander-6.2.1" @@ -18109,30 +18750,42 @@ in sources."@jridgewell/source-map-0.3.6" sources."@jridgewell/sourcemap-codec-1.5.0" sources."@jridgewell/trace-mapping-0.3.25" - (sources."@jsonjoy.com/base64-1.1.2" // { - dependencies = [ - sources."tslib-2.7.0" - ]; - }) - (sources."@jsonjoy.com/json-pack-1.1.0" // { - dependencies = [ - sources."tslib-2.7.0" - ]; - }) - (sources."@jsonjoy.com/util-1.3.0" // { - dependencies = [ - sources."tslib-2.7.0" - ]; - }) + ( + sources."@jsonjoy.com/base64-1.1.2" + // { + dependencies = [ + sources."tslib-2.7.0" + ]; + } + ) + ( + sources."@jsonjoy.com/json-pack-1.1.0" + // { + dependencies = [ + sources."tslib-2.7.0" + ]; + } + ) + ( + sources."@jsonjoy.com/util-1.3.0" + // { + dependencies = [ + sources."tslib-2.7.0" + ]; + } + ) sources."@nodelib/fs.scandir-2.1.5" sources."@nodelib/fs.stat-2.0.5" sources."@nodelib/fs.walk-1.2.8" sources."@npmcli/agent-2.2.2" - (sources."@npmcli/fs-3.1.1" // { - dependencies = [ - sources."semver-7.6.3" - ]; - }) + ( + sources."@npmcli/fs-3.1.1" + // { + dependencies = [ + sources."semver-7.6.3" + ]; + } + ) sources."@sindresorhus/is-0.14.0" sources."@sindresorhus/merge-streams-3.0.0" sources."@szmarczak/http-timer-1.1.2" @@ -18149,12 +18802,15 @@ in sources."@types/tmp-0.0.33" sources."accepts-1.3.8" sources."acorn-8.12.1" - (sources."agent-base-7.1.1" // { - dependencies = [ - sources."debug-4.3.7" - sources."ms-2.1.3" - ]; - }) + ( + sources."agent-base-7.1.1" + // { + dependencies = [ + sources."debug-4.3.7" + sources."ms-2.1.3" + ]; + } + ) sources."aggregate-error-3.1.0" sources."ansi-escapes-4.3.2" sources."ansi-regex-5.0.1" @@ -18167,11 +18823,14 @@ in sources."balanced-match-1.0.2" sources."batch-0.6.1" sources."binary-extensions-2.3.0" - (sources."body-parser-1.20.3" // { - dependencies = [ - sources."on-finished-2.4.1" - ]; - }) + ( + sources."body-parser-1.20.3" + // { + dependencies = [ + sources."on-finished-2.4.1" + ]; + } + ) sources."brace-expansion-1.1.11" sources."braces-3.0.3" sources."buffer-builder-0.2.0" @@ -18179,19 +18838,25 @@ in sources."bufferutil-4.0.8" sources."busboy-1.6.0" sources."bytes-3.1.2" - (sources."cacache-18.0.4" // { - dependencies = [ - sources."brace-expansion-2.0.1" - sources."glob-10.4.5" - sources."minimatch-9.0.5" - ]; - }) - (sources."cacheable-request-6.1.0" // { - dependencies = [ - sources."get-stream-5.2.0" - sources."lowercase-keys-2.0.0" - ]; - }) + ( + sources."cacache-18.0.4" + // { + dependencies = [ + sources."brace-expansion-2.0.1" + sources."glob-10.4.5" + sources."minimatch-9.0.5" + ]; + } + ) + ( + sources."cacheable-request-6.1.0" + // { + dependencies = [ + sources."get-stream-5.2.0" + sources."lowercase-keys-2.0.0" + ]; + } + ) sources."call-bind-1.0.7" sources."chalk-3.0.0" sources."chokidar-3.6.0" @@ -18211,11 +18876,14 @@ in sources."cookie-0.6.0" sources."cookie-signature-1.2.1" sources."copy-anything-2.0.6" - (sources."cross-spawn-7.0.3" // { - dependencies = [ - sources."which-2.0.2" - ]; - }) + ( + sources."cross-spawn-7.0.3" + // { + dependencies = [ + sources."which-2.0.2" + ]; + } + ) sources."debug-2.6.9" sources."decompress-response-3.3.0" sources."deep-extend-0.6.0" @@ -18224,21 +18892,27 @@ in sources."depd-2.0.0" sources."destroy-1.2.0" sources."detect-libc-1.0.3" - (sources."devcert-1.2.2" // { - dependencies = [ - sources."debug-3.2.7" - sources."ms-2.1.3" - ]; - }) + ( + sources."devcert-1.2.2" + // { + dependencies = [ + sources."debug-3.2.7" + sources."ms-2.1.3" + ]; + } + ) sources."duplexer3-0.1.5" sources."eastasianwidth-0.2.0" sources."ee-first-1.1.1" - (sources."elm-doc-preview-5.0.5" // { - dependencies = [ - sources."commander-5.1.0" - sources."tmp-0.1.0" - ]; - }) + ( + sources."elm-doc-preview-5.0.5" + // { + dependencies = [ + sources."commander-5.1.0" + sources."tmp-0.1.0" + ]; + } + ) sources."elm-hot-1.1.6" sources."emoji-regex-9.2.2" sources."encodeurl-1.0.2" @@ -18252,30 +18926,39 @@ in sources."escape-html-1.0.3" sources."esprima-4.0.1" sources."etag-1.8.1" - (sources."express-4.21.0" // { - dependencies = [ - sources."cookie-signature-1.0.6" - sources."encodeurl-2.0.0" - sources."finalhandler-1.3.1" - sources."on-finished-2.4.1" - sources."statuses-2.0.1" - ]; - }) - (sources."express-ws-4.0.0" // { - dependencies = [ - sources."ws-5.2.4" - ]; - }) + ( + sources."express-4.21.0" + // { + dependencies = [ + sources."cookie-signature-1.0.6" + sources."encodeurl-2.0.0" + sources."finalhandler-1.3.1" + sources."on-finished-2.4.1" + sources."statuses-2.0.1" + ]; + } + ) + ( + sources."express-ws-4.0.0" + // { + dependencies = [ + sources."ws-5.2.4" + ]; + } + ) sources."extend-shallow-2.0.1" sources."fast-glob-3.3.2" sources."fastq-1.17.1" sources."fill-range-7.1.1" sources."finalhandler-1.1.2" - (sources."foreground-child-3.3.0" // { - dependencies = [ - sources."signal-exit-4.1.0" - ]; - }) + ( + sources."foreground-child-3.3.0" + // { + dependencies = [ + sources."signal-exit-4.1.0" + ]; + } + ) sources."forwarded-0.2.0" sources."fresh-0.5.2" sources."fs-extra-11.2.0" @@ -18287,11 +18970,14 @@ in sources."get-stream-4.1.0" sources."glob-7.2.3" sources."glob-parent-5.1.2" - (sources."globby-14.0.0" // { - dependencies = [ - sources."@sindresorhus/merge-streams-1.0.0" - ]; - }) + ( + sources."globby-14.0.0" + // { + dependencies = [ + sources."@sindresorhus/merge-streams-1.0.0" + ]; + } + ) sources."gopd-1.0.1" sources."got-9.6.0" sources."graceful-fs-4.2.11" @@ -18302,23 +18988,32 @@ in sources."has-symbols-1.0.3" sources."hasown-2.0.2" sources."http-cache-semantics-4.1.1" - (sources."http-errors-2.0.0" // { - dependencies = [ - sources."statuses-2.0.1" - ]; - }) - (sources."http-proxy-agent-7.0.2" // { - dependencies = [ - sources."debug-4.3.7" - sources."ms-2.1.3" - ]; - }) - (sources."https-proxy-agent-7.0.5" // { - dependencies = [ - sources."debug-4.3.7" - sources."ms-2.1.3" - ]; - }) + ( + sources."http-errors-2.0.0" + // { + dependencies = [ + sources."statuses-2.0.1" + ]; + } + ) + ( + sources."http-proxy-agent-7.0.2" + // { + dependencies = [ + sources."debug-4.3.7" + sources."ms-2.1.3" + ]; + } + ) + ( + sources."https-proxy-agent-7.0.5" + // { + dependencies = [ + sources."debug-4.3.7" + sources."ms-2.1.3" + ]; + } + ) sources."hyperdyperid-1.2.0" sources."iconv-lite-0.4.24" sources."ignore-5.3.2" @@ -18329,11 +19024,14 @@ in sources."inflight-1.0.6" sources."inherits-2.0.4" sources."ini-1.3.8" - (sources."ip-address-9.0.5" // { - dependencies = [ - sources."sprintf-js-1.1.3" - ]; - }) + ( + sources."ip-address-9.0.5" + // { + dependencies = [ + sources."sprintf-js-1.1.3" + ]; + } + ) sources."ipaddr.js-1.9.1" sources."is-binary-path-2.1.0" sources."is-docker-2.2.1" @@ -18357,27 +19055,36 @@ in sources."kind-of-6.0.3" sources."kleur-4.1.5" sources."latest-version-5.1.0" - (sources."less-4.2.0" // { - dependencies = [ - sources."tslib-2.7.0" - ]; - }) + ( + sources."less-4.2.0" + // { + dependencies = [ + sources."tslib-2.7.0" + ]; + } + ) sources."lightningcss-1.27.0" sources."lodash-4.17.21" sources."lowercase-keys-1.0.1" sources."lru-cache-10.4.3" - (sources."make-dir-2.1.0" // { - dependencies = [ - sources."semver-5.7.2" - ]; - }) + ( + sources."make-dir-2.1.0" + // { + dependencies = [ + sources."semver-5.7.2" + ]; + } + ) sources."make-fetch-happen-13.0.1" sources."media-typer-0.3.0" - (sources."memfs-4.12.0" // { - dependencies = [ - sources."tslib-2.7.0" - ]; - }) + ( + sources."memfs-4.12.0" + // { + dependencies = [ + sources."tslib-2.7.0" + ]; + } + ) sources."merge-descriptors-1.0.3" sources."merge2-1.4.1" sources."methods-1.1.2" @@ -18392,34 +19099,49 @@ in sources."minipass-7.1.2" sources."minipass-collect-2.0.1" sources."minipass-fetch-3.0.5" - (sources."minipass-flush-1.0.5" // { - dependencies = [ - sources."minipass-3.3.6" - ]; - }) - (sources."minipass-pipeline-1.2.4" // { - dependencies = [ - sources."minipass-3.3.6" - ]; - }) - (sources."minipass-sized-1.0.3" // { - dependencies = [ - sources."minipass-3.3.6" - ]; - }) - (sources."minizlib-2.1.2" // { - dependencies = [ - sources."minipass-3.3.6" - ]; - }) + ( + sources."minipass-flush-1.0.5" + // { + dependencies = [ + sources."minipass-3.3.6" + ]; + } + ) + ( + sources."minipass-pipeline-1.2.4" + // { + dependencies = [ + sources."minipass-3.3.6" + ]; + } + ) + ( + sources."minipass-sized-1.0.3" + // { + dependencies = [ + sources."minipass-3.3.6" + ]; + } + ) + ( + sources."minizlib-2.1.2" + // { + dependencies = [ + sources."minipass-3.3.6" + ]; + } + ) sources."mkdirp-0.5.6" sources."ms-2.0.0" sources."nanoid-3.3.7" - (sources."needle-3.3.1" // { - dependencies = [ - sources."iconv-lite-0.6.3" - ]; - }) + ( + sources."needle-3.3.1" + // { + dependencies = [ + sources."iconv-lite-0.6.3" + ]; + } + ) sources."negotiator-0.6.3" sources."node-gyp-build-4.8.2" sources."normalize-path-3.0.0" @@ -18468,47 +19190,65 @@ in sources."rimraf-2.7.1" sources."rollup-4.22.5" sources."run-parallel-1.2.0" - (sources."rxjs-7.8.1" // { - dependencies = [ - sources."tslib-2.7.0" - ]; - }) + ( + sources."rxjs-7.8.1" + // { + dependencies = [ + sources."tslib-2.7.0" + ]; + } + ) sources."safe-buffer-5.2.1" sources."safer-buffer-2.1.2" - (sources."sass-1.79.3" // { - dependencies = [ - sources."chokidar-4.0.1" - sources."readdirp-4.0.1" - ]; - }) - (sources."sass-embedded-1.79.3" // { - dependencies = [ - sources."supports-color-8.1.1" - ]; - }) + ( + sources."sass-1.79.3" + // { + dependencies = [ + sources."chokidar-4.0.1" + sources."readdirp-4.0.1" + ]; + } + ) + ( + sources."sass-embedded-1.79.3" + // { + dependencies = [ + sources."supports-color-8.1.1" + ]; + } + ) sources."sax-1.4.1" sources."section-matter-1.0.0" sources."semver-6.3.1" - (sources."send-0.19.0" // { - dependencies = [ - sources."ms-2.1.3" - sources."on-finished-2.4.1" - sources."statuses-2.0.1" - ]; - }) - (sources."serve-index-1.9.1" // { - dependencies = [ - sources."depd-1.1.2" - sources."http-errors-1.6.3" - sources."inherits-2.0.3" - sources."setprototypeof-1.1.0" - ]; - }) - (sources."serve-static-1.16.2" // { - dependencies = [ - sources."encodeurl-2.0.0" - ]; - }) + ( + sources."send-0.19.0" + // { + dependencies = [ + sources."ms-2.1.3" + sources."on-finished-2.4.1" + sources."statuses-2.0.1" + ]; + } + ) + ( + sources."serve-index-1.9.1" + // { + dependencies = [ + sources."depd-1.1.2" + sources."http-errors-1.6.3" + sources."inherits-2.0.3" + sources."setprototypeof-1.1.0" + ]; + } + ) + ( + sources."serve-static-1.16.2" + // { + dependencies = [ + sources."encodeurl-2.0.0" + ]; + } + ) sources."set-function-length-1.2.2" sources."setprototypeof-1.2.0" sources."shebang-command-2.0.0" @@ -18518,12 +19258,15 @@ in sources."slash-5.1.0" sources."smart-buffer-4.2.0" sources."socks-2.8.3" - (sources."socks-proxy-agent-8.0.4" // { - dependencies = [ - sources."debug-4.3.7" - sources."ms-2.1.3" - ]; - }) + ( + sources."socks-proxy-agent-8.0.4" + // { + dependencies = [ + sources."debug-4.3.7" + sources."ms-2.1.3" + ]; + } + ) sources."source-map-0.6.1" sources."source-map-js-1.2.1" sources."source-map-support-0.5.21" @@ -18532,61 +19275,85 @@ in sources."statuses-1.5.0" sources."streamsearch-1.1.0" sources."string-width-5.1.2" - (sources."string-width-cjs-4.2.3" // { - dependencies = [ - sources."emoji-regex-8.0.0" - sources."strip-ansi-6.0.1" - ]; - }) - (sources."strip-ansi-7.1.0" // { - dependencies = [ - sources."ansi-regex-6.1.0" - ]; - }) + ( + sources."string-width-cjs-4.2.3" + // { + dependencies = [ + sources."emoji-regex-8.0.0" + sources."strip-ansi-6.0.1" + ]; + } + ) + ( + sources."strip-ansi-7.1.0" + // { + dependencies = [ + sources."ansi-regex-6.1.0" + ]; + } + ) sources."strip-ansi-cjs-6.0.1" sources."strip-bom-string-1.0.0" sources."strip-json-comments-2.0.1" - (sources."stylus-0.63.0" // { - dependencies = [ - sources."debug-4.3.7" - sources."ms-2.1.3" - sources."sax-1.3.0" - sources."source-map-0.7.4" - ]; - }) + ( + sources."stylus-0.63.0" + // { + dependencies = [ + sources."debug-4.3.7" + sources."ms-2.1.3" + sources."sax-1.3.0" + sources."source-map-0.7.4" + ]; + } + ) sources."sudo-prompt-8.2.5" sources."sugarss-4.0.1" sources."supports-color-7.2.0" - (sources."tar-6.2.1" // { - dependencies = [ - (sources."fs-minipass-2.1.0" // { - dependencies = [ - sources."minipass-3.3.6" - ]; - }) - sources."minipass-5.0.0" - sources."mkdirp-1.0.4" - ]; - }) - (sources."terser-5.34.0" // { - dependencies = [ - sources."commander-2.20.3" - ]; - }) - (sources."thingies-1.21.0" // { - dependencies = [ - sources."tslib-2.7.0" - ]; - }) + ( + sources."tar-6.2.1" + // { + dependencies = [ + ( + sources."fs-minipass-2.1.0" + // { + dependencies = [ + sources."minipass-3.3.6" + ]; + } + ) + sources."minipass-5.0.0" + sources."mkdirp-1.0.4" + ]; + } + ) + ( + sources."terser-5.34.0" + // { + dependencies = [ + sources."commander-2.20.3" + ]; + } + ) + ( + sources."thingies-1.21.0" + // { + dependencies = [ + sources."tslib-2.7.0" + ]; + } + ) sources."tmp-0.0.33" sources."to-readable-stream-1.0.0" sources."to-regex-range-5.0.1" sources."toidentifier-1.0.1" - (sources."tree-dump-1.0.2" // { - dependencies = [ - sources."tslib-2.7.0" - ]; - }) + ( + sources."tree-dump-1.0.2" + // { + dependencies = [ + sources."tslib-2.7.0" + ]; + } + ) sources."tslib-1.14.1" sources."type-fest-0.21.3" sources."type-is-1.6.18" @@ -18601,29 +19368,41 @@ in sources."utils-merge-1.0.1" sources."varint-6.0.0" sources."vary-1.1.2" - (sources."vite-5.4.8" // { - dependencies = [ - sources."@types/node-22.7.3" - sources."esbuild-0.21.5" - ]; - }) - (sources."which-4.0.0" // { - dependencies = [ - sources."isexe-3.1.1" - ]; - }) - (sources."wrap-ansi-8.1.0" // { - dependencies = [ - sources."ansi-styles-6.2.1" - ]; - }) - (sources."wrap-ansi-cjs-7.0.0" // { - dependencies = [ - sources."emoji-regex-8.0.0" - sources."string-width-4.2.3" - sources."strip-ansi-6.0.1" - ]; - }) + ( + sources."vite-5.4.8" + // { + dependencies = [ + sources."@types/node-22.7.3" + sources."esbuild-0.21.5" + ]; + } + ) + ( + sources."which-4.0.0" + // { + dependencies = [ + sources."isexe-3.1.1" + ]; + } + ) + ( + sources."wrap-ansi-8.1.0" + // { + dependencies = [ + sources."ansi-styles-6.2.1" + ]; + } + ) + ( + sources."wrap-ansi-cjs-7.0.0" + // { + dependencies = [ + sources."emoji-regex-8.0.0" + sources."string-width-4.2.3" + sources."strip-ansi-6.0.1" + ]; + } + ) sources."wrappy-1.0.2" sources."ws-7.5.10" sources."yallist-4.0.0" @@ -18647,13 +19426,16 @@ in sha512 = "so+G1hvCV85A63sQQzEhCNFNYyQVWDexXrz0TNEYg3/IIGHzN1bcRN+W4KJSvvFcmfEImzMSJ9AN20bvemU+4Q=="; }; dependencies = [ - (sources."@isaacs/cliui-8.0.2" // { - dependencies = [ - sources."ansi-styles-6.2.1" - sources."strip-ansi-7.1.0" - sources."wrap-ansi-8.1.0" - ]; - }) + ( + sources."@isaacs/cliui-8.0.2" + // { + dependencies = [ + sources."ansi-styles-6.2.1" + sources."strip-ansi-7.1.0" + sources."wrap-ansi-8.1.0" + ]; + } + ) sources."@nodelib/fs.scandir-2.1.5" sources."@nodelib/fs.stat-2.0.5" sources."@nodelib/fs.walk-1.2.8" @@ -18689,11 +19471,14 @@ in sources."concat-map-0.0.1" sources."cross-spawn-7.0.3" sources."debug-4.3.7" - (sources."decompress-response-6.0.0" // { - dependencies = [ - sources."mimic-response-3.1.0" - ]; - }) + ( + sources."decompress-response-6.0.0" + // { + dependencies = [ + sources."mimic-response-3.1.0" + ]; + } + ) sources."defaults-1.0.4" sources."defer-to-connect-2.0.1" sources."dir-glob-3.0.1" @@ -18710,12 +19495,15 @@ in sources."foreground-child-3.3.0" sources."fs-extra-9.1.0" sources."get-stream-5.2.0" - (sources."glob-10.4.5" // { - dependencies = [ - sources."brace-expansion-2.0.1" - sources."minimatch-9.0.5" - ]; - }) + ( + sources."glob-10.4.5" + // { + dependencies = [ + sources."brace-expansion-2.0.1" + sources."minimatch-9.0.5" + ]; + } + ) sources."glob-parent-5.1.2" sources."globby-13.2.2" sources."got-11.8.6" @@ -18774,11 +19562,14 @@ in sources."readdirp-3.6.0" sources."resolve-alpn-1.2.1" sources."responselike-2.0.1" - (sources."restore-cursor-3.1.0" // { - dependencies = [ - sources."signal-exit-3.0.7" - ]; - }) + ( + sources."restore-cursor-3.1.0" + // { + dependencies = [ + sources."signal-exit-3.0.7" + ]; + } + ) sources."reusify-1.0.4" sources."rimraf-5.0.10" sources."run-parallel-1.2.0" @@ -18788,27 +19579,39 @@ in sources."signal-exit-4.1.0" sources."sisteransi-1.0.5" sources."slash-4.0.0" - (sources."string-width-5.1.2" // { - dependencies = [ - sources."strip-ansi-7.1.0" - ]; - }) - (sources."string-width-cjs-4.2.3" // { - dependencies = [ - sources."emoji-regex-8.0.0" - ]; - }) + ( + sources."string-width-5.1.2" + // { + dependencies = [ + sources."strip-ansi-7.1.0" + ]; + } + ) + ( + sources."string-width-cjs-4.2.3" + // { + dependencies = [ + sources."emoji-regex-8.0.0" + ]; + } + ) sources."string_decoder-1.3.0" - (sources."strip-ansi-6.0.1" // { - dependencies = [ - sources."ansi-regex-5.0.1" - ]; - }) - (sources."strip-ansi-cjs-6.0.1" // { - dependencies = [ - sources."ansi-regex-5.0.1" - ]; - }) + ( + sources."strip-ansi-6.0.1" + // { + dependencies = [ + sources."ansi-regex-5.0.1" + ]; + } + ) + ( + sources."strip-ansi-cjs-6.0.1" + // { + dependencies = [ + sources."ansi-regex-5.0.1" + ]; + } + ) sources."supports-color-7.2.0" sources."supports-hyperlinks-2.3.0" sources."terminal-link-2.1.1" @@ -18819,18 +19622,24 @@ in sources."util-deprecate-1.0.2" sources."wcwidth-1.0.1" sources."which-2.0.2" - (sources."wrap-ansi-7.0.0" // { - dependencies = [ - sources."emoji-regex-8.0.0" - sources."string-width-4.2.3" - ]; - }) - (sources."wrap-ansi-cjs-7.0.0" // { - dependencies = [ - sources."emoji-regex-8.0.0" - sources."string-width-4.2.3" - ]; - }) + ( + sources."wrap-ansi-7.0.0" + // { + dependencies = [ + sources."emoji-regex-8.0.0" + sources."string-width-4.2.3" + ]; + } + ) + ( + sources."wrap-ansi-cjs-7.0.0" + // { + dependencies = [ + sources."emoji-regex-8.0.0" + sources."string-width-4.2.3" + ]; + } + ) sources."wrappy-1.0.2" ]; buildInputs = globalBuildInputs; diff --git a/pkgs/development/compilers/emscripten/default.nix b/pkgs/development/compilers/emscripten/default.nix index 4d5d69e495f7a9..6a3e7738fc1d9c 100644 --- a/pkgs/development/compilers/emscripten/default.nix +++ b/pkgs/development/compilers/emscripten/default.nix @@ -1,9 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, python3, nodejs, closurecompiler -, jre, binaryen -, llvmPackages -, symlinkJoin, makeWrapper, substituteAll -, buildNpmPackage -, emscripten +{ + lib, + stdenv, + fetchFromGitHub, + python3, + nodejs, + closurecompiler, + jre, + binaryen, + llvmPackages, + symlinkJoin, + makeWrapper, + substituteAll, + buildNpmPackage, + emscripten, }: stdenv.mkDerivation rec { @@ -12,7 +21,12 @@ stdenv.mkDerivation rec { llvmEnv = symlinkJoin { name = "emscripten-llvm-${version}"; - paths = with llvmPackages; [ clang-unwrapped (lib.getLib clang-unwrapped) lld llvm ]; + paths = with llvmPackages; [ + clang-unwrapped + (lib.getLib clang-unwrapped) + lld + llvm + ]; }; nodeModules = buildNpmPackage { @@ -37,7 +51,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ nodejs python3 ]; + buildInputs = [ + nodejs + python3 + ]; patches = [ (substituteAll { @@ -138,7 +155,12 @@ stdenv.mkDerivation rec { homepage = "https://github.com/emscripten-core/emscripten"; description = "LLVM-to-JavaScript Compiler"; platforms = platforms.all; - maintainers = with maintainers; [ qknight matthewbauer raitobezarius willcohen ]; + maintainers = with maintainers; [ + qknight + matthewbauer + raitobezarius + willcohen + ]; license = licenses.ncsa; }; } diff --git a/pkgs/development/compilers/fasm/bin.nix b/pkgs/development/compilers/fasm/bin.nix index 71e2146a700470..d7d83405a5fe05 100644 --- a/pkgs/development/compilers/fasm/bin.nix +++ b/pkgs/development/compilers/fasm/bin.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, fetchurl }: +{ + stdenvNoCC, + lib, + fetchurl, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "fasm-bin"; @@ -23,6 +27,9 @@ stdenvNoCC.mkDerivation (finalAttrs: { license = lib.licenses.bsd2; mainProgram = "fasm"; maintainers = with lib.maintainers; [ orivej ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; }) diff --git a/pkgs/development/compilers/fasm/default.nix b/pkgs/development/compilers/fasm/default.nix index f17d18bf92a623..13dde145965755 100644 --- a/pkgs/development/compilers/fasm/default.nix +++ b/pkgs/development/compilers/fasm/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fasm-bin, isx86_64 }: +{ + stdenv, + lib, + fasm-bin, + isx86_64, +}: stdenv.mkDerivation { inherit (fasm-bin) version src meta; @@ -15,7 +20,10 @@ stdenv.mkDerivation { done ''; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; installPhase = '' install -Dt $out/bin fasm tools/libc/fasm-* diff --git a/pkgs/development/compilers/fbc/default.nix b/pkgs/development/compilers/fbc/default.nix index 7f9c519703923e..0b8677854a50e8 100644 --- a/pkgs/development/compilers/fbc/default.nix +++ b/pkgs/development/compilers/fbc/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, buildPackages -, lib -, fetchzip -, gpm -, libffi -, libGL -, libX11 -, libXext -, libXpm -, libXrandr -, ncurses +{ + stdenv, + buildPackages, + lib, + fetchzip, + gpm, + libffi, + libGL, + libX11, + libXext, + libXpm, + libXrandr, + ncurses, }: stdenv.mkDerivation rec { @@ -34,17 +35,19 @@ stdenv.mkDerivation rec { buildPackages.libffi ]; - buildInputs = [ - ncurses - libffi - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - gpm - libGL - libX11 - libXext - libXpm - libXrandr - ]; + buildInputs = + [ + ncurses + libffi + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + gpm + libGL + libX11 + libXext + libXpm + libXrandr + ]; enableParallelBuilding = true; @@ -72,15 +75,20 @@ stdenv.mkDerivation rec { BUILD_PREFIX=${buildPackages.stdenv.cc.targetPrefix} LD=${buildPackages.stdenv.cc.targetPrefix}ld make rtlib -j$buildJobs \ "FBC=$PWD/bin/fbc${stdenv.buildPlatform.extensions.executable} -i $PWD/inc" \ - ${if (stdenv.buildPlatform == stdenv.hostPlatform) then - "BUILD_PREFIX=${buildPackages.stdenv.cc.targetPrefix} LD=${buildPackages.stdenv.cc.targetPrefix}ld" - else - "TARGET=${stdenv.hostPlatform.config}" + ${ + if (stdenv.buildPlatform == stdenv.hostPlatform) then + "BUILD_PREFIX=${buildPackages.stdenv.cc.targetPrefix} LD=${buildPackages.stdenv.cc.targetPrefix}ld" + else + "TARGET=${stdenv.hostPlatform.config}" } echo Install patched build compiler and host rtlib to local directory make install-compiler prefix=$PWD/patched-fbc - make install-rtlib prefix=$PWD/patched-fbc ${lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) "TARGET=${stdenv.hostPlatform.config}"} + make install-rtlib prefix=$PWD/patched-fbc ${ + lib.optionalString ( + stdenv.buildPlatform != stdenv.hostPlatform + ) "TARGET=${stdenv.hostPlatform.config}" + } make clean echo Compile patched host everything with previous patched stage diff --git a/pkgs/development/compilers/fbc/mac-bin.nix b/pkgs/development/compilers/fbc/mac-bin.nix index 937283721817ef..66f53c7bac1398 100644 --- a/pkgs/development/compilers/fbc/mac-bin.nix +++ b/pkgs/development/compilers/fbc/mac-bin.nix @@ -1,6 +1,7 @@ -{ stdenvNoCC -, lib -, fetchzip +{ + stdenvNoCC, + lib, + fetchzip, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/development/compilers/flutter/artifacts/fetch-artifacts.nix b/pkgs/development/compilers/flutter/artifacts/fetch-artifacts.nix index e42654c36c5174..37d6f9509b49b1 100644 --- a/pkgs/development/compilers/flutter/artifacts/fetch-artifacts.nix +++ b/pkgs/development/compilers/flutter/artifacts/fetch-artifacts.nix @@ -3,16 +3,17 @@ # # aarch64-darwin as a host is not yet supported. # https://github.com/flutter/flutter/issues/60118 -{ lib -, runCommand -, xorg -, cacert -, unzip +{ + lib, + runCommand, + xorg, + cacert, + unzip, -, flutterPlatform -, systemPlatform -, flutter -, hash + flutterPlatform, + systemPlatform, + flutter, + hash, }: let @@ -41,42 +42,61 @@ let }; in runCommand "flutter-artifacts-${flutterPlatform}-${systemPlatform}" -{ - nativeBuildInputs = [ xorg.lndir flutter' unzip ]; + { + nativeBuildInputs = [ + xorg.lndir + flutter' + unzip + ]; - NIX_FLUTTER_TOOLS_VM_OPTIONS = "--root-certs-file=${cacert}/etc/ssl/certs/ca-bundle.crt"; - NIX_FLUTTER_OPERATING_SYSTEM = { - "x86_64-linux" = "linux"; - "aarch64-linux" = "linux"; - "x86_64-darwin" = "macos"; - "aarch64-darwin" = "macos"; - }.${systemPlatform}; + NIX_FLUTTER_TOOLS_VM_OPTIONS = "--root-certs-file=${cacert}/etc/ssl/certs/ca-bundle.crt"; + NIX_FLUTTER_OPERATING_SYSTEM = + { + "x86_64-linux" = "linux"; + "aarch64-linux" = "linux"; + "x86_64-darwin" = "macos"; + "aarch64-darwin" = "macos"; + } + .${systemPlatform}; - outputHash = hash; - outputHashMode = "recursive"; - outputHashAlgo = "sha256"; + outputHash = hash; + outputHashMode = "recursive"; + outputHashAlgo = "sha256"; - passthru = { - inherit flutterPlatform; - }; -} ('' - export FLUTTER_ROOT="$NIX_BUILD_TOP" - lndir -silent '${flutter'}' "$FLUTTER_ROOT" - rm -rf "$FLUTTER_ROOT/bin/cache" - mkdir "$FLUTTER_ROOT/bin/cache" -'' + lib.optionalString (lib.versionAtLeast flutter'.version "3.26") '' - mkdir "$FLUTTER_ROOT/bin/cache/dart-sdk" - lndir -silent '${flutter'}/bin/cache/dart-sdk' "$FLUTTER_ROOT/bin/cache/dart-sdk" -'' + '' + passthru = { + inherit flutterPlatform; + }; + } + ( + '' + export FLUTTER_ROOT="$NIX_BUILD_TOP" + lndir -silent '${flutter'}' "$FLUTTER_ROOT" + rm -rf "$FLUTTER_ROOT/bin/cache" + mkdir "$FLUTTER_ROOT/bin/cache" + '' + + lib.optionalString (lib.versionAtLeast flutter'.version "3.26") '' + mkdir "$FLUTTER_ROOT/bin/cache/dart-sdk" + lndir -silent '${flutter'}/bin/cache/dart-sdk' "$FLUTTER_ROOT/bin/cache/dart-sdk" + '' + + '' - HOME="$(mktemp -d)" flutter precache ${lib.optionalString (flutter ? engine && flutter.engine.meta.available) "--local-engine ${flutter.engine.outName}"} \ - -v '--${flutterPlatform}' ${builtins.concatStringsSep " " (map (p: "'--no-${p}'") (lib.remove flutterPlatform flutterPlatforms))} + HOME="$(mktemp -d)" flutter precache ${ + lib.optionalString ( + flutter ? engine && flutter.engine.meta.available + ) "--local-engine ${flutter.engine.outName}" + } \ + -v '--${flutterPlatform}' ${ + builtins.concatStringsSep " " (map (p: "'--no-${p}'") (lib.remove flutterPlatform flutterPlatforms)) + } - rm -rf "$FLUTTER_ROOT/bin/cache/lockfile" -'' + lib.optionalString (lib.versionAtLeast flutter'.version "3.26") '' - rm -rf "$FLUTTER_ROOT/bin/cache/dart-sdk" -'' + '' - find "$FLUTTER_ROOT" -type l -lname '${flutter'}/*' -delete + rm -rf "$FLUTTER_ROOT/bin/cache/lockfile" + '' + + lib.optionalString (lib.versionAtLeast flutter'.version "3.26") '' + rm -rf "$FLUTTER_ROOT/bin/cache/dart-sdk" + '' + + '' + find "$FLUTTER_ROOT" -type l -lname '${flutter'}/*' -delete - cp -r bin/cache "$out" -'') + cp -r bin/cache "$out" + '' + ) diff --git a/pkgs/development/compilers/flutter/artifacts/overrides/darwin.nix b/pkgs/development/compilers/flutter/artifacts/overrides/darwin.nix index 83257d4e34d512..0a79a707bbaa32 100644 --- a/pkgs/development/compilers/flutter/artifacts/overrides/darwin.nix +++ b/pkgs/development/compilers/flutter/artifacts/overrides/darwin.nix @@ -1,6 +1,7 @@ -{}: -{ buildInputs ? [ ] -, ... +{ }: +{ + buildInputs ? [ ], + ... }: { postPatch = '' diff --git a/pkgs/development/compilers/flutter/artifacts/overrides/linux.nix b/pkgs/development/compilers/flutter/artifacts/overrides/linux.nix index bc6114415b9091..a06188f98e3ae1 100644 --- a/pkgs/development/compilers/flutter/artifacts/overrides/linux.nix +++ b/pkgs/development/compilers/flutter/artifacts/overrides/linux.nix @@ -1,8 +1,10 @@ -{ gtk3 +{ + gtk3, }: -{ buildInputs ? [ ] -, ... +{ + buildInputs ? [ ], + ... }: { diff --git a/pkgs/development/compilers/flutter/artifacts/prepare-artifacts.nix b/pkgs/development/compilers/flutter/artifacts/prepare-artifacts.nix index 23bd8485ccffaa..a98fa1ff0487d5 100644 --- a/pkgs/development/compilers/flutter/artifacts/prepare-artifacts.nix +++ b/pkgs/development/compilers/flutter/artifacts/prepare-artifacts.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, callPackage -, autoPatchelfHook -, src +{ + lib, + stdenv, + callPackage, + autoPatchelfHook, + src, }: (stdenv.mkDerivation { @@ -20,8 +21,10 @@ runHook postInstall ''; -}).overrideAttrs ( - if builtins.pathExists (./overrides + "/${src.flutterPlatform}.nix") - then callPackage (./overrides + "/${src.flutterPlatform}.nix") { } - else ({ ... }: { }) -) +}).overrideAttrs + ( + if builtins.pathExists (./overrides + "/${src.flutterPlatform}.nix") then + callPackage (./overrides + "/${src.flutterPlatform}.nix") { } + else + ({ ... }: { }) + ) diff --git a/pkgs/development/compilers/flutter/build-support/build-flutter-application.nix b/pkgs/development/compilers/flutter/build-support/build-flutter-application.nix index ae89d3720b338a..e241afb2080934 100644 --- a/pkgs/development/compilers/flutter/build-support/build-flutter-application.nix +++ b/pkgs/development/compilers/flutter/build-support/build-flutter-application.nix @@ -1,209 +1,242 @@ -{ lib -, callPackage -, runCommand -, makeWrapper -, wrapGAppsHook3 -, buildDartApplication -, cacert -, glib -, flutter -, pkg-config -, jq -, yq +{ + lib, + callPackage, + runCommand, + makeWrapper, + wrapGAppsHook3, + buildDartApplication, + cacert, + glib, + flutter, + pkg-config, + jq, + yq, }: # absolutely no mac support for now -{ pubGetScript ? null -, flutterBuildFlags ? [ ] -, targetFlutterPlatform ? "linux" -, extraWrapProgramArgs ? "" -, flutterMode ? null -, ... +{ + pubGetScript ? null, + flutterBuildFlags ? [ ], + targetFlutterPlatform ? "linux", + extraWrapProgramArgs ? "", + flutterMode ? null, + ... }@args: let hasEngine = flutter ? engine && flutter.engine != null && flutter.engine.meta.available; flutterMode = args.flutterMode or (if hasEngine then flutter.engine.runtimeMode else "release"); - flutterFlags = lib.optional hasEngine "--local-engine host_${flutterMode}${lib.optionalString (!flutter.engine.isOptimized) "_unopt"}"; - - flutterBuildFlags = [ - "--${flutterMode}" - ] ++ (args.flutterBuildFlags or []) ++ flutterFlags; - - builderArgs = rec { - universal = args // { - inherit flutterMode flutterFlags flutterBuildFlags; - - sdkSetupScript = '' - # Pub needs SSL certificates. Dart normally looks in a hardcoded path. - # https://github.com/dart-lang/sdk/blob/3.1.0/runtime/bin/security_context_linux.cc#L48 - # - # Dart does not respect SSL_CERT_FILE... - # https://github.com/dart-lang/sdk/issues/48506 - # ...and Flutter does not support --root-certs-file, so the path cannot be manually set. - # https://github.com/flutter/flutter/issues/56607 - # https://github.com/flutter/flutter/issues/113594 - # - # libredirect is of no use either, as Flutter does not pass any - # environment variables (including LD_PRELOAD) to the Pub process. - # - # Instead, Flutter is patched to allow the path to the Dart binary used for - # Pub commands to be overriden. - export NIX_FLUTTER_PUB_DART="${runCommand "dart-with-certs" { nativeBuildInputs = [ makeWrapper ]; } '' - mkdir -p "$out/bin" - makeWrapper ${flutter.dart}/bin/dart "$out/bin/dart" \ - --add-flags "--root-certs-file=${cacert}/etc/ssl/certs/ca-bundle.crt" - ''}/bin/dart" - - export HOME="$NIX_BUILD_TOP" - flutter config $flutterFlags --no-analytics &>/dev/null # mute first-run - flutter config $flutterFlags --enable-linux-desktop >/dev/null - ''; - - pubGetScript = args.pubGetScript or "flutter${lib.optionalString hasEngine " --local-engine $flutterMode"} pub get"; - - sdkSourceBuilders = { - # https://github.com/dart-lang/pub/blob/68dc2f547d0a264955c1fa551fa0a0e158046494/lib/src/sdk/flutter.dart#L81 - "flutter" = name: runCommand "flutter-sdk-${name}" { passthru.packageRoot = "."; } '' - for path in '${flutter}/packages/${name}' '${flutter}/bin/cache/pkg/${name}'; do - if [ -d "$path" ]; then - ln -s "$path" "$out" - break - fi - done - - if [ ! -e "$out" ]; then - echo 1>&2 'The Flutter SDK does not contain the requested package: ${name}!' - exit 1 - fi + flutterFlags = lib.optional hasEngine "--local-engine host_${flutterMode}${ + lib.optionalString (!flutter.engine.isOptimized) "_unopt" + }"; + + flutterBuildFlags = + [ + "--${flutterMode}" + ] + ++ (args.flutterBuildFlags or [ ]) + ++ flutterFlags; + + builderArgs = + rec { + universal = args // { + inherit flutterMode flutterFlags flutterBuildFlags; + + sdkSetupScript = '' + # Pub needs SSL certificates. Dart normally looks in a hardcoded path. + # https://github.com/dart-lang/sdk/blob/3.1.0/runtime/bin/security_context_linux.cc#L48 + # + # Dart does not respect SSL_CERT_FILE... + # https://github.com/dart-lang/sdk/issues/48506 + # ...and Flutter does not support --root-certs-file, so the path cannot be manually set. + # https://github.com/flutter/flutter/issues/56607 + # https://github.com/flutter/flutter/issues/113594 + # + # libredirect is of no use either, as Flutter does not pass any + # environment variables (including LD_PRELOAD) to the Pub process. + # + # Instead, Flutter is patched to allow the path to the Dart binary used for + # Pub commands to be overriden. + export NIX_FLUTTER_PUB_DART="${ + runCommand "dart-with-certs" { nativeBuildInputs = [ makeWrapper ]; } '' + mkdir -p "$out/bin" + makeWrapper ${flutter.dart}/bin/dart "$out/bin/dart" \ + --add-flags "--root-certs-file=${cacert}/etc/ssl/certs/ca-bundle.crt" + '' + }/bin/dart" + + export HOME="$NIX_BUILD_TOP" + flutter config $flutterFlags --no-analytics &>/dev/null # mute first-run + flutter config $flutterFlags --enable-linux-desktop >/dev/null ''; - # https://github.com/dart-lang/pub/blob/e1fbda73d1ac597474b82882ee0bf6ecea5df108/lib/src/sdk/dart.dart#L80 - "dart" = name: runCommand "dart-sdk-${name}" { passthru.packageRoot = "."; } '' - for path in '${flutter.dart}/pkg/${name}'; do - if [ -d "$path" ]; then - ln -s "$path" "$out" - break - fi - done - - if [ ! -e "$out" ]; then - echo 1>&2 'The Dart SDK does not contain the requested package: ${name}!' - exit 1 + + pubGetScript = + args.pubGetScript + or "flutter${lib.optionalString hasEngine " --local-engine $flutterMode"} pub get"; + + sdkSourceBuilders = { + # https://github.com/dart-lang/pub/blob/68dc2f547d0a264955c1fa551fa0a0e158046494/lib/src/sdk/flutter.dart#L81 + "flutter" = + name: + runCommand "flutter-sdk-${name}" { passthru.packageRoot = "."; } '' + for path in '${flutter}/packages/${name}' '${flutter}/bin/cache/pkg/${name}'; do + if [ -d "$path" ]; then + ln -s "$path" "$out" + break + fi + done + + if [ ! -e "$out" ]; then + echo 1>&2 'The Flutter SDK does not contain the requested package: ${name}!' + exit 1 + fi + ''; + # https://github.com/dart-lang/pub/blob/e1fbda73d1ac597474b82882ee0bf6ecea5df108/lib/src/sdk/dart.dart#L80 + "dart" = + name: + runCommand "dart-sdk-${name}" { passthru.packageRoot = "."; } '' + for path in '${flutter.dart}/pkg/${name}'; do + if [ -d "$path" ]; then + ln -s "$path" "$out" + break + fi + done + + if [ ! -e "$out" ]; then + echo 1>&2 'The Dart SDK does not contain the requested package: ${name}!' + exit 1 + fi + ''; + }; + + extraPackageConfigSetup = '' + # https://github.com/flutter/flutter/blob/3.13.8/packages/flutter_tools/lib/src/dart/pub.dart#L755 + if [ "$('${yq}/bin/yq' '.flutter.generate // false' pubspec.yaml)" = "true" ]; then + export TEMP_PACKAGES=$(mktemp) + '${jq}/bin/jq' '.packages |= . + [{ + name: "flutter_gen", + rootUri: "flutter_gen", + languageVersion: "2.12", + }]' "$out" > "$TEMP_PACKAGES" + cp "$TEMP_PACKAGES" "$out" + rm "$TEMP_PACKAGES" + unset TEMP_PACKAGES fi ''; }; - extraPackageConfigSetup = '' - # https://github.com/flutter/flutter/blob/3.13.8/packages/flutter_tools/lib/src/dart/pub.dart#L755 - if [ "$('${yq}/bin/yq' '.flutter.generate // false' pubspec.yaml)" = "true" ]; then - export TEMP_PACKAGES=$(mktemp) - '${jq}/bin/jq' '.packages |= . + [{ - name: "flutter_gen", - rootUri: "flutter_gen", - languageVersion: "2.12", - }]' "$out" > "$TEMP_PACKAGES" - cp "$TEMP_PACKAGES" "$out" - rm "$TEMP_PACKAGES" - unset TEMP_PACKAGES - fi - ''; - }; - - linux = universal // { - outputs = universal.outputs or [ ] ++ [ "debug" ]; + linux = universal // { + outputs = universal.outputs or [ ] ++ [ "debug" ]; - nativeBuildInputs = (universal.nativeBuildInputs or [ ]) ++ [ - wrapGAppsHook3 + nativeBuildInputs = (universal.nativeBuildInputs or [ ]) ++ [ + wrapGAppsHook3 - # Flutter requires pkg-config for Linux desktop support, and many plugins - # attempt to use it. - # - # It is available to the `flutter` tool through its wrapper, but it must be - # added here as well so the setup hook adds plugin dependencies to the - # pkg-config search paths. - pkg-config - ]; + # Flutter requires pkg-config for Linux desktop support, and many plugins + # attempt to use it. + # + # It is available to the `flutter` tool through its wrapper, but it must be + # added here as well so the setup hook adds plugin dependencies to the + # pkg-config search paths. + pkg-config + ]; - buildInputs = (universal.buildInputs or [ ]) ++ [ glib ]; + buildInputs = (universal.buildInputs or [ ]) ++ [ glib ]; - dontDartBuild = true; - buildPhase = universal.buildPhase or '' - runHook preBuild + dontDartBuild = true; + buildPhase = + universal.buildPhase or '' + runHook preBuild - mkdir -p build/flutter_assets/fonts + mkdir -p build/flutter_assets/fonts - flutter build linux -v --split-debug-info="$debug" $flutterBuildFlags + flutter build linux -v --split-debug-info="$debug" $flutterBuildFlags - runHook postBuild - ''; + runHook postBuild + ''; - dontDartInstall = true; - installPhase = universal.installPhase or '' - runHook preInstall + dontDartInstall = true; + installPhase = + universal.installPhase or '' + runHook preInstall - built=build/linux/*/$flutterMode/bundle + built=build/linux/*/$flutterMode/bundle - mkdir -p $out/bin - mkdir -p $out/app - mv $built $out/app/$pname + mkdir -p $out/bin + mkdir -p $out/app + mv $built $out/app/$pname - for f in $(find $out/app/$pname -iname "*.desktop" -type f); do - install -D $f $out/share/applications/$(basename $f) - done + for f in $(find $out/app/$pname -iname "*.desktop" -type f); do + install -D $f $out/share/applications/$(basename $f) + done - for f in $(find $out/app/$pname -maxdepth 1 -type f); do - ln -s $f $out/bin/$(basename $f) - done + for f in $(find $out/app/$pname -maxdepth 1 -type f); do + ln -s $f $out/bin/$(basename $f) + done - # make *.so executable - find $out/app/$pname -iname "*.so" -type f -exec chmod +x {} + + # make *.so executable + find $out/app/$pname -iname "*.so" -type f -exec chmod +x {} + - # remove stuff like /build/source/packages/ubuntu_desktop_installer/linux/flutter/ephemeral - for f in $(find $out/app/$pname -executable -type f); do - if patchelf --print-rpath "$f" | grep /build; then # this ignores static libs (e,g. libapp.so) also - echo "strip RPath of $f" - newrp=$(patchelf --print-rpath $f | sed -r "s|/build.*ephemeral:||g" | sed -r "s|/build.*profile:||g") - patchelf --set-rpath "$newrp" "$f" - fi - done + # remove stuff like /build/source/packages/ubuntu_desktop_installer/linux/flutter/ephemeral + for f in $(find $out/app/$pname -executable -type f); do + if patchelf --print-rpath "$f" | grep /build; then # this ignores static libs (e,g. libapp.so) also + echo "strip RPath of $f" + newrp=$(patchelf --print-rpath $f | sed -r "s|/build.*ephemeral:||g" | sed -r "s|/build.*profile:||g") + patchelf --set-rpath "$newrp" "$f" + fi + done - runHook postInstall - ''; + runHook postInstall + ''; - dontWrapGApps = true; - extraWrapProgramArgs = '' - ''${gappsWrapperArgs[@]} \ - ${extraWrapProgramArgs} - ''; - }; + dontWrapGApps = true; + extraWrapProgramArgs = '' + ''${gappsWrapperArgs[@]} \ + ${extraWrapProgramArgs} + ''; + }; - web = universal // { - dontDartBuild = true; - buildPhase = universal.buildPhase or '' - runHook preBuild + web = universal // { + dontDartBuild = true; + buildPhase = + universal.buildPhase or '' + runHook preBuild - mkdir -p build/flutter_assets/fonts + mkdir -p build/flutter_assets/fonts - flutter build web -v $flutterBuildFlags + flutter build web -v $flutterBuildFlags - runHook postBuild - ''; + runHook postBuild + ''; - dontDartInstall = true; - installPhase = universal.installPhase or '' - runHook preInstall + dontDartInstall = true; + installPhase = + universal.installPhase or '' + runHook preInstall - cp -r build/web "$out" + cp -r build/web "$out" - runHook postInstall - ''; - }; - }.${targetFlutterPlatform} or (throw "Unsupported Flutter host platform: ${targetFlutterPlatform}"); + runHook postInstall + ''; + }; + } + .${targetFlutterPlatform} or (throw "Unsupported Flutter host platform: ${targetFlutterPlatform}"); - minimalFlutter = flutter.override { supportedTargetFlutterPlatforms = [ "universal" targetFlutterPlatform ]; }; + minimalFlutter = flutter.override { + supportedTargetFlutterPlatforms = [ + "universal" + targetFlutterPlatform + ]; + }; buildAppWith = flutter: buildDartApplication.override { dart = flutter; }; in -buildAppWith minimalFlutter (builderArgs // { passthru = builderArgs.passthru or { } // { multiShell = buildAppWith flutter builderArgs; }; }) +buildAppWith minimalFlutter ( + builderArgs + // { + passthru = builderArgs.passthru or { } // { + multiShell = buildAppWith flutter builderArgs; + }; + } +) diff --git a/pkgs/development/compilers/flutter/default.nix b/pkgs/development/compilers/flutter/default.nix index 0a9d0feccd8189..dd055799863f30 100644 --- a/pkgs/development/compilers/flutter/default.nix +++ b/pkgs/development/compilers/flutter/default.nix @@ -1,28 +1,52 @@ -{ useNixpkgsEngine ? false, callPackage, fetchzip, fetchFromGitHub, dart, lib, stdenv }: +{ + useNixpkgsEngine ? false, + callPackage, + fetchzip, + fetchFromGitHub, + dart, + lib, + stdenv, +}: let mkCustomFlutter = args: callPackage ./flutter.nix args; wrapFlutter = flutter: callPackage ./wrapper.nix { inherit flutter; }; - getPatches = dir: - let files = builtins.attrNames (builtins.readDir dir); - in if (builtins.pathExists dir) then map (f: dir + ("/" + f)) files else [ ]; + getPatches = + dir: + let + files = builtins.attrNames (builtins.readDir dir); + in + if (builtins.pathExists dir) then map (f: dir + ("/" + f)) files else [ ]; mkFlutter = - { version - , engineVersion - , engineSwiftShaderHash - , engineSwiftShaderRev - , engineHashes - , enginePatches - , dartVersion - , flutterHash - , dartHash - , patches - , pubspecLock - , artifactHashes - , channel + { + version, + engineVersion, + engineSwiftShaderHash, + engineSwiftShaderRev, + engineHashes, + enginePatches, + dartVersion, + flutterHash, + dartHash, + patches, + pubspecLock, + artifactHashes, + channel, }: let args = { - inherit version engineVersion engineSwiftShaderRev engineSwiftShaderHash engineHashes enginePatches patches pubspecLock artifactHashes useNixpkgsEngine channel; + inherit + version + engineVersion + engineSwiftShaderRev + engineSwiftShaderHash + engineHashes + enginePatches + patches + pubspecLock + artifactHashes + useNixpkgsEngine + channel + ; dart = dart.override { version = dartVersion; @@ -53,29 +77,41 @@ let }; }; in - (mkCustomFlutter args).overrideAttrs (prev: next: { - passthru = next.passthru // rec { - inherit wrapFlutter mkCustomFlutter mkFlutter; - buildFlutterApplication = callPackage ./build-support/build-flutter-application.nix { flutter = wrapFlutter (mkCustomFlutter args); }; - }; - }); + (mkCustomFlutter args).overrideAttrs ( + prev: next: { + passthru = next.passthru // rec { + inherit wrapFlutter mkCustomFlutter mkFlutter; + buildFlutterApplication = callPackage ./build-support/build-flutter-application.nix { + flutter = wrapFlutter (mkCustomFlutter args); + }; + }; + } + ); - flutterVersions = lib.mapAttrs' - (version: _: - let - versionDir = ./versions + "/${version}"; - data = lib.importJSON (versionDir + "/data.json"); - in - lib.nameValuePair "v${version}" (wrapFlutter (mkFlutter ({ - patches = (getPatches ./patches) ++ (getPatches (versionDir + "/patches")); - enginePatches = (getPatches ./engine/patches) ++ (getPatches (versionDir + "/engine/patches")); - } // data)))) - (builtins.readDir ./versions); + flutterVersions = lib.mapAttrs' ( + version: _: + let + versionDir = ./versions + "/${version}"; + data = lib.importJSON (versionDir + "/data.json"); + in + lib.nameValuePair "v${version}" ( + wrapFlutter ( + mkFlutter ( + { + patches = (getPatches ./patches) ++ (getPatches (versionDir + "/patches")); + enginePatches = (getPatches ./engine/patches) ++ (getPatches (versionDir + "/engine/patches")); + } + // data + ) + ) + ) + ) (builtins.readDir ./versions); stableFlutterVersions = lib.attrsets.filterAttrs (_: v: v.channel == "stable") flutterVersions; betaFlutterVersions = lib.attrsets.filterAttrs (_: v: v.channel == "beta") flutterVersions; in -flutterVersions // { +flutterVersions +// { beta = flutterVersions.${lib.last (lib.naturalSort (builtins.attrNames betaFlutterVersions))}; stable = flutterVersions.${lib.last (lib.naturalSort (builtins.attrNames stableFlutterVersions))}; inherit wrapFlutter mkFlutter; diff --git a/pkgs/development/compilers/flutter/engine/dart.nix b/pkgs/development/compilers/flutter/engine/dart.nix index c872113f4a90e9..5d7d126cae022c 100644 --- a/pkgs/development/compilers/flutter/engine/dart.nix +++ b/pkgs/development/compilers/flutter/engine/dart.nix @@ -1,13 +1,15 @@ { engine, runCommand }: -runCommand "flutter-engine-${engine.version}-dart" { - version = engine.dartSdkVersion; +runCommand "flutter-engine-${engine.version}-dart" + { + version = engine.dartSdkVersion; - inherit engine; - inherit (engine) outName; + inherit engine; + inherit (engine) outName; - meta = engine.meta // { - description = "Dart SDK compiled from the Flutter Engine"; - }; -} '' - ln -s ${engine}/out/$outName/dart-sdk $out -'' + meta = engine.meta // { + description = "Dart SDK compiled from the Flutter Engine"; + }; + } + '' + ln -s ${engine}/out/$outName/dart-sdk $out + '' diff --git a/pkgs/development/compilers/flutter/engine/package.nix b/pkgs/development/compilers/flutter/engine/package.nix index fa11bfe01341a0..4693062cacb847 100644 --- a/pkgs/development/compilers/flutter/engine/package.nix +++ b/pkgs/development/compilers/flutter/engine/package.nix @@ -309,35 +309,41 @@ stdenv.mkDerivation (finalAttrs: { rm src/out/run_tests.log ''; - installPhase = '' - runHook preInstall - - rm -rf $out/out/$outName/{obj,exe.unstripped,lib.unstripped,zip_archives} - rm $out/out/$outName/{args.gn,build.ninja,build.ninja.d,compile_commands.json,toolchain.ninja} - find $out/out/$outName -name '*_unittests' -delete - find $out/out/$outName -name '*_benchmarks' -delete - '' + lib.optionalString (finalAttrs.doCheck) '' - rm $out/out/$outName/{display_list_rendertests,flutter_tester} - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + + rm -rf $out/out/$outName/{obj,exe.unstripped,lib.unstripped,zip_archives} + rm $out/out/$outName/{args.gn,build.ninja,build.ninja.d,compile_commands.json,toolchain.ninja} + find $out/out/$outName -name '*_unittests' -delete + find $out/out/$outName -name '*_benchmarks' -delete + '' + + lib.optionalString (finalAttrs.doCheck) '' + rm $out/out/$outName/{display_list_rendertests,flutter_tester} + '' + + '' + runHook postInstall + ''; passthru = { dart = callPackage ./dart.nix { engine = finalAttrs.finalPackage; }; }; - meta = with lib; { - # Very broken on Darwin - broken = stdenv.hostPlatform.isDarwin; - description = "The Flutter engine"; - homepage = "https://flutter.dev"; - maintainers = with maintainers; [ RossComputerGuy ]; - license = licenses.bsd3; - platforms = [ - "x86_64-linux" - "aarch64-linux" - "x86_64-darwin" - "aarch64-darwin" - ]; - } // lib.optionalAttrs (lib.versionOlder flutterVersion "3.22") { hydraPlatforms = [ ]; }; + meta = + with lib; + { + # Very broken on Darwin + broken = stdenv.hostPlatform.isDarwin; + description = "The Flutter engine"; + homepage = "https://flutter.dev"; + maintainers = with maintainers; [ RossComputerGuy ]; + license = licenses.bsd3; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; + } + // lib.optionalAttrs (lib.versionOlder flutterVersion "3.22") { hydraPlatforms = [ ]; }; }) diff --git a/pkgs/development/compilers/flutter/flutter-tools.nix b/pkgs/development/compilers/flutter/flutter-tools.nix index 1639d54a869e74..be00380ad91b41 100644 --- a/pkgs/development/compilers/flutter/flutter-tools.nix +++ b/pkgs/development/compilers/flutter/flutter-tools.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, systemPlatform -, buildDartApplication -, runCommand -, git -, which -, dart -, version -, flutterSrc -, patches ? [ ] -, pubspecLock +{ + lib, + stdenv, + systemPlatform, + buildDartApplication, + runCommand, + git, + which, + dart, + version, + flutterSrc, + patches ? [ ], + pubspecLock, }: buildDartApplication.override { inherit dart; } rec { @@ -24,19 +25,23 @@ buildDartApplication.override { inherit dart; } rec { inherit patches; # The given patches are made for the entire SDK source tree. prePatch = ''pushd "$NIX_BUILD_TOP/source"''; - postPatch = '' - popd - '' - # Use arm64 instead of arm64e. - + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace lib/src/ios/xcodeproj.dart \ - --replace-fail arm64e arm64 - ''; + postPatch = + '' + popd + '' + # Use arm64 instead of arm64e. + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace lib/src/ios/xcodeproj.dart \ + --replace-fail arm64e arm64 + ''; # When the JIT snapshot is being built, the application needs to run. # It attempts to generate configuration files, and relies on a few external # tools. - nativeBuildInputs = [ git which ]; + nativeBuildInputs = [ + git + which + ]; preConfigure = '' export HOME=. export FLUTTER_ROOT="$NIX_BUILD_TOP/source" @@ -57,19 +62,21 @@ buildDartApplication.override { inherit dart; } rec { sdkSourceBuilders = { # https://github.com/dart-lang/pub/blob/e1fbda73d1ac597474b82882ee0bf6ecea5df108/lib/src/sdk/dart.dart#L80 - "dart" = name: runCommand "dart-sdk-${name}" { passthru.packageRoot = "."; } '' - for path in '${dart}/pkg/${name}'; do - if [ -d "$path" ]; then - ln -s "$path" "$out" - break - fi - done + "dart" = + name: + runCommand "dart-sdk-${name}" { passthru.packageRoot = "."; } '' + for path in '${dart}/pkg/${name}'; do + if [ -d "$path" ]; then + ln -s "$path" "$out" + break + fi + done - if [ ! -e "$out" ]; then - echo 1>&2 'The Dart SDK does not contain the requested package: ${name}!' - exit 1 - fi - ''; + if [ ! -e "$out" ]; then + echo 1>&2 'The Dart SDK does not contain the requested package: ${name}!' + exit 1 + fi + ''; }; inherit pubspecLock; diff --git a/pkgs/development/compilers/flutter/flutter.nix b/pkgs/development/compilers/flutter/flutter.nix index 69872053952d38..89151d0e19c496 100644 --- a/pkgs/development/compilers/flutter/flutter.nix +++ b/pkgs/development/compilers/flutter/flutter.nix @@ -1,182 +1,205 @@ -{ useNixpkgsEngine ? false -, version -, engineVersion -, engineHashes ? {} -, engineUrl ? "https://github.com/flutter/engine.git@${engineVersion}" -, enginePatches ? [] -, engineRuntimeModes ? [ "release" "debug" ] -, engineSwiftShaderHash -, engineSwiftShaderRev -, patches -, channel -, dart -, src -, pubspecLock -, artifactHashes ? null -, lib -, stdenv -, callPackage -, makeWrapper -, darwin -, git -, which -, jq -, flutterTools ? null +{ + useNixpkgsEngine ? false, + version, + engineVersion, + engineHashes ? { }, + engineUrl ? "https://github.com/flutter/engine.git@${engineVersion}", + enginePatches ? [ ], + engineRuntimeModes ? [ + "release" + "debug" + ], + engineSwiftShaderHash, + engineSwiftShaderRev, + patches, + channel, + dart, + src, + pubspecLock, + artifactHashes ? null, + lib, + stdenv, + callPackage, + makeWrapper, + darwin, + git, + which, + jq, + flutterTools ? null, }@args: let - engine = if args.useNixpkgsEngine or false then - callPackage ./engine/default.nix { - inherit (args) dart; - dartSdkVersion = args.dart.version; - flutterVersion = version; - swiftshaderRev = engineSwiftShaderRev; - swiftshaderHash = engineSwiftShaderHash; - version = engineVersion; - hashes = engineHashes; - url = engineUrl; - patches = enginePatches; - runtimeModes = engineRuntimeModes; - } else null; - - dart = if args.useNixpkgsEngine or false then - engine.dart else args.dart; - - flutterTools = args.flutterTools or (callPackage ./flutter-tools.nix { - inherit dart version; - flutterSrc = src; - inherit patches; - inherit pubspecLock; - systemPlatform = stdenv.hostPlatform.system; - }); - - unwrapped = - stdenv.mkDerivation { - name = "flutter-${version}-unwrapped"; - inherit src patches version; - - buildInputs = [ git ]; - nativeBuildInputs = [ makeWrapper jq ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.DarwinTools ]; - - preConfigure = '' - if [ "$(< bin/internal/engine.version)" != '${engineVersion}' ]; then - echo 1>&2 "The given engine version (${engineVersion}) does not match the version required by the Flutter SDK ($(< bin/internal/engine.version))." - exit 1 - fi - ''; - - postPatch = '' - patchShebangs --build ./bin/ - ''; - - buildPhase = '' - # The flutter_tools package tries to run many Git commands. In most - # cases, unexpected output is handled gracefully, but commands are never - # expected to fail completely. A blank repository needs to be created. - rm -rf .git # Remove any existing Git directory - git init -b nixpkgs - GIT_AUTHOR_NAME=Nixpkgs GIT_COMMITTER_NAME=Nixpkgs \ - GIT_AUTHOR_EMAIL= GIT_COMMITTER_EMAIL= \ - GIT_AUTHOR_DATE='1/1/1970 00:00:00 +0000' GIT_COMMITTER_DATE='1/1/1970 00:00:00 +0000' \ - git commit --allow-empty -m "Initial commit" - (. '${../../../build-support/fetchgit/deterministic-git}'; make_deterministic_repo .) - - mkdir -p bin/cache - - # Add a flutter_tools artifact stamp, and build a snapshot. - # This is the Flutter CLI application. - echo "$(git rev-parse HEAD)" > bin/cache/flutter_tools.stamp - ln -s '${flutterTools}/share/flutter_tools.snapshot' bin/cache/flutter_tools.snapshot - - # Some of flutter_tools's dependencies contain static assets. The - # application attempts to read its own package_config.json to find these - # assets at runtime. - # TODO: Remove this once Flutter 3.24 is the lowest version in Nixpkgs. - # https://github.com/flutter/flutter/pull/150340 makes it redundant. - mkdir -p packages/flutter_tools/.dart_tool - ln -s '${flutterTools.pubcache}/package_config.json' packages/flutter_tools/.dart_tool/package_config.json - - echo -n "${version}" > version - cat < bin/cache/flutter.version.json - { - "devToolsVersion": "$(cat "${dart}/bin/resources/devtools/version.json" | jq -r .version)", - "flutterVersion": "${version}", - "frameworkVersion": "${version}", - "channel": "${channel}", - "repositoryUrl": "https://github.com/flutter/flutter.git", - "frameworkRevision": "nixpkgs000000000000000000000000000000000", - "frameworkCommitDate": "1970-01-01 00:00:00", - "engineRevision": "${engineVersion}", - "dartSdkVersion": "${dart.version}" - } - EOF - - # Suppress a small error now that `.gradle`'s location changed. - # Location changed because of the patch "gradle-flutter-tools-wrapper.patch". - mkdir -p "$out/packages/flutter_tools/gradle/.gradle" - ''; - - installPhase = '' - runHook preInstall - - mkdir -p $out - cp -r . $out - rm -rf $out/bin/cache/dart-sdk - ln -sf ${dart} $out/bin/cache/dart-sdk - - # The regular launchers are designed to download/build/update SDK - # components, and are not very useful in Nix. - # Replace them with simple links and wrappers. - rm "$out/bin"/{dart,flutter} - ln -s "$out/bin/cache/dart-sdk/bin/dart" "$out/bin/dart" - makeShellWrapper "$out/bin/dart" "$out/bin/flutter" \ - --set-default FLUTTER_ROOT "$out" \ - --set FLUTTER_ALREADY_LOCKED true \ - --add-flags "--disable-dart-dev --packages='${flutterTools.pubcache}/package_config.json' \$NIX_FLUTTER_TOOLS_VM_OPTIONS $out/bin/cache/flutter_tools.snapshot" - - runHook postInstall - ''; - - doInstallCheck = true; - nativeInstallCheckInputs = [ which ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.DarwinTools ]; - installCheckPhase = '' - runHook preInstallCheck - - export HOME="$(mktemp -d)" - $out/bin/flutter config --android-studio-dir $HOME - $out/bin/flutter config --android-sdk $HOME - $out/bin/flutter --version | fgrep -q '${builtins.substring 0 10 engineVersion}' - - runHook postInstallCheck - ''; - - passthru = { + engine = + if args.useNixpkgsEngine or false then + callPackage ./engine/default.nix { + inherit (args) dart; + dartSdkVersion = args.dart.version; + flutterVersion = version; + swiftshaderRev = engineSwiftShaderRev; + swiftshaderHash = engineSwiftShaderHash; + version = engineVersion; + hashes = engineHashes; + url = engineUrl; + patches = enginePatches; + runtimeModes = engineRuntimeModes; + } + else + null; + + dart = if args.useNixpkgsEngine or false then engine.dart else args.dart; + + flutterTools = + args.flutterTools or (callPackage ./flutter-tools.nix { + inherit dart version; + flutterSrc = src; + inherit patches; + inherit pubspecLock; + systemPlatform = stdenv.hostPlatform.system; + }); + + unwrapped = stdenv.mkDerivation { + name = "flutter-${version}-unwrapped"; + inherit src patches version; + + buildInputs = [ git ]; + nativeBuildInputs = [ + makeWrapper + jq + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.DarwinTools ]; + + preConfigure = '' + if [ "$(< bin/internal/engine.version)" != '${engineVersion}' ]; then + echo 1>&2 "The given engine version (${engineVersion}) does not match the version required by the Flutter SDK ($(< bin/internal/engine.version))." + exit 1 + fi + ''; + + postPatch = '' + patchShebangs --build ./bin/ + ''; + + buildPhase = '' + # The flutter_tools package tries to run many Git commands. In most + # cases, unexpected output is handled gracefully, but commands are never + # expected to fail completely. A blank repository needs to be created. + rm -rf .git # Remove any existing Git directory + git init -b nixpkgs + GIT_AUTHOR_NAME=Nixpkgs GIT_COMMITTER_NAME=Nixpkgs \ + GIT_AUTHOR_EMAIL= GIT_COMMITTER_EMAIL= \ + GIT_AUTHOR_DATE='1/1/1970 00:00:00 +0000' GIT_COMMITTER_DATE='1/1/1970 00:00:00 +0000' \ + git commit --allow-empty -m "Initial commit" + (. '${../../../build-support/fetchgit/deterministic-git}'; make_deterministic_repo .) + + mkdir -p bin/cache + + # Add a flutter_tools artifact stamp, and build a snapshot. + # This is the Flutter CLI application. + echo "$(git rev-parse HEAD)" > bin/cache/flutter_tools.stamp + ln -s '${flutterTools}/share/flutter_tools.snapshot' bin/cache/flutter_tools.snapshot + + # Some of flutter_tools's dependencies contain static assets. The + # application attempts to read its own package_config.json to find these + # assets at runtime. + # TODO: Remove this once Flutter 3.24 is the lowest version in Nixpkgs. + # https://github.com/flutter/flutter/pull/150340 makes it redundant. + mkdir -p packages/flutter_tools/.dart_tool + ln -s '${flutterTools.pubcache}/package_config.json' packages/flutter_tools/.dart_tool/package_config.json + + echo -n "${version}" > version + cat < bin/cache/flutter.version.json + { + "devToolsVersion": "$(cat "${dart}/bin/resources/devtools/version.json" | jq -r .version)", + "flutterVersion": "${version}", + "frameworkVersion": "${version}", + "channel": "${channel}", + "repositoryUrl": "https://github.com/flutter/flutter.git", + "frameworkRevision": "nixpkgs000000000000000000000000000000000", + "frameworkCommitDate": "1970-01-01 00:00:00", + "engineRevision": "${engineVersion}", + "dartSdkVersion": "${dart.version}" + } + EOF + + # Suppress a small error now that `.gradle`'s location changed. + # Location changed because of the patch "gradle-flutter-tools-wrapper.patch". + mkdir -p "$out/packages/flutter_tools/gradle/.gradle" + ''; + + installPhase = '' + runHook preInstall + + mkdir -p $out + cp -r . $out + rm -rf $out/bin/cache/dart-sdk + ln -sf ${dart} $out/bin/cache/dart-sdk + + # The regular launchers are designed to download/build/update SDK + # components, and are not very useful in Nix. + # Replace them with simple links and wrappers. + rm "$out/bin"/{dart,flutter} + ln -s "$out/bin/cache/dart-sdk/bin/dart" "$out/bin/dart" + makeShellWrapper "$out/bin/dart" "$out/bin/flutter" \ + --set-default FLUTTER_ROOT "$out" \ + --set FLUTTER_ALREADY_LOCKED true \ + --add-flags "--disable-dart-dev --packages='${flutterTools.pubcache}/package_config.json' \$NIX_FLUTTER_TOOLS_VM_OPTIONS $out/bin/cache/flutter_tools.snapshot" + + runHook postInstall + ''; + + doInstallCheck = true; + nativeInstallCheckInputs = [ + which + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.DarwinTools ]; + installCheckPhase = '' + runHook preInstallCheck + + export HOME="$(mktemp -d)" + $out/bin/flutter config --android-studio-dir $HOME + $out/bin/flutter config --android-sdk $HOME + $out/bin/flutter --version | fgrep -q '${builtins.substring 0 10 engineVersion}' + + runHook postInstallCheck + ''; + + passthru = + { # TODO: rely on engine.version instead of engineVersion - inherit dart engineVersion artifactHashes channel; + inherit + dart + engineVersion + artifactHashes + channel + ; tools = flutterTools; # The derivation containing the original Flutter SDK files. # When other derivations wrap this one, any unmodified files # found here should be included as-is, for tooling compatibility. sdk = unwrapped; - } // lib.optionalAttrs (engine != null) { + } + // lib.optionalAttrs (engine != null) { inherit engine; }; - meta = with lib; { - description = "Flutter is Google's SDK for building mobile, web and desktop with Dart"; - longDescription = '' - Flutter is Google’s UI toolkit for building beautiful, - natively compiled applications for mobile, web, and desktop from a single codebase. - ''; - homepage = "https://flutter.dev"; - license = licenses.bsd3; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; - maintainers = teams.flutter.members ++ (with maintainers; [ + meta = with lib; { + description = "Flutter is Google's SDK for building mobile, web and desktop with Dart"; + longDescription = '' + Flutter is Google’s UI toolkit for building beautiful, + natively compiled applications for mobile, web, and desktop from a single codebase. + ''; + homepage = "https://flutter.dev"; + license = licenses.bsd3; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; + maintainers = + teams.flutter.members + ++ (with maintainers; [ ericdallo ]); - }; }; + }; in unwrapped diff --git a/pkgs/development/compilers/flutter/sdk-symlink.nix b/pkgs/development/compilers/flutter/sdk-symlink.nix index 98051efa56136b..c171b7dbd1dace 100644 --- a/pkgs/development/compilers/flutter/sdk-symlink.nix +++ b/pkgs/development/compilers/flutter/sdk-symlink.nix @@ -1,59 +1,64 @@ -{ symlinkJoin -, makeWrapper -}: flutter: +{ + symlinkJoin, + makeWrapper, +}: +flutter: let - self = - symlinkJoin { - name = "${flutter.name}-sdk-links"; - paths = [ flutter flutter.cacheDir flutter.sdk ]; + self = symlinkJoin { + name = "${flutter.name}-sdk-links"; + paths = [ + flutter + flutter.cacheDir + flutter.sdk + ]; - nativeBuildInputs = [ makeWrapper ]; - postBuild = '' - wrapProgram "$out/bin/flutter" \ - --set-default FLUTTER_ROOT "$out" + nativeBuildInputs = [ makeWrapper ]; + postBuild = '' + wrapProgram "$out/bin/flutter" \ + --set-default FLUTTER_ROOT "$out" - # symlinkJoin seems to be missing the .git directory for some reason. - if [ -d '${flutter.sdk}/.git' ]; then - ln -s '${flutter.sdk}/.git' "$out" - fi + # symlinkJoin seems to be missing the .git directory for some reason. + if [ -d '${flutter.sdk}/.git' ]; then + ln -s '${flutter.sdk}/.git' "$out" + fi - # For iOS/macOS builds, *.xcframework/'s from the pre-built - # artifacts are copied into each built app. However, the symlinkJoin - # means that the *.xcframework's contain symlinks into the nix store, - # which causes issues when actually running the apps. - # - # We'll fix this by only linking to an outer *.xcframework dir instead - # of trying to symlinkJoin the files inside the *.xcframework. - artifactsDir="$out/bin/cache/artifacts/engine" - shopt -s globstar - for file in "$artifactsDir"/**/*.xcframework/Info.plist; do - # Get the unwrapped path from the Info.plist inside each .xcframework - origFile="$(readlink -f "$file")" - origFrameworkDir="$(dirname "$origFile")" + # For iOS/macOS builds, *.xcframework/'s from the pre-built + # artifacts are copied into each built app. However, the symlinkJoin + # means that the *.xcframework's contain symlinks into the nix store, + # which causes issues when actually running the apps. + # + # We'll fix this by only linking to an outer *.xcframework dir instead + # of trying to symlinkJoin the files inside the *.xcframework. + artifactsDir="$out/bin/cache/artifacts/engine" + shopt -s globstar + for file in "$artifactsDir"/**/*.xcframework/Info.plist; do + # Get the unwrapped path from the Info.plist inside each .xcframework + origFile="$(readlink -f "$file")" + origFrameworkDir="$(dirname "$origFile")" - # Remove the symlinkJoin .xcframework dir and replace it with a symlink - # to the unwrapped .xcframework dir. - frameworkDir="$(dirname "$file")" - rm -r "$frameworkDir" - ln -s "$origFrameworkDir" "$frameworkDir" - done - shopt -u globstar - ''; + # Remove the symlinkJoin .xcframework dir and replace it with a symlink + # to the unwrapped .xcframework dir. + frameworkDir="$(dirname "$file")" + rm -r "$frameworkDir" + ln -s "$origFrameworkDir" "$frameworkDir" + done + shopt -u globstar + ''; - passthru = flutter.passthru // { - # Update the SDK attribute. - # This allows any modified SDK files to be included - # in future invocations. - sdk = self; - }; + passthru = flutter.passthru // { + # Update the SDK attribute. + # This allows any modified SDK files to be included + # in future invocations. + sdk = self; + }; - meta = flutter.meta // { - longDescription = '' - ${flutter.meta.longDescription} - Modified binaries are linked into the original SDK directory for use with tools that use the whole SDK. - ''; - }; + meta = flutter.meta // { + longDescription = '' + ${flutter.meta.longDescription} + Modified binaries are linked into the original SDK directory for use with tools that use the whole SDK. + ''; }; + }; in self diff --git a/pkgs/development/compilers/flutter/wrapper.nix b/pkgs/development/compilers/flutter/wrapper.nix index 9b4123b0e7d95f..57f945477f41ad 100644 --- a/pkgs/development/compilers/flutter/wrapper.nix +++ b/pkgs/development/compilers/flutter/wrapper.nix @@ -1,50 +1,56 @@ -{ lib -, stdenv -, darwin -, callPackage -, flutter -, supportedTargetFlutterPlatforms ? [ - "universal" - "web" - ] - ++ lib.optional (stdenv.hostPlatform.isLinux && !(flutter ? engine)) "linux" - ++ lib.optional (stdenv.hostPlatform.isx86_64 || stdenv.hostPlatform.isDarwin) "android" - ++ lib.optionals stdenv.hostPlatform.isDarwin [ "macos" "ios" ] -, artifactHashes ? flutter.artifactHashes -, extraPkgConfigPackages ? [ ] -, extraLibraries ? [ ] -, extraIncludes ? [ ] -, extraCxxFlags ? [ ] -, extraCFlags ? [ ] -, extraLinkerFlags ? [ ] -, makeWrapper -, writeShellScript -, wrapGAppsHook3 -, git -, which -, pkg-config -, atk -, cairo -, gdk-pixbuf -, glib -, gtk3 -, harfbuzz -, libepoxy -, pango -, libX11 -, xorgproto -, libdeflate -, zlib -, cmake -, ninja -, clang -, symlinkJoin +{ + lib, + stdenv, + darwin, + callPackage, + flutter, + supportedTargetFlutterPlatforms ? + [ + "universal" + "web" + ] + ++ lib.optional (stdenv.hostPlatform.isLinux && !(flutter ? engine)) "linux" + ++ lib.optional (stdenv.hostPlatform.isx86_64 || stdenv.hostPlatform.isDarwin) "android" + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "macos" + "ios" + ], + artifactHashes ? flutter.artifactHashes, + extraPkgConfigPackages ? [ ], + extraLibraries ? [ ], + extraIncludes ? [ ], + extraCxxFlags ? [ ], + extraCFlags ? [ ], + extraLinkerFlags ? [ ], + makeWrapper, + writeShellScript, + wrapGAppsHook3, + git, + which, + pkg-config, + atk, + cairo, + gdk-pixbuf, + glib, + gtk3, + harfbuzz, + libepoxy, + pango, + libX11, + xorgproto, + libdeflate, + zlib, + cmake, + ninja, + clang, + symlinkJoin, }: let supportsLinuxDesktopTarget = builtins.elem "linux" supportedTargetFlutterPlatforms; - flutterPlatformArtifacts = lib.genAttrs supportedTargetFlutterPlatforms (flutterPlatform: + flutterPlatformArtifacts = lib.genAttrs supportedTargetFlutterPlatforms ( + flutterPlatform: (callPackage ./artifacts/prepare-artifacts.nix { src = callPackage ./artifacts/fetch-artifacts.nix { inherit flutterPlatform; @@ -52,7 +58,8 @@ let flutter = callPackage ./wrapper.nix { inherit flutter; }; hash = artifactHashes.${flutterPlatform}.${stdenv.hostPlatform.system} or ""; }; - })); + }) + ); cacheDir = symlinkJoin { name = "flutter-cache-dir"; @@ -72,7 +79,10 @@ let ''; # Tools that the Flutter tool depends on. - tools = [ git which ]; + tools = [ + git + which + ]; # Libraries that Flutter apps depend on at runtime. appRuntimeDeps = lib.optionals supportsLinuxDesktopTarget [ @@ -92,14 +102,22 @@ let appBuildDeps = let # https://discourse.nixos.org/t/handling-transitive-c-dependencies/5942/3 - deps = pkg: builtins.filter lib.isDerivation ((pkg.buildInputs or [ ]) ++ (pkg.propagatedBuildInputs or [ ])); + deps = + pkg: + builtins.filter lib.isDerivation ((pkg.buildInputs or [ ]) ++ (pkg.propagatedBuildInputs or [ ])); collect = pkg: lib.unique ([ pkg ] ++ deps pkg ++ builtins.concatMap collect (deps pkg)); in builtins.concatMap collect appRuntimeDeps; # Some header files and libraries are not properly located by the Flutter SDK. # They must be manually included. - appStaticBuildDeps = (lib.optionals supportsLinuxDesktopTarget [ libX11 xorgproto zlib ]) ++ extraLibraries; + appStaticBuildDeps = + (lib.optionals supportsLinuxDesktopTarget [ + libX11 + xorgproto + zlib + ]) + ++ extraLibraries; # Tools used by the Flutter SDK to compile applications. buildTools = lib.optionals supportsLinuxDesktopTarget [ @@ -111,52 +129,76 @@ let # Nix-specific compiler configuration. pkgConfigPackages = map (lib.getOutput "dev") (appBuildDeps ++ extraPkgConfigPackages); - includeFlags = map (pkg: "-isystem ${lib.getOutput "dev" pkg}/include") (appStaticBuildDeps ++ extraIncludes); - linkerFlags = (map (pkg: "-rpath,${lib.getOutput "lib" pkg}/lib") appRuntimeDeps) ++ extraLinkerFlags; + includeFlags = map (pkg: "-isystem ${lib.getOutput "dev" pkg}/include") ( + appStaticBuildDeps ++ extraIncludes + ); + linkerFlags = + (map (pkg: "-rpath,${lib.getOutput "lib" pkg}/lib") appRuntimeDeps) ++ extraLinkerFlags; in -(callPackage ./sdk-symlink.nix { }) (stdenv.mkDerivation -{ - pname = "flutter-wrapped"; - inherit (flutter) version; - - nativeBuildInputs = [ makeWrapper ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.DarwinTools ] - ++ lib.optionals supportsLinuxDesktopTarget [ glib wrapGAppsHook3 ]; - - passthru = flutter.passthru // { +(callPackage ./sdk-symlink.nix { }) ( + stdenv.mkDerivation { + pname = "flutter-wrapped"; inherit (flutter) version; - unwrapped = flutter; - updateScript = ./update/update.py; - inherit cacheDir; - }; - dontUnpack = true; - dontWrapGApps = true; - - installPhase = '' - runHook preInstall - - for path in ${builtins.concatStringsSep " " (builtins.foldl' (paths: pkg: paths ++ (map (directory: "'${pkg}/${directory}/pkgconfig'") ["lib" "share"])) [ ] pkgConfigPackages)}; do - addToSearchPath FLUTTER_PKG_CONFIG_PATH "$path" - done - - mkdir -p $out/bin - makeWrapper '${immutableFlutter}' $out/bin/flutter \ - --set-default ANDROID_EMULATOR_USE_SYSTEM_LIBS 1 \ - '' + lib.optionalString (flutter ? engine && flutter.engine.meta.available) '' + nativeBuildInputs = + [ makeWrapper ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.DarwinTools ] + ++ lib.optionals supportsLinuxDesktopTarget [ + glib + wrapGAppsHook3 + ]; + + passthru = flutter.passthru // { + inherit (flutter) version; + unwrapped = flutter; + updateScript = ./update/update.py; + inherit cacheDir; + }; + + dontUnpack = true; + dontWrapGApps = true; + + installPhase = + '' + runHook preInstall + + for path in ${ + builtins.concatStringsSep " " ( + builtins.foldl' ( + paths: pkg: + paths + ++ (map (directory: "'${pkg}/${directory}/pkgconfig'") [ + "lib" + "share" + ]) + ) [ ] pkgConfigPackages + ) + }; do + addToSearchPath FLUTTER_PKG_CONFIG_PATH "$path" + done + + mkdir -p $out/bin + makeWrapper '${immutableFlutter}' $out/bin/flutter \ + --set-default ANDROID_EMULATOR_USE_SYSTEM_LIBS 1 \ + '' + + lib.optionalString (flutter ? engine && flutter.engine.meta.available) '' --set-default FLUTTER_ENGINE "${flutter.engine}" \ --add-flags "--local-engine-host ${flutter.engine.outName}" \ - '' + '' - --suffix PATH : '${lib.makeBinPath (tools ++ buildTools)}' \ - --suffix PKG_CONFIG_PATH : "$FLUTTER_PKG_CONFIG_PATH" \ - --suffix LIBRARY_PATH : '${lib.makeLibraryPath appStaticBuildDeps}' \ - --prefix CXXFLAGS "''\t" '${builtins.concatStringsSep " " (includeFlags ++ extraCxxFlags)}' \ - --prefix CFLAGS "''\t" '${builtins.concatStringsSep " " (includeFlags ++ extraCFlags)}' \ - --prefix LDFLAGS "''\t" '${builtins.concatStringsSep " " (map (flag: "-Wl,${flag}") linkerFlags)}' \ - ''${gappsWrapperArgs[@]} - - runHook postInstall - ''; - - inherit (flutter) meta; -}) + '' + + '' + --suffix PATH : '${lib.makeBinPath (tools ++ buildTools)}' \ + --suffix PKG_CONFIG_PATH : "$FLUTTER_PKG_CONFIG_PATH" \ + --suffix LIBRARY_PATH : '${lib.makeLibraryPath appStaticBuildDeps}' \ + --prefix CXXFLAGS "''\t" '${builtins.concatStringsSep " " (includeFlags ++ extraCxxFlags)}' \ + --prefix CFLAGS "''\t" '${builtins.concatStringsSep " " (includeFlags ++ extraCFlags)}' \ + --prefix LDFLAGS "''\t" '${ + builtins.concatStringsSep " " (map (flag: "-Wl,${flag}") linkerFlags) + }' \ + ''${gappsWrapperArgs[@]} + + runHook postInstall + ''; + + inherit (flutter) meta; + } +) diff --git a/pkgs/development/compilers/fpc/binary.nix b/pkgs/development/compilers/fpc/binary.nix index 6f8acae7f91689..488931f4d4f409 100644 --- a/pkgs/development/compilers/fpc/binary.nix +++ b/pkgs/development/compilers/fpc/binary.nix @@ -1,4 +1,11 @@ -{ stdenv, fetchurl, undmg, cpio, xar, lib }: +{ + stdenv, + fetchurl, + undmg, + cpio, + xar, + lib, +}: stdenv.mkDerivation rec { pname = "fpc-binary"; @@ -25,8 +32,8 @@ stdenv.mkDerivation rec { url = "mirror://sourceforge/project/freepascal/Mac%20OS%20X/${version}/fpc-${version}.intelarm64-macosx.dmg"; sha256 = "05d4510c8c887e3c68de20272abf62171aa5b2ef1eba6bce25e4c0bc41ba8b7d"; } - else throw "Not supported on ${stdenv.hostPlatform.system}."; - + else + throw "Not supported on ${stdenv.hostPlatform.system}."; nativeBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ undmg @@ -39,7 +46,8 @@ stdenv.mkDerivation rec { ./binary-builder.sh else if stdenv.hostPlatform.isDarwin then ./binary-builder-darwin.sh - else throw "Not supported on ${stdenv.hostPlatform}."; + else + throw "Not supported on ${stdenv.hostPlatform}."; meta = { description = "Free Pascal Compiler from a binary distribution"; diff --git a/pkgs/development/compilers/fpc/default.nix b/pkgs/development/compilers/fpc/default.nix index d44f76d618a2fb..6b8fa48511c023 100644 --- a/pkgs/development/compilers/fpc/default.nix +++ b/pkgs/development/compilers/fpc/default.nix @@ -1,6 +1,27 @@ -{ lib, stdenv, fetchurl, gawk, fetchpatch, undmg, cpio, xar, libiconv }: +{ + lib, + stdenv, + fetchurl, + gawk, + fetchpatch, + undmg, + cpio, + xar, + libiconv, +}: -let startFPC = import ./binary.nix { inherit stdenv fetchurl undmg cpio xar lib; }; in +let + startFPC = import ./binary.nix { + inherit + stdenv + fetchurl + undmg + cpio + xar + lib + ; + }; +in stdenv.mkDerivation rec { version = "3.2.2"; @@ -11,20 +32,25 @@ stdenv.mkDerivation rec { sha256 = "85ef993043bb83f999e2212f1bca766eb71f6f973d362e2290475dbaaf50161f"; }; - buildInputs = [ startFPC gawk ]; + buildInputs = [ + startFPC + gawk + ]; glibc = stdenv.cc.libc.out; # Patch paths for linux systems. Other platforms will need their own patches. - patches = [ - ./mark-paths.patch # mark paths for later substitution in postPatch - ] ++ lib.optional stdenv.hostPlatform.isAarch64 (fetchpatch { - # backport upstream patch for aarch64 glibc 2.34 - url = "https://gitlab.com/freepascal.org/fpc/source/-/commit/a20a7e3497bccf3415bf47ccc55f133eb9d6d6a0.patch"; - hash = "sha256-xKTBwuOxOwX9KCazQbBNLhMXCqkuJgIFvlXewHY63GM="; - stripLen = 1; - extraPrefix = "fpcsrc/"; - }); + patches = + [ + ./mark-paths.patch # mark paths for later substitution in postPatch + ] + ++ lib.optional stdenv.hostPlatform.isAarch64 (fetchpatch { + # backport upstream patch for aarch64 glibc 2.34 + url = "https://gitlab.com/freepascal.org/fpc/source/-/commit/a20a7e3497bccf3415bf47ccc55f133eb9d6d6a0.patch"; + hash = "sha256-xKTBwuOxOwX9KCazQbBNLhMXCqkuJgIFvlXewHY63GM="; + stripLen = 1; + extraPrefix = "fpcsrc/"; + }); postPatch = '' # substitute the markers set by the mark-paths patch @@ -46,7 +72,10 @@ stdenv.mkDerivation rec { NIX_LDFLAGS="-syslibroot $SDKROOT -L${lib.getLib libiconv}/lib" ''; - makeFlags = [ "NOGDB=1" "FPC=${startFPC}/bin/fpc" ]; + makeFlags = [ + "NOGDB=1" + "FPC=${startFPC}/bin/fpc" + ]; installFlags = [ "INSTALL_PREFIX=\${out}" ]; @@ -71,7 +100,10 @@ stdenv.mkDerivation rec { description = "Free Pascal Compiler from a source distribution"; homepage = "https://www.freepascal.org"; maintainers = [ maintainers.raskin ]; - license = with licenses; [ gpl2 lgpl2 ]; + license = with licenses; [ + gpl2 + lgpl2 + ]; platforms = platforms.unix; }; } diff --git a/pkgs/development/compilers/fpc/lazarus.nix b/pkgs/development/compilers/fpc/lazarus.nix index 4cd1dd9ab2f0e7..e11084a3452782 100644 --- a/pkgs/development/compilers/fpc/lazarus.nix +++ b/pkgs/development/compilers/fpc/lazarus.nix @@ -1,8 +1,26 @@ -{ stdenv, lib, fetchurl, makeWrapper, writeText -, fpc, gtk2, glib, pango, atk, gdk-pixbuf -, libXi, xorgproto, libX11, libXext -, gdb, gnumake, binutils -, withQt ? false, qtbase ? null, libqt5pas ? null, wrapQtAppsHook ? null +{ + stdenv, + lib, + fetchurl, + makeWrapper, + writeText, + fpc, + gtk2, + glib, + pango, + atk, + gdk-pixbuf, + libXi, + xorgproto, + libX11, + libXext, + gdb, + gnumake, + binutils, + withQt ? false, + qtbase ? null, + libqt5pas ? null, + wrapQtAppsHook ? null, }: # TODO: @@ -13,15 +31,17 @@ let # as of 2.0.10 a suffix is being added. That may or may not disappear and then # come back, so just leave this here. - majorMinorPatch = v: - builtins.concatStringsSep "." (lib.take 2 (lib.splitVersion v)); - - overrides = writeText "revision.inc" (lib.concatStringsSep "\n" (lib.mapAttrsToList (k: v: - "const ${k} = '${v}';") { - # this is technically the SVN revision but as we don't have that replace - # it with the version instead of showing "Unknown" - RevisionStr = version; - })); + majorMinorPatch = v: builtins.concatStringsSep "." (lib.take 2 (lib.splitVersion v)); + + overrides = writeText "revision.inc" ( + lib.concatStringsSep "\n" ( + lib.mapAttrsToList (k: v: "const ${k} = '${v}';") { + # this is technically the SVN revision but as we don't have that replace + # it with the version instead of showing "Unknown" + RevisionStr = version; + } + ) + ); in stdenv.mkDerivation rec { @@ -37,13 +57,25 @@ stdenv.mkDerivation rec { cp ${overrides} ide/${overrides.name} ''; - buildInputs = [ - # we need gtk2 unconditionally as that is the default target when building applications with lazarus - fpc gtk2 glib libXi xorgproto - libX11 libXext pango atk - stdenv.cc gdk-pixbuf - ] - ++ lib.optionals withQt [ libqt5pas qtbase ]; + buildInputs = + [ + # we need gtk2 unconditionally as that is the default target when building applications with lazarus + fpc + gtk2 + glib + libXi + xorgproto + libX11 + libXext + pango + atk + stdenv.cc + gdk-pixbuf + ] + ++ lib.optionals withQt [ + libqt5pas + qtbase + ]; # Disable parallel build, errors: # Fatal: (1018) Compilation aborted @@ -64,25 +96,27 @@ stdenv.mkDerivation rec { LCL_PLATFORM = if withQt then "qt5" else "gtk2"; - NIX_LDFLAGS = lib.concatStringsSep " " ([ - "-L${lib.getLib stdenv.cc.cc}/lib" - "-lX11" - "-lXext" - "-lXi" - "-latk-1.0" - "-lc" - "-lcairo" - "-lgcc_s" - "-lgdk-x11-2.0" - "-lgdk_pixbuf-2.0" - "-lglib-2.0" - "-lgtk-x11-2.0" - "-lpango-1.0" - ] - ++ lib.optionals withQt [ - "-L${lib.getLib libqt5pas}/lib" - "-lQt5Pas" - ]); + NIX_LDFLAGS = lib.concatStringsSep " " ( + [ + "-L${lib.getLib stdenv.cc.cc}/lib" + "-lX11" + "-lXext" + "-lXi" + "-latk-1.0" + "-lc" + "-lcairo" + "-lgcc_s" + "-lgdk-x11-2.0" + "-lgdk_pixbuf-2.0" + "-lglib-2.0" + "-lgtk-x11-2.0" + "-lpango-1.0" + ] + ++ lib.optionals withQt [ + "-L${lib.getLib libqt5pas}/lib" + "-lQt5Pas" + ] + ); preBuild = '' mkdir -p $out/share "$out/lazarus" @@ -91,20 +125,29 @@ stdenv.mkDerivation rec { --replace '/usr/fpcsrc' "$out/share/fpcsrc" ''; - postInstall = let - ldFlags = ''$(echo "$NIX_LDFLAGS" | sed -re 's/-rpath [^ ]+//g')''; - in '' - wrapProgram $out/bin/startlazarus \ - --prefix NIX_LDFLAGS ' ' "${ldFlags}" \ - --prefix NIX_LDFLAGS_${binutils.suffixSalt} ' ' "${ldFlags}" \ - --prefix LCL_PLATFORM ' ' "$LCL_PLATFORM" \ - --prefix PATH ':' "${lib.makeBinPath [ fpc gdb gnumake binutils ]}" - ''; + postInstall = + let + ldFlags = ''$(echo "$NIX_LDFLAGS" | sed -re 's/-rpath [^ ]+//g')''; + in + '' + wrapProgram $out/bin/startlazarus \ + --prefix NIX_LDFLAGS ' ' "${ldFlags}" \ + --prefix NIX_LDFLAGS_${binutils.suffixSalt} ' ' "${ldFlags}" \ + --prefix LCL_PLATFORM ' ' "$LCL_PLATFORM" \ + --prefix PATH ':' "${ + lib.makeBinPath [ + fpc + gdb + gnumake + binutils + ] + }" + ''; meta = with lib; { description = "Graphical IDE for the FreePascal language"; homepage = "https://www.lazarus.freepascal.org"; - license = licenses.gpl2Plus ; + license = licenses.gpl2Plus; maintainers = with maintainers; [ raskin ]; platforms = platforms.linux; }; diff --git a/pkgs/development/compilers/fpc/libqt5pas.nix b/pkgs/development/compilers/fpc/libqt5pas.nix index f3ddfe9edc23d0..209a749846dc25 100644 --- a/pkgs/development/compilers/fpc/libqt5pas.nix +++ b/pkgs/development/compilers/fpc/libqt5pas.nix @@ -1,4 +1,11 @@ -{ mkDerivation, lib, lazarus, qmake, qtbase, qtx11extras }: +{ + mkDerivation, + lib, + lazarus, + qmake, + qtbase, + qtx11extras, +}: mkDerivation { pname = "libqt5pas"; @@ -13,7 +20,10 @@ mkDerivation { nativeBuildInputs = [ qmake ]; - buildInputs = [ qtbase qtx11extras ]; + buildInputs = [ + qtbase + qtx11extras + ]; meta = with lib; { description = "Free Pascal Qt5 binding library"; diff --git a/pkgs/development/compilers/fstar/default.nix b/pkgs/development/compilers/fstar/default.nix index bcec02476fc6ed..d32158784b0956 100644 --- a/pkgs/development/compilers/fstar/default.nix +++ b/pkgs/development/compilers/fstar/default.nix @@ -1,13 +1,14 @@ -{ callPackage -, fetchFromGitHub -, installShellFiles -, lib -, makeWrapper -, ocamlPackages -, removeReferencesTo -, stdenv -, writeScript -, z3 +{ + callPackage, + fetchFromGitHub, + installShellFiles, + lib, + makeWrapper, + ocamlPackages, + removeReferencesTo, + stdenv, + writeScript, + z3, }: let @@ -23,7 +24,14 @@ let fstar-dune = ocamlPackages.callPackage ./dune.nix { inherit version src; }; - fstar-ulib = callPackage ./ulib.nix { inherit version src fstar-dune z3; }; + fstar-ulib = callPackage ./ulib.nix { + inherit + version + src + fstar-dune + z3 + ; + }; in @@ -76,7 +84,10 @@ stdenv.mkDerivation { homepage = "https://www.fstar-lang.org"; changelog = "https://github.com/FStarLang/FStar/raw/v${version}/CHANGES.md"; license = licenses.asl20; - maintainers = with maintainers; [ gebner pnmadelaine ]; + maintainers = with maintainers; [ + gebner + pnmadelaine + ]; mainProgram = "fstar.exe"; platforms = with platforms; darwin ++ linux; }; diff --git a/pkgs/development/compilers/fstar/dune.nix b/pkgs/development/compilers/fstar/dune.nix index 1ca476838c8bbd..3bdd62e88c4767 100644 --- a/pkgs/development/compilers/fstar/dune.nix +++ b/pkgs/development/compilers/fstar/dune.nix @@ -1,19 +1,20 @@ -{ batteries -, buildDunePackage -, memtrace -, menhir -, menhirLib -, pprint -, ppx_deriving -, ppx_deriving_yojson -, ppxlib -, process -, sedlex -, src -, stdint -, version -, yojson -, zarith +{ + batteries, + buildDunePackage, + memtrace, + menhir, + menhirLib, + pprint, + ppx_deriving, + ppx_deriving_yojson, + ppxlib, + process, + sedlex, + src, + stdint, + version, + yojson, + zarith, }: buildDunePackage { diff --git a/pkgs/development/compilers/fstar/ulib.nix b/pkgs/development/compilers/fstar/ulib.nix index 4390a7bdb55e37..cc7651800df2c3 100644 --- a/pkgs/development/compilers/fstar/ulib.nix +++ b/pkgs/development/compilers/fstar/ulib.nix @@ -1,8 +1,9 @@ -{ fstar-dune -, src -, stdenv -, version -, z3 +{ + fstar-dune, + src, + stdenv, + version, + z3, }: stdenv.mkDerivation { diff --git a/pkgs/development/compilers/gambit/bootstrap.nix b/pkgs/development/compilers/gambit/bootstrap.nix index 708640c8719c44..47f55ba98f3257 100644 --- a/pkgs/development/compilers/gambit/bootstrap.nix +++ b/pkgs/development/compilers/gambit/bootstrap.nix @@ -1,7 +1,15 @@ # This derivation is a reduced-functionality variant of Gambit stable, # used to compile the full version of Gambit stable *and* unstable. -{ gccStdenv, fetchurl, autoconf, gcc, coreutils, gambit-support, ... }: +{ + gccStdenv, + fetchurl, + autoconf, + gcc, + coreutils, + gambit-support, + ... +}: # As explained in build.nix, GCC compiles Gambit 10x faster than Clang, for code 3x better gccStdenv.mkDerivation { diff --git a/pkgs/development/compilers/gambit/build.nix b/pkgs/development/compilers/gambit/build.nix index 78c98fe50f2153..2c9cdd2a66a994 100644 --- a/pkgs/development/compilers/gambit/build.nix +++ b/pkgs/development/compilers/gambit/build.nix @@ -1,11 +1,21 @@ -{ gccStdenv, lib, pkgs, - git, openssl, autoconf, coreutils, - src, version, git-version, - stampYmd ? 0, stampHms ? 0, +{ + gccStdenv, + lib, + pkgs, + git, + openssl, + autoconf, + coreutils, + src, + version, + git-version, + stampYmd ? 0, + stampHms ? 0, gambit-support, optimizationSetting ? "-O1", gambit-params ? pkgs.gambit-support.stable-params, - rev ? git-version }: + rev ? git-version, +}: # Note that according to a benchmark run by Marc Feeley on May 2018, # clang is 10x (with default settings) to 15% (with -O2) slower than GCC at compiling @@ -31,11 +41,22 @@ gccStdenv.mkDerivation rec { bootstrap = gambit-support.gambit-bootstrap; passthru = { - inherit src version git-version rev stampYmd stampHms optimizationSetting openssl; + inherit + src + version + git-version + rev + stampYmd + stampHms + optimizationSetting + openssl + ; }; - - nativeBuildInputs = [ git autoconf ]; + nativeBuildInputs = [ + git + autoconf + ]; # TODO: if/when we can get all the library packages we depend on to have static versions, # we could use something like (makeStaticLibraries openssl) to enable creation @@ -46,36 +67,38 @@ gccStdenv.mkDerivation rec { # Or wrap relevant programs to add a suitable PATH ? #runtimeDeps = [ gnused gnugrep ]; - configureFlags = [ - "--enable-targets=${gambit-params.targets}" - "--enable-single-host" - "--enable-c-opt=${optimizationSetting}" - "--enable-c-opt-rts=-O2" - "--enable-gcc-opts" - "--enable-trust-c-tco" - "--enable-shared" - "--enable-absolute-shared-libs" # Yes, NixOS will want an absolute path, and fix it. - "--enable-openssl" - "--enable-dynamic-clib" - #"--enable-default-compile-options='(compactness 9)'" # Make life easier on the JS backend - "--enable-default-runtime-options=${gambit-params.defaultRuntimeOptions}" - # "--enable-rtlib-debug" # used by Geiser, but only on recent-enough gambit, and messes js runtime - # "--enable-debug" # Nope: enables plenty of good stuff, but also the costly console.log - # "--enable-multiple-versions" # Nope, NixOS already does version multiplexing - # "--enable-guide" - # "--enable-track-scheme" - # "--enable-high-res-timing" - # "--enable-max-processors=4" - # "--enable-multiple-vms" - # "--enable-dynamic-tls" - # "--enable-multiple-threaded-vms" # when SMP branch is merged in - # "--enable-thread-system=posix" # default when --enable-multiple-vms is on. - # "--enable-profile" - # "--enable-coverage" - # "--enable-inline-jumps" - # "--enable-char-size=1" # default is 4 - # "--enable-march=native" # Nope, makes it not work on machines older than the builder - ] ++ gambit-params.extraOptions + configureFlags = + [ + "--enable-targets=${gambit-params.targets}" + "--enable-single-host" + "--enable-c-opt=${optimizationSetting}" + "--enable-c-opt-rts=-O2" + "--enable-gcc-opts" + "--enable-trust-c-tco" + "--enable-shared" + "--enable-absolute-shared-libs" # Yes, NixOS will want an absolute path, and fix it. + "--enable-openssl" + "--enable-dynamic-clib" + #"--enable-default-compile-options='(compactness 9)'" # Make life easier on the JS backend + "--enable-default-runtime-options=${gambit-params.defaultRuntimeOptions}" + # "--enable-rtlib-debug" # used by Geiser, but only on recent-enough gambit, and messes js runtime + # "--enable-debug" # Nope: enables plenty of good stuff, but also the costly console.log + # "--enable-multiple-versions" # Nope, NixOS already does version multiplexing + # "--enable-guide" + # "--enable-track-scheme" + # "--enable-high-res-timing" + # "--enable-max-processors=4" + # "--enable-multiple-vms" + # "--enable-dynamic-tls" + # "--enable-multiple-threaded-vms" # when SMP branch is merged in + # "--enable-thread-system=posix" # default when --enable-multiple-vms is on. + # "--enable-profile" + # "--enable-coverage" + # "--enable-inline-jumps" + # "--enable-char-size=1" # default is 4 + # "--enable-march=native" # Nope, makes it not work on machines older than the builder + ] + ++ gambit-params.extraOptions # TODO: pick an appropriate architecture to optimize on on x86-64? # https://gcc.gnu.org/onlinedocs/gcc-4.8.4/gcc/i386-and-x86-64-Options.html#i386-and-x86-64-Options # ++ lib.optional pkgs.stdenv.hostPlatform.isx86_64 "--enable-march=core-avx2" @@ -97,8 +120,11 @@ gccStdenv.mkDerivation rec { # OS-specific paths are hardcoded in ./configure substituteInPlace config.status \ - ${lib.optionalString (gccStdenv.hostPlatform.isDarwin && !gambit-params.stable) - ''--replace "/usr/local/opt/openssl@1.1" "${lib.getLib openssl}"''} \ + ${ + lib.optionalString ( + gccStdenv.hostPlatform.isDarwin && !gambit-params.stable + ) ''--replace "/usr/local/opt/openssl@1.1" "${lib.getLib openssl}"'' + } \ --replace "/usr/local/opt/openssl" "${lib.getLib openssl}" ./config.status diff --git a/pkgs/development/compilers/gambit/gambit-support.nix b/pkgs/development/compilers/gambit/gambit-support.nix index 1209ca10aa161d..64a9b6a2bb467e 100644 --- a/pkgs/development/compilers/gambit/gambit-support.nix +++ b/pkgs/development/compilers/gambit/gambit-support.nix @@ -18,25 +18,29 @@ rec { grep -i ' version=\|echo..#define ___STAMP_VERSION' include/makefile.in # XXX DEBUG -- REMOVE ME ''; modules = true; - extraOptions = ["CFLAGS=-foptimize-sibling-calls"]; + extraOptions = [ "CFLAGS=-foptimize-sibling-calls" ]; }; unstable-params = stable-params // { stable = false; - extraOptions = []; # "CFLAGS=-foptimize-sibling-calls" not necessary in latest unstable + extraOptions = [ ]; # "CFLAGS=-foptimize-sibling-calls" not necessary in latest unstable }; - export-gambopt = params : "export GAMBOPT=${params.buildRuntimeOptions} ;"; + export-gambopt = params: "export GAMBOPT=${params.buildRuntimeOptions} ;"; - gambit-bootstrap = import ./bootstrap.nix ( pkgs ); + gambit-bootstrap = import ./bootstrap.nix (pkgs); meta = with lib; { description = "Optimizing Scheme to C compiler"; - homepage = "http://gambitscheme.org"; - license = licenses.lgpl21Only; # dual, also asl20 + homepage = "http://gambitscheme.org"; + license = licenses.lgpl21Only; # dual, also asl20 # NB regarding platforms: continuously tested on Linux x86_64 and regularly tested on macOS x86_64. # *should* work everywhere. - platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice raskin fare ]; + platforms = platforms.unix; + maintainers = with maintainers; [ + thoughtpolice + raskin + fare + ]; }; } diff --git a/pkgs/development/compilers/gambit/unstable.nix b/pkgs/development/compilers/gambit/unstable.nix index f8c19640dd58a3..e1cfebb1470076 100644 --- a/pkgs/development/compilers/gambit/unstable.nix +++ b/pkgs/development/compilers/gambit/unstable.nix @@ -1,4 +1,8 @@ -{ callPackage, fetchFromGitHub, gambit-support }: +{ + callPackage, + fetchFromGitHub, + gambit-support, +}: callPackage ./build.nix rec { version = "unstable-2023-12-04"; diff --git a/pkgs/development/compilers/gcc/all.nix b/pkgs/development/compilers/gcc/all.nix index 444253a3787851..626aa0603f4d1a 100644 --- a/pkgs/development/compilers/gcc/all.nix +++ b/pkgs/development/compilers/gcc/all.nix @@ -1,52 +1,64 @@ -{ lib -, stdenv -, pkgs -, callPackage -, isl_0_20 -, libcCross -, threadsCross -, noSysDirs -, lowPrio -, wrapCC +{ + lib, + stdenv, + pkgs, + callPackage, + isl_0_20, + libcCross, + threadsCross, + noSysDirs, + lowPrio, + wrapCC, }@args: let versions = import ./versions.nix; - gccForMajorMinorVersion = majorMinorVersion: + gccForMajorMinorVersion = + majorMinorVersion: let majorVersion = lib.versions.major majorMinorVersion; atLeast = lib.versionAtLeast majorMinorVersion; - attrName = "gcc${lib.replaceStrings ["."] [""] majorMinorVersion}"; - pkg = lowPrio (wrapCC (callPackage ./default.nix { - inherit noSysDirs; - inherit majorMinorVersion; - reproducibleBuild = true; - profiledCompiler = false; - libcCross = if stdenv.targetPlatform != stdenv.buildPlatform then args.libcCross else null; - threadsCross = if stdenv.targetPlatform != stdenv.buildPlatform then threadsCross else { }; - isl = if stdenv.hostPlatform.isDarwin then null else isl_0_20; - # do not allow version skew when cross-building gcc - # - # When `gcc` is cross-built (`build` != `target` && `host` == `target`) - # `gcc` assumes that it has a compatible cross-compiler in the environment - # that can build target libraries. Version of a cross-compiler has to - # match the compiler being cross-built as libraries frequently use fresh - # compiler features, like `-std=c++26` or target-specific types like - # `_Bfloat16`. - # Version mismatch causes build failures like: - # https://github.com/NixOS/nixpkgs/issues/351905 - # - # Similar problems (but on a smaller scale) happen when a `gcc` - # cross-compiler is built (`build` == `host` && `host` != `target`) built - # by a mismatching version of a native compiler (`build` == `host` && - # `host` == `target`). - # - # Let's fix both problems by requiring the same compiler version for - # cross-case. - stdenv = if (stdenv.targetPlatform != stdenv.buildPlatform || stdenv.hostPlatform != stdenv.targetPlatform) && stdenv.cc.isGNU then pkgs."gcc${majorVersion}Stdenv" else stdenv; - })); + attrName = "gcc${lib.replaceStrings [ "." ] [ "" ] majorMinorVersion}"; + pkg = lowPrio ( + wrapCC ( + callPackage ./default.nix { + inherit noSysDirs; + inherit majorMinorVersion; + reproducibleBuild = true; + profiledCompiler = false; + libcCross = if stdenv.targetPlatform != stdenv.buildPlatform then args.libcCross else null; + threadsCross = if stdenv.targetPlatform != stdenv.buildPlatform then threadsCross else { }; + isl = if stdenv.hostPlatform.isDarwin then null else isl_0_20; + # do not allow version skew when cross-building gcc + # + # When `gcc` is cross-built (`build` != `target` && `host` == `target`) + # `gcc` assumes that it has a compatible cross-compiler in the environment + # that can build target libraries. Version of a cross-compiler has to + # match the compiler being cross-built as libraries frequently use fresh + # compiler features, like `-std=c++26` or target-specific types like + # `_Bfloat16`. + # Version mismatch causes build failures like: + # https://github.com/NixOS/nixpkgs/issues/351905 + # + # Similar problems (but on a smaller scale) happen when a `gcc` + # cross-compiler is built (`build` == `host` && `host` != `target`) built + # by a mismatching version of a native compiler (`build` == `host` && + # `host` == `target`). + # + # Let's fix both problems by requiring the same compiler version for + # cross-case. + stdenv = + if + (stdenv.targetPlatform != stdenv.buildPlatform || stdenv.hostPlatform != stdenv.targetPlatform) + && stdenv.cc.isGNU + then + pkgs."gcc${majorVersion}Stdenv" + else + stdenv; + } + ) + ); in - lib.nameValuePair attrName pkg; + lib.nameValuePair attrName pkg; in lib.listToAttrs (map gccForMajorMinorVersion versions.allMajorVersions) - diff --git a/pkgs/development/compilers/gcc/common/builder.nix b/pkgs/development/compilers/gcc/common/builder.nix index 874a43a75f8200..1b3754dad6bd7a 100644 --- a/pkgs/development/compilers/gcc/common/builder.nix +++ b/pkgs/development/compilers/gcc/common/builder.nix @@ -1,302 +1,317 @@ -{ lib -, stdenv -, enableMultilib -, targetConfig +{ + lib, + stdenv, + enableMultilib, + targetConfig, }: let - forceLibgccToBuildCrtStuff = - import ./libgcc-buildstuff.nix { inherit lib stdenv; }; + forceLibgccToBuildCrtStuff = import ./libgcc-buildstuff.nix { inherit lib stdenv; }; in -originalAttrs: (stdenv.mkDerivation (finalAttrs: originalAttrs // { - passthru = (originalAttrs.passthru or {}) // { inherit forceLibgccToBuildCrtStuff; }; - preUnpack = '' - oldOpts="$(shopt -po nounset)" || true - set -euo pipefail - - export NIX_FIXINC_DUMMY="$NIX_BUILD_TOP/dummy" - mkdir "$NIX_FIXINC_DUMMY" - - if test "$staticCompiler" = "1"; then - EXTRA_LDFLAGS="-static" - elif test "''${NIX_DONT_SET_RPATH-}" != "1"; then - EXTRA_LDFLAGS="-Wl,-rpath,''${!outputLib}/lib" - else - EXTRA_LDFLAGS="" - fi - - # GCC interprets empty paths as ".", which we don't want. - if test -z "''${CPATH-}"; then unset CPATH; fi - if test -z "''${LIBRARY_PATH-}"; then unset LIBRARY_PATH; fi - echo "\$CPATH is \`''${CPATH-}'" - echo "\$LIBRARY_PATH is \`''${LIBRARY_PATH-}'" - - if test "$noSysDirs" = "1"; then - - declare -g \ - EXTRA_FLAGS_FOR_BUILD EXTRA_FLAGS EXTRA_FLAGS_FOR_TARGET \ - EXTRA_LDFLAGS_FOR_BUILD EXTRA_LDFLAGS_FOR_TARGET - - # Extract flags from Bintools Wrappers - for post in '_FOR_BUILD' ""; do - curBintools="NIX_BINTOOLS''${post}" - - declare -a extraLDFlags=() - if [[ -e "''${!curBintools}/nix-support/orig-libc" ]]; then - # Figure out what extra flags when linking to pass to the gcc - # compilers being generated to make sure that they use our libc. - extraLDFlags=($(< "''${!curBintools}/nix-support/libc-ldflags") $(< "''${!curBintools}/nix-support/libc-ldflags-before" || true)) - if [ -e ''${!curBintools}/nix-support/ld-set-dynamic-linker ]; then - extraLDFlags=-dynamic-linker=$(< ''${!curBintools}/nix-support/dynamic-linker) - fi - - # The path to the Libc binaries such as `crti.o'. - libc_libdir="$(< "''${!curBintools}/nix-support/orig-libc")/lib" - else - # Hack: support impure environments. - extraLDFlags=("-L/usr/lib64" "-L/usr/lib") - libc_libdir="/usr/lib" - fi - declare -a prefixExtraLDFlags=() - prefixExtraLDFlags=("-L$libc_libdir") - nixDontSetRpathVar=NIX_DONT_SET_RPATH''${post} - if test "''${!nixDontSetRpathVar-}" != "1"; then - prefixExtraLDFlags+=("-rpath" "$libc_libdir") - fi - extraLDFlags=("''${prefixExtraLDFlags[@]}" "''${extraLDFlags[@]}") - for i in "''${extraLDFlags[@]}"; do - declare -g EXTRA_LDFLAGS''${post}+=" -Wl,$i" - done - done - - # Extract flags from CC Wrappers - for post in '_FOR_BUILD' ""; do - curCC="NIX_CC''${post}" - curFIXINC="NIX_FIXINC_DUMMY''${post}" - - declare -a extraFlags=() - if [[ -e "''${!curCC}/nix-support/orig-libc" ]]; then - # Figure out what extra compiling flags to pass to the gcc compilers - # being generated to make sure that they use our libc. - extraFlags=($(< "''${!curCC}/nix-support/libc-crt1-cflags") $(< "''${!curCC}/nix-support/libc-cflags")) - - # The path to the Libc headers - libc_devdir="$(< "''${!curCC}/nix-support/orig-libc-dev")" - - # Use *real* header files, otherwise a limits.h is generated that - # does not include Libc's limits.h (notably missing SSIZE_MAX, - # which breaks the build). - declare -g NIX_FIXINC_DUMMY''${post}="$libc_devdir/include" - else - # Hack: support impure environments. - extraFlags=("-isystem" "/usr/include") - declare -g NIX_FIXINC_DUMMY''${post}=/usr/include - fi - - extraFlags=("-I''${!curFIXINC}" "''${extraFlags[@]}") - - # BOOT_CFLAGS defaults to `-g -O2'; since we override it below, make - # sure to explictly add them so that files compiled with the bootstrap - # compiler are optimized and (optionally) contain debugging information - # (info "(gccinstall) Building"). - if test -n "''${dontStrip-}"; then - extraFlags=("-O2" "-g" "''${extraFlags[@]}") - else - # Don't pass `-g' at all; this saves space while building. - extraFlags=("-O2" "''${extraFlags[@]}") - fi - - declare -g EXTRA_FLAGS''${post}="''${extraFlags[*]}" - done - - if test -z "''${targetConfig-}"; then - # host = target, so the flags are the same - EXTRA_FLAGS_FOR_TARGET="$EXTRA_FLAGS" - EXTRA_LDFLAGS_FOR_TARGET="$EXTRA_LDFLAGS" +originalAttrs: +(stdenv.mkDerivation ( + finalAttrs: + originalAttrs + // { + passthru = (originalAttrs.passthru or { }) // { + inherit forceLibgccToBuildCrtStuff; + }; + preUnpack = '' + oldOpts="$(shopt -po nounset)" || true + set -euo pipefail + + export NIX_FIXINC_DUMMY="$NIX_BUILD_TOP/dummy" + mkdir "$NIX_FIXINC_DUMMY" + + if test "$staticCompiler" = "1"; then + EXTRA_LDFLAGS="-static" + elif test "''${NIX_DONT_SET_RPATH-}" != "1"; then + EXTRA_LDFLAGS="-Wl,-rpath,''${!outputLib}/lib" + else + EXTRA_LDFLAGS="" + fi + + # GCC interprets empty paths as ".", which we don't want. + if test -z "''${CPATH-}"; then unset CPATH; fi + if test -z "''${LIBRARY_PATH-}"; then unset LIBRARY_PATH; fi + echo "\$CPATH is \`''${CPATH-}'" + echo "\$LIBRARY_PATH is \`''${LIBRARY_PATH-}'" + + if test "$noSysDirs" = "1"; then + + declare -g \ + EXTRA_FLAGS_FOR_BUILD EXTRA_FLAGS EXTRA_FLAGS_FOR_TARGET \ + EXTRA_LDFLAGS_FOR_BUILD EXTRA_LDFLAGS_FOR_TARGET + + # Extract flags from Bintools Wrappers + for post in '_FOR_BUILD' ""; do + curBintools="NIX_BINTOOLS''${post}" + + declare -a extraLDFlags=() + if [[ -e "''${!curBintools}/nix-support/orig-libc" ]]; then + # Figure out what extra flags when linking to pass to the gcc + # compilers being generated to make sure that they use our libc. + extraLDFlags=($(< "''${!curBintools}/nix-support/libc-ldflags") $(< "''${!curBintools}/nix-support/libc-ldflags-before" || true)) + if [ -e ''${!curBintools}/nix-support/ld-set-dynamic-linker ]; then + extraLDFlags=-dynamic-linker=$(< ''${!curBintools}/nix-support/dynamic-linker) + fi + + # The path to the Libc binaries such as `crti.o'. + libc_libdir="$(< "''${!curBintools}/nix-support/orig-libc")/lib" + else + # Hack: support impure environments. + extraLDFlags=("-L/usr/lib64" "-L/usr/lib") + libc_libdir="/usr/lib" + fi + declare -a prefixExtraLDFlags=() + prefixExtraLDFlags=("-L$libc_libdir") + nixDontSetRpathVar=NIX_DONT_SET_RPATH''${post} + if test "''${!nixDontSetRpathVar-}" != "1"; then + prefixExtraLDFlags+=("-rpath" "$libc_libdir") + fi + extraLDFlags=("''${prefixExtraLDFlags[@]}" "''${extraLDFlags[@]}") + for i in "''${extraLDFlags[@]}"; do + declare -g EXTRA_LDFLAGS''${post}+=" -Wl,$i" + done + done + + # Extract flags from CC Wrappers + for post in '_FOR_BUILD' ""; do + curCC="NIX_CC''${post}" + curFIXINC="NIX_FIXINC_DUMMY''${post}" + + declare -a extraFlags=() + if [[ -e "''${!curCC}/nix-support/orig-libc" ]]; then + # Figure out what extra compiling flags to pass to the gcc compilers + # being generated to make sure that they use our libc. + extraFlags=($(< "''${!curCC}/nix-support/libc-crt1-cflags") $(< "''${!curCC}/nix-support/libc-cflags")) + + # The path to the Libc headers + libc_devdir="$(< "''${!curCC}/nix-support/orig-libc-dev")" + + # Use *real* header files, otherwise a limits.h is generated that + # does not include Libc's limits.h (notably missing SSIZE_MAX, + # which breaks the build). + declare -g NIX_FIXINC_DUMMY''${post}="$libc_devdir/include" + else + # Hack: support impure environments. + extraFlags=("-isystem" "/usr/include") + declare -g NIX_FIXINC_DUMMY''${post}=/usr/include + fi + + extraFlags=("-I''${!curFIXINC}" "''${extraFlags[@]}") + + # BOOT_CFLAGS defaults to `-g -O2'; since we override it below, make + # sure to explictly add them so that files compiled with the bootstrap + # compiler are optimized and (optionally) contain debugging information + # (info "(gccinstall) Building"). + if test -n "''${dontStrip-}"; then + extraFlags=("-O2" "-g" "''${extraFlags[@]}") + else + # Don't pass `-g' at all; this saves space while building. + extraFlags=("-O2" "''${extraFlags[@]}") + fi + + declare -g EXTRA_FLAGS''${post}="''${extraFlags[*]}" + done + + if test -z "''${targetConfig-}"; then + # host = target, so the flags are the same + EXTRA_FLAGS_FOR_TARGET="$EXTRA_FLAGS" + EXTRA_LDFLAGS_FOR_TARGET="$EXTRA_LDFLAGS" + fi + + # CFLAGS_FOR_TARGET are needed for the libstdc++ configure script to find + # the startfiles. + # FLAGS_FOR_TARGET are needed for the target libraries to receive the -Bxxx + # for the startfiles. + makeFlagsArray+=( + "BUILD_SYSTEM_HEADER_DIR=$NIX_FIXINC_DUMMY_FOR_BUILD" + "SYSTEM_HEADER_DIR=$NIX_FIXINC_DUMMY_FOR_BUILD" + "NATIVE_SYSTEM_HEADER_DIR=$NIX_FIXINC_DUMMY" + + "LDFLAGS_FOR_BUILD=$EXTRA_LDFLAGS_FOR_BUILD" + #"LDFLAGS=$EXTRA_LDFLAGS" + "LDFLAGS_FOR_TARGET=$EXTRA_LDFLAGS_FOR_TARGET" + + "CFLAGS_FOR_BUILD=$EXTRA_FLAGS_FOR_BUILD $EXTRA_LDFLAGS_FOR_BUILD" + "CXXFLAGS_FOR_BUILD=$EXTRA_FLAGS_FOR_BUILD $EXTRA_LDFLAGS_FOR_BUILD" + "FLAGS_FOR_BUILD=$EXTRA_FLAGS_FOR_BUILD $EXTRA_LDFLAGS_FOR_BUILD" + + # It seems there is a bug in GCC 5 + #"CFLAGS=$EXTRA_FLAGS $EXTRA_LDFLAGS" + #"CXXFLAGS=$EXTRA_FLAGS $EXTRA_LDFLAGS" + + "CFLAGS_FOR_TARGET=$EXTRA_FLAGS_FOR_TARGET $EXTRA_LDFLAGS_FOR_TARGET" + "CXXFLAGS_FOR_TARGET=$EXTRA_FLAGS_FOR_TARGET $EXTRA_LDFLAGS_FOR_TARGET" + "FLAGS_FOR_TARGET=$EXTRA_FLAGS_FOR_TARGET $EXTRA_LDFLAGS_FOR_TARGET" + ) + + if test -z "''${targetConfig-}"; then + makeFlagsArray+=( + "BOOT_CFLAGS=$EXTRA_FLAGS $EXTRA_LDFLAGS" + "BOOT_LDFLAGS=$EXTRA_FLAGS_FOR_TARGET $EXTRA_LDFLAGS_FOR_TARGET" + ) + fi + + if test "$withoutTargetLibc" == 1; then + # We don't want the gcc build to assume there will be a libc providing + # limits.h in this stage + makeFlagsArray+=( + 'LIMITS_H_TEST=false' + ) + else + makeFlagsArray+=( + 'LIMITS_H_TEST=true' + ) + fi + fi + + eval "$oldOpts" + ''; + + preConfigure = + (originalAttrs.preConfigure or "") + + '' + if test -n "$newlibSrc"; then + tar xvf "$newlibSrc" -C .. + ln -s ../newlib-*/newlib newlib + # Patch to get armvt5el working: + sed -i -e 's/ arm)/ arm*)/' newlib/configure.host fi - # CFLAGS_FOR_TARGET are needed for the libstdc++ configure script to find - # the startfiles. - # FLAGS_FOR_TARGET are needed for the target libraries to receive the -Bxxx - # for the startfiles. - makeFlagsArray+=( - "BUILD_SYSTEM_HEADER_DIR=$NIX_FIXINC_DUMMY_FOR_BUILD" - "SYSTEM_HEADER_DIR=$NIX_FIXINC_DUMMY_FOR_BUILD" - "NATIVE_SYSTEM_HEADER_DIR=$NIX_FIXINC_DUMMY" - - "LDFLAGS_FOR_BUILD=$EXTRA_LDFLAGS_FOR_BUILD" - #"LDFLAGS=$EXTRA_LDFLAGS" - "LDFLAGS_FOR_TARGET=$EXTRA_LDFLAGS_FOR_TARGET" - - "CFLAGS_FOR_BUILD=$EXTRA_FLAGS_FOR_BUILD $EXTRA_LDFLAGS_FOR_BUILD" - "CXXFLAGS_FOR_BUILD=$EXTRA_FLAGS_FOR_BUILD $EXTRA_LDFLAGS_FOR_BUILD" - "FLAGS_FOR_BUILD=$EXTRA_FLAGS_FOR_BUILD $EXTRA_LDFLAGS_FOR_BUILD" - - # It seems there is a bug in GCC 5 - #"CFLAGS=$EXTRA_FLAGS $EXTRA_LDFLAGS" - #"CXXFLAGS=$EXTRA_FLAGS $EXTRA_LDFLAGS" - - "CFLAGS_FOR_TARGET=$EXTRA_FLAGS_FOR_TARGET $EXTRA_LDFLAGS_FOR_TARGET" - "CXXFLAGS_FOR_TARGET=$EXTRA_FLAGS_FOR_TARGET $EXTRA_LDFLAGS_FOR_TARGET" - "FLAGS_FOR_TARGET=$EXTRA_FLAGS_FOR_TARGET $EXTRA_LDFLAGS_FOR_TARGET" - ) - - if test -z "''${targetConfig-}"; then - makeFlagsArray+=( - "BOOT_CFLAGS=$EXTRA_FLAGS $EXTRA_LDFLAGS" - "BOOT_LDFLAGS=$EXTRA_FLAGS_FOR_TARGET $EXTRA_LDFLAGS_FOR_TARGET" - ) + # Bug - they packaged zlib + if test -d "zlib"; then + # This breaks the build without-headers, which should build only + # the target libgcc as target libraries. + # See 'configure:5370' + rm -Rf zlib fi - if test "$withoutTargetLibc" == 1; then - # We don't want the gcc build to assume there will be a libc providing - # limits.h in this stage - makeFlagsArray+=( - 'LIMITS_H_TEST=false' - ) - else - makeFlagsArray+=( - 'LIMITS_H_TEST=true' - ) + if test -n "$crossMingw" -a -n "$withoutTargetLibc"; then + mkdir -p ../mingw + # --with-build-sysroot expects that: + cp -R $libcCross/include ../mingw + configureFlags="$configureFlags --with-build-sysroot=`pwd`/.." fi - fi - - eval "$oldOpts" - ''; - - preConfigure = (originalAttrs.preConfigure or "") + '' - if test -n "$newlibSrc"; then - tar xvf "$newlibSrc" -C .. - ln -s ../newlib-*/newlib newlib - # Patch to get armvt5el working: - sed -i -e 's/ arm)/ arm*)/' newlib/configure.host - fi - - # Bug - they packaged zlib - if test -d "zlib"; then - # This breaks the build without-headers, which should build only - # the target libgcc as target libraries. - # See 'configure:5370' - rm -Rf zlib - fi - - if test -n "$crossMingw" -a -n "$withoutTargetLibc"; then - mkdir -p ../mingw - # --with-build-sysroot expects that: - cp -R $libcCross/include ../mingw - configureFlags="$configureFlags --with-build-sysroot=`pwd`/.." - fi - - # Perform the build in a different directory. - mkdir ../build - cd ../build - configureScript=../$sourceRoot/configure - ''; - - postConfigure = '' - # Avoid store paths when embedding ./configure flags into gcc. - # Mangled arguments are still useful when reporting bugs upstream. - sed -e "/TOPLEVEL_CONFIGURE_ARGUMENTS=/ s|$NIX_STORE/[a-z0-9]\{32\}-|$NIX_STORE/eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee-|g" -i Makefile - ''; - - preInstall = '' - mkdir -p "$out/''${targetConfig}/lib" - mkdir -p "''${!outputLib}/''${targetConfig}/lib" - '' + - # if cross-compiling, link from $lib/lib to $lib/${targetConfig}. - # since native-compiles have $lib/lib as a directory (not a - # symlink), this ensures that in every case we can assume that - # $lib/lib contains the .so files - lib.optionalString (with stdenv; targetPlatform.config != hostPlatform.config) '' - ln -Ts "''${!outputLib}/''${targetConfig}/lib" $lib/lib - '' + - # Make `lib64` symlinks to `lib`. - lib.optionalString (!enableMultilib && stdenv.hostPlatform.is64bit && !stdenv.hostPlatform.isMips64n32) '' - ln -s lib "$out/''${targetConfig}/lib64" - ln -s lib "''${!outputLib}/''${targetConfig}/lib64" - '' + - # On mips platforms, gcc follows the IRIX naming convention: - # - # $PREFIX/lib = mips32 - # $PREFIX/lib32 = mips64n32 - # $PREFIX/lib64 = mips64 - # - # Make `lib32` symlinks to `lib`. - lib.optionalString (!enableMultilib && stdenv.targetPlatform.isMips64n32) '' - ln -s lib "$out/''${targetConfig}/lib32" - ln -s lib "''${!outputLib}/''${targetConfig}/lib32" - ''; - - postInstall = '' - # Move runtime libraries to lib output. - moveToOutput "''${targetConfig+$targetConfig/}lib/lib*.so*" "''${!outputLib}" - moveToOutput "''${targetConfig+$targetConfig/}lib/lib*.la" "''${!outputLib}" - moveToOutput "''${targetConfig+$targetConfig/}lib/lib*.dylib" "''${!outputLib}" - moveToOutput "''${targetConfig+$targetConfig/}lib/lib*.dll.a" "''${!outputLib}" - moveToOutput "''${targetConfig+$targetConfig/}lib/lib*.dll" "''${!outputLib}" - moveToOutput "share/gcc-*/python" "''${!outputLib}" - - if [ -z "$enableShared" ]; then - moveToOutput "''${targetConfig+$targetConfig/}lib/lib*.a" "''${!outputLib}" - fi - - for i in "''${!outputLib}/''${targetConfig}"/lib/*.{la,py}; do - substituteInPlace "$i" --replace "$out" "''${!outputLib}" - done - - if [ -n "$enableMultilib" ]; then - moveToOutput "''${targetConfig+$targetConfig/}lib64/lib*.so*" "''${!outputLib}" - moveToOutput "''${targetConfig+$targetConfig/}lib64/lib*.la" "''${!outputLib}" - moveToOutput "''${targetConfig+$targetConfig/}lib64/lib*.dylib" "''${!outputLib}" - moveToOutput "''${targetConfig+$targetConfig/}lib64/lib*.dll.a" "''${!outputLib}" - moveToOutput "''${targetConfig+$targetConfig/}lib64/lib*.dll" "''${!outputLib}" - - for i in "''${!outputLib}/''${targetConfig}"/lib64/*.{la,py}; do - substituteInPlace "$i" --replace "$out" "''${!outputLib}" - done - fi - - # Remove `fixincl' to prevent a retained dependency on the - # previous gcc. - rm -rf $out/libexec/gcc/*/*/install-tools - rm -rf $out/lib/gcc/*/*/install-tools - - # More dependencies with the previous gcc or some libs (gccbug stores the build command line) - rm -rf $out/bin/gccbug - - if type "install_name_tool"; then - for i in "''${!outputLib}"/lib/*.*.dylib "''${!outputLib}"/lib/*.so.[0-9]; do - install_name_tool -id "$i" "$i" || true - for old_path in $(otool -L "$i" | grep "$out" | awk '{print $1}'); do - new_path=`echo "$old_path" | sed "s,$out,''${!outputLib},"` - install_name_tool -change "$old_path" "$new_path" "$i" || true - done - done - fi - - # Get rid of some "fixed" header files - rm -rfv $out/lib/gcc/*/*/include-fixed/{root,linux,sys/mount.h,bits/statx.h,pthread.h} - - # Replace hard links for i686-pc-linux-gnu-gcc etc. with symlinks. - for i in $out/bin/*-gcc*; do - if cmp -s $out/bin/gcc $i; then - ln -sfn gcc $i - fi - done - - for i in $out/bin/c++ $out/bin/*-c++* $out/bin/*-g++*; do - if cmp -s $out/bin/g++ $i; then - ln -sfn g++ $i - fi - done - # Two identical man pages are shipped (moving and compressing is done later) - for i in "$out"/share/man/man1/*g++.1; do - if test -e "$i"; then - man_prefix=`echo "$i" | sed "s,.*/\(.*\)g++.1,\1,"` - ln -sf "$man_prefix"gcc.1 "$i" - fi - done - ''; -})) + # Perform the build in a different directory. + mkdir ../build + cd ../build + configureScript=../$sourceRoot/configure + ''; + + postConfigure = '' + # Avoid store paths when embedding ./configure flags into gcc. + # Mangled arguments are still useful when reporting bugs upstream. + sed -e "/TOPLEVEL_CONFIGURE_ARGUMENTS=/ s|$NIX_STORE/[a-z0-9]\{32\}-|$NIX_STORE/eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee-|g" -i Makefile + ''; + + preInstall = + '' + mkdir -p "$out/''${targetConfig}/lib" + mkdir -p "''${!outputLib}/''${targetConfig}/lib" + '' + + + # if cross-compiling, link from $lib/lib to $lib/${targetConfig}. + # since native-compiles have $lib/lib as a directory (not a + # symlink), this ensures that in every case we can assume that + # $lib/lib contains the .so files + lib.optionalString (with stdenv; targetPlatform.config != hostPlatform.config) '' + ln -Ts "''${!outputLib}/''${targetConfig}/lib" $lib/lib + '' + + + # Make `lib64` symlinks to `lib`. + lib.optionalString + (!enableMultilib && stdenv.hostPlatform.is64bit && !stdenv.hostPlatform.isMips64n32) + '' + ln -s lib "$out/''${targetConfig}/lib64" + ln -s lib "''${!outputLib}/''${targetConfig}/lib64" + '' + + + # On mips platforms, gcc follows the IRIX naming convention: + # + # $PREFIX/lib = mips32 + # $PREFIX/lib32 = mips64n32 + # $PREFIX/lib64 = mips64 + # + # Make `lib32` symlinks to `lib`. + lib.optionalString (!enableMultilib && stdenv.targetPlatform.isMips64n32) '' + ln -s lib "$out/''${targetConfig}/lib32" + ln -s lib "''${!outputLib}/''${targetConfig}/lib32" + ''; + + postInstall = '' + # Move runtime libraries to lib output. + moveToOutput "''${targetConfig+$targetConfig/}lib/lib*.so*" "''${!outputLib}" + moveToOutput "''${targetConfig+$targetConfig/}lib/lib*.la" "''${!outputLib}" + moveToOutput "''${targetConfig+$targetConfig/}lib/lib*.dylib" "''${!outputLib}" + moveToOutput "''${targetConfig+$targetConfig/}lib/lib*.dll.a" "''${!outputLib}" + moveToOutput "''${targetConfig+$targetConfig/}lib/lib*.dll" "''${!outputLib}" + moveToOutput "share/gcc-*/python" "''${!outputLib}" + + if [ -z "$enableShared" ]; then + moveToOutput "''${targetConfig+$targetConfig/}lib/lib*.a" "''${!outputLib}" + fi + + for i in "''${!outputLib}/''${targetConfig}"/lib/*.{la,py}; do + substituteInPlace "$i" --replace "$out" "''${!outputLib}" + done + + if [ -n "$enableMultilib" ]; then + moveToOutput "''${targetConfig+$targetConfig/}lib64/lib*.so*" "''${!outputLib}" + moveToOutput "''${targetConfig+$targetConfig/}lib64/lib*.la" "''${!outputLib}" + moveToOutput "''${targetConfig+$targetConfig/}lib64/lib*.dylib" "''${!outputLib}" + moveToOutput "''${targetConfig+$targetConfig/}lib64/lib*.dll.a" "''${!outputLib}" + moveToOutput "''${targetConfig+$targetConfig/}lib64/lib*.dll" "''${!outputLib}" + + for i in "''${!outputLib}/''${targetConfig}"/lib64/*.{la,py}; do + substituteInPlace "$i" --replace "$out" "''${!outputLib}" + done + fi + + # Remove `fixincl' to prevent a retained dependency on the + # previous gcc. + rm -rf $out/libexec/gcc/*/*/install-tools + rm -rf $out/lib/gcc/*/*/install-tools + + # More dependencies with the previous gcc or some libs (gccbug stores the build command line) + rm -rf $out/bin/gccbug + + if type "install_name_tool"; then + for i in "''${!outputLib}"/lib/*.*.dylib "''${!outputLib}"/lib/*.so.[0-9]; do + install_name_tool -id "$i" "$i" || true + for old_path in $(otool -L "$i" | grep "$out" | awk '{print $1}'); do + new_path=`echo "$old_path" | sed "s,$out,''${!outputLib},"` + install_name_tool -change "$old_path" "$new_path" "$i" || true + done + done + fi + + # Get rid of some "fixed" header files + rm -rfv $out/lib/gcc/*/*/include-fixed/{root,linux,sys/mount.h,bits/statx.h,pthread.h} + + # Replace hard links for i686-pc-linux-gnu-gcc etc. with symlinks. + for i in $out/bin/*-gcc*; do + if cmp -s $out/bin/gcc $i; then + ln -sfn gcc $i + fi + done + + for i in $out/bin/c++ $out/bin/*-c++* $out/bin/*-g++*; do + if cmp -s $out/bin/g++ $i; then + ln -sfn g++ $i + fi + done + + # Two identical man pages are shipped (moving and compressing is done later) + for i in "$out"/share/man/man1/*g++.1; do + if test -e "$i"; then + man_prefix=`echo "$i" | sed "s,.*/\(.*\)g++.1,\1,"` + ln -sf "$man_prefix"gcc.1 "$i" + fi + done + ''; + } +)) diff --git a/pkgs/development/compilers/gcc/common/checksum.nix b/pkgs/development/compilers/gcc/common/checksum.nix index 7a20ed1b8ba360..c0e59563a515dc 100644 --- a/pkgs/development/compilers/gcc/common/checksum.nix +++ b/pkgs/development/compilers/gcc/common/checksum.nix @@ -1,40 +1,51 @@ -{ lib -, stdenv -, nukeReferences -, langC -, langCC -, runtimeShell +{ + lib, + stdenv, + nukeReferences, + langC, + langCC, + runtimeShell, }: let - enableChecksum = (with stdenv; buildPlatform == hostPlatform && hostPlatform == targetPlatform) && langC && langCC && !stdenv.hostPlatform.isDarwin; + enableChecksum = + (with stdenv; buildPlatform == hostPlatform && hostPlatform == targetPlatform) + && langC + && langCC + && !stdenv.hostPlatform.isDarwin; in -(pkg: pkg.overrideAttrs (previousAttrs: lib.optionalAttrs enableChecksum { - outputs = previousAttrs.outputs ++ lib.optionals enableChecksum [ "checksum" ]; - # This is a separate phase because gcc assembles its phase scripts - # in bash instead of nix (we should fix that). - preFixupPhases = (previousAttrs.preFixupPhases or []) ++ [ "postInstallSaveChecksumPhase" ]; - # - # gcc uses an auxiliary utility `genchecksum` to md5-hash (most of) its - # `.o` and `.a` files prior to linking (in case the linker is - # nondeterministic). Since we want to compare across gccs built from two - # separate derivations, we wrap `genchecksum` with a `nuke-references` - # call. We also stash copies of the inputs to `genchecksum` in - # `$checksum/inputs/` -- this is extremely helpful for debugging since - # it's hard to get Nix to not delete the $NIX_BUILD_TOP of a successful - # build. - # - postInstallSaveChecksumPhase = '' - mv gcc/build/genchecksum gcc/build/.genchecksum-wrapped - cat > gcc/build/genchecksum <<\EOF - #!${runtimeShell} - ${nukeReferences}/bin/nuke-refs $@ - for INPUT in "$@"; do install -Dt $INPUT $checksum/inputs/; done - exec build/.genchecksum-wrapped $@ - EOF - chmod +x gcc/build/genchecksum - rm gcc/*-checksum.* - make -C gcc cc1-checksum.o cc1plus-checksum.o - install -Dt $checksum/checksums/ gcc/cc*-checksum.o - ''; -})) +( + pkg: + pkg.overrideAttrs ( + previousAttrs: + lib.optionalAttrs enableChecksum { + outputs = previousAttrs.outputs ++ lib.optionals enableChecksum [ "checksum" ]; + # This is a separate phase because gcc assembles its phase scripts + # in bash instead of nix (we should fix that). + preFixupPhases = (previousAttrs.preFixupPhases or [ ]) ++ [ "postInstallSaveChecksumPhase" ]; + # + # gcc uses an auxiliary utility `genchecksum` to md5-hash (most of) its + # `.o` and `.a` files prior to linking (in case the linker is + # nondeterministic). Since we want to compare across gccs built from two + # separate derivations, we wrap `genchecksum` with a `nuke-references` + # call. We also stash copies of the inputs to `genchecksum` in + # `$checksum/inputs/` -- this is extremely helpful for debugging since + # it's hard to get Nix to not delete the $NIX_BUILD_TOP of a successful + # build. + # + postInstallSaveChecksumPhase = '' + mv gcc/build/genchecksum gcc/build/.genchecksum-wrapped + cat > gcc/build/genchecksum <<\EOF + #!${runtimeShell} + ${nukeReferences}/bin/nuke-refs $@ + for INPUT in "$@"; do install -Dt $INPUT $checksum/inputs/; done + exec build/.genchecksum-wrapped $@ + EOF + chmod +x gcc/build/genchecksum + rm gcc/*-checksum.* + make -C gcc cc1-checksum.o cc1plus-checksum.o + install -Dt $checksum/checksums/ gcc/cc*-checksum.o + ''; + } + ) +) diff --git a/pkgs/development/compilers/gcc/common/dependencies.nix b/pkgs/development/compilers/gcc/common/dependencies.nix index f76b5fe601a96e..0e29fd51e45bb9 100644 --- a/pkgs/development/compilers/gcc/common/dependencies.nix +++ b/pkgs/development/compilers/gcc/common/dependencies.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, version -, buildPackages -, targetPackages -, texinfo -, which -, gettext -, gnused -, patchelf -, gmp -, mpfr -, libmpc -, libucontext ? null -, libxcrypt ? null -, darwin ? null -, isl ? null -, zlib ? null -, gnat-bootstrap ? null -, flex ? null -, perl ? null -, langAda ? false -, langGo ? false -, langRust ? false -, cargo -, withoutTargetLibc ? null -, threadsCross ? null +{ + lib, + stdenv, + version, + buildPackages, + targetPackages, + texinfo, + which, + gettext, + gnused, + patchelf, + gmp, + mpfr, + libmpc, + libucontext ? null, + libxcrypt ? null, + darwin ? null, + isl ? null, + zlib ? null, + gnat-bootstrap ? null, + flex ? null, + perl ? null, + langAda ? false, + langGo ? false, + langRust ? false, + cargo, + withoutTargetLibc ? null, + threadsCross ? null, }: let @@ -36,47 +37,55 @@ in # same for all gcc's depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ - texinfo - which - gettext - ] - ++ optionals (perl != null) [ perl ] - ++ optionals (with stdenv.targetPlatform; isVc4 || isRedox && flex != null) [ flex ] - ++ optionals langAda [ gnat-bootstrap ] - ++ optionals langRust [ cargo ] - # The builder relies on GNU sed (for instance, Darwin's `sed' fails with - # "-i may not be used with stdin"), and `stdenvNative' doesn't provide it. - ++ optionals buildPlatform.isDarwin [ gnused ] - ; + nativeBuildInputs = + [ + texinfo + which + gettext + ] + ++ optionals (perl != null) [ perl ] + ++ optionals (with stdenv.targetPlatform; isVc4 || isRedox && flex != null) [ flex ] + ++ optionals langAda [ gnat-bootstrap ] + ++ optionals langRust [ cargo ] + # The builder relies on GNU sed (for instance, Darwin's `sed' fails with + # "-i may not be used with stdin"), and `stdenvNative' doesn't provide it. + ++ optionals buildPlatform.isDarwin [ gnused ]; # For building runtime libs # same for all gcc's depsBuildTarget = ( - if hostPlatform == buildPlatform then [ - targetPackages.stdenv.cc.bintools # newly-built gcc will be used - ] else assert targetPlatform == hostPlatform; [ - # build != host == target - stdenv.cc - ] + if hostPlatform == buildPlatform then + [ + targetPackages.stdenv.cc.bintools # newly-built gcc will be used + ] + else + assert targetPlatform == hostPlatform; + [ + # build != host == target + stdenv.cc + ] ) ++ optionals targetPlatform.isLinux [ patchelf ]; - buildInputs = [ - gmp - mpfr - libmpc - ] - ++ optionals (lib.versionAtLeast version "10") [ libxcrypt ] - ++ [ - targetPackages.stdenv.cc.bintools # For linking code at run-time - ] - ++ optionals (isl != null) [ isl ] - ++ optionals (zlib != null) [ zlib ] - ++ optionals (langGo && stdenv.hostPlatform.isMusl) [ libucontext ] - ++ optionals (lib.versionAtLeast version "14" && stdenv.hostPlatform.isDarwin) [ darwin.apple_sdk.frameworks.CoreServices ] - ; + buildInputs = + [ + gmp + mpfr + libmpc + ] + ++ optionals (lib.versionAtLeast version "10") [ libxcrypt ] + ++ [ + targetPackages.stdenv.cc.bintools # For linking code at run-time + ] + ++ optionals (isl != null) [ isl ] + ++ optionals (zlib != null) [ zlib ] + ++ optionals (langGo && stdenv.hostPlatform.isMusl) [ libucontext ] + ++ optionals (lib.versionAtLeast version "14" && stdenv.hostPlatform.isDarwin) [ + darwin.apple_sdk.frameworks.CoreServices + ]; - depsTargetTarget = optionals (!withoutTargetLibc && threadsCross != { } && threadsCross.package != null) [ threadsCross.package ]; + depsTargetTarget = optionals ( + !withoutTargetLibc && threadsCross != { } && threadsCross.package != null + ) [ threadsCross.package ]; } diff --git a/pkgs/development/compilers/gcc/common/extra-target-flags.nix b/pkgs/development/compilers/gcc/common/extra-target-flags.nix index 30a24185e3b45d..de1f35f7f0fece 100644 --- a/pkgs/development/compilers/gcc/common/extra-target-flags.nix +++ b/pkgs/development/compilers/gcc/common/extra-target-flags.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, withoutTargetLibc, langD ? false, libcCross, threadsCross }: +{ + lib, + stdenv, + withoutTargetLibc, + langD ? false, + libcCross, + threadsCross, +}: let inherit (stdenv) hostPlatform targetPlatform; @@ -8,26 +15,42 @@ in # For non-cross builds these flags are currently assigned in builder.sh. # It would be good to consolidate the generation of makeFlags # ({C,CXX,LD}FLAGS_FOR_{BUILD,TARGET}, etc...) at some point. - EXTRA_FLAGS_FOR_TARGET = let - mkFlags = dep: langD: lib.optionals (targetPlatform != hostPlatform && dep != null && !langD) ([ - "-O2 -idirafter ${lib.getDev dep}${dep.incdir or "/include"}" - ] ++ lib.optionals (! withoutTargetLibc) [ - "-B${lib.getLib dep}${dep.libdir or "/lib"}" - ]); - in mkFlags libcCross langD - ++ lib.optionals (!withoutTargetLibc) (mkFlags (threadsCross.package or null) langD) - ; + EXTRA_FLAGS_FOR_TARGET = + let + mkFlags = + dep: langD: + lib.optionals (targetPlatform != hostPlatform && dep != null && !langD) ( + [ + "-O2 -idirafter ${lib.getDev dep}${dep.incdir or "/include"}" + ] + ++ lib.optionals (!withoutTargetLibc) [ + "-B${lib.getLib dep}${dep.libdir or "/lib"}" + ] + ); + in + mkFlags libcCross langD + ++ lib.optionals (!withoutTargetLibc) (mkFlags (threadsCross.package or null) langD); - EXTRA_LDFLAGS_FOR_TARGET = let - mkFlags = dep: lib.optionals (targetPlatform != hostPlatform && dep != null) ([ - "-Wl,-L${lib.getLib dep}${dep.libdir or "/lib"}" - ] ++ (if withoutTargetLibc then [ - "-B${lib.getLib dep}${dep.libdir or "/lib"}" - ] else [ - "-Wl,-rpath,${lib.getLib dep}${dep.libdir or "/lib"}" - "-Wl,-rpath-link,${lib.getLib dep}${dep.libdir or "/lib"}" - ])); - in mkFlags libcCross - ++ lib.optionals (!withoutTargetLibc) (mkFlags (threadsCross.package or null)) - ; + EXTRA_LDFLAGS_FOR_TARGET = + let + mkFlags = + dep: + lib.optionals (targetPlatform != hostPlatform && dep != null) ( + [ + "-Wl,-L${lib.getLib dep}${dep.libdir or "/lib"}" + ] + ++ ( + if withoutTargetLibc then + [ + "-B${lib.getLib dep}${dep.libdir or "/lib"}" + ] + else + [ + "-Wl,-rpath,${lib.getLib dep}${dep.libdir or "/lib"}" + "-Wl,-rpath-link,${lib.getLib dep}${dep.libdir or "/lib"}" + ] + ) + ); + in + mkFlags libcCross ++ lib.optionals (!withoutTargetLibc) (mkFlags (threadsCross.package or null)); } diff --git a/pkgs/development/compilers/gcc/common/libgcc-buildstuff.nix b/pkgs/development/compilers/gcc/common/libgcc-buildstuff.nix index 991efc20eee52c..5c72e0dbdf05d9 100644 --- a/pkgs/development/compilers/gcc/common/libgcc-buildstuff.nix +++ b/pkgs/development/compilers/gcc/common/libgcc-buildstuff.nix @@ -1,5 +1,6 @@ -{ lib -, stdenv +{ + lib, + stdenv, }: # Trick to build a gcc that is capable of emitting shared libraries *without* having the @@ -15,9 +16,7 @@ let # glibc. At this early pre-glibc stage these files sometimes # have different names. crtstuff-ofiles = - if stdenv.targetPlatform.isPower - then "ecrti.o ecrtn.o ncrti.o ncrtn.o" - else "crti.o crtn.o"; + if stdenv.targetPlatform.isPower then "ecrti.o ecrtn.o ncrti.o ncrtn.o" else "crti.o crtn.o"; # Normally, `SHLIB_LC` is set to `-lc`, which means that # `libgcc_s.so` cannot be built until `libc.so` is available. @@ -37,17 +36,22 @@ in echo 'SHLIB_LC=${SHLIB_LC}' >> libgcc/Makefile.in '' - # Meanwhile, crt{i,n}.S are not present on certain platforms - # (e.g. LoongArch64), resulting in the following error: - # - # No rule to make target '../../../gcc-xx.x.x/libgcc/config/loongarch/crti.S', needed by 'crti.o'. Stop. - # - # For LoongArch64 and S390, a hacky workaround is to simply touch them, - # as the platform forces .init_array support. - # - # https://www.openwall.com/lists/musl/2022/11/09/3 - # - # 'parsed.cpu.family' won't be correct for every platform. -+ lib.optionalString (stdenv.targetPlatform.isLoongArch64 || stdenv.targetPlatform.isS390 || stdenv.targetPlatform.isAlpha) '' - touch libgcc/config/${stdenv.targetPlatform.parsed.cpu.family}/crt{i,n}.S -'' +# Meanwhile, crt{i,n}.S are not present on certain platforms +# (e.g. LoongArch64), resulting in the following error: +# +# No rule to make target '../../../gcc-xx.x.x/libgcc/config/loongarch/crti.S', needed by 'crti.o'. Stop. +# +# For LoongArch64 and S390, a hacky workaround is to simply touch them, +# as the platform forces .init_array support. +# +# https://www.openwall.com/lists/musl/2022/11/09/3 +# +# 'parsed.cpu.family' won't be correct for every platform. ++ + lib.optionalString + ( + stdenv.targetPlatform.isLoongArch64 || stdenv.targetPlatform.isS390 || stdenv.targetPlatform.isAlpha + ) + '' + touch libgcc/config/${stdenv.targetPlatform.parsed.cpu.family}/crt{i,n}.S + '' diff --git a/pkgs/development/compilers/gcc/common/libgcc.nix b/pkgs/development/compilers/gcc/common/libgcc.nix index adb2974cc2d59d..3d4bd906776320 100644 --- a/pkgs/development/compilers/gcc/common/libgcc.nix +++ b/pkgs/development/compilers/gcc/common/libgcc.nix @@ -1,159 +1,180 @@ -{ lib -, stdenv -, version -, langC -, langCC -, langJit -, enableShared -, targetPlatform -, hostPlatform -, withoutTargetLibc -, libcCross +{ + lib, + stdenv, + version, + langC, + langCC, + langJit, + enableShared, + targetPlatform, + hostPlatform, + withoutTargetLibc, + libcCross, }: assert !stdenv.targetPlatform.hasSharedLibraries -> !enableShared; -drv: lib.pipe drv +drv: +lib.pipe drv -([ + ( + [ - (pkg: pkg.overrideAttrs (previousAttrs: - lib.optionalAttrs ( - targetPlatform != hostPlatform && - (enableShared || targetPlatform.isMinGW) && - withoutTargetLibc - ) { - makeFlags = [ "all-gcc" "all-target-libgcc" ]; - installTargets = "install-gcc install-target-libgcc"; - })) + ( + pkg: + pkg.overrideAttrs ( + previousAttrs: + lib.optionalAttrs + (targetPlatform != hostPlatform && (enableShared || targetPlatform.isMinGW) && withoutTargetLibc) + { + makeFlags = [ + "all-gcc" + "all-target-libgcc" + ]; + installTargets = "install-gcc install-target-libgcc"; + } + ) + ) -] ++ + ] + ++ -# nixpkgs did not add the "libgcc" output until gcc11. In theory -# the following condition can be changed to `true`, but that has not -# been tested. -lib.optionals (lib.versionAtLeast version "11.0") + # nixpkgs did not add the "libgcc" output until gcc11. In theory + # the following condition can be changed to `true`, but that has not + # been tested. + lib.optionals (lib.versionAtLeast version "11.0") -(let - targetPlatformSlash = - if hostPlatform == targetPlatform - then "" - else "${targetPlatform.config}/"; + ( + let + targetPlatformSlash = if hostPlatform == targetPlatform then "" else "${targetPlatform.config}/"; - # If we are building a cross-compiler and the target libc provided - # to us at build time has a libgcc, use that instead of building a - # new one. This avoids having two separate (but identical) libgcc - # outpaths in the closure of most packages, which can be confusing. - useLibgccFromTargetLibc = - libcCross != null && - libcCross?passthru.libgcc; + # If we are building a cross-compiler and the target libc provided + # to us at build time has a libgcc, use that instead of building a + # new one. This avoids having two separate (but identical) libgcc + # outpaths in the closure of most packages, which can be confusing. + useLibgccFromTargetLibc = libcCross != null && libcCross ? passthru.libgcc; - enableLibGccOutput = - (!stdenv.targetPlatform.isWindows || (with stdenv; targetPlatform == hostPlatform)) && - !langJit && - !stdenv.hostPlatform.isDarwin && - enableShared && - !useLibgccFromTargetLibc - ; + enableLibGccOutput = + (!stdenv.targetPlatform.isWindows || (with stdenv; targetPlatform == hostPlatform)) + && !langJit + && !stdenv.hostPlatform.isDarwin + && enableShared + && !useLibgccFromTargetLibc; - # For some reason libgcc_s.so has major-version "2" on m68k but - # "1" everywhere else. Might be worth changing this to "*". - libgcc_s-version-major = - if targetPlatform.isM68k - then "2" - else "1"; + # For some reason libgcc_s.so has major-version "2" on m68k but + # "1" everywhere else. Might be worth changing this to "*". + libgcc_s-version-major = if targetPlatform.isM68k then "2" else "1"; -in -[ + in + [ -(pkg: pkg.overrideAttrs (previousAttrs: lib.optionalAttrs useLibgccFromTargetLibc { - passthru = (previousAttrs.passthru or {}) // { - inherit (libcCross) libgcc; - }; -})) + ( + pkg: + pkg.overrideAttrs ( + previousAttrs: + lib.optionalAttrs useLibgccFromTargetLibc { + passthru = (previousAttrs.passthru or { }) // { + inherit (libcCross) libgcc; + }; + } + ) + ) -(pkg: pkg.overrideAttrs (previousAttrs: lib.optionalAttrs ((!langC) || langJit || enableLibGccOutput) { - outputs = previousAttrs.outputs ++ lib.optionals enableLibGccOutput [ "libgcc" ]; - # This is a separate phase because gcc assembles its phase scripts - # in bash instead of nix (we should fix that). - preFixupPhases = (previousAttrs.preFixupPhases or []) ++ lib.optionals ((!langC) || enableLibGccOutput) [ "preFixupLibGccPhase" ]; - preFixupLibGccPhase = - # delete extra/unused builds of libgcc_s in non-langC builds - # (i.e. libgccjit, gnat, etc) to avoid potential confusion - lib.optionalString (!langC) '' - rm -f $out/lib/libgcc_s.so* - '' + ( + pkg: + pkg.overrideAttrs ( + previousAttrs: + lib.optionalAttrs ((!langC) || langJit || enableLibGccOutput) { + outputs = previousAttrs.outputs ++ lib.optionals enableLibGccOutput [ "libgcc" ]; + # This is a separate phase because gcc assembles its phase scripts + # in bash instead of nix (we should fix that). + preFixupPhases = + (previousAttrs.preFixupPhases or [ ]) + ++ lib.optionals ((!langC) || enableLibGccOutput) [ "preFixupLibGccPhase" ]; + preFixupLibGccPhase = + # delete extra/unused builds of libgcc_s in non-langC builds + # (i.e. libgccjit, gnat, etc) to avoid potential confusion + lib.optionalString (!langC) '' + rm -f $out/lib/libgcc_s.so* + '' - # move `libgcc_s.so` into its own output, `$libgcc` - # We maintain $libgcc/lib/$target/ structure to make sure target - # strip runs over libgcc_s.so and remove debug references to headers: - # https://github.com/NixOS/nixpkgs/issues/316114 - + lib.optionalString enableLibGccOutput ('' - # move libgcc from lib to its own output (libgcc) - mkdir -p $libgcc/${targetPlatformSlash}lib - mv $lib/${targetPlatformSlash}lib/libgcc_s.so $libgcc/${targetPlatformSlash}lib/ - mv $lib/${targetPlatformSlash}lib/libgcc_s.so.${libgcc_s-version-major} $libgcc/${targetPlatformSlash}lib/ - ln -s $libgcc/${targetPlatformSlash}lib/libgcc_s.so $lib/${targetPlatformSlash}lib/ - ln -s $libgcc/${targetPlatformSlash}lib/libgcc_s.so.${libgcc_s-version-major} $lib/${targetPlatformSlash}lib/ - '' - + lib.optionalString (targetPlatformSlash != "") '' - ln -s ${targetPlatformSlash}lib $libgcc/lib - '' - # - # Nixpkgs ordinarily turns dynamic linking into pseudo-static linking: - # libraries are still loaded dynamically, exactly which copy of each - # library is loaded is permanently fixed at compile time (via RUNPATH). - # For libgcc_s we must revert to the "impure dynamic linking" style found - # in imperative software distributions. We must do this because - # `libgcc_s` calls `malloc()` and therefore has a `DT_NEEDED` for `libc`, - # which creates two problems: - # - # 1. A circular package dependency `glibc`<-`libgcc`<-`glibc` - # - # 2. According to the `-Wl,-rpath` flags added by Nixpkgs' `ld-wrapper`, - # the two versions of `glibc` in the cycle above are actually - # different packages. The later one is compiled by this `gcc`, but - # the earlier one was compiled by the compiler *that compiled* this - # `gcc` (usually the bootstrapFiles). In any event, the `glibc` - # dynamic loader won't honor that specificity without namespaced - # manual loads (`dlmopen()`). Once a `libc` is present in the address - # space of a process, that `libc` will be used to satisfy all - # `DT_NEEDED`s for `libc`, regardless of `RUNPATH`s. - # - # So we wipe the RUNPATH using `patchelf --set-rpath ""`. We can't use - # `patchelf --remove-rpath`, because at least as of patchelf 0.15.0 it - # will leave the old RUNPATH string in the file where the reference - # scanner can still find it: - # - # https://github.com/NixOS/patchelf/issues/453 - # - # Note: we might be using the bootstrapFiles' copy of patchelf, so we have - # to keep doing it this way until both the issue is fixed *and* all the - # bootstrapFiles are regenerated, on every platform. - # - # This patchelfing is *not* effectively equivalent to copying - # `libgcc_s` into `glibc`'s outpath. There is one minor and one - # major difference: - # - # 1. (Minor): multiple builds of `glibc` (say, with different - # overrides or parameters) will all reference a single store - # path: - # - # /nix/store/xxx...xxx-gcc-libgcc/lib/libgcc_s.so.1 - # - # This many-to-one referrer relationship will be visible in the store's - # dependency graph, and will be available to `nix-store -q` queries. - # Copying `libgcc_s` into each of its referrers would lose that - # information. - # - # 2. (Major): by referencing `libgcc_s.so.1`, rather than copying it, we - # are still able to run `nix-store -qd` on it to find out how it got - # built! Most importantly, we can see from that deriver which compiler - # was used to build it (or if it is part of the unpacked - # bootstrap-files). Copying `libgcc_s.so.1` from one outpath to - # another eliminates the ability to make these queries. - # - + '' - patchelf --set-rpath "" $libgcc/lib/libgcc_s.so.${libgcc_s-version-major} - ''); -}))])) + # move `libgcc_s.so` into its own output, `$libgcc` + # We maintain $libgcc/lib/$target/ structure to make sure target + # strip runs over libgcc_s.so and remove debug references to headers: + # https://github.com/NixOS/nixpkgs/issues/316114 + + lib.optionalString enableLibGccOutput ( + '' + # move libgcc from lib to its own output (libgcc) + mkdir -p $libgcc/${targetPlatformSlash}lib + mv $lib/${targetPlatformSlash}lib/libgcc_s.so $libgcc/${targetPlatformSlash}lib/ + mv $lib/${targetPlatformSlash}lib/libgcc_s.so.${libgcc_s-version-major} $libgcc/${targetPlatformSlash}lib/ + ln -s $libgcc/${targetPlatformSlash}lib/libgcc_s.so $lib/${targetPlatformSlash}lib/ + ln -s $libgcc/${targetPlatformSlash}lib/libgcc_s.so.${libgcc_s-version-major} $lib/${targetPlatformSlash}lib/ + '' + + lib.optionalString (targetPlatformSlash != "") '' + ln -s ${targetPlatformSlash}lib $libgcc/lib + '' + # + # Nixpkgs ordinarily turns dynamic linking into pseudo-static linking: + # libraries are still loaded dynamically, exactly which copy of each + # library is loaded is permanently fixed at compile time (via RUNPATH). + # For libgcc_s we must revert to the "impure dynamic linking" style found + # in imperative software distributions. We must do this because + # `libgcc_s` calls `malloc()` and therefore has a `DT_NEEDED` for `libc`, + # which creates two problems: + # + # 1. A circular package dependency `glibc`<-`libgcc`<-`glibc` + # + # 2. According to the `-Wl,-rpath` flags added by Nixpkgs' `ld-wrapper`, + # the two versions of `glibc` in the cycle above are actually + # different packages. The later one is compiled by this `gcc`, but + # the earlier one was compiled by the compiler *that compiled* this + # `gcc` (usually the bootstrapFiles). In any event, the `glibc` + # dynamic loader won't honor that specificity without namespaced + # manual loads (`dlmopen()`). Once a `libc` is present in the address + # space of a process, that `libc` will be used to satisfy all + # `DT_NEEDED`s for `libc`, regardless of `RUNPATH`s. + # + # So we wipe the RUNPATH using `patchelf --set-rpath ""`. We can't use + # `patchelf --remove-rpath`, because at least as of patchelf 0.15.0 it + # will leave the old RUNPATH string in the file where the reference + # scanner can still find it: + # + # https://github.com/NixOS/patchelf/issues/453 + # + # Note: we might be using the bootstrapFiles' copy of patchelf, so we have + # to keep doing it this way until both the issue is fixed *and* all the + # bootstrapFiles are regenerated, on every platform. + # + # This patchelfing is *not* effectively equivalent to copying + # `libgcc_s` into `glibc`'s outpath. There is one minor and one + # major difference: + # + # 1. (Minor): multiple builds of `glibc` (say, with different + # overrides or parameters) will all reference a single store + # path: + # + # /nix/store/xxx...xxx-gcc-libgcc/lib/libgcc_s.so.1 + # + # This many-to-one referrer relationship will be visible in the store's + # dependency graph, and will be available to `nix-store -q` queries. + # Copying `libgcc_s` into each of its referrers would lose that + # information. + # + # 2. (Major): by referencing `libgcc_s.so.1`, rather than copying it, we + # are still able to run `nix-store -qd` on it to find out how it got + # built! Most importantly, we can see from that deriver which compiler + # was used to build it (or if it is part of the unpacked + # bootstrap-files). Copying `libgcc_s.so.1` from one outpath to + # another eliminates the ability to make these queries. + # + + '' + patchelf --set-rpath "" $libgcc/lib/libgcc_s.so.${libgcc_s-version-major} + '' + ); + } + ) + ) + ] + ) + ) diff --git a/pkgs/development/compilers/gcc/common/meta.nix b/pkgs/development/compilers/gcc/common/meta.nix index 4e864f95a61149..f9af92746f0bf3 100644 --- a/pkgs/development/compilers/gcc/common/meta.nix +++ b/pkgs/development/compilers/gcc/common/meta.nix @@ -1,4 +1,4 @@ -{ lib, version, }: +{ lib, version }: let inherit (lib) diff --git a/pkgs/development/compilers/gcc/common/platform-flags.nix b/pkgs/development/compilers/gcc/common/platform-flags.nix index 9bcdb3070d6b97..7c1a04435076b8 100644 --- a/pkgs/development/compilers/gcc/common/platform-flags.nix +++ b/pkgs/development/compilers/gcc/common/platform-flags.nix @@ -2,15 +2,17 @@ let isAarch64Darwin = targetPlatform.isDarwin && targetPlatform.isAarch64; - gcc = targetPlatform.gcc or {}; - p = gcc - // targetPlatform.parsed.abi; -in lib.concatLists [ + gcc = targetPlatform.gcc or { }; + p = gcc // targetPlatform.parsed.abi; +in +lib.concatLists [ # --with-arch= is unknown flag on x86_64 and aarch64-darwin. (lib.optional (!targetPlatform.isx86_64 && !isAarch64Darwin && p ? arch) "--with-arch=${p.arch}") # See supported_defaults in gcc/config.gcc for architecture support. # --with-cpu on aarch64-darwin fails with "Unknown cpu used in --with-cpu=apple-a13". - (lib.optional (with targetPlatform; !isLoongArch64 && !isMips && !isRiscV && !isS390 && !isAarch64Darwin && p ? cpu) "--with-cpu=${p.cpu}") + (lib.optional ( + with targetPlatform; !isLoongArch64 && !isMips && !isRiscV && !isS390 && !isAarch64Darwin && p ? cpu + ) "--with-cpu=${p.cpu}") (lib.optional (p ? abi) "--with-abi=${p.abi}") (lib.optional (p ? fpu) "--with-fpu=${p.fpu}") (lib.optional (p ? float) "--with-float=${p.float}") @@ -18,16 +20,28 @@ in lib.concatLists [ (lib.optionals targetPlatform.isPower64 # musl explicitly rejects 128-bit long double on # powerpc64; see musl/arch/powerpc64/bits/float.h - (lib.optionals - (!targetPlatform.isMusl - && (targetPlatform.isLittleEndian || - # "... --with-long-double-format is only supported if the default cpu is power7 or newer" - # https://github.com/NixOS/nixpkgs/pull/170215#issuecomment-1202164709 - (lib.lists.elem - (lib.strings.substring 0 6 (p.cpu or "")) - [ "power7" "power8" "power9" "power1"/*0, 11, etc*/ ]))) [ - "--with-long-double-128" - "--with-long-double-format=${gcc.long-double-format or "ieee"}" - ])) + ( + lib.optionals + ( + !targetPlatform.isMusl + && ( + targetPlatform.isLittleEndian + || + # "... --with-long-double-format is only supported if the default cpu is power7 or newer" + # https://github.com/NixOS/nixpkgs/pull/170215#issuecomment-1202164709 + (lib.lists.elem (lib.strings.substring 0 6 (p.cpu or "")) [ + "power7" + "power8" + "power9" + "power1" # 0, 11, etc + ]) + ) + ) + [ + "--with-long-double-128" + "--with-long-double-format=${gcc.long-double-format or "ieee"}" + ] + ) + ) (lib.optional targetPlatform.isMips64n32 "--disable-libsanitizer") # libsanitizer does not compile on mips64n32 ] diff --git a/pkgs/development/compilers/gcc/common/pre-configure.nix b/pkgs/development/compilers/gcc/common/pre-configure.nix index 9e1764eae916e4..ca64ac375ca35a 100644 --- a/pkgs/development/compilers/gcc/common/pre-configure.nix +++ b/pkgs/development/compilers/gcc/common/pre-configure.nix @@ -1,15 +1,19 @@ -{ lib -, stdenv -, version, buildPlatform, hostPlatform, targetPlatform -, gnat-bootstrap ? null -, langAda ? false -, langFortran -, langJit ? false -, langGo -, withoutTargetLibc -, enableShared -, enableMultilib -, pkgsBuildTarget +{ + lib, + stdenv, + version, + buildPlatform, + hostPlatform, + targetPlatform, + gnat-bootstrap ? null, + langAda ? false, + langFortran, + langJit ? false, + langGo, + withoutTargetLibc, + enableShared, + enableMultilib, + pkgsBuildTarget, }: assert langAda -> gnat-bootstrap != null; @@ -19,7 +23,8 @@ lib.optionalString (hostPlatform.isSunOS && hostPlatform.is64bit) '' export LDFLAGS_FOR_TARGET="-Wl,-rpath,$prefix/lib/amd64 $LDFLAGS_FOR_TARGET" export CXXFLAGS_FOR_TARGET="-Wl,-rpath,$prefix/lib/amd64 $CXXFLAGS_FOR_TARGET" export CFLAGS_FOR_TARGET="-Wl,-rpath,$prefix/lib/amd64 $CFLAGS_FOR_TARGET" -'' + lib.optionalString langAda '' +'' ++ lib.optionalString langAda '' export PATH=${gnat-bootstrap}/bin:$PATH '' @@ -28,9 +33,12 @@ lib.optionalString (hostPlatform.isSunOS && hostPlatform.is64bit) '' # buildPlatform and emit code for the targetPlatform. The compiler # which is built alongside gfortran in this configuration doesn't # meet that need: it runs on the hostPlatform. -+ lib.optionalString (langFortran && (with stdenv; buildPlatform != hostPlatform && hostPlatform == targetPlatform)) '' - export GFORTRAN_FOR_TARGET=${pkgsBuildTarget.gfortran}/bin/${stdenv.targetPlatform.config}-gfortran -'' ++ + lib.optionalString + (langFortran && (with stdenv; buildPlatform != hostPlatform && hostPlatform == targetPlatform)) + '' + export GFORTRAN_FOR_TARGET=${pkgsBuildTarget.gfortran}/bin/${stdenv.targetPlatform.config}-gfortran + '' # NOTE 2020/3/18: This environment variable prevents configure scripts from # detecting the presence of aligned_alloc on Darwin. There are many facts that @@ -61,11 +69,13 @@ lib.optionalString (hostPlatform.isSunOS && hostPlatform.is64bit) '' # compilation even if the configure scripts did not check header presence. # + lib.optionalString (buildPlatform.isDarwin) '' - export build_configargs=ac_cv_func_aligned_alloc=no -'' + lib.optionalString (hostPlatform.isDarwin) '' - export host_configargs=ac_cv_func_aligned_alloc=no -'' + lib.optionalString (targetPlatform.isDarwin) '' - export target_configargs=ac_cv_func_aligned_alloc=no + export build_configargs=ac_cv_func_aligned_alloc=no +'' ++ lib.optionalString (hostPlatform.isDarwin) '' + export host_configargs=ac_cv_func_aligned_alloc=no +'' ++ lib.optionalString (targetPlatform.isDarwin) '' + export target_configargs=ac_cv_func_aligned_alloc=no '' # In order to properly install libgccjit on macOS Catalina, strip(1) @@ -79,20 +89,26 @@ lib.optionalString (hostPlatform.isSunOS && hostPlatform.is64bit) '' # HACK: if host and target config are the same, but the platforms are # actually different we need to convince the configure script that it # is in fact building a cross compiler although it doesn't believe it. -+ lib.optionalString (targetPlatform.config == hostPlatform.config && targetPlatform != hostPlatform) '' - substituteInPlace configure --replace is_cross_compiler=no is_cross_compiler=yes -'' ++ + lib.optionalString (targetPlatform.config == hostPlatform.config && targetPlatform != hostPlatform) + '' + substituteInPlace configure --replace is_cross_compiler=no is_cross_compiler=yes + '' # Normally (for host != target case) --without-headers automatically # enables 'inhibit_libc=true' in gcc's gcc/configure.ac. But case of # gcc->clang or dynamic->static "cross"-compilation manages to evade it: there # hostPlatform != targetPlatform, hostPlatform.config == targetPlatform.config. # We explicitly inhibit libc headers use in this case as well. -+ lib.optionalString (targetPlatform != hostPlatform && - withoutTargetLibc && - targetPlatform.config == hostPlatform.config) '' - export inhibit_libc=true -'' ++ + lib.optionalString + ( + targetPlatform != hostPlatform && withoutTargetLibc && targetPlatform.config == hostPlatform.config + ) + '' + export inhibit_libc=true + '' -+ lib.optionalString (targetPlatform != hostPlatform && withoutTargetLibc && enableShared) - (import ./libgcc-buildstuff.nix { inherit lib stdenv; }) ++ lib.optionalString (targetPlatform != hostPlatform && withoutTargetLibc && enableShared) ( + import ./libgcc-buildstuff.nix { inherit lib stdenv; } +) diff --git a/pkgs/development/compilers/gcc/common/strip-attributes.nix b/pkgs/development/compilers/gcc/common/strip-attributes.nix index f2f0efb1264a93..3871d846649595 100644 --- a/pkgs/development/compilers/gcc/common/strip-attributes.nix +++ b/pkgs/development/compilers/gcc/common/strip-attributes.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, langJit }: +{ + lib, + stdenv, + langJit, +}: { # Note [Cross-compiler stripping] @@ -29,42 +33,51 @@ # The rest of stripDebugList{Host,Target} will be populated in # postInstall to disambiguate lib/ object files. - stripDebugList = [ "bin" "libexec" ]; + stripDebugList = [ + "bin" + "libexec" + ]; stripDebugListTarget = [ stdenv.targetPlatform.config ]; - preFixup = '' - # Populate most delicated lib/ part of stripDebugList{,Target} - updateDebugListPaths() { - local oldOpts - oldOpts="$(shopt -p nullglob)" || true - shopt -s nullglob + preFixup = + '' + # Populate most delicated lib/ part of stripDebugList{,Target} + updateDebugListPaths() { + local oldOpts + oldOpts="$(shopt -p nullglob)" || true + shopt -s nullglob - pushd $out - local -ar outHostFiles=( - lib{,32,64}/*.{a,o,so*} - lib{,32,64}/gcc/${stdenv.targetPlatform.config}/*/plugin - ) - local -ar outTargetFiles=( - lib{,32,64}/gcc/${stdenv.targetPlatform.config}/*/*.{a,o,so*} - ) - popd - '' + lib.optionalString (!langJit) '' - ${/*keep indentation*/ ""} - pushd $lib - local -ar libHostFiles=( - lib{,32,64}/*.{a,o,so*} - ) - local -ar libTargetFiles=( - lib{,32,64}/${stdenv.targetPlatform.config}/*.{a,o,so*} - ) - popd + pushd $out + local -ar outHostFiles=( + lib{,32,64}/*.{a,o,so*} + lib{,32,64}/gcc/${stdenv.targetPlatform.config}/*/plugin + ) + local -ar outTargetFiles=( + lib{,32,64}/gcc/${stdenv.targetPlatform.config}/*/*.{a,o,so*} + ) + popd + '' + + lib.optionalString (!langJit) '' + ${ + # keep indentation + "" + } + pushd $lib + local -ar libHostFiles=( + lib{,32,64}/*.{a,o,so*} + ) + local -ar libTargetFiles=( + lib{,32,64}/${stdenv.targetPlatform.config}/*.{a,o,so*} + ) + popd - '' + '' - eval "$oldOpts" + '' + + '' + eval "$oldOpts" - stripDebugList="$stripDebugList ''${outHostFiles[*]} ''${libHostFiles[*]}" - stripDebugListTarget="$stripDebugListTarget ''${outTargetFiles[*]} ''${libTargetFiles[*]}" - } - updateDebugListPaths - ''; + stripDebugList="$stripDebugList ''${outHostFiles[*]} ''${libHostFiles[*]}" + stripDebugListTarget="$stripDebugListTarget ''${outTargetFiles[*]} ''${libTargetFiles[*]}" + } + updateDebugListPaths + ''; } diff --git a/pkgs/development/compilers/gcc/patches/default.nix b/pkgs/development/compilers/gcc/patches/default.nix index c9989f4c1e0b30..657a0f87697829 100644 --- a/pkgs/development/compilers/gcc/patches/default.nix +++ b/pkgs/development/compilers/gcc/patches/default.nix @@ -1,27 +1,29 @@ -{ lib, stdenv -, langC -, langAda -, langObjC -, langObjCpp -, langD -, langFortran -, langGo -, reproducibleBuild -, profiledCompiler -, langJit -, staticCompiler -, enableShared -, enableLTO -, version -, fetchpatch -, majorVersion -, targetPlatform -, hostPlatform -, noSysDirs -, buildPlatform -, fetchurl -, withoutTargetLibc -, threadsCross +{ + lib, + stdenv, + langC, + langAda, + langObjC, + langObjCpp, + langD, + langFortran, + langGo, + reproducibleBuild, + profiledCompiler, + langJit, + staticCompiler, + enableShared, + enableLTO, + version, + fetchpatch, + majorVersion, + targetPlatform, + hostPlatform, + noSysDirs, + buildPlatform, + fetchurl, + withoutTargetLibc, + threadsCross, }: let @@ -35,7 +37,7 @@ let is12 = majorVersion == "12"; is11 = majorVersion == "11"; is10 = majorVersion == "10"; - is9 = majorVersion == "9"; + is9 = majorVersion == "9"; inherit (lib) optionals optional; in @@ -46,30 +48,41 @@ in # 3. Patches relevant only to gcc<12 # - ## 1. Patches relevant to gcc>=12 on every platform #################################### -[] +[ ] ++ optional (!atLeast12) ./fix-bug-80431.patch ++ optional (targetPlatform != hostPlatform) ./libstdc++-target.patch ++ optionals (noSysDirs) ( - [(if atLeast12 then ./gcc-12-no-sys-dirs.patch else ./no-sys-dirs.patch)] ++ - ({ - "14" = [ ./13/no-sys-dirs-riscv.patch ./13/mangle-NIX_STORE-in-__FILE__.patch ]; - "13" = [ ./13/no-sys-dirs-riscv.patch ./13/mangle-NIX_STORE-in-__FILE__.patch ]; - "12" = [ ./no-sys-dirs-riscv.patch ./12/mangle-NIX_STORE-in-__FILE__.patch ]; - "11" = [ ./no-sys-dirs-riscv.patch ]; - "10" = [ ./no-sys-dirs-riscv.patch ]; - "9" = [ ./no-sys-dirs-riscv-gcc9.patch ]; - }."${majorVersion}" or []) + [ (if atLeast12 then ./gcc-12-no-sys-dirs.patch else ./no-sys-dirs.patch) ] + ++ ( + { + "14" = [ + ./13/no-sys-dirs-riscv.patch + ./13/mangle-NIX_STORE-in-__FILE__.patch + ]; + "13" = [ + ./13/no-sys-dirs-riscv.patch + ./13/mangle-NIX_STORE-in-__FILE__.patch + ]; + "12" = [ + ./no-sys-dirs-riscv.patch + ./12/mangle-NIX_STORE-in-__FILE__.patch + ]; + "11" = [ ./no-sys-dirs-riscv.patch ]; + "10" = [ ./no-sys-dirs-riscv.patch ]; + "9" = [ ./no-sys-dirs-riscv-gcc9.patch ]; + } + ."${majorVersion}" or [ ] + ) ) ++ optional (atLeast12 && langAda) ./gnat-cflags-11.patch -++ optional langFortran (if atLeast12 then ./gcc-12-gfortran-driving.patch else ./gfortran-driving.patch) +++ optional langFortran ( + if atLeast12 then ./gcc-12-gfortran-driving.patch else ./gfortran-driving.patch +) ++ [ ./ppc-musl.patch ] ++ optional langD ./libphobos.patch - - ## 2. Patches relevant to gcc>=12 on specific platforms #################################### ### Musl+Go+gcc12 @@ -112,73 +125,102 @@ in }) ] - ## Darwin # Fixes detection of Darwin on x86_64-darwin. Otherwise, GCC uses a deployment target of 10.5, which crashes ld64. -++ optional (atLeast14 && stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) ../patches/14/libgcc-darwin-detection.patch +++ optional ( + atLeast14 && stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64 +) ../patches/14/libgcc-darwin-detection.patch # Fix detection of bootstrap compiler Ada support (cctools as) on Nix Darwin -++ optional (atLeast12 && stdenv.hostPlatform.isDarwin && langAda) ./ada-cctools-as-detection-configure.patch +++ optional ( + atLeast12 && stdenv.hostPlatform.isDarwin && langAda +) ./ada-cctools-as-detection-configure.patch # Remove CoreServices on Darwin, as it is only needed for macOS SDK 14+ -++ optional (atLeast14 && stdenv.hostPlatform.isDarwin && langAda) ../patches/14/gcc-darwin-remove-coreservices.patch +++ optional ( + atLeast14 && stdenv.hostPlatform.isDarwin && langAda +) ../patches/14/gcc-darwin-remove-coreservices.patch # Use absolute path in GNAT dylib install names on Darwin -++ optionals (stdenv.hostPlatform.isDarwin && langAda) ({ - "14" = [ ../patches/14/gnat-darwin-dylib-install-name-14.patch ]; - "13" = [ ./gnat-darwin-dylib-install-name-13.patch ]; - "12" = [ ./gnat-darwin-dylib-install-name.patch ]; -}.${majorVersion} or []) +++ optionals (stdenv.hostPlatform.isDarwin && langAda) ( + { + "14" = [ ../patches/14/gnat-darwin-dylib-install-name-14.patch ]; + "13" = [ ./gnat-darwin-dylib-install-name-13.patch ]; + "12" = [ ./gnat-darwin-dylib-install-name.patch ]; + } + .${majorVersion} or [ ] +) # We only apply this patch when building a native toolchain for aarch64-darwin, as it breaks building # a foreign one: https://github.com/iains/gcc-12-branch/issues/18 -++ optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 && buildPlatform == hostPlatform && hostPlatform == targetPlatform) ({ - "14" = [ (fetchpatch { - # There are no upstream release tags in https://github.com/iains/gcc-14-branch. - # 04696df09633baf97cdbbdd6e9929b9d472161d3 is the commit from https://github.com/gcc-mirror/gcc/releases/tag/releases%2Fgcc-14.2.0 - name = "gcc-14-darwin-aarch64-support.patch"; - url = "https://github.com/iains/gcc-14-branch/compare/04696df09633baf97cdbbdd6e9929b9d472161d3..gcc-14.2-darwin-r0.diff"; - hash = "sha256-GEUz7KdGzd2WJ0gjX3Uddq2y9bWKdZpT3E9uZ09qLs4="; - }) ]; - "13" = [ (fetchpatch { - name = "gcc-13-darwin-aarch64-support.patch"; - url = "https://raw.githubusercontent.com/Homebrew/formula-patches/bda0faddfbfb392e7b9c9101056b2c5ab2500508/gcc/gcc-13.3.0.diff"; - sha256 = "sha256-RBTCBXIveGwuQGJLzMW/UexpUZdDgdXprp/G2NHkmQo="; - }) ]; - "12" = [ (fetchurl { - name = "gcc-12-darwin-aarch64-support.patch"; - url = "https://raw.githubusercontent.com/Homebrew/formula-patches/1ed9eaea059f1677d27382c62f21462b476b37fe/gcc/gcc-12.4.0.diff"; - sha256 = "sha256-wOjpT79lps4TKG5/E761odhLGCphBIkCbOPiQg/D1Fw="; - }) ]; - "11" = [ (fetchpatch { - # There are no upstream release tags in https://github.com/iains/gcc-11-branch. - # 5cc4c42a0d4de08715c2eef8715ad5b2e92a23b6 is the commit from https://github.com/gcc-mirror/gcc/releases/tag/releases%2Fgcc-11.5.0 - url = "https://github.com/iains/gcc-11-branch/compare/5cc4c42a0d4de08715c2eef8715ad5b2e92a23b6..gcc-11.5-darwin-r0.diff"; - hash = "sha256-7lH+GkgkrE6nOp9PMdIoqlQNWK31s6oW+lDt1LIkadE="; - }) ]; - "10" = [ (fetchpatch { - # There are no upstream release tags in https://github.com/iains/gcc-10-branch. - # d04fe55 is the commit from https://github.com/gcc-mirror/gcc/releases/tag/releases%2Fgcc-10.5.0 - url = "https://github.com/iains/gcc-10-branch/compare/d04fe5541c53cb16d1ca5c80da044b4c7633dbc6...gcc-10-5Dr0-pre-0.diff"; - hash = "sha256-kVUHZKtYqkWIcqxHG7yAOR2B60w4KWLoxzaiFD/FWYk="; - }) ]; -}.${majorVersion} or []) +++ + optionals + ( + stdenv.hostPlatform.isDarwin + && stdenv.hostPlatform.isAarch64 + && buildPlatform == hostPlatform + && hostPlatform == targetPlatform + ) + ( + { + "14" = [ + (fetchpatch { + # There are no upstream release tags in https://github.com/iains/gcc-14-branch. + # 04696df09633baf97cdbbdd6e9929b9d472161d3 is the commit from https://github.com/gcc-mirror/gcc/releases/tag/releases%2Fgcc-14.2.0 + name = "gcc-14-darwin-aarch64-support.patch"; + url = "https://github.com/iains/gcc-14-branch/compare/04696df09633baf97cdbbdd6e9929b9d472161d3..gcc-14.2-darwin-r0.diff"; + hash = "sha256-GEUz7KdGzd2WJ0gjX3Uddq2y9bWKdZpT3E9uZ09qLs4="; + }) + ]; + "13" = [ + (fetchpatch { + name = "gcc-13-darwin-aarch64-support.patch"; + url = "https://raw.githubusercontent.com/Homebrew/formula-patches/bda0faddfbfb392e7b9c9101056b2c5ab2500508/gcc/gcc-13.3.0.diff"; + sha256 = "sha256-RBTCBXIveGwuQGJLzMW/UexpUZdDgdXprp/G2NHkmQo="; + }) + ]; + "12" = [ + (fetchurl { + name = "gcc-12-darwin-aarch64-support.patch"; + url = "https://raw.githubusercontent.com/Homebrew/formula-patches/1ed9eaea059f1677d27382c62f21462b476b37fe/gcc/gcc-12.4.0.diff"; + sha256 = "sha256-wOjpT79lps4TKG5/E761odhLGCphBIkCbOPiQg/D1Fw="; + }) + ]; + "11" = [ + (fetchpatch { + # There are no upstream release tags in https://github.com/iains/gcc-11-branch. + # 5cc4c42a0d4de08715c2eef8715ad5b2e92a23b6 is the commit from https://github.com/gcc-mirror/gcc/releases/tag/releases%2Fgcc-11.5.0 + url = "https://github.com/iains/gcc-11-branch/compare/5cc4c42a0d4de08715c2eef8715ad5b2e92a23b6..gcc-11.5-darwin-r0.diff"; + hash = "sha256-7lH+GkgkrE6nOp9PMdIoqlQNWK31s6oW+lDt1LIkadE="; + }) + ]; + "10" = [ + (fetchpatch { + # There are no upstream release tags in https://github.com/iains/gcc-10-branch. + # d04fe55 is the commit from https://github.com/gcc-mirror/gcc/releases/tag/releases%2Fgcc-10.5.0 + url = "https://github.com/iains/gcc-10-branch/compare/d04fe5541c53cb16d1ca5c80da044b4c7633dbc6...gcc-10-5Dr0-pre-0.diff"; + hash = "sha256-kVUHZKtYqkWIcqxHG7yAOR2B60w4KWLoxzaiFD/FWYk="; + }) + ]; + } + .${majorVersion} or [ ] + ) # Work around newer AvailabilityInternal.h when building older versions of GCC. -++ optionals (stdenv.hostPlatform.isDarwin) ({ - "9" = [ ../patches/9/AvailabilityInternal.h-fixincludes.patch ]; -}.${majorVersion} or []) - +++ optionals (stdenv.hostPlatform.isDarwin) ( + { + "9" = [ ../patches/9/AvailabilityInternal.h-fixincludes.patch ]; + } + .${majorVersion} or [ ] +) ## Windows # Obtain latest patch with ../update-mcfgthread-patches.sh -++ optional (!atLeast13 && !withoutTargetLibc && targetPlatform.isMinGW && threadsCross.model == "mcf") - (./. + "/${majorVersion}/Added-mcf-thread-model-support-from-mcfgthread.patch") - - - +++ optional ( + !atLeast13 && !withoutTargetLibc && targetPlatform.isMinGW && threadsCross.model == "mcf" +) (./. + "/${majorVersion}/Added-mcf-thread-model-support-from-mcfgthread.patch") ############################################################################## ## @@ -190,27 +232,25 @@ in ## ############################################################################## - - - ## gcc 11.0 and older ############################################################################## # openjdk build fails without this on -march=opteron; is upstream in gcc12 ++ optionals (is11) [ ./11/gcc-issue-103910.patch ] - - ## gcc 10.0 and older ############################################################################## ++ optional (langAda && (is9 || is10)) ./gnat-cflags.patch -++ optional (is10 && buildPlatform.system == "aarch64-darwin" && targetPlatform != buildPlatform) (fetchpatch { - url = "https://raw.githubusercontent.com/richard-vd/musl-cross-make/5e9e87f06fc3220e102c29d3413fbbffa456fcd6/patches/gcc-${version}/0008-darwin-aarch64-self-host-driver.patch"; - sha256 = "sha256-XtykrPd5h/tsnjY1wGjzSOJ+AyyNLsfnjuOZ5Ryq9vA="; -}) +++ + optional (is10 && buildPlatform.system == "aarch64-darwin" && targetPlatform != buildPlatform) + (fetchpatch { + url = "https://raw.githubusercontent.com/richard-vd/musl-cross-make/5e9e87f06fc3220e102c29d3413fbbffa456fcd6/patches/gcc-${version}/0008-darwin-aarch64-self-host-driver.patch"; + sha256 = "sha256-XtykrPd5h/tsnjY1wGjzSOJ+AyyNLsfnjuOZ5Ryq9vA="; + }) # Fix undefined symbol errors when building older versions with clang -++ optional (!atLeast11 && stdenv.cc.isClang && stdenv.hostPlatform.isDarwin) ./clang-genconditions.patch - +++ optional ( + !atLeast11 && stdenv.cc.isClang && stdenv.hostPlatform.isDarwin +) ./clang-genconditions.patch ## gcc 9.0 and older ############################################################################## diff --git a/pkgs/development/compilers/gcc/versions.nix b/pkgs/development/compilers/gcc/versions.nix index 87ebf0681299cc..bbd32c21e9608f 100644 --- a/pkgs/development/compilers/gcc/versions.nix +++ b/pkgs/development/compilers/gcc/versions.nix @@ -5,23 +5,26 @@ let "12" = "12.4.0"; "11" = "11.5.0"; "10" = "10.5.0"; - "9" = "9.5.0"; + "9" = "9.5.0"; }; - fromMajorMinor = majorMinorVersion: - majorMinorToVersionMap."${majorMinorVersion}"; + fromMajorMinor = majorMinorVersion: majorMinorToVersionMap."${majorMinorVersion}"; # TODO(amjoseph): convert older hashes to SRI form - srcHashForVersion = version: { - "14.2.0" = "sha256-p7Obxpy/niWCbFpgqyZHcAH3wI2FzsBLwOKcq+1vPMk="; - "13.3.0" = "sha256-CEXpYhyVQ6E/SE6UWEpJ/8ASmXDpkUYkI1/B0GGgwIM="; - "12.4.0" = "sha256-cE9lJgTMvMsUvavzR4yVEciXiLEss7v/3tNzQZFqkXU="; - "11.5.0" = "sha256-puIYaOrVRc+H8MAfhCduS1KB1nIJhZHByJYkHwk2NHg="; - "10.5.0" = "sha256-JRCVQ/30bzl8NHtdi3osflaUpaUczkucbh6opxyjB8E="; - "9.5.0" = "13ygjmd938m0wmy946pxdhz9i1wq7z4w10l6pvidak0xxxj9yxi7"; - }."${version}"; + srcHashForVersion = + version: + { + "14.2.0" = "sha256-p7Obxpy/niWCbFpgqyZHcAH3wI2FzsBLwOKcq+1vPMk="; + "13.3.0" = "sha256-CEXpYhyVQ6E/SE6UWEpJ/8ASmXDpkUYkI1/B0GGgwIM="; + "12.4.0" = "sha256-cE9lJgTMvMsUvavzR4yVEciXiLEss7v/3tNzQZFqkXU="; + "11.5.0" = "sha256-puIYaOrVRc+H8MAfhCduS1KB1nIJhZHByJYkHwk2NHg="; + "10.5.0" = "sha256-JRCVQ/30bzl8NHtdi3osflaUpaUczkucbh6opxyjB8E="; + "9.5.0" = "13ygjmd938m0wmy946pxdhz9i1wq7z4w10l6pvidak0xxxj9yxi7"; + } + ."${version}"; -in { +in +{ inherit fromMajorMinor; inherit srcHashForVersion; allMajorVersions = builtins.attrNames majorMinorToVersionMap; diff --git a/pkgs/development/compilers/gcl/default.nix b/pkgs/development/compilers/gcl/default.nix index 64d36ea67a73c8..60005607263176 100644 --- a/pkgs/development/compilers/gcl/default.nix +++ b/pkgs/development/compilers/gcl/default.nix @@ -1,11 +1,28 @@ -{ lib, stdenv, fetchurl, mpfr, m4, binutils, emacs, zlib, which -, texinfo, libX11, xorgproto, libXi, gmp -, libXext, libXt, libXaw, libXmu } : +{ + lib, + stdenv, + fetchurl, + mpfr, + m4, + binutils, + emacs, + zlib, + which, + texinfo, + libX11, + xorgproto, + libXi, + gmp, + libXext, + libXt, + libXaw, + libXmu, +}: -assert stdenv ? cc ; -assert stdenv.cc.isGNU ; -assert stdenv.cc ? libc ; -assert stdenv.cc.libc != null ; +assert stdenv ? cc; +assert stdenv.cc.isGNU; +assert stdenv.cc ? libc; +assert stdenv.cc.libc != null; stdenv.mkDerivation rec { pname = "gcl"; @@ -17,10 +34,21 @@ stdenv.mkDerivation rec { }; buildInputs = [ - mpfr m4 binutils emacs gmp - libX11 xorgproto libXi - libXext libXt libXaw libXmu - zlib which texinfo + mpfr + m4 + binutils + emacs + gmp + libX11 + xorgproto + libXi + libXext + libXt + libXaw + libXmu + zlib + which + texinfo ]; configureFlags = [ diff --git a/pkgs/development/compilers/gerbil/build.nix b/pkgs/development/compilers/gerbil/build.nix index 5ed7339c31beb6..26808377b1ac50 100644 --- a/pkgs/development/compilers/gerbil/build.nix +++ b/pkgs/development/compilers/gerbil/build.nix @@ -1,21 +1,35 @@ -{ gccStdenv, lib, coreutils, - openssl, zlib, sqlite, - version, git-version, src, +{ + gccStdenv, + lib, + coreutils, + openssl, + zlib, + sqlite, + version, + git-version, + src, gambit-support, gambit-git-version, gambit-stampYmd, gambit-stampHms, - gambit-params }: + gambit-params, +}: # We use Gambit, that works 10x better with GCC than Clang. See ../gambit/build.nix -let stdenv = gccStdenv; in +let + stdenv = gccStdenv; +in stdenv.mkDerivation rec { pname = "gerbil"; inherit version; inherit src; - buildInputs_libraries = [ openssl zlib sqlite ]; + buildInputs_libraries = [ + openssl + zlib + sqlite + ]; # TODO: either fix all of Gerbil's dependencies to provide static libraries, # or give up and delete all tentative support for static libraries. @@ -41,16 +55,16 @@ stdenv.mkDerivation rec { done ''; -## TODO: make static compilation work. -## For that, get all the packages below to somehow expose static libraries, -## so we can offer users the option to statically link them into Gambit and/or Gerbil. -## Then add the following to the postPatch script above: -# cat > etc/gerbil_static_libraries.sh < etc/gerbil_static_libraries.sh < "${version-path}.ss"''} + ''echo -e '(import :clan/versioning${ + concatStringsSep "" ( + map ( + x: + let + px = x.passthru.pre-pkg; + in + optionalString (px.version-path != "") " :${px.gerbil-package}/${px.version-path}" + ) gerbilInputs + ) + })\n(register-software "${softwareName}" "v${git-version}")\n' > "${version-path}.ss"'' + } patchShebangs . ; ''; postConfigure = '' export GERBIL_BUILD_CORES=$NIX_BUILD_CORES export GERBIL_PATH=$PWD/.build - export GERBIL_LOADPATH=${gerbilLoadPath (["$out"] ++ gerbilInputs)} + export GERBIL_LOADPATH=${gerbilLoadPath ([ "$out" ] ++ gerbilInputs)} ${pkgs.gambit-support.export-gambopt gambit-params} ''; diff --git a/pkgs/development/compilers/gerbil/gerbil-utils.nix b/pkgs/development/compilers/gerbil/gerbil-utils.nix index ef6405c76304ba..dcc07d6eda67f5 100644 --- a/pkgs/development/compilers/gerbil/gerbil-utils.nix +++ b/pkgs/development/compilers/gerbil/gerbil-utils.nix @@ -18,9 +18,9 @@ meta = with lib; { description = "Gerbil Clan: Community curated Collection of Common Utilities"; - homepage = "https://github.com/fare/gerbil-utils"; - license = licenses.lgpl21; - platforms = platforms.unix; + homepage = "https://github.com/fare/gerbil-utils"; + license = licenses.lgpl21; + platforms = platforms.unix; maintainers = with maintainers; [ fare ]; }; } diff --git a/pkgs/development/compilers/gerbil/smug-gerbil.nix b/pkgs/development/compilers/gerbil/smug-gerbil.nix index 518ec0238f6b73..52f14ca122594d 100644 --- a/pkgs/development/compilers/gerbil/smug-gerbil.nix +++ b/pkgs/development/compilers/gerbil/smug-gerbil.nix @@ -17,9 +17,9 @@ meta = with lib; { description = "Super Monadic Über Go-into : Parsers and Gerbil Scheme"; - homepage = "https://github.com/drewc/smug-gerbil"; - license = licenses.mit; - platforms = platforms.unix; + homepage = "https://github.com/drewc/smug-gerbil"; + license = licenses.mit; + platforms = platforms.unix; maintainers = with maintainers; [ fare ]; }; } diff --git a/pkgs/development/compilers/gerbil/unstable.nix b/pkgs/development/compilers/gerbil/unstable.nix index 0dd078556efba3..871bbcb72242af 100644 --- a/pkgs/development/compilers/gerbil/unstable.nix +++ b/pkgs/development/compilers/gerbil/unstable.nix @@ -1,4 +1,8 @@ -{ callPackage, fetchFromGitHub, gambit-support }: +{ + callPackage, + fetchFromGitHub, + gambit-support, +}: callPackage ./build.nix rec { version = "unstable-2023-12-06"; diff --git a/pkgs/development/compilers/ghc/8.10.7-binary.nix b/pkgs/development/compilers/ghc/8.10.7-binary.nix index 20ad72462401d4..5d680574ad2307 100644 --- a/pkgs/development/compilers/ghc/8.10.7-binary.nix +++ b/pkgs/development/compilers/ghc/8.10.7-binary.nix @@ -1,17 +1,24 @@ -{ lib, stdenv -, fetchurl, perl, gcc -, ncurses5 -, ncurses6, gmp, libiconv, numactl -, llvmPackages -, coreutils -, rcodesign -, targetPackages +{ + lib, + stdenv, + fetchurl, + perl, + gcc, + ncurses5, + ncurses6, + gmp, + libiconv, + numactl, + llvmPackages, + coreutils, + rcodesign, + targetPackages, # minimal = true; will remove files that aren't strictly necessary for # regular builds and GHC bootstrapping. # This is "useful" for staying within hydra's output limits for at least the # aarch64-linux architecture. -, minimal ? false + minimal ? false, }: # Prebuilt only does native @@ -51,11 +58,17 @@ let }; exePathForLibraryCheck = "ghc/stage2/build/tmp/ghc-stage2"; archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } + { + nixPackage = gmp; + fileToCheckFor = null; + } # The i686-linux bindist provided by GHC HQ is currently built on Debian 9, # which link it against `libtinfo.so.5` (ncurses 5). # Other bindists are linked `libtinfo.so.6` (ncurses 6). - { nixPackage = ncurses5; fileToCheckFor = "libtinfo.so.5"; } + { + nixPackage = ncurses5; + fileToCheckFor = "libtinfo.so.5"; + } ]; }; x86_64-linux = { @@ -66,8 +79,14 @@ let }; exePathForLibraryCheck = "ghc/stage2/build/tmp/ghc-stage2"; archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = "libtinfo.so.6"; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = "libtinfo.so.6"; + } ]; }; armv7l-linux = { @@ -78,8 +97,14 @@ let }; exePathForLibraryCheck = "ghc/stage2/build/tmp/ghc-stage2"; archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = "libtinfo.so.6"; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = "libtinfo.so.6"; + } ]; }; aarch64-linux = { @@ -90,9 +115,18 @@ let }; exePathForLibraryCheck = "ghc/stage2/build/tmp/ghc-stage2"; archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = "libtinfo.so.6"; } - { nixPackage = numactl; fileToCheckFor = null; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = "libtinfo.so.6"; + } + { + nixPackage = numactl; + fileToCheckFor = null; + } ]; }; x86_64-darwin = { @@ -103,9 +137,18 @@ let }; exePathForLibraryCheck = null; # we don't have a library check for darwin yet archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = null; } - { nixPackage = libiconv; fileToCheckFor = null; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = null; + } + { + nixPackage = libiconv; + fileToCheckFor = null; + } ]; }; aarch64-darwin = { @@ -116,9 +159,18 @@ let }; exePathForLibraryCheck = null; # we don't have a library check for darwin yet archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = null; } - { nixPackage = libiconv; fileToCheckFor = null; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = null; + } + { + nixPackage = libiconv; + fileToCheckFor = null; + } ]; }; }; @@ -136,7 +188,10 @@ let # In contrast to glibc builds, the musl-bindist uses `libncursesw.so.*` # instead of `libtinfo.so.*.` - { nixPackage = ncurses6; fileToCheckFor = "libncursesw.so.6"; } + { + nixPackage = ncurses6; + fileToCheckFor = "libncursesw.so.6"; + } ]; isHadrian = true; }; @@ -145,32 +200,32 @@ let distSetName = if stdenv.hostPlatform.isMusl then "musl" else "defaultLibc"; - binDistUsed = ghcBinDists.${distSetName}.${stdenv.hostPlatform.system} - or (throw "cannot bootstrap GHC on this platform ('${stdenv.hostPlatform.system}' with libc '${distSetName}')"); + binDistUsed = + ghcBinDists.${distSetName}.${stdenv.hostPlatform.system} + or (throw "cannot bootstrap GHC on this platform ('${stdenv.hostPlatform.system}' with libc '${distSetName}')"); useLLVM = !stdenv.targetPlatform.isx86; - libPath = - lib.makeLibraryPath ( - # Add arch-specific libraries. - map ({ nixPackage, ... }: nixPackage) binDistUsed.archSpecificLibraries - ); - - libEnvVar = lib.optionalString stdenv.hostPlatform.isDarwin "DY" - + "LD_LIBRARY_PATH"; - - runtimeDeps = [ - targetPackages.stdenv.cc - targetPackages.stdenv.cc.bintools - coreutils # for cat - ] - ++ lib.optionals useLLVM [ - (lib.getBin llvmPackages.llvm) - ] - # On darwin, we need unwrapped bintools as well (for otool) - ++ lib.optionals (stdenv.targetPlatform.linker == "cctools") [ - targetPackages.stdenv.cc.bintools.bintools - ]; + libPath = lib.makeLibraryPath ( + # Add arch-specific libraries. + map ({ nixPackage, ... }: nixPackage) binDistUsed.archSpecificLibraries + ); + + libEnvVar = lib.optionalString stdenv.hostPlatform.isDarwin "DY" + "LD_LIBRARY_PATH"; + + runtimeDeps = + [ + targetPackages.stdenv.cc + targetPackages.stdenv.cc.bintools + coreutils # for cat + ] + ++ lib.optionals useLLVM [ + (lib.getBin llvmPackages.llvm) + ] + # On darwin, we need unwrapped bintools as well (for otool) + ++ lib.optionals (stdenv.targetPlatform.linker == "cctools") [ + targetPackages.stdenv.cc.bintools.bintools + ]; in @@ -191,7 +246,8 @@ stdenv.mkDerivation rec { # https://gitlab.haskell.org/ghc/ghc/-/issues/20059 # and update this comment accordingly. - nativeBuildInputs = [ perl ] + nativeBuildInputs = + [ perl ] # Upstream binaries may not be linker-signed, which invalidates their signatures # because `install_name_tool` will only replace a signature if it is both # an ad hoc signature and the signature is flagged as linker-signed. @@ -211,12 +267,14 @@ stdenv.mkDerivation rec { # Verify our assumptions of which `libtinfo.so` (ncurses) version is used, # so that we know when ghc bindists upgrade that and we need to update the # version used in `libPath`. - lib.optionalString - (binDistUsed.exePathForLibraryCheck != null) + lib.optionalString (binDistUsed.exePathForLibraryCheck != null) # Note the `*` glob because some GHCs have a suffix when unpacked, e.g. # the musl bindist has dir `ghc-VERSION-x86_64-unknown-linux/`. # As a result, don't shell-quote this glob when splicing the string. - (let buildExeGlob = ''ghc-${version}*/"${binDistUsed.exePathForLibraryCheck}"''; in + ( + let + buildExeGlob = ''ghc-${version}*/"${binDistUsed.exePathForLibraryCheck}"''; + in lib.concatStringsSep "\n" [ ('' shopt -u nullglob @@ -225,96 +283,104 @@ stdenv.mkDerivation rec { echo >&2 "GHC binary ${binDistUsed.exePathForLibraryCheck} could not be found in the bindist build directory (at ${buildExeGlob}) for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; fi '') - (lib.concatMapStringsSep - "\n" - ({ fileToCheckFor, nixPackage }: - lib.optionalString (fileToCheckFor != null) '' - echo "Checking bindist for ${fileToCheckFor} to ensure that is still used" - if ! readelf -d ${buildExeGlob} | grep "${fileToCheckFor}"; then - echo >&2 "File ${fileToCheckFor} could not be found in ${binDistUsed.exePathForLibraryCheck} for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; - fi - - echo "Checking that the nix package ${nixPackage} contains ${fileToCheckFor}" - if ! test -e "${lib.getLib nixPackage}/lib/${fileToCheckFor}"; then - echo >&2 "Nix package ${nixPackage} did not contain ${fileToCheckFor} for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; - fi - '' - ) - binDistUsed.archSpecificLibraries - ) - ]) + (lib.concatMapStringsSep "\n" ( + { fileToCheckFor, nixPackage }: + lib.optionalString (fileToCheckFor != null) '' + echo "Checking bindist for ${fileToCheckFor} to ensure that is still used" + if ! readelf -d ${buildExeGlob} | grep "${fileToCheckFor}"; then + echo >&2 "File ${fileToCheckFor} could not be found in ${binDistUsed.exePathForLibraryCheck} for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; + fi + + echo "Checking that the nix package ${nixPackage} contains ${fileToCheckFor}" + if ! test -e "${lib.getLib nixPackage}/lib/${fileToCheckFor}"; then + echo >&2 "Nix package ${nixPackage} did not contain ${fileToCheckFor} for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; + fi + '' + ) binDistUsed.archSpecificLibraries) + ] + ) # GHC has dtrace probes, which causes ld to try to open /usr/lib/libdtrace.dylib # during linking - + lib.optionalString stdenv.hostPlatform.isDarwin ('' - export NIX_LDFLAGS+=" -no_dtrace_dof" - # not enough room in the object files for the full path to libiconv :( - for exe in $(find . -type f -executable); do - isScript $exe && continue - ln -fs ${libiconv}/lib/libiconv.dylib $(dirname $exe)/libiconv.dylib - install_name_tool -change /usr/lib/libiconv.2.dylib @executable_path/libiconv.dylib -change /usr/local/lib/gcc/6/libgcc_s.1.dylib ${gcc.cc.lib}/lib/libgcc_s.1.dylib $exe - '' + lib.optionalString stdenv.hostPlatform.isAarch64 '' + + lib.optionalString stdenv.hostPlatform.isDarwin ( + '' + export NIX_LDFLAGS+=" -no_dtrace_dof" + # not enough room in the object files for the full path to libiconv :( + for exe in $(find . -type f -executable); do + isScript $exe && continue + ln -fs ${libiconv}/lib/libiconv.dylib $(dirname $exe)/libiconv.dylib + install_name_tool -change /usr/lib/libiconv.2.dylib @executable_path/libiconv.dylib -change /usr/local/lib/gcc/6/libgcc_s.1.dylib ${gcc.cc.lib}/lib/libgcc_s.1.dylib $exe + '' + + lib.optionalString stdenv.hostPlatform.isAarch64 '' # Resign the binary and set the linker-signed flag. Ignore failures when the file is an object file. # Object files don’t have signatures, so ignoring the failures is harmless. rcodesign sign --code-signature-flags linker-signed $exe || true - '' + '' - done - '') + + '' + + '' + done + '' + ) + + - # Some scripts used during the build need to have their shebangs patched - '' - patchShebangs ghc-${version}/utils/ - patchShebangs ghc-${version}/configure - test -d ghc-${version}/inplace/bin && \ - patchShebangs ghc-${version}/inplace/bin - '' + - # We have to patch the GMP paths for the integer-gmp package. - # Note that musl bindists do not contain them, - # see: https://gitlab.haskell.org/ghc/ghc/-/issues/20073#note_363231 - # However, musl bindists >= 8.10.6 use `integer-simple`, not `gmp`. - '' - find . -name integer-gmp.buildinfo \ - -exec sed -i "s@extra-lib-dirs: @extra-lib-dirs: ${gmp.out}/lib@" {} \; - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Some scripts used during the build need to have their shebangs patched + '' + patchShebangs ghc-${version}/utils/ + patchShebangs ghc-${version}/configure + test -d ghc-${version}/inplace/bin && \ + patchShebangs ghc-${version}/inplace/bin + '' + + + # We have to patch the GMP paths for the integer-gmp package. + # Note that musl bindists do not contain them, + # see: https://gitlab.haskell.org/ghc/ghc/-/issues/20073#note_363231 + # However, musl bindists >= 8.10.6 use `integer-simple`, not `gmp`. + '' + find . -name integer-gmp.buildinfo \ + -exec sed -i "s@extra-lib-dirs: @extra-lib-dirs: ${gmp.out}/lib@" {} \; + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' find . -name base.buildinfo \ -exec sed -i "s@extra-lib-dirs: @extra-lib-dirs: ${libiconv}/lib@" {} \; - '' + - # aarch64 does HAVE_NUMA so -lnuma requires it in library-dirs in rts/package.conf.in - # FFI_LIB_DIR is a good indication of places it must be needed. - lib.optionalString (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) '' - find . -name package.conf.in \ - -exec sed -i "s@FFI_LIB_DIR@FFI_LIB_DIR ${numactl.out}/lib@g" {} \; - '' + - # Rename needed libraries and binaries, fix interpreter - lib.optionalString stdenv.hostPlatform.isLinux '' - find . -type f -executable -exec patchelf \ - --interpreter ${stdenv.cc.bintools.dynamicLinker} {} \; - '' + - # The hadrian install Makefile uses 'xxx' as a temporary placeholder in path - # substitution. Which can break the build if the store path / prefix happens - # to contain this string. This will be fixed with 9.4 bindists. - # https://gitlab.haskell.org/ghc/ghc/-/issues/21402 '' - # Detect hadrian Makefile by checking for the target that has the problem - if grep '^update_package_db' ghc-${version}*/Makefile > /dev/null; then - echo Hadrian bindist, applying workaround for xxx path substitution. - # based on https://gitlab.haskell.org/ghc/ghc/-/commit/dd5fecb0e2990b192d92f4dfd7519ecb33164fad.patch - substituteInPlace ghc-${version}*/Makefile --replace 'xxx' '\0xxx\0' - else - echo Not a hadrian bindist, not applying xxx path workaround. - fi - ''; + + + # aarch64 does HAVE_NUMA so -lnuma requires it in library-dirs in rts/package.conf.in + # FFI_LIB_DIR is a good indication of places it must be needed. + lib.optionalString (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) '' + find . -name package.conf.in \ + -exec sed -i "s@FFI_LIB_DIR@FFI_LIB_DIR ${numactl.out}/lib@g" {} \; + '' + + + # Rename needed libraries and binaries, fix interpreter + lib.optionalString stdenv.hostPlatform.isLinux '' + find . -type f -executable -exec patchelf \ + --interpreter ${stdenv.cc.bintools.dynamicLinker} {} \; + '' + + + # The hadrian install Makefile uses 'xxx' as a temporary placeholder in path + # substitution. Which can break the build if the store path / prefix happens + # to contain this string. This will be fixed with 9.4 bindists. + # https://gitlab.haskell.org/ghc/ghc/-/issues/21402 + '' + # Detect hadrian Makefile by checking for the target that has the problem + if grep '^update_package_db' ghc-${version}*/Makefile > /dev/null; then + echo Hadrian bindist, applying workaround for xxx path substitution. + # based on https://gitlab.haskell.org/ghc/ghc/-/commit/dd5fecb0e2990b192d92f4dfd7519ecb33164fad.patch + substituteInPlace ghc-${version}*/Makefile --replace 'xxx' '\0xxx\0' + else + echo Not a hadrian bindist, not applying xxx path workaround. + fi + ''; # fix for `configure: error: Your linker is affected by binutils #16177` - preConfigure = lib.optionalString - stdenv.targetPlatform.isAarch32 - "LD=ld.gold"; + preConfigure = lib.optionalString stdenv.targetPlatform.isAarch32 "LD=ld.gold"; configurePlatforms = [ ]; - configureFlags = [ - "--with-gmp-includes=${lib.getDev gmp}/include" - # Note `--with-gmp-libraries` does nothing for GHC bindists: - # https://gitlab.haskell.org/ghc/ghc/-/merge_requests/6124 - ] ++ lib.optional stdenv.hostPlatform.isDarwin "--with-gcc=${./gcc-clang-wrapper.sh}" + configureFlags = + [ + "--with-gmp-includes=${lib.getDev gmp}/include" + # Note `--with-gmp-libraries` does nothing for GHC bindists: + # https://gitlab.haskell.org/ghc/ghc/-/merge_requests/6124 + ] + ++ lib.optional stdenv.hostPlatform.isDarwin "--with-gcc=${./gcc-clang-wrapper.sh}" # From: https://github.com/NixOS/nixpkgs/pull/43369/commits ++ lib.optional stdenv.hostPlatform.isMusl "--disable-ld-override"; @@ -349,58 +415,61 @@ stdenv.mkDerivation rec { # On Linux, use patchelf to modify the executables so that they can # find editline/gmp. - postFixup = lib.optionalString stdenv.hostPlatform.isLinux - (if stdenv.hostPlatform.isAarch64 then - # Keep rpath as small as possible on aarch64 for patchelf#244. All Elfs - # are 2 directories deep from $out/lib, so pooling symlinks there makes - # a short rpath. - '' - (cd $out/lib; ln -s ${ncurses6.out}/lib/libtinfo.so.6) - (cd $out/lib; ln -s ${gmp.out}/lib/libgmp.so.10) - (cd $out/lib; ln -s ${numactl.out}/lib/libnuma.so.1) - for p in $(find "$out/lib" -type f -name "*\.so*"); do - (cd $out/lib; ln -s $p) + postFixup = + lib.optionalString stdenv.hostPlatform.isLinux ( + if stdenv.hostPlatform.isAarch64 then + # Keep rpath as small as possible on aarch64 for patchelf#244. All Elfs + # are 2 directories deep from $out/lib, so pooling symlinks there makes + # a short rpath. + '' + (cd $out/lib; ln -s ${ncurses6.out}/lib/libtinfo.so.6) + (cd $out/lib; ln -s ${gmp.out}/lib/libgmp.so.10) + (cd $out/lib; ln -s ${numactl.out}/lib/libnuma.so.1) + for p in $(find "$out/lib" -type f -name "*\.so*"); do + (cd $out/lib; ln -s $p) + done + + for p in $(find "$out/lib" -type f -executable); do + if isELF "$p"; then + echo "Patchelfing $p" + patchelf --set-rpath "\$ORIGIN:\$ORIGIN/../.." $p + fi + done + '' + else + '' + for p in $(find "$out" -type f -executable); do + if isELF "$p"; then + echo "Patchelfing $p" + patchelf --set-rpath "${libPath}:$(patchelf --print-rpath $p)" $p + fi + done + '' + ) + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # not enough room in the object files for the full path to libiconv :( + for exe in $(find "$out" -type f -executable); do + isScript $exe && continue + ln -fs ${libiconv}/lib/libiconv.dylib $(dirname $exe)/libiconv.dylib + install_name_tool -change /usr/lib/libiconv.2.dylib @executable_path/libiconv.dylib -change /usr/local/lib/gcc/6/libgcc_s.1.dylib ${gcc.cc.lib}/lib/libgcc_s.1.dylib $exe done - for p in $(find "$out/lib" -type f -executable); do - if isELF "$p"; then - echo "Patchelfing $p" - patchelf --set-rpath "\$ORIGIN:\$ORIGIN/../.." $p - fi + for file in $(find "$out" -name setup-config); do + substituteInPlace $file --replace /usr/bin/ranlib "$(type -P ranlib)" done - '' - else - '' - for p in $(find "$out" -type f -executable); do - if isELF "$p"; then - echo "Patchelfing $p" - patchelf --set-rpath "${libPath}:$(patchelf --print-rpath $p)" $p - fi - done - '') + lib.optionalString stdenv.hostPlatform.isDarwin '' - # not enough room in the object files for the full path to libiconv :( - for exe in $(find "$out" -type f -executable); do - isScript $exe && continue - ln -fs ${libiconv}/lib/libiconv.dylib $(dirname $exe)/libiconv.dylib - install_name_tool -change /usr/lib/libiconv.2.dylib @executable_path/libiconv.dylib -change /usr/local/lib/gcc/6/libgcc_s.1.dylib ${gcc.cc.lib}/lib/libgcc_s.1.dylib $exe - done - - for file in $(find "$out" -name setup-config); do - substituteInPlace $file --replace /usr/bin/ranlib "$(type -P ranlib)" - done - '' + - lib.optionalString minimal '' - # Remove profiling files - find $out -type f -name '*.p_o' -delete - find $out -type f -name '*.p_hi' -delete - find $out -type f -name '*_p.a' -delete - # `-f` because e.g. musl bindist does not have this file. - rm -f $out/lib/ghc-*/bin/ghc-iserv-prof - # Hydra will redistribute this derivation, so we have to keep the docs for - # legal reasons (retaining the legal notices etc) - # As a last resort we could unpack the docs separately and symlink them in. - # They're in $out/share/{doc,man}. - ''; + '' + + lib.optionalString minimal '' + # Remove profiling files + find $out -type f -name '*.p_o' -delete + find $out -type f -name '*.p_hi' -delete + find $out -type f -name '*_p.a' -delete + # `-f` because e.g. musl bindist does not have this file. + rm -f $out/lib/ghc-*/bin/ghc-iserv-prof + # Hydra will redistribute this derivation, so we have to keep the docs for + # legal reasons (retaining the legal notices etc) + # As a last resort we could unpack the docs separately and symlink them in. + # They're in $out/share/{doc,man}. + ''; # In nixpkgs, musl based builds currently enable `pie` hardening by default # (see `defaultHardeningFlags` in `make-derivation.nix`). @@ -426,25 +495,26 @@ stdenv.mkDerivation rec { [ $(./main) == "yes" ] ''; - passthru = { - targetPrefix = ""; - enableShared = true; - - inherit llvmPackages; - - # Our Cabal compiler name - haskellCompilerName = "ghc-${version}"; - } - # We duplicate binDistUsed here since we have a sensible default even if no bindist is avaible, - # this makes sure that getting the `meta` attribute doesn't throw even on unsupported platforms. - // lib.optionalAttrs (ghcBinDists.${distSetName}.${stdenv.hostPlatform.system}.isHadrian or false) { - # Normal GHC derivations expose the hadrian derivation used to build them - # here. In the case of bindists we just make sure that the attribute exists, - # as it is used for checking if a GHC derivation has been built with hadrian. - # The isHadrian mechanism will become obsolete with GHCs that use hadrian - # exclusively, i.e. 9.6 (and 9.4?). - hadrian = null; - }; + passthru = + { + targetPrefix = ""; + enableShared = true; + + inherit llvmPackages; + + # Our Cabal compiler name + haskellCompilerName = "ghc-${version}"; + } + # We duplicate binDistUsed here since we have a sensible default even if no bindist is avaible, + # this makes sure that getting the `meta` attribute doesn't throw even on unsupported platforms. + // lib.optionalAttrs (ghcBinDists.${distSetName}.${stdenv.hostPlatform.system}.isHadrian or false) { + # Normal GHC derivations expose the hadrian derivation used to build them + # here. In the case of bindists we just make sure that the attribute exists, + # as it is used for checking if a GHC derivation has been built with hadrian. + # The isHadrian mechanism will become obsolete with GHCs that use hadrian + # exclusively, i.e. 9.6 (and 9.4?). + hadrian = null; + }; meta = rec { homepage = "http://haskell.org/ghc"; @@ -460,9 +530,12 @@ stdenv.mkDerivation rec { # long as the evaluator runs on a platform that supports # `pkgsMusl`. platforms = builtins.attrNames ghcBinDists.${distSetName}; - maintainers = with lib.maintainers; [ - prusnak - domenkozar - ] ++ lib.teams.haskell.members; + maintainers = + with lib.maintainers; + [ + prusnak + domenkozar + ] + ++ lib.teams.haskell.members; }; } diff --git a/pkgs/development/compilers/ghc/8.10.7.nix b/pkgs/development/compilers/ghc/8.10.7.nix index 03e4facd01980d..f6a4337d8622d7 100644 --- a/pkgs/development/compilers/ghc/8.10.7.nix +++ b/pkgs/development/compilers/ghc/8.10.7.nix @@ -1,83 +1,106 @@ -{ lib, stdenv, pkgsBuildTarget, pkgsHostTarget, buildPackages, targetPackages - -# build-tools -, bootPkgs -, autoreconfHook, autoconf, automake, coreutils, fetchpatch, fetchurl, perl, python3, m4, sphinx -, xattr, autoSignDarwinBinariesHook -, bash - -, libiconv ? null, ncurses - -, # GHC can be built with system libffi or a bundled one. +{ + lib, + stdenv, + pkgsBuildTarget, + pkgsHostTarget, + buildPackages, + targetPackages, + + # build-tools + bootPkgs, + autoreconfHook, + autoconf, + automake, + coreutils, + fetchpatch, + fetchurl, + perl, + python3, + m4, + sphinx, + xattr, + autoSignDarwinBinariesHook, + bash, + + libiconv ? null, + ncurses, + + # GHC can be built with system libffi or a bundled one. # we explicitly use libffi-3.3 here because 3.4 removes a flag that causes # problems for ghc-8.10.7's RTS. See #324384. # Save for aarch_darwin since libffi-3.3 is broken there but the issue isn't present anyway - libffi ? null -, libffi_3_3 ? null + libffi ? null, + libffi_3_3 ? null, -, useLLVM ? !(stdenv.targetPlatform.isx86 - || stdenv.targetPlatform.isPower - || stdenv.targetPlatform.isSparc) -, # LLVM is conceptually a run-time-only dependency, but for + useLLVM ? + !(stdenv.targetPlatform.isx86 || stdenv.targetPlatform.isPower || stdenv.targetPlatform.isSparc), + # LLVM is conceptually a run-time-only dependency, but for # non-x86, we need LLVM to bootstrap later stages, so it becomes a # build-time dependency too. - buildTargetLlvmPackages, llvmPackages + buildTargetLlvmPackages, + llvmPackages, -, # If enabled, GHC will be built with the GPL-free but slower integer-simple + # If enabled, GHC will be built with the GPL-free but slower integer-simple # library instead of the faster but GPLed integer-gmp library. - enableIntegerSimple ? !(lib.meta.availableOn stdenv.hostPlatform gmp - && lib.meta.availableOn stdenv.targetPlatform gmp) -, gmp + enableIntegerSimple ? + !(lib.meta.availableOn stdenv.hostPlatform gmp && lib.meta.availableOn stdenv.targetPlatform gmp), + gmp, -, # If enabled, use -fPIC when compiling static libs. - enableRelocatedStaticLibs ? stdenv.targetPlatform != stdenv.hostPlatform + # If enabled, use -fPIC when compiling static libs. + enableRelocatedStaticLibs ? stdenv.targetPlatform != stdenv.hostPlatform, # Exceeds Hydra output limit (at the time of writing ~3GB) when cross compiled to riscv64. # A riscv64 cross-compiler fits into the limit comfortably. -, enableProfiledLibs ? !stdenv.hostPlatform.isRiscV64 + enableProfiledLibs ? !stdenv.hostPlatform.isRiscV64, -, # Whether to build dynamic libs for the standard library (on the target + # Whether to build dynamic libs for the standard library (on the target # platform). Static libs are always built. - enableShared ? !stdenv.targetPlatform.isWindows && !stdenv.targetPlatform.useiOSPrebuilt - -, # Whether to build terminfo. - enableTerminfo ? !(stdenv.targetPlatform.isWindows - # terminfo can't be built for cross - || (stdenv.buildPlatform != stdenv.hostPlatform) - || (stdenv.hostPlatform != stdenv.targetPlatform)) - -, # What flavour to build. An empty string indicates no + enableShared ? !stdenv.targetPlatform.isWindows && !stdenv.targetPlatform.useiOSPrebuilt, + + # Whether to build terminfo. + enableTerminfo ? + !( + stdenv.targetPlatform.isWindows + # terminfo can't be built for cross + || (stdenv.buildPlatform != stdenv.hostPlatform) + || (stdenv.hostPlatform != stdenv.targetPlatform) + ), + + # What flavour to build. An empty string indicates no # specific flavour and falls back to ghc default values. - ghcFlavour ? lib.optionalString (stdenv.targetPlatform != stdenv.hostPlatform) - (if useLLVM then "perf-cross" else "perf-cross-ncg") + ghcFlavour ? lib.optionalString (stdenv.targetPlatform != stdenv.hostPlatform) ( + if useLLVM then "perf-cross" else "perf-cross-ncg" + ), -, # Whether to build sphinx documentation. + # Whether to build sphinx documentation. enableDocs ? ( # Docs disabled if we are building on musl because it's a large task to keep # all `sphinx` dependencies building in this environment. !stdenv.buildPlatform.isMusl - ) + ), -, enableHaddockProgram ? + enableHaddockProgram ? # Disabled for cross; see note [HADDOCK_DOCS]. - (stdenv.buildPlatform == stdenv.hostPlatform && stdenv.targetPlatform == stdenv.hostPlatform) + (stdenv.buildPlatform == stdenv.hostPlatform && stdenv.targetPlatform == stdenv.hostPlatform), -, # Whether to disable the large address space allocator + # Whether to disable the large address space allocator # necessary fix for iOS: https://www.reddit.com/r/haskell/comments/4ttdz1/building_an_osxi386_to_iosarm64_cross_compiler/d5qvd67/ - disableLargeAddressSpace ? stdenv.targetPlatform.isiOS + disableLargeAddressSpace ? stdenv.targetPlatform.isiOS, -, # Whether to build an unregisterised version of GHC. + # Whether to build an unregisterised version of GHC. # GHC will normally auto-detect whether it can do a registered build, but this # option will force it to do an unregistered build when set to true. # See https://gitlab.haskell.org/ghc/ghc/-/wikis/building/unregisterised - enableUnregisterised ? false + enableUnregisterised ? false, }@args: assert !enableIntegerSimple -> gmp != null; # Cross cannot currently build the `haddock` program for silly reasons, # see note [HADDOCK_DOCS]. -assert (stdenv.buildPlatform != stdenv.hostPlatform || stdenv.targetPlatform != stdenv.hostPlatform) -> !enableHaddockProgram; +assert + (stdenv.buildPlatform != stdenv.hostPlatform || stdenv.targetPlatform != stdenv.hostPlatform) + -> !enableHaddockProgram; # GHC does not support building when all 3 platforms are different. assert stdenv.buildPlatform == stdenv.hostPlatform || stdenv.hostPlatform == stdenv.targetPlatform; @@ -86,58 +109,64 @@ let inherit (stdenv) buildPlatform hostPlatform targetPlatform; # TODO(@Ericson2314) Make unconditional - targetPrefix = lib.optionalString - (targetPlatform != hostPlatform) - "${targetPlatform.config}-"; - - buildMK = '' - BuildFlavour = ${ghcFlavour} - ifneq \"\$(BuildFlavour)\" \"\" - include mk/flavours/\$(BuildFlavour).mk - endif - BUILD_SPHINX_HTML = ${if enableDocs then "YES" else "NO"} - BUILD_SPHINX_PDF = NO - - WITH_TERMINFO = ${if enableTerminfo then "YES" else "NO"} - '' + - # Note [HADDOCK_DOCS]: - # Unfortunately currently `HADDOCK_DOCS` controls both whether the `haddock` - # program is built (which we generally always want to have a complete GHC install) - # and whether it is run on the GHC sources to generate hyperlinked source code - # (which is impossible for cross-compilation); see: - # https://gitlab.haskell.org/ghc/ghc/-/issues/20077 - # This implies that currently a cross-compiled GHC will never have a `haddock` - # program, so it can never generate haddocks for any packages. - # If this is solved in the future, we'd like to unconditionally - # build the haddock program (removing the `enableHaddockProgram` option). - '' - HADDOCK_DOCS = ${if enableHaddockProgram then "YES" else "NO"} - # Build haddocks for boot packages with hyperlinking - EXTRA_HADDOCK_OPTS += --hyperlinked-source --quickjump - - DYNAMIC_GHC_PROGRAMS = ${if enableShared then "YES" else "NO"} - INTEGER_LIBRARY = ${if enableIntegerSimple then "integer-simple" else "integer-gmp"} - '' + lib.optionalString (targetPlatform != hostPlatform) '' - Stage1Only = ${if targetPlatform.system == hostPlatform.system then "NO" else "YES"} - CrossCompilePrefix = ${targetPrefix} - '' + lib.optionalString (!enableProfiledLibs) '' - BUILD_PROF_LIBS = NO - '' + lib.optionalString enableRelocatedStaticLibs '' - GhcLibHcOpts += -fPIC - GhcRtsHcOpts += -fPIC - '' + lib.optionalString targetPlatform.useAndroidPrebuilt '' - EXTRA_CC_OPTS += -std=gnu99 - '' - # While split sections are now enabled by default in ghc 8.8 for windows, - # they seem to lead to `too many sections` errors when building base for - # profiling. - + lib.optionalString targetPlatform.isWindows '' - SplitSections = NO - ''; + targetPrefix = lib.optionalString (targetPlatform != hostPlatform) "${targetPlatform.config}-"; + + buildMK = + '' + BuildFlavour = ${ghcFlavour} + ifneq \"\$(BuildFlavour)\" \"\" + include mk/flavours/\$(BuildFlavour).mk + endif + BUILD_SPHINX_HTML = ${if enableDocs then "YES" else "NO"} + BUILD_SPHINX_PDF = NO + + WITH_TERMINFO = ${if enableTerminfo then "YES" else "NO"} + '' + + + # Note [HADDOCK_DOCS]: + # Unfortunately currently `HADDOCK_DOCS` controls both whether the `haddock` + # program is built (which we generally always want to have a complete GHC install) + # and whether it is run on the GHC sources to generate hyperlinked source code + # (which is impossible for cross-compilation); see: + # https://gitlab.haskell.org/ghc/ghc/-/issues/20077 + # This implies that currently a cross-compiled GHC will never have a `haddock` + # program, so it can never generate haddocks for any packages. + # If this is solved in the future, we'd like to unconditionally + # build the haddock program (removing the `enableHaddockProgram` option). + '' + HADDOCK_DOCS = ${if enableHaddockProgram then "YES" else "NO"} + # Build haddocks for boot packages with hyperlinking + EXTRA_HADDOCK_OPTS += --hyperlinked-source --quickjump + + DYNAMIC_GHC_PROGRAMS = ${if enableShared then "YES" else "NO"} + INTEGER_LIBRARY = ${if enableIntegerSimple then "integer-simple" else "integer-gmp"} + '' + + lib.optionalString (targetPlatform != hostPlatform) '' + Stage1Only = ${if targetPlatform.system == hostPlatform.system then "NO" else "YES"} + CrossCompilePrefix = ${targetPrefix} + '' + + lib.optionalString (!enableProfiledLibs) '' + BUILD_PROF_LIBS = NO + '' + + lib.optionalString enableRelocatedStaticLibs '' + GhcLibHcOpts += -fPIC + GhcRtsHcOpts += -fPIC + '' + + lib.optionalString targetPlatform.useAndroidPrebuilt '' + EXTRA_CC_OPTS += -std=gnu99 + '' + # While split sections are now enabled by default in ghc 8.8 for windows, + # they seem to lead to `too many sections` errors when building base for + # profiling. + + lib.optionalString targetPlatform.isWindows '' + SplitSections = NO + ''; # Splicer will pull out correct variations - libDeps = platform: lib.optional enableTerminfo ncurses - ++ [args.${libffi_name}] + libDeps = + platform: + lib.optional enableTerminfo ncurses + ++ [ args.${libffi_name} ] ++ lib.optional (!enableIntegerSimple) gmp ++ lib.optional (platform.libc != "glibc" && !targetPlatform.isWindows) libiconv; @@ -155,48 +184,54 @@ let # given `stdenv.cc` derivation, i.e. it picks the correct derivation to take # the tool from (cc, cc.bintools, cc.bintools.bintools) and adds the correct # subpath of the tool. - toolPath = name: cc: + toolPath = + name: cc: let - tools = { - "cc" = cc; - "c++" = cc; - as = cc.bintools; - - ar = cc.bintools; - ranlib = cc.bintools; - nm = cc.bintools; - readelf = cc.bintools; - objdump = cc.bintools; - - ld = cc.bintools; - "ld.gold" = cc.bintools; - - otool = cc.bintools.bintools; - - # GHC needs install_name_tool on all darwin platforms. The same one can - # be used on both platforms. It is safe to use with linker-generated - # signatures because it will update the signatures automatically after - # modifying the target binary. - install_name_tool = cc.bintools.bintools; - - # strip on darwin is wrapped to enable deterministic mode. - strip = - # TODO(@sternenseemann): also use wrapper if linker == "bfd" or "gold" - if stdenv.targetPlatform.isDarwin - then cc.bintools - else cc.bintools.bintools; - - # clang is used as an assembler on darwin with the LLVM backend - clang = cc; - }.${name}; + tools = + { + "cc" = cc; + "c++" = cc; + as = cc.bintools; + + ar = cc.bintools; + ranlib = cc.bintools; + nm = cc.bintools; + readelf = cc.bintools; + objdump = cc.bintools; + + ld = cc.bintools; + "ld.gold" = cc.bintools; + + otool = cc.bintools.bintools; + + # GHC needs install_name_tool on all darwin platforms. The same one can + # be used on both platforms. It is safe to use with linker-generated + # signatures because it will update the signatures automatically after + # modifying the target binary. + install_name_tool = cc.bintools.bintools; + + # strip on darwin is wrapped to enable deterministic mode. + strip = + # TODO(@sternenseemann): also use wrapper if linker == "bfd" or "gold" + if stdenv.targetPlatform.isDarwin then cc.bintools else cc.bintools.bintools; + + # clang is used as an assembler on darwin with the LLVM backend + clang = cc; + } + .${name}; in "${tools}/bin/${tools.targetPrefix}${name}"; # Use gold either following the default, or to avoid the BFD linker due to some bugs / perf issues. # But we cannot avoid BFD when using musl libc due to https://sourceware.org/bugzilla/show_bug.cgi?id=23856 # see #84670 and #49071 for more background. - useLdGold = targetPlatform.linker == "gold" || - (targetPlatform.linker == "bfd" && (targetCC.bintools.bintools.hasGold or false) && !targetPlatform.isMusl); + useLdGold = + targetPlatform.linker == "gold" + || ( + targetPlatform.linker == "bfd" + && (targetCC.bintools.bintools.hasGold or false) + && !targetPlatform.isMusl + ); # Makes debugging easier to see which variant is at play in `nix-store -q --tree`. variantSuffix = lib.concatStrings [ @@ -205,9 +240,7 @@ let ]; libffi_name = - if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 - then "libffi" - else "libffi_3_3"; + if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 then "libffi" else "libffi_3_3"; # These libraries are library dependencies of the standard libraries bundled # by GHC (core libs) users will link their compiled artifacts again. Thus, @@ -226,347 +259,391 @@ let # target. targetLibs = let - basePackageSet = - if hostPlatform != targetPlatform - then targetPackages - else pkgsHostTarget; + basePackageSet = if hostPlatform != targetPlatform then targetPackages else pkgsHostTarget; in - { - inherit (basePackageSet) gmp ncurses; - # dynamic inherits are not possible in Nix - libffi = basePackageSet.${libffi_name}; - }; + { + inherit (basePackageSet) gmp ncurses; + # dynamic inherits are not possible in Nix + libffi = basePackageSet.${libffi_name}; + }; in -stdenv.mkDerivation (rec { - version = "8.10.7"; - pname = "${targetPrefix}ghc${variantSuffix}"; - - src = fetchurl { - url = "https://downloads.haskell.org/ghc/${version}/ghc-${version}-src.tar.xz"; - sha256 = "e3eef6229ce9908dfe1ea41436befb0455fefb1932559e860ad4c606b0d03c9d"; - }; - - enableParallelBuilding = true; - - outputs = [ "out" "doc" ]; - - patches = [ - # Fix docs build with sphinx >= 6.0 - # https://gitlab.haskell.org/ghc/ghc/-/issues/22766 - (fetchpatch { - name = "ghc-docs-sphinx-6.0.patch"; - url = "https://gitlab.haskell.org/ghc/ghc/-/commit/10e94a556b4f90769b7fd718b9790d58ae566600.patch"; - sha256 = "0kmhfamr16w8gch0lgln2912r8aryjky1hfcda3jkcwa5cdzgjdv"; - }) - - # See upstream patch at - # https://gitlab.haskell.org/ghc/ghc/-/merge_requests/4885. Since we build - # from source distributions, the auto-generated configure script needs to be - # patched as well, therefore we use an in-tree patch instead of pulling the - # upstream patch. Don't forget to check backport status of the upstream patch - # when adding new GHC releases in nixpkgs. - ./respect-ar-path.patch - - # fix hyperlinked haddock sources: https://github.com/haskell/haddock/pull/1482 - (fetchpatch { - url = "https://patch-diff.githubusercontent.com/raw/haskell/haddock/pull/1482.patch"; - sha256 = "sha256-8w8QUCsODaTvknCDGgTfFNZa8ZmvIKaKS+2ZJZ9foYk="; - extraPrefix = "utils/haddock/"; - stripLen = 1; - }) - - # cabal passes incorrect --host= when cross-compiling - # https://github.com/haskell/cabal/issues/5887 - (fetchpatch { - url = "https://raw.githubusercontent.com/input-output-hk/haskell.nix/122bd81150386867da07fdc9ad5096db6719545a/overlays/patches/ghc/cabal-host.patch"; - sha256 = "sha256:0yd0sajgi24sc1w5m55lkg2lp6kfkgpp3lgija2c8y3cmkwfpdc1"; - }) - - # In order to build ghcjs packages, the Cabal of the ghc used for the ghcjs - # needs to be patched. Ref https://github.com/haskell/cabal/pull/7575 - (fetchpatch { - url = "https://github.com/haskell/cabal/commit/369c4a0a54ad08a9e6b0d3bd303fedd7b5e5a336.patch"; - sha256 = "120f11hwyaqa0pq9g5l1300crqij49jg0rh83hnp9sa49zfdwx1n"; - stripLen = 3; - extraPrefix = "libraries/Cabal/Cabal/"; - }) - - # We need to be able to set AR_STAGE0 and LD_STAGE0 when cross-compiling - (fetchpatch { - url = "https://gitlab.haskell.org/ghc/ghc/-/commit/8f7dd5710b80906ea7a3e15b7bb56a883a49fed8.patch"; - hash = "sha256-C636Nq2U8YOG/av7XQmG3L1rU0bmC9/7m7Hty5pm5+s="; - }) - - # Backport part of to 8.10.7 - # The change we are interested in is that Cabal no longer sets include-dirs - # for the GHCi library delegating to the system search path or (in our case) - # cc-wrapper. Without this patch, the target libffi ends up in there (which - # we provide via --with-ffi-includes) which breaks bootstrapping e.g. when - # cross compiling GHC. Without include-dirs, cc-wrapper and splicing will - # correctly pick the suitable libffi out of the build environment. - (fetchpatch { - name = "ghci-no-libffi-include.patch"; - url = "https://gitlab.haskell.org/ghc/ghc/-/commit/b2721819f391ab49871271283f32df54810c4387.patch"; - sha256 = "1rmv3132xhxbka97v0rx7r6larx5f5nnvs4mgm9q3rmgpjyd1vf9"; - includes = [ "libraries/ghci/ghci.cabal.in" ]; - }) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # Make Block.h compile with c++ compilers. Remove with the next release - (fetchpatch { - url = "https://gitlab.haskell.org/ghc/ghc/-/commit/97d0b0a367e4c6a52a17c3299439ac7de129da24.patch"; - sha256 = "0r4zjj0bv1x1m2dgxp3adsf2xkr94fjnyj1igsivd9ilbs5ja0b5"; - }) - ] ++ lib.optionals (stdenv.targetPlatform.isDarwin && stdenv.targetPlatform.isAarch64) [ - # Prevent the paths module from emitting symbols that we don't use - # when building with separate outputs. - # - # These cause problems as they're not eliminated by GHC's dead code - # elimination on aarch64-darwin. (see - # https://github.com/NixOS/nixpkgs/issues/140774 for details). - ./Cabal-3.2-3.4-paths-fix-cycle-aarch64-darwin.patch - ]; - - postPatch = "patchShebangs ."; - - # GHC is a bit confused on its cross terminology. - # TODO(@sternenseemann): investigate coreutils dependencies and pass absolute paths - preConfigure = '' - for env in $(env | grep '^TARGET_' | sed -E 's|\+?=.*||'); do - export "''${env#TARGET_}=''${!env}" - done - # Stage0 (build->build) which builds stage 1 - export GHC="${bootPkgs.ghc}/bin/ghc" - # GHC is a bit confused on its cross terminology, as these would normally be - # the *host* tools. - export CC="${toolPath "cc" targetCC}" - export CXX="${toolPath "c++" targetCC}" - # Use gold to work around https://sourceware.org/bugzilla/show_bug.cgi?id=16177 - export LD="${toolPath "ld${lib.optionalString useLdGold ".gold"}" targetCC}" - export AS="${toolPath "as" targetCC}" - export AR="${toolPath "ar" targetCC}" - export NM="${toolPath "nm" targetCC}" - export RANLIB="${toolPath "ranlib" targetCC}" - export READELF="${toolPath "readelf" targetCC}" - export STRIP="${toolPath "strip" targetCC}" - export OBJDUMP="${toolPath "objdump" targetCC}" - '' + lib.optionalString (stdenv.targetPlatform.linker == "cctools") '' - export OTOOL="${toolPath "otool" targetCC}" - export INSTALL_NAME_TOOL="${toolPath "install_name_tool" targetCC}" - '' + lib.optionalString useLLVM '' - export LLC="${lib.getBin buildTargetLlvmPackages.llvm}/bin/llc" - export OPT="${lib.getBin buildTargetLlvmPackages.llvm}/bin/opt" - '' + lib.optionalString (useLLVM && stdenv.targetPlatform.isDarwin) '' - # LLVM backend on Darwin needs clang: https://downloads.haskell.org/~ghc/latest/docs/html/users_guide/codegens.html#llvm-code-generator-fllvm - # The executable we specify via $CLANG is used as an assembler (exclusively, it seems, but this isn't - # clarified in any user facing documentation). As such, it'll be called on assembly produced by $CC - # which usually comes from the darwin stdenv. To prevent a situation where $CLANG doesn't understand - # the assembly it is given, we need to make sure that it matches the LLVM version of $CC if possible. - # It is unclear (at the time of writing 2024-09-01) whether $CC should match the LLVM version we use - # for llc and opt which would require using a custom darwin stdenv for targetCC. - export CLANG="${ - if targetCC.isClang - then toolPath "clang" targetCC - else "${buildTargetLlvmPackages.clang}/bin/${buildTargetLlvmPackages.clang.targetPrefix}clang" - }" - '' + '' - # No need for absolute paths since these tools only need to work during the build - export CC_STAGE0="$CC_FOR_BUILD" - export LD_STAGE0="$LD_FOR_BUILD" - export AR_STAGE0="$AR_FOR_BUILD" - - echo -n "${buildMK}" > mk/build.mk - sed -i -e 's|-isysroot /Developer/SDKs/MacOSX10.5.sdk||' configure - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - export NIX_LDFLAGS+=" -rpath $out/lib/ghc-${version}" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - export NIX_LDFLAGS+=" -no_dtrace_dof" - - # GHC tries the host xattr /usr/bin/xattr by default which fails since it expects python to be 2.7 - export XATTR=${lib.getBin xattr}/bin/xattr - '' + lib.optionalString targetPlatform.useAndroidPrebuilt '' - sed -i -e '5i ,("armv7a-unknown-linux-androideabi", ("e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64", "cortex-a8", ""))' llvm-targets - '' + lib.optionalString targetPlatform.isMusl '' - echo "patching llvm-targets for musl targets..." - echo "Cloning these existing '*-linux-gnu*' targets:" - grep linux-gnu llvm-targets | sed 's/^/ /' - echo "(go go gadget sed)" - sed -i 's,\(^.*linux-\)gnu\(.*\)$,\0\n\1musl\2,' llvm-targets - echo "llvm-targets now contains these '*-linux-musl*' targets:" - grep linux-musl llvm-targets | sed 's/^/ /' - - echo "And now patching to preserve '-musleabi' as done with '-gnueabi'" - # (aclocal.m4 is actual source, but patch configure as well since we don't re-gen) - for x in configure aclocal.m4; do - substituteInPlace $x \ - --replace '*-android*|*-gnueabi*)' \ - '*-android*|*-gnueabi*|*-musleabi*)' - done - ''; - - # Although it is usually correct to pass --host, we don't do that here because - # GHC's usage of build, host, and target is non-standard. - # See https://gitlab.haskell.org/ghc/ghc/-/wikis/building/cross-compiling - # TODO(@Ericson2314): Always pass "--target" and always prefix. - configurePlatforms = [ "build" ] - ++ lib.optional (buildPlatform != hostPlatform || targetPlatform != hostPlatform) "target"; - - # `--with` flags for libraries needed for RTS linker - configureFlags = [ - "--datadir=$doc/share/doc/ghc" - ] ++ lib.optionals enableTerminfo [ - "--with-curses-includes=${lib.getDev targetLibs.ncurses}/include" - "--with-curses-libraries=${lib.getLib targetLibs.ncurses}/lib" - ] ++ lib.optionals (args.${libffi_name} != null) [ - "--with-system-libffi" - "--with-ffi-includes=${targetLibs.libffi.dev}/include" - "--with-ffi-libraries=${targetLibs.libffi.out}/lib" - ] ++ lib.optionals (targetPlatform == hostPlatform && !enableIntegerSimple) [ - "--with-gmp-includes=${targetLibs.gmp.dev}/include" - "--with-gmp-libraries=${targetLibs.gmp.out}/lib" - ] ++ lib.optionals (targetPlatform == hostPlatform && hostPlatform.libc != "glibc" && !targetPlatform.isWindows) [ - "--with-iconv-includes=${libiconv}/include" - "--with-iconv-libraries=${libiconv}/lib" - ] ++ lib.optionals (targetPlatform != hostPlatform) [ - "--enable-bootstrap-with-devel-snapshot" - ] ++ lib.optionals useLdGold [ - "CFLAGS=-fuse-ld=gold" - "CONF_GCC_LINKER_OPTS_STAGE1=-fuse-ld=gold" - "CONF_GCC_LINKER_OPTS_STAGE2=-fuse-ld=gold" - ] ++ lib.optionals (disableLargeAddressSpace) [ - "--disable-large-address-space" - ] ++ lib.optionals enableUnregisterised [ - "--enable-unregisterised" - ]; - - # Make sure we never relax`$PATH` and hooks support for compatibility. - strictDeps = true; - - # Don’t add -liconv to LDFLAGS automatically so that GHC will add it itself. - dontAddExtraLibs = true; - - nativeBuildInputs = [ - perl autoreconfHook autoconf automake m4 python3 - bootPkgs.alex bootPkgs.happy bootPkgs.hscolour - bootPkgs.ghc-settings-edit - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - autoSignDarwinBinariesHook - ] ++ lib.optionals enableDocs [ - sphinx - ]; - - # Everything the stage0 compiler needs to build stage1: CC, bintools, extra libs. - # See also GHC, {CC,LD,AR}_STAGE0 in preConfigure. - depsBuildBuild = [ - # N.B. We do not declare bootPkgs.ghc in any of the stdenv.mkDerivation - # dependency lists to prevent the bintools setup hook from adding ghc's - # lib directory to the linker flags. Instead we tell configure about it - # via the GHC environment variable. - buildCC - # stage0 builds terminfo unconditionally, so we always need ncurses - ncurses - ]; - # For building runtime libs - depsBuildTarget = toolsForTarget; - - # Prevent stage0 ghc from leaking into the final result. This was an issue - # with GHC 9.6. - disallowedReferences = [ - bootPkgs.ghc - ]; - - buildInputs = [ bash ] ++ (libDeps hostPlatform); - - depsTargetTarget = map lib.getDev (libDeps targetPlatform); - depsTargetTargetPropagated = map (lib.getOutput "out") (libDeps targetPlatform); - - # required, because otherwise all symbols from HSffi.o are stripped, and - # that in turn causes GHCi to abort - stripDebugFlags = [ "-S" ] ++ lib.optional (!targetPlatform.isDarwin) "--keep-file-symbols"; - - checkTarget = "test"; - - hardeningDisable = - [ "format" ] - # In nixpkgs, musl based builds currently enable `pie` hardening by default - # (see `defaultHardeningFlags` in `make-derivation.nix`). - # But GHC cannot currently produce outputs that are ready for `-pie` linking. - # Thus, disable `pie` hardening, otherwise `recompile with -fPIE` errors appear. - # See: - # * https://github.com/NixOS/nixpkgs/issues/129247 - # * https://gitlab.haskell.org/ghc/ghc/-/issues/19580 - ++ lib.optional stdenv.targetPlatform.isMusl "pie"; - - # big-parallel allows us to build with more than 2 cores on - # Hydra which already warrants a significant speedup - requiredSystemFeatures = [ "big-parallel" ]; - - postInstall = '' - settingsFile="$out/lib/${targetPrefix}${passthru.haskellCompilerName}/settings" - - # Make the installed GHC use the host->target tools. - ghc-settings-edit "$settingsFile" \ - "C compiler command" "${toolPath "cc" installCC}" \ - "Haskell CPP command" "${toolPath "cc" installCC}" \ - "C++ compiler command" "${toolPath "c++" installCC}" \ - "ld command" "${toolPath "ld${lib.optionalString useLdGold ".gold"}" installCC}" \ - "Merge objects command" "${toolPath "ld${lib.optionalString useLdGold ".gold"}" installCC}" \ - "ar command" "${toolPath "ar" installCC}" \ - "ranlib command" "${toolPath "ranlib" installCC}" - '' - + lib.optionalString (stdenv.targetPlatform.linker == "cctools") '' - ghc-settings-edit "$settingsFile" \ - "otool command" "${toolPath "otool" installCC}" \ - "install_name_tool command" "${toolPath "install_name_tool" installCC}" - '' - + lib.optionalString useLLVM '' - ghc-settings-edit "$settingsFile" \ - "LLVM llc command" "${lib.getBin llvmPackages.llvm}/bin/llc" \ - "LLVM opt command" "${lib.getBin llvmPackages.llvm}/bin/opt" - '' - + lib.optionalString (useLLVM && stdenv.targetPlatform.isDarwin) '' - ghc-settings-edit "$settingsFile" \ - "LLVM clang command" "${ - # See comment for CLANG in preConfigure - if installCC.isClang - then toolPath "clang" installCC - else "${llvmPackages.clang}/bin/${llvmPackages.clang.targetPrefix}clang" - }" - '' - + '' - - # Install the bash completion file. - install -D -m 444 utils/completion/ghc.bash $out/share/bash-completion/completions/${targetPrefix}ghc - ''; - - passthru = { - inherit bootPkgs targetPrefix; - - inherit llvmPackages; - inherit enableShared; - - # This is used by the haskell builder to query - # the presence of the haddock program. - hasHaddock = enableHaddockProgram; - - # Our Cabal compiler name - haskellCompilerName = "ghc-${version}"; - }; - - meta = { - homepage = "http://haskell.org/ghc"; - description = "Glasgow Haskell Compiler"; - maintainers = with lib.maintainers; [ - guibou - ] ++ lib.teams.haskell.members; - timeout = 24 * 3600; - platforms = lib.platforms.all; - inherit (bootPkgs.ghc.meta) license; - }; - -} // lib.optionalAttrs targetPlatform.useAndroidPrebuilt { - dontStrip = true; - dontPatchELF = true; - noAuditTmpdir = true; -}) +stdenv.mkDerivation ( + rec { + version = "8.10.7"; + pname = "${targetPrefix}ghc${variantSuffix}"; + + src = fetchurl { + url = "https://downloads.haskell.org/ghc/${version}/ghc-${version}-src.tar.xz"; + sha256 = "e3eef6229ce9908dfe1ea41436befb0455fefb1932559e860ad4c606b0d03c9d"; + }; + + enableParallelBuilding = true; + + outputs = [ + "out" + "doc" + ]; + + patches = + [ + # Fix docs build with sphinx >= 6.0 + # https://gitlab.haskell.org/ghc/ghc/-/issues/22766 + (fetchpatch { + name = "ghc-docs-sphinx-6.0.patch"; + url = "https://gitlab.haskell.org/ghc/ghc/-/commit/10e94a556b4f90769b7fd718b9790d58ae566600.patch"; + sha256 = "0kmhfamr16w8gch0lgln2912r8aryjky1hfcda3jkcwa5cdzgjdv"; + }) + + # See upstream patch at + # https://gitlab.haskell.org/ghc/ghc/-/merge_requests/4885. Since we build + # from source distributions, the auto-generated configure script needs to be + # patched as well, therefore we use an in-tree patch instead of pulling the + # upstream patch. Don't forget to check backport status of the upstream patch + # when adding new GHC releases in nixpkgs. + ./respect-ar-path.patch + + # fix hyperlinked haddock sources: https://github.com/haskell/haddock/pull/1482 + (fetchpatch { + url = "https://patch-diff.githubusercontent.com/raw/haskell/haddock/pull/1482.patch"; + sha256 = "sha256-8w8QUCsODaTvknCDGgTfFNZa8ZmvIKaKS+2ZJZ9foYk="; + extraPrefix = "utils/haddock/"; + stripLen = 1; + }) + + # cabal passes incorrect --host= when cross-compiling + # https://github.com/haskell/cabal/issues/5887 + (fetchpatch { + url = "https://raw.githubusercontent.com/input-output-hk/haskell.nix/122bd81150386867da07fdc9ad5096db6719545a/overlays/patches/ghc/cabal-host.patch"; + sha256 = "sha256:0yd0sajgi24sc1w5m55lkg2lp6kfkgpp3lgija2c8y3cmkwfpdc1"; + }) + + # In order to build ghcjs packages, the Cabal of the ghc used for the ghcjs + # needs to be patched. Ref https://github.com/haskell/cabal/pull/7575 + (fetchpatch { + url = "https://github.com/haskell/cabal/commit/369c4a0a54ad08a9e6b0d3bd303fedd7b5e5a336.patch"; + sha256 = "120f11hwyaqa0pq9g5l1300crqij49jg0rh83hnp9sa49zfdwx1n"; + stripLen = 3; + extraPrefix = "libraries/Cabal/Cabal/"; + }) + + # We need to be able to set AR_STAGE0 and LD_STAGE0 when cross-compiling + (fetchpatch { + url = "https://gitlab.haskell.org/ghc/ghc/-/commit/8f7dd5710b80906ea7a3e15b7bb56a883a49fed8.patch"; + hash = "sha256-C636Nq2U8YOG/av7XQmG3L1rU0bmC9/7m7Hty5pm5+s="; + }) + + # Backport part of to 8.10.7 + # The change we are interested in is that Cabal no longer sets include-dirs + # for the GHCi library delegating to the system search path or (in our case) + # cc-wrapper. Without this patch, the target libffi ends up in there (which + # we provide via --with-ffi-includes) which breaks bootstrapping e.g. when + # cross compiling GHC. Without include-dirs, cc-wrapper and splicing will + # correctly pick the suitable libffi out of the build environment. + (fetchpatch { + name = "ghci-no-libffi-include.patch"; + url = "https://gitlab.haskell.org/ghc/ghc/-/commit/b2721819f391ab49871271283f32df54810c4387.patch"; + sha256 = "1rmv3132xhxbka97v0rx7r6larx5f5nnvs4mgm9q3rmgpjyd1vf9"; + includes = [ "libraries/ghci/ghci.cabal.in" ]; + }) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # Make Block.h compile with c++ compilers. Remove with the next release + (fetchpatch { + url = "https://gitlab.haskell.org/ghc/ghc/-/commit/97d0b0a367e4c6a52a17c3299439ac7de129da24.patch"; + sha256 = "0r4zjj0bv1x1m2dgxp3adsf2xkr94fjnyj1igsivd9ilbs5ja0b5"; + }) + ] + ++ lib.optionals (stdenv.targetPlatform.isDarwin && stdenv.targetPlatform.isAarch64) [ + # Prevent the paths module from emitting symbols that we don't use + # when building with separate outputs. + # + # These cause problems as they're not eliminated by GHC's dead code + # elimination on aarch64-darwin. (see + # https://github.com/NixOS/nixpkgs/issues/140774 for details). + ./Cabal-3.2-3.4-paths-fix-cycle-aarch64-darwin.patch + ]; + + postPatch = "patchShebangs ."; + + # GHC is a bit confused on its cross terminology. + # TODO(@sternenseemann): investigate coreutils dependencies and pass absolute paths + preConfigure = + '' + for env in $(env | grep '^TARGET_' | sed -E 's|\+?=.*||'); do + export "''${env#TARGET_}=''${!env}" + done + # Stage0 (build->build) which builds stage 1 + export GHC="${bootPkgs.ghc}/bin/ghc" + # GHC is a bit confused on its cross terminology, as these would normally be + # the *host* tools. + export CC="${toolPath "cc" targetCC}" + export CXX="${toolPath "c++" targetCC}" + # Use gold to work around https://sourceware.org/bugzilla/show_bug.cgi?id=16177 + export LD="${toolPath "ld${lib.optionalString useLdGold ".gold"}" targetCC}" + export AS="${toolPath "as" targetCC}" + export AR="${toolPath "ar" targetCC}" + export NM="${toolPath "nm" targetCC}" + export RANLIB="${toolPath "ranlib" targetCC}" + export READELF="${toolPath "readelf" targetCC}" + export STRIP="${toolPath "strip" targetCC}" + export OBJDUMP="${toolPath "objdump" targetCC}" + '' + + lib.optionalString (stdenv.targetPlatform.linker == "cctools") '' + export OTOOL="${toolPath "otool" targetCC}" + export INSTALL_NAME_TOOL="${toolPath "install_name_tool" targetCC}" + '' + + lib.optionalString useLLVM '' + export LLC="${lib.getBin buildTargetLlvmPackages.llvm}/bin/llc" + export OPT="${lib.getBin buildTargetLlvmPackages.llvm}/bin/opt" + '' + + lib.optionalString (useLLVM && stdenv.targetPlatform.isDarwin) '' + # LLVM backend on Darwin needs clang: https://downloads.haskell.org/~ghc/latest/docs/html/users_guide/codegens.html#llvm-code-generator-fllvm + # The executable we specify via $CLANG is used as an assembler (exclusively, it seems, but this isn't + # clarified in any user facing documentation). As such, it'll be called on assembly produced by $CC + # which usually comes from the darwin stdenv. To prevent a situation where $CLANG doesn't understand + # the assembly it is given, we need to make sure that it matches the LLVM version of $CC if possible. + # It is unclear (at the time of writing 2024-09-01) whether $CC should match the LLVM version we use + # for llc and opt which would require using a custom darwin stdenv for targetCC. + export CLANG="${ + if targetCC.isClang then + toolPath "clang" targetCC + else + "${buildTargetLlvmPackages.clang}/bin/${buildTargetLlvmPackages.clang.targetPrefix}clang" + }" + '' + + '' + # No need for absolute paths since these tools only need to work during the build + export CC_STAGE0="$CC_FOR_BUILD" + export LD_STAGE0="$LD_FOR_BUILD" + export AR_STAGE0="$AR_FOR_BUILD" + + echo -n "${buildMK}" > mk/build.mk + sed -i -e 's|-isysroot /Developer/SDKs/MacOSX10.5.sdk||' configure + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + export NIX_LDFLAGS+=" -rpath $out/lib/ghc-${version}" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + export NIX_LDFLAGS+=" -no_dtrace_dof" + + # GHC tries the host xattr /usr/bin/xattr by default which fails since it expects python to be 2.7 + export XATTR=${lib.getBin xattr}/bin/xattr + '' + + lib.optionalString targetPlatform.useAndroidPrebuilt '' + sed -i -e '5i ,("armv7a-unknown-linux-androideabi", ("e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64", "cortex-a8", ""))' llvm-targets + '' + + lib.optionalString targetPlatform.isMusl '' + echo "patching llvm-targets for musl targets..." + echo "Cloning these existing '*-linux-gnu*' targets:" + grep linux-gnu llvm-targets | sed 's/^/ /' + echo "(go go gadget sed)" + sed -i 's,\(^.*linux-\)gnu\(.*\)$,\0\n\1musl\2,' llvm-targets + echo "llvm-targets now contains these '*-linux-musl*' targets:" + grep linux-musl llvm-targets | sed 's/^/ /' + + echo "And now patching to preserve '-musleabi' as done with '-gnueabi'" + # (aclocal.m4 is actual source, but patch configure as well since we don't re-gen) + for x in configure aclocal.m4; do + substituteInPlace $x \ + --replace '*-android*|*-gnueabi*)' \ + '*-android*|*-gnueabi*|*-musleabi*)' + done + ''; + + # Although it is usually correct to pass --host, we don't do that here because + # GHC's usage of build, host, and target is non-standard. + # See https://gitlab.haskell.org/ghc/ghc/-/wikis/building/cross-compiling + # TODO(@Ericson2314): Always pass "--target" and always prefix. + configurePlatforms = [ + "build" + ] ++ lib.optional (buildPlatform != hostPlatform || targetPlatform != hostPlatform) "target"; + + # `--with` flags for libraries needed for RTS linker + configureFlags = + [ + "--datadir=$doc/share/doc/ghc" + ] + ++ lib.optionals enableTerminfo [ + "--with-curses-includes=${lib.getDev targetLibs.ncurses}/include" + "--with-curses-libraries=${lib.getLib targetLibs.ncurses}/lib" + ] + ++ lib.optionals (args.${libffi_name} != null) [ + "--with-system-libffi" + "--with-ffi-includes=${targetLibs.libffi.dev}/include" + "--with-ffi-libraries=${targetLibs.libffi.out}/lib" + ] + ++ lib.optionals (targetPlatform == hostPlatform && !enableIntegerSimple) [ + "--with-gmp-includes=${targetLibs.gmp.dev}/include" + "--with-gmp-libraries=${targetLibs.gmp.out}/lib" + ] + ++ + lib.optionals + (targetPlatform == hostPlatform && hostPlatform.libc != "glibc" && !targetPlatform.isWindows) + [ + "--with-iconv-includes=${libiconv}/include" + "--with-iconv-libraries=${libiconv}/lib" + ] + ++ lib.optionals (targetPlatform != hostPlatform) [ + "--enable-bootstrap-with-devel-snapshot" + ] + ++ lib.optionals useLdGold [ + "CFLAGS=-fuse-ld=gold" + "CONF_GCC_LINKER_OPTS_STAGE1=-fuse-ld=gold" + "CONF_GCC_LINKER_OPTS_STAGE2=-fuse-ld=gold" + ] + ++ lib.optionals (disableLargeAddressSpace) [ + "--disable-large-address-space" + ] + ++ lib.optionals enableUnregisterised [ + "--enable-unregisterised" + ]; + + # Make sure we never relax`$PATH` and hooks support for compatibility. + strictDeps = true; + + # Don’t add -liconv to LDFLAGS automatically so that GHC will add it itself. + dontAddExtraLibs = true; + + nativeBuildInputs = + [ + perl + autoreconfHook + autoconf + automake + m4 + python3 + bootPkgs.alex + bootPkgs.happy + bootPkgs.hscolour + bootPkgs.ghc-settings-edit + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + autoSignDarwinBinariesHook + ] + ++ lib.optionals enableDocs [ + sphinx + ]; + + # Everything the stage0 compiler needs to build stage1: CC, bintools, extra libs. + # See also GHC, {CC,LD,AR}_STAGE0 in preConfigure. + depsBuildBuild = [ + # N.B. We do not declare bootPkgs.ghc in any of the stdenv.mkDerivation + # dependency lists to prevent the bintools setup hook from adding ghc's + # lib directory to the linker flags. Instead we tell configure about it + # via the GHC environment variable. + buildCC + # stage0 builds terminfo unconditionally, so we always need ncurses + ncurses + ]; + # For building runtime libs + depsBuildTarget = toolsForTarget; + + # Prevent stage0 ghc from leaking into the final result. This was an issue + # with GHC 9.6. + disallowedReferences = [ + bootPkgs.ghc + ]; + + buildInputs = [ bash ] ++ (libDeps hostPlatform); + + depsTargetTarget = map lib.getDev (libDeps targetPlatform); + depsTargetTargetPropagated = map (lib.getOutput "out") (libDeps targetPlatform); + + # required, because otherwise all symbols from HSffi.o are stripped, and + # that in turn causes GHCi to abort + stripDebugFlags = [ "-S" ] ++ lib.optional (!targetPlatform.isDarwin) "--keep-file-symbols"; + + checkTarget = "test"; + + hardeningDisable = + [ "format" ] + # In nixpkgs, musl based builds currently enable `pie` hardening by default + # (see `defaultHardeningFlags` in `make-derivation.nix`). + # But GHC cannot currently produce outputs that are ready for `-pie` linking. + # Thus, disable `pie` hardening, otherwise `recompile with -fPIE` errors appear. + # See: + # * https://github.com/NixOS/nixpkgs/issues/129247 + # * https://gitlab.haskell.org/ghc/ghc/-/issues/19580 + ++ lib.optional stdenv.targetPlatform.isMusl "pie"; + + # big-parallel allows us to build with more than 2 cores on + # Hydra which already warrants a significant speedup + requiredSystemFeatures = [ "big-parallel" ]; + + postInstall = + '' + settingsFile="$out/lib/${targetPrefix}${passthru.haskellCompilerName}/settings" + + # Make the installed GHC use the host->target tools. + ghc-settings-edit "$settingsFile" \ + "C compiler command" "${toolPath "cc" installCC}" \ + "Haskell CPP command" "${toolPath "cc" installCC}" \ + "C++ compiler command" "${toolPath "c++" installCC}" \ + "ld command" "${toolPath "ld${lib.optionalString useLdGold ".gold"}" installCC}" \ + "Merge objects command" "${toolPath "ld${lib.optionalString useLdGold ".gold"}" installCC}" \ + "ar command" "${toolPath "ar" installCC}" \ + "ranlib command" "${toolPath "ranlib" installCC}" + '' + + lib.optionalString (stdenv.targetPlatform.linker == "cctools") '' + ghc-settings-edit "$settingsFile" \ + "otool command" "${toolPath "otool" installCC}" \ + "install_name_tool command" "${toolPath "install_name_tool" installCC}" + '' + + lib.optionalString useLLVM '' + ghc-settings-edit "$settingsFile" \ + "LLVM llc command" "${lib.getBin llvmPackages.llvm}/bin/llc" \ + "LLVM opt command" "${lib.getBin llvmPackages.llvm}/bin/opt" + '' + + lib.optionalString (useLLVM && stdenv.targetPlatform.isDarwin) '' + ghc-settings-edit "$settingsFile" \ + "LLVM clang command" "${ + # See comment for CLANG in preConfigure + if installCC.isClang then + toolPath "clang" installCC + else + "${llvmPackages.clang}/bin/${llvmPackages.clang.targetPrefix}clang" + }" + '' + + '' + + # Install the bash completion file. + install -D -m 444 utils/completion/ghc.bash $out/share/bash-completion/completions/${targetPrefix}ghc + ''; + + passthru = { + inherit bootPkgs targetPrefix; + + inherit llvmPackages; + inherit enableShared; + + # This is used by the haskell builder to query + # the presence of the haddock program. + hasHaddock = enableHaddockProgram; + + # Our Cabal compiler name + haskellCompilerName = "ghc-${version}"; + }; + + meta = { + homepage = "http://haskell.org/ghc"; + description = "Glasgow Haskell Compiler"; + maintainers = + with lib.maintainers; + [ + guibou + ] + ++ lib.teams.haskell.members; + timeout = 24 * 3600; + platforms = lib.platforms.all; + inherit (bootPkgs.ghc.meta) license; + }; + + } + // lib.optionalAttrs targetPlatform.useAndroidPrebuilt { + dontStrip = true; + dontPatchELF = true; + noAuditTmpdir = true; + } +) diff --git a/pkgs/development/compilers/ghc/8.6.5-binary.nix b/pkgs/development/compilers/ghc/8.6.5-binary.nix index eef0cba9f00bd2..9e205aa0796d71 100644 --- a/pkgs/development/compilers/ghc/8.6.5-binary.nix +++ b/pkgs/development/compilers/ghc/8.6.5-binary.nix @@ -1,52 +1,71 @@ -{ lib, stdenv -, fetchurl, perl, gcc -, ncurses5, ncurses6, gmp, glibc, libiconv -, llvmPackages -, coreutils -, targetPackages +{ + lib, + stdenv, + fetchurl, + perl, + gcc, + ncurses5, + ncurses6, + gmp, + glibc, + libiconv, + llvmPackages, + coreutils, + targetPackages, }: # Prebuilt only does native assert stdenv.targetPlatform == stdenv.hostPlatform; let - useLLVM = !(stdenv.targetPlatform.isx86 - || stdenv.targetPlatform.isPower - || stdenv.targetPlatform.isSparc); + useLLVM = + !(stdenv.targetPlatform.isx86 || stdenv.targetPlatform.isPower || stdenv.targetPlatform.isSparc); - useNcurses6 = stdenv.hostPlatform.system == "x86_64-linux" - || (with stdenv.hostPlatform; isPower64 && isLittleEndian); + useNcurses6 = + stdenv.hostPlatform.system == "x86_64-linux" + || (with stdenv.hostPlatform; isPower64 && isLittleEndian); ourNcurses = if useNcurses6 then ncurses6 else ncurses5; - libPath = lib.makeLibraryPath ([ - ourNcurses gmp - ] ++ lib.optional (stdenv.hostPlatform.isDarwin) libiconv); + libPath = lib.makeLibraryPath ( + [ + ourNcurses + gmp + ] + ++ lib.optional (stdenv.hostPlatform.isDarwin) libiconv + ); - libEnvVar = lib.optionalString stdenv.hostPlatform.isDarwin "DY" - + "LD_LIBRARY_PATH"; + libEnvVar = lib.optionalString stdenv.hostPlatform.isDarwin "DY" + "LD_LIBRARY_PATH"; - glibcDynLinker = assert stdenv.hostPlatform.isLinux; + glibcDynLinker = + assert stdenv.hostPlatform.isLinux; if stdenv.hostPlatform.libc == "glibc" then - # Could be stdenv.cc.bintools.dynamicLinker, keeping as-is to avoid rebuild. - ''"$(cat $NIX_CC/nix-support/dynamic-linker)"'' + # Could be stdenv.cc.bintools.dynamicLinker, keeping as-is to avoid rebuild. + ''"$(cat $NIX_CC/nix-support/dynamic-linker)"'' else "${lib.getLib glibc}/lib/ld-linux*"; downloadsUrl = "https://downloads.haskell.org/ghc"; - runtimeDeps = [ - targetPackages.stdenv.cc - targetPackages.stdenv.cc.bintools - coreutils # for cat - ] - ++ lib.optionals (assert useLLVM -> !(llvmPackages == null); useLLVM) [ - (lib.getBin llvmPackages.llvm) - ] - # On darwin, we need unwrapped bintools as well (for otool) - ++ lib.optionals (stdenv.targetPlatform.linker == "cctools") [ - targetPackages.stdenv.cc.bintools.bintools - ]; + runtimeDeps = + [ + targetPackages.stdenv.cc + targetPackages.stdenv.cc.bintools + coreutils # for cat + ] + ++ + lib.optionals + ( + assert useLLVM -> !(llvmPackages == null); + useLLVM + ) + [ + (lib.getBin llvmPackages.llvm) + ] + # On darwin, we need unwrapped bintools as well (for otool) + ++ lib.optionals (stdenv.targetPlatform.linker == "cctools") [ + targetPackages.stdenv.cc.bintools.bintools + ]; in @@ -55,29 +74,31 @@ stdenv.mkDerivation rec { pname = "ghc-binary"; # https://downloads.haskell.org/~ghc/8.6.5/ - src = fetchurl ({ - i686-linux = { - # Don't use the Fedora27 build (as below) because there isn't one! - url = "${downloadsUrl}/${version}/ghc-${version}-i386-deb9-linux.tar.xz"; - sha256 = "1p2h29qghql19ajk755xa0yxkn85slbds8m9n5196ris743vkp8w"; - }; - x86_64-linux = { - # This is the Fedora build because it links against ncurses6 where the - # deb9 one links against ncurses5, see here - # https://github.com/NixOS/nixpkgs/issues/85924 for a discussion - url = "${downloadsUrl}/${version}/ghc-${version}-x86_64-fedora27-linux.tar.xz"; - sha256 = "18dlqm5d028fqh6ghzn7pgjspr5smw030jjzl3kq6q1kmwzbay6g"; - }; - x86_64-darwin = { - url = "${downloadsUrl}/${version}/ghc-${version}-x86_64-apple-darwin.tar.xz"; - sha256 = "0s9188vhhgf23q3rjarwhbr524z6h2qga5xaaa2pma03sfqvvhfz"; - }; - powerpc64le-linux = { - url = "https://downloads.haskell.org/~ghc/${version}/ghc-${version}-powerpc64le-fedora29-linux.tar.xz"; - sha256 = "sha256-tWSsJdPVrCiqDyIKzpBt5DaXb3b6j951tCya584kWs4="; - }; - }.${stdenv.hostPlatform.system} - or (throw "cannot bootstrap GHC on this platform")); + src = fetchurl ( + { + i686-linux = { + # Don't use the Fedora27 build (as below) because there isn't one! + url = "${downloadsUrl}/${version}/ghc-${version}-i386-deb9-linux.tar.xz"; + sha256 = "1p2h29qghql19ajk755xa0yxkn85slbds8m9n5196ris743vkp8w"; + }; + x86_64-linux = { + # This is the Fedora build because it links against ncurses6 where the + # deb9 one links against ncurses5, see here + # https://github.com/NixOS/nixpkgs/issues/85924 for a discussion + url = "${downloadsUrl}/${version}/ghc-${version}-x86_64-fedora27-linux.tar.xz"; + sha256 = "18dlqm5d028fqh6ghzn7pgjspr5smw030jjzl3kq6q1kmwzbay6g"; + }; + x86_64-darwin = { + url = "${downloadsUrl}/${version}/ghc-${version}-x86_64-apple-darwin.tar.xz"; + sha256 = "0s9188vhhgf23q3rjarwhbr524z6h2qga5xaaa2pma03sfqvvhfz"; + }; + powerpc64le-linux = { + url = "https://downloads.haskell.org/~ghc/${version}/ghc-${version}-powerpc64le-fedora29-linux.tar.xz"; + sha256 = "sha256-tWSsJdPVrCiqDyIKzpBt5DaXb3b6j951tCya584kWs4="; + }; + } + .${stdenv.hostPlatform.system} or (throw "cannot bootstrap GHC on this platform") + ); nativeBuildInputs = [ perl ]; @@ -96,53 +117,61 @@ stdenv.mkDerivation rec { ln -fs ${libiconv}/lib/libiconv.dylib $(dirname $exe)/libiconv.dylib install_name_tool -change /usr/lib/libiconv.2.dylib @executable_path/libiconv.dylib -change /usr/local/lib/gcc/6/libgcc_s.1.dylib ${gcc.cc.lib}/lib/libgcc_s.1.dylib $exe done - '' + - - # Some scripts used during the build need to have their shebangs patched '' - patchShebangs ghc-${version}/utils/ - patchShebangs ghc-${version}/configure - test -d ghc-${version}/inplace/bin && \ - patchShebangs ghc-${version}/inplace/bin - '' + + + - # We have to patch the GMP paths for the integer-gmp package. - '' - find . -name integer-gmp.buildinfo \ - -exec sed -i "s@extra-lib-dirs: @extra-lib-dirs: ${gmp.out}/lib@" {} \; - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Some scripts used during the build need to have their shebangs patched + '' + patchShebangs ghc-${version}/utils/ + patchShebangs ghc-${version}/configure + test -d ghc-${version}/inplace/bin && \ + patchShebangs ghc-${version}/inplace/bin + '' + + + + # We have to patch the GMP paths for the integer-gmp package. + '' + find . -name integer-gmp.buildinfo \ + -exec sed -i "s@extra-lib-dirs: @extra-lib-dirs: ${gmp.out}/lib@" {} \; + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' find . -name base.buildinfo \ -exec sed -i "s@extra-lib-dirs: @extra-lib-dirs: ${libiconv}/lib@" {} \; - '' + - # Rename needed libraries and binaries, fix interpreter - lib.optionalString stdenv.hostPlatform.isLinux '' - find . -type f -perm -0100 \ - -exec patchelf \ - --replace-needed libncurses${lib.optionalString stdenv.hostPlatform.is64bit "w"}.so.5 libncurses.so \ - ${ # This isn't required for x86_64-linux where we use ncurses6 - lib.optionalString (!useNcurses6) "--replace-needed libtinfo.so libtinfo.so.5" - } \ - --interpreter ${glibcDynLinker} {} \; - - sed -i "s|/usr/bin/perl|perl\x00 |" ghc-${version}/ghc/stage2/build/tmp/ghc-stage2 - sed -i "s|/usr/bin/gcc|gcc\x00 |" ghc-${version}/ghc/stage2/build/tmp/ghc-stage2 - '' + - # We're kludging a glibc bindist into working with non-glibc... - # Here we patch up the use of `__strdup` (part of glibc binary ABI) - # to instead use `strdup` since musl doesn't provide __strdup - # (`__strdup` is defined to be an alias of `strdup` anyway[1]). - # [1] http://refspecs.linuxbase.org/LSB_4.0.0/LSB-Core-generic/LSB-Core-generic/baselib---strdup-1.html - # Use objcopy magic to make the change: - lib.optionalString stdenv.hostPlatform.isMusl '' - find ./ghc-${version}/rts -name "libHSrts*.a" -exec ''${OBJCOPY:-objcopy} --redefine-sym __strdup=strdup {} \; - ''; + '' + + + # Rename needed libraries and binaries, fix interpreter + lib.optionalString stdenv.hostPlatform.isLinux '' + find . -type f -perm -0100 \ + -exec patchelf \ + --replace-needed libncurses${lib.optionalString stdenv.hostPlatform.is64bit "w"}.so.5 libncurses.so \ + ${ + # This isn't required for x86_64-linux where we use ncurses6 + lib.optionalString (!useNcurses6) "--replace-needed libtinfo.so libtinfo.so.5" + } \ + --interpreter ${glibcDynLinker} {} \; + + sed -i "s|/usr/bin/perl|perl\x00 |" ghc-${version}/ghc/stage2/build/tmp/ghc-stage2 + sed -i "s|/usr/bin/gcc|gcc\x00 |" ghc-${version}/ghc/stage2/build/tmp/ghc-stage2 + '' + + + # We're kludging a glibc bindist into working with non-glibc... + # Here we patch up the use of `__strdup` (part of glibc binary ABI) + # to instead use `strdup` since musl doesn't provide __strdup + # (`__strdup` is defined to be an alias of `strdup` anyway[1]). + # [1] http://refspecs.linuxbase.org/LSB_4.0.0/LSB-Core-generic/LSB-Core-generic/baselib---strdup-1.html + # Use objcopy magic to make the change: + lib.optionalString stdenv.hostPlatform.isMusl '' + find ./ghc-${version}/rts -name "libHSrts*.a" -exec ''${OBJCOPY:-objcopy} --redefine-sym __strdup=strdup {} \; + ''; configurePlatforms = [ ]; - configureFlags = [ - "--with-gmp-includes=${lib.getDev gmp}/include" - # Note `--with-gmp-libraries` does nothing for GHC bindists: - # https://gitlab.haskell.org/ghc/ghc/-/merge_requests/6124 - ] ++ lib.optional stdenv.hostPlatform.isDarwin "--with-gcc=${./gcc-clang-wrapper.sh}" + configureFlags = + [ + "--with-gmp-includes=${lib.getDev gmp}/include" + # Note `--with-gmp-libraries` does nothing for GHC bindists: + # https://gitlab.haskell.org/ghc/ghc/-/merge_requests/6124 + ] + ++ lib.optional stdenv.hostPlatform.isDarwin "--with-gcc=${./gcc-clang-wrapper.sh}" ++ lib.optional stdenv.hostPlatform.isMusl "--disable-ld-override"; # No building is necessary, but calling make without flags ironically @@ -160,25 +189,27 @@ stdenv.mkDerivation rec { # On Linux, use patchelf to modify the executables so that they can # find editline/gmp. - postFixup = lib.optionalString stdenv.hostPlatform.isLinux '' - for p in $(find "$out" -type f -executable); do - if isELF "$p"; then - echo "Patchelfing $p" - patchelf --set-rpath "${libPath}:$(patchelf --print-rpath $p)" $p - fi - done - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # not enough room in the object files for the full path to libiconv :( - for exe in $(find "$out" -type f -executable); do - isScript $exe && continue - ln -fs ${libiconv}/lib/libiconv.dylib $(dirname $exe)/libiconv.dylib - install_name_tool -change /usr/lib/libiconv.2.dylib @executable_path/libiconv.dylib -change /usr/local/lib/gcc/6/libgcc_s.1.dylib ${gcc.cc.lib}/lib/libgcc_s.1.dylib $exe - done + postFixup = + lib.optionalString stdenv.hostPlatform.isLinux '' + for p in $(find "$out" -type f -executable); do + if isELF "$p"; then + echo "Patchelfing $p" + patchelf --set-rpath "${libPath}:$(patchelf --print-rpath $p)" $p + fi + done + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # not enough room in the object files for the full path to libiconv :( + for exe in $(find "$out" -type f -executable); do + isScript $exe && continue + ln -fs ${libiconv}/lib/libiconv.dylib $(dirname $exe)/libiconv.dylib + install_name_tool -change /usr/lib/libiconv.2.dylib @executable_path/libiconv.dylib -change /usr/local/lib/gcc/6/libgcc_s.1.dylib ${gcc.cc.lib}/lib/libgcc_s.1.dylib $exe + done - for file in $(find "$out" -name setup-config); do - substituteInPlace $file --replace /usr/bin/ranlib "$(type -P ranlib)" - done - ''; + for file in $(find "$out" -name setup-config); do + substituteInPlace $file --replace /usr/bin/ranlib "$(type -P ranlib)" + done + ''; # In nixpkgs, musl based builds currently enable `pie` hardening by default # (see `defaultHardeningFlags` in `make-derivation.nix`). @@ -224,8 +255,11 @@ stdenv.mkDerivation rec { ]; # build segfaults, use ghc8107Binary which has proper musl support instead broken = stdenv.hostPlatform.isMusl; - maintainers = with lib.maintainers; [ - guibou - ] ++ lib.teams.haskell.members; + maintainers = + with lib.maintainers; + [ + guibou + ] + ++ lib.teams.haskell.members; }; } diff --git a/pkgs/development/compilers/ghc/9.2.4-binary.nix b/pkgs/development/compilers/ghc/9.2.4-binary.nix index e8c6d83ea82fe1..73873ec823a069 100644 --- a/pkgs/development/compilers/ghc/9.2.4-binary.nix +++ b/pkgs/development/compilers/ghc/9.2.4-binary.nix @@ -1,16 +1,24 @@ -{ lib, stdenv -, fetchurl, perl, gcc -, ncurses5 -, ncurses6, gmp, libiconv, numactl, libffi -, llvmPackages -, coreutils -, targetPackages +{ + lib, + stdenv, + fetchurl, + perl, + gcc, + ncurses5, + ncurses6, + gmp, + libiconv, + numactl, + libffi, + llvmPackages, + coreutils, + targetPackages, # minimal = true; will remove files that aren't strictly necessary for # regular builds and GHC bootstrapping. # This is "useful" for staying within hydra's output limits for at least the # aarch64-linux architecture. -, minimal ? false + minimal ? false, }: # Prebuilt only does native @@ -50,11 +58,17 @@ let }; exePathForLibraryCheck = "ghc/stage2/build/tmp/ghc-stage2"; archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } + { + nixPackage = gmp; + fileToCheckFor = null; + } # The i686-linux bindist provided by GHC HQ is currently built on Debian 9, # which link it against `libtinfo.so.5` (ncurses 5). # Other bindists are linked `libtinfo.so.6` (ncurses 6). - { nixPackage = ncurses5; fileToCheckFor = "libtinfo.so.5"; } + { + nixPackage = ncurses5; + fileToCheckFor = "libtinfo.so.5"; + } ]; }; x86_64-linux = { @@ -65,8 +79,14 @@ let }; exePathForLibraryCheck = "ghc/stage2/build/tmp/ghc-stage2"; archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = "libtinfo.so.6"; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = "libtinfo.so.6"; + } ]; }; aarch64-linux = { @@ -77,9 +97,18 @@ let }; exePathForLibraryCheck = "ghc/stage2/build/tmp/ghc-stage2"; archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = "libtinfo.so.6"; } - { nixPackage = numactl; fileToCheckFor = null; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = "libtinfo.so.6"; + } + { + nixPackage = numactl; + fileToCheckFor = null; + } ]; }; x86_64-darwin = { @@ -90,9 +119,18 @@ let }; exePathForLibraryCheck = null; # we don't have a library check for darwin yet archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = null; } - { nixPackage = libiconv; fileToCheckFor = null; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = null; + } + { + nixPackage = libiconv; + fileToCheckFor = null; + } ]; isHadrian = true; }; @@ -104,9 +142,18 @@ let }; exePathForLibraryCheck = null; # we don't have a library check for darwin yet archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = null; } - { nixPackage = libiconv; fileToCheckFor = null; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = null; + } + { + nixPackage = libiconv; + fileToCheckFor = null; + } ]; isHadrian = true; }; @@ -124,7 +171,10 @@ let # We can't check the RPATH for statically linked executable exePathForLibraryCheck = null; archSpecificLibraries = [ - { nixPackage = gmp.override { withStatic = true; }; fileToCheckFor = null; } + { + nixPackage = gmp.override { withStatic = true; }; + fileToCheckFor = null; + } ]; }; }; @@ -132,41 +182,44 @@ let distSetName = if stdenv.hostPlatform.isMusl then "musl" else "defaultLibc"; - binDistUsed = ghcBinDists.${distSetName}.${stdenv.hostPlatform.system} - or (throw "cannot bootstrap GHC on this platform ('${stdenv.hostPlatform.system}' with libc '${distSetName}')"); + binDistUsed = + ghcBinDists.${distSetName}.${stdenv.hostPlatform.system} + or (throw "cannot bootstrap GHC on this platform ('${stdenv.hostPlatform.system}' with libc '${distSetName}')"); - gmpUsed = (builtins.head ( - builtins.filter ( - drv: lib.hasPrefix "gmp" (drv.nixPackage.name or "") - ) binDistUsed.archSpecificLibraries - )).nixPackage; + gmpUsed = + (builtins.head ( + builtins.filter ( + drv: lib.hasPrefix "gmp" (drv.nixPackage.name or "") + ) binDistUsed.archSpecificLibraries + )).nixPackage; # GHC has other native backends (like PowerPC), but here only the ones # we ship bindists for matter. - useLLVM = !(stdenv.targetPlatform.isx86 - || (stdenv.targetPlatform.isAarch64 && stdenv.targetPlatform.isDarwin)); - - libPath = - lib.makeLibraryPath ( - # Add arch-specific libraries. - map ({ nixPackage, ... }: nixPackage) binDistUsed.archSpecificLibraries + useLLVM = + !( + stdenv.targetPlatform.isx86 || (stdenv.targetPlatform.isAarch64 && stdenv.targetPlatform.isDarwin) ); - libEnvVar = lib.optionalString stdenv.hostPlatform.isDarwin "DY" - + "LD_LIBRARY_PATH"; - - runtimeDeps = [ - targetPackages.stdenv.cc - targetPackages.stdenv.cc.bintools - coreutils # for cat - ] - ++ lib.optionals useLLVM [ - (lib.getBin llvmPackages.llvm) - ] - # On darwin, we need unwrapped bintools as well (for otool) - ++ lib.optionals (stdenv.targetPlatform.linker == "cctools") [ - targetPackages.stdenv.cc.bintools.bintools - ]; + libPath = lib.makeLibraryPath ( + # Add arch-specific libraries. + map ({ nixPackage, ... }: nixPackage) binDistUsed.archSpecificLibraries + ); + + libEnvVar = lib.optionalString stdenv.hostPlatform.isDarwin "DY" + "LD_LIBRARY_PATH"; + + runtimeDeps = + [ + targetPackages.stdenv.cc + targetPackages.stdenv.cc.bintools + coreutils # for cat + ] + ++ lib.optionals useLLVM [ + (lib.getBin llvmPackages.llvm) + ] + # On darwin, we need unwrapped bintools as well (for otool) + ++ lib.optionals (stdenv.targetPlatform.linker == "cctools") [ + targetPackages.stdenv.cc.bintools.bintools + ]; in @@ -188,12 +241,14 @@ stdenv.mkDerivation rec { # Verify our assumptions of which `libtinfo.so` (ncurses) version is used, # so that we know when ghc bindists upgrade that and we need to update the # version used in `libPath`. - lib.optionalString - (binDistUsed.exePathForLibraryCheck != null) + lib.optionalString (binDistUsed.exePathForLibraryCheck != null) # Note the `*` glob because some GHCs have a suffix when unpacked, e.g. # the musl bindist has dir `ghc-VERSION-x86_64-unknown-linux/`. # As a result, don't shell-quote this glob when splicing the string. - (let buildExeGlob = ''ghc-${version}*/"${binDistUsed.exePathForLibraryCheck}"''; in + ( + let + buildExeGlob = ''ghc-${version}*/"${binDistUsed.exePathForLibraryCheck}"''; + in lib.concatStringsSep "\n" [ ('' shopt -u nullglob @@ -202,24 +257,22 @@ stdenv.mkDerivation rec { echo >&2 "GHC binary ${binDistUsed.exePathForLibraryCheck} could not be found in the bindist build directory (at ${buildExeGlob}) for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; fi '') - (lib.concatMapStringsSep - "\n" - ({ fileToCheckFor, nixPackage }: - lib.optionalString (fileToCheckFor != null) '' - echo "Checking bindist for ${fileToCheckFor} to ensure that is still used" - if ! readelf -d ${buildExeGlob} | grep "${fileToCheckFor}"; then - echo >&2 "File ${fileToCheckFor} could not be found in ${binDistUsed.exePathForLibraryCheck} for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; - fi - - echo "Checking that the nix package ${nixPackage} contains ${fileToCheckFor}" - if ! test -e "${lib.getLib nixPackage}/lib/${fileToCheckFor}"; then - echo >&2 "Nix package ${nixPackage} did not contain ${fileToCheckFor} for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; - fi - '' - ) - binDistUsed.archSpecificLibraries - ) - ]) + (lib.concatMapStringsSep "\n" ( + { fileToCheckFor, nixPackage }: + lib.optionalString (fileToCheckFor != null) '' + echo "Checking bindist for ${fileToCheckFor} to ensure that is still used" + if ! readelf -d ${buildExeGlob} | grep "${fileToCheckFor}"; then + echo >&2 "File ${fileToCheckFor} could not be found in ${binDistUsed.exePathForLibraryCheck} for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; + fi + + echo "Checking that the nix package ${nixPackage} contains ${fileToCheckFor}" + if ! test -e "${lib.getLib nixPackage}/lib/${fileToCheckFor}"; then + echo >&2 "Nix package ${nixPackage} did not contain ${fileToCheckFor} for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; + fi + '' + ) binDistUsed.archSpecificLibraries) + ] + ) # GHC has dtrace probes, which causes ld to try to open /usr/lib/libdtrace.dylib # during linking + lib.optionalString stdenv.hostPlatform.isDarwin '' @@ -230,24 +283,27 @@ stdenv.mkDerivation rec { ln -fs ${libiconv}/lib/libiconv.dylib $(dirname $exe)/libiconv.dylib install_name_tool -change /usr/lib/libiconv.2.dylib @executable_path/libiconv.dylib -change /usr/local/lib/gcc/6/libgcc_s.1.dylib ${gcc.cc.lib}/lib/libgcc_s.1.dylib $exe done - '' + - - # Some scripts used during the build need to have their shebangs patched - '' - patchShebangs ghc-${version}/utils/ - patchShebangs ghc-${version}/configure - test -d ghc-${version}/inplace/bin && \ - patchShebangs ghc-${version}/inplace/bin - '' + - # We have to patch the GMP paths for the integer-gmp package. '' - find . -name ghc-bignum.buildinfo \ - -exec sed -i "s@extra-lib-dirs: @extra-lib-dirs: ${lib.getLib gmpUsed}/lib@" {} \; + + - # we need to modify the package db directly for hadrian bindists - find . -name 'ghc-bignum*.conf' \ - -exec sed -e '/^[a-z-]*library-dirs/a \ ${lib.getLib gmpUsed}/lib' -i {} \; - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Some scripts used during the build need to have their shebangs patched + '' + patchShebangs ghc-${version}/utils/ + patchShebangs ghc-${version}/configure + test -d ghc-${version}/inplace/bin && \ + patchShebangs ghc-${version}/inplace/bin + '' + + + # We have to patch the GMP paths for the integer-gmp package. + '' + find . -name ghc-bignum.buildinfo \ + -exec sed -i "s@extra-lib-dirs: @extra-lib-dirs: ${lib.getLib gmpUsed}/lib@" {} \; + + # we need to modify the package db directly for hadrian bindists + find . -name 'ghc-bignum*.conf' \ + -exec sed -e '/^[a-z-]*library-dirs/a \ ${lib.getLib gmpUsed}/lib' -i {} \; + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' # we need to modify the package db directly for hadrian bindists # (all darwin bindists are hadrian-based for 9.2.2) find . -name 'base*.conf' \ @@ -258,30 +314,32 @@ stdenv.mkDerivation rec { -exec sed -e '/^[a-z-]*library-dirs/a \ ${lib.getLib libffi}/lib' \ -e 's@/Library/Developer/.*/usr/include/ffi@${lib.getDev libffi}/include@' \ -i {} \; - '' + - # aarch64 does HAVE_NUMA so -lnuma requires it in library-dirs in rts/package.conf.in - # FFI_LIB_DIR is a good indication of places it must be needed. - lib.optionalString (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) '' - find . -name package.conf.in \ - -exec sed -i "s@FFI_LIB_DIR@FFI_LIB_DIR ${numactl.out}/lib@g" {} \; - '' + - # Rename needed libraries and binaries, fix interpreter - lib.optionalString stdenv.hostPlatform.isLinux '' - find . -type f -executable -exec patchelf \ - --interpreter ${stdenv.cc.bintools.dynamicLinker} {} \; - ''; + '' + + + # aarch64 does HAVE_NUMA so -lnuma requires it in library-dirs in rts/package.conf.in + # FFI_LIB_DIR is a good indication of places it must be needed. + lib.optionalString (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) '' + find . -name package.conf.in \ + -exec sed -i "s@FFI_LIB_DIR@FFI_LIB_DIR ${numactl.out}/lib@g" {} \; + '' + + + # Rename needed libraries and binaries, fix interpreter + lib.optionalString stdenv.hostPlatform.isLinux '' + find . -type f -executable -exec patchelf \ + --interpreter ${stdenv.cc.bintools.dynamicLinker} {} \; + ''; # fix for `configure: error: Your linker is affected by binutils #16177` - preConfigure = lib.optionalString - stdenv.targetPlatform.isAarch32 - "LD=ld.gold"; + preConfigure = lib.optionalString stdenv.targetPlatform.isAarch32 "LD=ld.gold"; configurePlatforms = [ ]; - configureFlags = [ - "--with-gmp-includes=${lib.getDev gmpUsed}/include" - # Note `--with-gmp-libraries` does nothing for GHC bindists: - # https://gitlab.haskell.org/ghc/ghc/-/merge_requests/6124 - ] ++ lib.optional stdenv.hostPlatform.isDarwin "--with-gcc=${./gcc-clang-wrapper.sh}" + configureFlags = + [ + "--with-gmp-includes=${lib.getDev gmpUsed}/include" + # Note `--with-gmp-libraries` does nothing for GHC bindists: + # https://gitlab.haskell.org/ghc/ghc/-/merge_requests/6124 + ] + ++ lib.optional stdenv.hostPlatform.isDarwin "--with-gcc=${./gcc-clang-wrapper.sh}" # From: https://github.com/NixOS/nixpkgs/pull/43369/commits ++ lib.optional stdenv.hostPlatform.isMusl "--disable-ld-override"; @@ -316,65 +374,68 @@ stdenv.mkDerivation rec { # On Linux, use patchelf to modify the executables so that they can # find editline/gmp. - postFixup = lib.optionalString (stdenv.hostPlatform.isLinux && !(binDistUsed.isStatic or false)) - (if stdenv.hostPlatform.isAarch64 then - # Keep rpath as small as possible on aarch64 for patchelf#244. All Elfs - # are 2 directories deep from $out/lib, so pooling symlinks there makes - # a short rpath. - '' - (cd $out/lib; ln -s ${ncurses6.out}/lib/libtinfo.so.6) - (cd $out/lib; ln -s ${lib.getLib gmpUsed}/lib/libgmp.so.10) - (cd $out/lib; ln -s ${numactl.out}/lib/libnuma.so.1) - for p in $(find "$out/lib" -type f -name "*\.so*"); do - (cd $out/lib; ln -s $p) + postFixup = + lib.optionalString (stdenv.hostPlatform.isLinux && !(binDistUsed.isStatic or false)) ( + if stdenv.hostPlatform.isAarch64 then + # Keep rpath as small as possible on aarch64 for patchelf#244. All Elfs + # are 2 directories deep from $out/lib, so pooling symlinks there makes + # a short rpath. + '' + (cd $out/lib; ln -s ${ncurses6.out}/lib/libtinfo.so.6) + (cd $out/lib; ln -s ${lib.getLib gmpUsed}/lib/libgmp.so.10) + (cd $out/lib; ln -s ${numactl.out}/lib/libnuma.so.1) + for p in $(find "$out/lib" -type f -name "*\.so*"); do + (cd $out/lib; ln -s $p) + done + + for p in $(find "$out/lib" -type f -executable); do + if isELF "$p"; then + echo "Patchelfing $p" + patchelf --set-rpath "\$ORIGIN:\$ORIGIN/../.." $p + fi + done + '' + else + '' + for p in $(find "$out" -type f -executable); do + if isELF "$p"; then + echo "Patchelfing $p" + patchelf --set-rpath "${libPath}:$(patchelf --print-rpath $p)" $p + fi + done + '' + ) + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # not enough room in the object files for the full path to libiconv :( + for exe in $(find "$out" -type f -executable); do + isScript $exe && continue + ln -fs ${libiconv}/lib/libiconv.dylib $(dirname $exe)/libiconv.dylib + install_name_tool -change /usr/lib/libiconv.2.dylib @executable_path/libiconv.dylib -change /usr/local/lib/gcc/6/libgcc_s.1.dylib ${gcc.cc.lib}/lib/libgcc_s.1.dylib $exe done - for p in $(find "$out/lib" -type f -executable); do - if isELF "$p"; then - echo "Patchelfing $p" - patchelf --set-rpath "\$ORIGIN:\$ORIGIN/../.." $p - fi + for file in $(find "$out" -name setup-config); do + substituteInPlace $file --replace /usr/bin/ranlib "$(type -P ranlib)" done - '' - else - '' - for p in $(find "$out" -type f -executable); do - if isELF "$p"; then - echo "Patchelfing $p" - patchelf --set-rpath "${libPath}:$(patchelf --print-rpath $p)" $p - fi - done - '') + lib.optionalString stdenv.hostPlatform.isDarwin '' - # not enough room in the object files for the full path to libiconv :( - for exe in $(find "$out" -type f -executable); do - isScript $exe && continue - ln -fs ${libiconv}/lib/libiconv.dylib $(dirname $exe)/libiconv.dylib - install_name_tool -change /usr/lib/libiconv.2.dylib @executable_path/libiconv.dylib -change /usr/local/lib/gcc/6/libgcc_s.1.dylib ${gcc.cc.lib}/lib/libgcc_s.1.dylib $exe - done - - for file in $(find "$out" -name setup-config); do - substituteInPlace $file --replace /usr/bin/ranlib "$(type -P ranlib)" - done - '' + - lib.optionalString minimal '' - # Remove profiling files - find $out -type f -name '*.p_o' -delete - find $out -type f -name '*.p_hi' -delete - find $out -type f -name '*_p.a' -delete - # `-f` because e.g. musl bindist does not have this file. - rm -f $out/lib/ghc-*/bin/ghc-iserv-prof - # Hydra will redistribute this derivation, so we have to keep the docs for - # legal reasons (retaining the legal notices etc) - # As a last resort we could unpack the docs separately and symlink them in. - # They're in $out/share/{doc,man}. - '' - # Recache package db which needs to happen for Hadrian bindists - # where we modify the package db before installing - + '' - shopt -s nullglob - package_db=("$out"/lib/ghc-*/lib/package.conf.d "$out"/lib/ghc-*/package.conf.d) - "$out/bin/ghc-pkg" --package-db="$package_db" recache - ''; + '' + + lib.optionalString minimal '' + # Remove profiling files + find $out -type f -name '*.p_o' -delete + find $out -type f -name '*.p_hi' -delete + find $out -type f -name '*_p.a' -delete + # `-f` because e.g. musl bindist does not have this file. + rm -f $out/lib/ghc-*/bin/ghc-iserv-prof + # Hydra will redistribute this derivation, so we have to keep the docs for + # legal reasons (retaining the legal notices etc) + # As a last resort we could unpack the docs separately and symlink them in. + # They're in $out/share/{doc,man}. + '' + # Recache package db which needs to happen for Hadrian bindists + # where we modify the package db before installing + + '' + shopt -s nullglob + package_db=("$out"/lib/ghc-*/lib/package.conf.d "$out"/lib/ghc-*/package.conf.d) + "$out/bin/ghc-pkg" --package-db="$package_db" recache + ''; # In nixpkgs, musl based builds currently enable `pie` hardening by default # (see `defaultHardeningFlags` in `make-derivation.nix`). @@ -400,25 +461,26 @@ stdenv.mkDerivation rec { [ $(./main) == "yes" ] ''; - passthru = { - targetPrefix = ""; - enableShared = true; - - inherit llvmPackages; - - # Our Cabal compiler name - haskellCompilerName = "ghc-${version}"; - } - # We duplicate binDistUsed here since we have a sensible default even if no bindist is avaible, - # this makes sure that getting the `meta` attribute doesn't throw even on unsupported platforms. - // lib.optionalAttrs (ghcBinDists.${distSetName}.${stdenv.hostPlatform.system}.isHadrian or false) { - # Normal GHC derivations expose the hadrian derivation used to build them - # here. In the case of bindists we just make sure that the attribute exists, - # as it is used for checking if a GHC derivation has been built with hadrian. - # The isHadrian mechanism will become obsolete with GHCs that use hadrian - # exclusively, i.e. 9.6 (and 9.4?). - hadrian = null; - }; + passthru = + { + targetPrefix = ""; + enableShared = true; + + inherit llvmPackages; + + # Our Cabal compiler name + haskellCompilerName = "ghc-${version}"; + } + # We duplicate binDistUsed here since we have a sensible default even if no bindist is avaible, + # this makes sure that getting the `meta` attribute doesn't throw even on unsupported platforms. + // lib.optionalAttrs (ghcBinDists.${distSetName}.${stdenv.hostPlatform.system}.isHadrian or false) { + # Normal GHC derivations expose the hadrian derivation used to build them + # here. In the case of bindists we just make sure that the attribute exists, + # as it is used for checking if a GHC derivation has been built with hadrian. + # The isHadrian mechanism will become obsolete with GHCs that use hadrian + # exclusively, i.e. 9.6 (and 9.4?). + hadrian = null; + }; meta = rec { homepage = "http://haskell.org/ghc"; diff --git a/pkgs/development/compilers/ghc/9.6.3-binary.nix b/pkgs/development/compilers/ghc/9.6.3-binary.nix index 6d8f195bb9d30e..96bf217884b6ad 100644 --- a/pkgs/development/compilers/ghc/9.6.3-binary.nix +++ b/pkgs/development/compilers/ghc/9.6.3-binary.nix @@ -1,16 +1,24 @@ -{ lib, stdenv -, fetchurl, perl, gcc -, ncurses5 -, ncurses6, gmp, libiconv, numactl, libffi -, llvmPackages -, coreutils -, targetPackages +{ + lib, + stdenv, + fetchurl, + perl, + gcc, + ncurses5, + ncurses6, + gmp, + libiconv, + numactl, + libffi, + llvmPackages, + coreutils, + targetPackages, # minimal = true; will remove files that aren't strictly necessary for # regular builds and GHC bootstrapping. # This is "useful" for staying within hydra's output limits for at least the # aarch64-linux architecture. -, minimal ? false + minimal ? false, }: # Prebuilt only does native @@ -50,11 +58,17 @@ let }; exePathForLibraryCheck = "bin/ghc"; archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } + { + nixPackage = gmp; + fileToCheckFor = null; + } # The i686-linux bindist provided by GHC HQ is currently built on Debian 9, # which link it against `libtinfo.so.5` (ncurses 5). # Other bindists are linked `libtinfo.so.6` (ncurses 6). - { nixPackage = ncurses5; fileToCheckFor = "libtinfo.so.5"; } + { + nixPackage = ncurses5; + fileToCheckFor = "libtinfo.so.5"; + } ]; }; x86_64-linux = { @@ -65,8 +79,14 @@ let }; exePathForLibraryCheck = "bin/ghc"; archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = "libtinfo.so.6"; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = "libtinfo.so.6"; + } ]; }; aarch64-linux = { @@ -77,9 +97,18 @@ let }; exePathForLibraryCheck = "bin/ghc"; archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = "libtinfo.so.6"; } - { nixPackage = numactl; fileToCheckFor = null; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = "libtinfo.so.6"; + } + { + nixPackage = numactl; + fileToCheckFor = null; + } ]; }; x86_64-darwin = { @@ -90,9 +119,18 @@ let }; exePathForLibraryCheck = null; # we don't have a library check for darwin yet archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = null; } - { nixPackage = libiconv; fileToCheckFor = null; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = null; + } + { + nixPackage = libiconv; + fileToCheckFor = null; + } ]; }; aarch64-darwin = { @@ -103,9 +141,18 @@ let }; exePathForLibraryCheck = null; # we don't have a library check for darwin yet archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = null; } - { nixPackage = libiconv; fileToCheckFor = null; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = null; + } + { + nixPackage = libiconv; + fileToCheckFor = null; + } ]; }; }; @@ -119,8 +166,14 @@ let }; exePathForLibraryCheck = "bin/ghc"; archSpecificLibraries = [ - { nixPackage = gmp; fileToCheckFor = null; } - { nixPackage = ncurses6; fileToCheckFor = "libncursesw.so.6"; } + { + nixPackage = gmp; + fileToCheckFor = null; + } + { + nixPackage = ncurses6; + fileToCheckFor = "libncursesw.so.6"; + } ]; }; }; @@ -128,41 +181,44 @@ let distSetName = if stdenv.hostPlatform.isMusl then "musl" else "defaultLibc"; - binDistUsed = ghcBinDists.${distSetName}.${stdenv.hostPlatform.system} - or (throw "cannot bootstrap GHC on this platform ('${stdenv.hostPlatform.system}' with libc '${distSetName}')"); + binDistUsed = + ghcBinDists.${distSetName}.${stdenv.hostPlatform.system} + or (throw "cannot bootstrap GHC on this platform ('${stdenv.hostPlatform.system}' with libc '${distSetName}')"); - gmpUsed = (builtins.head ( - builtins.filter ( - drv: lib.hasPrefix "gmp" (drv.nixPackage.name or "") - ) binDistUsed.archSpecificLibraries - )).nixPackage; + gmpUsed = + (builtins.head ( + builtins.filter ( + drv: lib.hasPrefix "gmp" (drv.nixPackage.name or "") + ) binDistUsed.archSpecificLibraries + )).nixPackage; # GHC has other native backends (like PowerPC), but here only the ones # we ship bindists for matter. - useLLVM = !(stdenv.targetPlatform.isx86 - || (stdenv.targetPlatform.isAarch64 && stdenv.targetPlatform.isDarwin)); - - libPath = - lib.makeLibraryPath ( - # Add arch-specific libraries. - map ({ nixPackage, ... }: nixPackage) binDistUsed.archSpecificLibraries + useLLVM = + !( + stdenv.targetPlatform.isx86 || (stdenv.targetPlatform.isAarch64 && stdenv.targetPlatform.isDarwin) ); - libEnvVar = lib.optionalString stdenv.hostPlatform.isDarwin "DY" - + "LD_LIBRARY_PATH"; - - runtimeDeps = [ - targetPackages.stdenv.cc - targetPackages.stdenv.cc.bintools - coreutils # for cat - ] - ++ lib.optionals useLLVM [ - (lib.getBin llvmPackages.llvm) - ] - # On darwin, we need unwrapped bintools as well (for otool) - ++ lib.optionals (stdenv.targetPlatform.linker == "cctools") [ - targetPackages.stdenv.cc.bintools.bintools - ]; + libPath = lib.makeLibraryPath ( + # Add arch-specific libraries. + map ({ nixPackage, ... }: nixPackage) binDistUsed.archSpecificLibraries + ); + + libEnvVar = lib.optionalString stdenv.hostPlatform.isDarwin "DY" + "LD_LIBRARY_PATH"; + + runtimeDeps = + [ + targetPackages.stdenv.cc + targetPackages.stdenv.cc.bintools + coreutils # for cat + ] + ++ lib.optionals useLLVM [ + (lib.getBin llvmPackages.llvm) + ] + # On darwin, we need unwrapped bintools as well (for otool) + ++ lib.optionals (stdenv.targetPlatform.linker == "cctools") [ + targetPackages.stdenv.cc.bintools.bintools + ]; in @@ -184,12 +240,14 @@ stdenv.mkDerivation rec { # Verify our assumptions of which `libtinfo.so` (ncurses) version is used, # so that we know when ghc bindists upgrade that and we need to update the # version used in `libPath`. - lib.optionalString - (binDistUsed.exePathForLibraryCheck != null) + lib.optionalString (binDistUsed.exePathForLibraryCheck != null) # Note the `*` glob because some GHCs have a suffix when unpacked, e.g. # the musl bindist has dir `ghc-VERSION-x86_64-unknown-linux/`. # As a result, don't shell-quote this glob when splicing the string. - (let buildExeGlob = ''ghc-${version}*/"${binDistUsed.exePathForLibraryCheck}"''; in + ( + let + buildExeGlob = ''ghc-${version}*/"${binDistUsed.exePathForLibraryCheck}"''; + in lib.concatStringsSep "\n" [ ('' shopt -u nullglob @@ -198,24 +256,22 @@ stdenv.mkDerivation rec { echo >&2 "GHC binary ${binDistUsed.exePathForLibraryCheck} could not be found in the bindist build directory (at ${buildExeGlob}) for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; fi '') - (lib.concatMapStringsSep - "\n" - ({ fileToCheckFor, nixPackage }: - lib.optionalString (fileToCheckFor != null) '' - echo "Checking bindist for ${fileToCheckFor} to ensure that is still used" - if ! readelf -d ${buildExeGlob} | grep "${fileToCheckFor}"; then - echo >&2 "File ${fileToCheckFor} could not be found in ${binDistUsed.exePathForLibraryCheck} for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; - fi - - echo "Checking that the nix package ${nixPackage} contains ${fileToCheckFor}" - if ! test -e "${lib.getLib nixPackage}/lib/${fileToCheckFor}"; then - echo >&2 "Nix package ${nixPackage} did not contain ${fileToCheckFor} for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; - fi - '' - ) - binDistUsed.archSpecificLibraries - ) - ]) + (lib.concatMapStringsSep "\n" ( + { fileToCheckFor, nixPackage }: + lib.optionalString (fileToCheckFor != null) '' + echo "Checking bindist for ${fileToCheckFor} to ensure that is still used" + if ! readelf -d ${buildExeGlob} | grep "${fileToCheckFor}"; then + echo >&2 "File ${fileToCheckFor} could not be found in ${binDistUsed.exePathForLibraryCheck} for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; + fi + + echo "Checking that the nix package ${nixPackage} contains ${fileToCheckFor}" + if ! test -e "${lib.getLib nixPackage}/lib/${fileToCheckFor}"; then + echo >&2 "Nix package ${nixPackage} did not contain ${fileToCheckFor} for arch ${stdenv.hostPlatform.system}, please check that ghcBinDists correctly reflect the bindist dependencies!"; exit 1; + fi + '' + ) binDistUsed.archSpecificLibraries) + ] + ) # GHC has dtrace probes, which causes ld to try to open /usr/lib/libdtrace.dylib # during linking + lib.optionalString stdenv.hostPlatform.isDarwin '' @@ -244,23 +300,23 @@ stdenv.mkDerivation rec { -exec sed -e '/^[a-z-]*library-dirs/a \ ${lib.getLib libffi}/lib' \ -e 's@/Library/Developer/.*/usr/include/ffi@${lib.getDev libffi}/include@' \ -i {} \; - '' + - # aarch64 does HAVE_NUMA so -lnuma requires it in library-dirs in rts/package.conf.in - # FFI_LIB_DIR is a good indication of places it must be needed. - lib.optionalString (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) '' - find . -name package.conf.in \ - -exec sed -i "s@FFI_LIB_DIR@FFI_LIB_DIR ${numactl.out}/lib@g" {} \; - '' + - # Rename needed libraries and binaries, fix interpreter - lib.optionalString stdenv.hostPlatform.isLinux '' - find . -type f -executable -exec patchelf \ - --interpreter ${stdenv.cc.bintools.dynamicLinker} {} \; - ''; + '' + + + # aarch64 does HAVE_NUMA so -lnuma requires it in library-dirs in rts/package.conf.in + # FFI_LIB_DIR is a good indication of places it must be needed. + lib.optionalString (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) '' + find . -name package.conf.in \ + -exec sed -i "s@FFI_LIB_DIR@FFI_LIB_DIR ${numactl.out}/lib@g" {} \; + '' + + + # Rename needed libraries and binaries, fix interpreter + lib.optionalString stdenv.hostPlatform.isLinux '' + find . -type f -executable -exec patchelf \ + --interpreter ${stdenv.cc.bintools.dynamicLinker} {} \; + ''; # fix for `configure: error: Your linker is affected by binutils #16177` - preConfigure = lib.optionalString - stdenv.targetPlatform.isAarch32 - "LD=ld.gold"; + preConfigure = lib.optionalString stdenv.targetPlatform.isAarch32 "LD=ld.gold"; # GHC has a patched config.sub and bindists' platforms should always work dontUpdateAutotoolsGnuConfigScripts = true; @@ -276,19 +332,21 @@ stdenv.mkDerivation rec { dontBuild = true; # Patch scripts to include runtime dependencies in $PATH. - postInstall = '' - for i in "$out/bin/"*; do - test ! -h "$i" || continue - isScript "$i" || continue - sed -i -e '2i export PATH="${lib.makeBinPath runtimeDeps}:$PATH"' "$i" - done - '' + lib.optionalString stdenv.targetPlatform.isDarwin '' - # Work around building with binary GHC on Darwin due to GHC’s use of `ar -L` when it - # detects `llvm-ar` even though the resulting archives are not supported by ld64. - # https://gitlab.haskell.org/ghc/ghc/-/issues/23188 - # https://github.com/haskell/cabal/issues/8882 - sed -i -e 's/,("ar supports -L", "YES")/,("ar supports -L", "NO")/' "$out/lib/ghc-${version}/lib/settings" - ''; + postInstall = + '' + for i in "$out/bin/"*; do + test ! -h "$i" || continue + isScript "$i" || continue + sed -i -e '2i export PATH="${lib.makeBinPath runtimeDeps}:$PATH"' "$i" + done + '' + + lib.optionalString stdenv.targetPlatform.isDarwin '' + # Work around building with binary GHC on Darwin due to GHC’s use of `ar -L` when it + # detects `llvm-ar` even though the resulting archives are not supported by ld64. + # https://gitlab.haskell.org/ghc/ghc/-/issues/23188 + # https://github.com/haskell/cabal/issues/8882 + sed -i -e 's/,("ar supports -L", "YES")/,("ar supports -L", "NO")/' "$out/lib/ghc-${version}/lib/settings" + ''; # Apparently necessary for the ghc Alpine (musl) bindist: # When we strip, and then run the @@ -308,52 +366,55 @@ stdenv.mkDerivation rec { # On Linux, use patchelf to modify the executables so that they can # find editline/gmp. - postFixup = lib.optionalString (stdenv.hostPlatform.isLinux && !(binDistUsed.isStatic or false)) - (if stdenv.hostPlatform.isAarch64 then - # Keep rpath as small as possible on aarch64 for patchelf#244. All Elfs - # are 2 directories deep from $out/lib, so pooling symlinks there makes - # a short rpath. - '' - (cd $out/lib; ln -s ${ncurses6.out}/lib/libtinfo.so.6) - (cd $out/lib; ln -s ${lib.getLib gmpUsed}/lib/libgmp.so.10) - (cd $out/lib; ln -s ${numactl.out}/lib/libnuma.so.1) - for p in $(find "$out/lib" -type f -name "*\.so*"); do - (cd $out/lib; ln -s $p) + postFixup = + lib.optionalString (stdenv.hostPlatform.isLinux && !(binDistUsed.isStatic or false)) ( + if stdenv.hostPlatform.isAarch64 then + # Keep rpath as small as possible on aarch64 for patchelf#244. All Elfs + # are 2 directories deep from $out/lib, so pooling symlinks there makes + # a short rpath. + '' + (cd $out/lib; ln -s ${ncurses6.out}/lib/libtinfo.so.6) + (cd $out/lib; ln -s ${lib.getLib gmpUsed}/lib/libgmp.so.10) + (cd $out/lib; ln -s ${numactl.out}/lib/libnuma.so.1) + for p in $(find "$out/lib" -type f -name "*\.so*"); do + (cd $out/lib; ln -s $p) + done + + for p in $(find "$out/lib" -type f -executable); do + if isELF "$p"; then + echo "Patchelfing $p" + patchelf --set-rpath "\$ORIGIN:\$ORIGIN/../.." $p + fi + done + '' + else + '' + for p in $(find "$out" -type f -executable); do + if isELF "$p"; then + echo "Patchelfing $p" + patchelf --set-rpath "${libPath}:$(patchelf --print-rpath $p)" $p + fi + done + '' + ) + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # not enough room in the object files for the full path to libiconv :( + for exe in $(find "$out" -type f -executable); do + isMachO $exe || continue + ln -fs ${libiconv}/lib/libiconv.dylib $(dirname $exe)/libiconv.dylib + install_name_tool -change /usr/lib/libiconv.2.dylib @executable_path/libiconv.dylib -change /usr/local/lib/gcc/6/libgcc_s.1.dylib ${gcc.cc.lib}/lib/libgcc_s.1.dylib $exe done - for p in $(find "$out/lib" -type f -executable); do - if isELF "$p"; then - echo "Patchelfing $p" - patchelf --set-rpath "\$ORIGIN:\$ORIGIN/../.." $p - fi - done - '' - else - '' - for p in $(find "$out" -type f -executable); do - if isELF "$p"; then - echo "Patchelfing $p" - patchelf --set-rpath "${libPath}:$(patchelf --print-rpath $p)" $p - fi + for file in $(find "$out" -name setup-config); do + substituteInPlace $file --replace /usr/bin/ranlib "$(type -P ranlib)" done - '') + lib.optionalString stdenv.hostPlatform.isDarwin '' - # not enough room in the object files for the full path to libiconv :( - for exe in $(find "$out" -type f -executable); do - isMachO $exe || continue - ln -fs ${libiconv}/lib/libiconv.dylib $(dirname $exe)/libiconv.dylib - install_name_tool -change /usr/lib/libiconv.2.dylib @executable_path/libiconv.dylib -change /usr/local/lib/gcc/6/libgcc_s.1.dylib ${gcc.cc.lib}/lib/libgcc_s.1.dylib $exe - done - - for file in $(find "$out" -name setup-config); do - substituteInPlace $file --replace /usr/bin/ranlib "$(type -P ranlib)" - done - '' - # Recache package db which needs to happen for Hadrian bindists - # where we modify the package db before installing - + '' - package_db=("$out"/lib/ghc-*/lib/package.conf.d) - "$out/bin/ghc-pkg" --package-db="$package_db" recache - ''; + '' + # Recache package db which needs to happen for Hadrian bindists + # where we modify the package db before installing + + '' + package_db=("$out"/lib/ghc-*/lib/package.conf.d) + "$out/bin/ghc-pkg" --package-db="$package_db" recache + ''; # In nixpkgs, musl based builds currently enable `pie` hardening by default # (see `defaultHardeningFlags` in `make-derivation.nix`). diff --git a/pkgs/development/compilers/ghc/common-make-native-bignum.nix b/pkgs/development/compilers/ghc/common-make-native-bignum.nix index 7593a175c77cd7..d4cb0f706572a6 100644 --- a/pkgs/development/compilers/ghc/common-make-native-bignum.nix +++ b/pkgs/development/compilers/ghc/common-make-native-bignum.nix @@ -1,88 +1,115 @@ -{ version -, sha256 -, url ? "https://downloads.haskell.org/ghc/${version}/ghc-${version}-src.tar.xz" +{ + version, + sha256, + url ? "https://downloads.haskell.org/ghc/${version}/ghc-${version}-src.tar.xz", }: -{ lib, stdenv, pkgsBuildTarget, pkgsHostTarget, buildPackages, targetPackages - -# build-tools -, bootPkgs -, autoconf, automake, coreutils, fetchpatch, fetchurl, perl, python3, m4, sphinx -, xattr, autoSignDarwinBinariesHook -, bash - -, libiconv ? null, ncurses -, glibcLocales ? null - -, # GHC can be built with system libffi or a bundled one. - libffi ? null - -, useLLVM ? !(stdenv.targetPlatform.isx86 - || stdenv.targetPlatform.isPower - || stdenv.targetPlatform.isSparc - || (lib.versionAtLeast version "9.2" && stdenv.targetPlatform.isAarch64)) -, # LLVM is conceptually a run-time-only dependency, but for +{ + lib, + stdenv, + pkgsBuildTarget, + pkgsHostTarget, + buildPackages, + targetPackages, + + # build-tools + bootPkgs, + autoconf, + automake, + coreutils, + fetchpatch, + fetchurl, + perl, + python3, + m4, + sphinx, + xattr, + autoSignDarwinBinariesHook, + bash, + + libiconv ? null, + ncurses, + glibcLocales ? null, + + # GHC can be built with system libffi or a bundled one. + libffi ? null, + + useLLVM ? + !( + stdenv.targetPlatform.isx86 + || stdenv.targetPlatform.isPower + || stdenv.targetPlatform.isSparc + || (lib.versionAtLeast version "9.2" && stdenv.targetPlatform.isAarch64) + ), + # LLVM is conceptually a run-time-only dependency, but for # non-x86, we need LLVM to bootstrap later stages, so it becomes a # build-time dependency too. - buildTargetLlvmPackages, llvmPackages + buildTargetLlvmPackages, + llvmPackages, -, # If enabled, GHC will be built with the GPL-free but slightly slower native + # If enabled, GHC will be built with the GPL-free but slightly slower native # bignum backend instead of the faster but GPLed gmp backend. - enableNativeBignum ? !(lib.meta.availableOn stdenv.hostPlatform gmp - && lib.meta.availableOn stdenv.targetPlatform gmp) -, gmp + enableNativeBignum ? + !(lib.meta.availableOn stdenv.hostPlatform gmp && lib.meta.availableOn stdenv.targetPlatform gmp), + gmp, -, # If enabled, use -fPIC when compiling static libs. - enableRelocatedStaticLibs ? stdenv.targetPlatform != stdenv.hostPlatform + # If enabled, use -fPIC when compiling static libs. + enableRelocatedStaticLibs ? stdenv.targetPlatform != stdenv.hostPlatform, # Exceeds Hydra output limit (at the time of writing ~3GB) when cross compiled to riscv64. # A riscv64 cross-compiler fits into the limit comfortably. -, enableProfiledLibs ? !stdenv.hostPlatform.isRiscV64 + enableProfiledLibs ? !stdenv.hostPlatform.isRiscV64, -, # Whether to build dynamic libs for the standard library (on the target + # Whether to build dynamic libs for the standard library (on the target # platform). Static libs are always built. - enableShared ? with stdenv.targetPlatform; !isWindows && !useiOSPrebuilt && !isStatic - -, # Whether to build terminfo. - enableTerminfo ? !(stdenv.targetPlatform.isWindows - # terminfo can't be built for cross - || (stdenv.buildPlatform != stdenv.hostPlatform) - || (stdenv.hostPlatform != stdenv.targetPlatform)) - -, # What flavour to build. An empty string indicates no + enableShared ? with stdenv.targetPlatform; !isWindows && !useiOSPrebuilt && !isStatic, + + # Whether to build terminfo. + enableTerminfo ? + !( + stdenv.targetPlatform.isWindows + # terminfo can't be built for cross + || (stdenv.buildPlatform != stdenv.hostPlatform) + || (stdenv.hostPlatform != stdenv.targetPlatform) + ), + + # What flavour to build. An empty string indicates no # specific flavour and falls back to ghc default values. - ghcFlavour ? lib.optionalString (stdenv.targetPlatform != stdenv.hostPlatform) - (if useLLVM then "perf-cross" else "perf-cross-ncg") + ghcFlavour ? lib.optionalString (stdenv.targetPlatform != stdenv.hostPlatform) ( + if useLLVM then "perf-cross" else "perf-cross-ncg" + ), -, # Whether to build sphinx documentation. + # Whether to build sphinx documentation. enableDocs ? ( # Docs disabled if we are building on musl because it's a large task to keep # all `sphinx` dependencies building in this environment. !stdenv.buildPlatform.isMusl - ) + ), -, enableHaddockProgram ? + enableHaddockProgram ? # Disabled for cross; see note [HADDOCK_DOCS]. - (stdenv.buildPlatform == stdenv.hostPlatform && stdenv.targetPlatform == stdenv.hostPlatform) + (stdenv.buildPlatform == stdenv.hostPlatform && stdenv.targetPlatform == stdenv.hostPlatform), -, # Whether to disable the large address space allocator + # Whether to disable the large address space allocator # necessary fix for iOS: https://www.reddit.com/r/haskell/comments/4ttdz1/building_an_osxi386_to_iosarm64_cross_compiler/d5qvd67/ - disableLargeAddressSpace ? stdenv.targetPlatform.isiOS + disableLargeAddressSpace ? stdenv.targetPlatform.isiOS, -, # Whether to build an unregisterised version of GHC. + # Whether to build an unregisterised version of GHC. # GHC will normally auto-detect whether it can do a registered build, but this # option will force it to do an unregistered build when set to true. # See https://gitlab.haskell.org/ghc/ghc/-/wikis/building/unregisterised # Registerised RV64 compiler produces programs that segfault # See https://gitlab.haskell.org/ghc/ghc/-/issues/23957 - enableUnregisterised ? stdenv.hostPlatform.isRiscV64 || stdenv.targetPlatform.isRiscV64 + enableUnregisterised ? stdenv.hostPlatform.isRiscV64 || stdenv.targetPlatform.isRiscV64, }: assert !enableNativeBignum -> gmp != null; # Cross cannot currently build the `haddock` program for silly reasons, # see note [HADDOCK_DOCS]. -assert (stdenv.buildPlatform != stdenv.hostPlatform || stdenv.targetPlatform != stdenv.hostPlatform) -> !enableHaddockProgram; +assert + (stdenv.buildPlatform != stdenv.hostPlatform || stdenv.targetPlatform != stdenv.hostPlatform) + -> !enableHaddockProgram; # GHC does not support building when all 3 platforms are different. assert stdenv.buildPlatform == stdenv.hostPlatform || stdenv.hostPlatform == stdenv.targetPlatform; @@ -91,56 +118,62 @@ let inherit (stdenv) buildPlatform hostPlatform targetPlatform; # TODO(@Ericson2314) Make unconditional - targetPrefix = lib.optionalString - (targetPlatform != hostPlatform) - "${targetPlatform.config}-"; - - buildMK = '' - BuildFlavour = ${ghcFlavour} - ifneq \"\$(BuildFlavour)\" \"\" - include mk/flavours/\$(BuildFlavour).mk - endif - BUILD_SPHINX_HTML = ${if enableDocs then "YES" else "NO"} - BUILD_SPHINX_PDF = NO - - WITH_TERMINFO = ${if enableTerminfo then "YES" else "NO"} - '' + - # Note [HADDOCK_DOCS]: - # Unfortunately currently `HADDOCK_DOCS` controls both whether the `haddock` - # program is built (which we generally always want to have a complete GHC install) - # and whether it is run on the GHC sources to generate hyperlinked source code - # (which is impossible for cross-compilation); see: - # https://gitlab.haskell.org/ghc/ghc/-/issues/20077 - # This implies that currently a cross-compiled GHC will never have a `haddock` - # program, so it can never generate haddocks for any packages. - # If this is solved in the future, we'd like to unconditionally - # build the haddock program (removing the `enableHaddockProgram` option). - '' - HADDOCK_DOCS = ${if enableHaddockProgram then "YES" else "NO"} - # Build haddocks for boot packages with hyperlinking - EXTRA_HADDOCK_OPTS += --hyperlinked-source --quickjump - - DYNAMIC_GHC_PROGRAMS = ${if enableShared then "YES" else "NO"} - BIGNUM_BACKEND = ${if enableNativeBignum then "native" else "gmp"} - '' + lib.optionalString (targetPlatform != hostPlatform) '' - Stage1Only = ${if targetPlatform.system == hostPlatform.system then "NO" else "YES"} - CrossCompilePrefix = ${targetPrefix} - '' + lib.optionalString (!enableProfiledLibs) '' - BUILD_PROF_LIBS = NO - '' + - # -fexternal-dynamic-refs apparently (because it's not clear from the documentation) - # makes the GHC RTS able to load static libraries, which may be needed for TemplateHaskell. - # This solution was described in https://www.tweag.io/blog/2020-09-30-bazel-static-haskell - lib.optionalString enableRelocatedStaticLibs '' - GhcLibHcOpts += -fPIC -fexternal-dynamic-refs - GhcRtsHcOpts += -fPIC -fexternal-dynamic-refs - '' + lib.optionalString targetPlatform.useAndroidPrebuilt '' - EXTRA_CC_OPTS += -std=gnu99 - ''; + targetPrefix = lib.optionalString (targetPlatform != hostPlatform) "${targetPlatform.config}-"; + + buildMK = + '' + BuildFlavour = ${ghcFlavour} + ifneq \"\$(BuildFlavour)\" \"\" + include mk/flavours/\$(BuildFlavour).mk + endif + BUILD_SPHINX_HTML = ${if enableDocs then "YES" else "NO"} + BUILD_SPHINX_PDF = NO + + WITH_TERMINFO = ${if enableTerminfo then "YES" else "NO"} + '' + + + # Note [HADDOCK_DOCS]: + # Unfortunately currently `HADDOCK_DOCS` controls both whether the `haddock` + # program is built (which we generally always want to have a complete GHC install) + # and whether it is run on the GHC sources to generate hyperlinked source code + # (which is impossible for cross-compilation); see: + # https://gitlab.haskell.org/ghc/ghc/-/issues/20077 + # This implies that currently a cross-compiled GHC will never have a `haddock` + # program, so it can never generate haddocks for any packages. + # If this is solved in the future, we'd like to unconditionally + # build the haddock program (removing the `enableHaddockProgram` option). + '' + HADDOCK_DOCS = ${if enableHaddockProgram then "YES" else "NO"} + # Build haddocks for boot packages with hyperlinking + EXTRA_HADDOCK_OPTS += --hyperlinked-source --quickjump + + DYNAMIC_GHC_PROGRAMS = ${if enableShared then "YES" else "NO"} + BIGNUM_BACKEND = ${if enableNativeBignum then "native" else "gmp"} + '' + + lib.optionalString (targetPlatform != hostPlatform) '' + Stage1Only = ${if targetPlatform.system == hostPlatform.system then "NO" else "YES"} + CrossCompilePrefix = ${targetPrefix} + '' + + lib.optionalString (!enableProfiledLibs) '' + BUILD_PROF_LIBS = NO + '' + + + # -fexternal-dynamic-refs apparently (because it's not clear from the documentation) + # makes the GHC RTS able to load static libraries, which may be needed for TemplateHaskell. + # This solution was described in https://www.tweag.io/blog/2020-09-30-bazel-static-haskell + lib.optionalString enableRelocatedStaticLibs '' + GhcLibHcOpts += -fPIC -fexternal-dynamic-refs + GhcRtsHcOpts += -fPIC -fexternal-dynamic-refs + '' + + lib.optionalString targetPlatform.useAndroidPrebuilt '' + EXTRA_CC_OPTS += -std=gnu99 + ''; # Splicer will pull out correct variations - libDeps = platform: lib.optional enableTerminfo ncurses - ++ [libffi] + libDeps = + platform: + lib.optional enableTerminfo ncurses + ++ [ libffi ] ++ lib.optional (!enableNativeBignum) gmp ++ lib.optional (platform.libc != "glibc" && !targetPlatform.isWindows) libiconv; @@ -158,48 +191,54 @@ let # given `stdenv.cc` derivation, i.e. it picks the correct derivation to take # the tool from (cc, cc.bintools, cc.bintools.bintools) and adds the correct # subpath of the tool. - toolPath = name: cc: + toolPath = + name: cc: let - tools = { - "cc" = cc; - "c++" = cc; - as = cc.bintools; - - ar = cc.bintools; - ranlib = cc.bintools; - nm = cc.bintools; - readelf = cc.bintools; - objdump = cc.bintools; - - ld = cc.bintools; - "ld.gold" = cc.bintools; - - otool = cc.bintools.bintools; - - # GHC needs install_name_tool on all darwin platforms. The same one can - # be used on both platforms. It is safe to use with linker-generated - # signatures because it will update the signatures automatically after - # modifying the target binary. - install_name_tool = cc.bintools.bintools; - - # strip on darwin is wrapped to enable deterministic mode. - strip = - # TODO(@sternenseemann): also use wrapper if linker == "bfd" or "gold" - if stdenv.targetPlatform.isDarwin - then cc.bintools - else cc.bintools.bintools; - - # clang is used as an assembler on darwin with the LLVM backend - clang = cc; - }.${name}; + tools = + { + "cc" = cc; + "c++" = cc; + as = cc.bintools; + + ar = cc.bintools; + ranlib = cc.bintools; + nm = cc.bintools; + readelf = cc.bintools; + objdump = cc.bintools; + + ld = cc.bintools; + "ld.gold" = cc.bintools; + + otool = cc.bintools.bintools; + + # GHC needs install_name_tool on all darwin platforms. The same one can + # be used on both platforms. It is safe to use with linker-generated + # signatures because it will update the signatures automatically after + # modifying the target binary. + install_name_tool = cc.bintools.bintools; + + # strip on darwin is wrapped to enable deterministic mode. + strip = + # TODO(@sternenseemann): also use wrapper if linker == "bfd" or "gold" + if stdenv.targetPlatform.isDarwin then cc.bintools else cc.bintools.bintools; + + # clang is used as an assembler on darwin with the LLVM backend + clang = cc; + } + .${name}; in "${tools}/bin/${tools.targetPrefix}${name}"; # Use gold either following the default, or to avoid the BFD linker due to some bugs / perf issues. # But we cannot avoid BFD when using musl libc due to https://sourceware.org/bugzilla/show_bug.cgi?id=23856 # see #84670 and #49071 for more background. - useLdGold = targetPlatform.linker == "gold" || - (targetPlatform.linker == "bfd" && (targetCC.bintools.bintools.hasGold or false) && !targetPlatform.isMusl); + useLdGold = + targetPlatform.linker == "gold" + || ( + targetPlatform.linker == "bfd" + && (targetCC.bintools.bintools.hasGold or false) + && !targetPlatform.isMusl + ); # Makes debugging easier to see which variant is at play in `nix-store -q --tree`. variantSuffix = lib.concatStrings [ @@ -223,351 +262,400 @@ let # used to build stage 2 GHC itself, i.e. the core libs are both host and # target. targetLibs = { - inherit - (if hostPlatform != targetPlatform then targetPackages else pkgsHostTarget) + inherit (if hostPlatform != targetPlatform then targetPackages else pkgsHostTarget) gmp libffi - ncurses; + ncurses + ; }; in -stdenv.mkDerivation (rec { - pname = "${targetPrefix}ghc${variantSuffix}"; - inherit version; - - src = fetchurl { - inherit url sha256; - }; - - enableParallelBuilding = true; - - outputs = [ "out" "doc" ]; - - patches = lib.optionals (lib.versionOlder version "9.4") [ - # fix hyperlinked haddock sources: https://github.com/haskell/haddock/pull/1482 - (fetchpatch { - url = "https://patch-diff.githubusercontent.com/raw/haskell/haddock/pull/1482.patch"; - sha256 = "sha256-8w8QUCsODaTvknCDGgTfFNZa8ZmvIKaKS+2ZJZ9foYk="; - extraPrefix = "utils/haddock/"; - stripLen = 1; - }) - ] - - ++ lib.optionals (lib.versionOlder version "9.4.6") [ - # Fix docs build with sphinx >= 6.0 - # https://gitlab.haskell.org/ghc/ghc/-/issues/22766 - (fetchpatch { - name = "ghc-docs-sphinx-6.0.patch"; - url = "https://gitlab.haskell.org/ghc/ghc/-/commit/10e94a556b4f90769b7fd718b9790d58ae566600.patch"; - sha256 = "0kmhfamr16w8gch0lgln2912r8aryjky1hfcda3jkcwa5cdzgjdv"; - }) - ] - - ++ [ - # Fix docs build with Sphinx >= 7 https://gitlab.haskell.org/ghc/ghc/-/issues/24129 - ./docs-sphinx-7.patch - ] - - ++ lib.optionals (lib.versionOlder version "9.2.2") [ - # Add flag that fixes C++ exception handling; opt-in. Merged in 9.4 and 9.2.2. - # https://gitlab.haskell.org/ghc/ghc/-/merge_requests/7423 - (fetchpatch { - name = "ghc-9.0.2-fcompact-unwind.patch"; - # Note that the test suite is not packaged. - url = "https://gitlab.haskell.org/ghc/ghc/-/commit/c6132c782d974a7701e7f6447bdcd2bf6db4299a.patch?merge_request_iid=7423"; - sha256 = "sha256-b4feGZIaKDj/UKjWTNY6/jH4s2iate0wAgMxG3rAbZI="; - }) - ] - - ++ lib.optionals (lib.versionAtLeast version "9.2") [ - # Don't generate code that doesn't compile when --enable-relocatable is passed to Setup.hs - # Can be removed if the Cabal library included with ghc backports the linked fix - (fetchpatch { - url = "https://github.com/haskell/cabal/commit/6c796218c92f93c95e94d5ec2d077f6956f68e98.patch"; - stripLen = 1; - extraPrefix = "libraries/Cabal/"; - sha256 = "sha256-yRQ6YmMiwBwiYseC5BsrEtDgFbWvst+maGgDtdD0vAY="; - }) - ] - - ++ lib.optionals (version == "9.4.6") [ - # Work around a type not being defined when including Rts.h in bytestring's cbits - # due to missing feature macros. See https://gitlab.haskell.org/ghc/ghc/-/issues/23810. - ./9.4.6-bytestring-posix-source.patch - ] - - ++ lib.optionals (stdenv.targetPlatform.isDarwin && stdenv.targetPlatform.isAarch64) [ - # Prevent the paths module from emitting symbols that we don't use - # when building with separate outputs. - # - # These cause problems as they're not eliminated by GHC's dead code - # elimination on aarch64-darwin. (see - # https://github.com/NixOS/nixpkgs/issues/140774 for details). - (if lib.versionAtLeast version "9.2" - then ./Cabal-at-least-3.6-paths-fix-cycle-aarch64-darwin.patch - else ./Cabal-3.2-3.4-paths-fix-cycle-aarch64-darwin.patch) - ]; - - postPatch = "patchShebangs ."; - - # GHC needs the locale configured during the Haddock phase. - LANG = "en_US.UTF-8"; - - # GHC is a bit confused on its cross terminology. - # TODO(@sternenseemann): investigate coreutils dependencies and pass absolute paths - preConfigure = '' - for env in $(env | grep '^TARGET_' | sed -E 's|\+?=.*||'); do - export "''${env#TARGET_}=''${!env}" - done - # Stage0 (build->build) which builds stage 1 - export GHC="${bootPkgs.ghc}/bin/ghc" - # GHC is a bit confused on its cross terminology, as these would normally be - # the *host* tools. - export CC="${toolPath "cc" targetCC}" - export CXX="${toolPath "c++" targetCC}" - # Use gold to work around https://sourceware.org/bugzilla/show_bug.cgi?id=16177 - export LD="${toolPath "ld${lib.optionalString useLdGold ".gold"}" targetCC}" - export AS="${toolPath "as" targetCC}" - export AR="${toolPath "ar" targetCC}" - export NM="${toolPath "nm" targetCC}" - export RANLIB="${toolPath "ranlib" targetCC}" - export READELF="${toolPath "readelf" targetCC}" - export STRIP="${toolPath "strip" targetCC}" - export OBJDUMP="${toolPath "objdump" targetCC}" - '' + lib.optionalString (stdenv.targetPlatform.linker == "cctools") '' - export OTOOL="${toolPath "otool" targetCC}" - export INSTALL_NAME_TOOL="${toolPath "install_name_tool" targetCC}" - '' + lib.optionalString useLLVM '' - export LLC="${lib.getBin buildTargetLlvmPackages.llvm}/bin/llc" - export OPT="${lib.getBin buildTargetLlvmPackages.llvm}/bin/opt" - '' + lib.optionalString (useLLVM && stdenv.targetPlatform.isDarwin) '' - # LLVM backend on Darwin needs clang: https://downloads.haskell.org/~ghc/latest/docs/html/users_guide/codegens.html#llvm-code-generator-fllvm - # The executable we specify via $CLANG is used as an assembler (exclusively, it seems, but this isn't - # clarified in any user facing documentation). As such, it'll be called on assembly produced by $CC - # which usually comes from the darwin stdenv. To prevent a situation where $CLANG doesn't understand - # the assembly it is given, we need to make sure that it matches the LLVM version of $CC if possible. - # It is unclear (at the time of writing 2024-09-01) whether $CC should match the LLVM version we use - # for llc and opt which would require using a custom darwin stdenv for targetCC. - export CLANG="${ - if targetCC.isClang - then toolPath "clang" targetCC - else "${buildTargetLlvmPackages.clang}/bin/${buildTargetLlvmPackages.clang.targetPrefix}clang" - }" - '' - + '' - # No need for absolute paths since these tools only need to work during the build - export CC_STAGE0="$CC_FOR_BUILD" - export LD_STAGE0="$LD_FOR_BUILD" - export AR_STAGE0="$AR_FOR_BUILD" - - echo -n "${buildMK}" > mk/build.mk - '' - + lib.optionalString (lib.versionOlder version "9.2" || lib.versionAtLeast version "9.4") '' - sed -i -e 's|-isysroot /Developer/SDKs/MacOSX10.5.sdk||' configure - '' + lib.optionalString (stdenv.hostPlatform.isLinux && hostPlatform.libc == "glibc") '' - export LOCALE_ARCHIVE="${glibcLocales}/lib/locale/locale-archive" - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - export NIX_LDFLAGS+=" -rpath $out/lib/ghc-${version}" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - export NIX_LDFLAGS+=" -no_dtrace_dof" - '' + lib.optionalString (stdenv.hostPlatform.isDarwin && lib.versionAtLeast version "9.2") '' - - # GHC tries the host xattr /usr/bin/xattr by default which fails since it expects python to be 2.7 - export XATTR=${lib.getBin xattr}/bin/xattr - '' + lib.optionalString targetPlatform.useAndroidPrebuilt '' - sed -i -e '5i ,("armv7a-unknown-linux-androideabi", ("e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64", "cortex-a8", ""))' llvm-targets - '' + lib.optionalString targetPlatform.isMusl '' - echo "patching llvm-targets for musl targets..." - echo "Cloning these existing '*-linux-gnu*' targets:" - grep linux-gnu llvm-targets | sed 's/^/ /' - echo "(go go gadget sed)" - sed -i 's,\(^.*linux-\)gnu\(.*\)$,\0\n\1musl\2,' llvm-targets - echo "llvm-targets now contains these '*-linux-musl*' targets:" - grep linux-musl llvm-targets | sed 's/^/ /' - - echo "And now patching to preserve '-musleabi' as done with '-gnueabi'" - # (aclocal.m4 is actual source, but patch configure as well since we don't re-gen) - for x in configure aclocal.m4; do - substituteInPlace $x \ - --replace '*-android*|*-gnueabi*)' \ - '*-android*|*-gnueabi*|*-musleabi*)' - done - '' - # HACK: allow bootstrapping with GHC 8.10 which works fine, as we don't have - # binary 9.0 packaged. Bootstrapping with 9.2 is broken without hadrian. - + lib.optionalString (lib.versions.majorMinor version == "9.4") '' - substituteInPlace configure --replace \ - 'MinBootGhcVersion="9.0"' \ - 'MinBootGhcVersion="8.10"' - ''; - - # Although it is usually correct to pass --host, we don't do that here because - # GHC's usage of build, host, and target is non-standard. - # See https://gitlab.haskell.org/ghc/ghc/-/wikis/building/cross-compiling - # TODO(@Ericson2314): Always pass "--target" and always prefix. - configurePlatforms = [ "build" ] - ++ lib.optional (buildPlatform != hostPlatform || targetPlatform != hostPlatform) "target"; - - # `--with` flags for libraries needed for RTS linker - configureFlags = [ - "--datadir=$doc/share/doc/ghc" - ] ++ lib.optionals enableTerminfo [ - "--with-curses-includes=${lib.getDev targetLibs.ncurses}/include" - "--with-curses-libraries=${lib.getLib targetLibs.ncurses}/lib" - ] ++ lib.optionals (libffi != null) [ - "--with-system-libffi" - "--with-ffi-includes=${targetLibs.libffi.dev}/include" - "--with-ffi-libraries=${targetLibs.libffi.out}/lib" - ] ++ lib.optionals (targetPlatform == hostPlatform && !enableNativeBignum) [ - "--with-gmp-includes=${targetLibs.gmp.dev}/include" - "--with-gmp-libraries=${targetLibs.gmp.out}/lib" - ] ++ lib.optionals (targetPlatform == hostPlatform && hostPlatform.libc != "glibc" && !targetPlatform.isWindows) [ - "--with-iconv-includes=${libiconv}/include" - "--with-iconv-libraries=${libiconv}/lib" - ] ++ lib.optionals (targetPlatform != hostPlatform) [ - "--enable-bootstrap-with-devel-snapshot" - ] ++ lib.optionals useLdGold [ - "CFLAGS=-fuse-ld=gold" - "CONF_GCC_LINKER_OPTS_STAGE1=-fuse-ld=gold" - "CONF_GCC_LINKER_OPTS_STAGE2=-fuse-ld=gold" - ] ++ lib.optionals (disableLargeAddressSpace) [ - "--disable-large-address-space" - ] ++ lib.optionals enableUnregisterised [ - "--enable-unregisterised" - ]; - - # Make sure we never relax`$PATH` and hooks support for compatibility. - strictDeps = true; - - # Don’t add -liconv to LDFLAGS automatically so that GHC will add it itself. - dontAddExtraLibs = true; - - nativeBuildInputs = [ - perl autoconf automake m4 python3 - bootPkgs.alex bootPkgs.happy bootPkgs.hscolour - bootPkgs.ghc-settings-edit - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - autoSignDarwinBinariesHook - ] ++ lib.optionals enableDocs [ - sphinx - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && lib.versions.majorMinor version == "9.0") [ - # TODO(@sternenseemann): backport addition of XATTR env var like - # https://gitlab.haskell.org/ghc/ghc/-/merge_requests/6447 - xattr - ]; - - # Everything the stage0 compiler needs to build stage1: CC, bintools, extra libs. - # See also GHC, {CC,LD,AR}_STAGE0 in preConfigure. - depsBuildBuild = [ - # N.B. We do not declare bootPkgs.ghc in any of the stdenv.mkDerivation - # dependency lists to prevent the bintools setup hook from adding ghc's - # lib directory to the linker flags. Instead we tell configure about it - # via the GHC environment variable. - buildCC - # stage0 builds terminfo unconditionally, so we always need ncurses - ncurses - ]; - # For building runtime libs - depsBuildTarget = toolsForTarget; - - # Prevent stage0 ghc from leaking into the final result. This was an issue - # with GHC 9.6. - disallowedReferences = [ - bootPkgs.ghc - ]; - - buildInputs = [ bash ] ++ (libDeps hostPlatform); - - depsTargetTarget = map lib.getDev (libDeps targetPlatform); - depsTargetTargetPropagated = map (lib.getOutput "out") (libDeps targetPlatform); - - # required, because otherwise all symbols from HSffi.o are stripped, and - # that in turn causes GHCi to abort - stripDebugFlags = [ "-S" ] ++ lib.optional (!targetPlatform.isDarwin) "--keep-file-symbols"; - - checkTarget = "test"; - - hardeningDisable = - [ "format" ] - # In nixpkgs, musl based builds currently enable `pie` hardening by default - # (see `defaultHardeningFlags` in `make-derivation.nix`). - # But GHC cannot currently produce outputs that are ready for `-pie` linking. - # Thus, disable `pie` hardening, otherwise `recompile with -fPIE` errors appear. - # See: - # * https://github.com/NixOS/nixpkgs/issues/129247 - # * https://gitlab.haskell.org/ghc/ghc/-/issues/19580 - ++ lib.optional stdenv.targetPlatform.isMusl "pie"; - - # big-parallel allows us to build with more than 2 cores on - # Hydra which already warrants a significant speedup - requiredSystemFeatures = [ "big-parallel" ]; - - postInstall = '' - settingsFile="$out/lib/${targetPrefix}${passthru.haskellCompilerName}/settings" - - # Make the installed GHC use the host->target tools. - ghc-settings-edit "$settingsFile" \ - "C compiler command" "${toolPath "cc" installCC}" \ - "Haskell CPP command" "${toolPath "cc" installCC}" \ - "C++ compiler command" "${toolPath "c++" installCC}" \ - "ld command" "${toolPath "ld${lib.optionalString useLdGold ".gold"}" installCC}" \ - "Merge objects command" "${toolPath "ld${lib.optionalString useLdGold ".gold"}" installCC}" \ - "ar command" "${toolPath "ar" installCC}" \ - "ranlib command" "${toolPath "ranlib" installCC}" - '' - + lib.optionalString (stdenv.targetPlatform.linker == "cctools") '' - ghc-settings-edit "$settingsFile" \ - "otool command" "${toolPath "otool" installCC}" \ - "install_name_tool command" "${toolPath "install_name_tool" installCC}" - '' - + lib.optionalString useLLVM '' - ghc-settings-edit "$settingsFile" \ - "LLVM llc command" "${lib.getBin llvmPackages.llvm}/bin/llc" \ - "LLVM opt command" "${lib.getBin llvmPackages.llvm}/bin/opt" - '' - + lib.optionalString (useLLVM && stdenv.targetPlatform.isDarwin) '' - ghc-settings-edit "$settingsFile" \ - "LLVM clang command" "${ - # See comment for CLANG in preConfigure - if installCC.isClang - then toolPath "clang" installCC - else "${llvmPackages.clang}/bin/${llvmPackages.clang.targetPrefix}clang" - }" - '' - + '' - - # Install the bash completion file. - install -D -m 444 utils/completion/ghc.bash $out/share/bash-completion/completions/${targetPrefix}ghc - ''; - - passthru = { - inherit bootPkgs targetPrefix; - - inherit llvmPackages; - inherit enableShared; - - # This is used by the haskell builder to query - # the presence of the haddock program. - hasHaddock = enableHaddockProgram; - - # Our Cabal compiler name - haskellCompilerName = "ghc-${version}"; - }; - - meta = { - homepage = "http://haskell.org/ghc"; - description = "Glasgow Haskell Compiler"; - maintainers = with lib.maintainers; [ - guibou - ] ++ lib.teams.haskell.members; - timeout = 24 * 3600; - platforms = lib.platforms.all; - inherit (bootPkgs.ghc.meta) license; - }; - -} // lib.optionalAttrs targetPlatform.useAndroidPrebuilt { - dontStrip = true; - dontPatchELF = true; - noAuditTmpdir = true; -}) +stdenv.mkDerivation ( + rec { + pname = "${targetPrefix}ghc${variantSuffix}"; + inherit version; + + src = fetchurl { + inherit url sha256; + }; + + enableParallelBuilding = true; + + outputs = [ + "out" + "doc" + ]; + + patches = + lib.optionals (lib.versionOlder version "9.4") [ + # fix hyperlinked haddock sources: https://github.com/haskell/haddock/pull/1482 + (fetchpatch { + url = "https://patch-diff.githubusercontent.com/raw/haskell/haddock/pull/1482.patch"; + sha256 = "sha256-8w8QUCsODaTvknCDGgTfFNZa8ZmvIKaKS+2ZJZ9foYk="; + extraPrefix = "utils/haddock/"; + stripLen = 1; + }) + ] + + ++ lib.optionals (lib.versionOlder version "9.4.6") [ + # Fix docs build with sphinx >= 6.0 + # https://gitlab.haskell.org/ghc/ghc/-/issues/22766 + (fetchpatch { + name = "ghc-docs-sphinx-6.0.patch"; + url = "https://gitlab.haskell.org/ghc/ghc/-/commit/10e94a556b4f90769b7fd718b9790d58ae566600.patch"; + sha256 = "0kmhfamr16w8gch0lgln2912r8aryjky1hfcda3jkcwa5cdzgjdv"; + }) + ] + + ++ [ + # Fix docs build with Sphinx >= 7 https://gitlab.haskell.org/ghc/ghc/-/issues/24129 + ./docs-sphinx-7.patch + ] + + ++ lib.optionals (lib.versionOlder version "9.2.2") [ + # Add flag that fixes C++ exception handling; opt-in. Merged in 9.4 and 9.2.2. + # https://gitlab.haskell.org/ghc/ghc/-/merge_requests/7423 + (fetchpatch { + name = "ghc-9.0.2-fcompact-unwind.patch"; + # Note that the test suite is not packaged. + url = "https://gitlab.haskell.org/ghc/ghc/-/commit/c6132c782d974a7701e7f6447bdcd2bf6db4299a.patch?merge_request_iid=7423"; + sha256 = "sha256-b4feGZIaKDj/UKjWTNY6/jH4s2iate0wAgMxG3rAbZI="; + }) + ] + + ++ lib.optionals (lib.versionAtLeast version "9.2") [ + # Don't generate code that doesn't compile when --enable-relocatable is passed to Setup.hs + # Can be removed if the Cabal library included with ghc backports the linked fix + (fetchpatch { + url = "https://github.com/haskell/cabal/commit/6c796218c92f93c95e94d5ec2d077f6956f68e98.patch"; + stripLen = 1; + extraPrefix = "libraries/Cabal/"; + sha256 = "sha256-yRQ6YmMiwBwiYseC5BsrEtDgFbWvst+maGgDtdD0vAY="; + }) + ] + + ++ lib.optionals (version == "9.4.6") [ + # Work around a type not being defined when including Rts.h in bytestring's cbits + # due to missing feature macros. See https://gitlab.haskell.org/ghc/ghc/-/issues/23810. + ./9.4.6-bytestring-posix-source.patch + ] + + ++ lib.optionals (stdenv.targetPlatform.isDarwin && stdenv.targetPlatform.isAarch64) [ + # Prevent the paths module from emitting symbols that we don't use + # when building with separate outputs. + # + # These cause problems as they're not eliminated by GHC's dead code + # elimination on aarch64-darwin. (see + # https://github.com/NixOS/nixpkgs/issues/140774 for details). + ( + if lib.versionAtLeast version "9.2" then + ./Cabal-at-least-3.6-paths-fix-cycle-aarch64-darwin.patch + else + ./Cabal-3.2-3.4-paths-fix-cycle-aarch64-darwin.patch + ) + ]; + + postPatch = "patchShebangs ."; + + # GHC needs the locale configured during the Haddock phase. + LANG = "en_US.UTF-8"; + + # GHC is a bit confused on its cross terminology. + # TODO(@sternenseemann): investigate coreutils dependencies and pass absolute paths + preConfigure = + '' + for env in $(env | grep '^TARGET_' | sed -E 's|\+?=.*||'); do + export "''${env#TARGET_}=''${!env}" + done + # Stage0 (build->build) which builds stage 1 + export GHC="${bootPkgs.ghc}/bin/ghc" + # GHC is a bit confused on its cross terminology, as these would normally be + # the *host* tools. + export CC="${toolPath "cc" targetCC}" + export CXX="${toolPath "c++" targetCC}" + # Use gold to work around https://sourceware.org/bugzilla/show_bug.cgi?id=16177 + export LD="${toolPath "ld${lib.optionalString useLdGold ".gold"}" targetCC}" + export AS="${toolPath "as" targetCC}" + export AR="${toolPath "ar" targetCC}" + export NM="${toolPath "nm" targetCC}" + export RANLIB="${toolPath "ranlib" targetCC}" + export READELF="${toolPath "readelf" targetCC}" + export STRIP="${toolPath "strip" targetCC}" + export OBJDUMP="${toolPath "objdump" targetCC}" + '' + + lib.optionalString (stdenv.targetPlatform.linker == "cctools") '' + export OTOOL="${toolPath "otool" targetCC}" + export INSTALL_NAME_TOOL="${toolPath "install_name_tool" targetCC}" + '' + + lib.optionalString useLLVM '' + export LLC="${lib.getBin buildTargetLlvmPackages.llvm}/bin/llc" + export OPT="${lib.getBin buildTargetLlvmPackages.llvm}/bin/opt" + '' + + lib.optionalString (useLLVM && stdenv.targetPlatform.isDarwin) '' + # LLVM backend on Darwin needs clang: https://downloads.haskell.org/~ghc/latest/docs/html/users_guide/codegens.html#llvm-code-generator-fllvm + # The executable we specify via $CLANG is used as an assembler (exclusively, it seems, but this isn't + # clarified in any user facing documentation). As such, it'll be called on assembly produced by $CC + # which usually comes from the darwin stdenv. To prevent a situation where $CLANG doesn't understand + # the assembly it is given, we need to make sure that it matches the LLVM version of $CC if possible. + # It is unclear (at the time of writing 2024-09-01) whether $CC should match the LLVM version we use + # for llc and opt which would require using a custom darwin stdenv for targetCC. + export CLANG="${ + if targetCC.isClang then + toolPath "clang" targetCC + else + "${buildTargetLlvmPackages.clang}/bin/${buildTargetLlvmPackages.clang.targetPrefix}clang" + }" + '' + + '' + # No need for absolute paths since these tools only need to work during the build + export CC_STAGE0="$CC_FOR_BUILD" + export LD_STAGE0="$LD_FOR_BUILD" + export AR_STAGE0="$AR_FOR_BUILD" + + echo -n "${buildMK}" > mk/build.mk + '' + + lib.optionalString (lib.versionOlder version "9.2" || lib.versionAtLeast version "9.4") '' + sed -i -e 's|-isysroot /Developer/SDKs/MacOSX10.5.sdk||' configure + '' + + lib.optionalString (stdenv.hostPlatform.isLinux && hostPlatform.libc == "glibc") '' + export LOCALE_ARCHIVE="${glibcLocales}/lib/locale/locale-archive" + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + export NIX_LDFLAGS+=" -rpath $out/lib/ghc-${version}" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + export NIX_LDFLAGS+=" -no_dtrace_dof" + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin && lib.versionAtLeast version "9.2") '' + + # GHC tries the host xattr /usr/bin/xattr by default which fails since it expects python to be 2.7 + export XATTR=${lib.getBin xattr}/bin/xattr + '' + + lib.optionalString targetPlatform.useAndroidPrebuilt '' + sed -i -e '5i ,("armv7a-unknown-linux-androideabi", ("e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64", "cortex-a8", ""))' llvm-targets + '' + + lib.optionalString targetPlatform.isMusl '' + echo "patching llvm-targets for musl targets..." + echo "Cloning these existing '*-linux-gnu*' targets:" + grep linux-gnu llvm-targets | sed 's/^/ /' + echo "(go go gadget sed)" + sed -i 's,\(^.*linux-\)gnu\(.*\)$,\0\n\1musl\2,' llvm-targets + echo "llvm-targets now contains these '*-linux-musl*' targets:" + grep linux-musl llvm-targets | sed 's/^/ /' + + echo "And now patching to preserve '-musleabi' as done with '-gnueabi'" + # (aclocal.m4 is actual source, but patch configure as well since we don't re-gen) + for x in configure aclocal.m4; do + substituteInPlace $x \ + --replace '*-android*|*-gnueabi*)' \ + '*-android*|*-gnueabi*|*-musleabi*)' + done + '' + # HACK: allow bootstrapping with GHC 8.10 which works fine, as we don't have + # binary 9.0 packaged. Bootstrapping with 9.2 is broken without hadrian. + + lib.optionalString (lib.versions.majorMinor version == "9.4") '' + substituteInPlace configure --replace \ + 'MinBootGhcVersion="9.0"' \ + 'MinBootGhcVersion="8.10"' + ''; + + # Although it is usually correct to pass --host, we don't do that here because + # GHC's usage of build, host, and target is non-standard. + # See https://gitlab.haskell.org/ghc/ghc/-/wikis/building/cross-compiling + # TODO(@Ericson2314): Always pass "--target" and always prefix. + configurePlatforms = [ + "build" + ] ++ lib.optional (buildPlatform != hostPlatform || targetPlatform != hostPlatform) "target"; + + # `--with` flags for libraries needed for RTS linker + configureFlags = + [ + "--datadir=$doc/share/doc/ghc" + ] + ++ lib.optionals enableTerminfo [ + "--with-curses-includes=${lib.getDev targetLibs.ncurses}/include" + "--with-curses-libraries=${lib.getLib targetLibs.ncurses}/lib" + ] + ++ lib.optionals (libffi != null) [ + "--with-system-libffi" + "--with-ffi-includes=${targetLibs.libffi.dev}/include" + "--with-ffi-libraries=${targetLibs.libffi.out}/lib" + ] + ++ lib.optionals (targetPlatform == hostPlatform && !enableNativeBignum) [ + "--with-gmp-includes=${targetLibs.gmp.dev}/include" + "--with-gmp-libraries=${targetLibs.gmp.out}/lib" + ] + ++ + lib.optionals + (targetPlatform == hostPlatform && hostPlatform.libc != "glibc" && !targetPlatform.isWindows) + [ + "--with-iconv-includes=${libiconv}/include" + "--with-iconv-libraries=${libiconv}/lib" + ] + ++ lib.optionals (targetPlatform != hostPlatform) [ + "--enable-bootstrap-with-devel-snapshot" + ] + ++ lib.optionals useLdGold [ + "CFLAGS=-fuse-ld=gold" + "CONF_GCC_LINKER_OPTS_STAGE1=-fuse-ld=gold" + "CONF_GCC_LINKER_OPTS_STAGE2=-fuse-ld=gold" + ] + ++ lib.optionals (disableLargeAddressSpace) [ + "--disable-large-address-space" + ] + ++ lib.optionals enableUnregisterised [ + "--enable-unregisterised" + ]; + + # Make sure we never relax`$PATH` and hooks support for compatibility. + strictDeps = true; + + # Don’t add -liconv to LDFLAGS automatically so that GHC will add it itself. + dontAddExtraLibs = true; + + nativeBuildInputs = + [ + perl + autoconf + automake + m4 + python3 + bootPkgs.alex + bootPkgs.happy + bootPkgs.hscolour + bootPkgs.ghc-settings-edit + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + autoSignDarwinBinariesHook + ] + ++ lib.optionals enableDocs [ + sphinx + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && lib.versions.majorMinor version == "9.0") [ + # TODO(@sternenseemann): backport addition of XATTR env var like + # https://gitlab.haskell.org/ghc/ghc/-/merge_requests/6447 + xattr + ]; + + # Everything the stage0 compiler needs to build stage1: CC, bintools, extra libs. + # See also GHC, {CC,LD,AR}_STAGE0 in preConfigure. + depsBuildBuild = [ + # N.B. We do not declare bootPkgs.ghc in any of the stdenv.mkDerivation + # dependency lists to prevent the bintools setup hook from adding ghc's + # lib directory to the linker flags. Instead we tell configure about it + # via the GHC environment variable. + buildCC + # stage0 builds terminfo unconditionally, so we always need ncurses + ncurses + ]; + # For building runtime libs + depsBuildTarget = toolsForTarget; + + # Prevent stage0 ghc from leaking into the final result. This was an issue + # with GHC 9.6. + disallowedReferences = [ + bootPkgs.ghc + ]; + + buildInputs = [ bash ] ++ (libDeps hostPlatform); + + depsTargetTarget = map lib.getDev (libDeps targetPlatform); + depsTargetTargetPropagated = map (lib.getOutput "out") (libDeps targetPlatform); + + # required, because otherwise all symbols from HSffi.o are stripped, and + # that in turn causes GHCi to abort + stripDebugFlags = [ "-S" ] ++ lib.optional (!targetPlatform.isDarwin) "--keep-file-symbols"; + + checkTarget = "test"; + + hardeningDisable = + [ "format" ] + # In nixpkgs, musl based builds currently enable `pie` hardening by default + # (see `defaultHardeningFlags` in `make-derivation.nix`). + # But GHC cannot currently produce outputs that are ready for `-pie` linking. + # Thus, disable `pie` hardening, otherwise `recompile with -fPIE` errors appear. + # See: + # * https://github.com/NixOS/nixpkgs/issues/129247 + # * https://gitlab.haskell.org/ghc/ghc/-/issues/19580 + ++ lib.optional stdenv.targetPlatform.isMusl "pie"; + + # big-parallel allows us to build with more than 2 cores on + # Hydra which already warrants a significant speedup + requiredSystemFeatures = [ "big-parallel" ]; + + postInstall = + '' + settingsFile="$out/lib/${targetPrefix}${passthru.haskellCompilerName}/settings" + + # Make the installed GHC use the host->target tools. + ghc-settings-edit "$settingsFile" \ + "C compiler command" "${toolPath "cc" installCC}" \ + "Haskell CPP command" "${toolPath "cc" installCC}" \ + "C++ compiler command" "${toolPath "c++" installCC}" \ + "ld command" "${toolPath "ld${lib.optionalString useLdGold ".gold"}" installCC}" \ + "Merge objects command" "${toolPath "ld${lib.optionalString useLdGold ".gold"}" installCC}" \ + "ar command" "${toolPath "ar" installCC}" \ + "ranlib command" "${toolPath "ranlib" installCC}" + '' + + lib.optionalString (stdenv.targetPlatform.linker == "cctools") '' + ghc-settings-edit "$settingsFile" \ + "otool command" "${toolPath "otool" installCC}" \ + "install_name_tool command" "${toolPath "install_name_tool" installCC}" + '' + + lib.optionalString useLLVM '' + ghc-settings-edit "$settingsFile" \ + "LLVM llc command" "${lib.getBin llvmPackages.llvm}/bin/llc" \ + "LLVM opt command" "${lib.getBin llvmPackages.llvm}/bin/opt" + '' + + lib.optionalString (useLLVM && stdenv.targetPlatform.isDarwin) '' + ghc-settings-edit "$settingsFile" \ + "LLVM clang command" "${ + # See comment for CLANG in preConfigure + if installCC.isClang then + toolPath "clang" installCC + else + "${llvmPackages.clang}/bin/${llvmPackages.clang.targetPrefix}clang" + }" + '' + + '' + + # Install the bash completion file. + install -D -m 444 utils/completion/ghc.bash $out/share/bash-completion/completions/${targetPrefix}ghc + ''; + + passthru = { + inherit bootPkgs targetPrefix; + + inherit llvmPackages; + inherit enableShared; + + # This is used by the haskell builder to query + # the presence of the haddock program. + hasHaddock = enableHaddockProgram; + + # Our Cabal compiler name + haskellCompilerName = "ghc-${version}"; + }; + + meta = { + homepage = "http://haskell.org/ghc"; + description = "Glasgow Haskell Compiler"; + maintainers = + with lib.maintainers; + [ + guibou + ] + ++ lib.teams.haskell.members; + timeout = 24 * 3600; + platforms = lib.platforms.all; + inherit (bootPkgs.ghc.meta) license; + }; + + } + // lib.optionalAttrs targetPlatform.useAndroidPrebuilt { + dontStrip = true; + dontPatchELF = true; + noAuditTmpdir = true; + } +) diff --git a/pkgs/development/compilers/ghcjs/8.10/common-overrides.nix b/pkgs/development/compilers/ghcjs/8.10/common-overrides.nix index 8f791b73abff94..109fa38c14c5a9 100644 --- a/pkgs/development/compilers/ghcjs/8.10/common-overrides.nix +++ b/pkgs/development/compilers/ghcjs/8.10/common-overrides.nix @@ -1,20 +1,40 @@ -{ haskellLib, fetchpatch, buildPackages }: +{ + haskellLib, + fetchpatch, + buildPackages, +}: -let inherit (haskellLib) addBuildTools appendConfigureFlag dontHaddock doJailbreak markUnbroken overrideCabal; -in self: super: { - ghcjs = overrideCabal (drv: { - # Jailbreak and patch can be dropped after https://github.com/ghcjs/ghcjs/pull/833 - jailbreak = true; - patches = drv.patches or [] ++ [ - (fetchpatch { - name = "ghcjs-aeson-2.0.patch"; - url = "https://github.com/ghcjs/ghcjs/commit/9ef1f92d740e8503d15d91699f57db147f0474cc.patch"; - sha256 = "0cgxcy6b5870bv4kj54n3bzcqinh4gl4w4r78dg43h2mblhkzbnj"; +let + inherit (haskellLib) + addBuildTools + appendConfigureFlag + dontHaddock + doJailbreak + markUnbroken + overrideCabal + ; +in +self: super: { + ghcjs = + overrideCabal + (drv: { + # Jailbreak and patch can be dropped after https://github.com/ghcjs/ghcjs/pull/833 + jailbreak = true; + patches = drv.patches or [ ] ++ [ + (fetchpatch { + name = "ghcjs-aeson-2.0.patch"; + url = "https://github.com/ghcjs/ghcjs/commit/9ef1f92d740e8503d15d91699f57db147f0474cc.patch"; + sha256 = "0cgxcy6b5870bv4kj54n3bzcqinh4gl4w4r78dg43h2mblhkzbnj"; + }) + ]; }) - ]; - }) (super.ghcjs.overrideScope (self: super: { - # Allow transformers-compat >= 0.7 - optparse-applicative = doJailbreak self.optparse-applicative_0_15_1_0; - ansi-wl-pprint = self.ansi-wl-pprint_0_6_9; - })); + ( + super.ghcjs.overrideScope ( + self: super: { + # Allow transformers-compat >= 0.7 + optparse-applicative = doJailbreak self.optparse-applicative_0_15_1_0; + ansi-wl-pprint = self.ansi-wl-pprint_0_6_9; + } + ) + ); } diff --git a/pkgs/development/compilers/ghcjs/8.10/configured-ghcjs-src.nix b/pkgs/development/compilers/ghcjs/8.10/configured-ghcjs-src.nix index c9e6d2f09cf76b..3df3a42bf5c38c 100644 --- a/pkgs/development/compilers/ghcjs/8.10/configured-ghcjs-src.nix +++ b/pkgs/development/compilers/ghcjs/8.10/configured-ghcjs-src.nix @@ -1,67 +1,70 @@ -{ perl -, autoconf -, automake -, python3 -, gcc -, cabal-install -, runCommand -, fetchpatch +{ + perl, + autoconf, + automake, + python3, + gcc, + cabal-install, + runCommand, + fetchpatch, -, ghc -, happy -, alex + ghc, + happy, + alex, -, ghcjsSrc -, version + ghcjsSrc, + version, }: -runCommand "configured-ghcjs-src" { - nativeBuildInputs = [ - perl - autoconf - automake - python3 - ghc - happy - alex - cabal-install - gcc - ]; +runCommand "configured-ghcjs-src" + { + nativeBuildInputs = [ + perl + autoconf + automake + python3 + ghc + happy + alex + cabal-install + gcc + ]; - inherit ghcjsSrc; + inherit ghcjsSrc; - ctimePatch = fetchpatch { - name = "ghcjs-base-ctime-64-bit.patch"; - url = "https://github.com/ghcjs/ghcjs/commit/b7711fbca7c3f43a61f1dba526e6f2a2656ef44c.patch"; - hash = "sha256-zZ3l8/5gbIGtvu0s2Xl92fEDhkhJ2c2w+5Ql5qkvr3s="; - }; -} '' - export HOME=$(pwd) - mkdir $HOME/.cabal - touch $HOME/.cabal/config - cp -r "$ghcjsSrc" "$out" - chmod -R +w "$out" - cd "$out" + ctimePatch = fetchpatch { + name = "ghcjs-base-ctime-64-bit.patch"; + url = "https://github.com/ghcjs/ghcjs/commit/b7711fbca7c3f43a61f1dba526e6f2a2656ef44c.patch"; + hash = "sha256-zZ3l8/5gbIGtvu0s2Xl92fEDhkhJ2c2w+5Ql5qkvr3s="; + }; + } + '' + export HOME=$(pwd) + mkdir $HOME/.cabal + touch $HOME/.cabal/config + cp -r "$ghcjsSrc" "$out" + chmod -R +w "$out" + cd "$out" - patch -p1 -i "$ctimePatch" + patch -p1 -i "$ctimePatch" - # TODO: Find a better way to avoid impure version numbers - sed -i 's/RELEASE=NO/RELEASE=YES/' ghc/configure.ac + # TODO: Find a better way to avoid impure version numbers + sed -i 's/RELEASE=NO/RELEASE=YES/' ghc/configure.ac - # These files are needed by ghc-boot package, and these are generated by the - # make/hadrian build system when compiling ghc. Since we dont have access to - # the generated code of the ghc while it got built, here is a little hack to - # generate these again. - runhaskell ${./generate_host_version.hs} - mkdir -p utils/pkg-cache/ghc/libraries/ghc-boot/dist-install/build/GHC/Platform - mv Host.hs utils/pkg-cache/ghc/libraries/ghc-boot/dist-install/build/GHC/Platform/Host.hs - mv Version.hs utils/pkg-cache/ghc/libraries/ghc-boot/dist-install/build/GHC/Version.hs + # These files are needed by ghc-boot package, and these are generated by the + # make/hadrian build system when compiling ghc. Since we dont have access to + # the generated code of the ghc while it got built, here is a little hack to + # generate these again. + runhaskell ${./generate_host_version.hs} + mkdir -p utils/pkg-cache/ghc/libraries/ghc-boot/dist-install/build/GHC/Platform + mv Host.hs utils/pkg-cache/ghc/libraries/ghc-boot/dist-install/build/GHC/Platform/Host.hs + mv Version.hs utils/pkg-cache/ghc/libraries/ghc-boot/dist-install/build/GHC/Version.hs - # The ghcjs has the following hardcoded paths of lib dir in its code. Patching - # these to match the path expected by the nixpkgs's generic-builder, etc. - sed -i 's/libSubDir = "lib"/libSubDir = "lib\/ghcjs-${version}"/' src-bin/Boot.hs - sed -i 's@let libDir = takeDirectory haddockPath ".." "lib"@let libDir = takeDirectory haddockPath ".." "lib/ghcjs-${version}"@' src-bin/HaddockDriver.hs + # The ghcjs has the following hardcoded paths of lib dir in its code. Patching + # these to match the path expected by the nixpkgs's generic-builder, etc. + sed -i 's/libSubDir = "lib"/libSubDir = "lib\/ghcjs-${version}"/' src-bin/Boot.hs + sed -i 's@let libDir = takeDirectory haddockPath ".." "lib"@let libDir = takeDirectory haddockPath ".." "lib/ghcjs-${version}"@' src-bin/HaddockDriver.hs - patchShebangs . - ./utils/makePackages.sh copy -'' + patchShebangs . + ./utils/makePackages.sh copy + '' diff --git a/pkgs/development/compilers/ghcjs/8.10/default.nix b/pkgs/development/compilers/ghcjs/8.10/default.nix index aea58c62b6d103..d3f74f52e86e9e 100644 --- a/pkgs/development/compilers/ghcjs/8.10/default.nix +++ b/pkgs/development/compilers/ghcjs/8.10/default.nix @@ -1,24 +1,25 @@ -{ stdenv -, pkgsHostHost -, callPackage -, fetchgit -, fetchpatch -, ghcjsSrcJson ? null -, ghcjsSrc ? fetchgit (lib.importJSON ghcjsSrcJson) -, bootPkgs -, stage0 -, haskellLib -, cabal-install -, nodejs -, makeWrapper -, xorg -, gmp -, pkg-config -, gcc -, lib -, ghcjsDepOverrides ? (_:_:{}) -, linkFarm -, buildPackages +{ + stdenv, + pkgsHostHost, + callPackage, + fetchgit, + fetchpatch, + ghcjsSrcJson ? null, + ghcjsSrc ? fetchgit (lib.importJSON ghcjsSrcJson), + bootPkgs, + stage0, + haskellLib, + cabal-install, + nodejs, + makeWrapper, + xorg, + gmp, + pkg-config, + gcc, + lib, + ghcjsDepOverrides ? (_: _: { }), + linkFarm, + buildPackages, }: let @@ -29,17 +30,22 @@ let inherit (bootGhcjs) version; happy = bootPkgs.happy_1_19_12; }; - bootPkgs = bootPkgs.extend (lib.foldr lib.composeExtensions (_:_:{}) [ - (self: _: import stage0 { - inherit (passthru) configuredSrc; - inherit (self) callPackage; - }) - - (callPackage ./common-overrides.nix { - inherit haskellLib fetchpatch buildPackages; - }) - ghcjsDepOverrides - ]); + bootPkgs = bootPkgs.extend ( + lib.foldr lib.composeExtensions (_: _: { }) [ + ( + self: _: + import stage0 { + inherit (passthru) configuredSrc; + inherit (self) callPackage; + } + ) + + (callPackage ./common-overrides.nix { + inherit haskellLib fetchpatch buildPackages; + }) + ghcjsDepOverrides + ] + ); targetPrefix = ""; inherit bootGhcjs; @@ -58,14 +64,22 @@ let # This provides the stuff we need from the emsdk emsdk = linkFarm "emsdk" [ - { name = "upstream/bin"; path = buildPackages.clang + "/bin";} - { name = "upstream/emscripten"; path = buildPackages.emscripten + "/bin"; } + { + name = "upstream/bin"; + path = buildPackages.clang + "/bin"; + } + { + name = "upstream/emscripten"; + path = buildPackages.emscripten + "/bin"; + } ]; -in stdenv.mkDerivation { - name = bootGhcjs.name; - src = passthru.configuredSrc; - nativeBuildInputs = [ +in +stdenv.mkDerivation { + name = bootGhcjs.name; + src = passthru.configuredSrc; + nativeBuildInputs = + [ bootGhcjs passthru.bootPkgs.ghc cabal-install @@ -74,54 +88,55 @@ in stdenv.mkDerivation { xorg.lndir gmp pkg-config - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ gcc # https://github.com/ghcjs/ghcjs/issues/663 ]; - dontConfigure = true; - dontInstall = true; + dontConfigure = true; + dontInstall = true; - # Newer versions of `config.sub` reject the `js-ghcjs` host string, but the - # older `config.sub` filed vendored within `ghc` still works - dontUpdateAutotoolsGnuConfigScripts = true; + # Newer versions of `config.sub` reject the `js-ghcjs` host string, but the + # older `config.sub` filed vendored within `ghc` still works + dontUpdateAutotoolsGnuConfigScripts = true; - buildPhase = '' - export HOME=$TMP - mkdir $HOME/.cabal - touch $HOME/.cabal/config - cd lib/boot + buildPhase = '' + export HOME=$TMP + mkdir $HOME/.cabal + touch $HOME/.cabal/config + cd lib/boot - mkdir -p $out/bin - mkdir -p $out/lib/${bootGhcjs.name} - lndir ${bootGhcjs}/bin $out/bin - chmod -R +w $out/bin - rm $out/bin/ghcjs-boot - cp ${bootGhcjs}/bin/ghcjs-boot $out/bin - rm $out/bin/haddock - cp ${bootGhcjs}/bin/haddock $out/bin - cp ${bootGhcjs}/bin/private-ghcjs-hsc2hs $out/bin/ghcjs-hsc2hs + mkdir -p $out/bin + mkdir -p $out/lib/${bootGhcjs.name} + lndir ${bootGhcjs}/bin $out/bin + chmod -R +w $out/bin + rm $out/bin/ghcjs-boot + cp ${bootGhcjs}/bin/ghcjs-boot $out/bin + rm $out/bin/haddock + cp ${bootGhcjs}/bin/haddock $out/bin + cp ${bootGhcjs}/bin/private-ghcjs-hsc2hs $out/bin/ghcjs-hsc2hs - wrapProgram $out/bin/ghcjs-boot --set ghcjs_libexecdir $out/bin + wrapProgram $out/bin/ghcjs-boot --set ghcjs_libexecdir $out/bin - wrapProgram $out/bin/ghcjs --add-flags "-B$out/lib/${bootGhcjs.name}" - wrapProgram $out/bin/haddock --add-flags "-B$out/lib/${bootGhcjs.name}" - wrapProgram $out/bin/ghcjs-pkg --add-flags "--global-package-db=$out/lib/${bootGhcjs.name}/package.conf.d" - wrapProgram $out/bin/ghcjs-hsc2hs --add-flags "-I$out/lib/${bootGhcjs.name}/include --template=$out/lib/${bootGhcjs.name}/include/template-hsc.h" + wrapProgram $out/bin/ghcjs --add-flags "-B$out/lib/${bootGhcjs.name}" + wrapProgram $out/bin/haddock --add-flags "-B$out/lib/${bootGhcjs.name}" + wrapProgram $out/bin/ghcjs-pkg --add-flags "--global-package-db=$out/lib/${bootGhcjs.name}/package.conf.d" + wrapProgram $out/bin/ghcjs-hsc2hs --add-flags "-I$out/lib/${bootGhcjs.name}/include --template=$out/lib/${bootGhcjs.name}/include/template-hsc.h" - env PATH=$out/bin:$PATH $out/bin/ghcjs-boot --with-emsdk=${emsdk} --no-haddock - ''; + env PATH=$out/bin:$PATH $out/bin/ghcjs-boot --with-emsdk=${emsdk} --no-haddock + ''; - enableParallelBuilding = true; + enableParallelBuilding = true; - inherit passthru; + inherit passthru; - meta = { - platforms = with lib.platforms; linux ++ darwin; + meta = { + platforms = with lib.platforms; linux ++ darwin; - # Hydra limits jobs to only outputting 1 gigabyte worth of files. - # GHCJS outputs over 3 gigabytes. - # https://github.com/NixOS/nixpkgs/pull/137066#issuecomment-922335563 - hydraPlatforms = lib.platforms.none; + # Hydra limits jobs to only outputting 1 gigabyte worth of files. + # GHCJS outputs over 3 gigabytes. + # https://github.com/NixOS/nixpkgs/pull/137066#issuecomment-922335563 + hydraPlatforms = lib.platforms.none; - maintainers = with lib.maintainers; [ obsidian-systems-maintenance ]; - }; - } + maintainers = with lib.maintainers; [ obsidian-systems-maintenance ]; + }; +} diff --git a/pkgs/development/compilers/ghcjs/8.10/stage0.nix b/pkgs/development/compilers/ghcjs/8.10/stage0.nix index d173d5a2e55776..30c89a1b2e1978 100644 --- a/pkgs/development/compilers/ghcjs/8.10/stage0.nix +++ b/pkgs/development/compilers/ghcjs/8.10/stage0.nix @@ -2,76 +2,244 @@ { - ghcjs = callPackage - ({ mkDerivation, aeson, alex, array, attoparsec, base, base16-bytestring - , base64-bytestring, binary, bytestring, Cabal, containers - , cryptohash, data-default, deepseq, directory, executable-path - , filepath, ghc-boot, ghc-boot-th, ghc-compact, ghc-heap, ghc-paths - , ghci, happy, hashable, hpc, http-types, HUnit, lens, lib - , lifted-base, mtl, network, optparse-applicative, parallel, parsec - , process, random, safe, shelly, split, stringsearch, syb, tar - , template-haskell, terminfo, test-framework, test-framework-hunit - , text, time, transformers, unix, unix-compat, unordered-containers - , vector, wai, wai-app-static, wai-extra, wai-websockets, warp - , webdriver, websockets, wl-pprint-text, xhtml, yaml - }: - mkDerivation { - pname = "ghcjs"; - version = "8.10.7"; - src = configuredSrc + /.; - isLibrary = true; - isExecutable = true; - libraryHaskellDepends = [ - aeson array attoparsec base base16-bytestring base64-bytestring - binary bytestring Cabal containers cryptohash data-default deepseq - directory filepath ghc-boot ghc-boot-th ghc-compact ghc-heap - ghc-paths ghci hashable hpc lens mtl optparse-applicative parallel - parsec process safe split stringsearch syb template-haskell - terminfo text time transformers unix unordered-containers vector - wl-pprint-text yaml - ]; - libraryToolDepends = [ alex happy ]; - executableHaskellDepends = [ - aeson array base binary bytestring Cabal containers deepseq - directory executable-path filepath ghc-boot lens mtl - optparse-applicative parsec process tar terminfo text time - transformers unix unix-compat unordered-containers vector xhtml - yaml - ]; - testHaskellDepends = [ - aeson base bytestring data-default deepseq directory filepath - http-types HUnit lens lifted-base network optparse-applicative - process random shelly test-framework test-framework-hunit text time - transformers unordered-containers wai wai-app-static wai-extra - wai-websockets warp webdriver websockets yaml - ]; - description = "Haskell to JavaScript compiler"; - license = lib.licenses.mit; - }) {}; + ghcjs = callPackage ( + { + mkDerivation, + aeson, + alex, + array, + attoparsec, + base, + base16-bytestring, + base64-bytestring, + binary, + bytestring, + Cabal, + containers, + cryptohash, + data-default, + deepseq, + directory, + executable-path, + filepath, + ghc-boot, + ghc-boot-th, + ghc-compact, + ghc-heap, + ghc-paths, + ghci, + happy, + hashable, + hpc, + http-types, + HUnit, + lens, + lib, + lifted-base, + mtl, + network, + optparse-applicative, + parallel, + parsec, + process, + random, + safe, + shelly, + split, + stringsearch, + syb, + tar, + template-haskell, + terminfo, + test-framework, + test-framework-hunit, + text, + time, + transformers, + unix, + unix-compat, + unordered-containers, + vector, + wai, + wai-app-static, + wai-extra, + wai-websockets, + warp, + webdriver, + websockets, + wl-pprint-text, + xhtml, + yaml, + }: + mkDerivation { + pname = "ghcjs"; + version = "8.10.7"; + src = configuredSrc + /.; + isLibrary = true; + isExecutable = true; + libraryHaskellDepends = [ + aeson + array + attoparsec + base + base16-bytestring + base64-bytestring + binary + bytestring + Cabal + containers + cryptohash + data-default + deepseq + directory + filepath + ghc-boot + ghc-boot-th + ghc-compact + ghc-heap + ghc-paths + ghci + hashable + hpc + lens + mtl + optparse-applicative + parallel + parsec + process + safe + split + stringsearch + syb + template-haskell + terminfo + text + time + transformers + unix + unordered-containers + vector + wl-pprint-text + yaml + ]; + libraryToolDepends = [ + alex + happy + ]; + executableHaskellDepends = [ + aeson + array + base + binary + bytestring + Cabal + containers + deepseq + directory + executable-path + filepath + ghc-boot + lens + mtl + optparse-applicative + parsec + process + tar + terminfo + text + time + transformers + unix + unix-compat + unordered-containers + vector + xhtml + yaml + ]; + testHaskellDepends = [ + aeson + base + bytestring + data-default + deepseq + directory + filepath + http-types + HUnit + lens + lifted-base + network + optparse-applicative + process + random + shelly + test-framework + test-framework-hunit + text + time + transformers + unordered-containers + wai + wai-app-static + wai-extra + wai-websockets + warp + webdriver + websockets + yaml + ]; + description = "Haskell to JavaScript compiler"; + license = lib.licenses.mit; + } + ) { }; - ghcjs-th = callPackage - ({ mkDerivation, base, binary, bytestring, containers, ghc-prim - , ghci, lib, template-haskell + ghcjs-th = callPackage ( + { + mkDerivation, + base, + binary, + bytestring, + containers, + ghc-prim, + ghci, + lib, + template-haskell, }: mkDerivation { pname = "ghcjs-th"; version = "0.1.0.0"; src = configuredSrc + /lib/ghcjs-th; libraryHaskellDepends = [ - base binary bytestring containers ghc-prim ghci template-haskell + base + binary + bytestring + containers + ghc-prim + ghci + template-haskell ]; homepage = "https://github.com/ghcjs"; license = lib.licenses.mit; - }) {}; + } + ) { }; - ghcjs-prim = callPackage - ({ mkDerivation, base, ghc-prim, lib }: + ghcjs-prim = callPackage ( + { + mkDerivation, + base, + ghc-prim, + lib, + }: mkDerivation { pname = "ghcjs-prim"; version = "0.1.1.0"; src = ./.; - libraryHaskellDepends = [ base ghc-prim ]; + libraryHaskellDepends = [ + base + ghc-prim + ]; homepage = "https://github.com/ghcjs"; license = lib.licenses.mit; - }) {}; + } + ) { }; } diff --git a/pkgs/development/compilers/ghcjs/ghcjs-base.nix b/pkgs/development/compilers/ghcjs/ghcjs-base.nix index 9c09412b027e99..bb57c0beefcacd 100644 --- a/pkgs/development/compilers/ghcjs/ghcjs-base.nix +++ b/pkgs/development/compilers/ghcjs/ghcjs-base.nix @@ -1,10 +1,35 @@ -{ mkDerivation, aeson, array, attoparsec, base, binary, bytestring -, containers, deepseq, directory, dlist, fetchFromGitHub, ghc-prim -, ghcjs-prim, hashable, HUnit, integer-gmp, primitive, QuickCheck -, quickcheck-unicode, random, scientific, test-framework -, test-framework-hunit, test-framework-quickcheck2, text, time -, transformers, unordered-containers, vector -, lib +{ + mkDerivation, + aeson, + array, + attoparsec, + base, + binary, + bytestring, + containers, + deepseq, + directory, + dlist, + fetchFromGitHub, + ghc-prim, + ghcjs-prim, + hashable, + HUnit, + integer-gmp, + primitive, + QuickCheck, + quickcheck-unicode, + random, + scientific, + test-framework, + test-framework-hunit, + test-framework-quickcheck2, + text, + time, + transformers, + unordered-containers, + vector, + lib, }: mkDerivation { pname = "ghcjs-base"; @@ -18,14 +43,43 @@ mkDerivation { sha256 = "sha256-x6eCAK1Hne0QkV3Loi9YpxbleNHU593E4AO8cbk2vUc="; }; libraryHaskellDepends = [ - aeson attoparsec base binary bytestring containers deepseq dlist - ghc-prim ghcjs-prim hashable integer-gmp primitive scientific text - time transformers unordered-containers vector + aeson + attoparsec + base + binary + bytestring + containers + deepseq + dlist + ghc-prim + ghcjs-prim + hashable + integer-gmp + primitive + scientific + text + time + transformers + unordered-containers + vector ]; testHaskellDepends = [ - array base bytestring deepseq directory ghc-prim ghcjs-prim HUnit - primitive QuickCheck quickcheck-unicode random test-framework - test-framework-hunit test-framework-quickcheck2 text + array + base + bytestring + deepseq + directory + ghc-prim + ghcjs-prim + HUnit + primitive + QuickCheck + quickcheck-unicode + random + test-framework + test-framework-hunit + test-framework-quickcheck2 + text ]; homepage = "https://github.com/ghcjs/ghcjs-base"; description = "base library for GHCJS"; diff --git a/pkgs/development/compilers/gleam/default.nix b/pkgs/development/compilers/gleam/default.nix index 81638062e61d70..8a083a0ab39041 100644 --- a/pkgs/development/compilers/gleam/default.nix +++ b/pkgs/development/compilers/gleam/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, git -, pkg-config -, openssl -, erlang -, Security -, nix-update-script -, SystemConfiguration +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + git, + pkg-config, + openssl, + erlang, + Security, + nix-update-script, + SystemConfiguration, }: rustPlatform.buildRustPackage rec { @@ -22,10 +23,20 @@ rustPlatform.buildRustPackage rec { hash = "sha256-r+iN6eLmy6qnrhvHKUQufd/4mvZL9TCVaqLqEPcLu1E="; }; - nativeBuildInputs = [ git pkg-config ]; + nativeBuildInputs = [ + git + pkg-config + ]; - buildInputs = [ openssl erlang ] ++ - lib.optionals stdenv.hostPlatform.isDarwin [ Security SystemConfiguration ]; + buildInputs = + [ + openssl + erlang + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + ]; cargoHash = "sha256-+kKKdNAvr8sTaFvzCCpY1bVS779DgJbHI9kUUIi4lXE="; diff --git a/pkgs/development/compilers/go/1.22.nix b/pkgs/development/compilers/go/1.22.nix index d0f0a4e7ff6863..319ed5081d0cce 100644 --- a/pkgs/development/compilers/go/1.22.nix +++ b/pkgs/development/compilers/go/1.22.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, tzdata -, substituteAll -, iana-etc -, apple-sdk_11 -, xcbuild -, mailcap -, buildPackages -, pkgsBuildTarget -, threadsCross -, testers -, skopeo -, buildGo122Module +{ + lib, + stdenv, + fetchurl, + tzdata, + substituteAll, + iana-etc, + apple-sdk_11, + xcbuild, + mailcap, + buildPackages, + pkgsBuildTarget, + threadsCross, + testers, + skopeo, + buildGo122Module, }: let @@ -20,23 +21,26 @@ let skopeoTest = skopeo.override { buildGoModule = buildGo122Module; }; - goarch = platform: { - "aarch64" = "arm64"; - "arm" = "arm"; - "armv5tel" = "arm"; - "armv6l" = "arm"; - "armv7l" = "arm"; - "i686" = "386"; - "mips" = "mips"; - "mips64el" = "mips64le"; - "mipsel" = "mipsle"; - "powerpc64" = "ppc64"; - "powerpc64le" = "ppc64le"; - "riscv64" = "riscv64"; - "s390x" = "s390x"; - "x86_64" = "amd64"; - "wasm32" = "wasm"; - }.${platform.parsed.cpu.name} or (throw "Unsupported system: ${platform.parsed.cpu.name}"); + goarch = + platform: + { + "aarch64" = "arm64"; + "arm" = "arm"; + "armv5tel" = "arm"; + "armv6l" = "arm"; + "armv7l" = "arm"; + "i686" = "386"; + "mips" = "mips"; + "mips64el" = "mips64le"; + "mipsel" = "mipsle"; + "powerpc64" = "ppc64"; + "powerpc64le" = "ppc64le"; + "riscv64" = "riscv64"; + "s390x" = "s390x"; + "x86_64" = "amd64"; + "wasm32" = "wasm"; + } + .${platform.parsed.cpu.name} or (throw "Unsupported system: ${platform.parsed.cpu.name}"); # We need a target compiler which is still runnable at build time, # to handle the cross-building case where build != host == target @@ -54,11 +58,15 @@ stdenv.mkDerivation (finalAttrs: { }; strictDeps = true; - buildInputs = [ ] + buildInputs = + [ ] ++ lib.optionals stdenv.hostPlatform.isLinux [ stdenv.cc.libc.out ] ++ lib.optionals (stdenv.hostPlatform.libc == "glibc") [ stdenv.cc.libc.static ]; - depsTargetTargetPropagated = lib.optionals stdenv.targetPlatform.isDarwin [ apple-sdk_11 xcbuild ]; + depsTargetTargetPropagated = lib.optionals stdenv.targetPlatform.isDarwin [ + apple-sdk_11 + xcbuild + ]; depsBuildTarget = lib.optional isCross targetCC; @@ -99,18 +107,12 @@ stdenv.mkDerivation (finalAttrs: { # {CC,CXX}_FOR_TARGET must be only set for cross compilation case as go expect those # to be different from CC/CXX - CC_FOR_TARGET = - if isCross then - "${targetCC}/bin/${targetCC.targetPrefix}cc" - else - null; - CXX_FOR_TARGET = - if isCross then - "${targetCC}/bin/${targetCC.targetPrefix}c++" - else - null; - - GOARM = toString (lib.intersectLists [ (stdenv.hostPlatform.parsed.cpu.version or "") ] [ "5" "6" "7" ]); + CC_FOR_TARGET = if isCross then "${targetCC}/bin/${targetCC.targetPrefix}cc" else null; + CXX_FOR_TARGET = if isCross then "${targetCC}/bin/${targetCC.targetPrefix}c++" else null; + + GOARM = toString ( + lib.intersectLists [ (stdenv.hostPlatform.parsed.cpu.version or "") ] [ "5" "6" "7" ] + ); GO386 = "softfloat"; # from Arch: don't assume sse2 on i686 # Wasi does not support CGO CGO_ENABLED = if stdenv.targetPlatform.isWasi then 0 else 1; @@ -126,9 +128,9 @@ stdenv.mkDerivation (finalAttrs: { export PATH=$(pwd)/bin:$PATH ${lib.optionalString isCross '' - # Independent from host/target, CC should produce code for the building system. - # We only set it when cross-compiling. - export CC=${buildPackages.stdenv.cc}/bin/cc + # Independent from host/target, CC should produce code for the building system. + # We only set it when cross-compiling. + export CC=${buildPackages.stdenv.cc}/bin/cc ''} ulimit -a @@ -138,22 +140,35 @@ stdenv.mkDerivation (finalAttrs: { runHook postBuild ''; - preInstall = '' - # Contains the wrong perl shebang when cross compiling, - # since it is not used for anything we can deleted as well. - rm src/regexp/syntax/make_perl_groups.pl - '' + (if (stdenv.buildPlatform.system != stdenv.hostPlatform.system) then '' - mv bin/*_*/* bin - rmdir bin/*_* - ${lib.optionalString (!(finalAttrs.GOHOSTARCH == finalAttrs.GOARCH && finalAttrs.GOOS == finalAttrs.GOHOSTOS)) '' - rm -rf pkg/${finalAttrs.GOHOSTOS}_${finalAttrs.GOHOSTARCH} pkg/tool/${finalAttrs.GOHOSTOS}_${finalAttrs.GOHOSTARCH} - ''} - '' else lib.optionalString (stdenv.hostPlatform.system != stdenv.targetPlatform.system) '' - rm -rf bin/*_* - ${lib.optionalString (!(finalAttrs.GOHOSTARCH == finalAttrs.GOARCH && finalAttrs.GOOS == finalAttrs.GOHOSTOS)) '' - rm -rf pkg/${finalAttrs.GOOS}_${finalAttrs.GOARCH} pkg/tool/${finalAttrs.GOOS}_${finalAttrs.GOARCH} - ''} - ''); + preInstall = + '' + # Contains the wrong perl shebang when cross compiling, + # since it is not used for anything we can deleted as well. + rm src/regexp/syntax/make_perl_groups.pl + '' + + ( + if (stdenv.buildPlatform.system != stdenv.hostPlatform.system) then + '' + mv bin/*_*/* bin + rmdir bin/*_* + ${lib.optionalString + (!(finalAttrs.GOHOSTARCH == finalAttrs.GOARCH && finalAttrs.GOOS == finalAttrs.GOHOSTOS)) + '' + rm -rf pkg/${finalAttrs.GOHOSTOS}_${finalAttrs.GOHOSTARCH} pkg/tool/${finalAttrs.GOHOSTOS}_${finalAttrs.GOHOSTARCH} + '' + } + '' + else + lib.optionalString (stdenv.hostPlatform.system != stdenv.targetPlatform.system) '' + rm -rf bin/*_* + ${lib.optionalString + (!(finalAttrs.GOHOSTARCH == finalAttrs.GOARCH && finalAttrs.GOOS == finalAttrs.GOHOSTOS)) + '' + rm -rf pkg/${finalAttrs.GOOS}_${finalAttrs.GOARCH} pkg/tool/${finalAttrs.GOOS}_${finalAttrs.GOARCH} + '' + } + '' + ); installPhase = '' runHook preInstall diff --git a/pkgs/development/compilers/go/1.23.nix b/pkgs/development/compilers/go/1.23.nix index 14a80eae8046d3..4d056b1504493c 100644 --- a/pkgs/development/compilers/go/1.23.nix +++ b/pkgs/development/compilers/go/1.23.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, tzdata -, substituteAll -, iana-etc -, apple-sdk_11 -, xcbuild -, mailcap -, buildPackages -, pkgsBuildTarget -, threadsCross -, testers -, skopeo -, buildGo123Module +{ + lib, + stdenv, + fetchurl, + tzdata, + substituteAll, + iana-etc, + apple-sdk_11, + xcbuild, + mailcap, + buildPackages, + pkgsBuildTarget, + threadsCross, + testers, + skopeo, + buildGo123Module, }: let @@ -20,23 +21,26 @@ let skopeoTest = skopeo.override { buildGoModule = buildGo123Module; }; - goarch = platform: { - "aarch64" = "arm64"; - "arm" = "arm"; - "armv5tel" = "arm"; - "armv6l" = "arm"; - "armv7l" = "arm"; - "i686" = "386"; - "mips" = "mips"; - "mips64el" = "mips64le"; - "mipsel" = "mipsle"; - "powerpc64" = "ppc64"; - "powerpc64le" = "ppc64le"; - "riscv64" = "riscv64"; - "s390x" = "s390x"; - "x86_64" = "amd64"; - "wasm32" = "wasm"; - }.${platform.parsed.cpu.name} or (throw "Unsupported system: ${platform.parsed.cpu.name}"); + goarch = + platform: + { + "aarch64" = "arm64"; + "arm" = "arm"; + "armv5tel" = "arm"; + "armv6l" = "arm"; + "armv7l" = "arm"; + "i686" = "386"; + "mips" = "mips"; + "mips64el" = "mips64le"; + "mipsel" = "mipsle"; + "powerpc64" = "ppc64"; + "powerpc64le" = "ppc64le"; + "riscv64" = "riscv64"; + "s390x" = "s390x"; + "x86_64" = "amd64"; + "wasm32" = "wasm"; + } + .${platform.parsed.cpu.name} or (throw "Unsupported system: ${platform.parsed.cpu.name}"); # We need a target compiler which is still runnable at build time, # to handle the cross-building case where build != host == target @@ -54,11 +58,15 @@ stdenv.mkDerivation (finalAttrs: { }; strictDeps = true; - buildInputs = [ ] + buildInputs = + [ ] ++ lib.optionals stdenv.hostPlatform.isLinux [ stdenv.cc.libc.out ] ++ lib.optionals (stdenv.hostPlatform.libc == "glibc") [ stdenv.cc.libc.static ]; - depsTargetTargetPropagated = lib.optionals stdenv.targetPlatform.isDarwin [ apple-sdk_11 xcbuild ]; + depsTargetTargetPropagated = lib.optionals stdenv.targetPlatform.isDarwin [ + apple-sdk_11 + xcbuild + ]; depsBuildTarget = lib.optional isCross targetCC; @@ -99,18 +107,12 @@ stdenv.mkDerivation (finalAttrs: { # {CC,CXX}_FOR_TARGET must be only set for cross compilation case as go expect those # to be different from CC/CXX - CC_FOR_TARGET = - if isCross then - "${targetCC}/bin/${targetCC.targetPrefix}cc" - else - null; - CXX_FOR_TARGET = - if isCross then - "${targetCC}/bin/${targetCC.targetPrefix}c++" - else - null; - - GOARM = toString (lib.intersectLists [ (stdenv.hostPlatform.parsed.cpu.version or "") ] [ "5" "6" "7" ]); + CC_FOR_TARGET = if isCross then "${targetCC}/bin/${targetCC.targetPrefix}cc" else null; + CXX_FOR_TARGET = if isCross then "${targetCC}/bin/${targetCC.targetPrefix}c++" else null; + + GOARM = toString ( + lib.intersectLists [ (stdenv.hostPlatform.parsed.cpu.version or "") ] [ "5" "6" "7" ] + ); GO386 = "softfloat"; # from Arch: don't assume sse2 on i686 # Wasi does not support CGO CGO_ENABLED = if stdenv.targetPlatform.isWasi then 0 else 1; @@ -124,9 +126,9 @@ stdenv.mkDerivation (finalAttrs: { export PATH=$(pwd)/bin:$PATH ${lib.optionalString isCross '' - # Independent from host/target, CC should produce code for the building system. - # We only set it when cross-compiling. - export CC=${buildPackages.stdenv.cc}/bin/cc + # Independent from host/target, CC should produce code for the building system. + # We only set it when cross-compiling. + export CC=${buildPackages.stdenv.cc}/bin/cc ''} ulimit -a @@ -136,22 +138,35 @@ stdenv.mkDerivation (finalAttrs: { runHook postBuild ''; - preInstall = '' - # Contains the wrong perl shebang when cross compiling, - # since it is not used for anything we can deleted as well. - rm src/regexp/syntax/make_perl_groups.pl - '' + (if (stdenv.buildPlatform.system != stdenv.hostPlatform.system) then '' - mv bin/*_*/* bin - rmdir bin/*_* - ${lib.optionalString (!(finalAttrs.GOHOSTARCH == finalAttrs.GOARCH && finalAttrs.GOOS == finalAttrs.GOHOSTOS)) '' - rm -rf pkg/${finalAttrs.GOHOSTOS}_${finalAttrs.GOHOSTARCH} pkg/tool/${finalAttrs.GOHOSTOS}_${finalAttrs.GOHOSTARCH} - ''} - '' else lib.optionalString (stdenv.hostPlatform.system != stdenv.targetPlatform.system) '' - rm -rf bin/*_* - ${lib.optionalString (!(finalAttrs.GOHOSTARCH == finalAttrs.GOARCH && finalAttrs.GOOS == finalAttrs.GOHOSTOS)) '' - rm -rf pkg/${finalAttrs.GOOS}_${finalAttrs.GOARCH} pkg/tool/${finalAttrs.GOOS}_${finalAttrs.GOARCH} - ''} - ''); + preInstall = + '' + # Contains the wrong perl shebang when cross compiling, + # since it is not used for anything we can deleted as well. + rm src/regexp/syntax/make_perl_groups.pl + '' + + ( + if (stdenv.buildPlatform.system != stdenv.hostPlatform.system) then + '' + mv bin/*_*/* bin + rmdir bin/*_* + ${lib.optionalString + (!(finalAttrs.GOHOSTARCH == finalAttrs.GOARCH && finalAttrs.GOOS == finalAttrs.GOHOSTOS)) + '' + rm -rf pkg/${finalAttrs.GOHOSTOS}_${finalAttrs.GOHOSTARCH} pkg/tool/${finalAttrs.GOHOSTOS}_${finalAttrs.GOHOSTARCH} + '' + } + '' + else + lib.optionalString (stdenv.hostPlatform.system != stdenv.targetPlatform.system) '' + rm -rf bin/*_* + ${lib.optionalString + (!(finalAttrs.GOHOSTARCH == finalAttrs.GOARCH && finalAttrs.GOOS == finalAttrs.GOHOSTOS)) + '' + rm -rf pkg/${finalAttrs.GOOS}_${finalAttrs.GOARCH} pkg/tool/${finalAttrs.GOOS}_${finalAttrs.GOARCH} + '' + } + '' + ); installPhase = '' runHook preInstall diff --git a/pkgs/development/compilers/go/binary.nix b/pkgs/development/compilers/go/binary.nix index 3c43cc4de1508e..aa993542249f13 100644 --- a/pkgs/development/compilers/go/binary.nix +++ b/pkgs/development/compilers/go/binary.nix @@ -1,18 +1,25 @@ -{ lib, stdenv, fetchurl, version, hashes }: +{ + lib, + stdenv, + fetchurl, + version, + hashes, +}: let - toGoKernel = platform: - if platform.isDarwin then "darwin" - else platform.parsed.kernel.name; + toGoKernel = platform: if platform.isDarwin then "darwin" else platform.parsed.kernel.name; - toGoCPU = platform: { - "i686" = "386"; - "x86_64" = "amd64"; - "aarch64" = "arm64"; - "armv6l" = "armv6l"; - "armv7l" = "armv6l"; - "powerpc64le" = "ppc64le"; - "riscv64" = "riscv64"; - }.${platform.parsed.cpu.name} or (throw "Unsupported CPU ${platform.parsed.cpu.name}"); + toGoCPU = + platform: + { + "i686" = "386"; + "x86_64" = "amd64"; + "aarch64" = "arm64"; + "armv6l" = "armv6l"; + "armv7l" = "armv6l"; + "powerpc64le" = "ppc64le"; + "riscv64" = "riscv64"; + } + .${platform.parsed.cpu.name} or (throw "Unsupported CPU ${platform.parsed.cpu.name}"); toGoPlatform = platform: "${toGoKernel platform}-${toGoCPU platform}"; diff --git a/pkgs/development/compilers/graalvm/community-edition/buildGraalvm.nix b/pkgs/development/compilers/graalvm/community-edition/buildGraalvm.nix index 366e2a9c17d714..ea4c6d1b282d16 100644 --- a/pkgs/development/compilers/graalvm/community-edition/buildGraalvm.nix +++ b/pkgs/development/compilers/graalvm/community-edition/buildGraalvm.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, alsa-lib -, apple-sdk_11 -, autoPatchelfHook -, cairo -, cups -, darwinMinVersionHook -, fontconfig -, glib -, glibc -, gtk3 -, makeWrapper -, musl -, runCommandCC -, setJavaClassPath -, unzip -, xorg -, zlib +{ + lib, + stdenv, + alsa-lib, + apple-sdk_11, + autoPatchelfHook, + cairo, + cups, + darwinMinVersionHook, + fontconfig, + glib, + glibc, + gtk3, + makeWrapper, + musl, + runCommandCC, + setJavaClassPath, + unzip, + xorg, + zlib, # extra params -, extraCLibs ? [ ] -, gtkSupport ? stdenv.hostPlatform.isLinux -, useMusl ? false -, ... -} @ args: + extraCLibs ? [ ], + gtkSupport ? stdenv.hostPlatform.isLinux, + useMusl ? false, + ... +}@args: assert useMusl -> stdenv.hostPlatform.isLinux; let @@ -55,187 +56,227 @@ let ]; cLibs = lib.optionals stdenv.hostPlatform.isLinux ( - [ glibc zlib.static ] + [ + glibc + zlib.static + ] ++ lib.optionals (!useMusl) [ glibc.static ] ++ lib.optionals useMusl [ musl ] ++ extraCLibs ); # GraalVM 21.3.0+ expects musl-gcc as -musl-gcc - musl-gcc = (runCommandCC "musl-gcc" { } '' - mkdir -p $out/bin - ln -s ${lib.getDev musl}/bin/musl-gcc $out/bin/${stdenv.hostPlatform.system}-musl-gcc - ''); + musl-gcc = ( + runCommandCC "musl-gcc" { } '' + mkdir -p $out/bin + ln -s ${lib.getDev musl}/bin/musl-gcc $out/bin/${stdenv.hostPlatform.system}-musl-gcc + '' + ); binPath = lib.makeBinPath (lib.optionals useMusl [ musl-gcc ] ++ [ stdenv.cc ]); - runtimeLibraryPath = lib.makeLibraryPath - ([ cups ] ++ lib.optionals gtkSupport [ cairo glib gtk3 ]); - - graalvm-ce = stdenv.mkDerivation ({ - pname = "graalvm-ce"; - - unpackPhase = '' - runHook preUnpack - - mkdir -p "$out" - - # The tarball on Linux has the following directory structure: - # - # graalvm-ce-java11-20.3.0/* - # - # while on Darwin it looks like this: - # - # graalvm-ce-java11-20.3.0/Contents/Home/* - # - # We therefor use --strip-components=1 vs 3 depending on the platform. - tar xf "$src" -C "$out" --strip-components=${ - if stdenv.hostPlatform.isLinux then "1" else "3" - } - - # Sanity check - if [ ! -d "$out/bin" ]; then - echo "The `bin` is directory missing after extracting the graalvm" - echo "tarball, please compare the directory structure of the" - echo "tarball with what happens in the unpackPhase (in particular" - echo "with regards to the `--strip-components` flag)." - exit 1 - fi - - runHook postUnpack - ''; - - dontStrip = true; - - nativeBuildInputs = [ unzip makeWrapper ] - ++ lib.optional stdenv.hostPlatform.isLinux autoPatchelfHook; - - propagatedBuildInputs = [ setJavaClassPath zlib ]; - - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib # libasound.so wanted by lib/libjsound.so - fontconfig - (lib.getLib stdenv.cc.cc) # libstdc++.so.6 - xorg.libX11 - xorg.libXext - xorg.libXi - xorg.libXrender - xorg.libXtst - ] ++ (lib.optionals stdenv.hostPlatform.isDarwin [ - apple-sdk_11 - (darwinMinVersionHook "11.0") - ]); - - postInstall = - let - cLibsAsFlags = (map (l: "--add-flags '-H:CLibraryPath=${l}/lib'") cLibs); - preservedNixVariables = [ - "-ENIX_BINTOOLS" - "-ENIX_BINTOOLS_WRAPPER_TARGET_HOST_${stdenv.cc.suffixSalt}" - "-ENIX_BUILD_CORES" - "-ENIX_BUILD_TOP" - "-ENIX_CC" - "-ENIX_CC_WRAPPER_TARGET_HOST_${stdenv.cc.suffixSalt}" - "-ENIX_CFLAGS_COMPILE" - "-ENIX_HARDENING_ENABLE" - "-ENIX_LDFLAGS" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "-ELOCALE_ARCHIVE" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-EDEVELOPER_DIR" - "-EDEVELOPER_DIR_FOR_BUILD" - "-EDEVELOPER_DIR_FOR_TARGET" - "-EMACOSX_DEPLOYMENT_TARGET" - "-EMACOSX_DEPLOYMENT_TARGET_FOR_BUILD" - "-EMACOSX_DEPLOYMENT_TARGET_FOR_TARGET" - "-ENIX_APPLE_SDK_VERSION" - ]; - preservedNixVariablesAsFlags = (map (f: "--add-flags '${f}'") preservedNixVariables); - in + runtimeLibraryPath = lib.makeLibraryPath ( + [ cups ] + ++ lib.optionals gtkSupport [ + cairo + glib + gtk3 + ] + ); + + graalvm-ce = stdenv.mkDerivation ( + { + pname = "graalvm-ce"; + + unpackPhase = '' + runHook preUnpack + + mkdir -p "$out" + + # The tarball on Linux has the following directory structure: + # + # graalvm-ce-java11-20.3.0/* + # + # while on Darwin it looks like this: + # + # graalvm-ce-java11-20.3.0/Contents/Home/* + # + # We therefor use --strip-components=1 vs 3 depending on the platform. + tar xf "$src" -C "$out" --strip-components=${if stdenv.hostPlatform.isLinux then "1" else "3"} + + # Sanity check + if [ ! -d "$out/bin" ]; then + echo "The `bin` is directory missing after extracting the graalvm" + echo "tarball, please compare the directory structure of the" + echo "tarball with what happens in the unpackPhase (in particular" + echo "with regards to the `--strip-components` flag)." + exit 1 + fi + + runHook postUnpack + ''; + + dontStrip = true; + + nativeBuildInputs = [ + unzip + makeWrapper + ] ++ lib.optional stdenv.hostPlatform.isLinux autoPatchelfHook; + + propagatedBuildInputs = [ + setJavaClassPath + zlib + ]; + + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib # libasound.so wanted by lib/libjsound.so + fontconfig + (lib.getLib stdenv.cc.cc) # libstdc++.so.6 + xorg.libX11 + xorg.libXext + xorg.libXi + xorg.libXrender + xorg.libXtst + ] + ++ (lib.optionals stdenv.hostPlatform.isDarwin [ + apple-sdk_11 + (darwinMinVersionHook "11.0") + ]); + + postInstall = + let + cLibsAsFlags = (map (l: "--add-flags '-H:CLibraryPath=${l}/lib'") cLibs); + preservedNixVariables = + [ + "-ENIX_BINTOOLS" + "-ENIX_BINTOOLS_WRAPPER_TARGET_HOST_${stdenv.cc.suffixSalt}" + "-ENIX_BUILD_CORES" + "-ENIX_BUILD_TOP" + "-ENIX_CC" + "-ENIX_CC_WRAPPER_TARGET_HOST_${stdenv.cc.suffixSalt}" + "-ENIX_CFLAGS_COMPILE" + "-ENIX_HARDENING_ENABLE" + "-ENIX_LDFLAGS" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "-ELOCALE_ARCHIVE" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-EDEVELOPER_DIR" + "-EDEVELOPER_DIR_FOR_BUILD" + "-EDEVELOPER_DIR_FOR_TARGET" + "-EMACOSX_DEPLOYMENT_TARGET" + "-EMACOSX_DEPLOYMENT_TARGET_FOR_BUILD" + "-EMACOSX_DEPLOYMENT_TARGET_FOR_TARGET" + "-ENIX_APPLE_SDK_VERSION" + ]; + preservedNixVariablesAsFlags = (map (f: "--add-flags '${f}'") preservedNixVariables); + in '' - # jni.h expects jni_md.h to be in the header search path. - ln -sf $out/include/linux/*_md.h $out/include/ - - mkdir -p $out/share - # move files in $out like LICENSE.txt - find $out/ -maxdepth 1 -type f -exec mv {} $out/share \; - # symbolic link to $out/lib/svm/LICENSE_NATIVEIMAGE.txt - rm -f $out/LICENSE_NATIVEIMAGE.txt - - # copy-paste openjdk's preFixup - # Set JAVA_HOME automatically. - mkdir -p $out/nix-support - cat > $out/nix-support/setup-hook << EOF - if [ -z "\''${JAVA_HOME-}" ]; then export JAVA_HOME=$out; fi - EOF - - wrapProgram $out/bin/native-image \ - --prefix PATH : ${binPath} \ - ${toString (cLibsAsFlags ++ preservedNixVariablesAsFlags)} + # jni.h expects jni_md.h to be in the header search path. + ln -sf $out/include/linux/*_md.h $out/include/ + + mkdir -p $out/share + # move files in $out like LICENSE.txt + find $out/ -maxdepth 1 -type f -exec mv {} $out/share \; + # symbolic link to $out/lib/svm/LICENSE_NATIVEIMAGE.txt + rm -f $out/LICENSE_NATIVEIMAGE.txt + + # copy-paste openjdk's preFixup + # Set JAVA_HOME automatically. + mkdir -p $out/nix-support + cat > $out/nix-support/setup-hook << EOF + if [ -z "\''${JAVA_HOME-}" ]; then export JAVA_HOME=$out; fi + EOF + + wrapProgram $out/bin/native-image \ + --prefix PATH : ${binPath} \ + ${toString (cLibsAsFlags ++ preservedNixVariablesAsFlags)} + ''; + + preFixup = lib.optionalString (stdenv.hostPlatform.isLinux) '' + for bin in $(find "$out/bin" -executable -type f); do + wrapProgram "$bin" --prefix LD_LIBRARY_PATH : "${runtimeLibraryPath}" + done ''; - preFixup = lib.optionalString (stdenv.hostPlatform.isLinux) '' - for bin in $(find "$out/bin" -executable -type f); do - wrapProgram "$bin" --prefix LD_LIBRARY_PATH : "${runtimeLibraryPath}" - done - ''; - - doInstallCheck = true; - installCheckPhase = '' - runHook preInstallCheck - - ${# broken in darwin - lib.optionalString stdenv.hostPlatform.isLinux '' - echo "Testing Jshell" - echo '1 + 1' | $out/bin/jshell - ''} - - echo ${lib.escapeShellArg '' - public class HelloWorld { - public static void main(String[] args) { - System.out.println("Hello World"); - } + doInstallCheck = true; + installCheckPhase = '' + runHook preInstallCheck + + ${ + # broken in darwin + lib.optionalString stdenv.hostPlatform.isLinux '' + echo "Testing Jshell" + echo '1 + 1' | $out/bin/jshell + '' } - ''} > HelloWorld.java - $out/bin/javac HelloWorld.java - # run on JVM with Graal Compiler - echo "Testing GraalVM" - $out/bin/java -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI -XX:+UseJVMCICompiler HelloWorld | fgrep 'Hello World' + echo ${lib.escapeShellArg '' + public class HelloWorld { + public static void main(String[] args) { + System.out.println("Hello World"); + } + } + ''} > HelloWorld.java + $out/bin/javac HelloWorld.java - echo "Ahead-Of-Time compilation" - $out/bin/native-image -H:+UnlockExperimentalVMOptions -H:-CheckToolchain -H:+ReportExceptionStackTraces -march=compatibility HelloWorld - ./helloworld | fgrep 'Hello World' + # run on JVM with Graal Compiler + echo "Testing GraalVM" + $out/bin/java -XX:+UnlockExperimentalVMOptions -XX:+EnableJVMCI -XX:+UseJVMCICompiler HelloWorld | fgrep 'Hello World' - ${# -H:+StaticExecutableWithDynamicLibC is only available in Linux - lib.optionalString (stdenv.hostPlatform.isLinux && !useMusl) '' - echo "Ahead-Of-Time compilation with -H:+StaticExecutableWithDynamicLibC" - $out/bin/native-image -H:+UnlockExperimentalVMOptions -H:+StaticExecutableWithDynamicLibC -march=compatibility $extraNativeImageArgs HelloWorld + echo "Ahead-Of-Time compilation" + $out/bin/native-image -H:+UnlockExperimentalVMOptions -H:-CheckToolchain -H:+ReportExceptionStackTraces -march=compatibility HelloWorld ./helloworld | fgrep 'Hello World' - ''} - ${# --static is only available in Linux - lib.optionalString (stdenv.hostPlatform.isLinux && useMusl) '' - echo "Ahead-Of-Time compilation with --static and --libc=musl" - $out/bin/native-image $extraNativeImageArgs -march=compatibility --libc=musl --static HelloWorld - ./helloworld | fgrep 'Hello World' - ''} - - runHook postInstallCheck - ''; - - passthru = { - home = graalvm-ce; - updateScript = [ ./update.sh "graalvm-ce" ]; - } // (args.passhtru or { }); - - meta = with lib; ({ - homepage = "https://www.graalvm.org/"; - description = "High-Performance Polyglot VM"; - license = with licenses; [ upl gpl2Classpath bsd3 ]; - sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - mainProgram = "java"; - maintainers = with maintainers; teams.graalvm-ce.members ++ [ ]; - } // (args.meta or { })); - } // extraArgs); + ${ + # -H:+StaticExecutableWithDynamicLibC is only available in Linux + lib.optionalString (stdenv.hostPlatform.isLinux && !useMusl) '' + echo "Ahead-Of-Time compilation with -H:+StaticExecutableWithDynamicLibC" + $out/bin/native-image -H:+UnlockExperimentalVMOptions -H:+StaticExecutableWithDynamicLibC -march=compatibility $extraNativeImageArgs HelloWorld + ./helloworld | fgrep 'Hello World' + '' + } + + ${ + # --static is only available in Linux + lib.optionalString (stdenv.hostPlatform.isLinux && useMusl) '' + echo "Ahead-Of-Time compilation with --static and --libc=musl" + $out/bin/native-image $extraNativeImageArgs -march=compatibility --libc=musl --static HelloWorld + ./helloworld | fgrep 'Hello World' + '' + } + + runHook postInstallCheck + ''; + + passthru = { + home = graalvm-ce; + updateScript = [ + ./update.sh + "graalvm-ce" + ]; + } // (args.passhtru or { }); + + meta = + with lib; + ( + { + homepage = "https://www.graalvm.org/"; + description = "High-Performance Polyglot VM"; + license = with licenses; [ + upl + gpl2Classpath + bsd3 + ]; + sourceProvenance = with sourceTypes; [ binaryNativeCode ]; + mainProgram = "java"; + maintainers = with maintainers; teams.graalvm-ce.members ++ [ ]; + } + // (args.meta or { }) + ); + } + // extraArgs + ); in graalvm-ce diff --git a/pkgs/development/compilers/graalvm/community-edition/buildGraalvmProduct.nix b/pkgs/development/compilers/graalvm/community-edition/buildGraalvmProduct.nix index 39b4136698c797..8c5ba7d4c046a3 100644 --- a/pkgs/development/compilers/graalvm/community-edition/buildGraalvmProduct.nix +++ b/pkgs/development/compilers/graalvm/community-edition/buildGraalvmProduct.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, autoPatchelfHook -, darwin -, graalvm-ce -, makeWrapper -, zlib -, libxcrypt-legacy +{ + lib, + stdenv, + autoPatchelfHook, + darwin, + graalvm-ce, + makeWrapper, + zlib, + libxcrypt-legacy, # extra params -, product -, extraBuildInputs ? [ ] -, extraNativeBuildInputs ? [ ] -, ... -} @ args: + product, + extraBuildInputs ? [ ], + extraNativeBuildInputs ? [ ], + ... +}@args: let extraArgs = builtins.removeAttrs args [ @@ -29,49 +30,66 @@ let "meta" ]; in -stdenv.mkDerivation ({ - pname = product; +stdenv.mkDerivation ( + { + pname = product; - nativeBuildInputs = [ makeWrapper ] - ++ lib.optional stdenv.hostPlatform.isLinux autoPatchelfHook - ++ extraNativeBuildInputs; + nativeBuildInputs = + [ makeWrapper ] + ++ lib.optional stdenv.hostPlatform.isLinux autoPatchelfHook + ++ extraNativeBuildInputs; - buildInputs = [ - (lib.getLib stdenv.cc.cc) # libstdc++.so.6 - zlib - libxcrypt-legacy # libcrypt.so.1 (default is .2 now) - ] - ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.Foundation - ++ extraBuildInputs; + buildInputs = + [ + (lib.getLib stdenv.cc.cc) # libstdc++.so.6 + zlib + libxcrypt-legacy # libcrypt.so.1 (default is .2 now) + ] + ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.Foundation + ++ extraBuildInputs; - unpackPhase = '' - runHook preUnpack + unpackPhase = '' + runHook preUnpack - mkdir -p "$out" + mkdir -p "$out" - tar xf "$src" -C "$out" --strip-components=1 + tar xf "$src" -C "$out" --strip-components=1 - # Sanity check - if [ ! -d "$out/bin" ]; then - echo "The `bin` is directory missing after extracting the graalvm" - echo "tarball, please compare the directory structure of the" - echo "tarball with what happens in the unpackPhase (in particular" - echo "with regards to the `--strip-components` flag)." - exit 1 - fi + # Sanity check + if [ ! -d "$out/bin" ]; then + echo "The `bin` is directory missing after extracting the graalvm" + echo "tarball, please compare the directory structure of the" + echo "tarball with what happens in the unpackPhase (in particular" + echo "with regards to the `--strip-components` flag)." + exit 1 + fi - runHook postUnpack - ''; + runHook postUnpack + ''; - dontStrip = true; + dontStrip = true; - passthru = { - updateScript = [ ./update.sh product ]; - } // (args.passhtru or { }); + passthru = { + updateScript = [ + ./update.sh + product + ]; + } // (args.passhtru or { }); - meta = ({ - inherit (graalvm-ce.meta) homepage license sourceProvenance maintainers platforms; - description = "High-Performance Polyglot VM (Product: ${product})"; - mainProgram = "js"; - } // (args.meta or { })); -} // extraArgs) + meta = ( + { + inherit (graalvm-ce.meta) + homepage + license + sourceProvenance + maintainers + platforms + ; + description = "High-Performance Polyglot VM (Product: ${product})"; + mainProgram = "js"; + } + // (args.meta or { }) + ); + } + // extraArgs +) diff --git a/pkgs/development/compilers/graalvm/community-edition/default.nix b/pkgs/development/compilers/graalvm/community-edition/default.nix index 2c703dd502b21d..c4fc958fa8fa18 100644 --- a/pkgs/development/compilers/graalvm/community-edition/default.nix +++ b/pkgs/development/compilers/graalvm/community-edition/default.nix @@ -1,9 +1,9 @@ -{ lib -, pkgs +{ + lib, + pkgs, }: -lib.makeScope pkgs.newScope (self: -{ +lib.makeScope pkgs.newScope (self: { buildGraalvm = self.callPackage ./buildGraalvm.nix; buildGraalvmProduct = self.callPackage ./buildGraalvmProduct.nix; diff --git a/pkgs/development/compilers/graalvm/community-edition/graaljs/default.nix b/pkgs/development/compilers/graalvm/community-edition/graaljs/default.nix index ec662e156721c5..5813b1acf4781d 100644 --- a/pkgs/development/compilers/graalvm/community-edition/graaljs/default.nix +++ b/pkgs/development/compilers/graalvm/community-edition/graaljs/default.nix @@ -1,6 +1,7 @@ -{ stdenv -, fetchurl -, graalvmCEPackages +{ + stdenv, + fetchurl, + graalvmCEPackages, }: graalvmCEPackages.buildGraalvmProduct { diff --git a/pkgs/development/compilers/graalvm/community-edition/graalnodejs/default.nix b/pkgs/development/compilers/graalvm/community-edition/graalnodejs/default.nix index d98f4b0e380f4f..b0e225b8fff648 100644 --- a/pkgs/development/compilers/graalvm/community-edition/graalnodejs/default.nix +++ b/pkgs/development/compilers/graalvm/community-edition/graalnodejs/default.nix @@ -1,6 +1,7 @@ -{ stdenv -, fetchurl -, graalvmCEPackages +{ + stdenv, + fetchurl, + graalvmCEPackages, }: graalvmCEPackages.buildGraalvmProduct { diff --git a/pkgs/development/compilers/graalvm/community-edition/graalpy/default.nix b/pkgs/development/compilers/graalvm/community-edition/graalpy/default.nix index e2b28500f7fe4f..e00cd1568c6e96 100644 --- a/pkgs/development/compilers/graalvm/community-edition/graalpy/default.nix +++ b/pkgs/development/compilers/graalvm/community-edition/graalpy/default.nix @@ -1,6 +1,7 @@ -{ stdenv -, fetchurl -, graalvmCEPackages +{ + stdenv, + fetchurl, + graalvmCEPackages, }: graalvmCEPackages.buildGraalvmProduct { diff --git a/pkgs/development/compilers/graalvm/community-edition/graalvm-ce/default.nix b/pkgs/development/compilers/graalvm/community-edition/graalvm-ce/default.nix index b7f7db61097f2d..c287da0d4092c3 100644 --- a/pkgs/development/compilers/graalvm/community-edition/graalvm-ce/default.nix +++ b/pkgs/development/compilers/graalvm/community-edition/graalvm-ce/default.nix @@ -1,7 +1,8 @@ -{ stdenv -, fetchurl -, graalvmCEPackages -, useMusl ? false +{ + stdenv, + fetchurl, + graalvmCEPackages, + useMusl ? false, }: graalvmCEPackages.buildGraalvm { diff --git a/pkgs/development/compilers/graalvm/community-edition/truffleruby/default.nix b/pkgs/development/compilers/graalvm/community-edition/truffleruby/default.nix index da971347652e17..a26a633262e8e2 100644 --- a/pkgs/development/compilers/graalvm/community-edition/truffleruby/default.nix +++ b/pkgs/development/compilers/graalvm/community-edition/truffleruby/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, graalvmCEPackages -, libyaml -, openssl +{ + lib, + stdenv, + fetchurl, + graalvmCEPackages, + libyaml, + openssl, }: graalvmCEPackages.buildGraalvmProduct { @@ -30,9 +31,11 @@ graalvmCEPackages.buildGraalvmProduct { export LANG=C export LC_ALL=C $out/bin/ruby -e 'puts(1 + 1)' - ${# broken in darwin with sandbox enabled + ${ + # broken in darwin with sandbox enabled lib.optionalString stdenv.hostPlatform.isLinux '' - echo '1 + 1' | $out/bin/irb - ''} + echo '1 + 1' | $out/bin/irb + '' + } ''; } diff --git a/pkgs/development/compilers/gwt/2.4.0.nix b/pkgs/development/compilers/gwt/2.4.0.nix index b769eb30463a95..03ef01b78f0fe0 100644 --- a/pkgs/development/compilers/gwt/2.4.0.nix +++ b/pkgs/development/compilers/gwt/2.4.0.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "gwt-java"; diff --git a/pkgs/development/compilers/heptagon/default.nix b/pkgs/development/compilers/heptagon/default.nix index 7f9c1c849f4a5a..0bfdb702aaafba 100644 --- a/pkgs/development/compilers/heptagon/default.nix +++ b/pkgs/development/compilers/heptagon/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitLab -, makeWrapper -, ocamlPackages +{ + lib, + stdenv, + fetchFromGitLab, + makeWrapper, + ocamlPackages, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/compilers/inform6/default.nix b/pkgs/development/compilers/inform6/default.nix index eafd03a02605e1..49c7d2b49e4b23 100644 --- a/pkgs/development/compilers/inform6/default.nix +++ b/pkgs/development/compilers/inform6/default.nix @@ -1,10 +1,15 @@ -{ lib, stdenv, fetchurl, perl }: +{ + lib, + stdenv, + fetchurl, + perl, +}: stdenv.mkDerivation rec { pname = "inform6"; version = "6.42-r6"; - src = fetchurl { + src = fetchurl { url = "https://ifarchive.org/if-archive/infocom/compilers/inform6/source/inform-${version}.tar.gz"; sha256 = "sha256-SVsIhvlWVK0UWgyL85YuueE92CQ9RAgaUBruIOzGoww="; }; diff --git a/pkgs/development/compilers/ios-cross-compile/9.2.nix b/pkgs/development/compilers/ios-cross-compile/9.2.nix index 320cbdc41b0f0c..5c77f19797ac09 100644 --- a/pkgs/development/compilers/ios-cross-compile/9.2.nix +++ b/pkgs/development/compilers/ios-cross-compile/9.2.nix @@ -1,7 +1,17 @@ -{ lib, git, clang, - fetchFromGitHub, requireFile, - openssl, xz, gnutar, - automake, autoconf, libtool, clangStdenv } : +{ + lib, + git, + clang, + fetchFromGitHub, + requireFile, + openssl, + xz, + gnutar, + automake, + autoconf, + libtool, + clangStdenv, +}: clangStdenv.mkDerivation rec { pname = "ios-cross-compile"; @@ -49,17 +59,26 @@ clangStdenv.mkDerivation rec { nix-prefetch-url file:///path/to/${name} and run this installation again. - ''; + ''; }; - nativeBuildInputs = [ autoconf automake ]; - buildInputs = [ git xz gnutar openssl libtool clang ]; + nativeBuildInputs = [ + autoconf + automake + ]; + buildInputs = [ + git + xz + gnutar + openssl + libtool + clang + ]; alt_wrapper = ./alt_wrapper.c; builder = ./9.2_builder.sh; meta = { - description = - "Provides an iOS cross compiler from 7.1 up to iOS-${version} and ldid"; + description = "Provides an iOS cross compiler from 7.1 up to iOS-${version} and ldid"; platforms = lib.platforms.linux; - hydraPlatforms = []; + hydraPlatforms = [ ]; maintainers = with lib.maintainers; [ fxfactorial ]; license = lib.licenses.gpl2; }; diff --git a/pkgs/development/compilers/ispc/default.nix b/pkgs/development/compilers/ispc/default.nix index c98712f5d9648b..7c3c7a0fdb38d1 100644 --- a/pkgs/development/compilers/ispc/default.nix +++ b/pkgs/development/compilers/ispc/default.nix @@ -1,26 +1,53 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, which, m4, python3, bison, flex, llvmPackages, ncurses, tbb +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + which, + m4, + python3, + bison, + flex, + llvmPackages, + ncurses, + tbb, # the default test target is sse4, but that is not supported by all Hydra agents -, testedTargets ? if stdenv.hostPlatform.isAarch64 || stdenv.hostPlatform.isAarch32 then [ "neon-i32x4" ] else [ "sse2-i32x4" ] + testedTargets ? + if stdenv.hostPlatform.isAarch64 || stdenv.hostPlatform.isAarch32 then + [ "neon-i32x4" ] + else + [ "sse2-i32x4" ], }: stdenv.mkDerivation rec { - pname = "ispc"; + pname = "ispc"; version = "1.25.3"; dontFixCmake = true; # https://github.com/NixOS/nixpkgs/pull/232522#issuecomment-2133803566 src = fetchFromGitHub { - owner = pname; - repo = pname; - rev = "v${version}"; + owner = pname; + repo = pname; + rev = "v${version}"; sha256 = "sha256-baTJNfhOSYfJJnrutkW06AIMXpVP3eBpEes0GSI1yGY="; }; - nativeBuildInputs = [ cmake which m4 bison flex python3 llvmPackages.libllvm.dev tbb ]; + nativeBuildInputs = [ + cmake + which + m4 + bison + flex + python3 + llvmPackages.libllvm.dev + tbb + ]; buildInputs = with llvmPackages; [ - libllvm libclang openmp ncurses + libllvm + libclang + openmp + ncurses ]; postPatch = '' @@ -61,16 +88,32 @@ stdenv.mkDerivation rec { "-DCLANGPP_EXECUTABLE=${llvmPackages.clang}/bin/clang++" "-DISPC_INCLUDE_EXAMPLES=OFF" "-DISPC_INCLUDE_UTILS=OFF" - ("-DARM_ENABLED=" + (if stdenv.hostPlatform.isAarch64 || stdenv.hostPlatform.isAarch32 then "TRUE" else "FALSE")) - ("-DX86_ENABLED=" + (if stdenv.hostPlatform.isx86_64 || stdenv.hostPlatform.isx86_32 then "TRUE" else "FALSE")) + ( + "-DARM_ENABLED=" + + (if stdenv.hostPlatform.isAarch64 || stdenv.hostPlatform.isAarch32 then "TRUE" else "FALSE") + ) + ( + "-DX86_ENABLED=" + + (if stdenv.hostPlatform.isx86_64 || stdenv.hostPlatform.isx86_32 then "TRUE" else "FALSE") + ) ]; meta = with lib; { - homepage = "https://ispc.github.io/"; + homepage = "https://ispc.github.io/"; description = "Intel 'Single Program, Multiple Data' Compiler, a vectorised language"; mainProgram = "ispc"; - license = licenses.bsd3; - platforms = [ "x86_64-linux" "x86_64-darwin" "aarch64-linux" "aarch64-darwin" ]; # TODO: buildable on more platforms? - maintainers = with maintainers; [ aristid thoughtpolice athas alexfmpe ]; + license = licenses.bsd3; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + "aarch64-linux" + "aarch64-darwin" + ]; # TODO: buildable on more platforms? + maintainers = with maintainers; [ + aristid + thoughtpolice + athas + alexfmpe + ]; }; } diff --git a/pkgs/development/compilers/jetbrains-jdk/17.nix b/pkgs/development/compilers/jetbrains-jdk/17.nix index a868a441ba4c97..bb9cd0a3894200 100644 --- a/pkgs/development/compilers/jetbrains-jdk/17.nix +++ b/pkgs/development/compilers/jetbrains-jdk/17.nix @@ -1,40 +1,43 @@ -{ lib -, stdenv -, fetchFromGitHub -, jetbrains -, openjdk17 -, openjdk17-bootstrap -, git -, autoconf -, unzip -, rsync -, debugBuild ? false -, withJcef ? true - -, libXdamage -, libXxf86vm -, libXrandr -, libXi -, libXcursor -, libXrender -, libX11 -, libXext -, libxcb -, nss -, nspr -, libdrm -, mesa -, wayland -, udev +{ + lib, + stdenv, + fetchFromGitHub, + jetbrains, + openjdk17, + openjdk17-bootstrap, + git, + autoconf, + unzip, + rsync, + debugBuild ? false, + withJcef ? true, + + libXdamage, + libXxf86vm, + libXrandr, + libXi, + libXcursor, + libXrender, + libX11, + libXext, + libxcb, + nss, + nspr, + libdrm, + mesa, + wayland, + udev, }: assert debugBuild -> withJcef; let - arch = { - "aarch64-linux" = "aarch64"; - "x86_64-linux" = "x64"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + arch = + { + "aarch64-linux" = "aarch64"; + "x86_64-linux" = "x64"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); cpu = stdenv.hostPlatform.parsed.cpu.name; in openjdk17.overrideAttrs (oldAttrs: rec { @@ -81,7 +84,9 @@ openjdk17.overrideAttrs (oldAttrs: rec { -i jb/project/tools/linux/scripts/mkimages_${arch}.sh patchShebangs . - ./jb/project/tools/linux/scripts/mkimages_${arch}.sh ${build} ${if debugBuild then "fd" else (if withJcef then "jcef" else "nomod")} + ./jb/project/tools/linux/scripts/mkimages_${arch}.sh ${build} ${ + if debugBuild then "fd" else (if withJcef then "jcef" else "nomod") + } runHook postBuild ''; @@ -99,7 +104,9 @@ openjdk17.overrideAttrs (oldAttrs: rec { mv build/linux-${cpu}-server-${buildType}/images/jdk/man build/linux-${cpu}-server-${buildType}/images/${jbrsdkDir} rm -rf build/linux-${cpu}-server-${buildType}/images/jdk mv build/linux-${cpu}-server-${buildType}/images/${jbrsdkDir} build/linux-${cpu}-server-${buildType}/images/jdk - '' + oldAttrs.installPhase + "runHook postInstall"; + '' + + oldAttrs.installPhase + + "runHook postInstall"; postInstall = lib.optionalString withJcef '' chmod +x $out/lib/openjdk/lib/chrome-sandbox @@ -109,10 +116,25 @@ openjdk17.overrideAttrs (oldAttrs: rec { postFixup = '' # Build the set of output library directories to rpath against - LIBDIRS="${lib.makeLibraryPath [ - libXdamage libXxf86vm libXrandr libXi libXcursor libXrender libX11 libXext libxcb - nss nspr libdrm mesa wayland udev - ]}" + LIBDIRS="${ + lib.makeLibraryPath [ + libXdamage + libXxf86vm + libXrandr + libXi + libXcursor + libXrender + libX11 + libXext + libxcb + nss + nspr + libdrm + mesa + wayland + udev + ] + }" for output in $outputs; do if [ "$output" = debug ]; then continue; fi LIBDIRS="$(find $(eval echo \$$output) -name \*.so\* -exec dirname {} \+ | sort -u | tr '\n' ':'):$LIBDIRS" @@ -129,7 +151,12 @@ openjdk17.overrideAttrs (oldAttrs: rec { done ''; - nativeBuildInputs = [ git autoconf unzip rsync ] ++ oldAttrs.nativeBuildInputs; + nativeBuildInputs = [ + git + autoconf + unzip + rsync + ] ++ oldAttrs.nativeBuildInputs; meta = with lib; { description = "An OpenJDK fork to better support Jetbrains's products."; diff --git a/pkgs/development/compilers/jetbrains-jdk/default.nix b/pkgs/development/compilers/jetbrains-jdk/default.nix index 77ac8e904d4725..35f0a2722d2ae3 100644 --- a/pkgs/development/compilers/jetbrains-jdk/default.nix +++ b/pkgs/development/compilers/jetbrains-jdk/default.nix @@ -1,39 +1,42 @@ -{ lib -, stdenv -, fetchFromGitHub -, jetbrains -, jdk -, git -, autoconf -, unzip -, rsync -, debugBuild ? false -, withJcef ? true - -, libXdamage -, libXxf86vm -, libXrandr -, libXi -, libXcursor -, libXrender -, libX11 -, libXext -, libxcb -, nss -, nspr -, libdrm -, mesa -, wayland -, udev +{ + lib, + stdenv, + fetchFromGitHub, + jetbrains, + jdk, + git, + autoconf, + unzip, + rsync, + debugBuild ? false, + withJcef ? true, + + libXdamage, + libXxf86vm, + libXrandr, + libXi, + libXcursor, + libXrender, + libX11, + libXext, + libxcb, + nss, + nspr, + libdrm, + mesa, + wayland, + udev, }: assert debugBuild -> withJcef; let - arch = { - "aarch64-linux" = "aarch64"; - "x86_64-linux" = "x64"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + arch = + { + "aarch64-linux" = "aarch64"; + "x86_64-linux" = "x64"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); cpu = stdenv.hostPlatform.parsed.cpu.name; in jdk.overrideAttrs (oldAttrs: rec { @@ -81,7 +84,9 @@ jdk.overrideAttrs (oldAttrs: rec { -i jb/project/tools/linux/scripts/mkimages_${arch}.sh patchShebangs . - ./jb/project/tools/linux/scripts/mkimages_${arch}.sh ${build} ${if debugBuild then "fd" else (if withJcef then "jcef" else "nomod")} + ./jb/project/tools/linux/scripts/mkimages_${arch}.sh ${build} ${ + if debugBuild then "fd" else (if withJcef then "jcef" else "nomod") + } runHook postBuild ''; @@ -99,7 +104,9 @@ jdk.overrideAttrs (oldAttrs: rec { mv build/linux-${cpu}-server-${buildType}/images/jdk/man build/linux-${cpu}-server-${buildType}/images/${jbrsdkDir} rm -rf build/linux-${cpu}-server-${buildType}/images/jdk mv build/linux-${cpu}-server-${buildType}/images/${jbrsdkDir} build/linux-${cpu}-server-${buildType}/images/jdk - '' + oldAttrs.installPhase + "runHook postInstall"; + '' + + oldAttrs.installPhase + + "runHook postInstall"; postInstall = lib.optionalString withJcef '' chmod +x $out/lib/openjdk/lib/chrome-sandbox @@ -109,10 +116,25 @@ jdk.overrideAttrs (oldAttrs: rec { postFixup = '' # Build the set of output library directories to rpath against - LIBDIRS="${lib.makeLibraryPath [ - libXdamage libXxf86vm libXrandr libXi libXcursor libXrender libX11 libXext libxcb - nss nspr libdrm mesa wayland udev - ]}" + LIBDIRS="${ + lib.makeLibraryPath [ + libXdamage + libXxf86vm + libXrandr + libXi + libXcursor + libXrender + libX11 + libXext + libxcb + nss + nspr + libdrm + mesa + wayland + udev + ] + }" for output in $outputs; do if [ "$output" = debug ]; then continue; fi LIBDIRS="$(find $(eval echo \$$output) -name \*.so\* -exec dirname {} \+ | sort -u | tr '\n' ':'):$LIBDIRS" @@ -129,7 +151,12 @@ jdk.overrideAttrs (oldAttrs: rec { done ''; - nativeBuildInputs = [ git autoconf unzip rsync ] ++ oldAttrs.nativeBuildInputs; + nativeBuildInputs = [ + git + autoconf + unzip + rsync + ] ++ oldAttrs.nativeBuildInputs; meta = with lib; { description = "OpenJDK fork to better support Jetbrains's products"; diff --git a/pkgs/development/compilers/jetbrains-jdk/jcef.nix b/pkgs/development/compilers/jetbrains-jdk/jcef.nix index 9cda4fc516237b..6baef76f924a88 100644 --- a/pkgs/development/compilers/jetbrains-jdk/jcef.nix +++ b/pkgs/development/compilers/jetbrains-jdk/jcef.nix @@ -1,48 +1,49 @@ -{ fetchFromGitHub -, fetchurl -, fetchzip -, stdenv -, cmake -, python3 -, jdk -, git -, rsync -, lib -, ant -, ninja -, strip-nondeterminism -, stripJavaArchivesHook - -, debugBuild ? false - -, glib -, nss -, nspr -, atk -, at-spi2-atk -, libdrm -, libGL -, expat -, libxcb -, libxkbcommon -, libX11 -, libXcomposite -, libXdamage -, libXext -, libXfixes -, libXrandr -, mesa -, gtk3 -, pango -, cairo -, alsa-lib -, dbus -, at-spi2-core -, cups -, libxshmfence -, udev -, boost -, thrift +{ + fetchFromGitHub, + fetchurl, + fetchzip, + stdenv, + cmake, + python3, + jdk, + git, + rsync, + lib, + ant, + ninja, + strip-nondeterminism, + stripJavaArchivesHook, + + debugBuild ? false, + + glib, + nss, + nspr, + atk, + at-spi2-atk, + libdrm, + libGL, + expat, + libxcb, + libxkbcommon, + libX11, + libXcomposite, + libXdamage, + libXext, + libXfixes, + libXrandr, + mesa, + gtk3, + pango, + cairo, + alsa-lib, + dbus, + at-spi2-core, + cups, + libxshmfence, + udev, + boost, + thrift, }: assert !stdenv.hostPlatform.isDarwin; @@ -79,22 +80,26 @@ let ]; buildType = if debugBuild then "Debug" else "Release"; - platform = { - "aarch64-linux" = "linuxarm64"; - "x86_64-linux" = "linux64"; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); - arches = { - "linuxarm64" = { - depsArch = "arm64"; - projectArch = "arm64"; - targetArch = "arm64"; - }; - "linux64" = { - depsArch = "amd64"; - projectArch = "x86_64"; - targetArch = "x86_64"; - }; - }.${platform}; + platform = + { + "aarch64-linux" = "linuxarm64"; + "x86_64-linux" = "linux64"; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + arches = + { + "linuxarm64" = { + depsArch = "arm64"; + projectArch = "arm64"; + targetArch = "arm64"; + }; + "linux64" = { + depsArch = "amd64"; + projectArch = "x86_64"; + targetArch = "x86_64"; + }; + } + .${platform}; inherit (arches) depsArch projectArch targetArch; in @@ -106,8 +111,25 @@ stdenv.mkDerivation rec { # Run `git rev-list --count HEAD` version = "867"; - nativeBuildInputs = [ cmake python3 jdk git rsync ant ninja strip-nondeterminism stripJavaArchivesHook ]; - buildInputs = [ boost libX11 libXdamage nss nspr thrift ]; + nativeBuildInputs = [ + cmake + python3 + jdk + git + rsync + ant + ninja + strip-nondeterminism + stripJavaArchivesHook + ]; + buildInputs = [ + boost + libX11 + libXdamage + nss + nspr + thrift + ]; src = fetchFromGitHub { owner = "jetbrains"; @@ -119,10 +141,12 @@ stdenv.mkDerivation rec { let # `cef_binary_${CEF_VERSION}_linux64_minimal`, where CEF_VERSION is from $src/CMakeLists.txt name = "cef_binary_122.1.9+gd14e051+chromium-122.0.6261.94_${platform}_minimal"; - hash = { - "linuxarm64" = "sha256-wABtvz0JHitlkkB748I7yr02Oxs5lXvqDfrBAQiKWHU="; - "linux64" = "sha256-qlutM0IsE1emcMe/3p7kwMIK7ou1rZGvpUkrSMVPnCc="; - }.${platform}; + hash = + { + "linuxarm64" = "sha256-wABtvz0JHitlkkB748I7yr02Oxs5lXvqDfrBAQiKWHU="; + "linux64" = "sha256-qlutM0IsE1emcMe/3p7kwMIK7ou1rZGvpUkrSMVPnCc="; + } + .${platform}; urlName = builtins.replaceStrings [ "+" ] [ "%2B" ] name; in fetchzip { @@ -173,7 +197,10 @@ stdenv.mkDerivation rec { runHook postConfigure ''; - outputs = [ "out" "unpacked" ]; + outputs = [ + "out" + "unpacked" + ]; postBuild = '' export JCEF_ROOT_DIR=$(realpath ..) @@ -183,86 +210,89 @@ stdenv.mkDerivation rec { # N.B. For new versions, manually synchronize the following # definitions with jb/tools/common/create_modules.sh to include # newly added modules - installPhase = '' - runHook preInstall - - export JCEF_ROOT_DIR=$(realpath ..) - export THRIFT_DIR="$JCEF_ROOT_DIR"/third_party/thrift - export THRIFT_JAR=libthrift-0.19.0.jar - export OUT_NATIVE_DIR=$JCEF_ROOT_DIR/jcef_build/native/${buildType} - export JB_TOOLS_DIR=$(realpath ../jb/tools) - export JB_TOOLS_OS_DIR=$JB_TOOLS_DIR/linux - export OUT_CLS_DIR=$(realpath ../out/${platform}) - export TARGET_ARCH=${targetArch} DEPS_ARCH=${depsArch} - export OS=linux - export JOGAMP_DIR="$JCEF_ROOT_DIR"/third_party/jogamp/jar - - mkdir -p $unpacked/{jogl,gluegen,jcef} - - function extract_jar { - __jar=$1 - __dst_dir=$2 - __content_dir="''${3:-.}" - __tmp=.tmp_extract_jar - rm -rf "$__tmp" && mkdir "$__tmp" - ( - cd "$__tmp" || exit 1 - jar -xf "$__jar" - ) - rm -rf "$__tmp/META-INF" - rm -rf "$__dst_dir" && mkdir "$__dst_dir" - if [ -z "$__content_dir" ] - then - cp -R "$__tmp"/* "$__dst_dir" - else - cp -R "$__tmp"/"$__content_dir"/* "$__dst_dir" - fi - rm -rf $__tmp - } - - cd $unpacked/gluegen - cp "$JOGAMP_DIR"/gluegen-rt.jar . - cp "$JB_TOOLS_DIR"/common/gluegen-module-info.java module-info.java - javac --patch-module gluegen.rt=gluegen-rt.jar module-info.java - jar uf gluegen-rt.jar module-info.class - rm module-info.class module-info.java - mkdir lib - '' - # see https://github.com/JetBrains/jcef/commit/f3b787e3326c1915d663abded7f055c0866f32ec - + lib.optionalString (platform != "linuxarm64") '' - extract_jar "$JOGAMP_DIR"/gluegen-rt-natives-"$OS"-"$DEPS_ARCH".jar lib natives/"$OS"-"$DEPS_ARCH" - '' + '' - - cd ../jogl - cp "$JOGAMP_DIR"/gluegen-rt.jar . - cp "$JOGAMP_DIR"/jogl-all.jar . - cp "$JB_TOOLS_OS_DIR"/jogl-module-info.java module-info.java - javac --module-path . --patch-module jogl.all=jogl-all.jar module-info.java - jar uf jogl-all.jar module-info.class - rm module-info.class module-info.java - mkdir lib - '' - # see https://github.com/JetBrains/jcef/commit/f3b787e3326c1915d663abded7f055c0866f32ec - + lib.optionalString (platform != "linuxarm64") '' - extract_jar "$JOGAMP_DIR"/jogl-all-natives-"$OS"-"$DEPS_ARCH".jar lib natives/"$OS"-"$DEPS_ARCH" - '' + '' - - cd ../jcef - cp "$THRIFT_DIR"/"$THRIFT_JAR" . - cp "$JB_TOOLS_DIR"/common/thrift-module-info.java module-info.java - javac --patch-module org.apache.thrift=$THRIFT_JAR module-info.java - jar uf $THRIFT_JAR module-info.class - rm module-info.class module-info.java - cp "$OUT_CLS_DIR"/jcef.jar . - mkdir lib - cp -R "$OUT_NATIVE_DIR"/* lib - - mkdir -p $out/jmods - - bash "$JB_TOOLS_DIR"/common/create_version_file.sh $out - - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + + export JCEF_ROOT_DIR=$(realpath ..) + export THRIFT_DIR="$JCEF_ROOT_DIR"/third_party/thrift + export THRIFT_JAR=libthrift-0.19.0.jar + export OUT_NATIVE_DIR=$JCEF_ROOT_DIR/jcef_build/native/${buildType} + export JB_TOOLS_DIR=$(realpath ../jb/tools) + export JB_TOOLS_OS_DIR=$JB_TOOLS_DIR/linux + export OUT_CLS_DIR=$(realpath ../out/${platform}) + export TARGET_ARCH=${targetArch} DEPS_ARCH=${depsArch} + export OS=linux + export JOGAMP_DIR="$JCEF_ROOT_DIR"/third_party/jogamp/jar + + mkdir -p $unpacked/{jogl,gluegen,jcef} + + function extract_jar { + __jar=$1 + __dst_dir=$2 + __content_dir="''${3:-.}" + __tmp=.tmp_extract_jar + rm -rf "$__tmp" && mkdir "$__tmp" + ( + cd "$__tmp" || exit 1 + jar -xf "$__jar" + ) + rm -rf "$__tmp/META-INF" + rm -rf "$__dst_dir" && mkdir "$__dst_dir" + if [ -z "$__content_dir" ] + then + cp -R "$__tmp"/* "$__dst_dir" + else + cp -R "$__tmp"/"$__content_dir"/* "$__dst_dir" + fi + rm -rf $__tmp + } + + cd $unpacked/gluegen + cp "$JOGAMP_DIR"/gluegen-rt.jar . + cp "$JB_TOOLS_DIR"/common/gluegen-module-info.java module-info.java + javac --patch-module gluegen.rt=gluegen-rt.jar module-info.java + jar uf gluegen-rt.jar module-info.class + rm module-info.class module-info.java + mkdir lib + '' + # see https://github.com/JetBrains/jcef/commit/f3b787e3326c1915d663abded7f055c0866f32ec + + lib.optionalString (platform != "linuxarm64") '' + extract_jar "$JOGAMP_DIR"/gluegen-rt-natives-"$OS"-"$DEPS_ARCH".jar lib natives/"$OS"-"$DEPS_ARCH" + '' + + '' + + cd ../jogl + cp "$JOGAMP_DIR"/gluegen-rt.jar . + cp "$JOGAMP_DIR"/jogl-all.jar . + cp "$JB_TOOLS_OS_DIR"/jogl-module-info.java module-info.java + javac --module-path . --patch-module jogl.all=jogl-all.jar module-info.java + jar uf jogl-all.jar module-info.class + rm module-info.class module-info.java + mkdir lib + '' + # see https://github.com/JetBrains/jcef/commit/f3b787e3326c1915d663abded7f055c0866f32ec + + lib.optionalString (platform != "linuxarm64") '' + extract_jar "$JOGAMP_DIR"/jogl-all-natives-"$OS"-"$DEPS_ARCH".jar lib natives/"$OS"-"$DEPS_ARCH" + '' + + '' + + cd ../jcef + cp "$THRIFT_DIR"/"$THRIFT_JAR" . + cp "$JB_TOOLS_DIR"/common/thrift-module-info.java module-info.java + javac --patch-module org.apache.thrift=$THRIFT_JAR module-info.java + jar uf $THRIFT_JAR module-info.class + rm module-info.class module-info.java + cp "$OUT_CLS_DIR"/jcef.jar . + mkdir lib + cp -R "$OUT_NATIVE_DIR"/* lib + + mkdir -p $out/jmods + + bash "$JB_TOOLS_DIR"/common/create_version_file.sh $out + + runHook postInstall + ''; dontStrip = debugBuild; diff --git a/pkgs/development/compilers/julia/generic-bin.nix b/pkgs/development/compilers/julia/generic-bin.nix index f7fb2b7559c260..a7c9d323b7a8a2 100644 --- a/pkgs/development/compilers/julia/generic-bin.nix +++ b/pkgs/development/compilers/julia/generic-bin.nix @@ -1,71 +1,80 @@ -{ version -, sha256 -, patches ? [ ] +{ + version, + sha256, + patches ? [ ], }: -{ autoPatchelfHook -, fetchurl -, lib -, stdenv +{ + autoPatchelfHook, + fetchurl, + lib, + stdenv, }: let - skip_tests = [ - # Test flaky on ofborg - "channels" - # Test flaky because of our RPATH patching - # https://github.com/NixOS/nixpkgs/pull/230965#issuecomment-1545336489 - "compiler/codegen" - # Test flaky - "read" - ] ++ lib.optionals (lib.versionAtLeast version "1.10") [ - # Test flaky - # https://github.com/JuliaLang/julia/issues/52739 - "REPL" - # Test flaky - "ccall" - ] ++ lib.optionals (lib.versionAtLeast version "1.11") [ - # Test flaky - # https://github.com/JuliaLang/julia/issues/54280 - "loading" - "cmdlineargs" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # Test flaky on ofborg - "FileWatching" - # Test requires pbcopy - "InteractiveUtils" - # Test requires network access - "Sockets" - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ - # Test Failed at $out/share/julia/stdlib/v1.8/LinearAlgebra/test/blas.jl:702 - "LinearAlgebra/blas" - # Test Failed at $out/share/julia/test/misc.jl:724 - "misc" - ]; + skip_tests = + [ + # Test flaky on ofborg + "channels" + # Test flaky because of our RPATH patching + # https://github.com/NixOS/nixpkgs/pull/230965#issuecomment-1545336489 + "compiler/codegen" + # Test flaky + "read" + ] + ++ lib.optionals (lib.versionAtLeast version "1.10") [ + # Test flaky + # https://github.com/JuliaLang/julia/issues/52739 + "REPL" + # Test flaky + "ccall" + ] + ++ lib.optionals (lib.versionAtLeast version "1.11") [ + # Test flaky + # https://github.com/JuliaLang/julia/issues/54280 + "loading" + "cmdlineargs" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # Test flaky on ofborg + "FileWatching" + # Test requires pbcopy + "InteractiveUtils" + # Test requires network access + "Sockets" + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + # Test Failed at $out/share/julia/stdlib/v1.8/LinearAlgebra/test/blas.jl:702 + "LinearAlgebra/blas" + # Test Failed at $out/share/julia/test/misc.jl:724 + "misc" + ]; in stdenv.mkDerivation { pname = "julia-bin"; inherit version patches; - src = { - x86_64-linux = fetchurl { - url = "https://julialang-s3.julialang.org/bin/linux/x64/${lib.versions.majorMinor version}/julia-${version}-linux-x86_64.tar.gz"; - sha256 = sha256.x86_64-linux; - }; - aarch64-linux = fetchurl { - url = "https://julialang-s3.julialang.org/bin/linux/aarch64/${lib.versions.majorMinor version}/julia-${version}-linux-aarch64.tar.gz"; - sha256 = sha256.aarch64-linux; - }; - x86_64-darwin = fetchurl { - url = "https://julialang-s3.julialang.org/bin/mac/x64/${lib.versions.majorMinor version}/julia-${version}-mac64.tar.gz"; - sha256 = sha256.x86_64-darwin; - }; - aarch64-darwin = fetchurl { - url = "https://julialang-s3.julialang.org/bin/mac/aarch64/${lib.versions.majorMinor version}/julia-${version}-macaarch64.tar.gz"; - sha256 = sha256.aarch64-darwin; - }; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + { + x86_64-linux = fetchurl { + url = "https://julialang-s3.julialang.org/bin/linux/x64/${lib.versions.majorMinor version}/julia-${version}-linux-x86_64.tar.gz"; + sha256 = sha256.x86_64-linux; + }; + aarch64-linux = fetchurl { + url = "https://julialang-s3.julialang.org/bin/linux/aarch64/${lib.versions.majorMinor version}/julia-${version}-linux-aarch64.tar.gz"; + sha256 = sha256.aarch64-linux; + }; + x86_64-darwin = fetchurl { + url = "https://julialang-s3.julialang.org/bin/mac/x64/${lib.versions.majorMinor version}/julia-${version}-mac64.tar.gz"; + sha256 = sha256.x86_64-darwin; + }; + aarch64-darwin = fetchurl { + url = "https://julialang-s3.julialang.org/bin/mac/aarch64/${lib.versions.majorMinor version}/julia-${version}-macaarch64.tar.gz"; + sha256 = sha256.aarch64-darwin; + }; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); postPatch = '' # Julia fails to pick up our Certification Authority root certificates, but @@ -82,16 +91,19 @@ stdenv.mkDerivation { stdenv.cc.cc ]; - installPhase = '' - runHook preInstall - cp -r . $out - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - # "$out/share" is intentionally omitted since it contains - # julia package images and patchelf would break them - autoPatchelf "$out/bin" "$out/lib" "$out/libexec" - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + cp -r . $out + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + # "$out/share" is intentionally omitted since it contains + # julia package images and patchelf would break them + autoPatchelf "$out/bin" "$out/lib" "$out/libexec" + '' + + '' + runHook postInstall + ''; # Breaks backtraces, etc. dontStrip = true; @@ -123,8 +135,18 @@ stdenv.mkDerivation { homepage = "https://julialang.org"; # Bundled and linked with various GPL code, although Julia itself is MIT. license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ raskin nickcao wegank thomasjm ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + maintainers = with lib.maintainers; [ + raskin + nickcao + wegank + thomasjm + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; mainProgram = "julia"; }; } diff --git a/pkgs/development/compilers/koka/default.nix b/pkgs/development/compilers/koka/default.nix index 029bd88dfb0f13..67f3f931025f9c 100644 --- a/pkgs/development/compilers/koka/default.nix +++ b/pkgs/development/compilers/koka/default.nix @@ -1,33 +1,34 @@ -{ stdenv -, pkgsHostTarget -, cmake -, makeWrapper -, mkDerivation -, fetchFromGitHub -, alex -, lib -, hpack -, aeson -, array -, async -, base -, bytestring -, co-log-core -, cond -, containers -, directory -, FloatingHex -, isocline -, lens -, lsp_2_4_0_0 -, mtl -, network -, network-simple -, parsec -, process -, text -, text-rope -, time +{ + stdenv, + pkgsHostTarget, + cmake, + makeWrapper, + mkDerivation, + fetchFromGitHub, + alex, + lib, + hpack, + aeson, + array, + async, + base, + bytestring, + co-log-core, + cond, + containers, + directory, + FloatingHex, + isocline, + lens, + lsp_2_4_0_0, + mtl, + network, + network-simple, + parsec, + process, + text, + text-rope, + time, }: let @@ -44,7 +45,10 @@ let inherit version; src = "${src}/kklib"; nativeBuildInputs = [ cmake ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postInstall = '' mkdir -p ''${!outputDev}/share/koka/v${version} cp -a ../../kklib ''${!outputDev}/share/koka/v${version} @@ -88,7 +92,10 @@ mkDerivation rec { time kklib ]; - executableToolDepends = [ alex makeWrapper ]; + executableToolDepends = [ + alex + makeWrapper + ]; postInstall = '' mkdir -p $out/share/koka/v${version} cp -a lib $out/share/koka/v${version} @@ -103,5 +110,8 @@ mkDerivation rec { homepage = "https://github.com/koka-lang/koka"; changelog = "${homepage}/blob/master/doc/spec/news.mdk"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ siraben sternenseemann ]; + maintainers = with lib.maintainers; [ + siraben + sternenseemann + ]; } diff --git a/pkgs/development/compilers/kotlin/native.nix b/pkgs/development/compilers/kotlin/native.nix index 5b54c22d3f3a9b..82e31e579fae1b 100644 --- a/pkgs/development/compilers/kotlin/native.nix +++ b/pkgs/development/compilers/kotlin/native.nix @@ -1,30 +1,38 @@ -{ lib -, stdenv -, fetchurl -, jre -, makeWrapper +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, }: stdenv.mkDerivation rec { pname = "kotlin-native"; version = "1.9.24"; - src = let - getArch = { - "aarch64-darwin" = "macos-aarch64"; - "x86_64-darwin" = "macos-x86_64"; - "x86_64-linux" = "linux-x86_64"; - }.${stdenv.system} or (throw "${pname}-${version}: ${stdenv.system} is unsupported."); + src = + let + getArch = + { + "aarch64-darwin" = "macos-aarch64"; + "x86_64-darwin" = "macos-x86_64"; + "x86_64-linux" = "linux-x86_64"; + } + .${stdenv.system} or (throw "${pname}-${version}: ${stdenv.system} is unsupported."); - getUrl = version: arch: - "https://github.com/JetBrains/kotlin/releases/download/v${version}/kotlin-native-${arch}-${version}.tar.gz"; + getUrl = + version: arch: + "https://github.com/JetBrains/kotlin/releases/download/v${version}/kotlin-native-${arch}-${version}.tar.gz"; - getHash = arch: { - "macos-aarch64" = "sha256-RGXi2SyUviH9HdMApSoBJfEdeOfnssaTnWldvGJ6ysY="; - "macos-x86_64" = "sha256-eDwbmVV0jLN5REb3D5JfDbjzUuZujxA2puw75Te1aFs="; - "linux-x86_64" = "sha256-sEvljAwLSzBxUxxpRAPxtlDnKlwH4FGQTDaQI+XcGaE="; - }.${arch}; - in + getHash = + arch: + { + "macos-aarch64" = "sha256-RGXi2SyUviH9HdMApSoBJfEdeOfnssaTnWldvGJ6ysY="; + "macos-x86_64" = "sha256-eDwbmVV0jLN5REb3D5JfDbjzUuZujxA2puw75Te1aFs="; + "linux-x86_64" = "sha256-sEvljAwLSzBxUxxpRAPxtlDnKlwH4FGQTDaQI+XcGaE="; + } + .${arch}; + in fetchurl { url = getUrl version getArch; sha256 = getHash getArch; diff --git a/pkgs/development/compilers/ligo/default.nix b/pkgs/development/compilers/ligo/default.nix index b472eb921cfa60..cebb3614490dc0 100644 --- a/pkgs/development/compilers/ligo/default.nix +++ b/pkgs/development/compilers/ligo/default.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitLab -, git -, coq -, ocamlPackages -, cacert -, ocaml-crunch -, jq -, mustache-go -, yaml2json -, tezos-rust-libs -, darwin +{ + stdenv, + lib, + fetchFromGitLab, + git, + coq, + ocamlPackages, + cacert, + ocaml-crunch, + jq, + mustache-go, + yaml2json, + tezos-rust-libs, + darwin, }: ocamlPackages.buildDunePackage rec { @@ -45,77 +46,80 @@ ocamlPackages.buildDunePackage rec { yaml2json ]; - buildInputs = with ocamlPackages; [ - coq - menhir - menhirLib - qcheck - ocamlgraph - bisect_ppx - decompress - fileutils - ppx_deriving - ppx_deriving_yojson - ppx_yojson_conv - ppx_expect - ppx_import - terminal_size - ocaml-recovery-parser - yojson - getopt - core - core_unix - pprint - linenoise - crunch - semver - lambda-term - tar-unix - parse-argv - hacl-star - prometheus - lwt_ppx - msgpck - # lsp - linol - linol-lwt - ocaml-lsp - # Test helpers deps - qcheck - qcheck-alcotest - alcotest-lwt - # vendored tezos' deps - aches - aches-lwt - ctypes - ctypes_stubs_js - class_group_vdf - dune-configurator - hacl-star - hacl-star-raw - lwt-canceler - ipaddr - bls12-381 - bls12-381-signature - ptime - mtime - lwt_log - secp256k1-internal - resto - resto-directory - resto-cohttp-self-serving-client - irmin-pack - ezjsonm - data-encoding - pure-splitmix - zarith_stubs_js - simple-diff - seqes - stdint - tezt - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + with ocamlPackages; + [ + coq + menhir + menhirLib + qcheck + ocamlgraph + bisect_ppx + decompress + fileutils + ppx_deriving + ppx_deriving_yojson + ppx_yojson_conv + ppx_expect + ppx_import + terminal_size + ocaml-recovery-parser + yojson + getopt + core + core_unix + pprint + linenoise + crunch + semver + lambda-term + tar-unix + parse-argv + hacl-star + prometheus + lwt_ppx + msgpck + # lsp + linol + linol-lwt + ocaml-lsp + # Test helpers deps + qcheck + qcheck-alcotest + alcotest-lwt + # vendored tezos' deps + aches + aches-lwt + ctypes + ctypes_stubs_js + class_group_vdf + dune-configurator + hacl-star + hacl-star-raw + lwt-canceler + ipaddr + bls12-381 + bls12-381-signature + ptime + mtime + lwt_log + secp256k1-internal + resto + resto-directory + resto-cohttp-self-serving-client + irmin-pack + ezjsonm + data-encoding + pure-splitmix + zarith_stubs_js + simple-diff + seqes + stdint + tezt + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; nativeCheckInputs = [ cacert diff --git a/pkgs/development/compilers/llvm/common/lldb-plugins/llef.nix b/pkgs/development/compilers/llvm/common/lldb-plugins/llef.nix index 97b80ade42e1a2..83c1366c344c0a 100644 --- a/pkgs/development/compilers/llvm/common/lldb-plugins/llef.nix +++ b/pkgs/development/compilers/llvm/common/lldb-plugins/llef.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, lldb +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + lldb, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/compilers/llvm/multi.nix b/pkgs/development/compilers/llvm/multi.nix index 136e13ba21f5e6..448ee461ad699a 100644 --- a/pkgs/development/compilers/llvm/multi.nix +++ b/pkgs/development/compilers/llvm/multi.nix @@ -1,42 +1,48 @@ -{ runCommand, -clang, -gcc64, -gcc32, -glibc_multi +{ + runCommand, + clang, + gcc64, + gcc32, + glibc_multi, }: let - combine = basegcc: runCommand "combine-gcc-libc" {} '' - mkdir -p $out - cp -r ${basegcc.cc}/lib $out/lib - - chmod u+rw -R $out/lib - cp -r ${basegcc.libc}/lib/* $(ls -d $out/lib/gcc/*/*) - ''; - gcc_multi_sysroot = runCommand "gcc-multi-sysroot" { - passthru = { - inherit (gcc64) version; - lib = gcc_multi_sysroot; - }; - } '' - mkdir -p $out/lib{,64}/gcc + combine = + basegcc: + runCommand "combine-gcc-libc" { } '' + mkdir -p $out + cp -r ${basegcc.cc}/lib $out/lib + + chmod u+rw -R $out/lib + cp -r ${basegcc.libc}/lib/* $(ls -d $out/lib/gcc/*/*) + ''; + gcc_multi_sysroot = + runCommand "gcc-multi-sysroot" + { + passthru = { + inherit (gcc64) version; + lib = gcc_multi_sysroot; + }; + } + '' + mkdir -p $out/lib{,64}/gcc - ln -s ${combine gcc64}/lib/gcc/* $out/lib64/gcc/ - ln -s ${combine gcc32}/lib/gcc/* $out/lib/gcc/ - # XXX: This shouldn't be needed, clang just doesn't look for "i686-unknown" - ln -s $out/lib/gcc/i686-unknown-linux-gnu $out/lib/gcc/i686-pc-linux-gnu + ln -s ${combine gcc64}/lib/gcc/* $out/lib64/gcc/ + ln -s ${combine gcc32}/lib/gcc/* $out/lib/gcc/ + # XXX: This shouldn't be needed, clang just doesn't look for "i686-unknown" + ln -s $out/lib/gcc/i686-unknown-linux-gnu $out/lib/gcc/i686-pc-linux-gnu - # includes - mkdir -p $out/include - ln -s ${glibc_multi.dev}/include/* $out/include - ln -s ${gcc64.cc}/include/c++ $out/include/c++ + # includes + mkdir -p $out/include + ln -s ${glibc_multi.dev}/include/* $out/include + ln -s ${gcc64.cc}/include/c++ $out/include/c++ - # dynamic linkers - mkdir -p $out/lib/32 - ln -s ${glibc_multi.out}/lib/ld-linux* $out/lib - ln -s ${glibc_multi.out}/lib/32/ld-linux* $out/lib/32/ - ''; + # dynamic linkers + mkdir -p $out/lib/32 + ln -s ${glibc_multi.out}/lib/ld-linux* $out/lib + ln -s ${glibc_multi.out}/lib/32/ld-linux* $out/lib/32/ + ''; clangMulti = clang.override { # Only used for providing expected structure re:dynamic linkers, AFAIK Most @@ -51,10 +57,12 @@ let gccForLibs = gcc_multi_sysroot // { inherit (glibc_multi) libgcc; langCC = - assert (gcc64.cc.langCC != gcc32.cc.langCC) - -> throw "(gcc64.cc.langCC=${gcc64.cc.langCC}) != (gcc32.cc.langCC=${gcc32.cc.langCC})"; + assert + (gcc64.cc.langCC != gcc32.cc.langCC) + -> throw "(gcc64.cc.langCC=${gcc64.cc.langCC}) != (gcc32.cc.langCC=${gcc32.cc.langCC})"; gcc64.cc.langCC; }; }; -in clangMulti +in +clangMulti diff --git a/pkgs/development/compilers/lobster/default.nix b/pkgs/development/compilers/lobster/default.nix index 2ebe573cf513c2..e54c71ebab64da 100644 --- a/pkgs/development/compilers/lobster/default.nix +++ b/pkgs/development/compilers/lobster/default.nix @@ -1,19 +1,21 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, callPackage +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + callPackage, -# Linux deps -, libGL -, xorg + # Linux deps + libGL, + xorg, -# Darwin deps -, CoreFoundation -, Cocoa -, AudioToolbox -, OpenGL -, Foundation -, ForceFeedback + # Darwin deps + CoreFoundation, + Cocoa, + AudioToolbox, + OpenGL, + Foundation, + ForceFeedback, }: stdenv.mkDerivation (finalAttrs: { @@ -28,26 +30,28 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ cmake ]; - buildInputs = if stdenv.hostPlatform.isDarwin - then [ - CoreFoundation - Cocoa - AudioToolbox - OpenGL - Foundation - ForceFeedback - ] - else [ - libGL - xorg.libX11 - xorg.libXext - ]; + buildInputs = + if stdenv.hostPlatform.isDarwin then + [ + CoreFoundation + Cocoa + AudioToolbox + OpenGL + Foundation + ForceFeedback + ] + else + [ + libGL + xorg.libX11 + xorg.libXext + ]; preConfigure = '' cd dev ''; - passthru.tests.can-run-hello-world = callPackage ./test-can-run-hello-world.nix {}; + passthru.tests.can-run-hello-world = callPackage ./test-can-run-hello-world.nix { }; meta = with lib; { broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/development/compilers/lobster/test-can-run-hello-world.nix b/pkgs/development/compilers/lobster/test-can-run-hello-world.nix index ceb0536b582cca..7971c9fd433984 100644 --- a/pkgs/development/compilers/lobster/test-can-run-hello-world.nix +++ b/pkgs/development/compilers/lobster/test-can-run-hello-world.nix @@ -10,4 +10,3 @@ stdenv.mkDerivation { touch $out ''; } - diff --git a/pkgs/development/compilers/matter-compiler/default.nix b/pkgs/development/compilers/matter-compiler/default.nix index 89daf7b27ebaaa..b00c26c0ba5f4b 100644 --- a/pkgs/development/compilers/matter-compiler/default.nix +++ b/pkgs/development/compilers/matter-compiler/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "matter_compiler"; @@ -12,9 +16,13 @@ bundlerApp { Matter Compiler is a API Blueprint AST Media Types to API Blueprint conversion tool. It composes an API blueprint from its serialzed AST media-type. ''; - homepage = "https://github.com/apiaryio/matter_compiler/"; - license = licenses.mit; - maintainers = with maintainers; [ rvlander manveru nicknovitski ]; - platforms = platforms.unix; + homepage = "https://github.com/apiaryio/matter_compiler/"; + license = licenses.mit; + maintainers = with maintainers; [ + rvlander + manveru + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/development/compilers/matter-compiler/gemset.nix b/pkgs/development/compilers/matter-compiler/gemset.nix index 2ef9e911b82438..739f664a7dc62f 100644 --- a/pkgs/development/compilers/matter-compiler/gemset.nix +++ b/pkgs/development/compilers/matter-compiler/gemset.nix @@ -1,9 +1,9 @@ { matter_compiler = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16501zdiqxk34v2d0nlbwrcrjm6g57hrsmsw0crwssn29v5zbykf"; type = "gem"; }; diff --git a/pkgs/development/compilers/mercury/default.nix b/pkgs/development/compilers/mercury/default.nix index f26745abda34eb..9e8cd70bc0752d 100644 --- a/pkgs/development/compilers/mercury/default.nix +++ b/pkgs/development/compilers/mercury/default.nix @@ -1,17 +1,36 @@ -{ lib, stdenv, fetchurl, gcc, flex, bison, texinfo, jdk_headless, erlang, makeWrapper -, readline }: +{ + lib, + stdenv, + fetchurl, + gcc, + flex, + bison, + texinfo, + jdk_headless, + erlang, + makeWrapper, + readline, +}: stdenv.mkDerivation rec { pname = "mercury"; version = "22.01.8"; src = fetchurl { - url = "https://dl.mercurylang.org/release/mercury-srcdist-${version}.tar.gz"; + url = "https://dl.mercurylang.org/release/mercury-srcdist-${version}.tar.gz"; sha256 = "sha256-oJfozI7KAVLtlSfByvc+XJyD9q2h0xOiW4D+eQcvutg="; }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ gcc flex bison texinfo jdk_headless erlang readline ]; + buildInputs = [ + gcc + flex + bison + texinfo + jdk_headless + erlang + readline + ]; patchPhase = '' # Fix calls to programs in /bin @@ -54,10 +73,10 @@ stdenv.mkDerivation rec { allowing modularity, separate compilation, and numerous optimization/time trade-offs. ''; - homepage = "https://mercurylang.org/"; - changelog = "https://dl.mercurylang.org/release/release-notes-${version}.html"; - license = lib.licenses.gpl2Only; - platforms = lib.platforms.all; + homepage = "https://mercurylang.org/"; + changelog = "https://dl.mercurylang.org/release/release-notes-${version}.html"; + license = lib.licenses.gpl2Only; + platforms = lib.platforms.all; maintainers = with lib.maintainers; [ vieta ]; }; } diff --git a/pkgs/development/compilers/mezzo/default.nix b/pkgs/development/compilers/mezzo/default.nix index a47228b1d0b127..51df8e7062d474 100644 --- a/pkgs/development/compilers/mezzo/default.nix +++ b/pkgs/development/compilers/mezzo/default.nix @@ -1,57 +1,83 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, findlib, ocamlbuild, camlp4, menhir -, menhirLib, yojson, ulex, pprint, fix, functory +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, + ocamlbuild, + camlp4, + menhir, + menhirLib, + yojson, + ulex, + pprint, + fix, + functory, }: -if lib.versionAtLeast ocaml.version "4.06" -then throw "mezzo is not available for OCaml ${ocaml.version}" +if lib.versionAtLeast ocaml.version "4.06" then + throw "mezzo is not available for OCaml ${ocaml.version}" else -let - check-ocaml-version = lib.versionAtLeast (lib.getVersion ocaml); -in + let + check-ocaml-version = lib.versionAtLeast (lib.getVersion ocaml); + in -assert check-ocaml-version "4"; + assert check-ocaml-version "4"; -stdenv.mkDerivation { + stdenv.mkDerivation { - pname = "mezzo"; - version = "0.0.m8"; + pname = "mezzo"; + version = "0.0.m8"; - src = fetchFromGitHub { - owner = "protz"; - repo = "mezzo"; - rev = "m8"; - sha256 = "0yck5r6di0935s3iy2mm9538jkf77ssr789qb06ms7sivd7g3ip6"; - }; + src = fetchFromGitHub { + owner = "protz"; + repo = "mezzo"; + rev = "m8"; + sha256 = "0yck5r6di0935s3iy2mm9538jkf77ssr789qb06ms7sivd7g3ip6"; + }; - strictDeps = true; + strictDeps = true; - nativeBuildInputs = [ ocaml findlib ocamlbuild camlp4 menhir ]; - buildInputs = [ yojson menhirLib ulex pprint fix functory ocamlbuild ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + camlp4 + menhir + ]; + buildInputs = [ + yojson + menhirLib + ulex + pprint + fix + functory + ocamlbuild + ]; - # Sets warning 3 as non-fatal - prePatch = lib.optionalString (check-ocaml-version "4.02") '' - substituteInPlace myocamlbuild.pre.ml \ - --replace '@1..3' '@1..2+3' - '' - # Compatibility with PPrint ≥ 20220103 - + '' - substituteInPlace typing/Fact.ml --replace PPrintOCaml PPrint.OCaml - ''; + # Sets warning 3 as non-fatal + prePatch = + lib.optionalString (check-ocaml-version "4.02") '' + substituteInPlace myocamlbuild.pre.ml \ + --replace '@1..3' '@1..2+3' + '' + # Compatibility with PPrint ≥ 20220103 + + '' + substituteInPlace typing/Fact.ml --replace PPrintOCaml PPrint.OCaml + ''; - createFindlibDestdir = true; - - postInstall = '' - mkdir $out/bin - cp mezzo $out/bin/ - ''; - - meta = with lib; { - homepage = "http://protz.github.io/mezzo/"; - description = "Programming language in the ML tradition, which places strong emphasis on the control of aliasing and access to mutable memory"; - license = licenses.gpl2; - platforms = ocaml.meta.platforms or []; - }; -} + createFindlibDestdir = true; + postInstall = '' + mkdir $out/bin + cp mezzo $out/bin/ + ''; + meta = with lib; { + homepage = "http://protz.github.io/mezzo/"; + description = "Programming language in the ML tradition, which places strong emphasis on the control of aliasing and access to mutable memory"; + license = licenses.gpl2; + platforms = ocaml.meta.platforms or [ ]; + }; + } diff --git a/pkgs/development/compilers/mint/default.nix b/pkgs/development/compilers/mint/default.nix index 5a94d35c051f6b..62e19008d46800 100644 --- a/pkgs/development/compilers/mint/default.nix +++ b/pkgs/development/compilers/mint/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, crystal, openssl }: +{ + lib, + fetchFromGitHub, + crystal, + openssl, +}: crystal.buildCrystalPackage rec { version = "0.19.0"; diff --git a/pkgs/development/compilers/mit-scheme/default.nix b/pkgs/development/compilers/mit-scheme/default.nix index 9b110b0a8b0458..505c3fb0552586 100644 --- a/pkgs/development/compilers/mit-scheme/default.nix +++ b/pkgs/development/compilers/mit-scheme/default.nix @@ -1,26 +1,27 @@ -{ fetchurl -, lib -, stdenv -, makeWrapper -, gnum4 -, texinfo -, texliveSmall -, automake -, autoconf -, libtool -, ghostscript -, ncurses -, enableX11 ? false, libX11 +{ + fetchurl, + lib, + stdenv, + makeWrapper, + gnum4, + texinfo, + texliveSmall, + automake, + autoconf, + libtool, + ghostscript, + ncurses, + enableX11 ? false, + libX11, }: let version = "12.1"; - bootstrapFromC = ! ((stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) || stdenv.hostPlatform.isx86_64); + bootstrapFromC = + !((stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) || stdenv.hostPlatform.isx86_64); - arch = if stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64 then - "-aarch64le" - else - "-x86-64"; + arch = + if stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64 then "-aarch64le" else "-x86-64"; in stdenv.mkDerivation { pname = "mit-scheme" + lib.optionalString enableX11 "-x11"; @@ -31,14 +32,16 @@ stdenv.mkDerivation { # leads to more efficient code than when building the tarball that contains # generated C code instead of those binaries. src = - if stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64 - then fetchurl { - url = "mirror://gnu/mit-scheme/stable.pkg/${version}/mit-scheme-${version}-aarch64le.tar.gz"; - sha256 = "12ra9bc93x8g07impbd8jr6djjzwpb9qvh9zhxvvrba3332zx3vh"; - } else fetchurl { - url = "mirror://gnu/mit-scheme/stable.pkg/${version}/mit-scheme-${version}-x86-64.tar.gz"; - sha256 = "035f92vni0vqmgj9hq2i7vwasz7crx52wll4823vhfkm1qdv5ywc"; - }; + if stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64 then + fetchurl { + url = "mirror://gnu/mit-scheme/stable.pkg/${version}/mit-scheme-${version}-aarch64le.tar.gz"; + sha256 = "12ra9bc93x8g07impbd8jr6djjzwpb9qvh9zhxvvrba3332zx3vh"; + } + else + fetchurl { + url = "mirror://gnu/mit-scheme/stable.pkg/${version}/mit-scheme-${version}-x86-64.tar.gz"; + sha256 = "035f92vni0vqmgj9hq2i7vwasz7crx52wll4823vhfkm1qdv5ywc"; + }; buildInputs = [ ncurses ] ++ lib.optionals enableX11 [ libX11 ]; @@ -56,23 +59,20 @@ stdenv.mkDerivation { ]; buildPhase = '' - runHook preBuild - cd src + runHook preBuild + cd src - ${if bootstrapFromC - then "./etc/make-liarc.sh --prefix=$out" - else "make compile-microcode"} + ${if bootstrapFromC then "./etc/make-liarc.sh --prefix=$out" else "make compile-microcode"} - cd ../doc + cd ../doc - make + make - cd .. + cd .. - runHook postBuild + runHook postBuild ''; - installPhase = '' runHook preInstall make prefix=$out install -C src @@ -85,7 +85,21 @@ stdenv.mkDerivation { $out/lib/mit-scheme${arch}-${version} ''; - nativeBuildInputs = [ makeWrapper gnum4 texinfo (texliveSmall.withPackages (ps: with ps; [ epsf ps.texinfo ])) automake ghostscript autoconf libtool ]; + nativeBuildInputs = [ + makeWrapper + gnum4 + texinfo + (texliveSmall.withPackages ( + ps: with ps; [ + epsf + ps.texinfo + ] + )) + automake + ghostscript + autoconf + libtool + ]; # XXX: The `check' target doesn't exist. doCheck = false; diff --git a/pkgs/development/compilers/mkcl/default.nix b/pkgs/development/compilers/mkcl/default.nix index 1483bd4a159734..620e4716dd5be0 100644 --- a/pkgs/development/compilers/mkcl/default.nix +++ b/pkgs/development/compilers/mkcl/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, makeWrapper, gmp, gcc }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + makeWrapper, + gmp, + gcc, +}: stdenv.mkDerivation rec { pname = "mkcl"; diff --git a/pkgs/development/compilers/mlton/20130715.nix b/pkgs/development/compilers/mlton/20130715.nix index 90285bf0898201..6cf88e34b57d96 100644 --- a/pkgs/development/compilers/mlton/20130715.nix +++ b/pkgs/development/compilers/mlton/20130715.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, patchelf, gmp }: +{ + lib, + stdenv, + fetchurl, + patchelf, + gmp, +}: let version = "20130715"; @@ -13,27 +19,33 @@ stdenv.mkDerivation rec { inherit version; binSrc = - if stdenv.hostPlatform.system == "i686-linux" then (fetchurl { - url = "mirror://sourceforge/project/mlton/mlton/${version}/${pname}-${version}-1.x86-linux.tgz"; - sha256 = "1kxjjmnw4xk2d9hpvz43w9dvyhb3025k4zvjx785c33nrwkrdn4j"; - }) - else if stdenv.hostPlatform.system == "x86_64-linux" then (fetchurl { + if stdenv.hostPlatform.system == "i686-linux" then + (fetchurl { + url = "mirror://sourceforge/project/mlton/mlton/${version}/${pname}-${version}-1.x86-linux.tgz"; + sha256 = "1kxjjmnw4xk2d9hpvz43w9dvyhb3025k4zvjx785c33nrwkrdn4j"; + }) + else if stdenv.hostPlatform.system == "x86_64-linux" then + (fetchurl { url = "mirror://sourceforge/project/mlton/mlton/${version}/${pname}-${version}-1.amd64-linux.tgz"; sha256 = "0fyhwxb4nmpirjbjcvk9f6w67gmn2gkz7xcgz0xbfih9kc015ygn"; - }) - else if stdenv.hostPlatform.system == "x86_64-darwin" then (fetchurl { + }) + else if stdenv.hostPlatform.system == "x86_64-darwin" then + (fetchurl { url = "mirror://sourceforge/project/mlton/mlton/${version}/${pname}-${version}-1.amd64-darwin.gmp-macports.tgz"; sha256 = "044wnh9hhg6if886xy805683k0as347xd37r0r1yi4x7qlxzzgx9"; - }) - else throw "Architecture not supported"; + }) + else + throw "Architecture not supported"; - codeSrc = - fetchurl { - url = "mirror://sourceforge/project/mlton/mlton/${version}/${pname}-${version}.src.tgz"; - sha256 = "0v1x2hrh9hiqkvnbq11kf34v4i5a2x0ffxbzqaa8skyl26nmfn11"; - }; + codeSrc = fetchurl { + url = "mirror://sourceforge/project/mlton/mlton/${version}/${pname}-${version}.src.tgz"; + sha256 = "0v1x2hrh9hiqkvnbq11kf34v4i5a2x0ffxbzqaa8skyl26nmfn11"; + }; - srcs = [ binSrc codeSrc ]; + srcs = [ + binSrc + codeSrc + ]; sourceRoot = "${pname}-${version}"; @@ -42,55 +54,61 @@ stdenv.mkDerivation rec { makeFlags = [ "all-no-docs" ]; - configurePhase = '' - # Fix paths in the source. - find . -type f | grep -v -e '\.tgz''$' | xargs sed -i "s@/usr/bin/env bash@$(type -p bash)@" - - substituteInPlace $(pwd)/Makefile --replace '/bin/cp' $(type -p cp) - substituteInPlace bin/mlton-script --replace gcc cc - substituteInPlace bin/regression --replace gcc cc - substituteInPlace lib/mlnlffi-lib/Makefile --replace gcc cc - substituteInPlace mlnlffigen/gen-cppcmd --replace gcc cc - substituteInPlace runtime/Makefile --replace gcc cc - substituteInPlace ../${usr_prefix}/bin/mlton --replace gcc cc - - # Fix paths in the binary distribution. - BIN_DIST_DIR="$(pwd)/../${usr_prefix}" - for f in "bin/mlton" "lib/mlton/platform" "lib/mlton/static-library" ; do - substituteInPlace "$BIN_DIST_DIR/$f" --replace '/${usr_prefix}/bin/env bash' $(type -p bash) - done - - substituteInPlace $(pwd)/../${usr_prefix}/bin/mlton --replace '/${usr_prefix}/lib/mlton' $(pwd)/../${usr_prefix}/lib/mlton - '' + lib.optionalString stdenv.cc.isClang '' - sed -i "s_ patch -s -p0 safeX11 stdenv; @@ -23,16 +40,25 @@ assert unsafeStringSupport -> lib.versionAtLeast version "4.06" && lib.versionOl assert framePointerSupport -> lib.versionAtLeast version "4.01"; let - src = args.src or (fetchurl { - url = args.url or "http://caml.inria.fr/pub/distrib/ocaml-${versionNoPatch}/ocaml-${version}.tar.xz"; - inherit (args) sha256; - }); + src = + args.src or (fetchurl { + url = + args.url or "http://caml.inria.fr/pub/distrib/ocaml-${versionNoPatch}/ocaml-${version}.tar.xz"; + inherit (args) sha256; + }); in let useNativeCompilers = !stdenv.hostPlatform.isMips; - inherit (lib) optional optionals optionalString strings concatStrings; - pname = concatStrings [ "ocaml" + inherit (lib) + optional + optionals + optionalString + strings + concatStrings + ; + pname = concatStrings [ + "ocaml" (optionalString aflSupport "+afl") (optionalString spaceTimeSupport "+spacetime") (optionalString flambdaSupport "+flambda") @@ -41,126 +67,157 @@ let in let - x11env = buildEnv { name = "x11env"; paths = [libX11 xorgproto]; }; + x11env = buildEnv { + name = "x11env"; + paths = [ + libX11 + xorgproto + ]; + }; x11lib = x11env + "/lib"; x11inc = x11env + "/include"; fetchpatch' = x: if builtins.isAttrs x then fetchpatch x else x; in -stdenv.mkDerivation (args // { - - inherit pname version src; - - patches = map fetchpatch' patches; - - strictDeps = true; - - prefixKey = "-prefix "; - configureFlags = - let flags = new: old: - if lib.versionAtLeast version "4.08" - then new else old - ; in - optionals useX11 (flags - [ "--x-libraries=${x11lib}" "--x-includes=${x11inc}"] - [ "-x11lib" x11lib "-x11include" x11inc ]) - ++ optional aflSupport (flags "--with-afl" "-afl-instrument") - ++ optional flambdaSupport (flags "--enable-flambda" "-flambda") - ++ optional spaceTimeSupport (flags "--enable-spacetime" "-spacetime") - ++ optional framePointerSupport (flags "--enable-frame-pointers" "-with-frame-pointers") - ++ optionals unsafeStringSupport [ - "--disable-force-safe-string" - "DEFAULT_STRING=unsafe" - ] - ++ optional (stdenv.hostPlatform.isStatic && (lib.versionOlder version "4.08")) "-no-shared-libs" - ++ optionals (stdenv.hostPlatform != stdenv.buildPlatform && lib.versionOlder version "4.08") [ - "-host ${stdenv.hostPlatform.config}" - "-target ${stdenv.targetPlatform.config}" - ]; - dontAddStaticConfigureFlags = lib.versionOlder version "4.08"; - - # on aarch64-darwin using --host and --target causes the build to invoke - # `aarch64-apple-darwin-clang` while using assembler. However, such binary - # does not exist. So, disable these configure flags on `aarch64-darwin`. - # See #144785 for details. - configurePlatforms = lib.optionals (lib.versionAtLeast version "4.08" && !(stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64)) [ "host" "target" ]; - # x86_64-unknown-linux-musl-ld: -r and -pie may not be used together - hardeningDisable = lib.optional (lib.versionAtLeast version "4.09" && stdenv.hostPlatform.isMusl) "pie" - ++ lib.optional (lib.versionAtLeast version "5.0" && stdenv.cc.isClang) "strictoverflow" - ++ lib.optionals (args ? hardeningDisable) args.hardeningDisable; - - # Older versions have some race: - # cp: cannot stat 'boot/ocamlrun': No such file or directory - # make[2]: *** [Makefile:199: backup] Error 1 - enableParallelBuilding = lib.versionAtLeast version "4.08"; - - # Workaround missing dependencies for install parallelism: - # install: target '...-ocaml-4.14.0/lib/ocaml/threads': No such file or directory - # make[1]: *** [Makefile:140: installopt] Error 1 - enableParallelInstalling = false; - - # Workaround lack of parallelism support among top-level targets: - # we place nixpkgs-specific targets to a separate file and set - # sequential order among them as a single rule. - makefile = ./Makefile.nixpkgs; - buildFlags = if useNativeCompilers - then [(if lib.versionOlder version "5.2" - then "nixpkgs_world_bootstrap_world_opt" - else "defaultentry")] - else ["nixpkgs_world"]; - buildInputs = optional (lib.versionOlder version "4.07") ncurses - ++ optionals useX11 [ libX11 xorgproto ]; - depsBuildBuild = lib.optionals (!stdenv.hostPlatform.isDarwin) [ binutils ]; - propagatedBuildInputs = optional spaceTimeSupport libunwind; - installTargets = [ "install" ] ++ optional useNativeCompilers "installopt"; - preConfigure = optionalString (lib.versionOlder version "4.04") '' - CAT=$(type -tp cat) - sed -e "s@/bin/cat@$CAT@" -i config/auto-aux/sharpbang - '' + optionalString (stdenv.hostPlatform.isDarwin) '' - # Do what upstream does by default now: https://github.com/ocaml/ocaml/pull/10176 - # This is required for aarch64-darwin, everything else works as is. - AS="${stdenv.cc}/bin/cc -c" ASPP="${stdenv.cc}/bin/cc -c" - '' + optionalString (lib.versionOlder version "4.08" && stdenv.hostPlatform.isStatic) '' - configureFlagsArray+=("-cc" "$CC" "-as" "$AS" "-partialld" "$LD -r") - ''; - postBuild = '' - mkdir -p $out/include - ln -sv $out/lib/ocaml/caml $out/include/caml - ''; - - passthru = { - nativeCompilers = useNativeCompilers; - }; - - meta = with lib; { - homepage = "https://ocaml.org/"; - branch = versionNoPatch; - license = with licenses; [ - qpl /* compiler */ - lgpl2 /* library */ - ]; - description = "OCaml is an industrial-strength programming language supporting functional, imperative and object-oriented styles"; - - longDescription = '' - OCaml is a general purpose programming language with an emphasis on expressiveness and safety. Developed for more than 20 years at Inria by a group of leading researchers, it has an advanced type system that helps catch your mistakes without getting in your way. It's used in environments where a single mistake can cost millions and speed matters, is supported by an active community, and has a rich set of libraries and development tools. It's widely used in teaching for its power and simplicity. - - Strengths: - * A powerful type system, equipped with parametric polymorphism and type inference. For instance, the type of a collection can be parameterized by the type of its elements. This allows defining some operations over a collection independently of the type of its elements: sorting an array is one example. Furthermore, type inference allows defining such operations without having to explicitly provide the type of their parameters and result. - * User-definable algebraic data types and pattern-matching. New algebraic data types can be defined as combinations of records and sums. Functions that operate over such data structures can then be defined by pattern matching, a generalized form of the well-known switch statement, which offers a clean and elegant way of simultaneously examining and naming data. - * Automatic memory management, thanks to a fast, unobtrusive, incremental garbage collector. - * Separate compilation of standalone applications. Portable bytecode compilers allow creating stand-alone applications out of Caml Light or OCaml programs. A foreign function interface allows OCaml code to interoperate with C code when necessary. Interactive use of OCaml is also supported via a “read-evaluate-print” loop. - - In addition, OCaml features: - * A sophisticated module system, which allows organizing modules hierarchically and parameterizing a module over a number of other modules. - * An expressive object-oriented layer, featuring multiple inheritance, parametric and virtual classes. - * Efficient native code compilers. In addition to its bytecode compiler, OCaml offers a compiler that produces efficient machine code for many architectures. - - Learn more at: https://ocaml.org/learn/description.html +stdenv.mkDerivation ( + args + // { + + inherit pname version src; + + patches = map fetchpatch' patches; + + strictDeps = true; + + prefixKey = "-prefix "; + configureFlags = + let + flags = new: old: if lib.versionAtLeast version "4.08" then new else old; + in + optionals useX11 ( + flags + [ "--x-libraries=${x11lib}" "--x-includes=${x11inc}" ] + [ "-x11lib" x11lib "-x11include" x11inc ] + ) + ++ optional aflSupport (flags "--with-afl" "-afl-instrument") + ++ optional flambdaSupport (flags "--enable-flambda" "-flambda") + ++ optional spaceTimeSupport (flags "--enable-spacetime" "-spacetime") + ++ optional framePointerSupport (flags "--enable-frame-pointers" "-with-frame-pointers") + ++ optionals unsafeStringSupport [ + "--disable-force-safe-string" + "DEFAULT_STRING=unsafe" + ] + ++ optional (stdenv.hostPlatform.isStatic && (lib.versionOlder version "4.08")) "-no-shared-libs" + ++ optionals (stdenv.hostPlatform != stdenv.buildPlatform && lib.versionOlder version "4.08") [ + "-host ${stdenv.hostPlatform.config}" + "-target ${stdenv.targetPlatform.config}" + ]; + dontAddStaticConfigureFlags = lib.versionOlder version "4.08"; + + # on aarch64-darwin using --host and --target causes the build to invoke + # `aarch64-apple-darwin-clang` while using assembler. However, such binary + # does not exist. So, disable these configure flags on `aarch64-darwin`. + # See #144785 for details. + configurePlatforms = + lib.optionals + ( + lib.versionAtLeast version "4.08" + && !(stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) + ) + [ + "host" + "target" + ]; + # x86_64-unknown-linux-musl-ld: -r and -pie may not be used together + hardeningDisable = + lib.optional (lib.versionAtLeast version "4.09" && stdenv.hostPlatform.isMusl) "pie" + ++ lib.optional (lib.versionAtLeast version "5.0" && stdenv.cc.isClang) "strictoverflow" + ++ lib.optionals (args ? hardeningDisable) args.hardeningDisable; + + # Older versions have some race: + # cp: cannot stat 'boot/ocamlrun': No such file or directory + # make[2]: *** [Makefile:199: backup] Error 1 + enableParallelBuilding = lib.versionAtLeast version "4.08"; + + # Workaround missing dependencies for install parallelism: + # install: target '...-ocaml-4.14.0/lib/ocaml/threads': No such file or directory + # make[1]: *** [Makefile:140: installopt] Error 1 + enableParallelInstalling = false; + + # Workaround lack of parallelism support among top-level targets: + # we place nixpkgs-specific targets to a separate file and set + # sequential order among them as a single rule. + makefile = ./Makefile.nixpkgs; + buildFlags = + if useNativeCompilers then + [ + (if lib.versionOlder version "5.2" then "nixpkgs_world_bootstrap_world_opt" else "defaultentry") + ] + else + [ "nixpkgs_world" ]; + buildInputs = + optional (lib.versionOlder version "4.07") ncurses + ++ optionals useX11 [ + libX11 + xorgproto + ]; + depsBuildBuild = lib.optionals (!stdenv.hostPlatform.isDarwin) [ binutils ]; + propagatedBuildInputs = optional spaceTimeSupport libunwind; + installTargets = [ "install" ] ++ optional useNativeCompilers "installopt"; + preConfigure = + optionalString (lib.versionOlder version "4.04") '' + CAT=$(type -tp cat) + sed -e "s@/bin/cat@$CAT@" -i config/auto-aux/sharpbang + '' + + optionalString (stdenv.hostPlatform.isDarwin) '' + # Do what upstream does by default now: https://github.com/ocaml/ocaml/pull/10176 + # This is required for aarch64-darwin, everything else works as is. + AS="${stdenv.cc}/bin/cc -c" ASPP="${stdenv.cc}/bin/cc -c" + '' + + optionalString (lib.versionOlder version "4.08" && stdenv.hostPlatform.isStatic) '' + configureFlagsArray+=("-cc" "$CC" "-as" "$AS" "-partialld" "$LD -r") + ''; + postBuild = '' + mkdir -p $out/include + ln -sv $out/lib/ocaml/caml $out/include/caml ''; - platforms = with platforms; linux ++ darwin; - broken = stdenv.hostPlatform.isAarch64 && lib.versionOlder version (if stdenv.hostPlatform.isDarwin then "4.10" else "4.02"); - }; - -}) + passthru = { + nativeCompilers = useNativeCompilers; + }; + + meta = with lib; { + homepage = "https://ocaml.org/"; + branch = versionNoPatch; + license = with licenses; [ + qpl # compiler + lgpl2 # library + ]; + description = "OCaml is an industrial-strength programming language supporting functional, imperative and object-oriented styles"; + + longDescription = '' + OCaml is a general purpose programming language with an emphasis on expressiveness and safety. Developed for more than 20 years at Inria by a group of leading researchers, it has an advanced type system that helps catch your mistakes without getting in your way. It's used in environments where a single mistake can cost millions and speed matters, is supported by an active community, and has a rich set of libraries and development tools. It's widely used in teaching for its power and simplicity. + + Strengths: + * A powerful type system, equipped with parametric polymorphism and type inference. For instance, the type of a collection can be parameterized by the type of its elements. This allows defining some operations over a collection independently of the type of its elements: sorting an array is one example. Furthermore, type inference allows defining such operations without having to explicitly provide the type of their parameters and result. + * User-definable algebraic data types and pattern-matching. New algebraic data types can be defined as combinations of records and sums. Functions that operate over such data structures can then be defined by pattern matching, a generalized form of the well-known switch statement, which offers a clean and elegant way of simultaneously examining and naming data. + * Automatic memory management, thanks to a fast, unobtrusive, incremental garbage collector. + * Separate compilation of standalone applications. Portable bytecode compilers allow creating stand-alone applications out of Caml Light or OCaml programs. A foreign function interface allows OCaml code to interoperate with C code when necessary. Interactive use of OCaml is also supported via a “read-evaluate-print” loop. + + In addition, OCaml features: + * A sophisticated module system, which allows organizing modules hierarchically and parameterizing a module over a number of other modules. + * An expressive object-oriented layer, featuring multiple inheritance, parametric and virtual classes. + * Efficient native code compilers. In addition to its bytecode compiler, OCaml offers a compiler that produces efficient machine code for many architectures. + + Learn more at: https://ocaml.org/learn/description.html + ''; + + platforms = with platforms; linux ++ darwin; + broken = + stdenv.hostPlatform.isAarch64 + && lib.versionOlder version (if stdenv.hostPlatform.isDarwin then "4.10" else "4.02"); + }; + + } +) diff --git a/pkgs/development/compilers/open-watcom/bin.nix b/pkgs/development/compilers/open-watcom/bin.nix index 5e7805a31b304e..b967b2752cbc35 100644 --- a/pkgs/development/compilers/open-watcom/bin.nix +++ b/pkgs/development/compilers/open-watcom/bin.nix @@ -1,4 +1,15 @@ -{ lib, stdenvNoCC, fetchurl, qemu, writeScript, writeScriptBin, ncurses, bash, coreutils, unixtools }: +{ + lib, + stdenvNoCC, + fetchurl, + qemu, + writeScript, + writeScriptBin, + ncurses, + bash, + coreutils, + unixtools, +}: let @@ -58,7 +69,10 @@ stdenvNoCC.mkDerivation rec { sha256 = "1wzkvc6ija0cjj5mcyjng5b7hnnc5axidz030c0jh05pgvi4nj7p"; }; - nativeBuildInputs = [ wrapInPlace unixtools.script ]; + nativeBuildInputs = [ + wrapInPlace + unixtools.script + ]; dontUnpack = true; dontConfigure = true; @@ -86,7 +100,10 @@ stdenvNoCC.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; homepage = "http://www.openwatcom.org/"; license = licenses.watcom; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ maintainers.blitz ]; }; } diff --git a/pkgs/development/compilers/open-watcom/v2.nix b/pkgs/development/compilers/open-watcom/v2.nix index 8ad74c00ec8701..f518605539f0bc 100644 --- a/pkgs/development/compilers/open-watcom/v2.nix +++ b/pkgs/development/compilers/open-watcom/v2.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, unstableGitUpdater -, dosbox - -# Docs cause an immense increase in build time, up to 2 additional hours -, withDocs ? false -, ghostscript -, withGUI ? false +{ + stdenv, + lib, + fetchFromGitHub, + unstableGitUpdater, + dosbox, + + # Docs cause an immense increase in build time, up to 2 additional hours + withDocs ? false, + ghostscript, + withGUI ? false, }: stdenv.mkDerivation rec { @@ -22,30 +23,34 @@ stdenv.mkDerivation rec { hash = "sha256-rT3z0KrkCZ78SbsK2CEHfvJa1TEnRH2kwhzZhi8fZDo="; }; - postPatch = '' - patchShebangs *.sh - - for dateSource in bld/wipfc/configure; do - substituteInPlace $dateSource \ - --replace '`date ' '`date -ud "@$SOURCE_DATE_EPOCH" ' - done - - substituteInPlace bld/watcom/h/banner.h \ - --replace '__DATE__' "\"$(date -ud "@$SOURCE_DATE_EPOCH" +'%b %d %Y')\"" \ - --replace '__TIME__' "\"$(date -ud "@$SOURCE_DATE_EPOCH" +'%T')\"" - - substituteInPlace build/makeinit \ - --replace '$+$(%__CYEAR__)$-' "$(date -ud "@$SOURCE_DATE_EPOCH" +'%Y')" - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - substituteInPlace build/mif/local.mif \ - --replace '-static' "" - ''; + postPatch = + '' + patchShebangs *.sh + + for dateSource in bld/wipfc/configure; do + substituteInPlace $dateSource \ + --replace '`date ' '`date -ud "@$SOURCE_DATE_EPOCH" ' + done + + substituteInPlace bld/watcom/h/banner.h \ + --replace '__DATE__' "\"$(date -ud "@$SOURCE_DATE_EPOCH" +'%b %d %Y')\"" \ + --replace '__TIME__' "\"$(date -ud "@$SOURCE_DATE_EPOCH" +'%T')\"" + + substituteInPlace build/makeinit \ + --replace '$+$(%__CYEAR__)$-' "$(date -ud "@$SOURCE_DATE_EPOCH" +'%Y')" + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + substituteInPlace build/mif/local.mif \ + --replace '-static' "" + ''; - nativeBuildInputs = [ - dosbox - ] ++ lib.optionals withDocs [ - ghostscript - ]; + nativeBuildInputs = + [ + dosbox + ] + ++ lib.optionals withDocs [ + ghostscript + ]; configurePhase = '' runHook preConfigure @@ -96,37 +101,43 @@ stdenv.mkDerivation rec { meta = with lib; { description = "V2 fork of the Open Watcom suite of compilers and tools"; - longDescription = '' - A fork of Open Watcom: A C/C++/Fortran compiler and assembler suite - targeting a multitude of architectures (x86, IA-32, Alpha AXP, MIPS, - PowerPC) and operating systems (DOS, OS/2, Windows, Linux). - - Main differences from Open Watcom 1.9: - - - New two-phase build system - Open Watcom can be built by the host's - native C/C++ compiler or by itself - - Code generator properly initializes pointers by DLL symbol addresses - - DOS tools now support long file names (LFN) if appropriate LFN driver - is loaded by DOS - - Open Watcom is ported to 64-bit hosts (Win64, Linux x64) - - Librarian supports x64 CPU object modules and libraries - - RDOS 32-bit C run-time compact memory model libraries are fixed - - Resource compiler and Resource editors support Win64 executables - - Open Watcom text editor is now self-contained, it can be used as - standalone tool without any requirements for any additional files or - configuration - - Broken C++ compiler pre-compiled header template support is fixed - - Many C++ compiler crashes are fixed - - Debugger has no length limit for any used environment variable - '' + lib.optionalString (!withDocs) '' - - The documentation has been excluded from this build for build time reasons. It can be found here: - https://github.com/open-watcom/open-watcom-v2/wiki/Open-Watcom-Documentation - ''; + longDescription = + '' + A fork of Open Watcom: A C/C++/Fortran compiler and assembler suite + targeting a multitude of architectures (x86, IA-32, Alpha AXP, MIPS, + PowerPC) and operating systems (DOS, OS/2, Windows, Linux). + + Main differences from Open Watcom 1.9: + + - New two-phase build system - Open Watcom can be built by the host's + native C/C++ compiler or by itself + - Code generator properly initializes pointers by DLL symbol addresses + - DOS tools now support long file names (LFN) if appropriate LFN driver + is loaded by DOS + - Open Watcom is ported to 64-bit hosts (Win64, Linux x64) + - Librarian supports x64 CPU object modules and libraries + - RDOS 32-bit C run-time compact memory model libraries are fixed + - Resource compiler and Resource editors support Win64 executables + - Open Watcom text editor is now self-contained, it can be used as + standalone tool without any requirements for any additional files or + configuration + - Broken C++ compiler pre-compiled header template support is fixed + - Many C++ compiler crashes are fixed + - Debugger has no length limit for any used environment variable + '' + + lib.optionalString (!withDocs) '' + + The documentation has been excluded from this build for build time reasons. It can be found here: + https://github.com/open-watcom/open-watcom-v2/wiki/Open-Watcom-Documentation + ''; homepage = "https://open-watcom.github.io"; license = licenses.watcom; platforms = with platforms; windows ++ unix; - badPlatforms = platforms.riscv ++ [ "powerpc64-linux" "powerpc64le-linux" "mips64el-linux" ]; + badPlatforms = platforms.riscv ++ [ + "powerpc64-linux" + "powerpc64le-linux" + "mips64el-linux" + ]; maintainers = with maintainers; [ OPNA2608 ]; }; } diff --git a/pkgs/development/compilers/open-watcom/wrapper.nix b/pkgs/development/compilers/open-watcom/wrapper.nix index 95752b2c2fe434..878253f2caf36b 100644 --- a/pkgs/development/compilers/open-watcom/wrapper.nix +++ b/pkgs/development/compilers/open-watcom/wrapper.nix @@ -1,46 +1,59 @@ # Arguments that this derivation gets when it is created with `callPackage` -{ stdenv -, lib -, symlinkJoin -, makeWrapper -, runCommand -, file +{ + stdenv, + lib, + symlinkJoin, + makeWrapper, + runCommand, + file, }: open-watcom: let wrapper = - {}: + { }: let - archToBindir = with stdenv.hostPlatform; if isx86 then - "bin" - else if isAarch then - "arm" - # we don't support running on AXP - # don't know what MIPS, PPC bindirs are called - else throw "Don't know where ${system} binaries are located!"; + archToBindir = + with stdenv.hostPlatform; + if isx86 then + "bin" + else if isAarch then + "arm" + # we don't support running on AXP + # don't know what MIPS, PPC bindirs are called + else + throw "Don't know where ${system} binaries are located!"; - binDirs = with stdenv.hostPlatform; if isWindows then [ - (lib.optionalString is64bit "${archToBindir}nt64") - "${archToBindir}nt" - (lib.optionalString is32bit "${archToBindir}w") - ] else if (isDarwin) then [ - (lib.optionalString is64bit "${archToBindir}o64") - # modern Darwin cannot execute 32-bit code anymore - (lib.optionalString is32bit "${archToBindir}o") - ] else [ - (lib.optionalString is64bit "${archToBindir}l64") - "${archToBindir}l" - ]; + binDirs = + with stdenv.hostPlatform; + if isWindows then + [ + (lib.optionalString is64bit "${archToBindir}nt64") + "${archToBindir}nt" + (lib.optionalString is32bit "${archToBindir}w") + ] + else if (isDarwin) then + [ + (lib.optionalString is64bit "${archToBindir}o64") + # modern Darwin cannot execute 32-bit code anymore + (lib.optionalString is32bit "${archToBindir}o") + ] + else + [ + (lib.optionalString is64bit "${archToBindir}l64") + "${archToBindir}l" + ]; # TODO # This works good enough as-is, but should really only be targetPlatform-specific # but we don't support targeting DOS, OS/2, 16-bit Windows etc Nixpkgs-wide so this needs extra logic - includeDirs = with stdenv.hostPlatform; [ - "h" - ] - ++ lib.optional isWindows "h/nt" - ++ lib.optional isLinux "lh"; + includeDirs = + with stdenv.hostPlatform; + [ + "h" + ] + ++ lib.optional isWindows "h/nt" + ++ lib.optional isLinux "lh"; listToDirs = list: lib.strings.concatMapStringsSep ":" (dir: "${placeholder "out"}/${dir}") list; name = "${open-watcom.passthru.prettyName}-${open-watcom.version}"; in @@ -72,69 +85,79 @@ let passthru = { unwrapped = open-watcom; - tests = let - wrapped = wrapper { }; - in { - simple = runCommand "${name}-test-simple" { nativeBuildInputs = [ wrapped ]; } '' - cat <test.c - #include - int main() { - printf ("Testing OpenWatcom C89 compiler.\n"); - return 0; - } - EOF - cat test.c - wcl386 -fe=test_c test.c - # Only test execution if hostPlatform is targetable - ${lib.optionalString (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isAarch) "./test_c"} - - cat <test.cpp - #include - #include - int main() { - std::cout << "Testing OpenWatcom C++ library implementation." << std::endl; - watcom::istring HELLO ("HELLO"); - if (HELLO != "hello") { - return 1; + tests = + let + wrapped = wrapper { }; + in + { + simple = runCommand "${name}-test-simple" { nativeBuildInputs = [ wrapped ]; } '' + cat <test.c + #include + int main() { + printf ("Testing OpenWatcom C89 compiler.\n"); + return 0; } - if (HELLO.find ("ello") != 1) { - return 2; + EOF + cat test.c + wcl386 -fe=test_c test.c + # Only test execution if hostPlatform is targetable + ${lib.optionalString (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isAarch) "./test_c"} + + cat <test.cpp + #include + #include + int main() { + std::cout << "Testing OpenWatcom C++ library implementation." << std::endl; + watcom::istring HELLO ("HELLO"); + if (HELLO != "hello") { + return 1; + } + if (HELLO.find ("ello") != 1) { + return 2; + } + return 0; } - return 0; - } - EOF - cat test.cpp - wcl386 -fe=test_cpp test.cpp - # Only test execution if hostPlatform is targetable - ${lib.optionalString (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isAarch) "./test_cpp"} - touch $out - ''; - cross = runCommand "${name}-test-cross" { nativeBuildInputs = [ wrapped file ]; } '' - cat <test.c - #include - int main() { - printf ("Testing OpenWatcom cross-compilation.\n"); - return 0; - } - EOF - cat test.c + EOF + cat test.cpp + wcl386 -fe=test_cpp test.cpp + # Only test execution if hostPlatform is targetable + ${lib.optionalString (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isAarch) "./test_cpp"} + touch $out + ''; + cross = + runCommand "${name}-test-cross" + { + nativeBuildInputs = [ + wrapped + file + ]; + } + '' + cat <test.c + #include + int main() { + printf ("Testing OpenWatcom cross-compilation.\n"); + return 0; + } + EOF + cat test.c - echo "Test compiling" - wcl386 -bcl=linux -fe=linux test.c - wcl386 -bcl=nt -fe=nt test.c - wcl386 -bcl=dos4g -fe=dos4g test.c - wcl -bcl=windows -fe=windows test.c - wcl -bcl=dos -fe=dos test.c + echo "Test compiling" + wcl386 -bcl=linux -fe=linux test.c + wcl386 -bcl=nt -fe=nt test.c + wcl386 -bcl=dos4g -fe=dos4g test.c + wcl -bcl=windows -fe=windows test.c + wcl -bcl=dos -fe=dos test.c - echo "Test file format" - file ./linux | grep "32-bit" | grep "Linux" - file ./nt.exe | grep "PE32" | grep "Windows" - file ./dos4g.exe | grep "MS-DOS" | grep "LE executable" - file ./windows.exe | grep "MS-DOS" | grep "Windows 3.x" - file ./dos.exe | grep "MS-DOS" | grep -v "LE" | grep -v "Windows 3.x" - touch $out - ''; - }; + echo "Test file format" + file ./linux | grep "32-bit" | grep "Linux" + file ./nt.exe | grep "PE32" | grep "Windows" + file ./dos4g.exe | grep "MS-DOS" | grep "LE executable" + file ./windows.exe | grep "MS-DOS" | grep "Windows 3.x" + file ./dos.exe | grep "MS-DOS" | grep -v "LE" | grep -v "Windows 3.x" + touch $out + ''; + }; }; inherit (open-watcom) meta; diff --git a/pkgs/development/compilers/openjdk/jre.nix b/pkgs/development/compilers/openjdk/jre.nix index da3bd16bcb5448..00686803cb8f54 100644 --- a/pkgs/development/compilers/openjdk/jre.nix +++ b/pkgs/development/compilers/openjdk/jre.nix @@ -1,8 +1,9 @@ -{ stdenv -, jdk -, lib -, callPackage -, modules ? [ "java.base" ] +{ + stdenv, + jdk, + lib, + callPackage, + modules ? [ "java.base" ], }: let @@ -31,9 +32,10 @@ let passthru = { home = "${jre}"; tests = { - jre_minimal-hello = callPackage ./tests/test_jre_minimal.nix {}; - jre_minimal-hello-logging = callPackage ./tests/test_jre_minimal_with_logging.nix {}; + jre_minimal-hello = callPackage ./tests/test_jre_minimal.nix { }; + jre_minimal-hello-logging = callPackage ./tests/test_jre_minimal_with_logging.nix { }; }; }; }; -in jre +in +jre diff --git a/pkgs/development/compilers/openjdk/tests/hello-logging.nix b/pkgs/development/compilers/openjdk/tests/hello-logging.nix index 20fbb93ae2be90..49d42c077b9b4e 100644 --- a/pkgs/development/compilers/openjdk/tests/hello-logging.nix +++ b/pkgs/development/compilers/openjdk/tests/hello-logging.nix @@ -1,9 +1,10 @@ -{ jdk -, jre -, pkgs +{ + jdk, + jre, + pkgs, }: -/* 'Hello world' Java application derivation for use in tests */ +# 'Hello world' Java application derivation for use in tests let source = pkgs.writeTextDir "src/Hello.java" '' import java.util.logging.Logger; @@ -18,30 +19,30 @@ let } ''; in - pkgs.stdenv.mkDerivation { - pname = "hello"; - version = "1.0.0"; - - src = source; - - buildPhase = '' - runHook preBuild - ${jdk}/bin/javac src/Hello.java - runHook postBuild - ''; - installPhase = '' - runHook preInstall - - mkdir -p $out/lib - cp src/Hello.class $out/lib - - mkdir -p $out/bin - cat >$out/bin/hello <$out/bin/hello <$out/bin/hello <$out/bin/hello </dev/stdout | grep "Hello, world!" - touch $out - '' +runCommand "test" { } '' + ${hello-logging}/bin/hello &>/dev/stdout | grep "Hello, world!" + touch $out +'' diff --git a/pkgs/development/compilers/osl/default.nix b/pkgs/development/compilers/osl/default.nix index f485998d1cfaae..17df7fa6f050a7 100644 --- a/pkgs/development/compilers/osl/default.nix +++ b/pkgs/development/compilers/osl/default.nix @@ -1,28 +1,30 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, clang -, libclang -, libxml2 -, zlib -, openexr -, openimageio -, llvm -, boost -, flex -, bison -, partio -, pugixml -, util-linux -, python3 +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + clang, + libclang, + libxml2, + zlib, + openexr, + openimageio, + llvm, + boost, + flex, + bison, + partio, + pugixml, + util-linux, + python3, }: let boost_static = boost.override { enableStatic = true; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "openshadinglanguage"; version = "1.13.11.0"; @@ -57,20 +59,22 @@ in stdenv.mkDerivation rec { flex ]; - buildInputs = [ - boost_static - libclang - llvm - openexr - openimageio - partio - pugixml - python3.pkgs.pybind11 - util-linux # needed just for hexdump - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libxml2 - ]; + buildInputs = + [ + boost_static + libclang + llvm + openexr + openimageio + partio + pugixml + python3.pkgs.pybind11 + util-linux # needed just for hexdump + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libxml2 + ]; postFixup = '' substituteInPlace "$out"/lib/pkgconfig/*.pc \ diff --git a/pkgs/development/compilers/p4c/default.nix b/pkgs/development/compilers/p4c/default.nix index 060e298098236e..3fd3aa022c07ae 100644 --- a/pkgs/development/compilers/p4c/default.nix +++ b/pkgs/development/compilers/p4c/default.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, boehmgc -, bison -, flex -, protobuf -, gmp -, boost -, python3 -, doxygen -, graphviz -, libbpf -, libllvm -, enableDocumentation ? true -, enableBPF ? true -, enableDPDK ? true -, enableBMV2 ? true -, enableGraphBackend ? true -, enableP4Tests ? true -, enableGTests ? true -, enableMultithreading ? false +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + boehmgc, + bison, + flex, + protobuf, + gmp, + boost, + python3, + doxygen, + graphviz, + libbpf, + libllvm, + enableDocumentation ? true, + enableBPF ? true, + enableDPDK ? true, + enableBMV2 ? true, + enableGraphBackend ? true, + enableP4Tests ? true, + enableGTests ? true, + enableMultithreading ? false, }: let toCMakeBoolean = v: if v then "ON" else "OFF"; @@ -63,7 +64,7 @@ stdenv.mkDerivation (finalAttrs: { "-DENABLE_DOCS=${toCMakeBoolean enableDocumentation}" "-DENABLE_GC=ON" "-DENABLE_GTESTS=${toCMakeBoolean enableGTests}" - "-DENABLE_PROTOBUF_STATIC=OFF" # static protobuf has been removed since 3.21.6 + "-DENABLE_PROTOBUF_STATIC=OFF" # static protobuf has been removed since 3.21.6 "-DENABLE_MULTITHREAD=${toCMakeBoolean enableMultithreading}" "-DENABLE_GMP=ON" ]; @@ -72,15 +73,22 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - nativeBuildInputs = [ - bison - flex - cmake - protobuf - python3 - ] - ++ lib.optionals enableDocumentation [ doxygen graphviz ] - ++ lib.optionals enableBPF [ libllvm libbpf ]; + nativeBuildInputs = + [ + bison + flex + cmake + protobuf + python3 + ] + ++ lib.optionals enableDocumentation [ + doxygen + graphviz + ] + ++ lib.optionals enableBPF [ + libllvm + libbpf + ]; buildInputs = [ protobuf @@ -95,7 +103,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Reference compiler for the P4 programming language"; homepage = "https://github.com/p4lang/p4c"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ raitobezarius govanify ]; + maintainers = with lib.maintainers; [ + raitobezarius + govanify + ]; platforms = lib.platforms.linux; }; }) diff --git a/pkgs/development/compilers/pakcs/curry-frontend.nix b/pkgs/development/compilers/pakcs/curry-frontend.nix index acf658024b010f..d3a144d9b3405e 100644 --- a/pkgs/development/compilers/pakcs/curry-frontend.nix +++ b/pkgs/development/compilers/pakcs/curry-frontend.nix @@ -1,7 +1,24 @@ -{ mkDerivation, base, binary, bytestring, Cabal, containers -, directory, extra, file-embed, filepath, lib, mtl, network-uri -, parsec, pretty, process, set-extra, template-haskell, time -, transformers +{ + mkDerivation, + base, + binary, + bytestring, + Cabal, + containers, + directory, + extra, + file-embed, + filepath, + lib, + mtl, + network-uri, + parsec, + pretty, + process, + set-extra, + template-haskell, + time, + transformers, }: mkDerivation { pname = "curry-frontend"; @@ -11,14 +28,40 @@ mkDerivation { isExecutable = true; enableSeparateDataOutput = true; libraryHaskellDepends = [ - base binary bytestring containers directory extra file-embed - filepath mtl network-uri parsec pretty process set-extra - template-haskell time transformers + base + binary + bytestring + containers + directory + extra + file-embed + filepath + mtl + network-uri + parsec + pretty + process + set-extra + template-haskell + time + transformers ]; executableHaskellDepends = [ base ]; testHaskellDepends = [ - base bytestring Cabal containers directory extra file-embed - filepath mtl network-uri pretty process set-extra template-haskell + base + bytestring + Cabal + containers + directory + extra + file-embed + filepath + mtl + network-uri + pretty + process + set-extra + template-haskell transformers ]; homepage = "http://curry-language.org"; diff --git a/pkgs/development/compilers/pakcs/default.nix b/pkgs/development/compilers/pakcs/default.nix index 625bab0cab319b..7d069535774c94 100644 --- a/pkgs/development/compilers/pakcs/default.nix +++ b/pkgs/development/compilers/pakcs/default.nix @@ -1,7 +1,22 @@ -{ lib, stdenv, fetchurl, fetchpatch2, makeWrapper -, haskellPackages, haskell -, which, swi-prolog, rlwrap, tk -, curl, git, unzip, gnutar, coreutils, sqlite }: +{ + lib, + stdenv, + fetchurl, + fetchpatch2, + makeWrapper, + haskellPackages, + haskell, + which, + swi-prolog, + rlwrap, + tk, + curl, + git, + unzip, + gnutar, + coreutils, + sqlite, +}: let pname = "pakcs"; @@ -14,10 +29,11 @@ let hash = "sha256-ZfQUgFqmPPCeDx/T5G/JdvYDq/7XbvsgxPcEX4y9HZ4="; }; - curry-frontend = (haskellPackages.override { - overrides = self: super: { - curry-frontend = lib.pipe (super.callPackage ./curry-frontend.nix { }) - [ haskell.lib.doJailbreak + curry-frontend = + (haskellPackages.override { + overrides = self: super: { + curry-frontend = lib.pipe (super.callPackage ./curry-frontend.nix { }) [ + haskell.lib.doJailbreak (haskell.lib.compose.overrideCabal (drv: { inherit src; postUnpack = "sourceRoot+=/frontend"; @@ -25,20 +41,27 @@ let (haskell.lib.compose.appendPatch # mtl 2.3 compatibility has been fixed upstream but it's not in # the release yet - (fetchpatch2 { - name = "fix-mtl-2.3.patch"; - url = "https://git.ps.informatik.uni-kiel.de/curry/curry-frontend/-/commit/3b26d2826141fee676da07939c2929a049279b70.diff"; - hash = "sha256-R3XjoUzAwTvDoUEAIIjmrSh2r4RHMqe00RMIs+7jFPY="; - })) + ( + fetchpatch2 { + name = "fix-mtl-2.3.patch"; + url = "https://git.ps.informatik.uni-kiel.de/curry/curry-frontend/-/commit/3b26d2826141fee676da07939c2929a049279b70.diff"; + hash = "sha256-R3XjoUzAwTvDoUEAIIjmrSh2r4RHMqe00RMIs+7jFPY="; + } + ) + ) ]; - }; - }).curry-frontend; + }; + }).curry-frontend; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname version src; buildInputs = [ swi-prolog ]; - nativeBuildInputs = [ which makeWrapper ]; + nativeBuildInputs = [ + which + makeWrapper + ]; makeFlags = [ "CURRYFRONTEND=${curry-frontend}/bin/curry-frontend" @@ -56,7 +79,7 @@ in stdenv.mkDerivation { scripts/compile-all-libs.sh; do substituteInPlace $file --replace "/bin/rm" "rm" done - '' ; + ''; preBuild = '' mkdir -p $out/pakcs @@ -78,7 +101,16 @@ in stdenv.mkDerivation { # List of dependencies from currytools/cpm/src/CPM/Main.curry wrapProgram $out/pakcs/bin/cypm \ - --prefix PATH ":" "${lib.makeBinPath [ curl git unzip gnutar coreutils sqlite ]}" + --prefix PATH ":" "${ + lib.makeBinPath [ + curl + git + unzip + gnutar + coreutils + sqlite + ] + }" runHook postInstall ''; diff --git a/pkgs/development/compilers/polyml/5.6.nix b/pkgs/development/compilers/polyml/5.6.nix index ee841882833c57..1601669673ebe4 100644 --- a/pkgs/development/compilers/polyml/5.6.nix +++ b/pkgs/development/compilers/polyml/5.6.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, autoreconfHook, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + fetchpatch, +}: let version = "5.6"; @@ -35,7 +41,8 @@ stdenv.mkDerivation { homepage = "https://www.polyml.org/"; license = lib.licenses.lgpl21; platforms = with lib.platforms; linux; - maintainers = [ #Add your name here! + maintainers = [ + # Add your name here! lib.maintainers.maggesi ]; }; diff --git a/pkgs/development/compilers/polyml/5.7.nix b/pkgs/development/compilers/polyml/5.7.nix index 471e8b2fd9f105..197a787594ea3c 100644 --- a/pkgs/development/compilers/polyml/5.7.nix +++ b/pkgs/development/compilers/polyml/5.7.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, gmp, libffi, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gmp, + libffi, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "polyml"; @@ -18,7 +26,10 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ libffi gmp ]; + buildInputs = [ + libffi + gmp + ]; nativeBuildInputs = lib.optional stdenv.hostPlatform.isDarwin autoreconfHook; diff --git a/pkgs/development/compilers/ponyc/default.nix b/pkgs/development/compilers/ponyc/default.nix index dd0d8f8c8e414a..005605e9095af3 100644 --- a/pkgs/development/compilers/ponyc/default.nix +++ b/pkgs/development/compilers/ponyc/default.nix @@ -113,25 +113,29 @@ stdenv.mkDerivation (rec { # make: *** [Makefile:222: test-full-programs-release] Killed: 9 doCheck = !stdenv.hostPlatform.isDarwin; - installPhase = '' - makeArgs=(config=release prefix=$out) - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - makeArgs+=(bits=64) - '' + lib.optionalString (stdenv.hostPlatform.isDarwin && !lto) '' - makeArgs+=(lto=no) - '' + '' - make "''${makeArgs[@]}" install - wrapProgram $out/bin/ponyc \ - --prefix PATH ":" "${stdenv.cc}/bin" \ - --set-default CC "$CC" \ - --prefix PONYPATH : "${ - lib.makeLibraryPath [ - pcre2 - openssl - (placeholder "out") - ] - }" - ''; + installPhase = + '' + makeArgs=(config=release prefix=$out) + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + makeArgs+=(bits=64) + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin && !lto) '' + makeArgs+=(lto=no) + '' + + '' + make "''${makeArgs[@]}" install + wrapProgram $out/bin/ponyc \ + --prefix PATH ":" "${stdenv.cc}/bin" \ + --set-default CC "$CC" \ + --prefix PONYPATH : "${ + lib.makeLibraryPath [ + pcre2 + openssl + (placeholder "out") + ] + }" + ''; # Stripping breaks linking for ponyc dontStrip = true; diff --git a/pkgs/development/compilers/ponyc/pony-corral.nix b/pkgs/development/compilers/ponyc/pony-corral.nix index 87dca22898f198..980b8e69d66661 100644 --- a/pkgs/development/compilers/ponyc/pony-corral.nix +++ b/pkgs/development/compilers/ponyc/pony-corral.nix @@ -33,7 +33,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.ponylang.io"; changelog = "https://github.com/ponylang/corral/blob/${finalAttrs.version}/CHANGELOG.md"; license = licenses.bsd2; - maintainers = with maintainers; [ redvers numinit ]; + maintainers = with maintainers; [ + redvers + numinit + ]; inherit (ponyc.meta) platforms; }; }) diff --git a/pkgs/development/compilers/purescript/purescript/default.nix b/pkgs/development/compilers/purescript/purescript/default.nix index 8f88fed052eef5..97000e8220ca73 100644 --- a/pkgs/development/compilers/purescript/purescript/default.nix +++ b/pkgs/development/compilers/purescript/purescript/default.nix @@ -1,4 +1,11 @@ -{ stdenv, pkgs, fetchurl, zlib, gmp, lib }: +{ + stdenv, + pkgs, + fetchurl, + zlib, + gmp, + lib, +}: # from justinwoo/easy-purescript-nix # https://github.com/justinwoo/easy-purescript-nix/blob/d383972c82620a712ead4033db14110497bc2c9c/purs.nix @@ -6,61 +13,69 @@ let dynamic-linker = stdenv.cc.bintools.dynamicLinker; - patchelf = libPath : + patchelf = + libPath: lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - chmod u+w $PURS - patchelf --interpreter ${dynamic-linker} --set-rpath ${libPath} $PURS - chmod u-w $PURS - ''; + chmod u+w $PURS + patchelf --interpreter ${dynamic-linker} --set-rpath ${libPath} $PURS + chmod u-w $PURS + ''; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "purescript"; version = "0.15.15"; # These hashes can be updated automatically by running the ./update.sh script. - src = let - url = "https://github.com/${pname}/${pname}/releases/download/v${version}/"; - sources = { - "x86_64-linux" = fetchurl { - url = url + "linux64.tar.gz"; - sha256 = "1w4jgjpfhaw3gkx9sna64lq9m030x49w4lwk01ik5ci0933imzj3"; + src = + let + url = "https://github.com/${pname}/${pname}/releases/download/v${version}/"; + sources = { + "x86_64-linux" = fetchurl { + url = url + "linux64.tar.gz"; + sha256 = "1w4jgjpfhaw3gkx9sna64lq9m030x49w4lwk01ik5ci0933imzj3"; + }; + "aarch64-linux" = fetchurl { + url = url + "linux-arm64.tar.gz"; + sha256 = "1ws5h337xq0l06zrs9010h6wj2hq5cqk5ikp9arq7hj7lxf43vn5"; + }; + "x86_64-darwin" = fetchurl { + url = url + "macos.tar.gz"; + sha256 = "178ix54k2yragcgn0j8z1cfa78s1qbh1bsx3v9jnngby8igr6yn3"; + }; + "aarch64-darwin" = fetchurl { + url = url + "macos-arm64.tar.gz"; + sha256 = "0bi231z1yhb7kjfn228wjkj6rv9lgpagz9f4djr2wy3kqgck4xg0"; + }; }; - "aarch64-linux" = fetchurl { - url = url + "linux-arm64.tar.gz"; - sha256 = "1ws5h337xq0l06zrs9010h6wj2hq5cqk5ikp9arq7hj7lxf43vn5"; - }; - "x86_64-darwin" = fetchurl { - url = url + "macos.tar.gz"; - sha256 = "178ix54k2yragcgn0j8z1cfa78s1qbh1bsx3v9jnngby8igr6yn3"; - }; - "aarch64-darwin" = fetchurl { - url = url + "macos-arm64.tar.gz"; - sha256 = "0bi231z1yhb7kjfn228wjkj6rv9lgpagz9f4djr2wy3kqgck4xg0"; - }; - }; - in + in sources.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); - buildInputs = [ zlib gmp ]; + buildInputs = [ + zlib + gmp + ]; libPath = lib.makeLibraryPath buildInputs; dontStrip = true; - installPhase = '' - mkdir -p $out/bin - PURS="$out/bin/purs" + installPhase = + '' + mkdir -p $out/bin + PURS="$out/bin/purs" - install -D -m555 -T purs $PURS - ${patchelf libPath} - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - mkdir -p $out/share/bash-completion/completions - $PURS --bash-completion-script $PURS > $out/share/bash-completion/completions/purs-completion.bash - ''; + install -D -m555 -T purs $PURS + ${patchelf libPath} + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + mkdir -p $out/share/bash-completion/completions + $PURS --bash-completion-script $PURS > $out/share/bash-completion/completions/purs-completion.bash + ''; passthru = { updateScript = ./update.sh; tests = { - minimal-module = pkgs.callPackage ./test-minimal-module {}; + minimal-module = pkgs.callPackage ./test-minimal-module { }; }; }; @@ -69,8 +84,17 @@ in stdenv.mkDerivation rec { homepage = "https://www.purescript.org/"; license = licenses.bsd3; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; - maintainers = with maintainers; [ justinwoo mbbx6spp cdepillabout ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + maintainers = with maintainers; [ + justinwoo + mbbx6spp + cdepillabout + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; mainProgram = "purs"; changelog = "https://github.com/purescript/purescript/releases/tag/v${version}"; }; diff --git a/pkgs/development/compilers/purescript/purescript/test-minimal-module/default.nix b/pkgs/development/compilers/purescript/purescript/test-minimal-module/default.nix index 9bc694cd73f314..a8503e1b9aae80 100644 --- a/pkgs/development/compilers/purescript/purescript/test-minimal-module/default.nix +++ b/pkgs/development/compilers/purescript/purescript/test-minimal-module/default.nix @@ -1,6 +1,10 @@ -{ runCommand, purescript, nodejs }: +{ + runCommand, + purescript, + nodejs, +}: -runCommand "purescript-test-minimal-module" {} '' +runCommand "purescript-test-minimal-module" { } '' ${purescript}/bin/purs compile -o ./output ${./.}/Main.purs echo 'import {main} from "./output/Main/index.js"; main()' > node.mjs diff --git a/pkgs/development/compilers/reason/rtop.nix b/pkgs/development/compilers/reason/rtop.nix index 0255e57d5c47e9..de47bcdad8545f 100644 --- a/pkgs/development/compilers/reason/rtop.nix +++ b/pkgs/development/compilers/reason/rtop.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, reason, cppo, utop, makeWrapper }: +{ + buildDunePackage, + reason, + cppo, + utop, + makeWrapper, +}: buildDunePackage { pname = "rtop"; @@ -9,7 +15,10 @@ buildDunePackage { cppo ]; - propagatedBuildInputs = [ reason utop ]; + propagatedBuildInputs = [ + reason + utop + ]; postInstall = '' wrapProgram $out/bin/rtop \ diff --git a/pkgs/development/compilers/reason/tests/hello/default.nix b/pkgs/development/compilers/reason/tests/hello/default.nix index 42a0173a03be30..80f60afbafd3b6 100644 --- a/pkgs/development/compilers/reason/tests/hello/default.nix +++ b/pkgs/development/compilers/reason/tests/hello/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, reason }: +{ + lib, + buildDunePackage, + reason, +}: buildDunePackage rec { pname = "helloreason"; diff --git a/pkgs/development/compilers/rml/default.nix b/pkgs/development/compilers/rml/default.nix index b2870cfb93d38c..e5f0f64f80dd4d 100644 --- a/pkgs/development/compilers/rml/default.nix +++ b/pkgs/development/compilers/rml/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, ocamlPackages +{ + lib, + stdenv, + fetchFromGitHub, + ocamlPackages, }: stdenv.mkDerivation rec { @@ -30,7 +31,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "ReactiveML: a programming language for implementing interactive systems"; homepage = "https://rml.lri.fr"; - license = with licenses; [ qpl lgpl21Plus ]; + license = with licenses; [ + qpl + lgpl21Plus + ]; maintainers = with maintainers; [ wegank ]; }; } diff --git a/pkgs/development/compilers/rust/binary.nix b/pkgs/development/compilers/rust/binary.nix index df3b8f729f7f9b..2e6aa5ca329f02 100644 --- a/pkgs/development/compilers/rust/binary.nix +++ b/pkgs/development/compilers/rust/binary.nix @@ -1,9 +1,18 @@ -{ lib, stdenv, makeWrapper, wrapRustc, bash, curl, darwin, zlib -, autoPatchelfHook, gcc -, version -, src -, platform -, versionType +{ + lib, + stdenv, + makeWrapper, + wrapRustc, + bash, + curl, + darwin, + zlib, + autoPatchelfHook, + gcc, + version, + src, + platform, + versionType, }: let @@ -12,10 +21,7 @@ let bootstrapping = versionType == "bootstrap"; - installComponents - = "rustc,rust-std-${platform}" - + (optionalString bootstrapping ",cargo") - ; + installComponents = "rustc,rust-std-${platform}" + (optionalString bootstrapping ",cargo"); in rec { @@ -30,11 +36,15 @@ rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; description = "Safe, concurrent, practical language"; maintainers = with maintainers; [ qknight ]; - license = [ licenses.mit licenses.asl20 ]; + license = [ + licenses.mit + licenses.asl20 + ]; }; nativeBuildInputs = lib.optional (!stdenv.hostPlatform.isDarwin) autoPatchelfHook; - buildInputs = [ bash ] + buildInputs = + [ bash ] ++ lib.optional (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isFreeBSD) gcc.cc.lib ++ lib.optional (!stdenv.hostPlatform.isDarwin) zlib ++ lib.optional stdenv.hostPlatform.isDarwin Security; @@ -66,24 +76,47 @@ rec { tier1TargetPlatforms = [ # Platforms with host tools from # https://doc.rust-lang.org/nightly/rustc/platform-support.html - "x86_64-darwin" "i686-darwin" "aarch64-darwin" - "i686-freebsd" "x86_64-freebsd" + "x86_64-darwin" + "i686-darwin" + "aarch64-darwin" + "i686-freebsd" + "x86_64-freebsd" "x86_64-solaris" - "aarch64-linux" "armv6l-linux" "armv7l-linux" "i686-linux" - "loongarch64-linux" "powerpc64-linux" "powerpc64le-linux" - "riscv64-linux" "s390x-linux" "x86_64-linux" - "aarch64-netbsd" "armv7l-netbsd" "i686-netbsd" "powerpc-netbsd" + "aarch64-linux" + "armv6l-linux" + "armv7l-linux" + "i686-linux" + "loongarch64-linux" + "powerpc64-linux" + "powerpc64le-linux" + "riscv64-linux" + "s390x-linux" + "x86_64-linux" + "aarch64-netbsd" + "armv7l-netbsd" + "i686-netbsd" + "powerpc-netbsd" "x86_64-netbsd" - "i686-openbsd" "x86_64-openbsd" - "i686-windows" "x86_64-windows" + "i686-openbsd" + "x86_64-openbsd" + "i686-windows" + "x86_64-windows" ]; targetPlatforms = tier1TargetPlatforms ++ [ # Platforms without host tools from # https://doc.rust-lang.org/nightly/rustc/platform-support.html "armv7a-darwin" - "armv5tel-linux" "armv7a-linux" "m68k-linux" "mips-linux" - "mips64-linux" "mipsel-linux" "mips64el-linux" "riscv32-linux" - "armv6l-netbsd" "mipsel-netbsd" "riscv64-netbsd" + "armv5tel-linux" + "armv7a-linux" + "m68k-linux" + "mips-linux" + "mips64-linux" + "mipsel-linux" + "mips64el-linux" + "riscv32-linux" + "armv6l-netbsd" + "mipsel-netbsd" + "riscv64-netbsd" "x86_64-redox" "wasm32-wasi" ]; @@ -107,12 +140,17 @@ rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; description = "Rust package manager"; maintainers = with maintainers; [ qknight ]; - license = [ licenses.mit licenses.asl20 ]; + license = [ + licenses.mit + licenses.asl20 + ]; }; - nativeBuildInputs = [ makeWrapper ] - ++ lib.optional (!stdenv.hostPlatform.isDarwin) autoPatchelfHook; - buildInputs = [ bash ] + nativeBuildInputs = [ + makeWrapper + ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) autoPatchelfHook; + buildInputs = + [ bash ] ++ lib.optional (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isFreeBSD) gcc.cc.lib ++ lib.optional stdenv.hostPlatform.isDarwin Security; diff --git a/pkgs/development/compilers/rust/bootstrap.nix b/pkgs/development/compilers/rust/bootstrap.nix index 97ac69270252d3..e01dac1e943501 100644 --- a/pkgs/development/compilers/rust/bootstrap.nix +++ b/pkgs/development/compilers/rust/bootstrap.nix @@ -1,14 +1,21 @@ -{ stdenv, fetchurl, callPackage, version, hashes }: +{ + stdenv, + fetchurl, + callPackage, + version, + hashes, +}: let platform = stdenv.hostPlatform.rust.rustcTarget; src = fetchurl { - url = "https://static.rust-lang.org/dist/rust-${version}-${platform}.tar.gz"; - sha256 = hashes.${platform} or (throw "missing bootstrap url for platform ${platform}"); + url = "https://static.rust-lang.org/dist/rust-${version}-${platform}.tar.gz"; + sha256 = hashes.${platform} or (throw "missing bootstrap url for platform ${platform}"); }; -in callPackage ./binary.nix - { inherit version src platform; - versionType = "bootstrap"; - } +in +callPackage ./binary.nix { + inherit version src platform; + versionType = "bootstrap"; +} diff --git a/pkgs/development/compilers/rust/cargo-auditable-cargo-wrapper.nix b/pkgs/development/compilers/rust/cargo-auditable-cargo-wrapper.nix index 6e982aee01a333..420b3bc8205262 100644 --- a/pkgs/development/compilers/rust/cargo-auditable-cargo-wrapper.nix +++ b/pkgs/development/compilers/rust/cargo-auditable-cargo-wrapper.nix @@ -1,24 +1,41 @@ -{ lib, runCommand, makeBinaryWrapper, rust-audit-info, cargo, cargo-auditable }: +{ + lib, + runCommand, + makeBinaryWrapper, + rust-audit-info, + cargo, + cargo-auditable, +}: if cargo-auditable.meta.broken then cargo else -runCommand "auditable-${cargo.name}" { - nativeBuildInputs = [ makeBinaryWrapper ]; + runCommand "auditable-${cargo.name}" + { + nativeBuildInputs = [ makeBinaryWrapper ]; - passthru.tests = runCommand "rust-audit-info-test" { - nativeBuildInputs = [ rust-audit-info ]; - } '' - rust-audit-info ${lib.getBin rust-audit-info}/bin/rust-audit-info > $out - ''; + passthru.tests = + runCommand "rust-audit-info-test" + { + nativeBuildInputs = [ rust-audit-info ]; + } + '' + rust-audit-info ${lib.getBin rust-audit-info}/bin/rust-audit-info > $out + ''; - meta = cargo-auditable.meta // { - mainProgram = "cargo"; - }; -} '' - mkdir -p $out/bin - makeWrapper ${cargo}/bin/cargo $out/bin/cargo \ - --set CARGO_AUDITABLE_IGNORE_UNSUPPORTED 1 \ - --prefix PATH : ${lib.makeBinPath [ cargo cargo-auditable ]} \ - --add-flags auditable -'' + meta = cargo-auditable.meta // { + mainProgram = "cargo"; + }; + } + '' + mkdir -p $out/bin + makeWrapper ${cargo}/bin/cargo $out/bin/cargo \ + --set CARGO_AUDITABLE_IGNORE_UNSUPPORTED 1 \ + --prefix PATH : ${ + lib.makeBinPath [ + cargo + cargo-auditable + ] + } \ + --add-flags auditable + '' diff --git a/pkgs/development/compilers/rust/cargo-auditable.nix b/pkgs/development/compilers/rust/cargo-auditable.nix index 0fa6098934c151..e0582703193340 100644 --- a/pkgs/development/compilers/rust/cargo-auditable.nix +++ b/pkgs/development/compilers/rust/cargo-auditable.nix @@ -1,4 +1,12 @@ -{ lib, buildPackages, fetchFromGitHub, fetchpatch, makeRustPlatform, installShellFiles, stdenv }: +{ + lib, + buildPackages, + fetchFromGitHub, + fetchpatch, + makeRustPlatform, + installShellFiles, + stdenv, +}: let args = rec { @@ -27,7 +35,10 @@ let mainProgram = "cargo-auditable"; homepage = "https://github.com/rust-secure-code/cargo-auditable"; changelog = "https://github.com/rust-secure-code/cargo-auditable/blob/v${version}/cargo-auditable/CHANGELOG.md"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ figsoda ]; broken = stdenv.hostPlatform != stdenv.buildPlatform; }; @@ -40,21 +51,27 @@ let }; }; - bootstrap = rustPlatform.buildRustPackage (args // { - auditable = false; - }); + bootstrap = rustPlatform.buildRustPackage ( + args + // { + auditable = false; + } + ); in -rustPlatform.buildRustPackage.override { cargo-auditable = bootstrap; } (args // { - nativeBuildInputs = [ - installShellFiles - ]; +rustPlatform.buildRustPackage.override { cargo-auditable = bootstrap; } ( + args + // { + nativeBuildInputs = [ + installShellFiles + ]; - postInstall = '' - installManPage cargo-auditable/cargo-auditable.1 - ''; + postInstall = '' + installManPage cargo-auditable/cargo-auditable.1 + ''; - passthru = { - inherit bootstrap; - }; -}) + passthru = { + inherit bootstrap; + }; + } +) diff --git a/pkgs/development/compilers/rust/cargo_cross.nix b/pkgs/development/compilers/rust/cargo_cross.nix index ba7651e63bdbbe..241fb8463f3bbc 100644 --- a/pkgs/development/compilers/rust/cargo_cross.nix +++ b/pkgs/development/compilers/rust/cargo_cross.nix @@ -1,14 +1,24 @@ -{ runCommand, stdenv, lib, pkgsBuildBuild, makeShellWrapper, rustc, ... }: +{ + runCommand, + stdenv, + lib, + pkgsBuildBuild, + makeShellWrapper, + rustc, + ... +}: -runCommand "${stdenv.targetPlatform.config}-cargo-${lib.getVersion pkgsBuildBuild.cargo}" { - # Use depsBuildBuild or it tries to use target-runtimeShell - depsBuildBuild = [ makeShellWrapper ]; +runCommand "${stdenv.targetPlatform.config}-cargo-${lib.getVersion pkgsBuildBuild.cargo}" + { + # Use depsBuildBuild or it tries to use target-runtimeShell + depsBuildBuild = [ makeShellWrapper ]; - inherit (pkgsBuildBuild.cargo) meta; -} '' - mkdir -p $out/bin - ln -s ${pkgsBuildBuild.cargo}/share $out/share + inherit (pkgsBuildBuild.cargo) meta; + } + '' + mkdir -p $out/bin + ln -s ${pkgsBuildBuild.cargo}/share $out/share - makeWrapper "${pkgsBuildBuild.cargo}/bin/cargo" "$out/bin/cargo" \ - --prefix PATH : "${rustc}/bin" - '' + makeWrapper "${pkgsBuildBuild.cargo}/bin/cargo" "$out/bin/cargo" \ + --prefix PATH : "${rustc}/bin" + '' diff --git a/pkgs/development/compilers/rust/clippy.nix b/pkgs/development/compilers/rust/clippy.nix index 6a233ffe18520d..42b285cd72ab66 100644 --- a/pkgs/development/compilers/rust/clippy.nix +++ b/pkgs/development/compilers/rust/clippy.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, rustPlatform, rustc, Security }: +{ + stdenv, + lib, + rustPlatform, + rustc, + Security, +}: rustPlatform.buildRustPackage { pname = "clippy"; @@ -13,8 +19,7 @@ rustPlatform.buildRustPackage { # changes hash of vendor directory otherwise dontUpdateAutotoolsGnuConfigScripts = true; - buildInputs = [ rustc.llvm ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; + buildInputs = [ rustc.llvm ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; # fixes: error: the option `Z` is only accepted on the nightly compiler RUSTC_BOOTSTRAP = 1; @@ -40,7 +45,10 @@ rustPlatform.buildRustPackage { description = "Bunch of lints to catch common mistakes and improve your Rust code"; mainProgram = "cargo-clippy"; maintainers = with maintainers; [ basvandijk ] ++ teams.rust.members; - license = with licenses; [ mit asl20 ]; + license = with licenses; [ + mit + asl20 + ]; platforms = platforms.unix; }; } diff --git a/pkgs/development/compilers/rust/make-rust-platform.nix b/pkgs/development/compilers/rust/make-rust-platform.nix index 41380005e196b1..dfe97ead03ca52 100644 --- a/pkgs/development/compilers/rust/make-rust-platform.nix +++ b/pkgs/development/compilers/rust/make-rust-platform.nix @@ -1,10 +1,20 @@ -{ lib, buildPackages, callPackage, callPackages, cargo-auditable, config, stdenv, runCommand }@prev: +{ + lib, + buildPackages, + callPackage, + callPackages, + cargo-auditable, + config, + stdenv, + runCommand, +}@prev: -{ rustc -, cargo -, cargo-auditable ? prev.cargo-auditable -, stdenv ? prev.stdenv -, ... +{ + rustc, + cargo, + cargo-auditable ? prev.cargo-auditable, + stdenv ? prev.stdenv, + ... }: rec { @@ -13,14 +23,30 @@ rec { inherit cargo; }; - fetchCargoVendor = buildPackages.callPackage ../../../build-support/rust/fetch-cargo-vendor.nix { inherit cargo; }; + fetchCargoVendor = buildPackages.callPackage ../../../build-support/rust/fetch-cargo-vendor.nix { + inherit cargo; + }; buildRustPackage = callPackage ../../../build-support/rust/build-rust-package { - inherit stdenv cargoBuildHook cargoCheckHook cargoInstallHook cargoNextestHook cargoSetupHook - fetchCargoTarball fetchCargoVendor importCargoLock rustc cargo cargo-auditable; + inherit + stdenv + cargoBuildHook + cargoCheckHook + cargoInstallHook + cargoNextestHook + cargoSetupHook + fetchCargoTarball + fetchCargoVendor + importCargoLock + rustc + cargo + cargo-auditable + ; }; - importCargoLock = buildPackages.callPackage ../../../build-support/rust/import-cargo-lock.nix { inherit cargo; }; + importCargoLock = buildPackages.callPackage ../../../build-support/rust/import-cargo-lock.nix { + inherit cargo; + }; rustcSrc = callPackage ./rust-src.nix { inherit runCommand rustc; @@ -31,10 +57,20 @@ rec { }; # Hooks - inherit (callPackages ../../../build-support/rust/hooks { - inherit stdenv cargo rustc; - }) cargoBuildHook cargoCheckHook cargoInstallHook cargoNextestHook cargoSetupHook maturinBuildHook bindgenHook; -} // lib.optionalAttrs config.allowAliases { + inherit + (callPackages ../../../build-support/rust/hooks { + inherit stdenv cargo rustc; + }) + cargoBuildHook + cargoCheckHook + cargoInstallHook + cargoNextestHook + cargoSetupHook + maturinBuildHook + bindgenHook + ; +} +// lib.optionalAttrs config.allowAliases { rust = { rustc = lib.warn "rustPlatform.rust.rustc is deprecated. Use rustc instead." rustc; cargo = lib.warn "rustPlatform.rust.cargo is deprecated. Use cargo instead." cargo; diff --git a/pkgs/development/compilers/rust/rust-src.nix b/pkgs/development/compilers/rust/rust-src.nix index 69bdb37ac2fdbb..dfc82e35c01d55 100644 --- a/pkgs/development/compilers/rust/rust-src.nix +++ b/pkgs/development/compilers/rust/rust-src.nix @@ -1,21 +1,31 @@ -{ lib, runCommand, rustc, minimalContent ? true }: +{ + lib, + runCommand, + rustc, + minimalContent ? true, +}: runCommand "rust-src" { } '' tar -xzf ${rustc.src} mv rustc-${rustc.version}-src $out - rm -rf $out/{${lib.concatStringsSep "," ([ - "ci" - "doc" - "etc" - "grammar" - "llvm-project" - "llvm-emscripten" - "rtstartup" - "rustllvm" - "test" - "vendor" - ] ++ lib.optionals minimalContent [ - "tools" - "stdarch" - ])}} + rm -rf $out/{${ + lib.concatStringsSep "," ( + [ + "ci" + "doc" + "etc" + "grammar" + "llvm-project" + "llvm-emscripten" + "rtstartup" + "rustllvm" + "test" + "vendor" + ] + ++ lib.optionals minimalContent [ + "tools" + "stdarch" + ] + ) + }} '' diff --git a/pkgs/development/compilers/rust/rustc.nix b/pkgs/development/compilers/rust/rustc.nix index 0e999407c9d06a..2641755a86d463 100644 --- a/pkgs/development/compilers/rust/rustc.nix +++ b/pkgs/development/compilers/rust/rustc.nix @@ -1,32 +1,60 @@ -{ lib, stdenv, removeReferencesTo, pkgsBuildBuild, pkgsBuildHost, pkgsBuildTarget, targetPackages -, llvmShared, llvmSharedForBuild, llvmSharedForHost, llvmSharedForTarget, llvmPackages -, runCommandLocal, fetchurl, file, python3 -, darwin, cargo, cmake, rustc, rustfmt -, pkg-config, openssl, xz, zlib -, bintools -, libiconv -, which, libffi -, withBundledLLVM ? false -, enableRustcDev ? true -, version -, sha256 -, patches ? [] -, fd -, ripgrep -, wezterm -, firefox -, thunderbird -# This only builds std for target and reuses the rustc from build. -, fastCross -, lndir -, makeWrapper +{ + lib, + stdenv, + removeReferencesTo, + pkgsBuildBuild, + pkgsBuildHost, + pkgsBuildTarget, + targetPackages, + llvmShared, + llvmSharedForBuild, + llvmSharedForHost, + llvmSharedForTarget, + llvmPackages, + runCommandLocal, + fetchurl, + file, + python3, + darwin, + cargo, + cmake, + rustc, + rustfmt, + pkg-config, + openssl, + xz, + zlib, + bintools, + libiconv, + which, + libffi, + withBundledLLVM ? false, + enableRustcDev ? true, + version, + sha256, + patches ? [ ], + fd, + ripgrep, + wezterm, + firefox, + thunderbird, + # This only builds std for target and reuses the rustc from build. + fastCross, + lndir, + makeWrapper, }: let - inherit (lib) optionals optional optionalString concatStringsSep; + inherit (lib) + optionals + optional + optionalString + concatStringsSep + ; inherit (darwin.apple_sdk.frameworks) Security; useLLVM = stdenv.targetPlatform.useLLVM or false; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "${targetPackages.stdenv.cc.targetPrefix}rustc"; inherit version; @@ -61,20 +89,24 @@ in stdenv.mkDerivation (finalAttrs: { # but it does support checking these idiosyncratic PKG_CONFIG_${TRIPLE} # environment variables. # [1]: https://github.com/rust-lang/pkg-config-rs/issues/53 - "PKG_CONFIG_${builtins.replaceStrings ["-"] ["_"] stdenv.buildPlatform.rust.rustcTarget}" = + "PKG_CONFIG_${builtins.replaceStrings [ "-" ] [ "_" ] stdenv.buildPlatform.rust.rustcTarget}" = "${pkgsBuildHost.stdenv.cc.targetPrefix}pkg-config"; NIX_LDFLAGS = toString ( - # when linking stage1 libstd: cc: undefined reference to `__cxa_begin_catch' - # This doesn't apply to cross-building for FreeBSD because the host - # uses libstdc++, but the target (used for building std) uses libc++ - optional (stdenv.hostPlatform.isLinux && !withBundledLLVM && !stdenv.targetPlatform.isFreeBSD && !useLLVM) - "--push-state --as-needed -lstdc++ --pop-state" - ++ optional (stdenv.hostPlatform.isLinux && !withBundledLLVM && !stdenv.targetPlatform.isFreeBSD && useLLVM) + # when linking stage1 libstd: cc: undefined reference to `__cxa_begin_catch' + # This doesn't apply to cross-building for FreeBSD because the host + # uses libstdc++, but the target (used for building std) uses libc++ + optional ( + stdenv.hostPlatform.isLinux && !withBundledLLVM && !stdenv.targetPlatform.isFreeBSD && !useLLVM + ) "--push-state --as-needed -lstdc++ --pop-state" + ++ + optional + (stdenv.hostPlatform.isLinux && !withBundledLLVM && !stdenv.targetPlatform.isFreeBSD && useLLVM) "--push-state --as-needed -L${llvmPackages.libcxx}/lib -lc++ -lc++abi -lLLVM-${lib.versions.major llvmPackages.llvm.version} --pop-state" ++ optional (stdenv.hostPlatform.isDarwin && !withBundledLLVM) "-lc++ -lc++abi" ++ optional stdenv.hostPlatform.isFreeBSD "-rpath ${llvmPackages.libunwind}/lib" - ++ optional stdenv.hostPlatform.isDarwin "-rpath ${llvmSharedForHost.lib}/lib"); + ++ optional stdenv.hostPlatform.isDarwin "-rpath ${llvmSharedForHost.lib}/lib" + ); # Increase codegen units to introduce parallelism within the compiler. RUSTFLAGS = "-Ccodegen-units=10"; @@ -82,105 +114,129 @@ in stdenv.mkDerivation (finalAttrs: { # We need rust to build rust. If we don't provide it, configure will try to download it. # Reference: https://github.com/rust-lang/rust/blob/master/src/bootstrap/configure.py - configureFlags = let - prefixForStdenv = stdenv: "${stdenv.cc}/bin/${stdenv.cc.targetPrefix}"; - ccPrefixForStdenv = stdenv: "${prefixForStdenv stdenv}${if (stdenv.cc.isClang or false) then "clang" else "cc"}"; - cxxPrefixForStdenv = stdenv: "${prefixForStdenv stdenv}${if (stdenv.cc.isClang or false) then "clang++" else "c++"}"; - setBuild = "--set=target.${stdenv.buildPlatform.rust.rustcTarget}"; - setHost = "--set=target.${stdenv.hostPlatform.rust.rustcTarget}"; - setTarget = "--set=target.${stdenv.targetPlatform.rust.rustcTarget}"; - ccForBuild = ccPrefixForStdenv pkgsBuildBuild.targetPackages.stdenv; - cxxForBuild = cxxPrefixForStdenv pkgsBuildBuild.targetPackages.stdenv; - ccForHost = ccPrefixForStdenv pkgsBuildHost.targetPackages.stdenv; - cxxForHost = cxxPrefixForStdenv pkgsBuildHost.targetPackages.stdenv; - ccForTarget = ccPrefixForStdenv pkgsBuildTarget.targetPackages.stdenv; - cxxForTarget = cxxPrefixForStdenv pkgsBuildTarget.targetPackages.stdenv; - in [ - "--sysconfdir=${placeholder "out"}/etc" - "--release-channel=stable" - "--set=build.rustc=${rustc}/bin/rustc" - "--set=build.cargo=${cargo}/bin/cargo" - ] ++ lib.optionals (!(finalAttrs.src.passthru.isReleaseTarball or false)) [ - # release tarballs vendor the rustfmt source; when - # git-bisect'ing from upstream's git repo we must prevent - # attempts to download the missing source tarball - "--set=build.rustfmt=${rustfmt}/bin/rustfmt" - ] ++ [ - "--tools=rustc,rustdoc,rust-analyzer-proc-macro-srv" - "--enable-rpath" - "--enable-vendor" - # For Nixpkgs it makes more sense to use stdenv's linker than - # letting rustc build its own. - "--disable-lld" - "--build=${stdenv.buildPlatform.rust.rustcTargetSpec}" - "--host=${stdenv.hostPlatform.rust.rustcTargetSpec}" - # std is built for all platforms in --target. - "--target=${concatStringsSep "," ([ - stdenv.targetPlatform.rust.rustcTargetSpec - - # Other targets that don't need any extra dependencies to build. - ] ++ optionals (!fastCross) [ - "wasm32-unknown-unknown" - - # (build!=target): When cross-building a compiler we need to add - # the build platform as well so rustc can compile build.rs - # scripts. - ] ++ optionals (stdenv.buildPlatform != stdenv.targetPlatform && !fastCross) [ - stdenv.buildPlatform.rust.rustcTargetSpec - - # (host!=target): When building a cross-targeting compiler we - # need to add the host platform as well so rustc can compile - # build.rs scripts. - ] ++ optionals (stdenv.hostPlatform != stdenv.targetPlatform && !fastCross) [ - stdenv.hostPlatform.rust.rustcTargetSpec - ])}" - - "${setBuild}.cc=${ccForBuild}" - "${setHost}.cc=${ccForHost}" - "${setTarget}.cc=${ccForTarget}" - - "${setBuild}.linker=${ccForBuild}" - "${setHost}.linker=${ccForHost}" - "${setTarget}.linker=${ccForTarget}" - - "${setBuild}.cxx=${cxxForBuild}" - "${setHost}.cxx=${cxxForHost}" - "${setTarget}.cxx=${cxxForTarget}" - - "${setBuild}.crt-static=${lib.boolToString stdenv.buildPlatform.isStatic}" - "${setHost}.crt-static=${lib.boolToString stdenv.hostPlatform.isStatic}" - "${setTarget}.crt-static=${lib.boolToString stdenv.targetPlatform.isStatic}" - ] ++ optionals (!withBundledLLVM) [ - "--enable-llvm-link-shared" - "${setBuild}.llvm-config=${llvmSharedForBuild.dev}/bin/llvm-config" - "${setHost}.llvm-config=${llvmSharedForHost.dev}/bin/llvm-config" - "${setTarget}.llvm-config=${llvmSharedForTarget.dev}/bin/llvm-config" - ] ++ optionals fastCross [ - # Since fastCross only builds std, it doesn't make sense (and - # doesn't work) to build a linker. - "--disable-llvm-bitcode-linker" - ] ++ optionals (stdenv.targetPlatform.isLinux && !(stdenv.targetPlatform.useLLVM or false)) [ - "--enable-profiler" # build libprofiler_builtins - ] ++ optionals stdenv.buildPlatform.isMusl [ - "${setBuild}.musl-root=${pkgsBuildBuild.targetPackages.stdenv.cc.libc}" - ] ++ optionals stdenv.hostPlatform.isMusl [ - "${setHost}.musl-root=${pkgsBuildHost.targetPackages.stdenv.cc.libc}" - ] ++ optionals stdenv.targetPlatform.isMusl [ - "${setTarget}.musl-root=${pkgsBuildTarget.targetPackages.stdenv.cc.libc}" - ] ++ optionals stdenv.targetPlatform.rust.isNoStdTarget [ - "--disable-docs" - ] ++ optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ - # https://github.com/rust-lang/rust/issues/92173 - "--set rust.jemalloc" - ] ++ optionals (useLLVM && !stdenv.targetPlatform.isFreeBSD) [ - # https://github.com/NixOS/nixpkgs/issues/311930 - "--llvm-libunwind=${if withBundledLLVM then "in-tree" else "system"}" - "--enable-use-libcxx" - ]; + configureFlags = + let + prefixForStdenv = stdenv: "${stdenv.cc}/bin/${stdenv.cc.targetPrefix}"; + ccPrefixForStdenv = + stdenv: "${prefixForStdenv stdenv}${if (stdenv.cc.isClang or false) then "clang" else "cc"}"; + cxxPrefixForStdenv = + stdenv: "${prefixForStdenv stdenv}${if (stdenv.cc.isClang or false) then "clang++" else "c++"}"; + setBuild = "--set=target.${stdenv.buildPlatform.rust.rustcTarget}"; + setHost = "--set=target.${stdenv.hostPlatform.rust.rustcTarget}"; + setTarget = "--set=target.${stdenv.targetPlatform.rust.rustcTarget}"; + ccForBuild = ccPrefixForStdenv pkgsBuildBuild.targetPackages.stdenv; + cxxForBuild = cxxPrefixForStdenv pkgsBuildBuild.targetPackages.stdenv; + ccForHost = ccPrefixForStdenv pkgsBuildHost.targetPackages.stdenv; + cxxForHost = cxxPrefixForStdenv pkgsBuildHost.targetPackages.stdenv; + ccForTarget = ccPrefixForStdenv pkgsBuildTarget.targetPackages.stdenv; + cxxForTarget = cxxPrefixForStdenv pkgsBuildTarget.targetPackages.stdenv; + in + [ + "--sysconfdir=${placeholder "out"}/etc" + "--release-channel=stable" + "--set=build.rustc=${rustc}/bin/rustc" + "--set=build.cargo=${cargo}/bin/cargo" + ] + ++ lib.optionals (!(finalAttrs.src.passthru.isReleaseTarball or false)) [ + # release tarballs vendor the rustfmt source; when + # git-bisect'ing from upstream's git repo we must prevent + # attempts to download the missing source tarball + "--set=build.rustfmt=${rustfmt}/bin/rustfmt" + ] + ++ [ + "--tools=rustc,rustdoc,rust-analyzer-proc-macro-srv" + "--enable-rpath" + "--enable-vendor" + # For Nixpkgs it makes more sense to use stdenv's linker than + # letting rustc build its own. + "--disable-lld" + "--build=${stdenv.buildPlatform.rust.rustcTargetSpec}" + "--host=${stdenv.hostPlatform.rust.rustcTargetSpec}" + # std is built for all platforms in --target. + "--target=${ + concatStringsSep "," ( + [ + stdenv.targetPlatform.rust.rustcTargetSpec + + # Other targets that don't need any extra dependencies to build. + ] + ++ optionals (!fastCross) [ + "wasm32-unknown-unknown" + + # (build!=target): When cross-building a compiler we need to add + # the build platform as well so rustc can compile build.rs + # scripts. + ] + ++ optionals (stdenv.buildPlatform != stdenv.targetPlatform && !fastCross) [ + stdenv.buildPlatform.rust.rustcTargetSpec + + # (host!=target): When building a cross-targeting compiler we + # need to add the host platform as well so rustc can compile + # build.rs scripts. + ] + ++ optionals (stdenv.hostPlatform != stdenv.targetPlatform && !fastCross) [ + stdenv.hostPlatform.rust.rustcTargetSpec + ] + ) + }" + + "${setBuild}.cc=${ccForBuild}" + "${setHost}.cc=${ccForHost}" + "${setTarget}.cc=${ccForTarget}" + + "${setBuild}.linker=${ccForBuild}" + "${setHost}.linker=${ccForHost}" + "${setTarget}.linker=${ccForTarget}" + + "${setBuild}.cxx=${cxxForBuild}" + "${setHost}.cxx=${cxxForHost}" + "${setTarget}.cxx=${cxxForTarget}" + + "${setBuild}.crt-static=${lib.boolToString stdenv.buildPlatform.isStatic}" + "${setHost}.crt-static=${lib.boolToString stdenv.hostPlatform.isStatic}" + "${setTarget}.crt-static=${lib.boolToString stdenv.targetPlatform.isStatic}" + ] + ++ optionals (!withBundledLLVM) [ + "--enable-llvm-link-shared" + "${setBuild}.llvm-config=${llvmSharedForBuild.dev}/bin/llvm-config" + "${setHost}.llvm-config=${llvmSharedForHost.dev}/bin/llvm-config" + "${setTarget}.llvm-config=${llvmSharedForTarget.dev}/bin/llvm-config" + ] + ++ optionals fastCross [ + # Since fastCross only builds std, it doesn't make sense (and + # doesn't work) to build a linker. + "--disable-llvm-bitcode-linker" + ] + ++ optionals (stdenv.targetPlatform.isLinux && !(stdenv.targetPlatform.useLLVM or false)) [ + "--enable-profiler" # build libprofiler_builtins + ] + ++ optionals stdenv.buildPlatform.isMusl [ + "${setBuild}.musl-root=${pkgsBuildBuild.targetPackages.stdenv.cc.libc}" + ] + ++ optionals stdenv.hostPlatform.isMusl [ + "${setHost}.musl-root=${pkgsBuildHost.targetPackages.stdenv.cc.libc}" + ] + ++ optionals stdenv.targetPlatform.isMusl [ + "${setTarget}.musl-root=${pkgsBuildTarget.targetPackages.stdenv.cc.libc}" + ] + ++ optionals stdenv.targetPlatform.rust.isNoStdTarget [ + "--disable-docs" + ] + ++ optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + # https://github.com/rust-lang/rust/issues/92173 + "--set rust.jemalloc" + ] + ++ optionals (useLLVM && !stdenv.targetPlatform.isFreeBSD) [ + # https://github.com/NixOS/nixpkgs/issues/311930 + "--llvm-libunwind=${if withBundledLLVM then "in-tree" else "system"}" + "--enable-use-libcxx" + ]; # if we already have a rust compiler for build just compile the target std # library and reuse compiler - buildPhase = if fastCross then " + buildPhase = + if fastCross then + " runHook preBuild mkdir -p build/${stdenv.hostPlatform.rust.rustcTargetSpec}/stage0-{std,rustc}/${stdenv.hostPlatform.rust.rustcTargetSpec}/release/ @@ -192,110 +248,145 @@ in stdenv.mkDerivation (finalAttrs: { python ./x.py --keep-stage=0 --stage=1 build library runHook postBuild - " else null; - - installPhase = if fastCross then '' - runHook preInstall - - python ./x.py --keep-stage=0 --stage=1 install library/std - mkdir -v $out/bin $doc $man - ln -s ${rustc.unwrapped}/bin/{rustc,rustdoc} $out/bin - rm -rf -v $out/lib/rustlib/{manifest-rust-std-,}${stdenv.hostPlatform.rust.rustcTargetSpec} - ln -s ${rustc.unwrapped}/lib/rustlib/{manifest-rust-std-,}${stdenv.hostPlatform.rust.rustcTargetSpec} $out/lib/rustlib/ - echo rust-std-${stdenv.hostPlatform.rust.rustcTargetSpec} >> $out/lib/rustlib/components - lndir ${rustc.doc} $doc - lndir ${rustc.man} $man - - runHook postInstall - '' else null; + " + else + null; + + installPhase = + if fastCross then + '' + runHook preInstall + + python ./x.py --keep-stage=0 --stage=1 install library/std + mkdir -v $out/bin $doc $man + ln -s ${rustc.unwrapped}/bin/{rustc,rustdoc} $out/bin + rm -rf -v $out/lib/rustlib/{manifest-rust-std-,}${stdenv.hostPlatform.rust.rustcTargetSpec} + ln -s ${rustc.unwrapped}/lib/rustlib/{manifest-rust-std-,}${stdenv.hostPlatform.rust.rustcTargetSpec} $out/lib/rustlib/ + echo rust-std-${stdenv.hostPlatform.rust.rustcTargetSpec} >> $out/lib/rustlib/components + lndir ${rustc.doc} $doc + lndir ${rustc.man} $man + + runHook postInstall + '' + else + null; # the rust build system complains that nix alters the checksums dontFixLibtool = true; inherit patches; - postPatch = '' - patchShebangs src/etc - - # rust-lld is the name rustup uses for its bundled lld, so that it - # doesn't conflict with any system lld. This is not an - # appropriate default for Nixpkgs, where there is no rust-lld. - substituteInPlace compiler/rustc_target/src/spec/*/*.rs \ - --replace-quiet '"rust-lld"' '"lld"' - - ${optionalString (!withBundledLLVM) "rm -rf src/llvm"} - - # Useful debugging parameter - # export VERBOSE=1 - '' + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) '' - # See https://github.com/jemalloc/jemalloc/issues/1997 - # Using a value of 48 should work on both emulated and native x86_64-darwin. - export JEMALLOC_SYS_WITH_LG_VADDR=48 - '' + lib.optionalString (!(finalAttrs.src.passthru.isReleaseTarball or false)) '' - mkdir .cargo - cat > .cargo/config.toml <<\EOF - [source.crates-io] - replace-with = "vendored-sources" - [source.vendored-sources] - directory = "vendor" - EOF - '' + lib.optionalString (stdenv.hostPlatform.isFreeBSD) '' - # lzma-sys bundles an old version of xz that doesn't build - # on modern FreeBSD, use the system one instead - substituteInPlace src/bootstrap/src/core/build_steps/tool.rs \ - --replace 'cargo.env("LZMA_API_STATIC", "1");' ' ' - ''; + postPatch = + '' + patchShebangs src/etc + + # rust-lld is the name rustup uses for its bundled lld, so that it + # doesn't conflict with any system lld. This is not an + # appropriate default for Nixpkgs, where there is no rust-lld. + substituteInPlace compiler/rustc_target/src/spec/*/*.rs \ + --replace-quiet '"rust-lld"' '"lld"' + + ${optionalString (!withBundledLLVM) "rm -rf src/llvm"} + + # Useful debugging parameter + # export VERBOSE=1 + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) '' + # See https://github.com/jemalloc/jemalloc/issues/1997 + # Using a value of 48 should work on both emulated and native x86_64-darwin. + export JEMALLOC_SYS_WITH_LG_VADDR=48 + '' + + lib.optionalString (!(finalAttrs.src.passthru.isReleaseTarball or false)) '' + mkdir .cargo + cat > .cargo/config.toml <<\EOF + [source.crates-io] + replace-with = "vendored-sources" + [source.vendored-sources] + directory = "vendor" + EOF + '' + + lib.optionalString (stdenv.hostPlatform.isFreeBSD) '' + # lzma-sys bundles an old version of xz that doesn't build + # on modern FreeBSD, use the system one instead + substituteInPlace src/bootstrap/src/core/build_steps/tool.rs \ + --replace 'cargo.env("LZMA_API_STATIC", "1");' ' ' + ''; # rustc unfortunately needs cmake to compile llvm-rt but doesn't # use it for the normal build. This disables cmake in Nix. dontUseCmakeConfigure = true; - depsBuildBuild = [ pkgsBuildHost.stdenv.cc pkg-config ]; + depsBuildBuild = [ + pkgsBuildHost.stdenv.cc + pkg-config + ]; depsBuildTarget = lib.optionals stdenv.targetPlatform.isMinGW [ bintools ]; - nativeBuildInputs = [ - file python3 rustc cmake - which libffi removeReferencesTo pkg-config xz - ] - ++ optionals fastCross [ lndir makeWrapper ]; + nativeBuildInputs = + [ + file + python3 + rustc + cmake + which + libffi + removeReferencesTo + pkg-config + xz + ] + ++ optionals fastCross [ + lndir + makeWrapper + ]; - buildInputs = [ openssl ] - ++ optionals stdenv.hostPlatform.isDarwin [ libiconv Security zlib ] + buildInputs = + [ openssl ] + ++ optionals stdenv.hostPlatform.isDarwin [ + libiconv + Security + zlib + ] ++ optional (!withBundledLLVM) llvmShared.lib ++ optional (useLLVM && !withBundledLLVM && !stdenv.targetPlatform.isFreeBSD) [ llvmPackages.libunwind # Hack which is used upstream https://github.com/gentoo/gentoo/blob/master/dev-lang/rust/rust-1.78.0.ebuild#L284 - (runCommandLocal "libunwind-libgcc" {} '' + (runCommandLocal "libunwind-libgcc" { } '' mkdir -p $out/lib ln -s ${llvmPackages.libunwind}/lib/libunwind.so $out/lib/libgcc_s.so ln -s ${llvmPackages.libunwind}/lib/libunwind.so $out/lib/libgcc_s.so.1 '') ]; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; setOutputFlags = false; - postInstall = lib.optionalString (enableRustcDev && !fastCross) '' - # install rustc-dev components. Necessary to build rls, clippy... - python x.py dist rustc-dev - tar xf build/dist/rustc-dev*tar.gz - cp -r rustc-dev*/rustc-dev*/lib/* $out/lib/ - rm $out/lib/rustlib/install.log - for m in $out/lib/rustlib/manifest-rust* - do - sort --output=$m < $m - done - - '' + '' - # remove references to llvm-config in lib/rustlib/x86_64-unknown-linux-gnu/codegen-backends/librustc_codegen_llvm-llvm.so - # and thus a transitive dependency on ncurses - find $out/lib -name "*.so" -type f -exec remove-references-to -t ${llvmShared} '{}' '+' - - # remove uninstall script that doesn't really make sense for Nix. - rm $out/lib/rustlib/uninstall.sh - ''; - - configurePlatforms = []; + postInstall = + lib.optionalString (enableRustcDev && !fastCross) '' + # install rustc-dev components. Necessary to build rls, clippy... + python x.py dist rustc-dev + tar xf build/dist/rustc-dev*tar.gz + cp -r rustc-dev*/rustc-dev*/lib/* $out/lib/ + rm $out/lib/rustlib/install.log + for m in $out/lib/rustlib/manifest-rust* + do + sort --output=$m < $m + done + + '' + + '' + # remove references to llvm-config in lib/rustlib/x86_64-unknown-linux-gnu/codegen-backends/librustc_codegen_llvm-llvm.so + # and thus a transitive dependency on ncurses + find $out/lib -name "*.so" -type f -exec remove-references-to -t ${llvmShared} '{}' '+' + + # remove uninstall script that doesn't really make sense for Nix. + rm $out/lib/rustlib/uninstall.sh + ''; + + configurePlatforms = [ ]; enableParallelBuilding = true; @@ -316,7 +407,10 @@ in stdenv.mkDerivation (finalAttrs: { homepage = "https://www.rust-lang.org/"; description = "Safe, concurrent, practical language"; maintainers = with maintainers; [ havvy ] ++ teams.rust.members; - license = [ licenses.mit licenses.asl20 ]; + license = [ + licenses.mit + licenses.asl20 + ]; platforms = rustc.tier1TargetPlatforms; # If rustc can't target a platform, we also can't build rustc for # that platform. diff --git a/pkgs/development/compilers/rust/rustfmt.nix b/pkgs/development/compilers/rust/rustfmt.nix index 42c71513151a6f..05ead37f67d3e2 100644 --- a/pkgs/development/compilers/rust/rustfmt.nix +++ b/pkgs/development/compilers/rust/rustfmt.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, rustPlatform, rustc, Security, asNightly ? false }: +{ + lib, + stdenv, + rustPlatform, + rustc, + Security, + asNightly ? false, +}: rustPlatform.buildRustPackage rec { pname = "rustfmt" + lib.optionalString asNightly "-nightly"; @@ -37,8 +44,14 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Tool for formatting Rust code according to style guidelines"; homepage = "https://github.com/rust-lang-nursery/rustfmt"; - license = with licenses; [ mit asl20 ]; + license = with licenses; [ + mit + asl20 + ]; mainProgram = "rustfmt"; - maintainers = with maintainers; [ globin basvandijk ]; + maintainers = with maintainers; [ + globin + basvandijk + ]; }; } diff --git a/pkgs/development/compilers/sbcl/bootstrap.nix b/pkgs/development/compilers/sbcl/bootstrap.nix index 6f9b75c1183c43..c60a5e135f6bb9 100644 --- a/pkgs/development/compilers/sbcl/bootstrap.nix +++ b/pkgs/development/compilers/sbcl/bootstrap.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, makeWrapper, cfg }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + cfg, +}: stdenv.mkDerivation rec { pname = "sbcl-bootstrap"; diff --git a/pkgs/development/compilers/scala-runners/default.nix b/pkgs/development/compilers/scala-runners/default.nix index bc0756e0c11cec..9bdf63cdaf4475 100644 --- a/pkgs/development/compilers/scala-runners/default.nix +++ b/pkgs/development/compilers/scala-runners/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, coursier }: +{ + stdenv, + lib, + fetchFromGitHub, + coursier, +}: stdenv.mkDerivation rec { pname = "scala-runners"; diff --git a/pkgs/development/compilers/scala/2.x.nix b/pkgs/development/compilers/scala/2.x.nix index d79e946ec7dec4..0ed9ccb5cc0168 100644 --- a/pkgs/development/compilers/scala/2.x.nix +++ b/pkgs/development/compilers/scala/2.x.nix @@ -1,5 +1,19 @@ -{ stdenv, lib, fetchurl, makeWrapper, jre, gnugrep, coreutils, writeScript -, common-updater-scripts, git, gnused, nix, nixfmt-classic, majorVersion }: +{ + stdenv, + lib, + fetchurl, + makeWrapper, + jre, + gnugrep, + coreutils, + writeScript, + common-updater-scripts, + git, + gnused, + nix, + nixfmt-classic, + majorVersion, +}: let repo = "git@github.com:scala/scala.git"; @@ -30,7 +44,8 @@ let }; }; -in with versionMap.${majorVersion}; +in +with versionMap.${majorVersion}; stdenv.mkDerivation rec { inherit version; @@ -114,6 +129,9 @@ stdenv.mkDerivation rec { license = licenses.bsd3; platforms = platforms.all; branch = versions.majorMinor version; - maintainers = with maintainers; [ nequissimus kashw2 ]; + maintainers = with maintainers; [ + nequissimus + kashw2 + ]; }; } diff --git a/pkgs/development/compilers/semeru-bin/jdk-darwin-base.nix b/pkgs/development/compilers/semeru-bin/jdk-darwin-base.nix index ccbc7d871e8a42..323918d5327e6c 100644 --- a/pkgs/development/compilers/semeru-bin/jdk-darwin-base.nix +++ b/pkgs/development/compilers/semeru-bin/jdk-darwin-base.nix @@ -1,5 +1,8 @@ args: -import ../temurin-bin/jdk-darwin-base.nix ({ - name-prefix = "semeru"; - brand-name = "IBM Semeru Runtime"; -} // args) +import ../temurin-bin/jdk-darwin-base.nix ( + { + name-prefix = "semeru"; + brand-name = "IBM Semeru Runtime"; + } + // args +) diff --git a/pkgs/development/compilers/semeru-bin/jdk-darwin.nix b/pkgs/development/compilers/semeru-bin/jdk-darwin.nix index 0f6e9ca002f8b0..e496be7e47edc0 100644 --- a/pkgs/development/compilers/semeru-bin/jdk-darwin.nix +++ b/pkgs/development/compilers/semeru-bin/jdk-darwin.nix @@ -2,10 +2,10 @@ let sources = (lib.importJSON ./sources.json).openj9.mac; - common = opts: callPackage (import ./jdk-darwin-base.nix opts) {}; + common = opts: callPackage (import ./jdk-darwin-base.nix opts) { }; - # EOL = [ "This JDK/JRE version has reached End of Life." ]; in +# EOL = [ "This JDK/JRE version has reached End of Life." ]; { jdk-8 = common { sourcePerArch = sources.jdk.openjdk8; }; jre-8 = common { sourcePerArch = sources.jre.openjdk8; }; diff --git a/pkgs/development/compilers/semeru-bin/jdk-linux-base.nix b/pkgs/development/compilers/semeru-bin/jdk-linux-base.nix index 41879ea8868175..2eff1578fc31c3 100644 --- a/pkgs/development/compilers/semeru-bin/jdk-linux-base.nix +++ b/pkgs/development/compilers/semeru-bin/jdk-linux-base.nix @@ -1,5 +1,8 @@ args: -import ../temurin-bin/jdk-linux-base.nix ({ - name-prefix = "semeru"; - brand-name = "IBM Semeru Runtime"; -} // args) +import ../temurin-bin/jdk-linux-base.nix ( + { + name-prefix = "semeru"; + brand-name = "IBM Semeru Runtime"; + } + // args +) diff --git a/pkgs/development/compilers/semeru-bin/jdk-linux.nix b/pkgs/development/compilers/semeru-bin/jdk-linux.nix index 16f14de26209e9..8044e7de8c6ee4 100644 --- a/pkgs/development/compilers/semeru-bin/jdk-linux.nix +++ b/pkgs/development/compilers/semeru-bin/jdk-linux.nix @@ -2,10 +2,10 @@ let sources = (lib.importJSON ./sources.json).openj9.linux; - common = opts: callPackage (import ./jdk-linux-base.nix opts) {}; + common = opts: callPackage (import ./jdk-linux-base.nix opts) { }; - # EOL = [ "This JDK/JRE version has reached End of Life." ]; in +# EOL = [ "This JDK/JRE version has reached End of Life." ]; { jdk-8 = common { sourcePerArch = sources.jdk.openjdk8; }; jre-8 = common { sourcePerArch = sources.jre.openjdk8; }; diff --git a/pkgs/development/compilers/shaderc/default.nix b/pkgs/development/compilers/shaderc/default.nix index 97c50cde91e780..cbbb42b62cfc5d 100644 --- a/pkgs/development/compilers/shaderc/default.nix +++ b/pkgs/development/compilers/shaderc/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, python3, autoSignDarwinBinariesHook, cctools }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, + autoSignDarwinBinariesHook, + cctools, +}: # Like many google projects, shaderc doesn't gracefully support separately compiled dependencies, so we can't easily use # the versions of glslang and spirv-tools used by vulkan-loader. Exact revisions are taken from # https://github.com/google/shaderc/blob/known-good/known_good.json @@ -28,7 +36,13 @@ stdenv.mkDerivation rec { pname = "shaderc"; version = "2024.0"; - outputs = [ "out" "lib" "bin" "dev" "static" ]; + outputs = [ + "out" + "lib" + "bin" + "dev" + "static" + ]; src = fetchFromGitHub { owner = "google"; @@ -44,9 +58,15 @@ stdenv.mkDerivation rec { patchShebangs --build utils/ ''; - nativeBuildInputs = [ cmake python3 ] + nativeBuildInputs = + [ + cmake + python3 + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools ] - ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ autoSignDarwinBinariesHook ]; + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + autoSignDarwinBinariesHook + ]; postInstall = '' moveToOutput "lib/*.a" $static diff --git a/pkgs/development/compilers/smlnj/bootstrap.nix b/pkgs/development/compilers/smlnj/bootstrap.nix index 6aba529a8fce01..ec9db0755fdc4a 100644 --- a/pkgs/development/compilers/smlnj/bootstrap.nix +++ b/pkgs/development/compilers/smlnj/bootstrap.nix @@ -2,7 +2,15 @@ # and is preserved only for pre-existing direct usage. New use cases should # just use the regular smlnj derivation. -{ lib, stdenv, fetchurl, cpio, rsync, xar, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + cpio, + rsync, + xar, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "smlnj-bootstrap"; @@ -15,7 +23,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ cpio rsync ]; + buildInputs = [ + cpio + rsync + ]; unpackPhase = '' ${xar}/bin/xar -xf $src @@ -40,9 +51,9 @@ stdenv.mkDerivation rec { meta = { description = "Compiler for the Standard ML '97 programming language"; - homepage = "http://www.smlnj.org"; - license = lib.licenses.free; - platforms = lib.platforms.darwin; + homepage = "http://www.smlnj.org"; + license = lib.licenses.free; + platforms = lib.platforms.darwin; maintainers = [ lib.maintainers.jwiegley ]; mainProgram = "sml"; }; diff --git a/pkgs/development/compilers/smlnj/default.nix b/pkgs/development/compilers/smlnj/default.nix index 718415a5eabd1d..c7322d9ef99e55 100644 --- a/pkgs/development/compilers/smlnj/default.nix +++ b/pkgs/development/compilers/smlnj/default.nix @@ -1,47 +1,119 @@ -{ lib, stdenv, fetchurl, Libsystem }: +{ + lib, + stdenv, + fetchurl, + Libsystem, +}: let version = "110.99.6.1"; baseurl = "http://smlnj.cs.uchicago.edu/dist/working/${version}"; - arch = if stdenv.hostPlatform.is64bit - then "64" - else "32"; + arch = if stdenv.hostPlatform.is64bit then "64" else "32"; - boot32 = { url = "${baseurl}/boot.x86-unix.tgz"; - hash = "sha256-2yBY0wGZ8B1jYC5os9SfH6eKJoWlQ4rAclBC3Pnacoc="; }; - boot64 = { url = "${baseurl}/boot.amd64-unix.tgz"; - hash = "sha256-kUabK03MdSYVRWhWKl3kS32SExUYpM3MtLU0mCxhiaQ="; }; + boot32 = { + url = "${baseurl}/boot.x86-unix.tgz"; + hash = "sha256-2yBY0wGZ8B1jYC5os9SfH6eKJoWlQ4rAclBC3Pnacoc="; + }; + boot64 = { + url = "${baseurl}/boot.amd64-unix.tgz"; + hash = "sha256-kUabK03MdSYVRWhWKl3kS32SExUYpM3MtLU0mCxhiaQ="; + }; - bootBinary = if stdenv.hostPlatform.is64bit - then boot64 - else boot32; + bootBinary = if stdenv.hostPlatform.is64bit then boot64 else boot32; sources = map fetchurl [ bootBinary - { url = "${baseurl}/config.tgz"; hash = "sha256-9BJPpa/xouqi3j39WsfzlRys4z1yxTdbYttHF5VwCVw="; } - { url = "${baseurl}/cm.tgz"; hash = "sha256-A3crC5EWX4kEB6olwdaObglQgkBBNqcBSCi/pQR5Wdw="; } - { url = "${baseurl}/compiler.tgz"; hash = "sha256-cTgkc5opaEXskdzt5yYsdjyF5m9846t2SyEiwY6W3HU="; } - { url = "${baseurl}/runtime.tgz"; hash = "sha256-JiNzfuZnp1eWQPNZBb9SPmQXtwgknpoGl+38iqUU3W4="; } - { url = "${baseurl}/system.tgz"; hash = "sha256-HUn8YCxlLe6+e5H9oMJjIoG23GBF3thMlHEkSGLZTus="; } - { url = "${baseurl}/MLRISC.tgz"; hash = "sha256-MPNpYhrbsIbVEOzJ7GIEQCm/7F/Jnxj0UXS7FeTp+7o="; } - { url = "${baseurl}/smlnj-lib.tgz"; hash = "sha256-1tp5waPl7MCWS4kIUFm/woQeeRfCjkpgSxHpGb+ymTM="; } - { url = "${baseurl}/old-basis.tgz"; hash = "sha256-I6DJRfIx+09ynFKXZ63dDWRpv0pEljWciAarK/EhQ/s="; } - { url = "${baseurl}/ckit.tgz"; hash = "sha256-vi6dSZISL+KWkpp/jxLPCNBno+qTYThvbExZ5R5L7Wc="; } - { url = "${baseurl}/nlffi.tgz"; hash = "sha256-WfYmX7dhrBqtE4juDVNyjuFtsJ1H+B7rJY2BXJYtKNM="; } - { url = "${baseurl}/cml.tgz"; hash = "sha256-5rZzp5IUj/xZX0fyeoNMohyTz1ifdY6Anu/Hg0spDQw="; } - { url = "${baseurl}/eXene.tgz"; hash = "sha256-c5QnjAQTtlBgYE6DGFMNDbu9ILSEVZgzs/u0bIowfHc="; } - { url = "${baseurl}/ml-lpt.tgz"; hash = "sha256-aRYFTEEl4td7LQ0LhsXGLtJ/ptwCDV1m9GeDtM7+vlo="; } - { url = "${baseurl}/ml-lex.tgz"; hash = "sha256-ZwO3xQUDaD2f7Tsro6kkahT7vSN1JvQbLkwY/m7xSIs="; } - { url = "${baseurl}/ml-yacc.tgz"; hash = "sha256-DBR4xmKiSA5on7+YDz7Zr8qBA6aD1fS64+g69ukSprc="; } - { url = "${baseurl}/ml-burg.tgz"; hash = "sha256-4ruWhGjxny97eUD9Gk4FakqEZzNHwJp7uSa97ET20p0="; } - { url = "${baseurl}/pgraph.tgz"; hash = "sha256-kDyaAMB6Pt3CdAna+V8aLfTx8Tj6a5vPfuSxtpga08w="; } - { url = "${baseurl}/trace-debug-profile.tgz"; hash = "sha256-AD9KWsskRkjTFYiRCIm0qj02sIBHG6HtBM5wKMBqeXY="; } - { url = "${baseurl}/heap2asm.tgz"; hash = "sha256-OHNPMErNoLpYuatgbgYlU/mMB4JXQ4aA50WZ2BHtt3I="; } - { url = "${baseurl}/smlnj-c.tgz"; hash = "sha256-Vure6h0TKqne5+5MJBX9cRkBgmrJ/kKVLUzrIIiH7lE="; } - { url = "${baseurl}/doc.tgz"; hash = "sha256-PliWxCffISPrAO7Zan33recFLRmGoqZLKHOzSEP0PEk="; } - { url = "${baseurl}/asdl.tgz"; hash = "sha256-O6/g20/hsMTG3CvMA59btjG+4UdUbGhMHkizESKJDEA="; } + { + url = "${baseurl}/config.tgz"; + hash = "sha256-9BJPpa/xouqi3j39WsfzlRys4z1yxTdbYttHF5VwCVw="; + } + { + url = "${baseurl}/cm.tgz"; + hash = "sha256-A3crC5EWX4kEB6olwdaObglQgkBBNqcBSCi/pQR5Wdw="; + } + { + url = "${baseurl}/compiler.tgz"; + hash = "sha256-cTgkc5opaEXskdzt5yYsdjyF5m9846t2SyEiwY6W3HU="; + } + { + url = "${baseurl}/runtime.tgz"; + hash = "sha256-JiNzfuZnp1eWQPNZBb9SPmQXtwgknpoGl+38iqUU3W4="; + } + { + url = "${baseurl}/system.tgz"; + hash = "sha256-HUn8YCxlLe6+e5H9oMJjIoG23GBF3thMlHEkSGLZTus="; + } + { + url = "${baseurl}/MLRISC.tgz"; + hash = "sha256-MPNpYhrbsIbVEOzJ7GIEQCm/7F/Jnxj0UXS7FeTp+7o="; + } + { + url = "${baseurl}/smlnj-lib.tgz"; + hash = "sha256-1tp5waPl7MCWS4kIUFm/woQeeRfCjkpgSxHpGb+ymTM="; + } + { + url = "${baseurl}/old-basis.tgz"; + hash = "sha256-I6DJRfIx+09ynFKXZ63dDWRpv0pEljWciAarK/EhQ/s="; + } + { + url = "${baseurl}/ckit.tgz"; + hash = "sha256-vi6dSZISL+KWkpp/jxLPCNBno+qTYThvbExZ5R5L7Wc="; + } + { + url = "${baseurl}/nlffi.tgz"; + hash = "sha256-WfYmX7dhrBqtE4juDVNyjuFtsJ1H+B7rJY2BXJYtKNM="; + } + { + url = "${baseurl}/cml.tgz"; + hash = "sha256-5rZzp5IUj/xZX0fyeoNMohyTz1ifdY6Anu/Hg0spDQw="; + } + { + url = "${baseurl}/eXene.tgz"; + hash = "sha256-c5QnjAQTtlBgYE6DGFMNDbu9ILSEVZgzs/u0bIowfHc="; + } + { + url = "${baseurl}/ml-lpt.tgz"; + hash = "sha256-aRYFTEEl4td7LQ0LhsXGLtJ/ptwCDV1m9GeDtM7+vlo="; + } + { + url = "${baseurl}/ml-lex.tgz"; + hash = "sha256-ZwO3xQUDaD2f7Tsro6kkahT7vSN1JvQbLkwY/m7xSIs="; + } + { + url = "${baseurl}/ml-yacc.tgz"; + hash = "sha256-DBR4xmKiSA5on7+YDz7Zr8qBA6aD1fS64+g69ukSprc="; + } + { + url = "${baseurl}/ml-burg.tgz"; + hash = "sha256-4ruWhGjxny97eUD9Gk4FakqEZzNHwJp7uSa97ET20p0="; + } + { + url = "${baseurl}/pgraph.tgz"; + hash = "sha256-kDyaAMB6Pt3CdAna+V8aLfTx8Tj6a5vPfuSxtpga08w="; + } + { + url = "${baseurl}/trace-debug-profile.tgz"; + hash = "sha256-AD9KWsskRkjTFYiRCIm0qj02sIBHG6HtBM5wKMBqeXY="; + } + { + url = "${baseurl}/heap2asm.tgz"; + hash = "sha256-OHNPMErNoLpYuatgbgYlU/mMB4JXQ4aA50WZ2BHtt3I="; + } + { + url = "${baseurl}/smlnj-c.tgz"; + hash = "sha256-Vure6h0TKqne5+5MJBX9cRkBgmrJ/kKVLUzrIIiH7lE="; + } + { + url = "${baseurl}/doc.tgz"; + hash = "sha256-PliWxCffISPrAO7Zan33recFLRmGoqZLKHOzSEP0PEk="; + } + { + url = "${baseurl}/asdl.tgz"; + hash = "sha256-O6/g20/hsMTG3CvMA59btjG+4UdUbGhMHkizESKJDEA="; + } ]; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "smlnj"; inherit version sources; @@ -55,14 +127,16 @@ in stdenv.mkDerivation { ./config/unpack $TMP runtime ''; - patchPhase = '' - sed -i '/^PATH=/d' config/_arch-n-opsys base/runtime/config/gen-posix-names.sh - echo SRCARCHIVEURL="file:/$TMP" > config/srcarchiveurl - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Locate standard headers like - substituteInPlace base/runtime/config/gen-posix-names.sh \ - --replace "\$SDK_PATH/usr" "${Libsystem}" - ''; + patchPhase = + '' + sed -i '/^PATH=/d' config/_arch-n-opsys base/runtime/config/gen-posix-names.sh + echo SRCARCHIVEURL="file:/$TMP" > config/srcarchiveurl + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Locate standard headers like + substituteInPlace base/runtime/config/gen-posix-names.sh \ + --replace "\$SDK_PATH/usr" "${Libsystem}" + ''; buildPhase = '' ./config/install.sh -default ${arch} @@ -80,10 +154,17 @@ in stdenv.mkDerivation { meta = { description = "Standard ML of New Jersey, a compiler"; - homepage = "http://smlnj.org"; - license = lib.licenses.bsd3; - platforms = [ "x86_64-linux" "i686-linux" "x86_64-darwin" ]; - maintainers = with lib.maintainers; [ skyesoss thoughtpolice ]; + homepage = "http://smlnj.org"; + license = lib.licenses.bsd3; + platforms = [ + "x86_64-linux" + "i686-linux" + "x86_64-darwin" + ]; + maintainers = with lib.maintainers; [ + skyesoss + thoughtpolice + ]; mainProgram = "sml"; # never built on x86_64-darwin since first introduction in nixpkgs broken = stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64; diff --git a/pkgs/development/compilers/squeak/default.nix b/pkgs/development/compilers/squeak/default.nix index d10a2cc2e5948c..9a72465115af01 100644 --- a/pkgs/development/compilers/squeak/default.nix +++ b/pkgs/development/compilers/squeak/default.nix @@ -1,36 +1,37 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchurl -, fetchzip -, autoconf -, automake -, autoreconfHook -, dos2unix -, file -, perl -, pkg-config -, alsa-lib -, coreutils -, freetype -, glib -, glibc -, gnugrep -, libGL -, libpulseaudio -, libtool -, libuuid -, openssl -, pango -, xorg -, squeakImageHash ? null -, squeakSourcesHash ? null -, squeakSourcesVersion ? null -, squeakVersion ? null -, squeakVmCommitHash ? null -, squeakVmCommitHashHash ? null -, squeakVmVersion ? null -} @ args: +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + fetchzip, + autoconf, + automake, + autoreconfHook, + dos2unix, + file, + perl, + pkg-config, + alsa-lib, + coreutils, + freetype, + glib, + glibc, + gnugrep, + libGL, + libpulseaudio, + libtool, + libuuid, + openssl, + pango, + xorg, + squeakImageHash ? null, + squeakSourcesHash ? null, + squeakSourcesVersion ? null, + squeakVersion ? null, + squeakVmCommitHash ? null, + squeakVmCommitHashHash ? null, + squeakVmVersion ? null, +}@args: let inherit (builtins) elemAt toString; @@ -61,10 +62,12 @@ let squeakVmCommitHash = nullableOr args.squeakVmCommitHash or null (fetchurl { url = "https://api.github.com/repos/OpenSmalltalk/opensmalltalk-vm/commits/${squeakVmVersionRelease}"; curlOpts = "--header Accept:application/vnd.github.v3.sha"; - hash = nullableOr args.squeakVmCommitHashHash or null - "sha256-quwmhpJlb2fp0fI9b03fBxSR44j1xmHPW20wkSqTOhQ="; + hash = + nullableOr args.squeakVmCommitHashHash or null + "sha256-quwmhpJlb2fp0fI9b03fBxSR44j1xmHPW20wkSqTOhQ="; }); -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "squeak"; version = squeakVersion; @@ -76,22 +79,25 @@ in stdenv.mkDerivation { owner = "OpenSmalltalk"; repo = "opensmalltalk-vm"; rev = squeakVmVersionRelease; - hash = nullableOr args.squeakVmHash or null - "sha256-rNJn5ya+7ggC21MpwSrl2ByJDjVycONKHADboH7dQLM="; - }; - imageSrc = let - squeakImageName = "Squeak${squeakVersionBase}-${squeakImageVersion}-${toString bits}bit"; - in fetchzip { - url = "https://files.squeak.org/${squeakVersionBase}/${squeakImageName}/${squeakImageName}.zip"; - name = "source"; - stripRoot = false; - hash = nullableOr args.squeakImageHash or null - "sha256-wDuRyc/DNqG1D4DzyBkUvrzFkBlXBtbpnANZlRV/Fas="; + hash = nullableOr args.squeakVmHash or null "sha256-rNJn5ya+7ggC21MpwSrl2ByJDjVycONKHADboH7dQLM="; }; + imageSrc = + let + squeakImageName = "Squeak${squeakVersionBase}-${squeakImageVersion}-${toString bits}bit"; + in + fetchzip { + url = "https://files.squeak.org/${squeakVersionBase}/${squeakImageName}/${squeakImageName}.zip"; + name = "source"; + stripRoot = false; + hash = + nullableOr args.squeakImageHash or null + "sha256-wDuRyc/DNqG1D4DzyBkUvrzFkBlXBtbpnANZlRV/Fas="; + }; sourcesSrc = fetchurl { url = "https://files.squeak.org/sources_files/SqueakV${squeakSourcesVersion}.sources.gz"; - hash = nullableOr args.squeakSourcesHash or null - "sha256-ZViZ1VgI32LwLTEyw7utp8oaAK3UmCNJnHqsGm1IKYE="; + hash = + nullableOr args.squeakSourcesHash or null + "sha256-ZViZ1VgI32LwLTEyw7utp8oaAK3UmCNJnHqsGm1IKYE="; }; vmBuild = "linux64x64"; @@ -220,7 +226,10 @@ in stdenv.mkDerivation { ]; configureScript = "./mvm"; - installTargets = [ "install" "install-image" ]; + installTargets = [ + "install" + "install-image" + ]; postInstall = '' rm "$out/squeak" @@ -230,7 +239,10 @@ in stdenv.mkDerivation { meta = with lib; { description = "Squeak virtual machine"; homepage = "https://opensmalltalk.org/"; - license = with licenses; [ asl20 mit ]; + license = with licenses; [ + asl20 + mit + ]; maintainers = with lib.maintainers; [ ehmry ]; platforms = [ "x86_64-linux" ]; }; diff --git a/pkgs/development/compilers/swi-prolog/default.nix b/pkgs/development/compilers/swi-prolog/default.nix index 9336adb1cd760c..4517a25b744494 100644 --- a/pkgs/development/compilers/swi-prolog/default.nix +++ b/pkgs/development/compilers/swi-prolog/default.nix @@ -1,10 +1,19 @@ { - lib, stdenv, fetchFromGitHub, - cmake, ninja, - - libxcrypt, zlib, openssl, - gmp, gperftools, readline, - libedit, libarchive, Security, + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + + libxcrypt, + zlib, + openssl, + gmp, + gperftools, + readline, + libedit, + libarchive, + Security, # optional dependencies withDb ? true, @@ -25,40 +34,48 @@ withYaml ? true, libyaml, - withGui ? false, - libX11, libXpm, libXext, libXft, libXinerama, libjpeg, libXt, libSM, freetype, fontconfig, + libX11, + libXpm, + libXext, + libXft, + libXinerama, + libjpeg, + libXt, + libSM, + freetype, + fontconfig, # gcc/g++ as runtime dependency - withNativeCompiler ? true - -# Packs must be installed from a local directory during the build, with dependencies -# resolved manually, e.g. to install the 'julian' pack, which depends on the 'delay', 'list_util' and 'typedef' packs: -# julian = pkgs.fetchzip { -# name = "swipl-pack-julian"; -# url = "https://github.com/mndrix/julian/archive/v0.1.3.zip"; -# sha256 = "1sgql7c21p3c5m14kwa0bcmlwn9fql612krn9h36gla1j9yjdfgy"; -# }; -# delay = pkgs.fetchzip { -# name = "swipl-pack-delay"; -# url = "https://github.com/mndrix/delay/archive/v0.3.3.zip"; -# sha256 = "0ira87afxnc2dnbbmgwmrr8qvary8lhzvhqwd52dccm6yqd3nybg"; -# }; -# list_util = pkgs.fetchzip { -# name = "swipl-pack-list_util"; -# url = "https://github.com/mndrix/list_util/archive/v0.13.0.zip"; -# sha256 = "0lx7vffflak0y8l8vg8k0g8qddwwn23ksbz02hi3f8rbarh1n89q"; -# }; -# typedef = builtins.fetchTarball { -# name = "swipl-pack-typedef"; -# url = "https://raw.githubusercontent.com/samer--/prolog/master/typedef/release/typedef-0.1.9.tgz"; -# sha256 = "056nqjn01g18fb1b2qivv9s7hb4azk24nx2d4kvkbmm1k91f44p3"; -# }; -# swi-prolog = pkgs.swi-prolog.override { extraPacks = map (dep-path: "'file://${dep-path}'") [ -# julian delay list_util typedef -# ]; }; -, extraPacks ? [] -, extraLibraries ? [] # removed option - see below + withNativeCompiler ? true, + + # Packs must be installed from a local directory during the build, with dependencies + # resolved manually, e.g. to install the 'julian' pack, which depends on the 'delay', 'list_util' and 'typedef' packs: + # julian = pkgs.fetchzip { + # name = "swipl-pack-julian"; + # url = "https://github.com/mndrix/julian/archive/v0.1.3.zip"; + # sha256 = "1sgql7c21p3c5m14kwa0bcmlwn9fql612krn9h36gla1j9yjdfgy"; + # }; + # delay = pkgs.fetchzip { + # name = "swipl-pack-delay"; + # url = "https://github.com/mndrix/delay/archive/v0.3.3.zip"; + # sha256 = "0ira87afxnc2dnbbmgwmrr8qvary8lhzvhqwd52dccm6yqd3nybg"; + # }; + # list_util = pkgs.fetchzip { + # name = "swipl-pack-list_util"; + # url = "https://github.com/mndrix/list_util/archive/v0.13.0.zip"; + # sha256 = "0lx7vffflak0y8l8vg8k0g8qddwwn23ksbz02hi3f8rbarh1n89q"; + # }; + # typedef = builtins.fetchTarball { + # name = "swipl-pack-typedef"; + # url = "https://raw.githubusercontent.com/samer--/prolog/master/typedef/release/typedef-0.1.9.tgz"; + # sha256 = "056nqjn01g18fb1b2qivv9s7hb4azk24nx2d4kvkbmm1k91f44p3"; + # }; + # swi-prolog = pkgs.swi-prolog.override { extraPacks = map (dep-path: "'file://${dep-path}'") [ + # julian delay list_util typedef + # ]; }; + extraPacks ? [ ], + extraLibraries ? [ ], # removed option - see below }: let @@ -68,25 +85,37 @@ let # This package provides several with* options, which replaces the old extraLibraries option. # This error should help users that still use this option find their way to these flags. # We can probably remove this after one NixOS version. - extraLibraries' = if extraLibraries == [] then [] else throw - "option 'extraLibraries' removed - use 'with*' options (e.g., 'withJava'), or overrideAttrs to inject extra build dependencies"; + extraLibraries' = + if extraLibraries == [ ] then + [ ] + else + throw "option 'extraLibraries' removed - use 'with*' options (e.g., 'withJava'), or overrideAttrs to inject extra build dependencies"; packInstall = swiplPath: pack: '' ${swiplPath}/bin/swipl -g "pack_install(${pack}, [package_directory(\"${swiplPath}/lib/swipl/extra-pack\"), silent(true), interactive(false), git(false)])." -t "halt." ''; withGui' = withGui && !stdenv.hostPlatform.isDarwin; - optionalDependencies = [] - ++ (lib.optional withDb db) - ++ (lib.optional withJava jdk) - ++ (lib.optional withOdbc unixODBC) - ++ (lib.optional withPcre pcre2) - ++ (lib.optional withPython python3) - ++ (lib.optional withYaml libyaml) - ++ (lib.optionals withGui' [ libXt libXext libXpm libXft libXinerama - libjpeg libSM freetype fontconfig - ]) - ++ (lib.optional stdenv.hostPlatform.isDarwin Security) - ++ extraLibraries'; + optionalDependencies = + [ ] + ++ (lib.optional withDb db) + ++ (lib.optional withJava jdk) + ++ (lib.optional withOdbc unixODBC) + ++ (lib.optional withPcre pcre2) + ++ (lib.optional withPython python3) + ++ (lib.optional withYaml libyaml) + ++ (lib.optionals withGui' [ + libXt + libXext + libXpm + libXft + libXinerama + libjpeg + libSM + freetype + fontconfig + ]) + ++ (lib.optional stdenv.hostPlatform.isDarwin Security) + ++ extraLibraries'; in stdenv.mkDerivation { pname = "swi-prolog"; @@ -108,7 +137,10 @@ stdenv.mkDerivation { echo "user:file_search_path(pack, '$out/lib/swipl/extra-pack')." >> boot/init.pl ''; - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; buildInputs = [ libarchive @@ -123,20 +155,19 @@ stdenv.mkDerivation { hardeningDisable = [ "format" ]; - cmakeFlags = [ "-DSWIPL_INSTALL_IN_LIB=ON" ] - ++ lib.optionals (!withNativeCompiler) [ - # without these options, the build will embed full compiler paths - "-DSWIPL_CC=${if stdenv.hostPlatform.isDarwin then "clang" else "gcc"}" - "-DSWIPL_CXX=${if stdenv.hostPlatform.isDarwin then "clang++" else "g++"}" - ]; + cmakeFlags = + [ "-DSWIPL_INSTALL_IN_LIB=ON" ] + ++ lib.optionals (!withNativeCompiler) [ + # without these options, the build will embed full compiler paths + "-DSWIPL_CC=${if stdenv.hostPlatform.isDarwin then "clang" else "gcc"}" + "-DSWIPL_CXX=${if stdenv.hostPlatform.isDarwin then "clang++" else "g++"}" + ]; preInstall = '' mkdir -p $out/lib/swipl/extra-pack ''; - postInstall = builtins.concatStringsSep "\n" - ( builtins.map (packInstall "$out") extraPacks - ); + postInstall = builtins.concatStringsSep "\n" (builtins.map (packInstall "$out") extraPacks); meta = { homepage = "https://www.swi-prolog.org"; @@ -144,6 +175,9 @@ stdenv.mkDerivation { license = lib.licenses.bsd2; mainProgram = "swipl"; platforms = lib.platforms.linux ++ lib.optionals (!withGui) lib.platforms.darwin; - maintainers = [ lib.maintainers.meditans lib.maintainers.matko ]; + maintainers = [ + lib.maintainers.meditans + lib.maintainers.matko + ]; }; } diff --git a/pkgs/development/compilers/swift/default.nix b/pkgs/development/compilers/swift/default.nix index 3ddd48399b1a96..085f2750d5c853 100644 --- a/pkgs/development/compilers/swift/default.nix +++ b/pkgs/development/compilers/swift/default.nix @@ -1,11 +1,12 @@ -{ lib -, pkgs -, newScope -, darwin -, llvmPackages -, llvmPackages_15 -, overrideCC -, overrideLibcxx +{ + lib, + pkgs, + newScope, + darwin, + llvmPackages, + llvmPackages_15, + overrideCC, + overrideLibcxx, }: let @@ -54,13 +55,17 @@ let useSwiftDriver = false; }; - Dispatch = if stdenv.hostPlatform.isDarwin - then null # part of apple-sdk - else callPackage ./libdispatch { swift = swiftNoSwiftDriver; }; + Dispatch = + if stdenv.hostPlatform.isDarwin then + null # part of apple-sdk + else + callPackage ./libdispatch { swift = swiftNoSwiftDriver; }; - Foundation = if stdenv.hostPlatform.isDarwin - then null # part of apple-sdk - else callPackage ./foundation { swift = swiftNoSwiftDriver; }; + Foundation = + if stdenv.hostPlatform.isDarwin then + null # part of apple-sdk + else + callPackage ./foundation { swift = swiftNoSwiftDriver; }; # TODO: Apple distributes a binary XCTest with Xcode, but it is not part of # CLTools (or SUS), so would have to figure out how to fetch it. The binary @@ -98,4 +103,5 @@ let }; -in self +in +self diff --git a/pkgs/development/compilers/swift/foundation/default.nix b/pkgs/development/compilers/swift/foundation/default.nix index 98eff7a31783a5..c1836607eb11f5 100644 --- a/pkgs/development/compilers/swift/foundation/default.nix +++ b/pkgs/development/compilers/swift/foundation/default.nix @@ -3,22 +3,24 @@ # This is separate because the CF build is completely different and part of # stdenv. Merging the two was kept outside of the scope of Swift work. -{ lib -, stdenv -, fetchpatch -, callPackage -, cmake -, ninja -, swift -, Dispatch -, icu -, libxml2 -, curl +{ + lib, + stdenv, + fetchpatch, + callPackage, + cmake, + ninja, + swift, + Dispatch, + icu, + libxml2, + curl, }: let sources = callPackage ../sources.nix { }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "swift-corelibs-foundation"; inherit (sources) version; @@ -33,10 +35,21 @@ in stdenv.mkDerivation { }) ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ cmake ninja swift ]; - buildInputs = [ icu libxml2 curl ]; + nativeBuildInputs = [ + cmake + ninja + swift + ]; + buildInputs = [ + icu + libxml2 + curl + ]; propagatedBuildInputs = [ Dispatch ]; preConfigure = '' diff --git a/pkgs/development/compilers/swift/libdispatch/default.nix b/pkgs/development/compilers/swift/libdispatch/default.nix index 8478d584948317..0b326af1b33bdc 100644 --- a/pkgs/development/compilers/swift/libdispatch/default.nix +++ b/pkgs/development/compilers/swift/libdispatch/default.nix @@ -1,23 +1,34 @@ -{ lib -, stdenv -, callPackage -, cmake -, ninja -, useSwift ? true, swift +{ + lib, + stdenv, + callPackage, + cmake, + ninja, + useSwift ? true, + swift, }: let sources = callPackage ../sources.nix { }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "swift-corelibs-libdispatch"; inherit (sources) version; src = sources.swift-corelibs-libdispatch; - outputs = [ "out" "dev" "man" ]; - - nativeBuildInputs = [ cmake ] - ++ lib.optionals useSwift [ ninja swift ]; + outputs = [ + "out" + "dev" + "man" + ]; + + nativeBuildInputs = + [ cmake ] + ++ lib.optionals useSwift [ + ninja + swift + ]; patches = [ ./disable-swift-overlay.patch ]; diff --git a/pkgs/development/compilers/swift/sourcekit-lsp/default.nix b/pkgs/development/compilers/swift/sourcekit-lsp/default.nix index 2d1cd6dd044052..8d425bcc6f5cca 100644 --- a/pkgs/development/compilers/swift/sourcekit-lsp/default.nix +++ b/pkgs/development/compilers/swift/sourcekit-lsp/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, callPackage -, fetchpatch -, pkg-config -, swift -, swiftpm -, swiftpm2nix -, Foundation -, XCTest -, sqlite -, ncurses -, CryptoKit -, LocalAuthentication +{ + lib, + stdenv, + callPackage, + fetchpatch, + pkg-config, + swift, + swiftpm, + swiftpm2nix, + Foundation, + XCTest, + sqlite, + ncurses, + CryptoKit, + LocalAuthentication, }: let sources = callPackage ../sources.nix { }; @@ -29,33 +30,46 @@ stdenv.mkDerivation { inherit (sources) version; src = sources.sourcekit-lsp; - nativeBuildInputs = [ pkg-config swift swiftpm ]; - buildInputs = [ - Foundation - XCTest - sqlite - ncursesInput - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ CryptoKit LocalAuthentication ]; + nativeBuildInputs = [ + pkg-config + swift + swiftpm + ]; + buildInputs = + [ + Foundation + XCTest + sqlite + ncursesInput + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CryptoKit + LocalAuthentication + ]; - configurePhase = generated.configure + '' - swiftpmMakeMutable indexstore-db - patch -p1 -d .build/checkouts/indexstore-db -i ${./patches/indexstore-db-macos-target.patch} + configurePhase = + generated.configure + + '' + swiftpmMakeMutable indexstore-db + patch -p1 -d .build/checkouts/indexstore-db -i ${./patches/indexstore-db-macos-target.patch} - swiftpmMakeMutable swift-tools-support-core - patch -p1 -d .build/checkouts/swift-tools-support-core -i ${fetchpatch { - url = "https://github.com/apple/swift-tools-support-core/commit/990afca47e75cce136d2f59e464577e68a164035.patch"; - hash = "sha256-PLzWsp+syiUBHhEFS8+WyUcSae5p0Lhk7SSRdNvfouE="; - includes = [ "Sources/TSCBasic/FileSystem.swift" ]; - }} + swiftpmMakeMutable swift-tools-support-core + patch -p1 -d .build/checkouts/swift-tools-support-core -i ${ + fetchpatch { + url = "https://github.com/apple/swift-tools-support-core/commit/990afca47e75cce136d2f59e464577e68a164035.patch"; + hash = "sha256-PLzWsp+syiUBHhEFS8+WyUcSae5p0Lhk7SSRdNvfouE="; + includes = [ "Sources/TSCBasic/FileSystem.swift" ]; + } + } - # This toggles a section specific to Xcode XCTest, which doesn't work on - # Darwin, where we also use swift-corelibs-xctest. - substituteInPlace Sources/LSPTestSupport/PerfTestCase.swift \ - --replace '#if os(macOS)' '#if false' + # This toggles a section specific to Xcode XCTest, which doesn't work on + # Darwin, where we also use swift-corelibs-xctest. + substituteInPlace Sources/LSPTestSupport/PerfTestCase.swift \ + --replace '#if os(macOS)' '#if false' - # Required to link with swift-corelibs-xctest on Darwin. - export SWIFTTSC_MACOS_DEPLOYMENT_TARGET=10.12 - ''; + # Required to link with swift-corelibs-xctest on Darwin. + export SWIFTTSC_MACOS_DEPLOYMENT_TARGET=10.12 + ''; # TODO: BuildServerBuildSystemTests fails #doCheck = true; diff --git a/pkgs/development/compilers/swift/sources.nix b/pkgs/development/compilers/swift/sources.nix index 11240f767d08e8..cb20a3d1b1c82b 100644 --- a/pkgs/development/compilers/swift/sources.nix +++ b/pkgs/development/compilers/swift/sources.nix @@ -24,12 +24,16 @@ let }; # Create fetch derivations. - sources = lib.mapAttrs (repo: hash: fetchFromGitHub { - owner = "apple"; - inherit repo; - rev = "swift-${version}-RELEASE"; - name = "${repo}-${version}-src"; - hash = hashes.${repo}; - }) hashes; + sources = lib.mapAttrs ( + repo: hash: + fetchFromGitHub { + owner = "apple"; + inherit repo; + rev = "swift-${version}-RELEASE"; + name = "${repo}-${version}-src"; + hash = hashes.${repo}; + } + ) hashes; -in sources // { inherit version; } +in +sources // { inherit version; } diff --git a/pkgs/development/compilers/swift/swift-docc/default.nix b/pkgs/development/compilers/swift/swift-docc/default.nix index 13595882241bc2..f1c1ee2dcd684e 100644 --- a/pkgs/development/compilers/swift/swift-docc/default.nix +++ b/pkgs/development/compilers/swift/swift-docc/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, callPackage -, swift -, swiftpm -, swiftpm2nix -, Foundation -, XCTest -, CryptoKit -, LocalAuthentication +{ + lib, + stdenv, + callPackage, + swift, + swiftpm, + swiftpm2nix, + Foundation, + XCTest, + CryptoKit, + LocalAuthentication, }: let sources = callPackage ../sources.nix { }; @@ -22,9 +23,19 @@ stdenv.mkDerivation { # repository is not tagged. renderArtifact = sources.swift-docc-render-artifact; - nativeBuildInputs = [ swift swiftpm ]; - buildInputs = [ Foundation XCTest ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ CryptoKit LocalAuthentication ]; + nativeBuildInputs = [ + swift + swiftpm + ]; + buildInputs = + [ + Foundation + XCTest + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CryptoKit + LocalAuthentication + ]; configurePhase = generated.configure; diff --git a/pkgs/development/compilers/swift/swift-driver/default.nix b/pkgs/development/compilers/swift/swift-driver/default.nix index 03c7898fe11210..52567304af3162 100644 --- a/pkgs/development/compilers/swift/swift-driver/default.nix +++ b/pkgs/development/compilers/swift/swift-driver/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, callPackage -, fetchpatch -, swift -, swiftpm -, swiftpm2nix -, Foundation -, XCTest -, sqlite -, ncurses -, substituteAll +{ + lib, + stdenv, + callPackage, + fetchpatch, + swift, + swiftpm, + swiftpm2nix, + Foundation, + XCTest, + sqlite, + ncurses, + substituteAll, }: let sources = callPackage ../sources.nix { }; @@ -27,7 +28,10 @@ stdenv.mkDerivation { inherit (sources) version; src = sources.swift-driver; - nativeBuildInputs = [ swift swiftpm ]; + nativeBuildInputs = [ + swift + swiftpm + ]; buildInputs = [ Foundation XCTest @@ -52,14 +56,18 @@ stdenv.mkDerivation { }) ]; - configurePhase = generated.configure + '' - swiftpmMakeMutable swift-tools-support-core - patch -p1 -d .build/checkouts/swift-tools-support-core -i ${fetchpatch { - url = "https://github.com/apple/swift-tools-support-core/commit/990afca47e75cce136d2f59e464577e68a164035.patch"; - hash = "sha256-PLzWsp+syiUBHhEFS8+WyUcSae5p0Lhk7SSRdNvfouE="; - includes = [ "Sources/TSCBasic/FileSystem.swift" ]; - }} - ''; + configurePhase = + generated.configure + + '' + swiftpmMakeMutable swift-tools-support-core + patch -p1 -d .build/checkouts/swift-tools-support-core -i ${ + fetchpatch { + url = "https://github.com/apple/swift-tools-support-core/commit/990afca47e75cce136d2f59e464577e68a164035.patch"; + hash = "sha256-PLzWsp+syiUBHhEFS8+WyUcSae5p0Lhk7SSRdNvfouE="; + includes = [ "Sources/TSCBasic/FileSystem.swift" ]; + } + } + ''; # TODO: Tests depend on indexstore-db being provided by an existing Swift # toolchain. (ie. looks for `../lib/libIndexStore.so` relative to swiftc. diff --git a/pkgs/development/compilers/swift/swift-format/default.nix b/pkgs/development/compilers/swift/swift-format/default.nix index 3ce4c22b697001..eee7dd931026f8 100644 --- a/pkgs/development/compilers/swift/swift-format/default.nix +++ b/pkgs/development/compilers/swift/swift-format/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchpatch -, callPackage -, swift -, swiftpm -, swiftpm2nix -, Foundation +{ + lib, + stdenv, + fetchpatch, + callPackage, + swift, + swiftpm, + swiftpm2nix, + Foundation, }: let sources = callPackage ../sources.nix { }; @@ -17,17 +18,24 @@ stdenv.mkDerivation { inherit (sources) version; src = sources.swift-format; - nativeBuildInputs = [ swift swiftpm ]; + nativeBuildInputs = [ + swift + swiftpm + ]; buildInputs = [ Foundation ]; - configurePhase = generated.configure + '' - swiftpmMakeMutable swift-tools-support-core - patch -p1 -d .build/checkouts/swift-tools-support-core -i ${fetchpatch { - url = "https://github.com/apple/swift-tools-support-core/commit/990afca47e75cce136d2f59e464577e68a164035.patch"; - hash = "sha256-PLzWsp+syiUBHhEFS8+WyUcSae5p0Lhk7SSRdNvfouE="; - includes = [ "Sources/TSCBasic/FileSystem.swift" ]; - }} - ''; + configurePhase = + generated.configure + + '' + swiftpmMakeMutable swift-tools-support-core + patch -p1 -d .build/checkouts/swift-tools-support-core -i ${ + fetchpatch { + url = "https://github.com/apple/swift-tools-support-core/commit/990afca47e75cce136d2f59e464577e68a164035.patch"; + hash = "sha256-PLzWsp+syiUBHhEFS8+WyUcSae5p0Lhk7SSRdNvfouE="; + includes = [ "Sources/TSCBasic/FileSystem.swift" ]; + } + } + ''; # We only install the swift-format binary, so don't need the other products. swiftpmFlags = [ "--product swift-format" ]; diff --git a/pkgs/development/compilers/swift/swiftpm/cmake-glue.nix b/pkgs/development/compilers/swift/swiftpm/cmake-glue.nix index 252040dd3ec018..1f07ed1838ed65 100644 --- a/pkgs/development/compilers/swift/swiftpm/cmake-glue.nix +++ b/pkgs/development/compilers/swift/swiftpm/cmake-glue.nix @@ -2,7 +2,11 @@ # CMake modules to link them together in a build tree. We have separate # derivations, so need a real install step. Here we provide our own minimal # CMake modules to install along with the build products. -{ lib, stdenv, swift }: +{ + lib, + stdenv, + swift, +}: let inherit (stdenv.hostPlatform) extensions; @@ -20,7 +24,8 @@ let ) ''; -in lib.mapAttrs mkInstallScript { +in +lib.mapAttrs mkInstallScript { SwiftSystem = '' add_library(SwiftSystem::SystemPackage STATIC IMPORTED) set_property(TARGET SwiftSystem::SystemPackage PROPERTY IMPORTED_LOCATION "@out@/lib/swift_static/@swiftOs@/libSystemPackage@staticLibExt@") diff --git a/pkgs/development/compilers/swift/swiftpm/default.nix b/pkgs/development/compilers/swift/swiftpm/default.nix index 52f07e3f822c17..76b2ad2d769613 100644 --- a/pkgs/development/compilers/swift/swiftpm/default.nix +++ b/pkgs/development/compilers/swift/swiftpm/default.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, callPackage -, fetchpatch -, cmake -, ninja -, git -, swift -, swiftpm2nix -, Foundation -, XCTest -, pkg-config -, sqlite -, ncurses -, substituteAll -, runCommandLocal -, makeWrapper -, DarwinTools # sw_vers -, cctools # vtool -, darwinMinVersionHook -, xcbuild -, CryptoKit -, LocalAuthentication +{ + lib, + stdenv, + callPackage, + fetchpatch, + cmake, + ninja, + git, + swift, + swiftpm2nix, + Foundation, + XCTest, + pkg-config, + sqlite, + ncurses, + substituteAll, + runCommandLocal, + makeWrapper, + DarwinTools, # sw_vers + cctools, # vtool + darwinMinVersionHook, + xcbuild, + CryptoKit, + LocalAuthentication, }: let @@ -81,7 +82,8 @@ let }; # Tools invoked by swiftpm at run-time. - runtimeDeps = [ git ] + runtimeDeps = + [ git ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ xcbuild.xcrun # These tools are part of cctools, but adding that as a build input puts @@ -97,47 +99,57 @@ let ]; # Common attributes for the bootstrap derivations. - mkBootstrapDerivation = attrs: stdenv.mkDerivation (attrs // { - nativeBuildInputs = (attrs.nativeBuildInputs or [ ]) - ++ [ cmake ninja swift ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ DarwinTools ]; - - buildInputs = (attrs.buildInputs or [ ]) - ++ [ Foundation ]; - - postPatch = (attrs.postPatch or "") - + lib.optionalString stdenv.hostPlatform.isDarwin '' - # On Darwin only, Swift uses arm64 as cpu arch. - if [ -e cmake/modules/SwiftSupport.cmake ]; then - substituteInPlace cmake/modules/SwiftSupport.cmake \ - --replace '"aarch64" PARENT_SCOPE' '"arm64" PARENT_SCOPE' - fi - ''; - - postInstall = (attrs.postInstall or "") - + lib.optionalString stdenv.hostPlatform.isDarwin '' - # The install name of libraries is incorrectly set to lib/ (via our - # CMake setup hook) instead of lib/swift/. This'd be easily fixed by - # fixDarwinDylibNames, but some builds create libraries that reference - # eachother, and we also have to fix those references. - dylibs="$(find $out/lib/swift* -name '*.dylib')" - changes="" - for dylib in $dylibs; do - changes+=" -change $(otool -D $dylib | tail -n 1) $dylib" - done - for dylib in $dylibs; do - install_name_tool -id $dylib $changes $dylib - done - ''; - - cmakeFlags = (attrs.cmakeFlags or [ ]) - ++ [ - # Some builds link to libraries within the same build. Make sure these - # create references to $out. None of our builds run their own products, - # so we don't have to account for that scenario. - "-DCMAKE_BUILD_WITH_INSTALL_NAME_DIR=ON" - ]; - }); + mkBootstrapDerivation = + attrs: + stdenv.mkDerivation ( + attrs + // { + nativeBuildInputs = + (attrs.nativeBuildInputs or [ ]) + ++ [ + cmake + ninja + swift + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ DarwinTools ]; + + buildInputs = (attrs.buildInputs or [ ]) ++ [ Foundation ]; + + postPatch = + (attrs.postPatch or "") + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # On Darwin only, Swift uses arm64 as cpu arch. + if [ -e cmake/modules/SwiftSupport.cmake ]; then + substituteInPlace cmake/modules/SwiftSupport.cmake \ + --replace '"aarch64" PARENT_SCOPE' '"arm64" PARENT_SCOPE' + fi + ''; + + postInstall = + (attrs.postInstall or "") + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # The install name of libraries is incorrectly set to lib/ (via our + # CMake setup hook) instead of lib/swift/. This'd be easily fixed by + # fixDarwinDylibNames, but some builds create libraries that reference + # eachother, and we also have to fix those references. + dylibs="$(find $out/lib/swift* -name '*.dylib')" + changes="" + for dylib in $dylibs; do + changes+=" -change $(otool -D $dylib | tail -n 1) $dylib" + done + for dylib in $dylibs; do + install_name_tool -id $dylib $changes $dylib + done + ''; + + cmakeFlags = (attrs.cmakeFlags or [ ]) ++ [ + # Some builds link to libraries within the same build. Make sure these + # create references to $out. None of our builds run their own products, + # so we don't have to account for that scenario. + "-DCMAKE_BUILD_WITH_INSTALL_NAME_DIR=ON" + ]; + } + ); # On Darwin, we only want ncurses in the linker search path, because headers # are part of libsystem. Adding its headers to the search path causes strange @@ -161,7 +173,8 @@ let name = "swift-system"; src = generated.sources.swift-system; - postInstall = cmakeGlue.SwiftSystem + postInstall = + cmakeGlue.SwiftSystem + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' # The cmake rules apparently only use the Darwin install convention. # Fix up the installation so the module can be found on non-Darwin. @@ -181,7 +194,8 @@ let sed -i -e '/BUILD_SHARED_LIBS/d' CMakeLists.txt ''; - postInstall = cmakeGlue.SwiftCollections + postInstall = + cmakeGlue.SwiftCollections + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' # The cmake rules apparently only use the Darwin install convention. # Fix up the installation so the module can be found on non-Darwin. @@ -213,32 +227,38 @@ let sqlite ]; - postInstall = cmakeGlue.TSC + '' - # Swift modules are not installed. - mkdir -p $out/${swiftModuleSubdir} - cp swift/*.swift{module,doc} $out/${swiftModuleSubdir}/ + postInstall = + cmakeGlue.TSC + + '' + # Swift modules are not installed. + mkdir -p $out/${swiftModuleSubdir} + cp swift/*.swift{module,doc} $out/${swiftModuleSubdir}/ - # Static libs are not installed. - cp lib/*.a $out/lib/ + # Static libs are not installed. + cp lib/*.a $out/lib/ - # Headers are not installed. - mkdir -p $out/include - cp -r ../Sources/TSCclibc/include $out/include/TSC - ''; + # Headers are not installed. + mkdir -p $out/include + cp -r ../Sources/TSCclibc/include $out/include/TSC + ''; }; swift-argument-parser = mkBootstrapDerivation { name = "swift-argument-parser"; src = generated.sources.swift-argument-parser; - buildInputs = [ ncursesInput sqlite ]; + buildInputs = [ + ncursesInput + sqlite + ]; cmakeFlags = [ "-DBUILD_TESTING=NO" "-DBUILD_EXAMPLES=NO" ]; - postInstall = cmakeGlue.ArgumentParser + postInstall = + cmakeGlue.ArgumentParser + lib.optionalString stdenv.hostPlatform.isLinux '' # Fix rpath so ArgumentParserToolInfo can be found. patchelf --add-rpath "$out/lib/swift/${swiftOs}" \ @@ -261,7 +281,10 @@ let src = generated.sources.swift-llbuild; nativeBuildInputs = lib.optional stdenv.hostPlatform.isDarwin xcbuild; - buildInputs = [ ncursesInput sqlite ]; + buildInputs = [ + ncursesInput + sqlite + ]; patches = [ ./patches/llbuild-cmake-disable-rpath.patch @@ -287,14 +310,16 @@ let "-DLLBUILD_SUPPORT_BINDINGS=Swift" ]; - postInstall = cmakeGlue.LLBuild + '' - # Install module map. - cp ../products/libllbuild/include/module.modulemap $out/include + postInstall = + cmakeGlue.LLBuild + + '' + # Install module map. + cp ../products/libllbuild/include/module.modulemap $out/include - # Swift modules are not installed. - mkdir -p $out/${swiftModuleSubdir} - cp products/llbuildSwift/*.swift{module,doc} $out/${swiftModuleSubdir}/ - ''; + # Swift modules are not installed. + mkdir -p $out/${swiftModuleSubdir} + cp products/llbuildSwift/*.swift{module,doc} $out/${swiftModuleSubdir}/ + ''; }; swift-driver = mkBootstrapDerivation { @@ -315,11 +340,13 @@ let --replace CYaml "" ''; - postInstall = cmakeGlue.SwiftDriver + '' - # Swift modules are not installed. - mkdir -p $out/${swiftModuleSubdir} - cp swift/*.swift{module,doc} $out/${swiftModuleSubdir}/ - ''; + postInstall = + cmakeGlue.SwiftDriver + + '' + # Swift modules are not installed. + mkdir -p $out/${swiftModuleSubdir} + cp swift/*.swift{module,doc} $out/${swiftModuleSubdir}/ + ''; }; swift-crypto = mkBootstrapDerivation { @@ -334,122 +361,137 @@ let --replace /usr/bin/ranlib $NIX_CC/bin/ranlib ''; - postInstall = cmakeGlue.SwiftCrypto + '' - # Static libs are not installed. - cp lib/*.a $out/lib/ + postInstall = + cmakeGlue.SwiftCrypto + + '' + # Static libs are not installed. + cp lib/*.a $out/lib/ - # Headers are not installed. - cp -r ../Sources/CCryptoBoringSSL/include $out/include - ''; + # Headers are not installed. + cp -r ../Sources/CCryptoBoringSSL/include $out/include + ''; }; # Build a bootrapping swiftpm using CMake. - swiftpm-bootstrap = mkBootstrapDerivation (commonAttrs // { - pname = "swiftpm-bootstrap"; + swiftpm-bootstrap = mkBootstrapDerivation ( + commonAttrs + // { + pname = "swiftpm-bootstrap"; + + buildInputs = [ + llbuild + sqlite + swift-argument-parser + swift-collections + swift-crypto + swift-driver + swift-system + swift-tools-support-core + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ (darwinMinVersionHook "10.15.4") ]; + + cmakeFlags = [ + "-DUSE_CMAKE_INSTALL=ON" + ]; - buildInputs = [ - llbuild - sqlite - swift-argument-parser - swift-collections - swift-crypto - swift-driver - swift-system - swift-tools-support-core - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ (darwinMinVersionHook "10.15.4") ]; + postInstall = '' + for program in $out/bin/swift-*; do + wrapProgram $program --prefix PATH : ${lib.makeBinPath runtimeDeps} + done + ''; + } + ); - cmakeFlags = [ - "-DUSE_CMAKE_INSTALL=ON" +in +# Build the final swiftpm with the bootstrapping swiftpm. +stdenv.mkDerivation ( + commonAttrs + // { + pname = "swiftpm"; + + nativeBuildInputs = commonAttrs.nativeBuildInputs ++ [ + pkg-config + swift + swiftpm-bootstrap ]; + buildInputs = + [ + ncursesInput + sqlite + XCTest + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CryptoKit + LocalAuthentication + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ (darwinMinVersionHook "10.15.4") ]; + + configurePhase = + generated.configure + + '' + # Functionality provided by Xcode XCTest, but not available in + # swift-corelibs-xctest. + swiftpmMakeMutable swift-tools-support-core + substituteInPlace .build/checkouts/swift-tools-support-core/Sources/TSCTestSupport/XCTestCasePerf.swift \ + --replace 'canImport(Darwin)' 'false' + patch -p1 -d .build/checkouts/swift-tools-support-core -i ${swift-tools-support-core-glibc-fix} + + # Prevent a warning about SDK directories we don't have. + swiftpmMakeMutable swift-driver + patch -p1 -d .build/checkouts/swift-driver -i ${ + substituteAll { + src = ../swift-driver/patches/prevent-sdk-dirs-warnings.patch; + inherit (builtins) storeDir; + } + } + ''; - postInstall = '' - for program in $out/bin/swift-*; do - wrapProgram $program --prefix PATH : ${lib.makeBinPath runtimeDeps} + buildPhase = '' + TERM=dumb swift-build -c release + ''; + + # TODO: Tests depend on indexstore-db being provided by an existing Swift + # toolchain. (ie. looks for `../lib/libIndexStore.so` relative to swiftc. + #doCheck = true; + #checkPhase = '' + # TERM=dumb swift-test -c release + #''; + + # The following is dervied from Utilities/bootstrap, see install_swiftpm. + installPhase = '' + binPath="$(swift-build --show-bin-path -c release)" + + mkdir -p $out/bin $out/lib/swift + + cp $binPath/swift-package-manager $out/bin/swift-package + wrapProgram $out/bin/swift-package \ + --prefix PATH : ${lib.makeBinPath runtimeDeps} + for tool in swift-build swift-test swift-run swift-package-collection swift-experimental-destination; do + ln -s $out/bin/swift-package $out/bin/$tool done + + installSwiftpmModule() { + mkdir -p $out/lib/swift/pm/$2 + cp $binPath/lib$1${sharedLibraryExt} $out/lib/swift/pm/$2/ + + if [[ -f $binPath/$1.swiftinterface ]]; then + cp $binPath/$1.swiftinterface $out/lib/swift/pm/$2/ + else + cp -r $binPath/$1.swiftmodule $out/lib/swift/pm/$2/ + fi + cp $binPath/$1.swiftdoc $out/lib/swift/pm/$2/ + } + installSwiftpmModule PackageDescription ManifestAPI + installSwiftpmModule PackagePlugin PluginAPI ''; - }); -# Build the final swiftpm with the bootstrapping swiftpm. -in stdenv.mkDerivation (commonAttrs // { - pname = "swiftpm"; - - nativeBuildInputs = commonAttrs.nativeBuildInputs ++ [ - pkg-config - swift - swiftpm-bootstrap - ]; - buildInputs = [ - ncursesInput - sqlite - XCTest - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CryptoKit - LocalAuthentication - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ (darwinMinVersionHook "10.15.4") ]; - - configurePhase = generated.configure + '' - # Functionality provided by Xcode XCTest, but not available in - # swift-corelibs-xctest. - swiftpmMakeMutable swift-tools-support-core - substituteInPlace .build/checkouts/swift-tools-support-core/Sources/TSCTestSupport/XCTestCasePerf.swift \ - --replace 'canImport(Darwin)' 'false' - patch -p1 -d .build/checkouts/swift-tools-support-core -i ${swift-tools-support-core-glibc-fix} - - # Prevent a warning about SDK directories we don't have. - swiftpmMakeMutable swift-driver - patch -p1 -d .build/checkouts/swift-driver -i ${substituteAll { - src = ../swift-driver/patches/prevent-sdk-dirs-warnings.patch; - inherit (builtins) storeDir; - }} - ''; - - buildPhase = '' - TERM=dumb swift-build -c release - ''; - - # TODO: Tests depend on indexstore-db being provided by an existing Swift - # toolchain. (ie. looks for `../lib/libIndexStore.so` relative to swiftc. - #doCheck = true; - #checkPhase = '' - # TERM=dumb swift-test -c release - #''; - - # The following is dervied from Utilities/bootstrap, see install_swiftpm. - installPhase = '' - binPath="$(swift-build --show-bin-path -c release)" - - mkdir -p $out/bin $out/lib/swift - - cp $binPath/swift-package-manager $out/bin/swift-package - wrapProgram $out/bin/swift-package \ - --prefix PATH : ${lib.makeBinPath runtimeDeps} - for tool in swift-build swift-test swift-run swift-package-collection swift-experimental-destination; do - ln -s $out/bin/swift-package $out/bin/$tool - done - - installSwiftpmModule() { - mkdir -p $out/lib/swift/pm/$2 - cp $binPath/lib$1${sharedLibraryExt} $out/lib/swift/pm/$2/ - - if [[ -f $binPath/$1.swiftinterface ]]; then - cp $binPath/$1.swiftinterface $out/lib/swift/pm/$2/ - else - cp -r $binPath/$1.swiftmodule $out/lib/swift/pm/$2/ - fi - cp $binPath/$1.swiftdoc $out/lib/swift/pm/$2/ - } - installSwiftpmModule PackageDescription ManifestAPI - installSwiftpmModule PackagePlugin PluginAPI - ''; - - setupHook = ./setup-hook.sh; - - meta = { - description = "Package Manager for the Swift Programming Language"; - homepage = "https://github.com/apple/swift-package-manager"; - platforms = with lib.platforms; linux ++ darwin; - license = lib.licenses.asl20; - maintainers = lib.teams.swift.members; - }; -}) + setupHook = ./setup-hook.sh; + + meta = { + description = "Package Manager for the Swift Programming Language"; + homepage = "https://github.com/apple/swift-package-manager"; + platforms = with lib.platforms; linux ++ darwin; + license = lib.licenses.asl20; + maintainers = lib.teams.swift.members; + }; + } +) diff --git a/pkgs/development/compilers/swift/swiftpm2nix/default.nix b/pkgs/development/compilers/swift/swiftpm2nix/default.nix index 461e572fe4f953..5f87f4b1f00639 100644 --- a/pkgs/development/compilers/swift/swiftpm2nix/default.nix +++ b/pkgs/development/compilers/swift/swiftpm2nix/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, callPackage, makeWrapper, jq, nurl }: +{ + lib, + stdenv, + callPackage, + makeWrapper, + jq, + nurl, +}: stdenv.mkDerivation { name = "swiftpm2nix"; @@ -10,7 +17,12 @@ stdenv.mkDerivation { installPhase = '' install -vD ${./swiftpm2nix.sh} $out/bin/swiftpm2nix wrapProgram $out/bin/$name \ - --prefix PATH : ${lib.makeBinPath [ jq nurl ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + jq + nurl + ] + } \ ''; preferLocalBuild = true; diff --git a/pkgs/development/compilers/swift/swiftpm2nix/support.nix b/pkgs/development/compilers/swift/swiftpm2nix/support.nix index 3debda233c5f46..1822c1c742a2a1 100644 --- a/pkgs/development/compilers/swift/swiftpm2nix/support.nix +++ b/pkgs/development/compilers/swift/swiftpm2nix/support.nix @@ -1,11 +1,23 @@ -{ lib, fetchgit, formats }: +{ + lib, + fetchgit, + formats, +}: let - inherit (lib) concatStrings listToAttrs makeOverridable mapAttrsToList nameValuePair; + inherit (lib) + concatStrings + listToAttrs + makeOverridable + mapAttrsToList + nameValuePair + ; json = formats.json { }; -in rec { +in +rec { # Derive a pin file from workspace state. - mkPinFile = workspaceState: + mkPinFile = + workspaceState: assert workspaceState.version >= 5 && workspaceState.version <= 6; json.generate "Package.resolved" { version = 1; @@ -17,41 +29,50 @@ in rec { }; # Make packaging helpers from swiftpm2nix generated output. - helpers = generated: let - inherit (import generated) workspaceStateFile hashes; - workspaceState = lib.importJSON workspaceStateFile; - pinFile = mkPinFile workspaceState; - in rec { + helpers = + generated: + let + inherit (import generated) workspaceStateFile hashes; + workspaceState = lib.importJSON workspaceStateFile; + pinFile = mkPinFile workspaceState; + in + rec { - # Create fetch expressions for dependencies. - sources = listToAttrs ( - map (dep: nameValuePair dep.subpath (fetchgit { - url = dep.packageRef.location; - rev = dep.state.checkoutState.revision; - sha256 = hashes.${dep.subpath}; - fetchSubmodules = true; - })) workspaceState.object.dependencies - ); + # Create fetch expressions for dependencies. + sources = listToAttrs ( + map ( + dep: + nameValuePair dep.subpath (fetchgit { + url = dep.packageRef.location; + rev = dep.state.checkoutState.revision; + sha256 = hashes.${dep.subpath}; + fetchSubmodules = true; + }) + ) workspaceState.object.dependencies + ); - # Configure phase snippet for use in packaging. - configure = '' - mkdir -p .build/checkouts - ln -sf ${pinFile} ./Package.resolved - install -m 0600 ${workspaceStateFile} ./.build/workspace-state.json - '' - + concatStrings (mapAttrsToList (name: src: '' - ln -s '${src}' '.build/checkouts/${name}' - '') sources) - + '' - # Helper that makes a swiftpm dependency mutable by copying the source. - swiftpmMakeMutable() { - local orig="$(readlink .build/checkouts/$1)" - rm .build/checkouts/$1 - cp -r "$orig" .build/checkouts/$1 - chmod -R u+w .build/checkouts/$1 - } - ''; + # Configure phase snippet for use in packaging. + configure = + '' + mkdir -p .build/checkouts + ln -sf ${pinFile} ./Package.resolved + install -m 0600 ${workspaceStateFile} ./.build/workspace-state.json + '' + + concatStrings ( + mapAttrsToList (name: src: '' + ln -s '${src}' '.build/checkouts/${name}' + '') sources + ) + + '' + # Helper that makes a swiftpm dependency mutable by copying the source. + swiftpmMakeMutable() { + local orig="$(readlink .build/checkouts/$1)" + rm .build/checkouts/$1 + cp -r "$orig" .build/checkouts/$1 + chmod -R u+w .build/checkouts/$1 + } + ''; - }; + }; } diff --git a/pkgs/development/compilers/swift/wrapper/default.nix b/pkgs/development/compilers/swift/wrapper/default.nix index 2bf8ef60ebf3f1..d8b08cf5e3c2d3 100644 --- a/pkgs/development/compilers/swift/wrapper/default.nix +++ b/pkgs/development/compilers/swift/wrapper/default.nix @@ -1,68 +1,85 @@ -{ lib -, stdenv -, swift -, useSwiftDriver ? true, swift-driver +{ + lib, + stdenv, + swift, + useSwiftDriver ? true, + swift-driver, }: -stdenv.mkDerivation (swift._wrapperParams // { - pname = "swift-wrapper"; - inherit (swift) version meta; +stdenv.mkDerivation ( + swift._wrapperParams + // { + pname = "swift-wrapper"; + inherit (swift) version meta; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - # Wrapper and setup hook variables. - inherit swift; - inherit (swift) - swiftOs swiftArch - swiftModuleSubdir swiftLibSubdir - swiftStaticModuleSubdir swiftStaticLibSubdir; - swiftDriver = lib.optionalString useSwiftDriver "${swift-driver}/bin/swift-driver"; + # Wrapper and setup hook variables. + inherit swift; + inherit (swift) + swiftOs + swiftArch + swiftModuleSubdir + swiftLibSubdir + swiftStaticModuleSubdir + swiftStaticLibSubdir + ; + swiftDriver = lib.optionalString useSwiftDriver "${swift-driver}/bin/swift-driver"; - env.darwinMinVersion = lib.optionalString stdenv.targetPlatform.isDarwin ( - stdenv.targetPlatform.darwinMinVersion - ); + env.darwinMinVersion = lib.optionalString stdenv.targetPlatform.isDarwin ( + stdenv.targetPlatform.darwinMinVersion + ); - passAsFile = [ "buildCommand" ]; - buildCommand = '' - mkdir -p $out/bin $out/nix-support + passAsFile = [ "buildCommand" ]; + buildCommand = '' + mkdir -p $out/bin $out/nix-support - # Symlink all Swift binaries first. - # NOTE: This specifically omits clang binaries. We want to hide these for - # private use by Swift only. - ln -s -t $out/bin/ $swift/bin/swift* + # Symlink all Swift binaries first. + # NOTE: This specifically omits clang binaries. We want to hide these for + # private use by Swift only. + ln -s -t $out/bin/ $swift/bin/swift* - # Replace specific binaries with wrappers. - for executable in swift swiftc swift-frontend; do - export prog=$swift/bin/$executable - rm $out/bin/$executable - substituteAll '${./wrapper.sh}' $out/bin/$executable - chmod a+x $out/bin/$executable - done + # Replace specific binaries with wrappers. + for executable in swift swiftc swift-frontend; do + export prog=$swift/bin/$executable + rm $out/bin/$executable + substituteAll '${./wrapper.sh}' $out/bin/$executable + chmod a+x $out/bin/$executable + done - ${lib.optionalString useSwiftDriver '' - # Symlink swift-driver executables. - ln -s -t $out/bin/ ${swift-driver}/bin/* - ''} + ${lib.optionalString useSwiftDriver '' + # Symlink swift-driver executables. + ln -s -t $out/bin/ ${swift-driver}/bin/* + ''} - ln -s ${swift.man} $man + ln -s ${swift.man} $man - # This link is here because various tools (swiftpm) check for stdlib - # relative to the swift compiler. It's fine if this is for build-time - # stuff, but we should patch all cases were it would end up in an output. - ln -s ${swift.lib}/lib $out/lib + # This link is here because various tools (swiftpm) check for stdlib + # relative to the swift compiler. It's fine if this is for build-time + # stuff, but we should patch all cases were it would end up in an output. + ln -s ${swift.lib}/lib $out/lib - substituteAll ${./setup-hook.sh} $out/nix-support/setup-hook + substituteAll ${./setup-hook.sh} $out/nix-support/setup-hook - # Propagate any propagated inputs from the unwrapped Swift compiler, if any. - if [ -e "$swift/nix-support" ]; then - for input in "$swift/nix-support/"*propagated*; do - cp "$input" "$out/nix-support/$(basename "$input")" - done - fi - ''; + # Propagate any propagated inputs from the unwrapped Swift compiler, if any. + if [ -e "$swift/nix-support" ]; then + for input in "$swift/nix-support/"*propagated*; do + cp "$input" "$out/nix-support/$(basename "$input")" + done + fi + ''; - passthru = { - inherit swift; - inherit (swift) swiftOs swiftArch swiftModuleSubdir swiftLibSubdir; - }; -}) + passthru = { + inherit swift; + inherit (swift) + swiftOs + swiftArch + swiftModuleSubdir + swiftLibSubdir + ; + }; + } +) diff --git a/pkgs/development/compilers/swift/xctest/default.nix b/pkgs/development/compilers/swift/xctest/default.nix index f6f4cdacaed116..59390318c6c4d8 100644 --- a/pkgs/development/compilers/swift/xctest/default.nix +++ b/pkgs/development/compilers/swift/xctest/default.nix @@ -1,16 +1,18 @@ -{ lib -, stdenv -, callPackage -, cmake -, ninja -, swift -, Foundation -, DarwinTools +{ + lib, + stdenv, + callPackage, + cmake, + ninja, + swift, + Foundation, + DarwinTools, }: let sources = callPackage ../sources.nix { }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "swift-corelibs-xctest"; inherit (sources) version; @@ -18,8 +20,11 @@ in stdenv.mkDerivation { outputs = [ "out" ]; - nativeBuildInputs = [ cmake ninja swift ] - ++ lib.optional stdenv.hostPlatform.isDarwin DarwinTools; # sw_vers + nativeBuildInputs = [ + cmake + ninja + swift + ] ++ lib.optional stdenv.hostPlatform.isDarwin DarwinTools; # sw_vers buildInputs = [ Foundation ]; postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' diff --git a/pkgs/development/compilers/temurin-bin/jdk-darwin-base.nix b/pkgs/development/compilers/temurin-bin/jdk-darwin-base.nix index 836b282b0e49f2..c4234ab3fda9a1 100644 --- a/pkgs/development/compilers/temurin-bin/jdk-darwin-base.nix +++ b/pkgs/development/compilers/temurin-bin/jdk-darwin-base.nix @@ -1,32 +1,37 @@ -{ name-prefix ? "temurin" -, brand-name ? "Eclipse Temurin" -, sourcePerArch -, knownVulnerabilities ? [ ] +{ + name-prefix ? "temurin", + brand-name ? "Eclipse Temurin", + sourcePerArch, + knownVulnerabilities ? [ ], }: -{ swingSupport ? true # not used for now -, lib -, stdenv -, fetchurl -, setJavaClassPath +{ + swingSupport ? true, # not used for now + lib, + stdenv, + fetchurl, + setJavaClassPath, }: let cpuName = stdenv.hostPlatform.parsed.cpu.name; validCpuTypes = builtins.attrNames lib.systems.parse.cpuTypes; - providedCpuTypes = builtins.filter - (arch: builtins.elem arch validCpuTypes) - (builtins.attrNames sourcePerArch); + providedCpuTypes = builtins.filter (arch: builtins.elem arch validCpuTypes) ( + builtins.attrNames sourcePerArch + ); result = stdenv.mkDerivation { pname = - if sourcePerArch.packageType == "jdk" - then "${name-prefix}-bin" - else "${name-prefix}-${sourcePerArch.packageType}-bin"; - version = - sourcePerArch.${cpuName}.version or (throw "unsupported CPU ${cpuName}"); + if sourcePerArch.packageType == "jdk" then + "${name-prefix}-bin" + else + "${name-prefix}-${sourcePerArch.packageType}-bin"; + version = sourcePerArch.${cpuName}.version or (throw "unsupported CPU ${cpuName}"); src = fetchurl { - inherit (sourcePerArch.${cpuName} or (throw "unsupported system ${stdenv.hostPlatform.system}")) url sha256; + inherit (sourcePerArch.${cpuName} or (throw "unsupported system ${stdenv.hostPlatform.system}")) + url + sha256 + ; }; # See: https://github.com/NixOS/patchelf/issues/10 @@ -66,7 +71,10 @@ let meta = with lib; { license = licenses.gpl2Classpath; - sourceProvenance = with sourceTypes; [ binaryNativeCode binaryBytecode ]; + sourceProvenance = with sourceTypes; [ + binaryNativeCode + binaryBytecode + ]; description = "${brand-name}, prebuilt OpenJDK binary"; platforms = builtins.map (arch: arch + "-darwin") providedCpuTypes; # some inherit jre.meta.platforms maintainers = with maintainers; [ taku0 ] ++ lib.teams.java.members; diff --git a/pkgs/development/compilers/temurin-bin/jdk-darwin.nix b/pkgs/development/compilers/temurin-bin/jdk-darwin.nix index 8363905118f8e8..1f5c42d75032e7 100644 --- a/pkgs/development/compilers/temurin-bin/jdk-darwin.nix +++ b/pkgs/development/compilers/temurin-bin/jdk-darwin.nix @@ -4,8 +4,8 @@ let sources = (lib.importJSON ./sources.json).hotspot.mac; common = opts: callPackage (import ./jdk-darwin-base.nix opts) { }; - # EOL = [ "This JDK version has reached End of Life." ]; in +# EOL = [ "This JDK version has reached End of Life." ]; { jdk-8 = common { sourcePerArch = sources.jdk.openjdk8; }; jre-8 = common { sourcePerArch = sources.jre.openjdk8; }; diff --git a/pkgs/development/compilers/temurin-bin/jdk-linux-base.nix b/pkgs/development/compilers/temurin-bin/jdk-linux-base.nix index b166d3c0738bc4..581dcdcee4f343 100644 --- a/pkgs/development/compilers/temurin-bin/jdk-linux-base.nix +++ b/pkgs/development/compilers/temurin-bin/jdk-linux-base.nix @@ -1,55 +1,59 @@ -{ name-prefix ? "temurin" -, brand-name ? "Eclipse Temurin" -, sourcePerArch -, knownVulnerabilities ? [ ] +{ + name-prefix ? "temurin", + brand-name ? "Eclipse Temurin", + sourcePerArch, + knownVulnerabilities ? [ ], }: -{ stdenv -, lib -, fetchurl -, autoPatchelfHook -, makeWrapper -, setJavaClassPath +{ + stdenv, + lib, + fetchurl, + autoPatchelfHook, + makeWrapper, + setJavaClassPath, # minimum dependencies -, alsa-lib -, fontconfig -, freetype -, libffi -, xorg -, zlib + alsa-lib, + fontconfig, + freetype, + libffi, + xorg, + zlib, # runtime dependencies -, cups + cups, # runtime dependencies for GTK+ Look and Feel # TODO(@sternenseemann): gtk3 fails to evaluate in pkgsCross.ghcjs.buildPackages # which should be fixable, this is a no-rebuild workaround for GHC. -, gtkSupport ? !stdenv.targetPlatform.isGhcjs -, cairo -, glib -, gtk3 + gtkSupport ? !stdenv.targetPlatform.isGhcjs, + cairo, + glib, + gtk3, }: let cpuName = stdenv.hostPlatform.parsed.cpu.name; - runtimeDependencies = [ - cups - ] ++ lib.optionals gtkSupport [ - cairo - glib - gtk3 - ]; + runtimeDependencies = + [ + cups + ] + ++ lib.optionals gtkSupport [ + cairo + glib + gtk3 + ]; runtimeLibraryPath = lib.makeLibraryPath runtimeDependencies; validCpuTypes = builtins.attrNames lib.systems.parse.cpuTypes; - providedCpuTypes = builtins.filter - (arch: builtins.elem arch validCpuTypes) - (builtins.attrNames sourcePerArch); + providedCpuTypes = builtins.filter (arch: builtins.elem arch validCpuTypes) ( + builtins.attrNames sourcePerArch + ); result = stdenv.mkDerivation { pname = - if sourcePerArch.packageType == "jdk" - then "${name-prefix}-bin" - else "${name-prefix}-${sourcePerArch.packageType}-bin"; + if sourcePerArch.packageType == "jdk" then + "${name-prefix}-bin" + else + "${name-prefix}-${sourcePerArch.packageType}-bin"; - version = - sourcePerArch.${cpuName}.version or (throw "unsupported CPU ${cpuName}"); + version = sourcePerArch.${cpuName}.version or (throw "unsupported CPU ${cpuName}"); src = fetchurl { inherit (sourcePerArch.${cpuName}) url sha256; @@ -68,7 +72,10 @@ let zlib ] ++ lib.optional stdenv.hostPlatform.isAarch32 libffi; - nativeBuildInputs = [ autoPatchelfHook makeWrapper ]; + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + ]; # See: https://github.com/NixOS/patchelf/issues/10 dontStrip = 1; @@ -124,7 +131,10 @@ let meta = with lib; { license = licenses.gpl2Classpath; - sourceProvenance = with sourceTypes; [ binaryNativeCode binaryBytecode ]; + sourceProvenance = with sourceTypes; [ + binaryNativeCode + binaryBytecode + ]; description = "${brand-name}, prebuilt OpenJDK binary"; platforms = builtins.map (arch: arch + "-linux") providedCpuTypes; # some inherit jre.meta.platforms maintainers = with maintainers; [ taku0 ] ++ lib.teams.java.members; diff --git a/pkgs/development/compilers/temurin-bin/jdk-linux.nix b/pkgs/development/compilers/temurin-bin/jdk-linux.nix index 2c633f150fdb05..4ed06b98198b24 100644 --- a/pkgs/development/compilers/temurin-bin/jdk-linux.nix +++ b/pkgs/development/compilers/temurin-bin/jdk-linux.nix @@ -1,12 +1,16 @@ -{ stdenv, lib, callPackage }: +{ + stdenv, + lib, + callPackage, +}: let variant = if stdenv.hostPlatform.isMusl then "alpine-linux" else "linux"; sources = (lib.importJSON ./sources.json).hotspot.${variant}; common = opts: callPackage (import ./jdk-linux-base.nix opts) { }; - # EOL = [ "This JDK version has reached End of Life." ]; in +# EOL = [ "This JDK version has reached End of Life." ]; { jdk-8 = common { sourcePerArch = sources.jdk.openjdk8; }; jre-8 = common { sourcePerArch = sources.jre.openjdk8; }; diff --git a/pkgs/development/compilers/terra/default.nix b/pkgs/development/compilers/terra/default.nix index 4193ab53164c5c..0a455d45ce0fc2 100644 --- a/pkgs/development/compilers/terra/default.nix +++ b/pkgs/development/compilers/terra/default.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, llvmPackages_16, ncurses, cmake, libxml2 -, symlinkJoin, cudaPackages, enableCUDA ? false -, libffi, libobjc, libpfm, Cocoa, Foundation +{ + lib, + stdenv, + fetchFromGitHub, + llvmPackages_16, + ncurses, + cmake, + libxml2, + symlinkJoin, + cudaPackages, + enableCUDA ? false, + libffi, + libobjc, + libpfm, + Cocoa, + Foundation, }: let @@ -31,7 +44,8 @@ let clangVersion = llvmPackages.clang-unwrapped.version; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "terra"; version = "1.1.0"; @@ -43,30 +57,44 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ llvmMerged ncurses libffi libxml2 ] + buildInputs = + [ + llvmMerged + ncurses + libffi + libxml2 + ] ++ lib.optionals enableCUDA [ cuda ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) libpfm - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libobjc Cocoa Foundation ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + Cocoa + Foundation + ]; - cmakeFlags = let - resourceDir = "${llvmMerged}/lib/clang/" + ( - if lib.versionOlder clangVersion "16" - then - clangVersion - else - lib.versions.major clangVersion - ); - in [ - "-DHAS_TERRA_VERSION=0" - "-DTERRA_VERSION=${version}" - "-DTERRA_LUA=luajit" - "-DTERRA_SKIP_LUA_DOWNLOAD=ON" - "-DCLANG_RESOURCE_DIR=${resourceDir}" - ] ++ lib.optional enableCUDA "-DTERRA_ENABLE_CUDA=ON"; + cmakeFlags = + let + resourceDir = + "${llvmMerged}/lib/clang/" + + (if lib.versionOlder clangVersion "16" then clangVersion else lib.versions.major clangVersion); + in + [ + "-DHAS_TERRA_VERSION=0" + "-DTERRA_VERSION=${version}" + "-DTERRA_LUA=luajit" + "-DTERRA_SKIP_LUA_DOWNLOAD=ON" + "-DCLANG_RESOURCE_DIR=${resourceDir}" + ] + ++ lib.optional enableCUDA "-DTERRA_ENABLE_CUDA=ON"; doCheck = true; hardeningDisable = [ "fortify" ]; - outputs = [ "bin" "dev" "out" "static" ]; + outputs = [ + "bin" + "dev" + "out" + "static" + ]; patches = [ ./nix-cflags.patch ]; @@ -95,7 +123,12 @@ in stdenv.mkDerivation rec { description = "Low-level counterpart to Lua"; homepage = "https://terralang.org/"; platforms = platforms.all; - maintainers = with maintainers; [ jb55 seylerius thoughtpolice elliottslaughter ]; + maintainers = with maintainers; [ + jb55 + seylerius + thoughtpolice + elliottslaughter + ]; license = licenses.mit; # never built on aarch64-darwin since first introduction in nixpkgs # Linux Aarch64 broken above LLVM11 diff --git a/pkgs/development/compilers/teyjus/default.nix b/pkgs/development/compilers/teyjus/default.nix index a8dc7b319c51f5..f0cbb2e8b8e871 100644 --- a/pkgs/development/compilers/teyjus/default.nix +++ b/pkgs/development/compilers/teyjus/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildDunePackage, flex, bison }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + flex, + bison, +}: buildDunePackage rec { pname = "teyjus"; @@ -13,7 +19,10 @@ buildDunePackage rec { strictDeps = true; - nativeBuildInputs = [ flex bison ]; + nativeBuildInputs = [ + flex + bison + ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/development/compilers/tinycc/default.nix b/pkgs/development/compilers/tinycc/default.nix index 65eea0a48e465f..1f848fe9a9a5ca 100644 --- a/pkgs/development/compilers/tinycc/default.nix +++ b/pkgs/development/compilers/tinycc/default.nix @@ -1,11 +1,12 @@ -{ lib -, copyPkgconfigItems -, fetchFromRepoOrCz -, makePkgconfigItem -, perl -, stdenv -, texinfo -, which +{ + lib, + copyPkgconfigItems, + fetchFromRepoOrCz, + makePkgconfigItem, + perl, + stdenv, + texinfo, + which, }: stdenv.mkDerivation (finalAttrs: { @@ -18,7 +19,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-jY0P2GErmo//YBaz6u4/jj/voOE3C2JaIDRmo0orXN8="; }; - outputs = [ "out" "info" "man" ]; + outputs = [ + "out" + "info" + "man" + ]; nativeBuildInputs = [ copyPkgconfigItems @@ -29,60 +34,68 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - pkgconfigItems = let - libtcc-pcitem = { - name = "libtcc"; - inherit (finalAttrs) version; - cflags = [ "-I${libtcc-pcitem.variables.includedir}" ]; - libs = [ - "-L${libtcc-pcitem.variables.libdir}" - "-Wl,--rpath ${libtcc-pcitem.variables.libdir}" - "-ltcc" - ]; - variables = { - prefix = "${placeholder "out"}"; - includedir = "${placeholder "dev"}/include"; - libdir = "${placeholder "lib"}/lib"; + pkgconfigItems = + let + libtcc-pcitem = { + name = "libtcc"; + inherit (finalAttrs) version; + cflags = [ "-I${libtcc-pcitem.variables.includedir}" ]; + libs = [ + "-L${libtcc-pcitem.variables.libdir}" + "-Wl,--rpath ${libtcc-pcitem.variables.libdir}" + "-ltcc" + ]; + variables = { + prefix = "${placeholder "out"}"; + includedir = "${placeholder "dev"}/include"; + libdir = "${placeholder "lib"}/lib"; + }; + description = "Tiny C compiler backend"; }; - description = "Tiny C compiler backend"; - }; - in [ - (makePkgconfigItem libtcc-pcitem) - ]; + in + [ + (makePkgconfigItem libtcc-pcitem) + ]; postPatch = '' patchShebangs texi2pod.pl ''; - configureFlags = [ - "--cc=$CC" - "--ar=$AR" - "--crtprefix=${lib.getLib stdenv.cc.libc}/lib" - "--sysincludepaths=${lib.getDev stdenv.cc.libc}/include:{B}/include" - "--libpaths=${lib.getLib stdenv.cc.libc}/lib" - # build cross compilers - "--enable-cross" - ] ++ lib.optionals stdenv.hostPlatform.isMusl [ - "--config-musl" - ]; - - preConfigure = let - # To avoid "malformed 32-bit x.y.z" error on mac when using clang - versionIsClean = version: - builtins.match "^[0-9]\\.+[0-9]+\\.[0-9]+" version != null; - in '' - ${ - if stdenv.hostPlatform.isDarwin && ! versionIsClean finalAttrs.version - then "echo 'not overwriting VERSION since it would upset ld'" - else "echo ${finalAttrs.version} > VERSION" - } - configureFlagsArray+=("--elfinterp=$(< $NIX_CC/nix-support/dynamic-linker)") - ''; + configureFlags = + [ + "--cc=$CC" + "--ar=$AR" + "--crtprefix=${lib.getLib stdenv.cc.libc}/lib" + "--sysincludepaths=${lib.getDev stdenv.cc.libc}/include:{B}/include" + "--libpaths=${lib.getLib stdenv.cc.libc}/lib" + # build cross compilers + "--enable-cross" + ] + ++ lib.optionals stdenv.hostPlatform.isMusl [ + "--config-musl" + ]; + + preConfigure = + let + # To avoid "malformed 32-bit x.y.z" error on mac when using clang + versionIsClean = version: builtins.match "^[0-9]\\.+[0-9]+\\.[0-9]+" version != null; + in + '' + ${ + if stdenv.hostPlatform.isDarwin && !versionIsClean finalAttrs.version then + "echo 'not overwriting VERSION since it would upset ld'" + else + "echo ${finalAttrs.version} > VERSION" + } + configureFlagsArray+=("--elfinterp=$(< $NIX_CC/nix-support/dynamic-linker)") + ''; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-error=implicit-int" - "-Wno-error=int-conversion" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-error=implicit-int" + "-Wno-error=int-conversion" + ] + ); # Test segfault for static build doCheck = !stdenv.hostPlatform.isStatic; @@ -119,7 +132,10 @@ stdenv.mkDerivation (finalAttrs: { ''; license = with lib.licenses; [ lgpl21Only ]; mainProgram = "tcc"; - maintainers = with lib.maintainers; [ joachifm AndersonTorres ]; + maintainers = with lib.maintainers; [ + joachifm + AndersonTorres + ]; platforms = lib.platforms.unix; # https://www.mail-archive.com/tinycc-devel@nongnu.org/msg10199.html broken = stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64; diff --git a/pkgs/development/compilers/tinygo/default.nix b/pkgs/development/compilers/tinygo/default.nix index 339a2abb7fa5a0..1829c3be1b4a88 100644 --- a/pkgs/development/compilers/tinygo/default.nix +++ b/pkgs/development/compilers/tinygo/default.nix @@ -1,22 +1,28 @@ -{ stdenv -, lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, llvmPackages -, go -, xar -, binaryen -, avrdude -, gdb -, openocd -, runCommand -, tinygoTests ? [ "smoketest" ] +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + llvmPackages, + go, + xar, + binaryen, + avrdude, + gdb, + openocd, + runCommand, + tinygoTests ? [ "smoketest" ], }: let llvmMajor = lib.versions.major llvm.version; - inherit (llvmPackages) llvm clang compiler-rt lld; + inherit (llvmPackages) + llvm + clang + compiler-rt + lld + ; # only doing this because only on darwin placing clang.cc in nativeBuildInputs # doesn't build @@ -52,9 +58,14 @@ buildGoModule rec { ]; nativeCheckInputs = [ binaryen ]; - nativeBuildInputs = [ makeWrapper lld ]; - buildInputs = [ llvm clang.cc ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ xar ]; + nativeBuildInputs = [ + makeWrapper + lld + ]; + buildInputs = [ + llvm + clang.cc + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ xar ]; doCheck = (stdenv.buildPlatform.canExecute stdenv.hostPlatform); inherit tinygoTests; @@ -111,8 +122,14 @@ buildGoModule rec { ''; # GDB upstream does not support ARM darwin - runtimeDeps = [ go clang.cc lld avrdude openocd binaryen ] - ++ lib.optionals (!(stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64)) [ gdb ]; + runtimeDeps = [ + go + clang.cc + lld + avrdude + openocd + binaryen + ] ++ lib.optionals (!(stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64)) [ gdb ]; installPhase = '' runHook preInstall @@ -120,7 +137,7 @@ buildGoModule rec { make build/release USE_SYSTEM_BINARYEN=1 wrapProgram $out/bin/tinygo \ - --prefix PATH : ${lib.makeBinPath runtimeDeps } + --prefix PATH : ${lib.makeBinPath runtimeDeps} runHook postInstall ''; @@ -129,6 +146,9 @@ buildGoModule rec { homepage = "https://tinygo.org/"; description = "Go compiler for small places"; license = licenses.bsd3; - maintainers = with maintainers; [ Madouura muscaln ]; + maintainers = with maintainers; [ + Madouura + muscaln + ]; }; } diff --git a/pkgs/development/compilers/urweb/default.nix b/pkgs/development/compilers/urweb/default.nix index f96cce8c53f1b8..f916e0285dfafa 100644 --- a/pkgs/development/compilers/urweb/default.nix +++ b/pkgs/development/compilers/urweb/default.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchurl, file, openssl, mlton -, libmysqlclient, postgresql, sqlite, gcc, icu +{ + lib, + stdenv, + fetchurl, + file, + openssl, + mlton, + libmysqlclient, + postgresql, + sqlite, + gcc, + icu, }: stdenv.mkDerivation rec { @@ -11,7 +21,14 @@ stdenv.mkDerivation rec { sha256 = "0qh6wcxfk5kf735i5gqwnkdirnnmqhnnpkfz96gz144dgz2i0c5c"; }; - buildInputs = [ openssl mlton libmysqlclient postgresql sqlite icu ]; + buildInputs = [ + openssl + mlton + libmysqlclient + postgresql + sqlite + icu + ]; prePatch = '' sed -e 's@/usr/bin/file@${file}/bin/file@g' -i configure @@ -43,9 +60,12 @@ stdenv.mkDerivation rec { meta = { description = "Advanced purely-functional web programming language"; mainProgram = "urweb"; - homepage = "http://www.impredicative.com/ur/"; - license = lib.licenses.bsd3; - platforms = lib.platforms.linux ++ lib.platforms.darwin; - maintainers = [ lib.maintainers.thoughtpolice lib.maintainers.sheganinans ]; + homepage = "http://www.impredicative.com/ur/"; + license = lib.licenses.bsd3; + platforms = lib.platforms.linux ++ lib.platforms.darwin; + maintainers = [ + lib.maintainers.thoughtpolice + lib.maintainers.sheganinans + ]; }; } diff --git a/pkgs/development/compilers/vala/default.nix b/pkgs/development/compilers/vala/default.nix index 96b995d64b6c32..0285a535546114 100644 --- a/pkgs/development/compilers/vala/default.nix +++ b/pkgs/development/compilers/vala/default.nix @@ -1,90 +1,136 @@ -{ stdenv, lib, fetchurl, pkg-config, flex, bison, libxslt, autoconf, autoreconfHook -, gnome, graphviz, glib, libiconv, libintl, libtool, expat, substituteAll, vala, gobject-introspection +{ + stdenv, + lib, + fetchurl, + pkg-config, + flex, + bison, + libxslt, + autoconf, + autoreconfHook, + gnome, + graphviz, + glib, + libiconv, + libintl, + libtool, + expat, + substituteAll, + vala, + gobject-introspection, }: let - generic = lib.makeOverridable ({ - version, hash, - extraNativeBuildInputs ? [], - extraBuildInputs ? [], - withGraphviz ? false - }: - let - # Build vala (valadoc) without graphviz support. Inspired from the openembedded-core project. - # https://github.com/openembedded/openembedded-core/blob/a5440d4288e09d3e/meta/recipes-devtools/vala/vala/disable-graphviz.patch - graphvizPatch = - { - "0.56" = ./disable-graphviz-0.56.8.patch; - }.${lib.versions.majorMinor version} or (throw "no graphviz patch for this version of vala"); - - disableGraphviz = !withGraphviz; - - in stdenv.mkDerivation rec { - pname = "vala"; - inherit version; - - setupHook = substituteAll { - src = ./setup-hook.sh; - apiVersion = lib.versions.majorMinor version; - }; - - src = fetchurl { - url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; - inherit hash; - }; - - postPatch = '' - patchShebangs tests - ''; - - # If we're disabling graphviz, apply the patches and corresponding - # configure flag. We also need to override the path to the valac compiler - # so that it can be used to regenerate documentation. - patches = lib.optionals disableGraphviz [ graphvizPatch ]; - configureFlags = lib.optional disableGraphviz "--disable-graphviz"; - # when cross-compiling ./compiler/valac is valac for host - # so add the build vala in nativeBuildInputs - preBuild = lib.optionalString (disableGraphviz && (stdenv.buildPlatform == stdenv.hostPlatform)) "buildFlagsArray+=(\"VALAC=$(pwd)/compiler/valac\")"; - - outputs = [ "out" "devdoc" ]; - - nativeBuildInputs = [ - pkg-config flex bison libxslt gobject-introspection - ] ++ lib.optional (stdenv.hostPlatform.isDarwin) expat - ++ lib.optional disableGraphviz autoreconfHook # if we changed our ./configure script, need to reconfigure - ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ vala ] - ++ extraNativeBuildInputs; - - buildInputs = [ - glib libiconv libintl - ] ++ lib.optional (withGraphviz) graphviz - ++ extraBuildInputs; - - enableParallelBuilding = true; - - doCheck = false; # fails, requires dbus daemon - - passthru = { - updateScript = gnome.updateScript { - attrPath = - let - roundUpToEven = num: num + lib.mod num 2; - in "${pname}_${lib.versions.major version}_${builtins.toString (roundUpToEven (lib.toInt (lib.versions.minor version)))}"; - packageName = pname; - freeze = true; + generic = lib.makeOverridable ( + { + version, + hash, + extraNativeBuildInputs ? [ ], + extraBuildInputs ? [ ], + withGraphviz ? false, + }: + let + # Build vala (valadoc) without graphviz support. Inspired from the openembedded-core project. + # https://github.com/openembedded/openembedded-core/blob/a5440d4288e09d3e/meta/recipes-devtools/vala/vala/disable-graphviz.patch + graphvizPatch = + { + "0.56" = ./disable-graphviz-0.56.8.patch; + } + .${lib.versions.majorMinor version} or (throw "no graphviz patch for this version of vala"); + + disableGraphviz = !withGraphviz; + + in + stdenv.mkDerivation rec { + pname = "vala"; + inherit version; + + setupHook = substituteAll { + src = ./setup-hook.sh; + apiVersion = lib.versions.majorMinor version; }; - }; - - meta = with lib; { - description = "Compiler for GObject type system"; - homepage = "https://vala.dev"; - license = licenses.lgpl21Plus; - platforms = platforms.unix; - maintainers = with maintainers; [ antono jtojnar ] ++ teams.pantheon.members; - }; - }); - -in rec { + + src = fetchurl { + url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; + inherit hash; + }; + + postPatch = '' + patchShebangs tests + ''; + + # If we're disabling graphviz, apply the patches and corresponding + # configure flag. We also need to override the path to the valac compiler + # so that it can be used to regenerate documentation. + patches = lib.optionals disableGraphviz [ graphvizPatch ]; + configureFlags = lib.optional disableGraphviz "--disable-graphviz"; + # when cross-compiling ./compiler/valac is valac for host + # so add the build vala in nativeBuildInputs + preBuild = lib.optionalString ( + disableGraphviz && (stdenv.buildPlatform == stdenv.hostPlatform) + ) "buildFlagsArray+=(\"VALAC=$(pwd)/compiler/valac\")"; + + outputs = [ + "out" + "devdoc" + ]; + + nativeBuildInputs = + [ + pkg-config + flex + bison + libxslt + gobject-introspection + ] + ++ lib.optional (stdenv.hostPlatform.isDarwin) expat + ++ lib.optional disableGraphviz autoreconfHook # if we changed our ./configure script, need to reconfigure + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ vala ] + ++ extraNativeBuildInputs; + + buildInputs = + [ + glib + libiconv + libintl + ] + ++ lib.optional (withGraphviz) graphviz + ++ extraBuildInputs; + + enableParallelBuilding = true; + + doCheck = false; # fails, requires dbus daemon + + passthru = { + updateScript = gnome.updateScript { + attrPath = + let + roundUpToEven = num: num + lib.mod num 2; + in + "${pname}_${lib.versions.major version}_${builtins.toString (roundUpToEven (lib.toInt (lib.versions.minor version)))}"; + packageName = pname; + freeze = true; + }; + }; + + meta = with lib; { + description = "Compiler for GObject type system"; + homepage = "https://vala.dev"; + license = licenses.lgpl21Plus; + platforms = platforms.unix; + maintainers = + with maintainers; + [ + antono + jtojnar + ] + ++ teams.pantheon.members; + }; + } + ); + +in +rec { vala_0_56 = generic { version = "0.56.17"; hash = "sha256-JhAMTk7wBJxhknXxQNl89WWIPQDHVDyCvM5aQmk07Wo="; diff --git a/pkgs/development/compilers/vyper/default.nix b/pkgs/development/compilers/vyper/default.nix index 89973eb524ee34..8f523f14735b60 100644 --- a/pkgs/development/compilers/vyper/default.nix +++ b/pkgs/development/compilers/vyper/default.nix @@ -1,18 +1,19 @@ -{ lib -, asttokens -, buildPythonPackage -, cbor2 -, fetchPypi -, git -, importlib-metadata -, packaging -, pycryptodome -, pythonOlder -, recommonmark -, setuptools-scm -, sphinx -, sphinx-rtd-theme -, writeText +{ + lib, + asttokens, + buildPythonPackage, + cbor2, + fetchPypi, + git, + importlib-metadata, + packaging, + pycryptodome, + pythonOlder, + recommonmark, + setuptools-scm, + sphinx, + sphinx-rtd-theme, + writeText, }: let diff --git a/pkgs/development/compilers/x11basic/default.nix b/pkgs/development/compilers/x11basic/default.nix index db1a0bc3ba8288..e90eb300ffdc87 100644 --- a/pkgs/development/compilers/x11basic/default.nix +++ b/pkgs/development/compilers/x11basic/default.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchFromGitHub -, automake, autoconf, readline -, libX11, bluez, SDL2 +{ + lib, + stdenv, + fetchFromGitHub, + automake, + autoconf, + readline, + libX11, + bluez, + SDL2, }: stdenv.mkDerivation rec { @@ -14,9 +21,15 @@ stdenv.mkDerivation rec { sha256 = "1hpxzdqnjl1fiwgs2vrjg4kxm29c7pqwk3g1m4p5pm4x33a3d1q2"; }; - nativeBuildInputs = [ autoconf automake ]; + nativeBuildInputs = [ + autoconf + automake + ]; buildInputs = [ - readline libX11 SDL2 bluez + readline + libX11 + SDL2 + bluez ]; preConfigure = "cd src;autoconf"; diff --git a/pkgs/development/compilers/yosys/default.nix b/pkgs/development/compilers/yosys/default.nix index 617e6b862fb5ab..ff0b276bebb4eb 100644 --- a/pkgs/development/compilers/yosys/default.nix +++ b/pkgs/development/compilers/yosys/default.nix @@ -1,23 +1,24 @@ -{ stdenv -, lib -, bison -, boost -, fetchFromGitHub -, flex -, libffi -, makeWrapper -, pkg-config -, python3 -, readline -, symlinkJoin -, tcl -, iverilog -, zlib -, yosys -, yosys-bluespec -, yosys-ghdl -, yosys-symbiflow -, enablePython ? true # enable python binding +{ + stdenv, + lib, + bison, + boost, + fetchFromGitHub, + flex, + libffi, + makeWrapper, + pkg-config, + python3, + readline, + symlinkJoin, + tcl, + iverilog, + zlib, + yosys, + yosys-bluespec, + yosys-ghdl, + yosys-symbiflow, + enablePython ? true, # enable python binding }: # NOTE: as of late 2020, yosys has switched to an automation robot that @@ -47,14 +48,17 @@ let # fasm # bluespec # ]); - withPlugins = plugins: + withPlugins = + plugins: let paths = lib.closePropagation plugins; - module_flags = with builtins; concatStringsSep " " - (map (n: "--add-flags -m --add-flags ${n.plugin}") plugins); - in lib.appendToName "with-plugins" ( symlinkJoin { + module_flags = + with builtins; + concatStringsSep " " (map (n: "--add-flags -m --add-flags ${n.plugin}") plugins); + in + lib.appendToName "with-plugins" (symlinkJoin { inherit (yosys) name; - paths = paths ++ [ yosys ] ; + paths = paths ++ [ yosys ]; nativeBuildInputs = [ makeWrapper ]; postBuild = '' wrapProgram $out/bin/yosys \ @@ -65,7 +69,7 @@ let allPlugins = { bluespec = yosys-bluespec; - ghdl = yosys-ghdl; + ghdl = yosys-ghdl; } // (yosys-symbiflow); boost_python = boost.override { @@ -73,15 +77,16 @@ let python = python3; }; -in stdenv.mkDerivation (finalAttrs: { - pname = "yosys"; +in +stdenv.mkDerivation (finalAttrs: { + pname = "yosys"; version = "0.47"; src = fetchFromGitHub { owner = "YosysHQ"; - repo = "yosys"; - rev = "refs/tags/${finalAttrs.version}"; - hash = "sha256-9u9aAPTZyt9vzZwryor3GRCGzs/mu2/XtM0XzV7uHfk="; + repo = "yosys"; + rev = "refs/tags/${finalAttrs.version}"; + hash = "sha256-9u9aAPTZyt9vzZwryor3GRCGzs/mu2/XtM0XzV7uHfk="; fetchSubmodules = true; leaveDotGit = true; postFetch = '' @@ -99,18 +104,24 @@ in stdenv.mkDerivation (finalAttrs: { }; enableParallelBuilding = true; - nativeBuildInputs = [ pkg-config bison flex ]; + nativeBuildInputs = [ + pkg-config + bison + flex + ]; propagatedBuildInputs = [ tcl readline libffi zlib - (python3.withPackages (pp: with pp; [ - click - ])) + (python3.withPackages ( + pp: with pp; [ + click + ] + )) ] ++ lib.optional enablePython boost_python; - makeFlags = [ "PREFIX=${placeholder "out"}"]; + makeFlags = [ "PREFIX=${placeholder "out"}" ]; patches = [ ./plugin-search-dirs.patch @@ -124,19 +135,21 @@ in stdenv.mkDerivation (finalAttrs: { patchShebangs tests ./misc/yosys-config.in ''; - preBuild = '' - chmod -R u+w . - make config-${if stdenv.cc.isClang or false then "clang" else "gcc"} - - if ! grep -q "YOSYS_VER := $version" Makefile; then - echo "ERROR: yosys version in Makefile isn't equivalent to version of the nix package (allegedly ${finalAttrs.version}), failing." - exit 1 - fi - '' + lib.optionalString enablePython '' - echo "ENABLE_PYOSYS := 1" >> Makefile.conf - echo "PYTHON_DESTDIR := $out/${python3.sitePackages}" >> Makefile.conf - echo "BOOST_PYTHON_LIB := -lboost_python${lib.versions.major python3.version}${lib.versions.minor python3.version}" >> Makefile.conf - ''; + preBuild = + '' + chmod -R u+w . + make config-${if stdenv.cc.isClang or false then "clang" else "gcc"} + + if ! grep -q "YOSYS_VER := $version" Makefile; then + echo "ERROR: yosys version in Makefile isn't equivalent to version of the nix package (allegedly ${finalAttrs.version}), failing." + exit 1 + fi + '' + + lib.optionalString enablePython '' + echo "ENABLE_PYOSYS := 1" >> Makefile.conf + echo "PYTHON_DESTDIR := $out/${python3.sitePackages}" >> Makefile.conf + echo "BOOST_PYTHON_LIB := -lboost_python${lib.versions.major python3.version}${lib.versions.minor python3.version}" >> Makefile.conf + ''; preCheck = '' # autotest.sh automatically compiles a utility during startup if it's out of date. @@ -157,9 +170,13 @@ in stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Open RTL synthesis framework and tools"; - homepage = "https://yosyshq.net/yosys/"; - license = licenses.isc; - platforms = platforms.all; - maintainers = with maintainers; [ shell thoughtpolice Luflosi ]; + homepage = "https://yosyshq.net/yosys/"; + license = licenses.isc; + platforms = platforms.all; + maintainers = with maintainers; [ + shell + thoughtpolice + Luflosi + ]; }; }) diff --git a/pkgs/development/compilers/yosys/plugins/bluespec.nix b/pkgs/development/compilers/yosys/plugins/bluespec.nix index 77d4ad8cf9dcd3..5a1a0ce3e21056 100644 --- a/pkgs/development/compilers/yosys/plugins/bluespec.nix +++ b/pkgs/development/compilers/yosys/plugins/bluespec.nix @@ -1,5 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config -, yosys, readline, zlib, bluespec +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + yosys, + readline, + zlib, + bluespec, }: stdenv.mkDerivation { @@ -8,13 +15,18 @@ stdenv.mkDerivation { plugin = "bluespec"; src = fetchFromGitHub { - owner = "thoughtpolice"; - repo = "yosys-bluespec"; - rev = "f6f4127a4e96e18080fd5362b6769fa3e24c76b1"; + owner = "thoughtpolice"; + repo = "yosys-bluespec"; + rev = "f6f4127a4e96e18080fd5362b6769fa3e24c76b1"; sha256 = "sha256-3cNFP/k4JsgLyUQHWU10Htl2Rh0staAcA3R4piD6hDE="; }; - buildInputs = [ yosys readline zlib bluespec ]; + buildInputs = [ + yosys + readline + zlib + bluespec + ]; nativeBuildInputs = [ pkg-config ]; doCheck = true; @@ -26,8 +38,8 @@ stdenv.mkDerivation { meta = with lib; { description = "Bluespec plugin for Yosys"; - license = licenses.isc; - platforms = platforms.all; + license = licenses.isc; + platforms = platforms.all; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/development/compilers/yosys/plugins/ghdl.nix b/pkgs/development/compilers/yosys/plugins/ghdl.nix index 2ec17f391a99e1..a12fd62ca2f826 100644 --- a/pkgs/development/compilers/yosys/plugins/ghdl.nix +++ b/pkgs/development/compilers/yosys/plugins/ghdl.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, yosys -, readline -, zlib -, ghdl +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + yosys, + readline, + zlib, + ghdl, }: stdenv.mkDerivation { @@ -15,9 +16,9 @@ stdenv.mkDerivation { plugin = "ghdl"; src = fetchFromGitHub { - owner = "ghdl"; - repo = "ghdl-yosys-plugin"; - rev = "c9b05e481423c55ffcbb856fd5296701f670808c"; + owner = "ghdl"; + repo = "ghdl-yosys-plugin"; + rev = "c9b05e481423c55ffcbb856fd5296701f670808c"; sha256 = "sha256-tT2+DXUtbJIBzBUBcyG2sz+3G+dTkciLVIczcRPr0Jw="; }; @@ -39,9 +40,9 @@ stdenv.mkDerivation { meta = with lib; { description = "GHDL plugin for Yosys"; - homepage = "https://github.com/ghdl/ghdl-yosys-plugin"; - license = licenses.isc; - platforms = platforms.all; + homepage = "https://github.com/ghdl/ghdl-yosys-plugin"; + license = licenses.isc; + platforms = platforms.all; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/development/compilers/yosys/plugins/symbiflow.nix b/pkgs/development/compilers/yosys/plugins/symbiflow.nix index 2afa372b6ec40a..82ff16fe5ed433 100644 --- a/pkgs/development/compilers/yosys/plugins/symbiflow.nix +++ b/pkgs/development/compilers/yosys/plugins/symbiflow.nix @@ -1,22 +1,24 @@ -{ fetchFromGitHub -, gtest -, lib -, python3 -, readline -, stdenv -, yosys -, zlib -, yosys-symbiflow -, pkg-config -}: let +{ + fetchFromGitHub, + gtest, + lib, + python3, + readline, + stdenv, + yosys, + zlib, + yosys-symbiflow, + pkg-config, +}: +let version = "1.20230906"; src = fetchFromGitHub { owner = "chipsalliance"; - repo = "yosys-f4pga-plugins"; - rev = "v${version}"; - hash = "sha256-XIn5wFw8i2njDN0Arua5BdZ0u1q6a/aJAs48YICehsc="; + repo = "yosys-f4pga-plugins"; + rev = "v${version}"; + hash = "sha256-XIn5wFw8i2njDN0Arua5BdZ0u1q6a/aJAs48YICehsc="; }; # Supported symbiflow plugins. @@ -38,62 +40,74 @@ static_gtest = gtest.overrideAttrs (old: { dontDisableStatic = true; disableHardening = [ "pie" ]; - cmakeFlags = old.cmakeFlags ++ ["-DBUILD_SHARED_LIBS=OFF"]; + cmakeFlags = old.cmakeFlags ++ [ "-DBUILD_SHARED_LIBS=OFF" ]; }); -in lib.genAttrs plugins (plugin: stdenv.mkDerivation (rec { - pname = "yosys-symbiflow-${plugin}-plugin"; - inherit src version plugin; - enableParallelBuilding = true; +in +lib.genAttrs plugins ( + plugin: + stdenv.mkDerivation (rec { + pname = "yosys-symbiflow-${plugin}-plugin"; + inherit src version plugin; + enableParallelBuilding = true; - nativeBuildInputs = [ python3 pkg-config ]; - buildInputs = [ - yosys - readline - zlib - ]; + nativeBuildInputs = [ + python3 + pkg-config + ]; + buildInputs = [ + yosys + readline + zlib + ]; - # xdc has an incorrect path to a test which has yet to be patched - doCheck = plugin != "xdc"; - nativeCheckInputs = [ static_gtest ]; + # xdc has an incorrect path to a test which has yet to be patched + doCheck = plugin != "xdc"; + nativeCheckInputs = [ static_gtest ]; - # A Makefile rule tries to wget-fetch a yosys script from github. - # Link the script from our yosys sources in preBuild instead, so that - # the Makefile rule is a no-op. - preBuild = '' - ln -s ${yosys.src}/passes/pmgen/pmgen.py pmgen.py - ''; + # A Makefile rule tries to wget-fetch a yosys script from github. + # Link the script from our yosys sources in preBuild instead, so that + # the Makefile rule is a no-op. + preBuild = '' + ln -s ${yosys.src}/passes/pmgen/pmgen.py pmgen.py + ''; - # Providing a symlink avoids the need for patching the test makefile - postUnpack = '' - mkdir -p source/third_party/googletest/build/ - ln -s ${static_gtest}/lib source/third_party/googletest/build/lib - ''; + # Providing a symlink avoids the need for patching the test makefile + postUnpack = '' + mkdir -p source/third_party/googletest/build/ + ln -s ${static_gtest}/lib source/third_party/googletest/build/lib + ''; - makeFlags = [ - "PLUGIN_LIST=${plugin}" - ]; + makeFlags = [ + "PLUGIN_LIST=${plugin}" + ]; - buildFlags = [ - "YOSYS_PLUGINS_DIR=\${out}/share/yosys/plugins/" - "YOSYS_DATA_DIR=\${out}/share/yosys/" - ]; + buildFlags = [ + "YOSYS_PLUGINS_DIR=\${out}/share/yosys/plugins/" + "YOSYS_DATA_DIR=\${out}/share/yosys/" + ]; - checkTarget = "test"; - checkFlags = [ - ( "NIX_YOSYS_PLUGIN_DIRS=\${NIX_BUILD_TOP}/source/${plugin}-plugin/build" - # sdc and xdc plugins use design introspection for their tests - + (lib.optionalString ( plugin == "sdc" || plugin == "xdc" ) - ":${yosys-symbiflow.design_introspection}/share/yosys/plugins/") - ) - ]; + checkTarget = "test"; + checkFlags = [ + ( + "NIX_YOSYS_PLUGIN_DIRS=\${NIX_BUILD_TOP}/source/${plugin}-plugin/build" + # sdc and xdc plugins use design introspection for their tests + + (lib.optionalString ( + plugin == "sdc" || plugin == "xdc" + ) ":${yosys-symbiflow.design_introspection}/share/yosys/plugins/") + ) + ]; - installFlags = buildFlags; + installFlags = buildFlags; - meta = with lib; { - description = "Symbiflow ${plugin} plugin for Yosys"; - license = licenses.isc; - platforms = platforms.all; - maintainers = with maintainers; [ ollieB thoughtpolice ]; - }; -})) + meta = with lib; { + description = "Symbiflow ${plugin} plugin for Yosys"; + license = licenses.isc; + platforms = platforms.all; + maintainers = with maintainers; [ + ollieB + thoughtpolice + ]; + }; + }) +) diff --git a/pkgs/development/compilers/zig/hook.nix b/pkgs/development/compilers/zig/hook.nix index 67cfac263a75e7..99adbdeb2b7b0e 100644 --- a/pkgs/development/compilers/zig/hook.nix +++ b/pkgs/development/compilers/zig/hook.nix @@ -1,6 +1,7 @@ -{ lib -, makeSetupHook -, zig +{ + lib, + makeSetupHook, + zig, }: makeSetupHook { @@ -39,7 +40,10 @@ makeSetupHook { else "-Drelease-safe=true"; in - [ "-Dcpu=baseline" releaseType ]; + [ + "-Dcpu=baseline" + releaseType + ]; }; passthru = { inherit zig; }; diff --git a/pkgs/development/compilers/zulu/11.nix b/pkgs/development/compilers/zulu/11.nix index ce4d15629b8115..6f5d0b66767a33 100644 --- a/pkgs/development/compilers/zulu/11.nix +++ b/pkgs/development/compilers/zulu/11.nix @@ -1,42 +1,54 @@ -{ callPackage -, enableJavaFX ? false -, ... +{ + callPackage, + enableJavaFX ? false, + ... }@args: -callPackage ./common.nix ({ - # Details from https://www.azul.com/downloads/?version=java-11-lts&package=jdk - # Note that the latest build may differ by platform - dists = { - x86_64-linux = { - zuluVersion = "11.74.15"; - jdkVersion = "11.0.24"; - hash = - if enableJavaFX then "sha256-eP2BCD77uRmukd48+pDlIlhos9RjL9VYx8tpQdq2uNo=" - else "sha256-p6rA5pqZv2Sho+yW8IFJrAaaW72q766SLuOnRl/ZGLM="; - }; +callPackage ./common.nix ( + { + # Details from https://www.azul.com/downloads/?version=java-11-lts&package=jdk + # Note that the latest build may differ by platform + dists = { + x86_64-linux = { + zuluVersion = "11.74.15"; + jdkVersion = "11.0.24"; + hash = + if enableJavaFX then + "sha256-eP2BCD77uRmukd48+pDlIlhos9RjL9VYx8tpQdq2uNo=" + else + "sha256-p6rA5pqZv2Sho+yW8IFJrAaaW72q766SLuOnRl/ZGLM="; + }; - aarch64-linux = { - zuluVersion = "11.74.15"; - jdkVersion = "11.0.24"; - hash = - if enableJavaFX then "sha256-nAUjPk9gktO0UJk7gAKygq+ztSJY5wk+EoG1LgJidJ8=" - else "sha256-T0c+YwfEZcA3iJmBriyzxBM2SECcczG25XVApIlgM+E="; - }; + aarch64-linux = { + zuluVersion = "11.74.15"; + jdkVersion = "11.0.24"; + hash = + if enableJavaFX then + "sha256-nAUjPk9gktO0UJk7gAKygq+ztSJY5wk+EoG1LgJidJ8=" + else + "sha256-T0c+YwfEZcA3iJmBriyzxBM2SECcczG25XVApIlgM+E="; + }; - x86_64-darwin = { - zuluVersion = "11.74.15"; - jdkVersion = "11.0.24"; - hash = - if enableJavaFX then "sha256-hanQw2FWbqsmGR1WixbM0BNWGeXmS2vt9tbaaEY7D1c=" - else "sha256-CH6pVui0PInHMt+AJOE0T2hrAmEcLFRJvmR4KZuanaw="; - }; + x86_64-darwin = { + zuluVersion = "11.74.15"; + jdkVersion = "11.0.24"; + hash = + if enableJavaFX then + "sha256-hanQw2FWbqsmGR1WixbM0BNWGeXmS2vt9tbaaEY7D1c=" + else + "sha256-CH6pVui0PInHMt+AJOE0T2hrAmEcLFRJvmR4KZuanaw="; + }; - aarch64-darwin = { - zuluVersion = "11.74.15"; - jdkVersion = "11.0.24"; - hash = - if enableJavaFX then "sha256-WbzpfPgoT3CTazKBnI1Fg+q+YQP6MwCWkon6VOeLZsA=" - else "sha256-+KxFgHbBDxN1O3NCAzqqBztxXveYAjrPFVuoFL/2dRQ="; + aarch64-darwin = { + zuluVersion = "11.74.15"; + jdkVersion = "11.0.24"; + hash = + if enableJavaFX then + "sha256-WbzpfPgoT3CTazKBnI1Fg+q+YQP6MwCWkon6VOeLZsA=" + else + "sha256-+KxFgHbBDxN1O3NCAzqqBztxXveYAjrPFVuoFL/2dRQ="; + }; }; - }; -} // builtins.removeAttrs args [ "callPackage" ]) + } + // builtins.removeAttrs args [ "callPackage" ] +) diff --git a/pkgs/development/compilers/zulu/17.nix b/pkgs/development/compilers/zulu/17.nix index 3e94e824d55d99..622f75365b4f38 100644 --- a/pkgs/development/compilers/zulu/17.nix +++ b/pkgs/development/compilers/zulu/17.nix @@ -1,42 +1,54 @@ -{ callPackage -, enableJavaFX ? false -, ... +{ + callPackage, + enableJavaFX ? false, + ... }@args: -callPackage ./common.nix ({ - # Details from https://www.azul.com/downloads/?version=java-17-lts&package=jdk - # Note that the latest build may differ by platform - dists = { - x86_64-linux = { - zuluVersion = "17.52.17"; - jdkVersion = "17.0.12"; - hash = - if enableJavaFX then "sha256-qKpkvk7/IEnlOJoy7An0AVGUXWkWeuuiQzqKKE/+Ec4=" - else "sha256-JCRcjQzkkV2G5wsoi13psbTHjxCtuw5rqT4pEAOarRk="; - }; +callPackage ./common.nix ( + { + # Details from https://www.azul.com/downloads/?version=java-17-lts&package=jdk + # Note that the latest build may differ by platform + dists = { + x86_64-linux = { + zuluVersion = "17.52.17"; + jdkVersion = "17.0.12"; + hash = + if enableJavaFX then + "sha256-qKpkvk7/IEnlOJoy7An0AVGUXWkWeuuiQzqKKE/+Ec4=" + else + "sha256-JCRcjQzkkV2G5wsoi13psbTHjxCtuw5rqT4pEAOarRk="; + }; - aarch64-linux = { - zuluVersion = "17.52.17"; - jdkVersion = "17.0.12"; - hash = - if enableJavaFX then "sha256-mpTM/43oyDsOnoZM8AW1Z7EFTznnPAnYoC+T6csc8Fw=" - else "sha256-uIz2D5WjqySy5lobuvWp3kFTGsBKhXzT56QgCGyXwSY="; - }; + aarch64-linux = { + zuluVersion = "17.52.17"; + jdkVersion = "17.0.12"; + hash = + if enableJavaFX then + "sha256-mpTM/43oyDsOnoZM8AW1Z7EFTznnPAnYoC+T6csc8Fw=" + else + "sha256-uIz2D5WjqySy5lobuvWp3kFTGsBKhXzT56QgCGyXwSY="; + }; - x86_64-darwin = { - zuluVersion = "17.52.17"; - jdkVersion = "17.0.12"; - hash = - if enableJavaFX then "sha256-jb1oPmRzlYUMONovdsHowlC44X3/PFZ8KilxSsR924U=" - else "sha256-8VlGFUhCn3NE2A42xi69KzZqu0RoGOV1ZYj8oaqCnTc="; - }; + x86_64-darwin = { + zuluVersion = "17.52.17"; + jdkVersion = "17.0.12"; + hash = + if enableJavaFX then + "sha256-jb1oPmRzlYUMONovdsHowlC44X3/PFZ8KilxSsR924U=" + else + "sha256-8VlGFUhCn3NE2A42xi69KzZqu0RoGOV1ZYj8oaqCnTc="; + }; - aarch64-darwin = { - zuluVersion = "17.52.17"; - jdkVersion = "17.0.12"; - hash = - if enableJavaFX then "sha256-rEILTKTpX8DEoOGhlrhbxpcCyF2+QrjW92h0ox9ezp0=" - else "sha256-RZ3hNQQFE+spTT9lFHLjmkolSkpHDg2Hvro6xi7uNww="; + aarch64-darwin = { + zuluVersion = "17.52.17"; + jdkVersion = "17.0.12"; + hash = + if enableJavaFX then + "sha256-rEILTKTpX8DEoOGhlrhbxpcCyF2+QrjW92h0ox9ezp0=" + else + "sha256-RZ3hNQQFE+spTT9lFHLjmkolSkpHDg2Hvro6xi7uNww="; + }; }; - }; -} // builtins.removeAttrs args [ "callPackage" ]) + } + // builtins.removeAttrs args [ "callPackage" ] +) diff --git a/pkgs/development/compilers/zulu/21.nix b/pkgs/development/compilers/zulu/21.nix index 9e86e0bc748b96..68a80599eec7ab 100644 --- a/pkgs/development/compilers/zulu/21.nix +++ b/pkgs/development/compilers/zulu/21.nix @@ -1,42 +1,54 @@ -{ callPackage -, enableJavaFX ? false -, ... +{ + callPackage, + enableJavaFX ? false, + ... }@args: -callPackage ./common.nix ({ - # Details from https://www.azul.com/downloads/?version=java-21-lts&package=jdk - # Note that the latest build may differ by platform - dists = { - x86_64-linux = { - zuluVersion = "21.36.17"; - jdkVersion = "21.0.4"; - hash = - if enableJavaFX then "sha256-Q2bdM0/a2t5aBRCIzXBlhXamf8N7wdSUsK5VhaU9DcY=" - else "sha256-MY0MLtPIdvt+oslSlFzc997PtSZMpRrs4VnmNaxT1UQ="; - }; +callPackage ./common.nix ( + { + # Details from https://www.azul.com/downloads/?version=java-21-lts&package=jdk + # Note that the latest build may differ by platform + dists = { + x86_64-linux = { + zuluVersion = "21.36.17"; + jdkVersion = "21.0.4"; + hash = + if enableJavaFX then + "sha256-Q2bdM0/a2t5aBRCIzXBlhXamf8N7wdSUsK5VhaU9DcY=" + else + "sha256-MY0MLtPIdvt+oslSlFzc997PtSZMpRrs4VnmNaxT1UQ="; + }; - aarch64-linux = { - zuluVersion = "21.36.17"; - jdkVersion = "21.0.4"; - hash = - if enableJavaFX then "sha256-BzNEcDrQo5yOWnEsJxw9JfXYdZGN6/wxnTDB0qC1i/0=" - else "sha256-2jwtfbM2cLz2ZTJEGut/M9zw0ifI2v5841zuZ/aCnEw="; - }; + aarch64-linux = { + zuluVersion = "21.36.17"; + jdkVersion = "21.0.4"; + hash = + if enableJavaFX then + "sha256-BzNEcDrQo5yOWnEsJxw9JfXYdZGN6/wxnTDB0qC1i/0=" + else + "sha256-2jwtfbM2cLz2ZTJEGut/M9zw0ifI2v5841zuZ/aCnEw="; + }; - x86_64-darwin = { - zuluVersion = "21.36.17"; - jdkVersion = "21.0.4"; - hash = - if enableJavaFX then "sha256-H3gM2XCCcuUxlAEzX6IO7Cp6NtH85PYHlH54k5XvNAc=" - else "sha256-XOdaaiR8cCm3TEynz29g/SstaM4eiVb7RI0phDFrX+o="; - }; + x86_64-darwin = { + zuluVersion = "21.36.17"; + jdkVersion = "21.0.4"; + hash = + if enableJavaFX then + "sha256-H3gM2XCCcuUxlAEzX6IO7Cp6NtH85PYHlH54k5XvNAc=" + else + "sha256-XOdaaiR8cCm3TEynz29g/SstaM4eiVb7RI0phDFrX+o="; + }; - aarch64-darwin = { - zuluVersion = "21.36.17"; - jdkVersion = "21.0.4"; - hash = - if enableJavaFX then "sha256-lLAb8MABo95A5WcayBLNvsBSdVFptnO4EmhX2gjo6r8=" - else "sha256-vCdQ+BoWbMbpwwroqrpU8lOoyOydjPwEpVX+IHEse/8="; + aarch64-darwin = { + zuluVersion = "21.36.17"; + jdkVersion = "21.0.4"; + hash = + if enableJavaFX then + "sha256-lLAb8MABo95A5WcayBLNvsBSdVFptnO4EmhX2gjo6r8=" + else + "sha256-vCdQ+BoWbMbpwwroqrpU8lOoyOydjPwEpVX+IHEse/8="; + }; }; - }; -} // builtins.removeAttrs args [ "callPackage" ]) + } + // builtins.removeAttrs args [ "callPackage" ] +) diff --git a/pkgs/development/compilers/zulu/23.nix b/pkgs/development/compilers/zulu/23.nix index 3208944f981fc7..512a0f0813d099 100644 --- a/pkgs/development/compilers/zulu/23.nix +++ b/pkgs/development/compilers/zulu/23.nix @@ -1,42 +1,54 @@ -{ callPackage -, enableJavaFX ? false -, ... +{ + callPackage, + enableJavaFX ? false, + ... }@args: -callPackage ./common.nix ({ - # Details from https://www.azul.com/downloads/?version=java-23-lts&package=jdk - # Note that the latest build may differ by platform - dists = { - x86_64-linux = { - zuluVersion = "23.28.85"; - jdkVersion = "23.0.0"; - hash = - if enableJavaFX then "sha256-HEQ0lxHsoyHG+ZWIlWsbkqMf/rauARafzWoiElRwekA=" - else "sha256-a1YPqBMaWkoruNFoSckLyx00LCOZNsowlSn2L3XCDJA="; - }; +callPackage ./common.nix ( + { + # Details from https://www.azul.com/downloads/?version=java-23-lts&package=jdk + # Note that the latest build may differ by platform + dists = { + x86_64-linux = { + zuluVersion = "23.28.85"; + jdkVersion = "23.0.0"; + hash = + if enableJavaFX then + "sha256-HEQ0lxHsoyHG+ZWIlWsbkqMf/rauARafzWoiElRwekA=" + else + "sha256-a1YPqBMaWkoruNFoSckLyx00LCOZNsowlSn2L3XCDJA="; + }; - aarch64-linux = { - zuluVersion = "23.28.85"; - jdkVersion = "23.0.0"; - hash = - if enableJavaFX then throw "JavaFX is not available for aarch64-linux" - else "sha256-/i+ch7BMAwMQ1C4e3shp9BHuQ67vVXfmIK1YKs7L24M="; - }; + aarch64-linux = { + zuluVersion = "23.28.85"; + jdkVersion = "23.0.0"; + hash = + if enableJavaFX then + throw "JavaFX is not available for aarch64-linux" + else + "sha256-/i+ch7BMAwMQ1C4e3shp9BHuQ67vVXfmIK1YKs7L24M="; + }; - x86_64-darwin = { - zuluVersion = "23.28.85"; - jdkVersion = "23.0.0"; - hash = - if enableJavaFX then "sha256-1/YmLWA/men8jMjnhkZVMf2irf6Tc/5x7UECxqKJcL4=" - else "sha256-rEr8M3KF9Z95gV8sHqi5lQD2RJjtssZx8Q8goy6danw="; - }; + x86_64-darwin = { + zuluVersion = "23.28.85"; + jdkVersion = "23.0.0"; + hash = + if enableJavaFX then + "sha256-1/YmLWA/men8jMjnhkZVMf2irf6Tc/5x7UECxqKJcL4=" + else + "sha256-rEr8M3KF9Z95gV8sHqi5lQD2RJjtssZx8Q8goy6danw="; + }; - aarch64-darwin = { - zuluVersion = "23.28.85"; - jdkVersion = "23.0.0"; - hash = - if enableJavaFX then "sha256-TumPJoHmvklMlcpF4PFY/Arcdc5fkX5z0xeIuNFxluQ=" - else "sha256-gFvfJL0RQgIOATLTMdfa+fStUCrdHYC3rxy0j5eNVDc="; + aarch64-darwin = { + zuluVersion = "23.28.85"; + jdkVersion = "23.0.0"; + hash = + if enableJavaFX then + "sha256-TumPJoHmvklMlcpF4PFY/Arcdc5fkX5z0xeIuNFxluQ=" + else + "sha256-gFvfJL0RQgIOATLTMdfa+fStUCrdHYC3rxy0j5eNVDc="; + }; }; - }; -} // builtins.removeAttrs args [ "callPackage" ]) + } + // builtins.removeAttrs args [ "callPackage" ] +) diff --git a/pkgs/development/compilers/zulu/8.nix b/pkgs/development/compilers/zulu/8.nix index 175519bb8ab464..03a6b1c211c40c 100644 --- a/pkgs/development/compilers/zulu/8.nix +++ b/pkgs/development/compilers/zulu/8.nix @@ -1,42 +1,54 @@ -{ callPackage -, enableJavaFX ? false -, ... +{ + callPackage, + enableJavaFX ? false, + ... }@args: -callPackage ./common.nix ({ - # Details from https://www.azul.com/downloads/?version=java-8-lts&package=jdk - # Note that the latest build may differ by platform - dists = { - x86_64-linux = { - zuluVersion = "8.80.0.17"; - jdkVersion = "8.0.422"; - hash = - if enableJavaFX then "sha256-Ls2sHCtP9htBIDwq5fNDRA3/bGN0bzaMp6nNkjU1zx8=" - else "sha256-YNxnNOFvTc0S3jt4F3UREi2196W7wSBmwieNJl7qamo="; - }; +callPackage ./common.nix ( + { + # Details from https://www.azul.com/downloads/?version=java-8-lts&package=jdk + # Note that the latest build may differ by platform + dists = { + x86_64-linux = { + zuluVersion = "8.80.0.17"; + jdkVersion = "8.0.422"; + hash = + if enableJavaFX then + "sha256-Ls2sHCtP9htBIDwq5fNDRA3/bGN0bzaMp6nNkjU1zx8=" + else + "sha256-YNxnNOFvTc0S3jt4F3UREi2196W7wSBmwieNJl7qamo="; + }; - aarch64-linux = { - zuluVersion = "8.80.0.17"; - jdkVersion = "8.0.422"; - hash = - if enableJavaFX then "sha256-aVBleFrj4OpUJh82rM8XQGy9SzGqjaeOBo20nAbtpJo=" - else "sha256-C5ebWtKAyKexOuEf4yM1y5tQZ2ICxREObwvMrcz5TXE="; - }; + aarch64-linux = { + zuluVersion = "8.80.0.17"; + jdkVersion = "8.0.422"; + hash = + if enableJavaFX then + "sha256-aVBleFrj4OpUJh82rM8XQGy9SzGqjaeOBo20nAbtpJo=" + else + "sha256-C5ebWtKAyKexOuEf4yM1y5tQZ2ICxREObwvMrcz5TXE="; + }; - x86_64-darwin = { - zuluVersion = "8.80.0.17"; - jdkVersion = "8.0.422"; - hash = - if enableJavaFX then "sha256-7NB0OH194nZdpIGyX8gLxJzjJdi2UIxmGsGI5M0yqJ4=" - else "sha256-vyB1Fepnpwsi9KjwFjEF+YbiCgmqZcirZu0zmRAp8PA="; - }; + x86_64-darwin = { + zuluVersion = "8.80.0.17"; + jdkVersion = "8.0.422"; + hash = + if enableJavaFX then + "sha256-7NB0OH194nZdpIGyX8gLxJzjJdi2UIxmGsGI5M0yqJ4=" + else + "sha256-vyB1Fepnpwsi9KjwFjEF+YbiCgmqZcirZu0zmRAp8PA="; + }; - aarch64-darwin = { - zuluVersion = "8.80.0.17"; - jdkVersion = "8.0.422"; - hash = - if enableJavaFX then "sha256-JuQkY923tizx5HQo4WC3YCk75a4qHJYNRFKpZ8XES58=" - else "sha256-Q/hU2ICVwmJehrXmACm4/X48ULTqM6WSc55JDVgkBvM="; + aarch64-darwin = { + zuluVersion = "8.80.0.17"; + jdkVersion = "8.0.422"; + hash = + if enableJavaFX then + "sha256-JuQkY923tizx5HQo4WC3YCk75a4qHJYNRFKpZ8XES58=" + else + "sha256-Q/hU2ICVwmJehrXmACm4/X48ULTqM6WSc55JDVgkBvM="; + }; }; - }; -} // builtins.removeAttrs args [ "callPackage" ]) + } + // builtins.removeAttrs args [ "callPackage" ] +) diff --git a/pkgs/development/compilers/zulu/common.nix b/pkgs/development/compilers/zulu/common.nix index 6b20c71c543813..1db9ba9b625d55 100644 --- a/pkgs/development/compilers/zulu/common.nix +++ b/pkgs/development/compilers/zulu/common.nix @@ -1,56 +1,65 @@ -{ lib -, stdenv -, fetchurl -, setJavaClassPath -, enableJavaFX ? false -, dists +{ + lib, + stdenv, + fetchurl, + setJavaClassPath, + enableJavaFX ? false, + dists, # minimum dependencies -, unzip -, autoPatchelfHook -, makeWrapper -, alsa-lib -, fontconfig -, freetype -, zlib -, xorg + unzip, + autoPatchelfHook, + makeWrapper, + alsa-lib, + fontconfig, + freetype, + zlib, + xorg, # runtime dependencies -, cups + cups, # runtime dependencies for GTK+ Look and Feel -, gtkSupport ? stdenv.hostPlatform.isLinux -, cairo -, glib -, gtk2 -, gtk3 + gtkSupport ? stdenv.hostPlatform.isLinux, + cairo, + glib, + gtk2, + gtk3, # runtime dependencies for JavaFX -, ffmpeg + ffmpeg, }: let - dist = dists.${stdenv.hostPlatform.system} - or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); - - arch = { - "aarch64" = "aarch64"; - "x86_64" = "x64"; - }.${stdenv.hostPlatform.parsed.cpu.name} - or (throw "Unsupported architecture: ${stdenv.hostPlatform.parsed.cpu.name}"); - - platform = { - "darwin" = "macosx"; - "linux" = "linux"; - }.${stdenv.hostPlatform.parsed.kernel.name} - or (throw "Unsupported platform: ${stdenv.hostPlatform.parsed.kernel.name}"); - - runtimeDependencies = [ - cups - ] ++ lib.optionals gtkSupport [ - cairo - glib - gtk3 - ] ++ lib.optionals (gtkSupport && lib.versionOlder dist.jdkVersion "17") [ - gtk2 - ] ++ lib.optionals (stdenv.hostPlatform.isLinux && enableJavaFX) [ - ffmpeg.lib - ]; + dist = + dists.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + + arch = + { + "aarch64" = "aarch64"; + "x86_64" = "x64"; + } + .${stdenv.hostPlatform.parsed.cpu.name} + or (throw "Unsupported architecture: ${stdenv.hostPlatform.parsed.cpu.name}"); + + platform = + { + "darwin" = "macosx"; + "linux" = "linux"; + } + .${stdenv.hostPlatform.parsed.kernel.name} + or (throw "Unsupported platform: ${stdenv.hostPlatform.parsed.kernel.name}"); + + runtimeDependencies = + [ + cups + ] + ++ lib.optionals gtkSupport [ + cairo + glib + gtk3 + ] + ++ lib.optionals (gtkSupport && lib.versionOlder dist.jdkVersion "17") [ + gtk2 + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && enableJavaFX) [ + ffmpeg.lib + ]; runtimeLibraryPath = lib.makeLibraryPath runtimeDependencies; @@ -73,31 +82,39 @@ let curlOpts = "-H Referer:https://www.azul.com/downloads/zulu/"; }; - nativeBuildInputs = [ - unzip - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - autoPatchelfHook - makeWrapper - ]; - - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib # libasound.so wanted by lib/libjsound.so - fontconfig - freetype - stdenv.cc.cc # libstdc++.so.6 - xorg.libX11 - xorg.libXext - xorg.libXi - xorg.libXrender - xorg.libXtst - xorg.libXxf86vm - zlib - ] ++ lib.optionals (stdenv.hostPlatform.isLinux && enableJavaFX) runtimeDependencies; - - autoPatchelfIgnoreMissingDeps = if (stdenv.hostPlatform.isLinux && enableJavaFX) then [ - "libavcodec*.so.*" - "libavformat*.so.*" - ] else null; + nativeBuildInputs = + [ + unzip + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + autoPatchelfHook + makeWrapper + ]; + + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib # libasound.so wanted by lib/libjsound.so + fontconfig + freetype + stdenv.cc.cc # libstdc++.so.6 + xorg.libX11 + xorg.libXext + xorg.libXi + xorg.libXrender + xorg.libXtst + xorg.libXxf86vm + zlib + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && enableJavaFX) runtimeDependencies; + + autoPatchelfIgnoreMissingDeps = + if (stdenv.hostPlatform.isLinux && enableJavaFX) then + [ + "libavcodec*.so.*" + "libavformat*.so.*" + ] + else + null; installPhase = '' mkdir -p $out @@ -115,33 +132,35 @@ let fi ''; - preFixup = '' - # Propagate the setJavaClassPath setup hook from the ${if isJdk8 then "JRE" else "JDK"} so that - # any package that depends on the ${if isJdk8 then "JRE" else "JDK"} has $CLASSPATH set up - # properly. - mkdir -p $out/nix-support - printWords ${setJavaClassPath} > $out/nix-support/propagated-build-inputs - - # Set JAVA_HOME automatically. - cat <> $out/nix-support/setup-hook - if [ -z "\''${JAVA_HOME-}" ]; then export JAVA_HOME=$out; fi - EOF - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - # We cannot use -exec since wrapProgram is a function but not a command. - # - # jspawnhelper is executed from JVM, so it doesn't need to wrap it, and it - # breaks building OpenJDK (#114495). - for bin in $( find "$out" -executable -type f -not -name jspawnhelper ); do - if patchelf --print-interpreter "$bin" &> /dev/null; then - wrapProgram "$bin" --prefix LD_LIBRARY_PATH : "${runtimeLibraryPath}" - fi - done - '' - # FIXME: move all of the above to installPhase. - + lib.optionalString stdenv.hostPlatform.isLinux '' - find "$out" -name libfontmanager.so -exec \ - patchelf --add-needed libfontconfig.so {} \; - ''; + preFixup = + '' + # Propagate the setJavaClassPath setup hook from the ${if isJdk8 then "JRE" else "JDK"} so that + # any package that depends on the ${if isJdk8 then "JRE" else "JDK"} has $CLASSPATH set up + # properly. + mkdir -p $out/nix-support + printWords ${setJavaClassPath} > $out/nix-support/propagated-build-inputs + + # Set JAVA_HOME automatically. + cat <> $out/nix-support/setup-hook + if [ -z "\''${JAVA_HOME-}" ]; then export JAVA_HOME=$out; fi + EOF + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + # We cannot use -exec since wrapProgram is a function but not a command. + # + # jspawnhelper is executed from JVM, so it doesn't need to wrap it, and it + # breaks building OpenJDK (#114495). + for bin in $( find "$out" -executable -type f -not -name jspawnhelper ); do + if patchelf --print-interpreter "$bin" &> /dev/null; then + wrapProgram "$bin" --prefix LD_LIBRARY_PATH : "${runtimeLibraryPath}" + fi + done + '' + # FIXME: move all of the above to installPhase. + + lib.optionalString stdenv.hostPlatform.isLinux '' + find "$out" -name libfontmanager.so -exec \ + patchelf --add-needed libfontconfig.so {} \; + ''; # fixupPhase is moving the man to share/man which breaks it because it's a # relative symlink. @@ -149,11 +168,13 @@ let ln -nsf ../zulu-${lib.versions.major version}.jdk/Contents/Home/man $out/share/man ''; - passthru = (lib.optionalAttrs isJdk8 { - jre = jdk; - }) // { - home = jdk; - }; + passthru = + (lib.optionalAttrs isJdk8 { + jre = jdk; + }) + // { + home = jdk; + }; meta = { description = "Certified builds of OpenJDK"; @@ -166,7 +187,10 @@ let mainProgram = "java"; maintainers = [ ] ++ lib.teams.java.members; platforms = builtins.attrNames dists; - sourceProvenance = with lib.sourceTypes; [ binaryBytecode binaryNativeCode ]; + sourceProvenance = with lib.sourceTypes; [ + binaryBytecode + binaryNativeCode + ]; }; }; in diff --git a/pkgs/development/coq-modules/Cheerios/default.nix b/pkgs/development/coq-modules/Cheerios/default.nix index ae8baba36c069b..8bdcbab8370adb 100644 --- a/pkgs/development/coq-modules/Cheerios/default.nix +++ b/pkgs/development/coq-modules/Cheerios/default.nix @@ -1,16 +1,30 @@ -{ lib, mkCoqDerivation, coq, StructTact, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + StructTact, + version ? null, +}: mkCoqDerivation { - pname = "cheerios"; - owner = "uwplse"; + pname = "cheerios"; + owner = "uwplse"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = range "8.14" "8.20"; out = "20230107"; } - { case = range "8.6" "8.16"; out = "20200201"; } - ] null; - release."20230107".rev = "bad8ad2476e14df6b5a819b7aaddc27a7c53fb69"; + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.14" "8.20"; + out = "20230107"; + } + { + case = range "8.6" "8.16"; + out = "20200201"; + } + ] null; + release."20230107".rev = "bad8ad2476e14df6b5a819b7aaddc27a7c53fb69"; release."20230107".sha256 = "sha256-G7a+6h4VDk7seKvFr6wy7vYqYmhUje78TYCj98wXrr8="; - release."20200201".rev = "9c7f66e57b91f706d70afa8ed99d64ed98ab367d"; + release."20200201".rev = "9c7f66e57b91f706d70afa8ed99d64ed98ab367d"; release."20200201".sha256 = "1h55s6lk47bk0lv5ralh81z55h799jbl9mhizmqwqzy57y8wqgs1"; propagatedBuildInputs = [ StructTact ]; diff --git a/pkgs/development/coq-modules/CoLoR/default.nix b/pkgs/development/coq-modules/CoLoR/default.nix index 779900d22671ab..3576fbe17270b9 100644 --- a/pkgs/development/coq-modules/CoLoR/default.nix +++ b/pkgs/development/coq-modules/CoLoR/default.nix @@ -1,27 +1,50 @@ -{ lib, mkCoqDerivation, coq, bignums, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + bignums, + version ? null, +}: mkCoqDerivation { pname = "color"; owner = "fblanqui"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - {case = range "8.14" "8.20"; out = "1.8.5"; } - {case = range "8.12" "8.16"; out = "1.8.2"; } - {case = range "8.10" "8.11"; out = "1.7.0"; } - {case = range "8.8" "8.9"; out = "1.6.0"; } - {case = range "8.6" "8.7"; out = "1.4.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.14" "8.20"; + out = "1.8.5"; + } + { + case = range "8.12" "8.16"; + out = "1.8.2"; + } + { + case = range "8.10" "8.11"; + out = "1.7.0"; + } + { + case = range "8.8" "8.9"; + out = "1.6.0"; + } + { + case = range "8.6" "8.7"; + out = "1.4.0"; + } + ] null; release."1.8.5".sha256 = "sha256-zKAyj6rKAasDF+iKExmpVHMe2WwgAwv2j1mmiVAl7ys="; release."1.8.4".sha256 = "sha256-WlRiaLgnFFW5AY0z6EzdP1mevNe1GHsik6wULJLN4k0="; release."1.8.3".sha256 = "sha256-mMUzIorkQ6WWQBJLk1ioUNwAdDdGHJyhenIvkAjALVU="; release."1.8.2".sha256 = "sha256:1gvx5cxm582793vxzrvsmhxif7px18h9xsb2jljy2gkphdmsnpqj"; release."1.8.1".sha256 = "0knhca9fffmyldn4q16h9265i7ih0h4jhcarq4rkn0wnn7x8w8yw"; - release."1.7.0".rev = "08b5481ed6ea1a5d2c4c068b62156f5be6d82b40"; + release."1.7.0".rev = "08b5481ed6ea1a5d2c4c068b62156f5be6d82b40"; release."1.7.0".sha256 = "1w7fmcpf0691gcwq00lm788k4ijlwz3667zj40j5jjc8j8hj7cq3"; - release."1.6.0".rev = "328aa06270584b578edc0d2925e773cced4f14c8"; + release."1.6.0".rev = "328aa06270584b578edc0d2925e773cced4f14c8"; release."1.6.0".sha256 = "07sy9kw1qlynsqy251adgi8b3hghrc9xxl2rid6c82mxfsp329sd"; - release."1.4.0".rev = "168c6b86c7d3f87ee51791f795a8828b1521589a"; + release."1.4.0".rev = "168c6b86c7d3f87ee51791f795a8828b1521589a"; release."1.4.0".sha256 = "1d2whsgs3kcg5wgampd6yaqagcpmzhgb6a0hp6qn4lbimck5dfmm"; propagatedBuildInputs = [ bignums ]; @@ -30,6 +53,9 @@ mkCoqDerivation { meta = { homepage = "https://github.com/fblanqui/color"; description = "CoLoR is a library of formal mathematical definitions and proofs of theorems on rewriting theory and termination whose correctness has been mechanically checked by the Coq proof assistant"; - maintainers = with lib.maintainers; [ jpas jwiegley ]; + maintainers = with lib.maintainers; [ + jpas + jwiegley + ]; }; } diff --git a/pkgs/development/coq-modules/HoTT/default.nix b/pkgs/development/coq-modules/HoTT/default.nix index 8652520b4a4042..cfb90d806a8fa2 100644 --- a/pkgs/development/coq-modules/HoTT/default.nix +++ b/pkgs/development/coq-modules/HoTT/default.nix @@ -1,13 +1,23 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "HoTT"; repo = "Coq-HoTT"; owner = "HoTT"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.14" "8.20"; out = coq.coq-version; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.14" "8.20"; + out = coq.coq-version; + } + ] null; releaseRev = v: "V${v}"; release."8.14".sha256 = "sha256-7kXk2pmYsTNodHA+Qts3BoMsewvzmCbYvxw9Sgwyvq0="; release."8.15".sha256 = "sha256-JfeiRZVnrjn3SQ87y6dj9DWNwCzrkK3HBogeZARUn9g="; @@ -44,6 +54,9 @@ mkCoqDerivation { Foundations library (which has since been incorporated into the Unimath library) and also cross-pollinates with the HoTT-Agda library. ''; - maintainers = with lib.maintainers; [ alizter siddharthist ]; + maintainers = with lib.maintainers; [ + alizter + siddharthist + ]; }; } diff --git a/pkgs/development/coq-modules/ITree/default.nix b/pkgs/development/coq-modules/ITree/default.nix index 78d788b962958f..b827c06ef2c894 100644 --- a/pkgs/development/coq-modules/ITree/default.nix +++ b/pkgs/development/coq-modules/ITree/default.nix @@ -1,13 +1,28 @@ -{ lib, mkCoqDerivation, coq, version ? null , paco, ExtLib }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, + paco, + ExtLib, +}: mkCoqDerivation rec { pname = "InteractionTrees"; owner = "DeepSpec"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = range "8.13" "8.20"; out = "5.2.0"; } - { case = range "8.10" "8.16"; out = "4.0.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.13" "8.20"; + out = "5.2.0"; + } + { + case = range "8.10" "8.16"; + out = "4.0.0"; + } + ] null; release."5.2.0".sha256 = "sha256-rKLz7ekZf/9xcQefBRsAdULmk81olzQ1W28y61vCDsY="; release."5.1.2".sha256 = "sha256-uKJIjNXGWl0YS0WH52Rnr9Jz98Eo2k0X0qWB9hUYJMk="; release."5.1.1".sha256 = "sha256-VlmPNwaGkdWrH7Z6DGXRosGtjuuQ+FBiGcadN2Hg5pY="; @@ -15,7 +30,10 @@ mkCoqDerivation rec { release."4.0.0".sha256 = "0h5rhndl8syc24hxq1gch86kj7mpmgr89bxp2hmf28fd7028ijsm"; release."3.2.0".sha256 = "sha256-10ckCAqSQ0I3CZKlSllI1obOgWVxDagTd7eyhrl1xpE="; releaseRev = v: "${v}"; - propagatedBuildInputs = [ ExtLib paco ]; + propagatedBuildInputs = [ + ExtLib + paco + ]; meta = { description = "Library for Representing Recursive and Impure Programs in Coq"; maintainers = with lib.maintainers; [ larsr ]; diff --git a/pkgs/development/coq-modules/InfSeqExt/default.nix b/pkgs/development/coq-modules/InfSeqExt/default.nix index cae401d8fdbf3b..d36a723deabf9b 100644 --- a/pkgs/development/coq-modules/InfSeqExt/default.nix +++ b/pkgs/development/coq-modules/InfSeqExt/default.nix @@ -1,15 +1,28 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "InfSeqExt"; owner = "DistributedComponents"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = range "8.9" "8.20"; out = "20230107"; } - { case = range "8.5" "8.16"; out = "20200131"; } - ] null; - release."20230107".rev = "601e89ec019501c48c27fcfc14b9a3c70456e408"; + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.9" "8.20"; + out = "20230107"; + } + { + case = range "8.5" "8.16"; + out = "20200131"; + } + ] null; + release."20230107".rev = "601e89ec019501c48c27fcfc14b9a3c70456e408"; release."20230107".sha256 = "sha256-YMBzVIsLkIC+w2TeyHrKe29eWLIxrH3wIMZqhik8p9I="; - release."20200131".rev = "203d4c20211d6b17741f1fdca46dbc091f5e961a"; + release."20200131".rev = "203d4c20211d6b17741f1fdca46dbc091f5e961a"; release."20200131".sha256 = "0xylkdmb2dqnnqinf3pigz4mf4zmczcbpjnn59g5g76m7f2cqxl0"; } diff --git a/pkgs/development/coq-modules/LibHyps/default.nix b/pkgs/development/coq-modules/LibHyps/default.nix index 63b4acdb86dbf9..3ed3318a941c38 100644 --- a/pkgs/development/coq-modules/LibHyps/default.nix +++ b/pkgs/development/coq-modules/LibHyps/default.nix @@ -1,4 +1,9 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "LibHyps"; diff --git a/pkgs/development/coq-modules/MenhirLib/default.nix b/pkgs/development/coq-modules/MenhirLib/default.nix index c94e0f95c49aeb..5b680c73da44d2 100644 --- a/pkgs/development/coq-modules/MenhirLib/default.nix +++ b/pkgs/development/coq-modules/MenhirLib/default.nix @@ -14,8 +14,14 @@ let defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.12" "8.20"; out = "20240715"; } - { case = range "8.7" "8.11"; out = "20200624"; } + { + case = range "8.12" "8.20"; + out = "20240715"; + } + { + case = range "8.7" "8.11"; + out = "20200624"; + } ] null; release = { "20240715".sha256 = "sha256-9CSxAIm0aEXkwF+aj8u/bqLG30y5eDNz65EnohJPjzI="; # coq 8.9 - 8.20 diff --git a/pkgs/development/coq-modules/QuickChick/default.nix b/pkgs/development/coq-modules/QuickChick/default.nix index 16f4eedb5ccaa5..0f70982dfaf12d 100644 --- a/pkgs/development/coq-modules/QuickChick/default.nix +++ b/pkgs/development/coq-modules/QuickChick/default.nix @@ -1,53 +1,137 @@ -{ lib, mkCoqDerivation, coq, ssreflect, ExtLib, simple-io, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + ssreflect, + ExtLib, + simple-io, + version ? null, +}: -let recent = lib.versions.isGe "8.7" coq.coq-version || coq.coq-version == "dev"; in +let + recent = lib.versions.isGe "8.7" coq.coq-version || coq.coq-version == "dev"; +in (mkCoqDerivation { pname = "QuickChick"; owner = "QuickChick"; inherit version; - defaultVersion = lib.switch [ coq.coq-version ssreflect.version ] [ - { cases = [ (lib.versions.range "8.15" "8.20") lib.pred.true ]; out = "2.0.4"; } - { cases = [ (lib.versions.range "8.13" "8.17") lib.pred.true ]; out = "1.6.5"; } - { cases = [ "8.13" lib.pred.true ]; out = "1.5.0"; } - { cases = [ "8.12" lib.pred.true ]; out = "1.4.0"; } - { cases = [ "8.11" lib.pred.true ]; out = "1.3.2"; } - { cases = [ "8.10" lib.pred.true ]; out = "1.2.1"; } - { cases = [ "8.9" lib.pred.true ]; out = "1.1.0"; } - { cases = [ "8.8" lib.pred.true ]; out = "20190311"; } - { cases = [ "8.7" lib.versions.isLe "1.8" ]; out = "1.0.0"; } - { cases = [ "8.6" lib.pred.true ]; out = "20171102"; } - { cases = [ "8.5" lib.pred.true ]; out = "20170512"; } - ] null; - release."2.0.4".sha256 = "sha256-WD8B+n8gyGctHMO+M8201Ca3Uw8zCWYsOatSNGCf0/s="; - release."2.0.2".sha256 = "sha256-xxKkwDRjB8nUiXNhein1Ppn0DP5FZ13J90xUPAnQBbs="; - release."2.0.1".sha256 = "sha256-gJc+9Or6tbqE00920Il4pnEvokRoiADX6CxP/Q0QZaY="; - release."1.6.5".sha256 = "sha256-rcFyRDH8UbB9KVk10P5qjtPkWs04p78VNHkCq4mXr3U="; - release."1.6.4".sha256 = "sha256-C1060wPSU33yZAFLxGmZlAMXASnx98qz3oSLO8DO+mM="; - release."1.6.2".sha256 = "0g5q9zw3xd4zndihq96nxkq4w3dh05418wzlwdk1nnn3b6vbx6z0"; - release."1.5.0".sha256 = "1lq8x86vd3vqqh2yq6hvyagpnhfq5wmk5pg2z0xq7b7dcw7hyfkw"; - release."1.4.0".sha256 = "068p48pm5yxjc3yv8qwzp25bp9kddvxj81l31mjkyx3sdrsw3kyc"; - release."1.3.2".sha256 = "0lciwaqv288dh2f13xk2x0lrn6zyrkqy6g4yy927wwzag2gklfrs"; - release."1.2.1".sha256 = "17vz88xjzxh3q7hs6hnndw61r3hdfawxp5awqpgfaxx4w6ni8z46"; - release."1.1.0".sha256 = "1c34v1k37rk7v0xk2czv5n79mbjxjrm6nh3llg2mpfmdsqi68wf3"; - release."1.0.0".sha256 = "1gqy9a4yavd0sa7kgysf9gf2lq4p8dmn4h89y8081f2j8zli0w5y"; - release."20190311".rev = "22af9e9a223d0038f05638654422e637e863b355"; + defaultVersion = + lib.switch + [ coq.coq-version ssreflect.version ] + [ + { + cases = [ + (lib.versions.range "8.15" "8.20") + lib.pred.true + ]; + out = "2.0.4"; + } + { + cases = [ + (lib.versions.range "8.13" "8.17") + lib.pred.true + ]; + out = "1.6.5"; + } + { + cases = [ + "8.13" + lib.pred.true + ]; + out = "1.5.0"; + } + { + cases = [ + "8.12" + lib.pred.true + ]; + out = "1.4.0"; + } + { + cases = [ + "8.11" + lib.pred.true + ]; + out = "1.3.2"; + } + { + cases = [ + "8.10" + lib.pred.true + ]; + out = "1.2.1"; + } + { + cases = [ + "8.9" + lib.pred.true + ]; + out = "1.1.0"; + } + { + cases = [ + "8.8" + lib.pred.true + ]; + out = "20190311"; + } + { + cases = [ + "8.7" + lib.versions.isLe + "1.8" + ]; + out = "1.0.0"; + } + { + cases = [ + "8.6" + lib.pred.true + ]; + out = "20171102"; + } + { + cases = [ + "8.5" + lib.pred.true + ]; + out = "20170512"; + } + ] + null; + release."2.0.4".sha256 = "sha256-WD8B+n8gyGctHMO+M8201Ca3Uw8zCWYsOatSNGCf0/s="; + release."2.0.2".sha256 = "sha256-xxKkwDRjB8nUiXNhein1Ppn0DP5FZ13J90xUPAnQBbs="; + release."2.0.1".sha256 = "sha256-gJc+9Or6tbqE00920Il4pnEvokRoiADX6CxP/Q0QZaY="; + release."1.6.5".sha256 = "sha256-rcFyRDH8UbB9KVk10P5qjtPkWs04p78VNHkCq4mXr3U="; + release."1.6.4".sha256 = "sha256-C1060wPSU33yZAFLxGmZlAMXASnx98qz3oSLO8DO+mM="; + release."1.6.2".sha256 = "0g5q9zw3xd4zndihq96nxkq4w3dh05418wzlwdk1nnn3b6vbx6z0"; + release."1.5.0".sha256 = "1lq8x86vd3vqqh2yq6hvyagpnhfq5wmk5pg2z0xq7b7dcw7hyfkw"; + release."1.4.0".sha256 = "068p48pm5yxjc3yv8qwzp25bp9kddvxj81l31mjkyx3sdrsw3kyc"; + release."1.3.2".sha256 = "0lciwaqv288dh2f13xk2x0lrn6zyrkqy6g4yy927wwzag2gklfrs"; + release."1.2.1".sha256 = "17vz88xjzxh3q7hs6hnndw61r3hdfawxp5awqpgfaxx4w6ni8z46"; + release."1.1.0".sha256 = "1c34v1k37rk7v0xk2czv5n79mbjxjrm6nh3llg2mpfmdsqi68wf3"; + release."1.0.0".sha256 = "1gqy9a4yavd0sa7kgysf9gf2lq4p8dmn4h89y8081f2j8zli0w5y"; + release."20190311".rev = "22af9e9a223d0038f05638654422e637e863b355"; release."20190311".sha256 = "00rnr19lg6lg0haq1sy4ld38p7imzand6fc52fvfq27gblxkp2aq"; - release."20171102".rev = "0fdb769e1dc87a278383b44a9f5102cc7ccbafcf"; + release."20171102".rev = "0fdb769e1dc87a278383b44a9f5102cc7ccbafcf"; release."20171102".sha256 = "0fri4nih40vfb0fbr82dsi631ydkw48xszinq43lyinpknf54y17"; - release."20170512".rev = "31eb050ae5ce57ab402db9726fb7cd945a0b4d03"; + release."20170512".rev = "31eb050ae5ce57ab402db9726fb7cd945a0b4d03"; release."20170512".sha256 = "033ch10i5wmqyw8j6wnr0dlbnibgfpr1vr0c07q3yj6h23xkmqpg"; releaseRev = v: "v${v}"; - preConfigure = lib.optionalString recent - "substituteInPlace Makefile --replace quickChickTool.byte quickChickTool.native"; + preConfigure = lib.optionalString recent "substituteInPlace Makefile --replace quickChickTool.byte quickChickTool.native"; useDuneifVersion = v: lib.versions.isGe "2.1" v || v == "dev"; opam-name = "coq-quickchick"; mlPlugin = true; nativeBuildInputs = lib.optional recent coq.ocamlPackages.ocamlbuild; - propagatedBuildInputs = [ ssreflect ] - ++ lib.optionals recent [ ExtLib simple-io ]; + propagatedBuildInputs = + [ ssreflect ] + ++ lib.optionals recent [ + ExtLib + simple-io + ]; extraInstallFlags = [ "-f Makefile.coq" ]; enableParallelBuilding = false; @@ -56,13 +140,26 @@ let recent = lib.versions.isGe "8.7" coq.coq-version || coq.coq-version == "dev" description = "Randomized property-based testing plugin for Coq; a clone of Haskell QuickCheck"; maintainers = with maintainers; [ jwiegley ]; }; -}).overrideAttrs (o: - let after_1_6 = lib.versions.isGe "1.6" o.version || o.version == "dev"; +}).overrideAttrs + ( + o: + let + after_1_6 = lib.versions.isGe "1.6" o.version || o.version == "dev"; after_2_1 = lib.versions.isGe "2.1" o.version || o.version == "dev"; - in { - nativeBuildInputs = o.nativeBuildInputs - ++ lib.optional after_1_6 coq.ocamlPackages.cppo - ++ lib.optional after_2_1 coq.ocamlPackages.menhir; - propagatedBuildInputs = o.propagatedBuildInputs - ++ lib.optionals after_1_6 (with coq.ocamlPackages; [ findlib zarith ]); -}) + in + { + nativeBuildInputs = + o.nativeBuildInputs + ++ lib.optional after_1_6 coq.ocamlPackages.cppo + ++ lib.optional after_2_1 coq.ocamlPackages.menhir; + propagatedBuildInputs = + o.propagatedBuildInputs + ++ lib.optionals after_1_6 ( + with coq.ocamlPackages; + [ + findlib + zarith + ] + ); + } + ) diff --git a/pkgs/development/coq-modules/StructTact/default.nix b/pkgs/development/coq-modules/StructTact/default.nix index 117f26cc6d88f4..8e982d19f609cb 100644 --- a/pkgs/development/coq-modules/StructTact/default.nix +++ b/pkgs/development/coq-modules/StructTact/default.nix @@ -1,18 +1,34 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "StructTact"; owner = "uwplse"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.9" "8.20"; out = "20230107"; } - { case = range "8.6" "8.16"; out = "20210328"; } - { case = range "8.5" "8.13"; out = "20181102"; } - ] null; - release."20230107".rev = "2f2ff253be29bb09f36cab96d036419b18a95b00"; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.9" "8.20"; + out = "20230107"; + } + { + case = range "8.6" "8.16"; + out = "20210328"; + } + { + case = range "8.5" "8.13"; + out = "20181102"; + } + ] null; + release."20230107".rev = "2f2ff253be29bb09f36cab96d036419b18a95b00"; release."20230107".sha256 = "sha256-4mWdnWD8m1ddgqWHqzjqclhinXJaB/YoLlmLeeL0yZA="; - release."20210328".rev = "179bd5312e9d8b63fc3f4071c628cddfc496d741"; + release."20210328".rev = "179bd5312e9d8b63fc3f4071c628cddfc496d741"; release."20210328".sha256 = "sha256:1y5r1zm3hli10ah6lnj7n8hxad6rb6rgldd0g7m2fjibzvwqzhdg"; - release."20181102".rev = "82a85b7ec07e71fa6b30cfc05f6a7bfb09ef2510"; + release."20181102".rev = "82a85b7ec07e71fa6b30cfc05f6a7bfb09ef2510"; release."20181102".sha256 = "08zry20flgj7qq37xk32kzmg4fg6d4wi9m7pf9aph8fd3j2a0b5v"; } diff --git a/pkgs/development/coq-modules/VST/default.nix b/pkgs/development/coq-modules/VST/default.nix index 8cfe5e9f764e93..d82699847d01fe 100644 --- a/pkgs/development/coq-modules/VST/default.nix +++ b/pkgs/development/coq-modules/VST/default.nix @@ -1,34 +1,62 @@ -{ lib, mkCoqDerivation, coq, compcert, ITree, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + compcert, + ITree, + version ? null, +}: # A few modules that are not built and installed by default # but that may be useful to some users. # They depend on ITree. -let extra_floyd_files = [ - "ASTsize.v" - "io_events.v" - "powerlater.v" - ] - # floyd/printf.v is broken in VST 2.9 - ++ lib.optional (!lib.versions.isGe "8.13" coq.coq-version) "printf.v" - ++ [ - "quickprogram.v" - ]; +let + extra_floyd_files = + [ + "ASTsize.v" + "io_events.v" + "powerlater.v" + ] + # floyd/printf.v is broken in VST 2.9 + ++ lib.optional (!lib.versions.isGe "8.13" coq.coq-version) "printf.v" + ++ [ + "quickprogram.v" + ]; in mkCoqDerivation { pname = "coq${coq.coq-version}-VST"; - namePrefix = []; - displayVersion = { coq = false; }; + namePrefix = [ ]; + displayVersion = { + coq = false; + }; owner = "PrincetonUniversity"; repo = "VST"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.15" "8.19"; out = "2.14"; } - { case = range "8.15" "8.17"; out = "2.13"; } - { case = range "8.14" "8.16"; out = "2.10"; } - { case = range "8.13" "8.15"; out = "2.9"; } - { case = range "8.12" "8.13"; out = "2.8"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.15" "8.19"; + out = "2.14"; + } + { + case = range "8.15" "8.17"; + out = "2.13"; + } + { + case = range "8.14" "8.16"; + out = "2.10"; + } + { + case = range "8.13" "8.15"; + out = "2.9"; + } + { + case = range "8.12" "8.13"; + out = "2.8"; + } + ] null; release."2.14".sha256 = "sha256-NHc1ZQ2VmXZy4lK2+mtyeNz1Qr9Nhj2QLxkPhhQB7Iw="; release."2.13".sha256 = "sha256-i6rvP3cpayBln5KHZOpeNfraYU5h0O9uciBQ4jRH4XA="; release."2.12".sha256 = "sha256-4HL0U4HA5/usKNXC0Dis1UZY/Hb/LRd2IGOrqrvdWkw="; diff --git a/pkgs/development/coq-modules/Velisarios/default.nix b/pkgs/development/coq-modules/Velisarios/default.nix index 62eb9c389abbcc..2dc81cb7ad59e1 100644 --- a/pkgs/development/coq-modules/Velisarios/default.nix +++ b/pkgs/development/coq-modules/Velisarios/default.nix @@ -1,4 +1,9 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "Velisarios"; @@ -6,7 +11,7 @@ mkCoqDerivation { inherit version; defaultVersion = if lib.versions.range "8.6" "8.8" coq.coq-version then "20180221" else null; - release."20180221".rev = "e1eee1f10d5d46331a560bd8565ac101229d0d6b"; + release."20180221".rev = "e1eee1f10d5d46331a560bd8565ac101229d0d6b"; release."20180221".sha256 = "0l9885nxy0n955fj1gnijlxl55lyxiv9yjfmz8hmfrn9hl8vv1m2"; mlPlugin = true; diff --git a/pkgs/development/coq-modules/Verdi/default.nix b/pkgs/development/coq-modules/Verdi/default.nix index b0ff84c4598121..a6152a97b0eac1 100644 --- a/pkgs/development/coq-modules/Verdi/default.nix +++ b/pkgs/development/coq-modules/Verdi/default.nix @@ -1,27 +1,55 @@ -{ lib, mkCoqDerivation, coq, Cheerios, InfSeqExt, ssreflect, version ? null }: - +{ + lib, + mkCoqDerivation, + coq, + Cheerios, + InfSeqExt, + ssreflect, + version ? null, +}: mkCoqDerivation { pname = "verdi"; owner = "uwplse"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.9" "8.18"; out = "20230503"; } - { case = range "8.7" "8.16"; out = "20211026"; } - { case = range "8.7" "8.14"; out = "20210524"; } - { case = range "8.7" "8.13"; out = "20200131"; } - { case = "8.6"; out = "20181102"; } - ] null; - release."20230503".rev = "76833a7b2188e99e358b8439ea6b4f38401c962a"; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.9" "8.18"; + out = "20230503"; + } + { + case = range "8.7" "8.16"; + out = "20211026"; + } + { + case = range "8.7" "8.14"; + out = "20210524"; + } + { + case = range "8.7" "8.13"; + out = "20200131"; + } + { + case = "8.6"; + out = "20181102"; + } + ] null; + release."20230503".rev = "76833a7b2188e99e358b8439ea6b4f38401c962a"; release."20230503".sha256 = "sha256-g59adl/FLMlk9vZciz2I1ZX4PDCElNOgVPCwML8E4DU="; - release."20211026".rev = "064cc4fb2347453bf695776ed820ffb5fbc1d804"; + release."20211026".rev = "064cc4fb2347453bf695776ed820ffb5fbc1d804"; release."20211026".sha256 = "sha256:13xrcyzay5sjszf5lg4s44wl9nrcz22n6gi4h95pkpj0ni5clinx"; - release."20210524".rev = "54597d8ac7ab7dd4dae683f651237644bf77701e"; + release."20210524".rev = "54597d8ac7ab7dd4dae683f651237644bf77701e"; release."20210524".sha256 = "sha256:05wb0km2jkhvi8807glxk9fi1kll4lwisiyzkxhqvymz4x6v8xqv"; - release."20200131".rev = "fdb4ede19d2150c254f0ebcfbed4fb9547a734b0"; + release."20200131".rev = "fdb4ede19d2150c254f0ebcfbed4fb9547a734b0"; release."20200131".sha256 = "1a2k19f9q5k5djbxplqmmpwck49kw3lrm3aax920h4yb40czkd8m"; - release."20181102".rev = "25b79cf1be5527ab8dc1b8314fcee93e76a2e564"; + release."20181102".rev = "25b79cf1be5527ab8dc1b8314fcee93e76a2e564"; release."20181102".sha256 = "1vw47c37k5vaa8vbr6ryqy8riagngwcrfmb3rai37yi9xhdqg55z"; - propagatedBuildInputs = [ Cheerios InfSeqExt ssreflect ]; + propagatedBuildInputs = [ + Cheerios + InfSeqExt + ssreflect + ]; } diff --git a/pkgs/development/coq-modules/Vpl/default.nix b/pkgs/development/coq-modules/Vpl/default.nix index 6581a919b8dff5..7a6b9d2ec3d68e 100644 --- a/pkgs/development/coq-modules/Vpl/default.nix +++ b/pkgs/development/coq-modules/Vpl/default.nix @@ -1,4 +1,9 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "Vpl"; diff --git a/pkgs/development/coq-modules/VplTactic/default.nix b/pkgs/development/coq-modules/VplTactic/default.nix index b907a10498e726..dbd930b6c1836e 100644 --- a/pkgs/development/coq-modules/VplTactic/default.nix +++ b/pkgs/development/coq-modules/VplTactic/default.nix @@ -1,4 +1,10 @@ -{ lib, mkCoqDerivation, coq, Vpl, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + Vpl, + version ? null, +}: mkCoqDerivation { pname = "VplTactic"; diff --git a/pkgs/development/coq-modules/aac-tactics/default.nix b/pkgs/development/coq-modules/aac-tactics/default.nix index 1dd396a8268483..a5cbfa49d93802 100644 --- a/pkgs/development/coq-modules/aac-tactics/default.nix +++ b/pkgs/development/coq-modules/aac-tactics/default.nix @@ -1,4 +1,9 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "aac-tactics"; @@ -25,23 +30,70 @@ mkCoqDerivation { release."8.5.0".sha256 = "sha256-7yNxJn6CH5xS5w/zsXfcZYORa6e5/qS9v8PUq2o02h4="; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = "8.20"; out = "8.20.0"; } - { case = "8.19"; out = "8.19.1"; } - { case = "8.18"; out = "8.18.0"; } - { case = "8.17"; out = "8.17.0"; } - { case = "8.16"; out = "8.16.0"; } - { case = "8.15"; out = "8.15.1"; } - { case = "8.14"; out = "8.14.1"; } - { case = "8.13"; out = "8.13.2"; } - { case = "8.12"; out = "8.12.0"; } - { case = "8.11"; out = "8.11.0"; } - { case = "8.10"; out = "8.10.0"; } - { case = "8.9"; out = "8.9.0"; } - { case = "8.8"; out = "8.8.0"; } - { case = "8.6"; out = "8.6.1"; } - { case = "8.5"; out = "8.5.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = "8.20"; + out = "8.20.0"; + } + { + case = "8.19"; + out = "8.19.1"; + } + { + case = "8.18"; + out = "8.18.0"; + } + { + case = "8.17"; + out = "8.17.0"; + } + { + case = "8.16"; + out = "8.16.0"; + } + { + case = "8.15"; + out = "8.15.1"; + } + { + case = "8.14"; + out = "8.14.1"; + } + { + case = "8.13"; + out = "8.13.2"; + } + { + case = "8.12"; + out = "8.12.0"; + } + { + case = "8.11"; + out = "8.11.0"; + } + { + case = "8.10"; + out = "8.10.0"; + } + { + case = "8.9"; + out = "8.9.0"; + } + { + case = "8.8"; + out = "8.8.0"; + } + { + case = "8.6"; + out = "8.6.1"; + } + { + case = "8.5"; + out = "8.5.0"; + } + ] null; mlPlugin = true; diff --git a/pkgs/development/coq-modules/addition-chains/default.nix b/pkgs/development/coq-modules/addition-chains/default.nix index d7274e66138688..95d247f108fee1 100644 --- a/pkgs/development/coq-modules/addition-chains/default.nix +++ b/pkgs/development/coq-modules/addition-chains/default.nix @@ -1,5 +1,13 @@ -{ lib, mkCoqDerivation, coq, mathcomp-ssreflect, mathcomp-algebra, mathcomp-fingroup, paramcoq -, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + mathcomp-ssreflect, + mathcomp-algebra, + mathcomp-fingroup, + paramcoq, + version ? null, +}: mkCoqDerivation { pname = "addition-chains"; @@ -11,12 +19,25 @@ mkCoqDerivation { releaseRev = (v: "v${v}"); inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.13" "8.18"; out = "0.6"; } - { case = range "8.11" "8.12"; out = "0.4"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.13" "8.18"; + out = "0.6"; + } + { + case = range "8.11" "8.12"; + out = "0.4"; + } + ] null; - propagatedBuildInputs = [ mathcomp-ssreflect mathcomp-algebra mathcomp-fingroup paramcoq ]; + propagatedBuildInputs = [ + mathcomp-ssreflect + mathcomp-algebra + mathcomp-fingroup + paramcoq + ]; useDune = true; diff --git a/pkgs/development/coq-modules/async-test/default.nix b/pkgs/development/coq-modules/async-test/default.nix index a6ec799db9c59a..46df8ee94086a9 100644 --- a/pkgs/development/coq-modules/async-test/default.nix +++ b/pkgs/development/coq-modules/async-test/default.nix @@ -1,4 +1,12 @@ -{ lib, mkCoqDerivation, coq, itree-io, json, QuickChick, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + itree-io, + json, + QuickChick, + version ? null, +}: mkCoqDerivation { pname = "async-test"; @@ -6,16 +14,26 @@ mkCoqDerivation { repo = "coq-async-test"; inherit version; - defaultVersion = let inherit (lib.versions) range; in + defaultVersion = + let + inherit (lib.versions) range; + in lib.switch coq.coq-version [ - { case = range "8.12" "8.19"; out = "0.1.0"; } + { + case = range "8.12" "8.19"; + out = "0.1.0"; + } ] null; release = { - "0.1.0".sha256 = "sha256-0DBUS20337tpBi64mlJIWTQvIAdUvWbFCM9Sat7MEA8="; + "0.1.0".sha256 = "sha256-0DBUS20337tpBi64mlJIWTQvIAdUvWbFCM9Sat7MEA8="; }; releaseRev = v: "v${v}"; - propagatedBuildInputs = [ itree-io json QuickChick ]; + propagatedBuildInputs = [ + itree-io + json + QuickChick + ]; meta = { description = "From interaction trees to asynchronous tests."; diff --git a/pkgs/development/coq-modules/atbr/default.nix b/pkgs/development/coq-modules/atbr/default.nix index e1a77312eefa2e..7310e4b457027a 100644 --- a/pkgs/development/coq-modules/atbr/default.nix +++ b/pkgs/development/coq-modules/atbr/default.nix @@ -1,14 +1,25 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "atbr"; inherit version; - defaultVersion = let inherit (lib.versions) range; in + defaultVersion = + let + inherit (lib.versions) range; + in lib.switch coq.coq-version [ - { case = range "8.20" "8.20"; out = "8.20.0"; } + { + case = range "8.20" "8.20"; + out = "8.20.0"; + } ] null; release = { - "8.20.0".sha256 = "sha256-Okhtq6Gnq4HA3tEZJvf8JBnmk3OKdm6hC1qINmoShmo="; + "8.20.0".sha256 = "sha256-Okhtq6Gnq4HA3tEZJvf8JBnmk3OKdm6hC1qINmoShmo="; }; releaseRev = v: "v${v}"; diff --git a/pkgs/development/coq-modules/autosubst/default.nix b/pkgs/development/coq-modules/autosubst/default.nix index 7be4725255129b..e5fd36cd7f0570 100644 --- a/pkgs/development/coq-modules/autosubst/default.nix +++ b/pkgs/development/coq-modules/autosubst/default.nix @@ -1,4 +1,10 @@ -{ lib, mkCoqDerivation, coq, mathcomp-ssreflect, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + mathcomp-ssreflect, + version ? null, +}: mkCoqDerivation { pname = "autosubst"; @@ -10,18 +16,32 @@ mkCoqDerivation { release."1.9".sha256 = "sha256-XiLZjMc+1iwRGOstfLm/WQRF6FTdX6oJr5urn3wmLlA="; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.14" "8.20"; out = "1.9"; } - { case = range "8.14" "8.18"; out = "1.8"; } - { case = range "8.10" "8.13"; out = "1.7"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.14" "8.20"; + out = "1.9"; + } + { + case = range "8.14" "8.18"; + out = "1.8"; + } + { + case = range "8.10" "8.13"; + out = "1.7"; + } + ] null; propagatedBuildInputs = [ mathcomp-ssreflect ]; meta = with lib; { homepage = "https://www.ps.uni-saarland.de/autosubst/"; description = "Automation for de Bruijn syntax and substitution in Coq"; - maintainers = with maintainers; [ siraben jwiegley ]; + maintainers = with maintainers; [ + siraben + jwiegley + ]; license = licenses.mit; }; } diff --git a/pkgs/development/coq-modules/bbv/default.nix b/pkgs/development/coq-modules/bbv/default.nix index 340f32b830c4a8..44d0b0b40ceed7 100644 --- a/pkgs/development/coq-modules/bbv/default.nix +++ b/pkgs/development/coq-modules/bbv/default.nix @@ -1,15 +1,26 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "bbv"; owner = "mit-plv"; inherit version; - defaultVersion = let inherit (lib.versions) range; in + defaultVersion = + let + inherit (lib.versions) range; + in lib.switch coq.coq-version [ - { case = range "8.16" "8.19"; out = "1.5"; } + { + case = range "8.16" "8.19"; + out = "1.5"; + } ] null; release = { - "1.5".sha256 = "sha256-8/VPsfhNpuYpLmLC/hWszDhgvS6n8m7BRxUlea8PSUw="; + "1.5".sha256 = "sha256-8/VPsfhNpuYpLmLC/hWszDhgvS6n8m7BRxUlea8PSUw="; }; releaseRev = v: "v${v}"; diff --git a/pkgs/development/coq-modules/bignums/default.nix b/pkgs/development/coq-modules/bignums/default.nix index 3ff2f16700b7a3..384ae1d80daeb3 100644 --- a/pkgs/development/coq-modules/bignums/default.nix +++ b/pkgs/development/coq-modules/bignums/default.nix @@ -1,13 +1,26 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "bignums"; owner = "coq"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.13" "8.20"; out = "9.0.0+coq${coq.coq-version}"; } - { case = range "8.6" "8.17"; out = "${coq.coq-version}.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.13" "8.20"; + out = "9.0.0+coq${coq.coq-version}"; + } + { + case = range "8.6" "8.17"; + out = "${coq.coq-version}.0"; + } + ] null; release."9.0.0+coq8.20".sha256 = "sha256-pkvyDaMXRalc6Uu1eBTuiqTpRauRrzu946c6TavyTKY="; release."9.0.0+coq8.19".sha256 = "sha256-02uL+qWbUveHe67zKfc8w3U0iN3X2DKBsvP3pKpW8KQ="; @@ -25,14 +38,16 @@ mkCoqDerivation { release."8.12.0".sha256 = "14ijb3qy2hin3g4djx437jmnswxxq7lkfh3dwh9qvrds9a015yg8"; release."8.11.0".sha256 = "1xcd7c7qlvs0narfba6px34zq0mz8rffnhxw0kzhhg6i4iw115dp"; release."8.10.0".sha256 = "0bpb4flckn4nqxbs3wjiznyx1k7r8k93qdigp3qwmikp2lxvcbw5"; - release."8.9.0".sha256 = "03qz1w2xb2j5p06liz5yyafl0fl9vprcqm6j0iwi7rxwghl00p01"; - release."8.8.0".sha256 = "1ymxyrvjygscxkfj3qkq66skl3vdjhb670rzvsvgmwrjkrakjnfg"; - release."8.7.0".sha256 = "11c4sdmpd3l6jjl4v6k213z9fhrmmm1xnly3zmzam1wrrdif4ghl"; - release."8.6.0".rev = "v8.6.0"; - release."8.6.0".sha256 = "0553pcsy21cyhmns6k9qggzb67az8kl31d0lwlnz08bsqswigzrj"; + release."8.9.0".sha256 = "03qz1w2xb2j5p06liz5yyafl0fl9vprcqm6j0iwi7rxwghl00p01"; + release."8.8.0".sha256 = "1ymxyrvjygscxkfj3qkq66skl3vdjhb670rzvsvgmwrjkrakjnfg"; + release."8.7.0".sha256 = "11c4sdmpd3l6jjl4v6k213z9fhrmmm1xnly3zmzam1wrrdif4ghl"; + release."8.6.0".rev = "v8.6.0"; + release."8.6.0".sha256 = "0553pcsy21cyhmns6k9qggzb67az8kl31d0lwlnz08bsqswigzrj"; releaseRev = v: "${if lib.versions.isGe "9.0" v then "v" else "V"}${v}"; mlPlugin = true; - meta = { license = lib.licenses.lgpl2; }; + meta = { + license = lib.licenses.lgpl2; + }; } diff --git a/pkgs/development/coq-modules/category-theory/default.nix b/pkgs/development/coq-modules/category-theory/default.nix index 568a7fa2e73b2b..8b51d20f461444 100644 --- a/pkgs/development/coq-modules/category-theory/default.nix +++ b/pkgs/development/coq-modules/category-theory/default.nix @@ -1,4 +1,11 @@ -{ lib, mkCoqDerivation, coq, ssreflect, equations, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + ssreflect, + equations, + version ? null, +}: mkCoqDerivation { @@ -6,25 +13,42 @@ mkCoqDerivation { owner = "jwiegley"; release."1.0.0".sha256 = "sha256-qPgho4/VcL3vyMPJAMXXdqhYPEbNeXSZsoWbA/lGek4="; - release."20211213".rev = "449e30e929d56f6f90c22af2c91ffcc4d79837be"; + release."20211213".rev = "449e30e929d56f6f90c22af2c91ffcc4d79837be"; release."20211213".sha256 = "sha256:0vgfmph5l1zn6j4b851rcm43s8y9r83swsz07rpzhmfg34pk0nl0"; - release."20210730".rev = "d87937faaf7460bcd6985931ac36f551d67e11af"; + release."20210730".rev = "d87937faaf7460bcd6985931ac36f551d67e11af"; release."20210730".sha256 = "04x7433yvibxknk6gy4971yzb4saa3z4dnfy9n6irhyafzlxyf0f"; - release."20190414".rev = "706fdb4065cc2302d92ac2bce62cb59713253119"; + release."20190414".rev = "706fdb4065cc2302d92ac2bce62cb59713253119"; release."20190414".sha256 = "16lg4xs2wzbdbsn148xiacgl4wq4xwfqjnjkdhfr3w0qh1s81hay"; - release."20180709".rev = "3b9ba7b26a64d49a55e8b6ccea570a7f32c11ead"; + release."20180709".rev = "3b9ba7b26a64d49a55e8b6ccea570a7f32c11ead"; release."20180709".sha256 = "0f2nr8dgn1ab7hr7jrdmr1zla9g9h8216q4yf4wnff9qkln8sbbs"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.14" "8.17"; out = "1.0.0"; } - { case = range "8.10" "8.15"; out = "20211213"; } - { case = range "8.8" "8.9"; out = "20190414"; } - { case = range "8.6" "8.7"; out = "20180709"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.14" "8.17"; + out = "1.0.0"; + } + { + case = range "8.10" "8.15"; + out = "20211213"; + } + { + case = range "8.8" "8.9"; + out = "20190414"; + } + { + case = range "8.6" "8.7"; + out = "20180709"; + } + ] null; mlPlugin = true; - propagatedBuildInputs = [ ssreflect equations ]; + propagatedBuildInputs = [ + ssreflect + equations + ]; meta = { description = "Formalization of category theory in Coq for personal study and practical work"; diff --git a/pkgs/development/coq-modules/ceres/default.nix b/pkgs/development/coq-modules/ceres/default.nix index 2bff5224573c4d..86907967f03837 100644 --- a/pkgs/development/coq-modules/ceres/default.nix +++ b/pkgs/development/coq-modules/ceres/default.nix @@ -1,4 +1,9 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { @@ -7,10 +12,18 @@ mkCoqDerivation { owner = "Lysxia"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = range "8.14" "8.20"; out = "0.4.1"; } - { case = range "8.8" "8.16"; out = "0.4.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.14" "8.20"; + out = "0.4.1"; + } + { + case = range "8.8" "8.16"; + out = "0.4.0"; + } + ] null; release."0.4.1".sha256 = "sha256-9vyk8/8IVsqNyhw3WPzl8w3L9Wu7gfaMVa3n2nWjFiA="; release."0.4.0".sha256 = "sha256:0zwp3pn6fdj0qdig734zdczrls886al06mxqhhabms0jvvqijmbi"; diff --git a/pkgs/development/coq-modules/coinduction/default.nix b/pkgs/development/coq-modules/coinduction/default.nix index 3cb264378e8e38..c9792d1e960f86 100644 --- a/pkgs/development/coq-modules/coinduction/default.nix +++ b/pkgs/development/coq-modules/coinduction/default.nix @@ -1,15 +1,26 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "coinduction"; owner = "damien-pous"; inherit version; - defaultVersion = let inherit (lib.versions) range; in + defaultVersion = + let + inherit (lib.versions) range; + in lib.switch coq.coq-version [ - { case = range "8.19" "8.19"; out = "1.9"; } + { + case = range "8.19" "8.19"; + out = "1.9"; + } ] null; release = { - "1.9".sha256 = "sha256-bBU+xDklnzJBeN41GarW5KXzD8eKsOYtb//ULYumwWE="; + "1.9".sha256 = "sha256-bBU+xDklnzJBeN41GarW5KXzD8eKsOYtb//ULYumwWE="; }; releaseRev = v: "v${v}"; diff --git a/pkgs/development/coq-modules/compcert/default.nix b/pkgs/development/coq-modules/compcert/default.nix index a8edc6931a3dec..4adfa5698cf86f 100644 --- a/pkgs/development/coq-modules/compcert/default.nix +++ b/pkgs/development/coq-modules/compcert/default.nix @@ -1,223 +1,291 @@ -{ lib, mkCoqDerivation -, coq, flocq, MenhirLib -, ocamlPackages, fetchpatch, makeWrapper, coq2html -, stdenv, tools ? stdenv.cc -, version ? null +{ + lib, + mkCoqDerivation, + coq, + flocq, + MenhirLib, + ocamlPackages, + fetchpatch, + makeWrapper, + coq2html, + stdenv, + tools ? stdenv.cc, + version ? null, }: let -# https://compcert.org/man/manual002.html -targets = { - x86_64-linux = "x86_64-linux"; - aarch64-linux = "aarch64-linux"; - x86_64-darwin = "x86_64-macos"; - aarch64-darwin = "aarch64-macos"; - riscv32-linux = "rv32-linux"; - riscv64-linux = "rv64-linux"; -}; - -target = targets.${stdenv.hostPlatform.system} - or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); - -compcert = mkCoqDerivation { - - pname = "compcert"; - owner = "AbsInt"; - - inherit version; - releaseRev = v: "v${v}"; - - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = range "8.14" "8.20"; out = "3.14"; } - { case = isEq "8.13" ; out = "3.10"; } - { case = isEq "8.12" ; out = "3.9"; } - { case = range "8.8" "8.11"; out = "3.8"; } - ] null; - - release = { - "3.8".sha256 = "1gzlyxvw64ca12qql3wnq3bidcx9ygsklv9grjma3ib4hvg7vnr7"; - "3.9".sha256 = "1srcz2dqrvmbvv5cl66r34zqkm0hsbryk7gd3i9xx4slahc9zvdb"; - "3.10".sha256 = "sha256:19rmx8r8v46101ij5myfrz60arqjy7q3ra3fb8mxqqi3c8c4l4j6"; - "3.11".sha256 = "sha256-ZISs/ZAJVWtxp9+Sg5qV5Rss1gI9hK769GnBfawLa6A="; - "3.12".sha256 = "sha256-hXkQ8UnAx3k50OJGBmSm4hgrnRFCosu4+PEMrcKfmV0="; - "3.13".sha256 = "sha256-ZedxgEPr1ZgKIcyhQ6zD1l2xr6RDNNUYq/4ZyR6ojM4="; - "3.13.1".sha256 = "sha256-ldXbuzVB0Z+UVTd5S4yGSg6oRYiKbXLMmUZcQsJLcns="; - "3.14".sha256 = "sha256-QXJMpp/BaPiK5okHeo2rcmXENToXKjB51UqljMHTDgw="; + # https://compcert.org/man/manual002.html + targets = { + x86_64-linux = "x86_64-linux"; + aarch64-linux = "aarch64-linux"; + x86_64-darwin = "x86_64-macos"; + aarch64-darwin = "aarch64-macos"; + riscv32-linux = "rv32-linux"; + riscv64-linux = "rv64-linux"; }; - strictDeps = true; - - nativeBuildInputs = with ocamlPackages; [ makeWrapper ocaml findlib menhir coq coq2html ]; - buildInputs = with ocamlPackages; [ menhirLib ]; - propagatedBuildInputs = [ flocq MenhirLib ]; - - enableParallelBuilding = true; - - postPatch = '' - substituteInPlace ./configure \ - --replace \$\{toolprefix\}ar 'ar' \ - --replace '{toolprefix}gcc' '{toolprefix}cc' - ''; - - configurePhase = '' - ./configure -clightgen \ - -prefix $out \ - -coqdevdir $lib/lib/coq/${coq.coq-version}/user-contrib/compcert/ \ - -toolprefix ${tools}/bin/ \ - -use-external-Flocq \ - -use-external-MenhirLib \ - ${target} \ - ''; # don't remove the \ above, the command gets appended in override below - - installTargets = "documentation install"; - installFlags = []; # trust ./configure - preInstall = '' - mkdir -p $out/share/man - mkdir -p $man/share - ''; - postInstall = '' - # move man into place - mv $out/share/man/ $man/share/ - - # move docs into place - mkdir -p $doc/share/doc/compcert - mv doc/html $doc/share/doc/compcert/ - - # wrap ccomp to undefine _FORTIFY_SOURCE; ccomp invokes cc1 which sets - # _FORTIFY_SOURCE=2 by default, but undefines __GNUC__ (as it should), - # which causes a warning in libc. this suppresses it. - for x in ccomp clightgen; do - wrapProgram $out/bin/$x --add-flags "-U_FORTIFY_SOURCE" - done - ''; - - outputs = [ "out" "lib" "doc" "man" ]; - - meta = with lib; { - description = "Formally verified C compiler"; - homepage = "https://compcert.org"; - license = licenses.inria-compcert; - platforms = builtins.attrNames targets; - maintainers = with maintainers; [ thoughtpolice jwiegley vbgl ]; + target = + targets.${stdenv.hostPlatform.system} + or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + + compcert = mkCoqDerivation { + + pname = "compcert"; + owner = "AbsInt"; + + inherit version; + releaseRev = v: "v${v}"; + + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.14" "8.20"; + out = "3.14"; + } + { + case = isEq "8.13"; + out = "3.10"; + } + { + case = isEq "8.12"; + out = "3.9"; + } + { + case = range "8.8" "8.11"; + out = "3.8"; + } + ] null; + + release = { + "3.8".sha256 = "1gzlyxvw64ca12qql3wnq3bidcx9ygsklv9grjma3ib4hvg7vnr7"; + "3.9".sha256 = "1srcz2dqrvmbvv5cl66r34zqkm0hsbryk7gd3i9xx4slahc9zvdb"; + "3.10".sha256 = "sha256:19rmx8r8v46101ij5myfrz60arqjy7q3ra3fb8mxqqi3c8c4l4j6"; + "3.11".sha256 = "sha256-ZISs/ZAJVWtxp9+Sg5qV5Rss1gI9hK769GnBfawLa6A="; + "3.12".sha256 = "sha256-hXkQ8UnAx3k50OJGBmSm4hgrnRFCosu4+PEMrcKfmV0="; + "3.13".sha256 = "sha256-ZedxgEPr1ZgKIcyhQ6zD1l2xr6RDNNUYq/4ZyR6ojM4="; + "3.13.1".sha256 = "sha256-ldXbuzVB0Z+UVTd5S4yGSg6oRYiKbXLMmUZcQsJLcns="; + "3.14".sha256 = "sha256-QXJMpp/BaPiK5okHeo2rcmXENToXKjB51UqljMHTDgw="; + }; + + strictDeps = true; + + nativeBuildInputs = with ocamlPackages; [ + makeWrapper + ocaml + findlib + menhir + coq + coq2html + ]; + buildInputs = with ocamlPackages; [ menhirLib ]; + propagatedBuildInputs = [ + flocq + MenhirLib + ]; + + enableParallelBuilding = true; + + postPatch = '' + substituteInPlace ./configure \ + --replace \$\{toolprefix\}ar 'ar' \ + --replace '{toolprefix}gcc' '{toolprefix}cc' + ''; + + configurePhase = '' + ./configure -clightgen \ + -prefix $out \ + -coqdevdir $lib/lib/coq/${coq.coq-version}/user-contrib/compcert/ \ + -toolprefix ${tools}/bin/ \ + -use-external-Flocq \ + -use-external-MenhirLib \ + ${target} \ + ''; # don't remove the \ above, the command gets appended in override below + + installTargets = "documentation install"; + installFlags = [ ]; # trust ./configure + preInstall = '' + mkdir -p $out/share/man + mkdir -p $man/share + ''; + postInstall = '' + # move man into place + mv $out/share/man/ $man/share/ + + # move docs into place + mkdir -p $doc/share/doc/compcert + mv doc/html $doc/share/doc/compcert/ + + # wrap ccomp to undefine _FORTIFY_SOURCE; ccomp invokes cc1 which sets + # _FORTIFY_SOURCE=2 by default, but undefines __GNUC__ (as it should), + # which causes a warning in libc. this suppresses it. + for x in ccomp clightgen; do + wrapProgram $out/bin/$x --add-flags "-U_FORTIFY_SOURCE" + done + ''; + + outputs = [ + "out" + "lib" + "doc" + "man" + ]; + + meta = with lib; { + description = "Formally verified C compiler"; + homepage = "https://compcert.org"; + license = licenses.inria-compcert; + platforms = builtins.attrNames targets; + maintainers = with maintainers; [ + thoughtpolice + jwiegley + vbgl + ]; + }; }; -}; -patched_compcert = compcert.overrideAttrs (o: - { - patches = with lib.versions; lib.switch [ coq.version o.version ] [ - { cases = [ (range "8.12.2" "8.13.2") "3.8" ]; - out = [ - # Support for Coq 8.12.2 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/06956421b4307054af221c118c5f59593c0e67b9.patch"; - sha256 = "1f90q6j3xfvnf3z830bkd4d8526issvmdlrjlc95bfsqs78i1yrl"; - }) - # Support for Coq 8.13.0 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/0895388e7ebf9c9f3176d225107e21968919fb97.patch"; - sha256 = "0qhkzgb2xl5kxys81pldp3mr39gd30lvr2l2wmplij319vp3xavd"; - }) - # Support for Coq 8.13.1 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/6bf310dd678285dc193798e89fc2c441d8430892.patch"; - sha256 = "026ahhvpj5pksy90f8pnxgmhgwfqk4kwyvcf8x3dsanvz98d4pj5"; - }) - # Drop support for Coq < 8.9 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/7563a5df926a4c6fb1489a7a4c847641c8a35095.patch"; - sha256 = "05vkslzy399r3dm6dmjs722rrajnyfa30xsyy3djl52isvn4gyfb"; - }) - # Support for Coq 8.13.2 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/48bc183167c4ce01a5c9ea86e49d60530adf7290.patch"; - sha256 = "0j62lppfk26d1brdp3qwll2wi4gvpx1k70qivpvby5f7dpkrkax1"; - }) - ]; - } - { cases = [ (range "8.14" "8.15") "3.10" ]; - out = [ - # Support for Coq 8.14.1 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/a79f0f99831aa0b0742bf7cce459cc9353bd7cd0.patch"; - sha256 = "sha256:0g20x8gfzvplpad9y9vr1p33k6qv6rsp691x6687v9ffvz7zsz94"; - }) - # Support for Coq 8.15.0 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/a882f78c069f7337dd9f4abff117d4df98ef38a6.patch"; - sha256 = "sha256:16i87s608fj9ni7cvd5wrd7gicqniad7w78wi26pxdy0pacl7bjg"; - }) - # Support for Coq 8.15.1 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/10a976994d7fd30d143354c289ae735d210ccc09.patch"; - sha256 = "sha256:0bg58gpkgxlmxzp6sg0dvybrfk0pxnm7qd6vxlrbsbm2w6wk03jv"; - }) - # Support for Coq 8.15.2 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/283a5be7296c4c0a94d863b427c77007ab875733.patch"; - sha256 = "sha256:1s7hvb5ii3p8kkcjlzwldvk8xc3iiibxi9935qjbrh25xi6qs66k"; - }) - ]; - } - { cases = [ (isEq "8.16") (range "3.11" "3.12") ]; - out = [ - # Support for Coq 8.16.0 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/34be08a23d18d56f2dde24fd24b6dbe3bcb01ec3.patch"; - sha256 = "sha256-a5YnftGVadVypEqrOYRRxI7YtGOEWyKnO4GqakFhvzI="; - }) - # Support for Coq 8.16.1 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/35531503b3493cb9b0ec8a8585e84928c85b4af9.patch"; - hash = "sha256-DvtYi/eiPUe8tA0EFTcCjJA0JjtVKceUsX4ZDM0pWkE="; - }) - ]; - } - { cases = [ (range "8.17" "8.19") (isEq "3.13") ]; - out = [ - # Support for Coq 8.17.0 & Coq 8.17.1 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/2e04d986bdae578186e40330842878559a550402.patch"; - hash = "sha256-2ZRAjUUSScJI8ogWFTnukCUnJdLWGvyOPyfIVlHL4ig="; - }) - # Support for Coq 8.18.0 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/28218c5663cba36c6078ca342335d4e55c412bd7.patch"; - hash = "sha256-aAatUMO26oZwFYGh1BXYWxbTuyOgU8BAKMGDS5796hM="; - }) - # MenhirLib update - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/9f3d7b6eb99377ad4689cd57563c484c57baa457.patch"; - hash = "sha256-paofdSBxP/JFoBSiO1OI+mjKRI3UCanXRh/drzYt93E="; - }) - # Support for Coq 8.19.0 & Coq 8.19.1 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/a2e4ed62fc558d565366845f9d135bd7db5e23c4.patch"; - hash = "sha256-ufk0bokuayLfkSvK3cK4E9iXU5eZpp9d/ETSa/zCfMg="; - }) - # Support for Coq 8.19.2 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/8fcfb7d2a6e9ba44003ccab0dfcc894982779af1.patch"; - hash = "sha256-m/kcnDBBPWFriipuGvKZUqLQU8/W1uqw8j4qfCwnTZk="; - }) - ]; - } - { cases = [ (range "8.19" "8.20") (isEq "3.14") ]; - out = [ - # Support for Coq 8.19.2 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/8fcfb7d2a6e9ba44003ccab0dfcc894982779af1.patch"; - hash = "sha256-m/kcnDBBPWFriipuGvKZUqLQU8/W1uqw8j4qfCwnTZk="; - }) - # Support for Coq 8.20.0 - (fetchpatch { - url = "https://github.com/AbsInt/CompCert/commit/20a5b48758bf8ac18e4c420df67017b371efc237.patch"; - hash = "sha256-TJ87CvLiAv1absGnPsTXsD/HQwKgS82loUTcosulyso="; - }) - ]; - } - ] []; - }); in -patched_compcert.overrideAttrs (o: - lib.optionalAttrs (coq.version != null && coq.version == "dev") - { configurePhase = "${o.configurePhase} -ignore-ocaml-version -ignore-coq-version"; } + patched_compcert = compcert.overrideAttrs (o: { + patches = + with lib.versions; + lib.switch [ coq.version o.version ] + [ + { + cases = [ + (range "8.12.2" "8.13.2") + "3.8" + ]; + out = [ + # Support for Coq 8.12.2 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/06956421b4307054af221c118c5f59593c0e67b9.patch"; + sha256 = "1f90q6j3xfvnf3z830bkd4d8526issvmdlrjlc95bfsqs78i1yrl"; + }) + # Support for Coq 8.13.0 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/0895388e7ebf9c9f3176d225107e21968919fb97.patch"; + sha256 = "0qhkzgb2xl5kxys81pldp3mr39gd30lvr2l2wmplij319vp3xavd"; + }) + # Support for Coq 8.13.1 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/6bf310dd678285dc193798e89fc2c441d8430892.patch"; + sha256 = "026ahhvpj5pksy90f8pnxgmhgwfqk4kwyvcf8x3dsanvz98d4pj5"; + }) + # Drop support for Coq < 8.9 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/7563a5df926a4c6fb1489a7a4c847641c8a35095.patch"; + sha256 = "05vkslzy399r3dm6dmjs722rrajnyfa30xsyy3djl52isvn4gyfb"; + }) + # Support for Coq 8.13.2 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/48bc183167c4ce01a5c9ea86e49d60530adf7290.patch"; + sha256 = "0j62lppfk26d1brdp3qwll2wi4gvpx1k70qivpvby5f7dpkrkax1"; + }) + ]; + } + { + cases = [ + (range "8.14" "8.15") + "3.10" + ]; + out = [ + # Support for Coq 8.14.1 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/a79f0f99831aa0b0742bf7cce459cc9353bd7cd0.patch"; + sha256 = "sha256:0g20x8gfzvplpad9y9vr1p33k6qv6rsp691x6687v9ffvz7zsz94"; + }) + # Support for Coq 8.15.0 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/a882f78c069f7337dd9f4abff117d4df98ef38a6.patch"; + sha256 = "sha256:16i87s608fj9ni7cvd5wrd7gicqniad7w78wi26pxdy0pacl7bjg"; + }) + # Support for Coq 8.15.1 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/10a976994d7fd30d143354c289ae735d210ccc09.patch"; + sha256 = "sha256:0bg58gpkgxlmxzp6sg0dvybrfk0pxnm7qd6vxlrbsbm2w6wk03jv"; + }) + # Support for Coq 8.15.2 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/283a5be7296c4c0a94d863b427c77007ab875733.patch"; + sha256 = "sha256:1s7hvb5ii3p8kkcjlzwldvk8xc3iiibxi9935qjbrh25xi6qs66k"; + }) + ]; + } + { + cases = [ + (isEq "8.16") + (range "3.11" "3.12") + ]; + out = [ + # Support for Coq 8.16.0 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/34be08a23d18d56f2dde24fd24b6dbe3bcb01ec3.patch"; + sha256 = "sha256-a5YnftGVadVypEqrOYRRxI7YtGOEWyKnO4GqakFhvzI="; + }) + # Support for Coq 8.16.1 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/35531503b3493cb9b0ec8a8585e84928c85b4af9.patch"; + hash = "sha256-DvtYi/eiPUe8tA0EFTcCjJA0JjtVKceUsX4ZDM0pWkE="; + }) + ]; + } + { + cases = [ + (range "8.17" "8.19") + (isEq "3.13") + ]; + out = [ + # Support for Coq 8.17.0 & Coq 8.17.1 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/2e04d986bdae578186e40330842878559a550402.patch"; + hash = "sha256-2ZRAjUUSScJI8ogWFTnukCUnJdLWGvyOPyfIVlHL4ig="; + }) + # Support for Coq 8.18.0 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/28218c5663cba36c6078ca342335d4e55c412bd7.patch"; + hash = "sha256-aAatUMO26oZwFYGh1BXYWxbTuyOgU8BAKMGDS5796hM="; + }) + # MenhirLib update + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/9f3d7b6eb99377ad4689cd57563c484c57baa457.patch"; + hash = "sha256-paofdSBxP/JFoBSiO1OI+mjKRI3UCanXRh/drzYt93E="; + }) + # Support for Coq 8.19.0 & Coq 8.19.1 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/a2e4ed62fc558d565366845f9d135bd7db5e23c4.patch"; + hash = "sha256-ufk0bokuayLfkSvK3cK4E9iXU5eZpp9d/ETSa/zCfMg="; + }) + # Support for Coq 8.19.2 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/8fcfb7d2a6e9ba44003ccab0dfcc894982779af1.patch"; + hash = "sha256-m/kcnDBBPWFriipuGvKZUqLQU8/W1uqw8j4qfCwnTZk="; + }) + ]; + } + { + cases = [ + (range "8.19" "8.20") + (isEq "3.14") + ]; + out = [ + # Support for Coq 8.19.2 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/8fcfb7d2a6e9ba44003ccab0dfcc894982779af1.patch"; + hash = "sha256-m/kcnDBBPWFriipuGvKZUqLQU8/W1uqw8j4qfCwnTZk="; + }) + # Support for Coq 8.20.0 + (fetchpatch { + url = "https://github.com/AbsInt/CompCert/commit/20a5b48758bf8ac18e4c420df67017b371efc237.patch"; + hash = "sha256-TJ87CvLiAv1absGnPsTXsD/HQwKgS82loUTcosulyso="; + }) + ]; + } + ] + [ ]; + }); +in +patched_compcert.overrideAttrs ( + o: + lib.optionalAttrs (coq.version != null && coq.version == "dev") { + configurePhase = "${o.configurePhase} -ignore-ocaml-version -ignore-coq-version"; + } ) diff --git a/pkgs/development/coq-modules/contribs/default.nix b/pkgs/development/coq-modules/contribs/default.nix index 2d10f683cc3603..f3c01cee334f73 100644 --- a/pkgs/development/coq-modules/contribs/default.nix +++ b/pkgs/development/coq-modules/contribs/default.nix @@ -1,29 +1,57 @@ -{ lib, mkCoqDerivation, coq, callPackage }: - - let mkContrib = pname: coqs: param: - let contribVersion = {version ? null}: mkCoqDerivation ({ - inherit pname version; - owner = "coq-contribs"; - mlPlugin = true; - } // lib.optionalAttrs (builtins.elem coq.coq-version coqs) ({ - defaultVersion = param.version; - release = { "${param.version}" = { inherit (param) rev sha256; }; }; - } // (removeAttrs param [ "version" "rev" "sha256" ])) - ); in - lib.makeOverridable contribVersion {} ; in { - aac-tactics = mkContrib "aac-tactics" [ "8.7" "8.8" ] { - "8.7" = { - version = "20180530"; - rev = "f01df35e1d796ce1fdc7ba3d670ce5d63c95d544"; - sha256 = "1bwvnbd5ws1plgj147blcrvyycf3gg3fz3rm2mckln8z3sfxyq2k"; - }; - "8.8" = { - version = "20180530"; - rev = "86ac28259030649ef51460e4de2441c8a1017751"; - sha256 = "09bbk2a7pn0j76mmapl583f8a20zqd3a1m9lkml8rpwml692bzi9"; - }; - }.${coq.coq-version}; + lib, + mkCoqDerivation, + coq, + callPackage, +}: + +let + mkContrib = + pname: coqs: param: + let + contribVersion = + { + version ? null, + }: + mkCoqDerivation ( + { + inherit pname version; + owner = "coq-contribs"; + mlPlugin = true; + } + // lib.optionalAttrs (builtins.elem coq.coq-version coqs) ( + { + defaultVersion = param.version; + release = { + "${param.version}" = { inherit (param) rev sha256; }; + }; + } + // (removeAttrs param [ + "version" + "rev" + "sha256" + ]) + ) + ); + in + lib.makeOverridable contribVersion { }; +in +{ + aac-tactics = + mkContrib "aac-tactics" [ "8.7" "8.8" ] + { + "8.7" = { + version = "20180530"; + rev = "f01df35e1d796ce1fdc7ba3d670ce5d63c95d544"; + sha256 = "1bwvnbd5ws1plgj147blcrvyycf3gg3fz3rm2mckln8z3sfxyq2k"; + }; + "8.8" = { + version = "20180530"; + rev = "86ac28259030649ef51460e4de2441c8a1017751"; + sha256 = "09bbk2a7pn0j76mmapl583f8a20zqd3a1m9lkml8rpwml692bzi9"; + }; + } + .${coq.coq-version}; abp = mkContrib "abp" [ "8.5" "8.6" "8.7" ] { version = "v8.6.0"; @@ -187,28 +215,31 @@ sha256 = "1ddwzg12pbzpnz3njin4zhpph92kscrbsn3bzds26yj8fp76zc33"; }; - containers = mkContrib "containers" [ "8.6" "8.7" "8.8" "8.9" ] { - "8.6" = { - version = "8.6.0"; - rev = "fa1fec7"; - sha256 = "1ns0swlr8hzb1zc7fsyd3vws1vbq0vvfxcf0lszqnca9c9hfkfy4"; - }; - "8.7" = { - version = "20180313"; - rev = "77ac16366529c9e558f70ba86f0168a76ca76b8f"; - sha256 = "01gp8injb0knaxgqsdc4x9h8714k7qxg7j5w7y6i45dnpd81ndr4"; - }; - "8.8" = { - version = "20180330"; - rev = "52b86bed1671321b25fe4d7495558f9f221b12aa"; - sha256 = "0hbnrwdgryr52170cfrlbiymr88jsyxilnpr343vnprqq3zk1xz0"; - }; - "8.9" = { - version = "20190222"; - rev = "aa33052c1edfc5a65885942a67c2773b5d96f8cc"; - sha256 = "0mjgfdr9bzsch0dlk4vq1frkaig14dqh46r54cv0l15flxapg0iw"; - }; - }.${coq.coq-version}; + containers = + mkContrib "containers" [ "8.6" "8.7" "8.8" "8.9" ] + { + "8.6" = { + version = "8.6.0"; + rev = "fa1fec7"; + sha256 = "1ns0swlr8hzb1zc7fsyd3vws1vbq0vvfxcf0lszqnca9c9hfkfy4"; + }; + "8.7" = { + version = "20180313"; + rev = "77ac16366529c9e558f70ba86f0168a76ca76b8f"; + sha256 = "01gp8injb0knaxgqsdc4x9h8714k7qxg7j5w7y6i45dnpd81ndr4"; + }; + "8.8" = { + version = "20180330"; + rev = "52b86bed1671321b25fe4d7495558f9f221b12aa"; + sha256 = "0hbnrwdgryr52170cfrlbiymr88jsyxilnpr343vnprqq3zk1xz0"; + }; + "8.9" = { + version = "20190222"; + rev = "aa33052c1edfc5a65885942a67c2773b5d96f8cc"; + sha256 = "0mjgfdr9bzsch0dlk4vq1frkaig14dqh46r54cv0l15flxapg0iw"; + }; + } + .${coq.coq-version}; continuations = mkContrib "continuations" [ ] { version = "v8.5.0-13-g6885310"; @@ -343,9 +374,9 @@ }; firing-squad = mkContrib "firing-squad" [ "8.6" ] { - version = "v8.5.0-9-gbe728cd"; - rev = "be728cddbee58088809b51c25425d2a4bdf9b823"; - sha256 = "0i0v5x6lncjasxk22pras3644ff026q8jai45dbimf2fz73312c9"; + version = "v8.5.0-9-gbe728cd"; + rev = "be728cddbee58088809b51c25425d2a4bdf9b823"; + sha256 = "0i0v5x6lncjasxk22pras3644ff026q8jai45dbimf2fz73312c9"; }; float = mkContrib "float" [ "8.7" ] { diff --git a/pkgs/development/coq-modules/coq-bits/default.nix b/pkgs/development/coq-modules/coq-bits/default.nix index cadf18df73113e..6754ba4d66a786 100644 --- a/pkgs/development/coq-modules/coq-bits/default.nix +++ b/pkgs/development/coq-modules/coq-bits/default.nix @@ -1,13 +1,36 @@ -{ lib, mkCoqDerivation, coq, mathcomp, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + mathcomp, + version ? null, +}: mkCoqDerivation { pname = "coq-bits"; repo = "bits"; inherit version; - defaultVersion = with lib.versions; lib.switch [ coq.version mathcomp.version ] [ - { cases = [ (range "8.10" "8.16") (isLt "2.0") ]; out = "1.1.0"; } - { cases = [ (range "8.7" "8.15") (isLt "2.0") ]; out = "1.0.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.version mathcomp.version ] + [ + { + cases = [ + (range "8.10" "8.16") + (isLt "2.0") + ]; + out = "1.1.0"; + } + { + cases = [ + (range "8.7" "8.15") + (isLt "2.0") + ]; + out = "1.0.0"; + } + ] + null; release."1.1.0".sha256 = "sha256-TCw1kSXeW0ysIdLeNr+EGmpGumEE9i8tinEMp57UXaE="; release."1.0.0".sha256 = "0nv5mdgrd075dpd8bc7h0xc5i95v0pkm0bfyq5rj6ii1s54dwcjl"; diff --git a/pkgs/development/coq-modules/coq-elpi/default.nix b/pkgs/development/coq-modules/coq-elpi/default.nix index eacafcbe38091c..4765e8fbb1deb4 100644 --- a/pkgs/development/coq-modules/coq-elpi/default.nix +++ b/pkgs/development/coq-modules/coq-elpi/default.nix @@ -1,61 +1,150 @@ -{ lib, mkCoqDerivation, which, coq, version ? null }: +{ + lib, + mkCoqDerivation, + which, + coq, + version ? null, +}: let - elpi = coq.ocamlPackages.elpi.override (lib.switch coq.coq-version [ - { case = "8.11"; out = { version = "1.11.4"; };} - { case = "8.12"; out = { version = "1.12.0"; };} - { case = "8.13"; out = { version = "1.13.7"; };} - { case = "8.14"; out = { version = "1.13.7"; };} - { case = "8.15"; out = { version = "1.15.0"; };} - { case = "8.16"; out = { version = "1.17.0"; };} - { case = "8.17"; out = { version = "1.17.0"; };} - { case = "8.18"; out = { version = "1.18.1"; };} - { case = "8.19"; out = { version = "1.18.1"; };} - { case = "8.20"; out = { version = "1.19.2"; };} - ] {} ); -in (mkCoqDerivation { + elpi = coq.ocamlPackages.elpi.override ( + lib.switch coq.coq-version [ + { + case = "8.11"; + out = { + version = "1.11.4"; + }; + } + { + case = "8.12"; + out = { + version = "1.12.0"; + }; + } + { + case = "8.13"; + out = { + version = "1.13.7"; + }; + } + { + case = "8.14"; + out = { + version = "1.13.7"; + }; + } + { + case = "8.15"; + out = { + version = "1.15.0"; + }; + } + { + case = "8.16"; + out = { + version = "1.17.0"; + }; + } + { + case = "8.17"; + out = { + version = "1.17.0"; + }; + } + { + case = "8.18"; + out = { + version = "1.18.1"; + }; + } + { + case = "8.19"; + out = { + version = "1.18.1"; + }; + } + { + case = "8.20"; + out = { + version = "1.19.2"; + }; + } + ] { } + ); +in +(mkCoqDerivation { pname = "elpi"; - repo = "coq-elpi"; + repo = "coq-elpi"; owner = "LPCIC"; inherit version; defaultVersion = lib.switch coq.coq-version [ - { case = "8.20"; out = "2.2.0"; } - { case = "8.19"; out = "2.0.1"; } - { case = "8.18"; out = "2.0.0"; } - { case = "8.17"; out = "1.18.0"; } - { case = "8.16"; out = "1.15.6"; } - { case = "8.15"; out = "1.14.0"; } - { case = "8.14"; out = "1.11.2"; } - { case = "8.13"; out = "1.11.1"; } - { case = "8.12"; out = "1.8.3_8.12"; } - { case = "8.11"; out = "1.6.3_8.11"; } + { + case = "8.20"; + out = "2.2.0"; + } + { + case = "8.19"; + out = "2.0.1"; + } + { + case = "8.18"; + out = "2.0.0"; + } + { + case = "8.17"; + out = "1.18.0"; + } + { + case = "8.16"; + out = "1.15.6"; + } + { + case = "8.15"; + out = "1.14.0"; + } + { + case = "8.14"; + out = "1.11.2"; + } + { + case = "8.13"; + out = "1.11.1"; + } + { + case = "8.12"; + out = "1.8.3_8.12"; + } + { + case = "8.11"; + out = "1.6.3_8.11"; + } ] null; - release."2.2.0".sha256 = "sha256-rADEoqTXM7/TyYkUKsmCFfj6fjpWdnZEOK++5oLfC/I="; - release."2.0.1".sha256 = "sha256-cuoPsEJ+JRLVc9Golt2rJj4P7lKltTrrmQijjoViooc="; - release."2.0.0".sha256 = "sha256-A/cH324M21k3SZ7+YWXtaYEbu6dZQq3K0cb1RMKjbsM="; - release."1.19.0".sha256 = "sha256-kGoo61nJxeG/BqV+iQaV3iinwPStND+7+fYMxFkiKrQ="; - release."1.18.0".sha256 = "sha256-2fCOlhqi4YkiL5n8SYHuc3pLH+DArf9zuMH7IhpBc2Y="; - release."1.17.0".sha256 = "sha256-J8GatRKFU0ekNCG3V5dBI+FXypeHcLgC5QJYGYzFiEM="; - release."1.15.6".sha256 = "sha256-qc0q01tW8NVm83801HHOBHe/7H1/F2WGDbKO6nCXfno="; - release."1.15.1".sha256 = "sha256-NT2RlcIsFB9AvBhMxil4ZZIgx+KusMqDflj2HgQxsZg="; - release."1.14.0".sha256 = "sha256:1v2p5dlpviwzky2i14cj7gcgf8cr0j54bdm9fl5iz1ckx60j6nvp"; - release."1.13.0".sha256 = "1j7s7dlnjbw222gnbrsjgmjck1yrx7h6hwm8zikcyxi0zys17w7n"; - release."1.12.1".sha256 = "sha256-4mO6/co7NcIQSGIQJyoO8lNWXr6dqz+bIYPO/G0cPkY="; - release."1.11.2".sha256 = "0qk5cfh15y2zrja7267629dybd3irvxk1raz7z8qfir25a81ckd4"; - release."1.11.1".sha256 = "10j076vc2hdcbm15m6s7b6xdzibgfcbzlkgjnlkr2vv9k13qf8kc"; - release."1.10.1".sha256 = "1zsyx26dvj7pznfd2msl2w7zbw51q1nsdw0bdvdha6dga7ijf7xk"; - release."1.9.7".sha256 = "0rvn12h9dpk9s4pxy32p8j0a1h7ib7kg98iv1cbrdg25y5vs85n1"; - release."1.9.5".sha256 = "0gjdwmb6bvb5gh0a6ra48bz5fb3pr5kpxijb7a8mfydvar5i9qr6"; - release."1.9.4".sha256 = "0nii7238mya74f9g6147qmpg6gv6ic9b54x5v85nb6q60d9jh0jq"; - release."1.9.3".sha256 = "198irm800fx3n8n56vx1c6f626cizp1d7jfkrc6ba4iqhb62ma0z"; - release."1.9.2".sha256 = "1rr2fr8vjkc0is7vh1461aidz2iwkigdkp6bqss4hhv0c3ijnn07"; - release."1.8.3_8.12".sha256 = "15z2l4zy0qpw0ws7bvsmpmyv543aqghrfnl48nlwzn9q0v89p557"; + release."2.2.0".sha256 = "sha256-rADEoqTXM7/TyYkUKsmCFfj6fjpWdnZEOK++5oLfC/I="; + release."2.0.1".sha256 = "sha256-cuoPsEJ+JRLVc9Golt2rJj4P7lKltTrrmQijjoViooc="; + release."2.0.0".sha256 = "sha256-A/cH324M21k3SZ7+YWXtaYEbu6dZQq3K0cb1RMKjbsM="; + release."1.19.0".sha256 = "sha256-kGoo61nJxeG/BqV+iQaV3iinwPStND+7+fYMxFkiKrQ="; + release."1.18.0".sha256 = "sha256-2fCOlhqi4YkiL5n8SYHuc3pLH+DArf9zuMH7IhpBc2Y="; + release."1.17.0".sha256 = "sha256-J8GatRKFU0ekNCG3V5dBI+FXypeHcLgC5QJYGYzFiEM="; + release."1.15.6".sha256 = "sha256-qc0q01tW8NVm83801HHOBHe/7H1/F2WGDbKO6nCXfno="; + release."1.15.1".sha256 = "sha256-NT2RlcIsFB9AvBhMxil4ZZIgx+KusMqDflj2HgQxsZg="; + release."1.14.0".sha256 = "sha256:1v2p5dlpviwzky2i14cj7gcgf8cr0j54bdm9fl5iz1ckx60j6nvp"; + release."1.13.0".sha256 = "1j7s7dlnjbw222gnbrsjgmjck1yrx7h6hwm8zikcyxi0zys17w7n"; + release."1.12.1".sha256 = "sha256-4mO6/co7NcIQSGIQJyoO8lNWXr6dqz+bIYPO/G0cPkY="; + release."1.11.2".sha256 = "0qk5cfh15y2zrja7267629dybd3irvxk1raz7z8qfir25a81ckd4"; + release."1.11.1".sha256 = "10j076vc2hdcbm15m6s7b6xdzibgfcbzlkgjnlkr2vv9k13qf8kc"; + release."1.10.1".sha256 = "1zsyx26dvj7pznfd2msl2w7zbw51q1nsdw0bdvdha6dga7ijf7xk"; + release."1.9.7".sha256 = "0rvn12h9dpk9s4pxy32p8j0a1h7ib7kg98iv1cbrdg25y5vs85n1"; + release."1.9.5".sha256 = "0gjdwmb6bvb5gh0a6ra48bz5fb3pr5kpxijb7a8mfydvar5i9qr6"; + release."1.9.4".sha256 = "0nii7238mya74f9g6147qmpg6gv6ic9b54x5v85nb6q60d9jh0jq"; + release."1.9.3".sha256 = "198irm800fx3n8n56vx1c6f626cizp1d7jfkrc6ba4iqhb62ma0z"; + release."1.9.2".sha256 = "1rr2fr8vjkc0is7vh1461aidz2iwkigdkp6bqss4hhv0c3ijnn07"; + release."1.8.3_8.12".sha256 = "15z2l4zy0qpw0ws7bvsmpmyv543aqghrfnl48nlwzn9q0v89p557"; release."1.8.3_8.12".version = "1.8.3"; - release."1.8.2_8.12".sha256 = "1n6jwcdazvjgj8vsv2r9zgwpw5yqr5a1ndc2pwhmhqfl04b5dk4y"; + release."1.8.2_8.12".sha256 = "1n6jwcdazvjgj8vsv2r9zgwpw5yqr5a1ndc2pwhmhqfl04b5dk4y"; release."1.8.2_8.12".version = "1.8.2"; - release."1.8.1".sha256 = "1fbbdccdmr8g4wwpihzp4r2xacynjznf817lhijw6kqfav75zd0r"; - release."1.8.0".sha256 = "13ywjg94zkbki22hx7s4gfm9rr87r4ghsgan23xyl3l9z8q0idd1"; - release."1.7.0".sha256 = "1ws5cqr0xawv69prgygbl3q6dgglbaw0vc397h9flh90kxaqgyh8"; + release."1.8.1".sha256 = "1fbbdccdmr8g4wwpihzp4r2xacynjznf817lhijw6kqfav75zd0r"; + release."1.8.0".sha256 = "13ywjg94zkbki22hx7s4gfm9rr87r4ghsgan23xyl3l9z8q0idd1"; + release."1.7.0".sha256 = "1ws5cqr0xawv69prgygbl3q6dgglbaw0vc397h9flh90kxaqgyh8"; release."1.6.3_8.11".sha256 = "1j340cr2bv95clzzkkfmsjkklham1mj84cmiyprzwv20q89zr1hp"; release."1.6.3_8.11".version = "1.6.3"; release."1.6.2_8.11".sha256 = "06xrx0ljilwp63ik2sxxr7h617dgbch042xfcnfpy5x96br147rn"; @@ -64,23 +153,28 @@ in (mkCoqDerivation { release."1.6.1_8.11".version = "1.6.1"; release."1.6.0_8.11".sha256 = "0ahxjnzmd7kl3gl38kyjqzkfgllncr2ybnw8bvgrc6iddgga7bpq"; release."1.6.0_8.11".version = "1.6.0"; - release."1.6.0".sha256 = "0kf99i43mlf750fr7fric764mm495a53mg5kahnbp6zcjcxxrm0b"; + release."1.6.0".sha256 = "0kf99i43mlf750fr7fric764mm495a53mg5kahnbp6zcjcxxrm0b"; releaseRev = v: "v${v}"; buildFlags = [ "OCAMLWARN=" ]; mlPlugin = true; useDuneifVersion = v: lib.versions.isGe "2.2.0" v || v == "dev"; - propagatedBuildInputs = [ coq.ocamlPackages.findlib elpi ]; + propagatedBuildInputs = [ + coq.ocamlPackages.findlib + elpi + ]; meta = { description = "Coq plugin embedding ELPI"; maintainers = [ lib.maintainers.cohencyril ]; license = lib.licenses.lgpl21Plus; }; -}).overrideAttrs (o: - lib.optionalAttrs (o.version != null - && (o.version == "dev" || lib.versions.isGe "2.2.0" o.version)) - { - propagatedBuildInputs = o.propagatedBuildInputs ++ [ coq.ocamlPackages.ppx_optcomp ]; - }) +}).overrideAttrs + ( + o: + lib.optionalAttrs (o.version != null && (o.version == "dev" || lib.versions.isGe "2.2.0" o.version)) + { + propagatedBuildInputs = o.propagatedBuildInputs ++ [ coq.ocamlPackages.ppx_optcomp ]; + } + ) diff --git a/pkgs/development/coq-modules/coq-hammer/default.nix b/pkgs/development/coq-modules/coq-hammer/default.nix index 33785178228f79..ab7f1b2da20f3a 100644 --- a/pkgs/development/coq-modules/coq-hammer/default.nix +++ b/pkgs/development/coq-modules/coq-hammer/default.nix @@ -1,9 +1,20 @@ -{ mkCoqDerivation, coq, coq-hammer-tactics, version ? null }: +{ + mkCoqDerivation, + coq, + coq-hammer-tactics, + version ? null, +}: mkCoqDerivation { inherit version; pname = "coq-hammer"; - inherit (coq-hammer-tactics) owner repo defaultVersion release releaseRev; + inherit (coq-hammer-tactics) + owner + repo + defaultVersion + release + releaseRev + ; buildFlags = [ "plugin" ]; installTargets = [ "install-plugin" ]; @@ -11,7 +22,10 @@ mkCoqDerivation { mlPlugin = true; - propagatedBuildInputs = [ coq.ocamlPackages.findlib coq-hammer-tactics ]; + propagatedBuildInputs = [ + coq.ocamlPackages.findlib + coq-hammer-tactics + ]; meta = coq-hammer-tactics.meta // { description = "General-purpose automated reasoning hammer tool for Coq"; diff --git a/pkgs/development/coq-modules/coq-hammer/tactics.nix b/pkgs/development/coq-modules/coq-hammer/tactics.nix index 27a0105833f8a0..c2f7e40f1a23fc 100644 --- a/pkgs/development/coq-modules/coq-hammer/tactics.nix +++ b/pkgs/development/coq-modules/coq-hammer/tactics.nix @@ -1,14 +1,33 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: let owner = "lukaszcz"; repo = "coqhammer"; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = "8.19"; out = "1.3.2+8.19"; } - { case = "8.18"; out = "1.3.2+8.18"; } - { case = "8.17"; out = "1.3.2+8.17"; } - { case = "8.16"; out = "1.3.2+8.16"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = "8.19"; + out = "1.3.2+8.19"; + } + { + case = "8.18"; + out = "1.3.2+8.18"; + } + { + case = "8.17"; + out = "1.3.2+8.17"; + } + { + case = "8.16"; + out = "1.3.2+8.16"; + } + ] null; release = { "1.3.2+8.19".sha256 = "sha256-Zd7piAWlKPAZKEz7HVWxhnzOLbA/eR9C/E0T298MJVY="; @@ -25,9 +44,21 @@ mkCoqDerivation { inherit version; pname = "coq-hammer-tactics"; - inherit owner repo defaultVersion release releaseRev; + inherit + owner + repo + defaultVersion + release + releaseRev + ; passthru = { - inherit owner repo defaultVersion release releaseRev; + inherit + owner + repo + defaultVersion + release + releaseRev + ; }; mlPlugin = true; diff --git a/pkgs/development/coq-modules/coq-haskell/default.nix b/pkgs/development/coq-modules/coq-haskell/default.nix index 7ffc29e943bda5..32522e8ef3a1bc 100644 --- a/pkgs/development/coq-modules/coq-haskell/default.nix +++ b/pkgs/development/coq-modules/coq-haskell/default.nix @@ -1,4 +1,10 @@ -{ lib, mkCoqDerivation, coq, ssreflect, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + ssreflect, + version ? null, +}: mkCoqDerivation { @@ -6,12 +12,15 @@ mkCoqDerivation { owner = "jwiegley"; inherit version; defaultVersion = if lib.versions.range "8.5" "8.8" coq.coq-version then "20171215" else null; - release."20171215".rev = "e2cf8b270c2efa3b56fab1ef6acc376c2c3de968"; + release."20171215".rev = "e2cf8b270c2efa3b56fab1ef6acc376c2c3de968"; release."20171215".sha256 = "09dq1vvshhlhgjccrhqgbhnq2hrys15xryfszqq11rzpgvl2zgdv"; mlPlugin = true; extraInstallFlags = [ "-f Makefile.coq" ]; - propagatedBuildInputs = [ coq ssreflect ]; + propagatedBuildInputs = [ + coq + ssreflect + ]; enableParallelBuilding = false; meta = { diff --git a/pkgs/development/coq-modules/coq-lsp/default.nix b/pkgs/development/coq-modules/coq-lsp/default.nix index 8103d28f86bd47..e4064be1d625b3 100644 --- a/pkgs/development/coq-modules/coq-lsp/default.nix +++ b/pkgs/development/coq-modules/coq-lsp/default.nix @@ -1,4 +1,11 @@ -{ lib, mkCoqDerivation, coq, serapi, makeWrapper, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + serapi, + makeWrapper, + version ? null, +}: (mkCoqDerivation rec { pname = "coq-lsp"; @@ -14,13 +21,30 @@ release."0.2.2+8.20".sha256 = "sha256-9yHisA3YJ/KuolU53qcQAjuSIAZPY+4rnkWV9dpLc6c="; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = isEq "8.16"; out = "0.1.8+8.16"; } - { case = isEq "8.17"; out = "0.2.2+8.17"; } - { case = isEq "8.18"; out = "0.2.2+8.18"; } - { case = isEq "8.19"; out = "0.2.2+8.19"; } - { case = isEq "8.20"; out = "0.2.2+8.20"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = isEq "8.16"; + out = "0.1.8+8.16"; + } + { + case = isEq "8.17"; + out = "0.2.2+8.17"; + } + { + case = isEq "8.18"; + out = "0.2.2+8.18"; + } + { + case = isEq "8.19"; + out = "0.2.2+8.19"; + } + { + case = isEq "8.20"; + out = "0.2.2+8.20"; + } + ] null; nativeBuildInputs = [ makeWrapper ]; @@ -31,8 +55,13 @@ runHook postInstall ''; - propagatedBuildInputs = - with coq.ocamlPackages; [ dune-build-info menhir result uri yojson ]; + propagatedBuildInputs = with coq.ocamlPackages; [ + dune-build-info + menhir + result + uri + yojson + ]; meta = with lib; { description = "Language Server Protocol and VS Code Extension for Coq"; @@ -41,14 +70,30 @@ maintainers = with maintainers; [ alizter ]; license = licenses.lgpl21Only; }; -}).overrideAttrs (o: - with coq.ocamlPackages; - { propagatedBuildInputs = o.propagatedBuildInputs ++ - (if o.version != null && lib.versions.isLe "0.1.9+8.19" o.version && o.version != "dev" then - [ camlp-streams serapi ] - else - [ cmdliner ppx_deriving ppx_deriving_yojson ppx_import ppx_sexp_conv - ppx_compare ppx_hash sexplib ]); - - patches = lib.optional (lib.versions.isEq "0.1.8" o.version) ./coq-loader.patch; -}) +}).overrideAttrs + ( + o: with coq.ocamlPackages; { + propagatedBuildInputs = + o.propagatedBuildInputs + ++ ( + if o.version != null && lib.versions.isLe "0.1.9+8.19" o.version && o.version != "dev" then + [ + camlp-streams + serapi + ] + else + [ + cmdliner + ppx_deriving + ppx_deriving_yojson + ppx_import + ppx_sexp_conv + ppx_compare + ppx_hash + sexplib + ] + ); + + patches = lib.optional (lib.versions.isEq "0.1.8" o.version) ./coq-loader.patch; + } + ) diff --git a/pkgs/development/coq-modules/coq-record-update/default.nix b/pkgs/development/coq-modules/coq-record-update/default.nix index c189168f76e9a5..ff71c5ecdc437f 100644 --- a/pkgs/development/coq-modules/coq-record-update/default.nix +++ b/pkgs/development/coq-modules/coq-record-update/default.nix @@ -1,12 +1,22 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: - mkCoqDerivation rec { +mkCoqDerivation rec { pname = "coq-record-update"; owner = "tchajed"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.10" "8.20"; out = "0.3.4"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.10" "8.20"; + out = "0.3.4"; + } + ] null; release."0.3.4".sha256 = "sha256-AhEcugUiVIsgbq884Lur/bQIuGw8prk+3AlNkP1omcw="; release."0.3.3".sha256 = "sha256-HDIPeFHiC9EwhiOH7yMGJ9d2zJMhboTpRGf9kWcB9Io="; release."0.3.1".sha256 = "sha256-DyGxO2tqmYZZluXN6Oy5Tw6fuLMyuyxonj8CCToWKkk="; diff --git a/pkgs/development/coq-modules/coqeal/default.nix b/pkgs/development/coq-modules/coqeal/default.nix index a0598d0bac8351..8876f02dcd7d1e 100644 --- a/pkgs/development/coq-modules/coqeal/default.nix +++ b/pkgs/development/coq-modules/coqeal/default.nix @@ -1,22 +1,83 @@ -{ coq, mkCoqDerivation, mathcomp, bignums, paramcoq, multinomials, +{ + coq, + mkCoqDerivation, + mathcomp, + bignums, + paramcoq, + multinomials, mathcomp-real-closed, - lib, version ? null }: + lib, + version ? null, +}: (mkCoqDerivation { pname = "CoqEAL"; inherit version; - defaultVersion = with lib.versions; lib.switch [ coq.version mathcomp.version ] [ - { cases = [ (range "8.16" "8.20") (isGe "2.0.0") ]; out = "2.0.1"; } - { cases = [ (range "8.16" "8.17") (isGe "2.0.0") ]; out = "2.0.0"; } - { cases = [ (range "8.15" "8.18") (range "1.15.0" "1.18.0") ]; out = "1.1.3"; } - { cases = [ (range "8.13" "8.17") (range "1.13.0" "1.18.0") ]; out = "1.1.1"; } - { cases = [ (range "8.10" "8.15") (range "1.12.0" "1.18.0") ]; out = "1.1.0"; } - { cases = [ (isGe "8.10") (range "1.11.0" "1.12.0") ]; out = "1.0.5"; } - { cases = [ (isGe "8.7") "1.11.0" ]; out = "1.0.4"; } - { cases = [ (isGe "8.7") "1.10.0" ]; out = "1.0.3"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.version mathcomp.version ] + [ + { + cases = [ + (range "8.16" "8.20") + (isGe "2.0.0") + ]; + out = "2.0.1"; + } + { + cases = [ + (range "8.16" "8.17") + (isGe "2.0.0") + ]; + out = "2.0.0"; + } + { + cases = [ + (range "8.15" "8.18") + (range "1.15.0" "1.18.0") + ]; + out = "1.1.3"; + } + { + cases = [ + (range "8.13" "8.17") + (range "1.13.0" "1.18.0") + ]; + out = "1.1.1"; + } + { + cases = [ + (range "8.10" "8.15") + (range "1.12.0" "1.18.0") + ]; + out = "1.1.0"; + } + { + cases = [ + (isGe "8.10") + (range "1.11.0" "1.12.0") + ]; + out = "1.0.5"; + } + { + cases = [ + (isGe "8.7") + "1.11.0" + ]; + out = "1.0.4"; + } + { + cases = [ + (isGe "8.7") + "1.10.0" + ]; + out = "1.0.3"; + } + ] + null; release."2.0.1".sha256 = "sha256-d/IQ4IdS2tpyPewcGobj2S6m2HU+iXQmlvR+ITNIcjI="; release."2.0.0".sha256 = "sha256-SG/KVnRJz2P+ZxkWVp1dDOnc/JVgigoexKfRUh1Y0GM"; @@ -28,13 +89,20 @@ release."1.0.4".sha256 = "1g5m26lr2lwxh6ld2gykailhay4d0ayql4bfh0aiwqpmmczmxipk"; release."1.0.3".sha256 = "0hc63ny7phzbihy8l7wxjvn3haxx8jfnhi91iw8hkq8n29i23v24"; - propagatedBuildInputs = [ mathcomp.algebra bignums paramcoq multinomials ]; + propagatedBuildInputs = [ + mathcomp.algebra + bignums + paramcoq + multinomials + ]; meta = { description = "CoqEAL - The Coq Effective Algebra Library"; license = lib.licenses.mit; }; -}).overrideAttrs (o: { - propagatedBuildInputs = o.propagatedBuildInputs - ++ lib.optional (lib.versions.isGe "1.1" o.version || o.version == "dev") mathcomp-real-closed; -}) +}).overrideAttrs + (o: { + propagatedBuildInputs = + o.propagatedBuildInputs + ++ lib.optional (lib.versions.isGe "1.1" o.version || o.version == "dev") mathcomp-real-closed; + }) diff --git a/pkgs/development/coq-modules/coqhammer/default.nix b/pkgs/development/coq-modules/coqhammer/default.nix index 2db9b6c969f08e..4ce7f6633e6280 100644 --- a/pkgs/development/coq-modules/coqhammer/default.nix +++ b/pkgs/development/coq-modules/coqhammer/default.nix @@ -4,22 +4,53 @@ # # ################################################################### -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { inherit version; pname = "coqhammer"; owner = "lukaszcz"; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = "8.15"; out = "1.3.2-coq8.15"; } - { case = "8.14"; out = "1.3.2-coq8.14"; } - { case = "8.13"; out = "1.3.2-coq8.13"; } - { case = "8.12"; out = "1.3.2-coq8.12"; } - { case = "8.11"; out = "1.3.2-coq8.11"; } - { case = "8.10"; out = "1.3.2-coq8.10"; } - { case = "8.9"; out = "1.1.1-coq8.9"; } - { case = "8.8"; out = "1.1-coq8.8"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = "8.15"; + out = "1.3.2-coq8.15"; + } + { + case = "8.14"; + out = "1.3.2-coq8.14"; + } + { + case = "8.13"; + out = "1.3.2-coq8.13"; + } + { + case = "8.12"; + out = "1.3.2-coq8.12"; + } + { + case = "8.11"; + out = "1.3.2-coq8.11"; + } + { + case = "8.10"; + out = "1.3.2-coq8.10"; + } + { + case = "8.9"; + out = "1.1.1-coq8.9"; + } + { + case = "8.8"; + out = "1.1-coq8.8"; + } + ] null; release."1.3.2-coq8.15".sha256 = "sha256:0n0y9wda8bx88r17ls9541ibxw013ghp73zshgb65bi7ibznbhha"; release."1.3.2-coq8.15".rev = "9a3e689036f12c09800ca3bac05054af0cc49233"; release."1.3.2-coq8.14".sha256 = "sha256:1pvs4p95lr31jb86f33p2q9v8zq3xbci1fk6s6a2g2snfxng1574"; @@ -31,23 +62,27 @@ mkCoqDerivation { release."1.3.1-coq8.12".sha256 = "0xy3vy4rv8w5ydwb9nq8y4dcimd91yr0hak2j4kn02svssg1kv1y"; release."1.3.1-coq8.11".sha256 = "0i9nlcayq0ac95vc09d1w8sd221gdjs0g215n086qscqjwimnz8j"; release."1.3.1-coq8.10".sha256 = "0aq9qwqx680lkidhb77fmyq403rvfcdxch849x1pzy6a48rz5yra"; - release."1.3-coq8.12".sha256 = "1q1y3cwhd98pkm98g71fsdjz85bfwgcz2xn7s7wwmiraifv5l6z8"; - release."1.3-coq8.11".sha256 = "08zf8qfna7b9p2myfaz4g7bas3a1q1156x78n5isqivlnqfrjc1b"; - release."1.3-coq8.10".sha256 = "1fj8497ir4m79hyrmmmmrag01001wrby0h24wv6525vz0w5py3cd"; - release."1.1.1-coq8.9" = { sha256 = "1knjmz4hr8vlp103j8n4fyb2lfxysnm512gh3m2kp85n6as6fvb9"; - rev = "f8b4d81a213aa1f25afbe53c7c9ca1b15e3d42bc"; }; - release."1.1-coq8.8" = { sha256 = "0ms086wp4jmrzyglb8wymchzyflflk01nsfsk4r6qv8rrx81nx9h"; - rev = "c3cb54b4d5f33fab372d33c7189861368a08fa22"; }; + release."1.3-coq8.12".sha256 = "1q1y3cwhd98pkm98g71fsdjz85bfwgcz2xn7s7wwmiraifv5l6z8"; + release."1.3-coq8.11".sha256 = "08zf8qfna7b9p2myfaz4g7bas3a1q1156x78n5isqivlnqfrjc1b"; + release."1.3-coq8.10".sha256 = "1fj8497ir4m79hyrmmmmrag01001wrby0h24wv6525vz0w5py3cd"; + release."1.1.1-coq8.9" = { + sha256 = "1knjmz4hr8vlp103j8n4fyb2lfxysnm512gh3m2kp85n6as6fvb9"; + rev = "f8b4d81a213aa1f25afbe53c7c9ca1b15e3d42bc"; + }; + release."1.1-coq8.8" = { + sha256 = "0ms086wp4jmrzyglb8wymchzyflflk01nsfsk4r6qv8rrx81nx9h"; + rev = "c3cb54b4d5f33fab372d33c7189861368a08fa22"; + }; - release."1.3.1-coq8.13".version = "1.3.1"; - release."1.3.1-coq8.12".version = "1.3.1"; - release."1.3.1-coq8.11".version = "1.3.1"; - release."1.3.1-coq8.10".version = "1.3.1"; - release."1.3-coq8.12".version = "1.3"; - release."1.3-coq8.11".version = "1.3"; - release."1.3-coq8.10".version = "1.3"; + release."1.3.1-coq8.13".version = "1.3.1"; + release."1.3.1-coq8.12".version = "1.3.1"; + release."1.3.1-coq8.11".version = "1.3.1"; + release."1.3.1-coq8.10".version = "1.3.1"; + release."1.3-coq8.12".version = "1.3"; + release."1.3-coq8.11".version = "1.3"; + release."1.3-coq8.10".version = "1.3"; release."1.1.1-coq8.9".version = "1.1.1"; - release."1.1-coq8.9".version = "1.1"; + release."1.1-coq8.9".version = "1.1"; releaseRev = v: "refs/tags/v${v}"; postPatch = '' diff --git a/pkgs/development/coq-modules/coqide/default.nix b/pkgs/development/coq-modules/coqide/default.nix index bf76a81e5d7197..8ae04078b77110 100644 --- a/pkgs/development/coq-modules/coqide/default.nix +++ b/pkgs/development/coq-modules/coqide/default.nix @@ -1,19 +1,21 @@ -{ lib -, makeDesktopItem -, copyDesktopItems -, wrapGAppsHook3 -, glib -, adwaita-icon-theme -, mkCoqDerivation -, coq -, version ? null }: +{ + lib, + makeDesktopItem, + copyDesktopItems, + wrapGAppsHook3, + glib, + adwaita-icon-theme, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation rec { pname = "coqide"; inherit version; inherit (coq) src; - release."${coq.version}" = {}; + release."${coq.version}" = { }; defaultVersion = if lib.versions.isGe "8.14" coq.version then coq.version else null; @@ -50,7 +52,13 @@ mkCoqDerivation rec { icon = "coq"; desktopName = "CoqIDE"; comment = "Graphical interface for the Coq proof assistant"; - categories = [ "Development" "Science" "Math" "IDE" "GTK" ]; + categories = [ + "Development" + "Science" + "Math" + "IDE" + "GTK" + ]; }) ]; diff --git a/pkgs/development/coq-modules/coqprime/default.nix b/pkgs/development/coq-modules/coqprime/default.nix index 2382141f2232bc..1373a05b00ec1d 100644 --- a/pkgs/development/coq-modules/coqprime/default.nix +++ b/pkgs/development/coq-modules/coqprime/default.nix @@ -1,25 +1,48 @@ -{ lib, mkCoqDerivation, coq, bignums, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + bignums, + version ? null, +}: mkCoqDerivation { pname = "coqprime"; owner = "thery"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.14" "8.20"; out = "8.18"; } - { case = range "8.12" "8.16"; out = "8.15"; } - { case = range "8.10" "8.11"; out = "8.10"; } - { case = range "8.8" "8.9"; out = "8.8"; } - { case = "8.7"; out = "8.7.2"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.14" "8.20"; + out = "8.18"; + } + { + case = range "8.12" "8.16"; + out = "8.15"; + } + { + case = range "8.10" "8.11"; + out = "8.10"; + } + { + case = range "8.8" "8.9"; + out = "8.8"; + } + { + case = "8.7"; + out = "8.7.2"; + } + ] null; - release."8.18".sha256 = "sha256-KObBEYerWhIStmq90G3vs9K5LUEOfB2SPxirwLiWQ6E="; - release."8.17".sha256 = "sha256-D878t/PijVCopRKHYqfwdNvt3arGlI8yxbK/vI6qZUY="; - release."8.15".sha256 = "sha256:1zr2q52r08na8265019pj9spcz982ivixk6cnzk6l1srn2g328gv"; - release."8.14.1".sha256= "sha256:0dqf87xkzcpg7gglbxjyx68ad84w1w73icxgy3s7d3w563glc2p7"; - release."8.12".sha256 = "1slka4w0pya15js4drx9frj7lxyp3k2lzib8v23givzpnxs8ijdj"; - release."8.10".sha256 = "0r9gnh5a5ykiiz5h1i8xnzgiydpwc4z9qhndxyya85xq0f910qaz"; - release."8.8".sha256 = "075yjczk79pf1hd3lgdjiz84ilkzfxjh18lgzrhhqp7d3kz5lxp5"; + release."8.18".sha256 = "sha256-KObBEYerWhIStmq90G3vs9K5LUEOfB2SPxirwLiWQ6E="; + release."8.17".sha256 = "sha256-D878t/PijVCopRKHYqfwdNvt3arGlI8yxbK/vI6qZUY="; + release."8.15".sha256 = "sha256:1zr2q52r08na8265019pj9spcz982ivixk6cnzk6l1srn2g328gv"; + release."8.14.1".sha256 = "sha256:0dqf87xkzcpg7gglbxjyx68ad84w1w73icxgy3s7d3w563glc2p7"; + release."8.12".sha256 = "1slka4w0pya15js4drx9frj7lxyp3k2lzib8v23givzpnxs8ijdj"; + release."8.10".sha256 = "0r9gnh5a5ykiiz5h1i8xnzgiydpwc4z9qhndxyya85xq0f910qaz"; + release."8.8".sha256 = "075yjczk79pf1hd3lgdjiz84ilkzfxjh18lgzrhhqp7d3kz5lxp5"; release."8.7.2".sha256 = "15zlcrx06qqxjy3nhh22wzy0rb4npc8l4nx2bbsfsvrisbq1qb7k"; releaseRev = v: "v${v}"; diff --git a/pkgs/development/coq-modules/coqtail-math/default.nix b/pkgs/development/coq-modules/coqtail-math/default.nix index b43cadb918e365..fb97986b5b1dd8 100644 --- a/pkgs/development/coq-modules/coqtail-math/default.nix +++ b/pkgs/development/coq-modules/coqtail-math/default.nix @@ -1,16 +1,29 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "coqtail-math"; owner = "coq-community"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.11" "8.15"; out = "8.14"; } - { case = range "8.11" "8.13"; out = "20201124"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.11" "8.15"; + out = "8.14"; + } + { + case = range "8.11" "8.13"; + out = "20201124"; + } + ] null; release."8.14".sha256 = "sha256:1k8f8idjnx0mf4z479vcx55iz42rjxrbplbznv80m2famxakq03c"; - release."20201124".rev = "5c22c3d7dcd8cf4c47cf84a281780f5915488e9e"; + release."20201124".rev = "5c22c3d7dcd8cf4c47cf84a281780f5915488e9e"; release."20201124".sha256 = "sha256-wd+Lh7dpAD4zfpyKuztDmSFEZo5ZiFrR8ti2jUCVvoQ="; mlPlugin = true; meta = with lib; { diff --git a/pkgs/development/coq-modules/coquelicot/default.nix b/pkgs/development/coq-modules/coquelicot/default.nix index 90ea6d6294664b..680e154de68a0f 100644 --- a/pkgs/development/coq-modules/coquelicot/default.nix +++ b/pkgs/development/coq-modules/coquelicot/default.nix @@ -1,19 +1,45 @@ -{ lib, mkCoqDerivation, autoconf, - coq, ssreflect, version ? null }: +{ + lib, + mkCoqDerivation, + autoconf, + coq, + ssreflect, + version ? null, +}: mkCoqDerivation { pname = "coquelicot"; owner = "coquelicot"; domain = "gitlab.inria.fr"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.12" "8.20"; out = "3.4.2"; } - { case = range "8.12" "8.18"; out = "3.4.0"; } - { case = range "8.12" "8.17"; out = "3.3.0"; } - { case = range "8.8" "8.16"; out = "3.2.0"; } - { case = range "8.8" "8.13"; out = "3.1.0"; } - { case = range "8.5" "8.9"; out = "3.0.2"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.12" "8.20"; + out = "3.4.2"; + } + { + case = range "8.12" "8.18"; + out = "3.4.0"; + } + { + case = range "8.12" "8.17"; + out = "3.3.0"; + } + { + case = range "8.8" "8.16"; + out = "3.2.0"; + } + { + case = range "8.8" "8.13"; + out = "3.1.0"; + } + { + case = range "8.5" "8.9"; + out = "3.0.2"; + } + ] null; release."3.4.2".sha256 = "sha256-aBTF8ZKu67Rb3ryCqFyejUXf/65KgG8i5je/ZMFSrj4="; release."3.4.1".sha256 = "sha256-REhvIBl3EaL8CQqI34Gn7Xjf9NhPI3nrUAO26pSLbm0="; release."3.4.0".sha256 = "sha256-LIj2SwTvVBxSAO58VYCQix/uxQQe8ey6hqFOSh3PNcg="; @@ -28,7 +54,7 @@ mkCoqDerivation { propagatedBuildInputs = [ ssreflect ]; useMelquiondRemake.logpath = "Coquelicot"; - meta = with lib; { + meta = with lib; { homepage = "http://coquelicot.saclay.inria.fr/"; description = "Coq library for Reals"; license = licenses.lgpl3; diff --git a/pkgs/development/coq-modules/coqutil/default.nix b/pkgs/development/coq-modules/coqutil/default.nix index ceac4b17b4c63a..53aff2a614db25 100644 --- a/pkgs/development/coq-modules/coqutil/default.nix +++ b/pkgs/development/coq-modules/coqutil/default.nix @@ -11,9 +11,17 @@ mkCoqDerivation { owner = "mit-plv"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = range "8.18" "8.20"; out = "0.0.6"; } - { case = range "8.17" "8.20"; out = "0.0.5"; } + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.18" "8.20"; + out = "0.0.6"; + } + { + case = range "8.17" "8.20"; + out = "0.0.5"; + } ] null; releaseRev = v: "v${v}"; diff --git a/pkgs/development/coq-modules/corn/default.nix b/pkgs/development/coq-modules/corn/default.nix index d1c54da398926b..9689d4d5eaf25b 100644 --- a/pkgs/development/coq-modules/corn/default.nix +++ b/pkgs/development/coq-modules/corn/default.nix @@ -1,15 +1,39 @@ -{ lib, mkCoqDerivation, coq, bignums, math-classes, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + bignums, + math-classes, + version ? null, +}: mkCoqDerivation rec { pname = "corn"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = (range "8.17" "8.20"); out = "8.19.0"; } - { case = (range "8.14" "8.18"); out = "8.18.0"; } - { case = (range "8.11" "8.17"); out = "8.16.0"; } - { case = (range "8.7" "8.15"); out = "8.13.0"; } - { case = "8.6"; out = "8.8.1"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = (range "8.17" "8.20"); + out = "8.19.0"; + } + { + case = (range "8.14" "8.18"); + out = "8.18.0"; + } + { + case = (range "8.11" "8.17"); + out = "8.16.0"; + } + { + case = (range "8.7" "8.15"); + out = "8.13.0"; + } + { + case = "8.6"; + out = "8.8.1"; + } + ] null; release = { "8.8.1".sha256 = "0gh32j0f18vv5lmf6nb87nr5450w6ai06rhrnvlx2wwi79gv10wp"; "8.12.0".sha256 = "0b92vhyzn1j6cs84z2182fn82hxxj0bqq7hk6cs4awwb3vc7dkhi"; @@ -22,9 +46,12 @@ mkCoqDerivation rec { configureScript = "./configure.sh"; dontAddPrefix = true; - propagatedBuildInputs = [ bignums math-classes ]; + propagatedBuildInputs = [ + bignums + math-classes + ]; - meta = with lib; { + meta = with lib; { homepage = "http://c-corn.github.io/"; license = licenses.gpl2; description = "Coq library for constructive analysis"; diff --git a/pkgs/development/coq-modules/deriving/default.nix b/pkgs/development/coq-modules/deriving/default.nix index 6998ec44598901..e4f03c4e7253cc 100644 --- a/pkgs/development/coq-modules/deriving/default.nix +++ b/pkgs/development/coq-modules/deriving/default.nix @@ -1,5 +1,9 @@ -{ lib, mkCoqDerivation, coq, version ? null -, ssreflect +{ + lib, + mkCoqDerivation, + coq, + version ? null, + ssreflect, }: mkCoqDerivation { @@ -7,10 +11,27 @@ mkCoqDerivation { owner = "arthuraa"; inherit version; - defaultVersion = with lib.versions; lib.switch [coq.coq-version ssreflect.version] [ - { cases = [(range "8.17" "8.20") (isGe "2.0.0")] ; out = "0.2.0"; } - { cases = [(range "8.11" "8.20") (isLe "2.0.0")] ; out = "0.1.1"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.coq-version ssreflect.version ] + [ + { + cases = [ + (range "8.17" "8.20") + (isGe "2.0.0") + ]; + out = "0.2.0"; + } + { + cases = [ + (range "8.11" "8.20") + (isLe "2.0.0") + ]; + out = "0.1.1"; + } + ] + null; releaseRev = v: "v${v}"; diff --git a/pkgs/development/coq-modules/dpdgraph/default.nix b/pkgs/development/coq-modules/dpdgraph/default.nix index 0ceb84095b70de..76e82bfbe10690 100644 --- a/pkgs/development/coq-modules/dpdgraph/default.nix +++ b/pkgs/development/coq-modules/dpdgraph/default.nix @@ -1,6 +1,14 @@ -{ lib, mkCoqDerivation, autoreconfHook, coq, version ? null }: +{ + lib, + mkCoqDerivation, + autoreconfHook, + coq, + version ? null, +}: -let hasWarning = lib.versionAtLeast coq.ocamlPackages.ocaml.version "4.08"; in +let + hasWarning = lib.versionAtLeast coq.ocamlPackages.ocaml.version "4.08"; +in mkCoqDerivation { pname = "dpdgraph"; @@ -8,20 +16,62 @@ mkCoqDerivation { repo = "coq-dpdgraph"; inherit version; defaultVersion = lib.switch coq.coq-version [ - { case = "8.20"; out = "1.0+8.20"; } - { case = "8.19"; out = "1.0+8.19"; } - { case = "8.18"; out = "1.0+8.18"; } - { case = "8.17"; out = "1.0+8.17"; } - { case = "8.16"; out = "1.0+8.16"; } - { case = "8.15"; out = "1.0+8.15"; } - { case = "8.14"; out = "1.0+8.14"; } - { case = "8.13"; out = "1.0+8.13"; } - { case = "8.12"; out = "0.6.8"; } - { case = "8.11"; out = "0.6.7"; } - { case = "8.10"; out = "0.6.6"; } - { case = "8.9"; out = "0.6.5"; } - { case = "8.8"; out = "0.6.3"; } - { case = "8.7"; out = "0.6.2"; } + { + case = "8.20"; + out = "1.0+8.20"; + } + { + case = "8.19"; + out = "1.0+8.19"; + } + { + case = "8.18"; + out = "1.0+8.18"; + } + { + case = "8.17"; + out = "1.0+8.17"; + } + { + case = "8.16"; + out = "1.0+8.16"; + } + { + case = "8.15"; + out = "1.0+8.15"; + } + { + case = "8.14"; + out = "1.0+8.14"; + } + { + case = "8.13"; + out = "1.0+8.13"; + } + { + case = "8.12"; + out = "0.6.8"; + } + { + case = "8.11"; + out = "0.6.7"; + } + { + case = "8.10"; + out = "0.6.6"; + } + { + case = "8.9"; + out = "0.6.5"; + } + { + case = "8.8"; + out = "0.6.3"; + } + { + case = "8.7"; + out = "0.6.2"; + } ] null; release."1.0+8.20".sha256 = "sha256-szfH/OksCH3SCbcFjwEvLwHE5avmHp1vYiJM6KAXFqs="; @@ -37,13 +87,13 @@ mkCoqDerivation { release."0.6.7".sha256 = "01vpi7scvkl4ls1z2k2x9zd65wflzb667idj759859hlz3ps9z09"; release."0.6.6".sha256 = "1gjrm5zjzw4cisiwdr5b3iqa7s4cssa220xr0k96rwgk61rcjd8w"; release."0.6.5".sha256 = "1f34z24yg05b1096gqv36jr3vffkcjkf9qncii3pzhhvagxd0w2f"; - release."0.6.3".rev = "0acbd0a594c7e927574d5f212cc73a486b5305d2"; + release."0.6.3".rev = "0acbd0a594c7e927574d5f212cc73a486b5305d2"; release."0.6.3".sha256 = "0c95b0bz2kjm6swr5na4gs06lxxywradszxbr5ldh2zx02r3f3rx"; - release."0.6.2".rev = "d76ddde37d918569945774733b7997e8b24daf51"; + release."0.6.2".rev = "d76ddde37d918569945774733b7997e8b24daf51"; release."0.6.2".sha256 = "04lnf4b25yarysj848cfl8pd3i3pr3818acyp9hgwdgd1rqmhjwm"; - release."0.6.1".rev = "c3b87af6bfa338e18b83f014ebd0e56e1f611663"; + release."0.6.1".rev = "c3b87af6bfa338e18b83f014ebd0e56e1f611663"; release."0.6.1".sha256 = "1jaafkwsb5450378nprjsds1illgdaq60gryi8kspw0i25ykz2c9"; - release."0.6".sha256 = "0qvar8gfbrcs9fmvkph5asqz4l5fi63caykx3bsn8zf0xllkwv0n"; + release."0.6".sha256 = "0qvar8gfbrcs9fmvkph5asqz4l5fi63caykx3bsn8zf0xllkwv0n"; releaseRev = v: "v${v}"; nativeBuildInputs = [ autoreconfHook ]; diff --git a/pkgs/development/coq-modules/equations/default.nix b/pkgs/development/coq-modules/equations/default.nix index b517d16ab2d47d..309b44559f26b3 100644 --- a/pkgs/development/coq-modules/equations/default.nix +++ b/pkgs/development/coq-modules/equations/default.nix @@ -1,4 +1,9 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: (mkCoqDerivation { pname = "equations"; @@ -6,66 +11,111 @@ repo = "Coq-Equations"; inherit version; defaultVersion = lib.switch coq.coq-version [ - { case = "8.20"; out = "1.3.1+8.20"; } - { case = "8.19"; out = "1.3+8.19"; } - { case = "8.18"; out = "1.3+8.18"; } - { case = "8.17"; out = "1.3+8.17"; } - { case = "8.16"; out = "1.3+8.16"; } - { case = "8.15"; out = "1.3+8.15"; } - { case = "8.14"; out = "1.3+8.14"; } - { case = "8.13"; out = "1.3+8.13"; } - { case = "8.12"; out = "1.2.4+coq8.12"; } - { case = "8.11"; out = "1.2.4+coq8.11"; } - { case = "8.10"; out = "1.2.1+coq8.10-2"; } - { case = "8.9"; out = "1.2.1+coq8.9"; } - { case = "8.8"; out = "1.2+coq8.8"; } - { case = "8.7"; out = "1.0+coq8.7"; } - { case = "8.6"; out = "1.0+coq8.6"; } + { + case = "8.20"; + out = "1.3.1+8.20"; + } + { + case = "8.19"; + out = "1.3+8.19"; + } + { + case = "8.18"; + out = "1.3+8.18"; + } + { + case = "8.17"; + out = "1.3+8.17"; + } + { + case = "8.16"; + out = "1.3+8.16"; + } + { + case = "8.15"; + out = "1.3+8.15"; + } + { + case = "8.14"; + out = "1.3+8.14"; + } + { + case = "8.13"; + out = "1.3+8.13"; + } + { + case = "8.12"; + out = "1.2.4+coq8.12"; + } + { + case = "8.11"; + out = "1.2.4+coq8.11"; + } + { + case = "8.10"; + out = "1.2.1+coq8.10-2"; + } + { + case = "8.9"; + out = "1.2.1+coq8.9"; + } + { + case = "8.8"; + out = "1.2+coq8.8"; + } + { + case = "8.7"; + out = "1.0+coq8.7"; + } + { + case = "8.6"; + out = "1.0+coq8.6"; + } ] null; - release."1.0+coq8.6".version = "1.0"; - release."1.0+coq8.6".rev = "v1.0"; - release."1.0+coq8.6".sha256 = "19ylw9v9g35607w4hm86j7mmkghh07hmkc1ls5bqlz3dizh5q4pj"; - release."1.0+coq8.7".version = "1.0"; - release."1.0+coq8.7".rev = "v1.0-8.7"; - release."1.0+coq8.7".sha256 = "1bavg4zl1xn0jqrdq8iw7xqzdvdf39ligj9saz5m9c507zri952h"; - release."1.2+coq8.8".version = "1.2"; - release."1.2+coq8.8".rev = "v1.2-8.8"; - release."1.2+coq8.8".sha256 = "06452fyzalz7zcjjp73qb7d6xvmqb6skljkivf8pfm55fsc8s7kx"; - release."1.2.1+coq8.9".version = "1.2.1"; - release."1.2.1+coq8.9".rev = "v1.2.1-8.9"; - release."1.2.1+coq8.9".sha256 = "0d8ddj6nc6p0k25cd8fs17cq427zhzbc3v9pk2wd2fnvk70nlfij"; - release."1.2.1+coq8.10-2".version = "1.2.1"; - release."1.2.1+coq8.10-2".rev = "v1.2.1-8.10-2"; - release."1.2.1+coq8.10-2".sha256 = "0j3z4l5nrbyi9zbbyqkc6kassjanwld2188mwmrbqspaypm2ys68"; - release."1.2.3+coq8.11".version = "1.2.3"; - release."1.2.3+coq8.11".rev = "v1.2.3-8.11"; - release."1.2.3+coq8.11".sha256 = "1srxz1rws8jsh7402g2x2vcqgjbbsr64dxxj5d2zs48pmhb20csf"; - release."1.2.3+coq8.12".version = "1.2.3"; - release."1.2.3+coq8.12".rev = "v1.2.3-8.12"; - release."1.2.3+coq8.12".sha256 = "1y0jkvzyz5ssv5vby41p1i8zs7nsdc8g3pzyq73ih9jz8h252643"; - release."1.2.4+coq8.11".rev = "v1.2.4-8.11"; - release."1.2.4+coq8.11".sha256 = "01fihyav8jbjinycgjc16adpa0zy5hcav5mlkf4s9zvqxka21i52"; - release."1.2.4+coq8.12".rev = "v1.2.4-8.12"; - release."1.2.4+coq8.12".sha256 = "1n0w8is464qcq8mk2mv7amaf0khbjz5mpc9phf0rhpjm0lb22cb3"; - release."1.2.4+coq8.13".rev = "v1.2.4-8.13"; - release."1.2.4+coq8.13".sha256 = "0i014lshsdflzw6h0qxra9d2f0q82vffxv2f29awbb9ad0p4rq4q"; - release."1.3+8.13".rev = "v1.3-8.13"; - release."1.3+8.13".sha256 = "1jwjbkkkk4bwf6pz4zzz8fy5bb17aqyf4smkja59rgj9ya6nrdhg"; - release."1.3+8.14".rev = "v1.3-8.14"; - release."1.3+8.14".sha256 = "19bj9nncd1r9g4273h5qx35gs3i4bw5z9bhjni24b413hyj55hkv"; - release."1.3+8.15".rev = "v1.3-8.15"; - release."1.3+8.15".sha256 = "1vfcfpsp9zyj0sw0cwibk76nj6n0r6gwh8m1aa3lbvc0b1kbm32k"; - release."1.3+8.16".rev = "v1.3-8.16"; - release."1.3+8.16".sha256 = "sha256-zyMGeRObtSGWh7n3WCqesBZL5EgLvKwmnTy09rYpxyE="; - release."1.3+8.17".rev = "v1.3-8.17"; - release."1.3+8.17".sha256 = "sha256-yNotSIxFkhTg3reZIchGQ7cV9WmTJ7p7hPfKGBiByDw="; - release."1.3+8.18".rev = "v1.3-8.18"; - release."1.3+8.18".sha256 = "sha256-8MZO9vWdr8wlAov0lBTYMnde0RuMyhaiM99zp7Zwfao="; - release."1.3+8.19".rev = "v1.3-8.19"; - release."1.3+8.19".sha256 = "sha256-roBCWfAHDww2Z2JbV5yMI3+EOfIsv3WvxEcUbBiZBsk="; - release."1.3.1+8.20".rev = "v1.3.1-8.20"; - release."1.3.1+8.20".sha256 = "sha256-u8LB1KiACM5zVaoL7dSdHYvZgX7pf30VuqtjLLGuTzc="; + release."1.0+coq8.6".version = "1.0"; + release."1.0+coq8.6".rev = "v1.0"; + release."1.0+coq8.6".sha256 = "19ylw9v9g35607w4hm86j7mmkghh07hmkc1ls5bqlz3dizh5q4pj"; + release."1.0+coq8.7".version = "1.0"; + release."1.0+coq8.7".rev = "v1.0-8.7"; + release."1.0+coq8.7".sha256 = "1bavg4zl1xn0jqrdq8iw7xqzdvdf39ligj9saz5m9c507zri952h"; + release."1.2+coq8.8".version = "1.2"; + release."1.2+coq8.8".rev = "v1.2-8.8"; + release."1.2+coq8.8".sha256 = "06452fyzalz7zcjjp73qb7d6xvmqb6skljkivf8pfm55fsc8s7kx"; + release."1.2.1+coq8.9".version = "1.2.1"; + release."1.2.1+coq8.9".rev = "v1.2.1-8.9"; + release."1.2.1+coq8.9".sha256 = "0d8ddj6nc6p0k25cd8fs17cq427zhzbc3v9pk2wd2fnvk70nlfij"; + release."1.2.1+coq8.10-2".version = "1.2.1"; + release."1.2.1+coq8.10-2".rev = "v1.2.1-8.10-2"; + release."1.2.1+coq8.10-2".sha256 = "0j3z4l5nrbyi9zbbyqkc6kassjanwld2188mwmrbqspaypm2ys68"; + release."1.2.3+coq8.11".version = "1.2.3"; + release."1.2.3+coq8.11".rev = "v1.2.3-8.11"; + release."1.2.3+coq8.11".sha256 = "1srxz1rws8jsh7402g2x2vcqgjbbsr64dxxj5d2zs48pmhb20csf"; + release."1.2.3+coq8.12".version = "1.2.3"; + release."1.2.3+coq8.12".rev = "v1.2.3-8.12"; + release."1.2.3+coq8.12".sha256 = "1y0jkvzyz5ssv5vby41p1i8zs7nsdc8g3pzyq73ih9jz8h252643"; + release."1.2.4+coq8.11".rev = "v1.2.4-8.11"; + release."1.2.4+coq8.11".sha256 = "01fihyav8jbjinycgjc16adpa0zy5hcav5mlkf4s9zvqxka21i52"; + release."1.2.4+coq8.12".rev = "v1.2.4-8.12"; + release."1.2.4+coq8.12".sha256 = "1n0w8is464qcq8mk2mv7amaf0khbjz5mpc9phf0rhpjm0lb22cb3"; + release."1.2.4+coq8.13".rev = "v1.2.4-8.13"; + release."1.2.4+coq8.13".sha256 = "0i014lshsdflzw6h0qxra9d2f0q82vffxv2f29awbb9ad0p4rq4q"; + release."1.3+8.13".rev = "v1.3-8.13"; + release."1.3+8.13".sha256 = "1jwjbkkkk4bwf6pz4zzz8fy5bb17aqyf4smkja59rgj9ya6nrdhg"; + release."1.3+8.14".rev = "v1.3-8.14"; + release."1.3+8.14".sha256 = "19bj9nncd1r9g4273h5qx35gs3i4bw5z9bhjni24b413hyj55hkv"; + release."1.3+8.15".rev = "v1.3-8.15"; + release."1.3+8.15".sha256 = "1vfcfpsp9zyj0sw0cwibk76nj6n0r6gwh8m1aa3lbvc0b1kbm32k"; + release."1.3+8.16".rev = "v1.3-8.16"; + release."1.3+8.16".sha256 = "sha256-zyMGeRObtSGWh7n3WCqesBZL5EgLvKwmnTy09rYpxyE="; + release."1.3+8.17".rev = "v1.3-8.17"; + release."1.3+8.17".sha256 = "sha256-yNotSIxFkhTg3reZIchGQ7cV9WmTJ7p7hPfKGBiByDw="; + release."1.3+8.18".rev = "v1.3-8.18"; + release."1.3+8.18".sha256 = "sha256-8MZO9vWdr8wlAov0lBTYMnde0RuMyhaiM99zp7Zwfao="; + release."1.3+8.19".rev = "v1.3-8.19"; + release."1.3+8.19".sha256 = "sha256-roBCWfAHDww2Z2JbV5yMI3+EOfIsv3WvxEcUbBiZBsk="; + release."1.3.1+8.20".rev = "v1.3.1-8.20"; + release."1.3.1+8.20".sha256 = "sha256-u8LB1KiACM5zVaoL7dSdHYvZgX7pf30VuqtjLLGuTzc="; mlPlugin = true; @@ -74,6 +124,9 @@ description = "Plugin for Coq to add dependent pattern-matching"; maintainers = with maintainers; [ jwiegley ]; }; -}).overrideAttrs (o: { - preBuild = "coq_makefile -f _CoqProject -o Makefile${lib.optionalString (lib.versionAtLeast o.version "1.2.1" || o.version == "dev") ".coq"}"; -}) +}).overrideAttrs + (o: { + preBuild = "coq_makefile -f _CoqProject -o Makefile${ + lib.optionalString (lib.versionAtLeast o.version "1.2.1" || o.version == "dev") ".coq" + }"; + }) diff --git a/pkgs/development/coq-modules/extructures/default.nix b/pkgs/development/coq-modules/extructures/default.nix index ba84b953490db1..e7825105762b4f 100644 --- a/pkgs/development/coq-modules/extructures/default.nix +++ b/pkgs/development/coq-modules/extructures/default.nix @@ -1,6 +1,10 @@ -{ lib, mkCoqDerivation, coq, version ? null -, ssreflect -, deriving +{ + lib, + mkCoqDerivation, + coq, + version ? null, + ssreflect, + deriving, }: (mkCoqDerivation { @@ -8,12 +12,41 @@ owner = "arthuraa"; inherit version; - defaultVersion = with lib.versions; lib.switch [coq.coq-version ssreflect.version] [ - { cases = [(range "8.17" "8.20") (isGe "2.0.0") ]; out = "0.4.0"; } - { cases = [(range "8.11" "8.20") (range "1.12.0" "1.19.0") ]; out = "0.3.1"; } - { cases = [(range "8.11" "8.14") (isLe "1.12.0") ]; out = "0.3.0"; } - { cases = [(range "8.10" "8.12") (isLe "1.12.0") ]; out = "0.2.2"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.coq-version ssreflect.version ] + [ + { + cases = [ + (range "8.17" "8.20") + (isGe "2.0.0") + ]; + out = "0.4.0"; + } + { + cases = [ + (range "8.11" "8.20") + (range "1.12.0" "1.19.0") + ]; + out = "0.3.1"; + } + { + cases = [ + (range "8.11" "8.14") + (isLe "1.12.0") + ]; + out = "0.3.0"; + } + { + cases = [ + (range "8.10" "8.12") + (isLe "1.12.0") + ]; + out = "0.2.2"; + } + ] + null; releaseRev = v: "v${v}"; @@ -30,7 +63,9 @@ maintainers = [ maintainers.vbgl ]; }; -}).overrideAttrs (o: { - propagatedBuildInputs = o.propagatedBuildInputs - ++ lib.optional (lib.versionAtLeast o.version "0.3.0") deriving; -}) +}).overrideAttrs + (o: { + propagatedBuildInputs = + o.propagatedBuildInputs + ++ lib.optional (lib.versionAtLeast o.version "0.3.0") deriving; + }) diff --git a/pkgs/development/coq-modules/fiat/HEAD.nix b/pkgs/development/coq-modules/fiat/HEAD.nix index 63cc17fbbdd2f6..be317a531d7576 100644 --- a/pkgs/development/coq-modules/fiat/HEAD.nix +++ b/pkgs/development/coq-modules/fiat/HEAD.nix @@ -1,13 +1,21 @@ -{lib, mkCoqDerivation, coq, python27, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + python27, + version ? null, +}: mkCoqDerivation rec { pname = "fiat"; owner = "mit-plv"; repo = "fiat"; - displayVersion = { fiat = v: "unstable-${v}"; }; + displayVersion = { + fiat = v: "unstable-${v}"; + }; inherit version; defaultVersion = if coq.coq-version == "8.5" then "2016-10-24" else null; - release."2016-10-24".rev = "7feb6c64be9ebcc05924ec58fe1463e73ec8206a"; + release."2016-10-24".rev = "7feb6c64be9ebcc05924ec58fe1463e73ec8206a"; release."2016-10-24".sha256 = "16y57vibq3f5i5avgj80f4i3aw46wdwzx36k5d3pf3qk17qrlrdi"; mlPlugin = true; diff --git a/pkgs/development/coq-modules/flocq/default.nix b/pkgs/development/coq-modules/flocq/default.nix index a7ff7044257fdc..80dfdd597bf389 100644 --- a/pkgs/development/coq-modules/flocq/default.nix +++ b/pkgs/development/coq-modules/flocq/default.nix @@ -1,18 +1,45 @@ -{ lib, bash, autoconf, mkCoqDerivation, coq, version ? null }: +{ + lib, + bash, + autoconf, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "flocq"; owner = "flocq"; domain = "gitlab.inria.fr"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.14" "8.20"; out = "4.2.0"; } - { case = range "8.14" "8.18"; out = "4.1.3"; } - { case = range "8.14" "8.17"; out = "4.1.1"; } - { case = range "8.14" "8.16"; out = "4.1.0"; } - { case = range "8.7" "8.15"; out = "3.4.3"; } - { case = range "8.5" "8.8"; out = "2.6.1"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.14" "8.20"; + out = "4.2.0"; + } + { + case = range "8.14" "8.18"; + out = "4.1.3"; + } + { + case = range "8.14" "8.17"; + out = "4.1.1"; + } + { + case = range "8.14" "8.16"; + out = "4.1.0"; + } + { + case = range "8.7" "8.15"; + out = "3.4.3"; + } + { + case = range "8.5" "8.8"; + out = "2.6.1"; + } + ] null; release."4.2.0".sha256 = "sha256-uTeo4GCs6wTLN3sLKsj0xLlt1fUDYfozXtq6iooLUgM="; release."4.1.4".sha256 = "sha256-Use6Mlx79yef1CkCPyGoOItsD69B9KR+mQArCtmre4s="; release."4.1.3".sha256 = "sha256-os3cI885xNpxI+1p5rb8fSNnxKr7SFxqh83+3AM3t4I="; @@ -24,7 +51,10 @@ mkCoqDerivation { release."2.6.1".sha256 = "0q5a038ww5dn72yvwn5298d3ridkcngb1dik8hdyr3xh7gr5qibj"; releaseRev = v: "flocq-${v}"; - nativeBuildInputs = [ bash autoconf ]; + nativeBuildInputs = [ + bash + autoconf + ]; mlPlugin = true; useMelquiondRemake.logpath = "Flocq"; diff --git a/pkgs/development/coq-modules/fourcolor/default.nix b/pkgs/development/coq-modules/fourcolor/default.nix index 53500b7f918c01..39f6b75135eb30 100644 --- a/pkgs/development/coq-modules/fourcolor/default.nix +++ b/pkgs/development/coq-modules/fourcolor/default.nix @@ -1,4 +1,10 @@ -{ lib, mkCoqDerivation, coq, mathcomp, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + mathcomp, + version ? null, +}: mkCoqDerivation { pname = "fourcolor"; @@ -14,17 +20,56 @@ mkCoqDerivation { release."1.4.0".sha256 = "sha256-8TtNPEbp3uLAH+MjOKiTZHOjPb3vVYlabuqsdWxbg80="; inherit version; - defaultVersion = with lib.versions; lib.switch [ coq.version mathcomp.version ] [ - { cases = [ (isGe "8.16") (isGe "2.0") ]; out = "1.4.0"; } - { cases = [ (isGe "8.16") "2.0.0" ]; out = "1.3.0"; } - { cases = [ (isGe "8.11") (range "1.12" "1.19") ]; out = "1.2.5"; } - { cases = [ (isGe "8.11") (range "1.11" "1.14") ]; out = "1.2.4"; } - { cases = [ (isLe "8.13") (lib.pred.inter (isGe "1.11.0") (isLt "1.13")) ]; out = "1.2.3"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.version mathcomp.version ] + [ + { + cases = [ + (isGe "8.16") + (isGe "2.0") + ]; + out = "1.4.0"; + } + { + cases = [ + (isGe "8.16") + "2.0.0" + ]; + out = "1.3.0"; + } + { + cases = [ + (isGe "8.11") + (range "1.12" "1.19") + ]; + out = "1.2.5"; + } + { + cases = [ + (isGe "8.11") + (range "1.11" "1.14") + ]; + out = "1.2.4"; + } + { + cases = [ + (isLe "8.13") + (lib.pred.inter (isGe "1.11.0") (isLt "1.13")) + ]; + out = "1.2.3"; + } + ] + null; - propagatedBuildInputs = [ mathcomp.algebra mathcomp.ssreflect mathcomp.fingroup ]; + propagatedBuildInputs = [ + mathcomp.algebra + mathcomp.ssreflect + mathcomp.fingroup + ]; - meta = with lib; { + meta = with lib; { description = "Formal proof of the Four Color Theorem"; maintainers = with maintainers; [ siraben ]; license = licenses.cecill-b; diff --git a/pkgs/development/coq-modules/gaia-hydras/default.nix b/pkgs/development/coq-modules/gaia-hydras/default.nix index 7152084854b637..e50eed907e164f 100644 --- a/pkgs/development/coq-modules/gaia-hydras/default.nix +++ b/pkgs/development/coq-modules/gaia-hydras/default.nix @@ -1,5 +1,13 @@ -{ lib, mkCoqDerivation, coq, hydra-battles, gaia, - mathcomp-zify, mathcomp, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + hydra-battles, + gaia, + mathcomp-zify, + mathcomp, + version ? null, +}: mkCoqDerivation rec { pname = "gaia-hydras"; @@ -11,10 +19,27 @@ mkCoqDerivation rec { releaseRev = (v: "v${v}"); inherit version; - defaultVersion = with lib.versions; lib.switch [coq.coq-version mathcomp.version] [ - { cases = [ (range "8.13" "8.16") (range "1.12.0" "1.18.0") ]; out = "0.9"; } - { cases = [ (range "8.13" "8.14") (range "1.12.0" "1.18.0") ]; out = "0.5"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.coq-version mathcomp.version ] + [ + { + cases = [ + (range "8.13" "8.16") + (range "1.12.0" "1.18.0") + ]; + out = "0.9"; + } + { + cases = [ + (range "8.13" "8.14") + (range "1.12.0" "1.18.0") + ]; + out = "0.5"; + } + ] + null; propagatedBuildInputs = [ hydra-battles diff --git a/pkgs/development/coq-modules/gaia/default.nix b/pkgs/development/coq-modules/gaia/default.nix index 073352d1744a27..63891055f22c62 100644 --- a/pkgs/development/coq-modules/gaia/default.nix +++ b/pkgs/development/coq-modules/gaia/default.nix @@ -1,4 +1,10 @@ -{ lib, mkCoqDerivation, coq, mathcomp, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + mathcomp, + version ? null, +}: mkCoqDerivation { pname = "gaia"; @@ -9,18 +15,44 @@ mkCoqDerivation { release."1.14".sha256 = "sha256-wgeQC0fIN3PSmRY1K6/KTy+rJmqqxdo3Bhsz1vjVAes="; release."1.15".sha256 = "sha256:04zchnkvaq2mzpcilpspn5l947689gj3m0w20m0nd7w4drvlahnw"; release."1.17".sha256 = "sha256-2VzdopXgKS/wC5Rd1/Zlr12J5bSIGINFjG1nrMjDrGE="; - release."2.2".sha256 = "sha256-y8LlQg9d9rfPFjzS9Xu3BW/H3tPiOC+Eb/zwXJGW9d4="; + release."2.2".sha256 = "sha256-y8LlQg9d9rfPFjzS9Xu3BW/H3tPiOC+Eb/zwXJGW9d4="; releaseRev = (v: "v${v}"); inherit version; - defaultVersion = with lib.versions; lib.switch [ coq.version mathcomp.version ] [ - { cases = [ (range "8.16" "8.20") (range "2.0" "2.2") ]; out = "2.2"; } - { cases = [ (range "8.10" "8.18") (range "1.12.0" "1.18.0") ]; out = "1.17"; } - { cases = [ (range "8.10" "8.12") "1.11.0" ]; out = "1.11"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.version mathcomp.version ] + [ + { + cases = [ + (range "8.16" "8.20") + (range "2.0" "2.2") + ]; + out = "2.2"; + } + { + cases = [ + (range "8.10" "8.18") + (range "1.12.0" "1.18.0") + ]; + out = "1.17"; + } + { + cases = [ + (range "8.10" "8.12") + "1.11.0" + ]; + out = "1.11"; + } + ] + null; - propagatedBuildInputs = - [ mathcomp.ssreflect mathcomp.algebra mathcomp.fingroup ]; + propagatedBuildInputs = [ + mathcomp.ssreflect + mathcomp.algebra + mathcomp.fingroup + ]; meta = with lib; { description = "Implementation of books from Bourbaki's Elements of Mathematics in Coq"; diff --git a/pkgs/development/coq-modules/gappalib/default.nix b/pkgs/development/coq-modules/gappalib/default.nix index 10b27aa5ca6337..0a35f995112567 100644 --- a/pkgs/development/coq-modules/gappalib/default.nix +++ b/pkgs/development/coq-modules/gappalib/default.nix @@ -1,4 +1,11 @@ -{ lib, mkCoqDerivation, autoconf, coq, flocq, version ? null }: +{ + lib, + mkCoqDerivation, + autoconf, + coq, + flocq, + version ? null, +}: mkCoqDerivation { pname = "gappalib"; diff --git a/pkgs/development/coq-modules/goedel/default.nix b/pkgs/development/coq-modules/goedel/default.nix index 2dae5941197d10..b9ca9a4fb5a947 100644 --- a/pkgs/development/coq-modules/goedel/default.nix +++ b/pkgs/development/coq-modules/goedel/default.nix @@ -1,4 +1,11 @@ -{ lib, mkCoqDerivation, coq, hydra-battles, pocklington, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + hydra-battles, + pocklington, + version ? null, +}: mkCoqDerivation { pname = "goedel"; @@ -10,11 +17,19 @@ mkCoqDerivation { release."8.13.0".sha256 = "0sqqkmj6wsk4xmhrnqkhcsbsrqjzn2gnk67nqzgrmjpw5danz8y5"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.11" "8.16"; out = "8.13.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.11" "8.16"; + out = "8.13.0"; + } + ] null; - propagatedBuildInputs = [ hydra-battles pocklington ]; + propagatedBuildInputs = [ + hydra-battles + pocklington + ]; meta = with lib; { description = "Gödel-Rosser 1st incompleteness theorem in Coq"; diff --git a/pkgs/development/coq-modules/graph-theory/default.nix b/pkgs/development/coq-modules/graph-theory/default.nix index 94e868c8ebf1c9..380ee69f1f8c7b 100644 --- a/pkgs/development/coq-modules/graph-theory/default.nix +++ b/pkgs/development/coq-modules/graph-theory/default.nix @@ -1,5 +1,13 @@ -{ lib, mkCoqDerivation, coq, mathcomp, mathcomp-finmap -, fourcolor, hierarchy-builder, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + mathcomp, + mathcomp-finmap, + fourcolor, + hierarchy-builder, + version ? null, +}: mkCoqDerivation { pname = "graph-theory"; @@ -13,15 +21,56 @@ mkCoqDerivation { releaseRev = v: "v${v}"; inherit version; - defaultVersion = with lib.versions; lib.switch [ coq.coq-version mathcomp.version ] [ - { cases = [ (range "8.16" "8.19") (range "2.0.0" "2.2.0") ]; out = "0.9.4"; } - { cases = [ (range "8.16" "8.18") (range "2.0.0" "2.1.0" ) ]; out = "0.9.3"; } - { cases = [ (range "8.14" "8.18") (range "1.13.0" "1.18.0") ]; out = "0.9.2"; } - { cases = [ (range "8.14" "8.16") (range "1.13.0" "1.14.0") ]; out = "0.9.1"; } - { cases = [ (range "8.12" "8.13") (range "1.12.0" "1.14.0") ]; out = "0.9"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.coq-version mathcomp.version ] + [ + { + cases = [ + (range "8.16" "8.19") + (range "2.0.0" "2.2.0") + ]; + out = "0.9.4"; + } + { + cases = [ + (range "8.16" "8.18") + (range "2.0.0" "2.1.0") + ]; + out = "0.9.3"; + } + { + cases = [ + (range "8.14" "8.18") + (range "1.13.0" "1.18.0") + ]; + out = "0.9.2"; + } + { + cases = [ + (range "8.14" "8.16") + (range "1.13.0" "1.14.0") + ]; + out = "0.9.1"; + } + { + cases = [ + (range "8.12" "8.13") + (range "1.12.0" "1.14.0") + ]; + out = "0.9"; + } + ] + null; - propagatedBuildInputs = [ mathcomp.algebra mathcomp-finmap mathcomp.fingroup fourcolor hierarchy-builder ]; + propagatedBuildInputs = [ + mathcomp.algebra + mathcomp-finmap + mathcomp.fingroup + fourcolor + hierarchy-builder + ]; meta = with lib; { description = "Library of formalized graph theory results in Coq"; diff --git a/pkgs/development/coq-modules/heq/default.nix b/pkgs/development/coq-modules/heq/default.nix index fc96b2abf98c5d..0d6ef1207e990e 100644 --- a/pkgs/development/coq-modules/heq/default.nix +++ b/pkgs/development/coq-modules/heq/default.nix @@ -1,10 +1,26 @@ -{lib, fetchzip, mkCoqDerivation, coq, version ? null }: +{ + lib, + fetchzip, + mkCoqDerivation, + coq, + version ? null, +}: -let fetcher = {rev, repo, owner, sha256, domain, ...}: - fetchzip { - url = "https://${domain}/${owner}/${repo}/download/${repo}-${rev}.zip"; - inherit sha256; - }; in +let + fetcher = + { + rev, + repo, + owner, + sha256, + domain, + ... + }: + fetchzip { + url = "https://${domain}/${owner}/${repo}/download/${repo}-${rev}.zip"; + inherit sha256; + }; +in mkCoqDerivation { pname = "heq"; repo = "Heq"; diff --git a/pkgs/development/coq-modules/high-school-geometry/default.nix b/pkgs/development/coq-modules/high-school-geometry/default.nix index 2f478978bd5806..29351db0c3183a 100644 --- a/pkgs/development/coq-modules/high-school-geometry/default.nix +++ b/pkgs/development/coq-modules/high-school-geometry/default.nix @@ -1,15 +1,34 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "high-school-geometry"; inherit version; repo = "HighSchoolGeometry"; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.16" "8.20"; out = "8.16"; } - { case = range "8.12" "8.16"; out = "8.13"; } - { case = "8.12"; out = "8.12"; } - { case = "8.11"; out = "8.11"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.16" "8.20"; + out = "8.16"; + } + { + case = range "8.12" "8.16"; + out = "8.13"; + } + { + case = "8.12"; + out = "8.12"; + } + { + case = "8.11"; + out = "8.11"; + } + ] null; release = { "8.16".sha256 = "sha256-HvUrZ6l7wCshuKUZs8rvfMkTEv+oXuogI5LICcD8Bn8="; diff --git a/pkgs/development/coq-modules/http/default.nix b/pkgs/development/coq-modules/http/default.nix index dafa5532523bc8..5eb5fa79e2ef00 100644 --- a/pkgs/development/coq-modules/http/default.nix +++ b/pkgs/development/coq-modules/http/default.nix @@ -1,4 +1,11 @@ -{ lib, mkCoqDerivation, coq, QuickChick, async-test, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + QuickChick, + async-test, + version ? null, +}: mkCoqDerivation { pname = "http"; @@ -6,16 +13,25 @@ mkCoqDerivation { repo = "coq-http"; inherit version; - defaultVersion = let inherit (lib.versions) range; in + defaultVersion = + let + inherit (lib.versions) range; + in lib.switch coq.coq-version [ - { case = range "8.14" "8.19"; out = "0.2.1"; } + { + case = range "8.14" "8.19"; + out = "0.2.1"; + } ] null; release = { - "0.2.1".sha256 = "sha256-CIcaXEojNdajXNoMBjGlQRc1sOJSKgUlditNxbNSPgk="; + "0.2.1".sha256 = "sha256-CIcaXEojNdajXNoMBjGlQRc1sOJSKgUlditNxbNSPgk="; }; releaseRev = v: "v${v}"; - propagatedBuildInputs = [ QuickChick async-test ]; + propagatedBuildInputs = [ + QuickChick + async-test + ]; configurePhase = '' sed -e 's/^ install extract.*//' -i Makefile diff --git a/pkgs/development/coq-modules/hydra-battles/default.nix b/pkgs/development/coq-modules/hydra-battles/default.nix index 4a6823dcf4203b..74f57cc77d62c3 100644 --- a/pkgs/development/coq-modules/hydra-battles/default.nix +++ b/pkgs/development/coq-modules/hydra-battles/default.nix @@ -1,4 +1,11 @@ -{ lib, mkCoqDerivation, coq, equations, LibHyps, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + equations, + LibHyps, + version ? null, +}: (mkCoqDerivation { pname = "hydra-battles"; @@ -11,10 +18,18 @@ releaseRev = (v: "v${v}"); inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.13" "8.16"; out = "0.9"; } - { case = range "8.11" "8.12"; out = "0.4"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.13" "8.16"; + out = "0.9"; + } + { + case = range "8.11" "8.12"; + out = "0.4"; + } + ] null; useDune = true; @@ -27,11 +42,22 @@ ordinal numbers, and a part of the so-called Ketonen and Solovay machinery (combinatorial properties of epsilon0). ''; - maintainers = with maintainers; [ siraben Zimmi48 ]; + maintainers = with maintainers; [ + siraben + Zimmi48 + ]; license = licenses.mit; platforms = platforms.unix; }; -}).overrideAttrs(o: - let inherit (o) version; in { - propagatedBuildInputs = [ equations ] ++ lib.optional (lib.versions.isGe "0.6" version || version == "dev") LibHyps; - }) +}).overrideAttrs + ( + o: + let + inherit (o) version; + in + { + propagatedBuildInputs = [ + equations + ] ++ lib.optional (lib.versions.isGe "0.6" version || version == "dev") LibHyps; + } + ) diff --git a/pkgs/development/coq-modules/interval/default.nix b/pkgs/development/coq-modules/interval/default.nix index 69f65fe6c5d7d5..e29863c2283c97 100644 --- a/pkgs/development/coq-modules/interval/default.nix +++ b/pkgs/development/coq-modules/interval/default.nix @@ -1,22 +1,62 @@ -{ lib, mkCoqDerivation, autoconf, coq, coquelicot, flocq, - mathcomp-ssreflect, mathcomp-fingroup, bignums ? null, gnuplot_qt, version ? null }: +{ + lib, + mkCoqDerivation, + autoconf, + coq, + coquelicot, + flocq, + mathcomp-ssreflect, + mathcomp-fingroup, + bignums ? null, + gnuplot_qt, + version ? null, +}: mkCoqDerivation rec { pname = "interval"; owner = "coqinterval"; domain = "gitlab.inria.fr"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.13" "8.20"; out = "4.11.0"; } - { case = range "8.12" "8.19"; out = "4.10.0"; } - { case = range "8.12" "8.18"; out = "4.9.0"; } - { case = range "8.12" "8.17"; out = "4.8.0"; } - { case = range "8.12" "8.16"; out = "4.6.0"; } - { case = range "8.8" "8.16"; out = "4.5.2"; } - { case = range "8.8" "8.12"; out = "4.0.0"; } - { case = range "8.7" "8.11"; out = "3.4.2"; } - { case = range "8.5" "8.6"; out = "3.3.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.13" "8.20"; + out = "4.11.0"; + } + { + case = range "8.12" "8.19"; + out = "4.10.0"; + } + { + case = range "8.12" "8.18"; + out = "4.9.0"; + } + { + case = range "8.12" "8.17"; + out = "4.8.0"; + } + { + case = range "8.12" "8.16"; + out = "4.6.0"; + } + { + case = range "8.8" "8.16"; + out = "4.5.2"; + } + { + case = range "8.8" "8.12"; + out = "4.0.0"; + } + { + case = range "8.7" "8.11"; + out = "3.4.2"; + } + { + case = range "8.5" "8.6"; + out = "3.3.0"; + } + ] null; release."4.11.0".sha256 = "sha256-vPwa4zSjyvxHLGDoNaBnHV2pb77dnQFbC50BL80fcvE="; release."4.10.0".sha256 = "sha256-MZJVoKGLXjDabdv9BuUSK1L9z1cubzC9cqVuWevKIXQ="; release."4.9.0".sha256 = "sha256-+5NppyQahcc1idGu/U3B+EIWuZz2L3/oY7dIJR6pitE="; @@ -36,8 +76,14 @@ mkCoqDerivation rec { releaseRev = v: "interval-${v}"; nativeBuildInputs = [ autoconf ]; - propagatedBuildInputs = lib.optional (lib.versions.isGe "8.6" coq.coq-version) bignums - ++ [ coquelicot flocq mathcomp-ssreflect mathcomp-fingroup ] + propagatedBuildInputs = + lib.optional (lib.versions.isGe "8.6" coq.coq-version) bignums + ++ [ + coquelicot + flocq + mathcomp-ssreflect + mathcomp-fingroup + ] ++ lib.optionals (lib.versions.isGe "4.2.0" defaultVersion) [ gnuplot_qt ]; useMelquiondRemake.logpath = "Interval"; mlPlugin = true; diff --git a/pkgs/development/coq-modules/iris-named-props/default.nix b/pkgs/development/coq-modules/iris-named-props/default.nix index 4499e435230c7c..e2b6f9d7e29691 100644 --- a/pkgs/development/coq-modules/iris-named-props/default.nix +++ b/pkgs/development/coq-modules/iris-named-props/default.nix @@ -1,12 +1,23 @@ -{ lib, mkCoqDerivation, coq, version ? null, iris }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, + iris, +}: mkCoqDerivation rec { pname = "iris-named-props"; owner = "tchajed"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = range "8.16" "8.19"; out = "2023-08-14"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.16" "8.19"; + out = "2023-08-14"; + } + ] null; release."2023-08-14".sha256 = "sha256-gu9qOdHO0qJ2B9Y9Vf66q08iNJcfuECJO66fizFB08g="; release."2023-08-14".rev = "ca1871dd33649f27257a0fbf94076acc80ecffbc"; propagatedBuildInputs = [ iris ]; diff --git a/pkgs/development/coq-modules/iris/default.nix b/pkgs/development/coq-modules/iris/default.nix index a8e925e98f04ba..14410a8cecd030 100644 --- a/pkgs/development/coq-modules/iris/default.nix +++ b/pkgs/development/coq-modules/iris/default.nix @@ -1,19 +1,48 @@ -{ lib, mkCoqDerivation, coq, stdpp, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + stdpp, + version ? null, +}: mkCoqDerivation rec { pname = "iris"; domain = "gitlab.mpi-sws.org"; owner = "iris"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.19" "8.20"; out = "4.3.0"; } - { case = range "8.18" "8.19"; out = "4.2.0"; } - { case = range "8.16" "8.18"; out = "4.1.0"; } - { case = range "8.13" "8.17"; out = "4.0.0"; } - { case = range "8.12" "8.14"; out = "3.5.0"; } - { case = range "8.11" "8.13"; out = "3.4.0"; } - { case = range "8.9" "8.10"; out = "3.3.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.19" "8.20"; + out = "4.3.0"; + } + { + case = range "8.18" "8.19"; + out = "4.2.0"; + } + { + case = range "8.16" "8.18"; + out = "4.1.0"; + } + { + case = range "8.13" "8.17"; + out = "4.0.0"; + } + { + case = range "8.12" "8.14"; + out = "3.5.0"; + } + { + case = range "8.11" "8.13"; + out = "3.4.0"; + } + { + case = range "8.9" "8.10"; + out = "3.3.0"; + } + ] null; release."4.3.0".sha256 = "sha256-3qhjiFI+A3I3fD8rFfJL5Hek77wScfn/FNNbDyGqA1k="; release."4.2.0".sha256 = "sha256-HuiHIe+5letgr1NN1biZZFq0qlWUbFmoVI7Q91+UIfM="; release."4.1.0".sha256 = "sha256-nTZUeZOXiH7HsfGbMKDE7vGrNVCkbMaWxdMWUcTUNlo="; @@ -35,6 +64,9 @@ mkCoqDerivation rec { meta = with lib; { description = "Coq development of the Iris Project"; license = licenses.bsd3; - maintainers = [ maintainers.vbgl maintainers.ineol ]; + maintainers = [ + maintainers.vbgl + maintainers.ineol + ]; }; } diff --git a/pkgs/development/coq-modules/itauto/default.nix b/pkgs/development/coq-modules/itauto/default.nix index fd7e4fa31859d9..238c89d1fd5ac6 100644 --- a/pkgs/development/coq-modules/itauto/default.nix +++ b/pkgs/development/coq-modules/itauto/default.nix @@ -1,4 +1,10 @@ -{ lib, callPackage, mkCoqDerivation, coq, version ? null }: +{ + lib, + callPackage, + mkCoqDerivation, + coq, + version ? null, +}: (mkCoqDerivation rec { pname = "itauto"; @@ -14,32 +20,65 @@ release."8.14.0".sha256 = "sha256:1k6pqhv4dwpkwg81f2rlfg40wh070ks1gy9r0ravm2zhsbxqcfc9"; release."8.13+no".sha256 = "sha256-gXoxtLcHPoyjJkt7WqvzfCMCQlh6kL2KtCGe3N6RC/A="; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = isEq "8.20"; out = "8.20.0"; } - { case = isEq "8.19"; out = "8.19.0"; } - { case = isEq "8.18"; out = "8.18.0"; } - { case = isEq "8.17"; out = "8.17.0"; } - { case = isEq "8.16"; out = "8.16.0"; } - { case = isEq "8.15"; out = "8.15.0"; } - { case = isEq "8.14"; out = "8.14.0"; } - { case = isEq "8.13"; out = "8.13+no"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = isEq "8.20"; + out = "8.20.0"; + } + { + case = isEq "8.19"; + out = "8.19.0"; + } + { + case = isEq "8.18"; + out = "8.18.0"; + } + { + case = isEq "8.17"; + out = "8.17.0"; + } + { + case = isEq "8.16"; + out = "8.16.0"; + } + { + case = isEq "8.15"; + out = "8.15.0"; + } + { + case = isEq "8.14"; + out = "8.14.0"; + } + { + case = isEq "8.13"; + out = "8.13+no"; + } + ] null; mlPlugin = true; nativeBuildInputs = (with coq.ocamlPackages; [ ocamlbuild ]); enableParallelBuilding = false; - passthru.tests.suite = callPackage ./test.nix {}; + passthru.tests.suite = callPackage ./test.nix { }; - meta = with lib; { + meta = with lib; { description = "Reflexive SAT solver parameterised by a leaf tactic and Nelson-Oppen support"; maintainers = with maintainers; [ siraben ]; license = licenses.gpl3Plus; }; -}).overrideAttrs (o: lib.optionalAttrs - (o.version == "dev" || lib.versionAtLeast o.version "8.16") { - propagatedBuildInputs = [ coq.ocamlPackages.findlib ]; -} // lib.optionalAttrs - (o.version == "dev" || lib.versionAtLeast o.version "8.18") { - nativeBuildInputs = with coq.ocamlPackages; [ ocaml findlib dune_3 ]; -}) +}).overrideAttrs + ( + o: + lib.optionalAttrs (o.version == "dev" || lib.versionAtLeast o.version "8.16") { + propagatedBuildInputs = [ coq.ocamlPackages.findlib ]; + } + // lib.optionalAttrs (o.version == "dev" || lib.versionAtLeast o.version "8.18") { + nativeBuildInputs = with coq.ocamlPackages; [ + ocaml + findlib + dune_3 + ]; + } + ) diff --git a/pkgs/development/coq-modules/itauto/test.nix b/pkgs/development/coq-modules/itauto/test.nix index ef3a85954e61e3..f4427839047391 100644 --- a/pkgs/development/coq-modules/itauto/test.nix +++ b/pkgs/development/coq-modules/itauto/test.nix @@ -1,14 +1,25 @@ -{ stdenv, lib, coq, itauto }: +{ + stdenv, + lib, + coq, + itauto, +}: -let excluded = - lib.optionals (lib.versions.isEq "8.16" itauto.version) [ "arith.v" "refl_bool.v" ] -; in +let + excluded = lib.optionals (lib.versions.isEq "8.16" itauto.version) [ + "arith.v" + "refl_bool.v" + ]; +in stdenv.mkDerivation { pname = "coq${coq.coq-version}-itauto-test"; inherit (itauto) src version; - nativeCheckInputs = [ coq itauto ]; + nativeCheckInputs = [ + coq + itauto + ]; dontConfigure = true; dontBuild = true; diff --git a/pkgs/development/coq-modules/itree-io/default.nix b/pkgs/development/coq-modules/itree-io/default.nix index f708509fce7aa6..d932513bbea571 100644 --- a/pkgs/development/coq-modules/itree-io/default.nix +++ b/pkgs/development/coq-modules/itree-io/default.nix @@ -1,4 +1,11 @@ -{ lib, mkCoqDerivation, coq, ITree, simple-io, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + ITree, + simple-io, + version ? null, +}: mkCoqDerivation { pname = "itree-io"; @@ -6,16 +13,25 @@ mkCoqDerivation { owner = "Lysxia"; inherit version; - defaultVersion = let inherit (lib.versions) range; in + defaultVersion = + let + inherit (lib.versions) range; + in lib.switch coq.coq-version [ - { case = range "8.12" "8.19"; out = "0.1.1"; } + { + case = range "8.12" "8.19"; + out = "0.1.1"; + } ] null; release = { - "0.1.1".sha256 = "sha256-IFwIj8dxW4jm2gvuUJ8LKZFSJeljp0bsn8fezxY6t2o="; + "0.1.1".sha256 = "sha256-IFwIj8dxW4jm2gvuUJ8LKZFSJeljp0bsn8fezxY6t2o="; }; releaseRev = v: "v${v}"; - propagatedBuildInputs = [ ITree simple-io ]; + propagatedBuildInputs = [ + ITree + simple-io + ]; meta = { description = "Interpret itree in the IO monad of simple-io."; diff --git a/pkgs/development/coq-modules/json/default.nix b/pkgs/development/coq-modules/json/default.nix index f30c238aafd00c..3b8ccef3bb9582 100644 --- a/pkgs/development/coq-modules/json/default.nix +++ b/pkgs/development/coq-modules/json/default.nix @@ -1,4 +1,11 @@ -{ lib, mkCoqDerivation, coq, parsec, MenhirLib, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + parsec, + MenhirLib, + version ? null, +}: (mkCoqDerivation { pname = "json"; @@ -6,18 +13,31 @@ repo = "coq-json"; inherit version; - defaultVersion = let inherit (lib.versions) range; in + defaultVersion = + let + inherit (lib.versions) range; + in lib.switch coq.coq-version [ - { case = range "8.14" "8.20"; out = "0.2.0"; } - { case = range "8.14" "8.20"; out = "0.1.3"; } + { + case = range "8.14" "8.20"; + out = "0.2.0"; + } + { + case = range "8.14" "8.20"; + out = "0.1.3"; + } ] null; release = { - "0.2.0".sha256 = "sha256-qDRTgWLUvu4x3/d3BDcqo2I4W5ZmLyRiwuY/Tm/FuKA="; - "0.1.3".sha256 = "sha256-lElAzW4IuX+BB6ngDjlyKn0MytLRfbhQanB+Lct/WR0="; + "0.2.0".sha256 = "sha256-qDRTgWLUvu4x3/d3BDcqo2I4W5ZmLyRiwuY/Tm/FuKA="; + "0.1.3".sha256 = "sha256-lElAzW4IuX+BB6ngDjlyKn0MytLRfbhQanB+Lct/WR0="; }; releaseRev = v: "v${v}"; - propagatedBuildInputs = [ parsec MenhirLib coq.ocamlPackages.menhir ]; + propagatedBuildInputs = [ + parsec + MenhirLib + coq.ocamlPackages.menhir + ]; useDuneifVersion = v: lib.versions.isGe "0.2.0" v || v == "dev"; @@ -25,6 +45,13 @@ description = "From JSON to Coq, and vice versa."; license = lib.licenses.bsd3; }; -}).overrideAttrs (o: lib.optionalAttrs (o.version != null - && lib.versions.isLt "0.2.0" o.version) - { buildFlags = [ "MENHIRFLAGS=--coq" "MENHIRFLAGS+=--coq-no-version-check" ]; }) +}).overrideAttrs + ( + o: + lib.optionalAttrs (o.version != null && lib.versions.isLt "0.2.0" o.version) { + buildFlags = [ + "MENHIRFLAGS=--coq" + "MENHIRFLAGS+=--coq-no-version-check" + ]; + } + ) diff --git a/pkgs/development/coq-modules/lemma-overloading/default.nix b/pkgs/development/coq-modules/lemma-overloading/default.nix index 8f4f12b02ba4eb..58400a50e0ee84 100644 --- a/pkgs/development/coq-modules/lemma-overloading/default.nix +++ b/pkgs/development/coq-modules/lemma-overloading/default.nix @@ -1,17 +1,57 @@ -{ lib, mkCoqDerivation, coq, mathcomp-ssreflect, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + mathcomp-ssreflect, + version ? null, +}: mkCoqDerivation rec { pname = "lemma-overloading"; inherit version; - defaultVersion = with lib.versions; - lib.switch [ coq.coq-version mathcomp-ssreflect.version ] [ - { cases = [ (range "8.10" "8.12") (range "1.7" "1.11") ]; out = "8.12.0"; } - { cases = [ (range "8.10" "8.11") (range "1.7" "1.11") ]; out = "8.11.0"; } - { cases = [ (range "8.8" "8.11") (range "1.7" "1.10") ]; out = "8.10.0"; } - { cases = [ (range "8.8" "8.9") (range "1.7" "1.8") ]; out = "8.9.0"; } - { cases = [ (isEq "8.8") (range "1.6.2" "1.7") ]; out = "8.8.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.coq-version mathcomp-ssreflect.version ] + [ + { + cases = [ + (range "8.10" "8.12") + (range "1.7" "1.11") + ]; + out = "8.12.0"; + } + { + cases = [ + (range "8.10" "8.11") + (range "1.7" "1.11") + ]; + out = "8.11.0"; + } + { + cases = [ + (range "8.8" "8.11") + (range "1.7" "1.10") + ]; + out = "8.10.0"; + } + { + cases = [ + (range "8.8" "8.9") + (range "1.7" "1.8") + ]; + out = "8.9.0"; + } + { + cases = [ + (isEq "8.8") + (range "1.6.2" "1.7") + ]; + out = "8.8.0"; + } + ] + null; release = { "8.12.0".sha256 = "sha256-ul1IhxFwhLTy3+rmo3gvjHI3Z8A8avN0Rzq0YDy2bjs="; diff --git a/pkgs/development/coq-modules/ltac2/default.nix b/pkgs/development/coq-modules/ltac2/default.nix index 11fa1af24de603..88b52f397bae46 100644 --- a/pkgs/development/coq-modules/ltac2/default.nix +++ b/pkgs/development/coq-modules/ltac2/default.nix @@ -1,21 +1,40 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "ltac2"; owner = "coq"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = "8.10"; out = "0.3"; } - { case = "8.9"; out = "0.2"; } - { case = "8.8"; out = "0.1"; } - { case = "8.7"; out = "0.1-8.7"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = "8.10"; + out = "0.3"; + } + { + case = "8.9"; + out = "0.2"; + } + { + case = "8.8"; + out = "0.1"; + } + { + case = "8.7"; + out = "0.1-8.7"; + } + ] null; release."0.3".sha256 = "0pzs5nsakh4l8ffwgn4ryxbnxdv2x0r1i7bc598ij621haxdirrr"; release."0.2".sha256 = "0xby1kb26r9gcvk5511wqj05fqm9paynwfxlfqkmwkgnfmzk0x73"; release."0.1".sha256 = "1zz26cyv99whj7rrpgnhhm9dfqnpmrx5pqizn8ihf8jkq8d4drz7"; release."0.1-8.7".version = "0.1"; - release."0.1-8.7".rev = "v0.1-8.7"; - release."0.1-8.7".sha256 = "0l6wiwi4cvd0i324fb29i9mdh0ijlxzggw4mrjjy695l2qdnlgg0"; + release."0.1-8.7".rev = "v0.1-8.7"; + release."0.1-8.7".sha256 = "0l6wiwi4cvd0i324fb29i9mdh0ijlxzggw4mrjjy695l2qdnlgg0"; mlPlugin = true; diff --git a/pkgs/development/coq-modules/math-classes/default.nix b/pkgs/development/coq-modules/math-classes/default.nix index 5466147f01de80..246ac5c617ab20 100644 --- a/pkgs/development/coq-modules/math-classes/default.nix +++ b/pkgs/development/coq-modules/math-classes/default.nix @@ -1,15 +1,35 @@ -{ lib, mkCoqDerivation, coq, bignums, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + bignums, + version ? null, +}: mkCoqDerivation { pname = "math-classes"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.17" "8.20"; out = "8.19.0"; } - { case = range "8.12" "8.18"; out = "8.18.0"; } - { case = range "8.12" "8.17"; out = "8.17.0"; } - { case = range "8.6" "8.16"; out = "8.15.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.17" "8.20"; + out = "8.19.0"; + } + { + case = range "8.12" "8.18"; + out = "8.18.0"; + } + { + case = range "8.12" "8.17"; + out = "8.17.0"; + } + { + case = range "8.6" "8.16"; + out = "8.15.0"; + } + ] null; release."8.12.0".sha256 = "14nd6a08zncrl5yg2gzk0xf4iinwq4hxnsgm4fyv07ydbkxfb425"; release."8.13.0".sha256 = "1ln7ziivfbxzbdvlhbvyg3v30jgblncmwcsam6gg3d1zz6r7cbby"; release."8.15.0".sha256 = "10w1hm537k6jx8a8vghq1yx12rsa0sjk2ipv3scgir71ln30hllw"; @@ -22,6 +42,9 @@ mkCoqDerivation { meta = { homepage = "https://math-classes.github.io"; description = "Library of abstract interfaces for mathematical structures in Coq"; - maintainers = with lib.maintainers; [ siddharthist jwiegley ]; + maintainers = with lib.maintainers; [ + siddharthist + jwiegley + ]; }; } diff --git a/pkgs/development/coq-modules/mathcomp-abel/default.nix b/pkgs/development/coq-modules/mathcomp-abel/default.nix index c9d6a709d6a383..8da24e652d9213 100644 --- a/pkgs/development/coq-modules/mathcomp-abel/default.nix +++ b/pkgs/development/coq-modules/mathcomp-abel/default.nix @@ -1,25 +1,59 @@ -{ coq, mkCoqDerivation, mathcomp, mathcomp-real-closed, lib, version ? null }: +{ + coq, + mkCoqDerivation, + mathcomp, + mathcomp-real-closed, + lib, + version ? null, +}: mkCoqDerivation { - namePrefix = [ "coq" "mathcomp" ]; + namePrefix = [ + "coq" + "mathcomp" + ]; pname = "abel"; owner = "math-comp"; inherit version; - defaultVersion = lib.switch [ coq.version mathcomp.version ] [ - { cases = [ (lib.versions.range "8.10" "8.16") (lib.versions.range "1.12.0" "1.15.0") ]; out = "1.2.1"; } - { cases = [ (lib.versions.range "8.10" "8.15") (lib.versions.range "1.12.0" "1.14.0") ]; out = "1.2.0"; } - { cases = [ (lib.versions.range "8.10" "8.14") (lib.versions.range "1.11.0" "1.12.0") ]; out = "1.1.2"; } - ] null; + defaultVersion = + lib.switch + [ coq.version mathcomp.version ] + [ + { + cases = [ + (lib.versions.range "8.10" "8.16") + (lib.versions.range "1.12.0" "1.15.0") + ]; + out = "1.2.1"; + } + { + cases = [ + (lib.versions.range "8.10" "8.15") + (lib.versions.range "1.12.0" "1.14.0") + ]; + out = "1.2.0"; + } + { + cases = [ + (lib.versions.range "8.10" "8.14") + (lib.versions.range "1.11.0" "1.12.0") + ]; + out = "1.1.2"; + } + ] + null; release."1.2.1".sha256 = "sha256-M1q6WIPBsayHde2hwlTxylH169hcTs3OuFsEkM0e3yc="; release."1.2.0".sha256 = "1picd4m85ipj22j3b84cv8ab3330radzrhd6kp0gpxq14dhv02c2"; release."1.1.2".sha256 = "0565w713z1cwxvvdlqws2z5lgdys8lddf0vpwfdj7bpd7pq9hwxg"; release."1.0.0".sha256 = "190jd8hb8anqsvr9ysr514pm5sh8qhw4030ddykvwxx9d9q6rbp3"; - - propagatedBuildInputs = [ mathcomp.field mathcomp-real-closed ]; + propagatedBuildInputs = [ + mathcomp.field + mathcomp-real-closed + ]; meta = with lib; { description = "Abel - Galois and Abel - Ruffini Theorems"; diff --git a/pkgs/development/coq-modules/mathcomp-algebra-tactics/default.nix b/pkgs/development/coq-modules/mathcomp-algebra-tactics/default.nix index 3e071850e8eff9..3996db951b2961 100644 --- a/pkgs/development/coq-modules/mathcomp-algebra-tactics/default.nix +++ b/pkgs/development/coq-modules/mathcomp-algebra-tactics/default.nix @@ -1,26 +1,68 @@ -{ lib, mkCoqDerivation, coq, mathcomp-algebra, - coq-elpi, mathcomp-zify, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + mathcomp-algebra, + coq-elpi, + mathcomp-zify, + version ? null, +}: mkCoqDerivation { - namePrefix = [ "coq" "mathcomp" ]; + namePrefix = [ + "coq" + "mathcomp" + ]; pname = "algebra-tactics"; owner = "math-comp"; inherit version; - defaultVersion = with lib.versions; - lib.switch [ coq.coq-version mathcomp-algebra.version ] [ - { cases = [ (range "8.16" "8.20") (isGe "2.0") ]; out = "1.2.3"; } - { cases = [ (range "8.16" "8.18") (isGe "2.0") ]; out = "1.2.2"; } - { cases = [ (range "8.16" "8.19") (isGe "1.15") ]; out = "1.1.1"; } - { cases = [ (range "8.13" "8.16") (isGe "1.12") ]; out = "1.0.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.coq-version mathcomp-algebra.version ] + [ + { + cases = [ + (range "8.16" "8.20") + (isGe "2.0") + ]; + out = "1.2.3"; + } + { + cases = [ + (range "8.16" "8.18") + (isGe "2.0") + ]; + out = "1.2.2"; + } + { + cases = [ + (range "8.16" "8.19") + (isGe "1.15") + ]; + out = "1.1.1"; + } + { + cases = [ + (range "8.13" "8.16") + (isGe "1.12") + ]; + out = "1.0.0"; + } + ] + null; release."1.0.0".sha256 = "sha256-kszARPBizWbxSQ/Iqpf2vLbxYc6AjpUCLnSNlPcNfls="; release."1.1.1".sha256 = "sha256-5wItMeeTRoJlRBH3zBNc2VUZn6pkDde60YAvXTx+J3U="; release."1.2.2".sha256 = "sha256-EU9RJGV3BvnmsX+mGH+6+MDXiGHgDI7aP5sIYiMUXTs="; release."1.2.3".sha256 = "sha256-6uc1VEfDv+fExEfBR2c0/Q/KjrkX0TbEMCLgeYcpkls="; - propagatedBuildInputs = [ mathcomp-algebra coq-elpi mathcomp-zify ]; + propagatedBuildInputs = [ + mathcomp-algebra + coq-elpi + mathcomp-zify + ]; meta = { description = "Ring and field tactics for Mathematical Components"; diff --git a/pkgs/development/coq-modules/mathcomp-analysis/default.nix b/pkgs/development/coq-modules/mathcomp-analysis/default.nix index 5949fead8b1d1b..64bd6fecab88f3 100644 --- a/pkgs/development/coq-modules/mathcomp-analysis/default.nix +++ b/pkgs/development/coq-modules/mathcomp-analysis/default.nix @@ -1,12 +1,18 @@ -{ lib, +{ + lib, mkCoqDerivation, - mathcomp, mathcomp-finmap, mathcomp-bigenough, + mathcomp, + mathcomp-finmap, + mathcomp-bigenough, hierarchy-builder, single ? false, - coqPackages, coq, version ? null }@args: + coqPackages, + coq, + version ? null, +}@args: let - repo = "analysis"; + repo = "analysis"; owner = "math-comp"; release."1.7.0".sha256 = "sha256-GgsMIHqLkWsPm2VyOPeZdOulkN00IoBz++qA6yE9raQ="; @@ -33,58 +39,192 @@ let release."0.3.1".sha256 = "1iad288yvrjv8ahl9v18vfblgqb1l5z6ax644w49w9hwxs93f2k8"; release."0.2.3".sha256 = "0p9mr8g1qma6h10qf7014dv98ln90dfkwn76ynagpww7qap8s966"; - defaultVersion = let inherit (lib.versions) range; in - lib.switch [ coq.version mathcomp.version ] [ - { cases = [ (range "8.19" "8.20") (range "2.1.0" "2.2.0") ]; out = "1.7.0"; } - { cases = [ (range "8.17" "8.20") (range "2.0.0" "2.2.0") ]; out = "1.1.0"; } - { cases = [ (range "8.17" "8.19") (range "1.17.0" "1.19.0") ]; out = "0.7.0"; } - { cases = [ (range "8.17" "8.18") (range "1.15.0" "1.18.0") ]; out = "0.6.7"; } - { cases = [ (range "8.17" "8.18") (range "1.15.0" "1.18.0") ]; out = "0.6.6"; } - { cases = [ (range "8.14" "8.18") (range "1.15.0" "1.17.0") ]; out = "0.6.5"; } - { cases = [ (range "8.14" "8.18") (range "1.13.0" "1.16.0") ]; out = "0.6.1"; } - { cases = [ (range "8.14" "8.18") (range "1.13" "1.15") ]; out = "0.5.2"; } - { cases = [ (range "8.13" "8.15") (range "1.13" "1.14") ]; out = "0.5.1"; } - { cases = [ (range "8.13" "8.15") (range "1.12" "1.14") ]; out = "0.3.13"; } - { cases = [ (range "8.11" "8.14") (range "1.12" "1.13") ]; out = "0.3.10"; } - { cases = [ (range "8.10" "8.12") "1.11.0" ]; out = "0.3.3"; } - { cases = [ (range "8.10" "8.11") "1.11.0" ]; out = "0.3.1"; } - { cases = [ (range "8.8" "8.11") (range "1.8" "1.10") ]; out = "0.2.3"; } - ] null; + defaultVersion = + let + inherit (lib.versions) range; + in + lib.switch + [ coq.version mathcomp.version ] + [ + { + cases = [ + (range "8.19" "8.20") + (range "2.1.0" "2.2.0") + ]; + out = "1.7.0"; + } + { + cases = [ + (range "8.17" "8.20") + (range "2.0.0" "2.2.0") + ]; + out = "1.1.0"; + } + { + cases = [ + (range "8.17" "8.19") + (range "1.17.0" "1.19.0") + ]; + out = "0.7.0"; + } + { + cases = [ + (range "8.17" "8.18") + (range "1.15.0" "1.18.0") + ]; + out = "0.6.7"; + } + { + cases = [ + (range "8.17" "8.18") + (range "1.15.0" "1.18.0") + ]; + out = "0.6.6"; + } + { + cases = [ + (range "8.14" "8.18") + (range "1.15.0" "1.17.0") + ]; + out = "0.6.5"; + } + { + cases = [ + (range "8.14" "8.18") + (range "1.13.0" "1.16.0") + ]; + out = "0.6.1"; + } + { + cases = [ + (range "8.14" "8.18") + (range "1.13" "1.15") + ]; + out = "0.5.2"; + } + { + cases = [ + (range "8.13" "8.15") + (range "1.13" "1.14") + ]; + out = "0.5.1"; + } + { + cases = [ + (range "8.13" "8.15") + (range "1.12" "1.14") + ]; + out = "0.3.13"; + } + { + cases = [ + (range "8.11" "8.14") + (range "1.12" "1.13") + ]; + out = "0.3.10"; + } + { + cases = [ + (range "8.10" "8.12") + "1.11.0" + ]; + out = "0.3.3"; + } + { + cases = [ + (range "8.10" "8.11") + "1.11.0" + ]; + out = "0.3.1"; + } + { + cases = [ + (range "8.8" "8.11") + (range "1.8" "1.10") + ]; + out = "0.2.3"; + } + ] + null; # list of analysis packages sorted by dependency order packages = { - "classical" = []; + "classical" = [ ]; "reals" = [ "classical" ]; "experimental-reals" = [ "reals" ]; "analysis" = [ "reals" ]; "reals-stdlib" = [ "reals" ]; - "analysis-stdlib" = [ "analysis" "reals-stdlib" ]; + "analysis-stdlib" = [ + "analysis" + "reals-stdlib" + ]; }; - mathcomp_ = package: let - classical-deps = [ mathcomp.algebra mathcomp-finmap ]; + mathcomp_ = + package: + let + classical-deps = [ + mathcomp.algebra + mathcomp-finmap + ]; experimental-reals-deps = [ mathcomp-bigenough ]; - analysis-deps = [ mathcomp.field mathcomp-bigenough ]; + analysis-deps = [ + mathcomp.field + mathcomp-bigenough + ]; intra-deps = lib.optionals (package != "single") (map mathcomp_ packages.${package}); pkgpath = lib.switch package [ - { case = "single"; out = "."; } - { case = "analysis"; out = "theories"; } - { case = "experimental-reals"; out = "experimental_reals"; } - { case = "reals-stdlib"; out = "reals_stdlib"; } - { case = "analysis-stdlib"; out = "analysis_stdlib"; } + { + case = "single"; + out = "."; + } + { + case = "analysis"; + out = "theories"; + } + { + case = "experimental-reals"; + out = "experimental_reals"; + } + { + case = "reals-stdlib"; + out = "reals_stdlib"; + } + { + case = "analysis-stdlib"; + out = "analysis_stdlib"; + } ] package; - pname = if package == "single" then "mathcomp-analysis-single" - else "mathcomp-${package}"; + pname = if package == "single" then "mathcomp-analysis-single" else "mathcomp-${package}"; derivation = mkCoqDerivation ({ - inherit version pname defaultVersion release repo owner; + inherit + version + pname + defaultVersion + release + repo + owner + ; - namePrefix = [ "coq" "mathcomp" ]; + namePrefix = [ + "coq" + "mathcomp" + ]; propagatedBuildInputs = intra-deps - ++ lib.optionals (lib.elem package [ "classical" "single" ]) classical-deps - ++ lib.optionals (lib.elem package [ "experimental-reals" "single" ]) experimental-reals-deps - ++ lib.optionals (lib.elem package [ "analysis" "single" ]) analysis-deps; + ++ lib.optionals (lib.elem package [ + "classical" + "single" + ]) classical-deps + ++ lib.optionals (lib.elem package [ + "experimental-reals" + "single" + ]) experimental-reals-deps + ++ lib.optionals (lib.elem package [ + "analysis" + "single" + ]) analysis-deps; preBuild = '' cd ${pkgpath} @@ -93,35 +233,64 @@ let meta = { description = "Analysis library compatible with Mathematical Components"; maintainers = [ lib.maintainers.cohencyril ]; - license = lib.licenses.cecill-c; + license = lib.licenses.cecill-c; }; passthru = lib.mapAttrs (package: deps: mathcomp_ package) packages; }); - # split packages didn't exist before 0.6, so bulding nothing in that case - patched-derivation1 = derivation.overrideAttrs (o: - lib.optionalAttrs (o.pname != null && o.pname != "mathcomp-analysis" && - o.version != null && o.version != "dev" && lib.versions.isLt "0.6" o.version) - { preBuild = ""; buildPhase = "echo doing nothing"; installPhase = "echo doing nothing"; } - ); - patched-derivation2 = patched-derivation1.overrideAttrs (o: - lib.optionalAttrs (o.pname != null && o.pname == "mathcomp-analysis" && - o.version != null && o.version != "dev" && lib.versions.isLt "0.6" o.version) - { preBuild = ""; } - ); - # only packages classical and analysis existed before 1.7, so bulding nothing in that case - patched-derivation3 = patched-derivation2.overrideAttrs (o: - lib.optionalAttrs (o.pname != null && o.pname != "mathcomp-classical" && o.pname != "mathcomp-analysis" && - o.version != null && o.version != "dev" && lib.versions.isLt "1.7" o.version) - { preBuild = ""; buildPhase = "echo doing nothing"; installPhase = "echo doing nothing"; } - ); - patched-derivation = patched-derivation3.overrideAttrs (o: - lib.optionalAttrs (o.version != null - && (o.version == "dev" || lib.versions.isGe "0.3.4" o.version)) - { - propagatedBuildInputs = o.propagatedBuildInputs ++ [ hierarchy-builder ]; - } - ); - in patched-derivation; + # split packages didn't exist before 0.6, so bulding nothing in that case + patched-derivation1 = derivation.overrideAttrs ( + o: + lib.optionalAttrs + ( + o.pname != null + && o.pname != "mathcomp-analysis" + && o.version != null + && o.version != "dev" + && lib.versions.isLt "0.6" o.version + ) + { + preBuild = ""; + buildPhase = "echo doing nothing"; + installPhase = "echo doing nothing"; + } + ); + patched-derivation2 = patched-derivation1.overrideAttrs ( + o: + lib.optionalAttrs ( + o.pname != null + && o.pname == "mathcomp-analysis" + && o.version != null + && o.version != "dev" + && lib.versions.isLt "0.6" o.version + ) { preBuild = ""; } + ); + # only packages classical and analysis existed before 1.7, so bulding nothing in that case + patched-derivation3 = patched-derivation2.overrideAttrs ( + o: + lib.optionalAttrs + ( + o.pname != null + && o.pname != "mathcomp-classical" + && o.pname != "mathcomp-analysis" + && o.version != null + && o.version != "dev" + && lib.versions.isLt "1.7" o.version + ) + { + preBuild = ""; + buildPhase = "echo doing nothing"; + installPhase = "echo doing nothing"; + } + ); + patched-derivation = patched-derivation3.overrideAttrs ( + o: + lib.optionalAttrs (o.version != null && (o.version == "dev" || lib.versions.isGe "0.3.4" o.version)) + { + propagatedBuildInputs = o.propagatedBuildInputs ++ [ hierarchy-builder ]; + } + ); + in + patched-derivation; in mathcomp_ (if single then "single" else "analysis") diff --git a/pkgs/development/coq-modules/mathcomp-apery/default.nix b/pkgs/development/coq-modules/mathcomp-apery/default.nix index 8e22a6c9aeb43e..390aae694fb6c3 100644 --- a/pkgs/development/coq-modules/mathcomp-apery/default.nix +++ b/pkgs/development/coq-modules/mathcomp-apery/default.nix @@ -1,20 +1,46 @@ -{ coq, mkCoqDerivation, mathcomp, coqeal, mathcomp-real-closed, - mathcomp-bigenough, mathcomp-zify, mathcomp-algebra-tactics, - lib, version ? null }: +{ + coq, + mkCoqDerivation, + mathcomp, + coqeal, + mathcomp-real-closed, + mathcomp-bigenough, + mathcomp-zify, + mathcomp-algebra-tactics, + lib, + version ? null, +}: mkCoqDerivation { pname = "apery"; inherit version; - defaultVersion = with lib.versions; lib.switch [ coq.version mathcomp.version ] [ - { cases = [ (range "8.13" "8.16") (range "1.12.0" "1.17.0") ]; out = "1.0.2"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.version mathcomp.version ] + [ + { + cases = [ + (range "8.13" "8.16") + (range "1.12.0" "1.17.0") + ]; + out = "1.0.2"; + } + ] + null; release."1.0.2".sha256 = "sha256-llxyMKYvWUA7fyroG1S/jtpioAoArmarR1edi3cikcY="; - propagatedBuildInputs = [ mathcomp.field coqeal mathcomp-real-closed - mathcomp-bigenough mathcomp-zify mathcomp-algebra-tactics ]; + propagatedBuildInputs = [ + mathcomp.field + coqeal + mathcomp-real-closed + mathcomp-bigenough + mathcomp-zify + mathcomp-algebra-tactics + ]; meta = { description = "Formally verified proof in Coq, by computer algebra, that ζ(3) is irrational"; diff --git a/pkgs/development/coq-modules/mathcomp-bigenough/default.nix b/pkgs/development/coq-modules/mathcomp-bigenough/default.nix index 25b4a5a2d010af..4a79a3d95d90f4 100644 --- a/pkgs/development/coq-modules/mathcomp-bigenough/default.nix +++ b/pkgs/development/coq-modules/mathcomp-bigenough/default.nix @@ -1,8 +1,17 @@ -{ coq, mkCoqDerivation, mathcomp, lib, version ? null }: +{ + coq, + mkCoqDerivation, + mathcomp, + lib, + version ? null, +}: mkCoqDerivation { - namePrefix = [ "coq" "mathcomp" ]; + namePrefix = [ + "coq" + "mathcomp" + ]; pname = "bigenough"; owner = "math-comp"; @@ -11,10 +20,18 @@ mkCoqDerivation { "1.0.1".sha256 = "sha256:02f4dv4rz72liciwxb2k7acwx6lgqz4381mqyq5854p3nbyn06aw"; }; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = range "8.10" "8.20"; out = "1.0.1"; } - { case = range "8.5" "8.14"; out = "1.0.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.10" "8.20"; + out = "1.0.1"; + } + { + case = range "8.5" "8.14"; + out = "1.0.0"; + } + ] null; propagatedBuildInputs = [ mathcomp.ssreflect ]; diff --git a/pkgs/development/coq-modules/mathcomp-finmap/default.nix b/pkgs/development/coq-modules/mathcomp-finmap/default.nix index 66d237c0a53d4c..f0fb42ddae8a61 100644 --- a/pkgs/development/coq-modules/mathcomp-finmap/default.nix +++ b/pkgs/development/coq-modules/mathcomp-finmap/default.nix @@ -1,36 +1,110 @@ -{ coq, mkCoqDerivation, mathcomp, lib, version ? null }: +{ + coq, + mkCoqDerivation, + mathcomp, + lib, + version ? null, +}: mkCoqDerivation { - namePrefix = [ "coq" "mathcomp" ]; + namePrefix = [ + "coq" + "mathcomp" + ]; pname = "finmap"; owner = "math-comp"; inherit version; - defaultVersion = with lib.versions; lib.switch [ coq.version mathcomp.version ] [ - { cases = [ (range "8.16" "8.20") (isGe "2.0") ]; out = "2.1.0"; } - { cases = [ (range "8.16" "8.18") (range "2.0" "2.1") ]; out = "2.0.0"; } - { cases = [ (range "8.13" "8.20") (range "1.12" "1.19") ]; out = "1.5.2"; } - { cases = [ (isGe "8.10") (range "1.11" "1.17") ]; out = "1.5.1"; } - { cases = [ (range "8.7" "8.11") "1.11.0" ]; out = "1.5.0"; } - { cases = [ (isEq "8.11") (range "1.8" "1.10") ]; out = "1.4.0+coq-8.11"; } - { cases = [ (range "8.7" "8.11.0") (range "1.8" "1.10") ]; out = "1.4.0"; } - { cases = [ (range "8.7" "8.11.0") (range "1.8" "1.10") ]; out = "1.3.4"; } - { cases = [ (range "8.7" "8.9") "1.7.0" ]; out = "1.1.0"; } - { cases = [ (range "8.6" "8.7") (range "1.6.1" "1.7") ]; out = "1.0.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.version mathcomp.version ] + [ + { + cases = [ + (range "8.16" "8.20") + (isGe "2.0") + ]; + out = "2.1.0"; + } + { + cases = [ + (range "8.16" "8.18") + (range "2.0" "2.1") + ]; + out = "2.0.0"; + } + { + cases = [ + (range "8.13" "8.20") + (range "1.12" "1.19") + ]; + out = "1.5.2"; + } + { + cases = [ + (isGe "8.10") + (range "1.11" "1.17") + ]; + out = "1.5.1"; + } + { + cases = [ + (range "8.7" "8.11") + "1.11.0" + ]; + out = "1.5.0"; + } + { + cases = [ + (isEq "8.11") + (range "1.8" "1.10") + ]; + out = "1.4.0+coq-8.11"; + } + { + cases = [ + (range "8.7" "8.11.0") + (range "1.8" "1.10") + ]; + out = "1.4.0"; + } + { + cases = [ + (range "8.7" "8.11.0") + (range "1.8" "1.10") + ]; + out = "1.3.4"; + } + { + cases = [ + (range "8.7" "8.9") + "1.7.0" + ]; + out = "1.1.0"; + } + { + cases = [ + (range "8.6" "8.7") + (range "1.6.1" "1.7") + ]; + out = "1.0.0"; + } + ] + null; release = { - "2.1.0".sha256 = "sha256-gh0cnhdVDyo+D5zdtxLc10kGKQLQ3ITzHnMC45mCtpY="; - "2.0.0".sha256 = "sha256-0Wr1ZUYVuZH74vawO4EZlZ+K3kq+s1xEz/BfzyKj+wk="; - "1.5.2".sha256 = "sha256-0KmmSjc2AlUo6BKr9RZ4FjL9wlGISlTGU0X1Eu7l4sw="; - "1.5.1".sha256 = "0ryfml4pf1dfya16d8ma80favasmrygvspvb923n06kfw9v986j7"; - "1.5.0".sha256 = "0vx9n1fi23592b3hv5p5ycy7mxc8qh1y5q05aksfwbzkk5zjkwnq"; - "1.4.1".sha256 = "0kx4nx24dml1igk0w0qijmw221r5bgxhwhl5qicnxp7ab3c35s8p"; + "2.1.0".sha256 = "sha256-gh0cnhdVDyo+D5zdtxLc10kGKQLQ3ITzHnMC45mCtpY="; + "2.0.0".sha256 = "sha256-0Wr1ZUYVuZH74vawO4EZlZ+K3kq+s1xEz/BfzyKj+wk="; + "1.5.2".sha256 = "sha256-0KmmSjc2AlUo6BKr9RZ4FjL9wlGISlTGU0X1Eu7l4sw="; + "1.5.1".sha256 = "0ryfml4pf1dfya16d8ma80favasmrygvspvb923n06kfw9v986j7"; + "1.5.0".sha256 = "0vx9n1fi23592b3hv5p5ycy7mxc8qh1y5q05aksfwbzkk5zjkwnq"; + "1.4.1".sha256 = "0kx4nx24dml1igk0w0qijmw221r5bgxhwhl5qicnxp7ab3c35s8p"; "1.4.0+coq-8.11".sha256 = "1fd00ihyx0kzq5fblh9vr8s5mr1kg7p6pk11c4gr8svl1n69ppmb"; - "1.4.0".sha256 = "0mp82mcmrs424ff1vj3cvd8353r9vcap027h3p0iprr1vkkwjbzd"; - "1.3.4".sha256 = "0f5a62ljhixy5d7gsnwd66gf054l26k3m79fb8nz40i2mgp6l9ii"; - "1.2.1".sha256 = "0jryb5dq8js3imbmwrxignlk5zh8gwfb1wr4b1s7jbwz410vp7zf"; - "1.1.0".sha256 = "05df59v3na8jhpsfp7hq3niam6asgcaipg2wngnzxzqnl86srp2a"; - "1.0.0".sha256 = "0sah7k9qm8sw17cgd02f0x84hki8vj8kdz7h15i7rmz08rj0whpa"; + "1.4.0".sha256 = "0mp82mcmrs424ff1vj3cvd8353r9vcap027h3p0iprr1vkkwjbzd"; + "1.3.4".sha256 = "0f5a62ljhixy5d7gsnwd66gf054l26k3m79fb8nz40i2mgp6l9ii"; + "1.2.1".sha256 = "0jryb5dq8js3imbmwrxignlk5zh8gwfb1wr4b1s7jbwz410vp7zf"; + "1.1.0".sha256 = "05df59v3na8jhpsfp7hq3niam6asgcaipg2wngnzxzqnl86srp2a"; + "1.0.0".sha256 = "0sah7k9qm8sw17cgd02f0x84hki8vj8kdz7h15i7rmz08rj0whpa"; }; propagatedBuildInputs = [ mathcomp.ssreflect ]; diff --git a/pkgs/development/coq-modules/mathcomp-infotheo/default.nix b/pkgs/development/coq-modules/mathcomp-infotheo/default.nix index 48ad46d9177093..3c5bc6df6b4ea7 100644 --- a/pkgs/development/coq-modules/mathcomp-infotheo/default.nix +++ b/pkgs/development/coq-modules/mathcomp-infotheo/default.nix @@ -1,20 +1,79 @@ -{ coq, mkCoqDerivation, mathcomp-analysis, mathcomp-analysis-stdlib, mathcomp-algebra-tactics, interval, lib, version ? null }: +{ + coq, + mkCoqDerivation, + mathcomp-analysis, + mathcomp-analysis-stdlib, + mathcomp-algebra-tactics, + interval, + lib, + version ? null, +}: (mkCoqDerivation { - namePrefix = [ "coq" "mathcomp" ]; + namePrefix = [ + "coq" + "mathcomp" + ]; pname = "infotheo"; owner = "affeldt-aist"; inherit version; - defaultVersion = with lib.versions; lib.switch [ coq.version mathcomp-analysis.version] [ - { cases = [ (range "8.19" "8.20") (isGe "1.7") ]; out = "0.7.5"; } - { cases = [ (range "8.18" "8.20") (isGe "1.5") ]; out = "0.7.3"; } - { cases = [ (range "8.18" "8.19") (isGe "1.2") ]; out = "0.7.2"; } - { cases = [ (range "8.17" "8.19") (isGe "1.0") ]; out = "0.7.1"; } - { cases = [ (isGe "8.17") (range "0.6.6" "0.7.0") ]; out = "0.6.1"; } - { cases = [ (range "8.17" "8.18") (range "0.6.0" "0.6.7") ]; out = "0.5.2"; } - { cases = [ (range "8.15" "8.16") (range "0.5.4" "0.6.5") ]; out = "0.5.1"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.version mathcomp-analysis.version ] + [ + { + cases = [ + (range "8.19" "8.20") + (isGe "1.7") + ]; + out = "0.7.5"; + } + { + cases = [ + (range "8.18" "8.20") + (isGe "1.5") + ]; + out = "0.7.3"; + } + { + cases = [ + (range "8.18" "8.19") + (isGe "1.2") + ]; + out = "0.7.2"; + } + { + cases = [ + (range "8.17" "8.19") + (isGe "1.0") + ]; + out = "0.7.1"; + } + { + cases = [ + (isGe "8.17") + (range "0.6.6" "0.7.0") + ]; + out = "0.6.1"; + } + { + cases = [ + (range "8.17" "8.18") + (range "0.6.0" "0.6.7") + ]; + out = "0.5.2"; + } + { + cases = [ + (range "8.15" "8.16") + (range "0.5.4" "0.6.5") + ]; + out = "0.5.1"; + } + ] + null; release."0.7.5".sha256 = "sha256-pzPo+Acjx3vlyqOkSZQ8uT2BDLSTfbAnRm39e+/CqE0="; release."0.7.3".sha256 = "sha256-7+qPtE1KfDmo9ZsQtWMzoR2MYnFpTjFHK/yZYVm+GxA="; release."0.7.2".sha256 = "sha256-dekrdVmuTcqXXmKhIb831EKtMhbPrXHJZhzmGb9rdRo="; @@ -29,9 +88,10 @@ description = "Coq formalization of information theory and linear error-correcting codes"; license = licenses.lgpl21Plus; }; -}).overrideAttrs (o: { - propagatedBuildInputs = o.propagatedBuildInputs - ++ lib.optional (lib.versions.isGe "0.6.1" o.version || o.version == "dev") mathcomp-algebra-tactics - ++ lib.optional (lib.versions.isGe "0.7.2" o.version || o.version == "dev") interval - ; -}) +}).overrideAttrs + (o: { + propagatedBuildInputs = + o.propagatedBuildInputs + ++ lib.optional (lib.versions.isGe "0.6.1" o.version || o.version == "dev") mathcomp-algebra-tactics + ++ lib.optional (lib.versions.isGe "0.7.2" o.version || o.version == "dev") interval; + }) diff --git a/pkgs/development/coq-modules/mathcomp-real-closed/default.nix b/pkgs/development/coq-modules/mathcomp-real-closed/default.nix index 987990429f37a9..07d0f15f3e7092 100644 --- a/pkgs/development/coq-modules/mathcomp-real-closed/default.nix +++ b/pkgs/development/coq-modules/mathcomp-real-closed/default.nix @@ -1,9 +1,18 @@ -{ coq, mkCoqDerivation, mathcomp, mathcomp-bigenough, - lib, version ? null }: +{ + coq, + mkCoqDerivation, + mathcomp, + mathcomp-bigenough, + lib, + version ? null, +}: mkCoqDerivation { - namePrefix = [ "coq" "mathcomp" ]; + namePrefix = [ + "coq" + "mathcomp" + ]; pname = "real-closed"; owner = "math-comp"; inherit version; @@ -20,17 +29,76 @@ mkCoqDerivation { "1.0.1".sha256 = "0j81gkjbza5vg89v4n9z598mfdbql416963rj4b8fzm7dp2r4rxg"; }; - defaultVersion = with lib.versions; lib.switch [ coq.version mathcomp.version ] [ - { cases = [ (isGe "8.17") (isGe "2.0.0") ]; out = "2.0.1"; } - { cases = [ (range "8.16" "8.19") (range "2.0.0" "2.2.0") ]; out = "2.0.0"; } - { cases = [ (range "8.13" "8.19") (range "1.13.0" "1.19.0") ]; out = "1.1.4"; } - { cases = [ (isGe "8.13") (range "1.12.0" "1.18.0") ]; out = "1.1.3"; } - { cases = [ (isGe "8.10") (range "1.12.0" "1.18.0") ]; out = "1.1.2"; } - { cases = [ (isGe "8.7") "1.11.0" ]; out = "1.1.1"; } - { cases = [ (isGe "8.7") (range "1.9.0" "1.10.0") ]; out = "1.0.4"; } - { cases = [ (isGe "8.7") "1.8.0" ]; out = "1.0.3"; } - { cases = [ (isGe "8.7") "1.7.0" ]; out = "1.0.1"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.version mathcomp.version ] + [ + { + cases = [ + (isGe "8.17") + (isGe "2.0.0") + ]; + out = "2.0.1"; + } + { + cases = [ + (range "8.16" "8.19") + (range "2.0.0" "2.2.0") + ]; + out = "2.0.0"; + } + { + cases = [ + (range "8.13" "8.19") + (range "1.13.0" "1.19.0") + ]; + out = "1.1.4"; + } + { + cases = [ + (isGe "8.13") + (range "1.12.0" "1.18.0") + ]; + out = "1.1.3"; + } + { + cases = [ + (isGe "8.10") + (range "1.12.0" "1.18.0") + ]; + out = "1.1.2"; + } + { + cases = [ + (isGe "8.7") + "1.11.0" + ]; + out = "1.1.1"; + } + { + cases = [ + (isGe "8.7") + (range "1.9.0" "1.10.0") + ]; + out = "1.0.4"; + } + { + cases = [ + (isGe "8.7") + "1.8.0" + ]; + out = "1.0.3"; + } + { + cases = [ + (isGe "8.7") + "1.7.0" + ]; + out = "1.0.1"; + } + ] + null; propagatedBuildInputs = [ mathcomp.ssreflect diff --git a/pkgs/development/coq-modules/mathcomp-tarjan/default.nix b/pkgs/development/coq-modules/mathcomp-tarjan/default.nix index 81951246683055..945c63657d97f9 100644 --- a/pkgs/development/coq-modules/mathcomp-tarjan/default.nix +++ b/pkgs/development/coq-modules/mathcomp-tarjan/default.nix @@ -1,24 +1,58 @@ -{ coq, mkCoqDerivation, mathcomp-ssreflect, mathcomp-fingroup, - lib, version ? null }@args: +{ + coq, + mkCoqDerivation, + mathcomp-ssreflect, + mathcomp-fingroup, + lib, + version ? null, +}@args: mkCoqDerivation { - namePrefix = [ "coq" "mathcomp" ]; + namePrefix = [ + "coq" + "mathcomp" + ]; pname = "tarjan"; owner = "math-comp"; inherit version; - defaultVersion = with lib.versions; - lib.switch [ coq.version mathcomp-ssreflect.version ] [ - { cases = [ (range "8.16" "8.20") (isGe "2.0.0") ]; out = "1.0.2"; } - { cases = [ (range "8.12" "8.18") (range "1.12.0" "1.17.0") ]; out = "1.0.1"; } - { cases = [ (range "8.10" "8.16") (range "1.12.0" "1.17.0") ]; out = "1.0.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.version mathcomp-ssreflect.version ] + [ + { + cases = [ + (range "8.16" "8.20") + (isGe "2.0.0") + ]; + out = "1.0.2"; + } + { + cases = [ + (range "8.12" "8.18") + (range "1.12.0" "1.17.0") + ]; + out = "1.0.1"; + } + { + cases = [ + (range "8.10" "8.16") + (range "1.12.0" "1.17.0") + ]; + out = "1.0.0"; + } + ] + null; release."1.0.2".sha256 = "sha256-U20xgA+e9KTRdvILD1cxN6ia+dlA8uBTIbc4QlKz9ss="; release."1.0.1".sha256 = "sha256-utNjFCAqC5xOuhdyKhfMZkRYJD0xv9Gt6U3ZdQ56mek="; release."1.0.0".sha256 = "sha256:0r459r0makshzwlygw6kd4lpvdjc43b3x5y9aa8x77f2z5gymjq1"; - propagatedBuildInputs = [ mathcomp-ssreflect mathcomp-fingroup ]; + propagatedBuildInputs = [ + mathcomp-ssreflect + mathcomp-fingroup + ]; meta = { description = "Proofs of Tarjan and Kosaraju connected components algorithms"; diff --git a/pkgs/development/coq-modules/mathcomp-word/default.nix b/pkgs/development/coq-modules/mathcomp-word/default.nix index 99d0a96cf79807..8e6825979be19d 100644 --- a/pkgs/development/coq-modules/mathcomp-word/default.nix +++ b/pkgs/development/coq-modules/mathcomp-word/default.nix @@ -1,16 +1,39 @@ -{ fetchurl, coq, mkCoqDerivation, mathcomp, lib, version ? null }: +{ + fetchurl, + coq, + mkCoqDerivation, + mathcomp, + lib, + version ? null, +}: let - namePrefix = [ "coq" "mathcomp" ]; + namePrefix = [ + "coq" + "mathcomp" + ]; pname = "word"; - fetcher = { domain, owner, repo, rev, sha256 ? null, ...}: - let prefix = "https://${domain}/${owner}/${repo}/"; in + fetcher = + { + domain, + owner, + repo, + rev, + sha256 ? null, + ... + }: + let + prefix = "https://${domain}/${owner}/${repo}/"; + in if sha256 == null then - fetchTarball { url = "${prefix}archive/refs/heads/${rev}.tar.gz"; } else - fetchurl { - url = "${prefix}releases/download/${rev}/${lib.concatStringsSep "-" (namePrefix ++ [ pname ])}-${rev}.tbz"; - inherit sha256; - }; + fetchTarball { url = "${prefix}archive/refs/heads/${rev}.tar.gz"; } + else + fetchurl { + url = "${prefix}releases/download/${rev}/${ + lib.concatStringsSep "-" (namePrefix ++ [ pname ]) + }-${rev}.tbz"; + inherit sha256; + }; in mkCoqDerivation { @@ -31,12 +54,33 @@ mkCoqDerivation { release."2.0".sha256 = "sha256-ySg3AviGGY5jXqqn1cP6lTw3aS5DhawXEwNUgj7pIjA="; inherit version; - defaultVersion = with lib.versions; lib.switch [ coq.version mathcomp.version ] [ - { cases = [ (range "8.16" "8.20") (isGe "2.0") ]; out = "3.2"; } - { cases = [ (range "8.12" "8.20") (range "1.12" "1.19") ]; out = "2.4"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.version mathcomp.version ] + [ + { + cases = [ + (range "8.16" "8.20") + (isGe "2.0") + ]; + out = "3.2"; + } + { + cases = [ + (range "8.12" "8.20") + (range "1.12" "1.19") + ]; + out = "2.4"; + } + ] + null; - propagatedBuildInputs = [ mathcomp.algebra mathcomp.ssreflect mathcomp.fingroup ]; + propagatedBuildInputs = [ + mathcomp.algebra + mathcomp.ssreflect + mathcomp.fingroup + ]; meta = with lib; { description = "Yet Another Coq Library on Machine Words"; diff --git a/pkgs/development/coq-modules/mathcomp-zify/default.nix b/pkgs/development/coq-modules/mathcomp-zify/default.nix index 84f5e718ed0501..d6be076ba47033 100644 --- a/pkgs/development/coq-modules/mathcomp-zify/default.nix +++ b/pkgs/development/coq-modules/mathcomp-zify/default.nix @@ -1,25 +1,62 @@ -{ lib, mkCoqDerivation, coq, mathcomp-algebra, mathcomp-ssreflect, mathcomp-fingroup, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + mathcomp-algebra, + mathcomp-ssreflect, + mathcomp-fingroup, + version ? null, +}: mkCoqDerivation rec { - namePrefix = [ "coq" "mathcomp" ]; + namePrefix = [ + "coq" + "mathcomp" + ]; pname = "zify"; repo = "mczify"; owner = "math-comp"; inherit version; - defaultVersion = with lib.versions; - lib.switch [ coq.coq-version mathcomp-algebra.version ] [ - { cases = [ (range "8.16" "8.20") (isGe "2.0.0") ]; out = "1.5.0+2.0+8.16"; } - { cases = [ (range "8.13" "8.20") (range "1.12" "1.19.0") ]; out = "1.3.0+1.12+8.13"; } - { cases = [ (range "8.13" "8.16") (range "1.12" "1.17.0") ]; out = "1.1.0+1.12+8.13"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.coq-version mathcomp-algebra.version ] + [ + { + cases = [ + (range "8.16" "8.20") + (isGe "2.0.0") + ]; + out = "1.5.0+2.0+8.16"; + } + { + cases = [ + (range "8.13" "8.20") + (range "1.12" "1.19.0") + ]; + out = "1.3.0+1.12+8.13"; + } + { + cases = [ + (range "8.13" "8.16") + (range "1.12" "1.17.0") + ]; + out = "1.1.0+1.12+8.13"; + } + ] + null; release."1.0.0+1.12+8.13".sha256 = "1j533vx6lacr89bj1bf15l1a0s7rvrx4l00wyjv99aczkfbz6h6k"; release."1.1.0+1.12+8.13".sha256 = "1plf4v6q5j7wvmd5gsqlpiy0vwlw6hy5daq2x42gqny23w9mi2pr"; release."1.3.0+1.12+8.13".sha256 = "sha256-ebfY8HatP4te44M6o84DSLpDCkMu4IroPCy+HqzOnTE="; release."1.5.0+2.0+8.16".sha256 = "sha256-boBYGvXdGFc6aPnjgSZYSoW4kmN5khtNrSV3DUv9DqM="; - propagatedBuildInputs = [ mathcomp-algebra mathcomp-ssreflect mathcomp-fingroup ]; + propagatedBuildInputs = [ + mathcomp-algebra + mathcomp-ssreflect + mathcomp-fingroup + ]; meta = { description = "Micromega tactics for Mathematical Components"; diff --git a/pkgs/development/coq-modules/metacoq/default.nix b/pkgs/development/coq-modules/metacoq/default.nix index 9452ac977b6fbd..15c83514cce248 100644 --- a/pkgs/development/coq-modules/metacoq/default.nix +++ b/pkgs/development/coq-modules/metacoq/default.nix @@ -1,23 +1,55 @@ -{ lib, - mkCoqDerivation, single ? false, - coq, equations, version ? null }@args: +{ + lib, + mkCoqDerivation, + single ? false, + coq, + equations, + version ? null, +}@args: let - repo = "metacoq"; + repo = "metacoq"; owner = "MetaCoq"; defaultVersion = lib.switch coq.coq-version [ - { case = "8.11"; out = "1.0-beta2-8.11"; } - { case = "8.12"; out = "1.0-beta2-8.12"; } - # Do not provide 8.13 because it does not compile with equations 1.3 provided by default (only 1.2.3) - # { case = "8.13"; out = "1.0-beta2-8.13"; } - { case = "8.14"; out = "1.1-8.14"; } - { case = "8.15"; out = "1.1-8.15"; } - { case = "8.16"; out = "1.1-8.16"; } - { case = "8.17"; out = "1.3.1-8.17"; } - { case = "8.18"; out = "1.3.1-8.18"; } - { case = "8.19"; out = "1.3.2-8.19"; } - { case = "8.20"; out = "1.3.2-8.20"; } - ] null; + { + case = "8.11"; + out = "1.0-beta2-8.11"; + } + { + case = "8.12"; + out = "1.0-beta2-8.12"; + } + # Do not provide 8.13 because it does not compile with equations 1.3 provided by default (only 1.2.3) + # { case = "8.13"; out = "1.0-beta2-8.13"; } + { + case = "8.14"; + out = "1.1-8.14"; + } + { + case = "8.15"; + out = "1.1-8.15"; + } + { + case = "8.16"; + out = "1.1-8.16"; + } + { + case = "8.17"; + out = "1.3.1-8.17"; + } + { + case = "8.18"; + out = "1.3.1-8.18"; + } + { + case = "8.19"; + out = "1.3.2-8.19"; + } + { + case = "8.20"; + out = "1.3.2-8.20"; + } + ] null; release = { "1.0-beta2-8.11".sha256 = "sha256-I9YNk5Di6Udvq5/xpLSNflfjRyRH8fMnRzbo3uhpXNs="; "1.0-beta2-8.12".sha256 = "sha256-I8gpmU9rUQJh0qfp5KOgDNscVvCybm5zX4TINxO1TVA="; @@ -40,92 +72,177 @@ let # list of core metacoq packages and their dependencies packages = { - "utils" = []; - "common" = [ "utils" ]; - "template-coq" = [ "common" ]; - "pcuic" = if (lib.versionAtLeast coq.coq-version "8.17" || coq.coq-version == "dev") - then [ "common" ] - else [ "template-coq" ]; - "safechecker" = [ "pcuic" ]; - "template-pcuic" = [ "template-coq" "pcuic" ]; - "erasure" = [ "safechecker" "template-pcuic" ]; - "quotation" = [ "template-coq" "pcuic" "template-pcuic" ]; - "safechecker-plugin" = [ "template-pcuic" "safechecker" ]; - "erasure-plugin" = [ "template-pcuic" "erasure" ]; - "translations" = [ "template-coq" ]; - "all" = [ "safechecker-plugin" "erasure-plugin" "translations" "quotation" ]; + "utils" = [ ]; + "common" = [ "utils" ]; + "template-coq" = [ "common" ]; + "pcuic" = + if (lib.versionAtLeast coq.coq-version "8.17" || coq.coq-version == "dev") then + [ "common" ] + else + [ "template-coq" ]; + "safechecker" = [ "pcuic" ]; + "template-pcuic" = [ + "template-coq" + "pcuic" + ]; + "erasure" = [ + "safechecker" + "template-pcuic" + ]; + "quotation" = [ + "template-coq" + "pcuic" + "template-pcuic" + ]; + "safechecker-plugin" = [ + "template-pcuic" + "safechecker" + ]; + "erasure-plugin" = [ + "template-pcuic" + "erasure" + ]; + "translations" = [ "template-coq" ]; + "all" = [ + "safechecker-plugin" + "erasure-plugin" + "translations" + "quotation" + ]; }; template-coq = metacoq_ "template-coq"; - metacoq_ = package: let + metacoq_ = + package: + let metacoq-deps = lib.optionals (package != "single") (map metacoq_ packages.${package}); pkgpath = if package == "single" then "./" else "./${package}"; pname = if package == "all" then "metacoq" else "metacoq-${package}"; pkgallMake = '' - mkdir all - echo "all:" > all/Makefile - echo "install:" >> all/Makefile - '' ; - derivation = (mkCoqDerivation ({ - inherit version pname defaultVersion release releaseRev repo owner; + mkdir all + echo "all:" > all/Makefile + echo "install:" >> all/Makefile + ''; + derivation = + (mkCoqDerivation ( + { + inherit + version + pname + defaultVersion + release + releaseRev + repo + owner + ; - mlPlugin = true; - propagatedBuildInputs = [ equations coq.ocamlPackages.zarith ] ++ metacoq-deps; + mlPlugin = true; + propagatedBuildInputs = [ + equations + coq.ocamlPackages.zarith + ] ++ metacoq-deps; - patchPhase = if lib.versionAtLeast coq.coq-version "8.17" || coq.coq-version == "dev" then '' - patchShebangs ./configure.sh - patchShebangs ./template-coq/update_plugin.sh - patchShebangs ./template-coq/gen-src/to-lower.sh - patchShebangs ./safechecker-plugin/clean_extraction.sh - patchShebangs ./erasure-plugin/clean_extraction.sh - echo "CAMLFLAGS+=-w -60 # Unused module" >> ./safechecker/Makefile.plugin.local - sed -i -e 's/mv $i $newi;/mv $i tmp; mv tmp $newi;/' ./template-coq/gen-src/to-lower.sh ./safechecker-plugin/clean_extraction.sh ./erasure-plugin/clean_extraction.sh - '' else '' - patchShebangs ./configure.sh - patchShebangs ./template-coq/update_plugin.sh - patchShebangs ./template-coq/gen-src/to-lower.sh - patchShebangs ./pcuic/clean_extraction.sh - patchShebangs ./safechecker/clean_extraction.sh - patchShebangs ./erasure/clean_extraction.sh - echo "CAMLFLAGS+=-w -60 # Unused module" >> ./safechecker/Makefile.plugin.local - sed -i -e 's/mv $i $newi;/mv $i tmp; mv tmp $newi;/' ./template-coq/gen-src/to-lower.sh ./pcuic/clean_extraction.sh ./safechecker/clean_extraction.sh ./erasure/clean_extraction.sh - '' ; + patchPhase = + if lib.versionAtLeast coq.coq-version "8.17" || coq.coq-version == "dev" then + '' + patchShebangs ./configure.sh + patchShebangs ./template-coq/update_plugin.sh + patchShebangs ./template-coq/gen-src/to-lower.sh + patchShebangs ./safechecker-plugin/clean_extraction.sh + patchShebangs ./erasure-plugin/clean_extraction.sh + echo "CAMLFLAGS+=-w -60 # Unused module" >> ./safechecker/Makefile.plugin.local + sed -i -e 's/mv $i $newi;/mv $i tmp; mv tmp $newi;/' ./template-coq/gen-src/to-lower.sh ./safechecker-plugin/clean_extraction.sh ./erasure-plugin/clean_extraction.sh + '' + else + '' + patchShebangs ./configure.sh + patchShebangs ./template-coq/update_plugin.sh + patchShebangs ./template-coq/gen-src/to-lower.sh + patchShebangs ./pcuic/clean_extraction.sh + patchShebangs ./safechecker/clean_extraction.sh + patchShebangs ./erasure/clean_extraction.sh + echo "CAMLFLAGS+=-w -60 # Unused module" >> ./safechecker/Makefile.plugin.local + sed -i -e 's/mv $i $newi;/mv $i tmp; mv tmp $newi;/' ./template-coq/gen-src/to-lower.sh ./pcuic/clean_extraction.sh ./safechecker/clean_extraction.sh ./erasure/clean_extraction.sh + ''; - configurePhase = lib.optionalString (package == "all") pkgallMake + '' - touch ${pkgpath}/metacoq-config - '' + lib.optionalString (lib.elem package ["erasure" "template-pcuic" "quotation" "safechecker-plugin" "erasure-plugin" "translations"]) '' - echo "-I ${template-coq}/lib/coq/${coq.coq-version}/user-contrib/MetaCoq/Template/" > ${pkgpath}/metacoq-config - '' + lib.optionalString (package == "single") '' - ./configure.sh local - ''; + configurePhase = + lib.optionalString (package == "all") pkgallMake + + '' + touch ${pkgpath}/metacoq-config + '' + + + lib.optionalString + (lib.elem package [ + "erasure" + "template-pcuic" + "quotation" + "safechecker-plugin" + "erasure-plugin" + "translations" + ]) + '' + echo "-I ${template-coq}/lib/coq/${coq.coq-version}/user-contrib/MetaCoq/Template/" > ${pkgpath}/metacoq-config + '' + + lib.optionalString (package == "single") '' + ./configure.sh local + ''; - preBuild = '' - cd ${pkgpath} - '' ; + preBuild = '' + cd ${pkgpath} + ''; - meta = { - homepage = "https://metacoq.github.io/"; - license = lib.licenses.mit; - maintainers = with lib.maintainers; [ cohencyril ]; - }; - } // lib.optionalAttrs (package != "single") - { passthru = lib.mapAttrs (package: deps: metacoq_ package) packages; }) - ).overrideAttrs (o: - let requiresOcamlStdlibShims = lib.versionAtLeast o.version "1.0-8.16" || - (o.version == "dev" && (lib.versionAtLeast coq.coq-version "8.16" || coq.coq-version == "dev")) ; - in - { - propagatedBuildInputs = o.propagatedBuildInputs ++ lib.optional requiresOcamlStdlibShims coq.ocamlPackages.stdlib-shims; - }); + meta = { + homepage = "https://metacoq.github.io/"; + license = lib.licenses.mit; + maintainers = with lib.maintainers; [ cohencyril ]; + }; + } + // lib.optionalAttrs (package != "single") { + passthru = lib.mapAttrs (package: deps: metacoq_ package) packages; + } + )).overrideAttrs + ( + o: + let + requiresOcamlStdlibShims = + lib.versionAtLeast o.version "1.0-8.16" + || (o.version == "dev" && (lib.versionAtLeast coq.coq-version "8.16" || coq.coq-version == "dev")); + in + { + propagatedBuildInputs = + o.propagatedBuildInputs + ++ lib.optional requiresOcamlStdlibShims coq.ocamlPackages.stdlib-shims; + } + ); # utils, common, template-pcuic, quotation, safechecker-plugin, and erasure-plugin # packages didn't exist before 1.2, so bulding nothing in that case - patched-derivation = derivation.overrideAttrs (o: - lib.optionalAttrs (o.pname != null && - lib.elem package [ "utils" "common" "template-pcuic" "quotation" "safechecker-plugin" "erasure-plugin" ] && - o.version != null && o.version != "dev" && lib.versions.isLt "1.2" o.version) - { patchPhase = ""; configurePhase = ""; preBuild = ""; buildPhase = "echo doing nothing"; installPhase = "echo doing nothing"; } + patched-derivation = derivation.overrideAttrs ( + o: + lib.optionalAttrs + ( + o.pname != null + && lib.elem package [ + "utils" + "common" + "template-pcuic" + "quotation" + "safechecker-plugin" + "erasure-plugin" + ] + && o.version != null + && o.version != "dev" + && lib.versions.isLt "1.2" o.version + ) + { + patchPhase = ""; + configurePhase = ""; + preBuild = ""; + buildPhase = "echo doing nothing"; + installPhase = "echo doing nothing"; + } ); - in patched-derivation; + in + patched-derivation; in metacoq_ (if single then "single" else "all") diff --git a/pkgs/development/coq-modules/metalib/default.nix b/pkgs/development/coq-modules/metalib/default.nix index 144b95cbebd433..a8a889e999b83a 100644 --- a/pkgs/development/coq-modules/metalib/default.nix +++ b/pkgs/development/coq-modules/metalib/default.nix @@ -1,13 +1,26 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: (mkCoqDerivation { pname = "metalib"; owner = "plclub"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.14" "8.18"; out = "8.15"; } - { case = range "8.10" "8.13"; out = "8.10"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.14" "8.18"; + out = "8.15"; + } + { + case = range "8.10" "8.13"; + out = "8.10"; + } + ] null; releaseRev = v: "coq${v}"; release."8.15".sha256 = "0wbp058zwa4bkdjj38aysy2g1avf9nrh8q23a3dil0q00qczi616"; release."8.10".sha256 = "0wbypc05d2lqfm9qaw98ynr5yc1p0ipsvyc3bh1rk9nz7zwirmjs"; @@ -16,6 +29,7 @@ license = licenses.mit; maintainers = [ maintainers.jwiegley ]; }; -}).overrideAttrs (oldAttrs: { - sourceRoot = "${oldAttrs.src.name}/Metalib"; -}) +}).overrideAttrs + (oldAttrs: { + sourceRoot = "${oldAttrs.src.name}/Metalib"; + }) diff --git a/pkgs/development/coq-modules/mtac2/default.nix b/pkgs/development/coq-modules/mtac2/default.nix index 8c2a96b4d78152..eed638c269e432 100644 --- a/pkgs/development/coq-modules/mtac2/default.nix +++ b/pkgs/development/coq-modules/mtac2/default.nix @@ -1,12 +1,23 @@ -{ lib, mkCoqDerivation, coq, unicoq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + unicoq, + version ? null, +}: mkCoqDerivation { pname = "Mtac2"; owner = "Mtac2"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = range "8.19" "8.19"; out = "1.4-coq${coq.coq-version}"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.19" "8.19"; + out = "1.4-coq${coq.coq-version}"; + } + ] null; release."1.4-coq8.19".sha256 = "sha256-G9eK0eLyECdT20/yf8yyz7M8Xq2WnHHaHpxVGP0yTtU="; releaseRev = v: "v${v}"; mlPlugin = true; diff --git a/pkgs/development/coq-modules/multinomials/default.nix b/pkgs/development/coq-modules/multinomials/default.nix index 6b61d9545f8808..78e8150aa01040 100644 --- a/pkgs/development/coq-modules/multinomials/default.nix +++ b/pkgs/development/coq-modules/multinomials/default.nix @@ -1,26 +1,108 @@ -{ coq, mkCoqDerivation, mathcomp, mathcomp-finmap, mathcomp-bigenough, - lib, version ? null, useDune ? false }@args: - mkCoqDerivation { +{ + coq, + mkCoqDerivation, + mathcomp, + mathcomp-finmap, + mathcomp-bigenough, + lib, + version ? null, + useDune ? false, +}@args: +mkCoqDerivation { - namePrefix = [ "coq" "mathcomp" ]; + namePrefix = [ + "coq" + "mathcomp" + ]; pname = "multinomials"; owner = "math-comp"; inherit version; - defaultVersion = with lib.versions; lib.switch [ coq.version mathcomp.version ] [ - { cases = [ (range "8.17" "8.20") (isGe "2.1.0") ]; out = "2.2.0"; } - { cases = [ (range "8.16" "8.18") "2.1.0" ]; out = "2.1.0"; } - { cases = [ (range "8.16" "8.18") "2.0.0" ]; out = "2.0.0"; } - { cases = [ (isGe "8.15") (range "1.15.0" "1.19.0") ]; out = "1.6.0"; } - { cases = [ (isGe "8.10") (range "1.13.0" "1.17.0") ]; out = "1.5.6"; } - { cases = [ (range "8.10" "8.16") (range "1.12.0" "1.15.0") ]; out = "1.5.5"; } - { cases = [ (range "8.10" "8.12") "1.12.0" ]; out = "1.5.3"; } - { cases = [ (range "8.7" "8.12") "1.11.0" ]; out = "1.5.2"; } - { cases = [ (range "8.7" "8.11") (range "1.8" "1.10") ]; out = "1.5.0"; } - { cases = [ (range "8.7" "8.10") (range "1.8" "1.10") ]; out = "1.4"; } - { cases = [ "8.6" (range "1.6" "1.7") ]; out = "1.1"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.version mathcomp.version ] + [ + { + cases = [ + (range "8.17" "8.20") + (isGe "2.1.0") + ]; + out = "2.2.0"; + } + { + cases = [ + (range "8.16" "8.18") + "2.1.0" + ]; + out = "2.1.0"; + } + { + cases = [ + (range "8.16" "8.18") + "2.0.0" + ]; + out = "2.0.0"; + } + { + cases = [ + (isGe "8.15") + (range "1.15.0" "1.19.0") + ]; + out = "1.6.0"; + } + { + cases = [ + (isGe "8.10") + (range "1.13.0" "1.17.0") + ]; + out = "1.5.6"; + } + { + cases = [ + (range "8.10" "8.16") + (range "1.12.0" "1.15.0") + ]; + out = "1.5.5"; + } + { + cases = [ + (range "8.10" "8.12") + "1.12.0" + ]; + out = "1.5.3"; + } + { + cases = [ + (range "8.7" "8.12") + "1.11.0" + ]; + out = "1.5.2"; + } + { + cases = [ + (range "8.7" "8.11") + (range "1.8" "1.10") + ]; + out = "1.5.0"; + } + { + cases = [ + (range "8.7" "8.10") + (range "1.8" "1.10") + ]; + out = "1.4"; + } + { + cases = [ + "8.6" + (range "1.6" "1.7") + ]; + out = "1.1"; + } + ] + null; release = { "2.2.0".sha256 = "sha256-Cie6paweITwPZy6ej9+qIvHFWknVR382uJPW927t/fo="; "2.1.0".sha256 = "sha256-QT91SBJ6DXhyg4j/okTvPP6yj2DnnPbnSlJ/p8pvZbY="; @@ -33,12 +115,12 @@ "1.5.2".sha256 = "15aspf3jfykp1xgsxf8knqkxv8aav2p39c2fyirw7pwsfbsv2c4s"; "1.5.1".sha256 = "13nlfm2wqripaq671gakz5mn4r0xwm0646araxv0nh455p9ndjs3"; "1.5.0".sha256 = "064rvc0x5g7y1a0nip6ic91vzmq52alf6in2bc2dmss6dmzv90hw"; - "1.5.0".rev = "1.5"; - "1.4".sha256 = "0vnkirs8iqsv8s59yx1fvg1nkwnzydl42z3scya1xp1b48qkgn0p"; - "1.3".sha256 = "0l3vi5n094nx3qmy66hsv867fnqm196r8v605kpk24gl0aa57wh4"; - "1.2".sha256 = "1mh1w339dslgv4f810xr1b8v2w7rpx6fgk9pz96q0fyq49fw2xcq"; - "1.1".sha256 = "1q8alsm89wkc0lhcvxlyn0pd8rbl2nnxg81zyrabpz610qqjqc3s"; - "1.0".sha256 = "1qmbxp1h81cy3imh627pznmng0kvv37k4hrwi2faa101s6bcx55m"; + "1.5.0".rev = "1.5"; + "1.4".sha256 = "0vnkirs8iqsv8s59yx1fvg1nkwnzydl42z3scya1xp1b48qkgn0p"; + "1.3".sha256 = "0l3vi5n094nx3qmy66hsv867fnqm196r8v605kpk24gl0aa57wh4"; + "1.2".sha256 = "1mh1w339dslgv4f810xr1b8v2w7rpx6fgk9pz96q0fyq49fw2xcq"; + "1.1".sha256 = "1q8alsm89wkc0lhcvxlyn0pd8rbl2nnxg81zyrabpz610qqjqc3s"; + "1.0".sha256 = "1qmbxp1h81cy3imh627pznmng0kvv37k4hrwi2faa101s6bcx55m"; }; useDuneifVersion = lib.versions.range "1.5.3" "2.2.0"; @@ -47,12 +129,17 @@ patchShebangs configure || true ''; - propagatedBuildInputs = - [ mathcomp.ssreflect mathcomp.algebra mathcomp-finmap mathcomp.fingroup mathcomp-bigenough ]; + propagatedBuildInputs = [ + mathcomp.ssreflect + mathcomp.algebra + mathcomp-finmap + mathcomp.fingroup + mathcomp-bigenough + ]; meta = { description = "Coq/SSReflect Library for Monoidal Rings and Multinomials"; license = lib.licenses.cecill-c; }; } -// lib.optionalAttrs (args?useDune) { inherit useDune; } +// lib.optionalAttrs (args ? useDune) { inherit useDune; } diff --git a/pkgs/development/coq-modules/odd-order/default.nix b/pkgs/development/coq-modules/odd-order/default.nix index b6770aa633defd..30082aa3de1215 100644 --- a/pkgs/development/coq-modules/odd-order/default.nix +++ b/pkgs/development/coq-modules/odd-order/default.nix @@ -1,4 +1,9 @@ -{ lib, mkCoqDerivation, mathcomp, version ? null }: +{ + lib, + mkCoqDerivation, + mathcomp, + version ? null, +}: mkCoqDerivation { pname = "odd-order"; @@ -10,11 +15,22 @@ mkCoqDerivation { releaseRev = v: "mathcomp-odd-order.${v}"; inherit version; - defaultVersion = with lib.versions; lib.switch mathcomp.character.version [ - { case = (range "1.13.0" "1.15.0"); out = "1.14.0"; } - { case = (range "1.12.0" "1.14.0"); out = "1.13.0"; } - { case = (range "1.10.0" "1.12.0"); out = "1.12.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch mathcomp.character.version [ + { + case = (range "1.13.0" "1.15.0"); + out = "1.14.0"; + } + { + case = (range "1.12.0" "1.14.0"); + out = "1.13.0"; + } + { + case = (range "1.10.0" "1.12.0"); + out = "1.12.0"; + } + ] null; propagatedBuildInputs = [ mathcomp.character diff --git a/pkgs/development/coq-modules/paco/default.nix b/pkgs/development/coq-modules/paco/default.nix index 80432fa1494ca2..2881e7bab81742 100644 --- a/pkgs/development/coq-modules/paco/default.nix +++ b/pkgs/development/coq-modules/paco/default.nix @@ -1,16 +1,38 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "paco"; owner = "snu-sf"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.13" "8.20"; out = "4.2.0"; } - { case = range "8.12" "8.17"; out = "4.1.2"; } - { case = range "8.9" "8.13"; out = "4.1.1"; } - { case = range "8.6" "8.13"; out = "4.0.2"; } - { case = isEq "8.5"; out = "1.2.8"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.13" "8.20"; + out = "4.2.0"; + } + { + case = range "8.12" "8.17"; + out = "4.1.2"; + } + { + case = range "8.9" "8.13"; + out = "4.1.1"; + } + { + case = range "8.6" "8.13"; + out = "4.0.2"; + } + { + case = isEq "8.5"; + out = "1.2.8"; + } + ] null; release."4.2.0".sha256 = "sha256-YHYtiz9hium96n3owL/C99AjJAFTlTCmmb2+ttevgMY="; release."4.1.2".sha256 = "sha256:1l8mwakqp4wnppsldl8wp2j24h1jvadnvrsgf35xnvdyygypjp2v"; release."4.1.1".sha256 = "1qap8cyv649lr1s11r7h5jzdjd4hsna8kph15qy5fw24h5nx6byy"; @@ -29,6 +51,9 @@ mkCoqDerivation { meta = { homepage = "https://plv.mpi-sws.org/paco/"; description = "Coq library implementing parameterized coinduction"; - maintainers = with lib.maintainers; [ jwiegley ptival ]; + maintainers = with lib.maintainers; [ + jwiegley + ptival + ]; }; } diff --git a/pkgs/development/coq-modules/paramcoq/default.nix b/pkgs/development/coq-modules/paramcoq/default.nix index f8749c89795065..d665b0b4f6051c 100644 --- a/pkgs/development/coq-modules/paramcoq/default.nix +++ b/pkgs/development/coq-modules/paramcoq/default.nix @@ -1,13 +1,28 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "paramcoq"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = range "8.10" "8.20"; out = "1.1.3+coq${coq.coq-version}"; } - { case = range "8.7" "8.13"; out = "1.1.2+coq${coq.coq-version}"; } - ] null; - displayVersion = { paramcoq = "..."; }; + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.10" "8.20"; + out = "1.1.3+coq${coq.coq-version}"; + } + { + case = range "8.7" "8.13"; + out = "1.1.2+coq${coq.coq-version}"; + } + ] null; + displayVersion = { + paramcoq = "..."; + }; release."1.1.3+coq8.20".sha256 = "sha256-34xDOz/2xO39fnQW6Zb9CI2EKFuJZjrAdOpMEmwuzY0="; release."1.1.3+coq8.19".sha256 = "sha256-5NVsdLXaoz6qrr5ra5YfoHeuK4pEf8JX/X9+SZA0U+U="; release."1.1.3+coq8.18".sha256 = "sha256-hNBaj9hB+OzwXsOX+TOXtDLjA5oP4EmEgseLwxFxW+I="; @@ -23,9 +38,9 @@ mkCoqDerivation { release."1.1.2+coq8.12".sha256 = "0qd72r45if4h7c256qdfiimv75zyrs0w0xqij3m866jxaq591v4i"; release."1.1.2+coq8.11".sha256 = "09c6813988nvq4fpa45s33k70plnhxsblhm7cxxkg0i37mhvigsa"; release."1.1.2+coq8.10".sha256 = "1lq1mw15w4yky79qg3rm0mpzqi2ir51b6ak04ismrdr7ixky49y8"; - release."1.1.2+coq8.9".sha256 = "1jjzgpff09xjn9kgp7w69r096jkj0x2ksng3pawrmhmn7clwivbk"; - release."1.1.2+coq8.8".sha256 = "0rc4lshqvnfdsph98gnscvpmlirs9wx91qcvffggg73xw0p1g9s0"; - release."1.1.2+coq8.7".sha256 = "09n0ky7ldb24by7yf5j3hv410h85x50ksilf7qacl7xglj4gy5hj"; + release."1.1.2+coq8.9".sha256 = "1jjzgpff09xjn9kgp7w69r096jkj0x2ksng3pawrmhmn7clwivbk"; + release."1.1.2+coq8.8".sha256 = "0rc4lshqvnfdsph98gnscvpmlirs9wx91qcvffggg73xw0p1g9s0"; + release."1.1.2+coq8.7".sha256 = "09n0ky7ldb24by7yf5j3hv410h85x50ksilf7qacl7xglj4gy5hj"; releaseRev = v: "v${v}"; mlPlugin = true; meta = with lib; { diff --git a/pkgs/development/coq-modules/parsec/default.nix b/pkgs/development/coq-modules/parsec/default.nix index b66baa5358ce63..4f8eeebc15da7d 100644 --- a/pkgs/development/coq-modules/parsec/default.nix +++ b/pkgs/development/coq-modules/parsec/default.nix @@ -1,4 +1,11 @@ -{ lib, mkCoqDerivation, coq, ceres, ExtLib, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + ceres, + ExtLib, + version ? null, +}: mkCoqDerivation { @@ -6,16 +13,33 @@ mkCoqDerivation { repo = "coq-parsec"; owner = "liyishuai"; - propagatedBuildInputs = [ ceres ExtLib ]; + propagatedBuildInputs = [ + ceres + ExtLib + ]; releaseRev = (v: "v${v}"); inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = range "8.14" "8.20"; out = "0.2.0"; } - { case = range "8.14" "8.20"; out = "0.1.2"; } - { case = range "8.12" "8.16"; out = "0.1.1"; } - { case = range "8.12" "8.13"; out = "0.1.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.14" "8.20"; + out = "0.2.0"; + } + { + case = range "8.14" "8.20"; + out = "0.1.2"; + } + { + case = range "8.12" "8.16"; + out = "0.1.1"; + } + { + case = range "8.12" "8.13"; + out = "0.1.0"; + } + ] null; release."0.2.0".sha256 = "sha256-hM6LVFQ2VQ42QeHu8Ex+oz1VvJUr+g8/nZN+bYHEljQ="; release."0.1.2".sha256 = "sha256-QN0h1CsX86DQBDsluXLtNUvMh3r60/0iDSbYam67AhA="; release."0.1.1".sha256 = "sha256:1c0l18s68pzd4c8i3jimh2yz0pqm4g38pca4bm7fr18r8xmqf189"; diff --git a/pkgs/development/coq-modules/pocklington/default.nix b/pkgs/development/coq-modules/pocklington/default.nix index 1ee80e9a4b6e1a..44dff53fb1a7ca 100644 --- a/pkgs/development/coq-modules/pocklington/default.nix +++ b/pkgs/development/coq-modules/pocklington/default.nix @@ -1,16 +1,26 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "pocklington"; owner = "coq-community"; - release."8.12.0".rev = "v8.12.0"; + release."8.12.0".rev = "v8.12.0"; release."8.12.0".sha256 = "sha256-0xBrw9+4g14niYdNqp0nx00fPJoSSnaDSDEaIVpPfjs="; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.7" "8.18"; out = "8.12.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.7" "8.18"; + out = "8.12.0"; + } + ] null; meta = with lib; { description = "Pocklington's criterion for primality in Coq"; diff --git a/pkgs/development/coq-modules/reglang/default.nix b/pkgs/development/coq-modules/reglang/default.nix index cc42c515c09e70..3e95e1b893b107 100644 --- a/pkgs/development/coq-modules/reglang/default.nix +++ b/pkgs/development/coq-modules/reglang/default.nix @@ -1,4 +1,10 @@ -{ lib, mkCoqDerivation, coq, mathcomp, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + mathcomp, + version ? null, +}: mkCoqDerivation { pname = "reglang"; @@ -11,12 +17,34 @@ mkCoqDerivation { release."1.1.2".sha256 = "sha256-SEnMilLNxh6a3oiDNGLaBr8quQ/nO2T9Fwdf/1il2Yk="; inherit version; - defaultVersion = with lib.versions; lib.switch [ coq.coq-version mathcomp.version ] [ - { cases = [ (range "8.16" "8.20") (isGe "2.0.0") ]; out = "1.2.1"; } - { cases = [ (range "8.16" "8.18") (range "2.0.0" "2.1.0") ]; out = "1.2.0"; } - { cases = [ (range "8.10" "8.20") (isLt "2.0.0") ]; out = "1.1.3"; } - ] null; - + defaultVersion = + with lib.versions; + lib.switch + [ coq.coq-version mathcomp.version ] + [ + { + cases = [ + (range "8.16" "8.20") + (isGe "2.0.0") + ]; + out = "1.2.1"; + } + { + cases = [ + (range "8.16" "8.18") + (range "2.0.0" "2.1.0") + ]; + out = "1.2.0"; + } + { + cases = [ + (range "8.10" "8.20") + (isLt "2.0.0") + ]; + out = "1.1.3"; + } + ] + null; propagatedBuildInputs = [ mathcomp.ssreflect ]; diff --git a/pkgs/development/coq-modules/relation-algebra/default.nix b/pkgs/development/coq-modules/relation-algebra/default.nix index 35c26573a82db5..571360d9926f40 100644 --- a/pkgs/development/coq-modules/relation-algebra/default.nix +++ b/pkgs/development/coq-modules/relation-algebra/default.nix @@ -1,13 +1,17 @@ -{ lib, mkCoqDerivation, coq, aac-tactics, mathcomp, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + aac-tactics, + mathcomp, + version ? null, +}: mkCoqDerivation { pname = "relation-algebra"; owner = "damien-pous"; - releaseRev = v: - if lib.versions.range "1.7.6" "1.7.9" v - then "v.${v}" - else "v${v}"; + releaseRev = v: if lib.versions.range "1.7.6" "1.7.9" v then "v.${v}" else "v${v}"; release."1.7.11".sha256 = "sha256-ZOV0lUdduSabW9Qsz70clkO7QK/NK2STaHqBWcXb7nI="; release."1.7.10".sha256 = "sha256-h738L+dybhmWZwTSLJrhv+sB+cIbj0+62Zcy9BH5sVo="; @@ -22,23 +26,61 @@ mkCoqDerivation { release."1.7.1".sha256 = "sha256-WWVMcR6z8rT4wzZPb8SlaVWGe7NC8gScPqawd7bltQA="; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = isEq "8.20"; out = "1.7.11"; } - { case = range "8.18" "8.19"; out = "1.7.10"; } - { case = isEq "8.17"; out = "1.7.9"; } - { case = isEq "8.16"; out = "1.7.8"; } - { case = isEq "8.15"; out = "1.7.7"; } - { case = isEq "8.14"; out = "1.7.6"; } - { case = isEq "8.13"; out = "1.7.5"; } - { case = isEq "8.12"; out = "1.7.4"; } - { case = isEq "8.11"; out = "1.7.3"; } - { case = isEq "8.10"; out = "1.7.2"; } - { case = isEq "8.9"; out = "1.7.1"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = isEq "8.20"; + out = "1.7.11"; + } + { + case = range "8.18" "8.19"; + out = "1.7.10"; + } + { + case = isEq "8.17"; + out = "1.7.9"; + } + { + case = isEq "8.16"; + out = "1.7.8"; + } + { + case = isEq "8.15"; + out = "1.7.7"; + } + { + case = isEq "8.14"; + out = "1.7.6"; + } + { + case = isEq "8.13"; + out = "1.7.5"; + } + { + case = isEq "8.12"; + out = "1.7.4"; + } + { + case = isEq "8.11"; + out = "1.7.3"; + } + { + case = isEq "8.10"; + out = "1.7.2"; + } + { + case = isEq "8.9"; + out = "1.7.1"; + } + ] null; mlPlugin = true; - propagatedBuildInputs = [ aac-tactics mathcomp.ssreflect ]; + propagatedBuildInputs = [ + aac-tactics + mathcomp.ssreflect + ]; meta = with lib; { description = "Relation algebra library for Coq"; diff --git a/pkgs/development/coq-modules/rewriter/default.nix b/pkgs/development/coq-modules/rewriter/default.nix index f5b425cd481134..15644c4dcee05c 100644 --- a/pkgs/development/coq-modules/rewriter/default.nix +++ b/pkgs/development/coq-modules/rewriter/default.nix @@ -1,15 +1,26 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "rewriter"; owner = "mit-plv"; inherit version; - defaultVersion = let inherit (lib.versions) range; in + defaultVersion = + let + inherit (lib.versions) range; + in lib.switch coq.coq-version [ - { case = range "8.17" "8.19"; out = "0.0.11"; } + { + case = range "8.17" "8.19"; + out = "0.0.11"; + } ] null; release = { - "0.0.11".sha256 = "sha256-aYoO08nwItlOoE5BnKRGib2Zk4Fz4Ni/L4QaqkObPow="; + "0.0.11".sha256 = "sha256-aYoO08nwItlOoE5BnKRGib2Zk4Fz4Ni/L4QaqkObPow="; }; releaseRev = v: "v${v}"; diff --git a/pkgs/development/coq-modules/semantics/default.nix b/pkgs/development/coq-modules/semantics/default.nix index 18e9171096d7bb..25e7645fb7c888 100644 --- a/pkgs/development/coq-modules/semantics/default.nix +++ b/pkgs/development/coq-modules/semantics/default.nix @@ -1,4 +1,9 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation rec { pname = "semantics"; @@ -14,13 +19,30 @@ mkCoqDerivation rec { release."8.6.0".sha256 = "sha256-GltkGQ3tJqUPAbdDkqqvKLLhMOap50XvGaCkjshiNdY="; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.10" "8.18"; out = "8.14.0"; } - { case = "8.9"; out = "8.9.0"; } - { case = "8.8"; out = "8.8.0"; } - { case = "8.7"; out = "8.7.0"; } - { case = "8.6"; out = "8.6.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.10" "8.18"; + out = "8.14.0"; + } + { + case = "8.9"; + out = "8.9.0"; + } + { + case = "8.8"; + out = "8.8.0"; + } + { + case = "8.7"; + out = "8.7.0"; + } + { + case = "8.6"; + out = "8.6.0"; + } + ] null; mlPlugin = true; nativeBuildInputs = (with coq.ocamlPackages; [ ocamlbuild ]); diff --git a/pkgs/development/coq-modules/serapi/default.nix b/pkgs/development/coq-modules/serapi/default.nix index 3b7cc6c73032c3..757f8d325ed0a3 100644 --- a/pkgs/development/coq-modules/serapi/default.nix +++ b/pkgs/development/coq-modules/serapi/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchzip, mkCoqDerivation, coq, coq-lsp, version ? null }: +{ + lib, + fetchzip, + mkCoqDerivation, + coq, + coq-lsp, + version ? null, +}: let release = { @@ -12,7 +19,7 @@ let "8.13.0+0.13.0".sha256 = "0k69907xn4k61w4mkhwf8kh8drw9pijk9ynijsppihw98j8w38fy"; "8.12.0+0.12.1".sha256 = "048x3sgcq4h845hi6hm4j4dsfca8zfj70dm42w68n63qcm6xf9hn"; "8.11.0+0.11.1".sha256 = "1phmh99yqv71vlwklqgfxiq2vj99zrzxmryj2j4qvg5vav3y3y6c"; - "8.10.0+0.7.2".sha256 = "1ljzm63hpd0ksvkyxcbh8rdf7p90vg91gb4h0zz0941v1zh40k8c"; + "8.10.0+0.7.2".sha256 = "1ljzm63hpd0ksvkyxcbh8rdf7p90vg91gb4h0zz0941v1zh40k8c"; }; in @@ -23,29 +30,61 @@ in inherit version release; defaultVersion = lib.switch coq.version [ - { case = lib.versions.isEq "8.20"; out = "8.20.0+0.20.0"; } - { case = lib.versions.isEq "8.19"; out = "8.19.0+0.19.3"; } - { case = lib.versions.isEq "8.18"; out = "8.18.0+0.18.3"; } - { case = lib.versions.isEq "8.17"; out = "8.17.0+0.17.3"; } - { case = lib.versions.isEq "8.16"; out = "8.16.0+0.16.3"; } - { case = lib.versions.isEq "8.15"; out = "8.15.0+0.15.0"; } - { case = lib.versions.isEq "8.14"; out = "8.14.0+0.14.0"; } - { case = lib.versions.isEq "8.13"; out = "8.13.0+0.13.0"; } - { case = lib.versions.isEq "8.12"; out = "8.12.0+0.12.1"; } - { case = lib.versions.isEq "8.11"; out = "8.11.0+0.11.1"; } - { case = lib.versions.isEq "8.10"; out = "8.10.0+0.7.2"; } - ] null; + { + case = lib.versions.isEq "8.20"; + out = "8.20.0+0.20.0"; + } + { + case = lib.versions.isEq "8.19"; + out = "8.19.0+0.19.3"; + } + { + case = lib.versions.isEq "8.18"; + out = "8.18.0+0.18.3"; + } + { + case = lib.versions.isEq "8.17"; + out = "8.17.0+0.17.3"; + } + { + case = lib.versions.isEq "8.16"; + out = "8.16.0+0.16.3"; + } + { + case = lib.versions.isEq "8.15"; + out = "8.15.0+0.15.0"; + } + { + case = lib.versions.isEq "8.14"; + out = "8.14.0+0.14.0"; + } + { + case = lib.versions.isEq "8.13"; + out = "8.13.0+0.13.0"; + } + { + case = lib.versions.isEq "8.12"; + out = "8.12.0+0.12.1"; + } + { + case = lib.versions.isEq "8.11"; + out = "8.11.0+0.11.1"; + } + { + case = lib.versions.isEq "8.10"; + out = "8.10.0+0.7.2"; + } + ] null; useDune = true; - propagatedBuildInputs = - with coq.ocamlPackages; [ - cmdliner - findlib # run time dependency of SerAPI - ppx_sexp_conv - ppx_hash - sexplib - ]; + propagatedBuildInputs = with coq.ocamlPackages; [ + cmdliner + findlib # run time dependency of SerAPI + ppx_sexp_conv + ppx_hash + sexplib + ]; installPhase = '' runHook preInstall @@ -57,54 +96,67 @@ in homepage = "https://github.com/ejgallego/coq-serapi"; description = "SerAPI is a library for machine-to-machine interaction with the Coq proof assistant"; license = licenses.lgpl21Plus; - maintainers = with maintainers; [ alizter Zimmi48 ]; - }; -}).overrideAttrs(o: -if lib.versions.isLe "8.19.0+0.19.3" o.version && o.version != "dev" then - let ppx_deriving = coq.ocamlPackages.ppx_deriving.override { version = "5.2.1"; }; in - let inherit (o) version; in { - src = fetchzip { - url = - "https://github.com/ejgallego/coq-serapi/releases/download/${version}/coq-serapi-${ - if version == "8.11.0+0.11.1" then version - else builtins.replaceStrings [ "+" ] [ "." ] version - }.tbz"; - sha256 = release."${version}".sha256; + maintainers = with maintainers; [ + alizter + Zimmi48 + ]; }; +}).overrideAttrs + ( + o: + if lib.versions.isLe "8.19.0+0.19.3" o.version && o.version != "dev" then + let + ppx_deriving = coq.ocamlPackages.ppx_deriving.override { version = "5.2.1"; }; + in + let + inherit (o) version; + in + { + src = fetchzip { + url = "https://github.com/ejgallego/coq-serapi/releases/download/${version}/coq-serapi-${ + if version == "8.11.0+0.11.1" then version else builtins.replaceStrings [ "+" ] [ "." ] version + }.tbz"; + sha256 = release."${version}".sha256; + }; - patches = lib.optional (lib.versions.isGe "8.16" version) ./sertop.patch ++ ( - if version == "8.10.0+0.7.2" - then [ - ./8.10.0+0.7.2.patch - ] - else if version == "8.11.0+0.11.1" - then [ - ./8.11.0+0.11.1.patch - ] - else if version == "8.12.0+0.12.1" || version == "8.13.0+0.13.0" - then [ - ./8.12.0+0.12.1.patch - ] - else if version == "8.14.0+0.14.0" || version == "8.15.0+0.15.0" - then [ - ./janestreet-0.15.patch - ] - else if version == "8.16.0+0.16.3" || version == "8.17.0+0.17.0" - then [ - ./janestreet-0.16.patch - ] - else [ - ]); + patches = + lib.optional (lib.versions.isGe "8.16" version) ./sertop.patch + ++ ( + if version == "8.10.0+0.7.2" then + [ + ./8.10.0+0.7.2.patch + ] + else if version == "8.11.0+0.11.1" then + [ + ./8.11.0+0.11.1.patch + ] + else if version == "8.12.0+0.12.1" || version == "8.13.0+0.13.0" then + [ + ./8.12.0+0.12.1.patch + ] + else if version == "8.14.0+0.14.0" || version == "8.15.0+0.15.0" then + [ + ./janestreet-0.15.patch + ] + else if version == "8.16.0+0.16.3" || version == "8.17.0+0.17.0" then + [ + ./janestreet-0.16.patch + ] + else + [ + ] + ); - propagatedBuildInputs = o.propagatedBuildInputs - ++ (with coq.ocamlPackages; [ - ppx_deriving - (ppx_deriving_yojson.override { inherit ppx_deriving; }) - (ppx_import.override { inherit ppx_deriving; }) - yojson - zarith # zarith needed because of Coq - ]) - ; } -else - { propagatedBuildInputs = o.propagatedBuildInputs ++ [ coq-lsp ]; } -) + propagatedBuildInputs = + o.propagatedBuildInputs + ++ (with coq.ocamlPackages; [ + ppx_deriving + (ppx_deriving_yojson.override { inherit ppx_deriving; }) + (ppx_import.override { inherit ppx_deriving; }) + yojson + zarith # zarith needed because of Coq + ]); + } + else + { propagatedBuildInputs = o.propagatedBuildInputs ++ [ coq-lsp ]; } + ) diff --git a/pkgs/development/coq-modules/simple-io/default.nix b/pkgs/development/coq-modules/simple-io/default.nix index 1c96922b2efd12..6345818db5d07f 100644 --- a/pkgs/development/coq-modules/simple-io/default.nix +++ b/pkgs/development/coq-modules/simple-io/default.nix @@ -1,36 +1,63 @@ -{ lib, callPackage, mkCoqDerivation, coq, ExtLib, version ? null }: +{ + lib, + callPackage, + mkCoqDerivation, + coq, + ExtLib, + version ? null, +}: (mkCoqDerivation { pname = "simple-io"; owner = "Lysxia"; repo = "coq-simple-io"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.17" "8.20"; out = "1.10.0"; } - { case = range "8.11" "8.19"; out = "1.8.0"; } - { case = range "8.7" "8.13"; out = "1.3.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.17" "8.20"; + out = "1.10.0"; + } + { + case = range "8.11" "8.19"; + out = "1.8.0"; + } + { + case = range "8.7" "8.13"; + out = "1.3.0"; + } + ] null; release."1.10.0".sha256 = "sha256-67cBhLvRMWLWBL7NXK1zZTQC4PtSKu9qtesU4SqKkOw="; release."1.8.0".sha256 = "sha256-3ADNeXrBIpYRlfUW+LkLHUWV1w1HFrVc/TZISMuwvRY="; release."1.7.0".sha256 = "sha256:1a1q9x2abx71hqvjdai3n12jxzd49mhf3nqqh3ya2ssl2lj609ci"; release."1.3.0".sha256 = "1yp7ca36jyl9kz35ghxig45x6cd0bny2bpmy058359p94wc617ax"; mlPlugin = true; nativeBuildInputs = [ coq.ocamlPackages.cppo ]; - propagatedBuildInputs = [ ExtLib ] - ++ (with coq.ocamlPackages; [ ocaml findlib ocamlbuild ]); + propagatedBuildInputs = + [ ExtLib ] + ++ (with coq.ocamlPackages; [ + ocaml + findlib + ocamlbuild + ]); doCheck = true; checkTarget = "test"; useDuneifVersion = v: (lib.versionAtLeast v "1.10.0" || v == "dev"); - passthru.tests.HelloWorld = callPackage ./test.nix {}; + passthru.tests.HelloWorld = callPackage ./test.nix { }; meta = with lib; { description = "Purely functional IO for Coq"; license = licenses.mit; maintainers = [ maintainers.vbgl ]; }; -}).overrideAttrs (o: lib.optionalAttrs (lib.versionAtLeast o.version "1.8.0" || o.version == "dev") { - doCheck = false; -}) +}).overrideAttrs + ( + o: + lib.optionalAttrs (lib.versionAtLeast o.version "1.8.0" || o.version == "dev") { + doCheck = false; + } + ) diff --git a/pkgs/development/coq-modules/simple-io/test.nix b/pkgs/development/coq-modules/simple-io/test.nix index cd8a29b3f1f77d..eabdfaa01bc83d 100644 --- a/pkgs/development/coq-modules/simple-io/test.nix +++ b/pkgs/development/coq-modules/simple-io/test.nix @@ -1,9 +1,16 @@ -{ stdenv, coq, simple-io }: +{ + stdenv, + coq, + simple-io, +}: stdenv.mkDerivation { pname = "coq-simple-io-test"; inherit (simple-io) src version; - nativeCheckInputs = [ coq simple-io ]; + nativeCheckInputs = [ + coq + simple-io + ]; dontConfigure = true; dontBuild = true; doCheck = true; diff --git a/pkgs/development/coq-modules/smpl/default.nix b/pkgs/development/coq-modules/smpl/default.nix index 147c04e0c3f332..920ea748b2f10d 100644 --- a/pkgs/development/coq-modules/smpl/default.nix +++ b/pkgs/development/coq-modules/smpl/default.nix @@ -1,4 +1,9 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "smpl"; @@ -12,13 +17,30 @@ mkCoqDerivation { releaseRev = v: "v${v}"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = isEq "8.15"; out = "8.15"; } - { case = isEq "8.14"; out = "8.14"; } - { case = "8.13.2"; out = "8.13"; } - { case = "8.12.2"; out = "8.12"; } - { case = "8.10.2"; out = "8.10.2"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = isEq "8.15"; + out = "8.15"; + } + { + case = isEq "8.14"; + out = "8.14"; + } + { + case = "8.13.2"; + out = "8.13"; + } + { + case = "8.12.2"; + out = "8.12"; + } + { + case = "8.10.2"; + out = "8.10.2"; + } + ] null; mlPlugin = true; diff --git a/pkgs/development/coq-modules/smtcoq/default.nix b/pkgs/development/coq-modules/smtcoq/default.nix index e8c94425409191..050a0bc1984be3 100644 --- a/pkgs/development/coq-modules/smtcoq/default.nix +++ b/pkgs/development/coq-modules/smtcoq/default.nix @@ -1,4 +1,14 @@ -{ lib, pkgs, mkCoqDerivation, coq, veriT, zchaff, fetchurl, cvc5, version ? null }: +{ + lib, + pkgs, + mkCoqDerivation, + coq, + veriT, + zchaff, + fetchurl, + cvc5, + version ? null, +}: let # version of veriT that works with SMTCoq @@ -22,27 +32,60 @@ mkCoqDerivation { release."SMTCoq-2.2+8.15".sha256 = "sha256-+GYOasJ32KJyOfqJlTtFmsJ2exd6gdueKwHdeMPErTo="; release."SMTCoq-2.2+8.14".sha256 = "sha256-jqnF33E/4CqR1HSrLmUmLVCKslw9h3bbWi4YFmFYrhY="; release."SMTCoq-2.2+8.13".sha256 = "sha256-AVpKU/SLaLYnCnx6GOEPGJjwbRrp28Fs5O50kJqdclI="; - release."SMTCoq-2.1+8.16".rev = "4996c00b455bfe98400e96c954839ceea93efdf7"; + release."SMTCoq-2.1+8.16".rev = "4996c00b455bfe98400e96c954839ceea93efdf7"; release."SMTCoq-2.1+8.16".sha256 = "sha256-k53e+frUjwq+ZZKbbOKd/EfVC40QeAzB2nCsGkCKnHA="; - release."SMTCoq-2.1+8.14".rev = "e11d9b424b0113f32265bcef0ddc962361da4dae"; + release."SMTCoq-2.1+8.14".rev = "e11d9b424b0113f32265bcef0ddc962361da4dae"; release."SMTCoq-2.1+8.14".sha256 = "sha256-4a01/CRHUon2OfpagAnMaEVkBFipPX3MCVmSFS1Bnt4="; - release."SMTCoq-2.1+8.13".rev = "d02269c43739f4559d83873563ca00daad9faaf1"; + release."SMTCoq-2.1+8.13".rev = "d02269c43739f4559d83873563ca00daad9faaf1"; release."SMTCoq-2.1+8.13".sha256 = "sha256-VZetGghdr5uJWDwZWSlhYScoNEoRHIbwqwJKSQyfKKg="; releaseRev = v: v; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = isEq "8.19"; out = "SMTCoq-2.2+8.19"; } - { case = isEq "8.18"; out = "SMTCoq-2.2+8.18"; } - { case = isEq "8.17"; out = "SMTCoq-2.2+8.17"; } - { case = isEq "8.16"; out = "SMTCoq-2.2+8.16"; } - { case = isEq "8.15"; out = "SMTCoq-2.2+8.15"; } - { case = isEq "8.14"; out = "SMTCoq-2.2+8.14"; } - { case = isEq "8.13"; out = "SMTCoq-2.2+8.13"; } - ] null; - - propagatedBuildInputs = [ cvc5 veriT' zchaff ] ++ (with coq.ocamlPackages; [ findlib num zarith ]); + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = isEq "8.19"; + out = "SMTCoq-2.2+8.19"; + } + { + case = isEq "8.18"; + out = "SMTCoq-2.2+8.18"; + } + { + case = isEq "8.17"; + out = "SMTCoq-2.2+8.17"; + } + { + case = isEq "8.16"; + out = "SMTCoq-2.2+8.16"; + } + { + case = isEq "8.15"; + out = "SMTCoq-2.2+8.15"; + } + { + case = isEq "8.14"; + out = "SMTCoq-2.2+8.14"; + } + { + case = isEq "8.13"; + out = "SMTCoq-2.2+8.13"; + } + ] null; + + propagatedBuildInputs = + [ + cvc5 + veriT' + zchaff + ] + ++ (with coq.ocamlPackages; [ + findlib + num + zarith + ]); mlPlugin = true; nativeBuildInputs = (with pkgs; [ gnumake42 ]) ++ (with coq.ocamlPackages; [ ocamlbuild ]); diff --git a/pkgs/development/coq-modules/ssprove/default.nix b/pkgs/development/coq-modules/ssprove/default.nix index 08f4400b98c221..c0e5b0bf8c5798 100644 --- a/pkgs/development/coq-modules/ssprove/default.nix +++ b/pkgs/development/coq-modules/ssprove/default.nix @@ -1,10 +1,14 @@ -{ lib, mkCoqDerivation, coq, version ? null -, equations -, mathcomp-ssreflect -, mathcomp-analysis -, mathcomp-experimental-reals -, extructures -, deriving +{ + lib, + mkCoqDerivation, + coq, + version ? null, + equations, + mathcomp-ssreflect, + mathcomp-analysis, + mathcomp-experimental-reals, + extructures, + deriving, }: (mkCoqDerivation { @@ -12,17 +16,34 @@ owner = "SSProve"; inherit version; - defaultVersion = with lib.versions; lib.switch [coq.coq-version mathcomp-ssreflect.version] [ - { cases = [(range "8.18" "8.20") (range "2.1.0" "2.2.0")]; out = "0.2.2"; } - # This is the original dependency: - # { cases = ["8.17" "1.18.0"]; out = "0.1.0"; } - # But it is not loadable. The math-comp nixpkgs configuration - # will always only output version 1.18.0 for Coq 8.17. - # Hence, the Coq 8.17 and math-comp 1.17.0 must be explicitly set - # to load it. - # (This version is not on the math-comp CI and hence not checked.) - { cases = ["8.17" "1.17.0"]; out = "0.1.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.coq-version mathcomp-ssreflect.version ] + [ + { + cases = [ + (range "8.18" "8.20") + (range "2.1.0" "2.2.0") + ]; + out = "0.2.2"; + } + # This is the original dependency: + # { cases = ["8.17" "1.18.0"]; out = "0.1.0"; } + # But it is not loadable. The math-comp nixpkgs configuration + # will always only output version 1.18.0 for Coq 8.17. + # Hence, the Coq 8.17 and math-comp 1.17.0 must be explicitly set + # to load it. + # (This version is not on the math-comp CI and hence not checked.) + { + cases = [ + "8.17" + "1.17.0" + ]; + out = "0.1.0"; + } + ] + null; releaseRev = v: "v${v}"; @@ -31,22 +52,26 @@ release."0.2.0".sha256 = "sha256-GDkWH0LUsW165vAUoYC5of9ndr0MbfBtmrPhsJVXi3o="; release."0.1.0".sha256 = "sha256-Yj+k+mBsudi3d6bRVlZLyM4UqQnzAX5tHvxtKoIuNTE="; - propagatedBuildInputs = [equations - mathcomp-ssreflect - mathcomp-analysis - mathcomp-experimental-reals - extructures - deriving]; + propagatedBuildInputs = [ + equations + mathcomp-ssreflect + mathcomp-analysis + mathcomp-experimental-reals + extructures + deriving + ]; meta = with lib; { description = "SSProve: A Foundational Framework for Modular Cryptographic Proofs in Coq"; license = licenses.mit; - maintainers = [ { - name = "Sebastian Ertel"; - email = "sebastian.ertel@gmail.com"; - github = "sertel"; - githubId = 3703100; - } ]; + maintainers = [ + { + name = "Sebastian Ertel"; + email = "sebastian.ertel@gmail.com"; + github = "sertel"; + githubId = 3703100; + } + ]; }; }) diff --git a/pkgs/development/coq-modules/stalmarck/default.nix b/pkgs/development/coq-modules/stalmarck/default.nix index 88ea4379372682..70863c9633591b 100644 --- a/pkgs/development/coq-modules/stalmarck/default.nix +++ b/pkgs/development/coq-modules/stalmarck/default.nix @@ -1,35 +1,60 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: let repo = "stalmarck"; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = isEq "8.20"; out = "8.20.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = isEq "8.20"; + out = "8.20.0"; + } + ] null; release = { "8.20.0".sha256 = "sha256-jITxQT1jLyZvWCGPnmK8i3IrwsZwMPOV0aBe9r22TIQ="; }; releaseRev = v: "v${v}"; - packages = [ "stalmarck" "stalmarck-tactic" ]; + packages = [ + "stalmarck" + "stalmarck-tactic" + ]; - stalmarck_ = package: let - pname = package; - istac = package == "stalmarck-tactic"; - propagatedBuildInputs = - lib.optional istac (stalmarck_ "stalmarck"); - description = - if istac then - "Coq tactic and verified tool for proving tautologies using Stålmarck's algorithm" - else - "A two-level approach to prove tautologies using Stålmarck's algorithm in Coq."; - in mkCoqDerivation { - inherit version pname defaultVersion release releaseRev repo - propagatedBuildInputs; + stalmarck_ = + package: + let + pname = package; + istac = package == "stalmarck-tactic"; + propagatedBuildInputs = lib.optional istac (stalmarck_ "stalmarck"); + description = + if istac then + "Coq tactic and verified tool for proving tautologies using Stålmarck's algorithm" + else + "A two-level approach to prove tautologies using Stålmarck's algorithm in Coq."; + in + mkCoqDerivation { + inherit + version + pname + defaultVersion + release + releaseRev + repo + propagatedBuildInputs + ; mlPlugin = istac; useDune = istac; - meta = { inherit description; license = lib.licenses.lgpl21Plus; }; + meta = { + inherit description; + license = lib.licenses.lgpl21Plus; + }; passthru = lib.genAttrs packages stalmarck_; }; diff --git a/pkgs/development/coq-modules/stdpp/default.nix b/pkgs/development/coq-modules/stdpp/default.nix index 509aac763b1655..930d5ae87fe191 100644 --- a/pkgs/development/coq-modules/stdpp/default.nix +++ b/pkgs/development/coq-modules/stdpp/default.nix @@ -1,19 +1,47 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation rec { pname = "stdpp"; inherit version; domain = "gitlab.mpi-sws.org"; owner = "iris"; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.19" "8.20"; out = "1.11.0"; } - { case = range "8.18" "8.19"; out = "1.10.0"; } - { case = range "8.16" "8.18"; out = "1.9.0"; } - { case = range "8.13" "8.17"; out = "1.8.0"; } - { case = range "8.12" "8.14"; out = "1.6.0"; } - { case = range "8.11" "8.13"; out = "1.5.0"; } - { case = range "8.8" "8.10"; out = "1.4.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.19" "8.20"; + out = "1.11.0"; + } + { + case = range "8.18" "8.19"; + out = "1.10.0"; + } + { + case = range "8.16" "8.18"; + out = "1.9.0"; + } + { + case = range "8.13" "8.17"; + out = "1.8.0"; + } + { + case = range "8.12" "8.14"; + out = "1.6.0"; + } + { + case = range "8.11" "8.13"; + out = "1.5.0"; + } + { + case = range "8.8" "8.10"; + out = "1.4.0"; + } + ] null; release."1.11.0".sha256 = "sha256-yqnkaA5gUdZBJZ3JnvPYh11vKQRl0BAnior1yGowG7k="; release."1.10.0".sha256 = "sha256-bfynevIKxAltvt76lsqVxBmifFkzEhyX8lRgTKxr21I="; release."1.9.0".sha256 = "sha256-OXeB+XhdyzWMp5Karsz8obp0rTeMKrtG7fu/tmc9aeI="; @@ -33,6 +61,9 @@ mkCoqDerivation rec { meta = with lib; { description = "Extended “Standard Library” for Coq"; license = licenses.bsd3; - maintainers = [ maintainers.vbgl maintainers.ineol ]; + maintainers = [ + maintainers.vbgl + maintainers.ineol + ]; }; } diff --git a/pkgs/development/coq-modules/tlc/default.nix b/pkgs/development/coq-modules/tlc/default.nix index 39e940a0b5f86d..ffc71f93a6062e 100644 --- a/pkgs/development/coq-modules/tlc/default.nix +++ b/pkgs/development/coq-modules/tlc/default.nix @@ -1,16 +1,37 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: (mkCoqDerivation { pname = "tlc"; owner = "charguer"; inherit version; - displayVersion = { tlc = false; }; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.13" "8.16"; out = "20211215"; } - { case = range "8.12" "8.13"; out = "20210316"; } - { case = range "8.10" "8.12"; out = "20200328"; } - { case = range "8.6" "8.12"; out = "20181116"; } - ] null; + displayVersion = { + tlc = false; + }; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.13" "8.16"; + out = "20211215"; + } + { + case = range "8.12" "8.13"; + out = "20210316"; + } + { + case = range "8.10" "8.12"; + out = "20200328"; + } + { + case = range "8.6" "8.12"; + out = "20181116"; + } + ] null; release."20211215".sha256 = "sha256:0m4d4jhdcyq8p2gpz9j3nd6jqzmz2bjmbpc0q06b38b8i550mamp"; release."20210316".sha256 = "1hlavnx20lxpf2iydbbxqmim9p8wdwv4phzp9ypij93yivih0g4a"; release."20200328".sha256 = "16vzild9gni8zhgb3qhmka47f8zagdh03k6nssif7drpim8233lx"; @@ -22,8 +43,10 @@ license = licenses.free; maintainers = [ maintainers.vbgl ]; }; -}).overrideAttrs (x: - lib.optionalAttrs (lib.versionOlder x.version "20210316" && x.version != "dev") { - installFlags = [ "CONTRIB=$(out)/lib/coq/${coq.coq-version}/user-contrib" ]; - } -) +}).overrideAttrs + ( + x: + lib.optionalAttrs (lib.versionOlder x.version "20210316" && x.version != "dev") { + installFlags = [ "CONTRIB=$(out)/lib/coq/${coq.coq-version}/user-contrib" ]; + } + ) diff --git a/pkgs/development/coq-modules/topology/default.nix b/pkgs/development/coq-modules/topology/default.nix index d50c83f0745eb4..fb0a321e0f9e94 100644 --- a/pkgs/development/coq-modules/topology/default.nix +++ b/pkgs/development/coq-modules/topology/default.nix @@ -1,4 +1,10 @@ -{ lib, mkCoqDerivation, coq, zorns-lemma, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + zorns-lemma, + version ? null, +}: mkCoqDerivation rec { pname = "topology"; @@ -15,14 +21,34 @@ mkCoqDerivation rec { release."8.6.0".sha256 = "sha256-eu/dBEFo3y6vnXlJljUD4hds6+qgAPQVvsuspyGHcj8="; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.12" "8.18"; out = "10.2.0"; } - { case = range "8.10" "8.16"; out = "9.0.0"; } - { case = "8.9"; out = "8.9.0"; } - { case = "8.8"; out = "8.8.0"; } - { case = "8.7"; out = "8.7.0"; } - { case = "8.6"; out = "8.6.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.12" "8.18"; + out = "10.2.0"; + } + { + case = range "8.10" "8.16"; + out = "9.0.0"; + } + { + case = "8.9"; + out = "8.9.0"; + } + { + case = "8.8"; + out = "8.8.0"; + } + { + case = "8.7"; + out = "8.7.0"; + } + { + case = "8.6"; + out = "8.6.0"; + } + ] null; propagatedBuildInputs = [ zorns-lemma ]; diff --git a/pkgs/development/coq-modules/trakt/default.nix b/pkgs/development/coq-modules/trakt/default.nix index e762a51880b247..544ca1e8111b4d 100644 --- a/pkgs/development/coq-modules/trakt/default.nix +++ b/pkgs/development/coq-modules/trakt/default.nix @@ -1,4 +1,10 @@ -{ lib, mkCoqDerivation, coq, coq-elpi, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + coq-elpi, + version ? null, +}: mkCoqDerivation { pname = "trakt"; @@ -10,11 +16,25 @@ mkCoqDerivation { release."1.2+8.13".sha256 = "sha256-hozms4sPSMr4lFkJ20x+uW9Wqt067bifnPQxdGyKhQQ="; inherit version; - defaultVersion = with lib.versions; lib.switch [ coq.version ] [ - { cases = [ (range "8.15" "8.17") ]; out = "1.2"; } - { cases = [ (isEq "8.13") ]; out = "1.2+8.13"; } - { cases = [ (range "8.13" "8.17") ]; out = "1.1"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch + [ coq.version ] + [ + { + cases = [ (range "8.15" "8.17") ]; + out = "1.2"; + } + { + cases = [ (isEq "8.13") ]; + out = "1.2+8.13"; + } + { + cases = [ (range "8.13" "8.17") ]; + out = "1.1"; + } + ] + null; propagatedBuildInputs = [ coq-elpi ]; diff --git a/pkgs/development/coq-modules/unicoq/default.nix b/pkgs/development/coq-modules/unicoq/default.nix index c3167e4a9d7d45..86a0567e3a9135 100644 --- a/pkgs/development/coq-modules/unicoq/default.nix +++ b/pkgs/development/coq-modules/unicoq/default.nix @@ -1,12 +1,22 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "unicoq"; owner = "unicoq"; inherit version; - defaultVersion = with lib.versions; lib.switch coq.version [ - { case = range "8.19" "8.19"; out = "1.6-${coq.coq-version}"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.version [ + { + case = range "8.19" "8.19"; + out = "1.6-${coq.coq-version}"; + } + ] null; release."1.6-8.19".sha256 = "sha256-fDk60B8AzJwiemxHGgWjNu6PTu6NcJoI9uK7Ww2AT14="; releaseRev = v: "v${v}"; mlPlugin = true; diff --git a/pkgs/development/coq-modules/vcfloat/default.nix b/pkgs/development/coq-modules/vcfloat/default.nix index cb1fa248fdc3d7..7e9aca3ea7d910 100644 --- a/pkgs/development/coq-modules/vcfloat/default.nix +++ b/pkgs/development/coq-modules/vcfloat/default.nix @@ -1,27 +1,51 @@ -{ lib, mkCoqDerivation, coq, interval, compcert, flocq, bignums, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + interval, + compcert, + flocq, + bignums, + version ? null, +}: -let self = mkCoqDerivation { - pname = "vcfloat"; - owner = "VeriNum"; - inherit version; - sourceRoot = "${self.src.name}/vcfloat"; - postPatch = '' - coq_makefile -o Makefile -f _CoqProject *.v - ''; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = isEq "8.19"; out = "2.2"; } - { case = range "8.16" "8.18"; out = "2.1.1"; } - ] null; - release."2.2".sha256 = "sha256-PyMm84ZYh+dOnl8Kk2wlYsQ+S/d1Hsp6uv2twTedEPg="; - release."2.1.1".sha256 = "sha256-bd/XSQhyFUAnSm2bhZEZBWB6l4/Ptlm9JrWu6w9BOpw="; - releaseRev = v: "v${v}"; +let + self = mkCoqDerivation { + pname = "vcfloat"; + owner = "VeriNum"; + inherit version; + sourceRoot = "${self.src.name}/vcfloat"; + postPatch = '' + coq_makefile -o Makefile -f _CoqProject *.v + ''; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = isEq "8.19"; + out = "2.2"; + } + { + case = range "8.16" "8.18"; + out = "2.1.1"; + } + ] null; + release."2.2".sha256 = "sha256-PyMm84ZYh+dOnl8Kk2wlYsQ+S/d1Hsp6uv2twTedEPg="; + release."2.1.1".sha256 = "sha256-bd/XSQhyFUAnSm2bhZEZBWB6l4/Ptlm9JrWu6w9BOpw="; + releaseRev = v: "v${v}"; - propagatedBuildInputs = [ interval compcert flocq bignums ]; + propagatedBuildInputs = [ + interval + compcert + flocq + bignums + ]; - meta = { - description = "Tool for Coq proofs about floating-point round-off error"; - maintainers = with lib.maintainers; [ quinn-dougherty ]; - license = lib.licenses.lgpl3Plus; + meta = { + description = "Tool for Coq proofs about floating-point round-off error"; + maintainers = with lib.maintainers; [ quinn-dougherty ]; + license = lib.licenses.lgpl3Plus; + }; }; -}; -in self +in +self diff --git a/pkgs/development/coq-modules/waterproof/default.nix b/pkgs/development/coq-modules/waterproof/default.nix index 7d9431c25c2862..61612f3cb1059a 100644 --- a/pkgs/development/coq-modules/waterproof/default.nix +++ b/pkgs/development/coq-modules/waterproof/default.nix @@ -1,16 +1,27 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: mkCoqDerivation { pname = "waterproof"; owner = "impermeable"; repo = "coq-waterproof"; inherit version; - defaultVersion = let inherit (lib.versions) range; in + defaultVersion = + let + inherit (lib.versions) range; + in lib.switch coq.coq-version [ - { case = range "8.18" "8.18"; out = "2.1.1+8.18"; } + { + case = range "8.18" "8.18"; + out = "2.1.1+8.18"; + } ] null; release = { - "2.1.1+8.18".sha256 = "sha256-jYuQ9SPFRefNCUfn6+jEaJ4399EnU0gXPPkEDCpJYOI="; + "2.1.1+8.18".sha256 = "sha256-jYuQ9SPFRefNCUfn6+jEaJ4399EnU0gXPPkEDCpJYOI="; }; mlPlugin = true; diff --git a/pkgs/development/coq-modules/zorns-lemma/default.nix b/pkgs/development/coq-modules/zorns-lemma/default.nix index 438f4f9fa933bd..37870d29d18a18 100644 --- a/pkgs/development/coq-modules/zorns-lemma/default.nix +++ b/pkgs/development/coq-modules/zorns-lemma/default.nix @@ -1,8 +1,13 @@ -{ lib, mkCoqDerivation, coq, version ? null }: +{ + lib, + mkCoqDerivation, + coq, + version ? null, +}: (mkCoqDerivation { pname = "zorns-lemma"; - repo = "topology"; + repo = "topology"; releaseRev = v: "v${v}"; @@ -17,15 +22,38 @@ release."8.5.0".sha256 = "sha256-mH/v02ObMjbVPYx2H+Jhz+Xp0XRKN67iMAdA1VNFzso="; inherit version; - defaultVersion = with lib.versions; lib.switch coq.coq-version [ - { case = range "8.12" "8.20"; out = "10.2.0"; } - { case = range "8.10" "8.16"; out = "9.0.0"; } - { case = "8.9"; out = "8.9.0"; } - { case = "8.8"; out = "8.8.0"; } - { case = "8.7"; out = "8.7.0"; } - { case = "8.6"; out = "8.6.0"; } - { case = "8.5"; out = "8.5.0"; } - ] null; + defaultVersion = + with lib.versions; + lib.switch coq.coq-version [ + { + case = range "8.12" "8.20"; + out = "10.2.0"; + } + { + case = range "8.10" "8.16"; + out = "9.0.0"; + } + { + case = "8.9"; + out = "8.9.0"; + } + { + case = "8.8"; + out = "8.8.0"; + } + { + case = "8.7"; + out = "8.7.0"; + } + { + case = "8.6"; + out = "8.6.0"; + } + { + case = "8.5"; + out = "8.5.0"; + } + ] null; useDuneifVersion = lib.versions.isGe "9.0"; @@ -39,4 +67,5 @@ maintainers = with maintainers; [ siraben ]; license = licenses.lgpl21Plus; }; -}).overrideAttrs({version, ...}: lib.optionalAttrs (lib.versions.isGe "9.0" version) { repo = "topology"; }) +}).overrideAttrs + ({ version, ... }: lib.optionalAttrs (lib.versions.isGe "9.0" version) { repo = "topology"; }) diff --git a/pkgs/development/cuda-modules/cudatoolkit/default.nix b/pkgs/development/cuda-modules/cudatoolkit/default.nix index 71a74517460051..69902540286991 100644 --- a/pkgs/development/cuda-modules/cudatoolkit/default.nix +++ b/pkgs/development/cuda-modules/cudatoolkit/default.nix @@ -212,36 +212,34 @@ backendStdenv.mkDerivation rec { mv pkg/builds/nsight_systems/target-linux-x64 $out/target-linux-x64 mv pkg/builds/nsight_systems/host-linux-x64 $out/host-linux-x64 rm $out/host-linux-x64/libstdc++.so* - ${ - lib.optionalString (lib.versionAtLeast version "11.8" && lib.versionOlder version "12") - # error: auto-patchelf could not satisfy dependency libtiff.so.5 wanted by /nix/store/.......-cudatoolkit-12.0.1/host-linux-x64/Plugins/imageformats/libqtiff.so - # we only ship libtiff.so.6, so let's use qt plugins built by Nix. - # TODO: don't copy, come up with a symlink-based "merge" - '' - rsync ${lib.getLib qt6Packages.qtimageformats}/lib/qt-6/plugins/ $out/host-linux-x64/Plugins/ -aP - '' + ${lib.optionalString (lib.versionAtLeast version "11.8" && lib.versionOlder version "12") + # error: auto-patchelf could not satisfy dependency libtiff.so.5 wanted by /nix/store/.......-cudatoolkit-12.0.1/host-linux-x64/Plugins/imageformats/libqtiff.so + # we only ship libtiff.so.6, so let's use qt plugins built by Nix. + # TODO: don't copy, come up with a symlink-based "merge" + '' + rsync ${lib.getLib qt6Packages.qtimageformats}/lib/qt-6/plugins/ $out/host-linux-x64/Plugins/ -aP + '' } - ${ - lib.optionalString (lib.versionAtLeast version "12") - # Use Qt plugins built by Nix. - '' - for qtlib in $out/host-linux-x64/Plugins/*/libq*.so; do - qtdir=$(basename $(dirname $qtlib)) - filename=$(basename $qtlib) - for qtpkgdir in ${ - lib.concatMapStringsSep " " (x: qt6Packages.${x}) [ - "qtbase" - "qtimageformats" - "qtsvg" - "qtwayland" - ] - }; do - if [ -e $qtpkgdir/lib/qt-6/plugins/$qtdir/$filename ]; then - ln -snf $qtpkgdir/lib/qt-6/plugins/$qtdir/$filename $qtlib - fi - done + ${lib.optionalString (lib.versionAtLeast version "12") + # Use Qt plugins built by Nix. + '' + for qtlib in $out/host-linux-x64/Plugins/*/libq*.so; do + qtdir=$(basename $(dirname $qtlib)) + filename=$(basename $qtlib) + for qtpkgdir in ${ + lib.concatMapStringsSep " " (x: qt6Packages.${x}) [ + "qtbase" + "qtimageformats" + "qtsvg" + "qtwayland" + ] + }; do + if [ -e $qtpkgdir/lib/qt-6/plugins/$qtdir/$filename ]; then + ln -snf $qtpkgdir/lib/qt-6/plugins/$qtdir/$filename $qtlib + fi done - '' + done + '' } rm -f $out/tools/CUDA_Occupancy_Calculator.xls # FIXME: why? diff --git a/pkgs/development/dhall-modules/Prelude.nix b/pkgs/development/dhall-modules/Prelude.nix index 320022abc0ed84..e89a47e8c1a2b2 100644 --- a/pkgs/development/dhall-modules/Prelude.nix +++ b/pkgs/development/dhall-modules/Prelude.nix @@ -1,11 +1,11 @@ { buildDhallGitHubPackage }: buildDhallGitHubPackage { - name = "Prelude"; - owner = "dhall-lang"; - repo = "dhall-lang"; + name = "Prelude"; + owner = "dhall-lang"; + repo = "dhall-lang"; directory = "Prelude"; - file = "package.dhall"; - rev = "v20.1.0"; - sha256 = "04r1w7wqydmwm9mh3lz4y96a87k5kkvzsmrhbdrf0izcy5bqqv5y"; + file = "package.dhall"; + rev = "v20.1.0"; + sha256 = "04r1w7wqydmwm9mh3lz4y96a87k5kkvzsmrhbdrf0izcy5bqqv5y"; } diff --git a/pkgs/development/dhall-modules/dhall-cloudformation.nix b/pkgs/development/dhall-modules/dhall-cloudformation.nix index e99fbc3b3177c3..cac5c4d4473652 100644 --- a/pkgs/development/dhall-modules/dhall-cloudformation.nix +++ b/pkgs/development/dhall-modules/dhall-cloudformation.nix @@ -3,7 +3,8 @@ let version = "0.9.64"; -in buildDhallGitHubPackage { +in +buildDhallGitHubPackage { name = "cloudformation"; owner = "jcouyang"; repo = "dhall-aws-cloudformation"; diff --git a/pkgs/development/dhall-modules/dhall-kubernetes.nix b/pkgs/development/dhall-modules/dhall-kubernetes.nix index 337ae474dafd99..9f893a1f047e23 100644 --- a/pkgs/development/dhall-modules/dhall-kubernetes.nix +++ b/pkgs/development/dhall-modules/dhall-kubernetes.nix @@ -1,10 +1,10 @@ { buildDhallGitHubPackage }: buildDhallGitHubPackage { - name = "dhall-kubernetes-3.0.0"; - owner = "dhall-lang"; - repo = "dhall-kubernetes"; - file = "package.dhall"; - rev = "3c6d09a9409977cdde58a091d76a6d20509ca4b0"; + name = "dhall-kubernetes-3.0.0"; + owner = "dhall-lang"; + repo = "dhall-kubernetes"; + file = "package.dhall"; + rev = "3c6d09a9409977cdde58a091d76a6d20509ca4b0"; sha256 = "1r4awh770ghsrwabh5ddy3jpmrbigakk0h32542n1kh71w3cdq1h"; } diff --git a/pkgs/development/dhall-modules/lib.nix b/pkgs/development/dhall-modules/lib.nix index c1993d0af02034..826fea8194838e 100644 --- a/pkgs/development/dhall-modules/lib.nix +++ b/pkgs/development/dhall-modules/lib.nix @@ -4,22 +4,22 @@ let # This is essentially the same thing as `lib.makeOverridable`, except storing # the override method in a method named `overridePackage` so that it's not # shadowed by the `override` method added by `callPackage` - makePackageOverridable = f: args: + makePackageOverridable = + f: args: let result = lib.makeOverridable f args; copyArgs = g: lib.setFunctionArgs g (lib.functionArgs f); - overrideWith = - update: args // (if lib.isFunction update then update args else update); + overrideWith = update: args // (if lib.isFunction update then update args else update); - overridePackage = - copyArgs (update: makePackageOverridable f (overrideWith update)); + overridePackage = copyArgs (update: makePackageOverridable f (overrideWith update)); in - result // { inherit overridePackage; }; + result // { inherit overridePackage; }; in - lib // { - inherit makePackageOverridable; - } +lib +// { + inherit makePackageOverridable; +} diff --git a/pkgs/development/em-modules/generic/default.nix b/pkgs/development/em-modules/generic/default.nix index eac0fcde53f691..c34fdaf82a5948 100644 --- a/pkgs/development/em-modules/generic/default.nix +++ b/pkgs/development/em-modules/generic/default.nix @@ -1,82 +1,100 @@ -{ pkgs, lib, emscripten, python3 }: +{ + pkgs, + lib, + emscripten, + python3, +}: argsFun: let - wrapDerivation = f: - pkgs.stdenv.mkDerivation (finalAttrs: - f (lib.toFunction argsFun finalAttrs) - ); + wrapDerivation = f: pkgs.stdenv.mkDerivation (finalAttrs: f (lib.toFunction argsFun finalAttrs)); in wrapDerivation ( -{ buildInputs ? [], nativeBuildInputs ? [] - -, enableParallelBuilding ? true - -, meta ? {}, ... } @ args: - - args // { - - pname = "emscripten-${lib.getName args}"; - version = lib.getVersion args; - buildInputs = [ emscripten python3 ] ++ buildInputs; - nativeBuildInputs = [ emscripten python3 ] ++ nativeBuildInputs; - - # fake conftest results with emscripten's python magic - EMCONFIGURE_JS=2; - - # removes archive indices - dontStrip = args.dontStrip or true; - - configurePhase = args.configurePhase or '' - # FIXME: Some tests require writing at $HOME - HOME=$TMPDIR - runHook preConfigure - - emconfigure ./configure --prefix=$out - - mkdir -p .emscriptencache - export EM_CACHE=$(pwd)/.emscriptencache - - runHook postConfigure - ''; - - buildPhase = args.buildPhase or '' - runHook preBuild - - HOME=$TMPDIR - - emmake make - - runHook postBuild - ''; - - doCheck = true; - - checkPhase = args.checkPhase or '' - runHook preCheck - - echo "Please provide a test for your emscripten based library/tool, see libxml2 as an exmple on how to use emcc/node to verify your build" - echo "" - echo "In normal C 'unresolved symbols' would yield an error and a breake of execution. In contrast, in emscripten they are only a warning which is ok given that emscripten assumptions about shared libraries." - echo " -> https://github.com/kripken/emscripten/wiki/Linking" - echo "So just assume the dependencies were built using hydra, then YOU WILL NEVER see the warning and your code depending on a library will always fail!" - exit 1 - - runHook postCheck - ''; - - enableParallelBuilding = args.enableParallelBuilding or true; - - meta = { - # Add default meta information - platforms = lib.platforms.all; - # Do not build this automatically - hydraPlatforms = []; - } // meta // { - # add an extra maintainer to every package - maintainers = (meta.maintainers or []) ++ - [ lib.maintainers.qknight ]; - }; -}) + buildInputs ? [ ], + nativeBuildInputs ? [ ], + + enableParallelBuilding ? true, + + meta ? { }, + ... + }@args: + + args + // { + + pname = "emscripten-${lib.getName args}"; + version = lib.getVersion args; + buildInputs = [ + emscripten + python3 + ] ++ buildInputs; + nativeBuildInputs = [ + emscripten + python3 + ] ++ nativeBuildInputs; + + # fake conftest results with emscripten's python magic + EMCONFIGURE_JS = 2; + + # removes archive indices + dontStrip = args.dontStrip or true; + + configurePhase = + args.configurePhase or '' + # FIXME: Some tests require writing at $HOME + HOME=$TMPDIR + runHook preConfigure + + emconfigure ./configure --prefix=$out + + mkdir -p .emscriptencache + export EM_CACHE=$(pwd)/.emscriptencache + + runHook postConfigure + ''; + + buildPhase = + args.buildPhase or '' + runHook preBuild + + HOME=$TMPDIR + + emmake make + + runHook postBuild + ''; + + doCheck = true; + + checkPhase = + args.checkPhase or '' + runHook preCheck + + echo "Please provide a test for your emscripten based library/tool, see libxml2 as an exmple on how to use emcc/node to verify your build" + echo "" + echo "In normal C 'unresolved symbols' would yield an error and a breake of execution. In contrast, in emscripten they are only a warning which is ok given that emscripten assumptions about shared libraries." + echo " -> https://github.com/kripken/emscripten/wiki/Linking" + echo "So just assume the dependencies were built using hydra, then YOU WILL NEVER see the warning and your code depending on a library will always fail!" + exit 1 + + runHook postCheck + ''; + + enableParallelBuilding = args.enableParallelBuilding or true; + + meta = + { + # Add default meta information + platforms = lib.platforms.all; + # Do not build this automatically + hydraPlatforms = [ ]; + } + // meta + // { + # add an extra maintainer to every package + maintainers = (meta.maintainers or [ ]) ++ [ lib.maintainers.qknight ]; + }; + } +) diff --git a/pkgs/development/embedded/arduino/arduino-core/chrootenv.nix b/pkgs/development/embedded/arduino/arduino-core/chrootenv.nix index 6697ecc6b19240..261d217681d5b7 100644 --- a/pkgs/development/embedded/arduino/arduino-core/chrootenv.nix +++ b/pkgs/development/embedded/arduino/arduino-core/chrootenv.nix @@ -1,4 +1,10 @@ -{ lib, buildFHSEnv, arduino-core-unwrapped, withGui ? false, withTeensyduino ? false }: +{ + lib, + buildFHSEnv, + arduino-core-unwrapped, + withGui ? false, + withTeensyduino ? false, +}: let arduino-unwrapped = arduino-core-unwrapped.override { inherit withGui withTeensyduino; }; in @@ -7,13 +13,16 @@ buildFHSEnv { inherit (arduino-core-unwrapped) version; targetPkgs = - pkgs: (with pkgs; [ + pkgs: + (with pkgs; [ ncurses arduino-unwrapped zlib - (python3.withPackages (p: with p; [ - pyserial - ])) + (python3.withPackages ( + p: with p; [ + pyserial + ] + )) ]); extraInstallCommands = '' diff --git a/pkgs/development/embedded/arduino/arduino-core/default.nix b/pkgs/development/embedded/arduino/arduino-core/default.nix index 43e6292143a4aa..133e5b02fda6b0 100644 --- a/pkgs/development/embedded/arduino/arduino-core/default.nix +++ b/pkgs/development/embedded/arduino/arduino-core/default.nix @@ -1,35 +1,36 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchurl -, jdk -, ant -, stripJavaArchivesHook -, libusb-compat-0_1 -, libusb1 -, unzip -, zlib -, ncurses -, readline -, withGui ? false -, gtk3 -, wrapGAppsHook3 -, withTeensyduino ? false - /* Packages needed for Teensyduino */ -, upx -, fontconfig -, xorg -, gcc -, atk -, glib -, pango -, gdk-pixbuf -, gtk2 -, libpng12 -, expat -, freetype -, cairo -, udev +{ + stdenv, + lib, + fetchFromGitHub, + fetchurl, + jdk, + ant, + stripJavaArchivesHook, + libusb-compat-0_1, + libusb1, + unzip, + zlib, + ncurses, + readline, + withGui ? false, + gtk3, + wrapGAppsHook3, + withTeensyduino ? false, + # Packages needed for Teensyduino + upx, + fontconfig, + xorg, + gcc, + atk, + glib, + pango, + gdk-pixbuf, + gtk2, + libpng12, + expat, + freetype, + cairo, + udev, }: assert withTeensyduino -> withGui; @@ -41,11 +42,22 @@ let }; # Some .so-files are later copied from .jar-s to $HOME, so patch them beforehand patchelfInJars = - lib.optional (stdenv.hostPlatform.system == "aarch64-linux") { jar = "share/arduino/lib/jssc-2.8.0-arduino4.jar"; file = "libs/linux/libjSSC-2.8_aarch64.so"; } - ++ lib.optional (builtins.match "armv[67]l-linux" stdenv.hostPlatform.system != null) { jar = "share/arduino/lib/jssc-2.8.0-arduino4.jar"; file = "libs/linux/libjSSC-2.8_armhf.so"; } - ++ lib.optional (stdenv.hostPlatform.system == "x86_64-linux") { jar = "share/arduino/lib/jssc-2.8.0-arduino4.jar"; file = "libs/linux/libjSSC-2.8_x86_64.so"; } - ++ lib.optional (stdenv.hostPlatform.system == "i686-linux") { jar = "share/arduino/lib/jssc-2.8.0-arduino4.jar"; file = "libs/linux/libjSSC-2.8_x86.so"; } - ; + lib.optional (stdenv.hostPlatform.system == "aarch64-linux") { + jar = "share/arduino/lib/jssc-2.8.0-arduino4.jar"; + file = "libs/linux/libjSSC-2.8_aarch64.so"; + } + ++ lib.optional (builtins.match "armv[67]l-linux" stdenv.hostPlatform.system != null) { + jar = "share/arduino/lib/jssc-2.8.0-arduino4.jar"; + file = "libs/linux/libjSSC-2.8_armhf.so"; + } + ++ lib.optional (stdenv.hostPlatform.system == "x86_64-linux") { + jar = "share/arduino/lib/jssc-2.8.0-arduino4.jar"; + file = "libs/linux/libjSSC-2.8_x86_64.so"; + } + ++ lib.optional (stdenv.hostPlatform.system == "i686-linux") { + jar = "share/arduino/lib/jssc-2.8.0-arduino4.jar"; + file = "libs/linux/libjSSC-2.8_x86.so"; + }; # abiVersion 6 is default, but we need 5 for `avrdude_bin` executable ncurses5 = ncurses.override { abiVersion = "5"; }; teensy_libpath = lib.makeLibraryPath [ @@ -71,15 +83,21 @@ let zlib ]; teensy_architecture = - if stdenv.hostPlatform.isx86_32 then "linux32" - else if stdenv.hostPlatform.isx86_64 then "linux64" - else if stdenv.hostPlatform.isAarch64 then "linuxaarch64" - else if stdenv.hostPlatform.isAarch32 then "linuxarm" - else throw "${stdenv.hostPlatform.system} is not supported in teensy"; + if stdenv.hostPlatform.isx86_32 then + "linux32" + else if stdenv.hostPlatform.isx86_64 then + "linux64" + else if stdenv.hostPlatform.isAarch64 then + "linuxaarch64" + else if stdenv.hostPlatform.isAarch32 then + "linuxarm" + else + throw "${stdenv.hostPlatform.system} is not supported in teensy"; in stdenv.mkDerivation rec { - pname = (if withTeensyduino then "teensyduino" else "arduino") + lib.optionalString (!withGui) "-core"; + pname = + (if withTeensyduino then "teensyduino" else "arduino") + lib.optionalString (!withGui) "-core"; version = "1.8.19"; src = fetchFromGitHub { @@ -92,28 +110,37 @@ stdenv.mkDerivation rec { teensyduino_version = "156"; teensyduino_src = fetchurl { url = "https://www.pjrc.com/teensy/td_${teensyduino_version}/TeensyduinoInstall.${teensy_architecture}"; - sha256 = { - linux64 = "sha256-4DbhmmYrx+rCBpDrYFaC0A88Qv9UEeNlQAkFi3zAstk="; - linux32 = "sha256-DlRPOtDxmMPv2Qzhib7vNZdKNZCxmm9YmVNnwUKXK/E="; - linuxarm = "sha256-d+DbpER/4lFPcPDFeMG5f3WaUGn8pFchdIDo7Hm0XWs="; - linuxaarch64 = "sha256-8keQzhWq7QlAGIbfHEe3lfxpJleMMvBORuPaNrLmM6Y="; - }.${teensy_architecture} or (throw "No arduino binaries for ${teensy_architecture}"); + sha256 = + { + linux64 = "sha256-4DbhmmYrx+rCBpDrYFaC0A88Qv9UEeNlQAkFi3zAstk="; + linux32 = "sha256-DlRPOtDxmMPv2Qzhib7vNZdKNZCxmm9YmVNnwUKXK/E="; + linuxarm = "sha256-d+DbpER/4lFPcPDFeMG5f3WaUGn8pFchdIDo7Hm0XWs="; + linuxaarch64 = "sha256-8keQzhWq7QlAGIbfHEe3lfxpJleMMvBORuPaNrLmM6Y="; + } + .${teensy_architecture} or (throw "No arduino binaries for ${teensy_architecture}"); }; # Used because teensyduino requires jars be a specific size arduino_dist_src = fetchurl { url = "https://downloads.arduino.cc/arduino-${version}-${teensy_architecture}.tar.xz"; - sha256 = { - linux64 = "sha256-62i93B0cASC+L8oTUKA+40Uxzzf1GEeyEhC25wVFvJs="; - linux32 = "sha256-wSxtx3BqXMQCeWQDK8PHkWLlQqQM1Csao8bIk98FrFg="; - linuxarm = "sha256-lJ/R1ePq7YtDk3bvloFcn8jswrJH+L63tvH5QpTqfXs="; - linuxaarch64 = "sha256-gm8cDjLKNfpcaeO7fw6Kyv1TnWV/ZmH4u++nun9X6jo="; - }.${teensy_architecture} or (throw "No arduino binaries for ${teensy_architecture}"); + sha256 = + { + linux64 = "sha256-62i93B0cASC+L8oTUKA+40Uxzzf1GEeyEhC25wVFvJs="; + linux32 = "sha256-wSxtx3BqXMQCeWQDK8PHkWLlQqQM1Csao8bIk98FrFg="; + linuxarm = "sha256-lJ/R1ePq7YtDk3bvloFcn8jswrJH+L63tvH5QpTqfXs="; + linuxaarch64 = "sha256-gm8cDjLKNfpcaeO7fw6Kyv1TnWV/ZmH4u++nun9X6jo="; + } + .${teensy_architecture} or (throw "No arduino binaries for ${teensy_architecture}"); }; # the glib setup hook will populate GSETTINGS_SCHEMAS_PATH, # wrapGAppHooks (among other things) adds it to XDG_DATA_DIRS # so 'save as...' works: - nativeBuildInputs = [ glib stripJavaArchivesHook wrapGAppsHook3 unzip ]; + nativeBuildInputs = [ + glib + stripJavaArchivesHook + wrapGAppsHook3 + unzip + ]; buildInputs = [ jdk ant @@ -155,7 +182,14 @@ stdenv.mkDerivation rec { javaPath = lib.makeBinPath [ jdk ]; # Everything else will be patched into rpath - rpath = lib.makeLibraryPath [ zlib libusb-compat-0_1 libusb1 readline ncurses5 stdenv.cc.cc ]; + rpath = lib.makeLibraryPath [ + zlib + libusb-compat-0_1 + libusb1 + readline + ncurses5 + stdenv.cc.cc + ]; installPhase = '' mkdir -p $out/share/arduino @@ -217,16 +251,15 @@ stdenv.mkDerivation rec { patchelf --set-rpath ${rpath}:$out/lib $file || true done - ${lib.concatMapStringsSep "\n" - ({ jar, file }: - '' - jar xvf $out/${jar} ${file} - patchelf --set-rpath $rpath ${file} - jar uvf $out/${jar} ${file} - rm -f ${file} - '' - ) - patchelfInJars} + ${lib.concatMapStringsSep "\n" ( + { jar, file }: + '' + jar xvf $out/${jar} ${file} + patchelf --set-rpath $rpath ${file} + jar uvf $out/${jar} ${file} + rm -f ${file} + '' + ) patchelfInJars} # avrdude_bin is linked against libtinfo.so.5 mkdir $out/lib/ @@ -251,6 +284,12 @@ stdenv.mkDerivation rec { binaryNativeCode ]; platforms = platforms.linux; - maintainers = with maintainers; [ antono auntie robberer bjornfor bergey ]; + maintainers = with maintainers; [ + antono + auntie + robberer + bjornfor + bergey + ]; }; } diff --git a/pkgs/development/embedded/arduino/arduino-core/downloads.nix b/pkgs/development/embedded/arduino/arduino-core/downloads.nix index 14ce93d2c50a8f..b450b11378339b 100644 --- a/pkgs/development/embedded/arduino/arduino-core/downloads.nix +++ b/pkgs/development/embedded/arduino/arduino-core/downloads.nix @@ -1,6 +1,7 @@ -{ fetchurl -, optionalAttrs -, system +{ + fetchurl, + optionalAttrs, + system, }: # This file preloads all the archives which Arduino's build/build.xml # would otherwise try to download itself. When updating this for a new diff --git a/pkgs/development/embedded/blisp/default.nix b/pkgs/development/embedded/blisp/default.nix index b6add8db9b8a96..d7b1b6018efc4e 100644 --- a/pkgs/development/embedded/blisp/default.nix +++ b/pkgs/development/embedded/blisp/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, argtable -, cmake -, libserialport -, pkg-config -, testers -, IOKit +{ + lib, + stdenv, + fetchFromGitHub, + argtable, + cmake, + libserialport, + pkg-config, + testers, + IOKit, }: stdenv.mkDerivation (finalAttrs: { @@ -20,7 +21,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-cN35VLbdQFA3KTZ8PxgpbsLGXqfFhw5eh3nEBRZqAm4="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ argtable diff --git a/pkgs/development/embedded/bossa/default.nix b/pkgs/development/embedded/bossa/default.nix index f50b91ddbb0913..05c2d3faddfc11 100644 --- a/pkgs/development/embedded/bossa/default.nix +++ b/pkgs/development/embedded/bossa/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, wxGTK32 -, libX11 -, readline -, darwin -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + wxGTK32, + libX11, + readline, + darwin, + fetchpatch, }: let @@ -47,13 +48,15 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ bin2c ]; - buildInputs = [ - wxGTK32 - libX11 - readline - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Cocoa - ]; + buildInputs = + [ + wxGTK32 + libX11 + readline + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Cocoa + ]; makeFlags = [ "WXVERSION=3.2" diff --git a/pkgs/development/embedded/fpga/apio/default.nix b/pkgs/development/embedded/fpga/apio/default.nix index ef153b96ca49b5..85e011d22dc16e 100644 --- a/pkgs/development/embedded/fpga/apio/default.nix +++ b/pkgs/development/embedded/fpga/apio/default.nix @@ -1,17 +1,18 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, click -, semantic-version -, requests -, colorama -, pyserial -, wheel -, scons -, setuptools -, tinyprog -, flit-core -, pytestCheckHook +{ + lib, + buildPythonApplication, + fetchFromGitHub, + click, + semantic-version, + requests, + colorama, + pyserial, + wheel, + scons, + setuptools, + tinyprog, + flit-core, + pytestCheckHook, }: buildPythonApplication rec { diff --git a/pkgs/development/embedded/fpga/ecpdap/default.nix b/pkgs/development/embedded/fpga/ecpdap/default.nix index 1dfc54e9c3c6ae..faa3790b344082 100644 --- a/pkgs/development/embedded/fpga/ecpdap/default.nix +++ b/pkgs/development/embedded/fpga/ecpdap/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, pkg-config, libusb1, AppKit }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + libusb1, + AppKit, +}: rustPlatform.buildRustPackage rec { pname = "ecpdap"; @@ -15,8 +23,7 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libusb1 ] - ++ lib.optional stdenv.hostPlatform.isDarwin AppKit; + buildInputs = [ libusb1 ] ++ lib.optional stdenv.hostPlatform.isDarwin AppKit; postInstall = '' mkdir -p $out/etc/udev/rules.d @@ -32,7 +39,6 @@ rustPlatform.buildRustPackage rec { ''; homepage = "https://github.com/adamgreig/ecpdap"; license = licenses.asl20; - maintainers = []; + maintainers = [ ]; }; } - diff --git a/pkgs/development/embedded/fpga/fujprog/default.nix b/pkgs/development/embedded/fpga/fujprog/default.nix index bdac1033053af0..fea0900ab2af66 100644 --- a/pkgs/development/embedded/fpga/fujprog/default.nix +++ b/pkgs/development/embedded/fpga/fujprog/default.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, IOKit -, libftdi1 -, libusb-compat-0_1 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + IOKit, + libftdi1, + libusb-compat-0_1, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/embedded/platformio/chrootenv.nix b/pkgs/development/embedded/platformio/chrootenv.nix index 1921d82ae4a381..870ce06d0ede2e 100644 --- a/pkgs/development/embedded/platformio/chrootenv.nix +++ b/pkgs/development/embedded/platformio/chrootenv.nix @@ -1,7 +1,12 @@ -{ lib, buildFHSEnv, platformio-core }: +{ + lib, + buildFHSEnv, + platformio-core, +}: let - pio-pkgs = pkgs: + pio-pkgs = + pkgs: let inherit (platformio-core) python; in @@ -12,7 +17,8 @@ let xdg-user-dirs ncurses udev - ]) ++ (with python.pkgs; [ + ]) + ++ (with python.pkgs; [ python setuptools pip diff --git a/pkgs/development/embedded/platformio/core.nix b/pkgs/development/embedded/platformio/core.nix index 038efbb65bbf59..e9071fa1ab24b7 100644 --- a/pkgs/development/embedded/platformio/core.nix +++ b/pkgs/development/embedded/platformio/core.nix @@ -1,15 +1,16 @@ -{ lib -, python3Packages -, fetchFromGitHub -, fetchpatch -, installShellFiles -, git -, spdx-license-list-data -, substituteAll +{ + lib, + python3Packages, + fetchFromGitHub, + fetchpatch, + installShellFiles, + git, + spdx-license-list-data, + substituteAll, }: - -with python3Packages; buildPythonApplication rec { +with python3Packages; +buildPythonApplication rec { pname = "platformio"; version = "6.1.16"; pyproject = true; @@ -22,7 +23,10 @@ with python3Packages; buildPythonApplication rec { hash = "sha256-hZgbLUk2Krynut5uD6GMxWA+95y8ONNUmv4kaAltumk="; }; - outputs = [ "out" "udev" ]; + outputs = [ + "out" + "udev" + ]; patches = [ (substituteAll { @@ -58,30 +62,32 @@ with python3Packages; buildPythonApplication rec { pythonRelaxDeps = true; - propagatedBuildInputs = [ - aiofiles - ajsonrpc - bottle - click - click-completion - colorama - git - lockfile - marshmallow - pyelftools - pyserial - requests - semantic-version - setuptools - spdx-license-list-data.json - starlette - tabulate - uvicorn - wsproto - zeroconf - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - chardet - ]; + propagatedBuildInputs = + [ + aiofiles + ajsonrpc + bottle + click + click-completion + colorama + git + lockfile + marshmallow + pyelftools + pyserial + requests + semantic-version + setuptools + spdx-license-list-data.json + starlette + tabulate + uvicorn + wsproto + zeroconf + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + chardet + ]; preCheck = '' export HOME=$(mktemp -d) @@ -135,66 +141,68 @@ with python3Packages; buildPythonApplication rec { "test_metadata_dump" ]; - pytestFlagsArray = [ - "tests" - ] ++ (map (e: "--deselect tests/${e}") [ - "commands/pkg/test_exec.py::test_pkg_specified" - "commands/pkg/test_exec.py::test_unrecognized_options" - "commands/test_ci.py::test_ci_boards" - "commands/test_ci.py::test_ci_build_dir" - "commands/test_ci.py::test_ci_keep_build_dir" - "commands/test_ci.py::test_ci_lib_and_board" - "commands/test_ci.py::test_ci_project_conf" - "commands/test_init.py::test_init_custom_framework" - "commands/test_init.py::test_init_duplicated_boards" - "commands/test_init.py::test_init_enable_auto_uploading" - "commands/test_init.py::test_init_ide_atom" - "commands/test_init.py::test_init_ide_clion" - "commands/test_init.py::test_init_ide_eclipse" - "commands/test_init.py::test_init_ide_vscode" - "commands/test_init.py::test_init_incorrect_board" - "commands/test_init.py::test_init_special_board" - "commands/test_lib.py::test_global_install_archive" - "commands/test_lib.py::test_global_install_registry" - "commands/test_lib.py::test_global_install_repository" - "commands/test_lib.py::test_global_lib_list" - "commands/test_lib.py::test_global_lib_uninstall" - "commands/test_lib.py::test_global_lib_update" - "commands/test_lib.py::test_global_lib_update_check" - "commands/test_lib.py::test_install_duplicates" - "commands/test_lib.py::test_lib_show" - "commands/test_lib.py::test_lib_stats" - "commands/test_lib.py::test_saving_deps" - "commands/test_lib.py::test_search" - "commands/test_lib.py::test_update" - "commands/test_lib_complex.py::test_global_install_archive" - "commands/test_lib_complex.py::test_global_install_registry" - "commands/test_lib_complex.py::test_global_install_repository" - "commands/test_lib_complex.py::test_global_lib_list" - "commands/test_lib_complex.py::test_global_lib_uninstall" - "commands/test_lib_complex.py::test_global_lib_update" - "commands/test_lib_complex.py::test_global_lib_update_check" - "commands/test_lib_complex.py::test_install_duplicates" - "commands/test_lib_complex.py::test_lib_show" - "commands/test_lib_complex.py::test_lib_stats" - "commands/test_lib_complex.py::test_search" - "package/test_manager.py::test_download" - "package/test_manager.py::test_install_force" - "package/test_manager.py::test_install_from_registry" - "package/test_manager.py::test_install_lib_depndencies" - "package/test_manager.py::test_registry" - "package/test_manager.py::test_uninstall" - "package/test_manager.py::test_update_with_metadata" - "package/test_manager.py::test_update_without_metadata" - "test_builder.py::test_build_flags" - "test_builder.py::test_build_unflags" - "test_builder.py::test_debug_custom_build_flags" - "test_builder.py::test_debug_default_build_flags" - "test_misc.py::test_api_cache" - "test_misc.py::test_ping_internet_ips" - "test_misc.py::test_platformio_cli" - "test_pkgmanifest.py::test_packages" - ]); + pytestFlagsArray = + [ + "tests" + ] + ++ (map (e: "--deselect tests/${e}") [ + "commands/pkg/test_exec.py::test_pkg_specified" + "commands/pkg/test_exec.py::test_unrecognized_options" + "commands/test_ci.py::test_ci_boards" + "commands/test_ci.py::test_ci_build_dir" + "commands/test_ci.py::test_ci_keep_build_dir" + "commands/test_ci.py::test_ci_lib_and_board" + "commands/test_ci.py::test_ci_project_conf" + "commands/test_init.py::test_init_custom_framework" + "commands/test_init.py::test_init_duplicated_boards" + "commands/test_init.py::test_init_enable_auto_uploading" + "commands/test_init.py::test_init_ide_atom" + "commands/test_init.py::test_init_ide_clion" + "commands/test_init.py::test_init_ide_eclipse" + "commands/test_init.py::test_init_ide_vscode" + "commands/test_init.py::test_init_incorrect_board" + "commands/test_init.py::test_init_special_board" + "commands/test_lib.py::test_global_install_archive" + "commands/test_lib.py::test_global_install_registry" + "commands/test_lib.py::test_global_install_repository" + "commands/test_lib.py::test_global_lib_list" + "commands/test_lib.py::test_global_lib_uninstall" + "commands/test_lib.py::test_global_lib_update" + "commands/test_lib.py::test_global_lib_update_check" + "commands/test_lib.py::test_install_duplicates" + "commands/test_lib.py::test_lib_show" + "commands/test_lib.py::test_lib_stats" + "commands/test_lib.py::test_saving_deps" + "commands/test_lib.py::test_search" + "commands/test_lib.py::test_update" + "commands/test_lib_complex.py::test_global_install_archive" + "commands/test_lib_complex.py::test_global_install_registry" + "commands/test_lib_complex.py::test_global_install_repository" + "commands/test_lib_complex.py::test_global_lib_list" + "commands/test_lib_complex.py::test_global_lib_uninstall" + "commands/test_lib_complex.py::test_global_lib_update" + "commands/test_lib_complex.py::test_global_lib_update_check" + "commands/test_lib_complex.py::test_install_duplicates" + "commands/test_lib_complex.py::test_lib_show" + "commands/test_lib_complex.py::test_lib_stats" + "commands/test_lib_complex.py::test_search" + "package/test_manager.py::test_download" + "package/test_manager.py::test_install_force" + "package/test_manager.py::test_install_from_registry" + "package/test_manager.py::test_install_lib_depndencies" + "package/test_manager.py::test_registry" + "package/test_manager.py::test_uninstall" + "package/test_manager.py::test_update_with_metadata" + "package/test_manager.py::test_update_without_metadata" + "test_builder.py::test_build_flags" + "test_builder.py::test_build_unflags" + "test_builder.py::test_debug_custom_build_flags" + "test_builder.py::test_debug_default_build_flags" + "test_misc.py::test_api_cache" + "test_misc.py::test_ping_internet_ips" + "test_misc.py::test_platformio_cli" + "test_pkgmanifest.py::test_packages" + ]); passthru = { python = python3Packages.python; @@ -206,7 +214,10 @@ with python3Packages; buildPythonApplication rec { downloadPage = "https://github.com/platformio/platformio-core"; homepage = "https://platformio.org"; license = licenses.asl20; - maintainers = with maintainers; [ mog makefu ]; + maintainers = with maintainers; [ + mog + makefu + ]; mainProgram = "platformio"; }; } diff --git a/pkgs/development/embedded/tytools/default.nix b/pkgs/development/embedded/tytools/default.nix index 1669ec239ac79b..76ff17c0b6fece 100644 --- a/pkgs/development/embedded/tytools/default.nix +++ b/pkgs/development/embedded/tytools/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, wrapQtAppsHook , qtbase}: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + wrapQtAppsHook, + qtbase, +}: stdenv.mkDerivation rec { pname = "tytools"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-MKhh0ooDZI1Ks8vVuPRiHhpOqStetGaAhE2ulvBstxA="; }; - nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapQtAppsHook + ]; buildInputs = [ qtbase ]; diff --git a/pkgs/development/gnuradio-modules/mkDerivation.nix b/pkgs/development/gnuradio-modules/mkDerivation.nix index 11ac506260ad03..1f6ee5f2f1ae8f 100644 --- a/pkgs/development/gnuradio-modules/mkDerivation.nix +++ b/pkgs/development/gnuradio-modules/mkDerivation.nix @@ -1,5 +1,6 @@ -{ lib -, unwrapped +{ + lib, + unwrapped, }: mkDerivation: @@ -8,24 +9,30 @@ args: # Check if it's supposed to not get built for the current gnuradio version if (builtins.hasAttr "disabled" args) && args.disabled then -let name = args.name or "${args.pname}"; in -throw "Package ${name} is incompatible with GNURadio ${unwrapped.versionAttr.major}" + let + name = args.name or "${args.pname}"; + in + throw "Package ${name} is incompatible with GNURadio ${unwrapped.versionAttr.major}" else if builtins.hasAttr "disabledForGRafter" args then -throw '' - `disabledForGRafter` is superseded by `disabled`. - Use `disabled = gnuradioAtLeast "${args.disabledForGRafter}";` instead. -'' + throw '' + `disabledForGRafter` is superseded by `disabled`. + Use `disabled = gnuradioAtLeast "${args.disabledForGRafter}";` instead. + '' else -let - args_ = { - enableParallelBuilding = args.enableParallelBuilding or true; - nativeBuildInputs = (args.nativeBuildInputs or []); - # We add gnuradio and volk itself by default - most gnuradio based packages - # will not consider it a depenency worth mentioning and it will almost - # always be needed - buildInputs = (args.buildInputs or []) ++ [ unwrapped unwrapped.volk ]; - }; -in mkDerivation (args // args_) + let + args_ = { + enableParallelBuilding = args.enableParallelBuilding or true; + nativeBuildInputs = (args.nativeBuildInputs or [ ]); + # We add gnuradio and volk itself by default - most gnuradio based packages + # will not consider it a depenency worth mentioning and it will almost + # always be needed + buildInputs = (args.buildInputs or [ ]) ++ [ + unwrapped + unwrapped.volk + ]; + }; + in + mkDerivation (args // args_) diff --git a/pkgs/development/haskell-modules/cabal2nix-unstable.nix b/pkgs/development/haskell-modules/cabal2nix-unstable.nix index 41c4a36ec2eef8..cfa7b7d3352347 100644 --- a/pkgs/development/haskell-modules/cabal2nix-unstable.nix +++ b/pkgs/development/haskell-modules/cabal2nix-unstable.nix @@ -1,10 +1,36 @@ # This file defines cabal2nix-unstable, used by maintainers/scripts/haskell/regenerate-hackage-packages.sh. -{ mkDerivation, aeson, ansi-wl-pprint, base, bytestring, Cabal -, containers, deepseq, directory, distribution-nixpkgs, fetchzip -, filepath, hackage-db, hopenssl, hpack, language-nix, lens, lib -, monad-par, monad-par-extras, mtl, optparse-applicative, pretty -, process, split, tasty, tasty-golden, text, time, transformers -, yaml +{ + mkDerivation, + aeson, + ansi-wl-pprint, + base, + bytestring, + Cabal, + containers, + deepseq, + directory, + distribution-nixpkgs, + fetchzip, + filepath, + hackage-db, + hopenssl, + hpack, + language-nix, + lens, + lib, + monad-par, + monad-par-extras, + mtl, + optparse-applicative, + pretty, + process, + split, + tasty, + tasty-golden, + text, + time, + transformers, + yaml, }: mkDerivation { pname = "cabal2nix"; @@ -17,19 +43,60 @@ mkDerivation { isLibrary = true; isExecutable = true; libraryHaskellDepends = [ - aeson ansi-wl-pprint base bytestring Cabal containers deepseq - directory distribution-nixpkgs filepath hackage-db hopenssl hpack - language-nix lens optparse-applicative pretty process split text - time transformers yaml + aeson + ansi-wl-pprint + base + bytestring + Cabal + containers + deepseq + directory + distribution-nixpkgs + filepath + hackage-db + hopenssl + hpack + language-nix + lens + optparse-applicative + pretty + process + split + text + time + transformers + yaml ]; executableHaskellDepends = [ - aeson base bytestring Cabal containers directory - distribution-nixpkgs filepath hopenssl language-nix lens monad-par - monad-par-extras mtl optparse-applicative pretty + aeson + base + bytestring + Cabal + containers + directory + distribution-nixpkgs + filepath + hopenssl + language-nix + lens + monad-par + monad-par-extras + mtl + optparse-applicative + pretty ]; testHaskellDepends = [ - base Cabal containers directory filepath language-nix lens pretty - process tasty tasty-golden + base + Cabal + containers + directory + filepath + language-nix + lens + pretty + process + tasty + tasty-golden ]; preCheck = '' export PATH="$PWD/dist/build/cabal2nix:$PATH" diff --git a/pkgs/development/haskell-modules/configuration-arm.nix b/pkgs/development/haskell-modules/configuration-arm.nix index 2f4e085855a441..36d746e4e98710 100644 --- a/pkgs/development/haskell-modules/configuration-arm.nix +++ b/pkgs/development/haskell-modules/configuration-arm.nix @@ -27,7 +27,8 @@ in with haskellLib; -self: super: { +self: super: +{ # COMMON ARM OVERRIDES # moved here from configuration-common.nix, no reason given. @@ -39,11 +40,18 @@ self: super: { happy_1_19_12 = doDistribute (dontCheck super.happy_1_19_12); # add arm specific library - wiringPi = overrideCabal ({librarySystemDepends ? [], ...}: { - librarySystemDepends = librarySystemDepends ++ [pkgs.wiringpi]; - }) super.wiringPi; + wiringPi = overrideCabal ( + { + librarySystemDepends ? [ ], + ... + }: + { + librarySystemDepends = librarySystemDepends ++ [ pkgs.wiringpi ]; + } + ) super.wiringPi; -} // lib.optionalAttrs pkgs.stdenv.hostPlatform.isAarch64 { +} +// lib.optionalAttrs pkgs.stdenv.hostPlatform.isAarch64 { # AARCH64-SPECIFIC OVERRIDES # Corrupted store path https://github.com/NixOS/nixpkgs/pull/272097#issuecomment-1848414265 @@ -108,7 +116,8 @@ self: super: { # Similar RTS issue in test suite: # rts/linker/elf_reloc_aarch64.c:98: encodeAddendAarch64: Assertion `isInt64(21+12, addend)' failed. # These still fail sporadically on ghc 9.2 -} // lib.optionalAttrs pkgs.stdenv.hostPlatform.isAarch32 { +} +// lib.optionalAttrs pkgs.stdenv.hostPlatform.isAarch32 { # AARCH32-SPECIFIC OVERRIDES # KAT/ECB/D2 test segfaults on armv7l diff --git a/pkgs/development/haskell-modules/configuration-ghc-8.10.x.nix b/pkgs/development/haskell-modules/configuration-ghc-8.10.x.nix index 33b2da04f77138..6341e1ea1043b3 100644 --- a/pkgs/development/haskell-modules/configuration-ghc-8.10.x.nix +++ b/pkgs/development/haskell-modules/configuration-ghc-8.10.x.nix @@ -11,9 +11,7 @@ self: super: { # ghcjs does not use `llvmPackages` and exposes `null` attribute. llvmPackages = - if self.ghc.llvmPackages != null - then pkgs.lib.dontRecurseIntoAttrs self.ghc.llvmPackages - else null; + if self.ghc.llvmPackages != null then pkgs.lib.dontRecurseIntoAttrs self.ghc.llvmPackages else null; # Disable GHC 8.10.x core libraries. array = null; @@ -44,7 +42,11 @@ self: super: { stm = null; template-haskell = null; # GHC only builds terminfo if it is a native compiler - terminfo = if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then null else doDistribute self.terminfo_0_4_1_6; + terminfo = + if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then + null + else + doDistribute self.terminfo_0_4_1_6; text = null; time = null; transformers = null; @@ -62,12 +64,17 @@ self: super: { # For GHC < 9.4, some packages need data-array-byte as an extra dependency # For GHC < 9.2, os-string is not required. primitive = addBuildDepends [ self.data-array-byte ] super.primitive; - hashable = addBuildDepends [ - self.data-array-byte - self.base-orphans - ] (super.hashable.override { - os-string = null; - }); + hashable = + addBuildDepends + [ + self.data-array-byte + self.base-orphans + ] + ( + super.hashable.override { + os-string = null; + } + ); hashable-time = doDistribute (unmarkBroken super.hashable-time); # Too strict lower bounds on base @@ -92,13 +99,14 @@ self: super: { shower = doJailbreak super.shower; # hnix 0.9.0 does not provide an executable for ghc < 8.10, so define completions here for now. - hnix = self.generateOptparseApplicativeCompletions [ "hnix" ] - (overrideCabal (drv: { + hnix = self.generateOptparseApplicativeCompletions [ "hnix" ] ( + overrideCabal (drv: { # executable is allowed for ghc >= 8.10 and needs repline - executableHaskellDepends = drv.executableToolDepends or [] ++ [ self.repline ]; - }) super.hnix); + executableHaskellDepends = drv.executableToolDepends or [ ] ++ [ self.repline ]; + }) super.hnix + ); - haskell-language-server = throw "haskell-language-server dropped support for ghc 8.10 in version 2.3.0.0 please use a newer ghc version or an older nixpkgs version"; + haskell-language-server = throw "haskell-language-server dropped support for ghc 8.10 in version 2.3.0.0 please use a newer ghc version or an older nixpkgs version"; ghc-lib-parser = doDistribute self.ghc-lib-parser_9_2_8_20230729; ghc-lib-parser-ex = doDistribute self.ghc-lib-parser-ex_9_2_1_1; @@ -113,11 +121,13 @@ self: super: { # weeder 2.3.* no longer supports GHC 8.10 weeder = doDistribute (doJailbreak self.weeder_2_2_0); # Unnecessarily strict upper bound on lens - weeder_2_2_0 = doJailbreak (super.weeder_2_2_0.override { - # weeder < 2.6 only supports algebraic-graphs < 0.7 - # We no longer have matching test deps for algebraic-graphs 0.6.1 in the set - algebraic-graphs = dontCheck self.algebraic-graphs_0_6_1; - }); + weeder_2_2_0 = doJailbreak ( + super.weeder_2_2_0.override { + # weeder < 2.6 only supports algebraic-graphs < 0.7 + # We no longer have matching test deps for algebraic-graphs 0.6.1 in the set + algebraic-graphs = dontCheck self.algebraic-graphs_0_6_1; + } + ); # Uses haddock placement that isn't supported by the versions of haddock # bundled with GHC < 9.0. @@ -171,23 +181,25 @@ self: super: { http-types = dontCheck super.http-types; # Packages which need compat library for GHC < 9.6 - inherit - (lib.mapAttrs - (_: addBuildDepends [ self.foldable1-classes-compat ]) - super) + inherit (lib.mapAttrs (_: addBuildDepends [ self.foldable1-classes-compat ]) super) indexed-traversable these - ; + ; base-compat-batteries = addBuildDepends [ self.foldable1-classes-compat self.OneTuple ] super.base-compat-batteries; # OneTuple needs hashable (instead of ghc-prim) and foldable1-classes-compat for GHC < 9 - OneTuple = addBuildDepends [ - self.foldable1-classes-compat - self.base-orphans - ] (super.OneTuple.override { - ghc-prim = self.hashable; - }); + OneTuple = + addBuildDepends + [ + self.foldable1-classes-compat + self.base-orphans + ] + ( + super.OneTuple.override { + ghc-prim = self.hashable; + } + ); } diff --git a/pkgs/development/haskell-modules/configuration-ghc-8.6.x.nix b/pkgs/development/haskell-modules/configuration-ghc-8.6.x.nix index 6fd85c971e239f..865df383f05f39 100644 --- a/pkgs/development/haskell-modules/configuration-ghc-8.6.x.nix +++ b/pkgs/development/haskell-modules/configuration-ghc-8.6.x.nix @@ -39,7 +39,11 @@ self: super: { stm = null; template-haskell = null; # GHC only builds terminfo if it is a native compiler - terminfo = if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then null else doDistribute self.terminfo_0_4_1_6; + terminfo = + if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then + null + else + doDistribute self.terminfo_0_4_1_6; text = null; time = null; transformers = null; @@ -61,7 +65,7 @@ self: super: { unordered-containers = dontCheck super.unordered-containers; # Test suite does not compile. - data-clist = doJailbreak super.data-clist; # won't cope with QuickCheck 2.12.x + data-clist = doJailbreak super.data-clist; # won't cope with QuickCheck 2.12.x dates = doJailbreak super.dates; # base >=4.9 && <4.12 Diff = dontCheck super.Diff; equivalence = dontCheck super.equivalence; # test suite doesn't compile https://github.com/pa-ba/equivalence/issues/5 diff --git a/pkgs/development/haskell-modules/configuration-ghc-9.0.x.nix b/pkgs/development/haskell-modules/configuration-ghc-9.0.x.nix index 45cbd487762b29..e53dab2b4b8456 100644 --- a/pkgs/development/haskell-modules/configuration-ghc-9.0.x.nix +++ b/pkgs/development/haskell-modules/configuration-ghc-9.0.x.nix @@ -41,7 +41,11 @@ self: super: { stm = null; template-haskell = null; # GHC only builds terminfo if it is a native compiler - terminfo = if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then null else doDistribute self.terminfo_0_4_1_6; + terminfo = + if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then + null + else + doDistribute self.terminfo_0_4_1_6; text = null; time = null; transformers = null; @@ -61,12 +65,17 @@ self: super: { # For GHC < 9.4, some packages need data-array-byte as an extra dependency primitive = addBuildDepends [ self.data-array-byte ] super.primitive; # For GHC < 9.2, os-string is not required. - hashable = addBuildDepends [ - self.data-array-byte - self.base-orphans - ] (super.hashable.override { - os-string = null; - }); + hashable = + addBuildDepends + [ + self.data-array-byte + self.base-orphans + ] + ( + super.hashable.override { + os-string = null; + } + ); # Too strict lower bounds on base primitive-addr = doJailbreak super.primitive-addr; @@ -83,7 +92,7 @@ self: super: { doctest = dontCheck super.doctest; - haskell-language-server = throw "haskell-language-server has dropped support for ghc 9.0 in version 2.4.0.0, please use a newer ghc version or an older nixpkgs version"; + haskell-language-server = throw "haskell-language-server has dropped support for ghc 9.0 in version 2.4.0.0, please use a newer ghc version or an older nixpkgs version"; # Needs to use ghc-lib due to incompatible GHC ghc-tags = doDistribute (addBuildDepend self.ghc-lib self.ghc-tags_1_5); @@ -106,7 +115,7 @@ self: super: { # 2021-09-18: cabal2nix does not detect the need for ghc-api-compat. hiedb = overrideCabal (old: { - libraryHaskellDepends = old.libraryHaskellDepends ++ [self.ghc-api-compat]; + libraryHaskellDepends = old.libraryHaskellDepends ++ [ self.ghc-api-compat ]; }) super.hiedb; # https://github.com/lspitzner/butcher/issues/7 @@ -115,17 +124,19 @@ self: super: { # We use a GHC patch to support the fix for https://github.com/fpco/inline-c/issues/127 # which means that the upstream cabal file isn't allowed to add the flag. inline-c-cpp = - (if isDarwin then appendConfigureFlags ["--ghc-option=-fcompact-unwind"] else x: x) - super.inline-c-cpp; + (if isDarwin then appendConfigureFlags [ "--ghc-option=-fcompact-unwind" ] else x: x) + super.inline-c-cpp; # 2022-05-31: weeder 2.4.* requires GHC 9.2 weeder = doDistribute self.weeder_2_3_1; # Unnecessarily strict upper bound on lens - weeder_2_3_1 = doJailbreak (super.weeder_2_3_1.override { - # weeder < 2.6 only supports algebraic-graphs < 0.7 - # We no longer have matching test deps for algebraic-graphs 0.6.1 in the set - algebraic-graphs = dontCheck self.algebraic-graphs_0_6_1; - }); + weeder_2_3_1 = doJailbreak ( + super.weeder_2_3_1.override { + # weeder < 2.6 only supports algebraic-graphs < 0.7 + # We no longer have matching test deps for algebraic-graphs 0.6.1 in the set + algebraic-graphs = dontCheck self.algebraic-graphs_0_6_1; + } + ); # Restrictive upper bound on base and containers sv2v = doJailbreak super.sv2v; @@ -149,13 +160,10 @@ self: super: { http-types = dontCheck super.http-types; # Packages which need compat library for GHC < 9.6 - inherit - (lib.mapAttrs - (_: addBuildDepends [ self.foldable1-classes-compat ]) - super) + inherit (lib.mapAttrs (_: addBuildDepends [ self.foldable1-classes-compat ]) super) indexed-traversable these - ; + ; base-compat-batteries = addBuildDepends [ self.foldable1-classes-compat self.OneTuple diff --git a/pkgs/development/haskell-modules/configuration-ghc-9.12.x.nix b/pkgs/development/haskell-modules/configuration-ghc-9.12.x.nix index adc18963062021..da44762d969e4a 100644 --- a/pkgs/development/haskell-modules/configuration-ghc-9.12.x.nix +++ b/pkgs/development/haskell-modules/configuration-ghc-9.12.x.nix @@ -45,7 +45,11 @@ self: super: { system-cxx-std-lib = null; template-haskell = null; # GHC only builds terminfo if it is a native compiler - terminfo = if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then null else haskellLib.doDistribute self.terminfo_0_4_1_6; + terminfo = + if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then + null + else + haskellLib.doDistribute self.terminfo_0_4_1_6; text = null; time = null; transformers = null; diff --git a/pkgs/development/haskell-modules/configuration-ghc-9.2.x.nix b/pkgs/development/haskell-modules/configuration-ghc-9.2.x.nix index eb31f4582a872d..d81d457418c52b 100644 --- a/pkgs/development/haskell-modules/configuration-ghc-9.2.x.nix +++ b/pkgs/development/haskell-modules/configuration-ghc-9.2.x.nix @@ -41,7 +41,11 @@ self: super: { stm = null; template-haskell = null; # GHC only builds terminfo if it is a native compiler - terminfo = if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then null else doDistribute self.terminfo_0_4_1_6; + terminfo = + if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then + null + else + doDistribute self.terminfo_0_4_1_6; text = null; time = null; transformers = null; @@ -59,23 +63,27 @@ self: super: { # weeder >= 2.5 requires GHC 9.4 weeder = doDistribute self.weeder_2_4_1; # Allow dhall 1.42.* - weeder_2_4_1 = doJailbreak (super.weeder_2_4_1.override { - # weeder < 2.6 only supports algebraic-graphs < 0.7 - # We no longer have matching test deps for algebraic-graphs 0.6.1 in the set - algebraic-graphs = dontCheck self.algebraic-graphs_0_6_1; - }); - + weeder_2_4_1 = doJailbreak ( + super.weeder_2_4_1.override { + # weeder < 2.6 only supports algebraic-graphs < 0.7 + # We no longer have matching test deps for algebraic-graphs 0.6.1 in the set + algebraic-graphs = dontCheck self.algebraic-graphs_0_6_1; + } + ); haskell-language-server = lib.pipe super.haskell-language-server [ (disableCabalFlag "fourmolu") (disableCabalFlag "ormolu") (disableCabalFlag "cabal") (disableCabalFlag "stylishHaskell") - (d: d.override { - ormolu = null; - fourmolu = null; - stan = null; - }) + ( + d: + d.override { + ormolu = null; + fourmolu = null; + stan = null; + } + ) ]; # For GHC < 9.4, some packages need data-array-byte as an extra dependency @@ -115,8 +123,8 @@ self: super: { # https://github.com/fpco/inline-c/pull/131 inline-c-cpp = - (if isDarwin then appendConfigureFlags ["--ghc-option=-fcompact-unwind"] else x: x) - super.inline-c-cpp; + (if isDarwin then appendConfigureFlags [ "--ghc-option=-fcompact-unwind" ] else x: x) + super.inline-c-cpp; # A given major version of ghc-exactprint only supports one version of GHC. ghc-exactprint = super.ghc-exactprint_1_5_0; @@ -125,14 +133,11 @@ self: super: { ghc-source-gen = doDistribute (unmarkBroken super.ghc-source-gen); # Packages which need compat library for GHC < 9.6 - inherit - (lib.mapAttrs - (_: addBuildDepends [ self.foldable1-classes-compat ]) - super) + inherit (lib.mapAttrs (_: addBuildDepends [ self.foldable1-classes-compat ]) super) indexed-traversable OneTuple these - ; + ; base-compat-batteries = addBuildDepends [ self.foldable1-classes-compat self.OneTuple diff --git a/pkgs/development/haskell-modules/configuration-ghc-9.4.x.nix b/pkgs/development/haskell-modules/configuration-ghc-9.4.x.nix index 9969456cee09d3..18ba0d1af60c94 100644 --- a/pkgs/development/haskell-modules/configuration-ghc-9.4.x.nix +++ b/pkgs/development/haskell-modules/configuration-ghc-9.4.x.nix @@ -2,16 +2,20 @@ let inherit (pkgs) fetchpatch lib; - checkAgainAfter = pkg: ver: msg: act: - if builtins.compareVersions pkg.version ver <= 0 then act + checkAgainAfter = + pkg: ver: msg: act: + if builtins.compareVersions pkg.version ver <= 0 then + act else builtins.throw "Check if '${msg}' was resolved in ${pkg.pname} ${pkg.version} and update or remove this"; in with haskellLib; -self: super: let +self: super: +let jailbreakForCurrentVersion = p: v: checkAgainAfter p v "bad bounds" (doJailbreak p); -in { +in +{ llvmPackages = lib.dontRecurseIntoAttrs self.ghc.llvmPackages; # Disable GHC core libraries. @@ -46,7 +50,11 @@ in { system-cxx-std-lib = null; template-haskell = null; # GHC only builds terminfo if it is a native compiler - terminfo = if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then null else doDistribute self.terminfo_0_4_1_6; + terminfo = + if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then + null + else + doDistribute self.terminfo_0_4_1_6; text = null; time = null; transformers = null; @@ -75,7 +83,7 @@ in { # 2021-10-10: 9.2.1 is not yet supported (also no issue) testFlags = [ "--skip=/Hpack/renderCabalFile/is inverse to readCabalFile/" - ] ++ drv.testFlags or []; + ] ++ drv.testFlags or [ ]; }) (doJailbreak super.hpack); # https://github.com/sjakobi/bsb-http-chunked/issues/38 @@ -119,17 +127,14 @@ in { ormolu hlint stylish-haskell - ; + ; # Packages which need compat library for GHC < 9.6 - inherit - (lib.mapAttrs - (_: addBuildDepends [ self.foldable1-classes-compat ]) - super) + inherit (lib.mapAttrs (_: addBuildDepends [ self.foldable1-classes-compat ]) super) indexed-traversable OneTuple these - ; + ; base-compat-batteries = addBuildDepends [ self.foldable1-classes-compat self.OneTuple diff --git a/pkgs/development/haskell-modules/configuration-ghc-9.6.x.nix b/pkgs/development/haskell-modules/configuration-ghc-9.6.x.nix index b6485a111b20e2..694b21a5e4824a 100644 --- a/pkgs/development/haskell-modules/configuration-ghc-9.6.x.nix +++ b/pkgs/development/haskell-modules/configuration-ghc-9.6.x.nix @@ -5,19 +5,25 @@ with haskellLib; let inherit (pkgs) lib; - jailbreakWhileRevision = rev: + jailbreakWhileRevision = + rev: overrideCabal (old: { - jailbreak = assert old.revision or "0" == toString rev; true; + jailbreak = + assert old.revision or "0" == toString rev; + true; }); - checkAgainAfter = pkg: ver: msg: act: - if builtins.compareVersions pkg.version ver <= 0 then act + checkAgainAfter = + pkg: ver: msg: act: + if builtins.compareVersions pkg.version ver <= 0 then + act else builtins.throw "Check if '${msg}' was resolved in ${pkg.pname} ${pkg.version} and update or remove this"; jailbreakForCurrentVersion = p: v: checkAgainAfter p v "bad bounds" (doJailbreak p); in -self: super: { +self: super: +{ llvmPackages = lib.dontRecurseIntoAttrs self.ghc.llvmPackages; # Disable GHC core libraries @@ -52,7 +58,11 @@ self: super: { system-cxx-std-lib = null; template-haskell = null; # terminfo is not built if GHC is a cross compiler - terminfo = if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then null else doDistribute self.terminfo_0_4_1_6; + terminfo = + if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then + null + else + doDistribute self.terminfo_0_4_1_6; text = null; time = null; transformers = null; @@ -99,13 +109,13 @@ self: super: { # https://github.com/kowainik/relude/issues/436 relude = dontCheck (doJailbreak super.relude); - inherit (pkgs.lib.mapAttrs (_: doJailbreak ) super) + inherit (pkgs.lib.mapAttrs (_: doJailbreak) super) ghc-trace-events - gi-cairo-connector # mtl <2.3 - ghc-prof # base <4.18 - env-guard # doctest <0.21 - package-version # doctest <0.21, tasty-hedgehog <1.4 - ; + gi-cairo-connector # mtl <2.3 + ghc-prof # base <4.18 + env-guard # doctest <0.21 + package-version # doctest <0.21, tasty-hedgehog <1.4 + ; # Pending text-2.0 support https://github.com/gtk2hs/gtk2hs/issues/327 gtk = doJailbreak super.gtk; @@ -119,54 +129,58 @@ self: super: { # This can be removed once https://github.com/typeclasses/ascii-predicates/pull/1 # is merged and in a release that's being tracked. - ascii-predicates = appendPatch - (pkgs.fetchpatch - { url = "https://github.com/typeclasses/ascii-predicates/commit/2e6d9ed45987a8566f3a77eedf7836055c076d1a.patch"; - name = "ascii-predicates-pull-1.patch"; - relative = "ascii-predicates"; - sha256 = "sha256-4JguQFZNRQpjZThLrAo13jNeypvLfqFp6o7c1bnkmZo="; - }) - super.ascii-predicates; + ascii-predicates = appendPatch (pkgs.fetchpatch { + url = "https://github.com/typeclasses/ascii-predicates/commit/2e6d9ed45987a8566f3a77eedf7836055c076d1a.patch"; + name = "ascii-predicates-pull-1.patch"; + relative = "ascii-predicates"; + sha256 = "sha256-4JguQFZNRQpjZThLrAo13jNeypvLfqFp6o7c1bnkmZo="; + }) super.ascii-predicates; # This can be removed once https://github.com/typeclasses/ascii-numbers/pull/1 # is merged and in a release that's being tracked. - ascii-numbers = appendPatch - (pkgs.fetchpatch - { url = "https://github.com/typeclasses/ascii-numbers/commit/e9474ad91bc997891f1a46afd5d0bdf9b9f7d768.patch"; - name = "ascii-numbers-pull-1.patch"; - relative = "ascii-numbers"; - sha256 = "sha256-buw1UeW57CFefEfqdDUraSyQ+H/NvCZOv6WF2ORiYQg="; - }) - super.ascii-numbers; + ascii-numbers = appendPatch (pkgs.fetchpatch { + url = "https://github.com/typeclasses/ascii-numbers/commit/e9474ad91bc997891f1a46afd5d0bdf9b9f7d768.patch"; + name = "ascii-numbers-pull-1.patch"; + relative = "ascii-numbers"; + sha256 = "sha256-buw1UeW57CFefEfqdDUraSyQ+H/NvCZOv6WF2ORiYQg="; + }) super.ascii-numbers; # Apply patch from PR with mtl-2.3 fix. ConfigFile = overrideCabal (drv: { editedCabalFile = null; - buildDepends = drv.buildDepends or [] ++ [ self.HUnit ]; - patches = [(pkgs.fetchpatch { - # https://github.com/jgoerzen/configfile/pull/12 - name = "ConfigFile-pr-12.patch"; - url = "https://github.com/jgoerzen/configfile/compare/d0a2e654be0b73eadbf2a50661d00574ad7b6f87...83ee30b43f74d2b6781269072cf5ed0f0e00012f.patch"; - sha256 = "sha256-b7u9GiIAd2xpOrM0MfILHNb6Nt7070lNRIadn2l3DfQ="; - })]; + buildDepends = drv.buildDepends or [ ] ++ [ self.HUnit ]; + patches = [ + (pkgs.fetchpatch { + # https://github.com/jgoerzen/configfile/pull/12 + name = "ConfigFile-pr-12.patch"; + url = "https://github.com/jgoerzen/configfile/compare/d0a2e654be0b73eadbf2a50661d00574ad7b6f87...83ee30b43f74d2b6781269072cf5ed0f0e00012f.patch"; + sha256 = "sha256-b7u9GiIAd2xpOrM0MfILHNb6Nt7070lNRIadn2l3DfQ="; + }) + ]; }) super.ConfigFile; # Compatibility with core libs of GHC 9.6 # Jailbreak to lift bound on time - kqueue = doJailbreak (appendPatches [ - (pkgs.fetchpatch { - name = "kqueue-ghc-9.6.patch"; - url = "https://github.com/hesselink/kqueue/pull/10/commits/a2735e807d761410e776482ec04515d9cf76a7f5.patch"; - sha256 = "18rilz4nrwcmlvll3acjx2lp7s129pviggb8fy3hdb0z34ls5j84"; - excludes = [ ".gitignore" ]; - }) - ] super.kqueue); + kqueue = doJailbreak ( + appendPatches [ + (pkgs.fetchpatch { + name = "kqueue-ghc-9.6.patch"; + url = "https://github.com/hesselink/kqueue/pull/10/commits/a2735e807d761410e776482ec04515d9cf76a7f5.patch"; + sha256 = "18rilz4nrwcmlvll3acjx2lp7s129pviggb8fy3hdb0z34ls5j84"; + excludes = [ ".gitignore" ]; + }) + ] super.kqueue + ); # This runs into the following GHC bug currently affecting 9.6.* and 9.8.* as # well as 9.10.1: https://gitlab.haskell.org/ghc/ghc/-/issues/24432 - inherit (lib.mapAttrs (_: overrideCabal (drv: { - badPlatforms = drv.badPlatforms or [ ] ++ [ "aarch64-linux" ]; - })) super) + inherit + (lib.mapAttrs ( + _: + overrideCabal (drv: { + badPlatforms = drv.badPlatforms or [ ] ++ [ "aarch64-linux" ]; + }) + ) super) mueval lambdabot lambdabot-haskell-plugins @@ -175,13 +189,15 @@ self: super: { singletons-base = dontCheck super.singletons-base; } # super.ghc is required to break infinite recursion as Nix is strict in the attrNames -// lib.optionalAttrs (pkgs.stdenv.hostPlatform.isAarch64 && lib.versionOlder super.ghc.version "9.6.4") { - # The NCG backend for aarch64 generates invalid jumps in some situations, - # the workaround on 9.6 is to revert to the LLVM backend (which is used - # for these sorts of situations even on 9.2 and 9.4). - # https://gitlab.haskell.org/ghc/ghc/-/issues/23746#note_525318 - inherit (lib.mapAttrs (_: self.forceLlvmCodegenBackend) super) - tls - mmark - ; -} +// + lib.optionalAttrs (pkgs.stdenv.hostPlatform.isAarch64 && lib.versionOlder super.ghc.version "9.6.4") + { + # The NCG backend for aarch64 generates invalid jumps in some situations, + # the workaround on 9.6 is to revert to the LLVM backend (which is used + # for these sorts of situations even on 9.2 and 9.4). + # https://gitlab.haskell.org/ghc/ghc/-/issues/23746#note_525318 + inherit (lib.mapAttrs (_: self.forceLlvmCodegenBackend) super) + tls + mmark + ; + } diff --git a/pkgs/development/haskell-modules/configuration-ghcjs-8.x.nix b/pkgs/development/haskell-modules/configuration-ghcjs-8.x.nix index 3f6e399f795b81..4c532de28bf20d 100644 --- a/pkgs/development/haskell-modules/configuration-ghcjs-8.x.nix +++ b/pkgs/development/haskell-modules/configuration-ghcjs-8.x.nix @@ -5,8 +5,8 @@ { pkgs, haskellLib }: let - removeLibraryHaskellDepends = pnames: depends: - builtins.filter (e: !(builtins.elem (e.pname or "") pnames)) depends; + removeLibraryHaskellDepends = + pnames: depends: builtins.filter (e: !(builtins.elem (e.pname or "") pnames)) depends; in with haskellLib; @@ -16,13 +16,21 @@ self: super: ## GENERAL SETUP BASE PACKAGES { inherit (self.ghc.bootPkgs) - jailbreak-cabal alex happy gtk2hs-buildtools rehoo hoogle; + jailbreak-cabal + alex + happy + gtk2hs-buildtools + rehoo + hoogle + ; # Test suite fails; https://github.com/ghcjs/ghcjs-base/issues/133 - ghcjs-base = dontCheck (self.callPackage ../compilers/ghcjs/ghcjs-base.nix { - fetchFromGitHub = pkgs.buildPackages.fetchFromGitHub; - aeson = self.aeson_1_5_6_0; - }); + ghcjs-base = dontCheck ( + self.callPackage ../compilers/ghcjs/ghcjs-base.nix { + fetchFromGitHub = pkgs.buildPackages.fetchFromGitHub; + aeson = self.aeson_1_5_6_0; + } + ); # Included in ghcjs itself ghcjs-prim = null; @@ -34,7 +42,7 @@ self: super: stm = doJailbreak self.stm_2_5_3_1; exceptions = dontCheck self.exceptions_0_10_8; -## OTHER PACKAGES + ## OTHER PACKAGES # Runtime exception in tests, missing C API h$realloc base-compat-batteries = dontCheck super.base-compat-batteries; @@ -50,13 +58,22 @@ self: super: ghcjs-dom = overrideCabal (drv: { libraryHaskellDepends = with self; [ - ghcjs-base ghcjs-dom-jsffi text transformers + ghcjs-base + ghcjs-dom-jsffi + text + transformers + ]; + configureFlags = [ + "-fjsffi" + "-f-webkit" ]; - configureFlags = [ "-fjsffi" "-f-webkit" ]; }) super.ghcjs-dom; ghcjs-dom-jsffi = overrideCabal (drv: { - libraryHaskellDepends = (drv.libraryHaskellDepends or []) ++ [ self.ghcjs-base self.text ]; + libraryHaskellDepends = (drv.libraryHaskellDepends or [ ]) ++ [ + self.ghcjs-base + self.text + ]; broken = false; }) super.ghcjs-dom-jsffi; @@ -70,7 +87,7 @@ self: super: http-types = dontCheck super.http-types; jsaddle = overrideCabal (drv: { - libraryHaskellDepends = (drv.libraryHaskellDepends or []) ++ [ self.ghcjs-base ]; + libraryHaskellDepends = (drv.libraryHaskellDepends or [ ]) ++ [ self.ghcjs-base ]; }) super.jsaddle; # Tests hang, possibly some issue with tasty and race(async) usage in the nonTerminating tests @@ -85,11 +102,13 @@ self: super: QuickCheck = dontCheck super.QuickCheck; reflex = overrideCabal (drv: { - libraryHaskellDepends = (drv.libraryHaskellDepends or []) ++ [ self.ghcjs-base ]; + libraryHaskellDepends = (drv.libraryHaskellDepends or [ ]) ++ [ self.ghcjs-base ]; }) super.reflex; reflex-dom = overrideCabal (drv: { - libraryHaskellDepends = removeLibraryHaskellDepends ["jsaddle-webkit2gtk"] (drv.libraryHaskellDepends or []); + libraryHaskellDepends = removeLibraryHaskellDepends [ "jsaddle-webkit2gtk" ] ( + drv.libraryHaskellDepends or [ ] + ); }) super.reflex-dom; # https://github.com/dreixel/syb/issues/21 diff --git a/pkgs/development/haskell-modules/configuration-tensorflow.nix b/pkgs/development/haskell-modules/configuration-tensorflow.nix index 634f521e5aa491..2f2727159449ff 100644 --- a/pkgs/development/haskell-modules/configuration-tensorflow.nix +++ b/pkgs/development/haskell-modules/configuration-tensorflow.nix @@ -16,16 +16,18 @@ let fetchSubmodules = true; }; - setTensorflowSourceRoot = dir: drv: - (overrideCabal (drv: { src = tensorflow-haskell; }) drv) - .overrideAttrs (_oldAttrs: { sourceRoot = "${tensorflow-haskell.name}/${dir}"; }); + setTensorflowSourceRoot = + dir: drv: + (overrideCabal (drv: { src = tensorflow-haskell; }) drv).overrideAttrs (_oldAttrs: { + sourceRoot = "${tensorflow-haskell.name}/${dir}"; + }); in { tensorflow-proto = doJailbreak (setTensorflowSourceRoot "tensorflow-proto" super.tensorflow-proto); - tensorflow = overrideCabal - (drv: { libraryHaskellDepends = drv.libraryHaskellDepends ++ [self.vector-split]; }) - (setTensorflowSourceRoot "tensorflow" super.tensorflow); + tensorflow = overrideCabal (drv: { + libraryHaskellDepends = drv.libraryHaskellDepends ++ [ self.vector-split ]; + }) (setTensorflowSourceRoot "tensorflow" super.tensorflow); tensorflow-core-ops = setTensorflowSourceRoot "tensorflow-core-ops" super.tensorflow-core-ops; diff --git a/pkgs/development/haskell-modules/default.nix b/pkgs/development/haskell-modules/default.nix index db247f70305274..8d34d6f4b2a8d5 100644 --- a/pkgs/development/haskell-modules/default.nix +++ b/pkgs/development/haskell-modules/default.nix @@ -1,15 +1,21 @@ -{ pkgs, stdenv, lib, haskellLib, ghc, all-cabal-hashes -, buildHaskellPackages -, compilerConfig ? (self: super: {}) -, packageSetConfig ? (self: super: {}) -, overrides ? (self: super: {}) -, initialPackages ? import ./initial-packages.nix -, nonHackagePackages ? import ./non-hackage-packages.nix -, configurationCommon ? import ./configuration-common.nix -, configurationNix ? import ./configuration-nix.nix -, configurationArm ? import ./configuration-arm.nix -, configurationDarwin ? import ./configuration-darwin.nix -, configurationJS ? import ./configuration-ghcjs-9.x.nix +{ + pkgs, + stdenv, + lib, + haskellLib, + ghc, + all-cabal-hashes, + buildHaskellPackages, + compilerConfig ? (self: super: { }), + packageSetConfig ? (self: super: { }), + overrides ? (self: super: { }), + initialPackages ? import ./initial-packages.nix, + nonHackagePackages ? import ./non-hackage-packages.nix, + configurationCommon ? import ./configuration-common.nix, + configurationNix ? import ./configuration-nix.nix, + configurationArm ? import ./configuration-arm.nix, + configurationDarwin ? import ./configuration-darwin.nix, + configurationJS ? import ./configuration-ghcjs-9.x.nix, }: let @@ -19,33 +25,47 @@ let haskellPackages = pkgs.callPackage makePackageSet { package-set = initialPackages; - inherit stdenv haskellLib ghc extensible-self all-cabal-hashes; + inherit + stdenv + haskellLib + ghc + extensible-self + all-cabal-hashes + ; # Prevent `pkgs/top-level/release-attrpaths-superset.nix` from recursing here. - buildHaskellPackages = buildHaskellPackages // { __attrsFailEvaluation = true; }; + buildHaskellPackages = buildHaskellPackages // { + __attrsFailEvaluation = true; + }; }; - platformConfigurations = lib.optionals stdenv.hostPlatform.isAarch [ - (configurationArm { inherit pkgs haskellLib; }) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - (configurationDarwin { inherit pkgs haskellLib; }) - ] ++ lib.optionals stdenv.hostPlatform.isGhcjs [ - (configurationJS { inherit pkgs haskellLib; }) - ] - ; - - extensions = lib.composeManyExtensions ([ - (nonHackagePackages { inherit pkgs haskellLib; }) - (configurationNix { inherit pkgs haskellLib; }) - (configurationCommon { inherit pkgs haskellLib; }) - ] ++ platformConfigurations ++ [ - compilerConfig - packageSetConfig - overrides - ]); + platformConfigurations = + lib.optionals stdenv.hostPlatform.isAarch [ + (configurationArm { inherit pkgs haskellLib; }) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + (configurationDarwin { inherit pkgs haskellLib; }) + ] + ++ lib.optionals stdenv.hostPlatform.isGhcjs [ + (configurationJS { inherit pkgs haskellLib; }) + ]; + + extensions = lib.composeManyExtensions ( + [ + (nonHackagePackages { inherit pkgs haskellLib; }) + (configurationNix { inherit pkgs haskellLib; }) + (configurationCommon { inherit pkgs haskellLib; }) + ] + ++ platformConfigurations + ++ [ + compilerConfig + packageSetConfig + overrides + ] + ); extensible-self = makeExtensible (extends extensions haskellPackages); in - extensible-self +extensible-self diff --git a/pkgs/development/haskell-modules/generic-stack-builder.nix b/pkgs/development/haskell-modules/generic-stack-builder.nix index eae0337effc07a..d2f6beb5260c6c 100644 --- a/pkgs/development/haskell-modules/generic-stack-builder.nix +++ b/pkgs/development/haskell-modules/generic-stack-builder.nix @@ -1,13 +1,22 @@ -{ stdenv, ghc, pkg-config, glibcLocales -, cacert, stack, makeSetupHook, lib }@depArgs: - -{ buildInputs ? [] -, nativeBuildInputs ? [] -, extraArgs ? [] -, LD_LIBRARY_PATH ? [] -, ghc ? depArgs.ghc -, stack ? depArgs.stack -, ... +{ + stdenv, + ghc, + pkg-config, + glibcLocales, + cacert, + stack, + makeSetupHook, + lib, +}@depArgs: + +{ + buildInputs ? [ ], + nativeBuildInputs ? [ ], + extraArgs ? [ ], + LD_LIBRARY_PATH ? [ ], + ghc ? depArgs.ghc, + stack ? depArgs.stack, + ... }@args: let @@ -20,61 +29,71 @@ let name = "stack-hook"; } ./stack-hook.sh; -in stdenv.mkDerivation (args // { +in +stdenv.mkDerivation ( + args + // { - # Doesn't work in the sandbox. Pass `--option sandbox relaxed` or - # `--option sandbox false` to be able to build this - __noChroot = true; + # Doesn't work in the sandbox. Pass `--option sandbox relaxed` or + # `--option sandbox false` to be able to build this + __noChroot = true; - buildInputs = buildInputs - ++ lib.optional (stdenv.hostPlatform.libc == "glibc") glibcLocales; + buildInputs = buildInputs ++ lib.optional (stdenv.hostPlatform.libc == "glibc") glibcLocales; - nativeBuildInputs = nativeBuildInputs - ++ [ ghc pkg-config stack stackHook ]; + nativeBuildInputs = nativeBuildInputs ++ [ + ghc + pkg-config + stack + stackHook + ]; - STACK_PLATFORM_VARIANT = "nix"; - STACK_IN_NIX_SHELL = 1; - STACK_IN_NIX_EXTRA_ARGS = extraArgs; + STACK_PLATFORM_VARIANT = "nix"; + STACK_IN_NIX_SHELL = 1; + STACK_IN_NIX_EXTRA_ARGS = extraArgs; - # XXX: workaround for https://ghc.haskell.org/trac/ghc/ticket/11042. - LD_LIBRARY_PATH = lib.makeLibraryPath (LD_LIBRARY_PATH ++ buildInputs); - # ^^^ Internally uses `getOutput "lib"` (equiv. to getLib) + # XXX: workaround for https://ghc.haskell.org/trac/ghc/ticket/11042. + LD_LIBRARY_PATH = lib.makeLibraryPath (LD_LIBRARY_PATH ++ buildInputs); + # ^^^ Internally uses `getOutput "lib"` (equiv. to getLib) - # Non-NixOS git needs cert - GIT_SSL_CAINFO = "${cacert}/etc/ssl/certs/ca-bundle.crt"; + # Non-NixOS git needs cert + GIT_SSL_CAINFO = "${cacert}/etc/ssl/certs/ca-bundle.crt"; - # Fixes https://github.com/commercialhaskell/stack/issues/2358 - LANG = "en_US.UTF-8"; + # Fixes https://github.com/commercialhaskell/stack/issues/2358 + LANG = "en_US.UTF-8"; - preferLocalBuild = true; + preferLocalBuild = true; - preConfigure = '' - export STACK_ROOT=$NIX_BUILD_TOP/.stack - ''; + preConfigure = '' + export STACK_ROOT=$NIX_BUILD_TOP/.stack + ''; - buildPhase = args.buildPhase or '' - runHook preBuild + buildPhase = + args.buildPhase or '' + runHook preBuild - ${stackCmd} build + ${stackCmd} build - runHook postBuild - ''; + runHook postBuild + ''; - checkPhase = args.checkPhase or '' - runHook preCheck + checkPhase = + args.checkPhase or '' + runHook preCheck - ${stackCmd} test + ${stackCmd} test - runHook postCheck - ''; + runHook postCheck + ''; - doCheck = args.doCheck or true; + doCheck = args.doCheck or true; - installPhase = args.installPhase or '' - runHook preInstall + installPhase = + args.installPhase or '' + runHook preInstall - ${stackCmd} --local-bin-path=$out/bin build --copy-bins + ${stackCmd} --local-bin-path=$out/bin build --copy-bins - runHook postInstall - ''; -}) + runHook postInstall + ''; + } +) diff --git a/pkgs/development/haskell-modules/hoogle.nix b/pkgs/development/haskell-modules/hoogle.nix index ebd0e15c280099..9237f0fda59f72 100644 --- a/pkgs/development/haskell-modules/hoogle.nix +++ b/pkgs/development/haskell-modules/hoogle.nix @@ -2,8 +2,12 @@ # database which provides "Source" links to all specified 'packages' -- or the # current Haskell Platform if no custom package set is provided. -{ lib, stdenv, buildPackages, haskellPackages -, writeText +{ + lib, + stdenv, + buildPackages, + haskellPackages, + writeText, }: # This argument is a function which selects a list of Haskell packages from any @@ -20,30 +24,29 @@ let wrapper = ./hoogle-local-wrapper.sh; isGhcjs = ghc.isGhcjs or false; opts = lib.optionalString; - haddockExe = - if !isGhcjs - then "haddock" - else "haddock-ghcjs"; - ghcDocLibDir = - if !isGhcjs - then ghc.doc + "/share/doc/ghc*/html/libraries" - else ghc + "/doc/lib"; + haddockExe = if !isGhcjs then "haddock" else "haddock-ghcjs"; + ghcDocLibDir = if !isGhcjs then ghc.doc + "/share/doc/ghc*/html/libraries" else ghc + "/doc/lib"; # On GHCJS, use a stripped down version of GHC's prologue.txt prologue = - if !isGhcjs - then "${ghcDocLibDir}/prologue.txt" - else writeText "ghcjs-prologue.txt" '' - This index includes documentation for many Haskell modules. - ''; - - docPackages = lib.closePropagation - # we grab the doc outputs - (map (lib.getOutput "doc") packages); + if !isGhcjs then + "${ghcDocLibDir}/prologue.txt" + else + writeText "ghcjs-prologue.txt" '' + This index includes documentation for many Haskell modules. + ''; + + docPackages = + lib.closePropagation + # we grab the doc outputs + (map (lib.getOutput "doc") packages); in buildPackages.stdenv.mkDerivation { name = "hoogle-with-packages"; - buildInputs = [ghc hoogle]; + buildInputs = [ + ghc + hoogle + ]; # compiling databases takes less time than copying the results # between machines. @@ -57,16 +60,21 @@ buildPackages.stdenv.mkDerivation { inherit docPackages; - passAsFile = ["buildCommand"]; + passAsFile = [ "buildCommand" ]; buildCommand = '' - ${let # Filter out nulls here to work around https://github.com/NixOS/nixpkgs/issues/82245 - # If we don't then grabbing `p.name` here will fail. - packages' = lib.filter (p: p != null) packages; - in lib.optionalString (packages' != [] -> docPackages == []) - ("echo WARNING: localHoogle package list empty, even though" - + " the following were specified: " - + lib.concatMapStringsSep ", " (p: p.name) packages')} + ${ + let + # Filter out nulls here to work around https://github.com/NixOS/nixpkgs/issues/82245 + # If we don't then grabbing `p.name` here will fail. + packages' = lib.filter (p: p != null) packages; + in + lib.optionalString (packages' != [ ] -> docPackages == [ ]) ( + "echo WARNING: localHoogle package list empty, even though" + + " the following were specified: " + + lib.concatMapStringsSep ", " (p: p.name) packages' + ) + } mkdir -p $out/share/doc/hoogle echo importing builtin packages @@ -79,13 +87,19 @@ buildPackages.stdenv.mkDerivation { done echo importing other packages - ${lib.concatMapStringsSep "\n" (el: '' + ${lib.concatMapStringsSep "\n" + (el: '' ln -sfn ${el.haddockDir} "$out/share/doc/hoogle/${el.name}" '') - (lib.filter (el: el.haddockDir != null) - (builtins.map (p: { haddockDir = if p ? haddockDir then p.haddockDir p else null; - name = p.pname; }) - docPackages))} + ( + lib.filter (el: el.haddockDir != null) ( + builtins.map (p: { + haddockDir = if p ? haddockDir then p.haddockDir p else null; + name = p.pname; + }) docPackages + ) + ) + } echo building hoogle database hoogle generate --database $out/share/doc/hoogle/default.hoo --local=$out/share/doc/hoogle diff --git a/pkgs/development/haskell-modules/initial-packages.nix b/pkgs/development/haskell-modules/initial-packages.nix index 3bbf9c037dd491..e114980043bf14 100644 --- a/pkgs/development/haskell-modules/initial-packages.nix +++ b/pkgs/development/haskell-modules/initial-packages.nix @@ -1,2 +1,6 @@ -args@{ pkgs, lib, callPackage }: self: - (import ./hackage-packages.nix args self) +args@{ + pkgs, + lib, + callPackage, +}: +self: (import ./hackage-packages.nix args self) diff --git a/pkgs/development/haskell-modules/lib/compose.nix b/pkgs/development/haskell-modules/lib/compose.nix index cbefc44bb01d0a..12b728e9d24578 100644 --- a/pkgs/development/haskell-modules/lib/compose.nix +++ b/pkgs/development/haskell-modules/lib/compose.nix @@ -4,269 +4,425 @@ rec { - /* This function takes a file like `hackage-packages.nix` and constructs - a full package set out of that. - */ + /* + This function takes a file like `hackage-packages.nix` and constructs + a full package set out of that. + */ makePackageSet = import ../make-package-set.nix; - /* The function overrideCabal lets you alter the arguments to the - mkDerivation function. - - Example: + /* + The function overrideCabal lets you alter the arguments to the + mkDerivation function. - First, note how the aeson package is constructed in hackage-packages.nix: + Example: - "aeson" = callPackage ({ mkDerivation, attoparsec, - }: - mkDerivation { - pname = "aeson"; - - homepage = "https://github.com/bos/aeson"; - }) + First, note how the aeson package is constructed in hackage-packages.nix: - The mkDerivation function of haskellPackages will take care of putting - the homepage in the right place, in meta. + "aeson" = callPackage ({ mkDerivation, attoparsec, + }: + mkDerivation { + pname = "aeson"; + + homepage = "https://github.com/bos/aeson"; + }) - > haskellPackages.aeson.meta.homepage - "https://github.com/bos/aeson" + The mkDerivation function of haskellPackages will take care of putting + the homepage in the right place, in meta. - > x = haskell.lib.compose.overrideCabal (old: { homepage = old.homepage + "#readme"; }) haskellPackages.aeson - > x.meta.homepage - "https://github.com/bos/aeson#readme" + > haskellPackages.aeson.meta.homepage + "https://github.com/bos/aeson" - */ - overrideCabal = f: drv: (drv.override (args: args // { - mkDerivation = drv: (args.mkDerivation drv).override f; - })) // { - overrideScope = scope: overrideCabal f (drv.overrideScope scope); - }; + > x = haskell.lib.compose.overrideCabal (old: { homepage = old.homepage + "#readme"; }) haskellPackages.aeson + > x.meta.homepage + "https://github.com/bos/aeson#readme" + */ + overrideCabal = + f: drv: + (drv.override ( + args: + args + // { + mkDerivation = drv: (args.mkDerivation drv).override f; + } + )) + // { + overrideScope = scope: overrideCabal f (drv.overrideScope scope); + }; # : Map Name (Either Path VersionNumber) -> HaskellPackageOverrideSet # Given a set whose values are either paths or version strings, produces # a package override set (i.e. (self: super: { etc. })) that sets # the packages named in the input set to the corresponding versions packageSourceOverrides = - overrides: self: super: pkgs.lib.mapAttrs (name: src: - let isPath = x: builtins.substring 0 1 (toString x) == "/"; - generateExprs = if isPath src - then self.callCabal2nix - else self.callHackage; - in generateExprs name src {}) overrides; - - /* doCoverage modifies a haskell package to enable the generation - and installation of a coverage report. - - See https://wiki.haskell.org/Haskell_program_coverage - */ - doCoverage = overrideCabal (drv: { doCoverage = true; }); - - /* dontCoverage modifies a haskell package to disable the generation - and installation of a coverage report. - */ - dontCoverage = overrideCabal (drv: { doCoverage = false; }); - - /* doHaddock modifies a haskell package to enable the generation and - installation of API documentation from code comments using the - haddock tool. - */ - doHaddock = overrideCabal (drv: { doHaddock = true; }); - - /* dontHaddock modifies a haskell package to disable the generation and - installation of API documentation from code comments using the - haddock tool. - */ - dontHaddock = overrideCabal (drv: { doHaddock = false; }); - - /* doJailbreak enables the removal of version bounds from the cabal - file. You may want to avoid this function. - - This is useful when a package reports that it can not be built - due to version mismatches. In some cases, removing the version - bounds entirely is an easy way to make a package build, but at - the risk of breaking software in non-obvious ways now or in the - future. - - Instead of jailbreaking, you can patch the cabal file. - - Note that jailbreaking at this time, doesn't lift bounds on - conditional branches. - https://github.com/peti/jailbreak-cabal/issues/7 has further details. - - */ - doJailbreak = overrideCabal (drv: { jailbreak = true; }); - - /* dontJailbreak restores the use of the version bounds the check - the use of dependencies in the package description. - */ - dontJailbreak = overrideCabal (drv: { jailbreak = false; }); - - /* doCheck enables dependency checking, compilation and execution - of test suites listed in the package description file. - */ - doCheck = overrideCabal (drv: { doCheck = true; }); - /* dontCheck disables dependency checking, compilation and execution - of test suites listed in the package description file. - */ - dontCheck = overrideCabal (drv: { doCheck = false; }); - /* The dontCheckIf variant sets doCheck = false if the condition - applies. In any other case the previously set/default value is used. - This prevents accidentally re-enabling tests in a later override. - */ + overrides: self: super: + pkgs.lib.mapAttrs ( + name: src: + let + isPath = x: builtins.substring 0 1 (toString x) == "/"; + generateExprs = if isPath src then self.callCabal2nix else self.callHackage; + in + generateExprs name src { } + ) overrides; + + /* + doCoverage modifies a haskell package to enable the generation + and installation of a coverage report. + + See https://wiki.haskell.org/Haskell_program_coverage + */ + doCoverage = overrideCabal (drv: { + doCoverage = true; + }); + + /* + dontCoverage modifies a haskell package to disable the generation + and installation of a coverage report. + */ + dontCoverage = overrideCabal (drv: { + doCoverage = false; + }); + + /* + doHaddock modifies a haskell package to enable the generation and + installation of API documentation from code comments using the + haddock tool. + */ + doHaddock = overrideCabal (drv: { + doHaddock = true; + }); + + /* + dontHaddock modifies a haskell package to disable the generation and + installation of API documentation from code comments using the + haddock tool. + */ + dontHaddock = overrideCabal (drv: { + doHaddock = false; + }); + + /* + doJailbreak enables the removal of version bounds from the cabal + file. You may want to avoid this function. + + This is useful when a package reports that it can not be built + due to version mismatches. In some cases, removing the version + bounds entirely is an easy way to make a package build, but at + the risk of breaking software in non-obvious ways now or in the + future. + + Instead of jailbreaking, you can patch the cabal file. + + Note that jailbreaking at this time, doesn't lift bounds on + conditional branches. + https://github.com/peti/jailbreak-cabal/issues/7 has further details. + */ + doJailbreak = overrideCabal (drv: { + jailbreak = true; + }); + + /* + dontJailbreak restores the use of the version bounds the check + the use of dependencies in the package description. + */ + dontJailbreak = overrideCabal (drv: { + jailbreak = false; + }); + + /* + doCheck enables dependency checking, compilation and execution + of test suites listed in the package description file. + */ + doCheck = overrideCabal (drv: { + doCheck = true; + }); + /* + dontCheck disables dependency checking, compilation and execution + of test suites listed in the package description file. + */ + dontCheck = overrideCabal (drv: { + doCheck = false; + }); + /* + The dontCheckIf variant sets doCheck = false if the condition + applies. In any other case the previously set/default value is used. + This prevents accidentally re-enabling tests in a later override. + */ dontCheckIf = condition: if condition then dontCheck else lib.id; - /* doBenchmark enables dependency checking and compilation - for benchmarks listed in the package description file. - Benchmarks are, however, not executed at the moment. - */ - doBenchmark = overrideCabal (drv: { doBenchmark = true; }); - /* dontBenchmark disables dependency checking, compilation and execution - for benchmarks listed in the package description file. - */ - dontBenchmark = overrideCabal (drv: { doBenchmark = false; }); - - /* doDistribute enables the distribution of binaries for the package - via hydra. - */ + /* + doBenchmark enables dependency checking and compilation + for benchmarks listed in the package description file. + Benchmarks are, however, not executed at the moment. + */ + doBenchmark = overrideCabal (drv: { + doBenchmark = true; + }); + /* + dontBenchmark disables dependency checking, compilation and execution + for benchmarks listed in the package description file. + */ + dontBenchmark = overrideCabal (drv: { + doBenchmark = false; + }); + + /* + doDistribute enables the distribution of binaries for the package + via hydra. + */ doDistribute = overrideCabal (drv: { # lib.platforms.all is the default value for platforms (since GHC can cross-compile) - hydraPlatforms = lib.subtractLists (drv.badPlatforms or []) - (drv.platforms or lib.platforms.all); + hydraPlatforms = lib.subtractLists (drv.badPlatforms or [ ]) (drv.platforms or lib.platforms.all); + }); + /* + dontDistribute disables the distribution of binaries for the package + via hydra. + */ + dontDistribute = overrideCabal (drv: { + hydraPlatforms = [ ]; }); - /* dontDistribute disables the distribution of binaries for the package - via hydra. - */ - dontDistribute = overrideCabal (drv: { hydraPlatforms = []; }); - /* appendConfigureFlag adds a single argument that will be passed to the - cabal configure command, after the arguments that have been defined - in the initial declaration or previous overrides. + /* + appendConfigureFlag adds a single argument that will be passed to the + cabal configure command, after the arguments that have been defined + in the initial declaration or previous overrides. - Example: + Example: - > haskell.lib.compose.appendConfigureFlag "--profiling-detail=all-functions" haskellPackages.servant - */ - appendConfigureFlag = x: appendConfigureFlags [x]; - appendConfigureFlags = xs: overrideCabal (drv: { configureFlags = (drv.configureFlags or []) ++ xs; }); + > haskell.lib.compose.appendConfigureFlag "--profiling-detail=all-functions" haskellPackages.servant + */ + appendConfigureFlag = x: appendConfigureFlags [ x ]; + appendConfigureFlags = + xs: + overrideCabal (drv: { + configureFlags = (drv.configureFlags or [ ]) ++ xs; + }); - appendBuildFlag = x: overrideCabal (drv: { buildFlags = (drv.buildFlags or []) ++ [x]; }); - appendBuildFlags = xs: overrideCabal (drv: { buildFlags = (drv.buildFlags or []) ++ xs; }); + appendBuildFlag = + x: + overrideCabal (drv: { + buildFlags = (drv.buildFlags or [ ]) ++ [ x ]; + }); + appendBuildFlags = + xs: + overrideCabal (drv: { + buildFlags = (drv.buildFlags or [ ]) ++ xs; + }); - /* removeConfigureFlag drv x is a Haskell package like drv, but with - all cabal configure arguments that are equal to x removed. + /* + removeConfigureFlag drv x is a Haskell package like drv, but with + all cabal configure arguments that are equal to x removed. - > haskell.lib.compose.removeConfigureFlag "--verbose" haskellPackages.servant - */ - removeConfigureFlag = x: overrideCabal (drv: { configureFlags = lib.remove x (drv.configureFlags or []); }); + > haskell.lib.compose.removeConfigureFlag "--verbose" haskellPackages.servant + */ + removeConfigureFlag = + x: + overrideCabal (drv: { + configureFlags = lib.remove x (drv.configureFlags or [ ]); + }); - addBuildTool = x: addBuildTools [x]; - addBuildTools = xs: overrideCabal (drv: { buildTools = (drv.buildTools or []) ++ xs; }); + addBuildTool = x: addBuildTools [ x ]; + addBuildTools = + xs: + overrideCabal (drv: { + buildTools = (drv.buildTools or [ ]) ++ xs; + }); - addExtraLibrary = x: addExtraLibraries [x]; - addExtraLibraries = xs: overrideCabal (drv: { extraLibraries = (drv.extraLibraries or []) ++ xs; }); + addExtraLibrary = x: addExtraLibraries [ x ]; + addExtraLibraries = + xs: + overrideCabal (drv: { + extraLibraries = (drv.extraLibraries or [ ]) ++ xs; + }); - addBuildDepend = x: addBuildDepends [x]; - addBuildDepends = xs: overrideCabal (drv: { buildDepends = (drv.buildDepends or []) ++ xs; }); + addBuildDepend = x: addBuildDepends [ x ]; + addBuildDepends = + xs: + overrideCabal (drv: { + buildDepends = (drv.buildDepends or [ ]) ++ xs; + }); - addTestToolDepend = x: addTestToolDepends [x]; - addTestToolDepends = xs: overrideCabal (drv: { testToolDepends = (drv.testToolDepends or []) ++ xs; }); + addTestToolDepend = x: addTestToolDepends [ x ]; + addTestToolDepends = + xs: + overrideCabal (drv: { + testToolDepends = (drv.testToolDepends or [ ]) ++ xs; + }); - addPkgconfigDepend = x: addPkgconfigDepends [x]; - addPkgconfigDepends = xs: overrideCabal (drv: { pkg-configDepends = (drv.pkg-configDepends or []) ++ xs; }); + addPkgconfigDepend = x: addPkgconfigDepends [ x ]; + addPkgconfigDepends = + xs: + overrideCabal (drv: { + pkg-configDepends = (drv.pkg-configDepends or [ ]) ++ xs; + }); - addSetupDepend = x: addSetupDepends [x]; - addSetupDepends = xs: overrideCabal (drv: { setupHaskellDepends = (drv.setupHaskellDepends or []) ++ xs; }); + addSetupDepend = x: addSetupDepends [ x ]; + addSetupDepends = + xs: + overrideCabal (drv: { + setupHaskellDepends = (drv.setupHaskellDepends or [ ]) ++ xs; + }); enableCabalFlag = x: drv: appendConfigureFlag "-f${x}" (removeConfigureFlag "-f-${x}" drv); disableCabalFlag = x: drv: appendConfigureFlag "-f-${x}" (removeConfigureFlag "-f${x}" drv); - markBroken = overrideCabal (drv: { broken = true; hydraPlatforms = []; }); - unmarkBroken = overrideCabal (drv: { broken = false; }); - markBrokenVersion = version: drv: assert drv.version == version; markBroken drv; - markUnbroken = overrideCabal (drv: { broken = false; }); - - /* disableParallelBuilding drops the -j option from the GHC - command line for the given package. This can be useful in rare - situations where parallel building of a package causes GHC to - fail for some reason. - */ - disableParallelBuilding = overrideCabal (drv: { enableParallelBuilding = false; }); - - enableLibraryProfiling = overrideCabal (drv: { enableLibraryProfiling = true; }); - disableLibraryProfiling = overrideCabal (drv: { enableLibraryProfiling = false; }); - - enableExecutableProfiling = overrideCabal (drv: { enableExecutableProfiling = true; }); - disableExecutableProfiling = overrideCabal (drv: { enableExecutableProfiling = false; }); - - enableSharedExecutables = overrideCabal (drv: { enableSharedExecutables = true; }); - disableSharedExecutables = overrideCabal (drv: { enableSharedExecutables = false; }); - - enableSharedLibraries = overrideCabal (drv: { enableSharedLibraries = true; }); - disableSharedLibraries = overrideCabal (drv: { enableSharedLibraries = false; }); - - enableDeadCodeElimination = overrideCabal (drv: { enableDeadCodeElimination = true; }); - disableDeadCodeElimination = overrideCabal (drv: { enableDeadCodeElimination = false; }); - - enableStaticLibraries = overrideCabal (drv: { enableStaticLibraries = true; }); - disableStaticLibraries = overrideCabal (drv: { enableStaticLibraries = false; }); - - enableSeparateBinOutput = overrideCabal (drv: { enableSeparateBinOutput = true; }); - - appendPatch = x: appendPatches [x]; - appendPatches = xs: overrideCabal (drv: { patches = (drv.patches or []) ++ xs; }); - - /* Set a specific build target instead of compiling all targets in the package. - * For example, imagine we have a .cabal file with a library, and 2 executables "dev" and "server". - * We can build only "server" and not wait on the compilation of "dev" by using setBuildTarget as follows: - * - * > setBuildTarget "server" (callCabal2nix "thePackageName" thePackageSrc {}) - * - */ - setBuildTargets = xs: overrideCabal (drv: { buildTarget = lib.concatStringsSep " " xs; }); - setBuildTarget = x: setBuildTargets [x]; - - doHyperlinkSource = overrideCabal (drv: { hyperlinkSource = true; }); - dontHyperlinkSource = overrideCabal (drv: { hyperlinkSource = false; }); - - disableHardening = flags: overrideCabal (drv: { hardeningDisable = flags; }); - - /* Let Nix strip the binary files. - * This removes debugging symbols. - */ - doStrip = overrideCabal (drv: { dontStrip = false; }); - - /* Stop Nix from stripping the binary files. - * This keeps debugging symbols. - */ - dontStrip = overrideCabal (drv: { dontStrip = true; }); - - /* Useful for debugging segfaults with gdb. - * This includes dontStrip. - */ - enableDWARFDebugging = drv: - # -g: enables debugging symbols - # --disable-*-stripping: tell GHC not to strip resulting binaries - # dontStrip: see above - appendConfigureFlag "--ghc-options=-g --disable-executable-stripping --disable-library-stripping" (dontStrip drv); - - /* Create a source distribution tarball like those found on hackage, - instead of building the package. - */ - sdistTarball = pkg: lib.overrideDerivation pkg (drv: { - name = "${drv.pname}-source-${drv.version}"; - # Since we disable the haddock phase, we also need to override the - # outputs since the separate doc output will not be produced. - outputs = ["out"]; - buildPhase = "./Setup sdist"; - haddockPhase = ":"; - checkPhase = ":"; - installPhase = "install -D dist/${drv.pname}-*.tar.gz $out/${drv.pname}-${drv.version}.tar.gz"; - fixupPhase = ":"; - }); - - /* Create a documentation tarball suitable for uploading to Hackage instead - of building the package. - */ - documentationTarball = pkg: + markBroken = overrideCabal (drv: { + broken = true; + hydraPlatforms = [ ]; + }); + unmarkBroken = overrideCabal (drv: { + broken = false; + }); + markBrokenVersion = + version: drv: + assert drv.version == version; + markBroken drv; + markUnbroken = overrideCabal (drv: { + broken = false; + }); + + /* + disableParallelBuilding drops the -j option from the GHC + command line for the given package. This can be useful in rare + situations where parallel building of a package causes GHC to + fail for some reason. + */ + disableParallelBuilding = overrideCabal (drv: { + enableParallelBuilding = false; + }); + + enableLibraryProfiling = overrideCabal (drv: { + enableLibraryProfiling = true; + }); + disableLibraryProfiling = overrideCabal (drv: { + enableLibraryProfiling = false; + }); + + enableExecutableProfiling = overrideCabal (drv: { + enableExecutableProfiling = true; + }); + disableExecutableProfiling = overrideCabal (drv: { + enableExecutableProfiling = false; + }); + + enableSharedExecutables = overrideCabal (drv: { + enableSharedExecutables = true; + }); + disableSharedExecutables = overrideCabal (drv: { + enableSharedExecutables = false; + }); + + enableSharedLibraries = overrideCabal (drv: { + enableSharedLibraries = true; + }); + disableSharedLibraries = overrideCabal (drv: { + enableSharedLibraries = false; + }); + + enableDeadCodeElimination = overrideCabal (drv: { + enableDeadCodeElimination = true; + }); + disableDeadCodeElimination = overrideCabal (drv: { + enableDeadCodeElimination = false; + }); + + enableStaticLibraries = overrideCabal (drv: { + enableStaticLibraries = true; + }); + disableStaticLibraries = overrideCabal (drv: { + enableStaticLibraries = false; + }); + + enableSeparateBinOutput = overrideCabal (drv: { + enableSeparateBinOutput = true; + }); + + appendPatch = x: appendPatches [ x ]; + appendPatches = + xs: + overrideCabal (drv: { + patches = (drv.patches or [ ]) ++ xs; + }); + + /* + Set a specific build target instead of compiling all targets in the package. + For example, imagine we have a .cabal file with a library, and 2 executables "dev" and "server". + We can build only "server" and not wait on the compilation of "dev" by using setBuildTarget as follows: + + > setBuildTarget "server" (callCabal2nix "thePackageName" thePackageSrc {}) + */ + setBuildTargets = + xs: + overrideCabal (drv: { + buildTarget = lib.concatStringsSep " " xs; + }); + setBuildTarget = x: setBuildTargets [ x ]; + + doHyperlinkSource = overrideCabal (drv: { + hyperlinkSource = true; + }); + dontHyperlinkSource = overrideCabal (drv: { + hyperlinkSource = false; + }); + + disableHardening = + flags: + overrideCabal (drv: { + hardeningDisable = flags; + }); + + /* + Let Nix strip the binary files. + This removes debugging symbols. + */ + doStrip = overrideCabal (drv: { + dontStrip = false; + }); + + /* + Stop Nix from stripping the binary files. + This keeps debugging symbols. + */ + dontStrip = overrideCabal (drv: { + dontStrip = true; + }); + + /* + Useful for debugging segfaults with gdb. + This includes dontStrip. + */ + enableDWARFDebugging = + drv: + # -g: enables debugging symbols + # --disable-*-stripping: tell GHC not to strip resulting binaries + # dontStrip: see above + appendConfigureFlag "--ghc-options=-g --disable-executable-stripping --disable-library-stripping" ( + dontStrip drv + ); + + /* + Create a source distribution tarball like those found on hackage, + instead of building the package. + */ + sdistTarball = + pkg: + lib.overrideDerivation pkg (drv: { + name = "${drv.pname}-source-${drv.version}"; + # Since we disable the haddock phase, we also need to override the + # outputs since the separate doc output will not be produced. + outputs = [ "out" ]; + buildPhase = "./Setup sdist"; + haddockPhase = ":"; + checkPhase = ":"; + installPhase = "install -D dist/${drv.pname}-*.tar.gz $out/${drv.pname}-${drv.version}.tar.gz"; + fixupPhase = ":"; + }); + + /* + Create a documentation tarball suitable for uploading to Hackage instead + of building the package. + */ + documentationTarball = + pkg: pkgs.lib.overrideDerivation pkg (drv: { name = "${drv.name}-docs"; # Like sdistTarball, disable the "doc" output here. @@ -288,97 +444,125 @@ rec { ''; }); - /* Use the gold linker. It is a linker for ELF that is designed - "to run as fast as possible on modern systems" - */ - linkWithGold = appendConfigureFlag - "--ghc-option=-optl-fuse-ld=gold --ld-option=-fuse-ld=gold --with-ld=ld.gold"; + /* + Use the gold linker. It is a linker for ELF that is designed + "to run as fast as possible on modern systems" + */ + linkWithGold = appendConfigureFlag "--ghc-option=-optl-fuse-ld=gold --ld-option=-fuse-ld=gold --with-ld=ld.gold"; - /* link executables statically against haskell libs to reduce - closure size - */ - justStaticExecutables = overrideCabal (drv: { + /* + link executables statically against haskell libs to reduce + closure size + */ + justStaticExecutables = overrideCabal (drv: { enableSharedExecutables = false; enableLibraryProfiling = drv.enableExecutableProfiling or false; isLibrary = false; doHaddock = false; - postFixup = drv.postFixup or "" + '' + postFixup = + drv.postFixup or "" + + '' - # Remove every directory which could have links to other store paths. - rm -rf $out/lib $out/nix-support $out/share/doc - ''; + # Remove every directory which could have links to other store paths. + rm -rf $out/lib $out/nix-support $out/share/doc + ''; disallowGhcReference = true; }); - /* Build a source distribution tarball instead of using the source files - directly. The effect is that the package is built as if it were published - on hackage. This can be used as a test for the source distribution, - assuming the build fails when packaging mistakes are in the cabal file. + /* + Build a source distribution tarball instead of using the source files + directly. The effect is that the package is built as if it were published + on hackage. This can be used as a test for the source distribution, + assuming the build fails when packaging mistakes are in the cabal file. - A faster implementation using `cabal-install` is available as - `buildFromCabalSdist` in your Haskell package set. - */ - buildFromSdist = pkg: overrideCabal (drv: { - src = "${sdistTarball pkg}/${pkg.pname}-${pkg.version}.tar.gz"; + A faster implementation using `cabal-install` is available as + `buildFromCabalSdist` in your Haskell package set. + */ + buildFromSdist = + pkg: + overrideCabal (drv: { + src = "${sdistTarball pkg}/${pkg.pname}-${pkg.version}.tar.gz"; - # Revising and jailbreaking the cabal file has been handled in sdistTarball - revision = null; - editedCabalFile = null; - jailbreak = false; - }) pkg; + # Revising and jailbreaking the cabal file has been handled in sdistTarball + revision = null; + editedCabalFile = null; + jailbreak = false; + }) pkg; - /* Build the package in a strict way to uncover potential problems. - This includes buildFromSdist and failOnAllWarnings. - */ + /* + Build the package in a strict way to uncover potential problems. + This includes buildFromSdist and failOnAllWarnings. + */ buildStrictly = pkg: buildFromSdist (failOnAllWarnings pkg); - /* Disable core optimizations, significantly speeds up build time */ + # Disable core optimizations, significantly speeds up build time disableOptimization = appendConfigureFlag "--disable-optimization"; - /* Turn on most of the compiler warnings and fail the build if any - of them occur. */ + /* + Turn on most of the compiler warnings and fail the build if any + of them occur. + */ failOnAllWarnings = appendConfigureFlag "--ghc-option=-Wall --ghc-option=-Werror"; - /* Add a post-build check to verify that dependencies declared in - the cabal file are actually used. + /* + Add a post-build check to verify that dependencies declared in + the cabal file are actually used. - The first attrset argument can be used to configure the strictness - of this check and a list of ignored package names that would otherwise - cause false alarms. - */ + The first attrset argument can be used to configure the strictness + of this check and a list of ignored package names that would otherwise + cause false alarms. + */ checkUnusedPackages = - { ignoreEmptyImports ? false - , ignoreMainModule ? false - , ignorePackages ? [] - } : drv : - overrideCabal (_drv: { - postBuild = - let args = lib.concatStringsSep " " ( - lib.optional ignoreEmptyImports "--ignore-empty-imports" ++ - lib.optional ignoreMainModule "--ignore-main-module" ++ - map (pkg: "--ignore-package ${pkg}") ignorePackages - ); - in "${pkgs.haskellPackages.packunused}/bin/packunused" + - lib.optionalString (args != "") " ${args}"; - }) (appendConfigureFlag "--ghc-option=-ddump-minimal-imports" drv); + { + ignoreEmptyImports ? false, + ignoreMainModule ? false, + ignorePackages ? [ ], + }: + drv: + overrideCabal (_drv: { + postBuild = + let + args = lib.concatStringsSep " " ( + lib.optional ignoreEmptyImports "--ignore-empty-imports" + ++ lib.optional ignoreMainModule "--ignore-main-module" + ++ map (pkg: "--ignore-package ${pkg}") ignorePackages + ); + in + "${pkgs.haskellPackages.packunused}/bin/packunused" + lib.optionalString (args != "") " ${args}"; + }) (appendConfigureFlag "--ghc-option=-ddump-minimal-imports" drv); buildStackProject = pkgs.callPackage ../generic-stack-builder.nix { }; - /* Add a dummy command to trigger a build despite an equivalent - earlier build that is present in the store or cache. - */ - triggerRebuild = i: overrideCabal (drv: { - postUnpack = drv.postUnpack or "" + '' - - # trigger rebuild ${toString i} - ''; - }); + /* + Add a dummy command to trigger a build despite an equivalent + earlier build that is present in the store or cache. + */ + triggerRebuild = + i: + overrideCabal (drv: { + postUnpack = + drv.postUnpack or "" + + '' + + # trigger rebuild ${toString i} + ''; + }); - /* Override the sources for the package and optionally the version. - This also takes of removing editedCabalFile. - */ - overrideSrc = { src, version ? null }: drv: - overrideCabal (_: { inherit src; version = if version == null then drv.version else version; editedCabalFile = null; }) drv; + /* + Override the sources for the package and optionally the version. + This also takes of removing editedCabalFile. + */ + overrideSrc = + { + src, + version ? null, + }: + drv: + overrideCabal (_: { + inherit src; + version = if version == null then drv.version else version; + editedCabalFile = null; + }) drv; # Get all of the build inputs of a haskell package, divided by category. getBuildInputs = p: p.getBuildInputs; @@ -392,13 +576,11 @@ rec { # nix-shell evaluation, return a nix-shell optimized environment. shellAware = p: if lib.inNixShell then p.env else p; - ghcInfo = ghc: - rec { isCross = (ghc.cross or null) != null; - isGhcjs = ghc.isGhcjs or false; - nativeGhc = if isCross || isGhcjs - then ghc.bootPkgs.ghc - else ghc; - }; + ghcInfo = ghc: rec { + isCross = (ghc.cross or null) != null; + isGhcjs = ghc.isGhcjs or false; + nativeGhc = if isCross || isGhcjs then ghc.bootPkgs.ghc else ghc; + }; ### mkDerivation helpers # These allow external users of a haskell package to extract @@ -410,11 +592,19 @@ rec { # an example of this. # Some information about which phases should be run. - controlPhases = ghc: let inherit (ghcInfo ghc) isCross; in - { doCheck ? !isCross - , doBenchmark ? false - , ... - }: { inherit doCheck doBenchmark; }; + controlPhases = + ghc: + let + inherit (ghcInfo ghc) isCross; + in + { + doCheck ? !isCross, + doBenchmark ? false, + ... + }: + { + inherit doCheck doBenchmark; + }; # Utility to convert a directory full of `cabal2nix`-generated files into a # package override set @@ -424,49 +614,53 @@ rec { { directory, ... }: self: super: - let - haskellPaths = - lib.filter (lib.hasSuffix ".nix") - (builtins.attrNames (builtins.readDir directory)); + let + haskellPaths = lib.filter (lib.hasSuffix ".nix") (builtins.attrNames (builtins.readDir directory)); - toKeyVal = file: { - name = builtins.replaceStrings [ ".nix" ] [ "" ] file; + toKeyVal = file: { + name = builtins.replaceStrings [ ".nix" ] [ "" ] file; - value = self.callPackage (directory + "/${file}") { }; - }; + value = self.callPackage (directory + "/${file}") { }; + }; - in - builtins.listToAttrs (map toKeyVal haskellPaths); + in + builtins.listToAttrs (map toKeyVal haskellPaths); /* INTERNAL function retained for backwards compatibility, use haskell.packages.*.generateOptparseApplicativeCompletions instead! */ - __generateOptparseApplicativeCompletion = exeName: overrideCabal (drv: { - postInstall = (drv.postInstall or "") + '' - bashCompDir="''${!outputBin}/share/bash-completion/completions" - zshCompDir="''${!outputBin}/share/zsh/vendor-completions" - fishCompDir="''${!outputBin}/share/fish/vendor_completions.d" - mkdir -p "$bashCompDir" "$zshCompDir" "$fishCompDir" - "''${!outputBin}/bin/${exeName}" --bash-completion-script "''${!outputBin}/bin/${exeName}" >"$bashCompDir/${exeName}" - "''${!outputBin}/bin/${exeName}" --zsh-completion-script "''${!outputBin}/bin/${exeName}" >"$zshCompDir/_${exeName}" - "''${!outputBin}/bin/${exeName}" --fish-completion-script "''${!outputBin}/bin/${exeName}" >"$fishCompDir/${exeName}.fish" - - # Sanity check - grep -F ${exeName} <$bashCompDir/${exeName} >/dev/null || { - echo 'Could not find ${exeName} in completion script.' - exit 1 - } - ''; - }); + __generateOptparseApplicativeCompletion = + exeName: + overrideCabal (drv: { + postInstall = + (drv.postInstall or "") + + '' + bashCompDir="''${!outputBin}/share/bash-completion/completions" + zshCompDir="''${!outputBin}/share/zsh/vendor-completions" + fishCompDir="''${!outputBin}/share/fish/vendor_completions.d" + mkdir -p "$bashCompDir" "$zshCompDir" "$fishCompDir" + "''${!outputBin}/bin/${exeName}" --bash-completion-script "''${!outputBin}/bin/${exeName}" >"$bashCompDir/${exeName}" + "''${!outputBin}/bin/${exeName}" --zsh-completion-script "''${!outputBin}/bin/${exeName}" >"$zshCompDir/_${exeName}" + "''${!outputBin}/bin/${exeName}" --fish-completion-script "''${!outputBin}/bin/${exeName}" >"$fishCompDir/${exeName}.fish" + + # Sanity check + grep -F ${exeName} <$bashCompDir/${exeName} >/dev/null || { + echo 'Could not find ${exeName} in completion script.' + exit 1 + } + ''; + }); /* Retained for backwards compatibility. Use haskell.packages.*.generateOptparseApplicativeCompletions which is cross aware instead. */ - generateOptparseApplicativeCompletions = commands: pkg: - lib.warnIf (lib.oldestSupportedReleaseIsAtLeast 2211) "haskellLib.generateOptparseApplicativeCompletions is deprecated in favor of haskellPackages.generateOptparseApplicativeCompletions. Please change ${pkg.name} to use the latter and make sure it uses its matching haskell.packages set!" + generateOptparseApplicativeCompletions = + commands: pkg: + lib.warnIf (lib.oldestSupportedReleaseIsAtLeast 2211) + "haskellLib.generateOptparseApplicativeCompletions is deprecated in favor of haskellPackages.generateOptparseApplicativeCompletions. Please change ${pkg.name} to use the latter and make sure it uses its matching haskell.packages set!" (pkgs.lib.foldr __generateOptparseApplicativeCompletion pkg commands); /* @@ -474,8 +668,10 @@ rec { Use haskell.packages.*.generateOptparseApplicativeCompletions which is cross aware instead. */ - generateOptparseApplicativeCompletion = command: pkg: - lib.warnIf (lib.oldestSupportedReleaseIsAtLeast 2211) "haskellLib.generateOptparseApplicativeCompletion is deprecated in favor of haskellPackages.generateOptparseApplicativeCompletions (plural!). Please change ${pkg.name} to use the latter and make sure it uses its matching haskell.packages set!" + generateOptparseApplicativeCompletion = + command: pkg: + lib.warnIf (lib.oldestSupportedReleaseIsAtLeast 2211) + "haskellLib.generateOptparseApplicativeCompletion is deprecated in favor of haskellPackages.generateOptparseApplicativeCompletions (plural!). Please change ${pkg.name} to use the latter and make sure it uses its matching haskell.packages set!" (__generateOptparseApplicativeCompletion command pkg); # Don't fail at configure time if there are multiple versions of the @@ -500,20 +696,30 @@ rec { # Take list of derivations and return list of the transitive dependency # closure, only taking into account buildInputs. Loosely based on # closePropagationFast. - propagatedPlainBuildInputs = drvs: + propagatedPlainBuildInputs = + drvs: builtins.map (i: i.val) ( builtins.genericClosure { - startSet = builtins.map (drv: - { key = drv.outPath; val = drv; } - ) drvs; - operator = { val, ... }: - if !lib.isDerivation val - then [ ] + startSet = builtins.map (drv: { + key = drv.outPath; + val = drv; + }) drvs; + operator = + { val, ... }: + if !lib.isDerivation val then + [ ] else - builtins.concatMap (drv: - if !lib.isDerivation drv - then [ ] - else [ { key = drv.outPath; val = drv; } ] + builtins.concatMap ( + drv: + if !lib.isDerivation drv then + [ ] + else + [ + { + key = drv.outPath; + val = drv; + } + ] ) (val.buildInputs or [ ] ++ val.propagatedBuildInputs or [ ]); } ); diff --git a/pkgs/development/haskell-modules/lib/default.nix b/pkgs/development/haskell-modules/lib/default.nix index 976e62afc630d7..dc34f30a810e86 100644 --- a/pkgs/development/haskell-modules/lib/default.nix +++ b/pkgs/development/haskell-modules/lib/default.nix @@ -3,45 +3,47 @@ { pkgs, lib }: rec { - /* The same functionality as this haskell.lib, except that the derivation - being overridden is always the last parameter. This permits more natural - composition of several overrides, i.e. without having to nestle one call - between the function name and argument of another. haskell.lib.compose is - preferred for any new code. + /* + The same functionality as this haskell.lib, except that the derivation + being overridden is always the last parameter. This permits more natural + composition of several overrides, i.e. without having to nestle one call + between the function name and argument of another. haskell.lib.compose is + preferred for any new code. */ compose = import ./compose.nix { inherit pkgs lib; }; - /* This function takes a file like `hackage-packages.nix` and constructs - a full package set out of that. - */ + /* + This function takes a file like `hackage-packages.nix` and constructs + a full package set out of that. + */ makePackageSet = compose.makePackageSet; - /* The function overrideCabal lets you alter the arguments to the - mkDerivation function. - - Example: + /* + The function overrideCabal lets you alter the arguments to the + mkDerivation function. - First, note how the aeson package is constructed in hackage-packages.nix: + Example: - "aeson" = callPackage ({ mkDerivation, attoparsec, - }: - mkDerivation { - pname = "aeson"; - - homepage = "https://github.com/bos/aeson"; - }) + First, note how the aeson package is constructed in hackage-packages.nix: - The mkDerivation function of haskellPackages will take care of putting - the homepage in the right place, in meta. + "aeson" = callPackage ({ mkDerivation, attoparsec, + }: + mkDerivation { + pname = "aeson"; + + homepage = "https://github.com/bos/aeson"; + }) - > haskellPackages.aeson.meta.homepage - "https://github.com/bos/aeson" + The mkDerivation function of haskellPackages will take care of putting + the homepage in the right place, in meta. - > x = haskell.lib.overrideCabal haskellPackages.aeson (old: { homepage = old.homepage + "#readme"; }) - > x.meta.homepage - "https://github.com/bos/aeson#readme" + > haskellPackages.aeson.meta.homepage + "https://github.com/bos/aeson" - */ + > x = haskell.lib.overrideCabal haskellPackages.aeson (old: { homepage = old.homepage + "#readme"; }) + > x.meta.homepage + "https://github.com/bos/aeson#readme" + */ overrideCabal = drv: f: compose.overrideCabal f drv; # : Map Name (Either Path VersionNumber) -> HaskellPackageOverrideSet @@ -50,104 +52,118 @@ rec { # the packages named in the input set to the corresponding versions packageSourceOverrides = compose.packageSourceOverrides; - /* doCoverage modifies a haskell package to enable the generation - and installation of a coverage report. + /* + doCoverage modifies a haskell package to enable the generation + and installation of a coverage report. - See https://wiki.haskell.org/Haskell_program_coverage - */ + See https://wiki.haskell.org/Haskell_program_coverage + */ doCoverage = compose.doCoverage; - /* dontCoverage modifies a haskell package to disable the generation - and installation of a coverage report. - */ + /* + dontCoverage modifies a haskell package to disable the generation + and installation of a coverage report. + */ dontCoverage = compose.dontCoverage; - /* doHaddock modifies a haskell package to enable the generation and - installation of API documentation from code comments using the - haddock tool. - */ + /* + doHaddock modifies a haskell package to enable the generation and + installation of API documentation from code comments using the + haddock tool. + */ doHaddock = compose.doHaddock; - /* dontHaddock modifies a haskell package to disable the generation and - installation of API documentation from code comments using the - haddock tool. - */ + /* + dontHaddock modifies a haskell package to disable the generation and + installation of API documentation from code comments using the + haddock tool. + */ dontHaddock = compose.dontHaddock; - /* doJailbreak enables the removal of version bounds from the cabal - file. You may want to avoid this function. - - This is useful when a package reports that it can not be built - due to version mismatches. In some cases, removing the version - bounds entirely is an easy way to make a package build, but at - the risk of breaking software in non-obvious ways now or in the - future. + /* + doJailbreak enables the removal of version bounds from the cabal + file. You may want to avoid this function. - Instead of jailbreaking, you can patch the cabal file. + This is useful when a package reports that it can not be built + due to version mismatches. In some cases, removing the version + bounds entirely is an easy way to make a package build, but at + the risk of breaking software in non-obvious ways now or in the + future. - Note that jailbreaking at this time, doesn't lift bounds on - conditional branches. - https://github.com/peti/jailbreak-cabal/issues/7 has further details. + Instead of jailbreaking, you can patch the cabal file. - */ + Note that jailbreaking at this time, doesn't lift bounds on + conditional branches. + https://github.com/peti/jailbreak-cabal/issues/7 has further details. + */ doJailbreak = compose.doJailbreak; - /* dontJailbreak restores the use of the version bounds the check - the use of dependencies in the package description. - */ + /* + dontJailbreak restores the use of the version bounds the check + the use of dependencies in the package description. + */ dontJailbreak = compose.dontJailbreak; - /* doCheck enables dependency checking, compilation and execution - of test suites listed in the package description file. - */ + /* + doCheck enables dependency checking, compilation and execution + of test suites listed in the package description file. + */ doCheck = compose.doCheck; - /* dontCheck disables dependency checking, compilation and execution - of test suites listed in the package description file. - */ + /* + dontCheck disables dependency checking, compilation and execution + of test suites listed in the package description file. + */ dontCheck = compose.dontCheck; - /* The dontCheckIf variant sets doCheck = false if the condition - applies. In any other case the previously set/default value is used. - This prevents accidentally re-enabling tests in a later override. - */ + /* + The dontCheckIf variant sets doCheck = false if the condition + applies. In any other case the previously set/default value is used. + This prevents accidentally re-enabling tests in a later override. + */ dontCheckIf = drv: condition: compose.dontCheckIf condition drv; - /* doBenchmark enables dependency checking, compilation and execution - for benchmarks listed in the package description file. - */ + /* + doBenchmark enables dependency checking, compilation and execution + for benchmarks listed in the package description file. + */ doBenchmark = compose.doBenchmark; - /* dontBenchmark disables dependency checking, compilation and execution - for benchmarks listed in the package description file. - */ + /* + dontBenchmark disables dependency checking, compilation and execution + for benchmarks listed in the package description file. + */ dontBenchmark = compose.dontBenchmark; - /* doDistribute enables the distribution of binaries for the package - via hydra. - */ + /* + doDistribute enables the distribution of binaries for the package + via hydra. + */ doDistribute = compose.doDistribute; - /* dontDistribute disables the distribution of binaries for the package - via hydra. - */ + /* + dontDistribute disables the distribution of binaries for the package + via hydra. + */ dontDistribute = compose.dontDistribute; - /* appendConfigureFlag adds a single argument that will be passed to the - cabal configure command, after the arguments that have been defined - in the initial declaration or previous overrides. + /* + appendConfigureFlag adds a single argument that will be passed to the + cabal configure command, after the arguments that have been defined + in the initial declaration or previous overrides. - Example: + Example: - > haskell.lib.appendConfigureFlag haskellPackages.servant "--profiling-detail=all-functions" - */ + > haskell.lib.appendConfigureFlag haskellPackages.servant "--profiling-detail=all-functions" + */ appendConfigureFlag = drv: x: compose.appendConfigureFlag x drv; appendConfigureFlags = drv: xs: compose.appendConfigureFlags xs drv; appendBuildFlag = drv: x: compose.appendBuildFlag x drv; appendBuildFlags = drv: xs: compose.appendBuildFlags xs drv; - /* removeConfigureFlag drv x is a Haskell package like drv, but with - all cabal configure arguments that are equal to x removed. + /* + removeConfigureFlag drv x is a Haskell package like drv, but with + all cabal configure arguments that are equal to x removed. - > haskell.lib.removeConfigureFlag haskellPackages.servant "--verbose" - */ + > haskell.lib.removeConfigureFlag haskellPackages.servant "--verbose" + */ removeConfigureFlag = drv: x: compose.removeConfigureFlag x drv; addBuildTool = drv: x: compose.addBuildTool x drv; @@ -201,13 +217,13 @@ rec { appendPatch = drv: x: compose.appendPatch x drv; appendPatches = drv: xs: compose.appendPatches xs drv; - /* Set a specific build target instead of compiling all targets in the package. - * For example, imagine we have a .cabal file with a library, and 2 executables "dev" and "server". - * We can build only "server" and not wait on the compilation of "dev" by using setBuildTarget as follows: - * - * setBuildTarget (callCabal2nix "thePackageName" thePackageSrc {}) "server" - * - */ + /* + Set a specific build target instead of compiling all targets in the package. + For example, imagine we have a .cabal file with a library, and 2 executables "dev" and "server". + We can build only "server" and not wait on the compilation of "dev" by using setBuildTarget as follows: + + setBuildTarget (callCabal2nix "thePackageName" thePackageSrc {}) "server" + */ setBuildTargets = drv: xs: compose.setBuildTargets xs drv; setBuildTarget = drv: x: compose.setBuildTarget x drv; @@ -216,79 +232,93 @@ rec { disableHardening = drv: flags: compose.disableHardening flags drv; - /* Let Nix strip the binary files. - * This removes debugging symbols. - */ + /* + Let Nix strip the binary files. + This removes debugging symbols. + */ doStrip = compose.doStrip; - /* Stop Nix from stripping the binary files. - * This keeps debugging symbols. - */ + /* + Stop Nix from stripping the binary files. + This keeps debugging symbols. + */ dontStrip = compose.dontStrip; - /* Useful for debugging segfaults with gdb. - * This includes dontStrip. - */ + /* + Useful for debugging segfaults with gdb. + This includes dontStrip. + */ enableDWARFDebugging = compose.enableDWARFDebugging; - /* Create a source distribution tarball like those found on hackage, - instead of building the package. - */ + /* + Create a source distribution tarball like those found on hackage, + instead of building the package. + */ sdistTarball = compose.sdistTarball; - /* Create a documentation tarball suitable for uploading to Hackage instead - of building the package. - */ + /* + Create a documentation tarball suitable for uploading to Hackage instead + of building the package. + */ documentationTarball = compose.documentationTarball; - /* Use the gold linker. It is a linker for ELF that is designed - "to run as fast as possible on modern systems" - */ + /* + Use the gold linker. It is a linker for ELF that is designed + "to run as fast as possible on modern systems" + */ linkWithGold = compose.linkWithGold; - /* link executables statically against haskell libs to reduce - closure size - */ + /* + link executables statically against haskell libs to reduce + closure size + */ justStaticExecutables = compose.justStaticExecutables; - /* Build a source distribution tarball instead of using the source files - directly. The effect is that the package is built as if it were published - on hackage. This can be used as a test for the source distribution, - assuming the build fails when packaging mistakes are in the cabal file. - */ + /* + Build a source distribution tarball instead of using the source files + directly. The effect is that the package is built as if it were published + on hackage. This can be used as a test for the source distribution, + assuming the build fails when packaging mistakes are in the cabal file. + */ buildFromSdist = compose.buildFromSdist; - /* Build the package in a strict way to uncover potential problems. - This includes buildFromSdist and failOnAllWarnings. - */ + /* + Build the package in a strict way to uncover potential problems. + This includes buildFromSdist and failOnAllWarnings. + */ buildStrictly = compose.buildStrictly; - /* Disable core optimizations, significantly speeds up build time */ + # Disable core optimizations, significantly speeds up build time disableOptimization = compose.disableOptimization; - /* Turn on most of the compiler warnings and fail the build if any - of them occur. */ + /* + Turn on most of the compiler warnings and fail the build if any + of them occur. + */ failOnAllWarnings = compose.failOnAllWarnings; - /* Add a post-build check to verify that dependencies declared in - the cabal file are actually used. + /* + Add a post-build check to verify that dependencies declared in + the cabal file are actually used. - The first attrset argument can be used to configure the strictness - of this check and a list of ignored package names that would otherwise - cause false alarms. - */ + The first attrset argument can be used to configure the strictness + of this check and a list of ignored package names that would otherwise + cause false alarms. + */ checkUnusedPackages = compose.checkUnusedPackages; buildStackProject = compose.buildStackProject; - /* Add a dummy command to trigger a build despite an equivalent - earlier build that is present in the store or cache. - */ + /* + Add a dummy command to trigger a build despite an equivalent + earlier build that is present in the store or cache. + */ triggerRebuild = drv: i: compose.triggerRebuild i drv; - /* Override the sources for the package and optionally the version. - This also takes of removing editedCabalFile. - */ + /* + Override the sources for the package and optionally the version. + This also takes of removing editedCabalFile. + */ overrideSrc = drv: src: compose.overrideSrc src drv; # Get all of the build inputs of a haskell package, divided by category. @@ -323,9 +353,11 @@ rec { # packagesFromDirectory : { directory : Directory, ... } -> HaskellPackageOverrideSet packagesFromDirectory = compose.packagesFromDirectory; - addOptparseApplicativeCompletionScripts = exeName: pkg: - lib.warn "addOptparseApplicativeCompletionScripts is deprecated in favor of haskellPackages.generateOptparseApplicativeCompletions. Please change ${pkg.name} to use the latter and make sure it uses its matching haskell.packages set!" - (compose.__generateOptparseApplicativeCompletion exeName pkg); + addOptparseApplicativeCompletionScripts = + exeName: pkg: + lib.warn "addOptparseApplicativeCompletionScripts is deprecated in favor of haskellPackages.generateOptparseApplicativeCompletions. Please change ${pkg.name} to use the latter and make sure it uses its matching haskell.packages set!" ( + compose.__generateOptparseApplicativeCompletion exeName pkg + ); /* Modify a Haskell package to add shell completion scripts for the @@ -336,7 +368,6 @@ rec { Invocation: generateOptparseApplicativeCompletions command pkg - command: name of an executable pkg: Haskell package that builds the executables */ @@ -351,7 +382,6 @@ rec { Invocation: generateOptparseApplicativeCompletions commands pkg - commands: name of an executable pkg: Haskell package that builds the executables */ diff --git a/pkgs/development/haskell-modules/make-package-set.nix b/pkgs/development/haskell-modules/make-package-set.nix index b07196db9b7ff8..50320b4a949b0f 100644 --- a/pkgs/development/haskell-modules/make-package-set.nix +++ b/pkgs/development/haskell-modules/make-package-set.nix @@ -1,41 +1,42 @@ # This expression takes a file like `hackage-packages.nix` and constructs # a full package set out of that. -{ # package-set used for build tools (all of nixpkgs) - buildPackages +{ + # package-set used for build tools (all of nixpkgs) + buildPackages, -, # A haskell package set for Setup.hs, compiler plugins, and similar + # A haskell package set for Setup.hs, compiler plugins, and similar # build-time uses. - buildHaskellPackages + buildHaskellPackages, -, # package-set used for non-haskell dependencies (all of nixpkgs) - pkgs + # package-set used for non-haskell dependencies (all of nixpkgs) + pkgs, -, # stdenv provides our build and host platforms - stdenv + # stdenv provides our build and host platforms + stdenv, -, # this module provides the list of known licenses and maintainers - lib + # this module provides the list of known licenses and maintainers + lib, # needed for overrideCabal & packageSourceOverrides -, haskellLib + haskellLib, -, # hashes for downloading Hackage packages + # hashes for downloading Hackage packages # This is either a directory or a .tar.gz containing the cabal files and # hashes of Hackage as exemplified by this repository: # https://github.com/commercialhaskell/all-cabal-hashes/tree/hackage - all-cabal-hashes + all-cabal-hashes, -, # compiler to use - ghc + # compiler to use + ghc, -, # A function that takes `{ pkgs, lib, callPackage }` as the first arg and + # A function that takes `{ pkgs, lib, callPackage }` as the first arg and # `self` as second, and returns a set of haskell packages - package-set + package-set, -, # The final, fully overridden package set usable with the nixpkgs fixpoint + # The final, fully overridden package set usable with the nixpkgs fixpoint # overriding functionality - extensible-self + extensible-self, }: # return value: a function from self to the package set @@ -50,25 +51,42 @@ let mkDerivationImpl = pkgs.callPackage ./generic-builder.nix { inherit stdenv; nodejs = buildPackages.nodejs-slim; - inherit (self) buildHaskellPackages ghc ghcWithHoogle ghcWithPackages; + inherit (self) + buildHaskellPackages + ghc + ghcWithHoogle + ghcWithPackages + ; inherit (self.buildHaskellPackages) jailbreak-cabal; hscolour = overrideCabal (drv: { isLibrary = false; doHaddock = false; - hyperlinkSource = false; # Avoid depending on hscolour for this build. + hyperlinkSource = false; # Avoid depending on hscolour for this build. postFixup = "rm -rf $out/lib $out/share $out/nix-support"; }) self.buildHaskellPackages.hscolour; - cpphs = overrideCabal (drv: { - isLibrary = false; - postFixup = "rm -rf $out/lib $out/share $out/nix-support"; - }) (self.cpphs.overrideScope (self: super: { - mkDerivation = drv: super.mkDerivation (drv // { - enableSharedExecutables = false; - enableSharedLibraries = false; - doHaddock = false; - useCpphs = false; - }); - })); + cpphs = + overrideCabal + (drv: { + isLibrary = false; + postFixup = "rm -rf $out/lib $out/share $out/nix-support"; + }) + ( + self.cpphs.overrideScope ( + self: super: { + mkDerivation = + drv: + super.mkDerivation ( + drv + // { + enableSharedExecutables = false; + enableSharedLibraries = false; + doHaddock = false; + useCpphs = false; + } + ); + } + ) + ); }; mkDerivation = makeOverridable mkDerivationImpl; @@ -78,7 +96,8 @@ let # callPackage foo { bar = null; }; # # here `bar` is a manual argument. - callPackageWithScope = scope: fn: manualArgs: + callPackageWithScope = + scope: fn: manualArgs: let # this code is copied from callPackage in lib/customisation.nix # @@ -94,82 +113,113 @@ let ensureAttrs = v: if builtins.isFunction v then { __functor = _: v; } else v; # this wraps the `drv` function to add `scope` and `overrideScope` to the result. - drvScope = allArgs: ensureAttrs (drv allArgs) // { - inherit scope; - overrideScope = f: - let newScope = mkScope (fix' (extends f scope.__unfix__)); - # note that we have to be careful here: `allArgs` includes the auto-arguments that - # weren't manually specified. If we would just pass `allArgs` to the recursive call here, - # then we wouldn't look up any packages in the scope in the next interation, because it - # appears as if all arguments were already manually passed, so the scope change would do - # nothing. - in callPackageWithScope newScope drv manualArgs; - }; - in lib.makeOverridable drvScope (auto // manualArgs); + drvScope = + allArgs: + ensureAttrs (drv allArgs) + // { + inherit scope; + overrideScope = + f: + let + newScope = mkScope (fix' (extends f scope.__unfix__)); + in + # note that we have to be careful here: `allArgs` includes the auto-arguments that + # weren't manually specified. If we would just pass `allArgs` to the recursive call here, + # then we wouldn't look up any packages in the scope in the next interation, because it + # appears as if all arguments were already manually passed, so the scope change would do + # nothing. + callPackageWithScope newScope drv manualArgs; + }; + in + lib.makeOverridable drvScope (auto // manualArgs); - mkScope = scope: let + mkScope = + scope: + let ps = pkgs.__splicedPackages; - scopeSpliced = pkgs.splicePackages { - pkgsBuildBuild = scope.buildHaskellPackages.buildHaskellPackages; - pkgsBuildHost = scope.buildHaskellPackages; - pkgsBuildTarget = {}; - pkgsHostHost = {}; - pkgsHostTarget = scope; - pkgsTargetTarget = {}; - } // { - # Don't splice these - inherit (scope) ghc buildHaskellPackages; - }; - in ps // ps.xorg // ps.gnome2 // { inherit stdenv; } // scopeSpliced; + scopeSpliced = + pkgs.splicePackages { + pkgsBuildBuild = scope.buildHaskellPackages.buildHaskellPackages; + pkgsBuildHost = scope.buildHaskellPackages; + pkgsBuildTarget = { }; + pkgsHostHost = { }; + pkgsHostTarget = scope; + pkgsTargetTarget = { }; + } + // { + # Don't splice these + inherit (scope) ghc buildHaskellPackages; + }; + in + ps // ps.xorg // ps.gnome2 // { inherit stdenv; } // scopeSpliced; defaultScope = mkScope self; callPackage = drv: args: callPackageWithScope defaultScope drv args; # Use cabal2nix to create a default.nix for the package sources found at 'src'. - haskellSrc2nix = { name, src, sha256 ? null, extraCabal2nixOptions ? "" }: + haskellSrc2nix = + { + name, + src, + sha256 ? null, + extraCabal2nixOptions ? "", + }: let sha256Arg = if sha256 == null then "--sha256=" else ''--sha256="${sha256}"''; - in buildPackages.runCommand "cabal2nix-${name}" { - nativeBuildInputs = [ buildPackages.cabal2nix-unwrapped ]; - preferLocalBuild = true; - allowSubstitutes = false; - LANG = "en_US.UTF-8"; - LOCALE_ARCHIVE = pkgs.lib.optionalString (buildPlatform.libc == "glibc") "${buildPackages.glibcLocales}/lib/locale/locale-archive"; - } '' - export HOME="$TMP" - mkdir -p "$out" - cabal2nix --compiler=${self.ghc.haskellCompilerName} --system=${hostPlatform.config} ${sha256Arg} "${src}" ${extraCabal2nixOptions} > "$out/default.nix" - ''; + in + buildPackages.runCommand "cabal2nix-${name}" + { + nativeBuildInputs = [ buildPackages.cabal2nix-unwrapped ]; + preferLocalBuild = true; + allowSubstitutes = false; + LANG = "en_US.UTF-8"; + LOCALE_ARCHIVE = pkgs.lib.optionalString ( + buildPlatform.libc == "glibc" + ) "${buildPackages.glibcLocales}/lib/locale/locale-archive"; + } + '' + export HOME="$TMP" + mkdir -p "$out" + cabal2nix --compiler=${self.ghc.haskellCompilerName} --system=${hostPlatform.config} ${sha256Arg} "${src}" ${extraCabal2nixOptions} > "$out/default.nix" + ''; # Given a package name and version, e.g. name = "async", version = "2.2.4", # gives its cabal file and hashes (JSON file) as discovered from the # all-cabal-hashes value. If that's a directory, it will copy the relevant # files to $out; if it's a tarball, it will extract and move them to $out. - all-cabal-hashes-component = name: version: buildPackages.runCommand "all-cabal-hashes-component-${name}-${version}" {} '' - mkdir -p $out - if [ -d ${all-cabal-hashes} ] - then - cp ${all-cabal-hashes}/${name}/${version}/${name}.json $out - cp ${all-cabal-hashes}/${name}/${version}/${name}.cabal $out - else - tar --wildcards -xzvf ${all-cabal-hashes} \*/${name}/${version}/${name}.{json,cabal} - mv */${name}/${version}/${name}.{json,cabal} $out - fi - ''; - - hackage2nix = name: version: let component = all-cabal-hashes-component name version; in self.haskellSrc2nix { - name = "${name}-${version}"; - sha256 = ''$(sed -e 's/.*"SHA256":"//' -e 's/".*$//' "${component}/${name}.json")''; - src = "${component}/${name}.cabal"; - }; + all-cabal-hashes-component = + name: version: + buildPackages.runCommand "all-cabal-hashes-component-${name}-${version}" { } '' + mkdir -p $out + if [ -d ${all-cabal-hashes} ] + then + cp ${all-cabal-hashes}/${name}/${version}/${name}.json $out + cp ${all-cabal-hashes}/${name}/${version}/${name}.cabal $out + else + tar --wildcards -xzvf ${all-cabal-hashes} \*/${name}/${version}/${name}.{json,cabal} + mv */${name}/${version}/${name}.{json,cabal} $out + fi + ''; + + hackage2nix = + name: version: + let + component = all-cabal-hashes-component name version; + in + self.haskellSrc2nix { + name = "${name}-${version}"; + sha256 = ''$(sed -e 's/.*"SHA256":"//' -e 's/".*$//' "${component}/${name}.json")''; + src = "${component}/${name}.cabal"; + }; # Adds a nix file derived from cabal2nix in the passthru of the derivation it # produces. This is useful to debug callHackage / callCabal2nix by looking at # the content of the nix file pointed by `cabal2nixDeriver`. # However, it does not keep a reference to that file, which may be garbage # collected, which may be an annoyance. - callPackageKeepDeriver = src: args: + callPackageKeepDeriver = + src: args: overrideCabal (orig: { - passthru = orig.passthru or {} // { + passthru = orig.passthru or { } // { # When using callCabal2nix or callHackage, it is often useful # to debug a failure by inspecting the Nix expression # generated by cabal2nix. This can be accessed via this @@ -178,346 +228,373 @@ let }; }) (self.callPackage src args); -in package-set { inherit pkgs lib callPackage; } self // { - - inherit mkDerivation callPackage haskellSrc2nix hackage2nix buildHaskellPackages; - - inherit (haskellLib) packageSourceOverrides; - - # callHackage :: Text -> Text -> AttrSet -> HaskellPackage - # - # e.g., while overriding a package set: - # '... foo = self.callHackage "foo" "1.5.3" {}; ...' - callHackage = name: version: callPackageKeepDeriver (self.hackage2nix name version); - - # callHackageDirect - # :: { pkg :: Text, ver :: Text, sha256 :: Text } - # -> AttrSet - # -> HaskellPackage - # - # This function does not depend on all-cabal-hashes and therefore will work - # for any version that has been released on hackage as opposed to only - # versions released before whatever version of all-cabal-hashes you happen - # to be currently using. - callHackageDirect = {pkg, ver, sha256, rev ? { revision = null; sha256 = null; }}: args: - let pkgver = "${pkg}-${ver}"; - firstRevision = self.callCabal2nix pkg (pkgs.fetchzip { - url = "mirror://hackage/${pkgver}/${pkgver}.tar.gz"; - inherit sha256; - }) args; - in overrideCabal (orig: { - revision = rev.revision; - editedCabalFile = rev.sha256; - }) firstRevision; - - # Creates a Haskell package from a source package by calling cabal2nix on the source. - callCabal2nixWithOptions = name: src: opts: args: - let - extraCabal2nixOptions = if builtins.isString opts - then opts - else opts.extraCabal2nixOptions or ""; - srcModifier = opts.srcModifier or null; - defaultFilter = path: type: - pkgs.lib.hasSuffix ".cabal" path || - baseNameOf path == "package.yaml"; - expr = self.haskellSrc2nix { - inherit name extraCabal2nixOptions; - src = if srcModifier != null - then srcModifier src - else if pkgs.lib.canCleanSource src - then pkgs.lib.cleanSourceWith { inherit src; filter = defaultFilter; } - else src; - }; - in overrideCabal (orig: { - inherit src; - }) (callPackageKeepDeriver expr args); - - callCabal2nix = name: src: args: self.callCabal2nixWithOptions name src "" args; - - # : { root : Path - # , name : Defaulted String - # , source-overrides : Defaulted (Either Path VersionNumber) - # , overrides : Defaulted (HaskellPackageOverrideSet) - # , modifier : Defaulted - # , returnShellEnv : Defaulted - # , withHoogle : Defaulted - # , cabal2nixOptions : Defaulted - # } -> NixShellAwareDerivation - # - # Given a path to a haskell package directory, an optional package name - # which defaults to the base name of the path, an optional set of source - # overrides as appropriate for the 'packageSourceOverrides' function, an - # optional set of arbitrary overrides, and an optional haskell package - # modifier, return a derivation appropriate for nix-build or nix-shell to - # build that package. - # - # If 'returnShellEnv' is true this returns a derivation which will give you - # an environment suitable for developing the listed packages with an - # incremental tool like cabal-install. - # - # If 'withHoogle' is true (the default if a shell environment is requested) - # then 'ghcWithHoogle' is used to generate the derivation (instead of - # 'ghcWithPackages'), see the documentation there for more information. - # - # 'cabal2nixOptions' can contain extra command line arguments to pass to - # 'cabal2nix' when generating the package derivation, for example setting - # a cabal flag with '--flag=myflag'. - developPackage = - { root - , name ? lib.optionalString (builtins.typeOf root == "path") (builtins.baseNameOf root) - , source-overrides ? {} - , overrides ? self: super: {} - , modifier ? drv: drv - , returnShellEnv ? pkgs.lib.inNixShell - , withHoogle ? returnShellEnv - , cabal2nixOptions ? "" }: - let drv = - (extensible-self.extend - (pkgs.lib.composeExtensions - (self.packageSourceOverrides source-overrides) - overrides)) - .callCabal2nixWithOptions name root cabal2nixOptions {}; - in if returnShellEnv - then (modifier drv).envFunc {inherit withHoogle;} - else modifier drv; - - # This can be used to easily create a derivation containing GHC and the specified set of Haskell packages. - # - # Example: - # $ nix-shell -p 'haskellPackages.ghcWithPackages (hpkgs: [ hpkgs.mtl hpkgs.lens ])' - # $ ghci # in the nix-shell - # Prelude > import Control.Lens - # - # GHC is setup with a package database with all the specified Haskell packages. - # - # ghcWithPackages :: (HaskellPkgSet -> [ HaskellPkg ]) -> Derivation - ghcWithPackages = buildHaskellPackages.callPackage ./with-packages-wrapper.nix { - haskellPackages = self; - inherit (self) hoogleWithPackages; - }; +in +package-set { inherit pkgs lib callPackage; } self +// { + inherit + mkDerivation + callPackage + haskellSrc2nix + hackage2nix + buildHaskellPackages + ; - # Put 'hoogle' into the derivation's PATH with a database containing all - # the package's dependencies; run 'hoogle server --local' in a shell to - # host a search engine for the dependencies. - # - # Example usage: - # $ nix-shell -p 'haskellPackages.hoogleWithPackages (p: [ p.mtl p.lens ])' - # [nix-shell] $ hoogle server - # - # hoogleWithPackages :: (HaskellPkgSet -> [ HaskellPkg ]) -> Derivation - # - # To reload the Hoogle server automatically on .cabal file changes try - # this: - # echo *.cabal | entr -r -- nix-shell --run 'hoogle server --local' - hoogleWithPackages = self.callPackage ./hoogle.nix { - haskellPackages = self; - }; - hoogleLocal = - { packages ? [] }: - lib.warn "hoogleLocal is deprecated, use hoogleWithPackages instead" ( - self.hoogleWithPackages (_: packages) + inherit (haskellLib) packageSourceOverrides; + + # callHackage :: Text -> Text -> AttrSet -> HaskellPackage + # + # e.g., while overriding a package set: + # '... foo = self.callHackage "foo" "1.5.3" {}; ...' + callHackage = name: version: callPackageKeepDeriver (self.hackage2nix name version); + + # callHackageDirect + # :: { pkg :: Text, ver :: Text, sha256 :: Text } + # -> AttrSet + # -> HaskellPackage + # + # This function does not depend on all-cabal-hashes and therefore will work + # for any version that has been released on hackage as opposed to only + # versions released before whatever version of all-cabal-hashes you happen + # to be currently using. + callHackageDirect = + { + pkg, + ver, + sha256, + rev ? { + revision = null; + sha256 = null; + }, + }: + args: + let + pkgver = "${pkg}-${ver}"; + firstRevision = self.callCabal2nix pkg (pkgs.fetchzip { + url = "mirror://hackage/${pkgver}/${pkgver}.tar.gz"; + inherit sha256; + }) args; + in + overrideCabal (orig: { + revision = rev.revision; + editedCabalFile = rev.sha256; + }) firstRevision; + + # Creates a Haskell package from a source package by calling cabal2nix on the source. + callCabal2nixWithOptions = + name: src: opts: args: + let + extraCabal2nixOptions = if builtins.isString opts then opts else opts.extraCabal2nixOptions or ""; + srcModifier = opts.srcModifier or null; + defaultFilter = path: type: pkgs.lib.hasSuffix ".cabal" path || baseNameOf path == "package.yaml"; + expr = self.haskellSrc2nix { + inherit name extraCabal2nixOptions; + src = + if srcModifier != null then + srcModifier src + else if pkgs.lib.canCleanSource src then + pkgs.lib.cleanSourceWith { + inherit src; + filter = defaultFilter; + } + else + src; + }; + in + overrideCabal (orig: { + inherit src; + }) (callPackageKeepDeriver expr args); + + callCabal2nix = + name: src: args: + self.callCabal2nixWithOptions name src "" args; + + # : { root : Path + # , name : Defaulted String + # , source-overrides : Defaulted (Either Path VersionNumber) + # , overrides : Defaulted (HaskellPackageOverrideSet) + # , modifier : Defaulted + # , returnShellEnv : Defaulted + # , withHoogle : Defaulted + # , cabal2nixOptions : Defaulted + # } -> NixShellAwareDerivation + # + # Given a path to a haskell package directory, an optional package name + # which defaults to the base name of the path, an optional set of source + # overrides as appropriate for the 'packageSourceOverrides' function, an + # optional set of arbitrary overrides, and an optional haskell package + # modifier, return a derivation appropriate for nix-build or nix-shell to + # build that package. + # + # If 'returnShellEnv' is true this returns a derivation which will give you + # an environment suitable for developing the listed packages with an + # incremental tool like cabal-install. + # + # If 'withHoogle' is true (the default if a shell environment is requested) + # then 'ghcWithHoogle' is used to generate the derivation (instead of + # 'ghcWithPackages'), see the documentation there for more information. + # + # 'cabal2nixOptions' can contain extra command line arguments to pass to + # 'cabal2nix' when generating the package derivation, for example setting + # a cabal flag with '--flag=myflag'. + developPackage = + { + root, + name ? lib.optionalString (builtins.typeOf root == "path") (builtins.baseNameOf root), + source-overrides ? { }, + overrides ? self: super: { }, + modifier ? drv: drv, + returnShellEnv ? pkgs.lib.inNixShell, + withHoogle ? returnShellEnv, + cabal2nixOptions ? "", + }: + let + drv = + (extensible-self.extend ( + pkgs.lib.composeExtensions (self.packageSourceOverrides source-overrides) overrides + )).callCabal2nixWithOptions + name + root + cabal2nixOptions + { }; + in + if returnShellEnv then (modifier drv).envFunc { inherit withHoogle; } else modifier drv; + + # This can be used to easily create a derivation containing GHC and the specified set of Haskell packages. + # + # Example: + # $ nix-shell -p 'haskellPackages.ghcWithPackages (hpkgs: [ hpkgs.mtl hpkgs.lens ])' + # $ ghci # in the nix-shell + # Prelude > import Control.Lens + # + # GHC is setup with a package database with all the specified Haskell packages. + # + # ghcWithPackages :: (HaskellPkgSet -> [ HaskellPkg ]) -> Derivation + ghcWithPackages = buildHaskellPackages.callPackage ./with-packages-wrapper.nix { + haskellPackages = self; + inherit (self) hoogleWithPackages; + }; + + # Put 'hoogle' into the derivation's PATH with a database containing all + # the package's dependencies; run 'hoogle server --local' in a shell to + # host a search engine for the dependencies. + # + # Example usage: + # $ nix-shell -p 'haskellPackages.hoogleWithPackages (p: [ p.mtl p.lens ])' + # [nix-shell] $ hoogle server + # + # hoogleWithPackages :: (HaskellPkgSet -> [ HaskellPkg ]) -> Derivation + # + # To reload the Hoogle server automatically on .cabal file changes try + # this: + # echo *.cabal | entr -r -- nix-shell --run 'hoogle server --local' + hoogleWithPackages = self.callPackage ./hoogle.nix { + haskellPackages = self; + }; + hoogleLocal = + { + packages ? [ ], + }: + lib.warn "hoogleLocal is deprecated, use hoogleWithPackages instead" ( + self.hoogleWithPackages (_: packages) + ); + # This is like a combination of ghcWithPackages and hoogleWithPackages. + # It provides a derivation containing both GHC and Hoogle with an index of + # the given Haskell package database. + # + # Example: + # $ nix-shell -p 'haskellPackages.ghcWithHoogle (hpkgs: [ hpkgs.conduit hpkgs.lens ])' + # + # ghcWithHoogle :: (HaskellPkgSet -> [ HaskellPkg ]) -> Derivation + ghcWithHoogle = self.ghcWithPackages.override { + withHoogle = true; + }; + + # Returns a derivation whose environment contains a GHC with only + # the dependencies of packages listed in `packages`, not the + # packages themselves. Using nix-shell on this derivation will + # give you an environment suitable for developing the listed + # packages with an incremental tool like cabal-install. + # + # In addition to the "packages" arg and "withHoogle" arg, anything that + # can be passed into stdenv.mkDerivation can be included in the input attrset + # + # # default.nix + # with import {}; + # haskellPackages.extend (haskell.lib.compose.packageSourceOverrides { + # frontend = ./frontend; + # backend = ./backend; + # common = ./common; + # }) + # + # # shell.nix + # let pkgs = import {} in + # (import ./.).shellFor { + # packages = p: [p.frontend p.backend p.common]; + # withHoogle = true; + # buildInputs = [ pkgs.python pkgs.cabal-install ]; + # } + # + # -- cabal.project + # packages: + # frontend/ + # backend/ + # common/ + # + # bash$ nix-shell --run "cabal new-build all" + # bash$ nix-shell --run "python" + shellFor = + { + # Packages to create this development shell for. These are usually + # your local packages. + packages, + # Whether or not to generate a Hoogle database for all the + # dependencies. + withHoogle ? false, + # Whether or not to include benchmark dependencies of your local + # packages. You should set this to true if you have benchmarks defined + # in your local packages that you want to be able to run with cabal benchmark + doBenchmark ? false, + # An optional function that can modify the generic builder arguments + # for the fake package that shellFor uses to construct its environment. + # + # Example: + # let + # # elided... + # haskellPkgs = pkgs.haskell.packages.ghc884.override (hpArgs: { + # overrides = pkgs.lib.composeExtensions (hpArgs.overrides or (_: _: { })) ( + # _hfinal: hprev: { + # mkDerivation = args: hprev.mkDerivation ({ + # doCheck = false; + # doBenchmark = false; + # doHoogle = true; + # doHaddock = true; + # enableLibraryProfiling = false; + # enableExecutableProfiling = false; + # } // args); + # } + # ); + # }); + # in + # haskellPkgs.shellFor { + # packages = p: [ p.foo ]; + # genericBuilderArgsModifier = args: args // { doCheck = true; doBenchmark = true }; + # } + # + # This will disable tests and benchmarks for everything in "haskellPkgs" + # (which will invalidate the binary cache), and then re-enable them + # for the "shellFor" environment (ensuring that any test/benchmark + # dependencies for "foo" will be available within the nix-shell). + genericBuilderArgsModifier ? (args: args), + + # Extra dependencies, in the form of cabal2nix build attributes. + # + # An example use case is when you have Haskell scripts that use + # libraries that don't occur in your packages' dependencies. + # + # Example: + # + # extraDependencies = p: { + # libraryHaskellDepends = [ p.releaser ]; + # }; + extraDependencies ? p: { }, + ... + }@args: + let + # A list of the packages we want to build a development shell for. + # This is a list of Haskell package derivations. + selected = packages self; + + # This is a list of attribute sets, where each attribute set + # corresponds to the build inputs of one of the packages input to shellFor. + # + # Each attribute has keys like buildDepends, executableHaskellDepends, + # testPkgconfigDepends, etc. The values for the keys of the attribute + # set are lists of dependencies. + # + # Example: + # cabalDepsForSelected + # => [ + # # This may be the attribute set corresponding to the `backend` + # # package in the example above. + # { buildDepends = [ gcc ... ]; + # libraryHaskellDepends = [ lens conduit ... ]; + # ... + # } + # # This may be the attribute set corresponding to the `common` + # # package in the example above. + # { testHaskellDepends = [ tasty hspec ... ]; + # libraryHaskellDepends = [ lens aeson ]; + # benchmarkHaskellDepends = [ criterion ... ]; + # ... + # } + # ... + # ] + cabalDepsForSelected = map (p: p.getCabalDeps) selected; + + # A predicate that takes a derivation as input, and tests whether it is + # the same as any of the `selected` packages. + # + # Returns true if the input derivation is not in the list of `selected` + # packages. + # + # isNotSelected :: Derivation -> Bool + # + # Example: + # + # isNotSelected common [ frontend backend common ] + # => false + # + # isNotSelected lens [ frontend backend common ] + # => true + isNotSelected = input: pkgs.lib.all (p: input.outPath or null != p.outPath) selected; + + # A function that takes a list of list of derivations, filters out all + # the `selected` packages from each list, and concats the results. + # + # zipperCombinedPkgs :: [[Derivation]] -> [Derivation] + # + # Example: + # zipperCombinedPkgs [ [ lens conduit ] [ aeson frontend ] ] + # => [ lens conduit aeson ] + # + # Note: The reason this isn't just the function `pkgs.lib.concat` is + # that we need to be careful to remove dependencies that are in the + # `selected` packages. + # + # For instance, in the above example, if `common` is a dependency of + # `backend`, then zipperCombinedPkgs needs to be careful to filter out + # `common`, because cabal will end up ignoring that built version, + # assuming new-style commands. + zipperCombinedPkgs = vals: pkgs.lib.concatMap (drvList: pkgs.lib.filter isNotSelected drvList) vals; + + # Zip `cabalDepsForSelected` into a single attribute list, combining + # the derivations in all the individual attributes. + # + # Example: + # packageInputs + # => # Assuming the value of cabalDepsForSelected is the same as + # # the example in cabalDepsForSelected: + # { buildDepends = [ gcc ... ]; + # libraryHaskellDepends = [ lens conduit aeson ... ]; + # testHaskellDepends = [ tasty hspec ... ]; + # benchmarkHaskellDepends = [ criterion ... ]; + # ... + # } + # + # See the Note in `zipperCombinedPkgs` for what gets filtered out from + # each of these dependency lists. + packageInputs = pkgs.lib.zipAttrsWith (_name: zipperCombinedPkgs) ( + cabalDepsForSelected ++ [ (extraDependencies self) ] ); - # This is like a combination of ghcWithPackages and hoogleWithPackages. - # It provides a derivation containing both GHC and Hoogle with an index of - # the given Haskell package database. - # - # Example: - # $ nix-shell -p 'haskellPackages.ghcWithHoogle (hpkgs: [ hpkgs.conduit hpkgs.lens ])' - # - # ghcWithHoogle :: (HaskellPkgSet -> [ HaskellPkg ]) -> Derivation - ghcWithHoogle = self.ghcWithPackages.override { - withHoogle = true; - }; - # Returns a derivation whose environment contains a GHC with only - # the dependencies of packages listed in `packages`, not the - # packages themselves. Using nix-shell on this derivation will - # give you an environment suitable for developing the listed - # packages with an incremental tool like cabal-install. - # - # In addition to the "packages" arg and "withHoogle" arg, anything that - # can be passed into stdenv.mkDerivation can be included in the input attrset - # - # # default.nix - # with import {}; - # haskellPackages.extend (haskell.lib.compose.packageSourceOverrides { - # frontend = ./frontend; - # backend = ./backend; - # common = ./common; - # }) - # - # # shell.nix - # let pkgs = import {} in - # (import ./.).shellFor { - # packages = p: [p.frontend p.backend p.common]; - # withHoogle = true; - # buildInputs = [ pkgs.python pkgs.cabal-install ]; - # } - # - # -- cabal.project - # packages: - # frontend/ - # backend/ - # common/ - # - # bash$ nix-shell --run "cabal new-build all" - # bash$ nix-shell --run "python" - shellFor = - { # Packages to create this development shell for. These are usually - # your local packages. - packages - , # Whether or not to generate a Hoogle database for all the - # dependencies. - withHoogle ? false - , # Whether or not to include benchmark dependencies of your local - # packages. You should set this to true if you have benchmarks defined - # in your local packages that you want to be able to run with cabal benchmark - doBenchmark ? false - # An optional function that can modify the generic builder arguments - # for the fake package that shellFor uses to construct its environment. - # - # Example: - # let - # # elided... - # haskellPkgs = pkgs.haskell.packages.ghc884.override (hpArgs: { - # overrides = pkgs.lib.composeExtensions (hpArgs.overrides or (_: _: { })) ( - # _hfinal: hprev: { - # mkDerivation = args: hprev.mkDerivation ({ - # doCheck = false; - # doBenchmark = false; - # doHoogle = true; - # doHaddock = true; - # enableLibraryProfiling = false; - # enableExecutableProfiling = false; - # } // args); - # } - # ); - # }); - # in - # haskellPkgs.shellFor { - # packages = p: [ p.foo ]; - # genericBuilderArgsModifier = args: args // { doCheck = true; doBenchmark = true }; - # } - # - # This will disable tests and benchmarks for everything in "haskellPkgs" - # (which will invalidate the binary cache), and then re-enable them - # for the "shellFor" environment (ensuring that any test/benchmark - # dependencies for "foo" will be available within the nix-shell). - , genericBuilderArgsModifier ? (args: args) - - # Extra dependencies, in the form of cabal2nix build attributes. - # - # An example use case is when you have Haskell scripts that use - # libraries that don't occur in your packages' dependencies. - # - # Example: - # - # extraDependencies = p: { - # libraryHaskellDepends = [ p.releaser ]; - # }; - , extraDependencies ? p: {} - , ... - } @ args: - let - # A list of the packages we want to build a development shell for. - # This is a list of Haskell package derivations. - selected = packages self; - - # This is a list of attribute sets, where each attribute set - # corresponds to the build inputs of one of the packages input to shellFor. - # - # Each attribute has keys like buildDepends, executableHaskellDepends, - # testPkgconfigDepends, etc. The values for the keys of the attribute - # set are lists of dependencies. - # - # Example: - # cabalDepsForSelected - # => [ - # # This may be the attribute set corresponding to the `backend` - # # package in the example above. - # { buildDepends = [ gcc ... ]; - # libraryHaskellDepends = [ lens conduit ... ]; - # ... - # } - # # This may be the attribute set corresponding to the `common` - # # package in the example above. - # { testHaskellDepends = [ tasty hspec ... ]; - # libraryHaskellDepends = [ lens aeson ]; - # benchmarkHaskellDepends = [ criterion ... ]; - # ... - # } - # ... - # ] - cabalDepsForSelected = map (p: p.getCabalDeps) selected; - - # A predicate that takes a derivation as input, and tests whether it is - # the same as any of the `selected` packages. - # - # Returns true if the input derivation is not in the list of `selected` - # packages. - # - # isNotSelected :: Derivation -> Bool - # - # Example: - # - # isNotSelected common [ frontend backend common ] - # => false - # - # isNotSelected lens [ frontend backend common ] - # => true - isNotSelected = input: pkgs.lib.all (p: input.outPath or null != p.outPath) selected; - - # A function that takes a list of list of derivations, filters out all - # the `selected` packages from each list, and concats the results. - # - # zipperCombinedPkgs :: [[Derivation]] -> [Derivation] - # - # Example: - # zipperCombinedPkgs [ [ lens conduit ] [ aeson frontend ] ] - # => [ lens conduit aeson ] - # - # Note: The reason this isn't just the function `pkgs.lib.concat` is - # that we need to be careful to remove dependencies that are in the - # `selected` packages. - # - # For instance, in the above example, if `common` is a dependency of - # `backend`, then zipperCombinedPkgs needs to be careful to filter out - # `common`, because cabal will end up ignoring that built version, - # assuming new-style commands. - zipperCombinedPkgs = vals: - pkgs.lib.concatMap - (drvList: pkgs.lib.filter isNotSelected drvList) - vals; - - # Zip `cabalDepsForSelected` into a single attribute list, combining - # the derivations in all the individual attributes. - # - # Example: - # packageInputs - # => # Assuming the value of cabalDepsForSelected is the same as - # # the example in cabalDepsForSelected: - # { buildDepends = [ gcc ... ]; - # libraryHaskellDepends = [ lens conduit aeson ... ]; - # testHaskellDepends = [ tasty hspec ... ]; - # benchmarkHaskellDepends = [ criterion ... ]; - # ... - # } - # - # See the Note in `zipperCombinedPkgs` for what gets filtered out from - # each of these dependency lists. - packageInputs = - pkgs.lib.zipAttrsWith (_name: zipperCombinedPkgs) (cabalDepsForSelected ++ [ (extraDependencies self) ]); - - # A attribute set to pass to `haskellPackages.mkDerivation`. - # - # The important thing to note here is that all the fields from - # packageInputs are set correctly. - genericBuilderArgs = { - pname = - if pkgs.lib.length selected == 1 - then (pkgs.lib.head selected).name - else "packages"; + # A attribute set to pass to `haskellPackages.mkDerivation`. + # + # The important thing to note here is that all the fields from + # packageInputs are set correctly. + genericBuilderArgs = + { + pname = if pkgs.lib.length selected == 1 then (pkgs.lib.head selected).name else "packages"; version = "0"; license = null; } @@ -527,61 +604,74 @@ in package-set { inherit pkgs lib callPackage; } self // { doBenchmark = true; }; - # This is a pseudo Haskell package derivation that contains all the - # dependencies for the packages in `selected`. - # - # This is a derivation created with `haskellPackages.mkDerivation`. - # - # pkgWithCombinedDeps :: HaskellDerivation - pkgWithCombinedDeps = self.mkDerivation (genericBuilderArgsModifier genericBuilderArgs); - - # The derivation returned from `envFunc` for `pkgWithCombinedDeps`. - # - # This is a derivation that can be run with `nix-shell`. It provides a - # GHC with a package database with all the dependencies of our - # `selected` packages. - # - # This is a derivation created with `stdenv.mkDerivation` (not - # `haskellPackages.mkDerivation`). - # - # pkgWithCombinedDepsDevDrv :: Derivation - pkgWithCombinedDepsDevDrv = pkgWithCombinedDeps.envFunc { inherit withHoogle; }; - - mkDerivationArgs = builtins.removeAttrs args [ "genericBuilderArgsModifier" "packages" "withHoogle" "doBenchmark" "extraDependencies" ]; - - in pkgWithCombinedDepsDevDrv.overrideAttrs (old: mkDerivationArgs // { - nativeBuildInputs = old.nativeBuildInputs ++ mkDerivationArgs.nativeBuildInputs or []; - buildInputs = old.buildInputs ++ mkDerivationArgs.buildInputs or []; - }); - - ghc = ghc // { - withPackages = self.ghcWithPackages; - withHoogle = self.ghcWithHoogle; - }; + # This is a pseudo Haskell package derivation that contains all the + # dependencies for the packages in `selected`. + # + # This is a derivation created with `haskellPackages.mkDerivation`. + # + # pkgWithCombinedDeps :: HaskellDerivation + pkgWithCombinedDeps = self.mkDerivation (genericBuilderArgsModifier genericBuilderArgs); + + # The derivation returned from `envFunc` for `pkgWithCombinedDeps`. + # + # This is a derivation that can be run with `nix-shell`. It provides a + # GHC with a package database with all the dependencies of our + # `selected` packages. + # + # This is a derivation created with `stdenv.mkDerivation` (not + # `haskellPackages.mkDerivation`). + # + # pkgWithCombinedDepsDevDrv :: Derivation + pkgWithCombinedDepsDevDrv = pkgWithCombinedDeps.envFunc { inherit withHoogle; }; + + mkDerivationArgs = builtins.removeAttrs args [ + "genericBuilderArgsModifier" + "packages" + "withHoogle" + "doBenchmark" + "extraDependencies" + ]; + + in + pkgWithCombinedDepsDevDrv.overrideAttrs ( + old: + mkDerivationArgs + // { + nativeBuildInputs = old.nativeBuildInputs ++ mkDerivationArgs.nativeBuildInputs or [ ]; + buildInputs = old.buildInputs ++ mkDerivationArgs.buildInputs or [ ]; + } + ); + + ghc = ghc // { + withPackages = self.ghcWithPackages; + withHoogle = self.ghcWithHoogle; + }; - /* - Run `cabal sdist` on a source. + /* + Run `cabal sdist` on a source. - Unlike `haskell.lib.sdistTarball`, this does not require any dependencies - to be present, as it uses `cabal-install` instead of building `Setup.hs`. - This makes `cabalSdist` faster than `sdistTarball`. - */ - cabalSdist = { + Unlike `haskell.lib.sdistTarball`, this does not require any dependencies + to be present, as it uses `cabal-install` instead of building `Setup.hs`. + This makes `cabalSdist` faster than `sdistTarball`. + */ + cabalSdist = + { src, - name ? if src?name then "${src.name}-sdist.tar.gz" else "source.tar.gz" + name ? if src ? name then "${src.name}-sdist.tar.gz" else "source.tar.gz", }: - pkgs.runCommandLocal name - { - inherit src; - nativeBuildInputs = [ - buildHaskellPackages.cabal-install - - # TODO after https://github.com/haskell/cabal/issues/8352 - # remove ghc - self.ghc - ]; - dontUnpack = false; - } '' + pkgs.runCommandLocal name + { + inherit src; + nativeBuildInputs = [ + buildHaskellPackages.cabal-install + + # TODO after https://github.com/haskell/cabal/issues/8352 + # remove ghc + self.ghc + ]; + dontUnpack = false; + } + '' unpackPhase cd "''${sourceRoot:-.}" patchPhase @@ -590,63 +680,61 @@ in package-set { inherit pkgs lib callPackage; } self // { mv out/*.tar.gz $out ''; - /* - Like `haskell.lib.buildFromSdist`, but using `cabal sdist` instead of - building `./Setup`. - - Unlike `haskell.lib.buildFromSdist`, this does not require any dependencies - to be present. This makes `buildFromCabalSdist` faster than `haskell.lib.buildFromSdist`. - */ - buildFromCabalSdist = pkg: - haskellLib.overrideSrc - { - src = self.cabalSdist { inherit (pkg) src; }; - version = pkg.version; - } - pkg; - - /* - Modify a Haskell package to add shell completion scripts for the - given executables produced by it. These completion scripts will be - picked up automatically if the resulting derivation is installed, - e.g. by `nix-env -i`. - - This depends on the `--*-completion` flag `optparse-applicative` provides - automatically. Since we need to invoke installed executables, completions - are not generated if we are cross-compiling. - - commands: names of the executables built by the derivation - pkg: Haskell package that builds the executables - - Example: - generateOptparseApplicativeCompletions [ "exec1" "exec2" ] pkg - - Type: [str] -> drv -> drv - */ - generateOptparseApplicativeCompletions = - self.callPackage ( - { stdenv }: - - commands: - pkg: - - if stdenv.buildPlatform.canExecute stdenv.hostPlatform - then lib.foldr haskellLib.__generateOptparseApplicativeCompletion pkg commands - else pkg - ) { }; - - /* - Modify given Haskell package to force GHC to employ the LLVM - codegen backend when compiling. Useful when working around bugs - in a native codegen backend GHC defaults to. - - Example: - forceLlvmCodegenBackend tls - - Type: drv -> drv - */ - forceLlvmCodegenBackend = overrideCabal (drv: { - configureFlags = drv.configureFlags or [ ] ++ [ "--ghc-option=-fllvm" ]; - buildTools = drv.buildTools or [ ] ++ [ self.llvmPackages.llvm ]; - }); - } + /* + Like `haskell.lib.buildFromSdist`, but using `cabal sdist` instead of + building `./Setup`. + + Unlike `haskell.lib.buildFromSdist`, this does not require any dependencies + to be present. This makes `buildFromCabalSdist` faster than `haskell.lib.buildFromSdist`. + */ + buildFromCabalSdist = + pkg: + haskellLib.overrideSrc { + src = self.cabalSdist { inherit (pkg) src; }; + version = pkg.version; + } pkg; + + /* + Modify a Haskell package to add shell completion scripts for the + given executables produced by it. These completion scripts will be + picked up automatically if the resulting derivation is installed, + e.g. by `nix-env -i`. + + This depends on the `--*-completion` flag `optparse-applicative` provides + automatically. Since we need to invoke installed executables, completions + are not generated if we are cross-compiling. + + commands: names of the executables built by the derivation + pkg: Haskell package that builds the executables + + Example: + generateOptparseApplicativeCompletions [ "exec1" "exec2" ] pkg + + Type: [str] -> drv -> drv + */ + generateOptparseApplicativeCompletions = self.callPackage ( + { stdenv }: + + commands: pkg: + + if stdenv.buildPlatform.canExecute stdenv.hostPlatform then + lib.foldr haskellLib.__generateOptparseApplicativeCompletion pkg commands + else + pkg + ) { }; + + /* + Modify given Haskell package to force GHC to employ the LLVM + codegen backend when compiling. Useful when working around bugs + in a native codegen backend GHC defaults to. + + Example: + forceLlvmCodegenBackend tls + + Type: drv -> drv + */ + forceLlvmCodegenBackend = overrideCabal (drv: { + configureFlags = drv.configureFlags or [ ] ++ [ "--ghc-option=-fllvm" ]; + buildTools = drv.buildTools or [ ] ++ [ self.llvmPackages.llvm ]; + }); +} diff --git a/pkgs/development/haskell-modules/package-list.nix b/pkgs/development/haskell-modules/package-list.nix index 3b0efe120b0ec4..dcc89bc56cd0eb 100644 --- a/pkgs/development/haskell-modules/package-list.nix +++ b/pkgs/development/haskell-modules/package-list.nix @@ -1,4 +1,9 @@ -{ runCommand, haskellPackages, lib, all-cabal-hashes }: +{ + runCommand, + haskellPackages, + lib, + all-cabal-hashes, +}: let # Checks if the version looks like a Haskell PVP version which is the format # Hackage enforces. This will return false if the version strings is empty or @@ -6,13 +11,16 @@ let # (sadly there's no good way to show something useful on hackage in this case). isPvpVersion = v: builtins.match "([0-9]+)(\\.[0-9]+)*" v != null; - pkgLine = name: pkg: + pkgLine = + name: pkg: let version = pkg.version or ""; in lib.optionalString (isPvpVersion version && (pkg.meta.hydraPlatforms or null) != lib.platforms.none) ''"${name}","${version}","http://hydra.nixos.org/job/nixpkgs/trunk/haskellPackages.${name}.x86_64-linux"''; - all-haskellPackages = builtins.toFile "all-haskellPackages" (lib.concatStringsSep "\n" (lib.filter (x: x != "") (lib.mapAttrsToList pkgLine haskellPackages))); + all-haskellPackages = builtins.toFile "all-haskellPackages" ( + lib.concatStringsSep "\n" (lib.filter (x: x != "") (lib.mapAttrsToList pkgLine haskellPackages)) + ); in runCommand "hackage-package-list" { } # This command will make a join between all packages on hackage and haskellPackages.*. diff --git a/pkgs/development/haskell-modules/with-packages-wrapper.nix b/pkgs/development/haskell-modules/with-packages-wrapper.nix index a3ca6f5b1d2f83..020dc12651b03a 100644 --- a/pkgs/development/haskell-modules/with-packages-wrapper.nix +++ b/pkgs/development/haskell-modules/with-packages-wrapper.nix @@ -1,14 +1,19 @@ -{ lib, stdenv, haskellPackages, symlinkJoin, makeWrapper -# GHC will have LLVM available if necessary for the respective target, -# so useLLVM only needs to be changed if -fllvm is to be used for a -# platform that has NCG support -, useLLVM ? false -, withHoogle ? false -# Whether to install `doc` outputs for GHC and all included libraries. -, installDocumentation ? true -, hoogleWithPackages -, postBuild ? "" -, ghcLibdir ? null # only used by ghcjs, when resolving plugins +{ + lib, + stdenv, + haskellPackages, + symlinkJoin, + makeWrapper, + # GHC will have LLVM available if necessary for the respective target, + # so useLLVM only needs to be changed if -fllvm is to be used for a + # platform that has NCG support + useLLVM ? false, + withHoogle ? false, + # Whether to install `doc` outputs for GHC and all included libraries. + installDocumentation ? true, + hoogleWithPackages, + postBuild ? "", + ghcLibdir ? null, # only used by ghcjs, when resolving plugins }: # This argument is a function which selects a list of Haskell packages from any @@ -42,161 +47,176 @@ selectPackages: let inherit (haskellPackages) llvmPackages ghc; - packages = selectPackages haskellPackages - ++ lib.optional withHoogle (hoogleWithPackages selectPackages); - - isGhcjs = ghc.isGhcjs or false; - isHaLVM = ghc.isHaLVM or false; - ghcCommand' = if isGhcjs then "ghcjs" else "ghc"; - ghcCommand = "${ghc.targetPrefix}${ghcCommand'}"; - ghcCommandCaps= lib.toUpper ghcCommand'; - libDir = if isHaLVM then "$out/lib/HaLVM-${ghc.version}" - else "$out/lib/${ghc.targetPrefix}${ghc.haskellCompilerName}" - + lib.optionalString (ghc ? hadrian) "/lib"; + packages = + selectPackages haskellPackages + ++ lib.optional withHoogle (hoogleWithPackages selectPackages); + + isGhcjs = ghc.isGhcjs or false; + isHaLVM = ghc.isHaLVM or false; + ghcCommand' = if isGhcjs then "ghcjs" else "ghc"; + ghcCommand = "${ghc.targetPrefix}${ghcCommand'}"; + ghcCommandCaps = lib.toUpper ghcCommand'; + libDir = + if isHaLVM then + "$out/lib/HaLVM-${ghc.version}" + else + "$out/lib/${ghc.targetPrefix}${ghc.haskellCompilerName}" + + lib.optionalString (ghc ? hadrian) "/lib"; # Boot libraries for GHC are present in a separate directory. - bootLibDir = let arch = if stdenv.targetPlatform.isAarch64 - then "aarch64" - else "x86_64"; - platform = if stdenv.targetPlatform.isDarwin then "osx" else "linux"; - in "${ghc}/lib/${ghc.haskellCompilerName}/lib/${arch}-${platform}-${ghc.haskellCompilerName}"; - docDir = "$out/share/doc/ghc/html"; + bootLibDir = + let + arch = if stdenv.targetPlatform.isAarch64 then "aarch64" else "x86_64"; + platform = if stdenv.targetPlatform.isDarwin then "osx" else "linux"; + in + "${ghc}/lib/${ghc.haskellCompilerName}/lib/${arch}-${platform}-${ghc.haskellCompilerName}"; + docDir = "$out/share/doc/ghc/html"; packageCfgDir = "${libDir}/package.conf.d"; - paths = lib.concatLists ( - builtins.map - (pkg: [ pkg ] ++ lib.optionals installDocumentation [ (lib.getOutput "doc" pkg) ]) - (lib.filter (x: x ? isHaskellLibrary) (lib.closePropagation packages)) - ); - hasLibraries = lib.any (x: x.isHaskellLibrary) paths; + paths = lib.concatLists ( + builtins.map (pkg: [ pkg ] ++ lib.optionals installDocumentation [ (lib.getOutput "doc" pkg) ]) ( + lib.filter (x: x ? isHaskellLibrary) (lib.closePropagation packages) + ) + ); + hasLibraries = lib.any (x: x.isHaskellLibrary) paths; # CLang is needed on Darwin for -fllvm to work: # https://downloads.haskell.org/~ghc/latest/docs/html/users_guide/codegens.html#llvm-code-generator-fllvm - llvm = lib.makeBinPath - ([ llvmPackages.llvm ] - ++ lib.optional stdenv.targetPlatform.isDarwin llvmPackages.clang); + llvm = lib.makeBinPath ( + [ llvmPackages.llvm ] ++ lib.optional stdenv.targetPlatform.isDarwin llvmPackages.clang + ); in assert ghcLibdir != null -> (ghc.isGhcjs or false); -if paths == [] && !useLLVM then ghc else -symlinkJoin { - # this makes computing paths from the name attribute impossible; - # if such a feature is needed, the real compiler name should be saved - # as a dedicated drv attribute, like `compiler-name` - name = ghc.name + "-with-packages"; - paths = paths - ++ [ ghc ] - ++ lib.optionals installDocumentation [ (lib.getOutput "doc" ghc) ]; - nativeBuildInputs = [ makeWrapper ]; - postBuild = '' - # wrap compiler executables with correct env variables - - for prg in ${ghcCommand} ${ghcCommand}i ${ghcCommand}-${ghc.version} ${ghcCommand}i-${ghc.version}; do - if [[ -x "${ghc}/bin/$prg" ]]; then - rm -f $out/bin/$prg - makeWrapper ${ghc}/bin/$prg $out/bin/$prg \ - --add-flags '"-B$NIX_${ghcCommandCaps}_LIBDIR"' \ - --set "NIX_${ghcCommandCaps}" "$out/bin/${ghcCommand}" \ - --set "NIX_${ghcCommandCaps}PKG" "$out/bin/${ghcCommand}-pkg" \ - --set "NIX_${ghcCommandCaps}_DOCDIR" "${docDir}" \ - --set "NIX_${ghcCommandCaps}_LIBDIR" "${libDir}" \ - ${lib.optionalString (ghc.isGhcjs or false) - ''--set NODE_PATH "${ghc.socket-io}/lib/node_modules"'' - } \ - ${lib.optionalString useLLVM ''--prefix "PATH" ":" "${llvm}"''} - fi - done - - for prg in runghc runhaskell; do - if [[ -x "${ghc}/bin/$prg" ]]; then - rm -f $out/bin/$prg - makeWrapper ${ghc}/bin/$prg $out/bin/$prg \ - --add-flags "-f $out/bin/${ghcCommand}" \ - --set "NIX_${ghcCommandCaps}" "$out/bin/${ghcCommand}" \ - --set "NIX_${ghcCommandCaps}PKG" "$out/bin/${ghcCommand}-pkg" \ - --set "NIX_${ghcCommandCaps}_DOCDIR" "${docDir}" \ - --set "NIX_${ghcCommandCaps}_LIBDIR" "${libDir}" - fi - done - - for prg in ${ghcCommand}-pkg ${ghcCommand}-pkg-${ghc.version}; do - if [[ -x "${ghc}/bin/$prg" ]]; then - rm -f $out/bin/$prg - makeWrapper ${ghc}/bin/$prg $out/bin/$prg --add-flags "--global-package-db=${packageCfgDir}" - fi - done - - # haddock was referring to the base ghc, https://github.com/NixOS/nixpkgs/issues/36976 - if [[ -x "${ghc}/bin/haddock" ]]; then - rm -f $out/bin/haddock - makeWrapper ${ghc}/bin/haddock $out/bin/haddock \ - --add-flags '"-B$NIX_${ghcCommandCaps}_LIBDIR"' \ - --set "NIX_${ghcCommandCaps}_LIBDIR" "${libDir}" - fi - - '' + (lib.optionalString (stdenv.targetPlatform.isDarwin && !isGhcjs && !stdenv.targetPlatform.isiOS) '' - # Work around a linker limit in macOS Sierra (see generic-builder.nix): - local packageConfDir="${packageCfgDir}"; - local dynamicLinksDir="$out/lib/links"; - mkdir -p $dynamicLinksDir - # Clean up the old links that may have been (transitively) included by - # symlinkJoin: - rm -f $dynamicLinksDir/* - - # Boot libraries are located differently than other libraries since GHC 9.6, so handle them separately. - if [[ -x "${bootLibDir}" ]]; then - ln -s "${bootLibDir}"/*.dylib $dynamicLinksDir - fi - - for d in $(grep -Poz "dynamic-library-dirs:\s*\K .+\n" $packageConfDir/*|awk '{print $2}'|sort -u); do - ln -s $d/*.dylib $dynamicLinksDir - done - for f in $packageConfDir/*.conf; do - # Initially, $f is a symlink to a read-only file in one of the inputs - # (as a result of this symlinkJoin derivation). - # Replace it with a copy whose dynamic-library-dirs points to - # $dynamicLinksDir - cp $f $f-tmp - rm $f - sed "N;s,dynamic-library-dirs:\s*.*\n,dynamic-library-dirs: $dynamicLinksDir\n," $f-tmp > $f - rm $f-tmp - done - '') + '' - ${lib.optionalString hasLibraries '' - # GHC 8.10 changes. - # Instead of replacing package.cache[.lock] with the new file, - # ghc-pkg is now trying to open the file. These file are symlink - # to another nix derivation, so they are not writable. Removing - # them allow the correct behavior of ghc-pkg recache - # See: https://github.com/NixOS/nixpkgs/issues/79441 - rm ${packageCfgDir}/package.cache.lock - rm ${packageCfgDir}/package.cache - - $out/bin/${ghcCommand}-pkg recache - ''} - ${# ghcjs will read the ghc_libdir file when resolving plugins. - lib.optionalString (isGhcjs && ghcLibdir != null) '' - mkdir -p "${libDir}" - rm -f "${libDir}/ghc_libdir" - printf '%s' '${ghcLibdir}' > "${libDir}/ghc_libdir" - ''} - $out/bin/${ghcCommand}-pkg check - '' + postBuild; - preferLocalBuild = true; - passthru = { - inherit (ghc) version meta; - - # Inform users about backwards incompatibilities with <= 21.05 - override = _: throw '' - The ghc.withPackages wrapper itself can now be overridden, but no longer - the result of calling it (as before). Consequently overrides need to be - adjusted: Instead of - - (ghc.withPackages (p: [ p.my-package ])).override { withLLLVM = true; } - - use - - (ghc.withPackages.override { useLLVM = true; }) (p: [ p.my-package ]) - - Also note that withLLVM has been renamed to useLLVM for consistency with - the GHC Nix expressions.''; - }; -} +if paths == [ ] && !useLLVM then + ghc +else + symlinkJoin { + # this makes computing paths from the name attribute impossible; + # if such a feature is needed, the real compiler name should be saved + # as a dedicated drv attribute, like `compiler-name` + name = ghc.name + "-with-packages"; + paths = paths ++ [ ghc ] ++ lib.optionals installDocumentation [ (lib.getOutput "doc" ghc) ]; + nativeBuildInputs = [ makeWrapper ]; + postBuild = + '' + # wrap compiler executables with correct env variables + + for prg in ${ghcCommand} ${ghcCommand}i ${ghcCommand}-${ghc.version} ${ghcCommand}i-${ghc.version}; do + if [[ -x "${ghc}/bin/$prg" ]]; then + rm -f $out/bin/$prg + makeWrapper ${ghc}/bin/$prg $out/bin/$prg \ + --add-flags '"-B$NIX_${ghcCommandCaps}_LIBDIR"' \ + --set "NIX_${ghcCommandCaps}" "$out/bin/${ghcCommand}" \ + --set "NIX_${ghcCommandCaps}PKG" "$out/bin/${ghcCommand}-pkg" \ + --set "NIX_${ghcCommandCaps}_DOCDIR" "${docDir}" \ + --set "NIX_${ghcCommandCaps}_LIBDIR" "${libDir}" \ + ${ + lib.optionalString (ghc.isGhcjs or false) ''--set NODE_PATH "${ghc.socket-io}/lib/node_modules"'' + } \ + ${lib.optionalString useLLVM ''--prefix "PATH" ":" "${llvm}"''} + fi + done + + for prg in runghc runhaskell; do + if [[ -x "${ghc}/bin/$prg" ]]; then + rm -f $out/bin/$prg + makeWrapper ${ghc}/bin/$prg $out/bin/$prg \ + --add-flags "-f $out/bin/${ghcCommand}" \ + --set "NIX_${ghcCommandCaps}" "$out/bin/${ghcCommand}" \ + --set "NIX_${ghcCommandCaps}PKG" "$out/bin/${ghcCommand}-pkg" \ + --set "NIX_${ghcCommandCaps}_DOCDIR" "${docDir}" \ + --set "NIX_${ghcCommandCaps}_LIBDIR" "${libDir}" + fi + done + + for prg in ${ghcCommand}-pkg ${ghcCommand}-pkg-${ghc.version}; do + if [[ -x "${ghc}/bin/$prg" ]]; then + rm -f $out/bin/$prg + makeWrapper ${ghc}/bin/$prg $out/bin/$prg --add-flags "--global-package-db=${packageCfgDir}" + fi + done + + # haddock was referring to the base ghc, https://github.com/NixOS/nixpkgs/issues/36976 + if [[ -x "${ghc}/bin/haddock" ]]; then + rm -f $out/bin/haddock + makeWrapper ${ghc}/bin/haddock $out/bin/haddock \ + --add-flags '"-B$NIX_${ghcCommandCaps}_LIBDIR"' \ + --set "NIX_${ghcCommandCaps}_LIBDIR" "${libDir}" + fi + + '' + + (lib.optionalString (stdenv.targetPlatform.isDarwin && !isGhcjs && !stdenv.targetPlatform.isiOS) + '' + # Work around a linker limit in macOS Sierra (see generic-builder.nix): + local packageConfDir="${packageCfgDir}"; + local dynamicLinksDir="$out/lib/links"; + mkdir -p $dynamicLinksDir + # Clean up the old links that may have been (transitively) included by + # symlinkJoin: + rm -f $dynamicLinksDir/* + + # Boot libraries are located differently than other libraries since GHC 9.6, so handle them separately. + if [[ -x "${bootLibDir}" ]]; then + ln -s "${bootLibDir}"/*.dylib $dynamicLinksDir + fi + + for d in $(grep -Poz "dynamic-library-dirs:\s*\K .+\n" $packageConfDir/*|awk '{print $2}'|sort -u); do + ln -s $d/*.dylib $dynamicLinksDir + done + for f in $packageConfDir/*.conf; do + # Initially, $f is a symlink to a read-only file in one of the inputs + # (as a result of this symlinkJoin derivation). + # Replace it with a copy whose dynamic-library-dirs points to + # $dynamicLinksDir + cp $f $f-tmp + rm $f + sed "N;s,dynamic-library-dirs:\s*.*\n,dynamic-library-dirs: $dynamicLinksDir\n," $f-tmp > $f + rm $f-tmp + done + '' + ) + + '' + ${lib.optionalString hasLibraries '' + # GHC 8.10 changes. + # Instead of replacing package.cache[.lock] with the new file, + # ghc-pkg is now trying to open the file. These file are symlink + # to another nix derivation, so they are not writable. Removing + # them allow the correct behavior of ghc-pkg recache + # See: https://github.com/NixOS/nixpkgs/issues/79441 + rm ${packageCfgDir}/package.cache.lock + rm ${packageCfgDir}/package.cache + + $out/bin/${ghcCommand}-pkg recache + ''} + ${ + # ghcjs will read the ghc_libdir file when resolving plugins. + lib.optionalString (isGhcjs && ghcLibdir != null) '' + mkdir -p "${libDir}" + rm -f "${libDir}/ghc_libdir" + printf '%s' '${ghcLibdir}' > "${libDir}/ghc_libdir" + '' + } + $out/bin/${ghcCommand}-pkg check + '' + + postBuild; + preferLocalBuild = true; + passthru = { + inherit (ghc) version meta; + + # Inform users about backwards incompatibilities with <= 21.05 + override = + _: + throw '' + The ghc.withPackages wrapper itself can now be overridden, but no longer + the result of calling it (as before). Consequently overrides need to be + adjusted: Instead of + + (ghc.withPackages (p: [ p.my-package ])).override { withLLLVM = true; } + + use + + (ghc.withPackages.override { useLLVM = true; }) (p: [ p.my-package ]) + + Also note that withLLVM has been renamed to useLLVM for consistency with + the GHC Nix expressions.''; + }; + } diff --git a/pkgs/development/idris-modules/array.nix b/pkgs/development/idris-modules/array.nix index ef8159e9a87395..a35b9c5be36ad9 100644 --- a/pkgs/development/idris-modules/array.nix +++ b/pkgs/development/idris-modules/array.nix @@ -1,6 +1,7 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: build-idris-package { pname = "array"; diff --git a/pkgs/development/idris-modules/bi.nix b/pkgs/development/idris-modules/bi.nix index ec1f9a13bcddcb..9ea6004049d769 100644 --- a/pkgs/development/idris-modules/bi.nix +++ b/pkgs/development/idris-modules/bi.nix @@ -1,15 +1,19 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, pruviloj -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + pruviloj, + lib, }: -build-idris-package { +build-idris-package { pname = "bi"; version = "2018-06-25"; ipkgName = "Bi"; - idrisDeps = [ contrib pruviloj ]; + idrisDeps = [ + contrib + pruviloj + ]; src = fetchFromGitHub { owner = "sbp"; diff --git a/pkgs/development/idris-modules/bifunctors.nix b/pkgs/development/idris-modules/bifunctors.nix index 8e8ae9d195f34e..74ea6ece78bba2 100644 --- a/pkgs/development/idris-modules/bifunctors.nix +++ b/pkgs/development/idris-modules/bifunctors.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "bifunctors"; version = "2017-02-07"; diff --git a/pkgs/development/idris-modules/build-builtin-package.nix b/pkgs/development/idris-modules/build-builtin-package.nix index fe23728e084897..a5fd167e6a5206 100644 --- a/pkgs/development/idris-modules/build-builtin-package.nix +++ b/pkgs/development/idris-modules/build-builtin-package.nix @@ -1,7 +1,8 @@ # Build one of the packages that comes with idris # pname: The pname of the package # deps: The dependencies of the package -{ idris, build-idris-package }: pname: deps: +{ idris, build-idris-package }: +pname: deps: let inherit (builtins.parseDrvName idris.name) version; in diff --git a/pkgs/development/idris-modules/build-idris-package.nix b/pkgs/development/idris-modules/build-idris-package.nix index b21826eac38476..30a88b810fa486 100644 --- a/pkgs/development/idris-modules/build-idris-package.nix +++ b/pkgs/development/idris-modules/build-idris-package.nix @@ -1,79 +1,99 @@ # Build an idris package -{ stdenv, lib, gmp, prelude, base, with-packages, idris }: - { idrisDeps ? [] - , noPrelude ? false - , noBase ? false - , pname - , version - , ipkgName ? pname - , extraBuildInputs ? [] - , idrisBuildOptions ? [] - , idrisTestOptions ? [] - , idrisInstallOptions ? [] - , idrisDocOptions ? [] - , ... - }@attrs: +{ + stdenv, + lib, + gmp, + prelude, + base, + with-packages, + idris, +}: +{ + idrisDeps ? [ ], + noPrelude ? false, + noBase ? false, + pname, + version, + ipkgName ? pname, + extraBuildInputs ? [ ], + idrisBuildOptions ? [ ], + idrisTestOptions ? [ ], + idrisInstallOptions ? [ ], + idrisDocOptions ? [ ], + ... +}@attrs: let - allIdrisDeps = idrisDeps - ++ lib.optional (!noPrelude) prelude - ++ lib.optional (!noBase) base; + allIdrisDeps = idrisDeps ++ lib.optional (!noPrelude) prelude ++ lib.optional (!noBase) base; idris-with-packages = with-packages allIdrisDeps; - newAttrs = builtins.removeAttrs attrs [ - "idrisDeps" "noPrelude" "noBase" - "pname" "version" "ipkgName" "extraBuildInputs" - ] // { - meta = attrs.meta // { - platforms = attrs.meta.platforms or idris.meta.platforms; + newAttrs = + builtins.removeAttrs attrs [ + "idrisDeps" + "noPrelude" + "noBase" + "pname" + "version" + "ipkgName" + "extraBuildInputs" + ] + // { + meta = attrs.meta // { + platforms = attrs.meta.platforms or idris.meta.platforms; + }; }; - }; in -stdenv.mkDerivation ({ - pname = "idris-${pname}"; - inherit version; +stdenv.mkDerivation ( + { + pname = "idris-${pname}"; + inherit version; - buildInputs = [ idris-with-packages gmp ] ++ extraBuildInputs; - propagatedBuildInputs = allIdrisDeps; + buildInputs = [ + idris-with-packages + gmp + ] ++ extraBuildInputs; + propagatedBuildInputs = allIdrisDeps; - # Some packages use the style - # opts = -i ../../path/to/package - # rather than the declarative pkgs attribute so we have to rewrite the path. - patchPhase = '' - runHook prePatch - sed -i ${ipkgName}.ipkg -e "/^opts/ s|-i \\.\\./|-i ${idris-with-packages}/libs/|g" - runHook postPatch - ''; + # Some packages use the style + # opts = -i ../../path/to/package + # rather than the declarative pkgs attribute so we have to rewrite the path. + patchPhase = '' + runHook prePatch + sed -i ${ipkgName}.ipkg -e "/^opts/ s|-i \\.\\./|-i ${idris-with-packages}/libs/|g" + runHook postPatch + ''; - buildPhase = '' - runHook preBuild - idris --build ${ipkgName}.ipkg ${lib.escapeShellArgs idrisBuildOptions} - runHook postBuild - ''; + buildPhase = '' + runHook preBuild + idris --build ${ipkgName}.ipkg ${lib.escapeShellArgs idrisBuildOptions} + runHook postBuild + ''; - checkPhase = '' - runHook preCheck - if grep -q tests ${ipkgName}.ipkg; then - idris --testpkg ${ipkgName}.ipkg ${lib.escapeShellArgs idrisTestOptions} - fi - runHook postCheck - ''; + checkPhase = '' + runHook preCheck + if grep -q tests ${ipkgName}.ipkg; then + idris --testpkg ${ipkgName}.ipkg ${lib.escapeShellArgs idrisTestOptions} + fi + runHook postCheck + ''; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - idris --install ${ipkgName}.ipkg --ibcsubdir $out/libs ${lib.escapeShellArgs idrisInstallOptions} + idris --install ${ipkgName}.ipkg --ibcsubdir $out/libs ${lib.escapeShellArgs idrisInstallOptions} - IDRIS_DOC_PATH=$out/doc idris --installdoc ${ipkgName}.ipkg ${lib.escapeShellArgs idrisDocOptions} || true + IDRIS_DOC_PATH=$out/doc idris --installdoc ${ipkgName}.ipkg ${lib.escapeShellArgs idrisDocOptions} || true - # If the ipkg file defines an executable, install that - executable=$(grep -Po '^executable = \K.*' ${ipkgName}.ipkg || true) - # $executable intentionally not quoted because it must be quoted correctly - # in the ipkg file already - if [ ! -z "$executable" ] && [ -f $executable ]; then - mkdir -p $out/bin - mv $executable $out/bin/$executable - fi + # If the ipkg file defines an executable, install that + executable=$(grep -Po '^executable = \K.*' ${ipkgName}.ipkg || true) + # $executable intentionally not quoted because it must be quoted correctly + # in the ipkg file already + if [ ! -z "$executable" ] && [ -f $executable ]; then + mkdir -p $out/bin + mv $executable $out/bin/$executable + fi - runHook postInstall - ''; + runHook postInstall + ''; -} // newAttrs) + } + // newAttrs +) diff --git a/pkgs/development/idris-modules/bytes.nix b/pkgs/development/idris-modules/bytes.nix index 0fd9b05f88d468..b14ab358b0fff6 100644 --- a/pkgs/development/idris-modules/bytes.nix +++ b/pkgs/development/idris-modules/bytes.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "bytes"; version = "2018-02-10"; diff --git a/pkgs/development/idris-modules/canvas.nix b/pkgs/development/idris-modules/canvas.nix index 3c74879eab6ccb..aabce4535d2123 100644 --- a/pkgs/development/idris-modules/canvas.nix +++ b/pkgs/development/idris-modules/canvas.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "canvas"; version = "2017-11-09"; diff --git a/pkgs/development/idris-modules/categories.nix b/pkgs/development/idris-modules/categories.nix index 0c64218bcd82da..d26e7daebd98f5 100644 --- a/pkgs/development/idris-modules/categories.nix +++ b/pkgs/development/idris-modules/categories.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "categories"; version = "2018-07-02"; diff --git a/pkgs/development/idris-modules/coda.nix b/pkgs/development/idris-modules/coda.nix index d1529ceb994e4f..9fde026cee7c0d 100644 --- a/pkgs/development/idris-modules/coda.nix +++ b/pkgs/development/idris-modules/coda.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "coda"; version = "2018-01-25"; diff --git a/pkgs/development/idris-modules/comonad.nix b/pkgs/development/idris-modules/comonad.nix index d7bf499ea22d26..517f934a6d64ba 100644 --- a/pkgs/development/idris-modules/comonad.nix +++ b/pkgs/development/idris-modules/comonad.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "comonad"; version = "2018-02-26"; diff --git a/pkgs/development/idris-modules/composition.nix b/pkgs/development/idris-modules/composition.nix index 831a1f32655c0b..834e135a81e2ca 100644 --- a/pkgs/development/idris-modules/composition.nix +++ b/pkgs/development/idris-modules/composition.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, hezarfen -, lib +{ + build-idris-package, + fetchFromGitHub, + hezarfen, + lib, }: -build-idris-package { +build-idris-package { pname = "composition"; version = "2017-11-12"; diff --git a/pkgs/development/idris-modules/config.nix b/pkgs/development/idris-modules/config.nix index 53d423f728f010..9e22601f081e73 100644 --- a/pkgs/development/idris-modules/config.nix +++ b/pkgs/development/idris-modules/config.nix @@ -1,16 +1,22 @@ -{ build-idris-package -, fetchFromGitHub -, effects -, containers -, lightyear -, test -, lib +{ + build-idris-package, + fetchFromGitHub, + effects, + containers, + lightyear, + test, + lib, }: -build-idris-package { +build-idris-package { pname = "config"; version = "2017-11-06"; - idrisDeps = [ effects containers lightyear test ]; + idrisDeps = [ + effects + containers + lightyear + test + ]; src = fetchFromGitHub { owner = "benclifford"; diff --git a/pkgs/development/idris-modules/console.nix b/pkgs/development/idris-modules/console.nix index e8c41e200db1d8..c3cc91eedc9557 100644 --- a/pkgs/development/idris-modules/console.nix +++ b/pkgs/development/idris-modules/console.nix @@ -1,15 +1,20 @@ -{ build-idris-package -, fetchFromGitHub -, idrisscript -, hrtime -, webgl -, lib +{ + build-idris-package, + fetchFromGitHub, + idrisscript, + hrtime, + webgl, + lib, }: -build-idris-package { +build-idris-package { pname = "console"; version = "2017-04-20"; - idrisDeps = [ idrisscript hrtime webgl ]; + idrisDeps = [ + idrisscript + hrtime + webgl + ]; src = fetchFromGitHub { owner = "pierrebeaucamp"; diff --git a/pkgs/development/idris-modules/containers.nix b/pkgs/development/idris-modules/containers.nix index 2b3ee404373623..d0b016d3e249ab 100644 --- a/pkgs/development/idris-modules/containers.nix +++ b/pkgs/development/idris-modules/containers.nix @@ -1,14 +1,18 @@ -{ build-idris-package -, fetchFromGitHub -, effects -, test -, lib +{ + build-idris-package, + fetchFromGitHub, + effects, + test, + lib, }: -build-idris-package { +build-idris-package { pname = "containers"; version = "2017-09-10"; - idrisDeps = [ effects test ]; + idrisDeps = [ + effects + test + ]; src = fetchFromGitHub { owner = "jfdm"; diff --git a/pkgs/development/idris-modules/cube.nix b/pkgs/development/idris-modules/cube.nix index 09b426c961189e..23934471dcb2e6 100644 --- a/pkgs/development/idris-modules/cube.nix +++ b/pkgs/development/idris-modules/cube.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "cube"; version = "2017-07-05"; diff --git a/pkgs/development/idris-modules/default.nix b/pkgs/development/idris-modules/default.nix index 38b4385ee71928..7272318511d9e3 100644 --- a/pkgs/development/idris-modules/default.nix +++ b/pkgs/development/idris-modules/default.nix @@ -1,211 +1,234 @@ -{ pkgs, config, idris-no-deps, overrides ? (self: super: {}) }: let +{ + pkgs, + config, + idris-no-deps, + overrides ? (self: super: { }), +}: +let inherit (pkgs.lib) callPackageWith fix' extends; - /* Taken from haskell-modules/default.nix, should probably abstract this away */ - callPackageWithScope = scope: drv: args: (callPackageWith scope drv args) // { - overrideScope = f: callPackageWithScope (mkScope (fix' (extends f scope.__unfix__))) drv args; - }; + # Taken from haskell-modules/default.nix, should probably abstract this away + callPackageWithScope = + scope: drv: args: + (callPackageWith scope drv args) + // { + overrideScope = f: callPackageWithScope (mkScope (fix' (extends f scope.__unfix__))) drv args; + }; - mkScope = scope : pkgs // pkgs.xorg // pkgs.gnome2 // scope; + mkScope = scope: pkgs // pkgs.xorg // pkgs.gnome2 // scope; - idrisPackages = self: let - defaultScope = mkScope self; + idrisPackages = + self: + let + defaultScope = mkScope self; - callPackage = callPackageWithScope defaultScope; + callPackage = callPackageWithScope defaultScope; - builtins_ = pkgs.lib.mapAttrs self.build-builtin-package { - prelude = []; + builtins_ = pkgs.lib.mapAttrs self.build-builtin-package { + prelude = [ ]; - base = [ self.prelude ]; + base = [ self.prelude ]; - contrib = [ self.prelude self.base ]; + contrib = [ + self.prelude + self.base + ]; - effects = [ self.prelude self.base ]; + effects = [ + self.prelude + self.base + ]; - pruviloj = [ self.prelude self.base ]; - }; + pruviloj = [ + self.prelude + self.base + ]; + }; - in + in { - inherit idris-no-deps callPackage; + inherit idris-no-deps callPackage; - # Idris wrapper with specified compiler and library paths, used to build packages + # Idris wrapper with specified compiler and library paths, used to build packages - idris = pkgs.callPackage ./idris-wrapper.nix { - inherit idris-no-deps; - }; + idris = pkgs.callPackage ./idris-wrapper.nix { + inherit idris-no-deps; + }; - # Utilities for building packages + # Utilities for building packages - with-packages = callPackage ./with-packages.nix {} ; + with-packages = callPackage ./with-packages.nix { }; - build-builtin-package = callPackage ./build-builtin-package.nix {}; + build-builtin-package = callPackage ./build-builtin-package.nix { }; - build-idris-package = callPackage ./build-idris-package.nix {}; + build-idris-package = callPackage ./build-idris-package.nix { }; - # The set of libraries that comes with idris + # The set of libraries that comes with idris - builtins = pkgs.lib.mapAttrsToList (name: value: value) builtins_; + builtins = pkgs.lib.mapAttrsToList (name: value: value) builtins_; - # Libraries + # Libraries - array = callPackage ./array.nix {}; + array = callPackage ./array.nix { }; - bi = callPackage ./bi.nix {}; + bi = callPackage ./bi.nix { }; - bifunctors = callPackage ./bifunctors.nix {}; + bifunctors = callPackage ./bifunctors.nix { }; - bytes = callPackage ./bytes.nix {}; + bytes = callPackage ./bytes.nix { }; - canvas = callPackage ./canvas.nix {}; + canvas = callPackage ./canvas.nix { }; - categories = callPackage ./categories.nix {}; + categories = callPackage ./categories.nix { }; - coda = callPackage ./coda.nix {}; + coda = callPackage ./coda.nix { }; - config = callPackage ./config.nix {}; + config = callPackage ./config.nix { }; - comonad = callPackage ./comonad.nix {}; + comonad = callPackage ./comonad.nix { }; - composition = callPackage ./composition.nix {}; + composition = callPackage ./composition.nix { }; - console = callPackage ./console.nix {}; + console = callPackage ./console.nix { }; - containers = callPackage ./containers.nix {}; + containers = callPackage ./containers.nix { }; - cube = callPackage ./cube.nix {}; + cube = callPackage ./cube.nix { }; - derive = callPackage ./derive.nix {}; + derive = callPackage ./derive.nix { }; - descncrunch = callPackage ./descncrunch.nix {}; + descncrunch = callPackage ./descncrunch.nix { }; - dict = callPackage ./dict.nix {}; + dict = callPackage ./dict.nix { }; - dom = callPackage ./dom.nix {}; + dom = callPackage ./dom.nix { }; - electron = callPackage ./electron.nix {}; + electron = callPackage ./electron.nix { }; - eternal = callPackage ./eternal.nix {}; + eternal = callPackage ./eternal.nix { }; - farrp = callPackage ./farrp.nix {}; + farrp = callPackage ./farrp.nix { }; - free = callPackage ./free.nix {}; + free = callPackage ./free.nix { }; - fsm = callPackage ./fsm.nix {}; + fsm = callPackage ./fsm.nix { }; - glfw = callPackage ./glfw.nix {}; + glfw = callPackage ./glfw.nix { }; - graphviz = callPackage ./graphviz.nix {}; + graphviz = callPackage ./graphviz.nix { }; - hamt = callPackage ./hamt.nix {}; + hamt = callPackage ./hamt.nix { }; - html = callPackage ./html.nix {}; + html = callPackage ./html.nix { }; - hezarfen = callPackage ./hezarfen.nix {}; + hezarfen = callPackage ./hezarfen.nix { }; - hrtime = callPackage ./hrtime.nix {}; + hrtime = callPackage ./hrtime.nix { }; - http = callPackage ./http.nix {}; + http = callPackage ./http.nix { }; - http4idris = callPackage ./http4idris.nix {}; + http4idris = callPackage ./http4idris.nix { }; - iaia = callPackage ./iaia.nix {}; + iaia = callPackage ./iaia.nix { }; - idrishighlighter = callPackage ./idrishighlighter.nix {}; + idrishighlighter = callPackage ./idrishighlighter.nix { }; - idrisscript = callPackage ./idrisscript.nix {}; + idrisscript = callPackage ./idrisscript.nix { }; - ipkgparser = callPackage ./ipkgparser.nix {}; + ipkgparser = callPackage ./ipkgparser.nix { }; - jheiling-extras = callPackage ./jheiling-extras.nix {}; + jheiling-extras = callPackage ./jheiling-extras.nix { }; - jheiling-js = callPackage ./jheiling-js.nix {}; + jheiling-js = callPackage ./jheiling-js.nix { }; - js = callPackage ./js.nix {}; + js = callPackage ./js.nix { }; - lens = callPackage ./lens.nix {}; + lens = callPackage ./lens.nix { }; - lightyear = callPackage ./lightyear.nix {}; + lightyear = callPackage ./lightyear.nix { }; - logic = callPackage ./logic.nix {}; + logic = callPackage ./logic.nix { }; - mapping = callPackage ./mapping.nix {}; + mapping = callPackage ./mapping.nix { }; - mhd = callPackage ./mhd.nix {}; + mhd = callPackage ./mhd.nix { }; - pacman = callPackage ./pacman.nix {}; + pacman = callPackage ./pacman.nix { }; - patricia = callPackage ./patricia.nix {}; + patricia = callPackage ./patricia.nix { }; - permutations = callPackage ./permutations.nix {}; + permutations = callPackage ./permutations.nix { }; - pfds = callPackage ./pfds.nix {}; + pfds = callPackage ./pfds.nix { }; - pipes = callPackage ./pipes.nix {}; + pipes = callPackage ./pipes.nix { }; - posix = callPackage ./posix.nix {}; + posix = callPackage ./posix.nix { }; - quantities = callPackage ./quantities.nix {}; + quantities = callPackage ./quantities.nix { }; - rationals = callPackage ./rationals.nix {}; + rationals = callPackage ./rationals.nix { }; - recursion_schemes = callPackage ./recursion_schemes.nix {}; + recursion_schemes = callPackage ./recursion_schemes.nix { }; - refined = callPackage ./refined.nix {}; + refined = callPackage ./refined.nix { }; - sdl2 = callPackage ./sdl2.nix {}; + sdl2 = callPackage ./sdl2.nix { }; - semidirect = callPackage ./semidirect.nix {}; + semidirect = callPackage ./semidirect.nix { }; - setoids = callPackage ./setoids.nix {}; + setoids = callPackage ./setoids.nix { }; - smproc = callPackage ./smproc.nix {}; + smproc = callPackage ./smproc.nix { }; - snippets = callPackage ./snippets.nix {}; + snippets = callPackage ./snippets.nix { }; - software_foundations = callPackage ./software_foundations.nix {}; + software_foundations = callPackage ./software_foundations.nix { }; - specdris = callPackage ./specdris.nix {}; + specdris = callPackage ./specdris.nix { }; - tap = callPackage ./tap.nix {}; + tap = callPackage ./tap.nix { }; - test = callPackage ./test.nix {}; + test = callPackage ./test.nix { }; - tf-random = callPackage ./tfrandom.nix {}; + tf-random = callPackage ./tfrandom.nix { }; - tlhydra = callPackage ./tlhydra.nix {}; + tlhydra = callPackage ./tlhydra.nix { }; - tomladris = callPackage ./tomladris.nix {}; + tomladris = callPackage ./tomladris.nix { }; - tp = callPackage ./tp.nix {}; + tp = callPackage ./tp.nix { }; - tparsec = callPackage ./tparsec.nix {}; + tparsec = callPackage ./tparsec.nix { }; - transducers = callPackage ./transducers.nix {}; + transducers = callPackage ./transducers.nix { }; - trees = callPackage ./trees.nix {}; + trees = callPackage ./trees.nix { }; - union_type = callPackage ./union_type.nix {}; + union_type = callPackage ./union_type.nix { }; - vdom = callPackage ./vdom.nix {}; + vdom = callPackage ./vdom.nix { }; - vecspace = callPackage ./vecspace.nix {}; + vecspace = callPackage ./vecspace.nix { }; - webgl = callPackage ./webgl.nix {}; + webgl = callPackage ./webgl.nix { }; - wl-pprint = callPackage ./wl-pprint.nix {}; + wl-pprint = callPackage ./wl-pprint.nix { }; - wyvern = callPackage ./wyvern.nix {}; + wyvern = callPackage ./wyvern.nix { }; - xhr = callPackage ./xhr.nix {}; + xhr = callPackage ./xhr.nix { }; - yaml = callPackage ./yaml.nix {}; + yaml = callPackage ./yaml.nix { }; - yampa = callPackage ./yampa.nix {}; + yampa = callPackage ./yampa.nix { }; - } // builtins_ // pkgs.lib.optionalAttrs config.allowAliases { - # removed packages - protobuf = throw "idrisPackages.protobuf has been removed: abandoned by upstream"; # Added 2022-02-06 - sdl = throw "'idrisPackages.sdl' has been removed, as it was broken and unmaintained"; # added 2024-05-09 - }; -in fix' (extends overrides idrisPackages) + } + // builtins_ + // pkgs.lib.optionalAttrs config.allowAliases { + # removed packages + protobuf = throw "idrisPackages.protobuf has been removed: abandoned by upstream"; # Added 2022-02-06 + sdl = throw "'idrisPackages.sdl' has been removed, as it was broken and unmaintained"; # added 2024-05-09 + }; +in +fix' (extends overrides idrisPackages) diff --git a/pkgs/development/idris-modules/derive.nix b/pkgs/development/idris-modules/derive.nix index 1ceca662e8a337..7a36001be9ded4 100644 --- a/pkgs/development/idris-modules/derive.nix +++ b/pkgs/development/idris-modules/derive.nix @@ -1,14 +1,18 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, pruviloj -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + pruviloj, + lib, }: -build-idris-package { +build-idris-package { pname = "derive"; version = "2018-07-02"; - idrisDeps = [ contrib pruviloj ]; + idrisDeps = [ + contrib + pruviloj + ]; src = fetchFromGitHub { owner = "david-christiansen"; diff --git a/pkgs/development/idris-modules/descncrunch.nix b/pkgs/development/idris-modules/descncrunch.nix index 3c82e23ec7ecbc..6ec4c9a4d7087b 100644 --- a/pkgs/development/idris-modules/descncrunch.nix +++ b/pkgs/development/idris-modules/descncrunch.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, pruviloj -, lib +{ + build-idris-package, + fetchFromGitHub, + pruviloj, + lib, }: -build-idris-package { +build-idris-package { pname = "descncrunch"; version = "2017-11-15"; diff --git a/pkgs/development/idris-modules/dict.nix b/pkgs/development/idris-modules/dict.nix index 3aa15287bd8d71..f803f7f3fe3347 100644 --- a/pkgs/development/idris-modules/dict.nix +++ b/pkgs/development/idris-modules/dict.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lib, }: -build-idris-package { +build-idris-package { pname = "dict"; version = "2016-12-26"; diff --git a/pkgs/development/idris-modules/dom.nix b/pkgs/development/idris-modules/dom.nix index 2698cbab48472b..bcc28b5dba6a38 100644 --- a/pkgs/development/idris-modules/dom.nix +++ b/pkgs/development/idris-modules/dom.nix @@ -1,15 +1,20 @@ -{ build-idris-package -, fetchFromGitHub -, idrisscript -, html -, xhr -, lib +{ + build-idris-package, + fetchFromGitHub, + idrisscript, + html, + xhr, + lib, }: -build-idris-package { +build-idris-package { pname = "dom"; version = "2017-04-22"; - idrisDeps = [ idrisscript html xhr ]; + idrisDeps = [ + idrisscript + html + xhr + ]; src = fetchFromGitHub { owner = "pierrebeaucamp"; diff --git a/pkgs/development/idris-modules/electron.nix b/pkgs/development/idris-modules/electron.nix index 769b0b3fe8c05c..a94526d6b0d2a4 100644 --- a/pkgs/development/idris-modules/electron.nix +++ b/pkgs/development/idris-modules/electron.nix @@ -1,15 +1,20 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, jheiling-extras -, jheiling-js -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + jheiling-extras, + jheiling-js, + lib, }: -build-idris-package { +build-idris-package { pname = "electron"; version = "2016-03-07"; - idrisDeps = [ contrib jheiling-extras jheiling-js ]; + idrisDeps = [ + contrib + jheiling-extras + jheiling-js + ]; src = fetchFromGitHub { owner = "jheiling"; diff --git a/pkgs/development/idris-modules/eternal.nix b/pkgs/development/idris-modules/eternal.nix index 9ca38907fe743a..de52277821ce2c 100644 --- a/pkgs/development/idris-modules/eternal.nix +++ b/pkgs/development/idris-modules/eternal.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, effects -, lib +{ + build-idris-package, + fetchFromGitHub, + effects, + lib, }: -build-idris-package { +build-idris-package { pname = "eternal"; version = "2018-07-02"; diff --git a/pkgs/development/idris-modules/farrp.nix b/pkgs/development/idris-modules/farrp.nix index 4326aeeadb6a57..19e3edd3bb9001 100644 --- a/pkgs/development/idris-modules/farrp.nix +++ b/pkgs/development/idris-modules/farrp.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, effects -, lib +{ + build-idris-package, + fetchFromGitHub, + effects, + lib, }: -build-idris-package { +build-idris-package { pname = "farrp"; version = "2018-02-13"; diff --git a/pkgs/development/idris-modules/free.nix b/pkgs/development/idris-modules/free.nix index 557dc30ff96a56..38a71bdc116ec4 100644 --- a/pkgs/development/idris-modules/free.nix +++ b/pkgs/development/idris-modules/free.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "free"; version = "2017-07-03"; diff --git a/pkgs/development/idris-modules/fsm.nix b/pkgs/development/idris-modules/fsm.nix index 1342e90f29bb7a..047b2f3d513bf8 100644 --- a/pkgs/development/idris-modules/fsm.nix +++ b/pkgs/development/idris-modules/fsm.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "fsm"; version = "2017-04-16"; diff --git a/pkgs/development/idris-modules/glfw.nix b/pkgs/development/idris-modules/glfw.nix index f67b65bb71f7d7..359ba66f9f50a5 100644 --- a/pkgs/development/idris-modules/glfw.nix +++ b/pkgs/development/idris-modules/glfw.nix @@ -1,10 +1,11 @@ -{ build-idris-package -, fetchFromGitHub -, effects -, lib -, pkgs +{ + build-idris-package, + fetchFromGitHub, + effects, + lib, + pkgs, }: -build-idris-package { +build-idris-package { pname = "glfw"; version = "2016-12-05"; diff --git a/pkgs/development/idris-modules/graphviz.nix b/pkgs/development/idris-modules/graphviz.nix index 28ab24a2ada626..2df9e62e3e8439 100644 --- a/pkgs/development/idris-modules/graphviz.nix +++ b/pkgs/development/idris-modules/graphviz.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitLab -, lightyear -, lib +{ + build-idris-package, + fetchFromGitLab, + lightyear, + lib, }: -build-idris-package { +build-idris-package { pname = "graphviz"; version = "2017-01-16"; diff --git a/pkgs/development/idris-modules/hamt.nix b/pkgs/development/idris-modules/hamt.nix index 97a72e8c905923..4fb2db977a3188 100644 --- a/pkgs/development/idris-modules/hamt.nix +++ b/pkgs/development/idris-modules/hamt.nix @@ -1,14 +1,18 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, effects -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + effects, + lib, }: -build-idris-package { +build-idris-package { pname = "hamt"; version = "2016-11-15"; - idrisDeps = [ contrib effects ]; + idrisDeps = [ + contrib + effects + ]; src = fetchFromGitHub { owner = "bamboo"; diff --git a/pkgs/development/idris-modules/hezarfen.nix b/pkgs/development/idris-modules/hezarfen.nix index 124c16759081f2..66f61651a0c9a4 100644 --- a/pkgs/development/idris-modules/hezarfen.nix +++ b/pkgs/development/idris-modules/hezarfen.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "hezarfen"; version = "2018-02-03"; diff --git a/pkgs/development/idris-modules/hrtime.nix b/pkgs/development/idris-modules/hrtime.nix index 3d1c0f4abf9129..f373c613407427 100644 --- a/pkgs/development/idris-modules/hrtime.nix +++ b/pkgs/development/idris-modules/hrtime.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, idrisscript -, lib +{ + build-idris-package, + fetchFromGitHub, + idrisscript, + lib, }: -build-idris-package { +build-idris-package { pname = "hrtime"; version = "2017-04-16"; diff --git a/pkgs/development/idris-modules/html.nix b/pkgs/development/idris-modules/html.nix index 8eb2f7f12d7543..66c97ee4671e00 100644 --- a/pkgs/development/idris-modules/html.nix +++ b/pkgs/development/idris-modules/html.nix @@ -1,15 +1,20 @@ -{ build-idris-package -, fetchFromGitHub -, idrisscript -, hrtime -, webgl -, lib +{ + build-idris-package, + fetchFromGitHub, + idrisscript, + hrtime, + webgl, + lib, }: -build-idris-package { +build-idris-package { pname = "html"; version = "2017-04-23"; - idrisDeps = [ idrisscript hrtime webgl ]; + idrisDeps = [ + idrisscript + hrtime + webgl + ]; src = fetchFromGitHub { owner = "pierrebeaucamp"; diff --git a/pkgs/development/idris-modules/http.nix b/pkgs/development/idris-modules/http.nix index 09e4e555264c62..63e0dfa46c3cbd 100644 --- a/pkgs/development/idris-modules/http.nix +++ b/pkgs/development/idris-modules/http.nix @@ -1,15 +1,20 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lightyear -, bytes -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lightyear, + bytes, + lib, }: -build-idris-package { +build-idris-package { pname = "http"; version = "2018-02-25"; - idrisDeps = [ contrib lightyear bytes ]; + idrisDeps = [ + contrib + lightyear + bytes + ]; src = fetchFromGitHub { owner = "uwap"; diff --git a/pkgs/development/idris-modules/http4idris.nix b/pkgs/development/idris-modules/http4idris.nix index 3e235750a6bcf2..0d5f8c3c7c4770 100644 --- a/pkgs/development/idris-modules/http4idris.nix +++ b/pkgs/development/idris-modules/http4idris.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lib, }: -build-idris-package { +build-idris-package { pname = "http4idris"; version = "2018-01-16"; diff --git a/pkgs/development/idris-modules/iaia.nix b/pkgs/development/idris-modules/iaia.nix index 1c631280eac951..6b8777fe9f9dd4 100644 --- a/pkgs/development/idris-modules/iaia.nix +++ b/pkgs/development/idris-modules/iaia.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lib, }: -build-idris-package { +build-idris-package { pname = "iaia"; version = "2017-11-10"; diff --git a/pkgs/development/idris-modules/idris-wrapper.nix b/pkgs/development/idris-modules/idris-wrapper.nix index da20fa7a66067e..8aee1bf9fa6976 100644 --- a/pkgs/development/idris-modules/idris-wrapper.nix +++ b/pkgs/development/idris-modules/idris-wrapper.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, symlinkJoin, makeWrapper, idris-no-deps, gmp }: +{ + stdenv, + lib, + symlinkJoin, + makeWrapper, + idris-no-deps, + gmp, +}: symlinkJoin { inherit (idris-no-deps) name src meta; diff --git a/pkgs/development/idris-modules/idrishighlighter.nix b/pkgs/development/idris-modules/idrishighlighter.nix index 759ea354747fdf..febdda3005a433 100644 --- a/pkgs/development/idris-modules/idrishighlighter.nix +++ b/pkgs/development/idris-modules/idrishighlighter.nix @@ -1,15 +1,19 @@ -{ build-idris-package -, fetchFromGitHub -, effects -, lightyear -, lib +{ + build-idris-package, + fetchFromGitHub, + effects, + lightyear, + lib, }: -build-idris-package { +build-idris-package { pname = "idrishighlighter"; version = "2018-02-22"; ipkgName = "idris-code-highlighter"; - idrisDeps = [ effects lightyear ]; + idrisDeps = [ + effects + lightyear + ]; src = fetchFromGitHub { owner = "david-christiansen"; diff --git a/pkgs/development/idris-modules/idrisscript.nix b/pkgs/development/idris-modules/idrisscript.nix index 2a2693c623e084..dbd467743dd7d4 100644 --- a/pkgs/development/idris-modules/idrisscript.nix +++ b/pkgs/development/idris-modules/idrisscript.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "idrisscript"; version = "2017-07-01"; diff --git a/pkgs/development/idris-modules/ipkgparser.nix b/pkgs/development/idris-modules/ipkgparser.nix index 4cd966d8b8513c..f771898c9481f3 100644 --- a/pkgs/development/idris-modules/ipkgparser.nix +++ b/pkgs/development/idris-modules/ipkgparser.nix @@ -1,15 +1,20 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, effects -, lightyear -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + effects, + lightyear, + lib, }: -build-idris-package { +build-idris-package { pname = "ipkgparser"; version = "2017-11-14"; - idrisDeps = [ contrib effects lightyear ]; + idrisDeps = [ + contrib + effects + lightyear + ]; src = fetchFromGitHub { owner = "emptyflash"; diff --git a/pkgs/development/idris-modules/jheiling-extras.nix b/pkgs/development/idris-modules/jheiling-extras.nix index da84ea2680092b..8da4d38ffc1be3 100644 --- a/pkgs/development/idris-modules/jheiling-extras.nix +++ b/pkgs/development/idris-modules/jheiling-extras.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lib, }: -build-idris-package { +build-idris-package { pname = "extras"; version = "2018-03-06"; diff --git a/pkgs/development/idris-modules/jheiling-js.nix b/pkgs/development/idris-modules/jheiling-js.nix index 425acceb4e6ce4..27a7dfc876d880 100644 --- a/pkgs/development/idris-modules/jheiling-js.nix +++ b/pkgs/development/idris-modules/jheiling-js.nix @@ -1,15 +1,19 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, jheiling-extras -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + jheiling-extras, + lib, }: -build-idris-package { +build-idris-package { pname = "jheiling-js"; version = "2016-03-09"; ipkgName = "js"; - idrisDeps = [ contrib jheiling-extras ]; + idrisDeps = [ + contrib + jheiling-extras + ]; src = fetchFromGitHub { owner = "jheiling"; diff --git a/pkgs/development/idris-modules/js.nix b/pkgs/development/idris-modules/js.nix index 4b96ca1a486220..51ac7f4da9a76a 100644 --- a/pkgs/development/idris-modules/js.nix +++ b/pkgs/development/idris-modules/js.nix @@ -1,14 +1,18 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, pruviloj -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + pruviloj, + lib, }: -build-idris-package { +build-idris-package { pname = "js"; version = "2018-11-27"; - idrisDeps = [ contrib pruviloj ]; + idrisDeps = [ + contrib + pruviloj + ]; src = fetchFromGitHub { owner = "rbarreiro"; diff --git a/pkgs/development/idris-modules/lens.nix b/pkgs/development/idris-modules/lens.nix index c9a8c2aa257d33..50996e783575aa 100644 --- a/pkgs/development/idris-modules/lens.nix +++ b/pkgs/development/idris-modules/lens.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, bifunctors -, lib +{ + build-idris-package, + fetchFromGitHub, + bifunctors, + lib, }: -build-idris-package { +build-idris-package { pname = "lens"; version = "2017-09-25"; diff --git a/pkgs/development/idris-modules/lightyear.nix b/pkgs/development/idris-modules/lightyear.nix index e8f94a82d2f151..b021a1b73236a8 100644 --- a/pkgs/development/idris-modules/lightyear.nix +++ b/pkgs/development/idris-modules/lightyear.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, effects -, lib +{ + build-idris-package, + fetchFromGitHub, + effects, + lib, }: -build-idris-package { +build-idris-package { pname = "lightyear"; version = "2017-09-10"; @@ -20,6 +21,9 @@ build-idris-package { description = "Parser combinators for Idris"; homepage = "https://github.com/ziman/lightyear"; license = lib.licenses.bsd2; - maintainers = with lib.maintainers; [ siddharthist brainrape ]; + maintainers = with lib.maintainers; [ + siddharthist + brainrape + ]; }; } diff --git a/pkgs/development/idris-modules/logic.nix b/pkgs/development/idris-modules/logic.nix index f20d16e9a190f2..41fe075318618b 100644 --- a/pkgs/development/idris-modules/logic.nix +++ b/pkgs/development/idris-modules/logic.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, bifunctors -, lib +{ + build-idris-package, + fetchFromGitHub, + bifunctors, + lib, }: -build-idris-package { +build-idris-package { pname = "logic"; version = "2016-12-02"; diff --git a/pkgs/development/idris-modules/mapping.nix b/pkgs/development/idris-modules/mapping.nix index 63b7a01bce1406..a333166c308ca7 100644 --- a/pkgs/development/idris-modules/mapping.nix +++ b/pkgs/development/idris-modules/mapping.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "mapping"; version = "2018-02-27"; diff --git a/pkgs/development/idris-modules/mhd.nix b/pkgs/development/idris-modules/mhd.nix index d47e0b46db35f9..f41191b20da8c0 100644 --- a/pkgs/development/idris-modules/mhd.nix +++ b/pkgs/development/idris-modules/mhd.nix @@ -1,16 +1,20 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, effects -, libmicrohttpd -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + effects, + libmicrohttpd, + lib, }: -build-idris-package { +build-idris-package { pname = "mhd"; version = "2016-04-22"; ipkgName = "MHD"; - idrisDeps = [ contrib effects ]; + idrisDeps = [ + contrib + effects + ]; extraBuildInputs = [ libmicrohttpd ]; diff --git a/pkgs/development/idris-modules/pacman.nix b/pkgs/development/idris-modules/pacman.nix index dbc3c9ced72d12..ba13f0889d7d37 100644 --- a/pkgs/development/idris-modules/pacman.nix +++ b/pkgs/development/idris-modules/pacman.nix @@ -1,14 +1,18 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, sdl2 -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + sdl2, + lib, }: -build-idris-package { +build-idris-package { pname = "pacman"; version = "2017-11-10"; - idrisDeps = [ contrib sdl2 ]; + idrisDeps = [ + contrib + sdl2 + ]; src = fetchFromGitHub { owner = "jdublu10"; diff --git a/pkgs/development/idris-modules/patricia.nix b/pkgs/development/idris-modules/patricia.nix index 21907f15da8102..ccc3f3bc0c13a5 100644 --- a/pkgs/development/idris-modules/patricia.nix +++ b/pkgs/development/idris-modules/patricia.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, specdris -, lib +{ + build-idris-package, + fetchFromGitHub, + specdris, + lib, }: -build-idris-package { +build-idris-package { pname = "patricia"; version = "2017-10-27"; diff --git a/pkgs/development/idris-modules/permutations.nix b/pkgs/development/idris-modules/permutations.nix index 6f4e299d223b35..0f448aef8e4c50 100644 --- a/pkgs/development/idris-modules/permutations.nix +++ b/pkgs/development/idris-modules/permutations.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "permutations"; version = "2018-01-19"; diff --git a/pkgs/development/idris-modules/pfds.nix b/pkgs/development/idris-modules/pfds.nix index db3004a72be019..c5711d53388629 100644 --- a/pkgs/development/idris-modules/pfds.nix +++ b/pkgs/development/idris-modules/pfds.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lib, }: -build-idris-package { +build-idris-package { pname = "pfds"; version = "2017-09-25"; diff --git a/pkgs/development/idris-modules/pipes.nix b/pkgs/development/idris-modules/pipes.nix index 1402a2facee17e..e99d81bc6f6755 100644 --- a/pkgs/development/idris-modules/pipes.nix +++ b/pkgs/development/idris-modules/pipes.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "pipes"; version = "2017-12-02"; diff --git a/pkgs/development/idris-modules/posix.nix b/pkgs/development/idris-modules/posix.nix index cc34c9007272f6..840f50ad1451b6 100644 --- a/pkgs/development/idris-modules/posix.nix +++ b/pkgs/development/idris-modules/posix.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "posix"; version = "2017-11-18"; diff --git a/pkgs/development/idris-modules/quantities.nix b/pkgs/development/idris-modules/quantities.nix index 76242c5d2299d0..e4b2fa88449d87 100644 --- a/pkgs/development/idris-modules/quantities.nix +++ b/pkgs/development/idris-modules/quantities.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "quantities"; version = "2018-04-17"; diff --git a/pkgs/development/idris-modules/rationals.nix b/pkgs/development/idris-modules/rationals.nix index a220287bdbb6d5..8865a5e5c97ccc 100644 --- a/pkgs/development/idris-modules/rationals.nix +++ b/pkgs/development/idris-modules/rationals.nix @@ -1,7 +1,8 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lib, }: build-idris-package { pname = "rationals"; diff --git a/pkgs/development/idris-modules/recursion_schemes.nix b/pkgs/development/idris-modules/recursion_schemes.nix index 3e9510563eee9c..9fee3953018eec 100644 --- a/pkgs/development/idris-modules/recursion_schemes.nix +++ b/pkgs/development/idris-modules/recursion_schemes.nix @@ -1,17 +1,24 @@ -{ build-idris-package -, fetchFromGitHub -, free -, composition -, comonad -, bifunctors -, hezarfen -, lib +{ + build-idris-package, + fetchFromGitHub, + free, + composition, + comonad, + bifunctors, + hezarfen, + lib, }: -build-idris-package { +build-idris-package { pname = "recursion_schemes"; version = "2018-01-19"; - idrisDeps = [ free composition comonad bifunctors hezarfen ]; + idrisDeps = [ + free + composition + comonad + bifunctors + hezarfen + ]; src = fetchFromGitHub { owner = "vmchale"; diff --git a/pkgs/development/idris-modules/refined.nix b/pkgs/development/idris-modules/refined.nix index c841f633b41fe4..24f8a8c4899d62 100644 --- a/pkgs/development/idris-modules/refined.nix +++ b/pkgs/development/idris-modules/refined.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "refined"; version = "2017-12-28"; diff --git a/pkgs/development/idris-modules/sdl2.nix b/pkgs/development/idris-modules/sdl2.nix index 36eb7395dde1aa..f1170c1032374e 100644 --- a/pkgs/development/idris-modules/sdl2.nix +++ b/pkgs/development/idris-modules/sdl2.nix @@ -1,10 +1,11 @@ -{ build-idris-package -, fetchFromGitHub -, effects -, lib -, pkg-config -, SDL2 -, SDL2_gfx +{ + build-idris-package, + fetchFromGitHub, + effects, + lib, + pkg-config, + SDL2, + SDL2_gfx, }: build-idris-package rec { pname = "sdl2"; diff --git a/pkgs/development/idris-modules/semidirect.nix b/pkgs/development/idris-modules/semidirect.nix index e3ca18fd2a267d..3155aa5d791eda 100644 --- a/pkgs/development/idris-modules/semidirect.nix +++ b/pkgs/development/idris-modules/semidirect.nix @@ -1,14 +1,18 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, patricia -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + patricia, + lib, }: -build-idris-package { +build-idris-package { pname = "semidirect"; version = "2018-07-02"; - idrisDeps = [ contrib patricia ]; + idrisDeps = [ + contrib + patricia + ]; src = fetchFromGitHub { owner = "clayrat"; diff --git a/pkgs/development/idris-modules/setoids.nix b/pkgs/development/idris-modules/setoids.nix index 49e7bc5e8a0e36..f585f0d5b141ac 100644 --- a/pkgs/development/idris-modules/setoids.nix +++ b/pkgs/development/idris-modules/setoids.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lib, }: -build-idris-package { +build-idris-package { pname = "setoids"; version = "2018-06-18"; diff --git a/pkgs/development/idris-modules/smproc.nix b/pkgs/development/idris-modules/smproc.nix index b3780c9af3b8e6..28ab452d12cfaa 100644 --- a/pkgs/development/idris-modules/smproc.nix +++ b/pkgs/development/idris-modules/smproc.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lib, }: -build-idris-package { +build-idris-package { pname = "smproc"; version = "2018-02-08"; diff --git a/pkgs/development/idris-modules/snippets.nix b/pkgs/development/idris-modules/snippets.nix index fa4f3226dcca4d..e3b6ced720395d 100644 --- a/pkgs/development/idris-modules/snippets.nix +++ b/pkgs/development/idris-modules/snippets.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lib, }: -build-idris-package { +build-idris-package { pname = "snippets"; version = "2018-03-17"; diff --git a/pkgs/development/idris-modules/software_foundations.nix b/pkgs/development/idris-modules/software_foundations.nix index cbbf959576f369..e1035148e75186 100644 --- a/pkgs/development/idris-modules/software_foundations.nix +++ b/pkgs/development/idris-modules/software_foundations.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, pruviloj -, lib +{ + build-idris-package, + fetchFromGitHub, + pruviloj, + lib, }: -build-idris-package { +build-idris-package { pname = "software_foundations"; version = "2017-11-04"; diff --git a/pkgs/development/idris-modules/specdris.nix b/pkgs/development/idris-modules/specdris.nix index ec692951ab7552..513eb89dbdad13 100644 --- a/pkgs/development/idris-modules/specdris.nix +++ b/pkgs/development/idris-modules/specdris.nix @@ -1,7 +1,8 @@ -{ build-idris-package -, fetchFromGitHub -, effects -, lib +{ + build-idris-package, + fetchFromGitHub, + effects, + lib, }: build-idris-package { pname = "specdris"; diff --git a/pkgs/development/idris-modules/tap.nix b/pkgs/development/idris-modules/tap.nix index 24aa3282f31982..69428159d76713 100644 --- a/pkgs/development/idris-modules/tap.nix +++ b/pkgs/development/idris-modules/tap.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lib, }: -build-idris-package { +build-idris-package { pname = "tap"; version = "2017-04-08"; diff --git a/pkgs/development/idris-modules/test.nix b/pkgs/development/idris-modules/test.nix index 9c14422cc8d287..efe069a958ed36 100644 --- a/pkgs/development/idris-modules/test.nix +++ b/pkgs/development/idris-modules/test.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, effects -, lib +{ + build-idris-package, + fetchFromGitHub, + effects, + lib, }: -build-idris-package { +build-idris-package { pname = "test"; version = "2017-03-30"; diff --git a/pkgs/development/idris-modules/tfrandom.nix b/pkgs/development/idris-modules/tfrandom.nix index b07f5253005ee1..bca0a7aa2b8565 100644 --- a/pkgs/development/idris-modules/tfrandom.nix +++ b/pkgs/development/idris-modules/tfrandom.nix @@ -1,9 +1,10 @@ -{ lib -, build-idris-package -, fetchFromGitHub +{ + lib, + build-idris-package, + fetchFromGitHub, }: -build-idris-package { +build-idris-package { pname = "tf-random"; version = "2020-01-15"; diff --git a/pkgs/development/idris-modules/tlhydra.nix b/pkgs/development/idris-modules/tlhydra.nix index 3b33367c88904d..c287a48db85bb4 100644 --- a/pkgs/development/idris-modules/tlhydra.nix +++ b/pkgs/development/idris-modules/tlhydra.nix @@ -1,15 +1,20 @@ -{ build-idris-package -, fetchFromGitHub -, effects -, contrib -, lightyear -, lib +{ + build-idris-package, + fetchFromGitHub, + effects, + contrib, + lightyear, + lib, }: -build-idris-package { +build-idris-package { pname = "tlhydra"; version = "2017-13-26"; - idrisDeps = [ effects contrib lightyear ]; + idrisDeps = [ + effects + contrib + lightyear + ]; src = fetchFromGitHub { owner = "Termina1"; diff --git a/pkgs/development/idris-modules/tomladris.nix b/pkgs/development/idris-modules/tomladris.nix index 8a0e7847f50778..1d754988a1ecc9 100644 --- a/pkgs/development/idris-modules/tomladris.nix +++ b/pkgs/development/idris-modules/tomladris.nix @@ -1,14 +1,18 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lightyear -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lightyear, + lib, }: -build-idris-package { +build-idris-package { pname = "tomladris"; version = "2017-11-14"; - idrisDeps = [ lightyear contrib ]; + idrisDeps = [ + lightyear + contrib + ]; src = fetchFromGitHub { owner = "emptyflash"; @@ -21,6 +25,9 @@ build-idris-package { description = "TOML parser for Idris"; homepage = "https://github.com/emptyflash/tomladris"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ siddharthist brainrape ]; + maintainers = with lib.maintainers; [ + siddharthist + brainrape + ]; }; } diff --git a/pkgs/development/idris-modules/tp.nix b/pkgs/development/idris-modules/tp.nix index 0aedc3f4859664..17352a1bc9cbfa 100644 --- a/pkgs/development/idris-modules/tp.nix +++ b/pkgs/development/idris-modules/tp.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "tp"; version = "2017-08-15"; diff --git a/pkgs/development/idris-modules/tparsec.nix b/pkgs/development/idris-modules/tparsec.nix index ddf24f7c9d9fc7..5009f1a8de20f8 100644 --- a/pkgs/development/idris-modules/tparsec.nix +++ b/pkgs/development/idris-modules/tparsec.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lib, }: -build-idris-package { +build-idris-package { pname = "tparsec"; version = "2020-02-11"; diff --git a/pkgs/development/idris-modules/transducers.nix b/pkgs/development/idris-modules/transducers.nix index 455e5c72a64421..06afdc6dc60efa 100644 --- a/pkgs/development/idris-modules/transducers.nix +++ b/pkgs/development/idris-modules/transducers.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "transducers"; version = "2017-07-28"; diff --git a/pkgs/development/idris-modules/trees.nix b/pkgs/development/idris-modules/trees.nix index 5c6e69471c7899..afb2d510a30117 100644 --- a/pkgs/development/idris-modules/trees.nix +++ b/pkgs/development/idris-modules/trees.nix @@ -1,14 +1,18 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, bi -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + bi, + lib, }: -build-idris-package { +build-idris-package { pname = "trees"; version = "2018-03-19"; - idrisDeps = [ contrib bi ]; + idrisDeps = [ + contrib + bi + ]; src = fetchFromGitHub { owner = "clayrat"; diff --git a/pkgs/development/idris-modules/union_type.nix b/pkgs/development/idris-modules/union_type.nix index 99f160a72d8669..29aa772f094ccf 100644 --- a/pkgs/development/idris-modules/union_type.nix +++ b/pkgs/development/idris-modules/union_type.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "union_type"; version = "2018-01-30"; diff --git a/pkgs/development/idris-modules/vdom.nix b/pkgs/development/idris-modules/vdom.nix index 9e3f151ee89155..da1fb7b9443435 100644 --- a/pkgs/development/idris-modules/vdom.nix +++ b/pkgs/development/idris-modules/vdom.nix @@ -1,8 +1,9 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: -build-idris-package { +build-idris-package { pname = "vdom"; version = "0.6.0"; diff --git a/pkgs/development/idris-modules/vecspace.nix b/pkgs/development/idris-modules/vecspace.nix index dea3c9b18dd035..5eb86f536ff9a9 100644 --- a/pkgs/development/idris-modules/vecspace.nix +++ b/pkgs/development/idris-modules/vecspace.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lib, }: -build-idris-package { +build-idris-package { pname = "vecspace"; version = "2018-01-12"; diff --git a/pkgs/development/idris-modules/webgl.nix b/pkgs/development/idris-modules/webgl.nix index 849cad2590c110..39bb9342847a3b 100644 --- a/pkgs/development/idris-modules/webgl.nix +++ b/pkgs/development/idris-modules/webgl.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, idrisscript -, lib +{ + build-idris-package, + fetchFromGitHub, + idrisscript, + lib, }: -build-idris-package { +build-idris-package { pname = "webgl"; version = "2017-05-08"; diff --git a/pkgs/development/idris-modules/with-packages.nix b/pkgs/development/idris-modules/with-packages.nix index 55bfd8c157505b..4dd4d4a836c2f4 100644 --- a/pkgs/development/idris-modules/with-packages.nix +++ b/pkgs/development/idris-modules/with-packages.nix @@ -1,14 +1,21 @@ # Build a version of idris with a set of packages visible # packages: The packages visible to idris -{ lib, idris, symlinkJoin, makeWrapper }: packages: +{ + lib, + idris, + symlinkJoin, + makeWrapper, +}: +packages: -let paths = lib.closePropagation packages; +let + paths = lib.closePropagation packages; in lib.appendToName "with-packages" (symlinkJoin { inherit (idris) name; - paths = paths ++ [idris] ; + paths = paths ++ [ idris ]; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/development/idris-modules/wl-pprint.nix b/pkgs/development/idris-modules/wl-pprint.nix index a6c7b78f5527d2..f39c86d0219796 100644 --- a/pkgs/development/idris-modules/wl-pprint.nix +++ b/pkgs/development/idris-modules/wl-pprint.nix @@ -1,6 +1,7 @@ -{ build-idris-package -, fetchFromGitHub -, lib +{ + build-idris-package, + fetchFromGitHub, + lib, }: build-idris-package { pname = "wl-pprint"; diff --git a/pkgs/development/idris-modules/wyvern.nix b/pkgs/development/idris-modules/wyvern.nix index 3a8742d9fe5d1c..32c6b0331b7655 100644 --- a/pkgs/development/idris-modules/wyvern.nix +++ b/pkgs/development/idris-modules/wyvern.nix @@ -1,14 +1,18 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, effects -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + effects, + lib, }: -build-idris-package { +build-idris-package { pname = "wyvern"; version = "2017-06-26"; - idrisDeps = [ contrib effects ]; + idrisDeps = [ + contrib + effects + ]; src = fetchFromGitHub { owner = "ericqweinstein"; diff --git a/pkgs/development/idris-modules/xhr.nix b/pkgs/development/idris-modules/xhr.nix index e8dc37d439898e..bd43bc7adbb034 100644 --- a/pkgs/development/idris-modules/xhr.nix +++ b/pkgs/development/idris-modules/xhr.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, idrisscript -, lib +{ + build-idris-package, + fetchFromGitHub, + idrisscript, + lib, }: -build-idris-package { +build-idris-package { pname = "xhr"; version = "2017-04-22"; diff --git a/pkgs/development/idris-modules/yaml.nix b/pkgs/development/idris-modules/yaml.nix index 2c8b8087576e08..eb4aa037de617e 100644 --- a/pkgs/development/idris-modules/yaml.nix +++ b/pkgs/development/idris-modules/yaml.nix @@ -1,15 +1,19 @@ -{ build-idris-package -, fetchFromGitHub -, contrib -, lightyear -, lib +{ + build-idris-package, + fetchFromGitHub, + contrib, + lightyear, + lib, }: -build-idris-package { +build-idris-package { pname = "yaml"; version = "2018-01-25"; ipkgName = "Yaml"; - idrisDeps = [ contrib lightyear ]; + idrisDeps = [ + contrib + lightyear + ]; src = fetchFromGitHub { owner = "Heather"; diff --git a/pkgs/development/idris-modules/yampa.nix b/pkgs/development/idris-modules/yampa.nix index ae790aa4bdaa30..135a9b3bc78093 100644 --- a/pkgs/development/idris-modules/yampa.nix +++ b/pkgs/development/idris-modules/yampa.nix @@ -1,9 +1,10 @@ -{ build-idris-package -, fetchFromGitHub -, bifunctors -, lib +{ + build-idris-package, + fetchFromGitHub, + bifunctors, + lib, }: -build-idris-package { +build-idris-package { pname = "yampa"; version = "2016-07-05"; diff --git a/pkgs/development/interpreters/acl2/default.nix b/pkgs/development/interpreters/acl2/default.nix index e3c17855e65d38..6be3b9a865c58e 100644 --- a/pkgs/development/interpreters/acl2/default.nix +++ b/pkgs/development/interpreters/acl2/default.nix @@ -1,8 +1,25 @@ -{ lib, stdenv, callPackage, fetchFromGitHub, fetchpatch, runCommandLocal, makeWrapper, substituteAll -, sbcl, bash, which, perl, hostname -, openssl, glucose, minisat, abc-verifier, z3, python3 -, certifyBooks ? true -} @ args: +{ + lib, + stdenv, + callPackage, + fetchFromGitHub, + fetchpatch, + runCommandLocal, + makeWrapper, + substituteAll, + sbcl, + bash, + which, + perl, + hostname, + openssl, + glucose, + minisat, + abc-verifier, + z3, + python3, + certifyBooks ? true, +}@args: let # Disable immobile space so we don't run out of memory on large books, and @@ -15,7 +32,8 @@ let --add-flags "--dynamic-space-size 2000" ''; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "acl2"; version = "8.5"; @@ -55,29 +73,39 @@ in stdenv.mkDerivation rec { nativeBuildInputs = lib.optional certifyBooks makeWrapper; - buildInputs = [ - # ACL2 itself only needs a Common Lisp compiler/interpreter: - sbcl - ] ++ lib.optionals certifyBooks [ - # To build community books, we need Perl and a couple of utilities: - which perl hostname - # Some of the books require one or more of these external tools: - glucose minisat abc-verifier libipasir - z3 (python3.withPackages (ps: [ ps.z3-solver ])) - ]; + buildInputs = + [ + # ACL2 itself only needs a Common Lisp compiler/interpreter: + sbcl + ] + ++ lib.optionals certifyBooks [ + # To build community books, we need Perl and a couple of utilities: + which + perl + hostname + # Some of the books require one or more of these external tools: + glucose + minisat + abc-verifier + libipasir + z3 + (python3.withPackages (ps: [ ps.z3-solver ])) + ]; # NOTE: Parallel building can be memory-intensive depending on the number of # concurrent jobs. For example, this build has been seen to use >120GB of # RAM on an 85 core machine. enableParallelBuilding = true; - preConfigure = '' - # When certifying books, ACL2 doesn't like $HOME not existing. - export HOME=$(pwd)/fake-home - '' + lib.optionalString certifyBooks '' - # Some books also care about $USER being nonempty. - export USER=nobody - ''; + preConfigure = + '' + # When certifying books, ACL2 doesn't like $HOME not existing. + export HOME=$(pwd)/fake-home + '' + + lib.optionalString certifyBooks '' + # Some books also care about $USER being nonempty. + export USER=nobody + ''; postConfigure = '' # ACL2 and its books need to be built in place in the out directory because @@ -90,18 +118,23 @@ in stdenv.mkDerivation rec { ''; preBuild = "mkdir -p $HOME"; - makeFlags = [ "LISP=${sbcl}/bin/sbcl" "ACL2_MAKE_LOG=NONE" ]; + makeFlags = [ + "LISP=${sbcl}/bin/sbcl" + "ACL2_MAKE_LOG=NONE" + ]; doCheck = true; checkTarget = "mini-proveall"; - installPhase = '' - mkdir -p $out/bin - ln -s $out/share/${pname}/saved_acl2 $out/bin/${pname} - '' + lib.optionalString certifyBooks '' - ln -s $out/share/${pname}/books/build/cert.pl $out/bin/${pname}-cert - ln -s $out/share/${pname}/books/build/clean.pl $out/bin/${pname}-clean - ''; + installPhase = + '' + mkdir -p $out/bin + ln -s $out/share/${pname}/saved_acl2 $out/bin/${pname} + '' + + lib.optionalString certifyBooks '' + ln -s $out/share/${pname}/books/build/cert.pl $out/bin/${pname}-cert + ln -s $out/share/${pname}/books/build/clean.pl $out/bin/${pname}-clean + ''; preDistPhases = [ (if certifyBooks then "certifyBooksPhase" else "removeBooksPhase") ]; @@ -127,36 +160,54 @@ in stdenv.mkDerivation rec { meta = with lib; { description = "Interpreter and prover for a Lisp dialect"; mainProgram = "acl2"; - longDescription = '' - ACL2 is a logic and programming language in which you can model computer - systems, together with a tool to help you prove properties of those - models. "ACL2" denotes "A Computational Logic for Applicative Common - Lisp". - - ACL2 is part of the Boyer-Moore family of provers, for which its authors - have received the 2005 ACM Software System Award. - - This package installs the main ACL2 executable ${pname}, as well as the - build tools cert.pl and clean.pl, renamed to ${pname}-cert and - ${pname}-clean. - - '' + (if certifyBooks then '' - The community books are also included and certified with the `make - everything` target. - '' else '' - The community books are not included in this package. - ''); + longDescription = + '' + ACL2 is a logic and programming language in which you can model computer + systems, together with a tool to help you prove properties of those + models. "ACL2" denotes "A Computational Logic for Applicative Common + Lisp". + + ACL2 is part of the Boyer-Moore family of provers, for which its authors + have received the 2005 ACM Software System Award. + + This package installs the main ACL2 executable ${pname}, as well as the + build tools cert.pl and clean.pl, renamed to ${pname}-cert and + ${pname}-clean. + + '' + + ( + if certifyBooks then + '' + The community books are also included and certified with the `make + everything` target. + '' + else + '' + The community books are not included in this package. + '' + ); homepage = "https://www.cs.utexas.edu/users/moore/acl2/"; downloadPage = "https://github.com/acl2-devel/acl2-devel/releases"; - license = with licenses; [ - # ACL2 itself is bsd3 - bsd3 - ] ++ optionals certifyBooks [ - # The community books are mostly bsd3 or mit but with a few - # other things thrown in. - mit gpl2 llgpl21 cc0 publicDomain unfreeRedistributable + license = + with licenses; + [ + # ACL2 itself is bsd3 + bsd3 + ] + ++ optionals certifyBooks [ + # The community books are mostly bsd3 or mit but with a few + # other things thrown in. + mit + gpl2 + llgpl21 + cc0 + publicDomain + unfreeRedistributable + ]; + maintainers = with maintainers; [ + kini + raskin ]; - maintainers = with maintainers; [ kini raskin ]; platforms = platforms.all; broken = stdenv.hostPlatform.isDarwin; }; diff --git a/pkgs/development/interpreters/acl2/libipasirglucose4/default.nix b/pkgs/development/interpreters/acl2/libipasirglucose4/default.nix index e59d2ed7c176a3..a2a4b159d1d9c5 100644 --- a/pkgs/development/interpreters/acl2/libipasirglucose4/default.nix +++ b/pkgs/development/interpreters/acl2/libipasirglucose4/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, zlib, unzip }: +{ + lib, + stdenv, + fetchurl, + zlib, + unzip, +}: stdenv.mkDerivation rec { pname = "libipasirglucose4"; diff --git a/pkgs/development/interpreters/asmrepl/default.nix b/pkgs/development/interpreters/asmrepl/default.nix index 1c9ea6338f65bd..f9c7010444812c 100644 --- a/pkgs/development/interpreters/asmrepl/default.nix +++ b/pkgs/development/interpreters/asmrepl/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "asmrepl"; diff --git a/pkgs/development/interpreters/asmrepl/gemset.nix b/pkgs/development/interpreters/asmrepl/gemset.nix index a7af8d50c68591..f3455e51502349 100644 --- a/pkgs/development/interpreters/asmrepl/gemset.nix +++ b/pkgs/development/interpreters/asmrepl/gemset.nix @@ -1,20 +1,20 @@ { asmrepl = { - dependencies = ["fisk"]; - groups = ["default"]; - platforms = []; + dependencies = [ "fisk" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10d0zvkhk3ja48vvx28hfsqfrzfl66vdpmk3gcgb5viy174c72v6"; type = "gem"; }; version = "1.0.3"; }; fisk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1mq2a7hjs9xfg514ci0xw90c33rzq1y58ywpnmhp7w767ll6wldd"; type = "gem"; }; diff --git a/pkgs/development/interpreters/babashka/clojure-tools.nix b/pkgs/development/interpreters/babashka/clojure-tools.nix index 858c3eb11c2111..916748365ce592 100644 --- a/pkgs/development/interpreters/babashka/clojure-tools.nix +++ b/pkgs/development/interpreters/babashka/clojure-tools.nix @@ -1,8 +1,9 @@ # This file tracks the Clojure tools version required by babashka. # See https://github.com/borkdude/deps.clj#deps_clj_tools_version for background. # The `updateScript` provided in default.nix takes care of keeping it in sync, as well. -{ clojure -, fetchurl +{ + clojure, + fetchurl, }: clojure.overrideAttrs (previousAttrs: { pname = "babashka-clojure-tools"; diff --git a/pkgs/development/interpreters/babashka/wrapped.nix b/pkgs/development/interpreters/babashka/wrapped.nix index 04be9bfd477af6..cfdfc0910b6b7d 100644 --- a/pkgs/development/interpreters/babashka/wrapped.nix +++ b/pkgs/development/interpreters/babashka/wrapped.nix @@ -1,12 +1,13 @@ -{ stdenvNoCC -, lib -, babashka-unwrapped -, callPackage -, makeWrapper -, installShellFiles -, rlwrap -, clojureToolsBabashka ? callPackage ./clojure-tools.nix { } -, jdkBabashka ? clojureToolsBabashka.jdk +{ + stdenvNoCC, + lib, + babashka-unwrapped, + callPackage, + makeWrapper, + installShellFiles, + rlwrap, + clojureToolsBabashka ? callPackage ./clojure-tools.nix { }, + jdkBabashka ? clojureToolsBabashka.jdk, # rlwrap is a small utility to allow the editing of keyboard input, see # https://book.babashka.org/#_repl @@ -15,7 +16,7 @@ # break some babashka scripts. For this reason, it is disabled by default. See: # https://github.com/NixOS/nixpkgs/issues/246839 # https://github.com/NixOS/nixpkgs/pull/248207 -, withRlwrap ? false + withRlwrap ? false, }: stdenvNoCC.mkDerivation (finalAttrs: { pname = "babashka"; @@ -24,10 +25,15 @@ stdenvNoCC.mkDerivation (finalAttrs: { dontUnpack = true; dontBuild = true; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; installPhase = - let unwrapped-bin = "${babashka-unwrapped}/bin/bb"; in + let + unwrapped-bin = "${babashka-unwrapped}/bin/bb"; + in '' mkdir -p $out/clojure_tools ln -s -t $out/clojure_tools ${clojureToolsBabashka}/*.edn @@ -41,8 +47,8 @@ stdenvNoCC.mkDerivation (finalAttrs: { installShellCompletion --cmd bb --bash ${babashka-unwrapped}/share/bash-completion/completions/bb.bash installShellCompletion --cmd bb --zsh ${babashka-unwrapped}/share/zsh/site-functions/_bb installShellCompletion --cmd bb --fish ${babashka-unwrapped}/share/fish/vendor_completions.d/bb.fish - '' + - lib.optionalString withRlwrap '' + '' + + lib.optionalString withRlwrap '' substituteInPlace $out/bin/bb \ --replace '"${unwrapped-bin}"' '"${rlwrap}/bin/rlwrap" "${unwrapped-bin}"' ''; diff --git a/pkgs/development/interpreters/bqn/cbqn/default.nix b/pkgs/development/interpreters/bqn/cbqn/default.nix index 2f4d7f08931a89..1c7a394a043175 100644 --- a/pkgs/development/interpreters/bqn/cbqn/default.nix +++ b/pkgs/development/interpreters/bqn/cbqn/default.nix @@ -1,16 +1,17 @@ -{ lib -, callPackage -, fixDarwinDylibNames -, libffi -, mbqn-source -, pkg-config -, stdenv -# Boolean flags -, enableReplxx ? false -, enableLibcbqn ? ((stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isDarwin) && !enableReplxx) -, generateBytecode ? false -# "Configurable" options -, bqn-interpreter +{ + lib, + callPackage, + fixDarwinDylibNames, + libffi, + mbqn-source, + pkg-config, + stdenv, + # Boolean flags + enableReplxx ? false, + enableLibcbqn ? ((stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isDarwin) && !enableReplxx), + generateBytecode ? false, + # "Configurable" options + bqn-interpreter, }: let @@ -20,11 +21,13 @@ stdenv.mkDerivation rec { pname = "cbqn" + lib.optionalString (!generateBytecode) "-standalone"; inherit (sources.cbqn) version src; - nativeBuildInputs = [ - pkg-config - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ]; + nativeBuildInputs = + [ + pkg-config + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ]; buildInputs = [ libffi @@ -34,24 +37,29 @@ stdenv.mkDerivation rec { "CC=${stdenv.cc.targetPrefix}cc" ]; - buildFlags = [ - # interpreter binary - "o3" - "notui=1" # display build progress in a plain-text format - "REPLXX=${if enableReplxx then "1" else "0"}" - ] ++ lib.optionals stdenv.hostPlatform.avx2Support [ - "has=avx2" - ] ++ lib.optionals enableLibcbqn [ - # embeddable interpreter as a shared lib - "shared-o3" - ]; + buildFlags = + [ + # interpreter binary + "o3" + "notui=1" # display build progress in a plain-text format + "REPLXX=${if enableReplxx then "1" else "0"}" + ] + ++ lib.optionals stdenv.hostPlatform.avx2Support [ + "has=avx2" + ] + ++ lib.optionals enableLibcbqn [ + # embeddable interpreter as a shared lib + "shared-o3" + ]; - outputs = [ - "out" - ] ++ lib.optionals enableLibcbqn [ - "lib" - "dev" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals enableLibcbqn [ + "lib" + "dev" + ]; dontConfigure = true; @@ -64,37 +72,45 @@ stdenv.mkDerivation rec { patchShebangs build/build ''; - preBuild = '' - mkdir -p build/singeliLocal/ - cp -r ${sources.singeli.src}/* build/singeliLocal/ - '' + (if generateBytecode then '' - mkdir -p build/bytecodeLocal/gen - ${bqn-interpreter} ./build/genRuntime ${mbqn-source} build/bytecodeLocal/ - '' else '' - mkdir -p build/bytecodeLocal/gen - cp -r ${sources.cbqn-bytecode.src}/* build/bytecodeLocal/ - '') - + lib.optionalString enableReplxx '' - mkdir -p build/replxxLocal/ - cp -r ${sources.replxx.src}/* build/replxxLocal/ - ''; - - installPhase = '' - runHook preInstall - - mkdir -p $out/bin/ - cp BQN -t $out/bin/ - # note guard condition for case-insensitive filesystems - [ -e $out/bin/bqn ] || ln -s $out/bin/BQN $out/bin/bqn - [ -e $out/bin/cbqn ] || ln -s $out/bin/BQN $out/bin/cbqn - '' - + lib.optionalString enableLibcbqn '' - install -Dm644 include/bqnffi.h -t "$dev/include" - install -Dm755 libcbqn${stdenv.hostPlatform.extensions.sharedLibrary} -t "$lib/lib" - '' - + '' - runHook postInstall - ''; + preBuild = + '' + mkdir -p build/singeliLocal/ + cp -r ${sources.singeli.src}/* build/singeliLocal/ + '' + + ( + if generateBytecode then + '' + mkdir -p build/bytecodeLocal/gen + ${bqn-interpreter} ./build/genRuntime ${mbqn-source} build/bytecodeLocal/ + '' + else + '' + mkdir -p build/bytecodeLocal/gen + cp -r ${sources.cbqn-bytecode.src}/* build/bytecodeLocal/ + '' + ) + + lib.optionalString enableReplxx '' + mkdir -p build/replxxLocal/ + cp -r ${sources.replxx.src}/* build/replxxLocal/ + ''; + + installPhase = + '' + runHook preInstall + + mkdir -p $out/bin/ + cp BQN -t $out/bin/ + # note guard condition for case-insensitive filesystems + [ -e $out/bin/bqn ] || ln -s $out/bin/BQN $out/bin/bqn + [ -e $out/bin/cbqn ] || ln -s $out/bin/BQN $out/bin/cbqn + '' + + lib.optionalString enableLibcbqn '' + install -Dm644 include/bqnffi.h -t "$dev/include" + install -Dm755 libcbqn${stdenv.hostPlatform.extensions.sharedLibrary} -t "$lib/lib" + '' + + '' + runHook postInstall + ''; installCheckPhase = '' runHook preInstallCheck diff --git a/pkgs/development/interpreters/bqn/cbqn/sources.nix b/pkgs/development/interpreters/bqn/cbqn/sources.nix index 48470c50e1ba28..7d21beb8ebb0dc 100644 --- a/pkgs/development/interpreters/bqn/cbqn/sources.nix +++ b/pkgs/development/interpreters/bqn/cbqn/sources.nix @@ -7,19 +7,20 @@ }: { - cbqn = let - self = { - pname = "cbqn"; - version = "0.8.0"; - - src = fetchFromGitHub { - owner = "dzaima"; - repo = "CBQN"; - rev = "v${self.version}"; - hash = "sha256-vmd7CX0jgozysmjKK0p5GM4Qd3vY71q1kcKwfr+6fkw="; + cbqn = + let + self = { + pname = "cbqn"; + version = "0.8.0"; + + src = fetchFromGitHub { + owner = "dzaima"; + repo = "CBQN"; + rev = "v${self.version}"; + hash = "sha256-vmd7CX0jgozysmjKK0p5GM4Qd3vY71q1kcKwfr+6fkw="; + }; }; - }; - in + in self; cbqn-bytecode = { diff --git a/pkgs/development/interpreters/clisp/default.nix b/pkgs/development/interpreters/clisp/default.nix index c0f0e2c5c2f84a..ff166272e3f543 100644 --- a/pkgs/development/interpreters/clisp/default.nix +++ b/pkgs/development/interpreters/clisp/default.nix @@ -3,42 +3,55 @@ # - base (default): contains readline and i18n, regexp and syscalls modules # by default # - full: contains base plus modules in withModules -{ lib -, stdenv -, fetchFromGitLab -, autoconf269 -, automake -, libtool -, libsigsegv -, gettext -, ncurses -, pcre -, zlib -, readline -, libffi -, libffcall -, libX11 -, libXau -, libXt -, libXpm -, libXext -, xorgproto -, coreutils -# build options -, threadSupport ? (stdenv.hostPlatform.isx86 && ! stdenv.hostPlatform.isDarwin) -, x11Support ? (stdenv.hostPlatform.isx86 && ! stdenv.hostPlatform.isDarwin) -, dllSupport ? true -, withModules ? [ - "asdf" - "pcre" - "rawsock" - ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ "bindings/glibc" "zlib" ] - ++ lib.optional x11Support "clx/new-clx" +{ + lib, + stdenv, + fetchFromGitLab, + autoconf269, + automake, + libtool, + libsigsegv, + gettext, + ncurses, + pcre, + zlib, + readline, + libffi, + libffcall, + libX11, + libXau, + libXt, + libXpm, + libXext, + xorgproto, + coreutils, + # build options + threadSupport ? (stdenv.hostPlatform.isx86 && !stdenv.hostPlatform.isDarwin), + x11Support ? (stdenv.hostPlatform.isx86 && !stdenv.hostPlatform.isDarwin), + dllSupport ? true, + withModules ? + [ + "asdf" + "pcre" + "rawsock" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "bindings/glibc" + "zlib" + ] + ++ lib.optional x11Support "clx/new-clx", }: -assert x11Support -> (libX11 != null && libXau != null && libXt != null - && libXpm != null && xorgproto != null && libXext != null); +assert + x11Support + -> ( + libX11 != null + && libXau != null + && libXt != null + && libXpm != null + && xorgproto != null + && libXext != null + ); let ffcallAvailable = stdenv.hostPlatform.isLinux && (libffcall != null); @@ -58,18 +71,28 @@ stdenv.mkDerivation { }; strictDeps = true; - nativeBuildInputs = [ autoconf269 automake libtool ]; - buildInputs = [libsigsegv] - ++ lib.optional (gettext != null) gettext - ++ lib.optional (ncurses != null) ncurses - ++ lib.optional (pcre != null) pcre - ++ lib.optional (zlib != null) zlib - ++ lib.optional (readline != null) readline - ++ lib.optional (ffcallAvailable && (libffi != null)) libffi - ++ lib.optional ffcallAvailable libffcall - ++ lib.optionals x11Support [ - libX11 libXau libXt libXpm xorgproto libXext + nativeBuildInputs = [ + autoconf269 + automake + libtool ]; + buildInputs = + [ libsigsegv ] + ++ lib.optional (gettext != null) gettext + ++ lib.optional (ncurses != null) ncurses + ++ lib.optional (pcre != null) pcre + ++ lib.optional (zlib != null) zlib + ++ lib.optional (readline != null) readline + ++ lib.optional (ffcallAvailable && (libffi != null)) libffi + ++ lib.optional ffcallAvailable libffcall + ++ lib.optionals x11Support [ + libX11 + libXau + libXt + libXpm + xorgproto + libXext + ]; patches = [ ./gnulib_aarch64.patch @@ -85,28 +108,32 @@ stdenv.mkDerivation { find . -type f | xargs sed -e 's/-lICE/-lXau &/' -i ''; - preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin ('' - ( - cd src - autoreconf -f -i -I m4 -I glm4 - ) - '' + lib.concatMapStrings (x: '' - ( - root="$PWD" - cd modules/${x} - autoreconf -f -i -I "$root/src" -I "$root/src/m4" -I "$root/src/glm4" - ) - '') (builtins.filter shouldReconfModule withModules)); + preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin ( + '' + ( + cd src + autoreconf -f -i -I m4 -I glm4 + ) + '' + + lib.concatMapStrings (x: '' + ( + root="$PWD" + cd modules/${x} + autoreconf -f -i -I "$root/src" -I "$root/src/m4" -I "$root/src/glm4" + ) + '') (builtins.filter shouldReconfModule withModules) + ); - configureFlags = [ "builddir" ] - ++ lib.optional (!dllSupport) "--without-dynamic-modules" - ++ lib.optional (readline != null) "--with-readline" - # --with-dynamic-ffi can only exist with --with-ffcall - foreign.d does not compile otherwise - ++ lib.optional (ffcallAvailable && (libffi != null)) "--with-dynamic-ffi" - ++ lib.optional ffcallAvailable "--with-ffcall" - ++ lib.optional (!ffcallAvailable) "--without-ffcall" - ++ builtins.map (x: " --with-module=" + x) withModules - ++ lib.optional threadSupport "--with-threads=POSIX_THREADS"; + configureFlags = + [ "builddir" ] + ++ lib.optional (!dllSupport) "--without-dynamic-modules" + ++ lib.optional (readline != null) "--with-readline" + # --with-dynamic-ffi can only exist with --with-ffcall - foreign.d does not compile otherwise + ++ lib.optional (ffcallAvailable && (libffi != null)) "--with-dynamic-ffi" + ++ lib.optional ffcallAvailable "--with-ffcall" + ++ lib.optional (!ffcallAvailable) "--without-ffcall" + ++ builtins.map (x: " --with-module=" + x) withModules + ++ lib.optional threadSupport "--with-threads=POSIX_THREADS"; preBuild = '' sed -e '/avcall.h/a\#include "config.h"' -i src/foreign.d @@ -116,12 +143,14 @@ stdenv.mkDerivation { doCheck = true; - postInstall = - lib.optionalString (withModules != []) - (''./clisp-link add "$out"/lib/clisp*/base "$(dirname "$out"/lib/clisp*/base)"/full'' - + lib.concatMapStrings (x: " " + x) withModules); + postInstall = lib.optionalString (withModules != [ ]) ( + ''./clisp-link add "$out"/lib/clisp*/base "$(dirname "$out"/lib/clisp*/base)"/full'' + + lib.concatMapStrings (x: " " + x) withModules + ); - env.NIX_CFLAGS_COMPILE = "-O0 -falign-functions=${if stdenv.hostPlatform.is64bit then "8" else "4"}"; + env.NIX_CFLAGS_COMPILE = "-O0 -falign-functions=${ + if stdenv.hostPlatform.is64bit then "8" else "4" + }"; meta = { description = "ANSI Common Lisp Implementation"; diff --git a/pkgs/development/interpreters/clojure/clooj.nix b/pkgs/development/interpreters/clojure/clooj.nix index 45659d56336917..d723a12be42405 100644 --- a/pkgs/development/interpreters/clojure/clooj.nix +++ b/pkgs/development/interpreters/clojure/clooj.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "clooj"; diff --git a/pkgs/development/interpreters/clojure/obb.nix b/pkgs/development/interpreters/clojure/obb.nix index d6717c4ec701c2..e367bcd72df9d9 100644 --- a/pkgs/development/interpreters/clojure/obb.nix +++ b/pkgs/development/interpreters/clojure/obb.nix @@ -1,14 +1,16 @@ -{ lib -, stdenv -, babashka -, cacert -, clojure -, git -, jdk -, obb -, fetchFromGitHub -, makeWrapper -, runCommand }: +{ + lib, + stdenv, + babashka, + cacert, + clojure, + git, + jdk, + obb, + fetchFromGitHub, + makeWrapper, + runCommand, +}: stdenv.mkDerivation rec { pname = "obb"; @@ -23,7 +25,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ babashka cacert git jdk ]; + buildInputs = [ + babashka + cacert + git + jdk + ]; configurePhase = '' runHook preConfigure @@ -64,7 +71,7 @@ stdenv.mkDerivation rec { ''; passthru.tests = { - simple = runCommand "${pname}-test" {} '' + simple = runCommand "${pname}-test" { } '' [ $(${obb}/bin/obb -e '(+ 1 2)') = '3' ] touch $out ''; diff --git a/pkgs/development/interpreters/dhall/build-dhall-directory-package.nix b/pkgs/development/interpreters/dhall/build-dhall-directory-package.nix index f7c730c927724b..0b147e630240bf 100644 --- a/pkgs/development/interpreters/dhall/build-dhall-directory-package.nix +++ b/pkgs/development/interpreters/dhall/build-dhall-directory-package.nix @@ -5,25 +5,27 @@ # the `file` # # This function is used by `dhall-to-nixpkgs` when given a directory -lib.makePackageOverridable - ( { # Arguments passed through to `buildDhallPackage` - name - , dependencies ? [] - , source ? false +lib.makePackageOverridable ( + { + # Arguments passed through to `buildDhallPackage` + name, + dependencies ? [ ], + source ? false, - , src - , # The file to import, relative to the root directory - file ? "package.dhall" - # Set to `true` to generate documentation for the package - , document ? false - }: + src, + # The file to import, relative to the root directory + file ? "package.dhall", + # Set to `true` to generate documentation for the package + document ? false, + }: - buildDhallPackage - ( { inherit name dependencies source; + buildDhallPackage ( + { + inherit name dependencies source; - code = "${src}/${file}"; + code = "${src}/${file}"; - } - // lib.optionalAttrs document { documentationRoot = "${src}"; } - ) + } + // lib.optionalAttrs document { documentationRoot = "${src}"; } ) +) diff --git a/pkgs/development/interpreters/dhall/build-dhall-github-package.nix b/pkgs/development/interpreters/dhall/build-dhall-github-package.nix index 8f9e4d835511c4..bf25b7e485a4d8 100644 --- a/pkgs/development/interpreters/dhall/build-dhall-github-package.nix +++ b/pkgs/development/interpreters/dhall/build-dhall-github-package.nix @@ -1,37 +1,44 @@ -{ buildDhallPackage, fetchFromGitHub, lib }: +{ + buildDhallPackage, + fetchFromGitHub, + lib, +}: # This function is used by `dhall-to-nixpkgs` when given a GitHub repository -lib.makePackageOverridable - ( { # Arguments passed through to `buildDhallPackage` - name - , dependencies ? [] - , source ? false - - , # The directory containing the Dhall files, if other than the root of the - # repository - directory ? "" - , # The file to import, relative to the above directory - file ? "package.dhall" - # Set to `true` to generate documentation for the package - , document ? false - - # Arguments passed through to `fetchFromGitHub` - , owner - , repo - , rev - # Extra arguments passed through to `fetchFromGitHub`, such as the hash - # or `fetchSubmodules` - , ... - }@args: - - let - versionedName = "${name}-${rev}"; - - src = fetchFromGitHub ({ +lib.makePackageOverridable ( + { + # Arguments passed through to `buildDhallPackage` + name, + dependencies ? [ ], + source ? false, + + # The directory containing the Dhall files, if other than the root of the + # repository + directory ? "", + # The file to import, relative to the above directory + file ? "package.dhall", + # Set to `true` to generate documentation for the package + document ? false, + + # Arguments passed through to `fetchFromGitHub` + owner, + repo, + rev, + # Extra arguments passed through to `fetchFromGitHub`, such as the hash + # or `fetchSubmodules` + ... + }@args: + + let + versionedName = "${name}-${rev}"; + + src = fetchFromGitHub ( + { name = "${versionedName}-source"; inherit owner repo rev; - } // removeAttrs args [ + } + // removeAttrs args [ "name" "dependencies" "document" @@ -41,22 +48,24 @@ lib.makePackageOverridable "owner" "repo" "rev" - ]); + ] + ); - prefix = lib.optionalString (directory != "") "/${directory}"; + prefix = lib.optionalString (directory != "") "/${directory}"; - in - buildDhallPackage - ( { inherit dependencies source; + in + buildDhallPackage ( + { + inherit dependencies source; - name = versionedName; + name = versionedName; - code = "${src}${prefix}/${file}"; - } - // lib.optionalAttrs document - { documentationRoot = "${src}/${prefix}"; + code = "${src}${prefix}/${file}"; + } + // lib.optionalAttrs document { + documentationRoot = "${src}/${prefix}"; - baseImportUrl = "https://raw.githubusercontent.com/${owner}/${repo}/${rev}${prefix}"; - } - ) + baseImportUrl = "https://raw.githubusercontent.com/${owner}/${repo}/${rev}${prefix}"; + } ) +) diff --git a/pkgs/development/interpreters/dhall/build-dhall-package.nix b/pkgs/development/interpreters/dhall/build-dhall-package.nix index f58546a9d3c614..214fe7f92d2898 100644 --- a/pkgs/development/interpreters/dhall/build-dhall-package.nix +++ b/pkgs/development/interpreters/dhall/build-dhall-package.nix @@ -1,9 +1,18 @@ -{ dhall, dhall-docs, haskell, lib, lndir, runCommand, writeText }: +{ + dhall, + dhall-docs, + haskell, + lib, + lndir, + runCommand, + writeText, +}: -{ name +{ + name, # Expressions to add to the cache before interpreting the code -, dependencies ? [] + dependencies ? [ ], # A Dhall expression # @@ -15,7 +24,7 @@ # # You can add a dependency to the cache using the preceding `dependencies` # option -, code + code, # `buildDhallPackage` can include both a "source distribution" in # `source.dhall` and a "binary distribution" in `binary.dhall`: @@ -30,19 +39,19 @@ # By default, `buildDhallPackage` only includes "binary.dhall" to conserve # space within the Nix store, but if you set the following `source` option to # `true` then the package will also include `source.dhall`. -, source ? false + source ? false, # Directory to generate documentation for (i.e. as the `--input` option to the # `dhall-docs` command.) # # If `null`, then no documentation is generated. -, documentationRoot ? null + documentationRoot ? null, # Base URL prepended to paths copied to the clipboard # # This is used in conjunction with `documentationRoot`, and is unused if # `documentationRoot` is `null`. -, baseImportUrl ? null + baseImportUrl ? null, }: let @@ -63,40 +72,42 @@ let sourceFile = "source.dhall"; in - runCommand name { inherit dependencies; } '' - set -eu +runCommand name { inherit dependencies; } '' + set -eu - mkdir -p ${cacheDhall} + mkdir -p ${cacheDhall} - for dependency in $dependencies; do - ${lndir}/bin/lndir -silent $dependency/${cacheDhall} ${cacheDhall} - done + for dependency in $dependencies; do + ${lndir}/bin/lndir -silent $dependency/${cacheDhall} ${cacheDhall} + done - export XDG_CACHE_HOME=$PWD/${cache} + export XDG_CACHE_HOME=$PWD/${cache} - mkdir -p $out/${cacheDhall} + mkdir -p $out/${cacheDhall} - ${dhallNoHTTP}/bin/dhall --alpha --file '${file}' > $out/${sourceFile} + ${dhallNoHTTP}/bin/dhall --alpha --file '${file}' > $out/${sourceFile} - SHA_HASH=$(${dhallNoHTTP}/bin/dhall hash <<< $out/${sourceFile}) + SHA_HASH=$(${dhallNoHTTP}/bin/dhall hash <<< $out/${sourceFile}) - HASH_FILE="''${SHA_HASH/sha256:/1220}" + HASH_FILE="''${SHA_HASH/sha256:/1220}" - ${dhallNoHTTP}/bin/dhall encode --file $out/${sourceFile} > $out/${cacheDhall}/$HASH_FILE + ${dhallNoHTTP}/bin/dhall encode --file $out/${sourceFile} > $out/${cacheDhall}/$HASH_FILE - echo "missing $SHA_HASH" > $out/binary.dhall + echo "missing $SHA_HASH" > $out/binary.dhall - ${lib.optionalString (!source) "rm $out/${sourceFile}"} + ${lib.optionalString (!source) "rm $out/${sourceFile}"} - ${lib.optionalString (documentationRoot != null) '' + ${lib.optionalString (documentationRoot != null) '' mkdir -p $out/${dataDhall} - XDG_DATA_HOME=$out/${data} ${dhall-docs}/bin/dhall-docs --output-link $out/docs ${lib.cli.toGNUCommandLineShell { } { - base-import-url = baseImportUrl; + XDG_DATA_HOME=$out/${data} ${dhall-docs}/bin/dhall-docs --output-link $out/docs ${ + lib.cli.toGNUCommandLineShell { } { + base-import-url = baseImportUrl; - input = documentationRoot; + input = documentationRoot; - package-name = name; - }} - ''} - '' + package-name = name; + } + } + ''} +'' diff --git a/pkgs/development/interpreters/dhall/build-dhall-url.nix b/pkgs/development/interpreters/dhall/build-dhall-url.nix index 6d7103f78e6fa7..5ffba739be47f3 100644 --- a/pkgs/development/interpreters/dhall/build-dhall-url.nix +++ b/pkgs/development/interpreters/dhall/build-dhall-url.nix @@ -1,4 +1,11 @@ -{ cacert, dhall, dhall-docs, haskell, lib, runCommand }: +{ + cacert, + dhall, + dhall-docs, + haskell, + lib, + runCommand, +}: # `buildDhallUrl` is similar to `buildDhallDirectoryPackage` or # `buildDhallGitHubPackage`, but instead builds a Nixpkgs Dhall package @@ -12,20 +19,21 @@ # # This function is primarily used by `dhall-to-nixpkgs directory --fixed-output-derivations`. -{ # URL of the input Dhall file. +{ + # URL of the input Dhall file. # example: "https://raw.githubusercontent.com/cdepillabout/example-dhall-repo/c1b0d0327146648dcf8de997b2aa32758f2ed735/example1.dhall" - url + url, # Nix hash of the input Dhall file. # example: "sha256-ZTSiQUXpPbPfPvS8OeK6dDQE6j6NbP27ho1cg9YfENI=" -, hash + hash, # Dhall hash of the input Dhall file. # example: "sha256:6534a24145e93db3df3ef4bc39e2ba743404ea3e8d6cfdbb868d5c83d61f10d2" -, dhallHash + dhallHash, # Name for this derivation. -, name ? (baseNameOf url + "-cache") + name ? (baseNameOf url + "-cache"), # `buildDhallUrl` can include both a "source distribution" in # `source.dhall` and a "binary distribution" in `binary.dhall`: @@ -40,7 +48,7 @@ # By default, `buildDhallUrl` only includes "binary.dhall" to conserve # space within the Nix store, but if you set the following `source` option to # `true` then the package will also include `source.dhall`. -, source ? false + source ? false, }: let @@ -52,8 +60,7 @@ let # The output Dhall file has all imports resolved, and then is # alpha-normalized and binary-encoded. downloadedEncodedFile = - runCommand - (baseNameOf url) + runCommand (baseNameOf url) { outputHashAlgo = null; outputHash = hash; @@ -66,19 +73,19 @@ let ${dhall}/bin/dhall --alpha --plain --file in-dhall-file | ${dhallNoHTTP}/bin/dhall encode > $out ''; - cache = ".cache"; + cache = ".cache"; - data = ".local/share"; + data = ".local/share"; - cacheDhall = "${cache}/dhall"; + cacheDhall = "${cache}/dhall"; - dataDhall = "${data}/dhall"; + dataDhall = "${data}/dhall"; - sourceFile = "source.dhall"; + sourceFile = "source.dhall"; in - runCommand name { } - ('' +runCommand name { } ( + '' set -eu mkdir -p ${cacheDhall} $out/${cacheDhall} @@ -92,7 +99,8 @@ in cp ${downloadedEncodedFile} $out/${cacheDhall}/$HASH_FILE echo "missing $SHA_HASH" > $out/binary.dhall - '' + - lib.optionalString source '' + '' + + lib.optionalString source '' ${dhallNoHTTP}/bin/dhall decode --file ${downloadedEncodedFile} > $out/${sourceFile} - '') + '' +) diff --git a/pkgs/development/interpreters/dhall/generate-dhall-directory-package.nix b/pkgs/development/interpreters/dhall/generate-dhall-directory-package.nix index 8ece89ef4f4857..2d5c36657ae388 100644 --- a/pkgs/development/interpreters/dhall/generate-dhall-directory-package.nix +++ b/pkgs/development/interpreters/dhall/generate-dhall-directory-package.nix @@ -1,4 +1,8 @@ -{ dhall-nixpkgs, lib, stdenv }: +{ + dhall-nixpkgs, + lib, + stdenv, +}: # This function calls `dhall-to-nixpkgs directory --fixed-output-derivations` # within a Nix derivation. @@ -8,20 +12,21 @@ # Dhall imports protected with Dhall integrity checksinto fixed-output # derivations (with the `buildDhallUrl` function), so no unrestricted network # access is necessary. -lib.makePackageOverridable - ( { src - , # The file to import, relative to the root directory - file ? "package.dhall" - , # Set to `true` to generate documentation for the package - document ? false - }: - stdenv.mkDerivation { - name = "dhall-directory-package.nix"; +lib.makePackageOverridable ( + { + src, + # The file to import, relative to the root directory + file ? "package.dhall", + # Set to `true` to generate documentation for the package + document ? false, + }: + stdenv.mkDerivation { + name = "dhall-directory-package.nix"; - buildCommand = '' - dhall-to-nixpkgs directory --fixed-output-derivations --file "${file}" "${src}" ${lib.optionalString document "--document"} > $out - ''; + buildCommand = '' + dhall-to-nixpkgs directory --fixed-output-derivations --file "${file}" "${src}" ${lib.optionalString document "--document"} > $out + ''; - nativeBuildInputs = [ dhall-nixpkgs ]; - } - ) + nativeBuildInputs = [ dhall-nixpkgs ]; + } +) diff --git a/pkgs/development/interpreters/dzaima-apl/default.nix b/pkgs/development/interpreters/dzaima-apl/default.nix index a607fb0fefe4e3..1921c3554cb954 100644 --- a/pkgs/development/interpreters/dzaima-apl/default.nix +++ b/pkgs/development/interpreters/dzaima-apl/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, jdk -, makeWrapper -, buildNativeImage ? true +{ + lib, + stdenv, + fetchFromGitHub, + jdk, + makeWrapper, + buildNativeImage ? true, }: stdenv.mkDerivation rec { @@ -28,39 +29,51 @@ stdenv.mkDerivation rec { patchShebangs --build ./build ''; - buildPhase = '' - runHook preBuild + buildPhase = + '' + runHook preBuild - ./build - '' + lib.optionalString buildNativeImage '' - native-image --report-unsupported-elements-at-runtime \ - -H:CLibraryPath=${lib.getLib jdk}/lib -J-Dfile.encoding=UTF-8 \ - -jar APL.jar dapl - '' + '' - runHook postBuild - ''; + ./build + '' + + lib.optionalString buildNativeImage '' + native-image --report-unsupported-elements-at-runtime \ + -H:CLibraryPath=${lib.getLib jdk}/lib -J-Dfile.encoding=UTF-8 \ + -jar APL.jar dapl + '' + + '' + runHook postBuild + ''; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - mkdir -p $out/bin - '' + (if buildNativeImage then '' - mv dapl $out/bin - '' else '' - mkdir -p $out/share/${pname} - mv APL.jar $out/share/${pname}/ + mkdir -p $out/bin + '' + + ( + if buildNativeImage then + '' + mv dapl $out/bin + '' + else + '' + mkdir -p $out/share/${pname} + mv APL.jar $out/share/${pname}/ - makeWrapper "${lib.getBin jdk}/bin/java" "$out/bin/dapl" \ - --add-flags "-jar $out/share/${pname}/APL.jar" - '') + '' - ln -s $out/bin/dapl $out/bin/apl + makeWrapper "${lib.getBin jdk}/bin/java" "$out/bin/dapl" \ + --add-flags "-jar $out/share/${pname}/APL.jar" + '' + ) + + '' + ln -s $out/bin/dapl $out/bin/apl - runHook postInstall - ''; + runHook postInstall + ''; meta = with lib; { homepage = "https://github.com/dzaima/APL"; - description = "APL implementation in Java" + lib.optionalString buildNativeImage ", compiled as a native image"; + description = + "APL implementation in Java" + lib.optionalString buildNativeImage ", compiled as a native image"; license = licenses.mit; maintainers = with maintainers; [ AndersonTorres ]; inherit (jdk.meta) platforms; diff --git a/pkgs/development/interpreters/elixir/generic-builder.nix b/pkgs/development/interpreters/elixir/generic-builder.nix index e1e14f14dee19f..64582c98c45b6b 100644 --- a/pkgs/development/interpreters/elixir/generic-builder.nix +++ b/pkgs/development/interpreters/elixir/generic-builder.nix @@ -1,27 +1,38 @@ -{ pkgs -, lib -, stdenv -, fetchFromGitHub -, erlang -, makeWrapper -, coreutils -, curl -, bash -, debugInfo ? false -} @ inputs: - -{ baseName ? "elixir" -, version -, erlang ? inputs.erlang -, minimumOTPVersion -, sha256 ? null -, rev ? "v${version}" -, src ? fetchFromGitHub { inherit rev sha256; owner = "elixir-lang"; repo = "elixir"; } -, escriptPath ? "lib/elixir/generate_app.escript" -} @ args: +{ + pkgs, + lib, + stdenv, + fetchFromGitHub, + erlang, + makeWrapper, + coreutils, + curl, + bash, + debugInfo ? false, +}@inputs: + +{ + baseName ? "elixir", + version, + erlang ? inputs.erlang, + minimumOTPVersion, + sha256 ? null, + rev ? "v${version}", + src ? fetchFromGitHub { + inherit rev sha256; + owner = "elixir-lang"; + repo = "elixir"; + }, + escriptPath ? "lib/elixir/generate_app.escript", +}@args: let - inherit (lib) getVersion versionAtLeast optional concatStringsSep; + inherit (lib) + getVersion + versionAtLeast + optional + concatStringsSep + ; in assert versionAtLeast (getVersion erlang) minimumOTPVersion; @@ -39,8 +50,7 @@ stdenv.mkDerivation ({ ERLC_OPTS = let - erlc_opts = [ "deterministic" ] - ++ optional debugInfo "debug_info"; + erlc_opts = [ "deterministic" ] ++ optional debugInfo "debug_info"; in "[${concatStringsSep "," erlc_opts}]"; @@ -59,7 +69,14 @@ stdenv.mkDerivation ({ b=$(basename $f) if [ "$b" = mix ]; then continue; fi wrapProgram $f \ - --prefix PATH ":" "${lib.makeBinPath [ erlang coreutils curl bash ]}" + --prefix PATH ":" "${ + lib.makeBinPath [ + erlang + coreutils + curl + bash + ] + }" done substituteInPlace $out/bin/mix \ diff --git a/pkgs/development/interpreters/emilua/default.nix b/pkgs/development/interpreters/emilua/default.nix index 22affc8b9adde8..170408d0bb9f5b 100644 --- a/pkgs/development/interpreters/emilua/default.nix +++ b/pkgs/development/interpreters/emilua/default.nix @@ -22,7 +22,7 @@ cmake, asciidoctor, makeWrapper, - gitUpdater + gitUpdater, }: let @@ -107,7 +107,8 @@ stdenv.mkDerivation (self: { mesonCheckFlags = [ # Skipped test: libpsx # Known issue with no-new-privs disabled in the Nix build environment. - "--no-suite" "libpsx" + "--no-suite" + "libpsx" ]; postInstall = '' @@ -118,7 +119,7 @@ stdenv.mkDerivation (self: { ''; passthru = { - updateScript = gitUpdater {rev-prefix = "v";}; + updateScript = gitUpdater { rev-prefix = "v"; }; inherit boost; sitePackages = "lib/emilua-${(lib.concatStringsSep "." (lib.take 2 (lib.splitVersion self.version)))}"; }; @@ -128,7 +129,10 @@ stdenv.mkDerivation (self: { mainProgram = "emilua"; homepage = "https://emilua.org/"; license = licenses.boost; - maintainers = with maintainers; [ manipuladordedados lucasew ]; + maintainers = with maintainers; [ + manipuladordedados + lucasew + ]; platforms = platforms.linux; }; }) diff --git a/pkgs/development/interpreters/erlang/generic-builder.nix b/pkgs/development/interpreters/erlang/generic-builder.nix index 2b363d4a06e6b3..499d3b7f879f04 100644 --- a/pkgs/development/interpreters/erlang/generic-builder.nix +++ b/pkgs/development/interpreters/erlang/generic-builder.nix @@ -1,231 +1,304 @@ -{ pkgs -, lib -, stdenv -, fetchFromGitHub -, makeWrapper -, gawk -, gnum4 -, gnused -, libxml2 -, libxslt -, ncurses -, openssl -, perl -, runtimeShell -, autoconf -, openjdk11 ? null # javacSupport -, unixODBC ? null # odbcSupport -, libGL ? null -, libGLU ? null -, wxGTK ? null -, xorg ? null -, ex_doc ? null -, parallelBuild ? false -, systemd -, wxSupport ? true -, ex_docSupport ? false -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd # systemd support in epmd +{ + pkgs, + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + gawk, + gnum4, + gnused, + libxml2, + libxslt, + ncurses, + openssl, + perl, + runtimeShell, + autoconf, + openjdk11 ? null, # javacSupport + unixODBC ? null, # odbcSupport + libGL ? null, + libGLU ? null, + wxGTK ? null, + xorg ? null, + ex_doc ? null, + parallelBuild ? false, + systemd, + wxSupport ? true, + ex_docSupport ? false, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, # systemd support in epmd # updateScript deps -, writeScript -, common-updater-scripts -, coreutils -, git -, wrapGAppsHook3 + writeScript, + common-updater-scripts, + coreutils, + git, + wrapGAppsHook3, }: -{ baseName ? "erlang" -, version -, sha256 ? null -, rev ? "OTP-${version}" -, src ? fetchFromGitHub { inherit rev sha256; owner = "erlang"; repo = "otp"; } -, enableHipe ? true -, enableDebugInfo ? false -, enableThreads ? true -, enableSmpSupport ? true -, enableKernelPoll ? true -, javacSupport ? false -, javacPackages ? [ openjdk11 ] -, odbcSupport ? false -, odbcPackages ? [ unixODBC ] -, opensslPackage ? openssl -, wxPackages ? [ libGL libGLU wxGTK xorg.libX11 wrapGAppsHook3 ] -, preUnpack ? "" -, postUnpack ? "" -, patches ? [ ] -, patchPhase ? "" -, prePatch ? "" -, postPatch ? "" -, configureFlags ? [ ] -, configurePhase ? "" -, preConfigure ? "" -, postConfigure ? "" -, buildPhase ? "" -, preBuild ? "" -, postBuild ? "" -, installPhase ? "" -, preInstall ? "" -, postInstall ? "" -, installTargets ? if ((lib.versionOlder version "27.0") || ex_docSupport) then [ "install" "install-docs" ] else [ "install" ] -, checkPhase ? "" -, preCheck ? "" -, postCheck ? "" -, fixupPhase ? "" -, preFixup ? "" -, postFixup ? "" -, meta ? { } +{ + baseName ? "erlang", + version, + sha256 ? null, + rev ? "OTP-${version}", + src ? fetchFromGitHub { + inherit rev sha256; + owner = "erlang"; + repo = "otp"; + }, + enableHipe ? true, + enableDebugInfo ? false, + enableThreads ? true, + enableSmpSupport ? true, + enableKernelPoll ? true, + javacSupport ? false, + javacPackages ? [ openjdk11 ], + odbcSupport ? false, + odbcPackages ? [ unixODBC ], + opensslPackage ? openssl, + wxPackages ? [ + libGL + libGLU + wxGTK + xorg.libX11 + wrapGAppsHook3 + ], + preUnpack ? "", + postUnpack ? "", + patches ? [ ], + patchPhase ? "", + prePatch ? "", + postPatch ? "", + configureFlags ? [ ], + configurePhase ? "", + preConfigure ? "", + postConfigure ? "", + buildPhase ? "", + preBuild ? "", + postBuild ? "", + installPhase ? "", + preInstall ? "", + postInstall ? "", + installTargets ? + if ((lib.versionOlder version "27.0") || ex_docSupport) then + [ + "install" + "install-docs" + ] + else + [ "install" ], + checkPhase ? "", + preCheck ? "", + postCheck ? "", + fixupPhase ? "", + preFixup ? "", + postFixup ? "", + meta ? { }, }: -assert wxSupport -> (if stdenv.hostPlatform.isDarwin -then wxGTK != null -else libGL != null && libGLU != null && wxGTK != null && xorg != null); +assert + wxSupport + -> ( + if stdenv.hostPlatform.isDarwin then + wxGTK != null + else + libGL != null && libGLU != null && wxGTK != null && xorg != null + ); assert odbcSupport -> unixODBC != null; assert javacSupport -> openjdk11 != null; assert ex_docSupport -> ex_doc != null; let - inherit (lib) optional optionals optionalAttrs optionalString; + inherit (lib) + optional + optionals + optionalAttrs + optionalString + ; wxPackages2 = if stdenv.hostPlatform.isDarwin then [ wxGTK ] else wxPackages; in -stdenv.mkDerivation ({ - # name is used instead of pname to - # - not have to pass pnames as argument - # - have a separate pname for erlang (main module) - name = "${baseName}" - + optionalString javacSupport "_javac" - + optionalString odbcSupport "_odbc" - + "-${version}"; - - inherit src version; - - LANG = "C.UTF-8"; - - nativeBuildInputs = [ autoconf makeWrapper perl gnum4 libxslt libxml2 ]; - - buildInputs = [ ncurses opensslPackage ] - ++ optionals wxSupport wxPackages2 - ++ optionals odbcSupport odbcPackages - ++ optionals javacSupport javacPackages - ++ optional systemdSupport systemd - ++ optionals stdenv.hostPlatform.isDarwin (with pkgs.darwin.apple_sdk.frameworks; [ AGL Carbon Cocoa WebKit ]); - - debugInfo = enableDebugInfo; - - # On some machines, parallel build reliably crashes on `GEN asn1ct_eval_ext.erl` step - enableParallelBuilding = parallelBuild; - - postPatch = '' - patchShebangs make - - ${postPatch} - '' + optionalString (lib.versionOlder "25" version) '' - substituteInPlace lib/os_mon/src/disksup.erl \ - --replace-fail '"sh ' '"${runtimeShell} ' - ''; - - # For OTP 27+ we need ex_doc to build the documentation - # When ex_docSupport is enabled, grab the raw ex_doc executable from the ex_doc - # derivation. Next, patch the first line to use the escript that will be - # built during the build phase of this derivation. Finally, building the - # documentation requires the erlang-logo.png asset. - preConfigure = '' - ./otp_build autoconf - '' + optionalString ex_docSupport '' - mkdir -p $out/bin - cp ${ex_doc}/bin/.ex_doc-wrapped $out/bin/ex_doc - sed -i "1 s:^.*$:#!$out/bin/escript:" $out/bin/ex_doc - export EX_DOC=$out/bin/ex_doc - - mkdir -p $out/lib/erlang/system/doc/assets - cp $src/system/doc/assets/erlang-logo.png $out/lib/erlang/system/doc/assets - ''; - - configureFlags = [ "--with-ssl=${lib.getOutput "out" opensslPackage}" ] - ++ [ "--with-ssl-incl=${lib.getDev opensslPackage}" ] # This flag was introduced in R24 - ++ optional enableThreads "--enable-threads" - ++ optional enableSmpSupport "--enable-smp-support" - ++ optional enableKernelPoll "--enable-kernel-poll" - ++ optional enableHipe "--enable-hipe" - ++ optional javacSupport "--with-javac" - ++ optional odbcSupport "--with-odbc=${unixODBC}" - ++ optional wxSupport "--enable-wx" - ++ optional systemdSupport "--enable-systemd" - ++ optional stdenv.hostPlatform.isDarwin "--enable-darwin-64bit" - # make[3]: *** [yecc.beam] Segmentation fault: 11 - ++ optional (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) "--disable-jit" - ++ configureFlags; - - # install-docs will generate and install manpages and html docs - # (PDFs are generated only when fop is available). - - postInstall = '' - ln -s $out/lib/erlang/lib/erl_interface*/bin/erl_call $out/bin/erl_call - - ${postInstall} - ''; - - # Some erlang bin/ scripts run sed and awk - postFixup = '' - wrapProgram $out/lib/erlang/bin/erl --prefix PATH ":" "${gnused}/bin/" - wrapProgram $out/lib/erlang/bin/start_erl --prefix PATH ":" "${lib.makeBinPath [ gnused gawk ]}" - ''; - - passthru = { - updateScript = - let major = builtins.head (builtins.splitVersion version); - in - writeScript "update.sh" '' - #!${stdenv.shell} - set -ox errexit - PATH=${lib.makeBinPath [ common-updater-scripts coreutils git gnused ]} - latest=$(list-git-tags --url=https://github.com/erlang/otp.git | sed -n 's/^OTP-${major}/${major}/p' | sort -V | tail -1) - if [ "$latest" != "${version}" ]; then - nixpkgs="$(git rev-parse --show-toplevel)" - nix_file="$nixpkgs/pkgs/development/interpreters/erlang/${major}.nix" - update-source-version ${baseName}R${major} "$latest" --version-key=version --print-changes --file="$nix_file" - else - echo "${baseName}R${major} is already up-to-date" - fi +stdenv.mkDerivation ( + { + # name is used instead of pname to + # - not have to pass pnames as argument + # - have a separate pname for erlang (main module) + name = + "${baseName}" + + optionalString javacSupport "_javac" + + optionalString odbcSupport "_odbc" + + "-${version}"; + + inherit src version; + + LANG = "C.UTF-8"; + + nativeBuildInputs = [ + autoconf + makeWrapper + perl + gnum4 + libxslt + libxml2 + ]; + + buildInputs = + [ + ncurses + opensslPackage + ] + ++ optionals wxSupport wxPackages2 + ++ optionals odbcSupport odbcPackages + ++ optionals javacSupport javacPackages + ++ optional systemdSupport systemd + ++ optionals stdenv.hostPlatform.isDarwin ( + with pkgs.darwin.apple_sdk.frameworks; + [ + AGL + Carbon + Cocoa + WebKit + ] + ); + + debugInfo = enableDebugInfo; + + # On some machines, parallel build reliably crashes on `GEN asn1ct_eval_ext.erl` step + enableParallelBuilding = parallelBuild; + + postPatch = + '' + patchShebangs make + + ${postPatch} + '' + + optionalString (lib.versionOlder "25" version) '' + substituteInPlace lib/os_mon/src/disksup.erl \ + --replace-fail '"sh ' '"${runtimeShell} ' + ''; + + # For OTP 27+ we need ex_doc to build the documentation + # When ex_docSupport is enabled, grab the raw ex_doc executable from the ex_doc + # derivation. Next, patch the first line to use the escript that will be + # built during the build phase of this derivation. Finally, building the + # documentation requires the erlang-logo.png asset. + preConfigure = + '' + ./otp_build autoconf + '' + + optionalString ex_docSupport '' + mkdir -p $out/bin + cp ${ex_doc}/bin/.ex_doc-wrapped $out/bin/ex_doc + sed -i "1 s:^.*$:#!$out/bin/escript:" $out/bin/ex_doc + export EX_DOC=$out/bin/ex_doc + + mkdir -p $out/lib/erlang/system/doc/assets + cp $src/system/doc/assets/erlang-logo.png $out/lib/erlang/system/doc/assets ''; - }; - - meta = with lib; ({ - homepage = "https://www.erlang.org/"; - downloadPage = "https://www.erlang.org/download.html"; - description = "Programming language used for massively scalable soft real-time systems"; - - longDescription = '' - Erlang is a programming language used to build massively scalable - soft real-time systems with requirements on high availability. - Some of its uses are in telecoms, banking, e-commerce, computer - telephony and instant messaging. Erlang's runtime system has - built-in support for concurrency, distribution and fault - tolerance. + + configureFlags = + [ "--with-ssl=${lib.getOutput "out" opensslPackage}" ] + ++ [ "--with-ssl-incl=${lib.getDev opensslPackage}" ] # This flag was introduced in R24 + ++ optional enableThreads "--enable-threads" + ++ optional enableSmpSupport "--enable-smp-support" + ++ optional enableKernelPoll "--enable-kernel-poll" + ++ optional enableHipe "--enable-hipe" + ++ optional javacSupport "--with-javac" + ++ optional odbcSupport "--with-odbc=${unixODBC}" + ++ optional wxSupport "--enable-wx" + ++ optional systemdSupport "--enable-systemd" + ++ optional stdenv.hostPlatform.isDarwin "--enable-darwin-64bit" + # make[3]: *** [yecc.beam] Segmentation fault: 11 + ++ optional (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) "--disable-jit" + ++ configureFlags; + + # install-docs will generate and install manpages and html docs + # (PDFs are generated only when fop is available). + + postInstall = '' + ln -s $out/lib/erlang/lib/erl_interface*/bin/erl_call $out/bin/erl_call + + ${postInstall} ''; - platforms = platforms.unix; - maintainers = teams.beam.members; - license = licenses.asl20; - } // meta); -} -// optionalAttrs (preUnpack != "") { inherit preUnpack; } -// optionalAttrs (postUnpack != "") { inherit postUnpack; } -// optionalAttrs (patches != [ ]) { inherit patches; } -// optionalAttrs (prePatch != "") { inherit prePatch; } -// optionalAttrs (patchPhase != "") { inherit patchPhase; } -// optionalAttrs (configurePhase != "") { inherit configurePhase; } -// optionalAttrs (preConfigure != "") { inherit preConfigure; } -// optionalAttrs (postConfigure != "") { inherit postConfigure; } -// optionalAttrs (buildPhase != "") { inherit buildPhase; } -// optionalAttrs (preBuild != "") { inherit preBuild; } -// optionalAttrs (postBuild != "") { inherit postBuild; } -// optionalAttrs (checkPhase != "") { inherit checkPhase; } -// optionalAttrs (preCheck != "") { inherit preCheck; } -// optionalAttrs (postCheck != "") { inherit postCheck; } -// optionalAttrs (installPhase != "") { inherit installPhase; } -// optionalAttrs (installTargets != [ ]) { inherit installTargets; } -// optionalAttrs (preInstall != "") { inherit preInstall; } -// optionalAttrs (fixupPhase != "") { inherit fixupPhase; } -// optionalAttrs (preFixup != "") { inherit preFixup; } -// optionalAttrs (postFixup != "") { inherit postFixup; } + # Some erlang bin/ scripts run sed and awk + postFixup = '' + wrapProgram $out/lib/erlang/bin/erl --prefix PATH ":" "${gnused}/bin/" + wrapProgram $out/lib/erlang/bin/start_erl --prefix PATH ":" "${ + lib.makeBinPath [ + gnused + gawk + ] + }" + ''; + + passthru = { + updateScript = + let + major = builtins.head (builtins.splitVersion version); + in + writeScript "update.sh" '' + #!${stdenv.shell} + set -ox errexit + PATH=${ + lib.makeBinPath [ + common-updater-scripts + coreutils + git + gnused + ] + } + latest=$(list-git-tags --url=https://github.com/erlang/otp.git | sed -n 's/^OTP-${major}/${major}/p' | sort -V | tail -1) + if [ "$latest" != "${version}" ]; then + nixpkgs="$(git rev-parse --show-toplevel)" + nix_file="$nixpkgs/pkgs/development/interpreters/erlang/${major}.nix" + update-source-version ${baseName}R${major} "$latest" --version-key=version --print-changes --file="$nix_file" + else + echo "${baseName}R${major} is already up-to-date" + fi + ''; + }; + + meta = + with lib; + ( + { + homepage = "https://www.erlang.org/"; + downloadPage = "https://www.erlang.org/download.html"; + description = "Programming language used for massively scalable soft real-time systems"; + + longDescription = '' + Erlang is a programming language used to build massively scalable + soft real-time systems with requirements on high availability. + Some of its uses are in telecoms, banking, e-commerce, computer + telephony and instant messaging. Erlang's runtime system has + built-in support for concurrency, distribution and fault + tolerance. + ''; + + platforms = platforms.unix; + maintainers = teams.beam.members; + license = licenses.asl20; + } + // meta + ); + } + // optionalAttrs (preUnpack != "") { inherit preUnpack; } + // optionalAttrs (postUnpack != "") { inherit postUnpack; } + // optionalAttrs (patches != [ ]) { inherit patches; } + // optionalAttrs (prePatch != "") { inherit prePatch; } + // optionalAttrs (patchPhase != "") { inherit patchPhase; } + // optionalAttrs (configurePhase != "") { inherit configurePhase; } + // optionalAttrs (preConfigure != "") { inherit preConfigure; } + // optionalAttrs (postConfigure != "") { inherit postConfigure; } + // optionalAttrs (buildPhase != "") { inherit buildPhase; } + // optionalAttrs (preBuild != "") { inherit preBuild; } + // optionalAttrs (postBuild != "") { inherit postBuild; } + // optionalAttrs (checkPhase != "") { inherit checkPhase; } + // optionalAttrs (preCheck != "") { inherit preCheck; } + // optionalAttrs (postCheck != "") { inherit postCheck; } + // optionalAttrs (installPhase != "") { inherit installPhase; } + // optionalAttrs (installTargets != [ ]) { inherit installTargets; } + // optionalAttrs (preInstall != "") { inherit preInstall; } + // optionalAttrs (fixupPhase != "") { inherit fixupPhase; } + // optionalAttrs (preFixup != "") { inherit preFixup; } + // optionalAttrs (postFixup != "") { inherit postFixup; } ) diff --git a/pkgs/development/interpreters/evcxr/default.nix b/pkgs/development/interpreters/evcxr/default.nix index a95e45fc65367f..8625eab28aca61 100644 --- a/pkgs/development/interpreters/evcxr/default.nix +++ b/pkgs/development/interpreters/evcxr/default.nix @@ -1,5 +1,17 @@ -{ cargo, fetchFromGitHub, makeWrapper, pkg-config, rustPlatform, lib, stdenv -, gcc, cmake, libiconv, CoreServices, Security }: +{ + cargo, + fetchFromGitHub, + makeWrapper, + pkg-config, + rustPlatform, + lib, + stdenv, + gcc, + cmake, + libiconv, + CoreServices, + Security, +}: rustPlatform.buildRustPackage rec { pname = "evcxr"; @@ -16,9 +28,16 @@ rustPlatform.buildRustPackage rec { RUST_SRC_PATH = "${rustPlatform.rustLibSrc}"; - nativeBuildInputs = [ pkg-config makeWrapper cmake ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin - [ libiconv CoreServices Security ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + cmake + ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + CoreServices + Security + ]; checkFlags = [ # test broken with rust 1.69: @@ -27,22 +46,32 @@ rustPlatform.buildRustPackage rec { "--skip=check_for_errors" ]; - postInstall = let - wrap = exe: '' - wrapProgram $out/bin/${exe} \ - --prefix PATH : ${lib.makeBinPath [ cargo gcc ]} \ - --set-default RUST_SRC_PATH "$RUST_SRC_PATH" + postInstall = + let + wrap = exe: '' + wrapProgram $out/bin/${exe} \ + --prefix PATH : ${ + lib.makeBinPath [ + cargo + gcc + ] + } \ + --set-default RUST_SRC_PATH "$RUST_SRC_PATH" + ''; + in + '' + ${wrap "evcxr"} + ${wrap "evcxr_jupyter"} + rm $out/bin/testing_runtime ''; - in '' - ${wrap "evcxr"} - ${wrap "evcxr_jupyter"} - rm $out/bin/testing_runtime - ''; meta = with lib; { description = "Evaluation context for Rust"; homepage = "https://github.com/google/evcxr"; license = licenses.asl20; - maintainers = with maintainers; [ protoben ma27 ]; + maintainers = with maintainers; [ + protoben + ma27 + ]; }; } diff --git a/pkgs/development/interpreters/falcon/default.nix b/pkgs/development/interpreters/falcon/default.nix index f7f5a54f415fa2..4acd72081967d2 100644 --- a/pkgs/development/interpreters/falcon/default.nix +++ b/pkgs/development/interpreters/falcon/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, pcre, zlib, sqlite }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + pcre, + zlib, + sqlite, +}: stdenv.mkDerivation { pname = "falcon"; @@ -15,8 +24,15 @@ stdenv.mkDerivation { # causing compilation to fail. env.NIX_CFLAGS_COMPILE = "-Wno-narrowing"; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ pcre zlib sqlite ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + pcre + zlib + sqlite + ]; meta = with lib; { description = "Programming language with macros and syntax at once"; diff --git a/pkgs/development/interpreters/gnudatalanguage/default.nix b/pkgs/development/interpreters/gnudatalanguage/default.nix index d9acb974df88dd..f7570e745d3d6a 100644 --- a/pkgs/development/interpreters/gnudatalanguage/default.nix +++ b/pkgs/development/interpreters/gnudatalanguage/default.nix @@ -1,73 +1,74 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, wrapGAppsHook3 -, readline -, ncurses -, zlib -, gsl -, openmp -, graphicsmagick -, fftw -, fftwFloat -, fftwLongDouble -, proj -, shapelib -, expat -, udunits -, eigen -, pslib -, libpng -, plplot -, libtiff -, libgeotiff -, libjpeg +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + wrapGAppsHook3, + readline, + ncurses, + zlib, + gsl, + openmp, + graphicsmagick, + fftw, + fftwFloat, + fftwLongDouble, + proj, + shapelib, + expat, + udunits, + eigen, + pslib, + libpng, + plplot, + libtiff, + libgeotiff, + libjpeg, # eccodes is broken on darwin -, enableGRIB ? stdenv.hostPlatform.isLinux -, eccodes -, enableGLPK ? stdenv.hostPlatform.isLinux -, glpk + enableGRIB ? stdenv.hostPlatform.isLinux, + eccodes, + enableGLPK ? stdenv.hostPlatform.isLinux, + glpk, # We enable it in hdf4 and use libtirpc as a dependency here from the passthru # of hdf4 -, enableLibtirpc ? stdenv.hostPlatform.isLinux -, libtirpc -, python3 -, enableMPI ? (stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isDarwin) + enableLibtirpc ? stdenv.hostPlatform.isLinux, + libtirpc, + python3, + enableMPI ? (stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isDarwin), # Choose MPICH over OpenMPI because it currently builds on AArch and Darwin -, mpi + mpi, # Unfree optional dependency for hdf4 and hdf5 -, enableSzip ? false -, szip -, enableHDF4 ? true -, hdf4 -, hdf4-forced ? null -, enableHDF5 ? true + enableSzip ? false, + szip, + enableHDF4 ? true, + hdf4, + hdf4-forced ? null, + enableHDF5 ? true, # HDF5 format version (API version) 1.10 and 1.12 is not fully compatible # Specify if the API version should default to 1.10 # netcdf currently depends on hdf5 with `usev110Api=true` # If you wish to use HDF5 API version 1.12 (`useHdf5v110Api=false`), # you will need to turn NetCDF off. -, useHdf5v110Api ? true -, hdf5 -, hdf5-forced ? null -, enableNetCDF ? true -, netcdf -, netcdf-forced ? null -, plplot-forced ? null + useHdf5v110Api ? true, + hdf5, + hdf5-forced ? null, + enableNetCDF ? true, + netcdf, + netcdf-forced ? null, + plplot-forced ? null, # wxWidgets is preferred over X11 for this project but we only have it on Linux # and Darwin. -, enableWX ? (stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isDarwin) -, wxGTK32 -, Cocoa + enableWX ? (stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isDarwin), + wxGTK32, + Cocoa, # X11: OFF by default for platform consistency. Use X where WX is not available -, enableXWin ? (!stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isDarwin) + enableXWin ? (!stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isDarwin), }: let hdf4-custom = - if hdf4-forced != null - then hdf4-forced + if hdf4-forced != null then + hdf4-forced else hdf4.override { uselibtirpc = enableLibtirpc; @@ -75,29 +76,32 @@ let inherit szip; }; hdf5-custom = - if hdf5-forced != null - then hdf5-forced + if hdf5-forced != null then + hdf5-forced else - hdf5.override ({ - usev110Api = useHdf5v110Api; - mpiSupport = enableMPI; - inherit mpi; - szipSupport = enableSzip; - inherit szip; - } // lib.optionalAttrs enableMPI { - cppSupport = false; - }); + hdf5.override ( + { + usev110Api = useHdf5v110Api; + mpiSupport = enableMPI; + inherit mpi; + szipSupport = enableSzip; + inherit szip; + } + // lib.optionalAttrs enableMPI { + cppSupport = false; + } + ); netcdf-custom = - if netcdf-forced != null - then netcdf-forced + if netcdf-forced != null then + netcdf-forced else netcdf.override { hdf5 = hdf5-custom; }; enablePlplotDrivers = enableWX || enableXWin; plplot-with-drivers = - if plplot-forced != null - then plplot-forced + if plplot-forced != null then + plplot-forced else plplot.override { inherit @@ -117,39 +121,41 @@ stdenv.mkDerivation rec { sha256 = "sha256-IrCLL8MQp0SkWj7sbfZlma5FrnMbgdl4E/1nPGy0Y60="; }; - buildInputs = [ - readline - ncurses - zlib - gsl - openmp - graphicsmagick - fftw - fftwFloat - fftwLongDouble - proj - shapelib - expat - mpi - udunits - eigen - pslib - libpng - libtiff - libgeotiff - libjpeg - hdf4-custom - hdf5-custom - netcdf-custom - plplot-with-drivers - ] ++ lib.optional enableXWin plplot-with-drivers.libX11 - ++ lib.optional enableGRIB eccodes - ++ lib.optional enableGLPK glpk - ++ lib.optional enableWX wxGTK32 - ++ lib.optional (enableWX && stdenv.hostPlatform.isDarwin) Cocoa - ++ lib.optional enableMPI mpi - ++ lib.optional enableLibtirpc hdf4-custom.libtirpc - ++ lib.optional enableSzip szip; + buildInputs = + [ + readline + ncurses + zlib + gsl + openmp + graphicsmagick + fftw + fftwFloat + fftwLongDouble + proj + shapelib + expat + mpi + udunits + eigen + pslib + libpng + libtiff + libgeotiff + libjpeg + hdf4-custom + hdf5-custom + netcdf-custom + plplot-with-drivers + ] + ++ lib.optional enableXWin plplot-with-drivers.libX11 + ++ lib.optional enableGRIB eccodes + ++ lib.optional enableGLPK glpk + ++ lib.optional enableWX wxGTK32 + ++ lib.optional (enableWX && stdenv.hostPlatform.isDarwin) Cocoa + ++ lib.optional enableMPI mpi + ++ lib.optional enableLibtirpc hdf4-custom.libtirpc + ++ lib.optional enableSzip szip; propagatedBuildInputs = [ (python3.withPackages (ps: with ps; [ numpy ])) @@ -159,7 +165,8 @@ stdenv.mkDerivation rec { cmake ] ++ lib.optional enableWX wrapGAppsHook3; - cmakeFlags = lib.optional (!enableHDF4) "-DHDF=OFF" + cmakeFlags = + lib.optional (!enableHDF4) "-DHDF=OFF" ++ [ (if enableHDF5 then "-DHDF5DIR=${hdf5-custom}" else "-DHDF5=OFF") ] ++ lib.optional (!enableNetCDF) "-DNETCDF=OFF" ++ lib.optional (!enablePlplotDrivers) "-DINTERACTIVE_GRAPHICS=OFF" @@ -167,8 +174,14 @@ stdenv.mkDerivation rec { ++ lib.optional (!enableGLPK) "-DGLPK=OFF" ++ lib.optional (!enableWX) "-DWXWIDGETS=OFF" ++ lib.optional enableSzip "-DSZIPDIR=${szip}" - ++ lib.optionals enableXWin [ "-DX11=ON" "-DX11DIR=${plplot-with-drivers.libX11}" ] - ++ lib.optionals enableMPI [ "-DMPI=ON" "-DMPIDIR=${mpi}" ]; + ++ lib.optionals enableXWin [ + "-DX11=ON" + "-DX11DIR=${plplot-with-drivers.libX11}" + ] + ++ lib.optionals enableMPI [ + "-DMPI=ON" + "-DMPIDIR=${mpi}" + ]; # Tests are failing on Hydra: # ./src/common/dpycmn.cpp(137): assert ""IsOk()"" failed in GetClientArea(): invalid wxDisplay object @@ -179,13 +192,15 @@ stdenv.mkDerivation rec { # https://github.com/gnudatalanguage/gdl/issues/1079 # https://github.com/gnudatalanguage/gdl/issues/460 preCheck = '' - checkFlagsArray+=("ARGS=-E '${lib.concatMapStringsSep "|" (test: test + ".pro") [ - "test_byte_conversion" - "test_bytscl" - "test_call_external" - "test_tic_toc" - "test_timestamp" - ]}'") + checkFlagsArray+=("ARGS=-E '${ + lib.concatMapStringsSep "|" (test: test + ".pro") [ + "test_byte_conversion" + "test_bytscl" + "test_call_external" + "test_tic_toc" + "test_timestamp" + ] + }'") ''; passthru = { diff --git a/pkgs/development/interpreters/guile/1.8.nix b/pkgs/development/interpreters/guile/1.8.nix index 51ac9ba3ed58f3..d5f0fe3f68002a 100644 --- a/pkgs/development/interpreters/guile/1.8.nix +++ b/pkgs/development/interpreters/guile/1.8.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, buildPackages -, gawk -, gmp -, libtool -, makeWrapper -, pkg-config -, pkgsBuildBuild -, readline +{ + lib, + stdenv, + fetchurl, + buildPackages, + gawk, + gmp, + libtool, + makeWrapper, + pkg-config, + pkgsBuildBuild, + readline, }: stdenv.mkDerivation rec { @@ -20,23 +21,25 @@ stdenv.mkDerivation rec { sha256 = "0l200a0v7h8bh0cwz6v7hc13ds39cgqsmfrks55b1rbj5vniyiy3"; }; - outputs = [ "out" "dev" "info" ]; + outputs = [ + "out" + "dev" + "info" + ]; setOutputFlags = false; # $dev gets into the library otherwise # GCC 4.6 raises a number of set-but-unused warnings. - configureFlags = [ - "--disable-error-on-warning" - ] - # Guile needs patching to preset results for the configure tests about - # pthreads, which work only in native builds. - ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) - "--with-threads=no"; + configureFlags = + [ + "--disable-error-on-warning" + ] + # Guile needs patching to preset results for the configure tests about + # pthreads, which work only in native builds. + ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "--with-threads=no"; depsBuildBuild = [ buildPackages.stdenv.cc - ] - ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) - pkgsBuildBuild.guile_1_8; + ] ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) pkgsBuildBuild.guile_1_8; nativeBuildInputs = [ makeWrapper pkg-config @@ -66,16 +69,17 @@ stdenv.mkDerivation rec { sed -e '/lt_dlinit/a lt_dladdsearchdir("'$out/lib'");' -i libguile/dynl.c ''; - postInstall = '' - wrapProgram $out/bin/guile-snarf --prefix PATH : "${gawk}/bin" - '' - # XXX: See http://thread.gmane.org/gmane.comp.lib.gnulib.bugs/18903 for - # why `--with-libunistring-prefix' and similar options coming from - # `AC_LIB_LINKFLAGS_BODY' don't work on NixOS/x86_64. - + '' - sed -i "$out/lib/pkgconfig/guile"-*.pc \ - -e "s|-lltdl|-L${libtool.lib}/lib -lltdl|g" - ''; + postInstall = + '' + wrapProgram $out/bin/guile-snarf --prefix PATH : "${gawk}/bin" + '' + # XXX: See http://thread.gmane.org/gmane.comp.lib.gnulib.bugs/18903 for + # why `--with-libunistring-prefix' and similar options coming from + # `AC_LIB_LINKFLAGS_BODY' don't work on NixOS/x86_64. + + '' + sed -i "$out/lib/pkgconfig/guile"-*.pc \ + -e "s|-lltdl|-L${libtool.lib}/lib -lltdl|g" + ''; # One test fails. # ERROR: file: "libtest-asmobs", message: "file not found" diff --git a/pkgs/development/interpreters/guile/2.0.nix b/pkgs/development/interpreters/guile/2.0.nix index 510834df4046b3..ad542da6432556 100644 --- a/pkgs/development/interpreters/guile/2.0.nix +++ b/pkgs/development/interpreters/guile/2.0.nix @@ -1,26 +1,25 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, boehmgc -, buildPackages -, coverageAnalysis ? null -, gawk -, gmp -, libffi -, libtool -, libunistring -, makeWrapper -, pkg-config -, pkgsBuildBuild -, readline +{ + lib, + stdenv, + fetchurl, + fetchpatch, + boehmgc, + buildPackages, + coverageAnalysis ? null, + gawk, + gmp, + libffi, + libtool, + libunistring, + makeWrapper, + pkg-config, + pkgsBuildBuild, + readline, }: let # Do either a coverage analysis build or a standard build. - builder = if coverageAnalysis != null - then coverageAnalysis - else stdenv.mkDerivation; + builder = if coverageAnalysis != null then coverageAnalysis else stdenv.mkDerivation; in builder rec { pname = "guile"; @@ -31,14 +30,16 @@ builder rec { sha256 = "12yqkr974y91ylgw6jnmci2v90i90s7h9vxa4zk0sai8vjnz4i1p"; }; - outputs = [ "out" "dev" "info" ]; + outputs = [ + "out" + "dev" + "info" + ]; setOutputFlags = false; # $dev gets into the library otherwise depsBuildBuild = [ buildPackages.stdenv.cc - ] - ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) - pkgsBuildBuild.guile_2_0; + ] ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) pkgsBuildBuild.guile_2_0; nativeBuildInputs = [ makeWrapper @@ -64,66 +65,72 @@ builder rec { enableParallelBuilding = true; - patches = [ - # Small fixes to Clang compiler - ./clang.patch - # Self-explanatory - ./disable-gc-sensitive-tests.patch - # Read the header of the patch to more info - ./eai_system.patch - # RISC-V endianness - ./riscv.patch - # Fixes stability issues with 00-repl-server.test - (fetchpatch { - url = "https://git.savannah.gnu.org/cgit/guile.git/patch/?id=2fbde7f02adb8c6585e9baf6e293ee49cd23d4c4"; - sha256 = "0p6c1lmw1iniq03z7x5m65kg3lq543kgvdb4nrxsaxjqf3zhl77v"; - })] ++ - (lib.optional (coverageAnalysis != null) ./gcov-file-name.patch) - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ./filter-mkostemp-darwin.patch - (fetchpatch { - url = "https://gitlab.gnome.org/GNOME/gtk-osx/raw/52898977f165777ad9ef169f7d4818f2d4c9b731/patches/guile-clocktime.patch"; - sha256 = "12wvwdna9j8795x59ldryv9d84c1j3qdk2iskw09306idfsis207"; - }) - ]; + patches = + [ + # Small fixes to Clang compiler + ./clang.patch + # Self-explanatory + ./disable-gc-sensitive-tests.patch + # Read the header of the patch to more info + ./eai_system.patch + # RISC-V endianness + ./riscv.patch + # Fixes stability issues with 00-repl-server.test + (fetchpatch { + url = "https://git.savannah.gnu.org/cgit/guile.git/patch/?id=2fbde7f02adb8c6585e9baf6e293ee49cd23d4c4"; + sha256 = "0p6c1lmw1iniq03z7x5m65kg3lq543kgvdb4nrxsaxjqf3zhl77v"; + }) + ] + ++ (lib.optional (coverageAnalysis != null) ./gcov-file-name.patch) + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ./filter-mkostemp-darwin.patch + (fetchpatch { + url = "https://gitlab.gnome.org/GNOME/gtk-osx/raw/52898977f165777ad9ef169f7d4818f2d4c9b731/patches/guile-clocktime.patch"; + sha256 = "12wvwdna9j8795x59ldryv9d84c1j3qdk2iskw09306idfsis207"; + }) + ]; # Explicitly link against libgcc_s, to work around the infamous # "libgcc_s.so.1 must be installed for pthread_cancel to work". # don't have "libgcc_s.so.1" on darwin - LDFLAGS = lib.optionalString - (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isMusl) "-lgcc_s"; - - configureFlags = [ - "--with-libreadline-prefix" - ] ++ lib.optionals stdenv.hostPlatform.isSunOS [ - # Make sure the right is found, and not the incompatible - # /usr/include/mp.h from OpenSolaris. See - # - # for details. - "--with-libgmp-prefix=${lib.getDev gmp}" - - # Same for these (?). - "--with-libreadline-prefix=${lib.getDev readline}" - "--with-libunistring-prefix=${libunistring}" - - # See below. - "--without-threads" - ]; - - postInstall = '' - wrapProgram $out/bin/guile-snarf --prefix PATH : "${gawk}/bin" - '' - # XXX: See http://thread.gmane.org/gmane.comp.lib.gnulib.bugs/18903 for - # why `--with-libunistring-prefix' and similar options coming from - # `AC_LIB_LINKFLAGS_BODY' don't work on NixOS/x86_64. - + '' - sed -i "$out/lib/pkgconfig/guile"-*.pc \ - -e "s|-lunistring|-L${libunistring}/lib -lunistring|g ; - s|^Cflags:\(.*\)$|Cflags: -I${libunistring.dev}/include \1|g ; - s|-lltdl|-L${libtool.lib}/lib -lltdl|g ; - s|includedir=$out|includedir=$dev|g - " + LDFLAGS = lib.optionalString ( + !stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isMusl + ) "-lgcc_s"; + + configureFlags = + [ + "--with-libreadline-prefix" + ] + ++ lib.optionals stdenv.hostPlatform.isSunOS [ + # Make sure the right is found, and not the incompatible + # /usr/include/mp.h from OpenSolaris. See + # + # for details. + "--with-libgmp-prefix=${lib.getDev gmp}" + + # Same for these (?). + "--with-libreadline-prefix=${lib.getDev readline}" + "--with-libunistring-prefix=${libunistring}" + + # See below. + "--without-threads" + ]; + + postInstall = + '' + wrapProgram $out/bin/guile-snarf --prefix PATH : "${gawk}/bin" + '' + # XXX: See http://thread.gmane.org/gmane.comp.lib.gnulib.bugs/18903 for + # why `--with-libunistring-prefix' and similar options coming from + # `AC_LIB_LINKFLAGS_BODY' don't work on NixOS/x86_64. + + '' + sed -i "$out/lib/pkgconfig/guile"-*.pc \ + -e "s|-lunistring|-L${libunistring}/lib -lunistring|g ; + s|^Cflags:\(.*\)$|Cflags: -I${libunistring.dev}/include \1|g ; + s|-lltdl|-L${libtool.lib}/lib -lltdl|g ; + s|includedir=$out|includedir=$dev|g + " ''; # make check doesn't work on darwin @@ -143,14 +150,14 @@ builder rec { homepage = "https://www.gnu.org/software/guile/"; description = "Embeddable Scheme implementation"; longDescription = '' - GNU Guile is an implementation of the Scheme programming language, with - support for many SRFIs, packaged for use in a wide variety of - environments. In addition to implementing the R5RS Scheme standard and - a large subset of R6RS, Guile includes a module system, full access to - POSIX system calls, networking support, multiple threads, dynamic - linking, a foreign function call interface, and powerful string - processing. - ''; + GNU Guile is an implementation of the Scheme programming language, with + support for many SRFIs, packaged for use in a wide variety of + environments. In addition to implementing the R5RS Scheme standard and + a large subset of R6RS, Guile includes a module system, full access to + POSIX system calls, networking support, multiple threads, dynamic + linking, a foreign function call interface, and powerful string + processing. + ''; license = licenses.lgpl3Plus; maintainers = with maintainers; [ ludo ]; platforms = platforms.all; @@ -159,8 +166,8 @@ builder rec { // -(lib.optionalAttrs (!stdenv.hostPlatform.isLinux) { - # Work around . - SHELL = stdenv.shell; - CONFIG_SHELL = stdenv.shell; -}) + (lib.optionalAttrs (!stdenv.hostPlatform.isLinux) { + # Work around . + SHELL = stdenv.shell; + CONFIG_SHELL = stdenv.shell; + }) diff --git a/pkgs/development/interpreters/guile/2.2.nix b/pkgs/development/interpreters/guile/2.2.nix index 6c75540dae0c36..deb74210bdb7c0 100644 --- a/pkgs/development/interpreters/guile/2.2.nix +++ b/pkgs/development/interpreters/guile/2.2.nix @@ -1,26 +1,25 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, boehmgc -, buildPackages -, coverageAnalysis ? null -, gawk -, gmp -, libffi -, libtool -, libunistring -, makeWrapper -, pkg-config -, pkgsBuildBuild -, readline +{ + lib, + stdenv, + fetchurl, + fetchpatch, + boehmgc, + buildPackages, + coverageAnalysis ? null, + gawk, + gmp, + libffi, + libtool, + libunistring, + makeWrapper, + pkg-config, + pkgsBuildBuild, + readline, }: let # Do either a coverage analysis build or a standard build. - builder = if coverageAnalysis != null - then coverageAnalysis - else stdenv.mkDerivation; + builder = if coverageAnalysis != null then coverageAnalysis else stdenv.mkDerivation; in builder rec { pname = "guile"; @@ -31,14 +30,16 @@ builder rec { sha256 = "013mydzhfswqci6xmyc1ajzd59pfbdak15i0b090nhr9bzm7dxyd"; }; - outputs = [ "out" "dev" "info" ]; + outputs = [ + "out" + "dev" + "info" + ]; setOutputFlags = false; # $dev gets into the library otherwise depsBuildBuild = [ buildPackages.stdenv.cc - ] - ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) - pkgsBuildBuild.guile_2_2; + ] ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) pkgsBuildBuild.guile_2_2; nativeBuildInputs = [ makeWrapper pkg-config @@ -69,12 +70,13 @@ builder rec { # re: https://build.opensuse.org/request/show/732638 enableParallelBuilding = false; - patches = [ - # Read the header of the patch to more info - ./eai_system.patch - ] ++ lib.optional (coverageAnalysis != null) ./gcov-file-name.patch - ++ lib.optional stdenv.hostPlatform.isDarwin - (fetchpatch { + patches = + [ + # Read the header of the patch to more info + ./eai_system.patch + ] + ++ lib.optional (coverageAnalysis != null) ./gcov-file-name.patch + ++ lib.optional stdenv.hostPlatform.isDarwin (fetchpatch { url = "https://gitlab.gnome.org/GNOME/gtk-osx/raw/52898977f165777ad9ef169f7d4818f2d4c9b731/patches/guile-clocktime.patch"; sha256 = "12wvwdna9j8795x59ldryv9d84c1j3qdk2iskw09306idfsis207"; }); @@ -83,38 +85,40 @@ builder rec { # "libgcc_s.so.1 must be installed for pthread_cancel to work". # don't have "libgcc_s.so.1" on clang - LDFLAGS = lib.optionalString - (stdenv.cc.isGNU && !stdenv.hostPlatform.isStatic) "-lgcc_s"; - - configureFlags = [ - "--with-libreadline-prefix=${lib.getDev readline}" - ] ++ lib.optionals stdenv.hostPlatform.isSunOS [ - # Make sure the right is found, and not the incompatible - # /usr/include/mp.h from OpenSolaris. See - # - # for details. - "--with-libgmp-prefix=${lib.getDev gmp}" - - # Same for these (?). - "--with-libunistring-prefix=${libunistring}" - - # See below. - "--without-threads" - ]; - - postInstall = '' - wrapProgram $out/bin/guile-snarf --prefix PATH : "${gawk}/bin" - '' - # XXX: See http://thread.gmane.org/gmane.comp.lib.gnulib.bugs/18903 for - # why `--with-libunistring-prefix' and similar options coming from - # `AC_LIB_LINKFLAGS_BODY' don't work on NixOS/x86_64. - + '' - sed -i "$out/lib/pkgconfig/guile"-*.pc \ - -e "s|-lunistring|-L${libunistring}/lib -lunistring|g ; - s|^Cflags:\(.*\)$|Cflags: -I${libunistring.dev}/include \1|g ; - s|-lltdl|-L${libtool.lib}/lib -lltdl|g ; - s|includedir=$out|includedir=$dev|g - " + LDFLAGS = lib.optionalString (stdenv.cc.isGNU && !stdenv.hostPlatform.isStatic) "-lgcc_s"; + + configureFlags = + [ + "--with-libreadline-prefix=${lib.getDev readline}" + ] + ++ lib.optionals stdenv.hostPlatform.isSunOS [ + # Make sure the right is found, and not the incompatible + # /usr/include/mp.h from OpenSolaris. See + # + # for details. + "--with-libgmp-prefix=${lib.getDev gmp}" + + # Same for these (?). + "--with-libunistring-prefix=${libunistring}" + + # See below. + "--without-threads" + ]; + + postInstall = + '' + wrapProgram $out/bin/guile-snarf --prefix PATH : "${gawk}/bin" + '' + # XXX: See http://thread.gmane.org/gmane.comp.lib.gnulib.bugs/18903 for + # why `--with-libunistring-prefix' and similar options coming from + # `AC_LIB_LINKFLAGS_BODY' don't work on NixOS/x86_64. + + '' + sed -i "$out/lib/pkgconfig/guile"-*.pc \ + -e "s|-lunistring|-L${libunistring}/lib -lunistring|g ; + s|^Cflags:\(.*\)$|Cflags: -I${libunistring.dev}/include \1|g ; + s|-lltdl|-L${libtool.lib}/lib -lltdl|g ; + s|includedir=$out|includedir=$dev|g + " ''; # make check doesn't work on darwin diff --git a/pkgs/development/interpreters/guile/3.0.nix b/pkgs/development/interpreters/guile/3.0.nix index 1eeda97b0f8bc3..473c05ea8383cd 100644 --- a/pkgs/development/interpreters/guile/3.0.nix +++ b/pkgs/development/interpreters/guile/3.0.nix @@ -1,28 +1,27 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, boehmgc -, buildPackages -, coverageAnalysis ? null -, gawk -, gmp -, libffi -, libtool -, libunistring -, libxcrypt -, makeWrapper -, pkg-config -, pkgsBuildBuild -, readline -, writeScript +{ + lib, + stdenv, + fetchurl, + fetchpatch, + boehmgc, + buildPackages, + coverageAnalysis ? null, + gawk, + gmp, + libffi, + libtool, + libunistring, + libxcrypt, + makeWrapper, + pkg-config, + pkgsBuildBuild, + readline, + writeScript, }: let # Do either a coverage analysis build or a standard build. - builder = if coverageAnalysis != null - then coverageAnalysis - else stdenv.mkDerivation; + builder = if coverageAnalysis != null then coverageAnalysis else stdenv.mkDerivation; in builder rec { pname = "guile"; @@ -33,38 +32,45 @@ builder rec { sha256 = "sha256-vXFoUX/VJjM0RtT3q4FlJ5JWNAlPvTcyLhfiuNjnY4g="; }; - outputs = [ "out" "dev" "info" ]; + outputs = [ + "out" + "dev" + "info" + ]; setOutputFlags = false; # $dev gets into the library otherwise depsBuildBuild = [ buildPackages.stdenv.cc - ] ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) - pkgsBuildBuild.guile_3_0; + ] ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) pkgsBuildBuild.guile_3_0; nativeBuildInputs = [ makeWrapper pkg-config ]; - buildInputs = [ - libffi - libtool - libunistring - readline - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libxcrypt - ]; - propagatedBuildInputs = [ - boehmgc - gmp - - # These ones aren't normally needed here, but `libguile*.la' has '-l' - # flags for them without corresponding '-L' flags. Adding them here will - # add the needed `-L' flags. As for why the `.la' file lacks the `-L' - # flags, see below. - libtool - libunistring - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libxcrypt - ]; + buildInputs = + [ + libffi + libtool + libunistring + readline + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libxcrypt + ]; + propagatedBuildInputs = + [ + boehmgc + gmp + + # These ones aren't normally needed here, but `libguile*.la' has '-l' + # flags for them without corresponding '-L' flags. Adding them here will + # add the needed `-L' flags. As for why the `.la' file lacks the `-L' + # flags, see below. + libtool + libunistring + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libxcrypt + ]; # According to # https://git.savannah.gnu.org/cgit/guix.git/tree/gnu/packages/guile.scm?h=a39207f7afd977e4e4299c6f0bb34bcb6d153818#n405 @@ -72,11 +78,12 @@ builder rec { # bit-reproducibly as long as we're not cross-compiling enableParallelBuilding = stdenv.buildPlatform == stdenv.hostPlatform; - patches = [ - ./eai_system.patch - ] ++ lib.optional (coverageAnalysis != null) ./gcov-file-name.patch - ++ lib.optional stdenv.hostPlatform.isDarwin - (fetchpatch { + patches = + [ + ./eai_system.patch + ] + ++ lib.optional (coverageAnalysis != null) ./gcov-file-name.patch + ++ lib.optional stdenv.hostPlatform.isDarwin (fetchpatch { url = "https://gitlab.gnome.org/GNOME/gtk-osx/raw/52898977f165777ad9ef169f7d4818f2d4c9b731/patches/guile-clocktime.patch"; sha256 = "12wvwdna9j8795x59ldryv9d84c1j3qdk2iskw09306idfsis207"; }); @@ -85,42 +92,44 @@ builder rec { # "libgcc_s.so.1 must be installed for pthread_cancel to work". # don't have "libgcc_s.so.1" on clang - LDFLAGS = lib.optionalString - (stdenv.cc.isGNU && !stdenv.hostPlatform.isStatic) "-lgcc_s"; - - configureFlags = [ - "--with-libreadline-prefix=${lib.getDev readline}" - ] ++ lib.optionals stdenv.hostPlatform.isSunOS [ - # Make sure the right is found, and not the incompatible - # /usr/include/mp.h from OpenSolaris. See - # - # for details. - "--with-libgmp-prefix=${lib.getDev gmp}" - - # Same for these (?). - "--with-libunistring-prefix=${libunistring}" - - # See below. - "--without-threads" - ] - # At least on x86_64-darwin '-flto' autodetection is not correct: - # https://github.com/NixOS/nixpkgs/pull/160051#issuecomment-1046193028 - ++ lib.optional (stdenv.hostPlatform.isDarwin) "--disable-lto"; - - postInstall = '' - wrapProgram $out/bin/guile-snarf --prefix PATH : "${gawk}/bin" - '' - # XXX: See http://thread.gmane.org/gmane.comp.lib.gnulib.bugs/18903 for - # why `--with-libunistring-prefix' and similar options coming from - # `AC_LIB_LINKFLAGS_BODY' don't work on NixOS/x86_64. - + '' - sed -i "$out/lib/pkgconfig/guile"-*.pc \ - -e "s|-lunistring|-L${libunistring}/lib -lunistring|g ; - s|-lltdl|-L${libtool.lib}/lib -lltdl|g ; - s|-lcrypt|-L${libxcrypt}/lib -lcrypt|g ; - s|^Cflags:\(.*\)$|Cflags: -I${libunistring.dev}/include \1|g ; - s|includedir=$out|includedir=$dev|g - " + LDFLAGS = lib.optionalString (stdenv.cc.isGNU && !stdenv.hostPlatform.isStatic) "-lgcc_s"; + + configureFlags = + [ + "--with-libreadline-prefix=${lib.getDev readline}" + ] + ++ lib.optionals stdenv.hostPlatform.isSunOS [ + # Make sure the right is found, and not the incompatible + # /usr/include/mp.h from OpenSolaris. See + # + # for details. + "--with-libgmp-prefix=${lib.getDev gmp}" + + # Same for these (?). + "--with-libunistring-prefix=${libunistring}" + + # See below. + "--without-threads" + ] + # At least on x86_64-darwin '-flto' autodetection is not correct: + # https://github.com/NixOS/nixpkgs/pull/160051#issuecomment-1046193028 + ++ lib.optional (stdenv.hostPlatform.isDarwin) "--disable-lto"; + + postInstall = + '' + wrapProgram $out/bin/guile-snarf --prefix PATH : "${gawk}/bin" + '' + # XXX: See http://thread.gmane.org/gmane.comp.lib.gnulib.bugs/18903 for + # why `--with-libunistring-prefix' and similar options coming from + # `AC_LIB_LINKFLAGS_BODY' don't work on NixOS/x86_64. + + '' + sed -i "$out/lib/pkgconfig/guile"-*.pc \ + -e "s|-lunistring|-L${libunistring}/lib -lunistring|g ; + s|-lltdl|-L${libtool.lib}/lib -lltdl|g ; + s|-lcrypt|-L${libxcrypt}/lib -lcrypt|g ; + s|^Cflags:\(.*\)$|Cflags: -I${libunistring.dev}/include \1|g ; + s|includedir=$out|includedir=$dev|g + " ''; # make check doesn't work on darwin diff --git a/pkgs/development/interpreters/janet/default.nix b/pkgs/development/interpreters/janet/default.nix index 7babe42c9458fd..bdc332731296fc 100644 --- a/pkgs/development/interpreters/janet/default.nix +++ b/pkgs/development/interpreters/janet/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, nix-update-script -, runCommand +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + nix-update-script, + runCommand, }: stdenv.mkDerivation (finalAttrs: { @@ -18,16 +19,21 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-KwuBJY3SG5Ao/sFgjrp0pzEasdI7AAWrG49uHjVA1Rs="; }; - postPatch = '' - substituteInPlace janet.1 \ - --replace /usr/local/ $out/ - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # error: Socket is not connected - substituteInPlace meson.build \ - --replace "'test/suite-ev.janet'," "" - ''; + postPatch = + '' + substituteInPlace janet.1 \ + --replace /usr/local/ $out/ + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # error: Socket is not connected + substituteInPlace meson.build \ + --replace "'test/suite-ev.janet'," "" + ''; - nativeBuildInputs = [ meson ninja ]; + nativeBuildInputs = [ + meson + ninja + ]; mesonBuildType = "release"; mesonFlags = [ "-Dgit_hash=release" ]; @@ -41,18 +47,21 @@ stdenv.mkDerivation (finalAttrs: { ''; passthru = { - tests.run = runCommand "janet-test-run" { - nativeBuildInputs = [finalAttrs.finalPackage]; - } '' - echo "(+ 1 2 3)" | janet | tail -n 1 > arithmeticTest.txt; - diff -U3 --color=auto <(cat arithmeticTest.txt) <(echo "6"); + tests.run = + runCommand "janet-test-run" + { + nativeBuildInputs = [ finalAttrs.finalPackage ]; + } + '' + echo "(+ 1 2 3)" | janet | tail -n 1 > arithmeticTest.txt; + diff -U3 --color=auto <(cat arithmeticTest.txt) <(echo "6"); - echo "(print \"Hello, World!\")" | janet | tail -n 2 > ioTest.txt; - diff -U3 --color=auto <(cat ioTest.txt) <(echo -e "Hello, World!\nnil"); + echo "(print \"Hello, World!\")" | janet | tail -n 2 > ioTest.txt; + diff -U3 --color=auto <(cat ioTest.txt) <(echo -e "Hello, World!\nnil"); - touch $out; - ''; - updateScript = nix-update-script {}; + touch $out; + ''; + updateScript = nix-update-script { }; }; meta = with lib; { @@ -60,7 +69,10 @@ stdenv.mkDerivation (finalAttrs: { mainProgram = "janet"; homepage = "https://janet-lang.org/"; license = licenses.mit; - maintainers = with maintainers; [ andrewchambers peterhoeg ]; + maintainers = with maintainers; [ + andrewchambers + peterhoeg + ]; platforms = platforms.all; }; }) diff --git a/pkgs/development/interpreters/janet/jpm.nix b/pkgs/development/interpreters/janet/jpm.nix index 31ed1e2fc1ff50..2982822bb50871 100644 --- a/pkgs/development/interpreters/janet/jpm.nix +++ b/pkgs/development/interpreters/janet/jpm.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, janet }: +{ + lib, + stdenv, + fetchFromGitHub, + janet, +}: let platformFiles = { diff --git a/pkgs/development/interpreters/jruby/default.nix b/pkgs/development/interpreters/jruby/default.nix index 6a8aca8ddf1222..4a3a28bbb356ee 100644 --- a/pkgs/development/interpreters/jruby/default.nix +++ b/pkgs/development/interpreters/jruby/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, callPackage, fetchurl, gitUpdater, mkRubyVersion, makeBinaryWrapper, jre }: +{ + lib, + stdenv, + callPackage, + fetchurl, + gitUpdater, + mkRubyVersion, + makeBinaryWrapper, + jre, +}: let # The version number here is whatever is reported by the RUBY_VERSION string @@ -61,7 +70,11 @@ stdenv.mkDerivation (finalAttrs: { description = "Ruby interpreter written in Java"; homepage = "https://www.jruby.org/"; changelog = "https://github.com/jruby/jruby/releases/tag/${finalAttrs.version}"; - license = with licenses; [ cpl10 gpl2 lgpl21 ]; + license = with licenses; [ + cpl10 + gpl2 + lgpl21 + ]; platforms = jre.meta.platforms; maintainers = [ maintainers.fzakaria ]; sourceProvenance = with sourceTypes; [ binaryBytecode ]; diff --git a/pkgs/development/interpreters/kerf/default.nix b/pkgs/development/interpreters/kerf/default.nix index e11a683082eda2..6fa17490d539f2 100644 --- a/pkgs/development/interpreters/kerf/default.nix +++ b/pkgs/development/interpreters/kerf/default.nix @@ -1,8 +1,16 @@ -{ lib, stdenv, fetchFromGitHub -, libedit, zlib, ncurses, expect +{ + lib, + stdenv, + fetchFromGitHub, + libedit, + zlib, + ncurses, + expect, -# darwin only below -, Accelerate, CoreGraphics, CoreVideo + # darwin only below + Accelerate, + CoreGraphics, + CoreVideo, }: stdenv.mkDerivation rec { @@ -11,32 +19,49 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "kevinlawler"; - repo = "kerf1"; - rev = "4ec5b592b310b96d33654d20d6a511e6fffc0f9d"; - hash = "sha256-0sU2zOk5I69lQyrn1g0qsae7S/IBT6eA/911qp0GNkk="; + repo = "kerf1"; + rev = "4ec5b592b310b96d33654d20d6a511e6fffc0f9d"; + hash = "sha256-0sU2zOk5I69lQyrn1g0qsae7S/IBT6eA/911qp0GNkk="; }; sourceRoot = "${src.name}/src"; - buildInputs = [ libedit zlib ncurses ] - ++ lib.optionals stdenv.hostPlatform.isDarwin ([ - Accelerate - ] ++ lib.optionals stdenv.hostPlatform.isx86_64 /* && isDarwin */ [ - CoreGraphics CoreVideo - ]); + buildInputs = + [ + libedit + zlib + ncurses + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + [ + Accelerate + ] + ++ + lib.optionals stdenv.hostPlatform.isx86_64 # && isDarwin + [ + CoreGraphics + CoreVideo + ] + ); nativeCheckInputs = [ expect ]; doCheck = true; - makeFlags = [ "kerf" "kerf_test" ]; + makeFlags = [ + "kerf" + "kerf_test" + ]; # avoid a huge amount of warnings to make failures clearer - env.NIX_CFLAGS_COMPILE = toString (map (x: "-Wno-${x}") [ - "void-pointer-to-int-cast" - "format" - "implicit-function-declaration" - "gnu-variable-sized-type-not-at-end" - "unused-result" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ "-fcommon" ]); + env.NIX_CFLAGS_COMPILE = toString ( + map (x: "-Wno-${x}") [ + "void-pointer-to-int-cast" + "format" + "implicit-function-declaration" + "gnu-variable-sized-type-not-at-end" + "unused-result" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ "-fcommon" ] + ); patchPhase = '' substituteInPlace ./Makefile \ diff --git a/pkgs/development/interpreters/lfe/generic-builder.nix b/pkgs/development/interpreters/lfe/generic-builder.nix index 908417f7c70894..a8bf4bc2faaa8e 100644 --- a/pkgs/development/interpreters/lfe/generic-builder.nix +++ b/pkgs/development/interpreters/lfe/generic-builder.nix @@ -1,19 +1,39 @@ -{ lib, fetchFromGitHub, erlang, makeWrapper, coreutils, bash, buildRebar3, buildHex }: - -{ baseName ? "lfe" -, version -, maximumOTPVersion -, sha256 ? "" -, hash ? "" -, rev ? version -, src ? fetchFromGitHub { inherit hash rev sha256; owner = "lfe"; repo = "lfe"; } -, patches ? [] +{ + lib, + fetchFromGitHub, + erlang, + makeWrapper, + coreutils, + bash, + buildRebar3, + buildHex, +}: + +{ + baseName ? "lfe", + version, + maximumOTPVersion, + sha256 ? "", + hash ? "", + rev ? version, + src ? fetchFromGitHub { + inherit hash rev sha256; + owner = "lfe"; + repo = "lfe"; + }, + patches ? [ ], }: let inherit (lib) - assertMsg makeBinPath optionalString - getVersion versionAtLeast versionOlder versions; + assertMsg + makeBinPath + optionalString + getVersion + versionAtLeast + versionOlder + versions + ; mainVersion = versions.major (getVersion erlang); @@ -21,7 +41,7 @@ let name = "proper"; version = "1.4.0"; - sha256 = "sha256-GChYQhhb0z772pfRNKXLWgiEOE2zYRn+4OPPpIhWjLs="; + sha256 = "sha256-GChYQhhb0z772pfRNKXLWgiEOE2zYRn+4OPPpIhWjLs="; }; in @@ -34,13 +54,23 @@ buildRebar3 { inherit src version; - nativeBuildInputs = [ makeWrapper erlang ]; - beamDeps = [ proper ]; - patches = [ ./fix-rebar-config.patch ./dedup-ebins.patch ] ++ patches; - doCheck = true; + nativeBuildInputs = [ + makeWrapper + erlang + ]; + beamDeps = [ proper ]; + patches = [ + ./fix-rebar-config.patch + ./dedup-ebins.patch + ] ++ patches; + doCheck = true; checkTarget = "travis"; - makeFlags = [ "-e" "MANDB=''" "PREFIX=$$out"]; + makeFlags = [ + "-e" + "MANDB=''" + "PREFIX=$$out" + ]; # These installPhase tricks are based on Elixir's Makefile. # TODO: Make, upload, and apply a patch. @@ -67,24 +97,30 @@ buildRebar3 { # Add some stuff to PATH so the scripts can run without problems. for f in $out/bin/*; do wrapProgram $f \ - --prefix PATH ":" "${makeBinPath [ erlang coreutils bash ]}:$out/bin" + --prefix PATH ":" "${ + makeBinPath [ + erlang + coreutils + bash + ] + }:$out/bin" substituteInPlace $f --replace "/usr/bin/env" "${coreutils}/bin/env" done ''; meta = with lib; { - description = "Best of Erlang and of Lisp; at the same time!"; + description = "Best of Erlang and of Lisp; at the same time!"; longDescription = '' LFE, Lisp Flavoured Erlang, is a lisp syntax front-end to the Erlang compiler. Code produced with it is compatible with "normal" Erlang code. An LFE evaluator and shell is also included. ''; - homepage = "https://lfe.io"; + homepage = "https://lfe.io"; downloadPage = "https://github.com/rvirding/lfe/releases"; - license = licenses.asl20; - maintainers = teams.beam.members; - platforms = platforms.unix; + license = licenses.asl20; + maintainers = teams.beam.members; + platforms = platforms.unix; }; } diff --git a/pkgs/development/interpreters/love/0.10.nix b/pkgs/development/interpreters/love/0.10.nix index 3443cb0c3cf562..2120ac516a3fa5 100644 --- a/pkgs/development/interpreters/love/0.10.nix +++ b/pkgs/development/interpreters/love/0.10.nix @@ -1,7 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config -, SDL2, libGLU, libGL, openal, luajit -, libdevil, freetype, physfs, libmodplug, mpg123, libvorbis, libogg -, libtheora, which, autoconf, automake, libtool +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + SDL2, + libGLU, + libGL, + openal, + luajit, + libdevil, + freetype, + physfs, + libmodplug, + mpg123, + libvorbis, + libogg, + libtheora, + which, + autoconf, + automake, + libtool, }: stdenv.mkDerivation rec { @@ -15,10 +33,27 @@ stdenv.mkDerivation rec { sha256 = "19yfmlcx6w8yi4ndm5lni8lrsvnn77bxw5py0dc293nzzlaqa9ym"; }; - nativeBuildInputs = [ pkg-config autoconf automake ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; buildInputs = [ - SDL2 libGLU libGL openal luajit libdevil freetype physfs libmodplug mpg123 - libvorbis libogg libtheora which libtool + SDL2 + libGLU + libGL + openal + luajit + libdevil + freetype + physfs + libmodplug + mpg123 + libvorbis + libogg + libtheora + which + libtool ]; preConfigure = "$shell ./platform/unix/automagic"; diff --git a/pkgs/development/interpreters/love/11.nix b/pkgs/development/interpreters/love/11.nix index 0f98906a542b94..785db5e9939caf 100644 --- a/pkgs/development/interpreters/love/11.nix +++ b/pkgs/development/interpreters/love/11.nix @@ -1,7 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config -, SDL2, libGLU, libGL, openal, luajit -, libdevil, freetype, physfs, libmodplug, mpg123, libvorbis, libogg -, libtheora, which, autoconf, automake, libtool +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + SDL2, + libGLU, + libGL, + openal, + luajit, + libdevil, + freetype, + physfs, + libmodplug, + mpg123, + libvorbis, + libogg, + libtheora, + which, + autoconf, + automake, + libtool, }: stdenv.mkDerivation rec { @@ -15,10 +33,27 @@ stdenv.mkDerivation rec { sha256 = "sha256-wZktNh4UB3QH2wAIIlnYUlNoXbjEDwUmPnT4vesZNm0="; }; - nativeBuildInputs = [ pkg-config autoconf automake ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + ]; buildInputs = [ - SDL2 libGLU libGL openal luajit libdevil freetype physfs libmodplug mpg123 - libvorbis libogg libtheora which libtool + SDL2 + libGLU + libGL + openal + luajit + libdevil + freetype + physfs + libmodplug + mpg123 + libvorbis + libogg + libtheora + which + libtool ]; preConfigure = "$shell ./platform/unix/automagic"; diff --git a/pkgs/development/interpreters/lua-5/build-luarocks-package.nix b/pkgs/development/interpreters/lua-5/build-luarocks-package.nix index 263cd11dd57266..71ad7bbb0989db 100644 --- a/pkgs/development/interpreters/lua-5/build-luarocks-package.nix +++ b/pkgs/development/interpreters/lua-5/build-luarocks-package.nix @@ -1,69 +1,71 @@ # Generic builder for lua packages -{ lib -, lua -, wrapLua -, luarocks_bootstrap -, writeTextFile - -# Whether the derivation provides a lua module or not. -, luarocksCheckHook -, luaLib +{ + lib, + lua, + wrapLua, + luarocks_bootstrap, + writeTextFile, + + # Whether the derivation provides a lua module or not. + luarocksCheckHook, + luaLib, }: -{ pname -, version -# we need rockspecVersion to find the .rockspec even when version changes -, rockspecVersion ? version +{ + pname, + version, + # we need rockspecVersion to find the .rockspec even when version changes + rockspecVersion ? version, -# by default prefix `name` e.g. "lua5.2-${name}" -, namePrefix ? "${lua.pname}${lib.versions.majorMinor lua.version}-" + # by default prefix `name` e.g. "lua5.2-${name}" + namePrefix ? "${lua.pname}${lib.versions.majorMinor lua.version}-", -# Dependencies for building the package -, buildInputs ? [] + # Dependencies for building the package + buildInputs ? [ ], -# Dependencies needed for running the checkPhase. -# These are added to nativeBuildInputs when doCheck = true. -, nativeCheckInputs ? [] + # Dependencies needed for running the checkPhase. + # These are added to nativeBuildInputs when doCheck = true. + nativeCheckInputs ? [ ], -# propagate build dependencies so in case we have A -> B -> C, -# C can import package A propagated by B -, propagatedBuildInputs ? [] + # propagate build dependencies so in case we have A -> B -> C, + # C can import package A propagated by B + propagatedBuildInputs ? [ ], -# used to disable derivation, useful for specific lua versions -# TODO move from this setting meta.broken to a 'disabled' attribute on the -# package, then use that to skip/include in each lua${ver}Packages set? -, disabled ? false + # used to disable derivation, useful for specific lua versions + # TODO move from this setting meta.broken to a 'disabled' attribute on the + # package, then use that to skip/include in each lua${ver}Packages set? + disabled ? false, -# Additional arguments to pass to the makeWrapper function, which wraps -# generated binaries. -, makeWrapperArgs ? [] + # Additional arguments to pass to the makeWrapper function, which wraps + # generated binaries. + makeWrapperArgs ? [ ], -# Skip wrapping of lua programs altogether -, dontWrapLuaPrograms ? false -, doCheck ? false -# Non-Lua / system (e.g. C library) dependencies. Is a list of deps, where -# each dep is either a derivation, or an attribute set like -# { name = "rockspec external_dependencies key"; dep = derivation; } -# The latter is used to work-around luarocks having a problem with -# multiple-output derivations as external deps: -# https://github.com/luarocks/luarocks/issues/766 -, externalDeps ? [] + # Skip wrapping of lua programs altogether + dontWrapLuaPrograms ? false, + doCheck ? false, + # Non-Lua / system (e.g. C library) dependencies. Is a list of deps, where + # each dep is either a derivation, or an attribute set like + # { name = "rockspec external_dependencies key"; dep = derivation; } + # The latter is used to work-around luarocks having a problem with + # multiple-output derivations as external deps: + # https://github.com/luarocks/luarocks/issues/766 + externalDeps ? [ ], -# Appended to the generated luarocks config -, extraConfig ? "" + # Appended to the generated luarocks config + extraConfig ? "", -# transparent mapping nix <-> lua used as LUAROCKS_CONFIG -# Refer to https://github.com/luarocks/luarocks/wiki/Config-file-format for specs -, luarocksConfig ? {} + # transparent mapping nix <-> lua used as LUAROCKS_CONFIG + # Refer to https://github.com/luarocks/luarocks/wiki/Config-file-format for specs + luarocksConfig ? { }, -# relative to srcRoot, path to the rockspec to use when using rocks -, rockspecFilename ? null + # relative to srcRoot, path to the rockspec to use when using rocks + rockspecFilename ? null, -# must be set for packages that don't have a rock -, knownRockspec ? null - -, ... } @ attrs: + # must be set for packages that don't have a rock + knownRockspec ? null, + ... +}@attrs: # Keep extra attributes from `attrs`, e.g., `patchPhase', etc. @@ -76,160 +78,181 @@ let # configured trees) luarocks_config = "luarocks-config.lua"; - luarocksDrv = luaLib.toLuaModule ( lua.stdenv.mkDerivation (self: attrs // { - - name = namePrefix + self.pname + "-" + self.version; - inherit rockspecVersion; - - __structuredAttrs = true; - env = { - LUAROCKS_CONFIG = self.configFile; - } // attrs.env or {}; - - generatedRockspecFilename = "./${self.pname}-${self.rockspecVersion}.rockspec"; - - nativeBuildInputs = [ - lua # for lua.h - wrapLua - luarocks_bootstrap - ]; - - inherit doCheck extraConfig rockspecFilename knownRockspec externalDeps nativeCheckInputs; - - buildInputs = let - # example externalDeps': [ { name = "CRYPTO"; dep = pkgs.openssl; } ] - externalDeps' = lib.filter (dep: !lib.isDerivation dep) self.externalDeps; - in [ luarocks_bootstrap ] - ++ buildInputs - ++ lib.optionals self.doCheck ([ luarocksCheckHook ] ++ self.nativeCheckInputs) - ++ (map (d: d.dep) externalDeps') - ; - - # propagate lua to active setup-hook in nix-shell - propagatedBuildInputs = propagatedBuildInputs ++ [ lua ]; - - # @-patterns do not capture formal argument default values, so we need to - # explicitly inherit this for it to be available as a shell variable in the - # builder - rocksSubdir = "${self.pname}-${self.version}-rocks"; - - configFile = writeTextFile { - name = self.pname + "-luarocks-config.lua"; - text = self.luarocks_content; - }; - - luarocks_content = - (lib.generators.toLua { asBindings = true; } self.luarocksConfig) + - '' - - ${self.extraConfig} - ''; - - # TODO make it the default variable - luarocksConfig = let - externalDepsGenerated = lib.filter (drv: !drv ? luaModule) - (self.nativeBuildInputs ++ self.propagatedBuildInputs ++ self.buildInputs); - - generatedConfig = luaLib.generateLuarocksConfig { - externalDeps = lib.unique (self.externalDeps ++ externalDepsGenerated); - local_cache = ""; - - # To prevent collisions when creating environments, we install the rock - # files into per-package subdirectories - rocks_subdir = self.rocksSubdir; - - # Filter out the lua derivation itself from the Lua module dependency - # closure, as it doesn't have a rock tree :) - # luaLib.hasLuaModule - requiredLuaRocks = lib.filter luaLib.hasLuaModule - (lua.pkgs.requiredLuaModules (self.nativeBuildInputs ++ self.propagatedBuildInputs)); - }; - - luarocksConfig' = lib.recursiveUpdate luarocksConfig - (lib.optionalAttrs (attrs ? extraVariables) (lib.warn "extraVariables in buildLuarocksPackage is deprecated, use luarocksConfig instead" - { - variables = attrs.extraVariables; - })) - ; - in lib.recursiveUpdate generatedConfig luarocksConfig'; - - - configurePhase = '' - runHook preConfigure - '' - + lib.optionalString (self.rockspecFilename == null) '' - rockspecFilename="${self.generatedRockspecFilename}" - '' - + lib.optionalString (self.knownRockspec != null) '' - # prevents the following type of error: - # Inconsistency between rockspec filename (42fm1b3d7iv6fcbhgm9674as3jh6y2sh-luv-1.22.0-1.rockspec) and its contents (luv-1.22.0-1.rockspec) - rockspecFilename="$TMP/$(stripHash ${self.knownRockspec})" - cp ${self.knownRockspec} "$rockspecFilename" - '' - + '' - runHook postConfigure - ''; - - buildPhase = '' - runHook preBuild - - source ${lua}/nix-support/utils.sh - nix_debug "Using LUAROCKS_CONFIG=$LUAROCKS_CONFIG" - - LUAROCKS_EXTRA_ARGS="" - if (( ''${NIX_DEBUG:-0} >= 1 )); then - LUAROCKS_EXTRA_ARGS=" --verbose" - fi - - runHook postBuild - ''; - - postFixup = lib.optionalString (!dontWrapLuaPrograms) '' - wrapLuaPrograms - '' + attrs.postFixup or ""; - - installPhase = '' - runHook preInstall - - # work around failing luarocks test for Write access - mkdir -p $out - - # luarocks make assumes sources are available in cwd - # After the build is complete, it also installs the rock. - # If no argument is given, it looks for a rockspec in the current directory - # but some packages have several rockspecs in their source directory so - # we force the use of the upper level since it is - # the sole rockspec in that folder - # maybe we could reestablish dependency checking via passing --rock-trees - - nix_debug "ROCKSPEC $rockspecFilename" - luarocks $LUAROCKS_EXTRA_ARGS make --deps-mode=all --tree=$out ''${rockspecFilename} - - runHook postInstall - ''; - - checkPhase = '' - runHook preCheck - luarocks test - runHook postCheck - ''; - - shellHook = '' - runHook preShell - export LUAROCKS_CONFIG="$PWD/${luarocks_config}"; - runHook postShell - ''; - - passthru = { - inherit lua; - } // attrs.passthru or { }; - - meta = { - platforms = lua.meta.platforms; - # add extra maintainer(s) to every package - maintainers = (attrs.meta.maintainers or []) ++ [ ]; - broken = disabled; - } // attrs.meta or {}; -})); + luarocksDrv = luaLib.toLuaModule ( + lua.stdenv.mkDerivation ( + self: + attrs + // { + + name = namePrefix + self.pname + "-" + self.version; + inherit rockspecVersion; + + __structuredAttrs = true; + env = { + LUAROCKS_CONFIG = self.configFile; + } // attrs.env or { }; + + generatedRockspecFilename = "./${self.pname}-${self.rockspecVersion}.rockspec"; + + nativeBuildInputs = [ + lua # for lua.h + wrapLua + luarocks_bootstrap + ]; + + inherit + doCheck + extraConfig + rockspecFilename + knownRockspec + externalDeps + nativeCheckInputs + ; + + buildInputs = + let + # example externalDeps': [ { name = "CRYPTO"; dep = pkgs.openssl; } ] + externalDeps' = lib.filter (dep: !lib.isDerivation dep) self.externalDeps; + in + [ luarocks_bootstrap ] + ++ buildInputs + ++ lib.optionals self.doCheck ([ luarocksCheckHook ] ++ self.nativeCheckInputs) + ++ (map (d: d.dep) externalDeps'); + + # propagate lua to active setup-hook in nix-shell + propagatedBuildInputs = propagatedBuildInputs ++ [ lua ]; + + # @-patterns do not capture formal argument default values, so we need to + # explicitly inherit this for it to be available as a shell variable in the + # builder + rocksSubdir = "${self.pname}-${self.version}-rocks"; + + configFile = writeTextFile { + name = self.pname + "-luarocks-config.lua"; + text = self.luarocks_content; + }; + + luarocks_content = + (lib.generators.toLua { asBindings = true; } self.luarocksConfig) + + '' + + ${self.extraConfig} + ''; + + # TODO make it the default variable + luarocksConfig = + let + externalDepsGenerated = lib.filter (drv: !drv ? luaModule) ( + self.nativeBuildInputs ++ self.propagatedBuildInputs ++ self.buildInputs + ); + + generatedConfig = luaLib.generateLuarocksConfig { + externalDeps = lib.unique (self.externalDeps ++ externalDepsGenerated); + local_cache = ""; + + # To prevent collisions when creating environments, we install the rock + # files into per-package subdirectories + rocks_subdir = self.rocksSubdir; + + # Filter out the lua derivation itself from the Lua module dependency + # closure, as it doesn't have a rock tree :) + # luaLib.hasLuaModule + requiredLuaRocks = lib.filter luaLib.hasLuaModule ( + lua.pkgs.requiredLuaModules (self.nativeBuildInputs ++ self.propagatedBuildInputs) + ); + }; + + luarocksConfig' = lib.recursiveUpdate luarocksConfig ( + lib.optionalAttrs (attrs ? extraVariables) ( + lib.warn "extraVariables in buildLuarocksPackage is deprecated, use luarocksConfig instead" { + variables = attrs.extraVariables; + } + ) + ); + in + lib.recursiveUpdate generatedConfig luarocksConfig'; + + configurePhase = + '' + runHook preConfigure + '' + + lib.optionalString (self.rockspecFilename == null) '' + rockspecFilename="${self.generatedRockspecFilename}" + '' + + lib.optionalString (self.knownRockspec != null) '' + # prevents the following type of error: + # Inconsistency between rockspec filename (42fm1b3d7iv6fcbhgm9674as3jh6y2sh-luv-1.22.0-1.rockspec) and its contents (luv-1.22.0-1.rockspec) + rockspecFilename="$TMP/$(stripHash ${self.knownRockspec})" + cp ${self.knownRockspec} "$rockspecFilename" + '' + + '' + runHook postConfigure + ''; + + buildPhase = '' + runHook preBuild + + source ${lua}/nix-support/utils.sh + nix_debug "Using LUAROCKS_CONFIG=$LUAROCKS_CONFIG" + + LUAROCKS_EXTRA_ARGS="" + if (( ''${NIX_DEBUG:-0} >= 1 )); then + LUAROCKS_EXTRA_ARGS=" --verbose" + fi + + runHook postBuild + ''; + + postFixup = + lib.optionalString (!dontWrapLuaPrograms) '' + wrapLuaPrograms + '' + + attrs.postFixup or ""; + + installPhase = '' + runHook preInstall + + # work around failing luarocks test for Write access + mkdir -p $out + + # luarocks make assumes sources are available in cwd + # After the build is complete, it also installs the rock. + # If no argument is given, it looks for a rockspec in the current directory + # but some packages have several rockspecs in their source directory so + # we force the use of the upper level since it is + # the sole rockspec in that folder + # maybe we could reestablish dependency checking via passing --rock-trees + + nix_debug "ROCKSPEC $rockspecFilename" + luarocks $LUAROCKS_EXTRA_ARGS make --deps-mode=all --tree=$out ''${rockspecFilename} + + runHook postInstall + ''; + + checkPhase = '' + runHook preCheck + luarocks test + runHook postCheck + ''; + + shellHook = '' + runHook preShell + export LUAROCKS_CONFIG="$PWD/${luarocks_config}"; + runHook postShell + ''; + + passthru = { + inherit lua; + } // attrs.passthru or { }; + + meta = { + platforms = lua.meta.platforms; + # add extra maintainer(s) to every package + maintainers = (attrs.meta.maintainers or [ ]) ++ [ ]; + broken = disabled; + } // attrs.meta or { }; + } + ) + ); in - luarocksDrv +luarocksDrv diff --git a/pkgs/development/interpreters/lua-5/default.nix b/pkgs/development/interpreters/lua-5/default.nix index 30ce00d44e61ac..8e6b68f27a60f3 100644 --- a/pkgs/development/interpreters/lua-5/default.nix +++ b/pkgs/development/interpreters/lua-5/default.nix @@ -1,80 +1,119 @@ # similar to interpreters/python/default.nix -{ stdenv, config, lib, callPackage, fetchFromGitHub, fetchurl, makeBinaryWrapper }: - +{ + stdenv, + config, + lib, + callPackage, + fetchFromGitHub, + fetchurl, + makeBinaryWrapper, +}: let # Common passthru for all lua interpreters. # copied from python passthruFun = - { executable - , luaversion - , packageOverrides - , luaOnBuildForBuild - , luaOnBuildForHost - , luaOnBuildForTarget - , luaOnHostForHost - , luaOnTargetForTarget - , luaAttr ? null - , self # is luaOnHostForTarget - }: let - luaPackages = callPackage - # Function that when called - # - imports lua-packages.nix - # - adds spliced package sets to the package set - # - applies overrides from `packageOverrides` - ({ lua, overrides, callPackage, makeScopeWithSplicing' }: let - luaPackagesFun = callPackage ../../../top-level/lua-packages.nix { + { + executable, + luaversion, + packageOverrides, + luaOnBuildForBuild, + luaOnBuildForHost, + luaOnBuildForTarget, + luaOnHostForHost, + luaOnTargetForTarget, + luaAttr ? null, + self, # is luaOnHostForTarget + }: + let + luaPackages = + callPackage + # Function that when called + # - imports lua-packages.nix + # - adds spliced package sets to the package set + # - applies overrides from `packageOverrides` + ( + { + lua, + overrides, + callPackage, + makeScopeWithSplicing', + }: + let + luaPackagesFun = callPackage ../../../top-level/lua-packages.nix { + lua = self; + }; + generatedPackages = + if (builtins.pathExists ../../lua-modules/generated-packages.nix) then + ( + final: prev: + callPackage ../../lua-modules/generated-packages.nix { inherit (final) callPackage; } final prev + ) + else + (final: prev: { }); + overriddenPackages = callPackage ../../lua-modules/overrides.nix { }; + + otherSplices = { + selfBuildBuild = luaOnBuildForBuild.pkgs; + selfBuildHost = luaOnBuildForHost.pkgs; + selfBuildTarget = luaOnBuildForTarget.pkgs; + selfHostHost = luaOnHostForHost.pkgs; + selfTargetTarget = luaOnTargetForTarget.pkgs or { }; + }; + + aliases = + final: prev: + lib.optionalAttrs config.allowAliases (import ../../lua-modules/aliases.nix lib final prev); + + extensions = lib.composeManyExtensions [ + aliases + generatedPackages + overriddenPackages + overrides + ]; + in + makeScopeWithSplicing' { + inherit otherSplices; + f = lib.extends extensions luaPackagesFun; + } + ) + { + overrides = packageOverrides; lua = self; }; - generatedPackages = if (builtins.pathExists ../../lua-modules/generated-packages.nix) then - (final: prev: callPackage ../../lua-modules/generated-packages.nix { inherit (final) callPackage; } final prev) - else (final: prev: {}); - overriddenPackages = callPackage ../../lua-modules/overrides.nix { }; - - otherSplices = { - selfBuildBuild = luaOnBuildForBuild.pkgs; - selfBuildHost = luaOnBuildForHost.pkgs; - selfBuildTarget = luaOnBuildForTarget.pkgs; - selfHostHost = luaOnHostForHost.pkgs; - selfTargetTarget = luaOnTargetForTarget.pkgs or {}; + in + rec { + buildEnv = callPackage ./wrapper.nix { + lua = self; + makeWrapper = makeBinaryWrapper; + inherit (luaPackages) requiredLuaModules; + }; + withPackages = import ./with-packages.nix { inherit buildEnv luaPackages; }; + pkgs = + let + lp = luaPackages; + in + lp + // { + luaPackages = lp.luaPackages // { + __attrsFailEvaluation = true; }; - - aliases = final: prev: - lib.optionalAttrs config.allowAliases - (import ../../lua-modules/aliases.nix lib final prev); - - extensions = lib.composeManyExtensions [ - aliases - generatedPackages - overriddenPackages - overrides - ]; - in makeScopeWithSplicing' { - inherit otherSplices; - f = lib.extends extensions luaPackagesFun; - }) - { - overrides = packageOverrides; - lua = self; - }; - in rec { - buildEnv = callPackage ./wrapper.nix { - lua = self; - makeWrapper = makeBinaryWrapper; - inherit (luaPackages) requiredLuaModules; }; - withPackages = import ./with-packages.nix { inherit buildEnv luaPackages;}; - pkgs = let lp = luaPackages; - in lp // { luaPackages = lp.luaPackages // { __attrsFailEvaluation = true; }; }; - interpreter = "${self}/bin/${executable}"; - inherit executable luaversion; - luaOnBuild = luaOnBuildForHost.override { inherit packageOverrides; self = luaOnBuild; }; + interpreter = "${self}/bin/${executable}"; + inherit executable luaversion; + luaOnBuild = luaOnBuildForHost.override { + inherit packageOverrides; + self = luaOnBuild; + }; - tests = callPackage ./tests { lua = self; inherit (luaPackages) wrapLua; }; + tests = callPackage ./tests { + lua = self; + inherit (luaPackages) wrapLua; + }; - inherit luaAttr; - }; + inherit luaAttr; + }; in @@ -89,7 +128,7 @@ rec { patches = lib.optional stdenv.hostPlatform.isDarwin ./5.4.darwin.patch; }; - lua5_4_compat = lua5_4.override({ + lua5_4_compat = lua5_4.override ({ self = lua5_4_compat; compat = true; }); @@ -101,16 +140,14 @@ rec { makeWrapper = makeBinaryWrapper; inherit passthruFun; - patches = - lib.optionals stdenv.hostPlatform.isDarwin [ ./5.2.darwin.patch ]; + patches = lib.optionals stdenv.hostPlatform.isDarwin [ ./5.2.darwin.patch ]; }; - lua5_3_compat = lua5_3.override({ + lua5_3_compat = lua5_3.override ({ self = lua5_3_compat; compat = true; }); - lua5_2 = callPackage ./interpreter.nix { self = lua5_2; version = "5.2.4"; @@ -122,25 +159,30 @@ rec { ] ++ lib.optional stdenv.hostPlatform.isDarwin ./5.2.darwin.patch; }; - lua5_2_compat = lua5_2.override({ + lua5_2_compat = lua5_2.override ({ self = lua5_2_compat; compat = true; }); - lua5_1 = callPackage ./interpreter.nix { self = lua5_1; version = "5.1.5"; hash = "2640fc56a795f29d28ef15e13c34a47e223960b0240e8cb0a82d9b0738695333"; makeWrapper = makeBinaryWrapper; inherit passthruFun; - patches = (lib.optional stdenv.hostPlatform.isDarwin ./5.1.darwin.patch) - ++ [ ./CVE-2014-5461.patch ]; + patches = (lib.optional stdenv.hostPlatform.isDarwin ./5.1.darwin.patch) ++ [ + ./CVE-2014-5461.patch + ]; }; luajit_2_0 = import ../luajit/2.0.nix { self = luajit_2_0; - inherit callPackage fetchFromGitHub lib passthruFun; + inherit + callPackage + fetchFromGitHub + lib + passthruFun + ; }; luajit_2_1 = import ../luajit/2.1.nix { diff --git a/pkgs/development/interpreters/lua-5/hooks/default.nix b/pkgs/development/interpreters/lua-5/hooks/default.nix index 5f935626fec453..cdc44e344d6287 100644 --- a/pkgs/development/interpreters/lua-5/hooks/default.nix +++ b/pkgs/development/interpreters/lua-5/hooks/default.nix @@ -1,25 +1,31 @@ # Hooks for building lua packages. -{ lua -, lib -, makeSetupHook -, runCommand +{ + lua, + lib, + makeSetupHook, + runCommand, }: let callPackage = lua.pkgs.callPackage; -in { +in +{ - luarocksCheckHook = callPackage ({ luarocks }: + luarocksCheckHook = callPackage ( + { luarocks }: makeSetupHook { name = "luarocks-check-hook"; propagatedBuildInputs = [ luarocks ]; - } ./luarocks-check-hook.sh) {}; + } ./luarocks-check-hook.sh + ) { }; # luarocks installs data in a non-overridable location. Until a proper luarocks patch, # we move the files around ourselves - luarocksMoveDataFolder = callPackage ({ }: + luarocksMoveDataFolder = callPackage ( + { }: makeSetupHook { name = "luarocks-move-rock"; propagatedBuildInputs = [ ]; - } ./luarocks-move-data.sh) {}; + } ./luarocks-move-data.sh + ) { }; } diff --git a/pkgs/development/interpreters/lua-5/interpreter.nix b/pkgs/development/interpreters/lua-5/interpreter.nix index 082fa879e2f7d7..54435308d1c186 100644 --- a/pkgs/development/interpreters/lua-5/interpreter.nix +++ b/pkgs/development/interpreters/lua-5/interpreter.nix @@ -1,176 +1,233 @@ -{ lib, stdenv, fetchurl, readline -, compat ? false -, makeWrapper -, self -, packageOverrides ? (final: prev: {}) -, substituteAll -, pkgsBuildBuild -, pkgsBuildHost -, pkgsBuildTarget -, pkgsHostHost -, pkgsTargetTarget -, version -, hash -, passthruFun -, patches ? [] -, postConfigure ? null -, postBuild ? null -, staticOnly ? stdenv.hostPlatform.isStatic -, luaAttr ? "lua${lib.versions.major version}_${lib.versions.minor version}" -} @ inputs: - -stdenv.mkDerivation (finalAttrs: +{ + lib, + stdenv, + fetchurl, + readline, + compat ? false, + makeWrapper, + self, + packageOverrides ? (final: prev: { }), + substituteAll, + pkgsBuildBuild, + pkgsBuildHost, + pkgsBuildTarget, + pkgsHostHost, + pkgsTargetTarget, + version, + hash, + passthruFun, + patches ? [ ], + postConfigure ? null, + postBuild ? null, + staticOnly ? stdenv.hostPlatform.isStatic, + luaAttr ? "lua${lib.versions.major version}_${lib.versions.minor version}", +}@inputs: + +stdenv.mkDerivation ( + finalAttrs: let luaPackages = self.pkgs; luaversion = lib.versions.majorMinor finalAttrs.version; - plat = if (stdenv.hostPlatform.isLinux && lib.versionOlder self.luaversion "5.4") then "linux" - else if (stdenv.hostPlatform.isLinux && lib.versionAtLeast self.luaversion "5.4") then "linux-readline" - else if stdenv.hostPlatform.isDarwin then "macosx" - else if stdenv.hostPlatform.isMinGW then "mingw" - else if stdenv.hostPlatform.isFreeBSD then "freebsd" - else if stdenv.hostPlatform.isSunOS then "solaris" - else if stdenv.hostPlatform.isBSD then "bsd" - else if stdenv.hostPlatform.isUnix then "posix" - else "generic"; - - compatFlags = if (lib.versionOlder self.luaversion "5.3") then " -DLUA_COMPAT_ALL" - else if (lib.versionOlder self.luaversion "5.4") then " -DLUA_COMPAT_5_1 -DLUA_COMPAT_5_2" - else " -DLUA_COMPAT_5_3"; + plat = + if (stdenv.hostPlatform.isLinux && lib.versionOlder self.luaversion "5.4") then + "linux" + else if (stdenv.hostPlatform.isLinux && lib.versionAtLeast self.luaversion "5.4") then + "linux-readline" + else if stdenv.hostPlatform.isDarwin then + "macosx" + else if stdenv.hostPlatform.isMinGW then + "mingw" + else if stdenv.hostPlatform.isFreeBSD then + "freebsd" + else if stdenv.hostPlatform.isSunOS then + "solaris" + else if stdenv.hostPlatform.isBSD then + "bsd" + else if stdenv.hostPlatform.isUnix then + "posix" + else + "generic"; + + compatFlags = + if (lib.versionOlder self.luaversion "5.3") then + " -DLUA_COMPAT_ALL" + else if (lib.versionOlder self.luaversion "5.4") then + " -DLUA_COMPAT_5_1 -DLUA_COMPAT_5_2" + else + " -DLUA_COMPAT_5_3"; in { - pname = "lua"; - inherit version; - outputs = [ "out" "doc" ]; - - src = fetchurl { - url = "https://www.lua.org/ftp/lua-${finalAttrs.version}.tar.gz"; - sha256 = hash; - }; - - LuaPathSearchPaths = luaPackages.luaLib.luaPathList; - LuaCPathSearchPaths = luaPackages.luaLib.luaCPathList; - setupHook = builtins.toFile "lua-setup-hook" '' + pname = "lua"; + inherit version; + outputs = [ + "out" + "doc" + ]; + + src = fetchurl { + url = "https://www.lua.org/ftp/lua-${finalAttrs.version}.tar.gz"; + sha256 = hash; + }; + + LuaPathSearchPaths = luaPackages.luaLib.luaPathList; + LuaCPathSearchPaths = luaPackages.luaLib.luaCPathList; + setupHook = builtins.toFile "lua-setup-hook" '' source @out@/nix-support/utils.sh addEnvHooks "$hostOffset" luaEnvHook + ''; + + nativeBuildInputs = [ makeWrapper ]; + buildInputs = [ readline ]; + + inherit patches; + + postPatch = + '' + sed -i "s@#define LUA_ROOT[[:space:]]*\"/usr/local/\"@#define LUA_ROOT \"$out/\"@g" src/luaconf.h + + # abort if patching didn't work + grep $out src/luaconf.h + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin && !staticOnly) '' + # Add a target for a shared library to the Makefile. + sed -e '1s/^/LUA_SO = liblua.so/' \ + -e 's/ALL_T *= */&$(LUA_SO) /' \ + -i src/Makefile + cat ${./lua-dso.make} >> src/Makefile ''; - nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ readline ]; - - inherit patches; - - postPatch = '' - sed -i "s@#define LUA_ROOT[[:space:]]*\"/usr/local/\"@#define LUA_ROOT \"$out/\"@g" src/luaconf.h - - # abort if patching didn't work - grep $out src/luaconf.h - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin && !staticOnly) '' - # Add a target for a shared library to the Makefile. - sed -e '1s/^/LUA_SO = liblua.so/' \ - -e 's/ALL_T *= */&$(LUA_SO) /' \ - -i src/Makefile - cat ${./lua-dso.make} >> src/Makefile - '' ; - - # see configurePhase for additional flags (with space) - makeFlags = [ - "INSTALL_TOP=${placeholder "out"}" - "INSTALL_MAN=${placeholder "out"}/share/man/man1" - "R=${version}" - "LDFLAGS=-fPIC" - "V=${luaversion}" - "PLAT=${plat}" - "CC=${stdenv.cc.targetPrefix}cc" - "RANLIB=${stdenv.cc.targetPrefix}ranlib" - # Lua links with readline wich depends on ncurses. For some reason when - # building pkgsStatic.lua it fails because symbols from ncurses are not - # found. Adding ncurses here fixes the problem. - "MYLIBS=-lncurses" - ]; - - configurePhase = '' - runHook preConfigure - - makeFlagsArray+=(CFLAGS='-O2 -fPIC${lib.optionalString compat compatFlags} $(${ - if lib.versionAtLeast luaversion "5.2" then "SYSCFLAGS" else "MYCFLAGS"})' ) - makeFlagsArray+=(${lib.optionalString stdenv.hostPlatform.isDarwin "CC=\"$CC\""}${lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) " 'AR=${stdenv.cc.targetPrefix}ar rcu'"}) - - installFlagsArray=( TO_BIN="lua luac" INSTALL_DATA='cp -d' \ - TO_LIB="${if stdenv.hostPlatform.isDarwin then "liblua.${finalAttrs.version}.dylib" - else ("liblua.a" + lib.optionalString (!staticOnly) " liblua.so liblua.so.${luaversion} liblua.so.${finalAttrs.version}" )}" ) - - runHook postConfigure - ''; - inherit postConfigure; - - inherit postBuild; - - postInstall = '' - mkdir -p "$out/nix-support" "$out/share/doc/lua" "$out/lib/pkgconfig" - cp ${substituteAll { - src = ./utils.sh; - luapathsearchpaths=lib.escapeShellArgs finalAttrs.LuaPathSearchPaths; - luacpathsearchpaths=lib.escapeShellArgs finalAttrs.LuaCPathSearchPaths; - }} $out/nix-support/utils.sh - mv "doc/"*.{gif,png,css,html} "$out/share/doc/lua/" - rmdir $out/{share,lib}/lua/${luaversion} $out/{share,lib}/lua - mkdir -p "$out/lib/pkgconfig" - - cat >"$out/lib/pkgconfig/lua.pc" <"$out/lib/pkgconfig/lua.pc" < require('http.request') # stdin:1: module 'http.request' not found: - checkSetupHook = pkgs.runCommandLocal "test-${lua.name}-setup-hook" ({ - nativeBuildInputs = [lua]; - buildInputs = [ lua.pkgs.http ]; - meta.platforms = lua.meta.platforms; - }) ('' - ${lua}/bin/lua -e "require'http.request'" - touch $out - ''); - - checkRelativeImports = pkgs.runCommandLocal "test-${lua.name}-relative-imports" ({ - }) ('' - source ${./assert.sh} - - lua_vanilla_package_path="$(${lua}/bin/lua -e "print(package.path)")" - lua_with_module_package_path="$(${luaWithModule}/bin/lua -e "print(package.path)")" - - assertStringContains "$lua_vanilla_package_path" "./?.lua" - assertStringContains "$lua_vanilla_package_path" "./?/init.lua" - - assertStringContains "$lua_with_module_package_path" "./?.lua" - assertStringContains "$lua_with_module_package_path" "./?/init.lua" - - touch $out - ''); - - - /* - Check that a lua package's propagatedBuildInputs end up in LUA_PATH - */ - checkPropagatedBuildInputs = pkgs.runCommandLocal "test-${lua.name}-setup-hook" ({ - # lua-curl is a propagatedBuildInput of rest-nvim has - buildInputs = [ lua.pkgs.rest-nvim ]; - }) ('' - ${lua}/bin/lua -e "require'cURL'" - touch $out - ''); + checkSetupHook = + pkgs.runCommandLocal "test-${lua.name}-setup-hook" + ({ + nativeBuildInputs = [ lua ]; + buildInputs = [ lua.pkgs.http ]; + meta.platforms = lua.meta.platforms; + }) + ('' + ${lua}/bin/lua -e "require'http.request'" + touch $out + ''); + + checkRelativeImports = + pkgs.runCommandLocal "test-${lua.name}-relative-imports" + ({ + }) + ('' + source ${./assert.sh} + + lua_vanilla_package_path="$(${lua}/bin/lua -e "print(package.path)")" + lua_with_module_package_path="$(${luaWithModule}/bin/lua -e "print(package.path)")" + + assertStringContains "$lua_vanilla_package_path" "./?.lua" + assertStringContains "$lua_vanilla_package_path" "./?/init.lua" + + assertStringContains "$lua_with_module_package_path" "./?.lua" + assertStringContains "$lua_with_module_package_path" "./?/init.lua" + + touch $out + ''); + + # Check that a lua package's propagatedBuildInputs end up in LUA_PATH + checkPropagatedBuildInputs = + pkgs.runCommandLocal "test-${lua.name}-setup-hook" + ({ + # lua-curl is a propagatedBuildInput of rest-nvim has + buildInputs = [ lua.pkgs.rest-nvim ]; + }) + ('' + ${lua}/bin/lua -e "require'cURL'" + touch $out + ''); }) diff --git a/pkgs/development/interpreters/lua-5/with-packages.nix b/pkgs/development/interpreters/lua-5/with-packages.nix index 0e0fbd3973583c..79633b3559bf5b 100644 --- a/pkgs/development/interpreters/lua-5/with-packages.nix +++ b/pkgs/development/interpreters/lua-5/with-packages.nix @@ -1,4 +1,8 @@ { buildEnv, luaPackages }: # this is a function that returns a function that returns an environment -f: let packages = f luaPackages; in buildEnv.override { extraLibs = packages; } +f: +let + packages = f luaPackages; +in +buildEnv.override { extraLibs = packages; } diff --git a/pkgs/development/interpreters/lua-5/wrap-lua.nix b/pkgs/development/interpreters/lua-5/wrap-lua.nix index 1b9409ff948e7d..1f074b04425dc6 100644 --- a/pkgs/development/interpreters/lua-5/wrap-lua.nix +++ b/pkgs/development/interpreters/lua-5/wrap-lua.nix @@ -1,6 +1,7 @@ -{ lua -, makeSetupHook -, makeWrapper +{ + lua, + makeSetupHook, + makeWrapper, }: # defined in trivial-builders diff --git a/pkgs/development/interpreters/lua-5/wrapper.nix b/pkgs/development/interpreters/lua-5/wrapper.nix index 6eb94b60360bb4..02e4a4e6405566 100644 --- a/pkgs/development/interpreters/lua-5/wrapper.nix +++ b/pkgs/development/interpreters/lua-5/wrapper.nix @@ -1,78 +1,88 @@ -{ lib, stdenv, lua, buildEnv, makeWrapper -, extraLibs ? [] -, extraOutputsToInstall ? [] -, postBuild ? "" -, ignoreCollisions ? false -, requiredLuaModules -, makeWrapperArgs ? [] +{ + lib, + stdenv, + lua, + buildEnv, + makeWrapper, + extraLibs ? [ ], + extraOutputsToInstall ? [ ], + postBuild ? "", + ignoreCollisions ? false, + requiredLuaModules, + makeWrapperArgs ? [ ], }: # Create a lua executable that knows about additional packages. let - env = let - paths = [ lua ] ++ requiredLuaModules extraLibs; - in buildEnv { - name = "${lua.name}-env"; + env = + let + paths = [ lua ] ++ requiredLuaModules extraLibs; + in + buildEnv { + name = "${lua.name}-env"; - inherit paths; - inherit ignoreCollisions; - extraOutputsToInstall = [ "out" ] ++ extraOutputsToInstall; + inherit paths; + inherit ignoreCollisions; + extraOutputsToInstall = [ "out" ] ++ extraOutputsToInstall; - nativeBuildInputs = [ - makeWrapper - ]; + nativeBuildInputs = [ + makeWrapper + ]; - # we create wrapper for the binaries in the different packages - postBuild = '' - source ${lua}/nix-support/utils.sh - if [ -L "$out/bin" ]; then - unlink "$out/bin" - fi - mkdir -p "$out/bin" + # we create wrapper for the binaries in the different packages + postBuild = + '' + source ${lua}/nix-support/utils.sh + if [ -L "$out/bin" ]; then + unlink "$out/bin" + fi + mkdir -p "$out/bin" - buildLuaPath "$out" + buildLuaPath "$out" - # take every binary from lua packages and put them into the env - for path in ${lib.concatStringsSep " " paths}; do - nix_debug "looking for binaries in path = $path" - if [ -d "$path/bin" ]; then - cd "$path/bin" - for prg in *; do - if [ -f "$prg" ]; then - rm -f "$out/bin/$prg" - if [ -x "$prg" ]; then - nix_debug "Making wrapper $prg" - makeWrapper "$path/bin/$prg" "$out/bin/$prg" \ - --set-default LUA_PATH ";;" \ - --suffix LUA_PATH ';' "$LUA_PATH" \ - --set-default LUA_CPATH ";;" \ - --suffix LUA_CPATH ';' "$LUA_CPATH" \ - ${lib.concatStringsSep " " makeWrapperArgs} - fi + # take every binary from lua packages and put them into the env + for path in ${lib.concatStringsSep " " paths}; do + nix_debug "looking for binaries in path = $path" + if [ -d "$path/bin" ]; then + cd "$path/bin" + for prg in *; do + if [ -f "$prg" ]; then + rm -f "$out/bin/$prg" + if [ -x "$prg" ]; then + nix_debug "Making wrapper $prg" + makeWrapper "$path/bin/$prg" "$out/bin/$prg" \ + --set-default LUA_PATH ";;" \ + --suffix LUA_PATH ';' "$LUA_PATH" \ + --set-default LUA_CPATH ";;" \ + --suffix LUA_CPATH ';' "$LUA_CPATH" \ + ${lib.concatStringsSep " " makeWrapperArgs} + fi + fi + done fi done - fi - done - '' + postBuild; + '' + + postBuild; - inherit (lua) meta; + inherit (lua) meta; - passthru = lua.passthru // { - interpreter = "${env}/bin/lua"; - inherit lua; - luaPath = lua.pkgs.luaLib.genLuaPathAbsStr env; - luaCpath = lua.pkgs.luaLib.genLuaCPathAbsStr env; - env = stdenv.mkDerivation { - name = "interactive-${lua.name}-environment"; - nativeBuildInputs = [ env ]; + passthru = lua.passthru // { + interpreter = "${env}/bin/lua"; + inherit lua; + luaPath = lua.pkgs.luaLib.genLuaPathAbsStr env; + luaCpath = lua.pkgs.luaLib.genLuaCPathAbsStr env; + env = stdenv.mkDerivation { + name = "interactive-${lua.name}-environment"; + nativeBuildInputs = [ env ]; - buildCommand = '' - echo >&2 "" - echo >&2 "*** lua 'env' attributes are intended for interactive nix-shell sessions, not for building! ***" - echo >&2 "" - exit 1 - ''; + buildCommand = '' + echo >&2 "" + echo >&2 "*** lua 'env' attributes are intended for interactive nix-shell sessions, not for building! ***" + echo >&2 "" + exit 1 + ''; + }; + }; }; - }; - }; -in env +in +env diff --git a/pkgs/development/interpreters/luajit/2.0.nix b/pkgs/development/interpreters/luajit/2.0.nix index c70b6809d1df9f..0b52ff61119118 100644 --- a/pkgs/development/interpreters/luajit/2.0.nix +++ b/pkgs/development/interpreters/luajit/2.0.nix @@ -1,4 +1,10 @@ -{ self, callPackage, fetchFromGitHub, lib, passthruFun }: +{ + self, + callPackage, + fetchFromGitHub, + lib, + passthruFun, +}: callPackage ./default.nix { # The patch version is the timestamp of the git commit, @@ -14,8 +20,9 @@ callPackage ./default.nix { extraMeta = { # this isn't precise but it at least stops the useless Hydra build - platforms = lib.filter (p: !lib.hasPrefix "aarch64-" p) - (lib.platforms.linux ++ lib.platforms.darwin); + platforms = lib.filter (p: !lib.hasPrefix "aarch64-" p) ( + lib.platforms.linux ++ lib.platforms.darwin + ); }; inherit self passthruFun; } diff --git a/pkgs/development/interpreters/luajit/2.1.nix b/pkgs/development/interpreters/luajit/2.1.nix index 90d7769e1d57dd..c151512edd1a90 100644 --- a/pkgs/development/interpreters/luajit/2.1.nix +++ b/pkgs/development/interpreters/luajit/2.1.nix @@ -1,4 +1,9 @@ -{ self, callPackage, fetchFromGitHub, passthruFun }: +{ + self, + callPackage, + fetchFromGitHub, + passthruFun, +}: callPackage ./default.nix { # The patch version is the timestamp of the git commit, diff --git a/pkgs/development/interpreters/luajit/default.nix b/pkgs/development/interpreters/luajit/default.nix index 22574dd2b389c5..147884c59f0126 100644 --- a/pkgs/development/interpreters/luajit/default.nix +++ b/pkgs/development/interpreters/luajit/default.nix @@ -1,38 +1,39 @@ -{ lib -, stdenv -, buildPackages -, version -, src -, substituteAll -, extraMeta ? { } -, self -, packageOverrides ? (final: prev: {}) -, pkgsBuildBuild -, pkgsBuildHost -, pkgsBuildTarget -, pkgsHostHost -, pkgsTargetTarget -, passthruFun -, enableFFI ? true -, enableJIT ? true -, enableJITDebugModule ? enableJIT -, enableGC64 ? true -, enable52Compat ? false -, enableValgrindSupport ? false -, valgrind ? null -, enableGDBJITSupport ? false -, enableAPICheck ? false -, enableVMAssertions ? false -, enableRegisterAllocationRandomization ? false -, useSystemMalloc ? false -# Upstream generates randomized string id's by default for security reasons -# https://github.com/LuaJIT/LuaJIT/issues/626. Deterministic string id's should -# never be needed for correctness (that should be fixed in the lua code), -# but may be helpful when you want to embed jit-compiled raw lua blobs in -# binaries that you want to be reproducible. -, deterministicStringIds ? false -, luaAttr ? "luajit_${lib.versions.major version}_${lib.versions.minor version}" -} @ inputs: +{ + lib, + stdenv, + buildPackages, + version, + src, + substituteAll, + extraMeta ? { }, + self, + packageOverrides ? (final: prev: { }), + pkgsBuildBuild, + pkgsBuildHost, + pkgsBuildTarget, + pkgsHostHost, + pkgsTargetTarget, + passthruFun, + enableFFI ? true, + enableJIT ? true, + enableJITDebugModule ? enableJIT, + enableGC64 ? true, + enable52Compat ? false, + enableValgrindSupport ? false, + valgrind ? null, + enableGDBJITSupport ? false, + enableAPICheck ? false, + enableVMAssertions ? false, + enableRegisterAllocationRandomization ? false, + useSystemMalloc ? false, + # Upstream generates randomized string id's by default for security reasons + # https://github.com/LuaJIT/LuaJIT/issues/626. Deterministic string id's should + # never be needed for correctness (that should be fixed in the lua code), + # but may be helpful when you want to embed jit-compiled raw lua blobs in + # binaries that you want to be reproducible. + deterministicStringIds ? false, + luaAttr ? "luajit_${lib.versions.major version}_${lib.versions.minor version}", +}@inputs: assert enableJITDebugModule -> enableJIT; assert enableGDBJITSupport -> enableJIT; assert enableValgrindSupport -> valgrind != null; @@ -51,16 +52,17 @@ let ++ lib.optional enableAPICheck "-DLUAJIT_USE_APICHECK" ++ lib.optional enableVMAssertions "-DLUAJIT_USE_ASSERT" ++ lib.optional enableRegisterAllocationRandomization "-DLUAJIT_RANDOM_RA" - ++ lib.optional deterministicStringIds "-DLUAJIT_SECURITY_STRID=0" - ; + ++ lib.optional deterministicStringIds "-DLUAJIT_SECURITY_STRID=0"; # LuaJIT requires build for 32bit architectures to be build on x86 not x86_64 # TODO support also other build architectures. The ideal way would be to use # stdenv_32bit but that doesn't work due to host platform mismatch: # https://github.com/NixOS/nixpkgs/issues/212494 - buildStdenv = if buildPackages.stdenv.hostPlatform.isx86_64 && stdenv.hostPlatform.is32bit - then buildPackages.pkgsi686Linux.buildPackages.stdenv - else buildPackages.stdenv; + buildStdenv = + if buildPackages.stdenv.hostPlatform.isx86_64 && stdenv.hostPlatform.is32bit then + buildPackages.pkgsi686Linux.buildPackages.stdenv + else + buildPackages.stdenv; in stdenv.mkDerivation (finalAttrs: { @@ -85,23 +87,27 @@ stdenv.mkDerivation (finalAttrs: { buildFlags = [ "amalg" # Build highly optimized version ]; - makeFlags = [ - "PREFIX=$(out)" - "DEFAULT_CC=cc" - "CROSS=${stdenv.cc.targetPrefix}" - "HOST_CC=${buildStdenv.cc}/bin/cc" - ] ++ lib.optional enableJITDebugModule "INSTALL_LJLIBD=$(INSTALL_LMOD)" + makeFlags = + [ + "PREFIX=$(out)" + "DEFAULT_CC=cc" + "CROSS=${stdenv.cc.targetPrefix}" + "HOST_CC=${buildStdenv.cc}/bin/cc" + ] + ++ lib.optional enableJITDebugModule "INSTALL_LJLIBD=$(INSTALL_LMOD)" ++ lib.optional stdenv.hostPlatform.isStatic "BUILDMODE=static"; enableParallelBuilding = true; env.NIX_CFLAGS_COMPILE = toString XCFLAGS; postInstall = '' mkdir -p $out/nix-support - cp ${substituteAll { - src = ../lua-5/utils.sh; - luapathsearchpaths=lib.escapeShellArgs finalAttrs.LuaPathSearchPaths; - luacpathsearchpaths=lib.escapeShellArgs finalAttrs.LuaCPathSearchPaths; - }} $out/nix-support/utils.sh + cp ${ + substituteAll { + src = ../lua-5/utils.sh; + luapathsearchpaths = lib.escapeShellArgs finalAttrs.LuaPathSearchPaths; + luacpathsearchpaths = lib.escapeShellArgs finalAttrs.LuaCPathSearchPaths; + } + } $out/nix-support/utils.sh ( cd "$out/include"; ln -s luajit-*/* . ) ln -s "$out"/bin/luajit-* "$out"/bin/lua if [[ ! -e "$out"/bin/luajit ]]; then @@ -109,39 +115,57 @@ stdenv.mkDerivation (finalAttrs: { fi ''; - LuaPathSearchPaths = luaPackages.luaLib.luaPathList; - LuaCPathSearchPaths = luaPackages.luaLib.luaCPathList; + LuaPathSearchPaths = luaPackages.luaLib.luaPathList; + LuaCPathSearchPaths = luaPackages.luaLib.luaCPathList; setupHook = builtins.toFile "lua-setup-hook" '' - source @out@/nix-support/utils.sh - addEnvHooks "$hostOffset" luaEnvHook - ''; + source @out@/nix-support/utils.sh + addEnvHooks "$hostOffset" luaEnvHook + ''; # copied from python - passthru = let - # When we override the interpreter we also need to override the spliced versions of the interpreter - inputs' = lib.filterAttrs (n: v: ! lib.isDerivation v && n != "passthruFun") inputs; - override = attr: let lua = attr.override (inputs' // { self = lua; }); in lua; - in passthruFun rec { - inherit self packageOverrides luaAttr; - inherit (finalAttrs) luaversion; - executable = "lua"; - luaOnBuildForBuild = override pkgsBuildBuild.${luaAttr}; - luaOnBuildForHost = override pkgsBuildHost.${luaAttr}; - luaOnBuildForTarget = override pkgsBuildTarget.${luaAttr}; - luaOnHostForHost = override pkgsHostHost.${luaAttr}; - luaOnTargetForTarget = lib.optionalAttrs (lib.hasAttr luaAttr pkgsTargetTarget) (override pkgsTargetTarget.${luaAttr}); - }; + passthru = + let + # When we override the interpreter we also need to override the spliced versions of the interpreter + inputs' = lib.filterAttrs (n: v: !lib.isDerivation v && n != "passthruFun") inputs; + override = + attr: + let + lua = attr.override (inputs' // { self = lua; }); + in + lua; + in + passthruFun rec { + inherit self packageOverrides luaAttr; + inherit (finalAttrs) luaversion; + executable = "lua"; + luaOnBuildForBuild = override pkgsBuildBuild.${luaAttr}; + luaOnBuildForHost = override pkgsBuildHost.${luaAttr}; + luaOnBuildForTarget = override pkgsBuildTarget.${luaAttr}; + luaOnHostForHost = override pkgsHostHost.${luaAttr}; + luaOnTargetForTarget = lib.optionalAttrs (lib.hasAttr luaAttr pkgsTargetTarget) ( + override pkgsTargetTarget.${luaAttr} + ); + }; - meta = with lib; { - description = "High-performance JIT compiler for Lua 5.1"; - homepage = "https://luajit.org/"; - license = licenses.mit; - platforms = platforms.linux ++ platforms.darwin; - badPlatforms = [ - "riscv64-linux" "riscv64-linux" # See https://github.com/LuaJIT/LuaJIT/issues/628 - "powerpc64le-linux" # `#error "No support for PPC64"` - ]; - maintainers = with maintainers; [ thoughtpolice smironov vcunat lblasc ]; - } // extraMeta; + meta = + with lib; + { + description = "High-performance JIT compiler for Lua 5.1"; + homepage = "https://luajit.org/"; + license = licenses.mit; + platforms = platforms.linux ++ platforms.darwin; + badPlatforms = [ + "riscv64-linux" + "riscv64-linux" # See https://github.com/LuaJIT/LuaJIT/issues/628 + "powerpc64le-linux" # `#error "No support for PPC64"` + ]; + maintainers = with maintainers; [ + thoughtpolice + smironov + vcunat + lblasc + ]; + } + // extraMeta; }) diff --git a/pkgs/development/interpreters/luajit/openresty.nix b/pkgs/development/interpreters/luajit/openresty.nix index 372d9233bf1fca..5a1397ec3da155 100644 --- a/pkgs/development/interpreters/luajit/openresty.nix +++ b/pkgs/development/interpreters/luajit/openresty.nix @@ -1,4 +1,9 @@ -{ self, callPackage, fetchFromGitHub, passthruFun }: +{ + self, + callPackage, + fetchFromGitHub, + passthruFun, +}: callPackage ./default.nix rec { version = "2.1-20220915"; diff --git a/pkgs/development/interpreters/octave/build-octave-package.nix b/pkgs/development/interpreters/octave/build-octave-package.nix index 30f9bc3b5e1cec..43760c6c511e32 100644 --- a/pkgs/development/interpreters/octave/build-octave-package.nix +++ b/pkgs/development/interpreters/octave/build-octave-package.nix @@ -4,52 +4,55 @@ # additional configuration provided, and the namePrefix to use (based on the # pname and version of Octave), the octave package, etc. -{ lib -, stdenv -, config -, octave -, texinfo -, computeRequiredOctavePackages -, writeRequiredOctavePackagesHook +{ + lib, + stdenv, + config, + octave, + texinfo, + computeRequiredOctavePackages, + writeRequiredOctavePackagesHook, }: # The inner function contains information required to build the individual # libraries. -{ fullLibName ? "${attrs.pname}-${attrs.version}" +{ + fullLibName ? "${attrs.pname}-${attrs.version}", -, src + src, -, dontPatch ? false -, patches ? [] -, patchPhase ? "" + dontPatch ? false, + patches ? [ ], + patchPhase ? "", -, enableParallelBuilding ? true -# Build-time dependencies for the package, which were compiled for the system compiling this. -, nativeBuildInputs ? [] + enableParallelBuilding ? true, + # Build-time dependencies for the package, which were compiled for the system compiling this. + nativeBuildInputs ? [ ], -# Build-time dependencies for the package, which may not have been compiled for the system compiling this. -, buildInputs ? [] + # Build-time dependencies for the package, which may not have been compiled for the system compiling this. + buildInputs ? [ ], -# Propagate build dependencies so in case we have A -> B -> C, -# C can import package A propagated by B -# Run-time dependencies for the package. -, propagatedBuildInputs ? [] + # Propagate build dependencies so in case we have A -> B -> C, + # C can import package A propagated by B + # Run-time dependencies for the package. + propagatedBuildInputs ? [ ], -# Octave packages that are required at runtime for this one. -# These behave similarly to propagatedBuildInputs, where if -# package A is needed by B, and C needs B, then C also requires A. -# The main difference between these and propagatedBuildInputs is -# during the package's installation into octave, where all -# requiredOctavePackages are ALSO installed into octave. -, requiredOctavePackages ? [] + # Octave packages that are required at runtime for this one. + # These behave similarly to propagatedBuildInputs, where if + # package A is needed by B, and C needs B, then C also requires A. + # The main difference between these and propagatedBuildInputs is + # during the package's installation into octave, where all + # requiredOctavePackages are ALSO installed into octave. + requiredOctavePackages ? [ ], -, preBuild ? "" + preBuild ? "", -, meta ? {} + meta ? { }, -, passthru ? {} + passthru ? { }, -, ... } @ attrs: + ... +}@attrs: let requiredOctavePackages' = computeRequiredOctavePackages requiredOctavePackages; @@ -59,16 +62,14 @@ let nativeBuildInputs' = [ octave writeRequiredOctavePackagesHook - ] - ++ nativeBuildInputs; + ] ++ nativeBuildInputs; passthru' = { updateScript = [ ../../../../maintainers/scripts/update-octave-packages (builtins.unsafeGetAttrPos "pname" octave.pkgs.${attrs.pname}).file ]; - } - // passthru; + } // passthru; # This step is required because when # a = { test = [ "a" "b" ]; }; b = { test = [ "c" "d" ]; }; @@ -76,60 +77,68 @@ let # This used to mean that if a package defined extra nativeBuildInputs, it # would override the ones for building an Octave package (the hook and Octave # itself, causing everything to fail. - attrs' = builtins.removeAttrs attrs [ "nativeBuildInputs" "passthru" ]; + attrs' = builtins.removeAttrs attrs [ + "nativeBuildInputs" + "passthru" + ]; -in stdenv.mkDerivation ({ - packageName = "${fullLibName}"; - # The name of the octave package ends up being - # "octave-version-package-version" - name = "${octave.pname}-${octave.version}-${fullLibName}"; +in +stdenv.mkDerivation ( + { + packageName = "${fullLibName}"; + # The name of the octave package ends up being + # "octave-version-package-version" + name = "${octave.pname}-${octave.version}-${fullLibName}"; - # This states that any package built with the function that this returns - # will be an octave package. This is used for ensuring other octave - # packages are installed into octave during the environment building phase. - isOctavePackage = true; + # This states that any package built with the function that this returns + # will be an octave package. This is used for ensuring other octave + # packages are installed into octave during the environment building phase. + isOctavePackage = true; - OCTAVE_HISTFILE = "/dev/null"; + OCTAVE_HISTFILE = "/dev/null"; - inherit src; + inherit src; - inherit dontPatch patches patchPhase; + inherit dontPatch patches patchPhase; - dontConfigure = true; + dontConfigure = true; - enableParallelBuilding = enableParallelBuilding; + enableParallelBuilding = enableParallelBuilding; - requiredOctavePackages = requiredOctavePackages'; + requiredOctavePackages = requiredOctavePackages'; - nativeBuildInputs = nativeBuildInputs'; + nativeBuildInputs = nativeBuildInputs'; - buildInputs = buildInputs ++ requiredOctavePackages'; + buildInputs = buildInputs ++ requiredOctavePackages'; - propagatedBuildInputs = propagatedBuildInputs ++ [ texinfo ]; + propagatedBuildInputs = propagatedBuildInputs ++ [ texinfo ]; - preBuild = if preBuild == "" then - '' - # This trickery is needed because Octave expects a single directory inside - # at the top-most level of the tarball. - tar --transform 's,^,${fullLibName}/,' -cz * -f ${fullLibName}.tar.gz - '' - else - preBuild; + preBuild = + if preBuild == "" then + '' + # This trickery is needed because Octave expects a single directory inside + # at the top-most level of the tarball. + tar --transform 's,^,${fullLibName}/,' -cz * -f ${fullLibName}.tar.gz + '' + else + preBuild; - buildPhase = '' - runHook preBuild + buildPhase = '' + runHook preBuild - mkdir -p $out - octave-cli --eval "pkg build $out ${fullLibName}.tar.gz" + mkdir -p $out + octave-cli --eval "pkg build $out ${fullLibName}.tar.gz" - runHook postBuild - ''; + runHook postBuild + ''; - # We don't install here, because that's handled when we build the environment - # together with Octave. - dontInstall = true; + # We don't install here, because that's handled when we build the environment + # together with Octave. + dontInstall = true; - passthru = passthru'; + passthru = passthru'; - inherit meta; -} // attrs') + inherit meta; + } + // attrs' +) diff --git a/pkgs/development/interpreters/octave/default.nix b/pkgs/development/interpreters/octave/default.nix index 72895919383db4..25be9fc6f2e6f3 100644 --- a/pkgs/development/interpreters/octave/default.nix +++ b/pkgs/development/interpreters/octave/default.nix @@ -1,76 +1,80 @@ -{ stdenv -, pkgs -, lib -, fetchurl -, gfortran -, ncurses -, perl -, flex -, texinfo -, qhull -, libsndfile -, portaudio -, libX11 -, graphicsmagick -, pcre2 -, pkg-config -, libGL -, libGLU -, fltk -# Both are needed for discrete Fourier transform -, fftw -, fftwSinglePrec -, zlib -, curl -, rapidjson -, blas, lapack -# These 3 should use the same lapack and blas as the above, see code prepending -, qrupdate, arpack, suitesparse -# If set to true, the above 5 deps are overridden to use the blas and lapack -# with 64 bit indexes support. If all are not compatible, the build will fail. -, use64BitIdx ? false -, libwebp -, gl2ps -, ghostscript -, hdf5 -, glpk -, gnuplot -# - Include support for GNU readline: -, enableReadline ? true -, readline -# - Build Java interface: -, enableJava ? true -, jdk -, python3 -, sundials -# - Packages required for building extra packages. -, newScope -, callPackage -, makeSetupHook -, makeWrapper -# - Build Octave Qt GUI: -, enableQt ? false -, libsForQt5 -, libiconv -, darwin +{ + stdenv, + pkgs, + lib, + fetchurl, + gfortran, + ncurses, + perl, + flex, + texinfo, + qhull, + libsndfile, + portaudio, + libX11, + graphicsmagick, + pcre2, + pkg-config, + libGL, + libGLU, + fltk, + # Both are needed for discrete Fourier transform + fftw, + fftwSinglePrec, + zlib, + curl, + rapidjson, + blas, + lapack, + # These 3 should use the same lapack and blas as the above, see code prepending + qrupdate, + arpack, + suitesparse, + # If set to true, the above 5 deps are overridden to use the blas and lapack + # with 64 bit indexes support. If all are not compatible, the build will fail. + use64BitIdx ? false, + libwebp, + gl2ps, + ghostscript, + hdf5, + glpk, + gnuplot, + # - Include support for GNU readline: + enableReadline ? true, + readline, + # - Build Java interface: + enableJava ? true, + jdk, + python3, + sundials, + # - Packages required for building extra packages. + newScope, + callPackage, + makeSetupHook, + makeWrapper, + # - Build Octave Qt GUI: + enableQt ? false, + libsForQt5, + libiconv, + darwin, }: let # Not always evaluated - blas' = if use64BitIdx then - blas.override { - isILP64 = true; - } - else - blas - ; - lapack' = if use64BitIdx then - lapack.override { - isILP64 = true; - } - else - lapack - ; + blas' = + if use64BitIdx then + blas.override { + isILP64 = true; + } + else + blas; + lapack' = + if use64BitIdx then + lapack.override { + isILP64 = true; + } + else + lapack; qrupdate' = qrupdate.override { # If use64BitIdx is false, this override doesn't evaluate to a new # derivation, as blas and lapack are not overridden. @@ -82,26 +86,28 @@ let lapack = lapack'; }; # We keep the option to not enable suitesparse support by putting it null - suitesparse' = if suitesparse != null then - suitesparse.override { - blas = blas'; - lapack = lapack'; - } - else - null - ; + suitesparse' = + if suitesparse != null then + suitesparse.override { + blas = blas'; + lapack = lapack'; + } + else + null; # To avoid confusion later in passthru allPkgs = pkgs; -in stdenv.mkDerivation (finalAttrs: { - version = "9.2.0"; - pname = "octave"; +in +stdenv.mkDerivation (finalAttrs: { + version = "9.2.0"; + pname = "octave"; - src = fetchurl { - url = "mirror://gnu/octave/octave-${finalAttrs.version}.tar.gz"; - sha256 = "sha256-BjZVSwWZaZfkMcqtRCLAA4bS18aJAEcnAP7PX/63yZE="; - }; + src = fetchurl { + url = "mirror://gnu/octave/octave-${finalAttrs.version}.tar.gz"; + sha256 = "sha256-BjZVSwWZaZfkMcqtRCLAA4bS18aJAEcnAP7PX/63yZE="; + }; - buildInputs = [ + buildInputs = + [ readline ncurses perl @@ -130,40 +136,49 @@ in stdenv.mkDerivation (finalAttrs: { sundials gnuplot python3 - ] ++ lib.optionals enableQt [ + ] + ++ lib.optionals enableQt [ libsForQt5.qtbase libsForQt5.qtsvg libsForQt5.qscintilla - ] ++ lib.optionals (enableJava) [ + ] + ++ lib.optionals (enableJava) [ jdk - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - libGL libGLU libX11 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libGL + libGLU + libX11 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv darwin.apple_sdk.frameworks.Accelerate darwin.apple_sdk.frameworks.Cocoa ]; - nativeBuildInputs = [ + nativeBuildInputs = + [ pkg-config gfortran texinfo - ] ++ lib.optionals enableQt [ + ] + ++ lib.optionals enableQt [ libsForQt5.wrapQtAppsHook libsForQt5.qtscript libsForQt5.qttools ]; - doCheck = !stdenv.hostPlatform.isDarwin; + doCheck = !stdenv.hostPlatform.isDarwin; - enableParallelBuilding = true; + enableParallelBuilding = true; - # Fix linker error on Darwin (see https://trac.macports.org/ticket/61865) - NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin "-lobjc"; + # Fix linker error on Darwin (see https://trac.macports.org/ticket/61865) + NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin "-lobjc"; - # See https://savannah.gnu.org/bugs/?50339 - F77_INTEGER_8_FLAG = lib.optionalString use64BitIdx "-fdefault-integer-8"; + # See https://savannah.gnu.org/bugs/?50339 + F77_INTEGER_8_FLAG = lib.optionalString use64BitIdx "-fdefault-integer-8"; - configureFlags = [ + configureFlags = + [ "--with-blas=blas" "--with-lapack=lapack" (if use64BitIdx then "--enable-64" else "--disable-64") @@ -171,51 +186,58 @@ in stdenv.mkDerivation (finalAttrs: { ++ lib.optionals stdenv.hostPlatform.isDarwin [ "--enable-link-all-dependencies" ] ++ lib.optionals enableReadline [ "--enable-readline" ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ "--with-x=no" ] - ++ lib.optionals enableQt [ "--with-qt=5" ] - ; + ++ lib.optionals enableQt [ "--with-qt=5" ]; - # Keep a copy of the octave tests detailed results in the output - # derivation, because someone may care - postInstall = '' - cp test/fntests.log $out/share/octave/octave-${finalAttrs.version}-fntests.log || true - ''; + # Keep a copy of the octave tests detailed results in the output + # derivation, because someone may care + postInstall = '' + cp test/fntests.log $out/share/octave/octave-${finalAttrs.version}-fntests.log || true + ''; - passthru = rec { - sitePath = "share/octave/${finalAttrs.version}/site"; - octPkgsPath = "share/octave/octave_packages"; - blas = blas'; - lapack = lapack'; - qrupdate = qrupdate'; - arpack = arpack'; - suitesparse = suitesparse'; - octavePackages = import ../../../top-level/octave-packages.nix { - pkgs = allPkgs; - inherit lib stdenv fetchurl newScope; - octave = finalAttrs.finalPackage; - }; - wrapOctave = callPackage ./wrap-octave.nix { - octave = finalAttrs.finalPackage; - inherit (allPkgs) makeSetupHook makeWrapper; - }; - inherit fftw fftwSinglePrec; - inherit portaudio; - inherit jdk; - python = python3; - inherit enableQt enableReadline enableJava; - buildEnv = callPackage ./build-env.nix { - octave = finalAttrs.finalPackage; - inherit wrapOctave; - inherit (octavePackages) computeRequiredOctavePackages; - }; - withPackages = import ./with-packages.nix { inherit buildEnv octavePackages; }; - pkgs = octavePackages; - interpreter = "${finalAttrs.finalPackage}/bin/octave"; + passthru = rec { + sitePath = "share/octave/${finalAttrs.version}/site"; + octPkgsPath = "share/octave/octave_packages"; + blas = blas'; + lapack = lapack'; + qrupdate = qrupdate'; + arpack = arpack'; + suitesparse = suitesparse'; + octavePackages = import ../../../top-level/octave-packages.nix { + pkgs = allPkgs; + inherit + lib + stdenv + fetchurl + newScope + ; + octave = finalAttrs.finalPackage; }; - - meta = { - homepage = "https://www.gnu.org/software/octave/"; - license = lib.licenses.gpl3Plus; - maintainers = with lib.maintainers; [ raskin doronbehar ]; - description = "Scientific Programming Language"; + wrapOctave = callPackage ./wrap-octave.nix { + octave = finalAttrs.finalPackage; + inherit (allPkgs) makeSetupHook makeWrapper; }; - }) + inherit fftw fftwSinglePrec; + inherit portaudio; + inherit jdk; + python = python3; + inherit enableQt enableReadline enableJava; + buildEnv = callPackage ./build-env.nix { + octave = finalAttrs.finalPackage; + inherit wrapOctave; + inherit (octavePackages) computeRequiredOctavePackages; + }; + withPackages = import ./with-packages.nix { inherit buildEnv octavePackages; }; + pkgs = octavePackages; + interpreter = "${finalAttrs.finalPackage}/bin/octave"; + }; + + meta = { + homepage = "https://www.gnu.org/software/octave/"; + license = lib.licenses.gpl3Plus; + maintainers = with lib.maintainers; [ + raskin + doronbehar + ]; + description = "Scientific Programming Language"; + }; +}) diff --git a/pkgs/development/interpreters/octave/hooks/default.nix b/pkgs/development/interpreters/octave/hooks/default.nix index f47560921af3c3..8e7acafd8489cf 100644 --- a/pkgs/development/interpreters/octave/hooks/default.nix +++ b/pkgs/development/interpreters/octave/hooks/default.nix @@ -1,13 +1,16 @@ # Hooks for building Octave packages. -{ octave -, lib -, callPackage -, makeSetupHook +{ + octave, + lib, + callPackage, + makeSetupHook, }: rec { - writeRequiredOctavePackagesHook = callPackage ({ }: + writeRequiredOctavePackagesHook = callPackage ( + { }: makeSetupHook { name = "write-required-octave-packages-hook"; - } ./write-required-octave-packages-hook.sh) {}; + } ./write-required-octave-packages-hook.sh + ) { }; } diff --git a/pkgs/development/interpreters/octave/with-packages.nix b/pkgs/development/interpreters/octave/with-packages.nix index f00befbb00d45a..dc2467d2c1bea2 100644 --- a/pkgs/development/interpreters/octave/with-packages.nix +++ b/pkgs/development/interpreters/octave/with-packages.nix @@ -3,4 +3,8 @@ # Takes the buildEnv defined for Octave and the set of octavePackages, and returns # a function, which when given a function whose return value is a list of extra # packages to install, builds and returns that environment. -f: let packages = f octavePackages; in buildEnv.override { extraLibs = packages; } +f: +let + packages = f octavePackages; +in +buildEnv.override { extraLibs = packages; } diff --git a/pkgs/development/interpreters/octave/wrap-octave.nix b/pkgs/development/interpreters/octave/wrap-octave.nix index 18a532226efe68..905ba06a504464 100644 --- a/pkgs/development/interpreters/octave/wrap-octave.nix +++ b/pkgs/development/interpreters/octave/wrap-octave.nix @@ -1,6 +1,7 @@ -{ octave -, makeSetupHook -, makeWrapper +{ + octave, + makeSetupHook, + makeWrapper, }: # Defined in trivial-builders diff --git a/pkgs/development/interpreters/perl/wrapper.nix b/pkgs/development/interpreters/perl/wrapper.nix index f86808306c55d0..8321f85ef39bc4 100644 --- a/pkgs/development/interpreters/perl/wrapper.nix +++ b/pkgs/development/interpreters/perl/wrapper.nix @@ -1,53 +1,68 @@ -{ lib, perl, buildEnv, makeBinaryWrapper, stdenv -, extraLibs ? [] -, extraOutputsToInstall ? [] -, postBuild ? "" -, ignoreCollisions ? false -, requiredPerlModules +{ + lib, + perl, + buildEnv, + makeBinaryWrapper, + stdenv, + extraLibs ? [ ], + extraOutputsToInstall ? [ ], + postBuild ? "", + ignoreCollisions ? false, + requiredPerlModules, }: # Create a perl executable that knows about additional packages. let - env = let - paths = requiredPerlModules (extraLibs ++ [ perl ] ); - in buildEnv { - name = "${perl.name}-env"; + env = + let + paths = requiredPerlModules (extraLibs ++ [ perl ]); + in + buildEnv { + name = "${perl.name}-env"; - inherit paths; - inherit ignoreCollisions; - extraOutputsToInstall = [ "out" ] ++ extraOutputsToInstall; + inherit paths; + inherit ignoreCollisions; + extraOutputsToInstall = [ "out" ] ++ extraOutputsToInstall; - # TODO: remove stdenv.cc as soon as it is added to propagatedNativeBuildInputs of makeBinaryWrapper - nativeBuildInputs = [ makeBinaryWrapper stdenv.cc ]; + # TODO: remove stdenv.cc as soon as it is added to propagatedNativeBuildInputs of makeBinaryWrapper + nativeBuildInputs = [ + makeBinaryWrapper + stdenv.cc + ]; - # we create wrapper for the binaries in the different packages - postBuild = '' - if [ -L "$out/bin" ]; then - unlink "$out/bin" - fi - mkdir -p "$out/bin" + # we create wrapper for the binaries in the different packages + postBuild = + '' + if [ -L "$out/bin" ]; then + unlink "$out/bin" + fi + mkdir -p "$out/bin" - # take every binary from perl packages and put them into the env - for path in ${lib.concatStringsSep " " paths}; do - if [ -d "$path/bin" ]; then - cd "$path/bin" - for prg in *; do - if [ -f "$prg" ]; then - rm -f "$out/bin/$prg" - if [ -x "$prg" ]; then - makeWrapper "$path/bin/$prg" "$out/bin/$prg" --suffix PERL5LIB ':' "$out/${perl.libPrefix}" - fi + # take every binary from perl packages and put them into the env + for path in ${lib.concatStringsSep " " paths}; do + if [ -d "$path/bin" ]; then + cd "$path/bin" + for prg in *; do + if [ -f "$prg" ]; then + rm -f "$out/bin/$prg" + if [ -x "$prg" ]; then + makeWrapper "$path/bin/$prg" "$out/bin/$prg" --suffix PERL5LIB ':' "$out/${perl.libPrefix}" + fi + fi + done fi done - fi - done - '' + postBuild; + '' + + postBuild; - meta = perl.meta // { outputsToInstall = ["out"]; }; # remove "man" from meta.outputsToInstall. pkgs.buildEnv produces no "man", it puts everything to "out" + meta = perl.meta // { + outputsToInstall = [ "out" ]; + }; # remove "man" from meta.outputsToInstall. pkgs.buildEnv produces no "man", it puts everything to "out" - passthru = perl.passthru // { - interpreter = "${env}/bin/perl"; - inherit perl; + passthru = perl.passthru // { + interpreter = "${env}/bin/perl"; + inherit perl; + }; }; - }; -in env +in +env diff --git a/pkgs/development/interpreters/php/8.1.nix b/pkgs/development/interpreters/php/8.1.nix index 51610fb4098514..84e22ab8b12f4b 100644 --- a/pkgs/development/interpreters/php/8.1.nix +++ b/pkgs/development/interpreters/php/8.1.nix @@ -1,52 +1,59 @@ { callPackage, fetchpatch, ... }@_args: let - base = callPackage ./generic.nix ((removeAttrs _args [ "fetchpatch" ]) // { - version = "8.1.31"; - hash = "sha256-CzmCizRRUcrxt5XZ9LkjyYhyMXdsMwdt/J2QpEOQ0Nw="; - }); + base = callPackage ./generic.nix ( + (removeAttrs _args [ "fetchpatch" ]) + // { + version = "8.1.31"; + hash = "sha256-CzmCizRRUcrxt5XZ9LkjyYhyMXdsMwdt/J2QpEOQ0Nw="; + } + ); in -base.withExtensions ({ all, ... }: with all; ([ - bcmath - calendar - curl - ctype - dom - exif - fileinfo - filter - ftp - gd - gettext - gmp - iconv - imap - intl - ldap - mbstring - mysqli - mysqlnd - opcache - openssl - pcntl - pdo - pdo_mysql - pdo_odbc - pdo_pgsql - pdo_sqlite - pgsql - posix - readline - session - simplexml - sockets - soap - sodium - sysvsem - sqlite3 - tokenizer - xmlreader - xmlwriter - zip - zlib -])) +base.withExtensions ( + { all, ... }: + with all; + ([ + bcmath + calendar + curl + ctype + dom + exif + fileinfo + filter + ftp + gd + gettext + gmp + iconv + imap + intl + ldap + mbstring + mysqli + mysqlnd + opcache + openssl + pcntl + pdo + pdo_mysql + pdo_odbc + pdo_pgsql + pdo_sqlite + pgsql + posix + readline + session + simplexml + sockets + soap + sodium + sysvsem + sqlite3 + tokenizer + xmlreader + xmlwriter + zip + zlib + ]) +) diff --git a/pkgs/development/interpreters/php/8.2.nix b/pkgs/development/interpreters/php/8.2.nix index 4fdcf60354f57a..6f80ac7be89d57 100644 --- a/pkgs/development/interpreters/php/8.2.nix +++ b/pkgs/development/interpreters/php/8.2.nix @@ -1,52 +1,59 @@ { callPackage, ... }@_args: let - base = callPackage ./generic.nix (_args // { - version = "8.2.26"; - hash = "sha256-vlfDR9RRyQW8tDNoMqhk2ZKN0OIJibhycF/qC6ZHbGs="; - }); + base = callPackage ./generic.nix ( + _args + // { + version = "8.2.26"; + hash = "sha256-vlfDR9RRyQW8tDNoMqhk2ZKN0OIJibhycF/qC6ZHbGs="; + } + ); in -base.withExtensions ({ all, ... }: with all; ([ - bcmath - calendar - curl - ctype - dom - exif - fileinfo - filter - ftp - gd - gettext - gmp - iconv - imap - intl - ldap - mbstring - mysqli - mysqlnd - opcache - openssl - pcntl - pdo - pdo_mysql - pdo_odbc - pdo_pgsql - pdo_sqlite - pgsql - posix - readline - session - simplexml - sockets - soap - sodium - sysvsem - sqlite3 - tokenizer - xmlreader - xmlwriter - zip - zlib -])) +base.withExtensions ( + { all, ... }: + with all; + ([ + bcmath + calendar + curl + ctype + dom + exif + fileinfo + filter + ftp + gd + gettext + gmp + iconv + imap + intl + ldap + mbstring + mysqli + mysqlnd + opcache + openssl + pcntl + pdo + pdo_mysql + pdo_odbc + pdo_pgsql + pdo_sqlite + pgsql + posix + readline + session + simplexml + sockets + soap + sodium + sysvsem + sqlite3 + tokenizer + xmlreader + xmlwriter + zip + zlib + ]) +) diff --git a/pkgs/development/interpreters/php/8.3.nix b/pkgs/development/interpreters/php/8.3.nix index c51dd4d0141543..abae36f9a5ed37 100644 --- a/pkgs/development/interpreters/php/8.3.nix +++ b/pkgs/development/interpreters/php/8.3.nix @@ -1,52 +1,59 @@ { callPackage, ... }@_args: let - base = callPackage ./generic.nix (_args // { - version = "8.3.14"; - hash = "sha256-9W+mac5MAUUqKSH0ADTXedjCuX0HSUk61HgYE7kiHPg="; - }); + base = callPackage ./generic.nix ( + _args + // { + version = "8.3.14"; + hash = "sha256-9W+mac5MAUUqKSH0ADTXedjCuX0HSUk61HgYE7kiHPg="; + } + ); in -base.withExtensions ({ all, ... }: with all; ([ - bcmath - calendar - curl - ctype - dom - exif - fileinfo - filter - ftp - gd - gettext - gmp - iconv - imap - intl - ldap - mbstring - mysqli - mysqlnd - opcache - openssl - pcntl - pdo - pdo_mysql - pdo_odbc - pdo_pgsql - pdo_sqlite - pgsql - posix - readline - session - simplexml - sockets - soap - sodium - sysvsem - sqlite3 - tokenizer - xmlreader - xmlwriter - zip - zlib -])) +base.withExtensions ( + { all, ... }: + with all; + ([ + bcmath + calendar + curl + ctype + dom + exif + fileinfo + filter + ftp + gd + gettext + gmp + iconv + imap + intl + ldap + mbstring + mysqli + mysqlnd + opcache + openssl + pcntl + pdo + pdo_mysql + pdo_odbc + pdo_pgsql + pdo_sqlite + pgsql + posix + readline + session + simplexml + sockets + soap + sodium + sysvsem + sqlite3 + tokenizer + xmlreader + xmlwriter + zip + zlib + ]) +) diff --git a/pkgs/development/interpreters/php/generic.nix b/pkgs/development/interpreters/php/generic.nix index a9d808641916d7..34f654db508418 100644 --- a/pkgs/development/interpreters/php/generic.nix +++ b/pkgs/development/interpreters/php/generic.nix @@ -3,63 +3,65 @@ let generic = - { callPackage - , lib - , stdenv - , nixosTests - , tests - , fetchurl - , makeBinaryWrapper - , symlinkJoin - , writeText - , autoconf - , automake - , bison - , flex - , libtool - , pkg-config - , re2c - , apacheHttpd - , libargon2 - , libxml2 - , pcre2 - , systemd - , system-sendmail - , valgrind - , xcbuild - , writeShellScript - , common-updater-scripts - , curl - , jq - - , version - , phpSrc ? null - , hash ? null - , extraPatches ? [ ] - , packageOverrides ? (final: prev: { }) - , phpAttrsOverrides ? (final: prev: { }) - , pearInstallPhar ? (callPackage ./install-pear-nozlib-phar.nix { }) + { + callPackage, + lib, + stdenv, + nixosTests, + tests, + fetchurl, + makeBinaryWrapper, + symlinkJoin, + writeText, + autoconf, + automake, + bison, + flex, + libtool, + pkg-config, + re2c, + apacheHttpd, + libargon2, + libxml2, + pcre2, + systemd, + system-sendmail, + valgrind, + xcbuild, + writeShellScript, + common-updater-scripts, + curl, + jq, + + version, + phpSrc ? null, + hash ? null, + extraPatches ? [ ], + packageOverrides ? (final: prev: { }), + phpAttrsOverrides ? (final: prev: { }), + pearInstallPhar ? (callPackage ./install-pear-nozlib-phar.nix { }), # Sapi flags - , cgiSupport ? true - , cliSupport ? true - , fpmSupport ? true - , pearSupport ? true - , pharSupport ? true - , phpdbgSupport ? true + cgiSupport ? true, + cliSupport ? true, + fpmSupport ? true, + pearSupport ? true, + pharSupport ? true, + phpdbgSupport ? true, # Misc flags - , apxs2Support ? false - , argon2Support ? true - , cgotoSupport ? false - , embedSupport ? false - , staticSupport ? false - , ipv6Support ? true - , zendSignalsSupport ? true - , zendMaxExecutionTimersSupport ? false - , systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd - , valgrindSupport ? !stdenv.hostPlatform.isDarwin && lib.meta.availableOn stdenv.hostPlatform valgrind - , ztsSupport ? apxs2Support + apxs2Support ? false, + argon2Support ? true, + cgotoSupport ? false, + embedSupport ? false, + staticSupport ? false, + ipv6Support ? true, + zendSignalsSupport ? true, + zendMaxExecutionTimersSupport ? false, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, + valgrindSupport ? + !stdenv.hostPlatform.isDarwin && lib.meta.availableOn stdenv.hostPlatform valgrind, + ztsSupport ? apxs2Support, }@args: let @@ -71,122 +73,145 @@ let # extensions functions in its closure. This is necessary for # consecutive calls to buildEnv and overrides to work as # expected. - mkBuildEnv = prevArgs: prevExtensionFunctions: lib.makeOverridable ( - { extensions ? ({ enabled, ... }: enabled), extraConfig ? "", ... }@innerArgs: - let - allArgs = args // prevArgs // innerArgs; - filteredArgs = builtins.removeAttrs allArgs [ "extensions" "extraConfig" ]; - php = generic filteredArgs; - - php-packages = (callPackage ../../../top-level/php-packages.nix { - phpPackage = phpWithExtensions; - }).overrideScope packageOverrides; - - allExtensionFunctions = prevExtensionFunctions ++ [ extensions ]; - enabledExtensions = - builtins.foldl' - (enabled: f: - f { inherit enabled; all = php-packages.extensions; }) - [ ] - allExtensionFunctions; - - getExtName = ext: ext.extensionName; - - # Recursively get a list of all internal dependencies - # for a list of extensions. - getDepsRecursively = extensions: - let - deps = lib.concatMap - (ext: (ext.internalDeps or [ ]) ++ (ext.peclDeps or [ ])) - extensions; - in - if ! (deps == [ ]) then - deps ++ (getDepsRecursively deps) - else - deps; - - # Generate extension load configuration snippets from the - # extension parameter. This is an attrset suitable for use - # with textClosureList, which is used to put the strings in - # the right order - if a plugin which is dependent on - # another plugin is placed before its dependency, it will - # fail to load. - extensionTexts = - lib.listToAttrs - (map - (ext: - let - extName = getExtName ext; - phpDeps = (ext.internalDeps or [ ]) ++ (ext.peclDeps or [ ]); - type = "${lib.optionalString (ext.zendExtension or false) "zend_"}extension"; - in - lib.nameValuePair extName { - text = "${type}=${ext}/lib/php/extensions/${extName}.so"; - deps = map getExtName phpDeps; - }) - (enabledExtensions ++ (getDepsRecursively enabledExtensions))); - - extNames = map getExtName enabledExtensions; - extraInit = writeText "php-extra-init-${version}.ini" '' - ${lib.concatStringsSep "\n" - (lib.textClosureList extensionTexts extNames)} - ${extraConfig} - ''; - - phpWithExtensions = symlinkJoin { - name = "php-with-extensions-${version}"; - inherit (php) version; - nativeBuildInputs = [ makeBinaryWrapper ]; - passthru = php.passthru // { - buildEnv = mkBuildEnv allArgs allExtensionFunctions; - withExtensions = mkWithExtensions allArgs allExtensionFunctions; - overrideAttrs = - f: + mkBuildEnv = + prevArgs: prevExtensionFunctions: + lib.makeOverridable ( + { + extensions ? ({ enabled, ... }: enabled), + extraConfig ? "", + ... + }@innerArgs: + let + allArgs = args // prevArgs // innerArgs; + filteredArgs = builtins.removeAttrs allArgs [ + "extensions" + "extraConfig" + ]; + php = generic filteredArgs; + + php-packages = + (callPackage ../../../top-level/php-packages.nix { + phpPackage = phpWithExtensions; + }).overrideScope + packageOverrides; + + allExtensionFunctions = prevExtensionFunctions ++ [ extensions ]; + enabledExtensions = builtins.foldl' ( + enabled: f: + f { + inherit enabled; + all = php-packages.extensions; + } + ) [ ] allExtensionFunctions; + + getExtName = ext: ext.extensionName; + + # Recursively get a list of all internal dependencies + # for a list of extensions. + getDepsRecursively = + extensions: + let + deps = lib.concatMap (ext: (ext.internalDeps or [ ]) ++ (ext.peclDeps or [ ])) extensions; + in + if !(deps == [ ]) then deps ++ (getDepsRecursively deps) else deps; + + # Generate extension load configuration snippets from the + # extension parameter. This is an attrset suitable for use + # with textClosureList, which is used to put the strings in + # the right order - if a plugin which is dependent on + # another plugin is placed before its dependency, it will + # fail to load. + extensionTexts = lib.listToAttrs ( + map ( + ext: let - phpAttrsOverrides = filteredArgs.phpAttrsOverrides or (final: prev: { }); - newPhpAttrsOverrides = lib.composeExtensions (lib.toExtension phpAttrsOverrides) (lib.toExtension f); - php = generic (filteredArgs // { phpAttrsOverrides = newPhpAttrsOverrides; }); + extName = getExtName ext; + phpDeps = (ext.internalDeps or [ ]) ++ (ext.peclDeps or [ ]); + type = "${lib.optionalString (ext.zendExtension or false) "zend_"}extension"; in - php.buildEnv { inherit extensions extraConfig; }; - phpIni = "${phpWithExtensions}/lib/php.ini"; - unwrapped = php; - # Select the right php tests for the php version - tests = { - nixos = lib.recurseIntoAttrs nixosTests."php${lib.strings.replaceStrings [ "." ] [ "" ] (lib.versions.majorMinor php.version)}"; - package = tests.php; - }; - inherit (php-packages) extensions buildPecl mkComposerRepository mkComposerVendor buildComposerProject buildComposerProject2 buildComposerWithPlugin composerHooks composerHooks2 mkExtension; - packages = php-packages.tools; - meta = php.meta // { - outputsToInstall = [ "out" ]; + lib.nameValuePair extName { + text = "${type}=${ext}/lib/php/extensions/${extName}.so"; + deps = map getExtName phpDeps; + } + ) (enabledExtensions ++ (getDepsRecursively enabledExtensions)) + ); + + extNames = map getExtName enabledExtensions; + extraInit = writeText "php-extra-init-${version}.ini" '' + ${lib.concatStringsSep "\n" (lib.textClosureList extensionTexts extNames)} + ${extraConfig} + ''; + + phpWithExtensions = symlinkJoin { + name = "php-with-extensions-${version}"; + inherit (php) version; + nativeBuildInputs = [ makeBinaryWrapper ]; + passthru = php.passthru // { + buildEnv = mkBuildEnv allArgs allExtensionFunctions; + withExtensions = mkWithExtensions allArgs allExtensionFunctions; + overrideAttrs = + f: + let + phpAttrsOverrides = filteredArgs.phpAttrsOverrides or (final: prev: { }); + newPhpAttrsOverrides = lib.composeExtensions (lib.toExtension phpAttrsOverrides) ( + lib.toExtension f + ); + php = generic (filteredArgs // { phpAttrsOverrides = newPhpAttrsOverrides; }); + in + php.buildEnv { inherit extensions extraConfig; }; + phpIni = "${phpWithExtensions}/lib/php.ini"; + unwrapped = php; + # Select the right php tests for the php version + tests = { + nixos = + lib.recurseIntoAttrs + nixosTests."php${lib.strings.replaceStrings [ "." ] [ "" ] (lib.versions.majorMinor php.version)}"; + package = tests.php; + }; + inherit (php-packages) + extensions + buildPecl + mkComposerRepository + mkComposerVendor + buildComposerProject + buildComposerProject2 + buildComposerWithPlugin + composerHooks + composerHooks2 + mkExtension + ; + packages = php-packages.tools; + meta = php.meta // { + outputsToInstall = [ "out" ]; + }; }; + paths = [ php ]; + postBuild = '' + ln -s ${extraInit} $out/lib/php.ini + + if test -e $out/bin/php; then + wrapProgram $out/bin/php --set-default PHP_INI_SCAN_DIR $out/lib + fi + + if test -e $out/bin/php-fpm; then + wrapProgram $out/bin/php-fpm --set-default PHP_INI_SCAN_DIR $out/lib + fi + + if test -e $out/bin/phpdbg; then + wrapProgram $out/bin/phpdbg --set-default PHP_INI_SCAN_DIR $out/lib + fi + + if test -e $out/bin/php-cgi; then + wrapProgram $out/bin/php-cgi --set-default PHP_INI_SCAN_DIR $out/lib + fi + ''; }; - paths = [ php ]; - postBuild = '' - ln -s ${extraInit} $out/lib/php.ini - - if test -e $out/bin/php; then - wrapProgram $out/bin/php --set-default PHP_INI_SCAN_DIR $out/lib - fi + in + phpWithExtensions + ); - if test -e $out/bin/php-fpm; then - wrapProgram $out/bin/php-fpm --set-default PHP_INI_SCAN_DIR $out/lib - fi - - if test -e $out/bin/phpdbg; then - wrapProgram $out/bin/phpdbg --set-default PHP_INI_SCAN_DIR $out/lib - fi - - if test -e $out/bin/php-cgi; then - wrapProgram $out/bin/php-cgi --set-default PHP_INI_SCAN_DIR $out/lib - fi - ''; - }; - in - phpWithExtensions - ); - - mkWithExtensions = prevArgs: prevExtensionFunctions: extensions: + mkWithExtensions = + prevArgs: prevExtensionFunctions: extensions: mkBuildEnv prevArgs prevExtensionFunctions { inherit extensions; }; defaultPhpSrc = fetchurl { @@ -203,8 +228,15 @@ let enableParallelBuilding = true; - nativeBuildInputs = [ autoconf automake bison flex libtool pkg-config re2c ] - ++ lib.optional stdenv.hostPlatform.isDarwin xcbuild; + nativeBuildInputs = [ + autoconf + automake + bison + flex + libtool + pkg-config + re2c + ] ++ lib.optional stdenv.hostPlatform.isDarwin xcbuild; buildInputs = # PCRE extension @@ -217,8 +249,7 @@ let ++ lib.optional apxs2Support apacheHttpd ++ lib.optional argon2Support libargon2 ++ lib.optional systemdSupport systemd - ++ lib.optional valgrindSupport valgrind - ; + ++ lib.optional valgrindSupport valgrind; CXXFLAGS = lib.optionalString stdenv.cc.isClang "-std=c++11"; SKIP_PERF_SENSITIVE = 1; @@ -234,11 +265,14 @@ let ++ lib.optional (!cgiSupport) "--disable-cgi" ++ lib.optional (!cliSupport) "--disable-cli" ++ lib.optional fpmSupport "--enable-fpm" - ++ lib.optionals pearSupport [ "--with-pear" "--enable-xml" "--with-libxml" ] + ++ lib.optionals pearSupport [ + "--with-pear" + "--enable-xml" + "--with-libxml" + ] ++ lib.optional pharSupport "--enable-phar" ++ lib.optional (!phpdbgSupport) "--disable-phpdbg" - # Misc flags ++ lib.optional apxs2Support "--with-apxs2=${apacheHttpd.dev}/bin/apxs" ++ lib.optional argon2Support "--with-password-argon2=${libargon2}" @@ -249,13 +283,11 @@ let ++ lib.optional valgrindSupport "--with-valgrind=${valgrind.dev}" ++ lib.optional ztsSupport "--enable-zts" ++ lib.optional staticSupport "--enable-static" - ++ lib.optional (!zendSignalsSupport) ["--disable-zend-signals"] + ++ lib.optional (!zendSignalsSupport) [ "--disable-zend-signals" ] ++ lib.optional zendMaxExecutionTimersSupport "--enable-zend-max-execution-timers" - # Sendmail - ++ [ "PROG_SENDMAIL=${system-sendmail}/bin/sendmail" ] - ; + ++ [ "PROG_SENDMAIL=${system-sendmail}/bin/sendmail" ]; hardeningDisable = [ "bindnow" ]; @@ -276,7 +308,8 @@ let if [ -f "scripts/dev/genfiles" ]; then ./scripts/dev/genfiles fi - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' substituteInPlace configure --replace-fail "-lstdc++" "-lc++" ''; @@ -304,26 +337,39 @@ let src = if phpSrc == null then defaultPhpSrc else phpSrc; - patches = lib.optionals (lib.versionOlder version "8.4") [ - ./fix-paths-php7.patch - ] ++ lib.optionals (lib.versionAtLeast version "8.4") [ - ./fix-paths-php84.patch - ] ++ extraPatches; + patches = + lib.optionals (lib.versionOlder version "8.4") [ + ./fix-paths-php7.patch + ] + ++ lib.optionals (lib.versionAtLeast version "8.4") [ + ./fix-paths-php84.patch + ] + ++ extraPatches; separateDebugInfo = true; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; passthru = { updateScript = let script = writeShellScript "php${lib.versions.major version}${lib.versions.minor version}-update-script" '' set -o errexit - PATH=${lib.makeBinPath [ common-updater-scripts curl jq ]} + PATH=${ + lib.makeBinPath [ + common-updater-scripts + curl + jq + ] + } new_version=$(curl --silent "https://www.php.net/releases/active" | jq --raw-output '."${lib.versions.major version}"."${lib.versions.majorMinor version}".version') update-source-version "$UPDATE_NIX_ATTR_PATH.unwrapped" "$new_version" "--file=$1" ''; - in [ + in + [ script # Passed as an argument so that update.nix can ensure it does not become a store path. (./. + "/${lib.versions.majorMinor version}.nix") @@ -333,7 +379,9 @@ let overrideAttrs = f: let - newPhpAttrsOverrides = lib.composeExtensions (lib.toExtension phpAttrsOverrides) (lib.toExtension f); + newPhpAttrsOverrides = lib.composeExtensions (lib.toExtension phpAttrsOverrides) ( + lib.toExtension f + ); php = generic (args // { phpAttrsOverrides = newPhpAttrsOverrides; }); in php; @@ -347,7 +395,10 @@ let mainProgram = "php"; maintainers = teams.php.members; platforms = platforms.all; - outputsToInstall = [ "out" "dev" ]; + outputsToInstall = [ + "out" + "dev" + ]; }; }; final = attrs // (lib.toExtension phpAttrsOverrides) final attrs; diff --git a/pkgs/development/interpreters/php/install-pear-nozlib-phar.nix b/pkgs/development/interpreters/php/install-pear-nozlib-phar.nix index 9de0ec44186280..36d168f48d67d6 100644 --- a/pkgs/development/interpreters/php/install-pear-nozlib-phar.nix +++ b/pkgs/development/interpreters/php/install-pear-nozlib-phar.nix @@ -1,5 +1,5 @@ { - fetchurl + fetchurl, }: fetchurl { diff --git a/pkgs/development/interpreters/python/conda/default.nix b/pkgs/development/interpreters/python/conda/default.nix index 77bda13f266c4c..a3c3cd30ceb831 100644 --- a/pkgs/development/interpreters/python/conda/default.nix +++ b/pkgs/development/interpreters/python/conda/default.nix @@ -1,25 +1,29 @@ -{ pkgs }: { +{ pkgs }: +{ # List of libraries that are needed for conda binary packages. # When installing a conda binary package, just extend # the `buildInputs` with `condaAutopatchLibs`. - condaPatchelfLibs = builtins.map (p: p.lib or p) ([ - pkgs.alsa-lib - pkgs.cups - pkgs.gcc-unwrapped - pkgs.libGL - ] ++ (with pkgs.xorg; [ - libSM - libICE - libX11 - libXau - libXdamage - libXi - libXrender - libXrandr - libXcomposite - libXcursor - libXtst - libXScrnSaver]) + condaPatchelfLibs = builtins.map (p: p.lib or p) ( + [ + pkgs.alsa-lib + pkgs.cups + pkgs.gcc-unwrapped + pkgs.libGL + ] + ++ (with pkgs.xorg; [ + libSM + libICE + libX11 + libXau + libXdamage + libXi + libXrender + libXrandr + libXcomposite + libXcursor + libXtst + libXScrnSaver + ]) ); } diff --git a/pkgs/development/interpreters/python/cpython/docs/3.10-texinfo.nix b/pkgs/development/interpreters/python/cpython/docs/3.10-texinfo.nix index 35664e17cd6857..fba3ae04e9cd41 100644 --- a/pkgs/development/interpreters/python/cpython/docs/3.10-texinfo.nix +++ b/pkgs/development/interpreters/python/cpython/docs/3.10-texinfo.nix @@ -1,6 +1,10 @@ # This file was generated and will be overwritten by ./generate.sh -{ stdenv, lib, fetchurl }: +{ + stdenv, + lib, + fetchurl, +}: stdenv.mkDerivation { pname = "python310-docs-texinfo"; diff --git a/pkgs/development/interpreters/python/hooks/default.nix b/pkgs/development/interpreters/python/hooks/default.nix index b4f7ca9cd83744..38afdb3026b9ca 100644 --- a/pkgs/development/interpreters/python/hooks/default.nix +++ b/pkgs/development/interpreters/python/hooks/default.nix @@ -1,4 +1,5 @@ -self: dontUse: with self; +self: dontUse: +with self; let inherit (python) pythonOnBuildForHost; @@ -7,180 +8,257 @@ let pythonSitePackages = python.sitePackages; pythonCheckInterpreter = python.interpreter; setuppy = ../run_setup.py; -in { - makePythonHook = let - defaultArgs = { passthru.provides.setupHook = true; }; - in args: pkgs.makeSetupHook (lib.recursiveUpdate defaultArgs args); +in +{ + makePythonHook = + let + defaultArgs = { + passthru.provides.setupHook = true; + }; + in + args: pkgs.makeSetupHook (lib.recursiveUpdate defaultArgs args); - condaInstallHook = callPackage ({ makePythonHook, gnutar, lbzip2 }: + condaInstallHook = callPackage ( + { + makePythonHook, + gnutar, + lbzip2, + }: makePythonHook { name = "conda-install-hook"; - propagatedBuildInputs = [ gnutar lbzip2 ]; + propagatedBuildInputs = [ + gnutar + lbzip2 + ]; substitutions = { inherit pythonSitePackages; }; - } ./conda-install-hook.sh) {}; + } ./conda-install-hook.sh + ) { }; - condaUnpackHook = callPackage ({ makePythonHook }: + condaUnpackHook = callPackage ( + { makePythonHook }: makePythonHook { name = "conda-unpack-hook"; - propagatedBuildInputs = []; - } ./conda-unpack-hook.sh) {}; + propagatedBuildInputs = [ ]; + } ./conda-unpack-hook.sh + ) { }; - eggBuildHook = callPackage ({ makePythonHook }: + eggBuildHook = callPackage ( + { makePythonHook }: makePythonHook { name = "egg-build-hook.sh"; propagatedBuildInputs = [ ]; - } ./egg-build-hook.sh) {}; + } ./egg-build-hook.sh + ) { }; - eggInstallHook = callPackage ({ makePythonHook, setuptools }: + eggInstallHook = callPackage ( + { makePythonHook, setuptools }: makePythonHook { name = "egg-install-hook.sh"; propagatedBuildInputs = [ setuptools ]; substitutions = { inherit pythonInterpreter pythonSitePackages; }; - } ./egg-install-hook.sh) {}; + } ./egg-install-hook.sh + ) { }; - eggUnpackHook = callPackage ({ makePythonHook, }: + eggUnpackHook = callPackage ( + { makePythonHook }: makePythonHook { name = "egg-unpack-hook.sh"; propagatedBuildInputs = [ ]; - } ./egg-unpack-hook.sh) {}; + } ./egg-unpack-hook.sh + ) { }; - pipBuildHook = callPackage ({ makePythonHook, pip, wheel }: + pipBuildHook = callPackage ( + { + makePythonHook, + pip, + wheel, + }: makePythonHook { name = "pip-build-hook.sh"; - propagatedBuildInputs = [ pip wheel ]; + propagatedBuildInputs = [ + pip + wheel + ]; substitutions = { inherit pythonInterpreter pythonSitePackages; }; - } ./pip-build-hook.sh) {}; + } ./pip-build-hook.sh + ) { }; - pypaBuildHook = callPackage ({ makePythonHook, build, wheel }: - makePythonHook { - name = "pypa-build-hook.sh"; - propagatedBuildInputs = [ wheel ]; - substitutions = { - inherit build; - }; - # A test to ensure that this hook never propagates any of its dependencies - # into the build environment. - # This prevents false positive alerts raised by catchConflictsHook. - # Such conflicts don't happen within the standard nixpkgs python package - # set, but in downstream projects that build packages depending on other - # versions of this hook's dependencies. - passthru.tests = callPackage ./pypa-build-hook-test.nix { - inherit pythonOnBuildForHost; + pypaBuildHook = + callPackage + ( + { + makePythonHook, + build, + wheel, + }: + makePythonHook { + name = "pypa-build-hook.sh"; + propagatedBuildInputs = [ wheel ]; + substitutions = { + inherit build; + }; + # A test to ensure that this hook never propagates any of its dependencies + # into the build environment. + # This prevents false positive alerts raised by catchConflictsHook. + # Such conflicts don't happen within the standard nixpkgs python package + # set, but in downstream projects that build packages depending on other + # versions of this hook's dependencies. + passthru.tests = callPackage ./pypa-build-hook-test.nix { + inherit pythonOnBuildForHost; + }; + } ./pypa-build-hook.sh + ) + { + inherit (pythonOnBuildForHost.pkgs) build; }; - } ./pypa-build-hook.sh) { - inherit (pythonOnBuildForHost.pkgs) build; - }; - pipInstallHook = callPackage ({ makePythonHook, pip }: + pipInstallHook = callPackage ( + { makePythonHook, pip }: makePythonHook { name = "pip-install-hook"; propagatedBuildInputs = [ pip ]; substitutions = { inherit pythonInterpreter pythonSitePackages; }; - } ./pip-install-hook.sh) {}; + } ./pip-install-hook.sh + ) { }; - pypaInstallHook = callPackage ({ makePythonHook, installer }: - makePythonHook { - name = "pypa-install-hook"; - propagatedBuildInputs = [ installer ]; - substitutions = { - inherit pythonInterpreter pythonSitePackages; + pypaInstallHook = + callPackage + ( + { makePythonHook, installer }: + makePythonHook { + name = "pypa-install-hook"; + propagatedBuildInputs = [ installer ]; + substitutions = { + inherit pythonInterpreter pythonSitePackages; + }; + } ./pypa-install-hook.sh + ) + { + inherit (pythonOnBuildForHost.pkgs) installer; }; - } ./pypa-install-hook.sh) { - inherit (pythonOnBuildForHost.pkgs) installer; - }; - pytestCheckHook = callPackage ({ makePythonHook, pytest }: + pytestCheckHook = callPackage ( + { makePythonHook, pytest }: makePythonHook { name = "pytest-check-hook"; propagatedBuildInputs = [ pytest ]; substitutions = { inherit pythonCheckInterpreter; }; - } ./pytest-check-hook.sh) {}; + } ./pytest-check-hook.sh + ) { }; - pythonCatchConflictsHook = callPackage ({ makePythonHook, setuptools }: + pythonCatchConflictsHook = callPackage ( + { makePythonHook, setuptools }: makePythonHook { name = "python-catch-conflicts-hook"; - substitutions = let - useLegacyHook = lib.versionOlder python.pythonVersion "3"; - in { - inherit pythonInterpreter pythonSitePackages; - catchConflicts = if useLegacyHook then - ../catch_conflicts/catch_conflicts_py2.py - else - ../catch_conflicts/catch_conflicts.py; - } // lib.optionalAttrs useLegacyHook { - inherit setuptools; - }; + substitutions = + let + useLegacyHook = lib.versionOlder python.pythonVersion "3"; + in + { + inherit pythonInterpreter pythonSitePackages; + catchConflicts = + if useLegacyHook then + ../catch_conflicts/catch_conflicts_py2.py + else + ../catch_conflicts/catch_conflicts.py; + } + // lib.optionalAttrs useLegacyHook { + inherit setuptools; + }; passthru.tests = import ./python-catch-conflicts-hook-tests.nix { inherit pythonOnBuildForHost runCommand; inherit lib; inherit (pkgs) coreutils gnugrep writeShellScript; }; - } ./python-catch-conflicts-hook.sh) {}; + } ./python-catch-conflicts-hook.sh + ) { }; - pythonImportsCheckHook = callPackage ({ makePythonHook }: + pythonImportsCheckHook = callPackage ( + { makePythonHook }: makePythonHook { name = "python-imports-check-hook.sh"; substitutions = { inherit pythonCheckInterpreter pythonSitePackages; }; - } ./python-imports-check-hook.sh) {}; + } ./python-imports-check-hook.sh + ) { }; - pythonNamespacesHook = callPackage ({ makePythonHook, buildPackages }: + pythonNamespacesHook = callPackage ( + { makePythonHook, buildPackages }: makePythonHook { name = "python-namespaces-hook.sh"; substitutions = { inherit pythonSitePackages; inherit (buildPackages) findutils; }; - } ./python-namespaces-hook.sh) {}; + } ./python-namespaces-hook.sh + ) { }; - pythonOutputDistHook = callPackage ({ makePythonHook }: + pythonOutputDistHook = callPackage ( + { makePythonHook }: makePythonHook { name = "python-output-dist-hook"; - } ./python-output-dist-hook.sh ) {}; + } ./python-output-dist-hook.sh + ) { }; - pythonRecompileBytecodeHook = callPackage ({ makePythonHook }: + pythonRecompileBytecodeHook = callPackage ( + { makePythonHook }: makePythonHook { name = "python-recompile-bytecode-hook"; substitutions = { inherit pythonInterpreter pythonSitePackages; - compileArgs = lib.concatStringsSep " " (["-q" "-f" "-i -"] ++ lib.optionals isPy3k ["-j $NIX_BUILD_CORES"]); + compileArgs = lib.concatStringsSep " " ( + [ + "-q" + "-f" + "-i -" + ] + ++ lib.optionals isPy3k [ "-j $NIX_BUILD_CORES" ] + ); bytecodeName = if isPy3k then "__pycache__" else "*.pyc"; }; - } ./python-recompile-bytecode-hook.sh ) {}; + } ./python-recompile-bytecode-hook.sh + ) { }; - pythonRelaxDepsHook = callPackage ({ makePythonHook, wheel }: + pythonRelaxDepsHook = callPackage ( + { makePythonHook, wheel }: makePythonHook { name = "python-relax-deps-hook"; substitutions = { inherit pythonInterpreter pythonSitePackages wheel; }; - } ./python-relax-deps-hook.sh) {}; + } ./python-relax-deps-hook.sh + ) { }; - pythonRemoveBinBytecodeHook = callPackage ({ makePythonHook }: + pythonRemoveBinBytecodeHook = callPackage ( + { makePythonHook }: makePythonHook { name = "python-remove-bin-bytecode-hook"; - } ./python-remove-bin-bytecode-hook.sh) {}; + } ./python-remove-bin-bytecode-hook.sh + ) { }; - pythonRemoveTestsDirHook = callPackage ({ makePythonHook }: + pythonRemoveTestsDirHook = callPackage ( + { makePythonHook }: makePythonHook { name = "python-remove-tests-dir-hook"; substitutions = { inherit pythonSitePackages; }; - } ./python-remove-tests-dir-hook.sh) {}; + } ./python-remove-tests-dir-hook.sh + ) { }; - pythonRuntimeDepsCheckHook = callPackage ({ makePythonHook, packaging }: + pythonRuntimeDepsCheckHook = callPackage ( + { makePythonHook, packaging }: makePythonHook { name = "python-runtime-deps-check-hook.sh"; propagatedBuildInputs = [ packaging ]; @@ -188,66 +266,91 @@ in { inherit pythonInterpreter pythonSitePackages; hook = ./python-runtime-deps-check-hook.py; }; - } ./python-runtime-deps-check-hook.sh) {}; + } ./python-runtime-deps-check-hook.sh + ) { }; - setuptoolsBuildHook = callPackage ({ makePythonHook, setuptools, wheel }: + setuptoolsBuildHook = callPackage ( + { + makePythonHook, + setuptools, + wheel, + }: makePythonHook { name = "setuptools-build-hook"; - propagatedBuildInputs = [ setuptools wheel ]; + propagatedBuildInputs = [ + setuptools + wheel + ]; substitutions = { inherit pythonInterpreter setuppy; # python2.pkgs.setuptools does not support parallelism setuptools_has_parallel = setuptools != null && lib.versionAtLeast setuptools.version "69"; }; - } ./setuptools-build-hook.sh) {}; + } ./setuptools-build-hook.sh + ) { }; setuptoolsCheckHook = throw "The setuptoolsCheckHook has been removed, since the test command has been removed in setuptools 72.0"; - setuptoolsRustBuildHook = callPackage ({ makePythonHook, setuptools-rust }: - makePythonHook { - name = "setuptools-rust-setup-hook"; - propagatedBuildInputs = [ setuptools-rust ]; - substitutions = { - pyLibDir = "${python}/lib/${python.libPrefix}"; - cargoBuildTarget = stdenv.hostPlatform.rust.rustcTargetSpec; - cargoLinkerVar = stdenv.hostPlatform.rust.cargoEnvVarTarget; - targetLinker = "${stdenv.cc}/bin/${stdenv.cc.targetPrefix}cc"; - }; - } ./setuptools-rust-hook.sh) {}; - - unittestCheckHook = callPackage ({ makePythonHook }: + setuptoolsRustBuildHook = callPackage ( + { makePythonHook, setuptools-rust }: makePythonHook { - name = "unittest-check-hook"; + name = "setuptools-rust-setup-hook"; + propagatedBuildInputs = [ setuptools-rust ]; substitutions = { - inherit pythonCheckInterpreter; + pyLibDir = "${python}/lib/${python.libPrefix}"; + cargoBuildTarget = stdenv.hostPlatform.rust.rustcTargetSpec; + cargoLinkerVar = stdenv.hostPlatform.rust.cargoEnvVarTarget; + targetLinker = "${stdenv.cc}/bin/${stdenv.cc.targetPrefix}cc"; }; - } ./unittest-check-hook.sh) {}; + } ./setuptools-rust-hook.sh + ) { }; - venvShellHook = disabledIf (!isPy3k) (callPackage ({ makePythonHook, ensureNewerSourcesForZipFilesHook }: + unittestCheckHook = callPackage ( + { makePythonHook }: makePythonHook { - name = "venv-shell-hook"; - propagatedBuildInputs = [ ensureNewerSourcesForZipFilesHook ]; + name = "unittest-check-hook"; substitutions = { - inherit pythonInterpreter; + inherit pythonCheckInterpreter; }; - } ./venv-shell-hook.sh) {}); + } ./unittest-check-hook.sh + ) { }; + + venvShellHook = disabledIf (!isPy3k) ( + callPackage ( + { makePythonHook, ensureNewerSourcesForZipFilesHook }: + makePythonHook { + name = "venv-shell-hook"; + propagatedBuildInputs = [ ensureNewerSourcesForZipFilesHook ]; + substitutions = { + inherit pythonInterpreter; + }; + } ./venv-shell-hook.sh + ) { } + ); - wheelUnpackHook = callPackage ({ makePythonHook, wheel }: + wheelUnpackHook = callPackage ( + { makePythonHook, wheel }: makePythonHook { name = "wheel-unpack-hook.sh"; propagatedBuildInputs = [ wheel ]; - } ./wheel-unpack-hook.sh) {}; + } ./wheel-unpack-hook.sh + ) { }; wrapPython = callPackage ../wrap-python.nix { inherit (pkgs.buildPackages) makeWrapper; }; - sphinxHook = callPackage ({ makePythonHook, installShellFiles }: + sphinxHook = callPackage ( + { makePythonHook, installShellFiles }: makePythonHook { name = "python${python.pythonVersion}-sphinx-hook"; - propagatedBuildInputs = [ pythonOnBuildForHost.pkgs.sphinx installShellFiles ]; + propagatedBuildInputs = [ + pythonOnBuildForHost.pkgs.sphinx + installShellFiles + ]; substitutions = { sphinxBuild = "${pythonOnBuildForHost.pkgs.sphinx}/bin/sphinx-build"; }; - } ./sphinx-hook.sh) {}; + } ./sphinx-hook.sh + ) { }; } diff --git a/pkgs/development/interpreters/python/hooks/pypa-build-hook-test.nix b/pkgs/development/interpreters/python/hooks/pypa-build-hook-test.nix index f862429d3987b6..9a9fea7bce05cd 100644 --- a/pkgs/development/interpreters/python/hooks/pypa-build-hook-test.nix +++ b/pkgs/development/interpreters/python/hooks/pypa-build-hook-test.nix @@ -1,19 +1,21 @@ -{ pythonOnBuildForHost, runCommand }: { - dont-propagate-conflicting-deps = let - # customize a package so that its store paths differs - mkConflict = pkg: pkg.overrideAttrs { some_modification = true; }; - # minimal pyproject.toml for the example project - pyprojectToml = builtins.toFile "pyproject.toml" '' - [project] - name = "my-project" - version = "1.0.0" - ''; - # the source of the example project - projectSource = runCommand "my-project-source" {} '' - mkdir -p $out/src/my_project - cp ${pyprojectToml} $out/pyproject.toml - touch $out/src/my_project/__init__.py - ''; +{ pythonOnBuildForHost, runCommand }: +{ + dont-propagate-conflicting-deps = + let + # customize a package so that its store paths differs + mkConflict = pkg: pkg.overrideAttrs { some_modification = true; }; + # minimal pyproject.toml for the example project + pyprojectToml = builtins.toFile "pyproject.toml" '' + [project] + name = "my-project" + version = "1.0.0" + ''; + # the source of the example project + projectSource = runCommand "my-project-source" { } '' + mkdir -p $out/src/my_project + cp ${pyprojectToml} $out/pyproject.toml + touch $out/src/my_project/__init__.py + ''; in # this build must never triger conflicts pythonOnBuildForHost.pkgs.buildPythonPackage { diff --git a/pkgs/development/interpreters/python/hooks/python-catch-conflicts-hook-tests.nix b/pkgs/development/interpreters/python/hooks/python-catch-conflicts-hook-tests.nix index 2a77ef015015e8..dfa237c96174e9 100644 --- a/pkgs/development/interpreters/python/hooks/python-catch-conflicts-hook-tests.nix +++ b/pkgs/development/interpreters/python/hooks/python-catch-conflicts-hook-tests.nix @@ -1,4 +1,12 @@ -{ lib, pythonOnBuildForHost, runCommand, writeShellScript, coreutils, gnugrep }: let +{ + lib, + pythonOnBuildForHost, + runCommand, + writeShellScript, + coreutils, + gnugrep, +}: +let pythonPkgs = pythonOnBuildForHost.pkgs; @@ -8,52 +16,61 @@ customize = pkg: pkg.overrideAttrs { some_modification = true; }; # generates minimal pyproject.toml - pyprojectToml = pname: builtins.toFile "pyproject.toml" '' - [project] - name = "${pname}" - version = "1.0.0" - ''; + pyprojectToml = + pname: + builtins.toFile "pyproject.toml" '' + [project] + name = "${pname}" + version = "1.0.0" + ''; # generates source for a python project - projectSource = pname: runCommand "my-project-source" {} '' - mkdir -p $out/src - cp ${pyprojectToml pname} $out/pyproject.toml - touch $out/src/__init__.py - ''; + projectSource = + pname: + runCommand "my-project-source" { } '' + mkdir -p $out/src + cp ${pyprojectToml pname} $out/pyproject.toml + touch $out/src/__init__.py + ''; # helper to reduce boilerplate - generatePythonPackage = args: pythonPkgs.buildPythonPackage ( - { - version = "1.0.0"; - src = runCommand "my-project-source" {} '' - mkdir -p $out/src - cp ${pyprojectToml args.pname} $out/pyproject.toml - touch $out/src/__init__.py - ''; - pyproject = true; - catchConflicts = true; - buildInputs = [ pythonPkgs.setuptools ]; - } - // args - ); + generatePythonPackage = + args: + pythonPkgs.buildPythonPackage ( + { + version = "1.0.0"; + src = runCommand "my-project-source" { } '' + mkdir -p $out/src + cp ${pyprojectToml args.pname} $out/pyproject.toml + touch $out/src/__init__.py + ''; + pyproject = true; + catchConflicts = true; + buildInputs = [ pythonPkgs.setuptools ]; + } + // args + ); # in order to test for a failing build, wrap it in a shell script - expectFailure = build: errorMsg: lib.overrideDerivation build (old: { - builder = writeShellScript "test-for-failure" '' - export PATH=${coreutils}/bin:${gnugrep}/bin:$PATH - ${old.builder} "$@" > ./log 2>&1 - status=$? - cat ./log - if [ $status -eq 0 ] || ! grep -q "${errorMsg}" ./log; then - echo "The build should have failed with '${errorMsg}', but it didn't" - exit 1 - else - echo "The build failed as expected with: ${errorMsg}" - mkdir -p $out - fi - ''; - }); -in { + expectFailure = + build: errorMsg: + lib.overrideDerivation build (old: { + builder = writeShellScript "test-for-failure" '' + export PATH=${coreutils}/bin:${gnugrep}/bin:$PATH + ${old.builder} "$@" > ./log 2>&1 + status=$? + cat ./log + if [ $status -eq 0 ] || ! grep -q "${errorMsg}" ./log; then + echo "The build should have failed with '${errorMsg}', but it didn't" + exit 1 + else + echo "The build failed as expected with: ${errorMsg}" + mkdir -p $out + fi + ''; + }); +in +{ ### TEST CASES @@ -61,55 +78,53 @@ in { # This derivation has runtime dependencies on custom versions of multiple build tools. # This scenario is relevant for lang2nix tools which do not override the nixpkgs fix-point. # see https://github.com/NixOS/nixpkgs/issues/283695 - ignores-build-time-deps = - generatePythonPackage { - pname = "ignores-build-time-deps"; - buildInputs = [ - pythonPkgs.build - pythonPkgs.packaging - pythonPkgs.setuptools - pythonPkgs.wheel - ]; - propagatedBuildInputs = [ - # Add customized versions of build tools as runtime deps - (customize pythonPkgs.packaging) - (customize pythonPkgs.setuptools) - (customize pythonPkgs.wheel) - ]; - }; + ignores-build-time-deps = generatePythonPackage { + pname = "ignores-build-time-deps"; + buildInputs = [ + pythonPkgs.build + pythonPkgs.packaging + pythonPkgs.setuptools + pythonPkgs.wheel + ]; + propagatedBuildInputs = [ + # Add customized versions of build tools as runtime deps + (customize pythonPkgs.packaging) + (customize pythonPkgs.setuptools) + (customize pythonPkgs.wheel) + ]; + }; # multi-output derivation with dependency on itself must not crash - cyclic-dependencies = - generatePythonPackage { - pname = "cyclic-dependencies"; - preFixup = '' - propagatedBuildInputs+=("$out") - ''; - }; + cyclic-dependencies = generatePythonPackage { + pname = "cyclic-dependencies"; + preFixup = '' + propagatedBuildInputs+=("$out") + ''; + }; # Simplest test case that should trigger a conflict - catches-simple-conflict = let - # this build must fail due to conflicts - package = pythonPkgs.buildPythonPackage rec { - pname = "catches-simple-conflict"; - version = "0.0.0"; - src = projectSource pname; - pyproject = true; - catchConflicts = true; - buildInputs = [ - pythonPkgs.setuptools - ]; - # depend on two different versions of packaging - # (an actual runtime dependency conflict) - propagatedBuildInputs = [ - pythonPkgs.packaging - (customize pythonPkgs.packaging) - ]; - }; - in + catches-simple-conflict = + let + # this build must fail due to conflicts + package = pythonPkgs.buildPythonPackage rec { + pname = "catches-simple-conflict"; + version = "0.0.0"; + src = projectSource pname; + pyproject = true; + catchConflicts = true; + buildInputs = [ + pythonPkgs.setuptools + ]; + # depend on two different versions of packaging + # (an actual runtime dependency conflict) + propagatedBuildInputs = [ + pythonPkgs.packaging + (customize pythonPkgs.packaging) + ]; + }; + in expectFailure package "Found duplicated packages in closure for dependency 'packaging'"; - /* More complex test case with a transitive conflict @@ -121,27 +136,31 @@ in { └── dep2 └── leaf (customized version -> conflicting) */ - catches-transitive-conflict = let - # package depending on both dependency1 and dependency2 - toplevel = generatePythonPackage { - pname = "catches-transitive-conflict"; - propagatedBuildInputs = [ dep1 dep2 ]; - }; - # dep1 package depending on leaf - dep1 = generatePythonPackage { - pname = "dependency1"; - propagatedBuildInputs = [ leaf ]; - }; - # dep2 package depending on conflicting version of leaf - dep2 = generatePythonPackage { - pname = "dependency2"; - propagatedBuildInputs = [ (customize leaf) ]; - }; - # some leaf package - leaf = generatePythonPackage { - pname = "leaf"; - }; - in + catches-transitive-conflict = + let + # package depending on both dependency1 and dependency2 + toplevel = generatePythonPackage { + pname = "catches-transitive-conflict"; + propagatedBuildInputs = [ + dep1 + dep2 + ]; + }; + # dep1 package depending on leaf + dep1 = generatePythonPackage { + pname = "dependency1"; + propagatedBuildInputs = [ leaf ]; + }; + # dep2 package depending on conflicting version of leaf + dep2 = generatePythonPackage { + pname = "dependency2"; + propagatedBuildInputs = [ (customize leaf) ]; + }; + # some leaf package + leaf = generatePythonPackage { + pname = "leaf"; + }; + in expectFailure toplevel "Found duplicated packages in closure for dependency 'leaf'"; /* @@ -158,31 +177,36 @@ in { └── dep3 └── leaf (customized version -> conflicting) */ - catches-conflict-multiple-chains = let - # package depending on dependency1, dependency2 and dependency3 - toplevel = generatePythonPackage { - pname = "catches-conflict-multiple-chains"; - propagatedBuildInputs = [ dep1 dep2 dep3 ]; - }; - # dep1 package depending on leaf - dep1 = generatePythonPackage { - pname = "dependency1"; - propagatedBuildInputs = [ leaf ]; - }; - # dep2 package depending on leaf - dep2 = generatePythonPackage { - pname = "dependency2"; - propagatedBuildInputs = [ leaf ]; - }; - # dep3 package depending on conflicting version of leaf - dep3 = generatePythonPackage { - pname = "dependency3"; - propagatedBuildInputs = [ (customize leaf) ]; - }; - # some leaf package - leaf = generatePythonPackage { - pname = "leaf"; - }; - in + catches-conflict-multiple-chains = + let + # package depending on dependency1, dependency2 and dependency3 + toplevel = generatePythonPackage { + pname = "catches-conflict-multiple-chains"; + propagatedBuildInputs = [ + dep1 + dep2 + dep3 + ]; + }; + # dep1 package depending on leaf + dep1 = generatePythonPackage { + pname = "dependency1"; + propagatedBuildInputs = [ leaf ]; + }; + # dep2 package depending on leaf + dep2 = generatePythonPackage { + pname = "dependency2"; + propagatedBuildInputs = [ leaf ]; + }; + # dep3 package depending on conflicting version of leaf + dep3 = generatePythonPackage { + pname = "dependency3"; + propagatedBuildInputs = [ (customize leaf) ]; + }; + # some leaf package + leaf = generatePythonPackage { + pname = "leaf"; + }; + in expectFailure toplevel "Found duplicated packages in closure for dependency 'leaf'"; } diff --git a/pkgs/development/interpreters/python/manylinux/default.nix b/pkgs/development/interpreters/python/manylinux/default.nix index ba20c0d3a4cda1..4b7110bab41351 100644 --- a/pkgs/development/interpreters/python/manylinux/default.nix +++ b/pkgs/development/interpreters/python/manylinux/default.nix @@ -2,75 +2,87 @@ let # Create a derivation that links all desired manylinux libraries - createManyLinuxPackage = name: libs: let - drvs = lib.unique (lib.attrValues libs); - names = lib.attrNames libs; - in pkgs.runCommand name { - buildInputs = drvs; - } '' - mkdir -p $out/lib - num_found=0 + createManyLinuxPackage = + name: libs: + let + drvs = lib.unique (lib.attrValues libs); + names = lib.attrNames libs; + in + pkgs.runCommand name + { + buildInputs = drvs; + } + '' + mkdir -p $out/lib + num_found=0 - IFS=: - export DESIRED_LIBRARIES=${lib.concatStringsSep ":" names} - export LIBRARY_PATH=${lib.makeLibraryPath drvs} - for desired in $DESIRED_LIBRARIES; do - for path in $LIBRARY_PATH; do - if [ -e $path/$desired ]; then - echo "FOUND $path/$desired" - ln -s $path/$desired $out/lib/$desired - num_found=$((num_found+1)) - break - fi - done - done + IFS=: + export DESIRED_LIBRARIES=${lib.concatStringsSep ":" names} + export LIBRARY_PATH=${lib.makeLibraryPath drvs} + for desired in $DESIRED_LIBRARIES; do + for path in $LIBRARY_PATH; do + if [ -e $path/$desired ]; then + echo "FOUND $path/$desired" + ln -s $path/$desired $out/lib/$desired + num_found=$((num_found+1)) + break + fi + done + done - num_desired=${toString (lib.length names)} - echo "Found $num_found of $num_desired libraries" - if [ "$num_found" -ne "$num_desired" ]; then - echo "Error: not all desired libraries were found" - exit 1 - fi - ''; + num_desired=${toString (lib.length names)} + echo "Found $num_found of $num_desired libraries" + if [ "$num_found" -ne "$num_desired" ]; then + echo "Error: not all desired libraries were found" + exit 1 + fi + ''; getLibOutputs = lib.mapAttrs (k: v: lib.getLib v); # https://www.python.org/dev/peps/pep-0599/ - manylinux2014Libs = getLibOutputs(with pkgs; { - "libgcc_s.so.1" = glibc; - "libstdc++.so.6" = stdenv.cc.cc; - "libm.so.6" = glibc; - "libdl.so.2" = glibc; - "librt.so.1" = glibc; - "libc.so.6" = glibc; - "libnsl.so.1" = glibc; - "libutil.so.1" = glibc; - "libpthread.so.0" = glibc; - "libresolv.so.2" = glibc; - "libX11.so.6" = xorg.libX11; - "libXext.so.6" = xorg.libXext; - "libXrender.so.1" = xorg.libXrender; - "libICE.so.6" = xorg.libICE; - "libSM.so.6" = xorg.libSM; - "libGL.so.1" = libGL; - "libgobject-2.0.so.0" = glib; - "libgthread-2.0.so.0" = glib; - "libglib-2.0.so.0" = glib; - "libz.so.1" = zlib; - "libexpat.so.1" = expat; - }); + manylinux2014Libs = getLibOutputs ( + with pkgs; + { + "libgcc_s.so.1" = glibc; + "libstdc++.so.6" = stdenv.cc.cc; + "libm.so.6" = glibc; + "libdl.so.2" = glibc; + "librt.so.1" = glibc; + "libc.so.6" = glibc; + "libnsl.so.1" = glibc; + "libutil.so.1" = glibc; + "libpthread.so.0" = glibc; + "libresolv.so.2" = glibc; + "libX11.so.6" = xorg.libX11; + "libXext.so.6" = xorg.libXext; + "libXrender.so.1" = xorg.libXrender; + "libICE.so.6" = xorg.libICE; + "libSM.so.6" = xorg.libSM; + "libGL.so.1" = libGL; + "libgobject-2.0.so.0" = glib; + "libgthread-2.0.so.0" = glib; + "libglib-2.0.so.0" = glib; + "libz.so.1" = zlib; + "libexpat.so.1" = expat; + } + ); # https://www.python.org/dev/peps/pep-0571/ manylinux2010Libs = manylinux2014Libs; # https://www.python.org/dev/peps/pep-0513/ - manylinux1Libs = getLibOutputs(manylinux2010Libs // (with pkgs; { - "libpanelw.so.5" = ncurses5; - "libncursesw.so.5" = ncurses5; - "libcrypt.so.1" = libxcrypt; - })); + manylinux1Libs = getLibOutputs ( + manylinux2010Libs + // (with pkgs; { + "libpanelw.so.5" = ncurses5; + "libncursesw.so.5" = ncurses5; + "libcrypt.so.1" = libxcrypt; + }) + ); -in { +in +{ # List of libraries that are needed for manylinux compatibility. # When using a wheel that is manylinux1 compatible, just extend # the `buildInputs` with one of these `manylinux` lists. diff --git a/pkgs/development/interpreters/python/mk-python-derivation.nix b/pkgs/development/interpreters/python/mk-python-derivation.nix index 2337b2eaa7c7f0..2287cec672bcbf 100644 --- a/pkgs/development/interpreters/python/mk-python-derivation.nix +++ b/pkgs/development/interpreters/python/mk-python-derivation.nix @@ -1,45 +1,63 @@ # Generic builder. -{ lib -, config -, python -, wrapPython -, unzip -, ensureNewerSourcesForZipFilesHook -# Whether the derivation provides a Python module or not. -, toPythonModule -, namePrefix -, update-python-libraries -, setuptools -, pypaBuildHook -, pypaInstallHook -, pythonCatchConflictsHook -, pythonImportsCheckHook -, pythonNamespacesHook -, pythonOutputDistHook -, pythonRelaxDepsHook -, pythonRemoveBinBytecodeHook -, pythonRemoveTestsDirHook -, pythonRuntimeDepsCheckHook -, setuptoolsBuildHook -, wheelUnpackHook -, eggUnpackHook -, eggBuildHook -, eggInstallHook +{ + lib, + config, + python, + wrapPython, + unzip, + ensureNewerSourcesForZipFilesHook, + # Whether the derivation provides a Python module or not. + toPythonModule, + namePrefix, + update-python-libraries, + setuptools, + pypaBuildHook, + pypaInstallHook, + pythonCatchConflictsHook, + pythonImportsCheckHook, + pythonNamespacesHook, + pythonOutputDistHook, + pythonRelaxDepsHook, + pythonRemoveBinBytecodeHook, + pythonRemoveTestsDirHook, + pythonRuntimeDepsCheckHook, + setuptoolsBuildHook, + wheelUnpackHook, + eggUnpackHook, + eggBuildHook, + eggInstallHook, }: let inherit (builtins) unsafeGetAttrPos; inherit (lib) - elem optionalString max stringLength fixedWidthString getName - optional optionals optionalAttrs hasSuffix escapeShellArgs - extendDerivation head splitString isBool; - - leftPadName = name: against: let + elem + optionalString + max + stringLength + fixedWidthString + getName + optional + optionals + optionalAttrs + hasSuffix + escapeShellArgs + extendDerivation + head + splitString + isBool + ; + + leftPadName = + name: against: + let len = max (stringLength name) (stringLength against); - in fixedWidthString len " " name; + in + fixedWidthString len " " name; - isPythonModule = drv: + isPythonModule = + drv: # all pythonModules have the pythonModule attribute (drv ? "pythonModule") # Some pythonModules are turned in to a pythonApplication by setting the field to false @@ -47,121 +65,152 @@ let isMismatchedPython = drv: drv.pythonModule != python; - withDistOutput' = lib.flip elem ["pyproject" "setuptools" "wheel"]; - - isBootstrapInstallPackage' = lib.flip elem [ "flit-core" "installer" ]; + withDistOutput' = lib.flip elem [ + "pyproject" + "setuptools" + "wheel" + ]; - isBootstrapPackage' = lib.flip elem ([ - "build" "packaging" "pyproject-hooks" "wheel" - ] ++ optionals (python.pythonOlder "3.11") [ - "tomli" - ]); + isBootstrapInstallPackage' = lib.flip elem [ + "flit-core" + "installer" + ]; - isSetuptoolsDependency' = lib.flip elem [ "setuptools" "wheel" ]; + isBootstrapPackage' = lib.flip elem ( + [ + "build" + "packaging" + "pyproject-hooks" + "wheel" + ] + ++ optionals (python.pythonOlder "3.11") [ + "tomli" + ] + ); + + isSetuptoolsDependency' = lib.flip elem [ + "setuptools" + "wheel" + ]; cleanAttrs = lib.flip removeAttrs [ - "disabled" "checkPhase" "checkInputs" "nativeCheckInputs" "doCheck" "doInstallCheck" "dontWrapPythonPrograms" "catchConflicts" "pyproject" "format" - "disabledTestPaths" "disabledTests" "pytestFlagsArray" "unittestFlagsArray" "outputs" "stdenv" - "dependencies" "optional-dependencies" "build-system" + "disabled" + "checkPhase" + "checkInputs" + "nativeCheckInputs" + "doCheck" + "doInstallCheck" + "dontWrapPythonPrograms" + "catchConflicts" + "pyproject" + "format" + "disabledTestPaths" + "disabledTests" + "pytestFlagsArray" + "unittestFlagsArray" + "outputs" + "stdenv" + "dependencies" + "optional-dependencies" + "build-system" ]; in -{ name ? "${attrs.pname}-${attrs.version}" +{ + name ? "${attrs.pname}-${attrs.version}", -# Build-time dependencies for the package -, nativeBuildInputs ? [] + # Build-time dependencies for the package + nativeBuildInputs ? [ ], -# Run-time dependencies for the package -, buildInputs ? [] + # Run-time dependencies for the package + buildInputs ? [ ], -# Dependencies needed for running the checkPhase. -# These are added to buildInputs when doCheck = true. -, checkInputs ? [] -, nativeCheckInputs ? [] + # Dependencies needed for running the checkPhase. + # These are added to buildInputs when doCheck = true. + checkInputs ? [ ], + nativeCheckInputs ? [ ], -# propagate build dependencies so in case we have A -> B -> C, -# C can import package A propagated by B -, propagatedBuildInputs ? [] + # propagate build dependencies so in case we have A -> B -> C, + # C can import package A propagated by B + propagatedBuildInputs ? [ ], -# Python module dependencies. -# These are named after PEP-621. -, dependencies ? [] -, optional-dependencies ? {} + # Python module dependencies. + # These are named after PEP-621. + dependencies ? [ ], + optional-dependencies ? { }, -# Python PEP-517 build systems. -, build-system ? [] + # Python PEP-517 build systems. + build-system ? [ ], -# DEPRECATED: use propagatedBuildInputs -, pythonPath ? [] + # DEPRECATED: use propagatedBuildInputs + pythonPath ? [ ], -# Enabled to detect some (native)BuildInputs mistakes -, strictDeps ? true + # Enabled to detect some (native)BuildInputs mistakes + strictDeps ? true, -, outputs ? [ "out" ] + outputs ? [ "out" ], -# used to disable derivation, useful for specific python versions -, disabled ? false + # used to disable derivation, useful for specific python versions + disabled ? false, -# Raise an error if two packages are installed with the same name -# TODO: For cross we probably need a different PYTHONPATH, or not -# add the runtime deps until after buildPhase. -, catchConflicts ? (python.stdenv.hostPlatform == python.stdenv.buildPlatform) + # Raise an error if two packages are installed with the same name + # TODO: For cross we probably need a different PYTHONPATH, or not + # add the runtime deps until after buildPhase. + catchConflicts ? (python.stdenv.hostPlatform == python.stdenv.buildPlatform), -# Additional arguments to pass to the makeWrapper function, which wraps -# generated binaries. -, makeWrapperArgs ? [] + # Additional arguments to pass to the makeWrapper function, which wraps + # generated binaries. + makeWrapperArgs ? [ ], -# Skip wrapping of python programs altogether -, dontWrapPythonPrograms ? false + # Skip wrapping of python programs altogether + dontWrapPythonPrograms ? false, -# Don't use Pip to install a wheel -# Note this is actually a variable for the pipInstallPhase in pip's setupHook. -# It's included here to prevent an infinite recursion. -, dontUsePipInstall ? false + # Don't use Pip to install a wheel + # Note this is actually a variable for the pipInstallPhase in pip's setupHook. + # It's included here to prevent an infinite recursion. + dontUsePipInstall ? false, -# Skip setting the PYTHONNOUSERSITE environment variable in wrapped programs -, permitUserSite ? false + # Skip setting the PYTHONNOUSERSITE environment variable in wrapped programs + permitUserSite ? false, -# Remove bytecode from bin folder. -# When a Python script has the extension `.py`, bytecode is generated -# Typically, executables in bin have no extension, so no bytecode is generated. -# However, some packages do provide executables with extensions, and thus bytecode is generated. -, removeBinBytecode ? true + # Remove bytecode from bin folder. + # When a Python script has the extension `.py`, bytecode is generated + # Typically, executables in bin have no extension, so no bytecode is generated. + # However, some packages do provide executables with extensions, and thus bytecode is generated. + removeBinBytecode ? true, -# pyproject = true <-> format = "pyproject" -# pyproject = false <-> format = "other" -# https://github.com/NixOS/nixpkgs/issues/253154 -, pyproject ? null + # pyproject = true <-> format = "pyproject" + # pyproject = false <-> format = "other" + # https://github.com/NixOS/nixpkgs/issues/253154 + pyproject ? null, -# Several package formats are supported. -# "setuptools" : Install a common setuptools/distutils based package. This builds a wheel. -# "wheel" : Install from a pre-compiled wheel. -# "pyproject": Install a package using a ``pyproject.toml`` file (PEP517). This builds a wheel. -# "egg": Install a package from an egg. -# "other" : Provide your own buildPhase and installPhase. -, format ? null + # Several package formats are supported. + # "setuptools" : Install a common setuptools/distutils based package. This builds a wheel. + # "wheel" : Install from a pre-compiled wheel. + # "pyproject": Install a package using a ``pyproject.toml`` file (PEP517). This builds a wheel. + # "egg": Install a package from an egg. + # "other" : Provide your own buildPhase and installPhase. + format ? null, -, meta ? {} + meta ? { }, -, doCheck ? true + doCheck ? true, -, disabledTestPaths ? [] + disabledTestPaths ? [ ], -# Allow passing in a custom stdenv to buildPython* -, stdenv ? python.stdenv + # Allow passing in a custom stdenv to buildPython* + stdenv ? python.stdenv, -, ... } @ attrs: + ... +}@attrs: assert (pyproject != null) -> (format == null); let format' = if pyproject != null then - if pyproject then - "pyproject" - else - "other" + if pyproject then "pyproject" else "other" else if format != null then format else @@ -169,45 +218,52 @@ let withDistOutput = withDistOutput' format'; - validatePythonMatches = let - throwMismatch = attrName: drv: let - myName = "'${namePrefix}${name}'"; - theirName = "'${drv.name}'"; - optionalLocation = let - pos = unsafeGetAttrPos (if attrs ? "pname" then "pname" else "name") attrs; - in optionalString (pos != null) " at ${pos.file}:${toString pos.line}:${toString pos.column}"; - in throw '' - Python version mismatch in ${myName}: + validatePythonMatches = + let + throwMismatch = + attrName: drv: + let + myName = "'${namePrefix}${name}'"; + theirName = "'${drv.name}'"; + optionalLocation = + let + pos = unsafeGetAttrPos (if attrs ? "pname" then "pname" else "name") attrs; + in + optionalString (pos != null) " at ${pos.file}:${toString pos.line}:${toString pos.column}"; + in + throw '' + Python version mismatch in ${myName}: - The Python derivation ${myName} depends on a Python derivation - named ${theirName}, but the two derivations use different versions - of Python: + The Python derivation ${myName} depends on a Python derivation + named ${theirName}, but the two derivations use different versions + of Python: - ${leftPadName myName theirName} uses ${python} - ${leftPadName theirName myName} uses ${toString drv.pythonModule} + ${leftPadName myName theirName} uses ${python} + ${leftPadName theirName myName} uses ${toString drv.pythonModule} - Possible solutions: + Possible solutions: - * If ${theirName} is a Python library, change the reference to ${theirName} - in the ${attrName} of ${myName} to use a ${theirName} built from the same - version of Python + * If ${theirName} is a Python library, change the reference to ${theirName} + in the ${attrName} of ${myName} to use a ${theirName} built from the same + version of Python - * If ${theirName} is used as a tool during the build, move the reference to - ${theirName} in ${myName} from ${attrName} to nativeBuildInputs + * If ${theirName} is used as a tool during the build, move the reference to + ${theirName} in ${myName} from ${attrName} to nativeBuildInputs - * If ${theirName} provides executables that are called at run time, pass its - bin path to makeWrapperArgs: + * If ${theirName} provides executables that are called at run time, pass its + bin path to makeWrapperArgs: - makeWrapperArgs = [ "--prefix PATH : ''${lib.makeBinPath [ ${getName drv } ] }" ]; + makeWrapperArgs = [ "--prefix PATH : ''${lib.makeBinPath [ ${getName drv} ] }" ]; - ${optionalLocation} - ''; + ${optionalLocation} + ''; - checkDrv = attrName: drv: - if (isPythonModule drv) && (isMismatchedPython drv) then throwMismatch attrName drv - else drv; + checkDrv = + attrName: drv: + if (isPythonModule drv) && (isMismatchedPython drv) then throwMismatch attrName drv else drv; - in attrName: inputs: map (checkDrv attrName) inputs; + in + attrName: inputs: map (checkDrv attrName) inputs; isBootstrapInstallPackage = isBootstrapInstallPackage' (attrs.pname or null); @@ -216,137 +272,183 @@ let isSetuptoolsDependency = isSetuptoolsDependency' (attrs.pname or null); # Keep extra attributes from `attrs`, e.g., `patchPhase', etc. - self = toPythonModule (stdenv.mkDerivation ((cleanAttrs attrs) // { - - name = namePrefix + name; - - nativeBuildInputs = [ - python - wrapPython - ensureNewerSourcesForZipFilesHook # move to wheel installer (pip) or builder (setuptools, flit, ...)? - pythonRemoveTestsDirHook - ] ++ optionals (catchConflicts && !isBootstrapPackage && !isSetuptoolsDependency) [ - # - # 1. When building a package that is also part of the bootstrap chain, we - # must ignore conflicts after installation, because there will be one with - # the package in the bootstrap. - # - # 2. When a package is a dependency of setuptools, we must ignore conflicts - # because the hook that checks for conflicts uses setuptools. - # - pythonCatchConflictsHook - ] ++ optionals (attrs ? pythonRelaxDeps || attrs ? pythonRemoveDeps) [ - pythonRelaxDepsHook - ] ++ optionals removeBinBytecode [ - pythonRemoveBinBytecodeHook - ] ++ optionals (hasSuffix "zip" (attrs.src.name or "")) [ - unzip - ] ++ optionals (format' == "setuptools") [ - setuptoolsBuildHook - ] ++ optionals (format' == "pyproject") [( - if isBootstrapPackage then - pypaBuildHook.override { - inherit (python.pythonOnBuildForHost.pkgs.bootstrap) build; - wheel = null; + self = toPythonModule ( + stdenv.mkDerivation ( + (cleanAttrs attrs) + // { + + name = namePrefix + name; + + nativeBuildInputs = + [ + python + wrapPython + ensureNewerSourcesForZipFilesHook # move to wheel installer (pip) or builder (setuptools, flit, ...)? + pythonRemoveTestsDirHook + ] + ++ optionals (catchConflicts && !isBootstrapPackage && !isSetuptoolsDependency) [ + # + # 1. When building a package that is also part of the bootstrap chain, we + # must ignore conflicts after installation, because there will be one with + # the package in the bootstrap. + # + # 2. When a package is a dependency of setuptools, we must ignore conflicts + # because the hook that checks for conflicts uses setuptools. + # + pythonCatchConflictsHook + ] + ++ optionals (attrs ? pythonRelaxDeps || attrs ? pythonRemoveDeps) [ + pythonRelaxDepsHook + ] + ++ optionals removeBinBytecode [ + pythonRemoveBinBytecodeHook + ] + ++ optionals (hasSuffix "zip" (attrs.src.name or "")) [ + unzip + ] + ++ optionals (format' == "setuptools") [ + setuptoolsBuildHook + ] + ++ optionals (format' == "pyproject") [ + ( + if isBootstrapPackage then + pypaBuildHook.override { + inherit (python.pythonOnBuildForHost.pkgs.bootstrap) build; + wheel = null; + } + else + pypaBuildHook + ) + ( + if isBootstrapPackage then + pythonRuntimeDepsCheckHook.override { + inherit (python.pythonOnBuildForHost.pkgs.bootstrap) packaging; + } + else + pythonRuntimeDepsCheckHook + ) + ] + ++ optionals (format' == "wheel") [ + wheelUnpackHook + ] + ++ optionals (format' == "egg") [ + eggUnpackHook + eggBuildHook + eggInstallHook + ] + ++ optionals (format' != "other") [ + ( + if isBootstrapInstallPackage then + pypaInstallHook.override { + inherit (python.pythonOnBuildForHost.pkgs.bootstrap) installer; + } + else + pypaInstallHook + ) + ] + ++ optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ + # This is a test, however, it should be ran independent of the checkPhase and checkInputs + pythonImportsCheckHook + ] + ++ optionals (python.pythonAtLeast "3.3") [ + # Optionally enforce PEP420 for python3 + pythonNamespacesHook + ] + ++ optionals withDistOutput [ + pythonOutputDistHook + ] + ++ nativeBuildInputs + ++ build-system; + + buildInputs = validatePythonMatches "buildInputs" (buildInputs ++ pythonPath); + + propagatedBuildInputs = validatePythonMatches "propagatedBuildInputs" ( + propagatedBuildInputs + ++ dependencies + ++ [ + # we propagate python even for packages transformed with 'toPythonApplication' + # this pollutes the PATH but avoids rebuilds + # see https://github.com/NixOS/nixpkgs/issues/170887 for more context + python + ] + ); + + inherit strictDeps; + + LANG = "${if python.stdenv.hostPlatform.isDarwin then "en_US" else "C"}.UTF-8"; + + # Python packages don't have a checkPhase, only an installCheckPhase + doCheck = false; + doInstallCheck = attrs.doCheck or true; + nativeInstallCheckInputs = nativeCheckInputs; + installCheckInputs = checkInputs; + + postFixup = + optionalString (!dontWrapPythonPrograms) '' + wrapPythonPrograms + '' + + attrs.postFixup or ""; + + # Python packages built through cross-compilation are always for the host platform. + disallowedReferences = optionals (python.stdenv.hostPlatform != python.stdenv.buildPlatform) [ + python.pythonOnBuildForHost + ]; + + outputs = outputs ++ optional withDistOutput "dist"; + + passthru = + attrs.passthru or { } + // { + updateScript = + let + filename = head (splitString ":" self.meta.position); + in + attrs.passthru.updateScript or [ + update-python-libraries + filename + ]; + } + // optionalAttrs (dependencies != [ ]) { + inherit dependencies; + } + // optionalAttrs (optional-dependencies != { }) { + inherit optional-dependencies; + } + // optionalAttrs (build-system != [ ]) { + inherit build-system; + }; + + meta = { + # default to python's platforms + platforms = python.meta.platforms; + isBuildPythonPackage = python.meta.platforms; + } // meta; + } + // optionalAttrs (attrs ? checkPhase) { + # If given use the specified checkPhase, otherwise use the setup hook. + # Longer-term we should get rid of `checkPhase` and use `installCheckPhase`. + installCheckPhase = attrs.checkPhase; + } + // optionalAttrs (attrs.doCheck or true) ( + optionalAttrs (disabledTestPaths != [ ]) { + disabledTestPaths = escapeShellArgs disabledTestPaths; + } + // optionalAttrs (attrs ? disabledTests) { + # `escapeShellArgs` should be used as well as `disabledTestPaths`, + # but some packages rely on existing raw strings. + disabledTests = attrs.disabledTests; } - else - pypaBuildHook - ) ( - if isBootstrapPackage then - pythonRuntimeDepsCheckHook.override { - inherit (python.pythonOnBuildForHost.pkgs.bootstrap) packaging; + // optionalAttrs (attrs ? pytestFlagsArray) { + pytestFlagsArray = attrs.pytestFlagsArray; } - else - pythonRuntimeDepsCheckHook - )] ++ optionals (format' == "wheel") [ - wheelUnpackHook - ] ++ optionals (format' == "egg") [ - eggUnpackHook eggBuildHook eggInstallHook - ] ++ optionals (format' != "other") [( - if isBootstrapInstallPackage then - pypaInstallHook.override { - inherit (python.pythonOnBuildForHost.pkgs.bootstrap) installer; + // optionalAttrs (attrs ? unittestFlagsArray) { + unittestFlagsArray = attrs.unittestFlagsArray; } - else - pypaInstallHook - )] ++ optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ - # This is a test, however, it should be ran independent of the checkPhase and checkInputs - pythonImportsCheckHook - ] ++ optionals (python.pythonAtLeast "3.3") [ - # Optionally enforce PEP420 for python3 - pythonNamespacesHook - ] ++ optionals withDistOutput [ - pythonOutputDistHook - ] ++ nativeBuildInputs ++ build-system; - - buildInputs = validatePythonMatches "buildInputs" (buildInputs ++ pythonPath); - - propagatedBuildInputs = validatePythonMatches "propagatedBuildInputs" (propagatedBuildInputs ++ dependencies ++ [ - # we propagate python even for packages transformed with 'toPythonApplication' - # this pollutes the PATH but avoids rebuilds - # see https://github.com/NixOS/nixpkgs/issues/170887 for more context - python - ]); - - inherit strictDeps; - - LANG = "${if python.stdenv.hostPlatform.isDarwin then "en_US" else "C"}.UTF-8"; - - # Python packages don't have a checkPhase, only an installCheckPhase - doCheck = false; - doInstallCheck = attrs.doCheck or true; - nativeInstallCheckInputs = nativeCheckInputs; - installCheckInputs = checkInputs; - - postFixup = optionalString (!dontWrapPythonPrograms) '' - wrapPythonPrograms - '' + attrs.postFixup or ""; - - # Python packages built through cross-compilation are always for the host platform. - disallowedReferences = optionals (python.stdenv.hostPlatform != python.stdenv.buildPlatform) [ python.pythonOnBuildForHost ]; - - outputs = outputs ++ optional withDistOutput "dist"; - - passthru = attrs.passthru or { } - // { - updateScript = let - filename = head (splitString ":" self.meta.position); - in attrs.passthru.updateScript or [ update-python-libraries filename ]; - } - // optionalAttrs (dependencies != []) { - inherit dependencies; - } - // optionalAttrs (optional-dependencies != {}) { - inherit optional-dependencies; - } - // optionalAttrs (build-system != []) { - inherit build-system; - }; - - meta = { - # default to python's platforms - platforms = python.meta.platforms; - isBuildPythonPackage = python.meta.platforms; - } // meta; - } // optionalAttrs (attrs?checkPhase) { - # If given use the specified checkPhase, otherwise use the setup hook. - # Longer-term we should get rid of `checkPhase` and use `installCheckPhase`. - installCheckPhase = attrs.checkPhase; - } // optionalAttrs (attrs.doCheck or true) ( - optionalAttrs (disabledTestPaths != []) { - disabledTestPaths = escapeShellArgs disabledTestPaths; - } // optionalAttrs (attrs ? disabledTests) { - # `escapeShellArgs` should be used as well as `disabledTestPaths`, - # but some packages rely on existing raw strings. - disabledTests = attrs.disabledTests; - } // optionalAttrs (attrs ? pytestFlagsArray) { - pytestFlagsArray = attrs.pytestFlagsArray; - } // optionalAttrs (attrs ? unittestFlagsArray) { - unittestFlagsArray = attrs.unittestFlagsArray; - } - ))); - -in extendDerivation - (disabled -> throw "${name} not supported for interpreter ${python.executable}") - { } - self + ) + ) + ); + +in +extendDerivation ( + disabled -> throw "${name} not supported for interpreter ${python.executable}" +) { } self diff --git a/pkgs/development/interpreters/python/passthrufun.nix b/pkgs/development/interpreters/python/passthrufun.nix index a4de1ecd3b2b6e..fde2bab1e86c2a 100644 --- a/pkgs/development/interpreters/python/passthrufun.nix +++ b/pkgs/development/interpreters/python/passthrufun.nix @@ -1,101 +1,152 @@ -{ lib, stdenv, callPackage, pythonPackagesExtensions, config, makeScopeWithSplicing', ... }: +{ + lib, + stdenv, + callPackage, + pythonPackagesExtensions, + config, + makeScopeWithSplicing', + ... +}: -{ implementation -, libPrefix -, executable -, sourceVersion -, pythonVersion -, packageOverrides -, sitePackages -, hasDistutilsCxxPatch -, pythonOnBuildForBuild -, pythonOnBuildForHost -, pythonOnBuildForTarget -, pythonOnHostForHost -, pythonOnTargetForTarget -, pythonAttr ? null -, self # is pythonOnHostForTarget -}: let - pythonPackages = let - ensurePythonModules = items: let - exceptions = [ - stdenv - ]; - providesSetupHook = lib.attrByPath [ "provides" "setupHook"] false; - valid = value: pythonPackages.hasPythonModule value || providesSetupHook value || lib.elem value exceptions; - func = name: value: - if lib.isDerivation value then - lib.extendDerivation (valid value || throw "${name} should use `buildPythonPackage` or `toPythonModule` if it is to be part of the Python packages set.") {} value - else - value; - in lib.mapAttrs func items; - in ensurePythonModules (callPackage - # Function that when called - # - imports python-packages.nix - # - adds spliced package sets to the package set - # - applies overrides from `packageOverrides` and `pythonPackagesOverlays`. - ({ pkgs, stdenv, python, overrides }: let - pythonPackagesFun = import ./python-packages-base.nix { - inherit stdenv pkgs lib; - python = self; - }; - otherSplices = { - selfBuildBuild = pythonOnBuildForBuild.pkgs; - selfBuildHost = pythonOnBuildForHost.pkgs; - selfBuildTarget = pythonOnBuildForTarget.pkgs; - selfHostHost = pythonOnHostForHost.pkgs; - selfTargetTarget = pythonOnTargetForTarget.pkgs or {}; # There is no Python TargetTarget. - }; - hooks = import ./hooks/default.nix; - keep = self: hooks self {}; - optionalExtensions = cond: as: lib.optionals cond as; - pythonExtension = import ../../../top-level/python-packages.nix; - python2Extension = import ../../../top-level/python2-packages.nix; - extensions = lib.composeManyExtensions ([ - hooks - pythonExtension - ] ++ (optionalExtensions (!self.isPy3k) [ - python2Extension - ]) ++ pythonPackagesExtensions ++ [ - overrides - ]); - aliases = self: super: lib.optionalAttrs config.allowAliases (import ../../../top-level/python-aliases.nix lib self super); - in makeScopeWithSplicing' { - inherit otherSplices keep; - f = lib.extends (lib.composeExtensions aliases extensions) pythonPackagesFun; - }) { - overrides = packageOverrides; - python = self; - }); - pythonOnBuildForHost_overridden = - pythonOnBuildForHost.override { inherit packageOverrides; self = pythonOnBuildForHost_overridden; }; -in rec { - isPy27 = pythonVersion == "2.7"; - isPy37 = pythonVersion == "3.7"; - isPy38 = pythonVersion == "3.8"; - isPy39 = pythonVersion == "3.9"; - isPy310 = pythonVersion == "3.10"; - isPy311 = pythonVersion == "3.11"; - isPy312 = pythonVersion == "3.12"; - isPy2 = lib.strings.substring 0 1 pythonVersion == "2"; - isPy3 = lib.strings.substring 0 1 pythonVersion == "3"; - isPy3k = isPy3; - isPyPy = lib.hasInfix "pypy" interpreter; +{ + implementation, + libPrefix, + executable, + sourceVersion, + pythonVersion, + packageOverrides, + sitePackages, + hasDistutilsCxxPatch, + pythonOnBuildForBuild, + pythonOnBuildForHost, + pythonOnBuildForTarget, + pythonOnHostForHost, + pythonOnTargetForTarget, + pythonAttr ? null, + self, # is pythonOnHostForTarget +}: +let + pythonPackages = + let + ensurePythonModules = + items: + let + exceptions = [ + stdenv + ]; + providesSetupHook = lib.attrByPath [ "provides" "setupHook" ] false; + valid = + value: pythonPackages.hasPythonModule value || providesSetupHook value || lib.elem value exceptions; + func = + name: value: + if lib.isDerivation value then + lib.extendDerivation ( + valid value + || throw "${name} should use `buildPythonPackage` or `toPythonModule` if it is to be part of the Python packages set." + ) { } value + else + value; + in + lib.mapAttrs func items; + in + ensurePythonModules ( + callPackage + # Function that when called + # - imports python-packages.nix + # - adds spliced package sets to the package set + # - applies overrides from `packageOverrides` and `pythonPackagesOverlays`. + ( + { + pkgs, + stdenv, + python, + overrides, + }: + let + pythonPackagesFun = import ./python-packages-base.nix { + inherit stdenv pkgs lib; + python = self; + }; + otherSplices = { + selfBuildBuild = pythonOnBuildForBuild.pkgs; + selfBuildHost = pythonOnBuildForHost.pkgs; + selfBuildTarget = pythonOnBuildForTarget.pkgs; + selfHostHost = pythonOnHostForHost.pkgs; + selfTargetTarget = pythonOnTargetForTarget.pkgs or { }; # There is no Python TargetTarget. + }; + hooks = import ./hooks/default.nix; + keep = self: hooks self { }; + optionalExtensions = cond: as: lib.optionals cond as; + pythonExtension = import ../../../top-level/python-packages.nix; + python2Extension = import ../../../top-level/python2-packages.nix; + extensions = lib.composeManyExtensions ( + [ + hooks + pythonExtension + ] + ++ (optionalExtensions (!self.isPy3k) [ + python2Extension + ]) + ++ pythonPackagesExtensions + ++ [ + overrides + ] + ); + aliases = + self: super: + lib.optionalAttrs config.allowAliases (import ../../../top-level/python-aliases.nix lib self super); + in + makeScopeWithSplicing' { + inherit otherSplices keep; + f = lib.extends (lib.composeExtensions aliases extensions) pythonPackagesFun; + } + ) + { + overrides = packageOverrides; + python = self; + } + ); + pythonOnBuildForHost_overridden = pythonOnBuildForHost.override { + inherit packageOverrides; + self = pythonOnBuildForHost_overridden; + }; +in +rec { + isPy27 = pythonVersion == "2.7"; + isPy37 = pythonVersion == "3.7"; + isPy38 = pythonVersion == "3.8"; + isPy39 = pythonVersion == "3.9"; + isPy310 = pythonVersion == "3.10"; + isPy311 = pythonVersion == "3.11"; + isPy312 = pythonVersion == "3.12"; + isPy2 = lib.strings.substring 0 1 pythonVersion == "2"; + isPy3 = lib.strings.substring 0 1 pythonVersion == "3"; + isPy3k = isPy3; + isPyPy = lib.hasInfix "pypy" interpreter; - buildEnv = callPackage ./wrapper.nix { python = self; inherit (pythonPackages) requiredPythonModules; }; - withPackages = import ./with-packages.nix { inherit buildEnv pythonPackages;}; - pkgs = pythonPackages; - interpreter = "${self}/bin/${executable}"; - inherit executable implementation libPrefix pythonVersion sitePackages; - inherit sourceVersion; - pythonAtLeast = lib.versionAtLeast pythonVersion; - pythonOlder = lib.versionOlder pythonVersion; - inherit hasDistutilsCxxPatch; - pythonOnBuildForHost = pythonOnBuildForHost_overridden; + buildEnv = callPackage ./wrapper.nix { + python = self; + inherit (pythonPackages) requiredPythonModules; + }; + withPackages = import ./with-packages.nix { inherit buildEnv pythonPackages; }; + pkgs = pythonPackages; + interpreter = "${self}/bin/${executable}"; + inherit + executable + implementation + libPrefix + pythonVersion + sitePackages + ; + inherit sourceVersion; + pythonAtLeast = lib.versionAtLeast pythonVersion; + pythonOlder = lib.versionOlder pythonVersion; + inherit hasDistutilsCxxPatch; + pythonOnBuildForHost = pythonOnBuildForHost_overridden; - tests = callPackage ./tests.nix { - python = self; - }; + tests = callPackage ./tests.nix { + python = self; + }; - inherit pythonAttr; + inherit pythonAttr; } diff --git a/pkgs/development/interpreters/python/python-packages-base.nix b/pkgs/development/interpreters/python/python-packages-base.nix index 1b10b44fb2433e..19c230a0b94ec2 100644 --- a/pkgs/development/interpreters/python/python-packages-base.nix +++ b/pkgs/development/interpreters/python/python-packages-base.nix @@ -1,7 +1,8 @@ -{ pkgs -, stdenv -, lib -, python +{ + pkgs, + stdenv, + lib, + python, }: self: @@ -13,47 +14,61 @@ let # Derivations built with `buildPythonPackage` can already be overridden with `override`, `overrideAttrs`, and `overrideDerivation`. # This function introduces `overridePythonAttrs` and it overrides the call to `buildPythonPackage`. - makeOverridablePythonPackage = f: lib.mirrorFunctionArgs f (origArgs: - let - args = lib.fix (lib.extends - (_: previousAttrs: { - passthru = (previousAttrs.passthru or { }) // { - overridePythonAttrs = newArgs: makeOverridablePythonPackage f (overrideWith newArgs); - }; - }) - (_: origArgs)); - result = f args; - overrideWith = newArgs: args // (if pkgs.lib.isFunction newArgs then newArgs args else newArgs); - in - if builtins.isAttrs result then result - else if builtins.isFunction result then { - overridePythonAttrs = newArgs: makeOverridablePythonPackage f (overrideWith newArgs); - __functor = self: result; - } - else result); - - mkPythonDerivation = if python.isPy3k then - ./mk-python-derivation.nix - else - ./python2/mk-python-derivation.nix; - - buildPythonPackage = makeOverridablePythonPackage (callPackage mkPythonDerivation { - inherit namePrefix; # We want Python libraries to be named like e.g. "python3.6-${name}" - inherit toPythonModule; # Libraries provide modules - }); - - buildPythonApplication = makeOverridablePythonPackage (callPackage mkPythonDerivation { - namePrefix = ""; # Python applications should not have any prefix - toPythonModule = x: x; # Application does not provide modules. - }); + makeOverridablePythonPackage = + f: + lib.mirrorFunctionArgs f ( + origArgs: + let + args = lib.fix ( + lib.extends (_: previousAttrs: { + passthru = (previousAttrs.passthru or { }) // { + overridePythonAttrs = newArgs: makeOverridablePythonPackage f (overrideWith newArgs); + }; + }) (_: origArgs) + ); + result = f args; + overrideWith = newArgs: args // (if pkgs.lib.isFunction newArgs then newArgs args else newArgs); + in + if builtins.isAttrs result then + result + else if builtins.isFunction result then + { + overridePythonAttrs = newArgs: makeOverridablePythonPackage f (overrideWith newArgs); + __functor = self: result; + } + else + result + ); + + mkPythonDerivation = + if python.isPy3k then ./mk-python-derivation.nix else ./python2/mk-python-derivation.nix; + + buildPythonPackage = makeOverridablePythonPackage ( + callPackage mkPythonDerivation { + inherit namePrefix; # We want Python libraries to be named like e.g. "python3.6-${name}" + inherit toPythonModule; # Libraries provide modules + } + ); + + buildPythonApplication = makeOverridablePythonPackage ( + callPackage mkPythonDerivation { + namePrefix = ""; # Python applications should not have any prefix + toPythonModule = x: x; # Application does not provide modules. + } + ); # Check whether a derivation provides a Python module. - hasPythonModule = drv: drv?pythonModule && drv.pythonModule == python; + hasPythonModule = drv: drv ? pythonModule && drv.pythonModule == python; # Get list of required Python modules given a list of derivations. - requiredPythonModules = drvs: let - modules = lib.filter hasPythonModule drvs; - in lib.unique ([python] ++ modules ++ lib.concatLists (lib.catAttrs "requiredPythonModules" modules)); + requiredPythonModules = + drvs: + let + modules = lib.filter hasPythonModule drvs; + in + lib.unique ( + [ python ] ++ modules ++ lib.concatLists (lib.catAttrs "requiredPythonModules" modules) + ); # Create a PYTHONPATH from a list of derivations. This function recurses into the items to find derivations # providing Python modules. @@ -66,23 +81,24 @@ let mkPythonMetaPackage = callPackage ./meta-package.nix { }; # Convert derivation to a Python module. - toPythonModule = drv: - drv.overrideAttrs( oldAttrs: { + toPythonModule = + drv: + drv.overrideAttrs (oldAttrs: { # Use passthru in order to prevent rebuilds when possible. - passthru = (oldAttrs.passthru or {})// { + passthru = (oldAttrs.passthru or { }) // { pythonModule = python; pythonPath = [ ]; # Deprecated, for compatibility. - requiredPythonModules = - builtins.addErrorContext - "while calculating requiredPythonModules for ${drv.name or drv.pname}:" - (requiredPythonModules drv.propagatedBuildInputs); + requiredPythonModules = builtins.addErrorContext "while calculating requiredPythonModules for ${drv.name or drv.pname}:" ( + requiredPythonModules drv.propagatedBuildInputs + ); }; }); # Convert a Python library to an application. - toPythonApplication = drv: - drv.overrideAttrs( oldAttrs: { - passthru = (oldAttrs.passthru or {}) // { + toPythonApplication = + drv: + drv.overrideAttrs (oldAttrs: { + passthru = (oldAttrs.passthru or { }) // { # Remove Python prefix from name so we have a "normal" name. # While the prefix shows up in the store path, it won't be # used by `nix-env`. @@ -91,15 +107,38 @@ let }; }); - disabled = drv: throw "${removePythonPrefix (drv.pname or drv.name)} not supported for interpreter ${python.executable}"; + disabled = + drv: + throw "${ + removePythonPrefix (drv.pname or drv.name) + } not supported for interpreter ${python.executable}"; disabledIf = x: drv: if x then disabled drv else drv; -in { +in +{ inherit lib pkgs stdenv; - inherit (python.passthru) isPy27 isPy37 isPy38 isPy39 isPy310 isPy311 isPy312 isPy3k isPyPy pythonAtLeast pythonOlder; + inherit (python.passthru) + isPy27 + isPy37 + isPy38 + isPy39 + isPy310 + isPy311 + isPy312 + isPy3k + isPyPy + pythonAtLeast + pythonOlder + ; inherit buildPythonPackage buildPythonApplication; - inherit hasPythonModule requiredPythonModules makePythonPath disabled disabledIf; + inherit + hasPythonModule + requiredPythonModules + makePythonPath + disabled + disabledIf + ; inherit toPythonModule toPythonApplication; inherit mkPythonMetaPackage mkPythonEditablePackage; @@ -107,5 +146,7 @@ in { # Don't take pythonPackages from "global" pkgs scope to avoid mixing python versions. # Prevent `pkgs/top-level/release-attrpaths-superset.nix` from recursing more than one level here. - pythonPackages = self // { __attrsFailEvaluation = true; }; + pythonPackages = self // { + __attrsFailEvaluation = true; + }; } diff --git a/pkgs/development/interpreters/python/python2/mk-python-derivation.nix b/pkgs/development/interpreters/python/python2/mk-python-derivation.nix index 427c942410705d..5bdfa4cd299212 100644 --- a/pkgs/development/interpreters/python/python2/mk-python-derivation.nix +++ b/pkgs/development/interpreters/python/python2/mk-python-derivation.nix @@ -1,243 +1,301 @@ # Generic builder only used for EOL and deprecated Python 2. -{ lib -, config -, python -, wrapPython -, unzip -, ensureNewerSourcesForZipFilesHook -# Whether the derivation provides a Python module or not. -, toPythonModule -, namePrefix -, update-python-libraries -, setuptools -, pipBuildHook -, pipInstallHook -, pythonCatchConflictsHook -, pythonImportsCheckHook -, pythonOutputDistHook -, pythonRemoveBinBytecodeHook -, pythonRemoveTestsDirHook -, setuptoolsBuildHook -, wheelUnpackHook -, eggUnpackHook -, eggBuildHook -, eggInstallHook +{ + lib, + config, + python, + wrapPython, + unzip, + ensureNewerSourcesForZipFilesHook, + # Whether the derivation provides a Python module or not. + toPythonModule, + namePrefix, + update-python-libraries, + setuptools, + pipBuildHook, + pipInstallHook, + pythonCatchConflictsHook, + pythonImportsCheckHook, + pythonOutputDistHook, + pythonRemoveBinBytecodeHook, + pythonRemoveTestsDirHook, + setuptoolsBuildHook, + wheelUnpackHook, + eggUnpackHook, + eggBuildHook, + eggInstallHook, }: -{ name ? "${attrs.pname}-${attrs.version}" +{ + name ? "${attrs.pname}-${attrs.version}", -# Build-time dependencies for the package -, nativeBuildInputs ? [] + # Build-time dependencies for the package + nativeBuildInputs ? [ ], -# Run-time dependencies for the package -, buildInputs ? [] + # Run-time dependencies for the package + buildInputs ? [ ], -# Dependencies needed for running the checkPhase. -# These are added to buildInputs when doCheck = true. -, checkInputs ? [] -, nativeCheckInputs ? [] + # Dependencies needed for running the checkPhase. + # These are added to buildInputs when doCheck = true. + checkInputs ? [ ], + nativeCheckInputs ? [ ], -# propagate build dependencies so in case we have A -> B -> C, -# C can import package A propagated by B -, propagatedBuildInputs ? [] + # propagate build dependencies so in case we have A -> B -> C, + # C can import package A propagated by B + propagatedBuildInputs ? [ ], -# DEPRECATED: use propagatedBuildInputs -, pythonPath ? [] + # DEPRECATED: use propagatedBuildInputs + pythonPath ? [ ], -# Enabled to detect some (native)BuildInputs mistakes -, strictDeps ? true + # Enabled to detect some (native)BuildInputs mistakes + strictDeps ? true, -, outputs ? [ "out" ] + outputs ? [ "out" ], -# used to disable derivation, useful for specific python versions -, disabled ? false + # used to disable derivation, useful for specific python versions + disabled ? false, -# Raise an error if two packages are installed with the same name -# TODO: For cross we probably need a different PYTHONPATH, or not -# add the runtime deps until after buildPhase. -, catchConflicts ? (python.stdenv.hostPlatform == python.stdenv.buildPlatform) + # Raise an error if two packages are installed with the same name + # TODO: For cross we probably need a different PYTHONPATH, or not + # add the runtime deps until after buildPhase. + catchConflicts ? (python.stdenv.hostPlatform == python.stdenv.buildPlatform), -# Additional arguments to pass to the makeWrapper function, which wraps -# generated binaries. -, makeWrapperArgs ? [] + # Additional arguments to pass to the makeWrapper function, which wraps + # generated binaries. + makeWrapperArgs ? [ ], -# Skip wrapping of python programs altogether -, dontWrapPythonPrograms ? false + # Skip wrapping of python programs altogether + dontWrapPythonPrograms ? false, -# Don't use Pip to install a wheel -# Note this is actually a variable for the pipInstallPhase in pip's setupHook. -# It's included here to prevent an infinite recursion. -, dontUsePipInstall ? false + # Don't use Pip to install a wheel + # Note this is actually a variable for the pipInstallPhase in pip's setupHook. + # It's included here to prevent an infinite recursion. + dontUsePipInstall ? false, -# Skip setting the PYTHONNOUSERSITE environment variable in wrapped programs -, permitUserSite ? false + # Skip setting the PYTHONNOUSERSITE environment variable in wrapped programs + permitUserSite ? false, -# Remove bytecode from bin folder. -# When a Python script has the extension `.py`, bytecode is generated -# Typically, executables in bin have no extension, so no bytecode is generated. -# However, some packages do provide executables with extensions, and thus bytecode is generated. -, removeBinBytecode ? true + # Remove bytecode from bin folder. + # When a Python script has the extension `.py`, bytecode is generated + # Typically, executables in bin have no extension, so no bytecode is generated. + # However, some packages do provide executables with extensions, and thus bytecode is generated. + removeBinBytecode ? true, -# Several package formats are supported. -# "setuptools" : Install a common setuptools/distutils based package. This builds a wheel. -# "wheel" : Install from a pre-compiled wheel. -# "pyproject": Install a package using a ``pyproject.toml`` file (PEP517). This builds a wheel. -# "egg": Install a package from an egg. -# "other" : Provide your own buildPhase and installPhase. -, format ? "setuptools" + # Several package formats are supported. + # "setuptools" : Install a common setuptools/distutils based package. This builds a wheel. + # "wheel" : Install from a pre-compiled wheel. + # "pyproject": Install a package using a ``pyproject.toml`` file (PEP517). This builds a wheel. + # "egg": Install a package from an egg. + # "other" : Provide your own buildPhase and installPhase. + format ? "setuptools", -, meta ? {} + meta ? { }, -, passthru ? {} + passthru ? { }, -, doCheck ? true + doCheck ? true, -, disabledTestPaths ? [] + disabledTestPaths ? [ ], -, ... } @ attrs: + ... +}@attrs: let inherit (python) stdenv; - withDistOutput = lib.elem format ["pyproject" "setuptools" "wheel"]; + withDistOutput = lib.elem format [ + "pyproject" + "setuptools" + "wheel" + ]; name_ = name; - validatePythonMatches = attrName: let - isPythonModule = drv: - # all pythonModules have the pythonModule attribute - (drv ? "pythonModule") - # Some pythonModules are turned in to a pythonApplication by setting the field to false - && (!builtins.isBool drv.pythonModule); - isMismatchedPython = drv: drv.pythonModule != python; + validatePythonMatches = + attrName: + let + isPythonModule = + drv: + # all pythonModules have the pythonModule attribute + (drv ? "pythonModule") + # Some pythonModules are turned in to a pythonApplication by setting the field to false + && (!builtins.isBool drv.pythonModule); + isMismatchedPython = drv: drv.pythonModule != python; - optionalLocation = let - pos = builtins.unsafeGetAttrPos (if attrs ? "pname" then "pname" else "name") attrs; - in lib.optionalString (pos != null) " at ${pos.file}:${toString pos.line}:${toString pos.column}"; + optionalLocation = + let + pos = builtins.unsafeGetAttrPos (if attrs ? "pname" then "pname" else "name") attrs; + in + lib.optionalString (pos != null) " at ${pos.file}:${toString pos.line}:${toString pos.column}"; - leftPadName = name: against: let - len = lib.max (lib.stringLength name) (lib.stringLength against); - in lib.strings.fixedWidthString len " " name; + leftPadName = + name: against: + let + len = lib.max (lib.stringLength name) (lib.stringLength against); + in + lib.strings.fixedWidthString len " " name; - throwMismatch = drv: let - myName = "'${namePrefix}${name}'"; - theirName = "'${drv.name}'"; - in throw '' - Python version mismatch in ${myName}: + throwMismatch = + drv: + let + myName = "'${namePrefix}${name}'"; + theirName = "'${drv.name}'"; + in + throw '' + Python version mismatch in ${myName}: - The Python derivation ${myName} depends on a Python derivation - named ${theirName}, but the two derivations use different versions - of Python: + The Python derivation ${myName} depends on a Python derivation + named ${theirName}, but the two derivations use different versions + of Python: - ${leftPadName myName theirName} uses ${python} - ${leftPadName theirName myName} uses ${toString drv.pythonModule} + ${leftPadName myName theirName} uses ${python} + ${leftPadName theirName myName} uses ${toString drv.pythonModule} - Possible solutions: + Possible solutions: - * If ${theirName} is a Python library, change the reference to ${theirName} - in the ${attrName} of ${myName} to use a ${theirName} built from the same - version of Python + * If ${theirName} is a Python library, change the reference to ${theirName} + in the ${attrName} of ${myName} to use a ${theirName} built from the same + version of Python - * If ${theirName} is used as a tool during the build, move the reference to - ${theirName} in ${myName} from ${attrName} to nativeBuildInputs + * If ${theirName} is used as a tool during the build, move the reference to + ${theirName} in ${myName} from ${attrName} to nativeBuildInputs - * If ${theirName} provides executables that are called at run time, pass its - bin path to makeWrapperArgs: + * If ${theirName} provides executables that are called at run time, pass its + bin path to makeWrapperArgs: - makeWrapperArgs = [ "--prefix PATH : ''${lib.makeBinPath [ ${lib.getName drv } ] }" ]; + makeWrapperArgs = [ "--prefix PATH : ''${lib.makeBinPath [ ${lib.getName drv} ] }" ]; - ${optionalLocation} - ''; + ${optionalLocation} + ''; - checkDrv = drv: - if (isPythonModule drv) && (isMismatchedPython drv) - then throwMismatch drv - else drv; + checkDrv = drv: if (isPythonModule drv) && (isMismatchedPython drv) then throwMismatch drv else drv; - in inputs: builtins.map (checkDrv) inputs; + in + inputs: builtins.map (checkDrv) inputs; # Keep extra attributes from `attrs`, e.g., `patchPhase', etc. - self = toPythonModule (stdenv.mkDerivation ((builtins.removeAttrs attrs [ - "disabled" "checkPhase" "checkInputs" "nativeCheckInputs" "doCheck" "doInstallCheck" "dontWrapPythonPrograms" "catchConflicts" "format" - "disabledTestPaths" "outputs" - ]) // { - - name = namePrefix + name_; - - nativeBuildInputs = [ - python - wrapPython - ensureNewerSourcesForZipFilesHook # move to wheel installer (pip) or builder (setuptools, ...)? - pythonRemoveTestsDirHook - ] ++ lib.optionals catchConflicts [ - pythonCatchConflictsHook - ] ++ lib.optionals removeBinBytecode [ - pythonRemoveBinBytecodeHook - ] ++ lib.optionals (lib.hasSuffix "zip" (attrs.src.name or "")) [ - unzip - ] ++ lib.optionals (format == "setuptools") [ - setuptoolsBuildHook - ] ++ lib.optionals (format == "pyproject") [( - pipBuildHook - )] ++ lib.optionals (format == "wheel") [ - wheelUnpackHook - ] ++ lib.optionals (format == "egg") [ - eggUnpackHook eggBuildHook eggInstallHook - ] ++ lib.optionals (format != "other") [( - pipInstallHook - )] ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ - # This is a test, however, it should be ran independent of the checkPhase and checkInputs - pythonImportsCheckHook - ] ++ lib.optionals withDistOutput [ - pythonOutputDistHook - ] ++ nativeBuildInputs; - - buildInputs = validatePythonMatches "buildInputs" (buildInputs ++ pythonPath); - - propagatedBuildInputs = validatePythonMatches "propagatedBuildInputs" (propagatedBuildInputs ++ [ - # we propagate python even for packages transformed with 'toPythonApplication' - # this pollutes the PATH but avoids rebuilds - # see https://github.com/NixOS/nixpkgs/issues/170887 for more context - python - ]); - - inherit strictDeps; - - LANG = "${if python.stdenv.hostPlatform.isDarwin then "en_US" else "C"}.UTF-8"; - - # Python packages don't have a checkPhase, only an installCheckPhase - doCheck = false; - doInstallCheck = attrs.doCheck or true; - nativeInstallCheckInputs = nativeCheckInputs; - installCheckInputs = checkInputs; - - postFixup = lib.optionalString (!dontWrapPythonPrograms) '' - wrapPythonPrograms - '' + attrs.postFixup or ""; - - # Python packages built through cross-compilation are always for the host platform. - disallowedReferences = lib.optionals (python.stdenv.hostPlatform != python.stdenv.buildPlatform) [ python.pythonOnBuildForHost ]; - - outputs = outputs ++ lib.optional withDistOutput "dist"; - - meta = { - # default to python's platforms - platforms = python.meta.platforms; - isBuildPythonPackage = python.meta.platforms; - } // meta; - } // lib.optionalAttrs (attrs?checkPhase) { - # If given use the specified checkPhase, otherwise use the setup hook. - # Longer-term we should get rid of `checkPhase` and use `installCheckPhase`. - installCheckPhase = attrs.checkPhase; - } // lib.optionalAttrs (disabledTestPaths != []) { - disabledTestPaths = lib.escapeShellArgs disabledTestPaths; - })); - - passthru.updateScript = let + self = toPythonModule ( + stdenv.mkDerivation ( + (builtins.removeAttrs attrs [ + "disabled" + "checkPhase" + "checkInputs" + "nativeCheckInputs" + "doCheck" + "doInstallCheck" + "dontWrapPythonPrograms" + "catchConflicts" + "format" + "disabledTestPaths" + "outputs" + ]) + // { + + name = namePrefix + name_; + + nativeBuildInputs = + [ + python + wrapPython + ensureNewerSourcesForZipFilesHook # move to wheel installer (pip) or builder (setuptools, ...)? + pythonRemoveTestsDirHook + ] + ++ lib.optionals catchConflicts [ + pythonCatchConflictsHook + ] + ++ lib.optionals removeBinBytecode [ + pythonRemoveBinBytecodeHook + ] + ++ lib.optionals (lib.hasSuffix "zip" (attrs.src.name or "")) [ + unzip + ] + ++ lib.optionals (format == "setuptools") [ + setuptoolsBuildHook + ] + ++ lib.optionals (format == "pyproject") [ + (pipBuildHook) + ] + ++ lib.optionals (format == "wheel") [ + wheelUnpackHook + ] + ++ lib.optionals (format == "egg") [ + eggUnpackHook + eggBuildHook + eggInstallHook + ] + ++ lib.optionals (format != "other") [ + (pipInstallHook) + ] + ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ + # This is a test, however, it should be ran independent of the checkPhase and checkInputs + pythonImportsCheckHook + ] + ++ lib.optionals withDistOutput [ + pythonOutputDistHook + ] + ++ nativeBuildInputs; + + buildInputs = validatePythonMatches "buildInputs" (buildInputs ++ pythonPath); + + propagatedBuildInputs = validatePythonMatches "propagatedBuildInputs" ( + propagatedBuildInputs + ++ [ + # we propagate python even for packages transformed with 'toPythonApplication' + # this pollutes the PATH but avoids rebuilds + # see https://github.com/NixOS/nixpkgs/issues/170887 for more context + python + ] + ); + + inherit strictDeps; + + LANG = "${if python.stdenv.hostPlatform.isDarwin then "en_US" else "C"}.UTF-8"; + + # Python packages don't have a checkPhase, only an installCheckPhase + doCheck = false; + doInstallCheck = attrs.doCheck or true; + nativeInstallCheckInputs = nativeCheckInputs; + installCheckInputs = checkInputs; + + postFixup = + lib.optionalString (!dontWrapPythonPrograms) '' + wrapPythonPrograms + '' + + attrs.postFixup or ""; + + # Python packages built through cross-compilation are always for the host platform. + disallowedReferences = lib.optionals (python.stdenv.hostPlatform != python.stdenv.buildPlatform) [ + python.pythonOnBuildForHost + ]; + + outputs = outputs ++ lib.optional withDistOutput "dist"; + + meta = { + # default to python's platforms + platforms = python.meta.platforms; + isBuildPythonPackage = python.meta.platforms; + } // meta; + } + // lib.optionalAttrs (attrs ? checkPhase) { + # If given use the specified checkPhase, otherwise use the setup hook. + # Longer-term we should get rid of `checkPhase` and use `installCheckPhase`. + installCheckPhase = attrs.checkPhase; + } + // lib.optionalAttrs (disabledTestPaths != [ ]) { + disabledTestPaths = lib.escapeShellArgs disabledTestPaths; + } + ) + ); + + passthru.updateScript = + let filename = builtins.head (lib.splitString ":" self.meta.position); - in attrs.passthru.updateScript or [ update-python-libraries filename ]; -in lib.extendDerivation - (disabled -> throw "${name} not supported for interpreter ${python.executable}") - passthru - self + in + attrs.passthru.updateScript or [ + update-python-libraries + filename + ]; +in +lib.extendDerivation ( + disabled -> throw "${name} not supported for interpreter ${python.executable}" +) passthru self diff --git a/pkgs/development/interpreters/python/rustpython/default.nix b/pkgs/development/interpreters/python/rustpython/default.nix index b63afe38148eea..bfd763a82578e8 100644 --- a/pkgs/development/interpreters/python/rustpython/default.nix +++ b/pkgs/development/interpreters/python/rustpython/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, SystemConfiguration -, python3 +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + SystemConfiguration, + python3, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/development/interpreters/python/setup-hook.nix b/pkgs/development/interpreters/python/setup-hook.nix index 8cfb9dd46784d4..364048484825b8 100644 --- a/pkgs/development/interpreters/python/setup-hook.nix +++ b/pkgs/development/interpreters/python/setup-hook.nix @@ -4,13 +4,16 @@ sitePackages: let hook = ./setup-hook.sh; -in runCommand "python-setup-hook.sh" { - strictDeps = true; - env = { - inherit sitePackages; - }; -} '' - cp ${hook} hook.sh - substituteAllInPlace hook.sh - mv hook.sh $out -'' +in +runCommand "python-setup-hook.sh" + { + strictDeps = true; + env = { + inherit sitePackages; + }; + } + '' + cp ${hook} hook.sh + substituteAllInPlace hook.sh + mv hook.sh $out + '' diff --git a/pkgs/development/interpreters/python/tests/test_cpython_gdb/default.nix b/pkgs/development/interpreters/python/tests/test_cpython_gdb/default.nix index 3d3bf549d91c10..80cb870f4551f2 100644 --- a/pkgs/development/interpreters/python/tests/test_cpython_gdb/default.nix +++ b/pkgs/development/interpreters/python/tests/test_cpython_gdb/default.nix @@ -1,4 +1,9 @@ -{ interpreter, gdb, writeText, runCommand }: +{ + interpreter, + gdb, + writeText, + runCommand, +}: let crashme-py = writeText "crashme.py" '' @@ -9,7 +14,8 @@ let sentinel_foo_bar() ''; -in runCommand "python-gdb" {} '' +in +runCommand "python-gdb" { } '' # test that gdb is able to recover the python stack frame of this segfault ${gdb}/bin/gdb -batch -ex 'set debug-file-directory ${interpreter.debug}/lib/debug' \ -ex 'source ${interpreter}/share/gdb/libpython.py' \ diff --git a/pkgs/development/interpreters/python/tests/test_nix_pythonprefix/default.nix b/pkgs/development/interpreters/python/tests/test_nix_pythonprefix/default.nix index 2030fab173a512..d7fb0f74793777 100644 --- a/pkgs/development/interpreters/python/tests/test_nix_pythonprefix/default.nix +++ b/pkgs/development/interpreters/python/tests/test_nix_pythonprefix/default.nix @@ -1,14 +1,23 @@ -{ interpreter, writeText, runCommand }: +{ + interpreter, + writeText, + runCommand, +}: let - python = let - packageOverrides = self: super: { - typeddep = self.callPackage ./typeddep {}; + python = + let + packageOverrides = self: super: { + typeddep = self.callPackage ./typeddep { }; + }; + in + interpreter.override { + inherit packageOverrides; + self = python; }; - in interpreter.override {inherit packageOverrides; self = python;}; - pythonEnv = python.withPackages(ps: [ + pythonEnv = python.withPackages (ps: [ ps.typeddep ps.mypy ]); @@ -19,7 +28,8 @@ let print(s) ''; -in runCommand "${interpreter.name}-site-prefix-mypy-test" {} '' +in +runCommand "${interpreter.name}-site-prefix-mypy-test" { } '' ${pythonEnv}/bin/mypy ${pythonScript} touch $out '' diff --git a/pkgs/development/interpreters/python/tests/test_nix_pythonprefix/typeddep/default.nix b/pkgs/development/interpreters/python/tests/test_nix_pythonprefix/typeddep/default.nix index fcb17dcbca381b..d82f4e45cf7b89 100644 --- a/pkgs/development/interpreters/python/tests/test_nix_pythonprefix/typeddep/default.nix +++ b/pkgs/development/interpreters/python/tests/test_nix_pythonprefix/typeddep/default.nix @@ -1,5 +1,8 @@ -{ lib, buildPythonPackage, pythonOlder }: - +{ + lib, + buildPythonPackage, + pythonOlder, +}: buildPythonPackage { diff --git a/pkgs/development/interpreters/python/tests/test_tkinter/default.nix b/pkgs/development/interpreters/python/tests/test_tkinter/default.nix index 67e67d2d1e97eb..21dc379d26ca4e 100644 --- a/pkgs/development/interpreters/python/tests/test_tkinter/default.nix +++ b/pkgs/development/interpreters/python/tests/test_tkinter/default.nix @@ -1,8 +1,12 @@ -{ interpreter, writeText, runCommand }: +{ + interpreter, + writeText, + runCommand, +}: let - pythonEnv = interpreter.withPackages(ps: [ + pythonEnv = interpreter.withPackages (ps: [ ps.tkinter ]); @@ -11,7 +15,8 @@ let print(tkinter) ''; -in runCommand "${interpreter.name}-tkinter-test" {} '' +in +runCommand "${interpreter.name}-tkinter-test" { } '' ${pythonEnv}/bin/python ${pythonScript} touch $out '' diff --git a/pkgs/development/interpreters/python/with-packages.nix b/pkgs/development/interpreters/python/with-packages.nix index e1de0b2ee4cadd..cd745ef5a3d0f7 100644 --- a/pkgs/development/interpreters/python/with-packages.nix +++ b/pkgs/development/interpreters/python/with-packages.nix @@ -1,3 +1,7 @@ { buildEnv, pythonPackages }: -f: let packages = f pythonPackages; in buildEnv.override { extraLibs = packages; } +f: +let + packages = f pythonPackages; +in +buildEnv.override { extraLibs = packages; } diff --git a/pkgs/development/interpreters/rakudo/default.nix b/pkgs/development/interpreters/rakudo/default.nix index 0a1ee9065a0a8e..fcd29b19d91d39 100644 --- a/pkgs/development/interpreters/rakudo/default.nix +++ b/pkgs/development/interpreters/rakudo/default.nix @@ -1,4 +1,14 @@ -{ stdenv, fetchFromGitHub, perl, icu, zlib, gmp, lib, nqp, removeReferencesTo }: +{ + stdenv, + fetchFromGitHub, + perl, + icu, + zlib, + gmp, + lib, + nqp, + removeReferencesTo, +}: stdenv.mkDerivation rec { pname = "rakudo"; @@ -15,7 +25,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ removeReferencesTo ]; - buildInputs = [ icu zlib gmp perl ]; + buildInputs = [ + icu + zlib + gmp + perl + ]; configureScript = "perl ./Configure.pl"; configureFlags = [ "--backends=moar" @@ -32,6 +47,9 @@ stdenv.mkDerivation rec { homepage = "https://rakudo.org"; license = licenses.artistic2; platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice sgo ]; + maintainers = with maintainers; [ + thoughtpolice + sgo + ]; }; } diff --git a/pkgs/development/interpreters/rakudo/moarvm.nix b/pkgs/development/interpreters/rakudo/moarvm.nix index 5537f13041d7db..9a09ff24839586 100644 --- a/pkgs/development/interpreters/rakudo/moarvm.nix +++ b/pkgs/development/interpreters/rakudo/moarvm.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, perl -, CoreServices -, ApplicationServices +{ + lib, + stdenv, + fetchFromGitHub, + perl, + CoreServices, + ApplicationServices, }: stdenv.mkDerivation rec { @@ -19,18 +20,25 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - postPatch = '' - patchShebangs . - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace Configure.pl \ - --replace '`/usr/bin/arch`' '"${stdenv.hostPlatform.darwinArch}"' \ - --replace '/usr/bin/arch' "$(type -P true)" \ - --replace '/usr/' '/nope/' - substituteInPlace 3rdparty/dyncall/configure \ - --replace '`sw_vers -productVersion`' '"11.0"' - ''; + postPatch = + '' + patchShebangs . + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace Configure.pl \ + --replace '`/usr/bin/arch`' '"${stdenv.hostPlatform.darwinArch}"' \ + --replace '/usr/bin/arch' "$(type -P true)" \ + --replace '/usr/' '/nope/' + substituteInPlace 3rdparty/dyncall/configure \ + --replace '`sw_vers -productVersion`' '"11.0"' + ''; - buildInputs = [ perl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices ApplicationServices ]; + buildInputs = + [ perl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + ApplicationServices + ]; doCheck = false; # MoarVM does not come with its own test suite configureScript = "${perl}/bin/perl ./Configure.pl"; @@ -39,7 +47,10 @@ stdenv.mkDerivation rec { description = "VM with adaptive optimization and JIT compilation, built for Rakudo"; homepage = "https://moarvm.org"; license = licenses.artistic2; - maintainers = with maintainers; [ thoughtpolice sgo ]; + maintainers = with maintainers; [ + thoughtpolice + sgo + ]; mainProgram = "moar"; platforms = platforms.unix; }; diff --git a/pkgs/development/interpreters/rakudo/nqp.nix b/pkgs/development/interpreters/rakudo/nqp.nix index 499e7cda3e280d..97471042402acd 100644 --- a/pkgs/development/interpreters/rakudo/nqp.nix +++ b/pkgs/development/interpreters/rakudo/nqp.nix @@ -1,4 +1,10 @@ -{ stdenv, fetchFromGitHub, perl, lib, moarvm }: +{ + stdenv, + fetchFromGitHub, + perl, + lib, + moarvm, +}: stdenv.mkDerivation rec { pname = "nqp"; @@ -38,6 +44,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/Raku/nqp"; license = licenses.artistic2; platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice sgo ]; + maintainers = with maintainers; [ + thoughtpolice + sgo + ]; }; } diff --git a/pkgs/development/interpreters/rakudo/zef.nix b/pkgs/development/interpreters/rakudo/zef.nix index abeb5ebb4cbba9..927c59d9bb239a 100644 --- a/pkgs/development/interpreters/rakudo/zef.nix +++ b/pkgs/development/interpreters/rakudo/zef.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, rakudo -, makeBinaryWrapper +{ + lib, + stdenv, + fetchFromGitHub, + rakudo, + makeBinaryWrapper, }: stdenv.mkDerivation (finalAttrs: { @@ -35,16 +36,16 @@ stdenv.mkDerivation (finalAttrs: { runHook postInstall ''; - postFixup ='' + postFixup = '' wrapProgram $out/bin/zef --prefix RAKUDOLIB , "inst#$out" ''; meta = { description = "Raku / Perl6 Module Management"; - homepage = "https://github.com/ugexe/zef"; - license = lib.licenses.artistic2; + homepage = "https://github.com/ugexe/zef"; + license = lib.licenses.artistic2; mainProgram = "zef"; maintainers = with lib.maintainers; [ sgo ]; - platforms = lib.platforms.unix; + platforms = lib.platforms.unix; }; }) diff --git a/pkgs/development/interpreters/ruby/default.nix b/pkgs/development/interpreters/ruby/default.nix index 11778cce06af7f..7834d4292939ed 100644 --- a/pkgs/development/interpreters/ruby/default.nix +++ b/pkgs/development/interpreters/ruby/default.nix @@ -1,303 +1,425 @@ -{ stdenv, buildPackages, lib -, fetchurl, fetchpatch, fetchFromSavannah -, zlib, gdbm, ncurses, readline, groff, libyaml, libffi, jemalloc, autoreconfHook, bison -, autoconf, libiconv, libobjc, libunwind, Foundation -, buildEnv, bundler, bundix, cargo, rustPlatform, rustc -, makeBinaryWrapper, buildRubyGem, defaultGemConfig, removeReferencesTo -, openssl -, linuxPackages, libsystemtap -, gitUpdater -} @ args: +{ + stdenv, + buildPackages, + lib, + fetchurl, + fetchpatch, + fetchFromSavannah, + zlib, + gdbm, + ncurses, + readline, + groff, + libyaml, + libffi, + jemalloc, + autoreconfHook, + bison, + autoconf, + libiconv, + libobjc, + libunwind, + Foundation, + buildEnv, + bundler, + bundix, + cargo, + rustPlatform, + rustc, + makeBinaryWrapper, + buildRubyGem, + defaultGemConfig, + removeReferencesTo, + openssl, + linuxPackages, + libsystemtap, + gitUpdater, +}@args: let op = lib.optional; ops = lib.optionals; opString = lib.optionalString; config = import ./config.nix { inherit fetchFromSavannah; }; - rubygems = import ./rubygems { inherit stdenv lib fetchurl gitUpdater; }; + rubygems = import ./rubygems { + inherit + stdenv + lib + fetchurl + gitUpdater + ; + }; # Contains the ruby version heuristics rubyVersion = import ./ruby-version.nix { inherit lib; }; - generic = { version, hash, cargoHash ? null }: let - ver = version; - atLeast31 = lib.versionAtLeast ver.majMin "3.1"; - atLeast32 = lib.versionAtLeast ver.majMin "3.2"; - # https://github.com/ruby/ruby/blob/v3_2_2/yjit.h#L21 - yjitSupported = atLeast32 && (stdenv.hostPlatform.isx86_64 || (!stdenv.hostPlatform.isWindows && stdenv.hostPlatform.isAarch64)); - rubyDrv = lib.makeOverridable ( - { stdenv, buildPackages, lib - , fetchurl, fetchpatch, fetchFromSavannah - , rubygemsSupport ? true - , zlib, zlibSupport ? true - , openssl, opensslSupport ? true - , gdbm, gdbmSupport ? true - , ncurses, readline, cursesSupport ? true - , groff, docSupport ? true - , libyaml, yamlSupport ? true - , libffi, fiddleSupport ? true - , jemalloc, jemallocSupport ? false - , linuxPackages, systemtap ? linuxPackages.systemtap, libsystemtap, dtraceSupport ? false - # By default, ruby has 3 observed references to stdenv.cc: - # - # - If you run: - # ruby -e "puts RbConfig::CONFIG['configure_args']" - # - In: - # $out/${passthru.libPath}/${stdenv.hostPlatform.system}/rbconfig.rb - # Or (usually): - # $(nix-build -A ruby)/lib/ruby/2.6.0/x86_64-linux/rbconfig.rb - # - In $out/lib/libruby.so and/or $out/lib/libruby.dylib - , removeReferencesTo, jitSupport ? yjitSupport - , cargo, rustPlatform, rustc, yjitSupport ? yjitSupported - , autoreconfHook, bison, autoconf - , buildEnv, bundler, bundix - , libiconv, libobjc, libunwind, Foundation - , makeBinaryWrapper, buildRubyGem, defaultGemConfig - , baseRuby ? buildPackages.ruby.override { - docSupport = false; - rubygemsSupport = false; - } - , useBaseRuby ? stdenv.hostPlatform != stdenv.buildPlatform - , gitUpdater - }: - stdenv.mkDerivation ( finalAttrs: { - pname = "ruby"; - inherit version; - - src = fetchurl { - url = "https://cache.ruby-lang.org/pub/ruby/${ver.majMin}/ruby-${ver}.tar.gz"; - inherit hash; - }; - - # Have `configure' avoid `/usr/bin/nroff' in non-chroot builds. - NROFF = if docSupport then "${groff}/bin/nroff" else null; - - outputs = [ "out" ] ++ lib.optional docSupport "devdoc"; - - strictDeps = true; - - nativeBuildInputs = [ autoreconfHook bison removeReferencesTo ] - ++ (op docSupport groff) - ++ (ops (dtraceSupport && stdenv.hostPlatform.isLinux) [ systemtap libsystemtap ]) - ++ ops yjitSupport [ rustPlatform.cargoSetupHook cargo rustc ] - ++ op useBaseRuby baseRuby; - buildInputs = [ autoconf ] - ++ (op fiddleSupport libffi) - ++ (ops cursesSupport [ ncurses readline ]) - ++ (op zlibSupport zlib) - ++ (op opensslSupport openssl) - ++ (op gdbmSupport gdbm) - ++ (op yamlSupport libyaml) - # Looks like ruby fails to build on darwin without readline even if curses - # support is not enabled, so add readline to the build inputs if curses - # support is disabled (if it's enabled, we already have it) and we're - # running on darwin - ++ op (!cursesSupport && stdenv.hostPlatform.isDarwin) readline - ++ ops stdenv.hostPlatform.isDarwin [ libiconv libobjc libunwind Foundation ]; - propagatedBuildInputs = op jemallocSupport jemalloc; - - enableParallelBuilding = true; - # /build/ruby-2.7.7/lib/fileutils.rb:882:in `chmod': - # No such file or directory @ apply2files - ...-ruby-2.7.7-devdoc/share/ri/2.7.0/system/ARGF/inspect-i.ri (Errno::ENOENT) - # make: *** [uncommon.mk:373: do-install-all] Error 1 - enableParallelInstalling = false; - - patches = op (lib.versionOlder ver.majMin "3.1") ./do-not-regenerate-revision.h.patch - ++ op useBaseRuby ( - if atLeast32 then ./do-not-update-gems-baseruby-3.2.patch - else ./do-not-update-gems-baseruby.patch - ) - ++ ops (ver.majMin == "3.0") [ - # Ruby 3.0 adds `-fdeclspec` to $CC instead of $CFLAGS. Fixed in later versions. - (fetchpatch { - url = "https://github.com/ruby/ruby/commit/0acc05caf7518cd0d63ab02bfa036455add02346.patch"; - hash = "sha256-43hI9L6bXfeujgmgKFVmiWhg7OXvshPCCtQ4TxqK1zk="; - }) - ] - ++ ops atLeast31 [ - # When using a baseruby, ruby always sets "libdir" to the build - # directory, which nix rejects due to a reference in to /build/ in - # the final product. Removing this reference doesn't seem to break - # anything and fixes cross compliation. - ./dont-refer-to-build-dir.patch - ]; - - cargoRoot = opString yjitSupport "yjit"; - - cargoDeps = if yjitSupport then rustPlatform.fetchCargoTarball { - inherit (finalAttrs) src; - sourceRoot = "${finalAttrs.pname}-${version}/${finalAttrs.cargoRoot}"; - hash = assert cargoHash != null; cargoHash; - } else null; - - postUnpack = opString rubygemsSupport '' - rm -rf $sourceRoot/{lib,test}/rubygems* - cp -r ${rubygems}/lib/rubygems* $sourceRoot/lib - ''; - - postPatch = '' - sed -i configure.ac -e '/config.guess/d' - cp --remove-destination ${config}/config.guess tool/ - cp --remove-destination ${config}/config.sub tool/ - ''; - - configureFlags = [ - (lib.enableFeature (!stdenv.hostPlatform.isStatic) "shared") - (lib.enableFeature true "pthread") - (lib.withFeatureAs true "soname" "ruby-${version}") - (lib.withFeatureAs useBaseRuby "baseruby" "${baseRuby}/bin/ruby") - (lib.enableFeature dtraceSupport "dtrace") - (lib.enableFeature jitSupport "jit-support") - (lib.enableFeature yjitSupport "yjit") - (lib.enableFeature docSupport "install-doc") - (lib.withFeature jemallocSupport "jemalloc") - (lib.withFeatureAs docSupport "ridir" "${placeholder "devdoc"}/share/ri") - # ruby enables -O3 for gcc, however our compiler hardening wrapper - # overrides that by enabling `-O2` which is the minimum optimization - # needed for `_FORTIFY_SOURCE`. - ] ++ lib.optional stdenv.cc.isGNU "CFLAGS=-O3" ++ [ - ] ++ ops stdenv.hostPlatform.isDarwin [ - # on darwin, we have /usr/include/tk.h -- so the configure script detects - # that tk is installed - "--with-out-ext=tk" - # on yosemite, "generating encdb.h" will hang for a very long time without this flag - "--with-setjmp-type=setjmp" - ] ++ ops stdenv.hostPlatform.isFreeBSD [ - "rb_cv_gnu_qsort_r=no" - "rb_cv_bsd_qsort_r=yes" - ]; - - preConfigure = opString docSupport '' - # rdoc creates XDG_DATA_DIR (defaulting to $HOME/.local/share) even if - # it's not going to be used. - export HOME=$TMPDIR - ''; - - # fails with "16993 tests, 2229489 assertions, 105 failures, 14 errors, 89 skips" - # mostly TZ- and patch-related tests - # TZ- failures are caused by nix sandboxing, I didn't investigate others - doCheck = false; - - preInstall = '' - # Ruby installs gems here itself now. - mkdir -pv "$out/${finalAttrs.passthru.gemPath}" - export GEM_HOME="$out/${finalAttrs.passthru.gemPath}" - ''; - - installFlags = lib.optional docSupport "install-doc"; - # Bundler tries to create this directory - postInstall = '' - rbConfig=$(find $out/lib/ruby -name rbconfig.rb) - # Remove references to the build environment from the closure - sed -i '/^ CONFIG\["\(BASERUBY\|SHELL\|GREP\|EGREP\|MKDIR_P\|MAKEDIRS\|INSTALL\)"\]/d' $rbConfig - # Remove unnecessary groff reference from runtime closure, since it's big - sed -i '/NROFF/d' $rbConfig - ${ - lib.optionalString (!jitSupport) '' - # Get rid of the CC runtime dependency - remove-references-to \ - -t ${stdenv.cc} \ - $out/lib/libruby* - remove-references-to \ - -t ${stdenv.cc} \ - $rbConfig - sed -i '/CC_VERSION_MESSAGE/d' $rbConfig - '' - } - - # Allow to override compiler. This is important for cross compiling as - # we need to set a compiler that is different from the build one. - sed -i "$rbConfig" \ - -e 's/CONFIG\["CC"\] = "\(.*\)"/CONFIG["CC"] = if ENV["CC"].nil? || ENV["CC"].empty? then "\1" else ENV["CC"] end/' \ - -e 's/CONFIG\["CXX"\] = "\(.*\)"/CONFIG["CXX"] = if ENV["CXX"].nil? || ENV["CXX"].empty? then "\1" else ENV["CXX"] end/' - - # Remove unnecessary external intermediate files created by gems - extMakefiles=$(find $out/${finalAttrs.passthru.gemPath} -name Makefile) - for makefile in $extMakefiles; do - make -C "$(dirname "$makefile")" distclean - done - find "$out/${finalAttrs.passthru.gemPath}" \( -name gem_make.out -o -name mkmf.log -o -name exts.mk \) -delete + generic = + { + version, + hash, + cargoHash ? null, + }: + let + ver = version; + atLeast31 = lib.versionAtLeast ver.majMin "3.1"; + atLeast32 = lib.versionAtLeast ver.majMin "3.2"; + # https://github.com/ruby/ruby/blob/v3_2_2/yjit.h#L21 + yjitSupported = + atLeast32 + && ( + stdenv.hostPlatform.isx86_64 || (!stdenv.hostPlatform.isWindows && stdenv.hostPlatform.isAarch64) + ); + rubyDrv = lib.makeOverridable ( + { + stdenv, + buildPackages, + lib, + fetchurl, + fetchpatch, + fetchFromSavannah, + rubygemsSupport ? true, + zlib, + zlibSupport ? true, + openssl, + opensslSupport ? true, + gdbm, + gdbmSupport ? true, + ncurses, + readline, + cursesSupport ? true, + groff, + docSupport ? true, + libyaml, + yamlSupport ? true, + libffi, + fiddleSupport ? true, + jemalloc, + jemallocSupport ? false, + linuxPackages, + systemtap ? linuxPackages.systemtap, + libsystemtap, + dtraceSupport ? false, + # By default, ruby has 3 observed references to stdenv.cc: + # + # - If you run: + # ruby -e "puts RbConfig::CONFIG['configure_args']" + # - In: + # $out/${passthru.libPath}/${stdenv.hostPlatform.system}/rbconfig.rb + # Or (usually): + # $(nix-build -A ruby)/lib/ruby/2.6.0/x86_64-linux/rbconfig.rb + # - In $out/lib/libruby.so and/or $out/lib/libruby.dylib + removeReferencesTo, + jitSupport ? yjitSupport, + cargo, + rustPlatform, + rustc, + yjitSupport ? yjitSupported, + autoreconfHook, + bison, + autoconf, + buildEnv, + bundler, + bundix, + libiconv, + libobjc, + libunwind, + Foundation, + makeBinaryWrapper, + buildRubyGem, + defaultGemConfig, + baseRuby ? buildPackages.ruby.override { + docSupport = false; + rubygemsSupport = false; + }, + useBaseRuby ? stdenv.hostPlatform != stdenv.buildPlatform, + gitUpdater, + }: + stdenv.mkDerivation (finalAttrs: { + pname = "ruby"; + inherit version; + + src = fetchurl { + url = "https://cache.ruby-lang.org/pub/ruby/${ver.majMin}/ruby-${ver}.tar.gz"; + inherit hash; + }; + + # Have `configure' avoid `/usr/bin/nroff' in non-chroot builds. + NROFF = if docSupport then "${groff}/bin/nroff" else null; + + outputs = [ "out" ] ++ lib.optional docSupport "devdoc"; + + strictDeps = true; + + nativeBuildInputs = + [ + autoreconfHook + bison + removeReferencesTo + ] + ++ (op docSupport groff) + ++ (ops (dtraceSupport && stdenv.hostPlatform.isLinux) [ + systemtap + libsystemtap + ]) + ++ ops yjitSupport [ + rustPlatform.cargoSetupHook + cargo + rustc + ] + ++ op useBaseRuby baseRuby; + buildInputs = + [ autoconf ] + ++ (op fiddleSupport libffi) + ++ (ops cursesSupport [ + ncurses + readline + ]) + ++ (op zlibSupport zlib) + ++ (op opensslSupport openssl) + ++ (op gdbmSupport gdbm) + ++ (op yamlSupport libyaml) + # Looks like ruby fails to build on darwin without readline even if curses + # support is not enabled, so add readline to the build inputs if curses + # support is disabled (if it's enabled, we already have it) and we're + # running on darwin + ++ op (!cursesSupport && stdenv.hostPlatform.isDarwin) readline + ++ ops stdenv.hostPlatform.isDarwin [ + libiconv + libobjc + libunwind + Foundation + ]; + propagatedBuildInputs = op jemallocSupport jemalloc; + + enableParallelBuilding = true; + # /build/ruby-2.7.7/lib/fileutils.rb:882:in `chmod': + # No such file or directory @ apply2files - ...-ruby-2.7.7-devdoc/share/ri/2.7.0/system/ARGF/inspect-i.ri (Errno::ENOENT) + # make: *** [uncommon.mk:373: do-install-all] Error 1 + enableParallelInstalling = false; + + patches = + op (lib.versionOlder ver.majMin "3.1") ./do-not-regenerate-revision.h.patch + ++ op useBaseRuby ( + if atLeast32 then ./do-not-update-gems-baseruby-3.2.patch else ./do-not-update-gems-baseruby.patch + ) + ++ ops (ver.majMin == "3.0") [ + # Ruby 3.0 adds `-fdeclspec` to $CC instead of $CFLAGS. Fixed in later versions. + (fetchpatch { + url = "https://github.com/ruby/ruby/commit/0acc05caf7518cd0d63ab02bfa036455add02346.patch"; + hash = "sha256-43hI9L6bXfeujgmgKFVmiWhg7OXvshPCCtQ4TxqK1zk="; + }) + ] + ++ ops atLeast31 [ + # When using a baseruby, ruby always sets "libdir" to the build + # directory, which nix rejects due to a reference in to /build/ in + # the final product. Removing this reference doesn't seem to break + # anything and fixes cross compliation. + ./dont-refer-to-build-dir.patch + ]; + + cargoRoot = opString yjitSupport "yjit"; + + cargoDeps = + if yjitSupport then + rustPlatform.fetchCargoTarball { + inherit (finalAttrs) src; + sourceRoot = "${finalAttrs.pname}-${version}/${finalAttrs.cargoRoot}"; + hash = + assert cargoHash != null; + cargoHash; + } + else + null; + + postUnpack = opString rubygemsSupport '' + rm -rf $sourceRoot/{lib,test}/rubygems* + cp -r ${rubygems}/lib/rubygems* $sourceRoot/lib + ''; + + postPatch = '' + sed -i configure.ac -e '/config.guess/d' + cp --remove-destination ${config}/config.guess tool/ + cp --remove-destination ${config}/config.sub tool/ + ''; + + configureFlags = + [ + (lib.enableFeature (!stdenv.hostPlatform.isStatic) "shared") + (lib.enableFeature true "pthread") + (lib.withFeatureAs true "soname" "ruby-${version}") + (lib.withFeatureAs useBaseRuby "baseruby" "${baseRuby}/bin/ruby") + (lib.enableFeature dtraceSupport "dtrace") + (lib.enableFeature jitSupport "jit-support") + (lib.enableFeature yjitSupport "yjit") + (lib.enableFeature docSupport "install-doc") + (lib.withFeature jemallocSupport "jemalloc") + (lib.withFeatureAs docSupport "ridir" "${placeholder "devdoc"}/share/ri") + # ruby enables -O3 for gcc, however our compiler hardening wrapper + # overrides that by enabling `-O2` which is the minimum optimization + # needed for `_FORTIFY_SOURCE`. + ] + ++ lib.optional stdenv.cc.isGNU "CFLAGS=-O3" + ++ [ + ] + ++ ops stdenv.hostPlatform.isDarwin [ + # on darwin, we have /usr/include/tk.h -- so the configure script detects + # that tk is installed + "--with-out-ext=tk" + # on yosemite, "generating encdb.h" will hang for a very long time without this flag + "--with-setjmp-type=setjmp" + ] + ++ ops stdenv.hostPlatform.isFreeBSD [ + "rb_cv_gnu_qsort_r=no" + "rb_cv_bsd_qsort_r=yes" + ]; + + preConfigure = opString docSupport '' + # rdoc creates XDG_DATA_DIR (defaulting to $HOME/.local/share) even if + # it's not going to be used. + export HOME=$TMPDIR + ''; + + # fails with "16993 tests, 2229489 assertions, 105 failures, 14 errors, 89 skips" + # mostly TZ- and patch-related tests + # TZ- failures are caused by nix sandboxing, I didn't investigate others + doCheck = false; + + preInstall = '' + # Ruby installs gems here itself now. + mkdir -pv "$out/${finalAttrs.passthru.gemPath}" + export GEM_HOME="$out/${finalAttrs.passthru.gemPath}" + ''; + + installFlags = lib.optional docSupport "install-doc"; # Bundler tries to create this directory - mkdir -p $out/nix-support - cat > $out/nix-support/setup-hook <&2 - false - fi - - fallback_cc=$(unset CC; $out/bin/ruby -rrbconfig -e 'puts RbConfig::CONFIG["CC"]') - if [[ "$fallback_cc" != "$CC" ]]; then - echo "CC='$fallback_cc' should be '$CC' by default" >&2 - false - fi - ''; - doInstallCheck = true; - - disallowedRequisites = op (!jitSupport) stdenv.cc - ++ op useBaseRuby baseRuby; - - meta = with lib; { - description = "Object-oriented language for quick and easy programming"; - homepage = "https://www.ruby-lang.org/"; - license = licenses.ruby; - maintainers = with maintainers; [ manveru ]; - platforms = platforms.all; - mainProgram = "ruby"; - knownVulnerabilities = op (lib.versionOlder ver.majMin "3.0") "This Ruby release has reached its end of life. See https://www.ruby-lang.org/en/downloads/branches/."; - }; - - passthru = rec { - version = ver; - rubyEngine = "ruby"; - libPath = "lib/${rubyEngine}/${ver.libDir}"; - gemPath = "lib/${rubyEngine}/gems/${ver.libDir}"; - devEnv = import ./dev.nix { - inherit buildEnv bundler bundix; - ruby = finalAttrs.finalPackage; + postInstall = + '' + rbConfig=$(find $out/lib/ruby -name rbconfig.rb) + # Remove references to the build environment from the closure + sed -i '/^ CONFIG\["\(BASERUBY\|SHELL\|GREP\|EGREP\|MKDIR_P\|MAKEDIRS\|INSTALL\)"\]/d' $rbConfig + # Remove unnecessary groff reference from runtime closure, since it's big + sed -i '/NROFF/d' $rbConfig + ${lib.optionalString (!jitSupport) '' + # Get rid of the CC runtime dependency + remove-references-to \ + -t ${stdenv.cc} \ + $out/lib/libruby* + remove-references-to \ + -t ${stdenv.cc} \ + $rbConfig + sed -i '/CC_VERSION_MESSAGE/d' $rbConfig + ''} + + # Allow to override compiler. This is important for cross compiling as + # we need to set a compiler that is different from the build one. + sed -i "$rbConfig" \ + -e 's/CONFIG\["CC"\] = "\(.*\)"/CONFIG["CC"] = if ENV["CC"].nil? || ENV["CC"].empty? then "\1" else ENV["CC"] end/' \ + -e 's/CONFIG\["CXX"\] = "\(.*\)"/CONFIG["CXX"] = if ENV["CXX"].nil? || ENV["CXX"].empty? then "\1" else ENV["CXX"] end/' + + # Remove unnecessary external intermediate files created by gems + extMakefiles=$(find $out/${finalAttrs.passthru.gemPath} -name Makefile) + for makefile in $extMakefiles; do + make -C "$(dirname "$makefile")" distclean + done + find "$out/${finalAttrs.passthru.gemPath}" \( -name gem_make.out -o -name mkmf.log -o -name exts.mk \) -delete + # Bundler tries to create this directory + mkdir -p $out/nix-support + cat > $out/nix-support/setup-hook <&2 + false + fi + + fallback_cc=$(unset CC; $out/bin/ruby -rrbconfig -e 'puts RbConfig::CONFIG["CC"]') + if [[ "$fallback_cc" != "$CC" ]]; then + echo "CC='$fallback_cc' should be '$CC' by default" >&2 + false + fi + ''; + doInstallCheck = true; + + disallowedRequisites = op (!jitSupport) stdenv.cc ++ op useBaseRuby baseRuby; + + meta = with lib; { + description = "Object-oriented language for quick and easy programming"; + homepage = "https://www.ruby-lang.org/"; + license = licenses.ruby; + maintainers = with maintainers; [ manveru ]; + platforms = platforms.all; + mainProgram = "ruby"; + knownVulnerabilities = op (lib.versionOlder ver.majMin "3.0") "This Ruby release has reached its end of life. See https://www.ruby-lang.org/en/downloads/branches/."; }; - inherit rubygems; - inherit (import ../../ruby-modules/with-packages { - inherit lib stdenv makeBinaryWrapper buildRubyGem buildEnv; - gemConfig = defaultGemConfig; - ruby = finalAttrs.finalPackage; - }) withPackages buildGems gems; - } // lib.optionalAttrs useBaseRuby { - inherit baseRuby; - }; - } ) - ) args; in rubyDrv; - -in { + passthru = + rec { + version = ver; + rubyEngine = "ruby"; + libPath = "lib/${rubyEngine}/${ver.libDir}"; + gemPath = "lib/${rubyEngine}/gems/${ver.libDir}"; + devEnv = import ./dev.nix { + inherit buildEnv bundler bundix; + ruby = finalAttrs.finalPackage; + }; + + inherit rubygems; + inherit + (import ../../ruby-modules/with-packages { + inherit + lib + stdenv + makeBinaryWrapper + buildRubyGem + buildEnv + ; + gemConfig = defaultGemConfig; + ruby = finalAttrs.finalPackage; + }) + withPackages + buildGems + gems + ; + } + // lib.optionalAttrs useBaseRuby { + inherit baseRuby; + }; + }) + ) args; + in + rubyDrv; + +in +{ mkRubyVersion = rubyVersion; mkRuby = generic; diff --git a/pkgs/development/interpreters/ruby/dev.nix b/pkgs/development/interpreters/ruby/dev.nix index dea21118b20010..cd37d3a324e8e8 100644 --- a/pkgs/development/interpreters/ruby/dev.nix +++ b/pkgs/development/interpreters/ruby/dev.nix @@ -1,8 +1,14 @@ -/* An environment for development that bundles ruby, bundler and bundix - together. This avoids version conflicts where each is using a different - version of each-other. +/* + An environment for development that bundles ruby, bundler and bundix + together. This avoids version conflicts where each is using a different + version of each-other. */ -{ buildEnv, ruby, bundler, bundix }: +{ + buildEnv, + ruby, + bundler, + bundix, +}: let bundler_ = bundler.override { ruby = ruby; diff --git a/pkgs/development/interpreters/ruby/ruby-version.nix b/pkgs/development/interpreters/ruby/ruby-version.nix index 57fa60aea28c07..8b8bebc9ec42da 100644 --- a/pkgs/development/interpreters/ruby/ruby-version.nix +++ b/pkgs/development/interpreters/ruby/ruby-version.nix @@ -3,61 +3,89 @@ let # The returned set should be immutable - rubyVersion = major: minor: tiny: tail: - rec { - inherit major minor tiny tail; + rubyVersion = major: minor: tiny: tail: rec { + inherit + major + minor + tiny + tail + ; - # Contains the patch number "223" if tail is "p223" or null - patchLevel = - let - p = lib.removePrefix "p" tail; - isPosInt = num: - 0 == lib.stringLength - (lib.replaceStrings - ["0" "1" "2" "3" "4" "5" "6" "7" "8" "9"] - ["" "" "" "" "" "" "" "" "" "" ] - num); - in - if lib.hasPrefix "p" tail && isPosInt p then p - else null; + # Contains the patch number "223" if tail is "p223" or null + patchLevel = + let + p = lib.removePrefix "p" tail; + isPosInt = + num: + 0 == lib.stringLength ( + lib.replaceStrings + [ + "0" + "1" + "2" + "3" + "4" + "5" + "6" + "7" + "8" + "9" + ] + [ + "" + "" + "" + "" + "" + "" + "" + "" + "" + "" + ] + num + ); + in + if lib.hasPrefix "p" tail && isPosInt p then p else null; - # Shortcuts - majMin = "${major}.${minor}"; - majMinTiny = "${major}.${minor}.${tiny}"; + # Shortcuts + majMin = "${major}.${minor}"; + majMinTiny = "${major}.${minor}.${tiny}"; - # Ruby separates lib and gem folders by ABI version which isn't very - # consistent. - libDir = - if lib.versionAtLeast majMinTiny "2.1.0" then - "${majMin}.0" - else if lib.versionAtLeast majMinTiny "2.0.0" then - "2.0.0" - else if lib.versionAtLeast majMinTiny "1.9.1" then - "1.9.1" - else - throw "version ${majMinTiny} is not supported"; + # Ruby separates lib and gem folders by ABI version which isn't very + # consistent. + libDir = + if lib.versionAtLeast majMinTiny "2.1.0" then + "${majMin}.0" + else if lib.versionAtLeast majMinTiny "2.0.0" then + "2.0.0" + else if lib.versionAtLeast majMinTiny "1.9.1" then + "1.9.1" + else + throw "version ${majMinTiny} is not supported"; - # How ruby releases are tagged on github.com/ruby/ruby - gitTag = - let - base = "v${major}_${minor}_${tiny}"; - in - if patchLevel != null then - "${base}_${patchLevel}" - else - if tail != "" then - "${base}_${tail}" - else - base; + # How ruby releases are tagged on github.com/ruby/ruby + gitTag = + let + base = "v${major}_${minor}_${tiny}"; + in + if patchLevel != null then + "${base}_${patchLevel}" + else if tail != "" then + "${base}_${tail}" + else + base; - # Implements the builtins.toString interface. - __toString = self: - self.majMinTiny + ( - if self.patchLevel != null then - "-p${self.patchLevel}" - else - lib.optionalString (self.tail != "") "-${self.tail}" - ); - }; + # Implements the builtins.toString interface. + __toString = + self: + self.majMinTiny + + ( + if self.patchLevel != null then + "-p${self.patchLevel}" + else + lib.optionalString (self.tail != "") "-${self.tail}" + ); + }; in - rubyVersion +rubyVersion diff --git a/pkgs/development/interpreters/ruby/rubygems/default.nix b/pkgs/development/interpreters/ruby/rubygems/default.nix index 9c56917ef5f29e..3269f4cdf2bf6f 100644 --- a/pkgs/development/interpreters/ruby/rubygems/default.nix +++ b/pkgs/development/interpreters/ruby/rubygems/default.nix @@ -36,7 +36,10 @@ stdenv.mkDerivation rec { description = "Package management framework for Ruby"; changelog = "https://github.com/rubygems/rubygems/blob/v${version}/CHANGELOG.md"; homepage = "https://rubygems.org/"; - license = with licenses; [ mit /* or */ ruby ]; + license = with licenses; [ + mit # or + ruby + ]; mainProgram = "gem"; maintainers = with maintainers; [ zimbatm ]; }; diff --git a/pkgs/development/interpreters/spidermonkey/common.nix b/pkgs/development/interpreters/spidermonkey/common.nix index 5feca82f6cf139..ba6861839386e3 100644 --- a/pkgs/development/interpreters/spidermonkey/common.nix +++ b/pkgs/development/interpreters/spidermonkey/common.nix @@ -1,124 +1,139 @@ { version, hash }: -{ callPackage -, lib -, stdenv -, fetchurl -, fetchpatch - -# build time -, buildPackages -, cargo -, m4 -, perl -, pkg-config -, python3 -, python39 -, python311 -, rust-cbindgen -, rustPlatform -, rustc -, which -, zip -, autoconf213 -, yasm -, xcbuild - -# runtime -, icu -, icu67 -, nspr -, readline -, zlib -, libobjc -, libiconv +{ + callPackage, + lib, + stdenv, + fetchurl, + fetchpatch, + + # build time + buildPackages, + cargo, + m4, + perl, + pkg-config, + python3, + python39, + python311, + rust-cbindgen, + rustPlatform, + rustc, + which, + zip, + autoconf213, + yasm, + xcbuild, + + # runtime + icu, + icu67, + nspr, + readline, + zlib, + libobjc, + libiconv, }: stdenv.mkDerivation (finalAttrs: rec { pname = "spidermonkey"; inherit version; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://mozilla/firefox/releases/${version}esr/source/firefox-${version}esr.source.tar.xz"; inherit hash; }; - patches = lib.optionals (lib.versionOlder version "91") [ - # Fix build failure on armv7l using Debian patch - # Upstream bug: https://bugzilla.mozilla.org/show_bug.cgi?id=1526653 - (fetchpatch { - url = "https://salsa.debian.org/mozilla-team/firefox/commit/fd6847c9416f9eebde636e21d794d25d1be8791d.patch"; - hash = "sha512-K8U3Qyo7g4si2r/8kJdXyRoTrDHAY48x/YJ7YL+YBwlpfNQcHxX+EZvhRzW8FHYW+f7kOnJu9QykhE8PhSQ9zQ=="; - }) - - # Remove this when updating to 79 - The patches are already applied upstream - # https://bugzilla.mozilla.org/show_bug.cgi?id=1318905 - - # Combination of 3 changesets, modified to apply on 78: - # - https://hg.mozilla.org/mozilla-central/rev/06d7e1b6b7e7 - # - https://hg.mozilla.org/mozilla-central/rev/ec48f15d085c - # - https://hg.mozilla.org/mozilla-central/rev/6803dda74d33 - ./add-riscv64-support.patch - ] ++ lib.optionals (lib.versionAtLeast version "102" && lib.versionOlder version "128") [ - # use pkg-config at all systems - ./always-check-for-pkg-config.patch - ./allow-system-s-nspr-and-icu-on-bootstrapped-sysroot.patch - ] ++ lib.optionals (lib.versionAtLeast version "128") [ - # rebased version of the above 2 patches - ./always-check-for-pkg-config-128.patch - ./allow-system-s-nspr-and-icu-on-bootstrapped-sysroot-128.patch - ] ++ lib.optionals (lib.versionAtLeast version "91" && stdenv.hostPlatform.system == "i686-linux") [ - # Fixes i686 build, https://bugzilla.mozilla.org/show_bug.cgi?id=1729459 - ./fix-float-i686.patch - ] ++ lib.optionals (lib.versionAtLeast version "91" && lib.versionOlder version "102") [ - # Fix 91 compatibility with python311 - (fetchpatch { - url = "https://src.fedoraproject.org/rpms/mozjs91/raw/e3729167646775e60a3d8c602c0412e04f206baf/f/0001-Python-Build-Use-r-instead-of-rU-file-read-modes.patch"; - hash = "sha256-WgDIBidB9XNQ/+HacK7jxWnjOF8PEUt5eB0+Aubtl48="; - }) - ]; - - nativeBuildInputs = [ - cargo - m4 - perl - pkg-config - # 78 requires python up to 3.9 - # 91 does not build with python 3.12: ModuleNotFoundError: No module named 'six.moves' - # 102 does not build with python 3.12: ModuleNotFoundError: No module named 'distutils' - ( - if lib.versionOlder version "91" then - python39 - else if lib.versionOlder version "115" then - python311 - else - python3 - ) - rustc - rustc.llvmPackages.llvm # for llvm-objdump - which - zip - ] ++ lib.optionals (lib.versionAtLeast version "128") [ - rust-cbindgen - rustPlatform.bindgenHook - ] ++ lib.optionals (lib.versionOlder version "91") [ - autoconf213 - yasm # to buid icu? seems weird - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - xcbuild - ]; - - buildInputs = [ - (if lib.versionOlder version "91" then icu67 else icu) - nspr - readline - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libobjc - libiconv - ]; + patches = + lib.optionals (lib.versionOlder version "91") [ + # Fix build failure on armv7l using Debian patch + # Upstream bug: https://bugzilla.mozilla.org/show_bug.cgi?id=1526653 + (fetchpatch { + url = "https://salsa.debian.org/mozilla-team/firefox/commit/fd6847c9416f9eebde636e21d794d25d1be8791d.patch"; + hash = "sha512-K8U3Qyo7g4si2r/8kJdXyRoTrDHAY48x/YJ7YL+YBwlpfNQcHxX+EZvhRzW8FHYW+f7kOnJu9QykhE8PhSQ9zQ=="; + }) + + # Remove this when updating to 79 - The patches are already applied upstream + # https://bugzilla.mozilla.org/show_bug.cgi?id=1318905 + + # Combination of 3 changesets, modified to apply on 78: + # - https://hg.mozilla.org/mozilla-central/rev/06d7e1b6b7e7 + # - https://hg.mozilla.org/mozilla-central/rev/ec48f15d085c + # - https://hg.mozilla.org/mozilla-central/rev/6803dda74d33 + ./add-riscv64-support.patch + ] + ++ lib.optionals (lib.versionAtLeast version "102" && lib.versionOlder version "128") [ + # use pkg-config at all systems + ./always-check-for-pkg-config.patch + ./allow-system-s-nspr-and-icu-on-bootstrapped-sysroot.patch + ] + ++ lib.optionals (lib.versionAtLeast version "128") [ + # rebased version of the above 2 patches + ./always-check-for-pkg-config-128.patch + ./allow-system-s-nspr-and-icu-on-bootstrapped-sysroot-128.patch + ] + ++ lib.optionals (lib.versionAtLeast version "91" && stdenv.hostPlatform.system == "i686-linux") [ + # Fixes i686 build, https://bugzilla.mozilla.org/show_bug.cgi?id=1729459 + ./fix-float-i686.patch + ] + ++ lib.optionals (lib.versionAtLeast version "91" && lib.versionOlder version "102") [ + # Fix 91 compatibility with python311 + (fetchpatch { + url = "https://src.fedoraproject.org/rpms/mozjs91/raw/e3729167646775e60a3d8c602c0412e04f206baf/f/0001-Python-Build-Use-r-instead-of-rU-file-read-modes.patch"; + hash = "sha256-WgDIBidB9XNQ/+HacK7jxWnjOF8PEUt5eB0+Aubtl48="; + }) + ]; + + nativeBuildInputs = + [ + cargo + m4 + perl + pkg-config + # 78 requires python up to 3.9 + # 91 does not build with python 3.12: ModuleNotFoundError: No module named 'six.moves' + # 102 does not build with python 3.12: ModuleNotFoundError: No module named 'distutils' + ( + if lib.versionOlder version "91" then + python39 + else if lib.versionOlder version "115" then + python311 + else + python3 + ) + rustc + rustc.llvmPackages.llvm # for llvm-objdump + which + zip + ] + ++ lib.optionals (lib.versionAtLeast version "128") [ + rust-cbindgen + rustPlatform.bindgenHook + ] + ++ lib.optionals (lib.versionOlder version "91") [ + autoconf213 + yasm # to buid icu? seems weird + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + xcbuild + ]; + + buildInputs = + [ + (if lib.versionOlder version "91" then icu67 else icu) + nspr + readline + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + libiconv + ]; depsBuildBuild = [ buildPackages.stdenv.cc @@ -126,29 +141,32 @@ stdenv.mkDerivation (finalAttrs: rec { setOutputFlags = false; # Configure script only understands --includedir - configureFlags = [ - "--with-intl-api" - "--with-system-icu" - "--with-system-nspr" - "--with-system-zlib" - # Fedora and Arch disable optimize, but it doesn't seme to be necessary - # It turns on -O3 which some gcc version had a problem with: - # https://src.fedoraproject.org/rpms/mozjs38/c/761399aba092bcb1299bb4fccfd60f370ab4216e - "--enable-optimize" - "--enable-readline" - "--enable-release" - "--enable-shared-js" - ] ++ lib.optionals (lib.versionAtLeast version "91") [ - "--disable-debug" - ] ++ [ - "--disable-jemalloc" - "--disable-strip" - "--disable-tests" - # Spidermonkey seems to use different host/build terminology for cross - # compilation here. - "--host=${stdenv.buildPlatform.config}" - "--target=${stdenv.hostPlatform.config}" - ]; + configureFlags = + [ + "--with-intl-api" + "--with-system-icu" + "--with-system-nspr" + "--with-system-zlib" + # Fedora and Arch disable optimize, but it doesn't seme to be necessary + # It turns on -O3 which some gcc version had a problem with: + # https://src.fedoraproject.org/rpms/mozjs38/c/761399aba092bcb1299bb4fccfd60f370ab4216e + "--enable-optimize" + "--enable-readline" + "--enable-release" + "--enable-shared-js" + ] + ++ lib.optionals (lib.versionAtLeast version "91") [ + "--disable-debug" + ] + ++ [ + "--disable-jemalloc" + "--disable-strip" + "--disable-tests" + # Spidermonkey seems to use different host/build terminology for cross + # compilation here. + "--host=${stdenv.buildPlatform.config}" + "--target=${stdenv.hostPlatform.config}" + ]; # mkDerivation by default appends --build/--host to configureFlags when cross compiling # These defaults are bogus for Spidermonkey - avoid passing them by providing an empty list @@ -158,7 +176,9 @@ stdenv.mkDerivation (finalAttrs: rec { # cc-rs insists on using -mabi=lp64 (soft-float) for riscv64, # while we have a double-float toolchain - env.NIX_CFLAGS_COMPILE = lib.optionalString (with stdenv.hostPlatform; isRiscV && is64bit && lib.versionOlder version "91") "-mabi=lp64d"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + with stdenv.hostPlatform; isRiscV && is64bit && lib.versionOlder version "91" + ) "-mabi=lp64d"; postPatch = lib.optionalString (lib.versionOlder version "102") '' # This patch is a manually applied fix of @@ -170,32 +190,39 @@ stdenv.mkDerivation (finalAttrs: rec { "class JS_PUBLIC_API SharedArrayRawBufferRefs {" ''; - preConfigure = lib.optionalString (lib.versionAtLeast version "128") '' - export MOZBUILD_STATE_PATH=$TMPDIR/mozbuild - '' + lib.optionalString (lib.versionOlder version "91") '' - export CXXFLAGS="-fpermissive" - '' + '' - export LIBXUL_DIST=$out - export PYTHON="${buildPackages.python3.interpreter}" - '' + lib.optionalString (lib.versionAtLeast version "91") '' - export M4=m4 - export AWK=awk - export AS=$CC - export AC_MACRODIR=$PWD/build/autoconf/ - - '' + lib.optionalString (lib.versionAtLeast version "91" && lib.versionOlder version "115") '' - pushd js/src - sh ../../build/autoconf/autoconf.sh --localdir=$PWD configure.in > configure - chmod +x configure - popd - '' + lib.optionalString (lib.versionAtLeast version "115") '' - patchShebangs build/cargo-linker - '' + '' - # We can't build in js/src/, so create a build dir - mkdir obj - cd obj/ - configureScript=../js/src/configure - ''; + preConfigure = + lib.optionalString (lib.versionAtLeast version "128") '' + export MOZBUILD_STATE_PATH=$TMPDIR/mozbuild + '' + + lib.optionalString (lib.versionOlder version "91") '' + export CXXFLAGS="-fpermissive" + '' + + '' + export LIBXUL_DIST=$out + export PYTHON="${buildPackages.python3.interpreter}" + '' + + lib.optionalString (lib.versionAtLeast version "91") '' + export M4=m4 + export AWK=awk + export AS=$CC + export AC_MACRODIR=$PWD/build/autoconf/ + + '' + + lib.optionalString (lib.versionAtLeast version "91" && lib.versionOlder version "115") '' + pushd js/src + sh ../../build/autoconf/autoconf.sh --localdir=$PWD configure.in > configure + chmod +x configure + popd + '' + + lib.optionalString (lib.versionAtLeast version "115") '' + patchShebangs build/cargo-linker + '' + + '' + # We can't build in js/src/, so create a build dir + mkdir obj + cd obj/ + configureScript=../js/src/configure + ''; # Remove unnecessary static lib preFixup = '' @@ -212,7 +239,11 @@ stdenv.mkDerivation (finalAttrs: rec { description = "Mozilla's JavaScript engine written in C/C++"; homepage = "https://spidermonkey.dev/"; license = licenses.mpl20; # TODO: MPL/GPL/LGPL tri-license for 78. - maintainers = with maintainers; [ abbradar lostnet catap ]; + maintainers = with maintainers; [ + abbradar + lostnet + catap + ]; broken = stdenv.hostPlatform.isDarwin && versionAtLeast version "115"; # Requires SDK 13.3 (see #242666). platforms = platforms.unix; }; diff --git a/pkgs/development/interpreters/spidermonkey/test.nix b/pkgs/development/interpreters/spidermonkey/test.nix index c3ef92bebfa8f2..3ac48a89b6829b 100644 --- a/pkgs/development/interpreters/spidermonkey/test.nix +++ b/pkgs/development/interpreters/spidermonkey/test.nix @@ -1,10 +1,12 @@ { runCommand, spidermonkey }: -runCommand "spidermonkey-test-run" { - nativeBuildInputs = [ - spidermonkey - ]; -} '' - diff -U3 --color=auto <(js <(echo "console.log('Hello, world\!')")) <(echo 'Hello, world!') - touch $out -'' +runCommand "spidermonkey-test-run" + { + nativeBuildInputs = [ + spidermonkey + ]; + } + '' + diff -U3 --color=auto <(js <(echo "console.log('Hello, world\!')")) <(echo 'Hello, world!') + touch $out + '' diff --git a/pkgs/development/interpreters/supercollider/wrapper.nix b/pkgs/development/interpreters/supercollider/wrapper.nix index e9e97f2b98de97..01f3c592ad9b8d 100644 --- a/pkgs/development/interpreters/supercollider/wrapper.nix +++ b/pkgs/development/interpreters/supercollider/wrapper.nix @@ -1,4 +1,9 @@ -{ symlinkJoin, makeWrapper, supercollider, plugins }: +{ + symlinkJoin, + makeWrapper, + supercollider, + plugins, +}: symlinkJoin { name = "supercollider-with-plugins-${supercollider.version}"; diff --git a/pkgs/development/interpreters/tcl/8.5.nix b/pkgs/development/interpreters/tcl/8.5.nix index 7676fbfc187d4d..6a8e2391751c19 100644 --- a/pkgs/development/interpreters/tcl/8.5.nix +++ b/pkgs/development/interpreters/tcl/8.5.nix @@ -1,13 +1,16 @@ -{ callPackage, fetchurl, ... } @ args: +{ callPackage, fetchurl, ... }@args: -callPackage ./generic.nix (args // rec { - release = "8.5"; - version = "${release}.19"; +callPackage ./generic.nix ( + args + // rec { + release = "8.5"; + version = "${release}.19"; - # Note: when updating, the hash in pkgs/development/libraries/tk/8.5.nix must also be updated! + # Note: when updating, the hash in pkgs/development/libraries/tk/8.5.nix must also be updated! - src = fetchurl { - url = "mirror://sourceforge/tcl/tcl${version}-src.tar.gz"; - sha256 = "066vlr9k5f44w9gl9382hlxnryq00d5p6c7w5vq1fgc7v9b49w6k"; - }; -}) + src = fetchurl { + url = "mirror://sourceforge/tcl/tcl${version}-src.tar.gz"; + sha256 = "066vlr9k5f44w9gl9382hlxnryq00d5p6c7w5vq1fgc7v9b49w6k"; + }; + } +) diff --git a/pkgs/development/interpreters/tcl/8.6.nix b/pkgs/development/interpreters/tcl/8.6.nix index 9da653b2f761d9..1c6217e79d5270 100644 --- a/pkgs/development/interpreters/tcl/8.6.nix +++ b/pkgs/development/interpreters/tcl/8.6.nix @@ -1,13 +1,16 @@ -{ callPackage, fetchurl, ... } @ args: +{ callPackage, fetchurl, ... }@args: -callPackage ./generic.nix (args // rec { - release = "8.6"; - version = "${release}.15"; +callPackage ./generic.nix ( + args + // rec { + release = "8.6"; + version = "${release}.15"; - # Note: when updating, the hash in pkgs/development/libraries/tk/8.6.nix must also be updated! + # Note: when updating, the hash in pkgs/development/libraries/tk/8.6.nix must also be updated! - src = fetchurl { - url = "mirror://sourceforge/tcl/tcl${version}-src.tar.gz"; - sha256 = "sha256-hh4Vl1Py4vvW7BSEEDcVsL5WvjNXUiuFjTy7X4k//vE="; - }; -}) + src = fetchurl { + url = "mirror://sourceforge/tcl/tcl${version}-src.tar.gz"; + sha256 = "sha256-hh4Vl1Py4vvW7BSEEDcVsL5WvjNXUiuFjTy7X4k//vE="; + }; + } +) diff --git a/pkgs/development/interpreters/tcl/generic.nix b/pkgs/development/interpreters/tcl/generic.nix index 7746034c357dca..86bc54b9ceb3dc 100644 --- a/pkgs/development/interpreters/tcl/generic.nix +++ b/pkgs/development/interpreters/tcl/generic.nix @@ -1,53 +1,68 @@ -{ lib, stdenv, callPackage, makeSetupHook, runCommand -, tzdata, zip, zlib +{ + lib, + stdenv, + callPackage, + makeSetupHook, + runCommand, + tzdata, + zip, + zlib, -# Version specific stuff -, release, version, src -, ... + # Version specific stuff + release, + version, + src, + ... }: let - baseInterp = - stdenv.mkDerivation rec { - pname = "tcl"; - inherit version src; + baseInterp = stdenv.mkDerivation rec { + pname = "tcl"; + inherit version src; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - setOutputFlags = false; + setOutputFlags = false; - postPatch = '' - substituteInPlace library/clock.tcl \ - --replace "/usr/share/zoneinfo" "${tzdata}/share/zoneinfo" \ - --replace "/usr/share/lib/zoneinfo" "" \ - --replace "/usr/lib/zoneinfo" "" \ - --replace "/usr/local/etc/zoneinfo" "" - ''; + postPatch = '' + substituteInPlace library/clock.tcl \ + --replace "/usr/share/zoneinfo" "${tzdata}/share/zoneinfo" \ + --replace "/usr/share/lib/zoneinfo" "" \ + --replace "/usr/lib/zoneinfo" "" \ + --replace "/usr/local/etc/zoneinfo" "" + ''; - nativeBuildInputs = lib.optionals (lib.versionAtLeast version "9.0") [ - # Only used to detect the presence of zlib. Could be replaced with a stub. - zip - ]; + nativeBuildInputs = lib.optionals (lib.versionAtLeast version "9.0") [ + # Only used to detect the presence of zlib. Could be replaced with a stub. + zip + ]; - buildInputs = lib.optionals (lib.versionAtLeast version "9.0") [ - zlib - ]; + buildInputs = lib.optionals (lib.versionAtLeast version "9.0") [ + zlib + ]; - preConfigure = '' - cd unix - ''; + preConfigure = '' + cd unix + ''; - # Note: pre-9.0 flags are temporarily interspersed to avoid a mass rebuild. - configureFlags = lib.optionals (lib.versionOlder version "9.0") [ + # Note: pre-9.0 flags are temporarily interspersed to avoid a mass rebuild. + configureFlags = + lib.optionals (lib.versionOlder version "9.0") [ "--enable-threads" - ] ++ [ + ] + ++ [ # Note: using $out instead of $man to prevent a runtime dependency on $man. "--mandir=${placeholder "out"}/share/man" - ] ++ lib.optionals (lib.versionOlder version "9.0") [ + ] + ++ lib.optionals (lib.versionOlder version "9.0") [ "--enable-man-symlinks" # Don't install tzdata because NixOS already has a more up-to-date copy. "--with-tzdata=no" - ] ++ lib.optionals (lib.versionAtLeast version "9.0") [ + ] + ++ lib.optionals (lib.versionAtLeast version "9.0") [ # By default, tcl libraries get zipped and embedded into libtcl*.so, # which gets `zipfs mount`ed at runtime. This is fragile (for example # stripping the .so removes the zip trailer), so we install them as @@ -56,52 +71,60 @@ let # however according to my benchmarks on fast storage and warm cache # tcl built with --disable-zipfs actually starts in half the time. "--disable-zipfs" - ] ++ [ + ] + ++ [ "tcl_cv_strtod_unbroken=ok" - ] ++ lib.optional stdenv.hostPlatform.is64bit "--enable-64bit"; + ] + ++ lib.optional stdenv.hostPlatform.is64bit "--enable-64bit"; - enableParallelBuilding = true; + enableParallelBuilding = true; - postInstall = let + postInstall = + let dllExtension = stdenv.hostPlatform.extensions.sharedLibrary; - in '' + in + '' make install-private-headers ln -s $out/bin/tclsh${release} $out/bin/tclsh ln -s $out/lib/libtcl${release}${dllExtension} $out/lib/libtcl${dllExtension} ''; - meta = with lib; { - description = "Tcl scripting language"; - homepage = "https://www.tcl.tk/"; - license = licenses.tcltk; - platforms = platforms.all; - maintainers = with maintainers; [ agbrooks ]; - }; + meta = with lib; { + description = "Tcl scripting language"; + homepage = "https://www.tcl.tk/"; + license = licenses.tcltk; + platforms = platforms.all; + maintainers = with maintainers; [ agbrooks ]; + }; - passthru = rec { - inherit release version; - libPrefix = "tcl${release}"; - libdir = "lib/${libPrefix}"; - tclPackageHook = callPackage ({ buildPackages }: makeSetupHook { + passthru = rec { + inherit release version; + libPrefix = "tcl${release}"; + libdir = "lib/${libPrefix}"; + tclPackageHook = callPackage ( + { buildPackages }: + makeSetupHook { name = "tcl-package-hook"; propagatedBuildInputs = [ buildPackages.makeBinaryWrapper ]; meta = { inherit (meta) maintainers platforms; }; - } ./tcl-package-hook.sh) {}; - # verify that Tcl's clock library can access tzdata - tests.tzdata = runCommand "${pname}-test-tzdata" {} '' - ${baseInterp}/bin/tclsh <(echo "set t [clock scan {2004-10-30 05:00:00} \ - -format {%Y-%m-%d %H:%M:%S} \ - -timezone :America/New_York]") > $out - ''; - }; + } ./tcl-package-hook.sh + ) { }; + # verify that Tcl's clock library can access tzdata + tests.tzdata = runCommand "${pname}-test-tzdata" { } '' + ${baseInterp}/bin/tclsh <(echo "set t [clock scan {2004-10-30 05:00:00} \ + -format {%Y-%m-%d %H:%M:%S} \ + -timezone :America/New_York]") > $out + ''; }; + }; mkTclDerivation = callPackage ./mk-tcl-derivation.nix { tcl = baseInterp; }; -in baseInterp.overrideAttrs (self: { - passthru = self.passthru // { - inherit mkTclDerivation; - }; +in +baseInterp.overrideAttrs (self: { + passthru = self.passthru // { + inherit mkTclDerivation; + }; }) diff --git a/pkgs/development/interpreters/tcl/mk-tcl-derivation.nix b/pkgs/development/interpreters/tcl/mk-tcl-derivation.nix index 57d60f0f2a65bd..b17d4514dfe27b 100644 --- a/pkgs/development/interpreters/tcl/mk-tcl-derivation.nix +++ b/pkgs/development/interpreters/tcl/mk-tcl-derivation.nix @@ -1,30 +1,33 @@ # Generic builder for tcl packages/applications, generally based on mk-python-derivation.nix -{ tcl -, lib -, makeWrapper -, runCommand -, writeScript +{ + tcl, + lib, + makeWrapper, + runCommand, + writeScript, }: -{ buildInputs ? [] -, nativeBuildInputs ? [] -, propagatedBuildInputs ? [] -, checkInputs ? [] -, nativeCheckInputs ? [] +{ + buildInputs ? [ ], + nativeBuildInputs ? [ ], + propagatedBuildInputs ? [ ], + checkInputs ? [ ], + nativeCheckInputs ? [ ], -# true if we should skip the configuration phase altogether -, dontConfigure ? false + # true if we should skip the configuration phase altogether + dontConfigure ? false, -# Extra flags passed to configure step -, configureFlags ? [] + # Extra flags passed to configure step + configureFlags ? [ ], -# Whether or not we should add common Tcl-related configure flags -, addTclConfigureFlags ? true + # Whether or not we should add common Tcl-related configure flags + addTclConfigureFlags ? true, -, meta ? {} -, passthru ? {} -, doCheck ? true -, ... } @ attrs: + meta ? { }, + passthru ? { }, + doCheck ? true, + ... +}@attrs: let inherit (tcl) stdenv; @@ -36,36 +39,49 @@ let "--exec-prefix=${placeholder "out"}" ]; - self = (stdenv.mkDerivation ((builtins.removeAttrs attrs [ - "addTclConfigureFlags" "checkPhase" "checkInputs" "nativeCheckInputs" "doCheck" - ]) // { - - buildInputs = buildInputs ++ [ tcl.tclPackageHook ]; - nativeBuildInputs = nativeBuildInputs ++ [ makeWrapper tcl ]; - propagatedBuildInputs = propagatedBuildInputs ++ [ tcl ]; - - TCLSH = "${getBin tcl}/bin/tclsh"; - - # Run tests after install, at which point we've done all TCLLIBPATH setup - doCheck = false; - doInstallCheck = attrs.doCheck or (attrs.doInstallCheck or false); - installCheckInputs = checkInputs ++ (attrs.installCheckInputs or []); - nativeInstallCheckInputs = nativeCheckInputs ++ (attrs.nativeInstallCheckInputs or []); - - # Add typical values expected by TEA for configureFlags - configureFlags = - if (!dontConfigure && addTclConfigureFlags) - then (configureFlags ++ defaultTclPkgConfigureFlags) - else configureFlags; - - meta = { - platforms = tcl.meta.platforms; - } // meta; - - - } // optionalAttrs (attrs?checkPhase) { - installCheckPhase = attrs.checkPhase; - } - )); - -in lib.extendDerivation true passthru self + self = ( + stdenv.mkDerivation ( + (builtins.removeAttrs attrs [ + "addTclConfigureFlags" + "checkPhase" + "checkInputs" + "nativeCheckInputs" + "doCheck" + ]) + // { + + buildInputs = buildInputs ++ [ tcl.tclPackageHook ]; + nativeBuildInputs = nativeBuildInputs ++ [ + makeWrapper + tcl + ]; + propagatedBuildInputs = propagatedBuildInputs ++ [ tcl ]; + + TCLSH = "${getBin tcl}/bin/tclsh"; + + # Run tests after install, at which point we've done all TCLLIBPATH setup + doCheck = false; + doInstallCheck = attrs.doCheck or (attrs.doInstallCheck or false); + installCheckInputs = checkInputs ++ (attrs.installCheckInputs or [ ]); + nativeInstallCheckInputs = nativeCheckInputs ++ (attrs.nativeInstallCheckInputs or [ ]); + + # Add typical values expected by TEA for configureFlags + configureFlags = + if (!dontConfigure && addTclConfigureFlags) then + (configureFlags ++ defaultTclPkgConfigureFlags) + else + configureFlags; + + meta = { + platforms = tcl.meta.platforms; + } // meta; + + } + // optionalAttrs (attrs ? checkPhase) { + installCheckPhase = attrs.checkPhase; + } + ) + ); + +in +lib.extendDerivation true passthru self diff --git a/pkgs/development/interpreters/wamr/default.nix b/pkgs/development/interpreters/wamr/default.nix index f8c5814df92ef3..2375774f1b358f 100644 --- a/pkgs/development/interpreters/wamr/default.nix +++ b/pkgs/development/interpreters/wamr/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -21,13 +22,17 @@ stdenv.mkDerivation (finalAttrs: { "-DCMAKE_OSX_DEPLOYMENT_TARGET=${stdenv.hostPlatform.darwinSdkVersion}" ]; - sourceRoot = let - platform = if stdenv.hostPlatform.isLinux then - "linux" - else if stdenv.hostPlatform.isDarwin then - "darwin" - else throw "unsupported platform"; - in "${finalAttrs.src.name}/product-mini/platforms/${platform}"; + sourceRoot = + let + platform = + if stdenv.hostPlatform.isLinux then + "linux" + else if stdenv.hostPlatform.isDarwin then + "darwin" + else + throw "unsupported platform"; + in + "${finalAttrs.src.name}/product-mini/platforms/${platform}"; meta = with lib; { description = "WebAssembly Micro Runtime"; diff --git a/pkgs/development/interpreters/wasmer/default.nix b/pkgs/development/interpreters/wasmer/default.nix index 7c1a8c19a802de..8e68316f6b1a16 100644 --- a/pkgs/development/interpreters/wasmer/default.nix +++ b/pkgs/development/interpreters/wasmer/default.nix @@ -33,13 +33,16 @@ rustPlatform.buildRustPackage rec { ]; # check references to `compiler_features` in Makefile on update - buildFeatures = [ - "cranelift" - "wasmer-artifact-create" - "static-artifact-create" - "wasmer-artifact-load" - "static-artifact-load" - ] ++ lib.optional withLLVM "llvm" ++ lib.optional withSinglepass "singlepass"; + buildFeatures = + [ + "cranelift" + "wasmer-artifact-create" + "static-artifact-create" + "wasmer-artifact-load" + "static-artifact-load" + ] + ++ lib.optional withLLVM "llvm" + ++ lib.optional withSinglepass "singlepass"; cargoBuildFlags = [ "--manifest-path" diff --git a/pkgs/development/interpreters/wavm/default.nix b/pkgs/development/interpreters/wavm/default.nix index feedb88acaa3cf..82ee3fee4eb623 100644 --- a/pkgs/development/interpreters/wavm/default.nix +++ b/pkgs/development/interpreters/wavm/default.nix @@ -1,7 +1,8 @@ -{ lib -, llvmPackages -, fetchFromGitHub -, cmake +{ + lib, + llvmPackages, + fetchFromGitHub, + cmake, }: llvmPackages.stdenv.mkDerivation (finalAttrs: { @@ -15,7 +16,10 @@ llvmPackages.stdenv.mkDerivation (finalAttrs: { hash = "sha256-SHz+oOOkwvVZucJYFSyZc3MnOAy1VatspmZmOAXYAWA="; }; - nativeBuildInputs = [ cmake llvmPackages.llvm ]; + nativeBuildInputs = [ + cmake + llvmPackages.llvm + ]; meta = with lib; { description = "WebAssembly Virtual Machine"; diff --git a/pkgs/development/julia-modules/default.nix b/pkgs/development/julia-modules/default.nix index 6b5531ac5690f0..01cabdb1eb4260 100644 --- a/pkgs/development/julia-modules/default.nix +++ b/pkgs/development/julia-modules/default.nix @@ -1,75 +1,95 @@ -{ callPackage -, fetchgit -, fontconfig -, git -, lib -, makeWrapper -, python3 -, runCommand -, system -, writeText -, writeTextFile - -# Artifacts dependencies -, fetchurl -, glibc -, pkgs -, stdenv - -, julia - -# Special registry which is equal to JuliaRegistries/General, but every Versions.toml -# entry is augmented with a Nix sha256 hash -, augmentedRegistry ? callPackage ./registry.nix {} - -# Other overridable arguments -, extraLibs ? [] -, juliaCpuTarget ? null -, makeTransitiveDependenciesImportable ? false # Used to support symbol indexing -, makeWrapperArgs ? "" -, packageOverrides ? {} -, precompile ? true -, setDefaultDepot ? true +{ + callPackage, + fetchgit, + fontconfig, + git, + lib, + makeWrapper, + python3, + runCommand, + system, + writeText, + writeTextFile, + + # Artifacts dependencies + fetchurl, + glibc, + pkgs, + stdenv, + + julia, + + # Special registry which is equal to JuliaRegistries/General, but every Versions.toml + # entry is augmented with a Nix sha256 hash + augmentedRegistry ? callPackage ./registry.nix { }, + + # Other overridable arguments + extraLibs ? [ ], + juliaCpuTarget ? null, + makeTransitiveDependenciesImportable ? false, # Used to support symbol indexing + makeWrapperArgs ? "", + packageOverrides ? { }, + precompile ? true, + setDefaultDepot ? true, }: packageNames: let - util = callPackage ./util.nix {}; + util = callPackage ./util.nix { }; # Some Julia packages require access to Python. Provide a Nixpkgs version so it # doesn't try to install its own. - pythonToUse = let - extraPythonPackages = ((callPackage ./extra-python-packages.nix { inherit python3; }).getExtraPythonPackages packageNames); - in (if extraPythonPackages == [] then python3 - else util.addPackagesToPython python3 (map (pkg: lib.getAttr pkg python3.pkgs) extraPythonPackages)); + pythonToUse = + let + extraPythonPackages = ( + (callPackage ./extra-python-packages.nix { inherit python3; }).getExtraPythonPackages packageNames + ); + in + ( + if extraPythonPackages == [ ] then + python3 + else + util.addPackagesToPython python3 (map (pkg: lib.getAttr pkg python3.pkgs) extraPythonPackages) + ); # Start by wrapping Julia so it has access to Python and any other extra libs. # Also, prevent various packages (CondaPkg.jl, PythonCall.jl) from trying to do network calls. - juliaWrapped = runCommand "julia-${julia.version}-wrapped" { nativeBuildInputs = [makeWrapper]; inherit makeWrapperArgs; } '' - mkdir -p $out/bin - makeWrapper ${julia}/bin/julia $out/bin/julia \ - --suffix LD_LIBRARY_PATH : "${lib.makeLibraryPath extraLibs}" \ - --set FONTCONFIG_FILE ${fontconfig.out}/etc/fonts/fonts.conf \ - --set PYTHONHOME "${pythonToUse}" \ - --prefix PYTHONPATH : "${pythonToUse}/${pythonToUse.sitePackages}" \ - --set PYTHON ${pythonToUse}/bin/python $makeWrapperArgs \ - --set JULIA_CONDAPKG_OFFLINE yes \ - --set JULIA_CONDAPKG_BACKEND Null \ - --set JULIA_PYTHONCALL_EXE "@PyCall" - ''; + juliaWrapped = + runCommand "julia-${julia.version}-wrapped" + { + nativeBuildInputs = [ makeWrapper ]; + inherit makeWrapperArgs; + } + '' + mkdir -p $out/bin + makeWrapper ${julia}/bin/julia $out/bin/julia \ + --suffix LD_LIBRARY_PATH : "${lib.makeLibraryPath extraLibs}" \ + --set FONTCONFIG_FILE ${fontconfig.out}/etc/fonts/fonts.conf \ + --set PYTHONHOME "${pythonToUse}" \ + --prefix PYTHONPATH : "${pythonToUse}/${pythonToUse.sitePackages}" \ + --set PYTHON ${pythonToUse}/bin/python $makeWrapperArgs \ + --set JULIA_CONDAPKG_OFFLINE yes \ + --set JULIA_CONDAPKG_BACKEND Null \ + --set JULIA_PYTHONCALL_EXE "@PyCall" + ''; # If our closure ends up with certain packages, add others. packageImplications = { # Because we want to put PythonCall in PyCall mode so it doesn't try to download # Python packages - PythonCall = ["PyCall"]; + PythonCall = [ "PyCall" ]; }; # Invoke Julia resolution logic to determine the full dependency closure packageOverridesRepoified = lib.mapAttrs util.repoifySimple packageOverrides; closureYaml = callPackage ./package-closure.nix { - inherit augmentedRegistry julia packageNames packageImplications; + inherit + augmentedRegistry + julia + packageNames + packageImplications + ; packageOverrides = packageOverridesRepoified; }; @@ -83,13 +103,26 @@ let # }; # ... # } - dependencies = runCommand "julia-sources.nix" { buildInputs = [(python3.withPackages (ps: with ps; [toml pyyaml])) git]; } '' - python ${./python}/sources_nix.py \ - "${augmentedRegistry}" \ - '${lib.generators.toJSON {} packageOverridesRepoified}' \ - "${closureYaml}" \ - "$out" - ''; + dependencies = + runCommand "julia-sources.nix" + { + buildInputs = [ + (python3.withPackages ( + ps: with ps; [ + toml + pyyaml + ] + )) + git + ]; + } + '' + python ${./python}/sources_nix.py \ + "${augmentedRegistry}" \ + '${lib.generators.toJSON { } packageOverridesRepoified}' \ + "${closureYaml}" \ + "$out" + ''; # Import the Nix file from the previous step (IFD) and turn each dependency repo into # a dummy Git repository, as Julia expects. Format the results as a YAML map from @@ -100,100 +133,163 @@ let # } # This is also the point where we apply the packageOverrides. dependencyUuidToInfo = import dependencies { inherit fetchgit; }; - fillInOverrideSrc = uuid: info: - if lib.hasAttr info.name packageOverrides then (info // { src = lib.getAttr info.name packageOverrides; }) else info; - dependencyUuidToRepo = lib.mapAttrs util.repoifyInfo (lib.mapAttrs fillInOverrideSrc dependencyUuidToInfo); + fillInOverrideSrc = + uuid: info: + if lib.hasAttr info.name packageOverrides then + (info // { src = lib.getAttr info.name packageOverrides; }) + else + info; + dependencyUuidToRepo = lib.mapAttrs util.repoifyInfo ( + lib.mapAttrs fillInOverrideSrc dependencyUuidToInfo + ); dependencyUuidToRepoYaml = writeTextFile { name = "dependency-uuid-to-repo.yml"; - text = lib.generators.toYAML {} dependencyUuidToRepo; + text = lib.generators.toYAML { } dependencyUuidToRepo; }; # Given the augmented registry, closure info yaml, and dependency path yaml, construct a complete # Julia registry containing all the necessary packages dependencyUuidToInfoYaml = writeTextFile { name = "dependency-uuid-to-info.yml"; - text = lib.generators.toYAML {} dependencyUuidToInfo; + text = lib.generators.toYAML { } dependencyUuidToInfo; }; - fillInOverrideSrc' = uuid: info: - if lib.hasAttr info.name packageOverridesRepoified then (info // { src = lib.getAttr info.name packageOverridesRepoified; }) else info; - overridesOnly = lib.mapAttrs fillInOverrideSrc' (lib.filterAttrs (uuid: info: info.src == null) dependencyUuidToInfo); - minimalRegistry = runCommand "minimal-julia-registry" { buildInputs = [(python3.withPackages (ps: with ps; [toml pyyaml])) git]; } '' - python ${./python}/minimal_registry.py \ - "${augmentedRegistry}" \ - "${closureYaml}" \ - '${lib.generators.toJSON {} overridesOnly}' \ - "${dependencyUuidToRepoYaml}" \ - "$out" - ''; + fillInOverrideSrc' = + uuid: info: + if lib.hasAttr info.name packageOverridesRepoified then + (info // { src = lib.getAttr info.name packageOverridesRepoified; }) + else + info; + overridesOnly = lib.mapAttrs fillInOverrideSrc' ( + lib.filterAttrs (uuid: info: info.src == null) dependencyUuidToInfo + ); + minimalRegistry = + runCommand "minimal-julia-registry" + { + buildInputs = [ + (python3.withPackages ( + ps: with ps; [ + toml + pyyaml + ] + )) + git + ]; + } + '' + python ${./python}/minimal_registry.py \ + "${augmentedRegistry}" \ + "${closureYaml}" \ + '${lib.generators.toJSON { } overridesOnly}' \ + "${dependencyUuidToRepoYaml}" \ + "$out" + ''; # Next, deal with artifacts. Scan each artifacts file individually and generate a Nix file that # produces the desired Overrides.toml. - artifactsNix = runCommand "julia-artifacts.nix" { buildInputs = [(python3.withPackages (ps: with ps; [toml pyyaml]))]; } '' - python ${./python}/extract_artifacts.py \ - "${dependencyUuidToRepoYaml}" \ - "${closureYaml}" \ - "${juliaWrapped}/bin/julia" \ - "${if lib.versionAtLeast julia.version "1.7" then ./extract_artifacts.jl else ./extract_artifacts_16.jl}" \ - '${lib.generators.toJSON {} (import ./extra-libs.nix)}' \ - '${lib.generators.toJSON {} (stdenv.hostPlatform.isDarwin)}' \ - "$out" - ''; + artifactsNix = + runCommand "julia-artifacts.nix" + { + buildInputs = [ + (python3.withPackages ( + ps: with ps; [ + toml + pyyaml + ] + )) + ]; + } + '' + python ${./python}/extract_artifacts.py \ + "${dependencyUuidToRepoYaml}" \ + "${closureYaml}" \ + "${juliaWrapped}/bin/julia" \ + "${ + if lib.versionAtLeast julia.version "1.7" then ./extract_artifacts.jl else ./extract_artifacts_16.jl + }" \ + '${lib.generators.toJSON { } (import ./extra-libs.nix)}' \ + '${lib.generators.toJSON { } (stdenv.hostPlatform.isDarwin)}' \ + "$out" + ''; # Import the artifacts Nix to build Overrides.toml (IFD) - artifacts = import artifactsNix ({ - inherit lib fetchurl pkgs stdenv; - } // lib.optionalAttrs (!stdenv.targetPlatform.isDarwin) { - inherit glibc; - }); + artifacts = import artifactsNix ( + { + inherit + lib + fetchurl + pkgs + stdenv + ; + } + // lib.optionalAttrs (!stdenv.targetPlatform.isDarwin) { + inherit glibc; + } + ); overridesJson = writeTextFile { name = "Overrides.json"; - text = lib.generators.toJSON {} artifacts; + text = lib.generators.toJSON { } artifacts; }; - overridesToml = runCommand "Overrides.toml" { buildInputs = [(python3.withPackages (ps: with ps; [toml]))]; } '' - python ${./python}/format_overrides.py \ - "${overridesJson}" \ - "$out" - ''; + overridesToml = + runCommand "Overrides.toml" { buildInputs = [ (python3.withPackages (ps: with ps; [ toml ])) ]; } + '' + python ${./python}/format_overrides.py \ + "${overridesJson}" \ + "$out" + ''; # Build a Julia project and depot. The project contains Project.toml/Manifest.toml, while the # depot contains package build products (including the precompiled libraries, if precompile=true) projectAndDepot = callPackage ./depot.nix { - inherit closureYaml extraLibs juliaCpuTarget overridesToml packageImplications precompile; + inherit + closureYaml + extraLibs + juliaCpuTarget + overridesToml + packageImplications + precompile + ; julia = juliaWrapped; registry = minimalRegistry; - packageNames = if makeTransitiveDependenciesImportable - then lib.mapAttrsToList (uuid: info: info.name) dependencyUuidToInfo - else packageNames; + packageNames = + if makeTransitiveDependenciesImportable then + lib.mapAttrsToList (uuid: info: info.name) dependencyUuidToInfo + else + packageNames; }; in -runCommand "julia-${julia.version}-env" { - nativeBuildInputs = [makeWrapper]; - - passthru = { - inherit julia; - inherit juliaWrapped; - inherit (julia) pname version meta; - - # Expose the steps we used along the way in case the user wants to use them, for example to build - # expressions and build them separately to avoid IFD. - inherit dependencies; - inherit closureYaml; - inherit dependencyUuidToInfoYaml; - inherit dependencyUuidToRepoYaml; - inherit minimalRegistry; - inherit artifactsNix; - inherit overridesJson; - inherit overridesToml; - inherit projectAndDepot; - }; -} ('' - mkdir -p $out/bin - makeWrapper ${juliaWrapped}/bin/julia $out/bin/julia \ - --suffix JULIA_DEPOT_PATH : "${projectAndDepot}/depot" \ - --set-default JULIA_PROJECT "${projectAndDepot}/project" \ - --set-default JULIA_LOAD_PATH '@:${projectAndDepot}/project/Project.toml:@v#.#:@stdlib' -'' + lib.optionalString setDefaultDepot '' - sed -i '2 i\JULIA_DEPOT_PATH=''${JULIA_DEPOT_PATH-"$HOME/.julia"}' $out/bin/julia -'') +runCommand "julia-${julia.version}-env" + { + nativeBuildInputs = [ makeWrapper ]; + + passthru = { + inherit julia; + inherit juliaWrapped; + inherit (julia) pname version meta; + + # Expose the steps we used along the way in case the user wants to use them, for example to build + # expressions and build them separately to avoid IFD. + inherit dependencies; + inherit closureYaml; + inherit dependencyUuidToInfoYaml; + inherit dependencyUuidToRepoYaml; + inherit minimalRegistry; + inherit artifactsNix; + inherit overridesJson; + inherit overridesToml; + inherit projectAndDepot; + }; + } + ( + '' + mkdir -p $out/bin + makeWrapper ${juliaWrapped}/bin/julia $out/bin/julia \ + --suffix JULIA_DEPOT_PATH : "${projectAndDepot}/depot" \ + --set-default JULIA_PROJECT "${projectAndDepot}/project" \ + --set-default JULIA_LOAD_PATH '@:${projectAndDepot}/project/Project.toml:@v#.#:@stdlib' + '' + + lib.optionalString setDefaultDepot '' + sed -i '2 i\JULIA_DEPOT_PATH=''${JULIA_DEPOT_PATH-"$HOME/.julia"}' $out/bin/julia + '' + ) diff --git a/pkgs/development/julia-modules/depot.nix b/pkgs/development/julia-modules/depot.nix index 29a49250000395..6047dc4c86f4b7 100644 --- a/pkgs/development/julia-modules/depot.nix +++ b/pkgs/development/julia-modules/depot.nix @@ -1,21 +1,22 @@ -{ lib -, runCommand - -, cacert -, curl -, git -, julia -, python3 -, stdenv - -, closureYaml -, extraLibs -, juliaCpuTarget -, overridesToml -, packageImplications -, packageNames -, precompile -, registry +{ + lib, + runCommand, + + cacert, + curl, + git, + julia, + python3, + stdenv, + + closureYaml, + extraLibs, + juliaCpuTarget, + overridesToml, + packageImplications, + packageNames, + precompile, + registry, }: let @@ -26,91 +27,106 @@ let # to use a file or directory of certificate authority roots, but your environment specifies one via the SSL_CERT_FILE # variable. If you believe your system's root certificates are safe to use, you can `export JULIA_SSL_CA_ROOTS_PATH=""` # in your environment to use those instead.) - setJuliaSslCaRootsPath = if stdenv.targetPlatform.isDarwin - then ''export JULIA_SSL_CA_ROOTS_PATH=""'' - else ''export JULIA_SSL_CA_ROOTS_PATH="${cacert}/etc/ssl/certs/ca-bundle.crt"''; + setJuliaSslCaRootsPath = + if stdenv.targetPlatform.isDarwin then + ''export JULIA_SSL_CA_ROOTS_PATH=""'' + else + ''export JULIA_SSL_CA_ROOTS_PATH="${cacert}/etc/ssl/certs/ca-bundle.crt"''; in -runCommand "julia-depot" { - nativeBuildInputs = [curl git julia (python3.withPackages (ps: with ps; [pyyaml]))] ++ extraLibs; - inherit precompile registry; -} ('' - export HOME=$(pwd) - - echo "Building Julia depot and project with the following inputs" - echo "Julia: ${julia}" - echo "Registry: $registry" - echo "Overrides ${overridesToml}" - - mkdir -p $out/project - export JULIA_PROJECT="$out/project" - - mkdir -p $out/depot/artifacts - export JULIA_DEPOT_PATH="$out/depot" - cp ${overridesToml} $out/depot/artifacts/Overrides.toml - - # These can be useful to debug problems - # export JULIA_DEBUG=Pkg - # export JULIA_DEBUG=loading - - ${setJuliaSslCaRootsPath} - - # Only precompile if configured to below - export JULIA_PKG_PRECOMPILE_AUTO=0 -'' + lib.optionalString (juliaCpuTarget != null) '' - export JULIA_CPU_TARGET="${juliaCpuTarget}" -'' + '' - # Prevent a warning where Julia tries to download package server info - export JULIA_PKG_SERVER="" - - # See if we need to add any extra package names based on the closure - # and the packageImplications. We're using the full closure YAML here since - # it's available, which is slightly weird, but it should work just as well - # for finding the extra packages we need to add - python ${./python}/find_package_implications.py "${closureYaml}" '${lib.generators.toJSON {} packageImplications}' extra_package_names.txt - - # Work around new git security features added in git 2.44.1 - # See https://github.com/NixOS/nixpkgs/issues/315890 - git config --global --add safe.directory '*' - - # Tell Julia to use the Git binary we provide, rather than internal libgit2. - export JULIA_PKG_USE_CLI_GIT="true" - - # At time of writing, this appears to be the only way to turn precompiling's - # terminal output into standard logging, so opportunistically do that. - # (Note this is different from JULIA_CI). - export CI=true - - julia -e ' \ - import Pkg - import Pkg.Types: PRESERVE_NONE - - Pkg.Registry.add(Pkg.RegistrySpec(path="${registry}")) - - input = ${lib.generators.toJSON {} packageNames} ::Vector{String} +runCommand "julia-depot" + { + nativeBuildInputs = [ + curl + git + julia + (python3.withPackages (ps: with ps; [ pyyaml ])) + ] ++ extraLibs; + inherit precompile registry; + } + ( + '' + export HOME=$(pwd) + + echo "Building Julia depot and project with the following inputs" + echo "Julia: ${julia}" + echo "Registry: $registry" + echo "Overrides ${overridesToml}" + + mkdir -p $out/project + export JULIA_PROJECT="$out/project" + + mkdir -p $out/depot/artifacts + export JULIA_DEPOT_PATH="$out/depot" + cp ${overridesToml} $out/depot/artifacts/Overrides.toml + + # These can be useful to debug problems + # export JULIA_DEBUG=Pkg + # export JULIA_DEBUG=loading + + ${setJuliaSslCaRootsPath} + + # Only precompile if configured to below + export JULIA_PKG_PRECOMPILE_AUTO=0 + '' + + lib.optionalString (juliaCpuTarget != null) '' + export JULIA_CPU_TARGET="${juliaCpuTarget}" + '' + + '' + # Prevent a warning where Julia tries to download package server info + export JULIA_PKG_SERVER="" + + # See if we need to add any extra package names based on the closure + # and the packageImplications. We're using the full closure YAML here since + # it's available, which is slightly weird, but it should work just as well + # for finding the extra packages we need to add + python ${./python}/find_package_implications.py "${closureYaml}" '${ + lib.generators.toJSON { } packageImplications + }' extra_package_names.txt + + # Work around new git security features added in git 2.44.1 + # See https://github.com/NixOS/nixpkgs/issues/315890 + git config --global --add safe.directory '*' + + # Tell Julia to use the Git binary we provide, rather than internal libgit2. + export JULIA_PKG_USE_CLI_GIT="true" + + # At time of writing, this appears to be the only way to turn precompiling's + # terminal output into standard logging, so opportunistically do that. + # (Note this is different from JULIA_CI). + export CI=true + + julia -e ' \ + import Pkg + import Pkg.Types: PRESERVE_NONE + + Pkg.Registry.add(Pkg.RegistrySpec(path="${registry}")) + + input = ${lib.generators.toJSON { } packageNames} ::Vector{String} + + if isfile("extra_package_names.txt") + append!(input, readlines("extra_package_names.txt")) + end - if isfile("extra_package_names.txt") - append!(input, readlines("extra_package_names.txt")) - end + input = unique(input) - input = unique(input) + if !isempty(input) + println("Adding packages: " * join(input, " ")) + Pkg.add(input; preserve=PRESERVE_NONE) + Pkg.instantiate() - if !isempty(input) - println("Adding packages: " * join(input, " ")) - Pkg.add(input; preserve=PRESERVE_NONE) - Pkg.instantiate() + if "precompile" in keys(ENV) && ENV["precompile"] != "0" && ENV["precompile"] != "" + if isdefined(Sys, :CPU_NAME) + println("Precompiling with CPU_NAME = " * Sys.CPU_NAME) + end - if "precompile" in keys(ENV) && ENV["precompile"] != "0" && ENV["precompile"] != "" - if isdefined(Sys, :CPU_NAME) - println("Precompiling with CPU_NAME = " * Sys.CPU_NAME) + Pkg.precompile() + end end - Pkg.precompile() - end - end - - # Remove the registry to save space - Pkg.Registry.rm("General") - ' -'') + # Remove the registry to save space + Pkg.Registry.rm("General") + ' + '' + ) diff --git a/pkgs/development/julia-modules/extra-libs.nix b/pkgs/development/julia-modules/extra-libs.nix index 815c67ac7a7dc0..b08412657e92ca 100644 --- a/pkgs/development/julia-modules/extra-libs.nix +++ b/pkgs/development/julia-modules/extra-libs.nix @@ -7,9 +7,9 @@ # Needs access to dbus or you get "Cannot find libdbus-1 in your system" # Repro: build environment with ["Plots"] # > using Plots; plot(cos, 0, 2pi) - "ea2cea3b-5b76-57ae-a6ef-0a8af62496e1" = ["dbus.lib"]; + "ea2cea3b-5b76-57ae-a6ef-0a8af62496e1" = [ "dbus.lib" ]; # Qt6Base_jll # Same reason as Qt5Base_jll - "c0090381-4147-56d7-9ebc-da0b1113ec56" = ["dbus.lib"]; + "c0090381-4147-56d7-9ebc-da0b1113ec56" = [ "dbus.lib" ]; } diff --git a/pkgs/development/julia-modules/extra-python-packages.nix b/pkgs/development/julia-modules/extra-python-packages.nix index 14731fb9de3507..76913ac48aa795 100644 --- a/pkgs/development/julia-modules/extra-python-packages.nix +++ b/pkgs/development/julia-modules/extra-python-packages.nix @@ -1,19 +1,24 @@ -{ lib -, python3 +{ + lib, + python3, }: # This file contains an extra mapping from Julia packages to the Python packages they depend on. rec { packageMapping = { - ExcelFiles = ["xlrd"]; - PyPlot = ["matplotlib"]; - PythonPlot = ["matplotlib"]; - SymPy = ["sympy"]; + ExcelFiles = [ "xlrd" ]; + PyPlot = [ "matplotlib" ]; + PythonPlot = [ "matplotlib" ]; + SymPy = [ "sympy" ]; }; - getExtraPythonPackages = names: lib.concatMap (name: let - allCandidates = if lib.hasAttr name packageMapping then lib.getAttr name packageMapping else []; - in - lib.filter (x: lib.hasAttr x python3.pkgs) allCandidates - ) names; + getExtraPythonPackages = + names: + lib.concatMap ( + name: + let + allCandidates = if lib.hasAttr name packageMapping then lib.getAttr name packageMapping else [ ]; + in + lib.filter (x: lib.hasAttr x python3.pkgs) allCandidates + ) names; } diff --git a/pkgs/development/julia-modules/package-closure.nix b/pkgs/development/julia-modules/package-closure.nix index 8bc9e2774d81f0..a393a2f4942709 100644 --- a/pkgs/development/julia-modules/package-closure.nix +++ b/pkgs/development/julia-modules/package-closure.nix @@ -1,12 +1,13 @@ -{ lib -, julia -, python3 -, runCommand - -, augmentedRegistry -, packageNames -, packageOverrides -, packageImplications +{ + lib, + julia, + python3, + runCommand, + + augmentedRegistry, + packageNames, + packageOverrides, + packageImplications, }: let @@ -16,7 +17,7 @@ let import Pkg.Types: Context, PackageSpec - input = ${lib.generators.toJSON {} packageNames} + input = ${lib.generators.toJSON { } packageNames} if isfile("extra_package_names.txt") append!(input, readlines("extra_package_names.txt")) @@ -30,7 +31,11 @@ let ctx = Context() - overrides = Dict{String, String}(${builtins.concatStringsSep ", " (lib.mapAttrsToList (name: path: ''"${name}" => "${path}"'') packageOverrides)}) + overrides = Dict{String, String}(${ + builtins.concatStringsSep ", " ( + lib.mapAttrsToList (name: path: ''"${name}" => "${path}"'') packageOverrides + ) + }) ${builtins.readFile ./resolve_packages.jl} open(ENV["out"], "w") do io @@ -49,25 +54,34 @@ let ''; in -runCommand "julia-package-closure.yml" { buildInputs = [julia (python3.withPackages (ps: with ps; [pyyaml]))]; } '' - mkdir home - export HOME=$(pwd)/home +runCommand "julia-package-closure.yml" + { + buildInputs = [ + julia + (python3.withPackages (ps: with ps; [ pyyaml ])) + ]; + } + '' + mkdir home + export HOME=$(pwd)/home - echo "Resolving Julia packages with the following inputs" - echo "Julia: ${julia}" - echo "Registry: ${augmentedRegistry}" + echo "Resolving Julia packages with the following inputs" + echo "Julia: ${julia}" + echo "Registry: ${augmentedRegistry}" - # Prevent a warning where Julia tries to download package server info - export JULIA_PKG_SERVER="" + # Prevent a warning where Julia tries to download package server info + export JULIA_PKG_SERVER="" - julia -e '${juliaExpression packageNames}'; - - # See if we need to add any extra package names based on the closure - # and the packageImplications - python ${./python}/find_package_implications.py "$out" '${lib.generators.toJSON {} packageImplications}' extra_package_names.txt - - if [ -f extra_package_names.txt ]; then - echo "Re-resolving with additional package names" julia -e '${juliaExpression packageNames}'; - fi -'' + + # See if we need to add any extra package names based on the closure + # and the packageImplications + python ${./python}/find_package_implications.py "$out" '${ + lib.generators.toJSON { } packageImplications + }' extra_package_names.txt + + if [ -f extra_package_names.txt ]; then + echo "Re-resolving with additional package names" + julia -e '${juliaExpression packageNames}'; + fi + '' diff --git a/pkgs/development/julia-modules/tests/julia-top-n/default.nix b/pkgs/development/julia-modules/tests/julia-top-n/default.nix index 9e42e19dd309ba..2db0c2f2ed47c0 100644 --- a/pkgs/development/julia-modules/tests/julia-top-n/default.nix +++ b/pkgs/development/julia-modules/tests/julia-top-n/default.nix @@ -1,5 +1,14 @@ -{ mkDerivation, aeson, base, filepath, lib, optparse-applicative -, sandwich, text, unliftio, yaml +{ + mkDerivation, + aeson, + base, + filepath, + lib, + optparse-applicative, + sandwich, + text, + unliftio, + yaml, }: mkDerivation { pname = "julia-top-n"; @@ -17,7 +26,13 @@ mkDerivation { isLibrary = false; isExecutable = true; executableHaskellDepends = [ - aeson base filepath optparse-applicative sandwich text unliftio + aeson + base + filepath + optparse-applicative + sandwich + text + unliftio yaml ]; license = lib.licenses.bsd3; diff --git a/pkgs/development/julia-modules/tests/top-julia-packages.nix b/pkgs/development/julia-modules/tests/top-julia-packages.nix index 3c50b5eed676c5..3a3a9f13a2f4b6 100644 --- a/pkgs/development/julia-modules/tests/top-julia-packages.nix +++ b/pkgs/development/julia-modules/tests/top-julia-packages.nix @@ -1,4 +1,4 @@ -with import ../../../../. {}; +with import ../../../../. { }; let package-requests = stdenv.mkDerivation { @@ -6,7 +6,11 @@ let __impure = true; - buildInputs = [cacert gzip wget]; + buildInputs = [ + cacert + gzip + wget + ]; buildCommand = '' wget https://julialang-logs.s3.amazonaws.com/public_outputs/current/package_requests.csv.gz @@ -15,13 +19,22 @@ let ''; }; - registry = callPackage ../registry.nix {}; + registry = callPackage ../registry.nix { }; in -runCommand "top-julia-packages.yaml" { - __impure = true; - nativeBuildInputs = [(python3.withPackages (ps: with ps; [pyyaml toml]))]; -} '' - python ${./process_top_n.py} ${package-requests} ${registry} > $out -'' +runCommand "top-julia-packages.yaml" + { + __impure = true; + nativeBuildInputs = [ + (python3.withPackages ( + ps: with ps; [ + pyyaml + toml + ] + )) + ]; + } + '' + python ${./process_top_n.py} ${package-requests} ${registry} > $out + '' diff --git a/pkgs/development/julia-modules/util.nix b/pkgs/development/julia-modules/util.nix index 0c01fcbe828630..d70bdc48bffa79 100644 --- a/pkgs/development/julia-modules/util.nix +++ b/pkgs/development/julia-modules/util.nix @@ -1,5 +1,6 @@ -{ git -, runCommand +{ + git, + runCommand, }: { @@ -7,15 +8,19 @@ # a) python3 # b) python3.withPackages (ps: [...]) # See https://github.com/NixOS/nixpkgs/pull/97467#issuecomment-689315186 - addPackagesToPython = python: packages: - if python ? "env" then python.override (old: { - extraLibs = old.extraLibs ++ packages; - }) - else python.withPackages (ps: packages); + addPackagesToPython = + python: packages: + if python ? "env" then + python.override (old: { + extraLibs = old.extraLibs ++ packages; + }) + else + python.withPackages (ps: packages); # Convert an ordinary source checkout into a repo with a single commit - repoifySimple = name: path: - runCommand ''${name}-repoified'' {buildInputs = [git];} '' + repoifySimple = + name: path: + runCommand ''${name}-repoified'' { buildInputs = [ git ]; } '' mkdir -p $out cp -r ${path}/. $out cd $out @@ -29,8 +34,9 @@ ''; # Convert an dependency source info into a repo with a single commit - repoifyInfo = uuid: info: - runCommand ''julia-${info.name}-${info.version}'' {buildInputs = [git];} '' + repoifyInfo = + uuid: info: + runCommand ''julia-${info.name}-${info.version}'' { buildInputs = [ git ]; } '' mkdir -p $out cp -r ${info.src}/. $out cd $out diff --git a/pkgs/development/libraries/CGAL/4.nix b/pkgs/development/libraries/CGAL/4.nix index d04a7bccded6f8..5d6ca6e89fbe71 100644 --- a/pkgs/development/libraries/CGAL/4.nix +++ b/pkgs/development/libraries/CGAL/4.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, fetchpatch, cmake, boost, gmp, mpfr }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + cmake, + boost, + gmp, + mpfr, +}: stdenv.mkDerivation rec { version = "4.14.3"; @@ -30,7 +39,11 @@ stdenv.mkDerivation rec { # note: optional component libCGAL_ImageIO would need zlib and opengl; # there are also libCGAL_Qt{3,4} omitted ATM - buildInputs = [ boost gmp mpfr ]; + buildInputs = [ + boost + gmp + mpfr + ]; nativeBuildInputs = [ cmake ]; doCheck = false; @@ -38,7 +51,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Computational Geometry Algorithms Library"; homepage = "http://cgal.org"; - license = with licenses; [ gpl3Plus lgpl3Plus]; + license = with licenses; [ + gpl3Plus + lgpl3Plus + ]; platforms = platforms.all; maintainers = [ maintainers.raskin ]; }; diff --git a/pkgs/development/libraries/CGAL/default.nix b/pkgs/development/libraries/CGAL/default.nix index 3c0ba58041a4d7..2615fc73d02d14 100644 --- a/pkgs/development/libraries/CGAL/default.nix +++ b/pkgs/development/libraries/CGAL/default.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchurl -, cmake -, boost -, gmp -, mpfr +{ + lib, + stdenv, + fetchurl, + cmake, + boost, + gmp, + mpfr, }: stdenv.mkDerivation rec { @@ -17,7 +19,11 @@ stdenv.mkDerivation rec { # note: optional component libCGAL_ImageIO would need zlib and opengl; # there are also libCGAL_Qt{3,4} omitted ATM - buildInputs = [ boost gmp mpfr ]; + buildInputs = [ + boost + gmp + mpfr + ]; nativeBuildInputs = [ cmake ]; patches = [ ./cgal_path.patch ]; @@ -27,7 +33,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Computational Geometry Algorithms Library"; homepage = "http://cgal.org"; - license = with licenses; [ gpl3Plus lgpl3Plus]; + license = with licenses; [ + gpl3Plus + lgpl3Plus + ]; platforms = platforms.all; maintainers = [ maintainers.raskin ]; }; diff --git a/pkgs/development/libraries/abseil-cpp/202103.nix b/pkgs/development/libraries/abseil-cpp/202103.nix index ec43a98c0497e7..823e816e03fdba 100644 --- a/pkgs/development/libraries/abseil-cpp/202103.nix +++ b/pkgs/development/libraries/abseil-cpp/202103.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, static ? stdenv.hostPlatform.isStatic -, cxxStandard ? null +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + static ? stdenv.hostPlatform.isStatic, + cxxStandard ? null, }: stdenv.mkDerivation rec { @@ -18,38 +19,43 @@ stdenv.mkDerivation rec { sha256 = "sha256-fcxPhuI2eL/fnd6nT11p8DpUNwGNaXZmd03yOiZcOT0="; }; - patches = [ - # Use CMAKE_INSTALL_FULL_{LIBDIR,INCLUDEDIR} - # https://github.com/abseil/abseil-cpp/pull/963 - (fetchpatch { - url = "https://github.com/abseil/abseil-cpp/commit/5bfa70c75e621c5d5ec095c8c4c0c050dcb2957e.patch"; - sha256 = "0nhjxqfxpi2pkfinnqvd5m4npf9l1kg39mjx9l3087ajhadaywl5"; - }) + patches = + [ + # Use CMAKE_INSTALL_FULL_{LIBDIR,INCLUDEDIR} + # https://github.com/abseil/abseil-cpp/pull/963 + (fetchpatch { + url = "https://github.com/abseil/abseil-cpp/commit/5bfa70c75e621c5d5ec095c8c4c0c050dcb2957e.patch"; + sha256 = "0nhjxqfxpi2pkfinnqvd5m4npf9l1kg39mjx9l3087ajhadaywl5"; + }) - # Bacport gcc-13 fix: - # https://github.com/abseil/abseil-cpp/pull/1187 - (fetchpatch { - name = "gcc-13.patch"; - url = "https://github.com/abseil/abseil-cpp/commit/36a4b073f1e7e02ed7d1ac140767e36f82f09b7c.patch"; - hash = "sha256-aA7mwGEtv/cQINcawjkukmCvfNuqwUeDFssSiNKPdgg="; - }) - ] ++ lib.optionals stdenv.hostPlatform.isLoongArch64 [ - # https://github.com/abseil/abseil-cpp/pull/1110 - (fetchpatch { - url = "https://github.com/abseil/abseil-cpp/commit/808bc202fc13e85a7948db0d7fb58f0f051200b1.patch"; - sha256 = "sha256-ayY/aV/xWOdEyFSDqV7B5WDGvZ0ASr/aeBeYwP5RZVc="; - }) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # Don’t propagate the path to CoreFoundation. Otherwise, it’s impossible to build packages - # that require a different SDK other than the default one. - ./cmake-core-foundation.patch - ]; + # Bacport gcc-13 fix: + # https://github.com/abseil/abseil-cpp/pull/1187 + (fetchpatch { + name = "gcc-13.patch"; + url = "https://github.com/abseil/abseil-cpp/commit/36a4b073f1e7e02ed7d1ac140767e36f82f09b7c.patch"; + hash = "sha256-aA7mwGEtv/cQINcawjkukmCvfNuqwUeDFssSiNKPdgg="; + }) + ] + ++ lib.optionals stdenv.hostPlatform.isLoongArch64 [ + # https://github.com/abseil/abseil-cpp/pull/1110 + (fetchpatch { + url = "https://github.com/abseil/abseil-cpp/commit/808bc202fc13e85a7948db0d7fb58f0f051200b1.patch"; + sha256 = "sha256-ayY/aV/xWOdEyFSDqV7B5WDGvZ0ASr/aeBeYwP5RZVc="; + }) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # Don’t propagate the path to CoreFoundation. Otherwise, it’s impossible to build packages + # that require a different SDK other than the default one. + ./cmake-core-foundation.patch + ]; - cmakeFlags = [ - "-DBUILD_SHARED_LIBS=${if static then "OFF" else "ON"}" - ] ++ lib.optionals (cxxStandard != null) [ - "-DCMAKE_CXX_STANDARD=${cxxStandard}" - ]; + cmakeFlags = + [ + "-DBUILD_SHARED_LIBS=${if static then "OFF" else "ON"}" + ] + ++ lib.optionals (cxxStandard != null) [ + "-DCMAKE_CXX_STANDARD=${cxxStandard}" + ]; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/development/libraries/accounts-qt/default.nix b/pkgs/development/libraries/accounts-qt/default.nix index e96c4b0aca813f..9b4a4f4a1728a0 100644 --- a/pkgs/development/libraries/accounts-qt/default.nix +++ b/pkgs/development/libraries/accounts-qt/default.nix @@ -1,4 +1,16 @@ -{ stdenv, lib, fetchFromGitLab, gitUpdater, doxygen, glib, libaccounts-glib, pkg-config, qmake, qtbase, wrapQtAppsHook }: +{ + stdenv, + lib, + fetchFromGitLab, + gitUpdater, + doxygen, + glib, + libaccounts-glib, + pkg-config, + qmake, + qtbase, + wrapQtAppsHook, +}: stdenv.mkDerivation (finalAttrs: { pname = "accounts-qt"; @@ -12,9 +24,17 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-mPZgD4r7vlUP6wklvZVknGqTXZBckSOtNzK7p6e2qSA="; }; - propagatedBuildInputs = [ glib libaccounts-glib ]; + propagatedBuildInputs = [ + glib + libaccounts-glib + ]; buildInputs = [ qtbase ]; - nativeBuildInputs = [ doxygen pkg-config qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + doxygen + pkg-config + qmake + wrapQtAppsHook + ]; # remove forbidden references to /build preFixup = '' diff --git a/pkgs/development/libraries/acl/default.nix b/pkgs/development/libraries/acl/default.nix index d4c1956914b9dc..4ed011a71cc7c4 100644 --- a/pkgs/development/libraries/acl/default.nix +++ b/pkgs/development/libraries/acl/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, gettext, attr }: +{ + lib, + stdenv, + fetchurl, + gettext, + attr, +}: # Note: this package is used for bootstrapping fetchurl, and thus # cannot use fetchpatch! All mutable patches (generated by GitHub or @@ -14,7 +20,13 @@ stdenv.mkDerivation rec { hash = "sha256-XyvbrWKXB6p9hcYj+ZSqih0t7FWnPeUgW6wL9gWKL3w="; }; - outputs = [ "bin" "dev" "out" "man" "doc" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + "doc" + ]; nativeBuildInputs = [ gettext ]; buildInputs = [ attr ]; diff --git a/pkgs/development/libraries/agda/1lab/default.nix b/pkgs/development/libraries/agda/1lab/default.nix index b9cea79b582a7a..e21e9537f75975 100644 --- a/pkgs/development/libraries/agda/1lab/default.nix +++ b/pkgs/development/libraries/agda/1lab/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDerivation, fetchFromGitHub }: +{ + lib, + mkDerivation, + fetchFromGitHub, +}: mkDerivation rec { pname = "1lab"; @@ -33,8 +37,7 @@ mkDerivation rec { everythingFile = "_build/all-pages.agda"; meta = with lib; { - description = - "A formalised, cross-linked reference resource for mathematics done in Homotopy Type Theory "; + description = "A formalised, cross-linked reference resource for mathematics done in Homotopy Type Theory "; homepage = src.meta.homepage; license = licenses.agpl3Only; platforms = platforms.unix; diff --git a/pkgs/development/libraries/agda/agda-categories/default.nix b/pkgs/development/libraries/agda/agda-categories/default.nix index cb0d12a3edfb2c..60a74c353f3ea7 100644 --- a/pkgs/development/libraries/agda/agda-categories/default.nix +++ b/pkgs/development/libraries/agda/agda-categories/default.nix @@ -1,4 +1,9 @@ -{ lib, mkDerivation, fetchFromGitHub, standard-library }: +{ + lib, + mkDerivation, + fetchFromGitHub, + standard-library, +}: mkDerivation rec { version = "0.2.0"; @@ -33,6 +38,9 @@ mkDerivation rec { description = "New Categories library"; license = licenses.bsd3; platforms = platforms.unix; - maintainers = with maintainers; [ alexarice turion ]; + maintainers = with maintainers; [ + alexarice + turion + ]; }; } diff --git a/pkgs/development/libraries/agda/agda-prelude/default.nix b/pkgs/development/libraries/agda/agda-prelude/default.nix index 661ffd71f839c1..4150941f09cbe2 100644 --- a/pkgs/development/libraries/agda/agda-prelude/default.nix +++ b/pkgs/development/libraries/agda/agda-prelude/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDerivation, fetchFromGitHub }: +{ + lib, + mkDerivation, + fetchFromGitHub, +}: mkDerivation rec { version = "unstable-2024-08-22"; @@ -23,6 +27,10 @@ mkDerivation rec { description = "Programming library for Agda"; license = lib.licenses.mit; platforms = lib.platforms.unix; - maintainers = with maintainers; [ mudri alexarice turion ]; + maintainers = with maintainers; [ + mudri + alexarice + turion + ]; }; } diff --git a/pkgs/development/libraries/agda/agdarsec/default.nix b/pkgs/development/libraries/agda/agdarsec/default.nix index 34730ae17f4e2b..257172ad31782a 100644 --- a/pkgs/development/libraries/agda/agdarsec/default.nix +++ b/pkgs/development/libraries/agda/agdarsec/default.nix @@ -1,5 +1,9 @@ -{ lib, mkDerivation, fetchFromGitHub -, standard-library }: +{ + lib, + mkDerivation, + fetchFromGitHub, + standard-library, +}: mkDerivation rec { pname = "agdarsec"; @@ -14,7 +18,10 @@ mkDerivation rec { everythingFile = "./index.agda"; - includePaths = [ "src" "examples" ]; + includePaths = [ + "src" + "examples" + ]; buildInputs = [ standard-library ]; diff --git a/pkgs/development/libraries/agda/cubical/default.nix b/pkgs/development/libraries/agda/cubical/default.nix index 3747535bec9d31..8d33b36c55eda5 100644 --- a/pkgs/development/libraries/agda/cubical/default.nix +++ b/pkgs/development/libraries/agda/cubical/default.nix @@ -1,4 +1,9 @@ -{ lib, mkDerivation, fetchFromGitHub, ghc }: +{ + lib, + mkDerivation, + fetchFromGitHub, + ghc, +}: mkDerivation rec { pname = "cubical"; @@ -21,11 +26,15 @@ mkDerivation rec { ''; meta = with lib; { - description = - "A cubical type theory library for use with the Agda compiler"; + description = "A cubical type theory library for use with the Agda compiler"; homepage = src.meta.homepage; license = licenses.mit; platforms = platforms.unix; - maintainers = with maintainers; [ alexarice ryanorendorff ncfavier phijor ]; + maintainers = with maintainers; [ + alexarice + ryanorendorff + ncfavier + phijor + ]; }; } diff --git a/pkgs/development/libraries/agda/functional-linear-algebra/default.nix b/pkgs/development/libraries/agda/functional-linear-algebra/default.nix index c91896993ce5b1..40ec014ca12963 100644 --- a/pkgs/development/libraries/agda/functional-linear-algebra/default.nix +++ b/pkgs/development/libraries/agda/functional-linear-algebra/default.nix @@ -1,4 +1,9 @@ -{ fetchFromGitHub, lib, mkDerivation, standard-library }: +{ + fetchFromGitHub, + lib, + mkDerivation, + standard-library, +}: mkDerivation rec { version = "0.5.0"; diff --git a/pkgs/development/libraries/agda/generic/default.nix b/pkgs/development/libraries/agda/generic/default.nix index 855dd0f33c516d..4f2a787dc66720 100644 --- a/pkgs/development/libraries/agda/generic/default.nix +++ b/pkgs/development/libraries/agda/generic/default.nix @@ -1,4 +1,9 @@ -{ lib, mkDerivation, fetchFromGitHub, standard-library }: +{ + lib, + mkDerivation, + fetchFromGitHub, + standard-library, +}: mkDerivation rec { pname = "generic"; @@ -23,11 +28,13 @@ mkDerivation rec { meta = with lib; { # Remove if a version compatible with agda 2.6.2 is made broken = true; - description = - "A library for doing generic programming in Agda"; + description = "A library for doing generic programming in Agda"; homepage = src.meta.homepage; license = licenses.mit; platforms = platforms.unix; - maintainers = with maintainers; [ alexarice turion ]; + maintainers = with maintainers; [ + alexarice + turion + ]; }; } diff --git a/pkgs/development/libraries/agda/generics/default.nix b/pkgs/development/libraries/agda/generics/default.nix index 12815a3617bc64..71219e334612ce 100644 --- a/pkgs/development/libraries/agda/generics/default.nix +++ b/pkgs/development/libraries/agda/generics/default.nix @@ -1,4 +1,9 @@ -{ lib, mkDerivation, fetchFromGitHub, standard-library }: +{ + lib, + mkDerivation, + fetchFromGitHub, + standard-library, +}: mkDerivation rec { pname = "generics"; @@ -18,8 +23,7 @@ mkDerivation rec { # everythingFile = "./README.agda"; meta = with lib; { - description = - "Library for datatype-generic programming in Agda"; + description = "Library for datatype-generic programming in Agda"; homepage = src.meta.homepage; license = licenses.mit; platforms = platforms.unix; diff --git a/pkgs/development/libraries/agda/iowa-stdlib/default.nix b/pkgs/development/libraries/agda/iowa-stdlib/default.nix index 1383cff9e55a35..55505f0edf42df 100644 --- a/pkgs/development/libraries/agda/iowa-stdlib/default.nix +++ b/pkgs/development/libraries/agda/iowa-stdlib/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDerivation, fetchFromGitHub }: +{ + lib, + mkDerivation, + fetchFromGitHub, +}: mkDerivation (rec { version = "1.5.0"; @@ -6,7 +10,7 @@ mkDerivation (rec { src = fetchFromGitHub { owner = "cedille"; - repo = "ial"; + repo = "ial"; rev = "v${version}"; sha256 = "0dlis6v6nzbscf713cmwlx8h9n2gxghci8y21qak3hp18gkxdp0g"; }; @@ -26,6 +30,9 @@ mkDerivation (rec { platforms = lib.platforms.unix; # broken since Agda 2.6.1 broken = true; - maintainers = with lib.maintainers; [ alexarice turion ]; + maintainers = with lib.maintainers; [ + alexarice + turion + ]; }; }) diff --git a/pkgs/development/libraries/agda/standard-library/default.nix b/pkgs/development/libraries/agda/standard-library/default.nix index 02f0eb327077ec..a9315c34274ce8 100644 --- a/pkgs/development/libraries/agda/standard-library/default.nix +++ b/pkgs/development/libraries/agda/standard-library/default.nix @@ -1,4 +1,10 @@ -{ lib, mkDerivation, fetchFromGitHub, ghcWithPackages, nixosTests }: +{ + lib, + mkDerivation, + fetchFromGitHub, + ghcWithPackages, + nixosTests, +}: mkDerivation rec { pname = "standard-library"; @@ -11,7 +17,7 @@ mkDerivation rec { hash = "sha256-4HfwNAkIhk1yC/oSxZ30xilzUM5/22nzbUSqTjcW5Ng="; }; - nativeBuildInputs = [ (ghcWithPackages (self : [ self.filemanip ])) ]; + nativeBuildInputs = [ (ghcWithPackages (self: [ self.filemanip ])) ]; preConfigure = '' runhaskell GenerateEverything.hs --include-deprecated # We will only build/consider Everything.agda, in particular we don't want Everything*.agda @@ -25,6 +31,11 @@ mkDerivation rec { description = "Standard library for use with the Agda compiler"; license = lib.licenses.mit; platforms = lib.platforms.unix; - maintainers = with maintainers; [ jwiegley mudri alexarice turion ]; + maintainers = with maintainers; [ + jwiegley + mudri + alexarice + turion + ]; }; } diff --git a/pkgs/development/libraries/agg/default.nix b/pkgs/development/libraries/agg/default.nix index 06d32b07baf2ee..d004915e04f1f0 100644 --- a/pkgs/development/libraries/agg/default.nix +++ b/pkgs/development/libraries/agg/default.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchurl, autoconf, automake, libtool, pkg-config -, freetype, SDL, libX11 }: +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + libtool, + pkg-config, + freetype, + SDL, + libX11, +}: stdenv.mkDerivation rec { pname = "agg"; @@ -14,12 +24,14 @@ stdenv.mkDerivation rec { automake libtool ]; - buildInputs = [ - freetype - SDL - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libX11 - ]; + buildInputs = + [ + freetype + SDL + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libX11 + ]; postPatch = '' substituteInPlace include/agg_renderer_outline_aa.h \ @@ -32,14 +44,16 @@ stdenv.mkDerivation rec { sh autogen.sh ''; - configureFlags = [ - (lib.enableFeature stdenv.hostPlatform.isLinux "platform") - (lib.enableFeature (!stdenv.hostPlatform.isDarwin) "sdltest") - "--enable-examples=no" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "--x-includes=${lib.getDev libX11}/include" - "--x-libraries=${lib.getLib libX11}/lib" - ]; + configureFlags = + [ + (lib.enableFeature stdenv.hostPlatform.isLinux "platform") + (lib.enableFeature (!stdenv.hostPlatform.isDarwin) "sdltest") + "--enable-examples=no" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "--x-includes=${lib.getDev libX11}/include" + "--x-libraries=${lib.getLib libX11}/lib" + ]; NIX_CFLAGS_COMPILE = [ "-fpermissive" ]; diff --git a/pkgs/development/libraries/alembic/default.nix b/pkgs/development/libraries/alembic/default.nix index b5fedecf0e813f..091edf3494127d 100644 --- a/pkgs/development/libraries/alembic/default.nix +++ b/pkgs/development/libraries/alembic/default.nix @@ -1,7 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, openexr, hdf5-threadsafe }: - -stdenv.mkDerivation rec { + lib, + stdenv, + fetchFromGitHub, + cmake, + openexr, + hdf5-threadsafe, +}: + +stdenv.mkDerivation rec { pname = "alembic"; version = "1.8.8"; @@ -13,14 +19,22 @@ stdenv.mkDerivation rec }; # note: out is unused (but required for outputDoc anyway) - outputs = [ "bin" "dev" "out" "lib" ]; + outputs = [ + "bin" + "dev" + "out" + "lib" + ]; # Prevent cycle between bin and dev (only occurs on Darwin for some reason) propagatedBuildOutputs = [ "lib" ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ openexr hdf5-threadsafe ]; + buildInputs = [ + openexr + hdf5-threadsafe + ]; # These flags along with the postPatch step ensure that all artifacts end up # in the correct output without needing to move anything @@ -57,6 +71,9 @@ stdenv.mkDerivation rec homepage = "http://alembic.io/"; license = licenses.bsd3; platforms = platforms.all; - maintainers = with maintainers; [ guibou tmarkus ]; + maintainers = with maintainers; [ + guibou + tmarkus + ]; }; } diff --git a/pkgs/development/libraries/alkimia/default.nix b/pkgs/development/libraries/alkimia/default.nix index d5c89209ce5dab..681b81ba9639a5 100644 --- a/pkgs/development/libraries/alkimia/default.nix +++ b/pkgs/development/libraries/alkimia/default.nix @@ -1,6 +1,17 @@ -{ mkDerivation, fetchurl, lib -, extra-cmake-modules, doxygen, graphviz, qtbase, qtwebengine, mpir -, kdelibs4support, plasma-framework, knewstuff, kpackage +{ + mkDerivation, + fetchurl, + lib, + extra-cmake-modules, + doxygen, + graphviz, + qtbase, + qtwebengine, + mpir, + kdelibs4support, + plasma-framework, + knewstuff, + kpackage, }: mkDerivation rec { @@ -12,12 +23,23 @@ mkDerivation rec { sha256 = "sha256-z4Ru6HucxjD1jgvdIzNCloELo7zBdR/i9HIhYYl+4zo="; }; - nativeBuildInputs = [ extra-cmake-modules doxygen graphviz ]; + nativeBuildInputs = [ + extra-cmake-modules + doxygen + graphviz + ]; # qtwebengine is not a mandatory dependency, but it adds some features # we might need for alkimia's dependents. See: # https://github.com/KDE/alkimia/blob/v8.1.2/CMakeLists.txt#L124 - buildInputs = [ qtbase qtwebengine kdelibs4support plasma-framework knewstuff kpackage ]; + buildInputs = [ + qtbase + qtwebengine + kdelibs4support + plasma-framework + knewstuff + kpackage + ]; propagatedBuildInputs = [ mpir ]; meta = { diff --git a/pkgs/development/libraries/allegro/default.nix b/pkgs/development/libraries/allegro/default.nix index be521257f1955b..c729bd547ab688 100644 --- a/pkgs/development/libraries/allegro/default.nix +++ b/pkgs/development/libraries/allegro/default.nix @@ -1,11 +1,30 @@ -{ lib, stdenv, fetchurl, texinfo6_5, libXext, xorgproto, libX11 -, libXpm, libXt, libXcursor, alsa-lib, cmake, zlib, libpng, libvorbis -, libXxf86dga, libXxf86misc -, libXxf86vm, openal, libGLU, libGL }: +{ + lib, + stdenv, + fetchurl, + texinfo6_5, + libXext, + xorgproto, + libX11, + libXpm, + libXt, + libXcursor, + alsa-lib, + cmake, + zlib, + libpng, + libvorbis, + libXxf86dga, + libXxf86misc, + libXxf86vm, + openal, + libGLU, + libGL, +}: stdenv.mkDerivation rec { pname = "allegro"; - version="4.4.3.1"; + version = "4.4.3.1"; src = fetchurl { url = "https://github.com/liballeg/allegro5/releases/download/${version}/${pname}-${version}.tar.gz"; @@ -19,9 +38,23 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; buildInputs = [ - texinfo6_5 libXext xorgproto libX11 libXpm libXt libXcursor - alsa-lib zlib libpng libvorbis libXxf86dga libXxf86misc - libXxf86vm openal libGLU libGL + texinfo6_5 + libXext + xorgproto + libX11 + libXpm + libXt + libXcursor + alsa-lib + zlib + libpng + libvorbis + libXxf86dga + libXxf86misc + libXxf86vm + openal + libGLU + libGL ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/development/libraries/applet-window-appmenu/default.nix b/pkgs/development/libraries/applet-window-appmenu/default.nix index 09185bfb3c26d0..ea4507b52d0b2f 100644 --- a/pkgs/development/libraries/applet-window-appmenu/default.nix +++ b/pkgs/development/libraries/applet-window-appmenu/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, kcoreaddons -, kdeclarative -, kdecoration -, plasma-framework -, plasma-workspace -, libSM -, qtx11extras -, kwindowsystem -, libdbusmenu -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + kcoreaddons, + kdeclarative, + kdecoration, + plasma-framework, + plasma-workspace, + libSM, + qtx11extras, + kwindowsystem, + libdbusmenu, + wrapQtAppsHook, }: stdenv.mkDerivation { diff --git a/pkgs/development/libraries/applet-window-buttons/default.nix b/pkgs/development/libraries/applet-window-buttons/default.nix index 4f605b8af98b6b..ed67ddd197af67 100644 --- a/pkgs/development/libraries/applet-window-buttons/default.nix +++ b/pkgs/development/libraries/applet-window-buttons/default.nix @@ -1,13 +1,14 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, fetchpatch -, cmake -, extra-cmake-modules -, kcoreaddons -, kdeclarative -, kdecoration -, plasma-framework +{ + lib, + mkDerivation, + fetchFromGitHub, + fetchpatch, + cmake, + extra-cmake-modules, + kcoreaddons, + kdeclarative, + kdecoration, + plasma-framework, }: mkDerivation rec { diff --git a/pkgs/development/libraries/appstream/qt.nix b/pkgs/development/libraries/appstream/qt.nix index 4699c7ce934ecb..d79db8c3c64002 100644 --- a/pkgs/development/libraries/appstream/qt.nix +++ b/pkgs/development/libraries/appstream/qt.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, appstream, qtbase, qttools, nixosTests }: +{ + lib, + stdenv, + appstream, + qtbase, + qttools, + nixosTests, +}: # TODO: look into using the libraries from the regular appstream derivation as we keep duplicates here @@ -9,9 +16,16 @@ stdenv.mkDerivation { pname = "appstream-qt"; inherit (appstream) version src; - outputs = [ "out" "dev" "installedTests" ]; + outputs = [ + "out" + "dev" + "installedTests" + ]; - buildInputs = appstream.buildInputs ++ [ appstream qtbase ]; + buildInputs = appstream.buildInputs ++ [ + appstream + qtbase + ]; nativeBuildInputs = appstream.nativeBuildInputs ++ [ qttools ]; @@ -41,5 +55,5 @@ stdenv.mkDerivation { meta = appstream.meta // { description = "Software metadata handling library - Qt"; - }; + }; } diff --git a/pkgs/development/libraries/apr/default.nix b/pkgs/development/libraries/apr/default.nix index 7d127f9367c0fa..5df85f8b536761 100644 --- a/pkgs/development/libraries/apr/default.nix +++ b/pkgs/development/libraries/apr/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, buildPackages, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + buildPackages, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "apr"; @@ -18,42 +24,46 @@ stdenv.mkDerivation rec { rm test/testsock.* ''; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; outputBin = "dev"; - preConfigure = - '' - configureFlagsArray+=("--with-installbuilddir=$dev/share/build") - ''; + preConfigure = '' + configureFlagsArray+=("--with-installbuilddir=$dev/share/build") + ''; - configureFlags = lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - # For cross builds, provide answers to the configure time tests. - # These answers are valid on x86_64-linux and aarch64-linux. - "ac_cv_file__dev_zero=yes" - "ac_cv_func_setpgrp_void=yes" - "apr_cv_tcp_nodelay_with_cork=yes" - "ac_cv_define_PTHREAD_PROCESS_SHARED=yes" - "apr_cv_process_shared_works=yes" - "apr_cv_mutex_robust_shared=yes" - "ap_cv_atomic_builtins=yes" - "apr_cv_mutex_recursive=yes" - "apr_cv_epoll=yes" - "apr_cv_epoll_create1=yes" - "apr_cv_dup3=yes" - "apr_cv_accept4=yes" - "apr_cv_sock_cloexec=yes" - "ac_cv_struct_rlimit=yes" - "ac_cv_func_sem_open=yes" - "ac_cv_negative_eai=yes" - "apr_cv_gai_addrconfig=yes" - "ac_cv_o_nonblock_inherited=no" - "apr_cv_pthreads_lib=-lpthread" - "CC_FOR_BUILD=${buildPackages.stdenv.cc}/bin/cc" - ] ++ lib.optionals (stdenv.hostPlatform.system == "i686-cygwin") [ - # Including the Windows headers breaks unistd.h. - # Based on ftp://sourceware.org/pub/cygwin/release/libapr1/libapr1-1.3.8-2-src.tar.bz2 - "ac_cv_header_windows_h=no" - ]; + configureFlags = + lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + # For cross builds, provide answers to the configure time tests. + # These answers are valid on x86_64-linux and aarch64-linux. + "ac_cv_file__dev_zero=yes" + "ac_cv_func_setpgrp_void=yes" + "apr_cv_tcp_nodelay_with_cork=yes" + "ac_cv_define_PTHREAD_PROCESS_SHARED=yes" + "apr_cv_process_shared_works=yes" + "apr_cv_mutex_robust_shared=yes" + "ap_cv_atomic_builtins=yes" + "apr_cv_mutex_recursive=yes" + "apr_cv_epoll=yes" + "apr_cv_epoll_create1=yes" + "apr_cv_dup3=yes" + "apr_cv_accept4=yes" + "apr_cv_sock_cloexec=yes" + "ac_cv_struct_rlimit=yes" + "ac_cv_func_sem_open=yes" + "ac_cv_negative_eai=yes" + "apr_cv_gai_addrconfig=yes" + "ac_cv_o_nonblock_inherited=no" + "apr_cv_pthreads_lib=-lpthread" + "CC_FOR_BUILD=${buildPackages.stdenv.cc}/bin/cc" + ] + ++ lib.optionals (stdenv.hostPlatform.system == "i686-cygwin") [ + # Including the Windows headers breaks unistd.h. + # Based on ftp://sourceware.org/pub/cygwin/release/libapr1/libapr1-1.3.8-2-src.tar.bz2 + "ac_cv_header_windows_h=no" + ]; # - Update libtool for macOS 11 support # - Regenerate for cross fix patch diff --git a/pkgs/development/libraries/aqbanking/default.nix b/pkgs/development/libraries/aqbanking/default.nix index 2b9f1a5913feb1..07ee1aef910c9d 100644 --- a/pkgs/development/libraries/aqbanking/default.nix +++ b/pkgs/development/libraries/aqbanking/default.nix @@ -1,10 +1,22 @@ -{ lib, stdenv, fetchurl, gmp, gwenhywfar, libtool, libxml2, libxslt -, pkg-config, gettext, xmlsec, zlib +{ + lib, + stdenv, + fetchurl, + gmp, + gwenhywfar, + libtool, + libxml2, + libxslt, + pkg-config, + gettext, + xmlsec, + zlib, }: let inherit ((import ./sources.nix).aqbanking) hash releaseId version; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "aqbanking"; inherit version; @@ -23,14 +35,25 @@ in stdenv.mkDerivation rec { }' configure ''; - buildInputs = [ gmp gwenhywfar libtool libxml2 libxslt xmlsec zlib ]; + buildInputs = [ + gmp + gwenhywfar + libtool + libxml2 + libxslt + xmlsec + zlib + ]; - nativeBuildInputs = [ pkg-config gettext ]; + nativeBuildInputs = [ + pkg-config + gettext + ]; meta = with lib; { description = "Interface to banking tasks, file formats and country information"; homepage = "https://www.aquamaniac.de/rdm/"; - hydraPlatforms = []; + hydraPlatforms = [ ]; license = licenses.gpl2Plus; maintainers = [ ]; platforms = platforms.linux; diff --git a/pkgs/development/libraries/aqbanking/gwenhywfar.nix b/pkgs/development/libraries/aqbanking/gwenhywfar.nix index ff0e55a446dbd2..a779438003320e 100644 --- a/pkgs/development/libraries/aqbanking/gwenhywfar.nix +++ b/pkgs/development/libraries/aqbanking/gwenhywfar.nix @@ -1,18 +1,29 @@ -{ lib, stdenv, fetchurl, gnutls, openssl, libgcrypt, libgpg-error, pkg-config, gettext -, which +{ + lib, + stdenv, + fetchurl, + gnutls, + openssl, + libgcrypt, + libgpg-error, + pkg-config, + gettext, + which, -# GUI support -, gtk3, qt5 + # GUI support + gtk3, + qt5, -, pluginSearchPaths ? [ + pluginSearchPaths ? [ "/run/current-system/sw/lib/gwenhywfar/plugins" ".nix-profile/lib/gwenhywfar/plugins" - ] + ], }: let inherit ((import ./sources.nix).gwenhywfar) hash releaseId version; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "gwenhywfar"; inherit version; @@ -30,32 +41,48 @@ in stdenv.mkDerivation rec { configureFlagsArray+=("--with-guis=gtk3 qt5") ''; - postPatch = let - isRelative = path: builtins.substring 0 1 path != "/"; - mkSearchPath = path: '' - p; g; s,\,"${path}",g; - '' + lib.optionalString (isRelative path) '' - s/AddPath(\(.*\));/AddRelPath(\1, GWEN_PathManager_RelModeHome);/g - ''; + postPatch = + let + isRelative = path: builtins.substring 0 1 path != "/"; + mkSearchPath = + path: + '' + p; g; s,\,"${path}",g; + '' + + lib.optionalString (isRelative path) '' + s/AddPath(\(.*\));/AddRelPath(\1, GWEN_PathManager_RelModeHome);/g + ''; - in '' - sed -i -e '/GWEN_PathManager_DefinePath.*GWEN_PM_PLUGINDIR/,/^#endif/ { - /^#if/,/^#endif/ { - H; /^#endif/ { - ${lib.concatMapStrings mkSearchPath pluginSearchPaths} + in + '' + sed -i -e '/GWEN_PathManager_DefinePath.*GWEN_PM_PLUGINDIR/,/^#endif/ { + /^#if/,/^#endif/ { + H; /^#endif/ { + ${lib.concatMapStrings mkSearchPath pluginSearchPaths} + } } - } - }' src/gwenhywfar.c + }' src/gwenhywfar.c - # Strip off the effective SO version from the path so that for example - # "lib/gwenhywfar/plugins/60" becomes just "lib/gwenhywfar/plugins". - sed -i -e '/^gwenhywfar_plugindir=/s,/\''${GWENHYWFAR_SO_EFFECTIVE},,' \ - configure - ''; + # Strip off the effective SO version from the path so that for example + # "lib/gwenhywfar/plugins/60" becomes just "lib/gwenhywfar/plugins". + sed -i -e '/^gwenhywfar_plugindir=/s,/\''${GWENHYWFAR_SO_EFFECTIVE},,' \ + configure + ''; - nativeBuildInputs = [ pkg-config gettext which ]; + nativeBuildInputs = [ + pkg-config + gettext + which + ]; - buildInputs = [ gtk3 qt5.qtbase gnutls openssl libgcrypt libgpg-error ]; + buildInputs = [ + gtk3 + qt5.qtbase + gnutls + openssl + libgcrypt + libgpg-error + ]; dontWrapQtApps = true; diff --git a/pkgs/development/libraries/aqbanking/libchipcard.nix b/pkgs/development/libraries/aqbanking/libchipcard.nix index 9190e1ad9b797f..e9b85f1db8de29 100644 --- a/pkgs/development/libraries/aqbanking/libchipcard.nix +++ b/pkgs/development/libraries/aqbanking/libchipcard.nix @@ -1,8 +1,17 @@ -{ lib, stdenv, fetchurl, pkg-config, gwenhywfar, pcsclite, zlib }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gwenhywfar, + pcsclite, + zlib, +}: let inherit ((import ./sources.nix).libchipcard) hash releaseId version; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "libchipcard"; inherit version; @@ -13,7 +22,11 @@ in stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gwenhywfar pcsclite zlib ]; + buildInputs = [ + gwenhywfar + pcsclite + zlib + ]; makeFlags = [ "crypttokenplugindir=$(out)/lib/gwenhywfar/plugins/ct" ]; diff --git a/pkgs/development/libraries/arrayfire/default.nix b/pkgs/development/libraries/arrayfire/default.nix index eb928f99e88a79..c33e6f4cbfe258 100644 --- a/pkgs/development/libraries/arrayfire/default.nix +++ b/pkgs/development/libraries/arrayfire/default.nix @@ -1,35 +1,36 @@ -{ blas -, boost -, clblast -, cmake -, config -, cudaPackages -, fetchFromGitHub -, fftw -, fftwFloat -, fmt_9 -, forge -, freeimage -, gtest -, lapack -, lib -, libGL -, mesa -, ocl-icd -, opencl-clhpp -, pkg-config -, python3 -, span-lite -, stdenv +{ + blas, + boost, + clblast, + cmake, + config, + cudaPackages, + fetchFromGitHub, + fftw, + fftwFloat, + fmt_9, + forge, + freeimage, + gtest, + lapack, + lib, + libGL, + mesa, + ocl-icd, + opencl-clhpp, + pkg-config, + python3, + span-lite, + stdenv, # NOTE: We disable tests by default, because they cannot be run easily on # non-NixOS systems when either CUDA or OpenCL support is enabled (CUDA and # OpenCL need access to drivers that are installed outside of Nix on # non-NixOS systems). -, doCheck ? false -, cpuSupport ? true -, cudaSupport ? config.cudaSupport + doCheck ? false, + cpuSupport ? true, + cudaSupport ? config.cudaSupport, # OpenCL needs mesa which is broken on Darwin -, openclSupport ? !stdenv.hostPlatform.isDarwin + openclSupport ? !stdenv.hostPlatform.isDarwin, # This argument lets one run CUDA & OpenCL tests on non-NixOS systems by # telling Nix where to find the drivers. If you know the version of the # Nvidia driver that is installed on your system, you can do: @@ -48,8 +49,8 @@ # }) # { libsOnly = true; }; # } -, nvidiaComputeDrivers ? null -, fetchpatch + nvidiaComputeDrivers ? null, + fetchpatch, }: # ArrayFire compiles with 64-bit BLAS, but some tests segfault or throw @@ -106,28 +107,30 @@ stdenv.mkDerivation rec { hash = "sha256-GSUdHtvV/97RyDKy8i+ticnSlQCubGGWHg4Oo+YAr8Y="; }; - cmakeFlags = [ - "-DBUILD_TESTING=ON" - # We do not build examples, because building tests already takes long enough... - "-DAF_BUILD_EXAMPLES=OFF" - # No need to build forge, because it's a separate package - "-DAF_BUILD_FORGE=OFF" - "-DAF_COMPUTE_LIBRARY='FFTW/LAPACK/BLAS'" - # Prevent ArrayFire from trying to download some matrices from the Internet - "-DAF_TEST_WITH_MTX_FILES=OFF" - # Have to use the header-only version, because we're not using the version - # from Nixpkgs. Otherwise, libaf.so won't be able to find the shared - # library, because ArrayFire's CMake files do not run the install step of - # spdlog. - "-DAF_WITH_SPDLOG_HEADER_ONLY=ON" - (if cpuSupport then "-DAF_BUILD_CPU=ON" else "-DAF_BUILD_CPU=OFF") - (if openclSupport then "-DAF_BUILD_OPENCL=ON" else "-DAF_BUILD_OPENCL=OFF") - (if cudaSupport then "-DAF_BUILD_CUDA=ON" else "-DAF_BUILD_CUDA=OFF") - ] ++ lib.optionals cudaSupport [ - # ArrayFire use deprecated FindCUDA in their CMake files, so we help CMake - # locate cudatoolkit. - "-DCUDA_LIBRARIES_PATH=${cudaPackages.cudatoolkit}/lib" - ]; + cmakeFlags = + [ + "-DBUILD_TESTING=ON" + # We do not build examples, because building tests already takes long enough... + "-DAF_BUILD_EXAMPLES=OFF" + # No need to build forge, because it's a separate package + "-DAF_BUILD_FORGE=OFF" + "-DAF_COMPUTE_LIBRARY='FFTW/LAPACK/BLAS'" + # Prevent ArrayFire from trying to download some matrices from the Internet + "-DAF_TEST_WITH_MTX_FILES=OFF" + # Have to use the header-only version, because we're not using the version + # from Nixpkgs. Otherwise, libaf.so won't be able to find the shared + # library, because ArrayFire's CMake files do not run the install step of + # spdlog. + "-DAF_WITH_SPDLOG_HEADER_ONLY=ON" + (if cpuSupport then "-DAF_BUILD_CPU=ON" else "-DAF_BUILD_CPU=OFF") + (if openclSupport then "-DAF_BUILD_OPENCL=ON" else "-DAF_BUILD_OPENCL=OFF") + (if cudaSupport then "-DAF_BUILD_CUDA=ON" else "-DAF_BUILD_CUDA=OFF") + ] + ++ lib.optionals cudaSupport [ + # ArrayFire use deprecated FindCUDA in their CMake files, so we help CMake + # locate cudatoolkit. + "-DCUDA_LIBRARIES_PATH=${cudaPackages.cudatoolkit}/lib" + ]; # ArrayFire have a repo with assets for the examples. Since we don't build # the examples anyway, remove the dependency on assets. @@ -165,55 +168,64 @@ stdenv.mkDerivation rec { checkPhase = let LD_LIBRARY_PATH = builtins.concatStringsSep ":" ( - [ "${forge}/lib" "${freeimage}/lib" ] + [ + "${forge}/lib" + "${freeimage}/lib" + ] ++ lib.optional cudaSupport "${cudaPackages.cudatoolkit}/lib64" # On non-NixOS systems, help the tests find Nvidia drivers ++ lib.optional (nvidiaComputeDrivers != null) "${nvidiaComputeDrivers}/lib" ); ctestFlags = builtins.concatStringsSep " " ( # We have to run with "-j1" otherwise various segfaults occur on non-NixOS systems. - [ "--output-on-errors" "-j1" ] + [ + "--output-on-errors" + "-j1" + ] # See https://github.com/arrayfire/arrayfire/issues/3484 ++ lib.optional openclSupport "-E '(inverse_dense|cholesky_dense)'" ); in '' export LD_LIBRARY_PATH=${LD_LIBRARY_PATH} - '' + - # On non-NixOS systems, help the tests find Nvidia drivers - lib.optionalString (openclSupport && nvidiaComputeDrivers != null) '' - export OCL_ICD_VENDORS=${nvidiaComputeDrivers}/etc/OpenCL/vendors - '' + '' + '' + + + # On non-NixOS systems, help the tests find Nvidia drivers + lib.optionalString (openclSupport && nvidiaComputeDrivers != null) '' + export OCL_ICD_VENDORS=${nvidiaComputeDrivers}/etc/OpenCL/vendors + '' + + '' # Note: for debugging, enable AF_TRACE=all AF_PRINT_ERRORS=1 ctest ${ctestFlags} ''; - buildInputs = [ - blas - boost.dev - boost.out - clblast - fftw - fftwFloat - # We need fmt_9 because ArrayFire fails to compile with newer versions. - fmt_9 - forge - freeimage - gtest - lapack - libGL - ocl-icd - opencl-clhpp - span-lite - ] - ++ lib.optionals cudaSupport [ - cudaPackages.cudatoolkit - cudaPackages.cudnn - cudaPackages.cuda_cccl - ] - ++ lib.optionals openclSupport [ - mesa - ]; + buildInputs = + [ + blas + boost.dev + boost.out + clblast + fftw + fftwFloat + # We need fmt_9 because ArrayFire fails to compile with newer versions. + fmt_9 + forge + freeimage + gtest + lapack + libGL + ocl-icd + opencl-clhpp + span-lite + ] + ++ lib.optionals cudaSupport [ + cudaPackages.cudatoolkit + cudaPackages.cudnn + cudaPackages.cuda_cccl + ] + ++ lib.optionals openclSupport [ + mesa + ]; nativeBuildInputs = [ cmake @@ -229,6 +241,9 @@ stdenv.mkDerivation rec { license = licenses.bsd3; homepage = "https://arrayfire.com/"; platforms = platforms.linux; - maintainers = with maintainers; [ chessai twesterhout ]; + maintainers = with maintainers; [ + chessai + twesterhout + ]; }; } diff --git a/pkgs/development/libraries/asio/1.10.nix b/pkgs/development/libraries/asio/1.10.nix index f63fbbd495cb75..1a283bc77f1eb6 100644 --- a/pkgs/development/libraries/asio/1.10.nix +++ b/pkgs/development/libraries/asio/1.10.nix @@ -1,6 +1,9 @@ -{callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./generic.nix (args // { - version = "1.10.8"; - sha256 = "0jgdl4fxw0hwy768rl3lhdc0czz7ak7czf3dg10j21pdpfpfvpi6"; -}) +callPackage ./generic.nix ( + args + // { + version = "1.10.8"; + sha256 = "0jgdl4fxw0hwy768rl3lhdc0czz7ak7czf3dg10j21pdpfpfvpi6"; + } +) diff --git a/pkgs/development/libraries/asio/default.nix b/pkgs/development/libraries/asio/default.nix index 4df73c752e5d4b..5508f848cc689f 100644 --- a/pkgs/development/libraries/asio/default.nix +++ b/pkgs/development/libraries/asio/default.nix @@ -1,6 +1,9 @@ -{callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./generic.nix (args // { - version = "1.24.0"; - sha256 = "sha256-iXaBLCShGGAPb88HGiBgZjCmmv5MCr7jsN6lKOaCxYU="; -}) +callPackage ./generic.nix ( + args + // { + version = "1.24.0"; + sha256 = "sha256-iXaBLCShGGAPb88HGiBgZjCmmv5MCr7jsN6lKOaCxYU="; + } +) diff --git a/pkgs/development/libraries/asio/generic.nix b/pkgs/development/libraries/asio/generic.nix index 44dd9e056874db..d3ab8aa40038ae 100644 --- a/pkgs/development/libraries/asio/generic.nix +++ b/pkgs/development/libraries/asio/generic.nix @@ -1,5 +1,12 @@ -{lib, stdenv, fetchurl, boost, openssl -, version, sha256, ... +{ + lib, + stdenv, + fetchurl, + boost, + openssl, + version, + sha256, + ... }: stdenv.mkDerivation { diff --git a/pkgs/development/libraries/aspell/aspell-with-dicts.nix b/pkgs/development/libraries/aspell/aspell-with-dicts.nix index fae94dbf08d2be..a66e86bf77f904 100644 --- a/pkgs/development/libraries/aspell/aspell-with-dicts.nix +++ b/pkgs/development/libraries/aspell/aspell-with-dicts.nix @@ -5,10 +5,11 @@ # dependency by another derivation, the passed dictionaries will be # missing. However, invoking aspell directly should be fine. -{ aspell -, aspellDicts -, makeWrapper -, buildEnv +{ + aspell, + aspellDicts, + makeWrapper, + buildEnv, }: f: @@ -17,7 +18,8 @@ let # Dictionaries we want dicts = f aspellDicts; -in buildEnv { +in +buildEnv { name = "aspell-env"; nativeBuildInputs = [ makeWrapper ]; paths = [ aspell ] ++ dicts; diff --git a/pkgs/development/libraries/aspell/default.nix b/pkgs/development/libraries/aspell/default.nix index 8c152d32ef6c3e..2cc9ff68f7df99 100644 --- a/pkgs/development/libraries/aspell/default.nix +++ b/pkgs/development/libraries/aspell/default.nix @@ -1,9 +1,17 @@ -{ lib, stdenv, fetchurl, fetchzip, perl, ncurses +{ + lib, + stdenv, + fetchurl, + fetchzip, + perl, + ncurses, # for tests -, aspell, glibc, runCommand + aspell, + glibc, + runCommand, -, searchNixProfiles ? true + searchNixProfiles ? true, }: let @@ -34,7 +42,10 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ perl ]; - buildInputs = [ ncurses perl ]; + buildInputs = [ + ncurses + perl + ]; doCheck = true; @@ -53,16 +64,19 @@ stdenv.mkDerivation rec { ''; passthru.tests = { - uses-curses = runCommand "${pname}-curses" { - buildInputs = [ glibc ]; - } '' - if ! ldd ${aspell}/bin/aspell | grep -q ${ncurses} - then - echo "Test failure: It does not look like aspell picked up the curses dependency." - exit 1 - fi - touch $out - ''; + uses-curses = + runCommand "${pname}-curses" + { + buildInputs = [ glibc ]; + } + '' + if ! ldd ${aspell}/bin/aspell | grep -q ${ncurses} + then + echo "Test failure: It does not look like aspell picked up the curses dependency." + exit 1 + fi + touch $out + ''; }; meta = { diff --git a/pkgs/development/libraries/aspell/dictionaries.nix b/pkgs/development/libraries/aspell/dictionaries.nix index 5958d23e2f2612..4874bb653eb8ec 100644 --- a/pkgs/development/libraries/aspell/dictionaries.nix +++ b/pkgs/development/libraries/aspell/dictionaries.nix @@ -1,185 +1,231 @@ -{lib, stdenv, fetchurl, aspell, which, writeScript}: - -/* HOWTO: - - * Add some of these to your profile or systemPackages. - - ~~~~ - environment.systemPackages = [ - aspell - aspellDicts.en - aspellDicts.en-computers - aspellDicts.en-science - ]; - ~~~~ - - * Rebuild and switch to the new profile. - * Add something like +{ + lib, + stdenv, + fetchurl, + aspell, + which, + writeScript, +}: + +/* + HOWTO: + + * Add some of these to your profile or systemPackages. + + ~~~~ + environment.systemPackages = [ + aspell + aspellDicts.en + aspellDicts.en-computers + aspellDicts.en-science + ]; + ~~~~ - ~~~~ - master en_US - extra-dicts en-computers.rws - add-extra-dicts en_US-science.rws - ~~~~ + * Rebuild and switch to the new profile. + * Add something like - to `/etc/aspell.conf` or `~/.aspell.conf`. - * Check that `aspell -a` starts without errors. - * (optional) Check your config with `aspell dump config | grep -vE '^(#|$)'`. - * Enjoy. + ~~~~ + master en_US + extra-dicts en-computers.rws + add-extra-dicts en_US-science.rws + ~~~~ + to `/etc/aspell.conf` or `~/.aspell.conf`. + * Check that `aspell -a` starts without errors. + * (optional) Check your config with `aspell dump config | grep -vE '^(#|$)'`. + * Enjoy. */ let - /* Function to compile an Aspell dictionary. Fortunately, they all - build in the exact same way. */ + /* + Function to compile an Aspell dictionary. Fortunately, they all + build in the exact same way. + */ buildDict = - {shortName, fullName, ...}@args: + { shortName, fullName, ... }@args: - stdenv.mkDerivation ({ - pname = "aspell-dict-${shortName}"; + stdenv.mkDerivation ( + { + pname = "aspell-dict-${shortName}"; - strictDeps = true; + strictDeps = true; - nativeBuildInputs = [ aspell which ]; + nativeBuildInputs = [ + aspell + which + ]; - dontAddPrefix = true; + dontAddPrefix = true; - configurePlatforms = [ ]; + configurePlatforms = [ ]; - preBuild = "makeFlagsArray=(dictdir=$out/lib/aspell datadir=$out/lib/aspell)"; - - meta = { - description = "Aspell dictionary for ${fullName}"; - platforms = lib.platforms.all; - } // (args.meta or {}); - } // removeAttrs args [ "meta" ]); + preBuild = "makeFlagsArray=(dictdir=$out/lib/aspell datadir=$out/lib/aspell)"; + meta = { + description = "Aspell dictionary for ${fullName}"; + platforms = lib.platforms.all; + } // (args.meta or { }); + } + // removeAttrs args [ "meta" ] + ); buildOfficialDict = - {language, version, filename, fullName, sha256, ...}@args: - let buildArgs = { - shortName = "${language}"; - - src = fetchurl { - url = "mirror://gnu/aspell/dict/${language}/${filename}-${language}-${version}.tar.bz2"; - inherit sha256; - }; - - /* Remove any instances of u-deva.cmap and u-deva.cset since - they are included in the main aspell package and can - cause conflicts otherwise. */ - postInstall = '' - rm -f $out/lib/aspell/u-deva.{cmap,cset} - ''; - - passthru.updateScript = writeScript "update-aspellDict-${language}" '' - #!/usr/bin/env nix-shell - #!nix-shell -i bash -p nix curl gnused common-updater-scripts - set -eu -o pipefail - - # List tarballs in the dictionary's subdirectory via HTTPS and - # the simple list method of Apache's mod_autoindex. - # - # Catalan dictionary has an exception where an earlier version - # compares as newer because the versioning scheme has changed. - versions=$( - echo '['; - curl -s 'https://ftp.gnu.org/gnu/aspell/dict/${language}/?F=0' | \ - sed -r 's/.* href="${filename}-${language}-([A-Za-z0-9_+.-]+)\.tar\.bz2".*/"\1"/;t;d' | \ - if [ '${language}' = "ca" ]; then grep -v 20040130-1; else cat; fi; \ - echo ']') - - # Sort versions in descending order using Nix's and take the first as the latest. - sortVersions="(with builtins; head (sort (a: b: compareVersions a b > 0) $versions))" - # nix-instantiate outputs Nix strings (with quotes), so remove them to get - # a result similar to `nix eval --raw`. - latestVersion=$(nix-instantiate --eval --expr "$sortVersions" | tr -d '"') - - update-source-version aspellDicts.${language} "$latestVersion" - ''; - - meta = { - homepage = "http://ftp.gnu.org/gnu/aspell/dict/0index.html"; - } // (args.meta or {}); - - } // lib.optionalAttrs (lib.elem language [ "is" "nb" ]) { - # These have Windows-1251 encoded non-ASCII characters, - # so need some special handling. - unpackPhase = '' - runHook preUnpack - - tar -xf $src --strip-components=1 || true - - runHook postUnpack - ''; - - postPatch = lib.getAttr language { - is = '' - cp icelandic.alias íslenska.alias - sed -i 's/ .slenska\.alias/ íslenska.alias/g' Makefile.pre - ''; - nb = '' - cp bokmal.alias bokmål.alias - sed -i 's/ bokm.l\.alias/ bokmål.alias/g' Makefile.pre - ''; - }; - } // removeAttrs args [ "language" "filename" "sha256" "meta" ]; - in buildDict buildArgs; + { + language, + version, + filename, + fullName, + sha256, + ... + }@args: + let + buildArgs = + { + shortName = "${language}"; + + src = fetchurl { + url = "mirror://gnu/aspell/dict/${language}/${filename}-${language}-${version}.tar.bz2"; + inherit sha256; + }; + + /* + Remove any instances of u-deva.cmap and u-deva.cset since + they are included in the main aspell package and can + cause conflicts otherwise. + */ + postInstall = '' + rm -f $out/lib/aspell/u-deva.{cmap,cset} + ''; + + passthru.updateScript = writeScript "update-aspellDict-${language}" '' + #!/usr/bin/env nix-shell + #!nix-shell -i bash -p nix curl gnused common-updater-scripts + set -eu -o pipefail + + # List tarballs in the dictionary's subdirectory via HTTPS and + # the simple list method of Apache's mod_autoindex. + # + # Catalan dictionary has an exception where an earlier version + # compares as newer because the versioning scheme has changed. + versions=$( + echo '['; + curl -s 'https://ftp.gnu.org/gnu/aspell/dict/${language}/?F=0' | \ + sed -r 's/.* href="${filename}-${language}-([A-Za-z0-9_+.-]+)\.tar\.bz2".*/"\1"/;t;d' | \ + if [ '${language}' = "ca" ]; then grep -v 20040130-1; else cat; fi; \ + echo ']') + + # Sort versions in descending order using Nix's and take the first as the latest. + sortVersions="(with builtins; head (sort (a: b: compareVersions a b > 0) $versions))" + # nix-instantiate outputs Nix strings (with quotes), so remove them to get + # a result similar to `nix eval --raw`. + latestVersion=$(nix-instantiate --eval --expr "$sortVersions" | tr -d '"') + + update-source-version aspellDicts.${language} "$latestVersion" + ''; + + meta = { + homepage = "http://ftp.gnu.org/gnu/aspell/dict/0index.html"; + } // (args.meta or { }); - /* Function to compile txt dict files into Aspell dictionaries. */ - buildTxtDict = - {langInputs ? [], ...}@args: - buildDict ({ - propagatedUserEnvPackages = langInputs; - - preBuild = '' - # Aspell can't handle multiple data-dirs - # Copy everything we might possibly need - ${lib.concatMapStringsSep "\n" (p: '' - cp -a ${p}/lib/aspell/* . - '') ([ aspell ] ++ langInputs)} - export ASPELL_CONF="data-dir $(pwd)" - - aspell-create() { - target=$1 - shift - echo building $target - aspell create "$@" master ./$target.rws } + // + lib.optionalAttrs + (lib.elem language [ + "is" + "nb" + ]) + { + # These have Windows-1251 encoded non-ASCII characters, + # so need some special handling. + unpackPhase = '' + runHook preUnpack + + tar -xf $src --strip-components=1 || true + + runHook postUnpack + ''; + + postPatch = lib.getAttr language { + is = '' + cp icelandic.alias íslenska.alias + sed -i 's/ .slenska\.alias/ íslenska.alias/g' Makefile.pre + ''; + nb = '' + cp bokmal.alias bokmål.alias + sed -i 's/ bokm.l\.alias/ bokmål.alias/g' Makefile.pre + ''; + }; + } + // removeAttrs args [ + "language" + "filename" + "sha256" + "meta" + ]; + in + buildDict buildArgs; + + # Function to compile txt dict files into Aspell dictionaries. + buildTxtDict = + { + langInputs ? [ ], + ... + }@args: + buildDict ( + { + propagatedUserEnvPackages = langInputs; + + preBuild = '' + # Aspell can't handle multiple data-dirs + # Copy everything we might possibly need + ${lib.concatMapStringsSep "\n" (p: '' + cp -a ${p}/lib/aspell/* . + '') ([ aspell ] ++ langInputs)} + export ASPELL_CONF="data-dir $(pwd)" + + aspell-create() { + target=$1 + shift + echo building $target + aspell create "$@" master ./$target.rws + } + + words-only() { + awk -F'\t' '{print $1}' | sort | uniq + } + + # drop comments + aspell-affix() { + words-only \ + | grep -a -v '#' \ + | aspell-create "$@" + } + + # Hack: drop comments and words with affixes + aspell-plain() { + words-only \ + | grep -a -v '#' \ + | grep -a -v '/' \ + | aspell-create "$@" + } + + aspell-install() { + install -d $out/lib/aspell + for a in "$@"; do + echo installing $a + install -t $out/lib/aspell $a.rws + done + } + ''; - words-only() { - awk -F'\t' '{print $1}' | sort | uniq - } - - # drop comments - aspell-affix() { - words-only \ - | grep -a -v '#' \ - | aspell-create "$@" - } - - # Hack: drop comments and words with affixes - aspell-plain() { - words-only \ - | grep -a -v '#' \ - | grep -a -v '/' \ - | aspell-create "$@" - } - - aspell-install() { - install -d $out/lib/aspell - for a in "$@"; do - echo installing $a - install -t $out/lib/aspell $a.rws - done - } - ''; - - dontUnpack = true; - } // args); + dontUnpack = true; + } + // args + ); -in rec { +in +rec { ### Languages diff --git a/pkgs/development/libraries/atkmm/2.36.nix b/pkgs/development/libraries/atkmm/2.36.nix index 600ae449fd3299..609c56331b0472 100644 --- a/pkgs/development/libraries/atkmm/2.36.nix +++ b/pkgs/development/libraries/atkmm/2.36.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, atk, glibmm_2_68, pkg-config, gnome, meson, ninja, python3 }: +{ + lib, + stdenv, + fetchurl, + atk, + glibmm_2_68, + pkg-config, + gnome, + meson, + ninja, + python3, +}: stdenv.mkDerivation rec { pname = "atkmm"; @@ -9,11 +20,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-bsJk6qDE3grbcgLGABcL3pp/vk1Ga/vpQOr3+qpsWXQ="; }; - outputs = [ "out" "dev" ]; - - propagatedBuildInputs = [ atk glibmm_2_68 ]; - - nativeBuildInputs = [ pkg-config meson ninja python3 ]; + outputs = [ + "out" + "dev" + ]; + + propagatedBuildInputs = [ + atk + glibmm_2_68 + ]; + + nativeBuildInputs = [ + pkg-config + meson + ninja + python3 + ]; doCheck = true; diff --git a/pkgs/development/libraries/atkmm/default.nix b/pkgs/development/libraries/atkmm/default.nix index a22e3fec16a678..3858fd287adf0a 100644 --- a/pkgs/development/libraries/atkmm/default.nix +++ b/pkgs/development/libraries/atkmm/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, atk, glibmm, pkg-config, gnome, meson, ninja, python3 }: +{ + lib, + stdenv, + fetchurl, + atk, + glibmm, + pkg-config, + gnome, + meson, + ninja, + python3, +}: stdenv.mkDerivation rec { pname = "atkmm"; @@ -9,11 +20,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-ChQqgSj4PAAe+4AU7kY+mnZgVO+EaGr5UxNeBNKP2rM="; }; - outputs = [ "out" "dev" ]; - - propagatedBuildInputs = [ atk glibmm ]; - - nativeBuildInputs = [ pkg-config meson python3 ninja ]; + outputs = [ + "out" + "dev" + ]; + + propagatedBuildInputs = [ + atk + glibmm + ]; + + nativeBuildInputs = [ + pkg-config + meson + python3 + ninja + ]; doCheck = true; diff --git a/pkgs/development/libraries/attr/default.nix b/pkgs/development/libraries/attr/default.nix index dfc8a5cdb82b3c..0b82272007c2f2 100644 --- a/pkgs/development/libraries/attr/default.nix +++ b/pkgs/development/libraries/attr/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, gettext }: +{ + lib, + stdenv, + fetchurl, + gettext, +}: # Note: this package is used for bootstrapping fetchurl, and thus # cannot use fetchpatch! All mutable patches (generated by GitHub or @@ -14,7 +19,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-Ob9nRS+kHQlIwhl2AQU/SLPXigKTiXNDMqYwmmgMbIc="; }; - outputs = [ "bin" "dev" "out" "man" "doc" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + "doc" + ]; nativeBuildInputs = [ gettext ]; diff --git a/pkgs/development/libraries/audio/cubeb/default.nix b/pkgs/development/libraries/audio/cubeb/default.nix index 478e8478382a1a..9c7e3a5c79b686 100644 --- a/pkgs/development/libraries/audio/cubeb/default.nix +++ b/pkgs/development/libraries/audio/cubeb/default.nix @@ -1,18 +1,23 @@ -{ lib, stdenv, fetchFromGitHub -, cmake -, pkg-config -, alsa-lib -, jack2 -, libpulseaudio -, sndio -, speexdsp -, AudioUnit -, CoreAudio -, CoreServices -, lazyLoad ? !stdenv.hostPlatform.isDarwin +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + alsa-lib, + jack2, + libpulseaudio, + sndio, + speexdsp, + AudioUnit, + CoreAudio, + CoreServices, + lazyLoad ? !stdenv.hostPlatform.isDarwin, }: -assert lib.assertMsg (stdenv.hostPlatform.isDarwin -> !lazyLoad) "cubeb: lazyLoad is inert on Darwin"; +assert lib.assertMsg ( + stdenv.hostPlatform.isDarwin -> !lazyLoad +) "cubeb: lazyLoad is inert on Darwin"; let backendLibs = [ @@ -22,7 +27,8 @@ let sndio ]; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "cubeb"; version = "unstable-2022-10-18"; @@ -38,10 +44,18 @@ in stdenv.mkDerivation { pkg-config ]; - buildInputs = [ speexdsp ] ++ ( - if stdenv.hostPlatform.isDarwin then [ AudioUnit CoreAudio CoreServices ] - else backendLibs - ); + buildInputs = + [ speexdsp ] + ++ ( + if stdenv.hostPlatform.isDarwin then + [ + AudioUnit + CoreAudio + CoreServices + ] + else + backendLibs + ); cmakeFlags = [ "-DBUILD_SHARED_LIBS=ON" diff --git a/pkgs/development/libraries/audio/libbass/default.nix b/pkgs/development/libraries/audio/libbass/default.nix index 364ba305d5c1fa..e3774f939de17e 100644 --- a/pkgs/development/libraries/audio/libbass/default.nix +++ b/pkgs/development/libraries/audio/libbass/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, unzip, fetchurl }: +{ + lib, + stdenv, + unzip, + fetchurl, +}: # Upstream changes files in-place, to update: # 1. Check latest version at http://www.un4seen.com/ @@ -62,38 +67,45 @@ let }; }; - dropBass = name: bass: stdenv.mkDerivation { - pname = "lib${name}"; - inherit (bass) version; + dropBass = + name: bass: + stdenv.mkDerivation { + pname = "lib${name}"; + inherit (bass) version; - src = fetchurl { - inherit (bass) hash url; - }; - - unpackCmd = '' - mkdir out - ${unzip}/bin/unzip $curSrc -d out - ''; + src = fetchurl { + inherit (bass) hash url; + }; - lpropagatedBuildInputs = [ unzip ]; - dontBuild = true; - installPhase = - let so = - if bass.so ? ${stdenv.hostPlatform.system} then bass.so.${stdenv.hostPlatform.system} - else throw "${name} not packaged for ${stdenv.hostPlatform.system} (yet)."; - in '' - mkdir -p $out/{lib,include} - install -m644 -t $out/lib/ ${so} - install -m644 -t $out/include/ ${bass.h} + unpackCmd = '' + mkdir out + ${unzip}/bin/unzip $curSrc -d out ''; - meta = with lib; { - description = "Shareware audio library"; - homepage = "https://www.un4seen.com/"; - license = licenses.unfreeRedistributable; - platforms = builtins.attrNames bass.so; - maintainers = with maintainers; [ jacekpoz ]; + lpropagatedBuildInputs = [ unzip ]; + dontBuild = true; + installPhase = + let + so = + if bass.so ? ${stdenv.hostPlatform.system} then + bass.so.${stdenv.hostPlatform.system} + else + throw "${name} not packaged for ${stdenv.hostPlatform.system} (yet)."; + in + '' + mkdir -p $out/{lib,include} + install -m644 -t $out/lib/ ${so} + install -m644 -t $out/include/ ${bass.h} + ''; + + meta = with lib; { + description = "Shareware audio library"; + homepage = "https://www.un4seen.com/"; + license = licenses.unfreeRedistributable; + platforms = builtins.attrNames bass.so; + maintainers = with maintainers; [ jacekpoz ]; + }; }; - }; -in lib.mapAttrs dropBass allBass +in +lib.mapAttrs dropBass allBass diff --git a/pkgs/development/libraries/audio/rtaudio/default.nix b/pkgs/development/libraries/audio/rtaudio/default.nix index 8c1bc7356db13e..e289cc2c3f9f31 100644 --- a/pkgs/development/libraries/audio/rtaudio/default.nix +++ b/pkgs/development/libraries/audio/rtaudio/default.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, config -, fetchFromGitHub -, cmake -, pkg-config -, alsaSupport ? stdenv.hostPlatform.isLinux -, alsa-lib -, pulseaudioSupport ? config.pulseaudio or stdenv.hostPlatform.isLinux -, libpulseaudio -, jackSupport ? true -, jack -, coreaudioSupport ? stdenv.hostPlatform.isDarwin -, CoreAudio +{ + stdenv, + lib, + config, + fetchFromGitHub, + cmake, + pkg-config, + alsaSupport ? stdenv.hostPlatform.isLinux, + alsa-lib, + pulseaudioSupport ? config.pulseaudio or stdenv.hostPlatform.isLinux, + libpulseaudio, + jackSupport ? true, + jack, + coreaudioSupport ? stdenv.hostPlatform.isDarwin, + CoreAudio, }: stdenv.mkDerivation rec { @@ -26,9 +27,13 @@ stdenv.mkDerivation rec { sha256 = "0xvahlfj3ysgsjsp53q81hayzw7f99n1g214gh7dwdr52kv2l987"; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = lib.optional alsaSupport alsa-lib + buildInputs = + lib.optional alsaSupport alsa-lib ++ lib.optional pulseaudioSupport libpulseaudio ++ lib.optional jackSupport jack ++ lib.optional coreaudioSupport CoreAudio; diff --git a/pkgs/development/libraries/audio/rtmidi/default.nix b/pkgs/development/libraries/audio/rtmidi/default.nix index c881e45ae559e8..79bf235d6833b2 100644 --- a/pkgs/development/libraries/audio/rtmidi/default.nix +++ b/pkgs/development/libraries/audio/rtmidi/default.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, alsaSupport ? stdenv.hostPlatform.isLinux -, alsa-lib -, jackSupport ? true -, jack -, coremidiSupport ? stdenv.hostPlatform.isDarwin -, CoreMIDI -, CoreAudio -, CoreServices +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + alsaSupport ? stdenv.hostPlatform.isLinux, + alsa-lib, + jackSupport ? true, + jack, + coremidiSupport ? stdenv.hostPlatform.isDarwin, + CoreMIDI, + CoreAudio, + CoreServices, }: stdenv.mkDerivation rec { @@ -40,11 +41,19 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = lib.optional alsaSupport alsa-lib + buildInputs = + lib.optional alsaSupport alsa-lib ++ lib.optional jackSupport jack - ++ lib.optionals coremidiSupport [ CoreMIDI CoreAudio CoreServices ]; + ++ lib.optionals coremidiSupport [ + CoreMIDI + CoreAudio + CoreServices + ]; cmakeFlags = [ "-DRTMIDI_API_ALSA=${if alsaSupport then "ON" else "OFF"}" diff --git a/pkgs/development/libraries/audiofile/default.nix b/pkgs/development/libraries/audiofile/default.nix index 3a65f2535b7c52..6fc2379753329e 100644 --- a/pkgs/development/libraries/audiofile/default.nix +++ b/pkgs/development/libraries/audiofile/default.nix @@ -1,8 +1,21 @@ -{ stdenv, lib, fetchurl, fetchpatch, alsa-lib, AudioUnit, CoreServices }: +{ + stdenv, + lib, + fetchurl, + fetchpatch, + alsa-lib, + AudioUnit, + CoreServices, +}: let - fetchDebianPatch = { name, debname, sha256 }: + fetchDebianPatch = + { + name, + debname, + sha256, + }: fetchpatch { inherit sha256 name; url = "https://salsa.debian.org/multimedia-team/audiofile/raw/debian/0.3.6-4/debian/patches/${debname}"; @@ -17,8 +30,10 @@ stdenv.mkDerivation rec { buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ alsa-lib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreServices AudioUnit + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + AudioUnit ]; src = fetchurl { @@ -26,7 +41,11 @@ stdenv.mkDerivation rec { sha256 = "0rb927zknk9kmhprd8rdr4azql4gn2dp75a36iazx2xhkbqhvind"; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; # std::unary_function has been removed in c++17 makeFlags = [ "CXXFLAGS=-std=c++11" ]; @@ -89,9 +108,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Library for reading and writing audio files in various formats"; - homepage = "http://www.68k.org/~michael/audiofile/"; - license = licenses.lgpl21Plus; + homepage = "http://www.68k.org/~michael/audiofile/"; + license = licenses.lgpl21Plus; maintainers = with maintainers; [ lovek323 ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/avahi/default.nix b/pkgs/development/libraries/avahi/default.nix index 366f5f290abf66..8416743b732ed8 100644 --- a/pkgs/development/libraries/avahi/default.nix +++ b/pkgs/development/libraries/avahi/default.nix @@ -1,25 +1,26 @@ -{ fetchurl -, fetchpatch -, lib -, config -, stdenv -, pkg-config -, libdaemon -, dbus -, libpcap -, expat -, gettext -, glib -, libiconv -, libevent -, nixosTests -, gtk3Support ? false -, gtk3 -, qt5 -, qt5Support ? false -, withLibdnssdCompat ? false -, python ? null -, withPython ? false +{ + fetchurl, + fetchpatch, + lib, + config, + stdenv, + pkg-config, + libdaemon, + dbus, + libpcap, + expat, + gettext, + glib, + libiconv, + libevent, + nixosTests, + gtk3Support ? false, + gtk3, + qt5, + qt5Support ? false, + withLibdnssdCompat ? false, + python ? null, + withPython ? false, }: stdenv.mkDerivation rec { @@ -31,7 +32,11 @@ stdenv.mkDerivation rec { sha256 = "1npdixwxxn3s9q1f365x9n9rc5xgfz39hxf23faqvlrklgbhj0q6"; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; patches = [ # CVE-2021-36217 / CVE-2021-3502 @@ -117,7 +122,10 @@ stdenv.mkDerivation rec { name = "core-no-longer-supply-bogus-services-to-callbacks.patch"; url = "https://github.com/avahi/avahi/commit/93b14365c1c1e04efd1a890e8caa01a2a514bfd8.patch"; sha256 = "sha256-VBm8vsBZkTbbWAK8FI71SL89lZuYd1yFNoB5o+FvlEU="; - excludes = [ ".github/workflows/smoke-tests.sh" "fuzz/fuzz-packet.c" ]; + excludes = [ + ".github/workflows/smoke-tests.sh" + "fuzz/fuzz-packet.c" + ]; }) ]; @@ -131,47 +139,57 @@ stdenv.mkDerivation rec { glib ]; - buildInputs = [ - libdaemon - dbus - glib - expat - libiconv - libevent - ] ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ - libpcap - ] ++ lib.optionals gtk3Support [ - gtk3 - ] ++ lib.optionals qt5Support [ - qt5 - ]; + buildInputs = + [ + libdaemon + dbus + glib + expat + libiconv + libevent + ] + ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ + libpcap + ] + ++ lib.optionals gtk3Support [ + gtk3 + ] + ++ lib.optionals qt5Support [ + qt5 + ]; - propagatedBuildInputs = lib.optionals withPython (with python.pkgs; [ - python - pygobject3 - dbus-python - ]); + propagatedBuildInputs = lib.optionals withPython ( + with python.pkgs; + [ + python + pygobject3 + dbus-python + ] + ); - configureFlags = [ - "--disable-gdbm" - "--disable-mono" - # Use non-deprecated path https://github.com/lathiat/avahi/pull/376 - "--with-dbus-sys=${placeholder "out"}/share/dbus-1/system.d" - (lib.enableFeature gtk3Support "gtk3") - (lib.enableFeature qt5Support "qt5") - (lib.enableFeature withPython "python") - "--localstatedir=/var" - "--runstatedir=/run" - "--sysconfdir=/etc" - "--with-distro=${with stdenv.hostPlatform; if isBSD then parsed.kernel.name else "none"}" - # A systemd unit is provided by the avahi-daemon NixOS module - "--with-systemdsystemunitdir=no" - ] ++ lib.optionals withLibdnssdCompat [ - "--enable-compat-libdns_sd" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # autoipd won't build on darwin - "--disable-autoipd" - ]; + configureFlags = + [ + "--disable-gdbm" + "--disable-mono" + # Use non-deprecated path https://github.com/lathiat/avahi/pull/376 + "--with-dbus-sys=${placeholder "out"}/share/dbus-1/system.d" + (lib.enableFeature gtk3Support "gtk3") + (lib.enableFeature qt5Support "qt5") + (lib.enableFeature withPython "python") + "--localstatedir=/var" + "--runstatedir=/run" + "--sysconfdir=/etc" + "--with-distro=${with stdenv.hostPlatform; if isBSD then parsed.kernel.name else "none"}" + # A systemd unit is provided by the avahi-daemon NixOS module + "--with-systemdsystemunitdir=no" + ] + ++ lib.optionals withLibdnssdCompat [ + "--enable-compat-libdns_sd" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # autoipd won't build on darwin + "--disable-autoipd" + ]; installFlags = [ # Override directories to install into the package. @@ -202,7 +220,10 @@ stdenv.mkDerivation rec { homepage = "http://avahi.org"; license = licenses.lgpl2Plus; platforms = platforms.unix; - maintainers = with maintainers; [ lovek323 globin ]; + maintainers = with maintainers; [ + lovek323 + globin + ]; longDescription = '' Avahi is a system which facilitates service discovery on a local diff --git a/pkgs/development/libraries/aws-c-cal/default.nix b/pkgs/development/libraries/aws-c-cal/default.nix index caf0ce60cdb2db..a407faec05efe6 100644 --- a/pkgs/development/libraries/aws-c-cal/default.nix +++ b/pkgs/development/libraries/aws-c-cal/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, aws-c-common, nix, openssl, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + aws-c-common, + nix, + openssl, + Security, +}: stdenv.mkDerivation (finalAttrs: { pname = "aws-c-cal"; @@ -18,7 +27,10 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ cmake ]; - buildInputs = [ aws-c-common openssl ]; + buildInputs = [ + aws-c-common + openssl + ]; propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; diff --git a/pkgs/development/libraries/aws-c-io/default.nix b/pkgs/development/libraries/aws-c-io/default.nix index 2b3019d48cfa73..f97c2def0aabfa 100644 --- a/pkgs/development/libraries/aws-c-io/default.nix +++ b/pkgs/development/libraries/aws-c-io/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, aws-c-cal, aws-c-common, nix, s2n-tls, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + aws-c-cal, + aws-c-common, + nix, + s2n-tls, + Security, +}: stdenv.mkDerivation rec { pname = "aws-c-io"; @@ -13,7 +23,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ aws-c-cal aws-c-common s2n-tls ]; + buildInputs = [ + aws-c-cal + aws-c-common + s2n-tls + ]; propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; cmakeFlags = [ diff --git a/pkgs/development/libraries/bashup-events/3.2.nix b/pkgs/development/libraries/bashup-events/3.2.nix index f7e88c3825110c..bc60859adef99b 100644 --- a/pkgs/development/libraries/bashup-events/3.2.nix +++ b/pkgs/development/libraries/bashup-events/3.2.nix @@ -18,7 +18,12 @@ callPackage ./generic.nix { }; keep = { # allow vars in eval - eval = [ "e" "f" "q" "r" ]; + eval = [ + "e" + "f" + "q" + "r" + ]; # allow vars executed as commands "$f" = true; "$n" = true; diff --git a/pkgs/development/libraries/bashup-events/4.4.nix b/pkgs/development/libraries/bashup-events/4.4.nix index f880009ea71ad7..063108f32e33d6 100644 --- a/pkgs/development/libraries/bashup-events/4.4.nix +++ b/pkgs/development/libraries/bashup-events/4.4.nix @@ -12,7 +12,11 @@ callPackage ./generic.nix { }; keep = { # allow vars in eval - eval = [ "e" "bashup_ev" "n" ]; + eval = [ + "e" + "bashup_ev" + "n" + ]; # allow vars executed as commands "$f" = true; "$n" = true; diff --git a/pkgs/development/libraries/bashup-events/generic.nix b/pkgs/development/libraries/bashup-events/generic.nix index eb54d79e6fadfa..f91179ff5a23eb 100644 --- a/pkgs/development/libraries/bashup-events/generic.nix +++ b/pkgs/development/libraries/bashup-events/generic.nix @@ -1,35 +1,34 @@ { # general - lib -, resholve -, bash -, doCheck ? true -, doInstallCheck ? true + lib, + resholve, + bash, + doCheck ? true, + doInstallCheck ? true, # variant-specific -, variant -, version -, branch -, src -, fake ? false -, keep + variant, + version, + branch, + src, + fake ? false, + keep, }: let # extracting this so that it's trivial to test in other shells - installCheck = shell: - '' - echo "testing bashup.events in ${shell}" - ${shell} <<'EOF' - source $out/bin/bashup.events - neat(){ - echo $0: Hi from event \'test event\'. I can have both $1 and $2 arguments. - exit 0 - } - event on "test event" @2 neat curried - echo event registered - event emit "test event" runtime - exit 1 # fail if emitting event didn't exit clean - EOF - ''; + installCheck = shell: '' + echo "testing bashup.events in ${shell}" + ${shell} <<'EOF' + source $out/bin/bashup.events + neat(){ + echo $0: Hi from event \'test event\'. I can have both $1 and $2 arguments. + exit 0 + } + event on "test event" @2 neat curried + echo event registered + event emit "test event" runtime + exit 1 # fail if emitting event didn't exit clean + EOF + ''; in resholve.mkDerivation rec { diff --git a/pkgs/development/libraries/boost/1.77.nix b/pkgs/development/libraries/boost/1.77.nix index 72663044d9c938..998107521e2233 100644 --- a/pkgs/development/libraries/boost/1.77.nix +++ b/pkgs/development/libraries/boost/1.77.nix @@ -1,15 +1,19 @@ -{ callPackage, fetchurl, ... } @ args: +{ callPackage, fetchurl, ... }@args: -callPackage ./generic.nix (args // rec { - version = "1.77.0"; - - src = fetchurl { - urls = [ - "mirror://sourceforge/boost/boost_${builtins.replaceStrings ["."] ["_"] version}.tar.bz2" - "https://boostorg.jfrog.io/artifactory/main/release/${version}/source/boost_${builtins.replaceStrings ["."] ["_"] version}.tar.bz2" - ]; - # SHA256 from http://www.boost.org/users/history/version_1_77_0.html - sha256 = "sha256-/J+F/AMOIzFCkIJBr3qEbmBjCqc4jeml+vsfOiaECFQ="; - }; -}) +callPackage ./generic.nix ( + args + // rec { + version = "1.77.0"; + src = fetchurl { + urls = [ + "mirror://sourceforge/boost/boost_${builtins.replaceStrings [ "." ] [ "_" ] version}.tar.bz2" + "https://boostorg.jfrog.io/artifactory/main/release/${version}/source/boost_${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.tar.bz2" + ]; + # SHA256 from http://www.boost.org/users/history/version_1_77_0.html + sha256 = "sha256-/J+F/AMOIzFCkIJBr3qEbmBjCqc4jeml+vsfOiaECFQ="; + }; + } +) diff --git a/pkgs/development/libraries/boost/1.78.nix b/pkgs/development/libraries/boost/1.78.nix index 53a3f300a792b0..3e95cf95a5ea65 100644 --- a/pkgs/development/libraries/boost/1.78.nix +++ b/pkgs/development/libraries/boost/1.78.nix @@ -1,15 +1,19 @@ -{ callPackage, fetchurl, ... } @ args: +{ callPackage, fetchurl, ... }@args: -callPackage ./generic.nix (args // rec { - version = "1.78.0"; - - src = fetchurl { - urls = [ - "mirror://sourceforge/boost/boost_${builtins.replaceStrings ["."] ["_"] version}.tar.bz2" - "https://boostorg.jfrog.io/artifactory/main/release/${version}/source/boost_${builtins.replaceStrings ["."] ["_"] version}.tar.bz2" - ]; - # SHA256 from http://www.boost.org/users/history/version_1_78_0.html - sha256 = "8681f175d4bdb26c52222665793eef08490d7758529330f98d3b29dd0735bccc"; - }; -}) +callPackage ./generic.nix ( + args + // rec { + version = "1.78.0"; + src = fetchurl { + urls = [ + "mirror://sourceforge/boost/boost_${builtins.replaceStrings [ "." ] [ "_" ] version}.tar.bz2" + "https://boostorg.jfrog.io/artifactory/main/release/${version}/source/boost_${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.tar.bz2" + ]; + # SHA256 from http://www.boost.org/users/history/version_1_78_0.html + sha256 = "8681f175d4bdb26c52222665793eef08490d7758529330f98d3b29dd0735bccc"; + }; + } +) diff --git a/pkgs/development/libraries/boost/1.79.nix b/pkgs/development/libraries/boost/1.79.nix index 91e13edf2265ad..c9bbce8f40b78f 100644 --- a/pkgs/development/libraries/boost/1.79.nix +++ b/pkgs/development/libraries/boost/1.79.nix @@ -1,14 +1,19 @@ -{ callPackage, fetchurl, ... } @ args: +{ callPackage, fetchurl, ... }@args: -callPackage ./generic.nix (args // rec { - version = "1.79.0"; +callPackage ./generic.nix ( + args + // rec { + version = "1.79.0"; - src = fetchurl { - urls = [ - "mirror://sourceforge/boost/boost_${builtins.replaceStrings ["."] ["_"] version}.tar.bz2" - "https://boostorg.jfrog.io/artifactory/main/release/${version}/source/boost_${builtins.replaceStrings ["."] ["_"] version}.tar.bz2" - ]; - # SHA256 from http://www.boost.org/users/history/version_1_79_0.html - sha256 = "475d589d51a7f8b3ba2ba4eda022b170e562ca3b760ee922c146b6c65856ef39"; - }; -}) + src = fetchurl { + urls = [ + "mirror://sourceforge/boost/boost_${builtins.replaceStrings [ "." ] [ "_" ] version}.tar.bz2" + "https://boostorg.jfrog.io/artifactory/main/release/${version}/source/boost_${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.tar.bz2" + ]; + # SHA256 from http://www.boost.org/users/history/version_1_79_0.html + sha256 = "475d589d51a7f8b3ba2ba4eda022b170e562ca3b760ee922c146b6c65856ef39"; + }; + } +) diff --git a/pkgs/development/libraries/boost/1.80.nix b/pkgs/development/libraries/boost/1.80.nix index 79281cd1c70a02..46376b14d57265 100644 --- a/pkgs/development/libraries/boost/1.80.nix +++ b/pkgs/development/libraries/boost/1.80.nix @@ -1,14 +1,19 @@ -{ callPackage, fetchurl, ... } @ args: +{ callPackage, fetchurl, ... }@args: -callPackage ./generic.nix (args // rec { - version = "1.80.0"; +callPackage ./generic.nix ( + args + // rec { + version = "1.80.0"; - src = fetchurl { - urls = [ - "mirror://sourceforge/boost/boost_${builtins.replaceStrings ["."] ["_"] version}.tar.bz2" - "https://boostorg.jfrog.io/artifactory/main/release/${version}/source/boost_${builtins.replaceStrings ["."] ["_"] version}.tar.bz2" - ]; - # SHA256 from http://www.boost.org/users/history/version_1_80_0.html - sha256 = "1e19565d82e43bc59209a168f5ac899d3ba471d55c7610c677d4ccf2c9c500c0"; - }; -}) + src = fetchurl { + urls = [ + "mirror://sourceforge/boost/boost_${builtins.replaceStrings [ "." ] [ "_" ] version}.tar.bz2" + "https://boostorg.jfrog.io/artifactory/main/release/${version}/source/boost_${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.tar.bz2" + ]; + # SHA256 from http://www.boost.org/users/history/version_1_80_0.html + sha256 = "1e19565d82e43bc59209a168f5ac899d3ba471d55c7610c677d4ccf2c9c500c0"; + }; + } +) diff --git a/pkgs/development/libraries/boost/1.84.nix b/pkgs/development/libraries/boost/1.84.nix index bfcfdfbfd7cfd7..79cf7fa099f1cc 100644 --- a/pkgs/development/libraries/boost/1.84.nix +++ b/pkgs/development/libraries/boost/1.84.nix @@ -1,14 +1,19 @@ -{ callPackage, fetchurl, ... } @ args: +{ callPackage, fetchurl, ... }@args: -callPackage ./generic.nix (args // rec { - version = "1.84.0"; +callPackage ./generic.nix ( + args + // rec { + version = "1.84.0"; - src = fetchurl { - urls = [ - "mirror://sourceforge/boost/boost_${builtins.replaceStrings ["."] ["_"] version}.tar.bz2" - "https://boostorg.jfrog.io/artifactory/main/release/${version}/source/boost_${builtins.replaceStrings ["."] ["_"] version}.tar.bz2" - ]; - # SHA256 from http://www.boost.org/users/history/version_1_84_0.html - sha256 = "cc4b893acf645c9d4b698e9a0f08ca8846aa5d6c68275c14c3e7949c24109454"; - }; -}) + src = fetchurl { + urls = [ + "mirror://sourceforge/boost/boost_${builtins.replaceStrings [ "." ] [ "_" ] version}.tar.bz2" + "https://boostorg.jfrog.io/artifactory/main/release/${version}/source/boost_${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.tar.bz2" + ]; + # SHA256 from http://www.boost.org/users/history/version_1_84_0.html + sha256 = "cc4b893acf645c9d4b698e9a0f08ca8846aa5d6c68275c14c3e7949c24109454"; + }; + } +) diff --git a/pkgs/development/libraries/boost/1.85.nix b/pkgs/development/libraries/boost/1.85.nix index a95789800e1bd7..45eefa25413c7d 100644 --- a/pkgs/development/libraries/boost/1.85.nix +++ b/pkgs/development/libraries/boost/1.85.nix @@ -1,14 +1,19 @@ -{ callPackage, fetchurl, ... } @ args: +{ callPackage, fetchurl, ... }@args: -callPackage ./generic.nix (args // rec { - version = "1.85.0"; +callPackage ./generic.nix ( + args + // rec { + version = "1.85.0"; - src = fetchurl { - urls = [ - "mirror://sourceforge/boost/boost_${builtins.replaceStrings ["."] ["_"] version}.tar.bz2" - "https://boostorg.jfrog.io/artifactory/main/release/${version}/source/boost_${builtins.replaceStrings ["."] ["_"] version}.tar.bz2" - ]; - # SHA256 from http://www.boost.org/users/history/version_1_85_0.html - sha256 = "7009fe1faa1697476bdc7027703a2badb84e849b7b0baad5086b087b971f8617"; - }; -}) + src = fetchurl { + urls = [ + "mirror://sourceforge/boost/boost_${builtins.replaceStrings [ "." ] [ "_" ] version}.tar.bz2" + "https://boostorg.jfrog.io/artifactory/main/release/${version}/source/boost_${ + builtins.replaceStrings [ "." ] [ "_" ] version + }.tar.bz2" + ]; + # SHA256 from http://www.boost.org/users/history/version_1_85_0.html + sha256 = "7009fe1faa1697476bdc7027703a2badb84e849b7b0baad5086b087b971f8617"; + }; + } +) diff --git a/pkgs/development/libraries/boost/default.nix b/pkgs/development/libraries/boost/default.nix index 8e1b3593162d89..59123eb779c4ca 100644 --- a/pkgs/development/libraries/boost/default.nix +++ b/pkgs/development/libraries/boost/default.nix @@ -1,12 +1,15 @@ -{ lib -, callPackage -, boost-build -, fetchurl +{ + lib, + callPackage, + boost-build, + fetchurl, }: let - makeBoost = file: - lib.fix (self: + makeBoost = + file: + lib.fix ( + self: callPackage file { boost-build = boost-build.override { # useBoost allows us passing in src and version from @@ -15,7 +18,8 @@ let }; } ); -in { +in +{ boost177 = makeBoost ./1.77.nix; boost178 = makeBoost ./1.78.nix; boost179 = makeBoost ./1.79.nix; diff --git a/pkgs/development/libraries/boost/generic.nix b/pkgs/development/libraries/boost/generic.nix index 94ee8c236423fc..d7182414f7338a 100644 --- a/pkgs/development/libraries/boost/generic.nix +++ b/pkgs/development/libraries/boost/generic.nix @@ -1,31 +1,52 @@ -{ lib, stdenv, icu, expat, zlib, bzip2, zstd, xz, python ? null, fixDarwinDylibNames, libiconv, libxcrypt -, makePkgconfigItem -, copyPkgconfigItems -, boost-build -, fetchpatch -, which -, toolset ? /**/ if stdenv.cc.isClang then "clang" - else if stdenv.cc.isGNU then "gcc" - else null -, enableRelease ? true -, enableDebug ? false -, enableSingleThreaded ? false -, enableMultiThreaded ? true -, enableShared ? !(with stdenv.hostPlatform; isStatic || isMinGW) # problems for now -, enableStatic ? !enableShared -, enablePython ? false -, enableNumpy ? false -, enableIcu ? stdenv.hostPlatform == stdenv.buildPlatform -, taggedLayout ? ((enableRelease && enableDebug) || (enableSingleThreaded && enableMultiThreaded) || (enableShared && enableStatic)) -, patches ? [] -, boostBuildPatches ? [] -, useMpi ? false -, mpi -, extraB2Args ? [] - -# Attributes inherit from specific versions -, version, src -, ... +{ + lib, + stdenv, + icu, + expat, + zlib, + bzip2, + zstd, + xz, + python ? null, + fixDarwinDylibNames, + libiconv, + libxcrypt, + makePkgconfigItem, + copyPkgconfigItems, + boost-build, + fetchpatch, + which, + toolset ? + if stdenv.cc.isClang then + "clang" + else if stdenv.cc.isGNU then + "gcc" + else + null, + enableRelease ? true, + enableDebug ? false, + enableSingleThreaded ? false, + enableMultiThreaded ? true, + enableShared ? !(with stdenv.hostPlatform; isStatic || isMinGW), # problems for now + enableStatic ? !enableShared, + enablePython ? false, + enableNumpy ? false, + enableIcu ? stdenv.hostPlatform == stdenv.buildPlatform, + taggedLayout ? ( + (enableRelease && enableDebug) + || (enableSingleThreaded && enableMultiThreaded) + || (enableShared && enableStatic) + ), + patches ? [ ], + boostBuildPatches ? [ ], + useMpi ? false, + mpi, + extraB2Args ? [ ], + + # Attributes inherit from specific versions + version, + src, + ... }: # We must build at least one type of libraries @@ -35,66 +56,94 @@ assert enableNumpy -> enablePython; let - variant = lib.concatStringsSep "," - (lib.optional enableRelease "release" ++ - lib.optional enableDebug "debug"); + variant = lib.concatStringsSep "," ( + lib.optional enableRelease "release" ++ lib.optional enableDebug "debug" + ); - threading = lib.concatStringsSep "," - (lib.optional enableSingleThreaded "single" ++ - lib.optional enableMultiThreaded "multi"); + threading = lib.concatStringsSep "," ( + lib.optional enableSingleThreaded "single" ++ lib.optional enableMultiThreaded "multi" + ); - link = lib.concatStringsSep "," - (lib.optional enableShared "shared" ++ - lib.optional enableStatic "static"); + link = lib.concatStringsSep "," ( + lib.optional enableShared "shared" ++ lib.optional enableStatic "static" + ); runtime-link = if enableShared then "shared" else "static"; # To avoid library name collisions layout = if taggedLayout then "tagged" else "system"; - needUserConfig = stdenv.hostPlatform != stdenv.buildPlatform || useMpi || (stdenv.hostPlatform.isDarwin && enableShared); - - b2Args = lib.concatStringsSep " " ([ - "--includedir=$dev/include" - "--libdir=$out/lib" - "-j$NIX_BUILD_CORES" - "--layout=${layout}" - "variant=${variant}" - "threading=${threading}" - "link=${link}" - "-sEXPAT_INCLUDE=${expat.dev}/include" - "-sEXPAT_LIBPATH=${expat.out}/lib" - - # TODO: make this unconditional - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform || - # required on mips; see 61d9f201baeef4c4bb91ad8a8f5f89b747e0dfe4 - (stdenv.hostPlatform.isMips && lib.versionAtLeast version "1.79")) [ - "address-model=${toString stdenv.hostPlatform.parsed.cpu.bits}" - "architecture=${if stdenv.hostPlatform.isMips64 - then if lib.versionOlder version "1.78" then "mips1" else "mips" - else if stdenv.hostPlatform.isS390 then "s390x" - else toString stdenv.hostPlatform.parsed.cpu.family}" - # env in host triplet for Mach-O is "macho", but boost binary format for Mach-O is "mach-o" - "binary-format=${if stdenv.hostPlatform.isMacho then "mach-o" - else toString stdenv.hostPlatform.parsed.kernel.execFormat.name}" - "target-os=${toString stdenv.hostPlatform.parsed.kernel.name}" - - # adapted from table in boost manual - # https://www.boost.org/doc/libs/1_66_0/libs/context/doc/html/context/architectures.html - "abi=${if stdenv.hostPlatform.parsed.cpu.family == "arm" then "aapcs" - else if stdenv.hostPlatform.isWindows then "ms" - else if stdenv.hostPlatform.isMips32 then "o32" - else if stdenv.hostPlatform.isMips64n64 then "n64" - else "sysv"}" - ] ++ lib.optional (link != "static") "runtime-link=${runtime-link}" + needUserConfig = + stdenv.hostPlatform != stdenv.buildPlatform + || useMpi + || (stdenv.hostPlatform.isDarwin && enableShared); + + b2Args = lib.concatStringsSep " " ( + [ + "--includedir=$dev/include" + "--libdir=$out/lib" + "-j$NIX_BUILD_CORES" + "--layout=${layout}" + "variant=${variant}" + "threading=${threading}" + "link=${link}" + "-sEXPAT_INCLUDE=${expat.dev}/include" + "-sEXPAT_LIBPATH=${expat.out}/lib" + + # TODO: make this unconditional + ] + ++ + lib.optionals + ( + stdenv.hostPlatform != stdenv.buildPlatform + || + # required on mips; see 61d9f201baeef4c4bb91ad8a8f5f89b747e0dfe4 + (stdenv.hostPlatform.isMips && lib.versionAtLeast version "1.79") + ) + [ + "address-model=${toString stdenv.hostPlatform.parsed.cpu.bits}" + "architecture=${ + if stdenv.hostPlatform.isMips64 then + if lib.versionOlder version "1.78" then "mips1" else "mips" + else if stdenv.hostPlatform.isS390 then + "s390x" + else + toString stdenv.hostPlatform.parsed.cpu.family + }" + # env in host triplet for Mach-O is "macho", but boost binary format for Mach-O is "mach-o" + "binary-format=${ + if stdenv.hostPlatform.isMacho then + "mach-o" + else + toString stdenv.hostPlatform.parsed.kernel.execFormat.name + }" + "target-os=${toString stdenv.hostPlatform.parsed.kernel.name}" + + # adapted from table in boost manual + # https://www.boost.org/doc/libs/1_66_0/libs/context/doc/html/context/architectures.html + "abi=${ + if stdenv.hostPlatform.parsed.cpu.family == "arm" then + "aapcs" + else if stdenv.hostPlatform.isWindows then + "ms" + else if stdenv.hostPlatform.isMips32 then + "o32" + else if stdenv.hostPlatform.isMips64n64 then + "n64" + else + "sysv" + }" + ] + ++ lib.optional (link != "static") "runtime-link=${runtime-link}" ++ lib.optional (variant == "release") "debug-symbols=off" ++ lib.optional (toolset != null) "toolset=${toolset}" ++ lib.optional (!enablePython) "--without-python" ++ lib.optional needUserConfig "--user-config=user-config.jam" ++ lib.optional (stdenv.buildPlatform.isDarwin && stdenv.hostPlatform.isLinux) "pch=off" ++ lib.optionals stdenv.hostPlatform.isMinGW [ - "threadapi=win32" - ] ++ extraB2Args + "threadapi=win32" + ] + ++ extraB2Args ); in @@ -104,54 +153,55 @@ stdenv.mkDerivation { inherit src version; - patchFlags = []; - - patches = patches - ++ lib.optional stdenv.hostPlatform.isDarwin ./darwin-no-system-python.patch - ++ [ ./cmake-paths-173.patch ] - ++ lib.optional (version == "1.77.0") (fetchpatch { - url = "https://github.com/boostorg/math/commit/7d482f6ebc356e6ec455ccb5f51a23971bf6ce5b.patch"; - relative = "include"; - sha256 = "sha256-KlmIbixcds6GyKYt1fx5BxDIrU7msrgDdYo9Va/KJR4="; - }) - # Fixes ABI detection - ++ lib.optional (version == "1.83.0") (fetchpatch { - url = "https://github.com/boostorg/context/commit/6fa6d5c50d120e69b2d8a1c0d2256ee933e94b3b.patch"; - stripLen = 1; - extraPrefix = "libs/context/"; - sha256 = "sha256-bCfLL7bD1Rn4Ie/P3X+nIcgTkbXdCX6FW7B9lHsmVW8="; - }) - # This fixes another issue regarding ill-formed constant expressions, which is a default error - # in clang 16 and will be a hard error in clang 17. - ++ lib.optional (lib.versionOlder version "1.80") (fetchpatch { - url = "https://github.com/boostorg/log/commit/77f1e20bd69c2e7a9e25e6a9818ae6105f7d070c.patch"; - relative = "include"; - hash = "sha256-6qOiGJASm33XzwoxVZfKJd7sTlQ5yd+MMFQzegXm5RI="; - }) - ++ lib.optionals (lib.versionOlder version "1.81") [ - # libc++ 15 dropped support for `std::unary_function` and `std::binary_function` in C++17+. - # C++17 is the default for clang 16, but clang 15 is also affected in that language mode. - # This patch is for Boost 1.80, but it also applies to earlier versions. - (fetchpatch { - url = "https://www.boost.org/patches/1_80_0/0005-config-libcpp15.patch"; - hash = "sha256-ULFMzKphv70unvPZ3o4vSP/01/xbSM9a2TlIV67eXDQ="; - }) - # This fixes another ill-formed contant expressions issue flagged by clang 16. - (fetchpatch { - url = "https://github.com/boostorg/numeric_conversion/commit/50a1eae942effb0a9b90724323ef8f2a67e7984a.patch"; + patchFlags = [ ]; + + patches = + patches + ++ lib.optional stdenv.hostPlatform.isDarwin ./darwin-no-system-python.patch + ++ [ ./cmake-paths-173.patch ] + ++ lib.optional (version == "1.77.0") (fetchpatch { + url = "https://github.com/boostorg/math/commit/7d482f6ebc356e6ec455ccb5f51a23971bf6ce5b.patch"; relative = "include"; - hash = "sha256-dq4SVgxkPJSC7Fvr59VGnXkM4Lb09kYDaBksCHo9C0s="; + sha256 = "sha256-KlmIbixcds6GyKYt1fx5BxDIrU7msrgDdYo9Va/KJR4="; }) - # This fixes an issue in Python 3.11 about Py_TPFLAGS_HAVE_GC - (fetchpatch { - name = "python311-compatibility.patch"; - url = "https://github.com/boostorg/python/commit/a218babc8daee904a83f550fb66e5cb3f1cb3013.patch"; - hash = "sha256-IHxLtJBx0xSy7QEr8FbCPofsjcPuSYzgtPwDlx1JM+4="; + # Fixes ABI detection + ++ lib.optional (version == "1.83.0") (fetchpatch { + url = "https://github.com/boostorg/context/commit/6fa6d5c50d120e69b2d8a1c0d2256ee933e94b3b.patch"; stripLen = 1; - extraPrefix = "libs/python/"; + extraPrefix = "libs/context/"; + sha256 = "sha256-bCfLL7bD1Rn4Ie/P3X+nIcgTkbXdCX6FW7B9lHsmVW8="; }) - ] - ++ lib.optional (lib.versionAtLeast version "1.81" && stdenv.cc.isClang) ./fix-clang-target.patch; + # This fixes another issue regarding ill-formed constant expressions, which is a default error + # in clang 16 and will be a hard error in clang 17. + ++ lib.optional (lib.versionOlder version "1.80") (fetchpatch { + url = "https://github.com/boostorg/log/commit/77f1e20bd69c2e7a9e25e6a9818ae6105f7d070c.patch"; + relative = "include"; + hash = "sha256-6qOiGJASm33XzwoxVZfKJd7sTlQ5yd+MMFQzegXm5RI="; + }) + ++ lib.optionals (lib.versionOlder version "1.81") [ + # libc++ 15 dropped support for `std::unary_function` and `std::binary_function` in C++17+. + # C++17 is the default for clang 16, but clang 15 is also affected in that language mode. + # This patch is for Boost 1.80, but it also applies to earlier versions. + (fetchpatch { + url = "https://www.boost.org/patches/1_80_0/0005-config-libcpp15.patch"; + hash = "sha256-ULFMzKphv70unvPZ3o4vSP/01/xbSM9a2TlIV67eXDQ="; + }) + # This fixes another ill-formed contant expressions issue flagged by clang 16. + (fetchpatch { + url = "https://github.com/boostorg/numeric_conversion/commit/50a1eae942effb0a9b90724323ef8f2a67e7984a.patch"; + relative = "include"; + hash = "sha256-dq4SVgxkPJSC7Fvr59VGnXkM4Lb09kYDaBksCHo9C0s="; + }) + # This fixes an issue in Python 3.11 about Py_TPFLAGS_HAVE_GC + (fetchpatch { + name = "python311-compatibility.patch"; + url = "https://github.com/boostorg/python/commit/a218babc8daee904a83f550fb66e5cb3f1cb3013.patch"; + hash = "sha256-IHxLtJBx0xSy7QEr8FbCPofsjcPuSYzgtPwDlx1JM+4="; + stripLen = 1; + extraPrefix = "libs/python/"; + }) + ] + ++ lib.optional (lib.versionAtLeast version "1.81" && stdenv.cc.isClang) ./fix-clang-target.patch; meta = with lib; { homepage = "http://boost.org/"; @@ -169,51 +219,52 @@ stdenv.mkDerivation { inherit boostBuildPatches; }; - preConfigure = lib.optionalString useMpi '' - cat << EOF >> user-config.jam - using mpi : ${lib.getDev mpi}/bin/mpiCC ; - EOF - '' - # On darwin we need to add the `$out/lib` to the libraries' rpath explicitly, - # otherwise the dynamic linker is unable to resolve the reference to @rpath - # when the boost libraries want to load each other at runtime. - + lib.optionalString (stdenv.hostPlatform.isDarwin && enableShared) '' - cat << EOF >> user-config.jam - using clang-darwin : : ${stdenv.cc.targetPrefix}c++ - : "-rpath $out/lib/" - $AR - $RANLIB - ; - EOF - '' - # b2 has trouble finding the correct compiler and tools for cross compilation - # since it apparently ignores $CC, $AR etc. Thus we need to set everything - # in user-config.jam. To keep things simple we just set everything in an - # uniform way for clang and gcc (which works thanks to our cc-wrapper). - # We pass toolset later which will make b2 invoke everything in the right - # way -- the other toolset in user-config.jam will be ignored. - + lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' - cat << EOF >> user-config.jam - using gcc : cross : ${stdenv.cc.targetPrefix}c++ - : $AR - $RANLIB - ; - - using clang : cross : ${stdenv.cc.targetPrefix}c++ - : $AR - $RANLIB - ; - EOF - '' - # b2 needs to be explicitly told how to find Python when cross-compiling - + lib.optionalString enablePython '' - cat << EOF >> user-config.jam - using python : : ${python.interpreter} - : ${python}/include/python${python.pythonVersion} - : ${python}/lib - ; - EOF - ''; + preConfigure = + lib.optionalString useMpi '' + cat << EOF >> user-config.jam + using mpi : ${lib.getDev mpi}/bin/mpiCC ; + EOF + '' + # On darwin we need to add the `$out/lib` to the libraries' rpath explicitly, + # otherwise the dynamic linker is unable to resolve the reference to @rpath + # when the boost libraries want to load each other at runtime. + + lib.optionalString (stdenv.hostPlatform.isDarwin && enableShared) '' + cat << EOF >> user-config.jam + using clang-darwin : : ${stdenv.cc.targetPrefix}c++ + : "-rpath $out/lib/" + $AR + $RANLIB + ; + EOF + '' + # b2 has trouble finding the correct compiler and tools for cross compilation + # since it apparently ignores $CC, $AR etc. Thus we need to set everything + # in user-config.jam. To keep things simple we just set everything in an + # uniform way for clang and gcc (which works thanks to our cc-wrapper). + # We pass toolset later which will make b2 invoke everything in the right + # way -- the other toolset in user-config.jam will be ignored. + + lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' + cat << EOF >> user-config.jam + using gcc : cross : ${stdenv.cc.targetPrefix}c++ + : $AR + $RANLIB + ; + + using clang : cross : ${stdenv.cc.targetPrefix}c++ + : $AR + $RANLIB + ; + EOF + '' + # b2 needs to be explicitly told how to find Python when cross-compiling + + lib.optionalString enablePython '' + cat << EOF >> user-config.jam + using python : : ${python.interpreter} + : ${python}/include/python${python.pythonVersion} + : ${python}/lib + ; + EOF + ''; env = { NIX_CFLAGS_LINK = lib.optionalString stdenv.hostPlatform.isDarwin "-headerpad_max_install_names"; @@ -236,24 +287,38 @@ stdenv.mkDerivation { enableParallelBuilding = true; - nativeBuildInputs = [ which boost-build copyPkgconfigItems ] - ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; - buildInputs = [ expat zlib bzip2 libiconv ] + nativeBuildInputs = [ + which + boost-build + copyPkgconfigItems + ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; + buildInputs = + [ + expat + zlib + bzip2 + libiconv + ] ++ lib.optional (lib.versionAtLeast version "1.69") zstd ++ [ xz ] ++ lib.optional enableIcu icu - ++ lib.optionals enablePython [ libxcrypt python ] + ++ lib.optionals enablePython [ + libxcrypt + python + ] ++ lib.optional enableNumpy python.pkgs.numpy; configureScript = "./bootstrap.sh"; - configurePlatforms = []; + configurePlatforms = [ ]; dontDisableStatic = true; dontAddStaticConfigureFlags = true; - configureFlags = [ - "--includedir=$(dev)/include" - "--libdir=$(out)/lib" - "--with-bjam=b2" # prevent bootstrapping b2 in configurePhase - ] ++ lib.optional (toolset != null) "--with-toolset=${toolset}" + configureFlags = + [ + "--includedir=$(dev)/include" + "--libdir=$(out)/lib" + "--with-bjam=b2" # prevent bootstrapping b2 in configurePhase + ] + ++ lib.optional (toolset != null) "--with-toolset=${toolset}" ++ [ (if enableIcu then "--with-icu=${icu.dev}" else "--without-icu") ]; buildPhase = '' @@ -275,14 +340,19 @@ stdenv.mkDerivation { runHook postInstall ''; - postFixup = '' - # Make boost header paths relative so that they are not runtime dependencies - cd "$dev" && find include \( -name '*.hpp' -or -name '*.h' -or -name '*.ipp' \) \ - -exec sed '1s/^\xef\xbb\xbf//;1i#line 1 "{}"' -i '{}' \; - '' + lib.optionalString stdenv.hostPlatform.isMinGW '' - $RANLIB "$out/lib/"*.a - ''; - - outputs = [ "out" "dev" ]; + postFixup = + '' + # Make boost header paths relative so that they are not runtime dependencies + cd "$dev" && find include \( -name '*.hpp' -or -name '*.h' -or -name '*.ipp' \) \ + -exec sed '1s/^\xef\xbb\xbf//;1i#line 1 "{}"' -i '{}' \; + '' + + lib.optionalString stdenv.hostPlatform.isMinGW '' + $RANLIB "$out/lib/"*.a + ''; + + outputs = [ + "out" + "dev" + ]; setOutputFlags = false; } diff --git a/pkgs/development/libraries/box2d/default.nix b/pkgs/development/libraries/box2d/default.nix index acc2d96caf4a72..197d9313de27ac 100644 --- a/pkgs/development/libraries/box2d/default.nix +++ b/pkgs/development/libraries/box2d/default.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libGLU -, libGL -, libglut -, libX11 -, libXcursor -, libXinerama -, libXrandr -, xorgproto -, libXi -, pkg-config -, Carbon -, Cocoa -, Kernel -, OpenGL -, settingsFile ? "include/box2d/b2_settings.h" +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libGLU, + libGL, + libglut, + libX11, + libXcursor, + libXinerama, + libXrandr, + xorgproto, + libXi, + pkg-config, + Carbon, + Cocoa, + Kernel, + OpenGL, + settingsFile ? "include/box2d/b2_settings.h", }: let @@ -34,22 +35,30 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-yvhpgiZpjTPeSY7Ma1bh4LwIokUUKB10v2WHlamL9D8="; }; - nativeBuildInputs = [ cmake pkg-config ]; - - buildInputs = [ - libGLU - libGL - libglut - libX11 - libXcursor - libXinerama - libXrandr - xorgproto - libXi - ] ++ optionals stdenv.hostPlatform.isDarwin [ - Carbon Cocoa Kernel OpenGL + nativeBuildInputs = [ + cmake + pkg-config ]; + buildInputs = + [ + libGLU + libGL + libglut + libX11 + libXcursor + libXinerama + libXrandr + xorgproto + libXi + ] + ++ optionals stdenv.hostPlatform.isDarwin [ + Carbon + Cocoa + Kernel + OpenGL + ]; + cmakeFlags = [ (cmakeBool "BOX2D_BUILD_UNIT_TESTS" finalAttrs.finalPackage.doCheck) ]; diff --git a/pkgs/development/libraries/bullet/default.nix b/pkgs/development/libraries/bullet/default.nix index 4a161423c7d3fc..63be83763eb29a 100644 --- a/pkgs/development/libraries/bullet/default.nix +++ b/pkgs/development/libraries/bullet/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libGLU -, libGL -, libglut -, Cocoa -, OpenGL +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libGLU, + libGL, + libglut, + Cocoa, + OpenGL, }: stdenv.mkDerivation rec { @@ -21,34 +22,45 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libGLU libGL libglut ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa OpenGL ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + libGLU + libGL + libglut + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + OpenGL + ]; - postPatch = '' - substituteInPlace examples/ThirdPartyLibs/Gwen/CMakeLists.txt \ - --replace "-DGLEW_STATIC" "-DGLEW_STATIC -Wno-narrowing" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - sed -i 's/FIND_PACKAGE(OpenGL)//' CMakeLists.txt - sed -i 's/FIND_LIBRARY(COCOA_LIBRARY Cocoa)//' CMakeLists.txt - ''; + postPatch = + '' + substituteInPlace examples/ThirdPartyLibs/Gwen/CMakeLists.txt \ + --replace "-DGLEW_STATIC" "-DGLEW_STATIC -Wno-narrowing" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + sed -i 's/FIND_PACKAGE(OpenGL)//' CMakeLists.txt + sed -i 's/FIND_LIBRARY(COCOA_LIBRARY Cocoa)//' CMakeLists.txt + ''; - cmakeFlags = [ - "-DBUILD_SHARED_LIBS=ON" - "-DBUILD_CPU_DEMOS=OFF" - "-DINSTALL_EXTRA_LIBS=ON" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DOPENGL_FOUND=true" - "-DOPENGL_LIBRARIES=${OpenGL}/Library/Frameworks/OpenGL.framework" - "-DOPENGL_INCLUDE_DIR=${OpenGL}/Library/Frameworks/OpenGL.framework" - "-DOPENGL_gl_LIBRARY=${OpenGL}/Library/Frameworks/OpenGL.framework" - "-DCOCOA_LIBRARY=${Cocoa}/Library/Frameworks/Cocoa.framework" - "-DBUILD_BULLET2_DEMOS=OFF" - "-DBUILD_UNIT_TESTS=OFF" - "-DBUILD_BULLET_ROBOTICS_GUI_EXTRA=OFF" - ]; + cmakeFlags = + [ + "-DBUILD_SHARED_LIBS=ON" + "-DBUILD_CPU_DEMOS=OFF" + "-DINSTALL_EXTRA_LIBS=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DOPENGL_FOUND=true" + "-DOPENGL_LIBRARIES=${OpenGL}/Library/Frameworks/OpenGL.framework" + "-DOPENGL_INCLUDE_DIR=${OpenGL}/Library/Frameworks/OpenGL.framework" + "-DOPENGL_gl_LIBRARY=${OpenGL}/Library/Frameworks/OpenGL.framework" + "-DCOCOA_LIBRARY=${Cocoa}/Library/Frameworks/Cocoa.framework" + "-DBUILD_BULLET2_DEMOS=OFF" + "-DBUILD_UNIT_TESTS=OFF" + "-DBUILD_BULLET_ROBOTICS_GUI_EXTRA=OFF" + ]; - env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang - "-Wno-error=argument-outside-range -Wno-error=c++11-narrowing"; + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-error=argument-outside-range -Wno-error=c++11-narrowing"; meta = with lib; { description = "Professional free 3D Game Multiphysics Library"; diff --git a/pkgs/development/libraries/bullet/roboschool-fork.nix b/pkgs/development/libraries/bullet/roboschool-fork.nix index bcc963f5b466c3..94ce4a3f865d0a 100644 --- a/pkgs/development/libraries/bullet/roboschool-fork.nix +++ b/pkgs/development/libraries/bullet/roboschool-fork.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, libGLU, libGL, libglut -, Cocoa, OpenGL +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libGLU, + libGL, + libglut, + Cocoa, + OpenGL, }: stdenv.mkDerivation { @@ -18,8 +26,16 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ cmake ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libGLU libGL libglut ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa OpenGL ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + libGLU + libGL + libglut + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + OpenGL + ]; patches = [ ./gwen-narrowing.patch ]; @@ -28,19 +44,21 @@ stdenv.mkDerivation { sed -i 's/FIND_LIBRARY(COCOA_LIBRARY Cocoa)//' CMakeLists.txt ''; - cmakeFlags = [ - "-DBUILD_SHARED_LIBS=ON" - "-DBUILD_CPU_DEMOS=OFF" - "-DINSTALL_EXTRA_LIBS=ON" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DOPENGL_FOUND=true" - "-DOPENGL_LIBRARIES=${OpenGL}/Library/Frameworks/OpenGL.framework" - "-DOPENGL_INCLUDE_DIR=${OpenGL}/Library/Frameworks/OpenGL.framework" - "-DOPENGL_gl_LIBRARY=${OpenGL}/Library/Frameworks/OpenGL.framework" - "-DCOCOA_LIBRARY=${Cocoa}/Library/Frameworks/Cocoa.framework" - "-DBUILD_BULLET2_DEMOS=OFF" - "-DBUILD_UNIT_TESTS=OFF" - ]; + cmakeFlags = + [ + "-DBUILD_SHARED_LIBS=ON" + "-DBUILD_CPU_DEMOS=OFF" + "-DINSTALL_EXTRA_LIBS=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DOPENGL_FOUND=true" + "-DOPENGL_LIBRARIES=${OpenGL}/Library/Frameworks/OpenGL.framework" + "-DOPENGL_INCLUDE_DIR=${OpenGL}/Library/Frameworks/OpenGL.framework" + "-DOPENGL_gl_LIBRARY=${OpenGL}/Library/Frameworks/OpenGL.framework" + "-DCOCOA_LIBRARY=${Cocoa}/Library/Frameworks/Cocoa.framework" + "-DBUILD_BULLET2_DEMOS=OFF" + "-DBUILD_UNIT_TESTS=OFF" + ]; meta = with lib; { description = "Professional free 3D Game Multiphysics Library"; diff --git a/pkgs/development/libraries/c-ares/default.nix b/pkgs/development/libraries/c-ares/default.nix index 32184e9c6d38e0..913c65e93f9726 100644 --- a/pkgs/development/libraries/c-ares/default.nix +++ b/pkgs/development/libraries/c-ares/default.nix @@ -1,9 +1,14 @@ -{ lib, stdenv, fetchurl, updateAutotoolsGnuConfigScriptsHook -, withCMake ? true, cmake - -# sensitive downstream packages -, curl -, grpc # consumes cmake config +{ + lib, + stdenv, + fetchurl, + updateAutotoolsGnuConfigScriptsHook, + withCMake ? true, + cmake, + + # sensitive downstream packages + curl, + grpc, # consumes cmake config }: # Note: this package is used for bootstrapping fetchurl, and thus @@ -17,18 +22,26 @@ stdenv.mkDerivation rec { src = fetchurl { # Note: tag name varies in some versions, e.g. v1.30.0, c-ares-1_17_0. - url = "https://github.com/c-ares/${pname}/releases/download/cares-${builtins.replaceStrings ["."] ["_"] version}/${pname}-${version}.tar.gz"; + url = "https://github.com/c-ares/${pname}/releases/download/cares-${ + builtins.replaceStrings [ "." ] [ "_" ] version + }/${pname}-${version}.tar.gz"; hash = "sha256-CnK+ZpWZVcQ+KvL70DQY6Cor1UZGBOyaYhR+N6zrQgs="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook ] ++ lib.optionals withCMake [ cmake ]; - cmakeFlags = [] ++ lib.optionals stdenv.hostPlatform.isStatic [ - "-DCARES_SHARED=OFF" - "-DCARES_STATIC=ON" - ]; + cmakeFlags = + [ ] + ++ lib.optionals stdenv.hostPlatform.isStatic [ + "-DCARES_SHARED=OFF" + "-DCARES_STATIC=ON" + ]; enableParallelBuilding = true; diff --git a/pkgs/development/libraries/c-blosc/1.nix b/pkgs/development/libraries/c-blosc/1.nix index aac58606cf458e..745521a686b761 100644 --- a/pkgs/development/libraries/c-blosc/1.nix +++ b/pkgs/development/libraries/c-blosc/1.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, testers +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + testers, -, static ? stdenv.hostPlatform.isStatic + static ? stdenv.hostPlatform.isStatic, -, lz4 -, zlib -, zstd + lz4, + zlib, + zstd, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/libraries/c-blosc/2.nix b/pkgs/development/libraries/c-blosc/2.nix index 170638c3c3e6b0..518dd25e06ea5b 100644 --- a/pkgs/development/libraries/c-blosc/2.nix +++ b/pkgs/development/libraries/c-blosc/2.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, testers +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + testers, -, static ? stdenv.hostPlatform.isStatic + static ? stdenv.hostPlatform.isStatic, -, lz4 -, zlib-ng -, zstd + lz4, + zlib-ng, + zstd, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/libraries/c-blosc/default.nix b/pkgs/development/libraries/c-blosc/default.nix index 4ebe3622af4c9d..f5281cf832abae 100644 --- a/pkgs/development/libraries/c-blosc/default.nix +++ b/pkgs/development/libraries/c-blosc/default.nix @@ -1,4 +1,5 @@ -{ callPackage }: { - c-blosc = callPackage ./1.nix {}; - c-blosc2 = callPackage ./2.nix {}; +{ callPackage }: +{ + c-blosc = callPackage ./1.nix { }; + c-blosc2 = callPackage ./2.nix { }; } diff --git a/pkgs/development/libraries/cairomm/1.16.nix b/pkgs/development/libraries/cairomm/1.16.nix index cd561d00918769..9ffbc38316a388 100644 --- a/pkgs/development/libraries/cairomm/1.16.nix +++ b/pkgs/development/libraries/cairomm/1.16.nix @@ -1,21 +1,25 @@ -{ stdenv -, lib -, fetchurl -, boost -, meson -, ninja -, pkg-config -, cairo -, fontconfig -, libsigcxx30 -, ApplicationServices +{ + stdenv, + lib, + fetchurl, + boost, + meson, + ninja, + pkg-config, + cairo, + fontconfig, + libsigcxx30, + ApplicationServices, }: stdenv.mkDerivation rec { pname = "cairomm"; version = "1.18.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "https://www.cairographics.org/releases/cairomm-${version}.tar.xz"; @@ -28,12 +32,14 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - boost # for tests - fontconfig - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ApplicationServices - ]; + buildInputs = + [ + boost # for tests + fontconfig + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ApplicationServices + ]; propagatedBuildInputs = [ cairo @@ -50,7 +56,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "C++ bindings for the Cairo vector graphics library"; homepage = "https://www.cairographics.org/"; - license = with licenses; [ lgpl2Plus mpl10 ]; + license = with licenses; [ + lgpl2Plus + mpl10 + ]; maintainers = teams.gnome.members; platforms = platforms.unix; }; diff --git a/pkgs/development/libraries/cairomm/default.nix b/pkgs/development/libraries/cairomm/default.nix index 382770e144f561..6c7046a15e537b 100644 --- a/pkgs/development/libraries/cairomm/default.nix +++ b/pkgs/development/libraries/cairomm/default.nix @@ -1,21 +1,25 @@ -{ fetchurl -, stdenv -, lib -, pkg-config -, darwin -, boost -, cairo -, fontconfig -, libsigcxx -, meson -, ninja +{ + fetchurl, + stdenv, + lib, + pkg-config, + darwin, + boost, + cairo, + fontconfig, + libsigcxx, + meson, + ninja, }: stdenv.mkDerivation rec { pname = "cairomm"; version = "1.14.5"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "https://www.cairographics.org/releases/cairomm-${version}.tar.xz"; @@ -28,12 +32,17 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - boost # for tests - fontconfig - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - ApplicationServices - ]); + buildInputs = + [ + boost # for tests + fontconfig + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + ApplicationServices + ] + ); propagatedBuildInputs = [ cairo @@ -49,7 +58,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "C++ bindings for the Cairo vector graphics library"; homepage = "https://www.cairographics.org/"; - license = with licenses; [ lgpl2Plus mpl10 ]; + license = with licenses; [ + lgpl2Plus + mpl10 + ]; platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/capstone/4.nix b/pkgs/development/libraries/capstone/4.nix index 836bb47568c345..d16356dc274d39 100644 --- a/pkgs/development/libraries/capstone/4.nix +++ b/pkgs/development/libraries/capstone/4.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, fixDarwinDylibNames +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + fixDarwinDylibNames, }: stdenv.mkDerivation rec { @@ -16,20 +17,25 @@ stdenv.mkDerivation rec { sha256 = "sha256-XMwQ7UaPC8YYu4yxsE4bbR3leYPfBHu5iixSLz05r3g="; }; - nativeBuildInputs = [ - cmake - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ]; + nativeBuildInputs = + [ + cmake + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ]; doCheck = true; meta = { description = "Advanced disassembly library"; - homepage = "http://www.capstone-engine.org"; - license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [ thoughtpolice ris ]; + homepage = "http://www.capstone-engine.org"; + license = lib.licenses.bsd3; + maintainers = with lib.maintainers; [ + thoughtpolice + ris + ]; mainProgram = "cstool"; - platforms = lib.platforms.unix; + platforms = lib.platforms.unix; }; } diff --git a/pkgs/development/libraries/capstone/default.nix b/pkgs/development/libraries/capstone/default.nix index 8873286d912a2f..d4490dce441e70 100644 --- a/pkgs/development/libraries/capstone/default.nix +++ b/pkgs/development/libraries/capstone/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, fixDarwinDylibNames +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + fixDarwinDylibNames, }: stdenv.mkDerivation rec { @@ -16,24 +17,31 @@ stdenv.mkDerivation rec { hash = "sha256-LZ10czBn5oaKMHQ8xguC6VZa7wvEgPRu6oWt/22QaDs="; }; - cmakeFlags = [ - (lib.cmakeBool "BUILD_SHARED_LIBS" true) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ (lib.cmakeBool "CAPSTONE_BUILD_MACOS_THIN" true) ]; + cmakeFlags = + [ + (lib.cmakeBool "BUILD_SHARED_LIBS" true) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ (lib.cmakeBool "CAPSTONE_BUILD_MACOS_THIN" true) ]; - nativeBuildInputs = [ - cmake - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ]; + nativeBuildInputs = + [ + cmake + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ]; doCheck = true; meta = { description = "Advanced disassembly library"; - homepage = "http://www.capstone-engine.org"; - license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [ thoughtpolice ris ]; + homepage = "http://www.capstone-engine.org"; + license = lib.licenses.bsd3; + maintainers = with lib.maintainers; [ + thoughtpolice + ris + ]; mainProgram = "cstool"; - platforms = lib.platforms.unix; + platforms = lib.platforms.unix; }; } diff --git a/pkgs/development/libraries/cassandra-cpp-driver/default.nix b/pkgs/development/libraries/cassandra-cpp-driver/default.nix index 4e8175d0585ac2..ff9e0dd77e4dd9 100644 --- a/pkgs/development/libraries/cassandra-cpp-driver/default.nix +++ b/pkgs/development/libraries/cassandra-cpp-driver/default.nix @@ -1,41 +1,54 @@ -{ fetchFromGitHub -, lib -, stdenv -, cmake -, zlib -, libuv -, openssl -, pkg-config -, examples ? false -}: stdenv.mkDerivation rec { - pname = "cassandra-cpp-driver"; - version = "2.17.1"; +{ + fetchFromGitHub, + lib, + stdenv, + cmake, + zlib, + libuv, + openssl, + pkg-config, + examples ? false, +}: +stdenv.mkDerivation rec { + pname = "cassandra-cpp-driver"; + version = "2.17.1"; - src = fetchFromGitHub { - owner = "datastax"; - repo = "cpp-driver"; - rev = "refs/tags/${version}"; - sha256 = "sha256-GuvmKHJknudyn7ahrn/8+kKUA4NW5UjCfkYoX3aTE+Q="; - }; + src = fetchFromGitHub { + owner = "datastax"; + repo = "cpp-driver"; + rev = "refs/tags/${version}"; + sha256 = "sha256-GuvmKHJknudyn7ahrn/8+kKUA4NW5UjCfkYoX3aTE+Q="; + }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ zlib libuv openssl.dev ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + zlib + libuv + openssl.dev + ]; - cmakeFlags = (lib.attrsets.mapAttrsToList - (name: value: "-DCASS_BUILD_${name}:BOOL=${if value then "ON" else "OFF"}") { + cmakeFlags = + (lib.attrsets.mapAttrsToList + (name: value: "-DCASS_BUILD_${name}:BOOL=${if value then "ON" else "OFF"}") + { EXAMPLES = examples; - }) ++ [ "-DLIBUV_INCLUDE_DIR=${lib.getDev libuv}/include" ]; + } + ) + ++ [ "-DLIBUV_INCLUDE_DIR=${lib.getDev libuv}/include" ]; - meta = with lib; { - description = "DataStax CPP cassandra driver"; - longDescription = '' - A modern, feature-rich and highly tunable C/C++ client - library for Apache Cassandra 2.1+ using exclusively Cassandra’s - binary protocol and Cassandra Query Language v3. - ''; - license = with licenses; [ asl20 ]; - platforms = platforms.x86_64; - homepage = "https://docs.datastax.com/en/developer/cpp-driver/"; - maintainers = [ maintainers.npatsakula ]; - }; + meta = with lib; { + description = "DataStax CPP cassandra driver"; + longDescription = '' + A modern, feature-rich and highly tunable C/C++ client + library for Apache Cassandra 2.1+ using exclusively Cassandra’s + binary protocol and Cassandra Query Language v3. + ''; + license = with licenses; [ asl20 ]; + platforms = platforms.x86_64; + homepage = "https://docs.datastax.com/en/developer/cpp-driver/"; + maintainers = [ maintainers.npatsakula ]; + }; } diff --git a/pkgs/development/libraries/catch2/3.nix b/pkgs/development/libraries/catch2/3.nix index b005dc3f81166f..c9b8058542001c 100644 --- a/pkgs/development/libraries/catch2/3.nix +++ b/pkgs/development/libraries/catch2/3.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, }: stdenv.mkDerivation rec { @@ -22,22 +23,26 @@ stdenv.mkDerivation rec { hardeningDisable = [ "trivialautovarinit" ]; - cmakeFlags = [ - "-DCATCH_DEVELOPMENT_BUILD=ON" - "-DCATCH_BUILD_TESTING=${if doCheck then "ON" else "OFF"}" - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && doCheck) [ - # test has a faulty path normalization technique that won't work in - # our darwin build environment https://github.com/catchorg/Catch2/issues/1691 - "-DCMAKE_CTEST_ARGUMENTS=-E;ApprovalTests" - ]; - - env = lib.optionalAttrs stdenv.hostPlatform.isx86_32 { - # Tests fail on x86_32 if compiled with x87 floats: https://github.com/catchorg/Catch2/issues/2796 - NIX_CFLAGS_COMPILE = "-msse2 -mfpmath=sse"; - } // lib.optionalAttrs (stdenv.hostPlatform.isRiscV || stdenv.hostPlatform.isAarch32) { - # Build failure caused by -Werror: https://github.com/catchorg/Catch2/issues/2808 - NIX_CFLAGS_COMPILE = "-Wno-error=cast-align"; - }; + cmakeFlags = + [ + "-DCATCH_DEVELOPMENT_BUILD=ON" + "-DCATCH_BUILD_TESTING=${if doCheck then "ON" else "OFF"}" + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && doCheck) [ + # test has a faulty path normalization technique that won't work in + # our darwin build environment https://github.com/catchorg/Catch2/issues/1691 + "-DCMAKE_CTEST_ARGUMENTS=-E;ApprovalTests" + ]; + + env = + lib.optionalAttrs stdenv.hostPlatform.isx86_32 { + # Tests fail on x86_32 if compiled with x87 floats: https://github.com/catchorg/Catch2/issues/2796 + NIX_CFLAGS_COMPILE = "-msse2 -mfpmath=sse"; + } + // lib.optionalAttrs (stdenv.hostPlatform.isRiscV || stdenv.hostPlatform.isAarch32) { + # Build failure caused by -Werror: https://github.com/catchorg/Catch2/issues/2808 + NIX_CFLAGS_COMPILE = "-Wno-error=cast-align"; + }; doCheck = true; diff --git a/pkgs/development/libraries/catch2/default.nix b/pkgs/development/libraries/catch2/default.nix index 0f79f7679834d2..4e1a8816cd7bc3 100644 --- a/pkgs/development/libraries/catch2/default.nix +++ b/pkgs/development/libraries/catch2/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "catch2"; @@ -8,7 +13,7 @@ stdenv.mkDerivation rec { owner = "catchorg"; repo = "Catch2"; rev = "v${version}"; - sha256="sha256-XnT2ziES94Y4uzWmaxSw7nWegJFQjAqFUG8PkwK5nLU="; + sha256 = "sha256-XnT2ziES94Y4uzWmaxSw7nWegJFQjAqFUG8PkwK5nLU="; }; nativeBuildInputs = [ cmake ]; @@ -19,7 +24,10 @@ stdenv.mkDerivation rec { description = "Multi-paradigm automated test framework for C++ and Objective-C (and, maybe, C)"; homepage = "http://catch-lib.net"; license = licenses.boost; - maintainers = with maintainers; [ edwtjo knedlsepp ]; + maintainers = with maintainers; [ + edwtjo + knedlsepp + ]; platforms = with platforms; unix ++ windows; }; } diff --git a/pkgs/development/libraries/cctz/default.nix b/pkgs/development/libraries/cctz/default.nix index 4ad0bf6b8034ce..2786ea7b1dca7d 100644 --- a/pkgs/development/libraries/cctz/default.nix +++ b/pkgs/development/libraries/cctz/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, Foundation }: +{ + lib, + stdenv, + fetchFromGitHub, + Foundation, +}: stdenv.mkDerivation rec { pname = "cctz"; @@ -15,7 +20,8 @@ stdenv.mkDerivation rec { buildInputs = lib.optional stdenv.hostPlatform.isDarwin Foundation; - installTargets = [ "install_hdrs" ] + installTargets = + [ "install_hdrs" ] ++ lib.optional (!stdenv.hostPlatform.isStatic) "install_shared_lib" ++ lib.optional stdenv.hostPlatform.isStatic "install_lib"; diff --git a/pkgs/development/libraries/celt/0.5.1.nix b/pkgs/development/libraries/celt/0.5.1.nix index 759dd6254b4ef9..ce69981e82e656 100644 --- a/pkgs/development/libraries/celt/0.5.1.nix +++ b/pkgs/development/libraries/celt/0.5.1.nix @@ -1,17 +1,20 @@ -{ callPackage, fetchurl, ... } @ args: +{ callPackage, fetchurl, ... }@args: -callPackage ./generic.nix (args // rec { - version = "0.5.1.3"; +callPackage ./generic.nix ( + args + // rec { + version = "0.5.1.3"; - src = fetchurl { - url = "http://downloads.xiph.org/releases/celt/celt-${version}.tar.gz"; - sha256 = "0bkam9z5vnrxpbxkkh9kw6yzjka9di56h11iijikdd1f71l5nbpw"; - }; + src = fetchurl { + url = "http://downloads.xiph.org/releases/celt/celt-${version}.tar.gz"; + sha256 = "0bkam9z5vnrxpbxkkh9kw6yzjka9di56h11iijikdd1f71l5nbpw"; + }; - # Don't build tests due to badness with ec_ilog - prePatch = '' - substituteInPlace Makefile.in \ - --replace 'SUBDIRS = libcelt tests' \ - 'SUBDIRS = libcelt' - ''; -}) + # Don't build tests due to badness with ec_ilog + prePatch = '' + substituteInPlace Makefile.in \ + --replace 'SUBDIRS = libcelt tests' \ + 'SUBDIRS = libcelt' + ''; + } +) diff --git a/pkgs/development/libraries/celt/0.7.nix b/pkgs/development/libraries/celt/0.7.nix index 2092941dc76106..5b17c0b0618e98 100644 --- a/pkgs/development/libraries/celt/0.7.nix +++ b/pkgs/development/libraries/celt/0.7.nix @@ -1,10 +1,13 @@ -{ callPackage, fetchurl, ... } @ args: +{ callPackage, fetchurl, ... }@args: -callPackage ./generic.nix (args // rec { - version = "0.7.1"; +callPackage ./generic.nix ( + args + // rec { + version = "0.7.1"; - src = fetchurl { - url = "http://downloads.xiph.org/releases/celt/celt-${version}.tar.gz"; - sha256 = "0rihjgzrqcprsv8a1pmiglwik7xqbs2yw3fwd6gb28chnpgy5w4k"; - }; -}) + src = fetchurl { + url = "http://downloads.xiph.org/releases/celt/celt-${version}.tar.gz"; + sha256 = "0rihjgzrqcprsv8a1pmiglwik7xqbs2yw3fwd6gb28chnpgy5w4k"; + }; + } +) diff --git a/pkgs/development/libraries/celt/default.nix b/pkgs/development/libraries/celt/default.nix index 3071b5d7c6bb23..66bafff16584c6 100644 --- a/pkgs/development/libraries/celt/default.nix +++ b/pkgs/development/libraries/celt/default.nix @@ -1,10 +1,13 @@ -{ callPackage, fetchurl, ... } @ args: +{ callPackage, fetchurl, ... }@args: -callPackage ./generic.nix (args // rec { - version = "0.11.3"; +callPackage ./generic.nix ( + args + // rec { + version = "0.11.3"; - src = fetchurl { - url = "http://downloads.xiph.org/releases/celt/celt-${version}.tar.gz"; - sha256 = "0dh893wqbh0q4a0x1xyqryykmnhpv7mkblpch019s04a99fq2r3y"; - }; -}) + src = fetchurl { + url = "http://downloads.xiph.org/releases/celt/celt-${version}.tar.gz"; + sha256 = "0dh893wqbh0q4a0x1xyqryykmnhpv7mkblpch019s04a99fq2r3y"; + }; + } +) diff --git a/pkgs/development/libraries/celt/generic.nix b/pkgs/development/libraries/celt/generic.nix index 1ddc016d66b1c2..46a92edc2f7628 100644 --- a/pkgs/development/libraries/celt/generic.nix +++ b/pkgs/development/libraries/celt/generic.nix @@ -1,7 +1,12 @@ -{ lib, stdenv, version, src -, liboggSupport ? true, libogg ? null # if disabled only the library will be built -, prePatch ? "" -, ... +{ + lib, + stdenv, + version, + src, + liboggSupport ? true, + libogg ? null, # if disabled only the library will be built + prePatch ? "", + ... }: # The celt codec has been deprecated and is now a part of the opus codec @@ -12,20 +17,25 @@ stdenv.mkDerivation { inherit src; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; inherit prePatch; - buildInputs = [] - ++ lib.optional liboggSupport libogg; + buildInputs = [ ] ++ lib.optional liboggSupport libogg; doCheck = false; # fails meta = with lib; { description = "Ultra-low delay audio codec"; - homepage = "https://gitlab.xiph.org/xiph/celt"; # http://www.celt-codec.org/ is gone - license = licenses.bsd2; - maintainers = with maintainers; [ codyopel raskin ]; - platforms = platforms.unix; + homepage = "https://gitlab.xiph.org/xiph/celt"; # http://www.celt-codec.org/ is gone + license = licenses.bsd2; + maintainers = with maintainers; [ + codyopel + raskin + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/ceres-solver/default.nix b/pkgs/development/libraries/ceres-solver/default.nix index da5afde02627a9..4917724278c385 100644 --- a/pkgs/development/libraries/ceres-solver/default.nix +++ b/pkgs/development/libraries/ceres-solver/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, blas -, cmake -, eigen -, gflags -, glog -, suitesparse -, metis -, runTests ? false -, enableStatic ? stdenv.hostPlatform.isStatic -, withBlas ? true +{ + lib, + stdenv, + fetchurl, + blas, + cmake, + eigen, + gflags, + glog, + suitesparse, + metis, + runTests ? false, + enableStatic ? stdenv.hostPlatform.isStatic, + withBlas ? true, }: # gflags is required to run tests @@ -25,12 +26,23 @@ stdenv.mkDerivation rec { sha256 = "sha256-99dO7N4K7XW/xR7EjJHQH+Fqa/FrzhmHpwcyhnAeL8Y="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake ]; buildInputs = lib.optional runTests gflags; - propagatedBuildInputs = [ eigen glog ] - ++ lib.optionals withBlas [ blas suitesparse metis ]; + propagatedBuildInputs = + [ + eigen + glog + ] + ++ lib.optionals withBlas [ + blas + suitesparse + metis + ]; cmakeFlags = [ "-DBUILD_SHARED_LIBS=${if enableStatic then "OFF" else "ON"}" diff --git a/pkgs/development/libraries/check/default.nix b/pkgs/development/libraries/check/default.nix index 82aca7c4ec0138..e8ea400c958b86 100644 --- a/pkgs/development/libraries/check/default.nix +++ b/pkgs/development/libraries/check/default.nix @@ -1,5 +1,8 @@ -{ fetchurl, lib, stdenv -, CoreServices +{ + fetchurl, + lib, + stdenv, + CoreServices, }: stdenv.mkDerivation rec { @@ -12,7 +15,9 @@ stdenv.mkDerivation rec { }; # fortify breaks the libcompat vsnprintf implementation - hardeningDisable = lib.optionals (stdenv.hostPlatform.isMusl && (stdenv.hostPlatform != stdenv.buildPlatform)) [ "fortify" ]; + hardeningDisable = lib.optionals ( + stdenv.hostPlatform.isMusl && (stdenv.hostPlatform != stdenv.buildPlatform) + ) [ "fortify" ]; # Test can randomly fail: https://hydra.nixos.org/build/7243912 doCheck = false; diff --git a/pkgs/development/libraries/clucene-core/2.x.nix b/pkgs/development/libraries/clucene-core/2.x.nix index 6fc4ac289677ae..f24d0f36400a5a 100644 --- a/pkgs/development/libraries/clucene-core/2.x.nix +++ b/pkgs/development/libraries/clucene-core/2.x.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchurl, fetchpatch, cmake, boost, zlib}: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + cmake, + boost, + zlib, +}: stdenv.mkDerivation rec { pname = "clucene-core"; @@ -11,44 +19,51 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ boost zlib ]; - - cmakeFlags = [ - "-DBUILD_CONTRIBS=ON" - "-DBUILD_CONTRIBS_LIB=ON" - "-DCMAKE_BUILD_WITH_INSTALL_NAME_DIR=ON" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "-D_CL_HAVE_GCC_ATOMIC_FUNCTIONS=0" - "-D_CL_HAVE_NAMESPACES_EXITCODE=0" - "-D_CL_HAVE_NAMESPACES_EXITCODE__TRYRUN_OUTPUT=" - "-D_CL_HAVE_NO_SNPRINTF_BUG_EXITCODE=0" - "-D_CL_HAVE_NO_SNPRINTF_BUG_EXITCODE__TRYRUN_OUTPUT=" - "-D_CL_HAVE_TRY_BLOCKS_EXITCODE=0" - "-D_CL_HAVE_TRY_BLOCKS_EXITCODE__TRYRUN_OUTPUT=" - "-D_CL_HAVE_PTHREAD_MUTEX_RECURSIVE=0" - "-DLUCENE_STATIC_CONSTANT_SYNTAX_EXITCODE=0" - "-DLUCENE_STATIC_CONSTANT_SYNTAX_EXITCODE__TRYRUN_OUTPUT=" + buildInputs = [ + boost + zlib ]; - patches = [ - # From debian - ./Fix-pkgconfig-file-by-adding-clucene-shared-library.patch - ./Fixing_ZLIB_configuration_in_shared_CMakeLists.patch - ./Install-contribs-lib.patch - # From arch - ./fix-missing-include-time.patch + cmakeFlags = + [ + "-DBUILD_CONTRIBS=ON" + "-DBUILD_CONTRIBS_LIB=ON" + "-DCMAKE_BUILD_WITH_INSTALL_NAME_DIR=ON" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "-D_CL_HAVE_GCC_ATOMIC_FUNCTIONS=0" + "-D_CL_HAVE_NAMESPACES_EXITCODE=0" + "-D_CL_HAVE_NAMESPACES_EXITCODE__TRYRUN_OUTPUT=" + "-D_CL_HAVE_NO_SNPRINTF_BUG_EXITCODE=0" + "-D_CL_HAVE_NO_SNPRINTF_BUG_EXITCODE__TRYRUN_OUTPUT=" + "-D_CL_HAVE_TRY_BLOCKS_EXITCODE=0" + "-D_CL_HAVE_TRY_BLOCKS_EXITCODE__TRYRUN_OUTPUT=" + "-D_CL_HAVE_PTHREAD_MUTEX_RECURSIVE=0" + "-DLUCENE_STATIC_CONSTANT_SYNTAX_EXITCODE=0" + "-DLUCENE_STATIC_CONSTANT_SYNTAX_EXITCODE__TRYRUN_OUTPUT=" + ]; - # required for darwin and linux-musl - ./pthread-include.patch - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ./fix-darwin.patch + patches = + [ + # From debian + ./Fix-pkgconfig-file-by-adding-clucene-shared-library.patch + ./Fixing_ZLIB_configuration_in_shared_CMakeLists.patch + ./Install-contribs-lib.patch + # From arch + ./fix-missing-include-time.patch - # see https://bugs.gentoo.org/869170 - (fetchpatch { - url = "https://869170.bugs.gentoo.org/attachment.cgi?id=858825"; - hash = "sha256-TbAfBKdXh+1HepZc8J6OhK1XGwhwBCMvO8QBDsad998="; - }) - ]; + # required for darwin and linux-musl + ./pthread-include.patch + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ./fix-darwin.patch + + # see https://bugs.gentoo.org/869170 + (fetchpatch { + url = "https://869170.bugs.gentoo.org/attachment.cgi?id=858825"; + hash = "sha256-TbAfBKdXh+1HepZc8J6OhK1XGwhwBCMvO8QBDsad998="; + }) + ]; # see https://github.com/macports/macports-ports/commit/236d43f2450c6be52dc42fd3a2bbabbaa5136201 postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' @@ -76,6 +91,9 @@ stdenv.mkDerivation rec { ''; homepage = "https://clucene.sourceforge.net"; platforms = platforms.unix; - license = with licenses; [ asl20 lgpl2 ]; + license = with licenses; [ + asl20 + lgpl2 + ]; }; } diff --git a/pkgs/development/libraries/clutter-gst/default.nix b/pkgs/development/libraries/clutter-gst/default.nix index e741893168a937..11cdf0b4f7fddf 100644 --- a/pkgs/development/libraries/clutter-gst/default.nix +++ b/pkgs/development/libraries/clutter-gst/default.nix @@ -1,10 +1,26 @@ -{ fetchurl, fetchpatch, lib, stdenv, pkg-config, clutter, gtk3, glib, cogl, gnome, gdk-pixbuf, gobject-introspection }: +{ + fetchurl, + fetchpatch, + lib, + stdenv, + pkg-config, + clutter, + gtk3, + glib, + cogl, + gnome, + gdk-pixbuf, + gobject-introspection, +}: stdenv.mkDerivation rec { pname = "clutter-gst"; version = "3.0.27"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -22,8 +38,18 @@ stdenv.mkDerivation rec { ]; strictDeps = true; - nativeBuildInputs = [ pkg-config glib gobject-introspection ]; - propagatedBuildInputs = [ clutter gtk3 glib cogl gdk-pixbuf ]; + nativeBuildInputs = [ + pkg-config + glib + gobject-introspection + ]; + propagatedBuildInputs = [ + clutter + gtk3 + glib + cogl + gdk-pixbuf + ]; postBuild = "rm -rf $out/share/gtk-doc"; diff --git a/pkgs/development/libraries/cogl/default.nix b/pkgs/development/libraries/cogl/default.nix index db34dc1669b18d..be83ec2d8ac922 100644 --- a/pkgs/development/libraries/cogl/default.nix +++ b/pkgs/development/libraries/cogl/default.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, libGL -, glib -, gdk-pixbuf -, xorg -, libintl -, pangoSupport ? true -, pango -, cairo -, gobject-introspection -, wayland -, gnome -, mesa -, automake -, autoconf -, gstreamerSupport ? true -, gst_all_1 -, harfbuzz -, OpenGL +{ + lib, + stdenv, + fetchurl, + pkg-config, + libGL, + glib, + gdk-pixbuf, + xorg, + libintl, + pangoSupport ? true, + pango, + cairo, + gobject-introspection, + wayland, + gnome, + mesa, + automake, + autoconf, + gstreamerSupport ? true, + gst_all_1, + harfbuzz, + OpenGL, }: stdenv.mkDerivation rec { @@ -40,59 +41,84 @@ stdenv.mkDerivation rec { ./patches/gnome_bugzilla_787443_361056_deepin.patch ]; - outputs = [ "out" "dev" ]; - - nativeBuildInputs = [ pkg-config libintl automake autoconf gobject-introspection ]; + outputs = [ + "out" + "dev" + ]; - configureFlags = [ - "--enable-introspection" - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - "--enable-kms-egl-platform" - "--enable-wayland-egl-platform" - "--enable-wayland-egl-server" - "--enable-gles1" - "--enable-gles2" - # Force linking against libGL. - # Otherwise, it tries to load it from the runtime library path. - "LIBS=-lGL" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "--disable-glx" - "--without-x" - ] ++ lib.optionals gstreamerSupport [ - "--enable-cogl-gst" + nativeBuildInputs = [ + pkg-config + libintl + automake + autoconf + gobject-introspection ]; + configureFlags = + [ + "--enable-introspection" + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + "--enable-kms-egl-platform" + "--enable-wayland-egl-platform" + "--enable-wayland-egl-server" + "--enable-gles1" + "--enable-gles2" + # Force linking against libGL. + # Otherwise, it tries to load it from the runtime library path. + "LIBS=-lGL" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "--disable-glx" + "--without-x" + ] + ++ lib.optionals gstreamerSupport [ + "--enable-cogl-gst" + ]; + # TODO: this shouldn't propagate so many things # especially not gobject-introspection - propagatedBuildInputs = [ - glib - gdk-pixbuf - gobject-introspection - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - wayland - mesa - libGL - xorg.libXrandr - xorg.libXfixes - xorg.libXcomposite - xorg.libXdamage - ] ++ lib.optionals gstreamerSupport [ - gst_all_1.gstreamer - gst_all_1.gst-plugins-base - ]; + propagatedBuildInputs = + [ + glib + gdk-pixbuf + gobject-introspection + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + wayland + mesa + libGL + xorg.libXrandr + xorg.libXfixes + xorg.libXcomposite + xorg.libXdamage + ] + ++ lib.optionals gstreamerSupport [ + gst_all_1.gstreamer + gst_all_1.gst-plugins-base + ]; - buildInputs = lib.optionals pangoSupport [ pango cairo harfbuzz ] + buildInputs = + lib.optionals pangoSupport [ + pango + cairo + harfbuzz + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ OpenGL ]; - env = { - COGL_PANGO_DEP_CFLAGS = toString (lib.optionals (stdenv.hostPlatform.isDarwin && pangoSupport) [ - "-I${pango.dev}/include/pango-1.0" - "-I${cairo.dev}/include/cairo" - "-I${harfbuzz.dev}/include/harfbuzz" - ]); - } // lib.optionalAttrs stdenv.cc.isClang { - NIX_CFLAGS_COMPILE = "-Wno-error=implicit-function-declaration"; - }; + env = + { + COGL_PANGO_DEP_CFLAGS = toString ( + lib.optionals (stdenv.hostPlatform.isDarwin && pangoSupport) [ + "-I${pango.dev}/include/pango-1.0" + "-I${cairo.dev}/include/cairo" + "-I${harfbuzz.dev}/include/harfbuzz" + ] + ); + } + // lib.optionalAttrs stdenv.cc.isClang { + NIX_CFLAGS_COMPILE = "-Wno-error=implicit-function-declaration"; + }; #doCheck = true; # all tests fail (no idea why) @@ -115,6 +141,11 @@ stdenv.mkDerivation rec { ''; platforms = platforms.unix; - license = with licenses; [ mit bsd3 publicDomain sgi-b-20 ]; + license = with licenses; [ + mit + bsd3 + publicDomain + sgi-b-20 + ]; }; } diff --git a/pkgs/development/libraries/ctranslate2/default.nix b/pkgs/development/libraries/ctranslate2/default.nix index 6d287b869ff323..2422540de7ff46 100644 --- a/pkgs/development/libraries/ctranslate2/default.nix +++ b/pkgs/development/libraries/ctranslate2/default.nix @@ -1,22 +1,26 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, darwin # Accelerate -, llvmPackages # openmp -, withMkl ? false, mkl -, withCUDA ? false -, withCuDNN ? false -, cudaPackages -# Enabling both withOneDNN and withOpenblas is broken -# https://github.com/OpenNMT/CTranslate2/issues/1294 -, withOneDNN ? false, oneDNN -, withOpenblas ? true, openblas -, withRuy ? true +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + darwin, # Accelerate + llvmPackages, # openmp + withMkl ? false, + mkl, + withCUDA ? false, + withCuDNN ? false, + cudaPackages, + # Enabling both withOneDNN and withOpenblas is broken + # https://github.com/OpenNMT/CTranslate2/issues/1294 + withOneDNN ? false, + oneDNN, + withOpenblas ? true, + openblas, + withRuy ? true, -# passthru tests -, libretranslate -, wyoming-faster-whisper + # passthru tests + libretranslate, + wyoming-faster-whisper, }: let @@ -34,11 +38,13 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ - cmake - ] ++ lib.optionals withCUDA [ - cudaPackages.cuda_nvcc - ]; + nativeBuildInputs = + [ + cmake + ] + ++ lib.optionals withCUDA [ + cudaPackages.cuda_nvcc + ]; cmakeFlags = [ # https://opennmt.net/CTranslate2/installation.html#build-options @@ -51,35 +57,41 @@ stdenv.mkDerivation rec { "-DWITH_OPENBLAS=${cmakeBool withOpenblas}" "-DWITH_RUY=${cmakeBool withRuy}" "-DWITH_MKL=${cmakeBool withMkl}" - ] - ++ lib.optional stdenv.hostPlatform.isDarwin "-DWITH_ACCELERATE=ON"; + ] ++ lib.optional stdenv.hostPlatform.isDarwin "-DWITH_ACCELERATE=ON"; - buildInputs = lib.optionals withMkl [ - mkl - ] ++ lib.optionals withCUDA [ - cudaPackages.cuda_cccl # required by the fp16 headers in cudart - cudaPackages.cuda_cudart - cudaPackages.libcublas - cudaPackages.libcurand - ] ++ lib.optionals (withCUDA && withCuDNN) [ - cudaPackages.cudnn - ] ++ lib.optionals withOneDNN [ - oneDNN - ] ++ lib.optionals withOpenblas [ - openblas - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - llvmPackages.openmp - darwin.apple_sdk.frameworks.Accelerate - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ - darwin.apple_sdk.frameworks.CoreGraphics - darwin.apple_sdk.frameworks.CoreVideo - ]; + buildInputs = + lib.optionals withMkl [ + mkl + ] + ++ lib.optionals withCUDA [ + cudaPackages.cuda_cccl # required by the fp16 headers in cudart + cudaPackages.cuda_cudart + cudaPackages.libcublas + cudaPackages.libcurand + ] + ++ lib.optionals (withCUDA && withCuDNN) [ + cudaPackages.cudnn + ] + ++ lib.optionals withOneDNN [ + oneDNN + ] + ++ lib.optionals withOpenblas [ + openblas + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + llvmPackages.openmp + darwin.apple_sdk.frameworks.Accelerate + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + darwin.apple_sdk.frameworks.CoreGraphics + darwin.apple_sdk.frameworks.CoreVideo + ]; passthru.tests = { inherit libretranslate wyoming-faster-whisper - ; + ; }; meta = with lib; { @@ -88,9 +100,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/OpenNMT/CTranslate2"; changelog = "https://github.com/OpenNMT/CTranslate2/blob/${src.rev}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ hexa misuzu ]; - broken = - (lib.versionOlder cudaPackages.cudaVersion "11.4") - || !(withCuDNN -> withCUDA); + maintainers = with maintainers; [ + hexa + misuzu + ]; + broken = (lib.versionOlder cudaPackages.cudaVersion "11.4") || !(withCuDNN -> withCUDA); }; } diff --git a/pkgs/development/libraries/cxxtest/default.nix b/pkgs/development/libraries/cxxtest/default.nix index 545aa4bc0e0c15..ae1e9c302000d0 100644 --- a/pkgs/development/libraries/cxxtest/default.nix +++ b/pkgs/development/libraries/cxxtest/default.nix @@ -1,4 +1,8 @@ -{ lib, python3Packages, fetchFromGitHub }: +{ + lib, + python3Packages, + fetchFromGitHub, +}: python3Packages.buildPythonApplication rec { pname = "cxxtest"; diff --git a/pkgs/development/libraries/db/db-4.8.nix b/pkgs/development/libraries/db/db-4.8.nix index 81705374381e7d..b91ec5dd5b6a1d 100644 --- a/pkgs/development/libraries/db/db-4.8.nix +++ b/pkgs/development/libraries/db/db-4.8.nix @@ -1,14 +1,23 @@ -{ lib, stdenv, fetchurl, autoreconfHook, ... } @ args: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + ... +}@args: -import ./generic.nix (args // { - version = "4.8.30"; - sha256 = "0ampbl2f0hb1nix195kz1syrqqxpmvnvnfvphambj7xjrl3iljg0"; - extraPatches = [ - ./clang-4.8.patch - ./CVE-2017-10140-4.8-cwd-db_config.patch - ./darwin-mutexes-4.8.patch - ]; +import ./generic.nix ( + args + // { + version = "4.8.30"; + sha256 = "0ampbl2f0hb1nix195kz1syrqqxpmvnvnfvphambj7xjrl3iljg0"; + extraPatches = [ + ./clang-4.8.patch + ./CVE-2017-10140-4.8-cwd-db_config.patch + ./darwin-mutexes-4.8.patch + ]; - drvArgs.hardeningDisable = [ "format" ]; - drvArgs.doCheck = false; -}) + drvArgs.hardeningDisable = [ "format" ]; + drvArgs.doCheck = false; + } +) diff --git a/pkgs/development/libraries/db/db-5.3.nix b/pkgs/development/libraries/db/db-5.3.nix index 2362cc9eecb0d1..77e9a1a04269ce 100644 --- a/pkgs/development/libraries/db/db-5.3.nix +++ b/pkgs/development/libraries/db/db-5.3.nix @@ -1,11 +1,20 @@ -{ lib, stdenv, fetchurl, autoreconfHook, ... } @ args: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + ... +}@args: -import ./generic.nix (args // { - version = "5.3.28"; - sha256 = "0a1n5hbl7027fbz5lm0vp0zzfp1hmxnz14wx3zl9563h83br5ag0"; - extraPatches = [ - ./clang-5.3.patch - ./CVE-2017-10140-cwd-db_config.patch - ./darwin-mutexes.patch - ]; -}) +import ./generic.nix ( + args + // { + version = "5.3.28"; + sha256 = "0a1n5hbl7027fbz5lm0vp0zzfp1hmxnz14wx3zl9563h83br5ag0"; + extraPatches = [ + ./clang-5.3.patch + ./CVE-2017-10140-cwd-db_config.patch + ./darwin-mutexes.patch + ]; + } +) diff --git a/pkgs/development/libraries/db/db-6.0.nix b/pkgs/development/libraries/db/db-6.0.nix index d92d28d094e613..f720ca18063929 100644 --- a/pkgs/development/libraries/db/db-6.0.nix +++ b/pkgs/development/libraries/db/db-6.0.nix @@ -1,12 +1,21 @@ -{ lib, stdenv, fetchurl, autoreconfHook, ... } @ args: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + ... +}@args: -import ./generic.nix (args // { - version = "6.0.30"; - sha256 = "1lhglbvg65j5slrlv7qv4vi3cvd7kjywa07gq1abzschycf4p3k0"; - license = lib.licenses.agpl3Only; - extraPatches = [ - ./clang-6.0.patch - ./CVE-2017-10140-cwd-db_config.patch - ./darwin-mutexes.patch - ]; -}) +import ./generic.nix ( + args + // { + version = "6.0.30"; + sha256 = "1lhglbvg65j5slrlv7qv4vi3cvd7kjywa07gq1abzschycf4p3k0"; + license = lib.licenses.agpl3Only; + extraPatches = [ + ./clang-6.0.patch + ./CVE-2017-10140-cwd-db_config.patch + ./darwin-mutexes.patch + ]; + } +) diff --git a/pkgs/development/libraries/db/db-6.2.nix b/pkgs/development/libraries/db/db-6.2.nix index fd5a53253522f4..2f573aaca1e9cd 100644 --- a/pkgs/development/libraries/db/db-6.2.nix +++ b/pkgs/development/libraries/db/db-6.2.nix @@ -1,12 +1,21 @@ -{ lib, stdenv, fetchurl, autoreconfHook, ... } @ args: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + ... +}@args: -import ./generic.nix (args // { - version = "6.2.32"; - sha256 = "1yx8wzhch5wwh016nh0kfxvknjkafv6ybkqh6nh7lxx50jqf5id9"; - license = lib.licenses.agpl3Only; - extraPatches = [ - ./clang-6.0.patch - ./CVE-2017-10140-cwd-db_config.patch - ./darwin-mutexes.patch - ]; -}) +import ./generic.nix ( + args + // { + version = "6.2.32"; + sha256 = "1yx8wzhch5wwh016nh0kfxvknjkafv6ybkqh6nh7lxx50jqf5id9"; + license = lib.licenses.agpl3Only; + extraPatches = [ + ./clang-6.0.patch + ./CVE-2017-10140-cwd-db_config.patch + ./darwin-mutexes.patch + ]; + } +) diff --git a/pkgs/development/libraries/db/generic.nix b/pkgs/development/libraries/db/generic.nix index 936aed633a4495..cc91c7e3604949 100644 --- a/pkgs/development/libraries/db/generic.nix +++ b/pkgs/development/libraries/db/generic.nix @@ -1,95 +1,111 @@ -{ lib, stdenv, fetchurl, autoreconfHook -, cxxSupport ? true -, compat185 ? true -, dbmSupport ? false - -# Options from inherited versions -, version, sha256 -, extraPatches ? [ ] -, license ? lib.licenses.sleepycat -, drvArgs ? {} +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + cxxSupport ? true, + compat185 ? true, + dbmSupport ? false, + + # Options from inherited versions + version, + sha256, + extraPatches ? [ ], + license ? lib.licenses.sleepycat, + drvArgs ? { }, }: -stdenv.mkDerivation (rec { - pname = "db"; - inherit version; - - src = fetchurl { - url = "https://download.oracle.com/berkeley-db/${pname}-${version}.tar.gz"; - sha256 = sha256; - }; - - # The provided configure script features `main` returning implicit `int`, which causes - # configure checks to work incorrectly with clang 16. - nativeBuildInputs = [ autoreconfHook ]; - - patches = extraPatches; - - outputs = [ "bin" "out" "dev" ]; - - # Required when regenerated the configure script to make sure the vendored macros are found. - autoreconfFlags = [ "-fi" "-Iaclocal" "-Iaclocal_java" ]; - - preAutoreconf = '' - pushd dist - # Upstream’s `dist/s_config` cats everything into `aclocal.m4`, but that doesn’t work with - # autoreconfHook, so cat `config.m4` to another file. Otherwise, it won’t be found by `aclocal`. - cat aclocal/config.m4 >> aclocal/options.m4 - ''; - - # This isn’t pretty. The version information is kept separate from the configure script. - # After the configure script is regenerated, the version information has to be replaced with the - # contents of `dist/RELEASE`. - postAutoreconf = '' - ( - declare -a vars=( - "DB_VERSION_FAMILY" - "DB_VERSION_RELEASE" - "DB_VERSION_MAJOR" - "DB_VERSION_MINOR" - "DB_VERSION_PATCH" - "DB_VERSION_STRING" - "DB_VERSION_FULL_STRING" - "DB_VERSION_UNIQUE_NAME" - "DB_VERSION" +stdenv.mkDerivation ( + rec { + pname = "db"; + inherit version; + + src = fetchurl { + url = "https://download.oracle.com/berkeley-db/${pname}-${version}.tar.gz"; + sha256 = sha256; + }; + + # The provided configure script features `main` returning implicit `int`, which causes + # configure checks to work incorrectly with clang 16. + nativeBuildInputs = [ autoreconfHook ]; + + patches = extraPatches; + + outputs = [ + "bin" + "out" + "dev" + ]; + + # Required when regenerated the configure script to make sure the vendored macros are found. + autoreconfFlags = [ + "-fi" + "-Iaclocal" + "-Iaclocal_java" + ]; + + preAutoreconf = '' + pushd dist + # Upstream’s `dist/s_config` cats everything into `aclocal.m4`, but that doesn’t work with + # autoreconfHook, so cat `config.m4` to another file. Otherwise, it won’t be found by `aclocal`. + cat aclocal/config.m4 >> aclocal/options.m4 + ''; + + # This isn’t pretty. The version information is kept separate from the configure script. + # After the configure script is regenerated, the version information has to be replaced with the + # contents of `dist/RELEASE`. + postAutoreconf = '' + ( + declare -a vars=( + "DB_VERSION_FAMILY" + "DB_VERSION_RELEASE" + "DB_VERSION_MAJOR" + "DB_VERSION_MINOR" + "DB_VERSION_PATCH" + "DB_VERSION_STRING" + "DB_VERSION_FULL_STRING" + "DB_VERSION_UNIQUE_NAME" + "DB_VERSION" + ) + source RELEASE + for var in "''${vars[@]}"; do + sed -e "s/__EDIT_''${var}__/''${!var}/g" -i configure + done ) - source RELEASE - for var in "''${vars[@]}"; do - sed -e "s/__EDIT_''${var}__/''${!var}/g" -i configure - done - ) - popd - ''; - - configureFlags = - [ - (if cxxSupport then "--enable-cxx" else "--disable-cxx") - (if compat185 then "--enable-compat185" else "--disable-compat185") - ] - ++ lib.optional dbmSupport "--enable-dbm" - ++ lib.optional stdenv.hostPlatform.isFreeBSD "--with-pic"; - - preConfigure = '' - cd build_unix - configureScript=../dist/configure - ''; - - postInstall = '' - rm -rf $out/docs - ''; - - enableParallelBuilding = true; - - doCheck = true; - - checkPhase = '' - make examples_c examples_cxx - ''; - - meta = with lib; { - homepage = "https://www.oracle.com/database/technologies/related/berkeleydb.html"; - description = "Berkeley DB"; - license = license; - platforms = platforms.unix; - }; -} // drvArgs) + popd + ''; + + configureFlags = + [ + (if cxxSupport then "--enable-cxx" else "--disable-cxx") + (if compat185 then "--enable-compat185" else "--disable-compat185") + ] + ++ lib.optional dbmSupport "--enable-dbm" + ++ lib.optional stdenv.hostPlatform.isFreeBSD "--with-pic"; + + preConfigure = '' + cd build_unix + configureScript=../dist/configure + ''; + + postInstall = '' + rm -rf $out/docs + ''; + + enableParallelBuilding = true; + + doCheck = true; + + checkPhase = '' + make examples_c examples_cxx + ''; + + meta = with lib; { + homepage = "https://www.oracle.com/database/technologies/related/berkeleydb.html"; + description = "Berkeley DB"; + license = license; + platforms = platforms.unix; + }; + } + // drvArgs +) diff --git a/pkgs/development/libraries/dbus-sharp-glib/dbus-sharp-glib-1.0.nix b/pkgs/development/libraries/dbus-sharp-glib/dbus-sharp-glib-1.0.nix index f47c91ca3eafec..f5cad9f4bf7af3 100644 --- a/pkgs/development/libraries/dbus-sharp-glib/dbus-sharp-glib-1.0.nix +++ b/pkgs/development/libraries/dbus-sharp-glib/dbus-sharp-glib-1.0.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, mono, dbus-sharp-1_0 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + mono, + dbus-sharp-1_0, +}: stdenv.mkDerivation rec { pname = "dbus-sharp-glib"; @@ -12,8 +20,14 @@ stdenv.mkDerivation rec { sha256 = "0z8ylzby8n5sar7aywc8rngd9ap5qqznadsscp5v34cacdfz1gxm"; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ mono dbus-sharp-1_0 ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + mono + dbus-sharp-1_0 + ]; dontStrip = true; diff --git a/pkgs/development/libraries/dbus-sharp-glib/default.nix b/pkgs/development/libraries/dbus-sharp-glib/default.nix index 65cd890436638c..9e5762e6cd526b 100644 --- a/pkgs/development/libraries/dbus-sharp-glib/default.nix +++ b/pkgs/development/libraries/dbus-sharp-glib/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, mono, dbus-sharp-2_0, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + mono, + dbus-sharp-2_0, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "dbus-sharp-glib"; @@ -12,8 +20,14 @@ stdenv.mkDerivation rec { sha256 = "0i39kfg731as6j0hlmasgj8dyw5xsak7rl2dlimi1naphhffwzm8"; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ mono dbus-sharp-2_0 ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = [ + mono + dbus-sharp-2_0 + ]; dontStrip = true; diff --git a/pkgs/development/libraries/dbus-sharp/dbus-sharp-1.0.nix b/pkgs/development/libraries/dbus-sharp/dbus-sharp-1.0.nix index eb1b20e29eb102..55a9ddbc727c2f 100644 --- a/pkgs/development/libraries/dbus-sharp/dbus-sharp-1.0.nix +++ b/pkgs/development/libraries/dbus-sharp/dbus-sharp-1.0.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchFromGitHub, pkg-config, mono, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + mono, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "dbus-sharp"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "13qlqx9wqahfpzzl59157cjxprqcx2bd40w5gb2bs3vdx058p562"; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; buildInputs = [ mono ]; dontStrip = true; diff --git a/pkgs/development/libraries/dbus-sharp/default.nix b/pkgs/development/libraries/dbus-sharp/default.nix index c64d7bbef9922a..ba20951653eb23 100644 --- a/pkgs/development/libraries/dbus-sharp/default.nix +++ b/pkgs/development/libraries/dbus-sharp/default.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchFromGitHub, pkg-config, mono4, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + mono4, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "dbus-sharp"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "1g5lblrvkd0wnhfzp326by6n3a9mj2bj7a7646g0ziwgsxp5w6y7"; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; # Use msbuild when https://github.com/NixOS/nixpkgs/pull/43680 is merged # See: https://github.com/NixOS/nixpkgs/pull/46060 diff --git a/pkgs/development/libraries/dbus/default.nix b/pkgs/development/libraries/dbus/default.nix index 017c83c5b11d8b..7170dd4dcdbd7c 100644 --- a/pkgs/development/libraries/dbus/default.nix +++ b/pkgs/development/libraries/dbus/default.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, expat -, enableSystemd ? lib.meta.availableOn stdenv.hostPlatform systemdMinimal -, systemdMinimal -, audit -, libapparmor -, dbus -, docbook_xml_dtd_44 -, docbook-xsl-nons -, xmlto -, autoreconfHook -, autoconf-archive -, x11Support ? (stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isDarwin) -, xorg +{ + stdenv, + lib, + fetchurl, + pkg-config, + expat, + enableSystemd ? lib.meta.availableOn stdenv.hostPlatform systemdMinimal, + systemdMinimal, + audit, + libapparmor, + dbus, + docbook_xml_dtd_44, + docbook-xsl-nons, + xmlto, + autoreconfHook, + autoconf-archive, + x11Support ? (stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isDarwin), + xorg, }: stdenv.mkDerivation rec { @@ -28,21 +29,30 @@ stdenv.mkDerivation rec { patches = lib.optional stdenv.hostPlatform.isSunOS ./implement-getgrouplist.patch; - postPatch = '' - substituteInPlace bus/Makefile.am \ - --replace 'install-data-hook:' 'disabled:' \ - --replace '$(mkinstalldirs) $(DESTDIR)$(localstatedir)/run/dbus' ':' - substituteInPlace tools/Makefile.am \ - --replace 'install-data-local:' 'disabled:' \ - --replace 'installcheck-local:' 'disabled:' - '' + /* cleanup of runtime references */ '' - substituteInPlace ./dbus/dbus-sysdeps-unix.c \ - --replace 'DBUS_BINDIR "/dbus-launch"' "\"$lib/bin/dbus-launch\"" - substituteInPlace ./tools/dbus-launch.c \ - --replace 'DBUS_DAEMONDIR"/dbus-daemon"' '"/run/current-system/sw/bin/dbus-daemon"' - ''; - - outputs = [ "out" "dev" "lib" "doc" "man" ]; + postPatch = + '' + substituteInPlace bus/Makefile.am \ + --replace 'install-data-hook:' 'disabled:' \ + --replace '$(mkinstalldirs) $(DESTDIR)$(localstatedir)/run/dbus' ':' + substituteInPlace tools/Makefile.am \ + --replace 'install-data-local:' 'disabled:' \ + --replace 'installcheck-local:' 'disabled:' + '' + # cleanup of runtime references + + '' + substituteInPlace ./dbus/dbus-sysdeps-unix.c \ + --replace 'DBUS_BINDIR "/dbus-launch"' "\"$lib/bin/dbus-launch\"" + substituteInPlace ./tools/dbus-launch.c \ + --replace 'DBUS_DAEMONDIR"/dbus-daemon"' '"/run/current-system/sw/bin/dbus-daemon"' + ''; + + outputs = [ + "out" + "dev" + "lib" + "doc" + "man" + ]; separateDebugInfo = true; strictDeps = true; @@ -60,32 +70,44 @@ stdenv.mkDerivation rec { ]; buildInputs = - lib.optionals x11Support (with xorg; [ - libX11 - libICE - libSM - ]) ++ lib.optional enableSystemd systemdMinimal - ++ lib.optionals stdenv.hostPlatform.isLinux [ audit libapparmor ]; + lib.optionals x11Support ( + with xorg; + [ + libX11 + libICE + libSM + ] + ) + ++ lib.optional enableSystemd systemdMinimal + ++ lib.optionals stdenv.hostPlatform.isLinux [ + audit + libapparmor + ]; # ToDo: optional selinux? __darwinAllowLocalNetworking = true; - configureFlags = [ - "--enable-user-session" - "--enable-xml-docs" - "--libexecdir=${placeholder "out"}/libexec" - "--datadir=/etc" - "--localstatedir=/var" - "--runstatedir=/run" - "--sysconfdir=/etc" - "--with-session-socket-dir=/tmp" - "--with-system-pid-file=/run/dbus/pid" - "--with-system-socket=/run/dbus/system_bus_socket" - "--with-systemdsystemunitdir=${placeholder "out"}/etc/systemd/system" - "--with-systemduserunitdir=${placeholder "out"}/etc/systemd/user" - ] ++ lib.optional (!x11Support) "--without-x" - ++ lib.optionals stdenv.hostPlatform.isLinux [ "--enable-apparmor" "--enable-libaudit" ] - ++ lib.optionals enableSystemd [ "SYSTEMCTL=${systemdMinimal}/bin/systemctl" ]; + configureFlags = + [ + "--enable-user-session" + "--enable-xml-docs" + "--libexecdir=${placeholder "out"}/libexec" + "--datadir=/etc" + "--localstatedir=/var" + "--runstatedir=/run" + "--sysconfdir=/etc" + "--with-session-socket-dir=/tmp" + "--with-system-pid-file=/run/dbus/pid" + "--with-system-socket=/run/dbus/system_bus_socket" + "--with-systemdsystemunitdir=${placeholder "out"}/etc/systemd/system" + "--with-systemduserunitdir=${placeholder "out"}/etc/systemd/user" + ] + ++ lib.optional (!x11Support) "--without-x" + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "--enable-apparmor" + "--enable-libaudit" + ] + ++ lib.optionals enableSystemd [ "SYSTEMCTL=${systemdMinimal}/bin/systemctl" ]; NIX_CFLAGS_LINK = lib.optionalString (!stdenv.hostPlatform.isDarwin) "-Wl,--as-needed"; diff --git a/pkgs/development/libraries/dbus/make-dbus-conf.nix b/pkgs/development/libraries/dbus/make-dbus-conf.nix index d6e3e86200cf01..1b98e3db037634 100644 --- a/pkgs/development/libraries/dbus/make-dbus-conf.nix +++ b/pkgs/development/libraries/dbus/make-dbus-conf.nix @@ -1,17 +1,19 @@ -{ runCommand -, libxslt -, dbus -, findXMLCatalogs -, serviceDirectories ? [] -, suidHelper ? "/var/setuid-wrappers/dbus-daemon-launch-helper" -, apparmor ? "disabled" # one of enabled, disabled, required +{ + runCommand, + libxslt, + dbus, + findXMLCatalogs, + serviceDirectories ? [ ], + suidHelper ? "/var/setuid-wrappers/dbus-daemon-launch-helper", + apparmor ? "disabled", # one of enabled, disabled, required }: -/* DBus has two configuration parsers -- normal and "trivial", which is used - * for suid helper. Unfortunately the latter doesn't support - * directive. That means that we can't just place our configuration to - * *-local.conf -- it needs to be in the main configuration file. - */ +/* + DBus has two configuration parsers -- normal and "trivial", which is used + for suid helper. Unfortunately the latter doesn't support + directive. That means that we can't just place our configuration to + *-local.conf -- it needs to be in the main configuration file. +*/ runCommand "dbus-1" { inherit serviceDirectories suidHelper apparmor; diff --git a/pkgs/development/libraries/dee/default.nix b/pkgs/development/libraries/dee/default.nix index 14d8247f0a2017..160263e8c4755f 100644 --- a/pkgs/development/libraries/dee/default.nix +++ b/pkgs/development/libraries/dee/default.nix @@ -1,21 +1,27 @@ -{ lib, stdenv -, fetchgit -, fetchpatch -, pkg-config -, glib -, icu -, gobject-introspection -, dbus-glib -, vala -, python3 -, autoreconfHook +{ + lib, + stdenv, + fetchgit, + fetchpatch, + pkg-config, + glib, + icu, + gobject-introspection, + dbus-glib, + vala, + python3, + autoreconfHook, }: stdenv.mkDerivation rec { pname = "dee"; version = "unstable-2017-06-16"; - outputs = [ "out" "dev" "py" ]; + outputs = [ + "out" + "dev" + "py" + ]; src = fetchgit { url = "https://git.launchpad.net/ubuntu/+source/dee"; diff --git a/pkgs/development/libraries/discord-rpc/default.nix b/pkgs/development/libraries/discord-rpc/default.nix index 05837c823c5647..c9c007adb8c69f 100644 --- a/pkgs/development/libraries/discord-rpc/default.nix +++ b/pkgs/development/libraries/discord-rpc/default.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, rapidjson -, AppKit -, buildExamples ? false +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + rapidjson, + AppKit, + buildExamples ? false, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/dotnetfx35/default.nix b/pkgs/development/libraries/dotnetfx35/default.nix index a3045949c6cace..73e6fa003090f1 100644 --- a/pkgs/development/libraries/dotnetfx35/default.nix +++ b/pkgs/development/libraries/dotnetfx35/default.nix @@ -1,4 +1,4 @@ -{stdenv}: +{ stdenv }: let windir = "/cygdrive/c/WINDOWS"; diff --git a/pkgs/development/libraries/dotnetfx40/default.nix b/pkgs/development/libraries/dotnetfx40/default.nix index 379be1bdc26d4b..7ca67f186ac8b9 100644 --- a/pkgs/development/libraries/dotnetfx40/default.nix +++ b/pkgs/development/libraries/dotnetfx40/default.nix @@ -1,4 +1,4 @@ -{stdenv}: +{ stdenv }: let windir = "/cygdrive/c/WINDOWS"; diff --git a/pkgs/development/libraries/draco/default.nix b/pkgs/development/libraries/draco/default.nix index 677c7e636986db..daf0116b06e246 100644 --- a/pkgs/development/libraries/draco/default.nix +++ b/pkgs/development/libraries/draco/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, cmake -, python3 -, gtest -, withAnimation ? true -, withTranscoder ? true -, eigen -, ghc_filesystem -, tinygltf +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + cmake, + python3, + gtest, + withAnimation ? true, + withTranscoder ? true, + eigen, + ghc_filesystem, + tinygltf, }: let @@ -33,22 +34,32 @@ stdenv.mkDerivation (finalAttrs: { --replace "^Clang" "^AppleClang" ''; - buildInputs = [ gtest ] - ++ lib.optionals withTranscoder [ eigen ghc_filesystem tinygltf ]; + buildInputs = + [ gtest ] + ++ lib.optionals withTranscoder [ + eigen + ghc_filesystem + tinygltf + ]; - nativeBuildInputs = [ cmake python3 ]; - - cmakeFlags = [ - "-DDRACO_ANIMATION_ENCODING=${cmakeBool withAnimation}" - "-DDRACO_GOOGLETEST_PATH=${gtest}" - "-DBUILD_SHARED_LIBS=${cmakeBool true}" - "-DDRACO_TRANSCODER_SUPPORTED=${cmakeBool withTranscoder}" - ] ++ lib.optionals withTranscoder [ - "-DDRACO_EIGEN_PATH=${eigen}/include/eigen3" - "-DDRACO_FILESYSTEM_PATH=${ghc_filesystem}" - "-DDRACO_TINYGLTF_PATH=${tinygltf}" + nativeBuildInputs = [ + cmake + python3 ]; + cmakeFlags = + [ + "-DDRACO_ANIMATION_ENCODING=${cmakeBool withAnimation}" + "-DDRACO_GOOGLETEST_PATH=${gtest}" + "-DBUILD_SHARED_LIBS=${cmakeBool true}" + "-DDRACO_TRANSCODER_SUPPORTED=${cmakeBool withTranscoder}" + ] + ++ lib.optionals withTranscoder [ + "-DDRACO_EIGEN_PATH=${eigen}/include/eigen3" + "-DDRACO_FILESYSTEM_PATH=${ghc_filesystem}" + "-DDRACO_TINYGLTF_PATH=${tinygltf}" + ]; + CXXFLAGS = [ # error: expected ')' before 'value' in 'explicit GltfValue(uint8_t value)' "-include cstdint" diff --git a/pkgs/development/libraries/draco/tinygltf.nix b/pkgs/development/libraries/draco/tinygltf.nix index 4f965c65385011..bce14b2d65d093 100644 --- a/pkgs/development/libraries/draco/tinygltf.nix +++ b/pkgs/development/libraries/draco/tinygltf.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, nix-update-script -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + nix-update-script, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/dxflib/default.nix b/pkgs/development/libraries/dxflib/default.nix index a90820c02cb9f9..acee812f5e8baf 100644 --- a/pkgs/development/libraries/dxflib/default.nix +++ b/pkgs/development/libraries/dxflib/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, qmake +{ + lib, + stdenv, + fetchurl, + qmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/eccodes/default.nix b/pkgs/development/libraries/eccodes/default.nix index 3266304366a6c2..969d6abf64ae27 100644 --- a/pkgs/development/libraries/eccodes/default.nix +++ b/pkgs/development/libraries/eccodes/default.nix @@ -1,17 +1,18 @@ -{ fetchurl -, lib -, stdenv -, cmake -, netcdf -, openjpeg -, libaec -, libpng -, gfortran -, perl -, enablePython ? false -, pythonPackages -, enablePosixThreads ? false -, enableOpenMPThreads ? false +{ + fetchurl, + lib, + stdenv, + cmake, + netcdf, + openjpeg, + libaec, + libpng, + gfortran, + perl, + enablePython ? false, + pythonPackages, + enablePosixThreads ? false, + enableOpenMPThreads ? false, }: stdenv.mkDerivation rec { @@ -38,7 +39,11 @@ stdenv.mkDerivation rec { --replace '$'{CMAKE_INSTALL_PREFIX}/'$'{INSTALL_INCLUDE_DIR} '$'{'$'{PROJECT_NAME}_FULL_INSTALL_INCLUDE_DIR} ''; - nativeBuildInputs = [ cmake gfortran perl ]; + nativeBuildInputs = [ + cmake + gfortran + perl + ]; buildInputs = [ netcdf diff --git a/pkgs/development/libraries/eigen/2.0.nix b/pkgs/development/libraries/eigen/2.0.nix index a1633594636757..37f1017a2531d7 100644 --- a/pkgs/development/libraries/eigen/2.0.nix +++ b/pkgs/development/libraries/eigen/2.0.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, cmake }: +{ + lib, + stdenv, + fetchFromGitLab, + cmake, +}: stdenv.mkDerivation rec { pname = "eigen"; @@ -17,7 +22,10 @@ stdenv.mkDerivation rec { homepage = "https://eigen.tuxfamily.org"; description = "C++ template library for linear algebra: vectors, matrices, and related algorithms"; license = licenses.lgpl3Plus; - maintainers = with maintainers; [ sander raskin ]; + maintainers = with maintainers; [ + sander + raskin + ]; platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/eigen/default.nix b/pkgs/development/libraries/eigen/default.nix index 65493e661beb6c..e612add0c7b1e0 100644 --- a/pkgs/development/libraries/eigen/default.nix +++ b/pkgs/development/libraries/eigen/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, cmake +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + cmake, }: stdenv.mkDerivation rec { @@ -40,7 +41,10 @@ stdenv.mkDerivation rec { homepage = "https://eigen.tuxfamily.org"; description = "C++ template library for linear algebra: vectors, matrices, and related algorithms"; license = licenses.lgpl3Plus; - maintainers = with maintainers; [ sander raskin ]; + maintainers = with maintainers; [ + sander + raskin + ]; platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/embree/2.x.nix b/pkgs/development/libraries/embree/2.x.nix index 45f423659195fe..c3a0adf867e9c9 100644 --- a/pkgs/development/libraries/embree/2.x.nix +++ b/pkgs/development/libraries/embree/2.x.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, ispc, tbb, glfw, -openimageio, libjpeg, libpng, libpthreadstubs, libX11 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + ispc, + tbb, + glfw, + openimageio, + libjpeg, + libpng, + libpthreadstubs, + libX11, }: stdenv.mkDerivation { @@ -15,8 +27,20 @@ stdenv.mkDerivation { cmakeFlags = [ "-DEMBREE_TUTORIALS=OFF" ]; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ ispc tbb glfw openimageio libjpeg libpng libX11 libpthreadstubs ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + ispc + tbb + glfw + openimageio + libjpeg + libpng + libX11 + libpthreadstubs + ]; meta = with lib; { description = "High performance ray tracing kernels from Intel"; homepage = "https://embree.github.io/"; diff --git a/pkgs/development/libraries/embree/default.nix b/pkgs/development/libraries/embree/default.nix index f45ea3dc7d3d0a..03f2a348f11d99 100644 --- a/pkgs/development/libraries/embree/default.nix +++ b/pkgs/development/libraries/embree/default.nix @@ -1,5 +1,19 @@ -{ stdenv, lib, fetchFromGitHub, cmake, pkg-config, ispc, tbb, glfw, - openimageio, libjpeg, libpng, libpthreadstubs, libX11, glib }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + ispc, + tbb, + glfw, + openimageio, + libjpeg, + libpng, + libpthreadstubs, + libX11, + glib, +}: stdenv.mkDerivation rec { pname = "embree"; @@ -28,14 +42,28 @@ stdenv.mkDerivation rec { "-DTBB_INCLUDE_DIR=${tbb.dev}/include" ]; - nativeBuildInputs = [ ispc pkg-config cmake ]; - buildInputs = [ tbb glfw openimageio libjpeg libpng libX11 libpthreadstubs ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ glib ]; + nativeBuildInputs = [ + ispc + pkg-config + cmake + ]; + buildInputs = [ + tbb + glfw + openimageio + libjpeg + libpng + libX11 + libpthreadstubs + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ glib ]; meta = with lib; { description = "High performance ray tracing kernels from Intel"; homepage = "https://embree.github.io/"; - maintainers = with maintainers; [ hodapp gebner ]; + maintainers = with maintainers; [ + hodapp + gebner + ]; license = licenses.asl20; platforms = platforms.unix; }; diff --git a/pkgs/development/libraries/enchant/2.x.nix b/pkgs/development/libraries/enchant/2.x.nix index d2f6036437fbe3..99eedc81ebba36 100644 --- a/pkgs/development/libraries/enchant/2.x.nix +++ b/pkgs/development/libraries/enchant/2.x.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchurl -, aspell -, groff -, pkg-config -, glib -, hunspell -, hspell -, nuspell -, unittest-cpp +{ + stdenv, + lib, + fetchurl, + aspell, + groff, + pkg-config, + glib, + hunspell, + hspell, + nuspell, + unittest-cpp, -, withHspell ? true -, withAspell ? true -, withHunspell ? true -, withNuspell ? true -, withAppleSpell ? stdenv.hostPlatform.isDarwin + withHspell ? true, + withAspell ? true, + withHunspell ? true, + withNuspell ? true, + withAppleSpell ? stdenv.hostPlatform.isDarwin, -, Cocoa + Cocoa, }: assert withAppleSpell -> stdenv.hostPlatform.isDarwin; @@ -25,7 +26,10 @@ stdenv.mkDerivation rec { pname = "enchant"; version = "2.6.9"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "https://github.com/rrthomas/${pname}/releases/download/v${version}/${pname}-${version}.tar.gz"; @@ -39,26 +43,32 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - glib - ] ++ lib.optionals withHunspell [ - hunspell - ] ++ lib.optionals withNuspell [ - nuspell - ] ++ lib.optionals withAppleSpell [ - Cocoa - ]; + buildInputs = + [ + glib + ] + ++ lib.optionals withHunspell [ + hunspell + ] + ++ lib.optionals withNuspell [ + nuspell + ] + ++ lib.optionals withAppleSpell [ + Cocoa + ]; checkInputs = [ unittest-cpp ]; # libtool puts these to .la files - propagatedBuildInputs = lib.optionals withHspell [ - hspell - ] ++ lib.optionals withAspell [ - aspell - ]; + propagatedBuildInputs = + lib.optionals withHspell [ + hspell + ] + ++ lib.optionals withAspell [ + aspell + ]; enableParallelBuilding = true; diff --git a/pkgs/development/libraries/farstream/default.nix b/pkgs/development/libraries/farstream/default.nix index 76ed20495725cd..8e589d0ec81d0a 100644 --- a/pkgs/development/libraries/farstream/default.nix +++ b/pkgs/development/libraries/farstream/default.nix @@ -1,24 +1,29 @@ -{ lib, stdenv -, fetchurl -, fetchpatch -, libnice -, pkg-config -, autoreconfHook -, gstreamer -, gst-plugins-base -, gupnp-igd -, gobject-introspection -, gst-plugins-good -, gst-plugins-bad -, gst-libav -, python3 +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libnice, + pkg-config, + autoreconfHook, + gstreamer, + gst-plugins-base, + gupnp-igd, + gobject-introspection, + gst-plugins-good, + gst-plugins-bad, + gst-libav, + python3, }: stdenv.mkDerivation rec { pname = "farstream"; version = "0.2.9"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "https://www.freedesktop.org/software/farstream/releases/farstream/${pname}-${version}.tar.gz"; diff --git a/pkgs/development/libraries/flatbuffers/default.nix b/pkgs/development/libraries/flatbuffers/default.nix index 58ea13a50b92f5..2dfabd5ad64333 100644 --- a/pkgs/development/libraries/flatbuffers/default.nix +++ b/pkgs/development/libraries/flatbuffers/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, }: stdenv.mkDerivation rec { @@ -16,7 +17,10 @@ stdenv.mkDerivation rec { hash = "sha256-uE9CQnhzVgOweYLhWPn2hvzXHyBbFiFVESJ1AEM3BmA="; }; - nativeBuildInputs = [ cmake python3 ]; + nativeBuildInputs = [ + cmake + python3 + ]; cmakeFlags = [ "-DFLATBUFFERS_BUILD_TESTS=${if doCheck then "ON" else "OFF"}" diff --git a/pkgs/development/libraries/flint/3.nix b/pkgs/development/libraries/flint/3.nix index 60321984d31657..2f046777a79452 100644 --- a/pkgs/development/libraries/flint/3.nix +++ b/pkgs/development/libraries/flint/3.nix @@ -1,20 +1,25 @@ -{ lib -, stdenv -, fetchpatch -, fetchurl -, gmp -, mpfr -, ntl -, autoconf -, automake -, gettext -, libtool -, openblas ? null, blas, lapack -, withBlas ? true -, withNtl ? true +{ + lib, + stdenv, + fetchpatch, + fetchurl, + gmp, + mpfr, + ntl, + autoconf, + automake, + gettext, + libtool, + openblas ? null, + blas, + lapack, + withBlas ? true, + withNtl ? true, }: -assert withBlas -> openblas != null && blas.implementation == "openblas" && lapack.implementation == "openblas"; +assert + withBlas + -> openblas != null && blas.implementation == "openblas" && lapack.implementation == "openblas"; stdenv.mkDerivation rec { pname = "flint3"; @@ -43,13 +48,16 @@ stdenv.mkDerivation rec { mpfr ]; - buildInputs = [ - gmp - ] ++ lib.optionals withBlas [ - openblas - ] ++ lib.optionals withNtl [ - ntl - ]; + buildInputs = + [ + gmp + ] + ++ lib.optionals withBlas [ + openblas + ] + ++ lib.optionals withNtl [ + ntl + ]; # We're not using autoreconfHook because flint's bootstrap # script calls autoreconf, among other things. @@ -58,14 +66,17 @@ stdenv.mkDerivation rec { ./bootstrap.sh ''; - configureFlags = [ - "--with-gmp=${gmp}" - "--with-mpfr=${mpfr}" - ] ++ lib.optionals withBlas [ - "--with-blas=${openblas}" - ] ++ lib.optionals withNtl [ - "--with-ntl=${ntl}" - ]; + configureFlags = + [ + "--with-gmp=${gmp}" + "--with-mpfr=${mpfr}" + ] + ++ lib.optionals withBlas [ + "--with-blas=${openblas}" + ] + ++ lib.optionals withNtl [ + "--with-ntl=${ntl}" + ]; enableParallelBuilding = true; diff --git a/pkgs/development/libraries/flint/default.nix b/pkgs/development/libraries/flint/default.nix index eeb928be8710df..daeba161679831 100644 --- a/pkgs/development/libraries/flint/default.nix +++ b/pkgs/development/libraries/flint/default.nix @@ -1,14 +1,19 @@ -{ lib -, stdenv -, fetchurl -, gmp -, mpfr -, ntl -, openblas ? null, blas, lapack -, withBlas ? true +{ + lib, + stdenv, + fetchurl, + gmp, + mpfr, + ntl, + openblas ? null, + blas, + lapack, + withBlas ? true, }: -assert withBlas -> openblas != null && blas.implementation == "openblas" && lapack.implementation == "openblas"; +assert + withBlas + -> openblas != null && blas.implementation == "openblas" && lapack.implementation == "openblas"; stdenv.mkDerivation rec { pname = "flint"; @@ -19,25 +24,29 @@ stdenv.mkDerivation rec { sha256 = "sha256-L8CQ1RAzyTII5sENQGOXpTyYOuU0O5WOsl9ypXpM52o="; }; - buildInputs = [ - gmp - mpfr - ntl - ] ++ lib.optionals withBlas [ - openblas - ]; + buildInputs = + [ + gmp + mpfr + ntl + ] + ++ lib.optionals withBlas [ + openblas + ]; propagatedBuildInputs = [ mpfr # flint.h includes mpfr.h ]; - configureFlags = [ - "--with-gmp=${gmp}" - "--with-mpfr=${mpfr}" - "--with-ntl=${ntl}" - ] ++ lib.optionals withBlas [ - "--with-blas=${openblas}" - ]; + configureFlags = + [ + "--with-gmp=${gmp}" + "--with-mpfr=${mpfr}" + "--with-ntl=${ntl}" + ] + ++ lib.optionals withBlas [ + "--with-blas=${openblas}" + ]; enableParallelBuilding = true; diff --git a/pkgs/development/libraries/fltk/common.nix b/pkgs/development/libraries/fltk/common.nix index 43776d5918b61f..19ac8309833715 100644 --- a/pkgs/development/libraries/fltk/common.nix +++ b/pkgs/development/libraries/fltk/common.nix @@ -1,44 +1,49 @@ -{ version, rev, sha256 }: - -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, zlib -, libjpeg -, libpng -, fontconfig -, freetype -, libX11 -, libXext -, libXinerama -, libXfixes -, libXcursor -, libXft -, libXrender -, ApplicationServices -, Carbon -, Cocoa - -, withGL ? true -, libGL -, libGLU -, glew -, OpenGL - -, withCairo ? true -, cairo - -, withPango ? (lib.strings.versionAtLeast version "1.4" && stdenv.hostPlatform.isLinux) -, pango - -, withDocs ? true -, doxygen -, graphviz - -, withExamples ? (stdenv.buildPlatform == stdenv.hostPlatform) -, withShared ? true +{ + version, + rev, + sha256, +}: + +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + zlib, + libjpeg, + libpng, + fontconfig, + freetype, + libX11, + libXext, + libXinerama, + libXfixes, + libXcursor, + libXft, + libXrender, + ApplicationServices, + Carbon, + Cocoa, + + withGL ? true, + libGL, + libGLU, + glew, + OpenGL, + + withCairo ? true, + cairo, + + withPango ? (lib.strings.versionAtLeast version "1.4" && stdenv.hostPlatform.isLinux), + pango, + + withDocs ? true, + doxygen, + graphviz, + + withExamples ? (stdenv.buildPlatform == stdenv.hostPlatform), + withShared ? true, }: let @@ -54,9 +59,7 @@ stdenv.mkDerivation rec { inherit rev sha256; }; - outputs = [ "out" ] - ++ lib.optional withExamples "bin" - ++ lib.optional withDocs "doc"; + outputs = [ "out" ] ++ lib.optional withExamples "bin" ++ lib.optional withDocs "doc"; # Manually move example & test binaries to $bin to avoid cyclic dependencies on dev binaries outputBin = lib.optionalString withExamples "out"; @@ -69,48 +72,60 @@ stdenv.mkDerivation rec { patchShebangs documentation/make_* ''; - nativeBuildInputs = [ - cmake - pkg-config - ] ++ lib.optionals withDocs [ - doxygen - graphviz - ]; - - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - ApplicationServices - Carbon - ] ++ lib.optionals (withGL && !stdenv.hostPlatform.isDarwin) [ - libGL - libGLU - ] ++ lib.optionals (withExamples && withGL) [ - glew - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - fontconfig - ]; - - propagatedBuildInputs = [ - zlib - libjpeg - libpng - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - freetype - libX11 - libXext - libXinerama - libXfixes - libXcursor - libXft - libXrender - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Cocoa - ] ++ lib.optionals (withGL && stdenv.hostPlatform.isDarwin) [ - OpenGL - ] ++ lib.optionals withCairo [ - cairo - ] ++ lib.optionals withPango [ - pango - ]; + nativeBuildInputs = + [ + cmake + pkg-config + ] + ++ lib.optionals withDocs [ + doxygen + graphviz + ]; + + buildInputs = + lib.optionals stdenv.hostPlatform.isDarwin [ + ApplicationServices + Carbon + ] + ++ lib.optionals (withGL && !stdenv.hostPlatform.isDarwin) [ + libGL + libGLU + ] + ++ lib.optionals (withExamples && withGL) [ + glew + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + fontconfig + ]; + + propagatedBuildInputs = + [ + zlib + libjpeg + libpng + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + freetype + libX11 + libXext + libXinerama + libXfixes + libXcursor + libXft + libXrender + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + ] + ++ lib.optionals (withGL && stdenv.hostPlatform.isDarwin) [ + OpenGL + ] + ++ lib.optionals withCairo [ + cairo + ] + ++ lib.optionals withPango [ + pango + ]; cmakeFlags = [ # Common @@ -162,30 +177,32 @@ stdenv.mkDerivation rec { make docs ''; - postInstall = lib.optionalString withExamples '' - mkdir -p $bin/bin - mv bin/{test,examples}/* $bin/bin/ - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/Library/Frameworks - mv $out{,/Library/Frameworks}/FLTK.framework - - moveAppBundles() { - echo "Moving and symlinking $1" - appname="$(basename "$1")" - binname="$(basename "$(find "$1"/Contents/MacOS/ -type f -executable | head -n1)")" - curpath="$(dirname "$1")" - - mkdir -p "$curpath"/../Applications/ - mv "$1" "$curpath"/../Applications/ - [ -f "$curpath"/"$binname" ] && rm "$curpath"/"$binname" - ln -s ../Applications/"$appname"/Contents/MacOS/"$binname" "$curpath"/"$binname" - } - - rm $out/bin/fluid.icns - for app in $out/bin/*.app ${lib.optionalString withExamples "$bin/bin/*.app"}; do - moveAppBundles "$app" - done - ''; + postInstall = + lib.optionalString withExamples '' + mkdir -p $bin/bin + mv bin/{test,examples}/* $bin/bin/ + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/Library/Frameworks + mv $out{,/Library/Frameworks}/FLTK.framework + + moveAppBundles() { + echo "Moving and symlinking $1" + appname="$(basename "$1")" + binname="$(basename "$(find "$1"/Contents/MacOS/ -type f -executable | head -n1)")" + curpath="$(dirname "$1")" + + mkdir -p "$curpath"/../Applications/ + mv "$1" "$curpath"/../Applications/ + [ -f "$curpath"/"$binname" ] && rm "$curpath"/"$binname" + ln -s ../Applications/"$appname"/Contents/MacOS/"$binname" "$curpath"/"$binname" + } + + rm $out/bin/fluid.icns + for app in $out/bin/*.app ${lib.optionalString withExamples "$bin/bin/*.app"}; do + moveAppBundles "$app" + done + ''; postFixup = '' substituteInPlace $out/bin/fltk-config \ diff --git a/pkgs/development/libraries/fontconfig/default.nix b/pkgs/development/libraries/fontconfig/default.nix index 4f7f3c0fe1e996..c7f14c8d86d4cb 100644 --- a/pkgs/development/libraries/fontconfig/default.nix +++ b/pkgs/development/libraries/fontconfig/default.nix @@ -1,26 +1,34 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, python3 -, freetype -, expat -, libxslt -, gperf -, dejavu_fonts -, autoreconfHook -, CoreFoundation -, testers +{ + stdenv, + lib, + fetchurl, + pkg-config, + python3, + freetype, + expat, + libxslt, + gperf, + dejavu_fonts, + autoreconfHook, + CoreFoundation, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "fontconfig"; version = "2.15.0"; - outputs = [ "bin" "dev" "lib" "out" ]; # $out contains all the config + outputs = [ + "bin" + "dev" + "lib" + "out" + ]; # $out contains all the config src = fetchurl { - url = with finalAttrs; "https://www.freedesktop.org/software/fontconfig/release/${pname}-${version}.tar.xz"; + url = + with finalAttrs; + "https://www.freedesktop.org/software/fontconfig/release/${pname}-${version}.tar.xz"; hash = "sha256-Y6BljQ4G4PqIYQZFK1jvBPIfWCAuoCqUw53g0zNdfA4="; }; @@ -45,15 +53,17 @@ stdenv.mkDerivation (finalAttrs: { sed -i '/check_PROGRAMS += test-crbug1004254/d' test/Makefile.am ''; - configureFlags = [ - "--sysconfdir=/etc" - "--with-arch=${stdenv.hostPlatform.parsed.cpu.name}" - "--with-cache-dir=/var/cache/fontconfig" # otherwise the fallback is in $out/ - # just <1MB; this is what you get when loading config fails for some reason - "--with-default-fonts=${dejavu_fonts.minimal}" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "--with-arch=${stdenv.hostPlatform.parsed.cpu.name}" - ]; + configureFlags = + [ + "--sysconfdir=/etc" + "--with-arch=${stdenv.hostPlatform.parsed.cpu.name}" + "--with-cache-dir=/var/cache/fontconfig" # otherwise the fallback is in $out/ + # just <1MB; this is what you get when loading config fails for some reason + "--with-default-fonts=${dejavu_fonts.minimal}" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "--with-arch=${stdenv.hostPlatform.parsed.cpu.name}" + ]; enableParallelBuilding = true; diff --git a/pkgs/development/libraries/fontconfig/make-fonts-cache.nix b/pkgs/development/libraries/fontconfig/make-fonts-cache.nix index 47884b9c3b928b..a1ac7d1b985946 100644 --- a/pkgs/development/libraries/fontconfig/make-fonts-cache.nix +++ b/pkgs/development/libraries/fontconfig/make-fonts-cache.nix @@ -1,4 +1,9 @@ -{ runCommand, lib, fontconfig, fontDirectories }: +{ + runCommand, + lib, + fontconfig, + fontDirectories, +}: runCommand "fc-cache" { diff --git a/pkgs/development/libraries/fontconfig/make-fonts-conf.nix b/pkgs/development/libraries/fontconfig/make-fonts-conf.nix index 669b66267f879c..d88b07ef8af1d0 100644 --- a/pkgs/development/libraries/fontconfig/make-fonts-conf.nix +++ b/pkgs/development/libraries/fontconfig/make-fonts-conf.nix @@ -1,26 +1,44 @@ -{ runCommand, stdenv, lib, libxslt, fontconfig, dejavu_fonts }: +{ + runCommand, + stdenv, + lib, + libxslt, + fontconfig, + dejavu_fonts, +}: -let fontconfig_ = fontconfig; in +let + fontconfig_ = fontconfig; +in { - fontconfig ? fontconfig_ + fontconfig ? fontconfig_, # an array of fonts, e.g. `[ pkgs.dejavu_fonts.minimal ]` - , fontDirectories - , impureFontDirectories ? [ - # nix user profile - "~/.nix-profile/lib/X11/fonts" "~/.nix-profile/share/fonts" - ] - ++ lib.optional stdenv.hostPlatform.isDarwin "~/Library/Fonts" - ++ [ - # FHS paths for non-NixOS platforms - "/usr/share/fonts" "/usr/local/share/fonts" - ] - # darwin paths - ++ lib.optionals stdenv.hostPlatform.isDarwin [ "/Library/Fonts" "/System/Library/Fonts" ] - # nix default profile - ++ [ "/nix/var/nix/profiles/default/lib/X11/fonts" "/nix/var/nix/profiles/default/share/fonts" ] + fontDirectories, + impureFontDirectories ? + [ + # nix user profile + "~/.nix-profile/lib/X11/fonts" + "~/.nix-profile/share/fonts" + ] + ++ lib.optional stdenv.hostPlatform.isDarwin "~/Library/Fonts" + ++ [ + # FHS paths for non-NixOS platforms + "/usr/share/fonts" + "/usr/local/share/fonts" + ] + # darwin paths + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "/Library/Fonts" + "/System/Library/Fonts" + ] + # nix default profile + ++ [ + "/nix/var/nix/profiles/default/lib/X11/fonts" + "/nix/var/nix/profiles/default/share/fonts" + ], # to include custom config - , includes ? ["/etc/fonts/conf.d"] + includes ? [ "/etc/fonts/conf.d" ], }: runCommand "fonts.conf" diff --git a/pkgs/development/libraries/fox/fox-1.6.nix b/pkgs/development/libraries/fox/fox-1.6.nix index e10d01d2c8421b..cfe531ccfa7b10 100644 --- a/pkgs/development/libraries/fox/fox-1.6.nix +++ b/pkgs/development/libraries/fox/fox-1.6.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchurl -, libpng -, libjpeg -, libtiff -, zlib -, bzip2 -, libXcursor -, libXrandr -, libGLU -, libGL -, libXext -, libXft -, libXfixes -, mesa -, xinput -, CoreServices +{ + lib, + stdenv, + fetchurl, + libpng, + libjpeg, + libtiff, + zlib, + bzip2, + libXcursor, + libXrandr, + libGLU, + libGL, + libXext, + libXft, + libXfixes, + mesa, + xinput, + CoreServices, }: stdenv.mkDerivation rec { @@ -28,8 +29,19 @@ stdenv.mkDerivation rec { }; buildInputs = [ - libpng libjpeg libtiff zlib bzip2 libXcursor libXrandr - libXext libXft libGLU libGL libXfixes xinput + libpng + libjpeg + libtiff + zlib + bzip2 + libXcursor + libXrandr + libXext + libXft + libGLU + libGL + libXfixes + xinput ] ++ lib.optional stdenv.hostPlatform.isDarwin CoreServices; doCheck = true; @@ -43,11 +55,11 @@ stdenv.mkDerivation rec { branch = "1.6"; description = "C++ based class library for building Graphical User Interfaces"; longDescription = '' - FOX stands for Free Objects for X. - It is a C++ based class library for building Graphical User Interfaces. - Initially, it was developed for LINUX, but the scope of this project has in the course of time become somewhat more ambitious. - Current aims are to make FOX completely platform independent, and thus programs written against the FOX library will be only a compile away from running on a variety of platforms. - ''; + FOX stands for Free Objects for X. + It is a C++ based class library for building Graphical User Interfaces. + Initially, it was developed for LINUX, but the scope of this project has in the course of time become somewhat more ambitious. + Current aims are to make FOX completely platform independent, and thus programs written against the FOX library will be only a compile away from running on a variety of platforms. + ''; homepage = "http://fox-toolkit.org"; license = lib.licenses.lgpl3; maintainers = [ ]; diff --git a/pkgs/development/libraries/fplll/20160331.nix b/pkgs/development/libraries/fplll/20160331.nix index 6bb9570d998a93..3936797241d673 100644 --- a/pkgs/development/libraries/fplll/20160331.nix +++ b/pkgs/development/libraries/fplll/20160331.nix @@ -1,5 +1,14 @@ -{lib, stdenv, fetchFromGitHub, autoconf, automake, libtool, gettext, autoreconfHook -, gmp, mpfr +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + gettext, + autoreconfHook, + gmp, + mpfr, }: stdenv.mkDerivation rec { pname = "fplll"; @@ -10,12 +19,21 @@ stdenv.mkDerivation rec { rev = "11dea26c2f9396ffb7a7191aa371343f1f74c5c3"; sha256 = "1clxch9hbr30w6s84m2mprxv58adhg5qw6sa2p3jr1cy4r7r59ib"; }; - nativeBuildInputs = [autoconf automake libtool gettext autoreconfHook]; - buildInputs = [gmp mpfr]; + nativeBuildInputs = [ + autoconf + automake + libtool + gettext + autoreconfHook + ]; + buildInputs = [ + gmp + mpfr + ]; meta = { description = "Lattice algorithms using floating-point arithmetic"; license = lib.licenses.lgpl21Plus; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/development/libraries/fplll/default.nix b/pkgs/development/libraries/fplll/default.nix index 5e2268199496b9..aa27ad68e4f276 100644 --- a/pkgs/development/libraries/fplll/default.nix +++ b/pkgs/development/libraries/fplll/default.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, pkg-config -, gettext -, autoreconfHook -, gmp -, mpfr +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + gettext, + autoreconfHook, + gmp, + mpfr, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/freeimage/default.nix b/pkgs/development/libraries/freeimage/default.nix index dd63935b23fd6e..cd58f37d4937eb 100644 --- a/pkgs/development/libraries/freeimage/default.nix +++ b/pkgs/development/libraries/freeimage/default.nix @@ -1,7 +1,21 @@ -{ lib, stdenv, fetchsvn, cctools, libtiff -, libpng, zlib, libwebp, libraw, openexr, openjpeg -, libjpeg, jxrlib, pkg-config -, fixDarwinDylibNames, autoSignDarwinBinariesHook }: +{ + lib, + stdenv, + fetchsvn, + cctools, + libtiff, + libpng, + zlib, + libwebp, + libraw, + openexr, + openjpeg, + libjpeg, + jxrlib, + pkg-config, + fixDarwinDylibNames, + autoSignDarwinBinariesHook, +}: stdenv.mkDerivation (finalAttrs: { pname = "freeimage"; @@ -24,26 +38,43 @@ stdenv.mkDerivation (finalAttrs: { ./libtiff-4.4.0.diff ]; - postPatch = '' - # To support cross compilation, use the correct `pkg-config`. - substituteInPlace Makefile.fip \ - --replace "pkg-config" "$PKG_CONFIG" - substituteInPlace Makefile.gnu \ - --replace "pkg-config" "$PKG_CONFIG" - '' + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' - # Upstream Makefile hardcodes i386 and x86_64 architectures only - substituteInPlace Makefile.osx --replace "x86_64" "arm64" - ''; + postPatch = + '' + # To support cross compilation, use the correct `pkg-config`. + substituteInPlace Makefile.fip \ + --replace "pkg-config" "$PKG_CONFIG" + substituteInPlace Makefile.gnu \ + --replace "pkg-config" "$PKG_CONFIG" + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' + # Upstream Makefile hardcodes i386 and x86_64 architectures only + substituteInPlace Makefile.osx --replace "x86_64" "arm64" + ''; - nativeBuildInputs = [ - pkg-config - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - cctools - fixDarwinDylibNames - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - autoSignDarwinBinariesHook + nativeBuildInputs = + [ + pkg-config + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + cctools + fixDarwinDylibNames + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + autoSignDarwinBinariesHook + ]; + buildInputs = [ + libtiff + libtiff.dev_private + libpng + zlib + libwebp + libraw + openexr + openjpeg + libjpeg + libjpeg.dev_private + jxrlib ]; - buildInputs = [ libtiff libtiff.dev_private libpng zlib libwebp libraw openexr openjpeg libjpeg libjpeg.dev_private jxrlib ]; postBuild = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' make -f Makefile.fip @@ -52,19 +83,22 @@ stdenv.mkDerivation (finalAttrs: { INCDIR = "${placeholder "out"}/include"; INSTALLDIR = "${placeholder "out"}/lib"; - preInstall = '' - mkdir -p $INCDIR $INSTALLDIR - '' - # Workaround for Makefiles.osx not using ?= - + lib.optionalString stdenv.hostPlatform.isDarwin '' - makeFlagsArray+=( "INCDIR=$INCDIR" "INSTALLDIR=$INSTALLDIR" ) - ''; + preInstall = + '' + mkdir -p $INCDIR $INSTALLDIR + '' + # Workaround for Makefiles.osx not using ?= + + lib.optionalString stdenv.hostPlatform.isDarwin '' + makeFlagsArray+=( "INCDIR=$INCDIR" "INSTALLDIR=$INSTALLDIR" ) + ''; - postInstall = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - make -f Makefile.fip install - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - ln -s $out/lib/libfreeimage.3.dylib $out/lib/libfreeimage.dylib - ''; + postInstall = + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + make -f Makefile.fip install + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + ln -s $out/lib/libfreeimage.3.dylib $out/lib/libfreeimage.dylib + ''; enableParallelBuilding = true; diff --git a/pkgs/development/libraries/freenect/default.nix b/pkgs/development/libraries/freenect/default.nix index f58785c1e1bd8c..08c6b5a3a810ca 100644 --- a/pkgs/development/libraries/freenect/default.nix +++ b/pkgs/development/libraries/freenect/default.nix @@ -1,6 +1,18 @@ -{ stdenv, lib, fetchFromGitHub, cmake, libusb1, pkg-config, libglut, libGLU, libGL, libXi, libXmu -, GLUT, Cocoa - }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + libusb1, + pkg-config, + libglut, + libGLU, + libGL, + libXi, + libXmu, + GLUT, + Cocoa, +}: stdenv.mkDerivation rec { pname = "freenect"; @@ -13,21 +25,44 @@ stdenv.mkDerivation rec { sha256 = "sha256-PpJGFWrlQ5sK7TJxQNoPujw1MxWRjphvblwOqnF+mSg="; }; - buildInputs = [ libusb1 libglut libGLU libGL libXi libXmu ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ GLUT Cocoa ]; + buildInputs = + [ + libusb1 + libglut + libGLU + libGL + libXi + libXmu + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + GLUT + Cocoa + ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; # see https://aur.archlinux.org/cgit/aur.git/commit/PKGBUILD?h=libfreenect&id=0d17db49ba64bcb9e3a4eed61cf55c9a5ceb97f1 - patchPhase = lib.concatMapStrings (x: '' - substituteInPlace ${x} --replace "{GLUT_LIBRARY}" "{GLUT_LIBRARIES}" - '') [ "examples/CMakeLists.txt" "wrappers/cpp/CMakeLists.txt" ]; + patchPhase = + lib.concatMapStrings + (x: '' + substituteInPlace ${x} --replace "{GLUT_LIBRARY}" "{GLUT_LIBRARIES}" + '') + [ + "examples/CMakeLists.txt" + "wrappers/cpp/CMakeLists.txt" + ]; meta = { description = "Drivers and libraries for the Xbox Kinect device on Windows, Linux, and macOS"; homepage = "http://openkinect.org"; - license = with lib.licenses; [ gpl2 asl20 ]; + license = with lib.licenses; [ + gpl2 + asl20 + ]; maintainers = with lib.maintainers; [ bennofs ]; - platforms = with lib.platforms; linux ++ darwin ; + platforms = with lib.platforms; linux ++ darwin; }; } diff --git a/pkgs/development/libraries/futuresql/default.nix b/pkgs/development/libraries/futuresql/default.nix index ed6a7033909ada..dddddd97ae676f 100644 --- a/pkgs/development/libraries/futuresql/default.nix +++ b/pkgs/development/libraries/futuresql/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchurl, cmake, extra-cmake-modules, qtbase }: +{ + stdenv, + lib, + fetchurl, + cmake, + extra-cmake-modules, + qtbase, +}: stdenv.mkDerivation rec { pname = "futuresql"; version = "0.1.1"; @@ -8,9 +15,12 @@ stdenv.mkDerivation rec { hash = "sha256-5E7Y1alhizynuimD7ZxfdXLm4KWxmflIaINLccy+vUM="; }; - nativeBuildInputs = [ cmake extra-cmake-modules ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; buildInputs = [ qtbase ]; - cmakeFlags = ["-DQT_MAJOR_VERSION=${lib.versions.major qtbase.version}"]; + cmakeFlags = [ "-DQT_MAJOR_VERSION=${lib.versions.major qtbase.version}" ]; # a library, nothing to wrap dontWrapQtApps = true; diff --git a/pkgs/development/libraries/g2o/default.nix b/pkgs/development/libraries/g2o/default.nix index 6f6560ea9f3f1a..0503edc339991d 100644 --- a/pkgs/development/libraries/g2o/default.nix +++ b/pkgs/development/libraries/g2o/default.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, mkDerivation, fetchFromGitHub, cmake, eigen, suitesparse, blas -, lapack, libGLU, qtbase, libqglviewer, spdlog }: +{ + lib, + stdenv, + mkDerivation, + fetchFromGitHub, + cmake, + eigen, + suitesparse, + blas, + lapack, + libGLU, + qtbase, + libqglviewer, + spdlog, +}: mkDerivation rec { pname = "g2o"; @@ -15,31 +28,48 @@ mkDerivation rec { # Removes a reference to gcc that is only used in a debug message patches = [ ./remove-compiler-reference.patch ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; separateDebugInfo = true; nativeBuildInputs = [ cmake ]; - buildInputs = [ eigen suitesparse blas lapack libGLU qtbase libqglviewer ]; + buildInputs = [ + eigen + suitesparse + blas + lapack + libGLU + qtbase + libqglviewer + ]; propagatedBuildInputs = [ spdlog ]; dontWrapQtApps = true; - cmakeFlags = [ - # Detection script is broken - "-DQGLVIEWER_INCLUDE_DIR=${libqglviewer}/include/QGLViewer" - "-DG2O_BUILD_EXAMPLES=OFF" - ] ++ lib.optionals stdenv.hostPlatform.isx86_64 [ - "-DDO_SSE_AUTODETECT=OFF" - "-DDISABLE_SSE3=${ if stdenv.hostPlatform.sse3Support then "OFF" else "ON"}" - "-DDISABLE_SSE4_1=${if stdenv.hostPlatform.sse4_1Support then "OFF" else "ON"}" - "-DDISABLE_SSE4_2=${if stdenv.hostPlatform.sse4_2Support then "OFF" else "ON"}" - "-DDISABLE_SSE4_A=${if stdenv.hostPlatform.sse4_aSupport then "OFF" else "ON"}" - ]; + cmakeFlags = + [ + # Detection script is broken + "-DQGLVIEWER_INCLUDE_DIR=${libqglviewer}/include/QGLViewer" + "-DG2O_BUILD_EXAMPLES=OFF" + ] + ++ lib.optionals stdenv.hostPlatform.isx86_64 [ + "-DDO_SSE_AUTODETECT=OFF" + "-DDISABLE_SSE3=${if stdenv.hostPlatform.sse3Support then "OFF" else "ON"}" + "-DDISABLE_SSE4_1=${if stdenv.hostPlatform.sse4_1Support then "OFF" else "ON"}" + "-DDISABLE_SSE4_2=${if stdenv.hostPlatform.sse4_2Support then "OFF" else "ON"}" + "-DDISABLE_SSE4_A=${if stdenv.hostPlatform.sse4_aSupport then "OFF" else "ON"}" + ]; meta = with lib; { description = "General Framework for Graph Optimization"; homepage = "https://github.com/RainerKuemmerle/g2o"; - license = with licenses; [ bsd3 lgpl3 gpl3 ]; + license = with licenses; [ + bsd3 + lgpl3 + gpl3 + ]; maintainers = with maintainers; [ lopsided98 ]; platforms = platforms.all; # fatal error: 'qglviewer.h' file not found diff --git a/pkgs/development/libraries/gamenetworkingsockets/default.nix b/pkgs/development/libraries/gamenetworkingsockets/default.nix index 3927e6e428a805..247d5d76b4a485 100644 --- a/pkgs/development/libraries/gamenetworkingsockets/default.nix +++ b/pkgs/development/libraries/gamenetworkingsockets/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, ninja, go, protobuf, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + go, + protobuf, + openssl, +}: stdenv.mkDerivation rec { pname = "GameNetworkingSockets"; @@ -11,7 +20,11 @@ stdenv.mkDerivation rec { sha256 = "12741wmpvy7mcvqqmjg4a7ph75rwliwgclhk4imjijqf2qkvsphd"; }; - nativeBuildInputs = [ cmake ninja go ]; + nativeBuildInputs = [ + cmake + ninja + go + ]; cmakeFlags = [ "-G Ninja" ]; diff --git a/pkgs/development/libraries/gcc/libgcc/default.nix b/pkgs/development/libraries/gcc/libgcc/default.nix index 600ca69f46d044..79d24de0da7df2 100644 --- a/pkgs/development/libraries/gcc/libgcc/default.nix +++ b/pkgs/development/libraries/gcc/libgcc/default.nix @@ -1,6 +1,10 @@ -{ lib, stdenvNoLibs, buildPackages -, gcc, glibc -, libiberty +{ + lib, + stdenvNoLibs, + buildPackages, + gcc, + glibc, + libiberty, }: let @@ -20,11 +24,15 @@ let "--with-build-sysroot=/" ]; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "libgcc"; inherit (gcc.cc) src version; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; strictDeps = true; depsBuildBuild = [ buildPackages.stdenv.cc ]; @@ -45,85 +53,91 @@ in stdenv.mkDerivation (finalAttrs: { hardeningDisable = [ "pie" ]; preConfigure = - '' - # Drop in libiberty, as external builds are not expected - cd "$buildRoot" - ( - mkdir -p build-${stdenv.buildPlatform.config}/libiberty/ - cd build-${stdenv.buildPlatform.config}/libiberty/ - ln -s ${buildPackages.libiberty}/lib/libiberty.a ./ - ) - mkdir -p "$buildRoot/gcc" - cd "$buildRoot/gcc" - ( - # We "shift" the tools over to fake platforms perspective from the previous stage. + '' + # Drop in libiberty, as external builds are not expected + cd "$buildRoot" + ( + mkdir -p build-${stdenv.buildPlatform.config}/libiberty/ + cd build-${stdenv.buildPlatform.config}/libiberty/ + ln -s ${buildPackages.libiberty}/lib/libiberty.a ./ + ) + mkdir -p "$buildRoot/gcc" + cd "$buildRoot/gcc" + ( + # We "shift" the tools over to fake platforms perspective from the previous stage. + export AS_FOR_BUILD=${buildPackages.stdenv.cc}/bin/$AS_FOR_BUILD + export CC_FOR_BUILD=${buildPackages.stdenv.cc}/bin/$CC_FOR_BUILD + export CPP_FOR_BUILD=${buildPackages.stdenv.cc}/bin/$CPP_FOR_BUILD + export CXX_FOR_BUILD=${buildPackages.stdenv.cc}/bin/$CXX_FOR_BUILD + export LD_FOR_BUILD=${buildPackages.stdenv.cc.bintools}/bin/$LD_FOR_BUILD + + export AS=$AS_FOR_BUILD + export CC=$CC_FOR_BUILD + export CPP=$CPP_FOR_BUILD + export CXX=$CXX_FOR_BUILD + export LD=$LD_FOR_BUILD + + export AS_FOR_TARGET=${stdenv.cc}/bin/$AS + export CC_FOR_TARGET=${stdenv.cc}/bin/$CC + export CPP_FOR_TARGET=${stdenv.cc}/bin/$CPP + export LD_FOR_TARGET=${stdenv.cc.bintools}/bin/$LD + + # We define GENERATOR_FILE so nothing bothers looking for GNU GMP. + export NIX_CFLAGS_COMPILE_FOR_BUILD+=' -DGENERATOR_FILE=1' + + "$sourceRoot/../gcc/configure" ${lib.concatStringsSep " " gccConfigureFlags} + + # We remove the `libgcc.mvar` deps so that the bootstrap xgcc isn't built. + sed -e 's,libgcc.mvars:.*$,libgcc.mvars:,' -i Makefile + + make \ + config.h \ + libgcc.mvars \ + tconfig.h \ + tm.h \ + options.h \ + insn-constants.h \ + '' + + lib.optionalString stdenv.targetPlatform.isM68k '' + sysroot-suffix.h \ + '' + + lib.optionalString stdenv.targetPlatform.isAarch32 '' + arm-isa.h \ + arm-cpu.h \ + '' + + '' + insn-modes.h + ) + mkdir -p "$buildRoot/gcc/include" + + # Preparing to configure + build libgcc itself + mkdir -p "$buildRoot/gcc/${stdenv.hostPlatform.config}/libgcc" + cd "$buildRoot/gcc/${stdenv.hostPlatform.config}/libgcc" + configureScript=$sourceRoot/configure + chmod +x "$configureScript" + export AS_FOR_BUILD=${buildPackages.stdenv.cc}/bin/$AS_FOR_BUILD export CC_FOR_BUILD=${buildPackages.stdenv.cc}/bin/$CC_FOR_BUILD export CPP_FOR_BUILD=${buildPackages.stdenv.cc}/bin/$CPP_FOR_BUILD export CXX_FOR_BUILD=${buildPackages.stdenv.cc}/bin/$CXX_FOR_BUILD export LD_FOR_BUILD=${buildPackages.stdenv.cc.bintools}/bin/$LD_FOR_BUILD - export AS=$AS_FOR_BUILD - export CC=$CC_FOR_BUILD - export CPP=$CPP_FOR_BUILD - export CXX=$CXX_FOR_BUILD - export LD=$LD_FOR_BUILD - - export AS_FOR_TARGET=${stdenv.cc}/bin/$AS - export CC_FOR_TARGET=${stdenv.cc}/bin/$CC - export CPP_FOR_TARGET=${stdenv.cc}/bin/$CPP - export LD_FOR_TARGET=${stdenv.cc.bintools}/bin/$LD - - # We define GENERATOR_FILE so nothing bothers looking for GNU GMP. - export NIX_CFLAGS_COMPILE_FOR_BUILD+=' -DGENERATOR_FILE=1' - - "$sourceRoot/../gcc/configure" ${lib.concatStringsSep " " gccConfigureFlags} - - # We remove the `libgcc.mvar` deps so that the bootstrap xgcc isn't built. - sed -e 's,libgcc.mvars:.*$,libgcc.mvars:,' -i Makefile - - make \ - config.h \ - libgcc.mvars \ - tconfig.h \ - tm.h \ - options.h \ - insn-constants.h \ - '' + lib.optionalString stdenv.targetPlatform.isM68k '' - sysroot-suffix.h \ - '' + lib.optionalString stdenv.targetPlatform.isAarch32 '' - arm-isa.h \ - arm-cpu.h \ - '' + '' - insn-modes.h - ) - mkdir -p "$buildRoot/gcc/include" - - # Preparing to configure + build libgcc itself - mkdir -p "$buildRoot/gcc/${stdenv.hostPlatform.config}/libgcc" - cd "$buildRoot/gcc/${stdenv.hostPlatform.config}/libgcc" - configureScript=$sourceRoot/configure - chmod +x "$configureScript" - - export AS_FOR_BUILD=${buildPackages.stdenv.cc}/bin/$AS_FOR_BUILD - export CC_FOR_BUILD=${buildPackages.stdenv.cc}/bin/$CC_FOR_BUILD - export CPP_FOR_BUILD=${buildPackages.stdenv.cc}/bin/$CPP_FOR_BUILD - export CXX_FOR_BUILD=${buildPackages.stdenv.cc}/bin/$CXX_FOR_BUILD - export LD_FOR_BUILD=${buildPackages.stdenv.cc.bintools}/bin/$LD_FOR_BUILD - - export AS=${stdenv.cc}/bin/$AS - export CC=${stdenv.cc}/bin/$CC - export CPP=${stdenv.cc}/bin/$CPP - export CXX=${stdenv.cc}/bin/$CXX - export LD=${stdenv.cc.bintools}/bin/$LD - - export AS_FOR_TARGET=${stdenv.cc}/bin/$AS_FOR_TARGET - export CC_FOR_TARGET=${stdenv.cc}/bin/$CC_FOR_TARGET - export CPP_FOR_TARGET=${stdenv.cc}/bin/$CPP_FOR_TARGET - export LD_FOR_TARGET=${stdenv.cc.bintools}/bin/$LD_FOR_TARGET - ''; + export AS=${stdenv.cc}/bin/$AS + export CC=${stdenv.cc}/bin/$CC + export CPP=${stdenv.cc}/bin/$CPP + export CXX=${stdenv.cc}/bin/$CXX + export LD=${stdenv.cc.bintools}/bin/$LD + + export AS_FOR_TARGET=${stdenv.cc}/bin/$AS_FOR_TARGET + export CC_FOR_TARGET=${stdenv.cc}/bin/$CC_FOR_TARGET + export CPP_FOR_TARGET=${stdenv.cc}/bin/$CPP_FOR_TARGET + export LD_FOR_TARGET=${stdenv.cc.bintools}/bin/$LD_FOR_TARGET + ''; - configurePlatforms = [ "build" "host" ]; + configurePlatforms = [ + "build" + "host" + ]; configureFlags = [ "cross_compiling=true" "--disable-gcov" diff --git a/pkgs/development/libraries/gcr/4.nix b/pkgs/development/libraries/gcr/4.nix index b99c5f9eaa490d..d534840887eea3 100644 --- a/pkgs/development/libraries/gcr/4.nix +++ b/pkgs/development/libraries/gcr/4.nix @@ -1,35 +1,41 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, meson -, ninja -, gettext -, gnupg -, p11-kit -, glib -, libgcrypt -, libtasn1 -, gtk4 -, pango -, libsecret -, openssh -, systemd -, gobject-introspection -, wrapGAppsHook4 -, vala -, gi-docgen -, gnome -, python3 -, shared-mime-info -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd +{ + stdenv, + lib, + fetchurl, + pkg-config, + meson, + ninja, + gettext, + gnupg, + p11-kit, + glib, + libgcrypt, + libtasn1, + gtk4, + pango, + libsecret, + openssh, + systemd, + gobject-introspection, + wrapGAppsHook4, + vala, + gi-docgen, + gnome, + python3, + shared-mime-info, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, }: stdenv.mkDerivation rec { pname = "gcr"; version = "4.3.0"; - outputs = [ "out" "bin" "dev" "devdoc" ]; + outputs = [ + "out" + "bin" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -51,16 +57,18 @@ stdenv.mkDerivation rec { shared-mime-info ]; - buildInputs = [ - libgcrypt - libtasn1 - pango - libsecret - openssh - gtk4 - ] ++ lib.optionals systemdSupport [ - systemd - ]; + buildInputs = + [ + libgcrypt + libtasn1 + pango + libsecret + openssh + gtk4 + ] + ++ lib.optionals systemdSupport [ + systemd + ]; propagatedBuildInputs = [ glib diff --git a/pkgs/development/libraries/gcr/default.nix b/pkgs/development/libraries/gcr/default.nix index db31927b7a70a8..518f403076cfac 100644 --- a/pkgs/development/libraries/gcr/default.nix +++ b/pkgs/development/libraries/gcr/default.nix @@ -1,34 +1,40 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, meson -, ninja -, gettext -, gnupg -, p11-kit -, glib -, libgcrypt -, libtasn1 -, gtk3 -, pango -, libsecret -, openssh -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, systemd -, gobject-introspection -, wrapGAppsHook3 -, gi-docgen -, vala -, gnome -, python3 -, shared-mime-info +{ + stdenv, + lib, + fetchurl, + pkg-config, + meson, + ninja, + gettext, + gnupg, + p11-kit, + glib, + libgcrypt, + libtasn1, + gtk3, + pango, + libsecret, + openssh, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + gobject-introspection, + wrapGAppsHook3, + gi-docgen, + vala, + gnome, + python3, + shared-mime-info, }: stdenv.mkDerivation rec { pname = "gcr"; version = "3.41.2"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -51,15 +57,17 @@ stdenv.mkDerivation rec { openssh ]; - buildInputs = [ - libgcrypt - libtasn1 - pango - libsecret - openssh - ] ++ lib.optionals (systemdSupport) [ - systemd - ]; + buildInputs = + [ + libgcrypt + libtasn1 + pango + libsecret + openssh + ] + ++ lib.optionals (systemdSupport) [ + systemd + ]; propagatedBuildInputs = [ glib @@ -71,14 +79,16 @@ stdenv.mkDerivation rec { python3 ]; - mesonFlags = [ - # We are still using ssh-agent from gnome-keyring. - # https://github.com/NixOS/nixpkgs/issues/140824 - "-Dssh_agent=false" - "-Dgpg_path=${lib.getBin gnupg}/bin/gpg" - ] ++ lib.optionals (!systemdSupport) [ - "-Dsystemd=disabled" - ]; + mesonFlags = + [ + # We are still using ssh-agent from gnome-keyring. + # https://github.com/NixOS/nixpkgs/issues/140824 + "-Dssh_agent=false" + "-Dgpg_path=${lib.getBin gnupg}/bin/gpg" + ] + ++ lib.optionals (!systemdSupport) [ + "-Dsystemd=disabled" + ]; doCheck = false; # fails 21 out of 603 tests, needs dbus daemon diff --git a/pkgs/development/libraries/gd/default.nix b/pkgs/development/libraries/gd/default.nix index 6b1a471d4aac32..d7b50cce5d5270 100644 --- a/pkgs/development/libraries/gd/default.nix +++ b/pkgs/development/libraries/gd/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, autoconf -, automake -, pkg-config -, zlib -, libpng -, libjpeg -, libwebp -, libtiff -, withXorg ? true -, libXpm -, libavif -, fontconfig -, freetype +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoconf, + automake, + pkg-config, + zlib, + libpng, + libjpeg, + libwebp, + libtiff, + withXorg ? true, + libXpm, + libavif, + fontconfig, + freetype, }: stdenv.mkDerivation rec { @@ -27,7 +28,8 @@ stdenv.mkDerivation rec { }; patches = [ - (fetchpatch { # included in > 2.3.3 + (fetchpatch { + # included in > 2.3.3 name = "restore-GD_FLIP.patch"; url = "https://github.com/libgd/libgd/commit/f4bc1f5c26925548662946ed7cfa473c190a104a.diff"; sha256 = "XRXR3NOkbEub3Nybaco2duQk0n8vxif5mTl2AUacn9w="; @@ -36,18 +38,39 @@ stdenv.mkDerivation rec { hardeningDisable = [ "format" ]; - configureFlags = [ - "--enable-gd-formats" - ] + configureFlags = + [ + "--enable-gd-formats" + ] # -pthread gets passed to clang, causing warnings ++ lib.optional stdenv.hostPlatform.isDarwin "--enable-werror=no"; - nativeBuildInputs = [ autoconf automake pkg-config ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + ]; - buildInputs = [ zlib freetype libpng libjpeg libwebp libtiff libavif ] - ++ lib.optionals withXorg [ fontconfig libXpm ]; + buildInputs = + [ + zlib + freetype + libpng + libjpeg + libwebp + libtiff + libavif + ] + ++ lib.optionals withXorg [ + fontconfig + libXpm + ]; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; postFixup = '' moveToOutput "bin/gdlib-config" $dev diff --git a/pkgs/development/libraries/gdal/tests.nix b/pkgs/development/libraries/gdal/tests.nix index e6d76730140350..7b648fefa9e917 100644 --- a/pkgs/development/libraries/gdal/tests.nix +++ b/pkgs/development/libraries/gdal/tests.nix @@ -1,4 +1,10 @@ -{ runCommand, gdal, jdk, lib, testers }: +{ + runCommand, + gdal, + jdk, + lib, + testers, +}: let inherit (gdal) pname version; diff --git a/pkgs/development/libraries/gdk-pixbuf/default.nix b/pkgs/development/libraries/gdk-pixbuf/default.nix index b7ba1224536298..37e90255a403fc 100644 --- a/pkgs/development/libraries/gdk-pixbuf/default.nix +++ b/pkgs/development/libraries/gdk-pixbuf/default.nix @@ -1,42 +1,52 @@ -{ stdenv -, fetchurl -, nixosTests -, fixDarwinDylibNames -, meson -, ninja -, pkg-config -, gettext -, python3 -, docutils -, gi-docgen -, glib -, libtiff -, libjpeg -, libpng -, gnome -, doCheck ? false -, makeWrapper -, lib -, testers -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, gobject-introspection +{ + stdenv, + fetchurl, + nixosTests, + fixDarwinDylibNames, + meson, + ninja, + pkg-config, + gettext, + python3, + docutils, + gi-docgen, + glib, + libtiff, + libjpeg, + libpng, + gnome, + doCheck ? false, + makeWrapper, + lib, + testers, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + gobject-introspection, }: stdenv.mkDerivation (finalAttrs: { pname = "gdk-pixbuf"; version = "2.42.12"; - outputs = [ "out" "dev" "man" ] + outputs = + [ + "out" + "dev" + "man" + ] ++ lib.optional withIntrospection "devdoc" ++ lib.optional (stdenv.buildPlatform == stdenv.hostPlatform) "installedTests"; - src = let - inherit (finalAttrs) pname version; - in fetchurl { - url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; - hash = "sha256-uVBbNEW5p+SM7TR2DDvLc+lm3zrJTJWhSMtmmrdI48c="; - }; + src = + let + inherit (finalAttrs) pname version; + in + fetchurl { + url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; + hash = "sha256-uVBbNEW5p+SM7TR2DDvLc+lm3zrJTJWhSMtmmrdI48c="; + }; patches = [ # Move installed tests to a separate output @@ -50,23 +60,26 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - gettext - python3 - makeWrapper - glib - - # for man pages - docutils - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ] ++ lib.optionals withIntrospection [ - gi-docgen - gobject-introspection - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gettext + python3 + makeWrapper + glib + + # for man pages + docutils + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ] + ++ lib.optionals withIntrospection [ + gi-docgen + gobject-introspection + ]; propagatedBuildInputs = [ glib @@ -105,14 +118,16 @@ stdenv.mkDerivation (finalAttrs: { moveToOutput "bin" "$dev" moveToOutput "bin/gdk-pixbuf-thumbnailer" "$out" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' # meson erroneously installs loaders with .dylib extension on Darwin. # Their @rpath has to be replaced before gdk-pixbuf-query-loaders looks at them. for f in $out/${finalAttrs.passthru.moduleDir}/*.dylib; do install_name_tool -change @rpath/libgdk_pixbuf-2.0.0.dylib $out/lib/libgdk_pixbuf-2.0.0.dylib $f mv $f ''${f%.dylib}.so done - '' + lib.optionalString withIntrospection '' + '' + + lib.optionalString withIntrospection '' # We need to install 'loaders.cache' in lib/gdk-pixbuf-2.0/2.10.0/ ${stdenv.hostPlatform.emulator buildPackages} $dev/bin/gdk-pixbuf-query-loaders --update-cache ''; diff --git a/pkgs/development/libraries/gdk-pixbuf/xlib.nix b/pkgs/development/libraries/gdk-pixbuf/xlib.nix index 0e0e2108da8dd5..61a4c4c2ef646a 100644 --- a/pkgs/development/libraries/gdk-pixbuf/xlib.nix +++ b/pkgs/development/libraries/gdk-pixbuf/xlib.nix @@ -1,20 +1,26 @@ -{ lib, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, docbook-xsl-nons -, docbook_xml_dtd_43 -, gtk-doc -, gdk-pixbuf -, libX11 +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + docbook-xsl-nons, + docbook_xml_dtd_43, + gtk-doc, + gdk-pixbuf, + libX11, }: stdenv.mkDerivation rec { pname = "gdk-pixbuf-xlib"; version = "2.40.2"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitLab { domain = "gitlab.gnome.org"; diff --git a/pkgs/development/libraries/gecode/3.nix b/pkgs/development/libraries/gecode/3.nix index 1d6f158b52f2bf..b171d53d8d7785 100644 --- a/pkgs/development/libraries/gecode/3.nix +++ b/pkgs/development/libraries/gecode/3.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, perl +{ + lib, + stdenv, + fetchurl, + fetchpatch, + perl, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/gecode/default.nix b/pkgs/development/libraries/gecode/default.nix index 57bac22951394f..078d21d87c6af7 100644 --- a/pkgs/development/libraries/gecode/default.nix +++ b/pkgs/development/libraries/gecode/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, bison -, flex -, perl -, gmp -, mpfr -, qtbase -, enableGist ? true +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + bison, + flex, + perl, + gmp, + mpfr, + qtbase, + enableGist ? true, }: stdenv.mkDerivation rec { @@ -28,9 +29,15 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; dontWrapQtApps = true; - nativeBuildInputs = [ bison flex ]; - buildInputs = [ perl gmp mpfr ] - ++ lib.optional enableGist qtbase; + nativeBuildInputs = [ + bison + flex + ]; + buildInputs = [ + perl + gmp + mpfr + ] ++ lib.optional enableGist qtbase; meta = with lib; { license = licenses.mit; diff --git a/pkgs/development/libraries/gensio/default.nix b/pkgs/development/libraries/gensio/default.nix index 9bd0633e3d1b53..bfdd37d93746b9 100644 --- a/pkgs/development/libraries/gensio/default.nix +++ b/pkgs/development/libraries/gensio/default.nix @@ -1,10 +1,11 @@ -{ autoreconfHook -, fetchFromGitHub -, lib -, nix-update-script -, openssl -, pkg-config -, stdenv +{ + autoreconfHook, + fetchFromGitHub, + lib, + nix-update-script, + openssl, + pkg-config, + stdenv, }: stdenv.mkDerivation rec { @@ -26,7 +27,10 @@ stdenv.mkDerivation rec { "--with-python=no" ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ openssl ]; diff --git a/pkgs/development/libraries/geoip/default.nix b/pkgs/development/libraries/geoip/default.nix index cdb1a0a43e81b2..e9ff8223501a27 100644 --- a/pkgs/development/libraries/geoip/default.nix +++ b/pkgs/development/libraries/geoip/default.nix @@ -1,19 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, drvName ? "geoip" +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + drvName ? "geoip", # in geoipDatabase, you can insert a package defining # "${geoipDatabase}/share/GeoIP" e.g. geolite-legacy -, geoipDatabase ? "/var/lib/geoip-databases" + geoipDatabase ? "/var/lib/geoip-databases", }: let dataDir = - if lib.isDerivation geoipDatabase - then "${toString geoipDatabase}/share/GeoIP" - else geoipDatabase; + if lib.isDerivation geoipDatabase then "${toString geoipDatabase}/share/GeoIP" else geoipDatabase; in stdenv.mkDerivation rec { @@ -44,7 +43,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "API for GeoIP/Geolocation databases"; - maintainers = with maintainers; [ thoughtpolice raskin ]; + maintainers = with maintainers; [ + thoughtpolice + raskin + ]; license = licenses.lgpl21; platforms = platforms.unix; homepage = "https://www.maxmind.com"; diff --git a/pkgs/development/libraries/geos/3.9.nix b/pkgs/development/libraries/geos/3.9.nix index b2cf3e8f962926..70cfa917993b0d 100644 --- a/pkgs/development/libraries/geos/3.9.nix +++ b/pkgs/development/libraries/geos/3.9.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, cmake -, testers +{ + lib, + stdenv, + fetchurl, + cmake, + testers, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/libraries/geos/default.nix b/pkgs/development/libraries/geos/default.nix index 2e63196b04207c..fef2d09b6bad3b 100644 --- a/pkgs/development/libraries/geos/default.nix +++ b/pkgs/development/libraries/geos/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, callPackage -, fetchurl -, testers - -, cmake +{ + lib, + stdenv, + callPackage, + fetchurl, + testers, + + cmake, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/libraries/geos/tests.nix b/pkgs/development/libraries/geos/tests.nix index ad9ab883db2d22..7f6e1c6dd007ea 100644 --- a/pkgs/development/libraries/geos/tests.nix +++ b/pkgs/development/libraries/geos/tests.nix @@ -3,13 +3,12 @@ let inherit (geos) pname; in -runCommand "${pname}-tests" { meta.timeout = 60; } - '' - ${geos}/bin/geosop \ - --explode \ - --format wkt \ - polygonize \ - -a "MULTILINESTRING ((200 100, 100 100, 200 200), (200 200, 200 100), (200 200, 300 100, 200 100))" \ - | grep 'POLYGON ((200 100, 100 100, 200 200, 200 100))' - touch $out - '' +runCommand "${pname}-tests" { meta.timeout = 60; } '' + ${geos}/bin/geosop \ + --explode \ + --format wkt \ + polygonize \ + -a "MULTILINESTRING ((200 100, 100 100, 200 200), (200 200, 200 100), (200 200, 300 100, 200 100))" \ + | grep 'POLYGON ((200 100, 100 100, 200 200, 200 100))' + touch $out +'' diff --git a/pkgs/development/libraries/getdns/default.nix b/pkgs/development/libraries/getdns/default.nix index b85dc689d96cf6..3be26afe3e5285 100644 --- a/pkgs/development/libraries/getdns/default.nix +++ b/pkgs/development/libraries/getdns/default.nix @@ -1,19 +1,40 @@ # Getdns and Stubby are released together, see https://getdnsapi.net/releases/ -{ lib, stdenv, fetchurl, cmake, darwin, doxygen, libidn2, libyaml, openssl -, systemd, unbound, yq }: +{ + lib, + stdenv, + fetchurl, + cmake, + darwin, + doxygen, + libidn2, + libyaml, + openssl, + systemd, + unbound, + yq, +}: let metaCommon = { - maintainers = with lib.maintainers; [ leenaars ehmry ]; + maintainers = with lib.maintainers; [ + leenaars + ehmry + ]; license = lib.licenses.bsd3; platforms = lib.platforms.all; }; -in rec { +in +rec { getdns = stdenv.mkDerivation rec { pname = "getdns"; version = "1.7.3"; - outputs = [ "out" "dev" "lib" "man" ]; + outputs = [ + "out" + "dev" + "lib" + "man" + ]; src = fetchurl { url = "https://getdnsapi.net/releases/${pname}-${lib.concatStringsSep "-" (lib.splitVersion version)}/${pname}-${version}.tar.gz"; @@ -21,9 +42,16 @@ in rec { sha256 = "f1404ca250f02e37a118aa00cf0ec2cbe11896e060c6d369c6761baea7d55a2c"; }; - nativeBuildInputs = [ cmake doxygen ]; + nativeBuildInputs = [ + cmake + doxygen + ]; - buildInputs = [ libidn2 openssl unbound ]; + buildInputs = [ + libidn2 + openssl + unbound + ]; # https://github.com/getdnsapi/getdns/issues/517 postPatch = '' @@ -54,15 +82,27 @@ in rec { stubby = stdenv.mkDerivation rec { pname = "stubby"; version = "0.4.3"; - outputs = [ "out" "man" "stubbyExampleJson" ]; + outputs = [ + "out" + "man" + "stubbyExampleJson" + ]; inherit (getdns) src; sourceRoot = "${getdns.pname}-${getdns.version}/stubby"; - nativeBuildInputs = [ cmake doxygen yq ]; - - buildInputs = [ getdns libyaml openssl systemd ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.Security ]; + nativeBuildInputs = [ + cmake + doxygen + yq + ]; + + buildInputs = [ + getdns + libyaml + openssl + systemd + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.Security ]; postInstall = '' rm -r $out/share/doc diff --git a/pkgs/development/libraries/gettext/default.nix b/pkgs/development/libraries/gettext/default.nix index 0518a40c293019..c923994f6a1899 100644 --- a/pkgs/development/libraries/gettext/default.nix +++ b/pkgs/development/libraries/gettext/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, libiconv, bash, updateAutotoolsGnuConfigScriptsHook +{ + stdenv, + lib, + fetchurl, + libiconv, + bash, + updateAutotoolsGnuConfigScriptsHook, }: # Note: this package is used for bootstrapping fetchurl, and thus @@ -21,45 +27,56 @@ stdenv.mkDerivation rec { ./0001-msginit-Do-not-use-POT-Creation-Date.patch ]; - outputs = [ "out" "man" "doc" "info" ]; + outputs = [ + "out" + "man" + "doc" + "info" + ]; hardeningDisable = [ "format" ]; LDFLAGS = lib.optionalString stdenv.hostPlatform.isSunOS "-lm -lmd -lmp -luutil -lnvpair -lnsl -lidmap -lavl -lsec"; - configureFlags = [ - "--disable-csharp" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - # On cross building, gettext supposes that the wchar.h from libc - # does not fulfill gettext needs, so it tries to work with its - # own wchar.h file, which does not cope well with the system's - # wchar.h and stddef.h (gcc-4.3 - glibc-2.9) - "gl_cv_func_wcwidth_works=yes" - ]; - - postPatch = '' - substituteAllInPlace gettext-runtime/src/gettext.sh.in - substituteInPlace gettext-tools/projects/KDE/trigger --replace "/bin/pwd" pwd - substituteInPlace gettext-tools/projects/GNOME/trigger --replace "/bin/pwd" pwd - substituteInPlace gettext-tools/src/project-id --replace "/bin/pwd" pwd - '' + lib.optionalString stdenv.hostPlatform.isCygwin '' - sed -i -e "s/\(cldr_plurals_LDADD = \)/\\1..\/gnulib-lib\/libxml_rpl.la /" gettext-tools/src/Makefile.in - sed -i -e "s/\(libgettextsrc_la_LDFLAGS = \)/\\1..\/gnulib-lib\/libxml_rpl.la /" gettext-tools/src/Makefile.in - '' + lib.optionalString stdenv.hostPlatform.isMinGW '' - sed -i "s/@GNULIB_CLOSE@/1/" */*/unistd.in.h - ''; + configureFlags = + [ + "--disable-csharp" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + # On cross building, gettext supposes that the wchar.h from libc + # does not fulfill gettext needs, so it tries to work with its + # own wchar.h file, which does not cope well with the system's + # wchar.h and stddef.h (gcc-4.3 - glibc-2.9) + "gl_cv_func_wcwidth_works=yes" + ]; + + postPatch = + '' + substituteAllInPlace gettext-runtime/src/gettext.sh.in + substituteInPlace gettext-tools/projects/KDE/trigger --replace "/bin/pwd" pwd + substituteInPlace gettext-tools/projects/GNOME/trigger --replace "/bin/pwd" pwd + substituteInPlace gettext-tools/src/project-id --replace "/bin/pwd" pwd + '' + + lib.optionalString stdenv.hostPlatform.isCygwin '' + sed -i -e "s/\(cldr_plurals_LDADD = \)/\\1..\/gnulib-lib\/libxml_rpl.la /" gettext-tools/src/Makefile.in + sed -i -e "s/\(libgettextsrc_la_LDFLAGS = \)/\\1..\/gnulib-lib\/libxml_rpl.la /" gettext-tools/src/Makefile.in + '' + + lib.optionalString stdenv.hostPlatform.isMinGW '' + sed -i "s/@GNULIB_CLOSE@/1/" */*/unistd.in.h + ''; strictDeps = true; nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook ]; - buildInputs = lib.optionals (!stdenv.hostPlatform.isMinGW) [ - bash - ] - ++ lib.optionals (!stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isCygwin) [ - # HACK, see #10874 (and 14664) - libiconv - ]; + buildInputs = + lib.optionals (!stdenv.hostPlatform.isMinGW) [ + bash + ] + ++ lib.optionals (!stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isCygwin) [ + # HACK, see #10874 (and 14664) + libiconv + ]; setupHooks = [ ../../../build-support/setup-hooks/role.bash diff --git a/pkgs/development/libraries/givaro/3.7.nix b/pkgs/development/libraries/givaro/3.7.nix index 7d7d414dfb2745..e3472d2d0bf75c 100644 --- a/pkgs/development/libraries/givaro/3.7.nix +++ b/pkgs/development/libraries/givaro/3.7.nix @@ -1,4 +1,13 @@ -{lib, stdenv, fetchurl, automake, autoconf, libtool, autoreconfHook, gmpxx}: +{ + lib, + stdenv, + fetchurl, + automake, + autoconf, + libtool, + autoreconfHook, + gmpxx, +}: stdenv.mkDerivation rec { pname = "givaro"; version = "3.7.2"; @@ -6,12 +15,19 @@ stdenv.mkDerivation rec { url = "https://forge.imag.fr/frs/download.php/370/givaro-${version}.tar.gz"; sha256 = "0lf5cnbyr27fw7klc3zabkb1979dn67jmrjz6pa3jzw2ng74x9b3"; }; - nativeBuildInputs = [ autoreconfHook autoconf automake ]; - buildInputs = [libtool gmpxx]; + nativeBuildInputs = [ + autoreconfHook + autoconf + automake + ]; + buildInputs = [ + libtool + gmpxx + ]; meta = { description = "C++ library for arithmetic and algebraic computations"; license = lib.licenses.cecill-b; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/development/libraries/givaro/3.nix b/pkgs/development/libraries/givaro/3.nix index f03fef8aac163a..605ce04e7d2a78 100644 --- a/pkgs/development/libraries/givaro/3.nix +++ b/pkgs/development/libraries/givaro/3.nix @@ -1,4 +1,13 @@ -{lib, stdenv, fetchurl, automake, autoconf, libtool, autoreconfHook, gmpxx}: +{ + lib, + stdenv, + fetchurl, + automake, + autoconf, + libtool, + autoreconfHook, + gmpxx, +}: stdenv.mkDerivation rec { pname = "givaro"; version = "3.8.0"; @@ -6,12 +15,19 @@ stdenv.mkDerivation rec { url = "https://forge.imag.fr/frs/download.php/592/givaro-${version}.tar.gz"; sha256 = "1822ksv8653a84hvcz0vxl3nk8dqz7d41ys8rplq0zjjmvb2i5yq"; }; - nativeBuildInputs = [ autoreconfHook autoconf automake ]; - buildInputs = [libtool gmpxx]; + nativeBuildInputs = [ + autoreconfHook + autoconf + automake + ]; + buildInputs = [ + libtool + gmpxx + ]; meta = { description = "C++ library for arithmetic and algebraic computations"; license = lib.licenses.cecill-b; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/development/libraries/givaro/default.nix b/pkgs/development/libraries/givaro/default.nix index a77cc10e2e36fb..44ef1637443fb8 100644 --- a/pkgs/development/libraries/givaro/default.nix +++ b/pkgs/development/libraries/givaro/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, automake -, autoconf -, libtool -, autoreconfHook -, gmpxx +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + automake, + autoconf, + libtool, + autoreconfHook, + gmpxx, }: stdenv.mkDerivation rec { pname = "givaro"; @@ -34,23 +35,29 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - nativeBuildInputs = [ autoreconfHook autoconf automake ]; - buildInputs = [libtool]; + nativeBuildInputs = [ + autoreconfHook + autoconf + automake + ]; + buildInputs = [ libtool ]; propagatedBuildInputs = [ gmpxx ]; - configureFlags = [ - "--without-archnative" - ] ++ lib.optionals stdenv.hostPlatform.isx86_64 [ - # disable SIMD instructions (which are enabled *when available* by default) - "--${if stdenv.hostPlatform.sse3Support then "enable" else "disable"}-sse3" - "--${if stdenv.hostPlatform.ssse3Support then "enable" else "disable"}-ssse3" - "--${if stdenv.hostPlatform.sse4_1Support then "enable" else "disable"}-sse41" - "--${if stdenv.hostPlatform.sse4_2Support then "enable" else "disable"}-sse42" - "--${if stdenv.hostPlatform.avxSupport then "enable" else "disable"}-avx" - "--${if stdenv.hostPlatform.avx2Support then "enable" else "disable"}-avx2" - "--${if stdenv.hostPlatform.fmaSupport then "enable" else "disable"}-fma" - "--${if stdenv.hostPlatform.fma4Support then "enable" else "disable"}-fma4" - ]; + configureFlags = + [ + "--without-archnative" + ] + ++ lib.optionals stdenv.hostPlatform.isx86_64 [ + # disable SIMD instructions (which are enabled *when available* by default) + "--${if stdenv.hostPlatform.sse3Support then "enable" else "disable"}-sse3" + "--${if stdenv.hostPlatform.ssse3Support then "enable" else "disable"}-ssse3" + "--${if stdenv.hostPlatform.sse4_1Support then "enable" else "disable"}-sse41" + "--${if stdenv.hostPlatform.sse4_2Support then "enable" else "disable"}-sse42" + "--${if stdenv.hostPlatform.avxSupport then "enable" else "disable"}-avx" + "--${if stdenv.hostPlatform.avx2Support then "enable" else "disable"}-avx2" + "--${if stdenv.hostPlatform.fmaSupport then "enable" else "disable"}-fma" + "--${if stdenv.hostPlatform.fma4Support then "enable" else "disable"}-fma4" + ]; # On darwin, tests are linked to dylib in the nix store, so we need to make # sure tests run after installPhase. @@ -62,7 +69,7 @@ stdenv.mkDerivation rec { description = "C++ library for arithmetic and algebraic computations"; mainProgram = "givaro-config"; license = lib.licenses.cecill-b; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.unix; }; } diff --git a/pkgs/development/libraries/glew/1.10.nix b/pkgs/development/libraries/glew/1.10.nix index a675eebaa3428d..f6198467aeecf2 100644 --- a/pkgs/development/libraries/glew/1.10.nix +++ b/pkgs/development/libraries/glew/1.10.nix @@ -1,7 +1,15 @@ -{ lib, stdenv, fetchurl, libGLU, libXmu, libXi, libXext -, AGL, OpenGL -, testers -, mesa +{ + lib, + stdenv, + fetchurl, + libGLU, + libXmu, + libXi, + libXext, + AGL, + OpenGL, + testers, + mesa, }: stdenv.mkDerivation (finalAttrs: { @@ -13,15 +21,26 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "01zki46dr5khzlyywr3cg615bcal32dazfazkf360s1znqh17i4r"; }; - buildInputs = if stdenv.hostPlatform.isDarwin then [ AGL ] else [ libXmu libXi libXext ]; + buildInputs = + if stdenv.hostPlatform.isDarwin then + [ AGL ] + else + [ + libXmu + libXi + libXext + ]; propagatedBuildInputs = if stdenv.hostPlatform.isDarwin then [ OpenGL ] else [ libGLU ]; # GL/glew.h includes GL/glu.h - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; patchPhase = '' sed -i 's|lib64|lib|' config/Makefile.linux ${lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' - sed -i -e 's/\(INSTALL.*\)-s/\1/' Makefile + sed -i -e 's/\(INSTALL.*\)-s/\1/' Makefile ''} ''; @@ -51,7 +70,7 @@ stdenv.mkDerivation (finalAttrs: { description = "OpenGL extension loading library for C(++)"; homepage = "https://glew.sourceforge.net/"; license = licenses.free; # different files under different licenses - #["BSD" "GLX" "SGI-B" "GPL2"] + #["BSD" "GLX" "SGI-B" "GPL2"] pkgConfigModules = [ "glew" ]; inherit (mesa.meta) platforms; }; diff --git a/pkgs/development/libraries/glew/default.nix b/pkgs/development/libraries/glew/default.nix index 8d68ad08676442..00a148c9df28e2 100644 --- a/pkgs/development/libraries/glew/default.nix +++ b/pkgs/development/libraries/glew/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, cmake -, libGLU -, libXmu -, libXi -, libXext -, OpenGL -, enableEGL ? (!stdenv.hostPlatform.isDarwin) -, testers -, mesa +{ + lib, + stdenv, + fetchurl, + fetchpatch, + cmake, + libGLU, + libXmu, + libXi, + libXext, + OpenGL, + enableEGL ? (!stdenv.hostPlatform.isDarwin), + testers, + mesa, }: stdenv.mkDerivation (finalAttrs: { @@ -22,7 +23,11 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "1qak8f7g1iswgswrgkzc7idk7jmqgwrs58fhg2ai007v7j4q5z6l"; }; - outputs = [ "bin" "out" "dev" ]; + outputs = [ + "bin" + "out" + "dev" + ]; patches = [ # https://github.com/nigels-com/glew/pull/342 @@ -40,7 +45,11 @@ stdenv.mkDerivation (finalAttrs: { ]; nativeBuildInputs = [ cmake ]; - buildInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ libXmu libXi libXext ]; + buildInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libXmu + libXi + libXext + ]; propagatedBuildInputs = if stdenv.hostPlatform.isDarwin then [ OpenGL ] else [ libGLU ]; # GL/glew.h includes GL/glu.h cmakeDir = "cmake"; @@ -71,12 +80,15 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "OpenGL extension loading library for C/C++"; homepage = "https://glew.sourceforge.net/"; - license = with licenses; [ /* modified bsd */ free mit gpl2Only ]; # For full details, see https://github.com/nigels-com/glew#copyright-and-licensing + license = with licenses; [ + # modified bsd + free + mit + gpl2Only + ]; # For full details, see https://github.com/nigels-com/glew#copyright-and-licensing pkgConfigModules = [ "glew" ]; - platforms = with platforms; - if enableEGL then - subtractLists darwin mesa.meta.platforms - else - mesa.meta.platforms; + platforms = + with platforms; + if enableEGL then subtractLists darwin mesa.meta.platforms else mesa.meta.platforms; }; }) diff --git a/pkgs/development/libraries/glfw/2.x.nix b/pkgs/development/libraries/glfw/2.x.nix index 545e7a418a5f55..cef83c64cad5d5 100644 --- a/pkgs/development/libraries/glfw/2.x.nix +++ b/pkgs/development/libraries/glfw/2.x.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, libGLU, libGL, libX11, libXext }: +{ + lib, + stdenv, + fetchurl, + libGLU, + libGL, + libX11, + libXext, +}: stdenv.mkDerivation rec { pname = "glfw"; @@ -9,7 +17,12 @@ stdenv.mkDerivation rec { sha256 = "17c2msdcb7pn3p8f83805h1c216bmdqnbn9hgzr1j8wnwjcpxx6i"; }; - buildInputs = [ libGLU libGL libX11 libXext ]; + buildInputs = [ + libGLU + libGL + libX11 + libXext + ]; buildPhase = '' make x11 diff --git a/pkgs/development/libraries/glibc/common.nix b/pkgs/development/libraries/glibc/common.nix index 09dde042848b45..fd9050525f96b4 100644 --- a/pkgs/development/libraries/glibc/common.nix +++ b/pkgs/development/libraries/glibc/common.nix @@ -1,4 +1,5 @@ -/* Build configuration used to build glibc, Info files, and locale +/* + Build configuration used to build glibc, Info files, and locale information. Note that this derivation has multiple outputs and does not respect the @@ -22,26 +23,30 @@ # cgit) that are needed here should be included directly in Nixpkgs as # files. -{ stdenv, lib -, buildPackages -, fetchurl -, linuxHeaders ? null -, gd ? null, libpng ? null -, libidn2 -, bison -, python3Minimal +{ + stdenv, + lib, + buildPackages, + fetchurl, + linuxHeaders ? null, + gd ? null, + libpng ? null, + libidn2, + bison, + python3Minimal, }: -{ pname -, withLinuxHeaders ? false -, profilingLibraries ? false -, withGd ? false -, enableCET ? false -, enableCETRuntimeDefault ? false -, extraBuildInputs ? [] -, extraNativeBuildInputs ? [] -, ... -} @ args: +{ + pname, + withLinuxHeaders ? false, + profilingLibraries ? false, + withGd ? false, + enableCET ? false, + enableCETRuntimeDefault ? false, + extraBuildInputs ? [ ], + extraNativeBuildInputs ? [ ], + ... +}@args: let version = "2.40"; @@ -53,248 +58,297 @@ assert withLinuxHeaders -> linuxHeaders != null; assert withGd -> gd != null && libpng != null; assert enableCET == false -> !enableCETRuntimeDefault; -stdenv.mkDerivation ({ - version = version + patchSuffix; - - enableParallelBuilding = true; - - patches = - [ - /* No tarballs for stable upstream branch, only https://sourceware.org/git/glibc.git and using git would complicate bootstrapping. - $ git fetch --all -p && git checkout origin/release/2.39/master && git describe - glibc-2.40-36-g7073164add - $ git show --minimal --reverse glibc-2.40.. ':!ADVISORIES' > 2.40-master.patch - - To compare the archive contents zdiff can be used. - $ diff -u 2.40-master.patch ../nixpkgs/pkgs/development/libraries/glibc/2.40-master.patch - - Please note that each commit has changes to the file ADVISORIES excluded since - that conflicts with the directory advisories/ making cross-builds from - hosts with case-insensitive file-systems impossible. - */ - ./2.40-master.patch - - /* Allow NixOS and Nix to handle the locale-archive. */ - ./nix-locale-archive.patch - - /* Don't use /etc/ld.so.cache, for non-NixOS systems. */ - ./dont-use-system-ld-so-cache.patch - - /* Don't use /etc/ld.so.preload, but /etc/ld-nix.so.preload. */ - ./dont-use-system-ld-so-preload.patch - - /* The command "getconf CS_PATH" returns the default search path - "/bin:/usr/bin", which is inappropriate on NixOS machines. This - patch extends the search path by "/run/current-system/sw/bin". */ - ./fix_path_attribute_in_getconf.patch - - ./fix-x64-abi.patch - - /* https://github.com/NixOS/nixpkgs/pull/137601 */ - ./nix-nss-open-files.patch - - ./0001-Revert-Remove-all-usage-of-BASH-or-BASH-in-installed.patch - - /* Patch derived from archlinux, - https://gitlab.archlinux.org/archlinux/packaging/packages/glibc/-/blob/e54d98e2d1aae4930ecad9404ef12234922d9dfd/reenable_DT_HASH.patch - - See also https://github.com/ValveSoftware/Proton/issues/6051 - & https://github.com/NixOS/nixpkgs/pull/188492#issuecomment-1233802991 +stdenv.mkDerivation ( + { + version = version + patchSuffix; + + enableParallelBuilding = true; + + patches = + [ + /* + No tarballs for stable upstream branch, only https://sourceware.org/git/glibc.git and using git would complicate bootstrapping. + $ git fetch --all -p && git checkout origin/release/2.39/master && git describe + glibc-2.40-36-g7073164add + $ git show --minimal --reverse glibc-2.40.. ':!ADVISORIES' > 2.40-master.patch + + To compare the archive contents zdiff can be used. + $ diff -u 2.40-master.patch ../nixpkgs/pkgs/development/libraries/glibc/2.40-master.patch + + Please note that each commit has changes to the file ADVISORIES excluded since + that conflicts with the directory advisories/ making cross-builds from + hosts with case-insensitive file-systems impossible. + */ + ./2.40-master.patch + + # Allow NixOS and Nix to handle the locale-archive. + ./nix-locale-archive.patch + + # Don't use /etc/ld.so.cache, for non-NixOS systems. + ./dont-use-system-ld-so-cache.patch + + # Don't use /etc/ld.so.preload, but /etc/ld-nix.so.preload. + ./dont-use-system-ld-so-preload.patch + + /* + The command "getconf CS_PATH" returns the default search path + "/bin:/usr/bin", which is inappropriate on NixOS machines. This + patch extends the search path by "/run/current-system/sw/bin". + */ + ./fix_path_attribute_in_getconf.patch + + ./fix-x64-abi.patch + + # https://github.com/NixOS/nixpkgs/pull/137601 + ./nix-nss-open-files.patch + + ./0001-Revert-Remove-all-usage-of-BASH-or-BASH-in-installed.patch + + /* + Patch derived from archlinux, + https://gitlab.archlinux.org/archlinux/packaging/packages/glibc/-/blob/e54d98e2d1aae4930ecad9404ef12234922d9dfd/reenable_DT_HASH.patch + + See also https://github.com/ValveSoftware/Proton/issues/6051 + & https://github.com/NixOS/nixpkgs/pull/188492#issuecomment-1233802991 + */ + ./reenable_DT_HASH.patch + ] + /* + NVCC does not support ARM intrinsics. Since is pulled in by almost + every HPC piece of software, without this patch CUDA compilation on ARM + is effectively broken. See + https://forums.developer.nvidia.com/t/nvcc-fails-to-build-with-arm-neon-instructions-cpp-vs-cu/248355/2. */ - ./reenable_DT_HASH.patch - ] - /* NVCC does not support ARM intrinsics. Since is pulled in by almost - every HPC piece of software, without this patch CUDA compilation on ARM - is effectively broken. See - https://forums.developer.nvidia.com/t/nvcc-fails-to-build-with-arm-neon-instructions-cpp-vs-cu/248355/2. - */ - ++ ( - let - isAarch64 = stdenv.buildPlatform.isAarch64 || stdenv.hostPlatform.isAarch64; - isLinux = stdenv.buildPlatform.isLinux || stdenv.hostPlatform.isLinux; - in - lib.optional (isAarch64 && isLinux) ./0001-aarch64-math-vector.h-add-NVCC-include-guard.patch - ) - ++ lib.optional stdenv.hostPlatform.isMusl ./fix-rpc-types-musl-conflicts.patch - ++ lib.optional stdenv.buildPlatform.isDarwin ./darwin-cross-build.patch - ++ lib.optional enableCETRuntimeDefault ./2.39-revert-cet-default-disable.patch; - - postPatch = - '' - # Needed for glibc to build with the gnumake 3.82 - # http://comments.gmane.org/gmane.linux.lfs.support/31227 - sed -i 's/ot \$/ot:\n\ttouch $@\n$/' manual/Makefile - - # nscd needs libgcc, and we don't want it dynamically linked - # because we don't want it to depend on bootstrap-tools libs. - echo "LDFLAGS-nscd += -static-libgcc" >> nscd/Makefile - - # Ensure that `__nss_files_fopen` can still be wrapped by `libredirect`. - sed -i -e '/libc_hidden_def (__nss_files_fopen)/d' nss/nss_files_fopen.c - sed -i -e '/libc_hidden_proto (__nss_files_fopen)/d' include/nss_files.h - '' - # FIXME: find a solution for infinite recursion in cross builds. - # For now it's hopefully acceptable that IDN from libc doesn't reliably work. - + lib.optionalString (stdenv.hostPlatform == stdenv.buildPlatform) '' - - # Ensure that libidn2 is found. - patch -p 1 <> nscd/Makefile + + # Ensure that `__nss_files_fopen` can still be wrapped by `libredirect`. + sed -i -e '/libc_hidden_def (__nss_files_fopen)/d' nss/nss_files_fopen.c + sed -i -e '/libc_hidden_proto (__nss_files_fopen)/d' include/nss_files.h + '' + # FIXME: find a solution for infinite recursion in cross builds. + # For now it's hopefully acceptable that IDN from libc doesn't reliably work. + + lib.optionalString (stdenv.hostPlatform == stdenv.buildPlatform) '' + + # Ensure that libidn2 is found. + patch -p 1 < config.cache << "EOF" + libc_cv_forced_unwind=yes + libc_cv_c_cleanup=yes + libc_cv_gnu89_inline=yes + EOF + + # ./configure has logic like + # + # AR=`$CC -print-prog-name=ar` + # + # This searches various directories in the gcc and its wrapper. In nixpkgs, + # this returns the bare string "ar", which is build ar. This can result as + # a build failure with the following message: + # + # libc_pic.a: error adding symbols: archive has no index; run ranlib to add one + # + # (Observed cross compiling from aarch64-linux -> armv7l-linux). + # + # Nixpkgs passes a correct value for AR and friends, so to use the correct + # set of tools, we only need to delete this special handling. + sed -i \ + -e '/^AR=/d' \ + -e '/^AS=/d' \ + -e '/^LD=/d' \ + -e '/^OBJCOPY=/d' \ + -e '/^OBJDUMP=/d' \ + $configureScript + ''; + + preBuild = lib.optionalString withGd "unset NIX_DONT_SET_RPATH"; + + doCheck = false; # fails + + meta = + with lib; + { + homepage = "https://www.gnu.org/software/libc/"; + description = "GNU C Library"; + + longDescription = '' + Any Unix-like operating system needs a C library: the library which + defines the "system calls" and other basic facilities such as + open, malloc, printf, exit... + + The GNU C library is used as the C library in the GNU system and + most systems with the Linux kernel. + ''; + + license = licenses.lgpl2Plus; + + maintainers = with maintainers; [ + ma27 + connorbaker + ]; + platforms = platforms.linux; + } + // (args.meta or { }); } - - - '' + lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' - sed -i s/-lgcc_eh//g "../$sourceRoot/Makeconfig" - - cat > config.cache << "EOF" - libc_cv_forced_unwind=yes - libc_cv_c_cleanup=yes - libc_cv_gnu89_inline=yes - EOF - - # ./configure has logic like - # - # AR=`$CC -print-prog-name=ar` - # - # This searches various directories in the gcc and its wrapper. In nixpkgs, - # this returns the bare string "ar", which is build ar. This can result as - # a build failure with the following message: - # - # libc_pic.a: error adding symbols: archive has no index; run ranlib to add one - # - # (Observed cross compiling from aarch64-linux -> armv7l-linux). - # - # Nixpkgs passes a correct value for AR and friends, so to use the correct - # set of tools, we only need to delete this special handling. - sed -i \ - -e '/^AR=/d' \ - -e '/^AS=/d' \ - -e '/^LD=/d' \ - -e '/^OBJCOPY=/d' \ - -e '/^OBJDUMP=/d' \ - $configureScript - ''; - - preBuild = lib.optionalString withGd "unset NIX_DONT_SET_RPATH"; - - doCheck = false; # fails - - meta = with lib; { - homepage = "https://www.gnu.org/software/libc/"; - description = "GNU C Library"; - - longDescription = '' - Any Unix-like operating system needs a C library: the library which - defines the "system calls" and other basic facilities such as - open, malloc, printf, exit... - - The GNU C library is used as the C library in the GNU system and - most systems with the Linux kernel. - ''; - - license = licenses.lgpl2Plus; - - maintainers = with maintainers; [ ma27 connorbaker ]; - platforms = platforms.linux; - } // (args.meta or {}); -}) +) diff --git a/pkgs/development/libraries/glibc/default.nix b/pkgs/development/libraries/glibc/default.nix index 532dfd58900f4e..46d28aea307c8c 100644 --- a/pkgs/development/libraries/glibc/default.nix +++ b/pkgs/development/libraries/glibc/default.nix @@ -1,11 +1,14 @@ -{ lib, stdenv, callPackage -, withLinuxHeaders ? true -, profilingLibraries ? false -, withGd ? false -, enableCET ? if stdenv.hostPlatform.isx86_64 then "permissive" else false -, enableCETRuntimeDefault ? false -, pkgsBuildBuild -, libgcc +{ + lib, + stdenv, + callPackage, + withLinuxHeaders ? true, + profilingLibraries ? false, + withGd ? false, + enableCET ? if stdenv.hostPlatform.isx86_64 then "permissive" else false, + enableCETRuntimeDefault ? false, + pkgsBuildBuild, + libgcc, }: let @@ -17,9 +20,19 @@ let in (callPackage ./common.nix { inherit stdenv; } { - inherit withLinuxHeaders withGd profilingLibraries enableCET enableCETRuntimeDefault; - pname = "glibc" + lib.optionalString withGd "-gd" + lib.optionalString (stdenv.cc.isGNU && libgcc==null) "-nolibgcc"; -}).overrideAttrs(previousAttrs: { + inherit + withLinuxHeaders + withGd + profilingLibraries + enableCET + enableCETRuntimeDefault + ; + pname = + "glibc" + + lib.optionalString withGd "-gd" + + lib.optionalString (stdenv.cc.isGNU && libgcc == null) "-nolibgcc"; +}).overrideAttrs + (previousAttrs: { # Note: # Things you write here override, and do not add to, @@ -47,29 +60,36 @@ in # The pie, stackprotector and fortify hardening flags are autodetected by # glibc and enabled by default if supported. Setting it for every gcc # invocation does not work. - hardeningDisable = [ "fortify" "pie" "stackprotector" ]; + hardeningDisable = [ + "fortify" + "pie" + "stackprotector" + ]; env = (previousAttrs.env or { }) // { - NIX_CFLAGS_COMPILE = (previousAttrs.env.NIX_CFLAGS_COMPILE or "") + lib.concatStringsSep " " - (builtins.concatLists [ - (lib.optionals withGd gdCflags) - # Fix -Werror build failure when building glibc with musl with GCC >= 8, see: - # https://github.com/NixOS/nixpkgs/pull/68244#issuecomment-544307798 - (lib.optional stdenv.hostPlatform.isMusl "-Wno-error=attribute-alias") - (lib.optionals ((stdenv.hostPlatform != stdenv.buildPlatform) || stdenv.hostPlatform.isMusl) [ - # Ignore "error: '__EI___errno_location' specifies less restrictive attributes than its target '__errno_location'" - # New warning as of GCC 9 - # Same for musl: https://github.com/NixOS/nixpkgs/issues/78805 - "-Wno-error=missing-attributes" - ]) - (lib.optionals (stdenv.hostPlatform.isPower64) [ - # Do not complain about the Processor Specific ABI (i.e. the - # choice to use IEEE-standard `long double`). We pass this - # flag in order to mute a `-Werror=psabi` passed by glibc; - # hopefully future glibc releases will not pass that flag. - "-Wno-error=psabi" - ]) - ]); + NIX_CFLAGS_COMPILE = + (previousAttrs.env.NIX_CFLAGS_COMPILE or "") + + lib.concatStringsSep " " ( + builtins.concatLists [ + (lib.optionals withGd gdCflags) + # Fix -Werror build failure when building glibc with musl with GCC >= 8, see: + # https://github.com/NixOS/nixpkgs/pull/68244#issuecomment-544307798 + (lib.optional stdenv.hostPlatform.isMusl "-Wno-error=attribute-alias") + (lib.optionals ((stdenv.hostPlatform != stdenv.buildPlatform) || stdenv.hostPlatform.isMusl) [ + # Ignore "error: '__EI___errno_location' specifies less restrictive attributes than its target '__errno_location'" + # New warning as of GCC 9 + # Same for musl: https://github.com/NixOS/nixpkgs/issues/78805 + "-Wno-error=missing-attributes" + ]) + (lib.optionals (stdenv.hostPlatform.isPower64) [ + # Do not complain about the Processor Specific ABI (i.e. the + # choice to use IEEE-standard `long double`). We pass this + # flag in order to mute a `-Werror=psabi` passed by glibc; + # hopefully future glibc releases will not pass that flag. + "-Wno-error=psabi" + ]) + ] + ); }; # glibc needs to `dlopen()` `libgcc_s.so` but does not link @@ -88,98 +108,109 @@ in # gcc.libgcc, since the path will be embedded in the resulting binary. # makeFlags = - (previousAttrs.makeFlags or []) + (previousAttrs.makeFlags or [ ]) ++ lib.optionals (libgcc != null) [ "user-defined-trusted-dirs=${libgcc}/lib" ]; - postInstall = previousAttrs.postInstall + (if stdenv.buildPlatform.canExecute stdenv.hostPlatform then '' - echo SUPPORTED-LOCALES=C.UTF-8/UTF-8 > ../glibc-2*/localedata/SUPPORTED - make -j''${NIX_BUILD_CORES:-1} localedata/install-locales - '' else lib.optionalString stdenv.buildPlatform.isLinux - # This is based on http://www.linuxfromscratch.org/lfs/view/development/chapter06/glibc.html - # Instead of using their patch to build a build-native localedef, - # we simply use the one from pkgsBuildBuild. - # - # Note that we can't use pkgsBuildHost (aka buildPackages) here, because - # that will cause an eval-time infinite recursion: "buildPackages.glibc - # depended on buildPackages.libgcc, which, since it's GCC, depends on the - # target's bintools, which depend on the target's glibc, which, again, - # depends on buildPackages.glibc, causing an infinute recursion when - # evaluating buildPackages.glibc when glibc hasn't come from stdenv - # (e.g. on musl)." https://github.com/NixOS/nixpkgs/pull/259964 - '' - pushd ../glibc-2*/localedata - export I18NPATH=$PWD GCONV_PATH=$PWD/../iconvdata - mkdir -p $NIX_BUILD_TOP/${pkgsBuildBuild.glibc}/lib/locale - ${lib.getBin pkgsBuildBuild.glibc}/bin/localedef \ - --alias-file=../intl/locale.alias \ - -i locales/C \ - -f charmaps/UTF-8 \ - --prefix $NIX_BUILD_TOP \ - ${if stdenv.hostPlatform.parsed.cpu.significantByte.name == "littleEndian" then - "--little-endian" - else - "--big-endian"} \ - C.UTF-8 - cp -r $NIX_BUILD_TOP/${pkgsBuildBuild.glibc}/lib/locale $out/lib - popd - '') + '' - - test -f $out/etc/ld.so.cache && rm $out/etc/ld.so.cache - - if test -n "$linuxHeaders"; then - # Include the Linux kernel headers in Glibc, except the `scsi' - # subdirectory, which Glibc provides itself. - (cd $dev/include && \ - ln -sv $(ls -d $linuxHeaders/include/* | grep -v scsi\$) .) - fi - - # Fix for NIXOS-54 (ldd not working on x86_64). Make a symlink - # "lib64" to "lib". - if test -n "$is64bit"; then - ln -s lib $out/lib64 - fi - - # Get rid of more unnecessary stuff. - rm -rf $out/var $bin/bin/sln - - # Backwards-compatibility to fix e.g. - # "configure: error: Pthreads are required to build libgomp" during `gcc`-build - # because it's not actually needed anymore to link against `pthreads` since - # it's now part of `libc.so.6` itself, but the gcc build breaks if - # this doesn't work. - ln -sf $out/lib/libpthread.so.0 $out/lib/libpthread.so - ln -sf $out/lib/librt.so.1 $out/lib/librt.so - ln -sf $out/lib/libdl.so.2 $out/lib/libdl.so - test -f $out/lib/libutil.so.1 && ln -sf $out/lib/libutil.so.1 $out/lib/libutil.so - touch $out/lib/libpthread.a - - # Put libraries for static linking in a separate output. Note - # that libc_nonshared.a and libpthread_nonshared.a are required - # for dynamically-linked applications. - mkdir -p $static/lib - mv $out/lib/*.a $static/lib - mv $static/lib/lib*_nonshared.a $out/lib - # If libutil.so.1 is missing, libutil.a is required. - test -f $out/lib/libutil.so.1 || mv $static/lib/libutil.a $out/lib - # Some of *.a files are linker scripts where moving broke the paths. - sed "/^GROUP/s|$out/lib/lib|$static/lib/lib|g" \ - -i "$static"/lib/*.a - - # Work around a Nix bug: hard links across outputs cause a build failure. - cp $bin/bin/getconf $bin/bin/getconf_ - mv $bin/bin/getconf_ $bin/bin/getconf - ''; + postInstall = + previousAttrs.postInstall + + ( + if stdenv.buildPlatform.canExecute stdenv.hostPlatform then + '' + echo SUPPORTED-LOCALES=C.UTF-8/UTF-8 > ../glibc-2*/localedata/SUPPORTED + make -j''${NIX_BUILD_CORES:-1} localedata/install-locales + '' + else + lib.optionalString stdenv.buildPlatform.isLinux + # This is based on http://www.linuxfromscratch.org/lfs/view/development/chapter06/glibc.html + # Instead of using their patch to build a build-native localedef, + # we simply use the one from pkgsBuildBuild. + # + # Note that we can't use pkgsBuildHost (aka buildPackages) here, because + # that will cause an eval-time infinite recursion: "buildPackages.glibc + # depended on buildPackages.libgcc, which, since it's GCC, depends on the + # target's bintools, which depend on the target's glibc, which, again, + # depends on buildPackages.glibc, causing an infinute recursion when + # evaluating buildPackages.glibc when glibc hasn't come from stdenv + # (e.g. on musl)." https://github.com/NixOS/nixpkgs/pull/259964 + '' + pushd ../glibc-2*/localedata + export I18NPATH=$PWD GCONV_PATH=$PWD/../iconvdata + mkdir -p $NIX_BUILD_TOP/${pkgsBuildBuild.glibc}/lib/locale + ${lib.getBin pkgsBuildBuild.glibc}/bin/localedef \ + --alias-file=../intl/locale.alias \ + -i locales/C \ + -f charmaps/UTF-8 \ + --prefix $NIX_BUILD_TOP \ + ${ + if stdenv.hostPlatform.parsed.cpu.significantByte.name == "littleEndian" then + "--little-endian" + else + "--big-endian" + } \ + C.UTF-8 + cp -r $NIX_BUILD_TOP/${pkgsBuildBuild.glibc}/lib/locale $out/lib + popd + '' + ) + + '' + + test -f $out/etc/ld.so.cache && rm $out/etc/ld.so.cache + + if test -n "$linuxHeaders"; then + # Include the Linux kernel headers in Glibc, except the `scsi' + # subdirectory, which Glibc provides itself. + (cd $dev/include && \ + ln -sv $(ls -d $linuxHeaders/include/* | grep -v scsi\$) .) + fi + + # Fix for NIXOS-54 (ldd not working on x86_64). Make a symlink + # "lib64" to "lib". + if test -n "$is64bit"; then + ln -s lib $out/lib64 + fi + + # Get rid of more unnecessary stuff. + rm -rf $out/var $bin/bin/sln + + # Backwards-compatibility to fix e.g. + # "configure: error: Pthreads are required to build libgomp" during `gcc`-build + # because it's not actually needed anymore to link against `pthreads` since + # it's now part of `libc.so.6` itself, but the gcc build breaks if + # this doesn't work. + ln -sf $out/lib/libpthread.so.0 $out/lib/libpthread.so + ln -sf $out/lib/librt.so.1 $out/lib/librt.so + ln -sf $out/lib/libdl.so.2 $out/lib/libdl.so + test -f $out/lib/libutil.so.1 && ln -sf $out/lib/libutil.so.1 $out/lib/libutil.so + touch $out/lib/libpthread.a + + # Put libraries for static linking in a separate output. Note + # that libc_nonshared.a and libpthread_nonshared.a are required + # for dynamically-linked applications. + mkdir -p $static/lib + mv $out/lib/*.a $static/lib + mv $static/lib/lib*_nonshared.a $out/lib + # If libutil.so.1 is missing, libutil.a is required. + test -f $out/lib/libutil.so.1 || mv $static/lib/libutil.a $out/lib + # Some of *.a files are linker scripts where moving broke the paths. + sed "/^GROUP/s|$out/lib/lib|$static/lib/lib|g" \ + -i "$static"/lib/*.a + + # Work around a Nix bug: hard links across outputs cause a build failure. + cp $bin/bin/getconf $bin/bin/getconf_ + mv $bin/bin/getconf_ $bin/bin/getconf + ''; separateDebugInfo = true; passthru = - (previousAttrs.passthru or {}) + (previousAttrs.passthru or { }) // lib.optionalAttrs (libgcc != null) { inherit libgcc; }; - meta = (previousAttrs.meta or {}) // { description = "GNU C Library"; }; -}) - + meta = (previousAttrs.meta or { }) // { + description = "GNU C Library"; + }; + }) diff --git a/pkgs/development/libraries/glibc/info.nix b/pkgs/development/libraries/glibc/info.nix index d643d8a6ba09ff..380ee25907a203 100644 --- a/pkgs/development/libraries/glibc/info.nix +++ b/pkgs/development/libraries/glibc/info.nix @@ -1,13 +1,20 @@ -{ callPackage, texinfo, perl }: +{ + callPackage, + texinfo, + perl, +}: -callPackage ./common.nix {} { +callPackage ./common.nix { } { pname = "glibc-info"; outputs = [ "out" ]; configureFlags = [ "--enable-add-ons" ]; - extraNativeBuildInputs = [ texinfo perl ]; + extraNativeBuildInputs = [ + texinfo + perl + ]; makeFlags = [ "info" ]; diff --git a/pkgs/development/libraries/glibc/multi.nix b/pkgs/development/libraries/glibc/multi.nix index 5cd48958ec2ca6..002c5aa35fb374 100644 --- a/pkgs/development/libraries/glibc/multi.nix +++ b/pkgs/development/libraries/glibc/multi.nix @@ -1,5 +1,8 @@ -{ lib -, runCommand, glibc, glibc32 +{ + lib, + runCommand, + glibc, + glibc32, }: let @@ -9,9 +12,13 @@ in runCommand "${nameVersion.name}-multi-${nameVersion.version}" # out as the first output is an exception exclusive to glibc { - outputs = [ "out" "bin" "dev" ]; # TODO: no static version here (yet) + outputs = [ + "out" + "bin" + "dev" + ]; # TODO: no static version here (yet) passthru = { - libgcc = lib.lists.filter (x: x!=null) [ + libgcc = lib.lists.filter (x: x != null) [ (glibc64.libgcc or null) (glibc32.libgcc or null) ]; diff --git a/pkgs/development/libraries/glibmm/2.68.nix b/pkgs/development/libraries/glibmm/2.68.nix index 0427280fcc428d..cb7054fe3398dd 100644 --- a/pkgs/development/libraries/glibmm/2.68.nix +++ b/pkgs/development/libraries/glibmm/2.68.nix @@ -1,21 +1,25 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gnum4 -, glib -, libsigcxx30 -, gnome -, Cocoa -, meson -, ninja +{ + lib, + stdenv, + fetchurl, + pkg-config, + gnum4, + glib, + libsigcxx30, + gnome, + Cocoa, + meson, + ninja, }: stdenv.mkDerivation rec { pname = "glibmm"; version = "2.82.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/development/libraries/glibmm/default.nix b/pkgs/development/libraries/glibmm/default.nix index 668f60ec10ec32..732c3d77c4e257 100644 --- a/pkgs/development/libraries/glibmm/default.nix +++ b/pkgs/development/libraries/glibmm/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, pkg-config, gnum4, glib, libsigcxx, gnome, darwin, meson, ninja }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gnum4, + glib, + libsigcxx, + gnome, + darwin, + meson, + ninja, +}: stdenv.mkDerivation rec { pname = "glibmm"; @@ -9,7 +21,10 @@ stdenv.mkDerivation rec { hash = "sha256-/gLB5fWCWUDYK1a27DGhLAbAXBWDz+Yvk00HY+HlQrM="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ meson @@ -19,10 +34,16 @@ stdenv.mkDerivation rec { glib # for glib-compile-schemas ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - Cocoa - ]); - propagatedBuildInputs = [ glib libsigcxx ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Cocoa + ] + ); + propagatedBuildInputs = [ + glib + libsigcxx + ]; doCheck = false; # fails. one test needs the net, another /etc/fstab @@ -41,7 +62,7 @@ stdenv.mkDerivation rec { license = licenses.lgpl2Plus; - maintainers = with maintainers; [raskin]; + maintainers = with maintainers; [ raskin ]; platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/gmime/2.nix b/pkgs/development/libraries/gmime/2.nix index e004437a77644c..313a2a8f1c5189 100644 --- a/pkgs/development/libraries/gmime/2.nix +++ b/pkgs/development/libraries/gmime/2.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, zlib, gnupg, libgpg-error, gobject-introspection }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + zlib, + gnupg, + libgpg-error, + gobject-introspection, +}: stdenv.mkDerivation rec { version = "2.6.23"; @@ -9,13 +19,25 @@ stdenv.mkDerivation rec { sha256 = "0slzlzcr3h8jikpz5a5amqd0csqh2m40gdk910ws2hnaf5m6hjbi"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ pkg-config gobject-introspection ]; - propagatedBuildInputs = [ glib zlib libgpg-error ]; - configureFlags = [ - "--enable-introspection=yes" - ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ "ac_cv_have_iconv_detect_h=yes" ]; + nativeBuildInputs = [ + pkg-config + gobject-introspection + ]; + propagatedBuildInputs = [ + glib + zlib + libgpg-error + ]; + configureFlags = + [ + "--enable-introspection=yes" + ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ "ac_cv_have_iconv_detect_h=yes" ]; postPatch = '' substituteInPlace tests/testsuite.c \ @@ -27,7 +49,9 @@ stdenv.mkDerivation rec { ''; preConfigure = lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' - cp ${if stdenv.hostPlatform.isMusl then ./musl-iconv-detect.h else ./iconv-detect.h} ./iconv-detect.h + cp ${ + if stdenv.hostPlatform.isMusl then ./musl-iconv-detect.h else ./iconv-detect.h + } ./iconv-detect.h ''; nativeCheckInputs = [ gnupg ]; diff --git a/pkgs/development/libraries/gmp/4.3.2.nix b/pkgs/development/libraries/gmp/4.3.2.nix index 2700dad0db09b3..00dbd620e3f221 100644 --- a/pkgs/development/libraries/gmp/4.3.2.nix +++ b/pkgs/development/libraries/gmp/4.3.2.nix @@ -1,78 +1,95 @@ -{ lib, stdenv, fetchurl, m4, cxx ? true }: +{ + lib, + stdenv, + fetchurl, + m4, + cxx ? true, +}: -let self = stdenv.mkDerivation rec { - pname = "gmp"; - version = "4.3.2"; +let + self = stdenv.mkDerivation rec { + pname = "gmp"; + version = "4.3.2"; - src = fetchurl { - url = "mirror://gnu/gmp/gmp-${version}.tar.bz2"; - sha256 = "0x8prpqi9amfcmi7r4zrza609ai9529pjaq0h4aw51i867064qck"; - }; + src = fetchurl { + url = "mirror://gnu/gmp/gmp-${version}.tar.bz2"; + sha256 = "0x8prpqi9amfcmi7r4zrza609ai9529pjaq0h4aw51i867064qck"; + }; - #outputs TODO: split $cxx due to libstdc++ dependency - # maybe let ghc use a version with *.so shared with rest of nixpkgs and *.a added - # - see #5855 for related discussion - outputs = [ "out" "dev" "info" ]; - passthru.static = self.out; + #outputs TODO: split $cxx due to libstdc++ dependency + # maybe let ghc use a version with *.so shared with rest of nixpkgs and *.a added + # - see #5855 for related discussion + outputs = [ + "out" + "dev" + "info" + ]; + passthru.static = self.out; - nativeBuildInputs = [ m4 ]; + nativeBuildInputs = [ m4 ]; - # Prevent the build system from using sub-architecture-specific - # instructions (e.g., SSE2 on i686). - # - # This is not a problem for Apple machines, which are all alike. In - # addition, `configfsf.guess' would return `i386-apple-darwin10.2.0' on - # `x86_64-darwin', leading to a 32-bit ABI build, which is undesirable. - preConfigure = - if !stdenv.hostPlatform.isDarwin - then "ln -sf configfsf.guess config.guess" - else ''echo "Darwin host is `./config.guess`."''; + # Prevent the build system from using sub-architecture-specific + # instructions (e.g., SSE2 on i686). + # + # This is not a problem for Apple machines, which are all alike. In + # addition, `configfsf.guess' would return `i386-apple-darwin10.2.0' on + # `x86_64-darwin', leading to a 32-bit ABI build, which is undesirable. + preConfigure = + if !stdenv.hostPlatform.isDarwin then + "ln -sf configfsf.guess config.guess" + else + ''echo "Darwin host is `./config.guess`."''; - configureFlags = [ - (lib.enableFeature cxx "cxx") - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "ac_cv_build=x86_64-apple-darwin13.4.0" - "ac_cv_host=x86_64-apple-darwin13.4.0" - ]; + configureFlags = + [ + (lib.enableFeature cxx "cxx") + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "ac_cv_build=x86_64-apple-darwin13.4.0" + "ac_cv_host=x86_64-apple-darwin13.4.0" + ]; - # The test t-lucnum_ui fails (on Linux/x86_64) when built with GCC 4.8. - # Newer versions of GMP don't have that issue anymore. - doCheck = false; + # The test t-lucnum_ui fails (on Linux/x86_64) when built with GCC 4.8. + # Newer versions of GMP don't have that issue anymore. + doCheck = false; - meta = { - branch = "4"; - description = "GNU multiple precision arithmetic library"; + meta = { + branch = "4"; + description = "GNU multiple precision arithmetic library"; - longDescription = '' - GMP is a free library for arbitrary precision arithmetic, operating - on signed integers, rational numbers, and floating point numbers. - There is no practical limit to the precision except the ones implied - by the available memory in the machine GMP runs on. GMP has a rich - set of functions, and the functions have a regular interface. + longDescription = '' + GMP is a free library for arbitrary precision arithmetic, operating + on signed integers, rational numbers, and floating point numbers. + There is no practical limit to the precision except the ones implied + by the available memory in the machine GMP runs on. GMP has a rich + set of functions, and the functions have a regular interface. - The main target applications for GMP are cryptography applications - and research, Internet security applications, algebra systems, - computational algebra research, etc. + The main target applications for GMP are cryptography applications + and research, Internet security applications, algebra systems, + computational algebra research, etc. - GMP is carefully designed to be as fast as possible, both for small - operands and for huge operands. The speed is achieved by using - fullwords as the basic arithmetic type, by using fast algorithms, - with highly optimised assembly code for the most common inner loops - for a lot of CPUs, and by a general emphasis on speed. + GMP is carefully designed to be as fast as possible, both for small + operands and for huge operands. The speed is achieved by using + fullwords as the basic arithmetic type, by using fast algorithms, + with highly optimised assembly code for the most common inner loops + for a lot of CPUs, and by a general emphasis on speed. - GMP is faster than any other bignum library. The advantage for GMP - increases with the operand sizes for many operations, since GMP uses - asymptotically faster algorithms. + GMP is faster than any other bignum library. The advantage for GMP + increases with the operand sizes for many operations, since GMP uses + asymptotically faster algorithms. ''; - homepage = "https://gmplib.org/"; - license = lib.licenses.lgpl3Plus; + homepage = "https://gmplib.org/"; + license = lib.licenses.lgpl3Plus; - maintainers = [ ]; - platforms = lib.platforms.all; - badPlatforms = [ "x86_64-darwin" ]; - # never built on aarch64-darwin, aarch64-linux since first introduction in nixpkgs - broken = (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) || (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64); + maintainers = [ ]; + platforms = lib.platforms.all; + badPlatforms = [ "x86_64-darwin" ]; + # never built on aarch64-darwin, aarch64-linux since first introduction in nixpkgs + broken = + (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) + || (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64); + }; }; -}; - in self +in +self diff --git a/pkgs/development/libraries/gmp/6.x.nix b/pkgs/development/libraries/gmp/6.x.nix index 458c7928c00e1d..2e3fdc5320592a 100644 --- a/pkgs/development/libraries/gmp/6.x.nix +++ b/pkgs/development/libraries/gmp/6.x.nix @@ -1,7 +1,11 @@ -{ lib, stdenv, fetchurl, m4 -, cxx ? !stdenv.hostPlatform.useAndroidPrebuilt && !stdenv.hostPlatform.isWasm -, buildPackages -, withStatic ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchurl, + m4, + cxx ? !stdenv.hostPlatform.useAndroidPrebuilt && !stdenv.hostPlatform.isWasm, + buildPackages, + withStatic ? stdenv.hostPlatform.isStatic, }: # Note: this package is used for bootstrapping fetchurl, and thus @@ -9,85 +13,99 @@ # cgit) that are needed here should be included directly in Nixpkgs as # files. -let inherit (lib) optional; in - -let self = stdenv.mkDerivation rec { - pname = "gmp${lib.optionalString cxx "-with-cxx"}"; - version = "6.3.0"; - - src = fetchurl { # we need to use bz2, others aren't in bootstrapping stdenv - urls = [ "mirror://gnu/gmp/gmp-${version}.tar.bz2" "ftp://ftp.gmplib.org/pub/gmp-${version}/gmp-${version}.tar.bz2" ]; - hash = "sha256-rCghGnz7YJuuLiyNYFjWbI/pZDT3QM9v4uR7AA0cIMs="; - }; - - #outputs TODO: split $cxx due to libstdc++ dependency - # maybe let ghc use a version with *.so shared with rest of nixpkgs and *.a added - # - see #5855 for related discussion - outputs = [ "out" "dev" "info" ]; - passthru.static = self.out; - - strictDeps = true; - depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ m4 ]; - - configureFlags = [ - "--with-pic" - (lib.enableFeature cxx "cxx") - # Build a "fat binary", with routines for several sub-architectures - # (x86), except on Solaris where some tests crash with "Memory fault". - # See , for instance. - # - # no darwin because gmp uses ASM that clang doesn't like - (lib.enableFeature (!stdenv.hostPlatform.isSunOS && stdenv.hostPlatform.isx86) "fat") - # The config.guess in GMP tries to runtime-detect various - # ARM optimization flags via /proc/cpuinfo (and is also - # broken on multicore CPUs). Avoid this impurity. - "--build=${stdenv.buildPlatform.config}" - ] ++ optional (cxx && stdenv.hostPlatform.isDarwin) "CPPFLAGS=-fexceptions" - ++ optional (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.is64bit) "ABI=64" - # to build a .dll on windows, we need --disable-static + --enable-shared - # see https://gmplib.org/manual/Notes-for-Particular-Systems.html - ++ optional (!withStatic && stdenv.hostPlatform.isWindows) "--disable-static --enable-shared" - ++ optional (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) "--disable-assembly"; - - doCheck = true; # not cross; - - dontDisableStatic = withStatic; - - enableParallelBuilding = true; - - meta = with lib; { - homepage = "https://gmplib.org/"; - description = "GNU multiple precision arithmetic library"; - license = with licenses; [ - lgpl3Only - gpl2Only +let + inherit (lib) optional; +in + +let + self = stdenv.mkDerivation rec { + pname = "gmp${lib.optionalString cxx "-with-cxx"}"; + version = "6.3.0"; + + src = fetchurl { + # we need to use bz2, others aren't in bootstrapping stdenv + urls = [ + "mirror://gnu/gmp/gmp-${version}.tar.bz2" + "ftp://ftp.gmplib.org/pub/gmp-${version}/gmp-${version}.tar.bz2" + ]; + hash = "sha256-rCghGnz7YJuuLiyNYFjWbI/pZDT3QM9v4uR7AA0cIMs="; + }; + + #outputs TODO: split $cxx due to libstdc++ dependency + # maybe let ghc use a version with *.so shared with rest of nixpkgs and *.a added + # - see #5855 for related discussion + outputs = [ + "out" + "dev" + "info" ]; - - longDescription = '' - GMP is a free library for arbitrary precision arithmetic, operating - on signed integers, rational numbers, and floating point numbers. - There is no practical limit to the precision except the ones implied - by the available memory in the machine GMP runs on. GMP has a rich - set of functions, and the functions have a regular interface. - - The main target applications for GMP are cryptography applications - and research, Internet security applications, algebra systems, - computational algebra research, etc. - - GMP is carefully designed to be as fast as possible, both for small - operands and for huge operands. The speed is achieved by using - fullwords as the basic arithmetic type, by using fast algorithms, - with highly optimised assembly code for the most common inner loops - for a lot of CPUs, and by a general emphasis on speed. - - GMP is faster than any other bignum library. The advantage for GMP - increases with the operand sizes for many operations, since GMP uses - asymptotically faster algorithms. - ''; - - platforms = platforms.all; - maintainers = [ ]; + passthru.static = self.out; + + strictDeps = true; + depsBuildBuild = [ buildPackages.stdenv.cc ]; + nativeBuildInputs = [ m4 ]; + + configureFlags = + [ + "--with-pic" + (lib.enableFeature cxx "cxx") + # Build a "fat binary", with routines for several sub-architectures + # (x86), except on Solaris where some tests crash with "Memory fault". + # See , for instance. + # + # no darwin because gmp uses ASM that clang doesn't like + (lib.enableFeature (!stdenv.hostPlatform.isSunOS && stdenv.hostPlatform.isx86) "fat") + # The config.guess in GMP tries to runtime-detect various + # ARM optimization flags via /proc/cpuinfo (and is also + # broken on multicore CPUs). Avoid this impurity. + "--build=${stdenv.buildPlatform.config}" + ] + ++ optional (cxx && stdenv.hostPlatform.isDarwin) "CPPFLAGS=-fexceptions" + ++ optional (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.is64bit) "ABI=64" + # to build a .dll on windows, we need --disable-static + --enable-shared + # see https://gmplib.org/manual/Notes-for-Particular-Systems.html + ++ optional (!withStatic && stdenv.hostPlatform.isWindows) "--disable-static --enable-shared" + ++ optional (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) "--disable-assembly"; + + doCheck = true; # not cross; + + dontDisableStatic = withStatic; + + enableParallelBuilding = true; + + meta = with lib; { + homepage = "https://gmplib.org/"; + description = "GNU multiple precision arithmetic library"; + license = with licenses; [ + lgpl3Only + gpl2Only + ]; + + longDescription = '' + GMP is a free library for arbitrary precision arithmetic, operating + on signed integers, rational numbers, and floating point numbers. + There is no practical limit to the precision except the ones implied + by the available memory in the machine GMP runs on. GMP has a rich + set of functions, and the functions have a regular interface. + + The main target applications for GMP are cryptography applications + and research, Internet security applications, algebra systems, + computational algebra research, etc. + + GMP is carefully designed to be as fast as possible, both for small + operands and for huge operands. The speed is achieved by using + fullwords as the basic arithmetic type, by using fast algorithms, + with highly optimised assembly code for the most common inner loops + for a lot of CPUs, and by a general emphasis on speed. + + GMP is faster than any other bignum library. The advantage for GMP + increases with the operand sizes for many operations, since GMP uses + asymptotically faster algorithms. + ''; + + platforms = platforms.all; + maintainers = [ ]; + }; }; -}; - in self +in +self diff --git a/pkgs/development/libraries/gobject-introspection/default.nix b/pkgs/development/libraries/gobject-introspection/default.nix index 925db88c9d011a..24732a588525fb 100644 --- a/pkgs/development/libraries/gobject-introspection/default.nix +++ b/pkgs/development/libraries/gobject-introspection/default.nix @@ -1,27 +1,28 @@ -{ stdenv -, lib -, fetchurl -, glib -, flex -, bison -, meson -, ninja -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_45 -, pkg-config -, libffi -, python3 -, cctools -, cairo -, gnome -, substituteAll -, buildPackages -, gobject-introspection-unwrapped -, nixStoreDir ? builtins.storeDir -, x11Support ? true -, testers -, propagateFullGlib ? true +{ + stdenv, + lib, + fetchurl, + glib, + flex, + bison, + meson, + ninja, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_45, + pkg-config, + libffi, + python3, + cctools, + cairo, + gnome, + substituteAll, + buildPackages, + gobject-introspection-unwrapped, + nixStoreDir ? builtins.storeDir, + x11Support ? true, + testers, + propagateFullGlib ? true, }: # now that gobject-introspection creates large .gir files (eg gtk3 case) @@ -44,7 +45,12 @@ stdenv.mkDerivation (finalAttrs: { # outputs TODO: share/gobject-introspection-1.0/tests is needed during build # by pygobject3 (and maybe others), but it's only searched in $out - outputs = [ "out" "dev" "devdoc" "man" ]; + outputs = [ + "out" + "dev" + "devdoc" + "man" + ]; outputBin = "dev"; src = fetchurl { @@ -52,39 +58,43 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-D1pMGQhCS/JrxB6TYRaMNjaFCA+9uHoZbIkchAHKLwk="; }; - patches = [ - # Make g-ir-scanner put absolute path to GIR files it generates - # so that programs can just dlopen them without having to muck - # with LD_LIBRARY_PATH environment variable. - (substituteAll { - src = ./absolute_shlib_path.patch; - inherit nixStoreDir; - }) - ] ++ lib.optionals x11Support [ - # Hardcode the cairo shared library path in the Cairo gir shipped with this package. - # https://github.com/NixOS/nixpkgs/issues/34080 - (substituteAll { - src = ./absolute_gir_path.patch; - cairoLib = "${lib.getLib cairo}/lib"; - }) - ]; + patches = + [ + # Make g-ir-scanner put absolute path to GIR files it generates + # so that programs can just dlopen them without having to muck + # with LD_LIBRARY_PATH environment variable. + (substituteAll { + src = ./absolute_shlib_path.patch; + inherit nixStoreDir; + }) + ] + ++ lib.optionals x11Support [ + # Hardcode the cairo shared library path in the Cairo gir shipped with this package. + # https://github.com/NixOS/nixpkgs/issues/34080 + (substituteAll { + src = ./absolute_gir_path.patch; + cairoLib = "${lib.getLib cairo}/lib"; + }) + ]; strictDeps = true; - nativeBuildInputs = [ - meson - ninja - pkg-config - flex - bison - gtk-doc - docbook-xsl-nons - docbook_xml_dtd_45 - # Build definition checks for the Python modules needed at runtime by importing them. - (buildPackages.python3.withPackages pythonModules) - finalAttrs.setupHook # move .gir files - # can't use canExecute, we need prebuilt when cross - ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ gobject-introspection-unwrapped ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + flex + bison + gtk-doc + docbook-xsl-nons + docbook_xml_dtd_45 + # Build definition checks for the Python modules needed at runtime by importing them. + (buildPackages.python3.withPackages pythonModules) + finalAttrs.setupHook # move .gir files + # can't use canExecute, we need prebuilt when cross + ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ gobject-introspection-unwrapped ]; buildInputs = [ (python3.withPackages pythonModules) @@ -99,23 +109,28 @@ stdenv.mkDerivation (finalAttrs: { (if propagateFullGlib then glib else glib') ]; - mesonFlags = [ - "--datadir=${placeholder "dev"}/share" - "-Dcairo=disabled" - "-Dgtk_doc=${lib.boolToString (stdenv.hostPlatform == stdenv.buildPlatform)}" - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - "-Dgi_cross_ldd_wrapper=${substituteAll { - name = "g-ir-scanner-lddwrapper"; - isExecutable = true; - src = ./wrappers/g-ir-scanner-lddwrapper.sh; - inherit (buildPackages) bash; - buildlddtree = "${buildPackages.pax-utils}/bin/lddtree"; - }}" - "-Dgi_cross_binary_wrapper=${stdenv.hostPlatform.emulator buildPackages}" - # can't use canExecute, we need prebuilt when cross - ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ - "-Dgi_cross_use_prebuilt_gi=true" - ]; + mesonFlags = + [ + "--datadir=${placeholder "dev"}/share" + "-Dcairo=disabled" + "-Dgtk_doc=${lib.boolToString (stdenv.hostPlatform == stdenv.buildPlatform)}" + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + "-Dgi_cross_ldd_wrapper=${ + substituteAll { + name = "g-ir-scanner-lddwrapper"; + isExecutable = true; + src = ./wrappers/g-ir-scanner-lddwrapper.sh; + inherit (buildPackages) bash; + buildlddtree = "${buildPackages.pax-utils}/bin/lddtree"; + } + }" + "-Dgi_cross_binary_wrapper=${stdenv.hostPlatform.emulator buildPackages}" + # can't use canExecute, we need prebuilt when cross + ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "-Dgi_cross_use_prebuilt_gi=true" + ]; doCheck = !stdenv.hostPlatform.isAarch64; @@ -159,11 +174,19 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Middleware layer between C libraries and language bindings"; homepage = "https://gi.readthedocs.io/"; - maintainers = teams.gnome.members ++ (with maintainers; [ lovek323 artturin ]); + maintainers = + teams.gnome.members + ++ (with maintainers; [ + lovek323 + artturin + ]); pkgConfigModules = [ "gobject-introspection-1.0" ]; platforms = platforms.unix; badPlatforms = [ lib.systems.inspect.platformPatterns.isStatic ]; - license = with licenses; [ gpl2 lgpl2 ]; + license = with licenses; [ + gpl2 + lgpl2 + ]; longDescription = '' GObject introspection is a middleware layer between C libraries (using diff --git a/pkgs/development/libraries/gobject-introspection/wrapper.nix b/pkgs/development/libraries/gobject-introspection/wrapper.nix index 5d6547a2b67d91..a89963ea2f432b 100644 --- a/pkgs/development/libraries/gobject-introspection/wrapper.nix +++ b/pkgs/development/libraries/gobject-introspection/wrapper.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, buildPackages -, targetPackages -, gobject-introspection-unwrapped -, ... +{ + lib, + stdenv, + buildPackages, + targetPackages, + gobject-introspection-unwrapped, + ... }@_args: # to build, run @@ -15,94 +16,101 @@ let # ensure that `.override` works - args = builtins.removeAttrs _args [ "buildPackages" "targetPackages" "gobject-introspection-unwrapped" ]; + args = builtins.removeAttrs _args [ + "buildPackages" + "targetPackages" + "gobject-introspection-unwrapped" + ]; # passing this stdenv to `targetPackages...` breaks due to splicing not working in `.override`` argsForTarget = builtins.removeAttrs args [ "stdenv" ]; overriddenUnwrappedGir = gobject-introspection-unwrapped.override args; # if we have targetPackages.gobject-introspection then propagate that overridenTargetUnwrappedGir = - if targetPackages ? gobject-introspection-unwrapped - then targetPackages.gobject-introspection-unwrapped.override argsForTarget - else overriddenUnwrappedGir; + if targetPackages ? gobject-introspection-unwrapped then + targetPackages.gobject-introspection-unwrapped.override argsForTarget + else + overriddenUnwrappedGir; in # wrap both pkgsCrossX.buildPackages.gobject-introspection and {pkgs,pkgsSomethingExecutableOnBuildSystem).buildPackages.gobject-introspection -if (!stdenv.hostPlatform.canExecute stdenv.targetPlatform) && stdenv.targetPlatform.emulatorAvailable buildPackages +if + (!stdenv.hostPlatform.canExecute stdenv.targetPlatform) + && stdenv.targetPlatform.emulatorAvailable buildPackages then - overriddenUnwrappedGir.overrideAttrs - (previousAttrs: - { + overriddenUnwrappedGir.overrideAttrs (previousAttrs: { - pname = "gobject-introspection-wrapped"; - passthru = previousAttrs.passthru // { - unwrapped = overriddenUnwrappedGir; - }; - dontStrip = true; - depsTargetTargetPropagated = [ overridenTargetUnwrappedGir ]; - buildCommand = '' - eval fixupPhase - ${lib.concatMapStrings (output: '' - mkdir -p ${"$" + "${output}"} - ${lib.getExe buildPackages.xorg.lndir} ${overriddenUnwrappedGir.${output}} ${"$" + "${output}"} - '') overriddenUnwrappedGir.outputs} - - cp $dev/bin/g-ir-compiler $dev/bin/.g-ir-compiler-wrapped - cp $dev/bin/g-ir-scanner $dev/bin/.g-ir-scanner-wrapped - - ( - rm "$dev/bin/g-ir-compiler" - rm "$dev/bin/g-ir-scanner" - export bash="${buildPackages.bash}" - export emulator=${lib.escapeShellArg (stdenv.targetPlatform.emulator buildPackages)} - export emulatorwrapper="$dev/bin/g-ir-scanner-qemuwrapper" - export buildlddtree="${buildPackages.pax-utils}/bin/lddtree" - - export targetgir="${lib.getDev overridenTargetUnwrappedGir}" - - substituteAll "${./wrappers/g-ir-compiler.sh}" "$dev/bin/g-ir-compiler" - substituteAll "${./wrappers/g-ir-scanner.sh}" "$dev/bin/g-ir-scanner" - substituteAll "${./wrappers/g-ir-scanner-lddwrapper.sh}" "$dev/bin/g-ir-scanner-lddwrapper" - substituteAll "${./wrappers/g-ir-scanner-qemuwrapper.sh}" "$dev/bin/g-ir-scanner-qemuwrapper" - chmod +x $dev/bin/g-ir-compiler - chmod +x $dev/bin/g-ir-scanner* - ) - '' - # when cross-compiling and using the wrapper then when a package looks up the g_ir_X - # variable with pkg-config they'll get the host version which can't be run - # override the variable to use the absolute path to g_ir_X in PATH which can be run - + '' - cat >> $dev/nix-support/setup-hook <<-'EOF' - override-pkg-config-gir-variables() { - PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_G_IR_SCANNER="$(type -p g-ir-scanner)" - PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_G_IR_COMPILER="$(type -p g-ir-compiler)" - PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_G_IR_GENERATE="$(type -p g-ir-generate)" - export PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_G_IR_SCANNER - export PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_G_IR_COMPILER - export PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_G_IR_GENERATE - } - - preConfigureHooks+=(override-pkg-config-gir-variables) - EOF - ''; - }) -else - overriddenUnwrappedGir.overrideAttrs (previousAttrs: - { - pname = "gobject-introspection-wrapped"; - passthru = previousAttrs.passthru // { - unwrapped = overriddenUnwrappedGir; - }; - dontStrip = true; - # Conditional is for `pkgsCross.x86_64-freebsd.pkgsBuildHost.gobject-introspection` `error: Don't know how to run x86_64-unknown-freebsd executables.` - # `pkgsCross.x86_64-freebsd.buildPackages.python3.withPackages (pp: [ pp.pygobject3 ])` - # Using the python module does not need this propagation - depsTargetTargetPropagated = lib.optionals (stdenv.targetPlatform.emulatorAvailable buildPackages) [ overridenTargetUnwrappedGir ]; - buildCommand = '' + pname = "gobject-introspection-wrapped"; + passthru = previousAttrs.passthru // { + unwrapped = overriddenUnwrappedGir; + }; + dontStrip = true; + depsTargetTargetPropagated = [ overridenTargetUnwrappedGir ]; + buildCommand = + '' eval fixupPhase ${lib.concatMapStrings (output: '' mkdir -p ${"$" + "${output}"} ${lib.getExe buildPackages.xorg.lndir} ${overriddenUnwrappedGir.${output}} ${"$" + "${output}"} '') overriddenUnwrappedGir.outputs} + + cp $dev/bin/g-ir-compiler $dev/bin/.g-ir-compiler-wrapped + cp $dev/bin/g-ir-scanner $dev/bin/.g-ir-scanner-wrapped + + ( + rm "$dev/bin/g-ir-compiler" + rm "$dev/bin/g-ir-scanner" + export bash="${buildPackages.bash}" + export emulator=${lib.escapeShellArg (stdenv.targetPlatform.emulator buildPackages)} + export emulatorwrapper="$dev/bin/g-ir-scanner-qemuwrapper" + export buildlddtree="${buildPackages.pax-utils}/bin/lddtree" + + export targetgir="${lib.getDev overridenTargetUnwrappedGir}" + + substituteAll "${./wrappers/g-ir-compiler.sh}" "$dev/bin/g-ir-compiler" + substituteAll "${./wrappers/g-ir-scanner.sh}" "$dev/bin/g-ir-scanner" + substituteAll "${./wrappers/g-ir-scanner-lddwrapper.sh}" "$dev/bin/g-ir-scanner-lddwrapper" + substituteAll "${./wrappers/g-ir-scanner-qemuwrapper.sh}" "$dev/bin/g-ir-scanner-qemuwrapper" + chmod +x $dev/bin/g-ir-compiler + chmod +x $dev/bin/g-ir-scanner* + ) + '' + # when cross-compiling and using the wrapper then when a package looks up the g_ir_X + # variable with pkg-config they'll get the host version which can't be run + # override the variable to use the absolute path to g_ir_X in PATH which can be run + + '' + cat >> $dev/nix-support/setup-hook <<-'EOF' + override-pkg-config-gir-variables() { + PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_G_IR_SCANNER="$(type -p g-ir-scanner)" + PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_G_IR_COMPILER="$(type -p g-ir-compiler)" + PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_G_IR_GENERATE="$(type -p g-ir-generate)" + export PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_G_IR_SCANNER + export PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_G_IR_COMPILER + export PKG_CONFIG_GOBJECT_INTROSPECTION_1_0_G_IR_GENERATE + } + + preConfigureHooks+=(override-pkg-config-gir-variables) + EOF ''; - }) + }) +else + overriddenUnwrappedGir.overrideAttrs (previousAttrs: { + pname = "gobject-introspection-wrapped"; + passthru = previousAttrs.passthru // { + unwrapped = overriddenUnwrappedGir; + }; + dontStrip = true; + # Conditional is for `pkgsCross.x86_64-freebsd.pkgsBuildHost.gobject-introspection` `error: Don't know how to run x86_64-unknown-freebsd executables.` + # `pkgsCross.x86_64-freebsd.buildPackages.python3.withPackages (pp: [ pp.pygobject3 ])` + # Using the python module does not need this propagation + depsTargetTargetPropagated = lib.optionals (stdenv.targetPlatform.emulatorAvailable buildPackages) [ + overridenTargetUnwrappedGir + ]; + buildCommand = '' + eval fixupPhase + ${lib.concatMapStrings (output: '' + mkdir -p ${"$" + "${output}"} + ${lib.getExe buildPackages.xorg.lndir} ${overriddenUnwrappedGir.${output}} ${"$" + "${output}"} + '') overriddenUnwrappedGir.outputs} + ''; + }) diff --git a/pkgs/development/libraries/goocanvas/2.x.nix b/pkgs/development/libraries/goocanvas/2.x.nix index 2066b1b72ec56b..9d0007b1ff2884 100644 --- a/pkgs/development/libraries/goocanvas/2.x.nix +++ b/pkgs/development/libraries/goocanvas/2.x.nix @@ -1,18 +1,45 @@ -{ lib, stdenv, fetchurl, pkg-config, gettext, gtk-doc, gobject-introspection, python3, gtk3, cairo, glib, gnome }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + gtk-doc, + gobject-introspection, + python3, + gtk3, + cairo, + glib, + gnome, +}: stdenv.mkDerivation rec { pname = "goocanvas"; version = "2.0.4"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/goocanvas/2.0/${pname}-${version}.tar.xz"; sha256 = "141fm7mbqib0011zmkv3g8vxcjwa7hypmq71ahdyhnj2sjvy4a67"; }; - nativeBuildInputs = [ pkg-config gettext gtk-doc python3 gobject-introspection ]; - buildInputs = [ gtk3 cairo glib ]; + nativeBuildInputs = [ + pkg-config + gettext + gtk-doc + python3 + gobject-introspection + ]; + buildInputs = [ + gtk3 + cairo + glib + ]; configureFlags = [ "--disable-python" diff --git a/pkgs/development/libraries/goocanvas/3.x.nix b/pkgs/development/libraries/goocanvas/3.x.nix index 4058412d83055e..d1f6aaee52a844 100644 --- a/pkgs/development/libraries/goocanvas/3.x.nix +++ b/pkgs/development/libraries/goocanvas/3.x.nix @@ -1,22 +1,27 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, gettext -, gobject-introspection -, gtk-doc -, python3 -, cairo -, gtk3 -, glib -, gnome +{ + lib, + stdenv, + fetchurl, + pkg-config, + gettext, + gobject-introspection, + gtk-doc, + python3, + cairo, + gtk3, + glib, + gnome, }: stdenv.mkDerivation rec { pname = "goocanvas"; version = "3.0.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/goocanvas/${lib.versions.majorMinor version}/goocanvas-${version}.tar.xz"; diff --git a/pkgs/development/libraries/goocanvas/default.nix b/pkgs/development/libraries/goocanvas/default.nix index 47ff343ffb630d..6e4655a872e314 100644 --- a/pkgs/development/libraries/goocanvas/default.nix +++ b/pkgs/development/libraries/goocanvas/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, gtk2, cairo, glib, pkg-config, gnome }: +{ + lib, + stdenv, + fetchurl, + gtk2, + cairo, + glib, + pkg-config, + gnome, +}: stdenv.mkDerivation rec { pname = "goocanvas"; @@ -10,7 +19,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk2 cairo glib ]; + buildInputs = [ + gtk2 + cairo + glib + ]; passthru = { updateScript = gnome.updateScript { diff --git a/pkgs/development/libraries/grantlee/5/default.nix b/pkgs/development/libraries/grantlee/5/default.nix index b115e1c8d7b60a..f5db48e14988a7 100644 --- a/pkgs/development/libraries/grantlee/5/default.nix +++ b/pkgs/development/libraries/grantlee/5/default.nix @@ -1,4 +1,11 @@ -{ mkDerivation, lib, fetchFromGitHub, qtbase, qtscript, cmake }: +{ + mkDerivation, + lib, + fetchFromGitHub, + qtbase, + qtscript, + cmake, +}: mkDerivation rec { pname = "grantlee"; @@ -12,7 +19,10 @@ mkDerivation rec { sha256 = "sha256-enP7b6A7Ndew2LJH569fN3IgPu2/KL5rCmU/jmKb9sY="; }; - buildInputs = [ qtbase qtscript ]; + buildInputs = [ + qtbase + qtscript + ]; nativeBuildInputs = [ cmake ]; patches = [ @@ -20,7 +30,10 @@ mkDerivation rec { ./grantlee-no-canonicalize-filepath.patch ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postFixup = # Disabuse CMake of the notion that libraries are in $dev '' diff --git a/pkgs/development/libraries/grantlee/default.nix b/pkgs/development/libraries/grantlee/default.nix index 2d1a87ab0b3ef4..982023d53f3d8e 100644 --- a/pkgs/development/libraries/grantlee/default.nix +++ b/pkgs/development/libraries/grantlee/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, qtbase, cmake, wrapQtAppsHook }: +{ + stdenv, + lib, + fetchFromGitHub, + qtbase, + cmake, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "grantlee"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { hash = "sha256-enP7b6A7Ndew2LJH569fN3IgPu2/KL5rCmU/jmKb9sY="; }; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; buildInputs = [ qtbase ]; meta = { diff --git a/pkgs/development/libraries/gsettings-qt/default.nix b/pkgs/development/libraries/gsettings-qt/default.nix index 803ab5e96dc5db..119932528cef0b 100644 --- a/pkgs/development/libraries/gsettings-qt/default.nix +++ b/pkgs/development/libraries/gsettings-qt/default.nix @@ -1,7 +1,15 @@ -{ lib, stdenv, fetchFromGitLab, pkg-config -, qmake, qtbase, qtdeclarative, wrapQtAppsHook -, glib, gobject-introspection -, gitUpdater +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + qmake, + qtbase, + qtdeclarative, + wrapQtAppsHook, + glib, + gobject-introspection, + gitUpdater, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/gsignond/default.nix b/pkgs/development/libraries/gsignond/default.nix index 6c1ee550f797de..f3f992ea8dac08 100644 --- a/pkgs/development/libraries/gsignond/default.nix +++ b/pkgs/development/libraries/gsignond/default.nix @@ -1,68 +1,93 @@ -{ lib, stdenv, fetchFromGitLab, pkg-config, meson, ninja, glib, glib-networking -, sqlite, gobject-introspection, vala, gtk-doc, libsecret, docbook_xsl -, docbook_xml_dtd_43, docbook_xml_dtd_45, glibcLocales, makeWrapper -, symlinkJoin, gsignondPlugins, plugins }: +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + meson, + ninja, + glib, + glib-networking, + sqlite, + gobject-introspection, + vala, + gtk-doc, + libsecret, + docbook_xsl, + docbook_xml_dtd_43, + docbook_xml_dtd_45, + glibcLocales, + makeWrapper, + symlinkJoin, + gsignondPlugins, + plugins, +}: let -unwrapped = stdenv.mkDerivation rec { - pname = "gsignond"; - version = "1.2.0"; + unwrapped = stdenv.mkDerivation rec { + pname = "gsignond"; + version = "1.2.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; - src = fetchFromGitLab { - owner = "accounts-sso"; - repo = pname; - rev = version; - sha256 = "17cpil3lpijgyj2z5c41vhb7fpk17038k5ggyw9p6049jrlf423m"; - }; + src = fetchFromGitLab { + owner = "accounts-sso"; + repo = pname; + rev = version; + sha256 = "17cpil3lpijgyj2z5c41vhb7fpk17038k5ggyw9p6049jrlf423m"; + }; - nativeBuildInputs = [ - docbook_xml_dtd_43 - docbook_xml_dtd_45 - docbook_xsl - glibcLocales - gobject-introspection - gtk-doc - meson - ninja - pkg-config - vala - ]; + nativeBuildInputs = [ + docbook_xml_dtd_43 + docbook_xml_dtd_45 + docbook_xsl + glibcLocales + gobject-introspection + gtk-doc + meson + ninja + pkg-config + vala + ]; - buildInputs = [ - glib - glib-networking - libsecret - ]; + buildInputs = [ + glib + glib-networking + libsecret + ]; - propagatedBuildInputs = [ sqlite ]; + propagatedBuildInputs = [ sqlite ]; - mesonFlags = [ - "-Dbus_type=session" - "-Dextension=desktop" - ]; + mesonFlags = [ + "-Dbus_type=session" + "-Dextension=desktop" + ]; - LC_ALL = "en_US.UTF-8"; + LC_ALL = "en_US.UTF-8"; - patches = [ - ./conf.patch - ./plugin-load-env.patch - ]; + patches = [ + ./conf.patch + ./plugin-load-env.patch + ]; - meta = with lib; { - description = "D-Bus service which performs user authentication on behalf of its clients"; - mainProgram = "gsignond"; - homepage = "https://gitlab.com/accounts-sso/gsignond"; - license = licenses.lgpl21Plus; - maintainers = [ ]; - platforms = platforms.linux; + meta = with lib; { + description = "D-Bus service which performs user authentication on behalf of its clients"; + mainProgram = "gsignond"; + homepage = "https://gitlab.com/accounts-sso/gsignond"; + license = licenses.lgpl21Plus; + maintainers = [ ]; + platforms = platforms.linux; + }; }; -}; - -in if plugins == [] then unwrapped - else import ./wrapper.nix { - inherit makeWrapper symlinkJoin plugins; - gsignond = unwrapped; - } +in +if plugins == [ ] then + unwrapped +else + import ./wrapper.nix { + inherit makeWrapper symlinkJoin plugins; + gsignond = unwrapped; + } diff --git a/pkgs/development/libraries/gsignond/plugins/lastfm.nix b/pkgs/development/libraries/gsignond/plugins/lastfm.nix index 8ba7c0483dc6dd..9f55e89e32b643 100644 --- a/pkgs/development/libraries/gsignond/plugins/lastfm.nix +++ b/pkgs/development/libraries/gsignond/plugins/lastfm.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitLab, pkg-config, meson, ninja, vala, glib, gsignond, json-glib, libsoup_2_4, gobject-introspection }: +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + meson, + ninja, + vala, + glib, + gsignond, + json-glib, + libsoup_2_4, + gobject-introspection, +}: stdenv.mkDerivation { pname = "gsignond-plugin-lastfm"; diff --git a/pkgs/development/libraries/gsignond/plugins/mail.nix b/pkgs/development/libraries/gsignond/plugins/mail.nix index d9012a3aa7981e..610f3e100de2f2 100644 --- a/pkgs/development/libraries/gsignond/plugins/mail.nix +++ b/pkgs/development/libraries/gsignond/plugins/mail.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitLab, pkg-config, meson, ninja, vala, glib, gsignond, gobject-introspection }: +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + meson, + ninja, + vala, + glib, + gsignond, + gobject-introspection, +}: stdenv.mkDerivation rec { pname = "gsignond-plugin-mail"; diff --git a/pkgs/development/libraries/gsignond/plugins/oauth.nix b/pkgs/development/libraries/gsignond/plugins/oauth.nix index 0261c39a8740b1..a26ce6caa1c6bc 100644 --- a/pkgs/development/libraries/gsignond/plugins/oauth.nix +++ b/pkgs/development/libraries/gsignond/plugins/oauth.nix @@ -1,6 +1,23 @@ -{ lib, stdenv, fetchFromGitLab, pkg-config, meson, ninja, glib, gsignond, check -, json-glib, libsoup_2_4, gnutls, gtk-doc, docbook_xml_dtd_43, docbook_xml_dtd_45 -, docbook_xsl, glibcLocales, gobject-introspection }: +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + meson, + ninja, + glib, + gsignond, + check, + json-glib, + libsoup_2_4, + gnutls, + gtk-doc, + docbook_xml_dtd_43, + docbook_xml_dtd_45, + docbook_xsl, + glibcLocales, + gobject-introspection, +}: stdenv.mkDerivation { pname = "gsignond-plugin-oauth"; diff --git a/pkgs/development/libraries/gsignond/plugins/sasl.nix b/pkgs/development/libraries/gsignond/plugins/sasl.nix index 3154f92b596f6f..5a89d996743ab5 100644 --- a/pkgs/development/libraries/gsignond/plugins/sasl.nix +++ b/pkgs/development/libraries/gsignond/plugins/sasl.nix @@ -1,5 +1,21 @@ -{ lib, stdenv, fetchFromGitLab, pkg-config, meson, ninja, glib, gsignond, gsasl, check -, gtk-doc, docbook_xml_dtd_43, docbook_xml_dtd_45, docbook_xsl, glibcLocales, gobject-introspection }: +{ + lib, + stdenv, + fetchFromGitLab, + pkg-config, + meson, + ninja, + glib, + gsignond, + gsasl, + check, + gtk-doc, + docbook_xml_dtd_43, + docbook_xml_dtd_45, + docbook_xsl, + glibcLocales, + gobject-introspection, +}: stdenv.mkDerivation { pname = "gsignond-plugin-sasl"; diff --git a/pkgs/development/libraries/gsignond/wrapper.nix b/pkgs/development/libraries/gsignond/wrapper.nix index 9b31a2213ceb12..ab7f6b9817df67 100644 --- a/pkgs/development/libraries/gsignond/wrapper.nix +++ b/pkgs/development/libraries/gsignond/wrapper.nix @@ -1,4 +1,9 @@ -{ makeWrapper, symlinkJoin, gsignond, plugins }: +{ + makeWrapper, + symlinkJoin, + gsignond, + plugins, +}: symlinkJoin { name = "gsignond-with-plugins-${gsignond.version}"; diff --git a/pkgs/development/libraries/gsmlib/default.nix b/pkgs/development/libraries/gsmlib/default.nix index 5b3672650f1970..673ede3f9d5719 100644 --- a/pkgs/development/libraries/gsmlib/default.nix +++ b/pkgs/development/libraries/gsmlib/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "gsmlib"; version = "unstable-2017-10-06"; diff --git a/pkgs/development/libraries/gssdp/1.6.nix b/pkgs/development/libraries/gssdp/1.6.nix index d52c90b41b916e..54eb043b65ed95 100644 --- a/pkgs/development/libraries/gssdp/1.6.nix +++ b/pkgs/development/libraries/gssdp/1.6.nix @@ -1,25 +1,30 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, gobject-introspection -, vala -, pandoc -, gi-docgen -, python3 -, libsoup_3 -, glib -, gnome -, gssdp-tools +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + gobject-introspection, + vala, + pandoc, + gi-docgen, + python3, + libsoup_3, + glib, + gnome, + gssdp-tools, }: stdenv.mkDerivation rec { pname = "gssdp"; version = "1.6.3"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/gssdp/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/development/libraries/gssdp/default.nix b/pkgs/development/libraries/gssdp/default.nix index d3ecb891394742..ff30e8748643a7 100644 --- a/pkgs/development/libraries/gssdp/default.nix +++ b/pkgs/development/libraries/gssdp/default.nix @@ -1,28 +1,33 @@ -{ stdenv -, lib -, fetchpatch2 -, fetchurl -, meson -, ninja -, pkg-config -, gobject-introspection -, vala -, gi-docgen -, python3 -, libsoup_2_4 -, glib -, gnome -, gssdp-tools -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages +{ + stdenv, + lib, + fetchpatch2, + fetchurl, + meson, + ninja, + pkg-config, + gobject-introspection, + vala, + gi-docgen, + python3, + libsoup_2_4, + glib, + gnome, + gssdp-tools, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, }: stdenv.mkDerivation rec { pname = "gssdp"; version = "1.4.1"; - outputs = [ "out" "dev" ] - ++ lib.optionals withIntrospection [ "devdoc" ]; + outputs = [ + "out" + "dev" + ] ++ lib.optionals withIntrospection [ "devdoc" ]; src = fetchurl { url = "mirror://gnome/sources/gssdp/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -43,17 +48,19 @@ stdenv.mkDerivation rec { pkg-config ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - glib - python3 - ] ++ lib.optionals withIntrospection [ - gobject-introspection - vala - gi-docgen - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + glib + python3 + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + vala + gi-docgen + ]; buildInputs = [ libsoup_2_4 diff --git a/pkgs/development/libraries/gssdp/tools.nix b/pkgs/development/libraries/gssdp/tools.nix index 1d5d25e6ef4ffe..7708bb6991a271 100644 --- a/pkgs/development/libraries/gssdp/tools.nix +++ b/pkgs/development/libraries/gssdp/tools.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, substituteAll -, meson -, ninja -, pkg-config -, wrapGAppsHook4 -, gssdp_1_6 -, gtk4 -, libsoup_3 +{ + stdenv, + lib, + substituteAll, + meson, + ninja, + pkg-config, + wrapGAppsHook4, + gssdp_1_6, + gtk4, + libsoup_3, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/gstreamer/default.nix b/pkgs/development/libraries/gstreamer/default.nix index cee836e86ac925..20331b598bc7f7 100644 --- a/pkgs/development/libraries/gstreamer/default.nix +++ b/pkgs/development/libraries/gstreamer/default.nix @@ -1,23 +1,24 @@ -{ stdenv -, callPackage -, AVFoundation -, AudioToolbox -, Cocoa -, CoreFoundation -, CoreMedia -, CoreServices -, CoreVideo -, DiskArbitration -, Foundation -, IOKit -, MediaToolbox -, OpenGL -, Security -, SystemConfiguration -, VideoToolbox -, xpc -, ipu6ep-camera-hal -, ipu6epmtl-camera-hal +{ + stdenv, + callPackage, + AVFoundation, + AudioToolbox, + Cocoa, + CoreFoundation, + CoreMedia, + CoreServices, + CoreVideo, + DiskArbitration, + Foundation, + IOKit, + MediaToolbox, + OpenGL, + Security, + SystemConfiguration, + VideoToolbox, + xpc, + ipu6ep-camera-hal, + ipu6epmtl-camera-hal, }: { @@ -31,7 +32,18 @@ gst-plugins-good = callPackage ./good { inherit Cocoa; }; - gst-plugins-bad = callPackage ./bad { inherit AudioToolbox AVFoundation Cocoa CoreMedia CoreVideo Foundation MediaToolbox VideoToolbox; }; + gst-plugins-bad = callPackage ./bad { + inherit + AudioToolbox + AVFoundation + Cocoa + CoreMedia + CoreVideo + Foundation + MediaToolbox + VideoToolbox + ; + }; gst-plugins-ugly = callPackage ./ugly { inherit CoreFoundation DiskArbitration IOKit; }; diff --git a/pkgs/development/libraries/gstreamer/gstreamermm/default.nix b/pkgs/development/libraries/gstreamer/gstreamermm/default.nix index 40186664284ee6..462a75392cca03 100644 --- a/pkgs/development/libraries/gstreamer/gstreamermm/default.nix +++ b/pkgs/development/libraries/gstreamer/gstreamermm/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, pkg-config -, file -, glibmm -, gst_all_1 -, gnome +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + file, + glibmm, + gst_all_1, + gnome, }: stdenv.mkDerivation rec { @@ -26,7 +27,10 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ pkg-config diff --git a/pkgs/development/libraries/gstreamer/icamerasrc/default.nix b/pkgs/development/libraries/gstreamer/icamerasrc/default.nix index 4bbb20c6e41a4b..d92d5b1a903d15 100644 --- a/pkgs/development/libraries/gstreamer/icamerasrc/default.nix +++ b/pkgs/development/libraries/gstreamer/icamerasrc/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, gst_all_1 -, ipu6-camera-hal -, libdrm -, libva +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + gst_all_1, + ipu6-camera-hal, + libdrm, + libva, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/gstreamer/rs/default.nix b/pkgs/development/libraries/gstreamer/rs/default.nix index 187d1a0486979f..2721cf46dddf6f 100644 --- a/pkgs/development/libraries/gstreamer/rs/default.nix +++ b/pkgs/development/libraries/gstreamer/rs/default.nix @@ -1,39 +1,40 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchFromGitHub -, fetchpatch -, rustPlatform -, meson -, ninja -, python3 -, pkg-config -, rustc -, cargo -, cargo-c -, lld -, nasm -, gstreamer -, gst-plugins-base -, gst-plugins-bad -, gtk4 -, cairo -, csound -, dav1d -, libsodium -, libwebp -, openssl -, pango -, Security -, SystemConfiguration -, gst-plugins-good -, nix-update-script -# specifies a limited subset of plugins to build (the default `null` means all plugins supported on the stdenv platform) -, plugins ? null -, withGtkPlugins ? true -# Checks meson.is_cross_build(), so even canExecute isn't enough. -, enableDocumentation ? stdenv.hostPlatform == stdenv.buildPlatform && plugins == null -, hotdoc +{ + lib, + stdenv, + fetchFromGitLab, + fetchFromGitHub, + fetchpatch, + rustPlatform, + meson, + ninja, + python3, + pkg-config, + rustc, + cargo, + cargo-c, + lld, + nasm, + gstreamer, + gst-plugins-base, + gst-plugins-bad, + gtk4, + cairo, + csound, + dav1d, + libsodium, + libwebp, + openssl, + pango, + Security, + SystemConfiguration, + gst-plugins-good, + nix-update-script, + # specifies a limited subset of plugins to build (the default `null` means all plugins supported on the stdenv platform) + plugins ? null, + withGtkPlugins ? true, + # Checks meson.is_cross_build(), so even canExecute isn't enough. + enableDocumentation ? stdenv.hostPlatform == stdenv.buildPlatform && plugins == null, + hotdoc, }: let @@ -64,8 +65,24 @@ let raptorq = [ ]; reqwest = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; rtp = [ ]; - webrtc = [ gst-plugins-bad openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security SystemConfiguration ]; - webrtchttp = [ gst-plugins-bad openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security SystemConfiguration ]; + webrtc = + [ + gst-plugins-bad + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + ]; + webrtchttp = + [ + gst-plugins-bad + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + ]; # text textahead = [ ]; @@ -106,30 +123,37 @@ let webp = [ libwebp ]; }; - selectedPlugins = if plugins != null then lib.unique (lib.sort lib.lessThan plugins) else lib.subtractLists ( - [ - "csound" # tests have weird failure on x86, does not currently work on arm or darwin - "livesync" # tests have suspicious intermittent failure, see https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/issues/357 - ] ++ lib.optionals stdenv.hostPlatform.isAarch64 [ - "raptorq" # pointer alignment failure in tests on aarch64 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "reqwest" # tests hang on darwin - "threadshare" # tests cannot bind to localhost on darwin - "webp" # not supported on darwin (upstream crate issue) - ] ++ lib.optionals (!gst-plugins-base.glEnabled || !withGtkPlugins) [ - # these require gstreamer-gl - "gtk4" - "livesync" - "fallbackswitch" - "togglerecord" - ] - ) (lib.attrNames validPlugins); + selectedPlugins = + if plugins != null then + lib.unique (lib.sort lib.lessThan plugins) + else + lib.subtractLists ( + [ + "csound" # tests have weird failure on x86, does not currently work on arm or darwin + "livesync" # tests have suspicious intermittent failure, see https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/issues/357 + ] + ++ lib.optionals stdenv.hostPlatform.isAarch64 [ + "raptorq" # pointer alignment failure in tests on aarch64 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "reqwest" # tests hang on darwin + "threadshare" # tests cannot bind to localhost on darwin + "webp" # not supported on darwin (upstream crate issue) + ] + ++ lib.optionals (!gst-plugins-base.glEnabled || !withGtkPlugins) [ + # these require gstreamer-gl + "gtk4" + "livesync" + "fallbackswitch" + "togglerecord" + ] + ) (lib.attrNames validPlugins); invalidPlugins = lib.subtractLists (lib.attrNames validPlugins) selectedPlugins; # TODO: figure out what must be done about this upstream - related lu-zero/cargo-c#323 lu-zero/cargo-c#138 cargo-c' = (cargo-c.__spliced.buildHost or cargo-c).overrideAttrs (oldAttrs: { - patches = (oldAttrs.patches or []) ++ [ + patches = (oldAttrs.patches or [ ]) ++ [ (fetchpatch { name = "cargo-c-test-rlib-fix.patch"; url = "https://github.com/lu-zero/cargo-c/commit/8421f2da07cd066d2ae8afbb027760f76dc9ee6c.diff"; @@ -139,14 +163,19 @@ let ]; }); in - assert lib.assertMsg (invalidPlugins == []) - "Invalid gst-plugins-rs plugin${lib.optionalString (lib.length invalidPlugins > 1) "s"}: ${lib.concatStringsSep ", " invalidPlugins}"; +assert lib.assertMsg (invalidPlugins == [ ]) + "Invalid gst-plugins-rs plugin${ + lib.optionalString (lib.length invalidPlugins > 1) "s" + }: ${lib.concatStringsSep ", " invalidPlugins}"; stdenv.mkDerivation (finalAttrs: { pname = "gst-plugins-rs"; version = "0.12.8"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitLab { domain = "gitlab.freedesktop.org"; @@ -189,22 +218,25 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - nativeBuildInputs = [ - rustPlatform.cargoSetupHook - meson - ninja - python3 - python3.pkgs.tomli - pkg-config - rustc - cargo - cargo-c' - nasm - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - lld - ] ++ lib.optionals enableDocumentation [ - hotdoc - ]; + nativeBuildInputs = + [ + rustPlatform.cargoSetupHook + meson + ninja + python3 + python3.pkgs.tomli + pkg-config + rustc + cargo + cargo-c' + nasm + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + lld + ] + ++ lib.optionals enableDocumentation [ + hotdoc + ]; env = lib.optionalAttrs stdenv.hostPlatform.isDarwin { NIX_CFLAGS_LINK = "-fuse-ld=lld"; }; @@ -218,9 +250,7 @@ stdenv.mkDerivation (finalAttrs: { gst-plugins-bad ]; - mesonFlags = ( - map (plugin: lib.mesonEnable plugin true) selectedPlugins - ) ++ [ + mesonFlags = (map (plugin: lib.mesonEnable plugin true) selectedPlugins) ++ [ (lib.mesonOption "sodium-source" "system") (lib.mesonEnable "tests" finalAttrs.finalPackage.doCheck) (lib.mesonEnable "doc" enableDocumentation) @@ -232,19 +262,25 @@ stdenv.mkDerivation (finalAttrs: { doCheck = stdenv.buildPlatform.canExecute stdenv.hostPlatform; # csound lib dir must be manually specified for it to build - preConfigure = '' - export CARGO_BUILD_JOBS=$NIX_BUILD_CORES + preConfigure = + '' + export CARGO_BUILD_JOBS=$NIX_BUILD_CORES - patchShebangs dependencies.py - '' + lib.optionalString (lib.elem "csound" selectedPlugins) '' - export CSOUND_LIB_DIR=${lib.getLib csound}/lib - ''; + patchShebangs dependencies.py + '' + + lib.optionalString (lib.elem "csound" selectedPlugins) '' + export CSOUND_LIB_DIR=${lib.getLib csound}/lib + ''; # give meson longer before timing out for tests - mesonCheckFlags = [ "--verbose" "--timeout-multiplier" "12" ]; + mesonCheckFlags = [ + "--verbose" + "--timeout-multiplier" + "12" + ]; - doInstallCheck = (lib.elem "webp" selectedPlugins) && !stdenv.hostPlatform.isStatic && - stdenv.hostPlatform.isElf; + doInstallCheck = + (lib.elem "webp" selectedPlugins) && !stdenv.hostPlatform.isStatic && stdenv.hostPlatform.isElf; installCheckPhase = '' runHook preInstallCheck readelf -a $out/lib/gstreamer-1.0/libgstrswebp.so | grep -F 'Shared library: [libwebpdemux.so' @@ -254,14 +290,22 @@ stdenv.mkDerivation (finalAttrs: { passthru.updateScript = nix-update-script { # use numbered releases rather than gstreamer-* releases # this matches upstream's recommendation: https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/issues/470#note_2202772 - extraArgs = [ "--version-regex" "([0-9.]+)" ]; + extraArgs = [ + "--version-regex" + "([0-9.]+)" + ]; }; meta = with lib; { description = "GStreamer plugins written in Rust"; mainProgram = "gst-webrtc-signalling-server"; homepage = "https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs"; - license = with licenses; [ mpl20 asl20 mit lgpl21Plus ]; + license = with licenses; [ + mpl20 + asl20 + mit + lgpl21Plus + ]; platforms = platforms.unix; maintainers = [ ]; }; diff --git a/pkgs/development/libraries/gstreamer/viperfx/default.nix b/pkgs/development/libraries/gstreamer/viperfx/default.nix index 0f8e8914e2e9cf..4fe8ad109c0882 100644 --- a/pkgs/development/libraries/gstreamer/viperfx/default.nix +++ b/pkgs/development/libraries/gstreamer/viperfx/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, wrapGAppsHook3 -, gst_all_1 -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + wrapGAppsHook3, + gst_all_1, + cmake, }: stdenv.mkDerivation rec { pname = "gst-plugins-viperfx"; @@ -17,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-0so4jV56nl3tZHuZpvtyMrpOZ4tNJ59Pyj6zbV5bJ5Y="; }; - nativeBuildInputs = [ cmake pkg-config wrapGAppsHook3 ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapGAppsHook3 + ]; propagatedBuildInputs = [ gst_all_1.gstreamer diff --git a/pkgs/development/libraries/gtk-mac-integration/default.nix b/pkgs/development/libraries/gtk-mac-integration/default.nix index 7dd08878bce18e..383fab6b5f68d4 100644 --- a/pkgs/development/libraries/gtk-mac-integration/default.nix +++ b/pkgs/development/libraries/gtk-mac-integration/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitLab, autoreconfHook, pkg-config, glib, gtk-doc, gtk, gobject-introspection }: +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + glib, + gtk-doc, + gtk, + gobject-introspection, +}: stdenv.mkDerivation rec { pname = "gtk-mac-integration"; @@ -12,7 +22,12 @@ stdenv.mkDerivation rec { sha256 = "0sc0m3p8r5xfh5i4d7dg72kfixx9yi4f800y43bszyr88y52jkga"; }; - nativeBuildInputs = [ autoreconfHook pkg-config gtk-doc gobject-introspection ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + gtk-doc + gobject-introspection + ]; buildInputs = [ glib ]; propagatedBuildInputs = [ gtk ]; diff --git a/pkgs/development/libraries/gtk-sharp/2.0.nix b/pkgs/development/libraries/gtk-sharp/2.0.nix index 1331fcff0e656e..120b39ced22a26 100644 --- a/pkgs/development/libraries/gtk-sharp/2.0.nix +++ b/pkgs/development/libraries/gtk-sharp/2.0.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, pkg-config -, mono -, glib -, pango -, gtk2 -, libxml2 -, monoDLLFixer -, autoconf -, automake -, libtool -, which -, fetchpatch +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + mono, + glib, + pango, + gtk2, + libxml2, + monoDLLFixer, + autoconf, + automake, + libtool, + which, + fetchpatch, }: stdenv.mkDerivation rec { @@ -43,10 +44,19 @@ stdenv.mkDerivation rec { popd ''; - nativeBuildInputs = [ pkg-config autoconf automake libtool which ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + libtool + which + ]; buildInputs = [ - mono glib pango gtk2 + mono + glib + pango + gtk2 libxml2 ]; @@ -54,9 +64,11 @@ stdenv.mkDerivation rec { ./bootstrap-${lib.versions.majorMinor version} ''; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-error=int-conversion" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-error=int-conversion" + ] + ); dontStrip = true; diff --git a/pkgs/development/libraries/gtk-sharp/3.0.nix b/pkgs/development/libraries/gtk-sharp/3.0.nix index 8b594a00a7e56b..98ccf2a111dea8 100644 --- a/pkgs/development/libraries/gtk-sharp/3.0.nix +++ b/pkgs/development/libraries/gtk-sharp/3.0.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchurl -, fetchpatch -, pkg-config -, mono -, glib -, pango -, gtk3 -, libxml2 -, monoDLLFixer +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + mono, + glib, + pango, + gtk3, + libxml2, + monoDLLFixer, }: stdenv.mkDerivation rec { @@ -22,7 +24,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ - mono glib pango gtk3 + mono + glib + pango + gtk3 libxml2 ]; diff --git a/pkgs/development/libraries/gtk/2.x.nix b/pkgs/development/libraries/gtk/2.x.nix index 7d11b671b1b7c6..9b1a3fc32439f4 100644 --- a/pkgs/development/libraries/gtk/2.x.nix +++ b/pkgs/development/libraries/gtk/2.x.nix @@ -1,33 +1,34 @@ -{ config -, lib -, stdenv -, fetchurl -, fetchpatch -, atk -, buildPackages -, cairo -, cups -, gdk-pixbuf -, gettext -, glib -, gobject-introspection -, libXcomposite -, libXcursor -, libXdamage -, libXi -, libXinerama -, libXrandr -, libXrender -, pango -, perl -, pkg-config -, substituteAll -, testers -, AppKit -, Cocoa -, gdktarget ? if stdenv.hostPlatform.isDarwin then "quartz" else "x11" -, cupsSupport ? config.gtk2.cups or stdenv.hostPlatform.isLinux -, xineramaSupport ? stdenv.hostPlatform.isLinux +{ + config, + lib, + stdenv, + fetchurl, + fetchpatch, + atk, + buildPackages, + cairo, + cups, + gdk-pixbuf, + gettext, + glib, + gobject-introspection, + libXcomposite, + libXcursor, + libXdamage, + libXi, + libXinerama, + libXrandr, + libXrender, + pango, + perl, + pkg-config, + substituteAll, + testers, + AppKit, + Cocoa, + gdktarget ? if stdenv.hostPlatform.isDarwin then "quartz" else "x11", + cupsSupport ? config.gtk2.cups or stdenv.hostPlatform.isLinux, + xineramaSupport ? stdenv.hostPlatform.isLinux, }: let @@ -46,10 +47,14 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-rCrHV/WULTGKMRpUsMgLXvKV8pnCpzxjL2v7H/Scxto="; }; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "dev"; - setupHooks = [ + setupHooks = [ ./hooks/drop-icon-theme-cache.sh gtkCleanImmodulesCache ]; @@ -61,60 +66,66 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - patches = [ - ./patches/2.0-immodules.cache.patch - ./patches/gtk2-theme-paths.patch - (fetchpatch { - # https://gitlab.gnome.org/GNOME/gtk/-/issues/6786 - name = "CVE-2024-6655.patch"; - url = "https://gitlab.gnome.org/GNOME/gtk/-/commit/3bbf0b6176d42836d23c36a6ac410e807ec0a7a7.patch"; - hash = "sha256-mstOPk9NNpUwScrdEbvGhmAv8jlds3SBdj53T0q33vM="; - }) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ./patches/2.0-gnome_bugzilla_557780_306776_freeciv_darwin.patch - ./patches/2.0-darwin-x11.patch - # Fixes an incompatible function pointer conversion and implicit int errors with clang 16. - ./patches/2.0-clang.patch - ]; + patches = + [ + ./patches/2.0-immodules.cache.patch + ./patches/gtk2-theme-paths.patch + (fetchpatch { + # https://gitlab.gnome.org/GNOME/gtk/-/issues/6786 + name = "CVE-2024-6655.patch"; + url = "https://gitlab.gnome.org/GNOME/gtk/-/commit/3bbf0b6176d42836d23c36a6ac410e807ec0a7a7.patch"; + hash = "sha256-mstOPk9NNpUwScrdEbvGhmAv8jlds3SBdj53T0q33vM="; + }) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ./patches/2.0-gnome_bugzilla_557780_306776_freeciv_darwin.patch + ./patches/2.0-darwin-x11.patch + # Fixes an incompatible function pointer conversion and implicit int errors with clang 16. + ./patches/2.0-clang.patch + ]; - propagatedBuildInputs = [ - atk - cairo - gdk-pixbuf - glib - pango - ] ++ lib.optionals (stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isDarwin) [ - libXcomposite - libXcursor - libXi - libXrandr - libXrender - ] ++ lib.optional xineramaSupport libXinerama - ++ lib.optional cupsSupport cups - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libXdamage - AppKit - Cocoa - ]; + propagatedBuildInputs = + [ + atk + cairo + gdk-pixbuf + glib + pango + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isDarwin) [ + libXcomposite + libXcursor + libXi + libXrandr + libXrender + ] + ++ lib.optional xineramaSupport libXinerama + ++ lib.optional cupsSupport cups + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libXdamage + AppKit + Cocoa + ]; - preConfigure = - lib.optionalString (stdenv.hostPlatform.isDarwin - && lib.versionAtLeast - stdenv.hostPlatform.darwinMinVersion "11") - "MACOSX_DEPLOYMENT_TARGET=10.16"; - - configureFlags = [ - "--sysconfdir=/etc" - "--with-gdktarget=${gdktarget}" - "--with-xinput=yes" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "--disable-glibtest" - "--disable-introspection" - "--disable-visibility" - ] ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ - "ac_cv_path_GTK_UPDATE_ICON_CACHE=${buildPackages.gtk2}/bin/gtk-update-icon-cache" - "ac_cv_path_GDK_PIXBUF_CSOURCE=${buildPackages.gdk-pixbuf.dev}/bin/gdk-pixbuf-csource" - ]; + preConfigure = lib.optionalString ( + stdenv.hostPlatform.isDarwin && lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11" + ) "MACOSX_DEPLOYMENT_TARGET=10.16"; + + configureFlags = + [ + "--sysconfdir=/etc" + "--with-gdktarget=${gdktarget}" + "--with-xinput=yes" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "--disable-glibtest" + "--disable-introspection" + "--disable-visibility" + ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "ac_cv_path_GTK_UPDATE_ICON_CACHE=${buildPackages.gtk2}/bin/gtk-update-icon-cache" + "ac_cv_path_GDK_PIXBUF_CSOURCE=${buildPackages.gdk-pixbuf.dev}/bin/gdk-pixbuf-csource" + ]; env = lib.optionalAttrs stdenv.cc.isGNU { NIX_CFLAGS_COMPILE = toString [ @@ -159,14 +170,19 @@ stdenv.mkDerivation (finalAttrs: { ''; changelog = "https://gitlab.gnome.org/GNOME/gtk/-/raw/${finalAttrs.version}/NEWS"; license = lib.licenses.lgpl2Plus; - maintainers = with lib.maintainers; [ lovek323 raskin ]; - platforms = lib.platforms.all; - pkgConfigModules = [ - "gdk-2.0" - "gtk+-2.0" - ] ++ lib.optionals (gdktarget == "x11") [ - "gdk-x11-2.0" - "gtk+-x11-2.0" + maintainers = with lib.maintainers; [ + lovek323 + raskin ]; + platforms = lib.platforms.all; + pkgConfigModules = + [ + "gdk-2.0" + "gtk+-2.0" + ] + ++ lib.optionals (gdktarget == "x11") [ + "gdk-x11-2.0" + "gtk+-x11-2.0" + ]; }; }) diff --git a/pkgs/development/libraries/gtkd/default.nix b/pkgs/development/libraries/gtkd/default.nix index faba68ede1482e..8c06d3818aa10f 100644 --- a/pkgs/development/libraries/gtkd/default.nix +++ b/pkgs/development/libraries/gtkd/default.nix @@ -1,9 +1,28 @@ -{ lib, stdenv, fetchzip, atk, cairo, dcompiler, gdk-pixbuf, gst_all_1, librsvg -, glib, gtk3, gtksourceview4, libgda, libpeas, pango, pkg-config, which, vte }: +{ + lib, + stdenv, + fetchzip, + atk, + cairo, + dcompiler, + gdk-pixbuf, + gst_all_1, + librsvg, + glib, + gtk3, + gtksourceview4, + libgda, + libpeas, + pango, + pkg-config, + which, + vte, +}: let inherit (gst_all_1) gstreamer gst-plugins-base gst-plugins-bad; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "gtkd"; version = "3.10.0"; @@ -13,10 +32,25 @@ in stdenv.mkDerivation rec { stripRoot = false; }; - nativeBuildInputs = [ dcompiler pkg-config which ]; + nativeBuildInputs = [ + dcompiler + pkg-config + which + ]; propagatedBuildInputs = [ - atk cairo gdk-pixbuf glib gstreamer gst-plugins-base gtk3 gtksourceview4 - libgda libpeas librsvg pango vte + atk + cairo + gdk-pixbuf + glib + gstreamer + gst-plugins-base + gtk3 + gtksourceview4 + libgda + libpeas + librsvg + pango + vte ]; postPatch = '' @@ -105,7 +139,7 @@ in stdenv.mkDerivation rec { --replace libvte-2.91.0.dylib ${vte}/lib/libvte-2.91.0.dylib ''; - makeFlags = [ + makeFlags = [ "prefix=${placeholder "out"}" "PKG_CONFIG=${pkg-config}/bin/${pkg-config.targetPrefix}pkg-config" ]; diff --git a/pkgs/development/libraries/gtkmm/2.x.nix b/pkgs/development/libraries/gtkmm/2.x.nix index 284ee83c2d4f4b..02da63e9679269 100644 --- a/pkgs/development/libraries/gtkmm/2.x.nix +++ b/pkgs/development/libraries/gtkmm/2.x.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, pkg-config, gtk2, glibmm, cairomm, pangomm, atkmm }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + glibmm, + cairomm, + pangomm, + atkmm, +}: stdenv.mkDerivation rec { pname = "gtkmm"; @@ -9,11 +19,20 @@ stdenv.mkDerivation rec { sha256 = "0680a53b7bf90b4e4bf444d1d89e6df41c777e0bacc96e9c09fc4dd2f5fe6b72"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ glibmm gtk2 atkmm cairomm pangomm ]; + propagatedBuildInputs = [ + glibmm + gtk2 + atkmm + cairomm + pangomm + ]; doCheck = true; diff --git a/pkgs/development/libraries/gtkmm/3.x.nix b/pkgs/development/libraries/gtkmm/3.x.nix index c09f05b437723a..b3dcf101f559ed 100644 --- a/pkgs/development/libraries/gtkmm/3.x.nix +++ b/pkgs/development/libraries/gtkmm/3.x.nix @@ -1,4 +1,21 @@ -{ lib, stdenv, fetchurl, pkg-config, meson, ninja, python3, gtk3, glibmm, cairomm, pangomm, atkmm, libepoxy, gnome, glib, gdk-pixbuf }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + meson, + ninja, + python3, + gtk3, + glibmm, + cairomm, + pangomm, + atkmm, + libepoxy, + gnome, + glib, + gdk-pixbuf, +}: stdenv.mkDerivation rec { pname = "gtkmm"; @@ -9,7 +26,10 @@ stdenv.mkDerivation rec { sha256 = "MNW/5ARXHOVmqOk4yLrBdXZCDrUI8eJXg32mPxStRM4="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ pkg-config @@ -21,7 +41,13 @@ stdenv.mkDerivation rec { ]; buildInputs = [ libepoxy ]; - propagatedBuildInputs = [ glibmm gtk3 atkmm cairomm pangomm ]; + propagatedBuildInputs = [ + glibmm + gtk3 + atkmm + cairomm + pangomm + ]; # https://bugzilla.gnome.org/show_bug.cgi?id=764521 doCheck = false; diff --git a/pkgs/development/libraries/gtkmm/4.x.nix b/pkgs/development/libraries/gtkmm/4.x.nix index c1b0be342f805e..75a54e47625dba 100644 --- a/pkgs/development/libraries/gtkmm/4.x.nix +++ b/pkgs/development/libraries/gtkmm/4.x.nix @@ -1,26 +1,30 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, meson -, ninja -, python3 -, gtk4 -, glib -, glibmm_2_68 -, cairomm_1_16 -, pangomm_2_48 -, libepoxy -, gnome -, makeFontsConf -, xvfb-run +{ + stdenv, + lib, + fetchurl, + pkg-config, + meson, + ninja, + python3, + gtk4, + glib, + glibmm_2_68, + cairomm_1_16, + pangomm_2_48, + libepoxy, + gnome, + makeFontsConf, + xvfb-run, }: stdenv.mkDerivation rec { pname = "gtkmm"; version = "4.16.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -46,7 +50,7 @@ stdenv.mkDerivation rec { pangomm_2_48 ]; - nativeCheckInputs = lib.optionals (!stdenv.hostPlatform.isDarwin)[ + nativeCheckInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ xvfb-run ]; diff --git a/pkgs/development/libraries/gtksourceview/3.x.nix b/pkgs/development/libraries/gtksourceview/3.x.nix index 9defccd8de650d..e3f4c1793f795a 100644 --- a/pkgs/development/libraries/gtksourceview/3.x.nix +++ b/pkgs/development/libraries/gtksourceview/3.x.nix @@ -1,18 +1,37 @@ -{ lib, stdenv, fetchurl, pkg-config, atk, cairo, glib, gtk3, pango, vala -, libxml2, perl, intltool, gettext, gobject-introspection, dbus, xvfb-run, shared-mime-info -, testers +{ + lib, + stdenv, + fetchurl, + pkg-config, + atk, + cairo, + glib, + gtk3, + pango, + vala, + libxml2, + perl, + intltool, + gettext, + gobject-introspection, + dbus, + xvfb-run, + shared-mime-info, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "gtksourceview"; version = "3.24.11"; - src = let - inherit (finalAttrs) pname version; - in fetchurl { - url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; - sha256 = "1zbpj283b5ycz767hqz5kdq02wzsga65pp4fykvhg8xj6x50f6v9"; - }; + src = + let + inherit (finalAttrs) pname version; + in + fetchurl { + url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; + sha256 = "1zbpj283b5ycz767hqz5kdq02wzsga65pp4fykvhg8xj6x50f6v9"; + }; propagatedBuildInputs = [ # Required by gtksourceview-3.0.pc @@ -21,13 +40,32 @@ stdenv.mkDerivation (finalAttrs: { shared-mime-info ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ pkg-config intltool perl gobject-introspection vala ]; + nativeBuildInputs = [ + pkg-config + intltool + perl + gobject-introspection + vala + ]; - nativeCheckInputs = [ xvfb-run dbus ]; + nativeCheckInputs = [ + xvfb-run + dbus + ]; - buildInputs = [ atk cairo glib pango libxml2 gettext ]; + buildInputs = [ + atk + cairo + glib + pango + libxml2 + gettext + ]; preBuild = '' substituteInPlace gtksourceview/gtksourceview-utils.c --replace "@NIX_SHARE_PATH@" "$out/share" diff --git a/pkgs/development/libraries/gtksourceview/4.x.nix b/pkgs/development/libraries/gtksourceview/4.x.nix index 1b427957c811af..e29f0ccdf0c85b 100644 --- a/pkgs/development/libraries/gtksourceview/4.x.nix +++ b/pkgs/development/libraries/gtksourceview/4.x.nix @@ -1,40 +1,46 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch2 -, meson -, ninja -, pkg-config -, atk -, cairo -, glib -, gtk3 -, pango -, fribidi -, vala -, libxml2 -, perl -, gettext -, gnome -, gobject-introspection -, dbus -, xvfb-run -, shared-mime-info -, testers +{ + lib, + stdenv, + fetchurl, + fetchpatch2, + meson, + ninja, + pkg-config, + atk, + cairo, + glib, + gtk3, + pango, + fribidi, + vala, + libxml2, + perl, + gettext, + gnome, + gobject-introspection, + dbus, + xvfb-run, + shared-mime-info, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "gtksourceview"; version = "4.8.4"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - src = let - inherit (finalAttrs) pname version; - in fetchurl { - url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; - sha256 = "fsnRj7KD0fhKOj7/O3pysJoQycAGWXs/uru1lYQgqH0="; - }; + src = + let + inherit (finalAttrs) pname version; + in + fetchurl { + url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; + sha256 = "fsnRj7KD0fhKOj7/O3pysJoQycAGWXs/uru1lYQgqH0="; + }; patches = [ # By default, the library loads syntaxes from XDG_DATA_DIRS and user directory diff --git a/pkgs/development/libraries/gtksourceview/5.x.nix b/pkgs/development/libraries/gtksourceview/5.x.nix index d83c019379e458..8c1b6b46aa7bd2 100644 --- a/pkgs/development/libraries/gtksourceview/5.x.nix +++ b/pkgs/development/libraries/gtksourceview/5.x.nix @@ -1,32 +1,37 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, glib -, pcre2 -, gtk4 -, pango -, fribidi -, vala -, gi-docgen -, libxml2 -, perl -, gettext -, gnome -, gobject-introspection -, dbus -, xvfb-run -, shared-mime-info -, testers +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + glib, + pcre2, + gtk4, + pango, + fribidi, + vala, + gi-docgen, + libxml2, + perl, + gettext, + gnome, + gobject-introspection, + dbus, + xvfb-run, + shared-mime-info, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "gtksourceview"; version = "5.14.2"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/gtksourceview/${lib.versions.majorMinor finalAttrs.version}/gtksourceview-${finalAttrs.version}.tar.xz"; @@ -41,7 +46,9 @@ stdenv.mkDerivation (finalAttrs: { ]; # The 10.12 SDK used by x86_64-darwin requires defining `_POSIX_C_SOURCE` to use `strnlen`. - env.NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) "-D_POSIX_C_SOURCE=200809L"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64 + ) "-D_POSIX_C_SOURCE=200809L"; nativeBuildInputs = [ meson diff --git a/pkgs/development/libraries/gtksourceviewmm/4.x.nix b/pkgs/development/libraries/gtksourceviewmm/4.x.nix index d6e7dfd3db56e8..021dde6d02a5b1 100644 --- a/pkgs/development/libraries/gtksourceviewmm/4.x.nix +++ b/pkgs/development/libraries/gtksourceviewmm/4.x.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, gtkmm3, glibmm, gtksourceview4, gnome }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtkmm3, + glibmm, + gtksourceview4, + gnome, +}: stdenv.mkDerivation rec { pname = "gtksourceviewmm"; @@ -18,7 +27,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ glibmm gtkmm3 gtksourceview4 ]; + propagatedBuildInputs = [ + glibmm + gtkmm3 + gtksourceview4 + ]; meta = with lib; { platforms = platforms.linux; @@ -28,4 +41,3 @@ stdenv.mkDerivation rec { maintainers = teams.gnome.members; }; } - diff --git a/pkgs/development/libraries/gtksourceviewmm/default.nix b/pkgs/development/libraries/gtksourceviewmm/default.nix index ec139651292913..975ac5bf685f5a 100644 --- a/pkgs/development/libraries/gtksourceviewmm/default.nix +++ b/pkgs/development/libraries/gtksourceviewmm/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, gtkmm3, glibmm, gtksourceview3, gnome }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtkmm3, + glibmm, + gtksourceview3, + gnome, +}: stdenv.mkDerivation rec { pname = "gtksourceviewmm"; @@ -18,7 +27,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glibmm gtkmm3 gtksourceview3 ]; + buildInputs = [ + glibmm + gtkmm3 + gtksourceview3 + ]; meta = with lib; { platforms = platforms.unix; @@ -28,4 +41,3 @@ stdenv.mkDerivation rec { maintainers = [ maintainers.juliendehos ]; }; } - diff --git a/pkgs/development/libraries/gtkspell/3.nix b/pkgs/development/libraries/gtkspell/3.nix index 7e75108b1a3ecf..2c9fcafad20157 100644 --- a/pkgs/development/libraries/gtkspell/3.nix +++ b/pkgs/development/libraries/gtkspell/3.nix @@ -1,18 +1,43 @@ -{lib, stdenv, fetchurl, gtk3, aspell, pkg-config, enchant, isocodes, intltool, gobject-introspection, vala}: +{ + lib, + stdenv, + fetchurl, + gtk3, + aspell, + pkg-config, + enchant, + isocodes, + intltool, + gobject-introspection, + vala, +}: stdenv.mkDerivation rec { pname = "gtkspell"; version = "3.0.10"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://sourceforge/gtkspell/gtkspell3-${version}.tar.xz"; sha256 = "0cjp6xdcnzh6kka42w9g0w2ihqjlq8yl8hjm9wsfnixk6qwgch5h"; }; - nativeBuildInputs = [ pkg-config intltool gobject-introspection vala ]; - buildInputs = [ aspell gtk3 enchant isocodes ]; + nativeBuildInputs = [ + pkg-config + intltool + gobject-introspection + vala + ]; + buildInputs = [ + aspell + gtk3 + enchant + isocodes + ]; propagatedBuildInputs = [ enchant ]; configureFlags = [ diff --git a/pkgs/development/libraries/gtkspell/default.nix b/pkgs/development/libraries/gtkspell/default.nix index eb8b1363c32b7e..b663839ac53c12 100644 --- a/pkgs/development/libraries/gtkspell/default.nix +++ b/pkgs/development/libraries/gtkspell/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchurl -, fetchpatch -, autoreconfHook -, docbook_xsl -, gtk-doc -, intltool -, pkg-config -, aspell -, enchant -, gtk2 +{ + stdenv, + lib, + fetchurl, + fetchpatch, + autoreconfHook, + docbook_xsl, + gtk-doc, + intltool, + pkg-config, + aspell, + enchant, + gtk2, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/gupnp/1.6.nix b/pkgs/development/libraries/gupnp/1.6.nix index 46714e2e25bd65..9f454b72cca111 100644 --- a/pkgs/development/libraries/gupnp/1.6.nix +++ b/pkgs/development/libraries/gupnp/1.6.nix @@ -1,24 +1,29 @@ -{ stdenv -, lib -, fetchurl -, meson -, ninja -, pkg-config -, gobject-introspection -, vala -, gi-docgen -, glib -, gssdp_1_6 -, libsoup_3 -, libxml2 -, gnome +{ + stdenv, + lib, + fetchurl, + meson, + ninja, + pkg-config, + gobject-introspection, + vala, + gi-docgen, + glib, + gssdp_1_6, + libsoup_3, + libxml2, + gnome, }: stdenv.mkDerivation rec { pname = "gupnp"; version = "1.6.7"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/gupnp/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -53,7 +58,8 @@ stdenv.mkDerivation rec { mesonCheckFlags = [ # The service-proxy test takes 28s on ofborg, which is too close to the time limit. - "--timeout-multiplier" "2" + "--timeout-multiplier" + "2" ]; postFixup = '' diff --git a/pkgs/development/libraries/gupnp/default.nix b/pkgs/development/libraries/gupnp/default.nix index 4835047a3edd0e..52e09d2c916e85 100644 --- a/pkgs/development/libraries/gupnp/default.nix +++ b/pkgs/development/libraries/gupnp/default.nix @@ -1,30 +1,33 @@ -{ stdenv -, lib -, fetchurl -, fetchpatch2 -, meson -, ninja -, pkg-config -, gobject-introspection -, vala -, gtk-doc -, docbook_xsl -, docbook_xml_dtd_412 -, docbook_xml_dtd_45 -, glib -, gssdp -, libsoup_2_4 -, libxml2 -, libuuid -, gnome +{ + stdenv, + lib, + fetchurl, + fetchpatch2, + meson, + ninja, + pkg-config, + gobject-introspection, + vala, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_412, + docbook_xml_dtd_45, + glib, + gssdp, + libsoup_2_4, + libxml2, + libuuid, + gnome, }: stdenv.mkDerivation rec { pname = "gupnp"; version = "1.4.4"; - outputs = [ "out" "dev" ] - ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ "devdoc" ]; + outputs = [ + "out" + "dev" + ] ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ "devdoc" ]; src = fetchurl { url = "mirror://gnome/sources/gupnp/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/development/libraries/hamlib/default.nix b/pkgs/development/libraries/hamlib/default.nix index 2089050552e7ec..94292e5fb64765 100644 --- a/pkgs/development/libraries/hamlib/default.nix +++ b/pkgs/development/libraries/hamlib/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchurl -, perl -, swig -, gd -, ncurses -, python311 -, libxml2 -, tcl -, libusb-compat-0_1 -, pkg-config -, boost -, libtool -, pythonBindings ? true -, tclBindings ? true -, perlBindings ? stdenv.buildPlatform == stdenv.hostPlatform -, buildPackages +{ + lib, + stdenv, + fetchurl, + perl, + swig, + gd, + ncurses, + python311, + libxml2, + tcl, + libusb-compat-0_1, + pkg-config, + boost, + libtool, + pythonBindings ? true, + tclBindings ? true, + perlBindings ? stdenv.buildPlatform == stdenv.hostPlatform, + buildPackages, }: let python3 = python311; # needs distutils and imp @@ -31,40 +32,54 @@ stdenv.mkDerivation rec { strictDeps = true; depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ - swig - pkg-config - libtool - ] ++ lib.optionals pythonBindings [ python3 ] + nativeBuildInputs = + [ + swig + pkg-config + libtool + ] + ++ lib.optionals pythonBindings [ python3 ] ++ lib.optionals tclBindings [ tcl ] ++ lib.optionals perlBindings [ perl ]; - buildInputs = [ - gd - libxml2 - libusb-compat-0_1 - boost - ] ++ lib.optionals pythonBindings [ python3 ncurses ] + buildInputs = + [ + gd + libxml2 + libusb-compat-0_1 + boost + ] + ++ lib.optionals pythonBindings [ + python3 + ncurses + ] ++ lib.optionals tclBindings [ tcl ]; - - configureFlags = [ - "CC_FOR_BUILD=${stdenv.cc.targetPrefix}cc" - ] ++ lib.optionals perlBindings [ "--with-perl-binding" ] - ++ lib.optionals tclBindings [ "--with-tcl-binding" "--with-tcl=${tcl}/lib/" ] + configureFlags = + [ + "CC_FOR_BUILD=${stdenv.cc.targetPrefix}cc" + ] + ++ lib.optionals perlBindings [ "--with-perl-binding" ] + ++ lib.optionals tclBindings [ + "--with-tcl-binding" + "--with-tcl=${tcl}/lib/" + ] ++ lib.optionals pythonBindings [ "--with-python-binding" ]; meta = with lib; { description = "Runtime library to control radio transceivers and receivers"; longDescription = '' - Hamlib provides a standardized programming interface that applications - can use to send the appropriate commands to a radio. + Hamlib provides a standardized programming interface that applications + can use to send the appropriate commands to a radio. - Also included in the package is a simple radio control program 'rigctl', - which lets one control a radio transceiver or receiver, either from - command line interface or in a text-oriented interactive interface. + Also included in the package is a simple radio control program 'rigctl', + which lets one control a radio transceiver or receiver, either from + command line interface or in a text-oriented interactive interface. ''; - license = with licenses; [ gpl2Plus lgpl2Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + ]; homepage = "https://hamlib.sourceforge.net"; maintainers = with maintainers; [ relrod ]; platforms = with platforms; unix; diff --git a/pkgs/development/libraries/harfbuzz/default.nix b/pkgs/development/libraries/harfbuzz/default.nix index 1ff6d193268e71..d724e06433a4b2 100644 --- a/pkgs/development/libraries/harfbuzz/default.nix +++ b/pkgs/development/libraries/harfbuzz/default.nix @@ -1,34 +1,37 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, glib -, freetype -, libintl -, meson -, ninja -, gobject-introspection -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, icu -, graphite2 -, harfbuzz # The icu variant uses and propagates the non-icu one. -, ApplicationServices -, CoreText -, withCoreText ? false -, withIcu ? false # recommended by upstream as default, but most don't needed and it's big -, withGraphite2 ? true # it is small and major distros do include it -, python3 -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_43 -# for passthru.tests -, gimp -, gtk3 -, gtk4 -, mapnik -, qt5 -, testers +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + freetype, + libintl, + meson, + ninja, + gobject-introspection, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + icu, + graphite2, + harfbuzz, # The icu variant uses and propagates the non-icu one. + ApplicationServices, + CoreText, + withCoreText ? false, + withIcu ? false, # recommended by upstream as default, but most don't needed and it's big + withGraphite2 ? true, # it is small and major distros do include it + python3, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_43, + # for passthru.tests + gimp, + gtk3, + gtk4, + mapnik, + qt5, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -40,15 +43,21 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-sssTvTUZBMuQOPkH3A3uCuBxJwYSQv41VrJ5XE6XSPw="; }; - postPatch = '' - patchShebangs src/*.py test - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # ApplicationServices.framework headers have cast-align warnings. - substituteInPlace src/hb.hh \ - --replace '#pragma GCC diagnostic error "-Wcast-align"' "" - ''; + postPatch = + '' + patchShebangs src/*.py test + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # ApplicationServices.framework headers have cast-align warnings. + substituteInPlace src/hb.hh \ + --replace '#pragma GCC diagnostic error "-Wcast-align"' "" + ''; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "dev"; mesonFlags = [ @@ -82,11 +91,22 @@ stdenv.mkDerivation (finalAttrs: { docbook_xml_dtd_43 ] ++ lib.optional withIntrospection gobject-introspection; - buildInputs = [ glib freetype ] - ++ lib.optionals withCoreText [ ApplicationServices CoreText ]; + buildInputs = + [ + glib + freetype + ] + ++ lib.optionals withCoreText [ + ApplicationServices + CoreText + ]; - propagatedBuildInputs = lib.optional withGraphite2 graphite2 - ++ lib.optionals withIcu [ icu harfbuzz ]; + propagatedBuildInputs = + lib.optional withGraphite2 graphite2 + ++ lib.optionals withIcu [ + icu + harfbuzz + ]; doCheck = true; @@ -101,7 +121,12 @@ stdenv.mkDerivation (finalAttrs: { ''; passthru.tests = { - inherit gimp gtk3 gtk4 mapnik; + inherit + gimp + gtk3 + gtk4 + mapnik + ; inherit (qt5) qtbase; pkg-config = testers.hasPkgConfigModules { package = finalAttrs.finalPackage; diff --git a/pkgs/development/libraries/herqq/default.nix b/pkgs/development/libraries/herqq/default.nix index de446eb9527dea..d994c290486d8f 100644 --- a/pkgs/development/libraries/herqq/default.nix +++ b/pkgs/development/libraries/herqq/default.nix @@ -1,13 +1,26 @@ -{ lib, mkDerivation, fetchFromGitHub, qmake, qtmultimedia, qtbase }: +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qtmultimedia, + qtbase, +}: mkDerivation rec { version = "unstable-20-06-26"; pname = "herqq"; nativeBuildInputs = [ qmake ]; - buildInputs = [ qtbase qtmultimedia ]; + buildInputs = [ + qtbase + qtmultimedia + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; sourceRoot = "${src.name}/herqq"; src = fetchFromGitHub { diff --git a/pkgs/development/libraries/hidapi/default.nix b/pkgs/development/libraries/hidapi/default.nix index 6e537e8b74fbd6..831f3fec8b90a3 100644 --- a/pkgs/development/libraries/hidapi/default.nix +++ b/pkgs/development/libraries/hidapi/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, libusb1 -, udev -, Cocoa -, IOKit -, testers +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + libusb1, + udev, + Cocoa, + IOKit, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -21,13 +22,22 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-p3uzBq5VxxQbVuy1lEHEEQdxXwnhQgJDIyAAWjVWNIg="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libusb1 udev ]; + buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ + libusb1 + udev + ]; enableParallelBuilding = true; - propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa IOKit ]; + propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + IOKit + ]; passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; @@ -36,13 +46,18 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/libusb/hidapi"; maintainers = with maintainers; [ prusnak ]; # You can choose between GPLv3, BSD or HIDAPI license (even more liberal) - license = with licenses; [ bsd3 /* or */ gpl3Only ] ; - pkgConfigModules = lib.optionals stdenv.hostPlatform.isDarwin [ - "hidapi" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "hidapi-hidraw" - "hidapi-libusb" + license = with licenses; [ + bsd3 # or + gpl3Only ]; + pkgConfigModules = + lib.optionals stdenv.hostPlatform.isDarwin [ + "hidapi" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "hidapi-hidraw" + "hidapi-libusb" + ]; platforms = platforms.unix ++ platforms.windows; }; }) diff --git a/pkgs/development/libraries/hivex/default.nix b/pkgs/development/libraries/hivex/default.nix index d31e57b6c22852..79315f1826890d 100644 --- a/pkgs/development/libraries/hivex/default.nix +++ b/pkgs/development/libraries/hivex/default.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchurl, pkg-config, autoreconfHook, makeWrapper, perlPackages -, ocamlPackages, libxml2, libintl +{ + lib, + stdenv, + fetchurl, + pkg-config, + autoreconfHook, + makeWrapper, + perlPackages, + ocamlPackages, + libxml2, + libintl, }: stdenv.mkDerivation rec { @@ -19,13 +28,26 @@ stdenv.mkDerivation rec { ''; strictDeps = true; - nativeBuildInputs = [ autoreconfHook makeWrapper perlPackages.perl pkg-config ] - ++ (with ocamlPackages; [ ocaml findlib ]); - buildInputs = [ - libxml2 - ] - ++ (with perlPackages; [ perl IOStringy ]) - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libintl ]; + nativeBuildInputs = + [ + autoreconfHook + makeWrapper + perlPackages.perl + pkg-config + ] + ++ (with ocamlPackages; [ + ocaml + findlib + ]); + buildInputs = + [ + libxml2 + ] + ++ (with perlPackages; [ + perl + IOStringy + ]) + ++ lib.optionals stdenv.hostPlatform.isDarwin [ libintl ]; enableParallelBuilding = true; @@ -42,7 +64,7 @@ stdenv.mkDerivation rec { description = "Windows registry hive extraction library"; license = licenses.lgpl2Only; homepage = "https://github.com/libguestfs/hivex"; - maintainers = with maintainers; [offline]; + maintainers = with maintainers; [ offline ]; platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/hpx/default.nix b/pkgs/development/libraries/hpx/default.nix index 843fc1991f279d..2e13c016433e87 100644 --- a/pkgs/development/libraries/hpx/default.nix +++ b/pkgs/development/libraries/hpx/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, asio -, boost -, cmake -, hwloc -, gperftools -, pkg-config -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + asio, + boost, + cmake, + hwloc, + gperftools, + pkg-config, + python3, }: stdenv.mkDerivation rec { @@ -22,8 +23,16 @@ stdenv.mkDerivation rec { }; propagatedBuildInputs = [ hwloc ]; - buildInputs = [ asio boost gperftools ]; - nativeBuildInputs = [ cmake pkg-config python3 ]; + buildInputs = [ + asio + boost + gperftools + ]; + nativeBuildInputs = [ + cmake + pkg-config + python3 + ]; strictDeps = true; diff --git a/pkgs/development/libraries/hspell/default.nix b/pkgs/development/libraries/hspell/default.nix index cead584b83ea1b..df8b97149d9c3e 100644 --- a/pkgs/development/libraries/hspell/default.nix +++ b/pkgs/development/libraries/hspell/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, perl, zlib, buildPackages }: +{ + lib, + stdenv, + fetchurl, + perl, + zlib, + buildPackages, +}: stdenv.mkDerivation rec { name = "${passthru.pname}-${passthru.version}"; @@ -15,7 +22,7 @@ stdenv.mkDerivation rec { hash = "sha256-cxD11YdA0h1tIVwReWWGAu99qXqBa8FJfIdkvpeqvqM="; }; - patches = [./remove-shared-library-checks.patch]; + patches = [ ./remove-shared-library-checks.patch ]; postPatch = "patchShebangs ."; preBuild = lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' make CC=${buildPackages.stdenv.cc}/bin/cc find_sizes @@ -30,7 +37,10 @@ stdenv.mkDerivation rec { postInstall = '' patchShebangs --update $out/bin/multispell ''; - nativeBuildInputs = [ perl zlib ]; + nativeBuildInputs = [ + perl + zlib + ]; buildInputs = [ perl ]; strictDeps = true; diff --git a/pkgs/development/libraries/hspell/dicts.nix b/pkgs/development/libraries/hspell/dicts.nix index 8b629d9b619462..a2a47c5aef1a49 100644 --- a/pkgs/development/libraries/hspell/dicts.nix +++ b/pkgs/development/libraries/hspell/dicts.nix @@ -1,15 +1,33 @@ -{ lib, stdenv, hspell }: +{ + lib, + stdenv, + hspell, +}: let - dict = variant: a: stdenv.mkDerivation ({ - inherit (hspell) version src patches postPatch nativeBuildInputs; - buildFlags = [ variant ]; - - meta = hspell.meta // { - broken = true; - description = "${variant} Hebrew dictionary"; - } // (lib.optionalAttrs (a ? meta) a.meta); - } // (removeAttrs a ["meta"])); + dict = + variant: a: + stdenv.mkDerivation ( + { + inherit (hspell) + version + src + patches + postPatch + nativeBuildInputs + ; + buildFlags = [ variant ]; + + meta = + hspell.meta + // { + broken = true; + description = "${variant} Hebrew dictionary"; + } + // (lib.optionalAttrs (a ? meta) a.meta); + } + // (removeAttrs a [ "meta" ]) + ); in { recurseForDerivations = true; diff --git a/pkgs/development/libraries/hunspell/default.nix b/pkgs/development/libraries/hunspell/default.nix index 4e704a4859132b..0644c6b6e984d5 100644 --- a/pkgs/development/libraries/hunspell/default.nix +++ b/pkgs/development/libraries/hunspell/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, ncurses, readline, autoreconfHook }: +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + readline, + autoreconfHook, +}: stdenv.mkDerivation rec { version = "1.7.2"; @@ -11,9 +18,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-x2FXxnVIqsf5/UEQcvchAndXBv/3mW8Z55djQAFgNA8="; }; - outputs = [ "bin" "dev" "out" "man" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + ]; - buildInputs = [ ncurses readline ]; + buildInputs = [ + ncurses + readline + ]; nativeBuildInputs = [ autoreconfHook ]; patches = [ @@ -26,7 +41,10 @@ stdenv.mkDerivation rec { autoreconfFlags = [ "-vfi" ]; - configureFlags = [ "--with-ui" "--with-readline" ]; + configureFlags = [ + "--with-ui" + "--with-readline" + ]; hardeningDisable = [ "format" ]; @@ -54,7 +72,11 @@ stdenv.mkDerivation rec { * Delphi, Java (JNA, JNI), Perl, .NET, Python, Ruby ([1], [2]), UNO. ''; platforms = platforms.all; - license = with licenses; [ gpl2 lgpl21 mpl11 ]; + license = with licenses; [ + gpl2 + lgpl21 + mpl11 + ]; maintainers = [ ]; }; } diff --git a/pkgs/development/libraries/hunspell/dictionaries-chromium.nix b/pkgs/development/libraries/hunspell/dictionaries-chromium.nix index e22c8c0a52c511..6e2bac906eeebb 100644 --- a/pkgs/development/libraries/hunspell/dictionaries-chromium.nix +++ b/pkgs/development/libraries/hunspell/dictionaries-chromium.nix @@ -1,7 +1,16 @@ -{ lib, stdenv, fetchgit }: +{ + lib, + stdenv, + fetchgit, +}: let - mkDictFromChromium = { shortName, dictFileName, shortDescription }: + mkDictFromChromium = + { + shortName, + dictFileName, + shortDescription, + }: stdenv.mkDerivation { pname = "hunspell-dict-${shortName}-chromium"; version = "115.0.5790.170"; @@ -35,7 +44,12 @@ let See https://www.chromium.org/developers/how-tos/editing-the-spell-checking-dictionaries/ ''; - license = with lib.licenses; [ gpl2 lgpl21 mpl11 lgpl3 ]; + license = with lib.licenses; [ + gpl2 + lgpl21 + mpl11 + lgpl3 + ]; maintainers = with lib.maintainers; [ networkexception ]; platforms = lib.platforms.all; }; @@ -43,7 +57,7 @@ let in rec { - /* ENGLISH */ + # ENGLISH en_US = en-us; en-us = mkDictFromChromium { @@ -59,7 +73,7 @@ rec { shortDescription = "English (United Kingdom)"; }; - /* GERMAN */ + # GERMAN de_DE = de-de; de-de = mkDictFromChromium { @@ -68,7 +82,7 @@ rec { shortDescription = "German (Germany)"; }; - /* FRENCH */ + # FRENCH fr_FR = fr-fr; fr-fr = mkDictFromChromium { diff --git a/pkgs/development/libraries/hyphen/default.nix b/pkgs/development/libraries/hyphen/default.nix index 85bee97a76d554..daa3f86b2e6de6 100644 --- a/pkgs/development/libraries/hyphen/default.nix +++ b/pkgs/development/libraries/hyphen/default.nix @@ -1,19 +1,31 @@ -{ lib, stdenv, fetchurl, perl, ... }: +{ + lib, + stdenv, + fetchurl, + perl, + ... +}: let version = "2.8.8"; - folder = with builtins; - let parts = splitVersion version; - in concatStringsSep "." [ (elemAt parts 0) (elemAt parts 1) ]; -in stdenv.mkDerivation rec { + folder = + with builtins; + let + parts = splitVersion version; + in + concatStringsSep "." [ + (elemAt parts 0) + (elemAt parts 1) + ]; +in +stdenv.mkDerivation rec { pname = "hyphen"; inherit version; nativeBuildInputs = [ perl ]; src = fetchurl { - url = - "https://sourceforge.net/projects/hunspell/files/Hyphen/${folder}/${pname}-${version}.tar.gz"; + url = "https://sourceforge.net/projects/hunspell/files/Hyphen/${folder}/${pname}-${version}.tar.gz"; sha256 = "01ap9pr6zzzbp4ky0vy7i1983fwyqy27pl0ld55s30fdxka3ciih"; }; @@ -34,7 +46,11 @@ in stdenv.mkDerivation rec { mainProgram = "substrings.pl"; homepage = "https://sourceforge.net/projects/hunspell/files/Hyphen/"; platforms = platforms.all; - license = with licenses; [ gpl2 lgpl21 mpl11 ]; + license = with licenses; [ + gpl2 + lgpl21 + mpl11 + ]; maintainers = with maintainers; [ Br1ght0ne ]; }; } diff --git a/pkgs/development/libraries/hyphen/dictionaries.nix b/pkgs/development/libraries/hyphen/dictionaries.nix index 49d314095c5773..7eabf1f985aac6 100644 --- a/pkgs/development/libraries/hyphen/dictionaries.nix +++ b/pkgs/development/libraries/hyphen/dictionaries.nix @@ -1,7 +1,12 @@ -/* hyphen dictionaries */ - -{ hyphen, stdenv, lib, fetchgit, fetchurl }: +# hyphen dictionaries +{ + hyphen, + stdenv, + lib, + fetchgit, + fetchurl, +}: let libreofficeRepository = "https://anongit.freedesktop.org/git/libreoffice/dictionaries.git"; @@ -9,7 +14,13 @@ let libreofficeSubdir = "de"; mkDictFromLibreofficeGit = - { subdir, shortName, shortDescription, dictFileName, readmeFileName }: + { + subdir, + shortName, + shortDescription, + dictFileName, + readmeFileName, + }: stdenv.mkDerivation rec { version = "24.8"; pname = "hyphen-dict-${shortName}-libreoffice"; @@ -41,16 +52,21 @@ let in rec { - /* ENGLISH */ + # ENGLISH en_US = en-us; en-us = stdenv.mkDerivation rec { nativeBuildInputs = hyphen.nativeBuildInputs; version = hyphen.version; pname = "hyphen-dict-en-us"; - src = hyphen.src; + src = hyphen.src; meta = { - inherit (hyphen.meta) homepage platforms license maintainers; + inherit (hyphen.meta) + homepage + platforms + license + maintainers + ; description = "Hyphen dictionary for English (United States)"; }; installPhase = '' @@ -60,7 +76,7 @@ rec { ''; }; - /* GERMAN */ + # GERMAN de_DE = de-de; de-de = mkDictFromLibreofficeGit { diff --git a/pkgs/development/libraries/icu/default.nix b/pkgs/development/libraries/icu/default.nix index e5fc14bb9cc9da..f2348a4772852e 100644 --- a/pkgs/development/libraries/icu/default.nix +++ b/pkgs/development/libraries/icu/default.nix @@ -1,8 +1,25 @@ -{ stdenv, lib, fetchurl, fetchpatch, fixDarwinDylibNames, testers, buildPackages, updateAutotoolsGnuConfigScriptsHook }: +{ + stdenv, + lib, + fetchurl, + fetchpatch, + fixDarwinDylibNames, + testers, + buildPackages, + updateAutotoolsGnuConfigScriptsHook, +}: let make-icu = (import ./make-icu.nix) { - inherit stdenv lib buildPackages fetchurl fixDarwinDylibNames testers updateAutotoolsGnuConfigScriptsHook; + inherit + stdenv + lib + buildPackages + fetchurl + fixDarwinDylibNames + testers + updateAutotoolsGnuConfigScriptsHook + ; }; in { diff --git a/pkgs/development/libraries/icu/make-icu.nix b/pkgs/development/libraries/icu/make-icu.nix index d7fe46041607ed..26058b27579e38 100644 --- a/pkgs/development/libraries/icu/make-icu.nix +++ b/pkgs/development/libraries/icu/make-icu.nix @@ -1,6 +1,20 @@ -{ stdenv, lib, buildPackages, fetchurl, fixDarwinDylibNames, testers, updateAutotoolsGnuConfigScriptsHook }: - -{ version, hash, patches ? [], patchFlags ? [], withStatic ? stdenv.hostPlatform.isStatic }: +{ + stdenv, + lib, + buildPackages, + fetchurl, + fixDarwinDylibNames, + testers, + updateAutotoolsGnuConfigScriptsHook, +}: + +{ + version, + hash, + patches ? [ ], + patchFlags ? [ ], + withStatic ? stdenv.hostPlatform.isStatic, +}: let # Cross-compiled icu4c requires a build-root of a native compile @@ -14,7 +28,9 @@ let baseAttrs = { src = fetchurl { - url = "https://github.com/unicode-org/icu/releases/download/release-${release}/icu4c-${lib.replaceStrings [ "." ] [ "_" ] version}-src.tgz"; + url = "https://github.com/unicode-org/icu/releases/download/release-${release}/icu4c-${ + lib.replaceStrings [ "." ] [ "_" ] version + }-src.tgz"; inherit hash; }; @@ -24,27 +40,37 @@ let ''; # https://sourceware.org/glibc/wiki/Release/2.26#Removal_of_.27xlocale.h.27 - postPatch = if (stdenv.hostPlatform.libc == "glibc" || stdenv.hostPlatform.libc == "musl") && lib.versionOlder version "62.1" - then "substituteInPlace i18n/digitlst.cpp --replace '' ''" - else null; # won't find locale_t on darwin + postPatch = + if + (stdenv.hostPlatform.libc == "glibc" || stdenv.hostPlatform.libc == "musl") + && lib.versionOlder version "62.1" + then + "substituteInPlace i18n/digitlst.cpp --replace '' ''" + else + null; # won't find locale_t on darwin inherit patchFlags patches; - preConfigure = '' - sed -i -e "s|/bin/sh|${stdenv.shell}|" configure + preConfigure = + '' + sed -i -e "s|/bin/sh|${stdenv.shell}|" configure - # $(includedir) is different from $(prefix)/include due to multiple outputs - sed -i -e 's|^\(CPPFLAGS = .*\) -I\$(prefix)/include|\1 -I$(includedir)|' config/Makefile.inc.in - '' + lib.optionalString stdenv.hostPlatform.isAarch32 '' - # From https://archlinuxarm.org/packages/armv7h/icu/files/icudata-stdlibs.patch - sed -e 's/LDFLAGSICUDT=-nodefaultlibs -nostdlib/LDFLAGSICUDT=/' -i config/mh-linux - ''; + # $(includedir) is different from $(prefix)/include due to multiple outputs + sed -i -e 's|^\(CPPFLAGS = .*\) -I\$(prefix)/include|\1 -I$(includedir)|' config/Makefile.inc.in + '' + + lib.optionalString stdenv.hostPlatform.isAarch32 '' + # From https://archlinuxarm.org/packages/armv7h/icu/files/icudata-stdlibs.patch + sed -e 's/LDFLAGSICUDT=-nodefaultlibs -nostdlib/LDFLAGSICUDT=/' -i config/mh-linux + ''; dontDisableStatic = withStatic; - configureFlags = [ "--disable-debug" ] + configureFlags = + [ "--disable-debug" ] ++ lib.optional (stdenv.hostPlatform.isFreeBSD || stdenv.hostPlatform.isDarwin) "--enable-rpath" - ++ lib.optional (stdenv.buildPlatform != stdenv.hostPlatform) "--with-cross-build=${nativeBuildRoot}" + ++ lib.optional ( + stdenv.buildPlatform != stdenv.hostPlatform + ) "--with-cross-build=${nativeBuildRoot}" ++ lib.optional withStatic "--enable-static"; enableParallelBuilding = true; @@ -65,33 +91,52 @@ let realAttrs = baseAttrs // { inherit pname version; - outputs = [ "out" "dev" ] ++ lib.optional withStatic "static"; + outputs = [ + "out" + "dev" + ] ++ lib.optional withStatic "static"; outputBin = "dev"; - nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook ] ++ + nativeBuildInputs = + [ updateAutotoolsGnuConfigScriptsHook ] + ++ # FIXME: This fixes dylib references in the dylibs themselves, but # not in the programs in $out/bin. lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; - # remove dependency on bootstrap-tools in early stdenv build - postInstall = lib.optionalString withStatic '' - mkdir -p $static/lib - mv -v lib/*.a $static/lib - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - sed -i 's/INSTALL_CMD=.*install/INSTALL_CMD=install/' $out/lib/icu/${lib.versions.majorMinor version}/pkgdata.inc - '' + (let - replacements = [ - { from = "\${prefix}/include"; to = "${placeholder "dev"}/include"; } # --cppflags-searchpath - { from = "\${pkglibdir}/Makefile.inc"; to = "${placeholder "dev"}/lib/icu/Makefile.inc"; } # --incfile - { from = "\${pkglibdir}/pkgdata.inc"; to = "${placeholder "dev"}/lib/icu/pkgdata.inc"; } # --incpkgdatafile - ]; - in '' - rm $out/share/icu/${lib.versions.majorMinor version}/install-sh $out/share/icu/${lib.versions.majorMinor version}/mkinstalldirs # Avoid having a runtime dependency on bash - - substituteInPlace "$dev/bin/icu-config" \ - ${lib.concatMapStringsSep " " (r: "--replace '${r.from}' '${r.to}'") replacements} - ''); + postInstall = + lib.optionalString withStatic '' + mkdir -p $static/lib + mv -v lib/*.a $static/lib + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + sed -i 's/INSTALL_CMD=.*install/INSTALL_CMD=install/' $out/lib/icu/${lib.versions.majorMinor version}/pkgdata.inc + '' + + ( + let + replacements = [ + { + from = "\${prefix}/include"; + to = "${placeholder "dev"}/include"; + } # --cppflags-searchpath + { + from = "\${pkglibdir}/Makefile.inc"; + to = "${placeholder "dev"}/lib/icu/Makefile.inc"; + } # --incfile + { + from = "\${pkglibdir}/pkgdata.inc"; + to = "${placeholder "dev"}/lib/icu/pkgdata.inc"; + } # --incpkgdatafile + ]; + in + '' + rm $out/share/icu/${lib.versions.majorMinor version}/install-sh $out/share/icu/${lib.versions.majorMinor version}/mkinstalldirs # Avoid having a runtime dependency on bash + + substituteInPlace "$dev/bin/icu-config" \ + ${lib.concatMapStringsSep " " (r: "--replace '${r.from}' '${r.to}'") replacements} + '' + ); postFixup = ''moveToOutput lib/icu "$dev" ''; }; @@ -100,11 +145,13 @@ let pname = pname + "-build-root"; inherit version; - preConfigure = baseAttrs.preConfigure + '' - mkdir build - cd build - configureScript=../configure - ''; + preConfigure = + baseAttrs.preConfigure + + '' + mkdir build + cd build + configureScript=../configure + ''; postBuild = '' cd .. @@ -114,9 +161,15 @@ let ''; }; - mkWithAttrs = attrs: stdenv.mkDerivation (finalAttrs: attrs // { - passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; - passthru.buildRootOnly = mkWithAttrs buildRootOnlyAttrs; - }); + mkWithAttrs = + attrs: + stdenv.mkDerivation ( + finalAttrs: + attrs + // { + passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; + passthru.buildRootOnly = mkWithAttrs buildRootOnlyAttrs; + } + ); in - mkWithAttrs realAttrs +mkWithAttrs realAttrs diff --git a/pkgs/development/libraries/iksemel/default.nix b/pkgs/development/libraries/iksemel/default.nix index 6ba64dcaa5888f..440790d97ec9c8 100644 --- a/pkgs/development/libraries/iksemel/default.nix +++ b/pkgs/development/libraries/iksemel/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, autoreconfHook, libtool, pkg-config, gnutls, fetchFromGitHub, texinfo }: +{ + lib, + stdenv, + autoreconfHook, + libtool, + pkg-config, + gnutls, + fetchFromGitHub, + texinfo, +}: stdenv.mkDerivation rec { pname = "iksemel"; @@ -11,7 +20,12 @@ stdenv.mkDerivation rec { sha256 = "1xv302p344hnpxqcgs3z6wwxhrik39ckgfw5cjyrw0dkf316z9yh"; }; - nativeBuildInputs = [ pkg-config autoreconfHook libtool texinfo ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + libtool + texinfo + ]; buildInputs = [ gnutls ]; meta = with lib; { diff --git a/pkgs/development/libraries/imgui/default.nix b/pkgs/development/libraries/imgui/default.nix index 16f9976e2df5b0..562fdd1dbd57d1 100644 --- a/pkgs/development/libraries/imgui/default.nix +++ b/pkgs/development/libraries/imgui/default.nix @@ -15,7 +15,8 @@ vulkan-loader, # NOTE: Not coming from vcpkg - IMGUI_LINK_GLVND ? !stdenv.hostPlatform.isWindows && (IMGUI_BUILD_OPENGL2_BINDING || IMGUI_BUILD_OPENGL3_BINDING), + IMGUI_LINK_GLVND ? + !stdenv.hostPlatform.isWindows && (IMGUI_BUILD_OPENGL2_BINDING || IMGUI_BUILD_OPENGL3_BINDING), # The intent is to mirror vcpkg's flags[^1], # but we only actually support Linux and glfw3 until someone contributes the rest @@ -33,8 +34,7 @@ IMGUI_BUILD_OPENGL3_BINDING ? IMGUI_BUILD_SDL2_BINDING || IMGUI_BUILD_GLFW_BINDING || IMGUI_BUILD_GLUT_BINDING, IMGUI_BUILD_OSX_BINDING ? stdenv.hostPlatform.isDarwin, - IMGUI_BUILD_SDL2_BINDING ? - !IMGUI_BUILD_GLFW_BINDING && !stdenv.hostPlatform.isDarwin, + IMGUI_BUILD_SDL2_BINDING ? !IMGUI_BUILD_GLFW_BINDING && !stdenv.hostPlatform.isDarwin, IMGUI_BUILD_SDL2_RENDERER_BINDING ? IMGUI_BUILD_SDL2_BINDING, IMGUI_BUILD_VULKAN_BINDING ? false, IMGUI_BUILD_WIN32_BINDING ? false, diff --git a/pkgs/development/libraries/indicator-application/gtk2.nix b/pkgs/development/libraries/indicator-application/gtk2.nix index 9fe3575b7bc2a5..d0f5b42cce47cb 100644 --- a/pkgs/development/libraries/indicator-application/gtk2.nix +++ b/pkgs/development/libraries/indicator-application/gtk2.nix @@ -1,7 +1,18 @@ -{ stdenv, fetchurl, lib, file -, pkg-config, autoconf -, glib, dbus-glib, json-glib -, gtk2, libindicator-gtk2, libdbusmenu-gtk2, libappindicator-gtk2 }: +{ + stdenv, + fetchurl, + lib, + file, + pkg-config, + autoconf, + glib, + dbus-glib, + json-glib, + gtk2, + libindicator-gtk2, + libdbusmenu-gtk2, + libappindicator-gtk2, +}: stdenv.mkDerivation rec { pname = "indicator-application-gtk2"; @@ -12,11 +23,19 @@ stdenv.mkDerivation rec { sha256 = "1xqsb6c1pwawabw854f7aybjrgyhc2r1316i9lyjspci51zk5m7v"; }; - nativeBuildInputs = [ pkg-config autoconf ]; + nativeBuildInputs = [ + pkg-config + autoconf + ]; buildInputs = [ - glib dbus-glib json-glib - gtk2 libindicator-gtk2 libdbusmenu-gtk2 libappindicator-gtk2 + glib + dbus-glib + json-glib + gtk2 + libindicator-gtk2 + libdbusmenu-gtk2 + libappindicator-gtk2 ]; postPatch = '' diff --git a/pkgs/development/libraries/indicator-application/gtk3.nix b/pkgs/development/libraries/indicator-application/gtk3.nix index 8947e33e9001af..d61baaacb77b08 100644 --- a/pkgs/development/libraries/indicator-application/gtk3.nix +++ b/pkgs/development/libraries/indicator-application/gtk3.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, fetchbzr -, pkg-config, systemd, autoreconfHook -, glib, dbus-glib, json-glib -, gtk3, libindicator-gtk3, libdbusmenu-gtk3, libappindicator-gtk3 }: +{ + lib, + stdenv, + fetchbzr, + pkg-config, + systemd, + autoreconfHook, + glib, + dbus-glib, + json-glib, + gtk3, + libindicator-gtk3, + libdbusmenu-gtk3, + libappindicator-gtk3, +}: stdenv.mkDerivation rec { pname = "indicator-application"; @@ -15,11 +26,20 @@ stdenv.mkDerivation rec { sha256 = "1f0jdyqqb5g86zdpbcyn16x94yjigsfiv2kf73dvni5rp1vafbq1"; }; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; buildInputs = [ - glib dbus-glib json-glib systemd - gtk3 libindicator-gtk3 libdbusmenu-gtk3 libappindicator-gtk3 + glib + dbus-glib + json-glib + systemd + gtk3 + libindicator-gtk3 + libdbusmenu-gtk3 + libappindicator-gtk3 ]; postPatch = '' diff --git a/pkgs/development/libraries/ipu6-camera-hal/default.nix b/pkgs/development/libraries/ipu6-camera-hal/default.nix index 0bbed96ca3af7a..71d0e2f5408d0e 100644 --- a/pkgs/development/libraries/ipu6-camera-hal/default.nix +++ b/pkgs/development/libraries/ipu6-camera-hal/default.nix @@ -1,30 +1,33 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, -# build -, cmake -, pkg-config + # build + cmake, + pkg-config, -# runtime -, expat -, ipu6-camera-bins -, libtool -, gst_all_1 -, libdrm + # runtime + expat, + ipu6-camera-bins, + libtool, + gst_all_1, + libdrm, -# Pick one of -# - ipu6 (Tiger Lake) -# - ipu6ep (Alder Lake) -# - ipu6epmtl (Meteor Lake) -, ipuVersion ? "ipu6" + # Pick one of + # - ipu6 (Tiger Lake) + # - ipu6ep (Alder Lake) + # - ipu6epmtl (Meteor Lake) + ipuVersion ? "ipu6", }: let - ipuTarget = { - "ipu6" = "ipu_tgl"; - "ipu6ep" = "ipu_adl"; - "ipu6epmtl" = "ipu_mtl"; - }.${ipuVersion}; + ipuTarget = + { + "ipu6" = "ipu_tgl"; + "ipu6ep" = "ipu_adl"; + "ipu6epmtl" = "ipu_mtl"; + } + .${ipuVersion}; in stdenv.mkDerivation { pname = "${ipuVersion}-camera-hal"; @@ -42,7 +45,6 @@ stdenv.mkDerivation { pkg-config ]; - cmakeFlags = [ "-DIPU_VER=${ipuVersion}" "-DTARGET_SUFFIX=-${ipuVersion}" diff --git a/pkgs/development/libraries/irrlicht/default.nix b/pkgs/development/libraries/irrlicht/default.nix index 6711622a2eb8b5..20250668eba610 100644 --- a/pkgs/development/libraries/irrlicht/default.nix +++ b/pkgs/development/libraries/irrlicht/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchzip, libGLU, libGL, libXrandr, libX11, libXxf86vm, zlib }: +{ + lib, + stdenv, + fetchzip, + libGLU, + libGL, + libXrandr, + libX11, + libXxf86vm, + zlib, +}: let common = import ./common.nix { inherit fetchzip; }; @@ -10,12 +20,14 @@ stdenv.mkDerivation rec { src = common.src; - postPatch = '' - sed -ie '/sys\/sysctl.h/d' source/Irrlicht/COSOperator.cpp - '' + lib.optionalString stdenv.hostPlatform.isAarch64 '' - substituteInPlace source/Irrlicht/Makefile \ - --replace "-DIRRLICHT_EXPORTS=1" "-DIRRLICHT_EXPORTS=1 -DPNG_ARM_NEON_OPT=0" - ''; + postPatch = + '' + sed -ie '/sys\/sysctl.h/d' source/Irrlicht/COSOperator.cpp + '' + + lib.optionalString stdenv.hostPlatform.isAarch64 '' + substituteInPlace source/Irrlicht/Makefile \ + --replace "-DIRRLICHT_EXPORTS=1" "-DIRRLICHT_EXPORTS=1 -DPNG_ARM_NEON_OPT=0" + ''; preConfigure = '' cd source/Irrlicht @@ -33,7 +45,11 @@ stdenv.mkDerivation rec { ''; buildInputs = [ - libGLU libGL libXrandr libX11 libXxf86vm + libGLU + libGL + libXrandr + libX11 + libXxf86vm ] ++ lib.optional stdenv.hostPlatform.isAarch64 zlib; meta = { diff --git a/pkgs/development/libraries/irrlicht/mac.nix b/pkgs/development/libraries/irrlicht/mac.nix index 06a5dfa5e9aad0..62ff5042a772c2 100644 --- a/pkgs/development/libraries/irrlicht/mac.nix +++ b/pkgs/development/libraries/irrlicht/mac.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchzip, fetchFromGitHub, cmake, Cocoa, OpenGL, IOKit }: +{ + lib, + stdenv, + fetchzip, + fetchFromGitHub, + cmake, + Cocoa, + OpenGL, + IOKit, +}: let common = import ./common.nix { inherit fetchzip; }; @@ -32,7 +41,11 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ OpenGL Cocoa IOKit ]; + buildInputs = [ + OpenGL + Cocoa + IOKit + ]; meta = { homepage = "https://irrlicht.sourceforge.net/"; diff --git a/pkgs/development/libraries/isa-l/default.nix b/pkgs/development/libraries/isa-l/default.nix index 6a53990b78235e..ea4a682f05f648 100644 --- a/pkgs/development/libraries/isa-l/default.nix +++ b/pkgs/development/libraries/isa-l/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, runCommand, autoreconfHook, nix, nasm }: +{ + lib, + stdenv, + fetchFromGitHub, + runCommand, + autoreconfHook, + nix, + nasm, +}: stdenv.mkDerivation (finalAttrs: { pname = "isa-l"; @@ -11,7 +19,10 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-eM1K3uObb4eZq0nSfafltp5DuZIDwknUYj9CdLn14lY="; }; - nativeBuildInputs = [ nasm autoreconfHook ]; + nativeBuildInputs = [ + nasm + autoreconfHook + ]; preConfigure = '' export AS=nasm @@ -19,37 +30,43 @@ stdenv.mkDerivation (finalAttrs: { passthru = { tests = { - igzip = runCommand "test-isa-l-igzip" { - nativeBuildInputs = [ - finalAttrs.finalPackage - ]; - sample = runCommand "nixpkgs-lib.nar" { - nativeBuildInputs = [ nix ]; - } '' - nix nar --extra-experimental-features nix-command pack ${../../../../lib} > "$out" - ''; - meta = { - description = "Cross validation of igzip provided by isa-l with gzip"; - }; - } '' - HASH_ORIGINAL="$(cat "$sample" | sha256sum | cut -d" " -f1)" - HASH_COMPRESSION_TEST="$(igzip -c "$sample" | gzip -d -c | sha256sum | cut -d" " -f1)" - HASH_DECOMPRESSION_TEST="$(gzip -c "$sample" | igzip -d -c | sha256sum | cut -d" " -f1)" - if [[ "$HASH_COMPRESSION_TEST" != "$HASH_ORIGINAL" ]] || [[ "$HASH_DECOMPRESSION_TEST" != "$HASH_ORIGINAL" ]]; then - if [[ "HASH_COMPRESSION_TEST" != "$HASH_ORIGINAL" ]]; then - echo "The igzip-compressed file does not decompress to the original file." 1>&2 - fi - if [[ "HASH_DECOMPRESSION_TEST" != "$HASH_ORIGINAL" ]]; then - echo "igzip does not decompress the gzip-compressed archive to the original file." 1>&2 - fi - echo "SHA256 checksums:" 1>&2 - printf ' original file:\t%s\n' "$HASH_ORIGINAL" 1>&2 - printf ' compression test:\t%s\n' "$HASH_COMPRESSION_TEST" 1>&2 - printf ' decompression test:\t%s\n' "$HASH_DECOMPRESSION_TEST" 1>&2 - exit 1 - fi - touch "$out" - ''; + igzip = + runCommand "test-isa-l-igzip" + { + nativeBuildInputs = [ + finalAttrs.finalPackage + ]; + sample = + runCommand "nixpkgs-lib.nar" + { + nativeBuildInputs = [ nix ]; + } + '' + nix nar --extra-experimental-features nix-command pack ${../../../../lib} > "$out" + ''; + meta = { + description = "Cross validation of igzip provided by isa-l with gzip"; + }; + } + '' + HASH_ORIGINAL="$(cat "$sample" | sha256sum | cut -d" " -f1)" + HASH_COMPRESSION_TEST="$(igzip -c "$sample" | gzip -d -c | sha256sum | cut -d" " -f1)" + HASH_DECOMPRESSION_TEST="$(gzip -c "$sample" | igzip -d -c | sha256sum | cut -d" " -f1)" + if [[ "$HASH_COMPRESSION_TEST" != "$HASH_ORIGINAL" ]] || [[ "$HASH_DECOMPRESSION_TEST" != "$HASH_ORIGINAL" ]]; then + if [[ "HASH_COMPRESSION_TEST" != "$HASH_ORIGINAL" ]]; then + echo "The igzip-compressed file does not decompress to the original file." 1>&2 + fi + if [[ "HASH_DECOMPRESSION_TEST" != "$HASH_ORIGINAL" ]]; then + echo "igzip does not decompress the gzip-compressed archive to the original file." 1>&2 + fi + echo "SHA256 checksums:" 1>&2 + printf ' original file:\t%s\n' "$HASH_ORIGINAL" 1>&2 + printf ' compression test:\t%s\n' "$HASH_COMPRESSION_TEST" 1>&2 + printf ' decompression test:\t%s\n' "$HASH_DECOMPRESSION_TEST" 1>&2 + exit 1 + fi + touch "$out" + ''; }; }; diff --git a/pkgs/development/libraries/jabcode/default.nix b/pkgs/development/libraries/jabcode/default.nix index d735937b934d12..ddfec0814ca076 100644 --- a/pkgs/development/libraries/jabcode/default.nix +++ b/pkgs/development/libraries/jabcode/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, fetchFromGitHub -, lib -, subproject ? "library" # one of "library", "reader" or "writer" -, zlib -, libpng -, libtiff -, jabcode +{ + stdenv, + fetchFromGitHub, + lib, + subproject ? "library", # one of "library", "reader" or "writer" + zlib, + libpng, + libtiff, + jabcode, }: let subdir = lib.getAttr subproject { @@ -24,20 +25,25 @@ stdenv.mkDerivation rec { hash = "sha256-GjRkDWefQFdT4i9hRcQhYsY4beMUIXxy38I5lsQytyA="; }; - nativeBuildInputs = - [ zlib libpng libtiff ] - ++ lib.optionals (subproject != "library") [ jabcode ]; + nativeBuildInputs = [ + zlib + libpng + libtiff + ] ++ lib.optionals (subproject != "library") [ jabcode ]; preConfigure = "cd src/${subdir}"; installPhase = - if subproject == "library" then '' - mkdir -p $out/lib - cp build/* $out/lib - '' else '' - mkdir -p $out/bin - cp -RT bin $out/bin - ''; + if subproject == "library" then + '' + mkdir -p $out/lib + cp build/* $out/lib + '' + else + '' + mkdir -p $out/bin + cp -RT bin $out/bin + ''; meta = with lib; { description = "High-capacity 2D color bar code (${subproject})"; diff --git a/pkgs/development/libraries/java/cup/default.nix b/pkgs/development/libraries/java/cup/default.nix index 65df9d6cfa22d0..219bbd5908c572 100644 --- a/pkgs/development/libraries/java/cup/default.nix +++ b/pkgs/development/libraries/java/cup/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, ant -, jdk -, makeWrapper -, stripJavaArchivesHook +{ + lib, + stdenv, + fetchurl, + ant, + jdk, + makeWrapper, + stripJavaArchivesHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/libraries/java/libmatthew-java/default.nix b/pkgs/development/libraries/java/libmatthew-java/default.nix index 6f736403e05653..60bc1231f5ff04 100644 --- a/pkgs/development/libraries/java/libmatthew-java/default.nix +++ b/pkgs/development/libraries/java/libmatthew-java/default.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, jdk}: +{ + lib, + stdenv, + fetchurl, + jdk, +}: stdenv.mkDerivation rec { pname = "libmatthew-java"; @@ -8,8 +13,8 @@ stdenv.mkDerivation rec { url = "https://src.fedoraproject.org/repo/pkgs/libmatthew-java/libmatthew-java-${version}.tar.gz/8455b8751083ce25c99c2840609271f5/libmatthew-java-${version}.tar.gz"; sha256 = "1yldkhsdzm0a41a0i881bin2jklhp85y3ah245jd6fz3npcx7l85"; }; - JAVA_HOME=jdk; - PREFIX="\${out}"; + JAVA_HOME = jdk; + PREFIX = "\${out}"; buildInputs = [ jdk ]; meta = with lib; { diff --git a/pkgs/development/libraries/java/rhino/default.nix b/pkgs/development/libraries/java/rhino/default.nix index 7d51386c589cec..e31665b2ef7ad8 100644 --- a/pkgs/development/libraries/java/rhino/default.nix +++ b/pkgs/development/libraries/java/rhino/default.nix @@ -1,7 +1,15 @@ -{ fetchurl, lib, stdenv, unzip, ant, javac, jvm }: +{ + fetchurl, + lib, + stdenv, + unzip, + ant, + javac, + jvm, +}: let - xbeans = fetchurl { + xbeans = fetchurl { url = "http://archive.apache.org/dist/xmlbeans/binaries/xmlbeans-2.2.0.zip"; sha256 = "1pb08d9j81d0wz5wj31idz198iwhqb7mch872n08jh1354rjlqwk"; }; @@ -17,29 +25,34 @@ stdenv.mkDerivation rec { patches = [ ./gcj-type-mismatch.patch ]; - hardeningDisable = [ "fortify" "format" ]; + hardeningDisable = [ + "fortify" + "format" + ]; - preConfigure = - '' - find -name \*.jar -or -name \*.class -exec rm -v {} \; + preConfigure = '' + find -name \*.jar -or -name \*.class -exec rm -v {} \; - # The build process tries to download it by itself. - mkdir -p "build/tmp-xbean" - ln -sv "${xbeans}" "build/tmp-xbean/xbean.zip" - ''; + # The build process tries to download it by itself. + mkdir -p "build/tmp-xbean" + ln -sv "${xbeans}" "build/tmp-xbean/xbean.zip" + ''; nativeBuildInputs = [ unzip ]; - buildInputs = [ ant javac jvm ]; + buildInputs = [ + ant + javac + jvm + ]; buildPhase = "ant jar"; - doCheck = false; + doCheck = false; # FIXME: Install javadoc as well. - installPhase = - '' - mkdir -p "$out/share/java" - cp -v *.jar "$out/share/java" - ''; + installPhase = '' + mkdir -p "$out/share/java" + cp -v *.jar "$out/share/java" + ''; meta = with lib; { description = "Implementation of JavaScript written in Java"; @@ -52,7 +65,10 @@ stdenv.mkDerivation rec { homepage = "http://www.mozilla.org/rhino/"; - license = with licenses; [ mpl11 /* or */ gpl2Plus ]; + license = with licenses; [ + mpl11 # or + gpl2Plus + ]; platforms = platforms.linux ++ platforms.darwin; }; } diff --git a/pkgs/development/libraries/java/saxon/default.nix b/pkgs/development/libraries/java/saxon/default.nix index cb6df7e5558b84..15f6d104a2209d 100644 --- a/pkgs/development/libraries/java/saxon/default.nix +++ b/pkgs/development/libraries/java/saxon/default.nix @@ -1,58 +1,74 @@ -{ lib -, stdenv -, fetchurl -, unzip -, jre -, jre8 -, genericUpdater -, writeShellScript -, common-updater-scripts -, gnused +{ + lib, + stdenv, + fetchurl, + unzip, + jre, + jre8, + genericUpdater, + writeShellScript, + common-updater-scripts, + gnused, }: let inherit (lib.versions) major majorMinor splitVersion; inherit (lib.strings) concatStringsSep versionAtLeast; - common = { pname, version, src, description, java ? jre - , prog ? null, jar ? null, license ? lib.licenses.mpl20 - , updateScript ? null }: - stdenv.mkDerivation (finalAttrs: let - mainProgram = if prog == null then pname else prog; - jar' = if jar == null then pname else jar; - in { - inherit pname version src; + common = + { + pname, + version, + src, + description, + java ? jre, + prog ? null, + jar ? null, + license ? lib.licenses.mpl20, + updateScript ? null, + }: + stdenv.mkDerivation ( + finalAttrs: + let + mainProgram = if prog == null then pname else prog; + jar' = if jar == null then pname else jar; + in + { + inherit pname version src; - nativeBuildInputs = [ unzip ]; + nativeBuildInputs = [ unzip ]; - buildCommand = '' - unzip $src -d $out - mkdir -p $out/bin $out/share $out/share/java - cp -s "$out"/*.jar "$out/share/java/" # */ - rm -rf $out/notices - mv $out/doc $out/share - cat > $out/bin/${mainProgram} < $out/bin/${mainProgram} < withOpenLDAP) '' @@ -57,7 +58,12 @@ stdenv.mkDerivation { hash = "sha256-WA3lo3eD05l7zKuKEVxudMmiG7OvjK/calaUzPQ2pWs="; }; - outputs = [ "out" "dev" "man" "info" ]; + outputs = [ + "out" + "dev" + "man" + "info" + ]; nativeBuildInputs = [ autoreconfHook @@ -70,8 +76,17 @@ stdenv.mkDerivation { texinfo ]; - buildInputs = [ db libedit pam ] - ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ CoreFoundation Security SystemConfiguration ] + buildInputs = + [ + db + libedit + pam + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ + CoreFoundation + Security + SystemConfiguration + ] ++ lib.optionals (withCJSON) [ cjson ] ++ lib.optionals (withCapNG) [ libcap_ng ] ++ lib.optionals (withMicroHTTPD) [ libmicrohttpd ] @@ -87,27 +102,33 @@ stdenv.mkDerivation { which ]; - configureFlags = [ - "--with-hdbdir=/var/lib/heimdal" - - "--with-libedit-include=${libedit.dev}/include" - "--with-libedit-lib=${libedit}/lib" - "--with-berkeley-db-include=${db.dev}/include" - "--with-berkeley-db" - - "--without-x" - "--disable-afs-string-to-key" - ] ++ lib.optionals (withCapNG) [ - "--with-capng" - ] ++ lib.optionals (withCJSON) [ - "--with-cjson=${cjson}" - ] ++ lib.optionals (withOpenLDAP) [ - "--with-openldap=${openldap.dev}" - ] ++ lib.optionals (withOpenLDAPAsHDBModule) [ - "--enable-hdb-openldap-module" - ] ++ lib.optionals (withSQLite3) [ - "--with-sqlite3=${sqlite.dev}" - ]; + configureFlags = + [ + "--with-hdbdir=/var/lib/heimdal" + + "--with-libedit-include=${libedit.dev}/include" + "--with-libedit-lib=${libedit}/lib" + "--with-berkeley-db-include=${db.dev}/include" + "--with-berkeley-db" + + "--without-x" + "--disable-afs-string-to-key" + ] + ++ lib.optionals (withCapNG) [ + "--with-capng" + ] + ++ lib.optionals (withCJSON) [ + "--with-cjson=${cjson}" + ] + ++ lib.optionals (withOpenLDAP) [ + "--with-openldap=${openldap.dev}" + ] + ++ lib.optionals (withOpenLDAPAsHDBModule) [ + "--enable-hdb-openldap-module" + ] + ++ lib.optionals (withSQLite3) [ + "--with-sqlite3=${sqlite.dev}" + ]; patches = [ # Proposed @ https://github.com/heimdal/heimdal/pull/1262 diff --git a/pkgs/development/libraries/kerberos/krb5.nix b/pkgs/development/libraries/kerberos/krb5.nix index cf429432c447e1..7a4df60f0ae5b1 100644 --- a/pkgs/development/libraries/kerberos/krb5.nix +++ b/pkgs/development/libraries/kerberos/krb5.nix @@ -1,30 +1,34 @@ -{ lib -, stdenv -, fetchurl -, bootstrap_cmds -, byacc # can also use bison, but byacc has fewer dependencies -, darwin -, keyutils -, openssl -, perl -, pkg-config - -# for passthru.tests -, bind -, curl -, nixosTests -, openssh -, postgresql -, python3 - -# Extra Arguments -, withLdap ? false, openldap -, withLibedit ? true, libedit -, withVerto ? false, libverto - -# This is called "staticOnly" because krb5 does not support -# builting both static and shared, see below. -, staticOnly ? false +{ + lib, + stdenv, + fetchurl, + bootstrap_cmds, + byacc, # can also use bison, but byacc has fewer dependencies + darwin, + keyutils, + openssl, + perl, + pkg-config, + + # for passthru.tests + bind, + curl, + nixosTests, + openssh, + postgresql, + python3, + + # Extra Arguments + withLdap ? false, + openldap, + withLibedit ? true, + libedit, + withVerto ? false, + libverto, + + # This is called "staticOnly" because krb5 does not support + # builting both static and shared, see below. + staticOnly ? false, }: stdenv.mkDerivation rec { @@ -36,7 +40,11 @@ stdenv.mkDerivation rec { hash = "sha256-t6TNXq1n+wi5gLIavRUP9yF+heoyDJ7QxtrdMEhArTU="; }; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; # While "out" acts as the bin output, most packages only care about the lib output. # We set prefix such that all the pkg-config configuration stays inside the dev and lib outputs. @@ -47,7 +55,8 @@ stdenv.mkDerivation rec { NIX_CFLAGS_COMPILE = "-fcommon"; }; - configureFlags = [ + configureFlags = + [ "--localstatedir=/var/lib" (lib.withFeature withLdap "ldap") (lib.withFeature withLibedit "libedit") @@ -55,42 +64,64 @@ stdenv.mkDerivation rec { ] # krb5's ./configure does not allow passing --enable-shared and --enable-static at the same time. # See https://bbs.archlinux.org/viewtopic.php?pid=1576737#p1576737 - ++ lib.optionals staticOnly [ "--enable-static" "--disable-shared" ] + ++ lib.optionals staticOnly [ + "--enable-static" + "--disable-shared" + ] ++ lib.optional stdenv.hostPlatform.isFreeBSD ''WARN_CFLAGS='' - ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) - [ "krb5_cv_attr_constructor_destructor=yes,yes" - "ac_cv_func_regcomp=yes" - "ac_cv_printf_positional=yes" - ]; - - nativeBuildInputs = [ byacc perl pkg-config ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "krb5_cv_attr_constructor_destructor=yes,yes" + "ac_cv_func_regcomp=yes" + "ac_cv_printf_positional=yes" + ]; + + nativeBuildInputs = + [ + byacc + perl + pkg-config + ] # Provides the mig command used by the build scripts ++ lib.optional stdenv.hostPlatform.isDarwin bootstrap_cmds; - buildInputs = [ openssl ] - ++ lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.libc != "bionic" && !(stdenv.hostPlatform.useLLVM or false)) [ keyutils ] + buildInputs = + [ openssl ] + ++ lib.optionals ( + stdenv.hostPlatform.isLinux + && stdenv.hostPlatform.libc != "bionic" + && !(stdenv.hostPlatform.useLLVM or false) + ) [ keyutils ] ++ lib.optionals withLdap [ openldap ] ++ lib.optionals withLibedit [ libedit ] ++ lib.optionals withVerto [ libverto ]; - propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk; [ - libs.xpc - frameworks.Kerberos - ]); + propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk; + [ + libs.xpc + frameworks.Kerberos + ] + ); sourceRoot = "krb5-${version}/src"; - postPatch = '' - substituteInPlace config/shlib.conf \ - --replace "'ld " "'${stdenv.cc.targetPrefix}ld " - '' - # this could be accomplished by updateAutotoolsGnuConfigScriptsHook, but that causes infinite recursion - # necessary for FreeBSD code path in configure - + '' - substituteInPlace ./config/config.guess --replace-fail /usr/bin/uname uname - ''; - - libFolders = [ "util" "include" "lib" "build-tools" ]; + postPatch = + '' + substituteInPlace config/shlib.conf \ + --replace "'ld " "'${stdenv.cc.targetPrefix}ld " + '' + # this could be accomplished by updateAutotoolsGnuConfigScriptsHook, but that causes infinite recursion + # necessary for FreeBSD code path in configure + + '' + substituteInPlace ./config/config.guess --replace-fail /usr/bin/uname uname + ''; + + libFolders = [ + "util" + "include" + "lib" + "build-tools" + ]; # To avoid cyclic outputs, we can't let lib depend on out in any way. Unfortunately, the configure # options don't give us enough granularity to specify that, so we have to override the generated diff --git a/pkgs/development/libraries/keybinder/default.nix b/pkgs/development/libraries/keybinder/default.nix index 38b1dafa006630..258326091b97e2 100644 --- a/pkgs/development/libraries/keybinder/default.nix +++ b/pkgs/development/libraries/keybinder/default.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libtool, pkg-config, gnome-common -, gtk-doc, gtk2, lua, gobject-introspection +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + pkg-config, + gnome-common, + gtk-doc, + gtk2, + lua, + gobject-introspection, }: stdenv.mkDerivation rec { @@ -13,10 +24,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-elL6DZtzCwAtoyGZYP0jAma6tHPks2KAtrziWtBENGU="; }; - nativeBuildInputs = [ pkg-config autoconf automake gobject-introspection ]; + nativeBuildInputs = [ + pkg-config + autoconf + automake + gobject-introspection + ]; buildInputs = [ - libtool gnome-common gtk-doc gtk2 + libtool + gnome-common + gtk-doc + gtk2 lua ]; diff --git a/pkgs/development/libraries/keybinder3/default.nix b/pkgs/development/libraries/keybinder3/default.nix index 3ee266ee3a18a8..6b95c5b46b2438 100644 --- a/pkgs/development/libraries/keybinder3/default.nix +++ b/pkgs/development/libraries/keybinder3/default.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libtool, pkg-config, gnome-common -, gtk-doc, gtk3, libX11, libXext, libXrender, gobject-introspection +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + pkg-config, + gnome-common, + gtk-doc, + gtk3, + libX11, + libXext, + libXrender, + gobject-introspection, }: stdenv.mkDerivation rec { @@ -24,7 +37,10 @@ stdenv.mkDerivation rec { gobject-introspection ]; buildInputs = [ - gtk3 libX11 libXext libXrender + gtk3 + libX11 + libXext + libXrender ]; preConfigure = '' diff --git a/pkgs/development/libraries/kf5gpgmepp/default.nix b/pkgs/development/libraries/kf5gpgmepp/default.nix index 5fa51987eaa7a5..5a4a7d70e02298 100644 --- a/pkgs/development/libraries/kf5gpgmepp/default.nix +++ b/pkgs/development/libraries/kf5gpgmepp/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchgit, cmake, extra-cmake-modules, qtbase, boost, gpgme }: +{ + mkDerivation, + lib, + fetchgit, + cmake, + extra-cmake-modules, + qtbase, + boost, + gpgme, +}: mkDerivation { pname = "kf5gpgmepp"; @@ -10,7 +19,11 @@ mkDerivation { sha256 = "02ck2l3s8s7xh44blqaqnc5k49ccicdnzvhiwa67a3zgicz5i0vh"; }; - buildInputs = [ extra-cmake-modules qtbase boost ]; + buildInputs = [ + extra-cmake-modules + qtbase + boost + ]; propagatedBuildInputs = [ gpgme ]; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/development/libraries/kimageannotator/default.nix b/pkgs/development/libraries/kimageannotator/default.nix index e179cb0f6c52a0..ea46ff3f11552c 100644 --- a/pkgs/development/libraries/kimageannotator/default.nix +++ b/pkgs/development/libraries/kimageannotator/default.nix @@ -1,8 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, cmake, qttools, qtbase, qtsvg, kcolorpicker }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qttools, + qtbase, + qtsvg, + kcolorpicker, +}: let isQt6 = lib.versions.major qtbase.version == "6"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "kimageannotator"; version = "0.7.1"; @@ -13,8 +23,14 @@ in stdenv.mkDerivation rec { hash = "sha256-LFou8gTF/XDBLNQbA4uurYJHQl7yOTKe2OGklUsmPrg="; }; - nativeBuildInputs = [ cmake qttools ]; - buildInputs = [ qtbase qtsvg ]; + nativeBuildInputs = [ + cmake + qttools + ]; + buildInputs = [ + qtbase + qtsvg + ]; propagatedBuildInputs = [ kcolorpicker ]; cmakeFlags = [ diff --git a/pkgs/development/libraries/kirigami-addons/default.nix b/pkgs/development/libraries/kirigami-addons/default.nix index 403267a4eb56e3..ed67dcb791629e 100644 --- a/pkgs/development/libraries/kirigami-addons/default.nix +++ b/pkgs/development/libraries/kirigami-addons/default.nix @@ -1,13 +1,14 @@ -{ lib -, mkDerivation -, fetchFromGitLab +{ + lib, + mkDerivation, + fetchFromGitLab, -, cmake -, extra-cmake-modules + cmake, + extra-cmake-modules, -, ki18n -, kirigami2 -, qtquickcontrols2 + ki18n, + kirigami2, + qtquickcontrols2, }: mkDerivation rec { @@ -41,4 +42,3 @@ mkDerivation rec { maintainers = with maintainers; [ matthiasbeyer ]; }; } - diff --git a/pkgs/development/libraries/kompute/default.nix b/pkgs/development/libraries/kompute/default.nix index ced30a87dbfa79..3639166560416a 100644 --- a/pkgs/development/libraries/kompute/default.nix +++ b/pkgs/development/libraries/kompute/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, vulkan-headers -, vulkan-loader -, fmt -, glslang -, ninja +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + vulkan-headers, + vulkan-loader, + fmt, + glslang, + ninja, }: stdenv.mkDerivation rec { @@ -39,9 +40,16 @@ stdenv.mkDerivation rec { "-DKOMPUTE_ENABLE_SPDLOG=1" ]; - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; buildInputs = [ fmt ]; - propagatedBuildInputs = [ glslang vulkan-headers vulkan-loader ]; + propagatedBuildInputs = [ + glslang + vulkan-headers + vulkan-loader + ]; meta = with lib; { description = "General purpose GPU compute framework built on Vulkan"; diff --git a/pkgs/development/libraries/kpeoplevcard/default.nix b/pkgs/development/libraries/kpeoplevcard/default.nix index 689b7c9869b69e..834556e3e1ca2c 100644 --- a/pkgs/development/libraries/kpeoplevcard/default.nix +++ b/pkgs/development/libraries/kpeoplevcard/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchurl -, cmake -, pkg-config -, wrapQtAppsHook -, extra-cmake-modules -, kcoreaddons -, kpeople -, kcontacts +{ + stdenv, + lib, + fetchurl, + cmake, + pkg-config, + wrapQtAppsHook, + extra-cmake-modules, + kcoreaddons, + kpeople, + kcontacts, }: stdenv.mkDerivation (finalAttrs: { @@ -34,9 +35,8 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Pulseaudio bindings for Qt"; - homepage = "https://github.com/KDE/kpeoplevcard"; - license = with licenses; [ lgpl2 ]; + homepage = "https://github.com/KDE/kpeoplevcard"; + license = with licenses; [ lgpl2 ]; maintainers = with maintainers; [ doronbehar ]; }; }) - diff --git a/pkgs/development/libraries/kproperty/default.nix b/pkgs/development/libraries/kproperty/default.nix index 6187d201f25986..b1a9aaa2c6e4b0 100644 --- a/pkgs/development/libraries/kproperty/default.nix +++ b/pkgs/development/libraries/kproperty/default.nix @@ -1,8 +1,14 @@ { - mkDerivation, lib, fetchurl, + mkDerivation, + lib, + fetchurl, extra-cmake-modules, - qtbase, kconfig, kcoreaddons, kwidgetsaddons, kguiaddons, - qttools + qtbase, + kconfig, + kcoreaddons, + kwidgetsaddons, + kguiaddons, + qttools, }: mkDerivation rec { @@ -16,7 +22,13 @@ mkDerivation rec { nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ kconfig kcoreaddons kwidgetsaddons kguiaddons qttools ]; + buildInputs = [ + kconfig + kcoreaddons + kwidgetsaddons + kguiaddons + qttools + ]; propagatedBuildInputs = [ qtbase ]; diff --git a/pkgs/development/libraries/kquickimageedit/default.nix b/pkgs/development/libraries/kquickimageedit/default.nix index cd43904a123e9b..358105ed2c1b21 100644 --- a/pkgs/development/libraries/kquickimageedit/default.nix +++ b/pkgs/development/libraries/kquickimageedit/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitLab -, extra-cmake-modules -, qtbase -, qtdeclarative +{ + lib, + stdenv, + fetchFromGitLab, + extra-cmake-modules, + qtbase, + qtdeclarative, }: stdenv.mkDerivation rec { @@ -19,8 +20,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ qtbase qtdeclarative ]; - cmakeFlags = ["-DQT_MAJOR_VERSION=${lib.versions.major qtbase.version}"]; + buildInputs = [ + qtbase + qtdeclarative + ]; + cmakeFlags = [ "-DQT_MAJOR_VERSION=${lib.versions.major qtbase.version}" ]; dontWrapQtApps = true; meta = with lib; { diff --git a/pkgs/development/libraries/kreport/default.nix b/pkgs/development/libraries/kreport/default.nix index 19f2b89a56e043..ec2d52647523a4 100644 --- a/pkgs/development/libraries/kreport/default.nix +++ b/pkgs/development/libraries/kreport/default.nix @@ -1,7 +1,17 @@ { - mkDerivation, lib, fetchurl, + mkDerivation, + lib, + fetchurl, extra-cmake-modules, - qtdeclarative, qtwebkit, kconfig, kcoreaddons, kwidgetsaddons, kguiaddons, kproperty, marble, python3 + qtdeclarative, + qtwebkit, + kconfig, + kcoreaddons, + kwidgetsaddons, + kguiaddons, + kproperty, + marble, + python3, }: mkDerivation rec { @@ -15,7 +25,17 @@ mkDerivation rec { nativeBuildInputs = [ extra-cmake-modules ]; - buildInputs = [ qtdeclarative qtwebkit kconfig kcoreaddons kwidgetsaddons kguiaddons kproperty marble python3 ]; + buildInputs = [ + qtdeclarative + qtwebkit + kconfig + kcoreaddons + kwidgetsaddons + kguiaddons + kproperty + marble + python3 + ]; meta = with lib; { description = "Framework for creation and generation of reports in multiple formats"; diff --git a/pkgs/development/libraries/ktextaddons/default.nix b/pkgs/development/libraries/ktextaddons/default.nix index 15286ff162cc94..a0ce40842593a7 100644 --- a/pkgs/development/libraries/ktextaddons/default.nix +++ b/pkgs/development/libraries/ktextaddons/default.nix @@ -1,4 +1,16 @@ -{ lib, mkDerivation, fetchurl, cmake, extra-cmake-modules, karchive, kconfigwidgets, kcoreaddons, ki18n, kxmlgui, qtkeychain }: +{ + lib, + mkDerivation, + fetchurl, + cmake, + extra-cmake-modules, + karchive, + kconfigwidgets, + kcoreaddons, + ki18n, + kxmlgui, + qtkeychain, +}: mkDerivation rec { pname = "ktextaddons"; version = "1.3.2"; @@ -8,8 +20,18 @@ mkDerivation rec { hash = "sha256-mB7Hh2Ljrg8D2GxDyHCa1s6CVmg5DDkhwafEqtSqUeM="; }; - nativeBuildInputs = [ cmake extra-cmake-modules ]; - buildInputs = [ karchive kconfigwidgets kcoreaddons ki18n kxmlgui qtkeychain ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; + buildInputs = [ + karchive + kconfigwidgets + kcoreaddons + ki18n + kxmlgui + qtkeychain + ]; meta = with lib; { description = "Various text handling addons for KDE applications"; diff --git a/pkgs/development/libraries/kuserfeedback/default.nix b/pkgs/development/libraries/kuserfeedback/default.nix index 5e1fe28297fdd8..f0114c8e274a67 100644 --- a/pkgs/development/libraries/kuserfeedback/default.nix +++ b/pkgs/development/libraries/kuserfeedback/default.nix @@ -1,8 +1,9 @@ -{ lib -, mkDerivation -, fetchurl -, extra-cmake-modules -, qttools +{ + lib, + mkDerivation, + fetchurl, + extra-cmake-modules, + qttools, }: mkDerivation rec { pname = "kuserfeedback"; @@ -13,7 +14,10 @@ mkDerivation rec { hash = "sha256-JSMIuCLdRpDqhasWiMmw2lUSl4rGtDX3ell5/B0v/RM="; }; - nativeBuildInputs = [ extra-cmake-modules qttools ]; + nativeBuildInputs = [ + extra-cmake-modules + qttools + ]; meta = with lib; { license = [ licenses.mit ]; diff --git a/pkgs/development/libraries/kweathercore/default.nix b/pkgs/development/libraries/kweathercore/default.nix index 6c957b6fc9e5dd..69fd778b59a552 100644 --- a/pkgs/development/libraries/kweathercore/default.nix +++ b/pkgs/development/libraries/kweathercore/default.nix @@ -1,10 +1,11 @@ -{ mkDerivation -, lib -, fetchFromGitLab -, extra-cmake-modules -, kholidays -, ki18n -, qtlocation +{ + mkDerivation, + lib, + fetchFromGitLab, + extra-cmake-modules, + kholidays, + ki18n, + qtlocation, }: mkDerivation rec { diff --git a/pkgs/development/libraries/l-smash/default.nix b/pkgs/development/libraries/l-smash/default.nix index 1439c1046fe2b6..1ccac4b6fa759e 100644 --- a/pkgs/development/libraries/l-smash/default.nix +++ b/pkgs/development/libraries/l-smash/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, which }: +{ + lib, + stdenv, + fetchFromGitHub, + which, +}: stdenv.mkDerivation rec { pname = "l-smash"; diff --git a/pkgs/development/libraries/languagemachines/frog.nix b/pkgs/development/libraries/languagemachines/frog.nix index fffc7d8da23a43..d9864573c3b580 100644 --- a/pkgs/development/libraries/languagemachines/frog.nix +++ b/pkgs/development/libraries/languagemachines/frog.nix @@ -1,7 +1,17 @@ -{ lib, stdenv, fetchurl -, automake, autoconf, bzip2, libtar, libtool, pkg-config, autoconf-archive -, libxml2, icu -, languageMachines +{ + lib, + stdenv, + fetchurl, + automake, + autoconf, + bzip2, + libtar, + libtool, + pkg-config, + autoconf-archive, + libxml2, + icu, + languageMachines, }: let @@ -11,18 +21,29 @@ in stdenv.mkDerivation { pname = "frog"; version = release.version; - src = fetchurl { inherit (release) url sha256; - name = "frog-v${release.version}.tar.gz"; }; - nativeBuildInputs = [ pkg-config automake autoconf ]; - buildInputs = [ bzip2 libtar libtool autoconf-archive - libxml2 icu - languageMachines.ticcutils - languageMachines.timbl - languageMachines.mbt - languageMachines.libfolia - languageMachines.ucto - languageMachines.frogdata - ]; + src = fetchurl { + inherit (release) url sha256; + name = "frog-v${release.version}.tar.gz"; + }; + nativeBuildInputs = [ + pkg-config + automake + autoconf + ]; + buildInputs = [ + bzip2 + libtar + libtool + autoconf-archive + libxml2 + icu + languageMachines.ticcutils + languageMachines.timbl + languageMachines.mbt + languageMachines.libfolia + languageMachines.ucto + languageMachines.frogdata + ]; preConfigure = '' sh bootstrap.sh @@ -39,9 +60,9 @@ stdenv.mkDerivation { meta = with lib; { description = "Tagger-Lemmatizer-Morphological-Analyzer-Dependency-Parser for Dutch"; - homepage = "https://languagemachines.github.io/frog"; - license = licenses.gpl3; - platforms = platforms.all; + homepage = "https://languagemachines.github.io/frog"; + license = licenses.gpl3; + platforms = platforms.all; maintainers = with maintainers; [ roberth ]; longDescription = '' diff --git a/pkgs/development/libraries/languagemachines/frogdata.nix b/pkgs/development/libraries/languagemachines/frogdata.nix index 5b1b07e7927727..76ff3c1f4f1886 100644 --- a/pkgs/development/libraries/languagemachines/frogdata.nix +++ b/pkgs/development/libraries/languagemachines/frogdata.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchurl -, automake, autoconf, libtool, pkg-config, autoconf-archive +{ + lib, + stdenv, + fetchurl, + automake, + autoconf, + libtool, + pkg-config, + autoconf-archive, }: let @@ -9,11 +16,19 @@ in stdenv.mkDerivation { pname = "frogdata"; version = release.version; - src = fetchurl { inherit (release) url sha256; - name = "frogdata-${release.version}.tar.gz"; }; - nativeBuildInputs = [ pkg-config automake autoconf ]; - buildInputs = [ libtool autoconf-archive - ]; + src = fetchurl { + inherit (release) url sha256; + name = "frogdata-${release.version}.tar.gz"; + }; + nativeBuildInputs = [ + pkg-config + automake + autoconf + ]; + buildInputs = [ + libtool + autoconf-archive + ]; preConfigure = '' sh bootstrap.sh @@ -21,9 +36,9 @@ stdenv.mkDerivation { meta = with lib; { description = "Data for Frog, a Tagger-Lemmatizer-Morphological-Analyzer-Dependency-Parser for Dutch"; - homepage = "https://languagemachines.github.io/frog"; - license = licenses.gpl3; - platforms = platforms.all; + homepage = "https://languagemachines.github.io/frog"; + license = licenses.gpl3; + platforms = platforms.all; maintainers = with maintainers; [ roberth ]; }; diff --git a/pkgs/development/libraries/languagemachines/libfolia.nix b/pkgs/development/libraries/languagemachines/libfolia.nix index 76bdcb7b9ba546..33d71bef3bebe8 100644 --- a/pkgs/development/libraries/languagemachines/libfolia.nix +++ b/pkgs/development/libraries/languagemachines/libfolia.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, fetchurl -, automake, autoconf, libtool, pkg-config, autoconf-archive -, libxml2, icu, bzip2, libtar -, languageMachines }: +{ + lib, + stdenv, + fetchurl, + automake, + autoconf, + libtool, + pkg-config, + autoconf-archive, + libxml2, + icu, + bzip2, + libtar, + languageMachines, +}: let release = lib.importJSON ./release-info/LanguageMachines-libfolia.json; @@ -10,10 +21,24 @@ in stdenv.mkDerivation { pname = "libfolia"; version = release.version; - src = fetchurl { inherit (release) url sha256; - name = "libfolia-${release.version}.tar.gz"; }; - nativeBuildInputs = [ pkg-config automake autoconf ]; - buildInputs = [ bzip2 libtool autoconf-archive libtar libxml2 icu languageMachines.ticcutils ]; + src = fetchurl { + inherit (release) url sha256; + name = "libfolia-${release.version}.tar.gz"; + }; + nativeBuildInputs = [ + pkg-config + automake + autoconf + ]; + buildInputs = [ + bzip2 + libtool + autoconf-archive + libtar + libxml2 + icu + languageMachines.ticcutils + ]; preConfigure = "sh bootstrap.sh"; # compat with icu61+ https://github.com/unicode-org/icu/blob/release-64-2/icu4c/readme.html#L554 @@ -22,9 +47,9 @@ stdenv.mkDerivation { meta = with lib; { description = "C++ API for FoLiA documents; an XML-based linguistic annotation format"; mainProgram = "folialint"; - homepage = "https://proycon.github.io/folia/"; - license = licenses.gpl3; - platforms = platforms.all; + homepage = "https://proycon.github.io/folia/"; + license = licenses.gpl3; + platforms = platforms.all; maintainers = with maintainers; [ roberth ]; longDescription = '' diff --git a/pkgs/development/libraries/languagemachines/mbt.nix b/pkgs/development/libraries/languagemachines/mbt.nix index 9556c1d5670115..51238615f9e9cc 100644 --- a/pkgs/development/libraries/languagemachines/mbt.nix +++ b/pkgs/development/libraries/languagemachines/mbt.nix @@ -1,7 +1,16 @@ -{ lib, stdenv, fetchurl -, automake, autoconf, bzip2, libtar, libtool, pkg-config, autoconf-archive -, libxml2 -, languageMachines +{ + lib, + stdenv, + fetchurl, + automake, + autoconf, + bzip2, + libtar, + libtool, + pkg-config, + autoconf-archive, + libxml2, + languageMachines, }: let @@ -11,14 +20,24 @@ in stdenv.mkDerivation { pname = "mbt"; version = release.version; - src = fetchurl { inherit (release) url sha256; - name = "mbt-${release.version}.tar.gz"; }; - nativeBuildInputs = [ pkg-config automake autoconf ]; - buildInputs = [ bzip2 libtar libtool autoconf-archive - libxml2 - languageMachines.ticcutils - languageMachines.timbl - ]; + src = fetchurl { + inherit (release) url sha256; + name = "mbt-${release.version}.tar.gz"; + }; + nativeBuildInputs = [ + pkg-config + automake + autoconf + ]; + buildInputs = [ + bzip2 + libtar + libtool + autoconf-archive + libxml2 + languageMachines.ticcutils + languageMachines.timbl + ]; patches = [ ./mbt-add-libxml2-dep.patch ]; preConfigure = '' sh bootstrap.sh @@ -26,9 +45,9 @@ stdenv.mkDerivation { meta = with lib; { description = "Memory Based Tagger"; - homepage = "https://languagemachines.github.io/mbt/"; - license = licenses.gpl3; - platforms = platforms.all; + homepage = "https://languagemachines.github.io/mbt/"; + license = licenses.gpl3; + platforms = platforms.all; maintainers = with maintainers; [ roberth ]; longDescription = '' diff --git a/pkgs/development/libraries/languagemachines/test.nix b/pkgs/development/libraries/languagemachines/test.nix index 26fff825a151d9..57965a758311ba 100644 --- a/pkgs/development/libraries/languagemachines/test.nix +++ b/pkgs/development/libraries/languagemachines/test.nix @@ -1,8 +1,9 @@ -{ runCommand -, languageMachines +{ + runCommand, + languageMachines, }: -runCommand "frog-test" {} '' +runCommand "frog-test" { } '' ${languageMachines.frog}/bin/frog >$out <. -, gtkSupport ? true, glib, gtk3 -, videoSupport ? true, libmpeg2 +{ + lib, + stdenv, + fetchurl, + fetchpatch2, + substituteAll, + libtool, + gettext, + zlib, + bzip2, + flac, + libvorbis, + exiv2, + libgsf, + pkg-config, + rpmSupport ? stdenv.hostPlatform.isLinux, + rpm, + gstreamerSupport ? true, + gst_all_1, + # ^ Needed e.g. for proper id3 and FLAC support. + # Set to `false` to decrease package closure size by about 87 MB (53%). + gstPlugins ? ( + gst: [ + gst.gst-plugins-base + gst.gst-plugins-good + ] + ), + # If an application needs additional gstreamer plugins it can also make them + # available by adding them to the environment variable + # GST_PLUGIN_SYSTEM_PATH_1_0, e.g. like this: + # postInstall = '' + # wrapProgram $out/bin/extract --prefix GST_PLUGIN_SYSTEM_PATH_1_0 : "$GST_PLUGIN_SYSTEM_PATH_1_0" + # ''; + # See also . + gtkSupport ? true, + glib, + gtk3, + videoSupport ? true, + libmpeg2, }: stdenv.mkDerivation rec { @@ -26,23 +48,25 @@ stdenv.mkDerivation rec { hash = "sha256-u48xLFHSAlciQ/ETxrYtghAwGrMMuu5gT5g32HjN91U="; }; - patches = [ - # 0008513: test_exiv2 fails with Exiv2 0.28 - # https://bugs.gnunet.org/view.php?id=8513 - (fetchpatch2 { - url = "https://sources.debian.org/data/main/libe/libextractor/1%3A1.13-4/debian/patches/exiv2-0.28.diff"; - hash = "sha256-Re5iwlSyEpWu3PcHibaRKSfmdyHSZGMOdMZ6svTofvs="; - }) - ] ++ lib.optionals gstreamerSupport [ + patches = + [ + # 0008513: test_exiv2 fails with Exiv2 0.28 + # https://bugs.gnunet.org/view.php?id=8513 + (fetchpatch2 { + url = "https://sources.debian.org/data/main/libe/libextractor/1%3A1.13-4/debian/patches/exiv2-0.28.diff"; + hash = "sha256-Re5iwlSyEpWu3PcHibaRKSfmdyHSZGMOdMZ6svTofvs="; + }) + ] + ++ lib.optionals gstreamerSupport [ - # Libraries cannot be wrapped so we need to hardcode the plug-in paths. - (substituteAll { - src = ./gst-hardcode-plugins.patch; - load_gst_plugins = lib.concatMapStrings - (plugin: ''gst_registry_scan_path(gst_registry_get(), "${lib.getLib plugin}/lib/gstreamer-1.0");'') - (gstPlugins gst_all_1); - }) - ]; + # Libraries cannot be wrapped so we need to hardcode the plug-in paths. + (substituteAll { + src = ./gst-hardcode-plugins.patch; + load_gst_plugins = lib.concatMapStrings ( + plugin: ''gst_registry_scan_path(gst_registry_get(), "${lib.getLib plugin}/lib/gstreamer-1.0");'' + ) (gstPlugins gst_all_1); + }) + ]; preConfigure = '' echo "patching installation directory in \`extractor.c'..." @@ -53,13 +77,23 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; buildInputs = - [ libtool gettext zlib bzip2 flac libvorbis exiv2 - libgsf - ] ++ lib.optionals rpmSupport [ rpm ] - ++ lib.optionals gstreamerSupport - ([ gst_all_1.gstreamer ] ++ gstPlugins gst_all_1) - ++ lib.optionals gtkSupport [ glib gtk3 ] - ++ lib.optionals videoSupport [ libmpeg2 ]; + [ + libtool + gettext + zlib + bzip2 + flac + libvorbis + exiv2 + libgsf + ] + ++ lib.optionals rpmSupport [ rpm ] + ++ lib.optionals gstreamerSupport ([ gst_all_1.gstreamer ] ++ gstPlugins gst_all_1) + ++ lib.optionals gtkSupport [ + glib + gtk3 + ] + ++ lib.optionals videoSupport [ libmpeg2 ]; # Checks need to be run after "make install", otherwise plug-ins are not in # the search path, etc. diff --git a/pkgs/development/libraries/libffi/3.3.nix b/pkgs/development/libraries/libffi/3.3.nix index d8dd3fa47d5c8e..f4e9d81dd6fcd5 100644 --- a/pkgs/development/libraries/libffi/3.3.nix +++ b/pkgs/development/libraries/libffi/3.3.nix @@ -1,7 +1,10 @@ -{ lib, stdenv, fetchurl +{ + lib, + stdenv, + fetchurl, -, doCheck ? true # test suite depends on dejagnu which cannot be used during bootstrapping -, dejagnu + doCheck ? true, # test suite depends on dejagnu which cannot be used during bootstrapping + dejagnu, }: stdenv.mkDerivation rec { @@ -13,9 +16,14 @@ stdenv.mkDerivation rec { hash = "sha256-cvunkicD3fp6Ao1ROsFahcjVTI1n9V+lpIAohdxlIFY="; }; - patches = []; + patches = [ ]; - outputs = [ "out" "dev" "man" "info" ]; + outputs = [ + "out" + "dev" + "man" + "info" + ]; configureFlags = [ "--with-gcc-arch=generic" # no detection of -march= or -mtune= diff --git a/pkgs/development/libraries/libffi/default.nix b/pkgs/development/libraries/libffi/default.nix index 021776ed385682..aaaddd7c896b80 100644 --- a/pkgs/development/libraries/libffi/default.nix +++ b/pkgs/development/libraries/libffi/default.nix @@ -1,11 +1,14 @@ -{ lib, stdenv, fetchurl +{ + lib, + stdenv, + fetchurl, # test suite depends on dejagnu which cannot be used during bootstrapping # dejagnu also requires tcl which can't be built statically at the moment -, doCheck ? !(stdenv.hostPlatform.isStatic) -, dejagnu -, nix-update-script -, testers + doCheck ? !(stdenv.hostPlatform.isStatic), + dejagnu, + nix-update-script, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -13,7 +16,9 @@ stdenv.mkDerivation (finalAttrs: { version = "3.4.6"; src = fetchurl { - url = with finalAttrs; "https://github.com/libffi/libffi/releases/download/v${version}/${pname}-${version}.tar.gz"; + url = + with finalAttrs; + "https://github.com/libffi/libffi/releases/download/v${version}/${pname}-${version}.tar.gz"; hash = "sha256-sN6p3yPIY6elDoJUQPPr/6vWXfFJcQjl1Dd0eEOJWk4="; }; @@ -28,11 +33,19 @@ stdenv.mkDerivation (finalAttrs: { ]; strictDeps = true; - outputs = [ "out" "dev" "man" "info" ]; + outputs = [ + "out" + "dev" + "man" + "info" + ]; enableParallelBuilding = true; - configurePlatforms = [ "build" "host" ]; + configurePlatforms = [ + "build" + "host" + ]; configureFlags = [ "--with-gcc-arch=generic" # no detection of -march= or -mtune= diff --git a/pkgs/development/libraries/libfive/default.nix b/pkgs/development/libraries/libfive/default.nix index 9e71c5beaa5bcf..143a4b4c887369 100644 --- a/pkgs/development/libraries/libfive/default.nix +++ b/pkgs/development/libraries/libfive/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, wrapQtAppsHook -, fetchFromGitHub -, unstableGitUpdater -, cmake -, ninja -, pkg-config -, eigen -, zlib -, libpng -, boost -, guile -, python -, qtbase -, darwin +{ + lib, + stdenv, + wrapQtAppsHook, + fetchFromGitHub, + unstableGitUpdater, + cmake, + ninja, + pkg-config, + eigen, + zlib, + libpng, + boost, + guile, + python, + qtbase, + darwin, }: stdenv.mkDerivation { @@ -27,9 +28,22 @@ stdenv.mkDerivation { hash = "sha256-bA+4wGAygdbHcOMGFwNyzn2daQ8E7NeOTUF2Tr3RQww="; }; - nativeBuildInputs = [ wrapQtAppsHook cmake ninja pkg-config python.pkgs.pythonImportsCheckHook ]; - buildInputs = [ eigen zlib libpng boost guile python qtbase ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk_11_0.frameworks.Cocoa ]; + nativeBuildInputs = [ + wrapQtAppsHook + cmake + ninja + pkg-config + python.pkgs.pythonImportsCheckHook + ]; + buildInputs = [ + eigen + zlib + libpng + boost + guile + python + qtbase + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk_11_0.frameworks.Cocoa ]; preConfigure = '' substituteInPlace studio/src/guile/interpreter.cpp \ @@ -55,39 +69,45 @@ stdenv.mkDerivation { export XDG_CACHE_HOME=$(mktemp -d)/.cache ''; - cmakeFlags = [ - "-DGUILE_CCACHE_DIR=${placeholder "out"}/${guile.siteCcacheDir}" - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && lib.versionOlder stdenv.hostPlatform.darwinMinVersion "11") [ - # warning: 'aligned_alloc' is only available on macOS 10.15 or newer - "-DCMAKE_OSX_DEPLOYMENT_TARGET=10.15" - ]; + cmakeFlags = + [ + "-DGUILE_CCACHE_DIR=${placeholder "out"}/${guile.siteCcacheDir}" + ] + ++ lib.optionals + (stdenv.hostPlatform.isDarwin && lib.versionOlder stdenv.hostPlatform.darwinMinVersion "11") + [ + # warning: 'aligned_alloc' is only available on macOS 10.15 or newer + "-DCMAKE_OSX_DEPLOYMENT_TARGET=10.15" + ]; env = lib.optionalAttrs stdenv.cc.isClang { NIX_CFLAGS_COMPILE = "-Wno-error=enum-constexpr-conversion"; }; - postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' - # No rules to install the mac app, so do it manually. - mkdir -p $out/Applications - cp -r studio/Studio.app $out/Applications/Studio.app + postInstall = + lib.optionalString stdenv.hostPlatform.isDarwin '' + # No rules to install the mac app, so do it manually. + mkdir -p $out/Applications + cp -r studio/Studio.app $out/Applications/Studio.app - install_name_tool -add_rpath $out/lib $out/Applications/Studio.app/Contents/MacOS/Studio + install_name_tool -add_rpath $out/lib $out/Applications/Studio.app/Contents/MacOS/Studio - makeWrapper $out/Applications/Studio.app/Contents/MacOS/Studio $out/bin/Studio - '' + '' - # Link "Studio" binary to "libfive-studio" to be more obvious: - ln -s "$out/bin/Studio" "$out/bin/libfive-studio" + makeWrapper $out/Applications/Studio.app/Contents/MacOS/Studio $out/bin/Studio + '' + + '' + # Link "Studio" binary to "libfive-studio" to be more obvious: + ln -s "$out/bin/Studio" "$out/bin/libfive-studio" - # Create links since libfive looks for the library in a specific path. - mkdir -p "$out/${python.sitePackages}/libfive/src" - ln -s "$out"/lib/libfive.* "$out/${python.sitePackages}/libfive/src/" - mkdir -p "$out/${python.sitePackages}/libfive/stdlib" - ln -s "$out"/lib/libfive-stdlib.* "$out/${python.sitePackages}/libfive/stdlib/" + # Create links since libfive looks for the library in a specific path. + mkdir -p "$out/${python.sitePackages}/libfive/src" + ln -s "$out"/lib/libfive.* "$out/${python.sitePackages}/libfive/src/" + mkdir -p "$out/${python.sitePackages}/libfive/stdlib" + ln -s "$out"/lib/libfive-stdlib.* "$out/${python.sitePackages}/libfive/stdlib/" - # Create links so Studio can find the bindings. - mkdir -p "$out/libfive/bind" - ln -s "$out/${python.sitePackages}" "$out/libfive/bind/python" - ''; + # Create links so Studio can find the bindings. + mkdir -p "$out/libfive/bind" + ln -s "$out/${python.sitePackages}" "$out/libfive/bind/python" + ''; pythonImportsCheck = [ "libfive" @@ -103,8 +123,15 @@ stdenv.mkDerivation { meta = with lib; { description = "Infrastructure for solid modeling with F-Reps in C, C++, and Guile"; homepage = "https://libfive.com/"; - maintainers = with maintainers; [ hodapp kovirobi wulfsta ]; - license = with licenses; [ mpl20 gpl2Plus ]; + maintainers = with maintainers; [ + hodapp + kovirobi + wulfsta + ]; + license = with licenses; [ + mpl20 + gpl2Plus + ]; platforms = with platforms; all; }; } diff --git a/pkgs/development/libraries/libfreefare/default.nix b/pkgs/development/libraries/libfreefare/default.nix index 90e6f29c9d6edb..3bbfb5f6834f5f 100644 --- a/pkgs/development/libraries/libfreefare/default.nix +++ b/pkgs/development/libraries/libfreefare/default.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pkg-config, libnfc, openssl -, libobjc ? null -, IOKit, Security +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + libnfc, + openssl, + libobjc ? null, + IOKit, + Security, }: stdenv.mkDerivation { @@ -12,14 +20,26 @@ stdenv.mkDerivation { sha256 = "0r5wfvwgf35lb1v65wavnwz2wlfyfdims6a9xpslf4lsm4a1v8xz"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ libnfc openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libobjc IOKit Security ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = + [ + libnfc + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + IOKit + Security + ]; meta = with lib; { description = "Libfreefare project aims to provide a convenient API for MIFARE card manipulations"; license = licenses.lgpl3; homepage = "https://github.com/nfc-tools/libfreefare"; - maintainers = with maintainers; [bobvanderlinden]; + maintainers = with maintainers; [ bobvanderlinden ]; platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/libftdi/default.nix b/pkgs/development/libraries/libftdi/default.nix index 18dab4e340da2b..0936316bbca421 100644 --- a/pkgs/development/libraries/libftdi/default.nix +++ b/pkgs/development/libraries/libftdi/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, libusb-compat-0_1 -, Security -, IOKit -, libobjc +{ + lib, + stdenv, + fetchurl, + libusb-compat-0_1, + Security, + IOKit, + libobjc, }: stdenv.mkDerivation rec { @@ -16,7 +17,13 @@ stdenv.mkDerivation rec { sha256 = "13l39f6k6gff30hsgh0wa2z422g9pyl91rh8a8zz6f34k2sxaxii"; }; - buildInputs = [ libusb-compat-0_1 ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libobjc Security IOKit ]; + buildInputs = + [ libusb-compat-0_1 ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + Security + IOKit + ]; propagatedBuildInputs = [ libusb-compat-0_1 ]; diff --git a/pkgs/development/libraries/libgcrypt/1.8.nix b/pkgs/development/libraries/libgcrypt/1.8.nix index 720c376d026369..51da7d0ccc03f1 100644 --- a/pkgs/development/libraries/libgcrypt/1.8.nix +++ b/pkgs/development/libraries/libgcrypt/1.8.nix @@ -1,13 +1,15 @@ -{ lib -, stdenv -, fetchurl -, libgpg-error -, enableCapabilities ? false, libcap -, buildPackages -# for passthru.tests -, gnupg -, libotr -, rsyslog +{ + lib, + stdenv, + fetchurl, + libgpg-error, + enableCapabilities ? false, + libcap, + buildPackages, + # for passthru.tests + gnupg, + libotr, + rsyslog, }: assert enableCapabilities -> stdenv.hostPlatform.isLinux; @@ -21,7 +23,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-aJaRVQH5UeI9AtywRTRpwswiqk13oAH/c6JkfC0p590="; }; - outputs = [ "out" "dev" "info" ]; + outputs = [ + "out" + "dev" + "info" + ]; outputBin = "dev"; # The CPU Jitter random number generator must not be compiled with @@ -31,17 +37,22 @@ stdenv.mkDerivation rec { depsBuildBuild = [ buildPackages.stdenv.cc ]; - buildInputs = [ libgpg-error ] - ++ lib.optional enableCapabilities libcap; + buildInputs = [ libgpg-error ] ++ lib.optional enableCapabilities libcap; strictDeps = true; - configureFlags = [ "--with-libgpg-error-prefix=${libgpg-error.dev}" ] - ++ lib.optional (stdenv.hostPlatform.isMusl || (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64)) "--disable-asm"; # for darwin see https://dev.gnupg.org/T5157 + configureFlags = + [ "--with-libgpg-error-prefix=${libgpg-error.dev}" ] + ++ lib.optional ( + stdenv.hostPlatform.isMusl || (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) + ) "--disable-asm"; # for darwin see https://dev.gnupg.org/T5157 # Necessary to generate correct assembly when compiling for aarch32 on # aarch64 - configurePlatforms = [ "host" "build" ]; + configurePlatforms = [ + "host" + "build" + ]; postConfigure = '' sed -i configure \ @@ -50,11 +61,13 @@ stdenv.mkDerivation rec { # Make sure libraries are correct for .pc and .la files # Also make sure includes are fixed for callers who don't use libgpgcrypt-config - postFixup = '' - sed -i 's,#include ,#include "${libgpg-error.dev}/include/gpg-error.h",g' "$dev/include/gcrypt.h" - '' + lib.optionalString enableCapabilities '' - sed -i 's,\(-lcap\),-L${libcap.lib}/lib \1,' $out/lib/libgcrypt.la - ''; + postFixup = + '' + sed -i 's,#include ,#include "${libgpg-error.dev}/include/gpg-error.h",g' "$dev/include/gcrypt.h" + '' + + lib.optionalString enableCapabilities '' + sed -i 's,\(-lcap\),-L${libcap.lib}/lib \1,' $out/lib/libgcrypt.la + ''; doCheck = true; diff --git a/pkgs/development/libraries/libgcrypt/default.nix b/pkgs/development/libraries/libgcrypt/default.nix index ad360dab55ca28..4ac7d48213e2a1 100644 --- a/pkgs/development/libraries/libgcrypt/default.nix +++ b/pkgs/development/libraries/libgcrypt/default.nix @@ -1,14 +1,16 @@ -{ lib -, stdenv -, fetchurl -, gettext -, libgpg-error -, enableCapabilities ? false, libcap -, buildPackages -# for passthru.tests -, gnupg -, libotr -, rsyslog +{ + lib, + stdenv, + fetchurl, + gettext, + libgpg-error, + enableCapabilities ? false, + libcap, + buildPackages, + # for passthru.tests + gnupg, + libotr, + rsyslog, }: assert enableCapabilities -> stdenv.hostPlatform.isLinux; @@ -22,7 +24,13 @@ stdenv.mkDerivation rec { hash = "sha256-iwhwiXrFrGfe1Wjc+t9Flpz6imvrD9YK8qnq3Coycqo="; }; - outputs = [ "bin" "lib" "dev" "info" "out" ]; + outputs = [ + "bin" + "lib" + "dev" + "info" + "out" + ]; # The CPU Jitter random number generator must not be compiled with # optimizations and the optimize -O0 pragma only works for gcc. @@ -31,20 +39,29 @@ stdenv.mkDerivation rec { depsBuildBuild = [ buildPackages.stdenv.cc ]; - buildInputs = [ libgpg-error ] + buildInputs = + [ libgpg-error ] ++ lib.optional stdenv.hostPlatform.isDarwin gettext ++ lib.optional enableCapabilities libcap; strictDeps = true; - configureFlags = [ "--with-libgpg-error-prefix=${libgpg-error.dev}" ] - ++ lib.optional (stdenv.hostPlatform.isMusl || (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64)) "--disable-asm" # for darwin see https://dev.gnupg.org/T5157 - # Fix undefined reference errors with version script under LLVM. - ++ lib.optional (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") "LDFLAGS=-Wl,--undefined-version"; + configureFlags = + [ "--with-libgpg-error-prefix=${libgpg-error.dev}" ] + ++ lib.optional ( + stdenv.hostPlatform.isMusl || (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) + ) "--disable-asm" # for darwin see https://dev.gnupg.org/T5157 + # Fix undefined reference errors with version script under LLVM. + ++ lib.optional ( + stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17" + ) "LDFLAGS=-Wl,--undefined-version"; # Necessary to generate correct assembly when compiling for aarch32 on # aarch64 - configurePlatforms = [ "host" "build" ]; + configurePlatforms = [ + "host" + "build" + ]; postConfigure = '' sed -i configure \ @@ -55,18 +72,20 @@ stdenv.mkDerivation rec { # Make sure libraries are correct for .pc and .la files # Also make sure includes are fixed for callers who don't use libgpgcrypt-config - postFixup = '' - sed -i 's,#include ,#include "${libgpg-error.dev}/include/gpg-error.h",g' "$dev/include/gcrypt.h" - '' - # The `libgcrypt-config` script references $dev and in the $dev output, the - # stdenv automagically puts the $bin output into propagatedBuildInputs. This - # would cause a cycle. This is a weird tool anyways, so let's stuff it in $dev - # instead. - + '' - moveToOutput bin/libgcrypt-config $dev - '' + lib.optionalString enableCapabilities '' - sed -i 's,\(-lcap\),-L${libcap.lib}/lib \1,' $lib/lib/libgcrypt.la - ''; + postFixup = + '' + sed -i 's,#include ,#include "${libgpg-error.dev}/include/gpg-error.h",g' "$dev/include/gcrypt.h" + '' + # The `libgcrypt-config` script references $dev and in the $dev output, the + # stdenv automagically puts the $bin output into propagatedBuildInputs. This + # would cause a cycle. This is a weird tool anyways, so let's stuff it in $dev + # instead. + + '' + moveToOutput bin/libgcrypt-config $dev + '' + + lib.optionalString enableCapabilities '' + sed -i 's,\(-lcap\),-L${libcap.lib}/lib \1,' $lib/lib/libgcrypt.la + ''; # TODO: figure out why this is even necessary and why the missing dylib only crashes # random instead of every test diff --git a/pkgs/development/libraries/libgda/6.x.nix b/pkgs/development/libraries/libgda/6.x.nix index 72f4741fd2e761..f0f23ec7953b96 100644 --- a/pkgs/development/libraries/libgda/6.x.nix +++ b/pkgs/development/libraries/libgda/6.x.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, pkg-config -, intltool -, meson -, ninja -, itstool -, libxml2 -, python3 -, gtk3 -, json-glib -, isocodes -, openssl -, gnome -, gobject-introspection -, vala -, libgee -, sqlite -, gtk-doc -, yelp-tools -, mysqlSupport ? false -, libmysqlclient ? null -, postgresSupport ? false -, postgresql ? null +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + intltool, + meson, + ninja, + itstool, + libxml2, + python3, + gtk3, + json-glib, + isocodes, + openssl, + gnome, + gobject-introspection, + vala, + libgee, + sqlite, + gtk-doc, + yelp-tools, + mysqlSupport ? false, + libmysqlclient ? null, + postgresSupport ? false, + postgresql ? null, }: assert mysqlSupport -> libmysqlclient != null; @@ -72,18 +73,21 @@ stdenv.mkDerivation rec { yelp-tools ]; - buildInputs = [ - gtk3 - json-glib - isocodes - openssl - libgee - sqlite - ] ++ lib.optionals mysqlSupport [ - libmysqlclient - ] ++ lib.optionals postgresSupport [ - postgresql - ]; + buildInputs = + [ + gtk3 + json-glib + isocodes + openssl + libgee + sqlite + ] + ++ lib.optionals mysqlSupport [ + libmysqlclient + ] + ++ lib.optionals postgresSupport [ + postgresql + ]; env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-error=incompatible-function-pointer-types"; diff --git a/pkgs/development/libraries/libgda/default.nix b/pkgs/development/libraries/libgda/default.nix index b6a64c4b7a3fbb..cc0306810d5ebf 100644 --- a/pkgs/development/libraries/libgda/default.nix +++ b/pkgs/development/libraries/libgda/default.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, intltool -, itstool -, libxml2 -, gtk3 -, openssl -, gnome -, gobject-introspection -, vala -, libgee -, fetchpatch -, autoreconfHook -, gtk-doc -, autoconf-archive -, yelp-tools -, mysqlSupport ? false -, libmysqlclient -, postgresSupport ? false -, postgresql +{ + lib, + stdenv, + fetchurl, + pkg-config, + intltool, + itstool, + libxml2, + gtk3, + openssl, + gnome, + gobject-introspection, + vala, + libgee, + fetchpatch, + autoreconfHook, + gtk-doc, + autoconf-archive, + yelp-tools, + mysqlSupport ? false, + libmysqlclient, + postgresSupport ? false, + postgresql, }: stdenv.mkDerivation rec { @@ -56,15 +57,18 @@ stdenv.mkDerivation rec { yelp-tools ]; - buildInputs = [ - gtk3 - openssl - libgee - ] ++ lib.optionals mysqlSupport [ - libmysqlclient - ] ++ lib.optionals postgresSupport [ - postgresql - ]; + buildInputs = + [ + gtk3 + openssl + libgee + ] + ++ lib.optionals mysqlSupport [ + libmysqlclient + ] + ++ lib.optionals postgresSupport [ + postgresql + ]; propagatedBuildInputs = [ libxml2 diff --git a/pkgs/development/libraries/libgdiplus/default.nix b/pkgs/development/libraries/libgdiplus/default.nix index 63efe5430537fd..58afe09e7cd4be 100644 --- a/pkgs/development/libraries/libgdiplus/default.nix +++ b/pkgs/development/libraries/libgdiplus/default.nix @@ -1,6 +1,20 @@ -{ lib, stdenv, fetchzip, pkg-config, glib, cairo, Carbon, fontconfig -, libtiff, giflib, libjpeg, libpng -, libXrender, libexif, autoreconfHook }: +{ + lib, + stdenv, + fetchzip, + pkg-config, + glib, + cairo, + Carbon, + fontconfig, + libtiff, + giflib, + libjpeg, + libpng, + libXrender, + libexif, + autoreconfHook, +}: stdenv.mkDerivation (finalAttrs: { pname = "libgdiplus"; @@ -20,21 +34,33 @@ stdenv.mkDerivation (finalAttrs: { NIX_LDFLAGS = "-lgif"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; hardeningDisable = [ "format" ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; configureFlags = lib.optional stdenv.cc.isClang "--host=${stdenv.hostPlatform.system}"; enableParallelBuilding = true; - buildInputs = - [ glib cairo fontconfig libtiff giflib - libjpeg libpng libXrender libexif - ] - ++ lib.optional stdenv.hostPlatform.isDarwin Carbon; + buildInputs = [ + glib + cairo + fontconfig + libtiff + giflib + libjpeg + libpng + libXrender + libexif + ] ++ lib.optional stdenv.hostPlatform.isDarwin Carbon; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' ln -s $out/lib/libgdiplus.0.dylib $out/lib/libgdiplus.so diff --git a/pkgs/development/libraries/libgnome-games-support/2.0.nix b/pkgs/development/libraries/libgnome-games-support/2.0.nix index bc8da8045899a7..300375c1843f7c 100644 --- a/pkgs/development/libraries/libgnome-games-support/2.0.nix +++ b/pkgs/development/libraries/libgnome-games-support/2.0.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, glib -, gobject-introspection -, gtk4 -, libgee -, gettext -, vala -, gnome -, libintl -, meson -, ninja +{ + stdenv, + lib, + fetchurl, + pkg-config, + glib, + gobject-introspection, + gtk4, + libgee, + gettext, + vala, + gnome, + libintl, + meson, + ninja, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/libgnome-games-support/default.nix b/pkgs/development/libraries/libgnome-games-support/default.nix index bdbdc10f514c8d..2deaadd37839fe 100644 --- a/pkgs/development/libraries/libgnome-games-support/default.nix +++ b/pkgs/development/libraries/libgnome-games-support/default.nix @@ -1,15 +1,17 @@ -{ lib, stdenv -, fetchurl -, pkg-config -, glib -, gtk3 -, libgee -, gettext -, vala -, gnome -, libintl -, meson -, ninja +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + gtk3, + libgee, + gettext, + vala, + gnome, + libintl, + meson, + ninja, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/libgpod/default.nix b/pkgs/development/libraries/libgpod/default.nix index 5d4e0253be8dca..ead4701576c791 100644 --- a/pkgs/development/libraries/libgpod/default.nix +++ b/pkgs/development/libraries/libgpod/default.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchurl -, fetchpatch -, perlPackages -, intltool -, autoreconfHook -, pkg-config -, glib -, libxml2 -, sqlite -, sg3_utils -, gdk-pixbuf -, taglib -, libimobiledevice -, monoSupport ? false -, mono -, gtk-sharp-2_0 +{ + stdenv, + lib, + fetchurl, + fetchpatch, + perlPackages, + intltool, + autoreconfHook, + pkg-config, + glib, + libxml2, + sqlite, + sg3_utils, + gdk-pixbuf, + taglib, + libimobiledevice, + monoSupport ? false, + mono, + gtk-sharp-2_0, }: stdenv.mkDerivation rec { @@ -27,7 +28,10 @@ stdenv.mkDerivation rec { hash = "sha256-Y4p5WdBOlfHmKrrQK9M3AuTo3++YSFrH2dUDlcN+lV0="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; patches = [ (fetchpatch { @@ -50,8 +54,16 @@ stdenv.mkDerivation rec { dontStrip = monoSupport; - nativeBuildInputs = [ autoreconfHook intltool pkg-config ] - ++ (with perlPackages; [ perl XMLParser ]) + nativeBuildInputs = + [ + autoreconfHook + intltool + pkg-config + ] + ++ (with perlPackages; [ + perl + XMLParser + ]) ++ lib.optional monoSupport mono; buildInputs = [ diff --git a/pkgs/development/libraries/libgrss/default.nix b/pkgs/development/libraries/libgrss/default.nix index d2ac5a83602a25..73b22e6c9035d9 100644 --- a/pkgs/development/libraries/libgrss/default.nix +++ b/pkgs/development/libraries/libgrss/default.nix @@ -1,13 +1,32 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, vala, gobject-introspection, gtk-doc -, docbook_xsl, docbook_xml_dtd_412, glib, libxml2, libsoup_2_4, gnome, buildPackages -, Foundation, AppKit +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + vala, + gobject-introspection, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_412, + glib, + libxml2, + libsoup_2_4, + gnome, + buildPackages, + Foundation, + AppKit, }: stdenv.mkDerivation rec { pname = "libgrss"; version = "0.7.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -32,20 +51,24 @@ stdenv.mkDerivation rec { docbook_xml_dtd_412 ]; - buildInputs = [ - glib - libxml2 - libsoup_2_4 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Foundation - AppKit - ]; + buildInputs = + [ + glib + libxml2 + libsoup_2_4 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Foundation + AppKit + ]; - configureFlags = [ - "PKG_CONFIG=${buildPackages.pkg-config}/bin/${buildPackages.pkg-config.targetPrefix}pkg-config" - ] ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ - "--enable-gtk-doc" - ]; + configureFlags = + [ + "PKG_CONFIG=${buildPackages.pkg-config}/bin/${buildPackages.pkg-config.targetPrefix}pkg-config" + ] + ++ lib.optionals (stdenv.buildPlatform == stdenv.hostPlatform) [ + "--enable-gtk-doc" + ]; doCheck = true; diff --git a/pkgs/development/libraries/libhandy/0.x.nix b/pkgs/development/libraries/libhandy/0.x.nix index c20a8382b5d083..9df815ce2e6c5a 100644 --- a/pkgs/development/libraries/libhandy/0.x.nix +++ b/pkgs/development/libraries/libhandy/0.x.nix @@ -1,15 +1,32 @@ -{ lib, stdenv, fetchFromGitLab, meson, ninja, pkg-config, gobject-introspection, vala -, gtk-doc, docbook_xsl, docbook_xml_dtd_43 -, gtk3, gnome-desktop -, dbus, xvfb-run, libxml2 -, hicolor-icon-theme +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + gobject-introspection, + vala, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_43, + gtk3, + gnome-desktop, + dbus, + xvfb-run, + libxml2, + hicolor-icon-theme, }: stdenv.mkDerivation rec { pname = "libhandy"; version = "0.0.13"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "dev"; src = fetchFromGitLab { @@ -21,11 +38,26 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - meson ninja pkg-config gobject-introspection vala libxml2 - gtk-doc docbook_xsl docbook_xml_dtd_43 + meson + ninja + pkg-config + gobject-introspection + vala + libxml2 + gtk-doc + docbook_xsl + docbook_xml_dtd_43 + ]; + buildInputs = [ + gnome-desktop + gtk3 + libxml2 + ]; + nativeCheckInputs = [ + dbus + xvfb-run + hicolor-icon-theme ]; - buildInputs = [ gnome-desktop gtk3 libxml2 ]; - nativeCheckInputs = [ dbus xvfb-run hicolor-icon-theme ]; mesonFlags = [ "-Dgtk_doc=true" diff --git a/pkgs/development/libraries/libhandy/default.nix b/pkgs/development/libraries/libhandy/default.nix index 829de78a6aeb35..9853dcbd3ff750 100644 --- a/pkgs/development/libraries/libhandy/default.nix +++ b/pkgs/development/libraries/libhandy/default.nix @@ -1,40 +1,43 @@ -{ lib -, stdenv -, fetchurl -, meson -, ninja -, pkg-config -, gobject-introspection -, vala -, gi-docgen -, glib -, gsettings-desktop-schemas -, gtk3 -, enableGlade ? false -, glade -, xvfb-run -, gdk-pixbuf -, librsvg -, libxml2 -, hicolor-icon-theme -, at-spi2-atk -, at-spi2-core -, gnome -, libhandy -, runCommand +{ + lib, + stdenv, + fetchurl, + meson, + ninja, + pkg-config, + gobject-introspection, + vala, + gi-docgen, + glib, + gsettings-desktop-schemas, + gtk3, + enableGlade ? false, + glade, + xvfb-run, + gdk-pixbuf, + librsvg, + libxml2, + hicolor-icon-theme, + at-spi2-atk, + at-spi2-core, + gnome, + libhandy, + runCommand, }: stdenv.mkDerivation rec { pname = "libhandy"; version = "1.8.3"; - outputs = [ - "out" - "dev" - "devdoc" - ] ++ lib.optionals enableGlade [ - "glade" - ]; + outputs = + [ + "out" + "dev" + "devdoc" + ] + ++ lib.optionals enableGlade [ + "glade" + ]; outputBin = "dev"; src = fetchurl { @@ -46,23 +49,27 @@ stdenv.mkDerivation rec { pkg-config ]; - nativeBuildInputs = [ - gobject-introspection - gi-docgen - meson - ninja - pkg-config - vala - ] ++ lib.optionals enableGlade [ - libxml2 # for xmllint - ]; - - buildInputs = [ - gdk-pixbuf - gtk3 - ] ++ lib.optionals enableGlade [ - glade - ]; + nativeBuildInputs = + [ + gobject-introspection + gi-docgen + meson + ninja + pkg-config + vala + ] + ++ lib.optionals enableGlade [ + libxml2 # for xmllint + ]; + + buildInputs = + [ + gdk-pixbuf + gtk3 + ] + ++ lib.optionals enableGlade [ + glade + ]; nativeCheckInputs = [ xvfb-run @@ -90,15 +97,17 @@ stdenv.mkDerivation rec { # Disable portal since we cannot run it in tests. HDY_DISABLE_PORTAL=1 - "XDG_DATA_DIRS=${lib.concatStringsSep ":" [ - # HdySettings needs to be initialized from “org.gnome.desktop.interface” GSettings schema when portal is not used for color scheme. - # It will not actually be used since the “color-scheme” key will only have been introduced in GNOME 42, falling back to detecting theme name. - # See hdy_settings_constructed function in https://gitlab.gnome.org/GNOME/libhandy/-/commit/bb68249b005c445947bfb2bee66c91d0fe9c41a4 - (glib.getSchemaDataDirPath gsettings-desktop-schemas) - - # Some tests require icons - "${hicolor-icon-theme}/share" - ]}" + "XDG_DATA_DIRS=${ + lib.concatStringsSep ":" [ + # HdySettings needs to be initialized from “org.gnome.desktop.interface” GSettings schema when portal is not used for color scheme. + # It will not actually be used since the “color-scheme” key will only have been introduced in GNOME 42, falling back to detecting theme name. + # See hdy_settings_constructed function in https://gitlab.gnome.org/GNOME/libhandy/-/commit/bb68249b005c445947bfb2bee66c91d0fe9c41a4 + (glib.getSchemaDataDirPath gsettings-desktop-schemas) + + # Some tests require icons + "${hicolor-icon-theme}/share" + ] + }" ) env "''${testEnvironment[@]}" xvfb-run \ meson test --print-errorlogs @@ -111,23 +120,26 @@ stdenv.mkDerivation rec { moveToOutput "share/doc" "$devdoc" ''; - passthru = { - updateScript = gnome.updateScript { - packageName = pname; - versionPolicy = "odd-unstable"; + passthru = + { + updateScript = gnome.updateScript { + packageName = pname; + versionPolicy = "odd-unstable"; + }; + } + // lib.optionalAttrs (!enableGlade) { + glade = + let + libhandyWithGlade = libhandy.override { + enableGlade = true; + }; + in + runCommand "${libhandy.name}-glade" { } '' + cp -r "${libhandyWithGlade.glade}" "$out" + chmod -R +w "$out" + sed -e "s#${libhandyWithGlade.out}#${libhandy.out}#g" -e "s#${libhandyWithGlade.glade}#$out#g" -i $(find "$out" -type f) + ''; }; - } // lib.optionalAttrs (!enableGlade) { - glade = - let - libhandyWithGlade = libhandy.override { - enableGlade = true; - }; - in runCommand "${libhandy.name}-glade" {} '' - cp -r "${libhandyWithGlade.glade}" "$out" - chmod -R +w "$out" - sed -e "s#${libhandyWithGlade.out}#${libhandy.out}#g" -e "s#${libhandyWithGlade.glade}#$out#g" -i $(find "$out" -type f) - ''; - }; meta = with lib; { changelog = "https://gitlab.gnome.org/GNOME/libhandy/-/tags/${version}"; diff --git a/pkgs/development/libraries/libiconv/default.nix b/pkgs/development/libraries/libiconv/default.nix index 3cf0e799cb7edd..507d0d9f5f5555 100644 --- a/pkgs/development/libraries/libiconv/default.nix +++ b/pkgs/development/libraries/libiconv/default.nix @@ -1,93 +1,102 @@ -{ fetchurl, stdenv, lib -, enableStatic ? stdenv.hostPlatform.isStatic -, enableShared ? !stdenv.hostPlatform.isStatic -, enableDarwinABICompat ? false +{ + fetchurl, + stdenv, + lib, + enableStatic ? stdenv.hostPlatform.isStatic, + enableShared ? !stdenv.hostPlatform.isStatic, + enableDarwinABICompat ? false, }: # assert !stdenv.hostPlatform.isLinux || stdenv.hostPlatform != stdenv.buildPlatform; # TODO: improve on cross -stdenv.mkDerivation (rec { - pname = "libiconv"; - version = "1.17"; +stdenv.mkDerivation ( + rec { + pname = "libiconv"; + version = "1.17"; - src = fetchurl { - url = "mirror://gnu/libiconv/${pname}-${version}.tar.gz"; - sha256 = "sha256-j3QhO1YjjIWlClMp934GGYdx5w3Zpzl3n0wC9l2XExM="; - }; + src = fetchurl { + url = "mirror://gnu/libiconv/${pname}-${version}.tar.gz"; + sha256 = "sha256-j3QhO1YjjIWlClMp934GGYdx5w3Zpzl3n0wC9l2XExM="; + }; - enableParallelBuilding = true; + enableParallelBuilding = true; - setupHooks = [ - ../../../build-support/setup-hooks/role.bash - ./setup-hook.sh - ]; + setupHooks = [ + ../../../build-support/setup-hooks/role.bash + ./setup-hook.sh + ]; - postPatch = - lib.optionalString ((stdenv.hostPlatform != stdenv.buildPlatform && stdenv.hostPlatform.isMinGW) || stdenv.cc.nativeLibc) + postPatch = + lib.optionalString + ( + (stdenv.hostPlatform != stdenv.buildPlatform && stdenv.hostPlatform.isMinGW) || stdenv.cc.nativeLibc + ) + '' + sed '/^_GL_WARN_ON_USE (gets/d' -i srclib/stdio.in.h + '' + + lib.optionalString (!enableShared) '' + sed -i -e '/preload/d' Makefile.in '' - sed '/^_GL_WARN_ON_USE (gets/d' -i srclib/stdio.in.h - '' - + lib.optionalString (!enableShared) '' - sed -i -e '/preload/d' Makefile.in - '' - # The system libiconv is based on libiconv 1.11 with some ABI differences. The following changes - # build a compatible libiconv on Darwin, allowing it to be sustituted in place of the system one - # using `install_name_tool`. This removes the need to for a separate, Darwin-specific libiconv - # derivation and allows Darwin to benefit from upstream updates and fixes. - + lib.optionalString enableDarwinABICompat '' - for iconv_h_in in iconv.h.in iconv.h.build.in; do - substituteInPlace "include/$iconv_h_in" \ - --replace-fail "#define iconv libiconv" "" \ - --replace-fail "#define iconv_close libiconv_close" "" \ - --replace-fail "#define iconv_open libiconv_open" "" \ - --replace-fail "#define iconv_open_into libiconv_open_into" "" \ - --replace-fail "#define iconvctl libiconvctl" "" \ - --replace-fail "#define iconvlist libiconvlist" "" - done - ''; + # The system libiconv is based on libiconv 1.11 with some ABI differences. The following changes + # build a compatible libiconv on Darwin, allowing it to be sustituted in place of the system one + # using `install_name_tool`. This removes the need to for a separate, Darwin-specific libiconv + # derivation and allows Darwin to benefit from upstream updates and fixes. + + lib.optionalString enableDarwinABICompat '' + for iconv_h_in in iconv.h.in iconv.h.build.in; do + substituteInPlace "include/$iconv_h_in" \ + --replace-fail "#define iconv libiconv" "" \ + --replace-fail "#define iconv_close libiconv_close" "" \ + --replace-fail "#define iconv_open libiconv_open" "" \ + --replace-fail "#define iconv_open_into libiconv_open_into" "" \ + --replace-fail "#define iconvctl libiconvctl" "" \ + --replace-fail "#define iconvlist libiconvlist" "" + done + ''; - # This is hacky, but `libiconv.dylib` needs to reexport `libcharset.dylib` to match the behavior - # of the system libiconv on Darwin. Trying to do this by modifying the `Makefile` results in an - # error linking `iconv` because `libcharset.dylib` is not at its final path yet. Avoid the error - # by building without the reexport then clean and rebuild `libiconv.dylib` with the reexport. - # - # For an explanation why `libcharset.dylib` is reexported, see: - # https://github.com/apple-oss-distributions/libiconv/blob/a167071feb7a83a01b27ec8d238590c14eb6faff/xcodeconfig/libiconv.xcconfig - postBuild = lib.optionalString enableDarwinABICompat '' - make clean -C lib - NIX_CFLAGS_COMPILE+=" -Wl,-reexport-lcharset -L. " make -C lib -j$NIX_BUILD_CORES SHELL=$SHELL - ''; + # This is hacky, but `libiconv.dylib` needs to reexport `libcharset.dylib` to match the behavior + # of the system libiconv on Darwin. Trying to do this by modifying the `Makefile` results in an + # error linking `iconv` because `libcharset.dylib` is not at its final path yet. Avoid the error + # by building without the reexport then clean and rebuild `libiconv.dylib` with the reexport. + # + # For an explanation why `libcharset.dylib` is reexported, see: + # https://github.com/apple-oss-distributions/libiconv/blob/a167071feb7a83a01b27ec8d238590c14eb6faff/xcodeconfig/libiconv.xcconfig + postBuild = lib.optionalString enableDarwinABICompat '' + make clean -C lib + NIX_CFLAGS_COMPILE+=" -Wl,-reexport-lcharset -L. " make -C lib -j$NIX_BUILD_CORES SHELL=$SHELL + ''; - configureFlags = [ - (lib.enableFeature enableStatic "static") - (lib.enableFeature enableShared "shared") - ] ++ lib.optional stdenv.hostPlatform.isFreeBSD "--with-pic"; + configureFlags = [ + (lib.enableFeature enableStatic "static") + (lib.enableFeature enableShared "shared") + ] ++ lib.optional stdenv.hostPlatform.isFreeBSD "--with-pic"; - passthru = { inherit setupHooks; }; + passthru = { inherit setupHooks; }; - meta = { - description = "Iconv(3) implementation"; + meta = { + description = "Iconv(3) implementation"; - longDescription = '' - Some programs, like mailers and web browsers, must be able to convert - between a given text encoding and the user's encoding. Other programs - internally store strings in Unicode, to facilitate internal processing, - and need to convert between internal string representation (Unicode) - and external string representation (a traditional encoding) when they - are doing I/O. GNU libiconv is a conversion library for both kinds of - applications. - ''; + longDescription = '' + Some programs, like mailers and web browsers, must be able to convert + between a given text encoding and the user's encoding. Other programs + internally store strings in Unicode, to facilitate internal processing, + and need to convert between internal string representation (Unicode) + and external string representation (a traditional encoding) when they + are doing I/O. GNU libiconv is a conversion library for both kinds of + applications. + ''; - homepage = "https://www.gnu.org/software/libiconv/"; - license = lib.licenses.lgpl2Plus; + homepage = "https://www.gnu.org/software/libiconv/"; + license = lib.licenses.lgpl2Plus; - maintainers = [ ]; - mainProgram = "iconv"; + maintainers = [ ]; + mainProgram = "iconv"; - # This library is not needed on GNU platforms. - hydraPlatforms = with lib.platforms; cygwin ++ darwin ++ freebsd; - }; -} // lib.optionalAttrs (stdenv.hostPlatform.libc == "bionic") { - # https://github.com/NixOS/nixpkgs/pull/192630#discussion_r978985593 - hardeningDisable = [ "fortify" ]; -}) + # This library is not needed on GNU platforms. + hydraPlatforms = with lib.platforms; cygwin ++ darwin ++ freebsd; + }; + } + // lib.optionalAttrs (stdenv.hostPlatform.libc == "bionic") { + # https://github.com/NixOS/nixpkgs/pull/192630#discussion_r978985593 + hardeningDisable = [ "fortify" ]; + } +) diff --git a/pkgs/development/libraries/libidn2/default.nix b/pkgs/development/libraries/libidn2/default.nix index 90c7198757c704..03bed5005db291 100644 --- a/pkgs/development/libraries/libidn2/default.nix +++ b/pkgs/development/libraries/libidn2/default.nix @@ -1,4 +1,13 @@ -{ fetchurl, lib, stdenv, libiconv, libunistring, help2man, texinfo, buildPackages }: +{ + fetchurl, + lib, + stdenv, + libiconv, + libunistring, + help2man, + texinfo, + buildPackages, +}: # Note: this package is used for bootstrapping fetchurl, and thus # cannot use fetchpatch! All mutable patches (generated by GitHub or @@ -16,13 +25,22 @@ stdenv.mkDerivation rec { strictDeps = true; # Beware: non-bootstrap libidn2 is overridden by ./hack.nix - outputs = [ "bin" "dev" "out" "info" "devdoc" ]; + outputs = [ + "bin" + "dev" + "out" + "info" + "devdoc" + ]; enableParallelBuilding = true; # The above patch causes the documentation to be regenerated, so the # documentation tools are required. - nativeBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ help2man texinfo ]; + nativeBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + help2man + texinfo + ]; buildInputs = [ libunistring ] ++ lib.optional stdenv.hostPlatform.isDarwin libiconv; depsBuildBuild = [ buildPackages.stdenv.cc ]; @@ -40,7 +58,11 @@ stdenv.mkDerivation rec { ''; mainProgram = "idn2"; - license = with lib.licenses; [ lgpl3Plus gpl2Plus gpl3Plus ]; + license = with lib.licenses; [ + lgpl3Plus + gpl2Plus + gpl3Plus + ]; platforms = lib.platforms.all; maintainers = with lib.maintainers; [ fpletz ]; }; diff --git a/pkgs/development/libraries/libidn2/no-bootstrap-reference.nix b/pkgs/development/libraries/libidn2/no-bootstrap-reference.nix index 216beb5c48bda5..7c01fddb75bd87 100644 --- a/pkgs/development/libraries/libidn2/no-bootstrap-reference.nix +++ b/pkgs/development/libraries/libidn2/no-bootstrap-reference.nix @@ -1,10 +1,20 @@ -{ stdenv, lib, libidn2, libunistring, runCommandLocal, patchelf }: +{ + stdenv, + lib, + libidn2, + libunistring, + runCommandLocal, + patchelf, +}: # Construct a copy of libidn2.* where all (transitive) libc references (in .bin) # get replaced by a new one, so that there's no reference to bootstrap tools. -runCommandLocal - "${libidn2.pname}-${libidn2.version}" +runCommandLocal "${libidn2.pname}-${libidn2.version}" { - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; passthru = { inherit (libidn2) out info devdoc; # no need to touch these store paths }; @@ -15,8 +25,13 @@ runCommandLocal chmod +w "$bin"/bin/* patchelf \ --set-interpreter '${stdenv.cc.bintools.dynamicLinker}' \ - --set-rpath '${lib.concatMapStringsSep ":" (p: lib.getLib p + "/lib") - [ stdenv.cc.libc libunistring libidn2 ]}' \ + --set-rpath '${ + lib.concatMapStringsSep ":" (p: lib.getLib p + "/lib") [ + stdenv.cc.libc + libunistring + libidn2 + ] + }' \ "$bin"/bin/* cp -r '${libidn2.dev}' "$dev" @@ -28,4 +43,3 @@ runCommandLocal ln -s '${libidn2.out}' "$out" # it's hard to be without any $out '' - diff --git a/pkgs/development/libraries/libiio/default.nix b/pkgs/development/libraries/libiio/default.nix index 023dfce86bf57d..ce75d6c0fe83e8 100644 --- a/pkgs/development/libraries/libiio/default.nix +++ b/pkgs/development/libraries/libiio/default.nix @@ -1,26 +1,32 @@ -{ stdenv -, fetchFromGitHub -, cmake -, flex -, bison -, libxml2 -, pythonSupport ? stdenv.hostPlatform.hasSharedLibraries, python -, libusb1 -, avahiSupport ? true, avahi -, libaio -, runtimeShell -, lib -, pkg-config -, CFNetwork -, CoreServices +{ + stdenv, + fetchFromGitHub, + cmake, + flex, + bison, + libxml2, + pythonSupport ? stdenv.hostPlatform.hasSharedLibraries, + python, + libusb1, + avahiSupport ? true, + avahi, + libaio, + runtimeShell, + lib, + pkg-config, + CFNetwork, + CoreServices, }: stdenv.mkDerivation rec { pname = "libiio"; version = "0.24"; - outputs = [ "out" "lib" "dev" ] - ++ lib.optional pythonSupport "python"; + outputs = [ + "out" + "lib" + "dev" + ] ++ lib.optional pythonSupport "python"; src = fetchFromGitHub { owner = "analogdevicesinc"; @@ -33,42 +39,57 @@ stdenv.mkDerivation rec { # fixed properly patches = [ ./cmake-fix-libxml2-find-package.patch ]; - nativeBuildInputs = [ - cmake - flex - bison - pkg-config - ] ++ lib.optionals pythonSupport ([ - python - ] ++ lib.optional python.isPy3k python.pkgs.setuptools); + nativeBuildInputs = + [ + cmake + flex + bison + pkg-config + ] + ++ lib.optionals pythonSupport ( + [ + python + ] + ++ lib.optional python.isPy3k python.pkgs.setuptools + ); - buildInputs = [ - libxml2 - libusb1 - ] ++ lib.optional avahiSupport avahi + buildInputs = + [ + libxml2 + libusb1 + ] + ++ lib.optional avahiSupport avahi ++ lib.optional stdenv.hostPlatform.isLinux libaio - ++ lib.optionals stdenv.hostPlatform.isDarwin [ CFNetwork CoreServices ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CFNetwork + CoreServices + ]; - cmakeFlags = [ - "-DUDEV_RULES_INSTALL_DIR=${placeholder "out"}/lib/udev/rules.d" - # osx framework is disabled, - # the linux-like directory structure is used for proper output splitting - "-DOSX_PACKAGE=off" - "-DOSX_FRAMEWORK=off" - ] ++ lib.optionals pythonSupport [ - "-DPython_EXECUTABLE=${python.pythonOnBuildForHost.interpreter}" - "-DPYTHON_BINDINGS=on" - ] ++ lib.optionals (!avahiSupport) [ - "-DHAVE_DNS_SD=OFF" - ]; + cmakeFlags = + [ + "-DUDEV_RULES_INSTALL_DIR=${placeholder "out"}/lib/udev/rules.d" + # osx framework is disabled, + # the linux-like directory structure is used for proper output splitting + "-DOSX_PACKAGE=off" + "-DOSX_FRAMEWORK=off" + ] + ++ lib.optionals pythonSupport [ + "-DPython_EXECUTABLE=${python.pythonOnBuildForHost.interpreter}" + "-DPYTHON_BINDINGS=on" + ] + ++ lib.optionals (!avahiSupport) [ + "-DHAVE_DNS_SD=OFF" + ]; - postPatch = '' - substituteInPlace libiio.rules.cmakein \ - --replace /bin/sh ${runtimeShell} - '' + lib.optionalString pythonSupport '' - # Hardcode path to the shared library into the bindings. - sed "s#@libiio@#$lib/lib/libiio${stdenv.hostPlatform.extensions.sharedLibrary}#g" ${./hardcode-library-path.patch} | patch -p1 - ''; + postPatch = + '' + substituteInPlace libiio.rules.cmakein \ + --replace /bin/sh ${runtimeShell} + '' + + lib.optionalString pythonSupport '' + # Hardcode path to the shared library into the bindings. + sed "s#@libiio@#$lib/lib/libiio${stdenv.hostPlatform.extensions.sharedLibrary}#g" ${./hardcode-library-path.patch} | patch -p1 + ''; postInstall = lib.optionalString pythonSupport '' # Move Python bindings into a separate output. diff --git a/pkgs/development/libraries/libimobiledevice/default.nix b/pkgs/development/libraries/libimobiledevice/default.nix index 88b9391d4bdbb3..416ebdb1e21a47 100644 --- a/pkgs/development/libraries/libimobiledevice/default.nix +++ b/pkgs/development/libraries/libimobiledevice/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, pkg-config -, openssl -, libgcrypt -, libplist -, libtasn1 -, libusbmuxd -, libimobiledevice-glue -, SystemConfiguration -, CoreFoundation -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + openssl, + libgcrypt, + libplist, + libtasn1, + libusbmuxd, + libimobiledevice-glue, + SystemConfiguration, + CoreFoundation, + unstableGitUpdater, }: stdenv.mkDerivation rec { @@ -47,20 +48,24 @@ stdenv.mkDerivation rec { pkg-config ]; - propagatedBuildInputs = [ - openssl - libgcrypt - libplist - libtasn1 - libusbmuxd - libimobiledevice-glue - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - SystemConfiguration - CoreFoundation - ]; - + propagatedBuildInputs = + [ + openssl + libgcrypt + libplist + libtasn1 + libusbmuxd + libimobiledevice-glue + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + SystemConfiguration + CoreFoundation + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; enableParallelBuilding = true; diff --git a/pkgs/development/libraries/libint/default.nix b/pkgs/development/libraries/libint/default.nix index 73e400810f619b..04510dc5bca013 100644 --- a/pkgs/development/libraries/libint/default.nix +++ b/pkgs/development/libraries/libint/default.nix @@ -1,63 +1,64 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, libtool -, python3 -, perl -, gmpxx -, mpfr -, boost -, eigen -, gfortran -, cmake -, enableFMA ? stdenv.hostPlatform.fmaSupport -, enableFortran ? true -, enableSSE ? (!enableFortran) && stdenv.hostPlatform.isx86_64 +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + python3, + perl, + gmpxx, + mpfr, + boost, + eigen, + gfortran, + cmake, + enableFMA ? stdenv.hostPlatform.fmaSupport, + enableFortran ? true, + enableSSE ? (!enableFortran) && stdenv.hostPlatform.isx86_64, # Maximum angular momentum of basis functions # 7 is required for def2/J auxiliary basis on 3d metals upwards -, maxAm ? 7 + maxAm ? 7, # ERI derivative order for 4-, 3- and 2-centre ERIs. # 2nd derivatives are defaults and allow gradients Hessians with density fitting # Setting them to zero disables derivatives. -, eriDeriv ? 2 -, eri3Deriv ? 2 -, eri2Deriv ? 2 + eriDeriv ? 2, + eri3Deriv ? 2, + eri2Deriv ? 2, # Angular momentum for derivatives of ERIs. Takes a list of length $DERIV_ORD+1. # Starting from index 0, each index i specifies the supported angular momentum # for the derivative order i, e.g. [6,5,4] supports ERIs for l=6, their first # derivatives for l=5 and their second derivatives for l=4. -, eriAm ? (builtins.genList (i: maxAm - 1 - i) (eriDeriv + 1)) -, eri3Am ? (builtins.genList (i: maxAm - i) (eri2Deriv + 1)) -, eri2Am ? (builtins.genList (i: maxAm - i) (eri2Deriv + 1)) + eriAm ? (builtins.genList (i: maxAm - 1 - i) (eriDeriv + 1)), + eri3Am ? (builtins.genList (i: maxAm - i) (eri2Deriv + 1)), + eri2Am ? (builtins.genList (i: maxAm - i) (eri2Deriv + 1)), # Same as above for optimised code. Higher optimisations take a long time. -, eriOptAm ? (builtins.genList (i: maxAm - 3 - i) (eriDeriv + 1)) -, eri3OptAm ? (builtins.genList (i: maxAm - 3 - i) (eri2Deriv + 1)) -, eri2OptAm ? (builtins.genList (i: maxAm - 3 - i) (eri2Deriv + 1)) + eriOptAm ? (builtins.genList (i: maxAm - 3 - i) (eriDeriv + 1)), + eri3OptAm ? (builtins.genList (i: maxAm - 3 - i) (eri2Deriv + 1)), + eri2OptAm ? (builtins.genList (i: maxAm - 3 - i) (eri2Deriv + 1)), # One-Electron integrals of all kinds including multipole integrals. # Libint does not build them and their derivatives by default. -, enableOneBody ? false -, oneBodyDerivOrd ? 2 -, multipoleOrd ? 4 # Maximum order of multipole integrals, 4=octopoles + enableOneBody ? false, + oneBodyDerivOrd ? 2, + multipoleOrd ? 4, # Maximum order of multipole integrals, 4=octopoles # Whether to enable generic code if angular momentum is unsupported -, enableGeneric ? true + enableGeneric ? true, # Support integrals over contracted Gaussian -, enableContracted ? true + enableContracted ? true, # Spherical harmonics/Cartesian orbital conventions -, cartGaussOrd ? "standard" # Ordering of Cartesian basis functions, "standard" is CCA -, shGaussOrd ? "standard" # Ordering of spherical harmonic basis functions. "standard" is -l to +l, "guassian" is 0, 1, -1, 2, -2, ... -, shellSet ? "standard" -, eri3PureSh ? false # Transformation of 3-centre ERIs into spherical harmonics -, eri2PureSh ? false # Transformation of 2-centre ERIs into spherical harmonics + cartGaussOrd ? "standard", # Ordering of Cartesian basis functions, "standard" is CCA + shGaussOrd ? "standard", # Ordering of spherical harmonic basis functions. "standard" is -l to +l, "guassian" is 0, 1, -1, 2, -2, ... + shellSet ? "standard", + eri3PureSh ? false, # Transformation of 3-centre ERIs into spherical harmonics + eri2PureSh ? false, # Transformation of 2-centre ERIs into spherical harmonics }: # Check that Fortran bindings are not used together with SIMD real type @@ -73,39 +74,57 @@ assert (eri3Deriv >= 0 && eri3Deriv <= 4); # Ensure valid arguments for generated angular momenta in ERI derivatives are used. assert ( - builtins.length eriAm == eriDeriv + 1 && - builtins.foldl' (a: b: a && b) true (builtins.map (a: a <= maxAm && a >= 0) eriAm) + builtins.length eriAm == eriDeriv + 1 + && builtins.foldl' (a: b: a && b) true (builtins.map (a: a <= maxAm && a >= 0) eriAm) ); assert ( - builtins.length eri3Am == eriDeriv + 1 && - builtins.foldl' (a: b: a && b) true (builtins.map (a: a <= maxAm && a >= 0) eri3Am) + builtins.length eri3Am == eriDeriv + 1 + && builtins.foldl' (a: b: a && b) true (builtins.map (a: a <= maxAm && a >= 0) eri3Am) ); assert ( - builtins.length eri2Am == eriDeriv + 1 && - builtins.foldl' (a: b: a && b) true (builtins.map (a: a <= maxAm && a >= 0) eri2Am) + builtins.length eri2Am == eriDeriv + 1 + && builtins.foldl' (a: b: a && b) true (builtins.map (a: a <= maxAm && a >= 0) eri2Am) ); # Ensure valid arguments for generated angular momenta in optimised ERI derivatives are used. assert ( - builtins.length eriOptAm == eriDeriv + 1 && - builtins.foldl' (a: b: a && b) true (builtins.map (a: a <= maxAm && a >= 0) eriOptAm) + builtins.length eriOptAm == eriDeriv + 1 + && builtins.foldl' (a: b: a && b) true (builtins.map (a: a <= maxAm && a >= 0) eriOptAm) ); assert ( - builtins.length eri3OptAm == eriDeriv + 1 && - builtins.foldl' (a: b: a && b) true (builtins.map (a: a <= maxAm && a >= 0) eri3OptAm) + builtins.length eri3OptAm == eriDeriv + 1 + && builtins.foldl' (a: b: a && b) true (builtins.map (a: a <= maxAm && a >= 0) eri3OptAm) ); assert ( - builtins.length eri2OptAm == eriDeriv + 1 && - builtins.foldl' (a: b: a && b) true (builtins.map (a: a <= maxAm && a >= 0) eri2OptAm) + builtins.length eri2OptAm == eriDeriv + 1 + && builtins.foldl' (a: b: a && b) true (builtins.map (a: a <= maxAm && a >= 0) eri2OptAm) ); # Ensure a valid derivative order for one-electron integrals assert (oneBodyDerivOrd >= 0 && oneBodyDerivOrd <= 4); # Check that valid basis shell orders are used, see https://github.com/evaleev/libint/wiki -assert (builtins.elem cartGaussOrd [ "standard" "intv3" "gamess" "orca" "bagel" ]); -assert (builtins.elem shGaussOrd [ "standard" "gaussian" ]); -assert (builtins.elem shellSet [ "standard" "orca" ]); +assert ( + builtins.elem cartGaussOrd [ + "standard" + "intv3" + "gamess" + "orca" + "bagel" + ] +); +assert ( + builtins.elem shGaussOrd [ + "standard" + "gaussian" + ] +); +assert ( + builtins.elem shellSet [ + "standard" + "orca" + ] +); let pname = "libint"; @@ -114,8 +133,14 @@ let meta = { description = "Library for the evaluation of molecular integrals of many-body operators over Gaussian functions"; homepage = "https://github.com/evaleev/libint"; - license = with lib.licenses; [ lgpl3Only gpl3Only ]; - maintainers = with lib.maintainers; [ markuskowa sheepforce ]; + license = with lib.licenses; [ + lgpl3Only + gpl3Only + ]; + maintainers = with lib.maintainers; [ + markuskowa + sheepforce + ]; platforms = [ "x86_64-linux" ]; }; @@ -153,34 +178,37 @@ let gmpxx ] ++ lib.optional enableFortran gfortran; - buildInputs = [ boost eigen ]; - - configureFlags = [ - "--with-max-am=${builtins.toString maxAm}" - "--with-eri-max-am=${lib.concatStringsSep "," (builtins.map builtins.toString eriAm)}" - "--with-eri3-max-am=${lib.concatStringsSep "," (builtins.map builtins.toString eri3Am)}" - "--with-eri2-max-am=${lib.concatStringsSep "," (builtins.map builtins.toString eri2Am)}" - "--with-eri-opt-am=${lib.concatStringsSep "," (builtins.map builtins.toString eriOptAm)}" - "--with-eri3-opt-am=${lib.concatStringsSep "," (builtins.map builtins.toString eri3OptAm)}" - "--with-eri2-opt-am=${lib.concatStringsSep "," (builtins.map builtins.toString eri2OptAm)}" - "--with-cartgauss-ordering=${cartGaussOrd}" - "--with-shgauss-ordering=${shGaussOrd}" - "--with-shell-set=${shellSet}" - ] - ++ lib.optional enableFMA "--enable-fma" - ++ lib.optional (eriDeriv > 0) "--enable-eri=${builtins.toString eriDeriv}" - ++ lib.optional (eri2Deriv > 0) "--enable-eri2=${builtins.toString eri2Deriv}" - ++ lib.optional (eri3Deriv > 0) "--enable-eri3=${builtins.toString eri3Deriv}" - ++ lib.optionals enableOneBody [ - "--enable-1body=${builtins.toString oneBodyDerivOrd}" - "--enable-1body-property-derivs" - ] - ++ lib.optional (multipoleOrd > 0) "--with-multipole-max-order=${builtins.toString multipoleOrd}" - ++ lib.optional enableGeneric "--enable-generic" - ++ lib.optional enableContracted "--enable-contracted-ints" - ++ lib.optional eri3PureSh "--enable-eri3-pure-sh" - ++ lib.optional eri2PureSh "--enable-eri2-pure-sh" - ; + buildInputs = [ + boost + eigen + ]; + + configureFlags = + [ + "--with-max-am=${builtins.toString maxAm}" + "--with-eri-max-am=${lib.concatStringsSep "," (builtins.map builtins.toString eriAm)}" + "--with-eri3-max-am=${lib.concatStringsSep "," (builtins.map builtins.toString eri3Am)}" + "--with-eri2-max-am=${lib.concatStringsSep "," (builtins.map builtins.toString eri2Am)}" + "--with-eri-opt-am=${lib.concatStringsSep "," (builtins.map builtins.toString eriOptAm)}" + "--with-eri3-opt-am=${lib.concatStringsSep "," (builtins.map builtins.toString eri3OptAm)}" + "--with-eri2-opt-am=${lib.concatStringsSep "," (builtins.map builtins.toString eri2OptAm)}" + "--with-cartgauss-ordering=${cartGaussOrd}" + "--with-shgauss-ordering=${shGaussOrd}" + "--with-shell-set=${shellSet}" + ] + ++ lib.optional enableFMA "--enable-fma" + ++ lib.optional (eriDeriv > 0) "--enable-eri=${builtins.toString eriDeriv}" + ++ lib.optional (eri2Deriv > 0) "--enable-eri2=${builtins.toString eri2Deriv}" + ++ lib.optional (eri3Deriv > 0) "--enable-eri3=${builtins.toString eri3Deriv}" + ++ lib.optionals enableOneBody [ + "--enable-1body=${builtins.toString oneBodyDerivOrd}" + "--enable-1body-property-derivs" + ] + ++ lib.optional (multipoleOrd > 0) "--with-multipole-max-order=${builtins.toString multipoleOrd}" + ++ lib.optional enableGeneric "--enable-generic" + ++ lib.optional enableContracted "--enable-contracted-ints" + ++ lib.optional eri3PureSh "--enable-eri3-pure-sh" + ++ lib.optional eri2PureSh "--enable-eri2-pure-sh"; preConfigure = '' ./autogen.sh @@ -208,15 +236,20 @@ let cmake ] ++ lib.optional enableFortran gfortran; - buildInputs = [ boost eigen ]; + buildInputs = [ + boost + eigen + ]; # Default is just "double", but SSE2 is available on all x86_64 CPUs. # AVX support is advertised, but does not work. # Fortran interface is incompatible with changing the LIBINT2_REALTYPE. - cmakeFlags = [ - "-DLIBINT2_SHGAUSS_ORDERING=${shGaussOrd}" - ] ++ lib.optional enableFortran "-DENABLE_FORTRAN=ON" - ++ lib.optional enableSSE "-DLIBINT2_REALTYPE=libint2::simd::VectorSSEDouble"; + cmakeFlags = + [ + "-DLIBINT2_SHGAUSS_ORDERING=${shGaussOrd}" + ] + ++ lib.optional enableFortran "-DENABLE_FORTRAN=ON" + ++ lib.optional enableSSE "-DLIBINT2_REALTYPE=libint2::simd::VectorSSEDouble"; # Can only build in the source-tree. A lot of preprocessing magic fails otherwise. dontUseCmakeBuildDir = true; diff --git a/pkgs/development/libraries/libiodbc/default.nix b/pkgs/development/libraries/libiodbc/default.nix index c059d619ccae2e..fea90d439c24f4 100644 --- a/pkgs/development/libraries/libiodbc/default.nix +++ b/pkgs/development/libraries/libiodbc/default.nix @@ -1,5 +1,13 @@ -{ config, lib, stdenv, fetchurl, pkg-config, gtk2, Carbon -, useGTK ? config.libiodbc.gtk or false }: +{ + config, + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + Carbon, + useGTK ? config.libiodbc.gtk or false, +}: stdenv.mkDerivation rec { pname = "libiodbc"; @@ -11,13 +19,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = lib.optionals useGTK [ gtk2 ] - ++ lib.optional stdenv.hostPlatform.isDarwin Carbon; + buildInputs = lib.optionals useGTK [ gtk2 ] ++ lib.optional stdenv.hostPlatform.isDarwin Carbon; - preBuild = - '' - export NIX_LDFLAGS_BEFORE="-rpath $out/lib" - ''; + preBuild = '' + export NIX_LDFLAGS_BEFORE="-rpath $out/lib" + ''; meta = with lib; { description = "iODBC driver manager"; diff --git a/pkgs/development/libraries/libirc/default.nix b/pkgs/development/libraries/libirc/default.nix index 368cd7e1d8591b..962a4d041e7930 100644 --- a/pkgs/development/libraries/libirc/default.nix +++ b/pkgs/development/libraries/libirc/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, qtbase }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtbase, +}: stdenv.mkDerivation rec { pname = "libirc"; diff --git a/pkgs/development/libraries/liblastfm/default.nix b/pkgs/development/libraries/liblastfm/default.nix index 060839326b1576..4fb1af2a14d627 100644 --- a/pkgs/development/libraries/liblastfm/default.nix +++ b/pkgs/development/libraries/liblastfm/default.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, pkg-config, which, cmake -, fftwSinglePrec, libsamplerate, qtbase -, darwin }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + pkg-config, + which, + cmake, + fftwSinglePrec, + libsamplerate, + qtbase, + darwin, +}: stdenv.mkDerivation rec { pname = "liblastfm-unstable"; @@ -13,17 +23,28 @@ stdenv.mkDerivation rec { sha256 = "1crih9xxf3rb109aqw12bjqv47z28lvlk2dpvyym5shf82nz6yd0"; }; - patches = [(fetchpatch { - url = "https://github.com/lastfm/liblastfm/commit/9c5d072b55f2863310e40291677e6397e9cbc3c2.patch"; - name = "0001-Remove-deprecated-staging-server-and-fix-test-for-QT5-at-Ubuntu-19.10.patch"; - sha256 = "04r14prydxshjgfws3pjajjmp2msszhjjs1mjh8s66yg29vq620l"; - })]; + patches = [ + (fetchpatch { + url = "https://github.com/lastfm/liblastfm/commit/9c5d072b55f2863310e40291677e6397e9cbc3c2.patch"; + name = "0001-Remove-deprecated-staging-server-and-fix-test-for-QT5-at-Ubuntu-19.10.patch"; + sha256 = "04r14prydxshjgfws3pjajjmp2msszhjjs1mjh8s66yg29vq620l"; + }) + ]; - nativeBuildInputs = [ pkg-config which cmake ]; - buildInputs = [ fftwSinglePrec libsamplerate qtbase ] - ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.SystemConfiguration; + nativeBuildInputs = [ + pkg-config + which + cmake + ]; + buildInputs = [ + fftwSinglePrec + libsamplerate + qtbase + ] ++ lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.SystemConfiguration; - env.NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "11") "-std=c++11"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "11" + ) "-std=c++11"; dontWrapQtApps = true; diff --git a/pkgs/development/libraries/libliftoff/generic.nix b/pkgs/development/libraries/libliftoff/generic.nix index 5e846cd6eb2b48..e2998ee8f39c70 100644 --- a/pkgs/development/libraries/libliftoff/generic.nix +++ b/pkgs/development/libraries/libliftoff/generic.nix @@ -1,16 +1,24 @@ -{ lib, stdenv -, meson, pkg-config, ninja -, libdrm -, version -, src -, patches +{ + lib, + stdenv, + meson, + pkg-config, + ninja, + libdrm, + version, + src, + patches, }: stdenv.mkDerivation (finalAttrs: { pname = "libliftoff"; inherit version src patches; - nativeBuildInputs = [ meson pkg-config ninja ]; + nativeBuildInputs = [ + meson + pkg-config + ninja + ]; buildInputs = [ libdrm ]; @@ -22,9 +30,12 @@ stdenv.mkDerivation (finalAttrs: { on them, and libliftoff will pick planes for these layers if possible. ''; inherit (finalAttrs.src.meta) homepage; - changelog = "https://gitlab.freedesktop.org/emersion/libliftoff/-/tags/v${finalAttrs.version}"; - license = lib.licenses.mit; - platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ primeos Scrumplex ]; + changelog = "https://gitlab.freedesktop.org/emersion/libliftoff/-/tags/v${finalAttrs.version}"; + license = lib.licenses.mit; + platforms = lib.platforms.linux; + maintainers = with lib.maintainers; [ + primeos + Scrumplex + ]; }; }) diff --git a/pkgs/development/libraries/liblqr-1/default.nix b/pkgs/development/libraries/liblqr-1/default.nix index f2f6497b676b9d..3062a91186cc0b 100644 --- a/pkgs/development/libraries/liblqr-1/default.nix +++ b/pkgs/development/libraries/liblqr-1/default.nix @@ -1,10 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, glib, Carbon, AppKit }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + glib, + Carbon, + AppKit, +}: stdenv.mkDerivation rec { pname = "liblqr-1"; version = "0.4.2"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "carlobaldassi"; @@ -14,13 +25,19 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Carbon AppKit ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + AppKit + ]; propagatedBuildInputs = [ glib ]; meta = with lib; { homepage = "http://liblqr.wikidot.com"; description = "Seam-carving C/C++ library called Liquid Rescaling"; platforms = platforms.all; - license = with licenses; [ gpl3 lgpl3 ]; + license = with licenses; [ + gpl3 + lgpl3 + ]; }; } diff --git a/pkgs/development/libraries/libmicrohttpd/0.9.77.nix b/pkgs/development/libraries/libmicrohttpd/0.9.77.nix index 189b691e0b60e1..9099de95bd8201 100644 --- a/pkgs/development/libraries/libmicrohttpd/0.9.77.nix +++ b/pkgs/development/libraries/libmicrohttpd/0.9.77.nix @@ -1,6 +1,6 @@ { callPackage, fetchurl }: -callPackage ./generic.nix ( rec { +callPackage ./generic.nix (rec { version = "0.9.77"; src = fetchurl { diff --git a/pkgs/development/libraries/libmicrohttpd/generic.nix b/pkgs/development/libraries/libmicrohttpd/generic.nix index 45736cea1e9518..7b2743ea1ac2f9 100644 --- a/pkgs/development/libraries/libmicrohttpd/generic.nix +++ b/pkgs/development/libraries/libmicrohttpd/generic.nix @@ -1,12 +1,35 @@ -{ lib, stdenv, libgcrypt, curl, gnutls, pkg-config, libiconv, libintl, version, src, meta ? {} }: +{ + lib, + stdenv, + libgcrypt, + curl, + gnutls, + pkg-config, + libiconv, + libintl, + version, + src, + meta ? { }, +}: stdenv.mkDerivation (finalAttrs: { pname = "libmicrohttpd"; inherit version src; - outputs = [ "out" "dev" "devdoc" "info" ]; + outputs = [ + "out" + "dev" + "devdoc" + "info" + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libgcrypt curl gnutls libiconv libintl ]; + buildInputs = [ + libgcrypt + curl + gnutls + libiconv + libintl + ]; preCheck = '' # Since `localhost' can't be resolved in a chroot, work around it. @@ -16,19 +39,22 @@ stdenv.mkDerivation (finalAttrs: { # Disabled because the tests can time-out. doCheck = false; - meta = with lib; { - description = "Embeddable HTTP server library"; + meta = + with lib; + { + description = "Embeddable HTTP server library"; - longDescription = '' - GNU libmicrohttpd is a small C library that is supposed to make - it easy to run an HTTP server as part of another application. - ''; + longDescription = '' + GNU libmicrohttpd is a small C library that is supposed to make + it easy to run an HTTP server as part of another application. + ''; - license = licenses.lgpl2Plus; + license = licenses.lgpl2Plus; - homepage = "https://www.gnu.org/software/libmicrohttpd/"; + homepage = "https://www.gnu.org/software/libmicrohttpd/"; - maintainers = with maintainers; [ fpletz ]; - platforms = platforms.unix; - } // meta; + maintainers = with maintainers; [ fpletz ]; + platforms = platforms.unix; + } + // meta; }) diff --git a/pkgs/development/libraries/libmikmod/default.nix b/pkgs/development/libraries/libmikmod/default.nix index 6e3f7eee3c5784..aac1dc74aff525 100644 --- a/pkgs/development/libraries/libmikmod/default.nix +++ b/pkgs/development/libraries/libmikmod/default.nix @@ -1,9 +1,18 @@ -{ lib, stdenv, fetchurl, texinfo, alsa-lib, libpulseaudio, CoreAudio }: +{ + lib, + stdenv, + fetchurl, + texinfo, + alsa-lib, + libpulseaudio, + CoreAudio, +}: let inherit (lib) optional optionalString; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "libmikmod"; version = "3.3.11.1"; @@ -12,13 +21,17 @@ in stdenv.mkDerivation rec { sha256 = "06bdnhb0l81srdzg6gn2v2ydhhaazza7rshrcj3q8dpqr3gn97dd"; }; - buildInputs = [ texinfo ] + buildInputs = + [ texinfo ] ++ optional stdenv.hostPlatform.isLinux alsa-lib ++ optional stdenv.hostPlatform.isDarwin CoreAudio; - propagatedBuildInputs = - optional stdenv.hostPlatform.isLinux libpulseaudio; + propagatedBuildInputs = optional stdenv.hostPlatform.isLinux libpulseaudio; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; NIX_LDFLAGS = optionalString stdenv.hostPlatform.isLinux "-lasound"; @@ -29,10 +42,13 @@ in stdenv.mkDerivation rec { meta = with lib; { description = "Library for playing tracker music module files"; mainProgram = "libmikmod-config"; - homepage = "https://mikmod.shlomifish.org/"; - license = licenses.lgpl2Plus; - maintainers = with maintainers; [ astsmtl lovek323 ]; - platforms = platforms.unix; + homepage = "https://mikmod.shlomifish.org/"; + license = licenses.lgpl2Plus; + maintainers = with maintainers; [ + astsmtl + lovek323 + ]; + platforms = platforms.unix; longDescription = '' A library for playing tracker music module files supporting many formats, diff --git a/pkgs/development/libraries/libmongocrypt/default.nix b/pkgs/development/libraries/libmongocrypt/default.nix index 0c887527307fbe..5792903067d59a 100644 --- a/pkgs/development/libraries/libmongocrypt/default.nix +++ b/pkgs/development/libraries/libmongocrypt/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, mongoc -, openssl -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + mongoc, + openssl, + darwin, }: stdenv.mkDerivation rec { @@ -29,13 +30,18 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ - mongoc - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk_11_0.frameworks.Security + nativeBuildInputs = [ + cmake + pkg-config ]; + buildInputs = + [ + mongoc + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk_11_0.frameworks.Security + ]; cmakeFlags = [ # all three of these are required to use system libbson diff --git a/pkgs/development/libraries/libmusicbrainz/5.x.nix b/pkgs/development/libraries/libmusicbrainz/5.x.nix index 14a6cc16c8371a..8b6a622965c80f 100644 --- a/pkgs/development/libraries/libmusicbrainz/5.x.nix +++ b/pkgs/development/libraries/libmusicbrainz/5.x.nix @@ -1,17 +1,34 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, neon, libdiscid, libxml2, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + neon, + libdiscid, + libxml2, + pkg-config, +}: stdenv.mkDerivation rec { version = "5.1.0"; pname = "libmusicbrainz"; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ neon libdiscid libxml2 ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + neon + libdiscid + libxml2 + ]; src = fetchFromGitHub { - owner = "metabrainz"; - repo = "libmusicbrainz"; + owner = "metabrainz"; + repo = "libmusicbrainz"; sha256 = "0ah9kaf3g3iv1cps2vs1hs33nfbjfx1xscpjgxr1cg28p4ri6jhq"; - rev = "release-${version}"; + rev = "release-${version}"; }; patches = [ @@ -26,7 +43,7 @@ stdenv.mkDerivation rec { }) ]; - dontUseCmakeBuildDir=true; + dontUseCmakeBuildDir = true; meta = with lib; { homepage = "http://musicbrainz.org/doc/libmusicbrainz"; diff --git a/pkgs/development/libraries/libmusicbrainz/default.nix b/pkgs/development/libraries/libmusicbrainz/default.nix index a77d64ffddce3a..d5df1f11322277 100644 --- a/pkgs/development/libraries/libmusicbrainz/default.nix +++ b/pkgs/development/libraries/libmusicbrainz/default.nix @@ -1,11 +1,21 @@ -{ lib, stdenv, fetchurl, cmake, neon, libdiscid }: +{ + lib, + stdenv, + fetchurl, + cmake, + neon, + libdiscid, +}: stdenv.mkDerivation rec { pname = "libmusicbrainz"; version = "3.0.3"; nativeBuildInputs = [ cmake ]; - buildInputs = [ neon libdiscid ]; + buildInputs = [ + neon + libdiscid + ]; src = fetchurl { url = "ftp://ftp.musicbrainz.org/pub/musicbrainz/${pname}-${version}.tar.gz"; diff --git a/pkgs/development/libraries/libopenshot-audio/default.nix b/pkgs/development/libraries/libopenshot-audio/default.nix index 9dfa5e09eddb11..4a63de87e643af 100644 --- a/pkgs/development/libraries/libopenshot-audio/default.nix +++ b/pkgs/development/libraries/libopenshot-audio/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, alsa-lib -, cmake -, doxygen -, libX11 -, libXcursor -, libXext -, libXft -, libXinerama -, libXrandr -, pkg-config -, zlib -, Accelerate -, AGL -, Cocoa -, Foundation +{ + lib, + stdenv, + fetchFromGitHub, + alsa-lib, + cmake, + doxygen, + libX11, + libXcursor, + libXext, + libXft, + libXinerama, + libXrandr, + pkg-config, + zlib, + Accelerate, + AGL, + Cocoa, + Foundation, }: stdenv.mkDerivation (finalAttrs: { @@ -40,22 +41,29 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - ] ++ (if stdenv.hostPlatform.isDarwin then [ - Accelerate - AGL - Cocoa - Foundation - zlib - ] else [ - libX11 - libXcursor - libXext - libXft - libXinerama - libXrandr - ]); + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + ] + ++ ( + if stdenv.hostPlatform.isDarwin then + [ + Accelerate + AGL + Cocoa + Foundation + zlib + ] + else + [ + libX11 + libXcursor + libXext + libXft + libXinerama + libXrandr + ] + ); strictDeps = true; diff --git a/pkgs/development/libraries/libopenshot/default.nix b/pkgs/development/libraries/libopenshot/default.nix index 564ad3ac911a92..478e5e50ade89a 100644 --- a/pkgs/development/libraries/libopenshot/default.nix +++ b/pkgs/development/libraries/libopenshot/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, alsa-lib -, cmake -, cppzmq -, doxygen -, ffmpeg -, imagemagick -, jsoncpp -, libopenshot-audio -, llvmPackages -, pkg-config -, python3 -, qtbase -, qtmultimedia -, swig -, zeromq +{ + lib, + stdenv, + fetchFromGitHub, + alsa-lib, + cmake, + cppzmq, + doxygen, + ffmpeg, + imagemagick, + jsoncpp, + libopenshot-audio, + llvmPackages, + pkg-config, + python3, + qtbase, + qtmultimedia, + swig, + zeromq, }: stdenv.mkDerivation (finalAttrs: { @@ -41,21 +42,24 @@ stdenv.mkDerivation (finalAttrs: { swig ]; - buildInputs = [ - cppzmq - ffmpeg - imagemagick - jsoncpp - libopenshot-audio - python3 - qtbase - qtmultimedia - zeromq - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - llvmPackages.openmp - ]; + buildInputs = + [ + cppzmq + ffmpeg + imagemagick + jsoncpp + libopenshot-audio + python3 + qtbase + qtmultimedia + zeromq + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + llvmPackages.openmp + ]; strictDeps = true; diff --git a/pkgs/development/libraries/libosmscout/default.nix b/pkgs/development/libraries/libosmscout/default.nix index c33b8881a03afc..5df2831aa051fb 100644 --- a/pkgs/development/libraries/libosmscout/default.nix +++ b/pkgs/development/libraries/libosmscout/default.nix @@ -1,5 +1,14 @@ -{ lib, mkDerivation, fetchFromGitHub, fetchpatch, cmake, pkg-config -, marisa, qttools, qtlocation }: +{ + lib, + mkDerivation, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + marisa, + qttools, + qtlocation, +}: mkDerivation rec { pname = "libosmscout"; @@ -24,8 +33,15 @@ mkDerivation rec { cmakeFlags = [ "-DOSMSCOUT_BUILD_TESTS=OFF" ]; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ marisa qttools qtlocation ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + marisa + qttools + qtlocation + ]; meta = with lib; { description = "Simple, high-level interfaces for offline location and POI lokup, rendering and routing functionalities based on OpenStreetMap (OSM) data"; diff --git a/pkgs/development/libraries/libpeas/default.nix b/pkgs/development/libraries/libpeas/default.nix index 71996ce7f81be9..df0398797df0d3 100644 --- a/pkgs/development/libraries/libpeas/default.nix +++ b/pkgs/development/libraries/libpeas/default.nix @@ -1,26 +1,31 @@ -{ stdenv -, lib -, fetchurl -, substituteAll -, meson -, ninja -, pkg-config -, gettext -, gi-docgen -, gnome -, glib -, gtk3 -, gobject-introspection -, python3 -, ncurses -, wrapGAppsHook3 +{ + stdenv, + lib, + fetchurl, + substituteAll, + meson, + ninja, + pkg-config, + gettext, + gi-docgen, + gnome, + glib, + gtk3, + gobject-introspection, + python3, + ncurses, + wrapGAppsHook3, }: stdenv.mkDerivation rec { pname = "libpeas"; version = "1.36.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/development/libraries/libpng/default.nix b/pkgs/development/libraries/libpng/default.nix index 57b75a949b7d62..9e508efcec84ec 100644 --- a/pkgs/development/libraries/libpng/default.nix +++ b/pkgs/development/libraries/libpng/default.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchurl, zlib, apngSupport ? true -, testers +{ + lib, + stdenv, + fetchurl, + zlib, + apngSupport ? true, + testers, }: assert zlib != null; @@ -12,7 +17,8 @@ let }; whenPatched = lib.optionalString apngSupport; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "libpng" + whenPatched "-apng"; version = "1.6.43"; @@ -20,13 +26,18 @@ in stdenv.mkDerivation (finalAttrs: { url = "mirror://sourceforge/libpng/libpng-${finalAttrs.version}.tar.xz"; hash = "sha256-alygZSOSotfJ2yrltAIQhDwLvAgcvUEIJasAzFnxSmw="; }; - postPatch = whenPatched "gunzip < ${patch_src} | patch -Np1" - + lib.optionalString stdenv.hostPlatform.isFreeBSD '' + postPatch = + whenPatched "gunzip < ${patch_src} | patch -Np1" + + lib.optionalString stdenv.hostPlatform.isFreeBSD '' - sed -i 1i'int feenableexcept(int __mask);' contrib/libtests/pngvalid.c - ''; + sed -i 1i'int feenableexcept(int __mask);' contrib/libtests/pngvalid.c + ''; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; outputBin = "dev"; propagatedBuildInputs = [ zlib ]; @@ -40,11 +51,15 @@ in stdenv.mkDerivation (finalAttrs: { }; meta = with lib; { - description = "Official reference implementation for the PNG file format" + whenPatched " with animation patch"; + description = + "Official reference implementation for the PNG file format" + whenPatched " with animation patch"; homepage = "http://www.libpng.org/pub/png/libpng.html"; changelog = "https://github.com/pnggroup/libpng/blob/v${finalAttrs.version}/CHANGES"; license = licenses.libpng2; - pkgConfigModules = [ "libpng" "libpng16" ]; + pkgConfigModules = [ + "libpng" + "libpng16" + ]; platforms = platforms.all; maintainers = with maintainers; [ vcunat ]; }; diff --git a/pkgs/development/libraries/libproxy/default.nix b/pkgs/development/libraries/libproxy/default.nix index 436b4d7ecfbe75..bb9d490b6fc719 100644 --- a/pkgs/development/libraries/libproxy/default.nix +++ b/pkgs/development/libraries/libproxy/default.nix @@ -1,28 +1,33 @@ -{ lib -, _experimental-update-script-combinators -, curl -, darwin -, duktape -, fetchFromGitHub -, gi-docgen -, gitUpdater -, glib -, gobject-introspection -, gsettings-desktop-schemas -, makeHardcodeGsettingsPatch -, meson -, ninja -, pkg-config -, stdenv -, substituteAll -, vala +{ + lib, + _experimental-update-script-combinators, + curl, + darwin, + duktape, + fetchFromGitHub, + gi-docgen, + gitUpdater, + glib, + gobject-introspection, + gsettings-desktop-schemas, + makeHardcodeGsettingsPatch, + meson, + ninja, + pkg-config, + stdenv, + substituteAll, + vala, }: stdenv.mkDerivation (finalAttrs: { pname = "libproxy"; version = "0.5.9"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitHub { owner = "libproxy"; @@ -31,20 +36,21 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-Z70TjLk5zulyYMAK+uMDhpsdvLa6m25pY8jahUA6ASE="; }; - patches = [ - ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - # Disable schema presence detection, it would fail because it cannot be autopatched, - # and it will be hardcoded by the next patch anyway. - ./skip-gsettings-detection.patch + patches = + [ + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + # Disable schema presence detection, it would fail because it cannot be autopatched, + # and it will be hardcoded by the next patch anyway. + ./skip-gsettings-detection.patch - # Hardcode path to Settings schemas for GNOME & related desktops. - # Otherwise every app using libproxy would need to be wrapped individually. - (substituteAll { - src = ./hardcode-gsettings.patch; - gds = glib.getSchemaPath gsettings-desktop-schemas; - }) - ]; + # Hardcode path to Settings schemas for GNOME & related desktops. + # Otherwise every app using libproxy would need to be wrapped individually. + (substituteAll { + src = ./hardcode-gsettings.patch; + gds = glib.getSchemaPath gsettings-desktop-schemas; + }) + ]; postPatch = '' # Fix running script that will try to install git hooks. @@ -68,23 +74,31 @@ stdenv.mkDerivation (finalAttrs: { vala ]; - buildInputs = [ - curl - duktape - ] ++ (if stdenv.hostPlatform.isDarwin then (with darwin.apple_sdk.frameworks; [ - Foundation - ]) else [ - glib - gsettings-desktop-schemas - ]); + buildInputs = + [ + curl + duktape + ] + ++ ( + if stdenv.hostPlatform.isDarwin then + (with darwin.apple_sdk.frameworks; [ + Foundation + ]) + else + [ + glib + gsettings-desktop-schemas + ] + ); - mesonFlags = [ - # Prevent installing commit hook. - "-Drelease=true" - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-Dconfig-gnome=false" - ]; + mesonFlags = + [ + # Prevent installing commit hook. + "-Drelease=true" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-Dconfig-gnome=false" + ]; doCheck = !stdenv.hostPlatform.isDarwin; diff --git a/pkgs/development/libraries/libpulsar/default.nix b/pkgs/development/libraries/libpulsar/default.nix index f083ef04145703..3aec246ce32802 100644 --- a/pkgs/development/libraries/libpulsar/default.nix +++ b/pkgs/development/libraries/libpulsar/default.nix @@ -1,25 +1,26 @@ -{ lib -, asioSupport ? true -, asio -, boost180 -, log4cxxSupport ? false -, log4cxx -, snappySupport ? false -, snappy -, zlibSupport ? true -, zlib -, zstdSupport ? true -, zstd -, gtest -, gtestSupport ? false -, cmake -, curl -, fetchFromGitHub -, protobuf -, jsoncpp -, openssl -, pkg-config -, stdenv +{ + lib, + asioSupport ? true, + asio, + boost180, + log4cxxSupport ? false, + log4cxx, + snappySupport ? false, + snappy, + zlibSupport ? true, + zlib, + zstdSupport ? true, + zstd, + gtest, + gtestSupport ? false, + cmake, + curl, + fetchFromGitHub, + protobuf, + jsoncpp, + openssl, + pkg-config, + stdenv, }: let @@ -35,7 +36,8 @@ let */ enableCmakeFeature = p: if (p == null || p == false) then "OFF" else "ON"; - defaultOptionals = [ protobuf ] + defaultOptionals = + [ protobuf ] ++ lib.optional snappySupport snappy.dev ++ lib.optional zlibSupport zlib ++ lib.optional zstdSupport zstd @@ -55,12 +57,19 @@ stdenv.mkDerivation (finalAttrs: rec { hash = "sha256-P1LhUH7V3EtWBXwPHQdN11mCjuyUyVdrtZsUItvC8xU="; }; - nativeBuildInputs = [ cmake pkg-config ] + nativeBuildInputs = + [ + cmake + pkg-config + ] ++ defaultOptionals ++ lib.optional gtestSupport gtest.dev; - buildInputs = [ jsoncpp openssl curl ] - ++ defaultOptionals; + buildInputs = [ + jsoncpp + openssl + curl + ] ++ defaultOptionals; cmakeFlags = [ "-DBUILD_TESTS=${enableCmakeFeature gtestSupport}" @@ -86,6 +95,9 @@ stdenv.mkDerivation (finalAttrs: rec { changelog = "https://github.com/apache/pulsar-client-cpp/releases/tag/v${version}"; platforms = platforms.all; license = licenses.asl20; - maintainers = with maintainers; [ corbanr gaelreyrol ]; + maintainers = with maintainers; [ + corbanr + gaelreyrol + ]; }; }) diff --git a/pkgs/development/libraries/libqaccessibilityclient/default.nix b/pkgs/development/libraries/libqaccessibilityclient/default.nix index 0d518a48308dec..beb1442951fa8a 100644 --- a/pkgs/development/libraries/libqaccessibilityclient/default.nix +++ b/pkgs/development/libraries/libqaccessibilityclient/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, cmake, qtbase, extra-cmake-modules }: +{ + lib, + stdenv, + fetchurl, + cmake, + qtbase, + extra-cmake-modules, +}: stdenv.mkDerivation rec { pname = "libqaccessibilityclient"; @@ -9,11 +16,17 @@ stdenv.mkDerivation rec { hash = "sha256-TFDESGItycUEHtENp9h7Pk5xzLSdSDGoSSEdQjxfXTM="; }; - nativeBuildInputs = [ cmake extra-cmake-modules ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; buildInputs = [ qtbase ]; - cmakeFlags = ["-DQT_MAJOR_VERSION=${lib.versions.major qtbase.version}"]; + cmakeFlags = [ "-DQT_MAJOR_VERSION=${lib.versions.major qtbase.version}" ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; dontWrapQtApps = true; @@ -21,7 +34,10 @@ stdenv.mkDerivation rec { description = "Accessibilty tools helper library, used e.g. by screen readers"; homepage = "https://github.com/KDE/libqaccessibilityclient"; maintainers = with maintainers; [ artturin ]; - license = with licenses; [ lgpl3Only /* or */ lgpl21Only ]; + license = with licenses; [ + lgpl3Only # or + lgpl21Only + ]; platforms = platforms.linux; }; } diff --git a/pkgs/development/libraries/libqofono/default.nix b/pkgs/development/libraries/libqofono/default.nix index f337de228a3e47..b79252cbbb5c42 100644 --- a/pkgs/development/libraries/libqofono/default.nix +++ b/pkgs/development/libraries/libqofono/default.nix @@ -1,12 +1,13 @@ -{ lib -, substituteAll -, mkDerivation -, fetchFromGitHub -, gitUpdater -, mobile-broadband-provider-info -, qmake -, qtbase -, qtdeclarative +{ + lib, + substituteAll, + mkDerivation, + fetchFromGitHub, + gitUpdater, + mobile-broadband-provider-info, + qmake, + qtbase, + qtdeclarative, }: mkDerivation rec { diff --git a/pkgs/development/libraries/libqtdbusmock/default.nix b/pkgs/development/libraries/libqtdbusmock/default.nix index 44532a0b9dae36..c5fcb384530f28 100644 --- a/pkgs/development/libraries/libqtdbusmock/default.nix +++ b/pkgs/development/libraries/libqtdbusmock/default.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitLab -, testers -, cmake -, cmake-extras -, dbus -, dbus-test-runner -, gtest -, libqtdbustest -, networkmanager -, pkg-config -, procps -, python3 -, qtbase +{ + stdenv, + lib, + fetchFromGitLab, + testers, + cmake, + cmake-extras, + dbus, + dbus-test-runner, + gtest, + libqtdbustest, + networkmanager, + pkg-config, + procps, + python3, + qtbase, }: stdenv.mkDerivation (finalAttrs: { @@ -26,13 +27,15 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-hVw2HnIHlA7vvt0Sr6F2qVhvBZ33aCeqb9vgbu3rgBo="; }; - postPatch = '' - # Workaround for "error: expected unqualified-id before 'public'" on "**signals" - sed -i -e '/add_definitions/a -DQT_NO_KEYWORDS' CMakeLists.txt - '' + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' - # Don't build tests when we're not running them - sed -i -e '/add_subdirectory(tests)/d' CMakeLists.txt - ''; + postPatch = + '' + # Workaround for "error: expected unqualified-id before 'public'" on "**signals" + sed -i -e '/add_definitions/a -DQT_NO_KEYWORDS' CMakeLists.txt + '' + + lib.optionalString (!finalAttrs.finalPackage.doCheck) '' + # Don't build tests when we're not running them + sed -i -e '/add_subdirectory(tests)/d' CMakeLists.txt + ''; strictDeps = true; @@ -52,9 +55,11 @@ stdenv.mkDerivation (finalAttrs: { dbus dbus-test-runner procps - (python3.withPackages (ps: with ps; [ - python-dbusmock - ])) + (python3.withPackages ( + ps: with ps; [ + python-dbusmock + ] + )) ]; checkInputs = [ diff --git a/pkgs/development/libraries/libqtdbustest/default.nix b/pkgs/development/libraries/libqtdbustest/default.nix index ab07a6577b833e..756fa756c39660 100644 --- a/pkgs/development/libraries/libqtdbustest/default.nix +++ b/pkgs/development/libraries/libqtdbustest/default.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, testers -, cmake -, cmake-extras -, dbus -, dbus-test-runner -, gtest -, pkg-config -, procps -, python3 -, qtbase +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + testers, + cmake, + cmake-extras, + dbus, + dbus-test-runner, + gtest, + pkg-config, + procps, + python3, + qtbase, }: stdenv.mkDerivation (finalAttrs: { @@ -45,7 +46,7 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - postPatch = lib.optionalString (!finalAttrs.finalPackage.doCheck) '' + postPatch = lib.optionalString (!finalAttrs.finalPackage.doCheck) '' # Don't build tests when we're not running them sed -i -e '/add_subdirectory(tests)/d' CMakeLists.txt ''; @@ -64,9 +65,11 @@ stdenv.mkDerivation (finalAttrs: { dbus dbus-test-runner procps - (python3.withPackages (ps: with ps; [ - python-dbusmock - ])) + (python3.withPackages ( + ps: with ps; [ + python-dbusmock + ] + )) ]; checkInputs = [ diff --git a/pkgs/development/libraries/libquotient/default.nix b/pkgs/development/libraries/libquotient/default.nix index 916fa4a3847e7c..fcec989390b8fd 100644 --- a/pkgs/development/libraries/libquotient/default.nix +++ b/pkgs/development/libraries/libquotient/default.nix @@ -1,12 +1,26 @@ -{ stdenv, lib, fetchFromGitHub, cmake, olm, openssl, qtbase, qtmultimedia, qtkeychain }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + olm, + openssl, + qtbase, + qtmultimedia, + qtkeychain, +}: let isQt6 = lib.versions.major qtbase.version == "6"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "libquotient"; version = "0.8.2"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "quotient-im"; @@ -17,7 +31,13 @@ in stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - propagatedBuildInputs = [ qtbase qtkeychain olm openssl qtmultimedia ]; + propagatedBuildInputs = [ + qtbase + qtkeychain + olm + openssl + qtmultimedia + ]; cmakeFlags = [ "-DQuotient_ENABLE_E2EE=ON" @@ -42,6 +62,9 @@ in stdenv.mkDerivation rec { description = "Qt5/Qt6 library to write cross-platform clients for Matrix"; homepage = "https://quotient-im.github.io/libQuotient/"; license = licenses.lgpl21; - maintainers = with maintainers; [ colemickens matthiasbeyer ]; + maintainers = with maintainers; [ + colemickens + matthiasbeyer + ]; }; } diff --git a/pkgs/development/libraries/librasterlite2/default.nix b/pkgs/development/libraries/librasterlite2/default.nix index d933baafdfff03..f5a2ed24d2bc3b 100644 --- a/pkgs/development/libraries/librasterlite2/default.nix +++ b/pkgs/development/libraries/librasterlite2/default.nix @@ -1,31 +1,32 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, validatePkgConfig -, cairo -, curl -, fontconfig -, freetype -, freexl -, geos -, giflib -, libgeotiff -, libjpeg -, libpng -, librttopo -, libspatialite -, libtiff -, libwebp -, libxml2 -, lz4 -, minizip -, openjpeg -, pixman -, proj -, sqlite -, zstd -, ApplicationServices +{ + lib, + stdenv, + fetchurl, + pkg-config, + validatePkgConfig, + cairo, + curl, + fontconfig, + freetype, + freexl, + geos, + giflib, + libgeotiff, + libjpeg, + libpng, + librttopo, + libspatialite, + libtiff, + libwebp, + libxml2, + lz4, + minizip, + openjpeg, + pixman, + proj, + sqlite, + zstd, + ApplicationServices, }: stdenv.mkDerivation rec { @@ -83,7 +84,11 @@ stdenv.mkDerivation rec { description = "Advanced library supporting raster handling methods"; homepage = "https://www.gaia-gis.it/fossil/librasterlite2"; # They allow any of these - license = with licenses; [ gpl2Plus lgpl21Plus mpl11 ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + mpl11 + ]; platforms = platforms.unix; maintainers = with maintainers; [ sikmir ]; }; diff --git a/pkgs/development/libraries/librdf/raptor.nix b/pkgs/development/libraries/librdf/raptor.nix index 2afdb5d32beded..1225af7f67e424 100644 --- a/pkgs/development/libraries/librdf/raptor.nix +++ b/pkgs/development/libraries/librdf/raptor.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libxml2, curl }: +{ + lib, + stdenv, + fetchurl, + libxml2, + curl, +}: stdenv.mkDerivation rec { pname = "raptor"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "db3172d6f3c432623ed87d7d609161973d2f7098e3d2233d0702fbcc22cfd8ca"; }; - buildInputs = [ libxml2 curl ]; + buildInputs = [ + libxml2 + curl + ]; preBuild = '' sed -e '/curl\/types/d' -i src/*.c src/*.h @@ -18,7 +27,10 @@ stdenv.mkDerivation rec { meta = { description = "RDF Parser Toolkit"; homepage = "https://librdf.org/raptor"; - license = with lib.licenses; [ lgpl21 asl20 ]; + license = with lib.licenses; [ + lgpl21 + asl20 + ]; maintainers = [ lib.maintainers.marcweber ]; platforms = lib.platforms.linux; }; diff --git a/pkgs/development/libraries/librdf/raptor2.nix b/pkgs/development/libraries/librdf/raptor2.nix index eace8af8156cf9..baad5320b2508e 100644 --- a/pkgs/development/libraries/librdf/raptor2.nix +++ b/pkgs/development/libraries/librdf/raptor2.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, libxml2 -, curl -, libxslt -, pkg-config -, cmake -, fetchFromGitHub -, perl -, bison -, flex -, fetchpatch -, static ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + libxml2, + curl, + libxslt, + pkg-config, + cmake, + fetchFromGitHub, + perl, + bison, + flex, + fetchpatch, + static ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { pname = "raptor2"; version = "2.0.16"; - underscoredVersion = lib.strings.replaceStrings ["."] ["_"] version; + underscoredVersion = lib.strings.replaceStrings [ "." ] [ "_" ] version; src = fetchFromGitHub { owner = "dajobe"; @@ -40,7 +41,13 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config cmake perl bison flex ]; + nativeBuildInputs = [ + pkg-config + cmake + perl + bison + flex + ]; buildInputs = [ curl libxml2 @@ -51,7 +58,10 @@ stdenv.mkDerivation rec { description = "RDF Parser Toolkit"; mainProgram = "rapper"; homepage = "https://librdf.org/raptor"; - license = with lib.licenses; [ lgpl21 asl20 ]; + license = with lib.licenses; [ + lgpl21 + asl20 + ]; maintainers = with lib.maintainers; [ marcweber ]; platforms = lib.platforms.unix; }; diff --git a/pkgs/development/libraries/librdf/rasqal.nix b/pkgs/development/libraries/librdf/rasqal.nix index 8d935bb0853056..f8af85bfb50eb0 100644 --- a/pkgs/development/libraries/librdf/rasqal.nix +++ b/pkgs/development/libraries/librdf/rasqal.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, librdf_raptor2, gmp, pkg-config, pcre, libxml2, perl }: +{ + lib, + stdenv, + fetchurl, + librdf_raptor2, + gmp, + pkg-config, + pcre, + libxml2, + perl, +}: stdenv.mkDerivation rec { pname = "rasqal"; @@ -11,7 +21,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gmp pcre libxml2 ]; + buildInputs = [ + gmp + pcre + libxml2 + ]; propagatedBuildInputs = [ librdf_raptor2 ]; @@ -24,7 +38,10 @@ stdenv.mkDerivation rec { meta = { description = "Library that handles Resource Description Framework (RDF)"; homepage = "https://librdf.org/rasqal"; - license = with lib.licenses; [ lgpl21 asl20 ]; + license = with lib.licenses; [ + lgpl21 + asl20 + ]; maintainers = with lib.maintainers; [ marcweber ]; platforms = lib.platforms.unix; }; diff --git a/pkgs/development/libraries/librdf/redland.nix b/pkgs/development/libraries/librdf/redland.nix index 252a5037f77cf7..ceac892f993441 100644 --- a/pkgs/development/libraries/librdf/redland.nix +++ b/pkgs/development/libraries/librdf/redland.nix @@ -1,9 +1,24 @@ -{ lib, stdenv, fetchurl, pkg-config, openssl, libxslt, perl -, curl, pcre, libxml2, librdf_rasqal, gmp -, libmysqlclient, withMysql ? false -, postgresql, withPostgresql ? false -, sqlite, withSqlite ? true -, db, withBdb ? false +{ + lib, + stdenv, + fetchurl, + pkg-config, + openssl, + libxslt, + perl, + curl, + pcre, + libxml2, + librdf_rasqal, + gmp, + libmysqlclient, + withMysql ? false, + postgresql, + withPostgresql ? false, + sqlite, + withSqlite ? true, + db, + withBdb ? false, }: stdenv.mkDerivation rec { @@ -15,9 +30,20 @@ stdenv.mkDerivation rec { sha256 = "de1847f7b59021c16bdc72abb4d8e2d9187cd6124d69156f3326dd34ee043681"; }; - nativeBuildInputs = [ perl pkg-config ]; + nativeBuildInputs = [ + perl + pkg-config + ]; - buildInputs = [ openssl libxslt curl pcre libxml2 gmp ] + buildInputs = + [ + openssl + libxslt + curl + pcre + libxml2 + gmp + ] ++ lib.optional withMysql libmysqlclient ++ lib.optional withSqlite sqlite ++ lib.optional withPostgresql postgresql diff --git a/pkgs/development/libraries/libressl/default.nix b/pkgs/development/libraries/libressl/default.nix index 0924285cae879e..9e0492c802b323 100644 --- a/pkgs/development/libraries/libressl/default.nix +++ b/pkgs/development/libraries/libressl/default.nix @@ -1,105 +1,124 @@ -{ stdenv -, fetchurl -, lib -, cmake -, cacert -, fetchpatch -, buildShared ? !stdenv.hostPlatform.isStatic +{ + stdenv, + fetchurl, + lib, + cmake, + cacert, + fetchpatch, + buildShared ? !stdenv.hostPlatform.isStatic, }: let - ldLibPathEnvName = if stdenv.hostPlatform.isDarwin - then "DYLD_LIBRARY_PATH" - else "LD_LIBRARY_PATH"; + ldLibPathEnvName = if stdenv.hostPlatform.isDarwin then "DYLD_LIBRARY_PATH" else "LD_LIBRARY_PATH"; generic = - { version - , hash - , patches ? [] - , knownVulnerabilities ? [] - }: stdenv.mkDerivation rec - { - pname = "libressl"; - inherit version; - - src = fetchurl { - url = "mirror://openbsd/LibreSSL/${pname}-${version}.tar.gz"; - inherit hash; + { + version, + hash, + patches ? [ ], + knownVulnerabilities ? [ ], + }: + stdenv.mkDerivation rec { + pname = "libressl"; + inherit version; + + src = fetchurl { + url = "mirror://openbsd/LibreSSL/${pname}-${version}.tar.gz"; + inherit hash; + }; + + nativeBuildInputs = [ cmake ]; + + cmakeFlags = [ + "-DENABLE_NC=ON" + # Ensure that the output libraries do not require an executable stack. + # Without this define, assembly files in libcrypto do not include a + # .note.GNU-stack section, and if that section is missing from any object, + # the linker will make the stack executable. + "-DCMAKE_C_FLAGS=-DHAVE_GNU_STACK" + # libressl will append this to the regular prefix for libdir + "-DCMAKE_INSTALL_LIBDIR=lib" + ] ++ lib.optional buildShared "-DBUILD_SHARED_LIBS=ON"; + + # The autoconf build is broken as of 2.9.1, resulting in the following error: + # libressl-2.9.1/tls/.libs/libtls.a', needed by 'handshake_table'. + # Fortunately LibreSSL provides a CMake build as well, so opt for CMake by + # removing ./configure pre-config. + preConfigure = '' + rm configure + substituteInPlace CMakeLists.txt \ + --replace 'exec_prefix \''${prefix}' "exec_prefix ${placeholder "bin"}" \ + --replace 'libdir \''${exec_prefix}' 'libdir \''${prefix}' + ''; + + inherit patches; + + # Since 2.9.x the default location can't be configured from the build using + # DEFAULT_CA_FILE anymore, instead we have to patch the default value. + postPatch = '' + patchShebangs tests/ + ${lib.optionalString (lib.versionAtLeast version "2.9.2") '' + substituteInPlace ./tls/tls_config.c --replace '"/etc/ssl/cert.pem"' '"${cacert}/etc/ssl/certs/ca-bundle.crt"' + ''} + ''; + + doCheck = !(stdenv.hostPlatform.isPower64 || stdenv.hostPlatform.isRiscV); + preCheck = '' + export PREVIOUS_${ldLibPathEnvName}=$${ldLibPathEnvName} + export ${ldLibPathEnvName}="$${ldLibPathEnvName}:$(realpath tls/):$(realpath ssl/):$(realpath crypto/)" + ''; + postCheck = '' + export ${ldLibPathEnvName}=$PREVIOUS_${ldLibPathEnvName} + ''; + + outputs = [ + "bin" + "dev" + "out" + "man" + "nc" + ]; + + postFixup = '' + moveToOutput "bin/nc" "$nc" + moveToOutput "bin/openssl" "$bin" + moveToOutput "bin/ocspcheck" "$bin" + moveToOutput "share/man/man1/nc.1.gz" "$nc" + ''; + + meta = with lib; { + description = "Free TLS/SSL implementation"; + homepage = "https://www.libressl.org"; + license = with licenses; [ + publicDomain + bsdOriginal + bsd0 + bsd3 + gpl3 + isc + openssl + ]; + platforms = platforms.all; + maintainers = with maintainers; [ + thoughtpolice + fpletz + ]; + inherit knownVulnerabilities; + + # OpenBSD believes that PowerPC should be always-big-endian; + # this assumption seems to have propagated into recent + # releases of libressl. Since libressl is aliased to many + # other packages (e.g. netcat) it's important to fail early + # here, otherwise it's very difficult to figure out why + # libressl is getting dragged into a failing build. + badPlatforms = with lib.systems.inspect.patterns; [ + (lib.recursiveUpdate isPower64 isLittleEndian) + ]; + }; }; - nativeBuildInputs = [ cmake ]; - - cmakeFlags = [ - "-DENABLE_NC=ON" - # Ensure that the output libraries do not require an executable stack. - # Without this define, assembly files in libcrypto do not include a - # .note.GNU-stack section, and if that section is missing from any object, - # the linker will make the stack executable. - "-DCMAKE_C_FLAGS=-DHAVE_GNU_STACK" - # libressl will append this to the regular prefix for libdir - "-DCMAKE_INSTALL_LIBDIR=lib" - ] ++ lib.optional buildShared "-DBUILD_SHARED_LIBS=ON"; - - # The autoconf build is broken as of 2.9.1, resulting in the following error: - # libressl-2.9.1/tls/.libs/libtls.a', needed by 'handshake_table'. - # Fortunately LibreSSL provides a CMake build as well, so opt for CMake by - # removing ./configure pre-config. - preConfigure = '' - rm configure - substituteInPlace CMakeLists.txt \ - --replace 'exec_prefix \''${prefix}' "exec_prefix ${placeholder "bin"}" \ - --replace 'libdir \''${exec_prefix}' 'libdir \''${prefix}' - ''; - - inherit patches; - - # Since 2.9.x the default location can't be configured from the build using - # DEFAULT_CA_FILE anymore, instead we have to patch the default value. - postPatch = '' - patchShebangs tests/ - ${lib.optionalString (lib.versionAtLeast version "2.9.2") '' - substituteInPlace ./tls/tls_config.c --replace '"/etc/ssl/cert.pem"' '"${cacert}/etc/ssl/certs/ca-bundle.crt"' - ''} - ''; - - doCheck = !(stdenv.hostPlatform.isPower64 || stdenv.hostPlatform.isRiscV); - preCheck = '' - export PREVIOUS_${ldLibPathEnvName}=$${ldLibPathEnvName} - export ${ldLibPathEnvName}="$${ldLibPathEnvName}:$(realpath tls/):$(realpath ssl/):$(realpath crypto/)" - ''; - postCheck = '' - export ${ldLibPathEnvName}=$PREVIOUS_${ldLibPathEnvName} - ''; - - outputs = [ "bin" "dev" "out" "man" "nc" ]; - - postFixup = '' - moveToOutput "bin/nc" "$nc" - moveToOutput "bin/openssl" "$bin" - moveToOutput "bin/ocspcheck" "$bin" - moveToOutput "share/man/man1/nc.1.gz" "$nc" - ''; - - meta = with lib; { - description = "Free TLS/SSL implementation"; - homepage = "https://www.libressl.org"; - license = with licenses; [ publicDomain bsdOriginal bsd0 bsd3 gpl3 isc openssl ]; - platforms = platforms.all; - maintainers = with maintainers; [ thoughtpolice fpletz ]; - inherit knownVulnerabilities; - - # OpenBSD believes that PowerPC should be always-big-endian; - # this assumption seems to have propagated into recent - # releases of libressl. Since libressl is aliased to many - # other packages (e.g. netcat) it's important to fail early - # here, otherwise it's very difficult to figure out why - # libressl is getting dragged into a failing build. - badPlatforms = with lib.systems.inspect.patterns; - [ (lib.recursiveUpdate isPower64 isLittleEndian) ]; - }; - }; - -in { +in +{ libressl_3_6 = generic { version = "3.6.3"; hash = "sha256-h7G7426e7I0K5fBMg9NrLFsOWBeEx+sIFwJe0p6t6jc="; diff --git a/pkgs/development/libraries/librest/1.0.nix b/pkgs/development/libraries/librest/1.0.nix index eff390cb2031a8..4024ecd8a88437 100644 --- a/pkgs/development/libraries/librest/1.0.nix +++ b/pkgs/development/libraries/librest/1.0.nix @@ -1,24 +1,29 @@ -{ lib -, stdenv -, fetchpatch -, fetchurl -, meson -, ninja -, pkg-config -, gi-docgen -, glib -, json-glib -, libsoup_3 -, libxml2 -, gobject-introspection -, gnome +{ + lib, + stdenv, + fetchpatch, + fetchurl, + meson, + ninja, + pkg-config, + gi-docgen, + glib, + json-glib, + libsoup_3, + libxml2, + gobject-introspection, + gnome, }: stdenv.mkDerivation rec { pname = "rest"; version = "0.9.1"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/development/libraries/librest/default.nix b/pkgs/development/libraries/librest/default.nix index 22e5309591058b..c932f59d0d1279 100644 --- a/pkgs/development/libraries/librest/default.nix +++ b/pkgs/development/libraries/librest/default.nix @@ -1,36 +1,43 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, glib -, libsoup_2_4 -, libxml2 -, gobject-introspection -, gtk-doc -, docbook-xsl-nons -, docbook_xml_dtd_412 -, gnome +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + libsoup_2_4, + libxml2, + gobject-introspection, + gtk-doc, + docbook-xsl-nons, + docbook_xml_dtd_412, + gnome, }: stdenv.mkDerivation rec { pname = "rest"; version = "0.8.1"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; sha256 = "0513aad38e5d3cedd4ae3c551634e3be1b9baaa79775e53b2dba9456f15b01c9"; }; - nativeBuildInputs = [ - pkg-config - gobject-introspection - ] ++ lib.optionals (stdenv.hostPlatform == stdenv.buildPlatform) [ - gtk-doc - docbook-xsl-nons - docbook_xml_dtd_412 - ]; + nativeBuildInputs = + [ + pkg-config + gobject-introspection + ] + ++ lib.optionals (stdenv.hostPlatform == stdenv.buildPlatform) [ + gtk-doc + docbook-xsl-nons + docbook_xml_dtd_412 + ]; propagatedBuildInputs = [ glib diff --git a/pkgs/development/libraries/librsb/default.nix b/pkgs/development/libraries/librsb/default.nix index 4a995cbbe89dbc..ee2258597e9715 100644 --- a/pkgs/development/libraries/librsb/default.nix +++ b/pkgs/development/libraries/librsb/default.nix @@ -1,17 +1,23 @@ -{ lib, stdenv, fetchurl -, gfortran -, pkg-config, libtool -, m4, gnum4 -, file -# Memory Hierarchy (End-user can provide this.) -, memHierarchy ? "" -# Headers/Libraries -, blas, zlib -# RPC headers (rpc/xdr.h) -, openmpi -, help2man -, doxygen -, octave +{ + lib, + stdenv, + fetchurl, + gfortran, + pkg-config, + libtool, + m4, + gnum4, + file, + # Memory Hierarchy (End-user can provide this.) + memHierarchy ? "", + # Headers/Libraries + blas, + zlib, + # RPC headers (rpc/xdr.h) + openmpi, + help2man, + doxygen, + octave, }: stdenv.mkDerivation rec { @@ -39,17 +45,26 @@ stdenv.mkDerivation rec { ]; # Ensure C/Fortran code is position-independent. - env.NIX_CFLAGS_COMPILE = toString [ "-fPIC" "-Ofast" ]; - FCFLAGS = [ "-fPIC" "-Ofast" ]; + env.NIX_CFLAGS_COMPILE = toString [ + "-fPIC" + "-Ofast" + ]; + FCFLAGS = [ + "-fPIC" + "-Ofast" + ]; enableParallelBuilding = true; nativeBuildInputs = [ gfortran - pkg-config libtool - m4 gnum4 + pkg-config + libtool + m4 + gnum4 file - blas zlib + blas + zlib openmpi octave help2man # Turn "--help" into a man-page diff --git a/pkgs/development/libraries/librsvg/default.nix b/pkgs/development/libraries/librsvg/default.nix index 3d7a8bf8e5bab7..7a71acada5044e 100644 --- a/pkgs/development/libraries/librsvg/default.nix +++ b/pkgs/development/libraries/librsvg/default.nix @@ -1,52 +1,60 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, glib -, gdk-pixbuf -, installShellFiles -, pango -, cairo -, libxml2 -, bzip2 -, libintl -, ApplicationServices -, Foundation -, libobjc -, rustPlatform -, rustc -, cargo-auditable-cargo-wrapper -, gi-docgen -, python3Packages -, gnome -, vala -, writeScript -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, buildPackages -, gobject-introspection -, _experimental-update-script-combinators -, common-updater-scripts -, jq -, nix - -# for passthru.tests -, enlightenment -, ffmpeg -, gegl -, gimp -, imagemagick -, imlib2 -, vips -, xfce +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + gdk-pixbuf, + installShellFiles, + pango, + cairo, + libxml2, + bzip2, + libintl, + ApplicationServices, + Foundation, + libobjc, + rustPlatform, + rustc, + cargo-auditable-cargo-wrapper, + gi-docgen, + python3Packages, + gnome, + vala, + writeScript, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + buildPackages, + gobject-introspection, + _experimental-update-script-combinators, + common-updater-scripts, + jq, + nix, + + # for passthru.tests + enlightenment, + ffmpeg, + gegl, + gimp, + imagemagick, + imlib2, + vips, + xfce, }: stdenv.mkDerivation (finalAttrs: { pname = "librsvg"; version = "2.58.3"; - outputs = [ "out" "dev" ] ++ lib.optionals withIntrospection [ - "devdoc" - ]; + outputs = + [ + "out" + "dev" + ] + ++ lib.optionals withIntrospection [ + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/librsvg/${lib.versions.majorMinor finalAttrs.version}/librsvg-${finalAttrs.version}.tar.xz"; @@ -67,31 +75,35 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - nativeBuildInputs = [ - gdk-pixbuf - installShellFiles - pkg-config - rustc - cargo-auditable-cargo-wrapper - python3Packages.docutils - vala - rustPlatform.cargoSetupHook - ] ++ lib.optionals withIntrospection [ - gobject-introspection - gi-docgen - ]; - - buildInputs = [ - libxml2 - bzip2 - pango - libintl - vala # for share/vala/Makefile.vapigen - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ApplicationServices - Foundation - libobjc - ]; + nativeBuildInputs = + [ + gdk-pixbuf + installShellFiles + pkg-config + rustc + cargo-auditable-cargo-wrapper + python3Packages.docutils + vala + rustPlatform.cargoSetupHook + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + gi-docgen + ]; + + buildInputs = + [ + libxml2 + bzip2 + pango + libintl + vala # for share/vala/Makefile.vapigen + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ApplicationServices + Foundation + libobjc + ]; propagatedBuildInputs = [ glib @@ -99,13 +111,17 @@ stdenv.mkDerivation (finalAttrs: { cairo ]; - configureFlags = [ - (lib.enableFeature withIntrospection "introspection") - (lib.enableFeature withIntrospection "vala") + configureFlags = + [ + (lib.enableFeature withIntrospection "introspection") + (lib.enableFeature withIntrospection "vala") - "--enable-always-build-tests" - ] ++ lib.optional stdenv.hostPlatform.isDarwin "--disable-Bsymbolic" - ++ lib.optional (stdenv.buildPlatform != stdenv.hostPlatform) "RUST_TARGET=${stdenv.hostPlatform.rust.rustcTarget}"; + "--enable-always-build-tests" + ] + ++ lib.optional stdenv.hostPlatform.isDarwin "--disable-Bsymbolic" + ++ lib.optional ( + stdenv.buildPlatform != stdenv.hostPlatform + ) "RUST_TARGET=${stdenv.hostPlatform.rust.rustcTarget}"; doCheck = false; # all tests fail on libtool-generated rsvg-convert not being able to find coreutils @@ -126,28 +142,39 @@ stdenv.mkDerivation (finalAttrs: { # relevant loader.cache here. # The loaders.cache can be used by setting GDK_PIXBUF_MODULE_FILE to # point to this file in a wrapper. - postConfigure = '' - GDK_PIXBUF=$out/lib/gdk-pixbuf-2.0/2.10.0 - mkdir -p $GDK_PIXBUF/loaders - sed -i gdk-pixbuf-loader/Makefile \ - -e "s#gdk_pixbuf_moduledir = .*#gdk_pixbuf_moduledir = $GDK_PIXBUF/loaders#" \ - -e "s#gdk_pixbuf_cache_file = .*#gdk_pixbuf_cache_file = $GDK_PIXBUF/loaders.cache#" \ - -e "s#\$(GDK_PIXBUF_QUERYLOADERS)#GDK_PIXBUF_MODULEDIR=$GDK_PIXBUF/loaders \$(GDK_PIXBUF_QUERYLOADERS)#" - - # Fix thumbnailer path - sed -e "s#@bindir@\(/gdk-pixbuf-thumbnailer\)#${gdk-pixbuf}/bin\1#g" \ - -i gdk-pixbuf-loader/librsvg.thumbnailer.in - - # 'error: linker `cc` not found' when cross-compiling - export RUSTFLAGS="-Clinker=$CC" - '' + lib.optionalString ((stdenv.buildPlatform != stdenv.hostPlatform) && (stdenv.hostPlatform.emulatorAvailable buildPackages)) '' - # the replacement is the native conditional - substituteInPlace gdk-pixbuf-loader/Makefile \ - --replace 'RUN_QUERY_LOADER_TEST = false' 'RUN_QUERY_LOADER_TEST = test -z "$(DESTDIR)"' \ - ''; + postConfigure = + '' + GDK_PIXBUF=$out/lib/gdk-pixbuf-2.0/2.10.0 + mkdir -p $GDK_PIXBUF/loaders + sed -i gdk-pixbuf-loader/Makefile \ + -e "s#gdk_pixbuf_moduledir = .*#gdk_pixbuf_moduledir = $GDK_PIXBUF/loaders#" \ + -e "s#gdk_pixbuf_cache_file = .*#gdk_pixbuf_cache_file = $GDK_PIXBUF/loaders.cache#" \ + -e "s#\$(GDK_PIXBUF_QUERYLOADERS)#GDK_PIXBUF_MODULEDIR=$GDK_PIXBUF/loaders \$(GDK_PIXBUF_QUERYLOADERS)#" + + # Fix thumbnailer path + sed -e "s#@bindir@\(/gdk-pixbuf-thumbnailer\)#${gdk-pixbuf}/bin\1#g" \ + -i gdk-pixbuf-loader/librsvg.thumbnailer.in + + # 'error: linker `cc` not found' when cross-compiling + export RUSTFLAGS="-Clinker=$CC" + '' + + + lib.optionalString + ( + (stdenv.buildPlatform != stdenv.hostPlatform) + && (stdenv.hostPlatform.emulatorAvailable buildPackages) + ) + '' + # the replacement is the native conditional + substituteInPlace gdk-pixbuf-loader/Makefile \ + --replace 'RUN_QUERY_LOADER_TEST = false' 'RUN_QUERY_LOADER_TEST = test -z "$(DESTDIR)"' \ + ''; # Not generated when cross compiling. - postInstall = let emulator = stdenv.hostPlatform.emulator buildPackages; in + postInstall = + let + emulator = stdenv.hostPlatform.emulator buildPackages; + in lib.optionalString (stdenv.hostPlatform.emulatorAvailable buildPackages) '' # Merge gdkpixbuf and librsvg loaders cat ${lib.getLib gdk-pixbuf}/lib/gdk-pixbuf-2.0/2.10.0/loaders.cache $GDK_PIXBUF/loaders.cache > $GDK_PIXBUF/loaders.cache.tmp @@ -176,11 +203,13 @@ stdenv.mkDerivation (finalAttrs: { "sh" "-c" '' - PATH=${lib.makeBinPath [ - common-updater-scripts - jq - nix - ]} + PATH=${ + lib.makeBinPath [ + common-updater-scripts + jq + nix + ] + } update-source-version librsvg --ignore-same-version --source-key=cargoDeps > /dev/null '' ]; @@ -198,7 +227,8 @@ stdenv.mkDerivation (finalAttrs: { gimp imagemagick imlib2 - vips; + vips + ; inherit (enlightenment) efl; inherit (xfce) xfwm4; ffmpeg = ffmpeg.override { withSvg = true; }; diff --git a/pkgs/development/libraries/libsamplerate/default.nix b/pkgs/development/libraries/libsamplerate/default.nix index ec4da5a34784ea..f50d40bf8e2f6c 100644 --- a/pkgs/development/libraries/libsamplerate/default.nix +++ b/pkgs/development/libraries/libsamplerate/default.nix @@ -1,9 +1,19 @@ -{ lib, stdenv, fetchurl, pkg-config, libsndfile, ApplicationServices, Carbon, CoreServices }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libsndfile, + ApplicationServices, + Carbon, + CoreServices, +}: let inherit (lib) optionals optionalString; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "libsamplerate"; version = "0.2.2"; @@ -13,12 +23,19 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libsndfile ] - ++ optionals stdenv.hostPlatform.isDarwin [ ApplicationServices CoreServices ]; + buildInputs = + [ libsndfile ] + ++ optionals stdenv.hostPlatform.isDarwin [ + ApplicationServices + CoreServices + ]; configureFlags = [ "--disable-fftw" ]; - outputs = [ "dev" "out" ]; + outputs = [ + "dev" + "out" + ]; postConfigure = optionalString stdenv.hostPlatform.isDarwin '' # need headers from the Carbon.framework in /System/Library/Frameworks to @@ -28,11 +45,11 @@ in stdenv.mkDerivation rec { meta = with lib; { description = "Sample Rate Converter for audio"; - homepage = "https://libsndfile.github.io/libsamplerate/"; - license = licenses.bsd2; + homepage = "https://libsndfile.github.io/libsamplerate/"; + license = licenses.bsd2; maintainers = with maintainers; [ lovek323 ]; - platforms = platforms.all; + platforms = platforms.all; # Linker is unhappy with the `.def` file. - broken = stdenv.hostPlatform.isMinGW; + broken = stdenv.hostPlatform.isMinGW; }; } diff --git a/pkgs/development/libraries/libsbsms/common.nix b/pkgs/development/libraries/libsbsms/common.nix index 7215c23667b8b2..358710b7950172 100644 --- a/pkgs/development/libraries/libsbsms/common.nix +++ b/pkgs/development/libraries/libsbsms/common.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, substituteAll -, pname -, version -, url -, sha256 -, homepage +{ + lib, + stdenv, + fetchurl, + substituteAll, + pname, + version, + url, + sha256, + homepage, }: stdenv.mkDerivation rec { @@ -29,7 +30,7 @@ stdenv.mkDerivation rec { meta = { inherit homepage; description = "Subband sinusoidal modeling library for time stretching and pitch scaling audio"; - maintainers = with lib.maintainers; [ yuu ]; + maintainers = with lib.maintainers; [ yuu ]; license = lib.licenses.gpl2; platforms = lib.platforms.all; }; diff --git a/pkgs/development/libraries/libsigcxx/3.0.nix b/pkgs/development/libraries/libsigcxx/3.0.nix index 672cb984b8ee41..4e1a656def5a1c 100644 --- a/pkgs/development/libraries/libsigcxx/3.0.nix +++ b/pkgs/development/libraries/libsigcxx/3.0.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, meson -, ninja -, gnome +{ + stdenv, + lib, + fetchurl, + pkg-config, + meson, + ninja, + gnome, }: stdenv.mkDerivation rec { @@ -16,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "w9I7N9/W458uCfCRt3sVQfv6F8Twtr9cibrvcikIDhc="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ pkg-config diff --git a/pkgs/development/libraries/libsigcxx/default.nix b/pkgs/development/libraries/libsigcxx/default.nix index 7e2746fb7f4c67..cfac1918e8073c 100644 --- a/pkgs/development/libraries/libsigcxx/default.nix +++ b/pkgs/development/libraries/libsigcxx/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, meson, ninja, gnome }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + meson, + ninja, + gnome, +}: stdenv.mkDerivation rec { pname = "libsigc++"; @@ -9,9 +17,16 @@ stdenv.mkDerivation rec { sha256 = "sha256-qdvuMjNR0Qm3ruB0qcuJyj57z4rY7e8YUfTPNZvVCEM="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ pkg-config meson ninja ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + ]; doCheck = true; diff --git a/pkgs/development/libraries/libsndfile/default.nix b/pkgs/development/libraries/libsndfile/default.nix index ad3ab58b0e13f8..0c91b3e13d8bd4 100644 --- a/pkgs/development/libraries/libsndfile/default.nix +++ b/pkgs/development/libraries/libsndfile/default.nix @@ -1,15 +1,29 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, autogen, pkg-config, python3 -, flac, lame, libmpg123, libogg, libopus, libvorbis -, alsa-lib, Carbon, AudioToolbox +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + autogen, + pkg-config, + python3, + flac, + lame, + libmpg123, + libogg, + libopus, + libvorbis, + alsa-lib, + Carbon, + AudioToolbox, -# for passthru.tests -, audacity -, freeswitch -, gst_all_1 -, libsamplerate -, moc -, pipewire -, pulseaudio + # for passthru.tests + audacity, + freeswitch, + gst_all_1, + libsamplerate, + moc, + pipewire, + pulseaudio, }: stdenv.mkDerivation rec { @@ -23,21 +37,42 @@ stdenv.mkDerivation rec { hash = "sha256-MOOX/O0UaoeMaQPW9PvvE0izVp+6IoE5VbtTx0RvMkI="; }; - nativeBuildInputs = [ autoreconfHook autogen pkg-config python3 ]; - buildInputs = [ flac lame libmpg123 libogg libopus libvorbis ] + nativeBuildInputs = [ + autoreconfHook + autogen + pkg-config + python3 + ]; + buildInputs = + [ + flac + lame + libmpg123 + libogg + libopus + libvorbis + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ alsa-lib ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Carbon AudioToolbox ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + AudioToolbox + ]; enableParallelBuilding = true; - outputs = [ "bin" "dev" "out" "man" "doc" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + "doc" + ]; # need headers from the Carbon.framework in /System/Library/Frameworks to # compile this on darwin -- not sure how to handle - preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin - '' - NIX_CFLAGS_COMPILE+=" -I$SDKROOT/System/Library/Frameworks/Carbon.framework/Versions/A/Headers" - ''; + preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin '' + NIX_CFLAGS_COMPILE+=" -I$SDKROOT/System/Library/Frameworks/Carbon.framework/Versions/A/Headers" + ''; # Needed on Darwin. NIX_CFLAGS_LINK = "-logg -lvorbis"; @@ -57,21 +92,23 @@ stdenv.mkDerivation rec { libsamplerate moc pipewire - pulseaudio; + pulseaudio + ; inherit (python3.pkgs) soundfile - wavefile; + wavefile + ; inherit (gst_all_1) gst-plugins-bad; lame = (lame.override { sndfileFileIOSupport = true; }); }; meta = with lib; { description = "C library for reading and writing files containing sampled sound"; - homepage = "https://libsndfile.github.io/libsndfile/"; - changelog = "https://github.com/libsndfile/libsndfile/releases/tag/${version}"; - license = licenses.lgpl2Plus; + homepage = "https://libsndfile.github.io/libsndfile/"; + changelog = "https://github.com/libsndfile/libsndfile/releases/tag/${version}"; + license = licenses.lgpl2Plus; maintainers = with maintainers; [ lovek323 ]; - platforms = platforms.all; + platforms = platforms.all; longDescription = '' Libsndfile is a C library for reading and writing files containing diff --git a/pkgs/development/libraries/libsoundio/default.nix b/pkgs/development/libraries/libsoundio/default.nix index c4b50162827231..6dab2ea2c6f0a7 100644 --- a/pkgs/development/libraries/libsoundio/default.nix +++ b/pkgs/development/libraries/libsoundio/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, alsa-lib, libjack2, libpulseaudio, AudioUnit }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + alsa-lib, + libjack2, + libpulseaudio, + AudioUnit, +}: stdenv.mkDerivation rec { version = "2.0.0"; @@ -13,8 +22,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ libjack2 ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libpulseaudio alsa-lib ] + buildInputs = + [ libjack2 ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libpulseaudio + alsa-lib + ] ++ lib.optional stdenv.hostPlatform.isDarwin AudioUnit; cmakeFlags = lib.optionals stdenv.hostPlatform.isDarwin [ diff --git a/pkgs/development/libraries/libsoup/3.x.nix b/pkgs/development/libraries/libsoup/3.x.nix index 2aff5ca6037732..b9ace3b528abfa 100644 --- a/pkgs/development/libraries/libsoup/3.x.nix +++ b/pkgs/development/libraries/libsoup/3.x.nix @@ -1,29 +1,35 @@ -{ stdenv -, lib -, fetchurl -, glib -, meson -, ninja -, pkg-config -, gnome -, libsysprof-capture -, sqlite -, buildPackages -, gobject-introspection -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, vala -, libpsl -, python3 -, gi-docgen -, brotli -, libnghttp2 +{ + stdenv, + lib, + fetchurl, + glib, + meson, + ninja, + pkg-config, + gnome, + libsysprof-capture, + sqlite, + buildPackages, + gobject-introspection, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + vala, + libpsl, + python3, + gi-docgen, + brotli, + libnghttp2, }: stdenv.mkDerivation rec { pname = "libsoup"; version = "3.6.0"; - outputs = [ "out" "dev" ] ++ lib.optional withIntrospection "devdoc"; + outputs = [ + "out" + "dev" + ] ++ lib.optional withIntrospection "devdoc"; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -34,27 +40,31 @@ stdenv.mkDerivation rec { pkg-config ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - glib - python3 - ] ++ lib.optionals withIntrospection [ - gi-docgen - gobject-introspection - vala - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + glib + python3 + ] + ++ lib.optionals withIntrospection [ + gi-docgen + gobject-introspection + vala + ]; - buildInputs = [ - sqlite - libpsl - glib.out - brotli - libnghttp2 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libsysprof-capture - ]; + buildInputs = + [ + sqlite + libpsl + glib.out + brotli + libnghttp2 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libsysprof-capture + ]; propagatedBuildInputs = [ glib diff --git a/pkgs/development/libraries/libsoup/default.nix b/pkgs/development/libraries/libsoup/default.nix index a88cd935532694..1598b773339b2e 100644 --- a/pkgs/development/libraries/libsoup/default.nix +++ b/pkgs/development/libraries/libsoup/default.nix @@ -1,28 +1,34 @@ -{ stdenv -, lib -, fetchurl -, glib -, libxml2 -, meson -, ninja -, pkg-config -, gnome -, libsysprof-capture -, gobject-introspection -, vala -, libpsl -, brotli -, gnomeSupport ? true -, sqlite -, buildPackages -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages +{ + stdenv, + lib, + fetchurl, + glib, + libxml2, + meson, + ninja, + pkg-config, + gnome, + libsysprof-capture, + gobject-introspection, + vala, + libpsl, + brotli, + gnomeSupport ? true, + sqlite, + buildPackages, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, }: stdenv.mkDerivation rec { pname = "libsoup"; version = "2.74.3"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -33,40 +39,46 @@ stdenv.mkDerivation rec { pkg-config ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - glib - ] ++ lib.optionals withIntrospection [ - gobject-introspection - vala - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + glib + ] + ++ lib.optionals withIntrospection [ + gobject-introspection + vala + ]; - buildInputs = [ - sqlite - libpsl - glib.out - brotli - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libsysprof-capture - ]; + buildInputs = + [ + sqlite + libpsl + glib.out + brotli + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libsysprof-capture + ]; propagatedBuildInputs = [ glib libxml2 ]; - mesonFlags = [ - "-Dtls_check=false" # glib-networking is a runtime dependency, not a compile-time dependency - "-Dgssapi=disabled" - "-Dvapi=${if withIntrospection then "enabled" else "disabled"}" - "-Dintrospection=${if withIntrospection then "enabled" else "disabled"}" - "-Dgnome=${lib.boolToString gnomeSupport}" - "-Dntlm=disabled" - ] ++ lib.optionals (!stdenv.hostPlatform.isLinux) [ - "-Dsysprof=disabled" - ]; + mesonFlags = + [ + "-Dtls_check=false" # glib-networking is a runtime dependency, not a compile-time dependency + "-Dgssapi=disabled" + "-Dvapi=${if withIntrospection then "enabled" else "disabled"}" + "-Dintrospection=${if withIntrospection then "enabled" else "disabled"}" + "-Dgnome=${lib.boolToString gnomeSupport}" + "-Dntlm=disabled" + ] + ++ lib.optionals (!stdenv.hostPlatform.isLinux) [ + "-Dsysprof=disabled" + ]; env.NIX_CFLAGS_COMPILE = "-lpthread"; diff --git a/pkgs/development/libraries/libstatgrab/default.nix b/pkgs/development/libraries/libstatgrab/default.nix index 9b45ffb58ce7b9..3dd55d1e690adc 100644 --- a/pkgs/development/libraries/libstatgrab/default.nix +++ b/pkgs/development/libraries/libstatgrab/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, IOKit +{ + lib, + stdenv, + fetchurl, + IOKit, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/libticalcs2/default.nix b/pkgs/development/libraries/libticalcs2/default.nix index c114ce5e3e3b18..0fae58094f4aa1 100644 --- a/pkgs/development/libraries/libticalcs2/default.nix +++ b/pkgs/development/libraries/libticalcs2/default.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, autoreconfHook -, glib -, libticonv -, libtifiles2 -, libticables2 -, xz -, bzip2 -, acl -, libobjc +{ + stdenv, + lib, + fetchurl, + pkg-config, + autoreconfHook, + glib, + libticonv, + libtifiles2, + libticables2, + xz, + bzip2, + acl, + libobjc, }: stdenv.mkDerivation rec { @@ -26,25 +27,31 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - glib - libticonv - libtifiles2 - libticables2 - xz - bzip2 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - acl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libobjc - ]; + buildInputs = + [ + glib + libticonv + libtifiles2 + libticables2 + xz + bzip2 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + acl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + ]; meta = with lib; { changelog = "http://lpg.ticalc.org/prj_tilp/news.html"; description = "This library is part of the TiLP framework"; homepage = "http://lpg.ticalc.org/prj_tilp/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ siraben clevor ]; + maintainers = with maintainers; [ + siraben + clevor + ]; platforms = with platforms; linux ++ darwin; }; } diff --git a/pkgs/development/libraries/libubox/default.nix b/pkgs/development/libraries/libubox/default.nix index 1a3a89a2d71d13..c001668c428eca 100644 --- a/pkgs/development/libraries/libubox/default.nix +++ b/pkgs/development/libraries/libubox/default.nix @@ -1,4 +1,15 @@ -{ stdenv, lib, fetchgit, cmake, pkg-config, json_c, with_lua ? false, lua5_1, with_ustream_ssl ? false, ustream-ssl }: +{ + stdenv, + lib, + fetchgit, + cmake, + pkg-config, + json_c, + with_lua ? false, + lua5_1, + with_ustream_ssl ? false, + ustream-ssl, +}: stdenv.mkDerivation { pname = "libubox"; @@ -10,10 +21,17 @@ stdenv.mkDerivation { hash = "sha256-QgpORITt6MYgfzUpaI2T0Ge2a0iVHjDhdYI/nZ2HbJ8="; }; - cmakeFlags = [ "-DBUILD_EXAMPLES=OFF" (if with_lua then "-DLUAPATH=${placeholder "out"}/lib/lua" else "-DBUILD_LUA=OFF") ]; + cmakeFlags = [ + "-DBUILD_EXAMPLES=OFF" + (if with_lua then "-DLUAPATH=${placeholder "out"}/lib/lua" else "-DBUILD_LUA=OFF") + ]; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ json_c ] ++ lib.optional with_lua lua5_1 ++ lib.optional with_ustream_ssl ustream-ssl; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = + [ json_c ] ++ lib.optional with_lua lua5_1 ++ lib.optional with_ustream_ssl ustream-ssl; postInstall = lib.optionalString with_ustream_ssl '' for fin in $(find ${ustream-ssl} -type f); do @@ -22,15 +40,20 @@ stdenv.mkDerivation { done ''; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ - "-Wno-error=gnu-folding-constant" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + "-Wno-error=gnu-folding-constant" + ] + ); meta = with lib; { description = "C utility functions for OpenWrt"; homepage = "https://git.openwrt.org/?p=project/libubox.git;a=summary"; license = licenses.isc; - maintainers = with maintainers; [ fpletz mkg20001 ]; + maintainers = with maintainers; [ + fpletz + mkg20001 + ]; mainProgram = "jshn"; platforms = platforms.all; }; diff --git a/pkgs/development/libraries/libui/default.nix b/pkgs/development/libraries/libui/default.nix index 77197986343f62..c3726929f9dfd8 100644 --- a/pkgs/development/libraries/libui/default.nix +++ b/pkgs/development/libraries/libui/default.nix @@ -1,53 +1,69 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, gtk3, Cocoa }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + gtk3, + Cocoa, +}: let - backend = if stdenv.hostPlatform.isDarwin then "darwin" else "unix"; + backend = if stdenv.hostPlatform.isDarwin then "darwin" else "unix"; in stdenv.mkDerivation rec { pname = "libui"; - version = "4.1a"; - src = fetchFromGitHub { - owner = "andlabs"; - repo = "libui"; - rev = "alpha4.1"; + version = "4.1a"; + src = fetchFromGitHub { + owner = "andlabs"; + repo = "libui"; + rev = "alpha4.1"; sha256 = "0bm6xvqk4drg2kw6d304x6mlfal7gh8mbl5a9f0509smmdzgdkwm"; }; - nativeBuildInputs = [ cmake pkg-config ]; - propagatedBuildInputs = lib.optional stdenv.hostPlatform.isLinux gtk3 + nativeBuildInputs = [ + cmake + pkg-config + ]; + propagatedBuildInputs = + lib.optional stdenv.hostPlatform.isLinux gtk3 ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin '' sed -i 's/set(CMAKE_OSX_DEPLOYMENT_TARGET "10.8")//' ./CMakeLists.txt ''; - installPhase = '' - mkdir -p $out/{include,lib} - mkdir -p $out/lib/pkgconfig - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - mv ./out/libui.so.0 $out/lib/ - ln -s $out/lib/libui.so.0 $out/lib/libui.so - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mv ./out/libui.A.dylib $out/lib/ - ln -s $out/lib/libui.A.dylib $out/lib/libui.dylib - '' + '' - cp $src/ui.h $out/include - cp $src/ui_${backend}.h $out/include + installPhase = + '' + mkdir -p $out/{include,lib} + mkdir -p $out/lib/pkgconfig + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + mv ./out/libui.so.0 $out/lib/ + ln -s $out/lib/libui.so.0 $out/lib/libui.so + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mv ./out/libui.A.dylib $out/lib/ + ln -s $out/lib/libui.A.dylib $out/lib/libui.dylib + '' + + '' + cp $src/ui.h $out/include + cp $src/ui_${backend}.h $out/include - cp ${./libui.pc} $out/lib/pkgconfig/libui.pc - substituteInPlace $out/lib/pkgconfig/libui.pc \ - --subst-var-by out $out \ - --subst-var-by version "${version}" - ''; + cp ${./libui.pc} $out/lib/pkgconfig/libui.pc + substituteInPlace $out/lib/pkgconfig/libui.pc \ + --subst-var-by out $out \ + --subst-var-by version "${version}" + ''; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' install_name_tool -id $out/lib/libui.A.dylib $out/lib/libui.A.dylib ''; meta = with lib; { - homepage = "https://github.com/andlabs/libui"; + homepage = "https://github.com/andlabs/libui"; description = "Simple and portable (but not inflexible) GUI library in C that uses the native GUI technologies of each platform it supports"; - license = licenses.mit; - platforms = platforms.unix; + license = licenses.mit; + platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/libuiohook/default.nix b/pkgs/development/libraries/libuiohook/default.nix index 7d58b78149584f..e39c2addfac43d 100644 --- a/pkgs/development/libraries/libuiohook/default.nix +++ b/pkgs/development/libraries/libuiohook/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, nixosTests -, cmake -, pkg-config -, AppKit -, ApplicationServices -, Carbon -, libX11 -, libxkbcommon -, xinput -, xorg +{ + lib, + stdenv, + fetchFromGitHub, + nixosTests, + cmake, + pkg-config, + AppKit, + ApplicationServices, + Carbon, + libX11, + libxkbcommon, + xinput, + xorg, }: stdenv.mkDerivation rec { @@ -24,27 +25,39 @@ stdenv.mkDerivation rec { sha256 = "1qlz55fp4i9dd8sdwmy1m8i4i1jy1s09cpmlxzrgf7v34w72ncm7"; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = - if stdenv.hostPlatform.isDarwin then [ AppKit ApplicationServices Carbon ] - else [ - libX11 - libxkbcommon - xinput - ] ++ - (with xorg; [ - libXau - libXdmcp - libXi - libXinerama - libXt - libXtst - libXext - libxkbfile - ]); + if stdenv.hostPlatform.isDarwin then + [ + AppKit + ApplicationServices + Carbon + ] + else + [ + libX11 + libxkbcommon + xinput + ] + ++ (with xorg; [ + libXau + libXdmcp + libXi + libXinerama + libXt + libXtst + libXext + libxkbfile + ]); - outputs = [ "out" "test" ]; + outputs = [ + "out" + "test" + ]; # We build the tests, but they're only installed when using the "test" output. # This will produce a "uiohook_tests" binary which can be run to test the diff --git a/pkgs/development/libraries/libunique/3.x.nix b/pkgs/development/libraries/libunique/3.x.nix index e5e6b21c1b999b..56c2db308652f8 100644 --- a/pkgs/development/libraries/libunique/3.x.nix +++ b/pkgs/development/libraries/libunique/3.x.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, fetchurl, pkg-config -, dbus, dbus-glib, gtk3, gobject-introspection -, gtk-doc, docbook_xml_dtd_45, docbook_xsl -, libxslt, libxml2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + dbus, + dbus-glib, + gtk3, + gobject-introspection, + gtk-doc, + docbook_xml_dtd_45, + docbook_xsl, + libxslt, + libxml2, +}: stdenv.mkDerivation rec { @@ -16,8 +27,20 @@ stdenv.mkDerivation rec { sha256 = "0f70lkw66v9cj72q0iw1s2546r6bwwcd8idcm3621fg2fgh2rw58"; }; - nativeBuildInputs = [ pkg-config gobject-introspection ]; - buildInputs = [ dbus dbus-glib gtk3 gtk-doc docbook_xml_dtd_45 docbook_xsl libxslt libxml2 ]; + nativeBuildInputs = [ + pkg-config + gobject-introspection + ]; + buildInputs = [ + dbus + dbus-glib + gtk3 + gtk-doc + docbook_xml_dtd_45 + docbook_xsl + libxslt + libxml2 + ]; meta = { homepage = "https://gitlab.gnome.org/Archive/unique"; diff --git a/pkgs/development/libraries/libunique/default.nix b/pkgs/development/libraries/libunique/default.nix index 2e9f2a8a12047b..a8fa987f673afe 100644 --- a/pkgs/development/libraries/libunique/default.nix +++ b/pkgs/development/libraries/libunique/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, gtk2, dbus-glib }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + gtk2, + dbus-glib, +}: stdenv.mkDerivation rec { pname = "libunique"; @@ -26,7 +34,11 @@ stdenv.mkDerivation rec { ] ++ [ ./gcc7-bug.patch ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib gtk2 dbus-glib ]; + buildInputs = [ + glib + gtk2 + dbus-glib + ]; doCheck = true; diff --git a/pkgs/development/libraries/libunistring/default.nix b/pkgs/development/libraries/libunistring/default.nix index abf5f0df25589a..cdd93f551920df 100644 --- a/pkgs/development/libraries/libunistring/default.nix +++ b/pkgs/development/libraries/libunistring/default.nix @@ -4,7 +4,7 @@ stdenv, libiconv, updateAutotoolsGnuConfigScriptsHook, - darwin + darwin, }: # Note: this package is used for bootstrapping fetchurl, and thus diff --git a/pkgs/development/libraries/libunwind/default.nix b/pkgs/development/libraries/libunwind/default.nix index 6f491a5c527f04..f0f7de192f4487 100644 --- a/pkgs/development/libraries/libunwind/default.nix +++ b/pkgs/development/libraries/libunwind/default.nix @@ -1,6 +1,12 @@ -{ stdenv, lib, fetchpatch, fetchFromGitHub, autoreconfHook, buildPackages -, xz -, testers +{ + stdenv, + lib, + fetchpatch, + fetchFromGitHub, + autoreconfHook, + buildPackages, + xz, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -19,30 +25,39 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-9oBZimCXonNN++jJs3emp9w+q1aj3eNzvSKPgh92itA="; }); - postPatch = if (stdenv.cc.isClang || stdenv.hostPlatform.isStatic) then '' - substituteInPlace configure.ac --replace "-lgcc_s" "" - '' else lib.optionalString stdenv.hostPlatform.isMusl '' - substituteInPlace configure.ac --replace "-lgcc_s" "-lgcc_eh" - ''; + postPatch = + if (stdenv.cc.isClang || stdenv.hostPlatform.isStatic) then + '' + substituteInPlace configure.ac --replace "-lgcc_s" "" + '' + else + lib.optionalString stdenv.hostPlatform.isMusl '' + substituteInPlace configure.ac --replace "-lgcc_s" "-lgcc_eh" + ''; nativeBuildInputs = [ autoreconfHook ]; - outputs = [ "out" "dev" "devman" ]; - - configureFlags = [ - # Starting from 1.8.1 libunwind installs testsuite by default. - # As we don't run the tests we disable it (this also fixes circular - # reference install failure). - "--disable-tests" - # Without latex2man, no man pages are installed despite being - # prebuilt in the source tarball. - "LATEX2MAN=${buildPackages.coreutils}/bin/true" - ] - # See https://github.com/libunwind/libunwind/issues/693 - ++ lib.optionals (with stdenv.hostPlatform; isAarch64 && isMusl && !isStatic) [ - "CFLAGS=-mno-outline-atomics" + outputs = [ + "out" + "dev" + "devman" ]; + configureFlags = + [ + # Starting from 1.8.1 libunwind installs testsuite by default. + # As we don't run the tests we disable it (this also fixes circular + # reference install failure). + "--disable-tests" + # Without latex2man, no man pages are installed despite being + # prebuilt in the source tarball. + "LATEX2MAN=${buildPackages.coreutils}/bin/true" + ] + # See https://github.com/libunwind/libunwind/issues/693 + ++ lib.optionals (with stdenv.hostPlatform; isAarch64 && isMusl && !isStatic) [ + "CFLAGS=-mno-outline-atomics" + ]; + propagatedBuildInputs = [ xz ]; postInstall = '' @@ -62,9 +77,33 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://www.nongnu.org/libunwind"; description = "Portable and efficient API to determine the call-chain of a program"; maintainers = with maintainers; [ orivej ]; - pkgConfigModules = [ "libunwind" "libunwind-coredump" "libunwind-generic" "libunwind-ptrace" "libunwind-setjmp" ]; + pkgConfigModules = [ + "libunwind" + "libunwind-coredump" + "libunwind-generic" + "libunwind-ptrace" + "libunwind-setjmp" + ]; # https://github.com/libunwind/libunwind#libunwind - platforms = [ "aarch64-linux" "armv5tel-linux" "armv6l-linux" "armv7a-linux" "armv7l-linux" "i686-freebsd" "i686-linux" "loongarch64-linux" "mips64el-linux" "mipsel-linux" "powerpc64-linux" "powerpc64le-linux" "riscv64-linux" "s390x-linux" "x86_64-freebsd" "x86_64-linux" "x86_64-solaris" ]; + platforms = [ + "aarch64-linux" + "armv5tel-linux" + "armv6l-linux" + "armv7a-linux" + "armv7l-linux" + "i686-freebsd" + "i686-linux" + "loongarch64-linux" + "mips64el-linux" + "mipsel-linux" + "powerpc64-linux" + "powerpc64le-linux" + "riscv64-linux" + "s390x-linux" + "x86_64-freebsd" + "x86_64-linux" + "x86_64-solaris" + ]; license = licenses.mit; }; }) diff --git a/pkgs/development/libraries/libusb-compat/0.1.nix b/pkgs/development/libraries/libusb-compat/0.1.nix index 841e781dfd5f93..904848cf78fbf4 100644 --- a/pkgs/development/libraries/libusb-compat/0.1.nix +++ b/pkgs/development/libraries/libusb-compat/0.1.nix @@ -1,16 +1,20 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libusb1 +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libusb1, }: stdenv.mkDerivation rec { pname = "libusb-compat"; version = "0.1.8"; - outputs = [ "out" "dev" ]; # get rid of propagating systemd closure + outputs = [ + "out" + "dev" + ]; # get rid of propagating systemd closure outputBin = "dev"; src = fetchFromGitHub { @@ -22,7 +26,10 @@ stdenv.mkDerivation rec { patches = lib.optional stdenv.hostPlatform.isMusl ./fix-headers.patch; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = [ libusb1 ]; diff --git a/pkgs/development/libraries/libusb1/default.nix b/pkgs/development/libraries/libusb1/default.nix index f0be68faae8f27..a02047b552c9fb 100644 --- a/pkgs/development/libraries/libusb1/default.nix +++ b/pkgs/development/libraries/libusb1/default.nix @@ -1,17 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, doxygen -, pkg-config -, enableUdev ? stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isStatic && !stdenv.hostPlatform.isAndroid -, udev -, libobjc -, IOKit -, Security -, withExamples ? false -, withStatic ? false -, withDocs ? stdenv.buildPlatform.canExecute stdenv.hostPlatform +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + doxygen, + pkg-config, + enableUdev ? + stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isStatic && !stdenv.hostPlatform.isAndroid, + udev, + libobjc, + IOKit, + Security, + withExamples ? false, + withStatic ? false, + withDocs ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, }: stdenv.mkDerivation rec { @@ -25,15 +27,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-OtzYxWwiba0jRK9X+4deWWDDTeZWlysEt0qMyGUarDo="; }; - outputs = [ "out" "dev" ] ++ lib.optionals withDocs [ "doc" ]; + outputs = [ + "out" + "dev" + ] ++ lib.optionals withDocs [ "doc" ]; nativeBuildInputs = [ pkg-config autoreconfHook ] ++ lib.optionals withDocs [ doxygen ]; propagatedBuildInputs = - lib.optional enableUdev udev ++ - lib.optionals stdenv.hostPlatform.isDarwin [ libobjc IOKit Security ]; + lib.optional enableUdev udev + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + IOKit + Security + ]; dontDisableStatic = withStatic; @@ -68,6 +77,9 @@ stdenv.mkDerivation rec { ''; platforms = platforms.all; license = licenses.lgpl21Plus; - maintainers = with maintainers; [ prusnak realsnick ]; + maintainers = with maintainers; [ + prusnak + realsnick + ]; }; } diff --git a/pkgs/development/libraries/libuv/default.nix b/pkgs/development/libraries/libuv/default.nix index 2b8020d4309344..fe0a33bb48b83b 100644 --- a/pkgs/development/libraries/libuv/default.nix +++ b/pkgs/development/libraries/libuv/default.nix @@ -1,25 +1,26 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoconf -, automake -, darwin -, libtool -, pkg-config -, pkgsStatic - -# for passthru.tests -, bind -, cmake -, knot-resolver -, sbclPackages -, luajitPackages -, mosquitto -, neovim -, nodejs -, ocamlPackages -, python3 -, testers +{ + stdenv, + lib, + fetchFromGitHub, + autoconf, + automake, + darwin, + libtool, + pkg-config, + pkgsStatic, + + # for passthru.tests + bind, + cmake, + knot-resolver, + sbclPackages, + luajitPackages, + mosquitto, + neovim, + nodejs, + ocamlPackages, + python3, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -33,66 +34,125 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-U68BmIQNpmIy3prS7LkYl+wvDJQNikoeFiKh50yQFoA="; }; - outputs = [ "out" "dev" ]; - - postPatch = let - toDisable = [ - "getnameinfo_basic" "udp_send_hang_loop" # probably network-dependent - "tcp_connect_timeout" # tries to reach out to 8.8.8.8 - "spawn_setuid_fails" "spawn_setgid_fails" "fs_chown" # user namespaces - "getaddrinfo_fail" "getaddrinfo_fail_sync" "tcp_connect6_link_local" - "threadpool_multiple_event_loops" # times out on slow machines - "get_passwd" # passed on NixOS but failed on other Linuxes - "tcp_writealot" "udp_multicast_join" "udp_multicast_join6" "metrics_pool_events" # times out sometimes - "fs_fstat" # https://github.com/libuv/libuv/issues/2235#issuecomment-1012086927 - - # Assertion failed in test/test-tcp-bind6-error.c on line 60: r == UV_EADDRINUSE - # Assertion failed in test/test-tcp-bind-error.c on line 99: r == UV_EADDRINUSE - "tcp_bind6_error_addrinuse" "tcp_bind_error_addrinuse_listen" - # https://github.com/libuv/libuv/pull/4075#issuecomment-1935572237 - "thread_priority" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # Sometimes: timeout (no output), failed uv_listen. Someone - # should report these failures to libuv team. There tests should - # be much more robust. - "process_title" "emfile" "poll_duplex" "poll_unidirectional" - "ipc_listen_before_write" "ipc_listen_after_write" "ipc_tcp_connection" - "tcp_alloc_cb_fail" "tcp_ping_pong" "tcp_ref3" "tcp_ref4" - "tcp_bind6_error_inval" "tcp_bind6_error_addrinuse" "tcp_read_stop" - "tcp_unexpected_read" "tcp_write_to_half_open_connection" - "tcp_oob" "tcp_close_accept" "tcp_create_early_accept" - "tcp_create_early" "tcp_close" "tcp_bind_error_inval" - "tcp_bind_error_addrinuse" "tcp_shutdown_after_write" - "tcp_open" "tcp_write_queue_order" "tcp_try_write" "tcp_writealot" - "multiple_listen" "delayed_accept" "udp_recv_in_a_row" - "shutdown_close_tcp" "shutdown_eof" "shutdown_twice" "callback_stack" - "tty_pty" "condvar_5" "hrtime" "udp_multicast_join" - # Tests that fail when sandboxing is enabled. - "fs_event_close_in_callback" "fs_event_watch_dir" "fs_event_error_reporting" - "fs_event_watch_dir_recursive" "fs_event_watch_file" - "fs_event_watch_file_current_dir" "fs_event_watch_file_exact_path" - "process_priority" "udp_create_early_bad_bind" - "fs_event_watch_delete_dir" - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ - # fail on macos < 10.15 (starting in libuv 1.47.0) - "fs_write_alotof_bufs_with_offset" "fs_write_multiple_bufs" "fs_read_bufs" - ] ++ lib.optionals stdenv.hostPlatform.isAarch32 [ - # I observe this test failing with some regularity on ARMv7: - # https://github.com/libuv/libuv/issues/1871 - "shutdown_close_pipe" - ] ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ - # EOPNOTSUPP when performed in jailed build env - "tcp_reuseport" "udp_reuseport" - # Fails when built on non-nix FreeBSD - # https://github.com/libuv/libuv/issues/4606 - "fs_event_watch_delete_dir" - ]; - tdRegexp = lib.concatStringsSep "\\|" toDisable; - in lib.optionalString (finalAttrs.finalPackage.doCheck) '' + outputs = [ + "out" + "dev" + ]; + + postPatch = + let + toDisable = + [ + "getnameinfo_basic" + "udp_send_hang_loop" # probably network-dependent + "tcp_connect_timeout" # tries to reach out to 8.8.8.8 + "spawn_setuid_fails" + "spawn_setgid_fails" + "fs_chown" # user namespaces + "getaddrinfo_fail" + "getaddrinfo_fail_sync" + "tcp_connect6_link_local" + "threadpool_multiple_event_loops" # times out on slow machines + "get_passwd" # passed on NixOS but failed on other Linuxes + "tcp_writealot" + "udp_multicast_join" + "udp_multicast_join6" + "metrics_pool_events" # times out sometimes + "fs_fstat" # https://github.com/libuv/libuv/issues/2235#issuecomment-1012086927 + + # Assertion failed in test/test-tcp-bind6-error.c on line 60: r == UV_EADDRINUSE + # Assertion failed in test/test-tcp-bind-error.c on line 99: r == UV_EADDRINUSE + "tcp_bind6_error_addrinuse" + "tcp_bind_error_addrinuse_listen" + # https://github.com/libuv/libuv/pull/4075#issuecomment-1935572237 + "thread_priority" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # Sometimes: timeout (no output), failed uv_listen. Someone + # should report these failures to libuv team. There tests should + # be much more robust. + "process_title" + "emfile" + "poll_duplex" + "poll_unidirectional" + "ipc_listen_before_write" + "ipc_listen_after_write" + "ipc_tcp_connection" + "tcp_alloc_cb_fail" + "tcp_ping_pong" + "tcp_ref3" + "tcp_ref4" + "tcp_bind6_error_inval" + "tcp_bind6_error_addrinuse" + "tcp_read_stop" + "tcp_unexpected_read" + "tcp_write_to_half_open_connection" + "tcp_oob" + "tcp_close_accept" + "tcp_create_early_accept" + "tcp_create_early" + "tcp_close" + "tcp_bind_error_inval" + "tcp_bind_error_addrinuse" + "tcp_shutdown_after_write" + "tcp_open" + "tcp_write_queue_order" + "tcp_try_write" + "tcp_writealot" + "multiple_listen" + "delayed_accept" + "udp_recv_in_a_row" + "shutdown_close_tcp" + "shutdown_eof" + "shutdown_twice" + "callback_stack" + "tty_pty" + "condvar_5" + "hrtime" + "udp_multicast_join" + # Tests that fail when sandboxing is enabled. + "fs_event_close_in_callback" + "fs_event_watch_dir" + "fs_event_error_reporting" + "fs_event_watch_dir_recursive" + "fs_event_watch_file" + "fs_event_watch_file_current_dir" + "fs_event_watch_file_exact_path" + "process_priority" + "udp_create_early_bad_bind" + "fs_event_watch_delete_dir" + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + # fail on macos < 10.15 (starting in libuv 1.47.0) + "fs_write_alotof_bufs_with_offset" + "fs_write_multiple_bufs" + "fs_read_bufs" + ] + ++ lib.optionals stdenv.hostPlatform.isAarch32 [ + # I observe this test failing with some regularity on ARMv7: + # https://github.com/libuv/libuv/issues/1871 + "shutdown_close_pipe" + ] + ++ lib.optionals stdenv.hostPlatform.isFreeBSD [ + # EOPNOTSUPP when performed in jailed build env + "tcp_reuseport" + "udp_reuseport" + # Fails when built on non-nix FreeBSD + # https://github.com/libuv/libuv/issues/4606 + "fs_event_watch_delete_dir" + ]; + tdRegexp = lib.concatStringsSep "\\|" toDisable; + in + lib.optionalString (finalAttrs.finalPackage.doCheck) '' sed '/${tdRegexp}/d' -i test/test-list.h ''; - nativeBuildInputs = [ automake autoconf libtool pkg-config ]; + nativeBuildInputs = [ + automake + autoconf + libtool + pkg-config + ]; # This is part of the Darwin bootstrap, so we don’t always get # `libutil.dylib` automatically propagated through the SDK. @@ -118,7 +178,14 @@ stdenv.mkDerivation (finalAttrs: { __darwinAllowLocalNetworking = true; passthru.tests = { - inherit bind cmake knot-resolver mosquitto neovim nodejs; + inherit + bind + cmake + knot-resolver + mosquitto + neovim + nodejs + ; inherit (sbclPackages) cl-libuv; luajit-libluv = luajitPackages.libluv; luajit-luv = luajitPackages.luv; @@ -131,12 +198,18 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Multi-platform support library with a focus on asynchronous I/O"; - homepage = "https://libuv.org/"; - changelog = "https://github.com/libuv/libuv/blob/v${finalAttrs.version}/ChangeLog"; + homepage = "https://libuv.org/"; + changelog = "https://github.com/libuv/libuv/blob/v${finalAttrs.version}/ChangeLog"; pkgConfigModules = [ "libuv" ]; maintainers = [ ]; - platforms = platforms.all; - license = with licenses; [ mit isc bsd2 bsd3 cc-by-40 ]; + platforms = platforms.all; + license = with licenses; [ + mit + isc + bsd2 + bsd3 + cc-by-40 + ]; }; }) diff --git a/pkgs/development/libraries/libva/1.nix b/pkgs/development/libraries/libva/1.nix index 15e4d0a9e8017d..05680090878ac1 100644 --- a/pkgs/development/libraries/libva/1.nix +++ b/pkgs/development/libraries/libva/1.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, libX11 -, pkg-config -, libXext -, libdrm -, libXfixes -, wayland -, wayland-scanner -, libffi -, libGL -, mesa -, minimal ? false -, libva1-minimal +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + libX11, + pkg-config, + libXext, + libdrm, + libXfixes, + wayland, + wayland-scanner, + libffi, + libGL, + mesa, + minimal ? false, + libva1-minimal, }: stdenv.mkDerivation rec { @@ -28,16 +29,35 @@ stdenv.mkDerivation rec { sha256 = "sha256-ur59cqdZqXIY2dDUSie9XsxyRomVBxIW2IVKAgWYC38="; }; - outputs = [ "dev" "out" ]; + outputs = [ + "dev" + "out" + ]; - nativeBuildInputs = [ autoreconfHook pkg-config wayland-scanner ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + wayland-scanner + ]; - buildInputs = [ libdrm ] - ++ lib.optionals (!minimal) [ libva1-minimal libX11 libXext libXfixes wayland libffi libGL ]; + buildInputs = + [ libdrm ] + ++ lib.optionals (!minimal) [ + libva1-minimal + libX11 + libXext + libXfixes + wayland + libffi + libGL + ]; # TODO: share libs between minimal and !minimal - perhaps just symlink them # Add FHS paths for non-NixOS applications. - configureFlags = lib.optionals stdenv.hostPlatform.isLinux [ "--with-drivers-path=${mesa.driverLink}/lib/dri:/usr/lib/dri:/usr/lib32/dri" ] + configureFlags = + lib.optionals stdenv.hostPlatform.isLinux [ + "--with-drivers-path=${mesa.driverLink}/lib/dri:/usr/lib/dri:/usr/lib32/dri" + ] ++ lib.optionals (!minimal) [ "--enable-glx" ]; installFlags = [ "dummy_drv_video_ladir=$(out)/lib/dri" ]; diff --git a/pkgs/development/libraries/libva/default.nix b/pkgs/development/libraries/libva/default.nix index f88404682b44c9..9fd523a70610c0 100644 --- a/pkgs/development/libraries/libva/default.nix +++ b/pkgs/development/libraries/libva/default.nix @@ -1,15 +1,27 @@ -{ stdenv, lib, fetchFromGitHub, meson, pkg-config, ninja, wayland-scanner -, libdrm -, minimal ? false -, libX11, libXext, libXfixes, wayland, libffi, libGL -, mesa -# for passthru.tests -, intel-compute-runtime -, intel-media-driver -, mpv -, intel-vaapi-driver -, vlc -, testers +{ + stdenv, + lib, + fetchFromGitHub, + meson, + pkg-config, + ninja, + wayland-scanner, + libdrm, + minimal ? false, + libX11, + libXext, + libXfixes, + wayland, + libffi, + libGL, + mesa, + # for passthru.tests + intel-compute-runtime, + intel-media-driver, + mpv, + intel-vaapi-driver, + vlc, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -17,37 +29,60 @@ stdenv.mkDerivation (finalAttrs: { version = "2.22.0"; src = fetchFromGitHub { - owner = "intel"; - repo = "libva"; - rev = finalAttrs.version; + owner = "intel"; + repo = "libva"; + rev = finalAttrs.version; sha256 = "sha256-0eOYxyMt2M2lkhoWOhoUQgP/1LYY3QQqSF5TdRUuCbs="; }; - outputs = [ "dev" "out" ]; + outputs = [ + "dev" + "out" + ]; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson pkg-config ninja ] - ++ lib.optional (!minimal) wayland-scanner; + nativeBuildInputs = [ + meson + pkg-config + ninja + ] ++ lib.optional (!minimal) wayland-scanner; - buildInputs = [ libdrm ] - ++ lib.optionals (!minimal) [ libX11 libXext libXfixes wayland libffi libGL ]; + buildInputs = + [ libdrm ] + ++ lib.optionals (!minimal) [ + libX11 + libXext + libXfixes + wayland + libffi + libGL + ]; mesonFlags = lib.optionals stdenv.hostPlatform.isLinux [ # Add FHS and Debian paths for non-NixOS applications "-Ddriverdir=${mesa.driverLink}/lib/dri:/usr/lib/dri:/usr/lib32/dri:/usr/lib/x86_64-linux-gnu/dri:/usr/lib/i386-linux-gnu/dri" ]; - env = lib.optionalAttrs (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") { - NIX_LDFLAGS = "--undefined-version"; - } // lib.optionalAttrs (stdenv.targetPlatform.useLLVM or false) { - NIX_CFLAGS_COMPILE = "-DHAVE_SECURE_GETENV"; - }; + env = + lib.optionalAttrs (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") + { + NIX_LDFLAGS = "--undefined-version"; + } + // lib.optionalAttrs (stdenv.targetPlatform.useLLVM or false) { + NIX_CFLAGS_COMPILE = "-DHAVE_SECURE_GETENV"; + }; passthru.tests = { # other drivers depending on libva and selected application users. # Please get a confirmation from the maintainer before adding more applications. - inherit intel-compute-runtime intel-media-driver intel-vaapi-driver mpv vlc; + inherit + intel-compute-runtime + intel-media-driver + intel-vaapi-driver + mpv + vlc + ; pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; }; @@ -63,9 +98,16 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://raw.githubusercontent.com/intel/libva/${finalAttrs.version}/NEWS"; license = licenses.mit; maintainers = with maintainers; [ SuperSandro2000 ]; - pkgConfigModules = [ "libva" "libva-drm" ] ++ lib.optionals (!minimal) [ - "libva-glx" "libva-wayland" "libva-x11" - ]; + pkgConfigModules = + [ + "libva" + "libva-drm" + ] + ++ lib.optionals (!minimal) [ + "libva-glx" + "libva-wayland" + "libva-x11" + ]; platforms = platforms.unix; badPlatforms = [ # Mandatory libva shared library. diff --git a/pkgs/development/libraries/libva/utils.nix b/pkgs/development/libraries/libva/utils.nix index 96373327ca0edc..1be8fd098fce16 100644 --- a/pkgs/development/libraries/libva/utils.nix +++ b/pkgs/development/libraries/libva/utils.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, pkg-config -, libdrm, libva, libX11, libXext, libXfixes, wayland +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + libdrm, + libva, + libX11, + libXext, + libXfixes, + wayland, }: stdenv.mkDerivation rec { @@ -7,15 +18,26 @@ stdenv.mkDerivation rec { version = "2.22.0"; src = fetchFromGitHub { - owner = "intel"; - repo = "libva-utils"; - rev = version; + owner = "intel"; + repo = "libva-utils"; + rev = version; sha256 = "sha256-CmhdhNNRO2j8lH7awp9YiKWMvV17GTBsXdrNY06jT2w="; }; - nativeBuildInputs = [ meson ninja pkg-config ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; - buildInputs = [ libdrm libva libX11 libXext libXfixes wayland ]; + buildInputs = [ + libdrm + libva + libX11 + libXext + libXfixes + wayland + ]; meta = with lib; { description = "Collection of utilities and examples for VA-API"; diff --git a/pkgs/development/libraries/libvncserver/default.nix b/pkgs/development/libraries/libvncserver/default.nix index e6b5bf4acb5b6a..29dd629480010f 100644 --- a/pkgs/development/libraries/libvncserver/default.nix +++ b/pkgs/development/libraries/libvncserver/default.nix @@ -1,22 +1,26 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libjpeg -, openssl -, zlib -, libgcrypt -, libpng -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, systemd -, Carbon +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libjpeg, + openssl, + zlib, + libgcrypt, + libpng, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + Carbon, }: stdenv.mkDerivation rec { pname = "libvncserver"; version = "0.9.14"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "LibVNC"; @@ -38,16 +42,19 @@ stdenv.mkDerivation rec { "-DWITH_SYSTEMD=${if withSystemd then "ON" else "OFF"}" ]; - buildInputs = [ - libjpeg - openssl - libgcrypt - libpng - ] ++ lib.optionals withSystemd [ - systemd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Carbon - ]; + buildInputs = + [ + libjpeg + openssl + libgcrypt + libpng + ] + ++ lib.optionals withSystemd [ + systemd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + ]; propagatedBuildInputs = [ zlib diff --git a/pkgs/development/libraries/libwnck/2.nix b/pkgs/development/libraries/libwnck/2.nix index 890b1a7651a8b2..5a15b05cee6a4e 100644 --- a/pkgs/development/libraries/libwnck/2.nix +++ b/pkgs/development/libraries/libwnck/2.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, gtk2, intltool, xorg }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk2, + intltool, + xorg, +}: stdenv.mkDerivation rec { pname = "libwnck"; @@ -9,11 +17,22 @@ stdenv.mkDerivation rec { sha256 = "17isfjvrzgj5znld2a7zsk9vd39q9wnsysnw5jr8iz410z935xw3"; }; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "dev"; - nativeBuildInputs = [ pkg-config intltool ]; - buildInputs = [ gtk2 xorg.libX11 xorg.libXres ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; + buildInputs = [ + gtk2 + xorg.libX11 + xorg.libXres + ]; # ?another optional: startup-notification configureFlags = [ "--disable-introspection" ]; # not needed anywhere AFAIK diff --git a/pkgs/development/libraries/libwnck/default.nix b/pkgs/development/libraries/libwnck/default.nix index 25b2be3db4a29d..853b3f45ddf07a 100644 --- a/pkgs/development/libraries/libwnck/default.nix +++ b/pkgs/development/libraries/libwnck/default.nix @@ -1,30 +1,35 @@ -{ stdenv -, lib -, fetchurl -, meson -, mesonEmulatorHook -, ninja -, pkg-config -, gtk-doc -, docbook_xsl -, docbook_xml_dtd_412 -, libX11 -, glib -, gtk3 -, pango -, cairo -, libXres -, libstartup_notification -, gettext -, gobject-introspection -, gnome +{ + stdenv, + lib, + fetchurl, + meson, + mesonEmulatorHook, + ninja, + pkg-config, + gtk-doc, + docbook_xsl, + docbook_xml_dtd_412, + libX11, + glib, + gtk3, + pango, + cairo, + libXres, + libstartup_notification, + gettext, + gobject-introspection, + gnome, }: stdenv.mkDerivation rec { pname = "libwnck"; version = "43.1"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; outputBin = "dev"; src = fetchurl { @@ -32,18 +37,20 @@ stdenv.mkDerivation rec { sha256 = "Y0tFh7c2ekk9OBjEtXdA2sBhU8+PJc1k9a8WtlfdaEU="; }; - nativeBuildInputs = [ - meson - ninja - pkg-config - gettext - gobject-introspection - gtk-doc - docbook_xsl - docbook_xml_dtd_412 - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + gettext + gobject-introspection + gtk-doc + docbook_xsl + docbook_xml_dtd_412 + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; buildInputs = [ libX11 diff --git a/pkgs/development/libraries/libwpd/0.8.nix b/pkgs/development/libraries/libwpd/0.8.nix index abac656f8e4737..5c5e7307192ba3 100644 --- a/pkgs/development/libraries/libwpd/0.8.nix +++ b/pkgs/development/libraries/libwpd/0.8.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, glib, libgsf, libxml2, bzip2 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + glib, + libgsf, + libxml2, + bzip2, +}: stdenv.mkDerivation rec { pname = "libwpd"; @@ -11,14 +20,24 @@ stdenv.mkDerivation rec { patches = [ ./gcc-0.8.patch ]; - buildInputs = [ glib libgsf libxml2 ]; + buildInputs = [ + glib + libgsf + libxml2 + ]; - nativeBuildInputs = [ pkg-config bzip2 ]; + nativeBuildInputs = [ + pkg-config + bzip2 + ]; meta = with lib; { description = "Library for importing WordPerfect documents"; homepage = "https://libwpd.sourceforge.net"; - license = with licenses; [ lgpl21 mpl20 ]; + license = with licenses; [ + lgpl21 + mpl20 + ]; platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/libwpd/default.nix b/pkgs/development/libraries/libwpd/default.nix index 0aa0b746978c8a..4ed68e09b4a763 100644 --- a/pkgs/development/libraries/libwpd/default.nix +++ b/pkgs/development/libraries/libwpd/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, zlib, pkg-config, glib, libgsf, libxml2, librevenge, boost }: +{ + lib, + stdenv, + fetchurl, + zlib, + pkg-config, + glib, + libgsf, + libxml2, + librevenge, + boost, +}: stdenv.mkDerivation rec { pname = "libwpd"; @@ -11,7 +22,14 @@ stdenv.mkDerivation rec { patches = [ ./gcc-1.0.patch ]; - buildInputs = [ glib libgsf libxml2 zlib librevenge boost ]; + buildInputs = [ + glib + libgsf + libxml2 + zlib + librevenge + boost + ]; nativeBuildInputs = [ pkg-config ]; diff --git a/pkgs/development/libraries/libwpe/default.nix b/pkgs/development/libraries/libwpe/default.nix index c78ee91a20926a..ece4d3997a51d9 100644 --- a/pkgs/development/libraries/libwpe/default.nix +++ b/pkgs/development/libraries/libwpe/default.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchurl -, meson -, pkg-config -, libxkbcommon -, libGL -, ninja -, libX11 +{ + stdenv, + lib, + fetchurl, + meson, + pkg-config, + libxkbcommon, + libGL, + ninja, + libX11, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/libwpe/fdo.nix b/pkgs/development/libraries/libwpe/fdo.nix index d4e743ee28556b..b7f09b7ebb7b6f 100644 --- a/pkgs/development/libraries/libwpe/fdo.nix +++ b/pkgs/development/libraries/libwpe/fdo.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchurl -, meson -, pkg-config -, ninja -, wayland-scanner -, wayland -, libepoxy -, glib -, libwpe -, libxkbcommon -, libGL -, libX11 - }: +{ + stdenv, + lib, + fetchurl, + meson, + pkg-config, + ninja, + wayland-scanner, + wayland, + libepoxy, + glib, + libwpe, + libxkbcommon, + libGL, + libX11, +}: stdenv.mkDerivation rec { pname = "wpebackend-fdo"; diff --git a/pkgs/development/libraries/libxcrypt/default.nix b/pkgs/development/libraries/libxcrypt/default.nix index efd3acb643fbe3..571f18db3c4f8f 100644 --- a/pkgs/development/libraries/libxcrypt/default.nix +++ b/pkgs/development/libraries/libxcrypt/default.nix @@ -1,9 +1,13 @@ -{ lib, stdenv, fetchurl, perl -# Update the enabled crypt scheme ids in passthru when the enabled hashes change -, enableHashes ? "strong" -, nixosTests -, runCommand -, python3 +{ + lib, + stdenv, + fetchurl, + perl, + # Update the enabled crypt scheme ids in passthru when the enabled hashes change + enableHashes ? "strong", + nixosTests, + runCommand, + python3, }: stdenv.mkDerivation (finalAttrs: { @@ -34,18 +38,18 @@ stdenv.mkDerivation (finalAttrs: { "--disable-werror" ]; - makeFlags = let - lld17Plus = stdenv.cc.bintools.isLLVM - && lib.versionAtLeast stdenv.cc.bintools.version "17"; - in [] + makeFlags = + let + lld17Plus = stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17"; + in + [ ] # fixes: can't build x86_64-w64-mingw32 shared library unless -no-undefined is specified ++ lib.optionals stdenv.hostPlatform.isWindows [ "LDFLAGS+=-no-undefined" ] # lld 17 sets `--no-undefined-version` by default and `libxcrypt`'s # version script unconditionally lists legacy compatibility symbols, even # when not exported: https://github.com/besser82/libxcrypt/issues/181 - ++ lib.optionals lld17Plus [ "LDFLAGS+=-Wl,--undefined-version" ] - ; + ++ lib.optionals lld17Plus [ "LDFLAGS+=-Wl,--undefined-version" ]; nativeBuildInputs = [ perl @@ -60,19 +64,28 @@ stdenv.mkDerivation (finalAttrs: { inherit (nixosTests) login shadow; passthruMatches = runCommand "libxcrypt-test-passthru-matches" { } '' - ${python3.interpreter} "${./check_passthru_matches.py}" ${lib.escapeShellArgs ([ finalAttrs.src enableHashes "--" ] ++ finalAttrs.passthru.enabledCryptSchemeIds)} + ${python3.interpreter} "${./check_passthru_matches.py}" ${ + lib.escapeShellArgs ( + [ + finalAttrs.src + enableHashes + "--" + ] + ++ finalAttrs.passthru.enabledCryptSchemeIds + ) + } touch "$out" ''; }; enabledCryptSchemeIds = [ # https://github.com/besser82/libxcrypt/blob/v4.4.35/lib/hashes.conf - "y" # yescrypt - "gy" # gost_yescrypt - "7" # scrypt - "2b" # bcrypt - "2y" # bcrypt_y - "2a" # bcrypt_a - "6" # sha512crypt + "y" # yescrypt + "gy" # gost_yescrypt + "7" # scrypt + "2b" # bcrypt + "2y" # bcrypt_y + "2a" # bcrypt_a + "6" # sha512crypt ]; }; @@ -81,7 +94,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Extended crypt library for descrypt, md5crypt, bcrypt, and others"; homepage = "https://github.com/besser82/libxcrypt/"; platforms = platforms.all; - maintainers = with maintainers; [ dottedmag hexa ]; + maintainers = with maintainers; [ + dottedmag + hexa + ]; license = licenses.lgpl21Plus; }; }) diff --git a/pkgs/development/libraries/libxml2/default.nix b/pkgs/development/libraries/libxml2/default.nix index 6924c71fab662c..b696dbffcefc93 100644 --- a/pkgs/development/libraries/libxml2/default.nix +++ b/pkgs/development/libraries/libxml2/default.nix @@ -1,32 +1,45 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, autoreconfHook -, libintl -, python -, gettext -, ncurses -, findXMLCatalogs -, libiconv -# Python limits cross-compilation to an allowlist of host OSes. -# https://github.com/python/cpython/blob/dfad678d7024ab86d265d84ed45999e031a03691/configure.ac#L534-L562 -, pythonSupport ? enableShared && - (stdenv.hostPlatform == stdenv.buildPlatform || stdenv.hostPlatform.isCygwin || stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isWasi) -, icuSupport ? false -, icu -, enableShared ? !stdenv.hostPlatform.isMinGW && !stdenv.hostPlatform.isStatic -, enableStatic ? !enableShared -, gnome -, testers -, enableHttp ? false +{ + stdenv, + lib, + fetchurl, + pkg-config, + autoreconfHook, + libintl, + python, + gettext, + ncurses, + findXMLCatalogs, + libiconv, + # Python limits cross-compilation to an allowlist of host OSes. + # https://github.com/python/cpython/blob/dfad678d7024ab86d265d84ed45999e031a03691/configure.ac#L534-L562 + pythonSupport ? + enableShared + && ( + stdenv.hostPlatform == stdenv.buildPlatform + || stdenv.hostPlatform.isCygwin + || stdenv.hostPlatform.isLinux + || stdenv.hostPlatform.isWasi + ), + icuSupport ? false, + icu, + enableShared ? !stdenv.hostPlatform.isMinGW && !stdenv.hostPlatform.isStatic, + enableStatic ? !enableShared, + gnome, + testers, + enableHttp ? false, }: stdenv.mkDerivation (finalAttrs: { pname = "libxml2"; version = "2.13.4"; - outputs = [ "bin" "dev" "out" "devdoc" ] + outputs = + [ + "bin" + "dev" + "out" + "devdoc" + ] ++ lib.optional pythonSupport "py" ++ lib.optional (enableStatic && enableShared) "static"; outputMan = "bin"; @@ -43,23 +56,30 @@ stdenv.mkDerivation (finalAttrs: { autoreconfHook ]; - buildInputs = lib.optionals pythonSupport [ - python - ] ++ lib.optionals (pythonSupport && python?isPy2 && python.isPy2) [ - gettext - ] ++ lib.optionals (pythonSupport && python?isPy3 && python.isPy3) [ - ncurses - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && pythonSupport && python?isPy2 && python.isPy2) [ - libintl - ]; - - propagatedBuildInputs = [ - findXMLCatalogs - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - ] ++ lib.optionals icuSupport [ - icu - ]; + buildInputs = + lib.optionals pythonSupport [ + python + ] + ++ lib.optionals (pythonSupport && python ? isPy2 && python.isPy2) [ + gettext + ] + ++ lib.optionals (pythonSupport && python ? isPy3 && python.isPy3) [ + ncurses + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && pythonSupport && python ? isPy2 && python.isPy2) [ + libintl + ]; + + propagatedBuildInputs = + [ + findXMLCatalogs + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + ] + ++ lib.optionals icuSupport [ + icu + ]; configureFlags = [ "--exec-prefix=${placeholder "dev"}" @@ -77,9 +97,7 @@ stdenv.mkDerivation (finalAttrs: { enableParallelBuilding = true; - doCheck = - (stdenv.hostPlatform == stdenv.buildPlatform) && - stdenv.hostPlatform.libc != "musl"; + doCheck = (stdenv.hostPlatform == stdenv.buildPlatform) && stdenv.hostPlatform.libc != "musl"; preCheck = lib.optional stdenv.hostPlatform.isDarwin '' export DYLD_LIBRARY_PATH="$PWD/.libs:$DYLD_LIBRARY_PATH" ''; @@ -92,12 +110,14 @@ stdenv.mkDerivation (finalAttrs: { substituteInPlace python/libxml2mod.la --replace-fail "$dev/${python.sitePackages}" "$py/${python.sitePackages}" ''; - postFixup = '' - moveToOutput bin/xml2-config "$dev" - moveToOutput lib/xml2Conf.sh "$dev" - '' + lib.optionalString (enableStatic && enableShared) '' - moveToOutput lib/libxml2.a "$static" - ''; + postFixup = + '' + moveToOutput bin/xml2-config "$dev" + moveToOutput lib/xml2Conf.sh "$dev" + '' + + lib.optionalString (enableStatic && enableShared) '' + moveToOutput lib/libxml2.a "$static" + ''; passthru = { inherit pythonSupport; diff --git a/pkgs/development/libraries/libxmlxx/default.nix b/pkgs/development/libraries/libxmlxx/default.nix index 5d55e242f00647..d2739a61551a7e 100644 --- a/pkgs/development/libraries/libxmlxx/default.nix +++ b/pkgs/development/libraries/libxmlxx/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, libxml2, glibmm, perl, gnome }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libxml2, + glibmm, + perl, + gnome, +}: stdenv.mkDerivation rec { pname = "libxml++"; @@ -14,11 +23,20 @@ stdenv.mkDerivation rec { "CXXFLAGS=-std=c++11" ]; - outputs = [ "out" "devdoc" ]; + outputs = [ + "out" + "devdoc" + ]; - nativeBuildInputs = [ pkg-config perl ]; + nativeBuildInputs = [ + pkg-config + perl + ]; - propagatedBuildInputs = [ libxml2 glibmm ]; + propagatedBuildInputs = [ + libxml2 + glibmm + ]; passthru = { updateScript = gnome.updateScript { diff --git a/pkgs/development/libraries/liquid-dsp/default.nix b/pkgs/development/libraries/liquid-dsp/default.nix index 0700b645e30ab6..2540eb9520f7f0 100644 --- a/pkgs/development/libraries/liquid-dsp/default.nix +++ b/pkgs/development/libraries/liquid-dsp/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, cctools -, autoSignDarwinBinariesHook -, fixDarwinDylibNames +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + cctools, + autoSignDarwinBinariesHook, + fixDarwinDylibNames, }: stdenv.mkDerivation rec { @@ -20,8 +21,13 @@ stdenv.mkDerivation rec { configureFlags = lib.optionals stdenv.hostPlatform.isDarwin [ "LIBTOOL=${cctools}/bin/libtool" ]; - nativeBuildInputs = [ autoreconfHook ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools autoSignDarwinBinariesHook fixDarwinDylibNames ]; + nativeBuildInputs = + [ autoreconfHook ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + cctools + autoSignDarwinBinariesHook + fixDarwinDylibNames + ]; meta = { homepage = "https://liquidsdr.org/"; diff --git a/pkgs/development/libraries/luabind/default.nix b/pkgs/development/libraries/luabind/default.nix index a6ce0903469d7c..e498602061c537 100644 --- a/pkgs/development/libraries/luabind/default.nix +++ b/pkgs/development/libraries/luabind/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, lua, boost, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + lua, + boost, + cmake, +}: stdenv.mkDerivation rec { pname = "luabind"; @@ -21,7 +28,7 @@ stdenv.mkDerivation rec { inherit lua; }; - patches = [./0.9.1-discover-luajit.patch]; + patches = [ ./0.9.1-discover-luajit.patch ]; meta = { homepage = "https://github.com/Oberon00/luabind"; diff --git a/pkgs/development/libraries/luksmeta/default.nix b/pkgs/development/libraries/luksmeta/default.nix index 976f6f188269e7..0968c5374a8f1f 100644 --- a/pkgs/development/libraries/luksmeta/default.nix +++ b/pkgs/development/libraries/luksmeta/default.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, asciidoc -, cryptsetup +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + asciidoc, + cryptsetup, }: stdenv.mkDerivation rec { @@ -13,7 +19,11 @@ stdenv.mkDerivation rec { sha256 = "10nslwk7m1qwskd12c204ipa3cbad0q6fn0v084z2f7q6xxbkd2d"; }; - nativeBuildInputs = [ autoreconfHook pkg-config asciidoc ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + asciidoc + ]; buildInputs = [ cryptsetup ]; meta = { diff --git a/pkgs/development/libraries/mailcore2/default.nix b/pkgs/development/libraries/mailcore2/default.nix index 1381a48315df43..60708ed7a4a258 100644 --- a/pkgs/development/libraries/mailcore2/default.nix +++ b/pkgs/development/libraries/mailcore2/default.nix @@ -1,6 +1,20 @@ -{ stdenv, lib, fetchFromGitHub, cmake, libetpan, icu, cyrus_sasl, libctemplate -, libuchardet, pkg-config, glib, html-tidy, libxml2, libuuid, openssl -, darwin +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + libetpan, + icu, + cyrus_sasl, + libctemplate, + libuchardet, + pkg-config, + glib, + html-tidy, + libxml2, + libuuid, + openssl, + darwin, }: stdenv.mkDerivation rec { @@ -9,38 +23,51 @@ stdenv.mkDerivation rec { version = "0.6.4"; src = fetchFromGitHub { - owner = "MailCore"; - repo = "mailcore2"; - rev = version; + owner = "MailCore"; + repo = "mailcore2"; + rev = version; sha256 = "0a69q11z194fdfwyazjyyylx57sqs9j4lz7jwh5qcws8syqgb23z"; }; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ - libetpan cyrus_sasl libctemplate libuchardet - html-tidy libxml2 openssl - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - glib - icu - libuuid - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Foundation + nativeBuildInputs = [ + cmake + pkg-config ]; + buildInputs = + [ + libetpan + cyrus_sasl + libctemplate + libuchardet + html-tidy + libxml2 + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + glib + icu + libuuid + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Foundation + ]; - postPatch = '' - substituteInPlace CMakeLists.txt \ - --replace " icule iculx" "" \ - --replace "tidy/tidy.h" "tidy.h" \ - --replace "/usr/include/tidy" "${html-tidy}/include" \ - --replace "/usr/include/libxml2" "${libxml2.dev}/include/libxml2" - substituteInPlace src/core/basetypes/MCHTMLCleaner.cpp \ - --replace buffio.h tidybuffio.h - substituteInPlace src/core/basetypes/MCString.cpp \ - --replace "xmlErrorPtr" "const xmlError *" - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - substituteInPlace src/core/basetypes/MCICUTypes.h \ - --replace "__CHAR16_TYPE__ UChar" "char16_t UChar" - ''; + postPatch = + '' + substituteInPlace CMakeLists.txt \ + --replace " icule iculx" "" \ + --replace "tidy/tidy.h" "tidy.h" \ + --replace "/usr/include/tidy" "${html-tidy}/include" \ + --replace "/usr/include/libxml2" "${libxml2.dev}/include/libxml2" + substituteInPlace src/core/basetypes/MCHTMLCleaner.cpp \ + --replace buffio.h tidybuffio.h + substituteInPlace src/core/basetypes/MCString.cpp \ + --replace "xmlErrorPtr" "const xmlError *" + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + substituteInPlace src/core/basetypes/MCICUTypes.h \ + --replace "__CHAR16_TYPE__ UChar" "char16_t UChar" + ''; cmakeFlags = lib.optionals (!stdenv.hostPlatform.isDarwin) [ "-DBUILD_SHARED_LIBS=ON" @@ -64,9 +91,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Simple and asynchronous API to work with e-mail protocols IMAP, POP and SMTP"; - homepage = "http://libmailcore.com"; - license = licenses.bsd3; + homepage = "http://libmailcore.com"; + license = licenses.bsd3; maintainers = [ ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/malcontent/ui.nix b/pkgs/development/libraries/malcontent/ui.nix index cf421bd11c1988..3e76f3a2e7f30c 100644 --- a/pkgs/development/libraries/malcontent/ui.nix +++ b/pkgs/development/libraries/malcontent/ui.nix @@ -1,21 +1,23 @@ -{ lib, stdenv -, meson -, ninja -, pkg-config -, gobject-introspection -, itstool -, wrapGAppsHook4 -, glib -, accountsservice -, dbus -, flatpak -, malcontent -, gtk4 -, libadwaita -, appstream -, desktop-file-utils -, polkit -, glib-testing +{ + lib, + stdenv, + meson, + ninja, + pkg-config, + gobject-introspection, + itstool, + wrapGAppsHook4, + glib, + accountsservice, + dbus, + flatpak, + malcontent, + gtk4, + libadwaita, + appstream, + desktop-file-utils, + polkit, + glib-testing, }: stdenv.mkDerivation rec { @@ -23,7 +25,11 @@ stdenv.mkDerivation rec { inherit (malcontent) version src; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; patches = [ # Allow installing installed tests to a separate output. diff --git a/pkgs/development/libraries/mapbox-gl-native/default.nix b/pkgs/development/libraries/mapbox-gl-native/default.nix index 01d51bdf7461a3..0f106cfe4cb69a 100644 --- a/pkgs/development/libraries/mapbox-gl-native/default.nix +++ b/pkgs/development/libraries/mapbox-gl-native/default.nix @@ -1,5 +1,16 @@ -{ lib, mkDerivation, fetchFromGitHub, fetchpatch, cmake, pkg-config -, qtbase, curl, libuv, glfw3, rapidjson }: +{ + lib, + mkDerivation, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + qtbase, + curl, + libuv, + glfw3, + rapidjson, +}: mkDerivation rec { pname = "mapbox-gl-native"; @@ -47,8 +58,17 @@ mkDerivation rec { rm -r vendor/mapbox-base/extras/rapidjson ''; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ curl libuv glfw3 qtbase rapidjson ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + curl + libuv + glfw3 + qtbase + rapidjson + ]; cmakeFlags = [ "-DMBGL_WITH_QT=ON" @@ -63,7 +83,10 @@ mkDerivation rec { description = "Interactive, thoroughly customizable maps in native Android, iOS, macOS, Node.js, and Qt applications, powered by vector tiles and OpenGL"; homepage = "https://mapbox.com/mobile"; license = licenses.bsd2; - maintainers = with maintainers; [ Thra11 dotlambda ]; + maintainers = with maintainers; [ + Thra11 + dotlambda + ]; platforms = platforms.linux; }; } diff --git a/pkgs/development/libraries/maplibre-gl-native/default.nix b/pkgs/development/libraries/maplibre-gl-native/default.nix index 3b2e988d47953b..047a358254eb3a 100644 --- a/pkgs/development/libraries/maplibre-gl-native/default.nix +++ b/pkgs/development/libraries/maplibre-gl-native/default.nix @@ -1,16 +1,17 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, fetchpatch -, fetchpatch2 -, cmake -, pkg-config -, qtbase -, curl -, libuv -, glfw3 -, rapidjson -, stdenv +{ + lib, + mkDerivation, + fetchFromGitHub, + fetchpatch, + fetchpatch2, + cmake, + pkg-config, + qtbase, + curl, + libuv, + glfw3, + rapidjson, + stdenv, }: mkDerivation rec { @@ -62,10 +63,12 @@ mkDerivation rec { "-DMBGL_WITH_QT_HEADLESS=OFF" ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ - # Needed with GCC 12 but problematic with some old GCCs - "-Wno-error=use-after-free" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ + # Needed with GCC 12 but problematic with some old GCCs + "-Wno-error=use-after-free" + ] + ); meta = with lib; { description = "Open-source alternative to Mapbox GL Native"; diff --git a/pkgs/development/libraries/maui-core/default.nix b/pkgs/development/libraries/maui-core/default.nix index 901b26f4e646a0..4a5658fa26587f 100644 --- a/pkgs/development/libraries/maui-core/default.nix +++ b/pkgs/development/libraries/maui-core/default.nix @@ -1,12 +1,13 @@ -{ lib -, mkDerivation -, libcanberra -, pulseaudio -, fetchFromGitHub -, cmake -, extra-cmake-modules -, kio -, kidletime +{ + lib, + mkDerivation, + libcanberra, + pulseaudio, + fetchFromGitHub, + cmake, + extra-cmake-modules, + kio, + kidletime, }: mkDerivation rec { diff --git a/pkgs/development/libraries/mbedtls/generic.nix b/pkgs/development/libraries/mbedtls/generic.nix index 14545a2710fc11..d2a0206dde2dbe 100644 --- a/pkgs/development/libraries/mbedtls/generic.nix +++ b/pkgs/development/libraries/mbedtls/generic.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, version -, hash -, patches ? [] -, fetchFromGitHub +{ + lib, + stdenv, + version, + hash, + patches ? [ ], + fetchFromGitHub, -, cmake -, ninja -, perl # Project uses Perl for scripting and testing -, python3 + cmake, + ninja, + perl, # Project uses Perl for scripting and testing + python3, -, enableThreading ? true # Threading can be disabled to increase security https://tls.mbed.org/kb/development/thread-safety-and-multi-threading + enableThreading ? true, # Threading can be disabled to increase security https://tls.mbed.org/kb/development/thread-safety-and-multi-threading }: stdenv.mkDerivation rec { @@ -28,7 +29,12 @@ stdenv.mkDerivation rec { inherit patches; - nativeBuildInputs = [ cmake ninja perl python3 ]; + nativeBuildInputs = [ + cmake + ninja + perl + python3 + ]; strictDeps = true; @@ -47,9 +53,11 @@ stdenv.mkDerivation rec { "-DGEN_FILES=off" ]; - env = lib.optionalAttrs (stdenv.cc.isGNU && (lib.versionAtLeast (lib.getVersion stdenv.cc.cc) "14")) { - NIX_CFLAGS_COMPILE = "-Wno-error=calloc-transposed-args"; - }; + env = + lib.optionalAttrs (stdenv.cc.isGNU && (lib.versionAtLeast (lib.getVersion stdenv.cc.cc) "14")) + { + NIX_CFLAGS_COMPILE = "-Wno-error=calloc-transposed-args"; + }; doCheck = true; @@ -61,7 +69,10 @@ stdenv.mkDerivation rec { homepage = "https://www.trustedfirmware.org/projects/mbed-tls/"; changelog = "https://github.com/Mbed-TLS/mbedtls/blob/${pname}-${version}/ChangeLog"; description = "Portable cryptographic and TLS library, formerly known as PolarSSL"; - license = [ licenses.asl20 /* or */ licenses.gpl2Plus ]; + license = [ + licenses.asl20 # or + licenses.gpl2Plus + ]; platforms = platforms.all; maintainers = with maintainers; [ raphaelr ]; }; diff --git a/pkgs/development/libraries/medfile/default.nix b/pkgs/development/libraries/medfile/default.nix index 296317788d2174..91a935bb99d9f8 100644 --- a/pkgs/development/libraries/medfile/default.nix +++ b/pkgs/development/libraries/medfile/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, cmake, hdf5 }: +{ + lib, + stdenv, + fetchurl, + cmake, + hdf5, +}: stdenv.mkDerivation (finalAttrs: { pname = "medfile"; @@ -9,28 +15,34 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-Jn520MZ+xRwQ4xmUhOwVCLqo1e2EXGKK32YFKdzno9Q="; }; - outputs = [ "out" "doc" "dev" ]; - - postPatch = '' - # Patch cmake and source files to work with hdf5 - substituteInPlace config/cmake_files/medMacros.cmake --replace-fail \ - "IF (NOT HDF_VERSION_MAJOR_REF EQUAL 1 OR NOT HDF_VERSION_MINOR_REF EQUAL 12 OR NOT HDF_VERSION_RELEASE_REF GREATER 0)" \ - "IF (HDF5_VERSION VERSION_LESS 1.12.0)" - substituteInPlace src/*/*.c --replace-warn \ - "#if H5_VERS_MINOR > 12" \ - "#if H5_VERS_MINOR > 14" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Some medfile test files #define _a, which - # breaks system header files that use _a as a function parameter - substituteInPlace tests/c/*.c \ - --replace-warn "_a" "_A" \ - --replace-warn "_b" "_B" - # Fix compiler errors in test files - substituteInPlace tests/c/*.c \ - --replace-warn "med_Bool" "med_bool" \ - --replace-warn "med_Axis_type" "med_axis_type" \ - --replace-warn "med_Access_mode" "med_access_mode" - ''; + outputs = [ + "out" + "doc" + "dev" + ]; + + postPatch = + '' + # Patch cmake and source files to work with hdf5 + substituteInPlace config/cmake_files/medMacros.cmake --replace-fail \ + "IF (NOT HDF_VERSION_MAJOR_REF EQUAL 1 OR NOT HDF_VERSION_MINOR_REF EQUAL 12 OR NOT HDF_VERSION_RELEASE_REF GREATER 0)" \ + "IF (HDF5_VERSION VERSION_LESS 1.12.0)" + substituteInPlace src/*/*.c --replace-warn \ + "#if H5_VERS_MINOR > 12" \ + "#if H5_VERS_MINOR > 14" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Some medfile test files #define _a, which + # breaks system header files that use _a as a function parameter + substituteInPlace tests/c/*.c \ + --replace-warn "_a" "_A" \ + --replace-warn "_b" "_B" + # Fix compiler errors in test files + substituteInPlace tests/c/*.c \ + --replace-warn "med_Bool" "med_bool" \ + --replace-warn "med_Axis_type" "med_axis_type" \ + --replace-warn "med_Access_mode" "med_access_mode" + ''; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/development/libraries/mediastreamer/default.nix b/pkgs/development/libraries/mediastreamer/default.nix index 03efb5d57a7035..b388622a959a2e 100644 --- a/pkgs/development/libraries/mediastreamer/default.nix +++ b/pkgs/development/libraries/mediastreamer/default.nix @@ -1,25 +1,26 @@ -{ bctoolbox -, bzrtp -, cmake -, fetchFromGitLab -, fetchpatch2 -, ffmpeg -, glew -, gsm -, lib -, libX11 -, libXext -, libopus -, libpulseaudio -, libv4l -, libvpx -, ortp -, python3 -, qtbase -, qtdeclarative -, speex -, srtp -, stdenv +{ + bctoolbox, + bzrtp, + cmake, + fetchFromGitLab, + fetchpatch2, + ffmpeg, + glew, + gsm, + lib, + libX11, + libXext, + libopus, + libpulseaudio, + libv4l, + libvpx, + ortp, + python3, + qtbase, + qtdeclarative, + speex, + srtp, + stdenv, }: stdenv.mkDerivation rec { @@ -75,9 +76,9 @@ stdenv.mkDerivation rec { srtp # Optional - gsm # GSM audio codec - libopus # Opus audio codec - libvpx # VP8 video codec + gsm # GSM audio codec + libopus # Opus audio codec + libvpx # VP8 video codec ]; strictDeps = true; diff --git a/pkgs/development/libraries/mediastreamer/msopenh264.nix b/pkgs/development/libraries/mediastreamer/msopenh264.nix index 7c987f64226918..67b063ec212928 100644 --- a/pkgs/development/libraries/mediastreamer/msopenh264.nix +++ b/pkgs/development/libraries/mediastreamer/msopenh264.nix @@ -1,9 +1,10 @@ -{ cmake -, fetchFromGitLab -, mediastreamer -, openh264 -, lib -, stdenv +{ + cmake, + fetchFromGitLab, + mediastreamer, + openh264, + lib, + stdenv, }: stdenv.mkDerivation rec { @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ mediastreamer openh264 ]; + buildInputs = [ + mediastreamer + openh264 + ]; # Do not build static libraries cmakeFlags = [ diff --git a/pkgs/development/libraries/memorymapping/default.nix b/pkgs/development/libraries/memorymapping/default.nix index 1b3c17bc4f8c6e..eb0bb5d6e768e9 100644 --- a/pkgs/development/libraries/memorymapping/default.nix +++ b/pkgs/development/libraries/memorymapping/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "memorymapping"; diff --git a/pkgs/development/libraries/memstream/default.nix b/pkgs/development/libraries/memstream/default.nix index 7877718e6d358f..11c4f4d9fa8301 100644 --- a/pkgs/development/libraries/memstream/default.nix +++ b/pkgs/development/libraries/memstream/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "memstream"; diff --git a/pkgs/development/libraries/mesa/common.nix b/pkgs/development/libraries/mesa/common.nix index 6c349d679871b8..8bc0715eb2c296 100644 --- a/pkgs/development/libraries/mesa/common.nix +++ b/pkgs/development/libraries/mesa/common.nix @@ -30,6 +30,10 @@ rec { changelog = "https://docs.mesa3d.org/relnotes/${version}.html"; license = with lib.licenses; [ mit ]; # X11 variant, in most files platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ k900 primeos vcunat ]; # Help is welcome :) + maintainers = with lib.maintainers; [ + k900 + primeos + vcunat + ]; # Help is welcome :) }; } diff --git a/pkgs/development/libraries/mesa/darwin.nix b/pkgs/development/libraries/mesa/darwin.nix index 5be2a27f74e98f..b59fbba15b2132 100644 --- a/pkgs/development/libraries/mesa/darwin.nix +++ b/pkgs/development/libraries/mesa/darwin.nix @@ -17,14 +17,23 @@ }: let common = import ./common.nix { inherit lib fetchFromGitLab; }; -in stdenv.mkDerivation { - inherit (common) pname version src meta; +in +stdenv.mkDerivation { + inherit (common) + pname + version + src + meta + ; patches = [ ./darwin-build-fix.patch ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ bison @@ -39,7 +48,7 @@ in stdenv.mkDerivation { ]; buildInputs = [ - libxml2 # should be propagated from libllvm + libxml2 # should be propagated from libllvm llvmPackages.libllvm Xplugin xorg.libX11 diff --git a/pkgs/development/libraries/mlt/default.nix b/pkgs/development/libraries/mlt/default.nix index c3fa57204987e9..e4fe44e0ccea1e 100644 --- a/pkgs/development/libraries/mlt/default.nix +++ b/pkgs/development/libraries/mlt/default.nix @@ -1,42 +1,43 @@ -{ config -, lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, which -, ffmpeg -, fftw -, frei0r -, libdv -, libjack2 -, libsamplerate -, libvorbis -, libxml2 -, makeWrapper -, movit -, opencv4 -, rtaudio -, rubberband -, sox -, vid-stab -, darwin -, cudaSupport ? config.cudaSupport -, cudaPackages ? { } -, enableJackrack ? stdenv.hostPlatform.isLinux -, glib -, ladspa-sdk -, ladspaPlugins -, enablePython ? false -, python3 -, swig -, qt ? null -, enableSDL1 ? stdenv.hostPlatform.isLinux -, SDL -, enableSDL2 ? true -, SDL2 -, gitUpdater -, libarchive +{ + config, + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + which, + ffmpeg, + fftw, + frei0r, + libdv, + libjack2, + libsamplerate, + libvorbis, + libxml2, + makeWrapper, + movit, + opencv4, + rtaudio, + rubberband, + sox, + vid-stab, + darwin, + cudaSupport ? config.cudaSupport, + cudaPackages ? { }, + enableJackrack ? stdenv.hostPlatform.isLinux, + glib, + ladspa-sdk, + ladspaPlugins, + enablePython ? false, + python3, + swig, + qt ? null, + enableSDL1 ? stdenv.hostPlatform.isLinux, + SDL, + enableSDL2 ? true, + SDL2, + gitUpdater, + libarchive, }: stdenv.mkDerivation rec { @@ -54,67 +55,84 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ - cmake - pkg-config - which - makeWrapper - ] ++ lib.optionals cudaSupport [ - cudaPackages.cuda_nvcc - ] ++ lib.optionals enablePython [ - python3 - swig - ] ++ lib.optionals (qt != null) [ - qt.wrapQtAppsHook - ]; - - buildInputs = [ - (opencv4.override { inherit ffmpeg; }) - ffmpeg - fftw - frei0r - libdv - libjack2 - libsamplerate - libvorbis - libxml2 - movit - rtaudio - rubberband - sox - vid-stab - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk_11_0.frameworks.Accelerate - ] ++ lib.optionals cudaSupport [ - cudaPackages.cuda_cudart - ] ++ lib.optionals enableJackrack [ - glib - ladspa-sdk - ladspaPlugins - ] ++ lib.optionals (qt != null) [ - qt.qtbase - qt.qtsvg - (qt.qt5compat or null) - libarchive - ] ++ lib.optionals enableSDL1 [ - SDL - ] ++ lib.optionals enableSDL2 [ - SDL2 - ]; + nativeBuildInputs = + [ + cmake + pkg-config + which + makeWrapper + ] + ++ lib.optionals cudaSupport [ + cudaPackages.cuda_nvcc + ] + ++ lib.optionals enablePython [ + python3 + swig + ] + ++ lib.optionals (qt != null) [ + qt.wrapQtAppsHook + ]; - outputs = [ "out" "dev" ]; + buildInputs = + [ + (opencv4.override { inherit ffmpeg; }) + ffmpeg + fftw + frei0r + libdv + libjack2 + libsamplerate + libvorbis + libxml2 + movit + rtaudio + rubberband + sox + vid-stab + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk_11_0.frameworks.Accelerate + ] + ++ lib.optionals cudaSupport [ + cudaPackages.cuda_cudart + ] + ++ lib.optionals enableJackrack [ + glib + ladspa-sdk + ladspaPlugins + ] + ++ lib.optionals (qt != null) [ + qt.qtbase + qt.qtsvg + (qt.qt5compat or null) + libarchive + ] + ++ lib.optionals enableSDL1 [ + SDL + ] + ++ lib.optionals enableSDL2 [ + SDL2 + ]; - cmakeFlags = [ - # RPATH of binary /nix/store/.../bin/... contains a forbidden reference to /build/ - "-DCMAKE_SKIP_BUILD_RPATH=ON" - "-DMOD_OPENCV=ON" - ] ++ lib.optionals enablePython [ - "-DSWIG_PYTHON=ON" - ] ++ lib.optionals (qt != null) [ - "-DMOD_QT${lib.versions.major qt.qtbase.version}=ON" - "-DMOD_GLAXNIMATE${if lib.versions.major qt.qtbase.version == "5" then "" else "_QT6"}=ON" + outputs = [ + "out" + "dev" ]; + cmakeFlags = + [ + # RPATH of binary /nix/store/.../bin/... contains a forbidden reference to /build/ + "-DCMAKE_SKIP_BUILD_RPATH=ON" + "-DMOD_OPENCV=ON" + ] + ++ lib.optionals enablePython [ + "-DSWIG_PYTHON=ON" + ] + ++ lib.optionals (qt != null) [ + "-DMOD_QT${lib.versions.major qt.qtbase.version}=ON" + "-DMOD_GLAXNIMATE${if lib.versions.major qt.qtbase.version == "5" then "" else "_QT6"}=ON" + ]; + preFixup = '' wrapProgram $out/bin/melt \ --prefix FREI0R_PATH : ${frei0r}/lib/frei0r-1 \ @@ -139,7 +157,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Open source multimedia framework, designed for television broadcasting"; homepage = "https://www.mltframework.org/"; - license = with licenses; [ lgpl21Plus gpl2Plus ]; + license = with licenses; [ + lgpl21Plus + gpl2Plus + ]; maintainers = [ ]; platforms = platforms.unix; }; diff --git a/pkgs/development/libraries/mongoc/default.nix b/pkgs/development/libraries/mongoc/default.nix index 577ca980cbf21c..650dd925518951 100644 --- a/pkgs/development/libraries/mongoc/default.nix +++ b/pkgs/development/libraries/mongoc/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, openssl -, zlib -, zstd -, icu -, cyrus_sasl -, snappy -, darwin +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + openssl, + zlib, + zstd, + icu, + cyrus_sasl, + snappy, + darwin, }: stdenv.mkDerivation rec { @@ -28,16 +29,18 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - openssl - zlib - zstd - icu - cyrus_sasl - snappy - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk_11_0.frameworks.Security - ]; + buildInputs = + [ + openssl + zlib + zstd + icu + cyrus_sasl + snappy + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk_11_0.frameworks.Security + ]; cmakeFlags = [ "-DBUILD_VERSION=${version}" diff --git a/pkgs/development/libraries/mygui/default.nix b/pkgs/development/libraries/mygui/default.nix index d52eadbba6cd75..e7d326e446ac0c 100644 --- a/pkgs/development/libraries/mygui/default.nix +++ b/pkgs/development/libraries/mygui/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, boost -, freetype -, libuuid -, ois -, withOgre ? false -, ogre -, libGL -, libGLU -, libX11 -, Cocoa +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + boost, + freetype, + libuuid, + ois, + withOgre ? false, + ogre, + libGL, + libGLU, + libX11, + Cocoa, }: let @@ -38,21 +39,26 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - boost - freetype - libuuid - ois - ] ++ lib.optionals withOgre [ - ogre - ] ++ lib.optionals (!withOgre && stdenv.hostPlatform.isLinux) [ - libGL - libGLU - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libX11 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Cocoa - ]; + buildInputs = + [ + boost + freetype + libuuid + ois + ] + ++ lib.optionals withOgre [ + ogre + ] + ++ lib.optionals (!withOgre && stdenv.hostPlatform.isLinux) [ + libGL + libGLU + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libX11 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + ]; # Tools are disabled due to compilation failures. cmakeFlags = [ diff --git a/pkgs/development/libraries/mypaint-brushes/1.0.nix b/pkgs/development/libraries/mypaint-brushes/1.0.nix index 73acfd9287f713..885dd5e5137db9 100644 --- a/pkgs/development/libraries/mypaint-brushes/1.0.nix +++ b/pkgs/development/libraries/mypaint-brushes/1.0.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, autoconf -, automake -, fetchFromGitHub -, pkg-config +{ + lib, + stdenv, + autoconf, + automake, + fetchFromGitHub, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/mypaint-brushes/default.nix b/pkgs/development/libraries/mypaint-brushes/default.nix index acdee52b85ef75..a8ca5edacc7e9e 100644 --- a/pkgs/development/libraries/mypaint-brushes/default.nix +++ b/pkgs/development/libraries/mypaint-brushes/default.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, autoconf -, automake -, fetchFromGitHub -, pkg-config +{ + lib, + stdenv, + autoconf, + automake, + fetchFromGitHub, + pkg-config, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/ndi/default.nix b/pkgs/development/libraries/ndi/default.nix index 78a4f808b4c3eb..316a1583ee8929 100644 --- a/pkgs/development/libraries/ndi/default.nix +++ b/pkgs/development/libraries/ndi/default.nix @@ -1,13 +1,24 @@ -{ lib, stdenv, fetchurl, avahi, obs-studio-plugins }: +{ + lib, + stdenv, + fetchurl, + avahi, + obs-studio-plugins, +}: let versionJSON = lib.importJSON ./version.json; ndiPlatform = - if stdenv.hostPlatform.isAarch64 then "aarch64-rpi4-linux-gnueabi" - else if stdenv.hostPlatform.isAarch32 then "arm-rpi2-linux-gnueabihf" - else if stdenv.hostPlatform.isx86_64 then "x86_64-linux-gnu" - else if stdenv.hostPlatform.isi686 then "i686-linux-gnu" - else throw "unsupported platform for NDI SDK"; + if stdenv.hostPlatform.isAarch64 then + "aarch64-rpi4-linux-gnueabi" + else if stdenv.hostPlatform.isAarch32 then + "arm-rpi2-linux-gnueabihf" + else if stdenv.hostPlatform.isx86_64 then + "x86_64-linux-gnu" + else if stdenv.hostPlatform.isi686 then + "i686-linux-gnu" + else + throw "unsupported platform for NDI SDK"; in stdenv.mkDerivation rec { pname = "ndi"; @@ -61,8 +72,13 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://ndi.video/ndi-sdk/"; description = "NDI Software Developer Kit"; - platforms = ["x86_64-linux" "i686-linux" "aarch64-linux" "armv7l-linux"]; - hydraPlatforms = []; + platforms = [ + "x86_64-linux" + "i686-linux" + "aarch64-linux" + "armv7l-linux" + ]; + hydraPlatforms = [ ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; }; diff --git a/pkgs/development/libraries/nemo-qml-plugin-dbus/default.nix b/pkgs/development/libraries/nemo-qml-plugin-dbus/default.nix index a07a692f295e6b..92e3b9d571f2b6 100644 --- a/pkgs/development/libraries/nemo-qml-plugin-dbus/default.nix +++ b/pkgs/development/libraries/nemo-qml-plugin-dbus/default.nix @@ -1,4 +1,10 @@ -{ mkDerivation, lib, fetchFromGitLab, qmake, qtbase }: +{ + mkDerivation, + lib, + fetchFromGitLab, + qmake, + qtbase, +}: mkDerivation rec { pname = "nemo-qml-plugin-dbus"; diff --git a/pkgs/development/libraries/netcdf-fortran/default.nix b/pkgs/development/libraries/netcdf-fortran/default.nix index d9a80768bb614a..aacafb1e674f2c 100644 --- a/pkgs/development/libraries/netcdf-fortran/default.nix +++ b/pkgs/development/libraries/netcdf-fortran/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, netcdf, hdf5, curl, gfortran, CoreFoundation, CoreServices, SystemConfiguration }: +{ + lib, + stdenv, + fetchFromGitHub, + netcdf, + hdf5, + curl, + gfortran, + CoreFoundation, + CoreServices, + SystemConfiguration, +}: stdenv.mkDerivation rec { pname = "netcdf-fortran"; version = "4.4.5"; @@ -11,16 +22,23 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ gfortran ]; - buildInputs = [ netcdf hdf5 curl ] + buildInputs = + [ + netcdf + hdf5 + curl + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreFoundation CoreServices SystemConfiguration ]; - env.NIX_LDFLAGS = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-F${CoreServices}/Library/Frameworks" - "-F${SystemConfiguration}/Library/Frameworks" - ]); + env.NIX_LDFLAGS = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-F${CoreServices}/Library/Frameworks" + "-F${SystemConfiguration}/Library/Frameworks" + ] + ); doCheck = true; FFLAGS = [ "-std=legacy" ]; diff --git a/pkgs/development/libraries/nettle/generic.nix b/pkgs/development/libraries/nettle/generic.nix index b1cf1f5f6bfe92..2ce64e94121f31 100644 --- a/pkgs/development/libraries/nettle/generic.nix +++ b/pkgs/development/libraries/nettle/generic.nix @@ -1,7 +1,13 @@ -{ lib, stdenv, buildPackages, gmp, gnum4 - -# Version specific args -, version, src +{ + lib, + stdenv, + buildPackages, + gmp, + gnum4, + + # Version specific args + version, + src, }: stdenv.mkDerivation { @@ -9,7 +15,10 @@ stdenv.mkDerivation { inherit version src; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; outputBin = "dev"; depsBuildBuild = [ buildPackages.stdenv.cc ]; @@ -29,40 +38,39 @@ stdenv.mkDerivation { enableParallelBuilding = true; - patches = lib.optional (stdenv.hostPlatform.system == "i686-cygwin") - ./cygwin.patch; + patches = lib.optional (stdenv.hostPlatform.system == "i686-cygwin") ./cygwin.patch; meta = with lib; { description = "Cryptographic library"; longDescription = '' - Nettle is a cryptographic library that is designed to fit - easily in more or less any context: In crypto toolkits for - object-oriented languages (C++, Python, Pike, ...), in - applications like LSH or GNUPG, or even in kernel space. In - most contexts, you need more than the basic cryptographic - algorithms, you also need some way to keep track of available - algorithms, their properties and variants. You often have - some algorithm selection process, often dictated by a protocol - you want to implement. - - And as the requirements of applications differ in subtle and - not so subtle ways, an API that fits one application well can - be a pain to use in a different context. And that is why - there are so many different cryptographic libraries around. - - Nettle tries to avoid this problem by doing one thing, the - low-level crypto stuff, and providing a simple but general - interface to it. In particular, Nettle doesn't do algorithm - selection. It doesn't do memory allocation. It doesn't do any - I/O. - ''; - - license = licenses.gpl2Plus; - - homepage = "https://www.lysator.liu.se/~nisse/nettle/"; - - platforms = platforms.all; - maintainers = [ maintainers.vcunat ]; + Nettle is a cryptographic library that is designed to fit + easily in more or less any context: In crypto toolkits for + object-oriented languages (C++, Python, Pike, ...), in + applications like LSH or GNUPG, or even in kernel space. In + most contexts, you need more than the basic cryptographic + algorithms, you also need some way to keep track of available + algorithms, their properties and variants. You often have + some algorithm selection process, often dictated by a protocol + you want to implement. + + And as the requirements of applications differ in subtle and + not so subtle ways, an API that fits one application well can + be a pain to use in a different context. And that is why + there are so many different cryptographic libraries around. + + Nettle tries to avoid this problem by doing one thing, the + low-level crypto stuff, and providing a simple but general + interface to it. In particular, Nettle doesn't do algorithm + selection. It doesn't do memory allocation. It doesn't do any + I/O. + ''; + + license = licenses.gpl2Plus; + + homepage = "https://www.lysator.liu.se/~nisse/nettle/"; + + platforms = platforms.all; + maintainers = [ maintainers.vcunat ]; }; } diff --git a/pkgs/development/libraries/newt/default.nix b/pkgs/development/libraries/newt/default.nix index d8adcf63b19dbe..4e6f408acc338f 100644 --- a/pkgs/development/libraries/newt/default.nix +++ b/pkgs/development/libraries/newt/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, stdenv, slang, popt, python }: +{ + lib, + fetchurl, + stdenv, + slang, + popt, + python, +}: let pythonIncludePath = "${lib.getDev python}/include/python"; @@ -26,7 +33,10 @@ stdenv.mkDerivation rec { strictDeps = true; nativeBuildInputs = [ python ]; - buildInputs = [ slang popt ]; + buildInputs = [ + slang + popt + ]; NIX_LDFLAGS = "-lncurses"; diff --git a/pkgs/development/libraries/nghttp3/default.nix b/pkgs/development/libraries/nghttp3/default.nix index d6fa71d590ea98..c7d53e0160dc99 100644 --- a/pkgs/development/libraries/nghttp3/default.nix +++ b/pkgs/development/libraries/nghttp3/default.nix @@ -1,7 +1,10 @@ -{ lib, stdenv, fetchFromGitHub -, cmake -, CoreServices -, curlHTTP3 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + CoreServices, + curlHTTP3, }: stdenv.mkDerivation rec { @@ -16,7 +19,11 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; nativeBuildInputs = [ cmake ]; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ diff --git a/pkgs/development/libraries/nlopt/default.nix b/pkgs/development/libraries/nlopt/default.nix index 4995d98adca761..1e1f5f01c3821f 100644 --- a/pkgs/development/libraries/nlopt/default.nix +++ b/pkgs/development/libraries/nlopt/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, octave ? null, libiconv }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + octave ? null, + libiconv, +}: stdenv.mkDerivation rec { pname = "nlopt"; @@ -14,18 +21,20 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; buildInputs = [ octave ]; - configureFlags = [ - "--with-cxx" - "--enable-shared" - "--with-pic" - "--without-guile" - "--without-python" - "--without-matlab" - ] ++ lib.optionals (octave != null) [ - "--with-octave" - "M_INSTALL_DIR=$(out)/${octave.sitePath}/m" - "OCT_INSTALL_DIR=$(out)/${octave.sitePath}/oct" - ]; + configureFlags = + [ + "--with-cxx" + "--enable-shared" + "--with-pic" + "--without-guile" + "--without-python" + "--without-matlab" + ] + ++ lib.optionals (octave != null) [ + "--with-octave" + "M_INSTALL_DIR=$(out)/${octave.sitePath}/m" + "OCT_INSTALL_DIR=$(out)/${octave.sitePath}/oct" + ]; postFixup = '' substituteInPlace $out/lib/cmake/nlopt/NLoptLibraryDepends.cmake --replace \ diff --git a/pkgs/development/libraries/nspr/default.nix b/pkgs/development/libraries/nspr/default.nix index 1f126d256870c2..e8cf01bb7a7ec4 100644 --- a/pkgs/development/libraries/nspr/default.nix +++ b/pkgs/development/libraries/nspr/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, CoreServices -, buildPackages -, nixosTests +{ + lib, + stdenv, + fetchurl, + CoreServices, + buildPackages, + nixosTests, }: stdenv.mkDerivation rec { @@ -19,15 +20,20 @@ stdenv.mkDerivation rec { ./0001-Makefile-use-SOURCE_DATE_EPOCH-for-reproducibility.patch ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; outputBin = "dev"; - preConfigure = '' - cd nspr - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace configure --replace '@executable_path/' "$out/lib/" - substituteInPlace configure.in --replace '@executable_path/' "$out/lib/" - ''; + preConfigure = + '' + cd nspr + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace configure --replace '@executable_path/' "$out/lib/" + substituteInPlace configure.in --replace '@executable_path/' "$out/lib/" + ''; HOST_CC = "cc"; depsBuildBuild = [ buildPackages.stdenv.cc ]; @@ -52,7 +58,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://firefox-source-docs.mozilla.org/nspr/index.html"; description = "Netscape Portable Runtime, a platform-neutral API for system-level and libc-like functions"; - maintainers = with maintainers; [ ajs124 hexa ]; + maintainers = with maintainers; [ + ajs124 + hexa + ]; platforms = platforms.all; license = licenses.mpl20; }; diff --git a/pkgs/development/libraries/nss/generic.nix b/pkgs/development/libraries/nss/generic.nix index 9e54ddda866f7d..38741f23a1214f 100644 --- a/pkgs/development/libraries/nss/generic.nix +++ b/pkgs/development/libraries/nss/generic.nix @@ -1,22 +1,23 @@ { version, hash }: -{ lib -, stdenv -, fetchFromGitHub -, nspr -, perl -, zlib -, sqlite -, ninja -, cctools -, fixDarwinDylibNames -, buildPackages -, useP11kit ? true -, p11-kit -, # allow FIPS mode. Note that this makes the output non-reproducible. +{ + lib, + stdenv, + fetchFromGitHub, + nspr, + perl, + zlib, + sqlite, + ninja, + cctools, + fixDarwinDylibNames, + buildPackages, + useP11kit ? true, + p11-kit, + # allow FIPS mode. Note that this makes the output non-reproducible. # https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS/NSS_Tech_Notes/nss_tech_note6 - enableFIPS ? false -, nixosTests -, nss_latest + enableFIPS ? false, + nixosTests, + nss_latest, }: let @@ -29,16 +30,27 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "nss-dev"; repo = "nss"; - rev = "NSS_${lib.replaceStrings ["."] ["_"] version}_RTM"; + rev = "NSS_${lib.replaceStrings [ "." ] [ "_" ] version}_RTM"; inherit hash; }; depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ perl ninja (buildPackages.python3.withPackages (ps: with ps; [ gyp ])) ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools fixDarwinDylibNames ]; - - buildInputs = [ zlib sqlite ]; + nativeBuildInputs = + [ + perl + ninja + (buildPackages.python3.withPackages (ps: with ps; [ gyp ])) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + cctools + fixDarwinDylibNames + ]; + + buildInputs = [ + zlib + sqlite + ]; propagatedBuildInputs = [ nspr ]; @@ -48,33 +60,43 @@ stdenv.mkDerivation rec { ./fix-cross-compilation.patch ]; - postPatch = '' - patchShebangs . + postPatch = + '' + patchShebangs . - for f in coreconf/config.gypi build.sh; do - substituteInPlace "$f" --replace "/usr/bin/env" "${buildPackages.coreutils}/bin/env" - done + for f in coreconf/config.gypi build.sh; do + substituteInPlace "$f" --replace "/usr/bin/env" "${buildPackages.coreutils}/bin/env" + done - substituteInPlace coreconf/config.gypi --replace "/usr/bin/grep" "${buildPackages.coreutils}/bin/env grep" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace coreconf/Darwin.mk --replace '@executable_path/$(notdir $@)' "$out/lib/\$(notdir \$@)" - substituteInPlace coreconf/config.gypi --replace "'DYLIB_INSTALL_NAME_BASE': '@executable_path'" "'DYLIB_INSTALL_NAME_BASE': '$out/lib'" - ''; + substituteInPlace coreconf/config.gypi --replace "/usr/bin/grep" "${buildPackages.coreutils}/bin/env grep" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace coreconf/Darwin.mk --replace '@executable_path/$(notdir $@)' "$out/lib/\$(notdir \$@)" + substituteInPlace coreconf/config.gypi --replace "'DYLIB_INSTALL_NAME_BASE': '@executable_path'" "'DYLIB_INSTALL_NAME_BASE': '$out/lib'" + ''; - outputs = [ "out" "dev" "tools" ]; + outputs = [ + "out" + "dev" + "tools" + ]; buildPhase = let - getArch = platform: - if platform.isx86_64 then "x64" - else if platform.isx86_32 then "ia32" - else if platform.isAarch32 then "arm" - else if platform.isAarch64 then "arm64" + getArch = + platform: + if platform.isx86_64 then + "x64" + else if platform.isx86_32 then + "ia32" + else if platform.isAarch32 then + "arm" + else if platform.isAarch64 then + "arm64" else if platform.isPower && platform.is64bit then - ( - if platform.isLittleEndian then "ppc64le" else "ppc64" - ) - else platform.parsed.cpu.name; + (if platform.isLittleEndian then "ppc64le" else "ppc64") + else + platform.parsed.cpu.name; # yes, this is correct. nixpkgs uses "host" for the platform the binary will run on whereas nss uses "host" for the platform that the build is running on target = getArch stdenv.hostPlatform; host = getArch stdenv.buildPlatform; @@ -99,14 +121,18 @@ stdenv.mkDerivation rec { runHook postBuild ''; - env.NIX_CFLAGS_COMPILE = toString ([ - "-Wno-error" - "-DNIX_NSS_LIBDIR=\"${placeholder "out"}/lib/\"" - ] ++ lib.optionals stdenv.hostPlatform.is64bit [ - "-DNSS_USE_64=1" - ] ++ lib.optionals stdenv.hostPlatform.isILP32 [ - "-DNS_PTR_LE_32=1" # See RNG_RandomUpdate() in drdbg.c - ]); + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-Wno-error" + "-DNIX_NSS_LIBDIR=\"${placeholder "out"}/lib/\"" + ] + ++ lib.optionals stdenv.hostPlatform.is64bit [ + "-DNSS_USE_64=1" + ] + ++ lib.optionals stdenv.hostPlatform.isILP32 [ + "-DNS_PTR_LE_32=1" # See RNG_RandomUpdate() in drdbg.c + ] + ); installPhase = '' runHook preInstall @@ -152,19 +178,26 @@ stdenv.mkDerivation rec { isCross = stdenv.hostPlatform != stdenv.buildPlatform; nss = if isCross then buildPackages.nss.tools else "$out"; in - (lib.optionalString enableFIPS ('' - for libname in freebl3 nssdbm3 softokn3 - do libfile="$out/lib/lib$libname${stdenv.hostPlatform.extensions.sharedLibrary}"'' + - (if stdenv.hostPlatform.isDarwin - then '' - DYLD_LIBRARY_PATH=$out/lib:${nspr.out}/lib \ - '' else '' - LD_LIBRARY_PATH=$out/lib:${nspr.out}/lib \ - '') + '' - ${nss}/bin/shlibsign -v -i "$libfile" - done - '')) + - '' + (lib.optionalString enableFIPS ( + '' + for libname in freebl3 nssdbm3 softokn3 + do libfile="$out/lib/lib$libname${stdenv.hostPlatform.extensions.sharedLibrary}"'' + + ( + if stdenv.hostPlatform.isDarwin then + '' + DYLD_LIBRARY_PATH=$out/lib:${nspr.out}/lib \ + '' + else + '' + LD_LIBRARY_PATH=$out/lib:${nspr.out}/lib \ + '' + ) + + '' + ${nss}/bin/shlibsign -v -i "$libfile" + done + '' + )) + + '' moveToOutput bin "$tools" moveToOutput bin/nss-config "$dev" moveToOutput lib/libcrmf.a "$dev" # needed by firefox, for example @@ -175,17 +208,22 @@ stdenv.mkDerivation rec { passthru.updateScript = ./update.sh; - passthru.tests = lib.optionalAttrs (lib.versionOlder version nss_latest.version) { - inherit (nixosTests) firefox-esr-115; - } // lib.optionalAttrs (lib.versionAtLeast version nss_latest.version) { - inherit (nixosTests) firefox; - }; + passthru.tests = + lib.optionalAttrs (lib.versionOlder version nss_latest.version) { + inherit (nixosTests) firefox-esr-115; + } + // lib.optionalAttrs (lib.versionAtLeast version nss_latest.version) { + inherit (nixosTests) firefox; + }; meta = with lib; { homepage = "https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS"; description = "Set of libraries for development of security-enabled client and server applications"; changelog = "https://github.com/nss-dev/nss/blob/master/doc/rst/releases/nss_${underscoreVersion}.rst"; - maintainers = with maintainers; [ hexa ajs124 ]; + maintainers = with maintainers; [ + hexa + ajs124 + ]; license = licenses.mpl20; platforms = platforms.all; }; diff --git a/pkgs/development/libraries/nuspell/default.nix b/pkgs/development/libraries/nuspell/default.nix index b2bd4de93f033f..f2e7309b09edff 100644 --- a/pkgs/development/libraries/nuspell/default.nix +++ b/pkgs/development/libraries/nuspell/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pandoc, pkg-config, icu, catch2_3 }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pandoc, + pkg-config, + icu, + catch2_3, +}: stdenv.mkDerivation rec { pname = "nuspell"; @@ -11,14 +20,22 @@ stdenv.mkDerivation rec { hash = "sha256-U/lHSxpKsBnamf4ikE2aIjEPSU5fxjtuSmhZR0jxMAI="; }; - nativeBuildInputs = [ cmake pandoc pkg-config ]; + nativeBuildInputs = [ + cmake + pandoc + pkg-config + ]; buildInputs = [ catch2_3 ]; propagatedBuildInputs = [ icu ]; cmakeFlags = [ "-DBUILD_TESTING=YES" ]; doCheck = true; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; meta = with lib; { description = "Free and open source C++ spell checking library"; diff --git a/pkgs/development/libraries/nuspell/wrapper.nix b/pkgs/development/libraries/nuspell/wrapper.nix index b3a929545f24fa..4bb97e623d38ff 100644 --- a/pkgs/development/libraries/nuspell/wrapper.nix +++ b/pkgs/development/libraries/nuspell/wrapper.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, nuspell, makeWrapper, dicts ? [] }: +{ + stdenv, + lib, + nuspell, + makeWrapper, + dicts ? [ ], +}: let searchPath = lib.makeSearchPath "share/hunspell" dicts; @@ -9,5 +15,5 @@ stdenv.mkDerivation { buildCommand = '' makeWrapper ${nuspell}/bin/nuspell $out/bin/nuspell --prefix DICPATH : ${lib.escapeShellArg searchPath} ''; - meta = removeAttrs nuspell.meta ["outputsToInstall"]; + meta = removeAttrs nuspell.meta [ "outputsToInstall" ]; } diff --git a/pkgs/development/libraries/nvidia-vaapi-driver/default.nix b/pkgs/development/libraries/nvidia-vaapi-driver/default.nix index aa8f6a16c44294..89eee7dbf8d57c 100644 --- a/pkgs/development/libraries/nvidia-vaapi-driver/default.nix +++ b/pkgs/development/libraries/nvidia-vaapi-driver/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, fetchFromGitHub -, lib -, meson -, ninja -, pkg-config -, libdrm -, libGL -, gst_all_1 -, nv-codec-headers-11 -, libva -, addDriverRunpath +{ + stdenv, + fetchFromGitHub, + lib, + meson, + ninja, + pkg-config, + libdrm, + libGL, + gst_all_1, + nv-codec-headers-11, + libva, + addDriverRunpath, }: stdenv.mkDerivation rec { @@ -47,11 +48,11 @@ stdenv.mkDerivation rec { addDriverRunpath "$out/lib/dri/nvidia_drv_video.so" ''; - meta = with lib;{ + meta = with lib; { homepage = "https://github.com/elFarto/nvidia-vaapi-driver"; description = "VA-API implemention using NVIDIA's NVDEC"; changelog = "https://github.com/elFarto/nvidia-vaapi-driver/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers;[ nickcao ]; + maintainers = with maintainers; [ nickcao ]; }; } diff --git a/pkgs/development/libraries/ogre/default.nix b/pkgs/development/libraries/ogre/default.nix index e24fdd9c12a518..9a74cf86576c53 100644 --- a/pkgs/development/libraries/ogre/default.nix +++ b/pkgs/development/libraries/ogre/default.nix @@ -1,114 +1,130 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, unzip -, SDL2 -, boost -, freetype -, libpng -, ois -, pugixml -, zziplib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + unzip, + SDL2, + boost, + freetype, + libpng, + ois, + pugixml, + zziplib, # linux -, libglut -, libGL -, libGLU -, libICE -, libSM -, libX11 -, libXaw -, libXmu -, libXrandr -, libXrender -, libXt -, libXxf86vm -, xorgproto + libglut, + libGL, + libGLU, + libICE, + libSM, + libX11, + libXaw, + libXmu, + libXrandr, + libXrender, + libXt, + libXxf86vm, + xorgproto, # darwin -, darwin + darwin, # optional -, withNvidiaCg ? false -, nvidia_cg_toolkit -, withSamples ? false + withNvidiaCg ? false, + nvidia_cg_toolkit, + withSamples ? false, }: let - common = { version, hash, imguiVersion, imguiHash }: - let - imgui.src = fetchFromGitHub { - owner = "ocornut"; - repo = "imgui"; - rev = "v${imguiVersion}"; - hash = imguiHash; - }; - in - stdenv.mkDerivation { - pname = "ogre"; - inherit version; + common = + { + version, + hash, + imguiVersion, + imguiHash, + }: + let + imgui.src = fetchFromGitHub { + owner = "ocornut"; + repo = "imgui"; + rev = "v${imguiVersion}"; + hash = imguiHash; + }; + in + stdenv.mkDerivation { + pname = "ogre"; + inherit version; - src = fetchFromGitHub { - owner = "OGRECave"; - repo = "ogre"; - rev = "v${version}"; - inherit hash; - }; + src = fetchFromGitHub { + owner = "OGRECave"; + repo = "ogre"; + rev = "v${version}"; + inherit hash; + }; - postPatch = '' - mkdir -p build - cp -R ${imgui.src} build/imgui-${imguiVersion} - chmod -R u+w build/imgui-${imguiVersion} - ''; + postPatch = '' + mkdir -p build + cp -R ${imgui.src} build/imgui-${imguiVersion} + chmod -R u+w build/imgui-${imguiVersion} + ''; - nativeBuildInputs = [ - cmake - pkg-config - unzip - ]; + nativeBuildInputs = [ + cmake + pkg-config + unzip + ]; - buildInputs = [ - SDL2 - boost - freetype - libpng - ois - pugixml - zziplib - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libglut - libGL - libGLU - libICE - libSM - libX11 - libXaw - libXmu - libXrandr - libXrender - libXt - libXxf86vm - xorgproto - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Cocoa - ] ++ lib.optionals withNvidiaCg [ - nvidia_cg_toolkit - ]; + buildInputs = + [ + SDL2 + boost + freetype + libpng + ois + pugixml + zziplib + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libglut + libGL + libGLU + libICE + libSM + libX11 + libXaw + libXmu + libXrandr + libXrender + libXt + libXxf86vm + xorgproto + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Cocoa + ] + ++ lib.optionals withNvidiaCg [ + nvidia_cg_toolkit + ]; - cmakeFlags = [ - (lib.cmakeBool "OGRE_BUILD_DEPENDENCIES" false) - (lib.cmakeBool "OGRE_BUILD_SAMPLES" withSamples) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - (lib.cmakeBool "OGRE_BUILD_LIBS_AS_FRAMEWORKS" false) - ]; + cmakeFlags = + [ + (lib.cmakeBool "OGRE_BUILD_DEPENDENCIES" false) + (lib.cmakeBool "OGRE_BUILD_SAMPLES" withSamples) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + (lib.cmakeBool "OGRE_BUILD_LIBS_AS_FRAMEWORKS" false) + ]; - meta = { - description = "3D Object-Oriented Graphics Rendering Engine"; - homepage = "https://www.ogre3d.org/"; - maintainers = with lib.maintainers; [ raskin wegank ]; - platforms = lib.platforms.unix; - license = lib.licenses.mit; + meta = { + description = "3D Object-Oriented Graphics Rendering Engine"; + homepage = "https://www.ogre3d.org/"; + maintainers = with lib.maintainers; [ + raskin + wegank + ]; + platforms = lib.platforms.unix; + license = lib.licenses.mit; + }; }; - }; in { ogre_14 = common { diff --git a/pkgs/development/libraries/ois/default.nix b/pkgs/development/libraries/ois/default.nix index 435509dee21605..b6ddc5ebbf6325 100644 --- a/pkgs/development/libraries/ois/default.nix +++ b/pkgs/development/libraries/ois/default.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchFromGitHub, cmake, libX11, Cocoa, IOKit, Kernel }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + libX11, + Cocoa, + IOKit, + Kernel, +}: stdenv.mkDerivation rec { pname = "ois"; @@ -13,8 +22,13 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libX11 ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa IOKit Kernel ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ libX11 ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + IOKit + Kernel + ]; cmakeFlags = [ "-DCMAKE_INSTALL_LIBDIR=lib" diff --git a/pkgs/development/libraries/okapi/default.nix b/pkgs/development/libraries/okapi/default.nix index 06f980e718c85f..e3a71e97f55fb9 100644 --- a/pkgs/development/libraries/okapi/default.nix +++ b/pkgs/development/libraries/okapi/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, rustPlatform, fetchurl, Security }: +{ + lib, + stdenv, + rustPlatform, + fetchurl, + Security, +}: rustPlatform.buildRustPackage rec { pname = "okapi"; diff --git a/pkgs/development/libraries/oneDNN/2.nix b/pkgs/development/libraries/oneDNN/2.nix index 8851b09214f1fd..5bd3c88a75eab0 100644 --- a/pkgs/development/libraries/oneDNN/2.nix +++ b/pkgs/development/libraries/oneDNN/2.nix @@ -1,7 +1,8 @@ -{ cmake -, fetchFromGitHub -, lib -, stdenv +{ + cmake, + fetchFromGitHub, + lib, + stdenv, }: # This was originally called mkl-dnn, then it was renamed to dnnl, and it has @@ -18,7 +19,11 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-oMPBORAdL2rk2ewyUrInYVHYBRvuvNX4p4rwykO3Rhs="; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; nativeBuildInputs = [ cmake ]; @@ -39,7 +44,10 @@ stdenv.mkDerivation (finalAttrs: { description = "oneAPI Deep Neural Network Library (oneDNN)"; homepage = "https://01.org/oneDNN"; license = lib.licenses.asl20; - maintainers = with lib.maintainers; [ alexarice bhipple ]; + maintainers = with lib.maintainers; [ + alexarice + bhipple + ]; platforms = lib.platforms.all; }; }) diff --git a/pkgs/development/libraries/openal-soft/default.nix b/pkgs/development/libraries/openal-soft/default.nix index 15a33af177cee8..a5d2f85e0dc268 100644 --- a/pkgs/development/libraries/openal-soft/default.nix +++ b/pkgs/development/libraries/openal-soft/default.nix @@ -1,9 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, removeReferencesTo -, alsaSupport ? !stdenv.hostPlatform.isDarwin, alsa-lib -, dbusSupport ? !stdenv.hostPlatform.isDarwin, dbus -, pipewireSupport ? !stdenv.hostPlatform.isDarwin, pipewire -, pulseSupport ? !stdenv.hostPlatform.isDarwin, libpulseaudio -, CoreServices, AudioUnit, AudioToolbox +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + removeReferencesTo, + alsaSupport ? !stdenv.hostPlatform.isDarwin, + alsa-lib, + dbusSupport ? !stdenv.hostPlatform.isDarwin, + dbus, + pipewireSupport ? !stdenv.hostPlatform.isDarwin, + pipewire, + pulseSupport ? !stdenv.hostPlatform.isDarwin, + libpulseaudio, + CoreServices, + AudioUnit, + AudioToolbox, }: stdenv.mkDerivation rec { @@ -29,22 +41,33 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ cmake pkg-config removeReferencesTo ]; + nativeBuildInputs = [ + cmake + pkg-config + removeReferencesTo + ]; - buildInputs = lib.optional alsaSupport alsa-lib + buildInputs = + lib.optional alsaSupport alsa-lib ++ lib.optional dbusSupport dbus ++ lib.optional pipewireSupport pipewire ++ lib.optional pulseSupport libpulseaudio - ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices AudioUnit AudioToolbox ]; - - cmakeFlags = [ - # Automatically links dependencies without having to rely on dlopen, thus - # removes the need for NIX_LDFLAGS. - "-DALSOFT_DLOPEN=OFF" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - # https://github.com/NixOS/nixpkgs/issues/183774 - "-DOSS_INCLUDE_DIR=${stdenv.cc.libc}/include" - ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + AudioUnit + AudioToolbox + ]; + + cmakeFlags = + [ + # Automatically links dependencies without having to rely on dlopen, thus + # removes the need for NIX_LDFLAGS. + "-DALSOFT_DLOPEN=OFF" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + # https://github.com/NixOS/nixpkgs/issues/183774 + "-DOSS_INCLUDE_DIR=${stdenv.cc.libc}/include" + ]; postInstall = lib.optional pipewireSupport '' remove-references-to -t ${pipewire.dev} $(readlink -f $out/lib/*.so) @@ -54,7 +77,7 @@ stdenv.mkDerivation rec { description = "OpenAL alternative"; homepage = "https://openal-soft.org/"; license = licenses.lgpl2; - maintainers = with maintainers; [ftrvxmtrx]; + maintainers = with maintainers; [ ftrvxmtrx ]; platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/openbabel/2.nix b/pkgs/development/libraries/openbabel/2.nix index b27960779cad06..90b27abf02d6a3 100644 --- a/pkgs/development/libraries/openbabel/2.nix +++ b/pkgs/development/libraries/openbabel/2.nix @@ -1,4 +1,17 @@ -{stdenv, lib, fetchFromGitHub, fetchpatch, cmake, zlib, libxml2, eigen, python3, cairo, pcre, pkg-config }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, + zlib, + libxml2, + eigen, + python3, + cairo, + pcre, + pkg-config, +}: stdenv.mkDerivation rec { pname = "openbabel"; @@ -7,7 +20,7 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "openbabel"; repo = "openbabel"; - rev = "openbabel-${lib.replaceStrings ["."] ["-"] version}"; + rev = "openbabel-${lib.replaceStrings [ "." ] [ "-" ] version}"; sha256 = "sha256-+pXsWMzex7rB1mm6dnTHzAcyw9jImgx1OZuLeCvbeJ0="; }; @@ -23,11 +36,21 @@ stdenv.mkDerivation rec { sed '1i#include ' -i include/openbabel/obutil.h # gcc12 ''; - buildInputs = [ zlib libxml2 eigen python3 cairo pcre ]; + buildInputs = [ + zlib + libxml2 + eigen + python3 + cairo + pcre + ]; cmakeFlags = [ "-DCMAKE_CXX_STANDARD=14" ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; meta = with lib; { description = "Toolbox designed to speak the many languages of chemical data"; diff --git a/pkgs/development/libraries/openbabel/default.nix b/pkgs/development/libraries/openbabel/default.nix index c08053d6786b62..1b81bfa7752035 100644 --- a/pkgs/development/libraries/openbabel/default.nix +++ b/pkgs/development/libraries/openbabel/default.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, perl -, zlib -, libxml2 -, eigen -, python -, cairo -, pcre -, pkg-config -, swig -, rapidjson -, boost -, maeparser -, coordgenlibs +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + perl, + zlib, + libxml2, + eigen, + python, + cairo, + pcre, + pkg-config, + swig, + rapidjson, + boost, + maeparser, + coordgenlibs, }: stdenv.mkDerivation rec { @@ -32,9 +33,25 @@ stdenv.mkDerivation rec { sed '1i#include ' -i include/openbabel/obutil.h # gcc12 ''; - buildInputs = [ perl zlib libxml2 eigen python cairo pcre swig rapidjson boost maeparser coordgenlibs ]; + buildInputs = [ + perl + zlib + libxml2 + eigen + python + cairo + pcre + swig + rapidjson + boost + maeparser + coordgenlibs + ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; preConfigure = '' cmakeFlagsArray+=( diff --git a/pkgs/development/libraries/opencolorio/1.x.nix b/pkgs/development/libraries/opencolorio/1.x.nix index 7d1839163efc26..4ac41482037fbc 100644 --- a/pkgs/development/libraries/opencolorio/1.x.nix +++ b/pkgs/development/libraries/opencolorio/1.x.nix @@ -1,4 +1,14 @@ -{ stdenv, lib, fetchFromGitHub, cmake, boost, pkg-config, lcms2, tinyxml, git }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + boost, + pkg-config, + lcms2, + tinyxml, + git, +}: stdenv.mkDerivation rec { pname = "opencolorio"; @@ -11,26 +21,41 @@ stdenv.mkDerivation rec { sha256 = "12srvxca51czpfjl0gabpidj9n84mw78ivxy5w75qhq2mmc798sb"; }; - outputs = [ "bin" "out" "dev" ]; + outputs = [ + "bin" + "out" + "dev" + ]; # TODO: Investigate whether git can be dropped: It's only used to apply patches - nativeBuildInputs = [ cmake pkg-config git ]; + nativeBuildInputs = [ + cmake + pkg-config + git + ]; - buildInputs = [ lcms2 tinyxml ] ++ lib.optional stdenv.hostPlatform.isDarwin boost; + buildInputs = [ + lcms2 + tinyxml + ] ++ lib.optional stdenv.hostPlatform.isDarwin boost; postPatch = '' substituteInPlace src/core/CMakeLists.txt --replace "-Werror" "" substituteInPlace src/pyglue/CMakeLists.txt --replace "-Werror" "" ''; - cmakeFlags = [ - "-DUSE_EXTERNAL_LCMS=ON" - "-DUSE_EXTERNAL_TINYXML=ON" - # External yaml-cpp 0.6.* not compatible: https://github.com/imageworks/OpenColorIO/issues/517 - "-DUSE_EXTERNAL_YAML=OFF" - ] ++ lib.optional stdenv.hostPlatform.isDarwin "-DOCIO_USE_BOOST_PTR=ON" + cmakeFlags = + [ + "-DUSE_EXTERNAL_LCMS=ON" + "-DUSE_EXTERNAL_TINYXML=ON" + # External yaml-cpp 0.6.* not compatible: https://github.com/imageworks/OpenColorIO/issues/517 + "-DUSE_EXTERNAL_YAML=OFF" + ] + ++ lib.optional stdenv.hostPlatform.isDarwin "-DOCIO_USE_BOOST_PTR=ON" ++ lib.optional (!stdenv.hostPlatform.isx86) "-DOCIO_USE_SSE=OFF" - ++ lib.optional (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) "-DCMAKE_OSX_ARCHITECTURES=arm64"; + ++ lib.optional ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 + ) "-DCMAKE_OSX_ARCHITECTURES=arm64"; postInstall = '' moveToOutput bin "$bin" diff --git a/pkgs/development/libraries/opencolorio/default.nix b/pkgs/development/libraries/opencolorio/default.nix index 4bc1f410872e6b..df4887e799b86e 100644 --- a/pkgs/development/libraries/opencolorio/default.nix +++ b/pkgs/development/libraries/opencolorio/default.nix @@ -1,26 +1,27 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, expat -, yaml-cpp -, pystring -, imath -, minizip-ng -# Only required on Linux -, glew -, libglut -# Only required on Darwin -, Carbon -, GLUT -, Cocoa -# Python bindings -, pythonBindings ? true # Python bindings -, python3Packages -# Build apps -, buildApps ? true # Utility applications -, lcms2 -, openexr_3 +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + expat, + yaml-cpp, + pystring, + imath, + minizip-ng, + # Only required on Linux + glew, + libglut, + # Only required on Darwin + Carbon, + GLUT, + Cocoa, + # Python bindings + pythonBindings ? true, # Python bindings + python3Packages, + # Build apps + buildApps ? true, # Utility applications + lcms2, + openexr_3, }: stdenv.mkDerivation rec { @@ -51,27 +52,41 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ cmake ]; - buildInputs = [ - expat - yaml-cpp - pystring - imath - minizip-ng - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ glew libglut ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Carbon GLUT Cocoa ] - ++ lib.optionals pythonBindings [ python3Packages.python python3Packages.pybind11 ] + buildInputs = + [ + expat + yaml-cpp + pystring + imath + minizip-ng + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + glew + libglut + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + GLUT + Cocoa + ] + ++ lib.optionals pythonBindings [ + python3Packages.python + python3Packages.pybind11 + ] ++ lib.optionals buildApps [ lcms2 openexr_3 ]; - cmakeFlags = [ - "-DOCIO_INSTALL_EXT_PACKAGES=NONE" - "-DOCIO_USE_SSE2NEON=OFF" - # GPU test fails with: libglut (GPU tests): failed to open display '' - "-DOCIO_BUILD_GPU_TESTS=OFF" - "-Dminizip-ng_INCLUDE_DIR=${minizip-ng}/include/minizip-ng" - ] ++ lib.optional (!pythonBindings) "-DOCIO_BUILD_PYTHON=OFF" + cmakeFlags = + [ + "-DOCIO_INSTALL_EXT_PACKAGES=NONE" + "-DOCIO_USE_SSE2NEON=OFF" + # GPU test fails with: libglut (GPU tests): failed to open display '' + "-DOCIO_BUILD_GPU_TESTS=OFF" + "-Dminizip-ng_INCLUDE_DIR=${minizip-ng}/include/minizip-ng" + ] + ++ lib.optional (!pythonBindings) "-DOCIO_BUILD_PYTHON=OFF" ++ lib.optional (!buildApps) "-DOCIO_BUILD_APPS=OFF"; # precision issues on non-x86 diff --git a/pkgs/development/libraries/opencsg/default.nix b/pkgs/development/libraries/opencsg/default.nix index 5aea0da2738086..b4b2c5a66c98e1 100644 --- a/pkgs/development/libraries/opencsg/default.nix +++ b/pkgs/development/libraries/opencsg/default.nix @@ -1,5 +1,18 @@ -{lib, stdenv, fetchurl, libGLU, libGL, libglut, glew, libXmu, libXext, libX11 -, qmake, GLUT, fixDarwinDylibNames }: +{ + lib, + stdenv, + fetchurl, + libGLU, + libGL, + libglut, + glew, + libXmu, + libXext, + libX11, + qmake, + GLUT, + fixDarwinDylibNames, +}: stdenv.mkDerivation rec { version = "1.6.0"; @@ -9,11 +22,18 @@ stdenv.mkDerivation rec { hash = "sha256-v4+4Dj4M4R2H3XjdFaDehy27iXLYf1+Jz/xGHvrUe+g="; }; - nativeBuildInputs = [ qmake ] - ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; + nativeBuildInputs = [ qmake ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; - buildInputs = [ glew ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libGLU libGL libglut libXmu libXext libX11 ] + buildInputs = + [ glew ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libGLU + libGL + libglut + libXmu + libXext + libX11 + ] ++ lib.optional stdenv.hostPlatform.isDarwin GLUT; doCheck = false; @@ -23,13 +43,15 @@ stdenv.mkDerivation rec { qmakeFlags=("''${qmakeFlags[@]}" "INSTALLDIR=$out") ''; - postInstall = '' - install -D copying.txt "$out/share/doc/opencsg/copying.txt" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/Applications - mv $out/bin/*.app $out/Applications - rmdir $out/bin || true - ''; + postInstall = + '' + install -D copying.txt "$out/share/doc/opencsg/copying.txt" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/Applications + mv $out/bin/*.app $out/Applications + rmdir $out/bin || true + ''; dontWrapQtApps = true; @@ -50,4 +72,3 @@ stdenv.mkDerivation rec { license = licenses.gpl2Plus; }; } - diff --git a/pkgs/development/libraries/opencv/libstdcxx-test.nix b/pkgs/development/libraries/opencv/libstdcxx-test.nix index d8cc483da9a894..63516f642ba530 100644 --- a/pkgs/development/libraries/opencv/libstdcxx-test.nix +++ b/pkgs/development/libraries/opencv/libstdcxx-test.nix @@ -1,17 +1,22 @@ -{ python3Packages, runCommand, attrName }: +{ + python3Packages, + runCommand, + attrName, +}: runCommand "${python3Packages.${attrName}.name}-libstdcxx-test" -{ - nativeBuildInputs = [ - (python3Packages.python.withPackages (ps: [ - (ps.${attrName}.override { enableCuda = true; }) - ps.scikit-image - ])) - ]; -} '' - python << EOF - import cv2 - from skimage.transform import pyramid_reduce - EOF - touch $out -'' + { + nativeBuildInputs = [ + (python3Packages.python.withPackages (ps: [ + (ps.${attrName}.override { enableCuda = true; }) + ps.scikit-image + ])) + ]; + } + '' + python << EOF + import cv2 + from skimage.transform import pyramid_reduce + EOF + touch $out + '' diff --git a/pkgs/development/libraries/openexr/default.nix b/pkgs/development/libraries/openexr/default.nix index a79759be24f226..84dc7fb990e79f 100644 --- a/pkgs/development/libraries/openexr/default.nix +++ b/pkgs/development/libraries/openexr/default.nix @@ -1,17 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, zlib -, ilmbase -, fetchpatch -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + zlib, + ilmbase, + fetchpatch, + cmake, }: stdenv.mkDerivation rec { pname = "openexr"; version = "2.5.10"; - outputs = [ "bin" "dev" "out" "doc" ]; + outputs = [ + "bin" + "dev" + "out" + "doc" + ]; src = fetchFromGitHub { owner = "AcademySoftwareFoundation"; @@ -54,7 +60,10 @@ stdenv.mkDerivation rec { ] ++ lib.optional stdenv.hostPlatform.isStatic "-DCMAKE_SKIP_RPATH=ON"; nativeBuildInputs = [ cmake ]; - propagatedBuildInputs = [ ilmbase zlib ]; + propagatedBuildInputs = [ + ilmbase + zlib + ]; # https://github.com/AcademySoftwareFoundation/openexr/issues/1400 # https://github.com/AcademySoftwareFoundation/openexr/issues/1281 diff --git a/pkgs/development/libraries/openscenegraph/default.nix b/pkgs/development/libraries/openscenegraph/default.nix index 1b0f4b229d36fd..ee13f76d7feedf 100644 --- a/pkgs/development/libraries/openscenegraph/default.nix +++ b/pkgs/development/libraries/openscenegraph/default.nix @@ -1,29 +1,68 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, fetchurl, cmake, pkg-config, doxygen, - libX11, libXinerama, libXrandr, libGLU, libGL, - glib, libxml2, pcre, zlib, - AGL, Accelerate, Carbon, Cocoa, Foundation, +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + fetchurl, + cmake, + pkg-config, + doxygen, + libX11, + libXinerama, + libXrandr, + libGLU, + libGL, + glib, + libxml2, + pcre, + zlib, + AGL, + Accelerate, + Carbon, + Cocoa, + Foundation, boost, - jpegSupport ? true, libjpeg, - exrSupport ? false, openexr_3, - gifSupport ? true, giflib, - pngSupport ? true, libpng, - tiffSupport ? true, libtiff, - gdalSupport ? false, gdal, - curlSupport ? true, curl, - colladaSupport ? false, opencollada, - opencascadeSupport ? false, opencascade-occt, - ffmpegSupport ? false, ffmpeg, - nvttSupport ? false, nvidia-texture-tools, - freetypeSupport ? true, freetype, - svgSupport ? false, librsvg, - pdfSupport ? false, poppler, - vncSupport ? false, libvncserver, - lasSupport ? false, libLAS, - luaSupport ? false, lua, - sdlSupport ? false, SDL2, - restSupport ? false, asio, + jpegSupport ? true, + libjpeg, + exrSupport ? false, + openexr_3, + gifSupport ? true, + giflib, + pngSupport ? true, + libpng, + tiffSupport ? true, + libtiff, + gdalSupport ? false, + gdal, + curlSupport ? true, + curl, + colladaSupport ? false, + opencollada, + opencascadeSupport ? false, + opencascade-occt, + ffmpegSupport ? false, + ffmpeg, + nvttSupport ? false, + nvidia-texture-tools, + freetypeSupport ? true, + freetype, + svgSupport ? false, + librsvg, + pdfSupport ? false, + poppler, + vncSupport ? false, + libvncserver, + lasSupport ? false, + libLAS, + luaSupport ? false, + lua, + sdlSupport ? false, + SDL2, + restSupport ? false, + asio, withApps ? false, - withExamples ? false, fltk, + withExamples ? false, + fltk, }: stdenv.mkDerivation rec { @@ -37,13 +76,27 @@ stdenv.mkDerivation rec { sha256 = "00i14h82qg3xzcyd8p02wrarnmby3aiwmz0z43l50byc9f8i05n1"; }; - nativeBuildInputs = [ pkg-config cmake doxygen ]; + nativeBuildInputs = [ + pkg-config + cmake + doxygen + ]; - buildInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ - libX11 libXinerama libXrandr libGLU libGL - ] ++ [ - glib libxml2 pcre zlib - ] ++ lib.optional jpegSupport libjpeg + buildInputs = + lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libX11 + libXinerama + libXrandr + libGLU + libGL + ] + ++ [ + glib + libxml2 + pcre + zlib + ] + ++ lib.optional jpegSupport libjpeg ++ lib.optional exrSupport openexr_3 ++ lib.optional gifSupport giflib ++ lib.optional pngSupport libpng @@ -63,10 +116,15 @@ stdenv.mkDerivation rec { ++ lib.optional sdlSupport SDL2 ++ lib.optional restSupport asio ++ lib.optionals withExamples [ fltk ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ AGL Accelerate Carbon Cocoa Foundation ] - ++ lib.optional (restSupport || colladaSupport) boost - ; + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AGL + Accelerate + Carbon + Cocoa + Foundation + ] + ++ lib.optional (restSupport || colladaSupport) boost; patches = [ (fetchpatch { @@ -81,12 +139,17 @@ stdenv.mkDerivation rec { }) ]; - cmakeFlags = lib.optional (!withApps) "-DBUILD_OSG_APPLICATIONS=OFF" ++ lib.optional withExamples "-DBUILD_OSG_EXAMPLES=ON"; + cmakeFlags = + lib.optional (!withApps) "-DBUILD_OSG_APPLICATIONS=OFF" + ++ lib.optional withExamples "-DBUILD_OSG_EXAMPLES=ON"; meta = with lib; { description = "3D graphics toolkit"; homepage = "http://www.openscenegraph.org/"; - maintainers = with maintainers; [ aanderse raskin ]; + maintainers = with maintainers; [ + aanderse + raskin + ]; platforms = with platforms; linux ++ darwin; license = "OpenSceneGraph Public License - free LGPL-based license"; }; diff --git a/pkgs/development/libraries/openssl/default.nix b/pkgs/development/libraries/openssl/default.nix index 3dee6474adee2d..f0cf68f8b6aa67 100644 --- a/pkgs/development/libraries/openssl/default.nix +++ b/pkgs/development/libraries/openssl/default.nix @@ -1,16 +1,25 @@ -{ lib, stdenv, fetchurl, buildPackages, perl, coreutils, writeShellScript -, makeBinaryWrapper -, withCryptodev ? false, cryptodev -, withZlib ? false, zlib -, enableSSL2 ? false -, enableSSL3 ? false -, enableMD2 ? false -, enableKTLS ? stdenv.hostPlatform.isLinux -, static ? stdenv.hostPlatform.isStatic -# path to openssl.cnf file. will be placed in $etc/etc/ssl/openssl.cnf to replace the default -, conf ? null -, removeReferencesTo -, testers +{ + lib, + stdenv, + fetchurl, + buildPackages, + perl, + coreutils, + writeShellScript, + makeBinaryWrapper, + withCryptodev ? false, + cryptodev, + withZlib ? false, + zlib, + enableSSL2 ? false, + enableSSL3 ? false, + enableMD2 ? false, + enableKTLS ? stdenv.hostPlatform.isLinux, + static ? stdenv.hostPlatform.isStatic, + # path to openssl.cnf file. will be placed in $etc/etc/ssl/openssl.cnf to replace the default + conf ? null, + removeReferencesTo, + testers, }: # Note: this package is used for bootstrapping fetchurl, and thus @@ -19,245 +28,290 @@ # files. let - common = { version, hash, patches ? [], withDocs ? false, extraMeta ? {} }: - stdenv.mkDerivation (finalAttrs: { - pname = "openssl"; - inherit version; - - src = fetchurl { - url = if lib.versionOlder version "3.0" then - let - versionFixed = builtins.replaceStrings ["."] ["_"] version; - in - "https://github.com/openssl/openssl/releases/download/OpenSSL_${versionFixed}/openssl-${version}.tar.gz" - else - "https://github.com/openssl/openssl/releases/download/openssl-${version}/openssl-${version}.tar.gz"; - inherit hash; - }; - - inherit patches; - - postPatch = '' - patchShebangs Configure - '' + lib.optionalString (lib.versionOlder version "1.1.1") '' - patchShebangs test/* - for a in test/t* ; do - substituteInPlace "$a" \ - --replace /bin/rm rm - done - '' - # config is a configure script which is not installed. - + lib.optionalString (lib.versionAtLeast version "1.1.1") '' - substituteInPlace config --replace '/usr/bin/env' '${buildPackages.coreutils}/bin/env' - '' + lib.optionalString (lib.versionAtLeast version "1.1.1" && stdenv.hostPlatform.isMusl) '' - substituteInPlace crypto/async/arch/async_posix.h \ - --replace '!defined(__ANDROID__) && !defined(__OpenBSD__)' \ - '!defined(__ANDROID__) && !defined(__OpenBSD__) && 0' - '' - # Move ENGINESDIR into OPENSSLDIR for static builds, in order to move - # it to the separate etc output. - + lib.optionalString static '' - substituteInPlace Configurations/unix-Makefile.tmpl \ - --replace 'ENGINESDIR=$(libdir)/engines-{- $sover_dirname -}' \ - 'ENGINESDIR=$(OPENSSLDIR)/engines-{- $sover_dirname -}' - ''; - - outputs = [ "bin" "dev" "out" "man" ] - ++ lib.optional withDocs "doc" - # Separate output for the runtime dependencies of the static build. - # Specifically, move OPENSSLDIR into this output, as its path will be - # compiled into 'libcrypto.a'. This makes it a runtime dependency of - # any package that statically links openssl, so we want to keep that - # output minimal. - ++ lib.optional static "etc"; - setOutputFlags = false; - separateDebugInfo = - !stdenv.hostPlatform.isDarwin && - !(stdenv.hostPlatform.useLLVM or false) && - stdenv.cc.isGNU; - - nativeBuildInputs = - lib.optional (!stdenv.hostPlatform.isWindows) makeBinaryWrapper - ++ [ perl ] - ++ lib.optionals static [ removeReferencesTo ]; - buildInputs = lib.optional withCryptodev cryptodev - ++ lib.optional withZlib zlib; - - # TODO(@Ericson2314): Improve with mass rebuild - configurePlatforms = []; - configureScript = { - armv5tel-linux = "./Configure linux-armv4 -march=armv5te"; - armv6l-linux = "./Configure linux-armv4 -march=armv6"; - armv7l-linux = "./Configure linux-armv4 -march=armv7-a"; - x86_64-darwin = "./Configure darwin64-x86_64-cc"; - aarch64-darwin = "./Configure darwin64-arm64-cc"; - x86_64-linux = "./Configure linux-x86_64"; - x86_64-solaris = "./Configure solaris64-x86_64-gcc"; - powerpc64-linux = "./Configure linux-ppc64"; - riscv32-linux = "./Configure ${if lib.versionAtLeast version "3.2" then "linux32-riscv32" else "linux-latomic"}"; - riscv64-linux = "./Configure linux64-riscv64"; - }.${stdenv.hostPlatform.system} or ( - if stdenv.hostPlatform == stdenv.buildPlatform - then "./config" - else if stdenv.hostPlatform.isBSD - then if stdenv.hostPlatform.isx86_64 then "./Configure BSD-x86_64" - else if stdenv.hostPlatform.isx86_32 - then "./Configure BSD-x86" + lib.optionalString stdenv.hostPlatform.isElf "-elf" - else "./Configure BSD-generic${toString stdenv.hostPlatform.parsed.cpu.bits}" - else if stdenv.hostPlatform.isMinGW - then "./Configure mingw${lib.optionalString - (stdenv.hostPlatform.parsed.cpu.bits != 32) - (toString stdenv.hostPlatform.parsed.cpu.bits)}" - else if stdenv.hostPlatform.isLinux - then if stdenv.hostPlatform.isx86_64 then "./Configure linux-x86_64" - else if stdenv.hostPlatform.isMicroBlaze then "./Configure linux-latomic" - else if stdenv.hostPlatform.isMips32 then "./Configure linux-mips32" - else if stdenv.hostPlatform.isMips64n32 then "./Configure linux-mips64" - else if stdenv.hostPlatform.isMips64n64 then "./Configure linux64-mips64" - else "./Configure linux-generic${toString stdenv.hostPlatform.parsed.cpu.bits}" - else if stdenv.hostPlatform.isiOS - then "./Configure ios${toString stdenv.hostPlatform.parsed.cpu.bits}-cross" - else - throw "Not sure what configuration to use for ${stdenv.hostPlatform.config}" - ); - - # OpenSSL doesn't like the `--enable-static` / `--disable-shared` flags. - dontAddStaticConfigureFlags = true; - configureFlags = [ - "shared" # "shared" builds both shared and static libraries - "--libdir=lib" - (if !static then - "--openssldir=etc/ssl" - else - # Move OPENSSLDIR to the 'etc' output for static builds. Prepend '/.' - # to the path to make it appear absolute before variable expansion, - # else the 'prefix' would be prepended to it. - "--openssldir=/.$(etc)/etc/ssl" - ) - ] ++ lib.optionals withCryptodev [ - "-DHAVE_CRYPTODEV" - "-DUSE_CRYPTODEV_DIGESTS" - ] ++ lib.optional enableMD2 "enable-md2" - ++ lib.optional enableSSL2 "enable-ssl2" - ++ lib.optional enableSSL3 "enable-ssl3" - # We select KTLS here instead of the configure-time detection (which we patch out). - # KTLS should work on FreeBSD 13+ as well, so we could enable it if someone tests it. - ++ lib.optional (lib.versionAtLeast version "3.0.0" && enableKTLS) "enable-ktls" - ++ lib.optional (lib.versionAtLeast version "1.1.1" && stdenv.hostPlatform.isAarch64) "no-afalgeng" - # OpenSSL needs a specific `no-shared` configure flag. - # See https://wiki.openssl.org/index.php/Compilation_and_Installation#Configure_Options - # for a comprehensive list of configuration options. - ++ lib.optional (lib.versionAtLeast version "1.1.1" && static) "no-shared" - ++ lib.optional (lib.versionAtLeast version "3.0.0" && static) "no-module" - # This introduces a reference to the CTLOG_FILE which is undesired when - # trying to build binaries statically. - ++ lib.optional static "no-ct" - ++ lib.optional withZlib "zlib" - # /dev/crypto support has been dropped in OpenBSD 5.7. - # - # OpenBSD's ports does this too, - # https://github.com/openbsd/ports/blob/a1147500c76970fea22947648fb92a093a529d7c/security/openssl/3.3/Makefile#L25. - # - # https://github.com/openssl/openssl/pull/10565 indicated the - # intent was that this would be configured properly automatically, - # but that doesn't appear to be the case. - ++ lib.optional stdenv.hostPlatform.isOpenBSD "no-devcryptoeng" - ++ lib.optionals (stdenv.hostPlatform.isMips && stdenv.hostPlatform ? gcc.arch) [ - # This is necessary in order to avoid openssl adding -march - # flags which ultimately conflict with those added by - # cc-wrapper. Openssl assumes that it can scan CFLAGS to - # detect any -march flags, using this perl code: - # - # && !grep { $_ =~ /-m(ips|arch=)/ } (@{$config{CFLAGS}}) - # - # The following bogus CFLAGS environment variable triggers the - # the code above, inhibiting `./Configure` from adding the - # conflicting flags. - "CFLAGS=-march=${stdenv.hostPlatform.gcc.arch}" - ]; - - makeFlags = [ - "MANDIR=$(man)/share/man" - # This avoids conflicts between man pages of openssl subcommands (for - # example 'ts' and 'err') man pages and their equivalent top-level - # command in other packages (respectively man-pages and moreutils). - # This is done in ubuntu and archlinux, and possiibly many other distros. - "MANSUFFIX=ssl" - ]; - - enableParallelBuilding = true; - - postInstall = - (if static then '' - # OPENSSLDIR has a reference to self - remove-references-to -t $out $out/lib/*.a - '' else '' - # If we're building dynamic libraries, then don't install static - # libraries. - if [ -n "$(echo $out/lib/*.so $out/lib/*.dylib $out/lib/*.dll)" ]; then - rm "$out/lib/"*.a - fi - - # 'etc' is a separate output on static builds only. - etc=$out - '') + '' - mkdir -p $bin - mv $out/bin $bin/bin - - '' + lib.optionalString (!stdenv.hostPlatform.isWindows) - # makeWrapper is broken for windows cross (https://github.com/NixOS/nixpkgs/issues/120726) - '' - # c_rehash is a legacy perl script with the same functionality - # as `openssl rehash` - # this wrapper script is created to maintain backwards compatibility without - # depending on perl - makeWrapper $bin/bin/openssl $bin/bin/c_rehash \ - --add-flags "rehash" - '' + '' - - mkdir $dev - mv $out/include $dev/ - - # remove dependency on Perl at runtime - rm -r $etc/etc/ssl/misc - - rmdir $etc/etc/ssl/{certs,private} - '' + lib.optionalString (conf != null) '' - cat ${conf} > $etc/etc/ssl/openssl.cnf - ''; - - postFixup = lib.optionalString (!stdenv.hostPlatform.isWindows) '' - # Check to make sure the main output and the static runtime dependencies - # don't depend on perl - if grep -r '${buildPackages.perl}' $out $etc; then - echo "Found an erroneous dependency on perl ^^^" >&2 - exit 1 - fi - '' + lib.optionalString (lib.versionAtLeast version "3.3.0") '' - # cleanup cmake helpers for now (for OpenSSL >= 3.3), only rely on pkg-config. - # pkg-config gets its paths fixed correctly - rm -rf $dev/lib/cmake - ''; - - passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; - - meta = { - homepage = "https://www.openssl.org/"; - changelog = "https://github.com/openssl/openssl/blob/openssl-${version}/CHANGES.md"; - description = "Cryptographic library that implements the SSL and TLS protocols"; - license = lib.licenses.openssl; - mainProgram = "openssl"; - maintainers = with lib.maintainers; [ thillux ] ++ lib.teams.stridtech.members; - pkgConfigModules = [ - "libcrypto" - "libssl" - "openssl" + common = + { + version, + hash, + patches ? [ ], + withDocs ? false, + extraMeta ? { }, + }: + stdenv.mkDerivation (finalAttrs: { + pname = "openssl"; + inherit version; + + src = fetchurl { + url = + if lib.versionOlder version "3.0" then + let + versionFixed = builtins.replaceStrings [ "." ] [ "_" ] version; + in + "https://github.com/openssl/openssl/releases/download/OpenSSL_${versionFixed}/openssl-${version}.tar.gz" + else + "https://github.com/openssl/openssl/releases/download/openssl-${version}/openssl-${version}.tar.gz"; + inherit hash; + }; + + inherit patches; + + postPatch = + '' + patchShebangs Configure + '' + + lib.optionalString (lib.versionOlder version "1.1.1") '' + patchShebangs test/* + for a in test/t* ; do + substituteInPlace "$a" \ + --replace /bin/rm rm + done + '' + # config is a configure script which is not installed. + + lib.optionalString (lib.versionAtLeast version "1.1.1") '' + substituteInPlace config --replace '/usr/bin/env' '${buildPackages.coreutils}/bin/env' + '' + + lib.optionalString (lib.versionAtLeast version "1.1.1" && stdenv.hostPlatform.isMusl) '' + substituteInPlace crypto/async/arch/async_posix.h \ + --replace '!defined(__ANDROID__) && !defined(__OpenBSD__)' \ + '!defined(__ANDROID__) && !defined(__OpenBSD__) && 0' + '' + # Move ENGINESDIR into OPENSSLDIR for static builds, in order to move + # it to the separate etc output. + + lib.optionalString static '' + substituteInPlace Configurations/unix-Makefile.tmpl \ + --replace 'ENGINESDIR=$(libdir)/engines-{- $sover_dirname -}' \ + 'ENGINESDIR=$(OPENSSLDIR)/engines-{- $sover_dirname -}' + ''; + + outputs = + [ + "bin" + "dev" + "out" + "man" + ] + ++ lib.optional withDocs "doc" + # Separate output for the runtime dependencies of the static build. + # Specifically, move OPENSSLDIR into this output, as its path will be + # compiled into 'libcrypto.a'. This makes it a runtime dependency of + # any package that statically links openssl, so we want to keep that + # output minimal. + ++ lib.optional static "etc"; + setOutputFlags = false; + separateDebugInfo = + !stdenv.hostPlatform.isDarwin && !(stdenv.hostPlatform.useLLVM or false) && stdenv.cc.isGNU; + + nativeBuildInputs = + lib.optional (!stdenv.hostPlatform.isWindows) makeBinaryWrapper + ++ [ perl ] + ++ lib.optionals static [ removeReferencesTo ]; + buildInputs = lib.optional withCryptodev cryptodev ++ lib.optional withZlib zlib; + + # TODO(@Ericson2314): Improve with mass rebuild + configurePlatforms = [ ]; + configureScript = + { + armv5tel-linux = "./Configure linux-armv4 -march=armv5te"; + armv6l-linux = "./Configure linux-armv4 -march=armv6"; + armv7l-linux = "./Configure linux-armv4 -march=armv7-a"; + x86_64-darwin = "./Configure darwin64-x86_64-cc"; + aarch64-darwin = "./Configure darwin64-arm64-cc"; + x86_64-linux = "./Configure linux-x86_64"; + x86_64-solaris = "./Configure solaris64-x86_64-gcc"; + powerpc64-linux = "./Configure linux-ppc64"; + riscv32-linux = "./Configure ${ + if lib.versionAtLeast version "3.2" then "linux32-riscv32" else "linux-latomic" + }"; + riscv64-linux = "./Configure linux64-riscv64"; + } + .${stdenv.hostPlatform.system} or ( + if stdenv.hostPlatform == stdenv.buildPlatform then + "./config" + else if stdenv.hostPlatform.isBSD then + if stdenv.hostPlatform.isx86_64 then + "./Configure BSD-x86_64" + else if stdenv.hostPlatform.isx86_32 then + "./Configure BSD-x86" + lib.optionalString stdenv.hostPlatform.isElf "-elf" + else + "./Configure BSD-generic${toString stdenv.hostPlatform.parsed.cpu.bits}" + else if stdenv.hostPlatform.isMinGW then + "./Configure mingw${ + lib.optionalString (stdenv.hostPlatform.parsed.cpu.bits != 32) ( + toString stdenv.hostPlatform.parsed.cpu.bits + ) + }" + else if stdenv.hostPlatform.isLinux then + if stdenv.hostPlatform.isx86_64 then + "./Configure linux-x86_64" + else if stdenv.hostPlatform.isMicroBlaze then + "./Configure linux-latomic" + else if stdenv.hostPlatform.isMips32 then + "./Configure linux-mips32" + else if stdenv.hostPlatform.isMips64n32 then + "./Configure linux-mips64" + else if stdenv.hostPlatform.isMips64n64 then + "./Configure linux64-mips64" + else + "./Configure linux-generic${toString stdenv.hostPlatform.parsed.cpu.bits}" + else if stdenv.hostPlatform.isiOS then + "./Configure ios${toString stdenv.hostPlatform.parsed.cpu.bits}-cross" + else + throw "Not sure what configuration to use for ${stdenv.hostPlatform.config}" + ); + + # OpenSSL doesn't like the `--enable-static` / `--disable-shared` flags. + dontAddStaticConfigureFlags = true; + configureFlags = + [ + "shared" # "shared" builds both shared and static libraries + "--libdir=lib" + ( + if !static then + "--openssldir=etc/ssl" + else + # Move OPENSSLDIR to the 'etc' output for static builds. Prepend '/.' + # to the path to make it appear absolute before variable expansion, + # else the 'prefix' would be prepended to it. + "--openssldir=/.$(etc)/etc/ssl" + ) + ] + ++ lib.optionals withCryptodev [ + "-DHAVE_CRYPTODEV" + "-DUSE_CRYPTODEV_DIGESTS" + ] + ++ lib.optional enableMD2 "enable-md2" + ++ lib.optional enableSSL2 "enable-ssl2" + ++ lib.optional enableSSL3 "enable-ssl3" + # We select KTLS here instead of the configure-time detection (which we patch out). + # KTLS should work on FreeBSD 13+ as well, so we could enable it if someone tests it. + ++ lib.optional (lib.versionAtLeast version "3.0.0" && enableKTLS) "enable-ktls" + ++ lib.optional (lib.versionAtLeast version "1.1.1" && stdenv.hostPlatform.isAarch64) "no-afalgeng" + # OpenSSL needs a specific `no-shared` configure flag. + # See https://wiki.openssl.org/index.php/Compilation_and_Installation#Configure_Options + # for a comprehensive list of configuration options. + ++ lib.optional (lib.versionAtLeast version "1.1.1" && static) "no-shared" + ++ lib.optional (lib.versionAtLeast version "3.0.0" && static) "no-module" + # This introduces a reference to the CTLOG_FILE which is undesired when + # trying to build binaries statically. + ++ lib.optional static "no-ct" + ++ lib.optional withZlib "zlib" + # /dev/crypto support has been dropped in OpenBSD 5.7. + # + # OpenBSD's ports does this too, + # https://github.com/openbsd/ports/blob/a1147500c76970fea22947648fb92a093a529d7c/security/openssl/3.3/Makefile#L25. + # + # https://github.com/openssl/openssl/pull/10565 indicated the + # intent was that this would be configured properly automatically, + # but that doesn't appear to be the case. + ++ lib.optional stdenv.hostPlatform.isOpenBSD "no-devcryptoeng" + ++ lib.optionals (stdenv.hostPlatform.isMips && stdenv.hostPlatform ? gcc.arch) [ + # This is necessary in order to avoid openssl adding -march + # flags which ultimately conflict with those added by + # cc-wrapper. Openssl assumes that it can scan CFLAGS to + # detect any -march flags, using this perl code: + # + # && !grep { $_ =~ /-m(ips|arch=)/ } (@{$config{CFLAGS}}) + # + # The following bogus CFLAGS environment variable triggers the + # the code above, inhibiting `./Configure` from adding the + # conflicting flags. + "CFLAGS=-march=${stdenv.hostPlatform.gcc.arch}" + ]; + + makeFlags = [ + "MANDIR=$(man)/share/man" + # This avoids conflicts between man pages of openssl subcommands (for + # example 'ts' and 'err') man pages and their equivalent top-level + # command in other packages (respectively man-pages and moreutils). + # This is done in ubuntu and archlinux, and possiibly many other distros. + "MANSUFFIX=ssl" ]; - platforms = lib.platforms.all; - } // extraMeta; - }); -in { + enableParallelBuilding = true; + + postInstall = + ( + if static then + '' + # OPENSSLDIR has a reference to self + remove-references-to -t $out $out/lib/*.a + '' + else + '' + # If we're building dynamic libraries, then don't install static + # libraries. + if [ -n "$(echo $out/lib/*.so $out/lib/*.dylib $out/lib/*.dll)" ]; then + rm "$out/lib/"*.a + fi + + # 'etc' is a separate output on static builds only. + etc=$out + '' + ) + + '' + mkdir -p $bin + mv $out/bin $bin/bin + + '' + + + lib.optionalString (!stdenv.hostPlatform.isWindows) + # makeWrapper is broken for windows cross (https://github.com/NixOS/nixpkgs/issues/120726) + '' + # c_rehash is a legacy perl script with the same functionality + # as `openssl rehash` + # this wrapper script is created to maintain backwards compatibility without + # depending on perl + makeWrapper $bin/bin/openssl $bin/bin/c_rehash \ + --add-flags "rehash" + '' + + '' + + mkdir $dev + mv $out/include $dev/ + + # remove dependency on Perl at runtime + rm -r $etc/etc/ssl/misc + + rmdir $etc/etc/ssl/{certs,private} + '' + + lib.optionalString (conf != null) '' + cat ${conf} > $etc/etc/ssl/openssl.cnf + ''; + + postFixup = + lib.optionalString (!stdenv.hostPlatform.isWindows) '' + # Check to make sure the main output and the static runtime dependencies + # don't depend on perl + if grep -r '${buildPackages.perl}' $out $etc; then + echo "Found an erroneous dependency on perl ^^^" >&2 + exit 1 + fi + '' + + lib.optionalString (lib.versionAtLeast version "3.3.0") '' + # cleanup cmake helpers for now (for OpenSSL >= 3.3), only rely on pkg-config. + # pkg-config gets its paths fixed correctly + rm -rf $dev/lib/cmake + ''; + + passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; + + meta = { + homepage = "https://www.openssl.org/"; + changelog = "https://github.com/openssl/openssl/blob/openssl-${version}/CHANGES.md"; + description = "Cryptographic library that implements the SSL and TLS protocols"; + license = lib.licenses.openssl; + mainProgram = "openssl"; + maintainers = with lib.maintainers; [ thillux ] ++ lib.teams.stridtech.members; + pkgConfigModules = [ + "libcrypto" + "libssl" + "openssl" + ]; + platforms = lib.platforms.all; + } // extraMeta; + }); + +in +{ # intended version "policy": # - 1.1 as long as some package exists, which does not build without it # (tracking issue: https://github.com/NixOS/nixpkgs/issues/269713) @@ -277,9 +331,9 @@ in { patches = [ ./1.1/nix-ssl-cert-file.patch - (if stdenv.hostPlatform.isDarwin - then ./use-etc-ssl-certs-darwin.patch - else ./use-etc-ssl-certs.patch) + ( + if stdenv.hostPlatform.isDarwin then ./use-etc-ssl-certs-darwin.patch else ./use-etc-ssl-certs.patch + ) ]; withDocs = true; extraMeta = { @@ -300,9 +354,9 @@ in { # This patch disables build-time detection. ./3.0/openssl-disable-kernel-detection.patch - (if stdenv.hostPlatform.isDarwin - then ./use-etc-ssl-certs-darwin.patch - else ./use-etc-ssl-certs.patch) + ( + if stdenv.hostPlatform.isDarwin then ./use-etc-ssl-certs-darwin.patch else ./use-etc-ssl-certs.patch + ) ]; withDocs = true; @@ -323,9 +377,12 @@ in { # This patch disables build-time detection. ./3.0/openssl-disable-kernel-detection.patch - (if stdenv.hostPlatform.isDarwin - then ./3.3/use-etc-ssl-certs-darwin.patch - else ./3.3/use-etc-ssl-certs.patch) + ( + if stdenv.hostPlatform.isDarwin then + ./3.3/use-etc-ssl-certs-darwin.patch + else + ./3.3/use-etc-ssl-certs.patch + ) ]; withDocs = true; diff --git a/pkgs/development/libraries/openvdb/default.nix b/pkgs/development/libraries/openvdb/default.nix index d7718eb1eee40f..b92a0601a8be30 100644 --- a/pkgs/development/libraries/openvdb/default.nix +++ b/pkgs/development/libraries/openvdb/default.nix @@ -1,11 +1,23 @@ -{ lib, stdenv, fetchFromGitHub, cmake, boost, jemalloc, c-blosc, tbb, zlib }: - -stdenv.mkDerivation rec { + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + jemalloc, + c-blosc, + tbb, + zlib, +}: + +stdenv.mkDerivation rec { pname = "openvdb"; version = "12.0.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "AcademySoftwareFoundation"; @@ -16,14 +28,30 @@ stdenv.mkDerivation rec nativeBuildInputs = [ cmake ]; - buildInputs = [ boost tbb jemalloc c-blosc zlib ]; + buildInputs = [ + boost + tbb + jemalloc + c-blosc + zlib + ]; - cmakeFlags = [ "-DOPENVDB_CORE_STATIC=OFF" "-DOPENVDB_BUILD_NANOVDB=ON"]; + cmakeFlags = [ + "-DOPENVDB_CORE_STATIC=OFF" + "-DOPENVDB_BUILD_NANOVDB=ON" + ]; # error: aligned deallocation function of type 'void (void *, std::align_val_t) noexcept' is only available on macOS 10.13 or newer - env = lib.optionalAttrs (stdenv.hostPlatform.isDarwin && lib.versionOlder stdenv.hostPlatform.darwinMinVersion "10.13" && lib.versionAtLeast tbb.version "2021.8.0") { - NIX_CFLAGS_COMPILE = "-faligned-allocation"; - }; + env = + lib.optionalAttrs + ( + stdenv.hostPlatform.isDarwin + && lib.versionOlder stdenv.hostPlatform.darwinMinVersion "10.13" + && lib.versionAtLeast tbb.version "2021.8.0" + ) + { + NIX_CFLAGS_COMPILE = "-faligned-allocation"; + }; postFixup = '' substituteInPlace $dev/lib/cmake/OpenVDB/FindOpenVDB.cmake \ diff --git a/pkgs/development/libraries/pango/default.nix b/pkgs/development/libraries/pango/default.nix index fcdf8f27f9811d..0e1c425cbad4a0 100644 --- a/pkgs/development/libraries/pango/default.nix +++ b/pkgs/development/libraries/pango/default.nix @@ -1,35 +1,46 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, cairo -, harfbuzz -, libintl -, libthai -, darwin -, fribidi -, gnome -, gi-docgen -, makeFontsConf -, freefont_ttf -, meson -, ninja -, glib -, python3 -, x11Support? !stdenv.hostPlatform.isDarwin, libXft -, withIntrospection ? lib.meta.availableOn stdenv.hostPlatform gobject-introspection && stdenv.hostPlatform.emulatorAvailable buildPackages -, buildPackages, gobject-introspection -, testers +{ + lib, + stdenv, + fetchurl, + pkg-config, + cairo, + harfbuzz, + libintl, + libthai, + darwin, + fribidi, + gnome, + gi-docgen, + makeFontsConf, + freefont_ttf, + meson, + ninja, + glib, + python3, + x11Support ? !stdenv.hostPlatform.isDarwin, + libXft, + withIntrospection ? + lib.meta.availableOn stdenv.hostPlatform gobject-introspection + && stdenv.hostPlatform.emulatorAvailable buildPackages, + buildPackages, + gobject-introspection, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "pango"; version = "1.54.0"; - outputs = [ "bin" "out" "dev" ] ++ lib.optional withIntrospection "devdoc"; + outputs = [ + "bin" + "out" + "dev" + ] ++ lib.optional withIntrospection "devdoc"; src = fetchurl { - url = with finalAttrs; "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; + url = + with finalAttrs; + "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; hash = "sha256-ip7tdQIe5zTX/A/fOmXDu6Ud/v5K5RqbQUpgxwstHtg="; }; @@ -37,34 +48,44 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - nativeBuildInputs = [ - meson ninja - glib # for glib-mkenum - pkg-config - python3 - ] ++ lib.optionals withIntrospection [ - gi-docgen - gobject-introspection - ]; + nativeBuildInputs = + [ + meson + ninja + glib # for glib-mkenum + pkg-config + python3 + ] + ++ lib.optionals withIntrospection [ + gi-docgen + gobject-introspection + ]; - buildInputs = [ - fribidi - libthai - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - ApplicationServices - Carbon - CoreGraphics - CoreText - ]); - - propagatedBuildInputs = [ - cairo - glib - libintl - harfbuzz - ] ++ lib.optionals x11Support [ - libXft - ]; + buildInputs = + [ + fribidi + libthai + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + ApplicationServices + Carbon + CoreGraphics + CoreText + ] + ); + + propagatedBuildInputs = + [ + cairo + glib + libintl + harfbuzz + ] + ++ lib.optionals x11Support [ + libXft + ]; mesonFlags = [ (lib.mesonBool "documentation" withIntrospection) diff --git a/pkgs/development/libraries/pangolin/default.nix b/pkgs/development/libraries/pangolin/default.nix index f15a7dfe449003..c53c31e32c1eb4 100644 --- a/pkgs/development/libraries/pangolin/default.nix +++ b/pkgs/development/libraries/pangolin/default.nix @@ -1,6 +1,20 @@ -{ stdenv, lib, fetchFromGitHub, cmake, pkg-config, doxygen, libGL, glew -, xorg, ffmpeg, libjpeg, libpng, libtiff, eigen -, Carbon, Cocoa +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + doxygen, + libGL, + glew, + xorg, + ffmpeg, + libjpeg, + libpng, + libtiff, + eigen, + Carbon, + Cocoa, }: stdenv.mkDerivation rec { @@ -14,19 +28,27 @@ stdenv.mkDerivation rec { sha256 = "sha256-B5YuNcJZHjR3dlVs66rySi68j29O3iMtlQvCjTUZBeY="; }; - nativeBuildInputs = [ cmake pkg-config doxygen ]; + nativeBuildInputs = [ + cmake + pkg-config + doxygen + ]; - buildInputs = [ - libGL - glew - xorg.libX11 - ffmpeg - libjpeg - libpng - libtiff - eigen - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Carbon Cocoa ]; + buildInputs = + [ + libGL + glew + xorg.libX11 + ffmpeg + libjpeg + libpng + libtiff + eigen + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + Cocoa + ]; # The tests use cmake's findPackage to find the installed version of # pangolin, which isn't what we want (or available). @@ -47,7 +69,7 @@ stdenv.mkDerivation rec { ''; homepage = "https://github.com/stevenlovegrove/Pangolin"; license = lib.licenses.mit; - maintainers = []; + maintainers = [ ]; platforms = lib.platforms.all; }; } diff --git a/pkgs/development/libraries/pangomm/2.42.nix b/pkgs/development/libraries/pangomm/2.42.nix index ebbaee66856302..e855aeb3659b0d 100644 --- a/pkgs/development/libraries/pangomm/2.42.nix +++ b/pkgs/development/libraries/pangomm/2.42.nix @@ -1,9 +1,21 @@ -{ lib, stdenv, fetchurl, pkg-config, meson, ninja, python3, pango, glibmm, cairomm, gnome -, ApplicationServices }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + meson, + ninja, + python3, + pango, + glibmm, + cairomm, + gnome, + ApplicationServices, +}: stdenv.mkDerivation rec { pname = "pangomm"; - version= "2.42.2"; + version = "2.42.2"; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -19,12 +31,26 @@ stdenv.mkDerivation rec { ./2.42.2-add-missing-include-attrlist.cc.patch ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ pkg-config meson ninja python3 ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ApplicationServices + nativeBuildInputs = + [ + pkg-config + meson + ninja + python3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ApplicationServices + ]; + propagatedBuildInputs = [ + pango + glibmm + cairomm ]; - propagatedBuildInputs = [ pango glibmm cairomm ]; doCheck = true; @@ -37,12 +63,19 @@ stdenv.mkDerivation rec { }; meta = with lib; { - broken = (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) || stdenv.hostPlatform.isDarwin; + broken = + (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) || stdenv.hostPlatform.isDarwin; description = "C++ interface to the Pango text rendering library"; - homepage = "https://www.pango.org/"; - license = with licenses; [ lgpl2 lgpl21 ]; - maintainers = with maintainers; [ lovek323 raskin ]; - platforms = platforms.unix; + homepage = "https://www.pango.org/"; + license = with licenses; [ + lgpl2 + lgpl21 + ]; + maintainers = with maintainers; [ + lovek323 + raskin + ]; + platforms = platforms.unix; longDescription = '' Pango is a library for laying out and rendering of text, with an diff --git a/pkgs/development/libraries/pangomm/2.48.nix b/pkgs/development/libraries/pangomm/2.48.nix index 92acaf32c09c39..748b961c65316f 100644 --- a/pkgs/development/libraries/pangomm/2.48.nix +++ b/pkgs/development/libraries/pangomm/2.48.nix @@ -1,36 +1,42 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, meson -, ninja -, python3 -, pango -, glibmm_2_68 -, cairomm_1_16 -, gnome -, ApplicationServices +{ + stdenv, + lib, + fetchurl, + pkg-config, + meson, + ninja, + python3, + pango, + glibmm_2_68, + cairomm_1_16, + gnome, + ApplicationServices, }: stdenv.mkDerivation rec { pname = "pangomm"; - version= "2.54.0"; + version = "2.54.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; hash = "sha256-Slsf0bfEehr0UnfqgrWr6sqOCPsQon2qY5TPiNdOes8="; }; - nativeBuildInputs = [ - pkg-config - meson - ninja - python3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ApplicationServices - ]; + nativeBuildInputs = + [ + pkg-config + meson + ninja + python3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ApplicationServices + ]; propagatedBuildInputs = [ pango @@ -59,7 +65,12 @@ stdenv.mkDerivation rec { ''; homepage = "https://www.pango.org/"; license = licenses.lgpl21Plus; - maintainers = teams.gnome.members ++ (with maintainers; [ lovek323 raskin ]); + maintainers = + teams.gnome.members + ++ (with maintainers; [ + lovek323 + raskin + ]); platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/pangomm/default.nix b/pkgs/development/libraries/pangomm/default.nix index 65dede46ee9ebb..9504a5ba9d1906 100644 --- a/pkgs/development/libraries/pangomm/default.nix +++ b/pkgs/development/libraries/pangomm/default.nix @@ -1,21 +1,47 @@ -{ lib, stdenv, fetchurl, pkg-config, meson, ninja, python3, pango, glibmm, cairomm, gnome -, ApplicationServices }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + meson, + ninja, + python3, + pango, + glibmm, + cairomm, + gnome, + ApplicationServices, +}: stdenv.mkDerivation rec { pname = "pangomm"; - version= "2.46.4"; + version = "2.46.4"; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; sha256 = "sha256-uSAWZhUmQk3kuTd/FRL1l4H0H7FsnAJn1hM7oc1o2yI="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ pkg-config meson ninja python3 ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ApplicationServices + nativeBuildInputs = + [ + pkg-config + meson + ninja + python3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ApplicationServices + ]; + propagatedBuildInputs = [ + pango + glibmm + cairomm ]; - propagatedBuildInputs = [ pango glibmm cairomm ]; doCheck = true; @@ -29,10 +55,16 @@ stdenv.mkDerivation rec { meta = with lib; { description = "C++ interface to the Pango text rendering library"; - homepage = "https://www.pango.org/"; - license = with licenses; [ lgpl2 lgpl21 ]; - maintainers = with maintainers; [ lovek323 raskin ]; - platforms = platforms.unix; + homepage = "https://www.pango.org/"; + license = with licenses; [ + lgpl2 + lgpl21 + ]; + maintainers = with maintainers; [ + lovek323 + raskin + ]; + platforms = platforms.unix; longDescription = '' Pango is a library for laying out and rendering of text, with an diff --git a/pkgs/development/libraries/pc-ble-driver/default.nix b/pkgs/development/libraries/pc-ble-driver/default.nix index 0391b72ada89ac..fd298709181e3e 100644 --- a/pkgs/development/libraries/pc-ble-driver/default.nix +++ b/pkgs/development/libraries/pc-ble-driver/default.nix @@ -1,7 +1,15 @@ -{ lib, stdenv, fetchpatch, fetchFromGitHub -, cmake, git -, asio, catch2, spdlog -, IOKit, udev +{ + lib, + stdenv, + fetchpatch, + fetchFromGitHub, + cmake, + git, + asio, + catch2, + spdlog, + IOKit, + udev, }: stdenv.mkDerivation rec { @@ -21,29 +29,41 @@ stdenv.mkDerivation rec { url = "https://github.com/NordicSemiconductor/pc-ble-driver/commit/76a6b31dba7a13ceae40587494cbfa01a29192f4.patch"; hash = "sha256-bvK1BXjdlhIXV8R4PiCGaq8oSLzgjMmTgAwssm8N2sk="; }) - # Fix build with GCC 11 + # Fix build with GCC 11 (fetchpatch { url = "https://github.com/NordicSemiconductor/pc-ble-driver/commit/37258e65bdbcd0b4369ae448faf650dd181816ec.patch"; hash = "sha256-gOdzIW8YJQC+PE4FJd644I1+I7CMcBY8wpF6g02eI5g="; }) ]; - cmakeFlags = [ - "-DNRF_BLE_DRIVER_VERSION=${version}" - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ - "-DARCH=arm64" - ]; + cmakeFlags = + [ + "-DNRF_BLE_DRIVER_VERSION=${version}" + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + "-DARCH=arm64" + ]; - nativeBuildInputs = [ cmake git ]; - buildInputs = [ asio catch2 spdlog ]; + nativeBuildInputs = [ + cmake + git + ]; + buildInputs = [ + asio + catch2 + spdlog + ]; - propagatedBuildInputs = [ + propagatedBuildInputs = + [ - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - IOKit - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - udev - ]; + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + IOKit + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + udev + ]; meta = with lib; { description = "Desktop library for Bluetooth low energy development"; diff --git a/pkgs/development/libraries/pcl/default.nix b/pkgs/development/libraries/pcl/default.nix index 41639d300ecdc1..7f2b0e9f1c9e0a 100644 --- a/pkgs/development/libraries/pcl/default.nix +++ b/pkgs/development/libraries/pcl/default.nix @@ -1,25 +1,27 @@ -{ lib -, stdenv -, fetchFromGitHub -, wrapQtAppsHook -, cmake -, qhull -, flann -, boost -, vtk -, eigen -, pkg-config -, qtbase -, libusb1 -, libpcap -, libtiff -, libXt -, libpng -, Cocoa -, AGL -, OpenGL -, config -, cudaSupport ? config.cudaSupport, cudaPackages +{ + lib, + stdenv, + fetchFromGitHub, + wrapQtAppsHook, + cmake, + qhull, + flann, + boost, + vtk, + eigen, + pkg-config, + qtbase, + libusb1, + libpcap, + libtiff, + libXt, + libpng, + Cocoa, + AGL, + OpenGL, + config, + cudaSupport ? config.cudaSupport, + cudaPackages, }: stdenv.mkDerivation rec { @@ -43,17 +45,20 @@ stdenv.mkDerivation rec { pkg-config cmake wrapQtAppsHook - ] - ++ lib.optionals cudaSupport [ cudaPackages.cuda_nvcc ]; + ] ++ lib.optionals cudaSupport [ cudaPackages.cuda_nvcc ]; - buildInputs = [ - eigen - libusb1 - libpcap - qtbase - libXt - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa AGL ]; + buildInputs = + [ + eigen + libusb1 + libpcap + qtbase + libXt + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + AGL + ]; propagatedBuildInputs = [ boost @@ -64,9 +69,11 @@ stdenv.mkDerivation rec { vtk ]; - cmakeFlags = lib.optionals stdenv.hostPlatform.isDarwin [ - "-DOPENGL_INCLUDE_DIR=${OpenGL}/Library/Frameworks" - ] ++ lib.optionals cudaSupport [ "-DWITH_CUDA=true" ]; + cmakeFlags = + lib.optionals stdenv.hostPlatform.isDarwin [ + "-DOPENGL_INCLUDE_DIR=${OpenGL}/Library/Frameworks" + ] + ++ lib.optionals cudaSupport [ "-DWITH_CUDA=true" ]; meta = { homepage = "https://pointclouds.org/"; diff --git a/pkgs/development/libraries/pcre/default.nix b/pkgs/development/libraries/pcre/default.nix index 58873ae875570f..7a49561e7a4fa3 100644 --- a/pkgs/development/libraries/pcre/default.nix +++ b/pkgs/development/libraries/pcre/default.nix @@ -1,14 +1,26 @@ -{ lib, stdenv, fetchurl, fetchpatch, updateAutotoolsGnuConfigScriptsHook -, pcre, windows ? null +{ + lib, + stdenv, + fetchurl, + fetchpatch, + updateAutotoolsGnuConfigScriptsHook, + pcre, + windows ? null, # Disable jit on Apple Silicon, https://github.com/zherczeg/sljit/issues/51 -, enableJit ? !(stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) -, variant ? null + enableJit ? !(stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64), + variant ? null, }: -assert lib.elem variant [ null "cpp" "pcre16" "pcre32" ]; +assert lib.elem variant [ + null + "cpp" + "pcre16" + "pcre32" +]; stdenv.mkDerivation rec { - pname = "pcre" + pname = + "pcre" + lib.optionalString (variant == "cpp") "-cpp" + lib.optionalString (variant != "cpp" && variant != null) variant; version = "8.45"; @@ -18,14 +30,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-Ta5v3NK7C7bDe1+Xwzwr6VTadDmFNpzdrDVG4yGL/7g="; }; - outputs = [ "bin" "dev" "out" "doc" "man" ]; + outputs = [ + "bin" + "dev" + "out" + "doc" + "man" + ]; hardeningDisable = lib.optional enableJit "shadowstack"; - configureFlags = [ - "--enable-unicode-properties" - "--disable-cpp" - ] ++ lib.optional enableJit "--enable-jit=auto" + configureFlags = + [ + "--enable-unicode-properties" + "--disable-cpp" + ] + ++ lib.optional enableJit "--enable-jit=auto" ++ lib.optional (variant != null) "--enable-${variant}"; patches = [ @@ -48,15 +68,18 @@ stdenv.mkDerivation rec { patchShebangs RunGrepTest ''; - doCheck = !(with stdenv.hostPlatform; isCygwin || isFreeBSD) && stdenv.hostPlatform == stdenv.buildPlatform; - # XXX: test failure on Cygwin - # we are running out of stack on both freeBSDs on Hydra + doCheck = + !(with stdenv.hostPlatform; isCygwin || isFreeBSD) && stdenv.hostPlatform == stdenv.buildPlatform; + # XXX: test failure on Cygwin + # we are running out of stack on both freeBSDs on Hydra - postFixup = '' - moveToOutput bin/pcre-config "$dev" - '' + lib.optionalString (variant != null) '' - ln -sf -t "$out/lib/" '${pcre.out}'/lib/libpcre{,posix}.{so.*.*.*,*dylib,*a} - ''; + postFixup = + '' + moveToOutput bin/pcre-config "$dev" + '' + + lib.optionalString (variant != null) '' + ln -sf -t "$out/lib/" '${pcre.out}'/lib/libpcre{,posix}.{so.*.*.*,*dylib,*a} + ''; meta = { homepage = "http://www.pcre.org/"; diff --git a/pkgs/development/libraries/pcre2/default.nix b/pkgs/development/libraries/pcre2/default.nix index a61a13590d1657..3667510d9a100b 100644 --- a/pkgs/development/libraries/pcre2/default.nix +++ b/pkgs/development/libraries/pcre2/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, updateAutotoolsGnuConfigScriptsHook -, withJitSealloc ? true +{ + lib, + stdenv, + fetchurl, + updateAutotoolsGnuConfigScriptsHook, + withJitSealloc ? true, }: stdenv.mkDerivation rec { @@ -16,16 +17,24 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook ]; - configureFlags = [ - "--enable-pcre2-16" - "--enable-pcre2-32" - # only enable jit on supported platforms which excludes Apple Silicon, see https://github.com/zherczeg/sljit/issues/51 - "--enable-jit=${if stdenv.hostPlatform.isS390x then "no" else "auto"}" - ] - # fix pcre jit in systemd units that set MemoryDenyWriteExecute=true like gitea - ++ lib.optional withJitSealloc "--enable-jit-sealloc"; + configureFlags = + [ + "--enable-pcre2-16" + "--enable-pcre2-32" + # only enable jit on supported platforms which excludes Apple Silicon, see https://github.com/zherczeg/sljit/issues/51 + "--enable-jit=${if stdenv.hostPlatform.isS390x then "no" else "auto"}" + ] + # fix pcre jit in systemd units that set MemoryDenyWriteExecute=true like gitea + ++ lib.optional withJitSealloc "--enable-jit-sealloc"; - outputs = [ "bin" "dev" "out" "doc" "man" "devdoc" ]; + outputs = [ + "bin" + "dev" + "out" + "doc" + "man" + "devdoc" + ]; postFixup = '' moveToOutput bin/pcre2-config "$dev" diff --git a/pkgs/development/libraries/pdfhummus/default.nix b/pkgs/development/libraries/pdfhummus/default.nix index 96d2887452d6ae..64fef66edde1c9 100644 --- a/pkgs/development/libraries/pdfhummus/default.nix +++ b/pkgs/development/libraries/pdfhummus/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qtbase -, zlib -, freetype -, libjpeg -, libtiff -, libpng +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtbase, + zlib, + freetype, + libjpeg, + libtiff, + libpng, }: stdenv.mkDerivation rec { @@ -53,4 +54,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ rewine ]; }; } - diff --git a/pkgs/development/libraries/phonetisaurus/default.nix b/pkgs/development/libraries/phonetisaurus/default.nix index 9ba00833d623b6..91a2f380115324 100644 --- a/pkgs/development/libraries/phonetisaurus/default.nix +++ b/pkgs/development/libraries/phonetisaurus/default.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, openfst -, pkg-config -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + openfst, + pkg-config, + python3, }: stdenv.mkDerivation rec { @@ -20,7 +22,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ python3 openfst ]; + buildInputs = [ + python3 + openfst + ]; meta = with lib; { description = "Framework for Grapheme-to-phoneme models for speech recognition using the OpenFst framework"; diff --git a/pkgs/development/libraries/phonon/backends/gstreamer.nix b/pkgs/development/libraries/phonon/backends/gstreamer.nix index a94234aec41bfb..9b4579318d976a 100644 --- a/pkgs/development/libraries/phonon/backends/gstreamer.nix +++ b/pkgs/development/libraries/phonon/backends/gstreamer.nix @@ -1,6 +1,17 @@ -{ stdenv, lib, fetchurl, fetchpatch, cmake, gst_all_1, phonon, pkg-config -, extra-cmake-modules, qttools, qtbase, qtx11extras -, debug ? false +{ + stdenv, + lib, + fetchurl, + fetchpatch, + cmake, + gst_all_1, + phonon, + pkg-config, + extra-cmake-modules, + qttools, + qtbase, + qtx11extras, + debug ? false, }: stdenv.mkDerivation rec { @@ -26,17 +37,21 @@ stdenv.mkDerivation rec { dontWrapQtApps = true; - env.NIX_CFLAGS_COMPILE = let - gstPluginPaths = lib.makeSearchPathOutput "lib" "/lib/gstreamer-1.0" - (with gst_all_1; [ - gstreamer - gst-plugins-base - gst-plugins-good - gst-plugins-ugly - gst-plugins-bad - gst-libav - ]); - in toString [ + env.NIX_CFLAGS_COMPILE = + let + gstPluginPaths = lib.makeSearchPathOutput "lib" "/lib/gstreamer-1.0" ( + with gst_all_1; + [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-ugly + gst-plugins-bad + gst-libav + ] + ); + in + toString [ # This flag should be picked up through pkg-config, but it isn't. "-I${gst_all_1.gstreamer.dev}/lib/gstreamer-1.0/include" diff --git a/pkgs/development/libraries/phonon/backends/vlc.nix b/pkgs/development/libraries/phonon/backends/vlc.nix index a50a07dde1a143..b8c8c5faa18560 100644 --- a/pkgs/development/libraries/phonon/backends/vlc.nix +++ b/pkgs/development/libraries/phonon/backends/vlc.nix @@ -1,6 +1,16 @@ -{ stdenv, lib, fetchurl, cmake, phonon, pkg-config, libvlc -, extra-cmake-modules, qttools, qtbase, qtx11extras -, debug ? false +{ + stdenv, + lib, + fetchurl, + cmake, + phonon, + pkg-config, + libvlc, + extra-cmake-modules, + qttools, + qtbase, + qtx11extras, + debug ? false, }: stdenv.mkDerivation rec { @@ -35,6 +45,9 @@ stdenv.mkDerivation rec { # Dev repo is at https://invent.kde.org/libraries/phonon-vlc description = "GStreamer backend for Phonon"; platforms = platforms.linux; - license = with licenses; [ bsd3 lgpl21Plus ]; + license = with licenses; [ + bsd3 + lgpl21Plus + ]; }; } diff --git a/pkgs/development/libraries/phonon/default.nix b/pkgs/development/libraries/phonon/default.nix index 58cd0245d0524d..8a523f78a3956c 100644 --- a/pkgs/development/libraries/phonon/default.nix +++ b/pkgs/development/libraries/phonon/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchurl -, cmake -, libGLU -, libGL -, pkg-config -, libpulseaudio -, extra-cmake-modules -, qtbase -, qttools -, debug ? false +{ + stdenv, + lib, + fetchurl, + cmake, + libGLU, + libGL, + pkg-config, + libpulseaudio, + extra-cmake-modules, + qtbase, + qttools, + debug ? false, }: let @@ -49,13 +50,19 @@ stdenv.mkDerivation rec { extra-cmake-modules ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - env.NIX_CFLAGS_COMPILE = toString ([ - "-fPIC" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-error=enum-constexpr-conversion" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-fPIC" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-error=enum-constexpr-conversion" + ] + ); cmakeBuildType = if debug then "Debug" else "Release"; diff --git a/pkgs/development/libraries/physics/applgrid/default.nix b/pkgs/development/libraries/physics/applgrid/default.nix index b083f278af9d15..7a0ae2cbdf1220 100644 --- a/pkgs/development/libraries/physics/applgrid/default.nix +++ b/pkgs/development/libraries/physics/applgrid/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, gfortran, hoppet, lhapdf, root5, zlib, Cocoa }: +{ + lib, + stdenv, + fetchurl, + gfortran, + hoppet, + lhapdf, + root5, + zlib, + Cocoa, +}: stdenv.mkDerivation rec { pname = "applgrid"; @@ -12,19 +22,26 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ gfortran ]; # For some reason zlib was only needed after bump to gfortran8 - buildInputs = [ hoppet lhapdf root5 zlib ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; + buildInputs = [ + hoppet + lhapdf + root5 + zlib + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; patches = [ ./bad_code.patch ]; - preConfigure = '' - substituteInPlace src/Makefile.in \ - --replace "-L\$(subst /libgfortran.a, ,\$(FRTLIB) )" "-L${gfortran.cc.lib}/lib" - '' + (lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace src/Makefile.in \ - --replace "gfortran -print-file-name=libgfortran.a" "gfortran -print-file-name=libgfortran.dylib" - ''); + preConfigure = + '' + substituteInPlace src/Makefile.in \ + --replace "-L\$(subst /libgfortran.a, ,\$(FRTLIB) )" "-L${gfortran.cc.lib}/lib" + '' + + (lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace src/Makefile.in \ + --replace "gfortran -print-file-name=libgfortran.a" "gfortran -print-file-name=libgfortran.dylib" + ''); enableParallelBuilding = false; # broken @@ -37,9 +54,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "APPLgrid project provides a fast and flexible way to reproduce the results of full NLO calculations with any input parton distribution set in only a few milliseconds rather than the weeks normally required to gain adequate statistics"; - license = licenses.gpl3; - homepage = "http://applgrid.hepforge.org"; - platforms = platforms.unix; + license = licenses.gpl3; + homepage = "http://applgrid.hepforge.org"; + platforms = platforms.unix; maintainers = with maintainers; [ veprbl ]; }; } diff --git a/pkgs/development/libraries/physics/hepmc3/default.nix b/pkgs/development/libraries/physics/hepmc3/default.nix index 5294f18661e31d..6598cd520b9a75 100644 --- a/pkgs/development/libraries/physics/hepmc3/default.nix +++ b/pkgs/development/libraries/physics/hepmc3/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, cmake -, coreutils -, python -, root +{ + lib, + stdenv, + fetchurl, + cmake, + coreutils, + python, + root, }: let @@ -25,26 +26,29 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake - ] - ++ lib.optional withPython python.pkgs.pythonImportsCheckHook; + ] ++ lib.optional withPython python.pkgs.pythonImportsCheckHook; buildInputs = [ root_py - ] - ++ lib.optional withPython python; + ] ++ lib.optional withPython python; # error: invalid version number in 'MACOSX_DEPLOYMENT_TARGET=11.0' - preConfigure = lib.optionalString (stdenv.hostPlatform.isDarwin && lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11") '' - MACOSX_DEPLOYMENT_TARGET=10.16 - ''; + preConfigure = + lib.optionalString + (stdenv.hostPlatform.isDarwin && lib.versionAtLeast stdenv.hostPlatform.darwinMinVersion "11") + '' + MACOSX_DEPLOYMENT_TARGET=10.16 + ''; - cmakeFlags = [ - "-DHEPMC3_CXX_STANDARD=17" - "-DHEPMC3_ENABLE_PYTHON=${if withPython then "ON" else "OFF"}" - ] ++ lib.optionals withPython [ - "-DHEPMC3_PYTHON_VERSIONS=${if python.isPy3k then "3.X" else "2.X"}" - "-DHEPMC3_Python_SITEARCH${pythonVersion}=${placeholder "out"}/${python.sitePackages}" - ]; + cmakeFlags = + [ + "-DHEPMC3_CXX_STANDARD=17" + "-DHEPMC3_ENABLE_PYTHON=${if withPython then "ON" else "OFF"}" + ] + ++ lib.optionals withPython [ + "-DHEPMC3_PYTHON_VERSIONS=${if python.isPy3k then "3.X" else "2.X"}" + "-DHEPMC3_Python_SITEARCH${pythonVersion}=${placeholder "out"}/${python.sitePackages}" + ]; postInstall = '' substituteInPlace "$out"/bin/HepMC3-config \ diff --git a/pkgs/development/libraries/physics/lhapdf/default.nix b/pkgs/development/libraries/physics/lhapdf/default.nix index 26ca234c520c7a..bb2bc4e8a72e84 100644 --- a/pkgs/development/libraries/physics/lhapdf/default.nix +++ b/pkgs/development/libraries/physics/lhapdf/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, python, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + python, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "lhapdf"; @@ -15,8 +21,11 @@ stdenv.mkDerivation rec { substituteInPlace src/GridPDF.cc --replace '#include ' '#include ' ''; - nativeBuildInputs = [ makeWrapper ] - ++ lib.optionals (python != null && lib.versionAtLeast python.version "3.10") [ python.pkgs.cython ]; + nativeBuildInputs = + [ makeWrapper ] + ++ lib.optionals (python != null && lib.versionAtLeast python.version "3.10") [ + python.pkgs.cython + ]; buildInputs = [ python ]; configureFlags = lib.optionals (python == null) [ "--disable-python" ]; @@ -37,9 +46,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "General purpose interpolator, used for evaluating Parton Distribution Functions from discretised data files"; - license = licenses.gpl2; - homepage = "http://lhapdf.hepforge.org"; - platforms = platforms.unix; + license = licenses.gpl2; + homepage = "http://lhapdf.hepforge.org"; + platforms = platforms.unix; maintainers = with maintainers; [ veprbl ]; }; } diff --git a/pkgs/development/libraries/physics/lhapdf/pdf_sets.nix b/pkgs/development/libraries/physics/lhapdf/pdf_sets.nix index 286cf8355b64c3..01bf108689599a 100644 --- a/pkgs/development/libraries/physics/lhapdf/pdf_sets.nix +++ b/pkgs/development/libraries/physics/lhapdf/pdf_sets.nix @@ -1,7 +1,12 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let - mkPdfSet = name: sha256: + mkPdfSet = + name: sha256: stdenv.mkDerivation { inherit name; @@ -20,1350 +25,1350 @@ let setupHook = ./pdfset-hook.sh; }; in - lib.mapAttrs mkPdfSet { - "ABMP15_3_nnlo" = "028q5xixxjxhb8sr7l5v5mwh9mkszm5m59fgnpb69yxvv40a70v0"; - "ABMP15_4_nnlo" = "11zjp4dxmgp69kdkmdwqkpsajvwjrbwylmwgs56mgjb0vgb8wk0i"; - "ABMP15_5_nnlo" = "0z47g5fwh53gg5ws5bbip5q2m5mm7vl09q2w58g6ah9dk25r10ll"; - "ABMP16_3_nlo" = "1ylppc7clyk74mr7qgk0r2cknj2m58y38r3h1dfhjjjmdkw1g1sn"; - "ABMP16_3_nnlo" = "0bwirm3wqyjj6i3asya7kjmmjhqi69l1rnc6gnq7v136ajmv96y0"; - "ABMP16_4_nlo" = "0wx00x98wgvhwsj2fg4kp76n9fhv2s5mbar75dsp6xs4v0d1w1g3"; - "ABMP16_4_nnlo" = "1cw52ijyrhgvyqc28pp278bavy9acvs6qywysgc7qjifygb14mca"; - "ABMP16_5_nlo" = "0s7yz85fjfkmmxj3xdkhz5658n3nx8rr4yjz4hrqbcy00zdcscr2"; - "ABMP16_5_nnlo" = "0iyypvj4645g7nh8w6v88pz37p81bxilgc4p7wlkaa90hiq0wrk0"; - "ABMP16als112_5_nnlo" = "17kg6gvl09p5gm99yb9d8hkl1q51904qflsziv3r5ybxs18ym5g8"; - "ABMP16als113_5_nnlo" = "1gaiyq70zxx7c7c0gkkad3ygbhdwc563al2a6ksy78q8is3bhdy9"; - "ABMP16als114_5_nlo" = "0vnwbz6v2d02d5r34ysd7b4d22h948f3zri2n3yj93k6za9y42gw"; - "ABMP16als114_5_nnlo" = "1gd41d8ay8i8m35qfqsm96jcv8vx6hpdsrdzsj415f4zpw5j29fm"; - "ABMP16als115_5_nlo" = "0pyk43d6v3hzcq487nzj5awd2zhcjbg9ak0pcs1lykhvxwm227hz"; - "ABMP16als115_5_nnlo" = "0i70z8i0qgzr875szdh8sa6x3xcdkvrfsba97a6ha7b6km4p1yjk"; - "ABMP16als116_5_nlo" = "0nyrcb3hbzngj5j3yhpwlnz8a7dx7higngzmp26kmcrr4bmhiq6w"; - "ABMP16als116_5_nnlo" = "11rph6vmmvvsi8msfp2agb7747n7xjgxb7z766i5jkvnggbmz75m"; - "ABMP16als117_5_nlo" = "1pfjdxxdwrwz5n5206jcv61l8ycliwigqgram6hlm8ibl9a828cy"; - "ABMP16als117_5_nnlo" = "1sz9hy2m983aiwyssg60v4kq1zvz4xxvbzrgsdik1qv13bj4wx9w"; - "ABMP16als118_5_nlo" = "0ddaf2a7v3kdynsmls6zxld9zflv9m8qkp8gibc5xd6vqsg64f8x"; - "ABMP16als118_5_nnlo" = "1slvr5ygwwryk63mah45xp5x31qwrf0gkrnh4p9fvl4rdkji6z0z"; - "ABMP16als119_5_nlo" = "1brv76x4z0r0vrxr51gqvfzn4d03srhvab6dmxhhj3sy23qnbxg5"; - "ABMP16als119_5_nnlo" = "1iqs1bi8r22awflf698cj39q8s2w86fwvdfgqb6sr8csm36ih6qp"; - "ABMP16als120_5_nlo" = "133vy2zhvh49fa9xkp889mxy6xbriv10q8r4lx74wb9d1kqwfx81"; - "ABMP16als120_5_nnlo" = "051bqfyh2017vnvlisvkm1ik6x7n829p8205f5algsw7wi1s7b9v"; - "ABMP16als121_5_nlo" = "1l41qgba24rslg6ascsn1i0y0y0d7yh6hszhclxqyn07gzwq7p78"; - "ABMP16als122_5_nlo" = "1ivy4m9fah8i0ipfxfq8caxa7pz8y86wgrqydg9wal9qin8n8xcd"; - "ABMP16als123_5_nlo" = "0gcf7dqr1gzjfa6iy0qzivyibw72qpagfda0a5aksd0h6aap5mxc"; - "ABMP16free_3_nlo" = "1hxlbmc2kzd8yai7ipyc95khdsawdcnzxzr0vkk3h42fxczx9y6q"; - "ABMP16free_4_nlo" = "1ckwbyj18bgvpv16r6lx3866ca4frq6rxmzvz14ak6h8mpwvcnmq"; - "ABMP16free_5_nlo" = "0sbkrn3g4048bn0y5bm6dqpn1za3761n6x40k7i4pdi0b1g7zlc0"; - "ATLAS-epWZ12-EIG" = "010ddmyfrmscgd1xdjsxsjc773jlvbh3s6mjbwk9zd298i3bf4kx"; - "ATLAS-epWZ12-VAR" = "1r9ip8549dzhs02skm8v00g6nsh7q1rwd3syz3bd6cl4sqhs0k37"; - "ATLAS-epWZ16-EIG" = "0b1zzp8p0kh4xjn76nm6waqlvdpqvnwyqsnnqdp2n7b9r9ssryyf"; - "ATLAS-epWZ16-THEO" = "0b0wqa203b2x159y54xhf9yh34lkchp48vp9693k51g9aznx8gjm"; - "ATLAS-epWZ16-VAR" = "1zkhlv8yxfla46gj57119w9prsd3zyy5vg275bayfwa6b71gmc0b"; - "ATLAS-epWZtop18-EIG" = "069rysd9mf3cshx7xkcv7735ydh2g6szvljbfkcqwckaqjg2x3v5"; - "ATLAS-epWZtop18-VAR" = "0hpyp52dwl8fnw47pyw8g7fsz97wr6sk4yli6sx0zbj8yy2j28yj"; - "ATLASepWZVjet20-EIG" = "0lvd3zkmisx95rbjx7r9wkk0s0mxvaybp3pk66sxrxf1bj1l9r52"; - "ATLASepWZVjet20-MOD" = "1iyb50isdsy3a5wnlm0185z9bfs6nxwlcl1aqlh4h3j1dbmz4ba9"; - "ATLASepWZVjet20-PAR" = "1kfqii7sbcs8zdsyd9kiy3r233nawc9yfc23fb6ql0xcwfzpyb1d"; - "CJ12max" = "1vk2zkaiqbl6fixaxy7mrggmmxv7lvnw736lxm5sh25dapg6s8ag"; - "CJ12mid" = "0s2558ihypn0l9qqx25qwnawbc7fkbi2wwwhbyb108rjk2klaf8v"; - "CJ12min" = "1kdla638m3axr65ndid9irmqhby4gl084r297xw3jxxlrb0b7hj9"; - "CJ15lo" = "0hww26wbcb3i61z41s518gj41mn5gcikb08pdzyb5vyrl63b39bf"; - "CJ15nlo" = "0acmyr5zpb7yzs2pikhgf8nx8l7csmai4sv361l7x3miqir56ss4"; - "CSKK_nnlo_EIG" = "0fdc2a7xax7xl5n5f3ff5dcf7zbpk43z4kfy3ffij2qykrwfx7bp"; - "CSKK_nnlo_THEO" = "0srs535f9xydqfzyy208304yxah1rg1r5ilx8hk9nvgaiy7kwnvq"; - "CSKK_nnlo_VAR" = "1iyiam3kbjrckh0sw290hwi04h5cqif081afgd16f0a44wbcjsi1"; - "CT09MC1" = "18ap08vh1f4ivibq5z57wv7lwvw1pzwl865xznzzcr0jy4f59103"; - "CT09MC2" = "04yxg4bl0dcgh6hb9g223wm084w0q1y2lbd4z7w8vmvvvn579ij8"; - "CT09MCS" = "01vjpdgy79gvk3w4blwjgfqpf50mjdi5kmfcgnlnwxp5q0804pgf"; - "CT10" = "17glhnqj4yknqy70zs7m097n1qq9fqljj3mna6qxchmgql04dvxw"; - "CT10as" = "1709bb3ky4mpn4cgx9lda8swmvb2pl70ly1gzk4ahgsflkb8iaj3"; - "CT10f3" = "0ijrx0wm03r0yg6f0n4vwp1c3kypdjpmmnv12gk79y193bfk362l"; - "CT10f4" = "14icbh8lg9290wfalr1bsx0zff1df19x0qrjqh8n0y9ckqmkbh6l"; - "CT10nlo" = "14ib003sxpxc8awywjckbw124aqhmi70wg4hlwc2nvdh46sqk11b"; - "CT10nlo_as_0112" = "0n2abywijgjys56kz5qm30arh3v5k685l0gayl4mdablbw0ccaca"; - "CT10nlo_as_0113" = "123kbzzfjlparffgmqpimygzjcn0wi1vnyrkjfjn2kwcdjazz8dp"; - "CT10nlo_as_0114" = "17lgcbf7914dfb89d4v8fal69zq7gmadvha8gpz0wfw4p0pq765b"; - "CT10nlo_as_0115" = "0rgpc3mcsd18yg4j41k9hhvbjbi3d1zrd9fq1314m4qvviq6d9j7"; - "CT10nlo_as_0116" = "15xyhmipv9xbiz3jaqdj59nyczn35nq14183xz4py68l2v20smqi"; - "CT10nlo_as_0117" = "1qf9azafrwqpyp5flc912g2frfpi899vb032yrrgqj2l1flg474x"; - "CT10nlo_as_0118" = "1jra85s6df6vvmljkf8gg2jkj3r6b1yl6aidzlm3j59di0fk9xp8"; - "CT10nlo_as_0119" = "0y7k0w592j777jpbrh8v2zh1l6n38xbxjvyiv5x4pvwi6zrp9ppf"; - "CT10nlo_as_0120" = "0mh1hdmic5c3krlb1xypy0n6r86r7da0ay9183xwb68d1kh4j630"; - "CT10nlo_as_0121" = "1gwvgj3bwv8fz8mbmgnfsy0bvsm4h9d898mf1kcaaivh56sfial8"; - "CT10nlo_as_0122" = "1jkkqcmjynd30paxc9z9gpmxkfhs6ad3x5sms5980jx291rc8hgd"; - "CT10nlo_as_0123" = "0gppcp49275pg3yv37mzkx7az6298wwy7gqla3gzxfzlas0ybg0b"; - "CT10nlo_as_0124" = "1irl19q4wyw36dwhln1m4y7y40by5xgdjqpgj7sqaix8jvijc9bz"; - "CT10nlo_as_0125" = "17c6n2prdsry2phqmaykrf1yc02mvhacb87r7yl0nhkhx80kysk2"; - "CT10nlo_as_0126" = "183p4fd85zs2c1j0zwfsa08wq6v780xvwbg44bpm52m4ih1dgqy3"; - "CT10nlo_as_0127" = "1vcpadkf90x9qiqaplc25hld7qljk5d3lzs1dssqi5fh1kci8qd1"; - "CT10nlo_nf3" = "1dfzas3z075riwx26bkmvjck42pjgbm32d1flg5rccsxjn4pmmm0"; - "CT10nlo_nf4" = "0npv1h5gi2vhgxzcbcsl740z2p7j9p8pg3jwfb0yz88wlbj5bkah"; - "CT10nnlo" = "1la35l1b3hxdkihh9vkibfh68rghcfgq48q27x2b05dfhcvcz9lz"; - "CT10nnlo_as_0110" = "0j1f6lbjhwcpgfb8kwzsij0hfmzb3dggi6zwwv9f2w39ax2rfb8i"; - "CT10nnlo_as_0111" = "1519hvpi1zrjk8p31ksna39n9l8v02ggj5q775q243p9qyfayxlf"; - "CT10nnlo_as_0112" = "0asnbr0va5p1j81kmv8ar267aciap638kcb48cs5ghz9fvhxp197"; - "CT10nnlo_as_0113" = "1j5cfbv1d5q2hscyrvig6xkk7gfv4x5cxn1142qmd8pdm9ky2fdb"; - "CT10nnlo_as_0114" = "03rkvf4ljv7bnzp0fyyrypbbx4rxd1y6id3dfvg4w22s65kp0csm"; - "CT10nnlo_as_0115" = "1d8rkwvnymx4pi0v1s2vbc880mggdmfnzjppd7fghjqj4lkkanyi"; - "CT10nnlo_as_0116" = "039i2bq4xr6hlvg0syzmyfv4lm7lrwr59myrhd609dybiky4aqd8"; - "CT10nnlo_as_0117" = "0q3a5lbpxh24zv7ypbc680kqrkwy5m7xbgx5v44b6cdzlib6lvsn"; - "CT10nnlo_as_0118" = "0b11mpgrkqn2n37asg8qg3qmhdhbr8lmj8qjixxpca0h1j7m71a5"; - "CT10nnlo_as_0119" = "1j411yqrlbhqmby8mplgghmb4zxclf1h3pdsffx9iv8sq1q6dy2i"; - "CT10nnlo_as_0120" = "1djf9qfqrywpsyv0w6igidg9a4ca739dvqgc7qz7qg2bpclbaly9"; - "CT10nnlo_as_0121" = "0nlm5iwcvb02fd7kan4yp60qbc0fgir4dii3xg03n42xzqixy2qm"; - "CT10nnlo_as_0122" = "1kwq04i5ln8wv32vf4akjnzid3jdq67zccfg7xriqrwd9367x5kv"; - "CT10nnlo_as_0123" = "0w4fmsmyci09v0cxnmhdbqxv3xq3wa9ma7m4g39sg2gdsxqz1rgd"; - "CT10nnlo_as_0124" = "0yzrj1pdigssi39z21k9jxbiahhc1785rjxhq7xl8zx38paspbg7"; - "CT10nnlo_as_0125" = "0qvdvj3wkbkw0b0zv79ybds2pk5z9kbriwsm5ffpnycrfkzrm2kd"; - "CT10nnlo_as_0126" = "1cf8bqi1g4c3xqg5k9m4fa8v8bcnwkzblmfn7zc396pgbzhhz610"; - "CT10nnlo_as_0127" = "0zknrx60h8jdf2pfg2zq6xk73hn86gcv69ml78ik5ms0y5gp21av"; - "CT10nnlo_as_0128" = "09yn8l3nv29frj3xn9pafiz2iamccp8ii8j7hmp63iaji6c7m5fg"; - "CT10nnlo_as_0129" = "1ypq63r5myz2phn4y5sbb5dbxvycwis8jixjl0n95xmqlx5zhixi"; - "CT10nnlo_as_0130" = "0ilr6ijbbh1zki66ma006h1qhdq7wmzm0ipki78bk01jnr5yl5sg"; - "CT10w" = "1qkwz1drbkxcb4gskkfn0r7fsa6g9hjlc8716m633x35kha1v52j"; - "CT10was" = "00s4n3nkngwyhh82l132v88c4jgkg03ff4x7m7nna21lvkv4wkb3"; - "CT10wf3" = "1r43pzb1291bjcmahgfh0f86pvb3nhdpxw7gikqmypdmck0n2mqf"; - "CT10wf4" = "18bf9k0jp95y9yz0m896sdzy9q1fyp0r4f5hrv4jq4d1z84zdis5"; - "CT10wnlo" = "17wsw6p0h618q68swn9mjsahfyqikjgsiykiby7y27ryairv709n"; - "CT10wnlo_as_0112" = "0p7mh56zyqh9i72llbmjchwm50ifa358snd8i1nqr3r6lr5265hb"; - "CT10wnlo_as_0113" = "0nl4lk3cscsn6p50b3qqaabqfnkn5xgjmcxvfrr1n4njh411kmln"; - "CT10wnlo_as_0114" = "1vck1i34dspbzskzpbqxbq11gp79drlrik52waklvsl5110xawnv"; - "CT10wnlo_as_0115" = "070cl0prprqqkkzwxnvyw7r4ivvs8slb98v5yza0gvpwck0blnzn"; - "CT10wnlo_as_0116" = "0v50pyjqpcrarbx886la0hr6vwvnavsldm9amcdp1vlck5w8mmg9"; - "CT10wnlo_as_0117" = "108sb5h79mpgkvdzqlx830dykba5kw9zqgxa60i7bcyjnv0277si"; - "CT10wnlo_as_0118" = "0zf335291hwfmdbhgl5v2y5pbc9slm7dmjfkijdv0jm33drpkcg2"; - "CT10wnlo_as_0119" = "0kvwc0k5y51p4qvlb6hhxvn9c2n8x0xn0xyp5zkz75ad3vaz9yvn"; - "CT10wnlo_as_0120" = "0yvbcni3xf718xild7s9g6cxw7dwa38f4iqdm5z7dd9ahxyw9rxv"; - "CT10wnlo_as_0121" = "1z0mlrbdn8a9n6h0jpha3p1lqz4iamrwa80svqn9y4qii9h5pjkn"; - "CT10wnlo_as_0122" = "1dh5czjvyjnwlzc14vz91693pr3nyls5g926g347rdrkqkjq8dcz"; - "CT10wnlo_as_0123" = "0nf7qpgb83ahm5dkzr10xafhcx4lvb3zlxnz70jczl1jd4v2cld9"; - "CT10wnlo_as_0124" = "14h07z06csxb6v6ai1w5ba0kygnsrzdwxr2nx1kcn93axcsqqbhv"; - "CT10wnlo_as_0125" = "0g0w6mwy5y4l36cn4z8gfmigzharyn5xqk5ricasracrnf7ydix2"; - "CT10wnlo_as_0126" = "0dbkkyimpll9r3979vbk4xqi5cfhzr6b28x6j73fbxxxi1xfavl5"; - "CT10wnlo_as_0127" = "1svmgs55kg74rifjyns38lggv1c18mzmpmvsv116rrllklb19pfp"; - "CT10wnlo_nf3" = "1m13if0d9xijq695x41snpwwrsgs5a0jvil6j2ww8cspc33d7vr3"; - "CT10wnlo_nf4" = "1b9lz23rn2w7fqwxxgf6fcg620ac58dnb1ssj3ml3vfn7z88yx43"; - "CT14MC1nlo" = "0z82q7xr9agq8iyw7w2rcclh27mry5snn5jswn3cxpgnalls50rx"; - "CT14MC1nnlo" = "0fj6hjdv82fp4iv7iyk9gna7sksnpkgqx0bsrl2wjbigm4ys031g"; - "CT14MC2nlo" = "1x6a6js1jpvkykagz6w3klh6hb2wf56r3kh65i6qlnzak4m7b8sq"; - "CT14MC2nnlo" = "0hbdz8agjm16mm51hclpl2nsa5ji88zpqdsn682xgihq64kahsnb"; - "CT14llo" = "0sz2ni8xcjjg8034qjrhb77ak1akzlf5fwq00qs9c196lk5b2x7s"; - "CT14llo_NF3" = "07zzs3jprh0haqx5bcsii213m99m2nh9vki76d9cbhicyzx23pc1"; - "CT14llo_NF4" = "0bxkw5qms6dpab0zf1hhd8dllrjip2izbv23aqpg72d5rqxb6ny4"; - "CT14llo_NF6" = "060fx2xrc90id3nb7rlmrvkxlyafx3g7nhdb5jmbr3hxwrzrq674"; - "CT14lo" = "0y36qkjqd75zf1w1hs1q51qxgin7sm3bhmcbwczwrb17c3vb4m2m"; - "CT14lo_NF3" = "06iad9lrpxsy0d365vrjv6gjlgggakylrmj1px17y6s796jq6c6g"; - "CT14lo_NF4" = "18c03j26mbapjidq01s4yrfdh0i7j75gbswdhwcllwdvcg3gnki1"; - "CT14lo_NF6" = "09ncggqnqcdpzakm16dzxd6ikay9gd5k8si80k52hrr9m2gf36ci"; - "CT14nlo" = "137i0n7g9rgfsf5rx65d50njwsqawprazp5an513kmz1cwq0cqmd"; - "CT14nlo_NF3" = "0pmamazh9i8pahalasr7mwx67ixbgrbsh8004grg0cimr2y4iwjj"; - "CT14nlo_NF4" = "1k7sy8lpzkwy0dc4ig9i9134k854fk0r0lann6pj3jsxs0l6h5km"; - "CT14nlo_NF6" = "1gfwr0sjbq41gx3057hqy8v6ysivjf1xrh6fp3qqn6m13gy2kbas"; - "CT14nlo_as_0111" = "0kgg9r635grdwp152ylzklawzy8nf2ywlp75bjc1yyagg765k6jv"; - "CT14nlo_as_0112" = "0j0bxx0gjdnj41gjasgd153gd811wyhsza56fvzrpka820bkk6rg"; - "CT14nlo_as_0113" = "06if5wk1asazvff57ah944mnzkh5460yqkkwcs8zhnwx2kbq9v85"; - "CT14nlo_as_0114" = "1szy7jwjvdvqqpjvcra1f0wn8qgrja6wx4kwcq9vf60pns7mzk7v"; - "CT14nlo_as_0115" = "1kkahzmrbdr7s06v093arnss0xpxv7byqqx2f5aqh4fzimwp9n7v"; - "CT14nlo_as_0116" = "0qpkmmpq1b33grf85jzkanwpa02j1cam39pkxchql95hv2jlgw4l"; - "CT14nlo_as_0117" = "0381620r6h9s2qby52jvys4z8m6jfafa5qnia2fq3q1pc0xp1q2p"; - "CT14nlo_as_0118" = "13hgxmjx6bv7njb6jdlypy1z61nqf5m5bavxsbrmwwfxlsl4jdzn"; - "CT14nlo_as_0119" = "06pjl10js0xq7p14ifjn7xhndxyb39sxyc9ksd6wx55i6zyqf08l"; - "CT14nlo_as_0120" = "1wyygxxjlcsh1qg6npk5szfbf59k4j80hnxnxhah9x9wrg5kg9j2"; - "CT14nlo_as_0121" = "064afbxxqx4rsa3l73rki8wxa08a1rb53qyf3nwwjb4zb426jfgg"; - "CT14nlo_as_0122" = "172xvndzcm8s4hzjgrq3szg6j7z4s2f4pgr07vr178zvn9986ham"; - "CT14nlo_as_0123" = "0q2dansvna4p04ilb1sajz3s5mi89jgd8badqh6r72g26s96dman"; - "CT14nnlo" = "1y3gd5wzpwv024xcrn70bz6h62n96mgqqwyl5r7q6czw0is52dzq"; - "CT14nnloIC" = "1wnpwy0mz0c5y29wi497jcn5k47bndd0h65d6a18qcfk0l15rfzx"; - "CT14nnlo_NF3" = "0ijns9bjkw8zcinba7rflc7ic03mn5701lqfrxqjyq4q6kh8fia7"; - "CT14nnlo_NF4" = "0fhyzaxnm17pi7wfh5hwaic9q4y0hb05ripd6r648wnnhhi353xy"; - "CT14nnlo_NF6" = "1dvabji3vrqk8ngln72xqiahm8fai3klgv5yz64b3bfxcr04wmg9"; - "CT14nnlo_as_0111" = "1hl88j40czr73h9fbz0zbliawlqwng7ikrmq01hsfns190axm8w9"; - "CT14nnlo_as_0112" = "1w9344v9ihr0w8vrfhhxn81gcnr0qm6ihwwijvcdds09jpdlp6vr"; - "CT14nnlo_as_0113" = "11symfb1ljislbksrars1k766fa2n1inbarzbw3kp01vxpw8gxf5"; - "CT14nnlo_as_0114" = "1s1zz0ibr72jvx9c7w3kcryiywnmg264gprn020yxl9sqfzm0kzz"; - "CT14nnlo_as_0115" = "19c4c4s7djav1zai2nlxbvy8fzg8hqlynri1y4hyhc8hhl00lwb4"; - "CT14nnlo_as_0116" = "1shjwky7jjwcci0frra2lfc0wycvza7na89c4bsqiksnk413v2z3"; - "CT14nnlo_as_0117" = "1mp5xxv810khs59zg4kfsdj5qp6ny0878fbz7jf101mpyhdawf0m"; - "CT14nnlo_as_0118" = "1mvyv13agnmc2c47i9yl8ki5d0qac3l6ipn3nf5rwxjgah495rv6"; - "CT14nnlo_as_0119" = "02b14lrx3zpbl5s4nj1rvh30i9xdji37yvvg2xwjiw3i56vl8b2l"; - "CT14nnlo_as_0120" = "0wf29wz9k2v39pbzh91bxwifbs4cn0gsnjdzm24cpgq7bnhyszn3"; - "CT14nnlo_as_0121" = "1w12xmxqclrrwvfb2g3zvivkq858n0lpp0bzfibvh4wamdyyx3an"; - "CT14nnlo_as_0122" = "1hgghn4ad7fj3ya17qnka3xcwz7sp4fl0vpcbqkrs9mbbz570fjc"; - "CT14nnlo_as_0123" = "0m66gwhw2n668sg4srq683qbavwabrk4f4vfcsbppzbcgm7i4yz7"; - "CT14qed_inc_neutron" = "0ph835nfx98i74nncmspj7qb5798yciq76hqvc505n5zd0hwp87x"; - "CT14qed_inc_proton" = "0gv0rlr6l62gidqp02ifn75d1ribvbihgpaqc92fww73zwilr7l0"; - "CT14qed_neutron" = "0ck1vmqk17i7rq42hra79cz2rm8ngxv4da6dvz62l6m2nrga3l2k"; - "CT14qed_proton" = "1gijxkq5gpsljijblzd13kgr7xjjvnjv18v02jivylf73igsakd7"; - "CT18ANLO" = "16lbhgkbiym3njiffxdcm3hf7kkm33hyj2w1hwgb3mvxx2sja31c"; - "CT18ANLO_as_0110" = "1lkxicxmphi4mdc23vig4a5l4gp0n53jblzsl7bvrixbkhd5arv8"; - "CT18ANLO_as_0111" = "1jk8siawnpnclgjc0jhx89ipym0jp94mrklwkn0awh0hgqxd26ra"; - "CT18ANLO_as_0112" = "0rpfx10b5hjwzmlqzkk1zkk38ysn5jfgipk71zl5da6qk1ih5v2s"; - "CT18ANLO_as_0113" = "0chhqgjddrb731y6haa94yypki6pzpjq5rvja61gfbghbvnc02fs"; - "CT18ANLO_as_0114" = "0nvl1a588jvmh7a7przrzpvf9prrpvv610jmsnfrcp4i98ipdn1p"; - "CT18ANLO_as_0115" = "1f757zlavyjxjwyda8rnkzg9kagmciywvvvdcsbks9ij3m4fcw5z"; - "CT18ANLO_as_0116" = "13bdsnwkqzjq63m02vmb7z03rx6chcyy3br4m52gja0qz03rxhyj"; - "CT18ANLO_as_0117" = "0w5pmqry5rd5jsfwiv43cy5z3hlk7gzllnk0vn1qgsjrgd284hj9"; - "CT18ANLO_as_0118" = "1g137nw812zqdkr97hdwvfi4c4bxfazy1wyk30gwgrhqs6xdsmyp"; - "CT18ANLO_as_0119" = "06pjg9nsq6pvda1yg6lg2qi15i3h2radampgk23rbz9g6zn5hw39"; - "CT18ANLO_as_0120" = "0jh6f5jj81sppv5fhm8ccgzwpacfr1nql3r5466z0bl201fc9x6x"; - "CT18ANLO_as_0121" = "0jh4x2y4rcp3l825dl3a89apmb0f94jrk0pl93lv8xg34f8jrb2i"; - "CT18ANLO_as_0122" = "0ma8r5vgdw9hj6cafkj8fbpq8i18cbild4aw4q9lrsszwwcrlv9i"; - "CT18ANLO_as_0123" = "1mv75gga1gdmnwkaxc0c89jxgapc38376xv5yxfqy2dn03pad9im"; - "CT18ANLO_as_0124" = "0913a748xm6lbdci8vicz08h323hbkc4z1bjq1wq8qfrl1cx02ic"; - "CT18ANNLO" = "1kbsbvvkkchhwwjdrj4d91lbykid4dcy4ghanpdd9x0nfm5b4sgk"; - "CT18ANNLO_as_0110" = "1inx20r83pfmwxfhyy3hhj2csp016d9cnald1rf8vl9riqxvx0j4"; - "CT18ANNLO_as_0111" = "0zzi0b27xp4xykbwd2y7l2ka1k4kfvhaq7y2w82fky2b842ixsmg"; - "CT18ANNLO_as_0112" = "0y031rslsmwxs76rz184mrjb07pdcxrf07yl5yab1y24vymqj4dy"; - "CT18ANNLO_as_0113" = "1pgrcb6sbahl2jf3v08bki28w9x0ag5n3zj1fi0jc69fxwgkczzq"; - "CT18ANNLO_as_0114" = "0ifzf428gxlmhc8wvpj3qaqr0cl6pripiabmnb5av43d5avwhagr"; - "CT18ANNLO_as_0115" = "1bxf5rs33kfl3q570wm49ad0drlanzq8wkrbd85qjlvyhy52j8vs"; - "CT18ANNLO_as_0116" = "0l43qn45wfj2lljpp8kri1n2p99lxj3gbbqh2p2s7v0my5ds5p06"; - "CT18ANNLO_as_0117" = "0nfh9y2w8lvlqbghxx4i7j7gxq5bm67h3vz1wajg86zndarkq6mz"; - "CT18ANNLO_as_0118" = "0m8s96rgnnl5xk7g3l2pf5qx7dwb8kgn18b9nyr8cyqxn90mh3vr"; - "CT18ANNLO_as_0119" = "1lpkcrcfmn0kc9g21ca90j1shcf3ii89yrr17rgwynmylwvizs2y"; - "CT18ANNLO_as_0120" = "0lmn2p57k7yvr5mpzykljhkpnb1c71f4ya2s4zbp2x84fqfg5wbk"; - "CT18ANNLO_as_0121" = "0arbvp0sc67fsf7slhlv96iwq89yjqqkv84pf76fqdvrrjsmyn61"; - "CT18ANNLO_as_0122" = "1nbkgb0wmjh2bfx944sqb810sn4bb0ppxgv2aw2y93jbfyx7x4ry"; - "CT18ANNLO_as_0123" = "1rlxn70mc299v596y0dwp9a1pdy1yz0r8367cjw5l97y46yxhjrh"; - "CT18ANNLO_as_0124" = "0sfkvhyxp9sqf75wj91h9h59vcs2y2n4qchsg0marjy849xxh6qb"; - "CT18NLO" = "04y2p6vz484l3yv6381pfavqs3xh78h3jn6bg7ncp5vywwqp44n9"; - "CT18NLO_as_0110" = "0nrydk44sp7hgabn6xk6r2hnkir7mgddcsbbnqmpwmq3x0xz27pn"; - "CT18NLO_as_0111" = "17xwzcj4n1bmfwz02n2g8afzxc4lp5diij00f2w50pqh2w7vj6g9"; - "CT18NLO_as_0112" = "0a6lsmpz3c1z7dm593nb3r9q7dgpskkls2i6wpdlrrg6s6cr8rmq"; - "CT18NLO_as_0113" = "1kwz9yp0vzyiwy9avxjwibdc6jla32vddf23pvfiv0qjcwfnp6ii"; - "CT18NLO_as_0114" = "161q98jr59vn1qldhd83qxx0qjq1rahgamwfqd3hw6dn6wy39970"; - "CT18NLO_as_0115" = "1dp0683zfn7mg0bj1l5m7i9kdbyxjl0ahhwppvgi5gs5kbmhbs9n"; - "CT18NLO_as_0116" = "0hpi5s175cpz251nav0v34l6qsfqj6181mhhp80kghyyvl7l22sw"; - "CT18NLO_as_0117" = "1v32wxdsvms23sghcszw6csd08kw0xppjzwjnbdsc8k6w67r546m"; - "CT18NLO_as_0118" = "1vd7vc7f49in1i5398p12b9vklxbsif89wv2q93k6m91kb38rm45"; - "CT18NLO_as_0119" = "1h0dlys71cngsxl9dj9l5amikxrvzzb7bins2a6wn6s7zgfyvlck"; - "CT18NLO_as_0120" = "126jfwml027mnpbr6ad7s8d94j3n1sv6fbdy5r5vcb64nyncjach"; - "CT18NLO_as_0121" = "1khffdgqdfl1g4cxp4fnyb900722s6pwzys7cdxmwhzi9f0rwgw8"; - "CT18NLO_as_0122" = "1w7q35igi7fnkrwnr1dnfq646qicz4549c6ddqbkyil10arvq7fk"; - "CT18NLO_as_0123" = "1bl6rf69gjnblvfdh5p8flax9qb65vk25hcfjw2r7qwdz3dxs6sr"; - "CT18NLO_as_0124" = "18mhpn4l3qqg9v79z2vz4jc8w3za726fndfl6sbc9mf94jy72chm"; - "CT18NNLO" = "1shkah5ma0hp101aklkz2p8n9y4i4sv6zwa5ifzyj3bgz1020l5f"; - "CT18NNLO_as_0110" = "0v7nsjcm1q7hgj726zlvfydl3arqkwyddd20z3g0nwdqcimv3qs9"; - "CT18NNLO_as_0111" = "118444ygv03ryhbb28njbsayvv0rdlcb9djja6p62kk6rnbwi1wz"; - "CT18NNLO_as_0112" = "0djxkvwk628sxgf62bff40m2m6vgzs08jss61f90rscvj6gxid5b"; - "CT18NNLO_as_0113" = "1xg7qs33h8zgj4007r8g4drhm95551slhwv62dzyv9pwy5vrvgdn"; - "CT18NNLO_as_0114" = "0i1g7kwfs39ps9ml0ckkcq7x4g1n764q1r06ilq7bci3m073cffn"; - "CT18NNLO_as_0115" = "16q0hc3p0325bq9zgskkpf9qfyhmz9q0rk3b0jrzpc0d4vk7b5r5"; - "CT18NNLO_as_0116" = "1mhnx8szpp4sfy592f8vzvjlzr9y46qndv3c42hf0jsygx5pc5cr"; - "CT18NNLO_as_0117" = "1bmcnjfzwf4bl70qyx6csix3ps46pd32yb2h33y2f144vp8bmkpg"; - "CT18NNLO_as_0118" = "1r1dmj42qrqprhq06i0h4kpjc1riql963n32icl0mfwjq9wpfa0g"; - "CT18NNLO_as_0119" = "1rxyd21h407zmjn3nnr4cqvinw2nwcdhid6cbr0wif8p2b3gasic"; - "CT18NNLO_as_0120" = "1llhnfijc7v6v4dkbsfgj2c3m0y4q42mvaynz06v2j3aqv3wzhza"; - "CT18NNLO_as_0121" = "19dqq2jz5daq59gv2zdvygyvwi9sx6i3ih82yl82yy82gbw2568h"; - "CT18NNLO_as_0122" = "0p8w4ypaxrpsyz3dn7f0964wgvd30iy4r1haa88hqwx74qrkb4pc"; - "CT18NNLO_as_0123" = "1c1sw5md5xp8l6b3qxbnf994kz2rd60p4bl3s3l2af7f77w57wfv"; - "CT18NNLO_as_0124" = "0ldf7dnzdlwqh0gmb6an0b8cwcjpkiaih49aa77j2irw2yja5p41"; - "CT18XNLO" = "1k0cli4j0z5hj24pk9f78flhlvsdfya51hgh90jv4myniapk616l"; - "CT18XNLO_as_0110" = "07k9ga6n2gf9qz0flvrd4if0mssddrq1bbk0rpxsy8wfp41cjsl8"; - "CT18XNLO_as_0111" = "1ysz50r2nc57c7srgqw1dcvyfr9h578dkz24sbimxq54akp9jkxy"; - "CT18XNLO_as_0112" = "11wvnvsc6a5c2ygq39avai4xk2mrnfnvi4fqzmkjdcm0kby0swpb"; - "CT18XNLO_as_0113" = "0cyv8y2m3514np7f3fwpf3g1mzy2cz905sc5lrjqff5djwjc23yg"; - "CT18XNLO_as_0114" = "16vj7hhg3psmyr4vqvy8mz4bg7rp6jc6b64n2dfpq5jvb15w2fbv"; - "CT18XNLO_as_0115" = "0ylw7d9g041fgrjfvq0i0ycpxwbm3s4jdgm5mkjk6yj0s4mrrqcy"; - "CT18XNLO_as_0116" = "0mcfgih55zja7k0cdi1yd7gx1gjr6cpzz28gz4fxyxi2l4paxh2k"; - "CT18XNLO_as_0117" = "0klzf5bchabcjc0c8h6f09g37jy6vwrpq7q8iwrfcmar2slx26r2"; - "CT18XNLO_as_0118" = "0hd1bhlkmnchcv0xbrqjc3paa7fqp249sxi9hg71x3qbh03ab036"; - "CT18XNLO_as_0119" = "1xlxw18hcsv7bij4dvnj9dfm8sai5xm9jggb8g7flmvkmcskgzmg"; - "CT18XNLO_as_0120" = "1ixdg56qgm5701al85zkp81xx3h9hsipqka8l3sh0ghp563qxk32"; - "CT18XNLO_as_0121" = "1msa7pp1a77wmvxa9mhr0sgjj4yv1msb0igqj53ahzgisyl3lnml"; - "CT18XNLO_as_0122" = "1kin5bf9bcxadqibqfzb03bxdrj759mlgpbpjvvpxg4ishj0b7yv"; - "CT18XNLO_as_0123" = "1mir3cpvbc30l3m84j1ql1d8phrx7nf0qd5xbq9jfl4gx1kjfw8c"; - "CT18XNLO_as_0124" = "0ims3sl32rria896ckm9fg5dsmbf6ivcfl3drnqpl328ynrkbzlr"; - "CT18XNNLO" = "0j7bwzkhax4cm3wnbhqdv48j4wha9zdd7v77ihlgcvcmk79rx1fa"; - "CT18XNNLO_as_0110" = "1cxlps6kvm08lkgvrqjd8080ykc1dvd56986iwwzd0s6whlpfsi0"; - "CT18XNNLO_as_0111" = "0bbp4qz3n9pwcfn6m623q2qqmx2wcgpy6759wzwpjnifym832j95"; - "CT18XNNLO_as_0112" = "16p36jf8c8pliaxd6s30cmmmxg9slnmb2527vnwkka0kp9qw3ffq"; - "CT18XNNLO_as_0113" = "15d4qx8x56kcg6p8980bslhfilkld8yf1mwpdzyf8v8ns50wrbw5"; - "CT18XNNLO_as_0114" = "1zsfys0xkgf8zlbzzjmh1wvzxwjqi4rvgik26s5y4ibr68gshvaj"; - "CT18XNNLO_as_0115" = "1x00d2q2lnl5w0l052v9cvkywav26b4r072dpn1jiak6n52yqqaw"; - "CT18XNNLO_as_0116" = "1gm9m0rl9vghswcb4xgp54lc3h8wkh6c077625m9y0166xbv5x2d"; - "CT18XNNLO_as_0117" = "0630arl5qwjhxw0avzlc0mr4hwi09ki8xfn4zvfccgpy2nd85q5b"; - "CT18XNNLO_as_0118" = "1nx75pf5krazrk3ff3lb6zjnxz2qmffrk5vcf06iq5qci9zi5l0q"; - "CT18XNNLO_as_0119" = "0dzjj9f2qkpwfr9pm3pfj6jw5ih2jis8wzc8d0vyh5mm084jlk6a"; - "CT18XNNLO_as_0120" = "17pp23l0brnd0phq23888qbkf1c5j1lcskrbm3v3f2cd8p7jcvvw"; - "CT18XNNLO_as_0121" = "0hlfx8zsxc1x6glny4cp2vpba8jgjix9cpsfixff9vkbqpm2ppk0"; - "CT18XNNLO_as_0122" = "1918l55khrfyb3lcxsbbf9w6v8j54klszl2c32nmna0apf8zc3qm"; - "CT18XNNLO_as_0123" = "02kak35pj6c4hml75na7452ryashfclglhahclzkpq8gs72l5w91"; - "CT18XNNLO_as_0124" = "03wym12nvwdcr13dz6d2gr4bz3csffnn21zfdld42fsyq4glx431"; - "CT18ZNLO" = "0iv8laks2ymn5fygk6k9lxm3s7fld5g292n9bfkhn3nmcfxczi03"; - "CT18ZNLO_as_0110" = "1d0j9nmn9mk90698pxqlpgz7c7cyxswc88n89cr2h8mgcg2w8g2v"; - "CT18ZNLO_as_0111" = "17l7j1j2x529mhk0andkdh83k9z6kg9v3ccfna08i7d4iilsdfrs"; - "CT18ZNLO_as_0112" = "1b8mi0jwln2wvysrkbm1fvay053d17dzvlj9fkz36xmr03bv5mvj"; - "CT18ZNLO_as_0113" = "13dkpjvh5a3p565mhpxqnhijl3jd2zr03np5psknvl121gr007fk"; - "CT18ZNLO_as_0114" = "0drryvq2x42xpf9bmd6n4vz1f8ddh83c3rynnzm54qssxmfkb073"; - "CT18ZNLO_as_0115" = "1wdj056rf02jksa2l2panvkijvvwr6rsb8kh3g2bvx0yjhff8g1c"; - "CT18ZNLO_as_0116" = "1ibf0841irsa4vq9sg0kvrhvakyyshpvs38frz9v3zjbc012cldz"; - "CT18ZNLO_as_0117" = "0l2nabywfsvb1sk44rqgrwf8h0lxkz8qf6pmzr8jc3zhq1fv04sl"; - "CT18ZNLO_as_0118" = "0dnksqqshxqr0y3qr3diyvhfq1jxy1x0hrjw8xk76jzm61xi96x1"; - "CT18ZNLO_as_0119" = "0qljv4d1qfc9rx3p4a8dghij11dv1mi03y30wdilfxrf98znvdyj"; - "CT18ZNLO_as_0120" = "1w0p5gai8qhfjh4jxhyl26xrp8n210cp2a7zjd4id1s4pcvpzvn7"; - "CT18ZNLO_as_0121" = "1ija1nqc4pbprcc3ddhl9rxxbaxngjr256zxiy7gg3wmg6364hjl"; - "CT18ZNLO_as_0122" = "0d7h3vli13m1pm5w91js8skv198aqz9kjkx7w0sa4v2vhvz1rdyh"; - "CT18ZNLO_as_0123" = "14cl8fmkl6jav7byqwcfa1z2ml6lnn6pzp0w4nqy75gc7wxsba0m"; - "CT18ZNLO_as_0124" = "18riha0fflfbsgh7nnc3ghm8cpzpcss0z6l48d28bbq0i7caqad7"; - "CT18ZNNLO" = "0zsqrpab6vgcinsxjq3rqdadig5flxzk61wc1aa9rwnkbpm1paa5"; - "CT18ZNNLO_as_0110" = "06qzlfshx8gwrhnmjfvz6sxq7h2is1dqvx5sz8jxrr1gl7gl92h9"; - "CT18ZNNLO_as_0111" = "08k101cn9x9y44zcpn6iql85qqx89rv7xjhvak4y6s309p9rlnzi"; - "CT18ZNNLO_as_0112" = "1c72mz93kha8mdfdcwj8fs8dqqylxmmc4vs7fjf9h7xbrqzmss7m"; - "CT18ZNNLO_as_0113" = "0z7s1kmlrv99r5mb6p1xwrydx0s896kr3va0ld3gq39a0f6bqvfz"; - "CT18ZNNLO_as_0114" = "0ir6n8i170czq7h3badim28540478cq5fb5vv4kdi0ncypsasr4d"; - "CT18ZNNLO_as_0115" = "0dncvhp99v5s9746ql37gdm65byih9ppg30c77k50i2485a1zfap"; - "CT18ZNNLO_as_0116" = "0qihfcsgxv66l781dmvmmpbr0s0c52s90jfmz5y52gyy1lplw569"; - "CT18ZNNLO_as_0117" = "0agqd4vgj53w9p7ghfkrskqyvg7lw5g9ilj0fid0jia8adfh58xp"; - "CT18ZNNLO_as_0118" = "07y1l00igx7d2yaj9gi60fvqz1p8f8z44fmxm84fpjikajabff5v"; - "CT18ZNNLO_as_0119" = "16nnwwj16c8fmqh5mwnihzvbgfj3cnvw01i1il1gr0g4zqpn0yhi"; - "CT18ZNNLO_as_0120" = "0yy0lxwm41aa727wdrq27l6ih7fdaqwiy4bkrbh0zrns0km9r958"; - "CT18ZNNLO_as_0121" = "0yg70dx2wi9wf5914shfqaf2j90dnkfnbp1pq2jzxd0h0sxhlphj"; - "CT18ZNNLO_as_0122" = "1bd4193ggv4nb48d0mw2n93ia30h4myfy197k9b0m3qc90xjq77z"; - "CT18ZNNLO_as_0123" = "0r2vri1brq0xcrpj0cg9hf9kwhkh2czmimrsg5bfvx35adiiis19"; - "CT18ZNNLO_as_0124" = "1wq0nz9jfb5fmzwnnh0xyra2j62kb5xpmh2nyy8ih4lvxhgi16mg"; - "EPPS16_B_90CL_Au_hess" = "0ab3pnv8fq45mdp29m6lfmrhhnr88k6qvkq6lwxmn17k39v8j9w4"; - "EPPS16_B_90CL_Pb_hess" = "1cjc79sygpxnir3qw9n6cdwvd3flfn11ajqs5y64svrpsqcx5ng0"; - "EPPS16_B_c_90CL_Au_hess" = "1ijvnglq4wrjhhvksyd60s7c6nv50vwyk5vd8c3gs0qr8yz1fk69"; - "EPPS16_B_c_90CL_Pb_hess" = "1347cqsfkim0xcds5imxmsdxh8x0h2n97x5zwpf035rbdk5mkr4n"; - "EPPS16_B_d_90CL_Au_hess" = "088jrj6xf1ph19sypa5dizllydfzi6ikxq2gisdlxpj1qnwjymsg"; - "EPPS16_B_d_90CL_Pb_hess" = "0x12r31l0nvqsc2ml1zkil0w1iji52xgbnxn3wss9pnmswrf3cah"; - "EPPS16_B_u_90CL_Au_hess" = "1pq7agglirpk2w566c1ql15ps1aglmnph2p2dfa535zlv89s7c0d"; - "EPPS16_B_u_90CL_Pb_hess" = "137jkcbikmcjaxp8rpr5j193cmr329mcvyy7j0s0a6ynglhpr76k"; - "EPPS16_D_90CL_Au_hess" = "01ggm0xxwd3nc95cjcf36sy0pdb0xvk6bkiaq328w2sfajccr5mk"; - "EPPS16_D_90CL_Pb_hess" = "1z3zam84m2kbs7zinn87xhlca90d5zwk8j72yj19nx3r92brnq8h"; - "EPPS16_D_c_90CL_Au_hess" = "18sviyvm3rm9n7x79w1sx8j9mcc6dnc2il8hsw2avjgy2aqmwj87"; - "EPPS16_D_c_90CL_Pb_hess" = "1ryv83iq1lrphgxvdsmh70j6iky993sax0s9cfrswpjyl2pcilq2"; - "EPPS16_D_d_90CL_Au_hess" = "15j6s9mj1ci9wjgsfhbxfikcyxc5pilv56cyzxjhgjhfgwvi1xyz"; - "EPPS16_D_d_90CL_Pb_hess" = "1qjyb57fhf6d3g7l48jcl6jizj2c5g63xahzanrmkm9r538hvhcc"; - "EPPS16_D_u_90CL_Au_hess" = "0jjk2rccvv0ngxn7wf33j21y72wvs4dhwl56yhmf7bfzd6v70rp2"; - "EPPS16_D_u_90CL_Pb_hess" = "09npz68wwvcsvd6h8lsgmlr19l0af4h4rppcd6jlwd88c2zpb3r3"; - "EPPS16_Jpsi_90CL_Au_hess" = "0msvkihdmhap0bbiydxbp552k1sgk20wadvc2s2h9jldakdx0pk9"; - "EPPS16_Jpsi_90CL_Pb_hess" = "13vc490k1769gbph3xn1lffj0ilvhz78by3lhw45lwkra4vx5zp4"; - "EPPS16_Jpsi_c_90CL_Au_hess" = "069lzrnm5kx56rblr4lxqvr014nrf2yyf1iw42s37q2xsxpjip87"; - "EPPS16_Jpsi_c_90CL_Pb_hess" = "1895iqzmcnaqkidcy96z4766wppycp1riwg9clg71cb404wz74as"; - "EPPS16_Jpsi_d_90CL_Au_hess" = "0ndh23dyaszam144dsdbg4281c61vai8avgi4y7x8kb0paha4icm"; - "EPPS16_Jpsi_d_90CL_Pb_hess" = "0xflijnwabg931z19v8c18dzh1lbqivkg94kpwm8j135ya1vpmm2"; - "EPPS16_Jpsi_u_90CL_Au_hess" = "1hagv9akwm337kq3kvkpkdkcpnic7klnigh9pyif1gm16i1q40jf"; - "EPPS16_Jpsi_u_90CL_Pb_hess" = "0dw68rky105lyaagkzkmfx6l9jk763m293m7s972jhnl5037bj74"; - "EPPS16nlo_CT14nlo_Ag108" = "1p7gckhv44h04rvknd6fdizy9c1jqfwic7ppf0ra14ic8wp1g7wg"; - "EPPS16nlo_CT14nlo_Al27" = "0hxyakfgknmixxndfj14i44afp5gcfz9afjvjdaj702sv42a7qa8"; - "EPPS16nlo_CT14nlo_Au197" = "1g272110y3a1fr6raxdfhagn68i0lcnwbdhiiqg4j6wb6v4m3p6i"; - "EPPS16nlo_CT14nlo_Be9" = "0zxsdmvz919ajwwb917613byshhpr876jcg9kik0pkz8c4ddr2z0"; - "EPPS16nlo_CT14nlo_C12" = "0mjmjk9n36aikhm8i6zwzfszyb5zcy1syn13vs2rm12x535j6dm5"; - "EPPS16nlo_CT14nlo_Ca40" = "18vd67splj75sjijfvhyq0q6068yr8l083sczamwpmy8z3l798ih"; - "EPPS16nlo_CT14nlo_Cu64" = "0g64gpc5cssmwl1sn7cl0ramsg2zfq7snr9bzr41q2dznbvqahgd"; - "EPPS16nlo_CT14nlo_Fe56" = "0dxfzpx99ha9g27bxx6xzxxh87va91qqwq6hnz1qsligjfx7q4yz"; - "EPPS16nlo_CT14nlo_He4" = "1ln5kz3270kyx6m3ji6q5xyp5a23f3kbwh9z9dmdwwsw7q9n8way"; - "EPPS16nlo_CT14nlo_Li6" = "04rviiml0rnym9qppsczcydw37r923ljx8hj63vv6dxng0g617qb"; - "EPPS16nlo_CT14nlo_Pb208" = "1b2zibpigdvvkg29zh7zm32jpdr2prm35jasafh17pfpwlfc55mb"; - "EPPS16nlo_CT14nlo_Pt195" = "14v1gicvm8i8z9d98rlv5rbhaglkbi9fhs3z465p4d764al6znnc"; - "EPPS16nlo_CT14nlo_Sn119" = "10nxn6rdp7svsrkdcdwxryjmirn1s871yj1w493adpfcy3chqw9k"; - "EPPS16nlo_CT14nlo_W184" = "1x8ndmkzmnl79vz1bgi9972190x03asvgnls6qiz746xl37q4ky7"; - "GKG18_DPDF_FitA_LO" = "0ql03hp30wfaw9gfyska0v5vf4p3n2dsxvkapjqnyfl01ad6vjw2"; - "GKG18_DPDF_FitA_NLO" = "0n9khzvhyxfwbl758vzy8jgyqkgcgl328m657vlami3w22hmpbrz"; - "GKG18_DPDF_FitB_LO" = "0s15ia8mcn00xl28rhdxjigpq0ai80a831366sx0w7qx44bb5n0p"; - "GKG18_DPDF_FitB_NLO" = "0qlv7p1fx3gq2cqrvamlpn6r54nssbk7rrx1znhfdzx3x9v1ii1q"; - "GRVPI0" = "0i5icsw9hf4jm25d0szxqc3r1131n417lv8b4gslg93xqj4ry1hf"; - "GRVPI1" = "05j3mcrb0sq4nzv7y0k68f2m3v8vnd13mzbhq43gjq712cbj126p"; - "H1PDF2017" = "10yfikq1mlw6bzhbvwblajicpqzhi06gl1aabhxr6mcf9vby4zw8"; - "HERAPDF15LO_EIG" = "12cqj3vqwi86sfgxkiwbd7rnpw1awnbqbc852b0x32d9j18nz9c2"; - "HERAPDF15NLO_ALPHAS" = "06yiid611zi5i9snqrkjr3g4z2n1gwkvqjs606ha0b4nrwlpnkhc"; - "HERAPDF15NLO_EIG" = "0h5brmk7w70dgbwhjikfpprni924c2f3kxsmxzcm2qlrlgj0nswd"; - "HERAPDF15NLO_VAR" = "049bfsgkcfnz4z7vzkl4vr6ivp9kvak2f07nmarm8q2wwd6pjjqy"; - "HERAPDF15NNLO_ALPHAS" = "09qf93b336yak3aqnfqlvz5j6xvvrsqkc4ag41xh4prpswj8fmrc"; - "HERAPDF15NNLO_EIG" = "1yf48sr7nak6lph2s1vd3s91mrw0da9kjxlvqzcg3n9j48l3f3r0"; - "HERAPDF15NNLO_VAR" = "0di4b75ag82iysyrv5wfvn8728jdi8mkq96ycpq534078ps2n3bd"; - "HERAPDF20_AG_NLO_EIG" = "0jr2s4dj5w9xwidrqbqi8af2dqycm4vr36qy3x5javllp4dn04cr"; - "HERAPDF20_AG_NNLO_EIG" = "11cdhjwz4qm2hxf8i5kl38ny4nbsrd2vf3jkwz17lrgls716wh00"; - "HERAPDF20_HiQ2_NLO_EIG" = "09wwkv8lk7gy14avvamk3sqdsvig2bvnzha5d4v5s2ln7g6g7vhq"; - "HERAPDF20_HiQ2_NLO_VAR" = "1cgprisw1bksi8nryqqsy6ac097ywxdgj5yg796izari7j72p4bh"; - "HERAPDF20_HiQ2_NNLO_EIG" = "05670fr76fx14gp4ywywz71scr6f25jk14i4k84gpcb2l6rnbv9g"; - "HERAPDF20_HiQ2_NNLO_VAR" = "15nxgq5hy6ncvqma6ai8k7601bfw97p0h9db2gqbbyyvxf2ldnc7"; - "HERAPDF20_Jets_NLO_EIG" = "1c2n2cn9l8x9jc8c4dh2whgz3378nnnvb3448cgpv0qfm589ygxy"; - "HERAPDF20_Jets_NLO_VAR_Duv" = "0z2pkmlpffy29x2bh0086m1ybbb94x507fkr4khmdb4d0h33ppdw"; - "HERAPDF20_Jets_NLO_VAR_fsdn" = "1ya4hbr3shjggpqi6h3g9j3jnbmmgrva2djbsaxgp7icii39yf1a"; - "HERAPDF20_Jets_NLO_VAR_fshdn" = "1sl2sq27xx40mj4zn00vc44k3vf1yxb7fwpqp0p3lqlp9gcwlycp"; - "HERAPDF20_Jets_NLO_VAR_fshup" = "0qs8g45s70d0l3g7xh0bqhk65ac9g003bjpacd9v97gzpm6jvr45"; - "HERAPDF20_Jets_NLO_VAR_fsup" = "17ix21qwjkp9gy9gvn3143d8ganzg9r78n6q47wdfxh12jzvgc7k"; - "HERAPDF20_Jets_NLO_VAR_haddn" = "15rbsdddm5ayg5r0gljxxcmrrvzhfdr44ky2d6a70wjr2g6lc5yc"; - "HERAPDF20_Jets_NLO_VAR_hadup" = "1x3rnr2hkcfglpmv732blziygzvdlw2rkks1ap9majnayh01vvfk"; - "HERAPDF20_Jets_NLO_VAR_mbdn" = "1fi0rp4gpqj7yjmv6b68ac7m8v4f9m4q9kd6nq4ndk2gp11i6799"; - "HERAPDF20_Jets_NLO_VAR_mbup" = "062dfx73lihlhndn5xjlsimfxalxbfhn1xyqzbk7bsqj9mffmwli"; - "HERAPDF20_Jets_NLO_VAR_mcdn" = "092hwkx9kliib8lf405sy9bvxg6xgydnsxl92yjqwyicajihhij4"; - "HERAPDF20_Jets_NLO_VAR_mcup" = "0qcirk0sqnkfyb3pdxlpkl51pbj2gybw7kgw9xzmj4j3jdg2zjqg"; - "HERAPDF20_Jets_NLO_VAR_q0dn" = "1xv319ai4pwy1mcy6i3wk3mp4nkdpjb2zcnz17gxvdx2l6z1bz5m"; - "HERAPDF20_Jets_NLO_VAR_q0up" = "0bfsqx23jsrjjsczl5j90hp3njvlwaw8mypj1si83mr1z0s9q4rx"; - "HERAPDF20_Jets_NLO_VAR_q2mdn" = "16qfw118c3lh91zsg2nb49xjynbd9w1rh4y5ybr35v38i4acpdab"; - "HERAPDF20_Jets_NLO_VAR_q2mup" = "1q80h7r0cklpz1jam3nzxs7h3i8jpgpc03l7c3g4mkz61ynh0ida"; - "HERAPDF20_LO_EIG" = "1r6ylwi2yszsk5dmw27734s0ghkvdawmqa6fik1k3j82d9s22mkl"; - "HERAPDF20_NLO_ALPHAS_110" = "0zmmg0k33bf52skbz42cgxdjw0ap33fyf0h1kfd9ciw4gra2rakn"; - "HERAPDF20_NLO_ALPHAS_111" = "1mlc33kfs4zlmn305hifjh2d85byvym1mzdj9bc3nlypv4zcszlf"; - "HERAPDF20_NLO_ALPHAS_112" = "0wswbdmkyv0a6fw531s1s7jnskzxsvwh9bydvgiav53pfpibsyx6"; - "HERAPDF20_NLO_ALPHAS_113" = "0qx7kh3cmqz59sm6vjcvi2hj5c7d816mc7jfhqr03hvavqcsla14"; - "HERAPDF20_NLO_ALPHAS_114" = "1n2434j9gvdz24h30sng8z5jmc9hhnm9nbr3hi82n6ssnwabsl97"; - "HERAPDF20_NLO_ALPHAS_115" = "05wk9glb6xpg5n689slihcfkdvm3kgwpxw8dxp4rp8zyvrsh6l6f"; - "HERAPDF20_NLO_ALPHAS_116" = "133vvg5bh1lx6zcacnaphkj11608wafim4rb6lcqx4mkpxabmzxa"; - "HERAPDF20_NLO_ALPHAS_117" = "18n1s7qqzf67lg8gphpm606dvz802i6xmlz5if5jdhjz8r3qklzf"; - "HERAPDF20_NLO_ALPHAS_118" = "07xj5j7k54bwi9xq51cf8zanqlkjcbdrvw9k8ch3h40bk961c5pz"; - "HERAPDF20_NLO_ALPHAS_119" = "0njyfp84kf51m9rw9z3d3figp23043p5ml7cdb45dvh9hbpssh40"; - "HERAPDF20_NLO_ALPHAS_120" = "02paa7bng9nycd8dd2zf2099592mbaz8c4a5hamcmvzqfz0sdy7d"; - "HERAPDF20_NLO_ALPHAS_121" = "07hmbvpm96pm5yp9bsx9aksznksh6k4qrw0k28bns0wjn75khxsl"; - "HERAPDF20_NLO_ALPHAS_122" = "1pjn3h1wr6l6sy7kjvk72qc409dr939z787q2qbaph7xh5rf7k2s"; - "HERAPDF20_NLO_ALPHAS_123" = "09hz6pw4nklwf94krna7g80659v9c2c0f5rf99mnx900xyhk7pxa"; - "HERAPDF20_NLO_ALPHAS_124" = "1d9gmc3g0j32kgwyfddmx9f3gxwrgnq3xcbrabdx9cw554ysd6sg"; - "HERAPDF20_NLO_ALPHAS_125" = "0mi2q9yhkcdpj7336kbs1vw4zvm8c9fryz0c7hdj246kj26rb0mv"; - "HERAPDF20_NLO_ALPHAS_126" = "067rng6gv24qf1j8lz37115mc42k8wjpzrfcw4jw2d1yg22ci0lb"; - "HERAPDF20_NLO_ALPHAS_127" = "0v3xcdr8wsradqf3bzayvvlsdjzr54qa2kbqb5pyvfi3rafrwrmi"; - "HERAPDF20_NLO_ALPHAS_128" = "0ywnd9c6bq5bp02s3b3pql8a74wm472p11alqi4b4pmlzphzk1ix"; - "HERAPDF20_NLO_ALPHAS_129" = "055ya2wxscbzp2w3zx2a5xgs94wl60bm6c2vxrs2rgnab72382j9"; - "HERAPDF20_NLO_ALPHAS_130" = "0k91azhwxrfni5yfasn83f67ma9w8fax2k1k9xc8pvgmbh3c14wi"; - "HERAPDF20_NLO_EIG" = "1ryamdwblj1ysbha672q2z9qai62h6cibb0laizfq2nq4j4ml3vz"; - "HERAPDF20_NLO_FF3A_EIG" = "1fs6ldnwflmn5ysqkq9aky2xskd0dvq372h48x89h4vmsvd302wn"; - "HERAPDF20_NLO_FF3A_VAR" = "0jd9wgrhchqjcjrkh5hjx7x8agm43jq5p8dmyvk0rniz9zybx64d"; - "HERAPDF20_NLO_FF3B_EIG" = "0r04zjfaaq686g3bd6c753vkcwsbgdcfzr67ngm7vsz27zscbjbz"; - "HERAPDF20_NLO_FF3B_VAR" = "12qrfld8958gvk9c2q8l0mvccx6wkrgnsiapgzl37s6s6zcgid10"; - "HERAPDF20_NLO_VAR" = "0q5ih9ac3z6n158h6q149h0ggkfjrdn5rqwf7nzi3j50fhs63swj"; - "HERAPDF20_NNLO_ALPHAS_110" = "1828i4ybdzs7zj62lzsifgshxdas81vjvhfg86ixry4xqkfprlfg"; - "HERAPDF20_NNLO_ALPHAS_111" = "011d1a900jjpa78ph05sdy353gfmrr8azpngcf0cjigcn4fwdna6"; - "HERAPDF20_NNLO_ALPHAS_112" = "0xb2bnigwlhs0vs3fwzsz66zidchwgs97kn6vjfhxnik8xdfkyb8"; - "HERAPDF20_NNLO_ALPHAS_113" = "13b8gh0qwpy574ra6184vgff3wba0blr44lxj56xrkaql9zi1jx1"; - "HERAPDF20_NNLO_ALPHAS_114" = "09n30p5pbw2wyjss2jjz1h4nl9scin42s91sxdcrwinnc3y5n1in"; - "HERAPDF20_NNLO_ALPHAS_115" = "0nlimqmfhx2ijx48ylciih5diwlsb5zzkli82rgnnxci3r4ycjq4"; - "HERAPDF20_NNLO_ALPHAS_116" = "0nr8svx60zrf42nxg74v0h759y9lwg54892xpdmswg7mw0nwcrm9"; - "HERAPDF20_NNLO_ALPHAS_117" = "0xiqdr2r5dyyp5q56b3w04wy3raqrh1mjsv1fm05xswxn2xwyhlq"; - "HERAPDF20_NNLO_ALPHAS_118" = "0d0w0f077g11s4clx1556y9xx5nn1dgm8zcp0bk92v4lapngf33c"; - "HERAPDF20_NNLO_ALPHAS_119" = "1w9nl0pnfc1cii4knmqdq4cnh6shhhgj8pg4a42bx20lvqc3aqgb"; - "HERAPDF20_NNLO_ALPHAS_120" = "1lksn0rcxq2scwpnps8dawlzijhvwbg0pn2is4r29igbqck2jvb3"; - "HERAPDF20_NNLO_ALPHAS_121" = "03d58rbibvgcvmsw86q3030qnw5nnvq8p6diqscd9srb8br06p8m"; - "HERAPDF20_NNLO_ALPHAS_122" = "0541yx5fcadw7rggpypd8kg393m5hwzsw5jangsmsrsby1rc2m4a"; - "HERAPDF20_NNLO_ALPHAS_123" = "1ckc8s04jf7x19xpwwb8g60likrlz3dp91qzaafljvbd9b27aa61"; - "HERAPDF20_NNLO_ALPHAS_124" = "13dx2wh0dhxsjjk6ak7wy1gr8g297dpc9xvkxvb5ayd0rzmhjlwb"; - "HERAPDF20_NNLO_ALPHAS_125" = "0yh6jakycsqhh4h6jqrilw1afmk1jkcq2px978z4qcz4y0m6bx4a"; - "HERAPDF20_NNLO_ALPHAS_126" = "0045sa1kl4w75ja6an38i2a3fi78q6xg22av536l9h1c8j82ql13"; - "HERAPDF20_NNLO_ALPHAS_127" = "1f5l9cy59dc3rc9xqrsq85g0mbhyaqkbpzi40f3gjg6bxjlgb4rx"; - "HERAPDF20_NNLO_ALPHAS_128" = "1c2pbd4zam5av582r777197638l6i5a0chmw9ci7l05lzm19nzmi"; - "HERAPDF20_NNLO_ALPHAS_129" = "1aipmxxn7s1r66m6gmrjgr2yca7sxvpf8r86s4a5j768akkgmlld"; - "HERAPDF20_NNLO_ALPHAS_130" = "1g2q3438bivd20i685jmx565cq108yv72vhxmpmhysh4qwvwpqqw"; - "HERAPDF20_NNLO_EIG" = "12zn49jx7qjr8apgpbhknzll4vwlz3x9y1ai908ix2h86pgap2ml"; - "HERAPDF20_NNLO_VAR" = "152h21khvkhxwx87c5lqwzpakmahcpj1ixw6kgl0wrrwjknvfgxn"; - "JAM19FF_kaon_nlo" = "05mcahzr0k5w0hqfbn902lmkwxlkbf8wrk6akpqnfsyqpbmhja5k"; - "JAM19FF_pion_nlo" = "06krcf0c9jbbpwf1rk1xd5z7rz904ji984xz05kv9p1j1vgk0ha0"; - "JAM19PDF_proton_nlo" = "1zrcijik60rci6km5d8pn8ivww8w3v8pb1m5dshqjs51lhf56ayp"; - "JAM20-SIDIS_FF_hadron_nlo" = "0bx3igckr2dszxskz5f952vl0q7kwvxgyb28yksjk75325dp2f9c"; - "JAM20-SIDIS_FF_kaon_nlo" = "060r6ah5843vm1r3rhjvlgp7w45z39cqgibfc2g2m1q7mwjqccjy"; - "JAM20-SIDIS_FF_pion_nlo" = "0fpkbl5fw76wgk8l599kf51mqa0fy92bq9ksfjfks0c4m6ah1g5i"; - "JAM20-SIDIS_PDF_proton_nlo" = "1g1g9n2ij58yzvgrw8g1f8jbqyhj9yvbvl9iqjxllkhkb2zbllpl"; - "JAM21PionPDFnlo" = "0zn7p9ny6072dkhsiaq64f2gdzpqbqc06d9a21rvvg3cgsba9jg3"; - "JAM21PionPDFnlo_pT" = "1wxpkk1wzx1z1kwxfj6kz14pxlckb96aqaq2fa4sf1a0ph1ibrc8"; - "JAM21PionPDFnlonll_cosine" = "0nbmdc0744kl6r7r9lfs20gffpjyxpcfpkp7f336fn1mcl89wggn"; - "JAM21PionPDFnlonll_double_Mellin" = "1n8fqar0dddc92054kg3pl1xlh6z7smm3glv5fvfxr933bxli5g8"; - "JAM21PionPDFnlonll_expansion" = "0dmmalgmp4xjwimyfx0sa8yafzzm0xzqk557qwkli3ramzwrwy8p"; - "JR14NLO08FF" = "16azkqxf1yw1j32ay6j01gf8n9n7qm56jh4yzgjag0zdhm01lbip"; - "JR14NLO08VF" = "1ilw38pp4vy8c8v1glfi4ixca73wjkdg3di1wh9p8xqrifdb096p"; - "JR14NNLO08FF" = "1w0pywmjb4xi7bsvv1mdd4q2adf1g7khspfbkphmlh8zipx29nxx"; - "JR14NNLO08VF" = "0kzszj1r141fcg9vbf53480224nxcc5wfk9zmpmzbmrxzi0w127r"; - "JR14NNLO20FF" = "0wc3qib90dpd1wgiymrn5lzwhqmh58ji2s92vpj2v9v4spws7pdq"; - "JR14NNLO20VF" = "18l4ipn80gmh9kdw7a1k49fwgbl7b1frgc0hsa04vbwnv6hm73hn"; - "LUXlep-NNPDF31_nlo_as_0118_luxqed" = "09ch6mjfn6rjsd31jfb59j92ngqiy0x19qamyxh0jwk0sbyr1dpw"; - "LUXqed17_plus_PDF4LHC15_nnlo_100" = "18y3pa6gjmcv2s21si9a5dvbq6xxqphbqz5qiy39c62g2zf8512c"; - "LUXqed17_plus_PDF4LHC15_nnlo_30" = "1bnwlxr8p4xmr36zd2flhqssil6w7jh50k46j0mxfnd8jgxgwn6n"; - "LUXqed_plus_PDF4LHC15_nnlo_100" = "08jzl4wcsrr9agycq1r5kd5bqxsx4b637nxk34s82vs7vwpq7qib"; - "MAPFF10NLOPIm" = "0w875dh5klqgggcr84g0g7qmh4q2xim8nrf0xdnfc665xww7v4my"; - "MAPFF10NLOPIp" = "1493k3p7b03sw0n7va60vqxcry2b3xgpww6fnk2gx8b4w1632yn2"; - "MAPFF10NLOPIsum" = "0x6sashkhg1hs7wy6fyln12s1f4yavvc90zv4k7rclbah4hr75wm"; - "METAv10LHC" = "1vn4wnx1blz6wylbzirswdqqf0knmyh1pcfh62wvj695mh7i0w16"; - "METAv10LHCH" = "1p4wy7m1ksz0r1fylwz3cbq7jl8s58v817n3d898l83ic2ghp4vj"; - "METAv10LHCHfull" = "1w623939fjdyx1316rxyaavf6kmxff19himr00br57jrw3v49nfg"; - "METAv10LHCas0116" = "0y1l6djkmx8zcsii9j9krwhvgh071a9y5d4m1rkqpbqf6dnq9kll"; - "METAv10LHCas0120" = "1g1izkf3j0vdrjskbjzh8lzsdn1bqssidr0gsapyzlx0dzc2ixdp"; - "MMHT2014lo68cl" = "03wrjv448zdqblv4zx5b2p4m0nj8h4igabh8pzskj0327w7g91lm"; - "MMHT2014lo_asmzsmallrange" = "16ki4aib5dslb7lx6w9nzx18nh0sgh41zbiw4hszf2qxn3asdyhz"; - "MMHT2014nlo68cl" = "039zw5zrzm661bgjv7d0imzhfv3j3ixnrssi13ynfpin9v2izy6g"; - "MMHT2014nlo68cl_nf3" = "0bjmng4ifdswi88kf59zzxpdq8ka80m01208nb2ij3dkpw0n5hnf"; - "MMHT2014nlo68cl_nf4" = "01g0bbfwxaqhgpv0yz17fvwa4q1a1vh9867kp9fyavn600kd91ds"; - "MMHT2014nlo68cl_nf4as5" = "1wdrk7b1hs6s8f2gxp7b3c1qrxvncs41h4aph1dhf8zffn3653yy"; - "MMHT2014nlo68clas118" = "1nv7h2j31z061mgph5154qgxn8rl5sdgwzzs3d3clxfshh5gcccn"; - "MMHT2014nlo68clas118_nf3" = "1d7k0vablssy1vfimsvxdiklaachw44lg37fgj1im52k81qxzd3n"; - "MMHT2014nlo68clas118_nf4" = "1s8gv434b4mz6y5rv4kms69ghliafcmih09icj4qwk66hj7pn5lj"; - "MMHT2014nlo68clas118_nf4as5" = "00zvf9zkrp9lk9psqvzsn04l1rw1xmq37bd2c8mqc2px3zdq9q0f"; - "MMHT2014nlo_asmzlargerange" = "186jz5r74qas28x04daqkxhs5p31i68hhy8a7q6lzd5nh42x6kk0"; - "MMHT2014nlo_asmzsmallrange" = "1x347h5g8d2k73wg6naj6zs7m2glankiwjgzy0gmmrnz3pyryq6x"; - "MMHT2014nlo_asmzsmallrange_nf3" = "0ckw5971pwvvix8idw2m6j7w6bjivqpa1ynm6ml0bhc75cmm6l4i"; - "MMHT2014nlo_asmzsmallrange_nf4" = "1asnk3pl3dw1sh76k0s95jb57cv5k90zjgpbkr3nnrbhvnkizl5a"; - "MMHT2014nlo_mbrange_nf3" = "0bghvriw01jxmzcm9isz7in43ph7vz6zzr0rmmi81snrwvg8918h"; - "MMHT2014nlo_mbrange_nf4" = "1gad7269hz4jj3946yyqzmcx3zyxx2p4r0h88x3lfrm0rd0fg00d"; - "MMHT2014nlo_mbrange_nf5" = "03id7bfds16kbnd0nwjla8sn4pl3q3qa5v0a3pykdwj14k9igi3n"; - "MMHT2014nlo_mcrange_nf3" = "1zfmdclsgwf6517v88zg34wby40606sspcghh4yahc2bbznd6a63"; - "MMHT2014nlo_mcrange_nf4" = "0hzhkv81a0z3ichj5kfhwnhc720xw48h63llijl0pcfv8qqpvl19"; - "MMHT2014nlo_mcrange_nf5" = "148hg5dc60yhfmwsm0svasxc7l1py6ggj7lzv0mrshl07rwfh62a"; - "MMHT2014nloas118_mbrange_nf3" = "03w1wish6ig3mw9j195rakxsjr7gr46qz8dh009sigqcgp3s9fad"; - "MMHT2014nloas118_mbrange_nf4" = "1lbj3r1bbxx2y1ybnxpd0cw7jzkdz0rb1grn1pmwmrl0l13s7j59"; - "MMHT2014nloas118_mbrange_nf5" = "12q0gkqzhxqwrvy8lpg66ldsxnwr8id6jv6k4dj6f0p93qif5wr8"; - "MMHT2014nloas118_mcrange_nf3" = "093yh7wa3p4028x5zxw15pwkrkjxzfl7kcdm7jqlf08zwm52clyx"; - "MMHT2014nloas118_mcrange_nf4" = "0q0y77i0fgdvjk9y76kqzxpn22jbzsh64qbx8186ri9fqzfi868i"; - "MMHT2014nloas118_mcrange_nf5" = "187wsfm49ack0jh9rwy5h29b1511b17myqn28bm6nbn7r4rfvnkz"; - "MMHT2014nnlo68cl" = "0sss77zwv94vcy4ghv6493vbw08xwm264dk081w34jc4ifa0vg90"; - "MMHT2014nnlo68cl_nf3" = "06paq3nzs87babpksabnkqi38gvvyfvpqlh8p18140zrdpdffaj2"; - "MMHT2014nnlo68cl_nf4" = "0lbqpdy66v3ns6ax9vj1ix4wjn2pwlw5y1z26hlbrxz3l8hbizg1"; - "MMHT2014nnlo68cl_nf4as5" = "1bh5nsral3lrlqq6afvq9ahkfmhfw3mq0m0qcvsx4ma5jx5rv7dv"; - "MMHT2014nnlo_asmzlargerange" = "00l2jqccsl3jfwdj7lndr4b5cpx44krjvnm3h0hjw6hkv4irxb5s"; - "MMHT2014nnlo_asmzsmallrange" = "1x36pv9nhj74whibb16bc414ypcks6nd1s7q1jc0fb7ndf5rijy6"; - "MMHT2014nnlo_asmzsmallrange_nf3" = "0svpc51n25cbz2b43zbd60bfckrlz3q2jn3x668xnha9qsd3c2vq"; - "MMHT2014nnlo_asmzsmallrange_nf4" = "15jggp2nbm828nprxyyinmp7kfxngpm0apg446hvwd8hg7blb1a4"; - "MMHT2014nnlo_mbrange_nf3" = "0r9gi5cw76zn0lq3fcs7s2xxh6jl9y5vdv31bhv6mac9jmhjb458"; - "MMHT2014nnlo_mbrange_nf4" = "190wva3k49mymflbm1v5xd449j38jm7ylfcdiflym8pgkdvwcgyl"; - "MMHT2014nnlo_mbrange_nf5" = "19mnv9nz01lmbiv01qmflhg24kldhqpmcc8mgp7bnkhicgivb5ib"; - "MMHT2014nnlo_mcrange_nf3" = "0zskxladqr40v6wqafbl1pl04vq43babqf437c4xxg4sz9435l3l"; - "MMHT2014nnlo_mcrange_nf4" = "0sny8r9zap8gnjh9id1klr59d9hs0bb40pf8hpy8q5pg6052vx3q"; - "MMHT2014nnlo_mcrange_nf5" = "1l340c1x4fz647bhybrvbb6z00mla81b78jfqpnwd4vwfxnqmq9y"; - "MMHT2015qed_nlo" = "130fmxnaashvwwaaiz5b787ldz8l78ar5h2h038xvisdjkxvdqni"; - "MMHT2015qed_nlo_elastic" = "1whplgg2s55wjii1hd32hzd5wsqbgvjjbnfw4fzjmnx4vwn63n2j"; - "MMHT2015qed_nlo_inelastic" = "1b24flby6n9q2cg4haldmjs8ql35lhlw0bgynwja1v2n0fbf550y"; - "MMHT2015qed_nnlo" = "1ypqiz0yz6hnxfml7ym83k4qqvqsbl39abbr38galns8xzzpi03m"; - "MMHT2015qed_nnlo_elastic" = "17in1cz5j7mm9qjk8i27fif6x276lcqmccl7kfz8a5yn73xxzja4"; - "MMHT2015qed_nnlo_inelastic" = "1ngk4p7w8l8b8sfg6hlm8ypxz97i1iwzlrc48szy7bi99kn8rmy1"; - "MRST2004qed_neutron" = "12vna0ic6gh313k22b44b0k9kd939v7zjl2hj65k1075j23mq425"; - "MRST2004qed_proton" = "10z0cr8pnr0lfxxi916naiz381a2cqn461jblfzvvddwqmqbllbc"; - "MRST2007lomod" = "13ar6hzw9al20zlm8lg0hvwmgrmv0dbam820gm36rj8p7i33qlr6"; - "MRSTMCal" = "0kbyp4rypw8jm28zfpvf0grvfvxmsrp3grwsmfxpa2c38x6la3rq"; - "MSHT20lo_as130" = "0ivjvqabk9jnrlrczjlqywmijx5ql8wy579j77qkl1vhv7sqccm1"; - "MSHT20nlo_as118" = "1qwbwcq8p4hrprz4ib18mp5142b0lbyyzc1bf5a4iq5jjvi5qm93"; - "MSHT20nlo_as120" = "10y1a6iryahrafzdqskypjrnad6xxq08gm72pa9yc61xdy6andc6"; - "MSHT20nlo_as120_mbrange_nf3" = "0548pw6lkwwqhlrg7c4cyqh76bcyz78yh06fs7crdbx7hfl47cj7"; - "MSHT20nlo_as120_mbrange_nf4" = "0pg49mad4845llj49a1piaggd8wpwb2s4ar7jydlhrv7im886by4"; - "MSHT20nlo_as120_mbrange_nf5" = "0148agm89p7pwzdfjk8gjdaicll30xhz6sawca632kp5qwyd4g3d"; - "MSHT20nlo_as120_mcrange_nf3" = "187hgg8klk5jhcadiy8viyrfi0jfb3i18jckv6d7nsapixz1wgkz"; - "MSHT20nlo_as120_mcrange_nf4" = "12pjy0igjcsih100g238v143kq5cjjm5a13cghcipgcz2w4ldglf"; - "MSHT20nlo_as120_mcrange_nf5" = "00mipn9ndnw1k4nx6pmxb95wddmh98hg9k0317vlirxrf2n2jy7g"; - "MSHT20nlo_as120_nf3" = "1zy0j9qc28xpav3gx24r6r02zfz49r11ic66hkyq83d3q3fj751b"; - "MSHT20nlo_as120_nf4" = "0fpyf9s9ppb6w49chsmb2xfp9gwkx3ky9v8gwwqxli9fpzsc2ywn"; - "MSHT20nlo_as_largerange" = "1f57dvxas2c6qnv38ysnsyf0y8imafnrxkcqh3b0an19mkln5mmg"; - "MSHT20nlo_as_smallrange" = "1rygvj33g84whl24kgpqa47g11c48l93jlnpzqq8f5zr1ijqcq7i"; - "MSHT20nlo_as_smallrange_nf3" = "1d6cr1akc25mwfyghvn1986i60l76fxb8fd02h7f4pl4lmnn6i8n"; - "MSHT20nlo_as_smallrange_nf4" = "08js1l5g6knjx3813i0rf34xfjkbn3mdsrbawzkn00vf49xzcxdj"; - "MSHT20nlo_mbrange_nf3" = "1bwl4inshg5h3sslss4lgvcqahb5q0n794ag73hyacxd1kmx7d2z"; - "MSHT20nlo_mbrange_nf4" = "1sm995pzzr601wcs4rjgjs6alm74vc23szgmkqa5dvxghw7x8w55"; - "MSHT20nlo_mbrange_nf5" = "1sal7iqma7770593ifxypl9zapvba693asc8m2fjsbgpbfjjid60"; - "MSHT20nlo_mcrange_nf3" = "0lmv6m8m7zv0s8kjfm8parr9xlfy39dhwxn71z33f5x6cyp08zlg"; - "MSHT20nlo_mcrange_nf4" = "0875zfv0dws8n44fqawa1jp5p8b9vky8yyq48wijhrcph8qbxbrx"; - "MSHT20nlo_mcrange_nf5" = "0qjvam29zwibx54fgijry58vdwqkiwyavdwn736bmckjycncnv8p"; - "MSHT20nlo_nf3" = "1v0mzsa2sxp0g3m3d8yqcs7dgi74am6cpx79f341ahpwybz5x829"; - "MSHT20nlo_nf4" = "1lyii55adqaah6sm8b778q8scaq5yjycq3s8jdi3k48z8m23zqng"; - "MSHT20nnlo_as118" = "1yz0003ixjg97974648qba5d37vb4fhzzmq4k9xh4c37pnc3kgyn"; - "MSHT20nnlo_as_largerange" = "014a9x6zsw3w7b6w3v6lg8qxdjicxslr79bnagi6ci0skqs2v7z9"; - "MSHT20nnlo_as_smallrange" = "1bv7cbdynp6dm5c9v7r32gqy1lch4428apw426pr0d7xpm0abnxv"; - "MSHT20nnlo_as_smallrange_nf3" = "0n1j9dd069qdmgmd85m7wp29g96cnbgsdxrvlh6y51q063lkqbwb"; - "MSHT20nnlo_as_smallrange_nf4" = "1jkdl3rd933czz753qbi7yvszg376r6bvwq2inqbslnzfkfav5bh"; - "MSHT20nnlo_mbrange_nf3" = "095zcxhpfhlsb67ki4j6a8z4d1r5hzx92xlzprwkwd4v5ya4f732"; - "MSHT20nnlo_mbrange_nf4" = "1114z5a0pk9svps918zifff23difxf37rbmr3jnzxnyp1vfgzws7"; - "MSHT20nnlo_mbrange_nf5" = "12i6m01bmnzqadi6jg5gmah1jliq4wr4p0vpjgmpgyagsk4drx4b"; - "MSHT20nnlo_mcrange_nf3" = "01wq537083dr9ibiahwdwdaxj0j2ys211m478w9wgvihdjjvjvvv"; - "MSHT20nnlo_mcrange_nf4" = "04abrnlnbr94lksn29w9ws9a3b6sqkqvi9awmbk4715dxk2amnpk"; - "MSHT20nnlo_mcrange_nf5" = "0za255xi66a1mfch2b91qqmsr305m0kvs4rzvqlzf7k0v141j90y"; - "MSHT20nnlo_nf3" = "10yx59r32q4rl0yn4gpc29z8xskbvizkdr7k219qf16lnv892jpa"; - "MSHT20nnlo_nf4" = "17d10rba8b0aqi1npnx93j1995has5sw2l4izd6lly3yhjynbgp6"; - "MSHT20qed_nnlo" = "05c2hjgysyvkcyqg1lq3y00hqixgc8w984zivxkr76nj5csyf6m3"; - "MSHT20qed_nnlo_elastic" = "0in0y27gn4k9h6ya77krhizv8rg3i6s3d6h4bk0fhz91hbi4l3gh"; - "MSHT20qed_nnlo_inelastic" = "0vna0gbadf92w3xngb8gnsxd3lil8m029as8260wlki2axm4gqlw"; - "MSHT20qed_nnlo_neutron" = "1hiq7m8j7736477vfs18mqwhkxyvjmcrs7jiqysa8v6rmhb4bali"; - "MSHT20qed_nnlo_neutron_elastic" = "06dbvsysszpbvabgafb569vq88q1sm9mvz1iwv1m2b9vzin2ixiy"; - "MSHT20qed_nnlo_neutron_inelastic" = "0gfh6nhl4vq4qz1jhnv5vhhz4h4wlkwgj4ffjqll6jqa5anfhbqr"; - "MSTW2008CPdeutnlo68cl" = "1x2y7hl8ckplx175bp3wi04xafm44dd7vzfgnmvvai1x0072xi51"; - "MSTW2008CPdeutnnlo68cl" = "1szsdqjkmny30mpw4pdzi97vj7i55agxm285dvnkzp06ycgp1ld3"; - "MSTW2008lo68cl" = "0j12mv286r4ds9v7piqh4n44yjnc51hm74lqa4vv5xznxhibng7l"; - "MSTW2008lo68cl_nf3" = "1s5z55b2aj37bx0p305lcgrdclgvyl99xgfrl0rhmdgr2byg33wi"; - "MSTW2008lo68cl_nf4" = "0m539ihcz3dxy4gpfbam5badhhsimywlbgnczbybph8yn1118j9r"; - "MSTW2008lo68cl_nf4as5" = "0vl1q7xnr425sscbk4djqi56jbpzpi8l3z2nknfqiy3l7ykg23ng"; - "MSTW2008lo90cl" = "0af5j0s1i8yn0mjs4nb77migihw643lhd7dfl184v6wik3031yg3"; - "MSTW2008lo90cl_nf3" = "1a6kc1lgswjk800jzcqlbpwzz4rs3g6agckhnlr8cizmp9p7risk"; - "MSTW2008lo90cl_nf4" = "1bdjl58gslhw539650qwi7vbvsr22hpxpca17rkbqz9szh0ljhym"; - "MSTW2008lo90cl_nf4as5" = "1crsm7dfcs0fn1i2ng18wy23z2ap01xr2rsnafqlra0q135m6hfp"; - "MSTW2008nlo68cl" = "0pdvb5nshjjw7ddmdmj1v88m3jlk3vwfnab0pf2kf8hfx10hbv4q"; - "MSTW2008nlo68cl_asmz+68cl" = "0gwmxs0f7raxvmpn12zavzqsrp3x0a82y1vq2kf9p9fq17in55yn"; - "MSTW2008nlo68cl_asmz+68clhalf" = "1rmda4zpm6cs9kyxkhwpz38iv6g259156bmka4dc4zyfg1lcw85d"; - "MSTW2008nlo68cl_asmz-68cl" = "15mmdnd3wwlrs5pwwhfa9f88vjpgza8vwxwxpyadxsmhx9jk79hy"; - "MSTW2008nlo68cl_asmz-68clhalf" = "0dd7llc6ip6myy2yvf16riqs334f20l8wkmkksq53xngmz9qf263"; - "MSTW2008nlo68cl_nf3" = "1j82imyylvnf3x39x1mb19hhp2nbcq2lk82hf7sj72c557l3qpjk"; - "MSTW2008nlo68cl_nf4" = "08f008by768c8v3cmrsbgxpglqdj58nwwf22dmk2mbf2jq449s0n"; - "MSTW2008nlo68cl_nf4as5" = "0hrqmmnp20vpj6dpz3bvm531i0pvl06als8irqz91cknv6zsvxf9"; - "MSTW2008nlo90cl" = "1d3p4cialrngci9kn7225zcmyrr547dskzi74dfgdhbqc0256a2r"; - "MSTW2008nlo90cl_asmz+90cl" = "19cd358yqklc8bxv0mg69cq3sf6zah7di0q9ilfqbiddmw1flw3p"; - "MSTW2008nlo90cl_asmz+90clhalf" = "0ngn8f149agvmc54nrxjxqa0rifbd8a1hbcgpa443l75bmd9sqcp"; - "MSTW2008nlo90cl_asmz-90cl" = "0fnqj7ywnp9nz5733ggjwmhxpy15zs2xgxjz7ixmql5mmaz3sxb6"; - "MSTW2008nlo90cl_asmz-90clhalf" = "1jrp9q8li7a4bwhgh7q9h9zc0sdhck957zn14q9ca9kjsflyb9f5"; - "MSTW2008nlo90cl_nf3" = "02ihabrcgp474wkq4w2fshpiqdznjaxyg5vawv52yj6hxifyy5a9"; - "MSTW2008nlo90cl_nf4" = "1wrdl79qy8mimqk48705f3sd651zy130k1dmvvzwvdsjd9y8q58w"; - "MSTW2008nlo90cl_nf4as5" = "18d1pvijcyfxkipmd2v2zrkxdbhxygkcyn3p8vz0vzq5q7s1s7r2"; - "MSTW2008nlo_asmzrange" = "161364fvc8w8ggad58r1c58b0kngqa1bjpabaqi5cigmzazj3rl8"; - "MSTW2008nlo_mbrange" = "1b7z4mm3f8wjjbxb8hs8l7kclh1yfz5yffzdsch2i09c7wh79616"; - "MSTW2008nlo_mbrange_nf4" = "02s7ljzwamsha87i6nsd4kdfb9ky4k6m8xpqa1iz9wgrcy4pmw5p"; - "MSTW2008nlo_mcrange" = "1bndxfi27r8k0m4r26bfsflbbrjc4s2vp5ixy7qidkw33g6mqh96"; - "MSTW2008nlo_mcrange_fixasmz" = "10s2sfhdx5668cffwb0sbh5m54zq0inmpfnhkj0zk9ij4f5y815f"; - "MSTW2008nlo_mcrange_fixasmz_nf3" = "0zwnicbmmqbak5sw92njpmvxpjnnhwl1ggvlj8q39hn5w5kdy1kq"; - "MSTW2008nlo_mcrange_nf3" = "01mlzqwk30glr95g7n2y3yvvy7s6mkbdb5cqwl1m7k8d6m18n49g"; - "MSTW2008nnlo68cl" = "0y6lv1wkhydfnlakjrrrjapxaapa0bcbmfx0w9c4psgy156kv1fv"; - "MSTW2008nnlo68cl_asmz+68cl" = "0fhkbkshrc29kz0fc9vi2dqsg6irjm4sfw4sp0s4wkj766wg19nz"; - "MSTW2008nnlo68cl_asmz+68clhalf" = "1z0fplsv1fij4fgrz7npr34hcmc2qkf7g398bq1smvb6b2qy5jb8"; - "MSTW2008nnlo68cl_asmz-68cl" = "1qhjhdzpy67665ccwv0n3g7jlyb2vfk60cphjr0jb1adgv9fxa7q"; - "MSTW2008nnlo68cl_asmz-68clhalf" = "0rlsis3r7l32jdiq2yhx1mz7q6qlzlsrarljvrmxf0g0g2d8nr4c"; - "MSTW2008nnlo68cl_nf3" = "07nrz7afd1mcsqc3lqv9vk2phs1nfxdl63qh1bc0g7nznxwmmn97"; - "MSTW2008nnlo68cl_nf4" = "1kd62hzk2p3q56kj79bs101arp55ajlyhwwa3vq3yp37i3ynz9ds"; - "MSTW2008nnlo68cl_nf4as5" = "0x19rq5k9c97vzskqppf4k0fjahwiw2c1nb6iy5c2fq8mj1pz2gj"; - "MSTW2008nnlo90cl" = "13xqlfys37b8chinah2yqmzd0clzli06p7vjk30ha22wgwm02dq3"; - "MSTW2008nnlo90cl_asmz+90cl" = "0pd6imc3hvq7vgyv1db9y8rvpgz4ffwqv6rqzp27c7ipxg0wjyz0"; - "MSTW2008nnlo90cl_asmz+90clhalf" = "1xn52ppixjg22ybd8ggf0azb3zg5zyilqjss033g0k9crq4a6y2v"; - "MSTW2008nnlo90cl_asmz-90cl" = "10wxgh52zs0fp0bwd0b6csnz9x6mvp45gvjhk0y1dhgfwbcvw9y9"; - "MSTW2008nnlo90cl_asmz-90clhalf" = "1kmvp1yfgsx4jhsjc4drg82cq4xs6as4grwrymfkrqnvhcg86vap"; - "MSTW2008nnlo90cl_nf3" = "0vw0cmszwp49fsskacccl921za88cl5cfy0sqckgxzs4hx21x43n"; - "MSTW2008nnlo90cl_nf4" = "1b3fy8mfclgsmvpyzfs34fjry6djmkjcjppdxni1ipjyp1bcaia3"; - "MSTW2008nnlo90cl_nf4as5" = "05phi752spikwq74i0hfid7lsqi51hdvwxm520kdmbdz2pblbz4f"; - "MSTW2008nnlo_asmzrange" = "1nj68qhvlsqi7299d9rrsmq7pr6bdil4gzr6yla2cgn4wwiggdwn"; - "MSTW2008nnlo_mbrange" = "0jnmy4i593wz80lbm0r0cwdj9xw496p3in0lq8ksr4yjwz0agpbk"; - "MSTW2008nnlo_mbrange_nf4" = "0lw3p4q0ixj7plcmwqh43lfgv1i7ljar3f3k1v6f0imyvz8swfgr"; - "MSTW2008nnlo_mcrange" = "17v549iq2wn5zvxfdvq8pf5f7zvgnpa72i6gxvxzfqwkji7mv522"; - "MSTW2008nnlo_mcrange_fixasmz" = "05c8z2q2866550clx2mwb1jvhpn0agkyg82vvrswi3h4hgkvlfjx"; - "MSTW2008nnlo_mcrange_fixasmz_nf3" = "0r86xsl1wfphwdj2hhlilkwc2949m7bcn42dms14g7w45i24g6id"; - "MSTW2008nnlo_mcrange_nf3" = "1c9lsggncwghvw9mgd18h50ljrnlpp1p5r2zlzf8z3g8i4f3aaih"; - "NNFF10_KAm_lo" = "19wn44svz61lhk33kzc6id18w6qbkw4bfnwncar19phrjjp965v6"; - "NNFF10_KAm_nlo" = "191db9pj5yspiqc7598r147j9wvfc4s6cm0q805m5vmzpfg2cgr6"; - "NNFF10_KAm_nnlo" = "1hm8vhk1p31zdn72bgcyyq0w5qii1ba0cf81wjlbhwv4fadfd4sy"; - "NNFF10_KAp_lo" = "13yas11c7xxij45zrd3r6njjvx33kn9lg8i28ki0y4nw6ss21w3b"; - "NNFF10_KAp_nlo" = "1jza83klbcb3j2pcg2xhgj2imh4llb6hsfkbfj294q0isqypgzsv"; - "NNFF10_KAp_nnlo" = "0xwl34a31ajxwlgx6bhzzyf9b2xiq7bpv51p4zi6k1xihs91vwzc"; - "NNFF10_KAsum_lo" = "128cj81qp09hn99dnkm9q06wf2dr7xjq9qmwvrmdizrd8cwfa4l1"; - "NNFF10_KAsum_nlo" = "19pglfl1i5qg8sj3hg0qnhr1f66isfbrv7f901hnxniibbdjxib2"; - "NNFF10_KAsum_nnlo" = "1769ybc49a94appmiw0bbn3kkvcpw82sggxgvvda5jq9m36m9yzb"; - "NNFF10_PIm_lo" = "095xl0cs6p5z44hydfa963ylxvzqxdwwj1n8jn7n0c48rwssx357"; - "NNFF10_PIm_nlo" = "1fn8863092fn4aqacprbsdxlgz27q6pam08pccwq9ps0dwjn7cc5"; - "NNFF10_PIm_nnlo" = "0j4p50k821pphy8i6s73h3c29d7jb3bp5s4l8rl3bfb0nfx4p6hq"; - "NNFF10_PIp_lo" = "0hhw2ympx1a8d3sl953k27yzww0j2f5m9b865gv1ybb3l9ccv1i6"; - "NNFF10_PIp_nlo" = "18k3s7i1xvh8717n5cdllbb6zs8svh2bkw0k2zf4ql5ijiypvc10"; - "NNFF10_PIp_nnlo" = "16mywhpc3439dpk2c1i6gxrv9khyyg0kl4gsc41qyi3r4d7k6n2c"; - "NNFF10_PIsum_lo" = "1yh3hxfmgzgpwqidmzlc189syjbsj4vyswc4kch7yykxw4dqf6sa"; - "NNFF10_PIsum_nlo" = "12rgg0nc9rjvwfpf0y9kl1w9814a4pv4b17p46h8qm6kfyqqwjia"; - "NNFF10_PIsum_nnlo" = "19iz4q31apgm2il9478c7zmmc6kgz2wyp84qja761jvyl6z0img5"; - "NNFF10_PRm_lo" = "0c5pavhf5flx2nmld2dprgp1lsbvsrjw5mqdzvgkks7ibvq0ap5j"; - "NNFF10_PRm_nlo" = "0nfwhp9hacnm95w2qa5hvmfwaj7drc0w7lxqw1lrdp074bpd0ma3"; - "NNFF10_PRm_nnlo" = "084dz4xxmydf71vkhcrmj03jkwyj56jxvmbzm22mdh2dxmkz3l1g"; - "NNFF10_PRp_lo" = "014m0vjzrr4rbi84qxzmrym07kc4wax29fs66mfxkmrimxpb9l21"; - "NNFF10_PRp_nlo" = "0lrzw2618kgk7vsksbr1qxqc4h9lza573bz6208hwdgkmh7awasc"; - "NNFF10_PRp_nnlo" = "0bv07hh5rxvqw58jcam3piiiy19w325nrwivrifyv5wii8sybz8r"; - "NNFF10_PRsum_lo" = "1a9m77rl49wzzgdkr6x618bzcm2p50f915bbggknx5xjw550dqd1"; - "NNFF10_PRsum_nlo" = "1qambqywda7lvvkd6kx2r1g60v6lnqcamdd51396id33fvw3k45h"; - "NNFF10_PRsum_nnlo" = "1kijaxw6v1w33q6l89raz7ic59zcmd3nx5djp83lyg134a15crmw"; - "NNFF11_HadronSum_nlo" = "1n9fb71kl7y8rp1smyal28wdvdx1b410mhqkxmavnr1fs85hkh85"; - "NNPDF21_lo_as_0119_100" = "19qw2hp1yk82qgcrpx8wp2fg8wklaj6rr653m6mndhhr0aa0w80v"; - "NNPDF21_lo_as_0130_100" = "0p5cw77dg5pkhl3d0y6r3k8vhw4m467wf3gd8kp2l5vcbdwb4izv"; - "NNPDF21_lostar_as_0119_100" = "0i23axf0xl11nb2dn6p34bnm1xfisnn3a82db9dz863n60gqb5x4"; - "NNPDF21_lostar_as_0130_100" = "1aka01747071l53jx4v7rgmfj5danzjillbwincgi1b28mw78yhq"; - "NNPDF23_lo_as_0119_qed" = "02d85an11mr66yg3vi5fq4919ymbrh9h8b8qzzzm9dvfarzmbwxi"; - "NNPDF23_lo_as_0130_qed" = "0qsxxw3nds42924xqnhs56wmd8ihmrip28glj47q9r9i3kgw3lv0"; - "NNPDF23_nlo_FFN_NF4_as_0116" = "1d5wccg8l5xmdr8pvks6851zxrlgq1rk2y5dgp10k6r108059rgn"; - "NNPDF23_nlo_FFN_NF4_as_0116_mc" = "1sc13cqah6di97fmlnb6qw454jyrp0i9jv2pfxvi8ix2vzd6km00"; - "NNPDF23_nlo_FFN_NF4_as_0117" = "1gkzb46fnf9k97fgbbxljdnklffwnxmg58z01x55iklq4sn2aww3"; - "NNPDF23_nlo_FFN_NF4_as_0117_mc" = "0nc3fx9ggqybymw5kglwq3kmznc9hm28sp58gs1l4gwx3xiy0bj6"; - "NNPDF23_nlo_FFN_NF4_as_0118" = "1zlcqh0nfy8yf2cnzs0iy615nbmhpa2zh4carvifcqd4lv4azkp6"; - "NNPDF23_nlo_FFN_NF4_as_0118_mc" = "0518z8jakc9r74kzanraf2n8haminfipp2rvr1288ymhsl5bxyp0"; - "NNPDF23_nlo_FFN_NF4_as_0119" = "1k5mcql2411020m6vq26ck8ig3q01j79ndjgci2biq743m8nlvm2"; - "NNPDF23_nlo_FFN_NF4_as_0119_mc" = "06yv9mwgvhag5442581r7by3nsxcy7c76llgaalphbzszqr2vy0p"; - "NNPDF23_nlo_FFN_NF4_as_0120" = "1m97g47p44vq3izjji6agwmj2fwdvgddzy8w40mqqbr9fk19lbyi"; - "NNPDF23_nlo_FFN_NF4_as_0120_mc" = "0bjllckv61jc1y6f8c1gqdh36r15glqn8fqp99q0kckaxyszy5vw"; - "NNPDF23_nlo_FFN_NF5_as_0116" = "0x4kjj791hkwng4l5dvch8z0ig1nkliirlz9mkv02g54qrilnkmy"; - "NNPDF23_nlo_FFN_NF5_as_0116_mc" = "055clf0m8l8gnby2lgwh4wkyqciskwp54y34vb1kwfbhdf71zmnj"; - "NNPDF23_nlo_FFN_NF5_as_0117" = "1cplvrizlsjcixsjzlm2drssbjsrzj9bvq0k5mnv79r3p1xdp997"; - "NNPDF23_nlo_FFN_NF5_as_0117_mc" = "17nic3kw991dbrhyjyxpk0zzv8rjh0r0whd6nl8v6wsf5q5h0ny2"; - "NNPDF23_nlo_FFN_NF5_as_0118" = "07fgr71x2zk2ywcbnw0ikv0p9kzsmd83kdidfs49vm7azcbm0qfw"; - "NNPDF23_nlo_FFN_NF5_as_0118_mc" = "0s365gsidichyj9x5926q1gm0x1bp52chv7fkpirflrrsywf0lc3"; - "NNPDF23_nlo_FFN_NF5_as_0119" = "1qspxbwswz7ssqj2rx2jdg0bkj8prawwshvjd26ifz9i0l9qnqc0"; - "NNPDF23_nlo_FFN_NF5_as_0119_mc" = "0aqyhrcrzs3kqhj1hndilpibvdwfw9qhg1x0cypx97h16n37j46x"; - "NNPDF23_nlo_FFN_NF5_as_0120" = "1k9savpyg2iqr1ab4i5y7q1qhd8zxq413040h2v46jl8mp7x6bjn"; - "NNPDF23_nlo_FFN_NF5_as_0120_mc" = "01g7mh7v62s47cwdf6ws6j37gxl4mrb26ivdzzwmhy6ydiw8ka53"; - "NNPDF23_nlo_as_0114" = "0mmq32kddspgpacx2qj086das9z2bxh3l37qvp9yf84gqzjj7mml"; - "NNPDF23_nlo_as_0115" = "0jn1gv137d2x3vxq7ny0qc0hnfmcd4hs3cxkyn7j26w7p59q81x7"; - "NNPDF23_nlo_as_0116" = "1mnq360acd5vfwz9z8fzynldchkqrfiqhsxvi3s9a263h3p44bsa"; - "NNPDF23_nlo_as_0116_mc" = "0ngw2hls52bax6dmis3nfa2ix8q8nh2d9mwjax4cjdkmmf7rdn2g"; - "NNPDF23_nlo_as_0117" = "01wkq68b8zl3mznzvc4p7p9b4ik2bnqgjq97mw2287i448mnj9jn"; - "NNPDF23_nlo_as_0117_mc" = "1s2g55240gh9j32ach9rban0iw4hjmw5haj1c21wgyh4nqiqlfwr"; - "NNPDF23_nlo_as_0117_qed" = "1l2rbxn9fw72nmhqazfkh568q4df0q2jp0pn0fj368wdpf36fk0b"; - "NNPDF23_nlo_as_0117_qed_neutron" = "17rpz4bdp3fxvafiz32aawxw64prkhqwqpnfnbqsigcslm18bwnc"; - "NNPDF23_nlo_as_0118" = "01kax3g4d8nd6n1gip70d02kl3kvbqib93b99xgwc1f0np85p3r0"; - "NNPDF23_nlo_as_0118_mc" = "0qhs7r4zzw68grrmfh7qdad49w4y4mvf55qnp86piri5vi8lklwk"; - "NNPDF23_nlo_as_0118_qed" = "10xfv8nkg2jjy3yg9m9gakz6lixdvmahdy1z12znqyr1br57bdhy"; - "NNPDF23_nlo_as_0118_qed_neutron" = "1zffxfykx2v3dniypsvyyqbz5pb4dcww653amaxv96hplw3fvr0h"; - "NNPDF23_nlo_as_0119" = "1v24iwddahxy6sd43bxv6ywf8n7302qkwl9hv7d074q1d932kgr1"; - "NNPDF23_nlo_as_0119_mc" = "0l95fgr5bwhsh0h3qqlnx9czkgmrf5y084zlzk3qhix3ldh8zbp4"; - "NNPDF23_nlo_as_0119_qed" = "0rayscazcacy89lzg0ynpwrl9g4pnjwwp0l0vwc3gjz9cwznmwsk"; - "NNPDF23_nlo_as_0119_qed_mc" = "1cc3candpavcfbv681zpg8gmwbh3g14vqkhs2s6v7rr9xhx6zqv1"; - "NNPDF23_nlo_as_0119_qed_neutron" = "12h4x97yglcklrvwh937xa5bgqahq949a5wm3nyjbvrfsw9n330i"; - "NNPDF23_nlo_as_0120" = "0f8lwydw45vy7c0mqmz60hpc0b40czx0gx35liyrhcbjvj9129m7"; - "NNPDF23_nlo_as_0120_mc" = "0kqiizf0c0mbdavnv7ivk89kga84j7p7xprqi10589ggplchx8ag"; - "NNPDF23_nlo_as_0121" = "17603srm35158sdwrqijyxm614splx7k6bjyzphgvznnkwpgi0i3"; - "NNPDF23_nlo_as_0122" = "0c16498ngx436k9mb8fwkhhvcbdyjd4m0jh54v2n1dl354jz60sm"; - "NNPDF23_nlo_as_0123" = "1j6d7k8d04gfx532iipd4vzm0nldbvy86pg8asgv4xrh80c1zslc"; - "NNPDF23_nlo_as_0124" = "0dwv41kc9qsvvp22gvxi56gj13dnklgfp4ndrm0475q6gvfz25ak"; - "NNPDF23_nlo_collider_as_0116" = "1hl7xw8jz0gijxh9cjkxv1rb1xncb1622ghf6wnsaarlqr4947ky"; - "NNPDF23_nlo_collider_as_0117" = "08krhmjbgza9f4mbq7cdj9g7hh260aaniqqi5awbgp7idbn3nccj"; - "NNPDF23_nlo_collider_as_0118" = "17645h9l8z8nk7pdaxdhvcfmcvi8ib8yylhiijkkw9yrywb5pakm"; - "NNPDF23_nlo_collider_as_0119" = "0csf74lpxgzg48v6962falxd8n2nc9xdrqnxxwadqqyrnrfs06dw"; - "NNPDF23_nlo_collider_as_0120" = "17xqx8hnwy7a67ah0ds8m3nv3cbq20vri83nlwahwfsbig7w505x"; - "NNPDF23_nlo_noLHC_as_0116" = "02nhh7n2qzx3ak7ih2d3vw3a4dffxbbpv9wrh2yhz30zbrqqlzv2"; - "NNPDF23_nlo_noLHC_as_0117" = "14j8hx346krwbi2fyyk77k60d7dlk2xlsc6zd543y03jdpk4ahlx"; - "NNPDF23_nlo_noLHC_as_0118" = "0vwi6h1fkwjg28p2f3br1g601i8ca4dpfjs9vxg80kjzkif6k310"; - "NNPDF23_nlo_noLHC_as_0119" = "02l15h62gn0njnj459pkp3k1nhiaivlknmbxb3giqpg6wmm2m9y1"; - "NNPDF23_nlo_noLHC_as_0120" = "13lxmwmywg7wrwhgp0cb41b42479fgfa1bz3aqkbrnf6gi6pviln"; - "NNPDF23_nnlo_FFN_NF4_as_0116" = "0j4ng2vl955vnq40zv5v9sb0wk8qari61v7995p2l0sxz268sz50"; - "NNPDF23_nnlo_FFN_NF4_as_0117" = "1wjqlv6mbl2lgvwr5av47amrs8gnqkpkxzq91jvpaxkya3bmglc3"; - "NNPDF23_nnlo_FFN_NF4_as_0118" = "113s8lxrmif79c6f11pnk5jz7q4lq7108gcfx84nanpksr9dmi6m"; - "NNPDF23_nnlo_FFN_NF4_as_0119" = "1688qacmp9kl50q1vzffcprf9ydbi2bb2brc68jvid5f7bjkyfmw"; - "NNPDF23_nnlo_FFN_NF4_as_0120" = "1i3cjnz5zgk8jw5jcrqy6kxx1i5v2a2lgy2fdck3j19cvn0iqqr9"; - "NNPDF23_nnlo_FFN_NF5_as_0116" = "0v6ap405v9zapbi5sqldvs5lyhz5wsh4cxl8ssxj0l4789qm24hb"; - "NNPDF23_nnlo_FFN_NF5_as_0117" = "153f95cqd0hkxfy9p81mf2dfdp13h3fhhp0qyxmiknhqm10ykdxq"; - "NNPDF23_nnlo_FFN_NF5_as_0118" = "0fch9i9qj1k8h3sdwfdcd75idi0bv2q7a338dvj4697xqpxf2mj4"; - "NNPDF23_nnlo_FFN_NF5_as_0119" = "03r72mrbvy9jkkbmgvp2776xxgjx0jyxsv4bvpxmhscpym9mjvq7"; - "NNPDF23_nnlo_FFN_NF5_as_0120" = "0rsflim77kdp849pg6f87rq6j0wirj4gayvrnvi4xvfjlk1mxkll"; - "NNPDF23_nnlo_as_0114" = "1p32hw48zwmvj9i5iyg9pqhf11zwf7m7g5q8prfj8825dvsgql94"; - "NNPDF23_nnlo_as_0115" = "0smmwd7xla73sb3bci46grj1kfd751pybkf7fz3w3qdkp5jjglqp"; - "NNPDF23_nnlo_as_0116" = "14blxcfb2jbdgwh73f2spvqxy5dhn5v6ygwi346dzwswipwbixir"; - "NNPDF23_nnlo_as_0117" = "0di0a5dkskalllnh90ngfb046z5hm9ihjra1r1ck06v9ryam2w9c"; - "NNPDF23_nnlo_as_0117_qed" = "0dvzz7ac45j4m655k0i3ycy6xwfm6y6801qsb5bgp1kdv7g2pj3z"; - "NNPDF23_nnlo_as_0117_qed_neutron" = "0v05yw5nc1r7vh8sjag4fmdklkn4jmcdpsmgvwm7sblgfc6gnssm"; - "NNPDF23_nnlo_as_0118" = "14p9y1ryc1j26gl01sn60pmrfpnkm81bhark2g98xz8dmfmjp7iq"; - "NNPDF23_nnlo_as_0118_qed" = "15mcq4q20ijmf06pcc626jlk22fm8c473p4i80bmi27h5x2pl56i"; - "NNPDF23_nnlo_as_0118_qed_neutron" = "15vsjjc1i2x6lb0603h6knj68si8cvxml2xk97pw343qn3p8h4ka"; - "NNPDF23_nnlo_as_0119" = "1qzap9zlpwyyshh8hc0gm82y9rl9hpy232j03gd6vwmcw5pgm2d2"; - "NNPDF23_nnlo_as_0119_qed" = "1cqvdmq0hm9rh6749bn08i6c94gshpjafmwv8siizdlm8v9af442"; - "NNPDF23_nnlo_as_0119_qed_mc" = "0a77i8grscxwnybgikik94ldiddrif3yy6d4bqb6x1aj4hr9i5ag"; - "NNPDF23_nnlo_as_0119_qed_neutron" = "182jqm5019n94givs4rwblpz02hp90mbizp0b5svrxf21zdyrmbx"; - "NNPDF23_nnlo_as_0120" = "1v8ykgxnqbvfra57xpamhgbcjvj89dndhk62pmji004gvqpmwi61"; - "NNPDF23_nnlo_as_0121" = "1fv1m86ya7zi77ajd8r1nls2zcr7n6s3wqrdiwq5ikxidqxc6cgy"; - "NNPDF23_nnlo_as_0122" = "0bn6bmvs8w9qsqcpq8y8a7w64xbkvrqwiikm5shjprwqy9xbspyf"; - "NNPDF23_nnlo_as_0123" = "0w7sqyyf98ymxpgqfh8gr9g1pdwr2pw12zc8gqykn5nkjbbmijgy"; - "NNPDF23_nnlo_as_0124" = "1hilgda0gqyj81a5h0mxrl5g9ahlm1n6mhd3ajkicxz2fvxm2n1l"; - "NNPDF23_nnlo_collider_as_0116" = "07m2jwjwzjc4bdsx9dkrp41qn04f9z3k2m6n4q308hwdq9lmcm99"; - "NNPDF23_nnlo_collider_as_0117" = "0i4kggkkkp407r33a2nsdy329zxpx8h6dq0h0wwpvq1kmyrjk6i4"; - "NNPDF23_nnlo_collider_as_0118" = "027wlw7lk04grz5qavyymj21ik4zr9fy9yk2kwjc9gx2ycp3sj2z"; - "NNPDF23_nnlo_collider_as_0119" = "0jq3q3sh1p8rn1qap77794v9hh3j0b7pmfl24wxvpc4dly4al0vs"; - "NNPDF23_nnlo_collider_as_0120" = "1s0jic8amasmxczdflbbhn6071nx8cxr3ynfrinllp36d92pmgsx"; - "NNPDF23_nnlo_noLHC_as_0116" = "0jzn78p2gygsqip50jfnnrmwl7issbp4vzpf71cbvj39ihsmavy0"; - "NNPDF23_nnlo_noLHC_as_0117" = "0zns2yy50c0bm91y8xaafmzhgx1wafvmv39cykw7xwsnkgclh487"; - "NNPDF23_nnlo_noLHC_as_0118" = "0v5bdc8d9w5g606h42rpn6zw31y1a5nk9akgfd1lyrhilvh7ayck"; - "NNPDF23_nnlo_noLHC_as_0119" = "1zacfd5jc5wvcig0g8g4jkr77zcxvzcvppa4ci81c1n8d0whnr5s"; - "NNPDF23_nnlo_noLHC_as_0120" = "1lx7m8ajwvhkzxck2ngxng1g90fpay5r5iwdnk2w7xgp1hb1ayc3"; - "NNPDF30_lo_as_0118" = "12adhizxskpjzdr6inc2hi6bxrs8ns3bnyihz09hfh9q53d5ayik"; - "NNPDF30_lo_as_0118_nf_3" = "1gjaiwqdhlswf1qmw39xr6g0w4bnnbinfpwl9c37jnggk6dxwdjz"; - "NNPDF30_lo_as_0118_nf_4" = "121xn280f5xx04q0rr4ina9iqzbc1v8cay78km836kqvgb3pcpyx"; - "NNPDF30_lo_as_0118_nf_6" = "1s77g0bf1qjb9rn1svnpfx10laxx87lw660ark9fhhx14zgybs3i"; - "NNPDF30_lo_as_0130" = "0nvpwbmdzm8fn4wlb2rhzar71kk4myfddpqsqhd7wb1fqxkj5b7y"; - "NNPDF30_lo_as_0130_nf_3" = "10diiahiy3yk6y7m1r4bd6nr1kf4mnccgj5qyq2lw49highn4s8k"; - "NNPDF30_lo_as_0130_nf_4" = "0j3b3rj5pr2ws3yaq6h74hhsjy7lv3d2x5nryc55q22xfkgf451i"; - "NNPDF30_lo_as_0130_nf_6" = "0w7k4a9ir4xvfh3v6dba70rhwkkq7qk16z178wld26zl6a7gw1hk"; - "NNPDF30_nlo_as_0115" = "15g9alyc317qydqy3g7sqlh6pc4pxn3xmhmzv9lcw2ghg3gn35fi"; - "NNPDF30_nlo_as_0115_nf_3" = "05b5xl89jvk6bgp86yl5hwdh3x8211czdsbianqkfix35rqrvlx3"; - "NNPDF30_nlo_as_0115_nf_4" = "02p9lhvricjl5r79pkcm2fv14p9gw1d2qizka4w254ang3i1hcm0"; - "NNPDF30_nlo_as_0115_nf_6" = "1iabf2qszv1270ac2sr2bqs7rb3gm58fj388saqbhnra4p2kv9fw"; - "NNPDF30_nlo_as_0117" = "01my1m7vx7yax8ldnjp7s1mz1w3x3m0h1gdd8mamfrvphaghwp4x"; - "NNPDF30_nlo_as_0117_atlas" = "0vjfh6kihsypvkpg3fwqf96kd2ldq0azcl72ia6w1nr52rsqc27l"; - "NNPDF30_nlo_as_0117_cms" = "1sbaq99731ihrkp9a2fj6lxj9dr2c9j4vp2335249nrkinfpf4mq"; - "NNPDF30_nlo_as_0117_cons" = "14qwjsa633v3h0sbizmhifrwdm7fmglyk608lq4ims8y7nn491nq"; - "NNPDF30_nlo_as_0117_hera" = "05gs9ril5vkm7xrnz5pvjd6pk8ivgk0bl4bh45gx658fgg2snhiy"; - "NNPDF30_nlo_as_0117_nf_3" = "0jc8p8h9pny0l7j3hv55iwaw684ymj0hl62d6bxlvw8sqvhxcqyl"; - "NNPDF30_nlo_as_0117_nf_4" = "0a37b46ach3m0gqniwk79qk963w0m96dknda2rhp1glpg5xdxl0z"; - "NNPDF30_nlo_as_0117_nf_6" = "1hjj6k5g2fia7xq5piy0dhsqs9lwriasmppjwil9wxnwklnwmr2m"; - "NNPDF30_nlo_as_0117_nojet" = "0z3s8ixmq2l4znv2dn0dcz9rq5f9b3jgnlwmvjzcab3wvj1za687"; - "NNPDF30_nlo_as_0117_nolhc" = "1x9nbnxm72wzaky4rvlrq1kmqs86ypphqwvsng33n0zdd9yr82pr"; - "NNPDF30_nlo_as_0118" = "0b51qb2i3h9d7hrviarfszwljsy88m8ibzgz7dd5gn88k9kardrm"; - "NNPDF30_nlo_as_0118_1000" = "17yla3w0rqy1a5hxq3bfq94ddda2qv6zzj76lfrm4zahl6m02kdy"; - "NNPDF30_nlo_as_0118_atlas" = "034h2wgakbm3mx70034nwb44ii38rca7xv3az3fhcnjbpg9vnf0p"; - "NNPDF30_nlo_as_0118_cms" = "08g9315fpc4khwfjf76vvyqa9nannvwq0bpc42f9f7yc0pck71qa"; - "NNPDF30_nlo_as_0118_cons" = "1lw0fhy9gwk3zr7vq7qh9p6zprbyd4faln3npnxs2snncic1mnz6"; - "NNPDF30_nlo_as_0118_hera" = "1833gd9h3gg75hblxf5qh5hp61k7n9vavb91ll9lbqmcbfr34aas"; - "NNPDF30_nlo_as_0118_hera_1000" = "0lljb96d3q25yw3fz3cbk2in90q6srpc4alkz95nyrvgp25xgbgy"; - "NNPDF30_nlo_as_0118_hessian" = "0h8d2zc02ccr1rmlsf4xd5a41irbs9q9wx68caj2xy0i7qr8rsmp"; - "NNPDF30_nlo_as_0118_mc" = "12nnyzh2f6mv4gq4x4b8nlqx34lbj5y2y60zivfdbcpyg2spj5y8"; - "NNPDF30_nlo_as_0118_nf_3" = "10f5md8bhf44n5x6r7ln8c58a9ylm4mfgxg30vd0d8mvjc3zpsng"; - "NNPDF30_nlo_as_0118_nf_4" = "0q14zqkzqy2hgh8wli5db7dsqgsljgbc717da661wj8kqa23w4r4"; - "NNPDF30_nlo_as_0118_nf_6" = "08ajfn1r27hdarff464j2gpi7ffjjxs6pwzh3vil8lpjij5y7d4l"; - "NNPDF30_nlo_as_0118_nojet" = "0zzzk72n7nq1mcaalbv7mpfpb9kh095j0zazbzfjf2k6r3p0v082"; - "NNPDF30_nlo_as_0118_nolhc" = "1p7iac75znr1li8qg9xf1my37i70flhvjkfjmrb5b0h3hk9agb1r"; - "NNPDF30_nlo_as_0118_nolhc_1000" = "04mgjfq1ncy90gqljfdzw1iwzav5infkfv7zj2rid088n3qfs91p"; - "NNPDF30_nlo_as_0119" = "0p0kgw17c97p99zy3ffr6g7pphhc8ccdhcq4iip5drqm4hc6nb58"; - "NNPDF30_nlo_as_0119_atlas" = "1hpx2jm4y6kz9b4j42ags98j115hd2s41km670979z9zxmj2qm5q"; - "NNPDF30_nlo_as_0119_cms" = "1j0135mxdiyn22iqrmg0d44w2w7ql1cdacprxgdz4jfb0ppn68rx"; - "NNPDF30_nlo_as_0119_cons" = "00qvhq9ypqv62zvlg32k3x5gibl5jh0b78hyrpvxf1l3y2b77nw1"; - "NNPDF30_nlo_as_0119_hera" = "008f4m8p9gi4w61mgjiqqpw346rgqxaayc1rncy2fggl4gs64yi1"; - "NNPDF30_nlo_as_0119_nf_3" = "1bh0sl8pjy5n90j5dz9c80n3vy21hdsv8vxwbqkq0b2lkv8gzw5g"; - "NNPDF30_nlo_as_0119_nf_4" = "0swgnmbxz0g3ziib1992s0454jfsdi7l0x3lrvs5qzzjk6rg6qgd"; - "NNPDF30_nlo_as_0119_nf_6" = "001awj8h76wybmxj9vvkxgqixzak4zbhsvjmj2lscb2v5qq3y68r"; - "NNPDF30_nlo_as_0119_nojet" = "1x961nmad1rxmf4yzbz2drpi5hfac2ag1bs1jbvvlw3p04xr2c38"; - "NNPDF30_nlo_as_0119_nolhc" = "1yx6f4n577zqwhp0i440r6zk06702jg4kkib9nmgws3jl5f28big"; - "NNPDF30_nlo_as_0121" = "10k01z1amzp3jmfvfb2snrm8d04vr31kly1m30pw4fv0qn78idlw"; - "NNPDF30_nlo_as_0121_nf_3" = "1gb40ycnf42fkrbdwfhb8wp56nmzxyi7fzbqgvlkby7pn86m2f7m"; - "NNPDF30_nlo_as_0121_nf_4" = "18ywp6b9f83rxmh7gfn648wslvvf5g4ffm83rradp308smr1sv6p"; - "NNPDF30_nlo_as_0121_nf_6" = "12dps7n3glrzwb8vsfghwbvnh1yyxvjnvqfilbrrcy0dm3sams7b"; - "NNPDF30_nlo_nf_4_pdfas" = "0hrx872m52bb894c32jrvlvm9lcpy3yllj5ps52nmywqd8n1simj"; - "NNPDF30_nlo_nf_5_pdfas" = "0q25jxvwpz8inkax0j2zq9pj8swqfn4jmkhs4ibkl6xs78bhjfb8"; - "NNPDF30_nnlo_as_0115" = "03apmzw7krj77zdyl6sxwqg5fyv3vicp8iax445qdx8ld9kv225w"; - "NNPDF30_nnlo_as_0115_nf_3" = "08y1gjzkpnjn6mn247n7a9ya8z6pml3602p08rjha4ljggxhyffq"; - "NNPDF30_nnlo_as_0115_nf_4" = "19mjfk1rib9dxbsn0473ggi6akwv1zs9y3q9nzjg47mdjqlspb2q"; - "NNPDF30_nnlo_as_0115_nf_6" = "1zcjjbjwjgbkrhgh0kira7wzwmy5vvi1n15wycg33yk09m06db6b"; - "NNPDF30_nnlo_as_0117" = "1225gj4ihmphnfav2h38rz17lj1dyi9j1lazqlwww8vizl8933bz"; - "NNPDF30_nnlo_as_0117_atlas" = "0i9nc7q1cwl8cxxaj1xaz28wmj09q5bjmh19p1fcbcln7hklvj5x"; - "NNPDF30_nnlo_as_0117_cms" = "01ffhsw191nrr58x6wnjizx7bbijkknicvgk73pjbwyr67gfj581"; - "NNPDF30_nnlo_as_0117_cons" = "1blfi0p231r5j34wspk192fmbv34gbvx3bkisjh7wxpiab80qdws"; - "NNPDF30_nnlo_as_0117_hera" = "0ds02aj1q6y4dndfk9l9fyxci0dhpwr7jx1jq1qb9g5bb7bbhzz1"; - "NNPDF30_nnlo_as_0117_nf_3" = "087rz8bz3j2h7yk7rknlqz3rpbczgx2r2zdag8pjccdqi9jnk9pg"; - "NNPDF30_nnlo_as_0117_nf_4" = "1w44bwx6m6g8r990vl6f505bgf3v583mi19r0nfh2pahx2k2djaw"; - "NNPDF30_nnlo_as_0117_nf_6" = "1l7gwbsl2haqaj6hqsnnqwrnxrkdv1h63qbs7iwfdq6474ndzwsf"; - "NNPDF30_nnlo_as_0117_nojet" = "1nmv44arab9gfhs02jf4zijdb0644pvdmi6k809bxbfhir9sry8v"; - "NNPDF30_nnlo_as_0117_nolhc" = "0zn2b05jv9da7394in14mswvma48y26lvpw7rwh7wmyw323rxpfv"; - "NNPDF30_nnlo_as_0118" = "09xxi0vq90n9vfzq72c0mbf4yz4zif3kl6xwcjdb8r620ihwrnfw"; - "NNPDF30_nnlo_as_0118_1000" = "1iy5inrsfpn70w65hy42pmz0630pbrgg4l48qgsamcjgqdhd3n84"; - "NNPDF30_nnlo_as_0118_atlas" = "013jm6f2hnmzc2di7spf6zp31fwhm6c9sddwql36hww63w8sys71"; - "NNPDF30_nnlo_as_0118_cms" = "1w0ax68rg5877s35zlg13c451fcz2rij4adzwhz4yf4skkbgflng"; - "NNPDF30_nnlo_as_0118_cons" = "1qniswwj6cmcs7bm4n11jx2disqcwszl08cb7im824nvrcjka2pg"; - "NNPDF30_nnlo_as_0118_hera" = "05j5yrra93dxh1nah19hszd0q3pj4zfica8a7vm5akbfn02rccj6"; - "NNPDF30_nnlo_as_0118_hera_1000" = "0ssiw9fk5fqwg77rbycrxrclldws35n6gj4a4sj6d9yc87vz1g7z"; - "NNPDF30_nnlo_as_0118_hessian" = "1hb32bamwlx5il8g2sf5gy6xjr7r4rky7xgvdhf5ndq7v3n1ncx1"; - "NNPDF30_nnlo_as_0118_mc" = "1gxl4c5z2vh382y8l2kpr8vy4fqvbxvrw6xjc6dp229ak89cd6c2"; - "NNPDF30_nnlo_as_0118_nf_3" = "0iccjcds9j9pp8s3mwrshhzl5anklax4rgcwm5im90hipj450rgj"; - "NNPDF30_nnlo_as_0118_nf_4" = "002r0179jsl0l43psvw3hd1drg9fcrlzw57sbyndlswvq4zkyzyc"; - "NNPDF30_nnlo_as_0118_nf_6" = "1mwh2dxymayxa2khxjfxqmbhaj85jdnz548wmq6fyrxr63cfmw07"; - "NNPDF30_nnlo_as_0118_nojet" = "0nly14fxfww78qihrd8b6wk3da24x5sxkb13h8l2cgdxkq90fxbd"; - "NNPDF30_nnlo_as_0118_nolhc" = "11yvr5h66v37376d5p2m2g8fajdycv9baqq6mjfphf4a2abrl7m5"; - "NNPDF30_nnlo_as_0118_nolhc_1000" = "1bi0mxs6v1izlbvich55vi7qab72v1sizd4wj13787w47ffqm89p"; - "NNPDF30_nnlo_as_0119" = "11bvbqqjbyz0vjd4kh5qyd0a4rb62l103n10d1cyffgdfxxsk8f9"; - "NNPDF30_nnlo_as_0119_atlas" = "1fm46crfparx2swpxnyscpwqgicxb4skhclnc5xaijcpzraflzp7"; - "NNPDF30_nnlo_as_0119_cms" = "0i2d4wq7bsbfp8hqdr88nbii980zhfmpg6758czz7swd5yv8076a"; - "NNPDF30_nnlo_as_0119_cons" = "0v54zyz410rg3wcdw44japzynzvvrbjrspk91d0129rdv2xz51cg"; - "NNPDF30_nnlo_as_0119_hera" = "09w3krirq117cnhfkxlb8pld3xb5g2r3nhgc11v3ksavq746jhvk"; - "NNPDF30_nnlo_as_0119_nf_3" = "1k00h1c0lv6884lb02qmqki7sfmxkqpj88fkvf057frk120f59ah"; - "NNPDF30_nnlo_as_0119_nf_4" = "0pqjvaw2ad3g9zzjdyhh72580jrj4p8hxlvy9h6q9hhpwdihnnmh"; - "NNPDF30_nnlo_as_0119_nf_6" = "096fc9958s3z559knxqccwj3vylxviq2g58rwirj3qdjvy96y2cc"; - "NNPDF30_nnlo_as_0119_nojet" = "0l5crj00jm2vxgyr5nhs6h1n64xnxwpanrsjk8f8qfis37s68ar7"; - "NNPDF30_nnlo_as_0119_nolhc" = "1nl4gkjjz3kpq1sbzqk2d0d50vmb3ks7j5z14hqf9dib2xr39jl1"; - "NNPDF30_nnlo_as_0121" = "1c0ddbjskxw4rq1p8sp63vayxkvcnls062qp16wvrrbw7zkj1jaa"; - "NNPDF30_nnlo_as_0121_nf_3" = "1sj9g0wg6x2cvwp45i726dcs44hpqjiqa011xzindnjh8cq7m6xn"; - "NNPDF30_nnlo_as_0121_nf_4" = "1j4khzpw52vc26n7a95xg1wyqz720fnz2kbb8l9a5bsbmxmaa7xv"; - "NNPDF30_nnlo_as_0121_nf_6" = "1kln7zjgl0hwl621wnhhsih0m8f9ir2i8ligfg2s0qp8s3787lrg"; - "NNPDF30_nnlo_nf_4_pdfas" = "0s460v9712ahz09fhzhlnsnkl9arsy3l82g1z6xjz4la8fwkr9wq"; - "NNPDF30_nnlo_nf_5_pdfas" = "1vjfm9j39m4389b0r51axlbzdbkpk2vbs3vks3yqcr3hr09g9myk"; - "NNPDF31_lo_as_0118" = "1jq8ad68kym717qinwdldvrjnry9sfsfq7lvfv6ipm1sdzixqm96"; - "NNPDF31_lo_as_0130" = "1lg49cbg43yrpb7fgqfk0d55m28rrw781mks3zn9m24fv0hiyzqp"; - "NNPDF31_lo_pch_as_0118" = "0xm3fyvrm77hd2layrfwc74vncc470gvf7hx8nzd2sw3ai1g9h7x"; - "NNPDF31_lo_pch_as_0130" = "18fip94c0ywzj543qq154z2wnllbn8jw61nx6l8v9wmg2sdzi6zi"; - "NNPDF31_nlo_as_0116" = "0i6bpa2wf52vsc6x5nlsmncal1ghqpsyz7pya2a2zg0k7z6dfcsp"; - "NNPDF31_nlo_as_0118" = "0vwbgaxs5gj5cnyncmc7m3650pd6bplwdga3fnyy1vrrh3mpsngh"; - "NNPDF31_nlo_as_0118_1000" = "0ql0phs563ck7bx7cm5x242icfb2jrlsxhsv80m0hxyr3fhyc06h"; - "NNPDF31_nlo_as_0118_C1p6" = "0nn6krh6vk8rxiwhpnn3nbxian8hw8d1vq31ywh9560hbi3vpcrl"; - "NNPDF31_nlo_as_0118_hessian" = "10v2ayms2mhm9zi7k0fw9rshawc7njdlbjs8rfg5hiqn1adss4w3"; - "NNPDF31_nlo_as_0118_luxqed" = "19fdqxfmx8kzcgq13dk4k1nhkgqpnm5xgahp13hwz1i2vcp6xq87"; - "NNPDF31_nlo_as_0118_mc" = "1yw21cs6p85ij8lm9k0cvlm651a3x9f73f23ysxjgh1r5kqnhz9y"; - "NNPDF31_nlo_as_0118_nf_4" = "0qywlyd34yqb2r8ch9wjimyfi1jr3rdhxliwrmns0558hbd47a3z"; - "NNPDF31_nlo_as_0118_nf_6" = "1pb22z2s0ir130dk5pkxwyid37i6mf8jpr7k7nlfi45gl9zy5ldd"; - "NNPDF31_nlo_as_0120" = "1b5wsab66karm1ay5vxpjw21g2ywhnzqnlahxnvnaf80izha35hl"; - "NNPDF31_nlo_hessian_pdfas" = "0sxka18qp99gjj9abml2ba4877zavijmjfzg6m0qczx9m8v9m3xg"; - "NNPDF31_nlo_pch_as_0116" = "1wqpq2qj5czvcj754nd6c7rrss8skjx58vp2gj2bc5n95jv1qazn"; - "NNPDF31_nlo_pch_as_0118" = "113xpp3xvpfpivlj6p7av4czfbfnh6bk2kd4d2635ddvy0clqkpf"; - "NNPDF31_nlo_pch_as_0118_1000" = "1sbjqkwq7iy7fnk3r9ga1rzadzy8x3ld933vcih87is09bzg5rfl"; - "NNPDF31_nlo_pch_as_0118_hessian" = "0xmz2hc3n8alhf210axv3amf7klhbyl1dd1z2yyx6c3pcvcrf80m"; - "NNPDF31_nlo_pch_as_0118_mc" = "1w1jifp5f7ypf5xqdw1mkx1d6shknryhqzk8rk8naf37bms68mfn"; - "NNPDF31_nlo_pch_as_0118_nf_3" = "0m7rq7k8x6bsakkw3kmcicq04c39flrw1axv72dqaf9xci9w3pii"; - "NNPDF31_nlo_pch_as_0118_nf_4" = "0k77chw866shjkc0ml6kb4az75sdcvdd897r8d56jl72d2lkxp3m"; - "NNPDF31_nlo_pch_as_0118_nf_6" = "0bdc60dxj7jmqacbbaxp2m9qzg82r6pgn7h9pi2k15d07qm6fc4d"; - "NNPDF31_nlo_pch_as_0120" = "15s1b5w52c3q1nfzckdxmdwrnxw08pprmphc1p33am9v7cwwq2jk"; - "NNPDF31_nlo_pch_hessian_pdfas" = "0qdswml17bg68y67yw2zbwwp233nxpd1qpc23rqjwyzk2r7qk9bg"; - "NNPDF31_nlo_pch_pdfas" = "196pcdwsi5p9g88g1c8958qkdj6qmzvl7rsg3j8zll6274m42s4c"; - "NNPDF31_nlo_pdfas" = "1as7bkp56pwpn2vinxdnhzlnvnxx5ng0mlpmwzz5n7gsinyaz1x9"; - "NNPDF31_nnlo_as_0108" = "03kg0i43wxf794c4xhvismks6c7nw9hq9ihn58sz628lqcjmsccq"; - "NNPDF31_nnlo_as_0110" = "04a5gf6nyd58h9sad8zv46vmb074dx7j19r23lbc9w1di23sk104"; - "NNPDF31_nnlo_as_0112" = "1xkjjm49nlm72f4l3ynrm4g2ayzask22saaf6p1p61lx0jv1hjyd"; - "NNPDF31_nnlo_as_0114" = "1j4q47qscyw52swmnn0a3lr0avfsjvy20ca50xfhjsvla6wd9lpg"; - "NNPDF31_nnlo_as_0116" = "1k2d4jzg5jfs6f2mscpvalmh7i5fypx98lnb5wjycprlwd3nr3i9"; - "NNPDF31_nnlo_as_0117" = "0b6d1xlq4qwjalvrc7ppavw44w5zf0fn3rbsvh3k4qy9r19wk5fb"; - "NNPDF31_nnlo_as_0118" = "1bw2ksmxdfbwdcimc0ld87hanbqy514sridrcarqwgqh9yv5n0qp"; - "NNPDF31_nnlo_as_0118_1000" = "026d0xygh046y10jxsfc91hr4qxgark12m393r0afip69dzdsrx0"; - "NNPDF31_nnlo_as_0118_CMSW1" = "0vqjyziilfzi0gz3a2rv0i6hk3ri3krc2zcdjwfa61z1mg5syi4a"; - "NNPDF31_nnlo_as_0118_CMSW1_hessian_100" = "1jc8k64pj1mfcw8v9qq9v8m222d09bgfkla7viqzzzbdhy5f6yy1"; - "NNPDF31_nnlo_as_0118_CMSW2" = "14acp7w3sx5v4ly5wa32vpsk8xw2rh8g5gl7x3f72c0s5jcs4n81"; - "NNPDF31_nnlo_as_0118_CMSW2_hessian_100" = "0ykaw8x0i6k8vlbms2inm9zm860apsi5mf4wkxha416v4chrpd04"; - "NNPDF31_nnlo_as_0118_CMSW3" = "1snkandx6apar3sp0c182n770rxn2s64pc07h5k18627cnvpzing"; - "NNPDF31_nnlo_as_0118_CMSW3_hessian_100" = "03n59yvpgciipkv3k0yr0ab3myhx263n90ah3q3h8hdszkf80ri1"; - "NNPDF31_nnlo_as_0118_CMSW4" = "1zpnvawdj20izx0mx9a3xz0d0an6i65axbzg5z7fkiq0p09rfx70"; - "NNPDF31_nnlo_as_0118_CMSW4_hessian_100" = "1qczy2935iq2h4mfq0mv53v2vlfsyvhkff36c5dkdlkrzfkvpl8x"; - "NNPDF31_nnlo_as_0118_collider" = "1y2axnkjwx7yg301mj1yx1x937j7mhsnbbdpip94pl3vm5hz10dk"; - "NNPDF31_nnlo_as_0118_hessian" = "0jvzl1bs0mh9c7ypkdgw0s06qn9jkww1d124lc7aq48w1g4n0zyy"; - "NNPDF31_nnlo_as_0118_luxqed" = "10fwxncr1y7hnja5nxywldpkzrijxz5ayldqjc21jamyhyj3qsh7"; - "NNPDF31_nnlo_as_0118_mc" = "0sg939j6xn7d5g46547np3123srgz44h9clh29ybl5cnmccv23cl"; - "NNPDF31_nnlo_as_0118_mc_138" = "1kbxhjzrr4802kcpi7m2g2dx4ywvs9rqjispjwbjc60rqkqispyv"; - "NNPDF31_nnlo_as_0118_mc_164" = "0i9yxnbps63nz6ala4jk6qmpxlg6p46w6jja8qn73hp0n69w2acz"; - "NNPDF31_nnlo_as_0118_mc_hessian_pdfas" = "1b9ijn595qfq32yz9rlnn2br7lssbk8ka39ripfcfyf33v9sv460"; - "NNPDF31_nnlo_as_0118_nf_4" = "0l796ns5xm0biyl0jra5z6y7vddv52v48wlbdywsq54082scfpl0"; - "NNPDF31_nnlo_as_0118_nf_4_mc_hessian" = "1bw0x75pah1kp387s8m0rv2qc54k5pbncbv507d5278hhfsn68qa"; - "NNPDF31_nnlo_as_0118_nf_6" = "0dbxxk0p001sk6sb9nf5ipzi39w65vf4c4g8cbhll7p4fqi8f8dy"; - "NNPDF31_nnlo_as_0118_noLHC" = "18y9mnp1gmvdbikgfdybw8wz2w5x60wk8lya13g7z6nhbfs08qa4"; - "NNPDF31_nnlo_as_0118_noZpt" = "1jwhkz8b1x6a2qi62jvprcp1rmcq5aq7s31qhw0skcpx8r6r6gnb"; - "NNPDF31_nnlo_as_0118_nojets" = "1bg714agc25p7zw2yydvl340sns7fhszpbphzap6fc0jsg511zh5"; - "NNPDF31_nnlo_as_0118_notop" = "1v675r4qk0wz1hg000fw79nmf1zjqi2ghvgjgs7hyzzbh5g4l3ds"; - "NNPDF31_nnlo_as_0118_proton" = "0ipsp8kk59fb3w9d1y4pq85f4fl6789rypjfbpp44gcy8hzshbm7"; - "NNPDF31_nnlo_as_0118_wEMC" = "0savd87jahlac4ag3qfamhnpa7mpnm00j104f3ci17gdax1sds50"; - "NNPDF31_nnlo_as_0119" = "1s7ildlffbh6cpmzlmafxzbbrlgggfqxsv4qic99yvgqvdgqar8w"; - "NNPDF31_nnlo_as_0120" = "1z6lqcq1dgvqnpwlfymlf9yhcaqc2p8ny7wv4xs57639dsp5xarb"; - "NNPDF31_nnlo_as_0122" = "0482r1hip6c4kpq24xzi8nw8awky0669k4plgpgv0av12l4bh9c9"; - "NNPDF31_nnlo_as_0124" = "0cf3djgs4gayzwy8p0qvynripz3hxd3866m8ldlhxnjmcsgcps11"; - "NNPDF31_nnlo_hessian_pdfas" = "1m5wdnj7hvg2a51w1qmhm934glhjf9db0x5nry5blp90y5x0v185"; - "NNPDF31_nnlo_pch_as_0116" = "1i8yzqywg4hcf53vcp25fg8llybis3pz6xbp5ajpyjvrvsgii1pc"; - "NNPDF31_nnlo_pch_as_0118" = "01rsx0ss67772b20dnnw463328pgbd57d8zcj3lqymlb4a6fq8f7"; - "NNPDF31_nnlo_pch_as_0118_1000" = "187xkvp7y1wssgpb21r1w4yxn6m1280jac9nmiavrma06jfd57c1"; - "NNPDF31_nnlo_pch_as_0118_hessian" = "0fs5d450hc15hqs6xv9nxfsnhwszmg9ybjypgwa9kn4s4kkaz1wl"; - "NNPDF31_nnlo_pch_as_0118_mc" = "06vgb01l1yigln7cn9y3lslg35grwvydpd8g04xn4pj4pj2vjrs0"; - "NNPDF31_nnlo_pch_as_0118_mc_138" = "0za3v1mg8gb631039kg5mkr9zhn390dkyim9p663srpk85j7h5g5"; - "NNPDF31_nnlo_pch_as_0118_mc_164" = "1xc02sbmhyjr4gjwim4p0gg90zh26zdmnz89395pxzbq2navcraz"; - "NNPDF31_nnlo_pch_as_0118_nf_3" = "14xb6m1wqc5f7xjiklwnshn7ljrlg6kmbzr2rib44pgbj6pnl2xn"; - "NNPDF31_nnlo_pch_as_0118_nf_4" = "1sg823n82j9ijqx4ldysh0g53pjzn4sysvag837ywfyns4p5qy9k"; - "NNPDF31_nnlo_pch_as_0118_nf_6" = "14ls2yd1n2pqvdvq18qmhizms3a8pwqvksdkvwn0m1379lkss106"; - "NNPDF31_nnlo_pch_as_0120" = "09zc56cmpj9iw0qp2bm9a8d86r0mdagg1vrpf2xqza4fr841r5km"; - "NNPDF31_nnlo_pch_hessian_pdfas" = "08baysni2lhbpr1scx7h0zf64gyncj2ahcv4y86142gl4zqrafvp"; - "NNPDF31_nnlo_pch_pdfas" = "09mw3gr7dz0vwdnralaplvlz2c464lmdizf673xsb0wlm12pqf6g"; - "NNPDF31_nnlo_pdfas" = "0l92q3xhdk5nrnhkmrirxnvplj531rdpnblnacd759cl4hgxcs2q"; - "NNPDF40_lo_as_01180" = "0m630n5i7s0qnlxzk6ka43qfp6ipz2jgzr7ys42hdb66kg3z5lkc"; - "NNPDF40_lo_pch_as_01180" = "0wrvmcgdaipi7vy7j85yszaa3c57hs3xll9lfn9cdbjscvmsx6x5"; - "NNPDF40_nlo_as_01170" = "14j21qryc25k1jk4ypdcr3cgfkhyy4hsb57hy8x5pggfwc2w3f36"; - "NNPDF40_nlo_as_01180" = "0399bnxvgl2h2ini198jmzjjb179f6dpxfv5x8imlfl515llivx2"; - "NNPDF40_nlo_as_01180_nf_4" = "01kwziiyg8vbl26znv7khqdckm501d7ccxlkq1y0cd9s1f5ff8xi"; - "NNPDF40_nlo_as_01180_nf_6" = "1gv8anb3vqpzdymp9g69702x64pbh6l2rn9257hdpz4i4m98rsjy"; - "NNPDF40_nlo_as_01190" = "0wf8p2i4mxs3hkqvxg1clj082yinbdgccr6qx5kbwkzsck4yybar"; - "NNPDF40_nlo_nf_4_pdfas" = "1ia9glingyds6bj6yxy867ahriqdhfkxczzc4nki933h6jbj74bf"; - "NNPDF40_nlo_pch_as_01180" = "0gad0hjq9kwiymc9pljj4z52jsg794m3knb38zj9icgjk0p9lwxm"; - "NNPDF40_nlo_pch_as_01180_nf_3" = "15j3vvc0vaf13d8cnyr4h7gwb7iznrcajnw59ryx6ksz7cn84sy4"; - "NNPDF40_nnlo_as_01160" = "0y9115xlg14m1ahfffiam4zp0axga86bhzfxf0xiaxb36yzbmdhw"; - "NNPDF40_nnlo_as_01170" = "1h6if1zw9dqlfnn7glbl5flj792i7fqiy7pprhwk93k4snh3800i"; - "NNPDF40_nnlo_as_01175" = "1dkzzhmkmzm92gmb83lyirj3clicrg70h5grzh0j8nfcw0xlz4rm"; - "NNPDF40_nnlo_as_01180" = "1bhysjkji0k7xy9njarkfvxff05kjl1byhkknxv0875p2znzkpva"; - "NNPDF40_nnlo_as_01180_1000" = "04yai94qwd7187wg26icwf2wbwi20747l6zikd66ygsz9n34xn9y"; - "NNPDF40_nnlo_as_01180_hessian" = "0cmpqgaz341hif0gdkzq8mnfh9apxn1zxjwa12fk5svbig9i1a81"; - "NNPDF40_nnlo_as_01180_nf_4" = "1aj5y3fyvna2jwxbsrgr2cbc452aprxnwv78vh3ph20jlnww20pd"; - "NNPDF40_nnlo_as_01180_nf_6" = "0bf6s6s0w7l592bm87mazwff05d8s4qlblzl9yj91am3xlv0cvn1"; - "NNPDF40_nnlo_as_01185" = "0y1xn9qcv2l81sbz9rayzrpd1bjsdyixr42lzfgmqbq45sw2m04n"; - "NNPDF40_nnlo_as_01190" = "1ibz4yfrw1n8plq4gi03yxi9afaca2yprxfk2y9lvbkycn608d0q"; - "NNPDF40_nnlo_as_01200" = "1cfcn819aali7ylv9y6yb2ggqy0yghyj0dys9lf9gv5wiqjwh5q2"; - "NNPDF40_nnlo_hessian_pdfas" = "1b5jvhdk7fmnz8gl38i3408h2qrqcsr7s9v7bh6ilc7x52xsg65k"; - "NNPDF40_nnlo_nf_4_pdfas" = "1ssp315xcqpc4md5gijbi2c02r6hpazp8yw1661r4m7xy5qm62wc"; - "NNPDF40_nnlo_pch_as_01180" = "173l2178plrir9fb3bq17l4dw5qfy9clic4m54wqg7y3r71bmv7p"; - "NNPDF40_nnlo_pch_as_01180_nf_3" = "1mh0pl1f1ayx1fjj0q1fw9s7wc7gmj7a46jli87s4g5nxrhyki9f"; - "NNPDF40_nnlo_pdfas" = "16d81h0pzxzgwwrfjghmradx4bijf08xbrdn79y9bxf6czacm8n6"; - "NNPDFpol10_100" = "0r5qfa8cyanalphgjdsh57s3viqv9i10v51p1pyamj1f90gb9pr8"; - "NNPDFpol11_100" = "0nny1lpw37jcillpfxjx82hq7wlzp4yksxialmc2ivr192qqdda8"; - "PDF4LHC15_nlo_100" = "0m9d4zy7608iryqy1ypgkr1d3yhw2wv1nrrc70zrfih7x0fp7lz7"; - "PDF4LHC15_nlo_100_pdfas" = "05wyqyh9y32sxflq69igcnnsl0ifnkyw3vnnnjn6kscl8h8hs7lp"; - "PDF4LHC15_nlo_30" = "05n0i1mr7v7ssvxvdmv9fn621rinl08frz71apjj7wfdm7s7bk72"; - "PDF4LHC15_nlo_30_pdfas" = "0xi4xydx0x4ina0wmqv9jf4978xhd8x0l91dwfxh5vy39r5x4lm4"; - "PDF4LHC15_nlo_asvar" = "14hdgj5g8ia7y6hi40zbh925dacrk7hd6cli6lkhlqzxl755nbs3"; - "PDF4LHC15_nlo_mc" = "09p7y0z04r6wdkf8gi3yj85qk5hmp0mmhab8c7a7lly4731fyf42"; - "PDF4LHC15_nlo_mc_pdfas" = "0sds9rkvbjkk7pardwq959qqbrvgwswxmsqcfppky2p0qmdsjs0s"; - "PDF4LHC15_nlo_nf4_30" = "1ysy6dqlacg4bwb2f16p1aza5gwm9qnhmc0g0mhsdw4d2i4ml5yg"; - "PDF4LHC15_nnlo_100" = "1gcq3qrf39dhq2pmpjrj3z0i0ycrk76mjdwmgfvzdxysp530ax54"; - "PDF4LHC15_nnlo_100_pdfas" = "16r8far43ymsd64a4bbqlj56qvbjmcyxbawv4lkfxysjvbydxj4w"; - "PDF4LHC15_nnlo_30" = "10cm4wa0mk34rnvsr5q8g9w7fs9cblsryms2nl370wdvcrhzsxph"; - "PDF4LHC15_nnlo_30_pdfas" = "13xln0y8l0qcj9951glj4f1kqfaagj8gwkxzlvdkgjnj1scdy6yj"; - "PDF4LHC15_nnlo_asvar" = "03fh1jcbmvla7n2jj3zq4ibwvq66h0rniply7h93d94zawcgsy4v"; - "PDF4LHC15_nnlo_mc" = "0c6nfkv3x1p5iw514knjvqcs1dcaryf74qqg1za8x234yr5ndi3p"; - "PDF4LHC15_nnlo_mc_pdfas" = "0l8hlcz69cdii7mpgargi9nsx7iy746nad5pnn7pvycrc40marij"; - "PDF4LHC21_40" = "037bs1l7zr3z8zi6wzh5kxgml84bl64258fr2sm0dzv9yxh8lvp5"; - "PDF4LHC21_40_nf4" = "0m2ki4qmgl1ggim2inlgynjzqr4ya3qgjph63jf72kia8ks2hfl0"; - "PDF4LHC21_40_pdfas" = "0pigpix2x2bv1a5ib17zjlfjqygjpjra0pgvmf6knm7mbgwxhqm3"; - "PDF4LHC21_40_pdfas_nf4" = "0dayiilh94cszqiphr487589qacawfp4za2cngr3da03yg1aswbd"; - "PDF4LHC21_mc" = "17fbwk7fp2m3fd0xzp94sp7m0mmjmzakg870rbhg8vi88bimmwry"; - "PDF4LHC21_mc_nf4" = "1n7h45yxw2mwppf6zblc8v415khy9vgrackmbfkm5lb9c79faas6"; - "PDF4LHC21_mc_pdfas" = "1pn9a7z0xl1bn18z461j90sjglccswimm4p23nyq0fxal5ziidbl"; - "PDF4LHC21_mc_pdfas_nf4" = "1andl5n1lw5iyd337czph5abd0sqc3l90b21g67af96am5pprcpk"; - "TUJU19_nlo_119_50" = "1q1dhsxz1kq75rpzv6gg6p6bzvvv0d44pc4y3wsiy9g14aff85vq"; - "TUJU19_nlo_12_6" = "006j6y4xbjss9apzagjcc3r1z6s61a1hzafhcyriiffqhn8bg50k"; - "TUJU19_nlo_131_54" = "0ymf35alyar6fwagmdny2zz2aag576f38kail7gh2lvqpmjmv6np"; - "TUJU19_nlo_197_79" = "0rq57sjcwljz8fz2m5bz0hm1670jp080zawmavmagmzvmyxbpnpj"; - "TUJU19_nlo_1_1" = "0fp4syfjgl0y58hrr3g515j96yp7ncbrnzj1h7i5h3fphxzayhcz"; - "TUJU19_nlo_208_82" = "16g5fjpa1r6pml6jnmzikwafdc0vgj8j3b0ivjz0bsqxms66msg9"; - "TUJU19_nlo_27_13" = "1ffipy7g22mjbhy7wpjipfka84k4iw52bni4gw2a6aan5qljlcii"; - "TUJU19_nlo_2_1" = "1l17drwy3vv8s7g9fdivxs2z6m88h7fpamnr5y0y6nbkh6bja2s6"; - "TUJU19_nlo_3_2" = "1qm010yjnj9amj2j89v6s5s42q18q8b6md35c9mbv88ibqbsdnvn"; - "TUJU19_nlo_40_20" = "0xylrincss1ijkfxnk7hl72c1rzpzm14hcarddh9pd57z7i1gv4c"; - "TUJU19_nlo_4_2" = "0adqxh47pnhgmq9r89wcqaldfrqll5gpjzqncqd5ba8301i3d98m"; - "TUJU19_nlo_56_26" = "04q8c3gkbxib5fz20f7rwn33sqapcmsj6fwwihi6ca8n1rl6hw6h"; - "TUJU19_nlo_64_29" = "1yyl70v8s16s2v630wamyfk8lwdw53cbp5hipgwdw1sfs33pj1mj"; - "TUJU19_nlo_7_3" = "17qfnf8bv6c5q6xkl68c6n1gxp81gang5w71gvn9m5d6pn2wiicj"; - "TUJU19_nnlo_119_50" = "186fja2z84csh6zsp0lpy5mch5swmwaf7mvq8kf073jxlrkrws42"; - "TUJU19_nnlo_12_6" = "0k5q6a8jidhmnjgll1l71dxx85lzd7w4v9bsmi42qladkd71vblv"; - "TUJU19_nnlo_131_54" = "0inwqb1v390xkjzhc7gy4hng07jzbbhpq99f4zpkzx115xs57l74"; - "TUJU19_nnlo_197_79" = "09c9b1kqzw28rqgxfxq2mvwna8yb6f2y90332f05jpvfk3mmr7n2"; - "TUJU19_nnlo_1_1" = "0qmvcbsyi333b9dd42xjdq62a7dfa3hvfcbk48fg4m179mzhp588"; - "TUJU19_nnlo_208_82" = "1xpwnl342g8ahhp3lm7p2xhzlx5qzhjvz6g1w1nqrd818w3994zn"; - "TUJU19_nnlo_27_13" = "18fsbp1nh4zx2wgg9r7ian0mvhvf4y8ssqv33vqvn0vwk7gqw7jf"; - "TUJU19_nnlo_2_1" = "1p0b74w1a9906lqbxbc8dkk5bcdhnbqc82lnhsr4qfi8sxih2l9i"; - "TUJU19_nnlo_3_2" = "132w4cv8r7958sad6jakfppsywifwzzacsfyn81qvv76xzc2hm3w"; - "TUJU19_nnlo_40_20" = "0fkbwxh0smj1icjfn58fsfh52ny35pmqjs7cs3qnw6dk5p95qx6k"; - "TUJU19_nnlo_4_2" = "12vm0dl8ylz38zzi6rsyy24h3yg30nq6l464nl5fr6jdkvkbz2f0"; - "TUJU19_nnlo_56_26" = "1kqc6v6qq6wl3nls31gn5nrzwfl9kshm2bbak771c3xvjsgvjpdy"; - "TUJU19_nnlo_64_29" = "166k8swsysr7x5rgivi6k04q4p8njb2ny7xj7xjqhkgxrznc8jzq"; - "TUJU19_nnlo_7_3" = "0q9vswr0s3k15abghx3cccf1ays0601n1438pwqgd5xz8981ngm5"; - "abkm09_3_nlo" = "0h268l7j1zkxm2nacari10f86lpha511xhgrg0q9r8hc47sw2vxs"; - "abkm09_3_nnlo" = "1gzhvblckskscql53pfxp79qclhhhhm45sqjhc9jrm1bp3x52w8i"; - "abkm09_4_nlo" = "0yq3gy0qgnk5dh0hh3ldrf5bqzx5wpkhw509nvz5arlh0bfwhyg4"; - "abkm09_4_nnlo" = "1b8470v2n5v87mmhp2dhmfh7iv3280ad67z2vyl0sfv87iic409j"; - "abkm09_5_nlo" = "1nhck955mw94h3pyhm2vd3q60qxwsmclkfqdscp06fc3avyvrzfv"; - "abkm09_5_nnlo" = "0wklkcjknn7ys1akg56zxdrkd7ardlc5qnbjq51mva1nf2bxk0np"; - "abm11_3n_nlo" = "06r54q3ph851a0hyn4di1ifwjmdkdklf3wlsdpz7qn0w4w3xcg29"; - "abm11_3n_nnlo" = "03rgkj2hyn3zmj8yxllfnc2iqr12j8shjcpdjka33v270lim3gq2"; - "abm11_4n_nlo" = "02r9ba7rz8f5438rfckzny5amnq9qjgl164x8il6xqh5crxn4vb3"; - "abm11_4n_nnlo" = "0z6a9wxy6018qm9nyyip9wdq46j7rh2if5xch19h4qx20gx6m48a"; - "abm11_5n_as_nlo" = "0x2w81w9cz955k9dd45872k98my57w83cjdsv4gvjb64d1hsygzq"; - "abm11_5n_as_nnlo" = "0091vwjkc686d1dnfn2dpa7jb56p8gli2z687fpx5f8yhjzpbh80"; - "abm11_5n_nlo" = "1bpf37mg5wgcf1id2am98l5mj162xrnb8k16ppfx3qxlakp0iabl"; - "abm11_5n_nnlo" = "1mpk322mqs078pk2nxxk8fa29ka6cxzsf65ffiny38678djmfqd2"; - "abm12lhc_3_nnlo" = "09k90vhjq7p0i0aaq2697pq2dc86bkmnv4q8zyqxjp3wnqx1v95f"; - "abm12lhc_4_nnlo" = "1hciv1z9b5fiz7swv21gr0rshijj9yj2n8x4l54v9g0jyd061jaz"; - "abm12lhc_5_nnlo" = "00xxkrhbfkxhg33mkpwwk5nsdp4nmi0zmllx5z5ygxl24rinsq9j"; - "cteq61" = "14hbc855b3wsjk7ypg86md46cjm1bj7n4hins9nr8kgzs69i6vss"; - "cteq66" = "09i69ac3gkrai5jmazjyjvi5sl8k2vm48m90ijn6pl24p31qf68y"; - "cteq6l1" = "1b5m7g7wawk72h76l9yr3gx3n67jggna1004lwffvj43gffwkjap"; - "nCTEQ15FullNuc_108_54" = "107klcpsr9d4dwavcqqs3849k90mdb3bdjam3pd79cmsy7ncr2hf"; - "nCTEQ15FullNuc_119_59" = "14az155s3xfl8nscwpajzwj0dy94dadc4qdc64njlg3xlnxsgxy7"; - "nCTEQ15FullNuc_12_6" = "14z11wyzclx5k6dl46zr0jp6mja178bvd547cqqfy811nbzmmri3"; - "nCTEQ15FullNuc_131_54" = "1984nphc6sqizaq1c1laphw3hdvkp5k7sy7g563wq18578fifbmk"; - "nCTEQ15FullNuc_14_7" = "11i2xcd6ncp2aqw3y8pgcp63zkaj383ciwvqpzmjnqraiqqqa77i"; - "nCTEQ15FullNuc_184_74" = "1m311m5bkzq00qf117dli9xrmcmx8qqh716wff1yj8ri4c4h9m8x"; - "nCTEQ15FullNuc_197_79" = "0vi29fdxaj7fnpc01k3y2ylb7ngpdnmbnzgxdnr6p9bj5wfa69z5"; - "nCTEQ15FullNuc_197_98" = "0qjkdfgpbcmwc39wzyfb07wrqnkkwn7v8235y1m25x4wy5bbpjbg"; - "nCTEQ15FullNuc_1_1" = "0nx1n814mkikd01pxmpndk2qxpwqwd55cbn6z1kgxm8qlhhhd2zw"; - "nCTEQ15FullNuc_207_103" = "09py38s7shcyy07p5mxfiil5wlxijzbv9k4l3x0g1v191k0vi3m6"; - "nCTEQ15FullNuc_208_82" = "1c9r5wr43291rw965axdzpshzjhnynsrlf28kfr17v7vpd9dykl4"; - "nCTEQ15FullNuc_20_10" = "19vhxi7ch9vxa1vyjpxknk69hnnm2n5wpz4qybg1cznk59dvpi28"; - "nCTEQ15FullNuc_27_13" = "09pflgyxl2ydzrmys7rv0mmvl32z3dmdx63wpilrw592aa70bc2i"; - "nCTEQ15FullNuc_3_2" = "1l2js36nh4jawwkpiq386blgwbmgi9ccvvzbwq92jb5kpd2fvh7z"; - "nCTEQ15FullNuc_40_18" = "11pw23fbrz97i9278cxrvc0a4wbdyhz788axq8jn7yka9mg9kch6"; - "nCTEQ15FullNuc_40_20" = "0raiqn6w90n17irf4l197my77999ygqwhim9lnjqgbn68yjqfqf3"; - "nCTEQ15FullNuc_4_2" = "0fip3n3pjd94rz3f4gcv2szrx5k72m5b8xcmsgjfd1671r5kmlkd"; - "nCTEQ15FullNuc_56_26" = "13msj49c1lfisgcigvc4wr32w597jwir8cggrcdq74b0d0ab85ch"; - "nCTEQ15FullNuc_64_32" = "1spgcb340nz8by8051hngnh6pa1wjf19vi5a40xr8gyprdzhwb4a"; - "nCTEQ15FullNuc_6_3" = "0v5yabjw3xkjq5c1zjqmj3wwb7yz1blkprxnrpvai54v17w3sk3r"; - "nCTEQ15FullNuc_7_3" = "1ncarbncfkqk6l3rx3zg34a3sj7mpm2diqsafyldpn92cw66bcs2"; - "nCTEQ15FullNuc_84_42" = "1z719mcx5lnx2ciwlnxxhgc4s00jrr9sfrxcimh69sj14hmzgx0d"; - "nCTEQ15FullNuc_9_4" = "180ipb4m2zy54h7n4s0jwqk9k6562bygvnv7mg9dp2f7vf5317a1"; - "nCTEQ15HIX_108_47" = "0iqv6rsvvr5mqiaddn2cs6psrslw6ncqxca993v0z0hng9ahnnwd"; - "nCTEQ15HIX_119_50" = "0gxdr596gk69sb76r90p5ksvx9bk4axj21qrsyxjf1bmgdg2rv72"; - "nCTEQ15HIX_12_6" = "0vkkz3hq0irvfb08cpdijfvv17bcvzaba5c1bf8kwx1i2zl5s6xz"; - "nCTEQ15HIX_131_54" = "0pbm6390cdglxqzrpl2slv65m943m32i10c49pf70fg68x3l2dff"; - "nCTEQ15HIX_14_7" = "1yshwpa3zzzmf7s5v3c3130ysm1wciicz202hrraz4px102h8a06"; - "nCTEQ15HIX_184_74" = "1wy1691pc776kv456cbjl5x5rg2z7cycyfny24caq1qvjifvbr94"; - "nCTEQ15HIX_197_79" = "0ckbp8cw49ch78q4nsm1fccn6nizpipdp8q85nnipql53xsnr4zm"; - "nCTEQ15HIX_1_1" = "13sfws9cmrsnp26mx4m2n03gary2m10l67bd8xic8pykgpr8c695"; - "nCTEQ15HIX_208_82" = "0fqvzpqszkyqb4f2y44hrdj7rvadbqj6y8fzkl9xzk432lalm8w5"; - "nCTEQ15HIX_27_13" = "0z356q82x6cm52f3qym7vkajlkf2amkz87as0jvfiygvi4gnilcn"; - "nCTEQ15HIX_2_1" = "117dgz8nx1j64xgqlp40zmgpg0z8b0p1j75d1llvshmksba43avb"; - "nCTEQ15HIX_3_2" = "1k1hxpcg39hrh629ml2kwnhir6pq41rpic48njq2lagmrcdpbn52"; - "nCTEQ15HIX_40_20" = "0q1ggww4a5cdf802737kh7igb0br3q50xw205v4b5p7v237wsiym"; - "nCTEQ15HIX_4_2" = "0n9zf4yxvp3b3ryxbkdw0yilsb21nrjh40ms883d6j42slzhf37f"; - "nCTEQ15HIX_56_26" = "1z39vjgp6jryvqaxv6jq05jj0lfxsj212g17amch65pgxm4l7cwg"; - "nCTEQ15HIX_64_29" = "1iy1g1226irrjxz9wwabwd6x0712dm1aap7ka6fy9wwwbn87f6d8"; - "nCTEQ15HIX_6_3" = "0ljq0h0cdwbfvlpd40v2nypklimw4hh6k999mnyxqfvq47m13ffl"; - "nCTEQ15HIX_7_3" = "1y9k2snzymzgs26ayfn2c8n6isqzqq14pzf05xvlxmc3k1fbsfyx"; - "nCTEQ15HIX_84_36" = "130g553b22s7plgy51n56az05v1pnfgrg5knpg1knx8xr8a9xhh5"; - "nCTEQ15HIX_9_4" = "05igk9g2i1gm7d7npdwd7y3k7xf39scx1mwiw4m39b52kbq7kszp"; - "nCTEQ15HIX_FullNuc_108_47" = "1h2x2h2n02nwinf8ba3yyqa61384p4g29ib8vnrzwzc7q34940i0"; - "nCTEQ15HIX_FullNuc_119_50" = "0m5z036py2m1863k62pzysjdr92dhyiwmb8lxgky5skd7514rrsd"; - "nCTEQ15HIX_FullNuc_12_6" = "13rsl7lczf5qzjgy8m3dp4f1gyib2ffvf86iwci91sq51sma5kk9"; - "nCTEQ15HIX_FullNuc_131_54" = "1bsi3y6b7sxykwablgghqc89s3vxrvjr9y4bvhwcm21c2i4y6vbp"; - "nCTEQ15HIX_FullNuc_14_7" = "0w93qfiqdnzvrry9ddpbqcy6y16sszxfmvvgdy6r8i8py8dzfkyr"; - "nCTEQ15HIX_FullNuc_184_74" = "1q93f9rvlc4z3hzfhdmmxlyqfschrf99a0xyrc78rq1z2pfgmm9b"; - "nCTEQ15HIX_FullNuc_197_79" = "0kb2lnvh8mq25i5pkfis86ggs0s6hmpmyqqgimhcsamk8xnf2pcv"; - "nCTEQ15HIX_FullNuc_1_1" = "1nk792chip0iamc6dlqgqqlc2qlxlbgvgnhsvbmzkmmzvp2ji961"; - "nCTEQ15HIX_FullNuc_208_82" = "1l038nhnwc0pd7sq4yki3sjrrn66bsvqkvba2j3kf4f852gsyswr"; - "nCTEQ15HIX_FullNuc_27_13" = "1gdb09429xn5n07qqjch9x1cnq4xinf05wla8fsq69qr7bcdq9mp"; - "nCTEQ15HIX_FullNuc_2_1" = "0fnbpwv8qzgchc2r2gcjgw9yh4r94vm1rzbwj1f6ahbwrsl4rfp3"; - "nCTEQ15HIX_FullNuc_3_2" = "1r1s7ljwa169nbgc1439cj0gkaqza6ilx3x4gyq2jg9byz30khzx"; - "nCTEQ15HIX_FullNuc_40_20" = "13p7mnh2h8abih8y24rfapnrsd036pc8xy8qm82j8g4bk0j5jacx"; - "nCTEQ15HIX_FullNuc_4_2" = "0j1w7d11ybmpfci79lz99i94szxf5xn6z4kxvh8hly3qlcgn636j"; - "nCTEQ15HIX_FullNuc_56_26" = "08wds8afv0fzlaxck5i2d3pzvi5nqnc1jmq58fpnc7i0g238wl8k"; - "nCTEQ15HIX_FullNuc_64_29" = "0w4hn5iwqa65lnf6mhihx5qrq4wpcqw04ii3jphy79l58j3i1iam"; - "nCTEQ15HIX_FullNuc_6_3" = "1ki2cfsg0wmvfkzv2j9akiyl4d4b8v3d6f65iryxakjkhqj6vvgx"; - "nCTEQ15HIX_FullNuc_7_3" = "14mx5lh278p3zdc572bhxw9sc6n7ga0ak0ch85h3lx9zwg2a1m5i"; - "nCTEQ15HIX_FullNuc_84_36" = "0hyxyhb2mn64fwmijigw8m3v5zlj52hf2hicvx4gcq0lw063jxj4"; - "nCTEQ15HIX_FullNuc_9_4" = "17pydzll5lgs974gz4bchl2wxc9ixfpnqjrsidzksl4jf03gn77z"; - "nCTEQ15WZSIH_108_54" = "02z08pzvl8fa0bi6ddrlbknj0iryimw02r40z0nn7p8xf99qabhz"; - "nCTEQ15WZSIH_119_59" = "0r03k6j6nd2mvdkidw4gx1xm1s9hil9z5kanxsn2hzp30ab971db"; - "nCTEQ15WZSIH_12_6" = "00d4lis1qas1k8yzfb3dbqgvy9ynv7h9lx67ys3mj1ws5fqyn5al"; - "nCTEQ15WZSIH_131_54" = "10frai6qmzvp8xpkanl1qlpnc6chf6k5j70f4pw4abw8ycbjymij"; - "nCTEQ15WZSIH_14_7" = "02qd5x041p6n8rzv5l446481jb9vkc5nrc018vcg41735azr0d0p"; - "nCTEQ15WZSIH_16_8" = "164ciyxkrxp33r5nrkl86gq0jvdzm90hf602raamn1b5l5yrnadl"; - "nCTEQ15WZSIH_184_74" = "00nrwb8q6sa3zwbdc9mx4jz5ndibml84lfz8gad9vhy20zayyh3q"; - "nCTEQ15WZSIH_197_79" = "03hzr05vhb0l58iv9c2743c688ygagy1bi5a7zqn8nilsmykbvag"; - "nCTEQ15WZSIH_197_98" = "1mdlhp643z0gkjpj2jdi5zdd4qxxjqsy93rkv69cn1x5abawdl8l"; - "nCTEQ15WZSIH_1_1" = "13wskph284niaxqx92yaa4jg749ry6y98ds1ifvwc9970iccdnk2"; - "nCTEQ15WZSIH_207_103" = "0mpc6msqqjbcs756zd426xgzxmmmcmk8cp8wh2mpagib1drrg1x8"; - "nCTEQ15WZSIH_208_82" = "130bs9y9337pmgwi1ix0ar2xvhfhl4rs0626kbin5yrxhdy7rpha"; - "nCTEQ15WZSIH_27_13" = "1r01sbzixlrqxkjp9kx3s4zgsd48myivyc70p7ha83i1qrq50g7w"; - "nCTEQ15WZSIH_2_1" = "1qlh3zxbg13sq187k1fmssan00ifmqr0q2l7i45vc8jz3mk70098"; - "nCTEQ15WZSIH_3_1" = "057zyvlxz3hwlwgydccl2y124bvc6iwqqgav2jqw0r53a39rc25g"; - "nCTEQ15WZSIH_40_20" = "11psi56yk2yd75v396j68hfdacsnxvng2bw4v9g4afbjv9697jgr"; - "nCTEQ15WZSIH_4_2" = "0g4rvlgksw5gf6a7zh7yzsi2sq5jqkwbrx6d7jgz7zpg8jkg4qrz"; - "nCTEQ15WZSIH_56_26" = "12d0bj92b615kzadxwivp1q0j906m2rlcxfflwgwg21sv9axhi4l"; - "nCTEQ15WZSIH_56_28" = "12yx9v87y59qf14005fmj55n38xnhlvc7qgcrgfsicmdbx3ncm5x"; - "nCTEQ15WZSIH_64_32" = "02w3a4sbygc72acxnfc6lhird4nxcgq5dprfldg10h7f9lr7441y"; - "nCTEQ15WZSIH_6_3" = "05x3cknlnc1kbqnmi3hk6fjgx07dhl7b36rg3abaqn4yg65i79sj"; - "nCTEQ15WZSIH_7_3" = "0d6cmpv6csysr96knip033mw7sg56ls1gcq8gvz2qy7isj167gx7"; - "nCTEQ15WZSIH_84_42" = "15zva7n91p6s98kkhcfsvws20s26fl1bvjql8m1n1c2d5pr29wj5"; - "nCTEQ15WZSIH_9_4" = "04cs89s2m99p31jkc2k4f5i5rr0l4fpa6a41d59zvknhgfy74yvw"; - "nCTEQ15WZSIH_FullNuc_108_54" = "1wk8vhhlzj3wrb994s66q5zmwxhcy9vxpyks36s3jr5729jxk1j1"; - "nCTEQ15WZSIH_FullNuc_119_59" = "1rrkj7inah6bg03mmxgza39z40ghdr8km9hy5v5b69bvqcyr42a3"; - "nCTEQ15WZSIH_FullNuc_12_6" = "14wgacbimifnaji6byq1cds9zz266a63bvv616b0n06391plvzff"; - "nCTEQ15WZSIH_FullNuc_131_54" = "0k6gncwq4l5avlnr4qpvakklysi6g855yqksylc42ndlgjm4jxfy"; - "nCTEQ15WZSIH_FullNuc_14_7" = "1mlffwsn3f942flxvvi0rp63xlcrq88ir9vffmkzh3br3qpm4q41"; - "nCTEQ15WZSIH_FullNuc_16_8" = "1ga0kijnlzjz98j32bakcan89bfhbhq8y08d84d90xpgaqkpb9z2"; - "nCTEQ15WZSIH_FullNuc_184_74" = "1nhly8065kabzjjkapr75vafx46f1zl21xc6fdcv15a2qwx54n0p"; - "nCTEQ15WZSIH_FullNuc_197_79" = "0l9c684f427b8hhwm68swh78n6104nbpdxq6v50zipwc6df0j6w9"; - "nCTEQ15WZSIH_FullNuc_197_98" = "0vc285bd21arpmaykb6baspzr8ak42yx9h4j0sx2vj07l648g5hi"; - "nCTEQ15WZSIH_FullNuc_1_1" = "13gbjq46f5cdpdr902nxv261hqw041f7ryxbwgvxr3k2zm7h8fw0"; - "nCTEQ15WZSIH_FullNuc_207_103" = "08m08pcz0f72nd7zcrvi8cl5va49djlvdff1w4is4gmsb44khyv2"; - "nCTEQ15WZSIH_FullNuc_208_82" = "04x5icmidi1p3j8bdarl3sj0ak6g2ygyc5wmkkn9g80qqn4mxwva"; - "nCTEQ15WZSIH_FullNuc_27_13" = "0x4iv1kxb5lp514qm1nr3k32m68aw7sgy12nhdjhy2dv018snd8n"; - "nCTEQ15WZSIH_FullNuc_2_1" = "177qv17wv15sr1zcm2p6av20h32cjkspf4jj3jvvvgvks947n7dl"; - "nCTEQ15WZSIH_FullNuc_3_1" = "0aawk1ppg3nhl5n6gpdi6l1rw53l2x2sv3fwjz5821b6d7cmb9f6"; - "nCTEQ15WZSIH_FullNuc_40_20" = "1271dlp580a5gm29sv6b8plpc8d06j57x2xrfjyp7kafxa1158ii"; - "nCTEQ15WZSIH_FullNuc_4_2" = "0sv20zpzbinrz5biia1g3jzgyq0wbqaqrmrhhcyg2yxg9z48vgca"; - "nCTEQ15WZSIH_FullNuc_56_26" = "1wz1vwy2q85qz85kdy9gzzhnvv0jy4iazzavf9janz2xzw7833gg"; - "nCTEQ15WZSIH_FullNuc_56_28" = "01y0f2bz5yxmfd719fq8s1i3q5wb0dd81l0qkllpa961db83zmz2"; - "nCTEQ15WZSIH_FullNuc_64_32" = "1a93nqx26pj9kyvy66dmm4ib2pl5qwf03420q84zdl1hlcgaszzc"; - "nCTEQ15WZSIH_FullNuc_6_3" = "157j927a4x53gcam5kmpcpkyk76qgdlszxa4bcj9wlqrygwxsk3k"; - "nCTEQ15WZSIH_FullNuc_7_3" = "0l369wpd3gcb6i452w2hsjvidz80xl623xf1g1p8d2485nrvh6jm"; - "nCTEQ15WZSIH_FullNuc_84_42" = "1nikb7yk35s27g43k1wlgcfxqfyjf40csn8a6aiabliqdfjacaqv"; - "nCTEQ15WZSIH_FullNuc_9_4" = "0nnxf32kllwvm3fyjlswnyjx8cpsanx15qwsn03z6d67wx2f87sw"; - "nCTEQ15WZ_108_47" = "0v1s95f0wxyz73pfv5z6hc4mslxb7ml6imjmkhn2p9yx5mvk94qf"; - "nCTEQ15WZ_108_54" = "0zqw1p1sls58v7aacmwamlic0vsjyjijfam6bas5lh92rrmcf9h6"; - "nCTEQ15WZ_119_50" = "1wwx1rsjhd8rqrvyq68r70issnsby8zrlr8d76br3622mxqr83a7"; - "nCTEQ15WZ_119_59" = "11hckxdqyfrbsv3lc12q8zjysr2nw9mhx438ff13azp93ha7h1v6"; - "nCTEQ15WZ_12_6" = "0naqqy223p6gyw2r1qy5fs185dhmxzmb3zmkx3bbccqnspk7qcnz"; - "nCTEQ15WZ_131_54" = "0fi4sjv7rs90yac1zmnlf38dv5ry9zwzxrjwakpzh00irxw0cz8r"; - "nCTEQ15WZ_14_7" = "1k4sc588n3rd8fvcvwhxzc405iqj28xzv7y1md45kz1c7m6qy4cj"; - "nCTEQ15WZ_16_8" = "0ndjlgbggbk3zk5bm9nm726ci1v8b3qfy3gag14jmp7q780zyhmy"; - "nCTEQ15WZ_184_74" = "08cdkqbjihls2sg4waj9rxg7nvs0mjzxfv3dx1jppiw6f7ljjzrr"; - "nCTEQ15WZ_197_79" = "0ss7wgvx8rv03x1g10c516i0yd65njc7qjh19maij49aizf1fd4l"; - "nCTEQ15WZ_197_98" = "0vlyjqlj9plniim0z7mdhia307i296iha94l8b3iqgzyp9553gly"; - "nCTEQ15WZ_1_0" = "13wnm5sz1sf3hng70j8d3ml53knrx9b7wrg2h6x947jl51flrkh4"; - "nCTEQ15WZ_1_1" = "0pllq4zdgjaklad9j87vilx8gapzfhjh478gcw479ahgjcbbbxxp"; - "nCTEQ15WZ_207_103" = "088d8sr9mq9q4bi0ipxznbm3k2b2k347bj9k5fxsb27f4dl5d0jp"; - "nCTEQ15WZ_207_82" = "0cxagqav2q6kwq83syiad67nmzzkmrg9q0hlshbz6bjlcqmdi4jr"; - "nCTEQ15WZ_208_82" = "1c7vacsr2m6r7dy1b439c46xgxjqvq1gj9y68p2vargm5az444sz"; - "nCTEQ15WZ_20_10" = "1y38sqjgsjrfhmyhf688jir2hgkk871sjz8dm89lm5g7m5c1mgmq"; - "nCTEQ15WZ_27_13" = "0gb2zg5j3jcqjisa3nzsbif4rfi8vshl5vq2vq93d2132qgpzq3l"; - "nCTEQ15WZ_2_1" = "04nhmrvy2m4a2i8b5qadsg8h51k171df1kb7mdqn3hjzga7lg0j7"; - "nCTEQ15WZ_3_1" = "00aansn8jjh8yqyhr2fx8h453nahrdf8j1j0qgny1n1mhad4mc56"; - "nCTEQ15WZ_3_2" = "1pk6gp5a1g15zn5w00l89liz4w7w4xsmpcdk4x50vc7k5phy6vj7"; - "nCTEQ15WZ_40_18" = "0m58lby911lxqy6rvvs959qg5gjbppnfxl34hn81glc0lr90qiz6"; - "nCTEQ15WZ_40_20" = "0dnk9yikivxd557bpi9j7dbpwkf4sk49bg8lf0lxf86bdmi2l330"; - "nCTEQ15WZ_4_2" = "00rr4qwwp7i419sy5wr6f2lz82121ilrvvj0js45bvcqknx26c7i"; - "nCTEQ15WZ_56_26" = "09qjjavqjwrh9adkz6yhcjjiy55dg6c7imnbsi8qxi8xspz8nqq3"; - "nCTEQ15WZ_56_28" = "0pdqsrj4dphjb50r3v95wp1drc8rkdgsbisgg430dj9xaa703ijr"; - "nCTEQ15WZ_64_29" = "1qjvvfzv5nfjp1k1kdv2kz5pjssr2avrnjlxznqvlxwgs7rv8p7v"; - "nCTEQ15WZ_64_32" = "172whqdyyvqxyr3lijw2v45y8nvc0vk7z47i9xfmcydi2qfz8g3s"; - "nCTEQ15WZ_6_3" = "0kr0cf8aqwsn4x8kjwihsynvb99i8bdp4g91digbgcfpp02jyvgd"; - "nCTEQ15WZ_7_3" = "1c76h9xfflfihqyxi9a6dlmg1gwwr2wh93mfac3a3jnx73981gq3"; - "nCTEQ15WZ_84_36" = "1cvykpl9r41dwahjv3kik98y6sx53wiyyzywqc87mhnlx1x5876f"; - "nCTEQ15WZ_84_42" = "1jslkk9wc0fzbm6s5czpmaf004pndwc2ggwnxgkga2idn45204xz"; - "nCTEQ15WZ_9_4" = "0farphic6jyzc5x3ja715wdmvv5rfcgil1c49i8fxqlap5mlgv89"; - "nCTEQ15WZ_9_4_iso" = "01zxmn50r14n1a5gq75pia8mz4ibyqhyjl5d31kv3h69xgdrlizc"; - "nCTEQ15WZ_FullNuc_108_47" = "0yl5ll4j3mr6nhiz9ynn9w3hybgwdypg0b8zwsxz1rjcr3c8bmz5"; - "nCTEQ15WZ_FullNuc_108_54" = "1c8cdilw9n91apqj9lrv9j6hf6mcg3ndndchc96d5svrqlqk4fg6"; - "nCTEQ15WZ_FullNuc_119_50" = "19lb71cmmi4fvpb0bxmz0ipjlzg6b5hrlwiml4bj5r65km46whyk"; - "nCTEQ15WZ_FullNuc_119_59" = "0r9cwy2znpl59ynv2av6whjl3igm4b19rzh6sjqsm6a85d5jjdpc"; - "nCTEQ15WZ_FullNuc_12_6" = "1972j8lziq1ckwq2s7qpcf9g7mg3762kfrnbdjf4ilfw5b2b9i9n"; - "nCTEQ15WZ_FullNuc_131_54" = "06w9yl6a11ir8qjyxaakyzs8b51hf3jhm8nj5nvrh4f6cicp1g66"; - "nCTEQ15WZ_FullNuc_14_7" = "095x9pphc9lx71hlhpwcb71p8wx3b1pnv6qd3s6992visismyb02"; - "nCTEQ15WZ_FullNuc_16_8" = "005h4mbf9c7d9w61pmgghpxb5yh63i6cbyxyylngznbbbaxggjcc"; - "nCTEQ15WZ_FullNuc_184_74" = "0niyiq85bmbr596gfrsmf79rksql7n2gqdxw72yrki5ywc3iy4sr"; - "nCTEQ15WZ_FullNuc_197_79" = "0vbgg6m0b1wlrsx2c5xxga0crz0nwvcq9a88f032yjzihh6rscjd"; - "nCTEQ15WZ_FullNuc_197_98" = "0sf4q5bb4b44zkbxq51pf0xhpldr5dj5d0gqpqs40qkdlmkb9z7k"; - "nCTEQ15WZ_FullNuc_1_0" = "1il9j3ggn9kc8k8jpql46lw5c9lq45ngaip45vqppgvl3zcrc4fv"; - "nCTEQ15WZ_FullNuc_1_1" = "0nxvm11qlapnpdkkymqhy86axcvcx84r9hk0dswa2ji5gmk18jww"; - "nCTEQ15WZ_FullNuc_207_103" = "05qqg6ckkhv30nfbs5rdpiwz7dkgywjrd8a9gr3skvlayj2bisni"; - "nCTEQ15WZ_FullNuc_207_82" = "0s27py7i2h0va79q9ivmgrpwk5pxrjx9csyad76fc7pmvi4xsgjl"; - "nCTEQ15WZ_FullNuc_208_82" = "1xygz9px4jwz3vkbx86384775vhiqqv5l2rp2qi42zy8y8ijwaqd"; - "nCTEQ15WZ_FullNuc_20_10" = "06bgr8r6pz8cpvqbncjaazxw7j2qzhh183brs7r5mi6yckg318gz"; - "nCTEQ15WZ_FullNuc_27_13" = "1qrs82jscmxyhqkd4fa2kjglzgig23kqwc7r2n8p23352ggcsn9x"; - "nCTEQ15WZ_FullNuc_2_1" = "0jxam0p1ypd3x8l83d2f14h2av9wk1r69prfhl6pgd6pdh3nx2gh"; - "nCTEQ15WZ_FullNuc_3_1" = "0kjgsiidi33p442bpp1g6sss62qn4pj90ag4hcmdqsdf5m9vpc5s"; - "nCTEQ15WZ_FullNuc_3_2" = "0srxdvk5jh4ga4r8hniikzanfa8fh65xc4g51arxwd9sda4n0mqb"; - "nCTEQ15WZ_FullNuc_40_18" = "1x7d1cpglijq4rag57m8sp6qyzn3c7r3zs5z9jqarsaqc9wv2ypw"; - "nCTEQ15WZ_FullNuc_40_20" = "1l58bvdhqs9i4mgc39dw9c13rsh5vq5vh6zq8xk35150cbysiwza"; - "nCTEQ15WZ_FullNuc_4_2" = "0s1zdn5r9hk7bjk2ggn7bhrzq2iaxspdhmwi9rq1xbsk7n8k3wif"; - "nCTEQ15WZ_FullNuc_56_26" = "15ilca90cvw7p3w1xr15jynqnvnyw8zhpydhyq11x1kc647bgirm"; - "nCTEQ15WZ_FullNuc_56_28" = "16bs4yq4jr4y3431csabgps6330gcw1ymgm2161z4nmmyp988w1g"; - "nCTEQ15WZ_FullNuc_64_29" = "17wqyn8g5zbrm6ywvqn2y5kphy9xwbgijwlzxsni5k821nzmjyxn"; - "nCTEQ15WZ_FullNuc_64_32" = "0ivyka1g2cj6ign8wm28pzim3saas3bvnxqhixxkr91m1gl40b86"; - "nCTEQ15WZ_FullNuc_6_3" = "00v5wydvrvw1fgbzc436cap7amk8yr7dj5wf3ykyd6415vxmlzl3"; - "nCTEQ15WZ_FullNuc_7_3" = "06z2p0gx988q5w4d3c0qx6pj7lp6mqlz1qrnwy5lf4i4i4vcqkkx"; - "nCTEQ15WZ_FullNuc_84_36" = "0rfn82f8f9f6bgngrs67maip2kfhy42i4ppa904d7dspyqkgfa31"; - "nCTEQ15WZ_FullNuc_84_42" = "14lyhhc5jwccqnz85msaqzdx7cn2vxkvm2l9mf1p2kmgy7p5jis3"; - "nCTEQ15WZ_FullNuc_9_4" = "1895lr4yydzk4cry5wnjhpl6gs2kcspjlm2mv2y00sb7gzinjs94"; - "nCTEQ15WZ_FullNuc_9_4_iso" = "0kvjk4wvw98w7y02ishjacn9frncspl6rsxlzcd4y2pdk1ckr29i"; - "nCTEQ15_108_54" = "1bjx2d61qjhabfx28pfi64hf8br4gl67nzir3ygdpwdcah4k6lz8"; - "nCTEQ15_119_59" = "0g7wffsyjh84r2wv8w67skx8gwdb3clv9c1dlpijwqmpkcm3b8q5"; - "nCTEQ15_12_6" = "1xnnqp38zz3b61jb38hz54wv09w06fwwnb66sf93r1agcajvv1vi"; - "nCTEQ15_131_54" = "062sg81yrrdsc376gpq01xzsb6114sp6814ah9jbrd08qqxh04p2"; - "nCTEQ15_14_7" = "164p2fhlsmkcc6fibi28lysbfn8q5vds4f0k0kppi96absgrfa70"; - "nCTEQ15_184_74" = "1zqyvla6dj93cgfjw5z97b6wh6qy8pkrvcbwirjva769210rax75"; - "nCTEQ15_197_79" = "0mp1gddlwxk2vdyhra5lafvblc82g6n2p19lmjwkmnrmjqdqsz12"; - "nCTEQ15_197_98" = "0z2ymk9y0syzqj88mnr2kjn104602ajg17s31d9vi29lggy4cn44"; - "nCTEQ15_1_1" = "14dlybcc038ssv2xbyhing27b9zx07nkqvgf66ysbb83ym5dvibs"; - "nCTEQ15_207_103" = "1zpxky925n9jssdr036dyax8wxa0d478l4mjl50bjmzqhr8wl7hv"; - "nCTEQ15_208_82" = "01jf2mrknx5igs0cvhm7xr25gr6z93bvj12cbq53k15fk5niyglv"; - "nCTEQ15_20_10" = "1vhk2lmpf5kci9173v5qh2gsz7zghvjb11x1mln8yqcdxaq4az8x"; - "nCTEQ15_27_13" = "1md9xv99m6jcdqldhbbypdix581nmhpyanvr049l5c1a2ab5nbpa"; - "nCTEQ15_3_2" = "0nq1aj4hxjih4z4xlhjfbza2dp2fyhwbccjgmgh2za5y7rzgz9fk"; - "nCTEQ15_40_18" = "1gb4kfs207izq4dij9pqbmwm10vx6f1h7pdnf749jysmf6nayndh"; - "nCTEQ15_40_20" = "0b44nkk315a9zaq3280wmsj67rkxw4jyk9v37s859fikr5v7s0sv"; - "nCTEQ15_4_2" = "0c8r4vq3phi40v5h4p3nm7by72pz27zqwd67z9slmf1jy1yilnly"; - "nCTEQ15_56_26" = "0ndyjjh7sxnhkamx182rpax0kcc2iqzwnmh391m5wh629zk0av8i"; - "nCTEQ15_64_32" = "0ixbr2d30v6slqvp6gpry1159rx5m4hd1msymgli1w9k7pp7xjz5"; - "nCTEQ15_6_3" = "14ars149pssaiyhaln9zm7vz3wzj2597cy2xasyhlrfqhlgrq056"; - "nCTEQ15_7_3" = "13b9wbm2hqx4lixq3dad1y3cr6didcch8kg7mqm9lgbism7dwaqw"; - "nCTEQ15_84_42" = "12vkqpvjjyh0x0hbn7r4gx5za01yqs9a7lqirdxd15k04fp5rnjr"; - "nCTEQ15_9_4" = "1rkxhxwp0v9dm6f71c5635ihlspfx0sj666maif4iaw1sf4hazln"; - "nCTEQ15_B_90CL_Au_hess" = "13sdn1ng4nd6935dksk7jin8yilp29zys3d0jvf7m7vx8gyxi187"; - "nCTEQ15_B_90CL_Pb_hess" = "1j11x8y5sbs5lz4z06wcl702ijvh1bcb4i222jdcq9gh9j40xn17"; - "nCTEQ15_B_c_90CL_Au_hess" = "0k0pn3yqb632j254h8w9wbdvcasnfxr7d9g47drqw3f4w1as3s16"; - "nCTEQ15_B_c_90CL_Pb_hess" = "0gvvwnc298qgxhpj4wgnzcrgz0wqlj5r7sfsl1fj21zhm3kc45jl"; - "nCTEQ15_B_d_90CL_Au_hess" = "0lzfa2gsl5cs2i6y833lhvf2pifzkysj9jgq22v9iyyz5q0nbsh4"; - "nCTEQ15_B_d_90CL_Pb_hess" = "0zp7dirc2l42f9zjyq1a2qbnir1bbj1firmg3s856mn7sp3p4i0k"; - "nCTEQ15_B_u_90CL_Au_hess" = "1w2ifnl9waqvsaz1yg696mmqxcijm2bphq8zp3rcbimck3rmr978"; - "nCTEQ15_B_u_90CL_Pb_hess" = "0j95dg6kyvd30qgivd9495glcd152cr1j3zh1cg76s6sdzfkhvs5"; - "nCTEQ15_D_90CL_Au_hess" = "0y3n008i22g9ny0v8z6hyc47730xb6qldkpall6p8icn8yzfdga9"; - "nCTEQ15_D_90CL_Pb_hess" = "0mp1plqxsd6j0ybnf7yrl4hgl68a85q56vdjhs911xah1bgrpix1"; - "nCTEQ15_D_c_90CL_Au_hess" = "1xk6ngc488n9immd9nbv8ygvxav5n7b7902k44rkxnw42kbx2c4m"; - "nCTEQ15_D_c_90CL_Pb_hess" = "1ldig46l08n00jvj0dl36jsnpjl2ycv3jdr9d9g375rwgv671kad"; - "nCTEQ15_D_d_90CL_Au_hess" = "059fz4rfhydnk25hmabavwi346cy2hzxaw2ciq8jx64fmawb3v79"; - "nCTEQ15_D_d_90CL_Pb_hess" = "0zgs89yjypn2sd97948z2r78sydadivvw6wy7pwi3a5b0yx1zpzn"; - "nCTEQ15_D_u_90CL_Au_hess" = "0j8sfih3r2wps1l7vapnllh88ibw7672f646m5p67aw5k2an4f8j"; - "nCTEQ15_D_u_90CL_Pb_hess" = "0d2nxsabard1yq8f2v9a7kwk0fzv549hx1k15k0dfif9523i6xqf"; - "nCTEQ15_Jpsi_90CL_Au_hess" = "0x75jizpqi8vss62xb2913vdhvckq2b468iqxd0ggr0fic1f8q9a"; - "nCTEQ15_Jpsi_90CL_Pb_hess" = "09a9s6gmf7q9rk8c88iskra5kxaiz131s5650964znxv29lpzlqm"; - "nCTEQ15_Jpsi_c_90CL_Au_hess" = "0mh3ikdkca7xc5bc2knjbyr7dkgbydnaa4i1gqln0i29b89j5nw0"; - "nCTEQ15_Jpsi_c_90CL_Pb_hess" = "1gs39gla77sqgry1799l9kapc1c48pzxgfba6p70fdbwdac45n3j"; - "nCTEQ15_Jpsi_d_90CL_Au_hess" = "1qn4f4nn8avjrsdqgab25053zadwx7vlr27w8bsmcxg25si104y9"; - "nCTEQ15_Jpsi_d_90CL_Pb_hess" = "107w4yiv6dl8gqfx0mpbnii06wzf15ih2kqmb8hkmz988x49l65q"; - "nCTEQ15_Jpsi_u_90CL_Au_hess" = "1mdm8qlzkyzrszsng49ns9hq7zdqaal61vbi64449fkvmxd0a7mk"; - "nCTEQ15_Jpsi_u_90CL_Pb_hess" = "1y0bcr3g9znjz2c3s4487yjl1ipf0ls05krfpdn8gcsxymf4cirm"; - "nCTEQ15npFullNuc_108_54" = "1g8id10rpys9566r8h92diqrr43mww6q8nhvlns0kfjkvkr22m9y"; - "nCTEQ15npFullNuc_119_59" = "0df499pvfls1281zkvngrhicnc0ac0bfwamzs027k7f2y6ygkfb4"; - "nCTEQ15npFullNuc_12_6" = "0mb3zixcikagsqzpxb7jzrcg05dln37d7anz5359ssjyd6p1mqyi"; - "nCTEQ15npFullNuc_131_54" = "0i83f1wg81nr742jf9407w7fbknigz6pyx64h7p65x82s4wmj9gf"; - "nCTEQ15npFullNuc_14_7" = "1k2554rg82msxzkarjx85p6di3kmfqxmbfxpasi1x74laz38663n"; - "nCTEQ15npFullNuc_184_74" = "1pnl4y2arxf87b1pp95b9jajzlqdyzs7mv82xhmw9fcn9yliy5s0"; - "nCTEQ15npFullNuc_197_79" = "0d5c6g4185k6pwm5bs5fqlwc97l0gvf6bhk9l8a5vc039dggsgkj"; - "nCTEQ15npFullNuc_197_98" = "0ql9xnwggsqibld13yisvsdkkymzph8wnqffnxhlyp5digwhl64v"; - "nCTEQ15npFullNuc_1_1" = "1fq80hzfy16gs00knvl0g0yqrys27vzyk8h5jzs1ra981zgcw1zp"; - "nCTEQ15npFullNuc_207_103" = "04bg7hnngfsckk92gdrxbrxhsbb1ac1s7dscj7ycdy64fxn4lq8x"; - "nCTEQ15npFullNuc_208_82" = "0f9ddimq9av2jr3yr15n630bi30bxh5nxrsbrcfw9cx8dwnjscwb"; - "nCTEQ15npFullNuc_20_10" = "03dv3z7j69l97xacd38wbp7iyyi36g0bbc2xmxhm3l64rjs21bmz"; - "nCTEQ15npFullNuc_27_13" = "03lb2dznl5dpv0cwsl08dlrh7x26yi9acx3n70imr13gspfxp8ag"; - "nCTEQ15npFullNuc_3_2" = "0rqjxc8q53jndxjrxd293r1m8gin3vif33jzr35y2ail9bhkjyzp"; - "nCTEQ15npFullNuc_40_18" = "1827gpzdrxdkg9ikk7pjgv9h983mwzk21p60635l1zhwby5p4mn6"; - "nCTEQ15npFullNuc_40_20" = "11mjdibgypwpphm1wmf4z311wg4lp37010vwyys8q6d927jzikn2"; - "nCTEQ15npFullNuc_4_2" = "12gx03drv7hnmsgk6sni7mc7c4rbpag5gn2czyha1n19v13rry93"; - "nCTEQ15npFullNuc_56_26" = "1hq6qv19gqzjv57msdajb9kc0lv5jvl3b6x2fc905lg0dc7h2ab5"; - "nCTEQ15npFullNuc_64_32" = "15gq3l91p69dba5gfxvh7j4npwl7rwkakjnsv9lx84hvys7hgba9"; - "nCTEQ15npFullNuc_6_3" = "1gcxs7vcjcdyniczd1rprvzlc1p9yf08sy1fcrny2jfbxkfndqwx"; - "nCTEQ15npFullNuc_7_3" = "09kwf5kbshw4pwh6iilqy1mzgvlg83jhakmvvgz27f569f20ci68"; - "nCTEQ15npFullNuc_84_42" = "0ah349jih2ia0x14mnrygzzw38prfgcmbxyw1hdvzqvgk73wazwa"; - "nCTEQ15npFullNuc_9_4" = "0gsh5jmyn7jlasp9ixx7imvkbp5rxmvfa480vy0bnxwjwz0924ia"; - "nCTEQ15np_108_54" = "16hsl5ihcbx7wvrabrff5h422zfhlfrpskn5dy8s1phhla4r4ff3"; - "nCTEQ15np_119_59" = "1bwhbfhw5xyb1dm18vxm095l1d9l9v0yl072qdbb6z9l29pa71dp"; - "nCTEQ15np_12_6" = "0zv9g7r648f1h1f9qifii0mk2afdvphbfib3hp2sf960zb0d0nsv"; - "nCTEQ15np_131_54" = "19sn6ig1c5smxi845qyflrrqaivm4pphwbxpz2zd9r0qhn032mlm"; - "nCTEQ15np_14_7" = "07pyaik3h2yi05hn49fv3x191i4x6429bb6kywy999bzfrkjndcp"; - "nCTEQ15np_184_74" = "1s2vmirmi1npw3pkxpzxjf9i69gmrl1dqrm2s0cfzl6286h87scb"; - "nCTEQ15np_197_79" = "0p7lnffr4gy8qad8nsm6qfaw05s9pndkw0n9yb6v5i6mqg0j3cgd"; - "nCTEQ15np_197_98" = "0vmjvjqkdn5cixsnvl9lvg07lrq17yw5pf2mdbzkrrfblqki6g0x"; - "nCTEQ15np_1_1" = "1fndfff1lialb2qy08qp44w4605j9c2acrwpdb16k3awj88kx7mf"; - "nCTEQ15np_207_103" = "1fcaw2hqxnzhs9glrh9lxvpfh0sn3mwahgd8d7hnfikrw93v0sbz"; - "nCTEQ15np_208_82" = "0glf5nw1mr42icmbcjliz627nlsb7a5hyp591ng9y7dh41hxr01w"; - "nCTEQ15np_20_10" = "1ka5hnq9cmr4l12ajmw4fpgdzcf0pjlw2pk4lkw6ai1h5h5absa5"; - "nCTEQ15np_27_13" = "02dmzdqqh58h7232s2hcjnpd76rll8vxynq1bx059mvxak5lr5kw"; - "nCTEQ15np_3_2" = "0jxg5f5n4yp4zbdkm9y7xd40m89pbw5687hz7mylpn9n3phsi58y"; - "nCTEQ15np_40_18" = "0yp65xq318qw6xh3wm0n4s4a3s4ahvl14kq3cmwq9b954c5a5vkl"; - "nCTEQ15np_40_20" = "1c367xb361p5mdwyda5iwswg7wb6s6gjibdv27n2kq41p1qp41y0"; - "nCTEQ15np_4_2" = "04q9gq8163lhfjrrp0ysqyb5sx2nkw5mpz70daqnxvybavbkg7mm"; - "nCTEQ15np_56_26" = "1qgh3g6xwk9jc6sd7kjj89w8mr89bhpdaiml5g7lvdqn39l95ng6"; - "nCTEQ15np_64_32" = "02966xmh15i7kg9iif19p5c27rv369yikpm1xqclf8dz45a7xsry"; - "nCTEQ15np_6_3" = "1rr7wr9wwsjfgnrnfvm7nrplhb38zym6qiyg2sagq7saw6kqpprz"; - "nCTEQ15np_7_3" = "0ndqi05g88b769p1chfc6maz6wvs33rx45r4k8f68n79yy6kvrh1"; - "nCTEQ15np_84_42" = "0v968jw1m9ky1mh82w1bjidvg7r7cx23bnpv0vr4c1kqz0n5hb5s"; - "nCTEQ15np_9_4" = "0akxbyrs4y8gmnjiwma8z8ryrzmaw6dj148iq7ihsllwar3hp3p0"; - "nNNPDF10_nlo_as_0118_Ag108" = "1xqhzgvkicxd9wy4lnhqw6brsksxqsq429r6bb0ghn1ll5ln4qzx"; - "nNNPDF10_nlo_as_0118_Al27" = "0z836h7a5abbwq988zdvvf8yhr92krzzmys6lkkgkcffdf2pc0zq"; - "nNNPDF10_nlo_as_0118_Au197" = "1f6vn6n0zz8wml8zn7n2n6wj5y41yanw9b9av51m5kiq4n1r9lrk"; - "nNNPDF10_nlo_as_0118_Be9" = "1jy2cix4gkx648dypdqfj7xi8gdlflh20xlasmwl78av5j7s7rs5"; - "nNNPDF10_nlo_as_0118_C12" = "1c6fvp82cs3464akqf0skrqpcvyp75yqp39zxafzgbqd4wc3pv9f"; - "nNNPDF10_nlo_as_0118_Ca40" = "0r903a01085yhfagnljvjaqfn190r3q0ggvx87kh54xsbv1wkvbl"; - "nNNPDF10_nlo_as_0118_Cu64" = "1vq8a6drcp606fkx8mml2qq37if59cakmcq73y4n7c7swp6q51r3"; - "nNNPDF10_nlo_as_0118_D2" = "07kjzhyh6n6723h2fylgwm7w7ljxz4m6fs9bgwjxp987i00msrra"; - "nNNPDF10_nlo_as_0118_Fe56" = "1smkjmymykhlp0vvlpsp6p6p44pw5aa705sw9lcyxmg8ccy9kmpj"; - "nNNPDF10_nlo_as_0118_He4" = "0mdxsh41m0vzcdq4axvz81m9ra0p6dff88k09gjb4adx9vv52mjc"; - "nNNPDF10_nlo_as_0118_Li6" = "1hrryxhhg9xxg817brrd39k5wz6iq1fv6z8sdabrpxn0nwr1bj7r"; - "nNNPDF10_nlo_as_0118_N1" = "01h7g4w3nc09jyi7g8j5yx2yzqair3ysbx9rx244k1rjx6jppian"; - "nNNPDF10_nlo_as_0118_N14" = "1ny3znivkkl7xhdw8pxkdadwc957236rh60wviiyw4cdqjb6a3iq"; - "nNNPDF10_nlo_as_0118_Pb208" = "066w59xm6lkwrm3glssc6n3qyvv38mx47mkx39p8z9r2spb8igks"; - "nNNPDF10_nlo_as_0118_Sn119" = "1mqx7wj095v0799wxbvfxvb6bl1qh5wdkf14a8gqsj0f5qjnpmyw"; - "nNNPDF10_nlo_as_0118_Xe131" = "0mz9fgxfyx1asi2vxs1xfwn8z51z08naiq1ycl77f4yp6wim6s54"; - "nNNPDF10_nnlo_as_0118_Ag108" = "08vy16fskrvc62y3h0hsikmi6q86njwfm2msmajxbd7vzcv5wkkn"; - "nNNPDF10_nnlo_as_0118_Al27" = "0vm95lawgsncsx10ypy99746sz34y6shblkj9pgn6si2cy8gpcwp"; - "nNNPDF10_nnlo_as_0118_Au197" = "0b3ld033f2hwjaqp5p5pzmmzfid8hl416a1q8fc0zmd2lfiamsac"; - "nNNPDF10_nnlo_as_0118_Be9" = "10skffir8hqfv2wj01ghc14lfs516kmh59q3v48nw3a724kxr93a"; - "nNNPDF10_nnlo_as_0118_C12" = "12rrpcq9bvwcncj1hk28wkym5zzdjkf0d0pdj1nx9asm6vpbjsdv"; - "nNNPDF10_nnlo_as_0118_Ca40" = "0k914fnqsv45f16s6zmdwbnbnhj5lxnrk9pbnnaap4vk7vx7101j"; - "nNNPDF10_nnlo_as_0118_Cu64" = "137n1nsq75g0n4hmbqfl1gihngfrz0rqd2gwj24m5byhbylwlg83"; - "nNNPDF10_nnlo_as_0118_D2" = "0xa17gjjh0mphg1h711vb6p2pjln0lqy7401lamnib2z7p7mss0m"; - "nNNPDF10_nnlo_as_0118_Fe56" = "0h0qwbckdcppqgbhfy3kyy9p4nryh3p45sjmlxhm94mlznipjwrd"; - "nNNPDF10_nnlo_as_0118_He4" = "022h44i8k2ybvm9lkgc4lkcv4z7r0xzlrq2bxyqkfmpp5fpp7gkw"; - "nNNPDF10_nnlo_as_0118_Li6" = "11bci8mnv57a583ayrpvvnz4lsxz43z23iqgqjc3b3rychgiz57a"; - "nNNPDF10_nnlo_as_0118_N1" = "174gscxa2acqpgf2mks5xpim1jcpb0vg76pggxazm376vyyjk883"; - "nNNPDF10_nnlo_as_0118_N14" = "1g2gwnbfzlfa094px1rnjgk8py8qzwq7bi68n7p49bqjj88km3av"; - "nNNPDF10_nnlo_as_0118_Pb208" = "0bdi3z36ckf788v3ld3ngvchyxzsxcfl9fj7rzs2lwkg80rclgd9"; - "nNNPDF10_nnlo_as_0118_Sn119" = "0k7lnr1ils38sqybipmf13n582wb0cf9rr288ibrbmx15rkk5c3w"; - "nNNPDF10_nnlo_as_0118_Xe131" = "17k1afk6j53nl83ixyy6nyds3wy5agacdyn62bwp7ykfs8x97s4n"; - "nNNPDF20_nlo_as_0118_Ag108" = "1fb2h6752vn0v66h12dhhk2izxjs4b10mdqx17djrvpkzl97hf8d"; - "nNNPDF20_nlo_as_0118_Al27" = "1lfkg84hf0chgk0qzp45ch23pzjixkzxxh3x7xphcmnpri4cgl3r"; - "nNNPDF20_nlo_as_0118_Au197" = "08ll61b96iggm1qnr9q2qdzyxasxn9mlshnxz7kzigfsnqqnkfbw"; - "nNNPDF20_nlo_as_0118_Be9" = "1g4vlr9p6i6n87bx6w2i5d4qkhymldkyxj1i2qnl8v467vhsz6la"; - "nNNPDF20_nlo_as_0118_C12" = "15366p04rh31nnd6zxcmcs9ki5fwzn8d8cvzms45apnw928k6pqn"; - "nNNPDF20_nlo_as_0118_Ca40" = "1abxkr4r5psi6n8rrsbf97gwwkh1dg9jqfd46hn2725r22c6k8l4"; - "nNNPDF20_nlo_as_0118_Cu64" = "1nkkiwx22b649pmyfykn2ggdq99y985mnkv3fnkm8i43scwbswvb"; - "nNNPDF20_nlo_as_0118_D2" = "0gvf9qqgr4ixm9cf2654xyvkc624k5ijqwdds61frljlhd49yqm1"; - "nNNPDF20_nlo_as_0118_Fe56" = "1ci132hc8mpsj0zjr9fichnkapagjs6q9pqli0yzgnnv6l2aih3a"; - "nNNPDF20_nlo_as_0118_He4" = "1phq7m6lbx87s4whs2xygigq7fz1qhzj3nd9anx5r67w7q99rcad"; - "nNNPDF20_nlo_as_0118_Li6" = "0pwdqrmivpm0j7hrg6h2qqshpna2vjlslxnz0sd100kc3lfq7xab"; - "nNNPDF20_nlo_as_0118_N1" = "09y7pd3nnys49w25gb4524x5xkahillvaypjgncbn8n5x1a11nsr"; - "nNNPDF20_nlo_as_0118_N14" = "0nb3kcmhbyncp9frs27ww550mjl3f7yiahyyrm3aik93ycpm16n7"; - "nNNPDF20_nlo_as_0118_O16" = "1wmi63l6cpj3nx0vwiqaa1pfw0im5ps96g7842428skzrg0q4yx3"; - "nNNPDF20_nlo_as_0118_Pb208" = "1rwb7vca0y1aj38mz8m3wg07q9hq66qd5j3y6hs9bh0jz6hkifzh"; - "nNNPDF20_nlo_as_0118_Sn119" = "1dan86ckd5padipp4x12x8msfg5p97b8hwxm78gfyf88kq725m6z"; - "nNNPDF20_nlo_as_0118_W184" = "0wzd8vw2svf3mzpyy1wryr5jz3anhykp5z3cx4hdljprws2b8nll"; - "nNNPDF20_nlo_as_0118_Xe131" = "1a62qi3qy5kli9q80p2w80mj5v3ps2g6p40zxlgm65q5mphkx1qi"; - "nNNPDF30_nlo_as_0118_A108_Z54" = "0n67w44rmz5s6cg2h58d8sf51dsfd0i5g09dh08mgfcn640bqlqw"; - "nNNPDF30_nlo_as_0118_A119_Z59" = "1zj5gn5021ig0j6p7jpyy683avg0890blmr90yjm6skqzxfjq48i"; - "nNNPDF30_nlo_as_0118_A12_Z6" = "0jvaq9a1w19dybv2hzvn8swk4i4z16lab9yfhbywq0vixyfn1swd"; - "nNNPDF30_nlo_as_0118_A131_Z54" = "01mcqnixjw5m9di508aq8fp74f3aqnvhc1bjirfvi3ca0jz0c1jz"; - "nNNPDF30_nlo_as_0118_A14_Z7" = "0hqpni9fxbf5qfamcirglr04cbwx58pwylqh8hqm3vc03ap3nmjd"; - "nNNPDF30_nlo_as_0118_A16_Z8" = "0f0h3hckxg4xgfd6ldblavhcidzdy2b5660a5nvv96y63sdsx2x4"; - "nNNPDF30_nlo_as_0118_A184_Z74" = "01jsbla72c3b6gbc7w4nx5bb5ws3g864avznb9vxmmk3prib7n8x"; - "nNNPDF30_nlo_as_0118_A197_Z79" = "1gm7nx0cn3lmjlsy6c7dr5vzyfmi1fcdib9656d4039m0ningrhg"; - "nNNPDF30_nlo_as_0118_A208_Z82" = "0r1spnj4qmjwpjybqv9aa6w3wybvgk4qzivzwz4s9bacz0kb3z4n"; - "nNNPDF30_nlo_as_0118_A27_Z13" = "17vmr3pwjp1prb83yngada7sw8553sv39dnncksabnklfp1l5x59"; - "nNNPDF30_nlo_as_0118_A2_Z1" = "1g97mc7c14hnkfsfvg4n9jmb4l461i9lka643s626hw0gcq053f5"; - "nNNPDF30_nlo_as_0118_A31_Z15" = "0h5rx9113yq6jw1l2alwyvw77vv733y5mcpa3m9773s7y61w3fpk"; - "nNNPDF30_nlo_as_0118_A40_Z20" = "1937kk4039hi9cslw4417174s83rs4n9vm16ay70pp1c8bcqzp6l"; - "nNNPDF30_nlo_as_0118_A4_Z2" = "147npkmbvzk6j95hnnil6jafc2gxjqavaawl9cilr93f9h64w54w"; - "nNNPDF30_nlo_as_0118_A56_Z26" = "06dxsapqirmajh107j24b3w2nhqz39gs9c2pglq71fc53i0fra5a"; - "nNNPDF30_nlo_as_0118_A64_Z29" = "1drvfd3i1drrb15m3vk9sm2lzx2x01da44gdq3wbc90nxvzc7d56"; - "nNNPDF30_nlo_as_0118_A6_Z3" = "0zp1cixj6ixayzdra2i5qyfn2b6y6qfxd5d1l101n8sgf4bdh6fb"; - "nNNPDF30_nlo_as_0118_A9_Z4" = "07i30jk29cgdbdk4n5acdki5aihaki5w0mqibjww1hy7mwh4y45w"; - "nNNPDF30_nlo_as_0118_p" = "0k4bs4zhlm7l14mbd2q9n0n7rdnpqwgnfwj289ql62v3kh8mnn18"; - "xFitterPI_NLO_EIG" = "1v6mfhmcrmdvica0wlc2ilfca1srxc7vjyli113wjvpd7wfpnvj5"; - "xFitterPI_NLO_VAR" = "09mlsww89hhm2s96rlkqbkfwwf9qkblw7n3nnrgas6l1kn2hxq1i"; - } +lib.mapAttrs mkPdfSet { + "ABMP15_3_nnlo" = "028q5xixxjxhb8sr7l5v5mwh9mkszm5m59fgnpb69yxvv40a70v0"; + "ABMP15_4_nnlo" = "11zjp4dxmgp69kdkmdwqkpsajvwjrbwylmwgs56mgjb0vgb8wk0i"; + "ABMP15_5_nnlo" = "0z47g5fwh53gg5ws5bbip5q2m5mm7vl09q2w58g6ah9dk25r10ll"; + "ABMP16_3_nlo" = "1ylppc7clyk74mr7qgk0r2cknj2m58y38r3h1dfhjjjmdkw1g1sn"; + "ABMP16_3_nnlo" = "0bwirm3wqyjj6i3asya7kjmmjhqi69l1rnc6gnq7v136ajmv96y0"; + "ABMP16_4_nlo" = "0wx00x98wgvhwsj2fg4kp76n9fhv2s5mbar75dsp6xs4v0d1w1g3"; + "ABMP16_4_nnlo" = "1cw52ijyrhgvyqc28pp278bavy9acvs6qywysgc7qjifygb14mca"; + "ABMP16_5_nlo" = "0s7yz85fjfkmmxj3xdkhz5658n3nx8rr4yjz4hrqbcy00zdcscr2"; + "ABMP16_5_nnlo" = "0iyypvj4645g7nh8w6v88pz37p81bxilgc4p7wlkaa90hiq0wrk0"; + "ABMP16als112_5_nnlo" = "17kg6gvl09p5gm99yb9d8hkl1q51904qflsziv3r5ybxs18ym5g8"; + "ABMP16als113_5_nnlo" = "1gaiyq70zxx7c7c0gkkad3ygbhdwc563al2a6ksy78q8is3bhdy9"; + "ABMP16als114_5_nlo" = "0vnwbz6v2d02d5r34ysd7b4d22h948f3zri2n3yj93k6za9y42gw"; + "ABMP16als114_5_nnlo" = "1gd41d8ay8i8m35qfqsm96jcv8vx6hpdsrdzsj415f4zpw5j29fm"; + "ABMP16als115_5_nlo" = "0pyk43d6v3hzcq487nzj5awd2zhcjbg9ak0pcs1lykhvxwm227hz"; + "ABMP16als115_5_nnlo" = "0i70z8i0qgzr875szdh8sa6x3xcdkvrfsba97a6ha7b6km4p1yjk"; + "ABMP16als116_5_nlo" = "0nyrcb3hbzngj5j3yhpwlnz8a7dx7higngzmp26kmcrr4bmhiq6w"; + "ABMP16als116_5_nnlo" = "11rph6vmmvvsi8msfp2agb7747n7xjgxb7z766i5jkvnggbmz75m"; + "ABMP16als117_5_nlo" = "1pfjdxxdwrwz5n5206jcv61l8ycliwigqgram6hlm8ibl9a828cy"; + "ABMP16als117_5_nnlo" = "1sz9hy2m983aiwyssg60v4kq1zvz4xxvbzrgsdik1qv13bj4wx9w"; + "ABMP16als118_5_nlo" = "0ddaf2a7v3kdynsmls6zxld9zflv9m8qkp8gibc5xd6vqsg64f8x"; + "ABMP16als118_5_nnlo" = "1slvr5ygwwryk63mah45xp5x31qwrf0gkrnh4p9fvl4rdkji6z0z"; + "ABMP16als119_5_nlo" = "1brv76x4z0r0vrxr51gqvfzn4d03srhvab6dmxhhj3sy23qnbxg5"; + "ABMP16als119_5_nnlo" = "1iqs1bi8r22awflf698cj39q8s2w86fwvdfgqb6sr8csm36ih6qp"; + "ABMP16als120_5_nlo" = "133vy2zhvh49fa9xkp889mxy6xbriv10q8r4lx74wb9d1kqwfx81"; + "ABMP16als120_5_nnlo" = "051bqfyh2017vnvlisvkm1ik6x7n829p8205f5algsw7wi1s7b9v"; + "ABMP16als121_5_nlo" = "1l41qgba24rslg6ascsn1i0y0y0d7yh6hszhclxqyn07gzwq7p78"; + "ABMP16als122_5_nlo" = "1ivy4m9fah8i0ipfxfq8caxa7pz8y86wgrqydg9wal9qin8n8xcd"; + "ABMP16als123_5_nlo" = "0gcf7dqr1gzjfa6iy0qzivyibw72qpagfda0a5aksd0h6aap5mxc"; + "ABMP16free_3_nlo" = "1hxlbmc2kzd8yai7ipyc95khdsawdcnzxzr0vkk3h42fxczx9y6q"; + "ABMP16free_4_nlo" = "1ckwbyj18bgvpv16r6lx3866ca4frq6rxmzvz14ak6h8mpwvcnmq"; + "ABMP16free_5_nlo" = "0sbkrn3g4048bn0y5bm6dqpn1za3761n6x40k7i4pdi0b1g7zlc0"; + "ATLAS-epWZ12-EIG" = "010ddmyfrmscgd1xdjsxsjc773jlvbh3s6mjbwk9zd298i3bf4kx"; + "ATLAS-epWZ12-VAR" = "1r9ip8549dzhs02skm8v00g6nsh7q1rwd3syz3bd6cl4sqhs0k37"; + "ATLAS-epWZ16-EIG" = "0b1zzp8p0kh4xjn76nm6waqlvdpqvnwyqsnnqdp2n7b9r9ssryyf"; + "ATLAS-epWZ16-THEO" = "0b0wqa203b2x159y54xhf9yh34lkchp48vp9693k51g9aznx8gjm"; + "ATLAS-epWZ16-VAR" = "1zkhlv8yxfla46gj57119w9prsd3zyy5vg275bayfwa6b71gmc0b"; + "ATLAS-epWZtop18-EIG" = "069rysd9mf3cshx7xkcv7735ydh2g6szvljbfkcqwckaqjg2x3v5"; + "ATLAS-epWZtop18-VAR" = "0hpyp52dwl8fnw47pyw8g7fsz97wr6sk4yli6sx0zbj8yy2j28yj"; + "ATLASepWZVjet20-EIG" = "0lvd3zkmisx95rbjx7r9wkk0s0mxvaybp3pk66sxrxf1bj1l9r52"; + "ATLASepWZVjet20-MOD" = "1iyb50isdsy3a5wnlm0185z9bfs6nxwlcl1aqlh4h3j1dbmz4ba9"; + "ATLASepWZVjet20-PAR" = "1kfqii7sbcs8zdsyd9kiy3r233nawc9yfc23fb6ql0xcwfzpyb1d"; + "CJ12max" = "1vk2zkaiqbl6fixaxy7mrggmmxv7lvnw736lxm5sh25dapg6s8ag"; + "CJ12mid" = "0s2558ihypn0l9qqx25qwnawbc7fkbi2wwwhbyb108rjk2klaf8v"; + "CJ12min" = "1kdla638m3axr65ndid9irmqhby4gl084r297xw3jxxlrb0b7hj9"; + "CJ15lo" = "0hww26wbcb3i61z41s518gj41mn5gcikb08pdzyb5vyrl63b39bf"; + "CJ15nlo" = "0acmyr5zpb7yzs2pikhgf8nx8l7csmai4sv361l7x3miqir56ss4"; + "CSKK_nnlo_EIG" = "0fdc2a7xax7xl5n5f3ff5dcf7zbpk43z4kfy3ffij2qykrwfx7bp"; + "CSKK_nnlo_THEO" = "0srs535f9xydqfzyy208304yxah1rg1r5ilx8hk9nvgaiy7kwnvq"; + "CSKK_nnlo_VAR" = "1iyiam3kbjrckh0sw290hwi04h5cqif081afgd16f0a44wbcjsi1"; + "CT09MC1" = "18ap08vh1f4ivibq5z57wv7lwvw1pzwl865xznzzcr0jy4f59103"; + "CT09MC2" = "04yxg4bl0dcgh6hb9g223wm084w0q1y2lbd4z7w8vmvvvn579ij8"; + "CT09MCS" = "01vjpdgy79gvk3w4blwjgfqpf50mjdi5kmfcgnlnwxp5q0804pgf"; + "CT10" = "17glhnqj4yknqy70zs7m097n1qq9fqljj3mna6qxchmgql04dvxw"; + "CT10as" = "1709bb3ky4mpn4cgx9lda8swmvb2pl70ly1gzk4ahgsflkb8iaj3"; + "CT10f3" = "0ijrx0wm03r0yg6f0n4vwp1c3kypdjpmmnv12gk79y193bfk362l"; + "CT10f4" = "14icbh8lg9290wfalr1bsx0zff1df19x0qrjqh8n0y9ckqmkbh6l"; + "CT10nlo" = "14ib003sxpxc8awywjckbw124aqhmi70wg4hlwc2nvdh46sqk11b"; + "CT10nlo_as_0112" = "0n2abywijgjys56kz5qm30arh3v5k685l0gayl4mdablbw0ccaca"; + "CT10nlo_as_0113" = "123kbzzfjlparffgmqpimygzjcn0wi1vnyrkjfjn2kwcdjazz8dp"; + "CT10nlo_as_0114" = "17lgcbf7914dfb89d4v8fal69zq7gmadvha8gpz0wfw4p0pq765b"; + "CT10nlo_as_0115" = "0rgpc3mcsd18yg4j41k9hhvbjbi3d1zrd9fq1314m4qvviq6d9j7"; + "CT10nlo_as_0116" = "15xyhmipv9xbiz3jaqdj59nyczn35nq14183xz4py68l2v20smqi"; + "CT10nlo_as_0117" = "1qf9azafrwqpyp5flc912g2frfpi899vb032yrrgqj2l1flg474x"; + "CT10nlo_as_0118" = "1jra85s6df6vvmljkf8gg2jkj3r6b1yl6aidzlm3j59di0fk9xp8"; + "CT10nlo_as_0119" = "0y7k0w592j777jpbrh8v2zh1l6n38xbxjvyiv5x4pvwi6zrp9ppf"; + "CT10nlo_as_0120" = "0mh1hdmic5c3krlb1xypy0n6r86r7da0ay9183xwb68d1kh4j630"; + "CT10nlo_as_0121" = "1gwvgj3bwv8fz8mbmgnfsy0bvsm4h9d898mf1kcaaivh56sfial8"; + "CT10nlo_as_0122" = "1jkkqcmjynd30paxc9z9gpmxkfhs6ad3x5sms5980jx291rc8hgd"; + "CT10nlo_as_0123" = "0gppcp49275pg3yv37mzkx7az6298wwy7gqla3gzxfzlas0ybg0b"; + "CT10nlo_as_0124" = "1irl19q4wyw36dwhln1m4y7y40by5xgdjqpgj7sqaix8jvijc9bz"; + "CT10nlo_as_0125" = "17c6n2prdsry2phqmaykrf1yc02mvhacb87r7yl0nhkhx80kysk2"; + "CT10nlo_as_0126" = "183p4fd85zs2c1j0zwfsa08wq6v780xvwbg44bpm52m4ih1dgqy3"; + "CT10nlo_as_0127" = "1vcpadkf90x9qiqaplc25hld7qljk5d3lzs1dssqi5fh1kci8qd1"; + "CT10nlo_nf3" = "1dfzas3z075riwx26bkmvjck42pjgbm32d1flg5rccsxjn4pmmm0"; + "CT10nlo_nf4" = "0npv1h5gi2vhgxzcbcsl740z2p7j9p8pg3jwfb0yz88wlbj5bkah"; + "CT10nnlo" = "1la35l1b3hxdkihh9vkibfh68rghcfgq48q27x2b05dfhcvcz9lz"; + "CT10nnlo_as_0110" = "0j1f6lbjhwcpgfb8kwzsij0hfmzb3dggi6zwwv9f2w39ax2rfb8i"; + "CT10nnlo_as_0111" = "1519hvpi1zrjk8p31ksna39n9l8v02ggj5q775q243p9qyfayxlf"; + "CT10nnlo_as_0112" = "0asnbr0va5p1j81kmv8ar267aciap638kcb48cs5ghz9fvhxp197"; + "CT10nnlo_as_0113" = "1j5cfbv1d5q2hscyrvig6xkk7gfv4x5cxn1142qmd8pdm9ky2fdb"; + "CT10nnlo_as_0114" = "03rkvf4ljv7bnzp0fyyrypbbx4rxd1y6id3dfvg4w22s65kp0csm"; + "CT10nnlo_as_0115" = "1d8rkwvnymx4pi0v1s2vbc880mggdmfnzjppd7fghjqj4lkkanyi"; + "CT10nnlo_as_0116" = "039i2bq4xr6hlvg0syzmyfv4lm7lrwr59myrhd609dybiky4aqd8"; + "CT10nnlo_as_0117" = "0q3a5lbpxh24zv7ypbc680kqrkwy5m7xbgx5v44b6cdzlib6lvsn"; + "CT10nnlo_as_0118" = "0b11mpgrkqn2n37asg8qg3qmhdhbr8lmj8qjixxpca0h1j7m71a5"; + "CT10nnlo_as_0119" = "1j411yqrlbhqmby8mplgghmb4zxclf1h3pdsffx9iv8sq1q6dy2i"; + "CT10nnlo_as_0120" = "1djf9qfqrywpsyv0w6igidg9a4ca739dvqgc7qz7qg2bpclbaly9"; + "CT10nnlo_as_0121" = "0nlm5iwcvb02fd7kan4yp60qbc0fgir4dii3xg03n42xzqixy2qm"; + "CT10nnlo_as_0122" = "1kwq04i5ln8wv32vf4akjnzid3jdq67zccfg7xriqrwd9367x5kv"; + "CT10nnlo_as_0123" = "0w4fmsmyci09v0cxnmhdbqxv3xq3wa9ma7m4g39sg2gdsxqz1rgd"; + "CT10nnlo_as_0124" = "0yzrj1pdigssi39z21k9jxbiahhc1785rjxhq7xl8zx38paspbg7"; + "CT10nnlo_as_0125" = "0qvdvj3wkbkw0b0zv79ybds2pk5z9kbriwsm5ffpnycrfkzrm2kd"; + "CT10nnlo_as_0126" = "1cf8bqi1g4c3xqg5k9m4fa8v8bcnwkzblmfn7zc396pgbzhhz610"; + "CT10nnlo_as_0127" = "0zknrx60h8jdf2pfg2zq6xk73hn86gcv69ml78ik5ms0y5gp21av"; + "CT10nnlo_as_0128" = "09yn8l3nv29frj3xn9pafiz2iamccp8ii8j7hmp63iaji6c7m5fg"; + "CT10nnlo_as_0129" = "1ypq63r5myz2phn4y5sbb5dbxvycwis8jixjl0n95xmqlx5zhixi"; + "CT10nnlo_as_0130" = "0ilr6ijbbh1zki66ma006h1qhdq7wmzm0ipki78bk01jnr5yl5sg"; + "CT10w" = "1qkwz1drbkxcb4gskkfn0r7fsa6g9hjlc8716m633x35kha1v52j"; + "CT10was" = "00s4n3nkngwyhh82l132v88c4jgkg03ff4x7m7nna21lvkv4wkb3"; + "CT10wf3" = "1r43pzb1291bjcmahgfh0f86pvb3nhdpxw7gikqmypdmck0n2mqf"; + "CT10wf4" = "18bf9k0jp95y9yz0m896sdzy9q1fyp0r4f5hrv4jq4d1z84zdis5"; + "CT10wnlo" = "17wsw6p0h618q68swn9mjsahfyqikjgsiykiby7y27ryairv709n"; + "CT10wnlo_as_0112" = "0p7mh56zyqh9i72llbmjchwm50ifa358snd8i1nqr3r6lr5265hb"; + "CT10wnlo_as_0113" = "0nl4lk3cscsn6p50b3qqaabqfnkn5xgjmcxvfrr1n4njh411kmln"; + "CT10wnlo_as_0114" = "1vck1i34dspbzskzpbqxbq11gp79drlrik52waklvsl5110xawnv"; + "CT10wnlo_as_0115" = "070cl0prprqqkkzwxnvyw7r4ivvs8slb98v5yza0gvpwck0blnzn"; + "CT10wnlo_as_0116" = "0v50pyjqpcrarbx886la0hr6vwvnavsldm9amcdp1vlck5w8mmg9"; + "CT10wnlo_as_0117" = "108sb5h79mpgkvdzqlx830dykba5kw9zqgxa60i7bcyjnv0277si"; + "CT10wnlo_as_0118" = "0zf335291hwfmdbhgl5v2y5pbc9slm7dmjfkijdv0jm33drpkcg2"; + "CT10wnlo_as_0119" = "0kvwc0k5y51p4qvlb6hhxvn9c2n8x0xn0xyp5zkz75ad3vaz9yvn"; + "CT10wnlo_as_0120" = "0yvbcni3xf718xild7s9g6cxw7dwa38f4iqdm5z7dd9ahxyw9rxv"; + "CT10wnlo_as_0121" = "1z0mlrbdn8a9n6h0jpha3p1lqz4iamrwa80svqn9y4qii9h5pjkn"; + "CT10wnlo_as_0122" = "1dh5czjvyjnwlzc14vz91693pr3nyls5g926g347rdrkqkjq8dcz"; + "CT10wnlo_as_0123" = "0nf7qpgb83ahm5dkzr10xafhcx4lvb3zlxnz70jczl1jd4v2cld9"; + "CT10wnlo_as_0124" = "14h07z06csxb6v6ai1w5ba0kygnsrzdwxr2nx1kcn93axcsqqbhv"; + "CT10wnlo_as_0125" = "0g0w6mwy5y4l36cn4z8gfmigzharyn5xqk5ricasracrnf7ydix2"; + "CT10wnlo_as_0126" = "0dbkkyimpll9r3979vbk4xqi5cfhzr6b28x6j73fbxxxi1xfavl5"; + "CT10wnlo_as_0127" = "1svmgs55kg74rifjyns38lggv1c18mzmpmvsv116rrllklb19pfp"; + "CT10wnlo_nf3" = "1m13if0d9xijq695x41snpwwrsgs5a0jvil6j2ww8cspc33d7vr3"; + "CT10wnlo_nf4" = "1b9lz23rn2w7fqwxxgf6fcg620ac58dnb1ssj3ml3vfn7z88yx43"; + "CT14MC1nlo" = "0z82q7xr9agq8iyw7w2rcclh27mry5snn5jswn3cxpgnalls50rx"; + "CT14MC1nnlo" = "0fj6hjdv82fp4iv7iyk9gna7sksnpkgqx0bsrl2wjbigm4ys031g"; + "CT14MC2nlo" = "1x6a6js1jpvkykagz6w3klh6hb2wf56r3kh65i6qlnzak4m7b8sq"; + "CT14MC2nnlo" = "0hbdz8agjm16mm51hclpl2nsa5ji88zpqdsn682xgihq64kahsnb"; + "CT14llo" = "0sz2ni8xcjjg8034qjrhb77ak1akzlf5fwq00qs9c196lk5b2x7s"; + "CT14llo_NF3" = "07zzs3jprh0haqx5bcsii213m99m2nh9vki76d9cbhicyzx23pc1"; + "CT14llo_NF4" = "0bxkw5qms6dpab0zf1hhd8dllrjip2izbv23aqpg72d5rqxb6ny4"; + "CT14llo_NF6" = "060fx2xrc90id3nb7rlmrvkxlyafx3g7nhdb5jmbr3hxwrzrq674"; + "CT14lo" = "0y36qkjqd75zf1w1hs1q51qxgin7sm3bhmcbwczwrb17c3vb4m2m"; + "CT14lo_NF3" = "06iad9lrpxsy0d365vrjv6gjlgggakylrmj1px17y6s796jq6c6g"; + "CT14lo_NF4" = "18c03j26mbapjidq01s4yrfdh0i7j75gbswdhwcllwdvcg3gnki1"; + "CT14lo_NF6" = "09ncggqnqcdpzakm16dzxd6ikay9gd5k8si80k52hrr9m2gf36ci"; + "CT14nlo" = "137i0n7g9rgfsf5rx65d50njwsqawprazp5an513kmz1cwq0cqmd"; + "CT14nlo_NF3" = "0pmamazh9i8pahalasr7mwx67ixbgrbsh8004grg0cimr2y4iwjj"; + "CT14nlo_NF4" = "1k7sy8lpzkwy0dc4ig9i9134k854fk0r0lann6pj3jsxs0l6h5km"; + "CT14nlo_NF6" = "1gfwr0sjbq41gx3057hqy8v6ysivjf1xrh6fp3qqn6m13gy2kbas"; + "CT14nlo_as_0111" = "0kgg9r635grdwp152ylzklawzy8nf2ywlp75bjc1yyagg765k6jv"; + "CT14nlo_as_0112" = "0j0bxx0gjdnj41gjasgd153gd811wyhsza56fvzrpka820bkk6rg"; + "CT14nlo_as_0113" = "06if5wk1asazvff57ah944mnzkh5460yqkkwcs8zhnwx2kbq9v85"; + "CT14nlo_as_0114" = "1szy7jwjvdvqqpjvcra1f0wn8qgrja6wx4kwcq9vf60pns7mzk7v"; + "CT14nlo_as_0115" = "1kkahzmrbdr7s06v093arnss0xpxv7byqqx2f5aqh4fzimwp9n7v"; + "CT14nlo_as_0116" = "0qpkmmpq1b33grf85jzkanwpa02j1cam39pkxchql95hv2jlgw4l"; + "CT14nlo_as_0117" = "0381620r6h9s2qby52jvys4z8m6jfafa5qnia2fq3q1pc0xp1q2p"; + "CT14nlo_as_0118" = "13hgxmjx6bv7njb6jdlypy1z61nqf5m5bavxsbrmwwfxlsl4jdzn"; + "CT14nlo_as_0119" = "06pjl10js0xq7p14ifjn7xhndxyb39sxyc9ksd6wx55i6zyqf08l"; + "CT14nlo_as_0120" = "1wyygxxjlcsh1qg6npk5szfbf59k4j80hnxnxhah9x9wrg5kg9j2"; + "CT14nlo_as_0121" = "064afbxxqx4rsa3l73rki8wxa08a1rb53qyf3nwwjb4zb426jfgg"; + "CT14nlo_as_0122" = "172xvndzcm8s4hzjgrq3szg6j7z4s2f4pgr07vr178zvn9986ham"; + "CT14nlo_as_0123" = "0q2dansvna4p04ilb1sajz3s5mi89jgd8badqh6r72g26s96dman"; + "CT14nnlo" = "1y3gd5wzpwv024xcrn70bz6h62n96mgqqwyl5r7q6czw0is52dzq"; + "CT14nnloIC" = "1wnpwy0mz0c5y29wi497jcn5k47bndd0h65d6a18qcfk0l15rfzx"; + "CT14nnlo_NF3" = "0ijns9bjkw8zcinba7rflc7ic03mn5701lqfrxqjyq4q6kh8fia7"; + "CT14nnlo_NF4" = "0fhyzaxnm17pi7wfh5hwaic9q4y0hb05ripd6r648wnnhhi353xy"; + "CT14nnlo_NF6" = "1dvabji3vrqk8ngln72xqiahm8fai3klgv5yz64b3bfxcr04wmg9"; + "CT14nnlo_as_0111" = "1hl88j40czr73h9fbz0zbliawlqwng7ikrmq01hsfns190axm8w9"; + "CT14nnlo_as_0112" = "1w9344v9ihr0w8vrfhhxn81gcnr0qm6ihwwijvcdds09jpdlp6vr"; + "CT14nnlo_as_0113" = "11symfb1ljislbksrars1k766fa2n1inbarzbw3kp01vxpw8gxf5"; + "CT14nnlo_as_0114" = "1s1zz0ibr72jvx9c7w3kcryiywnmg264gprn020yxl9sqfzm0kzz"; + "CT14nnlo_as_0115" = "19c4c4s7djav1zai2nlxbvy8fzg8hqlynri1y4hyhc8hhl00lwb4"; + "CT14nnlo_as_0116" = "1shjwky7jjwcci0frra2lfc0wycvza7na89c4bsqiksnk413v2z3"; + "CT14nnlo_as_0117" = "1mp5xxv810khs59zg4kfsdj5qp6ny0878fbz7jf101mpyhdawf0m"; + "CT14nnlo_as_0118" = "1mvyv13agnmc2c47i9yl8ki5d0qac3l6ipn3nf5rwxjgah495rv6"; + "CT14nnlo_as_0119" = "02b14lrx3zpbl5s4nj1rvh30i9xdji37yvvg2xwjiw3i56vl8b2l"; + "CT14nnlo_as_0120" = "0wf29wz9k2v39pbzh91bxwifbs4cn0gsnjdzm24cpgq7bnhyszn3"; + "CT14nnlo_as_0121" = "1w12xmxqclrrwvfb2g3zvivkq858n0lpp0bzfibvh4wamdyyx3an"; + "CT14nnlo_as_0122" = "1hgghn4ad7fj3ya17qnka3xcwz7sp4fl0vpcbqkrs9mbbz570fjc"; + "CT14nnlo_as_0123" = "0m66gwhw2n668sg4srq683qbavwabrk4f4vfcsbppzbcgm7i4yz7"; + "CT14qed_inc_neutron" = "0ph835nfx98i74nncmspj7qb5798yciq76hqvc505n5zd0hwp87x"; + "CT14qed_inc_proton" = "0gv0rlr6l62gidqp02ifn75d1ribvbihgpaqc92fww73zwilr7l0"; + "CT14qed_neutron" = "0ck1vmqk17i7rq42hra79cz2rm8ngxv4da6dvz62l6m2nrga3l2k"; + "CT14qed_proton" = "1gijxkq5gpsljijblzd13kgr7xjjvnjv18v02jivylf73igsakd7"; + "CT18ANLO" = "16lbhgkbiym3njiffxdcm3hf7kkm33hyj2w1hwgb3mvxx2sja31c"; + "CT18ANLO_as_0110" = "1lkxicxmphi4mdc23vig4a5l4gp0n53jblzsl7bvrixbkhd5arv8"; + "CT18ANLO_as_0111" = "1jk8siawnpnclgjc0jhx89ipym0jp94mrklwkn0awh0hgqxd26ra"; + "CT18ANLO_as_0112" = "0rpfx10b5hjwzmlqzkk1zkk38ysn5jfgipk71zl5da6qk1ih5v2s"; + "CT18ANLO_as_0113" = "0chhqgjddrb731y6haa94yypki6pzpjq5rvja61gfbghbvnc02fs"; + "CT18ANLO_as_0114" = "0nvl1a588jvmh7a7przrzpvf9prrpvv610jmsnfrcp4i98ipdn1p"; + "CT18ANLO_as_0115" = "1f757zlavyjxjwyda8rnkzg9kagmciywvvvdcsbks9ij3m4fcw5z"; + "CT18ANLO_as_0116" = "13bdsnwkqzjq63m02vmb7z03rx6chcyy3br4m52gja0qz03rxhyj"; + "CT18ANLO_as_0117" = "0w5pmqry5rd5jsfwiv43cy5z3hlk7gzllnk0vn1qgsjrgd284hj9"; + "CT18ANLO_as_0118" = "1g137nw812zqdkr97hdwvfi4c4bxfazy1wyk30gwgrhqs6xdsmyp"; + "CT18ANLO_as_0119" = "06pjg9nsq6pvda1yg6lg2qi15i3h2radampgk23rbz9g6zn5hw39"; + "CT18ANLO_as_0120" = "0jh6f5jj81sppv5fhm8ccgzwpacfr1nql3r5466z0bl201fc9x6x"; + "CT18ANLO_as_0121" = "0jh4x2y4rcp3l825dl3a89apmb0f94jrk0pl93lv8xg34f8jrb2i"; + "CT18ANLO_as_0122" = "0ma8r5vgdw9hj6cafkj8fbpq8i18cbild4aw4q9lrsszwwcrlv9i"; + "CT18ANLO_as_0123" = "1mv75gga1gdmnwkaxc0c89jxgapc38376xv5yxfqy2dn03pad9im"; + "CT18ANLO_as_0124" = "0913a748xm6lbdci8vicz08h323hbkc4z1bjq1wq8qfrl1cx02ic"; + "CT18ANNLO" = "1kbsbvvkkchhwwjdrj4d91lbykid4dcy4ghanpdd9x0nfm5b4sgk"; + "CT18ANNLO_as_0110" = "1inx20r83pfmwxfhyy3hhj2csp016d9cnald1rf8vl9riqxvx0j4"; + "CT18ANNLO_as_0111" = "0zzi0b27xp4xykbwd2y7l2ka1k4kfvhaq7y2w82fky2b842ixsmg"; + "CT18ANNLO_as_0112" = "0y031rslsmwxs76rz184mrjb07pdcxrf07yl5yab1y24vymqj4dy"; + "CT18ANNLO_as_0113" = "1pgrcb6sbahl2jf3v08bki28w9x0ag5n3zj1fi0jc69fxwgkczzq"; + "CT18ANNLO_as_0114" = "0ifzf428gxlmhc8wvpj3qaqr0cl6pripiabmnb5av43d5avwhagr"; + "CT18ANNLO_as_0115" = "1bxf5rs33kfl3q570wm49ad0drlanzq8wkrbd85qjlvyhy52j8vs"; + "CT18ANNLO_as_0116" = "0l43qn45wfj2lljpp8kri1n2p99lxj3gbbqh2p2s7v0my5ds5p06"; + "CT18ANNLO_as_0117" = "0nfh9y2w8lvlqbghxx4i7j7gxq5bm67h3vz1wajg86zndarkq6mz"; + "CT18ANNLO_as_0118" = "0m8s96rgnnl5xk7g3l2pf5qx7dwb8kgn18b9nyr8cyqxn90mh3vr"; + "CT18ANNLO_as_0119" = "1lpkcrcfmn0kc9g21ca90j1shcf3ii89yrr17rgwynmylwvizs2y"; + "CT18ANNLO_as_0120" = "0lmn2p57k7yvr5mpzykljhkpnb1c71f4ya2s4zbp2x84fqfg5wbk"; + "CT18ANNLO_as_0121" = "0arbvp0sc67fsf7slhlv96iwq89yjqqkv84pf76fqdvrrjsmyn61"; + "CT18ANNLO_as_0122" = "1nbkgb0wmjh2bfx944sqb810sn4bb0ppxgv2aw2y93jbfyx7x4ry"; + "CT18ANNLO_as_0123" = "1rlxn70mc299v596y0dwp9a1pdy1yz0r8367cjw5l97y46yxhjrh"; + "CT18ANNLO_as_0124" = "0sfkvhyxp9sqf75wj91h9h59vcs2y2n4qchsg0marjy849xxh6qb"; + "CT18NLO" = "04y2p6vz484l3yv6381pfavqs3xh78h3jn6bg7ncp5vywwqp44n9"; + "CT18NLO_as_0110" = "0nrydk44sp7hgabn6xk6r2hnkir7mgddcsbbnqmpwmq3x0xz27pn"; + "CT18NLO_as_0111" = "17xwzcj4n1bmfwz02n2g8afzxc4lp5diij00f2w50pqh2w7vj6g9"; + "CT18NLO_as_0112" = "0a6lsmpz3c1z7dm593nb3r9q7dgpskkls2i6wpdlrrg6s6cr8rmq"; + "CT18NLO_as_0113" = "1kwz9yp0vzyiwy9avxjwibdc6jla32vddf23pvfiv0qjcwfnp6ii"; + "CT18NLO_as_0114" = "161q98jr59vn1qldhd83qxx0qjq1rahgamwfqd3hw6dn6wy39970"; + "CT18NLO_as_0115" = "1dp0683zfn7mg0bj1l5m7i9kdbyxjl0ahhwppvgi5gs5kbmhbs9n"; + "CT18NLO_as_0116" = "0hpi5s175cpz251nav0v34l6qsfqj6181mhhp80kghyyvl7l22sw"; + "CT18NLO_as_0117" = "1v32wxdsvms23sghcszw6csd08kw0xppjzwjnbdsc8k6w67r546m"; + "CT18NLO_as_0118" = "1vd7vc7f49in1i5398p12b9vklxbsif89wv2q93k6m91kb38rm45"; + "CT18NLO_as_0119" = "1h0dlys71cngsxl9dj9l5amikxrvzzb7bins2a6wn6s7zgfyvlck"; + "CT18NLO_as_0120" = "126jfwml027mnpbr6ad7s8d94j3n1sv6fbdy5r5vcb64nyncjach"; + "CT18NLO_as_0121" = "1khffdgqdfl1g4cxp4fnyb900722s6pwzys7cdxmwhzi9f0rwgw8"; + "CT18NLO_as_0122" = "1w7q35igi7fnkrwnr1dnfq646qicz4549c6ddqbkyil10arvq7fk"; + "CT18NLO_as_0123" = "1bl6rf69gjnblvfdh5p8flax9qb65vk25hcfjw2r7qwdz3dxs6sr"; + "CT18NLO_as_0124" = "18mhpn4l3qqg9v79z2vz4jc8w3za726fndfl6sbc9mf94jy72chm"; + "CT18NNLO" = "1shkah5ma0hp101aklkz2p8n9y4i4sv6zwa5ifzyj3bgz1020l5f"; + "CT18NNLO_as_0110" = "0v7nsjcm1q7hgj726zlvfydl3arqkwyddd20z3g0nwdqcimv3qs9"; + "CT18NNLO_as_0111" = "118444ygv03ryhbb28njbsayvv0rdlcb9djja6p62kk6rnbwi1wz"; + "CT18NNLO_as_0112" = "0djxkvwk628sxgf62bff40m2m6vgzs08jss61f90rscvj6gxid5b"; + "CT18NNLO_as_0113" = "1xg7qs33h8zgj4007r8g4drhm95551slhwv62dzyv9pwy5vrvgdn"; + "CT18NNLO_as_0114" = "0i1g7kwfs39ps9ml0ckkcq7x4g1n764q1r06ilq7bci3m073cffn"; + "CT18NNLO_as_0115" = "16q0hc3p0325bq9zgskkpf9qfyhmz9q0rk3b0jrzpc0d4vk7b5r5"; + "CT18NNLO_as_0116" = "1mhnx8szpp4sfy592f8vzvjlzr9y46qndv3c42hf0jsygx5pc5cr"; + "CT18NNLO_as_0117" = "1bmcnjfzwf4bl70qyx6csix3ps46pd32yb2h33y2f144vp8bmkpg"; + "CT18NNLO_as_0118" = "1r1dmj42qrqprhq06i0h4kpjc1riql963n32icl0mfwjq9wpfa0g"; + "CT18NNLO_as_0119" = "1rxyd21h407zmjn3nnr4cqvinw2nwcdhid6cbr0wif8p2b3gasic"; + "CT18NNLO_as_0120" = "1llhnfijc7v6v4dkbsfgj2c3m0y4q42mvaynz06v2j3aqv3wzhza"; + "CT18NNLO_as_0121" = "19dqq2jz5daq59gv2zdvygyvwi9sx6i3ih82yl82yy82gbw2568h"; + "CT18NNLO_as_0122" = "0p8w4ypaxrpsyz3dn7f0964wgvd30iy4r1haa88hqwx74qrkb4pc"; + "CT18NNLO_as_0123" = "1c1sw5md5xp8l6b3qxbnf994kz2rd60p4bl3s3l2af7f77w57wfv"; + "CT18NNLO_as_0124" = "0ldf7dnzdlwqh0gmb6an0b8cwcjpkiaih49aa77j2irw2yja5p41"; + "CT18XNLO" = "1k0cli4j0z5hj24pk9f78flhlvsdfya51hgh90jv4myniapk616l"; + "CT18XNLO_as_0110" = "07k9ga6n2gf9qz0flvrd4if0mssddrq1bbk0rpxsy8wfp41cjsl8"; + "CT18XNLO_as_0111" = "1ysz50r2nc57c7srgqw1dcvyfr9h578dkz24sbimxq54akp9jkxy"; + "CT18XNLO_as_0112" = "11wvnvsc6a5c2ygq39avai4xk2mrnfnvi4fqzmkjdcm0kby0swpb"; + "CT18XNLO_as_0113" = "0cyv8y2m3514np7f3fwpf3g1mzy2cz905sc5lrjqff5djwjc23yg"; + "CT18XNLO_as_0114" = "16vj7hhg3psmyr4vqvy8mz4bg7rp6jc6b64n2dfpq5jvb15w2fbv"; + "CT18XNLO_as_0115" = "0ylw7d9g041fgrjfvq0i0ycpxwbm3s4jdgm5mkjk6yj0s4mrrqcy"; + "CT18XNLO_as_0116" = "0mcfgih55zja7k0cdi1yd7gx1gjr6cpzz28gz4fxyxi2l4paxh2k"; + "CT18XNLO_as_0117" = "0klzf5bchabcjc0c8h6f09g37jy6vwrpq7q8iwrfcmar2slx26r2"; + "CT18XNLO_as_0118" = "0hd1bhlkmnchcv0xbrqjc3paa7fqp249sxi9hg71x3qbh03ab036"; + "CT18XNLO_as_0119" = "1xlxw18hcsv7bij4dvnj9dfm8sai5xm9jggb8g7flmvkmcskgzmg"; + "CT18XNLO_as_0120" = "1ixdg56qgm5701al85zkp81xx3h9hsipqka8l3sh0ghp563qxk32"; + "CT18XNLO_as_0121" = "1msa7pp1a77wmvxa9mhr0sgjj4yv1msb0igqj53ahzgisyl3lnml"; + "CT18XNLO_as_0122" = "1kin5bf9bcxadqibqfzb03bxdrj759mlgpbpjvvpxg4ishj0b7yv"; + "CT18XNLO_as_0123" = "1mir3cpvbc30l3m84j1ql1d8phrx7nf0qd5xbq9jfl4gx1kjfw8c"; + "CT18XNLO_as_0124" = "0ims3sl32rria896ckm9fg5dsmbf6ivcfl3drnqpl328ynrkbzlr"; + "CT18XNNLO" = "0j7bwzkhax4cm3wnbhqdv48j4wha9zdd7v77ihlgcvcmk79rx1fa"; + "CT18XNNLO_as_0110" = "1cxlps6kvm08lkgvrqjd8080ykc1dvd56986iwwzd0s6whlpfsi0"; + "CT18XNNLO_as_0111" = "0bbp4qz3n9pwcfn6m623q2qqmx2wcgpy6759wzwpjnifym832j95"; + "CT18XNNLO_as_0112" = "16p36jf8c8pliaxd6s30cmmmxg9slnmb2527vnwkka0kp9qw3ffq"; + "CT18XNNLO_as_0113" = "15d4qx8x56kcg6p8980bslhfilkld8yf1mwpdzyf8v8ns50wrbw5"; + "CT18XNNLO_as_0114" = "1zsfys0xkgf8zlbzzjmh1wvzxwjqi4rvgik26s5y4ibr68gshvaj"; + "CT18XNNLO_as_0115" = "1x00d2q2lnl5w0l052v9cvkywav26b4r072dpn1jiak6n52yqqaw"; + "CT18XNNLO_as_0116" = "1gm9m0rl9vghswcb4xgp54lc3h8wkh6c077625m9y0166xbv5x2d"; + "CT18XNNLO_as_0117" = "0630arl5qwjhxw0avzlc0mr4hwi09ki8xfn4zvfccgpy2nd85q5b"; + "CT18XNNLO_as_0118" = "1nx75pf5krazrk3ff3lb6zjnxz2qmffrk5vcf06iq5qci9zi5l0q"; + "CT18XNNLO_as_0119" = "0dzjj9f2qkpwfr9pm3pfj6jw5ih2jis8wzc8d0vyh5mm084jlk6a"; + "CT18XNNLO_as_0120" = "17pp23l0brnd0phq23888qbkf1c5j1lcskrbm3v3f2cd8p7jcvvw"; + "CT18XNNLO_as_0121" = "0hlfx8zsxc1x6glny4cp2vpba8jgjix9cpsfixff9vkbqpm2ppk0"; + "CT18XNNLO_as_0122" = "1918l55khrfyb3lcxsbbf9w6v8j54klszl2c32nmna0apf8zc3qm"; + "CT18XNNLO_as_0123" = "02kak35pj6c4hml75na7452ryashfclglhahclzkpq8gs72l5w91"; + "CT18XNNLO_as_0124" = "03wym12nvwdcr13dz6d2gr4bz3csffnn21zfdld42fsyq4glx431"; + "CT18ZNLO" = "0iv8laks2ymn5fygk6k9lxm3s7fld5g292n9bfkhn3nmcfxczi03"; + "CT18ZNLO_as_0110" = "1d0j9nmn9mk90698pxqlpgz7c7cyxswc88n89cr2h8mgcg2w8g2v"; + "CT18ZNLO_as_0111" = "17l7j1j2x529mhk0andkdh83k9z6kg9v3ccfna08i7d4iilsdfrs"; + "CT18ZNLO_as_0112" = "1b8mi0jwln2wvysrkbm1fvay053d17dzvlj9fkz36xmr03bv5mvj"; + "CT18ZNLO_as_0113" = "13dkpjvh5a3p565mhpxqnhijl3jd2zr03np5psknvl121gr007fk"; + "CT18ZNLO_as_0114" = "0drryvq2x42xpf9bmd6n4vz1f8ddh83c3rynnzm54qssxmfkb073"; + "CT18ZNLO_as_0115" = "1wdj056rf02jksa2l2panvkijvvwr6rsb8kh3g2bvx0yjhff8g1c"; + "CT18ZNLO_as_0116" = "1ibf0841irsa4vq9sg0kvrhvakyyshpvs38frz9v3zjbc012cldz"; + "CT18ZNLO_as_0117" = "0l2nabywfsvb1sk44rqgrwf8h0lxkz8qf6pmzr8jc3zhq1fv04sl"; + "CT18ZNLO_as_0118" = "0dnksqqshxqr0y3qr3diyvhfq1jxy1x0hrjw8xk76jzm61xi96x1"; + "CT18ZNLO_as_0119" = "0qljv4d1qfc9rx3p4a8dghij11dv1mi03y30wdilfxrf98znvdyj"; + "CT18ZNLO_as_0120" = "1w0p5gai8qhfjh4jxhyl26xrp8n210cp2a7zjd4id1s4pcvpzvn7"; + "CT18ZNLO_as_0121" = "1ija1nqc4pbprcc3ddhl9rxxbaxngjr256zxiy7gg3wmg6364hjl"; + "CT18ZNLO_as_0122" = "0d7h3vli13m1pm5w91js8skv198aqz9kjkx7w0sa4v2vhvz1rdyh"; + "CT18ZNLO_as_0123" = "14cl8fmkl6jav7byqwcfa1z2ml6lnn6pzp0w4nqy75gc7wxsba0m"; + "CT18ZNLO_as_0124" = "18riha0fflfbsgh7nnc3ghm8cpzpcss0z6l48d28bbq0i7caqad7"; + "CT18ZNNLO" = "0zsqrpab6vgcinsxjq3rqdadig5flxzk61wc1aa9rwnkbpm1paa5"; + "CT18ZNNLO_as_0110" = "06qzlfshx8gwrhnmjfvz6sxq7h2is1dqvx5sz8jxrr1gl7gl92h9"; + "CT18ZNNLO_as_0111" = "08k101cn9x9y44zcpn6iql85qqx89rv7xjhvak4y6s309p9rlnzi"; + "CT18ZNNLO_as_0112" = "1c72mz93kha8mdfdcwj8fs8dqqylxmmc4vs7fjf9h7xbrqzmss7m"; + "CT18ZNNLO_as_0113" = "0z7s1kmlrv99r5mb6p1xwrydx0s896kr3va0ld3gq39a0f6bqvfz"; + "CT18ZNNLO_as_0114" = "0ir6n8i170czq7h3badim28540478cq5fb5vv4kdi0ncypsasr4d"; + "CT18ZNNLO_as_0115" = "0dncvhp99v5s9746ql37gdm65byih9ppg30c77k50i2485a1zfap"; + "CT18ZNNLO_as_0116" = "0qihfcsgxv66l781dmvmmpbr0s0c52s90jfmz5y52gyy1lplw569"; + "CT18ZNNLO_as_0117" = "0agqd4vgj53w9p7ghfkrskqyvg7lw5g9ilj0fid0jia8adfh58xp"; + "CT18ZNNLO_as_0118" = "07y1l00igx7d2yaj9gi60fvqz1p8f8z44fmxm84fpjikajabff5v"; + "CT18ZNNLO_as_0119" = "16nnwwj16c8fmqh5mwnihzvbgfj3cnvw01i1il1gr0g4zqpn0yhi"; + "CT18ZNNLO_as_0120" = "0yy0lxwm41aa727wdrq27l6ih7fdaqwiy4bkrbh0zrns0km9r958"; + "CT18ZNNLO_as_0121" = "0yg70dx2wi9wf5914shfqaf2j90dnkfnbp1pq2jzxd0h0sxhlphj"; + "CT18ZNNLO_as_0122" = "1bd4193ggv4nb48d0mw2n93ia30h4myfy197k9b0m3qc90xjq77z"; + "CT18ZNNLO_as_0123" = "0r2vri1brq0xcrpj0cg9hf9kwhkh2czmimrsg5bfvx35adiiis19"; + "CT18ZNNLO_as_0124" = "1wq0nz9jfb5fmzwnnh0xyra2j62kb5xpmh2nyy8ih4lvxhgi16mg"; + "EPPS16_B_90CL_Au_hess" = "0ab3pnv8fq45mdp29m6lfmrhhnr88k6qvkq6lwxmn17k39v8j9w4"; + "EPPS16_B_90CL_Pb_hess" = "1cjc79sygpxnir3qw9n6cdwvd3flfn11ajqs5y64svrpsqcx5ng0"; + "EPPS16_B_c_90CL_Au_hess" = "1ijvnglq4wrjhhvksyd60s7c6nv50vwyk5vd8c3gs0qr8yz1fk69"; + "EPPS16_B_c_90CL_Pb_hess" = "1347cqsfkim0xcds5imxmsdxh8x0h2n97x5zwpf035rbdk5mkr4n"; + "EPPS16_B_d_90CL_Au_hess" = "088jrj6xf1ph19sypa5dizllydfzi6ikxq2gisdlxpj1qnwjymsg"; + "EPPS16_B_d_90CL_Pb_hess" = "0x12r31l0nvqsc2ml1zkil0w1iji52xgbnxn3wss9pnmswrf3cah"; + "EPPS16_B_u_90CL_Au_hess" = "1pq7agglirpk2w566c1ql15ps1aglmnph2p2dfa535zlv89s7c0d"; + "EPPS16_B_u_90CL_Pb_hess" = "137jkcbikmcjaxp8rpr5j193cmr329mcvyy7j0s0a6ynglhpr76k"; + "EPPS16_D_90CL_Au_hess" = "01ggm0xxwd3nc95cjcf36sy0pdb0xvk6bkiaq328w2sfajccr5mk"; + "EPPS16_D_90CL_Pb_hess" = "1z3zam84m2kbs7zinn87xhlca90d5zwk8j72yj19nx3r92brnq8h"; + "EPPS16_D_c_90CL_Au_hess" = "18sviyvm3rm9n7x79w1sx8j9mcc6dnc2il8hsw2avjgy2aqmwj87"; + "EPPS16_D_c_90CL_Pb_hess" = "1ryv83iq1lrphgxvdsmh70j6iky993sax0s9cfrswpjyl2pcilq2"; + "EPPS16_D_d_90CL_Au_hess" = "15j6s9mj1ci9wjgsfhbxfikcyxc5pilv56cyzxjhgjhfgwvi1xyz"; + "EPPS16_D_d_90CL_Pb_hess" = "1qjyb57fhf6d3g7l48jcl6jizj2c5g63xahzanrmkm9r538hvhcc"; + "EPPS16_D_u_90CL_Au_hess" = "0jjk2rccvv0ngxn7wf33j21y72wvs4dhwl56yhmf7bfzd6v70rp2"; + "EPPS16_D_u_90CL_Pb_hess" = "09npz68wwvcsvd6h8lsgmlr19l0af4h4rppcd6jlwd88c2zpb3r3"; + "EPPS16_Jpsi_90CL_Au_hess" = "0msvkihdmhap0bbiydxbp552k1sgk20wadvc2s2h9jldakdx0pk9"; + "EPPS16_Jpsi_90CL_Pb_hess" = "13vc490k1769gbph3xn1lffj0ilvhz78by3lhw45lwkra4vx5zp4"; + "EPPS16_Jpsi_c_90CL_Au_hess" = "069lzrnm5kx56rblr4lxqvr014nrf2yyf1iw42s37q2xsxpjip87"; + "EPPS16_Jpsi_c_90CL_Pb_hess" = "1895iqzmcnaqkidcy96z4766wppycp1riwg9clg71cb404wz74as"; + "EPPS16_Jpsi_d_90CL_Au_hess" = "0ndh23dyaszam144dsdbg4281c61vai8avgi4y7x8kb0paha4icm"; + "EPPS16_Jpsi_d_90CL_Pb_hess" = "0xflijnwabg931z19v8c18dzh1lbqivkg94kpwm8j135ya1vpmm2"; + "EPPS16_Jpsi_u_90CL_Au_hess" = "1hagv9akwm337kq3kvkpkdkcpnic7klnigh9pyif1gm16i1q40jf"; + "EPPS16_Jpsi_u_90CL_Pb_hess" = "0dw68rky105lyaagkzkmfx6l9jk763m293m7s972jhnl5037bj74"; + "EPPS16nlo_CT14nlo_Ag108" = "1p7gckhv44h04rvknd6fdizy9c1jqfwic7ppf0ra14ic8wp1g7wg"; + "EPPS16nlo_CT14nlo_Al27" = "0hxyakfgknmixxndfj14i44afp5gcfz9afjvjdaj702sv42a7qa8"; + "EPPS16nlo_CT14nlo_Au197" = "1g272110y3a1fr6raxdfhagn68i0lcnwbdhiiqg4j6wb6v4m3p6i"; + "EPPS16nlo_CT14nlo_Be9" = "0zxsdmvz919ajwwb917613byshhpr876jcg9kik0pkz8c4ddr2z0"; + "EPPS16nlo_CT14nlo_C12" = "0mjmjk9n36aikhm8i6zwzfszyb5zcy1syn13vs2rm12x535j6dm5"; + "EPPS16nlo_CT14nlo_Ca40" = "18vd67splj75sjijfvhyq0q6068yr8l083sczamwpmy8z3l798ih"; + "EPPS16nlo_CT14nlo_Cu64" = "0g64gpc5cssmwl1sn7cl0ramsg2zfq7snr9bzr41q2dznbvqahgd"; + "EPPS16nlo_CT14nlo_Fe56" = "0dxfzpx99ha9g27bxx6xzxxh87va91qqwq6hnz1qsligjfx7q4yz"; + "EPPS16nlo_CT14nlo_He4" = "1ln5kz3270kyx6m3ji6q5xyp5a23f3kbwh9z9dmdwwsw7q9n8way"; + "EPPS16nlo_CT14nlo_Li6" = "04rviiml0rnym9qppsczcydw37r923ljx8hj63vv6dxng0g617qb"; + "EPPS16nlo_CT14nlo_Pb208" = "1b2zibpigdvvkg29zh7zm32jpdr2prm35jasafh17pfpwlfc55mb"; + "EPPS16nlo_CT14nlo_Pt195" = "14v1gicvm8i8z9d98rlv5rbhaglkbi9fhs3z465p4d764al6znnc"; + "EPPS16nlo_CT14nlo_Sn119" = "10nxn6rdp7svsrkdcdwxryjmirn1s871yj1w493adpfcy3chqw9k"; + "EPPS16nlo_CT14nlo_W184" = "1x8ndmkzmnl79vz1bgi9972190x03asvgnls6qiz746xl37q4ky7"; + "GKG18_DPDF_FitA_LO" = "0ql03hp30wfaw9gfyska0v5vf4p3n2dsxvkapjqnyfl01ad6vjw2"; + "GKG18_DPDF_FitA_NLO" = "0n9khzvhyxfwbl758vzy8jgyqkgcgl328m657vlami3w22hmpbrz"; + "GKG18_DPDF_FitB_LO" = "0s15ia8mcn00xl28rhdxjigpq0ai80a831366sx0w7qx44bb5n0p"; + "GKG18_DPDF_FitB_NLO" = "0qlv7p1fx3gq2cqrvamlpn6r54nssbk7rrx1znhfdzx3x9v1ii1q"; + "GRVPI0" = "0i5icsw9hf4jm25d0szxqc3r1131n417lv8b4gslg93xqj4ry1hf"; + "GRVPI1" = "05j3mcrb0sq4nzv7y0k68f2m3v8vnd13mzbhq43gjq712cbj126p"; + "H1PDF2017" = "10yfikq1mlw6bzhbvwblajicpqzhi06gl1aabhxr6mcf9vby4zw8"; + "HERAPDF15LO_EIG" = "12cqj3vqwi86sfgxkiwbd7rnpw1awnbqbc852b0x32d9j18nz9c2"; + "HERAPDF15NLO_ALPHAS" = "06yiid611zi5i9snqrkjr3g4z2n1gwkvqjs606ha0b4nrwlpnkhc"; + "HERAPDF15NLO_EIG" = "0h5brmk7w70dgbwhjikfpprni924c2f3kxsmxzcm2qlrlgj0nswd"; + "HERAPDF15NLO_VAR" = "049bfsgkcfnz4z7vzkl4vr6ivp9kvak2f07nmarm8q2wwd6pjjqy"; + "HERAPDF15NNLO_ALPHAS" = "09qf93b336yak3aqnfqlvz5j6xvvrsqkc4ag41xh4prpswj8fmrc"; + "HERAPDF15NNLO_EIG" = "1yf48sr7nak6lph2s1vd3s91mrw0da9kjxlvqzcg3n9j48l3f3r0"; + "HERAPDF15NNLO_VAR" = "0di4b75ag82iysyrv5wfvn8728jdi8mkq96ycpq534078ps2n3bd"; + "HERAPDF20_AG_NLO_EIG" = "0jr2s4dj5w9xwidrqbqi8af2dqycm4vr36qy3x5javllp4dn04cr"; + "HERAPDF20_AG_NNLO_EIG" = "11cdhjwz4qm2hxf8i5kl38ny4nbsrd2vf3jkwz17lrgls716wh00"; + "HERAPDF20_HiQ2_NLO_EIG" = "09wwkv8lk7gy14avvamk3sqdsvig2bvnzha5d4v5s2ln7g6g7vhq"; + "HERAPDF20_HiQ2_NLO_VAR" = "1cgprisw1bksi8nryqqsy6ac097ywxdgj5yg796izari7j72p4bh"; + "HERAPDF20_HiQ2_NNLO_EIG" = "05670fr76fx14gp4ywywz71scr6f25jk14i4k84gpcb2l6rnbv9g"; + "HERAPDF20_HiQ2_NNLO_VAR" = "15nxgq5hy6ncvqma6ai8k7601bfw97p0h9db2gqbbyyvxf2ldnc7"; + "HERAPDF20_Jets_NLO_EIG" = "1c2n2cn9l8x9jc8c4dh2whgz3378nnnvb3448cgpv0qfm589ygxy"; + "HERAPDF20_Jets_NLO_VAR_Duv" = "0z2pkmlpffy29x2bh0086m1ybbb94x507fkr4khmdb4d0h33ppdw"; + "HERAPDF20_Jets_NLO_VAR_fsdn" = "1ya4hbr3shjggpqi6h3g9j3jnbmmgrva2djbsaxgp7icii39yf1a"; + "HERAPDF20_Jets_NLO_VAR_fshdn" = "1sl2sq27xx40mj4zn00vc44k3vf1yxb7fwpqp0p3lqlp9gcwlycp"; + "HERAPDF20_Jets_NLO_VAR_fshup" = "0qs8g45s70d0l3g7xh0bqhk65ac9g003bjpacd9v97gzpm6jvr45"; + "HERAPDF20_Jets_NLO_VAR_fsup" = "17ix21qwjkp9gy9gvn3143d8ganzg9r78n6q47wdfxh12jzvgc7k"; + "HERAPDF20_Jets_NLO_VAR_haddn" = "15rbsdddm5ayg5r0gljxxcmrrvzhfdr44ky2d6a70wjr2g6lc5yc"; + "HERAPDF20_Jets_NLO_VAR_hadup" = "1x3rnr2hkcfglpmv732blziygzvdlw2rkks1ap9majnayh01vvfk"; + "HERAPDF20_Jets_NLO_VAR_mbdn" = "1fi0rp4gpqj7yjmv6b68ac7m8v4f9m4q9kd6nq4ndk2gp11i6799"; + "HERAPDF20_Jets_NLO_VAR_mbup" = "062dfx73lihlhndn5xjlsimfxalxbfhn1xyqzbk7bsqj9mffmwli"; + "HERAPDF20_Jets_NLO_VAR_mcdn" = "092hwkx9kliib8lf405sy9bvxg6xgydnsxl92yjqwyicajihhij4"; + "HERAPDF20_Jets_NLO_VAR_mcup" = "0qcirk0sqnkfyb3pdxlpkl51pbj2gybw7kgw9xzmj4j3jdg2zjqg"; + "HERAPDF20_Jets_NLO_VAR_q0dn" = "1xv319ai4pwy1mcy6i3wk3mp4nkdpjb2zcnz17gxvdx2l6z1bz5m"; + "HERAPDF20_Jets_NLO_VAR_q0up" = "0bfsqx23jsrjjsczl5j90hp3njvlwaw8mypj1si83mr1z0s9q4rx"; + "HERAPDF20_Jets_NLO_VAR_q2mdn" = "16qfw118c3lh91zsg2nb49xjynbd9w1rh4y5ybr35v38i4acpdab"; + "HERAPDF20_Jets_NLO_VAR_q2mup" = "1q80h7r0cklpz1jam3nzxs7h3i8jpgpc03l7c3g4mkz61ynh0ida"; + "HERAPDF20_LO_EIG" = "1r6ylwi2yszsk5dmw27734s0ghkvdawmqa6fik1k3j82d9s22mkl"; + "HERAPDF20_NLO_ALPHAS_110" = "0zmmg0k33bf52skbz42cgxdjw0ap33fyf0h1kfd9ciw4gra2rakn"; + "HERAPDF20_NLO_ALPHAS_111" = "1mlc33kfs4zlmn305hifjh2d85byvym1mzdj9bc3nlypv4zcszlf"; + "HERAPDF20_NLO_ALPHAS_112" = "0wswbdmkyv0a6fw531s1s7jnskzxsvwh9bydvgiav53pfpibsyx6"; + "HERAPDF20_NLO_ALPHAS_113" = "0qx7kh3cmqz59sm6vjcvi2hj5c7d816mc7jfhqr03hvavqcsla14"; + "HERAPDF20_NLO_ALPHAS_114" = "1n2434j9gvdz24h30sng8z5jmc9hhnm9nbr3hi82n6ssnwabsl97"; + "HERAPDF20_NLO_ALPHAS_115" = "05wk9glb6xpg5n689slihcfkdvm3kgwpxw8dxp4rp8zyvrsh6l6f"; + "HERAPDF20_NLO_ALPHAS_116" = "133vvg5bh1lx6zcacnaphkj11608wafim4rb6lcqx4mkpxabmzxa"; + "HERAPDF20_NLO_ALPHAS_117" = "18n1s7qqzf67lg8gphpm606dvz802i6xmlz5if5jdhjz8r3qklzf"; + "HERAPDF20_NLO_ALPHAS_118" = "07xj5j7k54bwi9xq51cf8zanqlkjcbdrvw9k8ch3h40bk961c5pz"; + "HERAPDF20_NLO_ALPHAS_119" = "0njyfp84kf51m9rw9z3d3figp23043p5ml7cdb45dvh9hbpssh40"; + "HERAPDF20_NLO_ALPHAS_120" = "02paa7bng9nycd8dd2zf2099592mbaz8c4a5hamcmvzqfz0sdy7d"; + "HERAPDF20_NLO_ALPHAS_121" = "07hmbvpm96pm5yp9bsx9aksznksh6k4qrw0k28bns0wjn75khxsl"; + "HERAPDF20_NLO_ALPHAS_122" = "1pjn3h1wr6l6sy7kjvk72qc409dr939z787q2qbaph7xh5rf7k2s"; + "HERAPDF20_NLO_ALPHAS_123" = "09hz6pw4nklwf94krna7g80659v9c2c0f5rf99mnx900xyhk7pxa"; + "HERAPDF20_NLO_ALPHAS_124" = "1d9gmc3g0j32kgwyfddmx9f3gxwrgnq3xcbrabdx9cw554ysd6sg"; + "HERAPDF20_NLO_ALPHAS_125" = "0mi2q9yhkcdpj7336kbs1vw4zvm8c9fryz0c7hdj246kj26rb0mv"; + "HERAPDF20_NLO_ALPHAS_126" = "067rng6gv24qf1j8lz37115mc42k8wjpzrfcw4jw2d1yg22ci0lb"; + "HERAPDF20_NLO_ALPHAS_127" = "0v3xcdr8wsradqf3bzayvvlsdjzr54qa2kbqb5pyvfi3rafrwrmi"; + "HERAPDF20_NLO_ALPHAS_128" = "0ywnd9c6bq5bp02s3b3pql8a74wm472p11alqi4b4pmlzphzk1ix"; + "HERAPDF20_NLO_ALPHAS_129" = "055ya2wxscbzp2w3zx2a5xgs94wl60bm6c2vxrs2rgnab72382j9"; + "HERAPDF20_NLO_ALPHAS_130" = "0k91azhwxrfni5yfasn83f67ma9w8fax2k1k9xc8pvgmbh3c14wi"; + "HERAPDF20_NLO_EIG" = "1ryamdwblj1ysbha672q2z9qai62h6cibb0laizfq2nq4j4ml3vz"; + "HERAPDF20_NLO_FF3A_EIG" = "1fs6ldnwflmn5ysqkq9aky2xskd0dvq372h48x89h4vmsvd302wn"; + "HERAPDF20_NLO_FF3A_VAR" = "0jd9wgrhchqjcjrkh5hjx7x8agm43jq5p8dmyvk0rniz9zybx64d"; + "HERAPDF20_NLO_FF3B_EIG" = "0r04zjfaaq686g3bd6c753vkcwsbgdcfzr67ngm7vsz27zscbjbz"; + "HERAPDF20_NLO_FF3B_VAR" = "12qrfld8958gvk9c2q8l0mvccx6wkrgnsiapgzl37s6s6zcgid10"; + "HERAPDF20_NLO_VAR" = "0q5ih9ac3z6n158h6q149h0ggkfjrdn5rqwf7nzi3j50fhs63swj"; + "HERAPDF20_NNLO_ALPHAS_110" = "1828i4ybdzs7zj62lzsifgshxdas81vjvhfg86ixry4xqkfprlfg"; + "HERAPDF20_NNLO_ALPHAS_111" = "011d1a900jjpa78ph05sdy353gfmrr8azpngcf0cjigcn4fwdna6"; + "HERAPDF20_NNLO_ALPHAS_112" = "0xb2bnigwlhs0vs3fwzsz66zidchwgs97kn6vjfhxnik8xdfkyb8"; + "HERAPDF20_NNLO_ALPHAS_113" = "13b8gh0qwpy574ra6184vgff3wba0blr44lxj56xrkaql9zi1jx1"; + "HERAPDF20_NNLO_ALPHAS_114" = "09n30p5pbw2wyjss2jjz1h4nl9scin42s91sxdcrwinnc3y5n1in"; + "HERAPDF20_NNLO_ALPHAS_115" = "0nlimqmfhx2ijx48ylciih5diwlsb5zzkli82rgnnxci3r4ycjq4"; + "HERAPDF20_NNLO_ALPHAS_116" = "0nr8svx60zrf42nxg74v0h759y9lwg54892xpdmswg7mw0nwcrm9"; + "HERAPDF20_NNLO_ALPHAS_117" = "0xiqdr2r5dyyp5q56b3w04wy3raqrh1mjsv1fm05xswxn2xwyhlq"; + "HERAPDF20_NNLO_ALPHAS_118" = "0d0w0f077g11s4clx1556y9xx5nn1dgm8zcp0bk92v4lapngf33c"; + "HERAPDF20_NNLO_ALPHAS_119" = "1w9nl0pnfc1cii4knmqdq4cnh6shhhgj8pg4a42bx20lvqc3aqgb"; + "HERAPDF20_NNLO_ALPHAS_120" = "1lksn0rcxq2scwpnps8dawlzijhvwbg0pn2is4r29igbqck2jvb3"; + "HERAPDF20_NNLO_ALPHAS_121" = "03d58rbibvgcvmsw86q3030qnw5nnvq8p6diqscd9srb8br06p8m"; + "HERAPDF20_NNLO_ALPHAS_122" = "0541yx5fcadw7rggpypd8kg393m5hwzsw5jangsmsrsby1rc2m4a"; + "HERAPDF20_NNLO_ALPHAS_123" = "1ckc8s04jf7x19xpwwb8g60likrlz3dp91qzaafljvbd9b27aa61"; + "HERAPDF20_NNLO_ALPHAS_124" = "13dx2wh0dhxsjjk6ak7wy1gr8g297dpc9xvkxvb5ayd0rzmhjlwb"; + "HERAPDF20_NNLO_ALPHAS_125" = "0yh6jakycsqhh4h6jqrilw1afmk1jkcq2px978z4qcz4y0m6bx4a"; + "HERAPDF20_NNLO_ALPHAS_126" = "0045sa1kl4w75ja6an38i2a3fi78q6xg22av536l9h1c8j82ql13"; + "HERAPDF20_NNLO_ALPHAS_127" = "1f5l9cy59dc3rc9xqrsq85g0mbhyaqkbpzi40f3gjg6bxjlgb4rx"; + "HERAPDF20_NNLO_ALPHAS_128" = "1c2pbd4zam5av582r777197638l6i5a0chmw9ci7l05lzm19nzmi"; + "HERAPDF20_NNLO_ALPHAS_129" = "1aipmxxn7s1r66m6gmrjgr2yca7sxvpf8r86s4a5j768akkgmlld"; + "HERAPDF20_NNLO_ALPHAS_130" = "1g2q3438bivd20i685jmx565cq108yv72vhxmpmhysh4qwvwpqqw"; + "HERAPDF20_NNLO_EIG" = "12zn49jx7qjr8apgpbhknzll4vwlz3x9y1ai908ix2h86pgap2ml"; + "HERAPDF20_NNLO_VAR" = "152h21khvkhxwx87c5lqwzpakmahcpj1ixw6kgl0wrrwjknvfgxn"; + "JAM19FF_kaon_nlo" = "05mcahzr0k5w0hqfbn902lmkwxlkbf8wrk6akpqnfsyqpbmhja5k"; + "JAM19FF_pion_nlo" = "06krcf0c9jbbpwf1rk1xd5z7rz904ji984xz05kv9p1j1vgk0ha0"; + "JAM19PDF_proton_nlo" = "1zrcijik60rci6km5d8pn8ivww8w3v8pb1m5dshqjs51lhf56ayp"; + "JAM20-SIDIS_FF_hadron_nlo" = "0bx3igckr2dszxskz5f952vl0q7kwvxgyb28yksjk75325dp2f9c"; + "JAM20-SIDIS_FF_kaon_nlo" = "060r6ah5843vm1r3rhjvlgp7w45z39cqgibfc2g2m1q7mwjqccjy"; + "JAM20-SIDIS_FF_pion_nlo" = "0fpkbl5fw76wgk8l599kf51mqa0fy92bq9ksfjfks0c4m6ah1g5i"; + "JAM20-SIDIS_PDF_proton_nlo" = "1g1g9n2ij58yzvgrw8g1f8jbqyhj9yvbvl9iqjxllkhkb2zbllpl"; + "JAM21PionPDFnlo" = "0zn7p9ny6072dkhsiaq64f2gdzpqbqc06d9a21rvvg3cgsba9jg3"; + "JAM21PionPDFnlo_pT" = "1wxpkk1wzx1z1kwxfj6kz14pxlckb96aqaq2fa4sf1a0ph1ibrc8"; + "JAM21PionPDFnlonll_cosine" = "0nbmdc0744kl6r7r9lfs20gffpjyxpcfpkp7f336fn1mcl89wggn"; + "JAM21PionPDFnlonll_double_Mellin" = "1n8fqar0dddc92054kg3pl1xlh6z7smm3glv5fvfxr933bxli5g8"; + "JAM21PionPDFnlonll_expansion" = "0dmmalgmp4xjwimyfx0sa8yafzzm0xzqk557qwkli3ramzwrwy8p"; + "JR14NLO08FF" = "16azkqxf1yw1j32ay6j01gf8n9n7qm56jh4yzgjag0zdhm01lbip"; + "JR14NLO08VF" = "1ilw38pp4vy8c8v1glfi4ixca73wjkdg3di1wh9p8xqrifdb096p"; + "JR14NNLO08FF" = "1w0pywmjb4xi7bsvv1mdd4q2adf1g7khspfbkphmlh8zipx29nxx"; + "JR14NNLO08VF" = "0kzszj1r141fcg9vbf53480224nxcc5wfk9zmpmzbmrxzi0w127r"; + "JR14NNLO20FF" = "0wc3qib90dpd1wgiymrn5lzwhqmh58ji2s92vpj2v9v4spws7pdq"; + "JR14NNLO20VF" = "18l4ipn80gmh9kdw7a1k49fwgbl7b1frgc0hsa04vbwnv6hm73hn"; + "LUXlep-NNPDF31_nlo_as_0118_luxqed" = "09ch6mjfn6rjsd31jfb59j92ngqiy0x19qamyxh0jwk0sbyr1dpw"; + "LUXqed17_plus_PDF4LHC15_nnlo_100" = "18y3pa6gjmcv2s21si9a5dvbq6xxqphbqz5qiy39c62g2zf8512c"; + "LUXqed17_plus_PDF4LHC15_nnlo_30" = "1bnwlxr8p4xmr36zd2flhqssil6w7jh50k46j0mxfnd8jgxgwn6n"; + "LUXqed_plus_PDF4LHC15_nnlo_100" = "08jzl4wcsrr9agycq1r5kd5bqxsx4b637nxk34s82vs7vwpq7qib"; + "MAPFF10NLOPIm" = "0w875dh5klqgggcr84g0g7qmh4q2xim8nrf0xdnfc665xww7v4my"; + "MAPFF10NLOPIp" = "1493k3p7b03sw0n7va60vqxcry2b3xgpww6fnk2gx8b4w1632yn2"; + "MAPFF10NLOPIsum" = "0x6sashkhg1hs7wy6fyln12s1f4yavvc90zv4k7rclbah4hr75wm"; + "METAv10LHC" = "1vn4wnx1blz6wylbzirswdqqf0knmyh1pcfh62wvj695mh7i0w16"; + "METAv10LHCH" = "1p4wy7m1ksz0r1fylwz3cbq7jl8s58v817n3d898l83ic2ghp4vj"; + "METAv10LHCHfull" = "1w623939fjdyx1316rxyaavf6kmxff19himr00br57jrw3v49nfg"; + "METAv10LHCas0116" = "0y1l6djkmx8zcsii9j9krwhvgh071a9y5d4m1rkqpbqf6dnq9kll"; + "METAv10LHCas0120" = "1g1izkf3j0vdrjskbjzh8lzsdn1bqssidr0gsapyzlx0dzc2ixdp"; + "MMHT2014lo68cl" = "03wrjv448zdqblv4zx5b2p4m0nj8h4igabh8pzskj0327w7g91lm"; + "MMHT2014lo_asmzsmallrange" = "16ki4aib5dslb7lx6w9nzx18nh0sgh41zbiw4hszf2qxn3asdyhz"; + "MMHT2014nlo68cl" = "039zw5zrzm661bgjv7d0imzhfv3j3ixnrssi13ynfpin9v2izy6g"; + "MMHT2014nlo68cl_nf3" = "0bjmng4ifdswi88kf59zzxpdq8ka80m01208nb2ij3dkpw0n5hnf"; + "MMHT2014nlo68cl_nf4" = "01g0bbfwxaqhgpv0yz17fvwa4q1a1vh9867kp9fyavn600kd91ds"; + "MMHT2014nlo68cl_nf4as5" = "1wdrk7b1hs6s8f2gxp7b3c1qrxvncs41h4aph1dhf8zffn3653yy"; + "MMHT2014nlo68clas118" = "1nv7h2j31z061mgph5154qgxn8rl5sdgwzzs3d3clxfshh5gcccn"; + "MMHT2014nlo68clas118_nf3" = "1d7k0vablssy1vfimsvxdiklaachw44lg37fgj1im52k81qxzd3n"; + "MMHT2014nlo68clas118_nf4" = "1s8gv434b4mz6y5rv4kms69ghliafcmih09icj4qwk66hj7pn5lj"; + "MMHT2014nlo68clas118_nf4as5" = "00zvf9zkrp9lk9psqvzsn04l1rw1xmq37bd2c8mqc2px3zdq9q0f"; + "MMHT2014nlo_asmzlargerange" = "186jz5r74qas28x04daqkxhs5p31i68hhy8a7q6lzd5nh42x6kk0"; + "MMHT2014nlo_asmzsmallrange" = "1x347h5g8d2k73wg6naj6zs7m2glankiwjgzy0gmmrnz3pyryq6x"; + "MMHT2014nlo_asmzsmallrange_nf3" = "0ckw5971pwvvix8idw2m6j7w6bjivqpa1ynm6ml0bhc75cmm6l4i"; + "MMHT2014nlo_asmzsmallrange_nf4" = "1asnk3pl3dw1sh76k0s95jb57cv5k90zjgpbkr3nnrbhvnkizl5a"; + "MMHT2014nlo_mbrange_nf3" = "0bghvriw01jxmzcm9isz7in43ph7vz6zzr0rmmi81snrwvg8918h"; + "MMHT2014nlo_mbrange_nf4" = "1gad7269hz4jj3946yyqzmcx3zyxx2p4r0h88x3lfrm0rd0fg00d"; + "MMHT2014nlo_mbrange_nf5" = "03id7bfds16kbnd0nwjla8sn4pl3q3qa5v0a3pykdwj14k9igi3n"; + "MMHT2014nlo_mcrange_nf3" = "1zfmdclsgwf6517v88zg34wby40606sspcghh4yahc2bbznd6a63"; + "MMHT2014nlo_mcrange_nf4" = "0hzhkv81a0z3ichj5kfhwnhc720xw48h63llijl0pcfv8qqpvl19"; + "MMHT2014nlo_mcrange_nf5" = "148hg5dc60yhfmwsm0svasxc7l1py6ggj7lzv0mrshl07rwfh62a"; + "MMHT2014nloas118_mbrange_nf3" = "03w1wish6ig3mw9j195rakxsjr7gr46qz8dh009sigqcgp3s9fad"; + "MMHT2014nloas118_mbrange_nf4" = "1lbj3r1bbxx2y1ybnxpd0cw7jzkdz0rb1grn1pmwmrl0l13s7j59"; + "MMHT2014nloas118_mbrange_nf5" = "12q0gkqzhxqwrvy8lpg66ldsxnwr8id6jv6k4dj6f0p93qif5wr8"; + "MMHT2014nloas118_mcrange_nf3" = "093yh7wa3p4028x5zxw15pwkrkjxzfl7kcdm7jqlf08zwm52clyx"; + "MMHT2014nloas118_mcrange_nf4" = "0q0y77i0fgdvjk9y76kqzxpn22jbzsh64qbx8186ri9fqzfi868i"; + "MMHT2014nloas118_mcrange_nf5" = "187wsfm49ack0jh9rwy5h29b1511b17myqn28bm6nbn7r4rfvnkz"; + "MMHT2014nnlo68cl" = "0sss77zwv94vcy4ghv6493vbw08xwm264dk081w34jc4ifa0vg90"; + "MMHT2014nnlo68cl_nf3" = "06paq3nzs87babpksabnkqi38gvvyfvpqlh8p18140zrdpdffaj2"; + "MMHT2014nnlo68cl_nf4" = "0lbqpdy66v3ns6ax9vj1ix4wjn2pwlw5y1z26hlbrxz3l8hbizg1"; + "MMHT2014nnlo68cl_nf4as5" = "1bh5nsral3lrlqq6afvq9ahkfmhfw3mq0m0qcvsx4ma5jx5rv7dv"; + "MMHT2014nnlo_asmzlargerange" = "00l2jqccsl3jfwdj7lndr4b5cpx44krjvnm3h0hjw6hkv4irxb5s"; + "MMHT2014nnlo_asmzsmallrange" = "1x36pv9nhj74whibb16bc414ypcks6nd1s7q1jc0fb7ndf5rijy6"; + "MMHT2014nnlo_asmzsmallrange_nf3" = "0svpc51n25cbz2b43zbd60bfckrlz3q2jn3x668xnha9qsd3c2vq"; + "MMHT2014nnlo_asmzsmallrange_nf4" = "15jggp2nbm828nprxyyinmp7kfxngpm0apg446hvwd8hg7blb1a4"; + "MMHT2014nnlo_mbrange_nf3" = "0r9gi5cw76zn0lq3fcs7s2xxh6jl9y5vdv31bhv6mac9jmhjb458"; + "MMHT2014nnlo_mbrange_nf4" = "190wva3k49mymflbm1v5xd449j38jm7ylfcdiflym8pgkdvwcgyl"; + "MMHT2014nnlo_mbrange_nf5" = "19mnv9nz01lmbiv01qmflhg24kldhqpmcc8mgp7bnkhicgivb5ib"; + "MMHT2014nnlo_mcrange_nf3" = "0zskxladqr40v6wqafbl1pl04vq43babqf437c4xxg4sz9435l3l"; + "MMHT2014nnlo_mcrange_nf4" = "0sny8r9zap8gnjh9id1klr59d9hs0bb40pf8hpy8q5pg6052vx3q"; + "MMHT2014nnlo_mcrange_nf5" = "1l340c1x4fz647bhybrvbb6z00mla81b78jfqpnwd4vwfxnqmq9y"; + "MMHT2015qed_nlo" = "130fmxnaashvwwaaiz5b787ldz8l78ar5h2h038xvisdjkxvdqni"; + "MMHT2015qed_nlo_elastic" = "1whplgg2s55wjii1hd32hzd5wsqbgvjjbnfw4fzjmnx4vwn63n2j"; + "MMHT2015qed_nlo_inelastic" = "1b24flby6n9q2cg4haldmjs8ql35lhlw0bgynwja1v2n0fbf550y"; + "MMHT2015qed_nnlo" = "1ypqiz0yz6hnxfml7ym83k4qqvqsbl39abbr38galns8xzzpi03m"; + "MMHT2015qed_nnlo_elastic" = "17in1cz5j7mm9qjk8i27fif6x276lcqmccl7kfz8a5yn73xxzja4"; + "MMHT2015qed_nnlo_inelastic" = "1ngk4p7w8l8b8sfg6hlm8ypxz97i1iwzlrc48szy7bi99kn8rmy1"; + "MRST2004qed_neutron" = "12vna0ic6gh313k22b44b0k9kd939v7zjl2hj65k1075j23mq425"; + "MRST2004qed_proton" = "10z0cr8pnr0lfxxi916naiz381a2cqn461jblfzvvddwqmqbllbc"; + "MRST2007lomod" = "13ar6hzw9al20zlm8lg0hvwmgrmv0dbam820gm36rj8p7i33qlr6"; + "MRSTMCal" = "0kbyp4rypw8jm28zfpvf0grvfvxmsrp3grwsmfxpa2c38x6la3rq"; + "MSHT20lo_as130" = "0ivjvqabk9jnrlrczjlqywmijx5ql8wy579j77qkl1vhv7sqccm1"; + "MSHT20nlo_as118" = "1qwbwcq8p4hrprz4ib18mp5142b0lbyyzc1bf5a4iq5jjvi5qm93"; + "MSHT20nlo_as120" = "10y1a6iryahrafzdqskypjrnad6xxq08gm72pa9yc61xdy6andc6"; + "MSHT20nlo_as120_mbrange_nf3" = "0548pw6lkwwqhlrg7c4cyqh76bcyz78yh06fs7crdbx7hfl47cj7"; + "MSHT20nlo_as120_mbrange_nf4" = "0pg49mad4845llj49a1piaggd8wpwb2s4ar7jydlhrv7im886by4"; + "MSHT20nlo_as120_mbrange_nf5" = "0148agm89p7pwzdfjk8gjdaicll30xhz6sawca632kp5qwyd4g3d"; + "MSHT20nlo_as120_mcrange_nf3" = "187hgg8klk5jhcadiy8viyrfi0jfb3i18jckv6d7nsapixz1wgkz"; + "MSHT20nlo_as120_mcrange_nf4" = "12pjy0igjcsih100g238v143kq5cjjm5a13cghcipgcz2w4ldglf"; + "MSHT20nlo_as120_mcrange_nf5" = "00mipn9ndnw1k4nx6pmxb95wddmh98hg9k0317vlirxrf2n2jy7g"; + "MSHT20nlo_as120_nf3" = "1zy0j9qc28xpav3gx24r6r02zfz49r11ic66hkyq83d3q3fj751b"; + "MSHT20nlo_as120_nf4" = "0fpyf9s9ppb6w49chsmb2xfp9gwkx3ky9v8gwwqxli9fpzsc2ywn"; + "MSHT20nlo_as_largerange" = "1f57dvxas2c6qnv38ysnsyf0y8imafnrxkcqh3b0an19mkln5mmg"; + "MSHT20nlo_as_smallrange" = "1rygvj33g84whl24kgpqa47g11c48l93jlnpzqq8f5zr1ijqcq7i"; + "MSHT20nlo_as_smallrange_nf3" = "1d6cr1akc25mwfyghvn1986i60l76fxb8fd02h7f4pl4lmnn6i8n"; + "MSHT20nlo_as_smallrange_nf4" = "08js1l5g6knjx3813i0rf34xfjkbn3mdsrbawzkn00vf49xzcxdj"; + "MSHT20nlo_mbrange_nf3" = "1bwl4inshg5h3sslss4lgvcqahb5q0n794ag73hyacxd1kmx7d2z"; + "MSHT20nlo_mbrange_nf4" = "1sm995pzzr601wcs4rjgjs6alm74vc23szgmkqa5dvxghw7x8w55"; + "MSHT20nlo_mbrange_nf5" = "1sal7iqma7770593ifxypl9zapvba693asc8m2fjsbgpbfjjid60"; + "MSHT20nlo_mcrange_nf3" = "0lmv6m8m7zv0s8kjfm8parr9xlfy39dhwxn71z33f5x6cyp08zlg"; + "MSHT20nlo_mcrange_nf4" = "0875zfv0dws8n44fqawa1jp5p8b9vky8yyq48wijhrcph8qbxbrx"; + "MSHT20nlo_mcrange_nf5" = "0qjvam29zwibx54fgijry58vdwqkiwyavdwn736bmckjycncnv8p"; + "MSHT20nlo_nf3" = "1v0mzsa2sxp0g3m3d8yqcs7dgi74am6cpx79f341ahpwybz5x829"; + "MSHT20nlo_nf4" = "1lyii55adqaah6sm8b778q8scaq5yjycq3s8jdi3k48z8m23zqng"; + "MSHT20nnlo_as118" = "1yz0003ixjg97974648qba5d37vb4fhzzmq4k9xh4c37pnc3kgyn"; + "MSHT20nnlo_as_largerange" = "014a9x6zsw3w7b6w3v6lg8qxdjicxslr79bnagi6ci0skqs2v7z9"; + "MSHT20nnlo_as_smallrange" = "1bv7cbdynp6dm5c9v7r32gqy1lch4428apw426pr0d7xpm0abnxv"; + "MSHT20nnlo_as_smallrange_nf3" = "0n1j9dd069qdmgmd85m7wp29g96cnbgsdxrvlh6y51q063lkqbwb"; + "MSHT20nnlo_as_smallrange_nf4" = "1jkdl3rd933czz753qbi7yvszg376r6bvwq2inqbslnzfkfav5bh"; + "MSHT20nnlo_mbrange_nf3" = "095zcxhpfhlsb67ki4j6a8z4d1r5hzx92xlzprwkwd4v5ya4f732"; + "MSHT20nnlo_mbrange_nf4" = "1114z5a0pk9svps918zifff23difxf37rbmr3jnzxnyp1vfgzws7"; + "MSHT20nnlo_mbrange_nf5" = "12i6m01bmnzqadi6jg5gmah1jliq4wr4p0vpjgmpgyagsk4drx4b"; + "MSHT20nnlo_mcrange_nf3" = "01wq537083dr9ibiahwdwdaxj0j2ys211m478w9wgvihdjjvjvvv"; + "MSHT20nnlo_mcrange_nf4" = "04abrnlnbr94lksn29w9ws9a3b6sqkqvi9awmbk4715dxk2amnpk"; + "MSHT20nnlo_mcrange_nf5" = "0za255xi66a1mfch2b91qqmsr305m0kvs4rzvqlzf7k0v141j90y"; + "MSHT20nnlo_nf3" = "10yx59r32q4rl0yn4gpc29z8xskbvizkdr7k219qf16lnv892jpa"; + "MSHT20nnlo_nf4" = "17d10rba8b0aqi1npnx93j1995has5sw2l4izd6lly3yhjynbgp6"; + "MSHT20qed_nnlo" = "05c2hjgysyvkcyqg1lq3y00hqixgc8w984zivxkr76nj5csyf6m3"; + "MSHT20qed_nnlo_elastic" = "0in0y27gn4k9h6ya77krhizv8rg3i6s3d6h4bk0fhz91hbi4l3gh"; + "MSHT20qed_nnlo_inelastic" = "0vna0gbadf92w3xngb8gnsxd3lil8m029as8260wlki2axm4gqlw"; + "MSHT20qed_nnlo_neutron" = "1hiq7m8j7736477vfs18mqwhkxyvjmcrs7jiqysa8v6rmhb4bali"; + "MSHT20qed_nnlo_neutron_elastic" = "06dbvsysszpbvabgafb569vq88q1sm9mvz1iwv1m2b9vzin2ixiy"; + "MSHT20qed_nnlo_neutron_inelastic" = "0gfh6nhl4vq4qz1jhnv5vhhz4h4wlkwgj4ffjqll6jqa5anfhbqr"; + "MSTW2008CPdeutnlo68cl" = "1x2y7hl8ckplx175bp3wi04xafm44dd7vzfgnmvvai1x0072xi51"; + "MSTW2008CPdeutnnlo68cl" = "1szsdqjkmny30mpw4pdzi97vj7i55agxm285dvnkzp06ycgp1ld3"; + "MSTW2008lo68cl" = "0j12mv286r4ds9v7piqh4n44yjnc51hm74lqa4vv5xznxhibng7l"; + "MSTW2008lo68cl_nf3" = "1s5z55b2aj37bx0p305lcgrdclgvyl99xgfrl0rhmdgr2byg33wi"; + "MSTW2008lo68cl_nf4" = "0m539ihcz3dxy4gpfbam5badhhsimywlbgnczbybph8yn1118j9r"; + "MSTW2008lo68cl_nf4as5" = "0vl1q7xnr425sscbk4djqi56jbpzpi8l3z2nknfqiy3l7ykg23ng"; + "MSTW2008lo90cl" = "0af5j0s1i8yn0mjs4nb77migihw643lhd7dfl184v6wik3031yg3"; + "MSTW2008lo90cl_nf3" = "1a6kc1lgswjk800jzcqlbpwzz4rs3g6agckhnlr8cizmp9p7risk"; + "MSTW2008lo90cl_nf4" = "1bdjl58gslhw539650qwi7vbvsr22hpxpca17rkbqz9szh0ljhym"; + "MSTW2008lo90cl_nf4as5" = "1crsm7dfcs0fn1i2ng18wy23z2ap01xr2rsnafqlra0q135m6hfp"; + "MSTW2008nlo68cl" = "0pdvb5nshjjw7ddmdmj1v88m3jlk3vwfnab0pf2kf8hfx10hbv4q"; + "MSTW2008nlo68cl_asmz+68cl" = "0gwmxs0f7raxvmpn12zavzqsrp3x0a82y1vq2kf9p9fq17in55yn"; + "MSTW2008nlo68cl_asmz+68clhalf" = "1rmda4zpm6cs9kyxkhwpz38iv6g259156bmka4dc4zyfg1lcw85d"; + "MSTW2008nlo68cl_asmz-68cl" = "15mmdnd3wwlrs5pwwhfa9f88vjpgza8vwxwxpyadxsmhx9jk79hy"; + "MSTW2008nlo68cl_asmz-68clhalf" = "0dd7llc6ip6myy2yvf16riqs334f20l8wkmkksq53xngmz9qf263"; + "MSTW2008nlo68cl_nf3" = "1j82imyylvnf3x39x1mb19hhp2nbcq2lk82hf7sj72c557l3qpjk"; + "MSTW2008nlo68cl_nf4" = "08f008by768c8v3cmrsbgxpglqdj58nwwf22dmk2mbf2jq449s0n"; + "MSTW2008nlo68cl_nf4as5" = "0hrqmmnp20vpj6dpz3bvm531i0pvl06als8irqz91cknv6zsvxf9"; + "MSTW2008nlo90cl" = "1d3p4cialrngci9kn7225zcmyrr547dskzi74dfgdhbqc0256a2r"; + "MSTW2008nlo90cl_asmz+90cl" = "19cd358yqklc8bxv0mg69cq3sf6zah7di0q9ilfqbiddmw1flw3p"; + "MSTW2008nlo90cl_asmz+90clhalf" = "0ngn8f149agvmc54nrxjxqa0rifbd8a1hbcgpa443l75bmd9sqcp"; + "MSTW2008nlo90cl_asmz-90cl" = "0fnqj7ywnp9nz5733ggjwmhxpy15zs2xgxjz7ixmql5mmaz3sxb6"; + "MSTW2008nlo90cl_asmz-90clhalf" = "1jrp9q8li7a4bwhgh7q9h9zc0sdhck957zn14q9ca9kjsflyb9f5"; + "MSTW2008nlo90cl_nf3" = "02ihabrcgp474wkq4w2fshpiqdznjaxyg5vawv52yj6hxifyy5a9"; + "MSTW2008nlo90cl_nf4" = "1wrdl79qy8mimqk48705f3sd651zy130k1dmvvzwvdsjd9y8q58w"; + "MSTW2008nlo90cl_nf4as5" = "18d1pvijcyfxkipmd2v2zrkxdbhxygkcyn3p8vz0vzq5q7s1s7r2"; + "MSTW2008nlo_asmzrange" = "161364fvc8w8ggad58r1c58b0kngqa1bjpabaqi5cigmzazj3rl8"; + "MSTW2008nlo_mbrange" = "1b7z4mm3f8wjjbxb8hs8l7kclh1yfz5yffzdsch2i09c7wh79616"; + "MSTW2008nlo_mbrange_nf4" = "02s7ljzwamsha87i6nsd4kdfb9ky4k6m8xpqa1iz9wgrcy4pmw5p"; + "MSTW2008nlo_mcrange" = "1bndxfi27r8k0m4r26bfsflbbrjc4s2vp5ixy7qidkw33g6mqh96"; + "MSTW2008nlo_mcrange_fixasmz" = "10s2sfhdx5668cffwb0sbh5m54zq0inmpfnhkj0zk9ij4f5y815f"; + "MSTW2008nlo_mcrange_fixasmz_nf3" = "0zwnicbmmqbak5sw92njpmvxpjnnhwl1ggvlj8q39hn5w5kdy1kq"; + "MSTW2008nlo_mcrange_nf3" = "01mlzqwk30glr95g7n2y3yvvy7s6mkbdb5cqwl1m7k8d6m18n49g"; + "MSTW2008nnlo68cl" = "0y6lv1wkhydfnlakjrrrjapxaapa0bcbmfx0w9c4psgy156kv1fv"; + "MSTW2008nnlo68cl_asmz+68cl" = "0fhkbkshrc29kz0fc9vi2dqsg6irjm4sfw4sp0s4wkj766wg19nz"; + "MSTW2008nnlo68cl_asmz+68clhalf" = "1z0fplsv1fij4fgrz7npr34hcmc2qkf7g398bq1smvb6b2qy5jb8"; + "MSTW2008nnlo68cl_asmz-68cl" = "1qhjhdzpy67665ccwv0n3g7jlyb2vfk60cphjr0jb1adgv9fxa7q"; + "MSTW2008nnlo68cl_asmz-68clhalf" = "0rlsis3r7l32jdiq2yhx1mz7q6qlzlsrarljvrmxf0g0g2d8nr4c"; + "MSTW2008nnlo68cl_nf3" = "07nrz7afd1mcsqc3lqv9vk2phs1nfxdl63qh1bc0g7nznxwmmn97"; + "MSTW2008nnlo68cl_nf4" = "1kd62hzk2p3q56kj79bs101arp55ajlyhwwa3vq3yp37i3ynz9ds"; + "MSTW2008nnlo68cl_nf4as5" = "0x19rq5k9c97vzskqppf4k0fjahwiw2c1nb6iy5c2fq8mj1pz2gj"; + "MSTW2008nnlo90cl" = "13xqlfys37b8chinah2yqmzd0clzli06p7vjk30ha22wgwm02dq3"; + "MSTW2008nnlo90cl_asmz+90cl" = "0pd6imc3hvq7vgyv1db9y8rvpgz4ffwqv6rqzp27c7ipxg0wjyz0"; + "MSTW2008nnlo90cl_asmz+90clhalf" = "1xn52ppixjg22ybd8ggf0azb3zg5zyilqjss033g0k9crq4a6y2v"; + "MSTW2008nnlo90cl_asmz-90cl" = "10wxgh52zs0fp0bwd0b6csnz9x6mvp45gvjhk0y1dhgfwbcvw9y9"; + "MSTW2008nnlo90cl_asmz-90clhalf" = "1kmvp1yfgsx4jhsjc4drg82cq4xs6as4grwrymfkrqnvhcg86vap"; + "MSTW2008nnlo90cl_nf3" = "0vw0cmszwp49fsskacccl921za88cl5cfy0sqckgxzs4hx21x43n"; + "MSTW2008nnlo90cl_nf4" = "1b3fy8mfclgsmvpyzfs34fjry6djmkjcjppdxni1ipjyp1bcaia3"; + "MSTW2008nnlo90cl_nf4as5" = "05phi752spikwq74i0hfid7lsqi51hdvwxm520kdmbdz2pblbz4f"; + "MSTW2008nnlo_asmzrange" = "1nj68qhvlsqi7299d9rrsmq7pr6bdil4gzr6yla2cgn4wwiggdwn"; + "MSTW2008nnlo_mbrange" = "0jnmy4i593wz80lbm0r0cwdj9xw496p3in0lq8ksr4yjwz0agpbk"; + "MSTW2008nnlo_mbrange_nf4" = "0lw3p4q0ixj7plcmwqh43lfgv1i7ljar3f3k1v6f0imyvz8swfgr"; + "MSTW2008nnlo_mcrange" = "17v549iq2wn5zvxfdvq8pf5f7zvgnpa72i6gxvxzfqwkji7mv522"; + "MSTW2008nnlo_mcrange_fixasmz" = "05c8z2q2866550clx2mwb1jvhpn0agkyg82vvrswi3h4hgkvlfjx"; + "MSTW2008nnlo_mcrange_fixasmz_nf3" = "0r86xsl1wfphwdj2hhlilkwc2949m7bcn42dms14g7w45i24g6id"; + "MSTW2008nnlo_mcrange_nf3" = "1c9lsggncwghvw9mgd18h50ljrnlpp1p5r2zlzf8z3g8i4f3aaih"; + "NNFF10_KAm_lo" = "19wn44svz61lhk33kzc6id18w6qbkw4bfnwncar19phrjjp965v6"; + "NNFF10_KAm_nlo" = "191db9pj5yspiqc7598r147j9wvfc4s6cm0q805m5vmzpfg2cgr6"; + "NNFF10_KAm_nnlo" = "1hm8vhk1p31zdn72bgcyyq0w5qii1ba0cf81wjlbhwv4fadfd4sy"; + "NNFF10_KAp_lo" = "13yas11c7xxij45zrd3r6njjvx33kn9lg8i28ki0y4nw6ss21w3b"; + "NNFF10_KAp_nlo" = "1jza83klbcb3j2pcg2xhgj2imh4llb6hsfkbfj294q0isqypgzsv"; + "NNFF10_KAp_nnlo" = "0xwl34a31ajxwlgx6bhzzyf9b2xiq7bpv51p4zi6k1xihs91vwzc"; + "NNFF10_KAsum_lo" = "128cj81qp09hn99dnkm9q06wf2dr7xjq9qmwvrmdizrd8cwfa4l1"; + "NNFF10_KAsum_nlo" = "19pglfl1i5qg8sj3hg0qnhr1f66isfbrv7f901hnxniibbdjxib2"; + "NNFF10_KAsum_nnlo" = "1769ybc49a94appmiw0bbn3kkvcpw82sggxgvvda5jq9m36m9yzb"; + "NNFF10_PIm_lo" = "095xl0cs6p5z44hydfa963ylxvzqxdwwj1n8jn7n0c48rwssx357"; + "NNFF10_PIm_nlo" = "1fn8863092fn4aqacprbsdxlgz27q6pam08pccwq9ps0dwjn7cc5"; + "NNFF10_PIm_nnlo" = "0j4p50k821pphy8i6s73h3c29d7jb3bp5s4l8rl3bfb0nfx4p6hq"; + "NNFF10_PIp_lo" = "0hhw2ympx1a8d3sl953k27yzww0j2f5m9b865gv1ybb3l9ccv1i6"; + "NNFF10_PIp_nlo" = "18k3s7i1xvh8717n5cdllbb6zs8svh2bkw0k2zf4ql5ijiypvc10"; + "NNFF10_PIp_nnlo" = "16mywhpc3439dpk2c1i6gxrv9khyyg0kl4gsc41qyi3r4d7k6n2c"; + "NNFF10_PIsum_lo" = "1yh3hxfmgzgpwqidmzlc189syjbsj4vyswc4kch7yykxw4dqf6sa"; + "NNFF10_PIsum_nlo" = "12rgg0nc9rjvwfpf0y9kl1w9814a4pv4b17p46h8qm6kfyqqwjia"; + "NNFF10_PIsum_nnlo" = "19iz4q31apgm2il9478c7zmmc6kgz2wyp84qja761jvyl6z0img5"; + "NNFF10_PRm_lo" = "0c5pavhf5flx2nmld2dprgp1lsbvsrjw5mqdzvgkks7ibvq0ap5j"; + "NNFF10_PRm_nlo" = "0nfwhp9hacnm95w2qa5hvmfwaj7drc0w7lxqw1lrdp074bpd0ma3"; + "NNFF10_PRm_nnlo" = "084dz4xxmydf71vkhcrmj03jkwyj56jxvmbzm22mdh2dxmkz3l1g"; + "NNFF10_PRp_lo" = "014m0vjzrr4rbi84qxzmrym07kc4wax29fs66mfxkmrimxpb9l21"; + "NNFF10_PRp_nlo" = "0lrzw2618kgk7vsksbr1qxqc4h9lza573bz6208hwdgkmh7awasc"; + "NNFF10_PRp_nnlo" = "0bv07hh5rxvqw58jcam3piiiy19w325nrwivrifyv5wii8sybz8r"; + "NNFF10_PRsum_lo" = "1a9m77rl49wzzgdkr6x618bzcm2p50f915bbggknx5xjw550dqd1"; + "NNFF10_PRsum_nlo" = "1qambqywda7lvvkd6kx2r1g60v6lnqcamdd51396id33fvw3k45h"; + "NNFF10_PRsum_nnlo" = "1kijaxw6v1w33q6l89raz7ic59zcmd3nx5djp83lyg134a15crmw"; + "NNFF11_HadronSum_nlo" = "1n9fb71kl7y8rp1smyal28wdvdx1b410mhqkxmavnr1fs85hkh85"; + "NNPDF21_lo_as_0119_100" = "19qw2hp1yk82qgcrpx8wp2fg8wklaj6rr653m6mndhhr0aa0w80v"; + "NNPDF21_lo_as_0130_100" = "0p5cw77dg5pkhl3d0y6r3k8vhw4m467wf3gd8kp2l5vcbdwb4izv"; + "NNPDF21_lostar_as_0119_100" = "0i23axf0xl11nb2dn6p34bnm1xfisnn3a82db9dz863n60gqb5x4"; + "NNPDF21_lostar_as_0130_100" = "1aka01747071l53jx4v7rgmfj5danzjillbwincgi1b28mw78yhq"; + "NNPDF23_lo_as_0119_qed" = "02d85an11mr66yg3vi5fq4919ymbrh9h8b8qzzzm9dvfarzmbwxi"; + "NNPDF23_lo_as_0130_qed" = "0qsxxw3nds42924xqnhs56wmd8ihmrip28glj47q9r9i3kgw3lv0"; + "NNPDF23_nlo_FFN_NF4_as_0116" = "1d5wccg8l5xmdr8pvks6851zxrlgq1rk2y5dgp10k6r108059rgn"; + "NNPDF23_nlo_FFN_NF4_as_0116_mc" = "1sc13cqah6di97fmlnb6qw454jyrp0i9jv2pfxvi8ix2vzd6km00"; + "NNPDF23_nlo_FFN_NF4_as_0117" = "1gkzb46fnf9k97fgbbxljdnklffwnxmg58z01x55iklq4sn2aww3"; + "NNPDF23_nlo_FFN_NF4_as_0117_mc" = "0nc3fx9ggqybymw5kglwq3kmznc9hm28sp58gs1l4gwx3xiy0bj6"; + "NNPDF23_nlo_FFN_NF4_as_0118" = "1zlcqh0nfy8yf2cnzs0iy615nbmhpa2zh4carvifcqd4lv4azkp6"; + "NNPDF23_nlo_FFN_NF4_as_0118_mc" = "0518z8jakc9r74kzanraf2n8haminfipp2rvr1288ymhsl5bxyp0"; + "NNPDF23_nlo_FFN_NF4_as_0119" = "1k5mcql2411020m6vq26ck8ig3q01j79ndjgci2biq743m8nlvm2"; + "NNPDF23_nlo_FFN_NF4_as_0119_mc" = "06yv9mwgvhag5442581r7by3nsxcy7c76llgaalphbzszqr2vy0p"; + "NNPDF23_nlo_FFN_NF4_as_0120" = "1m97g47p44vq3izjji6agwmj2fwdvgddzy8w40mqqbr9fk19lbyi"; + "NNPDF23_nlo_FFN_NF4_as_0120_mc" = "0bjllckv61jc1y6f8c1gqdh36r15glqn8fqp99q0kckaxyszy5vw"; + "NNPDF23_nlo_FFN_NF5_as_0116" = "0x4kjj791hkwng4l5dvch8z0ig1nkliirlz9mkv02g54qrilnkmy"; + "NNPDF23_nlo_FFN_NF5_as_0116_mc" = "055clf0m8l8gnby2lgwh4wkyqciskwp54y34vb1kwfbhdf71zmnj"; + "NNPDF23_nlo_FFN_NF5_as_0117" = "1cplvrizlsjcixsjzlm2drssbjsrzj9bvq0k5mnv79r3p1xdp997"; + "NNPDF23_nlo_FFN_NF5_as_0117_mc" = "17nic3kw991dbrhyjyxpk0zzv8rjh0r0whd6nl8v6wsf5q5h0ny2"; + "NNPDF23_nlo_FFN_NF5_as_0118" = "07fgr71x2zk2ywcbnw0ikv0p9kzsmd83kdidfs49vm7azcbm0qfw"; + "NNPDF23_nlo_FFN_NF5_as_0118_mc" = "0s365gsidichyj9x5926q1gm0x1bp52chv7fkpirflrrsywf0lc3"; + "NNPDF23_nlo_FFN_NF5_as_0119" = "1qspxbwswz7ssqj2rx2jdg0bkj8prawwshvjd26ifz9i0l9qnqc0"; + "NNPDF23_nlo_FFN_NF5_as_0119_mc" = "0aqyhrcrzs3kqhj1hndilpibvdwfw9qhg1x0cypx97h16n37j46x"; + "NNPDF23_nlo_FFN_NF5_as_0120" = "1k9savpyg2iqr1ab4i5y7q1qhd8zxq413040h2v46jl8mp7x6bjn"; + "NNPDF23_nlo_FFN_NF5_as_0120_mc" = "01g7mh7v62s47cwdf6ws6j37gxl4mrb26ivdzzwmhy6ydiw8ka53"; + "NNPDF23_nlo_as_0114" = "0mmq32kddspgpacx2qj086das9z2bxh3l37qvp9yf84gqzjj7mml"; + "NNPDF23_nlo_as_0115" = "0jn1gv137d2x3vxq7ny0qc0hnfmcd4hs3cxkyn7j26w7p59q81x7"; + "NNPDF23_nlo_as_0116" = "1mnq360acd5vfwz9z8fzynldchkqrfiqhsxvi3s9a263h3p44bsa"; + "NNPDF23_nlo_as_0116_mc" = "0ngw2hls52bax6dmis3nfa2ix8q8nh2d9mwjax4cjdkmmf7rdn2g"; + "NNPDF23_nlo_as_0117" = "01wkq68b8zl3mznzvc4p7p9b4ik2bnqgjq97mw2287i448mnj9jn"; + "NNPDF23_nlo_as_0117_mc" = "1s2g55240gh9j32ach9rban0iw4hjmw5haj1c21wgyh4nqiqlfwr"; + "NNPDF23_nlo_as_0117_qed" = "1l2rbxn9fw72nmhqazfkh568q4df0q2jp0pn0fj368wdpf36fk0b"; + "NNPDF23_nlo_as_0117_qed_neutron" = "17rpz4bdp3fxvafiz32aawxw64prkhqwqpnfnbqsigcslm18bwnc"; + "NNPDF23_nlo_as_0118" = "01kax3g4d8nd6n1gip70d02kl3kvbqib93b99xgwc1f0np85p3r0"; + "NNPDF23_nlo_as_0118_mc" = "0qhs7r4zzw68grrmfh7qdad49w4y4mvf55qnp86piri5vi8lklwk"; + "NNPDF23_nlo_as_0118_qed" = "10xfv8nkg2jjy3yg9m9gakz6lixdvmahdy1z12znqyr1br57bdhy"; + "NNPDF23_nlo_as_0118_qed_neutron" = "1zffxfykx2v3dniypsvyyqbz5pb4dcww653amaxv96hplw3fvr0h"; + "NNPDF23_nlo_as_0119" = "1v24iwddahxy6sd43bxv6ywf8n7302qkwl9hv7d074q1d932kgr1"; + "NNPDF23_nlo_as_0119_mc" = "0l95fgr5bwhsh0h3qqlnx9czkgmrf5y084zlzk3qhix3ldh8zbp4"; + "NNPDF23_nlo_as_0119_qed" = "0rayscazcacy89lzg0ynpwrl9g4pnjwwp0l0vwc3gjz9cwznmwsk"; + "NNPDF23_nlo_as_0119_qed_mc" = "1cc3candpavcfbv681zpg8gmwbh3g14vqkhs2s6v7rr9xhx6zqv1"; + "NNPDF23_nlo_as_0119_qed_neutron" = "12h4x97yglcklrvwh937xa5bgqahq949a5wm3nyjbvrfsw9n330i"; + "NNPDF23_nlo_as_0120" = "0f8lwydw45vy7c0mqmz60hpc0b40czx0gx35liyrhcbjvj9129m7"; + "NNPDF23_nlo_as_0120_mc" = "0kqiizf0c0mbdavnv7ivk89kga84j7p7xprqi10589ggplchx8ag"; + "NNPDF23_nlo_as_0121" = "17603srm35158sdwrqijyxm614splx7k6bjyzphgvznnkwpgi0i3"; + "NNPDF23_nlo_as_0122" = "0c16498ngx436k9mb8fwkhhvcbdyjd4m0jh54v2n1dl354jz60sm"; + "NNPDF23_nlo_as_0123" = "1j6d7k8d04gfx532iipd4vzm0nldbvy86pg8asgv4xrh80c1zslc"; + "NNPDF23_nlo_as_0124" = "0dwv41kc9qsvvp22gvxi56gj13dnklgfp4ndrm0475q6gvfz25ak"; + "NNPDF23_nlo_collider_as_0116" = "1hl7xw8jz0gijxh9cjkxv1rb1xncb1622ghf6wnsaarlqr4947ky"; + "NNPDF23_nlo_collider_as_0117" = "08krhmjbgza9f4mbq7cdj9g7hh260aaniqqi5awbgp7idbn3nccj"; + "NNPDF23_nlo_collider_as_0118" = "17645h9l8z8nk7pdaxdhvcfmcvi8ib8yylhiijkkw9yrywb5pakm"; + "NNPDF23_nlo_collider_as_0119" = "0csf74lpxgzg48v6962falxd8n2nc9xdrqnxxwadqqyrnrfs06dw"; + "NNPDF23_nlo_collider_as_0120" = "17xqx8hnwy7a67ah0ds8m3nv3cbq20vri83nlwahwfsbig7w505x"; + "NNPDF23_nlo_noLHC_as_0116" = "02nhh7n2qzx3ak7ih2d3vw3a4dffxbbpv9wrh2yhz30zbrqqlzv2"; + "NNPDF23_nlo_noLHC_as_0117" = "14j8hx346krwbi2fyyk77k60d7dlk2xlsc6zd543y03jdpk4ahlx"; + "NNPDF23_nlo_noLHC_as_0118" = "0vwi6h1fkwjg28p2f3br1g601i8ca4dpfjs9vxg80kjzkif6k310"; + "NNPDF23_nlo_noLHC_as_0119" = "02l15h62gn0njnj459pkp3k1nhiaivlknmbxb3giqpg6wmm2m9y1"; + "NNPDF23_nlo_noLHC_as_0120" = "13lxmwmywg7wrwhgp0cb41b42479fgfa1bz3aqkbrnf6gi6pviln"; + "NNPDF23_nnlo_FFN_NF4_as_0116" = "0j4ng2vl955vnq40zv5v9sb0wk8qari61v7995p2l0sxz268sz50"; + "NNPDF23_nnlo_FFN_NF4_as_0117" = "1wjqlv6mbl2lgvwr5av47amrs8gnqkpkxzq91jvpaxkya3bmglc3"; + "NNPDF23_nnlo_FFN_NF4_as_0118" = "113s8lxrmif79c6f11pnk5jz7q4lq7108gcfx84nanpksr9dmi6m"; + "NNPDF23_nnlo_FFN_NF4_as_0119" = "1688qacmp9kl50q1vzffcprf9ydbi2bb2brc68jvid5f7bjkyfmw"; + "NNPDF23_nnlo_FFN_NF4_as_0120" = "1i3cjnz5zgk8jw5jcrqy6kxx1i5v2a2lgy2fdck3j19cvn0iqqr9"; + "NNPDF23_nnlo_FFN_NF5_as_0116" = "0v6ap405v9zapbi5sqldvs5lyhz5wsh4cxl8ssxj0l4789qm24hb"; + "NNPDF23_nnlo_FFN_NF5_as_0117" = "153f95cqd0hkxfy9p81mf2dfdp13h3fhhp0qyxmiknhqm10ykdxq"; + "NNPDF23_nnlo_FFN_NF5_as_0118" = "0fch9i9qj1k8h3sdwfdcd75idi0bv2q7a338dvj4697xqpxf2mj4"; + "NNPDF23_nnlo_FFN_NF5_as_0119" = "03r72mrbvy9jkkbmgvp2776xxgjx0jyxsv4bvpxmhscpym9mjvq7"; + "NNPDF23_nnlo_FFN_NF5_as_0120" = "0rsflim77kdp849pg6f87rq6j0wirj4gayvrnvi4xvfjlk1mxkll"; + "NNPDF23_nnlo_as_0114" = "1p32hw48zwmvj9i5iyg9pqhf11zwf7m7g5q8prfj8825dvsgql94"; + "NNPDF23_nnlo_as_0115" = "0smmwd7xla73sb3bci46grj1kfd751pybkf7fz3w3qdkp5jjglqp"; + "NNPDF23_nnlo_as_0116" = "14blxcfb2jbdgwh73f2spvqxy5dhn5v6ygwi346dzwswipwbixir"; + "NNPDF23_nnlo_as_0117" = "0di0a5dkskalllnh90ngfb046z5hm9ihjra1r1ck06v9ryam2w9c"; + "NNPDF23_nnlo_as_0117_qed" = "0dvzz7ac45j4m655k0i3ycy6xwfm6y6801qsb5bgp1kdv7g2pj3z"; + "NNPDF23_nnlo_as_0117_qed_neutron" = "0v05yw5nc1r7vh8sjag4fmdklkn4jmcdpsmgvwm7sblgfc6gnssm"; + "NNPDF23_nnlo_as_0118" = "14p9y1ryc1j26gl01sn60pmrfpnkm81bhark2g98xz8dmfmjp7iq"; + "NNPDF23_nnlo_as_0118_qed" = "15mcq4q20ijmf06pcc626jlk22fm8c473p4i80bmi27h5x2pl56i"; + "NNPDF23_nnlo_as_0118_qed_neutron" = "15vsjjc1i2x6lb0603h6knj68si8cvxml2xk97pw343qn3p8h4ka"; + "NNPDF23_nnlo_as_0119" = "1qzap9zlpwyyshh8hc0gm82y9rl9hpy232j03gd6vwmcw5pgm2d2"; + "NNPDF23_nnlo_as_0119_qed" = "1cqvdmq0hm9rh6749bn08i6c94gshpjafmwv8siizdlm8v9af442"; + "NNPDF23_nnlo_as_0119_qed_mc" = "0a77i8grscxwnybgikik94ldiddrif3yy6d4bqb6x1aj4hr9i5ag"; + "NNPDF23_nnlo_as_0119_qed_neutron" = "182jqm5019n94givs4rwblpz02hp90mbizp0b5svrxf21zdyrmbx"; + "NNPDF23_nnlo_as_0120" = "1v8ykgxnqbvfra57xpamhgbcjvj89dndhk62pmji004gvqpmwi61"; + "NNPDF23_nnlo_as_0121" = "1fv1m86ya7zi77ajd8r1nls2zcr7n6s3wqrdiwq5ikxidqxc6cgy"; + "NNPDF23_nnlo_as_0122" = "0bn6bmvs8w9qsqcpq8y8a7w64xbkvrqwiikm5shjprwqy9xbspyf"; + "NNPDF23_nnlo_as_0123" = "0w7sqyyf98ymxpgqfh8gr9g1pdwr2pw12zc8gqykn5nkjbbmijgy"; + "NNPDF23_nnlo_as_0124" = "1hilgda0gqyj81a5h0mxrl5g9ahlm1n6mhd3ajkicxz2fvxm2n1l"; + "NNPDF23_nnlo_collider_as_0116" = "07m2jwjwzjc4bdsx9dkrp41qn04f9z3k2m6n4q308hwdq9lmcm99"; + "NNPDF23_nnlo_collider_as_0117" = "0i4kggkkkp407r33a2nsdy329zxpx8h6dq0h0wwpvq1kmyrjk6i4"; + "NNPDF23_nnlo_collider_as_0118" = "027wlw7lk04grz5qavyymj21ik4zr9fy9yk2kwjc9gx2ycp3sj2z"; + "NNPDF23_nnlo_collider_as_0119" = "0jq3q3sh1p8rn1qap77794v9hh3j0b7pmfl24wxvpc4dly4al0vs"; + "NNPDF23_nnlo_collider_as_0120" = "1s0jic8amasmxczdflbbhn6071nx8cxr3ynfrinllp36d92pmgsx"; + "NNPDF23_nnlo_noLHC_as_0116" = "0jzn78p2gygsqip50jfnnrmwl7issbp4vzpf71cbvj39ihsmavy0"; + "NNPDF23_nnlo_noLHC_as_0117" = "0zns2yy50c0bm91y8xaafmzhgx1wafvmv39cykw7xwsnkgclh487"; + "NNPDF23_nnlo_noLHC_as_0118" = "0v5bdc8d9w5g606h42rpn6zw31y1a5nk9akgfd1lyrhilvh7ayck"; + "NNPDF23_nnlo_noLHC_as_0119" = "1zacfd5jc5wvcig0g8g4jkr77zcxvzcvppa4ci81c1n8d0whnr5s"; + "NNPDF23_nnlo_noLHC_as_0120" = "1lx7m8ajwvhkzxck2ngxng1g90fpay5r5iwdnk2w7xgp1hb1ayc3"; + "NNPDF30_lo_as_0118" = "12adhizxskpjzdr6inc2hi6bxrs8ns3bnyihz09hfh9q53d5ayik"; + "NNPDF30_lo_as_0118_nf_3" = "1gjaiwqdhlswf1qmw39xr6g0w4bnnbinfpwl9c37jnggk6dxwdjz"; + "NNPDF30_lo_as_0118_nf_4" = "121xn280f5xx04q0rr4ina9iqzbc1v8cay78km836kqvgb3pcpyx"; + "NNPDF30_lo_as_0118_nf_6" = "1s77g0bf1qjb9rn1svnpfx10laxx87lw660ark9fhhx14zgybs3i"; + "NNPDF30_lo_as_0130" = "0nvpwbmdzm8fn4wlb2rhzar71kk4myfddpqsqhd7wb1fqxkj5b7y"; + "NNPDF30_lo_as_0130_nf_3" = "10diiahiy3yk6y7m1r4bd6nr1kf4mnccgj5qyq2lw49highn4s8k"; + "NNPDF30_lo_as_0130_nf_4" = "0j3b3rj5pr2ws3yaq6h74hhsjy7lv3d2x5nryc55q22xfkgf451i"; + "NNPDF30_lo_as_0130_nf_6" = "0w7k4a9ir4xvfh3v6dba70rhwkkq7qk16z178wld26zl6a7gw1hk"; + "NNPDF30_nlo_as_0115" = "15g9alyc317qydqy3g7sqlh6pc4pxn3xmhmzv9lcw2ghg3gn35fi"; + "NNPDF30_nlo_as_0115_nf_3" = "05b5xl89jvk6bgp86yl5hwdh3x8211czdsbianqkfix35rqrvlx3"; + "NNPDF30_nlo_as_0115_nf_4" = "02p9lhvricjl5r79pkcm2fv14p9gw1d2qizka4w254ang3i1hcm0"; + "NNPDF30_nlo_as_0115_nf_6" = "1iabf2qszv1270ac2sr2bqs7rb3gm58fj388saqbhnra4p2kv9fw"; + "NNPDF30_nlo_as_0117" = "01my1m7vx7yax8ldnjp7s1mz1w3x3m0h1gdd8mamfrvphaghwp4x"; + "NNPDF30_nlo_as_0117_atlas" = "0vjfh6kihsypvkpg3fwqf96kd2ldq0azcl72ia6w1nr52rsqc27l"; + "NNPDF30_nlo_as_0117_cms" = "1sbaq99731ihrkp9a2fj6lxj9dr2c9j4vp2335249nrkinfpf4mq"; + "NNPDF30_nlo_as_0117_cons" = "14qwjsa633v3h0sbizmhifrwdm7fmglyk608lq4ims8y7nn491nq"; + "NNPDF30_nlo_as_0117_hera" = "05gs9ril5vkm7xrnz5pvjd6pk8ivgk0bl4bh45gx658fgg2snhiy"; + "NNPDF30_nlo_as_0117_nf_3" = "0jc8p8h9pny0l7j3hv55iwaw684ymj0hl62d6bxlvw8sqvhxcqyl"; + "NNPDF30_nlo_as_0117_nf_4" = "0a37b46ach3m0gqniwk79qk963w0m96dknda2rhp1glpg5xdxl0z"; + "NNPDF30_nlo_as_0117_nf_6" = "1hjj6k5g2fia7xq5piy0dhsqs9lwriasmppjwil9wxnwklnwmr2m"; + "NNPDF30_nlo_as_0117_nojet" = "0z3s8ixmq2l4znv2dn0dcz9rq5f9b3jgnlwmvjzcab3wvj1za687"; + "NNPDF30_nlo_as_0117_nolhc" = "1x9nbnxm72wzaky4rvlrq1kmqs86ypphqwvsng33n0zdd9yr82pr"; + "NNPDF30_nlo_as_0118" = "0b51qb2i3h9d7hrviarfszwljsy88m8ibzgz7dd5gn88k9kardrm"; + "NNPDF30_nlo_as_0118_1000" = "17yla3w0rqy1a5hxq3bfq94ddda2qv6zzj76lfrm4zahl6m02kdy"; + "NNPDF30_nlo_as_0118_atlas" = "034h2wgakbm3mx70034nwb44ii38rca7xv3az3fhcnjbpg9vnf0p"; + "NNPDF30_nlo_as_0118_cms" = "08g9315fpc4khwfjf76vvyqa9nannvwq0bpc42f9f7yc0pck71qa"; + "NNPDF30_nlo_as_0118_cons" = "1lw0fhy9gwk3zr7vq7qh9p6zprbyd4faln3npnxs2snncic1mnz6"; + "NNPDF30_nlo_as_0118_hera" = "1833gd9h3gg75hblxf5qh5hp61k7n9vavb91ll9lbqmcbfr34aas"; + "NNPDF30_nlo_as_0118_hera_1000" = "0lljb96d3q25yw3fz3cbk2in90q6srpc4alkz95nyrvgp25xgbgy"; + "NNPDF30_nlo_as_0118_hessian" = "0h8d2zc02ccr1rmlsf4xd5a41irbs9q9wx68caj2xy0i7qr8rsmp"; + "NNPDF30_nlo_as_0118_mc" = "12nnyzh2f6mv4gq4x4b8nlqx34lbj5y2y60zivfdbcpyg2spj5y8"; + "NNPDF30_nlo_as_0118_nf_3" = "10f5md8bhf44n5x6r7ln8c58a9ylm4mfgxg30vd0d8mvjc3zpsng"; + "NNPDF30_nlo_as_0118_nf_4" = "0q14zqkzqy2hgh8wli5db7dsqgsljgbc717da661wj8kqa23w4r4"; + "NNPDF30_nlo_as_0118_nf_6" = "08ajfn1r27hdarff464j2gpi7ffjjxs6pwzh3vil8lpjij5y7d4l"; + "NNPDF30_nlo_as_0118_nojet" = "0zzzk72n7nq1mcaalbv7mpfpb9kh095j0zazbzfjf2k6r3p0v082"; + "NNPDF30_nlo_as_0118_nolhc" = "1p7iac75znr1li8qg9xf1my37i70flhvjkfjmrb5b0h3hk9agb1r"; + "NNPDF30_nlo_as_0118_nolhc_1000" = "04mgjfq1ncy90gqljfdzw1iwzav5infkfv7zj2rid088n3qfs91p"; + "NNPDF30_nlo_as_0119" = "0p0kgw17c97p99zy3ffr6g7pphhc8ccdhcq4iip5drqm4hc6nb58"; + "NNPDF30_nlo_as_0119_atlas" = "1hpx2jm4y6kz9b4j42ags98j115hd2s41km670979z9zxmj2qm5q"; + "NNPDF30_nlo_as_0119_cms" = "1j0135mxdiyn22iqrmg0d44w2w7ql1cdacprxgdz4jfb0ppn68rx"; + "NNPDF30_nlo_as_0119_cons" = "00qvhq9ypqv62zvlg32k3x5gibl5jh0b78hyrpvxf1l3y2b77nw1"; + "NNPDF30_nlo_as_0119_hera" = "008f4m8p9gi4w61mgjiqqpw346rgqxaayc1rncy2fggl4gs64yi1"; + "NNPDF30_nlo_as_0119_nf_3" = "1bh0sl8pjy5n90j5dz9c80n3vy21hdsv8vxwbqkq0b2lkv8gzw5g"; + "NNPDF30_nlo_as_0119_nf_4" = "0swgnmbxz0g3ziib1992s0454jfsdi7l0x3lrvs5qzzjk6rg6qgd"; + "NNPDF30_nlo_as_0119_nf_6" = "001awj8h76wybmxj9vvkxgqixzak4zbhsvjmj2lscb2v5qq3y68r"; + "NNPDF30_nlo_as_0119_nojet" = "1x961nmad1rxmf4yzbz2drpi5hfac2ag1bs1jbvvlw3p04xr2c38"; + "NNPDF30_nlo_as_0119_nolhc" = "1yx6f4n577zqwhp0i440r6zk06702jg4kkib9nmgws3jl5f28big"; + "NNPDF30_nlo_as_0121" = "10k01z1amzp3jmfvfb2snrm8d04vr31kly1m30pw4fv0qn78idlw"; + "NNPDF30_nlo_as_0121_nf_3" = "1gb40ycnf42fkrbdwfhb8wp56nmzxyi7fzbqgvlkby7pn86m2f7m"; + "NNPDF30_nlo_as_0121_nf_4" = "18ywp6b9f83rxmh7gfn648wslvvf5g4ffm83rradp308smr1sv6p"; + "NNPDF30_nlo_as_0121_nf_6" = "12dps7n3glrzwb8vsfghwbvnh1yyxvjnvqfilbrrcy0dm3sams7b"; + "NNPDF30_nlo_nf_4_pdfas" = "0hrx872m52bb894c32jrvlvm9lcpy3yllj5ps52nmywqd8n1simj"; + "NNPDF30_nlo_nf_5_pdfas" = "0q25jxvwpz8inkax0j2zq9pj8swqfn4jmkhs4ibkl6xs78bhjfb8"; + "NNPDF30_nnlo_as_0115" = "03apmzw7krj77zdyl6sxwqg5fyv3vicp8iax445qdx8ld9kv225w"; + "NNPDF30_nnlo_as_0115_nf_3" = "08y1gjzkpnjn6mn247n7a9ya8z6pml3602p08rjha4ljggxhyffq"; + "NNPDF30_nnlo_as_0115_nf_4" = "19mjfk1rib9dxbsn0473ggi6akwv1zs9y3q9nzjg47mdjqlspb2q"; + "NNPDF30_nnlo_as_0115_nf_6" = "1zcjjbjwjgbkrhgh0kira7wzwmy5vvi1n15wycg33yk09m06db6b"; + "NNPDF30_nnlo_as_0117" = "1225gj4ihmphnfav2h38rz17lj1dyi9j1lazqlwww8vizl8933bz"; + "NNPDF30_nnlo_as_0117_atlas" = "0i9nc7q1cwl8cxxaj1xaz28wmj09q5bjmh19p1fcbcln7hklvj5x"; + "NNPDF30_nnlo_as_0117_cms" = "01ffhsw191nrr58x6wnjizx7bbijkknicvgk73pjbwyr67gfj581"; + "NNPDF30_nnlo_as_0117_cons" = "1blfi0p231r5j34wspk192fmbv34gbvx3bkisjh7wxpiab80qdws"; + "NNPDF30_nnlo_as_0117_hera" = "0ds02aj1q6y4dndfk9l9fyxci0dhpwr7jx1jq1qb9g5bb7bbhzz1"; + "NNPDF30_nnlo_as_0117_nf_3" = "087rz8bz3j2h7yk7rknlqz3rpbczgx2r2zdag8pjccdqi9jnk9pg"; + "NNPDF30_nnlo_as_0117_nf_4" = "1w44bwx6m6g8r990vl6f505bgf3v583mi19r0nfh2pahx2k2djaw"; + "NNPDF30_nnlo_as_0117_nf_6" = "1l7gwbsl2haqaj6hqsnnqwrnxrkdv1h63qbs7iwfdq6474ndzwsf"; + "NNPDF30_nnlo_as_0117_nojet" = "1nmv44arab9gfhs02jf4zijdb0644pvdmi6k809bxbfhir9sry8v"; + "NNPDF30_nnlo_as_0117_nolhc" = "0zn2b05jv9da7394in14mswvma48y26lvpw7rwh7wmyw323rxpfv"; + "NNPDF30_nnlo_as_0118" = "09xxi0vq90n9vfzq72c0mbf4yz4zif3kl6xwcjdb8r620ihwrnfw"; + "NNPDF30_nnlo_as_0118_1000" = "1iy5inrsfpn70w65hy42pmz0630pbrgg4l48qgsamcjgqdhd3n84"; + "NNPDF30_nnlo_as_0118_atlas" = "013jm6f2hnmzc2di7spf6zp31fwhm6c9sddwql36hww63w8sys71"; + "NNPDF30_nnlo_as_0118_cms" = "1w0ax68rg5877s35zlg13c451fcz2rij4adzwhz4yf4skkbgflng"; + "NNPDF30_nnlo_as_0118_cons" = "1qniswwj6cmcs7bm4n11jx2disqcwszl08cb7im824nvrcjka2pg"; + "NNPDF30_nnlo_as_0118_hera" = "05j5yrra93dxh1nah19hszd0q3pj4zfica8a7vm5akbfn02rccj6"; + "NNPDF30_nnlo_as_0118_hera_1000" = "0ssiw9fk5fqwg77rbycrxrclldws35n6gj4a4sj6d9yc87vz1g7z"; + "NNPDF30_nnlo_as_0118_hessian" = "1hb32bamwlx5il8g2sf5gy6xjr7r4rky7xgvdhf5ndq7v3n1ncx1"; + "NNPDF30_nnlo_as_0118_mc" = "1gxl4c5z2vh382y8l2kpr8vy4fqvbxvrw6xjc6dp229ak89cd6c2"; + "NNPDF30_nnlo_as_0118_nf_3" = "0iccjcds9j9pp8s3mwrshhzl5anklax4rgcwm5im90hipj450rgj"; + "NNPDF30_nnlo_as_0118_nf_4" = "002r0179jsl0l43psvw3hd1drg9fcrlzw57sbyndlswvq4zkyzyc"; + "NNPDF30_nnlo_as_0118_nf_6" = "1mwh2dxymayxa2khxjfxqmbhaj85jdnz548wmq6fyrxr63cfmw07"; + "NNPDF30_nnlo_as_0118_nojet" = "0nly14fxfww78qihrd8b6wk3da24x5sxkb13h8l2cgdxkq90fxbd"; + "NNPDF30_nnlo_as_0118_nolhc" = "11yvr5h66v37376d5p2m2g8fajdycv9baqq6mjfphf4a2abrl7m5"; + "NNPDF30_nnlo_as_0118_nolhc_1000" = "1bi0mxs6v1izlbvich55vi7qab72v1sizd4wj13787w47ffqm89p"; + "NNPDF30_nnlo_as_0119" = "11bvbqqjbyz0vjd4kh5qyd0a4rb62l103n10d1cyffgdfxxsk8f9"; + "NNPDF30_nnlo_as_0119_atlas" = "1fm46crfparx2swpxnyscpwqgicxb4skhclnc5xaijcpzraflzp7"; + "NNPDF30_nnlo_as_0119_cms" = "0i2d4wq7bsbfp8hqdr88nbii980zhfmpg6758czz7swd5yv8076a"; + "NNPDF30_nnlo_as_0119_cons" = "0v54zyz410rg3wcdw44japzynzvvrbjrspk91d0129rdv2xz51cg"; + "NNPDF30_nnlo_as_0119_hera" = "09w3krirq117cnhfkxlb8pld3xb5g2r3nhgc11v3ksavq746jhvk"; + "NNPDF30_nnlo_as_0119_nf_3" = "1k00h1c0lv6884lb02qmqki7sfmxkqpj88fkvf057frk120f59ah"; + "NNPDF30_nnlo_as_0119_nf_4" = "0pqjvaw2ad3g9zzjdyhh72580jrj4p8hxlvy9h6q9hhpwdihnnmh"; + "NNPDF30_nnlo_as_0119_nf_6" = "096fc9958s3z559knxqccwj3vylxviq2g58rwirj3qdjvy96y2cc"; + "NNPDF30_nnlo_as_0119_nojet" = "0l5crj00jm2vxgyr5nhs6h1n64xnxwpanrsjk8f8qfis37s68ar7"; + "NNPDF30_nnlo_as_0119_nolhc" = "1nl4gkjjz3kpq1sbzqk2d0d50vmb3ks7j5z14hqf9dib2xr39jl1"; + "NNPDF30_nnlo_as_0121" = "1c0ddbjskxw4rq1p8sp63vayxkvcnls062qp16wvrrbw7zkj1jaa"; + "NNPDF30_nnlo_as_0121_nf_3" = "1sj9g0wg6x2cvwp45i726dcs44hpqjiqa011xzindnjh8cq7m6xn"; + "NNPDF30_nnlo_as_0121_nf_4" = "1j4khzpw52vc26n7a95xg1wyqz720fnz2kbb8l9a5bsbmxmaa7xv"; + "NNPDF30_nnlo_as_0121_nf_6" = "1kln7zjgl0hwl621wnhhsih0m8f9ir2i8ligfg2s0qp8s3787lrg"; + "NNPDF30_nnlo_nf_4_pdfas" = "0s460v9712ahz09fhzhlnsnkl9arsy3l82g1z6xjz4la8fwkr9wq"; + "NNPDF30_nnlo_nf_5_pdfas" = "1vjfm9j39m4389b0r51axlbzdbkpk2vbs3vks3yqcr3hr09g9myk"; + "NNPDF31_lo_as_0118" = "1jq8ad68kym717qinwdldvrjnry9sfsfq7lvfv6ipm1sdzixqm96"; + "NNPDF31_lo_as_0130" = "1lg49cbg43yrpb7fgqfk0d55m28rrw781mks3zn9m24fv0hiyzqp"; + "NNPDF31_lo_pch_as_0118" = "0xm3fyvrm77hd2layrfwc74vncc470gvf7hx8nzd2sw3ai1g9h7x"; + "NNPDF31_lo_pch_as_0130" = "18fip94c0ywzj543qq154z2wnllbn8jw61nx6l8v9wmg2sdzi6zi"; + "NNPDF31_nlo_as_0116" = "0i6bpa2wf52vsc6x5nlsmncal1ghqpsyz7pya2a2zg0k7z6dfcsp"; + "NNPDF31_nlo_as_0118" = "0vwbgaxs5gj5cnyncmc7m3650pd6bplwdga3fnyy1vrrh3mpsngh"; + "NNPDF31_nlo_as_0118_1000" = "0ql0phs563ck7bx7cm5x242icfb2jrlsxhsv80m0hxyr3fhyc06h"; + "NNPDF31_nlo_as_0118_C1p6" = "0nn6krh6vk8rxiwhpnn3nbxian8hw8d1vq31ywh9560hbi3vpcrl"; + "NNPDF31_nlo_as_0118_hessian" = "10v2ayms2mhm9zi7k0fw9rshawc7njdlbjs8rfg5hiqn1adss4w3"; + "NNPDF31_nlo_as_0118_luxqed" = "19fdqxfmx8kzcgq13dk4k1nhkgqpnm5xgahp13hwz1i2vcp6xq87"; + "NNPDF31_nlo_as_0118_mc" = "1yw21cs6p85ij8lm9k0cvlm651a3x9f73f23ysxjgh1r5kqnhz9y"; + "NNPDF31_nlo_as_0118_nf_4" = "0qywlyd34yqb2r8ch9wjimyfi1jr3rdhxliwrmns0558hbd47a3z"; + "NNPDF31_nlo_as_0118_nf_6" = "1pb22z2s0ir130dk5pkxwyid37i6mf8jpr7k7nlfi45gl9zy5ldd"; + "NNPDF31_nlo_as_0120" = "1b5wsab66karm1ay5vxpjw21g2ywhnzqnlahxnvnaf80izha35hl"; + "NNPDF31_nlo_hessian_pdfas" = "0sxka18qp99gjj9abml2ba4877zavijmjfzg6m0qczx9m8v9m3xg"; + "NNPDF31_nlo_pch_as_0116" = "1wqpq2qj5czvcj754nd6c7rrss8skjx58vp2gj2bc5n95jv1qazn"; + "NNPDF31_nlo_pch_as_0118" = "113xpp3xvpfpivlj6p7av4czfbfnh6bk2kd4d2635ddvy0clqkpf"; + "NNPDF31_nlo_pch_as_0118_1000" = "1sbjqkwq7iy7fnk3r9ga1rzadzy8x3ld933vcih87is09bzg5rfl"; + "NNPDF31_nlo_pch_as_0118_hessian" = "0xmz2hc3n8alhf210axv3amf7klhbyl1dd1z2yyx6c3pcvcrf80m"; + "NNPDF31_nlo_pch_as_0118_mc" = "1w1jifp5f7ypf5xqdw1mkx1d6shknryhqzk8rk8naf37bms68mfn"; + "NNPDF31_nlo_pch_as_0118_nf_3" = "0m7rq7k8x6bsakkw3kmcicq04c39flrw1axv72dqaf9xci9w3pii"; + "NNPDF31_nlo_pch_as_0118_nf_4" = "0k77chw866shjkc0ml6kb4az75sdcvdd897r8d56jl72d2lkxp3m"; + "NNPDF31_nlo_pch_as_0118_nf_6" = "0bdc60dxj7jmqacbbaxp2m9qzg82r6pgn7h9pi2k15d07qm6fc4d"; + "NNPDF31_nlo_pch_as_0120" = "15s1b5w52c3q1nfzckdxmdwrnxw08pprmphc1p33am9v7cwwq2jk"; + "NNPDF31_nlo_pch_hessian_pdfas" = "0qdswml17bg68y67yw2zbwwp233nxpd1qpc23rqjwyzk2r7qk9bg"; + "NNPDF31_nlo_pch_pdfas" = "196pcdwsi5p9g88g1c8958qkdj6qmzvl7rsg3j8zll6274m42s4c"; + "NNPDF31_nlo_pdfas" = "1as7bkp56pwpn2vinxdnhzlnvnxx5ng0mlpmwzz5n7gsinyaz1x9"; + "NNPDF31_nnlo_as_0108" = "03kg0i43wxf794c4xhvismks6c7nw9hq9ihn58sz628lqcjmsccq"; + "NNPDF31_nnlo_as_0110" = "04a5gf6nyd58h9sad8zv46vmb074dx7j19r23lbc9w1di23sk104"; + "NNPDF31_nnlo_as_0112" = "1xkjjm49nlm72f4l3ynrm4g2ayzask22saaf6p1p61lx0jv1hjyd"; + "NNPDF31_nnlo_as_0114" = "1j4q47qscyw52swmnn0a3lr0avfsjvy20ca50xfhjsvla6wd9lpg"; + "NNPDF31_nnlo_as_0116" = "1k2d4jzg5jfs6f2mscpvalmh7i5fypx98lnb5wjycprlwd3nr3i9"; + "NNPDF31_nnlo_as_0117" = "0b6d1xlq4qwjalvrc7ppavw44w5zf0fn3rbsvh3k4qy9r19wk5fb"; + "NNPDF31_nnlo_as_0118" = "1bw2ksmxdfbwdcimc0ld87hanbqy514sridrcarqwgqh9yv5n0qp"; + "NNPDF31_nnlo_as_0118_1000" = "026d0xygh046y10jxsfc91hr4qxgark12m393r0afip69dzdsrx0"; + "NNPDF31_nnlo_as_0118_CMSW1" = "0vqjyziilfzi0gz3a2rv0i6hk3ri3krc2zcdjwfa61z1mg5syi4a"; + "NNPDF31_nnlo_as_0118_CMSW1_hessian_100" = "1jc8k64pj1mfcw8v9qq9v8m222d09bgfkla7viqzzzbdhy5f6yy1"; + "NNPDF31_nnlo_as_0118_CMSW2" = "14acp7w3sx5v4ly5wa32vpsk8xw2rh8g5gl7x3f72c0s5jcs4n81"; + "NNPDF31_nnlo_as_0118_CMSW2_hessian_100" = "0ykaw8x0i6k8vlbms2inm9zm860apsi5mf4wkxha416v4chrpd04"; + "NNPDF31_nnlo_as_0118_CMSW3" = "1snkandx6apar3sp0c182n770rxn2s64pc07h5k18627cnvpzing"; + "NNPDF31_nnlo_as_0118_CMSW3_hessian_100" = "03n59yvpgciipkv3k0yr0ab3myhx263n90ah3q3h8hdszkf80ri1"; + "NNPDF31_nnlo_as_0118_CMSW4" = "1zpnvawdj20izx0mx9a3xz0d0an6i65axbzg5z7fkiq0p09rfx70"; + "NNPDF31_nnlo_as_0118_CMSW4_hessian_100" = "1qczy2935iq2h4mfq0mv53v2vlfsyvhkff36c5dkdlkrzfkvpl8x"; + "NNPDF31_nnlo_as_0118_collider" = "1y2axnkjwx7yg301mj1yx1x937j7mhsnbbdpip94pl3vm5hz10dk"; + "NNPDF31_nnlo_as_0118_hessian" = "0jvzl1bs0mh9c7ypkdgw0s06qn9jkww1d124lc7aq48w1g4n0zyy"; + "NNPDF31_nnlo_as_0118_luxqed" = "10fwxncr1y7hnja5nxywldpkzrijxz5ayldqjc21jamyhyj3qsh7"; + "NNPDF31_nnlo_as_0118_mc" = "0sg939j6xn7d5g46547np3123srgz44h9clh29ybl5cnmccv23cl"; + "NNPDF31_nnlo_as_0118_mc_138" = "1kbxhjzrr4802kcpi7m2g2dx4ywvs9rqjispjwbjc60rqkqispyv"; + "NNPDF31_nnlo_as_0118_mc_164" = "0i9yxnbps63nz6ala4jk6qmpxlg6p46w6jja8qn73hp0n69w2acz"; + "NNPDF31_nnlo_as_0118_mc_hessian_pdfas" = "1b9ijn595qfq32yz9rlnn2br7lssbk8ka39ripfcfyf33v9sv460"; + "NNPDF31_nnlo_as_0118_nf_4" = "0l796ns5xm0biyl0jra5z6y7vddv52v48wlbdywsq54082scfpl0"; + "NNPDF31_nnlo_as_0118_nf_4_mc_hessian" = "1bw0x75pah1kp387s8m0rv2qc54k5pbncbv507d5278hhfsn68qa"; + "NNPDF31_nnlo_as_0118_nf_6" = "0dbxxk0p001sk6sb9nf5ipzi39w65vf4c4g8cbhll7p4fqi8f8dy"; + "NNPDF31_nnlo_as_0118_noLHC" = "18y9mnp1gmvdbikgfdybw8wz2w5x60wk8lya13g7z6nhbfs08qa4"; + "NNPDF31_nnlo_as_0118_noZpt" = "1jwhkz8b1x6a2qi62jvprcp1rmcq5aq7s31qhw0skcpx8r6r6gnb"; + "NNPDF31_nnlo_as_0118_nojets" = "1bg714agc25p7zw2yydvl340sns7fhszpbphzap6fc0jsg511zh5"; + "NNPDF31_nnlo_as_0118_notop" = "1v675r4qk0wz1hg000fw79nmf1zjqi2ghvgjgs7hyzzbh5g4l3ds"; + "NNPDF31_nnlo_as_0118_proton" = "0ipsp8kk59fb3w9d1y4pq85f4fl6789rypjfbpp44gcy8hzshbm7"; + "NNPDF31_nnlo_as_0118_wEMC" = "0savd87jahlac4ag3qfamhnpa7mpnm00j104f3ci17gdax1sds50"; + "NNPDF31_nnlo_as_0119" = "1s7ildlffbh6cpmzlmafxzbbrlgggfqxsv4qic99yvgqvdgqar8w"; + "NNPDF31_nnlo_as_0120" = "1z6lqcq1dgvqnpwlfymlf9yhcaqc2p8ny7wv4xs57639dsp5xarb"; + "NNPDF31_nnlo_as_0122" = "0482r1hip6c4kpq24xzi8nw8awky0669k4plgpgv0av12l4bh9c9"; + "NNPDF31_nnlo_as_0124" = "0cf3djgs4gayzwy8p0qvynripz3hxd3866m8ldlhxnjmcsgcps11"; + "NNPDF31_nnlo_hessian_pdfas" = "1m5wdnj7hvg2a51w1qmhm934glhjf9db0x5nry5blp90y5x0v185"; + "NNPDF31_nnlo_pch_as_0116" = "1i8yzqywg4hcf53vcp25fg8llybis3pz6xbp5ajpyjvrvsgii1pc"; + "NNPDF31_nnlo_pch_as_0118" = "01rsx0ss67772b20dnnw463328pgbd57d8zcj3lqymlb4a6fq8f7"; + "NNPDF31_nnlo_pch_as_0118_1000" = "187xkvp7y1wssgpb21r1w4yxn6m1280jac9nmiavrma06jfd57c1"; + "NNPDF31_nnlo_pch_as_0118_hessian" = "0fs5d450hc15hqs6xv9nxfsnhwszmg9ybjypgwa9kn4s4kkaz1wl"; + "NNPDF31_nnlo_pch_as_0118_mc" = "06vgb01l1yigln7cn9y3lslg35grwvydpd8g04xn4pj4pj2vjrs0"; + "NNPDF31_nnlo_pch_as_0118_mc_138" = "0za3v1mg8gb631039kg5mkr9zhn390dkyim9p663srpk85j7h5g5"; + "NNPDF31_nnlo_pch_as_0118_mc_164" = "1xc02sbmhyjr4gjwim4p0gg90zh26zdmnz89395pxzbq2navcraz"; + "NNPDF31_nnlo_pch_as_0118_nf_3" = "14xb6m1wqc5f7xjiklwnshn7ljrlg6kmbzr2rib44pgbj6pnl2xn"; + "NNPDF31_nnlo_pch_as_0118_nf_4" = "1sg823n82j9ijqx4ldysh0g53pjzn4sysvag837ywfyns4p5qy9k"; + "NNPDF31_nnlo_pch_as_0118_nf_6" = "14ls2yd1n2pqvdvq18qmhizms3a8pwqvksdkvwn0m1379lkss106"; + "NNPDF31_nnlo_pch_as_0120" = "09zc56cmpj9iw0qp2bm9a8d86r0mdagg1vrpf2xqza4fr841r5km"; + "NNPDF31_nnlo_pch_hessian_pdfas" = "08baysni2lhbpr1scx7h0zf64gyncj2ahcv4y86142gl4zqrafvp"; + "NNPDF31_nnlo_pch_pdfas" = "09mw3gr7dz0vwdnralaplvlz2c464lmdizf673xsb0wlm12pqf6g"; + "NNPDF31_nnlo_pdfas" = "0l92q3xhdk5nrnhkmrirxnvplj531rdpnblnacd759cl4hgxcs2q"; + "NNPDF40_lo_as_01180" = "0m630n5i7s0qnlxzk6ka43qfp6ipz2jgzr7ys42hdb66kg3z5lkc"; + "NNPDF40_lo_pch_as_01180" = "0wrvmcgdaipi7vy7j85yszaa3c57hs3xll9lfn9cdbjscvmsx6x5"; + "NNPDF40_nlo_as_01170" = "14j21qryc25k1jk4ypdcr3cgfkhyy4hsb57hy8x5pggfwc2w3f36"; + "NNPDF40_nlo_as_01180" = "0399bnxvgl2h2ini198jmzjjb179f6dpxfv5x8imlfl515llivx2"; + "NNPDF40_nlo_as_01180_nf_4" = "01kwziiyg8vbl26znv7khqdckm501d7ccxlkq1y0cd9s1f5ff8xi"; + "NNPDF40_nlo_as_01180_nf_6" = "1gv8anb3vqpzdymp9g69702x64pbh6l2rn9257hdpz4i4m98rsjy"; + "NNPDF40_nlo_as_01190" = "0wf8p2i4mxs3hkqvxg1clj082yinbdgccr6qx5kbwkzsck4yybar"; + "NNPDF40_nlo_nf_4_pdfas" = "1ia9glingyds6bj6yxy867ahriqdhfkxczzc4nki933h6jbj74bf"; + "NNPDF40_nlo_pch_as_01180" = "0gad0hjq9kwiymc9pljj4z52jsg794m3knb38zj9icgjk0p9lwxm"; + "NNPDF40_nlo_pch_as_01180_nf_3" = "15j3vvc0vaf13d8cnyr4h7gwb7iznrcajnw59ryx6ksz7cn84sy4"; + "NNPDF40_nnlo_as_01160" = "0y9115xlg14m1ahfffiam4zp0axga86bhzfxf0xiaxb36yzbmdhw"; + "NNPDF40_nnlo_as_01170" = "1h6if1zw9dqlfnn7glbl5flj792i7fqiy7pprhwk93k4snh3800i"; + "NNPDF40_nnlo_as_01175" = "1dkzzhmkmzm92gmb83lyirj3clicrg70h5grzh0j8nfcw0xlz4rm"; + "NNPDF40_nnlo_as_01180" = "1bhysjkji0k7xy9njarkfvxff05kjl1byhkknxv0875p2znzkpva"; + "NNPDF40_nnlo_as_01180_1000" = "04yai94qwd7187wg26icwf2wbwi20747l6zikd66ygsz9n34xn9y"; + "NNPDF40_nnlo_as_01180_hessian" = "0cmpqgaz341hif0gdkzq8mnfh9apxn1zxjwa12fk5svbig9i1a81"; + "NNPDF40_nnlo_as_01180_nf_4" = "1aj5y3fyvna2jwxbsrgr2cbc452aprxnwv78vh3ph20jlnww20pd"; + "NNPDF40_nnlo_as_01180_nf_6" = "0bf6s6s0w7l592bm87mazwff05d8s4qlblzl9yj91am3xlv0cvn1"; + "NNPDF40_nnlo_as_01185" = "0y1xn9qcv2l81sbz9rayzrpd1bjsdyixr42lzfgmqbq45sw2m04n"; + "NNPDF40_nnlo_as_01190" = "1ibz4yfrw1n8plq4gi03yxi9afaca2yprxfk2y9lvbkycn608d0q"; + "NNPDF40_nnlo_as_01200" = "1cfcn819aali7ylv9y6yb2ggqy0yghyj0dys9lf9gv5wiqjwh5q2"; + "NNPDF40_nnlo_hessian_pdfas" = "1b5jvhdk7fmnz8gl38i3408h2qrqcsr7s9v7bh6ilc7x52xsg65k"; + "NNPDF40_nnlo_nf_4_pdfas" = "1ssp315xcqpc4md5gijbi2c02r6hpazp8yw1661r4m7xy5qm62wc"; + "NNPDF40_nnlo_pch_as_01180" = "173l2178plrir9fb3bq17l4dw5qfy9clic4m54wqg7y3r71bmv7p"; + "NNPDF40_nnlo_pch_as_01180_nf_3" = "1mh0pl1f1ayx1fjj0q1fw9s7wc7gmj7a46jli87s4g5nxrhyki9f"; + "NNPDF40_nnlo_pdfas" = "16d81h0pzxzgwwrfjghmradx4bijf08xbrdn79y9bxf6czacm8n6"; + "NNPDFpol10_100" = "0r5qfa8cyanalphgjdsh57s3viqv9i10v51p1pyamj1f90gb9pr8"; + "NNPDFpol11_100" = "0nny1lpw37jcillpfxjx82hq7wlzp4yksxialmc2ivr192qqdda8"; + "PDF4LHC15_nlo_100" = "0m9d4zy7608iryqy1ypgkr1d3yhw2wv1nrrc70zrfih7x0fp7lz7"; + "PDF4LHC15_nlo_100_pdfas" = "05wyqyh9y32sxflq69igcnnsl0ifnkyw3vnnnjn6kscl8h8hs7lp"; + "PDF4LHC15_nlo_30" = "05n0i1mr7v7ssvxvdmv9fn621rinl08frz71apjj7wfdm7s7bk72"; + "PDF4LHC15_nlo_30_pdfas" = "0xi4xydx0x4ina0wmqv9jf4978xhd8x0l91dwfxh5vy39r5x4lm4"; + "PDF4LHC15_nlo_asvar" = "14hdgj5g8ia7y6hi40zbh925dacrk7hd6cli6lkhlqzxl755nbs3"; + "PDF4LHC15_nlo_mc" = "09p7y0z04r6wdkf8gi3yj85qk5hmp0mmhab8c7a7lly4731fyf42"; + "PDF4LHC15_nlo_mc_pdfas" = "0sds9rkvbjkk7pardwq959qqbrvgwswxmsqcfppky2p0qmdsjs0s"; + "PDF4LHC15_nlo_nf4_30" = "1ysy6dqlacg4bwb2f16p1aza5gwm9qnhmc0g0mhsdw4d2i4ml5yg"; + "PDF4LHC15_nnlo_100" = "1gcq3qrf39dhq2pmpjrj3z0i0ycrk76mjdwmgfvzdxysp530ax54"; + "PDF4LHC15_nnlo_100_pdfas" = "16r8far43ymsd64a4bbqlj56qvbjmcyxbawv4lkfxysjvbydxj4w"; + "PDF4LHC15_nnlo_30" = "10cm4wa0mk34rnvsr5q8g9w7fs9cblsryms2nl370wdvcrhzsxph"; + "PDF4LHC15_nnlo_30_pdfas" = "13xln0y8l0qcj9951glj4f1kqfaagj8gwkxzlvdkgjnj1scdy6yj"; + "PDF4LHC15_nnlo_asvar" = "03fh1jcbmvla7n2jj3zq4ibwvq66h0rniply7h93d94zawcgsy4v"; + "PDF4LHC15_nnlo_mc" = "0c6nfkv3x1p5iw514knjvqcs1dcaryf74qqg1za8x234yr5ndi3p"; + "PDF4LHC15_nnlo_mc_pdfas" = "0l8hlcz69cdii7mpgargi9nsx7iy746nad5pnn7pvycrc40marij"; + "PDF4LHC21_40" = "037bs1l7zr3z8zi6wzh5kxgml84bl64258fr2sm0dzv9yxh8lvp5"; + "PDF4LHC21_40_nf4" = "0m2ki4qmgl1ggim2inlgynjzqr4ya3qgjph63jf72kia8ks2hfl0"; + "PDF4LHC21_40_pdfas" = "0pigpix2x2bv1a5ib17zjlfjqygjpjra0pgvmf6knm7mbgwxhqm3"; + "PDF4LHC21_40_pdfas_nf4" = "0dayiilh94cszqiphr487589qacawfp4za2cngr3da03yg1aswbd"; + "PDF4LHC21_mc" = "17fbwk7fp2m3fd0xzp94sp7m0mmjmzakg870rbhg8vi88bimmwry"; + "PDF4LHC21_mc_nf4" = "1n7h45yxw2mwppf6zblc8v415khy9vgrackmbfkm5lb9c79faas6"; + "PDF4LHC21_mc_pdfas" = "1pn9a7z0xl1bn18z461j90sjglccswimm4p23nyq0fxal5ziidbl"; + "PDF4LHC21_mc_pdfas_nf4" = "1andl5n1lw5iyd337czph5abd0sqc3l90b21g67af96am5pprcpk"; + "TUJU19_nlo_119_50" = "1q1dhsxz1kq75rpzv6gg6p6bzvvv0d44pc4y3wsiy9g14aff85vq"; + "TUJU19_nlo_12_6" = "006j6y4xbjss9apzagjcc3r1z6s61a1hzafhcyriiffqhn8bg50k"; + "TUJU19_nlo_131_54" = "0ymf35alyar6fwagmdny2zz2aag576f38kail7gh2lvqpmjmv6np"; + "TUJU19_nlo_197_79" = "0rq57sjcwljz8fz2m5bz0hm1670jp080zawmavmagmzvmyxbpnpj"; + "TUJU19_nlo_1_1" = "0fp4syfjgl0y58hrr3g515j96yp7ncbrnzj1h7i5h3fphxzayhcz"; + "TUJU19_nlo_208_82" = "16g5fjpa1r6pml6jnmzikwafdc0vgj8j3b0ivjz0bsqxms66msg9"; + "TUJU19_nlo_27_13" = "1ffipy7g22mjbhy7wpjipfka84k4iw52bni4gw2a6aan5qljlcii"; + "TUJU19_nlo_2_1" = "1l17drwy3vv8s7g9fdivxs2z6m88h7fpamnr5y0y6nbkh6bja2s6"; + "TUJU19_nlo_3_2" = "1qm010yjnj9amj2j89v6s5s42q18q8b6md35c9mbv88ibqbsdnvn"; + "TUJU19_nlo_40_20" = "0xylrincss1ijkfxnk7hl72c1rzpzm14hcarddh9pd57z7i1gv4c"; + "TUJU19_nlo_4_2" = "0adqxh47pnhgmq9r89wcqaldfrqll5gpjzqncqd5ba8301i3d98m"; + "TUJU19_nlo_56_26" = "04q8c3gkbxib5fz20f7rwn33sqapcmsj6fwwihi6ca8n1rl6hw6h"; + "TUJU19_nlo_64_29" = "1yyl70v8s16s2v630wamyfk8lwdw53cbp5hipgwdw1sfs33pj1mj"; + "TUJU19_nlo_7_3" = "17qfnf8bv6c5q6xkl68c6n1gxp81gang5w71gvn9m5d6pn2wiicj"; + "TUJU19_nnlo_119_50" = "186fja2z84csh6zsp0lpy5mch5swmwaf7mvq8kf073jxlrkrws42"; + "TUJU19_nnlo_12_6" = "0k5q6a8jidhmnjgll1l71dxx85lzd7w4v9bsmi42qladkd71vblv"; + "TUJU19_nnlo_131_54" = "0inwqb1v390xkjzhc7gy4hng07jzbbhpq99f4zpkzx115xs57l74"; + "TUJU19_nnlo_197_79" = "09c9b1kqzw28rqgxfxq2mvwna8yb6f2y90332f05jpvfk3mmr7n2"; + "TUJU19_nnlo_1_1" = "0qmvcbsyi333b9dd42xjdq62a7dfa3hvfcbk48fg4m179mzhp588"; + "TUJU19_nnlo_208_82" = "1xpwnl342g8ahhp3lm7p2xhzlx5qzhjvz6g1w1nqrd818w3994zn"; + "TUJU19_nnlo_27_13" = "18fsbp1nh4zx2wgg9r7ian0mvhvf4y8ssqv33vqvn0vwk7gqw7jf"; + "TUJU19_nnlo_2_1" = "1p0b74w1a9906lqbxbc8dkk5bcdhnbqc82lnhsr4qfi8sxih2l9i"; + "TUJU19_nnlo_3_2" = "132w4cv8r7958sad6jakfppsywifwzzacsfyn81qvv76xzc2hm3w"; + "TUJU19_nnlo_40_20" = "0fkbwxh0smj1icjfn58fsfh52ny35pmqjs7cs3qnw6dk5p95qx6k"; + "TUJU19_nnlo_4_2" = "12vm0dl8ylz38zzi6rsyy24h3yg30nq6l464nl5fr6jdkvkbz2f0"; + "TUJU19_nnlo_56_26" = "1kqc6v6qq6wl3nls31gn5nrzwfl9kshm2bbak771c3xvjsgvjpdy"; + "TUJU19_nnlo_64_29" = "166k8swsysr7x5rgivi6k04q4p8njb2ny7xj7xjqhkgxrznc8jzq"; + "TUJU19_nnlo_7_3" = "0q9vswr0s3k15abghx3cccf1ays0601n1438pwqgd5xz8981ngm5"; + "abkm09_3_nlo" = "0h268l7j1zkxm2nacari10f86lpha511xhgrg0q9r8hc47sw2vxs"; + "abkm09_3_nnlo" = "1gzhvblckskscql53pfxp79qclhhhhm45sqjhc9jrm1bp3x52w8i"; + "abkm09_4_nlo" = "0yq3gy0qgnk5dh0hh3ldrf5bqzx5wpkhw509nvz5arlh0bfwhyg4"; + "abkm09_4_nnlo" = "1b8470v2n5v87mmhp2dhmfh7iv3280ad67z2vyl0sfv87iic409j"; + "abkm09_5_nlo" = "1nhck955mw94h3pyhm2vd3q60qxwsmclkfqdscp06fc3avyvrzfv"; + "abkm09_5_nnlo" = "0wklkcjknn7ys1akg56zxdrkd7ardlc5qnbjq51mva1nf2bxk0np"; + "abm11_3n_nlo" = "06r54q3ph851a0hyn4di1ifwjmdkdklf3wlsdpz7qn0w4w3xcg29"; + "abm11_3n_nnlo" = "03rgkj2hyn3zmj8yxllfnc2iqr12j8shjcpdjka33v270lim3gq2"; + "abm11_4n_nlo" = "02r9ba7rz8f5438rfckzny5amnq9qjgl164x8il6xqh5crxn4vb3"; + "abm11_4n_nnlo" = "0z6a9wxy6018qm9nyyip9wdq46j7rh2if5xch19h4qx20gx6m48a"; + "abm11_5n_as_nlo" = "0x2w81w9cz955k9dd45872k98my57w83cjdsv4gvjb64d1hsygzq"; + "abm11_5n_as_nnlo" = "0091vwjkc686d1dnfn2dpa7jb56p8gli2z687fpx5f8yhjzpbh80"; + "abm11_5n_nlo" = "1bpf37mg5wgcf1id2am98l5mj162xrnb8k16ppfx3qxlakp0iabl"; + "abm11_5n_nnlo" = "1mpk322mqs078pk2nxxk8fa29ka6cxzsf65ffiny38678djmfqd2"; + "abm12lhc_3_nnlo" = "09k90vhjq7p0i0aaq2697pq2dc86bkmnv4q8zyqxjp3wnqx1v95f"; + "abm12lhc_4_nnlo" = "1hciv1z9b5fiz7swv21gr0rshijj9yj2n8x4l54v9g0jyd061jaz"; + "abm12lhc_5_nnlo" = "00xxkrhbfkxhg33mkpwwk5nsdp4nmi0zmllx5z5ygxl24rinsq9j"; + "cteq61" = "14hbc855b3wsjk7ypg86md46cjm1bj7n4hins9nr8kgzs69i6vss"; + "cteq66" = "09i69ac3gkrai5jmazjyjvi5sl8k2vm48m90ijn6pl24p31qf68y"; + "cteq6l1" = "1b5m7g7wawk72h76l9yr3gx3n67jggna1004lwffvj43gffwkjap"; + "nCTEQ15FullNuc_108_54" = "107klcpsr9d4dwavcqqs3849k90mdb3bdjam3pd79cmsy7ncr2hf"; + "nCTEQ15FullNuc_119_59" = "14az155s3xfl8nscwpajzwj0dy94dadc4qdc64njlg3xlnxsgxy7"; + "nCTEQ15FullNuc_12_6" = "14z11wyzclx5k6dl46zr0jp6mja178bvd547cqqfy811nbzmmri3"; + "nCTEQ15FullNuc_131_54" = "1984nphc6sqizaq1c1laphw3hdvkp5k7sy7g563wq18578fifbmk"; + "nCTEQ15FullNuc_14_7" = "11i2xcd6ncp2aqw3y8pgcp63zkaj383ciwvqpzmjnqraiqqqa77i"; + "nCTEQ15FullNuc_184_74" = "1m311m5bkzq00qf117dli9xrmcmx8qqh716wff1yj8ri4c4h9m8x"; + "nCTEQ15FullNuc_197_79" = "0vi29fdxaj7fnpc01k3y2ylb7ngpdnmbnzgxdnr6p9bj5wfa69z5"; + "nCTEQ15FullNuc_197_98" = "0qjkdfgpbcmwc39wzyfb07wrqnkkwn7v8235y1m25x4wy5bbpjbg"; + "nCTEQ15FullNuc_1_1" = "0nx1n814mkikd01pxmpndk2qxpwqwd55cbn6z1kgxm8qlhhhd2zw"; + "nCTEQ15FullNuc_207_103" = "09py38s7shcyy07p5mxfiil5wlxijzbv9k4l3x0g1v191k0vi3m6"; + "nCTEQ15FullNuc_208_82" = "1c9r5wr43291rw965axdzpshzjhnynsrlf28kfr17v7vpd9dykl4"; + "nCTEQ15FullNuc_20_10" = "19vhxi7ch9vxa1vyjpxknk69hnnm2n5wpz4qybg1cznk59dvpi28"; + "nCTEQ15FullNuc_27_13" = "09pflgyxl2ydzrmys7rv0mmvl32z3dmdx63wpilrw592aa70bc2i"; + "nCTEQ15FullNuc_3_2" = "1l2js36nh4jawwkpiq386blgwbmgi9ccvvzbwq92jb5kpd2fvh7z"; + "nCTEQ15FullNuc_40_18" = "11pw23fbrz97i9278cxrvc0a4wbdyhz788axq8jn7yka9mg9kch6"; + "nCTEQ15FullNuc_40_20" = "0raiqn6w90n17irf4l197my77999ygqwhim9lnjqgbn68yjqfqf3"; + "nCTEQ15FullNuc_4_2" = "0fip3n3pjd94rz3f4gcv2szrx5k72m5b8xcmsgjfd1671r5kmlkd"; + "nCTEQ15FullNuc_56_26" = "13msj49c1lfisgcigvc4wr32w597jwir8cggrcdq74b0d0ab85ch"; + "nCTEQ15FullNuc_64_32" = "1spgcb340nz8by8051hngnh6pa1wjf19vi5a40xr8gyprdzhwb4a"; + "nCTEQ15FullNuc_6_3" = "0v5yabjw3xkjq5c1zjqmj3wwb7yz1blkprxnrpvai54v17w3sk3r"; + "nCTEQ15FullNuc_7_3" = "1ncarbncfkqk6l3rx3zg34a3sj7mpm2diqsafyldpn92cw66bcs2"; + "nCTEQ15FullNuc_84_42" = "1z719mcx5lnx2ciwlnxxhgc4s00jrr9sfrxcimh69sj14hmzgx0d"; + "nCTEQ15FullNuc_9_4" = "180ipb4m2zy54h7n4s0jwqk9k6562bygvnv7mg9dp2f7vf5317a1"; + "nCTEQ15HIX_108_47" = "0iqv6rsvvr5mqiaddn2cs6psrslw6ncqxca993v0z0hng9ahnnwd"; + "nCTEQ15HIX_119_50" = "0gxdr596gk69sb76r90p5ksvx9bk4axj21qrsyxjf1bmgdg2rv72"; + "nCTEQ15HIX_12_6" = "0vkkz3hq0irvfb08cpdijfvv17bcvzaba5c1bf8kwx1i2zl5s6xz"; + "nCTEQ15HIX_131_54" = "0pbm6390cdglxqzrpl2slv65m943m32i10c49pf70fg68x3l2dff"; + "nCTEQ15HIX_14_7" = "1yshwpa3zzzmf7s5v3c3130ysm1wciicz202hrraz4px102h8a06"; + "nCTEQ15HIX_184_74" = "1wy1691pc776kv456cbjl5x5rg2z7cycyfny24caq1qvjifvbr94"; + "nCTEQ15HIX_197_79" = "0ckbp8cw49ch78q4nsm1fccn6nizpipdp8q85nnipql53xsnr4zm"; + "nCTEQ15HIX_1_1" = "13sfws9cmrsnp26mx4m2n03gary2m10l67bd8xic8pykgpr8c695"; + "nCTEQ15HIX_208_82" = "0fqvzpqszkyqb4f2y44hrdj7rvadbqj6y8fzkl9xzk432lalm8w5"; + "nCTEQ15HIX_27_13" = "0z356q82x6cm52f3qym7vkajlkf2amkz87as0jvfiygvi4gnilcn"; + "nCTEQ15HIX_2_1" = "117dgz8nx1j64xgqlp40zmgpg0z8b0p1j75d1llvshmksba43avb"; + "nCTEQ15HIX_3_2" = "1k1hxpcg39hrh629ml2kwnhir6pq41rpic48njq2lagmrcdpbn52"; + "nCTEQ15HIX_40_20" = "0q1ggww4a5cdf802737kh7igb0br3q50xw205v4b5p7v237wsiym"; + "nCTEQ15HIX_4_2" = "0n9zf4yxvp3b3ryxbkdw0yilsb21nrjh40ms883d6j42slzhf37f"; + "nCTEQ15HIX_56_26" = "1z39vjgp6jryvqaxv6jq05jj0lfxsj212g17amch65pgxm4l7cwg"; + "nCTEQ15HIX_64_29" = "1iy1g1226irrjxz9wwabwd6x0712dm1aap7ka6fy9wwwbn87f6d8"; + "nCTEQ15HIX_6_3" = "0ljq0h0cdwbfvlpd40v2nypklimw4hh6k999mnyxqfvq47m13ffl"; + "nCTEQ15HIX_7_3" = "1y9k2snzymzgs26ayfn2c8n6isqzqq14pzf05xvlxmc3k1fbsfyx"; + "nCTEQ15HIX_84_36" = "130g553b22s7plgy51n56az05v1pnfgrg5knpg1knx8xr8a9xhh5"; + "nCTEQ15HIX_9_4" = "05igk9g2i1gm7d7npdwd7y3k7xf39scx1mwiw4m39b52kbq7kszp"; + "nCTEQ15HIX_FullNuc_108_47" = "1h2x2h2n02nwinf8ba3yyqa61384p4g29ib8vnrzwzc7q34940i0"; + "nCTEQ15HIX_FullNuc_119_50" = "0m5z036py2m1863k62pzysjdr92dhyiwmb8lxgky5skd7514rrsd"; + "nCTEQ15HIX_FullNuc_12_6" = "13rsl7lczf5qzjgy8m3dp4f1gyib2ffvf86iwci91sq51sma5kk9"; + "nCTEQ15HIX_FullNuc_131_54" = "1bsi3y6b7sxykwablgghqc89s3vxrvjr9y4bvhwcm21c2i4y6vbp"; + "nCTEQ15HIX_FullNuc_14_7" = "0w93qfiqdnzvrry9ddpbqcy6y16sszxfmvvgdy6r8i8py8dzfkyr"; + "nCTEQ15HIX_FullNuc_184_74" = "1q93f9rvlc4z3hzfhdmmxlyqfschrf99a0xyrc78rq1z2pfgmm9b"; + "nCTEQ15HIX_FullNuc_197_79" = "0kb2lnvh8mq25i5pkfis86ggs0s6hmpmyqqgimhcsamk8xnf2pcv"; + "nCTEQ15HIX_FullNuc_1_1" = "1nk792chip0iamc6dlqgqqlc2qlxlbgvgnhsvbmzkmmzvp2ji961"; + "nCTEQ15HIX_FullNuc_208_82" = "1l038nhnwc0pd7sq4yki3sjrrn66bsvqkvba2j3kf4f852gsyswr"; + "nCTEQ15HIX_FullNuc_27_13" = "1gdb09429xn5n07qqjch9x1cnq4xinf05wla8fsq69qr7bcdq9mp"; + "nCTEQ15HIX_FullNuc_2_1" = "0fnbpwv8qzgchc2r2gcjgw9yh4r94vm1rzbwj1f6ahbwrsl4rfp3"; + "nCTEQ15HIX_FullNuc_3_2" = "1r1s7ljwa169nbgc1439cj0gkaqza6ilx3x4gyq2jg9byz30khzx"; + "nCTEQ15HIX_FullNuc_40_20" = "13p7mnh2h8abih8y24rfapnrsd036pc8xy8qm82j8g4bk0j5jacx"; + "nCTEQ15HIX_FullNuc_4_2" = "0j1w7d11ybmpfci79lz99i94szxf5xn6z4kxvh8hly3qlcgn636j"; + "nCTEQ15HIX_FullNuc_56_26" = "08wds8afv0fzlaxck5i2d3pzvi5nqnc1jmq58fpnc7i0g238wl8k"; + "nCTEQ15HIX_FullNuc_64_29" = "0w4hn5iwqa65lnf6mhihx5qrq4wpcqw04ii3jphy79l58j3i1iam"; + "nCTEQ15HIX_FullNuc_6_3" = "1ki2cfsg0wmvfkzv2j9akiyl4d4b8v3d6f65iryxakjkhqj6vvgx"; + "nCTEQ15HIX_FullNuc_7_3" = "14mx5lh278p3zdc572bhxw9sc6n7ga0ak0ch85h3lx9zwg2a1m5i"; + "nCTEQ15HIX_FullNuc_84_36" = "0hyxyhb2mn64fwmijigw8m3v5zlj52hf2hicvx4gcq0lw063jxj4"; + "nCTEQ15HIX_FullNuc_9_4" = "17pydzll5lgs974gz4bchl2wxc9ixfpnqjrsidzksl4jf03gn77z"; + "nCTEQ15WZSIH_108_54" = "02z08pzvl8fa0bi6ddrlbknj0iryimw02r40z0nn7p8xf99qabhz"; + "nCTEQ15WZSIH_119_59" = "0r03k6j6nd2mvdkidw4gx1xm1s9hil9z5kanxsn2hzp30ab971db"; + "nCTEQ15WZSIH_12_6" = "00d4lis1qas1k8yzfb3dbqgvy9ynv7h9lx67ys3mj1ws5fqyn5al"; + "nCTEQ15WZSIH_131_54" = "10frai6qmzvp8xpkanl1qlpnc6chf6k5j70f4pw4abw8ycbjymij"; + "nCTEQ15WZSIH_14_7" = "02qd5x041p6n8rzv5l446481jb9vkc5nrc018vcg41735azr0d0p"; + "nCTEQ15WZSIH_16_8" = "164ciyxkrxp33r5nrkl86gq0jvdzm90hf602raamn1b5l5yrnadl"; + "nCTEQ15WZSIH_184_74" = "00nrwb8q6sa3zwbdc9mx4jz5ndibml84lfz8gad9vhy20zayyh3q"; + "nCTEQ15WZSIH_197_79" = "03hzr05vhb0l58iv9c2743c688ygagy1bi5a7zqn8nilsmykbvag"; + "nCTEQ15WZSIH_197_98" = "1mdlhp643z0gkjpj2jdi5zdd4qxxjqsy93rkv69cn1x5abawdl8l"; + "nCTEQ15WZSIH_1_1" = "13wskph284niaxqx92yaa4jg749ry6y98ds1ifvwc9970iccdnk2"; + "nCTEQ15WZSIH_207_103" = "0mpc6msqqjbcs756zd426xgzxmmmcmk8cp8wh2mpagib1drrg1x8"; + "nCTEQ15WZSIH_208_82" = "130bs9y9337pmgwi1ix0ar2xvhfhl4rs0626kbin5yrxhdy7rpha"; + "nCTEQ15WZSIH_27_13" = "1r01sbzixlrqxkjp9kx3s4zgsd48myivyc70p7ha83i1qrq50g7w"; + "nCTEQ15WZSIH_2_1" = "1qlh3zxbg13sq187k1fmssan00ifmqr0q2l7i45vc8jz3mk70098"; + "nCTEQ15WZSIH_3_1" = "057zyvlxz3hwlwgydccl2y124bvc6iwqqgav2jqw0r53a39rc25g"; + "nCTEQ15WZSIH_40_20" = "11psi56yk2yd75v396j68hfdacsnxvng2bw4v9g4afbjv9697jgr"; + "nCTEQ15WZSIH_4_2" = "0g4rvlgksw5gf6a7zh7yzsi2sq5jqkwbrx6d7jgz7zpg8jkg4qrz"; + "nCTEQ15WZSIH_56_26" = "12d0bj92b615kzadxwivp1q0j906m2rlcxfflwgwg21sv9axhi4l"; + "nCTEQ15WZSIH_56_28" = "12yx9v87y59qf14005fmj55n38xnhlvc7qgcrgfsicmdbx3ncm5x"; + "nCTEQ15WZSIH_64_32" = "02w3a4sbygc72acxnfc6lhird4nxcgq5dprfldg10h7f9lr7441y"; + "nCTEQ15WZSIH_6_3" = "05x3cknlnc1kbqnmi3hk6fjgx07dhl7b36rg3abaqn4yg65i79sj"; + "nCTEQ15WZSIH_7_3" = "0d6cmpv6csysr96knip033mw7sg56ls1gcq8gvz2qy7isj167gx7"; + "nCTEQ15WZSIH_84_42" = "15zva7n91p6s98kkhcfsvws20s26fl1bvjql8m1n1c2d5pr29wj5"; + "nCTEQ15WZSIH_9_4" = "04cs89s2m99p31jkc2k4f5i5rr0l4fpa6a41d59zvknhgfy74yvw"; + "nCTEQ15WZSIH_FullNuc_108_54" = "1wk8vhhlzj3wrb994s66q5zmwxhcy9vxpyks36s3jr5729jxk1j1"; + "nCTEQ15WZSIH_FullNuc_119_59" = "1rrkj7inah6bg03mmxgza39z40ghdr8km9hy5v5b69bvqcyr42a3"; + "nCTEQ15WZSIH_FullNuc_12_6" = "14wgacbimifnaji6byq1cds9zz266a63bvv616b0n06391plvzff"; + "nCTEQ15WZSIH_FullNuc_131_54" = "0k6gncwq4l5avlnr4qpvakklysi6g855yqksylc42ndlgjm4jxfy"; + "nCTEQ15WZSIH_FullNuc_14_7" = "1mlffwsn3f942flxvvi0rp63xlcrq88ir9vffmkzh3br3qpm4q41"; + "nCTEQ15WZSIH_FullNuc_16_8" = "1ga0kijnlzjz98j32bakcan89bfhbhq8y08d84d90xpgaqkpb9z2"; + "nCTEQ15WZSIH_FullNuc_184_74" = "1nhly8065kabzjjkapr75vafx46f1zl21xc6fdcv15a2qwx54n0p"; + "nCTEQ15WZSIH_FullNuc_197_79" = "0l9c684f427b8hhwm68swh78n6104nbpdxq6v50zipwc6df0j6w9"; + "nCTEQ15WZSIH_FullNuc_197_98" = "0vc285bd21arpmaykb6baspzr8ak42yx9h4j0sx2vj07l648g5hi"; + "nCTEQ15WZSIH_FullNuc_1_1" = "13gbjq46f5cdpdr902nxv261hqw041f7ryxbwgvxr3k2zm7h8fw0"; + "nCTEQ15WZSIH_FullNuc_207_103" = "08m08pcz0f72nd7zcrvi8cl5va49djlvdff1w4is4gmsb44khyv2"; + "nCTEQ15WZSIH_FullNuc_208_82" = "04x5icmidi1p3j8bdarl3sj0ak6g2ygyc5wmkkn9g80qqn4mxwva"; + "nCTEQ15WZSIH_FullNuc_27_13" = "0x4iv1kxb5lp514qm1nr3k32m68aw7sgy12nhdjhy2dv018snd8n"; + "nCTEQ15WZSIH_FullNuc_2_1" = "177qv17wv15sr1zcm2p6av20h32cjkspf4jj3jvvvgvks947n7dl"; + "nCTEQ15WZSIH_FullNuc_3_1" = "0aawk1ppg3nhl5n6gpdi6l1rw53l2x2sv3fwjz5821b6d7cmb9f6"; + "nCTEQ15WZSIH_FullNuc_40_20" = "1271dlp580a5gm29sv6b8plpc8d06j57x2xrfjyp7kafxa1158ii"; + "nCTEQ15WZSIH_FullNuc_4_2" = "0sv20zpzbinrz5biia1g3jzgyq0wbqaqrmrhhcyg2yxg9z48vgca"; + "nCTEQ15WZSIH_FullNuc_56_26" = "1wz1vwy2q85qz85kdy9gzzhnvv0jy4iazzavf9janz2xzw7833gg"; + "nCTEQ15WZSIH_FullNuc_56_28" = "01y0f2bz5yxmfd719fq8s1i3q5wb0dd81l0qkllpa961db83zmz2"; + "nCTEQ15WZSIH_FullNuc_64_32" = "1a93nqx26pj9kyvy66dmm4ib2pl5qwf03420q84zdl1hlcgaszzc"; + "nCTEQ15WZSIH_FullNuc_6_3" = "157j927a4x53gcam5kmpcpkyk76qgdlszxa4bcj9wlqrygwxsk3k"; + "nCTEQ15WZSIH_FullNuc_7_3" = "0l369wpd3gcb6i452w2hsjvidz80xl623xf1g1p8d2485nrvh6jm"; + "nCTEQ15WZSIH_FullNuc_84_42" = "1nikb7yk35s27g43k1wlgcfxqfyjf40csn8a6aiabliqdfjacaqv"; + "nCTEQ15WZSIH_FullNuc_9_4" = "0nnxf32kllwvm3fyjlswnyjx8cpsanx15qwsn03z6d67wx2f87sw"; + "nCTEQ15WZ_108_47" = "0v1s95f0wxyz73pfv5z6hc4mslxb7ml6imjmkhn2p9yx5mvk94qf"; + "nCTEQ15WZ_108_54" = "0zqw1p1sls58v7aacmwamlic0vsjyjijfam6bas5lh92rrmcf9h6"; + "nCTEQ15WZ_119_50" = "1wwx1rsjhd8rqrvyq68r70issnsby8zrlr8d76br3622mxqr83a7"; + "nCTEQ15WZ_119_59" = "11hckxdqyfrbsv3lc12q8zjysr2nw9mhx438ff13azp93ha7h1v6"; + "nCTEQ15WZ_12_6" = "0naqqy223p6gyw2r1qy5fs185dhmxzmb3zmkx3bbccqnspk7qcnz"; + "nCTEQ15WZ_131_54" = "0fi4sjv7rs90yac1zmnlf38dv5ry9zwzxrjwakpzh00irxw0cz8r"; + "nCTEQ15WZ_14_7" = "1k4sc588n3rd8fvcvwhxzc405iqj28xzv7y1md45kz1c7m6qy4cj"; + "nCTEQ15WZ_16_8" = "0ndjlgbggbk3zk5bm9nm726ci1v8b3qfy3gag14jmp7q780zyhmy"; + "nCTEQ15WZ_184_74" = "08cdkqbjihls2sg4waj9rxg7nvs0mjzxfv3dx1jppiw6f7ljjzrr"; + "nCTEQ15WZ_197_79" = "0ss7wgvx8rv03x1g10c516i0yd65njc7qjh19maij49aizf1fd4l"; + "nCTEQ15WZ_197_98" = "0vlyjqlj9plniim0z7mdhia307i296iha94l8b3iqgzyp9553gly"; + "nCTEQ15WZ_1_0" = "13wnm5sz1sf3hng70j8d3ml53knrx9b7wrg2h6x947jl51flrkh4"; + "nCTEQ15WZ_1_1" = "0pllq4zdgjaklad9j87vilx8gapzfhjh478gcw479ahgjcbbbxxp"; + "nCTEQ15WZ_207_103" = "088d8sr9mq9q4bi0ipxznbm3k2b2k347bj9k5fxsb27f4dl5d0jp"; + "nCTEQ15WZ_207_82" = "0cxagqav2q6kwq83syiad67nmzzkmrg9q0hlshbz6bjlcqmdi4jr"; + "nCTEQ15WZ_208_82" = "1c7vacsr2m6r7dy1b439c46xgxjqvq1gj9y68p2vargm5az444sz"; + "nCTEQ15WZ_20_10" = "1y38sqjgsjrfhmyhf688jir2hgkk871sjz8dm89lm5g7m5c1mgmq"; + "nCTEQ15WZ_27_13" = "0gb2zg5j3jcqjisa3nzsbif4rfi8vshl5vq2vq93d2132qgpzq3l"; + "nCTEQ15WZ_2_1" = "04nhmrvy2m4a2i8b5qadsg8h51k171df1kb7mdqn3hjzga7lg0j7"; + "nCTEQ15WZ_3_1" = "00aansn8jjh8yqyhr2fx8h453nahrdf8j1j0qgny1n1mhad4mc56"; + "nCTEQ15WZ_3_2" = "1pk6gp5a1g15zn5w00l89liz4w7w4xsmpcdk4x50vc7k5phy6vj7"; + "nCTEQ15WZ_40_18" = "0m58lby911lxqy6rvvs959qg5gjbppnfxl34hn81glc0lr90qiz6"; + "nCTEQ15WZ_40_20" = "0dnk9yikivxd557bpi9j7dbpwkf4sk49bg8lf0lxf86bdmi2l330"; + "nCTEQ15WZ_4_2" = "00rr4qwwp7i419sy5wr6f2lz82121ilrvvj0js45bvcqknx26c7i"; + "nCTEQ15WZ_56_26" = "09qjjavqjwrh9adkz6yhcjjiy55dg6c7imnbsi8qxi8xspz8nqq3"; + "nCTEQ15WZ_56_28" = "0pdqsrj4dphjb50r3v95wp1drc8rkdgsbisgg430dj9xaa703ijr"; + "nCTEQ15WZ_64_29" = "1qjvvfzv5nfjp1k1kdv2kz5pjssr2avrnjlxznqvlxwgs7rv8p7v"; + "nCTEQ15WZ_64_32" = "172whqdyyvqxyr3lijw2v45y8nvc0vk7z47i9xfmcydi2qfz8g3s"; + "nCTEQ15WZ_6_3" = "0kr0cf8aqwsn4x8kjwihsynvb99i8bdp4g91digbgcfpp02jyvgd"; + "nCTEQ15WZ_7_3" = "1c76h9xfflfihqyxi9a6dlmg1gwwr2wh93mfac3a3jnx73981gq3"; + "nCTEQ15WZ_84_36" = "1cvykpl9r41dwahjv3kik98y6sx53wiyyzywqc87mhnlx1x5876f"; + "nCTEQ15WZ_84_42" = "1jslkk9wc0fzbm6s5czpmaf004pndwc2ggwnxgkga2idn45204xz"; + "nCTEQ15WZ_9_4" = "0farphic6jyzc5x3ja715wdmvv5rfcgil1c49i8fxqlap5mlgv89"; + "nCTEQ15WZ_9_4_iso" = "01zxmn50r14n1a5gq75pia8mz4ibyqhyjl5d31kv3h69xgdrlizc"; + "nCTEQ15WZ_FullNuc_108_47" = "0yl5ll4j3mr6nhiz9ynn9w3hybgwdypg0b8zwsxz1rjcr3c8bmz5"; + "nCTEQ15WZ_FullNuc_108_54" = "1c8cdilw9n91apqj9lrv9j6hf6mcg3ndndchc96d5svrqlqk4fg6"; + "nCTEQ15WZ_FullNuc_119_50" = "19lb71cmmi4fvpb0bxmz0ipjlzg6b5hrlwiml4bj5r65km46whyk"; + "nCTEQ15WZ_FullNuc_119_59" = "0r9cwy2znpl59ynv2av6whjl3igm4b19rzh6sjqsm6a85d5jjdpc"; + "nCTEQ15WZ_FullNuc_12_6" = "1972j8lziq1ckwq2s7qpcf9g7mg3762kfrnbdjf4ilfw5b2b9i9n"; + "nCTEQ15WZ_FullNuc_131_54" = "06w9yl6a11ir8qjyxaakyzs8b51hf3jhm8nj5nvrh4f6cicp1g66"; + "nCTEQ15WZ_FullNuc_14_7" = "095x9pphc9lx71hlhpwcb71p8wx3b1pnv6qd3s6992visismyb02"; + "nCTEQ15WZ_FullNuc_16_8" = "005h4mbf9c7d9w61pmgghpxb5yh63i6cbyxyylngznbbbaxggjcc"; + "nCTEQ15WZ_FullNuc_184_74" = "0niyiq85bmbr596gfrsmf79rksql7n2gqdxw72yrki5ywc3iy4sr"; + "nCTEQ15WZ_FullNuc_197_79" = "0vbgg6m0b1wlrsx2c5xxga0crz0nwvcq9a88f032yjzihh6rscjd"; + "nCTEQ15WZ_FullNuc_197_98" = "0sf4q5bb4b44zkbxq51pf0xhpldr5dj5d0gqpqs40qkdlmkb9z7k"; + "nCTEQ15WZ_FullNuc_1_0" = "1il9j3ggn9kc8k8jpql46lw5c9lq45ngaip45vqppgvl3zcrc4fv"; + "nCTEQ15WZ_FullNuc_1_1" = "0nxvm11qlapnpdkkymqhy86axcvcx84r9hk0dswa2ji5gmk18jww"; + "nCTEQ15WZ_FullNuc_207_103" = "05qqg6ckkhv30nfbs5rdpiwz7dkgywjrd8a9gr3skvlayj2bisni"; + "nCTEQ15WZ_FullNuc_207_82" = "0s27py7i2h0va79q9ivmgrpwk5pxrjx9csyad76fc7pmvi4xsgjl"; + "nCTEQ15WZ_FullNuc_208_82" = "1xygz9px4jwz3vkbx86384775vhiqqv5l2rp2qi42zy8y8ijwaqd"; + "nCTEQ15WZ_FullNuc_20_10" = "06bgr8r6pz8cpvqbncjaazxw7j2qzhh183brs7r5mi6yckg318gz"; + "nCTEQ15WZ_FullNuc_27_13" = "1qrs82jscmxyhqkd4fa2kjglzgig23kqwc7r2n8p23352ggcsn9x"; + "nCTEQ15WZ_FullNuc_2_1" = "0jxam0p1ypd3x8l83d2f14h2av9wk1r69prfhl6pgd6pdh3nx2gh"; + "nCTEQ15WZ_FullNuc_3_1" = "0kjgsiidi33p442bpp1g6sss62qn4pj90ag4hcmdqsdf5m9vpc5s"; + "nCTEQ15WZ_FullNuc_3_2" = "0srxdvk5jh4ga4r8hniikzanfa8fh65xc4g51arxwd9sda4n0mqb"; + "nCTEQ15WZ_FullNuc_40_18" = "1x7d1cpglijq4rag57m8sp6qyzn3c7r3zs5z9jqarsaqc9wv2ypw"; + "nCTEQ15WZ_FullNuc_40_20" = "1l58bvdhqs9i4mgc39dw9c13rsh5vq5vh6zq8xk35150cbysiwza"; + "nCTEQ15WZ_FullNuc_4_2" = "0s1zdn5r9hk7bjk2ggn7bhrzq2iaxspdhmwi9rq1xbsk7n8k3wif"; + "nCTEQ15WZ_FullNuc_56_26" = "15ilca90cvw7p3w1xr15jynqnvnyw8zhpydhyq11x1kc647bgirm"; + "nCTEQ15WZ_FullNuc_56_28" = "16bs4yq4jr4y3431csabgps6330gcw1ymgm2161z4nmmyp988w1g"; + "nCTEQ15WZ_FullNuc_64_29" = "17wqyn8g5zbrm6ywvqn2y5kphy9xwbgijwlzxsni5k821nzmjyxn"; + "nCTEQ15WZ_FullNuc_64_32" = "0ivyka1g2cj6ign8wm28pzim3saas3bvnxqhixxkr91m1gl40b86"; + "nCTEQ15WZ_FullNuc_6_3" = "00v5wydvrvw1fgbzc436cap7amk8yr7dj5wf3ykyd6415vxmlzl3"; + "nCTEQ15WZ_FullNuc_7_3" = "06z2p0gx988q5w4d3c0qx6pj7lp6mqlz1qrnwy5lf4i4i4vcqkkx"; + "nCTEQ15WZ_FullNuc_84_36" = "0rfn82f8f9f6bgngrs67maip2kfhy42i4ppa904d7dspyqkgfa31"; + "nCTEQ15WZ_FullNuc_84_42" = "14lyhhc5jwccqnz85msaqzdx7cn2vxkvm2l9mf1p2kmgy7p5jis3"; + "nCTEQ15WZ_FullNuc_9_4" = "1895lr4yydzk4cry5wnjhpl6gs2kcspjlm2mv2y00sb7gzinjs94"; + "nCTEQ15WZ_FullNuc_9_4_iso" = "0kvjk4wvw98w7y02ishjacn9frncspl6rsxlzcd4y2pdk1ckr29i"; + "nCTEQ15_108_54" = "1bjx2d61qjhabfx28pfi64hf8br4gl67nzir3ygdpwdcah4k6lz8"; + "nCTEQ15_119_59" = "0g7wffsyjh84r2wv8w67skx8gwdb3clv9c1dlpijwqmpkcm3b8q5"; + "nCTEQ15_12_6" = "1xnnqp38zz3b61jb38hz54wv09w06fwwnb66sf93r1agcajvv1vi"; + "nCTEQ15_131_54" = "062sg81yrrdsc376gpq01xzsb6114sp6814ah9jbrd08qqxh04p2"; + "nCTEQ15_14_7" = "164p2fhlsmkcc6fibi28lysbfn8q5vds4f0k0kppi96absgrfa70"; + "nCTEQ15_184_74" = "1zqyvla6dj93cgfjw5z97b6wh6qy8pkrvcbwirjva769210rax75"; + "nCTEQ15_197_79" = "0mp1gddlwxk2vdyhra5lafvblc82g6n2p19lmjwkmnrmjqdqsz12"; + "nCTEQ15_197_98" = "0z2ymk9y0syzqj88mnr2kjn104602ajg17s31d9vi29lggy4cn44"; + "nCTEQ15_1_1" = "14dlybcc038ssv2xbyhing27b9zx07nkqvgf66ysbb83ym5dvibs"; + "nCTEQ15_207_103" = "1zpxky925n9jssdr036dyax8wxa0d478l4mjl50bjmzqhr8wl7hv"; + "nCTEQ15_208_82" = "01jf2mrknx5igs0cvhm7xr25gr6z93bvj12cbq53k15fk5niyglv"; + "nCTEQ15_20_10" = "1vhk2lmpf5kci9173v5qh2gsz7zghvjb11x1mln8yqcdxaq4az8x"; + "nCTEQ15_27_13" = "1md9xv99m6jcdqldhbbypdix581nmhpyanvr049l5c1a2ab5nbpa"; + "nCTEQ15_3_2" = "0nq1aj4hxjih4z4xlhjfbza2dp2fyhwbccjgmgh2za5y7rzgz9fk"; + "nCTEQ15_40_18" = "1gb4kfs207izq4dij9pqbmwm10vx6f1h7pdnf749jysmf6nayndh"; + "nCTEQ15_40_20" = "0b44nkk315a9zaq3280wmsj67rkxw4jyk9v37s859fikr5v7s0sv"; + "nCTEQ15_4_2" = "0c8r4vq3phi40v5h4p3nm7by72pz27zqwd67z9slmf1jy1yilnly"; + "nCTEQ15_56_26" = "0ndyjjh7sxnhkamx182rpax0kcc2iqzwnmh391m5wh629zk0av8i"; + "nCTEQ15_64_32" = "0ixbr2d30v6slqvp6gpry1159rx5m4hd1msymgli1w9k7pp7xjz5"; + "nCTEQ15_6_3" = "14ars149pssaiyhaln9zm7vz3wzj2597cy2xasyhlrfqhlgrq056"; + "nCTEQ15_7_3" = "13b9wbm2hqx4lixq3dad1y3cr6didcch8kg7mqm9lgbism7dwaqw"; + "nCTEQ15_84_42" = "12vkqpvjjyh0x0hbn7r4gx5za01yqs9a7lqirdxd15k04fp5rnjr"; + "nCTEQ15_9_4" = "1rkxhxwp0v9dm6f71c5635ihlspfx0sj666maif4iaw1sf4hazln"; + "nCTEQ15_B_90CL_Au_hess" = "13sdn1ng4nd6935dksk7jin8yilp29zys3d0jvf7m7vx8gyxi187"; + "nCTEQ15_B_90CL_Pb_hess" = "1j11x8y5sbs5lz4z06wcl702ijvh1bcb4i222jdcq9gh9j40xn17"; + "nCTEQ15_B_c_90CL_Au_hess" = "0k0pn3yqb632j254h8w9wbdvcasnfxr7d9g47drqw3f4w1as3s16"; + "nCTEQ15_B_c_90CL_Pb_hess" = "0gvvwnc298qgxhpj4wgnzcrgz0wqlj5r7sfsl1fj21zhm3kc45jl"; + "nCTEQ15_B_d_90CL_Au_hess" = "0lzfa2gsl5cs2i6y833lhvf2pifzkysj9jgq22v9iyyz5q0nbsh4"; + "nCTEQ15_B_d_90CL_Pb_hess" = "0zp7dirc2l42f9zjyq1a2qbnir1bbj1firmg3s856mn7sp3p4i0k"; + "nCTEQ15_B_u_90CL_Au_hess" = "1w2ifnl9waqvsaz1yg696mmqxcijm2bphq8zp3rcbimck3rmr978"; + "nCTEQ15_B_u_90CL_Pb_hess" = "0j95dg6kyvd30qgivd9495glcd152cr1j3zh1cg76s6sdzfkhvs5"; + "nCTEQ15_D_90CL_Au_hess" = "0y3n008i22g9ny0v8z6hyc47730xb6qldkpall6p8icn8yzfdga9"; + "nCTEQ15_D_90CL_Pb_hess" = "0mp1plqxsd6j0ybnf7yrl4hgl68a85q56vdjhs911xah1bgrpix1"; + "nCTEQ15_D_c_90CL_Au_hess" = "1xk6ngc488n9immd9nbv8ygvxav5n7b7902k44rkxnw42kbx2c4m"; + "nCTEQ15_D_c_90CL_Pb_hess" = "1ldig46l08n00jvj0dl36jsnpjl2ycv3jdr9d9g375rwgv671kad"; + "nCTEQ15_D_d_90CL_Au_hess" = "059fz4rfhydnk25hmabavwi346cy2hzxaw2ciq8jx64fmawb3v79"; + "nCTEQ15_D_d_90CL_Pb_hess" = "0zgs89yjypn2sd97948z2r78sydadivvw6wy7pwi3a5b0yx1zpzn"; + "nCTEQ15_D_u_90CL_Au_hess" = "0j8sfih3r2wps1l7vapnllh88ibw7672f646m5p67aw5k2an4f8j"; + "nCTEQ15_D_u_90CL_Pb_hess" = "0d2nxsabard1yq8f2v9a7kwk0fzv549hx1k15k0dfif9523i6xqf"; + "nCTEQ15_Jpsi_90CL_Au_hess" = "0x75jizpqi8vss62xb2913vdhvckq2b468iqxd0ggr0fic1f8q9a"; + "nCTEQ15_Jpsi_90CL_Pb_hess" = "09a9s6gmf7q9rk8c88iskra5kxaiz131s5650964znxv29lpzlqm"; + "nCTEQ15_Jpsi_c_90CL_Au_hess" = "0mh3ikdkca7xc5bc2knjbyr7dkgbydnaa4i1gqln0i29b89j5nw0"; + "nCTEQ15_Jpsi_c_90CL_Pb_hess" = "1gs39gla77sqgry1799l9kapc1c48pzxgfba6p70fdbwdac45n3j"; + "nCTEQ15_Jpsi_d_90CL_Au_hess" = "1qn4f4nn8avjrsdqgab25053zadwx7vlr27w8bsmcxg25si104y9"; + "nCTEQ15_Jpsi_d_90CL_Pb_hess" = "107w4yiv6dl8gqfx0mpbnii06wzf15ih2kqmb8hkmz988x49l65q"; + "nCTEQ15_Jpsi_u_90CL_Au_hess" = "1mdm8qlzkyzrszsng49ns9hq7zdqaal61vbi64449fkvmxd0a7mk"; + "nCTEQ15_Jpsi_u_90CL_Pb_hess" = "1y0bcr3g9znjz2c3s4487yjl1ipf0ls05krfpdn8gcsxymf4cirm"; + "nCTEQ15npFullNuc_108_54" = "1g8id10rpys9566r8h92diqrr43mww6q8nhvlns0kfjkvkr22m9y"; + "nCTEQ15npFullNuc_119_59" = "0df499pvfls1281zkvngrhicnc0ac0bfwamzs027k7f2y6ygkfb4"; + "nCTEQ15npFullNuc_12_6" = "0mb3zixcikagsqzpxb7jzrcg05dln37d7anz5359ssjyd6p1mqyi"; + "nCTEQ15npFullNuc_131_54" = "0i83f1wg81nr742jf9407w7fbknigz6pyx64h7p65x82s4wmj9gf"; + "nCTEQ15npFullNuc_14_7" = "1k2554rg82msxzkarjx85p6di3kmfqxmbfxpasi1x74laz38663n"; + "nCTEQ15npFullNuc_184_74" = "1pnl4y2arxf87b1pp95b9jajzlqdyzs7mv82xhmw9fcn9yliy5s0"; + "nCTEQ15npFullNuc_197_79" = "0d5c6g4185k6pwm5bs5fqlwc97l0gvf6bhk9l8a5vc039dggsgkj"; + "nCTEQ15npFullNuc_197_98" = "0ql9xnwggsqibld13yisvsdkkymzph8wnqffnxhlyp5digwhl64v"; + "nCTEQ15npFullNuc_1_1" = "1fq80hzfy16gs00knvl0g0yqrys27vzyk8h5jzs1ra981zgcw1zp"; + "nCTEQ15npFullNuc_207_103" = "04bg7hnngfsckk92gdrxbrxhsbb1ac1s7dscj7ycdy64fxn4lq8x"; + "nCTEQ15npFullNuc_208_82" = "0f9ddimq9av2jr3yr15n630bi30bxh5nxrsbrcfw9cx8dwnjscwb"; + "nCTEQ15npFullNuc_20_10" = "03dv3z7j69l97xacd38wbp7iyyi36g0bbc2xmxhm3l64rjs21bmz"; + "nCTEQ15npFullNuc_27_13" = "03lb2dznl5dpv0cwsl08dlrh7x26yi9acx3n70imr13gspfxp8ag"; + "nCTEQ15npFullNuc_3_2" = "0rqjxc8q53jndxjrxd293r1m8gin3vif33jzr35y2ail9bhkjyzp"; + "nCTEQ15npFullNuc_40_18" = "1827gpzdrxdkg9ikk7pjgv9h983mwzk21p60635l1zhwby5p4mn6"; + "nCTEQ15npFullNuc_40_20" = "11mjdibgypwpphm1wmf4z311wg4lp37010vwyys8q6d927jzikn2"; + "nCTEQ15npFullNuc_4_2" = "12gx03drv7hnmsgk6sni7mc7c4rbpag5gn2czyha1n19v13rry93"; + "nCTEQ15npFullNuc_56_26" = "1hq6qv19gqzjv57msdajb9kc0lv5jvl3b6x2fc905lg0dc7h2ab5"; + "nCTEQ15npFullNuc_64_32" = "15gq3l91p69dba5gfxvh7j4npwl7rwkakjnsv9lx84hvys7hgba9"; + "nCTEQ15npFullNuc_6_3" = "1gcxs7vcjcdyniczd1rprvzlc1p9yf08sy1fcrny2jfbxkfndqwx"; + "nCTEQ15npFullNuc_7_3" = "09kwf5kbshw4pwh6iilqy1mzgvlg83jhakmvvgz27f569f20ci68"; + "nCTEQ15npFullNuc_84_42" = "0ah349jih2ia0x14mnrygzzw38prfgcmbxyw1hdvzqvgk73wazwa"; + "nCTEQ15npFullNuc_9_4" = "0gsh5jmyn7jlasp9ixx7imvkbp5rxmvfa480vy0bnxwjwz0924ia"; + "nCTEQ15np_108_54" = "16hsl5ihcbx7wvrabrff5h422zfhlfrpskn5dy8s1phhla4r4ff3"; + "nCTEQ15np_119_59" = "1bwhbfhw5xyb1dm18vxm095l1d9l9v0yl072qdbb6z9l29pa71dp"; + "nCTEQ15np_12_6" = "0zv9g7r648f1h1f9qifii0mk2afdvphbfib3hp2sf960zb0d0nsv"; + "nCTEQ15np_131_54" = "19sn6ig1c5smxi845qyflrrqaivm4pphwbxpz2zd9r0qhn032mlm"; + "nCTEQ15np_14_7" = "07pyaik3h2yi05hn49fv3x191i4x6429bb6kywy999bzfrkjndcp"; + "nCTEQ15np_184_74" = "1s2vmirmi1npw3pkxpzxjf9i69gmrl1dqrm2s0cfzl6286h87scb"; + "nCTEQ15np_197_79" = "0p7lnffr4gy8qad8nsm6qfaw05s9pndkw0n9yb6v5i6mqg0j3cgd"; + "nCTEQ15np_197_98" = "0vmjvjqkdn5cixsnvl9lvg07lrq17yw5pf2mdbzkrrfblqki6g0x"; + "nCTEQ15np_1_1" = "1fndfff1lialb2qy08qp44w4605j9c2acrwpdb16k3awj88kx7mf"; + "nCTEQ15np_207_103" = "1fcaw2hqxnzhs9glrh9lxvpfh0sn3mwahgd8d7hnfikrw93v0sbz"; + "nCTEQ15np_208_82" = "0glf5nw1mr42icmbcjliz627nlsb7a5hyp591ng9y7dh41hxr01w"; + "nCTEQ15np_20_10" = "1ka5hnq9cmr4l12ajmw4fpgdzcf0pjlw2pk4lkw6ai1h5h5absa5"; + "nCTEQ15np_27_13" = "02dmzdqqh58h7232s2hcjnpd76rll8vxynq1bx059mvxak5lr5kw"; + "nCTEQ15np_3_2" = "0jxg5f5n4yp4zbdkm9y7xd40m89pbw5687hz7mylpn9n3phsi58y"; + "nCTEQ15np_40_18" = "0yp65xq318qw6xh3wm0n4s4a3s4ahvl14kq3cmwq9b954c5a5vkl"; + "nCTEQ15np_40_20" = "1c367xb361p5mdwyda5iwswg7wb6s6gjibdv27n2kq41p1qp41y0"; + "nCTEQ15np_4_2" = "04q9gq8163lhfjrrp0ysqyb5sx2nkw5mpz70daqnxvybavbkg7mm"; + "nCTEQ15np_56_26" = "1qgh3g6xwk9jc6sd7kjj89w8mr89bhpdaiml5g7lvdqn39l95ng6"; + "nCTEQ15np_64_32" = "02966xmh15i7kg9iif19p5c27rv369yikpm1xqclf8dz45a7xsry"; + "nCTEQ15np_6_3" = "1rr7wr9wwsjfgnrnfvm7nrplhb38zym6qiyg2sagq7saw6kqpprz"; + "nCTEQ15np_7_3" = "0ndqi05g88b769p1chfc6maz6wvs33rx45r4k8f68n79yy6kvrh1"; + "nCTEQ15np_84_42" = "0v968jw1m9ky1mh82w1bjidvg7r7cx23bnpv0vr4c1kqz0n5hb5s"; + "nCTEQ15np_9_4" = "0akxbyrs4y8gmnjiwma8z8ryrzmaw6dj148iq7ihsllwar3hp3p0"; + "nNNPDF10_nlo_as_0118_Ag108" = "1xqhzgvkicxd9wy4lnhqw6brsksxqsq429r6bb0ghn1ll5ln4qzx"; + "nNNPDF10_nlo_as_0118_Al27" = "0z836h7a5abbwq988zdvvf8yhr92krzzmys6lkkgkcffdf2pc0zq"; + "nNNPDF10_nlo_as_0118_Au197" = "1f6vn6n0zz8wml8zn7n2n6wj5y41yanw9b9av51m5kiq4n1r9lrk"; + "nNNPDF10_nlo_as_0118_Be9" = "1jy2cix4gkx648dypdqfj7xi8gdlflh20xlasmwl78av5j7s7rs5"; + "nNNPDF10_nlo_as_0118_C12" = "1c6fvp82cs3464akqf0skrqpcvyp75yqp39zxafzgbqd4wc3pv9f"; + "nNNPDF10_nlo_as_0118_Ca40" = "0r903a01085yhfagnljvjaqfn190r3q0ggvx87kh54xsbv1wkvbl"; + "nNNPDF10_nlo_as_0118_Cu64" = "1vq8a6drcp606fkx8mml2qq37if59cakmcq73y4n7c7swp6q51r3"; + "nNNPDF10_nlo_as_0118_D2" = "07kjzhyh6n6723h2fylgwm7w7ljxz4m6fs9bgwjxp987i00msrra"; + "nNNPDF10_nlo_as_0118_Fe56" = "1smkjmymykhlp0vvlpsp6p6p44pw5aa705sw9lcyxmg8ccy9kmpj"; + "nNNPDF10_nlo_as_0118_He4" = "0mdxsh41m0vzcdq4axvz81m9ra0p6dff88k09gjb4adx9vv52mjc"; + "nNNPDF10_nlo_as_0118_Li6" = "1hrryxhhg9xxg817brrd39k5wz6iq1fv6z8sdabrpxn0nwr1bj7r"; + "nNNPDF10_nlo_as_0118_N1" = "01h7g4w3nc09jyi7g8j5yx2yzqair3ysbx9rx244k1rjx6jppian"; + "nNNPDF10_nlo_as_0118_N14" = "1ny3znivkkl7xhdw8pxkdadwc957236rh60wviiyw4cdqjb6a3iq"; + "nNNPDF10_nlo_as_0118_Pb208" = "066w59xm6lkwrm3glssc6n3qyvv38mx47mkx39p8z9r2spb8igks"; + "nNNPDF10_nlo_as_0118_Sn119" = "1mqx7wj095v0799wxbvfxvb6bl1qh5wdkf14a8gqsj0f5qjnpmyw"; + "nNNPDF10_nlo_as_0118_Xe131" = "0mz9fgxfyx1asi2vxs1xfwn8z51z08naiq1ycl77f4yp6wim6s54"; + "nNNPDF10_nnlo_as_0118_Ag108" = "08vy16fskrvc62y3h0hsikmi6q86njwfm2msmajxbd7vzcv5wkkn"; + "nNNPDF10_nnlo_as_0118_Al27" = "0vm95lawgsncsx10ypy99746sz34y6shblkj9pgn6si2cy8gpcwp"; + "nNNPDF10_nnlo_as_0118_Au197" = "0b3ld033f2hwjaqp5p5pzmmzfid8hl416a1q8fc0zmd2lfiamsac"; + "nNNPDF10_nnlo_as_0118_Be9" = "10skffir8hqfv2wj01ghc14lfs516kmh59q3v48nw3a724kxr93a"; + "nNNPDF10_nnlo_as_0118_C12" = "12rrpcq9bvwcncj1hk28wkym5zzdjkf0d0pdj1nx9asm6vpbjsdv"; + "nNNPDF10_nnlo_as_0118_Ca40" = "0k914fnqsv45f16s6zmdwbnbnhj5lxnrk9pbnnaap4vk7vx7101j"; + "nNNPDF10_nnlo_as_0118_Cu64" = "137n1nsq75g0n4hmbqfl1gihngfrz0rqd2gwj24m5byhbylwlg83"; + "nNNPDF10_nnlo_as_0118_D2" = "0xa17gjjh0mphg1h711vb6p2pjln0lqy7401lamnib2z7p7mss0m"; + "nNNPDF10_nnlo_as_0118_Fe56" = "0h0qwbckdcppqgbhfy3kyy9p4nryh3p45sjmlxhm94mlznipjwrd"; + "nNNPDF10_nnlo_as_0118_He4" = "022h44i8k2ybvm9lkgc4lkcv4z7r0xzlrq2bxyqkfmpp5fpp7gkw"; + "nNNPDF10_nnlo_as_0118_Li6" = "11bci8mnv57a583ayrpvvnz4lsxz43z23iqgqjc3b3rychgiz57a"; + "nNNPDF10_nnlo_as_0118_N1" = "174gscxa2acqpgf2mks5xpim1jcpb0vg76pggxazm376vyyjk883"; + "nNNPDF10_nnlo_as_0118_N14" = "1g2gwnbfzlfa094px1rnjgk8py8qzwq7bi68n7p49bqjj88km3av"; + "nNNPDF10_nnlo_as_0118_Pb208" = "0bdi3z36ckf788v3ld3ngvchyxzsxcfl9fj7rzs2lwkg80rclgd9"; + "nNNPDF10_nnlo_as_0118_Sn119" = "0k7lnr1ils38sqybipmf13n582wb0cf9rr288ibrbmx15rkk5c3w"; + "nNNPDF10_nnlo_as_0118_Xe131" = "17k1afk6j53nl83ixyy6nyds3wy5agacdyn62bwp7ykfs8x97s4n"; + "nNNPDF20_nlo_as_0118_Ag108" = "1fb2h6752vn0v66h12dhhk2izxjs4b10mdqx17djrvpkzl97hf8d"; + "nNNPDF20_nlo_as_0118_Al27" = "1lfkg84hf0chgk0qzp45ch23pzjixkzxxh3x7xphcmnpri4cgl3r"; + "nNNPDF20_nlo_as_0118_Au197" = "08ll61b96iggm1qnr9q2qdzyxasxn9mlshnxz7kzigfsnqqnkfbw"; + "nNNPDF20_nlo_as_0118_Be9" = "1g4vlr9p6i6n87bx6w2i5d4qkhymldkyxj1i2qnl8v467vhsz6la"; + "nNNPDF20_nlo_as_0118_C12" = "15366p04rh31nnd6zxcmcs9ki5fwzn8d8cvzms45apnw928k6pqn"; + "nNNPDF20_nlo_as_0118_Ca40" = "1abxkr4r5psi6n8rrsbf97gwwkh1dg9jqfd46hn2725r22c6k8l4"; + "nNNPDF20_nlo_as_0118_Cu64" = "1nkkiwx22b649pmyfykn2ggdq99y985mnkv3fnkm8i43scwbswvb"; + "nNNPDF20_nlo_as_0118_D2" = "0gvf9qqgr4ixm9cf2654xyvkc624k5ijqwdds61frljlhd49yqm1"; + "nNNPDF20_nlo_as_0118_Fe56" = "1ci132hc8mpsj0zjr9fichnkapagjs6q9pqli0yzgnnv6l2aih3a"; + "nNNPDF20_nlo_as_0118_He4" = "1phq7m6lbx87s4whs2xygigq7fz1qhzj3nd9anx5r67w7q99rcad"; + "nNNPDF20_nlo_as_0118_Li6" = "0pwdqrmivpm0j7hrg6h2qqshpna2vjlslxnz0sd100kc3lfq7xab"; + "nNNPDF20_nlo_as_0118_N1" = "09y7pd3nnys49w25gb4524x5xkahillvaypjgncbn8n5x1a11nsr"; + "nNNPDF20_nlo_as_0118_N14" = "0nb3kcmhbyncp9frs27ww550mjl3f7yiahyyrm3aik93ycpm16n7"; + "nNNPDF20_nlo_as_0118_O16" = "1wmi63l6cpj3nx0vwiqaa1pfw0im5ps96g7842428skzrg0q4yx3"; + "nNNPDF20_nlo_as_0118_Pb208" = "1rwb7vca0y1aj38mz8m3wg07q9hq66qd5j3y6hs9bh0jz6hkifzh"; + "nNNPDF20_nlo_as_0118_Sn119" = "1dan86ckd5padipp4x12x8msfg5p97b8hwxm78gfyf88kq725m6z"; + "nNNPDF20_nlo_as_0118_W184" = "0wzd8vw2svf3mzpyy1wryr5jz3anhykp5z3cx4hdljprws2b8nll"; + "nNNPDF20_nlo_as_0118_Xe131" = "1a62qi3qy5kli9q80p2w80mj5v3ps2g6p40zxlgm65q5mphkx1qi"; + "nNNPDF30_nlo_as_0118_A108_Z54" = "0n67w44rmz5s6cg2h58d8sf51dsfd0i5g09dh08mgfcn640bqlqw"; + "nNNPDF30_nlo_as_0118_A119_Z59" = "1zj5gn5021ig0j6p7jpyy683avg0890blmr90yjm6skqzxfjq48i"; + "nNNPDF30_nlo_as_0118_A12_Z6" = "0jvaq9a1w19dybv2hzvn8swk4i4z16lab9yfhbywq0vixyfn1swd"; + "nNNPDF30_nlo_as_0118_A131_Z54" = "01mcqnixjw5m9di508aq8fp74f3aqnvhc1bjirfvi3ca0jz0c1jz"; + "nNNPDF30_nlo_as_0118_A14_Z7" = "0hqpni9fxbf5qfamcirglr04cbwx58pwylqh8hqm3vc03ap3nmjd"; + "nNNPDF30_nlo_as_0118_A16_Z8" = "0f0h3hckxg4xgfd6ldblavhcidzdy2b5660a5nvv96y63sdsx2x4"; + "nNNPDF30_nlo_as_0118_A184_Z74" = "01jsbla72c3b6gbc7w4nx5bb5ws3g864avznb9vxmmk3prib7n8x"; + "nNNPDF30_nlo_as_0118_A197_Z79" = "1gm7nx0cn3lmjlsy6c7dr5vzyfmi1fcdib9656d4039m0ningrhg"; + "nNNPDF30_nlo_as_0118_A208_Z82" = "0r1spnj4qmjwpjybqv9aa6w3wybvgk4qzivzwz4s9bacz0kb3z4n"; + "nNNPDF30_nlo_as_0118_A27_Z13" = "17vmr3pwjp1prb83yngada7sw8553sv39dnncksabnklfp1l5x59"; + "nNNPDF30_nlo_as_0118_A2_Z1" = "1g97mc7c14hnkfsfvg4n9jmb4l461i9lka643s626hw0gcq053f5"; + "nNNPDF30_nlo_as_0118_A31_Z15" = "0h5rx9113yq6jw1l2alwyvw77vv733y5mcpa3m9773s7y61w3fpk"; + "nNNPDF30_nlo_as_0118_A40_Z20" = "1937kk4039hi9cslw4417174s83rs4n9vm16ay70pp1c8bcqzp6l"; + "nNNPDF30_nlo_as_0118_A4_Z2" = "147npkmbvzk6j95hnnil6jafc2gxjqavaawl9cilr93f9h64w54w"; + "nNNPDF30_nlo_as_0118_A56_Z26" = "06dxsapqirmajh107j24b3w2nhqz39gs9c2pglq71fc53i0fra5a"; + "nNNPDF30_nlo_as_0118_A64_Z29" = "1drvfd3i1drrb15m3vk9sm2lzx2x01da44gdq3wbc90nxvzc7d56"; + "nNNPDF30_nlo_as_0118_A6_Z3" = "0zp1cixj6ixayzdra2i5qyfn2b6y6qfxd5d1l101n8sgf4bdh6fb"; + "nNNPDF30_nlo_as_0118_A9_Z4" = "07i30jk29cgdbdk4n5acdki5aihaki5w0mqibjww1hy7mwh4y45w"; + "nNNPDF30_nlo_as_0118_p" = "0k4bs4zhlm7l14mbd2q9n0n7rdnpqwgnfwj289ql62v3kh8mnn18"; + "xFitterPI_NLO_EIG" = "1v6mfhmcrmdvica0wlc2ilfca1srxc7vjyli113wjvpd7wfpnvj5"; + "xFitterPI_NLO_VAR" = "09mlsww89hhm2s96rlkqbkfwwf9qkblw7n3nnrgas6l1kn2hxq1i"; +} diff --git a/pkgs/development/libraries/physics/pythia/default.nix b/pkgs/development/libraries/physics/pythia/default.nix index d5e54847d9225c..2cf2c89db87e9f 100644 --- a/pkgs/development/libraries/physics/pythia/default.nix +++ b/pkgs/development/libraries/physics/pythia/default.nix @@ -1,26 +1,51 @@ -{ lib, stdenv, fetchurl, boost, fastjet, fixDarwinDylibNames, hepmc, lhapdf, rsync, zlib }: +{ + lib, + stdenv, + fetchurl, + boost, + fastjet, + fixDarwinDylibNames, + hepmc, + lhapdf, + rsync, + zlib, +}: stdenv.mkDerivation rec { pname = "pythia"; version = "8.312"; src = fetchurl { - url = "https://pythia.org/download/pythia83/pythia${builtins.replaceStrings ["."] [""] version}.tgz"; + url = "https://pythia.org/download/pythia83/pythia${ + builtins.replaceStrings [ "." ] [ "" ] version + }.tgz"; sha256 = "sha256-utmOKWe2hwRsRWjJCR1jCgwxtih0XAIamUq6TR1Q+Oo="; }; - nativeBuildInputs = [ rsync ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ fixDarwinDylibNames ]; - buildInputs = [ boost fastjet hepmc zlib lhapdf ]; + nativeBuildInputs = [ rsync ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ fixDarwinDylibNames ]; + buildInputs = [ + boost + fastjet + hepmc + zlib + lhapdf + ]; - configureFlags = [ - "--enable-shared" - "--with-lhapdf6=${lhapdf}" - ] ++ (if lib.versions.major hepmc.version == "3" then [ - "--with-hepmc3=${hepmc}" - ] else [ - "--with-hepmc2=${hepmc}" - ]); + configureFlags = + [ + "--enable-shared" + "--with-lhapdf6=${lhapdf}" + ] + ++ ( + if lib.versions.major hepmc.version == "3" then + [ + "--with-hepmc3=${hepmc}" + ] + else + [ + "--with-hepmc2=${hepmc}" + ] + ); enableParallelBuilding = true; diff --git a/pkgs/development/libraries/physics/rivet/default.nix b/pkgs/development/libraries/physics/rivet/default.nix index 55d2de981e72df..adf5ae595efe73 100644 --- a/pkgs/development/libraries/physics/rivet/default.nix +++ b/pkgs/development/libraries/physics/rivet/default.nix @@ -1,4 +1,23 @@ -{ lib, stdenv, fetchurl, fastjet, fastjet-contrib, ghostscript, hdf5, hepmc3, highfive, imagemagick, less, pkg-config, python3, rsync, texliveBasic, yoda, which, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + fastjet, + fastjet-contrib, + ghostscript, + hdf5, + hepmc3, + highfive, + imagemagick, + less, + pkg-config, + python3, + rsync, + texliveBasic, + yoda, + which, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "rivet"; @@ -9,25 +28,42 @@ stdenv.mkDerivation rec { hash = "sha256-ZaOzb0K/94LtJ2eTDmaeCbFAiZYF15cvyPd3hbSogsA="; }; - latex = texliveBasic.withPackages (ps: with ps; [ - collection-pstricks - collection-fontsrecommended - l3kernel - l3packages - mathastext - pgf - relsize - sansmath - sfmath - siunitx - xcolor - xkeyval - xstring - ]); + latex = texliveBasic.withPackages ( + ps: with ps; [ + collection-pstricks + collection-fontsrecommended + l3kernel + l3packages + mathastext + pgf + relsize + sansmath + sfmath + siunitx + xcolor + xkeyval + xstring + ] + ); - nativeBuildInputs = [ rsync makeWrapper pkg-config ]; - buildInputs = [ hepmc3 highfive imagemagick python3 latex python3.pkgs.yoda ]; - propagatedBuildInputs = [ hdf5 fastjet fastjet-contrib ]; + nativeBuildInputs = [ + rsync + makeWrapper + pkg-config + ]; + buildInputs = [ + hepmc3 + highfive + imagemagick + python3 + latex + python3.pkgs.yoda + ]; + propagatedBuildInputs = [ + hdf5 + fastjet + fastjet-contrib + ]; preConfigure = '' substituteInPlace configure \ @@ -35,7 +71,9 @@ stdenv.mkDerivation rec { substituteInPlace bin/rivet-build.in \ --replace-fail 'num_jobs=$(getconf _NPROCESSORS_ONLN)' 'num_jobs=''${NIX_BUILD_CORES:-$(getconf _NPROCESSORS_ONLN)}' \ --replace-fail 'which' '"${which}/bin/which"' \ - --replace-fail 'mycxx=' 'mycxx=${stdenv.cc}/bin/${if stdenv.cc.isClang or false then "clang++" else "g++"} #' \ + --replace-fail 'mycxx=' 'mycxx=${stdenv.cc}/bin/${ + if stdenv.cc.isClang or false then "clang++" else "g++" + } #' \ --replace-fail 'mycxxflags="' "mycxxflags=\"$NIX_CFLAGS_COMPILE $NIX_CXXSTDLIB_COMPILE $NIX_CFLAGS_LINK " ''; @@ -73,9 +111,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Framework for comparison of experimental measurements from high-energy particle colliders to theory predictions"; - license = licenses.gpl3; - homepage = "https://rivet.hepforge.org"; - platforms = platforms.unix; + license = licenses.gpl3; + homepage = "https://rivet.hepforge.org"; + platforms = platforms.unix; maintainers = with maintainers; [ veprbl ]; }; } diff --git a/pkgs/development/libraries/physics/yoda/default.nix b/pkgs/development/libraries/physics/yoda/default.nix index b8eb2168db050e..746286254daed2 100644 --- a/pkgs/development/libraries/physics/yoda/default.nix +++ b/pkgs/development/libraries/physics/yoda/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitLab -, autoreconfHook -, python -, root -, makeWrapper -, zlib -, withRootSupport ? false +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + python, + root, + makeWrapper, + zlib, + withRootSupport ? false, }: stdenv.mkDerivation rec { @@ -26,14 +27,17 @@ stdenv.mkDerivation rec { makeWrapper ]; - buildInputs = [ - python - ] ++ (with python.pkgs; [ - numpy - matplotlib - ]) ++ lib.optionals withRootSupport [ - root - ]; + buildInputs = + [ + python + ] + ++ (with python.pkgs; [ + numpy + matplotlib + ]) + ++ lib.optionals withRootSupport [ + root + ]; propagatedBuildInputs = [ zlib diff --git a/pkgs/development/libraries/pipewire/default.nix b/pkgs/development/libraries/pipewire/default.nix index f8735c294a071b..c7bdcdff2454d4 100644 --- a/pkgs/development/libraries/pipewire/default.nix +++ b/pkgs/development/libraries/pipewire/default.nix @@ -1,63 +1,64 @@ -{ stdenv -, lib -, fetchFromGitLab -, python3 -, meson -, ninja -, elogind -, systemd -, enableSystemd ? true # enableSystemd=false maintained by maintainers.qyliss. -, pkg-config -, docutils -, doxygen -, graphviz -, glib -, dbus -, alsa-lib -, libjack2 -, libusb1 -, udev -, libsndfile -, vulkanSupport ? true -, vulkan-headers -, vulkan-loader -, webrtc-audio-processing -, webrtc-audio-processing_1 -, ncurses -, readline # meson can't find <7 as those versions don't have a .pc file -, lilv -, makeFontsConf -, nixosTests -, valgrind -, libcamera -, libdrm -, gst_all_1 -, ffmpeg -, bluez -, sbc -, libfreeaptx -, liblc3 -, fdk_aac -, libopus -, ldacbt -, modemmanager -, libpulseaudio -, zeroconfSupport ? true -, avahi -, raopSupport ? true -, openssl -, rocSupport ? true -, roc-toolkit -, x11Support ? true -, libcanberra -, xorg -, libmysofa -, ffadoSupport ? x11Support && lib.systems.equals stdenv.buildPlatform stdenv.hostPlatform -, ffado -, libselinux +{ + stdenv, + lib, + fetchFromGitLab, + python3, + meson, + ninja, + elogind, + systemd, + enableSystemd ? true, # enableSystemd=false maintained by maintainers.qyliss. + pkg-config, + docutils, + doxygen, + graphviz, + glib, + dbus, + alsa-lib, + libjack2, + libusb1, + udev, + libsndfile, + vulkanSupport ? true, + vulkan-headers, + vulkan-loader, + webrtc-audio-processing, + webrtc-audio-processing_1, + ncurses, + readline, # meson can't find <7 as those versions don't have a .pc file + lilv, + makeFontsConf, + nixosTests, + valgrind, + libcamera, + libdrm, + gst_all_1, + ffmpeg, + bluez, + sbc, + libfreeaptx, + liblc3, + fdk_aac, + libopus, + ldacbt, + modemmanager, + libpulseaudio, + zeroconfSupport ? true, + avahi, + raopSupport ? true, + openssl, + rocSupport ? true, + roc-toolkit, + x11Support ? true, + libcanberra, + xorg, + libmysofa, + ffadoSupport ? x11Support && lib.systems.equals stdenv.buildPlatform stdenv.hostPlatform, + ffado, + libselinux, }: -stdenv.mkDerivation(finalAttrs: { +stdenv.mkDerivation (finalAttrs: { pname = "pipewire"; version = "1.2.6"; @@ -97,42 +98,65 @@ stdenv.mkDerivation(finalAttrs: { glib ]; - buildInputs = [ - alsa-lib - bluez - dbus - fdk_aac - ffmpeg - glib - gst_all_1.gst-plugins-base - gst_all_1.gstreamer - libcamera - libjack2 - libfreeaptx - liblc3 - libmysofa - libopus - libpulseaudio - libusb1 - libselinux - libsndfile - lilv - modemmanager - ncurses - readline - sbc - ] ++ (if enableSystemd then [ systemd ] else [ elogind udev ]) - ++ (if lib.meta.availableOn stdenv.hostPlatform webrtc-audio-processing_1 then [ webrtc-audio-processing_1 ] else [ webrtc-audio-processing ]) - ++ lib.optional (lib.meta.availableOn stdenv.hostPlatform ldacbt) ldacbt - ++ lib.optional zeroconfSupport avahi - ++ lib.optional raopSupport openssl - ++ lib.optional rocSupport roc-toolkit - ++ lib.optionals vulkanSupport [ libdrm vulkan-headers vulkan-loader ] - ++ lib.optionals x11Support [ libcanberra xorg.libX11 xorg.libXfixes ] - ++ lib.optional ffadoSupport ffado; + buildInputs = + [ + alsa-lib + bluez + dbus + fdk_aac + ffmpeg + glib + gst_all_1.gst-plugins-base + gst_all_1.gstreamer + libcamera + libjack2 + libfreeaptx + liblc3 + libmysofa + libopus + libpulseaudio + libusb1 + libselinux + libsndfile + lilv + modemmanager + ncurses + readline + sbc + ] + ++ ( + if enableSystemd then + [ systemd ] + else + [ + elogind + udev + ] + ) + ++ ( + if lib.meta.availableOn stdenv.hostPlatform webrtc-audio-processing_1 then + [ webrtc-audio-processing_1 ] + else + [ webrtc-audio-processing ] + ) + ++ lib.optional (lib.meta.availableOn stdenv.hostPlatform ldacbt) ldacbt + ++ lib.optional zeroconfSupport avahi + ++ lib.optional raopSupport openssl + ++ lib.optional rocSupport roc-toolkit + ++ lib.optionals vulkanSupport [ + libdrm + vulkan-headers + vulkan-loader + ] + ++ lib.optionals x11Support [ + libcanberra + xorg.libX11 + xorg.libXfixes + ] + ++ lib.optional ffadoSupport ffado; # Valgrind binary is required for running one optional test. - nativeCheckInputs = lib.optional (lib.meta.availableOn stdenv.hostPlatform valgrind) valgrind; + nativeCheckInputs = lib.optional (lib.meta.availableOn stdenv.hostPlatform valgrind) valgrind; mesonFlags = [ (lib.mesonEnable "docs" true) @@ -201,6 +225,9 @@ stdenv.mkDerivation(finalAttrs: { homepage = "https://pipewire.org/"; license = licenses.mit; platforms = platforms.linux; - maintainers = with maintainers; [ kranzes k900 ]; + maintainers = with maintainers; [ + kranzes + k900 + ]; }; }) diff --git a/pkgs/development/libraries/pipewire/wireplumber.nix b/pkgs/development/libraries/pipewire/wireplumber.nix index 23d46918504048..958f0d52ab0ecf 100644 --- a/pkgs/development/libraries/pipewire/wireplumber.nix +++ b/pkgs/development/libraries/pipewire/wireplumber.nix @@ -1,32 +1,36 @@ -{ lib -, stdenv -, fetchFromGitLab -, nix-update-script -# base build deps -, meson -, pkg-config -, ninja -# docs build deps -, python3 -, doxygen -, graphviz -# GI build deps -, gobject-introspection -# runtime deps -, glib -, systemd -, lua5_4 -, pipewire -# options -, enableDocs ? true -, enableGI ? true +{ + lib, + stdenv, + fetchFromGitLab, + nix-update-script, + # base build deps + meson, + pkg-config, + ninja, + # docs build deps + python3, + doxygen, + graphviz, + # GI build deps + gobject-introspection, + # runtime deps + glib, + systemd, + lua5_4, + pipewire, + # options + enableDocs ? true, + enableGI ? true, }: stdenv.mkDerivation rec { pname = "wireplumber"; version = "0.5.7"; - outputs = [ "out" "dev" ] ++ lib.optional enableDocs "doc"; + outputs = [ + "out" + "dev" + ] ++ lib.optional enableDocs "doc"; src = fetchFromGitLab { domain = "gitlab.freedesktop.org"; @@ -36,21 +40,31 @@ stdenv.mkDerivation rec { hash = "sha256-KZ4ECpDZhTBQKylJwP3OcsyjZ1ktqwWUZFg9j9KvNsM="; }; - nativeBuildInputs = [ - meson - pkg-config - ninja - ] ++ lib.optionals enableDocs [ - graphviz - ] ++ lib.optionals enableGI [ - gobject-introspection - ] ++ lib.optionals (enableDocs || enableGI) [ - doxygen - (python3.pythonOnBuildForHost.withPackages (ps: with ps; - lib.optionals enableDocs [ sphinx sphinx-rtd-theme breathe ] - ++ lib.optionals enableGI [ lxml ] - )) - ]; + nativeBuildInputs = + [ + meson + pkg-config + ninja + ] + ++ lib.optionals enableDocs [ + graphviz + ] + ++ lib.optionals enableGI [ + gobject-introspection + ] + ++ lib.optionals (enableDocs || enableGI) [ + doxygen + (python3.pythonOnBuildForHost.withPackages ( + ps: + with ps; + lib.optionals enableDocs [ + sphinx + sphinx-rtd-theme + breathe + ] + ++ lib.optionals enableGI [ lxml ] + )) + ]; buildInputs = [ glib diff --git a/pkgs/development/libraries/plasma-wayland-protocols/default.nix b/pkgs/development/libraries/plasma-wayland-protocols/default.nix index e0121a04e3539d..f29f2c2ddc56e6 100644 --- a/pkgs/development/libraries/plasma-wayland-protocols/default.nix +++ b/pkgs/development/libraries/plasma-wayland-protocols/default.nix @@ -1,8 +1,9 @@ -{ mkDerivation -, fetchurl -, lib -, extra-cmake-modules -, qtbase +{ + mkDerivation, + fetchurl, + lib, + extra-cmake-modules, + qtbase, }: mkDerivation rec { diff --git a/pkgs/development/libraries/podofo/0.10.x.nix b/pkgs/development/libraries/podofo/0.10.x.nix index fdc42bc0f56532..a1d2022325446d 100644 --- a/pkgs/development/libraries/podofo/0.10.x.nix +++ b/pkgs/development/libraries/podofo/0.10.x.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, expat -, fontconfig -, freetype -, libidn -, libjpeg -, libpng -, libtiff -, libxml2 -, lua5 -, openssl -, pkg-config -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + expat, + fontconfig, + freetype, + libidn, + libjpeg, + libpng, + libtiff, + libxml2, + lua5, + openssl, + pkg-config, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -27,7 +28,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-ZY+kyimLzAeEgvDaflXM7MbyzsGgivOnG1aBD9/ozbk="; }; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; nativeBuildInputs = [ cmake @@ -57,7 +62,10 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://github.com/podofo/podofo"; description = "Library to work with the PDF file format"; platforms = lib.platforms.all; - license = with lib.licenses; [ gpl2Plus lgpl2Plus ]; + license = with lib.licenses; [ + gpl2Plus + lgpl2Plus + ]; maintainers = [ ]; }; }) diff --git a/pkgs/development/libraries/podofo/default.nix b/pkgs/development/libraries/podofo/default.nix index 598366dc6eb84e..c49c31be882279 100644 --- a/pkgs/development/libraries/podofo/default.nix +++ b/pkgs/development/libraries/podofo/default.nix @@ -1,5 +1,19 @@ -{ lib, stdenv, fetchurl, cmake, zlib, freetype, libjpeg, libtiff, fontconfig -, openssl, libpng, lua5, pkg-config, libidn, expat +{ + lib, + stdenv, + fetchurl, + cmake, + zlib, + freetype, + libjpeg, + libtiff, + fontconfig, + openssl, + libpng, + lua5, + pkg-config, + libidn, + expat, }: stdenv.mkDerivation rec { @@ -11,12 +25,29 @@ stdenv.mkDerivation rec { sha256 = "sha256-XeYH4V8ZK4rZBzgwB1nYjeoPXM3OO/AASKDJMrxkUVQ="; }; - outputs = [ "out" "dev" "lib" ]; + outputs = [ + "out" + "dev" + "lib" + ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ zlib freetype libjpeg libtiff fontconfig openssl libpng - libidn expat lua5 ]; + buildInputs = [ + zlib + freetype + libjpeg + libtiff + fontconfig + openssl + libpng + libidn + expat + lua5 + ]; cmakeFlags = [ "-DPODOFO_BUILD_SHARED=ON" @@ -37,6 +68,9 @@ stdenv.mkDerivation rec { homepage = "https://podofo.sourceforge.net"; description = "Library to work with the PDF file format"; platforms = platforms.all; - license = with licenses; [ gpl2Plus lgpl2Plus ]; + license = with licenses; [ + gpl2Plus + lgpl2Plus + ]; }; } diff --git a/pkgs/development/libraries/polkit-qt-1/default.nix b/pkgs/development/libraries/polkit-qt-1/default.nix index 0fb66ccc7c3d53..ff18b348a592f6 100644 --- a/pkgs/development/libraries/polkit-qt-1/default.nix +++ b/pkgs/development/libraries/polkit-qt-1/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, mkDerivation -, fetchurl -, cmake -, pkg-config -, polkit -, glib -, pcre -, libselinux -, libsepol -, util-linux +{ + stdenv, + lib, + mkDerivation, + fetchurl, + cmake, + pkg-config, + polkit, + glib, + pcre, + libselinux, + libsepol, + util-linux, }: mkDerivation rec { @@ -21,13 +22,22 @@ mkDerivation rec { sha256 = "sha256-LrDyJEWIgpX/or+8DDaThHoPlzu2sMPkzOAhi+fjkH4="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ - glib - pcre - polkit - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libselinux libsepol util-linux ]; + buildInputs = + [ + glib + pcre + polkit + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libselinux + libsepol + util-linux + ]; meta = with lib; { description = "Qt wrapper around PolKit"; diff --git a/pkgs/development/libraries/poppler/default.nix b/pkgs/development/libraries/poppler/default.nix index 368c5a06a463f4..a0153c459fa4f6 100644 --- a/pkgs/development/libraries/poppler/default.nix +++ b/pkgs/development/libraries/poppler/default.nix @@ -1,39 +1,46 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitLab -, fetchpatch -, cairo -, cmake -, boost -, curl -, fontconfig -, freetype -, lcms -, libiconv -, libintl -, libjpeg -, ninja -, openjpeg -, pkg-config -, python3 -, zlib -, withData ? true, poppler_data -, qt5Support ? false, qt6Support ? false, qtbase ? null -, introspectionSupport ? false, gobject-introspection ? null -, gpgmeSupport ? false, gpgme ? null -, utils ? false, nss ? null -, minimal ? false -, suffix ? "glib" - -# for passthru.tests -, cups-filters -, gdal -, gegl -, inkscape -, pdfslicer -, scribus -, vips +{ + lib, + stdenv, + fetchurl, + fetchFromGitLab, + fetchpatch, + cairo, + cmake, + boost, + curl, + fontconfig, + freetype, + lcms, + libiconv, + libintl, + libjpeg, + ninja, + openjpeg, + pkg-config, + python3, + zlib, + withData ? true, + poppler_data, + qt5Support ? false, + qt6Support ? false, + qtbase ? null, + introspectionSupport ? false, + gobject-introspection ? null, + gpgmeSupport ? false, + gpgme ? null, + utils ? false, + nss ? null, + minimal ? false, + suffix ? "glib", + + # for passthru.tests + cups-filters, + gdal, + gegl, + inkscape, + pdfslicer, + scribus, + vips, }: let @@ -55,7 +62,10 @@ stdenv.mkDerivation (finalAttrs: rec { pname = "poppler-${suffix}"; version = "24.02.0"; # beware: updates often break cups-filters build, check scribus too! - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "https://poppler.freedesktop.org/poppler-${version}.tar.xz"; @@ -78,49 +88,58 @@ stdenv.mkDerivation (finalAttrs: rec { python3 ]; - buildInputs = [ - boost - libiconv - libintl - ] ++ lib.optionals withData [ - poppler_data - ]; + buildInputs = + [ + boost + libiconv + libintl + ] + ++ lib.optionals withData [ + poppler_data + ]; # TODO: reduce propagation to necessary libs - propagatedBuildInputs = [ - zlib - freetype - fontconfig - libjpeg - openjpeg - ] ++ lib.optionals (!minimal) [ - cairo - lcms - curl - nss - ] ++ lib.optionals (qt5Support || qt6Support) [ - qtbase - ] ++ lib.optionals introspectionSupport [ - gobject-introspection - ] ++ lib.optionals gpgmeSupport [ - gpgme - ]; - - cmakeFlags = [ - (mkFlag true "UNSTABLE_API_ABI_HEADERS") # previously "XPDF_HEADERS" - (mkFlag (!minimal) "GLIB") - (mkFlag (!minimal) "CPP") - (mkFlag (!minimal) "LIBCURL") - (mkFlag (!minimal) "LCMS") - (mkFlag (!minimal) "LIBTIFF") - (mkFlag (!minimal) "NSS3") - (mkFlag utils "UTILS") - (mkFlag qt5Support "QT5") - (mkFlag qt6Support "QT6") - (mkFlag gpgmeSupport "GPGME") - ] ++ lib.optionals finalAttrs.finalPackage.doCheck [ - "-DTESTDATADIR=${testData}" - ]; + propagatedBuildInputs = + [ + zlib + freetype + fontconfig + libjpeg + openjpeg + ] + ++ lib.optionals (!minimal) [ + cairo + lcms + curl + nss + ] + ++ lib.optionals (qt5Support || qt6Support) [ + qtbase + ] + ++ lib.optionals introspectionSupport [ + gobject-introspection + ] + ++ lib.optionals gpgmeSupport [ + gpgme + ]; + + cmakeFlags = + [ + (mkFlag true "UNSTABLE_API_ABI_HEADERS") # previously "XPDF_HEADERS" + (mkFlag (!minimal) "GLIB") + (mkFlag (!minimal) "CPP") + (mkFlag (!minimal) "LIBCURL") + (mkFlag (!minimal) "LCMS") + (mkFlag (!minimal) "LIBTIFF") + (mkFlag (!minimal) "NSS3") + (mkFlag utils "UTILS") + (mkFlag qt5Support "QT5") + (mkFlag qt6Support "QT6") + (mkFlag gpgmeSupport "GPGME") + ] + ++ lib.optionals finalAttrs.finalPackage.doCheck [ + "-DTESTDATADIR=${testData}" + ]; disallowedReferences = lib.optional finalAttrs.finalPackage.doCheck testData; dontWrapQtApps = true; @@ -151,13 +170,13 @@ stdenv.mkDerivation (finalAttrs: rec { cups-filters inkscape scribus - ; + ; inherit gegl pdfslicer vips - ; + ; gdal = gdal.override { usePoppler = true; }; python-poppler-qt5 = python3.pkgs.poppler-qt5; }; diff --git a/pkgs/development/libraries/portaudio/default.nix b/pkgs/development/libraries/portaudio/default.nix index e16562d85eb110..99b1f8154cd343 100644 --- a/pkgs/development/libraries/portaudio/default.nix +++ b/pkgs/development/libraries/portaudio/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, alsa-lib -, libjack2 -, pkg-config -, which +{ + lib, + stdenv, + fetchurl, + alsa-lib, + libjack2, + pkg-config, + which, }: stdenv.mkDerivation rec { @@ -17,12 +18,18 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ pkg-config which ]; - buildInputs = - [ libjack2 ] - ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform alsa-lib) [ alsa-lib ]; + nativeBuildInputs = [ + pkg-config + which + ]; + buildInputs = [ + libjack2 + ] ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform alsa-lib) [ alsa-lib ]; - configureFlags = [ "--disable-mac-universal" "--enable-cxx" ]; + configureFlags = [ + "--disable-mac-universal" + "--enable-cxx" + ]; env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-error=nullability-inferred-on-nested-type -Wno-error=nullability-completeness-on-arrays -Wno-error=implicit-const-int-float-conversion"; @@ -39,22 +46,25 @@ stdenv.mkDerivation rec { ''; # not sure why, but all the headers seem to be installed by the make install - installPhase = '' - make install - '' + lib.optionalString (lib.meta.availableOn stdenv.hostPlatform alsa-lib) '' - # fixup .pc file to find alsa library - sed -i "s|-lasound|-L${alsa-lib.out}/lib -lasound|" "$out/lib/pkgconfig/"*.pc - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - cp include/pa_mac_core.h $out/include/pa_mac_core.h - ''; + installPhase = + '' + make install + '' + + lib.optionalString (lib.meta.availableOn stdenv.hostPlatform alsa-lib) '' + # fixup .pc file to find alsa library + sed -i "s|-lasound|-L${alsa-lib.out}/lib -lasound|" "$out/lib/pkgconfig/"*.pc + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + cp include/pa_mac_core.h $out/include/pa_mac_core.h + ''; meta = with lib; { description = "Portable cross-platform Audio API"; - homepage = "https://www.portaudio.com/"; + homepage = "https://www.portaudio.com/"; # Not exactly a bsd license, but alike - license = licenses.mit; + license = licenses.mit; maintainers = with maintainers; [ lovek323 ]; - platforms = platforms.unix; + platforms = platforms.unix; }; passthru = { diff --git a/pkgs/development/libraries/portmidi/default.nix b/pkgs/development/libraries/portmidi/default.nix index eac2a369fd0b0a..9afbb6018aebfe 100644 --- a/pkgs/development/libraries/portmidi/default.nix +++ b/pkgs/development/libraries/portmidi/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, unzip, cmake, alsa-lib, Carbon, CoreAudio, CoreFoundation, CoreMIDI, CoreServices }: +{ + lib, + stdenv, + fetchFromGitHub, + unzip, + cmake, + alsa-lib, + Carbon, + CoreAudio, + CoreFoundation, + CoreMIDI, + CoreServices, +}: stdenv.mkDerivation rec { pname = "portmidi"; @@ -22,16 +34,29 @@ stdenv.mkDerivation rec { ./missing-header.diff ]; - postInstall = let ext = stdenv.hostPlatform.extensions.sharedLibrary; in '' - ln -s libportmidi${ext} "$out/lib/libporttime${ext}" - ''; + postInstall = + let + ext = stdenv.hostPlatform.extensions.sharedLibrary; + in + '' + ln -s libportmidi${ext} "$out/lib/libporttime${ext}" + ''; - nativeBuildInputs = [ unzip cmake ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Carbon CoreAudio CoreFoundation CoreMIDI CoreServices + nativeBuildInputs = [ + unzip + cmake ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + CoreAudio + CoreFoundation + CoreMIDI + CoreServices + ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/development/libraries/proj/7.nix b/pkgs/development/libraries/proj/7.nix index cfd1156388024b..19f205df4b72cd 100644 --- a/pkgs/development/libraries/proj/7.nix +++ b/pkgs/development/libraries/proj/7.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, sqlite -, libtiff -, curl -, gtest -, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + sqlite, + libtiff, + curl, + gtest, + fetchpatch, }: stdenv.mkDerivation rec { @@ -22,7 +23,8 @@ stdenv.mkDerivation rec { }; patches = [ - (fetchpatch { # https://github.com/OSGeo/PROJ/issues/2557 + (fetchpatch { + # https://github.com/OSGeo/PROJ/issues/2557 name = "gie_self_tests-fail.diff"; # included in >= 8.0.1 url = "https://github.com/OSGeo/PROJ/commit/6f1a3c4648bf06862dca0b3725cbb3b7ee0284e3.diff"; sha256 = "0gapny0a9c3r0x9szjgn86sspjrrf4vwbija77b17w6ci5cq4pdf"; @@ -35,11 +37,21 @@ stdenv.mkDerivation rec { --replace "MAJOR 7 MINOR 2 PATCH 0" "MAJOR 7 MINOR 2 PATCH 1" ''; - outputs = [ "out" "dev"]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ sqlite libtiff curl ]; + buildInputs = [ + sqlite + libtiff + curl + ]; nativeCheckInputs = [ gtest ]; diff --git a/pkgs/development/libraries/proj/default.nix b/pkgs/development/libraries/proj/default.nix index f2833cedc805bb..e9a9caff159f11 100644 --- a/pkgs/development/libraries/proj/default.nix +++ b/pkgs/development/libraries/proj/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, buildPackages -, callPackage -, sqlite -, libtiff -, curl -, gtest -, nlohmann_json -, python3 -, cacert +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + buildPackages, + callPackage, + sqlite, + libtiff, + curl, + gtest, + nlohmann_json, + python3, + cacert, }: stdenv.mkDerivation (finalAttrs: { @@ -30,13 +31,27 @@ stdenv.mkDerivation (finalAttrs: { ./only-add-curl-for-static-builds.patch ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ sqlite libtiff curl nlohmann_json ]; + buildInputs = [ + sqlite + libtiff + curl + nlohmann_json + ]; - nativeCheckInputs = [ cacert gtest ]; + nativeCheckInputs = [ + cacert + gtest + ]; cmakeFlags = [ "-DUSE_EXTERNAL_GTEST=ON" @@ -53,11 +68,11 @@ stdenv.mkDerivation (finalAttrs: { let libPathEnvVar = if stdenv.hostPlatform.isDarwin then "DYLD_LIBRARY_PATH" else "LD_LIBRARY_PATH"; in - '' - export HOME=$TMPDIR - export TMP=$TMPDIR - export ${libPathEnvVar}=$PWD/lib - ''; + '' + export HOME=$TMPDIR + export TMP=$TMPDIR + export ${libPathEnvVar}=$PWD/lib + ''; doCheck = true; diff --git a/pkgs/development/libraries/proj/tests.nix b/pkgs/development/libraries/proj/tests.nix index 38126f06dd4d67..93ec7e17a72b42 100644 --- a/pkgs/development/libraries/proj/tests.nix +++ b/pkgs/development/libraries/proj/tests.nix @@ -3,9 +3,8 @@ let inherit (proj) pname; in -runCommand "${pname}-tests" { meta.timeout = 60; } - '' - ${proj}/bin/projinfo EPSG:4326 \ - | grep '+proj=longlat +datum=WGS84 +no_defs +type=crs' - touch $out - '' +runCommand "${pname}-tests" { meta.timeout = 60; } '' + ${proj}/bin/projinfo EPSG:4326 \ + | grep '+proj=longlat +datum=WGS84 +no_defs +type=crs' + touch $out +'' diff --git a/pkgs/development/libraries/prometheus-client-c/default.nix b/pkgs/development/libraries/prometheus-client-c/default.nix index 4d695eff640852..340a87666c1484 100644 --- a/pkgs/development/libraries/prometheus-client-c/default.nix +++ b/pkgs/development/libraries/prometheus-client-c/default.nix @@ -1,15 +1,18 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, libmicrohttpd +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + libmicrohttpd, }: let build = - { pname - , subdir - , buildInputs ? [ ] - , description + { + pname, + subdir, + buildInputs ? [ ], + description, }: stdenv.mkDerivation rec { inherit pname; @@ -29,18 +32,14 @@ let patches = [ # Required so CMAKE_INSTALL_PREFIX is honored, otherwise it # installs headers in /usr/include (absolute) - ( - fetchpatch { - url = "https://github.com/digitalocean/prometheus-client-c/commit/5fcedeb506b7d47dd7bab35797f2c3f23db6fe10.patch"; - sha256 = "10hzg8v5jcgxz224kdq0nha9vs78wz098b0ys7gig2iwgrg018fy"; - } - ) - ( - fetchpatch { - url = "https://github.com/digitalocean/prometheus-client-c/commit/0c15e7e45ad0c3726593591fdd7d8f2fde845fe3.patch"; - sha256 = "06899v1xz3lpsdxww4p3q7pv8nrymnibncdc472056znr5fidlp0"; - } - ) + (fetchpatch { + url = "https://github.com/digitalocean/prometheus-client-c/commit/5fcedeb506b7d47dd7bab35797f2c3f23db6fe10.patch"; + sha256 = "10hzg8v5jcgxz224kdq0nha9vs78wz098b0ys7gig2iwgrg018fy"; + }) + (fetchpatch { + url = "https://github.com/digitalocean/prometheus-client-c/commit/0c15e7e45ad0c3726593591fdd7d8f2fde845fe3.patch"; + sha256 = "06899v1xz3lpsdxww4p3q7pv8nrymnibncdc472056znr5fidlp0"; + }) ]; # Workaround build failure on -fno-common toolchains like upstream @@ -72,7 +71,10 @@ rec { libpromhttp = build { pname = "libpromhttp"; subdir = "promhttp"; - buildInputs = [ libmicrohttpd libprom ]; + buildInputs = [ + libmicrohttpd + libprom + ]; description = "Prometheus HTTP Endpoint in C"; }; } diff --git a/pkgs/development/libraries/pulseaudio-qt/default.nix b/pkgs/development/libraries/pulseaudio-qt/default.nix index 0db185b20b707a..9bc5141eeb6e75 100644 --- a/pkgs/development/libraries/pulseaudio-qt/default.nix +++ b/pkgs/development/libraries/pulseaudio-qt/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchurl -, cmake -, pkg-config -, extra-cmake-modules -, wrapQtAppsHook -, pulseaudio +{ + stdenv, + lib, + fetchurl, + cmake, + pkg-config, + extra-cmake-modules, + wrapQtAppsHook, + pulseaudio, }: stdenv.mkDerivation (finalAttrs: { @@ -30,8 +31,8 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Pulseaudio bindings for Qt"; - homepage = "https://invent.kde.org/libraries/pulseaudio-qt"; - license = with licenses; [ lgpl2 ]; + homepage = "https://invent.kde.org/libraries/pulseaudio-qt"; + license = with licenses; [ lgpl2 ]; maintainers = with maintainers; [ doronbehar ]; }; }) diff --git a/pkgs/development/libraries/pyotherside/default.nix b/pkgs/development/libraries/pyotherside/default.nix index f99f1927295aab..39afc2e4a11a07 100644 --- a/pkgs/development/libraries/pyotherside/default.nix +++ b/pkgs/development/libraries/pyotherside/default.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub -, python3, qmake, qtbase, qtquickcontrols, qtsvg, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + qmake, + qtbase, + qtquickcontrols, + qtsvg, + ncurses, +}: stdenv.mkDerivation rec { pname = "pyotherside"; @@ -14,7 +23,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ qmake ]; buildInputs = [ - python3 qtbase qtquickcontrols qtsvg ncurses + python3 + qtbase + qtquickcontrols + qtsvg + ncurses ]; dontWrapQtApps = true; diff --git a/pkgs/development/libraries/qca/default.nix b/pkgs/development/libraries/qca/default.nix index a8651c9c2a5f38..1f9524357c346e 100644 --- a/pkgs/development/libraries/qca/default.nix +++ b/pkgs/development/libraries/qca/default.nix @@ -1,8 +1,18 @@ -{ lib, stdenv, fetchurl, cmake, openssl, pkg-config, qtbase, qt5compat ? null }: +{ + lib, + stdenv, + fetchurl, + cmake, + openssl, + pkg-config, + qtbase, + qt5compat ? null, +}: let isQt6 = lib.versions.major qtbase.version == "6"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "qca"; version = "2.3.9"; @@ -11,8 +21,15 @@ in stdenv.mkDerivation rec { sha256 = "sha256-xVXVKYzde2uv4rH5YQbzDPpUOiPUWdUMipHqwzxHbk4="; }; - buildInputs = [ openssl qtbase qt5compat ]; - nativeBuildInputs = [ cmake pkg-config ]; + buildInputs = [ + openssl + qtbase + qt5compat + ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; dontWrapQtApps = true; diff --git a/pkgs/development/libraries/qcoro/default.nix b/pkgs/development/libraries/qcoro/default.nix index 877292493dba9d..92818b35571be4 100644 --- a/pkgs/development/libraries/qcoro/default.nix +++ b/pkgs/development/libraries/qcoro/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libpthreadstubs -, qtbase -, qtwebsockets -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libpthreadstubs, + qtbase, + qtwebsockets, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -19,7 +20,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-teRuWtNR8r/MHZhqphazr7Jmn43qsHGv9eXOGrhSND0="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ wrapQtAppsHook diff --git a/pkgs/development/libraries/qdjango/default.nix b/pkgs/development/libraries/qdjango/default.nix index 8036373a826add..128b4fbb08a968 100644 --- a/pkgs/development/libraries/qdjango/default.nix +++ b/pkgs/development/libraries/qdjango/default.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, testers -, doxygen -, qmake +{ + stdenv, + lib, + fetchFromGitHub, + testers, + doxygen, + qmake, }: stdenv.mkDerivation (finalAttrs: { @@ -17,18 +18,24 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-5MfRfsIlv73VMvKMBCLviXFovyGH0On5ukLIEy7zwkk="; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; - postPatch = '' - # HTML docs depend on regular docs - substituteInPlace qdjango.pro \ - --replace 'dist.depends = docs' 'htmldocs.depends = docs' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # tst_Auth:constIterator (tests/db/auth/tst_auth.cpp:624) fails on Darwin? - # QVERIFY(&*(it += 2) == 0) evals to false - substituteInPlace tests/db/db.pro \ - --replace 'auth' "" - ''; + postPatch = + '' + # HTML docs depend on regular docs + substituteInPlace qdjango.pro \ + --replace 'dist.depends = docs' 'htmldocs.depends = docs' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # tst_Auth:constIterator (tests/db/auth/tst_auth.cpp:624) fails on Darwin? + # QVERIFY(&*(it += 2) == 0) evals to false + substituteInPlace tests/db/db.pro \ + --replace 'auth' "" + ''; qmakeFlags = [ # Uses Qt testing infrastructure via QMake CONFIG testcase, diff --git a/pkgs/development/libraries/qgnomeplatform/default.nix b/pkgs/development/libraries/qgnomeplatform/default.nix index 6e489f69b72c6d..1872366217302e 100644 --- a/pkgs/development/libraries/qgnomeplatform/default.nix +++ b/pkgs/development/libraries/qgnomeplatform/default.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, nix-update-script -, cmake -, pkg-config -, adwaita-qt -, adwaita-qt6 -, glib -, gtk3 -, qtbase -, qtwayland -, substituteAll -, gsettings-desktop-schemas -, useQt6 ? false +{ + stdenv, + lib, + fetchFromGitHub, + nix-update-script, + cmake, + pkg-config, + adwaita-qt, + adwaita-qt6, + glib, + gtk3, + qtbase, + qtwayland, + substituteAll, + gsettings-desktop-schemas, + useQt6 ? false, }: stdenv.mkDerivation rec { @@ -43,26 +44,31 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - glib - gtk3 - qtbase - qtwayland - ] ++ lib.optionals (!useQt6) [ - adwaita-qt - ] ++ lib.optionals useQt6 [ - adwaita-qt6 - ]; + buildInputs = + [ + glib + gtk3 + qtbase + qtwayland + ] + ++ lib.optionals (!useQt6) [ + adwaita-qt + ] + ++ lib.optionals useQt6 [ + adwaita-qt6 + ]; # Qt setup hook complains about missing `wrapQtAppsHook` otherwise. dontWrapQtApps = true; - cmakeFlags = [ - "-DGLIB_SCHEMAS_DIR=${glib.getSchemaPath gsettings-desktop-schemas}" - "-DQT_PLUGINS_DIR=${placeholder "out"}/${qtbase.qtPluginPrefix}" - ] ++ lib.optionals useQt6 [ - "-DUSE_QT6=true" - ]; + cmakeFlags = + [ + "-DGLIB_SCHEMAS_DIR=${glib.getSchemaPath gsettings-desktop-schemas}" + "-DQT_PLUGINS_DIR=${placeholder "out"}/${qtbase.qtPluginPrefix}" + ] + ++ lib.optionals useQt6 [ + "-DUSE_QT6=true" + ]; passthru = { updateScript = nix-update-script { }; diff --git a/pkgs/development/libraries/qjson/default.nix b/pkgs/development/libraries/qjson/default.nix index 4308b46c5c1fd8..4edb927e221359 100644 --- a/pkgs/development/libraries/qjson/default.nix +++ b/pkgs/development/libraries/qjson/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, qtbase }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtbase, +}: stdenv.mkDerivation rec { version = "0.9.0"; diff --git a/pkgs/development/libraries/qmarkdowntextedit/default.nix b/pkgs/development/libraries/qmarkdowntextedit/default.nix index f3ac9693807b7c..77534706d2434d 100644 --- a/pkgs/development/libraries/qmarkdowntextedit/default.nix +++ b/pkgs/development/libraries/qmarkdowntextedit/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, qmake +{ + lib, + stdenv, + fetchFromGitHub, + qmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/qmenumodel/default.nix b/pkgs/development/libraries/qmenumodel/default.nix index c2b5e61b9d3b55..16e23abcc34a16 100644 --- a/pkgs/development/libraries/qmenumodel/default.nix +++ b/pkgs/development/libraries/qmenumodel/default.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, gitUpdater -, testers -, cmake -, cmake-extras -, dbus -, dbus-test-runner -, glib -, pkg-config -, python3 -, qtbase -, qtdeclarative -, gobject-introspection +{ + stdenv, + lib, + fetchFromGitHub, + gitUpdater, + testers, + cmake, + cmake-extras, + dbus, + dbus-test-runner, + glib, + pkg-config, + python3, + qtbase, + qtdeclarative, + gobject-introspection, }: stdenv.mkDerivation (finalAttrs: { @@ -26,18 +27,23 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-zbKAfq9R5fD2IqVYOAhy903QX1TDom9m6Ib2qpkFMak="; }; - outputs = [ "out" "dev" ]; - - postPatch = '' - substituteInPlace libqmenumodel/src/qmenumodel.pc.in \ - --replace "\''${exec_prefix}/@CMAKE_INSTALL_LIBDIR@" "\''${prefix}/lib" \ - --replace "\''${prefix}/@CMAKE_INSTALL_INCLUDEDIR@" "\''${prefix}/include" + outputs = [ + "out" + "dev" + ]; - substituteInPlace libqmenumodel/QMenuModel/CMakeLists.txt \ - --replace "\''${CMAKE_INSTALL_LIBDIR}/qt5/qml" "\''${CMAKE_INSTALL_PREFIX}/${qtbase.qtQmlPrefix}" - '' + lib.optionalString finalAttrs.finalPackage.doCheck '' - patchShebangs tests/{client,script}/*.py - ''; + postPatch = + '' + substituteInPlace libqmenumodel/src/qmenumodel.pc.in \ + --replace "\''${exec_prefix}/@CMAKE_INSTALL_LIBDIR@" "\''${prefix}/lib" \ + --replace "\''${prefix}/@CMAKE_INSTALL_INCLUDEDIR@" "\''${prefix}/include" + + substituteInPlace libqmenumodel/QMenuModel/CMakeLists.txt \ + --replace "\''${CMAKE_INSTALL_LIBDIR}/qt5/qml" "\''${CMAKE_INSTALL_PREFIX}/${qtbase.qtQmlPrefix}" + '' + + lib.optionalString finalAttrs.finalPackage.doCheck '' + patchShebangs tests/{client,script}/*.py + ''; strictDeps = true; @@ -57,10 +63,12 @@ stdenv.mkDerivation (finalAttrs: { dbus dbus-test-runner gobject-introspection - (python3.withPackages (ps: with ps; [ - dbus-python - pygobject3 - ])) + (python3.withPackages ( + ps: with ps; [ + dbus-python + pygobject3 + ] + )) ]; dontWrapQtApps = true; diff --git a/pkgs/development/libraries/qmlbox2d/default.nix b/pkgs/development/libraries/qmlbox2d/default.nix index 7f7613d7f05fae..5f6cf45351f223 100644 --- a/pkgs/development/libraries/qmlbox2d/default.nix +++ b/pkgs/development/libraries/qmlbox2d/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, qtbase, qtdeclarative, fetchFromGitHub, cmake, pkg-config, box2d }: +{ + lib, + stdenv, + qtbase, + qtdeclarative, + fetchFromGitHub, + cmake, + pkg-config, + box2d, +}: let inherit (lib) cmakeBool; @@ -34,9 +43,16 @@ stdenv.mkDerivation { dontWrapQtApps = true; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ box2d' qtbase qtdeclarative ]; + buildInputs = [ + box2d' + qtbase + qtdeclarative + ]; cmakeFlags = [ (cmakeBool "USE_SYSTEM_BOX2D" true) diff --git a/pkgs/development/libraries/qmltermwidget/default.nix b/pkgs/development/libraries/qmltermwidget/default.nix index 6ba9418a6e2059..e496a537c92683 100644 --- a/pkgs/development/libraries/qmltermwidget/default.nix +++ b/pkgs/development/libraries/qmltermwidget/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, qmake -, qtbase -, qtmultimedia -, utmp +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + qmake, + qtbase, + qtmultimedia, + utmp, }: stdenv.mkDerivation { diff --git a/pkgs/development/libraries/qoauth/default.nix b/pkgs/development/libraries/qoauth/default.nix index 51e91499cbdbae..2ba063f56ea779 100644 --- a/pkgs/development/libraries/qoauth/default.nix +++ b/pkgs/development/libraries/qoauth/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, qtbase, qmake, qca-qt5 }: +{ + lib, + stdenv, + fetchFromGitHub, + qtbase, + qmake, + qca-qt5, +}: stdenv.mkDerivation rec { pname = "qoauth"; @@ -18,7 +25,10 @@ stdenv.mkDerivation rec { -e '/features.path =/ s|$$\[QMAKE_MKSPECS\]|$$NIX_OUTPUT_DEV/mkspecs|' ''; - buildInputs = [ qtbase qca-qt5 ]; + buildInputs = [ + qtbase + qca-qt5 + ]; nativeBuildInputs = [ qmake ]; env.NIX_CFLAGS_COMPILE = "-I${qca-qt5}/include/Qca-qt5/QtCrypto"; diff --git a/pkgs/development/libraries/qscintilla/default.nix b/pkgs/development/libraries/qscintilla/default.nix index 0d8df9b316b8b1..abeecc0782f37d 100644 --- a/pkgs/development/libraries/qscintilla/default.nix +++ b/pkgs/development/libraries/qscintilla/default.nix @@ -1,21 +1,19 @@ -{ stdenv -, lib -, fetchurl -, unzip -, qtbase -, qtmacextras ? null -, qmake -, fixDarwinDylibNames -, darwin +{ + stdenv, + lib, + fetchurl, + unzip, + qtbase, + qtmacextras ? null, + qmake, + fixDarwinDylibNames, + darwin, }: let - stdenv' = if stdenv.hostPlatform.isDarwin then - darwin.apple_sdk_11_0.stdenv - else - stdenv - ; -in stdenv'.mkDerivation rec { + stdenv' = if stdenv.hostPlatform.isDarwin then darwin.apple_sdk_11_0.stdenv else stdenv; +in +stdenv'.mkDerivation rec { pname = "qscintilla-qt5"; version = "2.13.2"; @@ -30,8 +28,10 @@ in stdenv'.mkDerivation rec { propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ qtmacextras ]; - nativeBuildInputs = [ unzip qmake ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ fixDarwinDylibNames ]; + nativeBuildInputs = [ + unzip + qmake + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ fixDarwinDylibNames ]; # Make sure that libqscintilla2.so is available in $out/lib since it is expected # by some packages such as sqlitebrowser diff --git a/pkgs/development/libraries/qt-5/5.15/default.nix b/pkgs/development/libraries/qt-5/5.15/default.nix index b94be6d893d20c..60cccd443308e8 100644 --- a/pkgs/development/libraries/qt-5/5.15/default.nix +++ b/pkgs/development/libraries/qt-5/5.15/default.nix @@ -1,24 +1,41 @@ /* + # Updates -# Updates - -Run `./fetch.sh` to update package sources from Git. -Check for any minor version changes. - + Run `./fetch.sh` to update package sources from Git. + Check for any minor version changes. */ -{ makeScopeWithSplicing', generateSplicesForMkScope -, lib, stdenv, fetchurl, fetchgit, fetchpatch, fetchFromGitHub, makeSetupHook, makeWrapper -, bison, cups ? null, harfbuzz, libGL, perl, python3 -, gstreamer, gst-plugins-base, gtk3, dconf -, llvmPackages_15, overrideSDK, overrideLibcxx -, darwin +{ + makeScopeWithSplicing', + generateSplicesForMkScope, + lib, + stdenv, + fetchurl, + fetchgit, + fetchpatch, + fetchFromGitHub, + makeSetupHook, + makeWrapper, + bison, + cups ? null, + harfbuzz, + libGL, + perl, + python3, + gstreamer, + gst-plugins-base, + gtk3, + dconf, + llvmPackages_15, + overrideSDK, + overrideLibcxx, + darwin, # options -, developerBuild ? false -, decryptSslTraffic ? false -, debug ? false -, config + developerBuild ? false, + decryptSslTraffic ? false, + debug ? false, + config, }: let @@ -170,67 +187,84 @@ let hash = "sha256-B/z/+tai01RU/bAJSCp5a0/dGI8g36nwso8MiJv27YM="; }) ]; - qtwebengine = [ - ./qtwebengine-link-pulseaudio.patch - # Fixes Chromium build failure with Ninja 1.12. - # See: https://bugreports.qt.io/browse/QTBUG-124375 - # Backport of: https://code.qt.io/cgit/qt/qtwebengine-chromium.git/commit/?id=a766045f65f934df3b5f1aa63bc86fbb3e003a09 - ./qtwebengine-ninja-1.12.patch - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ./qtwebengine-darwin-no-platform-check.patch - ./qtwebengine-mac-dont-set-dsymutil-path.patch - ./qtwebengine-darwin-checks.patch - ]; - qtwebkit = [ - (fetchpatch { - name = "qtwebkit-python39-json.patch"; - url = "https://github.com/qtwebkit/qtwebkit/commit/78360c01c796b6260bf828bc9c8a0ef73c5132fd.patch"; - sha256 = "yCX/UL666BPxjnxT6rIsUrJsPcSWHhZwMFJfuHhbkhk="; - }) - (fetchpatch { - name = "qtwebkit-bison-3.7-build.patch"; - url = "https://github.com/qtwebkit/qtwebkit/commit/d92b11fea65364fefa700249bd3340e0cd4c5b31.patch"; - sha256 = "0h8ymfnwgkjkwaankr3iifiscsvngqpwb91yygndx344qdiw9y0n"; - }) - (fetchpatch { - name = "qtwebkit-glib-2.68.patch"; - url = "https://github.com/qtwebkit/qtwebkit/pull/1058/commits/5b698ba3faffd4e198a45be9fe74f53307395e4b.patch"; - sha256 = "0a3xv0h4lv8wggckgy8cg8xnpkg7n9h45312pdjdnnwy87xvzss0"; - }) - (fetchpatch { - name = "qtwebkit-darwin-handle.patch"; - url = "https://github.com/qtwebkit/qtwebkit/commit/5c272a21e621a66862821d3ae680f27edcc64c19.patch"; - sha256 = "9hjqLyABz372QDgoq7nXXXQ/3OXBGcYN1/92ekcC3WE="; - }) - (fetchpatch { - name = "qtwebkit-libxml2-api-change.patch"; - url = "https://github.com/WebKit/WebKit/commit/1bad176b2496579d760852c80cff3ad9fb7c3a4b.patch"; - sha256 = "WZEj+UuKhgJBM7auhND3uddk1wWdTY728jtiWVe7CSI="; - }) - ./qtwebkit.patch - ./qtwebkit-icu68.patch - ./qtwebkit-cstdint.patch - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ./qtwebkit-darwin-no-readline.patch - ./qtwebkit-darwin-no-qos-classes.patch - ]; + qtwebengine = + [ + ./qtwebengine-link-pulseaudio.patch + # Fixes Chromium build failure with Ninja 1.12. + # See: https://bugreports.qt.io/browse/QTBUG-124375 + # Backport of: https://code.qt.io/cgit/qt/qtwebengine-chromium.git/commit/?id=a766045f65f934df3b5f1aa63bc86fbb3e003a09 + ./qtwebengine-ninja-1.12.patch + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ./qtwebengine-darwin-no-platform-check.patch + ./qtwebengine-mac-dont-set-dsymutil-path.patch + ./qtwebengine-darwin-checks.patch + ]; + qtwebkit = + [ + (fetchpatch { + name = "qtwebkit-python39-json.patch"; + url = "https://github.com/qtwebkit/qtwebkit/commit/78360c01c796b6260bf828bc9c8a0ef73c5132fd.patch"; + sha256 = "yCX/UL666BPxjnxT6rIsUrJsPcSWHhZwMFJfuHhbkhk="; + }) + (fetchpatch { + name = "qtwebkit-bison-3.7-build.patch"; + url = "https://github.com/qtwebkit/qtwebkit/commit/d92b11fea65364fefa700249bd3340e0cd4c5b31.patch"; + sha256 = "0h8ymfnwgkjkwaankr3iifiscsvngqpwb91yygndx344qdiw9y0n"; + }) + (fetchpatch { + name = "qtwebkit-glib-2.68.patch"; + url = "https://github.com/qtwebkit/qtwebkit/pull/1058/commits/5b698ba3faffd4e198a45be9fe74f53307395e4b.patch"; + sha256 = "0a3xv0h4lv8wggckgy8cg8xnpkg7n9h45312pdjdnnwy87xvzss0"; + }) + (fetchpatch { + name = "qtwebkit-darwin-handle.patch"; + url = "https://github.com/qtwebkit/qtwebkit/commit/5c272a21e621a66862821d3ae680f27edcc64c19.patch"; + sha256 = "9hjqLyABz372QDgoq7nXXXQ/3OXBGcYN1/92ekcC3WE="; + }) + (fetchpatch { + name = "qtwebkit-libxml2-api-change.patch"; + url = "https://github.com/WebKit/WebKit/commit/1bad176b2496579d760852c80cff3ad9fb7c3a4b.patch"; + sha256 = "WZEj+UuKhgJBM7auhND3uddk1wWdTY728jtiWVe7CSI="; + }) + ./qtwebkit.patch + ./qtwebkit-icu68.patch + ./qtwebkit-cstdint.patch + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ./qtwebkit-darwin-no-readline.patch + ./qtwebkit-darwin-no-qos-classes.patch + ]; qttools = [ ./qttools.patch ]; }; - addPackages = self: + addPackages = + self: let qtModule = callPackage ../qtModule.nix { inherit patches; # Use a variant of mkDerivation that does not include wrapQtApplications # to avoid cyclic dependencies between Qt modules. - mkDerivation = - (callPackage ../mkDerivation.nix { wrapQtAppsHook = null; }) stdenv.mkDerivation; + mkDerivation = (callPackage ../mkDerivation.nix { wrapQtAppsHook = null; }) stdenv.mkDerivation; }; - callPackage = self.newScope { inherit qtCompatVersion qtModule srcs stdenv; }; - in { + callPackage = self.newScope { + inherit + qtCompatVersion + qtModule + srcs + stdenv + ; + }; + in + { - inherit callPackage qtCompatVersion qtModule srcs; + inherit + callPackage + qtCompatVersion + qtModule + srcs + ; mkDerivationWith = callPackage ../mkDerivation.nix { }; @@ -239,48 +273,54 @@ let qtbase = callPackage ../modules/qtbase.nix { inherit (srcs.qtbase) src version; patches = patches.qtbase; - inherit bison cups harfbuzz libGL; - withGtk3 = !stdenv.hostPlatform.isDarwin; inherit dconf gtk3; + inherit + bison + cups + harfbuzz + libGL + ; + withGtk3 = !stdenv.hostPlatform.isDarwin; + inherit dconf gtk3; inherit developerBuild decryptSslTraffic; }; - qt3d = callPackage ../modules/qt3d.nix {}; - qtcharts = callPackage ../modules/qtcharts.nix {}; + qt3d = callPackage ../modules/qt3d.nix { }; + qtcharts = callPackage ../modules/qtcharts.nix { }; qtconnectivity = callPackage ../modules/qtconnectivity.nix { }; - qtdatavis3d = callPackage ../modules/qtdatavis3d.nix {}; - qtdeclarative = callPackage ../modules/qtdeclarative.nix {}; - qtdoc = callPackage ../modules/qtdoc.nix {}; + qtdatavis3d = callPackage ../modules/qtdatavis3d.nix { }; + qtdeclarative = callPackage ../modules/qtdeclarative.nix { }; + qtdoc = callPackage ../modules/qtdoc.nix { }; qtgamepad = callPackage ../modules/qtgamepad.nix { }; - qtgraphicaleffects = callPackage ../modules/qtgraphicaleffects.nix {}; - qtimageformats = callPackage ../modules/qtimageformats.nix {}; - qtlocation = callPackage ../modules/qtlocation.nix {}; - qtlottie = callPackage ../modules/qtlottie.nix {}; - qtmacextras = callPackage ../modules/qtmacextras.nix {}; + qtgraphicaleffects = callPackage ../modules/qtgraphicaleffects.nix { }; + qtimageformats = callPackage ../modules/qtimageformats.nix { }; + qtlocation = callPackage ../modules/qtlocation.nix { }; + qtlottie = callPackage ../modules/qtlottie.nix { }; + qtmacextras = callPackage ../modules/qtmacextras.nix { }; qtmultimedia = callPackage ../modules/qtmultimedia.nix { inherit gstreamer gst-plugins-base; }; - qtnetworkauth = callPackage ../modules/qtnetworkauth.nix {}; - qtpim = callPackage ../modules/qtpim.nix {}; - qtpositioning = callPackage ../modules/qtpositioning.nix {}; + qtnetworkauth = callPackage ../modules/qtnetworkauth.nix { }; + qtpim = callPackage ../modules/qtpim.nix { }; + qtpositioning = callPackage ../modules/qtpositioning.nix { }; qtpurchasing = callPackage ../modules/qtpurchasing.nix { }; qtquick1 = null; qtquick3d = callPackage ../modules/qtquick3d.nix { }; - qtquickcontrols = callPackage ../modules/qtquickcontrols.nix {}; - qtquickcontrols2 = callPackage ../modules/qtquickcontrols2.nix {}; - qtremoteobjects = callPackage ../modules/qtremoteobjects.nix {}; - qtscript = callPackage ../modules/qtscript.nix {}; - qtsensors = callPackage ../modules/qtsensors.nix {}; - qtserialbus = callPackage ../modules/qtserialbus.nix {}; - qtserialport = callPackage ../modules/qtserialport.nix {}; - qtspeech = callPackage ../modules/qtspeech.nix {}; - qtsvg = callPackage ../modules/qtsvg.nix {}; - qtsystems = callPackage ../modules/qtsystems.nix {}; - qtscxml = callPackage ../modules/qtscxml.nix {}; - qttools = callPackage ../modules/qttools.nix {}; - qttranslations = callPackage ../modules/qttranslations.nix {}; - qtvirtualkeyboard = callPackage ../modules/qtvirtualkeyboard.nix {}; - qtwayland = callPackage ../modules/qtwayland.nix {}; - qtwebchannel = callPackage ../modules/qtwebchannel.nix {}; + qtquickcontrols = callPackage ../modules/qtquickcontrols.nix { }; + qtquickcontrols2 = callPackage ../modules/qtquickcontrols2.nix { }; + qtremoteobjects = callPackage ../modules/qtremoteobjects.nix { }; + qtscript = callPackage ../modules/qtscript.nix { }; + qtsensors = callPackage ../modules/qtsensors.nix { }; + qtserialbus = callPackage ../modules/qtserialbus.nix { }; + qtserialport = callPackage ../modules/qtserialport.nix { }; + qtspeech = callPackage ../modules/qtspeech.nix { }; + qtsvg = callPackage ../modules/qtsvg.nix { }; + qtsystems = callPackage ../modules/qtsystems.nix { }; + qtscxml = callPackage ../modules/qtscxml.nix { }; + qttools = callPackage ../modules/qttools.nix { }; + qttranslations = callPackage ../modules/qttranslations.nix { }; + qtvirtualkeyboard = callPackage ../modules/qtvirtualkeyboard.nix { }; + qtwayland = callPackage ../modules/qtwayland.nix { }; + qtwebchannel = callPackage ../modules/qtwebchannel.nix { }; qtwebengine = callPackage ../modules/qtwebengine.nix { # The version of Chromium used by Qt WebEngine 5.15.x does not build with clang 16 due # to the following errors: @@ -296,41 +336,83 @@ let inherit (darwin) bootstrap_cmds; python = python3; }; - qtwebglplugin = callPackage ../modules/qtwebglplugin.nix {}; + qtwebglplugin = callPackage ../modules/qtwebglplugin.nix { }; qtwebkit = callPackage ../modules/qtwebkit.nix { }; - qtwebsockets = callPackage ../modules/qtwebsockets.nix {}; + qtwebsockets = callPackage ../modules/qtwebsockets.nix { }; qtwebview = callPackage ../modules/qtwebview.nix { }; - qtx11extras = callPackage ../modules/qtx11extras.nix {}; - qtxmlpatterns = callPackage ../modules/qtxmlpatterns.nix {}; + qtx11extras = callPackage ../modules/qtx11extras.nix { }; + qtxmlpatterns = callPackage ../modules/qtxmlpatterns.nix { }; - env = callPackage ../qt-env.nix {}; - full = callPackage ({ env, qtbase }: env "qt-full-${qtbase.version}") { } - # `with self` is ok to use here because having these spliced is unnecessary - (with self; [ - qt3d qtcharts qtconnectivity qtdeclarative qtdoc qtgraphicaleffects - qtimageformats qtlocation qtmultimedia qtquickcontrols qtquickcontrols2 - qtscript qtsensors qtserialport qtsvg qttools qttranslations - qtvirtualkeyboard qtwebchannel qtwebengine qtwebsockets - qtwebview qtx11extras qtxmlpatterns qtlottie qtdatavis3d - ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) qtwayland - ++ lib.optional (stdenv.hostPlatform.isDarwin) qtmacextras); + env = callPackage ../qt-env.nix { }; + full = + callPackage ({ env, qtbase }: env "qt-full-${qtbase.version}") { } + # `with self` is ok to use here because having these spliced is unnecessary + ( + with self; + [ + qt3d + qtcharts + qtconnectivity + qtdeclarative + qtdoc + qtgraphicaleffects + qtimageformats + qtlocation + qtmultimedia + qtquickcontrols + qtquickcontrols2 + qtscript + qtsensors + qtserialport + qtsvg + qttools + qttranslations + qtvirtualkeyboard + qtwebchannel + qtwebengine + qtwebsockets + qtwebview + qtx11extras + qtxmlpatterns + qtlottie + qtdatavis3d + ] + ++ lib.optional (!stdenv.hostPlatform.isDarwin) qtwayland + ++ lib.optional (stdenv.hostPlatform.isDarwin) qtmacextras + ); - qmake = callPackage ({ qtbase }: makeSetupHook { - name = "qmake-hook"; - ${if stdenv.buildPlatform == stdenv.hostPlatform - then "propagatedBuildInputs" - else "depsTargetTargetPropagated"} = [ qtbase.dev ]; - substitutions = { - inherit debug; - fix_qmake_libtool = ../hooks/fix-qmake-libtool.sh; - }; - } ../hooks/qmake-hook.sh) { }; + qmake = callPackage ( + { qtbase }: + makeSetupHook { + name = "qmake-hook"; + ${ + if stdenv.buildPlatform == stdenv.hostPlatform then + "propagatedBuildInputs" + else + "depsTargetTargetPropagated" + } = + [ qtbase.dev ]; + substitutions = { + inherit debug; + fix_qmake_libtool = ../hooks/fix-qmake-libtool.sh; + }; + } ../hooks/qmake-hook.sh + ) { }; - wrapQtAppsHook = callPackage ({ makeBinaryWrapper, qtbase, qtwayland }: makeSetupHook { - name = "wrap-qt5-apps-hook"; - propagatedBuildInputs = [ qtbase.dev makeBinaryWrapper ] - ++ lib.optional stdenv.hostPlatform.isLinux qtwayland.dev; - } ../hooks/wrap-qt-apps-hook.sh) { }; + wrapQtAppsHook = callPackage ( + { + makeBinaryWrapper, + qtbase, + qtwayland, + }: + makeSetupHook { + name = "wrap-qt5-apps-hook"; + propagatedBuildInputs = [ + qtbase.dev + makeBinaryWrapper + ] ++ lib.optional stdenv.hostPlatform.isLinux qtwayland.dev; + } ../hooks/wrap-qt-apps-hook.sh + ) { }; }; baseScope = makeScopeWithSplicing' { @@ -338,17 +420,20 @@ let f = addPackages; }; - bootstrapScope = baseScope.overrideScope(final: prev: { - qtbase = prev.qtbase.override { qttranslations = null; }; - qtdeclarative = null; - }); + bootstrapScope = baseScope.overrideScope ( + final: prev: { + qtbase = prev.qtbase.override { qttranslations = null; }; + qtdeclarative = null; + } + ); - finalScope = baseScope.overrideScope(final: prev: { - # qttranslations causes eval-time infinite recursion when - # cross-compiling; disabled for now. - qttranslations = - if stdenv.buildPlatform == stdenv.hostPlatform - then bootstrapScope.qttranslations - else null; - }); -in finalScope + finalScope = baseScope.overrideScope ( + final: prev: { + # qttranslations causes eval-time infinite recursion when + # cross-compiling; disabled for now. + qttranslations = + if stdenv.buildPlatform == stdenv.hostPlatform then bootstrapScope.qttranslations else null; + } + ); +in +finalScope diff --git a/pkgs/development/libraries/qt-5/5.15/srcs.nix b/pkgs/development/libraries/qt-5/5.15/srcs.nix index 8de92625f8a510..b94e400bdf7b51 100644 --- a/pkgs/development/libraries/qt-5/5.15/srcs.nix +++ b/pkgs/development/libraries/qt-5/5.15/srcs.nix @@ -1,19 +1,22 @@ -{ lib, fetchgit, fetchFromGitHub }: +{ + lib, + fetchgit, + fetchFromGitHub, +}: let version = "5.15.15"; - mk = name: args: - { - inherit version; - src = fetchgit { - inherit (args) url rev sha256; - fetchLFS = false; - fetchSubmodules = true; - deepClone = false; - leaveDotGit = false; - }; + mk = name: args: { + inherit version; + src = fetchgit { + inherit (args) url rev sha256; + fetchLFS = false; + fetchSubmodules = true; + deepClone = false; + leaveDotGit = false; }; + }; in lib.mapAttrs mk (lib.importJSON ./srcs-generated.json) // { diff --git a/pkgs/development/libraries/qt-5/mkDerivation.nix b/pkgs/development/libraries/qt-5/mkDerivation.nix index a90e229e688d0b..1bcba44204eb03 100644 --- a/pkgs/development/libraries/qt-5/mkDerivation.nix +++ b/pkgs/development/libraries/qt-5/mkDerivation.nix @@ -7,7 +7,7 @@ args: let args_ = { - nativeBuildInputs = (args.nativeBuildInputs or []) ++ [ wrapQtAppsHook ]; + nativeBuildInputs = (args.nativeBuildInputs or [ ]) ++ [ wrapQtAppsHook ]; }; in diff --git a/pkgs/development/libraries/qt-5/modules/qt3d.nix b/pkgs/development/libraries/qt-5/modules/qt3d.nix index c54f4b7d7b48ec..f8fd88c1fc8097 100644 --- a/pkgs/development/libraries/qt-5/modules/qt3d.nix +++ b/pkgs/development/libraries/qt-5/modules/qt3d.nix @@ -1,9 +1,24 @@ -{ lib, stdenv, qtModule, qtbase, qtdeclarative }: +{ + lib, + stdenv, + qtModule, + qtbase, + qtdeclarative, +}: qtModule { pname = "qt3d"; - propagatedBuildInputs = [ qtbase qtdeclarative ]; - outputs = [ "out" "dev" "bin" ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ]; + outputs = [ + "out" + "dev" + "bin" + ]; # error: use of undeclared identifier 'stat64' - env.NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) "-Dstat64=stat"; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 + ) "-Dstat64=stat"; } diff --git a/pkgs/development/libraries/qt-5/modules/qtbase.nix b/pkgs/development/libraries/qt-5/modules/qtbase.nix index 49912da2b1678c..77c435f2e36a2b 100644 --- a/pkgs/development/libraries/qt-5/modules/qtbase.nix +++ b/pkgs/development/libraries/qt-5/modules/qtbase.nix @@ -1,42 +1,91 @@ -{ stdenv, lib -, src, patches, version, qtCompatVersion - -, coreutils, bison, flex, gdb, gperf, lndir, perl, pkg-config, python3 -, which +{ + stdenv, + lib, + src, + patches, + version, + qtCompatVersion, + + coreutils, + bison, + flex, + gdb, + gperf, + lndir, + perl, + pkg-config, + python3, + which, # darwin support -, apple-sdk_13, darwinMinVersionHook, xcbuild - -, dbus, fontconfig, freetype, glib, harfbuzz, icu, libdrm, libX11, libXcomposite -, libXcursor, libXext, libXi, libXrender, libinput, libjpeg, libpng , libxcb -, libxkbcommon, libxml2, libxslt, openssl, pcre2, sqlite, udev, xcbutil -, xcbutilimage, xcbutilkeysyms, xcbutilrenderutil, xcbutilwm , zlib, at-spi2-core + apple-sdk_13, + darwinMinVersionHook, + xcbuild, + + dbus, + fontconfig, + freetype, + glib, + harfbuzz, + icu, + libdrm, + libX11, + libXcomposite, + libXcursor, + libXext, + libXi, + libXrender, + libinput, + libjpeg, + libpng, + libxcb, + libxkbcommon, + libxml2, + libxslt, + openssl, + pcre2, + sqlite, + udev, + xcbutil, + xcbutilimage, + xcbutilkeysyms, + xcbutilrenderutil, + xcbutilwm, + zlib, + at-spi2-core, # optional dependencies -, cups ? null, postgresql ? null -, withGtk3 ? false, dconf, gtk3 -, withQttranslation ? true, qttranslations ? null + cups ? null, + postgresql ? null, + withGtk3 ? false, + dconf, + gtk3, + withQttranslation ? true, + qttranslations ? null, # options -, libGLSupported ? !stdenv.hostPlatform.isDarwin -, libGL + libGLSupported ? !stdenv.hostPlatform.isDarwin, + libGL, # qmake detection for libmysqlclient does not seem to work when cross compiling -, mysqlSupport ? stdenv.hostPlatform == stdenv.buildPlatform -, libmysqlclient -, buildExamples ? false -, buildTests ? false -, debug ? false -, developerBuild ? false -, decryptSslTraffic ? false -, testers -, buildPackages + mysqlSupport ? stdenv.hostPlatform == stdenv.buildPlatform, + libmysqlclient, + buildExamples ? false, + buildTests ? false, + debug ? false, + developerBuild ? false, + decryptSslTraffic ? false, + testers, + buildPackages, }: let debugSymbols = debug || developerBuild; - qtPlatformCross = plat: with plat; - if isLinux - then "linux-generic-g++" - else throw "Please add a qtPlatformCross entry for ${plat.config}"; + qtPlatformCross = + plat: + with plat; + if isLinux then + "linux-generic-g++" + else + throw "Please add a qtPlatformCross entry for ${plat.config}"; # Per https://doc.qt.io/qt-5/macos.html#supported-versions: deployment target = 10.13, build SDK = 13.x or 14.x. # Despite advertising support for the macOS 14 SDK, the build system sets the maximum to 13 and complains @@ -48,395 +97,503 @@ let ]; in -stdenv.mkDerivation (finalAttrs: ({ - pname = "qtbase"; - inherit qtCompatVersion src version; - debug = debugSymbols; - - propagatedBuildInputs = [ - libxml2 libxslt openssl sqlite zlib - - # Text rendering - harfbuzz icu - - # Image formats - libjpeg libpng - pcre2 - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) ( - [ - dbus glib udev - - # Text rendering - fontconfig freetype - - libdrm - - # X11 libs - libX11 libXcomposite libXext libXi libXrender libxcb libxkbcommon xcbutil - xcbutilimage xcbutilkeysyms xcbutilrenderutil xcbutilwm - ] ++ lib.optional libGLSupported libGL - ); - - buildInputs = [ python3 at-spi2-core ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) - ( - [ libinput ] - ++ lib.optional withGtk3 gtk3 - ) - ++ lib.optional stdenv.hostPlatform.isDarwin darwinVersionInputs - ++ lib.optional developerBuild gdb - ++ lib.optional (cups != null) cups - ++ lib.optional (mysqlSupport) libmysqlclient - ++ lib.optional (postgresql != null) postgresql; - - nativeBuildInputs = [ bison flex gperf lndir perl pkg-config which ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ xcbuild ]; - - } // lib.optionalAttrs (stdenv.buildPlatform != stdenv.hostPlatform) { - # `qtbase` expects to find `cc` (with no prefix) in the - # `$PATH`, so the following is needed even if - # `stdenv.buildPlatform.canExecute stdenv.hostPlatform` - depsBuildBuild = [ buildPackages.stdenv.cc ]; - } // { - - propagatedNativeBuildInputs = [ lndir ]; - - # libQt5Core links calls CoreFoundation APIs that call into the system ICU. Binaries linked - # against it will crash during build unless they can access `/usr/share/icu/icudtXXl.dat`. - propagatedSandboxProfile = lib.optionalString stdenv.hostPlatform.isDarwin '' - (allow file-read* (subpath "/usr/share/icu")) - ''; - - enableParallelBuilding = true; - - outputs = [ "bin" "dev" "out" ]; - - inherit patches; - - fix_qt_builtin_paths = ../hooks/fix-qt-builtin-paths.sh; - fix_qt_module_paths = ../hooks/fix-qt-module-paths.sh; - preHook = '' - . "$fix_qt_builtin_paths" - . "$fix_qt_module_paths" - . ${../hooks/move-qt-dev-tools.sh} - . ${../hooks/fix-qmake-libtool.sh} - ''; - - postPatch = '' - for prf in qml_plugin.prf qt_plugin.prf qt_docs.prf qml_module.prf create_cmake.prf; do - substituteInPlace "mkspecs/features/$prf" \ - --subst-var qtPluginPrefix \ - --subst-var qtQmlPrefix \ - --subst-var qtDocPrefix - done - - substituteInPlace configure --replace /bin/pwd pwd - substituteInPlace src/corelib/global/global.pri --replace /bin/ls ${coreutils}/bin/ls - sed -e 's@/\(usr\|opt\)/@/var/empty/@g' -i mkspecs/*/*.conf - - sed -i '/PATHS.*NO_DEFAULT_PATH/ d' src/corelib/Qt5Config.cmake.in - sed -i '/PATHS.*NO_DEFAULT_PATH/ d' src/corelib/Qt5CoreMacros.cmake - sed -i 's/NO_DEFAULT_PATH//' src/gui/Qt5GuiConfigExtras.cmake.in - sed -i '/PATHS.*NO_DEFAULT_PATH/ d' mkspecs/features/data/cmake/Qt5BasicConfig.cmake.in - - # https://bugs.gentoo.org/803470 - sed -i 's/-lpthread/-pthread/' mkspecs/common/linux.conf src/corelib/configure.json - - patchShebangs ./bin - '' + ( - if stdenv.hostPlatform.isDarwin then '' - for file in \ - configure \ - mkspecs/features/mac/asset_catalogs.prf \ - mkspecs/features/mac/default_pre.prf \ - mkspecs/features/mac/sdk.mk \ - mkspecs/features/mac/sdk.prf - do - substituteInPlace "$file" \ - --replace-quiet /usr/bin/xcode-select '${lib.getExe' xcbuild "xcode-select"}' \ - --replace-quiet /usr/bin/xcrun '${lib.getExe' xcbuild "xcrun"}' \ - --replace-quiet /usr/libexec/PlistBuddy '${lib.getExe' xcbuild "PlistBuddy"}' - done - - substituteInPlace configure \ - --replace-fail /System/Library/Frameworks/Cocoa.framework "$SDKROOT/System/Library/Frameworks/Cocoa.framework" - - substituteInPlace mkspecs/common/macx.conf \ - --replace-fail 'CONFIG += ' 'CONFIG += no_default_rpath ' \ - --replace-fail \ - 'QMAKE_MACOSX_DEPLOYMENT_TARGET = 10.13' \ - 'QMAKE_MACOSX_DEPLOYMENT_TARGET = ${deploymentTarget}' - '' else lib.optionalString libGLSupported '' - sed -i mkspecs/common/linux.conf \ - -e "/^QMAKE_INCDIR_OPENGL/ s|$|${lib.getDev libGL}/include|" \ - -e "/^QMAKE_LIBDIR_OPENGL/ s|$|${lib.getLib libGL}/lib|" - '' + lib.optionalString (stdenv.hostPlatform.isx86_32 && stdenv.cc.isGNU) '' - sed -i mkspecs/common/gcc-base-unix.conf \ - -e "/^QMAKE_LFLAGS_SHLIB/ s/-shared/-shared -static-libgcc/" - '' - ); - - qtPluginPrefix = "lib/qt-${qtCompatVersion}/plugins"; - qtQmlPrefix = "lib/qt-${qtCompatVersion}/qml"; - qtDocPrefix = "share/doc/qt-${qtCompatVersion}"; - - setOutputFlags = false; - preConfigure = '' - export LD_LIBRARY_PATH="$PWD/lib:$PWD/plugins/platforms''${LD_LIBRARY_PATH:+:}$LD_LIBRARY_PATH" - - NIX_CFLAGS_COMPILE+=" -DNIXPKGS_QT_PLUGIN_PREFIX=\"$qtPluginPrefix\"" - - # paralellize compilation of qtmake, which happens within ./configure - export MAKEFLAGS+=" -j$NIX_BUILD_CORES" - - ./bin/syncqt.pl -version $version - '' + lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - # QT's configure script will refuse to use pkg-config unless these two environment variables are set - export PKG_CONFIG_SYSROOT_DIR=/ - export PKG_CONFIG_LIBDIR=${lib.getLib pkg-config}/lib - echo "QMAKE_LFLAGS=''${LDFLAGS}" >> mkspecs/devices/${qtPlatformCross stdenv.hostPlatform}/qmake.conf - echo "QMAKE_CFLAGS=''${CFLAGS}" >> mkspecs/devices/${qtPlatformCross stdenv.hostPlatform}/qmake.conf - echo "QMAKE_CXXFLAGS=''${CXXFLAGS}" >> mkspecs/devices/${qtPlatformCross stdenv.hostPlatform}/qmake.conf - ''; - - postConfigure = '' - qmakeCacheInjectNixOutputs() { - local cache="$1/.qmake.stash" - echo "qmakeCacheInjectNixOutputs: $cache" - if ! [ -f "$cache" ]; then - echo >&2 "qmakeCacheInjectNixOutputs: WARNING: $cache does not exist" - fi - cat >>"$cache" <> mkspecs/devices/${qtPlatformCross stdenv.hostPlatform}/qmake.conf + echo "QMAKE_CFLAGS=''${CFLAGS}" >> mkspecs/devices/${qtPlatformCross stdenv.hostPlatform}/qmake.conf + echo "QMAKE_CXXFLAGS=''${CXXFLAGS}" >> mkspecs/devices/${qtPlatformCross stdenv.hostPlatform}/qmake.conf + ''; + + postConfigure = '' + qmakeCacheInjectNixOutputs() { + local cache="$1/.qmake.stash" + echo "qmakeCacheInjectNixOutputs: $cache" + if ! [ -f "$cache" ]; then + echo >&2 "qmakeCacheInjectNixOutputs: WARNING: $cache does not exist" + fi + cat >>"$cache" <> src/core/config/mac_osx.pri + echo "LIBS += -lavformat -lavcodec -lavutil" >> src/core/core_common.pri + '') + + postPatch; + + env = + { + NIX_CFLAGS_COMPILE = toString ( + lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + "-w " + ] + ++ lib.optionals stdenv.cc.isGNU [ + # with gcc8, -Wclass-memaccess became part of -Wall and this exceeds the logging limit + "-Wno-class-memaccess" + ] + ++ lib.optionals (stdenv.hostPlatform.gcc.arch or "" == "sandybridge") [ + # it fails when compiled with -march=sandybridge https://github.com/NixOS/nixpkgs/pull/59148#discussion_r276696940 + # TODO: investigate and fix properly + "-march=westmere" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-elaborated-enum-base" + ] + ); } - patch -p1 < ${ - (fetchpatch { # support for building with python 3.12 - name = "python312-six.patch"; - url = "https://gitlab.archlinux.org/archlinux/packaging/packages/qt5-webengine/-/raw/6b0c0e76e0934db2f84be40cb5978cee47266e78/python3.12-six.patch"; - hash = "sha256-YgP9Sq5+zTC+U7+0hQjZokwb+fytk0UEIJztUXFhTkI="; - }) - } - - # Manually fix unsupported shebangs - substituteInPlace third_party/harfbuzz-ng/src/src/update-unicode-tables.make \ - --replace "/usr/bin/env -S make -f" "/usr/bin/make -f" || true - - # TODO: be more precise - patchShebangs . - ) - '' - # Prevent Chromium build script from making the path to `clang` relative to - # the build directory. `clang_base_path` is the value of `QMAKE_CLANG_DIR` - # from `src/core/config/mac_osx.pri`. - + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace ./src/3rdparty/chromium/build/toolchain/mac/BUILD.gn \ - --replace 'prefix = rebase_path("$clang_base_path/bin/", root_build_dir)' 'prefix = "$clang_base_path/bin/"' - '' - # Patch library paths in Qt sources - + '' - sed -i \ - -e "s,QLibraryInfo::location(QLibraryInfo::DataPath),QLatin1String(\"$out\"),g" \ - -e "s,QLibraryInfo::location(QLibraryInfo::TranslationsPath),QLatin1String(\"$out/translations\"),g" \ - -e "s,QLibraryInfo::location(QLibraryInfo::LibraryExecutablesPath),QLatin1String(\"$out/libexec\"),g" \ - src/core/web_engine_library_info.cpp - '' - # Patch library paths in Chromium sources - + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - sed -i -e '/lib_loader.*Load/s!"\(libudev\.so\)!"${lib.getLib systemd}/lib/\1!' \ - src/3rdparty/chromium/device/udev_linux/udev?_loader.cc - - sed -i -e '/libpci_loader.*Load/s!"\(libpci\.so\)!"${pciutils}/lib/\1!' \ - src/3rdparty/chromium/gpu/config/gpu_info_collector_linux.cc - '' + lib.optionalString stdenv.hostPlatform.isDarwin ('' - substituteInPlace src/buildtools/config/mac_osx.pri \ - --replace 'QMAKE_CLANG_DIR = "/usr"' 'QMAKE_CLANG_DIR = "${stdenv.cc}"' - - # Use system ffmpeg - echo "gn_args += use_system_ffmpeg=true" >> src/core/config/mac_osx.pri - echo "LIBS += -lavformat -lavcodec -lavutil" >> src/core/core_common.pri - '') + postPatch; - - env = { - NIX_CFLAGS_COMPILE = - toString ( - lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ - "-w " - ] ++ lib.optionals stdenv.cc.isGNU [ - # with gcc8, -Wclass-memaccess became part of -Wall and this exceeds the logging limit - "-Wno-class-memaccess" - ] ++ lib.optionals (stdenv.hostPlatform.gcc.arch or "" == "sandybridge") [ - # it fails when compiled with -march=sandybridge https://github.com/NixOS/nixpkgs/pull/59148#discussion_r276696940 - # TODO: investigate and fix properly - "-march=westmere" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-elaborated-enum-base" - ]); - } // lib.optionalAttrs (stdenv.buildPlatform != stdenv.hostPlatform) { - NIX_CFLAGS_LINK = "-Wl,--no-warn-search-mismatch"; - "NIX_CFLAGS_LINK_${buildPackages.stdenv.cc.suffixSalt}" = "-Wl,--no-warn-search-mismatch"; - }; - - preConfigure = '' - export NINJAFLAGS=-j$NIX_BUILD_CORES - - if [ -d "$PWD/tools/qmake" ]; then - QMAKEPATH="$PWD/tools/qmake''${QMAKEPATH:+:}$QMAKEPATH" - fi - '' + lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' - export QMAKE_CC=$CC - export QMAKE_CXX=$CXX - export QMAKE_LINK=$CXX - export QMAKE_AR=$AR - ''; - - qmakeFlags = [ "--" "-system-ffmpeg" ] - ++ lib.optional (pipewireSupport && stdenv.buildPlatform == stdenv.hostPlatform) "-webengine-webrtc-pipewire" - ++ lib.optional enableProprietaryCodecs "-proprietary-codecs"; - - propagatedBuildInputs = [ - qtdeclarative qtquickcontrols qtlocation qtwebchannel - - # Image formats - libjpeg libpng libtiff libwebp - - # Video formats - srtp libvpx - - # Audio formats - libopus - - # Text rendering - harfbuzz icu - - libevent - ffmpeg - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - dbus zlib minizip snappy nss protobuf jsoncpp - - # Audio formats - alsa-lib - pulseaudio - - # Text rendering - fontconfig freetype - - libcap - pciutils - - # X11 libs - xorg.xrandr libXScrnSaver libXcursor libXrandr xorg.libpciaccess libXtst - xorg.libXcomposite xorg.libXdamage libdrm xorg.libxkbfile - - ] ++ lib.optionals pipewireSupport [ - # Pipewire - pipewire - ] - - # FIXME These dependencies shouldn't be needed but can't find a way - # around it. Chromium pulls this in while bootstrapping GN. - ++ lib.optionals stdenv.hostPlatform.isDarwin [ cctools.libtool ]; - - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - cups - - # `sw_vers` is used by `src/3rdparty/chromium/build/config/mac/sdk_info.py` - # to get some information about the host platform. - (writeScriptBin "sw_vers" '' - #!${stdenv.shell} - - while [ $# -gt 0 ]; do - case "$1" in - -buildVersion) echo "17E199";; - *) break ;; - - esac - shift - done - '') - ]; - - dontUseNinjaBuild = true; - dontUseNinjaInstall = true; - - postInstall = lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' - mkdir -p $out/libexec - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - cat > $out/libexec/qt.conf < $out/libexec/qt.conf </dev/null \ - && ! grep -q -F "''${version%%-*}" .qmake.conf 2>/dev/null - then - echo >&2 "error: could not find version ''${version%%-*} in .qmake.conf" - echo >&2 "hint: check .qmake.conf and update the package version in Nixpkgs" - exit 1 - fi - - if [[ -z "$dontSyncQt" && -f sync.profile ]]; then - syncqt.pl -version "''${version%%-*}" - fi - ''; - - dontWrapQtApps = args.dontWrapQtApps or true; - - postFixup = '' - if [ -d "''${!outputDev}/lib/pkgconfig" ]; then - find "''${!outputDev}/lib/pkgconfig" -name '*.pc' | while read pc; do - sed -i "$pc" \ - -e "/^prefix=/ c prefix=''${!outputLib}" \ - -e "/^exec_prefix=/ c exec_prefix=''${!outputBin}" \ - -e "/^includedir=/ c includedir=''${!outputDev}/include" - done - fi - - moveQtDevTools - - ${args.postFixup or ""} - ''; - - meta = { - homepage = "https://www.qt.io"; - description = "Cross-platform application framework for C++"; - license = with licenses; [ fdl13Plus gpl2Plus lgpl21Plus lgpl3Plus ]; - maintainers = with maintainers; [ qknight ttuegel periklis bkchr ]; - platforms = platforms.unix; - } // (args.meta or {}); -}) +mkDerivation ( + args + // { + inherit pname version src; + patches = (args.patches or [ ]) ++ (patches.${pname} or [ ]); + + buildInputs = + args.buildInputs or [ ] + # Per https://doc.qt.io/qt-5/macos.html#supported-versions + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + apple-sdk_13 + (darwinMinVersionHook "10.13") + ]; + + nativeBuildInputs = + (args.nativeBuildInputs or [ ]) + ++ [ + perl + qmake + ] + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ + pkgsHostTarget.qt5.qtbase.dev + ]; + propagatedBuildInputs = + (lib.warnIf (args ? qtInputs) "qt5.qtModule's qtInputs argument is deprecated" args.qtInputs or [ ]) + ++ (args.propagatedBuildInputs or [ ]); + } + // lib.optionalAttrs (stdenv.buildPlatform != stdenv.hostPlatform) { + depsBuildBuild = [ buildPackages.stdenv.cc ] ++ (args.depsBuildBuild or [ ]); + } + // { + + outputs = + args.outputs or [ + "out" + "dev" + ]; + setOutputFlags = args.setOutputFlags or false; + + preHook = '' + . ${./hooks/move-qt-dev-tools.sh} + . ${./hooks/fix-qt-builtin-paths.sh} + ''; + + preConfigure = + '' + ${args.preConfigure or ""} + + fixQtBuiltinPaths . '*.pr?' + '' + + + lib.optionalString (builtins.compareVersions "5.15.0" version <= 0) + # Note: We use ${version%%-*} to remove any tag from the end of the version + # string. Version tags are added by Nixpkgs maintainers and not reflected in + # the source version. + '' + if [[ -z "$dontCheckQtModuleVersion" ]] \ + && grep -q '^MODULE_VERSION' .qmake.conf 2>/dev/null \ + && ! grep -q -F "''${version%%-*}" .qmake.conf 2>/dev/null + then + echo >&2 "error: could not find version ''${version%%-*} in .qmake.conf" + echo >&2 "hint: check .qmake.conf and update the package version in Nixpkgs" + exit 1 + fi + + if [[ -z "$dontSyncQt" && -f sync.profile ]]; then + syncqt.pl -version "''${version%%-*}" + fi + ''; + + dontWrapQtApps = args.dontWrapQtApps or true; + + postFixup = '' + if [ -d "''${!outputDev}/lib/pkgconfig" ]; then + find "''${!outputDev}/lib/pkgconfig" -name '*.pc' | while read pc; do + sed -i "$pc" \ + -e "/^prefix=/ c prefix=''${!outputLib}" \ + -e "/^exec_prefix=/ c exec_prefix=''${!outputBin}" \ + -e "/^includedir=/ c includedir=''${!outputDev}/include" + done + fi + + moveQtDevTools + + ${args.postFixup or ""} + ''; + + meta = { + homepage = "https://www.qt.io"; + description = "Cross-platform application framework for C++"; + license = with licenses; [ + fdl13Plus + gpl2Plus + lgpl21Plus + lgpl3Plus + ]; + maintainers = with maintainers; [ + qknight + ttuegel + periklis + bkchr + ]; + platforms = platforms.unix; + } // (args.meta or { }); + } +) diff --git a/pkgs/development/libraries/qt-6/default.nix b/pkgs/development/libraries/qt-6/default.nix index 96a498c5f195fb..bfa2de2e529abc 100644 --- a/pkgs/development/libraries/qt-6/default.nix +++ b/pkgs/development/libraries/qt-6/default.nix @@ -1,21 +1,22 @@ -{ newScope -, lib -, stdenv -, generateSplicesForMkScope -, makeScopeWithSplicing' -, fetchurl -, fetchpatch2 -, makeSetupHook -, makeWrapper -, runCommand -, gst_all_1 -, libglvnd -, darwin -, apple-sdk_15 -, darwinMinVersionHook -, buildPackages -, python3 -, config +{ + newScope, + lib, + stdenv, + generateSplicesForMkScope, + makeScopeWithSplicing', + fetchurl, + fetchpatch2, + makeSetupHook, + makeWrapper, + runCommand, + gst_all_1, + libglvnd, + darwin, + apple-sdk_15, + darwinMinVersionHook, + buildPackages, + python3, + config, }: let @@ -24,7 +25,8 @@ let mirror = "mirror://qt"; }; - addPackages = self: + addPackages = + self: let callPackage = self.newScope ({ inherit (self) qtModule; @@ -39,14 +41,17 @@ let (darwinMinVersionHook "12.0") ]; - onlyPluginsAndQml = drv: let - drv' = drv.__spliced.targetTarget or drv; - inherit (self.qtbase) qtPluginPrefix qtQmlPrefix; - in (runCommand "${drv'.name}-only-plugins-qml" { } '' + onlyPluginsAndQml = + drv: + let + drv' = drv.__spliced.targetTarget or drv; + inherit (self.qtbase) qtPluginPrefix qtQmlPrefix; + in + (runCommand "${drv'.name}-only-plugins-qml" { } '' mkdir -p $(dirname "$out/${qtPluginPrefix}") test -d "${drv'}/${qtPluginPrefix}" && ln -s "${drv'}/${qtPluginPrefix}" "$out/${qtPluginPrefix}" || true test -d "${drv'}/${qtQmlPrefix}" && ln -s "${drv'}/${qtQmlPrefix}" "$out/${qtQmlPrefix}" || true - ''); + ''); in { @@ -86,49 +91,57 @@ let ]; }; env = callPackage ./qt-env.nix { }; - full = callPackage - ({ env, qtbase }: env "qt-full-${qtbase.version}" + full = callPackage ( + { env, qtbase }: + env "qt-full-${qtbase.version}" # `with self` is ok to use here because having these spliced is unnecessary - (with self;[ - qt3d - qt5compat - qtcharts - qtconnectivity - qtdatavis3d - qtdeclarative - qtdoc - qtgraphs - qtgrpc - qthttpserver - qtimageformats - qtlanguageserver - qtlocation - qtlottie - qtmultimedia - qtmqtt - qtnetworkauth - qtpositioning - qtsensors - qtserialbus - qtserialport - qtshadertools - qtspeech - qtquick3d - qtquick3dphysics - qtquickeffectmaker - qtquicktimeline - qtremoteobjects - qtsvg - qtscxml - qttools - qttranslations - qtvirtualkeyboard - qtwebchannel - qtwebengine - qtwebsockets - qtwebview - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ qtwayland libglvnd ])) - { }; + ( + with self; + [ + qt3d + qt5compat + qtcharts + qtconnectivity + qtdatavis3d + qtdeclarative + qtdoc + qtgraphs + qtgrpc + qthttpserver + qtimageformats + qtlanguageserver + qtlocation + qtlottie + qtmultimedia + qtmqtt + qtnetworkauth + qtpositioning + qtsensors + qtserialbus + qtserialport + qtshadertools + qtspeech + qtquick3d + qtquick3dphysics + qtquickeffectmaker + qtquicktimeline + qtremoteobjects + qtsvg + qtscxml + qttools + qttranslations + qtvirtualkeyboard + qtwebchannel + qtwebengine + qtwebsockets + qtwebview + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + qtwayland + libglvnd + ] + ) + ) { }; qt3d = callPackage ./modules/qt3d.nix { }; qt5compat = callPackage ./modules/qt5compat.nix { }; @@ -145,7 +158,13 @@ let qtlocation = callPackage ./modules/qtlocation.nix { }; qtlottie = callPackage ./modules/qtlottie.nix { }; qtmultimedia = callPackage ./modules/qtmultimedia.nix { - inherit (gst_all_1) gstreamer gst-plugins-base gst-plugins-good gst-libav gst-vaapi; + inherit (gst_all_1) + gstreamer + gst-plugins-base + gst-plugins-good + gst-libav + gst-vaapi + ; }; qtmqtt = callPackage ./modules/qtmqtt.nix { }; qtnetworkauth = callPackage ./modules/qtnetworkauth.nix { }; @@ -173,41 +192,46 @@ let qtwebsockets = callPackage ./modules/qtwebsockets.nix { }; qtwebview = callPackage ./modules/qtwebview.nix { }; - wrapQtAppsHook = callPackage - ({ makeBinaryWrapper, qtwayland, qtbase }: - makeSetupHook - { - name = "wrap-qt6-apps-hook"; - propagatedBuildInputs = [ makeBinaryWrapper ]; - depsTargetTargetPropagated = [ + wrapQtAppsHook = callPackage ( + { + makeBinaryWrapper, + qtwayland, + qtbase, + }: + makeSetupHook { + name = "wrap-qt6-apps-hook"; + propagatedBuildInputs = [ makeBinaryWrapper ]; + depsTargetTargetPropagated = + [ (onlyPluginsAndQml qtbase) - ] ++ lib.optionals (lib.meta.availableOn stdenv.targetPlatform qtwayland) [ + ] + ++ lib.optionals (lib.meta.availableOn stdenv.targetPlatform qtwayland) [ (onlyPluginsAndQml qtwayland) ]; - } ./hooks/wrap-qt-apps-hook.sh) - { }; + } ./hooks/wrap-qt-apps-hook.sh + ) { }; - wrapQtAppsNoGuiHook = callPackage - ({ makeBinaryWrapper, qtbase }: makeSetupHook - { - name = "wrap-qt6-apps-no-gui-hook"; - propagatedBuildInputs = [ makeBinaryWrapper ]; - depsTargetTargetPropagated = [ - (onlyPluginsAndQml qtbase) - ]; - } ./hooks/wrap-qt-apps-hook.sh) - { }; + wrapQtAppsNoGuiHook = callPackage ( + { makeBinaryWrapper, qtbase }: + makeSetupHook { + name = "wrap-qt6-apps-no-gui-hook"; + propagatedBuildInputs = [ makeBinaryWrapper ]; + depsTargetTargetPropagated = [ + (onlyPluginsAndQml qtbase) + ]; + } ./hooks/wrap-qt-apps-hook.sh + ) { }; - qmake = callPackage - ({ qtbase }: makeSetupHook - { - name = "qmake6-hook"; - propagatedBuildInputs = [ qtbase.dev ]; - substitutions = { - fix_qmake_libtool = ./hooks/fix-qmake-libtool.sh; - }; - } ./hooks/qmake-hook.sh) - { }; + qmake = callPackage ( + { qtbase }: + makeSetupHook { + name = "qmake6-hook"; + propagatedBuildInputs = [ qtbase.dev ]; + substitutions = { + fix_qmake_libtool = ./hooks/fix-qmake-libtool.sh; + }; + } ./hooks/qmake-hook.sh + ) { }; }; baseScope = makeScopeWithSplicing' { @@ -215,13 +239,17 @@ let f = addPackages; }; - bootstrapScope = baseScope.overrideScope (final: prev: { - qtbase = prev.qtbase.override { qttranslations = null; }; - qtdeclarative = null; - }); + bootstrapScope = baseScope.overrideScope ( + final: prev: { + qtbase = prev.qtbase.override { qttranslations = null; }; + qtdeclarative = null; + } + ); - finalScope = baseScope.overrideScope (final: prev: { - qttranslations = bootstrapScope.qttranslations; - }); + finalScope = baseScope.overrideScope ( + final: prev: { + qttranslations = bootstrapScope.qttranslations; + } + ); in finalScope diff --git a/pkgs/development/libraries/qt-6/modules/qt3d.nix b/pkgs/development/libraries/qt-6/modules/qt3d.nix index f1df7f6fc254fb..4260bf3979a486 100644 --- a/pkgs/development/libraries/qt-6/modules/qt3d.nix +++ b/pkgs/development/libraries/qt-6/modules/qt3d.nix @@ -1,11 +1,17 @@ -{ qtModule -, qtbase -, qtdeclarative -, qtmultimedia -, assimp +{ + qtModule, + qtbase, + qtdeclarative, + qtmultimedia, + assimp, }: qtModule { pname = "qt3d"; - propagatedBuildInputs = [ qtbase qtdeclarative qtmultimedia assimp ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + qtmultimedia + assimp + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qt5compat.nix b/pkgs/development/libraries/qt-6/modules/qt5compat.nix index d2049d7fc3e5b4..333f66e16a33de 100644 --- a/pkgs/development/libraries/qt-6/modules/qt5compat.nix +++ b/pkgs/development/libraries/qt-6/modules/qt5compat.nix @@ -1,13 +1,21 @@ -{ qtModule -, qtbase -, qtdeclarative -, libiconv -, icu -, openssl +{ + qtModule, + qtbase, + qtdeclarative, + libiconv, + icu, + openssl, }: qtModule { pname = "qt5compat"; - propagatedBuildInputs = [ qtbase qtdeclarative ]; - buildInputs = [ libiconv icu openssl ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ]; + buildInputs = [ + libiconv + icu + openssl + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtbase.nix b/pkgs/development/libraries/qt-6/modules/qtbase.nix index 9df79ccc89be89..90a09ad165f123 100644 --- a/pkgs/development/libraries/qt-6/modules/qtbase.nix +++ b/pkgs/development/libraries/qt-6/modules/qtbase.nix @@ -1,87 +1,88 @@ -{ stdenv -, lib -, src -, patches ? [ ] -, version -, bison -, flex -, gperf -, lndir -, perl -, pkg-config -, which -, cmake -, ninja -, xmlstarlet -, libproxy -, xorg -, zstd -, double-conversion -, util-linux -, systemd -, systemdSupport ? stdenv.hostPlatform.isLinux -, libb2 -, md4c -, mtdev -, lksctp-tools -, libselinux -, libsepol -, vulkan-headers -, vulkan-loader -, libthai -, libdrm -, libdatrie -, lttng-ust -, libepoxy -, dbus -, fontconfig -, freetype -, glib -, harfbuzz -, icu -, libX11 -, libXcomposite -, libXext -, libXi -, libXrender -, libinput -, libjpeg -, libpng -, libxcb -, libxkbcommon -, libxml2 -, libxslt -, openssl -, pcre -, pcre2 -, sqlite -, udev -, xcbutil -, xcbutilimage -, xcbutilkeysyms -, xcbutilrenderutil -, xcbutilwm -, zlib -, at-spi2-core -, unixODBC -, unixODBCDrivers +{ + stdenv, + lib, + src, + patches ? [ ], + version, + bison, + flex, + gperf, + lndir, + perl, + pkg-config, + which, + cmake, + ninja, + xmlstarlet, + libproxy, + xorg, + zstd, + double-conversion, + util-linux, + systemd, + systemdSupport ? stdenv.hostPlatform.isLinux, + libb2, + md4c, + mtdev, + lksctp-tools, + libselinux, + libsepol, + vulkan-headers, + vulkan-loader, + libthai, + libdrm, + libdatrie, + lttng-ust, + libepoxy, + dbus, + fontconfig, + freetype, + glib, + harfbuzz, + icu, + libX11, + libXcomposite, + libXext, + libXi, + libXrender, + libinput, + libjpeg, + libpng, + libxcb, + libxkbcommon, + libxml2, + libxslt, + openssl, + pcre, + pcre2, + sqlite, + udev, + xcbutil, + xcbutilimage, + xcbutilkeysyms, + xcbutilrenderutil, + xcbutilwm, + zlib, + at-spi2-core, + unixODBC, + unixODBCDrivers, # darwin -, moveBuildTree -, darwinVersionInputs -, xcbuild + moveBuildTree, + darwinVersionInputs, + xcbuild, # mingw -, pkgsBuildBuild + pkgsBuildBuild, # optional dependencies -, cups -, libmysqlclient -, postgresql -, withGtk3 ? false -, dconf -, gtk3 + cups, + libmysqlclient, + postgresql, + withGtk3 ? false, + dconf, + gtk3, # options -, libGLSupported ? stdenv.hostPlatform.isLinux -, libGL -, qttranslations ? null + libGLSupported ? stdenv.hostPlatform.isLinux, + libGL, + qttranslations ? null, }: let @@ -92,88 +93,111 @@ stdenv.mkDerivation rec { inherit src version; - propagatedBuildInputs = [ - libxml2 - libxslt - openssl - sqlite - zlib - # Text rendering - harfbuzz - icu - # Image formats - libjpeg - libpng - pcre2 - pcre - zstd - libb2 - md4c - double-conversion - ] ++ lib.optionals (!stdenv.hostPlatform.isMinGW) [ - libproxy - dbus - glib - # unixODBC drivers - unixODBC - unixODBCDrivers.psql - unixODBCDrivers.sqlite - unixODBCDrivers.mariadb - ] ++ lib.optionals systemdSupport [ - systemd - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - util-linux - mtdev - lksctp-tools - libselinux - libsepol - lttng-ust - vulkan-headers - vulkan-loader - libthai - libdrm - libdatrie - udev - # Text rendering - fontconfig - freetype - # X11 libs - libX11 - libXcomposite - libXext - libXi - libXrender - libxcb - libxkbcommon - xcbutil - xcbutilimage - xcbutilkeysyms - xcbutilrenderutil - xcbutilwm - xorg.libXdmcp - xorg.libXtst - xorg.xcbutilcursor - libepoxy - ] ++ lib.optionals libGLSupported [ - libGL - ] ++ lib.optionals stdenv.hostPlatform.isMinGW [ - vulkan-headers - vulkan-loader - ] ++ lib.optional (cups != null && lib.meta.availableOn stdenv.hostPlatform cups) cups; + propagatedBuildInputs = + [ + libxml2 + libxslt + openssl + sqlite + zlib + # Text rendering + harfbuzz + icu + # Image formats + libjpeg + libpng + pcre2 + pcre + zstd + libb2 + md4c + double-conversion + ] + ++ lib.optionals (!stdenv.hostPlatform.isMinGW) [ + libproxy + dbus + glib + # unixODBC drivers + unixODBC + unixODBCDrivers.psql + unixODBCDrivers.sqlite + unixODBCDrivers.mariadb + ] + ++ lib.optionals systemdSupport [ + systemd + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + util-linux + mtdev + lksctp-tools + libselinux + libsepol + lttng-ust + vulkan-headers + vulkan-loader + libthai + libdrm + libdatrie + udev + # Text rendering + fontconfig + freetype + # X11 libs + libX11 + libXcomposite + libXext + libXi + libXrender + libxcb + libxkbcommon + xcbutil + xcbutilimage + xcbutilkeysyms + xcbutilrenderutil + xcbutilwm + xorg.libXdmcp + xorg.libXtst + xorg.xcbutilcursor + libepoxy + ] + ++ lib.optionals libGLSupported [ + libGL + ] + ++ lib.optionals stdenv.hostPlatform.isMinGW [ + vulkan-headers + vulkan-loader + ] + ++ lib.optional (cups != null && lib.meta.availableOn stdenv.hostPlatform cups) cups; - buildInputs = lib.optionals (lib.meta.availableOn stdenv.hostPlatform at-spi2-core) [ - at-spi2-core - ] ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform libinput) [ - libinput - ] ++ lib.optionals stdenv.hostPlatform.isDarwin darwinVersionInputs - ++ lib.optional withGtk3 gtk3 - ++ lib.optional (libmysqlclient != null && !stdenv.hostPlatform.isMinGW) libmysqlclient - ++ lib.optional (postgresql != null && lib.meta.availableOn stdenv.hostPlatform postgresql) postgresql; + buildInputs = + lib.optionals (lib.meta.availableOn stdenv.hostPlatform at-spi2-core) [ + at-spi2-core + ] + ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform libinput) [ + libinput + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin darwinVersionInputs + ++ lib.optional withGtk3 gtk3 + ++ lib.optional (libmysqlclient != null && !stdenv.hostPlatform.isMinGW) libmysqlclient + ++ lib.optional ( + postgresql != null && lib.meta.availableOn stdenv.hostPlatform postgresql + ) postgresql; - nativeBuildInputs = [ bison flex gperf lndir perl pkg-config which cmake xmlstarlet ninja ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ moveBuildTree ]; + nativeBuildInputs = [ + bison + flex + gperf + lndir + perl + pkg-config + which + cmake + xmlstarlet + ninja + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ moveBuildTree ]; - propagatedNativeBuildInputs = [ lndir ] + propagatedNativeBuildInputs = + [ lndir ] # I’m not sure if this is necessary, but the macOS mkspecs stuff # tries to call `xcrun xcodebuild`, so better safe than sorry. ++ lib.optionals stdenv.hostPlatform.isDarwin [ xcbuild ]; @@ -215,41 +239,52 @@ stdenv.mkDerivation rec { qtPluginPrefix = "lib/qt-6/plugins"; qtQmlPrefix = "lib/qt-6/qml"; - cmakeFlags = [ - "-DQT_EMBED_TOOLCHAIN_COMPILER=OFF" - "-DINSTALL_PLUGINSDIR=${qtPluginPrefix}" - "-DINSTALL_QMLDIR=${qtQmlPrefix}" - "-DQT_FEATURE_libproxy=ON" - "-DQT_FEATURE_system_sqlite=ON" - "-DQT_FEATURE_openssl_linked=ON" - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - "-DQT_FEATURE_sctp=ON" - "-DQT_FEATURE_journald=${if systemdSupport then "ON" else "OFF"}" - "-DQT_FEATURE_vulkan=ON" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DQT_FEATURE_rpath=OFF" - ] ++ lib.optionals isCrossBuild [ - "-DQT_HOST_PATH=${pkgsBuildBuild.qt6.qtbase}" - "-DQt6HostInfo_DIR=${pkgsBuildBuild.qt6.qtbase}/lib/cmake/Qt6HostInfo" - ] - ++ lib.optional (qttranslations != null && !isCrossBuild) "-DINSTALL_TRANSLATIONSDIR=${qttranslations}/translations"; + cmakeFlags = + [ + "-DQT_EMBED_TOOLCHAIN_COMPILER=OFF" + "-DINSTALL_PLUGINSDIR=${qtPluginPrefix}" + "-DINSTALL_QMLDIR=${qtQmlPrefix}" + "-DQT_FEATURE_libproxy=ON" + "-DQT_FEATURE_system_sqlite=ON" + "-DQT_FEATURE_openssl_linked=ON" + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + "-DQT_FEATURE_sctp=ON" + "-DQT_FEATURE_journald=${if systemdSupport then "ON" else "OFF"}" + "-DQT_FEATURE_vulkan=ON" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DQT_FEATURE_rpath=OFF" + ] + ++ lib.optionals isCrossBuild [ + "-DQT_HOST_PATH=${pkgsBuildBuild.qt6.qtbase}" + "-DQt6HostInfo_DIR=${pkgsBuildBuild.qt6.qtbase}/lib/cmake/Qt6HostInfo" + ] + ++ lib.optional ( + qttranslations != null && !isCrossBuild + ) "-DINSTALL_TRANSLATIONSDIR=${qttranslations}/translations"; env.NIX_CFLAGS_COMPILE = "-DNIXPKGS_QT_PLUGIN_PREFIX=\"${qtPluginPrefix}\""; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; separateDebugInfo = true; moveToDev = false; - postFixup = '' - moveToOutput "mkspecs/modules" "$dev" - fixQtModulePaths "$dev/mkspecs/modules" - fixQtBuiltinPaths "$out" '*.pr?' - '' + lib.optionalString stdenv.hostPlatform.isLinux '' + postFixup = + '' + moveToOutput "mkspecs/modules" "$dev" + fixQtModulePaths "$dev/mkspecs/modules" + fixQtBuiltinPaths "$out" '*.pr?' + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' - # FIXME: not sure why this isn't added automatically? - patchelf --add-rpath "${libmysqlclient}/lib/mariadb" $out/${qtPluginPrefix}/sqldrivers/libqsqlmysql.so - ''; + # FIXME: not sure why this isn't added automatically? + patchelf --add-rpath "${libmysqlclient}/lib/mariadb" $out/${qtPluginPrefix}/sqldrivers/libqsqlmysql.so + ''; dontWrapQtApps = true; @@ -258,8 +293,17 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://www.qt.io/"; description = "Cross-platform application framework for C++"; - license = with licenses; [ fdl13Plus gpl2Plus lgpl21Plus lgpl3Plus ]; - maintainers = with maintainers; [ milahu nickcao LunNova ]; + license = with licenses; [ + fdl13Plus + gpl2Plus + lgpl21Plus + lgpl3Plus + ]; + maintainers = with maintainers; [ + milahu + nickcao + LunNova + ]; platforms = platforms.unix ++ platforms.windows; }; } diff --git a/pkgs/development/libraries/qt-6/modules/qtcharts.nix b/pkgs/development/libraries/qt-6/modules/qtcharts.nix index e9b6c8d6b33fad..8701933d9bd903 100644 --- a/pkgs/development/libraries/qt-6/modules/qtcharts.nix +++ b/pkgs/development/libraries/qt-6/modules/qtcharts.nix @@ -1,9 +1,13 @@ -{ qtModule -, qtbase -, qtdeclarative +{ + qtModule, + qtbase, + qtdeclarative, }: qtModule { pname = "qtcharts"; - propagatedBuildInputs = [ qtbase qtdeclarative ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtconnectivity.nix b/pkgs/development/libraries/qt-6/modules/qtconnectivity.nix index 8a48c84904352b..627454f85a517c 100644 --- a/pkgs/development/libraries/qt-6/modules/qtconnectivity.nix +++ b/pkgs/development/libraries/qt-6/modules/qtconnectivity.nix @@ -1,10 +1,11 @@ -{ qtModule -, lib -, stdenv -, qtbase -, qtdeclarative -, bluez -, pkg-config +{ + qtModule, + lib, + stdenv, + qtbase, + qtdeclarative, + bluez, + pkg-config, }: qtModule { diff --git a/pkgs/development/libraries/qt-6/modules/qtdatavis3d.nix b/pkgs/development/libraries/qt-6/modules/qtdatavis3d.nix index e6c12508c9d0ff..4e3eca80a9ed48 100644 --- a/pkgs/development/libraries/qt-6/modules/qtdatavis3d.nix +++ b/pkgs/development/libraries/qt-6/modules/qtdatavis3d.nix @@ -1,9 +1,13 @@ -{ qtModule -, qtbase -, qtdeclarative +{ + qtModule, + qtbase, + qtdeclarative, }: qtModule { pname = "qtdatavis3d"; - propagatedBuildInputs = [ qtbase qtdeclarative ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtdeclarative.nix b/pkgs/development/libraries/qt-6/modules/qtdeclarative.nix index 42f5bfd76b88b6..4247ae42fc6ab4 100644 --- a/pkgs/development/libraries/qt-6/modules/qtdeclarative.nix +++ b/pkgs/development/libraries/qt-6/modules/qtdeclarative.nix @@ -1,18 +1,24 @@ -{ qtModule -, qtbase -, qtlanguageserver -, qtshadertools -, openssl -, stdenv -, lib -, pkgsBuildBuild -, fetchpatch2 +{ + qtModule, + qtbase, + qtlanguageserver, + qtshadertools, + openssl, + stdenv, + lib, + pkgsBuildBuild, + fetchpatch2, }: qtModule { pname = "qtdeclarative"; - propagatedBuildInputs = [ qtbase qtlanguageserver qtshadertools openssl ]; + propagatedBuildInputs = [ + qtbase + qtlanguageserver + qtshadertools + openssl + ]; strictDeps = true; patches = [ @@ -39,13 +45,14 @@ qtModule { }) ]; - cmakeFlags = [ - "-DQt6ShaderToolsTools_DIR=${pkgsBuildBuild.qt6.qtshadertools}/lib/cmake/Qt6ShaderTools" - # for some reason doesn't get found automatically on Darwin - "-DPython_EXECUTABLE=${lib.getExe pkgsBuildBuild.python3}" - ] - # Conditional is required to prevent infinite recursion during a cross build - ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - "-DQt6QmlTools_DIR=${pkgsBuildBuild.qt6.qtdeclarative}/lib/cmake/Qt6QmlTools" - ]; + cmakeFlags = + [ + "-DQt6ShaderToolsTools_DIR=${pkgsBuildBuild.qt6.qtshadertools}/lib/cmake/Qt6ShaderTools" + # for some reason doesn't get found automatically on Darwin + "-DPython_EXECUTABLE=${lib.getExe pkgsBuildBuild.python3}" + ] + # Conditional is required to prevent infinite recursion during a cross build + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + "-DQt6QmlTools_DIR=${pkgsBuildBuild.qt6.qtdeclarative}/lib/cmake/Qt6QmlTools" + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtdoc.nix b/pkgs/development/libraries/qt-6/modules/qtdoc.nix index 555108caa01a53..fa091d4c6da6b4 100644 --- a/pkgs/development/libraries/qt-6/modules/qtdoc.nix +++ b/pkgs/development/libraries/qt-6/modules/qtdoc.nix @@ -1,7 +1,8 @@ -{ qtModule -, qtdeclarative -, qtbase -, qttools +{ + qtModule, + qtdeclarative, + qtbase, + qttools, }: qtModule { diff --git a/pkgs/development/libraries/qt-6/modules/qtgraphs.nix b/pkgs/development/libraries/qt-6/modules/qtgraphs.nix index 5cafb8d8d7fde5..5de167cc9c36ca 100644 --- a/pkgs/development/libraries/qt-6/modules/qtgraphs.nix +++ b/pkgs/development/libraries/qt-6/modules/qtgraphs.nix @@ -1,8 +1,9 @@ -{ qtModule -, qtbase -, qtdeclarative -, qtquick3d -, qtquicktimeline +{ + qtModule, + qtbase, + qtdeclarative, + qtquick3d, + qtquicktimeline, }: qtModule { diff --git a/pkgs/development/libraries/qt-6/modules/qtgrpc.nix b/pkgs/development/libraries/qt-6/modules/qtgrpc.nix index 09ff7ee89196cf..b344321d11db10 100644 --- a/pkgs/development/libraries/qt-6/modules/qtgrpc.nix +++ b/pkgs/development/libraries/qt-6/modules/qtgrpc.nix @@ -1,12 +1,19 @@ -{ qtModule -, qtbase -, qtdeclarative -, protobuf -, grpc +{ + qtModule, + qtbase, + qtdeclarative, + protobuf, + grpc, }: qtModule { pname = "qtgrpc"; - propagatedBuildInputs = [ qtbase qtdeclarative ]; - buildInputs = [ protobuf grpc ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ]; + buildInputs = [ + protobuf + grpc + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qthttpserver.nix b/pkgs/development/libraries/qt-6/modules/qthttpserver.nix index cf32c8a7ea76a3..8a1f85d1aee172 100644 --- a/pkgs/development/libraries/qt-6/modules/qthttpserver.nix +++ b/pkgs/development/libraries/qt-6/modules/qthttpserver.nix @@ -1,9 +1,13 @@ -{ qtModule -, qtbase -, qtwebsockets +{ + qtModule, + qtbase, + qtwebsockets, }: qtModule { pname = "qthttpserver"; - propagatedBuildInputs = [ qtbase qtwebsockets ]; + propagatedBuildInputs = [ + qtbase + qtwebsockets + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtimageformats.nix b/pkgs/development/libraries/qt-6/modules/qtimageformats.nix index 50420aaa7e4517..e5977e22e230c1 100644 --- a/pkgs/development/libraries/qt-6/modules/qtimageformats.nix +++ b/pkgs/development/libraries/qt-6/modules/qtimageformats.nix @@ -1,13 +1,19 @@ -{ qtModule -, qtbase -, libwebp -, jasper -, libmng -, libtiff +{ + qtModule, + qtbase, + libwebp, + jasper, + libmng, + libtiff, }: qtModule { pname = "qtimageformats"; propagatedBuildInputs = [ qtbase ]; - buildInputs = [ libwebp jasper libmng libtiff ]; + buildInputs = [ + libwebp + jasper + libmng + libtiff + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtlanguageserver.nix b/pkgs/development/libraries/qt-6/modules/qtlanguageserver.nix index b45ab11fc3ffbf..74596e538b8169 100644 --- a/pkgs/development/libraries/qt-6/modules/qtlanguageserver.nix +++ b/pkgs/development/libraries/qt-6/modules/qtlanguageserver.nix @@ -1,5 +1,6 @@ -{ qtModule -, qtbase +{ + qtModule, + qtbase, }: qtModule { diff --git a/pkgs/development/libraries/qt-6/modules/qtlocation.nix b/pkgs/development/libraries/qt-6/modules/qtlocation.nix index 12fa89b9aaead5..120b05b0b1939e 100644 --- a/pkgs/development/libraries/qt-6/modules/qtlocation.nix +++ b/pkgs/development/libraries/qt-6/modules/qtlocation.nix @@ -1,10 +1,15 @@ -{ qtModule -, qtbase -, qtdeclarative -, qtpositioning +{ + qtModule, + qtbase, + qtdeclarative, + qtpositioning, }: qtModule { pname = "qtlocation"; - propagatedBuildInputs = [ qtbase qtdeclarative qtpositioning ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + qtpositioning + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtlottie.nix b/pkgs/development/libraries/qt-6/modules/qtlottie.nix index 4231fcb26b1c94..c1cefda1984ccd 100644 --- a/pkgs/development/libraries/qt-6/modules/qtlottie.nix +++ b/pkgs/development/libraries/qt-6/modules/qtlottie.nix @@ -1,9 +1,13 @@ -{ qtModule -, qtbase -, qtdeclarative +{ + qtModule, + qtbase, + qtdeclarative, }: qtModule { pname = "qtlottie"; - propagatedBuildInputs = [ qtbase qtdeclarative ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtmqtt.nix b/pkgs/development/libraries/qt-6/modules/qtmqtt.nix index 80eef148701ac8..e9e638e976454c 100644 --- a/pkgs/development/libraries/qt-6/modules/qtmqtt.nix +++ b/pkgs/development/libraries/qt-6/modules/qtmqtt.nix @@ -1,6 +1,7 @@ -{ qtModule -, fetchFromGitHub -, qtbase +{ + qtModule, + fetchFromGitHub, + qtbase, }: qtModule rec { diff --git a/pkgs/development/libraries/qt-6/modules/qtmultimedia.nix b/pkgs/development/libraries/qt-6/modules/qtmultimedia.nix index ae02112475f03b..2a76d721667869 100644 --- a/pkgs/development/libraries/qt-6/modules/qtmultimedia.nix +++ b/pkgs/development/libraries/qt-6/modules/qtmultimedia.nix @@ -1,54 +1,77 @@ -{ qtModule -, lib -, stdenv -, qtbase -, qtdeclarative -, qtquick3d -, qtshadertools -, qtsvg -, pkg-config -, alsa-lib -, gstreamer -, gst-plugins-base -, gst-plugins-good -, gst-libav -, gst-vaapi -, ffmpeg -, libva -, libpulseaudio -, wayland -, libXrandr -, elfutils -, libunwind -, orc -, pkgsBuildBuild +{ + qtModule, + lib, + stdenv, + qtbase, + qtdeclarative, + qtquick3d, + qtshadertools, + qtsvg, + pkg-config, + alsa-lib, + gstreamer, + gst-plugins-base, + gst-plugins-good, + gst-libav, + gst-vaapi, + ffmpeg, + libva, + libpulseaudio, + wayland, + libXrandr, + elfutils, + libunwind, + orc, + pkgsBuildBuild, }: qtModule { pname = "qtmultimedia"; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ ffmpeg ] - ++ lib.optionals (!stdenv.hostPlatform.isMinGW) [ libunwind orc ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ libpulseaudio alsa-lib wayland libXrandr libva ] + buildInputs = + [ ffmpeg ] + ++ lib.optionals (!stdenv.hostPlatform.isMinGW) [ + libunwind + orc + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libpulseaudio + alsa-lib + wayland + libXrandr + libva + ] ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform elfutils) [ elfutils ]; - propagatedBuildInputs = [ qtbase qtdeclarative qtsvg qtshadertools ] + propagatedBuildInputs = + [ + qtbase + qtdeclarative + qtsvg + qtshadertools + ] ++ lib.optionals (!stdenv.hostPlatform.isMinGW) [ qtquick3d ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ gstreamer gst-plugins-base gst-plugins-good gst-libav gst-vaapi ]; + ++ lib.optionals stdenv.hostPlatform.isLinux [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-libav + gst-vaapi + ]; - patches = [ - ../patches/fix-qtgui-include-incorrect-case.patch - ] ++ lib.optionals stdenv.hostPlatform.isMinGW [ - ../patches/qtmultimedia-windows-no-uppercase-libs.patch - ../patches/qtmultimedia-windows-resolve-function-name.patch - ]; + patches = + [ + ../patches/fix-qtgui-include-incorrect-case.patch + ] + ++ lib.optionals stdenv.hostPlatform.isMinGW [ + ../patches/qtmultimedia-windows-no-uppercase-libs.patch + ../patches/qtmultimedia-windows-resolve-function-name.patch + ]; cmakeFlags = [ "-DENABLE_DYNAMIC_RESOLVE_VAAPI_SYMBOLS=0" "-DQt6ShaderToolsTools_DIR=${pkgsBuildBuild.qt6.qtshadertools}/lib/cmake/Qt6ShaderToolsTools" ]; - env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin - "-include AudioToolbox/AudioToolbox.h"; - NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin - "-framework AudioToolbox"; + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-include AudioToolbox/AudioToolbox.h"; + NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin "-framework AudioToolbox"; } diff --git a/pkgs/development/libraries/qt-6/modules/qtpositioning.nix b/pkgs/development/libraries/qt-6/modules/qtpositioning.nix index 20f059976323c0..f0f8a3f525be49 100644 --- a/pkgs/development/libraries/qt-6/modules/qtpositioning.nix +++ b/pkgs/development/libraries/qt-6/modules/qtpositioning.nix @@ -1,14 +1,19 @@ -{ qtModule -, qtbase -, qtdeclarative -, qtserialport -, pkg-config -, openssl +{ + qtModule, + qtbase, + qtdeclarative, + qtserialport, + pkg-config, + openssl, }: qtModule { pname = "qtpositioning"; - propagatedBuildInputs = [ qtbase qtdeclarative qtserialport ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + qtserialport + ]; nativeBuildInputs = [ pkg-config ]; buildInputs = [ openssl ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtquick3d.nix b/pkgs/development/libraries/qt-6/modules/qtquick3d.nix index 1c84856c0c1295..40b95dfb958821 100644 --- a/pkgs/development/libraries/qt-6/modules/qtquick3d.nix +++ b/pkgs/development/libraries/qt-6/modules/qtquick3d.nix @@ -1,11 +1,15 @@ -{ qtModule -, qtbase -, qtdeclarative -, openssl +{ + qtModule, + qtbase, + qtdeclarative, + openssl, }: qtModule { pname = "qtquick3d"; - propagatedBuildInputs = [ qtbase qtdeclarative ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ]; buildInputs = [ openssl ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtquick3dphysics.nix b/pkgs/development/libraries/qt-6/modules/qtquick3dphysics.nix index e9363f75ebbe04..6c74677b337cae 100644 --- a/pkgs/development/libraries/qt-6/modules/qtquick3dphysics.nix +++ b/pkgs/development/libraries/qt-6/modules/qtquick3dphysics.nix @@ -1,14 +1,19 @@ -{ qtModule -, lib -, stdenv -, qtbase -, qtquick3d +{ + qtModule, + lib, + stdenv, + qtbase, + qtquick3d, }: qtModule { pname = "qtquick3dphysics"; - propagatedBuildInputs = [ qtbase qtquick3d ]; - env.NIX_CFLAGS_COMPILE = lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) - "-faligned-allocation"; + propagatedBuildInputs = [ + qtbase + qtquick3d + ]; + env.NIX_CFLAGS_COMPILE = lib.optionalString ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64 + ) "-faligned-allocation"; meta.mainProgram = "cooker"; } diff --git a/pkgs/development/libraries/qt-6/modules/qtquickeffectmaker.nix b/pkgs/development/libraries/qt-6/modules/qtquickeffectmaker.nix index 085ce493de610d..f71c891e5f8f4b 100644 --- a/pkgs/development/libraries/qt-6/modules/qtquickeffectmaker.nix +++ b/pkgs/development/libraries/qt-6/modules/qtquickeffectmaker.nix @@ -1,10 +1,14 @@ -{ qtModule -, qtbase -, qtquick3d +{ + qtModule, + qtbase, + qtquick3d, }: qtModule { pname = "qtquickeffectmaker"; - propagatedBuildInputs = [ qtbase qtquick3d ]; + propagatedBuildInputs = [ + qtbase + qtquick3d + ]; meta.mainProgram = "qqem"; } diff --git a/pkgs/development/libraries/qt-6/modules/qtquicktimeline.nix b/pkgs/development/libraries/qt-6/modules/qtquicktimeline.nix index 9ac9c1f093934b..59c774b9abb581 100644 --- a/pkgs/development/libraries/qt-6/modules/qtquicktimeline.nix +++ b/pkgs/development/libraries/qt-6/modules/qtquicktimeline.nix @@ -1,9 +1,13 @@ -{ qtModule -, qtbase -, qtdeclarative +{ + qtModule, + qtbase, + qtdeclarative, }: qtModule { pname = "qtquicktimeline"; - propagatedBuildInputs = [ qtbase qtdeclarative ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtremoteobjects.nix b/pkgs/development/libraries/qt-6/modules/qtremoteobjects.nix index 1fd3b1b7a25342..42ad13e3a8fed4 100644 --- a/pkgs/development/libraries/qt-6/modules/qtremoteobjects.nix +++ b/pkgs/development/libraries/qt-6/modules/qtremoteobjects.nix @@ -1,9 +1,13 @@ -{ qtModule -, qtbase -, qtdeclarative +{ + qtModule, + qtbase, + qtdeclarative, }: qtModule { pname = "qtremoteobjects"; - propagatedBuildInputs = [ qtbase qtdeclarative ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtscxml.nix b/pkgs/development/libraries/qt-6/modules/qtscxml.nix index ece975f59e8db3..a0a821a302e001 100644 --- a/pkgs/development/libraries/qt-6/modules/qtscxml.nix +++ b/pkgs/development/libraries/qt-6/modules/qtscxml.nix @@ -1,6 +1,13 @@ -{ qtModule, qtbase, qtdeclarative }: +{ + qtModule, + qtbase, + qtdeclarative, +}: qtModule { pname = "qtscxml"; - propagatedBuildInputs = [ qtbase qtdeclarative ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtsensors.nix b/pkgs/development/libraries/qt-6/modules/qtsensors.nix index bc49c7a77f5830..888136e3b9ae22 100644 --- a/pkgs/development/libraries/qt-6/modules/qtsensors.nix +++ b/pkgs/development/libraries/qt-6/modules/qtsensors.nix @@ -1,10 +1,15 @@ -{ qtModule -, qtbase -, qtdeclarative -, qtsvg +{ + qtModule, + qtbase, + qtdeclarative, + qtsvg, }: qtModule { pname = "qtsensors"; - propagatedBuildInputs = [ qtbase qtdeclarative qtsvg ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + qtsvg + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtserialbus.nix b/pkgs/development/libraries/qt-6/modules/qtserialbus.nix index 59033f421cc256..5276b2e5d55a48 100644 --- a/pkgs/development/libraries/qt-6/modules/qtserialbus.nix +++ b/pkgs/development/libraries/qt-6/modules/qtserialbus.nix @@ -1,7 +1,14 @@ -{ qtModule, qtbase, qtserialport }: +{ + qtModule, + qtbase, + qtserialport, +}: qtModule { pname = "qtserialbus"; - propagatedBuildInputs = [ qtbase qtserialport ]; + propagatedBuildInputs = [ + qtbase + qtserialport + ]; meta.mainProgram = "canbusutil"; } diff --git a/pkgs/development/libraries/qt-6/modules/qtserialport.nix b/pkgs/development/libraries/qt-6/modules/qtserialport.nix index 00f668ef5631d4..74b647c6dfcc7f 100644 --- a/pkgs/development/libraries/qt-6/modules/qtserialport.nix +++ b/pkgs/development/libraries/qt-6/modules/qtserialport.nix @@ -1,9 +1,10 @@ -{ qtModule -, stdenv -, lib -, qtbase -, udev -, pkg-config +{ + qtModule, + stdenv, + lib, + qtbase, + udev, + pkg-config, }: qtModule { diff --git a/pkgs/development/libraries/qt-6/modules/qtshadertools.nix b/pkgs/development/libraries/qt-6/modules/qtshadertools.nix index ce0f381028c51d..0d8c8111f32808 100644 --- a/pkgs/development/libraries/qt-6/modules/qtshadertools.nix +++ b/pkgs/development/libraries/qt-6/modules/qtshadertools.nix @@ -1,8 +1,9 @@ -{ qtModule -, qtbase -, stdenv -, lib -, pkgsBuildBuild +{ + qtModule, + qtbase, + stdenv, + lib, + pkgsBuildBuild, }: qtModule { diff --git a/pkgs/development/libraries/qt-6/modules/qtspeech.nix b/pkgs/development/libraries/qt-6/modules/qtspeech.nix index 828f34bb72b9e7..4867bcaf7ee9a9 100644 --- a/pkgs/development/libraries/qt-6/modules/qtspeech.nix +++ b/pkgs/development/libraries/qt-6/modules/qtspeech.nix @@ -1,17 +1,25 @@ -{ qtModule -, lib -, stdenv -, qtbase -, qtmultimedia -, pkg-config -, flite -, alsa-lib -, speechd-minimal +{ + qtModule, + lib, + stdenv, + qtbase, + qtmultimedia, + pkg-config, + flite, + alsa-lib, + speechd-minimal, }: qtModule { pname = "qtspeech"; nativeBuildInputs = [ pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ flite alsa-lib speechd-minimal ]; - propagatedBuildInputs = [ qtbase qtmultimedia ]; + buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ + flite + alsa-lib + speechd-minimal + ]; + propagatedBuildInputs = [ + qtbase + qtmultimedia + ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtsvg.nix b/pkgs/development/libraries/qt-6/modules/qtsvg.nix index 3d7df288839ad1..068a2ddc3469ae 100644 --- a/pkgs/development/libraries/qt-6/modules/qtsvg.nix +++ b/pkgs/development/libraries/qt-6/modules/qtsvg.nix @@ -1,24 +1,28 @@ -{ qtModule -, qtbase -, libwebp -, jasper -, libmng -, zlib -, pkg-config -, lib -, stdenv +{ + qtModule, + qtbase, + libwebp, + jasper, + libmng, + zlib, + pkg-config, + lib, + stdenv, }: qtModule { pname = "qtsvg"; propagatedBuildInputs = [ qtbase ]; - buildInputs = [ - libwebp - ] ++ lib.optionals (stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - jasper - ] ++ [ - libmng - zlib - ]; + buildInputs = + [ + libwebp + ] + ++ lib.optionals (stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + jasper + ] + ++ [ + libmng + zlib + ]; nativeBuildInputs = [ pkg-config ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qttools.nix b/pkgs/development/libraries/qt-6/modules/qttools.nix index f13500d65464fa..ffdf7ec695f682 100644 --- a/pkgs/development/libraries/qt-6/modules/qttools.nix +++ b/pkgs/development/libraries/qt-6/modules/qttools.nix @@ -1,12 +1,13 @@ -{ qtModule -, stdenv -, lib -, qtbase -, qtdeclarative -, cups -, llvmPackages -# clang-based c++ parser for qdoc and lupdate -, withClang ? false +{ + qtModule, + stdenv, + lib, + qtbase, + qtdeclarative, + cups, + llvmPackages, + # clang-based c++ parser for qdoc and lupdate + withClang ? false, }: qtModule { @@ -15,8 +16,10 @@ qtModule { llvmPackages.libclang llvmPackages.llvm ]; - propagatedBuildInputs = [ qtbase qtdeclarative ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ cups ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ cups ]; patches = [ ../patches/qttools-paths.patch ]; diff --git a/pkgs/development/libraries/qt-6/modules/qttranslations.nix b/pkgs/development/libraries/qt-6/modules/qttranslations.nix index 61c642de108503..7b6457d8abc00c 100644 --- a/pkgs/development/libraries/qt-6/modules/qttranslations.nix +++ b/pkgs/development/libraries/qt-6/modules/qttranslations.nix @@ -1,5 +1,6 @@ -{ qtModule -, qttools +{ + qtModule, + qttools, }: qtModule { diff --git a/pkgs/development/libraries/qt-6/modules/qtvirtualkeyboard.nix b/pkgs/development/libraries/qt-6/modules/qtvirtualkeyboard.nix index 9f067900dc0686..4c9f449f5a198c 100644 --- a/pkgs/development/libraries/qt-6/modules/qtvirtualkeyboard.nix +++ b/pkgs/development/libraries/qt-6/modules/qtvirtualkeyboard.nix @@ -1,13 +1,19 @@ -{ qtModule -, qtbase -, qtdeclarative -, qtsvg -, hunspell -, pkg-config +{ + qtModule, + qtbase, + qtdeclarative, + qtsvg, + hunspell, + pkg-config, }: qtModule { pname = "qtvirtualkeyboard"; - propagatedBuildInputs = [ qtbase qtdeclarative qtsvg hunspell ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + qtsvg + hunspell + ]; nativeBuildInputs = [ pkg-config ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtwayland.nix b/pkgs/development/libraries/qt-6/modules/qtwayland.nix index d3d55685f5fb0d..5bcfd9b66c9cc3 100644 --- a/pkgs/development/libraries/qt-6/modules/qtwayland.nix +++ b/pkgs/development/libraries/qt-6/modules/qtwayland.nix @@ -1,11 +1,12 @@ -{ lib -, qtModule -, qtbase -, qtdeclarative -, wayland -, wayland-scanner -, pkg-config -, libdrm +{ + lib, + qtModule, + qtbase, + qtdeclarative, + wayland, + wayland-scanner, + pkg-config, + libdrm, }: qtModule { @@ -13,9 +14,19 @@ qtModule { # wayland-scanner needs to be propagated as both build # (for the wayland-scanner binary) and host (for the # actual wayland.xml protocol definition) - propagatedBuildInputs = [ qtbase qtdeclarative wayland-scanner ]; - propagatedNativeBuildInputs = [ wayland wayland-scanner ]; - buildInputs = [ wayland libdrm ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + wayland-scanner + ]; + propagatedNativeBuildInputs = [ + wayland + wayland-scanner + ]; + buildInputs = [ + wayland + libdrm + ]; nativeBuildInputs = [ pkg-config ]; # Replace vendored wayland.xml with our matching version diff --git a/pkgs/development/libraries/qt-6/modules/qtwebchannel.nix b/pkgs/development/libraries/qt-6/modules/qtwebchannel.nix index bf0ba0f6338588..b60e802312e30a 100644 --- a/pkgs/development/libraries/qt-6/modules/qtwebchannel.nix +++ b/pkgs/development/libraries/qt-6/modules/qtwebchannel.nix @@ -1,12 +1,17 @@ -{ qtModule -, qtbase -, qtdeclarative -, qtwebsockets -, openssl +{ + qtModule, + qtbase, + qtdeclarative, + qtwebsockets, + openssl, }: qtModule { pname = "qtwebchannel"; - propagatedBuildInputs = [ qtbase qtdeclarative qtwebsockets ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + qtwebsockets + ]; buildInputs = [ openssl ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtwebsockets.nix b/pkgs/development/libraries/qt-6/modules/qtwebsockets.nix index c3a346a8d78a68..11264a48858cfd 100644 --- a/pkgs/development/libraries/qt-6/modules/qtwebsockets.nix +++ b/pkgs/development/libraries/qt-6/modules/qtwebsockets.nix @@ -1,11 +1,15 @@ -{ qtModule -, qtbase -, qtdeclarative -, openssl +{ + qtModule, + qtbase, + qtdeclarative, + openssl, }: qtModule { pname = "qtwebsockets"; - propagatedBuildInputs = [ qtbase qtdeclarative ]; + propagatedBuildInputs = [ + qtbase + qtdeclarative + ]; buildInputs = [ openssl ]; } diff --git a/pkgs/development/libraries/qt-6/modules/qtwebview.nix b/pkgs/development/libraries/qt-6/modules/qtwebview.nix index 149ccc2a7ea132..56f5aa6a707295 100644 --- a/pkgs/development/libraries/qt-6/modules/qtwebview.nix +++ b/pkgs/development/libraries/qt-6/modules/qtwebview.nix @@ -1,12 +1,14 @@ -{ lib -, stdenv -, qtModule -, qtdeclarative -, qtwebengine +{ + lib, + stdenv, + qtModule, + qtdeclarative, + qtwebengine, }: qtModule { pname = "qtwebview"; - propagatedBuildInputs = [ qtdeclarative ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ qtwebengine ]; + propagatedBuildInputs = [ + qtdeclarative + ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ qtwebengine ]; } diff --git a/pkgs/development/libraries/qt-6/qt-env.nix b/pkgs/development/libraries/qt-6/qt-env.nix index c754c75cc2763b..113e57e3588bbd 100644 --- a/pkgs/development/libraries/qt-6/qt-env.nix +++ b/pkgs/development/libraries/qt-6/qt-env.nix @@ -1,11 +1,23 @@ -{ buildEnv, qtbase }: name: paths: +{ buildEnv, qtbase }: +name: paths: buildEnv { inherit name; paths = [ qtbase ] ++ paths; - pathsToLink = [ "/metatypes" "/bin" "/mkspecs" "/include" "/lib" "/share" "/libexec" ]; - extraOutputsToInstall = [ "out" "dev" ]; + pathsToLink = [ + "/metatypes" + "/bin" + "/mkspecs" + "/include" + "/lib" + "/share" + "/libexec" + ]; + extraOutputsToInstall = [ + "out" + "dev" + ]; postBuild = '' for f in qmake qmake6; do diff --git a/pkgs/development/libraries/qt-6/qtModule.nix b/pkgs/development/libraries/qt-6/qtModule.nix index 8b09c8cb19b8b9..afcabcd02dc06b 100644 --- a/pkgs/development/libraries/qt-6/qtModule.nix +++ b/pkgs/development/libraries/qt-6/qtModule.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, darwinVersionInputs -, cmake -, ninja -, perl -, moveBuildTree -, srcs -, patches ? [ ] +{ + lib, + stdenv, + darwinVersionInputs, + cmake, + ninja, + perl, + moveBuildTree, + srcs, + patches ? [ ], }: args: @@ -16,34 +17,60 @@ let version = args.version or srcs.${pname}.version; src = args.src or srcs.${pname}.src; in -stdenv.mkDerivation (args // { - inherit pname version src; - patches = args.patches or patches.${pname} or [ ]; +stdenv.mkDerivation ( + args + // { + inherit pname version src; + patches = args.patches or patches.${pname} or [ ]; - buildInputs = - args.buildInputs or [ ] - ++ lib.optionals stdenv.hostPlatform.isDarwin darwinVersionInputs; - nativeBuildInputs = (args.nativeBuildInputs or [ ]) ++ [ cmake ninja perl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ moveBuildTree ]; - propagatedBuildInputs = - (lib.warnIf (args ? qtInputs) "qt6.qtModule's qtInputs argument is deprecated" args.qtInputs or []) ++ - (args.propagatedBuildInputs or []); + buildInputs = + args.buildInputs or [ ] + ++ lib.optionals stdenv.hostPlatform.isDarwin darwinVersionInputs; + nativeBuildInputs = + (args.nativeBuildInputs or [ ]) + ++ [ + cmake + ninja + perl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ moveBuildTree ]; + propagatedBuildInputs = + (lib.warnIf (args ? qtInputs) "qt6.qtModule's qtInputs argument is deprecated" args.qtInputs or [ ]) + ++ (args.propagatedBuildInputs or [ ]); - moveToDev = false; + moveToDev = false; - outputs = args.outputs or [ "out" "dev" ]; - separateDebugInfo = args.separateDebugInfo or true; + outputs = + args.outputs or [ + "out" + "dev" + ]; + separateDebugInfo = args.separateDebugInfo or true; - dontWrapQtApps = args.dontWrapQtApps or true; -}) // { - meta = with lib; let - pos = builtins.unsafeGetAttrPos "pname" args; - in { - homepage = "https://www.qt.io/"; - description = "Cross-platform application framework for C++"; - license = with licenses; [ fdl13Plus gpl2Plus lgpl21Plus lgpl3Plus ]; - maintainers = with maintainers; [ milahu nickcao ]; - platforms = platforms.unix; - position = "${pos.file}:${toString pos.line}"; - } // (args.meta or { }); + dontWrapQtApps = args.dontWrapQtApps or true; + } +) +// { + meta = + with lib; + let + pos = builtins.unsafeGetAttrPos "pname" args; + in + { + homepage = "https://www.qt.io/"; + description = "Cross-platform application framework for C++"; + license = with licenses; [ + fdl13Plus + gpl2Plus + lgpl21Plus + lgpl3Plus + ]; + maintainers = with maintainers; [ + milahu + nickcao + ]; + platforms = platforms.unix; + position = "${pos.file}:${toString pos.line}"; + } + // (args.meta or { }); } diff --git a/pkgs/development/libraries/qtdbusextended/default.nix b/pkgs/development/libraries/qtdbusextended/default.nix index 22fa37611dd58a..c1cc09b29bc157 100644 --- a/pkgs/development/libraries/qtdbusextended/default.nix +++ b/pkgs/development/libraries/qtdbusextended/default.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, fetchFromGitHub -, qmake -, wrapQtAppsHook +{ + stdenv, + lib, + fetchFromGitHub, + qmake, + wrapQtAppsHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/qtfeedback/default.nix b/pkgs/development/libraries/qtfeedback/default.nix index 285a81ae1ac46c..182b709103326b 100644 --- a/pkgs/development/libraries/qtfeedback/default.nix +++ b/pkgs/development/libraries/qtfeedback/default.nix @@ -1,16 +1,20 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, perl -, qmake -, qtdeclarative +{ + lib, + mkDerivation, + fetchFromGitHub, + perl, + qmake, + qtdeclarative, }: mkDerivation rec { pname = "qtfeedback"; version = "unstable-2018-09-03"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "qt"; @@ -41,7 +45,13 @@ mkDerivation rec { meta = with lib; { description = "Qt Tactile Feedback"; homepage = "https://github.com/qt/qtfeedback"; - license = with licenses; [ lgpl3Only /* or */ gpl2Plus ]; - maintainers = with maintainers; [ dotlambda OPNA2608 ]; + license = with licenses; [ + lgpl3Only # or + gpl2Plus + ]; + maintainers = with maintainers; [ + dotlambda + OPNA2608 + ]; }; } diff --git a/pkgs/development/libraries/qtforkawesome/default.nix b/pkgs/development/libraries/qtforkawesome/default.nix index 432023a2ac65c7..795f3444436905 100644 --- a/pkgs/development/libraries/qtforkawesome/default.nix +++ b/pkgs/development/libraries/qtforkawesome/default.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, qttools -, perl -, cpp-utilities -, qtutilities -, qtbase +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + qttools, + perl, + cpp-utilities, + qtutilities, + qtbase, }: let @@ -16,7 +17,8 @@ let rev = "1.2.0"; sha256 = "sha256-zG6/0dWjU7/y/oDZuSEv+54Mchng64LVyV8bluskYzc="; }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "qtforkawesome"; version = "0.1.0"; @@ -55,7 +57,6 @@ in stdenv.mkDerivation (finalAttrs: { description = "Library that bundles ForkAwesome for use within Qt applications"; license = licenses.gpl2Plus; maintainers = with maintainers; [ doronbehar ]; - platforms = platforms.linux ++ platforms.darwin; + platforms = platforms.linux ++ platforms.darwin; }; }) - diff --git a/pkgs/development/libraries/qtinstaller/default.nix b/pkgs/development/libraries/qtinstaller/default.nix index 0fd21a1a296803..c551ff49889bb8 100644 --- a/pkgs/development/libraries/qtinstaller/default.nix +++ b/pkgs/development/libraries/qtinstaller/default.nix @@ -1,9 +1,19 @@ -{ stdenv, fetchurl, qtdeclarative , qttools, qtbase, qmake }: +{ + stdenv, + fetchurl, + qtdeclarative, + qttools, + qtbase, + qmake, +}: stdenv.mkDerivation rec { pname = "qtinstaller"; - propagatedBuildInputs = [ qtdeclarative qttools ]; + propagatedBuildInputs = [ + qtdeclarative + qttools + ]; nativeBuildInputs = [ qmake ]; version = "2.0.3"; @@ -13,7 +23,11 @@ stdenv.mkDerivation rec { name = "qt-installer-framework-opensource-src-${version}.tar.gz"; }; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; setOutputFlags = false; NIX_QT_SUBMODULE = true; diff --git a/pkgs/development/libraries/qtkeychain/default.nix b/pkgs/development/libraries/qtkeychain/default.nix index b6744692bbe88f..d865b183f9cafa 100644 --- a/pkgs/development/libraries/qtkeychain/default.nix +++ b/pkgs/development/libraries/qtkeychain/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, qtbase -, qttools -, CoreFoundation -, Security -, libsecret +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + qtbase, + qttools, + CoreFoundation, + Security, + libsecret, }: stdenv.mkDerivation rec { @@ -28,16 +29,19 @@ stdenv.mkDerivation rec { "-DQT_TRANSLATIONS_DIR=share/qt/translations" ]; - nativeBuildInputs = [ cmake ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ pkg-config ] # for finding libsecret + nativeBuildInputs = [ cmake ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ pkg-config ] # for finding libsecret ; - buildInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ libsecret ] - ++ [ qtbase qttools ] + buildInputs = + lib.optionals (!stdenv.hostPlatform.isDarwin) [ libsecret ] + ++ [ + qtbase + qttools + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreFoundation - Security - ]; + CoreFoundation + Security + ]; doInstallCheck = true; diff --git a/pkgs/development/libraries/qtmpris/default.nix b/pkgs/development/libraries/qtmpris/default.nix index ef595efa731d35..6bc94edeb30e4c 100644 --- a/pkgs/development/libraries/qtmpris/default.nix +++ b/pkgs/development/libraries/qtmpris/default.nix @@ -1,8 +1,9 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, qmake -, qtbase +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qtbase, }: mkDerivation rec { diff --git a/pkgs/development/libraries/qtpbfimageplugin/default.nix b/pkgs/development/libraries/qtpbfimageplugin/default.nix index 7005c781e2a65b..9caa9b5af4de83 100644 --- a/pkgs/development/libraries/qtpbfimageplugin/default.nix +++ b/pkgs/development/libraries/qtpbfimageplugin/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, qmake, qtbase, protobuf }: +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + qtbase, + protobuf, +}: stdenv.mkDerivation rec { pname = "qtpbfimageplugin"; @@ -12,20 +19,25 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ qmake ]; - buildInputs = [ qtbase protobuf ]; + buildInputs = [ + qtbase + protobuf + ]; dontWrapQtApps = true; - postPatch = '' - # Fix plugin dir - substituteInPlace pbfplugin.pro \ - --replace "\$\$[QT_INSTALL_PLUGINS]" "$out/$qtPluginPrefix" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Fix darwin build - substituteInPlace pbfplugin.pro \ - --replace '$$PROTOBUF/include' '${protobuf}/include' \ - --replace '$$PROTOBUF/lib/libprotobuf-lite.a' '${protobuf}/lib/libprotobuf-lite.dylib' - ''; + postPatch = + '' + # Fix plugin dir + substituteInPlace pbfplugin.pro \ + --replace "\$\$[QT_INSTALL_PLUGINS]" "$out/$qtPluginPrefix" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Fix darwin build + substituteInPlace pbfplugin.pro \ + --replace '$$PROTOBUF/include' '${protobuf}/include' \ + --replace '$$PROTOBUF/lib/libprotobuf-lite.a' '${protobuf}/lib/libprotobuf-lite.dylib' + ''; meta = with lib; { description = "Qt image plugin for displaying Mapbox vector tiles"; diff --git a/pkgs/development/libraries/qtstyleplugins/default.nix b/pkgs/development/libraries/qtstyleplugins/default.nix index ebc7bc0819337c..b46c7b52201893 100644 --- a/pkgs/development/libraries/qtstyleplugins/default.nix +++ b/pkgs/development/libraries/qtstyleplugins/default.nix @@ -1,4 +1,12 @@ -{ lib, mkDerivation, fetchFromGitHub, fetchpatch, qmake, pkg-config, gtk2 }: +{ + lib, + mkDerivation, + fetchFromGitHub, + fetchpatch, + qmake, + pkg-config, + gtk2, +}: mkDerivation { pname = "qtstyleplugins"; @@ -24,7 +32,10 @@ mkDerivation { }) ]; - nativeBuildInputs = [ pkg-config qmake ]; + nativeBuildInputs = [ + pkg-config + qmake + ]; buildInputs = [ gtk2 ]; meta = with lib; { diff --git a/pkgs/development/libraries/qtutilities/default.nix b/pkgs/development/libraries/qtutilities/default.nix index abeb58a8089417..f9d0db450273d9 100644 --- a/pkgs/development/libraries/qtutilities/default.nix +++ b/pkgs/development/libraries/qtutilities/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, qttools -, cpp-utilities -, qtbase +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + qttools, + cpp-utilities, + qtbase, }: stdenv.mkDerivation (finalAttrs: { @@ -39,6 +40,6 @@ stdenv.mkDerivation (finalAttrs: { description = "Common Qt related C++ classes and routines used by @Martchus' applications such as dialogs, widgets and models Topics"; license = licenses.gpl2Plus; maintainers = with maintainers; [ doronbehar ]; - platforms = platforms.linux ++ platforms.darwin; + platforms = platforms.linux ++ platforms.darwin; }; }) diff --git a/pkgs/development/libraries/qtwebkit-plugins/default.nix b/pkgs/development/libraries/qtwebkit-plugins/default.nix index dd6a7606f6e247..9d2541c0b7214e 100644 --- a/pkgs/development/libraries/qtwebkit-plugins/default.nix +++ b/pkgs/development/libraries/qtwebkit-plugins/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, qmake, qtwebkit, hunspell }: +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + qtwebkit, + hunspell, +}: stdenv.mkDerivation { pname = "qtwebkit-plugins"; @@ -13,7 +20,10 @@ stdenv.mkDerivation { nativeBuildInputs = [ qmake ]; - buildInputs = [ qtwebkit hunspell ]; + buildInputs = [ + qtwebkit + hunspell + ]; dontWrapQtApps = true; diff --git a/pkgs/development/libraries/quazip/default.nix b/pkgs/development/libraries/quazip/default.nix index b2fcad6cab8778..6acf4f1c60a166 100644 --- a/pkgs/development/libraries/quazip/default.nix +++ b/pkgs/development/libraries/quazip/default.nix @@ -1,4 +1,13 @@ -{ fetchFromGitHub, lib, stdenv, zlib, qtbase, qt5compat ? null, cmake, fixDarwinDylibNames }: +{ + fetchFromGitHub, + lib, + stdenv, + zlib, + qtbase, + qt5compat ? null, + cmake, + fixDarwinDylibNames, +}: stdenv.mkDerivation rec { pname = "quazip"; @@ -11,14 +20,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-JPpkYvndjDcHVChAyWhpb/XiUPu/qHqDZFh5XmonXMs="; }; - buildInputs = [ zlib qtbase ]; + buildInputs = [ + zlib + qtbase + ]; propagatedBuildInputs = [ qt5compat ]; - nativeBuildInputs = [ cmake ] - ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; + nativeBuildInputs = [ cmake ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; dontWrapQtApps = true; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = with lib; { description = "Provides access to ZIP archives from Qt programs"; diff --git a/pkgs/development/libraries/quickflux/default.nix b/pkgs/development/libraries/quickflux/default.nix index 3ab3058b478e72..be38b2f1b01a02 100644 --- a/pkgs/development/libraries/quickflux/default.nix +++ b/pkgs/development/libraries/quickflux/default.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, qtbase -, qtquickcontrols2 +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + qtbase, + qtquickcontrols2, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/libraries/qwlroots/default.nix b/pkgs/development/libraries/qwlroots/default.nix index 190a13e15a27da..6dfed9551920d4 100644 --- a/pkgs/development/libraries/qwlroots/default.nix +++ b/pkgs/development/libraries/qwlroots/default.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, wrapQtAppsHook -, wayland-scanner -, qtbase -, wayland -, wayland-protocols -, wlr-protocols -, pixman -, mesa -, vulkan-loader -, libinput -, xorg -, seatd -, wlroots +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + wrapQtAppsHook, + wayland-scanner, + qtbase, + wayland, + wayland-protocols, + wlr-protocols, + pixman, + mesa, + vulkan-loader, + libinput, + xorg, + seatd, + wlroots, }: stdenv.mkDerivation (finalAttrs: { @@ -62,9 +63,12 @@ stdenv.mkDerivation (finalAttrs: { meta = { description = "Qt and QML bindings for wlroots"; homepage = "https://github.com/vioken/qwlroots"; - license = with lib.licenses; [ gpl3Only lgpl3Only asl20 ]; + license = with lib.licenses; [ + gpl3Only + lgpl3Only + asl20 + ]; platforms = wlroots.meta.platforms; maintainers = with lib.maintainers; [ rewine ]; }; }) - diff --git a/pkgs/development/libraries/qwt/6_1.nix b/pkgs/development/libraries/qwt/6_1.nix index 4e3a179e752077..bf5a4c35a7029e 100644 --- a/pkgs/development/libraries/qwt/6_1.nix +++ b/pkgs/development/libraries/qwt/6_1.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, qtbase, qtsvg, qttools, qmake }: +{ + lib, + stdenv, + fetchurl, + qtbase, + qtsvg, + qttools, + qmake, +}: stdenv.mkDerivation rec { pname = "qwt"; @@ -9,7 +17,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-mUYNMcEV7kEXsBddiF9HwsWQ14QgbwmBXcBY++Xt4fY="; }; - propagatedBuildInputs = [ qtbase qtsvg qttools ]; + propagatedBuildInputs = [ + qtbase + qtsvg + qttools + ]; nativeBuildInputs = [ qmake ]; postPatch = '' diff --git a/pkgs/development/libraries/qwt/default.nix b/pkgs/development/libraries/qwt/default.nix index 814e8f0252c1bf..7ff4c929e4868f 100644 --- a/pkgs/development/libraries/qwt/default.nix +++ b/pkgs/development/libraries/qwt/default.nix @@ -1,17 +1,33 @@ -{ lib, stdenv, fetchurl, qtbase, qtsvg, qttools, qmake, fixDarwinDylibNames }: +{ + lib, + stdenv, + fetchurl, + qtbase, + qtsvg, + qttools, + qmake, + fixDarwinDylibNames, +}: stdenv.mkDerivation rec { pname = "qwt"; version = "6.3.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchurl { url = "mirror://sourceforge/qwt/qwt-${version}.tar.bz2"; sha256 = "sha256-3LCFiWwoquxVGMvAjA7itOYK2nrJKdgmOfYYmFGmEpo="; }; - propagatedBuildInputs = [ qtbase qtsvg qttools ]; + propagatedBuildInputs = [ + qtbase + qtsvg + qttools + ]; nativeBuildInputs = [ qmake ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; postPatch = '' diff --git a/pkgs/development/libraries/qxlsx/default.nix b/pkgs/development/libraries/qxlsx/default.nix index 45324d97e5a747..fa9d291a675905 100644 --- a/pkgs/development/libraries/qxlsx/default.nix +++ b/pkgs/development/libraries/qxlsx/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qtbase +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtbase, }: stdenv.mkDerivation rec { @@ -25,7 +26,7 @@ stdenv.mkDerivation rec { dontWrapQtApps = true; - meta = with lib;{ + meta = with lib; { description = "Excel file(*.xlsx) reader/writer library using Qt 5 or 6"; homepage = "https://qtexcel.github.io/QXlsx"; license = licenses.mit; diff --git a/pkgs/development/libraries/qzxing/default.nix b/pkgs/development/libraries/qzxing/default.nix index 4cb224e2c040f4..e8ac307dfe0f3d 100644 --- a/pkgs/development/libraries/qzxing/default.nix +++ b/pkgs/development/libraries/qzxing/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchFromGitHub -, nix-update-script -, testers -, qmake -, qtmultimedia +{ + stdenv, + lib, + fetchFromGitHub, + nix-update-script, + testers, + qmake, + qtmultimedia, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/libraries/rabbitmq-java-client/default.nix b/pkgs/development/libraries/rabbitmq-java-client/default.nix index 92aee32c38d1c7..ad21dff6609bc6 100644 --- a/pkgs/development/libraries/rabbitmq-java-client/default.nix +++ b/pkgs/development/libraries/rabbitmq-java-client/default.nix @@ -1,4 +1,13 @@ -{ fetchurl, lib, stdenv, ant, jdk, jre, python2, makeWrapper }: +{ + fetchurl, + lib, + stdenv, + ant, + jdk, + jre, + python2, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "rabbitmq-java-client"; @@ -10,7 +19,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ ant jdk python2 ]; + buildInputs = [ + ant + jdk + python2 + ]; buildPhase = "ant dist"; @@ -28,9 +41,12 @@ stdenv.mkDerivation rec { homepage = "https://www.rabbitmq.com/java-client.html"; sourceProvenance = with sourceTypes; [ fromSource - binaryBytecode # source bundles dependencies as jars + binaryBytecode # source bundles dependencies as jars + ]; + license = with licenses; [ + mpl11 + gpl2 ]; - license = with licenses; [ mpl11 gpl2 ]; platforms = platforms.linux; }; } diff --git a/pkgs/development/libraries/randomx/default.nix b/pkgs/development/libraries/randomx/default.nix index 4e85b3688ab7ec..75e72e16fbc127 100644 --- a/pkgs/development/libraries/randomx/default.nix +++ b/pkgs/development/libraries/randomx/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "randomX"; diff --git a/pkgs/development/libraries/readline/7.0.nix b/pkgs/development/libraries/readline/7.0.nix index 3b643a9e15fe53..273f8fdd754300 100644 --- a/pkgs/development/libraries/readline/7.0.nix +++ b/pkgs/development/libraries/readline/7.0.nix @@ -1,4 +1,8 @@ -{ fetchurl, lib, stdenv, ncurses +{ + fetchurl, + lib, + stdenv, + ncurses, }: stdenv.mkDerivation rec { @@ -10,28 +14,35 @@ stdenv.mkDerivation rec { sha256 = "0d13sg9ksf982rrrmv5mb6a2p4ys9rvg9r71d6il0vr8hmql63bm"; }; - outputs = [ "out" "dev" "man" "doc" "info" ]; + outputs = [ + "out" + "dev" + "man" + "doc" + "info" + ]; strictDeps = true; propagatedBuildInputs = [ ncurses ]; patchFlags = [ "-p0" ]; - upstreamPatches = - (let - patch = nr: sha256: - fetchurl { - url = "mirror://gnu/readline/readline-${meta.branch}-patches/readline70-${nr}"; - inherit sha256; - }; - in - import ./readline-7.0-patches.nix patch); - - patches = - [ ./link-against-ncurses.patch - ./no-arch_only-6.3.patch - ] - ++ upstreamPatches; + upstreamPatches = ( + let + patch = + nr: sha256: + fetchurl { + url = "mirror://gnu/readline/readline-${meta.branch}-patches/readline70-${nr}"; + inherit sha256; + }; + in + import ./readline-7.0-patches.nix patch + ); + + patches = [ + ./link-against-ncurses.patch + ./no-arch_only-6.3.patch + ] ++ upstreamPatches; meta = with lib; { description = "Library for interactive line editing"; diff --git a/pkgs/development/libraries/readline/readline-7.0-patches.nix b/pkgs/development/libraries/readline/readline-7.0-patches.nix index c34ef2bf97bbec..c4c95d91a0e9ee 100644 --- a/pkgs/development/libraries/readline/readline-7.0-patches.nix +++ b/pkgs/development/libraries/readline/readline-7.0-patches.nix @@ -1,9 +1,9 @@ # Automatically generated by `update-patch-set.sh'; do not edit. patch: [ -(patch "001" "0xm3sxvwmss7ddyfb11n6pgcqd1aglnpy15g143vzcf75snb7hcs") -(patch "002" "0n1dxmqsbjgrfxb1hgk5c6lsraw4ncbnzxlsx7m35nym6lncjiw7") -(patch "003" "1027kmymniizcy0zbdlrczxfx3clxcdln5yq05q9yzlc6y9slhwy") -(patch "004" "0r3bbaf12iz8m02z6p3fzww2m365fhn71xmzab2p62gj54s6h9gr") -(patch "005" "0lxpa4f72y2nsgj6fgrhjk2nmmxvccys6aciwfxwchb5f21rq5fa") + (patch "001" "0xm3sxvwmss7ddyfb11n6pgcqd1aglnpy15g143vzcf75snb7hcs") + (patch "002" "0n1dxmqsbjgrfxb1hgk5c6lsraw4ncbnzxlsx7m35nym6lncjiw7") + (patch "003" "1027kmymniizcy0zbdlrczxfx3clxcdln5yq05q9yzlc6y9slhwy") + (patch "004" "0r3bbaf12iz8m02z6p3fzww2m365fhn71xmzab2p62gj54s6h9gr") + (patch "005" "0lxpa4f72y2nsgj6fgrhjk2nmmxvccys6aciwfxwchb5f21rq5fa") ] diff --git a/pkgs/development/libraries/readline/readline-8.2-patches.nix b/pkgs/development/libraries/readline/readline-8.2-patches.nix index 37f9aeb8f7f72e..7d98ff1fc71fd0 100644 --- a/pkgs/development/libraries/readline/readline-8.2-patches.nix +++ b/pkgs/development/libraries/readline/readline-8.2-patches.nix @@ -1,17 +1,17 @@ # Automatically generated by `update-patch-set.sh'; do not edit. patch: [ -(patch "001" "1xxgfgr6hn3ads8m8xsrdi1kbx1f3s69k0danpd9x4haqhg7zydv") -(patch "002" "0ly0siy6qy3l7hv12847adpfa34yq1w4qz9qkw6vrxv25j106rg0") -(patch "003" "1c5cwvvkx9mfmpaapymq9cavmzh4fnagkjlchsqx4vml8sx8gx94") -(patch "004" "1b15sndx9v5vj3x1f3h73099nlagknx4rbfpd5ldrbw2xgm2wmvr") -(patch "005" "16ac25jz1a1mgkpfp1sydqf6qpsfh0s0dcmrnjpqbhg5va3s6av2") -(patch "006" "18gmh6y3klh0vv28cyqz4is3rlb32pl7f1kf5r482kfjq3w5zd67") -(patch "007" "1xmnpahs983n4w0gn3j0wr8nh1dpva33yj7fvfmhm46ph2wsa4ar") -(patch "008" "0smjjzhwxi2ibpdisnk53lh1pzgka6rhlqyh3662xy69v34ysxx1") -(patch "009" "05m1fwbs7mbs3pz3pg87gbbayandrrcgaqawzliqb6g1jbk8b61x") -(patch "010" "0k3vyrjs2g6y2cfs03l2gp37fhxgqpiwvxb1c7z4q88cbb32x3km") -(patch "011" "1msdahvz56l9m5m69a87zp2c7qrfv0dxwd09rj1697isgy83s0g0") -(patch "012" "1lybzig73pqpcbw79im0kn6299lkcbnh24yigygn5jm2sj7dz2kc") -(patch "013" "1a48lyrhvn6nbj5qhradfpbbs3md5maz7wb32yvaghvfgnak990y") + (patch "001" "1xxgfgr6hn3ads8m8xsrdi1kbx1f3s69k0danpd9x4haqhg7zydv") + (patch "002" "0ly0siy6qy3l7hv12847adpfa34yq1w4qz9qkw6vrxv25j106rg0") + (patch "003" "1c5cwvvkx9mfmpaapymq9cavmzh4fnagkjlchsqx4vml8sx8gx94") + (patch "004" "1b15sndx9v5vj3x1f3h73099nlagknx4rbfpd5ldrbw2xgm2wmvr") + (patch "005" "16ac25jz1a1mgkpfp1sydqf6qpsfh0s0dcmrnjpqbhg5va3s6av2") + (patch "006" "18gmh6y3klh0vv28cyqz4is3rlb32pl7f1kf5r482kfjq3w5zd67") + (patch "007" "1xmnpahs983n4w0gn3j0wr8nh1dpva33yj7fvfmhm46ph2wsa4ar") + (patch "008" "0smjjzhwxi2ibpdisnk53lh1pzgka6rhlqyh3662xy69v34ysxx1") + (patch "009" "05m1fwbs7mbs3pz3pg87gbbayandrrcgaqawzliqb6g1jbk8b61x") + (patch "010" "0k3vyrjs2g6y2cfs03l2gp37fhxgqpiwvxb1c7z4q88cbb32x3km") + (patch "011" "1msdahvz56l9m5m69a87zp2c7qrfv0dxwd09rj1697isgy83s0g0") + (patch "012" "1lybzig73pqpcbw79im0kn6299lkcbnh24yigygn5jm2sj7dz2kc") + (patch "013" "1a48lyrhvn6nbj5qhradfpbbs3md5maz7wb32yvaghvfgnak990y") ] diff --git a/pkgs/development/libraries/rlottie-qml/default.nix b/pkgs/development/libraries/rlottie-qml/default.nix index 5154c816624e72..7a71fa3295d7ca 100644 --- a/pkgs/development/libraries/rlottie-qml/default.nix +++ b/pkgs/development/libraries/rlottie-qml/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, cmake -, qtbase -, qtdeclarative -, qtmultimedia -, quazip -, rlottie +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + cmake, + qtbase, + qtdeclarative, + qtmultimedia, + quazip, + rlottie, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/libraries/rnnoise-plugin/default.nix b/pkgs/development/libraries/rnnoise-plugin/default.nix index 4cf983add42b0c..98cf154ec1e685 100644 --- a/pkgs/development/libraries/rnnoise-plugin/default.nix +++ b/pkgs/development/libraries/rnnoise-plugin/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, freetype -, gtk3-x11 -, pcre -, pkg-config -, webkitgtk_4_0 -, xorg -, WebKit -, MetalKit -, CoreAudioKit -, simd +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + freetype, + gtk3-x11, + pcre, + pkg-config, + webkitgtk_4_0, + xorg, + WebKit, + MetalKit, + CoreAudioKit, + simd, }: stdenv.mkDerivation rec { pname = "rnnoise-plugin"; @@ -24,7 +25,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-sfwHd5Fl2DIoGuPDjELrPp5KpApZJKzQikCJmCzhtY8="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; patches = lib.optionals stdenv.hostPlatform.isDarwin [ # Ubsan seems to be broken on aarch64-darwin, it produces linker errors similar to https://github.com/NixOS/nixpkgs/issues/140751 @@ -38,9 +42,11 @@ stdenv.mkDerivation rec { pcre xorg.libX11 xorg.libXrandr - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ webkitgtk_4_0 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ WebKit MetalKit CoreAudioKit @@ -52,6 +58,10 @@ stdenv.mkDerivation rec { homepage = "https://github.com/werman/noise-suppression-for-voice"; license = licenses.gpl3; platforms = platforms.all; - maintainers = with maintainers; [ panaeon henrikolsson sciencentistguy ]; + maintainers = with maintainers; [ + panaeon + henrikolsson + sciencentistguy + ]; }; } diff --git a/pkgs/development/libraries/rure/default.nix b/pkgs/development/libraries/rure/default.nix index 308eb41d1a9027..58cce26b19ea3c 100644 --- a/pkgs/development/libraries/rure/default.nix +++ b/pkgs/development/libraries/rure/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, rustPlatform -, fetchCrate -, fixDarwinDylibNames +{ + lib, + stdenv, + rustPlatform, + fetchCrate, + fixDarwinDylibNames, }: let @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage { cargoLock.lockFile = ./Cargo.lock; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; # Headers are not handled by cargo nor buildRustPackage postInstall = '' diff --git a/pkgs/development/libraries/schroedinger/default.nix b/pkgs/development/libraries/schroedinger/default.nix index 698ac7986204fa..8298aa6a6a2b4f 100644 --- a/pkgs/development/libraries/schroedinger/default.nix +++ b/pkgs/development/libraries/schroedinger/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, orc, pkg-config, fetchpatch, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + orc, + pkg-config, + fetchpatch, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "schroedinger"; @@ -9,9 +17,16 @@ stdenv.mkDerivation rec { sha256 = "04prr667l4sn4zx256v1z36a0nnkxfdqyln48rbwlamr6l3jlmqy"; }; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; buildInputs = [ orc ]; doCheck = (!stdenv.hostPlatform.isDarwin); @@ -28,7 +43,11 @@ stdenv.mkDerivation rec { description = "Implementation of the Dirac video codec in ANSI C"; homepage = "https://sourceforge.net/projects/schrodinger/"; maintainers = [ ]; - license = [ licenses.mpl11 licenses.lgpl2 licenses.mit ]; + license = [ + licenses.mpl11 + licenses.lgpl2 + licenses.mit + ]; platforms = platforms.unix; }; } diff --git a/pkgs/development/libraries/science/astronomy/stellarsolver/default.nix b/pkgs/development/libraries/science/astronomy/stellarsolver/default.nix index 3591a86dbb701d..6840b2f353d2bc 100644 --- a/pkgs/development/libraries/science/astronomy/stellarsolver/default.nix +++ b/pkgs/development/libraries/science/astronomy/stellarsolver/default.nix @@ -1,5 +1,14 @@ -{ lib, mkDerivation, fetchFromGitHub, cmake, - qtbase, cfitsio, gsl, wcslib, withTester ? false }: +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + qtbase, + cfitsio, + gsl, + wcslib, + withTester ? false, +}: mkDerivation rec { pname = "stellarsolver"; @@ -14,7 +23,12 @@ mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ qtbase cfitsio gsl wcslib ]; + buildInputs = [ + qtbase + cfitsio + gsl + wcslib + ]; cmakeFlags = [ "-DBUILD_TESTER=${if withTester then "on" else "off"}" diff --git a/pkgs/development/libraries/science/biology/mirtk/default.nix b/pkgs/development/libraries/science/biology/mirtk/default.nix index 979f3589b3302c..a1444db5b40ab2 100644 --- a/pkgs/development/libraries/science/biology/mirtk/default.nix +++ b/pkgs/development/libraries/science/biology/mirtk/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, python3 -, boost -, eigen -, libGLU -, fltk -, itk -, vtk -, zlib -, tbb +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + python3, + boost, + eigen, + libGLU, + fltk, + itk, + vtk, + zlib, + tbb, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/science/chemistry/avogadrolibs/default.nix b/pkgs/development/libraries/science/chemistry/avogadrolibs/default.nix index f0d23b7e2e257a..c362a76b222690 100644 --- a/pkgs/development/libraries/science/chemistry/avogadrolibs/default.nix +++ b/pkgs/development/libraries/science/chemistry/avogadrolibs/default.nix @@ -1,9 +1,30 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, zlib, eigen, libGL, spglib -, mmtf-cpp, glew, python3, libarchive, libmsym, msgpack, qttools, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + zlib, + eigen, + libGL, + spglib, + mmtf-cpp, + glew, + python3, + libarchive, + libmsym, + msgpack, + qttools, + wrapQtAppsHook, }: let - pythonWP = python3.withPackages (p: with p; [ openbabel-bindings numpy ]); + pythonWP = python3.withPackages ( + p: with p; [ + openbabel-bindings + numpy + ] + ); # Pure data repositories moleculesRepo = fetchFromGitHub { @@ -25,7 +46,8 @@ let hash = "sha256-Valc5zwlaZ//eDupFouCfWCeID7/4ObU1SDLFJ/mo/g="; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "avogadrolibs"; version = "1.99.0"; diff --git a/pkgs/development/libraries/science/chemistry/molequeue/default.nix b/pkgs/development/libraries/science/chemistry/molequeue/default.nix index 5cd8669c5597db..4ac575e7523899 100644 --- a/pkgs/development/libraries/science/chemistry/molequeue/default.nix +++ b/pkgs/development/libraries/science/chemistry/molequeue/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, qttools, wrapQtAppsHook }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qttools, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "molequeue"; diff --git a/pkgs/development/libraries/science/chemistry/simple-dftd3/default.nix b/pkgs/development/libraries/science/chemistry/simple-dftd3/default.nix index 79be07ccf959d7..ac2d3b1b8b9e8f 100644 --- a/pkgs/development/libraries/science/chemistry/simple-dftd3/default.nix +++ b/pkgs/development/libraries/science/chemistry/simple-dftd3/default.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, gfortran -, meson -, ninja -, pkg-config -, mctc-lib -, mstore -, toml-f -, blas +{ + stdenv, + lib, + fetchFromGitHub, + gfortran, + meson, + ninja, + pkg-config, + mctc-lib, + mstore, + toml-f, + blas, }: assert !blas.isILP64; @@ -24,11 +25,24 @@ stdenv.mkDerivation rec { hash = "sha256-c4xctcMcPQ70ippqbwtinygmnZ5en6ZGF5/v0ZWtzys="; }; - nativeBuildInputs = [ gfortran meson ninja pkg-config ]; - - buildInputs = [ mctc-lib mstore toml-f blas ]; - - outputs = [ "out" "dev" ]; + nativeBuildInputs = [ + gfortran + meson + ninja + pkg-config + ]; + + buildInputs = [ + mctc-lib + mstore + toml-f + blas + ]; + + outputs = [ + "out" + "dev" + ]; doCheck = true; preCheck = '' @@ -38,7 +52,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Reimplementation of the DFT-D3 program"; mainProgram = "s-dftd3"; - license = with licenses; [ lgpl3Only gpl3Only ]; + license = with licenses; [ + lgpl3Only + gpl3Only + ]; homepage = "https://github.com/dftd3/simple-dftd3"; platforms = platforms.linux; maintainers = [ maintainers.sheepforce ]; diff --git a/pkgs/development/libraries/science/chemistry/simple-dftd3/python.nix b/pkgs/development/libraries/science/chemistry/simple-dftd3/python.nix index 267ac53d75d1be..8fe3ef70ef2adc 100644 --- a/pkgs/development/libraries/science/chemistry/simple-dftd3/python.nix +++ b/pkgs/development/libraries/science/chemistry/simple-dftd3/python.nix @@ -1,16 +1,22 @@ -{ buildPythonPackage -, simple-dftd3 -, cffi -, numpy -, toml -, qcengine -, pyscf -, ase -, pytestCheckHook +{ + buildPythonPackage, + simple-dftd3, + cffi, + numpy, + toml, + qcengine, + pyscf, + ase, + pytestCheckHook, }: buildPythonPackage { - inherit (simple-dftd3) pname version src meta; + inherit (simple-dftd3) + pname + version + src + meta + ; # pytest is also required for installation, not only testing nativeBuildInputs = [ pytestCheckHook ]; diff --git a/pkgs/development/libraries/science/chemistry/tblite/default.nix b/pkgs/development/libraries/science/chemistry/tblite/default.nix index 4f8c43a08e4976..aab92c46c25a78 100644 --- a/pkgs/development/libraries/science/chemistry/tblite/default.nix +++ b/pkgs/development/libraries/science/chemistry/tblite/default.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, gfortran -, meson -, ninja -, pkg-config -, blas -, lapack -, mctc-lib -, mstore -, toml-f -, multicharge -, dftd4 -, simple-dftd3 +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + gfortran, + meson, + ninja, + pkg-config, + blas, + lapack, + mctc-lib, + mstore, + toml-f, + multicharge, + dftd4, + simple-dftd3, }: assert !blas.isILP64 && !lapack.isILP64; @@ -55,7 +56,10 @@ stdenv.mkDerivation rec { simple-dftd3 ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; doCheck = true; preCheck = '' @@ -65,7 +69,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Light-weight tight-binding framework"; mainProgram = "tblite"; - license = with licenses; [ gpl3Plus lgpl3Plus ]; + license = with licenses; [ + gpl3Plus + lgpl3Plus + ]; homepage = "https://github.com/tblite/tblite"; platforms = platforms.linux; maintainers = [ maintainers.sheepforce ]; diff --git a/pkgs/development/libraries/science/chemistry/tblite/python.nix b/pkgs/development/libraries/science/chemistry/tblite/python.nix index cfe8668204e275..2f6563295624db 100644 --- a/pkgs/development/libraries/science/chemistry/tblite/python.nix +++ b/pkgs/development/libraries/science/chemistry/tblite/python.nix @@ -1,38 +1,46 @@ -{ lib -, buildPythonPackage -, pythonAtLeast -, fetchpatch -, meson -, ninja -, pkg-config -, tblite -, numpy -, simple-dftd3 -, cffi -, gfortran -, blas -, lapack -, mctc-lib -, mstore -, toml-f -, multicharge -, dftd4 -, setuptools +{ + lib, + buildPythonPackage, + pythonAtLeast, + fetchpatch, + meson, + ninja, + pkg-config, + tblite, + numpy, + simple-dftd3, + cffi, + gfortran, + blas, + lapack, + mctc-lib, + mstore, + toml-f, + multicharge, + dftd4, + setuptools, }: buildPythonPackage { - inherit (tblite) pname version src meta; + inherit (tblite) + pname + version + src + meta + ; - nativeBuildInputs = [ - tblite - meson - ninja - pkg-config - gfortran - mctc-lib - ] ++ lib.optionals (pythonAtLeast "3.12") [ - setuptools - ]; + nativeBuildInputs = + [ + tblite + meson + ninja + pkg-config + gfortran + mctc-lib + ] + ++ lib.optionals (pythonAtLeast "3.12") [ + setuptools + ]; buildInputs = [ tblite @@ -46,8 +54,12 @@ buildPythonPackage { dftd4 ]; - propagatedBuildInputs = [ tblite simple-dftd3 cffi numpy ]; - + propagatedBuildInputs = [ + tblite + simple-dftd3 + cffi + numpy + ]; patches = [ # Add multicharge to the meson deps; otherwise we get missing mod_multicharge errors @@ -61,6 +73,9 @@ buildPythonPackage { ]; format = "other"; - pythonImportsCheck = [ "tblite" "tblite.interface" ]; + pythonImportsCheck = [ + "tblite" + "tblite.interface" + ]; mesonFlags = [ "-Dpython=true" ]; } diff --git a/pkgs/development/libraries/science/electronics/qcsxcad/default.nix b/pkgs/development/libraries/science/electronics/qcsxcad/default.nix index 6ac453aec2c034..25d739f739de2e 100644 --- a/pkgs/development/libraries/science/electronics/qcsxcad/default.nix +++ b/pkgs/development/libraries/science/electronics/qcsxcad/default.nix @@ -1,11 +1,12 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, cmake -, csxcad -, tinyxml -, vtkWithQt5 -, qtbase +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + csxcad, + tinyxml, + vtkWithQt5, + qtbase, }: mkDerivation { @@ -19,7 +20,10 @@ mkDerivation { hash = "sha256-kc9Vnx6jGiQC2K88ZH00b61D/DbWxAIZZwYCsINqtrY="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake diff --git a/pkgs/development/libraries/science/math/clblas/default.nix b/pkgs/development/libraries/science/math/clblas/default.nix index 17dddf90181994..8bd4297fb95bce 100644 --- a/pkgs/development/libraries/science/math/clblas/default.nix +++ b/pkgs/development/libraries/science/math/clblas/default.nix @@ -1,14 +1,19 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, gfortran -, blas -, boost -, python3 -, ocl-icd -, opencl-headers -, Accelerate, CoreGraphics, CoreVideo, OpenCL +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + gfortran, + blas, + boost, + python3, + ocl-icd, + opencl-headers, + Accelerate, + CoreGraphics, + CoreVideo, + OpenCL, }: stdenv.mkDerivation rec { @@ -39,21 +44,28 @@ stdenv.mkDerivation rec { ''; cmakeFlags = [ - "-DBUILD_TEST=OFF" + "-DBUILD_TEST=OFF" ]; - nativeBuildInputs = [ cmake gfortran python3 ]; - buildInputs = [ - blas - boost - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - ocl-icd - opencl-headers - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Accelerate - CoreGraphics - CoreVideo + nativeBuildInputs = [ + cmake + gfortran + python3 ]; + buildInputs = + [ + blas + boost + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + ocl-icd + opencl-headers + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Accelerate + CoreGraphics + CoreVideo + ]; propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ OpenCL ]; diff --git a/pkgs/development/libraries/science/math/libtorch/bin.nix b/pkgs/development/libraries/science/math/libtorch/bin.nix index 8cbe481207e2d5..5118017b247da5 100644 --- a/pkgs/development/libraries/science/math/libtorch/bin.nix +++ b/pkgs/development/libraries/science/math/libtorch/bin.nix @@ -1,16 +1,17 @@ -{ callPackage -, stdenv -, fetchzip -, lib -, libcxx -, llvmPackages -, config +{ + callPackage, + stdenv, + fetchzip, + lib, + libcxx, + llvmPackages, + config, -, addDriverRunpath -, patchelf -, fixDarwinDylibNames + addDriverRunpath, + patchelf, + fixDarwinDylibNames, -, cudaSupport ? config.cudaSupport + cudaSupport ? config.cudaSupport, }: let @@ -24,15 +25,18 @@ let srcs = import ./binary-hashes.nix version; unavailable = throw "libtorch is not available for this platform"; libcxx-for-libtorch = if stdenv.hostPlatform.isDarwin then libcxx else (lib.getLib stdenv.cc.cc); -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit version; pname = "libtorch"; src = fetchzip srcs."${stdenv.hostPlatform.system}-${device}" or unavailable; nativeBuildInputs = - if stdenv.hostPlatform.isDarwin then [ fixDarwinDylibNames ] - else [ patchelf ] ++ lib.optionals cudaSupport [ addDriverRunpath ]; + if stdenv.hostPlatform.isDarwin then + [ fixDarwinDylibNames ] + else + [ patchelf ] ++ lib.optionals cudaSupport [ addDriverRunpath ]; dontBuild = true; dontConfigure = true; @@ -58,38 +62,44 @@ in stdenv.mkDerivation { --replace \''${_IMPORT_PREFIX}/lib "$out/lib" \ ''; - postFixup = let - rpath = lib.makeLibraryPath [ stdenv.cc.cc ]; - in lib.optionalString stdenv.hostPlatform.isLinux '' - find $out/lib -type f \( -name '*.so' -or -name '*.so.*' \) | while read lib; do - echo "setting rpath for $lib..." - patchelf --set-rpath "${rpath}:$out/lib" "$lib" - ${lib.optionalString cudaSupport '' - addDriverRunpath "$lib" - ''} - done - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - for f in $out/lib/*.dylib; do - otool -L $f - done - for f in $out/lib/*.dylib; do - if otool -L $f | grep "@rpath/libomp.dylib" >& /dev/null; then - install_name_tool -change "@rpath/libomp.dylib" ${llvmPackages.openmp}/lib/libomp.dylib $f - fi - install_name_tool -id $out/lib/$(basename $f) $f || true - for rpath in $(otool -L $f | grep rpath | awk '{print $1}');do - install_name_tool -change $rpath $out/lib/$(basename $rpath) $f + postFixup = + let + rpath = lib.makeLibraryPath [ stdenv.cc.cc ]; + in + lib.optionalString stdenv.hostPlatform.isLinux '' + find $out/lib -type f \( -name '*.so' -or -name '*.so.*' \) | while read lib; do + echo "setting rpath for $lib..." + patchelf --set-rpath "${rpath}:$out/lib" "$lib" + ${lib.optionalString cudaSupport '' + addDriverRunpath "$lib" + ''} done - if otool -L $f | grep /usr/lib/libc++ >& /dev/null; then - install_name_tool -change /usr/lib/libc++.1.dylib ${libcxx-for-libtorch.outPath}/lib/libc++.1.0.dylib $f - fi - done - for f in $out/lib/*.dylib; do - otool -L $f - done - ''; + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + for f in $out/lib/*.dylib; do + otool -L $f + done + for f in $out/lib/*.dylib; do + if otool -L $f | grep "@rpath/libomp.dylib" >& /dev/null; then + install_name_tool -change "@rpath/libomp.dylib" ${llvmPackages.openmp}/lib/libomp.dylib $f + fi + install_name_tool -id $out/lib/$(basename $f) $f || true + for rpath in $(otool -L $f | grep rpath | awk '{print $1}');do + install_name_tool -change $rpath $out/lib/$(basename $rpath) $f + done + if otool -L $f | grep /usr/lib/libc++ >& /dev/null; then + install_name_tool -change /usr/lib/libc++.1.dylib ${libcxx-for-libtorch.outPath}/lib/libc++.1.0.dylib $f + fi + done + for f in $out/lib/*.dylib; do + otool -L $f + done + ''; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; passthru.tests.cmake = callPackage ./test { inherit cudaSupport; diff --git a/pkgs/development/libraries/science/math/libtorch/binary-hashes.nix b/pkgs/development/libraries/science/math/libtorch/binary-hashes.nix index 4f6350d931165d..9d6e860e3d0bec 100644 --- a/pkgs/development/libraries/science/math/libtorch/binary-hashes.nix +++ b/pkgs/development/libraries/science/math/libtorch/binary-hashes.nix @@ -1,4 +1,5 @@ -version: builtins.getAttr version { +version: +builtins.getAttr version { "2.5.0" = { aarch64-darwin-cpu = { name = "libtorch-macos-arm64-2.5.0.zip"; diff --git a/pkgs/development/libraries/science/math/libtorch/test/default.nix b/pkgs/development/libraries/science/math/libtorch/test/default.nix index a4b8c2f79140d2..01ae0e7d2c9756 100644 --- a/pkgs/development/libraries/science/math/libtorch/test/default.nix +++ b/pkgs/development/libraries/science/math/libtorch/test/default.nix @@ -1,29 +1,36 @@ -{ lib -, stdenv -, cmake -, libtorch-bin -, linkFarm -, symlinkJoin - -, cudaSupport -, cudaPackages ? {} +{ + lib, + stdenv, + cmake, + libtorch-bin, + linkFarm, + symlinkJoin, + + cudaSupport, + cudaPackages ? { }, }: let inherit (cudaPackages) cudatoolkit cudnn; cudatoolkit_joined = symlinkJoin { name = "${cudatoolkit.name}-unsplit"; - paths = [ cudatoolkit.out cudatoolkit.lib ]; + paths = [ + cudatoolkit.out + cudatoolkit.lib + ]; }; # We do not have access to /run/opengl-driver/lib in the sandbox, # so use a stub instead. - cudaStub = linkFarm "cuda-stub" [{ - name = "libcuda.so.1"; - path = "${cudatoolkit}/lib/stubs/libcuda.so"; - }]; + cudaStub = linkFarm "cuda-stub" [ + { + name = "libcuda.so.1"; + path = "${cudatoolkit}/lib/stubs/libcuda.so"; + } + ]; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "libtorch-test"; version = libtorch-bin.version; @@ -37,11 +44,9 @@ in stdenv.mkDerivation { nativeBuildInputs = [ cmake ]; - buildInputs = [ libtorch-bin ] ++ - lib.optionals cudaSupport [ cudnn ]; + buildInputs = [ libtorch-bin ] ++ lib.optionals cudaSupport [ cudnn ]; - cmakeFlags = lib.optionals cudaSupport - [ "-DCUDA_TOOLKIT_ROOT_DIR=${cudatoolkit_joined}" ]; + cmakeFlags = lib.optionals cudaSupport [ "-DCUDA_TOOLKIT_ROOT_DIR=${cudatoolkit_joined}" ]; doCheck = true; @@ -49,9 +54,11 @@ in stdenv.mkDerivation { touch $out ''; - checkPhase = lib.optionalString cudaSupport '' - LD_LIBRARY_PATH=${cudaStub}''${LD_LIBRARY_PATH:+:}$LD_LIBRARY_PATH \ - '' + '' - ./test - ''; + checkPhase = + lib.optionalString cudaSupport '' + LD_LIBRARY_PATH=${cudaStub}''${LD_LIBRARY_PATH:+:}$LD_LIBRARY_PATH \ + '' + + '' + ./test + ''; } diff --git a/pkgs/development/libraries/science/math/magma/default.nix b/pkgs/development/libraries/science/math/magma/default.nix index 9eb410595974d3..e23728abf203d3 100644 --- a/pkgs/development/libraries/science/math/magma/default.nix +++ b/pkgs/development/libraries/science/math/magma/default.nix @@ -1,6 +1,7 @@ -args@{ callPackage -, lib -, ... +args@{ + callPackage, + lib, + ... }: # Type aliases @@ -16,11 +17,14 @@ let computeName = version: "magma_${strings.replaceStrings [ "." ] [ "_" ] version}"; # buildMagmaPackage :: Release -> Derivation - buildMagmaPackage = magmaRelease: callPackage ./generic.nix ( - (builtins.removeAttrs args [ "callPackage" ]) // { - inherit magmaRelease; - } - ); + buildMagmaPackage = + magmaRelease: + callPackage ./generic.nix ( + (builtins.removeAttrs args [ "callPackage" ]) + // { + inherit magmaRelease; + } + ); # Reverse the list to have the latest release first # magmaReleases :: List Release @@ -50,4 +54,3 @@ let in builds - diff --git a/pkgs/development/libraries/science/math/magma/generic.nix b/pkgs/development/libraries/science/math/magma/generic.nix index b1b2b80be0fc66..9cd94467981793 100644 --- a/pkgs/development/libraries/science/math/magma/generic.nix +++ b/pkgs/development/libraries/science/math/magma/generic.nix @@ -5,41 +5,44 @@ # supportedGpuTargets: List String # } -{ autoPatchelfHook -, blas -, cmake -, cudaPackages_11 ? null -, cudaPackages -, cudaSupport ? config.cudaSupport -, fetchurl -, gfortran -, gpuTargets ? [ ] # Non-CUDA targets, that is HIP -, rocmPackages_5 -, lapack -, lib -, libpthreadstubs -, magmaRelease -, ninja -, python3 -, config +{ + autoPatchelfHook, + blas, + cmake, + cudaPackages_11 ? null, + cudaPackages, + cudaSupport ? config.cudaSupport, + fetchurl, + gfortran, + gpuTargets ? [ ], # Non-CUDA targets, that is HIP + rocmPackages_5, + lapack, + lib, + libpthreadstubs, + magmaRelease, + ninja, + python3, + config, # At least one back-end has to be enabled, # and we can't default to CUDA since it's unfree -, rocmSupport ? !cudaSupport -, static ? stdenv.hostPlatform.isStatic -, stdenv + rocmSupport ? !cudaSupport, + static ? stdenv.hostPlatform.isStatic, + stdenv, }: - let - inherit (lib) getLib lists strings trivial; + inherit (lib) + getLib + lists + strings + trivial + ; inherit (magmaRelease) version hash supportedGpuTargets; # Per https://icl.utk.edu/magma/downloads, support for CUDA 12 wasn't added until 2.7.1. # If we're building a version prior to that, use the latest release of the 11.x series. effectiveCudaPackages = - if strings.versionOlder version "2.7.1" - then cudaPackages_11 - else cudaPackages; + if strings.versionOlder version "2.7.1" then cudaPackages_11 else cudaPackages; inherit (effectiveCudaPackages) cudaAtLeast flags cudaOlder; @@ -62,17 +65,16 @@ let unsupportedCustomGpuTargets = lists.subtractLists supportedCustomGpuTargets gpuTargets; # Use trivial.warnIf to print a warning if any unsupported GPU targets are specified. - gpuArchWarner = supported: unsupported: - trivial.throwIf (supported == [ ]) - ( - "No supported GPU targets specified. Requested GPU targets: " - + strings.concatStringsSep ", " unsupported - ) - supported; + gpuArchWarner = + supported: unsupported: + trivial.throwIf (supported == [ ]) ( + "No supported GPU targets specified. Requested GPU targets: " + + strings.concatStringsSep ", " unsupported + ) supported; gpuTargetString = strings.concatStringsSep "," ( if gpuTargets != [ ] then - # If gpuTargets is specified, it always takes priority. + # If gpuTargets is specified, it always takes priority. gpuArchWarner supportedCustomGpuTargets unsupportedCustomGpuTargets else if rocmSupport then gpuArchWarner supportedRocmArches unsupportedRocmArches @@ -108,7 +110,10 @@ stdenv.mkDerivation { # Magma doesn't have anything which could be run under doCheck, but it does build test suite executables. # These are moved to $test/bin/ and $test/lib/ in postInstall. - outputs = ["out" "test"]; + outputs = [ + "out" + "test" + ]; # Fixup for the python test runners postPatch = '' @@ -119,57 +124,71 @@ stdenv.mkDerivation { "print(f\"{cmdp} doesn't exist (original name: {cmd}, precision: {precision})\", file=sys.stderr)" ''; - nativeBuildInputs = [ - autoPatchelfHook - cmake - ninja - gfortran - ] ++ lists.optionals cudaSupport [ - effectiveCudaPackages.cuda_nvcc - ]; - - buildInputs = [ - libpthreadstubs - lapack - blas - python3 - (getLib gfortran.cc) # libgfortran.so - ] ++ lists.optionals cudaSupport (with effectiveCudaPackages; [ - cuda_cudart # cuda_runtime.h - libcublas # cublas_v2.h - libcusparse # cusparse.h - ] ++ lists.optionals (cudaOlder "11.8") [ - cuda_nvprof # - ] ++ lists.optionals (cudaAtLeast "11.8") [ - cuda_profiler_api # - ] ++ lists.optionals (cudaAtLeast "12.0") [ - cuda_cccl # - ]) ++ lists.optionals rocmSupport [ - rocmPackages.clr - rocmPackages.hipblas - rocmPackages.hipsparse - rocmPackages.llvm.openmp - ]; - - cmakeFlags = [ - (strings.cmakeFeature "GPU_TARGET" gpuTargetString) - (strings.cmakeBool "MAGMA_ENABLE_CUDA" cudaSupport) - (strings.cmakeBool "MAGMA_ENABLE_HIP" rocmSupport) - (strings.cmakeBool "BUILD_SHARED_LIBS" (!static)) - # Set the Fortran name mangling scheme explicitly. We must set FORTRAN_CONVENTION manually because it will - # otherwise not be set in NVCC_FLAGS or DEVCCFLAGS (which we cannot modify). - # See https://github.com/NixOS/nixpkgs/issues/281656#issuecomment-1902931289 - (strings.cmakeBool "USE_FORTRAN" true) - (strings.cmakeFeature "CMAKE_C_FLAGS" "-DADD_") - (strings.cmakeFeature "CMAKE_CXX_FLAGS" "-DADD_") - (strings.cmakeFeature "FORTRAN_CONVENTION" "-DADD_") - ] ++ lists.optionals cudaSupport [ - (strings.cmakeFeature "CMAKE_CUDA_ARCHITECTURES" cudaArchitecturesString) - (strings.cmakeFeature "MIN_ARCH" minArch) # Disarms magma's asserts - ] ++ lists.optionals rocmSupport [ - (strings.cmakeFeature "CMAKE_C_COMPILER" "${rocmPackages.clr}/bin/hipcc") - (strings.cmakeFeature "CMAKE_CXX_COMPILER" "${rocmPackages.clr}/bin/hipcc") - ]; + nativeBuildInputs = + [ + autoPatchelfHook + cmake + ninja + gfortran + ] + ++ lists.optionals cudaSupport [ + effectiveCudaPackages.cuda_nvcc + ]; + + buildInputs = + [ + libpthreadstubs + lapack + blas + python3 + (getLib gfortran.cc) # libgfortran.so + ] + ++ lists.optionals cudaSupport ( + with effectiveCudaPackages; + [ + cuda_cudart # cuda_runtime.h + libcublas # cublas_v2.h + libcusparse # cusparse.h + ] + ++ lists.optionals (cudaOlder "11.8") [ + cuda_nvprof # + ] + ++ lists.optionals (cudaAtLeast "11.8") [ + cuda_profiler_api # + ] + ++ lists.optionals (cudaAtLeast "12.0") [ + cuda_cccl # + ] + ) + ++ lists.optionals rocmSupport [ + rocmPackages.clr + rocmPackages.hipblas + rocmPackages.hipsparse + rocmPackages.llvm.openmp + ]; + + cmakeFlags = + [ + (strings.cmakeFeature "GPU_TARGET" gpuTargetString) + (strings.cmakeBool "MAGMA_ENABLE_CUDA" cudaSupport) + (strings.cmakeBool "MAGMA_ENABLE_HIP" rocmSupport) + (strings.cmakeBool "BUILD_SHARED_LIBS" (!static)) + # Set the Fortran name mangling scheme explicitly. We must set FORTRAN_CONVENTION manually because it will + # otherwise not be set in NVCC_FLAGS or DEVCCFLAGS (which we cannot modify). + # See https://github.com/NixOS/nixpkgs/issues/281656#issuecomment-1902931289 + (strings.cmakeBool "USE_FORTRAN" true) + (strings.cmakeFeature "CMAKE_C_FLAGS" "-DADD_") + (strings.cmakeFeature "CMAKE_CXX_FLAGS" "-DADD_") + (strings.cmakeFeature "FORTRAN_CONVENTION" "-DADD_") + ] + ++ lists.optionals cudaSupport [ + (strings.cmakeFeature "CMAKE_CUDA_ARCHITECTURES" cudaArchitecturesString) + (strings.cmakeFeature "MIN_ARCH" minArch) # Disarms magma's asserts + ] + ++ lists.optionals rocmSupport [ + (strings.cmakeFeature "CMAKE_C_COMPILER" "${rocmPackages.clr}/bin/hipcc") + (strings.cmakeFeature "CMAKE_CXX_COMPILER" "${rocmPackages.clr}/bin/hipcc") + ]; # Magma doesn't have a test suite we can easily run, just loose executables, all of which require a GPU. doCheck = false; diff --git a/pkgs/development/libraries/science/math/openblas/default.nix b/pkgs/development/libraries/science/math/openblas/default.nix index 54b4f7cabd92a0..0a81f0f8af3938 100644 --- a/pkgs/development/libraries/science/math/openblas/default.nix +++ b/pkgs/development/libraries/science/math/openblas/default.nix @@ -1,39 +1,46 @@ -{ lib, stdenv, fetchFromGitHub, perl, which -# Most packages depending on openblas expect integer width to match -# pointer width, but some expect to use 32-bit integers always -# (for compatibility with reference BLAS). -, blas64 ? null -# Multi-threaded applications must not call a threaded OpenBLAS -# (the only exception is when an application uses OpenMP as its -# *only* form of multi-threading). See -# https://github.com/OpenMathLib/OpenBLAS/wiki/Faq/4bded95e8dc8aadc70ce65267d1093ca7bdefc4c#multi-threaded -# https://github.com/OpenMathLib/OpenBLAS/issues/2543 -# This flag builds a single-threaded OpenBLAS using the flags -# stated in thre. -, singleThreaded ? false -, buildPackages -# Select a specific optimization target (other than the default) -# See https://github.com/OpenMathLib/OpenBLAS/blob/develop/TargetList.txt -, target ? null -# Select whether DYNAMIC_ARCH is enabled or not. -, dynamicArch ? null -# enable AVX512 optimized kernels. -# These kernels have been a source of trouble in the past. -# Use with caution. -, enableAVX512 ? false -, enableStatic ? stdenv.hostPlatform.isStatic -, enableShared ? !stdenv.hostPlatform.isStatic - -# for passthru.tests -, ceres-solver -, giac -, octave -, opencv -, python3 -, openmp ? null +{ + lib, + stdenv, + fetchFromGitHub, + perl, + which, + # Most packages depending on openblas expect integer width to match + # pointer width, but some expect to use 32-bit integers always + # (for compatibility with reference BLAS). + blas64 ? null, + # Multi-threaded applications must not call a threaded OpenBLAS + # (the only exception is when an application uses OpenMP as its + # *only* form of multi-threading). See + # https://github.com/OpenMathLib/OpenBLAS/wiki/Faq/4bded95e8dc8aadc70ce65267d1093ca7bdefc4c#multi-threaded + # https://github.com/OpenMathLib/OpenBLAS/issues/2543 + # This flag builds a single-threaded OpenBLAS using the flags + # stated in thre. + singleThreaded ? false, + buildPackages, + # Select a specific optimization target (other than the default) + # See https://github.com/OpenMathLib/OpenBLAS/blob/develop/TargetList.txt + target ? null, + # Select whether DYNAMIC_ARCH is enabled or not. + dynamicArch ? null, + # enable AVX512 optimized kernels. + # These kernels have been a source of trouble in the past. + # Use with caution. + enableAVX512 ? false, + enableStatic ? stdenv.hostPlatform.isStatic, + enableShared ? !stdenv.hostPlatform.isStatic, + + # for passthru.tests + ceres-solver, + giac, + octave, + opencv, + python3, + openmp ? null, }: -let blas64_ = blas64; in +let + blas64_ = blas64; +in let setTarget = x: if target == null then x else target; @@ -127,21 +134,23 @@ in let config = configs.${stdenv.hostPlatform.system} - or (throw "unsupported system: ${stdenv.hostPlatform.system}"); + or (throw "unsupported system: ${stdenv.hostPlatform.system}"); in let - blas64 = - if blas64_ != null - then blas64_ - else lib.hasPrefix "x86_64" stdenv.hostPlatform.system; + blas64 = if blas64_ != null then blas64_ else lib.hasPrefix "x86_64" stdenv.hostPlatform.system; # Convert flag values to format OpenBLAS's build expects. # `toString` is almost what we need other than bools, # which we need to map {true -> 1, false -> 0} # (`toString` produces empty string `""` for false instead of `0`) - mkMakeFlagValue = val: - if !builtins.isBool val then toString val - else if val then "1" else "0"; + mkMakeFlagValue = + val: + if !builtins.isBool val then + toString val + else if val then + "1" + else + "0"; mkMakeFlagsFromConfig = lib.mapAttrsToList (var: val: "${var}=${mkMakeFlagValue val}"); shlibExt = stdenv.hostPlatform.extensions.sharedLibrary; @@ -151,7 +160,10 @@ stdenv.mkDerivation rec { pname = "openblas"; version = "0.3.28"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "OpenMathLib"; @@ -173,18 +185,22 @@ stdenv.mkDerivation rec { # In either case, OpenBLAS must only be used by trusted code--it is # inherently unsuitable for security-conscious applications--so there should # be no objection to disabling these hardening measures. - hardeningDisable = [ - # don't modify or move the stack - "stackprotector" "pic" - # don't alter index arithmetic - "strictoverflow" - # don't interfere with dynamic target detection - "relro" "bindnow" - ] ++ lib.optionals stdenv.hostPlatform.isAarch64 [ - # "__builtin_clear_padding not supported for variable length aggregates" - # in aarch64-specific code - "trivialautovarinit" - ]; + hardeningDisable = + [ + # don't modify or move the stack + "stackprotector" + "pic" + # don't alter index arithmetic + "strictoverflow" + # don't interfere with dynamic target detection + "relro" + "bindnow" + ] + ++ lib.optionals stdenv.hostPlatform.isAarch64 [ + # "__builtin_clear_padding not supported for variable length aggregates" + # in aarch64-specific code + "trivialautovarinit" + ]; nativeBuildInputs = [ perl @@ -200,74 +216,90 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - makeFlags = mkMakeFlagsFromConfig (config // { - FC = "${stdenv.cc.targetPrefix}gfortran"; - CC = "${stdenv.cc.targetPrefix}${if stdenv.cc.isClang then "clang" else "cc"}"; - PREFIX = placeholder "out"; - OPENBLAS_INCLUDE_DIR = "${placeholder "dev"}/include"; - NUM_THREADS = 64; - INTERFACE64 = blas64; - NO_STATIC = !enableStatic; - NO_SHARED = !enableShared; - CROSS = stdenv.hostPlatform != stdenv.buildPlatform; - HOSTCC = "cc"; - # Makefile.system only checks defined status - # This seems to be a bug in the openblas Makefile: - # on x86_64 it expects NO_BINARY_MODE= - # but on aarch64 it expects NO_BINARY_MODE=0 - NO_BINARY_MODE = if stdenv.hostPlatform.isx86_64 - then toString (stdenv.hostPlatform != stdenv.buildPlatform) - else stdenv.hostPlatform != stdenv.buildPlatform; - # This disables automatic build job count detection (which honours neither enableParallelBuilding nor NIX_BUILD_CORES) - # and uses the main make invocation's job count, falling back to 1 if no parallelism is used. - # https://github.com/OpenMathLib/OpenBLAS/blob/v0.3.20/getarch.c#L1781-L1792 - MAKE_NB_JOBS = 0; - } // (lib.optionalAttrs stdenv.cc.isClang { - LDFLAGS = "-L${lib.getLib buildPackages.gfortran.cc}/lib"; # contains `libgfortran.so`; building with clang needs this, gcc has it implicit - }) // (lib.optionalAttrs singleThreaded { - # As described on https://github.com/OpenMathLib/OpenBLAS/wiki/Faq/4bded95e8dc8aadc70ce65267d1093ca7bdefc4c#multi-threaded - USE_THREAD = false; - USE_LOCKING = true; # available with openblas >= 0.3.7 - USE_OPENMP = false; # openblas will refuse building with both USE_OPENMP=1 and USE_THREAD=0 - })); + makeFlags = mkMakeFlagsFromConfig ( + config + // { + FC = "${stdenv.cc.targetPrefix}gfortran"; + CC = "${stdenv.cc.targetPrefix}${if stdenv.cc.isClang then "clang" else "cc"}"; + PREFIX = placeholder "out"; + OPENBLAS_INCLUDE_DIR = "${placeholder "dev"}/include"; + NUM_THREADS = 64; + INTERFACE64 = blas64; + NO_STATIC = !enableStatic; + NO_SHARED = !enableShared; + CROSS = stdenv.hostPlatform != stdenv.buildPlatform; + HOSTCC = "cc"; + # Makefile.system only checks defined status + # This seems to be a bug in the openblas Makefile: + # on x86_64 it expects NO_BINARY_MODE= + # but on aarch64 it expects NO_BINARY_MODE=0 + NO_BINARY_MODE = + if stdenv.hostPlatform.isx86_64 then + toString (stdenv.hostPlatform != stdenv.buildPlatform) + else + stdenv.hostPlatform != stdenv.buildPlatform; + # This disables automatic build job count detection (which honours neither enableParallelBuilding nor NIX_BUILD_CORES) + # and uses the main make invocation's job count, falling back to 1 if no parallelism is used. + # https://github.com/OpenMathLib/OpenBLAS/blob/v0.3.20/getarch.c#L1781-L1792 + MAKE_NB_JOBS = 0; + } + // (lib.optionalAttrs stdenv.cc.isClang { + LDFLAGS = "-L${lib.getLib buildPackages.gfortran.cc}/lib"; # contains `libgfortran.so`; building with clang needs this, gcc has it implicit + }) + // (lib.optionalAttrs singleThreaded { + # As described on https://github.com/OpenMathLib/OpenBLAS/wiki/Faq/4bded95e8dc8aadc70ce65267d1093ca7bdefc4c#multi-threaded + USE_THREAD = false; + USE_LOCKING = true; # available with openblas >= 0.3.7 + USE_OPENMP = false; # openblas will refuse building with both USE_OPENMP=1 and USE_THREAD=0 + }) + ); doCheck = true; checkTarget = "tests"; - postInstall = '' - # Write pkgconfig aliases. Upstream report: - # https://github.com/OpenMathLib/OpenBLAS/issues/1740 - for alias in blas cblas lapack; do - cat < $out/lib/pkgconfig/$alias.pc -Name: $alias -Version: ${version} -Description: $alias provided by the OpenBLAS package. -Cflags: -I$dev/include -Libs: -L$out/lib -lopenblas -EOF - done - - # Setup symlinks for blas / lapack - '' + lib.optionalString enableShared '' - ln -s $out/lib/libopenblas${shlibExt} $out/lib/libblas${shlibExt} - ln -s $out/lib/libopenblas${shlibExt} $out/lib/libcblas${shlibExt} - ln -s $out/lib/libopenblas${shlibExt} $out/lib/liblapack${shlibExt} - ln -s $out/lib/libopenblas${shlibExt} $out/lib/liblapacke${shlibExt} - '' + lib.optionalString (stdenv.hostPlatform.isLinux && enableShared) '' - ln -s $out/lib/libopenblas${shlibExt} $out/lib/libblas${shlibExt}.3 - ln -s $out/lib/libopenblas${shlibExt} $out/lib/libcblas${shlibExt}.3 - ln -s $out/lib/libopenblas${shlibExt} $out/lib/liblapack${shlibExt}.3 - ln -s $out/lib/libopenblas${shlibExt} $out/lib/liblapacke${shlibExt}.3 - '' + lib.optionalString enableStatic '' - ln -s $out/lib/libopenblas.a $out/lib/libblas.a - ln -s $out/lib/libopenblas.a $out/lib/libcblas.a - ln -s $out/lib/libopenblas.a $out/lib/liblapack.a - ln -s $out/lib/libopenblas.a $out/lib/liblapacke.a - ''; + postInstall = + '' + # Write pkgconfig aliases. Upstream report: + # https://github.com/OpenMathLib/OpenBLAS/issues/1740 + for alias in blas cblas lapack; do + cat < $out/lib/pkgconfig/$alias.pc + Name: $alias + Version: ${version} + Description: $alias provided by the OpenBLAS package. + Cflags: -I$dev/include + Libs: -L$out/lib -lopenblas + EOF + done + + # Setup symlinks for blas / lapack + '' + + lib.optionalString enableShared '' + ln -s $out/lib/libopenblas${shlibExt} $out/lib/libblas${shlibExt} + ln -s $out/lib/libopenblas${shlibExt} $out/lib/libcblas${shlibExt} + ln -s $out/lib/libopenblas${shlibExt} $out/lib/liblapack${shlibExt} + ln -s $out/lib/libopenblas${shlibExt} $out/lib/liblapacke${shlibExt} + '' + + lib.optionalString (stdenv.hostPlatform.isLinux && enableShared) '' + ln -s $out/lib/libopenblas${shlibExt} $out/lib/libblas${shlibExt}.3 + ln -s $out/lib/libopenblas${shlibExt} $out/lib/libcblas${shlibExt}.3 + ln -s $out/lib/libopenblas${shlibExt} $out/lib/liblapack${shlibExt}.3 + ln -s $out/lib/libopenblas${shlibExt} $out/lib/liblapacke${shlibExt}.3 + '' + + lib.optionalString enableStatic '' + ln -s $out/lib/libopenblas.a $out/lib/libblas.a + ln -s $out/lib/libopenblas.a $out/lib/libcblas.a + ln -s $out/lib/libopenblas.a $out/lib/liblapack.a + ln -s $out/lib/libopenblas.a $out/lib/liblapacke.a + ''; passthru.tests = { inherit (python3.pkgs) numpy scipy scikit-learn; - inherit ceres-solver giac octave opencv; + inherit + ceres-solver + giac + octave + opencv + ; }; meta = with lib; { diff --git a/pkgs/development/libraries/science/math/or-tools/default.nix b/pkgs/development/libraries/science/math/or-tools/default.nix index 4589f6f1ec4ba2..c460694da0fed1 100644 --- a/pkgs/development/libraries/science/math/or-tools/default.nix +++ b/pkgs/development/libraries/science/math/or-tools/default.nix @@ -1,22 +1,23 @@ -{ abseil-cpp -, bzip2 -, cbc -, cmake -, DarwinTools # sw_vers -, eigen -, ensureNewerSourcesForZipFilesHook -, fetchFromGitHub -, substituteAll -, glpk -, lib -, pkg-config -, protobuf -, python -, re2 -, stdenv -, swig -, unzip -, zlib +{ + abseil-cpp, + bzip2, + cbc, + cmake, + DarwinTools, # sw_vers + eigen, + ensureNewerSourcesForZipFilesHook, + fetchFromGitHub, + substituteAll, + glpk, + lib, + pkg-config, + protobuf, + python, + re2, + stdenv, + swig, + unzip, + zlib, }: let @@ -70,20 +71,23 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ - cmake - ensureNewerSourcesForZipFilesHook - pkg-config - python.pythonOnBuildForHost - swig - unzip - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - DarwinTools - ] ++ (with python.pythonOnBuildForHost.pkgs; [ - pip - mypy-protobuf - mypy - ]); + nativeBuildInputs = + [ + cmake + ensureNewerSourcesForZipFilesHook + pkg-config + python.pythonOnBuildForHost + swig + unzip + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + DarwinTools + ] + ++ (with python.pythonOnBuildForHost.pkgs; [ + pip + mypy-protobuf + mypy + ]); buildInputs = [ abseil-cpp bzip2 @@ -135,7 +139,10 @@ stdenv.mkDerivation rec { pip install --prefix="$python" python/ ''; - outputs = [ "out" "python" ]; + outputs = [ + "out" + "python" + ]; meta = with lib; { homepage = "https://github.com/google/or-tools"; diff --git a/pkgs/development/libraries/science/math/p4est-sc/default.nix b/pkgs/development/libraries/science/math/p4est-sc/default.nix index 3ac61e5c2b360c..bab98a1e1cfb4a 100644 --- a/pkgs/development/libraries/science/math/p4est-sc/default.nix +++ b/pkgs/development/libraries/science/math/p4est-sc/default.nix @@ -1,7 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, mpiCheckPhaseHook -, autoreconfHook, pkg-config -, p4est-sc-debugEnable ? true, p4est-sc-mpiSupport ? true -, mpi, zlib +{ + lib, + stdenv, + fetchFromGitHub, + mpiCheckPhaseHook, + autoreconfHook, + pkg-config, + p4est-sc-debugEnable ? true, + p4est-sc-mpiSupport ? true, + mpi, + zlib, }: let @@ -22,8 +29,11 @@ stdenv.mkDerivation { }; strictDeps = true; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - propagatedNativeBuildInputs = lib.optional mpiSupport mpi ; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + propagatedNativeBuildInputs = lib.optional mpiSupport mpi; propagatedBuildInputs = [ zlib ]; inherit debugEnable mpiSupport; @@ -35,10 +45,10 @@ stdenv.mkDerivation { ${lib.optionalString mpiSupport "unset CC"} ''; - configureFlags = [ "--enable-pthread=-pthread" ] + configureFlags = + [ "--enable-pthread=-pthread" ] ++ lib.optional debugEnable "--enable-debug" - ++ lib.optional mpiSupport "--enable-mpi" - ; + ++ lib.optional mpiSupport "--enable-mpi"; dontDisableStatic = true; enableParallelBuilding = true; diff --git a/pkgs/development/libraries/science/math/p4est/default.nix b/pkgs/development/libraries/science/math/p4est/default.nix index 1218c695590ed1..4f2e1bcc159c47 100644 --- a/pkgs/development/libraries/science/math/p4est/default.nix +++ b/pkgs/development/libraries/science/math/p4est/default.nix @@ -1,10 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, p4est-withMetis ? true, metis -, p4est-sc +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + p4est-withMetis ? true, + metis, + p4est-sc, }: let @@ -25,7 +27,10 @@ stdenv.mkDerivation { }; strictDeps = true; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; propagatedBuildInputs = [ p4est-sc ]; buildInputs = lib.optional withMetis metis; inherit debugEnable mpiSupport withMetis; @@ -41,12 +46,15 @@ stdenv.mkDerivation { unset CC ''; - configureFlags = p4est-sc.configureFlags - ++ [ "--with-sc=${p4est-sc}" ] - ++ lib.optional withMetis "--with-metis" - ; + configureFlags = + p4est-sc.configureFlags ++ [ "--with-sc=${p4est-sc}" ] ++ lib.optional withMetis "--with-metis"; - inherit (p4est-sc) makeFlags dontDisableStatic enableParallelBuilding doCheck; + inherit (p4est-sc) + makeFlags + dontDisableStatic + enableParallelBuilding + doCheck + ; meta = { branch = "prev3-develop"; diff --git a/pkgs/development/libraries/science/math/suitesparse/4.2.nix b/pkgs/development/libraries/science/math/suitesparse/4.2.nix index c87bc4d31a8c23..67f580b145dcfa 100644 --- a/pkgs/development/libraries/science/math/suitesparse/4.2.nix +++ b/pkgs/development/libraries/science/math/suitesparse/4.2.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, gfortran, blas, lapack }: +{ + lib, + stdenv, + fetchurl, + gfortran, + blas, + lapack, +}: let int_t = if blas.isILP64 then "int64_t" else "int32_t"; @@ -7,12 +14,15 @@ stdenv.mkDerivation rec { version = "4.2.1"; pname = "suitesparse"; src = fetchurl { - url = "http://www.cise.ufl.edu/research/sparse/SuiteSparse/SuiteSparse-${version}.tar.gz" ; + url = "http://www.cise.ufl.edu/research/sparse/SuiteSparse/SuiteSparse-${version}.tar.gz"; sha256 = "1ga69637x7kdkiy3w3lq9dvva7220bdangv2lch2wx1hpi83h0p8"; }; nativeBuildInputs = [ gfortran ]; - buildInputs = [ blas lapack ]; + buildInputs = [ + blas + lapack + ]; preConfigure = '' mkdir -p $out/lib @@ -36,7 +46,11 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "http://faculty.cse.tamu.edu/davis/suitesparse.html"; description = "Suite of sparse matrix algorithms"; - license = with licenses; [ bsd2 gpl2Plus lgpl21Plus ]; + license = with licenses; [ + bsd2 + gpl2Plus + lgpl21Plus + ]; maintainers = with maintainers; [ ttuegel ]; platforms = with platforms; unix; }; diff --git a/pkgs/development/libraries/science/math/suitesparse/4.4.nix b/pkgs/development/libraries/science/math/suitesparse/4.4.nix index ef859cfc1ca2af..98a1d4599f4c5c 100644 --- a/pkgs/development/libraries/science/math/suitesparse/4.4.nix +++ b/pkgs/development/libraries/science/math/suitesparse/4.4.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchurl, gfortran, blas, lapack -, config -, enableCuda ? config.cudaSupport, cudatoolkit +{ + lib, + stdenv, + fetchurl, + gfortran, + blas, + lapack, + config, + enableCuda ? config.cudaSupport, + cudatoolkit, }: let @@ -16,35 +23,36 @@ stdenv.mkDerivation rec { sha256 = "1zdn1y0ij6amj7smmcslkqgbqv9yy5cwmbyzqc9v6drzdzllgbpj"; }; - preConfigure = '' - mkdir -p $out/lib - mkdir -p $out/include + preConfigure = + '' + mkdir -p $out/lib + mkdir -p $out/include - sed -i "SuiteSparse_config/SuiteSparse_config.mk" \ - -e 's/METIS .*$/METIS =/' \ - -e 's/METIS_PATH .*$/METIS_PATH =/' \ - -e '/CHOLMOD_CONFIG/ s/$/-DNPARTITION -DLONGBLAS=${int_t}/' \ - -e '/UMFPACK_CONFIG/ s/$/-DLONGBLAS=${int_t}/' - '' - + lib.optionalString stdenv.hostPlatform.isDarwin '' - sed -i "SuiteSparse_config/SuiteSparse_config.mk" \ - -e 's/^[[:space:]]*\(LIB = -lm\) -lrt/\1/' - '' - + lib.optionalString enableCuda '' - sed -i "SuiteSparse_config/SuiteSparse_config.mk" \ - -e 's|^[[:space:]]*\(CUDA_ROOT =\)|CUDA_ROOT = ${cudatoolkit}|' \ - -e 's|^[[:space:]]*\(GPU_BLAS_PATH =\)|GPU_BLAS_PATH = $(CUDA_ROOT)|' \ - -e 's|^[[:space:]]*\(GPU_CONFIG =\)|GPU_CONFIG = -I$(CUDA_ROOT)/include -DGPU_BLAS -DCHOLMOD_OMP_NUM_THREADS=$(NIX_BUILD_CORES) |' \ - -e 's|^[[:space:]]*\(CUDA_PATH =\)|CUDA_PATH = $(CUDA_ROOT)|' \ - -e 's|^[[:space:]]*\(CUDART_LIB =\)|CUDART_LIB = $(CUDA_ROOT)/lib64/libcudart.so|' \ - -e 's|^[[:space:]]*\(CUBLAS_LIB =\)|CUBLAS_LIB = $(CUDA_ROOT)/lib64/libcublas.so|' \ - -e 's|^[[:space:]]*\(CUDA_INC_PATH =\)|CUDA_INC_PATH = $(CUDA_ROOT)/include/|' \ - -e 's|^[[:space:]]*\(NV20 =\)|NV20 = -arch=sm_20 -Xcompiler -fPIC|' \ - -e 's|^[[:space:]]*\(NV30 =\)|NV30 = -arch=sm_30 -Xcompiler -fPIC|' \ - -e 's|^[[:space:]]*\(NV35 =\)|NV35 = -arch=sm_35 -Xcompiler -fPIC|' \ - -e 's|^[[:space:]]*\(NVCC =\) echo|NVCC = $(CUDA_ROOT)/bin/nvcc|' \ - -e 's|^[[:space:]]*\(NVCCFLAGS =\)|NVCCFLAGS = $(NV20) -O3 -gencode=arch=compute_20,code=sm_20 -gencode=arch=compute_30,code=sm_30 -gencode=arch=compute_35,code=sm_35 -gencode=arch=compute_60,code=sm_60|' - ''; + sed -i "SuiteSparse_config/SuiteSparse_config.mk" \ + -e 's/METIS .*$/METIS =/' \ + -e 's/METIS_PATH .*$/METIS_PATH =/' \ + -e '/CHOLMOD_CONFIG/ s/$/-DNPARTITION -DLONGBLAS=${int_t}/' \ + -e '/UMFPACK_CONFIG/ s/$/-DLONGBLAS=${int_t}/' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + sed -i "SuiteSparse_config/SuiteSparse_config.mk" \ + -e 's/^[[:space:]]*\(LIB = -lm\) -lrt/\1/' + '' + + lib.optionalString enableCuda '' + sed -i "SuiteSparse_config/SuiteSparse_config.mk" \ + -e 's|^[[:space:]]*\(CUDA_ROOT =\)|CUDA_ROOT = ${cudatoolkit}|' \ + -e 's|^[[:space:]]*\(GPU_BLAS_PATH =\)|GPU_BLAS_PATH = $(CUDA_ROOT)|' \ + -e 's|^[[:space:]]*\(GPU_CONFIG =\)|GPU_CONFIG = -I$(CUDA_ROOT)/include -DGPU_BLAS -DCHOLMOD_OMP_NUM_THREADS=$(NIX_BUILD_CORES) |' \ + -e 's|^[[:space:]]*\(CUDA_PATH =\)|CUDA_PATH = $(CUDA_ROOT)|' \ + -e 's|^[[:space:]]*\(CUDART_LIB =\)|CUDART_LIB = $(CUDA_ROOT)/lib64/libcudart.so|' \ + -e 's|^[[:space:]]*\(CUBLAS_LIB =\)|CUBLAS_LIB = $(CUDA_ROOT)/lib64/libcublas.so|' \ + -e 's|^[[:space:]]*\(CUDA_INC_PATH =\)|CUDA_INC_PATH = $(CUDA_ROOT)/include/|' \ + -e 's|^[[:space:]]*\(NV20 =\)|NV20 = -arch=sm_20 -Xcompiler -fPIC|' \ + -e 's|^[[:space:]]*\(NV30 =\)|NV30 = -arch=sm_30 -Xcompiler -fPIC|' \ + -e 's|^[[:space:]]*\(NV35 =\)|NV35 = -arch=sm_35 -Xcompiler -fPIC|' \ + -e 's|^[[:space:]]*\(NVCC =\) echo|NVCC = $(CUDA_ROOT)/bin/nvcc|' \ + -e 's|^[[:space:]]*\(NVCCFLAGS =\)|NVCCFLAGS = $(NV20) -O3 -gencode=arch=compute_20,code=sm_20 -gencode=arch=compute_30,code=sm_30 -gencode=arch=compute_35,code=sm_35 -gencode=arch=compute_60,code=sm_60|' + ''; makeFlags = [ "PREFIX=\"$(out)\"" @@ -63,7 +71,11 @@ stdenv.mkDerivation rec { for i in "$out"/lib/lib*.a; do ar -x $i done - ${if enableCuda then cudatoolkit else stdenv.cc.outPath}/bin/${if enableCuda then "nvcc" else "cc"} *.o ${if stdenv.hostPlatform.isDarwin then "-dynamiclib" else "--shared"} -o "$out/lib/libsuitesparse${SHLIB_EXT}" -lblas ${lib.optionalString enableCuda "-lcublas"} + ${if enableCuda then cudatoolkit else stdenv.cc.outPath}/bin/${ + if enableCuda then "nvcc" else "cc" + } *.o ${ + if stdenv.hostPlatform.isDarwin then "-dynamiclib" else "--shared" + } -o "$out/lib/libsuitesparse${SHLIB_EXT}" -lblas ${lib.optionalString enableCuda "-lcublas"} ) for i in umfpack cholmod amd camd colamd spqr; do ln -s libsuitesparse${SHLIB_EXT} "$out"/lib/lib$i${SHLIB_EXT} @@ -87,12 +99,19 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ gfortran ]; - buildInputs = [ blas lapack ]; + buildInputs = [ + blas + lapack + ]; meta = with lib; { homepage = "http://faculty.cse.tamu.edu/davis/suitesparse.html"; description = "Suite of sparse matrix algorithms"; - license = with licenses; [ bsd2 gpl2Plus lgpl21Plus ]; + license = with licenses; [ + bsd2 + gpl2Plus + lgpl21Plus + ]; maintainers = with maintainers; [ ttuegel ]; platforms = with platforms; unix; }; diff --git a/pkgs/development/libraries/science/math/suitesparse/default.nix b/pkgs/development/libraries/science/math/suitesparse/default.nix index 28909f53fecbbb..c840b25345c3d3 100644 --- a/pkgs/development/libraries/science/math/suitesparse/default.nix +++ b/pkgs/development/libraries/science/math/suitesparse/default.nix @@ -1,22 +1,29 @@ -{ lib, stdenv -, fetchFromGitHub -, gfortran -, blas, lapack -, metis -, fixDarwinDylibNames -, gmp -, mpfr -, config -, enableCuda ? config.cudaSupport -, cudaPackages -, openmp ? null +{ + lib, + stdenv, + fetchFromGitHub, + gfortran, + blas, + lapack, + metis, + fixDarwinDylibNames, + gmp, + mpfr, + config, + enableCuda ? config.cudaSupport, + cudaPackages, + openmp ? null, }: stdenv.mkDerivation rec { pname = "suitesparse"; version = "5.13.0"; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; src = fetchFromGitHub { owner = "DrTimothyAldenDavis"; @@ -25,51 +32,62 @@ stdenv.mkDerivation rec { sha256 = "sha256-Anen1YtXsSPhk8DpA4JtADIz9m8oXFl9umlkb4iImf8="; }; - nativeBuildInputs = [ - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ] ++ lib.optionals enableCuda [ - cudaPackages.cuda_nvcc - ]; + nativeBuildInputs = + [ + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ] + ++ lib.optionals enableCuda [ + cudaPackages.cuda_nvcc + ]; # Use compatible indexing for lapack and blas used - buildInputs = assert (blas.isILP64 == lapack.isILP64); [ - blas lapack - metis - (lib.getLib gfortran.cc) - gmp - mpfr - ] ++ lib.optionals stdenv.cc.isClang [ - openmp - ] ++ lib.optionals enableCuda [ - cudaPackages.cuda_cudart - cudaPackages.cuda_cccl - cudaPackages.libcublas - ]; + buildInputs = + assert (blas.isILP64 == lapack.isILP64); + [ + blas + lapack + metis + (lib.getLib gfortran.cc) + gmp + mpfr + ] + ++ lib.optionals stdenv.cc.isClang [ + openmp + ] + ++ lib.optionals enableCuda [ + cudaPackages.cuda_cudart + cudaPackages.cuda_cccl + cudaPackages.libcublas + ]; preConfigure = '' # Mongoose and GraphBLAS are packaged separately sed -i "Makefile" -e '/GraphBLAS\|Mongoose/d' ''; - makeFlags = [ - "INSTALL=${placeholder "out"}" - "INSTALL_INCLUDE=${placeholder "dev"}/include" - "JOBS=$(NIX_BUILD_CORES)" - "MY_METIS_LIB=-lmetis" - ] ++ lib.optionals blas.isILP64 [ - "CFLAGS=-DBLAS64" - ] ++ lib.optionals enableCuda [ - "CUDA_PATH=${cudaPackages.cuda_nvcc}" - "CUDART_LIB=${lib.getLib cudaPackages.cuda_cudart}/lib/libcudart.so" - "CUBLAS_LIB=${lib.getLib cudaPackages.libcublas}/lib/libcublas.so" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # Unless these are set, the build will attempt to use `Accelerate` on darwin, see: - # https://github.com/DrTimothyAldenDavis/SuiteSparse/blob/v5.13.0/SuiteSparse_config/SuiteSparse_config.mk#L368 - "BLAS=-lblas" - "LAPACK=-llapack" - ] - ; + makeFlags = + [ + "INSTALL=${placeholder "out"}" + "INSTALL_INCLUDE=${placeholder "dev"}/include" + "JOBS=$(NIX_BUILD_CORES)" + "MY_METIS_LIB=-lmetis" + ] + ++ lib.optionals blas.isILP64 [ + "CFLAGS=-DBLAS64" + ] + ++ lib.optionals enableCuda [ + "CUDA_PATH=${cudaPackages.cuda_nvcc}" + "CUDART_LIB=${lib.getLib cudaPackages.cuda_cudart}/lib/libcudart.so" + "CUBLAS_LIB=${lib.getLib cudaPackages.libcublas}/lib/libcublas.so" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # Unless these are set, the build will attempt to use `Accelerate` on darwin, see: + # https://github.com/DrTimothyAldenDavis/SuiteSparse/blob/v5.13.0/SuiteSparse_config/SuiteSparse_config.mk#L368 + "BLAS=-lblas" + "LAPACK=-llapack" + ]; env = lib.optionalAttrs stdenv.hostPlatform.isDarwin { # Ensure that there is enough space for the `fixDarwinDylibNames` hook to @@ -85,7 +103,11 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "http://faculty.cse.tamu.edu/davis/suitesparse.html"; description = "Suite of sparse matrix algorithms"; - license = with licenses; [ bsd2 gpl2Plus lgpl21Plus ]; + license = with licenses; [ + bsd2 + gpl2Plus + lgpl21Plus + ]; maintainers = with maintainers; [ ttuegel ]; platforms = with platforms; unix; }; diff --git a/pkgs/development/libraries/science/math/tensorrt/extension.nix b/pkgs/development/libraries/science/math/tensorrt/extension.nix index 7db869a2c1698a..19bf7e086d2a98 100644 --- a/pkgs/development/libraries/science/math/tensorrt/extension.nix +++ b/pkgs/development/libraries/science/math/tensorrt/extension.nix @@ -1,54 +1,77 @@ -final: prev: let +final: prev: +let inherit (final) callPackage; - inherit (prev) cudatoolkit cudaVersion lib pkgs; + inherit (prev) + cudatoolkit + cudaVersion + lib + pkgs + ; ### TensorRT - buildTensorRTPackage = args: - callPackage ./generic.nix { } args; + buildTensorRTPackage = args: callPackage ./generic.nix { } args; - toUnderscore = str: lib.replaceStrings ["."] ["_"] str; + toUnderscore = str: lib.replaceStrings [ "." ] [ "_" ] str; majorMinorPatch = str: lib.concatStringsSep "." (lib.take 3 (lib.splitVersion str)); - tensorRTPackages = let - # Check whether a file is supported for our cuda version - isSupported = fileData: lib.elem cudaVersion fileData.supportedCudaVersions; - # Return the first file that is supported. In practice there should only ever be one anyway. - supportedFile = files: lib.findFirst isSupported null files; + tensorRTPackages = + let + # Check whether a file is supported for our cuda version + isSupported = fileData: lib.elem cudaVersion fileData.supportedCudaVersions; + # Return the first file that is supported. In practice there should only ever be one anyway. + supportedFile = files: lib.findFirst isSupported null files; - # Compute versioned attribute name to be used in this package set - computeName = version: "tensorrt_${toUnderscore version}"; + # Compute versioned attribute name to be used in this package set + computeName = version: "tensorrt_${toUnderscore version}"; - # Supported versions with versions as keys and file as value - supportedVersions = lib.recursiveUpdate - { - tensorrt = { - enable = false; - fileVersionCuda = null; - fileVersionCudnn = null; - fullVersion = "0.0.0"; - sha256 = null; - tarball = null; - supportedCudaVersions = [ ]; - }; - } - (lib.mapAttrs' (version: attrs: lib.nameValuePair (computeName version) attrs) - (lib.filterAttrs (version: file: file != null) (lib.mapAttrs (version: files: supportedFile files) tensorRTVersions))); + # Supported versions with versions as keys and file as value + supportedVersions = + lib.recursiveUpdate + { + tensorrt = { + enable = false; + fileVersionCuda = null; + fileVersionCudnn = null; + fullVersion = "0.0.0"; + sha256 = null; + tarball = null; + supportedCudaVersions = [ ]; + }; + } + ( + lib.mapAttrs' (version: attrs: lib.nameValuePair (computeName version) attrs) ( + lib.filterAttrs (version: file: file != null) ( + lib.mapAttrs (version: files: supportedFile files) tensorRTVersions + ) + ) + ); - # Add all supported builds as attributes - allBuilds = lib.mapAttrs (name: file: buildTensorRTPackage (lib.removeAttrs file ["fileVersionCuda"])) supportedVersions; + # Add all supported builds as attributes + allBuilds = lib.mapAttrs ( + name: file: buildTensorRTPackage (lib.removeAttrs file [ "fileVersionCuda" ]) + ) supportedVersions; - # Set the default attributes, e.g. tensorrt = tensorrt_8_4; - defaultName = computeName tensorRTDefaultVersion; - defaultBuild = lib.optionalAttrs (allBuilds ? ${defaultName}) { tensorrt = allBuilds.${computeName tensorRTDefaultVersion}; }; - in { - inherit buildTensorRTPackage; - } // allBuilds // defaultBuild; + # Set the default attributes, e.g. tensorrt = tensorrt_8_4; + defaultName = computeName tensorRTDefaultVersion; + defaultBuild = lib.optionalAttrs (allBuilds ? ${defaultName}) { + tensorrt = allBuilds.${computeName tensorRTDefaultVersion}; + }; + in + { + inherit buildTensorRTPackage; + } + // allBuilds + // defaultBuild; tarballURL = - {fullVersion, fileVersionCuda, fileVersionCudnn ? null} : + { + fullVersion, + fileVersionCuda, + fileVersionCudnn ? null, + }: "TensorRT-${fullVersion}.Linux.x86_64-gnu.cuda-${fileVersionCuda}" + lib.optionalString (fileVersionCudnn != null) ".cudnn${fileVersionCudnn}" + ".tar.gz"; @@ -60,7 +83,10 @@ final: prev: let fullVersion = "8.6.1.6"; sha256 = "sha256-D4FXpfxTKZQ7M4uJNZE3M1CvqQyoEjnNrddYDNHrolQ="; tarball = tarballURL { inherit fileVersionCuda fullVersion; }; - supportedCudaVersions = [ "12.0" "12.1" ]; + supportedCudaVersions = [ + "12.0" + "12.1" + ]; } ]; "8.5.3" = [ @@ -70,7 +96,17 @@ final: prev: let fullVersion = "8.5.3.1"; sha256 = "sha256-BNeuOYvPTUAfGxI0DVsNrX6Z/FAB28+SE0ptuGu7YDY="; tarball = tarballURL { inherit fileVersionCuda fileVersionCudnn fullVersion; }; - supportedCudaVersions = [ "11.0" "11.1" "11.2" "11.3" "11.4" "11.5" "11.6" "11.7" "11.8" ]; + supportedCudaVersions = [ + "11.0" + "11.1" + "11.2" + "11.3" + "11.4" + "11.5" + "11.6" + "11.7" + "11.8" + ]; } rec { fileVersionCuda = "10.2"; @@ -88,7 +124,17 @@ final: prev: let fullVersion = "8.5.2.2"; sha256 = "sha256-Ov5irNS/JETpEz01FIFNMs9YVmjGHL7lSXmDpgCdgao="; tarball = tarballURL { inherit fileVersionCuda fileVersionCudnn fullVersion; }; - supportedCudaVersions = [ "11.0" "11.1" "11.2" "11.3" "11.4" "11.5" "11.6" "11.7" "11.8" ]; + supportedCudaVersions = [ + "11.0" + "11.1" + "11.2" + "11.3" + "11.4" + "11.5" + "11.6" + "11.7" + "11.8" + ]; } rec { fileVersionCuda = "10.2"; @@ -106,7 +152,17 @@ final: prev: let fullVersion = "8.5.1.7"; sha256 = "sha256-Ocx/B3BX0TY3lOj/UcTPIaXb7M8RFrACC6Da4PMGMHY="; tarball = tarballURL { inherit fileVersionCuda fileVersionCudnn fullVersion; }; - supportedCudaVersions = [ "11.0" "11.1" "11.2" "11.3" "11.4" "11.5" "11.6" "11.7" "11.8" ]; + supportedCudaVersions = [ + "11.0" + "11.1" + "11.2" + "11.3" + "11.4" + "11.5" + "11.6" + "11.7" + "11.8" + ]; } rec { fileVersionCuda = "10.2"; @@ -124,7 +180,15 @@ final: prev: let fullVersion = "8.4.0.6"; sha256 = "sha256-DNgHHXF/G4cK2nnOWImrPXAkOcNW6Wy+8j0LRpAH/LQ="; tarball = tarballURL { inherit fileVersionCuda fileVersionCudnn fullVersion; }; - supportedCudaVersions = [ "11.0" "11.1" "11.2" "11.3" "11.4" "11.5" "11.6" ]; + supportedCudaVersions = [ + "11.0" + "11.1" + "11.2" + "11.3" + "11.4" + "11.5" + "11.6" + ]; } rec { fileVersionCuda = "10.2"; @@ -138,19 +202,22 @@ final: prev: let }; # Default attributes - tensorRTDefaultVersion = { - "10.2" = "8.4.0"; - "11.0" = "8.4.0"; - "11.1" = "8.4.0"; - "11.2" = "8.4.0"; - "11.3" = "8.4.0"; - "11.4" = "8.4.0"; - "11.5" = "8.4.0"; - "11.6" = "8.4.0"; - "11.7" = "8.5.3"; - "11.8" = "8.5.3"; - "12.0" = "8.6.1"; - "12.1" = "8.6.1"; - }.${cudaVersion} or "8.4.0"; + tensorRTDefaultVersion = + { + "10.2" = "8.4.0"; + "11.0" = "8.4.0"; + "11.1" = "8.4.0"; + "11.2" = "8.4.0"; + "11.3" = "8.4.0"; + "11.4" = "8.4.0"; + "11.5" = "8.4.0"; + "11.6" = "8.4.0"; + "11.7" = "8.5.3"; + "11.8" = "8.5.3"; + "12.0" = "8.6.1"; + "12.1" = "8.6.1"; + } + .${cudaVersion} or "8.4.0"; -in tensorRTPackages +in +tensorRTPackages diff --git a/pkgs/development/libraries/science/math/trilinos/default.nix b/pkgs/development/libraries/science/math/trilinos/default.nix index 8e461f1caf24c1..e4c7f587eaef53 100644 --- a/pkgs/development/libraries/science/math/trilinos/default.nix +++ b/pkgs/development/libraries/science/math/trilinos/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, blas -, boost -, cmake -, gfortran -, lapack -, mpi -, suitesparse -, swig -, withMPI ? false +{ + stdenv, + lib, + fetchFromGitHub, + blas, + boost, + cmake, + gfortran, + lapack, + mpi, + suitesparse, + swig, + withMPI ? false, }: # NOTE: Not all packages are enabled. We specifically enable the ones @@ -70,17 +71,28 @@ stdenv.mkDerivation rec { sha256 = "sha256-Nqjr7RAlUHm6vs87a1P84Y7BIZEL0Vs/A1Z6dykfv+o="; }; - nativeBuildInputs = [ cmake gfortran swig ]; + nativeBuildInputs = [ + cmake + gfortran + swig + ]; - buildInputs = [ blas boost lapack suitesparse ] ++ lib.optionals withMPI [ mpi ]; + buildInputs = [ + blas + boost + lapack + suitesparse + ] ++ lib.optionals withMPI [ mpi ]; preConfigure = - if withMPI then '' - cmakeFlagsArray+=(${flagsBase} ${flagsParallel}) - '' - else '' - cmakeFlagsArray+=(${flagsBase}) - ''; + if withMPI then + '' + cmakeFlagsArray+=(${flagsBase} ${flagsParallel}) + '' + else + '' + cmakeFlagsArray+=(${flagsBase}) + ''; passthru = { inherit withMPI; diff --git a/pkgs/development/libraries/science/networking/ns-3/default.nix b/pkgs/development/libraries/science/networking/ns-3/default.nix index efcfa99be0e062..a69b6c27b6b0f3 100644 --- a/pkgs/development/libraries/science/networking/ns-3/default.nix +++ b/pkgs/development/libraries/science/networking/ns-3/default.nix @@ -1,56 +1,64 @@ -{ stdenv -, fetchFromGitLab -, python -, libxml2 -, sqlite +{ + stdenv, + fetchFromGitLab, + python, + libxml2, + sqlite, -, boost -, gtk3-x11 -, root -, glib -, gsl + boost, + gtk3-x11, + root, + glib, + gsl, -, cmake -, pkg-config + cmake, + pkg-config, + libpcap, -, libpcap + jansson, -, jansson - -, harfbuzz -, freetype + harfbuzz, + freetype, # for binding generation -, castxml ? null -, cppyy ? null + castxml ? null, + cppyy ? null, # can take a long time, generates > 30000 images/graphs -, enableDoxygen ? false + enableDoxygen ? false, # very long -, withManual ? false -, doxygen ? null -, graphviz ? null -, imagemagick ? null + withManual ? false, + doxygen ? null, + graphviz ? null, + imagemagick ? null, # for manual, tetex is used to get the eps2pdf binary # texlive to get latexmk. building manual still fails though -, dia -, tetex ? null -, ghostscript ? null -, texliveMedium ? null + dia, + tetex ? null, + ghostscript ? null, + texliveMedium ? null, # generates python bindings -, pythonSupport ? true -, ncurses ? null + pythonSupport ? true, + ncurses ? null, -, lib + lib, }: let - pythonEnv = python.withPackages (ps: + pythonEnv = python.withPackages ( + ps: lib.optional withManual ps.sphinx - ++ lib.optionals pythonSupport (with ps;[ pybindgen pygccxml cppyy]) + ++ lib.optionals pythonSupport ( + with ps; + [ + pybindgen + pygccxml + cppyy + ] + ) ); in stdenv.mkDerivation rec { @@ -64,29 +72,47 @@ stdenv.mkDerivation rec { hash = "sha256-2d8xCCfxRpcCZgt7ne17F7cUo/wIxLyvjQs3izNUnmY="; }; - nativeBuildInputs = [ cmake pkg-config pythonEnv ]; + nativeBuildInputs = [ + cmake + pkg-config + pythonEnv + ]; outputs = [ "out" ]; # ncurses is a hidden dependency of waf when checking python - buildInputs = lib.optionals pythonSupport [ castxml ncurses ] - ++ lib.optionals enableDoxygen [ doxygen graphviz imagemagick ] - ++ lib.optionals withManual [ dia tetex ghostscript imagemagick texliveMedium ] + buildInputs = + lib.optionals pythonSupport [ + castxml + ncurses + ] + ++ lib.optionals enableDoxygen [ + doxygen + graphviz + imagemagick + ] + ++ lib.optionals withManual [ + dia + tetex + ghostscript + imagemagick + texliveMedium + ] ++ [ - libxml2 - pythonEnv - sqlite.dev - gsl - boost - root # provides cppyy - glib.out - glib.dev - libpcap - gtk3-x11.dev - harfbuzz - freetype - jansson - ]; + libxml2 + pythonEnv + sqlite.dev + gsl + boost + root # provides cppyy + glib.out + glib.dev + libpcap + gtk3-x11.dev + harfbuzz + freetype + jansson + ]; propagatedBuildInputs = [ pythonEnv ]; @@ -103,15 +129,16 @@ stdenv.mkDerivation rec { doCheck = false; - buildTargets = "build" - + lib.optionalString enableDoxygen " doxygen" - + lib.optionalString withManual "sphinx"; + buildTargets = + "build" + lib.optionalString enableDoxygen " doxygen" + lib.optionalString withManual "sphinx"; # to prevent fatal error: 'backward_warning.h' file not found CXXFLAGS = "-D_GLIBCXX_PERMIT_BACKWARD_HASH"; # Make generated python bindings discoverable in customized python environment - passthru = { pythonModule = python; }; + passthru = { + pythonModule = python; + }; cmakeFlags = [ "-DPython3_LIBRARY_DIRS=${pythonEnv}/lib" @@ -124,19 +151,26 @@ stdenv.mkDerivation rec { "-DNS3_ASSERT=ON" "-DNS3_GTK3=ON" "-DGTK3_GLIBCONFIG_INCLUDE_DIR=${glib.out}/lib/glib-2.0/include" - ] - ++ lib.optional doCheck "-DNS3_TESTS=ON"; + ] ++ lib.optional doCheck "-DNS3_TESTS=ON"; # strictoverflow prevents clang from discovering pyembed when bindings - hardeningDisable = [ "fortify" "strictoverflow" ]; + hardeningDisable = [ + "fortify" + "strictoverflow" + ]; meta = with lib; { homepage = "http://www.nsnam.org"; license = licenses.gpl3; description = "Discrete time event network simulator"; platforms = with platforms; unix; - maintainers = with maintainers; [ teto rgrunbla ]; + maintainers = with maintainers; [ + teto + rgrunbla + ]; # never built on aarch64-darwin since first introduction in nixpkgs - broken = (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) || (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64); + broken = + (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) + || (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64); }; } diff --git a/pkgs/development/libraries/sfml/default.nix b/pkgs/development/libraries/sfml/default.nix index 2b28228c5f57e6..21c9927ee62013 100644 --- a/pkgs/development/libraries/sfml/default.nix +++ b/pkgs/development/libraries/sfml/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, libX11 -, freetype -, libjpeg -, openal -, flac -, libvorbis -, glew -, libXrandr -, libXrender -, udev -, xcbutilimage -, IOKit -, Foundation -, AppKit -, OpenAL +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + libX11, + freetype, + libjpeg, + openal, + flac, + libvorbis, + glew, + libXrandr, + libXrender, + udev, + xcbutilimage, + IOKit, + Foundation, + AppKit, + OpenAL, }: stdenv.mkDerivation rec { @@ -44,10 +45,28 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ freetype libjpeg openal flac libvorbis glew ] + buildInputs = + [ + freetype + libjpeg + openal + flac + libvorbis + glew + ] ++ lib.optional stdenv.hostPlatform.isLinux udev - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ libX11 libXrandr libXrender xcbutilimage ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ IOKit Foundation AppKit OpenAL ]; + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libX11 + libXrandr + libXrender + xcbutilimage + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + IOKit + Foundation + AppKit + OpenAL + ]; cmakeFlags = [ "-DSFML_INSTALL_PKGCONFIG_FILES=yes" diff --git a/pkgs/development/libraries/signond/default.nix b/pkgs/development/libraries/signond/default.nix index 5e9e5385531362..f6992e249dcf22 100644 --- a/pkgs/development/libraries/signond/default.nix +++ b/pkgs/development/libraries/signond/default.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitLab, qmake, qtbase, wrapQtAppsHook, doxygen }: +{ + stdenv, + lib, + fetchFromGitLab, + qmake, + qtbase, + wrapQtAppsHook, + doxygen, +}: stdenv.mkDerivation { pname = "signond"; diff --git a/pkgs/development/libraries/silgraphite/graphite2.nix b/pkgs/development/libraries/silgraphite/graphite2.nix index d2a4206e7dc1a4..7289820b60df1f 100644 --- a/pkgs/development/libraries/silgraphite/graphite2.nix +++ b/pkgs/development/libraries/silgraphite/graphite2.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, llvmPackages -, fetchurl -, pkg-config -, freetype -, cmake -, static ? stdenv.hostPlatform.isStatic -, testers +{ + lib, + stdenv, + llvmPackages, + fetchurl, + pkg-config, + freetype, + cmake, + static ? stdenv.hostPlatform.isStatic, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -14,18 +15,28 @@ stdenv.mkDerivation (finalAttrs: { pname = "graphite2"; src = fetchurl { - url = with finalAttrs; "https://github.com/silnrsi/graphite/releases/download/${version}/${pname}-${version}.tgz"; + url = + with finalAttrs; + "https://github.com/silnrsi/graphite/releases/download/${version}/${pname}-${version}.tgz"; sha256 = "1790ajyhk0ax8xxamnrk176gc9gvhadzy78qia4rd8jzm89ir7gr"; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ pkg-config cmake ]; - buildInputs = [ freetype ] - ++ lib.optional (stdenv.targetPlatform.useLLVM or false) - (llvmPackages.compiler-rt.override { + nativeBuildInputs = [ + pkg-config + cmake + ]; + buildInputs = + [ freetype ] + ++ lib.optional (stdenv.targetPlatform.useLLVM or false) ( + llvmPackages.compiler-rt.override { doFakeLibgcc = true; - }); + } + ); patches = lib.optionals stdenv.hostPlatform.isDarwin [ ./macosx.patch ]; postPatch = '' diff --git a/pkgs/development/libraries/simpleitk/default.nix b/pkgs/development/libraries/simpleitk/default.nix index c17064729f9618..a0bf151938b84f 100644 --- a/pkgs/development/libraries/simpleitk/default.nix +++ b/pkgs/development/libraries/simpleitk/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, swig -, lua -, elastix -, itk +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + swig, + lua, + elastix, + itk, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/libraries/slib/default.nix b/pkgs/development/libraries/slib/default.nix index 84b21e2c4fa9c0..393bf516118e5c 100644 --- a/pkgs/development/libraries/slib/default.nix +++ b/pkgs/development/libraries/slib/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, scheme, texinfo, unzip }: +{ + lib, + stdenv, + fetchurl, + scheme, + texinfo, + unzip, +}: stdenv.mkDerivation rec { pname = "slib"; @@ -19,7 +26,11 @@ stdenv.mkDerivation rec { --replace " clrnamdb.scm" "" ''; - nativeBuildInputs = [ scheme texinfo unzip ]; + nativeBuildInputs = [ + scheme + texinfo + unzip + ]; buildInputs = [ scheme ]; postInstall = '' diff --git a/pkgs/development/libraries/soci/bc-soci.nix b/pkgs/development/libraries/soci/bc-soci.nix index a3c967d80fe407..f8442371a6f715 100644 --- a/pkgs/development/libraries/soci/bc-soci.nix +++ b/pkgs/development/libraries/soci/bc-soci.nix @@ -1,10 +1,11 @@ -{ cmake -, fetchFromGitLab -, fetchpatch -, sqlite -, boost -, lib -, stdenv +{ + cmake, + fetchFromGitLab, + fetchpatch, + sqlite, + boost, + lib, + stdenv, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/soci/default.nix b/pkgs/development/libraries/soci/default.nix index 3ba387436e7648..7f4e7e01d1e900 100644 --- a/pkgs/development/libraries/soci/default.nix +++ b/pkgs/development/libraries/soci/default.nix @@ -1,11 +1,13 @@ -{ cmake -, fetchFromGitHub -, fetchpatch -, sqlite -, postgresql -, boost -, darwin -, lib, stdenv +{ + cmake, + fetchFromGitHub, + fetchpatch, + sqlite, + postgresql, + boost, + darwin, + lib, + stdenv, }: let inherit (darwin.apple_sdk_11_0.frameworks) Kerberos; @@ -30,16 +32,22 @@ stdenv.mkDerivation rec { ]; # Do not build static libraries - cmakeFlags = [ "-DSOCI_STATIC=OFF" "-DCMAKE_CXX_STANDARD=11" "-DSOCI_TESTS=off" ]; + cmakeFlags = [ + "-DSOCI_STATIC=OFF" + "-DCMAKE_CXX_STANDARD=11" + "-DSOCI_TESTS=off" + ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ - sqlite - postgresql - boost - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Kerberos - ]; + buildInputs = + [ + sqlite + postgresql + boost + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Kerberos + ]; meta = with lib; { description = "Database access library for C++"; diff --git a/pkgs/development/libraries/sofia-sip/default.nix b/pkgs/development/libraries/sofia-sip/default.nix index 7b33ed04871f26..8555b4e9617af7 100644 --- a/pkgs/development/libraries/sofia-sip/default.nix +++ b/pkgs/development/libraries/sofia-sip/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, glib, openssl, pkg-config, autoreconfHook, SystemConfiguration }: +{ + lib, + stdenv, + fetchFromGitHub, + glib, + openssl, + pkg-config, + autoreconfHook, + SystemConfiguration, +}: stdenv.mkDerivation rec { pname = "sofia-sip"; @@ -11,8 +20,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-7QmK2UxEO5lC0KBDWB3bwKTy0Nc7WrdTLjoQYzezoaY="; }; - buildInputs = [ glib openssl ] ++ lib.optional stdenv.hostPlatform.isDarwin SystemConfiguration; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + buildInputs = [ + glib + openssl + ] ++ lib.optional stdenv.hostPlatform.isDarwin SystemConfiguration; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; meta = with lib; { description = "Open-source SIP User-Agent library, compliant with the IETF RFC3261 specification"; diff --git a/pkgs/development/libraries/soil/default.nix b/pkgs/development/libraries/soil/default.nix index 39a64c84ddcdc0..e8f8e75f8fd8dd 100644 --- a/pkgs/development/libraries/soil/default.nix +++ b/pkgs/development/libraries/soil/default.nix @@ -1,8 +1,10 @@ -{ stdenv, lib -, Carbon -, fetchzip -, libGL -, libX11 +{ + stdenv, + lib, + Carbon, + fetchzip, + libGL, + libX11, }: stdenv.mkDerivation { @@ -14,12 +16,16 @@ stdenv.mkDerivation { sha256 = "1c05nwbnfdgwaz8ywn7kg2xrcvrcbpdyhcfkkiiwk69zvil0pbgd"; }; - buildInputs = if stdenv.hostPlatform.isDarwin then [ - Carbon - ] else [ - libGL - libX11 - ]; + buildInputs = + if stdenv.hostPlatform.isDarwin then + [ + Carbon + ] + else + [ + libGL + libX11 + ]; buildPhase = '' cd src diff --git a/pkgs/development/libraries/soqt/default.nix b/pkgs/development/libraries/soqt/default.nix index 14ff1ee1356fe4..151025b4d879a9 100644 --- a/pkgs/development/libraries/soqt/default.nix +++ b/pkgs/development/libraries/soqt/default.nix @@ -1,4 +1,12 @@ -{ fetchFromGitHub, lib, stdenv, coin3d, qtbase, cmake, pkg-config }: +{ + fetchFromGitHub, + lib, + stdenv, + coin3d, + qtbase, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "soqt"; @@ -13,9 +21,15 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - buildInputs = [ coin3d qtbase ]; + buildInputs = [ + coin3d + qtbase + ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; dontWrapQtApps = true; diff --git a/pkgs/development/libraries/spandsp/3.nix b/pkgs/development/libraries/spandsp/3.nix index 772388405c49fa..eedc5c38b527a6 100644 --- a/pkgs/development/libraries/spandsp/3.nix +++ b/pkgs/development/libraries/spandsp/3.nix @@ -1,8 +1,9 @@ -{ fetchFromGitHub -, callPackage +{ + fetchFromGitHub, + callPackage, }: -(callPackage ./common.nix {}).overrideAttrs(previousAttrs: { +(callPackage ./common.nix { }).overrideAttrs (previousAttrs: { version = "3.0.0"; src = fetchFromGitHub { owner = "freeswitch"; diff --git a/pkgs/development/libraries/spandsp/common.nix b/pkgs/development/libraries/spandsp/common.nix index 61439924b749d4..7abfee0668c5d3 100644 --- a/pkgs/development/libraries/spandsp/common.nix +++ b/pkgs/development/libraries/spandsp/common.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, audiofile -, libtiff -, buildPackages -, fetchpatch -, autoreconfHook +{ + lib, + stdenv, + audiofile, + libtiff, + buildPackages, + fetchpatch, + autoreconfHook, }: stdenv.mkDerivation (finalAttrs: { @@ -18,11 +19,17 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ autoreconfHook ]; depsBuildBuild = [ buildPackages.stdenv.cc ]; - propagatedBuildInputs = [ audiofile libtiff ]; + propagatedBuildInputs = [ + audiofile + libtiff + ]; configureFlags = [ # This flag is required to prevent linking error in the cross-compilation case. diff --git a/pkgs/development/libraries/spandsp/default.nix b/pkgs/development/libraries/spandsp/default.nix index 38e250ddef907b..991b9cd8ba17cf 100644 --- a/pkgs/development/libraries/spandsp/default.nix +++ b/pkgs/development/libraries/spandsp/default.nix @@ -1,8 +1,9 @@ -{ fetchurl -, callPackage +{ + fetchurl, + callPackage, }: -(callPackage ./common.nix {}).overrideAttrs(_: rec { +(callPackage ./common.nix { }).overrideAttrs (_: rec { version = "0.0.6"; src = fetchurl { url = "https://www.soft-switch.org/downloads/spandsp/spandsp-${version}.tar.gz"; diff --git a/pkgs/development/libraries/speech-tools/default.nix b/pkgs/development/libraries/speech-tools/default.nix index 1dbaa016cbbfef..6ee5391451c723 100644 --- a/pkgs/development/libraries/speech-tools/default.nix +++ b/pkgs/development/libraries/speech-tools/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, ncurses -, alsa-lib -, CoreServices -, AudioUnit -, Cocoa +{ + lib, + stdenv, + fetchurl, + fetchpatch, + ncurses, + alsa-lib, + CoreServices, + AudioUnit, + Cocoa, }: stdenv.mkDerivation rec { @@ -26,17 +27,23 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ - ncurses - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreServices - AudioUnit - Cocoa - ]; + buildInputs = + [ + ncurses + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + AudioUnit + Cocoa + ]; - makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" "CXX=${stdenv.cc.targetPrefix}c++" ]; + makeFlags = [ + "CC=${stdenv.cc.targetPrefix}cc" + "CXX=${stdenv.cc.targetPrefix}c++" + ]; # Workaround build failure on -fno-common toolchains: # ld: libestools.a(editline.o):(.bss+0x28): multiple definition of diff --git a/pkgs/development/libraries/speex/default.nix b/pkgs/development/libraries/speex/default.nix index 9e3f97b0344858..3803fd0b7d2a4f 100644 --- a/pkgs/development/libraries/speex/default.nix +++ b/pkgs/development/libraries/speex/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, pkg-config -, fftw -, speexdsp -, withFft ? !stdenv.hostPlatform.isMinGW +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + fftw, + speexdsp, + withFft ? !stdenv.hostPlatform.isMinGW, }: stdenv.mkDerivation rec { @@ -21,11 +22,17 @@ stdenv.mkDerivation rec { sed -i '/AC_CONFIG_MACRO_DIR/i PKG_PROG_PKG_CONFIG' configure.ac ''; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = lib.optionals withFft [ fftw ] - ++ [ speexdsp ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = lib.optionals withFft [ fftw ] ++ [ speexdsp ]; # TODO: Remove this will help with immediate backward compatibility propagatedBuildInputs = [ speexdsp ]; diff --git a/pkgs/development/libraries/speexdsp/default.nix b/pkgs/development/libraries/speexdsp/default.nix index e3452beab870da..58f049a233fa0e 100644 --- a/pkgs/development/libraries/speexdsp/default.nix +++ b/pkgs/development/libraries/speexdsp/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, pkg-config -, fftw -, withFftw3 ? (!stdenv.hostPlatform.isMinGW) +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + fftw, + withFftw3 ? (!stdenv.hostPlatform.isMinGW), }: stdenv.mkDerivation rec { @@ -19,12 +20,20 @@ stdenv.mkDerivation rec { patches = [ ./build-fix.patch ]; postPatch = "sed '3i#include ' -i ./include/speex/speexdsp_config_types.h.in"; - outputs = [ "out" "dev" "doc" ]; + outputs = [ + "out" + "dev" + "doc" + ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = lib.optionals withFftw3 [ fftw ]; - configureFlags = lib.optionals withFftw3 [ "--with-fft=gpl-fftw3" ] + configureFlags = + lib.optionals withFftw3 [ "--with-fft=gpl-fftw3" ] ++ lib.optional stdenv.hostPlatform.isAarch64 "--disable-neon"; meta = with lib; { diff --git a/pkgs/development/libraries/spglib/default.nix b/pkgs/development/libraries/spglib/default.nix index 75634072b8ec79..539c2cb58332ec 100644 --- a/pkgs/development/libraries/spglib/default.nix +++ b/pkgs/development/libraries/spglib/default.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, cmake, gfortran, gtest, openmp }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + gfortran, + gtest, + openmp, +}: stdenv.mkDerivation rec { pname = "spglib"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { hash = "sha256-/PG+ewlxIyf5Au2kVvsAYCfGZgUOOEpA1uATu15ut+M="; }; - nativeBuildInputs = [ cmake gfortran gtest ]; + nativeBuildInputs = [ + cmake + gfortran + gtest + ]; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ openmp ]; diff --git a/pkgs/development/libraries/sqlite/sqlar.nix b/pkgs/development/libraries/sqlite/sqlar.nix index 9063879b7e379a..7b6b41c7900de2 100644 --- a/pkgs/development/libraries/sqlite/sqlar.nix +++ b/pkgs/development/libraries/sqlite/sqlar.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchurl, fuse, zlib -, withFuse ? true }: +{ + lib, + stdenv, + fetchurl, + fuse, + zlib, + withFuse ? true, +}: stdenv.mkDerivation { pname = "sqlar"; @@ -15,17 +21,20 @@ stdenv.mkDerivation { --replace 'gcc' '${stdenv.cc.targetPrefix}cc' ''; - buildInputs = [ zlib ] - ++ lib.optional withFuse fuse; + buildInputs = [ zlib ] ++ lib.optional withFuse fuse; - buildFlags = [ "CFLAGS=-Wno-error" "sqlar" ] - ++ lib.optional withFuse "sqlarfs"; + buildFlags = [ + "CFLAGS=-Wno-error" + "sqlar" + ] ++ lib.optional withFuse "sqlarfs"; - installPhase = '' - install -D -t $out/bin sqlar - '' + lib.optionalString withFuse '' - install -D -t $out/bin sqlarfs - ''; + installPhase = + '' + install -D -t $out/bin sqlar + '' + + lib.optionalString withFuse '' + install -D -t $out/bin sqlarfs + ''; meta = with lib; { homepage = "https://sqlite.org/sqlar"; diff --git a/pkgs/development/libraries/sundials/default.nix b/pkgs/development/libraries/sundials/default.nix index 6a6752c3eb93e5..4086db31f0141a 100644 --- a/pkgs/development/libraries/sundials/default.nix +++ b/pkgs/development/libraries/sundials/default.nix @@ -1,20 +1,25 @@ -{ lib, stdenv -, cmake -, fetchurl -, python -, blas -, lapack -, gfortran -, suitesparse -, lapackSupport ? true -, kluSupport ? true +{ + lib, + stdenv, + cmake, + fetchurl, + python, + blas, + lapack, + gfortran, + suitesparse, + lapackSupport ? true, + kluSupport ? true, }: stdenv.mkDerivation rec { pname = "sundials"; version = "7.1.1"; - outputs = [ "out" "examples" ]; + outputs = [ + "out" + "examples" + ]; src = fetchurl { url = "https://github.com/LLNL/sundials/releases/download/v${version}/sundials-${version}.tar.gz"; @@ -26,49 +31,56 @@ stdenv.mkDerivation rec { gfortran ]; - buildInputs = [ - python - ] - ++ lib.optionals (lapackSupport) - # Check that the same index size is used for both libraries - (assert (blas.isILP64 == lapack.isILP64); [ - blas - lapack - ]) - # KLU support is based on Suitesparse. It is tested upstream according to the - # section 1.1.4.2 of INSTALL_GUIDE.pdf found in the source tarball. - ++ lib.optionals (kluSupport) [ - suitesparse - ]; + buildInputs = + [ + python + ] + ++ + lib.optionals (lapackSupport) + # Check that the same index size is used for both libraries + ( + assert (blas.isILP64 == lapack.isILP64); + [ + blas + lapack + ] + ) + # KLU support is based on Suitesparse. It is tested upstream according to the + # section 1.1.4.2 of INSTALL_GUIDE.pdf found in the source tarball. + ++ lib.optionals (kluSupport) [ + suitesparse + ]; - cmakeFlags = [ - "-DEXAMPLES_INSTALL_PATH=${placeholder "examples"}/share/examples" - ] ++ lib.optionals (lapackSupport) [ - "-DENABLE_LAPACK=ON" - "-DLAPACK_LIBRARIES=${lapack}/lib/liblapack${stdenv.hostPlatform.extensions.sharedLibrary}" - ] ++ lib.optionals (kluSupport) [ - "-DENABLE_KLU=ON" - "-DKLU_INCLUDE_DIR=${suitesparse.dev}/include" - "-DKLU_LIBRARY_DIR=${suitesparse}/lib" - ] ++ [( - # Use the correct index type according to lapack and blas used. They are - # already supposed to be compatible but we check both for extra safety. 64 - # should be the default but we prefer to be explicit, for extra safety. - if blas.isILP64 then - "-DSUNDIALS_INDEX_SIZE=64" - else - "-DSUNDIALS_INDEX_SIZE=32" - )] - ; + cmakeFlags = + [ + "-DEXAMPLES_INSTALL_PATH=${placeholder "examples"}/share/examples" + ] + ++ lib.optionals (lapackSupport) [ + "-DENABLE_LAPACK=ON" + "-DLAPACK_LIBRARIES=${lapack}/lib/liblapack${stdenv.hostPlatform.extensions.sharedLibrary}" + ] + ++ lib.optionals (kluSupport) [ + "-DENABLE_KLU=ON" + "-DKLU_INCLUDE_DIR=${suitesparse.dev}/include" + "-DKLU_LIBRARY_DIR=${suitesparse}/lib" + ] + ++ [ + ( + # Use the correct index type according to lapack and blas used. They are + # already supposed to be compatible but we check both for extra safety. 64 + # should be the default but we prefer to be explicit, for extra safety. + if blas.isILP64 then "-DSUNDIALS_INDEX_SIZE=64" else "-DSUNDIALS_INDEX_SIZE=32" + ) + ]; doCheck = true; checkTarget = "test"; meta = with lib; { description = "Suite of nonlinear differential/algebraic equation solvers"; - homepage = "https://computing.llnl.gov/projects/sundials"; - platforms = platforms.all; + homepage = "https://computing.llnl.gov/projects/sundials"; + platforms = platforms.all; maintainers = with maintainers; [ idontgetoutmuch ]; - license = licenses.bsd3; + license = licenses.bsd3; }; } diff --git a/pkgs/development/libraries/tachyon/default.nix b/pkgs/development/libraries/tachyon/default.nix index 9520f9a8404e5a..e006abaef21882 100644 --- a/pkgs/development/libraries/tachyon/default.nix +++ b/pkgs/development/libraries/tachyon/default.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchurl -, Carbon -, libjpeg -, libpng -, withJpegSupport ? true # support jpeg output -, withPngSupport ? true # support png output +{ + lib, + stdenv, + fetchurl, + Carbon, + libjpeg, + libpng, + withJpegSupport ? true, # support jpeg output + withPngSupport ? true, # support png output }: stdenv.mkDerivation rec { @@ -14,36 +16,55 @@ stdenv.mkDerivation rec { url = "http://jedi.ks.uiuc.edu/~johns/tachyon/files/${version}/${pname}-${version}.tar.gz"; sha256 = "sha256-CSA8ECMRFJ9d9cw2dAn5bHJXQmZtGcJNtbqZTVqBpvU="; }; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - Carbon - ] ++ lib.optionals withJpegSupport [ - libjpeg - ] ++ lib.optionals withPngSupport [ - libpng - ]; - preBuild = '' - cd unix - '' + lib.optionalString withJpegSupport '' - export USEJPEG=" -DUSEJPEG" - export JPEGLIB=" -ljpeg" - '' + lib.optionalString withPngSupport '' - export USEPNG=" -DUSEPNG" - export PNGLIB=" -lpng -lz" - ''; - arch = if stdenv.hostPlatform.system == "x86_64-linux" then "linux-64-thr" else - if stdenv.hostPlatform.system == "i686-linux" then "linux-thr" else - # 2021-03-29: multithread (-DTHR -D_REENTRANT) was disabled on linux-arm - # because it caused Sage's 3D plotting tests to hang indefinitely. - # see https://github.com/NixOS/nixpkgs/pull/117465 - if stdenv.hostPlatform.system == "aarch64-linux" then "linux-arm" else - if stdenv.hostPlatform.system == "armv7l-linux" then "linux-arm" else - if stdenv.hostPlatform.system == "aarch64-darwin" then "macosx" else - if stdenv.hostPlatform.system == "x86_64-darwin" then "macosx-thr" else - if stdenv.hostPlatform.system == "i686-darwin" then "macosx-64-thr" else - if stdenv.hostPlatform.system == "i686-cygwin" then "win32" else - if stdenv.hostPlatform.system == "x86_64-freebsd" then "bsd" else - if stdenv.hostPlatform.system == "x686-freebsd" then "bsd" else - throw "Don't know what arch to select for tachyon build"; + buildInputs = + lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + ] + ++ lib.optionals withJpegSupport [ + libjpeg + ] + ++ lib.optionals withPngSupport [ + libpng + ]; + preBuild = + '' + cd unix + '' + + lib.optionalString withJpegSupport '' + export USEJPEG=" -DUSEJPEG" + export JPEGLIB=" -ljpeg" + '' + + lib.optionalString withPngSupport '' + export USEPNG=" -DUSEPNG" + export PNGLIB=" -lpng -lz" + ''; + arch = + if stdenv.hostPlatform.system == "x86_64-linux" then + "linux-64-thr" + else if stdenv.hostPlatform.system == "i686-linux" then + "linux-thr" + else + # 2021-03-29: multithread (-DTHR -D_REENTRANT) was disabled on linux-arm + # because it caused Sage's 3D plotting tests to hang indefinitely. + # see https://github.com/NixOS/nixpkgs/pull/117465 + if stdenv.hostPlatform.system == "aarch64-linux" then + "linux-arm" + else if stdenv.hostPlatform.system == "armv7l-linux" then + "linux-arm" + else if stdenv.hostPlatform.system == "aarch64-darwin" then + "macosx" + else if stdenv.hostPlatform.system == "x86_64-darwin" then + "macosx-thr" + else if stdenv.hostPlatform.system == "i686-darwin" then + "macosx-64-thr" + else if stdenv.hostPlatform.system == "i686-cygwin" then + "win32" + else if stdenv.hostPlatform.system == "x86_64-freebsd" then + "bsd" + else if stdenv.hostPlatform.system == "x686-freebsd" then + "bsd" + else + throw "Don't know what arch to select for tachyon build"; makeFlags = [ arch ]; patches = [ @@ -72,7 +93,7 @@ stdenv.mkDerivation rec { description = "Parallel / Multiprocessor Ray Tracing System"; mainProgram = "tachyon"; license = lib.licenses.bsd3; - maintainers = [lib.maintainers.raskin]; + maintainers = [ lib.maintainers.raskin ]; platforms = with lib.platforms; linux ++ cygwin ++ darwin; homepage = "http://jedi.ks.uiuc.edu/~johns/tachyon/"; }; diff --git a/pkgs/development/libraries/tbb/2020_3.nix b/pkgs/development/libraries/tbb/2020_3.nix index c7e1e9127630b6..0399aa4c165fde 100644 --- a/pkgs/development/libraries/tbb/2020_3.nix +++ b/pkgs/development/libraries/tbb/2020_3.nix @@ -1,16 +1,20 @@ -{ lib -, stdenv -, fetchpatch -, fetchurl -, fetchFromGitHub -, fixDarwinDylibNames +{ + lib, + stdenv, + fetchpatch, + fetchurl, + fetchFromGitHub, + fixDarwinDylibNames, }: stdenv.mkDerivation rec { pname = "tbb"; version = "2020.3"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "oneapi-src"; @@ -48,20 +52,31 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = (lib.optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ]); - - makeFlags = lib.optionals stdenv.cc.isClang [ - "compiler=clang" - ] ++ (lib.optional (stdenv.buildPlatform != stdenv.hostPlatform) - (if stdenv.hostPlatform.isAarch64 then "arch=arm64" - else if stdenv.hostPlatform.isx86_64 then "arch=intel64" - else if stdenv.hostPlatform.isi686 then "arch=ia32" - else throw "Unsupported cross architecture")); + nativeBuildInputs = ( + lib.optionals stdenv.hostPlatform.isDarwin [ + fixDarwinDylibNames + ] + ); + + makeFlags = + lib.optionals stdenv.cc.isClang [ + "compiler=clang" + ] + ++ (lib.optional (stdenv.buildPlatform != stdenv.hostPlatform) ( + if stdenv.hostPlatform.isAarch64 then + "arch=arm64" + else if stdenv.hostPlatform.isx86_64 then + "arch=intel64" + else if stdenv.hostPlatform.isi686 then + "arch=ia32" + else + throw "Unsupported cross architecture" + )); # Fix undefined reference errors with version script under LLVM. - NIX_LDFLAGS = lib.optionalString (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") "--undefined-version"; + NIX_LDFLAGS = lib.optionalString ( + stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17" + ) "--undefined-version"; enableParallelBuilding = true; @@ -76,22 +91,24 @@ stdenv.mkDerivation rec { runHook postInstall ''; - postInstall = let - pcTemplate = fetchurl { - url = "https://github.com/oneapi-src/oneTBB/raw/478de5b1887c928e52f029d706af6ea640a877be/integration/pkg-config/tbb.pc.in"; - sha256 = "2pCad9txSpNbzac0vp/VY3x7HNySaYkbH3Rx8LK53pI="; - }; - in '' - # Generate pkg-config file based on upstream template. - # It should not be necessary with tbb after 2021.2. - mkdir -p "$out/lib/pkgconfig" - substitute "${pcTemplate}" "$out/lib/pkgconfig/tbb.pc" \ - --subst-var-by CMAKE_INSTALL_PREFIX "$out" \ - --subst-var-by CMAKE_INSTALL_LIBDIR "lib" \ - --subst-var-by CMAKE_INSTALL_INCLUDEDIR "include" \ - --subst-var-by TBB_VERSION "${version}" \ - --subst-var-by TBB_LIB_NAME "tbb" - ''; + postInstall = + let + pcTemplate = fetchurl { + url = "https://github.com/oneapi-src/oneTBB/raw/478de5b1887c928e52f029d706af6ea640a877be/integration/pkg-config/tbb.pc.in"; + sha256 = "2pCad9txSpNbzac0vp/VY3x7HNySaYkbH3Rx8LK53pI="; + }; + in + '' + # Generate pkg-config file based on upstream template. + # It should not be necessary with tbb after 2021.2. + mkdir -p "$out/lib/pkgconfig" + substitute "${pcTemplate}" "$out/lib/pkgconfig/tbb.pc" \ + --subst-var-by CMAKE_INSTALL_PREFIX "$out" \ + --subst-var-by CMAKE_INSTALL_LIBDIR "lib" \ + --subst-var-by CMAKE_INSTALL_INCLUDEDIR "include" \ + --subst-var-by TBB_VERSION "${version}" \ + --subst-var-by TBB_LIB_NAME "tbb" + ''; meta = with lib; { description = "Intel Thread Building Blocks C++ Library"; @@ -106,6 +123,9 @@ stdenv.mkDerivation rec { details and threading mechanisms for scalability and performance. ''; platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice tmarkus ]; + maintainers = with maintainers; [ + thoughtpolice + tmarkus + ]; }; } diff --git a/pkgs/development/libraries/tbb/2021_5.nix b/pkgs/development/libraries/tbb/2021_5.nix index 90e7aa2a9f2f30..b17ce8a760fcd5 100644 --- a/pkgs/development/libraries/tbb/2021_5.nix +++ b/pkgs/development/libraries/tbb/2021_5.nix @@ -1,15 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, }: stdenv.mkDerivation rec { pname = "tbb"; version = "2021.5.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "oneapi-src"; @@ -42,16 +46,24 @@ stdenv.mkDerivation rec { # Fix build with modern gcc # In member function 'void std::__atomic_base<_IntTp>::store(__int_type, std::memory_order) [with _ITp = bool]', - NIX_CFLAGS_COMPILE = lib.optionals stdenv.cc.isGNU [ "-Wno-error=array-bounds" "-Wno-error=stringop-overflow" "-Wno-address" ] ++ - # error: variable 'val' set but not used - lib.optionals stdenv.cc.isClang [ "-Wno-error=unused-but-set-variable" ] ++ - # Workaround for gcc-12 ICE when using -O3 - # https://gcc.gnu.org/PR108854 - lib.optionals (stdenv.cc.isGNU && stdenv.hostPlatform.isx86_32) [ "-O2" ]; + NIX_CFLAGS_COMPILE = + lib.optionals stdenv.cc.isGNU [ + "-Wno-error=array-bounds" + "-Wno-error=stringop-overflow" + "-Wno-address" + ] + ++ + # error: variable 'val' set but not used + lib.optionals stdenv.cc.isClang [ "-Wno-error=unused-but-set-variable" ] + ++ + # Workaround for gcc-12 ICE when using -O3 + # https://gcc.gnu.org/PR108854 + lib.optionals (stdenv.cc.isGNU && stdenv.hostPlatform.isx86_32) [ "-O2" ]; # Fix undefined reference errors with version script under LLVM. - NIX_LDFLAGS = lib.optionalString (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") "--undefined-version"; - + NIX_LDFLAGS = lib.optionalString ( + stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17" + ) "--undefined-version"; meta = with lib; { description = "Intel Thread Building Blocks C++ Library"; @@ -66,6 +78,9 @@ stdenv.mkDerivation rec { details and threading mechanisms for scalability and performance. ''; platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice tmarkus ]; + maintainers = with maintainers; [ + thoughtpolice + tmarkus + ]; }; } diff --git a/pkgs/development/libraries/tbb/default.nix b/pkgs/development/libraries/tbb/default.nix index c5c4a6275b5b69..a27ff43e241fb6 100644 --- a/pkgs/development/libraries/tbb/default.nix +++ b/pkgs/development/libraries/tbb/default.nix @@ -1,15 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, }: stdenv.mkDerivation rec { pname = "tbb"; version = "2021.11.0"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "oneapi-src"; @@ -32,15 +36,23 @@ stdenv.mkDerivation rec { # Fix build with modern gcc # In member function 'void std::__atomic_base<_IntTp>::store(__int_type, std::memory_order) [with _ITp = bool]', - NIX_CFLAGS_COMPILE = lib.optionals stdenv.cc.isGNU [ "-Wno-error=array-bounds" "-Wno-error=stringop-overflow" ] ++ - # error: variable 'val' set but not used - lib.optionals stdenv.cc.isClang [ "-Wno-error=unused-but-set-variable" ] ++ - # Workaround for gcc-12 ICE when using -O3 - # https://gcc.gnu.org/PR108854 - lib.optionals (stdenv.cc.isGNU && stdenv.hostPlatform.isx86_32) [ "-O2" ]; + NIX_CFLAGS_COMPILE = + lib.optionals stdenv.cc.isGNU [ + "-Wno-error=array-bounds" + "-Wno-error=stringop-overflow" + ] + ++ + # error: variable 'val' set but not used + lib.optionals stdenv.cc.isClang [ "-Wno-error=unused-but-set-variable" ] + ++ + # Workaround for gcc-12 ICE when using -O3 + # https://gcc.gnu.org/PR108854 + lib.optionals (stdenv.cc.isGNU && stdenv.hostPlatform.isx86_32) [ "-O2" ]; # Fix undefined reference errors with version script under LLVM. - NIX_LDFLAGS = lib.optionalString (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") "--undefined-version"; + NIX_LDFLAGS = lib.optionalString ( + stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17" + ) "--undefined-version"; # Disable failing test on musl # test/conformance/conformance_resumable_tasks.cpp:37:24: error: ‘suspend’ is not a member of ‘tbb::v1::task’; did you mean ‘tbb::detail::r1::suspend’? @@ -62,6 +74,9 @@ stdenv.mkDerivation rec { details and threading mechanisms for scalability and performance. ''; platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice tmarkus ]; + maintainers = with maintainers; [ + thoughtpolice + tmarkus + ]; }; } diff --git a/pkgs/development/libraries/tclap/1.2.nix b/pkgs/development/libraries/tclap/1.2.nix index cdb2b5193291ff..a586e69091937d 100644 --- a/pkgs/development/libraries/tclap/1.2.nix +++ b/pkgs/development/libraries/tclap/1.2.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "tclap"; diff --git a/pkgs/development/libraries/tclap/1.4.nix b/pkgs/development/libraries/tclap/1.4.nix index 7a0b576596331d..2daa837ad51405 100644 --- a/pkgs/development/libraries/tclap/1.4.nix +++ b/pkgs/development/libraries/tclap/1.4.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchgit -, cmake -, doxygen -, python3 +{ + lib, + stdenv, + fetchgit, + cmake, + doxygen, + python3, }: stdenv.mkDerivation { pname = "tclap"; diff --git a/pkgs/development/libraries/telepathy/qt/default.nix b/pkgs/development/libraries/telepathy/qt/default.nix index 605da19f77fc0e..d8468027985ca2 100644 --- a/pkgs/development/libraries/telepathy/qt/default.nix +++ b/pkgs/development/libraries/telepathy/qt/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, cmake -, qtbase -, pkg-config -, python3Packages -, dbus-glib -, dbus -, telepathy-farstream -, telepathy-glib +{ + lib, + stdenv, + fetchurl, + cmake, + qtbase, + pkg-config, + python3Packages, + dbus-glib, + dbus, + telepathy-farstream, + telepathy-glib, }: let @@ -23,10 +24,21 @@ stdenv.mkDerivation rec { sha256 = "bf8e2a09060addb80475a4938105b9b41d9e6837999b7a00e5351783857e18ad"; }; - nativeBuildInputs = [ cmake pkg-config python ]; - propagatedBuildInputs = [ qtbase telepathy-farstream telepathy-glib ]; + nativeBuildInputs = [ + cmake + pkg-config + python + ]; + propagatedBuildInputs = [ + qtbase + telepathy-farstream + telepathy-glib + ]; buildInputs = [ dbus-glib ]; - nativeCheckInputs = [ dbus dbus-python ]; + nativeCheckInputs = [ + dbus + dbus-python + ]; # No point in building tests if they are not run # On 0.9.7, they do not even build with QT4 diff --git a/pkgs/development/libraries/tinyxml/2.6.2.nix b/pkgs/development/libraries/tinyxml/2.6.2.nix index 456fd7fe2dd90c..f70142b6b2d4fd 100644 --- a/pkgs/development/libraries/tinyxml/2.6.2.nix +++ b/pkgs/development/libraries/tinyxml/2.6.2.nix @@ -1,9 +1,16 @@ -{ lib, stdenv, fetchurl, fetchpatch, unzip }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + unzip, +}: let version = "2.6.2"; SHLIB_EXT = stdenv.hostPlatform.extensions.sharedLibrary; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "tinyxml"; inherit version; @@ -38,8 +45,7 @@ in stdenv.mkDerivation { hardeningDisable = [ "format" ]; - env.NIX_CFLAGS_COMPILE = - lib.optionalString stdenv.hostPlatform.isDarwin "-mmacosx-version-min=10.9"; + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-mmacosx-version-min=10.9"; nativeBuildInputs = [ unzip ]; buildPhase = '' @@ -65,22 +71,24 @@ in stdenv.mkDerivation { fi ''; - installPhase = '' - mkdir -pv $out/include/ - mkdir -pv $out/lib/pkgconfig/ - mkdir -pv $out/share/doc/tinyxml/ + installPhase = + '' + mkdir -pv $out/include/ + mkdir -pv $out/lib/pkgconfig/ + mkdir -pv $out/share/doc/tinyxml/ - cp -v libtinyxml${SHLIB_EXT} $out/lib/ - cp -v *.h $out/include/ + cp -v libtinyxml${SHLIB_EXT} $out/lib/ + cp -v *.h $out/include/ - substituteInPlace tinyxml.pc --replace "@out@" "$out" - substituteInPlace tinyxml.pc --replace "@version@" "${version}" - cp -v tinyxml.pc $out/lib/pkgconfig/ + substituteInPlace tinyxml.pc --replace "@out@" "$out" + substituteInPlace tinyxml.pc --replace "@version@" "${version}" + cp -v tinyxml.pc $out/lib/pkgconfig/ - cp -v docs/* $out/share/doc/tinyxml/ - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install_name_tool -id $out/lib/libtinyxml.dylib $out/lib/libtinyxml.dylib - ''; + cp -v docs/* $out/share/doc/tinyxml/ + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install_name_tool -id $out/lib/libtinyxml.dylib $out/lib/libtinyxml.dylib + ''; meta = { description = "Simple, small, C++ XML parser that can be easily integrating into other programs"; diff --git a/pkgs/development/libraries/tk/8.5.nix b/pkgs/development/libraries/tk/8.5.nix index ad0013060ff631..77c8a1a1f0a5c1 100644 --- a/pkgs/development/libraries/tk/8.5.nix +++ b/pkgs/development/libraries/tk/8.5.nix @@ -1,28 +1,32 @@ -{ lib -, stdenv -, callPackage -, fetchurl -, fetchpatch -, tcl -, ... -} @ args: +{ + lib, + stdenv, + callPackage, + fetchurl, + fetchpatch, + tcl, + ... +}@args: -callPackage ./generic.nix (args // { +callPackage ./generic.nix ( + args + // { - src = fetchurl { - url = "mirror://sourceforge/tcl/tk${tcl.version}-src.tar.gz"; - sha256 = "1yhgcalldrjlc5q614rlzg1crgd3b52dhrk1pncdaxvl2vgg2yj0"; - }; + src = fetchurl { + url = "mirror://sourceforge/tcl/tk${tcl.version}-src.tar.gz"; + sha256 = "1yhgcalldrjlc5q614rlzg1crgd3b52dhrk1pncdaxvl2vgg2yj0"; + }; - patches = lib.optionals stdenv.hostPlatform.isDarwin [ - # Define MODULE_SCOPE before including tkPort.h - # https://core.tcl-lang.org/tk/info/dba9f5ce3b - (fetchpatch { - name = "module_scope.patch"; - url = "https://core.tcl-lang.org/tk/vpatch?from=ef6c6960c53ea30c&to=9b8aa74eebed509a"; - extraPrefix = ""; - sha256 = "0crhf4zrzdpc1jdgyv6l6mxqgmny12r3i39y1i0j8q3pbqkd04bv"; - }) - ]; + patches = lib.optionals stdenv.hostPlatform.isDarwin [ + # Define MODULE_SCOPE before including tkPort.h + # https://core.tcl-lang.org/tk/info/dba9f5ce3b + (fetchpatch { + name = "module_scope.patch"; + url = "https://core.tcl-lang.org/tk/vpatch?from=ef6c6960c53ea30c&to=9b8aa74eebed509a"; + extraPrefix = ""; + sha256 = "0crhf4zrzdpc1jdgyv6l6mxqgmny12r3i39y1i0j8q3pbqkd04bv"; + }) + ]; -}) + } +) diff --git a/pkgs/development/libraries/tk/8.6.nix b/pkgs/development/libraries/tk/8.6.nix index 84028762dbba9f..bb5f3e97da647c 100644 --- a/pkgs/development/libraries/tk/8.6.nix +++ b/pkgs/development/libraries/tk/8.6.nix @@ -1,18 +1,22 @@ -{ callPackage -, fetchurl -, tcl -, ... -} @ args: +{ + callPackage, + fetchurl, + tcl, + ... +}@args: -callPackage ./generic.nix (args // { +callPackage ./generic.nix ( + args + // { - src = fetchurl { - url = "mirror://sourceforge/tcl/tk${tcl.version}-src.tar.gz"; - sha256 = "sha256-VQlp81N5+VKzAg86t7ndW/0Rwe98m3xqdfXEmsp5P+w="; - }; + src = fetchurl { + url = "mirror://sourceforge/tcl/tk${tcl.version}-src.tar.gz"; + sha256 = "sha256-VQlp81N5+VKzAg86t7ndW/0Rwe98m3xqdfXEmsp5P+w="; + }; - patches = [ - ./tk-8_6_13-find-library.patch - ]; + patches = [ + ./tk-8_6_13-find-library.patch + ]; -}) + } +) diff --git a/pkgs/development/libraries/tpm2-tss/default.nix b/pkgs/development/libraries/tpm2-tss/default.nix index c1f3aeb7a34a8b..5604a3b19a74ed 100644 --- a/pkgs/development/libraries/tpm2-tss/default.nix +++ b/pkgs/development/libraries/tpm2-tss/default.nix @@ -1,8 +1,23 @@ -{ stdenv, lib, fetchFromGitHub -, autoreconfHook, autoconf-archive, pkg-config, doxygen, perl -, openssl, json_c, curl, libgcrypt -, cmocka, uthash, swtpm, iproute2, procps, which -, libuuid +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + autoconf-archive, + pkg-config, + doxygen, + perl, + openssl, + json_c, + curl, + libgcrypt, + cmocka, + uthash, + swtpm, + iproute2, + procps, + which, + libuuid, }: let # Avoid a circular dependency on Linux systems (systemd depends on tpm2-tss, @@ -24,23 +39,42 @@ stdenv.mkDerivation rec { hash = "sha256-BP28utEUI9g1VNv3lCXuiKrDtEImFQxxZfIjLiE3Wr8="; }; - outputs = [ "out" "man" "dev" ]; + outputs = [ + "out" + "man" + "dev" + ]; nativeBuildInputs = [ - autoreconfHook autoconf-archive pkg-config doxygen perl + autoreconfHook + autoconf-archive + pkg-config + doxygen + perl ]; - buildInputs = [ - openssl json_c curl libgcrypt uthash libuuid - ] - # cmocka is checked in the configure script - # when unit and/or integration testing is enabled - # cmocka doesn't build with pkgsStatic, and we don't need it anyway - # when tests are not run - ++ lib.optional doInstallCheck cmocka; + buildInputs = + [ + openssl + json_c + curl + libgcrypt + uthash + libuuid + ] + # cmocka is checked in the configure script + # when unit and/or integration testing is enabled + # cmocka doesn't build with pkgsStatic, and we don't need it anyway + # when tests are not run + ++ lib.optional doInstallCheck cmocka; nativeInstallCheckInputs = [ - cmocka which openssl procps_pkg iproute2 swtpm + cmocka + which + openssl + procps_pkg + iproute2 + swtpm ]; strictDeps = true; diff --git a/pkgs/development/libraries/unixODBCDrivers/default.nix b/pkgs/development/libraries/unixODBCDrivers/default.nix index b5b7e78e32a6b9..38d0d8ff4f7f8e 100644 --- a/pkgs/development/libraries/unixODBCDrivers/default.nix +++ b/pkgs/development/libraries/unixODBCDrivers/default.nix @@ -1,4 +1,23 @@ -{ fetchurl, stdenv, unixODBC, cmake, mariadb, sqlite, zlib, libxml2, dpkg, lib, openssl, libkrb5, libuuid, patchelf, libiconv, fixDarwinDylibNames, fetchFromGitHub, psqlodbc }: +{ + fetchurl, + stdenv, + unixODBC, + cmake, + mariadb, + sqlite, + zlib, + libxml2, + dpkg, + lib, + openssl, + libkrb5, + libuuid, + patchelf, + libiconv, + fixDarwinDylibNames, + fetchFromGitHub, + psqlodbc, +}: # Each of these ODBC drivers can be configured in your odbcinst.ini file using # the various passthru and meta values. Of note are: @@ -16,7 +35,10 @@ # '' { - psql = psqlodbc.override { withUnixODBC = true; withLibiodbc = false; }; + psql = psqlodbc.override { + withUnixODBC = true; + withLibiodbc = false; + }; mariadb = stdenv.mkDerivation rec { pname = "mariadb-connector-odbc"; @@ -38,8 +60,12 @@ ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ unixODBC openssl libiconv zlib ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libkrb5 ]; + buildInputs = [ + unixODBC + openssl + libiconv + zlib + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libkrb5 ]; cmakeFlags = [ "-DWITH_EXTERNAL_ZLIB=ON" @@ -83,7 +109,10 @@ }; nativeBuildInputs = [ cmake ]; - buildInputs = [ unixODBC mariadb ]; + buildInputs = [ + unixODBC + mariadb + ]; cmakeFlags = [ "-DWITH_UNIXODBC=1" ]; @@ -111,9 +140,17 @@ sha256 = "0dgsj28sc7f7aprmdd0n5a1rmcx6pv7170c8dfjl0x1qsjxim6hs"; }; - buildInputs = [ unixODBC sqlite zlib libxml2 ]; + buildInputs = [ + unixODBC + sqlite + zlib + libxml2 + ]; - configureFlags = [ "--with-odbc=${unixODBC}" "--with-sqlite3=${sqlite.dev}" ]; + configureFlags = [ + "--with-odbc=${unixODBC}" + "--with-sqlite3=${sqlite.dev}" + ]; installTargets = [ "install-3" ]; @@ -151,7 +188,10 @@ sha256 = "0vwirnp56jibm3qf0kmi4jnz1w7xfhnsfr8imr0c9hg6av4sk3a6"; }; - nativeBuildInputs = [ dpkg patchelf ]; + nativeBuildInputs = [ + dpkg + patchelf + ]; unpackPhase = "dpkg -x $src ./"; buildPhase = ""; @@ -163,7 +203,15 @@ ''; postFixup = '' - patchelf --set-rpath ${lib.makeLibraryPath [ unixODBC openssl libkrb5 libuuid stdenv.cc.cc ]} \ + patchelf --set-rpath ${ + lib.makeLibraryPath [ + unixODBC + openssl + libkrb5 + libuuid + stdenv.cc.cc + ] + } \ $out/lib/libmsodbcsql-${versionMajor}.${versionMinor}.so.${versionAdditional} ''; @@ -184,7 +232,7 @@ }; }; - msodbcsql18 = stdenv.mkDerivation(finalAttrs: { + msodbcsql18 = stdenv.mkDerivation (finalAttrs: { pname = "msodbcsql${finalAttrs.versionMajor}"; version = "${finalAttrs.versionMajor}.${finalAttrs.versionMinor}.${finalAttrs.versionAdditional}${finalAttrs.versionSuffix}"; @@ -194,23 +242,26 @@ versionSuffix = lib.optionalString stdenv.hostPlatform.isLinux "-1"; src = fetchurl { - url = { - x86_64-linux = "https://packages.microsoft.com/debian/11/prod/pool/main/m/msodbcsql${finalAttrs.versionMajor}/msodbcsql${finalAttrs.versionMajor}_${finalAttrs.version}_amd64.deb"; - aarch64-linux = "https://packages.microsoft.com/debian/11/prod/pool/main/m/msodbcsql${finalAttrs.versionMajor}/msodbcsql${finalAttrs.versionMajor}_${finalAttrs.version}_arm64.deb"; - x86_64-darwin = "https://download.microsoft.com/download/6/4/0/64006503-51e3-44f0-a6cd-a9b757d0d61b/msodbcsql${finalAttrs.versionMajor}-${finalAttrs.version}-amd64.tar.gz"; - aarch64-darwin = "https://download.microsoft.com/download/6/4/0/64006503-51e3-44f0-a6cd-a9b757d0d61b/msodbcsql${finalAttrs.versionMajor}-${finalAttrs.version}-arm64.tar.gz"; - }.${stdenv.system} or (throw "Unsupported system: ${stdenv.system}"); - hash = { - x86_64-linux = "sha256:1f0rmh1aynf1sqmjclbsyh2wz5jby0fixrwz71zp6impxpwvil52"; - aarch64-linux = "sha256:0zphnbvkqdbkcv6lvv63p7pyl68h5bs2dy6vv44wm6bi89svms4a"; - x86_64-darwin = "sha256:1fn80byn1yihflznxcm9cpj42mpllnz54apnk9n46vzm2ng2lj6d"; - aarch64-darwin = "sha256:116xl8r2apr5b48jnq6myj9fwqs88yccw5176yfyzh4534fznj5x"; - }.${stdenv.system} or (throw "Unsupported system: ${stdenv.system}"); + url = + { + x86_64-linux = "https://packages.microsoft.com/debian/11/prod/pool/main/m/msodbcsql${finalAttrs.versionMajor}/msodbcsql${finalAttrs.versionMajor}_${finalAttrs.version}_amd64.deb"; + aarch64-linux = "https://packages.microsoft.com/debian/11/prod/pool/main/m/msodbcsql${finalAttrs.versionMajor}/msodbcsql${finalAttrs.versionMajor}_${finalAttrs.version}_arm64.deb"; + x86_64-darwin = "https://download.microsoft.com/download/6/4/0/64006503-51e3-44f0-a6cd-a9b757d0d61b/msodbcsql${finalAttrs.versionMajor}-${finalAttrs.version}-amd64.tar.gz"; + aarch64-darwin = "https://download.microsoft.com/download/6/4/0/64006503-51e3-44f0-a6cd-a9b757d0d61b/msodbcsql${finalAttrs.versionMajor}-${finalAttrs.version}-arm64.tar.gz"; + } + .${stdenv.system} or (throw "Unsupported system: ${stdenv.system}"); + hash = + { + x86_64-linux = "sha256:1f0rmh1aynf1sqmjclbsyh2wz5jby0fixrwz71zp6impxpwvil52"; + aarch64-linux = "sha256:0zphnbvkqdbkcv6lvv63p7pyl68h5bs2dy6vv44wm6bi89svms4a"; + x86_64-darwin = "sha256:1fn80byn1yihflznxcm9cpj42mpllnz54apnk9n46vzm2ng2lj6d"; + aarch64-darwin = "sha256:116xl8r2apr5b48jnq6myj9fwqs88yccw5176yfyzh4534fznj5x"; + } + .${stdenv.system} or (throw "Unsupported system: ${stdenv.system}"); }; nativeBuildInputs = - if stdenv.hostPlatform.isDarwin - then + if stdenv.hostPlatform.isDarwin then [ # Fix up the names encoded into the dylib, and make them absolute. fixDarwinDylibNames @@ -226,8 +277,7 @@ ''; installPhase = - if stdenv.hostPlatform.isDarwin - then + if stdenv.hostPlatform.isDarwin then '' mkdir -p $out tar xf $src --strip-components=1 -C $out @@ -248,14 +298,27 @@ ''; postFixup = lib.optionalString stdenv.hostPlatform.isLinux '' - patchelf --set-rpath ${lib.makeLibraryPath [ unixODBC openssl libkrb5 libuuid stdenv.cc.cc ]} \ + patchelf --set-rpath ${ + lib.makeLibraryPath [ + unixODBC + openssl + libkrb5 + libuuid + stdenv.cc.cc + ] + } \ $out/${finalAttrs.passthru.driver} ''; # see the top of the file for an explanation passthru = { fancyName = "ODBC Driver ${finalAttrs.versionMajor} for SQL Server"; - driver = "lib/libmsodbcsql${if stdenv.hostPlatform.isDarwin then ".${finalAttrs.versionMajor}.dylib" else "-${finalAttrs.versionMajor}.${finalAttrs.versionMinor}.so.${finalAttrs.versionAdditional}"}"; + driver = "lib/libmsodbcsql${ + if stdenv.hostPlatform.isDarwin then + ".${finalAttrs.versionMajor}.dylib" + else + "-${finalAttrs.versionMajor}.${finalAttrs.versionMinor}.so.${finalAttrs.versionAdditional}" + }"; }; meta = with lib; { diff --git a/pkgs/development/libraries/unqlite/default.nix b/pkgs/development/libraries/unqlite/default.nix index c0e405c8849c94..471cbcc347f0f7 100644 --- a/pkgs/development/libraries/unqlite/default.nix +++ b/pkgs/development/libraries/unqlite/default.nix @@ -1,6 +1,9 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "unqlite"; diff --git a/pkgs/development/libraries/ustream-ssl/default.nix b/pkgs/development/libraries/ustream-ssl/default.nix index 4bee9d4f31558b..e618431bb01c64 100644 --- a/pkgs/development/libraries/ustream-ssl/default.nix +++ b/pkgs/development/libraries/ustream-ssl/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchgit -, cmake -, pkg-config -, libubox-nossl -, ssl_implementation -, additional_buildInputs ? [ ] +{ + stdenv, + lib, + fetchgit, + cmake, + pkg-config, + libubox-nossl, + ssl_implementation, + additional_buildInputs ? [ ], }: stdenv.mkDerivation { @@ -22,13 +23,18 @@ stdenv.mkDerivation { sed -r \ -e "s|ubox_include_dir libubox/ustream.h|ubox_include_dir libubox/ustream.h HINTS ${libubox-nossl}/include|g" \ -e "s|ubox_library NAMES ubox|ubox_library NAMES ubox HINTS ${libubox-nossl}/lib|g" \ - -e "s|^ FIND_LIBRARY\((.+)\)| FIND_LIBRARY\(\1 HINTS ${if ssl_implementation ? lib then ssl_implementation.lib else ssl_implementation.out}\)|g" \ + -e "s|^ FIND_LIBRARY\((.+)\)| FIND_LIBRARY\(\1 HINTS ${ + if ssl_implementation ? lib then ssl_implementation.lib else ssl_implementation.out + }\)|g" \ -i CMakeLists.txt ''; cmakeFlags = [ "-D${lib.toUpper ssl_implementation.pname}=ON" ]; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ ssl_implementation ] ++ additional_buildInputs; passthru = { @@ -39,7 +45,10 @@ stdenv.mkDerivation { description = "ustream SSL wrapper"; homepage = "https://git.openwrt.org/?p=project/ustream-ssl.git;a=summary"; license = licenses.isc; - maintainers = with maintainers; [ fpletz mkg20001 ]; + maintainers = with maintainers; [ + fpletz + mkg20001 + ]; platforms = platforms.all; }; } diff --git a/pkgs/development/libraries/v8/default.nix b/pkgs/development/libraries/v8/default.nix index b6b2d4e6298f8e..335c6fd4f6c694 100644 --- a/pkgs/development/libraries/v8/default.nix +++ b/pkgs/development/libraries/v8/default.nix @@ -1,9 +1,17 @@ -{ stdenv, lib, fetchgit -, gn, ninja, python3, glib, pkg-config, icu -, xcbuild -, fetchpatch -, llvmPackages -, symlinkJoin +{ + stdenv, + lib, + fetchgit, + gn, + ninja, + python3, + glib, + pkg-config, + icu, + xcbuild, + fetchpatch, + llvmPackages, + symlinkJoin, }: # Use update.sh to update all checksums. @@ -21,38 +29,38 @@ let # This data is from the DEPS file in the root of a V8 checkout. deps = { "base/trace_event/common" = fetchgit { - url = "${git_url}/chromium/src/base/trace_event/common.git"; - rev = "7f36dbc19d31e2aad895c60261ca8f726442bfbb"; + url = "${git_url}/chromium/src/base/trace_event/common.git"; + rev = "7f36dbc19d31e2aad895c60261ca8f726442bfbb"; sha256 = "01b2fhbxznqbakxv42ivrzg6w8l7i9yrd9nf72d6p5xx9dm993j4"; }; "build" = fetchgit { - url = "${git_url}/chromium/src/build.git"; - rev = "cf325916d58a194a935c26a56fcf6b525d1e2bf4"; + url = "${git_url}/chromium/src/build.git"; + rev = "cf325916d58a194a935c26a56fcf6b525d1e2bf4"; sha256 = "1ix4h1cpx9bvgln8590xh7lllhsd9w1hd5k9l1gx5yxxrmywd3s4"; }; "third_party/googletest/src" = fetchgit { - url = "${git_url}/external/github.com/google/googletest.git"; - rev = "16f637fbf4ffc3f7a01fa4eceb7906634565242f"; + url = "${git_url}/external/github.com/google/googletest.git"; + rev = "16f637fbf4ffc3f7a01fa4eceb7906634565242f"; sha256 = "11012k3c3mxzdwcw2iparr9lrckafpyhqzclsj26hmfbgbdi0rrh"; }; "third_party/icu" = fetchgit { - url = "${git_url}/chromium/deps/icu.git"; - rev = "eedbaf76e49d28465d9119b10c30b82906e606ff"; + url = "${git_url}/chromium/deps/icu.git"; + rev = "eedbaf76e49d28465d9119b10c30b82906e606ff"; sha256 = "0mppvx7wf9zlqjsfaa1cf06brh1fjb6nmiib0lhbb9hd55mqjdjj"; }; "third_party/zlib" = fetchgit { - url = "${git_url}/chromium/src/third_party/zlib.git"; - rev = "6da1d53b97c89b07e47714d88cab61f1ce003c68"; + url = "${git_url}/chromium/src/third_party/zlib.git"; + rev = "6da1d53b97c89b07e47714d88cab61f1ce003c68"; sha256 = "0v7ylmbwfwv6w6wp29qdf77kjjnfr2xzin08n0v1yvbhs01h5ppy"; }; "third_party/jinja2" = fetchgit { - url = "${git_url}/chromium/src/third_party/jinja2.git"; - rev = "ee69aa00ee8536f61db6a451f3858745cf587de6"; + url = "${git_url}/chromium/src/third_party/jinja2.git"; + rev = "ee69aa00ee8536f61db6a451f3858745cf587de6"; sha256 = "1fsnd5h0gisfp8bdsfd81kk5v4mkqf8z368c7qlm1qcwc4ri4x7a"; }; "third_party/markupsafe" = fetchgit { - url = "${git_url}/chromium/src/third_party/markupsafe.git"; - rev = "1b882ef6372b58bfd55a3285f37ed801be9137cd"; + url = "${git_url}/chromium/src/third_party/markupsafe.git"; + rev = "1b882ef6372b58bfd55a3285f37ed801be9137cd"; sha256 = "1jnjidbh03lhfaawimkjxbprmsgz4snr0jl06630dyd41zkdw5kr"; }; }; @@ -83,7 +91,7 @@ stdenv.mkDerivation rec { # gcc-13 build fix for mixxign includes (fetchpatch { name = "gcc-13.patch"; - url = "https://chromium.googlesource.com/v8/v8/+/c2792e58035fcbaa16d0cb70998852fbeb5df4cc^!?format=TEXT"; + url = "https://chromium.googlesource.com/v8/v8/+/c2792e58035fcbaa16d0cb70998852fbeb5df4cc^!?format=TEXT"; decode = "base64 -d"; hash = "sha256-hoPAkSaCmzXflPFXaKUwVPLECMpt6N6/8m8mBSTAHbU="; }) @@ -96,7 +104,8 @@ stdenv.mkDerivation rec { lib.mapAttrsToList (n: v: '' mkdir -p $sourceRoot/${n} cp -r ${v}/* $sourceRoot/${n} - '') deps)} + '') deps + )} chmod u+w -R . ''; @@ -121,48 +130,67 @@ stdenv.mkDerivation rec { sed '1i#include ' -i src/heap/cppgc/prefinalizer-handler.h # gcc12 ''; - llvmCcAndBintools = symlinkJoin { name = "llvmCcAndBintools"; paths = [ stdenv.cc llvmPackages.llvm ]; }; - - gnFlags = [ - "use_custom_libcxx=false" - "is_clang=${lib.boolToString stdenv.cc.isClang}" - "use_sysroot=false" - # "use_system_icu=true" - "clang_use_chrome_plugins=false" - "is_component_build=false" - "v8_use_external_startup_data=false" - "v8_monolithic=true" - "is_debug=true" - "is_official_build=false" - "treat_warnings_as_errors=false" - "v8_enable_i18n_support=true" - "use_gold=false" - # ''custom_toolchain="//build/toolchain/linux/unbundle:default"'' - ''host_toolchain="//build/toolchain/linux/unbundle:default"'' - ''v8_snapshot_toolchain="//build/toolchain/linux/unbundle:default"'' - ] ++ lib.optional stdenv.cc.isClang ''clang_base_path="${llvmCcAndBintools}"'' - ++ lib.optional stdenv.hostPlatform.isDarwin ''use_lld=false''; - - env.NIX_CFLAGS_COMPILE = toString ([ - "-O2" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-error=enum-constexpr-conversion" - ]); + llvmCcAndBintools = symlinkJoin { + name = "llvmCcAndBintools"; + paths = [ + stdenv.cc + llvmPackages.llvm + ]; + }; + + gnFlags = + [ + "use_custom_libcxx=false" + "is_clang=${lib.boolToString stdenv.cc.isClang}" + "use_sysroot=false" + # "use_system_icu=true" + "clang_use_chrome_plugins=false" + "is_component_build=false" + "v8_use_external_startup_data=false" + "v8_monolithic=true" + "is_debug=true" + "is_official_build=false" + "treat_warnings_as_errors=false" + "v8_enable_i18n_support=true" + "use_gold=false" + # ''custom_toolchain="//build/toolchain/linux/unbundle:default"'' + ''host_toolchain="//build/toolchain/linux/unbundle:default"'' + ''v8_snapshot_toolchain="//build/toolchain/linux/unbundle:default"'' + ] + ++ lib.optional stdenv.cc.isClang ''clang_base_path="${llvmCcAndBintools}"'' + ++ lib.optional stdenv.hostPlatform.isDarwin ''use_lld=false''; + + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-O2" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-error=enum-constexpr-conversion" + ] + ); FORCE_MAC_SDK_MIN = stdenv.hostPlatform.sdkVer or "10.12"; - nativeBuildInputs = [ - myGn - ninja - pkg-config - python3 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - xcbuild - llvmPackages.llvm - python3.pkgs.setuptools + nativeBuildInputs = + [ + myGn + ninja + pkg-config + python3 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + xcbuild + llvmPackages.llvm + python3.pkgs.setuptools + ]; + buildInputs = [ + glib + icu ]; - buildInputs = [ glib icu ]; - ninjaFlags = [ ":d8" "v8_monolith" ]; + ninjaFlags = [ + ":d8" + "v8_monolith" + ]; enableParallelBuilding = true; @@ -187,7 +215,10 @@ stdenv.mkDerivation rec { homepage = "https://v8.dev/"; description = "Google's open source JavaScript engine"; mainProgram = "d8"; - maintainers = with maintainers; [ proglodyte matthewbauer ]; + maintainers = with maintainers; [ + proglodyte + matthewbauer + ]; platforms = platforms.unix; license = licenses.bsd3; knownVulnerabilities = [ "Severely outdated with multiple publicly known vulnerabilities" ]; diff --git a/pkgs/development/libraries/valhalla/default.nix b/pkgs/development/libraries/valhalla/default.nix index 3a699cd0823da8..387362906e2ed6 100644 --- a/pkgs/development/libraries/valhalla/default.nix +++ b/pkgs/development/libraries/valhalla/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, pkg-config -, boost -, curl -, geos -, libspatialite -, luajit -, prime-server -, protobuf -, python3 -, sqlite -, zeromq -, zlib -, testers +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + boost, + curl, + geos, + libspatialite, + luajit, + prime-server, + protobuf, + python3, + sqlite, + zeromq, + zlib, + testers, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/libraries/vc/0.7.nix b/pkgs/development/libraries/vc/0.7.nix index fa0e6feb7df76f..c894dc31de22dd 100644 --- a/pkgs/development/libraries/vc/0.7.nix +++ b/pkgs/development/libraries/vc/0.7.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "Vc"; @@ -28,6 +33,8 @@ stdenv.mkDerivation rec { platforms = platforms.all; maintainers = with maintainers; [ abbradar ]; # never built on aarch64-darwin since first introduction in nixpkgs - broken = (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) || (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64); + broken = + (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) + || (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64); }; } diff --git a/pkgs/development/libraries/vc/default.nix b/pkgs/development/libraries/vc/default.nix index 6eb3c3db642784..8ff1ccd81d53da 100644 --- a/pkgs/development/libraries/vc/default.nix +++ b/pkgs/development/libraries/vc/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "Vc"; diff --git a/pkgs/development/libraries/vid-stab/default.nix b/pkgs/development/libraries/vid-stab/default.nix index a1eb5cf53e5dac..dcc4779090b269 100644 --- a/pkgs/development/libraries/vid-stab/default.nix +++ b/pkgs/development/libraries/vid-stab/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, openmp }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + openmp, +}: stdenv.mkDerivation rec { pname = "vid.stab"; diff --git a/pkgs/development/libraries/vmmlib/default.nix b/pkgs/development/libraries/vmmlib/default.nix index 71b540b01ca7fd..8283a89095c5fb 100644 --- a/pkgs/development/libraries/vmmlib/default.nix +++ b/pkgs/development/libraries/vmmlib/default.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, boost, lapack -, Accelerate, CoreGraphics, CoreVideo +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + boost, + lapack, + Accelerate, + CoreGraphics, + CoreVideo, }: stdenv.mkDerivation rec { @@ -14,12 +23,23 @@ stdenv.mkDerivation rec { }; patches = [ - ./disable-cpack.patch #disable the need of cpack/rpm + ./disable-cpack.patch # disable the need of cpack/rpm ]; - nativeBuildInputs = [ pkg-config cmake ]; - buildInputs = [ boost lapack ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Accelerate CoreGraphics CoreVideo ]; + nativeBuildInputs = [ + pkg-config + cmake + ]; + buildInputs = + [ + boost + lapack + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Accelerate + CoreGraphics + CoreVideo + ]; doCheck = !stdenv.hostPlatform.isDarwin; @@ -38,9 +58,9 @@ stdenv.mkDerivation rec { computations and frustum culling classes, and spatial data structures ''; - license = licenses.bsd2; - homepage = "https://github.com/VMML/vmmlib/"; + license = licenses.bsd2; + homepage = "https://github.com/VMML/vmmlib/"; maintainers = [ maintainers.adev ]; - platforms = platforms.all; + platforms = platforms.all; }; } diff --git a/pkgs/development/libraries/vtk/generic.nix b/pkgs/development/libraries/vtk/generic.nix index 91c210814a8954..c67b4b843aad2e 100644 --- a/pkgs/development/libraries/vtk/generic.nix +++ b/pkgs/development/libraries/vtk/generic.nix @@ -1,9 +1,30 @@ -{ majorVersion, minorVersion, sourceSha256, patchesToFetch ? [] }: -{ stdenv, lib, fetchurl, cmake, libGLU, libGL, libX11, xorgproto, libXt, libpng, libtiff -, fetchpatch -, enableQt ? false, qtx11extras, qttools, qtdeclarative, qtEnv -, enablePython ? false, python ? throw "vtk: Python support requested, but no python interpreter was given." -, enableEgl ? false +{ + majorVersion, + minorVersion, + sourceSha256, + patchesToFetch ? [ ], +}: +{ + stdenv, + lib, + fetchurl, + cmake, + libGLU, + libGL, + libX11, + xorgproto, + libXt, + libpng, + libtiff, + fetchpatch, + enableQt ? false, + qtx11extras, + qttools, + qtdeclarative, + qtEnv, + enablePython ? false, + python ? throw "vtk: Python support requested, but no python interpreter was given.", + enableEgl ? false, }: let @@ -12,10 +33,9 @@ let version = "${majorVersion}.${minorVersion}"; pythonMajor = lib.substring 0 1 python.pythonVersion; -in stdenv.mkDerivation { - pname = "vtk" - + optionalString enableEgl "-egl" - + optionalString enableQt "-qvtk"; +in +stdenv.mkDerivation { + pname = "vtk" + optionalString enableEgl "-egl" + optionalString enableQt "-qvtk"; inherit version; src = fetchurl { @@ -25,31 +45,46 @@ in stdenv.mkDerivation { nativeBuildInputs = [ cmake ]; - buildInputs = [ libpng libtiff ] - ++ optionals enableQt [ (qtEnv "qvtk-qt-env" [ qtx11extras qttools qtdeclarative ]) ] + buildInputs = + [ + libpng + libtiff + ] + ++ optionals enableQt [ + (qtEnv "qvtk-qt-env" [ + qtx11extras + qttools + qtdeclarative + ]) + ] ++ optionals stdenv.hostPlatform.isLinux [ libGLU xorgproto libXt - ] ++ optionals enablePython [ + ] + ++ optionals enablePython [ python ]; - propagatedBuildInputs = optionals stdenv.hostPlatform.isLinux [ libX11 libGL ]; - # see https://github.com/NixOS/nixpkgs/pull/178367#issuecomment-1238827254 + propagatedBuildInputs = optionals stdenv.hostPlatform.isLinux [ + libX11 + libGL + ]; + # see https://github.com/NixOS/nixpkgs/pull/178367#issuecomment-1238827254 patches = map fetchpatch patchesToFetch; # GCC 13: error: 'int64_t' in namespace 'std' does not name a type - postPatch = '' - sed '1i#include ' \ - -i ThirdParty/libproj/vtklibproj/src/proj_json_streaming_writer.hpp \ - -i IO/Image/vtkSEPReader.h - '' - + optionalString stdenv.hostPlatform.isDarwin '' - sed -i 's|COMMAND vtkHashSource|COMMAND "DYLD_LIBRARY_PATH=''${VTK_BINARY_DIR}/lib" ''${VTK_BINARY_DIR}/bin/vtkHashSource-${majorVersion}|' ./Parallel/Core/CMakeLists.txt - sed -i 's/fprintf(output, shift)/fprintf(output, "%s", shift)/' ./ThirdParty/libxml2/vtklibxml2/xmlschemas.c - sed -i 's/fprintf(output, shift)/fprintf(output, "%s", shift)/g' ./ThirdParty/libxml2/vtklibxml2/xpath.c - ''; + postPatch = + '' + sed '1i#include ' \ + -i ThirdParty/libproj/vtklibproj/src/proj_json_streaming_writer.hpp \ + -i IO/Image/vtkSEPReader.h + '' + + optionalString stdenv.hostPlatform.isDarwin '' + sed -i 's|COMMAND vtkHashSource|COMMAND "DYLD_LIBRARY_PATH=''${VTK_BINARY_DIR}/lib" ''${VTK_BINARY_DIR}/bin/vtkHashSource-${majorVersion}|' ./Parallel/Core/CMakeLists.txt + sed -i 's/fprintf(output, shift)/fprintf(output, "%s", shift)/' ./ThirdParty/libxml2/vtklibxml2/xmlschemas.c + sed -i 's/fprintf(output, shift)/fprintf(output, "%s", shift)/g' ./ThirdParty/libxml2/vtklibxml2/xpath.c + ''; dontWrapQtApps = true; @@ -58,23 +93,27 @@ in stdenv.mkDerivation { # built and requiring one of the shared objects. # At least, we use -fPIC for other packages to be able to use this in shared # objects. - cmakeFlags = [ - "-DCMAKE_C_FLAGS=-fPIC" - "-DCMAKE_CXX_FLAGS=-fPIC" - "-DVTK_MODULE_USE_EXTERNAL_vtkpng=ON" - "-DVTK_MODULE_USE_EXTERNAL_vtktiff=1" - "-DVTK_MODULE_ENABLE_VTK_RenderingExternal=YES" - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - "-DOPENGL_INCLUDE_DIR=${libGL}/include" - (lib.cmakeBool "VTK_OPENGL_HAS_EGL" enableEgl) - ] ++ [ - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - "-DCMAKE_INSTALL_BINDIR=bin" - "-DVTK_VERSIONED_INSTALL=OFF" - ] ++ optionals enableQt [ - "-DVTK_GROUP_ENABLE_Qt:STRING=YES" - ] + cmakeFlags = + [ + "-DCMAKE_C_FLAGS=-fPIC" + "-DCMAKE_CXX_FLAGS=-fPIC" + "-DVTK_MODULE_USE_EXTERNAL_vtkpng=ON" + "-DVTK_MODULE_USE_EXTERNAL_vtktiff=1" + "-DVTK_MODULE_ENABLE_VTK_RenderingExternal=YES" + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + "-DOPENGL_INCLUDE_DIR=${libGL}/include" + (lib.cmakeBool "VTK_OPENGL_HAS_EGL" enableEgl) + ] + ++ [ + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + "-DCMAKE_INSTALL_BINDIR=bin" + "-DVTK_VERSIONED_INSTALL=OFF" + ] + ++ optionals enableQt [ + "-DVTK_GROUP_ENABLE_Qt:STRING=YES" + ] ++ optionals enablePython [ "-DVTK_WRAP_PYTHON:BOOL=ON" "-DVTK_PYTHON_VERSION:STRING=${pythonMajor}" @@ -95,7 +134,10 @@ in stdenv.mkDerivation { description = "Open source libraries for 3D computer graphics, image processing and visualization"; homepage = "https://www.vtk.org/"; license = licenses.bsd3; - maintainers = with maintainers; [ knedlsepp tfmoraes ]; + maintainers = with maintainers; [ + knedlsepp + tfmoraes + ]; platforms = platforms.unix; badPlatforms = optionals enableEgl platforms.darwin; }; diff --git a/pkgs/development/libraries/vulkan-headers/default.nix b/pkgs/development/libraries/vulkan-headers/default.nix index d48dc790424adc..b44f50c8b381c1 100644 --- a/pkgs/development/libraries/vulkan-headers/default.nix +++ b/pkgs/development/libraries/vulkan-headers/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, ninja }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, +}: stdenv.mkDerivation rec { pname = "vulkan-headers"; version = "1.3.296.0"; @@ -6,7 +12,10 @@ stdenv.mkDerivation rec { # Adding `ninja` here to enable Ninja backend. Otherwise on gcc-14 or # later the build fails as: # modules are not supported by this generator: Unix Makefiles - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; # TODO: investigate why isn't found cmakeFlags = lib.optionals stdenv.hostPlatform.isDarwin [ "-DVULKAN_HEADERS_ENABLE_MODULE=OFF" ]; @@ -22,9 +31,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Vulkan Header files and API registry"; - homepage = "https://www.lunarg.com"; - platforms = platforms.unix ++ platforms.windows; - license = licenses.asl20; + homepage = "https://www.lunarg.com"; + platforms = platforms.unix ++ platforms.windows; + license = licenses.asl20; maintainers = [ maintainers.ralith ]; }; } diff --git a/pkgs/development/libraries/wasilibc/default.nix b/pkgs/development/libraries/wasilibc/default.nix index c0714a78556a34..3fafb7e14f4cc0 100644 --- a/pkgs/development/libraries/wasilibc/default.nix +++ b/pkgs/development/libraries/wasilibc/default.nix @@ -1,9 +1,10 @@ -{ stdenv -, buildPackages -, fetchFromGitHub -, lib -, firefox-unwrapped -, firefox-esr-unwrapped +{ + stdenv, + buildPackages, + fetchFromGitHub, + lib, + firefox-unwrapped, + firefox-esr-unwrapped, }: let @@ -21,7 +22,11 @@ stdenv.mkDerivation { fetchSubmodules = true; }; - outputs = [ "out" "dev" "share" ]; + outputs = [ + "out" + "dev" + "share" + ]; # clang-13: error: argument unused during compilation: '-rtlib=compiler-rt' [-Werror,-Wunused-command-line-argument] postPatch = '' @@ -62,7 +67,13 @@ stdenv.mkDerivation { description = "WASI libc implementation for WebAssembly"; homepage = "https://wasi.dev"; platforms = platforms.wasi; - maintainers = with maintainers; [ matthewbauer rvolosatovs ]; - license = with licenses; [ asl20-llvm mit ]; + maintainers = with maintainers; [ + matthewbauer + rvolosatovs + ]; + license = with licenses; [ + asl20-llvm + mit + ]; }; } diff --git a/pkgs/development/libraries/wayland/default.nix b/pkgs/development/libraries/wayland/default.nix index 72ba54250b511c..518fd31e2ffa89 100644 --- a/pkgs/development/libraries/wayland/default.nix +++ b/pkgs/development/libraries/wayland/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, meson -, pkg-config -, ninja -, wayland-scanner -, withTests ? stdenv.hostPlatform.isLinux -, libffi -, epoll-shim -, withDocumentation ? stdenv.hostPlatform == stdenv.buildPlatform -, graphviz-nox -, doxygen -, libxslt -, xmlto -, python3 -, docbook_xsl -, docbook_xml_dtd_45 -, docbook_xml_dtd_42 -, testers +{ + lib, + stdenv, + fetchurl, + meson, + pkg-config, + ninja, + wayland-scanner, + withTests ? stdenv.hostPlatform.isLinux, + libffi, + epoll-shim, + withDocumentation ? stdenv.hostPlatform == stdenv.buildPlatform, + graphviz-nox, + doxygen, + libxslt, + xmlto, + python3, + docbook_xsl, + docbook_xml_dtd_45, + docbook_xml_dtd_42, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -25,7 +26,9 @@ stdenv.mkDerivation (finalAttrs: { version = "1.23.1"; src = fetchurl { - url = with finalAttrs; "https://gitlab.freedesktop.org/wayland/wayland/-/releases/${version}/downloads/${pname}-${version}.tar.xz"; + url = + with finalAttrs; + "https://gitlab.freedesktop.org/wayland/wayland/-/releases/${version}/downloads/${pname}-${version}.tar.xz"; hash = "sha256-hk+yqDmeLQ7DnVbp2bdTwJN3W+rcYCLOgfRBkpqB5e0="; }; @@ -33,15 +36,25 @@ stdenv.mkDerivation (finalAttrs: { ./darwin.patch ]; - postPatch = lib.optionalString withDocumentation '' - patchShebangs doc/doxygen/gen-doxygen.py - '' + lib.optionalString stdenv.hostPlatform.isStatic '' - # delete line containing os-wrappers-test, disables - # the building of os-wrappers-test - sed -i '/os-wrappers-test/d' tests/meson.build - ''; + postPatch = + lib.optionalString withDocumentation '' + patchShebangs doc/doxygen/gen-doxygen.py + '' + + lib.optionalString stdenv.hostPlatform.isStatic '' + # delete line containing os-wrappers-test, disables + # the building of os-wrappers-test + sed -i '/os-wrappers-test/d' tests/meson.build + ''; - outputs = [ "out" "dev" ] ++ lib.optionals withDocumentation [ "doc" "man" ]; + outputs = + [ + "out" + "dev" + ] + ++ lib.optionals withDocumentation [ + "doc" + "man" + ]; separateDebugInfo = true; mesonFlags = [ @@ -54,30 +67,35 @@ stdenv.mkDerivation (finalAttrs: { pkg-config ]; - nativeBuildInputs = [ - meson - pkg-config - ninja - wayland-scanner - ] ++ lib.optionals withDocumentation [ - (graphviz-nox.override { pango = null; }) # To avoid an infinite recursion - doxygen - libxslt - xmlto - python3 - docbook_xml_dtd_45 - docbook_xsl - ]; + nativeBuildInputs = + [ + meson + pkg-config + ninja + wayland-scanner + ] + ++ lib.optionals withDocumentation [ + (graphviz-nox.override { pango = null; }) # To avoid an infinite recursion + doxygen + libxslt + xmlto + python3 + docbook_xml_dtd_45 + docbook_xsl + ]; - buildInputs = [ - libffi - ] ++ lib.optionals (!stdenv.hostPlatform.isLinux) [ - epoll-shim - ] ++ lib.optionals withDocumentation [ - docbook_xsl - docbook_xml_dtd_45 - docbook_xml_dtd_42 - ]; + buildInputs = + [ + libffi + ] + ++ lib.optionals (!stdenv.hostPlatform.isLinux) [ + epoll-shim + ] + ++ lib.optionals withDocumentation [ + docbook_xsl + docbook_xml_dtd_45 + docbook_xml_dtd_42 + ]; passthru = { tests.pkg-config = testers.hasPkgConfigModules { @@ -99,7 +117,11 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://wayland.freedesktop.org/"; license = licenses.mit; # Expat version platforms = platforms.unix; - maintainers = with maintainers; [ primeos codyopel qyliss ]; + maintainers = with maintainers; [ + primeos + codyopel + qyliss + ]; pkgConfigModules = [ "wayland-client" "wayland-cursor" diff --git a/pkgs/development/libraries/wayland/protocols.nix b/pkgs/development/libraries/wayland/protocols.nix index 76976be200b541..82f41bdf30ca3d 100644 --- a/pkgs/development/libraries/wayland/protocols.nix +++ b/pkgs/development/libraries/wayland/protocols.nix @@ -1,17 +1,27 @@ -{ lib, stdenv, fetchurl -, pkg-config -, meson, ninja, wayland-scanner -, python3, wayland -, gitUpdater, testers +{ + lib, + stdenv, + fetchurl, + pkg-config, + meson, + ninja, + wayland-scanner, + python3, + wayland, + gitUpdater, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "wayland-protocols"; version = "1.38"; - doCheck = stdenv.hostPlatform == stdenv.buildPlatform && - # https://gitlab.freedesktop.org/wayland/wayland-protocols/-/issues/48 - stdenv.hostPlatform.linker == "bfd" && lib.meta.availableOn stdenv.hostPlatform wayland; + doCheck = + stdenv.hostPlatform == stdenv.buildPlatform + && + # https://gitlab.freedesktop.org/wayland/wayland-protocols/-/issues/48 + stdenv.hostPlatform.linker == "bfd" + && lib.meta.availableOn stdenv.hostPlatform wayland; src = fetchurl { url = "https://gitlab.freedesktop.org/wayland/${finalAttrs.pname}/-/releases/${finalAttrs.version}/downloads/${finalAttrs.pname}-${finalAttrs.version}.tar.xz"; @@ -23,7 +33,11 @@ stdenv.mkDerivation (finalAttrs: { ''; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson ninja wayland-scanner ]; + nativeBuildInputs = [ + meson + ninja + wayland-scanner + ]; nativeCheckInputs = [ python3 ]; checkInputs = [ wayland ]; @@ -38,9 +52,9 @@ stdenv.mkDerivation (finalAttrs: { protocol either in Wayland core, or some other protocol in wayland-protocols. ''; - homepage = "https://gitlab.freedesktop.org/wayland/wayland-protocols"; - license = lib.licenses.mit; # Expat version - platforms = lib.platforms.all; + homepage = "https://gitlab.freedesktop.org/wayland/wayland-protocols"; + license = lib.licenses.mit; # Expat version + platforms = lib.platforms.all; maintainers = with lib.maintainers; [ primeos ]; pkgConfigModules = [ "wayland-protocols" ]; }; diff --git a/pkgs/development/libraries/waylandpp/default.nix b/pkgs/development/libraries/waylandpp/default.nix index 7eeeb2467eddea..fbb0d0dad266f4 100644 --- a/pkgs/development/libraries/waylandpp/default.nix +++ b/pkgs/development/libraries/waylandpp/default.nix @@ -1,17 +1,19 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, makeFontsConf -, pkg-config -, pugixml -, wayland -, libGL -, libffi -, buildPackages -, docSupport ? true -, doxygen -, graphviz +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + makeFontsConf, + pkg-config, + pugixml, + wayland, + libGL, + libffi, + buildPackages, + docSupport ? true, + doxygen, + graphviz, }: stdenv.mkDerivation rec { @@ -37,19 +39,46 @@ stdenv.mkDerivation rec { }) ]; - cmakeFlags = [ - "-DCMAKE_INSTALL_DATADIR=${placeholder "dev"}" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "-DWAYLAND_SCANNERPP=${buildPackages.waylandpp}/bin/wayland-scanner++" - ]; + cmakeFlags = + [ + "-DCMAKE_INSTALL_DATADIR=${placeholder "dev"}" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "-DWAYLAND_SCANNERPP=${buildPackages.waylandpp}/bin/wayland-scanner++" + ]; # Complains about not being able to find the fontconfig config file otherwise - FONTCONFIG_FILE = lib.optional docSupport (makeFontsConf { fontDirectories = [ ]; }); + FONTCONFIG_FILE = lib.optional docSupport (makeFontsConf { + fontDirectories = [ ]; + }); - nativeBuildInputs = [ cmake pkg-config ] ++ lib.optionals docSupport [ doxygen graphviz ]; - buildInputs = [ pugixml wayland libGL libffi ]; + nativeBuildInputs = + [ + cmake + pkg-config + ] + ++ lib.optionals docSupport [ + doxygen + graphviz + ]; + buildInputs = [ + pugixml + wayland + libGL + libffi + ]; - outputs = [ "bin" "dev" "lib" "out" ] ++ lib.optionals docSupport [ "doc" "devman" ]; + outputs = + [ + "bin" + "dev" + "lib" + "out" + ] + ++ lib.optionals docSupport [ + "doc" + "devman" + ]; # Resolves the warning "Fontconfig error: No writable cache directories" preBuild = '' @@ -60,7 +89,10 @@ stdenv.mkDerivation rec { description = "Wayland C++ binding"; mainProgram = "wayland-scanner++"; homepage = "https://github.com/NilsBrause/waylandpp/"; - license = with lib.licenses; [ bsd2 hpnd ]; + license = with lib.licenses; [ + bsd2 + hpnd + ]; maintainers = with lib.maintainers; [ minijackson ]; }; } diff --git a/pkgs/development/libraries/waylib/default.nix b/pkgs/development/libraries/waylib/default.nix index d3ae7273fae8c8..bc8d9025dbfdf7 100644 --- a/pkgs/development/libraries/waylib/default.nix +++ b/pkgs/development/libraries/waylib/default.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, pkg-config -, wayland-scanner -, wrapQtAppsHook -, qtbase -, qtdeclarative -, qwlroots -, wayland -, wayland-protocols -, wlr-protocols -, pixman -, libdrm -, libinput +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + wayland-scanner, + wrapQtAppsHook, + qtbase, + qtdeclarative, + qwlroots, + wayland, + wayland-protocols, + wlr-protocols, + pixman, + libdrm, + libinput, }: stdenv.mkDerivation (finalAttrs: { @@ -54,14 +55,20 @@ stdenv.mkDerivation (finalAttrs: { dontWrapQtApps = true; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = { description = "Wrapper for wlroots based on Qt"; homepage = "https://github.com/vioken/waylib"; - license = with lib.licenses; [ gpl3Only lgpl3Only asl20 ]; + license = with lib.licenses; [ + gpl3Only + lgpl3Only + asl20 + ]; platforms = lib.platforms.linux; maintainers = with lib.maintainers; [ rewine ]; }; }) - diff --git a/pkgs/development/libraries/wayqt/default.nix b/pkgs/development/libraries/wayqt/default.nix index 47e11c9f10d0a0..86fa6cd2032580 100644 --- a/pkgs/development/libraries/wayqt/default.nix +++ b/pkgs/development/libraries/wayqt/default.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitLab -, substituteAll -, meson -, pkg-config -, qttools -, ninja -, qtbase -, qtwayland -, wayland +{ + stdenv, + lib, + fetchFromGitLab, + substituteAll, + meson, + pkg-config, + qttools, + ninja, + qtbase, + qtwayland, + wayland, }: stdenv.mkDerivation (finalAttrs: { @@ -49,7 +50,10 @@ stdenv.mkDerivation (finalAttrs: { dontWrapQtApps = true; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = { homepage = "https://gitlab.com/desktop-frameworks/wayqt"; diff --git a/pkgs/development/libraries/webkit2-sharp/default.nix b/pkgs/development/libraries/webkit2-sharp/default.nix index 6407a8709f6e87..78b89397b76dab 100644 --- a/pkgs/development/libraries/webkit2-sharp/default.nix +++ b/pkgs/development/libraries/webkit2-sharp/default.nix @@ -42,7 +42,7 @@ stdenv.mkDerivation rec { ''; ac_cv_path_MONODOCER = "no"; - installFlags = ["GAPIXMLDIR=/tmp/gapixml"]; + installFlags = [ "GAPIXMLDIR=/tmp/gapixml" ]; passthru = { inherit webkitgtk; diff --git a/pkgs/development/libraries/webkitgtk/default.nix b/pkgs/development/libraries/webkitgtk/default.nix index 153ba7901460d8..9a48e668b54884 100644 --- a/pkgs/development/libraries/webkitgtk/default.nix +++ b/pkgs/development/libraries/webkitgtk/default.nix @@ -1,88 +1,98 @@ -{ lib -, clangStdenv -, buildPackages -, runCommand -, fetchurl -, perl -, python3 -, ruby -, gi-docgen -, bison -, gperf -, cmake -, ninja -, pkg-config -, gettext -, gobject-introspection -, gnutls -, libgcrypt -, libgpg-error -, gtk3 -, wayland -, wayland-protocols -, wayland-scanner -, libwebp -, enchant2 -, xorg -, libxkbcommon -, libavif -, libepoxy -, libjxl -, at-spi2-core -, cairo -, libxml2 -, libsoup -, libsecret -, libxslt -, harfbuzz -, hyphen -, libsysprof-capture -, libpthreadstubs -, nettle -, libtasn1 -, p11-kit -, libidn -, libedit -, readline -, apple_sdk -, libGL -, libGLU -, mesa -, libintl -, lcms2 -, libmanette -, geoclue2 -, flite -, fontconfig -, freetype -, openssl -, sqlite -, gst-plugins-base -, gst-plugins-bad -, woff2 -, bubblewrap -, libseccomp -, libbacktrace -, systemd -, xdg-dbus-proxy -, substituteAll -, glib -, unifdef -, addDriverRunpath -, enableGeoLocation ? true -, enableExperimental ? false -, withLibsecret ? true -, systemdSupport ? lib.meta.availableOn clangStdenv.hostPlatform systemd -, testers +{ + lib, + clangStdenv, + buildPackages, + runCommand, + fetchurl, + perl, + python3, + ruby, + gi-docgen, + bison, + gperf, + cmake, + ninja, + pkg-config, + gettext, + gobject-introspection, + gnutls, + libgcrypt, + libgpg-error, + gtk3, + wayland, + wayland-protocols, + wayland-scanner, + libwebp, + enchant2, + xorg, + libxkbcommon, + libavif, + libepoxy, + libjxl, + at-spi2-core, + cairo, + libxml2, + libsoup, + libsecret, + libxslt, + harfbuzz, + hyphen, + libsysprof-capture, + libpthreadstubs, + nettle, + libtasn1, + p11-kit, + libidn, + libedit, + readline, + apple_sdk, + libGL, + libGLU, + mesa, + libintl, + lcms2, + libmanette, + geoclue2, + flite, + fontconfig, + freetype, + openssl, + sqlite, + gst-plugins-base, + gst-plugins-bad, + woff2, + bubblewrap, + libseccomp, + libbacktrace, + systemd, + xdg-dbus-proxy, + substituteAll, + glib, + unifdef, + addDriverRunpath, + enableGeoLocation ? true, + enableExperimental ? false, + withLibsecret ? true, + systemdSupport ? lib.meta.availableOn clangStdenv.hostPlatform systemd, + testers, }: # https://webkitgtk.org/2024/10/04/webkitgtk-2.46.html recommends building with clang. clangStdenv.mkDerivation (finalAttrs: { pname = "webkitgtk"; version = "2.46.4"; - name = "${finalAttrs.pname}-${finalAttrs.version}+abi=${if lib.versionAtLeast gtk3.version "4.0" then "6.0" else "4.${if lib.versions.major libsoup.version == "2" then "0" else "1"}"}"; + name = "${finalAttrs.pname}-${finalAttrs.version}+abi=${ + if lib.versionAtLeast gtk3.version "4.0" then + "6.0" + else + "4.${if lib.versions.major libsoup.version == "2" then "0" else "1"}" + }"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; # https://github.com/NixOS/nixpkgs/issues/153528 # Can't be linked within a 4GB address space. @@ -109,93 +119,111 @@ clangStdenv.mkDerivation (finalAttrs: { cmakeFlags+=" -DCMAKE_IGNORE_PATH=${lib.getBin gettext}/bin" ''; - nativeBuildInputs = [ - bison - cmake - gettext - gobject-introspection - gperf - ninja - perl - perl.pkgs.FileCopyRecursive # used by copy-user-interface-resources.pl - pkg-config - python3 - ruby - gi-docgen - glib # for gdbus-codegen - unifdef - ] ++ lib.optionals clangStdenv.hostPlatform.isLinux [ - wayland-scanner - ]; + nativeBuildInputs = + [ + bison + cmake + gettext + gobject-introspection + gperf + ninja + perl + perl.pkgs.FileCopyRecursive # used by copy-user-interface-resources.pl + pkg-config + python3 + ruby + gi-docgen + glib # for gdbus-codegen + unifdef + ] + ++ lib.optionals clangStdenv.hostPlatform.isLinux [ + wayland-scanner + ]; - buildInputs = [ - at-spi2-core - cairo # required even when using skia - enchant2 - libavif - libepoxy - libjxl - gnutls - gst-plugins-bad - gst-plugins-base - harfbuzz - hyphen - libGL - libGLU - mesa # for libEGL headers - libgcrypt - libgpg-error - libidn - libintl - lcms2 - libpthreadstubs - libsysprof-capture - libtasn1 - libwebp - libxkbcommon - libxml2 - libxslt - libbacktrace - nettle - p11-kit - sqlite - woff2 - ] ++ lib.optionals clangStdenv.hostPlatform.isBigEndian [ - # https://bugs.webkit.org/show_bug.cgi?id=274032 - fontconfig - freetype - ] ++ lib.optionals clangStdenv.hostPlatform.isDarwin [ - libedit - readline - ] ++ lib.optional (clangStdenv.hostPlatform.isDarwin && lib.versionOlder clangStdenv.hostPlatform.darwinSdkVersion "11.0") ( - # this can likely be removed as: - # "libproc.h is included in the 10.12 SDK Libsystem and should be identical to this one." - # but the package is marked broken on darwin so unable to test + buildInputs = + [ + at-spi2-core + cairo # required even when using skia + enchant2 + libavif + libepoxy + libjxl + gnutls + gst-plugins-bad + gst-plugins-base + harfbuzz + hyphen + libGL + libGLU + mesa # for libEGL headers + libgcrypt + libgpg-error + libidn + libintl + lcms2 + libpthreadstubs + libsysprof-capture + libtasn1 + libwebp + libxkbcommon + libxml2 + libxslt + libbacktrace + nettle + p11-kit + sqlite + woff2 + ] + ++ lib.optionals clangStdenv.hostPlatform.isBigEndian [ + # https://bugs.webkit.org/show_bug.cgi?id=274032 + fontconfig + freetype + ] + ++ lib.optionals clangStdenv.hostPlatform.isDarwin [ + libedit + readline + ] + ++ + lib.optional + ( + clangStdenv.hostPlatform.isDarwin + && lib.versionOlder clangStdenv.hostPlatform.darwinSdkVersion "11.0" + ) + ( + # this can likely be removed as: + # "libproc.h is included in the 10.12 SDK Libsystem and should be identical to this one." + # but the package is marked broken on darwin so unable to test - # Pull a header that contains a definition of proc_pid_rusage(). - # (We pick just that one because using the other headers from `sdk` is not - # compatible with our C++ standard library. This header is already in - # the standard library on aarch64) - runCommand "webkitgtk_headers" { } '' - install -Dm444 "${lib.getDev apple_sdk.sdk}"/include/libproc.h "$out"/include/libproc.h - '' - ) ++ lib.optionals clangStdenv.hostPlatform.isLinux [ - libseccomp - libmanette - wayland - xorg.libX11 - ] ++ lib.optionals systemdSupport [ - systemd - ] ++ lib.optionals enableGeoLocation [ - geoclue2 - ] ++ lib.optionals enableExperimental [ - flite - openssl - ] ++ lib.optionals withLibsecret [ - libsecret - ] ++ lib.optionals (lib.versionAtLeast gtk3.version "4.0") [ - wayland-protocols - ]; + # Pull a header that contains a definition of proc_pid_rusage(). + # (We pick just that one because using the other headers from `sdk` is not + # compatible with our C++ standard library. This header is already in + # the standard library on aarch64) + runCommand "webkitgtk_headers" { } '' + install -Dm444 "${lib.getDev apple_sdk.sdk}"/include/libproc.h "$out"/include/libproc.h + '' + ) + ++ lib.optionals clangStdenv.hostPlatform.isLinux [ + libseccomp + libmanette + wayland + xorg.libX11 + ] + ++ lib.optionals systemdSupport [ + systemd + ] + ++ lib.optionals enableGeoLocation [ + geoclue2 + ] + ++ lib.optionals enableExperimental [ + flite + openssl + ] + ++ lib.optionals withLibsecret [ + libsecret + ] + ++ lib.optionals (lib.versionAtLeast gtk3.version "4.0") [ + wayland-protocols + ]; propagatedBuildInputs = [ gtk3 @@ -212,12 +240,14 @@ clangStdenv.mkDerivation (finalAttrs: { "-DUSE_SOUP2=${cmakeBool (lib.versions.major libsoup.version == "2")}" "-DUSE_LIBSECRET=${cmakeBool withLibsecret}" "-DENABLE_EXPERIMENTAL_FEATURES=${cmakeBool enableExperimental}" - ] ++ lib.optionals clangStdenv.hostPlatform.isLinux [ + ] + ++ lib.optionals clangStdenv.hostPlatform.isLinux [ # Have to be explicitly specified when cross. # https://github.com/WebKit/WebKit/commit/a84036c6d1d66d723f217a4c29eee76f2039a353 "-DBWRAP_EXECUTABLE=${lib.getExe bubblewrap}" "-DDBUS_PROXY_EXECUTABLE=${lib.getExe xdg-dbus-proxy}" - ] ++ lib.optionals clangStdenv.hostPlatform.isDarwin [ + ] + ++ lib.optionals clangStdenv.hostPlatform.isDarwin [ "-DENABLE_GAMEPAD=OFF" "-DENABLE_GTKDOC=OFF" "-DENABLE_MINIBROWSER=OFF" @@ -225,9 +255,11 @@ clangStdenv.mkDerivation (finalAttrs: { "-DENABLE_X11_TARGET=OFF" "-DUSE_APPLE_ICU=OFF" "-DUSE_OPENGL_OR_ES=OFF" - ] ++ lib.optionals (lib.versionOlder gtk3.version "4.0") [ + ] + ++ lib.optionals (lib.versionOlder gtk3.version "4.0") [ "-DUSE_GTK4=OFF" - ] ++ lib.optionals (!systemdSupport) [ + ] + ++ lib.optionals (!systemdSupport) [ "-DENABLE_JOURNALD_LOG=OFF" ]; diff --git a/pkgs/development/libraries/webrtc-audio-processing/default.nix b/pkgs/development/libraries/webrtc-audio-processing/default.nix index 4f5c7bbdcb1006..a7ed8c8ea0a205 100644 --- a/pkgs/development/libraries/webrtc-audio-processing/default.nix +++ b/pkgs/development/libraries/webrtc-audio-processing/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchurl -, darwin -, abseil-cpp -, meson -, ninja -, pkg-config +{ + lib, + stdenv, + fetchFromGitLab, + fetchurl, + darwin, + abseil-cpp, + meson, + ninja, + pkg-config, }: stdenv.mkDerivation rec { @@ -30,7 +31,10 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ meson @@ -42,7 +46,13 @@ stdenv.mkDerivation rec { abseil-cpp ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ ApplicationServices Foundation ]); + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + ApplicationServices + Foundation + ] + ); env = lib.optionalAttrs stdenv.hostPlatform.isx86_32 { # https://gitlab.freedesktop.org/pulseaudio/webrtc-audio-processing/-/issues/5 @@ -53,11 +63,19 @@ stdenv.mkDerivation rec { homepage = "https://www.freedesktop.org/software/pulseaudio/webrtc-audio-processing"; description = "More Linux packaging friendly copy of the AudioProcessing module from the WebRTC project"; license = licenses.bsd3; - platforms = intersectLists - # https://gitlab.freedesktop.org/pulseaudio/webrtc-audio-processing/-/blob/master/meson.build - (platforms.darwin ++ platforms.linux ++ platforms.windows) - # https://gitlab.freedesktop.org/pulseaudio/webrtc-audio-processing/-/blob/master/webrtc/rtc_base/system/arch.h - (platforms.arm ++ platforms.aarch64 ++ platforms.mips ++ platforms.power ++ platforms.riscv ++ platforms.x86); + platforms = + intersectLists + # https://gitlab.freedesktop.org/pulseaudio/webrtc-audio-processing/-/blob/master/meson.build + (platforms.darwin ++ platforms.linux ++ platforms.windows) + # https://gitlab.freedesktop.org/pulseaudio/webrtc-audio-processing/-/blob/master/webrtc/rtc_base/system/arch.h + ( + platforms.arm + ++ platforms.aarch64 + ++ platforms.mips + ++ platforms.power + ++ platforms.riscv + ++ platforms.x86 + ); # BE platforms are unsupported # https://gitlab.freedesktop.org/pulseaudio/webrtc-audio-processing/-/issues/31 badPlatforms = platforms.bigEndian; diff --git a/pkgs/development/libraries/wiiuse/default.nix b/pkgs/development/libraries/wiiuse/default.nix index b3fe943494534a..2f4222de053ed2 100644 --- a/pkgs/development/libraries/wiiuse/default.nix +++ b/pkgs/development/libraries/wiiuse/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, bluez -, libobjc -, Foundation -, IOBluetooth +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + bluez, + libobjc, + Foundation, + IOBluetooth, }: stdenv.mkDerivation rec { @@ -21,8 +22,13 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ bluez ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libobjc Foundation IOBluetooth ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ bluez ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + Foundation + IOBluetooth + ]; propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ bluez ]; diff --git a/pkgs/development/libraries/wildmidi/default.nix b/pkgs/development/libraries/wildmidi/default.nix index 19a8ae3d3957e4..5433a09dc9559a 100644 --- a/pkgs/development/libraries/wildmidi/default.nix +++ b/pkgs/development/libraries/wildmidi/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, writeTextFile, cmake, alsa-lib, OpenAL, CoreAudioKit, freepats }: +{ + lib, + stdenv, + fetchFromGitHub, + writeTextFile, + cmake, + alsa-lib, + OpenAL, + CoreAudioKit, + freepats, +}: let defaultCfgPath = "${placeholder "out"}/etc/wildmidi/wildmidi.cfg"; @@ -16,11 +26,15 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = lib.optionals stdenv.buildPlatform.isLinux [ - alsa-lib stdenv.cc.libc/*couldn't find libm*/ - ] ++ lib.optionals stdenv.buildPlatform.isDarwin [ - OpenAL CoreAudioKit - ]; + buildInputs = + lib.optionals stdenv.buildPlatform.isLinux [ + alsa-lib + stdenv.cc.libc # couldn't find libm + ] + ++ lib.optionals stdenv.buildPlatform.isDarwin [ + OpenAL + CoreAudioKit + ]; preConfigure = '' # https://github.com/Mindwerks/wildmidi/issues/236 @@ -33,18 +47,20 @@ stdenv.mkDerivation rec { "-DWILDMIDI_CFG=${defaultCfgPath}" ]; - postInstall = let - defaultCfg = writeTextFile { - name = "wildmidi.cfg"; - text = '' - dir ${freepats} - source ${freepats}/freepats.cfg - ''; - }; - in '' - mkdir -p "$(dirname ${defaultCfgPath})" - ln -s ${defaultCfg} ${defaultCfgPath} - ''; + postInstall = + let + defaultCfg = writeTextFile { + name = "wildmidi.cfg"; + text = '' + dir ${freepats} + source ${freepats}/freepats.cfg + ''; + }; + in + '' + mkdir -p "$(dirname ${defaultCfgPath})" + ln -s ${defaultCfg} ${defaultCfgPath} + ''; meta = with lib; { description = "Software MIDI player and library"; diff --git a/pkgs/development/libraries/wlroots/default.nix b/pkgs/development/libraries/wlroots/default.nix index 7f6213c7df1876..1e8192dcb6379a 100644 --- a/pkgs/development/libraries/wlroots/default.nix +++ b/pkgs/development/libraries/wlroots/default.nix @@ -1,37 +1,46 @@ -{ lib -, stdenv -, fetchFromGitLab -, meson -, ninja -, pkg-config -, wayland-scanner -, libGL -, wayland -, wayland-protocols -, libinput -, libxkbcommon -, pixman -, libcap -, mesa -, xorg -, libpng -, ffmpeg -, hwdata -, seatd -, vulkan-loader -, glslang -, libliftoff -, libdisplay-info -, lcms2 -, nixosTests -, testers - -, enableXWayland ? true -, xwayland ? null +{ + lib, + stdenv, + fetchFromGitLab, + meson, + ninja, + pkg-config, + wayland-scanner, + libGL, + wayland, + wayland-protocols, + libinput, + libxkbcommon, + pixman, + libcap, + mesa, + xorg, + libpng, + ffmpeg, + hwdata, + seatd, + vulkan-loader, + glslang, + libliftoff, + libdisplay-info, + lcms2, + nixosTests, + testers, + + enableXWayland ? true, + xwayland ? null, }: let - generic = { version, hash, extraBuildInputs ? [ ], extraNativeBuildInputs ? [ ], patches ? [ ], postPatch ? "" }: + generic = + { + version, + hash, + extraBuildInputs ? [ ], + extraNativeBuildInputs ? [ ], + patches ? [ ], + postPatch ? "", + }: stdenv.mkDerivation (finalAttrs: { pname = "wlroots"; inherit version; @@ -49,38 +58,45 @@ let inherit patches postPatch; # $out for the library and $examples for the example programs (in examples): - outputs = [ "out" "examples" ]; + outputs = [ + "out" + "examples" + ]; strictDeps = true; depsBuildBuild = [ pkg-config ]; - nativeBuildInputs = [ meson ninja pkg-config wayland-scanner glslang ] - ++ extraNativeBuildInputs; - - buildInputs = [ - libGL - libcap - libinput - libpng - libxkbcommon - mesa - pixman - seatd - vulkan-loader - wayland - wayland-protocols - xorg.libX11 - xorg.xcbutilerrors - xorg.xcbutilimage - xorg.xcbutilrenderutil - xorg.xcbutilwm - ] - ++ lib.optional finalAttrs.enableXWayland xwayland - ++ extraBuildInputs; - - mesonFlags = - lib.optional (!finalAttrs.enableXWayland) "-Dxwayland=disabled" - ; + nativeBuildInputs = [ + meson + ninja + pkg-config + wayland-scanner + glslang + ] ++ extraNativeBuildInputs; + + buildInputs = + [ + libGL + libcap + libinput + libpng + libxkbcommon + mesa + pixman + seatd + vulkan-loader + wayland + wayland-protocols + xorg.libX11 + xorg.xcbutilerrors + xorg.xcbutilimage + xorg.xcbutilrenderutil + xorg.xcbutilwm + ] + ++ lib.optional finalAttrs.enableXWayland xwayland + ++ extraBuildInputs; + + mesonFlags = lib.optional (!finalAttrs.enableXWayland) "-Dxwayland=disabled"; postFixup = '' # Install ALL example programs to $examples: @@ -112,11 +128,18 @@ let changelog = "https://gitlab.freedesktop.org/wlroots/wlroots/-/tags/${version}"; license = lib.licenses.mit; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ primeos synthetica rewine ]; + maintainers = with lib.maintainers; [ + primeos + synthetica + rewine + ]; pkgConfigModules = [ - (if lib.versionOlder finalAttrs.version "0.18" - then "wlroots" - else "wlroots-${lib.versions.majorMinor finalAttrs.version}") + ( + if lib.versionOlder finalAttrs.version "0.18" then + "wlroots" + else + "wlroots-${lib.versions.majorMinor finalAttrs.version}" + ) ]; }; }); diff --git a/pkgs/development/libraries/wlroots/protocols.nix b/pkgs/development/libraries/wlroots/protocols.nix index c928da147e1262..898513a9d4f170 100644 --- a/pkgs/development/libraries/wlroots/protocols.nix +++ b/pkgs/development/libraries/wlroots/protocols.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, wayland-scanner }: +{ + lib, + stdenv, + fetchFromGitLab, + wayland-scanner, +}: stdenv.mkDerivation { pname = "wlr-protocols"; @@ -24,7 +29,10 @@ stdenv.mkDerivation { doCheck = true; checkTarget = "check"; - installFlags = [ "DESTDIR=$(out)" "PREFIX=" ]; + installFlags = [ + "DESTDIR=$(out)" + "PREFIX=" + ]; meta = with lib; { description = "Wayland roots protocol extensions"; @@ -35,9 +43,9 @@ stdenv.mkDerivation { extend the functionality of some other protocol either in Wayland core, or some other protocol in wayland-protocols. ''; - homepage = "https://gitlab.freedesktop.org/wlroots/wlr-protocols"; - license = licenses.mit; # See file headers - platforms = platforms.linux; + homepage = "https://gitlab.freedesktop.org/wlroots/wlr-protocols"; + license = licenses.mit; # See file headers + platforms = platforms.linux; maintainers = with maintainers; [ Scrumplex ]; }; } diff --git a/pkgs/development/libraries/wolfssl/default.nix b/pkgs/development/libraries/wolfssl/default.nix index 0a8202839c3648..549231806144a9 100644 --- a/pkgs/development/libraries/wolfssl/default.nix +++ b/pkgs/development/libraries/wolfssl/default.nix @@ -1,17 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, Security -, autoreconfHook -, util-linux -, openssl -, cacert -# The primary --enable-XXX variant. 'all' enables most features, but causes build-errors for some software, -# requiring to build a special variant for that software. Example: 'haproxy' -, variant ? "all" -, extraConfigureFlags ? [] -, enableARMCryptoExtensions ? stdenv.hostPlatform.isAarch64 && ((builtins.match "^.*\\+crypto.*$" stdenv.hostPlatform.gcc.arch) != null) -, enableLto ? !(stdenv.hostPlatform.isStatic || stdenv.cc.isClang) +{ + lib, + stdenv, + fetchFromGitHub, + Security, + autoreconfHook, + util-linux, + openssl, + cacert, + # The primary --enable-XXX variant. 'all' enables most features, but causes build-errors for some software, + # requiring to build a special variant for that software. Example: 'haproxy' + variant ? "all", + extraConfigureFlags ? [ ], + enableARMCryptoExtensions ? + stdenv.hostPlatform.isAarch64 + && ((builtins.match "^.*\\+crypto.*$" stdenv.hostPlatform.gcc.arch) != null), + enableLto ? !(stdenv.hostPlatform.isStatic || stdenv.cc.isClang), }: stdenv.mkDerivation (finalAttrs: { pname = "wolfssl-${variant}"; @@ -31,37 +34,45 @@ stdenv.mkDerivation (finalAttrs: { --replace '"linux-gnu"' '"linux-"' ''; - configureFlags = [ - "--enable-${variant}" - "--enable-reproducible-build" - ] ++ lib.optionals (variant == "all") [ - # Extra feature flags to add while building the 'all' variant. - # Since they conflict while building other variants, only specify them for this one. - "--enable-pkcs11" - "--enable-writedup" - "--enable-base64encode" - ] ++ [ - # We're not on tiny embedded machines. - # Increase TLS session cache from 33 sessions to 20k. - "--enable-bigcache" + configureFlags = + [ + "--enable-${variant}" + "--enable-reproducible-build" + ] + ++ lib.optionals (variant == "all") [ + # Extra feature flags to add while building the 'all' variant. + # Since they conflict while building other variants, only specify them for this one. + "--enable-pkcs11" + "--enable-writedup" + "--enable-base64encode" + ] + ++ [ + # We're not on tiny embedded machines. + # Increase TLS session cache from 33 sessions to 20k. + "--enable-bigcache" - # Use WolfSSL's Single Precision Math with timing-resistant cryptography. - "--enable-sp=yes${lib.optionalString (stdenv.hostPlatform.isx86_64 || stdenv.hostPlatform.isAarch) ",asm"}" - "--enable-sp-math-all" - "--enable-harden" - ] ++ lib.optionals (stdenv.hostPlatform.isx86_64) [ - # Enable AVX/AVX2/AES-NI instructions, gated by runtime detection via CPUID. - "--enable-intelasm" - "--enable-aesni" - ] ++ lib.optionals (stdenv.hostPlatform.isAarch64) [ - # No runtime detection under ARM and no platform function checks like for X86. - (if enableARMCryptoExtensions - then "--enable-armasm=inline" - else "--disable-armasm") - ] ++ extraConfigureFlags; + # Use WolfSSL's Single Precision Math with timing-resistant cryptography. + "--enable-sp=yes${ + lib.optionalString (stdenv.hostPlatform.isx86_64 || stdenv.hostPlatform.isAarch) ",asm" + }" + "--enable-sp-math-all" + "--enable-harden" + ] + ++ lib.optionals (stdenv.hostPlatform.isx86_64) [ + # Enable AVX/AVX2/AES-NI instructions, gated by runtime detection via CPUID. + "--enable-intelasm" + "--enable-aesni" + ] + ++ lib.optionals (stdenv.hostPlatform.isAarch64) [ + # No runtime detection under ARM and no platform function checks like for X86. + (if enableARMCryptoExtensions then "--enable-armasm=inline" else "--disable-armasm") + ] + ++ extraConfigureFlags; # Breaks tls13 tests on aarch64-darwin. - hardeningDisable = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ "zerocallusedregs" ]; + hardeningDisable = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) [ + "zerocallusedregs" + ]; # LTO should help with the C implementations. env.NIX_CFLAGS_COMPILE = lib.optionalString enableLto "-flto"; @@ -108,6 +119,9 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://github.com/wolfSSL/wolfssl/releases/tag/v${finalAttrs.version}-stable"; platforms = platforms.all; license = licenses.gpl2Plus; - maintainers = with maintainers; [ fab vifino ]; + maintainers = with maintainers; [ + fab + vifino + ]; }; }) diff --git a/pkgs/development/libraries/wxSVG/default.nix b/pkgs/development/libraries/wxSVG/default.nix index a1a08d3eb1d795..6cccca05c7935f 100644 --- a/pkgs/development/libraries/wxSVG/default.nix +++ b/pkgs/development/libraries/wxSVG/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchurl -, cairo -, expat -, ffmpeg -, libexif -, pango -, pkg-config -, wxGTK -, darwin +{ + lib, + stdenv, + fetchurl, + cairo, + expat, + ffmpeg, + libexif, + pango, + pkg-config, + wxGTK, + darwin, }: let diff --git a/pkgs/development/libraries/wxsqlite3/default.nix b/pkgs/development/libraries/wxsqlite3/default.nix index f06af1417de8c4..d2c019b43ae2a7 100644 --- a/pkgs/development/libraries/wxsqlite3/default.nix +++ b/pkgs/development/libraries/wxsqlite3/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, wxGTK -, sqlite -, Cocoa -, setfile -, rez -, derez +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + wxGTK, + sqlite, + Cocoa, + setfile, + rez, + derez, }: stdenv.mkDerivation rec { @@ -23,14 +24,26 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ sqlite wxGTK ] - ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ Cocoa setfile rez derez ]; + buildInputs = + [ + sqlite + wxGTK + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ + Cocoa + setfile + rez + derez + ]; meta = with lib; { homepage = "https://utelle.github.io/wxsqlite3/"; description = "C++ wrapper around the public domain SQLite 3.x for wxWidgets"; platforms = platforms.unix; maintainers = [ ]; - license = with licenses; [ lgpl3Plus gpl3Plus ]; + license = with licenses; [ + lgpl3Plus + gpl3Plus + ]; }; } diff --git a/pkgs/development/libraries/wxsqliteplus/default.nix b/pkgs/development/libraries/wxsqliteplus/default.nix index 2d980c69cbe63a..0120571bb09b7f 100644 --- a/pkgs/development/libraries/wxsqliteplus/default.nix +++ b/pkgs/development/libraries/wxsqliteplus/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, wxGTK, wxsqlite3, sqlite, Cocoa, setfile }: +{ + lib, + stdenv, + fetchFromGitHub, + wxGTK, + wxsqlite3, + sqlite, + Cocoa, + setfile, +}: stdenv.mkDerivation rec { pname = "wxsqliteplus"; @@ -15,26 +24,36 @@ stdenv.mkDerivation rec { sed -i '/WX_CLEAR_ARRAY/s/$/;/' src/{createtable,sqlite3table}.cpp ''; - buildInputs = [ wxGTK wxsqlite3 sqlite ] ++ lib.optional stdenv.hostPlatform.isDarwin Cocoa; + buildInputs = [ + wxGTK + wxsqlite3 + sqlite + ] ++ lib.optional stdenv.hostPlatform.isDarwin Cocoa; - makeFlags = [ - "LDFLAGS=-L${wxsqlite3}/lib" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "SETFILE=${setfile}/bin/SetFile" - ]; + makeFlags = + [ + "LDFLAGS=-L${wxsqlite3}/lib" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "SETFILE=${setfile}/bin/SetFile" + ]; preBuild = '' sed -ie 's|all: $(LIBPREFIX)wxsqlite$(LIBEXT)|all: |g' Makefile sed -ie 's|wxsqliteplus$(EXEEXT): $(WXSQLITEPLUS_OBJECTS) $(LIBPREFIX)wxsqlite$(LIBEXT)|wxsqliteplus$(EXEEXT): $(WXSQLITEPLUS_OBJECTS) |g' Makefile - sed -ie 's|-lwxsqlite |-lwxcode_${if stdenv.hostPlatform.isDarwin then "osx_cocoau_wxsqlite3-3.2.0" else "gtk3u_wxsqlite3-3.2"} |g' Makefile + sed -ie 's|-lwxsqlite |-lwxcode_${ + if stdenv.hostPlatform.isDarwin then "osx_cocoau_wxsqlite3-3.2.0" else "gtk3u_wxsqlite3-3.2" + } |g' Makefile ''; - installPhase = '' - install -D ${lib.optionalString stdenv.hostPlatform.isDarwin "wxsqliteplus.app/Contents/MacOS/"}wxsqliteplus $out/bin/wxsqliteplus - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/Applications - mv wxsqliteplus.app $out/Applications/ - ''; + installPhase = + '' + install -D ${lib.optionalString stdenv.hostPlatform.isDarwin "wxsqliteplus.app/Contents/MacOS/"}wxsqliteplus $out/bin/wxsqliteplus + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/Applications + mv wxsqliteplus.app $out/Applications/ + ''; meta = with lib; { description = "Simple SQLite database browser built with wxWidgets"; diff --git a/pkgs/development/libraries/wxwidgets/wxGTK31.nix b/pkgs/development/libraries/wxwidgets/wxGTK31.nix index 1379a15801e6c9..1c72e919aed538 100644 --- a/pkgs/development/libraries/wxwidgets/wxGTK31.nix +++ b/pkgs/development/libraries/wxwidgets/wxGTK31.nix @@ -1,35 +1,36 @@ -{ lib -, stdenv -, fetchFromGitHub -, curl -, gst_all_1 -, gtk3 -, libGL -, libGLU -, libSM -, libXinerama -, libXtst -, libXxf86vm -, pkg-config -, xorgproto -, compat28 ? false -, compat30 ? true -, unicode ? true -, withCurl ? false -, withPrivateFonts ? false -, withEGL ? true -, withMesa ? !stdenv.hostPlatform.isDarwin -, withWebKit ? stdenv.hostPlatform.isDarwin -, webkitgtk_4_0 -, setfile -, AGL -, Carbon -, Cocoa -, Kernel -, QTKit -, AVFoundation -, AVKit -, WebKit +{ + lib, + stdenv, + fetchFromGitHub, + curl, + gst_all_1, + gtk3, + libGL, + libGLU, + libSM, + libXinerama, + libXtst, + libXxf86vm, + pkg-config, + xorgproto, + compat28 ? false, + compat30 ? true, + unicode ? true, + withCurl ? false, + withPrivateFonts ? false, + withEGL ? true, + withMesa ? !stdenv.hostPlatform.isDarwin, + withWebKit ? stdenv.hostPlatform.isDarwin, + webkitgtk_4_0, + setfile, + AGL, + Carbon, + Cocoa, + Kernel, + QTKit, + AVFoundation, + AVKit, + WebKit, }: stdenv.mkDerivation rec { @@ -51,71 +52,79 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - gst_all_1.gst-plugins-base - gst_all_1.gstreamer - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - gtk3 - libSM - libXinerama - libXtst - libXxf86vm - xorgproto - ] - ++ lib.optional withCurl curl - ++ lib.optional withMesa libGLU - ++ lib.optional (withWebKit && !stdenv.hostPlatform.isDarwin) webkitgtk_4_0 - ++ lib.optional (withWebKit && stdenv.hostPlatform.isDarwin) WebKit - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - setfile - Carbon - Cocoa - Kernel - QTKit - AVFoundation - AVKit - WebKit - ]; + buildInputs = + [ + gst_all_1.gst-plugins-base + gst_all_1.gstreamer + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + gtk3 + libSM + libXinerama + libXtst + libXxf86vm + xorgproto + ] + ++ lib.optional withCurl curl + ++ lib.optional withMesa libGLU + ++ lib.optional (withWebKit && !stdenv.hostPlatform.isDarwin) webkitgtk_4_0 + ++ lib.optional (withWebKit && stdenv.hostPlatform.isDarwin) WebKit + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + setfile + Carbon + Cocoa + Kernel + QTKit + AVFoundation + AVKit + WebKit + ]; propagatedBuildInputs = lib.optional stdenv.hostPlatform.isDarwin AGL; - configureFlags = [ - "--disable-precomp-headers" - # This is the default option, but be explicit - "--disable-monolithic" - "--enable-mediactrl" - (if compat28 then "--enable-compat28" else "--disable-compat28") - (if compat30 then "--enable-compat30" else "--disable-compat30") - ] - ++ lib.optional (!withEGL) "--disable-glcanvasegl" - ++ lib.optional unicode "--enable-unicode" - ++ lib.optional withCurl "--enable-webrequest" - ++ lib.optional withPrivateFonts "--enable-privatefonts" - ++ lib.optional withMesa "--with-opengl" - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "--with-osx_cocoa" - "--with-libiconv" - ] ++ lib.optionals withWebKit [ - "--enable-webview" - "--enable-webviewwebkit" - ]; + configureFlags = + [ + "--disable-precomp-headers" + # This is the default option, but be explicit + "--disable-monolithic" + "--enable-mediactrl" + (if compat28 then "--enable-compat28" else "--disable-compat28") + (if compat30 then "--enable-compat30" else "--disable-compat30") + ] + ++ lib.optional (!withEGL) "--disable-glcanvasegl" + ++ lib.optional unicode "--enable-unicode" + ++ lib.optional withCurl "--enable-webrequest" + ++ lib.optional withPrivateFonts "--enable-privatefonts" + ++ lib.optional withMesa "--with-opengl" + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "--with-osx_cocoa" + "--with-libiconv" + ] + ++ lib.optionals withWebKit [ + "--enable-webview" + "--enable-webviewwebkit" + ]; - SEARCH_LIB = lib.optionalString (!stdenv.hostPlatform.isDarwin) "${libGLU.out}/lib ${libGL.out}/lib "; + SEARCH_LIB = lib.optionalString ( + !stdenv.hostPlatform.isDarwin + ) "${libGLU.out}/lib ${libGL.out}/lib "; - preConfigure = '' - substituteInPlace configure --replace \ - 'SEARCH_INCLUDE=' 'DUMMY_SEARCH_INCLUDE=' - substituteInPlace configure --replace \ - 'SEARCH_LIB=' 'DUMMY_SEARCH_LIB=' - substituteInPlace configure --replace \ - /usr /no-such-path - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace configure --replace \ - 'ac_cv_prog_SETFILE="/Developer/Tools/SetFile"' \ - 'ac_cv_prog_SETFILE="${setfile}/bin/SetFile"' - substituteInPlace configure --replace \ - "-framework System" "-lSystem" - ''; + preConfigure = + '' + substituteInPlace configure --replace \ + 'SEARCH_INCLUDE=' 'DUMMY_SEARCH_INCLUDE=' + substituteInPlace configure --replace \ + 'SEARCH_LIB=' 'DUMMY_SEARCH_LIB=' + substituteInPlace configure --replace \ + /usr /no-such-path + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace configure --replace \ + 'ac_cv_prog_SETFILE="/Developer/Tools/SetFile"' \ + 'ac_cv_prog_SETFILE="${setfile}/bin/SetFile"' + substituteInPlace configure --replace \ + "-framework System" "-lSystem" + ''; postInstall = " pushd $out/include diff --git a/pkgs/development/libraries/xcb-util-cursor/HEAD.nix b/pkgs/development/libraries/xcb-util-cursor/HEAD.nix index 4ac58c3f3d0a6a..a13169f25da5ea 100644 --- a/pkgs/development/libraries/xcb-util-cursor/HEAD.nix +++ b/pkgs/development/libraries/xcb-util-cursor/HEAD.nix @@ -1,27 +1,45 @@ -{ lib, stdenv, fetchgit, autoconf, automake, libtool, pkg-config -, xorg, gnum4, libxcb, gperf }: +{ + lib, + stdenv, + fetchgit, + autoconf, + automake, + libtool, + pkg-config, + xorg, + gnum4, + libxcb, + gperf, +}: stdenv.mkDerivation { pname = "xcb-util-cursor-0.1.1-3-unstable"; version = "2017-04-05"; src = fetchgit { - url = "http://anongit.freedesktop.org/git/xcb/util-cursor.git"; - rev = "f03cc278c6cce0cf721adf9c3764d3c5fba63392"; + url = "http://anongit.freedesktop.org/git/xcb/util-cursor.git"; + rev = "f03cc278c6cce0cf721adf9c3764d3c5fba63392"; sha256 = "127zfmihd8nqlj8jjaja06xb84xdgl263w0av1xnprx05mkbkcyc"; }; meta = with lib; { description = "XCB cursor library (libxcursor port)"; - homepage = "https://cgit.freedesktop.org/xcb/util-cursor"; - license = licenses.mit; + homepage = "https://cgit.freedesktop.org/xcb/util-cursor"; + license = licenses.mit; maintainers = with maintainers; [ lovek323 ]; - platforms = platforms.linux ++ platforms.darwin; + platforms = platforms.linux ++ platforms.darwin; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ autoconf automake pkg-config ]; + nativeBuildInputs = [ + autoconf + automake + pkg-config + ]; buildInputs = [ gnum4 gperf diff --git a/pkgs/development/libraries/xdg-desktop-portal/default.nix b/pkgs/development/libraries/xdg-desktop-portal/default.nix index 6275dafd6bcd74..b492fba90534dd 100644 --- a/pkgs/development/libraries/xdg-desktop-portal/default.nix +++ b/pkgs/development/libraries/xdg-desktop-portal/default.nix @@ -1,42 +1,46 @@ -{ lib -, fetchFromGitHub -, flatpak -, fuse3 -, bubblewrap -, docbook_xml_dtd_412 -, docbook_xml_dtd_43 -, docbook_xsl -, docutils -, systemdMinimal -, geoclue2 -, glib -, gsettings-desktop-schemas -, json-glib -, libportal -, libxml2 -, meson -, ninja -, nixosTests -, pipewire -, gdk-pixbuf -, librsvg -, gobject-introspection -, python3 -, pkg-config -, stdenv -, runCommand -, wrapGAppsHook3 -, xmlto -, bash -, enableGeoLocation ? true -, enableSystemd ? true +{ + lib, + fetchFromGitHub, + flatpak, + fuse3, + bubblewrap, + docbook_xml_dtd_412, + docbook_xml_dtd_43, + docbook_xsl, + docutils, + systemdMinimal, + geoclue2, + glib, + gsettings-desktop-schemas, + json-glib, + libportal, + libxml2, + meson, + ninja, + nixosTests, + pipewire, + gdk-pixbuf, + librsvg, + gobject-introspection, + python3, + pkg-config, + stdenv, + runCommand, + wrapGAppsHook3, + xmlto, + bash, + enableGeoLocation ? true, + enableSystemd ? true, }: stdenv.mkDerivation (finalAttrs: { pname = "xdg-desktop-portal"; version = "1.18.4"; - outputs = [ "out" "installedTests" ]; + outputs = [ + "out" + "installedTests" + ]; src = fetchFromGitHub { owner = "flatpak"; @@ -89,30 +93,35 @@ stdenv.mkDerivation (finalAttrs: { xmlto ]; - buildInputs = [ - flatpak - fuse3 - bubblewrap - glib - gsettings-desktop-schemas - json-glib - libportal - pipewire - - # For icon validator - gdk-pixbuf - librsvg - - # For document-fuse installed test. - (python3.withPackages (pp: with pp; [ - pygobject3 - ])) - bash - ] ++ lib.optionals enableGeoLocation [ - geoclue2 - ] ++ lib.optionals enableSystemd [ - systemdMinimal # libsystemd - ]; + buildInputs = + [ + flatpak + fuse3 + bubblewrap + glib + gsettings-desktop-schemas + json-glib + libportal + pipewire + + # For icon validator + gdk-pixbuf + librsvg + + # For document-fuse installed test. + (python3.withPackages ( + pp: with pp; [ + pygobject3 + ] + )) + bash + ] + ++ lib.optionals enableGeoLocation [ + geoclue2 + ] + ++ lib.optionals enableSystemd [ + systemdMinimal # libsystemd + ]; nativeCheckInputs = [ gobject-introspection @@ -122,16 +131,19 @@ stdenv.mkDerivation (finalAttrs: { python3.pkgs.dbus-python ]; - mesonFlags = [ - "--sysconfdir=/etc" - "-Dinstalled-tests=true" - "-Dinstalled_test_prefix=${placeholder "installedTests"}" - (lib.mesonEnable "systemd" enableSystemd) - ] ++ lib.optionals (!enableGeoLocation) [ - "-Dgeoclue=disabled" - ] ++ lib.optionals (!finalAttrs.finalPackage.doCheck) [ - "-Dpytest=disabled" - ]; + mesonFlags = + [ + "--sysconfdir=/etc" + "-Dinstalled-tests=true" + "-Dinstalled_test_prefix=${placeholder "installedTests"}" + (lib.mesonEnable "systemd" enableSystemd) + ] + ++ lib.optionals (!enableGeoLocation) [ + "-Dgeoclue=disabled" + ] + ++ lib.optionals (!finalAttrs.finalPackage.doCheck) [ + "-Dpytest=disabled" + ]; strictDeps = true; @@ -148,20 +160,22 @@ stdenv.mkDerivation (finalAttrs: { export TEST_IN_CI=1 ''; - postFixup = let - documentFuse = "${placeholder "installedTests"}/libexec/installed-tests/xdg-desktop-portal/test-document-fuse.py"; - testPortals = "${placeholder "installedTests"}/libexec/installed-tests/xdg-desktop-portal/test-portals"; - - in '' - if [ -x '${documentFuse}' ] ; then - wrapGApp '${documentFuse}' - wrapGApp '${testPortals}' - # (xdg-desktop-portal:995): xdg-desktop-portal-WARNING **: 21:21:55.673: Failed to get GeoClue client: Timeout was reached - # xdg-desktop-portal:ERROR:../tests/location.c:22:location_cb: 'res' should be TRUE - # https://github.com/flatpak/xdg-desktop-portal/blob/1d6dfb57067dec182b546dfb60c87aa3452c77ed/tests/location.c#L21 - rm $installedTests/share/installed-tests/xdg-desktop-portal/test-portals-location.test - fi - ''; + postFixup = + let + documentFuse = "${placeholder "installedTests"}/libexec/installed-tests/xdg-desktop-portal/test-document-fuse.py"; + testPortals = "${placeholder "installedTests"}/libexec/installed-tests/xdg-desktop-portal/test-portals"; + + in + '' + if [ -x '${documentFuse}' ] ; then + wrapGApp '${documentFuse}' + wrapGApp '${testPortals}' + # (xdg-desktop-portal:995): xdg-desktop-portal-WARNING **: 21:21:55.673: Failed to get GeoClue client: Timeout was reached + # xdg-desktop-portal:ERROR:../tests/location.c:22:location_cb: 'res' should be TRUE + # https://github.com/flatpak/xdg-desktop-portal/blob/1d6dfb57067dec182b546dfb60c87aa3452c77ed/tests/location.c#L21 + rm $installedTests/share/installed-tests/xdg-desktop-portal/test-portals-location.test + fi + ''; passthru = { tests = { diff --git a/pkgs/development/libraries/xsd/default.nix b/pkgs/development/libraries/xsd/default.nix index dd50c68574c4df..14600a773bf8c2 100644 --- a/pkgs/development/libraries/xsd/default.nix +++ b/pkgs/development/libraries/xsd/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, xercesc }: +{ + lib, + stdenv, + fetchurl, + xercesc, +}: let in diff --git a/pkgs/development/libraries/yaml-cpp/0.3.0.nix b/pkgs/development/libraries/yaml-cpp/0.3.0.nix index 7e244261005e3b..e1103c33a036b7 100644 --- a/pkgs/development/libraries/yaml-cpp/0.3.0.nix +++ b/pkgs/development/libraries/yaml-cpp/0.3.0.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + cmake, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/yaml-cpp/default.nix b/pkgs/development/libraries/yaml-cpp/default.nix index f87849b58c7221..75941866b60447 100644 --- a/pkgs/development/libraries/yaml-cpp/default.nix +++ b/pkgs/development/libraries/yaml-cpp/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, gitUpdater -, cmake -, static ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + cmake, + static ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/libraries/yubico-pam/default.nix b/pkgs/development/libraries/yubico-pam/default.nix index e60008994b031f..646188c4c69484 100644 --- a/pkgs/development/libraries/yubico-pam/default.nix +++ b/pkgs/development/libraries/yubico-pam/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, asciidoc -, libxslt -, docbook_xsl -, pam -, yubikey-personalization -, libyubikey -, libykclient -, CoreServices -, SystemConfiguration +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + asciidoc, + libxslt, + docbook_xsl, + pam, + yubikey-personalization, + libyubikey, + libykclient, + CoreServices, + SystemConfiguration, }: stdenv.mkDerivation rec { @@ -24,9 +25,24 @@ stdenv.mkDerivation rec { sha256 = "0hb773zlf11xz4bwmsqv2mq5d4aq2g0crdr5cp9xwc4ivi5gd4kg"; }; - nativeBuildInputs = [ autoreconfHook pkg-config asciidoc libxslt docbook_xsl ]; - buildInputs = [ pam yubikey-personalization libyubikey libykclient ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices SystemConfiguration ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + asciidoc + libxslt + docbook_xsl + ]; + buildInputs = + [ + pam + yubikey-personalization + libyubikey + libykclient + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + SystemConfiguration + ]; meta = with lib; { description = "Yubico PAM module"; diff --git a/pkgs/development/libraries/zint/default.nix b/pkgs/development/libraries/zint/default.nix index e6f40879a9cee9..8badae678e1155 100644 --- a/pkgs/development/libraries/zint/default.nix +++ b/pkgs/development/libraries/zint/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, wrapQtAppsHook -, cmake -, qtbase -, qtsvg -, qttools -, testers -, zint +{ + lib, + stdenv, + fetchFromGitHub, + wrapQtAppsHook, + cmake, + qtbase, + qtsvg, + qttools, + testers, + zint, }: stdenv.mkDerivation rec { @@ -21,11 +22,21 @@ stdenv.mkDerivation rec { hash = "sha256-/ILq/7A8Lffe2NuiABiV3KeYXapuL1SO55Qk3wXfC/8="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; - buildInputs = [ qtbase qtsvg qttools ]; + buildInputs = [ + qtbase + qtsvg + qttools + ]; cmakeFlags = [ "-DZINT_QT6:BOOL=ON" ]; diff --git a/pkgs/development/libraries/zlib/default.nix b/pkgs/development/libraries/zlib/default.nix index 23795b6aab40df..47b038358a32ae 100644 --- a/pkgs/development/libraries/zlib/default.nix +++ b/pkgs/development/libraries/zlib/default.nix @@ -1,15 +1,17 @@ -{ lib, stdenv -, fetchurl -, shared ? !stdenv.hostPlatform.isStatic -, static ? true -# If true, a separate .static ouput is created and the .a is moved there. -# In this case `pkg-config` auto detection does not currently work if the -# .static output is given as `buildInputs` to another package (#66461), because -# the `.pc` file lists only the main output's lib dir. -# If false, and if `{ static = true; }`, the .a stays in the main output. -, splitStaticOutput ? shared && static -, testers -, minizip +{ + lib, + stdenv, + fetchurl, + shared ? !stdenv.hostPlatform.isStatic, + static ? true, + # If true, a separate .static ouput is created and the .a is moved there. + # In this case `pkg-config` auto detection does not currently work if the + # .static output is given as `buildInputs` to another package (#66461), because + # the `.pc` file lists only the main output's lib dir. + # If false, and if `{ static = true; }`, the .a stays in the main output. + splitStaticOutput ? shared && static, + testers, + minizip, }: # Without either the build will actually still succeed because the build @@ -27,17 +29,19 @@ stdenv.mkDerivation (finalAttrs: { pname = "zlib"; version = "1.3.1"; - src = let - inherit (finalAttrs) version; - in fetchurl { - urls = [ - # This URL works for 1.2.13 only; hopefully also for future releases. - "https://github.com/madler/zlib/releases/download/v${version}/zlib-${version}.tar.gz" - # Stable archive path, but captcha can be encountered, causing hash mismatch. - "https://www.zlib.net/fossils/zlib-${version}.tar.gz" - ]; - hash = "sha256-mpOyt9/ax3zrpaVYpYDnRmfdb+3kWFuR7vtg8Dty3yM="; - }; + src = + let + inherit (finalAttrs) version; + in + fetchurl { + urls = [ + # This URL works for 1.2.13 only; hopefully also for future releases. + "https://github.com/madler/zlib/releases/download/v${version}/zlib-${version}.tar.gz" + # Stable archive path, but captcha can be encountered, causing hash mismatch. + "https://www.zlib.net/fossils/zlib-${version}.tar.gz" + ]; + hash = "sha256-mpOyt9/ax3zrpaVYpYDnRmfdb+3kWFuR7vtg8Dty3yM="; + }; postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' substituteInPlace configure \ @@ -47,8 +51,10 @@ stdenv.mkDerivation (finalAttrs: { ''; strictDeps = true; - outputs = [ "out" "dev" ] - ++ lib.optional splitStaticOutput "static"; + outputs = [ + "out" + "dev" + ] ++ lib.optional splitStaticOutput "static"; setOutputFlags = false; outputDoc = "dev"; # single tiny man3 page @@ -70,8 +76,7 @@ stdenv.mkDerivation (finalAttrs: { # `--static --shared`, `--shared` and giving nothing. # Of these, we choose `--static --shared`, for clarity and simpler # conditions. - configureFlags = lib.optional static "--static" - ++ lib.optional shared "--shared"; + configureFlags = lib.optional static "--static" ++ lib.optional shared "--shared"; # We do the right thing manually, above, so don't need these. dontDisableStatic = true; dontAddStaticConfigureFlags = true; @@ -84,38 +89,41 @@ stdenv.mkDerivation (finalAttrs: { # here (in case zlib ever switches to autoconf in the future), # but we don't do it simply to avoid mass rebuilds. - postInstall = lib.optionalString splitStaticOutput '' - moveToOutput lib/libz.a "$static" - '' + postInstall = + lib.optionalString splitStaticOutput '' + moveToOutput lib/libz.a "$static" + '' # jww (2015-01-06): Sometimes this library install as a .so, even on # Darwin; others time it installs as a .dylib. I haven't yet figured out # what causes this difference. - + lib.optionalString stdenv.hostPlatform.isDarwin '' - for file in $out/lib/*.so* $out/lib/*.dylib* ; do - ${stdenv.cc.bintools.targetPrefix}install_name_tool -id "$file" $file - done - '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + for file in $out/lib/*.so* $out/lib/*.dylib* ; do + ${stdenv.cc.bintools.targetPrefix}install_name_tool -id "$file" $file + done + '' # Non-typical naming confuses libtool which then refuses to use zlib's DLL # in some cases, e.g. when compiling libpng. - + lib.optionalString (stdenv.hostPlatform.isMinGW && shared) '' - ln -s zlib1.dll $out/bin/libz.dll - ''; - - env = lib.optionalAttrs (!stdenv.hostPlatform.isDarwin) { - # As zlib takes part in the stdenv building, we don't want references - # to the bootstrap-tools libgcc (as uses to happen on arm/mips) - NIX_CFLAGS_COMPILE = "-static-libgcc"; - } // lib.optionalAttrs (stdenv.hostPlatform.linker == "lld") { - # lld 16 enables --no-undefined-version by defualt - # This makes configure think it can't build dynamic libraries - # this may be removed when a version is packaged with https://github.com/madler/zlib/issues/960 fixed - NIX_LDFLAGS = "--undefined-version"; - }; + + lib.optionalString (stdenv.hostPlatform.isMinGW && shared) '' + ln -s zlib1.dll $out/bin/libz.dll + ''; + + env = + lib.optionalAttrs (!stdenv.hostPlatform.isDarwin) { + # As zlib takes part in the stdenv building, we don't want references + # to the bootstrap-tools libgcc (as uses to happen on arm/mips) + NIX_CFLAGS_COMPILE = "-static-libgcc"; + } + // lib.optionalAttrs (stdenv.hostPlatform.linker == "lld") { + # lld 16 enables --no-undefined-version by defualt + # This makes configure think it can't build dynamic libraries + # this may be removed when a version is packaged with https://github.com/madler/zlib/issues/960 fixed + NIX_LDFLAGS = "--undefined-version"; + }; # We don't strip on static cross-compilation because of reports that native # stripping corrupted the target library; see commit 12e960f5 for the report. dontStrip = stdenv.hostPlatform != stdenv.buildPlatform && static; - configurePlatforms = []; + configurePlatforms = [ ]; installFlags = lib.optionals stdenv.hostPlatform.isMinGW [ "BINARY_PATH=$(out)/bin" @@ -126,15 +134,19 @@ stdenv.mkDerivation (finalAttrs: { enableParallelBuilding = true; doCheck = true; - makeFlags = [ - "PREFIX=${stdenv.cc.targetPrefix}" - ] ++ lib.optionals stdenv.hostPlatform.isMinGW [ - "-f" "win32/Makefile.gcc" - ] ++ lib.optionals shared [ - # Note that as of writing (zlib 1.2.11), this flag only has an effect - # for Windows as it is specific to `win32/Makefile.gcc`. - "SHARED_MODE=1" - ]; + makeFlags = + [ + "PREFIX=${stdenv.cc.targetPrefix}" + ] + ++ lib.optionals stdenv.hostPlatform.isMinGW [ + "-f" + "win32/Makefile.gcc" + ] + ++ lib.optionals shared [ + # Note that as of writing (zlib 1.2.11), this flag only has an effect + # for Windows as it is specific to `win32/Makefile.gcc`. + "SHARED_MODE=1" + ]; passthru.tests = { pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; diff --git a/pkgs/development/lisp-modules/asdf/2.26.nix b/pkgs/development/lisp-modules/asdf/2.26.nix index dbf81bb76a5f74..eceb9c175a18f8 100644 --- a/pkgs/development/lisp-modules/asdf/2.26.nix +++ b/pkgs/development/lisp-modules/asdf/2.26.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, texinfo, texLive, perl }: +{ + lib, + stdenv, + fetchurl, + texinfo, + texLive, + perl, +}: stdenv.mkDerivation rec { pname = "asdf"; diff --git a/pkgs/development/lisp-modules/asdf/3.1.nix b/pkgs/development/lisp-modules/asdf/3.1.nix index cda5d46131a09f..4346f68ea79e6e 100644 --- a/pkgs/development/lisp-modules/asdf/3.1.nix +++ b/pkgs/development/lisp-modules/asdf/3.1.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, texinfo, texLive, perl }: +{ + lib, + stdenv, + fetchurl, + texinfo, + texLive, + perl, +}: stdenv.mkDerivation rec { pname = "asdf"; diff --git a/pkgs/development/lisp-modules/asdf/3.3.nix b/pkgs/development/lisp-modules/asdf/3.3.nix index 3981ed272a236f..f82a42d68b0159 100644 --- a/pkgs/development/lisp-modules/asdf/3.3.nix +++ b/pkgs/development/lisp-modules/asdf/3.3.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, fetchpatch, texinfo, texLive, perl }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + texinfo, + texLive, + perl, +}: stdenv.mkDerivation rec { pname = "asdf"; diff --git a/pkgs/development/lisp-modules/asdf/default.nix b/pkgs/development/lisp-modules/asdf/default.nix index 78d49a91789854..9729d6d62c2d08 100644 --- a/pkgs/development/lisp-modules/asdf/default.nix +++ b/pkgs/development/lisp-modules/asdf/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, texinfo, texLive, perl }: +{ + lib, + stdenv, + fetchurl, + texinfo, + texLive, + perl, +}: stdenv.mkDerivation rec { pname = "asdf"; diff --git a/pkgs/development/lisp-modules/imported.nix b/pkgs/development/lisp-modules/imported.nix index e788bd8bf2048b..fb4b99e34c548d 100644 --- a/pkgs/development/lisp-modules/imported.nix +++ b/pkgs/development/lisp-modules/imported.nix @@ -1,74290 +1,107740 @@ - # This file was auto-generated by nix-quicklisp.lisp -{ runCommand, pkgs, lib, fetchzip, build-asdf-system, ... }: +{ + runCommand, + pkgs, + lib, + fetchzip, + build-asdf-system, + ... +}: let - inherit (builtins) getAttr; + inherit (builtins) getAttr; -# Ensures that every non-slashy `system` exists in a unique .asd file. -# (Think cl-async-base being declared in cl-async.asd upstream) -# -# This is required because we're building and loading a system called -# `system`, not `asd`, so otherwise `system` would not be loadable -# without building and loading `asd` first. -# - createAsd = { url, sha256, asd, system }: - let - src = fetchzip { inherit url sha256; }; - in - if asd == system - then src - else runCommand "source" {} '' - mkdir -pv $out - cp -r ${src}/* $out - find $out -name "${asd}.asd" | while read f; do mv -fv $f $(dirname $f)/${system}.asd || true; done - ''; -in lib.makeScope pkgs.newScope (self: { - _1am = (build-asdf-system { - pname = "1am"; - version = "20141106-git"; - asds = [ "1am" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/1am/2014-11-06/1am-20141106-git.tgz"; - sha256 = "05ss4nz1jb9kb796295482b62w5cj29msfj8zis33sp2rw2vmv2g"; - system = "1am"; - asd = "1am"; - }); - systems = [ "1am" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _2d-array = (build-asdf-system { - pname = "2d-array"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "2d-array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "2d-array"; - asd = "2d-array"; - }); - systems = [ "2d-array" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _2d-array-test = (build-asdf-system { - pname = "2d-array-test"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "2d-array-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "2d-array-test"; - asd = "2d-array-test"; - }); - systems = [ "2d-array-test" ]; - lispLibs = [ (getAttr "_2d-array" self) (getAttr "scrutiny" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3b-bmfont = (build-asdf-system { - pname = "3b-bmfont"; - version = "20241012-git"; - asds = [ "3b-bmfont" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3b-bmfont/2024-10-12/3b-bmfont-20241012-git.tgz"; - sha256 = "1zmkmhw8ma2j8p6crw0x6am6fx95rxkb1n3fqlgvs2rxdk273dan"; - system = "3b-bmfont"; - asd = "3b-bmfont"; - }); - systems = [ "3b-bmfont" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "parse-number" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3b-hdr = (build-asdf-system { - pname = "3b-hdr"; - version = "20200925-git"; - asds = [ "3b-hdr" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3b-hdr/2020-09-25/3b-hdr-20200925-git.tgz"; - sha256 = "0bvpdzz88xjwvqapjnkdr44ds3gh5xl3r6r1c2y7x9d6lnvc38jq"; - system = "3b-hdr"; - asd = "3b-hdr"; - }); - systems = [ "3b-hdr" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "parse-number" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3b-swf = (build-asdf-system { - pname = "3b-swf"; - version = "20120107-git"; - asds = [ "3b-swf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3b-swf/2012-01-07/3b-swf-20120107-git.tgz"; - sha256 = "1d74045b6zfxjf0as8n5ji14j5cxsdi3qkqkzcdy3i83whbxkcbm"; - system = "3b-swf"; - asd = "3b-swf"; - }); - systems = [ "3b-swf" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "chipz" self) (getAttr "cl-jpeg" self) (getAttr "cxml" self) (getAttr "flexi-streams" self) (getAttr "ieee-floats" self) (getAttr "salza2" self) (getAttr "vecto" self) (getAttr "zpng" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3b-swf-swc = (build-asdf-system { - pname = "3b-swf-swc"; - version = "20120107-git"; - asds = [ "3b-swf-swc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3b-swf/2012-01-07/3b-swf-20120107-git.tgz"; - sha256 = "1d74045b6zfxjf0as8n5ji14j5cxsdi3qkqkzcdy3i83whbxkcbm"; - system = "3b-swf-swc"; - asd = "3b-swf-swc"; - }); - systems = [ "3b-swf-swc" ]; - lispLibs = [ (getAttr "_3b-swf" self) (getAttr "cxml" self) (getAttr "zip" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3bgl-shader = (build-asdf-system { - pname = "3bgl-shader"; - version = "20241012-git"; - asds = [ "3bgl-shader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3bgl-shader/2024-10-12/3bgl-shader-20241012-git.tgz"; - sha256 = "06v9a3m0cwhj2m5nz20shzgz3362sd7bv011rlknm4nz6i4q5bzz"; - system = "3bgl-shader"; - asd = "3bgl-shader"; - }); - systems = [ "3bgl-shader" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-opengl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3bgl-shader-example = (build-asdf-system { - pname = "3bgl-shader-example"; - version = "20241012-git"; - asds = [ "3bgl-shader-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3bgl-shader/2024-10-12/3bgl-shader-20241012-git.tgz"; - sha256 = "06v9a3m0cwhj2m5nz20shzgz3362sd7bv011rlknm4nz6i4q5bzz"; - system = "3bgl-shader-example"; - asd = "3bgl-shader-example"; - }); - systems = [ "3bgl-shader-example" ]; - lispLibs = [ (getAttr "_3bgl-shader" self) (getAttr "cl-glu" self) (getAttr "cl-glut" self) (getAttr "mathkit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3bmd = (build-asdf-system { - pname = "3bmd"; - version = "20241012-git"; - asds = [ "3bmd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; - sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; - system = "3bmd"; - asd = "3bmd"; - }); - systems = [ "3bmd" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "esrap" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3bmd-ext-code-blocks = (build-asdf-system { - pname = "3bmd-ext-code-blocks"; - version = "20241012-git"; - asds = [ "3bmd-ext-code-blocks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; - sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; - system = "3bmd-ext-code-blocks"; - asd = "3bmd-ext-code-blocks"; - }); - systems = [ "3bmd-ext-code-blocks" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "alexandria" self) (getAttr "colorize" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3bmd-ext-definition-lists = (build-asdf-system { - pname = "3bmd-ext-definition-lists"; - version = "20241012-git"; - asds = [ "3bmd-ext-definition-lists" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; - sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; - system = "3bmd-ext-definition-lists"; - asd = "3bmd-ext-definition-lists"; - }); - systems = [ "3bmd-ext-definition-lists" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "alexandria" self) (getAttr "colorize" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3bmd-ext-math = (build-asdf-system { - pname = "3bmd-ext-math"; - version = "20241012-git"; - asds = [ "3bmd-ext-math" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; - sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; - system = "3bmd-ext-math"; - asd = "3bmd-ext-math"; - }); - systems = [ "3bmd-ext-math" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "esrap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3bmd-ext-tables = (build-asdf-system { - pname = "3bmd-ext-tables"; - version = "20241012-git"; - asds = [ "3bmd-ext-tables" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; - sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; - system = "3bmd-ext-tables"; - asd = "3bmd-ext-tables"; - }); - systems = [ "3bmd-ext-tables" ]; - lispLibs = [ (getAttr "_3bmd" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3bmd-ext-wiki-links = (build-asdf-system { - pname = "3bmd-ext-wiki-links"; - version = "20241012-git"; - asds = [ "3bmd-ext-wiki-links" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; - sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; - system = "3bmd-ext-wiki-links"; - asd = "3bmd-ext-wiki-links"; - }); - systems = [ "3bmd-ext-wiki-links" ]; - lispLibs = [ (getAttr "_3bmd" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3bmd-tests = (build-asdf-system { - pname = "3bmd-tests"; - version = "20241012-git"; - asds = [ "3bmd-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; - sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; - system = "3bmd-tests"; - asd = "3bmd-tests"; - }); - systems = [ "3bmd-tests" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "_3bmd-ext-code-blocks" self) (getAttr "fiasco" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3bmd-youtube = (build-asdf-system { - pname = "3bmd-youtube"; - version = "20241012-git"; - asds = [ "3bmd-youtube" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; - sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; - system = "3bmd-youtube"; - asd = "3bmd-youtube"; - }); - systems = [ "3bmd-youtube" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "esrap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3bmd-youtube-tests = (build-asdf-system { - pname = "3bmd-youtube-tests"; - version = "20241012-git"; - asds = [ "3bmd-youtube-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; - sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; - system = "3bmd-youtube-tests"; - asd = "3bmd-youtube-tests"; - }); - systems = [ "3bmd-youtube-tests" ]; - lispLibs = [ (getAttr "_3bmd-youtube" self) (getAttr "fiasco" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3bz = (build-asdf-system { - pname = "3bz"; - version = "20230618-git"; - asds = [ "3bz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3bz/2023-06-18/3bz-20230618-git.tgz"; - sha256 = "0qdnxj2sn185l0jnp4zjlh5la14pxkgp1hmcyw4d2zwx30sc37p7"; - system = "3bz"; - asd = "3bz"; - }); - systems = [ "3bz" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cffi" self) (getAttr "mmap" self) (getAttr "nibbles" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3d-math = (build-asdf-system { - pname = "3d-math"; - version = "20241012-git"; - asds = [ "3d-math" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3d-math/2024-10-12/3d-math-20241012-git.tgz"; - sha256 = "01xnzizy76ypypzpqrg9fwnxfl5mlldc554b0791rsckkhh35xvd"; - system = "3d-math"; - asd = "3d-math"; - }); - systems = [ "3d-math" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "type-templates" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3d-math-test = (build-asdf-system { - pname = "3d-math-test"; - version = "20241012-git"; - asds = [ "3d-math-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3d-math/2024-10-12/3d-math-20241012-git.tgz"; - sha256 = "01xnzizy76ypypzpqrg9fwnxfl5mlldc554b0791rsckkhh35xvd"; - system = "3d-math-test"; - asd = "3d-math-test"; - }); - systems = [ "3d-math-test" ]; - lispLibs = [ (getAttr "_3d-math" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3d-matrices = (build-asdf-system { - pname = "3d-matrices"; - version = "20231021-git"; - asds = [ "3d-matrices" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3d-matrices/2023-10-21/3d-matrices-20231021-git.tgz"; - sha256 = "0kn68awww0h8gwiqih8a65d2p34q3qh4z5ji2g5ja99vgpr1498q"; - system = "3d-matrices"; - asd = "3d-matrices"; - }); - systems = [ "3d-matrices" ]; - lispLibs = [ (getAttr "_3d-vectors" self) (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3d-matrices-test = (build-asdf-system { - pname = "3d-matrices-test"; - version = "20231021-git"; - asds = [ "3d-matrices-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3d-matrices/2023-10-21/3d-matrices-20231021-git.tgz"; - sha256 = "0kn68awww0h8gwiqih8a65d2p34q3qh4z5ji2g5ja99vgpr1498q"; - system = "3d-matrices-test"; - asd = "3d-matrices-test"; - }); - systems = [ "3d-matrices-test" ]; - lispLibs = [ (getAttr "_3d-matrices" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3d-quaternions = (build-asdf-system { - pname = "3d-quaternions"; - version = "20231021-git"; - asds = [ "3d-quaternions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3d-quaternions/2023-10-21/3d-quaternions-20231021-git.tgz"; - sha256 = "1m72g2rn1n5xsqaa50qbj6hcp8b4gk7xsld4qaly788bwscparl8"; - system = "3d-quaternions"; - asd = "3d-quaternions"; - }); - systems = [ "3d-quaternions" ]; - lispLibs = [ (getAttr "_3d-matrices" self) (getAttr "_3d-vectors" self) (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3d-quaternions-test = (build-asdf-system { - pname = "3d-quaternions-test"; - version = "20231021-git"; - asds = [ "3d-quaternions-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3d-quaternions/2023-10-21/3d-quaternions-20231021-git.tgz"; - sha256 = "1m72g2rn1n5xsqaa50qbj6hcp8b4gk7xsld4qaly788bwscparl8"; - system = "3d-quaternions-test"; - asd = "3d-quaternions-test"; - }); - systems = [ "3d-quaternions-test" ]; - lispLibs = [ (getAttr "_3d-quaternions" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3d-spaces = (build-asdf-system { - pname = "3d-spaces"; - version = "20241012-git"; - asds = [ "3d-spaces" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3d-spaces/2024-10-12/3d-spaces-20241012-git.tgz"; - sha256 = "170f2hyvrf3mvkfg9mj7rg2zafcnqbm9h9c29y716ppq1vk1pxhc"; - system = "3d-spaces"; - asd = "3d-spaces"; - }); - systems = [ "3d-spaces" ]; - lispLibs = [ (getAttr "_3d-math" self) (getAttr "documentation-utils" self) (getAttr "for" self) (getAttr "trivial-extensible-sequences" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3d-spaces-test = (build-asdf-system { - pname = "3d-spaces-test"; - version = "20241012-git"; - asds = [ "3d-spaces-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3d-spaces/2024-10-12/3d-spaces-20241012-git.tgz"; - sha256 = "170f2hyvrf3mvkfg9mj7rg2zafcnqbm9h9c29y716ppq1vk1pxhc"; - system = "3d-spaces-test"; - asd = "3d-spaces-test"; - }); - systems = [ "3d-spaces-test" ]; - lispLibs = [ (getAttr "_3d-spaces" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3d-transforms = (build-asdf-system { - pname = "3d-transforms"; - version = "20231021-git"; - asds = [ "3d-transforms" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3d-transforms/2023-10-21/3d-transforms-20231021-git.tgz"; - sha256 = "0876pih289fgn8maclihiz9xl66zbi4nbznpdq2xpfbsr1k4sihy"; - system = "3d-transforms"; - asd = "3d-transforms"; - }); - systems = [ "3d-transforms" ]; - lispLibs = [ (getAttr "_3d-matrices" self) (getAttr "_3d-quaternions" self) (getAttr "_3d-vectors" self) (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3d-transforms-test = (build-asdf-system { - pname = "3d-transforms-test"; - version = "20231021-git"; - asds = [ "3d-transforms-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3d-transforms/2023-10-21/3d-transforms-20231021-git.tgz"; - sha256 = "0876pih289fgn8maclihiz9xl66zbi4nbznpdq2xpfbsr1k4sihy"; - system = "3d-transforms-test"; - asd = "3d-transforms-test"; - }); - systems = [ "3d-transforms-test" ]; - lispLibs = [ (getAttr "_3d-transforms" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3d-vectors = (build-asdf-system { - pname = "3d-vectors"; - version = "20231021-git"; - asds = [ "3d-vectors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3d-vectors/2023-10-21/3d-vectors-20231021-git.tgz"; - sha256 = "0y3iwb0bvxf8ixgsbg3idlx91k3lim9na53fasb4scnhlmpsbk28"; - system = "3d-vectors"; - asd = "3d-vectors"; - }); - systems = [ "3d-vectors" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _3d-vectors-test = (build-asdf-system { - pname = "3d-vectors-test"; - version = "20231021-git"; - asds = [ "3d-vectors-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/3d-vectors/2023-10-21/3d-vectors-20231021-git.tgz"; - sha256 = "0y3iwb0bvxf8ixgsbg3idlx91k3lim9na53fasb4scnhlmpsbk28"; - system = "3d-vectors-test"; - asd = "3d-vectors-test"; - }); - systems = [ "3d-vectors-test" ]; - lispLibs = [ (getAttr "_3d-vectors" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-asdf-system = (build-asdf-system { - pname = "40ants-asdf-system"; - version = "20241012-git"; - asds = [ "40ants-asdf-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/40ants-asdf-system/2024-10-12/40ants-asdf-system-20241012-git.tgz"; - sha256 = "0wi575m0s0a9fvp1wy5ga760f71la16z1633qk6s2f87rwcjs8kw"; - system = "40ants-asdf-system"; - asd = "40ants-asdf-system"; - }); - systems = [ "40ants-asdf-system" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-asdf-system-ci = (build-asdf-system { - pname = "40ants-asdf-system-ci"; - version = "20241012-git"; - asds = [ "40ants-asdf-system-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/40ants-asdf-system/2024-10-12/40ants-asdf-system-20241012-git.tgz"; - sha256 = "0wi575m0s0a9fvp1wy5ga760f71la16z1633qk6s2f87rwcjs8kw"; - system = "40ants-asdf-system-ci"; - asd = "40ants-asdf-system-ci"; - }); - systems = [ "40ants-asdf-system-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-asdf-system-tests = (build-asdf-system { - pname = "40ants-asdf-system-tests"; - version = "20241012-git"; - asds = [ "40ants-asdf-system-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/40ants-asdf-system/2024-10-12/40ants-asdf-system-20241012-git.tgz"; - sha256 = "0wi575m0s0a9fvp1wy5ga760f71la16z1633qk6s2f87rwcjs8kw"; - system = "40ants-asdf-system-tests"; - asd = "40ants-asdf-system-tests"; - }); - systems = [ "40ants-asdf-system-tests" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-ci = (build-asdf-system { - pname = "40ants-ci"; - version = "20241012-git"; - asds = [ "40ants-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ci/2024-10-12/ci-20241012-git.tgz"; - sha256 = "0fmy1302c89qbhn4zc58cydcv8qc3qrl6cjbf2fy53sphnmj0wgm"; - system = "40ants-ci"; - asd = "40ants-ci"; - }); - systems = [ "40ants-ci" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "alexandria" self) (getAttr "serapeum" self) (getAttr "str" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-ci-docs = (build-asdf-system { - pname = "40ants-ci-docs"; - version = "20241012-git"; - asds = [ "40ants-ci-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ci/2024-10-12/ci-20241012-git.tgz"; - sha256 = "0fmy1302c89qbhn4zc58cydcv8qc3qrl6cjbf2fy53sphnmj0wgm"; - system = "40ants-ci-docs"; - asd = "40ants-ci-docs"; - }); - systems = [ "40ants-ci-docs" ]; - lispLibs = [ (getAttr "_40ants-ci" self) (getAttr "_40ants-doc" self) (getAttr "_40ants-logging-docs" self) (getAttr "docs-config" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-ci-tests = (build-asdf-system { - pname = "40ants-ci-tests"; - version = "20241012-git"; - asds = [ "40ants-ci-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ci/2024-10-12/ci-20241012-git.tgz"; - sha256 = "0fmy1302c89qbhn4zc58cydcv8qc3qrl6cjbf2fy53sphnmj0wgm"; - system = "40ants-ci-tests"; - asd = "40ants-ci-tests"; - }); - systems = [ "40ants-ci-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-doc = (build-asdf-system { - pname = "40ants-doc"; - version = "20241012-git"; - asds = [ "40ants-doc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/doc/2024-10-12/doc-20241012-git.tgz"; - sha256 = "1vkczfcdgg1dmzb5jzxvc50kywbz7il130qrj0smlg1grwgw10a2"; - system = "40ants-doc"; - asd = "40ants-doc"; - }); - systems = [ "40ants-doc" ]; - lispLibs = [ (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-doc-full = (build-asdf-system { - pname = "40ants-doc-full"; - version = "20241012-git"; - asds = [ "40ants-doc-full" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/doc/2024-10-12/doc-20241012-git.tgz"; - sha256 = "1vkczfcdgg1dmzb5jzxvc50kywbz7il130qrj0smlg1grwgw10a2"; - system = "40ants-doc-full"; - asd = "40ants-doc-full"; - }); - systems = [ "40ants-doc-full" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "common-doc" self) (getAttr "common-html" self) (getAttr "commondoc-markdown" self) (getAttr "dexador" self) (getAttr "docs-config" self) (getAttr "fare-utils" self) (getAttr "jonathan" self) (getAttr "lass" self) (getAttr "local-time" self) (getAttr "log4cl" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) (getAttr "slynk" self) (getAttr "spinneret" self) (getAttr "stem" self) (getAttr "str" self) (getAttr "swank" self) (getAttr "tmpdir" self) (getAttr "which" self) (getAttr "xml-emitter" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-doc-test = (build-asdf-system { - pname = "40ants-doc-test"; - version = "20241012-git"; - asds = [ "40ants-doc-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/doc/2024-10-12/doc-20241012-git.tgz"; - sha256 = "1vkczfcdgg1dmzb5jzxvc50kywbz7il130qrj0smlg1grwgw10a2"; - system = "40ants-doc-test"; - asd = "40ants-doc-test"; - }); - systems = [ "40ants-doc-test" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "alexandria" self) (getAttr "common-doc" self) (getAttr "common-html" self) (getAttr "commondoc-markdown" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-logging = (build-asdf-system { - pname = "40ants-logging"; - version = "20241012-git"; - asds = [ "40ants-logging" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/logging/2024-10-12/logging-20241012-git.tgz"; - sha256 = "1rkh0ls12qkwxs7szvnr5fz2bi1wwxsz7z72ywnin13hisvgkkwz"; - system = "40ants-logging"; - asd = "40ants-logging"; - }); - systems = [ "40ants-logging" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "global-vars" self) (getAttr "log4cl-extras" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-logging-ci = (build-asdf-system { - pname = "40ants-logging-ci"; - version = "20241012-git"; - asds = [ "40ants-logging-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/logging/2024-10-12/logging-20241012-git.tgz"; - sha256 = "1rkh0ls12qkwxs7szvnr5fz2bi1wwxsz7z72ywnin13hisvgkkwz"; - system = "40ants-logging-ci"; - asd = "40ants-logging-ci"; - }); - systems = [ "40ants-logging-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-logging-docs = (build-asdf-system { - pname = "40ants-logging-docs"; - version = "20241012-git"; - asds = [ "40ants-logging-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/logging/2024-10-12/logging-20241012-git.tgz"; - sha256 = "1rkh0ls12qkwxs7szvnr5fz2bi1wwxsz7z72ywnin13hisvgkkwz"; - system = "40ants-logging-docs"; - asd = "40ants-logging-docs"; - }); - systems = [ "40ants-logging-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "_40ants-logging" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-logging-example = (build-asdf-system { - pname = "40ants-logging-example"; - version = "20241012-git"; - asds = [ "40ants-logging-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/logging/2024-10-12/logging-20241012-git.tgz"; - sha256 = "1rkh0ls12qkwxs7szvnr5fz2bi1wwxsz7z72ywnin13hisvgkkwz"; - system = "40ants-logging-example"; - asd = "40ants-logging-example"; - }); - systems = [ "40ants-logging-example" ]; - lispLibs = [ (getAttr "_40ants-logging" self) (getAttr "_40ants-slynk" self) (getAttr "defmain" self) (getAttr "log4cl" self) (getAttr "log4cl-extras" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-logging-tests = (build-asdf-system { - pname = "40ants-logging-tests"; - version = "20241012-git"; - asds = [ "40ants-logging-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/logging/2024-10-12/logging-20241012-git.tgz"; - sha256 = "1rkh0ls12qkwxs7szvnr5fz2bi1wwxsz7z72ywnin13hisvgkkwz"; - system = "40ants-logging-tests"; - asd = "40ants-logging-tests"; - }); - systems = [ "40ants-logging-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-slynk = (build-asdf-system { - pname = "40ants-slynk"; - version = "20241012-git"; - asds = [ "40ants-slynk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/40ants-slynk/2024-10-12/40ants-slynk-20241012-git.tgz"; - sha256 = "0rz32aaya177s8c4lsasyfff91b2ancjlw8bi50xz150kwqqqmmx"; - system = "40ants-slynk"; - asd = "40ants-slynk"; - }); - systems = [ "40ants-slynk" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "_40ants-logging" self) (getAttr "global-vars" self) (getAttr "log4cl" self) (getAttr "slynk" self) (getAttr "slynk-macrostep" self) (getAttr "slynk-named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-slynk-ci = (build-asdf-system { - pname = "40ants-slynk-ci"; - version = "20241012-git"; - asds = [ "40ants-slynk-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/40ants-slynk/2024-10-12/40ants-slynk-20241012-git.tgz"; - sha256 = "0rz32aaya177s8c4lsasyfff91b2ancjlw8bi50xz150kwqqqmmx"; - system = "40ants-slynk-ci"; - asd = "40ants-slynk-ci"; - }); - systems = [ "40ants-slynk-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-slynk-docs = (build-asdf-system { - pname = "40ants-slynk-docs"; - version = "20241012-git"; - asds = [ "40ants-slynk-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/40ants-slynk/2024-10-12/40ants-slynk-20241012-git.tgz"; - sha256 = "0rz32aaya177s8c4lsasyfff91b2ancjlw8bi50xz150kwqqqmmx"; - system = "40ants-slynk-docs"; - asd = "40ants-slynk-docs"; - }); - systems = [ "40ants-slynk-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "_40ants-slynk" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - _40ants-slynk-tests = (build-asdf-system { - pname = "40ants-slynk-tests"; - version = "20241012-git"; - asds = [ "40ants-slynk-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/40ants-slynk/2024-10-12/40ants-slynk-20241012-git.tgz"; - sha256 = "0rz32aaya177s8c4lsasyfff91b2ancjlw8bi50xz150kwqqqmmx"; - system = "40ants-slynk-tests"; - asd = "40ants-slynk-tests"; - }); - systems = [ "40ants-slynk-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - a-cl-cairo2-loader = (build-asdf-system { - pname = "a-cl-cairo2-loader"; - version = "20211020-git"; - asds = [ "a-cl-cairo2-loader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cairo2/2021-10-20/cl-cairo2-20211020-git.tgz"; - sha256 = "0cpfgyxw6pz7y033dlya8c4vjmkpw127zdq3a9xclp9q8jbdlb7q"; - system = "a-cl-cairo2-loader"; - asd = "a-cl-cairo2-loader"; - }); - systems = [ "a-cl-cairo2-loader" ]; - lispLibs = [ (getAttr "cl-cairo2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - a-cl-logger = (build-asdf-system { - pname = "a-cl-logger"; - version = "20220331-git"; - asds = [ "a-cl-logger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/a-cl-logger/2022-03-31/a-cl-logger-20220331-git.tgz"; - sha256 = "0vhhbnh4akxh0ivqh8r0f2djv2nbf3l9hbbi0b5fdk9bdpziqkb4"; - system = "a-cl-logger"; - asd = "a-cl-logger"; - }); - systems = [ "a-cl-logger" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-interpol" self) (getAttr "cl-json" self) (getAttr "closer-mop" self) (getAttr "exit-hooks" self) (getAttr "iterate" self) (getAttr "local-time" self) (getAttr "osicat" self) (getAttr "symbol-munger" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - a-cl-logger-logstash = (build-asdf-system { - pname = "a-cl-logger-logstash"; - version = "20220331-git"; - asds = [ "a-cl-logger-logstash" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/a-cl-logger/2022-03-31/a-cl-logger-20220331-git.tgz"; - sha256 = "0vhhbnh4akxh0ivqh8r0f2djv2nbf3l9hbbi0b5fdk9bdpziqkb4"; - system = "a-cl-logger-logstash"; - asd = "a-cl-logger-logstash"; - }); - systems = [ "a-cl-logger-logstash" ]; - lispLibs = [ (getAttr "a-cl-logger" self) (getAttr "cl-json" self) (getAttr "zmq" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - a-cl-logger-tests = (build-asdf-system { - pname = "a-cl-logger-tests"; - version = "20220331-git"; - asds = [ "a-cl-logger-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/a-cl-logger/2022-03-31/a-cl-logger-20220331-git.tgz"; - sha256 = "0vhhbnh4akxh0ivqh8r0f2djv2nbf3l9hbbi0b5fdk9bdpziqkb4"; - system = "a-cl-logger-tests"; - asd = "a-cl-logger"; - }); - systems = [ "a-cl-logger-tests" ]; - lispLibs = [ (getAttr "a-cl-logger" self) (getAttr "lisp-unit2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - aabbcc = (build-asdf-system { - pname = "aabbcc"; - version = "20200427-git"; - asds = [ "aabbcc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "aabbcc"; - asd = "aabbcc"; - }); - systems = [ "aabbcc" ]; - lispLibs = [ (getAttr "quads" self) (getAttr "utility" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - able = (build-asdf-system { - pname = "able"; - version = "20171227-git"; - asds = [ "able" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/able/2017-12-27/able-20171227-git.tgz"; - sha256 = "1fbcmr6hy7bwlnsnrml3j4b2jkkj8ddxw27l8hr2z6l3fi3qw4hh"; - system = "able"; - asd = "able"; - }); - systems = [ "able" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "ltk" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - abnf = (build-asdf-system { - pname = "abnf"; - version = "20200325-git"; - asds = [ "abnf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-abnf/2020-03-25/cl-abnf-20200325-git.tgz"; - sha256 = "0f09nsndxa90acm71zd4qdnp40v705a4sqm04mnv9x76h6dlggmz"; - system = "abnf"; - asd = "abnf"; - }); - systems = [ "abnf" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "esrap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - abstract-classes = (build-asdf-system { - pname = "abstract-classes"; - version = "20190307-hg"; - asds = [ "abstract-classes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-abstract-classes/2019-03-07/cl-abstract-classes-20190307-hg.tgz"; - sha256 = "0q03j3ksgn56j9xvs3d3hhasplj3hvg488f4cx1z97nlyqxr5w1d"; - system = "abstract-classes"; - asd = "abstract-classes"; - }); - systems = [ "abstract-classes" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - access = (build-asdf-system { - pname = "access"; - version = "20241012-git"; - asds = [ "access" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/access/2024-10-12/access-20241012-git.tgz"; - sha256 = "0zdjqhb9rvnlq6nzmsp7372gi91k1rq9bz510m6hcki7g3r01iv5"; - system = "access"; - asd = "access"; - }); - systems = [ "access" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "iterate" self) ]; - meta = {}; - }); - acclimation = (build-asdf-system { - pname = "acclimation"; - version = "20241012-git"; - asds = [ "acclimation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/acclimation/2024-10-12/acclimation-20241012-git.tgz"; - sha256 = "1rp4794czi01hlv67mgykxym1hqsyn04ldgwiqjwf4lj5d3p7aj4"; - system = "acclimation"; - asd = "acclimation"; - }); - systems = [ "acclimation" ]; - lispLibs = [ ]; - meta = {}; - }); - acclimation-temperature = (build-asdf-system { - pname = "acclimation-temperature"; - version = "20241012-git"; - asds = [ "acclimation-temperature" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/acclimation/2024-10-12/acclimation-20241012-git.tgz"; - sha256 = "1rp4794czi01hlv67mgykxym1hqsyn04ldgwiqjwf4lj5d3p7aj4"; - system = "acclimation-temperature"; - asd = "acclimation-temperature"; - }); - systems = [ "acclimation-temperature" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - acl-compat = (build-asdf-system { - pname = "acl-compat"; - version = "20190813-git"; - asds = [ "acl-compat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/portableaserve/2019-08-13/portableaserve-20190813-git.tgz"; - sha256 = "0ak6mqp84sjr0a7h5svr16vra4bf4fcx6wpir0n88dc1vjwy5xqa"; - system = "acl-compat"; - asd = "acl-compat"; - }); - systems = [ "acl-compat" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "ironclad" self) (getAttr "puri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - acm-random = (build-asdf-system { - pname = "acm-random"; - version = "20191007-git"; - asds = [ "acm-random" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/random/2019-10-07/random-20191007-git.tgz"; - sha256 = "1fb4mnp85jm9s667y4dgz07klhkr9pvi5xbxws28lbb8iip75y2p"; - system = "acm-random"; - asd = "acm-random"; - }); - systems = [ "acm-random" ]; - lispLibs = [ (getAttr "com_dot_google_dot_base" self) (getAttr "random" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - acm-random-test = (build-asdf-system { - pname = "acm-random-test"; - version = "20191007-git"; - asds = [ "acm-random-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/random/2019-10-07/random-20191007-git.tgz"; - sha256 = "1fb4mnp85jm9s667y4dgz07klhkr9pvi5xbxws28lbb8iip75y2p"; - system = "acm-random-test"; - asd = "acm-random-test"; - }); - systems = [ "acm-random-test" ]; - lispLibs = [ (getAttr "acm-random" self) (getAttr "hu_dot_dwim_dot_stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - action-list = (build-asdf-system { - pname = "action-list"; - version = "20241012-git"; - asds = [ "action-list" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/action-list/2024-10-12/action-list-20241012-git.tgz"; - sha256 = "0ky38svlm0xhgsmh5maqj314q4wl3apg7532q8apy37axg1y3xvh"; - system = "action-list"; - asd = "action-list"; - }); - systems = [ "action-list" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "trivial-extensible-sequences" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - add-two = (build-asdf-system { - pname = "add-two"; - version = "20241012-git"; - asds = [ "add-two" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/whereiseveryone.command-line-args/2024-10-12/whereiseveryone.command-line-args-20241012-git.tgz"; - sha256 = "140xnz2v0v3hfg3dp2fhidw8ns6lxd3a5knm07wqdp48ksg119wy"; - system = "add-two"; - asd = "add-two"; - }); - systems = [ "add-two" ]; - lispLibs = [ (getAttr "cl-annot" self) (getAttr "whereiseveryone_dot_command-line-args" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - adhoc = (build-asdf-system { - pname = "adhoc"; - version = "20241012-git"; - asds = [ "adhoc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/adhoc/2024-10-12/adhoc-20241012-git.tgz"; - sha256 = "1h7mnwybapxzpv0zlwr1mr91lsd7wiv722ifa21gczllvrg5qai6"; - system = "adhoc"; - asd = "adhoc"; - }); - systems = [ "adhoc" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - adhoc-tests = (build-asdf-system { - pname = "adhoc-tests"; - version = "20241012-git"; - asds = [ "adhoc-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/adhoc/2024-10-12/adhoc-20241012-git.tgz"; - sha256 = "1h7mnwybapxzpv0zlwr1mr91lsd7wiv722ifa21gczllvrg5qai6"; - system = "adhoc-tests"; - asd = "adhoc-tests"; - }); - systems = [ "adhoc-tests" ]; - lispLibs = [ (getAttr "adhoc" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - adjuvant = (build-asdf-system { - pname = "adjuvant"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "adjuvant" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "adjuvant"; - asd = "adjuvant"; - }); - systems = [ "adjuvant" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - adjuvant-test = (build-asdf-system { - pname = "adjuvant-test"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "adjuvant-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "adjuvant-test"; - asd = "adjuvant-test"; - }); - systems = [ "adjuvant-test" ]; - lispLibs = [ (getAttr "adjuvant" self) (getAttr "scrutiny" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - adopt = (build-asdf-system { - pname = "adopt"; - version = "20241012-hg"; - asds = [ "adopt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/adopt/2024-10-12/adopt-20241012-hg.tgz"; - sha256 = "1q36b9bp76daprnhd97h00x56kccmii8pc9w2ra6yihkfbcas41q"; - system = "adopt"; - asd = "adopt"; - }); - systems = [ "adopt" ]; - lispLibs = [ (getAttr "bobbin" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - adopt-subcommands = (build-asdf-system { - pname = "adopt-subcommands"; - version = "v0.2.2"; - asds = [ "adopt-subcommands" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/adopt-subcommands/2021-05-31/adopt-subcommands-v0.2.2.tgz"; - sha256 = "0q35s3ihhlshakjalq5pgf14x502qnj8jimim8yf7bp1p9sn83h8"; - system = "adopt-subcommands"; - asd = "adopt-subcommands"; - }); - systems = [ "adopt-subcommands" ]; - lispLibs = [ (getAttr "adopt" self) (getAttr "bobbin" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - adopt-subcommands-test = (build-asdf-system { - pname = "adopt-subcommands-test"; - version = "v0.2.2"; - asds = [ "adopt-subcommands-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/adopt-subcommands/2021-05-31/adopt-subcommands-v0.2.2.tgz"; - sha256 = "0q35s3ihhlshakjalq5pgf14x502qnj8jimim8yf7bp1p9sn83h8"; - system = "adopt-subcommands-test"; - asd = "adopt-subcommands-test"; - }); - systems = [ "adopt-subcommands-test" ]; - lispLibs = [ (getAttr "adopt-subcommands" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - adp = (build-asdf-system { - pname = "adp"; - version = "20241012-git"; - asds = [ "adp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/adp/2024-10-12/adp-20241012-git.tgz"; - sha256 = "04h91m2x1vcn8iidhx1y2cwb8j55siiifhx1ksy7hyn9hf39b2kv"; - system = "adp"; - asd = "adp"; - }); - systems = [ "adp" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "named-readtables" self) (getAttr "scribble" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - adp-github = (build-asdf-system { - pname = "adp-github"; - version = "20241012-git"; - asds = [ "adp-github" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/adp-github/2024-10-12/adp-github-20241012-git.tgz"; - sha256 = "1g33l2k6pc5m8d0d3dl4rf8p364563jpyk22rywrh5188m9nayjc"; - system = "adp-github"; - asd = "adp-github"; - }); - systems = [ "adp-github" ]; - lispLibs = [ (getAttr "adp" self) (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "trivial-arguments" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - adp-plain = (build-asdf-system { - pname = "adp-plain"; - version = "20241012-git"; - asds = [ "adp-plain" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/adp-plain/2024-10-12/adp-plain-20241012-git.tgz"; - sha256 = "0dnfx7hhdibkg0qphs3wsfll2kmpkfpg4hxfjv2paxnsmqdhspnz"; - system = "adp-plain"; - asd = "adp-plain"; - }); - systems = [ "adp-plain" ]; - lispLibs = [ (getAttr "adp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - advanced-readtable = (build-asdf-system { - pname = "advanced-readtable"; - version = "20130720-git"; - asds = [ "advanced-readtable" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/advanced-readtable/2013-07-20/advanced-readtable-20130720-git.tgz"; - sha256 = "0dgm3lp9s6792g22swcb085f67q68jsyqj71vicb1wdr9qslvgwm"; - system = "advanced-readtable"; - asd = "advanced-readtable"; - }); - systems = [ "advanced-readtable" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - aether = (build-asdf-system { - pname = "aether"; - version = "v1.1.0"; - asds = [ "aether" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/aether/2021-12-09/aether-v1.1.0.tgz"; - sha256 = "0q60gc4lsxpvv4g572mnhpzkziq1412k1q0xm4y2d1zigryg30bb"; - system = "aether"; - asd = "aether"; - }); - systems = [ "aether" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-heap" self) (getAttr "global-vars" self) (getAttr "policy-cond" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - aether-tests = (build-asdf-system { - pname = "aether-tests"; - version = "v1.1.0"; - asds = [ "aether-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/aether/2021-12-09/aether-v1.1.0.tgz"; - sha256 = "0q60gc4lsxpvv4g572mnhpzkziq1412k1q0xm4y2d1zigryg30bb"; - system = "aether-tests"; - asd = "aether-tests"; - }); - systems = [ "aether-tests" ]; - lispLibs = [ (getAttr "aether" self) (getAttr "fiasco" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - agnostic-lizard = (build-asdf-system { - pname = "agnostic-lizard"; - version = "20241012-git"; - asds = [ "agnostic-lizard" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/agnostic-lizard/2024-10-12/agnostic-lizard-20241012-git.tgz"; - sha256 = "0amzshh6v3mp24j0h2cinv4zvdlg4kih04md5biakwhnmcw4j4pr"; - system = "agnostic-lizard"; - asd = "agnostic-lizard"; - }); - systems = [ "agnostic-lizard" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - agnostic-lizard-debugger-prototype = (build-asdf-system { - pname = "agnostic-lizard-debugger-prototype"; - version = "20241012-git"; - asds = [ "agnostic-lizard-debugger-prototype" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/agnostic-lizard/2024-10-12/agnostic-lizard-20241012-git.tgz"; - sha256 = "0amzshh6v3mp24j0h2cinv4zvdlg4kih04md5biakwhnmcw4j4pr"; - system = "agnostic-lizard-debugger-prototype"; - asd = "agnostic-lizard-debugger-prototype"; - }); - systems = [ "agnostic-lizard-debugger-prototype" ]; - lispLibs = [ (getAttr "agnostic-lizard" self) (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - agutil = (build-asdf-system { - pname = "agutil"; - version = "20210531-git"; - asds = [ "agutil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/agutil/2021-05-31/agutil-20210531-git.tgz"; - sha256 = "10lccrqkaqq0h1p79gjqsqk1nqa6c25n0w7pj39y2gs14s5qr5q9"; - system = "agutil"; - asd = "agutil"; - }); - systems = [ "agutil" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "optima" self) ]; - meta = {}; - }); - alexa = (build-asdf-system { - pname = "alexa"; - version = "20180831-git"; - asds = [ "alexa" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/alexa/2018-08-31/alexa-20180831-git.tgz"; - sha256 = "1y9jyz9gfmd02h492kf7v3mmpbhc0yfh4ka2rzd1vczq6fl8qgqv"; - system = "alexa"; - asd = "alexa"; - }); - systems = [ "alexa" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - alexa-tests = (build-asdf-system { - pname = "alexa-tests"; - version = "20180831-git"; - asds = [ "alexa-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/alexa/2018-08-31/alexa-20180831-git.tgz"; - sha256 = "1y9jyz9gfmd02h492kf7v3mmpbhc0yfh4ka2rzd1vczq6fl8qgqv"; - system = "alexa-tests"; - asd = "alexa-tests"; - }); - systems = [ "alexa-tests" ]; - lispLibs = [ (getAttr "alexa" self) (getAttr "fiasco" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - alexandria = (build-asdf-system { - pname = "alexandria"; - version = "20241012-git"; - asds = [ "alexandria" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/alexandria/2024-10-12/alexandria-20241012-git.tgz"; - sha256 = "0jq0n59s0r9yl374f0zpdnaflb5g853yqvax7ka8rnypspyykwdw"; - system = "alexandria"; - asd = "alexandria"; - }); - systems = [ "alexandria" ]; - lispLibs = [ ]; - meta = {}; - }); - alexandria_plus = (build-asdf-system { - pname = "alexandria+"; - version = "20241012-git"; - asds = [ "alexandria+" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/alexandria-plus/2024-10-12/alexandria-plus-20241012-git.tgz"; - sha256 = "05j88i289nx2dgc8r3n3h8x3ma31gk8xk2bpvxc5y9yzfl2mp0hk"; - system = "alexandria+"; - asd = "alexandria+"; - }); - systems = [ "alexandria+" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - algebraic-data-library = (build-asdf-system { - pname = "algebraic-data-library"; - version = "20180831-git"; - asds = [ "algebraic-data-library" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/algebraic-data-library/2018-08-31/algebraic-data-library-20180831-git.tgz"; - sha256 = "0mmakfdwgfjl812ydzbbl81lkv41zfnqhw9ydjk1w63lq8c11cmn"; - system = "algebraic-data-library"; - asd = "algebraic-data-library"; - }); - systems = [ "algebraic-data-library" ]; - lispLibs = [ (getAttr "cl-algebraic-data-type" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - allioli = (build-asdf-system { - pname = "allioli"; - version = "20241012-git"; - asds = [ "allioli" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/allioli/2024-10-12/allioli-20241012-git.tgz"; - sha256 = "00504wf4rxrwpc171czlk56zzbf798c39jzhbipm7ba3iz28qkai"; - system = "allioli"; - asd = "allioli"; - }); - systems = [ "allioli" ]; - lispLibs = [ (getAttr "fare-quasiquote-extras" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - also-alsa = (build-asdf-system { - pname = "also-alsa"; - version = "20231021-git"; - asds = [ "also-alsa" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/also-alsa/2023-10-21/also-alsa-20231021-git.tgz"; - sha256 = "17xvq04nnw2kmxvahj56ja5k21d3wg3fzclbfm36fn641lr6l7dx"; - system = "also-alsa"; - asd = "also-alsa"; - }); - systems = [ "also-alsa" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - alternate-asdf-system-connections = (build-asdf-system { - pname = "alternate-asdf-system-connections"; - version = "20241012-git"; - asds = [ "alternate-asdf-system-connections" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/alternate-asdf-system-connections/2024-10-12/alternate-asdf-system-connections-20241012-git.tgz"; - sha256 = "0wlmr29a8azs5kjvwdaqmfn2iwqid0f659cmj34ywchgxahdr6p6"; - system = "alternate-asdf-system-connections"; - asd = "alternate-asdf-system-connections"; - }); - systems = [ "alternate-asdf-system-connections" ]; - lispLibs = [ (getAttr "asdf-system-connections" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - amazon-ecs = (build-asdf-system { - pname = "amazon-ecs"; - version = "20110418-git"; - asds = [ "amazon-ecs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/amazon-ecs/2011-04-18/amazon-ecs-20110418-git.tgz"; - sha256 = "1gi3ybfkdfqvgmwgf0l77xpp5xgmkbycdpz6kn79vm0iga3kd2mz"; - system = "amazon-ecs"; - asd = "amazon-ecs"; - }); - systems = [ "amazon-ecs" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "hunchentoot" self) (getAttr "ironclad" self) (getAttr "net-telent-date" self) (getAttr "parse-number" self) (getAttr "trivial-http" self) (getAttr "xml-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - amb = (build-asdf-system { - pname = "amb"; - version = "20230214-git"; - asds = [ "amb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/amb/2023-02-14/amb-20230214-git.tgz"; - sha256 = "014vpsqxjnsr0x2zql6xpz0kh448p3lqw521amsf6700jqa2s1wp"; - system = "amb"; - asd = "amb"; - }); - systems = [ "amb" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - anaphora = (build-asdf-system { - pname = "anaphora"; - version = "20220220-git"; - asds = [ "anaphora" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/anaphora/2022-02-20/anaphora-20220220-git.tgz"; - sha256 = "1ds5ab0rzkrhfl29xpvmvyxmkdyj9mi19p330pz603lx95njjc0b"; - system = "anaphora"; - asd = "anaphora"; - }); - systems = [ "anaphora" ]; - lispLibs = [ ]; - meta = {}; - }); - anaphoric-variants = (build-asdf-system { - pname = "anaphoric-variants"; - version = "1.0.1"; - asds = [ "anaphoric-variants" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/anaphoric-variants/2012-10-13/anaphoric-variants-1.0.1.tgz"; - sha256 = "02ms01w09b9bzsdsr0icd3ggyl86kyxk164kf0759k2k9y6kjsp5"; - system = "anaphoric-variants"; - asd = "anaphoric-variants"; - }); - systems = [ "anaphoric-variants" ]; - lispLibs = [ (getAttr "map-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - anatevka = (build-asdf-system { - pname = "anatevka"; - version = "v1.0.1"; - asds = [ "anatevka" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/anatevka/2024-10-12/anatevka-v1.0.1.tgz"; - sha256 = "1cxrbbb947pccy6532cxqrdlkfpm0m6z135mnyaiplfsd77jy772"; - system = "anatevka"; - asd = "anatevka"; - }); - systems = [ "anatevka" ]; - lispLibs = [ (getAttr "aether" self) (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - anatevka-tests = (build-asdf-system { - pname = "anatevka-tests"; - version = "v1.0.1"; - asds = [ "anatevka-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/anatevka/2024-10-12/anatevka-v1.0.1.tgz"; - sha256 = "1cxrbbb947pccy6532cxqrdlkfpm0m6z135mnyaiplfsd77jy772"; - system = "anatevka-tests"; - asd = "anatevka-tests"; - }); - systems = [ "anatevka-tests" ]; - lispLibs = [ (getAttr "anatevka" self) (getAttr "closer-mop" self) (getAttr "fiasco" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ansi-escape = (build-asdf-system { - pname = "ansi-escape"; - version = "20241012-git"; - asds = [ "ansi-escape" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/croatoan/2024-10-12/croatoan-20241012-git.tgz"; - sha256 = "04776x4i8inxs8n4mgy9xf0q39bzv4mfz4cl880sxwk6mnhwnn4c"; - system = "ansi-escape"; - asd = "ansi-escape"; - }); - systems = [ "ansi-escape" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ansi-escape-test = (build-asdf-system { - pname = "ansi-escape-test"; - version = "20241012-git"; - asds = [ "ansi-escape-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/croatoan/2024-10-12/croatoan-20241012-git.tgz"; - sha256 = "04776x4i8inxs8n4mgy9xf0q39bzv4mfz4cl880sxwk6mnhwnn4c"; - system = "ansi-escape-test"; - asd = "ansi-escape-test"; - }); - systems = [ "ansi-escape-test" ]; - lispLibs = [ (getAttr "ansi-escape" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ansi-test-harness = (build-asdf-system { - pname = "ansi-test-harness"; - version = "20231021-git"; - asds = [ "ansi-test-harness" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ansi-test-harness/2023-10-21/ansi-test-harness-20231021-git.tgz"; - sha256 = "168q2358ag5lf7k8378462279q0izllbwqr1axljm0nsn6d4g0yl"; - system = "ansi-test-harness"; - asd = "ansi-test-harness"; - }); - systems = [ "ansi-test-harness" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - antik = (build-asdf-system { - pname = "antik"; - version = "master-df14cb8c-git"; - asds = [ "antik" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/antik/2024-10-12/antik-master-df14cb8c-git.tgz"; - sha256 = "1n08cx4n51z8v4bxyak166lp495xda3x7llfxcdpxndxqxcammr0"; - system = "antik"; - asd = "antik"; - }); - systems = [ "antik" ]; - lispLibs = [ (getAttr "gsll" self) (getAttr "physical-dimension" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - antik-base = (build-asdf-system { - pname = "antik-base"; - version = "master-df14cb8c-git"; - asds = [ "antik-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/antik/2024-10-12/antik-master-df14cb8c-git.tgz"; - sha256 = "1n08cx4n51z8v4bxyak166lp495xda3x7llfxcdpxndxqxcammr0"; - system = "antik-base"; - asd = "antik-base"; - }); - systems = [ "antik-base" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "iterate" self) (getAttr "lisp-unit" self) (getAttr "metabang-bind" self) (getAttr "named-readtables" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - anypool = (build-asdf-system { - pname = "anypool"; - version = "20241012-git"; - asds = [ "anypool" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/anypool/2024-10-12/anypool-20241012-git.tgz"; - sha256 = "1ffssc5fzh7gj0z94xxfb3mk5cwja65lrhxyfgib15a6yxqf1kk1"; - system = "anypool"; - asd = "anypool"; - }); - systems = [ "anypool" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-speedy-queue" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - aplesque = (build-asdf-system { - pname = "aplesque"; - version = "20241012-git"; - asds = [ "aplesque" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "aplesque"; - asd = "aplesque"; - }); - systems = [ "aplesque" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "array-operations" self) (getAttr "cl-ppcre" self) (getAttr "lparallel" self) (getAttr "parse-number" self) (getAttr "symbol-munger" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - application = (build-asdf-system { - pname = "application"; - version = "20200427-git"; - asds = [ "application" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "application"; - asd = "application"; - }); - systems = [ "application" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-opengl" self) (getAttr "deflazy" self) (getAttr "glhelp" self) (getAttr "scratch-buffer" self) (getAttr "utility" self) (getAttr "window" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - apply-argv = (build-asdf-system { - pname = "apply-argv"; - version = "20150608-git"; - asds = [ "apply-argv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/apply-argv/2015-06-08/apply-argv-20150608-git.tgz"; - sha256 = "19qj847vyawjgm5iwk96469c0plnxj37948ac1bcd86hgpbm75w0"; - system = "apply-argv"; - asd = "apply-argv"; - }); - systems = [ "apply-argv" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - apply-argv-tests = (build-asdf-system { - pname = "apply-argv-tests"; - version = "20150608-git"; - asds = [ "apply-argv-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/apply-argv/2015-06-08/apply-argv-20150608-git.tgz"; - sha256 = "19qj847vyawjgm5iwk96469c0plnxj37948ac1bcd86hgpbm75w0"; - system = "apply-argv-tests"; - asd = "apply-argv"; - }); - systems = [ "apply-argv-tests" ]; - lispLibs = [ (getAttr "apply-argv" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - april = (build-asdf-system { - pname = "april"; - version = "20241012-git"; - asds = [ "april" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "april"; - asd = "april"; - }); - systems = [ "april" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "aplesque" self) (getAttr "array-operations" self) (getAttr "cl-ppcre" self) (getAttr "cl-unicode" self) (getAttr "lparallel" self) (getAttr "parse-number" self) (getAttr "prove" self) (getAttr "random-state" self) (getAttr "simple-date-time" self) (getAttr "symbol-munger" self) (getAttr "trivia" self) (getAttr "varray" self) (getAttr "vex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - april-demo_dot_cnn = (build-asdf-system { - pname = "april-demo.cnn"; - version = "20241012-git"; - asds = [ "april-demo.cnn" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "april-demo.cnn"; - asd = "april-demo.cnn"; - }); - systems = [ "april-demo.cnn" ]; - lispLibs = [ (getAttr "april" self) (getAttr "lisp-binary" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - april-demo_dot_fnn = (build-asdf-system { - pname = "april-demo.fnn"; - version = "20241012-git"; - asds = [ "april-demo.fnn" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "april-demo.fnn"; - asd = "april-demo.fnn"; - }); - systems = [ "april-demo.fnn" ]; - lispLibs = [ (getAttr "april" self) (getAttr "april-lib_dot_dfns_dot_array" self) (getAttr "lisp-binary" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - april-lib_dot_dfns_dot_array = (build-asdf-system { - pname = "april-lib.dfns.array"; - version = "20241012-git"; - asds = [ "april-lib.dfns.array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "april-lib.dfns.array"; - asd = "april-lib.dfns.array"; - }); - systems = [ "april-lib.dfns.array" ]; - lispLibs = [ (getAttr "april" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - april-lib_dot_dfns_dot_graph = (build-asdf-system { - pname = "april-lib.dfns.graph"; - version = "20241012-git"; - asds = [ "april-lib.dfns.graph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "april-lib.dfns.graph"; - asd = "april-lib.dfns.graph"; - }); - systems = [ "april-lib.dfns.graph" ]; - lispLibs = [ (getAttr "april" self) (getAttr "april-lib_dot_dfns_dot_array" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - april-lib_dot_dfns_dot_numeric = (build-asdf-system { - pname = "april-lib.dfns.numeric"; - version = "20241012-git"; - asds = [ "april-lib.dfns.numeric" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "april-lib.dfns.numeric"; - asd = "april-lib.dfns.numeric"; - }); - systems = [ "april-lib.dfns.numeric" ]; - lispLibs = [ (getAttr "april" self) (getAttr "april-lib_dot_dfns_dot_graph" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - april-lib_dot_dfns_dot_power = (build-asdf-system { - pname = "april-lib.dfns.power"; - version = "20241012-git"; - asds = [ "april-lib.dfns.power" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "april-lib.dfns.power"; - asd = "april-lib.dfns.power"; - }); - systems = [ "april-lib.dfns.power" ]; - lispLibs = [ (getAttr "april" self) (getAttr "april-lib_dot_dfns_dot_array" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - april-lib_dot_dfns_dot_string = (build-asdf-system { - pname = "april-lib.dfns.string"; - version = "20241012-git"; - asds = [ "april-lib.dfns.string" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "april-lib.dfns.string"; - asd = "april-lib.dfns.string"; - }); - systems = [ "april-lib.dfns.string" ]; - lispLibs = [ (getAttr "april" self) (getAttr "april-lib_dot_dfns_dot_array" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - april-lib_dot_dfns_dot_tree = (build-asdf-system { - pname = "april-lib.dfns.tree"; - version = "20241012-git"; - asds = [ "april-lib.dfns.tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "april-lib.dfns.tree"; - asd = "april-lib.dfns.tree"; - }); - systems = [ "april-lib.dfns.tree" ]; - lispLibs = [ (getAttr "april" self) (getAttr "april-lib_dot_dfns_dot_array" self) (getAttr "april-lib_dot_dfns_dot_power" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - april-xt_dot_uzuki = (build-asdf-system { - pname = "april-xt.uzuki"; - version = "20241012-git"; - asds = [ "april-xt.uzuki" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "april-xt.uzuki"; - asd = "april-xt.uzuki"; - }); - systems = [ "april-xt.uzuki" ]; - lispLibs = [ (getAttr "april" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - arc-compat = (build-asdf-system { - pname = "arc-compat"; - version = "20241012-git"; - asds = [ "arc-compat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/arc-compat/2024-10-12/arc-compat-20241012-git.tgz"; - sha256 = "1wmq5mvlkvdbl4562p3n7x8bhv3swjj0yqbly07y8mv0snasns8d"; - system = "arc-compat"; - asd = "arc-compat"; - }); - systems = [ "arc-compat" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "cl-fad" self) (getAttr "fiveam" self) (getAttr "ironclad" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - architecture_dot_builder-protocol = (build-asdf-system { - pname = "architecture.builder-protocol"; - version = "20241012-git"; - asds = [ "architecture.builder-protocol" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/architecture.builder-protocol/2024-10-12/architecture.builder-protocol-20241012-git.tgz"; - sha256 = "1ckrv0ca57xvsvd9rwjcq0yljiv76wj22p1pjpjbjfr5clb9gl0q"; - system = "architecture.builder-protocol"; - asd = "architecture.builder-protocol"; - }); - systems = [ "architecture.builder-protocol" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - architecture_dot_builder-protocol_dot_inspection = (build-asdf-system { - pname = "architecture.builder-protocol.inspection"; - version = "20241012-git"; - asds = [ "architecture.builder-protocol.inspection" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/architecture.builder-protocol/2024-10-12/architecture.builder-protocol-20241012-git.tgz"; - sha256 = "1ckrv0ca57xvsvd9rwjcq0yljiv76wj22p1pjpjbjfr5clb9gl0q"; - system = "architecture.builder-protocol.inspection"; - asd = "architecture.builder-protocol.inspection"; - }); - systems = [ "architecture.builder-protocol.inspection" ]; - lispLibs = [ (getAttr "architecture_dot_builder-protocol" self) (getAttr "clouseau" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - architecture_dot_builder-protocol_dot_json = (build-asdf-system { - pname = "architecture.builder-protocol.json"; - version = "20241012-git"; - asds = [ "architecture.builder-protocol.json" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/architecture.builder-protocol/2024-10-12/architecture.builder-protocol-20241012-git.tgz"; - sha256 = "1ckrv0ca57xvsvd9rwjcq0yljiv76wj22p1pjpjbjfr5clb9gl0q"; - system = "architecture.builder-protocol.json"; - asd = "architecture.builder-protocol.json"; - }); - systems = [ "architecture.builder-protocol.json" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "architecture_dot_builder-protocol" self) (getAttr "cl-json" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - architecture_dot_builder-protocol_dot_print-tree = (build-asdf-system { - pname = "architecture.builder-protocol.print-tree"; - version = "20241012-git"; - asds = [ "architecture.builder-protocol.print-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/architecture.builder-protocol/2024-10-12/architecture.builder-protocol-20241012-git.tgz"; - sha256 = "1ckrv0ca57xvsvd9rwjcq0yljiv76wj22p1pjpjbjfr5clb9gl0q"; - system = "architecture.builder-protocol.print-tree"; - asd = "architecture.builder-protocol.print-tree"; - }); - systems = [ "architecture.builder-protocol.print-tree" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "architecture_dot_builder-protocol" self) (getAttr "utilities_dot_print-tree" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - architecture_dot_builder-protocol_dot_universal-builder = (build-asdf-system { - pname = "architecture.builder-protocol.universal-builder"; - version = "20241012-git"; - asds = [ "architecture.builder-protocol.universal-builder" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/architecture.builder-protocol/2024-10-12/architecture.builder-protocol-20241012-git.tgz"; - sha256 = "1ckrv0ca57xvsvd9rwjcq0yljiv76wj22p1pjpjbjfr5clb9gl0q"; - system = "architecture.builder-protocol.universal-builder"; - asd = "architecture.builder-protocol.universal-builder"; - }); - systems = [ "architecture.builder-protocol.universal-builder" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "architecture_dot_builder-protocol" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - architecture_dot_builder-protocol_dot_xpath = (build-asdf-system { - pname = "architecture.builder-protocol.xpath"; - version = "20241012-git"; - asds = [ "architecture.builder-protocol.xpath" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/architecture.builder-protocol/2024-10-12/architecture.builder-protocol-20241012-git.tgz"; - sha256 = "1ckrv0ca57xvsvd9rwjcq0yljiv76wj22p1pjpjbjfr5clb9gl0q"; - system = "architecture.builder-protocol.xpath"; - asd = "architecture.builder-protocol.xpath"; - }); - systems = [ "architecture.builder-protocol.xpath" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "architecture_dot_builder-protocol" self) (getAttr "xpath" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - architecture_dot_service-provider = (build-asdf-system { - pname = "architecture.service-provider"; - version = "20191007-git"; - asds = [ "architecture.service-provider" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/architecture.service-provider/2019-10-07/architecture.service-provider-20191007-git.tgz"; - sha256 = "0n4a299md5z0wvk6j3my4ii6cs198fqgizz1swic89p1qz5n2fjm"; - system = "architecture.service-provider"; - asd = "architecture.service-provider"; - }); - systems = [ "architecture.service-provider" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "let-plus" self) (getAttr "more-conditions" self) (getAttr "utilities_dot_print-items" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - architecture_dot_service-provider-and-hooks = (build-asdf-system { - pname = "architecture.service-provider-and-hooks"; - version = "20191007-git"; - asds = [ "architecture.service-provider-and-hooks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/architecture.service-provider/2019-10-07/architecture.service-provider-20191007-git.tgz"; - sha256 = "0n4a299md5z0wvk6j3my4ii6cs198fqgizz1swic89p1qz5n2fjm"; - system = "architecture.service-provider-and-hooks"; - asd = "architecture.service-provider-and-hooks"; - }); - systems = [ "architecture.service-provider-and-hooks" ]; - lispLibs = [ (getAttr "architecture_dot_service-provider" self) (getAttr "cl-hooks" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - archive = (build-asdf-system { - pname = "archive"; - version = "20160318-git"; - asds = [ "archive" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/archive/2016-03-18/archive-20160318-git.tgz"; - sha256 = "0pvsc9fmybx7rxd0kmzq4shi6hszdpwdc1sfy7jwyfxf8n3hnv4p"; - system = "archive"; - asd = "archive"; - }); - systems = [ "archive" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - arith = (build-asdf-system { - pname = "arith"; - version = "20170830-git"; - asds = [ "arith" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/paren-test/2017-08-30/paren-test-20170830-git.tgz"; - sha256 = "0b2d3kcv3n4b0dm67pzhxx8wxjsgnb32bw2dsprblc7149gaczdr"; - system = "arith"; - asd = "arith"; - }); - systems = [ "arith" ]; - lispLibs = [ (getAttr "paren-files" self) (getAttr "paren-test" self) (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - arithmetic-operators-as-words = (build-asdf-system { - pname = "arithmetic-operators-as-words"; - version = "20200610-git"; - asds = [ "arithmetic-operators-as-words" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/arithmetic-operators-as-words/2020-06-10/arithmetic-operators-as-words-20200610-git.tgz"; - sha256 = "1bcfkbq3kqns2ng0cdmj81c72j63641pqlskg4xrzkgkh25bhkks"; - system = "arithmetic-operators-as-words"; - asd = "arithmetic-operators-as-words"; - }); - systems = [ "arithmetic-operators-as-words" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - arnesi = (build-asdf-system { - pname = "arnesi"; - version = "20170403-git"; - asds = [ "arnesi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/arnesi/2017-04-03/arnesi-20170403-git.tgz"; - sha256 = "0jgj2xgd1gq6rf8ia43lkmbrbxnp8rgs053br9azfa25ygk3ikbh"; - system = "arnesi"; - asd = "arnesi"; - }); - systems = [ "arnesi" ]; - lispLibs = [ (getAttr "collectors" self) ]; - meta = {}; - }); - array-operations = (build-asdf-system { - pname = "array-operations"; - version = "1.2.1"; - asds = [ "array-operations" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/array-operations/2023-10-21/array-operations-1.2.1.tgz"; - sha256 = "06zg7ds7c1vi59zxzrd52a9zfpw8x0jsf1hqcdgaz8s3dcfma3mn"; - system = "array-operations"; - asd = "array-operations"; - }); - systems = [ "array-operations" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "let-plus" self) ]; - meta = {}; - }); - array-utils = (build-asdf-system { - pname = "array-utils"; - version = "20241012-git"; - asds = [ "array-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/array-utils/2024-10-12/array-utils-20241012-git.tgz"; - sha256 = "0rya7k9sfpyrn5vrn12wywpgsr2f0pmcywv51ixzb0sv8ska0mhs"; - system = "array-utils"; - asd = "array-utils"; - }); - systems = [ "array-utils" ]; - lispLibs = [ ]; - meta = {}; - }); - array-utils-test = (build-asdf-system { - pname = "array-utils-test"; - version = "20241012-git"; - asds = [ "array-utils-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/array-utils/2024-10-12/array-utils-20241012-git.tgz"; - sha256 = "0rya7k9sfpyrn5vrn12wywpgsr2f0pmcywv51ixzb0sv8ska0mhs"; - system = "array-utils-test"; - asd = "array-utils-test"; - }); - systems = [ "array-utils-test" ]; - lispLibs = [ (getAttr "array-utils" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - arrival = (build-asdf-system { - pname = "arrival"; - version = "20211209-git"; - asds = [ "arrival" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/arrival/2021-12-09/arrival-20211209-git.tgz"; - sha256 = "1iwdk5fdismw91ln5wdnn8c8xv06fbgiwbvdj2gy2hpp8f3qk00b"; - system = "arrival"; - asd = "arrival"; - }); - systems = [ "arrival" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "log4cl" self) (getAttr "trivia" self) (getAttr "trivia_dot_quasiquote" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - arrow-macros = (build-asdf-system { - pname = "arrow-macros"; - version = "20241012-git"; - asds = [ "arrow-macros" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/arrow-macros/2024-10-12/arrow-macros-20241012-git.tgz"; - sha256 = "0q4vpysk4h9ghs5zmnzzilky9jyz7i8n0x0p98nq528crbrkh6c4"; - system = "arrow-macros"; - asd = "arrow-macros"; - }); - systems = [ "arrow-macros" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - arrow-macros-test = (build-asdf-system { - pname = "arrow-macros-test"; - version = "20241012-git"; - asds = [ "arrow-macros-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/arrow-macros/2024-10-12/arrow-macros-20241012-git.tgz"; - sha256 = "0q4vpysk4h9ghs5zmnzzilky9jyz7i8n0x0p98nq528crbrkh6c4"; - system = "arrow-macros-test"; - asd = "arrow-macros-test"; - }); - systems = [ "arrow-macros-test" ]; - lispLibs = [ (getAttr "arrow-macros" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - arrows = (build-asdf-system { - pname = "arrows"; - version = "20181018-git"; - asds = [ "arrows" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/arrows/2018-10-18/arrows-20181018-git.tgz"; - sha256 = "042k9vkssrqx9nhp14wdzm942zgdxvp35mba0p2syz98i75im2yy"; - system = "arrows"; - asd = "arrows"; - }); - systems = [ "arrows" ]; - lispLibs = [ ]; - meta = {}; - }); - ascii-strings = (build-asdf-system { - pname = "ascii-strings"; - version = "20211209-git"; - asds = [ "ascii-strings" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-string-match/2021-12-09/cl-string-match-20211209-git.tgz"; - sha256 = "0zndlkw3qy3vw4px4qv884z6232w8zfaliyc88irjwizdv35wcq9"; - system = "ascii-strings"; - asd = "ascii-strings"; - }); - systems = [ "ascii-strings" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asd-generator = (build-asdf-system { - pname = "asd-generator"; - version = "20190107-git"; - asds = [ "asd-generator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asd-generator/2019-01-07/asd-generator-20190107-git.tgz"; - sha256 = "0yiybl7b9x1f85v0drj0yw9821y3yfhya4n6gycnv5vvx6jp9by4"; - system = "asd-generator"; - asd = "asd-generator"; - }); - systems = [ "asd-generator" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "iterate" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asd-generator-test = (build-asdf-system { - pname = "asd-generator-test"; - version = "20190107-git"; - asds = [ "asd-generator-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asd-generator/2019-01-07/asd-generator-20190107-git.tgz"; - sha256 = "0yiybl7b9x1f85v0drj0yw9821y3yfhya4n6gycnv5vvx6jp9by4"; - system = "asd-generator-test"; - asd = "asd-generator-test"; - }); - systems = [ "asd-generator-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asdf-dependency-graph = (build-asdf-system { - pname = "asdf-dependency-graph"; - version = "20230618-git"; - asds = [ "asdf-dependency-graph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-dependency-graph/2023-06-18/asdf-dependency-graph-20230618-git.tgz"; - sha256 = "1m3cgjmr5fzyas33gjnahcbjiiksr02h2lwdxxl35y2dbip8pygp"; - system = "asdf-dependency-graph"; - asd = "asdf-dependency-graph"; - }); - systems = [ "asdf-dependency-graph" ]; - lispLibs = [ (getAttr "optima" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asdf-dependency-grovel = (build-asdf-system { - pname = "asdf-dependency-grovel"; - version = "20170403-git"; - asds = [ "asdf-dependency-grovel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-dependency-grovel/2017-04-03/asdf-dependency-grovel-20170403-git.tgz"; - sha256 = "1y4kdqsda4ira4r9dws6kxzzv6mg45q3lkmb2c9mg9q7ksc5glif"; - system = "asdf-dependency-grovel"; - asd = "asdf-dependency-grovel"; - }); - systems = [ "asdf-dependency-grovel" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asdf-driver = (build-asdf-system { - pname = "asdf-driver"; - version = "3.3.7"; - asds = [ "asdf-driver" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uiop/2024-10-12/uiop-3.3.7.tgz"; - sha256 = "0xvzxglkf9hlly7if0l307k31kwglk2ay4k393545c1l5l1ac584"; - system = "asdf-driver"; - asd = "asdf-driver"; - }); - systems = [ "asdf-driver" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asdf-encodings = (build-asdf-system { - pname = "asdf-encodings"; - version = "20191007-git"; - asds = [ "asdf-encodings" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-encodings/2019-10-07/asdf-encodings-20191007-git.tgz"; - sha256 = "1yn77nhrz5w2s7nlafxjnk9j8fsrz7ivrm7nbj4r726bwc5knky6"; - system = "asdf-encodings"; - asd = "asdf-encodings"; - }); - systems = [ "asdf-encodings" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asdf-finalizers = (build-asdf-system { - pname = "asdf-finalizers"; - version = "20221106-git"; - asds = [ "asdf-finalizers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-finalizers/2022-11-06/asdf-finalizers-20221106-git.tgz"; - sha256 = "1w56c9yjjydjshsgqxz57qlp2v3r4ilbisnsgiqphvxnhvd41y0v"; - system = "asdf-finalizers"; - asd = "asdf-finalizers"; - }); - systems = [ "asdf-finalizers" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asdf-linguist = (build-asdf-system { - pname = "asdf-linguist"; - version = "20150923-git"; - asds = [ "asdf-linguist" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-linguist/2015-09-23/asdf-linguist-20150923-git.tgz"; - sha256 = "14jaqmxxh70f1jf58mxb117951iql2sjxymmbjyqniqwazznbd9a"; - system = "asdf-linguist"; - asd = "asdf-linguist"; - }); - systems = [ "asdf-linguist" ]; - lispLibs = [ (getAttr "inferior-shell" self) (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asdf-manager = (build-asdf-system { - pname = "asdf-manager"; - version = "20160208-git"; - asds = [ "asdf-manager" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-manager/2016-02-08/asdf-manager-20160208-git.tgz"; - sha256 = "0jw7d0vg13v1l1fwwhsw04n6w3c49vsbmq6vrlrkh95aayc5413w"; - system = "asdf-manager"; - asd = "asdf-manager"; - }); - systems = [ "asdf-manager" ]; - lispLibs = [ (getAttr "trivial-download" self) (getAttr "trivial-extract" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asdf-manager-test = (build-asdf-system { - pname = "asdf-manager-test"; - version = "20160208-git"; - asds = [ "asdf-manager-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-manager/2016-02-08/asdf-manager-20160208-git.tgz"; - sha256 = "0jw7d0vg13v1l1fwwhsw04n6w3c49vsbmq6vrlrkh95aayc5413w"; - system = "asdf-manager-test"; - asd = "asdf-manager-test"; - }); - systems = [ "asdf-manager-test" ]; - lispLibs = [ (getAttr "asdf-manager" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asdf-nst = (build-asdf-system { - pname = "asdf-nst"; - version = "20210807-git"; - asds = [ "asdf-nst" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; - sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; - system = "asdf-nst"; - asd = "asdf-nst"; - }); - systems = [ "asdf-nst" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asdf-package-system = (build-asdf-system { - pname = "asdf-package-system"; - version = "20150608-git"; - asds = [ "asdf-package-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-package-system/2015-06-08/asdf-package-system-20150608-git.tgz"; - sha256 = "1q4qgvbl64c4zdbq91by1la8licdgam7ybnhvg2bixdhq4v693sj"; - system = "asdf-package-system"; - asd = "asdf-package-system"; - }); - systems = [ "asdf-package-system" ]; - lispLibs = [ ]; - meta = {}; - }); - asdf-system-connections = (build-asdf-system { - pname = "asdf-system-connections"; - version = "20170124-git"; - asds = [ "asdf-system-connections" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-system-connections/2017-01-24/asdf-system-connections-20170124-git.tgz"; - sha256 = "06kg0m8bv383qq3r34x0f8hz6p6zxcw02qn7kj960vcnrp5a5b3y"; - system = "asdf-system-connections"; - asd = "asdf-system-connections"; - }); - systems = [ "asdf-system-connections" ]; - lispLibs = [ ]; - meta = {}; - }); - asdf-viz = (build-asdf-system { - pname = "asdf-viz"; - version = "20200610-git"; - asds = [ "asdf-viz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-viz/2020-06-10/asdf-viz-20200610-git.tgz"; - sha256 = "1hj9ac1m2kz8x65n62gd1s2k2x9pip9a85pnmib53qsks3a9sc4z"; - system = "asdf-viz"; - asd = "asdf-viz"; - }); - systems = [ "asdf-viz" ]; - lispLibs = [ (getAttr "cl-dot" self) (getAttr "closer-mop" self) (getAttr "iterate" self) (getAttr "swank" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - aserve = (build-asdf-system { - pname = "aserve"; - version = "20190813-git"; - asds = [ "aserve" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/portableaserve/2019-08-13/portableaserve-20190813-git.tgz"; - sha256 = "0ak6mqp84sjr0a7h5svr16vra4bf4fcx6wpir0n88dc1vjwy5xqa"; - system = "aserve"; - asd = "aserve"; - }); - systems = [ "aserve" ]; - lispLibs = [ (getAttr "acl-compat" self) (getAttr "htmlgen" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asn1 = (build-asdf-system { - pname = "asn1"; - version = "20220331-git"; - asds = [ "asn1" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asn1/2022-03-31/asn1-20220331-git.tgz"; - sha256 = "16gs4xznmg19ii0cg7g2yxrk9ls5vah8ynjj80s99rv8wi3789z1"; - system = "asn1"; - asd = "asn1"; - }); - systems = [ "asn1" ]; - lispLibs = [ (getAttr "fast-io" self) (getAttr "ironclad" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - assert-p = (build-asdf-system { - pname = "assert-p"; - version = "20200610-git"; - asds = [ "assert-p" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/assert-p/2020-06-10/assert-p-20200610-git.tgz"; - sha256 = "1x24rkqkqiw8zd26swi9rmhfplkmr5scz3bhjwccah9d2s36b1xs"; - system = "assert-p"; - asd = "assert-p"; - }); - systems = [ "assert-p" ]; - lispLibs = [ (getAttr "assertion-error" self) (getAttr "simplet-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - assertion-error = (build-asdf-system { - pname = "assertion-error"; - version = "20191227-git"; - asds = [ "assertion-error" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/assertion-error/2019-12-27/assertion-error-20191227-git.tgz"; - sha256 = "0ix23kkakmf4nwx852zsssb831jvajr3qyppqfyks7y1ls617svn"; - system = "assertion-error"; - asd = "assertion-error"; - }); - systems = [ "assertion-error" ]; - lispLibs = [ (getAttr "dissect" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - assoc-utils = (build-asdf-system { - pname = "assoc-utils"; - version = "20241012-git"; - asds = [ "assoc-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/assoc-utils/2024-10-12/assoc-utils-20241012-git.tgz"; - sha256 = "0rgfv9qni9dnmm3qnaf1x67h0z38vw2zbmbsdk3a4x5s8ckxln6r"; - system = "assoc-utils"; - asd = "assoc-utils"; - }); - systems = [ "assoc-utils" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - assoc-utils-test = (build-asdf-system { - pname = "assoc-utils-test"; - version = "20241012-git"; - asds = [ "assoc-utils-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/assoc-utils/2024-10-12/assoc-utils-20241012-git.tgz"; - sha256 = "0rgfv9qni9dnmm3qnaf1x67h0z38vw2zbmbsdk3a4x5s8ckxln6r"; - system = "assoc-utils-test"; - asd = "assoc-utils-test"; - }); - systems = [ "assoc-utils-test" ]; - lispLibs = [ (getAttr "assoc-utils" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - asteroids = (build-asdf-system { - pname = "asteroids"; - version = "20191007-git"; - asds = [ "asteroids" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asteroids/2019-10-07/asteroids-20191007-git.tgz"; - sha256 = "1wdzwpizgy477ny6pxjshj3q25phdxsjfq8cvrbx0x7k5w8fkg50"; - system = "asteroids"; - asd = "asteroids"; - }); - systems = [ "asteroids" ]; - lispLibs = [ (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-gfx" self) (getAttr "lispbuilder-sdl-mixer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - astonish = (build-asdf-system { - pname = "astonish"; - version = "20210124-git"; - asds = [ "astonish" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/astonish/2021-01-24/astonish-20210124-git.tgz"; - sha256 = "14qphx97q4gqcc71figc6r3cgy89rn9c43sh35fzxkln9ydk2pr6"; - system = "astonish"; - asd = "astonish"; - }); - systems = [ "astonish" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - async-process = (build-asdf-system { - pname = "async-process"; - version = "20241012-git"; - asds = [ "async-process" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/async-process/2024-10-12/async-process-20241012-git.tgz"; - sha256 = "0691z0vs5c65m24p1yi12iy27j59layzvzyy1yl19704x05442qh"; - system = "async-process"; - asd = "async-process"; - }); - systems = [ "async-process" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - atdoc = (build-asdf-system { - pname = "atdoc"; - version = "20120305-git"; - asds = [ "atdoc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/atdoc/2012-03-05/atdoc-20120305-git.tgz"; - sha256 = "1w54phadjj00sy5qz5n0hmhzyjrx26h9hw06756zdpfbzk4f5il6"; - system = "atdoc"; - asd = "atdoc"; - }); - systems = [ "atdoc" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "cxml" self) (getAttr "split-sequence" self) (getAttr "swank" self) (getAttr "xuriella" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - atomics = (build-asdf-system { - pname = "atomics"; - version = "20241012-git"; - asds = [ "atomics" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/atomics/2024-10-12/atomics-20241012-git.tgz"; - sha256 = "1ah6fgvfva0axnhj4sp1qy6gjyw41fkhpnv998di0wbp6hls8j39"; - system = "atomics"; - asd = "atomics"; - }); - systems = [ "atomics" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - atomics-test = (build-asdf-system { - pname = "atomics-test"; - version = "20241012-git"; - asds = [ "atomics-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/atomics/2024-10-12/atomics-20241012-git.tgz"; - sha256 = "1ah6fgvfva0axnhj4sp1qy6gjyw41fkhpnv998di0wbp6hls8j39"; - system = "atomics-test"; - asd = "atomics-test"; - }); - systems = [ "atomics-test" ]; - lispLibs = [ (getAttr "atomics" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - audio-tag = (build-asdf-system { - pname = "audio-tag"; - version = "20210531-git"; - asds = [ "audio-tag" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/audio-tag/2021-05-31/audio-tag-20210531-git.tgz"; - sha256 = "1k9152wakazr34q4q5x8zzv3mjjkf0n9xdg7c2qqwigwws0ysgzh"; - system = "audio-tag"; - asd = "audio-tag"; - }); - systems = [ "audio-tag" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "osicat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - authenticated-encryption = (build-asdf-system { - pname = "authenticated-encryption"; - version = "20181018-git"; - asds = [ "authenticated-encryption" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/authenticated-encryption/2018-10-18/authenticated-encryption-20181018-git.tgz"; - sha256 = "0cvl4g0g59z5dicg7q3f9hhqshz2m0a6l2fzic75c3yv28q8m2vr"; - system = "authenticated-encryption"; - asd = "authenticated-encryption"; - }); - systems = [ "authenticated-encryption" ]; - lispLibs = [ (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - authenticated-encryption-test = (build-asdf-system { - pname = "authenticated-encryption-test"; - version = "20181018-git"; - asds = [ "authenticated-encryption-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/authenticated-encryption/2018-10-18/authenticated-encryption-20181018-git.tgz"; - sha256 = "0cvl4g0g59z5dicg7q3f9hhqshz2m0a6l2fzic75c3yv28q8m2vr"; - system = "authenticated-encryption-test"; - asd = "authenticated-encryption-test"; - }); - systems = [ "authenticated-encryption-test" ]; - lispLibs = [ (getAttr "_1am" self) (getAttr "authenticated-encryption" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - auto-restart = (build-asdf-system { - pname = "auto-restart"; - version = "20241012-git"; - asds = [ "auto-restart" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/auto-restart/2024-10-12/auto-restart-20241012-git.tgz"; - sha256 = "1kz50w4x7glin8fyrfysazz07r4rrk90daml35yrwnz08vi3dfw7"; - system = "auto-restart"; - asd = "auto-restart"; - }); - systems = [ "auto-restart" ]; - lispLibs = [ (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - autoexport = (build-asdf-system { - pname = "autoexport"; - version = "20211020-git"; - asds = [ "autoexport" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/autoexport/2021-10-20/autoexport-20211020-git.tgz"; - sha256 = "15kzq4hfsracxapxik3i6sxqqnwl7cb9lisgk9krrsk13d97l844"; - system = "autoexport"; - asd = "autoexport"; - }); - systems = [ "autoexport" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - automaton = (build-asdf-system { - pname = "automaton"; - version = "20241012-git"; - asds = [ "automaton" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "automaton"; - asd = "automaton"; - }); - systems = [ "automaton" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - avatar-api = (build-asdf-system { - pname = "avatar-api"; - version = "20150608-git"; - asds = [ "avatar-api" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/avatar-api/2015-06-08/avatar-api-20150608-git.tgz"; - sha256 = "026s8m0bl13iqyakfxc6zwacvpj2bxxipms1kl3k9ql99yn8imvr"; - system = "avatar-api"; - asd = "avatar-api"; - }); - systems = [ "avatar-api" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "crypto-shortcuts" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - avatar-api-test = (build-asdf-system { - pname = "avatar-api-test"; - version = "20150608-git"; - asds = [ "avatar-api-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/avatar-api/2015-06-08/avatar-api-20150608-git.tgz"; - sha256 = "026s8m0bl13iqyakfxc6zwacvpj2bxxipms1kl3k9ql99yn8imvr"; - system = "avatar-api-test"; - asd = "avatar-api-test"; - }); - systems = [ "avatar-api-test" ]; - lispLibs = [ (getAttr "avatar-api" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - avl-tree = (build-asdf-system { - pname = "avl-tree"; - version = "20220707-git"; - asds = [ "avl-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/avl-tree/2022-07-07/avl-tree-20220707-git.tgz"; - sha256 = "1xvh5rpz0kwzx42jrnh3kgqa87z5kmgd7f3fkkydiqj04hknsj7k"; - system = "avl-tree"; - asd = "avl-tree"; - }); - systems = [ "avl-tree" ]; - lispLibs = [ (getAttr "mfiano-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - aws-foundation = (build-asdf-system { - pname = "aws-foundation"; - version = "20180711-git"; - asds = [ "aws-foundation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/aws-foundation/2018-07-11/aws-foundation-20180711-git.tgz"; - sha256 = "1f5af22qw583frqjhnkf9wcccdkkpjiv0bbnlqqk7fxzm9pqpvhb"; - system = "aws-foundation"; - asd = "aws-foundation"; - }); - systems = [ "aws-foundation" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-json" self) (getAttr "cl-json-helper" self) (getAttr "dexador" self) (getAttr "ironclad" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - aws-sdk = (build-asdf-system { - pname = "aws-sdk"; - version = "20241012-git"; - asds = [ "aws-sdk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/aws-sdk-lisp/2024-10-12/aws-sdk-lisp-20241012-git.tgz"; - sha256 = "0iqm441fr1qx5py7cvrv4jl9zgfsm813igwvq3rj90606g6lyxjc"; - system = "aws-sdk"; - asd = "aws-sdk"; - }); - systems = [ "aws-sdk" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "assoc-utils" self) (getAttr "aws-sign4" self) (getAttr "babel" self) (getAttr "cl-base64" self) (getAttr "cl-ppcre" self) (getAttr "dexador" self) (getAttr "ironclad" self) (getAttr "kebab" self) (getAttr "local-time" self) (getAttr "parser_dot_ini" self) (getAttr "quri" self) (getAttr "trivial-timeout" self) (getAttr "trivial-types" self) (getAttr "xmls" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - aws-sign4 = (build-asdf-system { - pname = "aws-sign4"; - version = "20201220-git"; - asds = [ "aws-sign4" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/aws-sign4/2020-12-20/aws-sign4-20201220-git.tgz"; - sha256 = "1bwqmy9vlq0ilwhp48y05cdfav9inwv4kai8mjj1a95776xjmjnk"; - system = "aws-sign4"; - asd = "aws-sign4"; - }); - systems = [ "aws-sign4" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "ironclad" self) (getAttr "local-time" self) (getAttr "secret-values" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - aws-sign4-example = (build-asdf-system { - pname = "aws-sign4-example"; - version = "20201220-git"; - asds = [ "aws-sign4-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/aws-sign4/2020-12-20/aws-sign4-20201220-git.tgz"; - sha256 = "1bwqmy9vlq0ilwhp48y05cdfav9inwv4kai8mjj1a95776xjmjnk"; - system = "aws-sign4-example"; - asd = "aws-sign4"; - }); - systems = [ "aws-sign4-example" ]; - lispLibs = [ (getAttr "aws-sign4" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - aws-sign4-tests = (build-asdf-system { - pname = "aws-sign4-tests"; - version = "20201220-git"; - asds = [ "aws-sign4-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/aws-sign4/2020-12-20/aws-sign4-20201220-git.tgz"; - sha256 = "1bwqmy9vlq0ilwhp48y05cdfav9inwv4kai8mjj1a95776xjmjnk"; - system = "aws-sign4-tests"; - asd = "aws-sign4"; - }); - systems = [ "aws-sign4-tests" ]; - lispLibs = [ (getAttr "aws-sign4" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ayah-captcha = (build-asdf-system { - pname = "ayah-captcha"; - version = "20180228-git"; - asds = [ "ayah-captcha" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ayah-captcha/2018-02-28/ayah-captcha-20180228-git.tgz"; - sha256 = "1l9zg0hj5cd1yda1nnab7byrgkakh5vn3qcd4lmfidbijk6kiamw"; - system = "ayah-captcha"; - asd = "ayah-captcha"; - }); - systems = [ "ayah-captcha" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ayah-captcha-demo = (build-asdf-system { - pname = "ayah-captcha-demo"; - version = "20180228-git"; - asds = [ "ayah-captcha-demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ayah-captcha/2018-02-28/ayah-captcha-20180228-git.tgz"; - sha256 = "1l9zg0hj5cd1yda1nnab7byrgkakh5vn3qcd4lmfidbijk6kiamw"; - system = "ayah-captcha-demo"; - asd = "ayah-captcha-demo"; - }); - systems = [ "ayah-captcha-demo" ]; - lispLibs = [ (getAttr "ayah-captcha" self) (getAttr "cl-who" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - babel = (build-asdf-system { - pname = "babel"; - version = "20241012-git"; - asds = [ "babel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/babel/2024-10-12/babel-20241012-git.tgz"; - sha256 = "0359bj3yr6frybcmg8qr5vi4q8hzbsb7hmvxdc0jgkfz3c33q667"; - system = "babel"; - asd = "babel"; - }); - systems = [ "babel" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-features" self) ]; - meta = {}; - }); - babel-streams = (build-asdf-system { - pname = "babel-streams"; - version = "20241012-git"; - asds = [ "babel-streams" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/babel/2024-10-12/babel-20241012-git.tgz"; - sha256 = "0359bj3yr6frybcmg8qr5vi4q8hzbsb7hmvxdc0jgkfz3c33q667"; - system = "babel-streams"; - asd = "babel-streams"; - }); - systems = [ "babel-streams" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - babel-tests = (build-asdf-system { - pname = "babel-tests"; - version = "20241012-git"; - asds = [ "babel-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/babel/2024-10-12/babel-20241012-git.tgz"; - sha256 = "0359bj3yr6frybcmg8qr5vi4q8hzbsb7hmvxdc0jgkfz3c33q667"; - system = "babel-tests"; - asd = "babel-tests"; - }); - systems = [ "babel-tests" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "hu_dot_dwim_dot_stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - babylon = (build-asdf-system { - pname = "babylon"; - version = "20231021-git"; - asds = [ "babylon" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/babylon/2023-10-21/babylon-20231021-git.tgz"; - sha256 = "14k9kvcfyfpn74l5ij5mdc7zlj9vnlnig8piqw0wm5gq9pxmhydg"; - system = "babylon"; - asd = "babylon"; - }); - systems = [ "babylon" ]; - lispLibs = [ (getAttr "fare-quasiquote-extras" self) (getAttr "fmcs" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - base = (build-asdf-system { - pname = "base"; - version = "master-fe503896-git"; - asds = [ "base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "base"; - asd = "base"; - }); - systems = [ "base" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - base-blobs = (build-asdf-system { - pname = "base-blobs"; - version = "stable-git"; - asds = [ "base-blobs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/base-blobs/2020-10-16/base-blobs-stable-git.tgz"; - sha256 = "06m8rvczj309wq8by697gvrklhff5mnn5n5sky7i11bnszrxysys"; - system = "base-blobs"; - asd = "base-blobs"; - }); - systems = [ "base-blobs" ]; - lispLibs = [ (getAttr "bodge-blobs-support" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - base64 = (build-asdf-system { - pname = "base64"; - version = "20181018-git"; - asds = [ "base64" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/base64/2018-10-18/base64-20181018-git.tgz"; - sha256 = "0qkqcrgmcqshcsnzn4pcyk8d1j9c7pks2qf51p1hfybz5shxkqkh"; - system = "base64"; - asd = "base64"; - }); - systems = [ "base64" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - basic-binary-ipc = (build-asdf-system { - pname = "basic-binary-ipc"; - version = "20211209-git"; - asds = [ "basic-binary-ipc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/basic-binary-ipc/2021-12-09/basic-binary-ipc-20211209-git.tgz"; - sha256 = "0bsxy27mnmzr6vys96cs2is57zvk0n9hlif9llnp4q9m2wzycbwm"; - system = "basic-binary-ipc"; - asd = "basic-binary-ipc"; - }); - systems = [ "basic-binary-ipc" ]; - lispLibs = [ (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - basic-binary-ipc-tests = (build-asdf-system { - pname = "basic-binary-ipc-tests"; - version = "20211209-git"; - asds = [ "basic-binary-ipc-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/basic-binary-ipc/2021-12-09/basic-binary-ipc-20211209-git.tgz"; - sha256 = "0bsxy27mnmzr6vys96cs2is57zvk0n9hlif9llnp4q9m2wzycbwm"; - system = "basic-binary-ipc-tests"; - asd = "basic-binary-ipc-tests"; - }); - systems = [ "basic-binary-ipc-tests" ]; - lispLibs = [ (getAttr "basic-binary-ipc" self) (getAttr "bordeaux-threads" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bdef = (build-asdf-system { - pname = "bdef"; - version = "20241012-git"; - asds = [ "bdef" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bdef/2024-10-12/bdef-20241012-git.tgz"; - sha256 = "16jz9fxxjcpnmhx0yagv8xs7l0b7qh8yx7i7p8fnlxz3pn7726y6"; - system = "bdef"; - asd = "bdef"; - }); - systems = [ "bdef" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "eager-future2" self) (getAttr "jsown" self) (getAttr "mutility" self) (getAttr "parse-float" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - beast = (build-asdf-system { - pname = "beast"; - version = "20211020-hg"; - asds = [ "beast" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/beast/2021-10-20/beast-20211020-hg.tgz"; - sha256 = "0rb7yxr4clsdbgyjz9d8inxgj7zs0knrngl7gb6b8ky1vyrv12k4"; - system = "beast"; - asd = "beast"; - }); - systems = [ "beast" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - beirc = (build-asdf-system { - pname = "beirc"; - version = "20150505-git"; - asds = [ "beirc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/beirc/2015-05-05/beirc-20150505-git.tgz"; - sha256 = "1jmxihxln51vxy85r3zx0gfrzs9ng8nmj87j5ws1fg8bwv8b2zc4"; - system = "beirc"; - asd = "beirc"; - }); - systems = [ "beirc" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cl-irc" self) (getAttr "cl-ppcre" self) (getAttr "mcclim" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bencode = (build-asdf-system { - pname = "bencode"; - version = "20180228-git"; - asds = [ "bencode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bencode/2018-02-28/cl-bencode-20180228-git.tgz"; - sha256 = "02n9cv5jbgzjwmw11c1a557r62m4i4gmmx38csscbq0cv6vzys1j"; - system = "bencode"; - asd = "bencode"; - }); - systems = [ "bencode" ]; - lispLibs = [ (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bencode-test = (build-asdf-system { - pname = "bencode-test"; - version = "20180228-git"; - asds = [ "bencode-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bencode/2018-02-28/cl-bencode-20180228-git.tgz"; - sha256 = "02n9cv5jbgzjwmw11c1a557r62m4i4gmmx38csscbq0cv6vzys1j"; - system = "bencode-test"; - asd = "bencode"; - }); - systems = [ "bencode-test" ]; - lispLibs = [ (getAttr "bencode" self) (getAttr "check-it" self) (getAttr "hu_dot_dwim_dot_stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bermuda = (build-asdf-system { - pname = "bermuda"; - version = "20150608-git"; - asds = [ "bermuda" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pal/2015-06-08/pal-20150608-git.tgz"; - sha256 = "0kn6jxirrn7wzqymzsi0kx2ivl0nrrcgbl4dm1714s48qw0jwhcw"; - system = "bermuda"; - asd = "bermuda"; - }); - systems = [ "bermuda" ]; - lispLibs = [ (getAttr "pal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bert = (build-asdf-system { - pname = "bert"; - version = "20141106-git"; - asds = [ "bert" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bert/2014-11-06/cl-bert-20141106-git.tgz"; - sha256 = "18cyk63dmcqqwsld4h65mzscgjsc085ws69z097naqm1r70kkygr"; - system = "bert"; - asd = "bert"; - }); - systems = [ "bert" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "erlang-term" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bibtex = (build-asdf-system { - pname = "bibtex"; - version = "20181210-git"; - asds = [ "bibtex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bibtex/2018-12-10/cl-bibtex-20181210-git.tgz"; - sha256 = "1rb4yf1z0vvl6z4kyj0s81kq1pvxwpvbgiaraqllgj1wpf51m78h"; - system = "bibtex"; - asd = "bibtex"; - }); - systems = [ "bibtex" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - big-string = (build-asdf-system { - pname = "big-string"; - version = "20230618-git"; - asds = [ "big-string" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/big-string/2023-06-18/big-string-20230618-git.tgz"; - sha256 = "03w0y3x9sm0fv0dclmrnh55i83nviz7pw7mdg6di05gw03bnslrc"; - system = "big-string"; - asd = "big-string"; - }); - systems = [ "big-string" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bike-internals = (build-asdf-system { - pname = "bike-internals"; - version = "20241012-git"; - asds = [ "bike-internals" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bike/2024-10-12/bike-20241012-git.tgz"; - sha256 = "0ssv4n39wl3i0r8gy2sg6rxfz571jcfsd6db9ndy13drqnhyda6s"; - system = "bike-internals"; - asd = "bike-internals"; - }); - systems = [ "bike-internals" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "flexi-streams" self) (getAttr "global-vars" self) (getAttr "split-sequence" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - binary-io = (build-asdf-system { - pname = "binary-io"; - version = "20201016-git"; - asds = [ "binary-io" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/binary-io/2020-10-16/binary-io-20201016-git.tgz"; - sha256 = "0gxnl12nydh8aslw78jc4cmq8licj342y2f04jalqb4d9m9jbri2"; - system = "binary-io"; - asd = "binary-io"; - }); - systems = [ "binary-io" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "ieee-floats" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - binary-lass = (build-asdf-system { - pname = "binary-lass"; - version = "20241012-git"; - asds = [ "binary-lass" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lass/2024-10-12/lass-20241012-git.tgz"; - sha256 = "1b6a3v763i5fcdxczffd59kh4m73p4ilz6az85apd22apc8lr80z"; - system = "binary-lass"; - asd = "binary-lass"; - }); - systems = [ "binary-lass" ]; - lispLibs = [ (getAttr "lass" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - binary-parser = (build-asdf-system { - pname = "binary-parser"; - version = "20230214-git"; - asds = [ "binary-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/binary-parser/2023-02-14/binary-parser-20230214-git.tgz"; - sha256 = "06lq5iv0ap6qnsrc73rmnr9qirllyz4yxsvimj6ny5wl2hn8i9jl"; - system = "binary-parser"; - asd = "binary-parser"; - }); - systems = [ "binary-parser" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "bitio" self) (getAttr "chipz" self) (getAttr "fast-io" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - binary-search-tree = (build-asdf-system { - pname = "binary-search-tree"; - version = "20220707-git"; - asds = [ "binary-search-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/binary-search-tree/2022-07-07/binary-search-tree-20220707-git.tgz"; - sha256 = "1k7p5dgziwni5yma7q3sbnr23kk2730vzb7ap6knnazpp0smgclf"; - system = "binary-search-tree"; - asd = "binary-search-tree"; - }); - systems = [ "binary-search-tree" ]; - lispLibs = [ (getAttr "mfiano-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - binary-structures = (build-asdf-system { - pname = "binary-structures"; - version = "20241012-git"; - asds = [ "binary-structures" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/binary-structures/2024-10-12/binary-structures-20241012-git.tgz"; - sha256 = "1ygfa4xgd0wliggmmxlqqh9nd7hfsgjwl168l8s9r595vx6fnzmb"; - system = "binary-structures"; - asd = "binary-structures"; - }); - systems = [ "binary-structures" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "form-fiddle" self) (getAttr "nibbles" self) (getAttr "trivial-extensible-sequences" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - binary-types = (build-asdf-system { - pname = "binary-types"; - version = "20130615-git"; - asds = [ "binary-types" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/binary-types/2013-06-15/binary-types-20130615-git.tgz"; - sha256 = "1bh65p9vg2kgh4m8q1a4jiyncnp5prdzh0d0l4pzh3jvfhgbm0gh"; - system = "binary-types"; - asd = "binary-types"; - }); - systems = [ "binary-types" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - binascii = (build-asdf-system { - pname = "binascii"; - version = "20150709-git"; - asds = [ "binascii" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/binascii/2015-07-09/binascii-20150709-git.tgz"; - sha256 = "000rcdl8qshr7n48zq9bzrc4lkjx4ylb3r3w9x9syhiwfla9j4b7"; - system = "binascii"; - asd = "binascii"; - }); - systems = [ "binascii" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - binascii-tests = (build-asdf-system { - pname = "binascii-tests"; - version = "20150709-git"; - asds = [ "binascii-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/binascii/2015-07-09/binascii-20150709-git.tgz"; - sha256 = "000rcdl8qshr7n48zq9bzrc4lkjx4ylb3r3w9x9syhiwfla9j4b7"; - system = "binascii-tests"; - asd = "binascii"; - }); - systems = [ "binascii-tests" ]; - lispLibs = [ (getAttr "binascii" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - binding-arrows = (build-asdf-system { - pname = "binding-arrows"; - version = "20241012-git"; - asds = [ "binding-arrows" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/binding-arrows/2024-10-12/binding-arrows-20241012-git.tgz"; - sha256 = "0kzybw5qlb49czh9v2lnxniz9jzqx306a6lnarfv59x48a7cch22"; - system = "binding-arrows"; - asd = "binding-arrows"; - }); - systems = [ "binding-arrows" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - binding-knx = (build-asdf-system { - pname = "binding-knx"; - version = "20241012-git"; - asds = [ "binding-knx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chipi/2024-10-12/chipi-20241012-git.tgz"; - sha256 = "0xpfclvl5v031cjnjvr3bcfc87rayw624m9yrw35f5r31p8m283g"; - system = "binding-knx"; - asd = "binding-knx"; - }); - systems = [ "binding-knx" ]; - lispLibs = [ (getAttr "chipi" self) (getAttr "knx-conn" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - binfix = (build-asdf-system { - pname = "binfix"; - version = "20190813-git"; - asds = [ "binfix" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/binfix/2019-08-13/binfix-20190813-git.tgz"; - sha256 = "07925kj32y7ppwmz62c08gd0s6yp12s6nz1wh0pzh0ccq9nwgzhz"; - system = "binfix"; - asd = "binfix"; - }); - systems = [ "binfix" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - binomial-heap = (build-asdf-system { - pname = "binomial-heap"; - version = "20130420-git"; - asds = [ "binomial-heap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/binomial-heap/2013-04-20/binomial-heap-20130420-git.tgz"; - sha256 = "1d4jrlkdjdppnvqpqkr7i7djpgmrvrbky4pc1pxvqci5jx7xlkk6"; - system = "binomial-heap"; - asd = "binomial-heap"; - }); - systems = [ "binomial-heap" ]; - lispLibs = [ ]; - meta = {}; - }); - binpack = (build-asdf-system { - pname = "binpack"; - version = "20230214-git"; - asds = [ "binpack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/binpack/2023-02-14/binpack-20230214-git.tgz"; - sha256 = "0cfflx7aqmkzsljjaw0dwk49ii0vxm7d07s4gyrszb7zbpmz0jri"; - system = "binpack"; - asd = "binpack"; - }); - systems = [ "binpack" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = {}; - }); - binpack-test = (build-asdf-system { - pname = "binpack-test"; - version = "20230214-git"; - asds = [ "binpack-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/binpack/2023-02-14/binpack-20230214-git.tgz"; - sha256 = "0cfflx7aqmkzsljjaw0dwk49ii0vxm7d07s4gyrszb7zbpmz0jri"; - system = "binpack-test"; - asd = "binpack-test"; - }); - systems = [ "binpack-test" ]; - lispLibs = [ (getAttr "binpack" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - birch = (build-asdf-system { - pname = "birch"; - version = "20241012-git"; - asds = [ "birch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/birch/2024-10-12/birch-20241012-git.tgz"; - sha256 = "1b24xng92ra7420s3zy44pybk4h7xg4kjwdk35arl46badgi28r1"; - system = "birch"; - asd = "birch"; - }); - systems = [ "birch" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl_plus_ssl" self) (getAttr "flexi-streams" self) (getAttr "split-sequence" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - birch_dot_test = (build-asdf-system { - pname = "birch.test"; - version = "20241012-git"; - asds = [ "birch.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/birch/2024-10-12/birch-20241012-git.tgz"; - sha256 = "1b24xng92ra7420s3zy44pybk4h7xg4kjwdk35arl46badgi28r1"; - system = "birch.test"; - asd = "birch.test"; - }); - systems = [ "birch.test" ]; - lispLibs = [ (getAttr "birch" self) (getAttr "flexi-streams" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bit-ops = (build-asdf-system { - pname = "bit-ops"; - version = "20180228-git"; - asds = [ "bit-ops" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bit-ops/2018-02-28/bit-ops-20180228-git.tgz"; - sha256 = "0rwmm438bgxfl5ab1vnrsxgimxnr3d5kjv9a0yzmlnbg9i2hyhz7"; - system = "bit-ops"; - asd = "bit-ops"; - }); - systems = [ "bit-ops" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "immutable-struct" self) (getAttr "iterate" self) (getAttr "lisp-namespace" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bit-ops_dot_test = (build-asdf-system { - pname = "bit-ops.test"; - version = "20180228-git"; - asds = [ "bit-ops.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bit-ops/2018-02-28/bit-ops-20180228-git.tgz"; - sha256 = "0rwmm438bgxfl5ab1vnrsxgimxnr3d5kjv9a0yzmlnbg9i2hyhz7"; - system = "bit-ops.test"; - asd = "bit-ops.test"; - }); - systems = [ "bit-ops.test" ]; - lispLibs = [ (getAttr "bit-ops" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bit-smasher = (build-asdf-system { - pname = "bit-smasher"; - version = "20221106-git"; - asds = [ "bit-smasher" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bit-smasher/2022-11-06/bit-smasher-20221106-git.tgz"; - sha256 = "1dad4x9sjq45zz8rys6rflsklmw77631r3k4g248ynmaqkdaqjyd"; - system = "bit-smasher"; - asd = "bit-smasher"; - }); - systems = [ "bit-smasher" ]; - lispLibs = [ (getAttr "cl-base58" self) (getAttr "cl-base64" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bit-smasher-test = (build-asdf-system { - pname = "bit-smasher-test"; - version = "20221106-git"; - asds = [ "bit-smasher-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bit-smasher/2022-11-06/bit-smasher-20221106-git.tgz"; - sha256 = "1dad4x9sjq45zz8rys6rflsklmw77631r3k4g248ynmaqkdaqjyd"; - system = "bit-smasher-test"; - asd = "bit-smasher-test"; - }); - systems = [ "bit-smasher-test" ]; - lispLibs = [ (getAttr "bit-smasher" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bitfield = (build-asdf-system { - pname = "bitfield"; - version = "20211230-git"; - asds = [ "bitfield" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bitfield/2021-12-30/bitfield-20211230-git.tgz"; - sha256 = "1137kdj5imc5gj9g6hj4w6ksqnqppgm3knzv7j2f8r5qpfl8rfl2"; - system = "bitfield"; - asd = "bitfield"; - }); - systems = [ "bitfield" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bitfield-schema = (build-asdf-system { - pname = "bitfield-schema"; - version = "20120107-git"; - asds = [ "bitfield-schema" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bitfield-schema/2012-01-07/bitfield-schema-20120107-git.tgz"; - sha256 = "08xkl7rbfhrx8vj98zj1lmhv6pfg2f5gk14xj7qys7mkj2iv4li6"; - system = "bitfield-schema"; - asd = "bitfield-schema"; - }); - systems = [ "bitfield-schema" ]; - lispLibs = [ (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bitio = (build-asdf-system { - pname = "bitio"; - version = "20220220-git"; - asds = [ "bitio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bitio/2022-02-20/bitio-20220220-git.tgz"; - sha256 = "0z2yn19nxg46j274nxzry255z86p0y3p68s1f2sg7rx9y2nx3rjg"; - system = "bitio"; - asd = "bitio"; - }); - systems = [ "bitio" ]; - lispLibs = [ (getAttr "checkl" self) (getAttr "cl-package-locks" self) (getAttr "fast-io" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bk-tree = (build-asdf-system { - pname = "bk-tree"; - version = "20130420-git"; - asds = [ "bk-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bk-tree/2013-04-20/bk-tree-20130420-git.tgz"; - sha256 = "1nrz6fwzvkzvs6ipc5rgas77p5hv5bnaw2in5760v240gg7lxqzz"; - system = "bk-tree"; - asd = "bk-tree"; - }); - systems = [ "bk-tree" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bknr_dot_data_dot_impex = (build-asdf-system { - pname = "bknr.data.impex"; - version = "20220220-git"; - asds = [ "bknr.data.impex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; - sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; - system = "bknr.data.impex"; - asd = "bknr.data.impex"; - }); - systems = [ "bknr.data.impex" ]; - lispLibs = [ (getAttr "bknr_dot_datastore" self) (getAttr "bknr_dot_impex" self) (getAttr "bknr_dot_indices" self) (getAttr "bknr_dot_utils" self) (getAttr "cl-interpol" self) (getAttr "unit-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bknr_dot_datastore = (build-asdf-system { - pname = "bknr.datastore"; - version = "20220220-git"; - asds = [ "bknr.datastore" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; - sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; - system = "bknr.datastore"; - asd = "bknr.datastore"; - }); - systems = [ "bknr.datastore" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bknr_dot_indices" self) (getAttr "bknr_dot_utils" self) (getAttr "cl-interpol" self) (getAttr "closer-mop" self) (getAttr "trivial-utf-8" self) (getAttr "unit-test" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bknr_dot_impex = (build-asdf-system { - pname = "bknr.impex"; - version = "20220220-git"; - asds = [ "bknr.impex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; - sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; - system = "bknr.impex"; - asd = "bknr.impex"; - }); - systems = [ "bknr.impex" ]; - lispLibs = [ (getAttr "bknr_dot_indices" self) (getAttr "bknr_dot_utils" self) (getAttr "bknr_dot_xml" self) (getAttr "cl-interpol" self) (getAttr "closer-mop" self) (getAttr "cxml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bknr_dot_indices = (build-asdf-system { - pname = "bknr.indices"; - version = "20220220-git"; - asds = [ "bknr.indices" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; - sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; - system = "bknr.indices"; - asd = "bknr.indices"; - }); - systems = [ "bknr.indices" ]; - lispLibs = [ (getAttr "bknr_dot_skip-list" self) (getAttr "bknr_dot_utils" self) (getAttr "cl-interpol" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bknr_dot_modules = (build-asdf-system { - pname = "bknr.modules"; - version = "20140713-git"; - asds = [ "bknr.modules" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-web/2014-07-13/bknr-web-20140713-git.tgz"; - sha256 = "1m73z0hv7qsc9yddrg8zs7n3zmn9h64v4d62239wrvfnmzqk75x2"; - system = "bknr.modules"; - asd = "bknr.modules"; - }); - systems = [ "bknr.modules" ]; - lispLibs = [ (getAttr "bknr_dot_utils" self) (getAttr "bknr_dot_web" self) (getAttr "cl-gd" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "cl-smtp" self) (getAttr "closer-mop" self) (getAttr "cxml" self) (getAttr "md5" self) (getAttr "parenscript" self) (getAttr "puri" self) (getAttr "stem" self) (getAttr "unit-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bknr_dot_skip-list = (build-asdf-system { - pname = "bknr.skip-list"; - version = "20220220-git"; - asds = [ "bknr.skip-list" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; - sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; - system = "bknr.skip-list"; - asd = "bknr.skip-list"; - }); - systems = [ "bknr.skip-list" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bknr_dot_skip-list_dot_test = (build-asdf-system { - pname = "bknr.skip-list.test"; - version = "20220220-git"; - asds = [ "bknr.skip-list.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; - sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; - system = "bknr.skip-list.test"; - asd = "bknr.skip-list"; - }); - systems = [ "bknr.skip-list.test" ]; - lispLibs = [ (getAttr "bknr_dot_skip-list" self) (getAttr "unit-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bknr_dot_utils = (build-asdf-system { - pname = "bknr.utils"; - version = "20220220-git"; - asds = [ "bknr.utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; - sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; - system = "bknr.utils"; - asd = "bknr.utils"; - }); - systems = [ "bknr.utils" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "md5" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bknr_dot_web = (build-asdf-system { - pname = "bknr.web"; - version = "20140713-git"; - asds = [ "bknr.web" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-web/2014-07-13/bknr-web-20140713-git.tgz"; - sha256 = "1m73z0hv7qsc9yddrg8zs7n3zmn9h64v4d62239wrvfnmzqk75x2"; - system = "bknr.web"; - asd = "bknr.web"; - }); - systems = [ "bknr.web" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bknr_dot_data_dot_impex" self) (getAttr "bknr_dot_datastore" self) (getAttr "bknr_dot_utils" self) (getAttr "bknr_dot_xml" self) (getAttr "cl-gd" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "cxml" self) (getAttr "drakma" self) (getAttr "hunchentoot" self) (getAttr "md5" self) (getAttr "parenscript" self) (getAttr "puri" self) (getAttr "unit-test" self) (getAttr "usocket" self) (getAttr "xhtmlgen" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bknr_dot_xml = (build-asdf-system { - pname = "bknr.xml"; - version = "20220220-git"; - asds = [ "bknr.xml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; - sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; - system = "bknr.xml"; - asd = "bknr.xml"; - }); - systems = [ "bknr.xml" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "cxml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - black-tie = (build-asdf-system { - pname = "black-tie"; - version = "20220707-git"; - asds = [ "black-tie" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/black-tie/2022-07-07/black-tie-20220707-git.tgz"; - sha256 = "0a1zczxp4wkqs4cmwc4rnsgwwc2h4zqmg58cjykfzz4jh31fa43a"; - system = "black-tie"; - asd = "black-tie"; - }); - systems = [ "black-tie" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - blackbird = (build-asdf-system { - pname = "blackbird"; - version = "20241012-git"; - asds = [ "blackbird" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/blackbird/2024-10-12/blackbird-20241012-git.tgz"; - sha256 = "0bqg8sn816qfar410w2c2k07vqh9sig8zbkvlmwj1bk33snvmam8"; - system = "blackbird"; - asd = "blackbird"; - }); - systems = [ "blackbird" ]; - lispLibs = [ (getAttr "vom" self) ]; - meta = {}; - }); - blackbird-test = (build-asdf-system { - pname = "blackbird-test"; - version = "20241012-git"; - asds = [ "blackbird-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/blackbird/2024-10-12/blackbird-20241012-git.tgz"; - sha256 = "0bqg8sn816qfar410w2c2k07vqh9sig8zbkvlmwj1bk33snvmam8"; - system = "blackbird-test"; - asd = "blackbird-test"; - }); - systems = [ "blackbird-test" ]; - lispLibs = [ (getAttr "blackbird" self) (getAttr "cl-async" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - blas = (build-asdf-system { - pname = "blas"; - version = "20231021-git"; - asds = [ "blas" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "blas"; - asd = "blas"; - }); - systems = [ "blas" ]; - lispLibs = [ (getAttr "blas-complex" self) (getAttr "blas-package" self) (getAttr "blas-real" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - blas-complex = (build-asdf-system { - pname = "blas-complex"; - version = "20231021-git"; - asds = [ "blas-complex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "blas-complex"; - asd = "blas-complex"; - }); - systems = [ "blas-complex" ]; - lispLibs = [ (getAttr "blas-real" self) (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - blas-hompack = (build-asdf-system { - pname = "blas-hompack"; - version = "20231021-git"; - asds = [ "blas-hompack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "blas-hompack"; - asd = "blas-hompack"; - }); - systems = [ "blas-hompack" ]; - lispLibs = [ (getAttr "blas-package" self) (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - blas-package = (build-asdf-system { - pname = "blas-package"; - version = "20231021-git"; - asds = [ "blas-package" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "blas-package"; - asd = "blas-package"; - }); - systems = [ "blas-package" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - blas-real = (build-asdf-system { - pname = "blas-real"; - version = "20231021-git"; - asds = [ "blas-real" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "blas-real"; - asd = "blas-real"; - }); - systems = [ "blas-real" ]; - lispLibs = [ (getAttr "blas-hompack" self) (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - blocks-world = (build-asdf-system { - pname = "blocks-world"; - version = "20120305-git"; - asds = [ "blocks-world" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/atdoc/2012-03-05/atdoc-20120305-git.tgz"; - sha256 = "1w54phadjj00sy5qz5n0hmhzyjrx26h9hw06756zdpfbzk4f5il6"; - system = "blocks-world"; - asd = "blocks-world"; - }); - systems = [ "blocks-world" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bmas = (build-asdf-system { - pname = "bmas"; - version = "20241012-git"; - asds = [ "bmas" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bmas/2024-10-12/cl-bmas-20241012-git.tgz"; - sha256 = "1j4wniwcxz4kqzw7q3ac8rpz2xhd0qfdgl5dylswh02ifdgq9z4m"; - system = "bmas"; - asd = "bmas"; - }); - systems = [ "bmas" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-autowrap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bmp-test = (build-asdf-system { - pname = "bmp-test"; - version = "20211020-git"; - asds = [ "bmp-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-png/2021-10-20/cl-png-20211020-git.tgz"; - sha256 = "17xcb9ps5vf3if61blmx7cpfrz3gsw7jk8d5zv3f4cq8jrriqdx4"; - system = "bmp-test"; - asd = "bmp-test"; - }); - systems = [ "bmp-test" ]; - lispLibs = [ (getAttr "png" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bnf = (build-asdf-system { - pname = "bnf"; - version = "20220220-git"; - asds = [ "bnf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bnf/2022-02-20/bnf-20220220-git.tgz"; - sha256 = "1kr6k9qs9bbza591hi1c2mlxqd5yz3nrvyd3cw7139iz1z2m7dbg"; - system = "bnf"; - asd = "bnf"; - }); - systems = [ "bnf" ]; - lispLibs = [ (getAttr "trestrul" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bnf_dot_test = (build-asdf-system { - pname = "bnf.test"; - version = "20220220-git"; - asds = [ "bnf.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bnf/2022-02-20/bnf-20220220-git.tgz"; - sha256 = "1kr6k9qs9bbza591hi1c2mlxqd5yz3nrvyd3cw7139iz1z2m7dbg"; - system = "bnf.test"; - asd = "bnf.test"; - }); - systems = [ "bnf.test" ]; - lispLibs = [ (getAttr "bnf" self) (getAttr "jingoh" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bobbin = (build-asdf-system { - pname = "bobbin"; - version = "20201016-hg"; - asds = [ "bobbin" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bobbin/2020-10-16/bobbin-20201016-hg.tgz"; - sha256 = "1yvx7d0cx5b119r4aays2rck33088bp7spaydnvkc329hfq1ahc2"; - system = "bobbin"; - asd = "bobbin"; - }); - systems = [ "bobbin" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-blobs-support = (build-asdf-system { - pname = "bodge-blobs-support"; - version = "stable-git"; - asds = [ "bodge-blobs-support" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-blobs-support/2020-10-16/bodge-blobs-support-stable-git.tgz"; - sha256 = "02nd1x6y1akp1ymv1y4z9ympwbnpd1drwi4f86xbjszxqff6jyj8"; - system = "bodge-blobs-support"; - asd = "bodge-blobs-support"; - }); - systems = [ "bodge-blobs-support" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-chipmunk = (build-asdf-system { - pname = "bodge-chipmunk"; - version = "stable-git"; - asds = [ "bodge-chipmunk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-chipmunk/2020-10-16/bodge-chipmunk-stable-git.tgz"; - sha256 = "06zkia7rrhn1961jmayyvdbbbnf2rnr84lbd1x6gq8psfb2rif2f"; - system = "bodge-chipmunk"; - asd = "bodge-chipmunk"; - }); - systems = [ "bodge-chipmunk" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-c-ref" self) (getAttr "claw" self) (getAttr "claw-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-concurrency = (build-asdf-system { - pname = "bodge-concurrency"; - version = "stable-git"; - asds = [ "bodge-concurrency" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-concurrency/2020-10-16/bodge-concurrency-stable-git.tgz"; - sha256 = "06v2h7vassp5v50qsqxkmshcrlrzlhqaga4z7lnidfniw7f8d5vd"; - system = "bodge-concurrency"; - asd = "bodge-concurrency"; - }); - systems = [ "bodge-concurrency" ]; - lispLibs = [ (getAttr "bodge-memory" self) (getAttr "bodge-queue" self) (getAttr "bodge-utilities" self) (getAttr "bordeaux-threads" self) (getAttr "cl-flow" self) (getAttr "cl-muth" self) (getAttr "simple-flow-dispatcher" self) (getAttr "trivial-main-thread" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-glad = (build-asdf-system { - pname = "bodge-glad"; - version = "stable-git"; - asds = [ "bodge-glad" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-glad/2020-10-16/bodge-glad-stable-git.tgz"; - sha256 = "0ghrg0z5pj36igp5wpvp1iwnvjbca3wfb60kvirhv3l9ww51jg9g"; - system = "bodge-glad"; - asd = "bodge-glad"; - }); - systems = [ "bodge-glad" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-glfw = (build-asdf-system { - pname = "bodge-glfw"; - version = "stable-git"; - asds = [ "bodge-glfw" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-glfw/2020-10-16/bodge-glfw-stable-git.tgz"; - sha256 = "1xjg75grndl2mbfql1g2qgx810kg6wxrnhxb406m9lisd112i0m8"; - system = "bodge-glfw"; - asd = "bodge-glfw"; - }); - systems = [ "bodge-glfw" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-c-ref" self) (getAttr "claw" self) (getAttr "claw-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-heap = (build-asdf-system { - pname = "bodge-heap"; - version = "stable-git"; - asds = [ "bodge-heap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-heap/2020-10-16/bodge-heap-stable-git.tgz"; - sha256 = "1ngi9ccr9iz93mm3b4hgh2fj39vqpjrpkcfza5vly16z3r7gxca4"; - system = "bodge-heap"; - asd = "bodge-heap"; - }); - systems = [ "bodge-heap" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-host = (build-asdf-system { - pname = "bodge-host"; - version = "stable-git"; - asds = [ "bodge-host" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-host/2021-12-09/bodge-host-stable-git.tgz"; - sha256 = "0piayirpbh91klrk3pg0g1vxhlk8yxvbr2wv923awdalwy0fn73n"; - system = "bodge-host"; - asd = "bodge-host"; - }); - systems = [ "bodge-host" ]; - lispLibs = [ (getAttr "bodge-concurrency" self) (getAttr "bodge-glfw" self) (getAttr "bodge-libc-essentials" self) (getAttr "bodge-math" self) (getAttr "bodge-utilities" self) (getAttr "cffi-c-ref" self) (getAttr "float-features" self) (getAttr "glfw-blob" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-libc-essentials = (build-asdf-system { - pname = "bodge-libc-essentials"; - version = "stable-git"; - asds = [ "bodge-libc-essentials" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-libc-essentials/2020-10-16/bodge-libc-essentials-stable-git.tgz"; - sha256 = "1nkjhkaap78xk9rkvnnnkchphiz0qwrsfp4jsvcl6mvv3rb4gp2k"; - system = "bodge-libc-essentials"; - asd = "bodge-libc-essentials"; - }); - systems = [ "bodge-libc-essentials" ]; - lispLibs = [ (getAttr "claw" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-math = (build-asdf-system { - pname = "bodge-math"; - version = "stable-git"; - asds = [ "bodge-math" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-math/2020-10-16/bodge-math-stable-git.tgz"; - sha256 = "0r3vnl9lywn4ksy34apcv6j825qp7l1naddawr14v4lwacndb80v"; - system = "bodge-math"; - asd = "bodge-math"; - }); - systems = [ "bodge-math" ]; - lispLibs = [ (getAttr "bodge-utilities" self) (getAttr "rtg-math" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-memory = (build-asdf-system { - pname = "bodge-memory"; - version = "stable-git"; - asds = [ "bodge-memory" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-memory/2020-10-16/bodge-memory-stable-git.tgz"; - sha256 = "19fn3dw5z6f2kpar0jx7ysy5zvqjv7yv0ca7njgaam3p891yy2j9"; - system = "bodge-memory"; - asd = "bodge-memory"; - }); - systems = [ "bodge-memory" ]; - lispLibs = [ (getAttr "bodge-utilities" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-nanovg = (build-asdf-system { - pname = "bodge-nanovg"; - version = "stable-git"; - asds = [ "bodge-nanovg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-nanovg/2020-10-16/bodge-nanovg-stable-git.tgz"; - sha256 = "0cg4rlsddjrn0ps891n29xnd14xiis20ka5gafbz9npbj6nrc4v1"; - system = "bodge-nanovg"; - asd = "bodge-nanovg"; - }); - systems = [ "bodge-nanovg" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-c-ref" self) (getAttr "claw" self) (getAttr "claw-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-nuklear = (build-asdf-system { - pname = "bodge-nuklear"; - version = "stable-git"; - asds = [ "bodge-nuklear" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-nuklear/2020-10-16/bodge-nuklear-stable-git.tgz"; - sha256 = "15q89dz2zi99yyxhb90wyydy24y2lj5xm2mzh1mrw4v8rz9aqhc2"; - system = "bodge-nuklear"; - asd = "bodge-nuklear"; - }); - systems = [ "bodge-nuklear" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-c-ref" self) (getAttr "claw" self) (getAttr "claw-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-ode = (build-asdf-system { - pname = "bodge-ode"; - version = "stable-git"; - asds = [ "bodge-ode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-ode/2020-10-16/bodge-ode-stable-git.tgz"; - sha256 = "1c051ljn5x7ssysia7lil0ykjdnbx8dfkr45ck77plv39acgicbs"; - system = "bodge-ode"; - asd = "bodge-ode"; - }); - systems = [ "bodge-ode" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-c-ref" self) (getAttr "claw" self) (getAttr "claw-utils" self) (getAttr "float-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-openal = (build-asdf-system { - pname = "bodge-openal"; - version = "stable-git"; - asds = [ "bodge-openal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-openal/2020-10-16/bodge-openal-stable-git.tgz"; - sha256 = "0051pwifygj1ijv5b39ldmfrka2yrj8rpap04bw3w9cckbkp6bnw"; - system = "bodge-openal"; - asd = "bodge-openal"; - }); - systems = [ "bodge-openal" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "claw" self) (getAttr "claw-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-queue = (build-asdf-system { - pname = "bodge-queue"; - version = "stable-git"; - asds = [ "bodge-queue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-queue/2020-10-16/bodge-queue-stable-git.tgz"; - sha256 = "0f4252i8pfy5s4v7w1bpjawysn4cw7di405mqsx2h7skv27hvpz6"; - system = "bodge-queue"; - asd = "bodge-queue"; - }); - systems = [ "bodge-queue" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-sndfile = (build-asdf-system { - pname = "bodge-sndfile"; - version = "stable-git"; - asds = [ "bodge-sndfile" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-sndfile/2020-10-16/bodge-sndfile-stable-git.tgz"; - sha256 = "0chdasp4zvr5n34x037lhymh90wg5xwbpr5flwj8aw0cw2nlg485"; - system = "bodge-sndfile"; - asd = "bodge-sndfile"; - }); - systems = [ "bodge-sndfile" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bodge-libc-essentials" self) (getAttr "cffi" self) (getAttr "cffi-c-ref" self) (getAttr "claw" self) (getAttr "claw-utils" self) (getAttr "static-vectors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bodge-utilities = (build-asdf-system { - pname = "bodge-utilities"; - version = "stable-git"; - asds = [ "bodge-utilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bodge-utilities/2022-07-07/bodge-utilities-stable-git.tgz"; - sha256 = "0jmz7zb5ahg2kfd5nrh9nb7dda5szamjv7iv9skgcvf7rwn8qf0g"; - system = "bodge-utilities"; - asd = "bodge-utilities"; - }); - systems = [ "bodge-utilities" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "claw" self) (getAttr "dissect" self) (getAttr "local-time" self) (getAttr "log4cl" self) (getAttr "split-sequence" self) (getAttr "static-vectors" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bordeaux-fft = (build-asdf-system { - pname = "bordeaux-fft"; - version = "20150608-http"; - asds = [ "bordeaux-fft" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bordeaux-fft/2015-06-08/bordeaux-fft-20150608-http.tgz"; - sha256 = "0kmz0wv34p8wixph5i6vj6p60xa48fflh9aq6kismlb0q4a1amp3"; - system = "bordeaux-fft"; - asd = "bordeaux-fft"; - }); - systems = [ "bordeaux-fft" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bordeaux-threads = (build-asdf-system { - pname = "bordeaux-threads"; - version = "v0.9.4"; - asds = [ "bordeaux-threads" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bordeaux-threads/2024-10-12/bordeaux-threads-v0.9.4.tgz"; - sha256 = "1ds1aa3rd38hq5i1nwd9qi8icxmdag0shcwwsf7km91v9214385d"; - system = "bordeaux-threads"; - asd = "bordeaux-threads"; - }); - systems = [ "bordeaux-threads" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "global-vars" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - bourbaki = (build-asdf-system { - pname = "bourbaki"; - version = "20110110-http"; - asds = [ "bourbaki" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bourbaki/2011-01-10/bourbaki-20110110-http.tgz"; - sha256 = "0d222kjk1h60467bkjpxglds3gykily5pyrnb45yvx86shkiv4lp"; - system = "bourbaki"; - asd = "bourbaki"; - }); - systems = [ "bourbaki" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bp = (build-asdf-system { - pname = "bp"; - version = "20231021-git"; - asds = [ "bp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bp/2023-10-21/bp-20231021-git.tgz"; - sha256 = "1l58bf2fq0807id4cs39sajsfw0z7zz4gxb2vpcvfa9nxcbyziqx"; - system = "bp"; - asd = "bp"; - }); - systems = [ "bp" ]; - lispLibs = [ (getAttr "aserve" self) (getAttr "cffi" self) (getAttr "ironclad" self) (getAttr "jsown" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bst = (build-asdf-system { - pname = "bst"; - version = "20221106-git"; - asds = [ "bst" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bst/2022-11-06/bst-20221106-git.tgz"; - sha256 = "0y052jf3gkqhb7rfx72961kg42dnqhmizk7cxlv87d1jr2906d1d"; - system = "bst"; - asd = "bst"; - }); - systems = [ "bst" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bt-semaphore = (build-asdf-system { - pname = "bt-semaphore"; - version = "20180711-git"; - asds = [ "bt-semaphore" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bt-semaphore/2018-07-11/bt-semaphore-20180711-git.tgz"; - sha256 = "0rl7yp36225z975hg069pywwlpchwn4086cgxwsi2db5mhghpr7l"; - system = "bt-semaphore"; - asd = "bt-semaphore"; - }); - systems = [ "bt-semaphore" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bt-semaphore-test = (build-asdf-system { - pname = "bt-semaphore-test"; - version = "20180711-git"; - asds = [ "bt-semaphore-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bt-semaphore/2018-07-11/bt-semaphore-20180711-git.tgz"; - sha256 = "0rl7yp36225z975hg069pywwlpchwn4086cgxwsi2db5mhghpr7l"; - system = "bt-semaphore-test"; - asd = "bt-semaphore-test"; - }); - systems = [ "bt-semaphore-test" ]; - lispLibs = [ (getAttr "bt-semaphore" self) (getAttr "clunit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - btrie = (build-asdf-system { - pname = "btrie"; - version = "20140713-git"; - asds = [ "btrie" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/btrie/2014-07-13/btrie-20140713-git.tgz"; - sha256 = "0f1rs2zlpi2bcyba951h3cnyz2mfsxr2i6icmqbam5acqjdrmp30"; - system = "btrie"; - asd = "btrie"; - }); - systems = [ "btrie" ]; - lispLibs = [ (getAttr "arnesi" self) (getAttr "lift" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - btrie-tests = (build-asdf-system { - pname = "btrie-tests"; - version = "20140713-git"; - asds = [ "btrie-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/btrie/2014-07-13/btrie-20140713-git.tgz"; - sha256 = "0f1rs2zlpi2bcyba951h3cnyz2mfsxr2i6icmqbam5acqjdrmp30"; - system = "btrie-tests"; - asd = "btrie"; - }); - systems = [ "btrie-tests" ]; - lispLibs = [ (getAttr "btrie" self) (getAttr "lift" self) (getAttr "metabang-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bubble-operator-upwards = (build-asdf-system { - pname = "bubble-operator-upwards"; - version = "1.1"; - asds = [ "bubble-operator-upwards" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bubble-operator-upwards/2023-10-21/bubble-operator-upwards_1.1.tgz"; - sha256 = "1k6rvhlx4z0xb460dyg6blvqkwxakvqxslky69ld8p2yni1qar5p"; - system = "bubble-operator-upwards"; - asd = "bubble-operator-upwards"; - }); - systems = [ "bubble-operator-upwards" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bubble-operator-upwards__tests = (build-asdf-system { - pname = "bubble-operator-upwards_tests"; - version = "1.1"; - asds = [ "bubble-operator-upwards_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bubble-operator-upwards/2023-10-21/bubble-operator-upwards_1.1.tgz"; - sha256 = "1k6rvhlx4z0xb460dyg6blvqkwxakvqxslky69ld8p2yni1qar5p"; - system = "bubble-operator-upwards_tests"; - asd = "bubble-operator-upwards_tests"; - }); - systems = [ "bubble-operator-upwards_tests" ]; - lispLibs = [ (getAttr "bubble-operator-upwards" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - buildapp = (build-asdf-system { - pname = "buildapp"; - version = "1.5.6"; - asds = [ "buildapp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/buildapp/2015-12-18/buildapp-1.5.6.tgz"; - sha256 = "020ipjfqa3l8skd97cj5kq837wgpj28ygfxnkv64cnjrlbnzh161"; - system = "buildapp"; - asd = "buildapp"; - }); - systems = [ "buildapp" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - buildnode = (build-asdf-system { - pname = "buildnode"; - version = "20170403-git"; - asds = [ "buildnode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; - sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; - system = "buildnode"; - asd = "buildnode"; - }); - systems = [ "buildnode" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "closure-html" self) (getAttr "collectors" self) (getAttr "cxml" self) (getAttr "flexi-streams" self) (getAttr "iterate" self) (getAttr "split-sequence" self) (getAttr "swank" self) (getAttr "symbol-munger" self) ]; - meta = {}; - }); - buildnode-excel = (build-asdf-system { - pname = "buildnode-excel"; - version = "20170403-git"; - asds = [ "buildnode-excel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; - sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; - system = "buildnode-excel"; - asd = "buildnode-excel"; - }); - systems = [ "buildnode-excel" ]; - lispLibs = [ (getAttr "buildnode" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - buildnode-html5 = (build-asdf-system { - pname = "buildnode-html5"; - version = "20170403-git"; - asds = [ "buildnode-html5" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; - sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; - system = "buildnode-html5"; - asd = "buildnode-html5"; - }); - systems = [ "buildnode-html5" ]; - lispLibs = [ (getAttr "buildnode" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - buildnode-kml = (build-asdf-system { - pname = "buildnode-kml"; - version = "20170403-git"; - asds = [ "buildnode-kml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; - sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; - system = "buildnode-kml"; - asd = "buildnode-kml"; - }); - systems = [ "buildnode-kml" ]; - lispLibs = [ (getAttr "buildnode" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - buildnode-test = (build-asdf-system { - pname = "buildnode-test"; - version = "20170403-git"; - asds = [ "buildnode-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; - sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; - system = "buildnode-test"; - asd = "buildnode"; - }); - systems = [ "buildnode-test" ]; - lispLibs = [ (getAttr "buildnode" self) (getAttr "buildnode-xhtml" self) (getAttr "lisp-unit2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - buildnode-xhtml = (build-asdf-system { - pname = "buildnode-xhtml"; - version = "20170403-git"; - asds = [ "buildnode-xhtml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; - sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; - system = "buildnode-xhtml"; - asd = "buildnode-xhtml"; - }); - systems = [ "buildnode-xhtml" ]; - lispLibs = [ (getAttr "buildnode" self) ]; - meta = {}; - }); - buildnode-xul = (build-asdf-system { - pname = "buildnode-xul"; - version = "20170403-git"; - asds = [ "buildnode-xul" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; - sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; - system = "buildnode-xul"; - asd = "buildnode-xul"; - }); - systems = [ "buildnode-xul" ]; - lispLibs = [ (getAttr "buildnode" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - burgled-batteries = (build-asdf-system { - pname = "burgled-batteries"; - version = "20160825-git"; - asds = [ "burgled-batteries" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/burgled-batteries/2016-08-25/burgled-batteries-20160825-git.tgz"; - sha256 = "080ff1yrmfb87pqq1jqr35djjkh3fh8i6cbhv3d1md5qy7hhgdaj"; - system = "burgled-batteries"; - asd = "burgled-batteries"; - }); - systems = [ "burgled-batteries" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-fad" self) (getAttr "parse-declarations-1_dot_0" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - burgled-batteries-tests = (build-asdf-system { - pname = "burgled-batteries-tests"; - version = "20160825-git"; - asds = [ "burgled-batteries-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/burgled-batteries/2016-08-25/burgled-batteries-20160825-git.tgz"; - sha256 = "080ff1yrmfb87pqq1jqr35djjkh3fh8i6cbhv3d1md5qy7hhgdaj"; - system = "burgled-batteries-tests"; - asd = "burgled-batteries-tests"; - }); - systems = [ "burgled-batteries-tests" ]; - lispLibs = [ (getAttr "burgled-batteries" self) (getAttr "cl-quickcheck" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - burgled-batteries_dot_syntax = (build-asdf-system { - pname = "burgled-batteries.syntax"; - version = "20210531-git"; - asds = [ "burgled-batteries.syntax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/burgled-batteries.syntax/2021-05-31/burgled-batteries.syntax-20210531-git.tgz"; - sha256 = "1hx8w74cgx1qbk6r2p7lzygjqxs5mzxh7w73zrmdibny64akir9a"; - system = "burgled-batteries.syntax"; - asd = "burgled-batteries.syntax"; - }); - systems = [ "burgled-batteries.syntax" ]; - lispLibs = [ (getAttr "burgled-batteries" self) (getAttr "esrap" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - burgled-batteries_dot_syntax-test = (build-asdf-system { - pname = "burgled-batteries.syntax-test"; - version = "20210531-git"; - asds = [ "burgled-batteries.syntax-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/burgled-batteries.syntax/2021-05-31/burgled-batteries.syntax-20210531-git.tgz"; - sha256 = "1hx8w74cgx1qbk6r2p7lzygjqxs5mzxh7w73zrmdibny64akir9a"; - system = "burgled-batteries.syntax-test"; - asd = "burgled-batteries.syntax-test"; - }); - systems = [ "burgled-batteries.syntax-test" ]; - lispLibs = [ (getAttr "burgled-batteries_dot_syntax" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bus = (build-asdf-system { - pname = "bus"; - version = "master-fe503896-git"; - asds = [ "bus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "bus"; - asd = "bus"; - }); - systems = [ "bus" ]; - lispLibs = [ (getAttr "gwl-graphics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bytecurry_dot_asdf-ext = (build-asdf-system { - pname = "bytecurry.asdf-ext"; - version = "20150505-git"; - asds = [ "bytecurry.asdf-ext" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bytecurry.asdf-ext/2015-05-05/bytecurry.asdf-ext-20150505-git.tgz"; - sha256 = "07w2lz9mq35sgzzvmz9084l1sia40zkhlvfblkpzxfwyzr6cxrxa"; - system = "bytecurry.asdf-ext"; - asd = "bytecurry.asdf-ext"; - }); - systems = [ "bytecurry.asdf-ext" ]; - lispLibs = [ (getAttr "asdf-package-system" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - bytecurry_dot_mocks = (build-asdf-system { - pname = "bytecurry.mocks"; - version = "20200325-git"; - asds = [ "bytecurry.mocks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bytecurry.mocks/2020-03-25/bytecurry.mocks-20200325-git.tgz"; - sha256 = "0md2j6iggmfm1v7nzcmz7f0xy2jxrsg77iszpisdzmwnijfy8ks0"; - system = "bytecurry.mocks"; - asd = "bytecurry.mocks"; - }); - systems = [ "bytecurry.mocks" ]; - lispLibs = [ (getAttr "asdf-package-system" self) (getAttr "bytecurry_dot_asdf-ext" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - c2ffi-blob = (build-asdf-system { - pname = "c2ffi-blob"; - version = "stable-git"; - asds = [ "c2ffi-blob" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/c2ffi-blob/2020-10-16/c2ffi-blob-stable-git.tgz"; - sha256 = "1rk89nycdvcb4a50zm3wdmrbz8w5xk4jgvjg2wib1dnslwnwdivc"; - system = "c2ffi-blob"; - asd = "c2ffi-blob"; - }); - systems = [ "c2ffi-blob" ]; - lispLibs = [ (getAttr "claw-support" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cacau = (build-asdf-system { - pname = "cacau"; - version = "20200610-git"; - asds = [ "cacau" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cacau/2020-06-10/cacau-20200610-git.tgz"; - sha256 = "0m8v1xw68cr5ldv045rxgvnhigr4iahh7v6v32z6xlq2sj6r55x0"; - system = "cacau"; - asd = "cacau"; - }); - systems = [ "cacau" ]; - lispLibs = [ (getAttr "assertion-error" self) (getAttr "eventbus" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cacau-asdf = (build-asdf-system { - pname = "cacau-asdf"; - version = "20200610-git"; - asds = [ "cacau-asdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cacau/2020-06-10/cacau-20200610-git.tgz"; - sha256 = "0m8v1xw68cr5ldv045rxgvnhigr4iahh7v6v32z6xlq2sj6r55x0"; - system = "cacau-asdf"; - asd = "cacau-asdf"; - }); - systems = [ "cacau-asdf" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cacau-examples-asdf-integration = (build-asdf-system { - pname = "cacau-examples-asdf-integration"; - version = "20200610-git"; - asds = [ "cacau-examples-asdf-integration" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cacau/2020-06-10/cacau-20200610-git.tgz"; - sha256 = "0m8v1xw68cr5ldv045rxgvnhigr4iahh7v6v32z6xlq2sj6r55x0"; - system = "cacau-examples-asdf-integration"; - asd = "cacau-examples-asdf-integration"; - }); - systems = [ "cacau-examples-asdf-integration" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cacau-examples-asdf-integration-test = (build-asdf-system { - pname = "cacau-examples-asdf-integration-test"; - version = "20200610-git"; - asds = [ "cacau-examples-asdf-integration-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cacau/2020-06-10/cacau-20200610-git.tgz"; - sha256 = "0m8v1xw68cr5ldv045rxgvnhigr4iahh7v6v32z6xlq2sj6r55x0"; - system = "cacau-examples-asdf-integration-test"; - asd = "cacau-examples-asdf-integration-test"; - }); - systems = [ "cacau-examples-asdf-integration-test" ]; - lispLibs = [ (getAttr "assert-p" self) (getAttr "cacau" self) (getAttr "cacau-asdf" self) (getAttr "cacau-examples-asdf-integration" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cacau-test = (build-asdf-system { - pname = "cacau-test"; - version = "20200610-git"; - asds = [ "cacau-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cacau/2020-06-10/cacau-20200610-git.tgz"; - sha256 = "0m8v1xw68cr5ldv045rxgvnhigr4iahh7v6v32z6xlq2sj6r55x0"; - system = "cacau-test"; - asd = "cacau-test"; - }); - systems = [ "cacau-test" ]; - lispLibs = [ (getAttr "assert-p" self) (getAttr "cacau" self) (getAttr "cacau-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cache-while = (build-asdf-system { - pname = "cache-while"; - version = "20210807-git"; - asds = [ "cache-while" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cache-while/2021-08-07/cache-while-20210807-git.tgz"; - sha256 = "1qil68rfn5irmkb0jk1f6g1zy80wgc3skl8cr4rfgh7ywgm5izx3"; - system = "cache-while"; - asd = "cache-while"; - }); - systems = [ "cache-while" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cacle = (build-asdf-system { - pname = "cacle"; - version = "20190521-git"; - asds = [ "cacle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cacle/2019-05-21/cacle-20190521-git.tgz"; - sha256 = "0h0dk0sfkfl8g0sbrs76ydb9l4znssqhx8nc5k1sg7zxpni5a4qy"; - system = "cacle"; - asd = "cacle"; - }); - systems = [ "cacle" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - calispel = (build-asdf-system { - pname = "calispel"; - version = "20170830-git"; - asds = [ "calispel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/calispel/2017-08-30/calispel-20170830-git.tgz"; - sha256 = "08bmf3pi7n5hadpmqqkg65cxcj6kbvm997wcs1f53ml1nb79d9z8"; - system = "calispel"; - asd = "calispel"; - }); - systems = [ "calispel" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "jpl-queues" self) (getAttr "jpl-util" self) ]; - meta = {}; - }); - calispel-test = (build-asdf-system { - pname = "calispel-test"; - version = "20170830-git"; - asds = [ "calispel-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/calispel/2017-08-30/calispel-20170830-git.tgz"; - sha256 = "08bmf3pi7n5hadpmqqkg65cxcj6kbvm997wcs1f53ml1nb79d9z8"; - system = "calispel-test"; - asd = "calispel"; - }); - systems = [ "calispel-test" ]; - lispLibs = [ (getAttr "calispel" self) (getAttr "eager-future2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - calm = (build-asdf-system { - pname = "calm"; - version = "20241012-git"; - asds = [ "calm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/calm/2024-10-12/calm-20241012-git.tgz"; - sha256 = "0c8d7aagx02cqk42pyj62hpqz3yarncigsw0g2ccc64sk74v67js"; - system = "calm"; - asd = "calm"; - }); - systems = [ "calm" ]; - lispLibs = [ (getAttr "bt-semaphore" self) (getAttr "cl-cairo2" self) (getAttr "cl-gobject-introspection" self) (getAttr "sdl2" self) (getAttr "sdl2-image" self) (getAttr "sdl2-mixer" self) (getAttr "str" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cambl = (build-asdf-system { - pname = "cambl"; - version = "20181210-git"; - asds = [ "cambl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cambl/2018-12-10/cambl-20181210-git.tgz"; - sha256 = "103mry04j2k9vznsxm7wcvccgxkil92cdrv52miwcmxl8daa4jiz"; - system = "cambl"; - asd = "cambl"; - }); - systems = [ "cambl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-containers" self) (getAttr "fprog" self) (getAttr "local-time" self) (getAttr "periods" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cambl-test = (build-asdf-system { - pname = "cambl-test"; - version = "20181210-git"; - asds = [ "cambl-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cambl/2018-12-10/cambl-20181210-git.tgz"; - sha256 = "103mry04j2k9vznsxm7wcvccgxkil92cdrv52miwcmxl8daa4jiz"; - system = "cambl-test"; - asd = "cambl-test"; - }); - systems = [ "cambl-test" ]; - lispLibs = [ (getAttr "cambl" self) (getAttr "xlunit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - camera-matrix = (build-asdf-system { - pname = "camera-matrix"; - version = "20200427-git"; - asds = [ "camera-matrix" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "camera-matrix"; - asd = "camera-matrix"; - }); - systems = [ "camera-matrix" ]; - lispLibs = [ (getAttr "nsb-cga" self) (getAttr "uncommon-lisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - can = (build-asdf-system { - pname = "can"; - version = "20180328-git"; - asds = [ "can" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/can/2018-03-28/can-20180328-git.tgz"; - sha256 = "0m3lqc56aw46cj2z379a19fh7f1h0vaxn78xpvbxq3bwar46jzqh"; - system = "can"; - asd = "can"; - }); - systems = [ "can" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - can-test = (build-asdf-system { - pname = "can-test"; - version = "20180328-git"; - asds = [ "can-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/can/2018-03-28/can-20180328-git.tgz"; - sha256 = "0m3lqc56aw46cj2z379a19fh7f1h0vaxn78xpvbxq3bwar46jzqh"; - system = "can-test"; - asd = "can-test"; - }); - systems = [ "can-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "can" self) (getAttr "mito" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - canonicalized-initargs = (build-asdf-system { - pname = "canonicalized-initargs"; - version = "2.0"; - asds = [ "canonicalized-initargs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/canonicalized-initargs/2021-04-11/canonicalized-initargs_2.0.tgz"; - sha256 = "0jmmjw86x9mmlfla4kdmdqf1fjrj0p2fmv1lc4k555mcf67mj2fq"; - system = "canonicalized-initargs"; - asd = "canonicalized-initargs"; - }); - systems = [ "canonicalized-initargs" ]; - lispLibs = [ (getAttr "cesdi" self) (getAttr "closer-mop" self) (getAttr "compatible-metaclasses" self) (getAttr "enhanced-defclass" self) (getAttr "enhanced-typep" self) (getAttr "object-class" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - canonicalized-initargs__tests = (build-asdf-system { - pname = "canonicalized-initargs_tests"; - version = "2.0"; - asds = [ "canonicalized-initargs_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/canonicalized-initargs/2021-04-11/canonicalized-initargs_2.0.tgz"; - sha256 = "0jmmjw86x9mmlfla4kdmdqf1fjrj0p2fmv1lc4k555mcf67mj2fq"; - system = "canonicalized-initargs_tests"; - asd = "canonicalized-initargs_tests"; - }); - systems = [ "canonicalized-initargs_tests" ]; - lispLibs = [ (getAttr "canonicalized-initargs" self) (getAttr "enhanced-boolean" self) (getAttr "enhanced-eval-when" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - capstone = (build-asdf-system { - pname = "capstone"; - version = "20220331-git"; - asds = [ "capstone" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-capstone/2022-03-31/cl-capstone-20220331-git.tgz"; - sha256 = "1jbhp1sf7mr6yrqkdyjl93m1dl901ka6gkgdj20nv2bgp400ycmp"; - system = "capstone"; - asd = "capstone"; - }); - systems = [ "capstone" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "gt" self) (getAttr "static-vectors" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - caramel = (build-asdf-system { - pname = "caramel"; - version = "20130420-git"; - asds = [ "caramel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/caramel/2013-04-20/caramel-20130420-git.tgz"; - sha256 = "08kyjxd8hyk5xnnq0p0w4aqpvisv278h38pqjkz04a032dn5b87a"; - system = "caramel"; - asd = "caramel"; - }); - systems = [ "caramel" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "buildnode" self) (getAttr "closure-html" self) (getAttr "css-selectors" self) (getAttr "cxml" self) (getAttr "cxml-dom" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cardioex = (build-asdf-system { - pname = "cardioex"; - version = "20211020-git"; - asds = [ "cardioex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cardiogram/2021-10-20/cardiogram-20211020-git.tgz"; - sha256 = "08kqcj3c4vkx5s6ba9m67xh7w7paaavp2ds072crp1x7pjkh4n5i"; - system = "cardioex"; - asd = "cardioex"; - }); - systems = [ "cardioex" ]; - lispLibs = [ (getAttr "cardiogram" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cardiogram = (build-asdf-system { - pname = "cardiogram"; - version = "20211020-git"; - asds = [ "cardiogram" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cardiogram/2021-10-20/cardiogram-20211020-git.tgz"; - sha256 = "08kqcj3c4vkx5s6ba9m67xh7w7paaavp2ds072crp1x7pjkh4n5i"; - system = "cardiogram"; - asd = "cardiogram"; - }); - systems = [ "cardiogram" ]; - lispLibs = [ (getAttr "cl-annot" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cari3s = (build-asdf-system { - pname = "cari3s"; - version = "20231021-git"; - asds = [ "cari3s" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cari3s/2023-10-21/cari3s-20231021-git.tgz"; - sha256 = "1q977ykj4fb095ilr1x4g0nrhqmipcgmdxbxn4gmlksg457sb4lm"; - system = "cari3s"; - asd = "cari3s"; - }); - systems = [ "cari3s" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "closer-mop" self) (getAttr "com_dot_inuoe_dot_jzon" self) (getAttr "documentation-utils" self) (getAttr "drakma" self) (getAttr "pango-markup" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - carrier = (build-asdf-system { - pname = "carrier"; - version = "20241012-git"; - asds = [ "carrier" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/carrier/2024-10-12/carrier-20241012-git.tgz"; - sha256 = "04w6hzqqbcvi8niqj35xz098gjfg4pdv6fbihfbna3c5v7q59gr1"; - system = "carrier"; - asd = "carrier"; - }); - systems = [ "carrier" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "blackbird" self) (getAttr "cl-async" self) (getAttr "cl-async-ssl" self) (getAttr "cl-cookie" self) (getAttr "fast-http" self) (getAttr "fast-io" self) (getAttr "quri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cartesian-product-switch = (build-asdf-system { - pname = "cartesian-product-switch"; - version = "2.0"; - asds = [ "cartesian-product-switch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cartesian-product-switch/2012-09-09/cartesian-product-switch-2.0.tgz"; - sha256 = "18cxslj2753k6h666j0mmzg0h0z9l6ddi24gqls6h5d5svd7l3xk"; - system = "cartesian-product-switch"; - asd = "cartesian-product-switch"; - }); - systems = [ "cartesian-product-switch" ]; - lispLibs = [ (getAttr "map-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - caveman-middleware-dbimanager = (build-asdf-system { - pname = "caveman-middleware-dbimanager"; - version = "20241012-git"; - asds = [ "caveman-middleware-dbimanager" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/caveman/2024-10-12/caveman-20241012-git.tgz"; - sha256 = "1q07mmm41zymh464j4mldf3lv1sb9amzdcwinkywqhwnjmnx6axi"; - system = "caveman-middleware-dbimanager"; - asd = "caveman-middleware-dbimanager"; - }); - systems = [ "caveman-middleware-dbimanager" ]; - lispLibs = [ (getAttr "dbi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - caveman2 = (build-asdf-system { - pname = "caveman2"; - version = "20241012-git"; - asds = [ "caveman2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/caveman/2024-10-12/caveman-20241012-git.tgz"; - sha256 = "1q07mmm41zymh464j4mldf3lv1sb9amzdcwinkywqhwnjmnx6axi"; - system = "caveman2"; - asd = "caveman2"; - }); - systems = [ "caveman2" ]; - lispLibs = [ (getAttr "cl-project" self) (getAttr "cl-syntax-annot" self) (getAttr "dbi" self) (getAttr "lack-request" self) (getAttr "lack-response" self) (getAttr "myway" self) (getAttr "ningle" self) (getAttr "quri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - caveman2-db = (build-asdf-system { - pname = "caveman2-db"; - version = "20241012-git"; - asds = [ "caveman2-db" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/caveman/2024-10-12/caveman-20241012-git.tgz"; - sha256 = "1q07mmm41zymh464j4mldf3lv1sb9amzdcwinkywqhwnjmnx6axi"; - system = "caveman2-db"; - asd = "caveman2-db"; - }); - systems = [ "caveman2-db" ]; - lispLibs = [ (getAttr "caveman-middleware-dbimanager" self) (getAttr "dbi" self) (getAttr "sxql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - caveman2-test = (build-asdf-system { - pname = "caveman2-test"; - version = "20241012-git"; - asds = [ "caveman2-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/caveman/2024-10-12/caveman-20241012-git.tgz"; - sha256 = "1q07mmm41zymh464j4mldf3lv1sb9amzdcwinkywqhwnjmnx6axi"; - system = "caveman2-test"; - asd = "caveman2-test"; - }); - systems = [ "caveman2-test" ]; - lispLibs = [ (getAttr "caveman2" self) (getAttr "dexador" self) (getAttr "lack-component" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "trivial-types" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - caveman2-widgets = (build-asdf-system { - pname = "caveman2-widgets"; - version = "20180228-git"; - asds = [ "caveman2-widgets" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/caveman2-widgets/2018-02-28/caveman2-widgets-20180228-git.tgz"; - sha256 = "1rzb868m3f28z1hcr3nzlprgqqq1kwg3qyh24p36fv76b4g96wkq"; - system = "caveman2-widgets"; - asd = "caveman2-widgets"; - }); - systems = [ "caveman2-widgets" ]; - lispLibs = [ (getAttr "caveman2" self) (getAttr "moptilities" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - caveman2-widgets-bootstrap = (build-asdf-system { - pname = "caveman2-widgets-bootstrap"; - version = "20180228-git"; - asds = [ "caveman2-widgets-bootstrap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/caveman2-widgets-bootstrap/2018-02-28/caveman2-widgets-bootstrap-20180228-git.tgz"; - sha256 = "1xh3x7r7givxxyrkh4ngx098s35qz98gcz7yjyf4dp0psfkk65xj"; - system = "caveman2-widgets-bootstrap"; - asd = "caveman2-widgets-bootstrap"; - }); - systems = [ "caveman2-widgets-bootstrap" ]; - lispLibs = [ (getAttr "caveman2" self) (getAttr "caveman2-widgets" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - caveman2-widgets-bootstrap-test = (build-asdf-system { - pname = "caveman2-widgets-bootstrap-test"; - version = "20180228-git"; - asds = [ "caveman2-widgets-bootstrap-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/caveman2-widgets-bootstrap/2018-02-28/caveman2-widgets-bootstrap-20180228-git.tgz"; - sha256 = "1xh3x7r7givxxyrkh4ngx098s35qz98gcz7yjyf4dp0psfkk65xj"; - system = "caveman2-widgets-bootstrap-test"; - asd = "caveman2-widgets-bootstrap-test"; - }); - systems = [ "caveman2-widgets-bootstrap-test" ]; - lispLibs = [ (getAttr "caveman2-widgets-bootstrap" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - caveman2-widgets-test = (build-asdf-system { - pname = "caveman2-widgets-test"; - version = "20180228-git"; - asds = [ "caveman2-widgets-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/caveman2-widgets/2018-02-28/caveman2-widgets-20180228-git.tgz"; - sha256 = "1rzb868m3f28z1hcr3nzlprgqqq1kwg3qyh24p36fv76b4g96wkq"; - system = "caveman2-widgets-test"; - asd = "caveman2-widgets-test"; - }); - systems = [ "caveman2-widgets-test" ]; - lispLibs = [ (getAttr "caveman2-widgets" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cblas = (build-asdf-system { - pname = "cblas"; - version = "20221106-git"; - asds = [ "cblas" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cblas/2022-11-06/cl-cblas-20221106-git.tgz"; - sha256 = "1bd2w51r71pgm6sc6m2fms4j1bbnli023j4w3rbxw9cln0g7badp"; - system = "cblas"; - asd = "cblas"; - }); - systems = [ "cblas" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-autowrap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cbor = (build-asdf-system { - pname = "cbor"; - version = "20241012-git"; - asds = [ "cbor" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cbor/2024-10-12/cbor-20241012-git.tgz"; - sha256 = "0bkjfi449m651hbsm39dc9863mcry3ynz1j59wb2kl8zwxm1qg2r"; - system = "cbor"; - asd = "cbor"; - }); - systems = [ "cbor" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "ieee-floats" self) (getAttr "local-time" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ccl-compat = (build-asdf-system { - pname = "ccl-compat"; - version = "20171130-git"; - asds = [ "ccl-compat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ccl-compat/2017-11-30/ccl-compat-20171130-git.tgz"; - sha256 = "15402373wprmyx4l7zgpv64vj3c11xvxnnpzqbmq4j6rljpb40da"; - system = "ccl-compat"; - asd = "ccl-compat"; - }); - systems = [ "ccl-compat" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ccldoc = (build-asdf-system { - pname = "ccldoc"; - version = "20241012-git"; - asds = [ "ccldoc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ccldoc/2024-10-12/ccldoc-20241012-git.tgz"; - sha256 = "15pc25pwnlg2lhzxniln53fr2i2cqa6fpr60nv4i1743x9ahp35l"; - system = "ccldoc"; - asd = "ccldoc"; - }); - systems = [ "ccldoc" ]; - lispLibs = [ (getAttr "ccl-compat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ccldoc-docbook = (build-asdf-system { - pname = "ccldoc-docbook"; - version = "20241012-git"; - asds = [ "ccldoc-docbook" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ccldoc/2024-10-12/ccldoc-20241012-git.tgz"; - sha256 = "15pc25pwnlg2lhzxniln53fr2i2cqa6fpr60nv4i1743x9ahp35l"; - system = "ccldoc-docbook"; - asd = "ccldoc-docbook"; - }); - systems = [ "ccldoc-docbook" ]; - lispLibs = [ (getAttr "ccldoc" self) (getAttr "s-xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ccldoc-libraries = (build-asdf-system { - pname = "ccldoc-libraries"; - version = "20241012-git"; - asds = [ "ccldoc-libraries" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ccldoc/2024-10-12/ccldoc-20241012-git.tgz"; - sha256 = "15pc25pwnlg2lhzxniln53fr2i2cqa6fpr60nv4i1743x9ahp35l"; - system = "ccldoc-libraries"; - asd = "ccldoc-libraries"; - }); - systems = [ "ccldoc-libraries" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "s-xml" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ceigen-lite = (build-asdf-system { - pname = "ceigen-lite"; - version = "20241012-git"; - asds = [ "ceigen-lite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ceigen-lite/2024-10-12/cl-ceigen-lite-20241012-git.tgz"; - sha256 = "0k2b6x913mnv1f5712xvvv7d6j3lrja4isjg6cyad694py59d09q"; - system = "ceigen-lite"; - asd = "ceigen-lite"; - }); - systems = [ "ceigen-lite" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-autowrap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cells = (build-asdf-system { - pname = "cells"; - version = "20230618-git"; - asds = [ "cells" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cells/2023-06-18/cells-20230618-git.tgz"; - sha256 = "1mh14g8x2mpb8qdngqxgnkawqbv4xxxr3bgn01jm5d6c8jn6ph3f"; - system = "cells"; - asd = "cells"; - }); - systems = [ "cells" ]; - lispLibs = [ (getAttr "utils-kt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cells-test = (build-asdf-system { - pname = "cells-test"; - version = "20230618-git"; - asds = [ "cells-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cells/2023-06-18/cells-20230618-git.tgz"; - sha256 = "1mh14g8x2mpb8qdngqxgnkawqbv4xxxr3bgn01jm5d6c8jn6ph3f"; - system = "cells-test"; - asd = "cells-test"; - }); - systems = [ "cells-test" ]; - lispLibs = [ (getAttr "cells" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cephes = (build-asdf-system { - pname = "cephes"; - version = "20241012-git"; - asds = [ "cephes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cephes.cl/2024-10-12/cephes.cl-20241012-git.tgz"; - sha256 = "1p0npidiy9zjb90gyihdmx0nmm87a5akph1jhs6y7z50fx8470hb"; - system = "cephes"; - asd = "cephes"; - }); - systems = [ "cephes" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cepl = (build-asdf-system { - pname = "cepl"; - version = "release-quicklisp-543c9fc1-git"; - asds = [ "cepl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cepl/2024-10-12/cepl-release-quicklisp-543c9fc1-git.tgz"; - sha256 = "0g5frci6ljmy6pyyrjhh2kw894l3fl3wsz27k75xw49cd8xm24mh"; - system = "cepl"; - asd = "cepl"; - }); - systems = [ "cepl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cepl_dot_build" self) (getAttr "cffi" self) (getAttr "cl-opengl" self) (getAttr "cl-ppcre" self) (getAttr "documentation-utils" self) (getAttr "float-features" self) (getAttr "ieee-floats" self) (getAttr "split-sequence" self) (getAttr "varjo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cepl_dot_build = (build-asdf-system { - pname = "cepl.build"; - version = "release-quicklisp-543c9fc1-git"; - asds = [ "cepl.build" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cepl/2024-10-12/cepl-release-quicklisp-543c9fc1-git.tgz"; - sha256 = "0g5frci6ljmy6pyyrjhh2kw894l3fl3wsz27k75xw49cd8xm24mh"; - system = "cepl.build"; - asd = "cepl.build"; - }); - systems = [ "cepl.build" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cepl_dot_camera = (build-asdf-system { - pname = "cepl.camera"; - version = "release-quicklisp-1292212a-git"; - asds = [ "cepl.camera" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cepl.camera/2018-02-28/cepl.camera-release-quicklisp-1292212a-git.tgz"; - sha256 = "0z73f95bxr2vn47g8qrvf9gzy1my25mkg7hl7kpib21yahfpzzvb"; - system = "cepl.camera"; - asd = "cepl.camera"; - }); - systems = [ "cepl.camera" ]; - lispLibs = [ (getAttr "cepl" self) (getAttr "cepl_dot_spaces" self) (getAttr "rtg-math" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cepl_dot_devil = (build-asdf-system { - pname = "cepl.devil"; - version = "release-quicklisp-ea5f8514-git"; - asds = [ "cepl.devil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cepl.devil/2018-02-28/cepl.devil-release-quicklisp-ea5f8514-git.tgz"; - sha256 = "1b64vfjchkwppcp3j4krwx2x9nj29llisqy1yc9ncbnmi9xs38a0"; - system = "cepl.devil"; - asd = "cepl.devil"; - }); - systems = [ "cepl.devil" ]; - lispLibs = [ (getAttr "cepl" self) (getAttr "cl-devil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cepl_dot_drm-gbm = (build-asdf-system { - pname = "cepl.drm-gbm"; - version = "20190521-git"; - asds = [ "cepl.drm-gbm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cepl.drm-gbm/2019-05-21/cepl.drm-gbm-20190521-git.tgz"; - sha256 = "00csd2f6z13rjqipaf02w87phn2xynmzf1jcrrshbibs204m4nmy"; - system = "cepl.drm-gbm"; - asd = "cepl.drm-gbm"; - }); - systems = [ "cepl.drm-gbm" ]; - lispLibs = [ (getAttr "cepl" self) (getAttr "cl-drm" self) (getAttr "cl-egl" self) (getAttr "cl-gbm" self) (getAttr "osicat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cepl_dot_glop = (build-asdf-system { - pname = "cepl.glop"; - version = "release-quicklisp-8ec09801-git"; - asds = [ "cepl.glop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cepl.glop/2018-02-28/cepl.glop-release-quicklisp-8ec09801-git.tgz"; - sha256 = "1dq727v2s22yna6ycxxs79pg13b0cyh1lfrk6hsb6vizgiks20jw"; - system = "cepl.glop"; - asd = "cepl.glop"; - }); - systems = [ "cepl.glop" ]; - lispLibs = [ (getAttr "cepl" self) (getAttr "glop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cepl_dot_sdl2 = (build-asdf-system { - pname = "cepl.sdl2"; - version = "release-quicklisp-6da5a030-git"; - asds = [ "cepl.sdl2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cepl.sdl2/2018-02-28/cepl.sdl2-release-quicklisp-6da5a030-git.tgz"; - sha256 = "0lz8yxm1g2ch0w779lhrs2xkfciy3iz6viz7cdgyd2824isvinjf"; - system = "cepl.sdl2"; - asd = "cepl.sdl2"; - }); - systems = [ "cepl.sdl2" ]; - lispLibs = [ (getAttr "cepl" self) (getAttr "sdl2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cepl_dot_sdl2-image = (build-asdf-system { - pname = "cepl.sdl2-image"; - version = "release-quicklisp-94a77649-git"; - asds = [ "cepl.sdl2-image" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cepl.sdl2-image/2018-02-28/cepl.sdl2-image-release-quicklisp-94a77649-git.tgz"; - sha256 = "16dzjk2q658xr1v9rk2iny70rjhxbgi4lcp59s5mkdfs2k3a2637"; - system = "cepl.sdl2-image"; - asd = "cepl.sdl2-image"; - }); - systems = [ "cepl.sdl2-image" ]; - lispLibs = [ (getAttr "cepl" self) (getAttr "sdl2" self) (getAttr "sdl2-image" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cepl_dot_sdl2-ttf = (build-asdf-system { - pname = "cepl.sdl2-ttf"; - version = "release-quicklisp-11b498a3-git"; - asds = [ "cepl.sdl2-ttf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cepl.sdl2-ttf/2018-01-31/cepl.sdl2-ttf-release-quicklisp-11b498a3-git.tgz"; - sha256 = "1fxj3rdv2rlyks00h18dpd42xywgnydgyvb1s4d67hjk7fl19a5p"; - system = "cepl.sdl2-ttf"; - asd = "cepl.sdl2-ttf"; - }); - systems = [ "cepl.sdl2-ttf" ]; - lispLibs = [ (getAttr "cepl_dot_sdl2" self) (getAttr "rtg-math" self) (getAttr "sdl2-ttf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cepl_dot_skitter_dot_glop = (build-asdf-system { - pname = "cepl.skitter.glop"; - version = "release-quicklisp-f52b9240-git"; - asds = [ "cepl.skitter.glop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cepl.skitter/2018-02-28/cepl.skitter-release-quicklisp-f52b9240-git.tgz"; - sha256 = "1xz53q8klzrd7cr586jd16pypxgpy68vlvfirqhlv6jc7k99sjvs"; - system = "cepl.skitter.glop"; - asd = "cepl.skitter.glop"; - }); - systems = [ "cepl.skitter.glop" ]; - lispLibs = [ (getAttr "cepl_dot_glop" self) (getAttr "skitter_dot_glop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cepl_dot_skitter_dot_sdl2 = (build-asdf-system { - pname = "cepl.skitter.sdl2"; - version = "release-quicklisp-f52b9240-git"; - asds = [ "cepl.skitter.sdl2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cepl.skitter/2018-02-28/cepl.skitter-release-quicklisp-f52b9240-git.tgz"; - sha256 = "1xz53q8klzrd7cr586jd16pypxgpy68vlvfirqhlv6jc7k99sjvs"; - system = "cepl.skitter.sdl2"; - asd = "cepl.skitter.sdl2"; - }); - systems = [ "cepl.skitter.sdl2" ]; - lispLibs = [ (getAttr "cepl_dot_sdl2" self) (getAttr "skitter_dot_sdl2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cepl_dot_spaces = (build-asdf-system { - pname = "cepl.spaces"; - version = "release-quicklisp-c7f83f26-git"; - asds = [ "cepl.spaces" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cepl.spaces/2018-03-28/cepl.spaces-release-quicklisp-c7f83f26-git.tgz"; - sha256 = "0z74ipd4j2spjwl6h625azdczpds3v44iin77q685ldx9rwx3k8y"; - system = "cepl.spaces"; - asd = "cepl.spaces"; - }); - systems = [ "cepl.spaces" ]; - lispLibs = [ (getAttr "cepl" self) (getAttr "documentation-utils" self) (getAttr "fn" self) (getAttr "rtg-math" self) (getAttr "rtg-math_dot_vari" self) (getAttr "varjo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ceramic = (build-asdf-system { - pname = "ceramic"; - version = "20210807-git"; - asds = [ "ceramic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ceramic/2021-08-07/ceramic-20210807-git.tgz"; - sha256 = "0hd553gj4cwmli45pfwhqpz7sg6kzn31iv8akaxr5ba3hssa1aap"; - system = "ceramic"; - asd = "ceramic"; - }); - systems = [ "ceramic" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "clack-handler-hunchentoot" self) (getAttr "copy-directory" self) (getAttr "electron-tools" self) (getAttr "external-program" self) (getAttr "remote-js" self) (getAttr "trivial-build" self) (getAttr "trivial-compress" self) (getAttr "trivial-download" self) (getAttr "trivial-exe" self) (getAttr "trivial-extract" self) (getAttr "uuid" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ceramic-test-app = (build-asdf-system { - pname = "ceramic-test-app"; - version = "20210807-git"; - asds = [ "ceramic-test-app" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ceramic/2021-08-07/ceramic-20210807-git.tgz"; - sha256 = "0hd553gj4cwmli45pfwhqpz7sg6kzn31iv8akaxr5ba3hssa1aap"; - system = "ceramic-test-app"; - asd = "ceramic-test-app"; - }); - systems = [ "ceramic-test-app" ]; - lispLibs = [ (getAttr "ceramic" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cerberus = (build-asdf-system { - pname = "cerberus"; - version = "20241012-git"; - asds = [ "cerberus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cerberus/2024-10-12/cerberus-20241012-git.tgz"; - sha256 = "131x0raccj5majd72hmmlp67dsj2zdizm2xzdhw6s0jbxjbhdgfs"; - system = "cerberus"; - asd = "cerberus"; - }); - systems = [ "cerberus" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "flexi-streams" self) (getAttr "glass" self) (getAttr "ironclad" self) (getAttr "nibbles" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cerberus-kdc = (build-asdf-system { - pname = "cerberus-kdc"; - version = "20241012-git"; - asds = [ "cerberus-kdc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cerberus/2024-10-12/cerberus-20241012-git.tgz"; - sha256 = "131x0raccj5majd72hmmlp67dsj2zdizm2xzdhw6s0jbxjbhdgfs"; - system = "cerberus-kdc"; - asd = "cerberus"; - }); - systems = [ "cerberus-kdc" ]; - lispLibs = [ (getAttr "cerberus" self) (getAttr "frpc" self) (getAttr "pounds" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cesdi = (build-asdf-system { - pname = "cesdi"; - version = "1.0.1"; - asds = [ "cesdi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cesdi/2020-07-15/cesdi_1.0.1.tgz"; - sha256 = "02f2pz5rw79ljkkx1ywh8nkpjj4g3z3s1lyvzqb8krbnx11wl0q9"; - system = "cesdi"; - asd = "cesdi"; - }); - systems = [ "cesdi" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cesdi__tests = (build-asdf-system { - pname = "cesdi_tests"; - version = "1.0.1"; - asds = [ "cesdi_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cesdi/2020-07-15/cesdi_1.0.1.tgz"; - sha256 = "02f2pz5rw79ljkkx1ywh8nkpjj4g3z3s1lyvzqb8krbnx11wl0q9"; - system = "cesdi_tests"; - asd = "cesdi_tests"; - }); - systems = [ "cesdi_tests" ]; - lispLibs = [ (getAttr "cesdi" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cf = (build-asdf-system { - pname = "cf"; - version = "20241012-git"; - asds = [ "cf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cf/2024-10-12/cl-cf-20241012-git.tgz"; - sha256 = "1w4asb8v81q2rf8fhhq88c2ib4ax5fbm0655kvdpfvkz1457yi25"; - system = "cf"; - asd = "cf"; - }); - systems = [ "cf" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cf-tests = (build-asdf-system { - pname = "cf-tests"; - version = "20241012-git"; - asds = [ "cf-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cf/2024-10-12/cl-cf-20241012-git.tgz"; - sha256 = "1w4asb8v81q2rf8fhhq88c2ib4ax5fbm0655kvdpfvkz1457yi25"; - system = "cf-tests"; - asd = "cf-tests"; - }); - systems = [ "cf-tests" ]; - lispLibs = [ (getAttr "cf" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cffi = (build-asdf-system { - pname = "cffi"; - version = "20241012-git"; - asds = [ "cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; - sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; - system = "cffi"; - asd = "cffi"; - }); - systems = [ "cffi" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "trivial-features" self) ]; - meta = {}; - }); - cffi-c-ref = (build-asdf-system { - pname = "cffi-c-ref"; - version = "stable-git"; - asds = [ "cffi-c-ref" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cffi-c-ref/2020-10-16/cffi-c-ref-stable-git.tgz"; - sha256 = "1a3pp6xcisabqir3rp1gvvjfdxcvpm8yr35p38nri9azsinmmc7z"; - system = "cffi-c-ref"; - asd = "cffi-c-ref"; - }); - systems = [ "cffi-c-ref" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cffi-examples = (build-asdf-system { - pname = "cffi-examples"; - version = "20241012-git"; - asds = [ "cffi-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; - sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; - system = "cffi-examples"; - asd = "cffi-examples"; - }); - systems = [ "cffi-examples" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cffi-grovel = (build-asdf-system { - pname = "cffi-grovel"; - version = "20241012-git"; - asds = [ "cffi-grovel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; - sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; - system = "cffi-grovel"; - asd = "cffi-grovel"; - }); - systems = [ "cffi-grovel" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-toolchain" self) ]; - meta = {}; - }); - cffi-libffi = (build-asdf-system { - pname = "cffi-libffi"; - version = "20241012-git"; - asds = [ "cffi-libffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; - sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; - system = "cffi-libffi"; - asd = "cffi-libffi"; - }); - systems = [ "cffi-libffi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cffi-object = (build-asdf-system { - pname = "cffi-object"; - version = "20241012-git"; - asds = [ "cffi-object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cffi-object/2024-10-12/cffi-object-20241012-git.tgz"; - sha256 = "0hdxy2lqf0q04j57y6plnlh2v6w7y7prsypxk9f4vdlnp2ah3lln"; - system = "cffi-object"; - asd = "cffi-object"; - }); - systems = [ "cffi-object" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cffi-object_dot_ops = (build-asdf-system { - pname = "cffi-object.ops"; - version = "20241012-git"; - asds = [ "cffi-object.ops" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cffi-object/2024-10-12/cffi-object-20241012-git.tgz"; - sha256 = "0hdxy2lqf0q04j57y6plnlh2v6w7y7prsypxk9f4vdlnp2ah3lln"; - system = "cffi-object.ops"; - asd = "cffi-object.ops"; - }); - systems = [ "cffi-object.ops" ]; - lispLibs = [ (getAttr "cffi-object" self) (getAttr "cffi-ops" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cffi-ops = (build-asdf-system { - pname = "cffi-ops"; - version = "20241012-git"; - asds = [ "cffi-ops" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cffi-ops/2024-10-12/cffi-ops-20241012-git.tgz"; - sha256 = "0hi3svwfb7m1wq892wlrsgj52jkh3x6msnimax28221baj6g64gg"; - system = "cffi-ops"; - asd = "cffi-ops"; - }); - systems = [ "cffi-ops" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "arrow-macros" self) (getAttr "cffi" self) (getAttr "trivial-macroexpand-all" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cffi-tests = (build-asdf-system { - pname = "cffi-tests"; - version = "20241012-git"; - asds = [ "cffi-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; - sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; - system = "cffi-tests"; - asd = "cffi-tests"; - }); - systems = [ "cffi-tests" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi-grovel" self) (getAttr "cffi-libffi" self) (getAttr "rt" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cffi-toolchain = (build-asdf-system { - pname = "cffi-toolchain"; - version = "20241012-git"; - asds = [ "cffi-toolchain" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; - sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; - system = "cffi-toolchain"; - asd = "cffi-toolchain"; - }); - systems = [ "cffi-toolchain" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = {}; - }); - cffi-uffi-compat = (build-asdf-system { - pname = "cffi-uffi-compat"; - version = "20241012-git"; - asds = [ "cffi-uffi-compat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; - sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; - system = "cffi-uffi-compat"; - asd = "cffi-uffi-compat"; - }); - systems = [ "cffi-uffi-compat" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = {}; - }); - chain = (build-asdf-system { - pname = "chain"; - version = "20211209-git"; - asds = [ "chain" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chain/2021-12-09/chain-20211209-git.tgz"; - sha256 = "0x8b2cbp1xq61fpbk0mqwbksnfynlgai3782rafsywka8rgfhmjh"; - system = "chain"; - asd = "chain"; - }); - systems = [ "chain" ]; - lispLibs = [ (getAttr "metabang-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chameleon = (build-asdf-system { - pname = "chameleon"; - version = "v2.1.1"; - asds = [ "chameleon" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chameleon/2022-02-20/chameleon-v2.1.1.tgz"; - sha256 = "1bqminvhx3hlqzxvy2a105gm9d2dxl5cy6ls5rm9wmkvw7gyza6c"; - system = "chameleon"; - asd = "chameleon"; - }); - systems = [ "chameleon" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chancery = (build-asdf-system { - pname = "chancery"; - version = "20201016-hg"; - asds = [ "chancery" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chancery/2020-10-16/chancery-20201016-hg.tgz"; - sha256 = "1g0jgrih7q14gizy481j9z2s15pmv6iwymnpddbyqfja9miv61lw"; - system = "chancery"; - asd = "chancery"; - }); - systems = [ "chancery" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chancery_dot_test = (build-asdf-system { - pname = "chancery.test"; - version = "20201016-hg"; - asds = [ "chancery.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chancery/2020-10-16/chancery-20201016-hg.tgz"; - sha256 = "1g0jgrih7q14gizy481j9z2s15pmv6iwymnpddbyqfja9miv61lw"; - system = "chancery.test"; - asd = "chancery.test"; - }); - systems = [ "chancery.test" ]; - lispLibs = [ (getAttr "_1am" self) (getAttr "chancery" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - changed-stream = (build-asdf-system { - pname = "changed-stream"; - version = "20130128-git"; - asds = [ "changed-stream" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/changed-stream/2013-01-28/changed-stream-20130128-git.tgz"; - sha256 = "1cll7xclg9jr55swhi3g6z567bxvb9kmljh67091xazcfacz732i"; - system = "changed-stream"; - asd = "changed-stream"; - }); - systems = [ "changed-stream" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - changed-stream_dot_test = (build-asdf-system { - pname = "changed-stream.test"; - version = "20130128-git"; - asds = [ "changed-stream.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/changed-stream/2013-01-28/changed-stream-20130128-git.tgz"; - sha256 = "1cll7xclg9jr55swhi3g6z567bxvb9kmljh67091xazcfacz732i"; - system = "changed-stream.test"; - asd = "changed-stream.test"; - }); - systems = [ "changed-stream.test" ]; - lispLibs = [ (getAttr "changed-stream" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chanl = (build-asdf-system { - pname = "chanl"; - version = "20241012-git"; - asds = [ "chanl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chanl/2024-10-12/chanl-20241012-git.tgz"; - sha256 = "1gyvsajvqjzfmcbccnysw7qyvhyqdlfcwl57lhsfwz9gif50y1fw"; - system = "chanl"; - asd = "chanl"; - }); - systems = [ "chanl" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = {}; - }); - character-modifier-bits = (build-asdf-system { - pname = "character-modifier-bits"; - version = "20200427-git"; - asds = [ "character-modifier-bits" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "character-modifier-bits"; - asd = "character-modifier-bits"; - }); - systems = [ "character-modifier-bits" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - charje_dot_documentation = (build-asdf-system { - pname = "charje.documentation"; - version = "20241012-git"; - asds = [ "charje.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/charje.documentation/2024-10-12/charje.documentation-20241012-git.tgz"; - sha256 = "0rdfi4sj5ad6krwypmsr934ic6y5xlj6iixdwwxrxj9fihfq47zb"; - system = "charje.documentation"; - asd = "charje.documentation"; - }); - systems = [ "charje.documentation" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cheat-js = (build-asdf-system { - pname = "cheat-js"; - version = "20121013-git"; - asds = [ "cheat-js" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cheat-js/2012-10-13/cheat-js-20121013-git.tgz"; - sha256 = "1h73kx0iii4y4gslz6f8kvf980bnypsras6xj38apm0fcwm93w03"; - system = "cheat-js"; - asd = "cheat-js"; - }); - systems = [ "cheat-js" ]; - lispLibs = [ (getAttr "cl-uglify-js" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - check-bnf = (build-asdf-system { - pname = "check-bnf"; - version = "20220707-git"; - asds = [ "check-bnf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/check-bnf/2022-07-07/check-bnf-20220707-git.tgz"; - sha256 = "1dpp0xzj51a7fg9yw0xsipnsa54xj1axvkk55n0yxq9yv9ih3rb0"; - system = "check-bnf"; - asd = "check-bnf"; - }); - systems = [ "check-bnf" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "jingoh_dot_documentizer" self) (getAttr "matrix-case" self) (getAttr "millet" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - check-bnf_dot_test = (build-asdf-system { - pname = "check-bnf.test"; - version = "20220707-git"; - asds = [ "check-bnf.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/check-bnf/2022-07-07/check-bnf-20220707-git.tgz"; - sha256 = "1dpp0xzj51a7fg9yw0xsipnsa54xj1axvkk55n0yxq9yv9ih3rb0"; - system = "check-bnf.test"; - asd = "check-bnf.test"; - }); - systems = [ "check-bnf.test" ]; - lispLibs = [ (getAttr "check-bnf" self) (getAttr "jingoh" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - check-it = (build-asdf-system { - pname = "check-it"; - version = "20150709-git"; - asds = [ "check-it" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/check-it/2015-07-09/check-it-20150709-git.tgz"; - sha256 = "1kbjwpniffdpv003igmlz5r0vy65m7wpfnhg54fhwirp1227hgg7"; - system = "check-it"; - asd = "check-it"; - }); - systems = [ "check-it" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "optima" self) ]; - meta = {}; - }); - check-it-test = (build-asdf-system { - pname = "check-it-test"; - version = "20150709-git"; - asds = [ "check-it-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/check-it/2015-07-09/check-it-20150709-git.tgz"; - sha256 = "1kbjwpniffdpv003igmlz5r0vy65m7wpfnhg54fhwirp1227hgg7"; - system = "check-it-test"; - asd = "check-it"; - }); - systems = [ "check-it-test" ]; - lispLibs = [ (getAttr "check-it" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - checkl = (build-asdf-system { - pname = "checkl"; - version = "20180328-git"; - asds = [ "checkl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/checkl/2018-03-28/checkl-20180328-git.tgz"; - sha256 = "0bpisihx1gay44xmyr1dmhlwh00j0zzi04rp9fy35i95l2r4xdlx"; - system = "checkl"; - asd = "checkl"; - }); - systems = [ "checkl" ]; - lispLibs = [ (getAttr "marshal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - checkl-docs = (build-asdf-system { - pname = "checkl-docs"; - version = "20180328-git"; - asds = [ "checkl-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/checkl/2018-03-28/checkl-20180328-git.tgz"; - sha256 = "0bpisihx1gay44xmyr1dmhlwh00j0zzi04rp9fy35i95l2r4xdlx"; - system = "checkl-docs"; - asd = "checkl-docs"; - }); - systems = [ "checkl-docs" ]; - lispLibs = [ (getAttr "checkl" self) (getAttr "cl-gendoc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - checkl-test = (build-asdf-system { - pname = "checkl-test"; - version = "20180328-git"; - asds = [ "checkl-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/checkl/2018-03-28/checkl-20180328-git.tgz"; - sha256 = "0bpisihx1gay44xmyr1dmhlwh00j0zzi04rp9fy35i95l2r4xdlx"; - system = "checkl-test"; - asd = "checkl-test"; - }); - systems = [ "checkl-test" ]; - lispLibs = [ (getAttr "checkl" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chemical-compounds = (build-asdf-system { - pname = "chemical-compounds"; - version = "1.0.2"; - asds = [ "chemical-compounds" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chemical-compounds/2011-10-01/chemical-compounds-1.0.2.tgz"; - sha256 = "047z1lab08y4nsb32rnzqfpb6akyhibzjgmmr1bnwrh9pmhv3s2k"; - system = "chemical-compounds"; - asd = "chemical-compounds"; - }); - systems = [ "chemical-compounds" ]; - lispLibs = [ (getAttr "periodic-table" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chillax = (build-asdf-system { - pname = "chillax"; - version = "20150302-git"; - asds = [ "chillax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chillax/2015-03-02/chillax-20150302-git.tgz"; - sha256 = "1is3qm68wyfi3rmpn8mw0x9861951a2w60snsdippikygm3smzr1"; - system = "chillax"; - asd = "chillax"; - }); - systems = [ "chillax" ]; - lispLibs = [ (getAttr "chillax_dot_core" self) (getAttr "chillax_dot_yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chillax_dot_core = (build-asdf-system { - pname = "chillax.core"; - version = "20150302-git"; - asds = [ "chillax.core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chillax/2015-03-02/chillax-20150302-git.tgz"; - sha256 = "1is3qm68wyfi3rmpn8mw0x9861951a2w60snsdippikygm3smzr1"; - system = "chillax.core"; - asd = "chillax.core"; - }); - systems = [ "chillax.core" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "drakma" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chillax_dot_jsown = (build-asdf-system { - pname = "chillax.jsown"; - version = "20150302-git"; - asds = [ "chillax.jsown" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chillax/2015-03-02/chillax-20150302-git.tgz"; - sha256 = "1is3qm68wyfi3rmpn8mw0x9861951a2w60snsdippikygm3smzr1"; - system = "chillax.jsown"; - asd = "chillax.jsown"; - }); - systems = [ "chillax.jsown" ]; - lispLibs = [ (getAttr "chillax_dot_core" self) (getAttr "jsown" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chillax_dot_view-server = (build-asdf-system { - pname = "chillax.view-server"; - version = "20150302-git"; - asds = [ "chillax.view-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chillax/2015-03-02/chillax-20150302-git.tgz"; - sha256 = "1is3qm68wyfi3rmpn8mw0x9861951a2w60snsdippikygm3smzr1"; - system = "chillax.view-server"; - asd = "chillax.view-server"; - }); - systems = [ "chillax.view-server" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chillax_dot_yason = (build-asdf-system { - pname = "chillax.yason"; - version = "20150302-git"; - asds = [ "chillax.yason" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chillax/2015-03-02/chillax-20150302-git.tgz"; - sha256 = "1is3qm68wyfi3rmpn8mw0x9861951a2w60snsdippikygm3smzr1"; - system = "chillax.yason"; - asd = "chillax.yason"; - }); - systems = [ "chillax.yason" ]; - lispLibs = [ (getAttr "chillax_dot_core" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chipi = (build-asdf-system { - pname = "chipi"; - version = "20241012-git"; - asds = [ "chipi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chipi/2024-10-12/chipi-20241012-git.tgz"; - sha256 = "0xpfclvl5v031cjnjvr3bcfc87rayw624m9yrw35f5r31p8m283g"; - system = "chipi"; - asd = "chipi"; - }); - systems = [ "chipi" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "binding-arrows" self) (getAttr "cl-cron" self) (getAttr "drakma" self) (getAttr "local-time" self) (getAttr "parse-float" self) (getAttr "sento" self) (getAttr "timer-wheel" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chipi-web = (build-asdf-system { - pname = "chipi-web"; - version = "20241012-git"; - asds = [ "chipi-web" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chipi/2024-10-12/chipi-20241012-git.tgz"; - sha256 = "0xpfclvl5v031cjnjvr3bcfc87rayw624m9yrw35f5r31p8m283g"; - system = "chipi-web"; - asd = "chipi-web"; - }); - systems = [ "chipi-web" ]; - lispLibs = [ (getAttr "chipi" self) (getAttr "cl-base64" self) (getAttr "cl-ppcre" self) (getAttr "com_dot_inuoe_dot_jzon" self) (getAttr "drakma" self) (getAttr "hunchentoot" self) (getAttr "ironclad" self) (getAttr "marshal" self) (getAttr "snooze" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chipmunk-blob = (build-asdf-system { - pname = "chipmunk-blob"; - version = "stable-git"; - asds = [ "chipmunk-blob" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chipmunk-blob/2020-10-16/chipmunk-blob-stable-git.tgz"; - sha256 = "0kdi1al1cn90hzjfnjhkxp3k5ibp6l73k3m04mkpzkzpjy7jc80d"; - system = "chipmunk-blob"; - asd = "chipmunk-blob"; - }); - systems = [ "chipmunk-blob" ]; - lispLibs = [ (getAttr "bodge-blobs-support" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chipz = (build-asdf-system { - pname = "chipz"; - version = "20230618-git"; - asds = [ "chipz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chipz/2023-06-18/chipz-20230618-git.tgz"; - sha256 = "04ysl1lz47dd8p1cbm637kpyf84hl74xvcdpqhdyxwh4n97csm5h"; - system = "chipz"; - asd = "chipz"; - }); - systems = [ "chipz" ]; - lispLibs = [ ]; - meta = {}; - }); - chirp = (build-asdf-system { - pname = "chirp"; - version = "20231021-git"; - asds = [ "chirp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chirp/2023-10-21/chirp-20231021-git.tgz"; - sha256 = "00vin2svx54wpk2yv9645y3gfy5pg78pfpr79srqk7jklr1wwa1m"; - system = "chirp"; - asd = "chirp"; - }); - systems = [ "chirp" ]; - lispLibs = [ (getAttr "chirp-drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chirp-core = (build-asdf-system { - pname = "chirp-core"; - version = "20231021-git"; - asds = [ "chirp-core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chirp/2023-10-21/chirp-20231021-git.tgz"; - sha256 = "00vin2svx54wpk2yv9645y3gfy5pg78pfpr79srqk7jklr1wwa1m"; - system = "chirp-core"; - asd = "chirp-core"; - }); - systems = [ "chirp-core" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-base64" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "ironclad" self) (getAttr "local-time" self) (getAttr "split-sequence" self) (getAttr "uuid" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chirp-dexador = (build-asdf-system { - pname = "chirp-dexador"; - version = "20231021-git"; - asds = [ "chirp-dexador" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chirp/2023-10-21/chirp-20231021-git.tgz"; - sha256 = "00vin2svx54wpk2yv9645y3gfy5pg78pfpr79srqk7jklr1wwa1m"; - system = "chirp-dexador"; - asd = "chirp-dexador"; - }); - systems = [ "chirp-dexador" ]; - lispLibs = [ (getAttr "chirp-core" self) (getAttr "dexador" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chirp-drakma = (build-asdf-system { - pname = "chirp-drakma"; - version = "20231021-git"; - asds = [ "chirp-drakma" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chirp/2023-10-21/chirp-20231021-git.tgz"; - sha256 = "00vin2svx54wpk2yv9645y3gfy5pg78pfpr79srqk7jklr1wwa1m"; - system = "chirp-drakma"; - asd = "chirp-drakma"; - }); - systems = [ "chirp-drakma" ]; - lispLibs = [ (getAttr "chirp-core" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chlorophyll = (build-asdf-system { - pname = "chlorophyll"; - version = "20231021-git"; - asds = [ "chlorophyll" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chlorophyll/2023-10-21/chlorophyll-20231021-git.tgz"; - sha256 = "0q681pbcx4vcshrlligd5h07kakbjprb0kpf48z4glswy59vg8mg"; - system = "chlorophyll"; - asd = "chlorophyll"; - }); - systems = [ "chlorophyll" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chlorophyll-test = (build-asdf-system { - pname = "chlorophyll-test"; - version = "20231021-git"; - asds = [ "chlorophyll-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chlorophyll/2023-10-21/chlorophyll-20231021-git.tgz"; - sha256 = "0q681pbcx4vcshrlligd5h07kakbjprb0kpf48z4glswy59vg8mg"; - system = "chlorophyll-test"; - asd = "chlorophyll-test"; - }); - systems = [ "chlorophyll-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "chlorophyll" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chrome-native-messaging = (build-asdf-system { - pname = "chrome-native-messaging"; - version = "20150302-git"; - asds = [ "chrome-native-messaging" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chrome-native-messaging/2015-03-02/chrome-native-messaging-20150302-git.tgz"; - sha256 = "1fw02w5brpwa0kl7sx5b13fbcfv1ny8rwcj11ayj2q528i2xmpx5"; - system = "chrome-native-messaging"; - asd = "chrome-native-messaging"; - }); - systems = [ "chrome-native-messaging" ]; - lispLibs = [ (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chronicity = (build-asdf-system { - pname = "chronicity"; - version = "20190202-git"; - asds = [ "chronicity" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chronicity/2019-02-02/chronicity-20190202-git.tgz"; - sha256 = "1h5dlgvccffd8sqszqwilscysklzfcp374zl48rq14ywgv3rnwhl"; - system = "chronicity"; - asd = "chronicity"; - }); - systems = [ "chronicity" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chronicity-test = (build-asdf-system { - pname = "chronicity-test"; - version = "20190202-git"; - asds = [ "chronicity-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chronicity/2019-02-02/chronicity-20190202-git.tgz"; - sha256 = "1h5dlgvccffd8sqszqwilscysklzfcp374zl48rq14ywgv3rnwhl"; - system = "chronicity-test"; - asd = "chronicity-test"; - }); - systems = [ "chronicity-test" ]; - lispLibs = [ (getAttr "chronicity" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chtml-matcher = (build-asdf-system { - pname = "chtml-matcher"; - version = "20111001-git"; - asds = [ "chtml-matcher" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chtml-matcher/2011-10-01/chtml-matcher-20111001-git.tgz"; - sha256 = "1q1ksy2w0c4dcmq8543scl11x4crh1m5w29p1wjpqhxk826jx7fd"; - system = "chtml-matcher"; - asd = "chtml-matcher"; - }); - systems = [ "chtml-matcher" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "closure-html" self) (getAttr "f-underscore" self) (getAttr "stdutils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - chunga = (build-asdf-system { - pname = "chunga"; - version = "20241012-git"; - asds = [ "chunga" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/chunga/2024-10-12/chunga-20241012-git.tgz"; - sha256 = "17jswsp31dh1jpg2n60nn34wxf4z6vvxjq1avy50z9fnzywvikyi"; - system = "chunga"; - asd = "chunga"; - }); - systems = [ "chunga" ]; - lispLibs = [ (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - ci-utils = (build-asdf-system { - pname = "ci-utils"; - version = "20241012-git"; - asds = [ "ci-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ci-utils/2024-10-12/ci-utils-20241012-git.tgz"; - sha256 = "1wrr1v2r7kd668hyz54x28xh153l2qkl1gra3bk4wmqi3x7xyxdg"; - system = "ci-utils"; - asd = "ci-utils"; - }); - systems = [ "ci-utils" ]; - lispLibs = [ (getAttr "ci-utils-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ci-utils-features = (build-asdf-system { - pname = "ci-utils-features"; - version = "20241012-git"; - asds = [ "ci-utils-features" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ci-utils/2024-10-12/ci-utils-20241012-git.tgz"; - sha256 = "1wrr1v2r7kd668hyz54x28xh153l2qkl1gra3bk4wmqi3x7xyxdg"; - system = "ci-utils-features"; - asd = "ci-utils-features"; - }); - systems = [ "ci-utils-features" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ciao = (build-asdf-system { - pname = "ciao"; - version = "20241012-git"; - asds = [ "ciao" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ciao/2024-10-12/ciao-20241012-git.tgz"; - sha256 = "1x443k02kl5iyq6awv2vqm08d9x9f92hjivqv2c5xdamki7y513s"; - system = "ciao"; - asd = "ciao"; - }); - systems = [ "ciao" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "dexador" self) (getAttr "hunchentoot" self) (getAttr "trivial-open-browser" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - circular-streams = (build-asdf-system { - pname = "circular-streams"; - version = "20161204-git"; - asds = [ "circular-streams" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/circular-streams/2016-12-04/circular-streams-20161204-git.tgz"; - sha256 = "1wpw6d5cciyqcf92f7mvihak52pd5s47kk4qq6f0r2z2as68p5rs"; - system = "circular-streams"; - asd = "circular-streams"; - }); - systems = [ "circular-streams" ]; - lispLibs = [ (getAttr "fast-io" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - circular-streams-test = (build-asdf-system { - pname = "circular-streams-test"; - version = "20161204-git"; - asds = [ "circular-streams-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/circular-streams/2016-12-04/circular-streams-20161204-git.tgz"; - sha256 = "1wpw6d5cciyqcf92f7mvihak52pd5s47kk4qq6f0r2z2as68p5rs"; - system = "circular-streams-test"; - asd = "circular-streams-test"; - }); - systems = [ "circular-streams-test" ]; - lispLibs = [ (getAttr "circular-streams" self) (getAttr "cl-test-more" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - city-hash = (build-asdf-system { - pname = "city-hash"; - version = "20200925-git"; - asds = [ "city-hash" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/city-hash/2020-09-25/city-hash-20200925-git.tgz"; - sha256 = "10ksl402aa37sn78hnvlvpqibr66qzpjvf2x4a789gnl411cf44a"; - system = "city-hash"; - asd = "city-hash"; - }); - systems = [ "city-hash" ]; - lispLibs = [ (getAttr "com_dot_google_dot_base" self) (getAttr "nibbles" self) (getAttr "swap-bytes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - city-hash-test = (build-asdf-system { - pname = "city-hash-test"; - version = "20200925-git"; - asds = [ "city-hash-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/city-hash/2020-09-25/city-hash-20200925-git.tgz"; - sha256 = "10ksl402aa37sn78hnvlvpqibr66qzpjvf2x4a789gnl411cf44a"; - system = "city-hash-test"; - asd = "city-hash-test"; - }); - systems = [ "city-hash-test" ]; - lispLibs = [ (getAttr "city-hash" self) (getAttr "hu_dot_dwim_dot_stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ckr-tables = (build-asdf-system { - pname = "ckr-tables"; - version = "20241012-git"; - asds = [ "ckr-tables" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-critic/2024-10-12/lisp-critic-20241012-git.tgz"; - sha256 = "19czs2m8h3kgwjd10pdk9r5kazbgly8g82a5q3bs7pqkja42i7x7"; - system = "ckr-tables"; - asd = "ckr-tables"; - }); - systems = [ "ckr-tables" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl_plus_ssl = (build-asdf-system { - pname = "cl+ssl"; - version = "20231021-git"; - asds = [ "cl+ssl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl+ssl/2023-10-21/cl+ssl-20231021-git.tgz"; - sha256 = "0v0kx2m5355jkdshmj0z923c5rlvdl2n11rb3hjbv3kssdfsbs0s"; - system = "cl+ssl"; - asd = "cl+ssl"; - }); - systems = [ "cl+ssl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "flexi-streams" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) (getAttr "trivial-gray-streams" self) (getAttr "usocket" self) ]; - meta = {}; - }); - cl_plus_ssl_dot_test = (build-asdf-system { - pname = "cl+ssl.test"; - version = "20231021-git"; - asds = [ "cl+ssl.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl+ssl/2023-10-21/cl+ssl-20231021-git.tgz"; - sha256 = "0v0kx2m5355jkdshmj0z923c5rlvdl2n11rb3hjbv3kssdfsbs0s"; - system = "cl+ssl.test"; - asd = "cl+ssl.test"; - }); - systems = [ "cl+ssl.test" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl_plus_ssl" self) (getAttr "cl-coveralls" self) (getAttr "fiveam" self) (getAttr "trivial-sockets" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-6502 = (build-asdf-system { - pname = "cl-6502"; - version = "20241012-git"; - asds = [ "cl-6502" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-6502/2024-10-12/cl-6502-20241012-git.tgz"; - sha256 = "1cj38bi12i7ji3m8dd8gxb17dlna2v8s3b3h6b0a9pvmv6wchpmz"; - system = "cl-6502"; - asd = "cl-6502"; - }); - systems = [ "cl-6502" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-aa = (build-asdf-system { - pname = "cl-aa"; - version = "20241012-git"; - asds = [ "cl-aa" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-vectors/2024-10-12/cl-vectors-20241012-git.tgz"; - sha256 = "1nkmmn38y6af10ysff3g2qkf5lb2601dcjp5rffsjh6bv2ik2jd5"; - system = "cl-aa"; - asd = "cl-aa"; - }); - systems = [ "cl-aa" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-aa-misc = (build-asdf-system { - pname = "cl-aa-misc"; - version = "20241012-git"; - asds = [ "cl-aa-misc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-vectors/2024-10-12/cl-vectors-20241012-git.tgz"; - sha256 = "1nkmmn38y6af10ysff3g2qkf5lb2601dcjp5rffsjh6bv2ik2jd5"; - system = "cl-aa-misc"; - asd = "cl-aa-misc"; - }); - systems = [ "cl-aa-misc" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-acronyms = (build-asdf-system { - pname = "cl-acronyms"; - version = "20150302-git"; - asds = [ "cl-acronyms" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-acronyms/2015-03-02/cl-acronyms-20150302-git.tgz"; - sha256 = "1b827g6n87i81wbqzvmlq0yn41kfa502v5ssbh2wh1b4xznhn8cc"; - system = "cl-acronyms"; - asd = "cl-acronyms"; - }); - systems = [ "cl-acronyms" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-actors = (build-asdf-system { - pname = "cl-actors"; - version = "20191130-git"; - asds = [ "cl-actors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-lisp-actors/2019-11-30/common-lisp-actors-20191130-git.tgz"; - sha256 = "0snf91yivxq6jcbvm3l6b05lcka7jrzciqd4m841amghfw32clfn"; - system = "cl-actors"; - asd = "cl-actors"; - }); - systems = [ "cl-actors" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-advice = (build-asdf-system { - pname = "cl-advice"; - version = "20230214-git"; - asds = [ "cl-advice" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-advice/2023-02-14/cl-advice-20230214-git.tgz"; - sha256 = "038fhy7chgn9racrcikqncyiq5yqngs6d5ahxz7jkypixcdz48jx"; - system = "cl-advice"; - asd = "cl-advice"; - }); - systems = [ "cl-advice" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-advice-tests = (build-asdf-system { - pname = "cl-advice-tests"; - version = "20230214-git"; - asds = [ "cl-advice-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-advice/2023-02-14/cl-advice-20230214-git.tgz"; - sha256 = "038fhy7chgn9racrcikqncyiq5yqngs6d5ahxz7jkypixcdz48jx"; - system = "cl-advice-tests"; - asd = "cl-advice-tests"; - }); - systems = [ "cl-advice-tests" ]; - lispLibs = [ (getAttr "cl-advice" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-alc = (build-asdf-system { - pname = "cl-alc"; - version = "20221106-git"; - asds = [ "cl-alc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-openal/2022-11-06/cl-openal-20221106-git.tgz"; - sha256 = "0jmp81mf23ckcm4knnh0q7zpmyls5220imaqbmnl0xvvra10b1zy"; - system = "cl-alc"; - asd = "cl-alc"; - }); - systems = [ "cl-alc" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-openal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-algebraic-data-type = (build-asdf-system { - pname = "cl-algebraic-data-type"; - version = "20241012-git"; - asds = [ "cl-algebraic-data-type" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-algebraic-data-type/2024-10-12/cl-algebraic-data-type-20241012-git.tgz"; - sha256 = "02bfx9g4267f7f85banmfy15adyvlzaz3flia8zmhlzhpx7j4bj6"; - system = "cl-algebraic-data-type"; - asd = "cl-algebraic-data-type"; - }); - systems = [ "cl-algebraic-data-type" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "global-vars" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-all = (build-asdf-system { - pname = "cl-all"; - version = "20241012-git"; - asds = [ "cl-all" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-all/2024-10-12/cl-all-20241012-git.tgz"; - sha256 = "02n30b3yp949fxwnb9wr3m9hd5h1kcmxcbjc8c5fj4ihphf8sd7d"; - system = "cl-all"; - asd = "cl-all"; - }); - systems = [ "cl-all" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-alut = (build-asdf-system { - pname = "cl-alut"; - version = "20221106-git"; - asds = [ "cl-alut" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-openal/2022-11-06/cl-openal-20221106-git.tgz"; - sha256 = "0jmp81mf23ckcm4knnh0q7zpmyls5220imaqbmnl0xvvra10b1zy"; - system = "cl-alut"; - asd = "cl-alut"; - }); - systems = [ "cl-alut" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-openal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-amqp = (build-asdf-system { - pname = "cl-amqp"; - version = "v0.4.1"; - asds = [ "cl-amqp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-amqp/2019-10-08/cl-amqp-v0.4.1.tgz"; - sha256 = "1ggd77ckfr54z7z5yi8d04k310x2dhf53qija8dzjhk1r9py20vz"; - system = "cl-amqp"; - asd = "cl-amqp"; - }); - systems = [ "cl-amqp" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-interpol" self) (getAttr "collectors" self) (getAttr "fast-io" self) (getAttr "local-time" self) (getAttr "log4cl" self) (getAttr "nibbles" self) (getAttr "trivial-utf-8" self) (getAttr "wu-decimal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-amqp_dot_test = (build-asdf-system { - pname = "cl-amqp.test"; - version = "v0.4.1"; - asds = [ "cl-amqp.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-amqp/2019-10-08/cl-amqp-v0.4.1.tgz"; - sha256 = "1ggd77ckfr54z7z5yi8d04k310x2dhf53qija8dzjhk1r9py20vz"; - system = "cl-amqp.test"; - asd = "cl-amqp.test"; - }); - systems = [ "cl-amqp.test" ]; - lispLibs = [ (getAttr "cl-amqp" self) (getAttr "cl-interpol" self) (getAttr "log4cl" self) (getAttr "mw-equiv" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana = (build-asdf-system { - pname = "cl-ana"; - version = "20220707-git"; - asds = [ "cl-ana" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana"; - asd = "cl-ana"; - }); - systems = [ "cl-ana" ]; - lispLibs = [ (getAttr "cl-ana_dot_array-utils" self) (getAttr "cl-ana_dot_binary-tree" self) (getAttr "cl-ana_dot_calculus" self) (getAttr "cl-ana_dot_clos-utils" self) (getAttr "cl-ana_dot_columnar-table" self) (getAttr "cl-ana_dot_csv-table" self) (getAttr "cl-ana_dot_error-propogation" self) (getAttr "cl-ana_dot_file-utils" self) (getAttr "cl-ana_dot_fitting" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_hash-table-utils" self) (getAttr "cl-ana_dot_hdf-table" self) (getAttr "cl-ana_dot_histogram" self) (getAttr "cl-ana_dot_int-char" self) (getAttr "cl-ana_dot_linear-algebra" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_lorentz" self) (getAttr "cl-ana_dot_makeres" self) (getAttr "cl-ana_dot_makeres-block" self) (getAttr "cl-ana_dot_makeres-branch" self) (getAttr "cl-ana_dot_makeres-graphviz" self) (getAttr "cl-ana_dot_makeres-macro" self) (getAttr "cl-ana_dot_makeres-progress" self) (getAttr "cl-ana_dot_makeres-table" self) (getAttr "cl-ana_dot_makeres-utils" self) (getAttr "cl-ana_dot_map" self) (getAttr "cl-ana_dot_math-functions" self) (getAttr "cl-ana_dot_ntuple-table" self) (getAttr "cl-ana_dot_package-utils" self) (getAttr "cl-ana_dot_pathname-utils" self) (getAttr "cl-ana_dot_plotting" self) (getAttr "cl-ana_dot_quantity" self) (getAttr "cl-ana_dot_reusable-table" self) (getAttr "cl-ana_dot_serialization" self) (getAttr "cl-ana_dot_spline" self) (getAttr "cl-ana_dot_statistical-learning" self) (getAttr "cl-ana_dot_statistics" self) (getAttr "cl-ana_dot_table" self) (getAttr "cl-ana_dot_table-utils" self) (getAttr "cl-ana_dot_table-viewing" self) (getAttr "cl-ana_dot_tensor" self) ]; - meta = {}; - }); - cl-ana_dot_array-utils = (build-asdf-system { - pname = "cl-ana.array-utils"; - version = "20220707-git"; - asds = [ "cl-ana.array-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.array-utils"; - asd = "cl-ana.array-utils"; - }); - systems = [ "cl-ana.array-utils" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_binary-tree = (build-asdf-system { - pname = "cl-ana.binary-tree"; - version = "20220707-git"; - asds = [ "cl-ana.binary-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.binary-tree"; - asd = "cl-ana.binary-tree"; - }); - systems = [ "cl-ana.binary-tree" ]; - lispLibs = [ (getAttr "cl-ana_dot_functional-utils" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_calculus = (build-asdf-system { - pname = "cl-ana.calculus"; - version = "20220707-git"; - asds = [ "cl-ana.calculus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.calculus"; - asd = "cl-ana.calculus"; - }); - systems = [ "cl-ana.calculus" ]; - lispLibs = [ (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_linear-algebra" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_clos-utils = (build-asdf-system { - pname = "cl-ana.clos-utils"; - version = "20220707-git"; - asds = [ "cl-ana.clos-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.clos-utils"; - asd = "cl-ana.clos-utils"; - }); - systems = [ "cl-ana.clos-utils" ]; - lispLibs = [ (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_symbol-utils" self) (getAttr "cl-ana_dot_tensor" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_columnar-table = (build-asdf-system { - pname = "cl-ana.columnar-table"; - version = "20220707-git"; - asds = [ "cl-ana.columnar-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.columnar-table"; - asd = "cl-ana.columnar-table"; - }); - systems = [ "cl-ana.columnar-table" ]; - lispLibs = [ (getAttr "cl-ana_dot_reusable-table" self) (getAttr "cl-ana_dot_table" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_csv-table = (build-asdf-system { - pname = "cl-ana.csv-table"; - version = "20220707-git"; - asds = [ "cl-ana.csv-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.csv-table"; - asd = "cl-ana.csv-table"; - }); - systems = [ "cl-ana.csv-table" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "antik" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_table" self) (getAttr "cl-csv" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_error-propogation = (build-asdf-system { - pname = "cl-ana.error-propogation"; - version = "20220707-git"; - asds = [ "cl-ana.error-propogation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.error-propogation"; - asd = "cl-ana.error-propogation"; - }); - systems = [ "cl-ana.error-propogation" ]; - lispLibs = [ (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_math-functions" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_file-utils = (build-asdf-system { - pname = "cl-ana.file-utils"; - version = "20220707-git"; - asds = [ "cl-ana.file-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.file-utils"; - asd = "cl-ana.file-utils"; - }); - systems = [ "cl-ana.file-utils" ]; - lispLibs = [ (getAttr "external-program" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_fitting = (build-asdf-system { - pname = "cl-ana.fitting"; - version = "20220707-git"; - asds = [ "cl-ana.fitting" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.fitting"; - asd = "cl-ana.fitting"; - }); - systems = [ "cl-ana.fitting" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_error-propogation" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_map" self) (getAttr "cl-ana_dot_math-functions" self) (getAttr "gsll" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_functional-utils = (build-asdf-system { - pname = "cl-ana.functional-utils"; - version = "20220707-git"; - asds = [ "cl-ana.functional-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.functional-utils"; - asd = "cl-ana.functional-utils"; - }); - systems = [ "cl-ana.functional-utils" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_generic-math = (build-asdf-system { - pname = "cl-ana.generic-math"; - version = "20220707-git"; - asds = [ "cl-ana.generic-math" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.generic-math"; - asd = "cl-ana.generic-math"; - }); - systems = [ "cl-ana.generic-math" ]; - lispLibs = [ (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_package-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_gnuplot-interface = (build-asdf-system { - pname = "cl-ana.gnuplot-interface"; - version = "20220707-git"; - asds = [ "cl-ana.gnuplot-interface" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.gnuplot-interface"; - asd = "cl-ana.gnuplot-interface"; - }); - systems = [ "cl-ana.gnuplot-interface" ]; - lispLibs = [ (getAttr "external-program" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_gsl-cffi = (build-asdf-system { - pname = "cl-ana.gsl-cffi"; - version = "20220707-git"; - asds = [ "cl-ana.gsl-cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.gsl-cffi"; - asd = "cl-ana.gsl-cffi"; - }); - systems = [ "cl-ana.gsl-cffi" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_hash-table-utils = (build-asdf-system { - pname = "cl-ana.hash-table-utils"; - version = "20220707-git"; - asds = [ "cl-ana.hash-table-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.hash-table-utils"; - asd = "cl-ana.hash-table-utils"; - }); - systems = [ "cl-ana.hash-table-utils" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_hdf-cffi = (build-asdf-system { - pname = "cl-ana.hdf-cffi"; - version = "20220707-git"; - asds = [ "cl-ana.hdf-cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.hdf-cffi"; - asd = "cl-ana.hdf-cffi"; - }); - systems = [ "cl-ana.hdf-cffi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_hdf-table = (build-asdf-system { - pname = "cl-ana.hdf-table"; - version = "20220707-git"; - asds = [ "cl-ana.hdf-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.hdf-table"; - asd = "cl-ana.hdf-table"; - }); - systems = [ "cl-ana.hdf-table" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_binary-tree" self) (getAttr "cl-ana_dot_hdf-typespec" self) (getAttr "cl-ana_dot_hdf-utils" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_memoization" self) (getAttr "cl-ana_dot_table" self) (getAttr "cl-ana_dot_typed-table" self) (getAttr "cl-ana_dot_typespec" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_hdf-typespec = (build-asdf-system { - pname = "cl-ana.hdf-typespec"; - version = "20220707-git"; - asds = [ "cl-ana.hdf-typespec" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.hdf-typespec"; - asd = "cl-ana.hdf-typespec"; - }); - systems = [ "cl-ana.hdf-typespec" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-ana_dot_hdf-cffi" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_memoization" self) (getAttr "cl-ana_dot_string-utils" self) (getAttr "cl-ana_dot_symbol-utils" self) (getAttr "cl-ana_dot_typespec" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_hdf-utils = (build-asdf-system { - pname = "cl-ana.hdf-utils"; - version = "20220707-git"; - asds = [ "cl-ana.hdf-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.hdf-utils"; - asd = "cl-ana.hdf-utils"; - }); - systems = [ "cl-ana.hdf-utils" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-ana_dot_hdf-cffi" self) (getAttr "cl-ana_dot_hdf-typespec" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_memoization" self) (getAttr "cl-ana_dot_pathname-utils" self) (getAttr "cl-ana_dot_string-utils" self) (getAttr "cl-ana_dot_typespec" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_histogram = (build-asdf-system { - pname = "cl-ana.histogram"; - version = "20220707-git"; - asds = [ "cl-ana.histogram" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.histogram"; - asd = "cl-ana.histogram"; - }); - systems = [ "cl-ana.histogram" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_binary-tree" self) (getAttr "cl-ana_dot_clos-utils" self) (getAttr "cl-ana_dot_fitting" self) (getAttr "cl-ana_dot_functional-utils" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_hash-table-utils" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_map" self) (getAttr "cl-ana_dot_symbol-utils" self) (getAttr "cl-ana_dot_tensor" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_int-char = (build-asdf-system { - pname = "cl-ana.int-char"; - version = "20220707-git"; - asds = [ "cl-ana.int-char" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.int-char"; - asd = "cl-ana.int-char"; - }); - systems = [ "cl-ana.int-char" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_linear-algebra = (build-asdf-system { - pname = "cl-ana.linear-algebra"; - version = "20220707-git"; - asds = [ "cl-ana.linear-algebra" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.linear-algebra"; - asd = "cl-ana.linear-algebra"; - }); - systems = [ "cl-ana.linear-algebra" ]; - lispLibs = [ (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_math-functions" self) (getAttr "cl-ana_dot_tensor" self) (getAttr "gsll" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_list-utils = (build-asdf-system { - pname = "cl-ana.list-utils"; - version = "20220707-git"; - asds = [ "cl-ana.list-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.list-utils"; - asd = "cl-ana.list-utils"; - }); - systems = [ "cl-ana.list-utils" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_functional-utils" self) (getAttr "cl-ana_dot_string-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_lorentz = (build-asdf-system { - pname = "cl-ana.lorentz"; - version = "20220707-git"; - asds = [ "cl-ana.lorentz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.lorentz"; - asd = "cl-ana.lorentz"; - }); - systems = [ "cl-ana.lorentz" ]; - lispLibs = [ (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_linear-algebra" self) (getAttr "cl-ana_dot_tensor" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_macro-utils = (build-asdf-system { - pname = "cl-ana.macro-utils"; - version = "20220707-git"; - asds = [ "cl-ana.macro-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.macro-utils"; - asd = "cl-ana.macro-utils"; - }); - systems = [ "cl-ana.macro-utils" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_string-utils" self) (getAttr "cl-ana_dot_symbol-utils" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_makeres = (build-asdf-system { - pname = "cl-ana.makeres"; - version = "20220707-git"; - asds = [ "cl-ana.makeres" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.makeres"; - asd = "cl-ana.makeres"; - }); - systems = [ "cl-ana.makeres" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_error-propogation" self) (getAttr "cl-ana_dot_file-utils" self) (getAttr "cl-ana_dot_functional-utils" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_hash-table-utils" self) (getAttr "cl-ana_dot_hdf-utils" self) (getAttr "cl-ana_dot_histogram" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_map" self) (getAttr "cl-ana_dot_memoization" self) (getAttr "cl-ana_dot_pathname-utils" self) (getAttr "cl-ana_dot_plotting" self) (getAttr "cl-ana_dot_reusable-table" self) (getAttr "cl-ana_dot_serialization" self) (getAttr "cl-ana_dot_string-utils" self) (getAttr "cl-ana_dot_symbol-utils" self) (getAttr "cl-ana_dot_table" self) (getAttr "cl-fad" self) (getAttr "external-program" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_makeres-block = (build-asdf-system { - pname = "cl-ana.makeres-block"; - version = "20220707-git"; - asds = [ "cl-ana.makeres-block" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.makeres-block"; - asd = "cl-ana.makeres-block"; - }); - systems = [ "cl-ana.makeres-block" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_makeres" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_makeres-branch = (build-asdf-system { - pname = "cl-ana.makeres-branch"; - version = "20220707-git"; - asds = [ "cl-ana.makeres-branch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.makeres-branch"; - asd = "cl-ana.makeres-branch"; - }); - systems = [ "cl-ana.makeres-branch" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_hash-table-utils" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_makeres" self) (getAttr "cl-ana_dot_map" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_makeres-graphviz = (build-asdf-system { - pname = "cl-ana.makeres-graphviz"; - version = "20220707-git"; - asds = [ "cl-ana.makeres-graphviz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.makeres-graphviz"; - asd = "cl-ana.makeres-graphviz"; - }); - systems = [ "cl-ana.makeres-graphviz" ]; - lispLibs = [ (getAttr "cl-ana_dot_makeres" self) (getAttr "external-program" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_makeres-macro = (build-asdf-system { - pname = "cl-ana.makeres-macro"; - version = "20220707-git"; - asds = [ "cl-ana.makeres-macro" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.makeres-macro"; - asd = "cl-ana.makeres-macro"; - }); - systems = [ "cl-ana.makeres-macro" ]; - lispLibs = [ (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_makeres" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_makeres-progress = (build-asdf-system { - pname = "cl-ana.makeres-progress"; - version = "20220707-git"; - asds = [ "cl-ana.makeres-progress" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.makeres-progress"; - asd = "cl-ana.makeres-progress"; - }); - systems = [ "cl-ana.makeres-progress" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_makeres" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_makeres-table = (build-asdf-system { - pname = "cl-ana.makeres-table"; - version = "20220707-git"; - asds = [ "cl-ana.makeres-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.makeres-table"; - asd = "cl-ana.makeres-table"; - }); - systems = [ "cl-ana.makeres-table" ]; - lispLibs = [ (getAttr "cl-ana_dot_csv-table" self) (getAttr "cl-ana_dot_hash-table-utils" self) (getAttr "cl-ana_dot_hdf-table" self) (getAttr "cl-ana_dot_hdf-utils" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_makeres" self) (getAttr "cl-ana_dot_makeres-macro" self) (getAttr "cl-ana_dot_memoization" self) (getAttr "cl-ana_dot_ntuple-table" self) (getAttr "cl-ana_dot_reusable-table" self) (getAttr "cl-ana_dot_string-utils" self) (getAttr "cl-ana_dot_table" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_makeres-utils = (build-asdf-system { - pname = "cl-ana.makeres-utils"; - version = "20220707-git"; - asds = [ "cl-ana.makeres-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.makeres-utils"; - asd = "cl-ana.makeres-utils"; - }); - systems = [ "cl-ana.makeres-utils" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_file-utils" self) (getAttr "cl-ana_dot_fitting" self) (getAttr "cl-ana_dot_functional-utils" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_histogram" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_makeres" self) (getAttr "cl-ana_dot_map" self) (getAttr "cl-ana_dot_pathname-utils" self) (getAttr "cl-ana_dot_plotting" self) (getAttr "cl-ana_dot_reusable-table" self) (getAttr "cl-ana_dot_string-utils" self) (getAttr "cl-ana_dot_symbol-utils" self) (getAttr "cl-ana_dot_table" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_map = (build-asdf-system { - pname = "cl-ana.map"; - version = "20220707-git"; - asds = [ "cl-ana.map" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.map"; - asd = "cl-ana.map"; - }); - systems = [ "cl-ana.map" ]; - lispLibs = [ (getAttr "cl-ana_dot_hash-table-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_math-functions = (build-asdf-system { - pname = "cl-ana.math-functions"; - version = "20220707-git"; - asds = [ "cl-ana.math-functions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.math-functions"; - asd = "cl-ana.math-functions"; - }); - systems = [ "cl-ana.math-functions" ]; - lispLibs = [ (getAttr "cl-ana_dot_generic-math" self) (getAttr "gsll" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_memoization = (build-asdf-system { - pname = "cl-ana.memoization"; - version = "20220707-git"; - asds = [ "cl-ana.memoization" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.memoization"; - asd = "cl-ana.memoization"; - }); - systems = [ "cl-ana.memoization" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_ntuple-table = (build-asdf-system { - pname = "cl-ana.ntuple-table"; - version = "20220707-git"; - asds = [ "cl-ana.ntuple-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.ntuple-table"; - asd = "cl-ana.ntuple-table"; - }); - systems = [ "cl-ana.ntuple-table" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-ana_dot_gsl-cffi" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_table" self) (getAttr "cl-ana_dot_typed-table" self) (getAttr "cl-ana_dot_typespec" self) (getAttr "gsll" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_package-utils = (build-asdf-system { - pname = "cl-ana.package-utils"; - version = "20220707-git"; - asds = [ "cl-ana.package-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.package-utils"; - asd = "cl-ana.package-utils"; - }); - systems = [ "cl-ana.package-utils" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_pathname-utils = (build-asdf-system { - pname = "cl-ana.pathname-utils"; - version = "20220707-git"; - asds = [ "cl-ana.pathname-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.pathname-utils"; - asd = "cl-ana.pathname-utils"; - }); - systems = [ "cl-ana.pathname-utils" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_plotting = (build-asdf-system { - pname = "cl-ana.plotting"; - version = "20220707-git"; - asds = [ "cl-ana.plotting" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.plotting"; - asd = "cl-ana.plotting"; - }); - systems = [ "cl-ana.plotting" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_error-propogation" self) (getAttr "cl-ana_dot_functional-utils" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_gnuplot-interface" self) (getAttr "cl-ana_dot_histogram" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_map" self) (getAttr "cl-ana_dot_math-functions" self) (getAttr "cl-ana_dot_pathname-utils" self) (getAttr "cl-ana_dot_string-utils" self) (getAttr "cl-ana_dot_tensor" self) (getAttr "external-program" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_quantity = (build-asdf-system { - pname = "cl-ana.quantity"; - version = "20220707-git"; - asds = [ "cl-ana.quantity" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.quantity"; - asd = "cl-ana.quantity"; - }); - systems = [ "cl-ana.quantity" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_error-propogation" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_math-functions" self) (getAttr "cl-ana_dot_symbol-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_reusable-table = (build-asdf-system { - pname = "cl-ana.reusable-table"; - version = "20220707-git"; - asds = [ "cl-ana.reusable-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.reusable-table"; - asd = "cl-ana.reusable-table"; - }); - systems = [ "cl-ana.reusable-table" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_table" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_serialization = (build-asdf-system { - pname = "cl-ana.serialization"; - version = "20220707-git"; - asds = [ "cl-ana.serialization" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.serialization"; - asd = "cl-ana.serialization"; - }); - systems = [ "cl-ana.serialization" ]; - lispLibs = [ (getAttr "cl-ana_dot_error-propogation" self) (getAttr "cl-ana_dot_hdf-table" self) (getAttr "cl-ana_dot_hdf-utils" self) (getAttr "cl-ana_dot_histogram" self) (getAttr "cl-ana_dot_int-char" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_typespec" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_spline = (build-asdf-system { - pname = "cl-ana.spline"; - version = "20220707-git"; - asds = [ "cl-ana.spline" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.spline"; - asd = "cl-ana.spline"; - }); - systems = [ "cl-ana.spline" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-ana_dot_fitting" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_math-functions" self) (getAttr "cl-ana_dot_tensor" self) (getAttr "gsll" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_statistical-learning = (build-asdf-system { - pname = "cl-ana.statistical-learning"; - version = "20220707-git"; - asds = [ "cl-ana.statistical-learning" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.statistical-learning"; - asd = "cl-ana.statistical-learning"; - }); - systems = [ "cl-ana.statistical-learning" ]; - lispLibs = [ (getAttr "cl-ana_dot_functional-utils" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_histogram" self) (getAttr "cl-ana_dot_linear-algebra" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_map" self) (getAttr "cl-ana_dot_math-functions" self) (getAttr "cl-ana_dot_statistics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_statistics = (build-asdf-system { - pname = "cl-ana.statistics"; - version = "20220707-git"; - asds = [ "cl-ana.statistics" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.statistics"; - asd = "cl-ana.statistics"; - }); - systems = [ "cl-ana.statistics" ]; - lispLibs = [ (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_histogram" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_map" self) (getAttr "cl-ana_dot_math-functions" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_string-utils = (build-asdf-system { - pname = "cl-ana.string-utils"; - version = "20220707-git"; - asds = [ "cl-ana.string-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.string-utils"; - asd = "cl-ana.string-utils"; - }); - systems = [ "cl-ana.string-utils" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_symbol-utils = (build-asdf-system { - pname = "cl-ana.symbol-utils"; - version = "20220707-git"; - asds = [ "cl-ana.symbol-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.symbol-utils"; - asd = "cl-ana.symbol-utils"; - }); - systems = [ "cl-ana.symbol-utils" ]; - lispLibs = [ (getAttr "cl-ana_dot_list-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_table = (build-asdf-system { - pname = "cl-ana.table"; - version = "20220707-git"; - asds = [ "cl-ana.table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.table"; - asd = "cl-ana.table"; - }); - systems = [ "cl-ana.table" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_functional-utils" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_string-utils" self) (getAttr "cl-ana_dot_symbol-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_table-utils = (build-asdf-system { - pname = "cl-ana.table-utils"; - version = "20220707-git"; - asds = [ "cl-ana.table-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.table-utils"; - asd = "cl-ana.table-utils"; - }); - systems = [ "cl-ana.table-utils" ]; - lispLibs = [ (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_hash-table-utils" self) (getAttr "cl-ana_dot_statistics" self) (getAttr "cl-ana_dot_string-utils" self) (getAttr "cl-ana_dot_symbol-utils" self) (getAttr "cl-ana_dot_table" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_table-viewing = (build-asdf-system { - pname = "cl-ana.table-viewing"; - version = "20220707-git"; - asds = [ "cl-ana.table-viewing" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.table-viewing"; - asd = "cl-ana.table-viewing"; - }); - systems = [ "cl-ana.table-viewing" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_histogram" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_plotting" self) (getAttr "cl-ana_dot_string-utils" self) (getAttr "cl-ana_dot_table" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_tensor = (build-asdf-system { - pname = "cl-ana.tensor"; - version = "20220707-git"; - asds = [ "cl-ana.tensor" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.tensor"; - asd = "cl-ana.tensor"; - }); - systems = [ "cl-ana.tensor" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_generic-math" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_macro-utils" self) (getAttr "cl-ana_dot_symbol-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_typed-table = (build-asdf-system { - pname = "cl-ana.typed-table"; - version = "20220707-git"; - asds = [ "cl-ana.typed-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.typed-table"; - asd = "cl-ana.typed-table"; - }); - systems = [ "cl-ana.typed-table" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_string-utils" self) (getAttr "cl-ana_dot_symbol-utils" self) (getAttr "cl-ana_dot_table" self) (getAttr "cl-ana_dot_typespec" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ana_dot_typespec = (build-asdf-system { - pname = "cl-ana.typespec"; - version = "20220707-git"; - asds = [ "cl-ana.typespec" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; - sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; - system = "cl-ana.typespec"; - asd = "cl-ana.typespec"; - }); - systems = [ "cl-ana.typespec" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-ana_dot_int-char" self) (getAttr "cl-ana_dot_list-utils" self) (getAttr "cl-ana_dot_memoization" self) (getAttr "cl-ana_dot_string-utils" self) (getAttr "cl-ana_dot_symbol-utils" self) (getAttr "cl-ana_dot_tensor" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-android = (build-asdf-system { - pname = "cl-android"; - version = "20150804-git"; - asds = [ "cl-android" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sl4a/2015-08-04/cl-sl4a-20150804-git.tgz"; - sha256 = "0lqla60apkc8xfiyi43w18dldf0m8z5q290wv3d89qf0n9gwk3cr"; - system = "cl-android"; - asd = "cl-android"; - }); - systems = [ "cl-android" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-annot = (build-asdf-system { - pname = "cl-annot"; - version = "20150608-git"; - asds = [ "cl-annot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-annot/2015-06-08/cl-annot-20150608-git.tgz"; - sha256 = "1wq1gs9jjd5m6iwrv06c2d7i5dvqsfjcljgbspfbc93cg5xahk4n"; - system = "cl-annot"; - asd = "cl-annot"; - }); - systems = [ "cl-annot" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = {}; - }); - cl-annot-prove = (build-asdf-system { - pname = "cl-annot-prove"; - version = "20150923-git"; - asds = [ "cl-annot-prove" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-annot-prove/2015-09-23/cl-annot-prove-20150923-git.tgz"; - sha256 = "000nlxxs1id1pccp3y5s9xnm76fc5r87q0bxmjrpklxwwf5y8wwy"; - system = "cl-annot-prove"; - asd = "cl-annot-prove"; - }); - systems = [ "cl-annot-prove" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "cl-syntax" self) (getAttr "cl-syntax-annot" self) (getAttr "prove" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-annot-prove-test = (build-asdf-system { - pname = "cl-annot-prove-test"; - version = "20150923-git"; - asds = [ "cl-annot-prove-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-annot-prove/2015-09-23/cl-annot-prove-20150923-git.tgz"; - sha256 = "000nlxxs1id1pccp3y5s9xnm76fc5r87q0bxmjrpklxwwf5y8wwy"; - system = "cl-annot-prove-test"; - asd = "cl-annot-prove-test"; - }); - systems = [ "cl-annot-prove-test" ]; - lispLibs = [ (getAttr "cl-annot-prove" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-annot-revisit = (build-asdf-system { - pname = "cl-annot-revisit"; - version = "20221106-git"; - asds = [ "cl-annot-revisit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-annot-revisit/2022-11-06/cl-annot-revisit-20221106-git.tgz"; - sha256 = "0jlllgq14bi1rddzlmq9wfs4vb24apgqz17wfd79kjjcmnzzjp4m"; - system = "cl-annot-revisit"; - asd = "cl-annot-revisit"; - }); - systems = [ "cl-annot-revisit" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-annot-revisit-compat = (build-asdf-system { - pname = "cl-annot-revisit-compat"; - version = "20221106-git"; - asds = [ "cl-annot-revisit-compat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-annot-revisit/2022-11-06/cl-annot-revisit-20221106-git.tgz"; - sha256 = "0jlllgq14bi1rddzlmq9wfs4vb24apgqz17wfd79kjjcmnzzjp4m"; - system = "cl-annot-revisit-compat"; - asd = "cl-annot-revisit-compat"; - }); - systems = [ "cl-annot-revisit-compat" ]; - lispLibs = [ (getAttr "cl-annot-revisit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-annot-revisit-test = (build-asdf-system { - pname = "cl-annot-revisit-test"; - version = "20221106-git"; - asds = [ "cl-annot-revisit-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-annot-revisit/2022-11-06/cl-annot-revisit-20221106-git.tgz"; - sha256 = "0jlllgq14bi1rddzlmq9wfs4vb24apgqz17wfd79kjjcmnzzjp4m"; - system = "cl-annot-revisit-test"; - asd = "cl-annot-revisit-test"; - }); - systems = [ "cl-annot-revisit-test" ]; - lispLibs = [ (getAttr "_1am" self) (getAttr "cl-annot-revisit" self) (getAttr "cl-annot-revisit-compat" self) (getAttr "trivial-macroexpand-all" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-anonfun = (build-asdf-system { - pname = "cl-anonfun"; - version = "20111203-git"; - asds = [ "cl-anonfun" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-anonfun/2011-12-03/cl-anonfun-20111203-git.tgz"; - sha256 = "086x2vjvasdy9bhikvdzx34nrq008c0sfkq3ncv0i9mhfk5xwp2j"; - system = "cl-anonfun"; - asd = "cl-anonfun"; - }); - systems = [ "cl-anonfun" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-ansi-term = (build-asdf-system { - pname = "cl-ansi-term"; - version = "20241012-git"; - asds = [ "cl-ansi-term" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ansi-term/2024-10-12/cl-ansi-term-20241012-git.tgz"; - sha256 = "01nrlyb8lqca9z16ndlyy22wqy83ixcr02yibfypj255x6xbql1x"; - system = "cl-ansi-term"; - asd = "cl-ansi-term"; - }); - systems = [ "cl-ansi-term" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ansi-text = (build-asdf-system { - pname = "cl-ansi-text"; - version = "20211020-git"; - asds = [ "cl-ansi-text" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ansi-text/2021-10-20/cl-ansi-text-20211020-git.tgz"; - sha256 = "0nk7ajqfa937w1iy3zy86jjbw8yffm05cqs4wxkgl97v6kmmya14"; - system = "cl-ansi-text"; - asd = "cl-ansi-text"; - }); - systems = [ "cl-ansi-text" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-colors2" self) ]; - meta = {}; - }); - cl-ansi-text_dot_test = (build-asdf-system { - pname = "cl-ansi-text.test"; - version = "20211020-git"; - asds = [ "cl-ansi-text.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ansi-text/2021-10-20/cl-ansi-text-20211020-git.tgz"; - sha256 = "0nk7ajqfa937w1iy3zy86jjbw8yffm05cqs4wxkgl97v6kmmya14"; - system = "cl-ansi-text.test"; - asd = "cl-ansi-text.test"; - }); - systems = [ "cl-ansi-text.test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ansi-text" self) (getAttr "cl-colors2" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-apertium-stream = (build-asdf-system { - pname = "cl-apertium-stream"; - version = "20230618-git"; - asds = [ "cl-apertium-stream" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-apertium-stream-parser/2023-06-18/cl-apertium-stream-parser-20230618-git.tgz"; - sha256 = "1f3v5pgar83iw443haa4nlzy1qvr55xxqggq9klvsji1a3jdypqy"; - system = "cl-apertium-stream"; - asd = "cl-apertium-stream"; - }); - systems = [ "cl-apertium-stream" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "esrap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-apple-plist = (build-asdf-system { - pname = "cl-apple-plist"; - version = "20111105-git"; - asds = [ "cl-apple-plist" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-apple-plist/2011-11-05/cl-apple-plist-20111105-git.tgz"; - sha256 = "104j5lvvp7apdx59kbwc6kpa8b82y20w03627ml91lpbqk9bq63f"; - system = "cl-apple-plist"; - asd = "cl-apple-plist"; - }); - systems = [ "cl-apple-plist" ]; - lispLibs = [ (getAttr "html-encode" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-arff-parser = (build-asdf-system { - pname = "cl-arff-parser"; - version = "20130421-git"; - asds = [ "cl-arff-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-arff-parser/2013-04-21/cl-arff-parser-20130421-git.tgz"; - sha256 = "0rn76r48b2y2richfy3si4r8kbwkvm7q15g34sxi0fkfmx15z4jx"; - system = "cl-arff-parser"; - asd = "cl-arff-parser"; - }); - systems = [ "cl-arff-parser" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-argparse = (build-asdf-system { - pname = "cl-argparse"; - version = "20210531-git"; - asds = [ "cl-argparse" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-argparse/2021-05-31/cl-argparse-20210531-git.tgz"; - sha256 = "05vy2iaqr7yiaw0ykzwm0ml0mil5qagy87b8hqx4vvb3lq1qpn14"; - system = "cl-argparse"; - asd = "cl-argparse"; - }); - systems = [ "cl-argparse" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-aristid = (build-asdf-system { - pname = "cl-aristid"; - version = "20200925-git"; - asds = [ "cl-aristid" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-aristid/2020-09-25/cl-aristid-20200925-git.tgz"; - sha256 = "0k573k3wydy6dd5pmvqdxmlwk0n5kq2wsk86syddhqyjgx2jmw98"; - system = "cl-aristid"; - asd = "cl-aristid"; - }); - systems = [ "cl-aristid" ]; - lispLibs = [ (getAttr "cl-colors" self) (getAttr "cl-svg" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-arxiv-api = (build-asdf-system { - pname = "cl-arxiv-api"; - version = "20170403-git"; - asds = [ "cl-arxiv-api" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-arxiv-api/2017-04-03/cl-arxiv-api-20170403-git.tgz"; - sha256 = "1id95gszqxmmjydv1vjv2vyxz0svqvnx74bmgy63xnajb4kfnpq3"; - system = "cl-arxiv-api"; - asd = "cl-arxiv-api"; - }); - systems = [ "cl-arxiv-api" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "cxml" self) (getAttr "iterate" self) (getAttr "trivial-http" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ascii-art = (build-asdf-system { - pname = "cl-ascii-art"; - version = "20171019-git"; - asds = [ "cl-ascii-art" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ascii-art/2017-10-19/cl-ascii-art-20171019-git.tgz"; - sha256 = "03d3bd8m7dd2l4170vky8y8ini3giqhjpd06rlswz287mkvzq8aa"; - system = "cl-ascii-art"; - asd = "cl-ascii-art"; - }); - systems = [ "cl-ascii-art" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ansi-text" self) (getAttr "cl-ppcre" self) (getAttr "inferior-shell" self) (getAttr "iterate" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ascii-table = (build-asdf-system { - pname = "cl-ascii-table"; - version = "20200610-git"; - asds = [ "cl-ascii-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ascii-table/2020-06-10/cl-ascii-table-20200610-git.tgz"; - sha256 = "1nclyypd2p06hyfydcv16m9lbj1xmrpmf00wp8mfyhwimv021zlp"; - system = "cl-ascii-table"; - asd = "cl-ascii-table"; - }); - systems = [ "cl-ascii-table" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-aseprite = (build-asdf-system { - pname = "cl-aseprite"; - version = "20241012-git"; - asds = [ "cl-aseprite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-aseprite/2024-10-12/cl-aseprite-20241012-git.tgz"; - sha256 = "0xjrfi232d0my4ncafp1l2yfas8nj0k8nsbppkq70anic5ihbhch"; - system = "cl-aseprite"; - asd = "cl-aseprite"; - }); - systems = [ "cl-aseprite" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "chipz" self) (getAttr "let-plus" self) (getAttr "lisp-binary" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-association-rules = (build-asdf-system { - pname = "cl-association-rules"; - version = "20170403-git"; - asds = [ "cl-association-rules" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-association-rules/2017-04-03/cl-association-rules-20170403-git.tgz"; - sha256 = "1d4sg9j30ydk1m17byacww8l2x9ggb82iay507g08ij0jxdky86z"; - system = "cl-association-rules"; - asd = "cl-association-rules"; - }); - systems = [ "cl-association-rules" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-association-rules-tests = (build-asdf-system { - pname = "cl-association-rules-tests"; - version = "20170403-git"; - asds = [ "cl-association-rules-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-association-rules/2017-04-03/cl-association-rules-20170403-git.tgz"; - sha256 = "1d4sg9j30ydk1m17byacww8l2x9ggb82iay507g08ij0jxdky86z"; - system = "cl-association-rules-tests"; - asd = "cl-association-rules"; - }); - systems = [ "cl-association-rules-tests" ]; - lispLibs = [ (getAttr "cl-association-rules" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-astar = (build-asdf-system { - pname = "cl-astar"; - version = "20241012-git"; - asds = [ "cl-astar" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-astar/2024-10-12/cl-astar-20241012-git.tgz"; - sha256 = "0fdwyg3xnj5sxn4cqycydg0cp1l3ii0brk7ad1sh28m703zmndxv"; - system = "cl-astar"; - asd = "cl-astar"; - }); - systems = [ "cl-astar" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "float-features" self) (getAttr "let-plus" self) (getAttr "trivial-adjust-simple-array" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-async = (build-asdf-system { - pname = "cl-async"; - version = "20241012-git"; - asds = [ "cl-async" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-async/2024-10-12/cl-async-20241012-git.tgz"; - sha256 = "0z0gnwfb0flrxpbjmvzap0kmyz8r898x5jriyna365plc50hlcdr"; - system = "cl-async"; - asd = "cl-async"; - }); - systems = [ "cl-async" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cffi" self) (getAttr "cl-async-base" self) (getAttr "cl-async-util" self) (getAttr "cl-libuv" self) (getAttr "cl-ppcre" self) (getAttr "static-vectors" self) (getAttr "trivial-features" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - cl-async-await = (build-asdf-system { - pname = "cl-async-await"; - version = "20201016-git"; - asds = [ "cl-async-await" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-async-await/2020-10-16/cl-async-await-20201016-git.tgz"; - sha256 = "1slhn9z4hljvad3hd8jmvw4q4m6310s04yh3212wvbfar8q0yasj"; - system = "cl-async-await"; - asd = "cl-async-await"; - }); - systems = [ "cl-async-await" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "simple-actors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-async-base = (build-asdf-system { - pname = "cl-async-base"; - version = "20241012-git"; - asds = [ "cl-async-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-async/2024-10-12/cl-async-20241012-git.tgz"; - sha256 = "0z0gnwfb0flrxpbjmvzap0kmyz8r898x5jriyna365plc50hlcdr"; - system = "cl-async-base"; - asd = "cl-async"; - }); - systems = [ "cl-async-base" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cl-libuv" self) ]; - meta = {}; - }); - cl-async-future = (build-asdf-system { - pname = "cl-async-future"; - version = "20150113-git"; - asds = [ "cl-async-future" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-async-future/2015-01-13/cl-async-future-20150113-git.tgz"; - sha256 = "0z0sc7qlzzxk99f4l26zp6rai9kv0kj0f599sxai5s44p17zbbvh"; - system = "cl-async-future"; - asd = "cl-async-future"; - }); - systems = [ "cl-async-future" ]; - lispLibs = [ (getAttr "blackbird" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-async-repl = (build-asdf-system { - pname = "cl-async-repl"; - version = "20241012-git"; - asds = [ "cl-async-repl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-async/2024-10-12/cl-async-20241012-git.tgz"; - sha256 = "0z0gnwfb0flrxpbjmvzap0kmyz8r898x5jriyna365plc50hlcdr"; - system = "cl-async-repl"; - asd = "cl-async-repl"; - }); - systems = [ "cl-async-repl" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-async" self) ]; - meta = {}; - }); - cl-async-ssl = (build-asdf-system { - pname = "cl-async-ssl"; - version = "20241012-git"; - asds = [ "cl-async-ssl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-async/2024-10-12/cl-async-20241012-git.tgz"; - sha256 = "0z0gnwfb0flrxpbjmvzap0kmyz8r898x5jriyna365plc50hlcdr"; - system = "cl-async-ssl"; - asd = "cl-async-ssl"; - }); - systems = [ "cl-async-ssl" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-async" self) (getAttr "vom" self) ]; - meta = {}; - }); - cl-async-test = (build-asdf-system { - pname = "cl-async-test"; - version = "20241012-git"; - asds = [ "cl-async-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-async/2024-10-12/cl-async-20241012-git.tgz"; - sha256 = "0z0gnwfb0flrxpbjmvzap0kmyz8r898x5jriyna365plc50hlcdr"; - system = "cl-async-test"; - asd = "cl-async-test"; - }); - systems = [ "cl-async-test" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cl-async" self) (getAttr "cl-async-ssl" self) (getAttr "fiveam" self) (getAttr "flexi-streams" self) (getAttr "ironclad" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-async-util = (build-asdf-system { - pname = "cl-async-util"; - version = "20241012-git"; - asds = [ "cl-async-util" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-async/2024-10-12/cl-async-20241012-git.tgz"; - sha256 = "0z0gnwfb0flrxpbjmvzap0kmyz8r898x5jriyna365plc50hlcdr"; - system = "cl-async-util"; - asd = "cl-async"; - }); - systems = [ "cl-async-util" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-async-base" self) (getAttr "cl-libuv" self) (getAttr "cl-ppcre" self) (getAttr "fast-io" self) (getAttr "vom" self) ]; - meta = {}; - }); - cl-aubio = (build-asdf-system { - pname = "cl-aubio"; - version = "20200427-git"; - asds = [ "cl-aubio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-aubio/2020-04-27/cl-aubio-20200427-git.tgz"; - sha256 = "1xyflxy46z4487dbnizhv058y2mdka9iyikl097m60w42blidpn3"; - system = "cl-aubio"; - asd = "cl-aubio"; - }); - systems = [ "cl-aubio" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-libffi" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-authorize-net = (build-asdf-system { - pname = "cl-authorize-net"; - version = "20150113-git"; - asds = [ "cl-authorize-net" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-creditcard/2015-01-13/cl-creditcard-20150113-git.tgz"; - sha256 = "1qq9r7q50k7jw6sv65aqi9xalaw8m6aqsbb0cgpjxv8wdhy934cr"; - system = "cl-authorize-net"; - asd = "cl-authorize-net"; - }); - systems = [ "cl-authorize-net" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-creditcard" self) (getAttr "drakma" self) (getAttr "split-sequence" self) (getAttr "symbol-munger" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-authorize-net-tests = (build-asdf-system { - pname = "cl-authorize-net-tests"; - version = "20150113-git"; - asds = [ "cl-authorize-net-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-creditcard/2015-01-13/cl-creditcard-20150113-git.tgz"; - sha256 = "1qq9r7q50k7jw6sv65aqi9xalaw8m6aqsbb0cgpjxv8wdhy934cr"; - system = "cl-authorize-net-tests"; - asd = "cl-authorize-net"; - }); - systems = [ "cl-authorize-net-tests" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-authorize-net" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-autorepo = (build-asdf-system { - pname = "cl-autorepo"; - version = "20180711-git"; - asds = [ "cl-autorepo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-autorepo/2018-07-11/cl-autorepo-20180711-git.tgz"; - sha256 = "01hpg3r3493mri44kxp8sjy8i5kfvjklmnksvm0727i6bhpf8cz9"; - system = "cl-autorepo"; - asd = "cl-autorepo"; - }); - systems = [ "cl-autorepo" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-autowrap = (build-asdf-system { - pname = "cl-autowrap"; - version = "20241012-git"; - asds = [ "cl-autowrap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-autowrap/2024-10-12/cl-autowrap-20241012-git.tgz"; - sha256 = "1sfvhyrwm9dhxi0y42xp7mx8mvs6lmq3bzxdx34frxni5srcgly0"; - system = "cl-autowrap"; - asd = "cl-autowrap"; - }); - systems = [ "cl-autowrap" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "defpackage-plus" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-autowrap-test = (build-asdf-system { - pname = "cl-autowrap-test"; - version = "20241012-git"; - asds = [ "cl-autowrap-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-autowrap/2024-10-12/cl-autowrap-20241012-git.tgz"; - sha256 = "1sfvhyrwm9dhxi0y42xp7mx8mvs6lmq3bzxdx34frxni5srcgly0"; - system = "cl-autowrap-test"; - asd = "cl-autowrap-test"; - }); - systems = [ "cl-autowrap-test" ]; - lispLibs = [ (getAttr "cl-autowrap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-azure = (build-asdf-system { - pname = "cl-azure"; - version = "20160825-git"; - asds = [ "cl-azure" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-azure/2016-08-25/cl-azure-20160825-git.tgz"; - sha256 = "19sgzbvgs1f1h3qhx11xhpia2x3n8x729h9fsqkc7fap0ak1h31d"; - system = "cl-azure"; - asd = "cl-azure"; - }); - systems = [ "cl-azure" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-base64" self) (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "cxml" self) (getAttr "drakma" self) (getAttr "ironclad" self) (getAttr "puri" self) (getAttr "rt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-base16 = (build-asdf-system { - pname = "cl-base16"; - version = "20200925-git"; - asds = [ "cl-base16" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-base16/2020-09-25/cl-base16-20200925-git.tgz"; - sha256 = "0m7ndmk4xhizn3q3ywjvw8sg4pfgp6lrd0wac5d1bf7wbw6afh5q"; - system = "cl-base16"; - asd = "cl-base16"; - }); - systems = [ "cl-base16" ]; - lispLibs = [ (getAttr "cl-mustache" self) (getAttr "cl-slug" self) (getAttr "cl-yaml" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-base32 = (build-asdf-system { - pname = "cl-base32"; - version = "20241012-git"; - asds = [ "cl-base32" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-base32/2024-10-12/cl-base32-20241012-git.tgz"; - sha256 = "0kc0rxwx2ak5kvrzl8y8x3csm0d6appi5k0as2jgm3ig5vgcs5cn"; - system = "cl-base32"; - asd = "cl-base32"; - }); - systems = [ "cl-base32" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-base58 = (build-asdf-system { - pname = "cl-base58"; - version = "20150113-git"; - asds = [ "cl-base58" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-base58/2015-01-13/cl-base58-20150113-git.tgz"; - sha256 = "01wiiyz1jzxx3zhxi2hpq5n8hv28g1mn0adk793vwjzh4v5bi5zz"; - system = "cl-base58"; - asd = "cl-base58"; - }); - systems = [ "cl-base58" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-base58-test = (build-asdf-system { - pname = "cl-base58-test"; - version = "20150113-git"; - asds = [ "cl-base58-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-base58/2015-01-13/cl-base58-20150113-git.tgz"; - sha256 = "01wiiyz1jzxx3zhxi2hpq5n8hv28g1mn0adk793vwjzh4v5bi5zz"; - system = "cl-base58-test"; - asd = "cl-base58-test"; - }); - systems = [ "cl-base58-test" ]; - lispLibs = [ (getAttr "cl-base58" self) (getAttr "cl-test-more" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-base64 = (build-asdf-system { - pname = "cl-base64"; - version = "20201016-git"; - asds = [ "cl-base64" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-base64/2020-10-16/cl-base64-20201016-git.tgz"; - sha256 = "12jj54h0fs6n237cvnp8v6hn0imfksammq22ys6pi0gwz2w47rbj"; - system = "cl-base64"; - asd = "cl-base64"; - }); - systems = [ "cl-base64" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-bayesnet = (build-asdf-system { - pname = "cl-bayesnet"; - version = "20130420-git"; - asds = [ "cl-bayesnet" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bayesnet/2013-04-20/cl-bayesnet-20130420-git.tgz"; - sha256 = "02as2isvgm89qpyj49ccs1cg4fl9iswxi26w4j0svsha0q1dh5m8"; - system = "cl-bayesnet"; - asd = "cl-bayesnet"; - }); - systems = [ "cl-bayesnet" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "s-xml" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bcrypt = (build-asdf-system { - pname = "cl-bcrypt"; - version = "20231021-git"; - asds = [ "cl-bcrypt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bcrypt/2023-10-21/cl-bcrypt-20231021-git.tgz"; - sha256 = "0mfs1jwf1xi6za61hfc7dgf1g5lqqsqdclnnspncvdg6l137013n"; - system = "cl-bcrypt"; - asd = "cl-bcrypt"; - }); - systems = [ "cl-bcrypt" ]; - lispLibs = [ (getAttr "binascii" self) (getAttr "cl-ppcre" self) (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bcrypt_dot_test = (build-asdf-system { - pname = "cl-bcrypt.test"; - version = "20231021-git"; - asds = [ "cl-bcrypt.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bcrypt/2023-10-21/cl-bcrypt-20231021-git.tgz"; - sha256 = "0mfs1jwf1xi6za61hfc7dgf1g5lqqsqdclnnspncvdg6l137013n"; - system = "cl-bcrypt.test"; - asd = "cl-bcrypt.test"; - }); - systems = [ "cl-bcrypt.test" ]; - lispLibs = [ (getAttr "cl-bcrypt" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-beanstalk = (build-asdf-system { - pname = "cl-beanstalk"; - version = "20220707-git"; - asds = [ "cl-beanstalk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-beanstalk/2022-07-07/cl-beanstalk-20220707-git.tgz"; - sha256 = "0vca8dw2l765m7g7xcpzi80m8f3145hhshh8ym602336fhiz61q1"; - system = "cl-beanstalk"; - asd = "cl-beanstalk"; - }); - systems = [ "cl-beanstalk" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "split-sequence" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bip39 = (build-asdf-system { - pname = "cl-bip39"; - version = "20180711-git"; - asds = [ "cl-bip39" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bip39/2018-07-11/cl-bip39-20180711-git.tgz"; - sha256 = "04h4lhppvavvqknp11gaj4ka2wpn9i883w1w27llblkg2vnn0816"; - system = "cl-bip39"; - asd = "cl-bip39"; - }); - systems = [ "cl-bip39" ]; - lispLibs = [ (getAttr "ironclad" self) (getAttr "secure-random" self) (getAttr "split-sequence" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bloggy = (build-asdf-system { - pname = "cl-bloggy"; - version = "20211020-git"; - asds = [ "cl-bloggy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bloggy/2021-10-20/cl-bloggy-20211020-git.tgz"; - sha256 = "1clz2a0s3g3jbsrpypb4byb432l0yb4658riqs6ckin57c4bzxc8"; - system = "cl-bloggy"; - asd = "cl-bloggy"; - }); - systems = [ "cl-bloggy" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "do-urlencode" self) (getAttr "hunchentoot" self) (getAttr "lass" self) (getAttr "local-time" self) (getAttr "lorem-ipsum" self) (getAttr "spinneret" self) (getAttr "str" self) (getAttr "xml-emitter" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bloom = (build-asdf-system { - pname = "cl-bloom"; - version = "20180228-git"; - asds = [ "cl-bloom" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bloom/2018-02-28/cl-bloom-20180228-git.tgz"; - sha256 = "1ircc5sa0a2xlx0fca0is6inwrk311hbj8jx6r4sas5pfv78k4am"; - system = "cl-bloom"; - asd = "cl-bloom"; - }); - systems = [ "cl-bloom" ]; - lispLibs = [ (getAttr "cl-murmurhash" self) (getAttr "static-vectors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bloom-filter = (build-asdf-system { - pname = "cl-bloom-filter"; - version = "20221106-git"; - asds = [ "cl-bloom-filter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bloom-filter/2022-11-06/cl-bloom-filter-20221106-git.tgz"; - sha256 = "1s9m617fh3krh2klc2nx7jf89nk43cvvrnvqrhvw9jprw7gqanvq"; - system = "cl-bloom-filter"; - asd = "cl-bloom-filter"; - }); - systems = [ "cl-bloom-filter" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bmp = (build-asdf-system { - pname = "cl-bmp"; - version = "20241012-git"; - asds = [ "cl-bmp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bmp/2024-10-12/cl-bmp-20241012-git.tgz"; - sha256 = "1mcayxjppka40q9xx1qwdvrjjblclnggnicg70i95xqnv5sdwdhz"; - system = "cl-bmp"; - asd = "cl-bmp"; - }); - systems = [ "cl-bmp" ]; - lispLibs = [ (getAttr "binary-structures" self) (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bnf = (build-asdf-system { - pname = "cl-bnf"; - version = "20241012-git"; - asds = [ "cl-bnf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bnf/2024-10-12/cl-bnf-20241012-git.tgz"; - sha256 = "0aa7hnkj71f37lxzlhsppwcmk3yv42hclq08c4jrdnv8jmdb8r0l"; - system = "cl-bnf"; - asd = "cl-bnf"; - }); - systems = [ "cl-bnf" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "utf8-input-stream" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bnf-examples = (build-asdf-system { - pname = "cl-bnf-examples"; - version = "20241012-git"; - asds = [ "cl-bnf-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bnf/2024-10-12/cl-bnf-20241012-git.tgz"; - sha256 = "0aa7hnkj71f37lxzlhsppwcmk3yv42hclq08c4jrdnv8jmdb8r0l"; - system = "cl-bnf-examples"; - asd = "cl-bnf-examples"; - }); - systems = [ "cl-bnf-examples" ]; - lispLibs = [ (getAttr "cl-bnf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bnf-tests = (build-asdf-system { - pname = "cl-bnf-tests"; - version = "20241012-git"; - asds = [ "cl-bnf-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bnf/2024-10-12/cl-bnf-20241012-git.tgz"; - sha256 = "0aa7hnkj71f37lxzlhsppwcmk3yv42hclq08c4jrdnv8jmdb8r0l"; - system = "cl-bnf-tests"; - asd = "cl-bnf-tests"; - }); - systems = [ "cl-bnf-tests" ]; - lispLibs = [ (getAttr "cl-bnf" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bootstrap = (build-asdf-system { - pname = "cl-bootstrap"; - version = "20180831-git"; - asds = [ "cl-bootstrap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bootstrap/2018-08-31/cl-bootstrap-20180831-git.tgz"; - sha256 = "0pk7wx4arsljxlnbx1hzcgxwsvhdp3gn22wv43xls2jv1rdi2xry"; - system = "cl-bootstrap"; - asd = "cl-bootstrap"; - }); - systems = [ "cl-bootstrap" ]; - lispLibs = [ (getAttr "cl-who" self) (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bootstrap-demo = (build-asdf-system { - pname = "cl-bootstrap-demo"; - version = "20180831-git"; - asds = [ "cl-bootstrap-demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bootstrap/2018-08-31/cl-bootstrap-20180831-git.tgz"; - sha256 = "0pk7wx4arsljxlnbx1hzcgxwsvhdp3gn22wv43xls2jv1rdi2xry"; - system = "cl-bootstrap-demo"; - asd = "cl-bootstrap-demo"; - }); - systems = [ "cl-bootstrap-demo" ]; - lispLibs = [ (getAttr "cl-bootstrap" self) (getAttr "cl-who" self) (getAttr "hunchentoot" self) (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bootstrap-test = (build-asdf-system { - pname = "cl-bootstrap-test"; - version = "20180831-git"; - asds = [ "cl-bootstrap-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bootstrap/2018-08-31/cl-bootstrap-20180831-git.tgz"; - sha256 = "0pk7wx4arsljxlnbx1hzcgxwsvhdp3gn22wv43xls2jv1rdi2xry"; - system = "cl-bootstrap-test"; - asd = "cl-bootstrap-test"; - }); - systems = [ "cl-bootstrap-test" ]; - lispLibs = [ (getAttr "cl-bootstrap" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bplustree = (build-asdf-system { - pname = "cl-bplustree"; - version = "20180328-git"; - asds = [ "cl-bplustree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bplustree/2018-03-28/cl-bplustree-20180328-git.tgz"; - sha256 = "1d9pm9fi9bhh73bhcgig0wq5i4fvc4551kxvny3di6x6yr7j2kbl"; - system = "cl-bplustree"; - asd = "cl-bplustree"; - }); - systems = [ "cl-bplustree" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bplustree-test = (build-asdf-system { - pname = "cl-bplustree-test"; - version = "20180328-git"; - asds = [ "cl-bplustree-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bplustree/2018-03-28/cl-bplustree-20180328-git.tgz"; - sha256 = "1d9pm9fi9bhh73bhcgig0wq5i4fvc4551kxvny3di6x6yr7j2kbl"; - system = "cl-bplustree-test"; - asd = "cl-bplustree"; - }); - systems = [ "cl-bplustree-test" ]; - lispLibs = [ (getAttr "cl-bplustree" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-brewer-ci = (build-asdf-system { - pname = "cl-brewer-ci"; - version = "20241012-git"; - asds = [ "cl-brewer-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-brewer/2024-10-12/cl-brewer-20241012-git.tgz"; - sha256 = "0izf6v4qx82jhk7ln28jhdmnr3lb0r5iqjj0by9igq5sk3y1my4x"; - system = "cl-brewer-ci"; - asd = "cl-brewer-ci"; - }); - systems = [ "cl-brewer-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-brewer-deploy-hooks = (build-asdf-system { - pname = "cl-brewer-deploy-hooks"; - version = "20241012-git"; - asds = [ "cl-brewer-deploy-hooks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-brewer/2024-10-12/cl-brewer-20241012-git.tgz"; - sha256 = "0izf6v4qx82jhk7ln28jhdmnr3lb0r5iqjj0by9igq5sk3y1my4x"; - system = "cl-brewer-deploy-hooks"; - asd = "cl-brewer-deploy-hooks"; - }); - systems = [ "cl-brewer-deploy-hooks" ]; - lispLibs = [ (getAttr "deploy" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-brewer-tests = (build-asdf-system { - pname = "cl-brewer-tests"; - version = "20241012-git"; - asds = [ "cl-brewer-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-brewer/2024-10-12/cl-brewer-20241012-git.tgz"; - sha256 = "0izf6v4qx82jhk7ln28jhdmnr3lb0r5iqjj0by9igq5sk3y1my4x"; - system = "cl-brewer-tests"; - asd = "cl-brewer-tests"; - }); - systems = [ "cl-brewer-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-buchberger = (build-asdf-system { - pname = "cl-buchberger"; - version = "20241012-git"; - asds = [ "cl-buchberger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-buchberger/2024-10-12/cl-buchberger-20241012-git.tgz"; - sha256 = "0hn340y52xfgj788zh449jrh7blfv6yqfnkmqg2vghy92s8jcr1i"; - system = "cl-buchberger"; - asd = "cl-buchberger"; - }); - systems = [ "cl-buchberger" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-bus = (build-asdf-system { - pname = "cl-bus"; - version = "20211209-git"; - asds = [ "cl-bus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-bus/2021-12-09/cl-bus-20211209-git.tgz"; - sha256 = "1galzqm1qv2slibn3awfyxnmlslxmzw09a8fidmbdy1r0ppp5r7z"; - system = "cl-bus"; - asd = "cl-bus"; - }); - systems = [ "cl-bus" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ca = (build-asdf-system { - pname = "cl-ca"; - version = "20161204-git"; - asds = [ "cl-ca" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ca/2016-12-04/cl-ca-20161204-git.tgz"; - sha256 = "0kpwpxw3c8q7b2ajyj9rzhs1r1h6kipdm9qjkgsn0sqrmx9acfnz"; - system = "cl-ca"; - asd = "cl-ca"; - }); - systems = [ "cl-ca" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cache-tables = (build-asdf-system { - pname = "cl-cache-tables"; - version = "20171019-git"; - asds = [ "cl-cache-tables" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cache-tables/2017-10-19/cl-cache-tables-20171019-git.tgz"; - sha256 = "008m7v39mq2475y1f4if5iazb15rm02g22id4q4qgig1zx2vfpg1"; - system = "cl-cache-tables"; - asd = "cl-cache-tables"; - }); - systems = [ "cl-cache-tables" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cache-tables-tests = (build-asdf-system { - pname = "cl-cache-tables-tests"; - version = "20171019-git"; - asds = [ "cl-cache-tables-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cache-tables/2017-10-19/cl-cache-tables-20171019-git.tgz"; - sha256 = "008m7v39mq2475y1f4if5iazb15rm02g22id4q4qgig1zx2vfpg1"; - system = "cl-cache-tables-tests"; - asd = "cl-cache-tables"; - }); - systems = [ "cl-cache-tables-tests" ]; - lispLibs = [ (getAttr "cl-cache-tables" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cairo2 = (build-asdf-system { - pname = "cl-cairo2"; - version = "20211020-git"; - asds = [ "cl-cairo2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cairo2/2021-10-20/cl-cairo2-20211020-git.tgz"; - sha256 = "0cpfgyxw6pz7y033dlya8c4vjmkpw127zdq3a9xclp9q8jbdlb7q"; - system = "cl-cairo2"; - asd = "cl-cairo2"; - }); - systems = [ "cl-cairo2" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-colors" self) (getAttr "cl-utilities" self) (getAttr "metabang-bind" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - cl-cairo2-demos = (build-asdf-system { - pname = "cl-cairo2-demos"; - version = "20211020-git"; - asds = [ "cl-cairo2-demos" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cairo2/2021-10-20/cl-cairo2-20211020-git.tgz"; - sha256 = "0cpfgyxw6pz7y033dlya8c4vjmkpw127zdq3a9xclp9q8jbdlb7q"; - system = "cl-cairo2-demos"; - asd = "cl-cairo2-demos"; - }); - systems = [ "cl-cairo2-demos" ]; - lispLibs = [ (getAttr "cl-cairo2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cairo2-xlib = (build-asdf-system { - pname = "cl-cairo2-xlib"; - version = "20211020-git"; - asds = [ "cl-cairo2-xlib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cairo2/2021-10-20/cl-cairo2-20211020-git.tgz"; - sha256 = "0cpfgyxw6pz7y033dlya8c4vjmkpw127zdq3a9xclp9q8jbdlb7q"; - system = "cl-cairo2-xlib"; - asd = "cl-cairo2-xlib"; - }); - systems = [ "cl-cairo2-xlib" ]; - lispLibs = [ (getAttr "cl-cairo2" self) (getAttr "cl-freetype2" self) ]; - meta = {}; - }); - cl-case-control = (build-asdf-system { - pname = "cl-case-control"; - version = "20141106-git"; - asds = [ "cl-case-control" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-case-control/2014-11-06/cl-case-control-20141106-git.tgz"; - sha256 = "0510m1dfz4abw3s7w0axr1b1nsmi72avr850r0sn6p2pq091pc71"; - system = "cl-case-control"; - asd = "cl-case-control"; - }); - systems = [ "cl-case-control" ]; - lispLibs = [ (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-catmull-rom-spline = (build-asdf-system { - pname = "cl-catmull-rom-spline"; - version = "20220220-git"; - asds = [ "cl-catmull-rom-spline" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-catmull-rom-spline/2022-02-20/cl-catmull-rom-spline-20220220-git.tgz"; - sha256 = "0702swja11zpfdx04l0901ipvi0acg17mk9ryvhibnbzq70npyjs"; - system = "cl-catmull-rom-spline"; - asd = "cl-catmull-rom-spline"; - }); - systems = [ "cl-catmull-rom-spline" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cerf = (build-asdf-system { - pname = "cl-cerf"; - version = "20210531-git"; - asds = [ "cl-cerf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cerf/2021-05-31/cl-cerf-20210531-git.tgz"; - sha256 = "0n1b6ig1d0dqkjn06iqsk0m4y7j7msi2gcq7niivcwc4s0ry0ljn"; - system = "cl-cerf"; - asd = "cl-cerf"; - }); - systems = [ "cl-cerf" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-libffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cffi-gtk = (build-asdf-system { - pname = "cl-cffi-gtk"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk"; - asd = "cl-cffi-gtk"; - }); - systems = [ "cl-cffi-gtk" ]; - lispLibs = [ (getAttr "cl-cffi-gtk-cairo" self) (getAttr "cl-cffi-gtk-gdk" self) (getAttr "cl-cffi-gtk-gdk-pixbuf" self) (getAttr "cl-cffi-gtk-gio" self) (getAttr "cl-cffi-gtk-glib" self) (getAttr "cl-cffi-gtk-gobject" self) (getAttr "cl-cffi-gtk-pango" self) ]; - meta = {}; - }); - cl-cffi-gtk-cairo = (build-asdf-system { - pname = "cl-cffi-gtk-cairo"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk-cairo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk-cairo"; - asd = "cl-cffi-gtk-cairo"; - }); - systems = [ "cl-cffi-gtk-cairo" ]; - lispLibs = [ (getAttr "cl-cffi-gtk-glib" self) ]; - meta = {}; - }); - cl-cffi-gtk-demo-cairo = (build-asdf-system { - pname = "cl-cffi-gtk-demo-cairo"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk-demo-cairo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk-demo-cairo"; - asd = "cl-cffi-gtk-demo-cairo"; - }); - systems = [ "cl-cffi-gtk-demo-cairo" ]; - lispLibs = [ (getAttr "cl-cffi-gtk" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cffi-gtk-demo-glib = (build-asdf-system { - pname = "cl-cffi-gtk-demo-glib"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk-demo-glib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk-demo-glib"; - asd = "cl-cffi-gtk-demo-glib"; - }); - systems = [ "cl-cffi-gtk-demo-glib" ]; - lispLibs = [ (getAttr "cl-cffi-gtk" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cffi-gtk-demo-gobject = (build-asdf-system { - pname = "cl-cffi-gtk-demo-gobject"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk-demo-gobject" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk-demo-gobject"; - asd = "cl-cffi-gtk-demo-gobject"; - }); - systems = [ "cl-cffi-gtk-demo-gobject" ]; - lispLibs = [ (getAttr "cl-cffi-gtk-gobject" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cffi-gtk-example-gtk = (build-asdf-system { - pname = "cl-cffi-gtk-example-gtk"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk-example-gtk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk-example-gtk"; - asd = "cl-cffi-gtk-example-gtk"; - }); - systems = [ "cl-cffi-gtk-example-gtk" ]; - lispLibs = [ (getAttr "cl-cffi-gtk" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cffi-gtk-gdk = (build-asdf-system { - pname = "cl-cffi-gtk-gdk"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk-gdk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk-gdk"; - asd = "cl-cffi-gtk-gdk"; - }); - systems = [ "cl-cffi-gtk-gdk" ]; - lispLibs = [ (getAttr "cl-cffi-gtk-cairo" self) (getAttr "cl-cffi-gtk-gdk-pixbuf" self) (getAttr "cl-cffi-gtk-gio" self) (getAttr "cl-cffi-gtk-glib" self) (getAttr "cl-cffi-gtk-gobject" self) (getAttr "cl-cffi-gtk-pango" self) ]; - meta = {}; - }); - cl-cffi-gtk-gdk-pixbuf = (build-asdf-system { - pname = "cl-cffi-gtk-gdk-pixbuf"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk-gdk-pixbuf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk-gdk-pixbuf"; - asd = "cl-cffi-gtk-gdk-pixbuf"; - }); - systems = [ "cl-cffi-gtk-gdk-pixbuf" ]; - lispLibs = [ (getAttr "cl-cffi-gtk-glib" self) (getAttr "cl-cffi-gtk-gobject" self) ]; - meta = {}; - }); - cl-cffi-gtk-gio = (build-asdf-system { - pname = "cl-cffi-gtk-gio"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk-gio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk-gio"; - asd = "cl-cffi-gtk-gio"; - }); - systems = [ "cl-cffi-gtk-gio" ]; - lispLibs = [ (getAttr "cl-cffi-gtk-glib" self) (getAttr "cl-cffi-gtk-gobject" self) ]; - meta = {}; - }); - cl-cffi-gtk-glib = (build-asdf-system { - pname = "cl-cffi-gtk-glib"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk-glib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk-glib"; - asd = "cl-cffi-gtk-glib"; - }); - systems = [ "cl-cffi-gtk-glib" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "iterate" self) (getAttr "trivial-features" self) ]; - meta = {}; - }); - cl-cffi-gtk-gobject = (build-asdf-system { - pname = "cl-cffi-gtk-gobject"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk-gobject" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk-gobject"; - asd = "cl-cffi-gtk-gobject"; - }); - systems = [ "cl-cffi-gtk-gobject" ]; - lispLibs = [ (getAttr "cl-cffi-gtk-glib" self) (getAttr "closer-mop" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - cl-cffi-gtk-opengl-demo = (build-asdf-system { - pname = "cl-cffi-gtk-opengl-demo"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk-opengl-demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk-opengl-demo"; - asd = "cl-cffi-gtk-opengl-demo"; - }); - systems = [ "cl-cffi-gtk-opengl-demo" ]; - lispLibs = [ (getAttr "cl-cffi-gtk" self) (getAttr "cl-opengl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cffi-gtk-pango = (build-asdf-system { - pname = "cl-cffi-gtk-pango"; - version = "20230214-git"; - asds = [ "cl-cffi-gtk-pango" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; - sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; - system = "cl-cffi-gtk-pango"; - asd = "cl-cffi-gtk-pango"; - }); - systems = [ "cl-cffi-gtk-pango" ]; - lispLibs = [ (getAttr "cl-cffi-gtk-cairo" self) (getAttr "cl-cffi-gtk-glib" self) (getAttr "cl-cffi-gtk-gobject" self) ]; - meta = {}; - }); - cl-change-case = (build-asdf-system { - pname = "cl-change-case"; - version = "20231021-git"; - asds = [ "cl-change-case" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-change-case/2023-10-21/cl-change-case-20231021-git.tgz"; - sha256 = "0g17n80jmaiyqsx8r35v6p0axb03s6j9wywlf8qkvw8rm848pp7s"; - system = "cl-change-case"; - asd = "cl-change-case"; - }); - systems = [ "cl-change-case" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cl-ppcre-unicode" self) ]; - meta = {}; - }); - cl-charms = (build-asdf-system { - pname = "cl-charms"; - version = "20230618-git"; - asds = [ "cl-charms" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-charms/2023-06-18/cl-charms-20230618-git.tgz"; - sha256 = "0g6kw0b3b8wjb89rv6slyjl55pymadkcf35ig4d22z8igac7kj8b"; - system = "cl-charms"; - asd = "cl-charms"; - }); - systems = [ "cl-charms" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-charms-marquee = (build-asdf-system { - pname = "cl-charms-marquee"; - version = "20230618-git"; - asds = [ "cl-charms-marquee" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-charms/2023-06-18/cl-charms-20230618-git.tgz"; - sha256 = "0g6kw0b3b8wjb89rv6slyjl55pymadkcf35ig4d22z8igac7kj8b"; - system = "cl-charms-marquee"; - asd = "cl-charms-marquee"; - }); - systems = [ "cl-charms-marquee" ]; - lispLibs = [ (getAttr "cl-charms" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-charms-paint = (build-asdf-system { - pname = "cl-charms-paint"; - version = "20230618-git"; - asds = [ "cl-charms-paint" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-charms/2023-06-18/cl-charms-20230618-git.tgz"; - sha256 = "0g6kw0b3b8wjb89rv6slyjl55pymadkcf35ig4d22z8igac7kj8b"; - system = "cl-charms-paint"; - asd = "cl-charms-paint"; - }); - systems = [ "cl-charms-paint" ]; - lispLibs = [ (getAttr "cl-charms" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-charms-timer = (build-asdf-system { - pname = "cl-charms-timer"; - version = "20230618-git"; - asds = [ "cl-charms-timer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-charms/2023-06-18/cl-charms-20230618-git.tgz"; - sha256 = "0g6kw0b3b8wjb89rv6slyjl55pymadkcf35ig4d22z8igac7kj8b"; - system = "cl-charms-timer"; - asd = "cl-charms-timer"; - }); - systems = [ "cl-charms-timer" ]; - lispLibs = [ (getAttr "cl-charms" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-clblas = (build-asdf-system { - pname = "cl-clblas"; - version = "20181018-git"; - asds = [ "cl-clblas" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-clblas/2018-10-18/cl-clblas-20181018-git.tgz"; - sha256 = "0cn4hvywaw97ccnj2wxjf20lh7h7n5fs6rq6kgjyfs9cxcixmvrj"; - system = "cl-clblas"; - asd = "cl-clblas"; - }); - systems = [ "cl-clblas" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-clblas-test = (build-asdf-system { - pname = "cl-clblas-test"; - version = "20181018-git"; - asds = [ "cl-clblas-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-clblas/2018-10-18/cl-clblas-20181018-git.tgz"; - sha256 = "0cn4hvywaw97ccnj2wxjf20lh7h7n5fs6rq6kgjyfs9cxcixmvrj"; - system = "cl-clblas-test"; - asd = "cl-clblas-test"; - }); - systems = [ "cl-clblas-test" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-clblas" self) (getAttr "cl-oclapi" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cli = (build-asdf-system { - pname = "cl-cli"; - version = "20151218-git"; - asds = [ "cl-cli" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cli/2015-12-18/cl-cli-20151218-git.tgz"; - sha256 = "0zlifq55r78vfdlqf8jy6rkny73438f1i9cp9a8vybmila5dij3q"; - system = "cl-cli"; - asd = "cl-cli"; - }); - systems = [ "cl-cli" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = {}; - }); - cl-clsparse = (build-asdf-system { - pname = "cl-clsparse"; - version = "20190813-git"; - asds = [ "cl-clsparse" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-clsparse/2019-08-13/cl-clsparse-20190813-git.tgz"; - sha256 = "0cmmwx2ka1jp5711x21knw3zi6kcpkpcs39dm62w82s97bv794gz"; - system = "cl-clsparse"; - asd = "cl-clsparse"; - }); - systems = [ "cl-clsparse" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-libffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cognito = (build-asdf-system { - pname = "cl-cognito"; - version = "20181210-git"; - asds = [ "cl-cognito" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cognito/2018-12-10/cl-cognito-20181210-git.tgz"; - sha256 = "0zy4yg4zggvxwbvkjkd89d2ps236kz6pvz90zn6gzq812wnidsd3"; - system = "cl-cognito"; - asd = "cl-cognito"; - }); - systems = [ "cl-cognito" ]; - lispLibs = [ (getAttr "aws-foundation" self) (getAttr "cl-base64" self) (getAttr "cl-json-helper" self) (getAttr "ironclad" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-coinpayments = (build-asdf-system { - pname = "cl-coinpayments"; - version = "20210807-git"; - asds = [ "cl-coinpayments" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-coinpayments/2021-08-07/cl-coinpayments-20210807-git.tgz"; - sha256 = "1vgsh95vjqqg0a6lqg1ivs36yjx6ck8cqhsmlr5l3ldfd8yr65q7"; - system = "cl-coinpayments"; - asd = "cl-coinpayments"; - }); - systems = [ "cl-coinpayments" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "closer-mop" self) (getAttr "dexador" self) (getAttr "ironclad" self) (getAttr "jonathan" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-collider = (build-asdf-system { - pname = "cl-collider"; - version = "20241012-git"; - asds = [ "cl-collider" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-collider/2024-10-12/cl-collider-20241012-git.tgz"; - sha256 = "0h0fyx7glxnzwyam2aflma6003h8fcvcf5nj5f7svarw9brcc2xa"; - system = "cl-collider"; - asd = "cl-collider"; - }); - systems = [ "cl-collider" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "named-readtables" self) (getAttr "pileup" self) (getAttr "sc-osc" self) (getAttr "simple-inferiors" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-colors = (build-asdf-system { - pname = "cl-colors"; - version = "20180328-git"; - asds = [ "cl-colors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-colors/2018-03-28/cl-colors-20180328-git.tgz"; - sha256 = "0l446lday4hybsm9bq3jli97fvv8jb1d33abg79vbylpwjmf3y9a"; - system = "cl-colors"; - asd = "cl-colors"; - }); - systems = [ "cl-colors" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "let-plus" self) ]; - meta = {}; - }); - cl-colors-tests = (build-asdf-system { - pname = "cl-colors-tests"; - version = "20180328-git"; - asds = [ "cl-colors-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-colors/2018-03-28/cl-colors-20180328-git.tgz"; - sha256 = "0l446lday4hybsm9bq3jli97fvv8jb1d33abg79vbylpwjmf3y9a"; - system = "cl-colors-tests"; - asd = "cl-colors"; - }); - systems = [ "cl-colors-tests" ]; - lispLibs = [ (getAttr "cl-colors" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-colors2 = (build-asdf-system { - pname = "cl-colors2"; - version = "20241012-git"; - asds = [ "cl-colors2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-colors2/2024-10-12/cl-colors2-20241012-git.tgz"; - sha256 = "053bidgbqziv5visdq09gy8zf30cvqh1w06l23yygn1yrg7m7302"; - system = "cl-colors2"; - asd = "cl-colors2"; - }); - systems = [ "cl-colors2" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "parse-number" self) ]; - meta = {}; - }); - cl-concord = (build-asdf-system { - pname = "cl-concord"; - version = "20241012-git"; - asds = [ "cl-concord" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-concord/2024-10-12/cl-concord-20241012-git.tgz"; - sha256 = "01i13lp3z2v2w165h0xh72r1vyfbjr6k1gwk4hff1rf2yx2yg9k1"; - system = "cl-concord"; - asd = "cl-concord"; - }); - systems = [ "cl-concord" ]; - lispLibs = [ (getAttr "cl-redis" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-conllu = (build-asdf-system { - pname = "cl-conllu"; - version = "20211209-git"; - asds = [ "cl-conllu" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-conllu/2021-12-09/cl-conllu-20211209-git.tgz"; - sha256 = "0n69k0apifnirs2g3rfdsxiwy6dimd9qqxaqywaingvbd7yn42jn"; - system = "cl-conllu"; - asd = "cl-conllu"; - }); - systems = [ "cl-conllu" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-log" self) (getAttr "cl-markup" self) (getAttr "cl-ppcre" self) (getAttr "lispbuilder-lexer" self) (getAttr "optima_dot_ppcre" self) (getAttr "split-sequence" self) (getAttr "uuid" self) (getAttr "wilbur" self) (getAttr "xmls" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-conspack = (build-asdf-system { - pname = "cl-conspack"; - version = "20230214-git"; - asds = [ "cl-conspack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-conspack/2023-02-14/cl-conspack-20230214-git.tgz"; - sha256 = "0y5wp5c89ph44k2xjppy1c1jf2ac3q9yrk22da2rkwnbxn0h1a8d"; - system = "cl-conspack"; - asd = "cl-conspack"; - }); - systems = [ "cl-conspack" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "fast-io" self) (getAttr "ieee-floats" self) (getAttr "trivial-garbage" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-conspack-test = (build-asdf-system { - pname = "cl-conspack-test"; - version = "20230214-git"; - asds = [ "cl-conspack-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-conspack/2023-02-14/cl-conspack-20230214-git.tgz"; - sha256 = "0y5wp5c89ph44k2xjppy1c1jf2ac3q9yrk22da2rkwnbxn0h1a8d"; - system = "cl-conspack-test"; - asd = "cl-conspack-test"; - }); - systems = [ "cl-conspack-test" ]; - lispLibs = [ (getAttr "cl-conspack" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cont = (build-asdf-system { - pname = "cl-cont"; - version = "20110219-darcs"; - asds = [ "cl-cont" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cont/2011-02-19/cl-cont-20110219-darcs.tgz"; - sha256 = "1zf8zvb0i6jm3hhfks4w74hibm6avgc6f9s1qwgjrn2bcik8lrvz"; - system = "cl-cont"; - asd = "cl-cont"; - }); - systems = [ "cl-cont" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cont-test = (build-asdf-system { - pname = "cl-cont-test"; - version = "20110219-darcs"; - asds = [ "cl-cont-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cont/2011-02-19/cl-cont-20110219-darcs.tgz"; - sha256 = "1zf8zvb0i6jm3hhfks4w74hibm6avgc6f9s1qwgjrn2bcik8lrvz"; - system = "cl-cont-test"; - asd = "cl-cont-test"; - }); - systems = [ "cl-cont-test" ]; - lispLibs = [ (getAttr "cl-cont" self) (getAttr "rt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-containers = (build-asdf-system { - pname = "cl-containers"; - version = "20241012-git"; - asds = [ "cl-containers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-containers/2024-10-12/cl-containers-20241012-git.tgz"; - sha256 = "0xpa5yhsndh33cs4q6vgjc8jxwlmv8lxkg4bamfi0f3ad4smi7zl"; - system = "cl-containers"; - asd = "cl-containers"; - }); - systems = [ "cl-containers" ]; - lispLibs = [ (getAttr "asdf-system-connections" self) (getAttr "metatilities-base" self) ]; - meta = {}; - }); - cl-containers-test = (build-asdf-system { - pname = "cl-containers-test"; - version = "20241012-git"; - asds = [ "cl-containers-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-containers/2024-10-12/cl-containers-20241012-git.tgz"; - sha256 = "0xpa5yhsndh33cs4q6vgjc8jxwlmv8lxkg4bamfi0f3ad4smi7zl"; - system = "cl-containers-test"; - asd = "cl-containers-test"; - }); - systems = [ "cl-containers-test" ]; - lispLibs = [ (getAttr "cl-containers" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cookie = (build-asdf-system { - pname = "cl-cookie"; - version = "20241012-git"; - asds = [ "cl-cookie" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cookie/2024-10-12/cl-cookie-20241012-git.tgz"; - sha256 = "172lw0sm6i9nvlx0iv0851rsm5pc28xqqf6a75pwv1fvr6srq8qh"; - system = "cl-cookie"; - asd = "cl-cookie"; - }); - systems = [ "cl-cookie" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "local-time" self) (getAttr "proc-parse" self) (getAttr "quri" self) ]; - meta = {}; - }); - cl-cookie-test = (build-asdf-system { - pname = "cl-cookie-test"; - version = "20241012-git"; - asds = [ "cl-cookie-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cookie/2024-10-12/cl-cookie-20241012-git.tgz"; - sha256 = "172lw0sm6i9nvlx0iv0851rsm5pc28xqqf6a75pwv1fvr6srq8qh"; - system = "cl-cookie-test"; - asd = "cl-cookie-test"; - }); - systems = [ "cl-cookie-test" ]; - lispLibs = [ (getAttr "cl-cookie" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-coroutine = (build-asdf-system { - pname = "cl-coroutine"; - version = "20160929-git"; - asds = [ "cl-coroutine" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-coroutine/2016-09-29/cl-coroutine-20160929-git.tgz"; - sha256 = "1cqdhdjxffgfs116l1swjlsmcbly0xgcgrckvaajd566idj9yj4l"; - system = "cl-coroutine"; - asd = "cl-coroutine"; - }); - systems = [ "cl-coroutine" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-cont" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-coroutine-test = (build-asdf-system { - pname = "cl-coroutine-test"; - version = "20160929-git"; - asds = [ "cl-coroutine-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-coroutine/2016-09-29/cl-coroutine-20160929-git.tgz"; - sha256 = "1cqdhdjxffgfs116l1swjlsmcbly0xgcgrckvaajd566idj9yj4l"; - system = "cl-coroutine-test"; - asd = "cl-coroutine-test"; - }); - systems = [ "cl-coroutine-test" ]; - lispLibs = [ (getAttr "cl-coroutine" self) (getAttr "cl-test-more" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-coveralls = (build-asdf-system { - pname = "cl-coveralls"; - version = "20210411-git"; - asds = [ "cl-coveralls" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-coveralls/2021-04-11/cl-coveralls-20210411-git.tgz"; - sha256 = "1n4jks92827xbi2zzy6gsx3r2gl97difl04da9wz94n9rjj3bcz0"; - system = "cl-coveralls"; - asd = "cl-coveralls"; - }); - systems = [ "cl-coveralls" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "dexador" self) (getAttr "flexi-streams" self) (getAttr "ironclad" self) (getAttr "jonathan" self) (getAttr "lquery" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-coveralls-test = (build-asdf-system { - pname = "cl-coveralls-test"; - version = "20210411-git"; - asds = [ "cl-coveralls-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-coveralls/2021-04-11/cl-coveralls-20210411-git.tgz"; - sha256 = "1n4jks92827xbi2zzy6gsx3r2gl97difl04da9wz94n9rjj3bcz0"; - system = "cl-coveralls-test"; - asd = "cl-coveralls-test"; - }); - systems = [ "cl-coveralls-test" ]; - lispLibs = [ (getAttr "cl-coveralls" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-covid19 = (build-asdf-system { - pname = "cl-covid19"; - version = "20220331-git"; - asds = [ "cl-covid19" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-covid19/2022-03-31/cl-covid19-20220331-git.tgz"; - sha256 = "0nxdharz29nrdylrwnhgdayfsfwm0vd5g487mi4i5lly8q0i9vl0"; - system = "cl-covid19"; - asd = "cl-covid19"; - }); - systems = [ "cl-covid19" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ascii-table" self) (getAttr "cl-csv" self) (getAttr "cl-migratum" self) (getAttr "cl-migratum_dot_driver_dot_dbi" self) (getAttr "cl-migratum_dot_provider_dot_local-path" self) (getAttr "dexador" self) (getAttr "djula" self) (getAttr "jonathan" self) (getAttr "quri" self) (getAttr "tmpdir" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cpu-affinity = (build-asdf-system { - pname = "cl-cpu-affinity"; - version = "20210411-git"; - asds = [ "cl-cpu-affinity" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; - sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; - system = "cl-cpu-affinity"; - asd = "cl-cpu-affinity"; - }); - systems = [ "cl-cpu-affinity" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cpus = (build-asdf-system { - pname = "cl-cpus"; - version = "20230618-git"; - asds = [ "cl-cpus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cpus/2023-06-18/cl-cpus-20230618-git.tgz"; - sha256 = "1gxyb85hpjmhz7vhny9cscrzldx06f7c5q93pl1qs0s3b7avh5vd"; - system = "cl-cpus"; - asd = "cl-cpus"; - }); - systems = [ "cl-cpus" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cram = (build-asdf-system { - pname = "cl-cram"; - version = "20230618-git"; - asds = [ "cl-cram" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cram/2023-06-18/cl-cram-20230618-git.tgz"; - sha256 = "139p4hbb6ac57ay5vgr969d3rki9ypk9ninaqm5vkax2hcx7mq3i"; - system = "cl-cram"; - asd = "cl-cram"; - }); - systems = [ "cl-cram" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-crc64 = (build-asdf-system { - pname = "cl-crc64"; - version = "20140713-git"; - asds = [ "cl-crc64" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-crc64/2014-07-13/cl-crc64-20140713-git.tgz"; - sha256 = "1cqky5ps28r49z6ib4vjwfjpq3ml81p2ayf0nqppf2lc4vf3kb20"; - system = "cl-crc64"; - asd = "cl-crc64"; - }); - systems = [ "cl-crc64" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-creditcard = (build-asdf-system { - pname = "cl-creditcard"; - version = "20150113-git"; - asds = [ "cl-creditcard" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-creditcard/2015-01-13/cl-creditcard-20150113-git.tgz"; - sha256 = "1qq9r7q50k7jw6sv65aqi9xalaw8m6aqsbb0cgpjxv8wdhy934cr"; - system = "cl-creditcard"; - asd = "cl-creditcard"; - }); - systems = [ "cl-creditcard" ]; - lispLibs = [ (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cron = (build-asdf-system { - pname = "cl-cron"; - version = "20231021-git"; - asds = [ "cl-cron" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cron/2023-10-21/cl-cron-20231021-git.tgz"; - sha256 = "0l1jg2sqdqniaqsaywy0ar49m10gzls8i31gpxmd7c4yzazy4fib"; - system = "cl-cron"; - asd = "cl-cron"; - }); - systems = [ "cl-cron" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-css = (build-asdf-system { - pname = "cl-css"; - version = "20140914-git"; - asds = [ "cl-css" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-css/2014-09-14/cl-css-20140914-git.tgz"; - sha256 = "1lc42zi2sw11fl2589sc19nr5sd2p0wy7wgvgwaggxa5f3ajhsmd"; - system = "cl-css"; - asd = "cl-css"; - }); - systems = [ "cl-css" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-csv = (build-asdf-system { - pname = "cl-csv"; - version = "20241012-git"; - asds = [ "cl-csv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-csv/2024-10-12/cl-csv-20241012-git.tgz"; - sha256 = "0pb89l3bi2cnk7sav2w0dmlvjxij1wpy3w6n9c4b6imjs0pznrxi"; - system = "cl-csv"; - asd = "cl-csv"; - }); - systems = [ "cl-csv" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-interpol" self) (getAttr "iterate" self) ]; - meta = {}; - }); - cl-csv-clsql = (build-asdf-system { - pname = "cl-csv-clsql"; - version = "20241012-git"; - asds = [ "cl-csv-clsql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-csv/2024-10-12/cl-csv-20241012-git.tgz"; - sha256 = "0pb89l3bi2cnk7sav2w0dmlvjxij1wpy3w6n9c4b6imjs0pznrxi"; - system = "cl-csv-clsql"; - asd = "cl-csv-clsql"; - }); - systems = [ "cl-csv-clsql" ]; - lispLibs = [ (getAttr "cl-csv" self) (getAttr "clsql-helper" self) (getAttr "data-table-clsql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-csv-data-table = (build-asdf-system { - pname = "cl-csv-data-table"; - version = "20241012-git"; - asds = [ "cl-csv-data-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-csv/2024-10-12/cl-csv-20241012-git.tgz"; - sha256 = "0pb89l3bi2cnk7sav2w0dmlvjxij1wpy3w6n9c4b6imjs0pznrxi"; - system = "cl-csv-data-table"; - asd = "cl-csv-data-table"; - }); - systems = [ "cl-csv-data-table" ]; - lispLibs = [ (getAttr "cl-csv" self) (getAttr "data-table" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cuda = (build-asdf-system { - pname = "cl-cuda"; - version = "20210807-git"; - asds = [ "cl-cuda" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cuda/2021-08-07/cl-cuda-20210807-git.tgz"; - sha256 = "019m2khbiadm0yxfhbbfsidnmxq9spn3hn8r6vx4cw3i22jin0hg"; - system = "cl-cuda"; - asd = "cl-cuda"; - }); - systems = [ "cl-cuda" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-pattern" self) (getAttr "cl-ppcre" self) (getAttr "cl-reexport" self) (getAttr "external-program" self) (getAttr "osicat" self) (getAttr "split-sequence" self) ]; - meta = {}; - }); - cl-cuda-examples = (build-asdf-system { - pname = "cl-cuda-examples"; - version = "20210807-git"; - asds = [ "cl-cuda-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cuda/2021-08-07/cl-cuda-20210807-git.tgz"; - sha256 = "019m2khbiadm0yxfhbbfsidnmxq9spn3hn8r6vx4cw3i22jin0hg"; - system = "cl-cuda-examples"; - asd = "cl-cuda-examples"; - }); - systems = [ "cl-cuda-examples" ]; - lispLibs = [ (getAttr "cl-cuda" self) (getAttr "imago" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cuda-interop = (build-asdf-system { - pname = "cl-cuda-interop"; - version = "20210807-git"; - asds = [ "cl-cuda-interop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cuda/2021-08-07/cl-cuda-20210807-git.tgz"; - sha256 = "019m2khbiadm0yxfhbbfsidnmxq9spn3hn8r6vx4cw3i22jin0hg"; - system = "cl-cuda-interop"; - asd = "cl-cuda-interop"; - }); - systems = [ "cl-cuda-interop" ]; - lispLibs = [ (getAttr "cl-cuda" self) (getAttr "cl-glu" self) (getAttr "cl-glut" self) (getAttr "cl-opengl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cuda-interop-examples = (build-asdf-system { - pname = "cl-cuda-interop-examples"; - version = "20210807-git"; - asds = [ "cl-cuda-interop-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cuda/2021-08-07/cl-cuda-20210807-git.tgz"; - sha256 = "019m2khbiadm0yxfhbbfsidnmxq9spn3hn8r6vx4cw3i22jin0hg"; - system = "cl-cuda-interop-examples"; - asd = "cl-cuda-interop-examples"; - }); - systems = [ "cl-cuda-interop-examples" ]; - lispLibs = [ (getAttr "cl-cuda-interop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-cuda-misc = (build-asdf-system { - pname = "cl-cuda-misc"; - version = "20210807-git"; - asds = [ "cl-cuda-misc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cuda/2021-08-07/cl-cuda-20210807-git.tgz"; - sha256 = "019m2khbiadm0yxfhbbfsidnmxq9spn3hn8r6vx4cw3i22jin0hg"; - system = "cl-cuda-misc"; - asd = "cl-cuda-misc"; - }); - systems = [ "cl-cuda-misc" ]; - lispLibs = [ (getAttr "cl-emb" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-custom-hash-table = (build-asdf-system { - pname = "cl-custom-hash-table"; - version = "20241012-git"; - asds = [ "cl-custom-hash-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-custom-hash-table/2024-10-12/cl-custom-hash-table-20241012-git.tgz"; - sha256 = "1sb5anv9kh7wv165nra95v0qkk1gvp3mn461zi7m0fla1290g598"; - system = "cl-custom-hash-table"; - asd = "cl-custom-hash-table"; - }); - systems = [ "cl-custom-hash-table" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-custom-hash-table-test = (build-asdf-system { - pname = "cl-custom-hash-table-test"; - version = "20241012-git"; - asds = [ "cl-custom-hash-table-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-custom-hash-table/2024-10-12/cl-custom-hash-table-20241012-git.tgz"; - sha256 = "1sb5anv9kh7wv165nra95v0qkk1gvp3mn461zi7m0fla1290g598"; - system = "cl-custom-hash-table-test"; - asd = "cl-custom-hash-table-test"; - }); - systems = [ "cl-custom-hash-table-test" ]; - lispLibs = [ (getAttr "cl-custom-hash-table" self) (getAttr "hu_dot_dwim_dot_stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-data-structures = (build-asdf-system { - pname = "cl-data-structures"; - version = "20241012-git"; - asds = [ "cl-data-structures" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-data-structures/2024-10-12/cl-data-structures-20241012-git.tgz"; - sha256 = "0h49h1x9dgr53imj0r4lgx0zvdsv3mnh7lyayzy9hlysy2ixp425"; - system = "cl-data-structures"; - asd = "cl-data-structures"; - }); - systems = [ "cl-data-structures" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "documentation-utils-extensions" self) (getAttr "flexichain" self) (getAttr "iterate" self) (getAttr "lparallel" self) (getAttr "metabang-bind" self) (getAttr "more-conditions" self) (getAttr "serapeum" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-data-structures-tests = (build-asdf-system { - pname = "cl-data-structures-tests"; - version = "20241012-git"; - asds = [ "cl-data-structures-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-data-structures/2024-10-12/cl-data-structures-20241012-git.tgz"; - sha256 = "0h49h1x9dgr53imj0r4lgx0zvdsv3mnh7lyayzy9hlysy2ixp425"; - system = "cl-data-structures-tests"; - asd = "cl-data-structures-tests"; - }); - systems = [ "cl-data-structures-tests" ]; - lispLibs = [ (getAttr "cl-data-structures" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-date-time-parser = (build-asdf-system { - pname = "cl-date-time-parser"; - version = "20140713-git"; - asds = [ "cl-date-time-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-date-time-parser/2014-07-13/cl-date-time-parser-20140713-git.tgz"; - sha256 = "0dswpbbb57jm609xxfah25dxxhjzc7qh5lr1a1ffkpms84l0r7m5"; - system = "cl-date-time-parser"; - asd = "cl-date-time-parser"; - }); - systems = [ "cl-date-time-parser" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cl-ppcre" self) (getAttr "local-time" self) (getAttr "parse-float" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-dbi = (build-asdf-system { - pname = "cl-dbi"; - version = "20241012-git"; - asds = [ "cl-dbi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dbi/2024-10-12/cl-dbi-20241012-git.tgz"; - sha256 = "17szd6sz1hlwl5fm4qjgyd8ax01wkbhv8hxcyy8qscx39sc0cnpy"; - system = "cl-dbi"; - asd = "cl-dbi"; - }); - systems = [ "cl-dbi" ]; - lispLibs = [ (getAttr "dbi" self) ]; - meta = {}; - }); - cl-debug-print = (build-asdf-system { - pname = "cl-debug-print"; - version = "20210807-git"; - asds = [ "cl-debug-print" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-debug-print/2021-08-07/cl-debug-print-20210807-git.tgz"; - sha256 = "1cm5nybmv0pq9s4lrwhd01rjj1wlcj1sjcrcakabi7w7b5zw4cyh"; - system = "cl-debug-print"; - asd = "cl-debug-print"; - }); - systems = [ "cl-debug-print" ]; - lispLibs = [ (getAttr "cl-syntax" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-debug-print-test = (build-asdf-system { - pname = "cl-debug-print-test"; - version = "20210807-git"; - asds = [ "cl-debug-print-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-debug-print/2021-08-07/cl-debug-print-20210807-git.tgz"; - sha256 = "1cm5nybmv0pq9s4lrwhd01rjj1wlcj1sjcrcakabi7w7b5zw4cyh"; - system = "cl-debug-print-test"; - asd = "cl-debug-print-test"; - }); - systems = [ "cl-debug-print-test" ]; - lispLibs = [ (getAttr "cl-debug-print" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-dejavu = (build-asdf-system { - pname = "cl-dejavu"; - version = "20210124-git"; - asds = [ "cl-dejavu" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dejavu/2021-01-24/cl-dejavu-20210124-git.tgz"; - sha256 = "1lbxiq21bxj8r11c58cqskgn8gnl2p8q1ydkhdsv7i7xnhv2y7r0"; - system = "cl-dejavu"; - asd = "cl-dejavu"; - }); - systems = [ "cl-dejavu" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-devil = (build-asdf-system { - pname = "cl-devil"; - version = "20150302-git"; - asds = [ "cl-devil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-devil/2015-03-02/cl-devil-20150302-git.tgz"; - sha256 = "1qdjb7xwzjkv99s8q0834lfdq4ch5j2ymrmqsvwzhg47ys17pvvf"; - system = "cl-devil"; - asd = "cl-devil"; - }); - systems = [ "cl-devil" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-diceware = (build-asdf-system { - pname = "cl-diceware"; - version = "20150923-git"; - asds = [ "cl-diceware" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-diceware/2015-09-23/cl-diceware-20150923-git.tgz"; - sha256 = "0560ji51ksp8kngn2pyi41vw9zlnwiqj64ici43lzjx0qgv5v84l"; - system = "cl-diceware"; - asd = "cl-diceware"; - }); - systems = [ "cl-diceware" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-difflib = (build-asdf-system { - pname = "cl-difflib"; - version = "20130128-git"; - asds = [ "cl-difflib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-difflib/2013-01-28/cl-difflib-20130128-git.tgz"; - sha256 = "08if0abhqg191xcz9s7xv8faqq51nswzp8hw423fkqjzr24pmq48"; - system = "cl-difflib"; - asd = "cl-difflib"; - }); - systems = [ "cl-difflib" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-difflib-tests = (build-asdf-system { - pname = "cl-difflib-tests"; - version = "20130128-git"; - asds = [ "cl-difflib-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-difflib/2013-01-28/cl-difflib-20130128-git.tgz"; - sha256 = "08if0abhqg191xcz9s7xv8faqq51nswzp8hw423fkqjzr24pmq48"; - system = "cl-difflib-tests"; - asd = "cl-difflib-tests"; - }); - systems = [ "cl-difflib-tests" ]; - lispLibs = [ (getAttr "cl-difflib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-digraph = (build-asdf-system { - pname = "cl-digraph"; - version = "20241012-hg"; - asds = [ "cl-digraph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-digraph/2024-10-12/cl-digraph-20241012-hg.tgz"; - sha256 = "18avbb608rv5radbczilfzb2857wz7pad49hwhr5za5qycjam8ss"; - system = "cl-digraph"; - asd = "cl-digraph"; - }); - systems = [ "cl-digraph" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-digraph_dot_dot = (build-asdf-system { - pname = "cl-digraph.dot"; - version = "20241012-hg"; - asds = [ "cl-digraph.dot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-digraph/2024-10-12/cl-digraph-20241012-hg.tgz"; - sha256 = "18avbb608rv5radbczilfzb2857wz7pad49hwhr5za5qycjam8ss"; - system = "cl-digraph.dot"; - asd = "cl-digraph.dot"; - }); - systems = [ "cl-digraph.dot" ]; - lispLibs = [ (getAttr "cl-digraph" self) (getAttr "cl-dot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-digraph_dot_test = (build-asdf-system { - pname = "cl-digraph.test"; - version = "20241012-hg"; - asds = [ "cl-digraph.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-digraph/2024-10-12/cl-digraph-20241012-hg.tgz"; - sha256 = "18avbb608rv5radbczilfzb2857wz7pad49hwhr5za5qycjam8ss"; - system = "cl-digraph.test"; - asd = "cl-digraph.test"; - }); - systems = [ "cl-digraph.test" ]; - lispLibs = [ (getAttr "_1am" self) (getAttr "alexandria" self) (getAttr "cl-digraph" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-diskspace = (build-asdf-system { - pname = "cl-diskspace"; - version = "20220331-git"; - asds = [ "cl-diskspace" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-diskspace/2022-03-31/cl-diskspace-20220331-git.tgz"; - sha256 = "0l19hxqw6b8i5i1jdbr45k1xib9axcwdagsp3y8wkb35g6wwc0s7"; - system = "cl-diskspace"; - asd = "cl-diskspace"; - }); - systems = [ "cl-diskspace" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-disque = (build-asdf-system { - pname = "cl-disque"; - version = "20171227-git"; - asds = [ "cl-disque" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-disque/2017-12-27/cl-disque-20171227-git.tgz"; - sha256 = "0z26ls9vzlq43fwn307nb7xvqck5h3l9yygf93b0filki83krg3s"; - system = "cl-disque"; - asd = "cl-disque"; - }); - systems = [ "cl-disque" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "rutils" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-disque-test = (build-asdf-system { - pname = "cl-disque-test"; - version = "20171227-git"; - asds = [ "cl-disque-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-disque/2017-12-27/cl-disque-20171227-git.tgz"; - sha256 = "0z26ls9vzlq43fwn307nb7xvqck5h3l9yygf93b0filki83krg3s"; - system = "cl-disque-test"; - asd = "cl-disque-test"; - }); - systems = [ "cl-disque-test" ]; - lispLibs = [ (getAttr "cl-disque" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-djula-svg = (build-asdf-system { - pname = "cl-djula-svg"; - version = "20221106-git"; - asds = [ "cl-djula-svg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-djula-svg/2022-11-06/cl-djula-svg-20221106-git.tgz"; - sha256 = "1jxgngr51ars234by4vnczfqmkwi2iy94sdxnj3pkjrdximy5any"; - system = "cl-djula-svg"; - asd = "cl-djula-svg"; - }); - systems = [ "cl-djula-svg" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "xmls" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-djula-tailwind = (build-asdf-system { - pname = "cl-djula-tailwind"; - version = "20221106-git"; - asds = [ "cl-djula-tailwind" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-djula-tailwind/2022-11-06/cl-djula-tailwind-20221106-git.tgz"; - sha256 = "059mfgh53gpj74rgr7b61fnm24bwx8hdrw15mjk687y9sna3avda"; - system = "cl-djula-tailwind"; - asd = "cl-djula-tailwind"; - }); - systems = [ "cl-djula-tailwind" ]; - lispLibs = [ (getAttr "cl-css" self) (getAttr "cl-minify-css" self) (getAttr "cl-ppcre" self) (getAttr "djula" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-dot = (build-asdf-system { - pname = "cl-dot"; - version = "20241012-git"; - asds = [ "cl-dot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dot/2024-10-12/cl-dot-20241012-git.tgz"; - sha256 = "1874jsc51pkyh6rz27qdhhsdyzx1mr7zx7v65m849wp49qlxs1ya"; - system = "cl-dot"; - asd = "cl-dot"; - }); - systems = [ "cl-dot" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-dotenv = (build-asdf-system { - pname = "cl-dotenv"; - version = "20181018-git"; - asds = [ "cl-dotenv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dotenv/2018-10-18/cl-dotenv-20181018-git.tgz"; - sha256 = "0cdbk886aizsnqqs3z4jfn8nyrnxj4yb3y00av49xc4h83h6xn53"; - system = "cl-dotenv"; - asd = "cl-dotenv"; - }); - systems = [ "cl-dotenv" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-dotenv-test = (build-asdf-system { - pname = "cl-dotenv-test"; - version = "20181018-git"; - asds = [ "cl-dotenv-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dotenv/2018-10-18/cl-dotenv-20181018-git.tgz"; - sha256 = "0cdbk886aizsnqqs3z4jfn8nyrnxj4yb3y00av49xc4h83h6xn53"; - system = "cl-dotenv-test"; - asd = "cl-dotenv-test"; - }); - systems = [ "cl-dotenv-test" ]; - lispLibs = [ (getAttr "cl-dotenv" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-drawille = (build-asdf-system { - pname = "cl-drawille"; - version = "20210807-git"; - asds = [ "cl-drawille" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-drawille/2021-08-07/cl-drawille-20210807-git.tgz"; - sha256 = "0wmiz0c7h2zsfj7inzzn8jivnfsc94rq8pczfi44h36n2jg6hdys"; - system = "cl-drawille"; - asd = "cl-drawille"; - }); - systems = [ "cl-drawille" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "osicat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-drm = (build-asdf-system { - pname = "cl-drm"; - version = "20161204-git"; - asds = [ "cl-drm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-drm/2016-12-04/cl-drm-20161204-git.tgz"; - sha256 = "018jsdi9hs71x14mq18k08hwrgdvvbc2yqbqww6gara0bg9cl3l6"; - system = "cl-drm"; - asd = "cl-drm"; - }); - systems = [ "cl-drm" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-dropbox = (build-asdf-system { - pname = "cl-dropbox"; - version = "20150608-git"; - asds = [ "cl-dropbox" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dropbox/2015-06-08/cl-dropbox-20150608-git.tgz"; - sha256 = "09giwr1wlz42flrpy71gv60p53nixjk9jaj4lirgf59dkh718f9x"; - system = "cl-dropbox"; - asd = "cl-dropbox"; - }); - systems = [ "cl-dropbox" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "cl-oauth" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-dsl = (build-asdf-system { - pname = "cl-dsl"; - version = "20130720-git"; - asds = [ "cl-dsl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dsl/2013-07-20/cl-dsl-20130720-git.tgz"; - sha256 = "1bj5yp20r8z6gi6rpf88kpy4i06c8i2d3cg5sjlq7d1ninkb4gg4"; - system = "cl-dsl"; - asd = "cl-dsl"; - }); - systems = [ "cl-dsl" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-dsl-tests = (build-asdf-system { - pname = "cl-dsl-tests"; - version = "20130720-git"; - asds = [ "cl-dsl-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dsl/2013-07-20/cl-dsl-20130720-git.tgz"; - sha256 = "1bj5yp20r8z6gi6rpf88kpy4i06c8i2d3cg5sjlq7d1ninkb4gg4"; - system = "cl-dsl-tests"; - asd = "cl-dsl"; - }); - systems = [ "cl-dsl-tests" ]; - lispLibs = [ (getAttr "cl-dsl" self) (getAttr "eos" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-durian = (build-asdf-system { - pname = "cl-durian"; - version = "20150608-git"; - asds = [ "cl-durian" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-durian/2015-06-08/cl-durian-20150608-git.tgz"; - sha256 = "0s89gr5gwwkyirrv7l5fzk9ws7fhy087c3myksblsh00z1xcrvng"; - system = "cl-durian"; - asd = "cl-durian"; - }); - systems = [ "cl-durian" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-earley-parser = (build-asdf-system { - pname = "cl-earley-parser"; - version = "20211020-git"; - asds = [ "cl-earley-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-earley-parser/2021-10-20/cl-earley-parser-20211020-git.tgz"; - sha256 = "1pkry3ynxn2y3nf13lc3zjqgf4hx43d9zb0w0m34s51xd4xp2h1x"; - system = "cl-earley-parser"; - asd = "cl-earley-parser"; - }); - systems = [ "cl-earley-parser" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ecma-48 = (build-asdf-system { - pname = "cl-ecma-48"; - version = "20200218-http"; - asds = [ "cl-ecma-48" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ecma-48/2020-02-18/cl-ecma-48-20200218-http.tgz"; - sha256 = "1y3srzahci25qp959b87m82d1i1i8jmq039yp9nf0hifxyhw6dgy"; - system = "cl-ecma-48"; - asd = "cl-ecma-48"; - }); - systems = [ "cl-ecma-48" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-egl = (build-asdf-system { - pname = "cl-egl"; - version = "20190521-git"; - asds = [ "cl-egl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-egl/2019-05-21/cl-egl-20190521-git.tgz"; - sha256 = "19shhzmdc9f1128slc9m4ns6zraka99awqgb4dkrwzgv7w3miqfl"; - system = "cl-egl"; - asd = "cl-egl"; - }); - systems = [ "cl-egl" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-elastic = (build-asdf-system { - pname = "cl-elastic"; - version = "20200218-git"; - asds = [ "cl-elastic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-elastic/2020-02-18/cl-elastic-20200218-git.tgz"; - sha256 = "107ha226n3mxzvm0cp8kvgybcv4rr0b4lwik4f4j7lrhz6xvnncq"; - system = "cl-elastic"; - asd = "cl-elastic"; - }); - systems = [ "cl-elastic" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "named-readtables" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-elastic-test = (build-asdf-system { - pname = "cl-elastic-test"; - version = "20200218-git"; - asds = [ "cl-elastic-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-elastic/2020-02-18/cl-elastic-20200218-git.tgz"; - sha256 = "107ha226n3mxzvm0cp8kvgybcv4rr0b4lwik4f4j7lrhz6xvnncq"; - system = "cl-elastic-test"; - asd = "cl-elastic-test"; - }); - systems = [ "cl-elastic-test" ]; - lispLibs = [ (getAttr "cl-elastic" self) (getAttr "named-readtables" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-emacs-if = (build-asdf-system { - pname = "cl-emacs-if"; - version = "20120305-git"; - asds = [ "cl-emacs-if" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-emacs-if/2012-03-05/cl-emacs-if-20120305-git.tgz"; - sha256 = "0br3jvihq24ymqjn2r2qnl3l099r329bsqh18nmkk3yw3kclrcfv"; - system = "cl-emacs-if"; - asd = "cl-emacs-if"; - }); - systems = [ "cl-emacs-if" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-emb = (build-asdf-system { - pname = "cl-emb"; - version = "20190521-git"; - asds = [ "cl-emb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-emb/2019-05-21/cl-emb-20190521-git.tgz"; - sha256 = "1xcm31n7afh5316lwz8iqbjx7kn5lw0l11arg8mhdmkx42aj4gkk"; - system = "cl-emb"; - asd = "cl-emb"; - }); - systems = [ "cl-emb" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = {}; - }); - cl-emoji = (build-asdf-system { - pname = "cl-emoji"; - version = "20200218-git"; - asds = [ "cl-emoji" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-emoji/2020-02-18/cl-emoji-20200218-git.tgz"; - sha256 = "1v91kzx42qyjm936frvfsr0cgnj9g197x78xlda6x7x6xri2r9gm"; - system = "cl-emoji"; - asd = "cl-emoji"; - }); - systems = [ "cl-emoji" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-emoji-test = (build-asdf-system { - pname = "cl-emoji-test"; - version = "20200218-git"; - asds = [ "cl-emoji-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-emoji/2020-02-18/cl-emoji-20200218-git.tgz"; - sha256 = "1v91kzx42qyjm936frvfsr0cgnj9g197x78xlda6x7x6xri2r9gm"; - system = "cl-emoji-test"; - asd = "cl-emoji-test"; - }); - systems = [ "cl-emoji-test" ]; - lispLibs = [ (getAttr "cl-emoji" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-env = (build-asdf-system { - pname = "cl-env"; - version = "20180430-git"; - asds = [ "cl-env" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-env/2018-04-30/cl-env-20180430-git.tgz"; - sha256 = "1r0d004gr1za9ib53jhxkx315wd4av0ar2063dcvs9g4nahk2d07"; - system = "cl-env"; - asd = "cl-env"; - }); - systems = [ "cl-env" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-environments = (build-asdf-system { - pname = "cl-environments"; - version = "20241012-git"; - asds = [ "cl-environments" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-environments/2024-10-12/cl-environments-20241012-git.tgz"; - sha256 = "0pafk4c0qdzqp0l23fi1pgrqycbcrwm51wq0x0jvr7975yfx2lim"; - system = "cl-environments"; - asd = "cl-environments"; - }); - systems = [ "cl-environments" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "collectors" self) (getAttr "optima" self) (getAttr "parse-declarations-1_dot_0" self) ]; - meta = {}; - }); - cl-etcd = (build-asdf-system { - pname = "cl-etcd"; - version = "20230214-git"; - asds = [ "cl-etcd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-etcd/2023-02-14/cl-etcd-20230214-git.tgz"; - sha256 = "0bals10r07prxvjxd744vz02ri72isf168lkhrx9qkc96hd214ah"; - system = "cl-etcd"; - asd = "cl-etcd"; - }); - systems = [ "cl-etcd" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "async-process" self) (getAttr "bordeaux-threads" self) (getAttr "cl-base64" self) (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "flexi-streams" self) (getAttr "split-sequence" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-events = (build-asdf-system { - pname = "cl-events"; - version = "20160318-git"; - asds = [ "cl-events" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-events/2016-03-18/cl-events-20160318-git.tgz"; - sha256 = "1r847q1bwblnb2395dsydylr9nxgjx7gdwc9dx1051zhvi9in36g"; - system = "cl-events"; - asd = "cl-events"; - }); - systems = [ "cl-events" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "blackbird" self) (getAttr "iterate" self) (getAttr "log4cl" self) (getAttr "lparallel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-events_dot_test = (build-asdf-system { - pname = "cl-events.test"; - version = "20160318-git"; - asds = [ "cl-events.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-events/2016-03-18/cl-events-20160318-git.tgz"; - sha256 = "1r847q1bwblnb2395dsydylr9nxgjx7gdwc9dx1051zhvi9in36g"; - system = "cl-events.test"; - asd = "cl-events.test"; - }); - systems = [ "cl-events.test" ]; - lispLibs = [ (getAttr "cl-events" self) (getAttr "log4cl" self) (getAttr "mw-equiv" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ewkb = (build-asdf-system { - pname = "cl-ewkb"; - version = "20110619-git"; - asds = [ "cl-ewkb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ewkb/2011-06-19/cl-ewkb-20110619-git.tgz"; - sha256 = "1mk5j34m9gkwl7c4d464l42gclxlrcpifp2nq41z3fsfl8badn6w"; - system = "cl-ewkb"; - asd = "cl-ewkb"; - }); - systems = [ "cl-ewkb" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "ieee-floats" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ewkb-tests = (build-asdf-system { - pname = "cl-ewkb-tests"; - version = "20110619-git"; - asds = [ "cl-ewkb-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ewkb/2011-06-19/cl-ewkb-20110619-git.tgz"; - sha256 = "1mk5j34m9gkwl7c4d464l42gclxlrcpifp2nq41z3fsfl8badn6w"; - system = "cl-ewkb-tests"; - asd = "cl-ewkb"; - }); - systems = [ "cl-ewkb-tests" ]; - lispLibs = [ (getAttr "cl-ewkb" self) (getAttr "postmodern" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-factoring = (build-asdf-system { - pname = "cl-factoring"; - version = "20221106-git"; - asds = [ "cl-factoring" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-factoring/2022-11-06/cl-factoring-20221106-git.tgz"; - sha256 = "0vn3kb8mmi93pr76lx1mbwp7qc2krzb0ayzcrffwq2aw2q201fhd"; - system = "cl-factoring"; - asd = "cl-factoring"; - }); - systems = [ "cl-factoring" ]; - lispLibs = [ (getAttr "cl-primality" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fad = (build-asdf-system { - pname = "cl-fad"; - version = "20220220-git"; - asds = [ "cl-fad" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fad/2022-02-20/cl-fad-20220220-git.tgz"; - sha256 = "0a1xqldrq170lflnns3xp6swpnvsvllf5vq0h7sz8jqh4riqlny6"; - system = "cl-fad"; - asd = "cl-fad"; - }); - systems = [ "cl-fad" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) ]; - meta = {}; - }); - cl-fam = (build-asdf-system { - pname = "cl-fam"; - version = "20121125-git"; - asds = [ "cl-fam" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fam/2012-11-25/cl-fam-20121125-git.tgz"; - sha256 = "1imv87imhxvigghx3l28kbsldz6hpqd32280wjwffqwvadhx0gng"; - system = "cl-fam"; - asd = "cl-fam"; - }); - systems = [ "cl-fam" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fast-ecs = (build-asdf-system { - pname = "cl-fast-ecs"; - version = "20241012-git"; - asds = [ "cl-fast-ecs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fast-ecs/2024-10-12/cl-fast-ecs-20241012-git.tgz"; - sha256 = "0hwprzq6dnbfh4y08db615gzpdpr8vphy27whgsjhyg980503hxv"; - system = "cl-fast-ecs"; - asd = "cl-fast-ecs"; - }); - systems = [ "cl-fast-ecs" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fastcgi = (build-asdf-system { - pname = "cl-fastcgi"; - version = "20241012-git"; - asds = [ "cl-fastcgi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fastcgi/2024-10-12/cl-fastcgi-20241012-git.tgz"; - sha256 = "0hf6a8jrz8dx91px8q4201k3y919ls7cgn4qjmkqxqhjk2gxy5k7"; - system = "cl-fastcgi"; - asd = "cl-fastcgi"; - }); - systems = [ "cl-fastcgi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fbclient = (build-asdf-system { - pname = "cl-fbclient"; - version = "20140113-git"; - asds = [ "cl-fbclient" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fbclient/2014-01-13/cl-fbclient-20140113-git.tgz"; - sha256 = "1q2dwizrjnal3fdcdgim4kdq0dma71p3s8w6i8bjkg4fs49k5p9j"; - system = "cl-fbclient"; - asd = "cl-fbclient"; - }); - systems = [ "cl-fbclient" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fbx = (build-asdf-system { - pname = "cl-fbx"; - version = "20241012-git"; - asds = [ "cl-fbx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fbx/2024-10-12/cl-fbx-20241012-git.tgz"; - sha256 = "1g6s3ili3fcxy37g34ykmf2zc6nm70sh5q0diqbikikaly8kfi50"; - system = "cl-fbx"; - asd = "cl-fbx"; - }); - systems = [ "cl-fbx" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "float-features" self) (getAttr "static-vectors" self) (getAttr "trivial-extensible-sequences" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-feedparser = (build-asdf-system { - pname = "cl-feedparser"; - version = "20230618-git"; - asds = [ "cl-feedparser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-feedparser/2023-06-18/cl-feedparser-20230618-git.tgz"; - sha256 = "18cl4318g8szhdsqvg68ajry91m1hn0znmsqd0r2ikq6l5wpixmb"; - system = "cl-feedparser"; - asd = "cl-feedparser"; - }); - systems = [ "cl-feedparser" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "asdf-package-system" self) (getAttr "cl-html5-parser" self) (getAttr "cl-ppcre" self) (getAttr "fset" self) (getAttr "fxml" self) (getAttr "local-time" self) (getAttr "net-telent-date" self) (getAttr "plump" self) (getAttr "quri" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-feedparser-tests = (build-asdf-system { - pname = "cl-feedparser-tests"; - version = "20230618-git"; - asds = [ "cl-feedparser-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-feedparser/2023-06-18/cl-feedparser-20230618-git.tgz"; - sha256 = "18cl4318g8szhdsqvg68ajry91m1hn0znmsqd0r2ikq6l5wpixmb"; - system = "cl-feedparser-tests"; - asd = "cl-feedparser-tests"; - }); - systems = [ "cl-feedparser-tests" ]; - lispLibs = [ (getAttr "cl-feedparser" self) (getAttr "fiveam" self) (getAttr "fxml" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fix = (build-asdf-system { - pname = "cl-fix"; - version = "20230214-git"; - asds = [ "cl-fix" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fix/2023-02-14/cl-fix-20230214-git.tgz"; - sha256 = "0hw9sms558vn964sw5bav74wmfahf066nqj1xyd6b3f1lz3jarbb"; - system = "cl-fix"; - asd = "cl-fix"; - }); - systems = [ "cl-fix" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "arrow-macros" self) (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "local-time" self) (getAttr "log4cl" self) (getAttr "parse-number" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fixtures = (build-asdf-system { - pname = "cl-fixtures"; - version = "20200325-git"; - asds = [ "cl-fixtures" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fixtures/2020-03-25/cl-fixtures-20200325-git.tgz"; - sha256 = "01z8brw32lv8lqn6r9srwrna5gkd4cyncpbpg6pc0khgdxzpzaag"; - system = "cl-fixtures"; - asd = "cl-fixtures"; - }); - systems = [ "cl-fixtures" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fixtures-test = (build-asdf-system { - pname = "cl-fixtures-test"; - version = "20200325-git"; - asds = [ "cl-fixtures-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fixtures/2020-03-25/cl-fixtures-20200325-git.tgz"; - sha256 = "01z8brw32lv8lqn6r9srwrna5gkd4cyncpbpg6pc0khgdxzpzaag"; - system = "cl-fixtures-test"; - asd = "cl-fixtures-test"; - }); - systems = [ "cl-fixtures-test" ]; - lispLibs = [ (getAttr "cl-fixtures" self) (getAttr "incf-cl" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "rutils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-flac = (build-asdf-system { - pname = "cl-flac"; - version = "20231021-git"; - asds = [ "cl-flac" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-flac/2023-10-21/cl-flac-20231021-git.tgz"; - sha256 = "1p6hrg9j58yyml78l82zd6p33apbbnbw24slxw876n2j30qiyc84"; - system = "cl-flac"; - asd = "cl-flac"; - }); - systems = [ "cl-flac" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-flow = (build-asdf-system { - pname = "cl-flow"; - version = "stable-git"; - asds = [ "cl-flow" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-flow/2022-07-07/cl-flow-stable-git.tgz"; - sha256 = "0mh9g0zj2kwnsq31zg4af5k9jvfbwp28zx02f0r1jlg2rha87vlg"; - system = "cl-flow"; - asd = "cl-flow"; - }); - systems = [ "cl-flow" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-muth" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-flowd = (build-asdf-system { - pname = "cl-flowd"; - version = "20140713-git"; - asds = [ "cl-flowd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-flowd/2014-07-13/cl-flowd-20140713-git.tgz"; - sha256 = "0qppiqgy4fgvkm519bqjrw1mfp90q8fs1spvawf24d1nzslf51pj"; - system = "cl-flowd"; - asd = "cl-flowd"; - }); - systems = [ "cl-flowd" ]; - lispLibs = [ (getAttr "cl-annot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fluent-logger = (build-asdf-system { - pname = "cl-fluent-logger"; - version = "20241012-git"; - asds = [ "cl-fluent-logger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fluent-logger/2024-10-12/cl-fluent-logger-20241012-git.tgz"; - sha256 = "0dqmx28d49fraqymrvaxq19d1x5nd6sb30bza7s9vgcyz404hzg4"; - system = "cl-fluent-logger"; - asd = "cl-fluent-logger"; - }); - systems = [ "cl-fluent-logger" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "chanl" self) (getAttr "cl-messagepack" self) (getAttr "jonathan" self) (getAttr "local-time" self) (getAttr "pack" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fluiddb = (build-asdf-system { - pname = "cl-fluiddb"; - version = "20130312-git"; - asds = [ "cl-fluiddb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fluidinfo/2013-03-12/cl-fluidinfo-20130312-git.tgz"; - sha256 = "0npkkp2w88f6vb9pckjp4q4d4idx9p2s4s4imljs2vfym2j3w0wb"; - system = "cl-fluiddb"; - asd = "cl-fluiddb"; - }); - systems = [ "cl-fluiddb" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-json" self) (getAttr "drakma" self) (getAttr "flexi-streams" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fluiddb-test = (build-asdf-system { - pname = "cl-fluiddb-test"; - version = "20130312-git"; - asds = [ "cl-fluiddb-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fluidinfo/2013-03-12/cl-fluidinfo-20130312-git.tgz"; - sha256 = "0npkkp2w88f6vb9pckjp4q4d4idx9p2s4s4imljs2vfym2j3w0wb"; - system = "cl-fluiddb-test"; - asd = "cl-fluiddb-test"; - }); - systems = [ "cl-fluiddb-test" ]; - lispLibs = [ (getAttr "cl-fluiddb" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fluidinfo = (build-asdf-system { - pname = "cl-fluidinfo"; - version = "20130312-git"; - asds = [ "cl-fluidinfo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fluidinfo/2013-03-12/cl-fluidinfo-20130312-git.tgz"; - sha256 = "0npkkp2w88f6vb9pckjp4q4d4idx9p2s4s4imljs2vfym2j3w0wb"; - system = "cl-fluidinfo"; - asd = "cl-fluidinfo"; - }); - systems = [ "cl-fluidinfo" ]; - lispLibs = [ (getAttr "cl-fluiddb" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fond = (build-asdf-system { - pname = "cl-fond"; - version = "20191130-git"; - asds = [ "cl-fond" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fond/2019-11-30/cl-fond-20191130-git.tgz"; - sha256 = "03ygcw1azb44bhdsqcq99xi4ci0by76ap5jf5l2d1vfxq04v8grq"; - system = "cl-fond"; - asd = "cl-fond"; - }); - systems = [ "cl-fond" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-opengl" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-form-types = (build-asdf-system { - pname = "cl-form-types"; - version = "20241012-git"; - asds = [ "cl-form-types" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-form-types/2024-10-12/cl-form-types-20241012-git.tgz"; - sha256 = "1qc9dy9ji14nz5k2i17idbfks3ddwrwy9bf60rq95pnngkzqs3d1"; - system = "cl-form-types"; - asd = "cl-form-types"; - }); - systems = [ "cl-form-types" ]; - lispLibs = [ (getAttr "agutil" self) (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "arrows" self) (getAttr "cl-environments" self) (getAttr "introspect-environment" self) (getAttr "optima" self) ]; - meta = {}; - }); - cl-forms = (build-asdf-system { - pname = "cl-forms"; - version = "20241012-git"; - asds = [ "cl-forms" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; - sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; - system = "cl-forms"; - asd = "cl-forms"; - }); - systems = [ "cl-forms" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "clavier" self) (getAttr "fmt" self) (getAttr "hunchentoot" self) (getAttr "ironclad" self) (getAttr "str" self) (getAttr "uuid" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-forms_dot_demo = (build-asdf-system { - pname = "cl-forms.demo"; - version = "20241012-git"; - asds = [ "cl-forms.demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; - sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; - system = "cl-forms.demo"; - asd = "cl-forms.demo"; - }); - systems = [ "cl-forms.demo" ]; - lispLibs = [ (getAttr "cl-css" self) (getAttr "cl-forms" self) (getAttr "cl-forms_dot_djula" self) (getAttr "cl-forms_dot_test" self) (getAttr "cl-forms_dot_who" self) (getAttr "cl-forms_dot_who_dot_bootstrap" self) (getAttr "cl-who" self) (getAttr "djula" self) (getAttr "hunchentoot" self) (getAttr "trivial-open-browser" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-forms_dot_djula = (build-asdf-system { - pname = "cl-forms.djula"; - version = "20241012-git"; - asds = [ "cl-forms.djula" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; - sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; - system = "cl-forms.djula"; - asd = "cl-forms.djula"; - }); - systems = [ "cl-forms.djula" ]; - lispLibs = [ (getAttr "cl-forms" self) (getAttr "cl-forms_dot_who" self) (getAttr "djula" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-forms_dot_peppol = (build-asdf-system { - pname = "cl-forms.peppol"; - version = "20241012-git"; - asds = [ "cl-forms.peppol" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; - sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; - system = "cl-forms.peppol"; - asd = "cl-forms.peppol"; - }); - systems = [ "cl-forms.peppol" ]; - lispLibs = [ (getAttr "cl-forms" self) (getAttr "peppol" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-forms_dot_test = (build-asdf-system { - pname = "cl-forms.test"; - version = "20241012-git"; - asds = [ "cl-forms.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; - sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; - system = "cl-forms.test"; - asd = "cl-forms.test"; - }); - systems = [ "cl-forms.test" ]; - lispLibs = [ (getAttr "cl-forms" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-forms_dot_who = (build-asdf-system { - pname = "cl-forms.who"; - version = "20241012-git"; - asds = [ "cl-forms.who" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; - sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; - system = "cl-forms.who"; - asd = "cl-forms.who"; - }); - systems = [ "cl-forms.who" ]; - lispLibs = [ (getAttr "cl-forms" self) (getAttr "cl-who" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-forms_dot_who_dot_bootstrap = (build-asdf-system { - pname = "cl-forms.who.bootstrap"; - version = "20241012-git"; - asds = [ "cl-forms.who.bootstrap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; - sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; - system = "cl-forms.who.bootstrap"; - asd = "cl-forms.who.bootstrap"; - }); - systems = [ "cl-forms.who.bootstrap" ]; - lispLibs = [ (getAttr "cl-forms_dot_who" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-freeimage = (build-asdf-system { - pname = "cl-freeimage"; - version = "20170403-git"; - asds = [ "cl-freeimage" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-freeimage/2017-04-03/cl-freeimage-20170403-git.tgz"; - sha256 = "1333i8sh670nkb0c35xp511xjlafn5zh8a6gk3wnh19gffvj63hq"; - system = "cl-freeimage"; - asd = "cl-freeimage"; - }); - systems = [ "cl-freeimage" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-freetype2 = (build-asdf-system { - pname = "cl-freetype2"; - version = "20241012-git"; - asds = [ "cl-freetype2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-freetype2/2024-10-12/cl-freetype2-20241012-git.tgz"; - sha256 = "00lkmawhjgqzfrsaaqmnffm7mmn3b31gzwz8g51kdjm9s16vwpjs"; - system = "cl-freetype2"; - asd = "cl-freetype2"; - }); - systems = [ "cl-freetype2" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - cl-freetype2-tests = (build-asdf-system { - pname = "cl-freetype2-tests"; - version = "20241012-git"; - asds = [ "cl-freetype2-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-freetype2/2024-10-12/cl-freetype2-20241012-git.tgz"; - sha256 = "00lkmawhjgqzfrsaaqmnffm7mmn3b31gzwz8g51kdjm9s16vwpjs"; - system = "cl-freetype2-tests"; - asd = "cl-freetype2-tests"; - }); - systems = [ "cl-freetype2-tests" ]; - lispLibs = [ (getAttr "cl-freetype2" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fsnotify = (build-asdf-system { - pname = "cl-fsnotify"; - version = "20150302-git"; - asds = [ "cl-fsnotify" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fsnotify/2015-03-02/cl-fsnotify-20150302-git.tgz"; - sha256 = "0693ga1xqcvi89j3aw0lmyi3a1yl3hrfwli2jiwxv0mgpcaxz0yr"; - system = "cl-fsnotify"; - asd = "cl-fsnotify"; - }); - systems = [ "cl-fsnotify" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ftp = (build-asdf-system { - pname = "cl-ftp"; - version = "20150608-http"; - asds = [ "cl-ftp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ftp/2015-06-08/cl-ftp-20150608-http.tgz"; - sha256 = "1m955rjpaynybzmb9q631mll764hm06lydvhra50mfjj75ynwsvw"; - system = "cl-ftp"; - asd = "cl-ftp"; - }); - systems = [ "cl-ftp" ]; - lispLibs = [ (getAttr "split-sequence" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-fuse = (build-asdf-system { - pname = "cl-fuse"; - version = "20200925-git"; - asds = [ "cl-fuse" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fuse/2020-09-25/cl-fuse-20200925-git.tgz"; - sha256 = "1qxvf8ybn0v1hiaz11k1h47y0dksj8ah9v8jdfrjp9ad1rrrnxqs"; - system = "cl-fuse"; - asd = "cl-fuse"; - }); - systems = [ "cl-fuse" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-utilities" self) (getAttr "iterate" self) (getAttr "trivial-backtrace" self) (getAttr "trivial-utf-8" self) ]; - meta = {}; - }); - cl-fuse-meta-fs = (build-asdf-system { - pname = "cl-fuse-meta-fs"; - version = "20190710-git"; - asds = [ "cl-fuse-meta-fs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fuse-meta-fs/2019-07-10/cl-fuse-meta-fs-20190710-git.tgz"; - sha256 = "1wbi7lvczfn09qb72rg1bps9w51mz42dwa7lyjl2hp8lbwc2a5a9"; - system = "cl-fuse-meta-fs"; - asd = "cl-fuse-meta-fs"; - }); - systems = [ "cl-fuse-meta-fs" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-fuse" self) (getAttr "iterate" self) (getAttr "pcall" self) ]; - meta = {}; - }); - cl-fuzz = (build-asdf-system { - pname = "cl-fuzz"; - version = "20181018-git"; - asds = [ "cl-fuzz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fuzz/2018-10-18/cl-fuzz-20181018-git.tgz"; - sha256 = "1zvlh0nh4iip75p6dblx5kajqaa3hhv6mdjbx9cids8491r388rz"; - system = "cl-fuzz"; - asd = "cl-fuzz"; - }); - systems = [ "cl-fuzz" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = {}; - }); - cl-fxml = (build-asdf-system { - pname = "cl-fxml"; - version = "20220331-git"; - asds = [ "cl-fxml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-fxml/2022-03-31/cl-fxml-20220331-git.tgz"; - sha256 = "0i5w3z0rgyi42rlhvf92k95w6bajf3m1x9g4zprwf602kp7abr3c"; - system = "cl-fxml"; - asd = "cl-fxml"; - }); - systems = [ "cl-fxml" ]; - lispLibs = [ (getAttr "agnostic-lizard" self) (getAttr "alexandria" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gamepad = (build-asdf-system { - pname = "cl-gamepad"; - version = "20241012-git"; - asds = [ "cl-gamepad" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gamepad/2024-10-12/cl-gamepad-20241012-git.tgz"; - sha256 = "015qx89rnkkqaa6qsl78zvb3sb1m4xdgjpgzn5ip5i27gw94770g"; - system = "cl-gamepad"; - asd = "cl-gamepad"; - }); - systems = [ "cl-gamepad" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gap-buffer = (build-asdf-system { - pname = "cl-gap-buffer"; - version = "20230618-git"; - asds = [ "cl-gap-buffer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gap-buffer/2023-06-18/cl-gap-buffer-20230618-git.tgz"; - sha256 = "0dzwhzv139z9pspnh1krnldnk4nfrj8f5khh08085xkc5bgg1jfv"; - system = "cl-gap-buffer"; - asd = "cl-gap-buffer"; - }); - systems = [ "cl-gap-buffer" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gbm = (build-asdf-system { - pname = "cl-gbm"; - version = "20180430-git"; - asds = [ "cl-gbm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gbm/2018-04-30/cl-gbm-20180430-git.tgz"; - sha256 = "14bshi7q1hhyag8va9javjjn5cnhmwyjlw8vvvb4fyzfspz3kpdx"; - system = "cl-gbm"; - asd = "cl-gbm"; - }); - systems = [ "cl-gbm" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gcrypt = (build-asdf-system { - pname = "cl-gcrypt"; - version = "20211209-git"; - asds = [ "cl-gcrypt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gcrypt/2021-12-09/cl-gcrypt-20211209-git.tgz"; - sha256 = "1f4gx5ssirr4f3n68i2da6ad7hbhgsk18zv0gfqy3q635zai0z3w"; - system = "cl-gcrypt"; - asd = "cl-gcrypt"; - }); - systems = [ "cl-gcrypt" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gcrypt-test = (build-asdf-system { - pname = "cl-gcrypt-test"; - version = "20211209-git"; - asds = [ "cl-gcrypt-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gcrypt/2021-12-09/cl-gcrypt-20211209-git.tgz"; - sha256 = "1f4gx5ssirr4f3n68i2da6ad7hbhgsk18zv0gfqy3q635zai0z3w"; - system = "cl-gcrypt-test"; - asd = "cl-gcrypt-test"; - }); - systems = [ "cl-gcrypt-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cffi" self) (getAttr "cl-gcrypt" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gd = (build-asdf-system { - pname = "cl-gd"; - version = "20201220-git"; - asds = [ "cl-gd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gd/2020-12-20/cl-gd-20201220-git.tgz"; - sha256 = "1wa6nv5bdf0v38hzr6cfadkk6mhvvnj9lpl9igcxygdjbnn2a3y6"; - system = "cl-gd"; - asd = "cl-gd"; - }); - systems = [ "cl-gd" ]; - lispLibs = [ (getAttr "uffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gd-test = (build-asdf-system { - pname = "cl-gd-test"; - version = "20201220-git"; - asds = [ "cl-gd-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gd/2020-12-20/cl-gd-20201220-git.tgz"; - sha256 = "1wa6nv5bdf0v38hzr6cfadkk6mhvvnj9lpl9igcxygdjbnn2a3y6"; - system = "cl-gd-test"; - asd = "cl-gd-test"; - }); - systems = [ "cl-gd-test" ]; - lispLibs = [ (getAttr "cl-gd" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gdata = (build-asdf-system { - pname = "cl-gdata"; - version = "20171130-git"; - asds = [ "cl-gdata" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gdata/2017-11-30/cl-gdata-20171130-git.tgz"; - sha256 = "0x2sq03nacjbq7p9baxlhr7bb0xg7v1ljq7qj1b3xrd4rbcibxi9"; - system = "cl-gdata"; - asd = "cl-gdata"; - }); - systems = [ "cl-gdata" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "cxml" self) (getAttr "drakma" self) (getAttr "flexi-streams" self) (getAttr "gzip-stream" self) (getAttr "local-time" self) (getAttr "parse-number" self) (getAttr "split-sequence" self) (getAttr "string-case" self) (getAttr "trivial-utf-8" self) (getAttr "url-rewrite" self) (getAttr "xpath" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gearman = (build-asdf-system { - pname = "cl-gearman"; - version = "20211020-git"; - asds = [ "cl-gearman" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gearman/2021-10-20/cl-gearman-20211020-git.tgz"; - sha256 = "0cnkpqn43p55xlhdi8bws2ssa1ahvzbgggh3pam0zbqma2m525j6"; - system = "cl-gearman"; - asd = "cl-gearman"; - }); - systems = [ "cl-gearman" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "split-sequence" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gearman-test = (build-asdf-system { - pname = "cl-gearman-test"; - version = "20211020-git"; - asds = [ "cl-gearman-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gearman/2021-10-20/cl-gearman-20211020-git.tgz"; - sha256 = "0cnkpqn43p55xlhdi8bws2ssa1ahvzbgggh3pam0zbqma2m525j6"; - system = "cl-gearman-test"; - asd = "cl-gearman-test"; - }); - systems = [ "cl-gearman-test" ]; - lispLibs = [ (getAttr "cl-gearman" self) (getAttr "cl-test-more" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gendoc = (build-asdf-system { - pname = "cl-gendoc"; - version = "20180831-git"; - asds = [ "cl-gendoc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gendoc/2018-08-31/cl-gendoc-20180831-git.tgz"; - sha256 = "19f8fmz2hj332kh3y3fbil2dchpckdsqci6ljhadymd8p2h6w4ws"; - system = "cl-gendoc"; - asd = "cl-gendoc"; - }); - systems = [ "cl-gendoc" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "_3bmd-ext-code-blocks" self) (getAttr "cl-who" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gendoc-docs = (build-asdf-system { - pname = "cl-gendoc-docs"; - version = "20180831-git"; - asds = [ "cl-gendoc-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gendoc/2018-08-31/cl-gendoc-20180831-git.tgz"; - sha256 = "19f8fmz2hj332kh3y3fbil2dchpckdsqci6ljhadymd8p2h6w4ws"; - system = "cl-gendoc-docs"; - asd = "cl-gendoc"; - }); - systems = [ "cl-gendoc-docs" ]; - lispLibs = [ (getAttr "cl-gendoc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gene-searcher = (build-asdf-system { - pname = "cl-gene-searcher"; - version = "20111001-git"; - asds = [ "cl-gene-searcher" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gene-searcher/2011-10-01/cl-gene-searcher-20111001-git.tgz"; - sha256 = "0n8p6yk600h7m050bjxazmcxdrcfrkcklrcj8ncflyshm72qv1yk"; - system = "cl-gene-searcher"; - asd = "cl-gene-searcher"; - }); - systems = [ "cl-gene-searcher" ]; - lispLibs = [ (getAttr "clsql-sqlite3" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-generator = (build-asdf-system { - pname = "cl-generator"; - version = "20221106-git"; - asds = [ "cl-generator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-generator/2022-11-06/cl-generator-20221106-git.tgz"; - sha256 = "0aa5prw6f4fqw9j8m6kvdb3h3lqyvi15dd1l6437p9408mmyxk30"; - system = "cl-generator"; - asd = "cl-generator"; - }); - systems = [ "cl-generator" ]; - lispLibs = [ (getAttr "cl-cont" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-generator-test = (build-asdf-system { - pname = "cl-generator-test"; - version = "20221106-git"; - asds = [ "cl-generator-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-generator/2022-11-06/cl-generator-20221106-git.tgz"; - sha256 = "0aa5prw6f4fqw9j8m6kvdb3h3lqyvi15dd1l6437p9408mmyxk30"; - system = "cl-generator-test"; - asd = "cl-generator-test"; - }); - systems = [ "cl-generator-test" ]; - lispLibs = [ (getAttr "cl-generator" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-geocode = (build-asdf-system { - pname = "cl-geocode"; - version = "20190813-git"; - asds = [ "cl-geocode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-geocode/2019-08-13/cl-geocode-20190813-git.tgz"; - sha256 = "17z0v29rrhsfjikg4sn9ynxckh5i3ahjn7c8qs381n1p9fbd668l"; - system = "cl-geocode"; - asd = "cl-geocode"; - }); - systems = [ "cl-geocode" ]; - lispLibs = [ (getAttr "acl-compat" self) (getAttr "aserve" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-geoip = (build-asdf-system { - pname = "cl-geoip"; - version = "20130615-git"; - asds = [ "cl-geoip" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-geoip/2013-06-15/cl-geoip-20130615-git.tgz"; - sha256 = "0ys8wysppx06j3s0dc9lc9zjizr1fmj388fiigyn1wrdyyka41y2"; - system = "cl-geoip"; - asd = "cl-geoip"; - }); - systems = [ "cl-geoip" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-geometry = (build-asdf-system { - pname = "cl-geometry"; - version = "20160531-git"; - asds = [ "cl-geometry" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-geometry/2016-05-31/cl-geometry-20160531-git.tgz"; - sha256 = "188xrd8plvc34gz7q01zmkdrzxbpwzln103l5dl78pa4a6vzz34h"; - system = "cl-geometry"; - asd = "cl-geometry"; - }); - systems = [ "cl-geometry" ]; - lispLibs = [ (getAttr "iterate" self) (getAttr "trees" self) ]; - meta = {}; - }); - cl-geometry-tests = (build-asdf-system { - pname = "cl-geometry-tests"; - version = "20160531-git"; - asds = [ "cl-geometry-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-geometry/2016-05-31/cl-geometry-20160531-git.tgz"; - sha256 = "188xrd8plvc34gz7q01zmkdrzxbpwzln103l5dl78pa4a6vzz34h"; - system = "cl-geometry-tests"; - asd = "cl-geometry-tests"; - }); - systems = [ "cl-geometry-tests" ]; - lispLibs = [ (getAttr "cl-geometry" self) (getAttr "iterate" self) (getAttr "vecto" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-geos = (build-asdf-system { - pname = "cl-geos"; - version = "20180711-git"; - asds = [ "cl-geos" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-geos/2018-07-11/cl-geos-20180711-git.tgz"; - sha256 = "0igq2c1p82pbkyc7zg90fm3lbsmhwnfmb3q8jc8baklb958555ck"; - system = "cl-geos"; - asd = "cl-geos"; - }); - systems = [ "cl-geos" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "trivial-garbage" self) (getAttr "xarray" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-getopt = (build-asdf-system { - pname = "cl-getopt"; - version = "20211209-git"; - asds = [ "cl-getopt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-getopt/2021-12-09/cl-getopt-20211209-git.tgz"; - sha256 = "16qkpg2qln7q9j5614py00zwsnmxcy3xcmhb4m8f0w0zbnpvkjxl"; - system = "cl-getopt"; - asd = "cl-getopt"; - }); - systems = [ "cl-getopt" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-getx = (build-asdf-system { - pname = "cl-getx"; - version = "20200925-git"; - asds = [ "cl-getx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-getx/2020-09-25/cl-getx-20200925-git.tgz"; - sha256 = "07gi346vqrhnbkdk4l6g06z4shhnx7f4l44jgayzfdd0xkv02brv"; - system = "cl-getx"; - asd = "cl-getx"; - }); - systems = [ "cl-getx" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gimei = (build-asdf-system { - pname = "cl-gimei"; - version = "20211020-git"; - asds = [ "cl-gimei" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gimei/2021-10-20/cl-gimei-20211020-git.tgz"; - sha256 = "1405qbqrrrmanmg2dl7yfdj8z4vcsj1silpsa7i1y00pd18xgk8q"; - system = "cl-gimei"; - asd = "cl-gimei"; - }); - systems = [ "cl-gimei" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-yaml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gio = (build-asdf-system { - pname = "cl-gio"; - version = "20231021-git"; - asds = [ "cl-gio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glib/2023-10-21/cl-glib-20231021-git.tgz"; - sha256 = "07y8hpvdl490p8j4k8y47raqqwnpym9scz7jlg2f1jx897dkssjb"; - system = "cl-gio"; - asd = "cl-gio"; - }); - systems = [ "cl-gio" ]; - lispLibs = [ (getAttr "cl-gobject-introspection-wrapper" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gists = (build-asdf-system { - pname = "cl-gists"; - version = "20231021-git"; - asds = [ "cl-gists" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gists/2023-10-21/cl-gists-20231021-git.tgz"; - sha256 = "0kza5y6jckvydaw9bw8va5kli5d3ybyvil6w2bhf411crd2z15vc"; - system = "cl-gists"; - asd = "cl-gists"; - }); - systems = [ "cl-gists" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "alexandria_plus" self) (getAttr "babel" self) (getAttr "dexador" self) (getAttr "local-time" self) (getAttr "quri" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-git = (build-asdf-system { - pname = "cl-git"; - version = "20230618-git"; - asds = [ "cl-git" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-git/2023-06-18/cl-git-20230618-git.tgz"; - sha256 = "13h7n3nbpf2qq0vq0dz33r0468baskw83pjfxb3hik4rllrv04h6"; - system = "cl-git"; - asd = "cl-git"; - }); - systems = [ "cl-git" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-fad" self) (getAttr "closer-mop" self) (getAttr "flexi-streams" self) (getAttr "local-time" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-github-v3 = (build-asdf-system { - pname = "cl-github-v3"; - version = "20241012-git"; - asds = [ "cl-github-v3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-github-v3/2024-10-12/cl-github-v3-20241012-git.tgz"; - sha256 = "0ayhnildyjjmnyk0a1sx7qxg6vq9kcggaprqf37s5qi4kadvcsr2"; - system = "cl-github-v3"; - asd = "cl-github-v3"; - }); - systems = [ "cl-github-v3" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw = (build-asdf-system { - pname = "cl-glfw"; - version = "20150302-git"; - asds = [ "cl-glfw" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw"; - asd = "cl-glfw"; - }); - systems = [ "cl-glfw" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-glfw-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-ftgl = (build-asdf-system { - pname = "cl-glfw-ftgl"; - version = "20150302-git"; - asds = [ "cl-glfw-ftgl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-ftgl"; - asd = "cl-glfw-ftgl"; - }); - systems = [ "cl-glfw-ftgl" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-glu = (build-asdf-system { - pname = "cl-glfw-glu"; - version = "20150302-git"; - asds = [ "cl-glfw-glu" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-glu"; - asd = "cl-glfw-glu"; - }); - systems = [ "cl-glfw-glu" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-glfw-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-3dfx__multisample = (build-asdf-system { - pname = "cl-glfw-opengl-3dfx_multisample"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-3dfx_multisample" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-3dfx_multisample"; - asd = "cl-glfw-opengl-3dfx_multisample"; - }); - systems = [ "cl-glfw-opengl-3dfx_multisample" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-3dfx__tbuffer = (build-asdf-system { - pname = "cl-glfw-opengl-3dfx_tbuffer"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-3dfx_tbuffer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-3dfx_tbuffer"; - asd = "cl-glfw-opengl-3dfx_tbuffer"; - }); - systems = [ "cl-glfw-opengl-3dfx_tbuffer" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-3dfx__texture__compression__fxt1 = (build-asdf-system { - pname = "cl-glfw-opengl-3dfx_texture_compression_fxt1"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-3dfx_texture_compression_fxt1" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-3dfx_texture_compression_fxt1"; - asd = "cl-glfw-opengl-3dfx_texture_compression_fxt1"; - }); - systems = [ "cl-glfw-opengl-3dfx_texture_compression_fxt1" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-amd__blend__minmax__factor = (build-asdf-system { - pname = "cl-glfw-opengl-amd_blend_minmax_factor"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-amd_blend_minmax_factor" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-amd_blend_minmax_factor"; - asd = "cl-glfw-opengl-amd_blend_minmax_factor"; - }); - systems = [ "cl-glfw-opengl-amd_blend_minmax_factor" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-amd__depth__clamp__separate = (build-asdf-system { - pname = "cl-glfw-opengl-amd_depth_clamp_separate"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-amd_depth_clamp_separate" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-amd_depth_clamp_separate"; - asd = "cl-glfw-opengl-amd_depth_clamp_separate"; - }); - systems = [ "cl-glfw-opengl-amd_depth_clamp_separate" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-amd__draw__buffers__blend = (build-asdf-system { - pname = "cl-glfw-opengl-amd_draw_buffers_blend"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-amd_draw_buffers_blend" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-amd_draw_buffers_blend"; - asd = "cl-glfw-opengl-amd_draw_buffers_blend"; - }); - systems = [ "cl-glfw-opengl-amd_draw_buffers_blend" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-amd__multi__draw__indirect = (build-asdf-system { - pname = "cl-glfw-opengl-amd_multi_draw_indirect"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-amd_multi_draw_indirect" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-amd_multi_draw_indirect"; - asd = "cl-glfw-opengl-amd_multi_draw_indirect"; - }); - systems = [ "cl-glfw-opengl-amd_multi_draw_indirect" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-amd__name__gen__delete = (build-asdf-system { - pname = "cl-glfw-opengl-amd_name_gen_delete"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-amd_name_gen_delete" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-amd_name_gen_delete"; - asd = "cl-glfw-opengl-amd_name_gen_delete"; - }); - systems = [ "cl-glfw-opengl-amd_name_gen_delete" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-amd__performance__monitor = (build-asdf-system { - pname = "cl-glfw-opengl-amd_performance_monitor"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-amd_performance_monitor" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-amd_performance_monitor"; - asd = "cl-glfw-opengl-amd_performance_monitor"; - }); - systems = [ "cl-glfw-opengl-amd_performance_monitor" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-amd__sample__positions = (build-asdf-system { - pname = "cl-glfw-opengl-amd_sample_positions"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-amd_sample_positions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-amd_sample_positions"; - asd = "cl-glfw-opengl-amd_sample_positions"; - }); - systems = [ "cl-glfw-opengl-amd_sample_positions" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-amd__seamless__cubemap__per__texture = (build-asdf-system { - pname = "cl-glfw-opengl-amd_seamless_cubemap_per_texture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-amd_seamless_cubemap_per_texture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-amd_seamless_cubemap_per_texture"; - asd = "cl-glfw-opengl-amd_seamless_cubemap_per_texture"; - }); - systems = [ "cl-glfw-opengl-amd_seamless_cubemap_per_texture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-amd__vertex__shader__tesselator = (build-asdf-system { - pname = "cl-glfw-opengl-amd_vertex_shader_tesselator"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-amd_vertex_shader_tesselator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-amd_vertex_shader_tesselator"; - asd = "cl-glfw-opengl-amd_vertex_shader_tesselator"; - }); - systems = [ "cl-glfw-opengl-amd_vertex_shader_tesselator" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__aux__depth__stencil = (build-asdf-system { - pname = "cl-glfw-opengl-apple_aux_depth_stencil"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_aux_depth_stencil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_aux_depth_stencil"; - asd = "cl-glfw-opengl-apple_aux_depth_stencil"; - }); - systems = [ "cl-glfw-opengl-apple_aux_depth_stencil" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__client__storage = (build-asdf-system { - pname = "cl-glfw-opengl-apple_client_storage"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_client_storage" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_client_storage"; - asd = "cl-glfw-opengl-apple_client_storage"; - }); - systems = [ "cl-glfw-opengl-apple_client_storage" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__element__array = (build-asdf-system { - pname = "cl-glfw-opengl-apple_element_array"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_element_array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_element_array"; - asd = "cl-glfw-opengl-apple_element_array"; - }); - systems = [ "cl-glfw-opengl-apple_element_array" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__fence = (build-asdf-system { - pname = "cl-glfw-opengl-apple_fence"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_fence" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_fence"; - asd = "cl-glfw-opengl-apple_fence"; - }); - systems = [ "cl-glfw-opengl-apple_fence" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__float__pixels = (build-asdf-system { - pname = "cl-glfw-opengl-apple_float_pixels"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_float_pixels" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_float_pixels"; - asd = "cl-glfw-opengl-apple_float_pixels"; - }); - systems = [ "cl-glfw-opengl-apple_float_pixels" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__flush__buffer__range = (build-asdf-system { - pname = "cl-glfw-opengl-apple_flush_buffer_range"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_flush_buffer_range" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_flush_buffer_range"; - asd = "cl-glfw-opengl-apple_flush_buffer_range"; - }); - systems = [ "cl-glfw-opengl-apple_flush_buffer_range" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__object__purgeable = (build-asdf-system { - pname = "cl-glfw-opengl-apple_object_purgeable"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_object_purgeable" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_object_purgeable"; - asd = "cl-glfw-opengl-apple_object_purgeable"; - }); - systems = [ "cl-glfw-opengl-apple_object_purgeable" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__rgb__422 = (build-asdf-system { - pname = "cl-glfw-opengl-apple_rgb_422"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_rgb_422" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_rgb_422"; - asd = "cl-glfw-opengl-apple_rgb_422"; - }); - systems = [ "cl-glfw-opengl-apple_rgb_422" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__row__bytes = (build-asdf-system { - pname = "cl-glfw-opengl-apple_row_bytes"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_row_bytes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_row_bytes"; - asd = "cl-glfw-opengl-apple_row_bytes"; - }); - systems = [ "cl-glfw-opengl-apple_row_bytes" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__specular__vector = (build-asdf-system { - pname = "cl-glfw-opengl-apple_specular_vector"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_specular_vector" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_specular_vector"; - asd = "cl-glfw-opengl-apple_specular_vector"; - }); - systems = [ "cl-glfw-opengl-apple_specular_vector" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__texture__range = (build-asdf-system { - pname = "cl-glfw-opengl-apple_texture_range"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_texture_range" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_texture_range"; - asd = "cl-glfw-opengl-apple_texture_range"; - }); - systems = [ "cl-glfw-opengl-apple_texture_range" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__transform__hint = (build-asdf-system { - pname = "cl-glfw-opengl-apple_transform_hint"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_transform_hint" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_transform_hint"; - asd = "cl-glfw-opengl-apple_transform_hint"; - }); - systems = [ "cl-glfw-opengl-apple_transform_hint" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__vertex__array__object = (build-asdf-system { - pname = "cl-glfw-opengl-apple_vertex_array_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_vertex_array_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_vertex_array_object"; - asd = "cl-glfw-opengl-apple_vertex_array_object"; - }); - systems = [ "cl-glfw-opengl-apple_vertex_array_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__vertex__array__range = (build-asdf-system { - pname = "cl-glfw-opengl-apple_vertex_array_range"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_vertex_array_range" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_vertex_array_range"; - asd = "cl-glfw-opengl-apple_vertex_array_range"; - }); - systems = [ "cl-glfw-opengl-apple_vertex_array_range" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__vertex__program__evaluators = (build-asdf-system { - pname = "cl-glfw-opengl-apple_vertex_program_evaluators"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_vertex_program_evaluators" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_vertex_program_evaluators"; - asd = "cl-glfw-opengl-apple_vertex_program_evaluators"; - }); - systems = [ "cl-glfw-opengl-apple_vertex_program_evaluators" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-apple__ycbcr__422 = (build-asdf-system { - pname = "cl-glfw-opengl-apple_ycbcr_422"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-apple_ycbcr_422" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-apple_ycbcr_422"; - asd = "cl-glfw-opengl-apple_ycbcr_422"; - }); - systems = [ "cl-glfw-opengl-apple_ycbcr_422" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__blend__func__extended = (build-asdf-system { - pname = "cl-glfw-opengl-arb_blend_func_extended"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_blend_func_extended" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_blend_func_extended"; - asd = "cl-glfw-opengl-arb_blend_func_extended"; - }); - systems = [ "cl-glfw-opengl-arb_blend_func_extended" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__color__buffer__float = (build-asdf-system { - pname = "cl-glfw-opengl-arb_color_buffer_float"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_color_buffer_float" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_color_buffer_float"; - asd = "cl-glfw-opengl-arb_color_buffer_float"; - }); - systems = [ "cl-glfw-opengl-arb_color_buffer_float" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__copy__buffer = (build-asdf-system { - pname = "cl-glfw-opengl-arb_copy_buffer"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_copy_buffer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_copy_buffer"; - asd = "cl-glfw-opengl-arb_copy_buffer"; - }); - systems = [ "cl-glfw-opengl-arb_copy_buffer" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__depth__buffer__float = (build-asdf-system { - pname = "cl-glfw-opengl-arb_depth_buffer_float"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_depth_buffer_float" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_depth_buffer_float"; - asd = "cl-glfw-opengl-arb_depth_buffer_float"; - }); - systems = [ "cl-glfw-opengl-arb_depth_buffer_float" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__depth__clamp = (build-asdf-system { - pname = "cl-glfw-opengl-arb_depth_clamp"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_depth_clamp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_depth_clamp"; - asd = "cl-glfw-opengl-arb_depth_clamp"; - }); - systems = [ "cl-glfw-opengl-arb_depth_clamp" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__depth__texture = (build-asdf-system { - pname = "cl-glfw-opengl-arb_depth_texture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_depth_texture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_depth_texture"; - asd = "cl-glfw-opengl-arb_depth_texture"; - }); - systems = [ "cl-glfw-opengl-arb_depth_texture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__draw__buffers = (build-asdf-system { - pname = "cl-glfw-opengl-arb_draw_buffers"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_draw_buffers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_draw_buffers"; - asd = "cl-glfw-opengl-arb_draw_buffers"; - }); - systems = [ "cl-glfw-opengl-arb_draw_buffers" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__draw__buffers__blend = (build-asdf-system { - pname = "cl-glfw-opengl-arb_draw_buffers_blend"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_draw_buffers_blend" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_draw_buffers_blend"; - asd = "cl-glfw-opengl-arb_draw_buffers_blend"; - }); - systems = [ "cl-glfw-opengl-arb_draw_buffers_blend" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__draw__elements__base__vertex = (build-asdf-system { - pname = "cl-glfw-opengl-arb_draw_elements_base_vertex"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_draw_elements_base_vertex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_draw_elements_base_vertex"; - asd = "cl-glfw-opengl-arb_draw_elements_base_vertex"; - }); - systems = [ "cl-glfw-opengl-arb_draw_elements_base_vertex" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__draw__indirect = (build-asdf-system { - pname = "cl-glfw-opengl-arb_draw_indirect"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_draw_indirect" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_draw_indirect"; - asd = "cl-glfw-opengl-arb_draw_indirect"; - }); - systems = [ "cl-glfw-opengl-arb_draw_indirect" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__draw__instanced = (build-asdf-system { - pname = "cl-glfw-opengl-arb_draw_instanced"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_draw_instanced" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_draw_instanced"; - asd = "cl-glfw-opengl-arb_draw_instanced"; - }); - systems = [ "cl-glfw-opengl-arb_draw_instanced" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__es2__compatibility = (build-asdf-system { - pname = "cl-glfw-opengl-arb_es2_compatibility"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_es2_compatibility" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_es2_compatibility"; - asd = "cl-glfw-opengl-arb_es2_compatibility"; - }); - systems = [ "cl-glfw-opengl-arb_es2_compatibility" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__fragment__program = (build-asdf-system { - pname = "cl-glfw-opengl-arb_fragment_program"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_fragment_program" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_fragment_program"; - asd = "cl-glfw-opengl-arb_fragment_program"; - }); - systems = [ "cl-glfw-opengl-arb_fragment_program" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__fragment__shader = (build-asdf-system { - pname = "cl-glfw-opengl-arb_fragment_shader"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_fragment_shader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_fragment_shader"; - asd = "cl-glfw-opengl-arb_fragment_shader"; - }); - systems = [ "cl-glfw-opengl-arb_fragment_shader" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__framebuffer__object = (build-asdf-system { - pname = "cl-glfw-opengl-arb_framebuffer_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_framebuffer_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_framebuffer_object"; - asd = "cl-glfw-opengl-arb_framebuffer_object"; - }); - systems = [ "cl-glfw-opengl-arb_framebuffer_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__framebuffer__object__deprecated = (build-asdf-system { - pname = "cl-glfw-opengl-arb_framebuffer_object_deprecated"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_framebuffer_object_deprecated" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_framebuffer_object_deprecated"; - asd = "cl-glfw-opengl-arb_framebuffer_object_deprecated"; - }); - systems = [ "cl-glfw-opengl-arb_framebuffer_object_deprecated" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__framebuffer__srgb = (build-asdf-system { - pname = "cl-glfw-opengl-arb_framebuffer_srgb"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_framebuffer_srgb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_framebuffer_srgb"; - asd = "cl-glfw-opengl-arb_framebuffer_srgb"; - }); - systems = [ "cl-glfw-opengl-arb_framebuffer_srgb" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__geometry__shader4 = (build-asdf-system { - pname = "cl-glfw-opengl-arb_geometry_shader4"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_geometry_shader4" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_geometry_shader4"; - asd = "cl-glfw-opengl-arb_geometry_shader4"; - }); - systems = [ "cl-glfw-opengl-arb_geometry_shader4" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__get__program__binary = (build-asdf-system { - pname = "cl-glfw-opengl-arb_get_program_binary"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_get_program_binary" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_get_program_binary"; - asd = "cl-glfw-opengl-arb_get_program_binary"; - }); - systems = [ "cl-glfw-opengl-arb_get_program_binary" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__gpu__shader5 = (build-asdf-system { - pname = "cl-glfw-opengl-arb_gpu_shader5"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_gpu_shader5" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_gpu_shader5"; - asd = "cl-glfw-opengl-arb_gpu_shader5"; - }); - systems = [ "cl-glfw-opengl-arb_gpu_shader5" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__gpu__shader__fp64 = (build-asdf-system { - pname = "cl-glfw-opengl-arb_gpu_shader_fp64"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_gpu_shader_fp64" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_gpu_shader_fp64"; - asd = "cl-glfw-opengl-arb_gpu_shader_fp64"; - }); - systems = [ "cl-glfw-opengl-arb_gpu_shader_fp64" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__half__float__pixel = (build-asdf-system { - pname = "cl-glfw-opengl-arb_half_float_pixel"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_half_float_pixel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_half_float_pixel"; - asd = "cl-glfw-opengl-arb_half_float_pixel"; - }); - systems = [ "cl-glfw-opengl-arb_half_float_pixel" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__half__float__vertex = (build-asdf-system { - pname = "cl-glfw-opengl-arb_half_float_vertex"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_half_float_vertex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_half_float_vertex"; - asd = "cl-glfw-opengl-arb_half_float_vertex"; - }); - systems = [ "cl-glfw-opengl-arb_half_float_vertex" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__imaging = (build-asdf-system { - pname = "cl-glfw-opengl-arb_imaging"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_imaging" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_imaging"; - asd = "cl-glfw-opengl-arb_imaging"; - }); - systems = [ "cl-glfw-opengl-arb_imaging" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__imaging__deprecated = (build-asdf-system { - pname = "cl-glfw-opengl-arb_imaging_deprecated"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_imaging_deprecated" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_imaging_deprecated"; - asd = "cl-glfw-opengl-arb_imaging_deprecated"; - }); - systems = [ "cl-glfw-opengl-arb_imaging_deprecated" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__instanced__arrays = (build-asdf-system { - pname = "cl-glfw-opengl-arb_instanced_arrays"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_instanced_arrays" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_instanced_arrays"; - asd = "cl-glfw-opengl-arb_instanced_arrays"; - }); - systems = [ "cl-glfw-opengl-arb_instanced_arrays" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__map__buffer__range = (build-asdf-system { - pname = "cl-glfw-opengl-arb_map_buffer_range"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_map_buffer_range" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_map_buffer_range"; - asd = "cl-glfw-opengl-arb_map_buffer_range"; - }); - systems = [ "cl-glfw-opengl-arb_map_buffer_range" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__matrix__palette = (build-asdf-system { - pname = "cl-glfw-opengl-arb_matrix_palette"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_matrix_palette" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_matrix_palette"; - asd = "cl-glfw-opengl-arb_matrix_palette"; - }); - systems = [ "cl-glfw-opengl-arb_matrix_palette" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__multisample = (build-asdf-system { - pname = "cl-glfw-opengl-arb_multisample"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_multisample" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_multisample"; - asd = "cl-glfw-opengl-arb_multisample"; - }); - systems = [ "cl-glfw-opengl-arb_multisample" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__multitexture = (build-asdf-system { - pname = "cl-glfw-opengl-arb_multitexture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_multitexture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_multitexture"; - asd = "cl-glfw-opengl-arb_multitexture"; - }); - systems = [ "cl-glfw-opengl-arb_multitexture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__occlusion__query = (build-asdf-system { - pname = "cl-glfw-opengl-arb_occlusion_query"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_occlusion_query" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_occlusion_query"; - asd = "cl-glfw-opengl-arb_occlusion_query"; - }); - systems = [ "cl-glfw-opengl-arb_occlusion_query" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__occlusion__query2 = (build-asdf-system { - pname = "cl-glfw-opengl-arb_occlusion_query2"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_occlusion_query2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_occlusion_query2"; - asd = "cl-glfw-opengl-arb_occlusion_query2"; - }); - systems = [ "cl-glfw-opengl-arb_occlusion_query2" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__pixel__buffer__object = (build-asdf-system { - pname = "cl-glfw-opengl-arb_pixel_buffer_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_pixel_buffer_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_pixel_buffer_object"; - asd = "cl-glfw-opengl-arb_pixel_buffer_object"; - }); - systems = [ "cl-glfw-opengl-arb_pixel_buffer_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__point__parameters = (build-asdf-system { - pname = "cl-glfw-opengl-arb_point_parameters"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_point_parameters" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_point_parameters"; - asd = "cl-glfw-opengl-arb_point_parameters"; - }); - systems = [ "cl-glfw-opengl-arb_point_parameters" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__point__sprite = (build-asdf-system { - pname = "cl-glfw-opengl-arb_point_sprite"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_point_sprite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_point_sprite"; - asd = "cl-glfw-opengl-arb_point_sprite"; - }); - systems = [ "cl-glfw-opengl-arb_point_sprite" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__provoking__vertex = (build-asdf-system { - pname = "cl-glfw-opengl-arb_provoking_vertex"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_provoking_vertex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_provoking_vertex"; - asd = "cl-glfw-opengl-arb_provoking_vertex"; - }); - systems = [ "cl-glfw-opengl-arb_provoking_vertex" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__robustness = (build-asdf-system { - pname = "cl-glfw-opengl-arb_robustness"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_robustness" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_robustness"; - asd = "cl-glfw-opengl-arb_robustness"; - }); - systems = [ "cl-glfw-opengl-arb_robustness" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__sample__shading = (build-asdf-system { - pname = "cl-glfw-opengl-arb_sample_shading"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_sample_shading" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_sample_shading"; - asd = "cl-glfw-opengl-arb_sample_shading"; - }); - systems = [ "cl-glfw-opengl-arb_sample_shading" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__sampler__objects = (build-asdf-system { - pname = "cl-glfw-opengl-arb_sampler_objects"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_sampler_objects" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_sampler_objects"; - asd = "cl-glfw-opengl-arb_sampler_objects"; - }); - systems = [ "cl-glfw-opengl-arb_sampler_objects" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__seamless__cube__map = (build-asdf-system { - pname = "cl-glfw-opengl-arb_seamless_cube_map"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_seamless_cube_map" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_seamless_cube_map"; - asd = "cl-glfw-opengl-arb_seamless_cube_map"; - }); - systems = [ "cl-glfw-opengl-arb_seamless_cube_map" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__separate__shader__objects = (build-asdf-system { - pname = "cl-glfw-opengl-arb_separate_shader_objects"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_separate_shader_objects" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_separate_shader_objects"; - asd = "cl-glfw-opengl-arb_separate_shader_objects"; - }); - systems = [ "cl-glfw-opengl-arb_separate_shader_objects" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__shader__objects = (build-asdf-system { - pname = "cl-glfw-opengl-arb_shader_objects"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_shader_objects" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_shader_objects"; - asd = "cl-glfw-opengl-arb_shader_objects"; - }); - systems = [ "cl-glfw-opengl-arb_shader_objects" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__shader__subroutine = (build-asdf-system { - pname = "cl-glfw-opengl-arb_shader_subroutine"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_shader_subroutine" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_shader_subroutine"; - asd = "cl-glfw-opengl-arb_shader_subroutine"; - }); - systems = [ "cl-glfw-opengl-arb_shader_subroutine" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__shading__language__100 = (build-asdf-system { - pname = "cl-glfw-opengl-arb_shading_language_100"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_shading_language_100" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_shading_language_100"; - asd = "cl-glfw-opengl-arb_shading_language_100"; - }); - systems = [ "cl-glfw-opengl-arb_shading_language_100" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__shading__language__include = (build-asdf-system { - pname = "cl-glfw-opengl-arb_shading_language_include"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_shading_language_include" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_shading_language_include"; - asd = "cl-glfw-opengl-arb_shading_language_include"; - }); - systems = [ "cl-glfw-opengl-arb_shading_language_include" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__shadow = (build-asdf-system { - pname = "cl-glfw-opengl-arb_shadow"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_shadow" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_shadow"; - asd = "cl-glfw-opengl-arb_shadow"; - }); - systems = [ "cl-glfw-opengl-arb_shadow" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__shadow__ambient = (build-asdf-system { - pname = "cl-glfw-opengl-arb_shadow_ambient"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_shadow_ambient" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_shadow_ambient"; - asd = "cl-glfw-opengl-arb_shadow_ambient"; - }); - systems = [ "cl-glfw-opengl-arb_shadow_ambient" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__tessellation__shader = (build-asdf-system { - pname = "cl-glfw-opengl-arb_tessellation_shader"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_tessellation_shader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_tessellation_shader"; - asd = "cl-glfw-opengl-arb_tessellation_shader"; - }); - systems = [ "cl-glfw-opengl-arb_tessellation_shader" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__border__clamp = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_border_clamp"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_border_clamp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_border_clamp"; - asd = "cl-glfw-opengl-arb_texture_border_clamp"; - }); - systems = [ "cl-glfw-opengl-arb_texture_border_clamp" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__buffer__object = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_buffer_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_buffer_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_buffer_object"; - asd = "cl-glfw-opengl-arb_texture_buffer_object"; - }); - systems = [ "cl-glfw-opengl-arb_texture_buffer_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__buffer__object__rgb32 = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_buffer_object_rgb32"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_buffer_object_rgb32" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_buffer_object_rgb32"; - asd = "cl-glfw-opengl-arb_texture_buffer_object_rgb32"; - }); - systems = [ "cl-glfw-opengl-arb_texture_buffer_object_rgb32" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__compression = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_compression"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_compression" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_compression"; - asd = "cl-glfw-opengl-arb_texture_compression"; - }); - systems = [ "cl-glfw-opengl-arb_texture_compression" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__compression__bptc = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_compression_bptc"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_compression_bptc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_compression_bptc"; - asd = "cl-glfw-opengl-arb_texture_compression_bptc"; - }); - systems = [ "cl-glfw-opengl-arb_texture_compression_bptc" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__compression__rgtc = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_compression_rgtc"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_compression_rgtc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_compression_rgtc"; - asd = "cl-glfw-opengl-arb_texture_compression_rgtc"; - }); - systems = [ "cl-glfw-opengl-arb_texture_compression_rgtc" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__cube__map = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_cube_map"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_cube_map" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_cube_map"; - asd = "cl-glfw-opengl-arb_texture_cube_map"; - }); - systems = [ "cl-glfw-opengl-arb_texture_cube_map" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__cube__map__array = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_cube_map_array"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_cube_map_array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_cube_map_array"; - asd = "cl-glfw-opengl-arb_texture_cube_map_array"; - }); - systems = [ "cl-glfw-opengl-arb_texture_cube_map_array" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__env__combine = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_env_combine"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_env_combine" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_env_combine"; - asd = "cl-glfw-opengl-arb_texture_env_combine"; - }); - systems = [ "cl-glfw-opengl-arb_texture_env_combine" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__env__dot3 = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_env_dot3"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_env_dot3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_env_dot3"; - asd = "cl-glfw-opengl-arb_texture_env_dot3"; - }); - systems = [ "cl-glfw-opengl-arb_texture_env_dot3" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__float = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_float"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_float" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_float"; - asd = "cl-glfw-opengl-arb_texture_float"; - }); - systems = [ "cl-glfw-opengl-arb_texture_float" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__gather = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_gather"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_gather" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_gather"; - asd = "cl-glfw-opengl-arb_texture_gather"; - }); - systems = [ "cl-glfw-opengl-arb_texture_gather" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__mirrored__repeat = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_mirrored_repeat"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_mirrored_repeat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_mirrored_repeat"; - asd = "cl-glfw-opengl-arb_texture_mirrored_repeat"; - }); - systems = [ "cl-glfw-opengl-arb_texture_mirrored_repeat" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__multisample = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_multisample"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_multisample" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_multisample"; - asd = "cl-glfw-opengl-arb_texture_multisample"; - }); - systems = [ "cl-glfw-opengl-arb_texture_multisample" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__rectangle = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_rectangle"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_rectangle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_rectangle"; - asd = "cl-glfw-opengl-arb_texture_rectangle"; - }); - systems = [ "cl-glfw-opengl-arb_texture_rectangle" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__rg = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_rg"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_rg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_rg"; - asd = "cl-glfw-opengl-arb_texture_rg"; - }); - systems = [ "cl-glfw-opengl-arb_texture_rg" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__rgb10__a2ui = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_rgb10_a2ui"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_rgb10_a2ui" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_rgb10_a2ui"; - asd = "cl-glfw-opengl-arb_texture_rgb10_a2ui"; - }); - systems = [ "cl-glfw-opengl-arb_texture_rgb10_a2ui" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__texture__swizzle = (build-asdf-system { - pname = "cl-glfw-opengl-arb_texture_swizzle"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_texture_swizzle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_texture_swizzle"; - asd = "cl-glfw-opengl-arb_texture_swizzle"; - }); - systems = [ "cl-glfw-opengl-arb_texture_swizzle" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__timer__query = (build-asdf-system { - pname = "cl-glfw-opengl-arb_timer_query"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_timer_query" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_timer_query"; - asd = "cl-glfw-opengl-arb_timer_query"; - }); - systems = [ "cl-glfw-opengl-arb_timer_query" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__transform__feedback2 = (build-asdf-system { - pname = "cl-glfw-opengl-arb_transform_feedback2"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_transform_feedback2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_transform_feedback2"; - asd = "cl-glfw-opengl-arb_transform_feedback2"; - }); - systems = [ "cl-glfw-opengl-arb_transform_feedback2" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__transpose__matrix = (build-asdf-system { - pname = "cl-glfw-opengl-arb_transpose_matrix"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_transpose_matrix" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_transpose_matrix"; - asd = "cl-glfw-opengl-arb_transpose_matrix"; - }); - systems = [ "cl-glfw-opengl-arb_transpose_matrix" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__uniform__buffer__object = (build-asdf-system { - pname = "cl-glfw-opengl-arb_uniform_buffer_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_uniform_buffer_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_uniform_buffer_object"; - asd = "cl-glfw-opengl-arb_uniform_buffer_object"; - }); - systems = [ "cl-glfw-opengl-arb_uniform_buffer_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__vertex__array__bgra = (build-asdf-system { - pname = "cl-glfw-opengl-arb_vertex_array_bgra"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_vertex_array_bgra" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_vertex_array_bgra"; - asd = "cl-glfw-opengl-arb_vertex_array_bgra"; - }); - systems = [ "cl-glfw-opengl-arb_vertex_array_bgra" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__vertex__array__object = (build-asdf-system { - pname = "cl-glfw-opengl-arb_vertex_array_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_vertex_array_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_vertex_array_object"; - asd = "cl-glfw-opengl-arb_vertex_array_object"; - }); - systems = [ "cl-glfw-opengl-arb_vertex_array_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__vertex__attrib__64bit = (build-asdf-system { - pname = "cl-glfw-opengl-arb_vertex_attrib_64bit"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_vertex_attrib_64bit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_vertex_attrib_64bit"; - asd = "cl-glfw-opengl-arb_vertex_attrib_64bit"; - }); - systems = [ "cl-glfw-opengl-arb_vertex_attrib_64bit" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__vertex__blend = (build-asdf-system { - pname = "cl-glfw-opengl-arb_vertex_blend"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_vertex_blend" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_vertex_blend"; - asd = "cl-glfw-opengl-arb_vertex_blend"; - }); - systems = [ "cl-glfw-opengl-arb_vertex_blend" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__vertex__buffer__object = (build-asdf-system { - pname = "cl-glfw-opengl-arb_vertex_buffer_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_vertex_buffer_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_vertex_buffer_object"; - asd = "cl-glfw-opengl-arb_vertex_buffer_object"; - }); - systems = [ "cl-glfw-opengl-arb_vertex_buffer_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__vertex__program = (build-asdf-system { - pname = "cl-glfw-opengl-arb_vertex_program"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_vertex_program" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_vertex_program"; - asd = "cl-glfw-opengl-arb_vertex_program"; - }); - systems = [ "cl-glfw-opengl-arb_vertex_program" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__vertex__shader = (build-asdf-system { - pname = "cl-glfw-opengl-arb_vertex_shader"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_vertex_shader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_vertex_shader"; - asd = "cl-glfw-opengl-arb_vertex_shader"; - }); - systems = [ "cl-glfw-opengl-arb_vertex_shader" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__vertex__type__2__10__10__10__rev = (build-asdf-system { - pname = "cl-glfw-opengl-arb_vertex_type_2_10_10_10_rev"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_vertex_type_2_10_10_10_rev" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_vertex_type_2_10_10_10_rev"; - asd = "cl-glfw-opengl-arb_vertex_type_2_10_10_10_rev"; - }); - systems = [ "cl-glfw-opengl-arb_vertex_type_2_10_10_10_rev" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__viewport__array = (build-asdf-system { - pname = "cl-glfw-opengl-arb_viewport_array"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_viewport_array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_viewport_array"; - asd = "cl-glfw-opengl-arb_viewport_array"; - }); - systems = [ "cl-glfw-opengl-arb_viewport_array" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-arb__window__pos = (build-asdf-system { - pname = "cl-glfw-opengl-arb_window_pos"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-arb_window_pos" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-arb_window_pos"; - asd = "cl-glfw-opengl-arb_window_pos"; - }); - systems = [ "cl-glfw-opengl-arb_window_pos" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__draw__buffers = (build-asdf-system { - pname = "cl-glfw-opengl-ati_draw_buffers"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_draw_buffers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_draw_buffers"; - asd = "cl-glfw-opengl-ati_draw_buffers"; - }); - systems = [ "cl-glfw-opengl-ati_draw_buffers" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__element__array = (build-asdf-system { - pname = "cl-glfw-opengl-ati_element_array"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_element_array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_element_array"; - asd = "cl-glfw-opengl-ati_element_array"; - }); - systems = [ "cl-glfw-opengl-ati_element_array" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__envmap__bumpmap = (build-asdf-system { - pname = "cl-glfw-opengl-ati_envmap_bumpmap"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_envmap_bumpmap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_envmap_bumpmap"; - asd = "cl-glfw-opengl-ati_envmap_bumpmap"; - }); - systems = [ "cl-glfw-opengl-ati_envmap_bumpmap" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__fragment__shader = (build-asdf-system { - pname = "cl-glfw-opengl-ati_fragment_shader"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_fragment_shader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_fragment_shader"; - asd = "cl-glfw-opengl-ati_fragment_shader"; - }); - systems = [ "cl-glfw-opengl-ati_fragment_shader" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__map__object__buffer = (build-asdf-system { - pname = "cl-glfw-opengl-ati_map_object_buffer"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_map_object_buffer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_map_object_buffer"; - asd = "cl-glfw-opengl-ati_map_object_buffer"; - }); - systems = [ "cl-glfw-opengl-ati_map_object_buffer" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__meminfo = (build-asdf-system { - pname = "cl-glfw-opengl-ati_meminfo"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_meminfo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_meminfo"; - asd = "cl-glfw-opengl-ati_meminfo"; - }); - systems = [ "cl-glfw-opengl-ati_meminfo" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__pixel__format__float = (build-asdf-system { - pname = "cl-glfw-opengl-ati_pixel_format_float"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_pixel_format_float" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_pixel_format_float"; - asd = "cl-glfw-opengl-ati_pixel_format_float"; - }); - systems = [ "cl-glfw-opengl-ati_pixel_format_float" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__pn__triangles = (build-asdf-system { - pname = "cl-glfw-opengl-ati_pn_triangles"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_pn_triangles" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_pn_triangles"; - asd = "cl-glfw-opengl-ati_pn_triangles"; - }); - systems = [ "cl-glfw-opengl-ati_pn_triangles" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__separate__stencil = (build-asdf-system { - pname = "cl-glfw-opengl-ati_separate_stencil"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_separate_stencil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_separate_stencil"; - asd = "cl-glfw-opengl-ati_separate_stencil"; - }); - systems = [ "cl-glfw-opengl-ati_separate_stencil" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__text__fragment__shader = (build-asdf-system { - pname = "cl-glfw-opengl-ati_text_fragment_shader"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_text_fragment_shader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_text_fragment_shader"; - asd = "cl-glfw-opengl-ati_text_fragment_shader"; - }); - systems = [ "cl-glfw-opengl-ati_text_fragment_shader" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__texture__env__combine3 = (build-asdf-system { - pname = "cl-glfw-opengl-ati_texture_env_combine3"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_texture_env_combine3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_texture_env_combine3"; - asd = "cl-glfw-opengl-ati_texture_env_combine3"; - }); - systems = [ "cl-glfw-opengl-ati_texture_env_combine3" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__texture__float = (build-asdf-system { - pname = "cl-glfw-opengl-ati_texture_float"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_texture_float" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_texture_float"; - asd = "cl-glfw-opengl-ati_texture_float"; - }); - systems = [ "cl-glfw-opengl-ati_texture_float" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__texture__mirror__once = (build-asdf-system { - pname = "cl-glfw-opengl-ati_texture_mirror_once"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_texture_mirror_once" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_texture_mirror_once"; - asd = "cl-glfw-opengl-ati_texture_mirror_once"; - }); - systems = [ "cl-glfw-opengl-ati_texture_mirror_once" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__vertex__array__object = (build-asdf-system { - pname = "cl-glfw-opengl-ati_vertex_array_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_vertex_array_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_vertex_array_object"; - asd = "cl-glfw-opengl-ati_vertex_array_object"; - }); - systems = [ "cl-glfw-opengl-ati_vertex_array_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__vertex__attrib__array__object = (build-asdf-system { - pname = "cl-glfw-opengl-ati_vertex_attrib_array_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_vertex_attrib_array_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_vertex_attrib_array_object"; - asd = "cl-glfw-opengl-ati_vertex_attrib_array_object"; - }); - systems = [ "cl-glfw-opengl-ati_vertex_attrib_array_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ati__vertex__streams = (build-asdf-system { - pname = "cl-glfw-opengl-ati_vertex_streams"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ati_vertex_streams" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ati_vertex_streams"; - asd = "cl-glfw-opengl-ati_vertex_streams"; - }); - systems = [ "cl-glfw-opengl-ati_vertex_streams" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-core = (build-asdf-system { - pname = "cl-glfw-opengl-core"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-core"; - asd = "cl-glfw-opengl-core"; - }); - systems = [ "cl-glfw-opengl-core" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-glfw-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__422__pixels = (build-asdf-system { - pname = "cl-glfw-opengl-ext_422_pixels"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_422_pixels" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_422_pixels"; - asd = "cl-glfw-opengl-ext_422_pixels"; - }); - systems = [ "cl-glfw-opengl-ext_422_pixels" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__abgr = (build-asdf-system { - pname = "cl-glfw-opengl-ext_abgr"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_abgr" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_abgr"; - asd = "cl-glfw-opengl-ext_abgr"; - }); - systems = [ "cl-glfw-opengl-ext_abgr" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__bgra = (build-asdf-system { - pname = "cl-glfw-opengl-ext_bgra"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_bgra" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_bgra"; - asd = "cl-glfw-opengl-ext_bgra"; - }); - systems = [ "cl-glfw-opengl-ext_bgra" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__bindable__uniform = (build-asdf-system { - pname = "cl-glfw-opengl-ext_bindable_uniform"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_bindable_uniform" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_bindable_uniform"; - asd = "cl-glfw-opengl-ext_bindable_uniform"; - }); - systems = [ "cl-glfw-opengl-ext_bindable_uniform" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__blend__color = (build-asdf-system { - pname = "cl-glfw-opengl-ext_blend_color"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_blend_color" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_blend_color"; - asd = "cl-glfw-opengl-ext_blend_color"; - }); - systems = [ "cl-glfw-opengl-ext_blend_color" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__blend__equation__separate = (build-asdf-system { - pname = "cl-glfw-opengl-ext_blend_equation_separate"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_blend_equation_separate" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_blend_equation_separate"; - asd = "cl-glfw-opengl-ext_blend_equation_separate"; - }); - systems = [ "cl-glfw-opengl-ext_blend_equation_separate" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__blend__func__separate = (build-asdf-system { - pname = "cl-glfw-opengl-ext_blend_func_separate"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_blend_func_separate" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_blend_func_separate"; - asd = "cl-glfw-opengl-ext_blend_func_separate"; - }); - systems = [ "cl-glfw-opengl-ext_blend_func_separate" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__blend__minmax = (build-asdf-system { - pname = "cl-glfw-opengl-ext_blend_minmax"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_blend_minmax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_blend_minmax"; - asd = "cl-glfw-opengl-ext_blend_minmax"; - }); - systems = [ "cl-glfw-opengl-ext_blend_minmax" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__blend__subtract = (build-asdf-system { - pname = "cl-glfw-opengl-ext_blend_subtract"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_blend_subtract" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_blend_subtract"; - asd = "cl-glfw-opengl-ext_blend_subtract"; - }); - systems = [ "cl-glfw-opengl-ext_blend_subtract" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__clip__volume__hint = (build-asdf-system { - pname = "cl-glfw-opengl-ext_clip_volume_hint"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_clip_volume_hint" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_clip_volume_hint"; - asd = "cl-glfw-opengl-ext_clip_volume_hint"; - }); - systems = [ "cl-glfw-opengl-ext_clip_volume_hint" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__cmyka = (build-asdf-system { - pname = "cl-glfw-opengl-ext_cmyka"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_cmyka" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_cmyka"; - asd = "cl-glfw-opengl-ext_cmyka"; - }); - systems = [ "cl-glfw-opengl-ext_cmyka" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__color__subtable = (build-asdf-system { - pname = "cl-glfw-opengl-ext_color_subtable"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_color_subtable" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_color_subtable"; - asd = "cl-glfw-opengl-ext_color_subtable"; - }); - systems = [ "cl-glfw-opengl-ext_color_subtable" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__compiled__vertex__array = (build-asdf-system { - pname = "cl-glfw-opengl-ext_compiled_vertex_array"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_compiled_vertex_array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_compiled_vertex_array"; - asd = "cl-glfw-opengl-ext_compiled_vertex_array"; - }); - systems = [ "cl-glfw-opengl-ext_compiled_vertex_array" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__convolution = (build-asdf-system { - pname = "cl-glfw-opengl-ext_convolution"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_convolution" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_convolution"; - asd = "cl-glfw-opengl-ext_convolution"; - }); - systems = [ "cl-glfw-opengl-ext_convolution" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__coordinate__frame = (build-asdf-system { - pname = "cl-glfw-opengl-ext_coordinate_frame"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_coordinate_frame" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_coordinate_frame"; - asd = "cl-glfw-opengl-ext_coordinate_frame"; - }); - systems = [ "cl-glfw-opengl-ext_coordinate_frame" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__copy__texture = (build-asdf-system { - pname = "cl-glfw-opengl-ext_copy_texture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_copy_texture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_copy_texture"; - asd = "cl-glfw-opengl-ext_copy_texture"; - }); - systems = [ "cl-glfw-opengl-ext_copy_texture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__cull__vertex = (build-asdf-system { - pname = "cl-glfw-opengl-ext_cull_vertex"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_cull_vertex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_cull_vertex"; - asd = "cl-glfw-opengl-ext_cull_vertex"; - }); - systems = [ "cl-glfw-opengl-ext_cull_vertex" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__depth__bounds__test = (build-asdf-system { - pname = "cl-glfw-opengl-ext_depth_bounds_test"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_depth_bounds_test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_depth_bounds_test"; - asd = "cl-glfw-opengl-ext_depth_bounds_test"; - }); - systems = [ "cl-glfw-opengl-ext_depth_bounds_test" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__direct__state__access = (build-asdf-system { - pname = "cl-glfw-opengl-ext_direct_state_access"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_direct_state_access" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_direct_state_access"; - asd = "cl-glfw-opengl-ext_direct_state_access"; - }); - systems = [ "cl-glfw-opengl-ext_direct_state_access" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__draw__buffers2 = (build-asdf-system { - pname = "cl-glfw-opengl-ext_draw_buffers2"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_draw_buffers2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_draw_buffers2"; - asd = "cl-glfw-opengl-ext_draw_buffers2"; - }); - systems = [ "cl-glfw-opengl-ext_draw_buffers2" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__draw__instanced = (build-asdf-system { - pname = "cl-glfw-opengl-ext_draw_instanced"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_draw_instanced" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_draw_instanced"; - asd = "cl-glfw-opengl-ext_draw_instanced"; - }); - systems = [ "cl-glfw-opengl-ext_draw_instanced" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__draw__range__elements = (build-asdf-system { - pname = "cl-glfw-opengl-ext_draw_range_elements"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_draw_range_elements" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_draw_range_elements"; - asd = "cl-glfw-opengl-ext_draw_range_elements"; - }); - systems = [ "cl-glfw-opengl-ext_draw_range_elements" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__fog__coord = (build-asdf-system { - pname = "cl-glfw-opengl-ext_fog_coord"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_fog_coord" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_fog_coord"; - asd = "cl-glfw-opengl-ext_fog_coord"; - }); - systems = [ "cl-glfw-opengl-ext_fog_coord" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__framebuffer__blit = (build-asdf-system { - pname = "cl-glfw-opengl-ext_framebuffer_blit"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_framebuffer_blit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_framebuffer_blit"; - asd = "cl-glfw-opengl-ext_framebuffer_blit"; - }); - systems = [ "cl-glfw-opengl-ext_framebuffer_blit" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__framebuffer__multisample = (build-asdf-system { - pname = "cl-glfw-opengl-ext_framebuffer_multisample"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_framebuffer_multisample" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_framebuffer_multisample"; - asd = "cl-glfw-opengl-ext_framebuffer_multisample"; - }); - systems = [ "cl-glfw-opengl-ext_framebuffer_multisample" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__framebuffer__object = (build-asdf-system { - pname = "cl-glfw-opengl-ext_framebuffer_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_framebuffer_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_framebuffer_object"; - asd = "cl-glfw-opengl-ext_framebuffer_object"; - }); - systems = [ "cl-glfw-opengl-ext_framebuffer_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__framebuffer__srgb = (build-asdf-system { - pname = "cl-glfw-opengl-ext_framebuffer_srgb"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_framebuffer_srgb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_framebuffer_srgb"; - asd = "cl-glfw-opengl-ext_framebuffer_srgb"; - }); - systems = [ "cl-glfw-opengl-ext_framebuffer_srgb" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__geometry__shader4 = (build-asdf-system { - pname = "cl-glfw-opengl-ext_geometry_shader4"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_geometry_shader4" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_geometry_shader4"; - asd = "cl-glfw-opengl-ext_geometry_shader4"; - }); - systems = [ "cl-glfw-opengl-ext_geometry_shader4" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__gpu__program__parameters = (build-asdf-system { - pname = "cl-glfw-opengl-ext_gpu_program_parameters"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_gpu_program_parameters" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_gpu_program_parameters"; - asd = "cl-glfw-opengl-ext_gpu_program_parameters"; - }); - systems = [ "cl-glfw-opengl-ext_gpu_program_parameters" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__gpu__shader4 = (build-asdf-system { - pname = "cl-glfw-opengl-ext_gpu_shader4"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_gpu_shader4" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_gpu_shader4"; - asd = "cl-glfw-opengl-ext_gpu_shader4"; - }); - systems = [ "cl-glfw-opengl-ext_gpu_shader4" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__histogram = (build-asdf-system { - pname = "cl-glfw-opengl-ext_histogram"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_histogram" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_histogram"; - asd = "cl-glfw-opengl-ext_histogram"; - }); - systems = [ "cl-glfw-opengl-ext_histogram" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__index__array__formats = (build-asdf-system { - pname = "cl-glfw-opengl-ext_index_array_formats"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_index_array_formats" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_index_array_formats"; - asd = "cl-glfw-opengl-ext_index_array_formats"; - }); - systems = [ "cl-glfw-opengl-ext_index_array_formats" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__index__func = (build-asdf-system { - pname = "cl-glfw-opengl-ext_index_func"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_index_func" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_index_func"; - asd = "cl-glfw-opengl-ext_index_func"; - }); - systems = [ "cl-glfw-opengl-ext_index_func" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__index__material = (build-asdf-system { - pname = "cl-glfw-opengl-ext_index_material"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_index_material" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_index_material"; - asd = "cl-glfw-opengl-ext_index_material"; - }); - systems = [ "cl-glfw-opengl-ext_index_material" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__light__texture = (build-asdf-system { - pname = "cl-glfw-opengl-ext_light_texture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_light_texture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_light_texture"; - asd = "cl-glfw-opengl-ext_light_texture"; - }); - systems = [ "cl-glfw-opengl-ext_light_texture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__multi__draw__arrays = (build-asdf-system { - pname = "cl-glfw-opengl-ext_multi_draw_arrays"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_multi_draw_arrays" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_multi_draw_arrays"; - asd = "cl-glfw-opengl-ext_multi_draw_arrays"; - }); - systems = [ "cl-glfw-opengl-ext_multi_draw_arrays" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__multisample = (build-asdf-system { - pname = "cl-glfw-opengl-ext_multisample"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_multisample" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_multisample"; - asd = "cl-glfw-opengl-ext_multisample"; - }); - systems = [ "cl-glfw-opengl-ext_multisample" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__packed__depth__stencil = (build-asdf-system { - pname = "cl-glfw-opengl-ext_packed_depth_stencil"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_packed_depth_stencil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_packed_depth_stencil"; - asd = "cl-glfw-opengl-ext_packed_depth_stencil"; - }); - systems = [ "cl-glfw-opengl-ext_packed_depth_stencil" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__packed__float = (build-asdf-system { - pname = "cl-glfw-opengl-ext_packed_float"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_packed_float" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_packed_float"; - asd = "cl-glfw-opengl-ext_packed_float"; - }); - systems = [ "cl-glfw-opengl-ext_packed_float" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__packed__pixels = (build-asdf-system { - pname = "cl-glfw-opengl-ext_packed_pixels"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_packed_pixels" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_packed_pixels"; - asd = "cl-glfw-opengl-ext_packed_pixels"; - }); - systems = [ "cl-glfw-opengl-ext_packed_pixels" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__paletted__texture = (build-asdf-system { - pname = "cl-glfw-opengl-ext_paletted_texture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_paletted_texture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_paletted_texture"; - asd = "cl-glfw-opengl-ext_paletted_texture"; - }); - systems = [ "cl-glfw-opengl-ext_paletted_texture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__pixel__buffer__object = (build-asdf-system { - pname = "cl-glfw-opengl-ext_pixel_buffer_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_pixel_buffer_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_pixel_buffer_object"; - asd = "cl-glfw-opengl-ext_pixel_buffer_object"; - }); - systems = [ "cl-glfw-opengl-ext_pixel_buffer_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__pixel__transform = (build-asdf-system { - pname = "cl-glfw-opengl-ext_pixel_transform"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_pixel_transform" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_pixel_transform"; - asd = "cl-glfw-opengl-ext_pixel_transform"; - }); - systems = [ "cl-glfw-opengl-ext_pixel_transform" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__point__parameters = (build-asdf-system { - pname = "cl-glfw-opengl-ext_point_parameters"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_point_parameters" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_point_parameters"; - asd = "cl-glfw-opengl-ext_point_parameters"; - }); - systems = [ "cl-glfw-opengl-ext_point_parameters" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__polygon__offset = (build-asdf-system { - pname = "cl-glfw-opengl-ext_polygon_offset"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_polygon_offset" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_polygon_offset"; - asd = "cl-glfw-opengl-ext_polygon_offset"; - }); - systems = [ "cl-glfw-opengl-ext_polygon_offset" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__provoking__vertex = (build-asdf-system { - pname = "cl-glfw-opengl-ext_provoking_vertex"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_provoking_vertex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_provoking_vertex"; - asd = "cl-glfw-opengl-ext_provoking_vertex"; - }); - systems = [ "cl-glfw-opengl-ext_provoking_vertex" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__secondary__color = (build-asdf-system { - pname = "cl-glfw-opengl-ext_secondary_color"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_secondary_color" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_secondary_color"; - asd = "cl-glfw-opengl-ext_secondary_color"; - }); - systems = [ "cl-glfw-opengl-ext_secondary_color" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__separate__shader__objects = (build-asdf-system { - pname = "cl-glfw-opengl-ext_separate_shader_objects"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_separate_shader_objects" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_separate_shader_objects"; - asd = "cl-glfw-opengl-ext_separate_shader_objects"; - }); - systems = [ "cl-glfw-opengl-ext_separate_shader_objects" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__separate__specular__color = (build-asdf-system { - pname = "cl-glfw-opengl-ext_separate_specular_color"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_separate_specular_color" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_separate_specular_color"; - asd = "cl-glfw-opengl-ext_separate_specular_color"; - }); - systems = [ "cl-glfw-opengl-ext_separate_specular_color" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__shader__image__load__store = (build-asdf-system { - pname = "cl-glfw-opengl-ext_shader_image_load_store"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_shader_image_load_store" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_shader_image_load_store"; - asd = "cl-glfw-opengl-ext_shader_image_load_store"; - }); - systems = [ "cl-glfw-opengl-ext_shader_image_load_store" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__stencil__clear__tag = (build-asdf-system { - pname = "cl-glfw-opengl-ext_stencil_clear_tag"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_stencil_clear_tag" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_stencil_clear_tag"; - asd = "cl-glfw-opengl-ext_stencil_clear_tag"; - }); - systems = [ "cl-glfw-opengl-ext_stencil_clear_tag" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__stencil__two__side = (build-asdf-system { - pname = "cl-glfw-opengl-ext_stencil_two_side"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_stencil_two_side" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_stencil_two_side"; - asd = "cl-glfw-opengl-ext_stencil_two_side"; - }); - systems = [ "cl-glfw-opengl-ext_stencil_two_side" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__stencil__wrap = (build-asdf-system { - pname = "cl-glfw-opengl-ext_stencil_wrap"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_stencil_wrap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_stencil_wrap"; - asd = "cl-glfw-opengl-ext_stencil_wrap"; - }); - systems = [ "cl-glfw-opengl-ext_stencil_wrap" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__subtexture = (build-asdf-system { - pname = "cl-glfw-opengl-ext_subtexture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_subtexture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_subtexture"; - asd = "cl-glfw-opengl-ext_subtexture"; - }); - systems = [ "cl-glfw-opengl-ext_subtexture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture"; - asd = "cl-glfw-opengl-ext_texture"; - }); - systems = [ "cl-glfw-opengl-ext_texture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture3d = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture3d"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture3d" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture3d"; - asd = "cl-glfw-opengl-ext_texture3d"; - }); - systems = [ "cl-glfw-opengl-ext_texture3d" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__array = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_array"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_array"; - asd = "cl-glfw-opengl-ext_texture_array"; - }); - systems = [ "cl-glfw-opengl-ext_texture_array" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__buffer__object = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_buffer_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_buffer_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_buffer_object"; - asd = "cl-glfw-opengl-ext_texture_buffer_object"; - }); - systems = [ "cl-glfw-opengl-ext_texture_buffer_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__compression__latc = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_compression_latc"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_compression_latc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_compression_latc"; - asd = "cl-glfw-opengl-ext_texture_compression_latc"; - }); - systems = [ "cl-glfw-opengl-ext_texture_compression_latc" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__compression__rgtc = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_compression_rgtc"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_compression_rgtc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_compression_rgtc"; - asd = "cl-glfw-opengl-ext_texture_compression_rgtc"; - }); - systems = [ "cl-glfw-opengl-ext_texture_compression_rgtc" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__compression__s3tc = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_compression_s3tc"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_compression_s3tc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_compression_s3tc"; - asd = "cl-glfw-opengl-ext_texture_compression_s3tc"; - }); - systems = [ "cl-glfw-opengl-ext_texture_compression_s3tc" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__cube__map = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_cube_map"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_cube_map" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_cube_map"; - asd = "cl-glfw-opengl-ext_texture_cube_map"; - }); - systems = [ "cl-glfw-opengl-ext_texture_cube_map" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__env__combine = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_env_combine"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_env_combine" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_env_combine"; - asd = "cl-glfw-opengl-ext_texture_env_combine"; - }); - systems = [ "cl-glfw-opengl-ext_texture_env_combine" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__env__dot3 = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_env_dot3"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_env_dot3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_env_dot3"; - asd = "cl-glfw-opengl-ext_texture_env_dot3"; - }); - systems = [ "cl-glfw-opengl-ext_texture_env_dot3" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__filter__anisotropic = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_filter_anisotropic"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_filter_anisotropic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_filter_anisotropic"; - asd = "cl-glfw-opengl-ext_texture_filter_anisotropic"; - }); - systems = [ "cl-glfw-opengl-ext_texture_filter_anisotropic" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__integer = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_integer"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_integer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_integer"; - asd = "cl-glfw-opengl-ext_texture_integer"; - }); - systems = [ "cl-glfw-opengl-ext_texture_integer" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__lod__bias = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_lod_bias"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_lod_bias" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_lod_bias"; - asd = "cl-glfw-opengl-ext_texture_lod_bias"; - }); - systems = [ "cl-glfw-opengl-ext_texture_lod_bias" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__mirror__clamp = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_mirror_clamp"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_mirror_clamp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_mirror_clamp"; - asd = "cl-glfw-opengl-ext_texture_mirror_clamp"; - }); - systems = [ "cl-glfw-opengl-ext_texture_mirror_clamp" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__object = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_object"; - asd = "cl-glfw-opengl-ext_texture_object"; - }); - systems = [ "cl-glfw-opengl-ext_texture_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__perturb__normal = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_perturb_normal"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_perturb_normal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_perturb_normal"; - asd = "cl-glfw-opengl-ext_texture_perturb_normal"; - }); - systems = [ "cl-glfw-opengl-ext_texture_perturb_normal" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__shared__exponent = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_shared_exponent"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_shared_exponent" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_shared_exponent"; - asd = "cl-glfw-opengl-ext_texture_shared_exponent"; - }); - systems = [ "cl-glfw-opengl-ext_texture_shared_exponent" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__snorm = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_snorm"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_snorm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_snorm"; - asd = "cl-glfw-opengl-ext_texture_snorm"; - }); - systems = [ "cl-glfw-opengl-ext_texture_snorm" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__srgb = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_srgb"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_srgb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_srgb"; - asd = "cl-glfw-opengl-ext_texture_srgb"; - }); - systems = [ "cl-glfw-opengl-ext_texture_srgb" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__srgb__decode = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_srgb_decode"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_srgb_decode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_srgb_decode"; - asd = "cl-glfw-opengl-ext_texture_srgb_decode"; - }); - systems = [ "cl-glfw-opengl-ext_texture_srgb_decode" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__texture__swizzle = (build-asdf-system { - pname = "cl-glfw-opengl-ext_texture_swizzle"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_texture_swizzle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_texture_swizzle"; - asd = "cl-glfw-opengl-ext_texture_swizzle"; - }); - systems = [ "cl-glfw-opengl-ext_texture_swizzle" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__timer__query = (build-asdf-system { - pname = "cl-glfw-opengl-ext_timer_query"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_timer_query" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_timer_query"; - asd = "cl-glfw-opengl-ext_timer_query"; - }); - systems = [ "cl-glfw-opengl-ext_timer_query" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__transform__feedback = (build-asdf-system { - pname = "cl-glfw-opengl-ext_transform_feedback"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_transform_feedback" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_transform_feedback"; - asd = "cl-glfw-opengl-ext_transform_feedback"; - }); - systems = [ "cl-glfw-opengl-ext_transform_feedback" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__vertex__array = (build-asdf-system { - pname = "cl-glfw-opengl-ext_vertex_array"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_vertex_array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_vertex_array"; - asd = "cl-glfw-opengl-ext_vertex_array"; - }); - systems = [ "cl-glfw-opengl-ext_vertex_array" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__vertex__array__bgra = (build-asdf-system { - pname = "cl-glfw-opengl-ext_vertex_array_bgra"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_vertex_array_bgra" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_vertex_array_bgra"; - asd = "cl-glfw-opengl-ext_vertex_array_bgra"; - }); - systems = [ "cl-glfw-opengl-ext_vertex_array_bgra" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__vertex__attrib__64bit = (build-asdf-system { - pname = "cl-glfw-opengl-ext_vertex_attrib_64bit"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_vertex_attrib_64bit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_vertex_attrib_64bit"; - asd = "cl-glfw-opengl-ext_vertex_attrib_64bit"; - }); - systems = [ "cl-glfw-opengl-ext_vertex_attrib_64bit" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__vertex__shader = (build-asdf-system { - pname = "cl-glfw-opengl-ext_vertex_shader"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_vertex_shader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_vertex_shader"; - asd = "cl-glfw-opengl-ext_vertex_shader"; - }); - systems = [ "cl-glfw-opengl-ext_vertex_shader" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ext__vertex__weighting = (build-asdf-system { - pname = "cl-glfw-opengl-ext_vertex_weighting"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ext_vertex_weighting" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ext_vertex_weighting"; - asd = "cl-glfw-opengl-ext_vertex_weighting"; - }); - systems = [ "cl-glfw-opengl-ext_vertex_weighting" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-gremedy__frame__terminator = (build-asdf-system { - pname = "cl-glfw-opengl-gremedy_frame_terminator"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-gremedy_frame_terminator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-gremedy_frame_terminator"; - asd = "cl-glfw-opengl-gremedy_frame_terminator"; - }); - systems = [ "cl-glfw-opengl-gremedy_frame_terminator" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-gremedy__string__marker = (build-asdf-system { - pname = "cl-glfw-opengl-gremedy_string_marker"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-gremedy_string_marker" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-gremedy_string_marker"; - asd = "cl-glfw-opengl-gremedy_string_marker"; - }); - systems = [ "cl-glfw-opengl-gremedy_string_marker" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-hp__convolution__border__modes = (build-asdf-system { - pname = "cl-glfw-opengl-hp_convolution_border_modes"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-hp_convolution_border_modes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-hp_convolution_border_modes"; - asd = "cl-glfw-opengl-hp_convolution_border_modes"; - }); - systems = [ "cl-glfw-opengl-hp_convolution_border_modes" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-hp__image__transform = (build-asdf-system { - pname = "cl-glfw-opengl-hp_image_transform"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-hp_image_transform" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-hp_image_transform"; - asd = "cl-glfw-opengl-hp_image_transform"; - }); - systems = [ "cl-glfw-opengl-hp_image_transform" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-hp__occlusion__test = (build-asdf-system { - pname = "cl-glfw-opengl-hp_occlusion_test"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-hp_occlusion_test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-hp_occlusion_test"; - asd = "cl-glfw-opengl-hp_occlusion_test"; - }); - systems = [ "cl-glfw-opengl-hp_occlusion_test" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-hp__texture__lighting = (build-asdf-system { - pname = "cl-glfw-opengl-hp_texture_lighting"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-hp_texture_lighting" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-hp_texture_lighting"; - asd = "cl-glfw-opengl-hp_texture_lighting"; - }); - systems = [ "cl-glfw-opengl-hp_texture_lighting" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ibm__cull__vertex = (build-asdf-system { - pname = "cl-glfw-opengl-ibm_cull_vertex"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ibm_cull_vertex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ibm_cull_vertex"; - asd = "cl-glfw-opengl-ibm_cull_vertex"; - }); - systems = [ "cl-glfw-opengl-ibm_cull_vertex" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ibm__multimode__draw__arrays = (build-asdf-system { - pname = "cl-glfw-opengl-ibm_multimode_draw_arrays"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ibm_multimode_draw_arrays" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ibm_multimode_draw_arrays"; - asd = "cl-glfw-opengl-ibm_multimode_draw_arrays"; - }); - systems = [ "cl-glfw-opengl-ibm_multimode_draw_arrays" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ibm__rasterpos__clip = (build-asdf-system { - pname = "cl-glfw-opengl-ibm_rasterpos_clip"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ibm_rasterpos_clip" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ibm_rasterpos_clip"; - asd = "cl-glfw-opengl-ibm_rasterpos_clip"; - }); - systems = [ "cl-glfw-opengl-ibm_rasterpos_clip" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ibm__texture__mirrored__repeat = (build-asdf-system { - pname = "cl-glfw-opengl-ibm_texture_mirrored_repeat"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ibm_texture_mirrored_repeat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ibm_texture_mirrored_repeat"; - asd = "cl-glfw-opengl-ibm_texture_mirrored_repeat"; - }); - systems = [ "cl-glfw-opengl-ibm_texture_mirrored_repeat" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ibm__vertex__array__lists = (build-asdf-system { - pname = "cl-glfw-opengl-ibm_vertex_array_lists"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ibm_vertex_array_lists" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ibm_vertex_array_lists"; - asd = "cl-glfw-opengl-ibm_vertex_array_lists"; - }); - systems = [ "cl-glfw-opengl-ibm_vertex_array_lists" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ingr__blend__func__separate = (build-asdf-system { - pname = "cl-glfw-opengl-ingr_blend_func_separate"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ingr_blend_func_separate" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ingr_blend_func_separate"; - asd = "cl-glfw-opengl-ingr_blend_func_separate"; - }); - systems = [ "cl-glfw-opengl-ingr_blend_func_separate" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ingr__color__clamp = (build-asdf-system { - pname = "cl-glfw-opengl-ingr_color_clamp"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ingr_color_clamp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ingr_color_clamp"; - asd = "cl-glfw-opengl-ingr_color_clamp"; - }); - systems = [ "cl-glfw-opengl-ingr_color_clamp" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-ingr__interlace__read = (build-asdf-system { - pname = "cl-glfw-opengl-ingr_interlace_read"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-ingr_interlace_read" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-ingr_interlace_read"; - asd = "cl-glfw-opengl-ingr_interlace_read"; - }); - systems = [ "cl-glfw-opengl-ingr_interlace_read" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-intel__parallel__arrays = (build-asdf-system { - pname = "cl-glfw-opengl-intel_parallel_arrays"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-intel_parallel_arrays" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-intel_parallel_arrays"; - asd = "cl-glfw-opengl-intel_parallel_arrays"; - }); - systems = [ "cl-glfw-opengl-intel_parallel_arrays" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-mesa__pack__invert = (build-asdf-system { - pname = "cl-glfw-opengl-mesa_pack_invert"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-mesa_pack_invert" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-mesa_pack_invert"; - asd = "cl-glfw-opengl-mesa_pack_invert"; - }); - systems = [ "cl-glfw-opengl-mesa_pack_invert" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-mesa__packed__depth__stencil = (build-asdf-system { - pname = "cl-glfw-opengl-mesa_packed_depth_stencil"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-mesa_packed_depth_stencil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-mesa_packed_depth_stencil"; - asd = "cl-glfw-opengl-mesa_packed_depth_stencil"; - }); - systems = [ "cl-glfw-opengl-mesa_packed_depth_stencil" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-mesa__program__debug = (build-asdf-system { - pname = "cl-glfw-opengl-mesa_program_debug"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-mesa_program_debug" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-mesa_program_debug"; - asd = "cl-glfw-opengl-mesa_program_debug"; - }); - systems = [ "cl-glfw-opengl-mesa_program_debug" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-mesa__resize__buffers = (build-asdf-system { - pname = "cl-glfw-opengl-mesa_resize_buffers"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-mesa_resize_buffers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-mesa_resize_buffers"; - asd = "cl-glfw-opengl-mesa_resize_buffers"; - }); - systems = [ "cl-glfw-opengl-mesa_resize_buffers" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-mesa__shader__debug = (build-asdf-system { - pname = "cl-glfw-opengl-mesa_shader_debug"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-mesa_shader_debug" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-mesa_shader_debug"; - asd = "cl-glfw-opengl-mesa_shader_debug"; - }); - systems = [ "cl-glfw-opengl-mesa_shader_debug" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-mesa__trace = (build-asdf-system { - pname = "cl-glfw-opengl-mesa_trace"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-mesa_trace" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-mesa_trace"; - asd = "cl-glfw-opengl-mesa_trace"; - }); - systems = [ "cl-glfw-opengl-mesa_trace" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-mesa__window__pos = (build-asdf-system { - pname = "cl-glfw-opengl-mesa_window_pos"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-mesa_window_pos" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-mesa_window_pos"; - asd = "cl-glfw-opengl-mesa_window_pos"; - }); - systems = [ "cl-glfw-opengl-mesa_window_pos" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-mesa__ycbcr__texture = (build-asdf-system { - pname = "cl-glfw-opengl-mesa_ycbcr_texture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-mesa_ycbcr_texture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-mesa_ycbcr_texture"; - asd = "cl-glfw-opengl-mesa_ycbcr_texture"; - }); - systems = [ "cl-glfw-opengl-mesa_ycbcr_texture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-mesax__texture__stack = (build-asdf-system { - pname = "cl-glfw-opengl-mesax_texture_stack"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-mesax_texture_stack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-mesax_texture_stack"; - asd = "cl-glfw-opengl-mesax_texture_stack"; - }); - systems = [ "cl-glfw-opengl-mesax_texture_stack" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__conditional__render = (build-asdf-system { - pname = "cl-glfw-opengl-nv_conditional_render"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_conditional_render" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_conditional_render"; - asd = "cl-glfw-opengl-nv_conditional_render"; - }); - systems = [ "cl-glfw-opengl-nv_conditional_render" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__copy__depth__to__color = (build-asdf-system { - pname = "cl-glfw-opengl-nv_copy_depth_to_color"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_copy_depth_to_color" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_copy_depth_to_color"; - asd = "cl-glfw-opengl-nv_copy_depth_to_color"; - }); - systems = [ "cl-glfw-opengl-nv_copy_depth_to_color" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__copy__image = (build-asdf-system { - pname = "cl-glfw-opengl-nv_copy_image"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_copy_image" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_copy_image"; - asd = "cl-glfw-opengl-nv_copy_image"; - }); - systems = [ "cl-glfw-opengl-nv_copy_image" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__depth__buffer__float = (build-asdf-system { - pname = "cl-glfw-opengl-nv_depth_buffer_float"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_depth_buffer_float" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_depth_buffer_float"; - asd = "cl-glfw-opengl-nv_depth_buffer_float"; - }); - systems = [ "cl-glfw-opengl-nv_depth_buffer_float" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__depth__clamp = (build-asdf-system { - pname = "cl-glfw-opengl-nv_depth_clamp"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_depth_clamp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_depth_clamp"; - asd = "cl-glfw-opengl-nv_depth_clamp"; - }); - systems = [ "cl-glfw-opengl-nv_depth_clamp" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__evaluators = (build-asdf-system { - pname = "cl-glfw-opengl-nv_evaluators"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_evaluators" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_evaluators"; - asd = "cl-glfw-opengl-nv_evaluators"; - }); - systems = [ "cl-glfw-opengl-nv_evaluators" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__explicit__multisample = (build-asdf-system { - pname = "cl-glfw-opengl-nv_explicit_multisample"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_explicit_multisample" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_explicit_multisample"; - asd = "cl-glfw-opengl-nv_explicit_multisample"; - }); - systems = [ "cl-glfw-opengl-nv_explicit_multisample" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__fence = (build-asdf-system { - pname = "cl-glfw-opengl-nv_fence"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_fence" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_fence"; - asd = "cl-glfw-opengl-nv_fence"; - }); - systems = [ "cl-glfw-opengl-nv_fence" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__float__buffer = (build-asdf-system { - pname = "cl-glfw-opengl-nv_float_buffer"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_float_buffer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_float_buffer"; - asd = "cl-glfw-opengl-nv_float_buffer"; - }); - systems = [ "cl-glfw-opengl-nv_float_buffer" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__fog__distance = (build-asdf-system { - pname = "cl-glfw-opengl-nv_fog_distance"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_fog_distance" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_fog_distance"; - asd = "cl-glfw-opengl-nv_fog_distance"; - }); - systems = [ "cl-glfw-opengl-nv_fog_distance" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__fragment__program = (build-asdf-system { - pname = "cl-glfw-opengl-nv_fragment_program"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_fragment_program" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_fragment_program"; - asd = "cl-glfw-opengl-nv_fragment_program"; - }); - systems = [ "cl-glfw-opengl-nv_fragment_program" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__fragment__program2 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_fragment_program2"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_fragment_program2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_fragment_program2"; - asd = "cl-glfw-opengl-nv_fragment_program2"; - }); - systems = [ "cl-glfw-opengl-nv_fragment_program2" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__framebuffer__multisample__coverage = (build-asdf-system { - pname = "cl-glfw-opengl-nv_framebuffer_multisample_coverage"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_framebuffer_multisample_coverage" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_framebuffer_multisample_coverage"; - asd = "cl-glfw-opengl-nv_framebuffer_multisample_coverage"; - }); - systems = [ "cl-glfw-opengl-nv_framebuffer_multisample_coverage" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__geometry__program4 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_geometry_program4"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_geometry_program4" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_geometry_program4"; - asd = "cl-glfw-opengl-nv_geometry_program4"; - }); - systems = [ "cl-glfw-opengl-nv_geometry_program4" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__gpu__program4 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_gpu_program4"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_gpu_program4" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_gpu_program4"; - asd = "cl-glfw-opengl-nv_gpu_program4"; - }); - systems = [ "cl-glfw-opengl-nv_gpu_program4" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__gpu__program5 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_gpu_program5"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_gpu_program5" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_gpu_program5"; - asd = "cl-glfw-opengl-nv_gpu_program5"; - }); - systems = [ "cl-glfw-opengl-nv_gpu_program5" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__gpu__shader5 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_gpu_shader5"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_gpu_shader5" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_gpu_shader5"; - asd = "cl-glfw-opengl-nv_gpu_shader5"; - }); - systems = [ "cl-glfw-opengl-nv_gpu_shader5" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__half__float = (build-asdf-system { - pname = "cl-glfw-opengl-nv_half_float"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_half_float" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_half_float"; - asd = "cl-glfw-opengl-nv_half_float"; - }); - systems = [ "cl-glfw-opengl-nv_half_float" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__light__max__exponent = (build-asdf-system { - pname = "cl-glfw-opengl-nv_light_max_exponent"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_light_max_exponent" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_light_max_exponent"; - asd = "cl-glfw-opengl-nv_light_max_exponent"; - }); - systems = [ "cl-glfw-opengl-nv_light_max_exponent" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__multisample__coverage = (build-asdf-system { - pname = "cl-glfw-opengl-nv_multisample_coverage"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_multisample_coverage" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_multisample_coverage"; - asd = "cl-glfw-opengl-nv_multisample_coverage"; - }); - systems = [ "cl-glfw-opengl-nv_multisample_coverage" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__multisample__filter__hint = (build-asdf-system { - pname = "cl-glfw-opengl-nv_multisample_filter_hint"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_multisample_filter_hint" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_multisample_filter_hint"; - asd = "cl-glfw-opengl-nv_multisample_filter_hint"; - }); - systems = [ "cl-glfw-opengl-nv_multisample_filter_hint" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__occlusion__query = (build-asdf-system { - pname = "cl-glfw-opengl-nv_occlusion_query"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_occlusion_query" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_occlusion_query"; - asd = "cl-glfw-opengl-nv_occlusion_query"; - }); - systems = [ "cl-glfw-opengl-nv_occlusion_query" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__packed__depth__stencil = (build-asdf-system { - pname = "cl-glfw-opengl-nv_packed_depth_stencil"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_packed_depth_stencil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_packed_depth_stencil"; - asd = "cl-glfw-opengl-nv_packed_depth_stencil"; - }); - systems = [ "cl-glfw-opengl-nv_packed_depth_stencil" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__parameter__buffer__object = (build-asdf-system { - pname = "cl-glfw-opengl-nv_parameter_buffer_object"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_parameter_buffer_object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_parameter_buffer_object"; - asd = "cl-glfw-opengl-nv_parameter_buffer_object"; - }); - systems = [ "cl-glfw-opengl-nv_parameter_buffer_object" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__pixel__data__range = (build-asdf-system { - pname = "cl-glfw-opengl-nv_pixel_data_range"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_pixel_data_range" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_pixel_data_range"; - asd = "cl-glfw-opengl-nv_pixel_data_range"; - }); - systems = [ "cl-glfw-opengl-nv_pixel_data_range" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__point__sprite = (build-asdf-system { - pname = "cl-glfw-opengl-nv_point_sprite"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_point_sprite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_point_sprite"; - asd = "cl-glfw-opengl-nv_point_sprite"; - }); - systems = [ "cl-glfw-opengl-nv_point_sprite" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__present__video = (build-asdf-system { - pname = "cl-glfw-opengl-nv_present_video"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_present_video" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_present_video"; - asd = "cl-glfw-opengl-nv_present_video"; - }); - systems = [ "cl-glfw-opengl-nv_present_video" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__primitive__restart = (build-asdf-system { - pname = "cl-glfw-opengl-nv_primitive_restart"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_primitive_restart" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_primitive_restart"; - asd = "cl-glfw-opengl-nv_primitive_restart"; - }); - systems = [ "cl-glfw-opengl-nv_primitive_restart" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__register__combiners = (build-asdf-system { - pname = "cl-glfw-opengl-nv_register_combiners"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_register_combiners" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_register_combiners"; - asd = "cl-glfw-opengl-nv_register_combiners"; - }); - systems = [ "cl-glfw-opengl-nv_register_combiners" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__register__combiners2 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_register_combiners2"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_register_combiners2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_register_combiners2"; - asd = "cl-glfw-opengl-nv_register_combiners2"; - }); - systems = [ "cl-glfw-opengl-nv_register_combiners2" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__shader__buffer__load = (build-asdf-system { - pname = "cl-glfw-opengl-nv_shader_buffer_load"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_shader_buffer_load" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_shader_buffer_load"; - asd = "cl-glfw-opengl-nv_shader_buffer_load"; - }); - systems = [ "cl-glfw-opengl-nv_shader_buffer_load" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__shader__buffer__store = (build-asdf-system { - pname = "cl-glfw-opengl-nv_shader_buffer_store"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_shader_buffer_store" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_shader_buffer_store"; - asd = "cl-glfw-opengl-nv_shader_buffer_store"; - }); - systems = [ "cl-glfw-opengl-nv_shader_buffer_store" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__tessellation__program5 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_tessellation_program5"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_tessellation_program5" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_tessellation_program5"; - asd = "cl-glfw-opengl-nv_tessellation_program5"; - }); - systems = [ "cl-glfw-opengl-nv_tessellation_program5" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__texgen__emboss = (build-asdf-system { - pname = "cl-glfw-opengl-nv_texgen_emboss"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_texgen_emboss" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_texgen_emboss"; - asd = "cl-glfw-opengl-nv_texgen_emboss"; - }); - systems = [ "cl-glfw-opengl-nv_texgen_emboss" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__texgen__reflection = (build-asdf-system { - pname = "cl-glfw-opengl-nv_texgen_reflection"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_texgen_reflection" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_texgen_reflection"; - asd = "cl-glfw-opengl-nv_texgen_reflection"; - }); - systems = [ "cl-glfw-opengl-nv_texgen_reflection" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__texture__barrier = (build-asdf-system { - pname = "cl-glfw-opengl-nv_texture_barrier"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_texture_barrier" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_texture_barrier"; - asd = "cl-glfw-opengl-nv_texture_barrier"; - }); - systems = [ "cl-glfw-opengl-nv_texture_barrier" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__texture__env__combine4 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_texture_env_combine4"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_texture_env_combine4" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_texture_env_combine4"; - asd = "cl-glfw-opengl-nv_texture_env_combine4"; - }); - systems = [ "cl-glfw-opengl-nv_texture_env_combine4" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__texture__expand__normal = (build-asdf-system { - pname = "cl-glfw-opengl-nv_texture_expand_normal"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_texture_expand_normal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_texture_expand_normal"; - asd = "cl-glfw-opengl-nv_texture_expand_normal"; - }); - systems = [ "cl-glfw-opengl-nv_texture_expand_normal" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__texture__multisample = (build-asdf-system { - pname = "cl-glfw-opengl-nv_texture_multisample"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_texture_multisample" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_texture_multisample"; - asd = "cl-glfw-opengl-nv_texture_multisample"; - }); - systems = [ "cl-glfw-opengl-nv_texture_multisample" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__texture__rectangle = (build-asdf-system { - pname = "cl-glfw-opengl-nv_texture_rectangle"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_texture_rectangle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_texture_rectangle"; - asd = "cl-glfw-opengl-nv_texture_rectangle"; - }); - systems = [ "cl-glfw-opengl-nv_texture_rectangle" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__texture__shader = (build-asdf-system { - pname = "cl-glfw-opengl-nv_texture_shader"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_texture_shader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_texture_shader"; - asd = "cl-glfw-opengl-nv_texture_shader"; - }); - systems = [ "cl-glfw-opengl-nv_texture_shader" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__texture__shader2 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_texture_shader2"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_texture_shader2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_texture_shader2"; - asd = "cl-glfw-opengl-nv_texture_shader2"; - }); - systems = [ "cl-glfw-opengl-nv_texture_shader2" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__texture__shader3 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_texture_shader3"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_texture_shader3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_texture_shader3"; - asd = "cl-glfw-opengl-nv_texture_shader3"; - }); - systems = [ "cl-glfw-opengl-nv_texture_shader3" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__transform__feedback = (build-asdf-system { - pname = "cl-glfw-opengl-nv_transform_feedback"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_transform_feedback" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_transform_feedback"; - asd = "cl-glfw-opengl-nv_transform_feedback"; - }); - systems = [ "cl-glfw-opengl-nv_transform_feedback" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__transform__feedback2 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_transform_feedback2"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_transform_feedback2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_transform_feedback2"; - asd = "cl-glfw-opengl-nv_transform_feedback2"; - }); - systems = [ "cl-glfw-opengl-nv_transform_feedback2" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__vertex__array__range = (build-asdf-system { - pname = "cl-glfw-opengl-nv_vertex_array_range"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_vertex_array_range" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_vertex_array_range"; - asd = "cl-glfw-opengl-nv_vertex_array_range"; - }); - systems = [ "cl-glfw-opengl-nv_vertex_array_range" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__vertex__array__range2 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_vertex_array_range2"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_vertex_array_range2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_vertex_array_range2"; - asd = "cl-glfw-opengl-nv_vertex_array_range2"; - }); - systems = [ "cl-glfw-opengl-nv_vertex_array_range2" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__vertex__attrib__integer__64bit = (build-asdf-system { - pname = "cl-glfw-opengl-nv_vertex_attrib_integer_64bit"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_vertex_attrib_integer_64bit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_vertex_attrib_integer_64bit"; - asd = "cl-glfw-opengl-nv_vertex_attrib_integer_64bit"; - }); - systems = [ "cl-glfw-opengl-nv_vertex_attrib_integer_64bit" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__vertex__buffer__unified__memory = (build-asdf-system { - pname = "cl-glfw-opengl-nv_vertex_buffer_unified_memory"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_vertex_buffer_unified_memory" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_vertex_buffer_unified_memory"; - asd = "cl-glfw-opengl-nv_vertex_buffer_unified_memory"; - }); - systems = [ "cl-glfw-opengl-nv_vertex_buffer_unified_memory" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__vertex__program = (build-asdf-system { - pname = "cl-glfw-opengl-nv_vertex_program"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_vertex_program" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_vertex_program"; - asd = "cl-glfw-opengl-nv_vertex_program"; - }); - systems = [ "cl-glfw-opengl-nv_vertex_program" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__vertex__program2__option = (build-asdf-system { - pname = "cl-glfw-opengl-nv_vertex_program2_option"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_vertex_program2_option" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_vertex_program2_option"; - asd = "cl-glfw-opengl-nv_vertex_program2_option"; - }); - systems = [ "cl-glfw-opengl-nv_vertex_program2_option" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__vertex__program3 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_vertex_program3"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_vertex_program3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_vertex_program3"; - asd = "cl-glfw-opengl-nv_vertex_program3"; - }); - systems = [ "cl-glfw-opengl-nv_vertex_program3" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-nv__vertex__program4 = (build-asdf-system { - pname = "cl-glfw-opengl-nv_vertex_program4"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-nv_vertex_program4" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-nv_vertex_program4"; - asd = "cl-glfw-opengl-nv_vertex_program4"; - }); - systems = [ "cl-glfw-opengl-nv_vertex_program4" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-oes__read__format = (build-asdf-system { - pname = "cl-glfw-opengl-oes_read_format"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-oes_read_format" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-oes_read_format"; - asd = "cl-glfw-opengl-oes_read_format"; - }); - systems = [ "cl-glfw-opengl-oes_read_format" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-oml__interlace = (build-asdf-system { - pname = "cl-glfw-opengl-oml_interlace"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-oml_interlace" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-oml_interlace"; - asd = "cl-glfw-opengl-oml_interlace"; - }); - systems = [ "cl-glfw-opengl-oml_interlace" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-oml__resample = (build-asdf-system { - pname = "cl-glfw-opengl-oml_resample"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-oml_resample" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-oml_resample"; - asd = "cl-glfw-opengl-oml_resample"; - }); - systems = [ "cl-glfw-opengl-oml_resample" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-oml__subsample = (build-asdf-system { - pname = "cl-glfw-opengl-oml_subsample"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-oml_subsample" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-oml_subsample"; - asd = "cl-glfw-opengl-oml_subsample"; - }); - systems = [ "cl-glfw-opengl-oml_subsample" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-pgi__misc__hints = (build-asdf-system { - pname = "cl-glfw-opengl-pgi_misc_hints"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-pgi_misc_hints" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-pgi_misc_hints"; - asd = "cl-glfw-opengl-pgi_misc_hints"; - }); - systems = [ "cl-glfw-opengl-pgi_misc_hints" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-pgi__vertex__hints = (build-asdf-system { - pname = "cl-glfw-opengl-pgi_vertex_hints"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-pgi_vertex_hints" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-pgi_vertex_hints"; - asd = "cl-glfw-opengl-pgi_vertex_hints"; - }); - systems = [ "cl-glfw-opengl-pgi_vertex_hints" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-rend__screen__coordinates = (build-asdf-system { - pname = "cl-glfw-opengl-rend_screen_coordinates"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-rend_screen_coordinates" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-rend_screen_coordinates"; - asd = "cl-glfw-opengl-rend_screen_coordinates"; - }); - systems = [ "cl-glfw-opengl-rend_screen_coordinates" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-s3__s3tc = (build-asdf-system { - pname = "cl-glfw-opengl-s3_s3tc"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-s3_s3tc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-s3_s3tc"; - asd = "cl-glfw-opengl-s3_s3tc"; - }); - systems = [ "cl-glfw-opengl-s3_s3tc" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgi__color__table = (build-asdf-system { - pname = "cl-glfw-opengl-sgi_color_table"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgi_color_table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgi_color_table"; - asd = "cl-glfw-opengl-sgi_color_table"; - }); - systems = [ "cl-glfw-opengl-sgi_color_table" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgi__depth__pass__instrument = (build-asdf-system { - pname = "cl-glfw-opengl-sgi_depth_pass_instrument"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgi_depth_pass_instrument" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgi_depth_pass_instrument"; - asd = "cl-glfw-opengl-sgi_depth_pass_instrument"; - }); - systems = [ "cl-glfw-opengl-sgi_depth_pass_instrument" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgis__detail__texture = (build-asdf-system { - pname = "cl-glfw-opengl-sgis_detail_texture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgis_detail_texture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgis_detail_texture"; - asd = "cl-glfw-opengl-sgis_detail_texture"; - }); - systems = [ "cl-glfw-opengl-sgis_detail_texture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgis__fog__function = (build-asdf-system { - pname = "cl-glfw-opengl-sgis_fog_function"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgis_fog_function" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgis_fog_function"; - asd = "cl-glfw-opengl-sgis_fog_function"; - }); - systems = [ "cl-glfw-opengl-sgis_fog_function" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgis__multisample = (build-asdf-system { - pname = "cl-glfw-opengl-sgis_multisample"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgis_multisample" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgis_multisample"; - asd = "cl-glfw-opengl-sgis_multisample"; - }); - systems = [ "cl-glfw-opengl-sgis_multisample" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgis__pixel__texture = (build-asdf-system { - pname = "cl-glfw-opengl-sgis_pixel_texture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgis_pixel_texture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgis_pixel_texture"; - asd = "cl-glfw-opengl-sgis_pixel_texture"; - }); - systems = [ "cl-glfw-opengl-sgis_pixel_texture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgis__point__parameters = (build-asdf-system { - pname = "cl-glfw-opengl-sgis_point_parameters"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgis_point_parameters" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgis_point_parameters"; - asd = "cl-glfw-opengl-sgis_point_parameters"; - }); - systems = [ "cl-glfw-opengl-sgis_point_parameters" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgis__sharpen__texture = (build-asdf-system { - pname = "cl-glfw-opengl-sgis_sharpen_texture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgis_sharpen_texture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgis_sharpen_texture"; - asd = "cl-glfw-opengl-sgis_sharpen_texture"; - }); - systems = [ "cl-glfw-opengl-sgis_sharpen_texture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgis__texture4d = (build-asdf-system { - pname = "cl-glfw-opengl-sgis_texture4d"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgis_texture4d" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgis_texture4d"; - asd = "cl-glfw-opengl-sgis_texture4d"; - }); - systems = [ "cl-glfw-opengl-sgis_texture4d" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgis__texture__color__mask = (build-asdf-system { - pname = "cl-glfw-opengl-sgis_texture_color_mask"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgis_texture_color_mask" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgis_texture_color_mask"; - asd = "cl-glfw-opengl-sgis_texture_color_mask"; - }); - systems = [ "cl-glfw-opengl-sgis_texture_color_mask" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgis__texture__filter4 = (build-asdf-system { - pname = "cl-glfw-opengl-sgis_texture_filter4"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgis_texture_filter4" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgis_texture_filter4"; - asd = "cl-glfw-opengl-sgis_texture_filter4"; - }); - systems = [ "cl-glfw-opengl-sgis_texture_filter4" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgis__texture__select = (build-asdf-system { - pname = "cl-glfw-opengl-sgis_texture_select"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgis_texture_select" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgis_texture_select"; - asd = "cl-glfw-opengl-sgis_texture_select"; - }); - systems = [ "cl-glfw-opengl-sgis_texture_select" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__async = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_async"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_async" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_async"; - asd = "cl-glfw-opengl-sgix_async"; - }); - systems = [ "cl-glfw-opengl-sgix_async" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__depth__texture = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_depth_texture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_depth_texture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_depth_texture"; - asd = "cl-glfw-opengl-sgix_depth_texture"; - }); - systems = [ "cl-glfw-opengl-sgix_depth_texture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__flush__raster = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_flush_raster"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_flush_raster" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_flush_raster"; - asd = "cl-glfw-opengl-sgix_flush_raster"; - }); - systems = [ "cl-glfw-opengl-sgix_flush_raster" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__fog__scale = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_fog_scale"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_fog_scale" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_fog_scale"; - asd = "cl-glfw-opengl-sgix_fog_scale"; - }); - systems = [ "cl-glfw-opengl-sgix_fog_scale" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__fragment__lighting = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_fragment_lighting"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_fragment_lighting" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_fragment_lighting"; - asd = "cl-glfw-opengl-sgix_fragment_lighting"; - }); - systems = [ "cl-glfw-opengl-sgix_fragment_lighting" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__framezoom = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_framezoom"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_framezoom" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_framezoom"; - asd = "cl-glfw-opengl-sgix_framezoom"; - }); - systems = [ "cl-glfw-opengl-sgix_framezoom" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__igloo__interface = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_igloo_interface"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_igloo_interface" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_igloo_interface"; - asd = "cl-glfw-opengl-sgix_igloo_interface"; - }); - systems = [ "cl-glfw-opengl-sgix_igloo_interface" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__instruments = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_instruments"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_instruments" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_instruments"; - asd = "cl-glfw-opengl-sgix_instruments"; - }); - systems = [ "cl-glfw-opengl-sgix_instruments" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__line__quality__hint = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_line_quality_hint"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_line_quality_hint" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_line_quality_hint"; - asd = "cl-glfw-opengl-sgix_line_quality_hint"; - }); - systems = [ "cl-glfw-opengl-sgix_line_quality_hint" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__list__priority = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_list_priority"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_list_priority" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_list_priority"; - asd = "cl-glfw-opengl-sgix_list_priority"; - }); - systems = [ "cl-glfw-opengl-sgix_list_priority" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__pixel__texture = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_pixel_texture"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_pixel_texture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_pixel_texture"; - asd = "cl-glfw-opengl-sgix_pixel_texture"; - }); - systems = [ "cl-glfw-opengl-sgix_pixel_texture" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__polynomial__ffd = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_polynomial_ffd"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_polynomial_ffd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_polynomial_ffd"; - asd = "cl-glfw-opengl-sgix_polynomial_ffd"; - }); - systems = [ "cl-glfw-opengl-sgix_polynomial_ffd" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__reference__plane = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_reference_plane"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_reference_plane" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_reference_plane"; - asd = "cl-glfw-opengl-sgix_reference_plane"; - }); - systems = [ "cl-glfw-opengl-sgix_reference_plane" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__resample = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_resample"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_resample" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_resample"; - asd = "cl-glfw-opengl-sgix_resample"; - }); - systems = [ "cl-glfw-opengl-sgix_resample" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__scalebias__hint = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_scalebias_hint"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_scalebias_hint" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_scalebias_hint"; - asd = "cl-glfw-opengl-sgix_scalebias_hint"; - }); - systems = [ "cl-glfw-opengl-sgix_scalebias_hint" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__shadow = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_shadow"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_shadow" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_shadow"; - asd = "cl-glfw-opengl-sgix_shadow"; - }); - systems = [ "cl-glfw-opengl-sgix_shadow" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__shadow__ambient = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_shadow_ambient"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_shadow_ambient" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_shadow_ambient"; - asd = "cl-glfw-opengl-sgix_shadow_ambient"; - }); - systems = [ "cl-glfw-opengl-sgix_shadow_ambient" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__slim = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_slim"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_slim" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_slim"; - asd = "cl-glfw-opengl-sgix_slim"; - }); - systems = [ "cl-glfw-opengl-sgix_slim" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__sprite = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_sprite"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_sprite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_sprite"; - asd = "cl-glfw-opengl-sgix_sprite"; - }); - systems = [ "cl-glfw-opengl-sgix_sprite" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__tag__sample__buffer = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_tag_sample_buffer"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_tag_sample_buffer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_tag_sample_buffer"; - asd = "cl-glfw-opengl-sgix_tag_sample_buffer"; - }); - systems = [ "cl-glfw-opengl-sgix_tag_sample_buffer" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__texture__coordinate__clamp = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_texture_coordinate_clamp"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_texture_coordinate_clamp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_texture_coordinate_clamp"; - asd = "cl-glfw-opengl-sgix_texture_coordinate_clamp"; - }); - systems = [ "cl-glfw-opengl-sgix_texture_coordinate_clamp" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__texture__lod__bias = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_texture_lod_bias"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_texture_lod_bias" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_texture_lod_bias"; - asd = "cl-glfw-opengl-sgix_texture_lod_bias"; - }); - systems = [ "cl-glfw-opengl-sgix_texture_lod_bias" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__texture__multi__buffer = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_texture_multi_buffer"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_texture_multi_buffer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_texture_multi_buffer"; - asd = "cl-glfw-opengl-sgix_texture_multi_buffer"; - }); - systems = [ "cl-glfw-opengl-sgix_texture_multi_buffer" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sgix__ycrcba = (build-asdf-system { - pname = "cl-glfw-opengl-sgix_ycrcba"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sgix_ycrcba" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sgix_ycrcba"; - asd = "cl-glfw-opengl-sgix_ycrcba"; - }); - systems = [ "cl-glfw-opengl-sgix_ycrcba" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sun__convolution__border__modes = (build-asdf-system { - pname = "cl-glfw-opengl-sun_convolution_border_modes"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sun_convolution_border_modes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sun_convolution_border_modes"; - asd = "cl-glfw-opengl-sun_convolution_border_modes"; - }); - systems = [ "cl-glfw-opengl-sun_convolution_border_modes" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sun__global__alpha = (build-asdf-system { - pname = "cl-glfw-opengl-sun_global_alpha"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sun_global_alpha" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sun_global_alpha"; - asd = "cl-glfw-opengl-sun_global_alpha"; - }); - systems = [ "cl-glfw-opengl-sun_global_alpha" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sun__mesh__array = (build-asdf-system { - pname = "cl-glfw-opengl-sun_mesh_array"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sun_mesh_array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sun_mesh_array"; - asd = "cl-glfw-opengl-sun_mesh_array"; - }); - systems = [ "cl-glfw-opengl-sun_mesh_array" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sun__slice__accum = (build-asdf-system { - pname = "cl-glfw-opengl-sun_slice_accum"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sun_slice_accum" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sun_slice_accum"; - asd = "cl-glfw-opengl-sun_slice_accum"; - }); - systems = [ "cl-glfw-opengl-sun_slice_accum" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sun__triangle__list = (build-asdf-system { - pname = "cl-glfw-opengl-sun_triangle_list"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sun_triangle_list" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sun_triangle_list"; - asd = "cl-glfw-opengl-sun_triangle_list"; - }); - systems = [ "cl-glfw-opengl-sun_triangle_list" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sun__vertex = (build-asdf-system { - pname = "cl-glfw-opengl-sun_vertex"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sun_vertex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sun_vertex"; - asd = "cl-glfw-opengl-sun_vertex"; - }); - systems = [ "cl-glfw-opengl-sun_vertex" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-sunx__constant__data = (build-asdf-system { - pname = "cl-glfw-opengl-sunx_constant_data"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-sunx_constant_data" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-sunx_constant_data"; - asd = "cl-glfw-opengl-sunx_constant_data"; - }); - systems = [ "cl-glfw-opengl-sunx_constant_data" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-version__1__0 = (build-asdf-system { - pname = "cl-glfw-opengl-version_1_0"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-version_1_0" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-version_1_0"; - asd = "cl-glfw-opengl-version_1_0"; - }); - systems = [ "cl-glfw-opengl-version_1_0" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-version__1__1 = (build-asdf-system { - pname = "cl-glfw-opengl-version_1_1"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-version_1_1" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-version_1_1"; - asd = "cl-glfw-opengl-version_1_1"; - }); - systems = [ "cl-glfw-opengl-version_1_1" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-version__1__2 = (build-asdf-system { - pname = "cl-glfw-opengl-version_1_2"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-version_1_2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-version_1_2"; - asd = "cl-glfw-opengl-version_1_2"; - }); - systems = [ "cl-glfw-opengl-version_1_2" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-version__1__3 = (build-asdf-system { - pname = "cl-glfw-opengl-version_1_3"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-version_1_3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-version_1_3"; - asd = "cl-glfw-opengl-version_1_3"; - }); - systems = [ "cl-glfw-opengl-version_1_3" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-version__1__4 = (build-asdf-system { - pname = "cl-glfw-opengl-version_1_4"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-version_1_4" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-version_1_4"; - asd = "cl-glfw-opengl-version_1_4"; - }); - systems = [ "cl-glfw-opengl-version_1_4" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-version__1__5 = (build-asdf-system { - pname = "cl-glfw-opengl-version_1_5"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-version_1_5" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-version_1_5"; - asd = "cl-glfw-opengl-version_1_5"; - }); - systems = [ "cl-glfw-opengl-version_1_5" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-version__2__0 = (build-asdf-system { - pname = "cl-glfw-opengl-version_2_0"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-version_2_0" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-version_2_0"; - asd = "cl-glfw-opengl-version_2_0"; - }); - systems = [ "cl-glfw-opengl-version_2_0" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-version__2__1 = (build-asdf-system { - pname = "cl-glfw-opengl-version_2_1"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-version_2_1" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-version_2_1"; - asd = "cl-glfw-opengl-version_2_1"; - }); - systems = [ "cl-glfw-opengl-version_2_1" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-win__phong__shading = (build-asdf-system { - pname = "cl-glfw-opengl-win_phong_shading"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-win_phong_shading" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-win_phong_shading"; - asd = "cl-glfw-opengl-win_phong_shading"; - }); - systems = [ "cl-glfw-opengl-win_phong_shading" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-opengl-win__specular__fog = (build-asdf-system { - pname = "cl-glfw-opengl-win_specular_fog"; - version = "20150302-git"; - asds = [ "cl-glfw-opengl-win_specular_fog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-opengl-win_specular_fog"; - asd = "cl-glfw-opengl-win_specular_fog"; - }); - systems = [ "cl-glfw-opengl-win_specular_fog" ]; - lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw-types = (build-asdf-system { - pname = "cl-glfw-types"; - version = "20150302-git"; - asds = [ "cl-glfw-types" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; - sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; - system = "cl-glfw-types"; - asd = "cl-glfw-types"; - }); - systems = [ "cl-glfw-types" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw3 = (build-asdf-system { - pname = "cl-glfw3"; - version = "20210531-git"; - asds = [ "cl-glfw3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw3/2021-05-31/cl-glfw3-20210531-git.tgz"; - sha256 = "1wzr43nckdx4rlgxzhm1r4kfc264q969mc43y0js9ramh7l8gba5"; - system = "cl-glfw3"; - asd = "cl-glfw3"; - }); - systems = [ "cl-glfw3" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glfw3-examples = (build-asdf-system { - pname = "cl-glfw3-examples"; - version = "20210531-git"; - asds = [ "cl-glfw3-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glfw3/2021-05-31/cl-glfw3-20210531-git.tgz"; - sha256 = "1wzr43nckdx4rlgxzhm1r4kfc264q969mc43y0js9ramh7l8gba5"; - system = "cl-glfw3-examples"; - asd = "cl-glfw3-examples"; - }); - systems = [ "cl-glfw3-examples" ]; - lispLibs = [ (getAttr "cl-glfw3" self) (getAttr "cl-opengl" self) (getAttr "trivial-main-thread" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glib = (build-asdf-system { - pname = "cl-glib"; - version = "20231021-git"; - asds = [ "cl-glib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glib/2023-10-21/cl-glib-20231021-git.tgz"; - sha256 = "07y8hpvdl490p8j4k8y47raqqwnpym9scz7jlg2f1jx897dkssjb"; - system = "cl-glib"; - asd = "cl-glib"; - }); - systems = [ "cl-glib" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-gobject-introspection-wrapper" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gltf = (build-asdf-system { - pname = "cl-gltf"; - version = "20241012-git"; - asds = [ "cl-gltf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gltf/2024-10-12/cl-gltf-20241012-git.tgz"; - sha256 = "0s7q6zsy85wryy3wb2hn3nprh1m4vmjzsai1mdcqlhzqyh5rm6jq"; - system = "cl-gltf"; - asd = "cl-gltf"; - }); - systems = [ "cl-gltf" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "com_dot_inuoe_dot_jzon" self) (getAttr "documentation-utils" self) (getAttr "mmap" self) (getAttr "nibbles" self) (getAttr "qbase64" self) (getAttr "static-vectors" self) (getAttr "trivial-extensible-sequences" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glu = (build-asdf-system { - pname = "cl-glu"; - version = "20241012-git"; - asds = [ "cl-glu" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opengl/2024-10-12/cl-opengl-20241012-git.tgz"; - sha256 = "1xpa3x9fx7wxrs5xmkj13yzh2wjfnlb0ihirfr9clngpv1y4gcm6"; - system = "cl-glu"; - asd = "cl-glu"; - }); - systems = [ "cl-glu" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-opengl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glut = (build-asdf-system { - pname = "cl-glut"; - version = "20241012-git"; - asds = [ "cl-glut" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opengl/2024-10-12/cl-opengl-20241012-git.tgz"; - sha256 = "1xpa3x9fx7wxrs5xmkj13yzh2wjfnlb0ihirfr9clngpv1y4gcm6"; - system = "cl-glut"; - asd = "cl-glut"; - }); - systems = [ "cl-glut" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-opengl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-glut-examples = (build-asdf-system { - pname = "cl-glut-examples"; - version = "20241012-git"; - asds = [ "cl-glut-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opengl/2024-10-12/cl-opengl-20241012-git.tgz"; - sha256 = "1xpa3x9fx7wxrs5xmkj13yzh2wjfnlb0ihirfr9clngpv1y4gcm6"; - system = "cl-glut-examples"; - asd = "cl-glut-examples"; - }); - systems = [ "cl-glut-examples" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-glu" self) (getAttr "cl-glut" self) (getAttr "cl-opengl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gobject = (build-asdf-system { - pname = "cl-gobject"; - version = "20231021-git"; - asds = [ "cl-gobject" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-glib/2023-10-21/cl-glib-20231021-git.tgz"; - sha256 = "07y8hpvdl490p8j4k8y47raqqwnpym9scz7jlg2f1jx897dkssjb"; - system = "cl-gobject"; - asd = "cl-gobject"; - }); - systems = [ "cl-gobject" ]; - lispLibs = [ (getAttr "cl-gobject-introspection-wrapper" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gobject-introspection = (build-asdf-system { - pname = "cl-gobject-introspection"; - version = "20241012-git"; - asds = [ "cl-gobject-introspection" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gobject-introspection/2024-10-12/cl-gobject-introspection-20241012-git.tgz"; - sha256 = "0iw8fciydh9bi2svq30hi029df16arpspk0mjzh0cm1c6kjm9dcj"; - system = "cl-gobject-introspection"; - asd = "cl-gobject-introspection"; - }); - systems = [ "cl-gobject-introspection" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "iterate" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - cl-gobject-introspection-test = (build-asdf-system { - pname = "cl-gobject-introspection-test"; - version = "20241012-git"; - asds = [ "cl-gobject-introspection-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gobject-introspection/2024-10-12/cl-gobject-introspection-20241012-git.tgz"; - sha256 = "0iw8fciydh9bi2svq30hi029df16arpspk0mjzh0cm1c6kjm9dcj"; - system = "cl-gobject-introspection-test"; - asd = "cl-gobject-introspection-test"; - }); - systems = [ "cl-gobject-introspection-test" ]; - lispLibs = [ (getAttr "cl-gobject-introspection" self) (getAttr "fiveam" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gobject-introspection-wrapper = (build-asdf-system { - pname = "cl-gobject-introspection-wrapper"; - version = "20231021-git"; - asds = [ "cl-gobject-introspection-wrapper" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gobject-introspection-wrapper/2023-10-21/cl-gobject-introspection-wrapper-20231021-git.tgz"; - sha256 = "0x1nryxkv6i0bzn2zmlsgbq0impni4drzawy3wc7zy5nr2qnd1x5"; - system = "cl-gobject-introspection-wrapper"; - asd = "cl-gobject-introspection-wrapper"; - }); - systems = [ "cl-gobject-introspection-wrapper" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-gobject-introspection" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gog-galaxy = (build-asdf-system { - pname = "cl-gog-galaxy"; - version = "20241012-git"; - asds = [ "cl-gog-galaxy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gog-galaxy/2024-10-12/cl-gog-galaxy-20241012-git.tgz"; - sha256 = "0pb8q4q1gj4n8ll5cglip4rl9gqy8y0g9kpqn2xkc3lssvxkkh63"; - system = "cl-gog-galaxy"; - asd = "cl-gog-galaxy"; - }); - systems = [ "cl-gog-galaxy" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) (getAttr "trivial-indent" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gopher = (build-asdf-system { - pname = "cl-gopher"; - version = "20231021-git"; - asds = [ "cl-gopher" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gopher/2023-10-21/cl-gopher-20231021-git.tgz"; - sha256 = "0x8rj4icrx04rfh9qlh7hp2c0zyk4ii6s4wqwhqjxh5580mwblgb"; - system = "cl-gopher"; - asd = "cl-gopher"; - }); - systems = [ "cl-gopher" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "drakma" self) (getAttr "flexi-streams" self) (getAttr "quri" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gpio = (build-asdf-system { - pname = "cl-gpio"; - version = "20231021-git"; - asds = [ "cl-gpio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gpio/2023-10-21/cl-gpio-20231021-git.tgz"; - sha256 = "0sh40fg9gcz72xsfi17zh1b1wckw4fsyx75kkm2w3757lx69wkmh"; - system = "cl-gpio"; - asd = "cl-gpio"; - }); - systems = [ "cl-gpio" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-graph = (build-asdf-system { - pname = "cl-graph"; - version = "20241012-git"; - asds = [ "cl-graph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-graph/2024-10-12/cl-graph-20241012-git.tgz"; - sha256 = "1adwlkj2qp73irsswfi50ayjvz3di8fh1sqavsdl7l2d6k7yipdg"; - system = "cl-graph"; - asd = "cl-graph"; - }); - systems = [ "cl-graph" ]; - lispLibs = [ (getAttr "asdf-system-connections" self) (getAttr "cl-containers" self) (getAttr "metabang-bind" self) (getAttr "metatilities-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-graph_plus_hu_dot_dwim_dot_graphviz = (build-asdf-system { - pname = "cl-graph+hu.dwim.graphviz"; - version = "20241012-git"; - asds = [ "cl-graph+hu.dwim.graphviz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-graph/2024-10-12/cl-graph-20241012-git.tgz"; - sha256 = "1adwlkj2qp73irsswfi50ayjvz3di8fh1sqavsdl7l2d6k7yipdg"; - system = "cl-graph+hu.dwim.graphviz"; - asd = "cl-graph+hu.dwim.graphviz"; - }); - systems = [ "cl-graph+hu.dwim.graphviz" ]; - lispLibs = [ (getAttr "cl-graph" self) (getAttr "hu_dot_dwim_dot_graphviz" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-grip = (build-asdf-system { - pname = "cl-grip"; - version = "20241012-git"; - asds = [ "cl-grip" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-grip/2024-10-12/cl-grip-20241012-git.tgz"; - sha256 = "0k9qg6pdj4xs5rshf78jmiasyqj4sy5r5hhrccskfsajw6wfmbc9"; - system = "cl-grip"; - asd = "cl-grip"; - }); - systems = [ "cl-grip" ]; - lispLibs = [ (getAttr "cl-strings" self) (getAttr "local-time" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-grnm = (build-asdf-system { - pname = "cl-grnm"; - version = "20180131-git"; - asds = [ "cl-grnm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-grnm/2018-01-31/cl-grnm-20180131-git.tgz"; - sha256 = "1hb5n37n3x2ylrghcqsia2g9a6f5wg24l659jiz4ncpi5bsv4m3s"; - system = "cl-grnm"; - asd = "cl-grnm"; - }); - systems = [ "cl-grnm" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-growl = (build-asdf-system { - pname = "cl-growl"; - version = "20161208-git"; - asds = [ "cl-growl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-growl/2016-12-08/cl-growl-20161208-git.tgz"; - sha256 = "1qgj3sq22dznwxj1b3rw0099fsf6wgfbc63r376pab74kdnji3n6"; - system = "cl-growl"; - asd = "cl-growl"; - }); - systems = [ "cl-growl" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "ironclad" self) (getAttr "trivial-utf-8" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gss = (build-asdf-system { - pname = "cl-gss"; - version = "20180228-git"; - asds = [ "cl-gss" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gss/2018-02-28/cl-gss-20180228-git.tgz"; - sha256 = "0zhxxn3zarird255s9i56bz0fm6dkv00mn8bbsjrhskg3wpcg4pb"; - system = "cl-gss"; - asd = "cl-gss"; - }); - systems = [ "cl-gss" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "trivial-garbage" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-gtk2-gdk = (build-asdf-system { - pname = "cl-gtk2-gdk"; - version = "20211020-git"; - asds = [ "cl-gtk2-gdk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gtk2/2021-10-20/cl-gtk2-20211020-git.tgz"; - sha256 = "1lnrwd7s47cmksllim56mcg9l5m6jrwv6f0q1hq5lr8xpi5ix9vx"; - system = "cl-gtk2-gdk"; - asd = "cl-gtk2-gdk"; - }); - systems = [ "cl-gtk2-gdk" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-gtk2-glib" self) (getAttr "cl-gtk2-pango" self) ]; - meta = {}; - }); - cl-gtk2-glib = (build-asdf-system { - pname = "cl-gtk2-glib"; - version = "20211020-git"; - asds = [ "cl-gtk2-glib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gtk2/2021-10-20/cl-gtk2-20211020-git.tgz"; - sha256 = "1lnrwd7s47cmksllim56mcg9l5m6jrwv6f0q1hq5lr8xpi5ix9vx"; - system = "cl-gtk2-glib"; - asd = "cl-gtk2-glib"; - }); - systems = [ "cl-gtk2-glib" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "closer-mop" self) (getAttr "iterate" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - cl-gtk2-pango = (build-asdf-system { - pname = "cl-gtk2-pango"; - version = "20211020-git"; - asds = [ "cl-gtk2-pango" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gtk2/2021-10-20/cl-gtk2-20211020-git.tgz"; - sha256 = "1lnrwd7s47cmksllim56mcg9l5m6jrwv6f0q1hq5lr8xpi5ix9vx"; - system = "cl-gtk2-pango"; - asd = "cl-gtk2-pango"; - }); - systems = [ "cl-gtk2-pango" ]; - lispLibs = [ (getAttr "cl-gtk2-glib" self) (getAttr "iterate" self) ]; - meta = {}; - }); - cl-haml = (build-asdf-system { - pname = "cl-haml"; - version = "20180228-git"; - asds = [ "cl-haml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-haml/2018-02-28/cl-haml-20180228-git.tgz"; - sha256 = "017qr3509ha2680h3c8ip5rqyfaz7v9hfjmx0pg1wrjqw8vyjyb5"; - system = "cl-haml"; - asd = "cl-haml"; - }); - systems = [ "cl-haml" ]; - lispLibs = [ (getAttr "cl-who" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-haml-test = (build-asdf-system { - pname = "cl-haml-test"; - version = "20180228-git"; - asds = [ "cl-haml-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-haml/2018-02-28/cl-haml-20180228-git.tgz"; - sha256 = "017qr3509ha2680h3c8ip5rqyfaz7v9hfjmx0pg1wrjqw8vyjyb5"; - system = "cl-haml-test"; - asd = "cl-haml"; - }); - systems = [ "cl-haml-test" ]; - lispLibs = [ (getAttr "cl-haml" self) (getAttr "cl-test-more" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-hamt = (build-asdf-system { - pname = "cl-hamt"; - version = "20200325-git"; - asds = [ "cl-hamt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-hamt/2020-03-25/cl-hamt-20200325-git.tgz"; - sha256 = "1ycbd73ykfj5j9sdhlzamyv18qbjj6xqf7fhm4fa0nsyr6sr3rf5"; - system = "cl-hamt"; - asd = "cl-hamt"; - }); - systems = [ "cl-hamt" ]; - lispLibs = [ (getAttr "cl-murmurhash" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-hamt-examples = (build-asdf-system { - pname = "cl-hamt-examples"; - version = "20200325-git"; - asds = [ "cl-hamt-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-hamt/2020-03-25/cl-hamt-20200325-git.tgz"; - sha256 = "1ycbd73ykfj5j9sdhlzamyv18qbjj6xqf7fhm4fa0nsyr6sr3rf5"; - system = "cl-hamt-examples"; - asd = "cl-hamt-examples"; - }); - systems = [ "cl-hamt-examples" ]; - lispLibs = [ (getAttr "cl-hamt" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-hamt-test = (build-asdf-system { - pname = "cl-hamt-test"; - version = "20200325-git"; - asds = [ "cl-hamt-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-hamt/2020-03-25/cl-hamt-20200325-git.tgz"; - sha256 = "1ycbd73ykfj5j9sdhlzamyv18qbjj6xqf7fhm4fa0nsyr6sr3rf5"; - system = "cl-hamt-test"; - asd = "cl-hamt-test"; - }); - systems = [ "cl-hamt-test" ]; - lispLibs = [ (getAttr "cl-hamt" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-hash-table-destructuring = (build-asdf-system { - pname = "cl-hash-table-destructuring"; - version = "20160531-git"; - asds = [ "cl-hash-table-destructuring" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-hash-table-destructuring/2016-05-31/cl-hash-table-destructuring-20160531-git.tgz"; - sha256 = "0za8jlqfvsilmnidk429509vbdd18w7ykcycni411pjpz0lxrh1v"; - system = "cl-hash-table-destructuring"; - asd = "cl-hash-table-destructuring"; - }); - systems = [ "cl-hash-table-destructuring" ]; - lispLibs = [ (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-hash-table-destructuring-test = (build-asdf-system { - pname = "cl-hash-table-destructuring-test"; - version = "20160531-git"; - asds = [ "cl-hash-table-destructuring-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-hash-table-destructuring/2016-05-31/cl-hash-table-destructuring-20160531-git.tgz"; - sha256 = "0za8jlqfvsilmnidk429509vbdd18w7ykcycni411pjpz0lxrh1v"; - system = "cl-hash-table-destructuring-test"; - asd = "cl-hash-table-destructuring"; - }); - systems = [ "cl-hash-table-destructuring-test" ]; - lispLibs = [ (getAttr "cl-hash-table-destructuring" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-hash-util = (build-asdf-system { - pname = "cl-hash-util"; - version = "20241012-git"; - asds = [ "cl-hash-util" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-hash-util/2024-10-12/cl-hash-util-20241012-git.tgz"; - sha256 = "1xab7v2mav241rs8w68qmg485g4f75nrac3hjcnm0cb19ickbs1m"; - system = "cl-hash-util"; - asd = "cl-hash-util"; - }); - systems = [ "cl-hash-util" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-hash-util-test = (build-asdf-system { - pname = "cl-hash-util-test"; - version = "20241012-git"; - asds = [ "cl-hash-util-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-hash-util/2024-10-12/cl-hash-util-20241012-git.tgz"; - sha256 = "1xab7v2mav241rs8w68qmg485g4f75nrac3hjcnm0cb19ickbs1m"; - system = "cl-hash-util-test"; - asd = "cl-hash-util-test"; - }); - systems = [ "cl-hash-util-test" ]; - lispLibs = [ (getAttr "cl-hash-util" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-heap = (build-asdf-system { - pname = "cl-heap"; - version = "0.1.6"; - asds = [ "cl-heap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-heap/2013-03-12/cl-heap-0.1.6.tgz"; - sha256 = "01bss182x9i167lfv0lr8ylavk2m42s84vz6629kspgjhczm52w7"; - system = "cl-heap"; - asd = "cl-heap"; - }); - systems = [ "cl-heap" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-heap-tests = (build-asdf-system { - pname = "cl-heap-tests"; - version = "0.1.6"; - asds = [ "cl-heap-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-heap/2013-03-12/cl-heap-0.1.6.tgz"; - sha256 = "01bss182x9i167lfv0lr8ylavk2m42s84vz6629kspgjhczm52w7"; - system = "cl-heap-tests"; - asd = "cl-heap-tests"; - }); - systems = [ "cl-heap-tests" ]; - lispLibs = [ (getAttr "cl-heap" self) (getAttr "xlunit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-heredoc = (build-asdf-system { - pname = "cl-heredoc"; - version = "20220707-git"; - asds = [ "cl-heredoc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-heredoc/2022-07-07/cl-heredoc-20220707-git.tgz"; - sha256 = "0hj9y6drd93nwcbmwwhnc30flm48ppw4rhfgfyqfc02fq2wnc83z"; - system = "cl-heredoc"; - asd = "cl-heredoc"; - }); - systems = [ "cl-heredoc" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-heredoc-test = (build-asdf-system { - pname = "cl-heredoc-test"; - version = "20220707-git"; - asds = [ "cl-heredoc-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-heredoc/2022-07-07/cl-heredoc-20220707-git.tgz"; - sha256 = "0hj9y6drd93nwcbmwwhnc30flm48ppw4rhfgfyqfc02fq2wnc83z"; - system = "cl-heredoc-test"; - asd = "cl-heredoc-test"; - }); - systems = [ "cl-heredoc-test" ]; - lispLibs = [ (getAttr "cl-heredoc" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-hooks = (build-asdf-system { - pname = "cl-hooks"; - version = "20181210-git"; - asds = [ "cl-hooks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/architecture.hooks/2018-12-10/architecture.hooks-20181210-git.tgz"; - sha256 = "0bg3l0a28lw5gqqjp6p6b5nhwqk46sgkb7184w5qbfngw1hk8x9y"; - system = "cl-hooks"; - asd = "cl-hooks"; - }); - systems = [ "cl-hooks" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "let-plus" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - cl-html-diff = (build-asdf-system { - pname = "cl-html-diff"; - version = "20130128-git"; - asds = [ "cl-html-diff" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-html-diff/2013-01-28/cl-html-diff-20130128-git.tgz"; - sha256 = "1varnijivzd4jpimn1cz8p5ks713zzha5cgl4vmb0xr8ahravwzb"; - system = "cl-html-diff"; - asd = "cl-html-diff"; - }); - systems = [ "cl-html-diff" ]; - lispLibs = [ (getAttr "cl-difflib" self) ]; - meta = {}; - }); - cl-html-parse = (build-asdf-system { - pname = "cl-html-parse"; - version = "20231021-git"; - asds = [ "cl-html-parse" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-html-parse/2023-10-21/cl-html-parse-20231021-git.tgz"; - sha256 = "1qgjaq45lvqrsw4rrnyy4d5bwlmb7vd45ibdzgbxx5az02x3ahmy"; - system = "cl-html-parse"; - asd = "cl-html-parse"; - }); - systems = [ "cl-html-parse" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-html-readme = (build-asdf-system { - pname = "cl-html-readme"; - version = "quicklisp-current-release-f8aed591-git"; - asds = [ "cl-html-readme" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-html-readme/2024-10-12/cl-html-readme-quicklisp-current-release-f8aed591-git.tgz"; - sha256 = "1q23fdbhmra7hl12vd70m7q350wych6f739l8xmz6f84dwm9i8c7"; - system = "cl-html-readme"; - asd = "cl-html-readme"; - }); - systems = [ "cl-html-readme" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-html5-parser = (build-asdf-system { - pname = "cl-html5-parser"; - version = "20190521-git"; - asds = [ "cl-html5-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-html5-parser/2019-05-21/cl-html5-parser-20190521-git.tgz"; - sha256 = "04if61wigylsmn996rbfl8ylsd0d9hzdmg7p2wiglncibjzcl5k9"; - system = "cl-html5-parser"; - asd = "cl-html5-parser"; - }); - systems = [ "cl-html5-parser" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "string-case" self) ]; - meta = {}; - }); - cl-html5-parser-cxml = (build-asdf-system { - pname = "cl-html5-parser-cxml"; - version = "20190521-git"; - asds = [ "cl-html5-parser-cxml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-html5-parser/2019-05-21/cl-html5-parser-20190521-git.tgz"; - sha256 = "04if61wigylsmn996rbfl8ylsd0d9hzdmg7p2wiglncibjzcl5k9"; - system = "cl-html5-parser-cxml"; - asd = "cl-html5-parser-cxml"; - }); - systems = [ "cl-html5-parser-cxml" ]; - lispLibs = [ (getAttr "cl-html5-parser" self) (getAttr "cxml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-html5-parser-tests = (build-asdf-system { - pname = "cl-html5-parser-tests"; - version = "20190521-git"; - asds = [ "cl-html5-parser-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-html5-parser/2019-05-21/cl-html5-parser-20190521-git.tgz"; - sha256 = "04if61wigylsmn996rbfl8ylsd0d9hzdmg7p2wiglncibjzcl5k9"; - system = "cl-html5-parser-tests"; - asd = "cl-html5-parser-tests"; - }); - systems = [ "cl-html5-parser-tests" ]; - lispLibs = [ (getAttr "cl-html5-parser" self) (getAttr "json-streams" self) (getAttr "split-sequence" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-htmlprag = (build-asdf-system { - pname = "cl-htmlprag"; - version = "20160628-git"; - asds = [ "cl-htmlprag" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-htmlprag/2016-06-28/cl-htmlprag-20160628-git.tgz"; - sha256 = "1akfy9rldx5a2h34vf7y02pj2j7b5anbxja53m41ism4vklgqg1c"; - system = "cl-htmlprag"; - asd = "cl-htmlprag"; - }); - systems = [ "cl-htmlprag" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "optima" self) (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-httpsqs = (build-asdf-system { - pname = "cl-httpsqs"; - version = "20180228-git"; - asds = [ "cl-httpsqs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-httpsqs/2018-02-28/cl-httpsqs-20180228-git.tgz"; - sha256 = "14nhr03lm8012crczjpgsmf0ydipqf3kggayshm7w72vkyf0haj7"; - system = "cl-httpsqs"; - asd = "cl-httpsqs"; - }); - systems = [ "cl-httpsqs" ]; - lispLibs = [ (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-hue = (build-asdf-system { - pname = "cl-hue"; - version = "20150113-git"; - asds = [ "cl-hue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-hue/2015-01-13/cl-hue-20150113-git.tgz"; - sha256 = "0d2qv60pih1xmk0zzbdwcsyk8k9abjzilcmhz3jdicinl8jinfr4"; - system = "cl-hue"; - asd = "cl-hue"; - }); - systems = [ "cl-hue" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "drakma" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-i18n = (build-asdf-system { - pname = "cl-i18n"; - version = "20241012-git"; - asds = [ "cl-i18n" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-i18n/2024-10-12/cl-i18n-20241012-git.tgz"; - sha256 = "1gp4ncf7ywyyh2f0zdkqibvn0wxm4hvsj672ni2vfqvhcivqfdza"; - system = "cl-i18n"; - asd = "cl-i18n"; - }); - systems = [ "cl-i18n" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-ppcre-unicode" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-id3 = (build-asdf-system { - pname = "cl-id3"; - version = "20230618-git"; - asds = [ "cl-id3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-id3/2023-06-18/cl-id3-20230618-git.tgz"; - sha256 = "0p5rcxy6zy8jq673yphbq5dq0g28vx9g7kfklfhicg2blpzy2yf5"; - system = "cl-id3"; - asd = "cl-id3"; - }); - systems = [ "cl-id3" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ilu = (build-asdf-system { - pname = "cl-ilu"; - version = "20150302-git"; - asds = [ "cl-ilu" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-devil/2015-03-02/cl-devil-20150302-git.tgz"; - sha256 = "1qdjb7xwzjkv99s8q0834lfdq4ch5j2ymrmqsvwzhg47ys17pvvf"; - system = "cl-ilu"; - asd = "cl-ilu"; - }); - systems = [ "cl-ilu" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-devil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ilut = (build-asdf-system { - pname = "cl-ilut"; - version = "20150302-git"; - asds = [ "cl-ilut" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-devil/2015-03-02/cl-devil-20150302-git.tgz"; - sha256 = "1qdjb7xwzjkv99s8q0834lfdq4ch5j2ymrmqsvwzhg47ys17pvvf"; - system = "cl-ilut"; - asd = "cl-ilut"; - }); - systems = [ "cl-ilut" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-devil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-incognia = (build-asdf-system { - pname = "cl-incognia"; - version = "20211230-git"; - asds = [ "cl-incognia" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-incognia/2021-12-30/cl-incognia-20211230-git.tgz"; - sha256 = "0c5v7vqh26vg4mzzz7rkq3r29ygj2q4fw6v56pi79bbszyklfs21"; - system = "cl-incognia"; - asd = "cl-incognia"; - }); - systems = [ "cl-incognia" ]; - lispLibs = [ (getAttr "dexador" self) (getAttr "jonathan" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-indentify = (build-asdf-system { - pname = "cl-indentify"; - version = "20230214-git"; - asds = [ "cl-indentify" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-indentify/2023-02-14/cl-indentify-20230214-git.tgz"; - sha256 = "1np7b3mh3wd5dv7nvwmjl5rgy7m0qf0fx61s04yazlh46k3d0nxd"; - system = "cl-indentify"; - asd = "cl-indentify"; - }); - systems = [ "cl-indentify" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-inflector = (build-asdf-system { - pname = "cl-inflector"; - version = "20150113-git"; - asds = [ "cl-inflector" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-inflector/2015-01-13/cl-inflector-20150113-git.tgz"; - sha256 = "1xwwlhik1la4fp984qnx2dqq24v012qv4x0y49sngfpwg7n0ya7y"; - system = "cl-inflector"; - asd = "cl-inflector"; - }); - systems = [ "cl-inflector" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-inflector-test = (build-asdf-system { - pname = "cl-inflector-test"; - version = "20150113-git"; - asds = [ "cl-inflector-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-inflector/2015-01-13/cl-inflector-20150113-git.tgz"; - sha256 = "1xwwlhik1la4fp984qnx2dqq24v012qv4x0y49sngfpwg7n0ya7y"; - system = "cl-inflector-test"; - asd = "cl-inflector"; - }); - systems = [ "cl-inflector-test" ]; - lispLibs = [ (getAttr "cl-inflector" self) (getAttr "lisp-unit2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-influxdb = (build-asdf-system { - pname = "cl-influxdb"; - version = "20180131-git"; - asds = [ "cl-influxdb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-influxdb/2018-01-31/cl-influxdb-20180131-git.tgz"; - sha256 = "0fqnsdw6x79qsvw7l6xp1gxgzcj6jwpa4mn0z2gbbipff4g7k527"; - system = "cl-influxdb"; - asd = "cl-influxdb"; - }); - systems = [ "cl-influxdb" ]; - lispLibs = [ (getAttr "cl-annot" self) (getAttr "cl-json" self) (getAttr "do-urlencode" self) (getAttr "drakma" self) (getAttr "flexi-streams" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-info = (build-asdf-system { - pname = "cl-info"; - version = "20241012-git"; - asds = [ "cl-info" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-info/2024-10-12/cl-info-20241012-git.tgz"; - sha256 = "0vrrlcwdqnw8v34zd7wkjxh02zysam5c5s5n4l5q6s2jy0gmai0y"; - system = "cl-info"; - asd = "cl-info"; - }); - systems = [ "cl-info" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "docs-config" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-info-test = (build-asdf-system { - pname = "cl-info-test"; - version = "20241012-git"; - asds = [ "cl-info-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-info/2024-10-12/cl-info-20241012-git.tgz"; - sha256 = "0vrrlcwdqnw8v34zd7wkjxh02zysam5c5s5n4l5q6s2jy0gmai0y"; - system = "cl-info-test"; - asd = "cl-info-test"; - }); - systems = [ "cl-info-test" ]; - lispLibs = [ (getAttr "cl-info" self) (getAttr "hamcrest" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ini = (build-asdf-system { - pname = "cl-ini"; - version = "20241012-git"; - asds = [ "cl-ini" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ini/2024-10-12/cl-ini-20241012-git.tgz"; - sha256 = "1dj2w1fs1j52wxy91qy2jrn88aqggrvsg4fngl90ssvfh3awk4wm"; - system = "cl-ini"; - asd = "cl-ini"; - }); - systems = [ "cl-ini" ]; - lispLibs = [ (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ini-test = (build-asdf-system { - pname = "cl-ini-test"; - version = "20241012-git"; - asds = [ "cl-ini-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ini/2024-10-12/cl-ini-20241012-git.tgz"; - sha256 = "1dj2w1fs1j52wxy91qy2jrn88aqggrvsg4fngl90ssvfh3awk4wm"; - system = "cl-ini-test"; - asd = "cl-ini-test"; - }); - systems = [ "cl-ini-test" ]; - lispLibs = [ (getAttr "cl-ini" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-inotify = (build-asdf-system { - pname = "cl-inotify"; - version = "20220707-git"; - asds = [ "cl-inotify" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-inotify/2022-07-07/cl-inotify-20220707-git.tgz"; - sha256 = "0d3bvp5lqnddzhk1w9yyli03njbkhc8d129a058g0j49kgd47c7v"; - system = "cl-inotify"; - asd = "cl-inotify"; - }); - systems = [ "cl-inotify" ]; - lispLibs = [ (getAttr "binary-types" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "iolib" self) (getAttr "iolib_dot_asdf" self) (getAttr "iolib_dot_base" self) (getAttr "iolib_dot_conf" self) (getAttr "osicat" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-inotify-tests = (build-asdf-system { - pname = "cl-inotify-tests"; - version = "20220707-git"; - asds = [ "cl-inotify-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-inotify/2022-07-07/cl-inotify-20220707-git.tgz"; - sha256 = "0d3bvp5lqnddzhk1w9yyli03njbkhc8d129a058g0j49kgd47c7v"; - system = "cl-inotify-tests"; - asd = "cl-inotify-tests"; - }); - systems = [ "cl-inotify-tests" ]; - lispLibs = [ (getAttr "cl-inotify" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-intbytes = (build-asdf-system { - pname = "cl-intbytes"; - version = "20150923-git"; - asds = [ "cl-intbytes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-intbytes/2015-09-23/cl-intbytes-20150923-git.tgz"; - sha256 = "0chwfda7pi8mrgwj31li7f0x0hr5yrp4csiq8hwkgd4c1ag1z9fx"; - system = "cl-intbytes"; - asd = "cl-intbytes"; - }); - systems = [ "cl-intbytes" ]; - lispLibs = [ (getAttr "fast-io" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-intbytes-test = (build-asdf-system { - pname = "cl-intbytes-test"; - version = "20150923-git"; - asds = [ "cl-intbytes-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-intbytes/2015-09-23/cl-intbytes-20150923-git.tgz"; - sha256 = "0chwfda7pi8mrgwj31li7f0x0hr5yrp4csiq8hwkgd4c1ag1z9fx"; - system = "cl-intbytes-test"; - asd = "cl-intbytes-test"; - }); - systems = [ "cl-intbytes-test" ]; - lispLibs = [ (getAttr "cl-intbytes" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-interpol = (build-asdf-system { - pname = "cl-interpol"; - version = "20221106-git"; - asds = [ "cl-interpol" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-interpol/2022-11-06/cl-interpol-20221106-git.tgz"; - sha256 = "1nkjn8byyfdxhi84rbpqs87bb5m478lvphfgxqqv0q37rn75c946"; - system = "cl-interpol"; - asd = "cl-interpol"; - }); - systems = [ "cl-interpol" ]; - lispLibs = [ (getAttr "cl-unicode" self) (getAttr "named-readtables" self) ]; - meta = {}; - }); - cl-interval = (build-asdf-system { - pname = "cl-interval"; - version = "20200715-git"; - asds = [ "cl-interval" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-interval/2020-07-15/cl-interval-20200715-git.tgz"; - sha256 = "1425l6xmrqadjqgqb5qasisf14pbr6zpj30bpxfv8hhnxs5njq4p"; - system = "cl-interval"; - asd = "cl-interval"; - }); - systems = [ "cl-interval" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-interval-docs = (build-asdf-system { - pname = "cl-interval-docs"; - version = "20200715-git"; - asds = [ "cl-interval-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-interval/2020-07-15/cl-interval-20200715-git.tgz"; - sha256 = "1425l6xmrqadjqgqb5qasisf14pbr6zpj30bpxfv8hhnxs5njq4p"; - system = "cl-interval-docs"; - asd = "cl-interval-docs"; - }); - systems = [ "cl-interval-docs" ]; - lispLibs = [ (getAttr "cl-gendoc" self) (getAttr "cl-interval" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ipfs-api2 = (build-asdf-system { - pname = "cl-ipfs-api2"; - version = "20241012-git"; - asds = [ "cl-ipfs-api2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ipfs-api2/2024-10-12/cl-ipfs-api2-20241012-git.tgz"; - sha256 = "0lz19ayvcdhakckxp6z6gzlglhvnaj0qqyx1jmp211fms7dzyl0x"; - system = "cl-ipfs-api2"; - asd = "cl-ipfs-api2"; - }); - systems = [ "cl-ipfs-api2" ]; - lispLibs = [ (getAttr "arnesi" self) (getAttr "drakma" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-irc = (build-asdf-system { - pname = "cl-irc"; - version = "0.9.2"; - asds = [ "cl-irc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-irc/2015-09-23/cl-irc-0.9.2.tgz"; - sha256 = "15h3ram8b6vyg4718ad2m92xgilda2x3zmkzbjnijk69kkqsq01r"; - system = "cl-irc"; - asd = "cl-irc"; - }); - systems = [ "cl-irc" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "split-sequence" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-irc-test = (build-asdf-system { - pname = "cl-irc-test"; - version = "0.9.2"; - asds = [ "cl-irc-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-irc/2015-09-23/cl-irc-0.9.2.tgz"; - sha256 = "15h3ram8b6vyg4718ad2m92xgilda2x3zmkzbjnijk69kkqsq01r"; - system = "cl-irc-test"; - asd = "cl-irc-test"; - }); - systems = [ "cl-irc-test" ]; - lispLibs = [ (getAttr "cl-irc" self) (getAttr "rt" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-irregsexp = (build-asdf-system { - pname = "cl-irregsexp"; - version = "20160825-git"; - asds = [ "cl-irregsexp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-irregsexp/2016-08-25/cl-irregsexp-20160825-git.tgz"; - sha256 = "09pf3jlqskcs32shbj9q3m0zww5pxyrizbvk2nxiwwnbl1rdb406"; - system = "cl-irregsexp"; - asd = "cl-irregsexp"; - }); - systems = [ "cl-irregsexp" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-isaac = (build-asdf-system { - pname = "cl-isaac"; - version = "20231021-git"; - asds = [ "cl-isaac" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-isaac/2023-10-21/cl-isaac-20231021-git.tgz"; - sha256 = "07gjfynhqwwsa839i24h08xd9w7kn5g02rm35x96hq1qrfv1v0fn"; - system = "cl-isaac"; - asd = "cl-isaac"; - }); - systems = [ "cl-isaac" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-iterative = (build-asdf-system { - pname = "cl-iterative"; - version = "20160318-git"; - asds = [ "cl-iterative" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-iterative/2016-03-18/cl-iterative-20160318-git.tgz"; - sha256 = "01h2fs7nq2wivjwh9swsmfdvsdmd7j9dvzgrq0ijbq456zm8vilq"; - system = "cl-iterative"; - asd = "cl-iterative"; - }); - systems = [ "cl-iterative" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "optima" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-iterative-tests = (build-asdf-system { - pname = "cl-iterative-tests"; - version = "20160318-git"; - asds = [ "cl-iterative-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-iterative/2016-03-18/cl-iterative-20160318-git.tgz"; - sha256 = "01h2fs7nq2wivjwh9swsmfdvsdmd7j9dvzgrq0ijbq456zm8vilq"; - system = "cl-iterative-tests"; - asd = "cl-iterative-tests"; - }); - systems = [ "cl-iterative-tests" ]; - lispLibs = [ (getAttr "cl-iterative" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-itertools = (build-asdf-system { - pname = "cl-itertools"; - version = "20160421-git"; - asds = [ "cl-itertools" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-itertools/2016-04-21/cl-itertools-20160421-git.tgz"; - sha256 = "0m1g7nxqnz03bcj46skcr2d50pi3lb4hwizna5d4mvl5hk4zwbxr"; - system = "cl-itertools"; - asd = "cl-itertools"; - }); - systems = [ "cl-itertools" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-coroutine" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-itertools-tests = (build-asdf-system { - pname = "cl-itertools-tests"; - version = "20160421-git"; - asds = [ "cl-itertools-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-itertools/2016-04-21/cl-itertools-20160421-git.tgz"; - sha256 = "0m1g7nxqnz03bcj46skcr2d50pi3lb4hwizna5d4mvl5hk4zwbxr"; - system = "cl-itertools-tests"; - asd = "cl-itertools"; - }); - systems = [ "cl-itertools-tests" ]; - lispLibs = [ (getAttr "cl-itertools" self) (getAttr "fiveam" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-jpeg = (build-asdf-system { - pname = "cl-jpeg"; - version = "20230214-git"; - asds = [ "cl-jpeg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-jpeg/2023-02-14/cl-jpeg-20230214-git.tgz"; - sha256 = "1xl1id4k1bdw6hf24ndkzr6nxi30yw7xlr1fhfmxnwjqwy5hcq14"; - system = "cl-jpeg"; - asd = "cl-jpeg"; - }); - systems = [ "cl-jpeg" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-js = (build-asdf-system { - pname = "cl-js"; - version = "20241012-git"; - asds = [ "cl-js" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/js/2024-10-12/js-20241012-git.tgz"; - sha256 = "084rfqxbhrwqb3xfcx3kzmnyzacr2wb8bkxzl0srdgn17pl7hkx3"; - system = "cl-js"; - asd = "cl-js"; - }); - systems = [ "cl-js" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "local-time" self) (getAttr "parse-js" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-jschema = (build-asdf-system { - pname = "cl-jschema"; - version = "v1.1.1"; - asds = [ "cl-jschema" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-jschema/2023-06-18/cl-jschema-v1.1.1.tgz"; - sha256 = "0awc7hy07sg4h8k58xxxy578a5qklpkj3slslp7ghfzfdbi7nz11"; - system = "cl-jschema"; - asd = "cl-jschema"; - }); - systems = [ "cl-jschema" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "com_dot_inuoe_dot_jzon" self) (getAttr "puri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-json = (build-asdf-system { - pname = "cl-json"; - version = "20220707-git"; - asds = [ "cl-json" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-json/2022-07-07/cl-json-20220707-git.tgz"; - sha256 = "12vakz47d1i7pywgb9cm2364fzykidc9m7l7b6n9lx0gn2qx9ar5"; - system = "cl-json"; - asd = "cl-json"; - }); - systems = [ "cl-json" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-json-helper = (build-asdf-system { - pname = "cl-json-helper"; - version = "20181210-git"; - asds = [ "cl-json-helper" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-json-helper/2018-12-10/cl-json-helper-20181210-git.tgz"; - sha256 = "1dhv5lh514m7bvl77xjhb4ky7nf4bskgpld7rqg3rq24k4y0c79a"; - system = "cl-json-helper"; - asd = "cl-json-helper"; - }); - systems = [ "cl-json-helper" ]; - lispLibs = [ (getAttr "cl-json" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-json-pointer = (build-asdf-system { - pname = "cl-json-pointer"; - version = "20221106-git"; - asds = [ "cl-json-pointer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-json-pointer/2022-11-06/cl-json-pointer-20221106-git.tgz"; - sha256 = "0b7a755wc2ghsd1pv7d32877b21h4nssp41xs017anbmj55czb2h"; - system = "cl-json-pointer"; - asd = "cl-json-pointer"; - }); - systems = [ "cl-json-pointer" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "st-json" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-json-schema = (build-asdf-system { - pname = "cl-json-schema"; - version = "20210228-git"; - asds = [ "cl-json-schema" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-json-schema/2021-02-28/cl-json-schema-20210228-git.tgz"; - sha256 = "1c90c9j6d2b02zyyqd07200waqa4saq0svps7vfy5a3lxp9vag9i"; - system = "cl-json-schema"; - asd = "cl-json-schema"; - }); - systems = [ "cl-json-schema" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "trivial-do" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-json-schema-tests = (build-asdf-system { - pname = "cl-json-schema-tests"; - version = "20210228-git"; - asds = [ "cl-json-schema-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-json-schema/2021-02-28/cl-json-schema-20210228-git.tgz"; - sha256 = "1c90c9j6d2b02zyyqd07200waqa4saq0svps7vfy5a3lxp9vag9i"; - system = "cl-json-schema-tests"; - asd = "cl-json-schema-tests"; - }); - systems = [ "cl-json-schema-tests" ]; - lispLibs = [ (getAttr "cl-json-schema" self) (getAttr "cl-ppcre" self) (getAttr "fiasco" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-jsonl = (build-asdf-system { - pname = "cl-jsonl"; - version = "20231021-git"; - asds = [ "cl-jsonl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-jsonl/2023-10-21/cl-jsonl-20231021-git.tgz"; - sha256 = "0mwszi9r88p21rl6x7gh0cjgmfmzvgs34257h88m6zr7q7h7djw4"; - system = "cl-jsonl"; - asd = "cl-jsonl"; - }); - systems = [ "cl-jsonl" ]; - lispLibs = [ (getAttr "gtwiwtg" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-jsx = (build-asdf-system { - pname = "cl-jsx"; - version = "20160208-git"; - asds = [ "cl-jsx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-jsx/2016-02-08/cl-jsx-20160208-git.tgz"; - sha256 = "1vkqs65sqnfkfka2p93ibfrgg3wps3qhlcgcd8j40h0bv3phcjp7"; - system = "cl-jsx"; - asd = "cl-jsx"; - }); - systems = [ "cl-jsx" ]; - lispLibs = [ (getAttr "cl-who" self) (getAttr "esrap" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-jsx-test = (build-asdf-system { - pname = "cl-jsx-test"; - version = "20160208-git"; - asds = [ "cl-jsx-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-jsx/2016-02-08/cl-jsx-20160208-git.tgz"; - sha256 = "1vkqs65sqnfkfka2p93ibfrgg3wps3qhlcgcd8j40h0bv3phcjp7"; - system = "cl-jsx-test"; - asd = "cl-jsx-test"; - }); - systems = [ "cl-jsx-test" ]; - lispLibs = [ (getAttr "cl-jsx" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-junit-xml = (build-asdf-system { - pname = "cl-junit-xml"; - version = "20150113-git"; - asds = [ "cl-junit-xml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-junit-xml/2015-01-13/cl-junit-xml-20150113-git.tgz"; - sha256 = "1ssrcgw5bhfsb5lk7jb8jyz77mj6sg23wc3gmnw747iqvpikwakr"; - system = "cl-junit-xml"; - asd = "cl-junit-xml"; - }); - systems = [ "cl-junit-xml" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cxml" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-junit-xml_dot_lisp-unit = (build-asdf-system { - pname = "cl-junit-xml.lisp-unit"; - version = "20150113-git"; - asds = [ "cl-junit-xml.lisp-unit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-junit-xml/2015-01-13/cl-junit-xml-20150113-git.tgz"; - sha256 = "1ssrcgw5bhfsb5lk7jb8jyz77mj6sg23wc3gmnw747iqvpikwakr"; - system = "cl-junit-xml.lisp-unit"; - asd = "cl-junit-xml.lisp-unit"; - }); - systems = [ "cl-junit-xml.lisp-unit" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-junit-xml" self) (getAttr "cl-ppcre" self) (getAttr "iterate" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-junit-xml_dot_lisp-unit2 = (build-asdf-system { - pname = "cl-junit-xml.lisp-unit2"; - version = "20150113-git"; - asds = [ "cl-junit-xml.lisp-unit2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-junit-xml/2015-01-13/cl-junit-xml-20150113-git.tgz"; - sha256 = "1ssrcgw5bhfsb5lk7jb8jyz77mj6sg23wc3gmnw747iqvpikwakr"; - system = "cl-junit-xml.lisp-unit2"; - asd = "cl-junit-xml.lisp-unit2"; - }); - systems = [ "cl-junit-xml.lisp-unit2" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-junit-xml" self) (getAttr "cl-ppcre" self) (getAttr "iterate" self) (getAttr "lisp-unit2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-junit-xml_dot_test = (build-asdf-system { - pname = "cl-junit-xml.test"; - version = "20150113-git"; - asds = [ "cl-junit-xml.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-junit-xml/2015-01-13/cl-junit-xml-20150113-git.tgz"; - sha256 = "1ssrcgw5bhfsb5lk7jb8jyz77mj6sg23wc3gmnw747iqvpikwakr"; - system = "cl-junit-xml.test"; - asd = "cl-junit-xml"; - }); - systems = [ "cl-junit-xml.test" ]; - lispLibs = [ (getAttr "cl-junit-xml" self) (getAttr "lisp-unit2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-jwk = (build-asdf-system { - pname = "cl-jwk"; - version = "20231021-git"; - asds = [ "cl-jwk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-jwk/2023-10-21/cl-jwk-20231021-git.tgz"; - sha256 = "07hphgx40583hpvzj2xnk73lypfp1iq40nfpv3gf3hba4x54c17a"; - system = "cl-jwk"; - asd = "cl-jwk"; - }); - systems = [ "cl-jwk" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "binascii" self) (getAttr "cl-reexport" self) (getAttr "dexador" self) (getAttr "ironclad" self) (getAttr "jonathan" self) (getAttr "jose" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-jwk_dot_test = (build-asdf-system { - pname = "cl-jwk.test"; - version = "20231021-git"; - asds = [ "cl-jwk.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-jwk/2023-10-21/cl-jwk-20231021-git.tgz"; - sha256 = "07hphgx40583hpvzj2xnk73lypfp1iq40nfpv3gf3hba4x54c17a"; - system = "cl-jwk.test"; - asd = "cl-jwk.test"; - }); - systems = [ "cl-jwk.test" ]; - lispLibs = [ (getAttr "cl-jwk" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-k8055 = (build-asdf-system { - pname = "cl-k8055"; - version = "20231021-git"; - asds = [ "cl-k8055" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-k8055/2023-10-21/cl-k8055-20231021-git.tgz"; - sha256 = "1qap7pf90l89lqb8asnnnc0qfaabd6p179vmdq1z7n5wxdwsw2b3"; - system = "cl-k8055"; - asd = "cl-k8055"; - }); - systems = [ "cl-k8055" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-ppcre" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-kanren = (build-asdf-system { - pname = "cl-kanren"; - version = "20241012-git"; - asds = [ "cl-kanren" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-kanren/2024-10-12/cl-kanren-20241012-git.tgz"; - sha256 = "136jdgh23vb7imihk9dqwpk8wzjmpvkqfhah3qrxpsw0xpir29sh"; - system = "cl-kanren"; - asd = "cl-kanren"; - }); - systems = [ "cl-kanren" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-kanren-test = (build-asdf-system { - pname = "cl-kanren-test"; - version = "20241012-git"; - asds = [ "cl-kanren-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-kanren/2024-10-12/cl-kanren-20241012-git.tgz"; - sha256 = "136jdgh23vb7imihk9dqwpk8wzjmpvkqfhah3qrxpsw0xpir29sh"; - system = "cl-kanren-test"; - asd = "cl-kanren-test"; - }); - systems = [ "cl-kanren-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-kanren" self) (getAttr "clunit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-keycloak = (build-asdf-system { - pname = "cl-keycloak"; - version = "20190710-git"; - asds = [ "cl-keycloak" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-keycloak/2019-07-10/cl-keycloak-20190710-git.tgz"; - sha256 = "052x10xj951061xa80kp1ziwrr8hskjsr7q2ni1d1ab26rkmhb9q"; - system = "cl-keycloak"; - asd = "cl-keycloak"; - }); - systems = [ "cl-keycloak" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "flexi-streams" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-kraken = (build-asdf-system { - pname = "cl-kraken"; - version = "20220331-git"; - asds = [ "cl-kraken" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-kraken/2022-03-31/cl-kraken-20220331-git.tgz"; - sha256 = "07a9a7yqii0gsiaf4r6jfz2nb2m8766rv4acqcdjm8zmsllwx7jz"; - system = "cl-kraken"; - asd = "cl-kraken"; - }); - systems = [ "cl-kraken" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "dexador" self) (getAttr "ironclad" self) (getAttr "jsown" self) (getAttr "quri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ksuid = (build-asdf-system { - pname = "cl-ksuid"; - version = "20170830-git"; - asds = [ "cl-ksuid" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ksuid/2017-08-30/cl-ksuid-20170830-git.tgz"; - sha256 = "142fr8l6aa6wxnjxv04f61hy9504cx9x1r10byhmj475s5pfr6gl"; - system = "cl-ksuid"; - asd = "cl-ksuid"; - }); - systems = [ "cl-ksuid" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "ironclad" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ksuid-test = (build-asdf-system { - pname = "cl-ksuid-test"; - version = "20170830-git"; - asds = [ "cl-ksuid-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ksuid/2017-08-30/cl-ksuid-20170830-git.tgz"; - sha256 = "142fr8l6aa6wxnjxv04f61hy9504cx9x1r10byhmj475s5pfr6gl"; - system = "cl-ksuid-test"; - asd = "cl-ksuid"; - }); - systems = [ "cl-ksuid-test" ]; - lispLibs = [ (getAttr "cl-ksuid" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ktx = (build-asdf-system { - pname = "cl-ktx"; - version = "20231021-git"; - asds = [ "cl-ktx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ktx/2023-10-21/cl-ktx-20231021-git.tgz"; - sha256 = "1nggg3qixnmv9gisj0aqd369z1rm2qqdf17xnsxcpzz1d9lvxqhq"; - system = "cl-ktx"; - asd = "cl-ktx"; - }); - systems = [ "cl-ktx" ]; - lispLibs = [ (getAttr "binary-structures" self) (getAttr "cl-opengl" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-kyoto-cabinet = (build-asdf-system { - pname = "cl-kyoto-cabinet"; - version = "20191130-git"; - asds = [ "cl-kyoto-cabinet" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-kyoto-cabinet/2019-11-30/cl-kyoto-cabinet-20191130-git.tgz"; - sha256 = "0ayp87ggayaf8d1dblpv90a87fmgh9vhhcah3ch6jvcw6zzb9lcr"; - system = "cl-kyoto-cabinet"; - asd = "cl-kyoto-cabinet"; - }); - systems = [ "cl-kyoto-cabinet" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-l10n = (build-asdf-system { - pname = "cl-l10n"; - version = "20211209-git"; - asds = [ "cl-l10n" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-l10n/2021-12-09/cl-l10n-20211209-git.tgz"; - sha256 = "10yknvjcbgc82a6k6yzj2diki2z2s04q5kg642f2gfj2rl3bjyz7"; - system = "cl-l10n"; - asd = "cl-l10n"; - }); - systems = [ "cl-l10n" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "cl-l10n-cldr" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "cxml" self) (getAttr "flexi-streams" self) (getAttr "iterate" self) (getAttr "local-time" self) (getAttr "metabang-bind" self) ]; - meta = {}; - }); - cl-l10n-cldr = (build-asdf-system { - pname = "cl-l10n-cldr"; - version = "20120909-darcs"; - asds = [ "cl-l10n-cldr" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-l10n-cldr/2012-09-09/cl-l10n-cldr-20120909-darcs.tgz"; - sha256 = "1mwkjdc51158v9rpdpsc1qzqqs0x8hb9k1k7b0pm8q7dp9rrb53v"; - system = "cl-l10n-cldr"; - asd = "cl-l10n-cldr"; - }); - systems = [ "cl-l10n-cldr" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-lambdacalc = (build-asdf-system { - pname = "cl-lambdacalc"; - version = "20230214-git"; - asds = [ "cl-lambdacalc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-lambdacalc/2023-02-14/cl-lambdacalc-20230214-git.tgz"; - sha256 = "0ja08d6p1dnbpf8yl8n59vis5lzr3x32in3iin72zmhj5n60axbd"; - system = "cl-lambdacalc"; - asd = "cl-lambdacalc"; - }); - systems = [ "cl-lambdacalc" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-lambdacalc-test = (build-asdf-system { - pname = "cl-lambdacalc-test"; - version = "20230214-git"; - asds = [ "cl-lambdacalc-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-lambdacalc/2023-02-14/cl-lambdacalc-20230214-git.tgz"; - sha256 = "0ja08d6p1dnbpf8yl8n59vis5lzr3x32in3iin72zmhj5n60axbd"; - system = "cl-lambdacalc-test"; - asd = "cl-lambdacalc-test"; - }); - systems = [ "cl-lambdacalc-test" ]; - lispLibs = [ (getAttr "cl-lambdacalc" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-las = (build-asdf-system { - pname = "cl-las"; - version = "20221106-git"; - asds = [ "cl-las" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-las/2022-11-06/cl-las-20221106-git.tgz"; - sha256 = "119v5mrvxhz8b3alqj9gzfbzhigdm1n1hmwyylncn5w5dkq3jc9k"; - system = "cl-las"; - asd = "cl-las"; - }); - systems = [ "cl-las" ]; - lispLibs = [ (getAttr "binary-io" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-lastfm = (build-asdf-system { - pname = "cl-lastfm"; - version = "0.2.1"; - asds = [ "cl-lastfm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-lastfm/2014-07-13/cl-lastfm-0.2.1.tgz"; - sha256 = "0f37b8swgfz57bffcypjhcgzj5dhanssiraahkianj65a6zbindl"; - system = "cl-lastfm"; - asd = "cl-lastfm"; - }); - systems = [ "cl-lastfm" ]; - lispLibs = [ (getAttr "cxml-stp" self) (getAttr "drakma" self) (getAttr "trivial-utf-8" self) (getAttr "url-rewrite" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-lastfm-test = (build-asdf-system { - pname = "cl-lastfm-test"; - version = "0.2.1"; - asds = [ "cl-lastfm-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-lastfm/2014-07-13/cl-lastfm-0.2.1.tgz"; - sha256 = "0f37b8swgfz57bffcypjhcgzj5dhanssiraahkianj65a6zbindl"; - system = "cl-lastfm-test"; - asd = "cl-lastfm-test"; - }); - systems = [ "cl-lastfm-test" ]; - lispLibs = [ (getAttr "cl-lastfm" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-launch = (build-asdf-system { - pname = "cl-launch"; - version = "4.1.4.1"; - asds = [ "cl-launch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-launch/2015-10-31/cl-launch-4.1.4.1.tgz"; - sha256 = "041nh1sh9rqdk9c1kr63n3g2pn11i68x9plzyfq36wmyhz2aypnr"; - system = "cl-launch"; - asd = "cl-launch"; - }); - systems = [ "cl-launch" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-lc = (build-asdf-system { - pname = "cl-lc"; - version = "20241012-git"; - asds = [ "cl-lc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-lc/2024-10-12/cl-lc-20241012-git.tgz"; - sha256 = "07wpbwgjybhp6vdr2rbd93jwakqixr9dyymp3yz1h684ln7wvfkb"; - system = "cl-lc"; - asd = "cl-lc"; - }); - systems = [ "cl-lc" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "optima" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ledger = (build-asdf-system { - pname = "cl-ledger"; - version = "20200218-git"; - asds = [ "cl-ledger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ledger/2020-02-18/cl-ledger-20200218-git.tgz"; - sha256 = "1dpxna9s0rgshqbc58h698ihwyk34a3napb8zrm8vbq8aigjrrzs"; - system = "cl-ledger"; - asd = "cl-ledger"; - }); - systems = [ "cl-ledger" ]; - lispLibs = [ (getAttr "cambl" self) (getAttr "cl-ppcre" self) (getAttr "local-time" self) (getAttr "periods-series" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-lex = (build-asdf-system { - pname = "cl-lex"; - version = "20160929-git"; - asds = [ "cl-lex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-lex/2016-09-29/cl-lex-20160929-git.tgz"; - sha256 = "1kg50f76bfpfxcv4dfivq1n9a0xlsra2ajb0vd68lxwgbidgyc2y"; - system = "cl-lex"; - asd = "cl-lex"; - }); - systems = [ "cl-lex" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-lexer = (build-asdf-system { - pname = "cl-lexer"; - version = "20191007-git"; - asds = [ "cl-lexer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-lexer/2019-10-07/cl-lexer-20191007-git.tgz"; - sha256 = "182fnmazfmc3zdp14lvpxlaxrwwsjp8mbjn8sdzywjxcnvlpkdmk"; - system = "cl-lexer"; - asd = "cl-lexer"; - }); - systems = [ "cl-lexer" ]; - lispLibs = [ (getAttr "regex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-liballegro = (build-asdf-system { - pname = "cl-liballegro"; - version = "20241012-git"; - asds = [ "cl-liballegro" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-liballegro/2024-10-12/cl-liballegro-20241012-git.tgz"; - sha256 = "1q263wzm25rynyhcym216l3swhrz6fhiwhdbh4iz212hw9w0kn71"; - system = "cl-liballegro"; - asd = "cl-liballegro"; - }); - systems = [ "cl-liballegro" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-libffi" self) (getAttr "float-features" self) (getAttr "trivial-garbage" self) (getAttr "trivial-gray-streams" self) (getAttr "trivial-main-thread" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-liballegro-nuklear = (build-asdf-system { - pname = "cl-liballegro-nuklear"; - version = "20241012-git"; - asds = [ "cl-liballegro-nuklear" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-liballegro-nuklear/2024-10-12/cl-liballegro-nuklear-20241012-git.tgz"; - sha256 = "15wbs1jfl60dnyzgzdibw2hkl64cx3n3v90i5jp0vd123kix217j"; - system = "cl-liballegro-nuklear"; - asd = "cl-liballegro-nuklear"; - }); - systems = [ "cl-liballegro-nuklear" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-libffi" self) (getAttr "cl-liballegro" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libevent2 = (build-asdf-system { - pname = "cl-libevent2"; - version = "20190107-git"; - asds = [ "cl-libevent2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libevent2/2019-01-07/cl-libevent2-20190107-git.tgz"; - sha256 = "18c8cxlh0vmyca7ihj8dz3f1j31h7y0kcis6qr6mpkzyi0k2cf0g"; - system = "cl-libevent2"; - asd = "cl-libevent2"; - }); - systems = [ "cl-libevent2" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libevent2-ssl = (build-asdf-system { - pname = "cl-libevent2-ssl"; - version = "20190107-git"; - asds = [ "cl-libevent2-ssl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libevent2/2019-01-07/cl-libevent2-20190107-git.tgz"; - sha256 = "18c8cxlh0vmyca7ihj8dz3f1j31h7y0kcis6qr6mpkzyi0k2cf0g"; - system = "cl-libevent2-ssl"; - asd = "cl-libevent2-ssl"; - }); - systems = [ "cl-libevent2-ssl" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-libevent2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libiio = (build-asdf-system { - pname = "cl-libiio"; - version = "20191130-git"; - asds = [ "cl-libiio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libiio/2019-11-30/cl-libiio-20191130-git.tgz"; - sha256 = "1z1jslm303c22imhshr92j1mq7g3j81xa5rk5psj3x00papncwmr"; - system = "cl-libiio"; - asd = "cl-libiio"; - }); - systems = [ "cl-libiio" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libinput = (build-asdf-system { - pname = "cl-libinput"; - version = "20220707-git"; - asds = [ "cl-libinput" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libinput/2022-07-07/cl-libinput-20220707-git.tgz"; - sha256 = "18c3rl3d2bizbp3607gnn9j50x84f2mkypj9rqbry56i5gcw8zkh"; - system = "cl-libinput"; - asd = "cl-libinput"; - }); - systems = [ "cl-libinput" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "osicat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-liblinear = (build-asdf-system { - pname = "cl-liblinear"; - version = "20211020-git"; - asds = [ "cl-liblinear" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libsvm/2021-10-20/cl-libsvm-20211020-git.tgz"; - sha256 = "0fpcw82hz6bp2hicjhvhxwcj4azprcl911n8q941lk8xcld3pmi0"; - system = "cl-liblinear"; - asd = "cl-liblinear"; - }); - systems = [ "cl-liblinear" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libpuzzle = (build-asdf-system { - pname = "cl-libpuzzle"; - version = "20150608-git"; - asds = [ "cl-libpuzzle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libpuzzle/2015-06-08/cl-libpuzzle-20150608-git.tgz"; - sha256 = "0qgpdg4lni4sq6jp23qcd1jldsnrsn4h5b14ddmc8mb7va4qshlp"; - system = "cl-libpuzzle"; - asd = "cl-libpuzzle"; - }); - systems = [ "cl-libpuzzle" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libpuzzle-test = (build-asdf-system { - pname = "cl-libpuzzle-test"; - version = "20150608-git"; - asds = [ "cl-libpuzzle-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libpuzzle/2015-06-08/cl-libpuzzle-20150608-git.tgz"; - sha256 = "0qgpdg4lni4sq6jp23qcd1jldsnrsn4h5b14ddmc8mb7va4qshlp"; - system = "cl-libpuzzle-test"; - asd = "cl-libpuzzle-test"; - }); - systems = [ "cl-libpuzzle-test" ]; - lispLibs = [ (getAttr "cl-libpuzzle" self) (getAttr "cl-test-more" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libsvm = (build-asdf-system { - pname = "cl-libsvm"; - version = "20211020-git"; - asds = [ "cl-libsvm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libsvm/2021-10-20/cl-libsvm-20211020-git.tgz"; - sha256 = "0fpcw82hz6bp2hicjhvhxwcj4azprcl911n8q941lk8xcld3pmi0"; - system = "cl-libsvm"; - asd = "cl-libsvm"; - }); - systems = [ "cl-libsvm" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libsvm-format = (build-asdf-system { - pname = "cl-libsvm-format"; - version = "20180711-git"; - asds = [ "cl-libsvm-format" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libsvm-format/2018-07-11/cl-libsvm-format-20180711-git.tgz"; - sha256 = "0284aj84xszhkhlivaigf9qj855fxad3mzmv3zfr0qzb5k0nzwrg"; - system = "cl-libsvm-format"; - asd = "cl-libsvm-format"; - }); - systems = [ "cl-libsvm-format" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libsvm-format-test = (build-asdf-system { - pname = "cl-libsvm-format-test"; - version = "20180711-git"; - asds = [ "cl-libsvm-format-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libsvm-format/2018-07-11/cl-libsvm-format-20180711-git.tgz"; - sha256 = "0284aj84xszhkhlivaigf9qj855fxad3mzmv3zfr0qzb5k0nzwrg"; - system = "cl-libsvm-format-test"; - asd = "cl-libsvm-format-test"; - }); - systems = [ "cl-libsvm-format-test" ]; - lispLibs = [ (getAttr "cl-libsvm-format" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libusb = (build-asdf-system { - pname = "cl-libusb"; - version = "20210228-git"; - asds = [ "cl-libusb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libusb/2021-02-28/cl-libusb-20210228-git.tgz"; - sha256 = "0kyzgcflwb85q58fgn82sp0bipnq5bprg5i4h0h3jxafqqyagbnk"; - system = "cl-libusb"; - asd = "cl-libusb"; - }); - systems = [ "cl-libusb" ]; - lispLibs = [ (getAttr "libusb-ffi" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libuv = (build-asdf-system { - pname = "cl-libuv"; - version = "20230618-git"; - asds = [ "cl-libuv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libuv/2023-06-18/cl-libuv-20230618-git.tgz"; - sha256 = "13kymryibhlq7jc8q3yar0c676srx82axfmz0x2r5kq7k94cknl9"; - system = "cl-libuv"; - asd = "cl-libuv"; - }); - systems = [ "cl-libuv" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = {}; - }); - cl-libuv-config = (build-asdf-system { - pname = "cl-libuv-config"; - version = "20230618-git"; - asds = [ "cl-libuv-config" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libuv/2023-06-18/cl-libuv-20230618-git.tgz"; - sha256 = "13kymryibhlq7jc8q3yar0c676srx82axfmz0x2r5kq7k94cknl9"; - system = "cl-libuv-config"; - asd = "cl-libuv-config"; - }); - systems = [ "cl-libuv-config" ]; - lispLibs = [ (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libxml2 = (build-asdf-system { - pname = "cl-libxml2"; - version = "20130615-git"; - asds = [ "cl-libxml2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libxml2/2013-06-15/cl-libxml2-20130615-git.tgz"; - sha256 = "09049c13cfp5sc6x9lrw762jd7a9qkfq5jgngqgrzn4kn9qscarw"; - system = "cl-libxml2"; - asd = "cl-libxml2"; - }); - systems = [ "cl-libxml2" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "flexi-streams" self) (getAttr "garbage-pools" self) (getAttr "iterate" self) (getAttr "metabang-bind" self) (getAttr "puri" self) ]; - meta = {}; - }); - cl-libxml2-test = (build-asdf-system { - pname = "cl-libxml2-test"; - version = "20130615-git"; - asds = [ "cl-libxml2-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libxml2/2013-06-15/cl-libxml2-20130615-git.tgz"; - sha256 = "09049c13cfp5sc6x9lrw762jd7a9qkfq5jgngqgrzn4kn9qscarw"; - system = "cl-libxml2-test"; - asd = "cl-libxml2"; - }); - systems = [ "cl-libxml2-test" ]; - lispLibs = [ (getAttr "cl-libxml2" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-libyaml = (build-asdf-system { - pname = "cl-libyaml"; - version = "20201220-git"; - asds = [ "cl-libyaml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libyaml/2020-12-20/cl-libyaml-20201220-git.tgz"; - sha256 = "06pvmackyhq03rjmihpx6w63m6cy8wx78ll5xpwwvd85bgrqq817"; - system = "cl-libyaml"; - asd = "cl-libyaml"; - }); - systems = [ "cl-libyaml" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = {}; - }); - cl-libyaml-test = (build-asdf-system { - pname = "cl-libyaml-test"; - version = "20201220-git"; - asds = [ "cl-libyaml-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libyaml/2020-12-20/cl-libyaml-20201220-git.tgz"; - sha256 = "06pvmackyhq03rjmihpx6w63m6cy8wx78ll5xpwwvd85bgrqq817"; - system = "cl-libyaml-test"; - asd = "cl-libyaml-test"; - }); - systems = [ "cl-libyaml-test" ]; - lispLibs = [ (getAttr "cl-libyaml" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-lite = (build-asdf-system { - pname = "cl-lite"; - version = "master-fe503896-git"; - asds = [ "cl-lite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "cl-lite"; - asd = "cl-lite"; - }); - systems = [ "cl-lite" ]; - lispLibs = [ (getAttr "glisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-locale = (build-asdf-system { - pname = "cl-locale"; - version = "20151031-git"; - asds = [ "cl-locale" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-locale/2015-10-31/cl-locale-20151031-git.tgz"; - sha256 = "1rhannhpsw1yg1fpflam483a3w9qb1izgyvmnmiddv3dn4qsmn9p"; - system = "cl-locale"; - asd = "cl-locale"; - }); - systems = [ "cl-locale" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "arnesi" self) (getAttr "cl-annot" self) (getAttr "cl-syntax" self) (getAttr "cl-syntax-annot" self) ]; - meta = {}; - }); - cl-locale-syntax = (build-asdf-system { - pname = "cl-locale-syntax"; - version = "20151031-git"; - asds = [ "cl-locale-syntax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-locale/2015-10-31/cl-locale-20151031-git.tgz"; - sha256 = "1rhannhpsw1yg1fpflam483a3w9qb1izgyvmnmiddv3dn4qsmn9p"; - system = "cl-locale-syntax"; - asd = "cl-locale-syntax"; - }); - systems = [ "cl-locale-syntax" ]; - lispLibs = [ (getAttr "cl-locale" self) (getAttr "cl-syntax" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-locale-test = (build-asdf-system { - pname = "cl-locale-test"; - version = "20151031-git"; - asds = [ "cl-locale-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-locale/2015-10-31/cl-locale-20151031-git.tgz"; - sha256 = "1rhannhpsw1yg1fpflam483a3w9qb1izgyvmnmiddv3dn4qsmn9p"; - system = "cl-locale-test"; - asd = "cl-locale-test"; - }); - systems = [ "cl-locale-test" ]; - lispLibs = [ (getAttr "cl-locale" self) (getAttr "cl-syntax" self) (getAttr "flexi-streams" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-locatives = (build-asdf-system { - pname = "cl-locatives"; - version = "20230618-git"; - asds = [ "cl-locatives" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-locatives/2023-06-18/cl-locatives-20230618-git.tgz"; - sha256 = "05avna8fj3bicdhbcvnjmv9dnqq10g26m9pwgmrh6a4hyxz9zdaq"; - system = "cl-locatives"; - asd = "cl-locatives"; - }); - systems = [ "cl-locatives" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-log = (build-asdf-system { - pname = "cl-log"; - version = "20241012-git"; - asds = [ "cl-log" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-log/2024-10-12/cl-log-20241012-git.tgz"; - sha256 = "1r3z9swy1b59swvaa5b97is9ysrfmjvjjhhw56p7p5hqg93b92ak"; - system = "cl-log"; - asd = "cl-log"; - }); - systems = [ "cl-log" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-logic = (build-asdf-system { - pname = "cl-logic"; - version = "20141217-git"; - asds = [ "cl-logic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-logic/2014-12-17/cl-logic-20141217-git.tgz"; - sha256 = "17n2wzqali3j6b7pqbydipwlxgwdrj4mdnsgwjdyz32n8jvfyjwh"; - system = "cl-logic"; - asd = "cl-logic"; - }); - systems = [ "cl-logic" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "quine-mccluskey" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ltsv = (build-asdf-system { - pname = "cl-ltsv"; - version = "20140713-git"; - asds = [ "cl-ltsv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ltsv/2014-07-13/cl-ltsv-20140713-git.tgz"; - sha256 = "1bjvnwxyaaw3yrq5hws2fr4qmk5938hdh2np2bqpm4m3b2c94n22"; - system = "cl-ltsv"; - asd = "cl-ltsv"; - }); - systems = [ "cl-ltsv" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ltsv-test = (build-asdf-system { - pname = "cl-ltsv-test"; - version = "20140713-git"; - asds = [ "cl-ltsv-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ltsv/2014-07-13/cl-ltsv-20140713-git.tgz"; - sha256 = "1bjvnwxyaaw3yrq5hws2fr4qmk5938hdh2np2bqpm4m3b2c94n22"; - system = "cl-ltsv-test"; - asd = "cl-ltsv-test"; - }); - systems = [ "cl-ltsv-test" ]; - lispLibs = [ (getAttr "cl-ltsv" self) (getAttr "cl-test-more" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-lzma = (build-asdf-system { - pname = "cl-lzma"; - version = "20191130-git"; - asds = [ "cl-lzma" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-lzma/2019-11-30/cl-lzma-20191130-git.tgz"; - sha256 = "17fdinmi2ffdga17slv86van0sp9gkvlmjprfdwak2jzziz6fxx6"; - system = "cl-lzma"; - asd = "cl-lzma"; - }); - systems = [ "cl-lzma" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-autowrap" self) (getAttr "fast-io" self) (getAttr "static-vectors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-m4 = (build-asdf-system { - pname = "cl-m4"; - version = "20130312-git"; - asds = [ "cl-m4" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-m4/2013-03-12/cl-m4-20130312-git.tgz"; - sha256 = "1dqdhxb45j4vqmx38xkq32gsckldca8rxpf2idg4b61wd21c0ci6"; - system = "cl-m4"; - asd = "cl-m4"; - }); - systems = [ "cl-m4" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "external-program" self) (getAttr "graylex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-m4-test = (build-asdf-system { - pname = "cl-m4-test"; - version = "20130312-git"; - asds = [ "cl-m4-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-m4/2013-03-12/cl-m4-20130312-git.tgz"; - sha256 = "1dqdhxb45j4vqmx38xkq32gsckldca8rxpf2idg4b61wd21c0ci6"; - system = "cl-m4-test"; - asd = "cl-m4-test"; - }); - systems = [ "cl-m4-test" ]; - lispLibs = [ (getAttr "cl-heredoc" self) (getAttr "cl-m4" self) (getAttr "hu_dot_dwim_dot_stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mango = (build-asdf-system { - pname = "cl-mango"; - version = "20200925-git"; - asds = [ "cl-mango" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mango/2020-09-25/cl-mango-20200925-git.tgz"; - sha256 = "0ipa1azakzqigq103m1j2z597bp2i34kx4z1418kp2jn8zwbdz5s"; - system = "cl-mango"; - asd = "cl-mango"; - }); - systems = [ "cl-mango" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "json-mop" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-markdown = (build-asdf-system { - pname = "cl-markdown"; - version = "20191227-git"; - asds = [ "cl-markdown" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-markdown/2019-12-27/cl-markdown-20191227-git.tgz"; - sha256 = "1wksi765nk8kf5qm2chh7dcn6k562kvc108dzdb9y5iwp97lqqvg"; - system = "cl-markdown"; - asd = "cl-markdown"; - }); - systems = [ "cl-markdown" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "cl-containers" self) (getAttr "cl-ppcre" self) (getAttr "dynamic-classes" self) (getAttr "metabang-bind" self) (getAttr "metatilities-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-markdown-comparisons = (build-asdf-system { - pname = "cl-markdown-comparisons"; - version = "20191227-git"; - asds = [ "cl-markdown-comparisons" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-markdown/2019-12-27/cl-markdown-20191227-git.tgz"; - sha256 = "1wksi765nk8kf5qm2chh7dcn6k562kvc108dzdb9y5iwp97lqqvg"; - system = "cl-markdown-comparisons"; - asd = "cl-markdown-comparisons"; - }); - systems = [ "cl-markdown-comparisons" ]; - lispLibs = [ (getAttr "cl-html-diff" self) (getAttr "cl-markdown" self) (getAttr "html-encode" self) (getAttr "lift" self) (getAttr "lml2" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-markdown-test = (build-asdf-system { - pname = "cl-markdown-test"; - version = "20191227-git"; - asds = [ "cl-markdown-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-markdown/2019-12-27/cl-markdown-20191227-git.tgz"; - sha256 = "1wksi765nk8kf5qm2chh7dcn6k562kvc108dzdb9y5iwp97lqqvg"; - system = "cl-markdown-test"; - asd = "cl-markdown-test"; - }); - systems = [ "cl-markdown-test" ]; - lispLibs = [ (getAttr "cl-markdown" self) (getAttr "lift" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-markless = (build-asdf-system { - pname = "cl-markless"; - version = "20241012-git"; - asds = [ "cl-markless" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; - sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; - system = "cl-markless"; - asd = "cl-markless"; - }); - systems = [ "cl-markless" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "trivial-indent" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-markless-epub = (build-asdf-system { - pname = "cl-markless-epub"; - version = "20241012-git"; - asds = [ "cl-markless-epub" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; - sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; - system = "cl-markless-epub"; - asd = "cl-markless-epub"; - }); - systems = [ "cl-markless-epub" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-markless-plump" self) (getAttr "trivial-gray-streams" self) (getAttr "trivial-indent" self) (getAttr "trivial-mimes" self) (getAttr "zip" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-markless-latex = (build-asdf-system { - pname = "cl-markless-latex"; - version = "20241012-git"; - asds = [ "cl-markless-latex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; - sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; - system = "cl-markless-latex"; - asd = "cl-markless-latex"; - }); - systems = [ "cl-markless-latex" ]; - lispLibs = [ (getAttr "cl-markless" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-markless-markdown = (build-asdf-system { - pname = "cl-markless-markdown"; - version = "20241012-git"; - asds = [ "cl-markless-markdown" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; - sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; - system = "cl-markless-markdown"; - asd = "cl-markless-markdown"; - }); - systems = [ "cl-markless-markdown" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "_3bmd-ext-code-blocks" self) (getAttr "cl-markless" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-markless-plump = (build-asdf-system { - pname = "cl-markless-plump"; - version = "20241012-git"; - asds = [ "cl-markless-plump" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; - sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; - system = "cl-markless-plump"; - asd = "cl-markless-plump"; - }); - systems = [ "cl-markless-plump" ]; - lispLibs = [ (getAttr "cl-markless" self) (getAttr "plump-dom" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-markless-standalone = (build-asdf-system { - pname = "cl-markless-standalone"; - version = "20241012-git"; - asds = [ "cl-markless-standalone" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; - sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; - system = "cl-markless-standalone"; - asd = "cl-markless-standalone"; - }); - systems = [ "cl-markless-standalone" ]; - lispLibs = [ (getAttr "cl-markless" self) (getAttr "cl-markless-epub" self) (getAttr "cl-markless-latex" self) (getAttr "cl-markless-markdown" self) (getAttr "cl-markless-plump" self) (getAttr "command-line-arguments" self) (getAttr "pathname-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-markless-test = (build-asdf-system { - pname = "cl-markless-test"; - version = "20241012-git"; - asds = [ "cl-markless-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; - sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; - system = "cl-markless-test"; - asd = "cl-markless-test"; - }); - systems = [ "cl-markless-test" ]; - lispLibs = [ (getAttr "cl-markless" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-marklogic = (build-asdf-system { - pname = "cl-marklogic"; - version = "20210124-git"; - asds = [ "cl-marklogic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-marklogic/2021-01-24/cl-marklogic-20210124-git.tgz"; - sha256 = "0baq2ccb88zyr2dqdvpm32lsin4zalv11w48x4xm80cr4kw45fk5"; - system = "cl-marklogic"; - asd = "cl-marklogic"; - }); - systems = [ "cl-marklogic" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "drakma" self) (getAttr "fiveam" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-markup = (build-asdf-system { - pname = "cl-markup"; - version = "20131003-git"; - asds = [ "cl-markup" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-markup/2013-10-03/cl-markup-20131003-git.tgz"; - sha256 = "10l6k45971dl13fkdmva7zc6i453lmq9j4xax2ci6pjzlc6xjhp7"; - system = "cl-markup"; - asd = "cl-markup"; - }); - systems = [ "cl-markup" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-markup-test = (build-asdf-system { - pname = "cl-markup-test"; - version = "20131003-git"; - asds = [ "cl-markup-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-markup/2013-10-03/cl-markup-20131003-git.tgz"; - sha256 = "10l6k45971dl13fkdmva7zc6i453lmq9j4xax2ci6pjzlc6xjhp7"; - system = "cl-markup-test"; - asd = "cl-markup-test"; - }); - systems = [ "cl-markup-test" ]; - lispLibs = [ (getAttr "cl-markup" self) (getAttr "cl-test-more" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-match = (build-asdf-system { - pname = "cl-match"; - version = "20121125-git"; - asds = [ "cl-match" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-match/2012-11-25/cl-match-20121125-git.tgz"; - sha256 = "1qc8gzp7f4phgyi5whkxacrqzdqs0y1hvkf71m8n7l303jly9wjf"; - system = "cl-match"; - asd = "cl-match"; - }); - systems = [ "cl-match" ]; - lispLibs = [ (getAttr "standard-cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-match-test = (build-asdf-system { - pname = "cl-match-test"; - version = "20121125-git"; - asds = [ "cl-match-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-match/2012-11-25/cl-match-20121125-git.tgz"; - sha256 = "1qc8gzp7f4phgyi5whkxacrqzdqs0y1hvkf71m8n7l303jly9wjf"; - system = "cl-match-test"; - asd = "cl-match-test"; - }); - systems = [ "cl-match-test" ]; - lispLibs = [ (getAttr "cl-match" self) (getAttr "pcl-unit-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mathstats = (build-asdf-system { - pname = "cl-mathstats"; - version = "20230214-git"; - asds = [ "cl-mathstats" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mathstats/2023-02-14/cl-mathstats-20230214-git.tgz"; - sha256 = "17ic625bdsvgfjndl4zzxkjy7dcl54alg2pdr0jjn4cpysffga6z"; - system = "cl-mathstats"; - asd = "cl-mathstats"; - }); - systems = [ "cl-mathstats" ]; - lispLibs = [ (getAttr "cl-containers" self) (getAttr "metatilities-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mathstats-test = (build-asdf-system { - pname = "cl-mathstats-test"; - version = "20230214-git"; - asds = [ "cl-mathstats-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mathstats/2023-02-14/cl-mathstats-20230214-git.tgz"; - sha256 = "17ic625bdsvgfjndl4zzxkjy7dcl54alg2pdr0jjn4cpysffga6z"; - system = "cl-mathstats-test"; - asd = "cl-mathstats-test"; - }); - systems = [ "cl-mathstats-test" ]; - lispLibs = [ (getAttr "cl-mathstats" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-maxminddb = (build-asdf-system { - pname = "cl-maxminddb"; - version = "20210630-git"; - asds = [ "cl-maxminddb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-maxminddb/2021-06-30/cl-maxminddb-20210630-git.tgz"; - sha256 = "1mm7cpiygcka39pj4a0rvhayfl4wh0zfjkda60yshq24xmml84pw"; - system = "cl-maxminddb"; - asd = "cl-maxminddb"; - }); - systems = [ "cl-maxminddb" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cffi" self) (getAttr "cffi-libffi" self) (getAttr "ieee-floats" self) (getAttr "iterate" self) (getAttr "metabang-bind" self) (getAttr "mmap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-maxsat = (build-asdf-system { - pname = "cl-maxsat"; - version = "20200218-git"; - asds = [ "cl-maxsat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-maxsat/2020-02-18/cl-maxsat-20200218-git.tgz"; - sha256 = "0qy4hhi8y3wv88x3s88g2hl2cz25cjp26xapd3z4h7lrx7cy786i"; - system = "cl-maxsat"; - asd = "cl-maxsat"; - }); - systems = [ "cl-maxsat" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-sat" self) (getAttr "iterate" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-maxsat_dot_test = (build-asdf-system { - pname = "cl-maxsat.test"; - version = "20200218-git"; - asds = [ "cl-maxsat.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-maxsat/2020-02-18/cl-maxsat-20200218-git.tgz"; - sha256 = "0qy4hhi8y3wv88x3s88g2hl2cz25cjp26xapd3z4h7lrx7cy786i"; - system = "cl-maxsat.test"; - asd = "cl-maxsat.test"; - }); - systems = [ "cl-maxsat.test" ]; - lispLibs = [ (getAttr "cl-maxsat" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mdb = (build-asdf-system { - pname = "cl-mdb"; - version = "20220707-git"; - asds = [ "cl-mdb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mdb/2022-07-07/cl-mdb-20220707-git.tgz"; - sha256 = "1xkhk39485yv3j9bshnnv74c95asf9704g80wb8vwvwsvqi7ym2a"; - system = "cl-mdb"; - asd = "cl-mdb"; - }); - systems = [ "cl-mdb" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mecab = (build-asdf-system { - pname = "cl-mecab"; - version = "20181018-git"; - asds = [ "cl-mecab" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mecab/2018-10-18/cl-mecab-20181018-git.tgz"; - sha256 = "0lfan9p8dsniyp60g6n8awfjvv8lyickc40qdxiry6kmp65636ps"; - system = "cl-mecab"; - asd = "cl-mecab"; - }); - systems = [ "cl-mecab" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mecab-test = (build-asdf-system { - pname = "cl-mecab-test"; - version = "20181018-git"; - asds = [ "cl-mecab-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mecab/2018-10-18/cl-mecab-20181018-git.tgz"; - sha256 = "0lfan9p8dsniyp60g6n8awfjvv8lyickc40qdxiry6kmp65636ps"; - system = "cl-mecab-test"; - asd = "cl-mecab-test"; - }); - systems = [ "cl-mecab-test" ]; - lispLibs = [ (getAttr "cl-mecab" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mechanize = (build-asdf-system { - pname = "cl-mechanize"; - version = "20180711-git"; - asds = [ "cl-mechanize" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mechanize/2018-07-11/cl-mechanize-20180711-git.tgz"; - sha256 = "0y86sdi2nl3jv6n535cd62jax0mpc0cckrhffaqacbgbdjc875sn"; - system = "cl-mechanize"; - asd = "cl-mechanize"; - }); - systems = [ "cl-mechanize" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "closure-html" self) (getAttr "cxml-stp" self) (getAttr "drakma" self) (getAttr "puri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mediawiki = (build-asdf-system { - pname = "cl-mediawiki"; - version = "20161204-git"; - asds = [ "cl-mediawiki" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mediawiki/2016-12-04/cl-mediawiki-20161204-git.tgz"; - sha256 = "1wrysj9l64k3xx152yw1arvn1glnx60j730qvj8prm65iid95xgm"; - system = "cl-mediawiki"; - asd = "cl-mediawiki"; - }); - systems = [ "cl-mediawiki" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cxml" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mediawiki-test = (build-asdf-system { - pname = "cl-mediawiki-test"; - version = "20161204-git"; - asds = [ "cl-mediawiki-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mediawiki/2016-12-04/cl-mediawiki-20161204-git.tgz"; - sha256 = "1wrysj9l64k3xx152yw1arvn1glnx60j730qvj8prm65iid95xgm"; - system = "cl-mediawiki-test"; - asd = "cl-mediawiki-test"; - }); - systems = [ "cl-mediawiki-test" ]; - lispLibs = [ (getAttr "cl-mediawiki" self) (getAttr "lisp-unit2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-megolm = (build-asdf-system { - pname = "cl-megolm"; - version = "20230214-git"; - asds = [ "cl-megolm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-megolm/2023-02-14/cl-megolm-20230214-git.tgz"; - sha256 = "1n80v63pw2ck419fglgdhhqnc06jmams6mnxb8sqdg966qxhql2k"; - system = "cl-megolm"; - asd = "cl-megolm"; - }); - systems = [ "cl-megolm" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "claw-olm" self) (getAttr "ironclad" self) (getAttr "jonathan" self) (getAttr "lisp-unit" self) (getAttr "s-base64" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-memcached = (build-asdf-system { - pname = "cl-memcached"; - version = "20150608-git"; - asds = [ "cl-memcached" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-memcached/2015-06-08/cl-memcached-20150608-git.tgz"; - sha256 = "0g66m0yiazzh0447qbmgxjn4kxjcx9bk2l8cimyzmriz5d0j2q3i"; - system = "cl-memcached"; - asd = "cl-memcached"; - }); - systems = [ "cl-memcached" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "pooler" self) (getAttr "split-sequence" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-messagepack = (build-asdf-system { - pname = "cl-messagepack"; - version = "20231021-git"; - asds = [ "cl-messagepack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-messagepack/2023-10-21/cl-messagepack-20231021-git.tgz"; - sha256 = "1hjd1q18lz46k46afz94ljflp76mfr30d6z4jrsgd26y2lc4gchc"; - system = "cl-messagepack"; - asd = "cl-messagepack"; - }); - systems = [ "cl-messagepack" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "closer-mop" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-messagepack-rpc = (build-asdf-system { - pname = "cl-messagepack-rpc"; - version = "20171227-git"; - asds = [ "cl-messagepack-rpc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-messagepack-rpc/2017-12-27/cl-messagepack-rpc-20171227-git.tgz"; - sha256 = "02nrnhav28v5vwig9mmmmax59nl0sbjkmdzwakzpj6y1gafiqgy9"; - system = "cl-messagepack-rpc"; - asd = "cl-messagepack-rpc"; - }); - systems = [ "cl-messagepack-rpc" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-async" self) (getAttr "cl-libuv" self) (getAttr "cl-messagepack" self) (getAttr "flexi-streams" self) (getAttr "trivial-backtrace" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-messagepack-rpc-tests = (build-asdf-system { - pname = "cl-messagepack-rpc-tests"; - version = "20171227-git"; - asds = [ "cl-messagepack-rpc-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-messagepack-rpc/2017-12-27/cl-messagepack-rpc-20171227-git.tgz"; - sha256 = "02nrnhav28v5vwig9mmmmax59nl0sbjkmdzwakzpj6y1gafiqgy9"; - system = "cl-messagepack-rpc-tests"; - asd = "cl-messagepack-rpc-tests"; - }); - systems = [ "cl-messagepack-rpc-tests" ]; - lispLibs = [ (getAttr "cl-messagepack-rpc" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-messagepack-tests = (build-asdf-system { - pname = "cl-messagepack-tests"; - version = "20231021-git"; - asds = [ "cl-messagepack-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-messagepack/2023-10-21/cl-messagepack-20231021-git.tgz"; - sha256 = "1hjd1q18lz46k46afz94ljflp76mfr30d6z4jrsgd26y2lc4gchc"; - system = "cl-messagepack-tests"; - asd = "cl-messagepack-tests"; - }); - systems = [ "cl-messagepack-tests" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "cl-messagepack" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-migrations = (build-asdf-system { - pname = "cl-migrations"; - version = "20110110-http"; - asds = [ "cl-migrations" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-migrations/2011-01-10/cl-migrations-20110110-http.tgz"; - sha256 = "0mq3ir1kffw921q5a878964ghnrhcrh79p6yxsrb25bzkwpnfx02"; - system = "cl-migrations"; - asd = "cl-migrations"; - }); - systems = [ "cl-migrations" ]; - lispLibs = [ (getAttr "clsql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-migratum = (build-asdf-system { - pname = "cl-migratum"; - version = "20241012-git"; - asds = [ "cl-migratum" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; - sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; - system = "cl-migratum"; - asd = "cl-migratum"; - }); - systems = [ "cl-migratum" ]; - lispLibs = [ (getAttr "cl-ascii-table" self) (getAttr "cl-reexport" self) (getAttr "local-time" self) (getAttr "log4cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-migratum_dot_cli = (build-asdf-system { - pname = "cl-migratum.cli"; - version = "20241012-git"; - asds = [ "cl-migratum.cli" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; - sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; - system = "cl-migratum.cli"; - asd = "cl-migratum.cli"; - }); - systems = [ "cl-migratum.cli" ]; - lispLibs = [ (getAttr "cl-migratum" self) (getAttr "cl-migratum_dot_driver_dot_dbi" self) (getAttr "cl-migratum_dot_driver_dot_rdbms-postgresql" self) (getAttr "cl-migratum_dot_provider_dot_local-path" self) (getAttr "clingon" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-migratum_dot_driver_dot_dbi = (build-asdf-system { - pname = "cl-migratum.driver.dbi"; - version = "20241012-git"; - asds = [ "cl-migratum.driver.dbi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; - sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; - system = "cl-migratum.driver.dbi"; - asd = "cl-migratum.driver.dbi"; - }); - systems = [ "cl-migratum.driver.dbi" ]; - lispLibs = [ (getAttr "cl-dbi" self) (getAttr "cl-migratum" self) (getAttr "cl-migratum_dot_driver_dot_mixins" self) (getAttr "cl-ppcre" self) (getAttr "log4cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-migratum_dot_driver_dot_mixins = (build-asdf-system { - pname = "cl-migratum.driver.mixins"; - version = "20241012-git"; - asds = [ "cl-migratum.driver.mixins" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; - sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; - system = "cl-migratum.driver.mixins"; - asd = "cl-migratum.driver.mixins"; - }); - systems = [ "cl-migratum.driver.mixins" ]; - lispLibs = [ (getAttr "cl-migratum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-migratum_dot_driver_dot_postmodern-postgresql = (build-asdf-system { - pname = "cl-migratum.driver.postmodern-postgresql"; - version = "20241012-git"; - asds = [ "cl-migratum.driver.postmodern-postgresql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; - sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; - system = "cl-migratum.driver.postmodern-postgresql"; - asd = "cl-migratum.driver.postmodern-postgresql"; - }); - systems = [ "cl-migratum.driver.postmodern-postgresql" ]; - lispLibs = [ (getAttr "cl-migratum" self) (getAttr "cl-migratum_dot_driver_dot_mixins" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "log4cl" self) (getAttr "postmodern" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-migratum_dot_driver_dot_rdbms-postgresql = (build-asdf-system { - pname = "cl-migratum.driver.rdbms-postgresql"; - version = "20241012-git"; - asds = [ "cl-migratum.driver.rdbms-postgresql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; - sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; - system = "cl-migratum.driver.rdbms-postgresql"; - asd = "cl-migratum.driver.rdbms-postgresql"; - }); - systems = [ "cl-migratum.driver.rdbms-postgresql" ]; - lispLibs = [ (getAttr "cl-migratum" self) (getAttr "cl-migratum_dot_driver_dot_mixins" self) (getAttr "cl-ppcre" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_postgresql" self) (getAttr "log4cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-migratum_dot_provider_dot_local-path = (build-asdf-system { - pname = "cl-migratum.provider.local-path"; - version = "20241012-git"; - asds = [ "cl-migratum.provider.local-path" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; - sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; - system = "cl-migratum.provider.local-path"; - asd = "cl-migratum.provider.local-path"; - }); - systems = [ "cl-migratum.provider.local-path" ]; - lispLibs = [ (getAttr "cl-migratum" self) (getAttr "cl-ppcre" self) (getAttr "log4cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-migratum_dot_test = (build-asdf-system { - pname = "cl-migratum.test"; - version = "20241012-git"; - asds = [ "cl-migratum.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; - sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; - system = "cl-migratum.test"; - asd = "cl-migratum.test"; - }); - systems = [ "cl-migratum.test" ]; - lispLibs = [ (getAttr "cl-migratum" self) (getAttr "cl-migratum_dot_driver_dot_dbi" self) (getAttr "cl-migratum_dot_driver_dot_postmodern-postgresql" self) (getAttr "cl-migratum_dot_driver_dot_rdbms-postgresql" self) (getAttr "cl-migratum_dot_provider_dot_local-path" self) (getAttr "dbd-sqlite3" self) (getAttr "rove" self) (getAttr "tmpdir" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mime = (build-asdf-system { - pname = "cl-mime"; - version = "20201220-git"; - asds = [ "cl-mime" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mime/2020-12-20/cl-mime-20201220-git.tgz"; - sha256 = "0i2vyc1d4qp36f3c3qfpx9rkp3d2ka80r40wc9lsvhqn1hjxa2gv"; - system = "cl-mime"; - asd = "cl-mime"; - }); - systems = [ "cl-mime" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "cl-ppcre" self) (getAttr "cl-qprint" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mime-from-string = (build-asdf-system { - pname = "cl-mime-from-string"; - version = "20200427-git"; - asds = [ "cl-mime-from-string" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mime-from-string/2020-04-27/cl-mime-from-string-20200427-git.tgz"; - sha256 = "1pzhfbv6j3b0vvf4rxxd56v54lh6v7cs16nq2d64cawn6qzmk4bp"; - system = "cl-mime-from-string"; - asd = "cl-mime-from-string"; - }); - systems = [ "cl-mime-from-string" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mime-test = (build-asdf-system { - pname = "cl-mime-test"; - version = "20201220-git"; - asds = [ "cl-mime-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mime/2020-12-20/cl-mime-20201220-git.tgz"; - sha256 = "0i2vyc1d4qp36f3c3qfpx9rkp3d2ka80r40wc9lsvhqn1hjxa2gv"; - system = "cl-mime-test"; - asd = "cl-mime-test"; - }); - systems = [ "cl-mime-test" ]; - lispLibs = [ (getAttr "cl-mime" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mimeparse = (build-asdf-system { - pname = "cl-mimeparse"; - version = "20210531-git"; - asds = [ "cl-mimeparse" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mimeparse/2021-05-31/cl-mimeparse-20210531-git.tgz"; - sha256 = "0gdkpi3620va0a3q56svcn1q9f5w0pqfhx30lnldg8fjnrdfiwkk"; - system = "cl-mimeparse"; - asd = "cl-mimeparse"; - }); - systems = [ "cl-mimeparse" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mimeparse-tests = (build-asdf-system { - pname = "cl-mimeparse-tests"; - version = "20210531-git"; - asds = [ "cl-mimeparse-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mimeparse/2021-05-31/cl-mimeparse-20210531-git.tgz"; - sha256 = "0gdkpi3620va0a3q56svcn1q9f5w0pqfhx30lnldg8fjnrdfiwkk"; - system = "cl-mimeparse-tests"; - asd = "cl-mimeparse-tests"; - }); - systems = [ "cl-mimeparse-tests" ]; - lispLibs = [ (getAttr "cl-mimeparse" self) (getAttr "rt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-minify-css = (build-asdf-system { - pname = "cl-minify-css"; - version = "20200925-git"; - asds = [ "cl-minify-css" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-minify-css/2020-09-25/cl-minify-css-20200925-git.tgz"; - sha256 = "1wj1mh7qzr8ybqyx7kxnpsmj3d9lylnzmq1qmycdyf2llqkcdxgd"; - system = "cl-minify-css"; - asd = "cl-minify-css"; - }); - systems = [ "cl-minify-css" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-minify-css-test = (build-asdf-system { - pname = "cl-minify-css-test"; - version = "20200925-git"; - asds = [ "cl-minify-css-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-minify-css/2020-09-25/cl-minify-css-20200925-git.tgz"; - sha256 = "1wj1mh7qzr8ybqyx7kxnpsmj3d9lylnzmq1qmycdyf2llqkcdxgd"; - system = "cl-minify-css-test"; - asd = "cl-minify-css-test"; - }); - systems = [ "cl-minify-css-test" ]; - lispLibs = [ (getAttr "assert-p" self) (getAttr "cacau" self) (getAttr "cacau-asdf" self) (getAttr "cl-minify-css" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed = (build-asdf-system { - pname = "cl-mixed"; - version = "20241012-git"; - asds = [ "cl-mixed" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed"; - asd = "cl-mixed"; - }); - systems = [ "cl-mixed" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "static-vectors" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-aaudio = (build-asdf-system { - pname = "cl-mixed-aaudio"; - version = "20241012-git"; - asds = [ "cl-mixed-aaudio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-aaudio"; - asd = "cl-mixed-aaudio"; - }); - systems = [ "cl-mixed-aaudio" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-mixed" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-alsa = (build-asdf-system { - pname = "cl-mixed-alsa"; - version = "20241012-git"; - asds = [ "cl-mixed-alsa" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-alsa"; - asd = "cl-mixed-alsa"; - }); - systems = [ "cl-mixed-alsa" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-mixed" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-coreaudio = (build-asdf-system { - pname = "cl-mixed-coreaudio"; - version = "20241012-git"; - asds = [ "cl-mixed-coreaudio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-coreaudio"; - asd = "cl-mixed-coreaudio"; - }); - systems = [ "cl-mixed-coreaudio" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cl-mixed" self) (getAttr "float-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-examples = (build-asdf-system { - pname = "cl-mixed-examples"; - version = "20241012-git"; - asds = [ "cl-mixed-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-examples"; - asd = "cl-mixed-examples"; - }); - systems = [ "cl-mixed-examples" ]; - lispLibs = [ (getAttr "cl-mixed" self) (getAttr "cl-mixed-mpg123" self) (getAttr "cl-mixed-out123" self) (getAttr "cl-mixed-pulse" self) (getAttr "cl-mixed-wav" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-flac = (build-asdf-system { - pname = "cl-mixed-flac"; - version = "20241012-git"; - asds = [ "cl-mixed-flac" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-flac"; - asd = "cl-mixed-flac"; - }); - systems = [ "cl-mixed-flac" ]; - lispLibs = [ (getAttr "cl-flac" self) (getAttr "cl-mixed" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-jack = (build-asdf-system { - pname = "cl-mixed-jack"; - version = "20241012-git"; - asds = [ "cl-mixed-jack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-jack"; - asd = "cl-mixed-jack"; - }); - systems = [ "cl-mixed-jack" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-mixed" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-mpg123 = (build-asdf-system { - pname = "cl-mixed-mpg123"; - version = "20241012-git"; - asds = [ "cl-mixed-mpg123" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-mpg123"; - asd = "cl-mixed-mpg123"; - }); - systems = [ "cl-mixed-mpg123" ]; - lispLibs = [ (getAttr "cl-mixed" self) (getAttr "cl-mpg123" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-mpt = (build-asdf-system { - pname = "cl-mixed-mpt"; - version = "20241012-git"; - asds = [ "cl-mixed-mpt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-mpt"; - asd = "cl-mixed-mpt"; - }); - systems = [ "cl-mixed-mpt" ]; - lispLibs = [ (getAttr "cl-mixed" self) (getAttr "static-vectors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-nxau = (build-asdf-system { - pname = "cl-mixed-nxau"; - version = "20241012-git"; - asds = [ "cl-mixed-nxau" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-nxau"; - asd = "cl-mixed-nxau"; - }); - systems = [ "cl-mixed-nxau" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-mixed" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-opus = (build-asdf-system { - pname = "cl-mixed-opus"; - version = "20241012-git"; - asds = [ "cl-mixed-opus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-opus"; - asd = "cl-mixed-opus"; - }); - systems = [ "cl-mixed-opus" ]; - lispLibs = [ (getAttr "cl-mixed" self) (getAttr "cl-opus" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-oss = (build-asdf-system { - pname = "cl-mixed-oss"; - version = "20241012-git"; - asds = [ "cl-mixed-oss" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-oss"; - asd = "cl-mixed-oss"; - }); - systems = [ "cl-mixed-oss" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-mixed" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-out123 = (build-asdf-system { - pname = "cl-mixed-out123"; - version = "20241012-git"; - asds = [ "cl-mixed-out123" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-out123"; - asd = "cl-mixed-out123"; - }); - systems = [ "cl-mixed-out123" ]; - lispLibs = [ (getAttr "cl-mixed" self) (getAttr "cl-out123" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-pulse = (build-asdf-system { - pname = "cl-mixed-pulse"; - version = "20241012-git"; - asds = [ "cl-mixed-pulse" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-pulse"; - asd = "cl-mixed-pulse"; - }); - systems = [ "cl-mixed-pulse" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-mixed" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-qoa = (build-asdf-system { - pname = "cl-mixed-qoa"; - version = "20241012-git"; - asds = [ "cl-mixed-qoa" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-qoa"; - asd = "cl-mixed-qoa"; - }); - systems = [ "cl-mixed-qoa" ]; - lispLibs = [ (getAttr "cl-mixed" self) (getAttr "cl-qoa" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-sdl2 = (build-asdf-system { - pname = "cl-mixed-sdl2"; - version = "20241012-git"; - asds = [ "cl-mixed-sdl2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-sdl2"; - asd = "cl-mixed-sdl2"; - }); - systems = [ "cl-mixed-sdl2" ]; - lispLibs = [ (getAttr "cl-mixed" self) (getAttr "sdl2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-vorbis = (build-asdf-system { - pname = "cl-mixed-vorbis"; - version = "20241012-git"; - asds = [ "cl-mixed-vorbis" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-vorbis"; - asd = "cl-mixed-vorbis"; - }); - systems = [ "cl-mixed-vorbis" ]; - lispLibs = [ (getAttr "cl-mixed" self) (getAttr "cl-vorbis" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-wasapi = (build-asdf-system { - pname = "cl-mixed-wasapi"; - version = "20241012-git"; - asds = [ "cl-mixed-wasapi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-wasapi"; - asd = "cl-mixed-wasapi"; - }); - systems = [ "cl-mixed-wasapi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-mixed" self) (getAttr "com-on" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-wav = (build-asdf-system { - pname = "cl-mixed-wav"; - version = "20241012-git"; - asds = [ "cl-mixed-wav" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-wav"; - asd = "cl-mixed-wav"; - }); - systems = [ "cl-mixed-wav" ]; - lispLibs = [ (getAttr "cl-mixed" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-winmm = (build-asdf-system { - pname = "cl-mixed-winmm"; - version = "20241012-git"; - asds = [ "cl-mixed-winmm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-winmm"; - asd = "cl-mixed-winmm"; - }); - systems = [ "cl-mixed-winmm" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-mixed" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mixed-xaudio2 = (build-asdf-system { - pname = "cl-mixed-xaudio2"; - version = "20241012-git"; - asds = [ "cl-mixed-xaudio2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; - sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; - system = "cl-mixed-xaudio2"; - asd = "cl-mixed-xaudio2"; - }); - systems = [ "cl-mixed-xaudio2" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-mixed" self) (getAttr "com-on" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mock = (build-asdf-system { - pname = "cl-mock"; - version = "20221106-git"; - asds = [ "cl-mock" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mock/2022-11-06/cl-mock-20221106-git.tgz"; - sha256 = "19641sm3klx9yfk8lr376rfkd26vy72yp1hkpkqcw3q3m1xrf9xp"; - system = "cl-mock"; - asd = "cl-mock"; - }); - systems = [ "cl-mock" ]; - lispLibs = [ (getAttr "cl-mock-basic" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mock-basic = (build-asdf-system { - pname = "cl-mock-basic"; - version = "20221106-git"; - asds = [ "cl-mock-basic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mock/2022-11-06/cl-mock-20221106-git.tgz"; - sha256 = "19641sm3klx9yfk8lr376rfkd26vy72yp1hkpkqcw3q3m1xrf9xp"; - system = "cl-mock-basic"; - asd = "cl-mock-basic"; - }); - systems = [ "cl-mock-basic" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mock-tests = (build-asdf-system { - pname = "cl-mock-tests"; - version = "20221106-git"; - asds = [ "cl-mock-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mock/2022-11-06/cl-mock-20221106-git.tgz"; - sha256 = "19641sm3klx9yfk8lr376rfkd26vy72yp1hkpkqcw3q3m1xrf9xp"; - system = "cl-mock-tests"; - asd = "cl-mock-tests"; - }); - systems = [ "cl-mock-tests" ]; - lispLibs = [ (getAttr "cl-mock" self) (getAttr "cl-mock-tests-basic" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mock-tests-basic = (build-asdf-system { - pname = "cl-mock-tests-basic"; - version = "20221106-git"; - asds = [ "cl-mock-tests-basic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mock/2022-11-06/cl-mock-20221106-git.tgz"; - sha256 = "19641sm3klx9yfk8lr376rfkd26vy72yp1hkpkqcw3q3m1xrf9xp"; - system = "cl-mock-tests-basic"; - asd = "cl-mock-tests-basic"; - }); - systems = [ "cl-mock-tests-basic" ]; - lispLibs = [ (getAttr "cl-mock-basic" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-modio = (build-asdf-system { - pname = "cl-modio"; - version = "20241012-git"; - asds = [ "cl-modio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-modio/2024-10-12/cl-modio-20241012-git.tgz"; - sha256 = "1f755xqpibdrxiqclnsiba36bl8xgw958h0lb0rw6hjsvrx9z8dg"; - system = "cl-modio"; - asd = "cl-modio"; - }); - systems = [ "cl-modio" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "com_dot_inuoe_dot_jzon" self) (getAttr "documentation-utils" self) (getAttr "drakma" self) (getAttr "language-codes" self) (getAttr "zippy" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-monad-macros = (build-asdf-system { - pname = "cl-monad-macros"; - version = "20110619-svn"; - asds = [ "cl-monad-macros" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-monad-macros/2011-06-19/cl-monad-macros-20110619-svn.tgz"; - sha256 = "184p018xb07yd04bpscrwrnwv1cdxh9hxggmrnj95lhlr6r97l1z"; - system = "cl-monad-macros"; - asd = "cl-monad-macros"; - }); - systems = [ "cl-monad-macros" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-moneris = (build-asdf-system { - pname = "cl-moneris"; - version = "20231021-git"; - asds = [ "cl-moneris" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-moneris/2023-10-21/cl-moneris-20231021-git.tgz"; - sha256 = "1ajxqdgqy7cnkq6qz18xayw5z1idz3slzj7nc7pcv4ha7h3ak63k"; - system = "cl-moneris"; - asd = "cl-moneris"; - }); - systems = [ "cl-moneris" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "s-xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-moneris-test = (build-asdf-system { - pname = "cl-moneris-test"; - version = "20231021-git"; - asds = [ "cl-moneris-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-moneris/2023-10-21/cl-moneris-20231021-git.tgz"; - sha256 = "1ajxqdgqy7cnkq6qz18xayw5z1idz3slzj7nc7pcv4ha7h3ak63k"; - system = "cl-moneris-test"; - asd = "cl-moneris-test"; - }); - systems = [ "cl-moneris-test" ]; - lispLibs = [ (getAttr "cl-moneris" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mongo = (build-asdf-system { - pname = "cl-mongo"; - version = "20160531-git"; - asds = [ "cl-mongo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mongo/2016-05-31/cl-mongo-20160531-git.tgz"; - sha256 = "1l3kydbxbxhs1z76v6qpwjnabv8wf0mff1pfjkrpjfz6bia1svx6"; - system = "cl-mongo"; - asd = "cl-mongo"; - }); - systems = [ "cl-mongo" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "documentation-template" self) (getAttr "lisp-unit" self) (getAttr "parenscript" self) (getAttr "split-sequence" self) (getAttr "usocket" self) (getAttr "uuid" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mongo-id = (build-asdf-system { - pname = "cl-mongo-id"; - version = "20201220-git"; - asds = [ "cl-mongo-id" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mongo-id/2020-12-20/cl-mongo-id-20201220-git.tgz"; - sha256 = "1bpwmh5970rpr6ayygcgdg96hq2dlrksgpa1vdmy5l6vdbw9xrys"; - system = "cl-mongo-id"; - asd = "cl-mongo-id"; - }); - systems = [ "cl-mongo-id" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "local-time" self) (getAttr "md5" self) (getAttr "secure-random" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-monitors = (build-asdf-system { - pname = "cl-monitors"; - version = "20231021-git"; - asds = [ "cl-monitors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-monitors/2023-10-21/cl-monitors-20231021-git.tgz"; - sha256 = "09ddgs7sbqjx91bajpk5qf6716vnx63mfg9yw0biw16mnfjhrg4i"; - system = "cl-monitors"; - asd = "cl-monitors"; - }); - systems = [ "cl-monitors" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mop = (build-asdf-system { - pname = "cl-mop"; - version = "20150113-git"; - asds = [ "cl-mop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mop/2015-01-13/cl-mop-20150113-git.tgz"; - sha256 = "0wqjbp6jr868a89hklf1ppxkdfbznafrdpriakqiraicvr9kvksg"; - system = "cl-mop"; - asd = "cl-mop"; - }); - systems = [ "cl-mop" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-morse = (build-asdf-system { - pname = "cl-morse"; - version = "v1.0.0"; - asds = [ "cl-morse" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-morse/2022-07-07/cl-morse-v1.0.0.tgz"; - sha256 = "01sh34nhbsx2dsrb2r1vkd4j8lzm9gjd5jfi8a4cs4m3djjwhh5i"; - system = "cl-morse"; - asd = "cl-morse"; - }); - systems = [ "cl-morse" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-moss = (build-asdf-system { - pname = "cl-moss"; - version = "20171019-git"; - asds = [ "cl-moss" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-moss/2017-10-19/cl-moss-20171019-git.tgz"; - sha256 = "1qxzppnyxc8lkhfbbp5m3dbhp4rfkyc2lfrry2448i5w5icrigzd"; - system = "cl-moss"; - asd = "cl-moss"; - }); - systems = [ "cl-moss" ]; - lispLibs = [ (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mount-info = (build-asdf-system { - pname = "cl-mount-info"; - version = "20241012-git"; - asds = [ "cl-mount-info" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mount-info/2024-10-12/cl-mount-info-20241012-git.tgz"; - sha256 = "0i5vpr0s27gqrskl5qkbw23ba00abbmsskgvg2zhpdljg5qiwlcw"; - system = "cl-mount-info"; - asd = "cl-mount-info"; - }); - systems = [ "cl-mount-info" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mpg123 = (build-asdf-system { - pname = "cl-mpg123"; - version = "20241012-git"; - asds = [ "cl-mpg123" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mpg123/2024-10-12/cl-mpg123-20241012-git.tgz"; - sha256 = "03ysv3psfj4agf62gn1skc26qzd9g9zx6yjxxs9lrjz7g9kwf1xk"; - system = "cl-mpg123"; - asd = "cl-mpg123"; - }); - systems = [ "cl-mpg123" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mpg123-example = (build-asdf-system { - pname = "cl-mpg123-example"; - version = "20241012-git"; - asds = [ "cl-mpg123-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mpg123/2024-10-12/cl-mpg123-20241012-git.tgz"; - sha256 = "03ysv3psfj4agf62gn1skc26qzd9g9zx6yjxxs9lrjz7g9kwf1xk"; - system = "cl-mpg123-example"; - asd = "cl-mpg123-example"; - }); - systems = [ "cl-mpg123-example" ]; - lispLibs = [ (getAttr "cl-mpg123" self) (getAttr "cl-out123" self) (getAttr "verbose" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mpi = (build-asdf-system { - pname = "cl-mpi"; - version = "20190710-git"; - asds = [ "cl-mpi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mpi/2019-07-10/cl-mpi-20190710-git.tgz"; - sha256 = "1ykwk7acjhzpsjgm2b5svdpyw2qgrh860gkx3n2ckyrgd9l9q6jb"; - system = "cl-mpi"; - asd = "cl-mpi"; - }); - systems = [ "cl-mpi" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-mpi-asdf-integration" self) (getAttr "static-vectors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mpi-asdf-integration = (build-asdf-system { - pname = "cl-mpi-asdf-integration"; - version = "20190710-git"; - asds = [ "cl-mpi-asdf-integration" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mpi/2019-07-10/cl-mpi-20190710-git.tgz"; - sha256 = "1ykwk7acjhzpsjgm2b5svdpyw2qgrh860gkx3n2ckyrgd9l9q6jb"; - system = "cl-mpi-asdf-integration"; - asd = "cl-mpi-asdf-integration"; - }); - systems = [ "cl-mpi-asdf-integration" ]; - lispLibs = [ (getAttr "cffi-grovel" self) (getAttr "cffi-toolchain" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mpi-examples = (build-asdf-system { - pname = "cl-mpi-examples"; - version = "20190710-git"; - asds = [ "cl-mpi-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mpi/2019-07-10/cl-mpi-20190710-git.tgz"; - sha256 = "1ykwk7acjhzpsjgm2b5svdpyw2qgrh860gkx3n2ckyrgd9l9q6jb"; - system = "cl-mpi-examples"; - asd = "cl-mpi-examples"; - }); - systems = [ "cl-mpi-examples" ]; - lispLibs = [ (getAttr "cl-mpi" self) (getAttr "cl-mpi-asdf-integration" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mpi-extensions = (build-asdf-system { - pname = "cl-mpi-extensions"; - version = "20190710-git"; - asds = [ "cl-mpi-extensions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mpi/2019-07-10/cl-mpi-20190710-git.tgz"; - sha256 = "1ykwk7acjhzpsjgm2b5svdpyw2qgrh860gkx3n2ckyrgd9l9q6jb"; - system = "cl-mpi-extensions"; - asd = "cl-mpi-extensions"; - }); - systems = [ "cl-mpi-extensions" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-conspack" self) (getAttr "cl-mpi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mpi-test-suite = (build-asdf-system { - pname = "cl-mpi-test-suite"; - version = "20190710-git"; - asds = [ "cl-mpi-test-suite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mpi/2019-07-10/cl-mpi-20190710-git.tgz"; - sha256 = "1ykwk7acjhzpsjgm2b5svdpyw2qgrh860gkx3n2ckyrgd9l9q6jb"; - system = "cl-mpi-test-suite"; - asd = "cl-mpi-test-suite"; - }); - systems = [ "cl-mpi-test-suite" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-mpi" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mtgnet = (build-asdf-system { - pname = "cl-mtgnet"; - version = "20180711-git"; - asds = [ "cl-mtgnet" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mtgnet/2018-07-11/cl-mtgnet-20180711-git.tgz"; - sha256 = "08mwkfa9s51is6npn7al4rn5a65ip2bq0psb1pdvh111h5zqxdrb"; - system = "cl-mtgnet"; - asd = "cl-mtgnet"; - }); - systems = [ "cl-mtgnet" ]; - lispLibs = [ (getAttr "blackbird" self) (getAttr "cl-json" self) (getAttr "cl-netstring_plus" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mtgnet-async = (build-asdf-system { - pname = "cl-mtgnet-async"; - version = "20180711-git"; - asds = [ "cl-mtgnet-async" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mtgnet/2018-07-11/cl-mtgnet-20180711-git.tgz"; - sha256 = "08mwkfa9s51is6npn7al4rn5a65ip2bq0psb1pdvh111h5zqxdrb"; - system = "cl-mtgnet-async"; - asd = "cl-mtgnet-async"; - }); - systems = [ "cl-mtgnet-async" ]; - lispLibs = [ (getAttr "cl-async" self) (getAttr "cl-mtgnet" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mtgnet-sync = (build-asdf-system { - pname = "cl-mtgnet-sync"; - version = "20180711-git"; - asds = [ "cl-mtgnet-sync" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mtgnet/2018-07-11/cl-mtgnet-20180711-git.tgz"; - sha256 = "08mwkfa9s51is6npn7al4rn5a65ip2bq0psb1pdvh111h5zqxdrb"; - system = "cl-mtgnet-sync"; - asd = "cl-mtgnet-sync"; - }); - systems = [ "cl-mtgnet-sync" ]; - lispLibs = [ (getAttr "cl-mtgnet" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-murmurhash = (build-asdf-system { - pname = "cl-murmurhash"; - version = "20210630-git"; - asds = [ "cl-murmurhash" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-murmurhash/2021-06-30/cl-murmurhash-20210630-git.tgz"; - sha256 = "0251r0mpjm0y3qsm4lm7ncvrkxvgwc53spdm1p2mpayhvkkqqsws"; - system = "cl-murmurhash"; - asd = "cl-murmurhash"; - }); - systems = [ "cl-murmurhash" ]; - lispLibs = [ (getAttr "babel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mustache = (build-asdf-system { - pname = "cl-mustache"; - version = "20241012-git"; - asds = [ "cl-mustache" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mustache/2024-10-12/cl-mustache-20241012-git.tgz"; - sha256 = "0isdrz1dgjvmfqvsgs2pmrran41w9n6f44r9fpdhdkjxa5zvy46b"; - system = "cl-mustache"; - asd = "cl-mustache"; - }); - systems = [ "cl-mustache" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-mustache-test = (build-asdf-system { - pname = "cl-mustache-test"; - version = "20241012-git"; - asds = [ "cl-mustache-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mustache/2024-10-12/cl-mustache-20241012-git.tgz"; - sha256 = "0isdrz1dgjvmfqvsgs2pmrran41w9n6f44r9fpdhdkjxa5zvy46b"; - system = "cl-mustache-test"; - asd = "cl-mustache-test"; - }); - systems = [ "cl-mustache-test" ]; - lispLibs = [ (getAttr "cl-mustache" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-muth = (build-asdf-system { - pname = "cl-muth"; - version = "stable-git"; - asds = [ "cl-muth" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-muth/2022-07-07/cl-muth-stable-git.tgz"; - sha256 = "0409arzy51chgi9anj9s2zn0qkx9wnphlbwcdvpamr4b51b60xjz"; - system = "cl-muth"; - asd = "cl-muth"; - }); - systems = [ "cl-muth" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bodge-heap" self) (getAttr "bodge-queue" self) (getAttr "bordeaux-threads" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mw = (build-asdf-system { - pname = "cl-mw"; - version = "20150407-git"; - asds = [ "cl-mw" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; - sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; - system = "cl-mw"; - asd = "cl-mw"; - }); - systems = [ "cl-mw" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-ppcre" self) (getAttr "hu_dot_dwim_dot_serializer" self) (getAttr "iolib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mw_dot_examples_dot_argument-processing = (build-asdf-system { - pname = "cl-mw.examples.argument-processing"; - version = "20150407-git"; - asds = [ "cl-mw.examples.argument-processing" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; - sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; - system = "cl-mw.examples.argument-processing"; - asd = "cl-mw.examples.argument-processing"; - }); - systems = [ "cl-mw.examples.argument-processing" ]; - lispLibs = [ (getAttr "cl-mw" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mw_dot_examples_dot_hello-world = (build-asdf-system { - pname = "cl-mw.examples.hello-world"; - version = "20150407-git"; - asds = [ "cl-mw.examples.hello-world" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; - sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; - system = "cl-mw.examples.hello-world"; - asd = "cl-mw.examples.hello-world"; - }); - systems = [ "cl-mw.examples.hello-world" ]; - lispLibs = [ (getAttr "cl-mw" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mw_dot_examples_dot_higher-order = (build-asdf-system { - pname = "cl-mw.examples.higher-order"; - version = "20150407-git"; - asds = [ "cl-mw.examples.higher-order" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; - sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; - system = "cl-mw.examples.higher-order"; - asd = "cl-mw.examples.higher-order"; - }); - systems = [ "cl-mw.examples.higher-order" ]; - lispLibs = [ (getAttr "cl-mw" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mw_dot_examples_dot_monte-carlo-pi = (build-asdf-system { - pname = "cl-mw.examples.monte-carlo-pi"; - version = "20150407-git"; - asds = [ "cl-mw.examples.monte-carlo-pi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; - sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; - system = "cl-mw.examples.monte-carlo-pi"; - asd = "cl-mw.examples.monte-carlo-pi"; - }); - systems = [ "cl-mw.examples.monte-carlo-pi" ]; - lispLibs = [ (getAttr "cl-mw" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mw_dot_examples_dot_ping = (build-asdf-system { - pname = "cl-mw.examples.ping"; - version = "20150407-git"; - asds = [ "cl-mw.examples.ping" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; - sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; - system = "cl-mw.examples.ping"; - asd = "cl-mw.examples.ping"; - }); - systems = [ "cl-mw.examples.ping" ]; - lispLibs = [ (getAttr "cl-mw" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mw_dot_examples_dot_with-task-policy = (build-asdf-system { - pname = "cl-mw.examples.with-task-policy"; - version = "20150407-git"; - asds = [ "cl-mw.examples.with-task-policy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; - sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; - system = "cl-mw.examples.with-task-policy"; - asd = "cl-mw.examples.with-task-policy"; - }); - systems = [ "cl-mw.examples.with-task-policy" ]; - lispLibs = [ (getAttr "cl-mw" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-myriam = (build-asdf-system { - pname = "cl-myriam"; - version = "20220331-git"; - asds = [ "cl-myriam" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-myriam/2022-03-31/cl-myriam-20220331-git.tgz"; - sha256 = "0vyyyy6yj62id5m1a98rbq3pz7hm74znnawxh4apqhrff37xcs1l"; - system = "cl-myriam"; - asd = "cl-myriam"; - }); - systems = [ "cl-myriam" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "cl-conspack" self) (getAttr "cl-ppcre" self) (getAttr "lparallel" self) (getAttr "pzmq" self) (getAttr "serapeum" self) (getAttr "sha3" self) (getAttr "str" self) (getAttr "usocket" self) (getAttr "uuid" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-mysql = (build-asdf-system { - pname = "cl-mysql"; - version = "20241012-git"; - asds = [ "cl-mysql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mysql/2024-10-12/cl-mysql-20241012-git.tgz"; - sha256 = "0ibxfjnvcgpibsfqjx2d3dcjcabiw6dj43vmr76b55fc4qlkjvz5"; - system = "cl-mysql"; - asd = "cl-mysql"; - }); - systems = [ "cl-mysql" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = {}; - }); - cl-mysql-test = (build-asdf-system { - pname = "cl-mysql-test"; - version = "20241012-git"; - asds = [ "cl-mysql-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mysql/2024-10-12/cl-mysql-20241012-git.tgz"; - sha256 = "0ibxfjnvcgpibsfqjx2d3dcjcabiw6dj43vmr76b55fc4qlkjvz5"; - system = "cl-mysql-test"; - asd = "cl-mysql-test"; - }); - systems = [ "cl-mysql-test" ]; - lispLibs = [ (getAttr "cl-mysql" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-naive-deprecation = (build-asdf-system { - pname = "cl-naive-deprecation"; - version = "20241012-git"; - asds = [ "cl-naive-deprecation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-naive-deprecation/2024-10-12/cl-naive-deprecation-20241012-git.tgz"; - sha256 = "17x6b5sr34qjfzbn2r6f5n4xa4p1qi438k792b48qiqnalkfp29m"; - system = "cl-naive-deprecation"; - asd = "cl-naive-deprecation"; - }); - systems = [ "cl-naive-deprecation" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-naive-ptrees = (build-asdf-system { - pname = "cl-naive-ptrees"; - version = "20241012-git"; - asds = [ "cl-naive-ptrees" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-naive-ptrees/2024-10-12/cl-naive-ptrees-20241012-git.tgz"; - sha256 = "10548wm3mpjxmjibidv1dd8wzcn3nn12pzwlpdd1li362v8l9n6y"; - system = "cl-naive-ptrees"; - asd = "cl-naive-ptrees"; - }); - systems = [ "cl-naive-ptrees" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-naive-ptrees_dot_tests = (build-asdf-system { - pname = "cl-naive-ptrees.tests"; - version = "20241012-git"; - asds = [ "cl-naive-ptrees.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-naive-ptrees/2024-10-12/cl-naive-ptrees-20241012-git.tgz"; - sha256 = "10548wm3mpjxmjibidv1dd8wzcn3nn12pzwlpdd1li362v8l9n6y"; - system = "cl-naive-ptrees.tests"; - asd = "cl-naive-ptrees.tests"; - }); - systems = [ "cl-naive-ptrees.tests" ]; - lispLibs = [ (getAttr "cl-naive-ptrees" self) (getAttr "cl-naive-tests" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-naive-tests = (build-asdf-system { - pname = "cl-naive-tests"; - version = "20241012-git"; - asds = [ "cl-naive-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-naive-tests/2024-10-12/cl-naive-tests-20241012-git.tgz"; - sha256 = "1b7vvl5myybx92k778p3ca5367g4m6rh5k3rpr6qp9p4amd0yy2f"; - system = "cl-naive-tests"; - asd = "cl-naive-tests"; - }); - systems = [ "cl-naive-tests" ]; - lispLibs = [ (getAttr "cl-who" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-naive-tests_dot_tests = (build-asdf-system { - pname = "cl-naive-tests.tests"; - version = "20241012-git"; - asds = [ "cl-naive-tests.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-naive-tests/2024-10-12/cl-naive-tests-20241012-git.tgz"; - sha256 = "1b7vvl5myybx92k778p3ca5367g4m6rh5k3rpr6qp9p4amd0yy2f"; - system = "cl-naive-tests.tests"; - asd = "cl-naive-tests.tests"; - }); - systems = [ "cl-naive-tests.tests" ]; - lispLibs = [ (getAttr "cl-naive-tests" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ncurses = (build-asdf-system { - pname = "cl-ncurses"; - version = "0.1.4"; - asds = [ "cl-ncurses" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ncurses/2010-10-06/cl-ncurses_0.1.4.tgz"; - sha256 = "1frcap93i4ni3d648rrbnjjpz7p4cxlv57mmzlpxpzchzbcga026"; - system = "cl-ncurses"; - asd = "cl-ncurses"; - }); - systems = [ "cl-ncurses" ]; - lispLibs = [ (getAttr "uffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-neo4j = (build-asdf-system { - pname = "cl-neo4j"; - version = "release-b8ad637a-git"; - asds = [ "cl-neo4j" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-neo4j/2013-01-28/cl-neo4j-release-b8ad637a-git.tgz"; - sha256 = "061xqjn08aqynfqygk48pwjp1d1mnhcb6fnl4lcfyw261dxsp871"; - system = "cl-neo4j"; - asd = "cl-neo4j"; - }); - systems = [ "cl-neo4j" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "babel" self) (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-neo4j_dot_tests = (build-asdf-system { - pname = "cl-neo4j.tests"; - version = "release-b8ad637a-git"; - asds = [ "cl-neo4j.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-neo4j/2013-01-28/cl-neo4j-release-b8ad637a-git.tgz"; - sha256 = "061xqjn08aqynfqygk48pwjp1d1mnhcb6fnl4lcfyw261dxsp871"; - system = "cl-neo4j.tests"; - asd = "cl-neo4j"; - }); - systems = [ "cl-neo4j.tests" ]; - lispLibs = [ (getAttr "cl-neo4j" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-neovim = (build-asdf-system { - pname = "cl-neovim"; - version = "20241012-git"; - asds = [ "cl-neovim" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-neovim/2024-10-12/cl-neovim-20241012-git.tgz"; - sha256 = "1c72qy10kmccpfl90q4c0yinmy9z9mdqniqx24269h91xd3jyagc"; - system = "cl-neovim"; - asd = "cl-neovim"; - }); - systems = [ "cl-neovim" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-messagepack-rpc" self) (getAttr "form-fiddle" self) (getAttr "split-sequence" self) (getAttr "vom" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-netpbm = (build-asdf-system { - pname = "cl-netpbm"; - version = "20241012-hg"; - asds = [ "cl-netpbm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-netpbm/2024-10-12/cl-netpbm-20241012-hg.tgz"; - sha256 = "16dv3d6x62vvc9wdvm2dc9mrm29ypzjzn2fvy46kl0h0wg7hjz92"; - system = "cl-netpbm"; - asd = "cl-netpbm"; - }); - systems = [ "cl-netpbm" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-netstring_plus = (build-asdf-system { - pname = "cl-netstring+"; - version = "20150709-git"; - asds = [ "cl-netstring+" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-netstring-plus/2015-07-09/cl-netstring-plus-20150709-git.tgz"; - sha256 = "03nxhgkab8lsx8mvavd4yny1894yxl5bllvqb12hyjdgg1v8whrr"; - system = "cl-netstring+"; - asd = "cl-netstring+"; - }); - systems = [ "cl-netstring+" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-netstrings = (build-asdf-system { - pname = "cl-netstrings"; - version = "20121013-git"; - asds = [ "cl-netstrings" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-netstrings/2012-10-13/cl-netstrings-20121013-git.tgz"; - sha256 = "1mprrb8i3fjpmw7w461ib8zrcjwx77sqwaxyqq7i8yqkbhk7p1ql"; - system = "cl-netstrings"; - asd = "cl-netstrings"; - }); - systems = [ "cl-netstrings" ]; - lispLibs = [ (getAttr "arnesi" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-notebook = (build-asdf-system { - pname = "cl-notebook"; - version = "20201220-git"; - asds = [ "cl-notebook" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-notebook/2020-12-20/cl-notebook-20201220-git.tgz"; - sha256 = "0kg5wdclz9i64gcx27z5bs739hsvjrfl9kf1awi31x4142yxrva8"; - system = "cl-notebook"; - asd = "cl-notebook"; - }); - systems = [ "cl-notebook" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cl-css" self) (getAttr "cl-fad" self) (getAttr "cl-who" self) (getAttr "closer-mop" self) (getAttr "fact-base" self) (getAttr "house" self) (getAttr "parenscript" self) (getAttr "prove-asdf" self) (getAttr "qlot" self) (getAttr "quri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ntp-client = (build-asdf-system { - pname = "cl-ntp-client"; - version = "20210630-git"; - asds = [ "cl-ntp-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ntp-client/2021-06-30/cl-ntp-client-20210630-git.tgz"; - sha256 = "1mc16bvs0l8srnxjcjg4m192rw5waq291zks2jslxmxij0pa28cm"; - system = "cl-ntp-client"; - asd = "cl-ntp-client"; - }); - systems = [ "cl-ntp-client" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ntriples = (build-asdf-system { - pname = "cl-ntriples"; - version = "20190307-hg"; - asds = [ "cl-ntriples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ntriples/2019-03-07/cl-ntriples-20190307-hg.tgz"; - sha256 = "0k8q2r2nxkgxp91398gb0iwfy9kd2mn519nxxa3zq831c433l2mq"; - system = "cl-ntriples"; - asd = "cl-ntriples"; - }); - systems = [ "cl-ntriples" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-oauth = (build-asdf-system { - pname = "cl-oauth"; - version = "20150804-git"; - asds = [ "cl-oauth" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-oauth/2015-08-04/cl-oauth-20150804-git.tgz"; - sha256 = "1q4r5i3099684q5x9wqddrm9g88qm16nnra9glvxngywfjc5zzkk"; - system = "cl-oauth"; - asd = "cl-oauth"; - }); - systems = [ "cl-oauth" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "babel" self) (getAttr "cl-base64" self) (getAttr "closer-mop" self) (getAttr "drakma" self) (getAttr "f-underscore" self) (getAttr "hunchentoot" self) (getAttr "ironclad" self) (getAttr "puri" self) (getAttr "split-sequence" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-oauth_dot_tests = (build-asdf-system { - pname = "cl-oauth.tests"; - version = "20150804-git"; - asds = [ "cl-oauth.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-oauth/2015-08-04/cl-oauth-20150804-git.tgz"; - sha256 = "1q4r5i3099684q5x9wqddrm9g88qm16nnra9glvxngywfjc5zzkk"; - system = "cl-oauth.tests"; - asd = "cl-oauth"; - }); - systems = [ "cl-oauth.tests" ]; - lispLibs = [ (getAttr "cl-oauth" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-oclapi = (build-asdf-system { - pname = "cl-oclapi"; - version = "20180831-git"; - asds = [ "cl-oclapi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-oclapi/2018-08-31/cl-oclapi-20180831-git.tgz"; - sha256 = "0aix5ipw98fsnvg1w7qmrjbwgn70gn7vf5av21xsgblp2sd7w2aw"; - system = "cl-oclapi"; - asd = "cl-oclapi"; - }); - systems = [ "cl-oclapi" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-annot" self) (getAttr "cl-reexport" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-oclapi-test = (build-asdf-system { - pname = "cl-oclapi-test"; - version = "20180831-git"; - asds = [ "cl-oclapi-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-oclapi/2018-08-31/cl-oclapi-20180831-git.tgz"; - sha256 = "0aix5ipw98fsnvg1w7qmrjbwgn70gn7vf5av21xsgblp2sd7w2aw"; - system = "cl-oclapi-test"; - asd = "cl-oclapi-test"; - }); - systems = [ "cl-oclapi-test" ]; - lispLibs = [ (getAttr "cl-annot" self) (getAttr "cl-oclapi" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-octet-streams = (build-asdf-system { - pname = "cl-octet-streams"; - version = "20201220-git"; - asds = [ "cl-octet-streams" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-octet-streams/2020-12-20/cl-octet-streams-20201220-git.tgz"; - sha256 = "1hffh98bv4w5yrchagzwqrc43d2p473pvw7ka4kyyvhrr52dk2f8"; - system = "cl-octet-streams"; - asd = "cl-octet-streams"; - }); - systems = [ "cl-octet-streams" ]; - lispLibs = [ (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ode = (build-asdf-system { - pname = "cl-ode"; - version = "20160628-git"; - asds = [ "cl-ode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ode/2016-06-28/cl-ode-20160628-git.tgz"; - sha256 = "1pxm2pq0br0rhdfnvs5jqfkxfs8bc9wdqrzwyv83l8n7pax941b0"; - system = "cl-ode"; - asd = "cl-ode"; - }); - systems = [ "cl-ode" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ohm = (build-asdf-system { - pname = "cl-ohm"; - version = "20180228-git"; - asds = [ "cl-ohm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ohm/2018-02-28/cl-ohm-20180228-git.tgz"; - sha256 = "00gdfsiba761gk7xw91wfnr9yv84maagf9idh55bk5bs4ws1ymyp"; - system = "cl-ohm"; - asd = "cl-ohm"; - }); - systems = [ "cl-ohm" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-redis" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-oju = (build-asdf-system { - pname = "cl-oju"; - version = "20241012-git"; - asds = [ "cl-oju" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-oju/2024-10-12/cl-oju-20241012-git.tgz"; - sha256 = "0gwzxl4pj45jq7vx6vssgzsp4xxc99bzfi6fbklc5nnlfkqq0v62"; - system = "cl-oju"; - asd = "cl-oju"; - }); - systems = [ "cl-oju" ]; - lispLibs = [ (getAttr "_1am" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-olefs = (build-asdf-system { - pname = "cl-olefs"; - version = "20150709-git"; - asds = [ "cl-olefs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-olefs/2015-07-09/cl-olefs-20150709-git.tgz"; - sha256 = "0cqna6zzfrjmsq17yc4wg204kr77riczqjpm1w5cj1mba43zcac7"; - system = "cl-olefs"; - asd = "cl-olefs"; - }); - systems = [ "cl-olefs" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-one-time-passwords = (build-asdf-system { - pname = "cl-one-time-passwords"; - version = "20171019-git"; - asds = [ "cl-one-time-passwords" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-one-time-passwords/2017-10-19/cl-one-time-passwords-20171019-git.tgz"; - sha256 = "1nhq2jij257cfaadh9k421qaisicxpmx3wsc4kivf1psgbrc56lg"; - system = "cl-one-time-passwords"; - asd = "cl-one-time-passwords"; - }); - systems = [ "cl-one-time-passwords" ]; - lispLibs = [ (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-one-time-passwords-test = (build-asdf-system { - pname = "cl-one-time-passwords-test"; - version = "20171019-git"; - asds = [ "cl-one-time-passwords-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-one-time-passwords/2017-10-19/cl-one-time-passwords-20171019-git.tgz"; - sha256 = "1nhq2jij257cfaadh9k421qaisicxpmx3wsc4kivf1psgbrc56lg"; - system = "cl-one-time-passwords-test"; - asd = "cl-one-time-passwords-test"; - }); - systems = [ "cl-one-time-passwords-test" ]; - lispLibs = [ (getAttr "cl-one-time-passwords" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-oneliner = (build-asdf-system { - pname = "cl-oneliner"; - version = "20131003-git"; - asds = [ "cl-oneliner" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/oneliner/2013-10-03/oneliner-20131003-git.tgz"; - sha256 = "0q9350s0r9yjmfc2360g35qi04b3867gd7hw5ada4176whinmjxb"; - system = "cl-oneliner"; - asd = "cl-oneliner"; - }); - systems = [ "cl-oneliner" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "lisp-unit" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-online-learning = (build-asdf-system { - pname = "cl-online-learning"; - version = "20220331-git"; - asds = [ "cl-online-learning" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-online-learning/2022-03-31/cl-online-learning-20220331-git.tgz"; - sha256 = "136v9kxcy53qar2j4y38awnw2idnf0lwxqwx7wgak664w3hxs6k8"; - system = "cl-online-learning"; - asd = "cl-online-learning"; - }); - systems = [ "cl-online-learning" ]; - lispLibs = [ (getAttr "cl-libsvm-format" self) (getAttr "cl-store" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-online-learning-test = (build-asdf-system { - pname = "cl-online-learning-test"; - version = "20220331-git"; - asds = [ "cl-online-learning-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-online-learning/2022-03-31/cl-online-learning-20220331-git.tgz"; - sha256 = "136v9kxcy53qar2j4y38awnw2idnf0lwxqwx7wgak664w3hxs6k8"; - system = "cl-online-learning-test"; - asd = "cl-online-learning-test"; - }); - systems = [ "cl-online-learning-test" ]; - lispLibs = [ (getAttr "cl-online-learning" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-openal = (build-asdf-system { - pname = "cl-openal"; - version = "20221106-git"; - asds = [ "cl-openal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-openal/2022-11-06/cl-openal-20221106-git.tgz"; - sha256 = "0jmp81mf23ckcm4knnh0q7zpmyls5220imaqbmnl0xvvra10b1zy"; - system = "cl-openal"; - asd = "cl-openal"; - }); - systems = [ "cl-openal" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-openal-examples = (build-asdf-system { - pname = "cl-openal-examples"; - version = "20221106-git"; - asds = [ "cl-openal-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-openal/2022-11-06/cl-openal-20221106-git.tgz"; - sha256 = "0jmp81mf23ckcm4knnh0q7zpmyls5220imaqbmnl0xvvra10b1zy"; - system = "cl-openal-examples"; - asd = "cl-openal-examples"; - }); - systems = [ "cl-openal-examples" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-alc" self) (getAttr "cl-alut" self) (getAttr "cl-openal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-opencl = (build-asdf-system { - pname = "cl-opencl"; - version = "20211209-git"; - asds = [ "cl-opencl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opencl/2021-12-09/cl-opencl-20211209-git.tgz"; - sha256 = "1agg6rg7lsbq2jgarx25bwm1nw22jpl20bzhyn4ivygcgzp2mv29"; - system = "cl-opencl"; - asd = "cl-opencl"; - }); - systems = [ "cl-opencl" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-opencl-utils = (build-asdf-system { - pname = "cl-opencl-utils"; - version = "20230214-git"; - asds = [ "cl-opencl-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opencl-utils/2023-02-14/cl-opencl-utils-20230214-git.tgz"; - sha256 = "17l4wsvhjj3zvhl5nsigh9fwnv7s7xiqfk2998gh86j32a02r95y"; - system = "cl-opencl-utils"; - asd = "cl-opencl-utils"; - }); - systems = [ "cl-opencl-utils" ]; - lispLibs = [ (getAttr "cl-opencl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-opengl = (build-asdf-system { - pname = "cl-opengl"; - version = "20241012-git"; - asds = [ "cl-opengl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opengl/2024-10-12/cl-opengl-20241012-git.tgz"; - sha256 = "1xpa3x9fx7wxrs5xmkj13yzh2wjfnlb0ihirfr9clngpv1y4gcm6"; - system = "cl-opengl"; - asd = "cl-opengl"; - }); - systems = [ "cl-opengl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "float-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-opensearch-query-builder = (build-asdf-system { - pname = "cl-opensearch-query-builder"; - version = "20241012-git"; - asds = [ "cl-opensearch-query-builder" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opensearch-query-builder/2024-10-12/cl-opensearch-query-builder-20241012-git.tgz"; - sha256 = "1pxlafahhgwyfhila0ikbpljcxgi59cqd2m6dvlib6ii90yq5dqx"; - system = "cl-opensearch-query-builder"; - asd = "cl-opensearch-query-builder"; - }); - systems = [ "cl-opensearch-query-builder" ]; - lispLibs = [ (getAttr "com_dot_inuoe_dot_jzon" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-openstack-client = (build-asdf-system { - pname = "cl-openstack-client"; - version = "20191007-git"; - asds = [ "cl-openstack-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-openstack-client/2019-10-07/cl-openstack-client-20191007-git.tgz"; - sha256 = "1sak75i82vn3acg7bxx8vjbw2y35wbq1vkh1yqhs68ksnph6d097"; - system = "cl-openstack-client"; - asd = "cl-openstack-client"; - }); - systems = [ "cl-openstack-client" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-json" self) (getAttr "drakma" self) (getAttr "local-time" self) (getAttr "uri-template" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-openstack-client-test = (build-asdf-system { - pname = "cl-openstack-client-test"; - version = "20191007-git"; - asds = [ "cl-openstack-client-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-openstack-client/2019-10-07/cl-openstack-client-20191007-git.tgz"; - sha256 = "1sak75i82vn3acg7bxx8vjbw2y35wbq1vkh1yqhs68ksnph6d097"; - system = "cl-openstack-client-test"; - asd = "cl-openstack-client-test"; - }); - systems = [ "cl-openstack-client-test" ]; - lispLibs = [ (getAttr "chunga" self) (getAttr "cl-openstack-client" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "fiveam" self) (getAttr "flexi-streams" self) (getAttr "local-time" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-opsresearch = (build-asdf-system { - pname = "cl-opsresearch"; - version = "20170403-git"; - asds = [ "cl-opsresearch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opsresearch/2017-04-03/cl-opsresearch-20170403-git.tgz"; - sha256 = "1fipw6qjggswzcg8ifwx5qnhnc7mmi53s6h14l0vzj6afa5rdpm7"; - system = "cl-opsresearch"; - asd = "cl-opsresearch"; - }); - systems = [ "cl-opsresearch" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-opus = (build-asdf-system { - pname = "cl-opus"; - version = "20241012-git"; - asds = [ "cl-opus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opus/2024-10-12/cl-opus-20241012-git.tgz"; - sha256 = "183xjlqjwildm1fb8piiic1f6l9fx4mxf9gcagpav8r60d1wmbpm"; - system = "cl-opus"; - asd = "cl-opus"; - }); - systems = [ "cl-opus" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "static-vectors" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-org-mode = (build-asdf-system { - pname = "cl-org-mode"; - version = "20101207-git"; - asds = [ "cl-org-mode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-org-mode/2010-12-07/cl-org-mode-20101207-git.tgz"; - sha256 = "1fvwl9jlbpd352b5zn2d45mabsim5xvzabwyz1h10hwv4gviymzf"; - system = "cl-org-mode"; - asd = "cl-org-mode"; - }); - systems = [ "cl-org-mode" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-out123 = (build-asdf-system { - pname = "cl-out123"; - version = "20231021-git"; - asds = [ "cl-out123" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-out123/2023-10-21/cl-out123-20231021-git.tgz"; - sha256 = "1h48hfd956799wx9kmkmb9azg01jmjbnj16b6z9ciw9y9k5jlzsh"; - system = "cl-out123"; - asd = "cl-out123"; - }); - systems = [ "cl-out123" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-pack = (build-asdf-system { - pname = "cl-pack"; - version = "20200427-git"; - asds = [ "cl-pack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pack/2020-04-27/cl-pack-20200427-git.tgz"; - sha256 = "0q7gawy0cwy49m1mxgj0jqnzzckk2ps74ncfaw1pqiqilfyx7np6"; - system = "cl-pack"; - asd = "cl-pack"; - }); - systems = [ "cl-pack" ]; - lispLibs = [ (getAttr "ieee-floats" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-pack-test = (build-asdf-system { - pname = "cl-pack-test"; - version = "20200427-git"; - asds = [ "cl-pack-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pack/2020-04-27/cl-pack-20200427-git.tgz"; - sha256 = "0q7gawy0cwy49m1mxgj0jqnzzckk2ps74ncfaw1pqiqilfyx7np6"; - system = "cl-pack-test"; - asd = "cl-pack"; - }); - systems = [ "cl-pack-test" ]; - lispLibs = [ (getAttr "cl-pack" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-package-locks = (build-asdf-system { - pname = "cl-package-locks"; - version = "20111203-git"; - asds = [ "cl-package-locks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-package-locks/2011-12-03/cl-package-locks-20111203-git.tgz"; - sha256 = "0g3gfljnvpgd66ccd2sqawlkwqx4a0wsdrg5180va61w869cgxqq"; - system = "cl-package-locks"; - asd = "cl-package-locks"; - }); - systems = [ "cl-package-locks" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-pango = (build-asdf-system { - pname = "cl-pango"; - version = "20170403-git"; - asds = [ "cl-pango" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pango/2017-04-03/cl-pango-20170403-git.tgz"; - sha256 = "0zkn4yn8nkkjr0x1vcy856cvbmnyhdidqz0in8xvd2i93jvw5w0i"; - system = "cl-pango"; - asd = "cl-pango"; - }); - systems = [ "cl-pango" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-cairo2" self) (getAttr "xmls" self) ]; - meta = {}; - }); - cl-parallel = (build-asdf-system { - pname = "cl-parallel"; - version = "20130312-git"; - asds = [ "cl-parallel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-parallel/2013-03-12/cl-parallel-20130312-git.tgz"; - sha256 = "1hmkcbwkj7rx8zg5wf2w06nvbabldpr7hbbg1ycj0fss86s2cx2c"; - system = "cl-parallel"; - asd = "cl-parallel"; - }); - systems = [ "cl-parallel" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-pass = (build-asdf-system { - pname = "cl-pass"; - version = "20201220-git"; - asds = [ "cl-pass" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pass/2020-12-20/cl-pass-20201220-git.tgz"; - sha256 = "05qx4jrkxqbqi72cxgswbpnifbdvp9mh7apc7566v522899bh0hb"; - system = "cl-pass"; - asd = "cl-pass"; - }); - systems = [ "cl-pass" ]; - lispLibs = [ (getAttr "ironclad" self) (getAttr "split-sequence" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-pass-test = (build-asdf-system { - pname = "cl-pass-test"; - version = "20201220-git"; - asds = [ "cl-pass-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pass/2020-12-20/cl-pass-20201220-git.tgz"; - sha256 = "05qx4jrkxqbqi72cxgswbpnifbdvp9mh7apc7566v522899bh0hb"; - system = "cl-pass-test"; - asd = "cl-pass-test"; - }); - systems = [ "cl-pass-test" ]; - lispLibs = [ (getAttr "cl-pass" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-paths = (build-asdf-system { - pname = "cl-paths"; - version = "20241012-git"; - asds = [ "cl-paths" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-vectors/2024-10-12/cl-vectors-20241012-git.tgz"; - sha256 = "1nkmmn38y6af10ysff3g2qkf5lb2601dcjp5rffsjh6bv2ik2jd5"; - system = "cl-paths"; - asd = "cl-paths"; - }); - systems = [ "cl-paths" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-paths-ttf = (build-asdf-system { - pname = "cl-paths-ttf"; - version = "20241012-git"; - asds = [ "cl-paths-ttf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-vectors/2024-10-12/cl-vectors-20241012-git.tgz"; - sha256 = "1nkmmn38y6af10ysff3g2qkf5lb2601dcjp5rffsjh6bv2ik2jd5"; - system = "cl-paths-ttf"; - asd = "cl-paths-ttf"; - }); - systems = [ "cl-paths-ttf" ]; - lispLibs = [ (getAttr "cl-paths" self) (getAttr "zpb-ttf" self) ]; - meta = {}; - }); - cl-pattern = (build-asdf-system { - pname = "cl-pattern"; - version = "20140713-git"; - asds = [ "cl-pattern" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pattern/2014-07-13/cl-pattern-20140713-git.tgz"; - sha256 = "0kc1yynn1ysa7bcaazhi1pq8l3hj3jq6p835kh5di7g1imrfkrny"; - system = "cl-pattern"; - asd = "cl-pattern"; - }); - systems = [ "cl-pattern" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-annot" self) (getAttr "cl-syntax" self) (getAttr "cl-syntax-annot" self) ]; - meta = {}; - }); - cl-pattern-benchmark = (build-asdf-system { - pname = "cl-pattern-benchmark"; - version = "20140713-git"; - asds = [ "cl-pattern-benchmark" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pattern/2014-07-13/cl-pattern-20140713-git.tgz"; - sha256 = "0kc1yynn1ysa7bcaazhi1pq8l3hj3jq6p835kh5di7g1imrfkrny"; - system = "cl-pattern-benchmark"; - asd = "cl-pattern-benchmark"; - }); - systems = [ "cl-pattern-benchmark" ]; - lispLibs = [ (getAttr "cl-pattern" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-patterns = (build-asdf-system { - pname = "cl-patterns"; - version = "20241012-git"; - asds = [ "cl-patterns" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-patterns/2024-10-12/cl-patterns-20241012-git.tgz"; - sha256 = "0g0q514fn1hxq518358yy2va4cb9xxqwds9cglw133qxy0wsjllh"; - system = "cl-patterns"; - asd = "cl-patterns"; - }); - systems = [ "cl-patterns" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "local-time" self) (getAttr "mutility" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-paymill = (build-asdf-system { - pname = "cl-paymill"; - version = "20131111-git"; - asds = [ "cl-paymill" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-paymill/2013-11-11/cl-paymill-20131111-git.tgz"; - sha256 = "1dhddmw7gxfxbv1vfqi6nzyh8m5n3b160ch6ianf5sn6apmi92nw"; - system = "cl-paymill"; - asd = "cl-paymill"; - }); - systems = [ "cl-paymill" ]; - lispLibs = [ (getAttr "cl_plus_ssl" self) (getAttr "drakma" self) (getAttr "st-json" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-paypal = (build-asdf-system { - pname = "cl-paypal"; - version = "20101006-git"; - asds = [ "cl-paypal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-paypal/2010-10-06/cl-paypal-20101006-git.tgz"; - sha256 = "0cc6zv17klgiyj1mbbrkbvajkr6dwsjv3iilh57vhdqd01lrhnb2"; - system = "cl-paypal"; - asd = "cl-paypal"; - }); - systems = [ "cl-paypal" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-pcg = (build-asdf-system { - pname = "cl-pcg"; - version = "20201016-hg"; - asds = [ "cl-pcg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pcg/2020-10-16/cl-pcg-20201016-hg.tgz"; - sha256 = "1w2b2y5fgjc6z8akvlmwasj90dnjv55nvb8pghq4xpv43hfy73mp"; - system = "cl-pcg"; - asd = "cl-pcg"; - }); - systems = [ "cl-pcg" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-pcg_dot_test = (build-asdf-system { - pname = "cl-pcg.test"; - version = "20201016-hg"; - asds = [ "cl-pcg.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pcg/2020-10-16/cl-pcg-20201016-hg.tgz"; - sha256 = "1w2b2y5fgjc6z8akvlmwasj90dnjv55nvb8pghq4xpv43hfy73mp"; - system = "cl-pcg.test"; - asd = "cl-pcg.test"; - }); - systems = [ "cl-pcg.test" ]; - lispLibs = [ (getAttr "_1am" self) (getAttr "cl-pcg" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-pdf = (build-asdf-system { - pname = "cl-pdf"; - version = "20231021-git"; - asds = [ "cl-pdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pdf/2023-10-21/cl-pdf-20231021-git.tgz"; - sha256 = "1x88fvk3kxi3k6a84iajb6myw67z8n3plfidq8d4c26ymiz0kvfm"; - system = "cl-pdf"; - asd = "cl-pdf"; - }); - systems = [ "cl-pdf" ]; - lispLibs = [ (getAttr "iterate" self) (getAttr "zpb-ttf" self) ]; - meta = {}; - }); - cl-pdf-doc = (build-asdf-system { - pname = "cl-pdf-doc"; - version = "20210531-git"; - asds = [ "cl-pdf-doc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-typesetting/2021-05-31/cl-typesetting-20210531-git.tgz"; - sha256 = "0fcs5mq0gxfczbrg7ay8r4bf5r4g6blvpdbjkhcl8dapcikyn35h"; - system = "cl-pdf-doc"; - asd = "cl-pdf-doc"; - }); - systems = [ "cl-pdf-doc" ]; - lispLibs = [ (getAttr "cl-pdf" self) (getAttr "cl-typesetting" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-pdf-parser = (build-asdf-system { - pname = "cl-pdf-parser"; - version = "20231021-git"; - asds = [ "cl-pdf-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pdf/2023-10-21/cl-pdf-20231021-git.tgz"; - sha256 = "1x88fvk3kxi3k6a84iajb6myw67z8n3plfidq8d4c26ymiz0kvfm"; - system = "cl-pdf-parser"; - asd = "cl-pdf-parser"; - }); - systems = [ "cl-pdf-parser" ]; - lispLibs = [ (getAttr "cl-pdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-performance-tuning-helper = (build-asdf-system { - pname = "cl-performance-tuning-helper"; - version = "20130615-git"; - asds = [ "cl-performance-tuning-helper" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-performance-tuning-helper/2013-06-15/cl-performance-tuning-helper-20130615-git.tgz"; - sha256 = "1j0k319il271grm6hjqq2bazp5l105lazayqsmpsy8lsy4lmy0c3"; - system = "cl-performance-tuning-helper"; - asd = "cl-performance-tuning-helper"; - }); - systems = [ "cl-performance-tuning-helper" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-performance-tuning-helper-test = (build-asdf-system { - pname = "cl-performance-tuning-helper-test"; - version = "20130615-git"; - asds = [ "cl-performance-tuning-helper-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-performance-tuning-helper/2013-06-15/cl-performance-tuning-helper-20130615-git.tgz"; - sha256 = "1j0k319il271grm6hjqq2bazp5l105lazayqsmpsy8lsy4lmy0c3"; - system = "cl-performance-tuning-helper-test"; - asd = "cl-performance-tuning-helper-test"; - }); - systems = [ "cl-performance-tuning-helper-test" ]; - lispLibs = [ (getAttr "cl-performance-tuning-helper" self) (getAttr "rt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-permutation = (build-asdf-system { - pname = "cl-permutation"; - version = "20231021-git"; - asds = [ "cl-permutation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-permutation/2023-10-21/cl-permutation-20231021-git.tgz"; - sha256 = "1zq7hjfn854jr1sglagvdpn749ihxki0l1wcbg9nd2i7ds1g5h4y"; - system = "cl-permutation"; - asd = "cl-permutation"; - }); - systems = [ "cl-permutation" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-fft" self) (getAttr "cl-algebraic-data-type" self) (getAttr "cl-cont" self) (getAttr "closer-mop" self) (getAttr "iterate" self) (getAttr "priority-queue" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-permutation-examples = (build-asdf-system { - pname = "cl-permutation-examples"; - version = "20231021-git"; - asds = [ "cl-permutation-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-permutation/2023-10-21/cl-permutation-20231021-git.tgz"; - sha256 = "1zq7hjfn854jr1sglagvdpn749ihxki0l1wcbg9nd2i7ds1g5h4y"; - system = "cl-permutation-examples"; - asd = "cl-permutation-examples"; - }); - systems = [ "cl-permutation-examples" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-permutation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-permutation-tests = (build-asdf-system { - pname = "cl-permutation-tests"; - version = "20231021-git"; - asds = [ "cl-permutation-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-permutation/2023-10-21/cl-permutation-20231021-git.tgz"; - sha256 = "1zq7hjfn854jr1sglagvdpn749ihxki0l1wcbg9nd2i7ds1g5h4y"; - system = "cl-permutation-tests"; - asd = "cl-permutation-tests"; - }); - systems = [ "cl-permutation-tests" ]; - lispLibs = [ (getAttr "cl-permutation" self) (getAttr "cl-permutation-examples" self) (getAttr "fiasco" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-photo = (build-asdf-system { - pname = "cl-photo"; - version = "20150923-git"; - asds = [ "cl-photo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-photo/2015-09-23/cl-photo-20150923-git.tgz"; - sha256 = "03rzsi1rqvlnw43z7kh5sy1h8gjxc5n0cfryfkkqnhym9q9186mj"; - system = "cl-photo"; - asd = "cl-photo"; - }); - systems = [ "cl-photo" ]; - lispLibs = [ (getAttr "kmrcl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-photo-tests = (build-asdf-system { - pname = "cl-photo-tests"; - version = "20150923-git"; - asds = [ "cl-photo-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-photo/2015-09-23/cl-photo-20150923-git.tgz"; - sha256 = "03rzsi1rqvlnw43z7kh5sy1h8gjxc5n0cfryfkkqnhym9q9186mj"; - system = "cl-photo-tests"; - asd = "cl-photo-tests"; - }); - systems = [ "cl-photo-tests" ]; - lispLibs = [ (getAttr "cl-photo" self) (getAttr "rt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-plplot = (build-asdf-system { - pname = "cl-plplot"; - version = "20180228-git"; - asds = [ "cl-plplot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-plplot/2018-02-28/cl-plplot-20180228-git.tgz"; - sha256 = "0hfgq47ga2r764jfc3ywaz5ynnvp701fjhbw0s4j1mrw4gaf6y6w"; - system = "cl-plplot"; - asd = "cl-plplot"; - }); - systems = [ "cl-plplot" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-plumbing = (build-asdf-system { - pname = "cl-plumbing"; - version = "20181018-git"; - asds = [ "cl-plumbing" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-plumbing/2018-10-18/cl-plumbing-20181018-git.tgz"; - sha256 = "0bc4qqj0c4hghwx8jm3vg422c3i8livv3vvzfzi0gw79khaqdiyr"; - system = "cl-plumbing"; - asd = "cl-plumbing"; - }); - systems = [ "cl-plumbing" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "iterate" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-plumbing-test = (build-asdf-system { - pname = "cl-plumbing-test"; - version = "20181018-git"; - asds = [ "cl-plumbing-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-plumbing/2018-10-18/cl-plumbing-20181018-git.tgz"; - sha256 = "0bc4qqj0c4hghwx8jm3vg422c3i8livv3vvzfzi0gw79khaqdiyr"; - system = "cl-plumbing-test"; - asd = "cl-plumbing-test"; - }); - systems = [ "cl-plumbing-test" ]; - lispLibs = [ (getAttr "cl-plumbing" self) (getAttr "iterate" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-plus-c = (build-asdf-system { - pname = "cl-plus-c"; - version = "20241012-git"; - asds = [ "cl-plus-c" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-autowrap/2024-10-12/cl-autowrap-20241012-git.tgz"; - sha256 = "1sfvhyrwm9dhxi0y42xp7mx8mvs6lmq3bzxdx34frxni5srcgly0"; - system = "cl-plus-c"; - asd = "cl-plus-c"; - }); - systems = [ "cl-plus-c" ]; - lispLibs = [ (getAttr "cl-autowrap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-plus-ssl-osx-fix = (build-asdf-system { - pname = "cl-plus-ssl-osx-fix"; - version = "20241012-git"; - asds = [ "cl-plus-ssl-osx-fix" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-plus-ssl-osx-fix/2024-10-12/cl-plus-ssl-osx-fix-20241012-git.tgz"; - sha256 = "0rkrazia05zzwzd9vx2kl1azwgjy0d4pvfmwp5mjmqsvpklgacwv"; - system = "cl-plus-ssl-osx-fix"; - asd = "cl-plus-ssl-osx-fix"; - }); - systems = [ "cl-plus-ssl-osx-fix" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "cl_plus_ssl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-plus-ssl-osx-fix-ci = (build-asdf-system { - pname = "cl-plus-ssl-osx-fix-ci"; - version = "20241012-git"; - asds = [ "cl-plus-ssl-osx-fix-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-plus-ssl-osx-fix/2024-10-12/cl-plus-ssl-osx-fix-20241012-git.tgz"; - sha256 = "0rkrazia05zzwzd9vx2kl1azwgjy0d4pvfmwp5mjmqsvpklgacwv"; - system = "cl-plus-ssl-osx-fix-ci"; - asd = "cl-plus-ssl-osx-fix-ci"; - }); - systems = [ "cl-plus-ssl-osx-fix-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-plus-ssl-osx-fix-docs = (build-asdf-system { - pname = "cl-plus-ssl-osx-fix-docs"; - version = "20241012-git"; - asds = [ "cl-plus-ssl-osx-fix-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-plus-ssl-osx-fix/2024-10-12/cl-plus-ssl-osx-fix-20241012-git.tgz"; - sha256 = "0rkrazia05zzwzd9vx2kl1azwgjy0d4pvfmwp5mjmqsvpklgacwv"; - system = "cl-plus-ssl-osx-fix-docs"; - asd = "cl-plus-ssl-osx-fix-docs"; - }); - systems = [ "cl-plus-ssl-osx-fix-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "cl-plus-ssl-osx-fix" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-plus-ssl-osx-fix-tests = (build-asdf-system { - pname = "cl-plus-ssl-osx-fix-tests"; - version = "20241012-git"; - asds = [ "cl-plus-ssl-osx-fix-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-plus-ssl-osx-fix/2024-10-12/cl-plus-ssl-osx-fix-20241012-git.tgz"; - sha256 = "0rkrazia05zzwzd9vx2kl1azwgjy0d4pvfmwp5mjmqsvpklgacwv"; - system = "cl-plus-ssl-osx-fix-tests"; - asd = "cl-plus-ssl-osx-fix-tests"; - }); - systems = [ "cl-plus-ssl-osx-fix-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ply = (build-asdf-system { - pname = "cl-ply"; - version = "20150505-git"; - asds = [ "cl-ply" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ply/2015-05-05/cl-ply-20150505-git.tgz"; - sha256 = "1va3il5ahvziwm6i3f2zy3vchv0qkh1l7jci7gnfam43gf88fl12"; - system = "cl-ply"; - asd = "cl-ply"; - }); - systems = [ "cl-ply" ]; - lispLibs = [ (getAttr "cl-pattern" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ply-test = (build-asdf-system { - pname = "cl-ply-test"; - version = "20150505-git"; - asds = [ "cl-ply-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ply/2015-05-05/cl-ply-20150505-git.tgz"; - sha256 = "1va3il5ahvziwm6i3f2zy3vchv0qkh1l7jci7gnfam43gf88fl12"; - system = "cl-ply-test"; - asd = "cl-ply-test"; - }); - systems = [ "cl-ply-test" ]; - lispLibs = [ (getAttr "cl-ply" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-poker-eval = (build-asdf-system { - pname = "cl-poker-eval"; - version = "20150804-git"; - asds = [ "cl-poker-eval" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-poker-eval/2015-08-04/cl-poker-eval-20150804-git.tgz"; - sha256 = "1w4dsr4j7r3n7p0jbp8ccwwk83wcjjiz1rhhfrqpsd9v263v7kw8"; - system = "cl-poker-eval"; - asd = "cl-poker-eval"; - }); - systems = [ "cl-poker-eval" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-pop = (build-asdf-system { - pname = "cl-pop"; - version = "20110418-http"; - asds = [ "cl-pop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pop/2011-04-18/cl-pop-20110418-http.tgz"; - sha256 = "1g47p9w2pzf7glx92cz859di9pz454xpaq97p76lcvyilxk6q819"; - system = "cl-pop"; - asd = "cl-pop"; - }); - systems = [ "cl-pop" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-portaudio = (build-asdf-system { - pname = "cl-portaudio"; - version = "20201220-git"; - asds = [ "cl-portaudio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-portaudio/2020-12-20/cl-portaudio-20201220-git.tgz"; - sha256 = "177c6bgf30caj5qpzfnzhbamax7c5zm2p4911mw7fay94vjs7zyb"; - system = "cl-portaudio"; - asd = "cl-portaudio"; - }); - systems = [ "cl-portaudio" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "ffa" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-postgres = (build-asdf-system { - pname = "cl-postgres"; - version = "20241012-git"; - asds = [ "cl-postgres" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/postmodern/2024-10-12/postmodern-20241012-git.tgz"; - sha256 = "1hj0dpclzihy1rcnwhiv16abmaa54wygxyib3j2h9q4qs26w7pzb"; - system = "cl-postgres"; - asd = "cl-postgres"; - }); - systems = [ "cl-postgres" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "ironclad" self) (getAttr "md5" self) (getAttr "split-sequence" self) (getAttr "uax-15" self) ]; - meta = {}; - }); - cl-postgres_plus_local-time = (build-asdf-system { - pname = "cl-postgres+local-time"; - version = "20241012-git"; - asds = [ "cl-postgres+local-time" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/local-time/2024-10-12/local-time-20241012-git.tgz"; - sha256 = "0jb1mb5zs4ryiah8zjzhpln1z686mfmpmvg1phgpr2mh9vvlgjk2"; - system = "cl-postgres+local-time"; - asd = "cl-postgres+local-time"; - }); - systems = [ "cl-postgres+local-time" ]; - lispLibs = [ (getAttr "cl-postgres" self) (getAttr "local-time" self) ]; - meta = {}; - }); - cl-postgres_plus_local-time-duration = (build-asdf-system { - pname = "cl-postgres+local-time-duration"; - version = "20180430-git"; - asds = [ "cl-postgres+local-time-duration" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/local-time-duration/2018-04-30/local-time-duration-20180430-git.tgz"; - sha256 = "0f13mg18lv31lclz9jvqyj8d85p1jj1366nlld8m3dxnnwsbbkd6"; - system = "cl-postgres+local-time-duration"; - asd = "cl-postgres+local-time-duration"; - }); - systems = [ "cl-postgres+local-time-duration" ]; - lispLibs = [ (getAttr "cl-postgres" self) (getAttr "local-time-duration" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-postgres-datetime = (build-asdf-system { - pname = "cl-postgres-datetime"; - version = "20190521-git"; - asds = [ "cl-postgres-datetime" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-postgres-datetime/2019-05-21/cl-postgres-datetime-20190521-git.tgz"; - sha256 = "1vwv5j1i968927j070bagqx9i114a8phmx7k9ankj9j5zg5dj0l3"; - system = "cl-postgres-datetime"; - asd = "cl-postgres-datetime"; - }); - systems = [ "cl-postgres-datetime" ]; - lispLibs = [ (getAttr "cl-postgres" self) (getAttr "local-time" self) (getAttr "simple-date" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-postgres-plus-uuid = (build-asdf-system { - pname = "cl-postgres-plus-uuid"; - version = "20181018-git"; - asds = [ "cl-postgres-plus-uuid" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-postgres-plus-uuid/2018-10-18/cl-postgres-plus-uuid-20181018-git.tgz"; - sha256 = "1iw11v67gpwgpa5dw3d7chjmkc4d7sdwrqvnx0vg0m2qf4j7azmi"; - system = "cl-postgres-plus-uuid"; - asd = "cl-postgres-plus-uuid"; - }); - systems = [ "cl-postgres-plus-uuid" ]; - lispLibs = [ (getAttr "cl-postgres" self) (getAttr "uuid" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ppcre = (build-asdf-system { - pname = "cl-ppcre"; - version = "20241012-git"; - asds = [ "cl-ppcre" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ppcre/2024-10-12/cl-ppcre-20241012-git.tgz"; - sha256 = "0aw7lh79wgn18c75v29md2x8irl8v7f96lj1mfkp7x0mkqsb0cs8"; - system = "cl-ppcre"; - asd = "cl-ppcre"; - }); - systems = [ "cl-ppcre" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-ppcre-template = (build-asdf-system { - pname = "cl-ppcre-template"; - version = "20241012-git"; - asds = [ "cl-ppcre-template" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-unification/2024-10-12/cl-unification-20241012-git.tgz"; - sha256 = "1q7bjj9dzazhgj32291rqy4lld1ilrpck374c21864qn3pmz31ag"; - system = "cl-ppcre-template"; - asd = "cl-ppcre-template"; - }); - systems = [ "cl-ppcre-template" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cl-unification" self) ]; - meta = {}; - }); - cl-ppcre-unicode = (build-asdf-system { - pname = "cl-ppcre-unicode"; - version = "20241012-git"; - asds = [ "cl-ppcre-unicode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ppcre/2024-10-12/cl-ppcre-20241012-git.tgz"; - sha256 = "0aw7lh79wgn18c75v29md2x8irl8v7f96lj1mfkp7x0mkqsb0cs8"; - system = "cl-ppcre-unicode"; - asd = "cl-ppcre-unicode"; - }); - systems = [ "cl-ppcre-unicode" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cl-unicode" self) ]; - meta = {}; - }); - cl-prevalence = (build-asdf-system { - pname = "cl-prevalence"; - version = "20230214-git"; - asds = [ "cl-prevalence" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prevalence/2023-02-14/cl-prevalence-20230214-git.tgz"; - sha256 = "1lb957ivshgp56phqhvhsmnc4r55x5shvi3mpsan2xsm4hvqspp0"; - system = "cl-prevalence"; - asd = "cl-prevalence"; - }); - systems = [ "cl-prevalence" ]; - lispLibs = [ (getAttr "moptilities" self) (getAttr "s-sysdeps" self) (getAttr "s-xml" self) ]; - meta = {}; - }); - cl-prevalence-test = (build-asdf-system { - pname = "cl-prevalence-test"; - version = "20230214-git"; - asds = [ "cl-prevalence-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prevalence/2023-02-14/cl-prevalence-20230214-git.tgz"; - sha256 = "1lb957ivshgp56phqhvhsmnc4r55x5shvi3mpsan2xsm4hvqspp0"; - system = "cl-prevalence-test"; - asd = "cl-prevalence-test"; - }); - systems = [ "cl-prevalence-test" ]; - lispLibs = [ (getAttr "cl-prevalence" self) (getAttr "find-port" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-primality = (build-asdf-system { - pname = "cl-primality"; - version = "20150608-git"; - asds = [ "cl-primality" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-primality/2015-06-08/cl-primality-20150608-git.tgz"; - sha256 = "1hvbsd5x7yrrrh7jjq0p8ign3ppzzpacmmz7nps60wgk38q1b618"; - system = "cl-primality"; - asd = "cl-primality"; - }); - systems = [ "cl-primality" ]; - lispLibs = [ (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-primality-test = (build-asdf-system { - pname = "cl-primality-test"; - version = "20150608-git"; - asds = [ "cl-primality-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-primality/2015-06-08/cl-primality-20150608-git.tgz"; - sha256 = "1hvbsd5x7yrrrh7jjq0p8ign3ppzzpacmmz7nps60wgk38q1b618"; - system = "cl-primality-test"; - asd = "cl-primality-test"; - }); - systems = [ "cl-primality-test" ]; - lispLibs = [ (getAttr "cl-primality" self) (getAttr "iterate" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prime-maker = (build-asdf-system { - pname = "cl-prime-maker"; - version = "20150302-git"; - asds = [ "cl-prime-maker" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prime-maker/2015-03-02/cl-prime-maker-20150302-git.tgz"; - sha256 = "0hs95zs990aiwspss2dzmjvl18ipvlkx3p9cgmcncqxhgkizds9s"; - system = "cl-prime-maker"; - asd = "cl-prime-maker"; - }); - systems = [ "cl-prime-maker" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-progress-bar = (build-asdf-system { - pname = "cl-progress-bar"; - version = "20211209-git"; - asds = [ "cl-progress-bar" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-progress-bar/2021-12-09/cl-progress-bar-20211209-git.tgz"; - sha256 = "1y4kg4qb4bxkqnc84mczx5fhqlr6qbagxwsn93xrilv8lqg8ymiv"; - system = "cl-progress-bar"; - asd = "cl-progress-bar"; - }); - systems = [ "cl-progress-bar" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "documentation-utils-extensions" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-project = (build-asdf-system { - pname = "cl-project"; - version = "20241012-git"; - asds = [ "cl-project" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-project/2024-10-12/cl-project-20241012-git.tgz"; - sha256 = "12bvhs1ll6wxwgarvyxbrm978jxpvgj9vyqcbnwqmf5kqxjlrh0j"; - system = "cl-project"; - asd = "cl-project"; - }); - systems = [ "cl-project" ]; - lispLibs = [ (getAttr "cl-emb" self) (getAttr "cl-ppcre" self) (getAttr "local-time" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-project-test = (build-asdf-system { - pname = "cl-project-test"; - version = "20241012-git"; - asds = [ "cl-project-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-project/2024-10-12/cl-project-20241012-git.tgz"; - sha256 = "12bvhs1ll6wxwgarvyxbrm978jxpvgj9vyqcbnwqmf5kqxjlrh0j"; - system = "cl-project-test"; - asd = "cl-project-test"; - }); - systems = [ "cl-project-test" ]; - lispLibs = [ (getAttr "caveman2" self) (getAttr "cl-project" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prolog2 = (build-asdf-system { - pname = "cl-prolog2"; - version = "20211209-git"; - asds = [ "cl-prolog2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; - sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; - system = "cl-prolog2"; - asd = "cl-prolog2"; - }); - systems = [ "cl-prolog2" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "external-program" self) (getAttr "trivia" self) (getAttr "trivia_dot_quasiquote" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prolog2_dot_bprolog = (build-asdf-system { - pname = "cl-prolog2.bprolog"; - version = "20211209-git"; - asds = [ "cl-prolog2.bprolog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; - sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; - system = "cl-prolog2.bprolog"; - asd = "cl-prolog2.bprolog"; - }); - systems = [ "cl-prolog2.bprolog" ]; - lispLibs = [ (getAttr "cl-prolog2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prolog2_dot_bprolog_dot_test = (build-asdf-system { - pname = "cl-prolog2.bprolog.test"; - version = "20211209-git"; - asds = [ "cl-prolog2.bprolog.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; - sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; - system = "cl-prolog2.bprolog.test"; - asd = "cl-prolog2.bprolog.test"; - }); - systems = [ "cl-prolog2.bprolog.test" ]; - lispLibs = [ (getAttr "cl-prolog2_dot_bprolog" self) (getAttr "cl-prolog2_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prolog2_dot_gprolog = (build-asdf-system { - pname = "cl-prolog2.gprolog"; - version = "20211209-git"; - asds = [ "cl-prolog2.gprolog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; - sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; - system = "cl-prolog2.gprolog"; - asd = "cl-prolog2.gprolog"; - }); - systems = [ "cl-prolog2.gprolog" ]; - lispLibs = [ (getAttr "cl-prolog2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prolog2_dot_gprolog_dot_test = (build-asdf-system { - pname = "cl-prolog2.gprolog.test"; - version = "20211209-git"; - asds = [ "cl-prolog2.gprolog.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; - sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; - system = "cl-prolog2.gprolog.test"; - asd = "cl-prolog2.gprolog.test"; - }); - systems = [ "cl-prolog2.gprolog.test" ]; - lispLibs = [ (getAttr "cl-prolog2_dot_gprolog" self) (getAttr "cl-prolog2_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prolog2_dot_swi = (build-asdf-system { - pname = "cl-prolog2.swi"; - version = "20211209-git"; - asds = [ "cl-prolog2.swi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; - sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; - system = "cl-prolog2.swi"; - asd = "cl-prolog2.swi"; - }); - systems = [ "cl-prolog2.swi" ]; - lispLibs = [ (getAttr "cl-prolog2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prolog2_dot_swi_dot_test = (build-asdf-system { - pname = "cl-prolog2.swi.test"; - version = "20211209-git"; - asds = [ "cl-prolog2.swi.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; - sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; - system = "cl-prolog2.swi.test"; - asd = "cl-prolog2.swi.test"; - }); - systems = [ "cl-prolog2.swi.test" ]; - lispLibs = [ (getAttr "cl-prolog2_dot_swi" self) (getAttr "cl-prolog2_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prolog2_dot_test = (build-asdf-system { - pname = "cl-prolog2.test"; - version = "20211209-git"; - asds = [ "cl-prolog2.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; - sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; - system = "cl-prolog2.test"; - asd = "cl-prolog2.test"; - }); - systems = [ "cl-prolog2.test" ]; - lispLibs = [ (getAttr "cl-prolog2" self) (getAttr "fiveam" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prolog2_dot_xsb = (build-asdf-system { - pname = "cl-prolog2.xsb"; - version = "20211209-git"; - asds = [ "cl-prolog2.xsb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; - sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; - system = "cl-prolog2.xsb"; - asd = "cl-prolog2.xsb"; - }); - systems = [ "cl-prolog2.xsb" ]; - lispLibs = [ (getAttr "cl-prolog2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prolog2_dot_xsb_dot_test = (build-asdf-system { - pname = "cl-prolog2.xsb.test"; - version = "20211209-git"; - asds = [ "cl-prolog2.xsb.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; - sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; - system = "cl-prolog2.xsb.test"; - asd = "cl-prolog2.xsb.test"; - }); - systems = [ "cl-prolog2.xsb.test" ]; - lispLibs = [ (getAttr "cl-prolog2_dot_test" self) (getAttr "cl-prolog2_dot_xsb" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prolog2_dot_yap = (build-asdf-system { - pname = "cl-prolog2.yap"; - version = "20211209-git"; - asds = [ "cl-prolog2.yap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; - sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; - system = "cl-prolog2.yap"; - asd = "cl-prolog2.yap"; - }); - systems = [ "cl-prolog2.yap" ]; - lispLibs = [ (getAttr "cl-prolog2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-prolog2_dot_yap_dot_test = (build-asdf-system { - pname = "cl-prolog2.yap.test"; - version = "20211209-git"; - asds = [ "cl-prolog2.yap.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; - sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; - system = "cl-prolog2.yap.test"; - asd = "cl-prolog2.yap.test"; - }); - systems = [ "cl-prolog2.yap.test" ]; - lispLibs = [ (getAttr "cl-prolog2_dot_test" self) (getAttr "cl-prolog2_dot_yap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-protobufs_dot_asdf = (build-asdf-system { - pname = "cl-protobufs.asdf"; - version = "20241012-git"; - asds = [ "cl-protobufs.asdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-protobufs/2024-10-12/cl-protobufs-20241012-git.tgz"; - sha256 = "08digcsyxs46pl7r5d945db5r2hbrxydqqcmzbgziq61ca4p0ifn"; - system = "cl-protobufs.asdf"; - asd = "cl-protobufs.asdf"; - }); - systems = [ "cl-protobufs.asdf" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-pslib = (build-asdf-system { - pname = "cl-pslib"; - version = "20241012-git"; - asds = [ "cl-pslib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pslib/2024-10-12/cl-pslib-20241012-git.tgz"; - sha256 = "12lg64nbjkxmaf212qr4i0msnsixc2cbqmxkdgqjii9rsyqdvrn6"; - system = "cl-pslib"; - asd = "cl-pslib"; - }); - systems = [ "cl-pslib" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-colors2" self) (getAttr "cl-ppcre-unicode" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-pslib-barcode = (build-asdf-system { - pname = "cl-pslib-barcode"; - version = "20241012-git"; - asds = [ "cl-pslib-barcode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pslib-barcode/2024-10-12/cl-pslib-barcode-20241012-git.tgz"; - sha256 = "1n17yv7qr6i6dhbjrcc1binlxxkc1p5blj9nwn6g26fyvakgwrsb"; - system = "cl-pslib-barcode"; - asd = "cl-pslib-barcode"; - }); - systems = [ "cl-pslib-barcode" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-colors2" self) (getAttr "cl-ppcre-unicode" self) (getAttr "cl-pslib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-punch = (build-asdf-system { - pname = "cl-punch"; - version = "20190107-git"; - asds = [ "cl-punch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-punch/2019-01-07/cl-punch-20190107-git.tgz"; - sha256 = "1sjgwn6c77n8pgs0rrw70xfl18rps6a0dlf2chfsbgk8shz6qyl2"; - system = "cl-punch"; - asd = "cl-punch"; - }); - systems = [ "cl-punch" ]; - lispLibs = [ (getAttr "cl-syntax" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-punch-test = (build-asdf-system { - pname = "cl-punch-test"; - version = "20190107-git"; - asds = [ "cl-punch-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-punch/2019-01-07/cl-punch-20190107-git.tgz"; - sha256 = "1sjgwn6c77n8pgs0rrw70xfl18rps6a0dlf2chfsbgk8shz6qyl2"; - system = "cl-punch-test"; - asd = "cl-punch-test"; - }); - systems = [ "cl-punch-test" ]; - lispLibs = [ (getAttr "cl-punch" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-qoa = (build-asdf-system { - pname = "cl-qoa"; - version = "20241012-git"; - asds = [ "cl-qoa" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-qoa/2024-10-12/cl-qoa-20241012-git.tgz"; - sha256 = "0gxrra0mvvkyvhvg7cc4bvi3nwdsnx0dbjszp41ch6dsdhd3pcpy"; - system = "cl-qoa"; - asd = "cl-qoa"; - }); - systems = [ "cl-qoa" ]; - lispLibs = [ (getAttr "binary-structures" self) (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-qprint = (build-asdf-system { - pname = "cl-qprint"; - version = "20150804-git"; - asds = [ "cl-qprint" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-qprint/2015-08-04/cl-qprint-20150804-git.tgz"; - sha256 = "099h0rrdzxnlmn8avi72mg2dl0kccp7w01b2p9nwyy4b8yr32cir"; - system = "cl-qprint"; - asd = "cl-qprint"; - }); - systems = [ "cl-qprint" ]; - lispLibs = [ (getAttr "flexi-streams" self) ]; - meta = {}; - }); - cl-qrencode = (build-asdf-system { - pname = "cl-qrencode"; - version = "20191007-git"; - asds = [ "cl-qrencode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-qrencode/2019-10-07/cl-qrencode-20191007-git.tgz"; - sha256 = "1l5k131dchbf6cj8a8xqa731790p01p3qa1kdy2wa9dawy3ymkxr"; - system = "cl-qrencode"; - asd = "cl-qrencode"; - }); - systems = [ "cl-qrencode" ]; - lispLibs = [ (getAttr "zpng" self) ]; - meta = {}; - }); - cl-qrencode-test = (build-asdf-system { - pname = "cl-qrencode-test"; - version = "20191007-git"; - asds = [ "cl-qrencode-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-qrencode/2019-10-07/cl-qrencode-20191007-git.tgz"; - sha256 = "1l5k131dchbf6cj8a8xqa731790p01p3qa1kdy2wa9dawy3ymkxr"; - system = "cl-qrencode-test"; - asd = "cl-qrencode-test"; - }); - systems = [ "cl-qrencode-test" ]; - lispLibs = [ (getAttr "cl-qrencode" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-quickcheck = (build-asdf-system { - pname = "cl-quickcheck"; - version = "20200610-git"; - asds = [ "cl-quickcheck" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-quickcheck/2020-06-10/cl-quickcheck-20200610-git.tgz"; - sha256 = "0cfyxbdhklvdk3qdzyxxaq9q6cxnsvqjfi86nay1vc7h6ziysb60"; - system = "cl-quickcheck"; - asd = "cl-quickcheck"; - }); - systems = [ "cl-quickcheck" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rabbit = (build-asdf-system { - pname = "cl-rabbit"; - version = "20210411-git"; - asds = [ "cl-rabbit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rabbit/2021-04-11/cl-rabbit-20210411-git.tgz"; - sha256 = "1q1mhqxqvxbr6ak7j0ym6mjhhq6r0pqk1l7az9hfajmqmw3xfija"; - system = "cl-rabbit"; - asd = "cl-rabbit"; - }); - systems = [ "cl-rabbit" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cffi-libffi" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rabbit-tests = (build-asdf-system { - pname = "cl-rabbit-tests"; - version = "20210411-git"; - asds = [ "cl-rabbit-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rabbit/2021-04-11/cl-rabbit-20210411-git.tgz"; - sha256 = "1q1mhqxqvxbr6ak7j0ym6mjhhq6r0pqk1l7az9hfajmqmw3xfija"; - system = "cl-rabbit-tests"; - asd = "cl-rabbit-tests"; - }); - systems = [ "cl-rabbit-tests" ]; - lispLibs = [ (getAttr "cl-rabbit" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-randist = (build-asdf-system { - pname = "cl-randist"; - version = "20221106-git"; - asds = [ "cl-randist" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-randist/2022-11-06/cl-randist-20221106-git.tgz"; - sha256 = "1r0d76n5zjqg5fb2ypqx5i1wg4hsg5g0c126ylqb28wdaf2yjz5a"; - system = "cl-randist"; - asd = "cl-randist"; - }); - systems = [ "cl-randist" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-random-forest = (build-asdf-system { - pname = "cl-random-forest"; - version = "20221106-git"; - asds = [ "cl-random-forest" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-random-forest/2022-11-06/cl-random-forest-20221106-git.tgz"; - sha256 = "0jn5f3s1zvjql35c4m67lqc0vjr7sm7kzf8w4jfbfabcnxf3y6jx"; - system = "cl-random-forest"; - asd = "cl-random-forest"; - }); - systems = [ "cl-random-forest" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-libsvm-format" self) (getAttr "cl-online-learning" self) (getAttr "lparallel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-random-forest-test = (build-asdf-system { - pname = "cl-random-forest-test"; - version = "20221106-git"; - asds = [ "cl-random-forest-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-random-forest/2022-11-06/cl-random-forest-20221106-git.tgz"; - sha256 = "0jn5f3s1zvjql35c4m67lqc0vjr7sm7kzf8w4jfbfabcnxf3y6jx"; - system = "cl-random-forest-test"; - asd = "cl-random-forest-test"; - }); - systems = [ "cl-random-forest-test" ]; - lispLibs = [ (getAttr "cl-random-forest" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rdfxml = (build-asdf-system { - pname = "cl-rdfxml"; - version = "20140713-git"; - asds = [ "cl-rdfxml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rdfxml/2014-07-13/cl-rdfxml-20140713-git.tgz"; - sha256 = "09v76qg6l3y1llapnkfqrfgib67h7lpkzrdmfimwk49bi80iii8v"; - system = "cl-rdfxml"; - asd = "cl-rdfxml"; - }); - systems = [ "cl-rdfxml" ]; - lispLibs = [ (getAttr "cxml" self) (getAttr "puri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rdkafka = (build-asdf-system { - pname = "cl-rdkafka"; - version = "20230214-git"; - asds = [ "cl-rdkafka" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rdkafka/2023-02-14/cl-rdkafka-20230214-git.tgz"; - sha256 = "10y56avak66k2la9bmfzrni01wybi86avxjh64hz57b351bf2s55"; - system = "cl-rdkafka"; - asd = "cl-rdkafka"; - }); - systems = [ "cl-rdkafka" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "lparallel" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-readline = (build-asdf-system { - pname = "cl-readline"; - version = "20241012-git"; - asds = [ "cl-readline" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-readline/2024-10-12/cl-readline-20241012-git.tgz"; - sha256 = "0law12vnj1d5174kk9l949mgkkxm1x6kpcw5wixxjavmxxwqwric"; - system = "cl-readline"; - asd = "cl-readline"; - }); - systems = [ "cl-readline" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) ]; - meta = {}; - }); - cl-recaptcha = (build-asdf-system { - pname = "cl-recaptcha"; - version = "20150608-git"; - asds = [ "cl-recaptcha" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-recaptcha/2015-06-08/cl-recaptcha-20150608-git.tgz"; - sha256 = "09qdmzbhc5hikay31mbsfd7dps72rm4gcdbbi0b6gkb6qbia6m71"; - system = "cl-recaptcha"; - asd = "cl-recaptcha"; - }); - systems = [ "cl-recaptcha" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "flexi-streams" self) (getAttr "jsown" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-reddit = (build-asdf-system { - pname = "cl-reddit"; - version = "20241012-git"; - asds = [ "cl-reddit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-reddit/2024-10-12/cl-reddit-20241012-git.tgz"; - sha256 = "0jnc88mdz7hsmsncqrqmc8m8f1yd3n9087750kqpnn1sp1cwskk1"; - system = "cl-reddit"; - asd = "cl-reddit"; - }); - systems = [ "cl-reddit" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-redis = (build-asdf-system { - pname = "cl-redis"; - version = "20200925-git"; - asds = [ "cl-redis" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-redis/2020-09-25/cl-redis-20200925-git.tgz"; - sha256 = "0x5ahxb5cx37biyn3cjycshhm1rr9p5cf1a9l5hd1n1xjxm2f8vi"; - system = "cl-redis"; - asd = "cl-redis"; - }); - systems = [ "cl-redis" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "rutils" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-redis-test = (build-asdf-system { - pname = "cl-redis-test"; - version = "20200925-git"; - asds = [ "cl-redis-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-redis/2020-09-25/cl-redis-20200925-git.tgz"; - sha256 = "0x5ahxb5cx37biyn3cjycshhm1rr9p5cf1a9l5hd1n1xjxm2f8vi"; - system = "cl-redis-test"; - asd = "cl-redis"; - }); - systems = [ "cl-redis-test" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-redis" self) (getAttr "flexi-streams" self) (getAttr "should-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-reexport = (build-asdf-system { - pname = "cl-reexport"; - version = "20210228-git"; - asds = [ "cl-reexport" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-reexport/2021-02-28/cl-reexport-20210228-git.tgz"; - sha256 = "02la6z3ickhmh2m87ymm2ijh9nkn7l6slskj99l8a1rhps394qqc"; - system = "cl-reexport"; - asd = "cl-reexport"; - }); - systems = [ "cl-reexport" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = {}; - }); - cl-reexport-test = (build-asdf-system { - pname = "cl-reexport-test"; - version = "20210228-git"; - asds = [ "cl-reexport-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-reexport/2021-02-28/cl-reexport-20210228-git.tgz"; - sha256 = "02la6z3ickhmh2m87ymm2ijh9nkn7l6slskj99l8a1rhps394qqc"; - system = "cl-reexport-test"; - asd = "cl-reexport-test"; - }); - systems = [ "cl-reexport-test" ]; - lispLibs = [ (getAttr "cl-reexport" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-renderdoc = (build-asdf-system { - pname = "cl-renderdoc"; - version = "20200925-git"; - asds = [ "cl-renderdoc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-renderdoc/2020-09-25/cl-renderdoc-20200925-git.tgz"; - sha256 = "0rrcp4y1f07x8h0ikvf5ncc3pbqj6vaciblab9qghmgdglnn7akx"; - system = "cl-renderdoc"; - asd = "cl-renderdoc"; - }); - systems = [ "cl-renderdoc" ]; - lispLibs = [ (getAttr "cl-autowrap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-replica = (build-asdf-system { - pname = "cl-replica"; - version = "20230618-git"; - asds = [ "cl-replica" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-replica/2023-06-18/cl-replica-20230618-git.tgz"; - sha256 = "06nywqz7il4dk79s3ga8115s5cr9bpz1fh8b7jms5wxlc1h5p0mn"; - system = "cl-replica"; - asd = "cl-replica"; - }); - systems = [ "cl-replica" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-resvg = (build-asdf-system { - pname = "cl-resvg"; - version = "20241012-git"; - asds = [ "cl-resvg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-resvg/2024-10-12/cl-resvg-20241012-git.tgz"; - sha256 = "0263na51qs0wrc9r2dqigj4a1h70pjf0mqsgbnd6hfshvx0kq1cl"; - system = "cl-resvg"; - asd = "cl-resvg"; - }); - systems = [ "cl-resvg" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "float-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rethinkdb = (build-asdf-system { - pname = "cl-rethinkdb"; - version = "20160825-git"; - asds = [ "cl-rethinkdb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rethinkdb/2016-08-25/cl-rethinkdb-20160825-git.tgz"; - sha256 = "0sps1p203gn7i123w96pj5ggpncmkngkfdb6zfnm5yjq544sjjf7"; - system = "cl-rethinkdb"; - asd = "cl-rethinkdb"; - }); - systems = [ "cl-rethinkdb" ]; - lispLibs = [ (getAttr "blackbird" self) (getAttr "cl-async" self) (getAttr "cl-base64" self) (getAttr "cl-hash-util" self) (getAttr "cl-ppcre" self) (getAttr "event-glue" self) (getAttr "fast-io" self) (getAttr "jonathan" self) (getAttr "local-time" self) (getAttr "vom" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rethinkdb-test = (build-asdf-system { - pname = "cl-rethinkdb-test"; - version = "20160825-git"; - asds = [ "cl-rethinkdb-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rethinkdb/2016-08-25/cl-rethinkdb-20160825-git.tgz"; - sha256 = "0sps1p203gn7i123w96pj5ggpncmkngkfdb6zfnm5yjq544sjjf7"; - system = "cl-rethinkdb-test"; - asd = "cl-rethinkdb-test"; - }); - systems = [ "cl-rethinkdb-test" ]; - lispLibs = [ (getAttr "blackbird" self) (getAttr "cl-async" self) (getAttr "cl-ppcre" self) (getAttr "cl-rethinkdb" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rfc2047 = (build-asdf-system { - pname = "cl-rfc2047"; - version = "20150804-git"; - asds = [ "cl-rfc2047" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rfc2047/2015-08-04/cl-rfc2047-20150804-git.tgz"; - sha256 = "1kh48p5i7lmv1hcdsddlcjavhai9gi54jndnbpm9r55a6ladi8gv"; - system = "cl-rfc2047"; - asd = "cl-rfc2047"; - }); - systems = [ "cl-rfc2047" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-base64" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rfc2047-test = (build-asdf-system { - pname = "cl-rfc2047-test"; - version = "20150804-git"; - asds = [ "cl-rfc2047-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rfc2047/2015-08-04/cl-rfc2047-20150804-git.tgz"; - sha256 = "1kh48p5i7lmv1hcdsddlcjavhai9gi54jndnbpm9r55a6ladi8gv"; - system = "cl-rfc2047-test"; - asd = "cl-rfc2047-test"; - }); - systems = [ "cl-rfc2047-test" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cl-rfc2047" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rfc4251 = (build-asdf-system { - pname = "cl-rfc4251"; - version = "20231021-git"; - asds = [ "cl-rfc4251" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rfc4251/2023-10-21/cl-rfc4251-20231021-git.tgz"; - sha256 = "11xz6w1gvyj5a01yjfy52byfrq6v8k1mzkp3wajhzhg60nkhn4jh"; - system = "cl-rfc4251"; - asd = "cl-rfc4251"; - }); - systems = [ "cl-rfc4251" ]; - lispLibs = [ (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rfc4251_dot_test = (build-asdf-system { - pname = "cl-rfc4251.test"; - version = "20231021-git"; - asds = [ "cl-rfc4251.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rfc4251/2023-10-21/cl-rfc4251-20231021-git.tgz"; - sha256 = "11xz6w1gvyj5a01yjfy52byfrq6v8k1mzkp3wajhzhg60nkhn4jh"; - system = "cl-rfc4251.test"; - asd = "cl-rfc4251.test"; - }); - systems = [ "cl-rfc4251.test" ]; - lispLibs = [ (getAttr "cl-rfc4251" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-riff = (build-asdf-system { - pname = "cl-riff"; - version = "20220707-git"; - asds = [ "cl-riff" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-riff/2022-07-07/cl-riff-20220707-git.tgz"; - sha256 = "0b2j6yw3xkv6611snn7cy56vmnjfgi58wyvfr9lx82xkakd9rw3z"; - system = "cl-riff"; - asd = "cl-riff"; - }); - systems = [ "cl-riff" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rlimit = (build-asdf-system { - pname = "cl-rlimit"; - version = "20150608-git"; - asds = [ "cl-rlimit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rlimit/2015-06-08/cl-rlimit-20150608-git.tgz"; - sha256 = "19p02r380qhs76qlcb3jp4lm4nsnpy7zch01fdiwn7l7xgxkzxh0"; - system = "cl-rlimit"; - asd = "cl-rlimit"; - }); - systems = [ "cl-rlimit" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rmath = (build-asdf-system { - pname = "cl-rmath"; - version = "20180328-git"; - asds = [ "cl-rmath" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rmath/2018-03-28/cl-rmath-20180328-git.tgz"; - sha256 = "1ld8vbpy10paymx2hn0mcgd21i7cjhdrayln1jx0kayqxm12mmk4"; - system = "cl-rmath"; - asd = "cl-rmath"; - }); - systems = [ "cl-rmath" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-robdd = (build-asdf-system { - pname = "cl-robdd"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "cl-robdd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "cl-robdd"; - asd = "cl-robdd"; - }); - systems = [ "cl-robdd" ]; - lispLibs = [ (getAttr "adjuvant" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-robdd-analysis = (build-asdf-system { - pname = "cl-robdd-analysis"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "cl-robdd-analysis" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "cl-robdd-analysis"; - asd = "cl-robdd-analysis"; - }); - systems = [ "cl-robdd-analysis" ]; - lispLibs = [ (getAttr "adjuvant" self) (getAttr "cl-fad" self) (getAttr "cl-robdd" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-robdd-analysis-test = (build-asdf-system { - pname = "cl-robdd-analysis-test"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "cl-robdd-analysis-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "cl-robdd-analysis-test"; - asd = "cl-robdd-analysis-test"; - }); - systems = [ "cl-robdd-analysis-test" ]; - lispLibs = [ (getAttr "adjuvant" self) (getAttr "cl-robdd-analysis" self) (getAttr "scrutiny" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-robdd-test = (build-asdf-system { - pname = "cl-robdd-test"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "cl-robdd-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "cl-robdd-test"; - asd = "cl-robdd-test"; - }); - systems = [ "cl-robdd-test" ]; - lispLibs = [ (getAttr "adjuvant" self) (getAttr "cl-fad" self) (getAttr "cl-robdd" self) (getAttr "scrutiny" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rrd = (build-asdf-system { - pname = "cl-rrd"; - version = "20130128-git"; - asds = [ "cl-rrd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rrd/2013-01-28/cl-rrd-20130128-git.tgz"; - sha256 = "0a7fs46q41qzi6k8q9lvxryn2m90vamcsw7vl9kcjivyckjqrsm2"; - system = "cl-rrd"; - asd = "cl-rrd"; - }); - systems = [ "cl-rrd" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rrt = (build-asdf-system { - pname = "cl-rrt"; - version = "20200925-git"; - asds = [ "cl-rrt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rrt/2020-09-25/cl-rrt-20200925-git.tgz"; - sha256 = "0lf1dvw5j9awy7ic1i4j5wd7657a170ywxihinmsdn4bwd4fynv0"; - system = "cl-rrt"; - asd = "cl-rrt"; - }); - systems = [ "cl-rrt" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cl-syntax-annot" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rrt_dot_benchmark = (build-asdf-system { - pname = "cl-rrt.benchmark"; - version = "20200925-git"; - asds = [ "cl-rrt.benchmark" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rrt/2020-09-25/cl-rrt-20200925-git.tgz"; - sha256 = "0lf1dvw5j9awy7ic1i4j5wd7657a170ywxihinmsdn4bwd4fynv0"; - system = "cl-rrt.benchmark"; - asd = "cl-rrt.benchmark"; - }); - systems = [ "cl-rrt.benchmark" ]; - lispLibs = [ (getAttr "cl-rrt" self) (getAttr "cl-rrt_dot_rtree" self) (getAttr "cl-rrt_dot_test" self) (getAttr "fiveam" self) (getAttr "vecto" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rrt_dot_rtree = (build-asdf-system { - pname = "cl-rrt.rtree"; - version = "20200925-git"; - asds = [ "cl-rrt.rtree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rrt/2020-09-25/cl-rrt-20200925-git.tgz"; - sha256 = "0lf1dvw5j9awy7ic1i4j5wd7657a170ywxihinmsdn4bwd4fynv0"; - system = "cl-rrt.rtree"; - asd = "cl-rrt.rtree"; - }); - systems = [ "cl-rrt.rtree" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cl-rrt" self) (getAttr "cl-syntax-annot" self) (getAttr "iterate" self) (getAttr "spatial-trees" self) (getAttr "spatial-trees_dot_nns" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rrt_dot_test = (build-asdf-system { - pname = "cl-rrt.test"; - version = "20200925-git"; - asds = [ "cl-rrt.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rrt/2020-09-25/cl-rrt-20200925-git.tgz"; - sha256 = "0lf1dvw5j9awy7ic1i4j5wd7657a170ywxihinmsdn4bwd4fynv0"; - system = "cl-rrt.test"; - asd = "cl-rrt.test"; - }); - systems = [ "cl-rrt.test" ]; - lispLibs = [ (getAttr "cl-rrt" self) (getAttr "cl-rrt_dot_rtree" self) (getAttr "fiveam" self) (getAttr "vecto" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rsvg2 = (build-asdf-system { - pname = "cl-rsvg2"; - version = "20200925-git"; - asds = [ "cl-rsvg2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rsvg2/2020-09-25/cl-rsvg2-20200925-git.tgz"; - sha256 = "1amq4q27lj0nzffvwmqrkg8v9pdcf0281zzrvxl9w6vdm9qy1v3n"; - system = "cl-rsvg2"; - asd = "cl-rsvg2"; - }); - systems = [ "cl-rsvg2" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-cairo2" self) (getAttr "cl-gtk2-glib" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - cl-rsvg2-pixbuf = (build-asdf-system { - pname = "cl-rsvg2-pixbuf"; - version = "20200925-git"; - asds = [ "cl-rsvg2-pixbuf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rsvg2/2020-09-25/cl-rsvg2-20200925-git.tgz"; - sha256 = "1amq4q27lj0nzffvwmqrkg8v9pdcf0281zzrvxl9w6vdm9qy1v3n"; - system = "cl-rsvg2-pixbuf"; - asd = "cl-rsvg2-pixbuf"; - }); - systems = [ "cl-rsvg2-pixbuf" ]; - lispLibs = [ (getAttr "cl-gtk2-gdk" self) (getAttr "cl-rsvg2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rsvg2-test = (build-asdf-system { - pname = "cl-rsvg2-test"; - version = "20200925-git"; - asds = [ "cl-rsvg2-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rsvg2/2020-09-25/cl-rsvg2-20200925-git.tgz"; - sha256 = "1amq4q27lj0nzffvwmqrkg8v9pdcf0281zzrvxl9w6vdm9qy1v3n"; - system = "cl-rsvg2-test"; - asd = "cl-rsvg2-test"; - }); - systems = [ "cl-rsvg2-test" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-rsvg2" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rules = (build-asdf-system { - pname = "cl-rules"; - version = "20190710-git"; - asds = [ "cl-rules" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rules/2019-07-10/cl-rules-20190710-git.tgz"; - sha256 = "0jidck62n0jkfqwrpqjn43zmjb3jlfaxxhn2lsyfwy2740i8ppr1"; - system = "cl-rules"; - asd = "cl-rules"; - }); - systems = [ "cl-rules" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-yaml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-rules-test = (build-asdf-system { - pname = "cl-rules-test"; - version = "20190710-git"; - asds = [ "cl-rules-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rules/2019-07-10/cl-rules-20190710-git.tgz"; - sha256 = "0jidck62n0jkfqwrpqjn43zmjb3jlfaxxhn2lsyfwy2740i8ppr1"; - system = "cl-rules-test"; - asd = "cl-rules-test"; - }); - systems = [ "cl-rules-test" ]; - lispLibs = [ (getAttr "cl-rules" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-s3 = (build-asdf-system { - pname = "cl-s3"; - version = "20130128-git"; - asds = [ "cl-s3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-s3/2013-01-28/cl-s3-20130128-git.tgz"; - sha256 = "1lbvf7phkm5vjk013p484rh4vh33i58jlqq3z4cv2yxqcw6r639d"; - system = "cl-s3"; - asd = "cl-s3"; - }); - systems = [ "cl-s3" ]; - lispLibs = [ (getAttr "ironclad" self) (getAttr "s-base64" self) (getAttr "s-http-client" self) (getAttr "s-utils" self) (getAttr "s-xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sam = (build-asdf-system { - pname = "cl-sam"; - version = "20150608-git"; - asds = [ "cl-sam" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sam/2015-06-08/cl-sam-20150608-git.tgz"; - sha256 = "0frrxz70jin4sa5n087zm4ikckf1zdjqqpjq3llrv46753c62fc6"; - system = "cl-sam"; - asd = "cl-sam"; - }); - systems = [ "cl-sam" ]; - lispLibs = [ (getAttr "deoxybyte-gzip" self) (getAttr "deoxybyte-systems" self) (getAttr "deoxybyte-unix" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sam-test = (build-asdf-system { - pname = "cl-sam-test"; - version = "20150608-git"; - asds = [ "cl-sam-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sam/2015-06-08/cl-sam-20150608-git.tgz"; - sha256 = "0frrxz70jin4sa5n087zm4ikckf1zdjqqpjq3llrv46753c62fc6"; - system = "cl-sam-test"; - asd = "cl-sam-test"; - }); - systems = [ "cl-sam-test" ]; - lispLibs = [ (getAttr "cl-sam" self) (getAttr "deoxybyte-io" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sandbox = (build-asdf-system { - pname = "cl-sandbox"; - version = "20180131-git"; - asds = [ "cl-sandbox" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sandbox/2018-01-31/cl-sandbox-20180131-git.tgz"; - sha256 = "053zxy3zi5jvlbg8zxlf922sxb32mq34zvwfhgpj4rcmgvgmqnxv"; - system = "cl-sandbox"; - asd = "cl-sandbox"; - }); - systems = [ "cl-sandbox" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sasl = (build-asdf-system { - pname = "cl-sasl"; - version = "v0.3.2"; - asds = [ "cl-sasl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sasl/2019-05-21/cl-sasl-v0.3.2.tgz"; - sha256 = "0a05q8rls2hn46rbbk6w5km9kqvhsj365zlw6hp32724xy2nd98w"; - system = "cl-sasl"; - asd = "cl-sasl"; - }); - systems = [ "cl-sasl" ]; - lispLibs = [ (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sat = (build-asdf-system { - pname = "cl-sat"; - version = "20220707-git"; - asds = [ "cl-sat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sat/2022-07-07/cl-sat-20220707-git.tgz"; - sha256 = "1fcvxpmja757vyyhcpb00g150dyx90jsg9z8s596vy1nb0z81f49"; - system = "cl-sat"; - asd = "cl-sat"; - }); - systems = [ "cl-sat" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "trivia" self) (getAttr "trivial-features" self) ]; - meta = {}; - }); - cl-sat_dot_glucose = (build-asdf-system { - pname = "cl-sat.glucose"; - version = "20220331-git"; - asds = [ "cl-sat.glucose" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sat.glucose/2022-03-31/cl-sat.glucose-20220331-git.tgz"; - sha256 = "11hbhsjzw3xzz6i6niisk5h271kg52y3y77sl6ljnszfgp9xjfxy"; - system = "cl-sat.glucose"; - asd = "cl-sat.glucose"; - }); - systems = [ "cl-sat.glucose" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-sat" self) (getAttr "iterate" self) (getAttr "trivia" self) (getAttr "trivial-package-manager" self) ]; - meta = {}; - }); - cl-sat_dot_glucose_dot_test = (build-asdf-system { - pname = "cl-sat.glucose.test"; - version = "20220331-git"; - asds = [ "cl-sat.glucose.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sat.glucose/2022-03-31/cl-sat.glucose-20220331-git.tgz"; - sha256 = "11hbhsjzw3xzz6i6niisk5h271kg52y3y77sl6ljnszfgp9xjfxy"; - system = "cl-sat.glucose.test"; - asd = "cl-sat.glucose.test"; - }); - systems = [ "cl-sat.glucose.test" ]; - lispLibs = [ (getAttr "cl-sat_dot_glucose" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sat_dot_minisat = (build-asdf-system { - pname = "cl-sat.minisat"; - version = "20241012-git"; - asds = [ "cl-sat.minisat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sat.minisat/2024-10-12/cl-sat.minisat-20241012-git.tgz"; - sha256 = "00h5smjs60r1abq27w2ayg55ypsw32769pkk72mrikyn29r6z9ni"; - system = "cl-sat.minisat"; - asd = "cl-sat.minisat"; - }); - systems = [ "cl-sat.minisat" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-sat" self) (getAttr "iterate" self) (getAttr "trivia" self) (getAttr "trivial-package-manager" self) ]; - meta = {}; - }); - cl-sat_dot_minisat_dot_test = (build-asdf-system { - pname = "cl-sat.minisat.test"; - version = "20241012-git"; - asds = [ "cl-sat.minisat.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sat.minisat/2024-10-12/cl-sat.minisat-20241012-git.tgz"; - sha256 = "00h5smjs60r1abq27w2ayg55ypsw32769pkk72mrikyn29r6z9ni"; - system = "cl-sat.minisat.test"; - asd = "cl-sat.minisat.test"; - }); - systems = [ "cl-sat.minisat.test" ]; - lispLibs = [ (getAttr "cl-sat_dot_minisat" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sat_dot_test = (build-asdf-system { - pname = "cl-sat.test"; - version = "20220707-git"; - asds = [ "cl-sat.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sat/2022-07-07/cl-sat-20220707-git.tgz"; - sha256 = "1fcvxpmja757vyyhcpb00g150dyx90jsg9z8s596vy1nb0z81f49"; - system = "cl-sat.test"; - asd = "cl-sat.test"; - }); - systems = [ "cl-sat.test" ]; - lispLibs = [ (getAttr "cl-sat" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-scram = (build-asdf-system { - pname = "cl-scram"; - version = "20150923-git"; - asds = [ "cl-scram" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-scram/2015-09-23/cl-scram-20150923-git.tgz"; - sha256 = "1absr9h9z79f1fbs4g33y2rc9jsqjs7vd2l5sl8dvqq4fyx8v6g0"; - system = "cl-scram"; - asd = "cl-scram"; - }); - systems = [ "cl-scram" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "cl-sasl" self) (getAttr "ironclad" self) (getAttr "secure-random" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-scribd = (build-asdf-system { - pname = "cl-scribd"; - version = "20130312-git"; - asds = [ "cl-scribd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-scribd/2013-03-12/cl-scribd-20130312-git.tgz"; - sha256 = "0r4ah3f1ndi66bm1mir3ldl31sfbmav0kdfpb16f1n9931452mry"; - system = "cl-scribd"; - asd = "cl-scribd"; - }); - systems = [ "cl-scribd" ]; - lispLibs = [ (getAttr "cxml" self) (getAttr "drakma" self) (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-scripting = (build-asdf-system { - pname = "cl-scripting"; - version = "20211020-git"; - asds = [ "cl-scripting" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-scripting/2021-10-20/cl-scripting-20211020-git.tgz"; - sha256 = "1xi8klkn4fhmcrnhxzxvl0rj68dc7az6l2hc10560g9jvblcmmpp"; - system = "cl-scripting"; - asd = "cl-scripting"; - }); - systems = [ "cl-scripting" ]; - lispLibs = [ (getAttr "cl-launch" self) (getAttr "fare-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-scrobbler = (build-asdf-system { - pname = "cl-scrobbler"; - version = "20111105-git"; - asds = [ "cl-scrobbler" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-scrobbler/2011-11-05/cl-scrobbler-20111105-git.tgz"; - sha256 = "0cd0zfmhxf5chcg7hncavfjr8m06cjbiyqylk76z8mprdsv1n062"; - system = "cl-scrobbler"; - asd = "cl-scrobbler"; - }); - systems = [ "cl-scrobbler" ]; - lispLibs = [ (getAttr "arnesi" self) (getAttr "cl-store" self) (getAttr "drakma" self) (getAttr "flexi-streams" self) (getAttr "md5" self) (getAttr "st-json" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-scrobbler-tests = (build-asdf-system { - pname = "cl-scrobbler-tests"; - version = "20111105-git"; - asds = [ "cl-scrobbler-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-scrobbler/2011-11-05/cl-scrobbler-20111105-git.tgz"; - sha256 = "0cd0zfmhxf5chcg7hncavfjr8m06cjbiyqylk76z8mprdsv1n062"; - system = "cl-scrobbler-tests"; - asd = "cl-scrobbler"; - }); - systems = [ "cl-scrobbler-tests" ]; - lispLibs = [ (getAttr "cl-scrobbler" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-scsu = (build-asdf-system { - pname = "cl-scsu"; - version = "20221106-git"; - asds = [ "cl-scsu" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-scsu/2022-11-06/cl-scsu-20221106-git.tgz"; - sha256 = "0jiqyayflyyrdks4yl894vzw2bkxkd87w4sy4n6ikjz450xk3yxf"; - system = "cl-scsu"; - asd = "cl-scsu"; - }); - systems = [ "cl-scsu" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-scsu-test = (build-asdf-system { - pname = "cl-scsu-test"; - version = "20221106-git"; - asds = [ "cl-scsu-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-scsu/2022-11-06/cl-scsu-20221106-git.tgz"; - sha256 = "0jiqyayflyyrdks4yl894vzw2bkxkd87w4sy4n6ikjz450xk3yxf"; - system = "cl-scsu-test"; - asd = "cl-scsu-test"; - }); - systems = [ "cl-scsu-test" ]; - lispLibs = [ (getAttr "_1am" self) (getAttr "alexandria" self) (getAttr "cl-scsu" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-selenium = (build-asdf-system { - pname = "cl-selenium"; - version = "20180328-git"; - asds = [ "cl-selenium" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-selenium-webdriver/2018-03-28/cl-selenium-webdriver-20180328-git.tgz"; - sha256 = "0216vqg1ax5gcqahclii7ifqpc92rbi86rfcf1qn8bdahmfjccbb"; - system = "cl-selenium"; - asd = "cl-selenium"; - }); - systems = [ "cl-selenium" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-json" self) (getAttr "dexador" self) (getAttr "quri" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-selenium-test = (build-asdf-system { - pname = "cl-selenium-test"; - version = "20180328-git"; - asds = [ "cl-selenium-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-selenium-webdriver/2018-03-28/cl-selenium-webdriver-20180328-git.tgz"; - sha256 = "0216vqg1ax5gcqahclii7ifqpc92rbi86rfcf1qn8bdahmfjccbb"; - system = "cl-selenium-test"; - asd = "cl-selenium-test"; - }); - systems = [ "cl-selenium-test" ]; - lispLibs = [ (getAttr "cl-selenium" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-semver = (build-asdf-system { - pname = "cl-semver"; - version = "20230618-git"; - asds = [ "cl-semver" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-semver/2023-06-18/cl-semver-20230618-git.tgz"; - sha256 = "1zlcn7lrpvjiixgqm4yxnqqwak1hxfmxmchkpvrly41yhl586ril"; - system = "cl-semver"; - asd = "cl-semver"; - }); - systems = [ "cl-semver" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "esrap" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-semver-test = (build-asdf-system { - pname = "cl-semver-test"; - version = "20230618-git"; - asds = [ "cl-semver-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-semver/2023-06-18/cl-semver-20230618-git.tgz"; - sha256 = "1zlcn7lrpvjiixgqm4yxnqqwak1hxfmxmchkpvrly41yhl586ril"; - system = "cl-semver-test"; - asd = "cl-semver-test"; - }); - systems = [ "cl-semver-test" ]; - lispLibs = [ (getAttr "cl-semver" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sentiment = (build-asdf-system { - pname = "cl-sentiment"; - version = "20130128-git"; - asds = [ "cl-sentiment" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sentiment/2013-01-28/cl-sentiment-20130128-git.tgz"; - sha256 = "18jx6ivbzcg9bsmp1pmlqvzr4kfxzll75b4viz1hrkq78nsnpp5v"; - system = "cl-sentiment"; - asd = "cl-sentiment"; - }); - systems = [ "cl-sentiment" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "rt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-server-manager = (build-asdf-system { - pname = "cl-server-manager"; - version = "20231021-git"; - asds = [ "cl-server-manager" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-server-manager/2023-10-21/cl-server-manager-20231021-git.tgz"; - sha256 = "0vrdn9iiwmx2zg7lrw56dqjaxbb9fvn4107qxgp3n3z8zxhiw03s"; - system = "cl-server-manager"; - asd = "cl-server-manager"; - }); - systems = [ "cl-server-manager" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "hunchentoot" self) (getAttr "prepl" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ses4 = (build-asdf-system { - pname = "cl-ses4"; - version = "20221106-git"; - asds = [ "cl-ses4" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ses4/2022-11-06/cl-ses4-20221106-git.tgz"; - sha256 = "1n31k81i19hx26h9wcz39fsciq92hbblnbd15krblx9g877a1598"; - system = "cl-ses4"; - asd = "cl-ses4"; - }); - systems = [ "cl-ses4" ]; - lispLibs = [ (getAttr "arrow-macros" self) (getAttr "cl-base64" self) (getAttr "cl-ppcre" self) (getAttr "dexador" self) (getAttr "ironclad" self) (getAttr "local-time" self) (getAttr "quickapp" self) (getAttr "quri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-setlocale = (build-asdf-system { - pname = "cl-setlocale"; - version = "20201220-git"; - asds = [ "cl-setlocale" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-setlocale/2020-12-20/cl-setlocale-20201220-git.tgz"; - sha256 = "0g1b89yj6n42ayf2074krk3h9yvglqxn54a6i3sxgpsqww2ll2a1"; - system = "cl-setlocale"; - asd = "cl-setlocale"; - }); - systems = [ "cl-setlocale" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sha1 = (build-asdf-system { - pname = "cl-sha1"; - version = "20210807-git"; - asds = [ "cl-sha1" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sha1/2021-08-07/cl-sha1-20210807-git.tgz"; - sha256 = "16hczcr7ghah0p9fi29ddrw5c4zbb2d4765iigfx7yrgk5z5jb8p"; - system = "cl-sha1"; - asd = "cl-sha1"; - }); - systems = [ "cl-sha1" ]; - lispLibs = [ (getAttr "cl-base64" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-shellwords = (build-asdf-system { - pname = "cl-shellwords"; - version = "20150923-git"; - asds = [ "cl-shellwords" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-shellwords/2015-09-23/cl-shellwords-20150923-git.tgz"; - sha256 = "0im8cni1ig5zaha9gbmma7zk1xxa4xajvzfgalvl2f0fhvksl4pn"; - system = "cl-shellwords"; - asd = "cl-shellwords"; - }); - systems = [ "cl-shellwords" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = {}; - }); - cl-shellwords-test = (build-asdf-system { - pname = "cl-shellwords-test"; - version = "20150923-git"; - asds = [ "cl-shellwords-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-shellwords/2015-09-23/cl-shellwords-20150923-git.tgz"; - sha256 = "0im8cni1ig5zaha9gbmma7zk1xxa4xajvzfgalvl2f0fhvksl4pn"; - system = "cl-shellwords-test"; - asd = "cl-shellwords-test"; - }); - systems = [ "cl-shellwords-test" ]; - lispLibs = [ (getAttr "cl-shellwords" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-simple-concurrent-jobs = (build-asdf-system { - pname = "cl-simple-concurrent-jobs"; - version = "20150505-git"; - asds = [ "cl-simple-concurrent-jobs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-simple-concurrent-jobs/2015-05-05/cl-simple-concurrent-jobs-20150505-git.tgz"; - sha256 = "0mv7svsil58h8v8kq9965bpbradmhfpyrmi61dbzp5mbw8c5mrwj"; - system = "cl-simple-concurrent-jobs"; - asd = "cl-simple-concurrent-jobs"; - }); - systems = [ "cl-simple-concurrent-jobs" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "chanl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-simple-table = (build-asdf-system { - pname = "cl-simple-table"; - version = "20130312-git"; - asds = [ "cl-simple-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-simple-table/2013-03-12/cl-simple-table-20130312-git.tgz"; - sha256 = "1pnczi5hbqlyxxvzlpy6vc58qc9hh9mdm5rgq304bp3v2qajh0b7"; - system = "cl-simple-table"; - asd = "cl-simple-table"; - }); - systems = [ "cl-simple-table" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-singleton-mixin = (build-asdf-system { - pname = "cl-singleton-mixin"; - version = "20150505-git"; - asds = [ "cl-singleton-mixin" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-singleton-mixin/2015-05-05/cl-singleton-mixin-20150505-git.tgz"; - sha256 = "10dvwzx1kw9ac163i6sc8yfg3hpkn0dlq4hf6qipb46b4mcib01s"; - system = "cl-singleton-mixin"; - asd = "cl-singleton-mixin"; - }); - systems = [ "cl-singleton-mixin" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "metap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-singleton-mixin-test = (build-asdf-system { - pname = "cl-singleton-mixin-test"; - version = "20150505-git"; - asds = [ "cl-singleton-mixin-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-singleton-mixin/2015-05-05/cl-singleton-mixin-20150505-git.tgz"; - sha256 = "10dvwzx1kw9ac163i6sc8yfg3hpkn0dlq4hf6qipb46b4mcib01s"; - system = "cl-singleton-mixin-test"; - asd = "cl-singleton-mixin-test"; - }); - systems = [ "cl-singleton-mixin-test" ]; - lispLibs = [ (getAttr "cl-singleton-mixin" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-skip-list = (build-asdf-system { - pname = "cl-skip-list"; - version = "20220707-git"; - asds = [ "cl-skip-list" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-skip-list/2022-07-07/cl-skip-list-20220707-git.tgz"; - sha256 = "1k3hbi9n1yzky3hjcg48jkkkp2jx5vm7bsywhnyyb1z6hz5phakd"; - system = "cl-skip-list"; - asd = "cl-skip-list"; - }); - systems = [ "cl-skip-list" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-skkserv = (build-asdf-system { - pname = "cl-skkserv"; - version = "20241012-git"; - asds = [ "cl-skkserv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-skkserv/2024-10-12/cl-skkserv-20241012-git.tgz"; - sha256 = "1fnar6iw6hr5w37sc96zk9kdcgam8bm71l26l7c6f5daxk57labi"; - system = "cl-skkserv"; - asd = "cl-skkserv"; - }); - systems = [ "cl-skkserv" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "esrap" self) (getAttr "flexi-streams" self) (getAttr "jp-numeral" self) (getAttr "named-readtables" self) (getAttr "papyrus" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-slice = (build-asdf-system { - pname = "cl-slice"; - version = "20210531-git"; - asds = [ "cl-slice" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-slice/2021-05-31/cl-slice-20210531-git.tgz"; - sha256 = "1ybznf4y5lda6bn163jcvj281qzhm24dfcwhbgxmm5n6f27gdccl"; - system = "cl-slice"; - asd = "cl-slice"; - }); - systems = [ "cl-slice" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "let-plus" self) ]; - meta = {}; - }); - cl-slice-tests = (build-asdf-system { - pname = "cl-slice-tests"; - version = "20210531-git"; - asds = [ "cl-slice-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-slice/2021-05-31/cl-slice-20210531-git.tgz"; - sha256 = "1ybznf4y5lda6bn163jcvj281qzhm24dfcwhbgxmm5n6f27gdccl"; - system = "cl-slice-tests"; - asd = "cl-slice"; - }); - systems = [ "cl-slice-tests" ]; - lispLibs = [ (getAttr "cl-slice" self) (getAttr "clunit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-slp = (build-asdf-system { - pname = "cl-slp"; - version = "20140826-git"; - asds = [ "cl-slp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-slp/2014-08-26/cl-slp-20140826-git.tgz"; - sha256 = "10wfrw6r6w646lzx0nasnfvjpy63icxl8qm4888dpcjc57y1cd1w"; - system = "cl-slp"; - asd = "cl-slp"; - }); - systems = [ "cl-slp" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-slug = (build-asdf-system { - pname = "cl-slug"; - version = "20180228-git"; - asds = [ "cl-slug" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-slug/2018-02-28/cl-slug-20180228-git.tgz"; - sha256 = "1asdq6xllmsvfw5fky9wblqcx9isac9jrrlkfl7vyxcq1wxrnflx"; - system = "cl-slug"; - asd = "cl-slug"; - }); - systems = [ "cl-slug" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-slug-test = (build-asdf-system { - pname = "cl-slug-test"; - version = "20180228-git"; - asds = [ "cl-slug-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-slug/2018-02-28/cl-slug-20180228-git.tgz"; - sha256 = "1asdq6xllmsvfw5fky9wblqcx9isac9jrrlkfl7vyxcq1wxrnflx"; - system = "cl-slug-test"; - asd = "cl-slug-test"; - }); - systems = [ "cl-slug-test" ]; - lispLibs = [ (getAttr "cl-slug" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-slugify = (build-asdf-system { - pname = "cl-slugify"; - version = "20230618-git"; - asds = [ "cl-slugify" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-slugify/2023-06-18/cl-slugify-20230618-git.tgz"; - sha256 = "18vjz9xb8q73j2bd609if2r6svljsnivl3sniz2p7j7w0qppps72"; - system = "cl-slugify"; - asd = "cl-slugify"; - }); - systems = [ "cl-slugify" ]; - lispLibs = [ (getAttr "cl-unac" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-slugify_dot_tests = (build-asdf-system { - pname = "cl-slugify.tests"; - version = "20230618-git"; - asds = [ "cl-slugify.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-slugify/2023-06-18/cl-slugify-20230618-git.tgz"; - sha256 = "18vjz9xb8q73j2bd609if2r6svljsnivl3sniz2p7j7w0qppps72"; - system = "cl-slugify.tests"; - asd = "cl-slugify.tests"; - }); - systems = [ "cl-slugify.tests" ]; - lispLibs = [ (getAttr "cl-slugify" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-smt-lib = (build-asdf-system { - pname = "cl-smt-lib"; - version = "20220331-git"; - asds = [ "cl-smt-lib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-smt-lib/2022-03-31/cl-smt-lib-20220331-git.tgz"; - sha256 = "09xqpmzd8rmp4dkj6mzwlwnhqk266abqvskz9dm6mr3cnf2r774z"; - system = "cl-smt-lib"; - asd = "cl-smt-lib"; - }); - systems = [ "cl-smt-lib" ]; - lispLibs = [ (getAttr "asdf-package-system" self) (getAttr "named-readtables" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - cl-smtp = (build-asdf-system { - pname = "cl-smtp"; - version = "20241012-git"; - asds = [ "cl-smtp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-smtp/2024-10-12/cl-smtp-20241012-git.tgz"; - sha256 = "1r4gsklf4p163hn4ylabx7lp5zkz27v6gq3rkyrvwb7qz6sv8ws4"; - system = "cl-smtp"; - asd = "cl-smtp"; - }); - systems = [ "cl-smtp" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl_plus_ssl" self) (getAttr "cl-base64" self) (getAttr "flexi-streams" self) (getAttr "frugal-uuid" self) (getAttr "usocket" self) ]; - meta = {}; - }); - cl-smtp-tests = (build-asdf-system { - pname = "cl-smtp-tests"; - version = "20241012-git"; - asds = [ "cl-smtp-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-smtp/2024-10-12/cl-smtp-20241012-git.tgz"; - sha256 = "1r4gsklf4p163hn4ylabx7lp5zkz27v6gq3rkyrvwb7qz6sv8ws4"; - system = "cl-smtp-tests"; - asd = "cl-smtp-tests"; - }); - systems = [ "cl-smtp-tests" ]; - lispLibs = [ (getAttr "cl-smtp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-soil = (build-asdf-system { - pname = "cl-soil"; - version = "release-quicklisp-f27087ce-git"; - asds = [ "cl-soil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-soil/2018-08-31/cl-soil-release-quicklisp-f27087ce-git.tgz"; - sha256 = "0mnz5yaw3kc14ja9g4j7dxh96kd82ifj25gy0dil7kqjd08lwcq9"; - system = "cl-soil"; - asd = "cl-soil"; - }); - systems = [ "cl-soil" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-opengl" self) (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-soloud = (build-asdf-system { - pname = "cl-soloud"; - version = "20231021-git"; - asds = [ "cl-soloud" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-soloud/2023-10-21/cl-soloud-20231021-git.tgz"; - sha256 = "0r0z365gcgf93vy8g2nbjwgh5r04gv0l645l2knvip420jxqqp1c"; - system = "cl-soloud"; - asd = "cl-soloud"; - }); - systems = [ "cl-soloud" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-mpg123" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) (getAttr "trivial-indent" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sophia = (build-asdf-system { - pname = "cl-sophia"; - version = "20150608-git"; - asds = [ "cl-sophia" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sophia/2015-06-08/cl-sophia-20150608-git.tgz"; - sha256 = "1x027mr7lg5fs0d82n5mshnd19kan76y3zb9yxbcnq222l4j8j00"; - system = "cl-sophia"; - asd = "cl-sophia"; - }); - systems = [ "cl-sophia" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-fad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sophia-test = (build-asdf-system { - pname = "cl-sophia-test"; - version = "20150608-git"; - asds = [ "cl-sophia-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sophia/2015-06-08/cl-sophia-20150608-git.tgz"; - sha256 = "1x027mr7lg5fs0d82n5mshnd19kan76y3zb9yxbcnq222l4j8j00"; - system = "cl-sophia-test"; - asd = "cl-sophia"; - }); - systems = [ "cl-sophia-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "cl-sophia" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-spark = (build-asdf-system { - pname = "cl-spark"; - version = "20150709-git"; - asds = [ "cl-spark" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-spark/2015-07-09/cl-spark-20150709-git.tgz"; - sha256 = "0my1fsgi2rjaqkpk934f2bjy63pmnj7faza3fzvnk6k3l66y19nk"; - system = "cl-spark"; - asd = "cl-spark"; - }); - systems = [ "cl-spark" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-spark-test = (build-asdf-system { - pname = "cl-spark-test"; - version = "20150709-git"; - asds = [ "cl-spark-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-spark/2015-07-09/cl-spark-20150709-git.tgz"; - sha256 = "0my1fsgi2rjaqkpk934f2bjy63pmnj7faza3fzvnk6k3l66y19nk"; - system = "cl-spark-test"; - asd = "cl-spark-test"; - }); - systems = [ "cl-spark-test" ]; - lispLibs = [ (getAttr "cl-spark" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sparql = (build-asdf-system { - pname = "cl-sparql"; - version = "20220331-git"; - asds = [ "cl-sparql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sparql/2022-03-31/cl-sparql-20220331-git.tgz"; - sha256 = "1fjp5a25yly3l3pg07gzhz8q830fcaz0dwspigw8v90sx4insz0p"; - system = "cl-sparql"; - asd = "cl-sparql"; - }); - systems = [ "cl-sparql" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "parser-combinators" self) (getAttr "puri" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sparql-tests = (build-asdf-system { - pname = "cl-sparql-tests"; - version = "20220331-git"; - asds = [ "cl-sparql-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sparql/2022-03-31/cl-sparql-20220331-git.tgz"; - sha256 = "1fjp5a25yly3l3pg07gzhz8q830fcaz0dwspigw8v90sx4insz0p"; - system = "cl-sparql-tests"; - asd = "cl-sparql-tests"; - }); - systems = [ "cl-sparql-tests" ]; - lispLibs = [ (getAttr "cl-sparql" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-speedy-queue = (build-asdf-system { - pname = "cl-speedy-queue"; - version = "20150302-git"; - asds = [ "cl-speedy-queue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-speedy-queue/2015-03-02/cl-speedy-queue-20150302-git.tgz"; - sha256 = "0czhnvxn9lvbjz9h1lb7y18nqrsq3drq5icd3lqdaa07362alriq"; - system = "cl-speedy-queue"; - asd = "cl-speedy-queue"; - }); - systems = [ "cl-speedy-queue" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-spidev = (build-asdf-system { - pname = "cl-spidev"; - version = "20231021-git"; - asds = [ "cl-spidev" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-spidev/2023-10-21/cl-spidev-20231021-git.tgz"; - sha256 = "1dhh6hb2myw8p04psdhdjmikl02r66szpg70yapgyqpycb9yg0l3"; - system = "cl-spidev"; - asd = "cl-spidev"; - }); - systems = [ "cl-spidev" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ssdb = (build-asdf-system { - pname = "cl-ssdb"; - version = "20210124-git"; - asds = [ "cl-ssdb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ssdb/2021-01-24/cl-ssdb-20210124-git.tgz"; - sha256 = "05l0wg4a1kxgggmg1nalq811by76lja0gpa2c4i999h74bf4n3dc"; - system = "cl-ssdb"; - asd = "cl-ssdb"; - }); - systems = [ "cl-ssdb" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "parse-number" self) (getAttr "rutils" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ssdb-test = (build-asdf-system { - pname = "cl-ssdb-test"; - version = "20210124-git"; - asds = [ "cl-ssdb-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ssdb/2021-01-24/cl-ssdb-20210124-git.tgz"; - sha256 = "05l0wg4a1kxgggmg1nalq811by76lja0gpa2c4i999h74bf4n3dc"; - system = "cl-ssdb-test"; - asd = "cl-ssdb-test"; - }); - systems = [ "cl-ssdb-test" ]; - lispLibs = [ (getAttr "cl-ssdb" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ssh-keys = (build-asdf-system { - pname = "cl-ssh-keys"; - version = "20241012-git"; - asds = [ "cl-ssh-keys" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ssh-keys/2024-10-12/cl-ssh-keys-20241012-git.tgz"; - sha256 = "037j89fjjrld46m9j71x6zfixdm7irwd58c08j0gq6w09qjlk5l2"; - system = "cl-ssh-keys"; - asd = "cl-ssh-keys"; - }); - systems = [ "cl-ssh-keys" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-base64" self) (getAttr "cl-rfc4251" self) (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-ssh-keys_dot_test = (build-asdf-system { - pname = "cl-ssh-keys.test"; - version = "20241012-git"; - asds = [ "cl-ssh-keys.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ssh-keys/2024-10-12/cl-ssh-keys-20241012-git.tgz"; - sha256 = "037j89fjjrld46m9j71x6zfixdm7irwd58c08j0gq6w09qjlk5l2"; - system = "cl-ssh-keys.test"; - asd = "cl-ssh-keys.test"; - }); - systems = [ "cl-ssh-keys.test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ssh-keys" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-statsd = (build-asdf-system { - pname = "cl-statsd"; - version = "20170124-git"; - asds = [ "cl-statsd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-statsd/2017-01-24/cl-statsd-20170124-git.tgz"; - sha256 = "1l2sxbzhp7wwalxn8k0k1gis9c9w462fygfw4ps0s1bnhgbvr6qb"; - system = "cl-statsd"; - asd = "cl-statsd"; - }); - systems = [ "cl-statsd" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-interpol" self) (getAttr "local-time" self) (getAttr "log4cl" self) (getAttr "safe-queue" self) (getAttr "trivial-utf-8" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-statsd_dot_test = (build-asdf-system { - pname = "cl-statsd.test"; - version = "20170124-git"; - asds = [ "cl-statsd.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-statsd/2017-01-24/cl-statsd-20170124-git.tgz"; - sha256 = "1l2sxbzhp7wwalxn8k0k1gis9c9w462fygfw4ps0s1bnhgbvr6qb"; - system = "cl-statsd.test"; - asd = "cl-statsd.test"; - }); - systems = [ "cl-statsd.test" ]; - lispLibs = [ (getAttr "cl-statsd" self) (getAttr "log4cl" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-steamworks = (build-asdf-system { - pname = "cl-steamworks"; - version = "20241012-git"; - asds = [ "cl-steamworks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-steamworks/2024-10-12/cl-steamworks-20241012-git.tgz"; - sha256 = "0401gfmzcc29pm15yyl0p36id0yza2i02wixma2zl8ah3cxb39w5"; - system = "cl-steamworks"; - asd = "cl-steamworks"; - }); - systems = [ "cl-steamworks" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "float-features" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-steamworks-generator = (build-asdf-system { - pname = "cl-steamworks-generator"; - version = "20241012-git"; - asds = [ "cl-steamworks-generator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-steamworks/2024-10-12/cl-steamworks-20241012-git.tgz"; - sha256 = "0401gfmzcc29pm15yyl0p36id0yza2i02wixma2zl8ah3cxb39w5"; - system = "cl-steamworks-generator"; - asd = "cl-steamworks-generator"; - }); - systems = [ "cl-steamworks-generator" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-ppcre" self) (getAttr "parse-number" self) (getAttr "pathname-utils" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-stomp = (build-asdf-system { - pname = "cl-stomp"; - version = "20200925-git"; - asds = [ "cl-stomp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-stomp/2020-09-25/cl-stomp-20200925-git.tgz"; - sha256 = "180y0x53ghsvz6n0bz67aw69p962bsslarikk89rf41kcv998xvw"; - system = "cl-stomp"; - asd = "cl-stomp"; - }); - systems = [ "cl-stomp" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-stopwatch = (build-asdf-system { - pname = "cl-stopwatch"; - version = "20230618-git"; - asds = [ "cl-stopwatch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-stopwatch/2023-06-18/cl-stopwatch-20230618-git.tgz"; - sha256 = "14jmylqk1kijbhhn897r76ii4xg32k22p4v7h29jbcs9y2mn2day"; - system = "cl-stopwatch"; - asd = "cl-stopwatch"; - }); - systems = [ "cl-stopwatch" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-store = (build-asdf-system { - pname = "cl-store"; - version = "20230214-git"; - asds = [ "cl-store" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-store/2023-02-14/cl-store-20230214-git.tgz"; - sha256 = "1kw39lmbiaksrxsq8pf5np8vjarymcvlc451z83275194av3imix"; - system = "cl-store"; - asd = "cl-store"; - }); - systems = [ "cl-store" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-store-tests = (build-asdf-system { - pname = "cl-store-tests"; - version = "20230214-git"; - asds = [ "cl-store-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-store/2023-02-14/cl-store-20230214-git.tgz"; - sha256 = "1kw39lmbiaksrxsq8pf5np8vjarymcvlc451z83275194av3imix"; - system = "cl-store-tests"; - asd = "cl-store"; - }); - systems = [ "cl-store-tests" ]; - lispLibs = [ (getAttr "cl-store" self) (getAttr "rt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-stream = (build-asdf-system { - pname = "cl-stream"; - version = "20190521-git"; - asds = [ "cl-stream" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-stream/2019-05-21/cl-stream-20190521-git.tgz"; - sha256 = "1r2spbcx3ifz51yq2pxkdb1n2k5fvyg3pz3w42mnw99pq78cbasv"; - system = "cl-stream"; - asd = "cl-stream"; - }); - systems = [ "cl-stream" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-strftime = (build-asdf-system { - pname = "cl-strftime"; - version = "20160318-git"; - asds = [ "cl-strftime" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-strftime/2016-03-18/cl-strftime-20160318-git.tgz"; - sha256 = "00c8hq7vzgb89ab3q7mrp60x743kiqmsk1g51ynhxlqhph2bnslf"; - system = "cl-strftime"; - asd = "cl-strftime"; - }); - systems = [ "cl-strftime" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "local-time" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-string-complete = (build-asdf-system { - pname = "cl-string-complete"; - version = "20230618-git"; - asds = [ "cl-string-complete" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-string-complete/2023-06-18/cl-string-complete-20230618-git.tgz"; - sha256 = "14l1yyz5fakz5xn31yjfn4mz7j9rcbijw1sp4mdfizfvjbbwcixl"; - system = "cl-string-complete"; - asd = "cl-string-complete"; - }); - systems = [ "cl-string-complete" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-string-generator = (build-asdf-system { - pname = "cl-string-generator"; - version = "20210630-git"; - asds = [ "cl-string-generator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-string-generator/2021-06-30/cl-string-generator-20210630-git.tgz"; - sha256 = "0zm6lyzd205lw30fdvnhrrlv9fylpfqksqxl32zvj9vzcn8qc1vi"; - system = "cl-string-generator"; - asd = "cl-string-generator"; - }); - systems = [ "cl-string-generator" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-string-match = (build-asdf-system { - pname = "cl-string-match"; - version = "20211209-git"; - asds = [ "cl-string-match" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-string-match/2021-12-09/cl-string-match-20211209-git.tgz"; - sha256 = "0zndlkw3qy3vw4px4qv884z6232w8zfaliyc88irjwizdv35wcq9"; - system = "cl-string-match"; - asd = "cl-string-match"; - }); - systems = [ "cl-string-match" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "ascii-strings" self) (getAttr "iterate" self) (getAttr "jpl-queues" self) (getAttr "mgl-pax" self) (getAttr "yacc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-string-match-test = (build-asdf-system { - pname = "cl-string-match-test"; - version = "20211209-git"; - asds = [ "cl-string-match-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-string-match/2021-12-09/cl-string-match-20211209-git.tgz"; - sha256 = "0zndlkw3qy3vw4px4qv884z6232w8zfaliyc88irjwizdv35wcq9"; - system = "cl-string-match-test"; - asd = "cl-string-match-test"; - }); - systems = [ "cl-string-match-test" ]; - lispLibs = [ (getAttr "ascii-strings" self) (getAttr "cl-string-match" self) (getAttr "lisp-unit" self) (getAttr "simple-scanf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-strings = (build-asdf-system { - pname = "cl-strings"; - version = "20210411-git"; - asds = [ "cl-strings" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-strings/2021-04-11/cl-strings-20210411-git.tgz"; - sha256 = "1j8hs54fn0wsf5zfzhhgiva47n9hsmfa74iinahz6nmcs8iy75aj"; - system = "cl-strings"; - asd = "cl-strings"; - }); - systems = [ "cl-strings" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-strings-tests = (build-asdf-system { - pname = "cl-strings-tests"; - version = "20210411-git"; - asds = [ "cl-strings-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-strings/2021-04-11/cl-strings-20210411-git.tgz"; - sha256 = "1j8hs54fn0wsf5zfzhhgiva47n9hsmfa74iinahz6nmcs8iy75aj"; - system = "cl-strings-tests"; - asd = "cl-strings"; - }); - systems = [ "cl-strings-tests" ]; - lispLibs = [ (getAttr "cl-strings" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-svg = (build-asdf-system { - pname = "cl-svg"; - version = "20241012-git"; - asds = [ "cl-svg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-svg/2024-10-12/cl-svg-20241012-git.tgz"; - sha256 = "05zrg6sxi01xn940c7lygfgxwjkq0zmlkihbhm7lhfaszg2xj8bh"; - system = "cl-svg"; - asd = "cl-svg"; - }); - systems = [ "cl-svg" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-svm = (build-asdf-system { - pname = "cl-svm"; - version = "20110418-git"; - asds = [ "cl-svm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-svm/2011-04-18/cl-svm-20110418-git.tgz"; - sha256 = "03d070k3bl5c0b2f6bzig5gkhlj074v74f7kg8hh3znrbmwji2wv"; - system = "cl-svm"; - asd = "cl-svm"; - }); - systems = [ "cl-svm" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-swagger = (build-asdf-system { - pname = "cl-swagger"; - version = "20180831-git"; - asds = [ "cl-swagger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-swagger-codegen/2018-08-31/cl-swagger-codegen-20180831-git.tgz"; - sha256 = "1lkp69n7wscyf2az3h2bmxmvzzppdfxcq5s0m607b1f7nfmxzjsq"; - system = "cl-swagger"; - asd = "cl-swagger"; - }); - systems = [ "cl-swagger" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "cl-mustache" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sxml = (build-asdf-system { - pname = "cl-sxml"; - version = "20200325-git"; - asds = [ "cl-sxml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sxml/2020-03-25/cl-sxml-20200325-git.tgz"; - sha256 = "1105s9whidq1lf0lli2wdhcfcs5gwzxa0h1x3izx4mp2p7psvciz"; - system = "cl-sxml"; - asd = "cl-sxml"; - }); - systems = [ "cl-sxml" ]; - lispLibs = [ (getAttr "cxml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-sxml-test = (build-asdf-system { - pname = "cl-sxml-test"; - version = "20200325-git"; - asds = [ "cl-sxml-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sxml/2020-03-25/cl-sxml-20200325-git.tgz"; - sha256 = "1105s9whidq1lf0lli2wdhcfcs5gwzxa0h1x3izx4mp2p7psvciz"; - system = "cl-sxml-test"; - asd = "cl-sxml"; - }); - systems = [ "cl-sxml-test" ]; - lispLibs = [ (getAttr "cl-sxml" self) (getAttr "fiveam" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-syntax = (build-asdf-system { - pname = "cl-syntax"; - version = "20150407-git"; - asds = [ "cl-syntax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; - sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; - system = "cl-syntax"; - asd = "cl-syntax"; - }); - systems = [ "cl-syntax" ]; - lispLibs = [ (getAttr "named-readtables" self) (getAttr "trivial-types" self) ]; - meta = {}; - }); - cl-syntax-annot = (build-asdf-system { - pname = "cl-syntax-annot"; - version = "20150407-git"; - asds = [ "cl-syntax-annot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; - sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; - system = "cl-syntax-annot"; - asd = "cl-syntax-annot"; - }); - systems = [ "cl-syntax-annot" ]; - lispLibs = [ (getAttr "cl-annot" self) (getAttr "cl-syntax" self) ]; - meta = {}; - }); - cl-syntax-anonfun = (build-asdf-system { - pname = "cl-syntax-anonfun"; - version = "20150407-git"; - asds = [ "cl-syntax-anonfun" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; - sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; - system = "cl-syntax-anonfun"; - asd = "cl-syntax-anonfun"; - }); - systems = [ "cl-syntax-anonfun" ]; - lispLibs = [ (getAttr "cl-anonfun" self) (getAttr "cl-syntax" self) ]; - meta = {}; - }); - cl-syntax-clsql = (build-asdf-system { - pname = "cl-syntax-clsql"; - version = "20150407-git"; - asds = [ "cl-syntax-clsql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; - sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; - system = "cl-syntax-clsql"; - asd = "cl-syntax-clsql"; - }); - systems = [ "cl-syntax-clsql" ]; - lispLibs = [ (getAttr "cl-syntax" self) (getAttr "clsql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-syntax-debug-print = (build-asdf-system { - pname = "cl-syntax-debug-print"; - version = "20210807-git"; - asds = [ "cl-syntax-debug-print" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-debug-print/2021-08-07/cl-debug-print-20210807-git.tgz"; - sha256 = "1cm5nybmv0pq9s4lrwhd01rjj1wlcj1sjcrcakabi7w7b5zw4cyh"; - system = "cl-syntax-debug-print"; - asd = "cl-syntax-debug-print"; - }); - systems = [ "cl-syntax-debug-print" ]; - lispLibs = [ (getAttr "cl-debug-print" self) (getAttr "cl-syntax" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-syntax-fare-quasiquote = (build-asdf-system { - pname = "cl-syntax-fare-quasiquote"; - version = "20150407-git"; - asds = [ "cl-syntax-fare-quasiquote" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; - sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; - system = "cl-syntax-fare-quasiquote"; - asd = "cl-syntax-fare-quasiquote"; - }); - systems = [ "cl-syntax-fare-quasiquote" ]; - lispLibs = [ (getAttr "cl-syntax" self) (getAttr "fare-quasiquote" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-syntax-interpol = (build-asdf-system { - pname = "cl-syntax-interpol"; - version = "20150407-git"; - asds = [ "cl-syntax-interpol" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; - sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; - system = "cl-syntax-interpol"; - asd = "cl-syntax-interpol"; - }); - systems = [ "cl-syntax-interpol" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "cl-syntax" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-syntax-lsx = (build-asdf-system { - pname = "cl-syntax-lsx"; - version = "20220220-git"; - asds = [ "cl-syntax-lsx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lsx/2022-02-20/lsx-20220220-git.tgz"; - sha256 = "1pdq6csr8pkzcq2zkhhm6wkp9zxx2aypjd16rcw4q43mff09y041"; - system = "cl-syntax-lsx"; - asd = "cl-syntax-lsx"; - }); - systems = [ "cl-syntax-lsx" ]; - lispLibs = [ (getAttr "cl-syntax" self) (getAttr "lsx" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-syntax-markup = (build-asdf-system { - pname = "cl-syntax-markup"; - version = "20150407-git"; - asds = [ "cl-syntax-markup" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; - sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; - system = "cl-syntax-markup"; - asd = "cl-syntax-markup"; - }); - systems = [ "cl-syntax-markup" ]; - lispLibs = [ (getAttr "cl-markup" self) (getAttr "cl-syntax" self) ]; - meta = {}; - }); - cl-syslog = (build-asdf-system { - pname = "cl-syslog"; - version = "20190202-git"; - asds = [ "cl-syslog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-syslog/2019-02-02/cl-syslog-20190202-git.tgz"; - sha256 = "1qcz55jiqwk91b01hsahxnha884f6zf2883j2m51sqph0mvj69mh"; - system = "cl-syslog"; - asd = "cl-syslog"; - }); - systems = [ "cl-syslog" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cffi" self) (getAttr "global-vars" self) (getAttr "local-time" self) (getAttr "split-sequence" self) (getAttr "usocket" self) ]; - meta = {}; - }); - cl-table = (build-asdf-system { - pname = "cl-table"; - version = "20130128-git"; - asds = [ "cl-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-table/2013-01-28/cl-table-20130128-git.tgz"; - sha256 = "0c7bdnpi473grayycdcdh4q8fi137i3c80k05k87pvjdrl1qnkpn"; - system = "cl-table"; - asd = "cl-table"; - }); - systems = [ "cl-table" ]; - lispLibs = [ (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tasukete = (build-asdf-system { - pname = "cl-tasukete"; - version = "20180228-git"; - asds = [ "cl-tasukete" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tasukete/2018-02-28/cl-tasukete-20180228-git.tgz"; - sha256 = "0i8ibg2a33mb32vr2b70psb5dvh47r52lfhkh84rxzmcsk6ww230"; - system = "cl-tasukete"; - asd = "cl-tasukete"; - }); - systems = [ "cl-tasukete" ]; - lispLibs = [ (getAttr "cl-annot" self) (getAttr "cl-gists" self) (getAttr "dissect" self) (getAttr "jonathan" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tasukete-test = (build-asdf-system { - pname = "cl-tasukete-test"; - version = "20180228-git"; - asds = [ "cl-tasukete-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tasukete/2018-02-28/cl-tasukete-20180228-git.tgz"; - sha256 = "0i8ibg2a33mb32vr2b70psb5dvh47r52lfhkh84rxzmcsk6ww230"; - system = "cl-tasukete-test"; - asd = "cl-tasukete-test"; - }); - systems = [ "cl-tasukete-test" ]; - lispLibs = [ (getAttr "cl-tasukete" self) (getAttr "dissect" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-telebot = (build-asdf-system { - pname = "cl-telebot"; - version = "20211020-git"; - asds = [ "cl-telebot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-telebot/2021-10-20/cl-telebot-20211020-git.tgz"; - sha256 = "0nl002l4f3x6843s6h5w2iz2hganxb369k8c2hbbgqq7plb4mdf1"; - system = "cl-telebot"; - asd = "cl-telebot"; - }); - systems = [ "cl-telebot" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "dexador" self) (getAttr "jonathan" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-telegram-bot = (build-asdf-system { - pname = "cl-telegram-bot"; - version = "20241012-git"; - asds = [ "cl-telegram-bot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-telegram-bot/2024-10-12/cl-telegram-bot-20241012-git.tgz"; - sha256 = "1i1g9ax46b5jyx2nckp2q00asb46wwlin0hj5wlqlp7cb27r3dqj"; - system = "cl-telegram-bot"; - asd = "cl-telegram-bot"; - }); - systems = [ "cl-telegram-bot" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "alexandria" self) (getAttr "arrows" self) (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "cl-strings" self) (getAttr "closer-mop" self) (getAttr "dexador" self) (getAttr "jonathan" self) (getAttr "kebab" self) (getAttr "log4cl" self) (getAttr "serapeum" self) (getAttr "str" self) (getAttr "trivial-backtrace" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-telegram-bot-ci = (build-asdf-system { - pname = "cl-telegram-bot-ci"; - version = "20241012-git"; - asds = [ "cl-telegram-bot-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-telegram-bot/2024-10-12/cl-telegram-bot-20241012-git.tgz"; - sha256 = "1i1g9ax46b5jyx2nckp2q00asb46wwlin0hj5wlqlp7cb27r3dqj"; - system = "cl-telegram-bot-ci"; - asd = "cl-telegram-bot-ci"; - }); - systems = [ "cl-telegram-bot-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-telegram-bot-docs = (build-asdf-system { - pname = "cl-telegram-bot-docs"; - version = "20241012-git"; - asds = [ "cl-telegram-bot-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-telegram-bot/2024-10-12/cl-telegram-bot-20241012-git.tgz"; - sha256 = "1i1g9ax46b5jyx2nckp2q00asb46wwlin0hj5wlqlp7cb27r3dqj"; - system = "cl-telegram-bot-docs"; - asd = "cl-telegram-bot-docs"; - }); - systems = [ "cl-telegram-bot-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "cl-telegram-bot" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-telegram-bot-tests = (build-asdf-system { - pname = "cl-telegram-bot-tests"; - version = "20241012-git"; - asds = [ "cl-telegram-bot-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-telegram-bot/2024-10-12/cl-telegram-bot-20241012-git.tgz"; - sha256 = "1i1g9ax46b5jyx2nckp2q00asb46wwlin0hj5wlqlp7cb27r3dqj"; - system = "cl-telegram-bot-tests"; - asd = "cl-telegram-bot-tests"; - }); - systems = [ "cl-telegram-bot-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-template = (build-asdf-system { - pname = "cl-template"; - version = "20130615-git"; - asds = [ "cl-template" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-template/2013-06-15/cl-template-20130615-git.tgz"; - sha256 = "1rhg023a2nxsk5x6abd6i0a8sh36aj0bgsh80w60m3b7xlsva2x2"; - system = "cl-template"; - asd = "cl-template"; - }); - systems = [ "cl-template" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-template-tests = (build-asdf-system { - pname = "cl-template-tests"; - version = "20130615-git"; - asds = [ "cl-template-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-template/2013-06-15/cl-template-20130615-git.tgz"; - sha256 = "1rhg023a2nxsk5x6abd6i0a8sh36aj0bgsh80w60m3b7xlsva2x2"; - system = "cl-template-tests"; - asd = "cl-template"; - }); - systems = [ "cl-template-tests" ]; - lispLibs = [ (getAttr "cl-template" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-termbox = (build-asdf-system { - pname = "cl-termbox"; - version = "20211020-git"; - asds = [ "cl-termbox" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-termbox/2021-10-20/cl-termbox-20211020-git.tgz"; - sha256 = "1igmq64zndkgchmzggp34jrmxa81dqlhz2il8qizrpfw5a39cpld"; - system = "cl-termbox"; - asd = "cl-termbox"; - }); - systems = [ "cl-termbox" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tesseract = (build-asdf-system { - pname = "cl-tesseract"; - version = "20171130-git"; - asds = [ "cl-tesseract" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tesseract/2017-11-30/cl-tesseract-20171130-git.tgz"; - sha256 = "086627k8whbj60bpw9r3jrdifr4bigqpnp9hxsi7r6702gixz50x"; - system = "cl-tesseract"; - asd = "cl-tesseract"; - }); - systems = [ "cl-tesseract" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-test-more = (build-asdf-system { - pname = "cl-test-more"; - version = "20200218-git"; - asds = [ "cl-test-more" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prove/2020-02-18/prove-20200218-git.tgz"; - sha256 = "0ca6ha3zhmckq3ad9lxm6sbg4i0hg3m81xhan4dkxd3x9898jzpc"; - system = "cl-test-more"; - asd = "cl-test-more"; - }); - systems = [ "cl-test-more" ]; - lispLibs = [ (getAttr "prove" self) ]; - meta = {}; - }); - cl-tetris3d = (build-asdf-system { - pname = "cl-tetris3d"; - version = "20181210-git"; - asds = [ "cl-tetris3d" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tetris3d/2018-12-10/cl-tetris3d-20181210-git.tgz"; - sha256 = "09n7344is2vfbp32cd22ynk14h4vqs4xw3plbhga8q25ghhx5y9p"; - system = "cl-tetris3d"; - asd = "cl-tetris3d"; - }); - systems = [ "cl-tetris3d" ]; - lispLibs = [ (getAttr "cl-glu" self) (getAttr "cl-opengl" self) (getAttr "iterate" self) (getAttr "lispbuilder-sdl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-textmagic = (build-asdf-system { - pname = "cl-textmagic"; - version = "20151218-git"; - asds = [ "cl-textmagic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-textmagic/2015-12-18/cl-textmagic-20151218-git.tgz"; - sha256 = "0xw6g1r5vxmnbz3kxf2q6s9dr9l2aacyri1wchzw4jx5wlcnkshw"; - system = "cl-textmagic"; - asd = "cl-textmagic"; - }); - systems = [ "cl-textmagic" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "dexador" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-textmagic-test = (build-asdf-system { - pname = "cl-textmagic-test"; - version = "20151218-git"; - asds = [ "cl-textmagic-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-textmagic/2015-12-18/cl-textmagic-20151218-git.tgz"; - sha256 = "0xw6g1r5vxmnbz3kxf2q6s9dr9l2aacyri1wchzw4jx5wlcnkshw"; - system = "cl-textmagic-test"; - asd = "cl-textmagic-test"; - }); - systems = [ "cl-textmagic-test" ]; - lispLibs = [ (getAttr "cl-textmagic" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tga = (build-asdf-system { - pname = "cl-tga"; - version = "20160318-git"; - asds = [ "cl-tga" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tga/2016-03-18/cl-tga-20160318-git.tgz"; - sha256 = "03k3npmn0xd3fd2m7vwxph82av2xrfb150imqrinlzqmzvz1v1br"; - system = "cl-tga"; - asd = "cl-tga"; - }); - systems = [ "cl-tga" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-threadpool = (build-asdf-system { - pname = "cl-threadpool"; - version = "quickload-current-release-feda6ff9-git"; - asds = [ "cl-threadpool" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-threadpool/2024-10-12/cl-threadpool-quickload-current-release-feda6ff9-git.tgz"; - sha256 = "0y2kai8ijz0y6j54svvdrl2f2v96pz0pl652x86lz7pl4yyg99vr"; - system = "cl-threadpool"; - asd = "cl-threadpool"; - }); - systems = [ "cl-threadpool" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "queues_dot_simple-cqueue" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tidy = (build-asdf-system { - pname = "cl-tidy"; - version = "20170830-git"; - asds = [ "cl-tidy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tidy/2017-08-30/cl-tidy-20170830-git.tgz"; - sha256 = "13j0jgf6czb24148w2wxfwlji6vnc49qvyr5wzq5ps55b27ddlz6"; - system = "cl-tidy"; - asd = "cl-tidy"; - }); - systems = [ "cl-tidy" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tiled = (build-asdf-system { - pname = "cl-tiled"; - version = "20241012-git"; - asds = [ "cl-tiled" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tiled/2024-10-12/cl-tiled-20241012-git.tgz"; - sha256 = "0ni61iahr58i44psk4z3q1w9nsxbc49m5wbb8w0icm4f7x0ijn07"; - system = "cl-tiled"; - asd = "cl-tiled"; - }); - systems = [ "cl-tiled" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "chipz" self) (getAttr "cl-base64" self) (getAttr "cl-json" self) (getAttr "nibbles" self) (getAttr "parse-float" self) (getAttr "split-sequence" self) (getAttr "xmls" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tk = (build-asdf-system { - pname = "cl-tk"; - version = "20150608-git"; - asds = [ "cl-tk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tk/2015-06-08/cl-tk-20150608-git.tgz"; - sha256 = "0fm4q4pkzbyxr6227vavvy4lm7rfw214lp2dylgzjzcp6f5r4n7w"; - system = "cl-tk"; - asd = "cl-tk"; - }); - systems = [ "cl-tk" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tld = (build-asdf-system { - pname = "cl-tld"; - version = "20220220-git"; - asds = [ "cl-tld" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tld/2022-02-20/cl-tld-20220220-git.tgz"; - sha256 = "1xm471p92in5g4fcxgqshwgr2d7937jw7jv6j473slwkxjvx8dp6"; - system = "cl-tld"; - asd = "cl-tld"; - }); - systems = [ "cl-tld" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tls = (build-asdf-system { - pname = "cl-tls"; - version = "20231021-git"; - asds = [ "cl-tls" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tls/2023-10-21/cl-tls-20231021-git.tgz"; - sha256 = "1gq7m5wmsrjmyhrk9xljxz9ickahwzl1anz2fcns5q2nj0j6d9bx"; - system = "cl-tls"; - asd = "cl-tls"; - }); - systems = [ "cl-tls" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-base64" self) (getAttr "fast-io" self) (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tokyo-cabinet = (build-asdf-system { - pname = "cl-tokyo-cabinet"; - version = "20160825-git"; - asds = [ "cl-tokyo-cabinet" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tokyo-cabinet/2016-08-25/cl-tokyo-cabinet-20160825-git.tgz"; - sha256 = "07961in8fa09bjnpwkdn0w6dj37nppzmgg50kf8khspnjh1sjsr2"; - system = "cl-tokyo-cabinet"; - asd = "cl-tokyo-cabinet"; - }); - systems = [ "cl-tokyo-cabinet" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "deoxybyte-systems" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tokyo-cabinet-test = (build-asdf-system { - pname = "cl-tokyo-cabinet-test"; - version = "20160825-git"; - asds = [ "cl-tokyo-cabinet-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tokyo-cabinet/2016-08-25/cl-tokyo-cabinet-20160825-git.tgz"; - sha256 = "07961in8fa09bjnpwkdn0w6dj37nppzmgg50kf8khspnjh1sjsr2"; - system = "cl-tokyo-cabinet-test"; - asd = "cl-tokyo-cabinet-test"; - }); - systems = [ "cl-tokyo-cabinet-test" ]; - lispLibs = [ (getAttr "cl-tokyo-cabinet" self) (getAttr "deoxybyte-io" self) (getAttr "deoxybyte-utilities" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-toml = (build-asdf-system { - pname = "cl-toml"; - version = "20191130-git"; - asds = [ "cl-toml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-toml/2019-11-30/cl-toml-20191130-git.tgz"; - sha256 = "1g5i60i78s0ms608fyc6sgaaqr6jdsln75n26lmfbcaqw2g1q9dk"; - system = "cl-toml"; - asd = "cl-toml"; - }); - systems = [ "cl-toml" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "esrap" self) (getAttr "local-time" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-toml-test = (build-asdf-system { - pname = "cl-toml-test"; - version = "20191130-git"; - asds = [ "cl-toml-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-toml/2019-11-30/cl-toml-20191130-git.tgz"; - sha256 = "1g5i60i78s0ms608fyc6sgaaqr6jdsln75n26lmfbcaqw2g1q9dk"; - system = "cl-toml-test"; - asd = "cl-toml-test"; - }); - systems = [ "cl-toml-test" ]; - lispLibs = [ (getAttr "cl-toml" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tqdm = (build-asdf-system { - pname = "cl-tqdm"; - version = "20241012-git"; - asds = [ "cl-tqdm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tqdm/2024-10-12/cl-tqdm-20241012-git.tgz"; - sha256 = "0wlbgs7wfiy149d7zq5bpkm8g3785b1crcf2m802f9qhin2r0nzg"; - system = "cl-tqdm"; - asd = "cl-tqdm"; - }); - systems = [ "cl-tqdm" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-transmission = (build-asdf-system { - pname = "cl-transmission"; - version = "20200325-git"; - asds = [ "cl-transmission" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-transmission/2020-03-25/cl-transmission-20200325-git.tgz"; - sha256 = "0sg3f2jqs2z3mvscjhc43hkd34vlcc4c8hq8rhh5w1gjg19z57hb"; - system = "cl-transmission"; - asd = "cl-transmission"; - }); - systems = [ "cl-transmission" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "jonathan" self) (getAttr "named-readtables" self) (getAttr "rutils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-transmission-test = (build-asdf-system { - pname = "cl-transmission-test"; - version = "20200325-git"; - asds = [ "cl-transmission-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-transmission/2020-03-25/cl-transmission-20200325-git.tgz"; - sha256 = "0sg3f2jqs2z3mvscjhc43hkd34vlcc4c8hq8rhh5w1gjg19z57hb"; - system = "cl-transmission-test"; - asd = "cl-transmission-test"; - }); - systems = [ "cl-transmission-test" ]; - lispLibs = [ (getAttr "cl-transmission" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-trie = (build-asdf-system { - pname = "cl-trie"; - version = "20230214-git"; - asds = [ "cl-trie" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-trie/2023-02-14/cl-trie-20230214-git.tgz"; - sha256 = "0d0mnac9rbqvwr45650yimfw4fyldbgasj139g7y1wzrranrcldf"; - system = "cl-trie"; - asd = "cl-trie"; - }); - systems = [ "cl-trie" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-trie-examples = (build-asdf-system { - pname = "cl-trie-examples"; - version = "20230214-git"; - asds = [ "cl-trie-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-trie/2023-02-14/cl-trie-20230214-git.tgz"; - sha256 = "0d0mnac9rbqvwr45650yimfw4fyldbgasj139g7y1wzrranrcldf"; - system = "cl-trie-examples"; - asd = "cl-trie-examples"; - }); - systems = [ "cl-trie-examples" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cl-trie" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tui = (build-asdf-system { - pname = "cl-tui"; - version = "20200427-git"; - asds = [ "cl-tui" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tui/2020-04-27/cl-tui-20200427-git.tgz"; - sha256 = "1s0z7sjb3p1fxypc2x9fl0y094qa1a2iqjbn5him4hs8z7xm5kz8"; - system = "cl-tui"; - asd = "cl-tui"; - }); - systems = [ "cl-tui" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cl-charms" self) (getAttr "cl-containers" self) (getAttr "osicat" self) (getAttr "split-sequence" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tulip-graph = (build-asdf-system { - pname = "cl-tulip-graph"; - version = "20130615-git"; - asds = [ "cl-tulip-graph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tulip-graph/2013-06-15/cl-tulip-graph-20130615-git.tgz"; - sha256 = "0zmmwqabbyzdikn8x0xqrj192wr5w87l828nwandqg59af2isxav"; - system = "cl-tulip-graph"; - asd = "cl-tulip-graph"; - }); - systems = [ "cl-tulip-graph" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-tuples = (build-asdf-system { - pname = "cl-tuples"; - version = "20140713-git"; - asds = [ "cl-tuples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tuples/2014-07-13/cl-tuples-20140713-git.tgz"; - sha256 = "060xmr03y8n0mnf4x4fnrirljcjk1jcir7jsjq4w9d5vzq3aqm9m"; - system = "cl-tuples"; - asd = "cl-tuples"; - }); - systems = [ "cl-tuples" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-twit-repl = (build-asdf-system { - pname = "cl-twit-repl"; - version = "20180228-git"; - asds = [ "cl-twit-repl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-twitter/2018-02-28/cl-twitter-20180228-git.tgz"; - sha256 = "07l86c63ssahpz3s9f7d99mbzmh60askkpdrhjrdbzd1vxlwkhcr"; - system = "cl-twit-repl"; - asd = "cl-twit-repl"; - }); - systems = [ "cl-twit-repl" ]; - lispLibs = [ (getAttr "cl-twitter" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-twitter = (build-asdf-system { - pname = "cl-twitter"; - version = "20180228-git"; - asds = [ "cl-twitter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-twitter/2018-02-28/cl-twitter-20180228-git.tgz"; - sha256 = "07l86c63ssahpz3s9f7d99mbzmh60askkpdrhjrdbzd1vxlwkhcr"; - system = "cl-twitter"; - asd = "cl-twitter"; - }); - systems = [ "cl-twitter" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "cl-json" self) (getAttr "cl-oauth" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "drakma" self) (getAttr "trivial-http" self) (getAttr "url-rewrite" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-typesetting = (build-asdf-system { - pname = "cl-typesetting"; - version = "20210531-git"; - asds = [ "cl-typesetting" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-typesetting/2021-05-31/cl-typesetting-20210531-git.tgz"; - sha256 = "0fcs5mq0gxfczbrg7ay8r4bf5r4g6blvpdbjkhcl8dapcikyn35h"; - system = "cl-typesetting"; - asd = "cl-typesetting"; - }); - systems = [ "cl-typesetting" ]; - lispLibs = [ (getAttr "cl-pdf" self) ]; - meta = {}; - }); - cl-uglify-js = (build-asdf-system { - pname = "cl-uglify-js"; - version = "20150709-git"; - asds = [ "cl-uglify-js" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-uglify-js/2015-07-09/cl-uglify-js-20150709-git.tgz"; - sha256 = "0k39y3c93jgxpr7gwz7w0d8yknn1fdnxrjhd03057lvk5w8js27a"; - system = "cl-uglify-js"; - asd = "cl-uglify-js"; - }); - systems = [ "cl-uglify-js" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cl-ppcre-unicode" self) (getAttr "iterate" self) (getAttr "parse-js" self) (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-unac = (build-asdf-system { - pname = "cl-unac"; - version = "20230618-git"; - asds = [ "cl-unac" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-unac/2023-06-18/cl-unac-20230618-git.tgz"; - sha256 = "16i4lwg70k05dw3vynyyz09ldgr4zzd1ar68g4jcxk7q4ijfdw9m"; - system = "cl-unac"; - asd = "cl-unac"; - }); - systems = [ "cl-unac" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-unac_dot_config" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-unac_dot_config = (build-asdf-system { - pname = "cl-unac.config"; - version = "20230618-git"; - asds = [ "cl-unac.config" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-unac/2023-06-18/cl-unac-20230618-git.tgz"; - sha256 = "16i4lwg70k05dw3vynyyz09ldgr4zzd1ar68g4jcxk7q4ijfdw9m"; - system = "cl-unac.config"; - asd = "cl-unac.config"; - }); - systems = [ "cl-unac.config" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-unac_dot_tests = (build-asdf-system { - pname = "cl-unac.tests"; - version = "20230618-git"; - asds = [ "cl-unac.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-unac/2023-06-18/cl-unac-20230618-git.tgz"; - sha256 = "16i4lwg70k05dw3vynyyz09ldgr4zzd1ar68g4jcxk7q4ijfdw9m"; - system = "cl-unac.tests"; - asd = "cl-unac.tests"; - }); - systems = [ "cl-unac.tests" ]; - lispLibs = [ (getAttr "cl-unac" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-unicode = (build-asdf-system { - pname = "cl-unicode"; - version = "20241012-git"; - asds = [ "cl-unicode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-unicode/2024-10-12/cl-unicode-20241012-git.tgz"; - sha256 = "14ydcjkj94mmx40vs27w8137lgmw16jjhpr5m46mm6gqv46yvr6l"; - system = "cl-unicode"; - asd = "cl-unicode"; - }); - systems = [ "cl-unicode" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = {}; - }); - cl-unification = (build-asdf-system { - pname = "cl-unification"; - version = "20241012-git"; - asds = [ "cl-unification" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-unification/2024-10-12/cl-unification-20241012-git.tgz"; - sha256 = "1q7bjj9dzazhgj32291rqy4lld1ilrpck374c21864qn3pmz31ag"; - system = "cl-unification"; - asd = "cl-unification"; - }); - systems = [ "cl-unification" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-unification-lib = (build-asdf-system { - pname = "cl-unification-lib"; - version = "20241012-git"; - asds = [ "cl-unification-lib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-unification/2024-10-12/cl-unification-20241012-git.tgz"; - sha256 = "1q7bjj9dzazhgj32291rqy4lld1ilrpck374c21864qn3pmz31ag"; - system = "cl-unification-lib"; - asd = "cl-unification-lib"; - }); - systems = [ "cl-unification-lib" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cl-unification" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-unification-test = (build-asdf-system { - pname = "cl-unification-test"; - version = "20241012-git"; - asds = [ "cl-unification-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-unification/2024-10-12/cl-unification-20241012-git.tgz"; - sha256 = "1q7bjj9dzazhgj32291rqy4lld1ilrpck374c21864qn3pmz31ag"; - system = "cl-unification-test"; - asd = "cl-unification-test"; - }); - systems = [ "cl-unification-test" ]; - lispLibs = [ (getAttr "cl-unification" self) (getAttr "ptester" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-union-find = (build-asdf-system { - pname = "cl-union-find"; - version = "20221106-git"; - asds = [ "cl-union-find" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-union-find/2022-11-06/cl-union-find-20221106-git.tgz"; - sha256 = "14xciva5v3c4zi4vzp1vfhs82a2654yhkfyllr3b0cr7x36jdm7y"; - system = "cl-union-find"; - asd = "cl-union-find"; - }); - systems = [ "cl-union-find" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-utilities = (build-asdf-system { - pname = "cl-utilities"; - version = "1.2.4"; - asds = [ "cl-utilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-utilities/2010-10-06/cl-utilities-1.2.4.tgz"; - sha256 = "1dmbkdr8xm2jw5yx1makqbf1ypqbm0hpkd7zyknxv3cblvz0a87w"; - system = "cl-utilities"; - asd = "cl-utilities"; - }); - systems = [ "cl-utilities" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-variates = (build-asdf-system { - pname = "cl-variates"; - version = "20180131-darcs"; - asds = [ "cl-variates" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-variates/2018-01-31/cl-variates-20180131-darcs.tgz"; - sha256 = "02pd02isfxrn3h8h5kh369rwy17hfjkmd7j24pcihfskamgcqgfx"; - system = "cl-variates"; - asd = "cl-variates"; - }); - systems = [ "cl-variates" ]; - lispLibs = [ (getAttr "asdf-system-connections" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-vectors = (build-asdf-system { - pname = "cl-vectors"; - version = "20241012-git"; - asds = [ "cl-vectors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-vectors/2024-10-12/cl-vectors-20241012-git.tgz"; - sha256 = "1nkmmn38y6af10ysff3g2qkf5lb2601dcjp5rffsjh6bv2ik2jd5"; - system = "cl-vectors"; - asd = "cl-vectors"; - }); - systems = [ "cl-vectors" ]; - lispLibs = [ (getAttr "cl-aa" self) (getAttr "cl-paths" self) ]; - meta = {}; - }); - cl-vhdl = (build-asdf-system { - pname = "cl-vhdl"; - version = "20160421-git"; - asds = [ "cl-vhdl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-vhdl/2016-04-21/cl-vhdl-20160421-git.tgz"; - sha256 = "0i2780ljak8kcqa2zm24dk2fk771m2mvmnbq4xd4vvx9z87lbnvi"; - system = "cl-vhdl"; - asd = "cl-vhdl"; - }); - systems = [ "cl-vhdl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-interpol" self) (getAttr "cl-itertools" self) (getAttr "cl-ppcre" self) (getAttr "esrap-liquid" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-vhdl-tests = (build-asdf-system { - pname = "cl-vhdl-tests"; - version = "20160421-git"; - asds = [ "cl-vhdl-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-vhdl/2016-04-21/cl-vhdl-20160421-git.tgz"; - sha256 = "0i2780ljak8kcqa2zm24dk2fk771m2mvmnbq4xd4vvx9z87lbnvi"; - system = "cl-vhdl-tests"; - asd = "cl-vhdl"; - }); - systems = [ "cl-vhdl-tests" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "cl-vhdl" self) (getAttr "fare-quasiquote-optima" self) (getAttr "fiveam" self) (getAttr "optima" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-video = (build-asdf-system { - pname = "cl-video"; - version = "20180228-git"; - asds = [ "cl-video" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-video/2018-02-28/cl-video-20180228-git.tgz"; - sha256 = "1azldcp6r0j1kw6rczicmnv4m0d7rq4m5axz48ny6r2qybha80lr"; - system = "cl-video"; - asd = "cl-video"; - }); - systems = [ "cl-video" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-video-avi = (build-asdf-system { - pname = "cl-video-avi"; - version = "20180228-git"; - asds = [ "cl-video-avi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-video/2018-02-28/cl-video-20180228-git.tgz"; - sha256 = "1azldcp6r0j1kw6rczicmnv4m0d7rq4m5axz48ny6r2qybha80lr"; - system = "cl-video-avi"; - asd = "cl-video-avi"; - }); - systems = [ "cl-video-avi" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-jpeg" self) (getAttr "cl-riff" self) (getAttr "cl-video" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-video-gif = (build-asdf-system { - pname = "cl-video-gif"; - version = "20180228-git"; - asds = [ "cl-video-gif" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-video/2018-02-28/cl-video-20180228-git.tgz"; - sha256 = "1azldcp6r0j1kw6rczicmnv4m0d7rq4m5axz48ny6r2qybha80lr"; - system = "cl-video-gif"; - asd = "cl-video-gif"; - }); - systems = [ "cl-video-gif" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-video" self) (getAttr "skippy" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-video-player = (build-asdf-system { - pname = "cl-video-player"; - version = "20180228-git"; - asds = [ "cl-video-player" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-video/2018-02-28/cl-video-20180228-git.tgz"; - sha256 = "1azldcp6r0j1kw6rczicmnv4m0d7rq4m5axz48ny6r2qybha80lr"; - system = "cl-video-player"; - asd = "cl-video-player"; - }); - systems = [ "cl-video-player" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-portaudio" self) (getAttr "cl-video-avi" self) (getAttr "cl-video-gif" self) (getAttr "cl-video-wav" self) (getAttr "clx" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-video-wav = (build-asdf-system { - pname = "cl-video-wav"; - version = "20180228-git"; - asds = [ "cl-video-wav" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-video/2018-02-28/cl-video-20180228-git.tgz"; - sha256 = "1azldcp6r0j1kw6rczicmnv4m0d7rq4m5axz48ny6r2qybha80lr"; - system = "cl-video-wav"; - asd = "cl-video-wav"; - }); - systems = [ "cl-video-wav" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-riff" self) (getAttr "cl-video" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-virtualbox = (build-asdf-system { - pname = "cl-virtualbox"; - version = "20180831-git"; - asds = [ "cl-virtualbox" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-virtualbox/2018-08-31/cl-virtualbox-20180831-git.tgz"; - sha256 = "1jzn8jjn9yn9vgnn1r6h0iyxb6j17wm8lmf9j5hk4yqwdzb2nidv"; - system = "cl-virtualbox"; - asd = "cl-virtualbox"; - }); - systems = [ "cl-virtualbox" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-vorbis = (build-asdf-system { - pname = "cl-vorbis"; - version = "20241012-git"; - asds = [ "cl-vorbis" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-vorbis/2024-10-12/cl-vorbis-20241012-git.tgz"; - sha256 = "04p0ix2mxa8iv2dab19mlix6m3inwyb0rs5wsrf8r9l1n41dyp2p"; - system = "cl-vorbis"; - asd = "cl-vorbis"; - }); - systems = [ "cl-vorbis" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "static-vectors" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-voxelize = (build-asdf-system { - pname = "cl-voxelize"; - version = "20150709-git"; - asds = [ "cl-voxelize" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-voxelize/2015-07-09/cl-voxelize-20150709-git.tgz"; - sha256 = "1sim8n175dgy0i0dxi1vsqzgjx07lgsnrgn3bizzka58ni5y8xdm"; - system = "cl-voxelize"; - asd = "cl-voxelize"; - }); - systems = [ "cl-voxelize" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-voxelize-examples = (build-asdf-system { - pname = "cl-voxelize-examples"; - version = "20150709-git"; - asds = [ "cl-voxelize-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-voxelize/2015-07-09/cl-voxelize-20150709-git.tgz"; - sha256 = "1sim8n175dgy0i0dxi1vsqzgjx07lgsnrgn3bizzka58ni5y8xdm"; - system = "cl-voxelize-examples"; - asd = "cl-voxelize-examples"; - }); - systems = [ "cl-voxelize-examples" ]; - lispLibs = [ (getAttr "cl-ply" self) (getAttr "cl-voxelize" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-voxelize-test = (build-asdf-system { - pname = "cl-voxelize-test"; - version = "20150709-git"; - asds = [ "cl-voxelize-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-voxelize/2015-07-09/cl-voxelize-20150709-git.tgz"; - sha256 = "1sim8n175dgy0i0dxi1vsqzgjx07lgsnrgn3bizzka58ni5y8xdm"; - system = "cl-voxelize-test"; - asd = "cl-voxelize-test"; - }); - systems = [ "cl-voxelize-test" ]; - lispLibs = [ (getAttr "cl-voxelize" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-wadler-pprint = (build-asdf-system { - pname = "cl-wadler-pprint"; - version = "20191007-git"; - asds = [ "cl-wadler-pprint" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-wadler-pprint/2019-10-07/cl-wadler-pprint-20191007-git.tgz"; - sha256 = "0y5jxk7yiw8wng7hg91cwibh6d2hf1sv2mzqhkds6l4myhzxb4jr"; - system = "cl-wadler-pprint"; - asd = "cl-wadler-pprint"; - }); - systems = [ "cl-wadler-pprint" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-wav = (build-asdf-system { - pname = "cl-wav"; - version = "20221106-git"; - asds = [ "cl-wav" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-wav/2022-11-06/cl-wav-20221106-git.tgz"; - sha256 = "1nf4zw72v0c9fl8mr4si5cr2xz753ydzv19mfzy5dqqx0k1g7wyl"; - system = "cl-wav"; - asd = "cl-wav"; - }); - systems = [ "cl-wav" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-riff" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-wave-file-writer = (build-asdf-system { - pname = "cl-wave-file-writer"; - version = "quickload-current-release-42cde6cf-git"; - asds = [ "cl-wave-file-writer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-wave-file-writer/2021-10-20/cl-wave-file-writer-quickload-current-release-42cde6cf-git.tgz"; - sha256 = "0mxzp6rm7ah86vp1xj67q43al71k62x407m5vmbldvyb6pmx37fp"; - system = "cl-wave-file-writer"; - asd = "cl-wave-file-writer"; - }); - systems = [ "cl-wave-file-writer" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-wavefront = (build-asdf-system { - pname = "cl-wavefront"; - version = "20241012-git"; - asds = [ "cl-wavefront" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-wavefront/2024-10-12/cl-wavefront-20241012-git.tgz"; - sha256 = "1il5i04x2ff3pnjm2pgvq0hryd9rnjdbczvinj3l3w30lj553g83"; - system = "cl-wavefront"; - asd = "cl-wavefront"; - }); - systems = [ "cl-wavefront" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "documentation-utils" self) (getAttr "parse-float" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-wavelets = (build-asdf-system { - pname = "cl-wavelets"; - version = "20220707-git"; - asds = [ "cl-wavelets" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-wavelets/2022-07-07/cl-wavelets-20220707-git.tgz"; - sha256 = "0z4r01d5mv4rachz5rr5zvnv94q7ka17138vcpsb05sz00vv03ba"; - system = "cl-wavelets"; - asd = "cl-wavelets"; - }); - systems = [ "cl-wavelets" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-wayland = (build-asdf-system { - pname = "cl-wayland"; - version = "20190307-git"; - asds = [ "cl-wayland" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-wayland/2019-03-07/cl-wayland-20190307-git.tgz"; - sha256 = "1axdkdm5d2bvj674jq6ylwhfwbzzs7yjj6f04c519qbdq9sknbcn"; - system = "cl-wayland"; - asd = "cl-wayland"; - }); - systems = [ "cl-wayland" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-weather-jp = (build-asdf-system { - pname = "cl-weather-jp"; - version = "20160208-git"; - asds = [ "cl-weather-jp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-weather-jp/2016-02-08/cl-weather-jp-20160208-git.tgz"; - sha256 = "15bp7gdk7ck9xs9lx2rrzqw6awlk6nz03cqy14wv2lvy3j84dc01"; - system = "cl-weather-jp"; - asd = "cl-weather-jp"; - }); - systems = [ "cl-weather-jp" ]; - lispLibs = [ (getAttr "clss" self) (getAttr "dexador" self) (getAttr "function-cache" self) (getAttr "jonathan" self) (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-weather-jp-test = (build-asdf-system { - pname = "cl-weather-jp-test"; - version = "20160208-git"; - asds = [ "cl-weather-jp-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-weather-jp/2016-02-08/cl-weather-jp-20160208-git.tgz"; - sha256 = "15bp7gdk7ck9xs9lx2rrzqw6awlk6nz03cqy14wv2lvy3j84dc01"; - system = "cl-weather-jp-test"; - asd = "cl-weather-jp-test"; - }); - systems = [ "cl-weather-jp-test" ]; - lispLibs = [ (getAttr "cl-weather-jp" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-webdav = (build-asdf-system { - pname = "cl-webdav"; - version = "20170830-git"; - asds = [ "cl-webdav" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-webdav/2017-08-30/cl-webdav-20170830-git.tgz"; - sha256 = "1cmzv763k4s5blfhx2p8s7q9gk20p8mj9p34dngydc14d2acrxmg"; - system = "cl-webdav"; - asd = "cl-webdav"; - }); - systems = [ "cl-webdav" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cxml" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-webdriver-client = (build-asdf-system { - pname = "cl-webdriver-client"; - version = "20241012-git"; - asds = [ "cl-webdriver-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-webdriver-client/2024-10-12/cl-webdriver-client-20241012-git.tgz"; - sha256 = "1975yyvvdxg11vgpyx93nkqr5x6i1xy47230vc40yd0c9bn6lpbr"; - system = "cl-webdriver-client"; - asd = "cl-webdriver-client"; - }); - systems = [ "cl-webdriver-client" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "assoc-utils" self) (getAttr "cl-json" self) (getAttr "dexador" self) (getAttr "quri" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-webdriver-client-test = (build-asdf-system { - pname = "cl-webdriver-client-test"; - version = "20241012-git"; - asds = [ "cl-webdriver-client-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-webdriver-client/2024-10-12/cl-webdriver-client-20241012-git.tgz"; - sha256 = "1975yyvvdxg11vgpyx93nkqr5x6i1xy47230vc40yd0c9bn6lpbr"; - system = "cl-webdriver-client-test"; - asd = "cl-webdriver-client-test"; - }); - systems = [ "cl-webdriver-client-test" ]; - lispLibs = [ (getAttr "cl-webdriver-client" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-webkit2 = (build-asdf-system { - pname = "cl-webkit2"; - version = "20241012-git"; - asds = [ "cl-webkit2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-webkit/2024-10-12/cl-webkit-20241012-git.tgz"; - sha256 = "1ppx4pdnx3c41hp1j8msvpyw22ck2lll2f4ap5hyfvhadp07g3m5"; - system = "cl-webkit2"; - asd = "cl-webkit2"; - }); - systems = [ "cl-webkit2" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-cffi-gtk" self) ]; - meta = {}; - }); - cl-who = (build-asdf-system { - pname = "cl-who"; - version = "20241012-git"; - asds = [ "cl-who" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-who/2024-10-12/cl-who-20241012-git.tgz"; - sha256 = "1kfpy69dw0g7w7k0akimncpkxfqq85r08i2da8nw1dhk2hp6l8jc"; - system = "cl-who"; - asd = "cl-who"; - }); - systems = [ "cl-who" ]; - lispLibs = [ ]; - meta = {}; - }); - cl-who-test = (build-asdf-system { - pname = "cl-who-test"; - version = "20241012-git"; - asds = [ "cl-who-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-who/2024-10-12/cl-who-20241012-git.tgz"; - sha256 = "1kfpy69dw0g7w7k0akimncpkxfqq85r08i2da8nw1dhk2hp6l8jc"; - system = "cl-who-test"; - asd = "cl-who"; - }); - systems = [ "cl-who-test" ]; - lispLibs = [ (getAttr "cl-who" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-why = (build-asdf-system { - pname = "cl-why"; - version = "20180228-git"; - asds = [ "cl-why" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-why/2018-02-28/cl-why-20180228-git.tgz"; - sha256 = "01xm7gj1wwd7i3r49jfdm96gwl7nvrn0h6q22kpzrb8zs48wj947"; - system = "cl-why"; - asd = "cl-why"; - }); - systems = [ "cl-why" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-why-test = (build-asdf-system { - pname = "cl-why-test"; - version = "20180228-git"; - asds = [ "cl-why-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-why/2018-02-28/cl-why-20180228-git.tgz"; - sha256 = "01xm7gj1wwd7i3r49jfdm96gwl7nvrn0h6q22kpzrb8zs48wj947"; - system = "cl-why-test"; - asd = "cl-why"; - }); - systems = [ "cl-why-test" ]; - lispLibs = [ (getAttr "cl-why" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-with = (build-asdf-system { - pname = "cl-with"; - version = "20211020-git"; - asds = [ "cl-with" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-with/2021-10-20/cl-with-20211020-git.tgz"; - sha256 = "1x4laq7zi12xb28rfrh8hcy92pkfvjxsp2nn6jkmrhfynky5180w"; - system = "cl-with"; - asd = "cl-with"; - }); - systems = [ "cl-with" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-wol_dot_cli = (build-asdf-system { - pname = "cl-wol.cli"; - version = "20231021-git"; - asds = [ "cl-wol.cli" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-wol/2023-10-21/cl-wol-20231021-git.tgz"; - sha256 = "1gfrih0899i7280169cjp6bg3zmrx6znrr3i9qjgda0jk4dn5rp4"; - system = "cl-wol.cli"; - asd = "cl-wol.cli"; - }); - systems = [ "cl-wol.cli" ]; - lispLibs = [ (getAttr "cl-ascii-table" self) (getAttr "cl-migratum" self) (getAttr "cl-migratum_dot_driver_dot_dbi" self) (getAttr "cl-migratum_dot_provider_dot_local-path" self) (getAttr "cl-wol_dot_core" self) (getAttr "clingon" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-wol_dot_core = (build-asdf-system { - pname = "cl-wol.core"; - version = "20231021-git"; - asds = [ "cl-wol.core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-wol/2023-10-21/cl-wol-20231021-git.tgz"; - sha256 = "1gfrih0899i7280169cjp6bg3zmrx6znrr3i9qjgda0jk4dn5rp4"; - system = "cl-wol.core"; - asd = "cl-wol.core"; - }); - systems = [ "cl-wol.core" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-wol_dot_test = (build-asdf-system { - pname = "cl-wol.test"; - version = "20231021-git"; - asds = [ "cl-wol.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-wol/2023-10-21/cl-wol-20231021-git.tgz"; - sha256 = "1gfrih0899i7280169cjp6bg3zmrx6znrr3i9qjgda0jk4dn5rp4"; - system = "cl-wol.test"; - asd = "cl-wol.test"; - }); - systems = [ "cl-wol.test" ]; - lispLibs = [ (getAttr "cl-wol_dot_core" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-wordcut = (build-asdf-system { - pname = "cl-wordcut"; - version = "20160421-git"; - asds = [ "cl-wordcut" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-wordcut/2016-04-21/cl-wordcut-20160421-git.tgz"; - sha256 = "1b8b3b1rgk0y87l54325ilcly8rq9qxalcsmw6rk8q6dq13lgv78"; - system = "cl-wordcut"; - asd = "cl-wordcut"; - }); - systems = [ "cl-wordcut" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-xdg = (build-asdf-system { - pname = "cl-xdg"; - version = "20170124-git"; - asds = [ "cl-xdg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-xdg/2017-01-24/cl-xdg-20170124-git.tgz"; - sha256 = "078hgsab0gl6s96wq09ibq5alzyyqh6wwc3yjs44fv18561p5jgc"; - system = "cl-xdg"; - asd = "cl-xdg"; - }); - systems = [ "cl-xdg" ]; - lispLibs = [ (getAttr "cl-sxml" self) (getAttr "cl-xmlspam" self) (getAttr "flexi-streams" self) (getAttr "parse-number" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-xdg-test = (build-asdf-system { - pname = "cl-xdg-test"; - version = "20170124-git"; - asds = [ "cl-xdg-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-xdg/2017-01-24/cl-xdg-20170124-git.tgz"; - sha256 = "078hgsab0gl6s96wq09ibq5alzyyqh6wwc3yjs44fv18561p5jgc"; - system = "cl-xdg-test"; - asd = "cl-xdg"; - }); - systems = [ "cl-xdg-test" ]; - lispLibs = [ (getAttr "cl-xdg" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-xkb = (build-asdf-system { - pname = "cl-xkb"; - version = "20230214-git"; - asds = [ "cl-xkb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-xkb/2023-02-14/cl-xkb-20230214-git.tgz"; - sha256 = "002bskv0dvq2hahz7dah2zwwkp2zrkf98w7lm96jmqfn8vyp4k75"; - system = "cl-xkb"; - asd = "cl-xkb"; - }); - systems = [ "cl-xkb" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-xkeysym = (build-asdf-system { - pname = "cl-xkeysym"; - version = "20140914-git"; - asds = [ "cl-xkeysym" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-xkeysym/2014-09-14/cl-xkeysym-20140914-git.tgz"; - sha256 = "0yxijl6xb5apb6v6qm8g3kfdr90slgg6vsnx4d1ps9z4zhrjlc6c"; - system = "cl-xkeysym"; - asd = "cl-xkeysym"; - }); - systems = [ "cl-xkeysym" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-xmlspam = (build-asdf-system { - pname = "cl-xmlspam"; - version = "20101006-http"; - asds = [ "cl-xmlspam" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-xmlspam/2010-10-06/cl-xmlspam-20101006-http.tgz"; - sha256 = "03jw57889b60nsqgb13vrf5q1g2fasah7qv7knjlx2w4mc1ci7ks"; - system = "cl-xmlspam"; - asd = "cl-xmlspam"; - }); - systems = [ "cl-xmlspam" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cxml" self) ]; - meta = {}; - }); - cl-xmpp = (build-asdf-system { - pname = "cl-xmpp"; - version = "0.8.1"; - asds = [ "cl-xmpp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-xmpp/2010-10-06/cl-xmpp-0.8.1.tgz"; - sha256 = "1kzzq1y0625zlg83ppcpb0aqzvqbga9x3gm826grmy4rf5jrhz5f"; - system = "cl-xmpp"; - asd = "cl-xmpp"; - }); - systems = [ "cl-xmpp" ]; - lispLibs = [ (getAttr "cxml" self) (getAttr "ironclad" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-xmpp-sasl = (build-asdf-system { - pname = "cl-xmpp-sasl"; - version = "0.8.1"; - asds = [ "cl-xmpp-sasl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-xmpp/2010-10-06/cl-xmpp-0.8.1.tgz"; - sha256 = "1kzzq1y0625zlg83ppcpb0aqzvqbga9x3gm826grmy4rf5jrhz5f"; - system = "cl-xmpp-sasl"; - asd = "cl-xmpp-sasl"; - }); - systems = [ "cl-xmpp-sasl" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "cl-sasl" self) (getAttr "cl-xmpp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-xmpp-tls = (build-asdf-system { - pname = "cl-xmpp-tls"; - version = "0.8.1"; - asds = [ "cl-xmpp-tls" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-xmpp/2010-10-06/cl-xmpp-0.8.1.tgz"; - sha256 = "1kzzq1y0625zlg83ppcpb0aqzvqbga9x3gm826grmy4rf5jrhz5f"; - system = "cl-xmpp-tls"; - asd = "cl-xmpp-tls"; - }); - systems = [ "cl-xmpp-tls" ]; - lispLibs = [ (getAttr "cl_plus_ssl" self) (getAttr "cl-xmpp-sasl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-xul = (build-asdf-system { - pname = "cl-xul"; - version = "20160318-git"; - asds = [ "cl-xul" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-xul/2016-03-18/cl-xul-20160318-git.tgz"; - sha256 = "0ldny4bjfndrkyqcq6klqxvqkpb0lhcqlj52y89ybl9w7dkl2d9p"; - system = "cl-xul"; - asd = "cl-xul"; - }); - systems = [ "cl-xul" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "cl-json" self) (getAttr "closer-mop" self) (getAttr "clws" self) (getAttr "cxml" self) (getAttr "log5" self) (getAttr "md5" self) (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-xul-test = (build-asdf-system { - pname = "cl-xul-test"; - version = "20160318-git"; - asds = [ "cl-xul-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-xul/2016-03-18/cl-xul-20160318-git.tgz"; - sha256 = "0ldny4bjfndrkyqcq6klqxvqkpb0lhcqlj52y89ybl9w7dkl2d9p"; - system = "cl-xul-test"; - asd = "cl-xul-test"; - }); - systems = [ "cl-xul-test" ]; - lispLibs = [ (getAttr "cl-xul" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-yaclyaml = (build-asdf-system { - pname = "cl-yaclyaml"; - version = "20160825-git"; - asds = [ "cl-yaclyaml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-yaclyaml/2016-08-25/cl-yaclyaml-20160825-git.tgz"; - sha256 = "1clfhz4ii2p11yc3bm23ib4rx0rfxsh18ddc2br82i7mbwks3pll"; - system = "cl-yaclyaml"; - asd = "cl-yaclyaml"; - }); - systems = [ "cl-yaclyaml" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "cl-test-more" self) (getAttr "esrap-liquid" self) (getAttr "iterate" self) (getAttr "parse-number" self) (getAttr "rutils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-yaclyaml-tests = (build-asdf-system { - pname = "cl-yaclyaml-tests"; - version = "20160825-git"; - asds = [ "cl-yaclyaml-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-yaclyaml/2016-08-25/cl-yaclyaml-20160825-git.tgz"; - sha256 = "1clfhz4ii2p11yc3bm23ib4rx0rfxsh18ddc2br82i7mbwks3pll"; - system = "cl-yaclyaml-tests"; - asd = "cl-yaclyaml"; - }); - systems = [ "cl-yaclyaml-tests" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "cl-yaclyaml" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-yahoo-finance = (build-asdf-system { - pname = "cl-yahoo-finance"; - version = "20130312-git"; - asds = [ "cl-yahoo-finance" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-yahoo-finance/2013-03-12/cl-yahoo-finance-20130312-git.tgz"; - sha256 = "1qhs4j00iw1w81lx0vmyiayzqyvixaxc5j2rc89qlr1gx12mqadl"; - system = "cl-yahoo-finance"; - asd = "cl-yahoo-finance"; - }); - systems = [ "cl-yahoo-finance" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-csv" self) (getAttr "drakma" self) (getAttr "url-rewrite" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-yaml = (build-asdf-system { - pname = "cl-yaml"; - version = "20221106-git"; - asds = [ "cl-yaml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-yaml/2022-11-06/cl-yaml-20221106-git.tgz"; - sha256 = "053fvrrd0p2xx4zxbz4kg9469895ypwsbjfd3nwpi7lwcll2bir5"; - system = "cl-yaml"; - asd = "cl-yaml"; - }); - systems = [ "cl-yaml" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-libyaml" self) (getAttr "cl-ppcre" self) (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-yaml-test = (build-asdf-system { - pname = "cl-yaml-test"; - version = "20221106-git"; - asds = [ "cl-yaml-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-yaml/2022-11-06/cl-yaml-20221106-git.tgz"; - sha256 = "053fvrrd0p2xx4zxbz4kg9469895ypwsbjfd3nwpi7lwcll2bir5"; - system = "cl-yaml-test"; - asd = "cl-yaml-test"; - }); - systems = [ "cl-yaml-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "cl-yaml" self) (getAttr "fiveam" self) (getAttr "generic-comparability" self) (getAttr "trivial-benchmark" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-yesql = (build-asdf-system { - pname = "cl-yesql"; - version = "20211020-git"; - asds = [ "cl-yesql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-yesql/2021-10-20/cl-yesql-20211020-git.tgz"; - sha256 = "0bg133kprbssv0z4ir2hkhf72fbmnz9v9861ncs1isqaby2d4xlj"; - system = "cl-yesql"; - asd = "cl-yesql"; - }); - systems = [ "cl-yesql" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "asdf-package-system" self) (getAttr "esrap" self) (getAttr "serapeum" self) (getAttr "trivia" self) (getAttr "vernacular" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-zipper = (build-asdf-system { - pname = "cl-zipper"; - version = "20200610-git"; - asds = [ "cl-zipper" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-zipper/2020-06-10/cl-zipper-20200610-git.tgz"; - sha256 = "1zcfy97l40ynbldxpx8nad81jlrfp0k2vic10wbkrqdfkr696xkg"; - system = "cl-zipper"; - asd = "cl-zipper"; - }); - systems = [ "cl-zipper" ]; - lispLibs = [ (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl-zipper-test = (build-asdf-system { - pname = "cl-zipper-test"; - version = "20200610-git"; - asds = [ "cl-zipper-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-zipper/2020-06-10/cl-zipper-20200610-git.tgz"; - sha256 = "1zcfy97l40ynbldxpx8nad81jlrfp0k2vic10wbkrqdfkr696xkg"; - system = "cl-zipper-test"; - asd = "cl-zipper"; - }); - systems = [ "cl-zipper-test" ]; - lispLibs = [ (getAttr "cl-zipper" self) (getAttr "prove-asdf" self) (getAttr "test-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cl4store = (build-asdf-system { - pname = "cl4store"; - version = "20200325-git"; - asds = [ "cl4store" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl4store/2020-03-25/cl4store-20200325-git.tgz"; - sha256 = "0qajxwlvmb5vd9qynnl0n62bcl1xhin49xk0p44v6pig8q2jzc26"; - system = "cl4store"; - asd = "cl4store"; - }); - systems = [ "cl4store" ]; - lispLibs = [ (getAttr "cl-rdfxml" self) (getAttr "cl-sparql" self) (getAttr "drakma" self) (getAttr "log5" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clache = (build-asdf-system { - pname = "clache"; - version = "20171130-git"; - asds = [ "clache" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clache/2017-11-30/clache-20171130-git.tgz"; - sha256 = "0wxg004bsay58vr6xr6mlk7wj415qmvisqxvpnjsg6glfwca86ys"; - system = "clache"; - asd = "clache"; - }); - systems = [ "clache" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-annot" self) (getAttr "cl-fad" self) (getAttr "cl-store" self) (getAttr "cl-syntax" self) (getAttr "cl-syntax-annot" self) (getAttr "ironclad" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clache-test = (build-asdf-system { - pname = "clache-test"; - version = "20171130-git"; - asds = [ "clache-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clache/2017-11-30/clache-20171130-git.tgz"; - sha256 = "0wxg004bsay58vr6xr6mlk7wj415qmvisqxvpnjsg6glfwca86ys"; - system = "clache-test"; - asd = "clache-test"; - }); - systems = [ "clache-test" ]; - lispLibs = [ (getAttr "cl-test-more" self) (getAttr "clache" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack = (build-asdf-system { - pname = "clack"; - version = "20241012-git"; - asds = [ "clack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; - sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; - system = "clack"; - asd = "clack"; - }); - systems = [ "clack" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "lack" self) (getAttr "lack-middleware-backtrace" self) (getAttr "lack-util" self) (getAttr "swank" self) (getAttr "usocket" self) ]; - meta = {}; - }); - clack-cors = (build-asdf-system { - pname = "clack-cors"; - version = "20241012-git"; - asds = [ "clack-cors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-cors/2024-10-12/clack-cors-20241012-git.tgz"; - sha256 = "0bndzkrqmdq5cz7wfzr7kw2gy5vk8h1hmf3vplc6mqk7vr3zm6m2"; - system = "clack-cors"; - asd = "clack-cors"; - }); - systems = [ "clack-cors" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "alexandria" self) (getAttr "log4cl" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-cors-ci = (build-asdf-system { - pname = "clack-cors-ci"; - version = "20241012-git"; - asds = [ "clack-cors-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-cors/2024-10-12/clack-cors-20241012-git.tgz"; - sha256 = "0bndzkrqmdq5cz7wfzr7kw2gy5vk8h1hmf3vplc6mqk7vr3zm6m2"; - system = "clack-cors-ci"; - asd = "clack-cors-ci"; - }); - systems = [ "clack-cors-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-cors-docs = (build-asdf-system { - pname = "clack-cors-docs"; - version = "20241012-git"; - asds = [ "clack-cors-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-cors/2024-10-12/clack-cors-20241012-git.tgz"; - sha256 = "0bndzkrqmdq5cz7wfzr7kw2gy5vk8h1hmf3vplc6mqk7vr3zm6m2"; - system = "clack-cors-docs"; - asd = "clack-cors-docs"; - }); - systems = [ "clack-cors-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "clack-cors" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-cors-tests = (build-asdf-system { - pname = "clack-cors-tests"; - version = "20241012-git"; - asds = [ "clack-cors-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-cors/2024-10-12/clack-cors-20241012-git.tgz"; - sha256 = "0bndzkrqmdq5cz7wfzr7kw2gy5vk8h1hmf3vplc6mqk7vr3zm6m2"; - system = "clack-cors-tests"; - asd = "clack-cors-tests"; - }); - systems = [ "clack-cors-tests" ]; - lispLibs = [ (getAttr "clack-test" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-errors = (build-asdf-system { - pname = "clack-errors"; - version = "20190813-git"; - asds = [ "clack-errors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-errors/2019-08-13/clack-errors-20190813-git.tgz"; - sha256 = "0z6jyn37phnpq02l5wml8z0593g8ps95c0c2lzkhi3is2wcj9cpf"; - system = "clack-errors"; - asd = "clack-errors"; - }); - systems = [ "clack-errors" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "clack" self) (getAttr "closer-mop" self) (getAttr "djula" self) (getAttr "local-time" self) (getAttr "trivial-backtrace" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-errors-demo = (build-asdf-system { - pname = "clack-errors-demo"; - version = "20190813-git"; - asds = [ "clack-errors-demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-errors/2019-08-13/clack-errors-20190813-git.tgz"; - sha256 = "0z6jyn37phnpq02l5wml8z0593g8ps95c0c2lzkhi3is2wcj9cpf"; - system = "clack-errors-demo"; - asd = "clack-errors-demo"; - }); - systems = [ "clack-errors-demo" ]; - lispLibs = [ (getAttr "cl-markup" self) (getAttr "clack-errors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-errors-test = (build-asdf-system { - pname = "clack-errors-test"; - version = "20190813-git"; - asds = [ "clack-errors-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-errors/2019-08-13/clack-errors-20190813-git.tgz"; - sha256 = "0z6jyn37phnpq02l5wml8z0593g8ps95c0c2lzkhi3is2wcj9cpf"; - system = "clack-errors-test"; - asd = "clack-errors-test"; - }); - systems = [ "clack-errors-test" ]; - lispLibs = [ (getAttr "clack" self) (getAttr "clack-errors" self) (getAttr "drakma" self) (getAttr "fiveam" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-handler-hunchentoot = (build-asdf-system { - pname = "clack-handler-hunchentoot"; - version = "20241012-git"; - asds = [ "clack-handler-hunchentoot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; - sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; - system = "clack-handler-hunchentoot"; - asd = "clack-handler-hunchentoot"; - }); - systems = [ "clack-handler-hunchentoot" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "clack-socket" self) (getAttr "flexi-streams" self) (getAttr "hunchentoot" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-handler-toot = (build-asdf-system { - pname = "clack-handler-toot"; - version = "20241012-git"; - asds = [ "clack-handler-toot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; - sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; - system = "clack-handler-toot"; - asd = "clack-handler-toot"; - }); - systems = [ "clack-handler-toot" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "split-sequence" self) (getAttr "toot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-handler-woo = (build-asdf-system { - pname = "clack-handler-woo"; - version = "20241012-git"; - asds = [ "clack-handler-woo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/woo/2024-10-12/woo-20241012-git.tgz"; - sha256 = "0nhxlb1qhkl20vknm44gx0cq5cks33rcljczfhgbnmpkzrdpdrrl"; - system = "clack-handler-woo"; - asd = "clack-handler-woo"; - }); - systems = [ "clack-handler-woo" ]; - lispLibs = [ (getAttr "woo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-handler-wookie = (build-asdf-system { - pname = "clack-handler-wookie"; - version = "20241012-git"; - asds = [ "clack-handler-wookie" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; - sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; - system = "clack-handler-wookie"; - asd = "clack-handler-wookie"; - }); - systems = [ "clack-handler-wookie" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-async" self) (getAttr "clack-socket" self) (getAttr "fast-http" self) (getAttr "fast-io" self) (getAttr "flexi-streams" self) (getAttr "quri" self) (getAttr "split-sequence" self) (getAttr "wookie" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-pretend = (build-asdf-system { - pname = "clack-pretend"; - version = "20241012-git"; - asds = [ "clack-pretend" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-pretend/2024-10-12/clack-pretend-20241012-git.tgz"; - sha256 = "0f9y264bdxspd3sfzf9hq7v0myvq5va0drw8kji1b4gyprmg995k"; - system = "clack-pretend"; - asd = "clack-pretend"; - }); - systems = [ "clack-pretend" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "circular-streams" self) (getAttr "cl-hash-util" self) (getAttr "clack" self) (getAttr "lack-request" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-prometheus = (build-asdf-system { - pname = "clack-prometheus"; - version = "20241012-git"; - asds = [ "clack-prometheus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-prometheus/2024-10-12/clack-prometheus-20241012-git.tgz"; - sha256 = "1zkflszvxyhxn7m9c2f1k2snqwdzasbvscw5vpsglb50pczs9g0d"; - system = "clack-prometheus"; - asd = "clack-prometheus"; - }); - systems = [ "clack-prometheus" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "cffi-grovel" self) (getAttr "lack-middleware-mount" self) (getAttr "prometheus" self) (getAttr "prometheus-gc" self) (getAttr "prometheus_dot_collectors_dot_process" self) (getAttr "prometheus_dot_collectors_dot_sbcl" self) (getAttr "prometheus_dot_formats_dot_text" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-prometheus-ci = (build-asdf-system { - pname = "clack-prometheus-ci"; - version = "20241012-git"; - asds = [ "clack-prometheus-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-prometheus/2024-10-12/clack-prometheus-20241012-git.tgz"; - sha256 = "1zkflszvxyhxn7m9c2f1k2snqwdzasbvscw5vpsglb50pczs9g0d"; - system = "clack-prometheus-ci"; - asd = "clack-prometheus-ci"; - }); - systems = [ "clack-prometheus-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-prometheus-docs = (build-asdf-system { - pname = "clack-prometheus-docs"; - version = "20241012-git"; - asds = [ "clack-prometheus-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-prometheus/2024-10-12/clack-prometheus-20241012-git.tgz"; - sha256 = "1zkflszvxyhxn7m9c2f1k2snqwdzasbvscw5vpsglb50pczs9g0d"; - system = "clack-prometheus-docs"; - asd = "clack-prometheus-docs"; - }); - systems = [ "clack-prometheus-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "clack-prometheus" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-prometheus-tests = (build-asdf-system { - pname = "clack-prometheus-tests"; - version = "20241012-git"; - asds = [ "clack-prometheus-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-prometheus/2024-10-12/clack-prometheus-20241012-git.tgz"; - sha256 = "1zkflszvxyhxn7m9c2f1k2snqwdzasbvscw5vpsglb50pczs9g0d"; - system = "clack-prometheus-tests"; - asd = "clack-prometheus-tests"; - }); - systems = [ "clack-prometheus-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-socket = (build-asdf-system { - pname = "clack-socket"; - version = "20241012-git"; - asds = [ "clack-socket" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; - sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; - system = "clack-socket"; - asd = "clack-socket"; - }); - systems = [ "clack-socket" ]; - lispLibs = [ ]; - meta = {}; - }); - clack-static-asset-djula-helpers = (build-asdf-system { - pname = "clack-static-asset-djula-helpers"; - version = "20211209-git"; - asds = [ "clack-static-asset-djula-helpers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-static-asset-middleware/2021-12-09/clack-static-asset-middleware-20211209-git.tgz"; - sha256 = "0fk288812sdm012knqx4qqdhggdqbfgd0zfb6mc06xig20wj02hc"; - system = "clack-static-asset-djula-helpers"; - asd = "clack-static-asset-djula-helpers"; - }); - systems = [ "clack-static-asset-djula-helpers" ]; - lispLibs = [ (getAttr "clack-static-asset-middleware" self) (getAttr "djula" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-static-asset-middleware = (build-asdf-system { - pname = "clack-static-asset-middleware"; - version = "20211209-git"; - asds = [ "clack-static-asset-middleware" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-static-asset-middleware/2021-12-09/clack-static-asset-middleware-20211209-git.tgz"; - sha256 = "0fk288812sdm012knqx4qqdhggdqbfgd0zfb6mc06xig20wj02hc"; - system = "clack-static-asset-middleware"; - asd = "clack-static-asset-middleware"; - }); - systems = [ "clack-static-asset-middleware" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "ironclad" self) (getAttr "local-time" self) (getAttr "trivial-mimes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-static-asset-middleware-test = (build-asdf-system { - pname = "clack-static-asset-middleware-test"; - version = "20211209-git"; - asds = [ "clack-static-asset-middleware-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-static-asset-middleware/2021-12-09/clack-static-asset-middleware-20211209-git.tgz"; - sha256 = "0fk288812sdm012knqx4qqdhggdqbfgd0zfb6mc06xig20wj02hc"; - system = "clack-static-asset-middleware-test"; - asd = "clack-static-asset-middleware-test"; - }); - systems = [ "clack-static-asset-middleware-test" ]; - lispLibs = [ (getAttr "clack-static-asset-djula-helpers" self) (getAttr "clack-static-asset-middleware" self) (getAttr "lack-test" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clack-test = (build-asdf-system { - pname = "clack-test"; - version = "20241012-git"; - asds = [ "clack-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; - sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; - system = "clack-test"; - asd = "clack-test"; - }); - systems = [ "clack-test" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "clack" self) (getAttr "clack-handler-hunchentoot" self) (getAttr "dexador" self) (getAttr "flexi-streams" self) (getAttr "http-body" self) (getAttr "ironclad" self) (getAttr "rove" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clad = (build-asdf-system { - pname = "clad"; - version = "20241012-git"; - asds = [ "clad" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clad/2024-10-12/clad-20241012-git.tgz"; - sha256 = "1ah8d4wyd7yqchcnyjcnd27gx2m410cgybyp194ng1ipdpa4mm6n"; - system = "clad"; - asd = "clad"; - }); - systems = [ "clad" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - class-options = (build-asdf-system { - pname = "class-options"; - version = "1.0.1"; - asds = [ "class-options" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/class-options/2020-10-16/class-options_1.0.1.tgz"; - sha256 = "1dkgr1vbrsra44jznzz2bvdf8nlpdrrkjcqrfs8aa7axksda3bqk"; - system = "class-options"; - asd = "class-options"; - }); - systems = [ "class-options" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - class-options__tests = (build-asdf-system { - pname = "class-options_tests"; - version = "1.0.1"; - asds = [ "class-options_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/class-options/2020-10-16/class-options_1.0.1.tgz"; - sha256 = "1dkgr1vbrsra44jznzz2bvdf8nlpdrrkjcqrfs8aa7axksda3bqk"; - system = "class-options_tests"; - asd = "class-options_tests"; - }); - systems = [ "class-options_tests" ]; - lispLibs = [ (getAttr "class-options" self) (getAttr "closer-mop" self) (getAttr "enhanced-boolean" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - classimp = (build-asdf-system { - pname = "classimp"; - version = "20241012-git"; - asds = [ "classimp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/classimp/2024-10-12/classimp-20241012-git.tgz"; - sha256 = "1sq34s5yrljh7fffllsscay7xi11lg03alrkyrh6xfwa2w7cnqmx"; - system = "classimp"; - asd = "classimp"; - }); - systems = [ "classimp" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - classimp-samples = (build-asdf-system { - pname = "classimp-samples"; - version = "20241012-git"; - asds = [ "classimp-samples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/classimp/2024-10-12/classimp-20241012-git.tgz"; - sha256 = "1sq34s5yrljh7fffllsscay7xi11lg03alrkyrh6xfwa2w7cnqmx"; - system = "classimp-samples"; - asd = "classimp-samples"; - }); - systems = [ "classimp-samples" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cl-glu" self) (getAttr "cl-glut" self) (getAttr "cl-ilut" self) (getAttr "classimp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - classowary = (build-asdf-system { - pname = "classowary"; - version = "20231021-git"; - asds = [ "classowary" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/classowary/2023-10-21/classowary-20231021-git.tgz"; - sha256 = "099zhf41d4frlrm99ldzypqjh03ijrvfn29f2pb0j6664h65bcsm"; - system = "classowary"; - asd = "classowary"; - }); - systems = [ "classowary" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = {}; - }); - classowary-test = (build-asdf-system { - pname = "classowary-test"; - version = "20231021-git"; - asds = [ "classowary-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/classowary/2023-10-21/classowary-20231021-git.tgz"; - sha256 = "099zhf41d4frlrm99ldzypqjh03ijrvfn29f2pb0j6664h65bcsm"; - system = "classowary-test"; - asd = "classowary-test"; - }); - systems = [ "classowary-test" ]; - lispLibs = [ (getAttr "classowary" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clast = (build-asdf-system { - pname = "clast"; - version = "20241012-git"; - asds = [ "clast" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clast/2024-10-12/clast-20241012-git.tgz"; - sha256 = "0509hrpd049s62s03wwb2mp24dfw8f0l8cg0vgq3s8wrsch7af2m"; - system = "clast"; - asd = "clast"; - }); - systems = [ "clast" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clath = (build-asdf-system { - pname = "clath"; - version = "20241012-git"; - asds = [ "clath" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clath/2024-10-12/clath-20241012-git.tgz"; - sha256 = "0519jzm8r55am6f5w11pfbyq0bvn8jxkcz33kbrznwrf43xz5fcv"; - system = "clath"; - asd = "clath"; - }); - systems = [ "clath" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-hash-util" self) (getAttr "cl-json" self) (getAttr "cl-who" self) (getAttr "clack" self) (getAttr "drakma" self) (getAttr "flexi-streams" self) (getAttr "ironclad" self) (getAttr "jose" self) (getAttr "ningle" self) (getAttr "north" self) (getAttr "ubiquitous" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clavatar = (build-asdf-system { - pname = "clavatar"; - version = "20121013-git"; - asds = [ "clavatar" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clavatar/2012-10-13/clavatar-20121013-git.tgz"; - sha256 = "07r58d4dk5nr3aimrryzbf3jw6580b5gkkbpw74ax4nmm8hz6v5y"; - system = "clavatar"; - asd = "clavatar"; - }); - systems = [ "clavatar" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "drakma" self) (getAttr "iolib" self) (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clavier = (build-asdf-system { - pname = "clavier"; - version = "20241012-git"; - asds = [ "clavier" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clavier/2024-10-12/clavier-20241012-git.tgz"; - sha256 = "0v81ql9bbnsqaxcrv0ynm82xwifxvc6ysmfrn1lgphn4szx1p230"; - system = "clavier"; - asd = "clavier"; - }); - systems = [ "clavier" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "chronicity" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clavier_dot_test = (build-asdf-system { - pname = "clavier.test"; - version = "20241012-git"; - asds = [ "clavier.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clavier/2024-10-12/clavier-20241012-git.tgz"; - sha256 = "0v81ql9bbnsqaxcrv0ynm82xwifxvc6ysmfrn1lgphn4szx1p230"; - system = "clavier.test"; - asd = "clavier.test"; - }); - systems = [ "clavier.test" ]; - lispLibs = [ (getAttr "clavier" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - claw = (build-asdf-system { - pname = "claw"; - version = "stable-git"; - asds = [ "claw" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/claw/2020-10-16/claw-stable-git.tgz"; - sha256 = "146yv0hc4hmk72562ssj2d41143pp84dcbd1h7f4nx1c7hf2bb0d"; - system = "claw"; - asd = "claw"; - }); - systems = [ "claw" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "claw-support" self) (getAttr "local-time" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - claw-olm = (build-asdf-system { - pname = "claw-olm"; - version = "20210531-git"; - asds = [ "claw-olm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/claw-olm/2021-05-31/claw-olm-20210531-git.tgz"; - sha256 = "04r6d8infhcc7vz95asrvlpc0wzkzq1blaza74nd62alakr6mmrr"; - system = "claw-olm"; - asd = "claw-olm"; - }); - systems = [ "claw-olm" ]; - lispLibs = [ (getAttr "claw-olm-bindings" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - claw-olm-bindings = (build-asdf-system { - pname = "claw-olm-bindings"; - version = "20210531-git"; - asds = [ "claw-olm-bindings" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/claw-olm/2021-05-31/claw-olm-20210531-git.tgz"; - sha256 = "04r6d8infhcc7vz95asrvlpc0wzkzq1blaza74nd62alakr6mmrr"; - system = "claw-olm-bindings"; - asd = "claw-olm-bindings"; - }); - systems = [ "claw-olm-bindings" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - claw-support = (build-asdf-system { - pname = "claw-support"; - version = "stable-git"; - asds = [ "claw-support" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/claw-support/2020-10-16/claw-support-stable-git.tgz"; - sha256 = "1my2ka7h72ipx5n3b465g6kjkasrhsvhqlijwcg6dhlzs5yygl23"; - system = "claw-support"; - asd = "claw-support"; - }); - systems = [ "claw-support" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - claw-utils = (build-asdf-system { - pname = "claw-utils"; - version = "stable-git"; - asds = [ "claw-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/claw-utils/2020-10-16/claw-utils-stable-git.tgz"; - sha256 = "01df3kyf2qs3czi332dnz2s35x2j0fq46vgmsw7wjrrvnqc22mk5"; - system = "claw-utils"; - asd = "claw-utils"; - }); - systems = [ "claw-utils" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "claw" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clawk = (build-asdf-system { - pname = "clawk"; - version = "20200925-git"; - asds = [ "clawk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clawk/2020-09-25/clawk-20200925-git.tgz"; - sha256 = "1ph3xjqilvinvgr9q3w47zxqyz1sqnq030nlx7kgkkv8j3bnqk7a"; - system = "clawk"; - asd = "clawk"; - }); - systems = [ "clawk" ]; - lispLibs = [ (getAttr "regex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - claxy = (build-asdf-system { - pname = "claxy"; - version = "20220220-git"; - asds = [ "claxy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/claxy/2022-02-20/claxy-20220220-git.tgz"; - sha256 = "1n6zbsfp0zkndw7r3nar8srjj1wmfgngia3p7z756mmsvp1l68va"; - system = "claxy"; - asd = "claxy"; - }); - systems = [ "claxy" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "dexador" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clazy = (build-asdf-system { - pname = "clazy"; - version = "20241012-git"; - asds = [ "clazy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clazy/2024-10-12/clazy-20241012-git.tgz"; - sha256 = "0z9iy89p4grj2a803nlrnvj335c6knmnlbicpf0b4br41j6q74xj"; - system = "clazy"; - asd = "clazy"; - }); - systems = [ "clazy" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clem = (build-asdf-system { - pname = "clem"; - version = "20210807-git"; - asds = [ "clem" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clem/2021-08-07/clem-20210807-git.tgz"; - sha256 = "0vmsgxdpxrqkx3xp9n8b0fwkzk1r2dwcwjlc8yy5w2m2sighh2rk"; - system = "clem"; - asd = "clem"; - }); - systems = [ "clem" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clem-benchmark = (build-asdf-system { - pname = "clem-benchmark"; - version = "20210807-git"; - asds = [ "clem-benchmark" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clem/2021-08-07/clem-20210807-git.tgz"; - sha256 = "0vmsgxdpxrqkx3xp9n8b0fwkzk1r2dwcwjlc8yy5w2m2sighh2rk"; - system = "clem-benchmark"; - asd = "clem-benchmark"; - }); - systems = [ "clem-benchmark" ]; - lispLibs = [ (getAttr "clem" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clem-test = (build-asdf-system { - pname = "clem-test"; - version = "20210807-git"; - asds = [ "clem-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clem/2021-08-07/clem-20210807-git.tgz"; - sha256 = "0vmsgxdpxrqkx3xp9n8b0fwkzk1r2dwcwjlc8yy5w2m2sighh2rk"; - system = "clem-test"; - asd = "clem-test"; - }); - systems = [ "clem-test" ]; - lispLibs = [ (getAttr "clem" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cleric = (build-asdf-system { - pname = "cleric"; - version = "20220220-git"; - asds = [ "cleric" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cleric/2022-02-20/cleric-20220220-git.tgz"; - sha256 = "0a0xqr0bpp0v62f8d13yflz3vz6j4fa9icgc134ajaqxcfa7k0vp"; - system = "cleric"; - asd = "cleric"; - }); - systems = [ "cleric" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "com_dot_gigamonkeys_dot_binary-data" self) (getAttr "epmd" self) (getAttr "erlang-term" self) (getAttr "md5" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cleric-test = (build-asdf-system { - pname = "cleric-test"; - version = "20220220-git"; - asds = [ "cleric-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cleric/2022-02-20/cleric-20220220-git.tgz"; - sha256 = "0a0xqr0bpp0v62f8d13yflz3vz6j4fa9icgc134ajaqxcfa7k0vp"; - system = "cleric-test"; - asd = "cleric-test"; - }); - systems = [ "cleric-test" ]; - lispLibs = [ (getAttr "cleric" self) (getAttr "erlang-term-test" self) (getAttr "fiveam" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clerk = (build-asdf-system { - pname = "clerk"; - version = "20241012-git"; - asds = [ "clerk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clerk/2024-10-12/clerk-20241012-git.tgz"; - sha256 = "0p81ha537bfs8421y74vrvhi1h61f38djr3iwgab30f6sdfj4k8j"; - system = "clerk"; - asd = "clerk"; - }); - systems = [ "clerk" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clerk-test = (build-asdf-system { - pname = "clerk-test"; - version = "20241012-git"; - asds = [ "clerk-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clerk/2024-10-12/clerk-20241012-git.tgz"; - sha256 = "0p81ha537bfs8421y74vrvhi1h61f38djr3iwgab30f6sdfj4k8j"; - system = "clerk-test"; - asd = "clerk"; - }); - systems = [ "clerk-test" ]; - lispLibs = [ (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clesh = (build-asdf-system { - pname = "clesh"; - version = "20201220-git"; - asds = [ "clesh" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clesh/2020-12-20/clesh-20201220-git.tgz"; - sha256 = "012ry02djnqyvvs61wbbqj3saz621w2l9gczrywdxhi5p4ycx318"; - system = "clesh"; - asd = "clesh"; - }); - systems = [ "clesh" ]; - lispLibs = [ (getAttr "named-readtables" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clesh-tests = (build-asdf-system { - pname = "clesh-tests"; - version = "20201220-git"; - asds = [ "clesh-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clesh/2020-12-20/clesh-20201220-git.tgz"; - sha256 = "012ry02djnqyvvs61wbbqj3saz621w2l9gczrywdxhi5p4ycx318"; - system = "clesh-tests"; - asd = "clesh-tests"; - }); - systems = [ "clesh-tests" ]; - lispLibs = [ (getAttr "clesh" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cletris = (build-asdf-system { - pname = "cletris"; - version = "20211020-git"; - asds = [ "cletris" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cletris/2021-10-20/cletris-20211020-git.tgz"; - sha256 = "0k7j0jg4dc6q7p7h3vin3hs0f7q8d7yarg2mw0c3hng19r4q9p8v"; - system = "cletris"; - asd = "cletris"; - }); - systems = [ "cletris" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "pal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cletris-network = (build-asdf-system { - pname = "cletris-network"; - version = "20211020-git"; - asds = [ "cletris-network" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cletris/2021-10-20/cletris-20211020-git.tgz"; - sha256 = "0k7j0jg4dc6q7p7h3vin3hs0f7q8d7yarg2mw0c3hng19r4q9p8v"; - system = "cletris-network"; - asd = "cletris-network"; - }); - systems = [ "cletris-network" ]; - lispLibs = [ (getAttr "cl-log" self) (getAttr "cl-ppcre" self) (getAttr "cletris" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cletris-test = (build-asdf-system { - pname = "cletris-test"; - version = "20211020-git"; - asds = [ "cletris-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cletris/2021-10-20/cletris-20211020-git.tgz"; - sha256 = "0k7j0jg4dc6q7p7h3vin3hs0f7q8d7yarg2mw0c3hng19r4q9p8v"; - system = "cletris-test"; - asd = "cletris-test"; - }); - systems = [ "cletris-test" ]; - lispLibs = [ (getAttr "cletris" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clfswm = (build-asdf-system { - pname = "clfswm"; - version = "20161204-git"; - asds = [ "clfswm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clfswm/2016-12-04/clfswm-20161204-git.tgz"; - sha256 = "1r84cpcs74avkjw18ckz3r3836xhky2fcf5ypbfmajpjzxwn5dzc"; - system = "clfswm"; - asd = "clfswm"; - }); - systems = [ "clfswm" ]; - lispLibs = [ (getAttr "clx" self) ]; - meta = {}; - }); - clgplot = (build-asdf-system { - pname = "clgplot"; - version = "20241012-git"; - asds = [ "clgplot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clgplot/2024-10-12/clgplot-20241012-git.tgz"; - sha256 = "0sl5g33v1lpkjimmcs22f32hgnlfhz0ydd5rgy0ykwb7jf7x3pv7"; - system = "clgplot"; - asd = "clgplot"; - }); - systems = [ "clgplot" ]; - lispLibs = [ (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clgplot-test = (build-asdf-system { - pname = "clgplot-test"; - version = "20241012-git"; - asds = [ "clgplot-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clgplot/2024-10-12/clgplot-20241012-git.tgz"; - sha256 = "0sl5g33v1lpkjimmcs22f32hgnlfhz0ydd5rgy0ykwb7jf7x3pv7"; - system = "clgplot-test"; - asd = "clgplot-test"; - }); - systems = [ "clgplot-test" ]; - lispLibs = [ (getAttr "clgplot" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clhs = (build-asdf-system { - pname = "clhs"; - version = "0.6.3"; - asds = [ "clhs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clhs/2015-04-07/clhs-0.6.3.tgz"; - sha256 = "1jffq2w9yql4cvxy2g5c2v402014306qklp4xhddjjlfvs30sfjd"; - system = "clhs"; - asd = "clhs"; - }); - systems = [ "clhs" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cli-parser = (build-asdf-system { - pname = "cli-parser"; - version = "20150608-git"; - asds = [ "cli-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cli-parser/2015-06-08/cl-cli-parser-20150608-git.tgz"; - sha256 = "0gnpakzakkb2j67v2wh4q87k6mmrv0c0fg56m4vx88kgpxp7f90f"; - system = "cli-parser"; - asd = "cli-parser"; - }); - systems = [ "cli-parser" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clickr = (build-asdf-system { - pname = "clickr"; - version = "20140713-git"; - asds = [ "clickr" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clickr/2014-07-13/clickr-20140713-git.tgz"; - sha256 = "0sykp4aaxjf8xcyiqyqs6967f0fna8ahjqi7ij5z79fd530sxz2s"; - system = "clickr"; - asd = "clickr"; - }); - systems = [ "clickr" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "md5" self) (getAttr "s-xml" self) (getAttr "s-xml-rpc" self) (getAttr "trivial-http" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clim = (build-asdf-system { - pname = "clim"; - version = "20241012-git"; - asds = [ "clim" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "clim"; - asd = "clim"; - }); - systems = [ "clim" ]; - lispLibs = [ (getAttr "clim-core" self) (getAttr "drei-mcclim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clim-core = (build-asdf-system { - pname = "clim-core"; - version = "20241012-git"; - asds = [ "clim-core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "clim-core"; - asd = "clim-core"; - }); - systems = [ "clim-core" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "cluffer" self) (getAttr "spatial-trees" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clim-debugger = (build-asdf-system { - pname = "clim-debugger"; - version = "20241012-git"; - asds = [ "clim-debugger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "clim-debugger"; - asd = "clim-debugger"; - }); - systems = [ "clim-debugger" ]; - lispLibs = [ (getAttr "clouseau" self) (getAttr "mcclim" self) (getAttr "slim" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clim-examples = (build-asdf-system { - pname = "clim-examples"; - version = "20241012-git"; - asds = [ "clim-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "clim-examples"; - asd = "clim-examples"; - }); - systems = [ "clim-examples" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "clim" self) (getAttr "closer-mop" self) (getAttr "lorem-ipsum" self) (getAttr "mcclim" self) (getAttr "mcclim-raster-image" self) (getAttr "mcclim-svg" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clim-lisp = (build-asdf-system { - pname = "clim-lisp"; - version = "20241012-git"; - asds = [ "clim-lisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "clim-lisp"; - asd = "clim-lisp"; - }); - systems = [ "clim-lisp" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "cluffer" self) (getAttr "trivial-features" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clim-listener = (build-asdf-system { - pname = "clim-listener"; - version = "20241012-git"; - asds = [ "clim-listener" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "clim-listener"; - asd = "clim-listener"; - }); - systems = [ "clim-listener" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "clim-debugger" self) (getAttr "mcclim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clim-pdf = (build-asdf-system { - pname = "clim-pdf"; - version = "20241012-git"; - asds = [ "clim-pdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "clim-pdf"; - asd = "clim-pdf"; - }); - systems = [ "clim-pdf" ]; - lispLibs = [ (getAttr "cl-pdf" self) (getAttr "cl-pdf-parser" self) (getAttr "clim" self) (getAttr "clim-postscript" self) (getAttr "clim-postscript-font" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clim-postscript = (build-asdf-system { - pname = "clim-postscript"; - version = "20241012-git"; - asds = [ "clim-postscript" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "clim-postscript"; - asd = "clim-postscript"; - }); - systems = [ "clim-postscript" ]; - lispLibs = [ (getAttr "clim" self) (getAttr "clim-postscript-font" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clim-postscript-font = (build-asdf-system { - pname = "clim-postscript-font"; - version = "20241012-git"; - asds = [ "clim-postscript-font" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "clim-postscript-font"; - asd = "clim-postscript-font"; - }); - systems = [ "clim-postscript-font" ]; - lispLibs = [ (getAttr "clim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clim-widgets = (build-asdf-system { - pname = "clim-widgets"; - version = "20200715-git"; - asds = [ "clim-widgets" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clim-widgets/2020-07-15/clim-widgets-20200715-git.tgz"; - sha256 = "0cpr8xn5a33sy75d06b95cfd3b1h9m5iixgg5h4isavpx3aglmy2"; - system = "clim-widgets"; - asd = "clim-widgets"; - }); - systems = [ "clim-widgets" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "closer-mop" self) (getAttr "local-time" self) (getAttr "manifest" self) (getAttr "mcclim" self) (getAttr "nsort" self) (getAttr "perlre" self) (getAttr "simple-date-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - climacs = (build-asdf-system { - pname = "climacs"; - version = "20241012-git"; - asds = [ "climacs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/climacs/2024-10-12/climacs-20241012-git.tgz"; - sha256 = "0swbnsnavwaxpdcdsdag6iadc6v436pawbrzz6p8lkkbmbmc7yf8"; - system = "climacs"; - asd = "climacs"; - }); - systems = [ "climacs" ]; - lispLibs = [ (getAttr "flexichain" self) (getAttr "mcclim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - climc = (build-asdf-system { - pname = "climc"; - version = "20230214-git"; - asds = [ "climc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/climc/2023-02-14/climc-20230214-git.tgz"; - sha256 = "0wnsyxkff5i4n36rwb5z54j4gi0j9n8459wcm6cj3lg77njmpasb"; - system = "climc"; - asd = "climc"; - }); - systems = [ "climc" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cl-xmpp-tls" self) (getAttr "mcclim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - climc-test = (build-asdf-system { - pname = "climc-test"; - version = "20230214-git"; - asds = [ "climc-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/climc/2023-02-14/climc-20230214-git.tgz"; - sha256 = "0wnsyxkff5i4n36rwb5z54j4gi0j9n8459wcm6cj3lg77njmpasb"; - system = "climc-test"; - asd = "climc-test"; - }); - systems = [ "climc-test" ]; - lispLibs = [ (getAttr "climc" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - climon = (build-asdf-system { - pname = "climon"; - version = "20220220-git"; - asds = [ "climon" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/climon/2022-02-20/climon-20220220-git.tgz"; - sha256 = "00bdxpzgvmf5yg785xc9454nv7x5n314kywjd0f12mbvrgklb818"; - system = "climon"; - asd = "climon"; - }); - systems = [ "climon" ]; - lispLibs = [ (getAttr "pal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - climon-test = (build-asdf-system { - pname = "climon-test"; - version = "20220220-git"; - asds = [ "climon-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/climon/2022-02-20/climon-20220220-git.tgz"; - sha256 = "00bdxpzgvmf5yg785xc9454nv7x5n314kywjd0f12mbvrgklb818"; - system = "climon-test"; - asd = "climon-test"; - }); - systems = [ "climon-test" ]; - lispLibs = [ (getAttr "climon" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clinch = (build-asdf-system { - pname = "clinch"; - version = "20180228-git"; - asds = [ "clinch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clinch/2018-02-28/clinch-20180228-git.tgz"; - sha256 = "0hrj3kdxnazffrax3jmr6pgfahpj94lg43lczha6xpayhl49bqik"; - system = "clinch"; - asd = "clinch"; - }); - systems = [ "clinch" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-opengl" self) (getAttr "rtg-math" self) (getAttr "sdl2" self) (getAttr "swank" self) (getAttr "trivial-channels" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clinch-cairo = (build-asdf-system { - pname = "clinch-cairo"; - version = "20180228-git"; - asds = [ "clinch-cairo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clinch/2018-02-28/clinch-20180228-git.tgz"; - sha256 = "0hrj3kdxnazffrax3jmr6pgfahpj94lg43lczha6xpayhl49bqik"; - system = "clinch-cairo"; - asd = "clinch-cairo"; - }); - systems = [ "clinch-cairo" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-cairo2" self) (getAttr "clinch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clinch-classimp = (build-asdf-system { - pname = "clinch-classimp"; - version = "20180228-git"; - asds = [ "clinch-classimp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clinch/2018-02-28/clinch-20180228-git.tgz"; - sha256 = "0hrj3kdxnazffrax3jmr6pgfahpj94lg43lczha6xpayhl49bqik"; - system = "clinch-classimp"; - asd = "clinch-classimp"; - }); - systems = [ "clinch-classimp" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "classimp" self) (getAttr "clinch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clinch-freeimage = (build-asdf-system { - pname = "clinch-freeimage"; - version = "20180228-git"; - asds = [ "clinch-freeimage" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clinch/2018-02-28/clinch-20180228-git.tgz"; - sha256 = "0hrj3kdxnazffrax3jmr6pgfahpj94lg43lczha6xpayhl49bqik"; - system = "clinch-freeimage"; - asd = "clinch-freeimage"; - }); - systems = [ "clinch-freeimage" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-freeimage" self) (getAttr "clinch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clinch-pango = (build-asdf-system { - pname = "clinch-pango"; - version = "20180228-git"; - asds = [ "clinch-pango" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clinch/2018-02-28/clinch-20180228-git.tgz"; - sha256 = "0hrj3kdxnazffrax3jmr6pgfahpj94lg43lczha6xpayhl49bqik"; - system = "clinch-pango"; - asd = "clinch-pango"; - }); - systems = [ "clinch-pango" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-cairo2" self) (getAttr "cl-pango" self) (getAttr "clinch" self) (getAttr "clinch-cairo" self) (getAttr "xmls" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clinenoise = (build-asdf-system { - pname = "clinenoise"; - version = "20200427-git"; - asds = [ "clinenoise" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clinenoise/2020-04-27/clinenoise-20200427-git.tgz"; - sha256 = "0ydlirfk4dbpqqjwwph99v5swcrhd8v9g8q24fvs35wn2vm08lh1"; - system = "clinenoise"; - asd = "clinenoise"; - }); - systems = [ "clinenoise" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clingon = (build-asdf-system { - pname = "clingon"; - version = "20241012-git"; - asds = [ "clingon" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clingon/2024-10-12/clingon-20241012-git.tgz"; - sha256 = "0p8i9bkzzy4v0pg15dldrl73xri4kxyxa7si82bawh1dnnm53jgc"; - system = "clingon"; - asd = "clingon"; - }); - systems = [ "clingon" ]; - lispLibs = [ (getAttr "bobbin" self) (getAttr "cl-reexport" self) (getAttr "split-sequence" self) (getAttr "with-user-abort" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clingon_dot_demo = (build-asdf-system { - pname = "clingon.demo"; - version = "20241012-git"; - asds = [ "clingon.demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clingon/2024-10-12/clingon-20241012-git.tgz"; - sha256 = "0p8i9bkzzy4v0pg15dldrl73xri4kxyxa7si82bawh1dnnm53jgc"; - system = "clingon.demo"; - asd = "clingon.demo"; - }); - systems = [ "clingon.demo" ]; - lispLibs = [ (getAttr "clingon" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clingon_dot_intro = (build-asdf-system { - pname = "clingon.intro"; - version = "20241012-git"; - asds = [ "clingon.intro" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clingon/2024-10-12/clingon-20241012-git.tgz"; - sha256 = "0p8i9bkzzy4v0pg15dldrl73xri4kxyxa7si82bawh1dnnm53jgc"; - system = "clingon.intro"; - asd = "clingon.intro"; - }); - systems = [ "clingon.intro" ]; - lispLibs = [ (getAttr "clingon" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clingon_dot_test = (build-asdf-system { - pname = "clingon.test"; - version = "20241012-git"; - asds = [ "clingon.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clingon/2024-10-12/clingon-20241012-git.tgz"; - sha256 = "0p8i9bkzzy4v0pg15dldrl73xri4kxyxa7si82bawh1dnnm53jgc"; - system = "clingon.test"; - asd = "clingon.test"; - }); - systems = [ "clingon.test" ]; - lispLibs = [ (getAttr "clingon" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clip = (build-asdf-system { - pname = "clip"; - version = "20241012-git"; - asds = [ "clip" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clip/2024-10-12/clip-20241012-git.tgz"; - sha256 = "1ikzfza4s5xl67bz4vi05hmqmkvs5qr2ycy1f6vi1ihsdvjfify0"; - system = "clip"; - asd = "clip"; - }); - systems = [ "clip" ]; - lispLibs = [ (getAttr "array-utils" self) (getAttr "lquery" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clipper = (build-asdf-system { - pname = "clipper"; - version = "20150923-git"; - asds = [ "clipper" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clipper/2015-09-23/clipper-20150923-git.tgz"; - sha256 = "0xx1z7xjy2qkb6hx4bjjxcpv180lynpxrmx0741zk0qcxf32y56n"; - system = "clipper"; - asd = "clipper"; - }); - systems = [ "clipper" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "cl-syntax-annot" self) (getAttr "closer-mop" self) (getAttr "dexador" self) (getAttr "fast-io" self) (getAttr "opticl" self) (getAttr "quri" self) (getAttr "split-sequence" self) (getAttr "zs3" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clipper-test = (build-asdf-system { - pname = "clipper-test"; - version = "20150923-git"; - asds = [ "clipper-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clipper/2015-09-23/clipper-20150923-git.tgz"; - sha256 = "0xx1z7xjy2qkb6hx4bjjxcpv180lynpxrmx0741zk0qcxf32y56n"; - system = "clipper-test"; - asd = "clipper-test"; - }); - systems = [ "clipper-test" ]; - lispLibs = [ (getAttr "clipper" self) (getAttr "integral" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clite = (build-asdf-system { - pname = "clite"; - version = "20130615-git"; - asds = [ "clite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clite/2013-06-15/clite-20130615-git.tgz"; - sha256 = "0q73vzm55i7m6in9i3fwwaqxvwm3pr7mm7gh7qsvfya61248ynrz"; - system = "clite"; - asd = "clite"; - }); - systems = [ "clite" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clith = (build-asdf-system { - pname = "clith"; - version = "20241012-git"; - asds = [ "clith" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clith/2024-10-12/clith-20241012-git.tgz"; - sha256 = "02qfyrnihx9x6nwxgzlh2x6ymz90i524jg8gc5zsy9rcfqj2sfa7"; - system = "clith"; - asd = "clith"; - }); - systems = [ "clith" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clj = (build-asdf-system { - pname = "clj"; - version = "20201220-git"; - asds = [ "clj" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clj/2020-12-20/clj-20201220-git.tgz"; - sha256 = "0yic6w2n09w3v2r1dlg9a7z59j9rapj4hpz8whcxlw6zs4wrwib2"; - system = "clj"; - asd = "clj"; - }); - systems = [ "clj" ]; - lispLibs = [ (getAttr "agnostic-lizard" self) (getAttr "arrow-macros" self) (getAttr "cl-hamt" self) (getAttr "local-package-aliases" self) (getAttr "named-readtables" self) (getAttr "optima" self) (getAttr "prove-asdf" self) (getAttr "test-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clj-arrows = (build-asdf-system { - pname = "clj-arrows"; - version = "20241012-git"; - asds = [ "clj-arrows" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clj-arrows/2024-10-12/clj-arrows-20241012-git.tgz"; - sha256 = "0b0dpjbyk41h32laqa4hwlgximafkjgrgdahabyc3blkg5v7lill"; - system = "clj-arrows"; - asd = "clj-arrows"; - }); - systems = [ "clj-arrows" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clj-arrows-test = (build-asdf-system { - pname = "clj-arrows-test"; - version = "20241012-git"; - asds = [ "clj-arrows-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clj-arrows/2024-10-12/clj-arrows-20241012-git.tgz"; - sha256 = "0b0dpjbyk41h32laqa4hwlgximafkjgrgdahabyc3blkg5v7lill"; - system = "clj-arrows-test"; - asd = "clj-arrows-test"; - }); - systems = [ "clj-arrows-test" ]; - lispLibs = [ (getAttr "clj-arrows" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clj-con = (build-asdf-system { - pname = "clj-con"; - version = "20241012-git"; - asds = [ "clj-con" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clj-con/2024-10-12/clj-con-20241012-git.tgz"; - sha256 = "05zjw4ncwwpmckxqv61zhv1lcyfm7w4ic59ypcw5bypxwgkapa7c"; - system = "clj-con"; - asd = "clj-con"; - }); - systems = [ "clj-con" ]; - lispLibs = [ (getAttr "atomics" self) (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clj-con-test = (build-asdf-system { - pname = "clj-con-test"; - version = "20241012-git"; - asds = [ "clj-con-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clj-con/2024-10-12/clj-con-20241012-git.tgz"; - sha256 = "05zjw4ncwwpmckxqv61zhv1lcyfm7w4ic59ypcw5bypxwgkapa7c"; - system = "clj-con-test"; - asd = "clj-con-test"; - }); - systems = [ "clj-con-test" ]; - lispLibs = [ (getAttr "clj-con" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clj-re = (build-asdf-system { - pname = "clj-re"; - version = "20241012-git"; - asds = [ "clj-re" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clj-re/2024-10-12/clj-re-20241012-git.tgz"; - sha256 = "05d0xqnhd50hmvicaq3a08m52c12j7cmxz99mpmk10mp0cv572bl"; - system = "clj-re"; - asd = "clj-re"; - }); - systems = [ "clj-re" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clj-re-test = (build-asdf-system { - pname = "clj-re-test"; - version = "20241012-git"; - asds = [ "clj-re-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clj-re/2024-10-12/clj-re-20241012-git.tgz"; - sha256 = "05d0xqnhd50hmvicaq3a08m52c12j7cmxz99mpmk10mp0cv572bl"; - system = "clj-re-test"; - asd = "clj-re-test"; - }); - systems = [ "clj-re-test" ]; - lispLibs = [ (getAttr "clj-re" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml = (build-asdf-system { - pname = "clml"; - version = "20220220-git"; - asds = [ "clml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml"; - asd = "clml"; - }); - systems = [ "clml" ]; - lispLibs = [ (getAttr "clml_dot_association-rule" self) (getAttr "clml_dot_blas" self) (getAttr "clml_dot_classifiers" self) (getAttr "clml_dot_clustering" self) (getAttr "clml_dot_data" self) (getAttr "clml_dot_decision-tree" self) (getAttr "clml_dot_graph" self) (getAttr "clml_dot_hjs" self) (getAttr "clml_dot_lapack" self) (getAttr "clml_dot_nearest-search" self) (getAttr "clml_dot_nonparametric" self) (getAttr "clml_dot_numeric" self) (getAttr "clml_dot_pca" self) (getAttr "clml_dot_som" self) (getAttr "clml_dot_statistics" self) (getAttr "clml_dot_svm" self) (getAttr "clml_dot_text" self) (getAttr "clml_dot_time-series" self) (getAttr "clml_dot_utility" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_association-rule = (build-asdf-system { - pname = "clml.association-rule"; - version = "20220220-git"; - asds = [ "clml.association-rule" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.association-rule"; - asd = "clml.association-rule"; - }); - systems = [ "clml.association-rule" ]; - lispLibs = [ (getAttr "clml_dot_hjs" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_blas = (build-asdf-system { - pname = "clml.blas"; - version = "20220220-git"; - asds = [ "clml.blas" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.blas"; - asd = "clml.blas"; - }); - systems = [ "clml.blas" ]; - lispLibs = [ (getAttr "clml_dot_blas_dot_complex" self) (getAttr "clml_dot_blas_dot_hompack" self) (getAttr "clml_dot_blas_dot_real" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_blas_dot_complex = (build-asdf-system { - pname = "clml.blas.complex"; - version = "20220220-git"; - asds = [ "clml.blas.complex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.blas.complex"; - asd = "clml.blas"; - }); - systems = [ "clml.blas.complex" ]; - lispLibs = [ (getAttr "f2cl-lib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_blas_dot_hompack = (build-asdf-system { - pname = "clml.blas.hompack"; - version = "20220220-git"; - asds = [ "clml.blas.hompack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.blas.hompack"; - asd = "clml.blas"; - }); - systems = [ "clml.blas.hompack" ]; - lispLibs = [ (getAttr "f2cl-lib" self) ]; - meta = { - broken = true; - hydraPlatforms = [ ]; - }; - }); - clml_dot_blas_dot_real = (build-asdf-system { - pname = "clml.blas.real"; - version = "20220220-git"; - asds = [ "clml.blas.real" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.blas.real"; - asd = "clml.blas"; - }); - systems = [ "clml.blas.real" ]; - lispLibs = [ (getAttr "f2cl-lib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_classifiers = (build-asdf-system { - pname = "clml.classifiers"; - version = "20220220-git"; - asds = [ "clml.classifiers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.classifiers"; - asd = "clml.classifiers"; - }); - systems = [ "clml.classifiers" ]; - lispLibs = [ (getAttr "clml_dot_clustering" self) (getAttr "clml_dot_hjs" self) (getAttr "clml_dot_svm" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_clustering = (build-asdf-system { - pname = "clml.clustering"; - version = "20220220-git"; - asds = [ "clml.clustering" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.clustering"; - asd = "clml.clustering"; - }); - systems = [ "clml.clustering" ]; - lispLibs = [ (getAttr "clml_dot_blas" self) (getAttr "clml_dot_hjs" self) (getAttr "clml_dot_nearest-search" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_data = (build-asdf-system { - pname = "clml.data"; - version = "20220220-git"; - asds = [ "clml.data" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.data"; - asd = "clml.data"; - }); - systems = [ "clml.data" ]; - lispLibs = [ (getAttr "clml_dot_data_dot_r-datasets" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_data_dot_r-datasets = (build-asdf-system { - pname = "clml.data.r-datasets"; - version = "20220220-git"; - asds = [ "clml.data.r-datasets" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.data.r-datasets"; - asd = "clml.data.r-datasets"; - }); - systems = [ "clml.data.r-datasets" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "clml_dot_hjs" self) (getAttr "clml_dot_utility" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_decision-tree = (build-asdf-system { - pname = "clml.decision-tree"; - version = "20220220-git"; - asds = [ "clml.decision-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.decision-tree"; - asd = "clml.decision-tree"; - }); - systems = [ "clml.decision-tree" ]; - lispLibs = [ (getAttr "clml_dot_hjs" self) (getAttr "lparallel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_docs = (build-asdf-system { - pname = "clml.docs"; - version = "20220220-git"; - asds = [ "clml.docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.docs"; - asd = "clml.docs"; - }); - systems = [ "clml.docs" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "clml" self) (getAttr "clod" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_graph = (build-asdf-system { - pname = "clml.graph"; - version = "20220220-git"; - asds = [ "clml.graph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.graph"; - asd = "clml.graph"; - }); - systems = [ "clml.graph" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "clml_dot_hjs" self) (getAttr "clml_dot_statistics" self) (getAttr "clml_dot_time-series" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_hjs = (build-asdf-system { - pname = "clml.hjs"; - version = "20220220-git"; - asds = [ "clml.hjs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.hjs"; - asd = "clml.hjs"; - }); - systems = [ "clml.hjs" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "clml_dot_blas" self) (getAttr "clml_dot_lapack" self) (getAttr "clml_dot_statistics" self) (getAttr "clml_dot_utility" self) (getAttr "future" self) (getAttr "introspect-environment" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_lapack = (build-asdf-system { - pname = "clml.lapack"; - version = "20220220-git"; - asds = [ "clml.lapack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.lapack"; - asd = "clml.lapack"; - }); - systems = [ "clml.lapack" ]; - lispLibs = [ (getAttr "clml_dot_blas" self) (getAttr "clml_dot_lapack-real" self) (getAttr "f2cl-lib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_lapack-real = (build-asdf-system { - pname = "clml.lapack-real"; - version = "20220220-git"; - asds = [ "clml.lapack-real" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.lapack-real"; - asd = "clml.lapack"; - }); - systems = [ "clml.lapack-real" ]; - lispLibs = [ (getAttr "clml_dot_blas" self) (getAttr "f2cl-lib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_nearest-search = (build-asdf-system { - pname = "clml.nearest-search"; - version = "20220220-git"; - asds = [ "clml.nearest-search" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.nearest-search"; - asd = "clml.nearest-search"; - }); - systems = [ "clml.nearest-search" ]; - lispLibs = [ (getAttr "clml_dot_hjs" self) (getAttr "clml_dot_nonparametric" self) (getAttr "clml_dot_pca" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_nonparametric = (build-asdf-system { - pname = "clml.nonparametric"; - version = "20220220-git"; - asds = [ "clml.nonparametric" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.nonparametric"; - asd = "clml.nonparametric"; - }); - systems = [ "clml.nonparametric" ]; - lispLibs = [ (getAttr "clml_dot_hjs" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_numeric = (build-asdf-system { - pname = "clml.numeric"; - version = "20220220-git"; - asds = [ "clml.numeric" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.numeric"; - asd = "clml.numeric"; - }); - systems = [ "clml.numeric" ]; - lispLibs = [ (getAttr "clml_dot_hjs" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_pca = (build-asdf-system { - pname = "clml.pca"; - version = "20220220-git"; - asds = [ "clml.pca" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.pca"; - asd = "clml.pca"; - }); - systems = [ "clml.pca" ]; - lispLibs = [ (getAttr "clml_dot_decision-tree" self) (getAttr "clml_dot_hjs" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_pca_dot_examples = (build-asdf-system { - pname = "clml.pca.examples"; - version = "20220220-git"; - asds = [ "clml.pca.examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.pca.examples"; - asd = "clml.pca"; - }); - systems = [ "clml.pca.examples" ]; - lispLibs = [ (getAttr "clml_dot_hjs" self) (getAttr "clml_dot_pca" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_som = (build-asdf-system { - pname = "clml.som"; - version = "20220220-git"; - asds = [ "clml.som" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.som"; - asd = "clml.som"; - }); - systems = [ "clml.som" ]; - lispLibs = [ (getAttr "clml_dot_hjs" self) (getAttr "clml_dot_statistics" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_som_dot_example = (build-asdf-system { - pname = "clml.som.example"; - version = "20220220-git"; - asds = [ "clml.som.example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.som.example"; - asd = "clml.som"; - }); - systems = [ "clml.som.example" ]; - lispLibs = [ (getAttr "clml_dot_hjs" self) (getAttr "clml_dot_som" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_statistics = (build-asdf-system { - pname = "clml.statistics"; - version = "20220220-git"; - asds = [ "clml.statistics" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.statistics"; - asd = "clml.statistics"; - }); - systems = [ "clml.statistics" ]; - lispLibs = [ (getAttr "clml_dot_statistics_dot_rand" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_statistics_dot_rand = (build-asdf-system { - pname = "clml.statistics.rand"; - version = "20220220-git"; - asds = [ "clml.statistics.rand" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.statistics.rand"; - asd = "clml.statistics.rand"; - }); - systems = [ "clml.statistics.rand" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_svm = (build-asdf-system { - pname = "clml.svm"; - version = "20220220-git"; - asds = [ "clml.svm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.svm"; - asd = "clml.svm"; - }); - systems = [ "clml.svm" ]; - lispLibs = [ (getAttr "clml_dot_decision-tree" self) (getAttr "clml_dot_hjs" self) (getAttr "future" self) (getAttr "lparallel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_svm_dot_examples = (build-asdf-system { - pname = "clml.svm.examples"; - version = "20220220-git"; - asds = [ "clml.svm.examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.svm.examples"; - asd = "clml.svm"; - }); - systems = [ "clml.svm.examples" ]; - lispLibs = [ (getAttr "clml_dot_hjs" self) (getAttr "clml_dot_svm" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_test = (build-asdf-system { - pname = "clml.test"; - version = "20220220-git"; - asds = [ "clml.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.test"; - asd = "clml.test"; - }); - systems = [ "clml.test" ]; - lispLibs = [ (getAttr "clml" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_text = (build-asdf-system { - pname = "clml.text"; - version = "20220220-git"; - asds = [ "clml.text" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.text"; - asd = "clml.text"; - }); - systems = [ "clml.text" ]; - lispLibs = [ (getAttr "clml_dot_hjs" self) (getAttr "clml_dot_nonparametric" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_time-series = (build-asdf-system { - pname = "clml.time-series"; - version = "20220220-git"; - asds = [ "clml.time-series" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.time-series"; - asd = "clml.time-series"; - }); - systems = [ "clml.time-series" ]; - lispLibs = [ (getAttr "array-operations" self) (getAttr "clml_dot_hjs" self) (getAttr "clml_dot_numeric" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clml_dot_utility = (build-asdf-system { - pname = "clml.utility"; - version = "20220220-git"; - asds = [ "clml.utility" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "clml.utility"; - asd = "clml.utility"; - }); - systems = [ "clml.utility" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "iterate" self) (getAttr "parse-number" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clnuplot = (build-asdf-system { - pname = "clnuplot"; - version = "20130128-darcs"; - asds = [ "clnuplot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clnuplot/2013-01-28/clnuplot-20130128-darcs.tgz"; - sha256 = "0yfaay5idv9lq4ilafj305sg349c960n3q400kdayr0gda6pqlqr"; - system = "clnuplot"; - asd = "clnuplot"; - }); - systems = [ "clnuplot" ]; - lispLibs = [ (getAttr "cl-containers" self) (getAttr "cl-mathstats" self) (getAttr "metabang-bind" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clobber = (build-asdf-system { - pname = "clobber"; - version = "20241012-git"; - asds = [ "clobber" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clobber/2024-10-12/clobber-20241012-git.tgz"; - sha256 = "1n6j9q0czrzigw7vfahlylm1g8hmk7b1wm84jm94cgl8r5r3s8ra"; - system = "clobber"; - asd = "clobber"; - }); - systems = [ "clobber" ]; - lispLibs = [ (getAttr "clobber-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clobber-base = (build-asdf-system { - pname = "clobber-base"; - version = "20241012-git"; - asds = [ "clobber-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clobber/2024-10-12/clobber-20241012-git.tgz"; - sha256 = "1n6j9q0czrzigw7vfahlylm1g8hmk7b1wm84jm94cgl8r5r3s8ra"; - system = "clobber-base"; - asd = "clobber-base"; - }); - systems = [ "clobber-base" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clobber-test = (build-asdf-system { - pname = "clobber-test"; - version = "20241012-git"; - asds = [ "clobber-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clobber/2024-10-12/clobber-20241012-git.tgz"; - sha256 = "1n6j9q0czrzigw7vfahlylm1g8hmk7b1wm84jm94cgl8r5r3s8ra"; - system = "clobber-test"; - asd = "clobber-test"; - }); - systems = [ "clobber-test" ]; - lispLibs = [ (getAttr "clobber" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clod = (build-asdf-system { - pname = "clod"; - version = "20190307-hg"; - asds = [ "clod" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clod/2019-03-07/clod-20190307-hg.tgz"; - sha256 = "0sdlr6jlqnbiyf06648zhq8dpni3zy0n5rwjcrvm4hw7vcy8vhy1"; - system = "clod"; - asd = "clod"; - }); - systems = [ "clod" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clods-export = (build-asdf-system { - pname = "clods-export"; - version = "20210411-git"; - asds = [ "clods-export" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clods-export/2021-04-11/clods-export-20210411-git.tgz"; - sha256 = "1bbzrl855qjs88ni548filghb2y8fvklkik22amwzi6dbzvq48qx"; - system = "clods-export"; - asd = "clods-export"; - }); - systems = [ "clods-export" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "cxml" self) (getAttr "iterate" self) (getAttr "local-time" self) (getAttr "zip" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clog = (build-asdf-system { - pname = "clog"; - version = "20241012-git"; - asds = [ "clog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clog/2024-10-12/clog-20241012-git.tgz"; - sha256 = "0hqpj9ji7kfqgcxdfnc7x202qzmb7zdkmjwcyhdllqs6b0ssw5lx"; - system = "clog"; - asd = "clog"; - }); - systems = [ "clog" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "atomics" self) (getAttr "bordeaux-threads" self) (getAttr "cl-dbi" self) (getAttr "cl-isaac" self) (getAttr "cl-pass" self) (getAttr "cl-ppcre" self) (getAttr "cl-template" self) (getAttr "clack" self) (getAttr "closer-mop" self) (getAttr "hunchentoot" self) (getAttr "lack-middleware-static" self) (getAttr "lack-request" self) (getAttr "lack-util-writer-stream" self) (getAttr "mgl-pax" self) (getAttr "parse-float" self) (getAttr "quri" self) (getAttr "sqlite" self) (getAttr "trivial-gray-streams" self) (getAttr "websocket-driver" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clog-ace = (build-asdf-system { - pname = "clog-ace"; - version = "20241012-git"; - asds = [ "clog-ace" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clog-ace/2024-10-12/clog-ace-20241012-git.tgz"; - sha256 = "01hwaiccy5i81w22kya00jscgpjw6iib2hnklqwky88i35kbb4sj"; - system = "clog-ace"; - asd = "clog-ace"; - }); - systems = [ "clog-ace" ]; - lispLibs = [ (getAttr "clog" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clog-collection = (build-asdf-system { - pname = "clog-collection"; - version = "20241012-git"; - asds = [ "clog-collection" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clog-collection/2024-10-12/clog-collection-20241012-git.tgz"; - sha256 = "0f6rw9sla5f7jglbisving0c97vz3a5bbn59li0jzngqp8rqwsqx"; - system = "clog-collection"; - asd = "clog-collection"; - }); - systems = [ "clog-collection" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "clog" self) (getAttr "iterate" self) (getAttr "literate-lisp" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clog-plotly = (build-asdf-system { - pname = "clog-plotly"; - version = "20241012-git"; - asds = [ "clog-plotly" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clog-plotly/2024-10-12/clog-plotly-20241012-git.tgz"; - sha256 = "064fhfhh5nr1g9f4pn9x2ydmxdnxmvyxhwgbl3dgqm416scjzzs1"; - system = "clog-plotly"; - asd = "clog-plotly"; - }); - systems = [ "clog-plotly" ]; - lispLibs = [ (getAttr "clog" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clog-terminal = (build-asdf-system { - pname = "clog-terminal"; - version = "20241012-git"; - asds = [ "clog-terminal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clog-terminal/2024-10-12/clog-terminal-20241012-git.tgz"; - sha256 = "1pvrja8fvdzqmiqzl23lb7665vcpx9lhwxahns81wlykkyx7cjd5"; - system = "clog-terminal"; - asd = "clog-terminal"; - }); - systems = [ "clog-terminal" ]; - lispLibs = [ (getAttr "clog" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clohost = (build-asdf-system { - pname = "clohost"; - version = "20241012-git"; - asds = [ "clohost" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clohost/2024-10-12/clohost-20241012-git.tgz"; - sha256 = "1qph7nrjb62qxwkv5wbzqkycdavsjvi39b97qvs5g8jsrvbl50lh"; - system = "clohost"; - asd = "clohost"; - }); - systems = [ "clohost" ]; - lispLibs = [ (getAttr "com_dot_inuoe_dot_jzon" self) (getAttr "crypto-shortcuts" self) (getAttr "documentation-utils" self) (getAttr "drakma" self) (getAttr "trivial-mimes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clonsigna = (build-asdf-system { - pname = "clonsigna"; - version = "20120909-git"; - asds = [ "clonsigna" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clonsigna/2012-09-09/clonsigna-20120909-git.tgz"; - sha256 = "052vdch0q07sx3j615qgw8z536fmqz8fm3qv7f298ql3wcskrj7j"; - system = "clonsigna"; - asd = "clonsigna"; - }); - systems = [ "clonsigna" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl_plus_ssl" self) (getAttr "cl-base64" self) (getAttr "cl-ppcre" self) (getAttr "iolib" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clop = (build-asdf-system { - pname = "clop"; - version = "v1.0.1"; - asds = [ "clop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clop/2022-02-20/clop-v1.0.1.tgz"; - sha256 = "1q7rlizr8gcbfz4a9660gdbw7d2zbld18akjpibg54j7jh5kb8gc"; - system = "clop"; - asd = "clop"; - }); - systems = [ "clop" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "esrap" self) (getAttr "local-time" self) (getAttr "parse-number" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clop-tests = (build-asdf-system { - pname = "clop-tests"; - version = "v1.0.1"; - asds = [ "clop-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clop/2022-02-20/clop-v1.0.1.tgz"; - sha256 = "1q7rlizr8gcbfz4a9660gdbw7d2zbld18akjpibg54j7jh5kb8gc"; - system = "clop-tests"; - asd = "clop"; - }); - systems = [ "clop-tests" ]; - lispLibs = [ (getAttr "clop" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clos-diff = (build-asdf-system { - pname = "clos-diff"; - version = "20150608-git"; - asds = [ "clos-diff" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clos-diff/2015-06-08/clos-diff-20150608-git.tgz"; - sha256 = "0y6chxzqwwwkrrmxxb74wwci6i4ck6i3fq36w9gl03qbrksfyjkz"; - system = "clos-diff"; - asd = "clos-diff"; - }); - systems = [ "clos-diff" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clos-encounters = (build-asdf-system { - pname = "clos-encounters"; - version = "20241012-git"; - asds = [ "clos-encounters" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clos-encounters/2024-10-12/clos-encounters-20241012-git.tgz"; - sha256 = "021ygh6s5qb7l155bcp9qv1w2dhq9csscasp77vjlms1ahpq9ixf"; - system = "clos-encounters"; - asd = "clos-encounters"; - }); - systems = [ "clos-encounters" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clos-fixtures = (build-asdf-system { - pname = "clos-fixtures"; - version = "20160825-git"; - asds = [ "clos-fixtures" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clos-fixtures/2016-08-25/clos-fixtures-20160825-git.tgz"; - sha256 = "1a3yvqszdwnsnk5hr4zrdpaqxb8vlxpl2nhxjl0j97fnmfaiqjhk"; - system = "clos-fixtures"; - asd = "clos-fixtures"; - }); - systems = [ "clos-fixtures" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clos-fixtures-test = (build-asdf-system { - pname = "clos-fixtures-test"; - version = "20160825-git"; - asds = [ "clos-fixtures-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clos-fixtures/2016-08-25/clos-fixtures-20160825-git.tgz"; - sha256 = "1a3yvqszdwnsnk5hr4zrdpaqxb8vlxpl2nhxjl0j97fnmfaiqjhk"; - system = "clos-fixtures-test"; - asd = "clos-fixtures-test"; - }); - systems = [ "clos-fixtures-test" ]; - lispLibs = [ (getAttr "clos-fixtures" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - closer-mop = (build-asdf-system { - pname = "closer-mop"; - version = "20241012-git"; - asds = [ "closer-mop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/closer-mop/2024-10-12/closer-mop-20241012-git.tgz"; - sha256 = "1affaqh0sm1phs6qa12vbhf69abssjcpy55cwf4fi4nd6hgcrfqr"; - system = "closer-mop"; - asd = "closer-mop"; - }); - systems = [ "closer-mop" ]; - lispLibs = [ ]; - meta = {}; - }); - closure-common = (build-asdf-system { - pname = "closure-common"; - version = "20181018-git"; - asds = [ "closure-common" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/closure-common/2018-10-18/closure-common-20181018-git.tgz"; - sha256 = "0k5r2qxn122pxi301ijir3nayi9sg4d7yiy276l36qmzwhp4mg5n"; - system = "closure-common"; - asd = "closure-common"; - }); - systems = [ "closure-common" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - closure-html = (build-asdf-system { - pname = "closure-html"; - version = "20180711-git"; - asds = [ "closure-html" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/closure-html/2018-07-11/closure-html-20180711-git.tgz"; - sha256 = "105vm29qnxh6zj3rh4jwpm8dyp3b9bsva64c8a78cr270p28d032"; - system = "closure-html"; - asd = "closure-html"; - }); - systems = [ "closure-html" ]; - lispLibs = [ (getAttr "closure-common" self) (getAttr "flexi-streams" self) ]; - meta = {}; - }); - closure-template = (build-asdf-system { - pname = "closure-template"; - version = "20150804-git"; - asds = [ "closure-template" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-closure-template/2015-08-04/cl-closure-template-20150804-git.tgz"; - sha256 = "16h0fs6bjjd4n9pbkwcprpgyj26vsw2akk3q08m7xmsmqi05dppv"; - system = "closure-template"; - asd = "closure-template"; - }); - systems = [ "closure-template" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "closer-mop" self) (getAttr "esrap" self) (getAttr "iterate" self) (getAttr "parse-number" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - closure-template-test = (build-asdf-system { - pname = "closure-template-test"; - version = "20150804-git"; - asds = [ "closure-template-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-closure-template/2015-08-04/cl-closure-template-20150804-git.tgz"; - sha256 = "16h0fs6bjjd4n9pbkwcprpgyj26vsw2akk3q08m7xmsmqi05dppv"; - system = "closure-template-test"; - asd = "closure-template"; - }); - systems = [ "closure-template-test" ]; - lispLibs = [ (getAttr "closure-template" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clouchdb = (build-asdf-system { - pname = "clouchdb"; - version = "0.0.16"; - asds = [ "clouchdb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clouchdb/2012-04-07/clouchdb_0.0.16.tgz"; - sha256 = "1zfk4wkz0k5gbfznnbds0gcpc2y08p47rq7mhchf27v6rqg4kd7d"; - system = "clouchdb"; - asd = "clouchdb"; - }); - systems = [ "clouchdb" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "drakma" self) (getAttr "flexi-streams" self) (getAttr "parenscript" self) (getAttr "s-base64" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clouchdb-examples = (build-asdf-system { - pname = "clouchdb-examples"; - version = "0.0.16"; - asds = [ "clouchdb-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clouchdb/2012-04-07/clouchdb_0.0.16.tgz"; - sha256 = "1zfk4wkz0k5gbfznnbds0gcpc2y08p47rq7mhchf27v6rqg4kd7d"; - system = "clouchdb-examples"; - asd = "clouchdb-examples"; - }); - systems = [ "clouchdb-examples" ]; - lispLibs = [ (getAttr "clouchdb" self) (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clouseau = (build-asdf-system { - pname = "clouseau"; - version = "20241012-git"; - asds = [ "clouseau" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "clouseau"; - asd = "clouseau"; - }); - systems = [ "clouseau" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "mcclim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clpython = (build-asdf-system { - pname = "clpython"; - version = "20220331-git"; - asds = [ "clpython" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-python/2022-03-31/cl-python-20220331-git.tgz"; - sha256 = "1liskpyfd8rbqn45xbymwvh4vic05pyvvf3hnq2ybyixwnkan9i9"; - system = "clpython"; - asd = "clpython"; - }); - systems = [ "clpython" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "closer-mop" self) (getAttr "yacc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql = (build-asdf-system { - pname = "clsql"; - version = "20221106-git"; - asds = [ "clsql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; - sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; - system = "clsql"; - asd = "clsql"; - }); - systems = [ "clsql" ]; - lispLibs = [ (getAttr "uffi" self) ]; - meta = {}; - }); - clsql-aodbc = (build-asdf-system { - pname = "clsql-aodbc"; - version = "20221106-git"; - asds = [ "clsql-aodbc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; - sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; - system = "clsql-aodbc"; - asd = "clsql-aodbc"; - }); - systems = [ "clsql-aodbc" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-cffi = (build-asdf-system { - pname = "clsql-cffi"; - version = "20221106-git"; - asds = [ "clsql-cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; - sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; - system = "clsql-cffi"; - asd = "clsql-cffi"; - }); - systems = [ "clsql-cffi" ]; - lispLibs = [ (getAttr "clsql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-fluid = (build-asdf-system { - pname = "clsql-fluid"; - version = "20170830-git"; - asds = [ "clsql-fluid" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql-fluid/2017-08-30/clsql-fluid-20170830-git.tgz"; - sha256 = "0i7x1xbh83wfr3k4ddsdy57yf0nqfhdxcbwv1na1ina6m5javg11"; - system = "clsql-fluid"; - asd = "clsql-fluid"; - }); - systems = [ "clsql-fluid" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "clsql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-helper = (build-asdf-system { - pname = "clsql-helper"; - version = "20180131-git"; - asds = [ "clsql-helper" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql-helper/2018-01-31/clsql-helper-20180131-git.tgz"; - sha256 = "0yc6m8yh0gcark98wvjjwdq3xxy308x15pb7fzha6svxa06hf27g"; - system = "clsql-helper"; - asd = "clsql-helper"; - }); - systems = [ "clsql-helper" ]; - lispLibs = [ (getAttr "access" self) (getAttr "alexandria" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "clsql" self) (getAttr "collectors" self) (getAttr "iterate" self) (getAttr "md5" self) (getAttr "symbol-munger" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-helper-slot-coercer = (build-asdf-system { - pname = "clsql-helper-slot-coercer"; - version = "20180131-git"; - asds = [ "clsql-helper-slot-coercer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql-helper/2018-01-31/clsql-helper-20180131-git.tgz"; - sha256 = "0yc6m8yh0gcark98wvjjwdq3xxy308x15pb7fzha6svxa06hf27g"; - system = "clsql-helper-slot-coercer"; - asd = "clsql-helper-slot-coercer"; - }); - systems = [ "clsql-helper-slot-coercer" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "clsql-helper" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-helper-slot-coercer-test = (build-asdf-system { - pname = "clsql-helper-slot-coercer-test"; - version = "20180131-git"; - asds = [ "clsql-helper-slot-coercer-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql-helper/2018-01-31/clsql-helper-20180131-git.tgz"; - sha256 = "0yc6m8yh0gcark98wvjjwdq3xxy308x15pb7fzha6svxa06hf27g"; - system = "clsql-helper-slot-coercer-test"; - asd = "clsql-helper-slot-coercer"; - }); - systems = [ "clsql-helper-slot-coercer-test" ]; - lispLibs = [ (getAttr "clsql-helper-slot-coercer" self) (getAttr "lisp-unit2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-helper-test = (build-asdf-system { - pname = "clsql-helper-test"; - version = "20180131-git"; - asds = [ "clsql-helper-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql-helper/2018-01-31/clsql-helper-20180131-git.tgz"; - sha256 = "0yc6m8yh0gcark98wvjjwdq3xxy308x15pb7fzha6svxa06hf27g"; - system = "clsql-helper-test"; - asd = "clsql-helper"; - }); - systems = [ "clsql-helper-test" ]; - lispLibs = [ (getAttr "clsql-helper" self) (getAttr "clsql-tests" self) (getAttr "lisp-unit2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-local-time = (build-asdf-system { - pname = "clsql-local-time"; - version = "20201016-git"; - asds = [ "clsql-local-time" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql-local-time/2020-10-16/clsql-local-time-20201016-git.tgz"; - sha256 = "1ipv6ij1md5mw44cbif31hiccrric3302rhssj8f7kg3s8n6mphv"; - system = "clsql-local-time"; - asd = "clsql-local-time"; - }); - systems = [ "clsql-local-time" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-mysql = (build-asdf-system { - pname = "clsql-mysql"; - version = "20221106-git"; - asds = [ "clsql-mysql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; - sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; - system = "clsql-mysql"; - asd = "clsql-mysql"; - }); - systems = [ "clsql-mysql" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "clsql-uffi" self) (getAttr "uffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-odbc = (build-asdf-system { - pname = "clsql-odbc"; - version = "20221106-git"; - asds = [ "clsql-odbc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; - sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; - system = "clsql-odbc"; - asd = "clsql-odbc"; - }); - systems = [ "clsql-odbc" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "clsql-uffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-orm = (build-asdf-system { - pname = "clsql-orm"; - version = "20160208-git"; - asds = [ "clsql-orm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql-orm/2016-02-08/clsql-orm-20160208-git.tgz"; - sha256 = "1y9604k0mj8h03p85l5nrjkihr3yfj5fp910db9f4ksd1ln2qkka"; - system = "clsql-orm"; - asd = "clsql-orm"; - }); - systems = [ "clsql-orm" ]; - lispLibs = [ (getAttr "cl-inflector" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "clsql" self) (getAttr "iterate" self) (getAttr "symbol-munger" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-postgresql = (build-asdf-system { - pname = "clsql-postgresql"; - version = "20221106-git"; - asds = [ "clsql-postgresql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; - sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; - system = "clsql-postgresql"; - asd = "clsql-postgresql"; - }); - systems = [ "clsql-postgresql" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "clsql-uffi" self) ]; - meta = {}; - }); - clsql-postgresql-socket = (build-asdf-system { - pname = "clsql-postgresql-socket"; - version = "20221106-git"; - asds = [ "clsql-postgresql-socket" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; - sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; - system = "clsql-postgresql-socket"; - asd = "clsql-postgresql-socket"; - }); - systems = [ "clsql-postgresql-socket" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "md5" self) (getAttr "uffi" self) ]; - meta = {}; - }); - clsql-postgresql-socket3 = (build-asdf-system { - pname = "clsql-postgresql-socket3"; - version = "20221106-git"; - asds = [ "clsql-postgresql-socket3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; - sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; - system = "clsql-postgresql-socket3"; - asd = "clsql-postgresql-socket3"; - }); - systems = [ "clsql-postgresql-socket3" ]; - lispLibs = [ (getAttr "cl-postgres" self) (getAttr "clsql" self) (getAttr "md5" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-sqlite = (build-asdf-system { - pname = "clsql-sqlite"; - version = "20221106-git"; - asds = [ "clsql-sqlite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; - sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; - system = "clsql-sqlite"; - asd = "clsql-sqlite"; - }); - systems = [ "clsql-sqlite" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "clsql-uffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-sqlite3 = (build-asdf-system { - pname = "clsql-sqlite3"; - version = "20221106-git"; - asds = [ "clsql-sqlite3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; - sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; - system = "clsql-sqlite3"; - asd = "clsql-sqlite3"; - }); - systems = [ "clsql-sqlite3" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "clsql-uffi" self) ]; - meta = {}; - }); - clsql-tests = (build-asdf-system { - pname = "clsql-tests"; - version = "20221106-git"; - asds = [ "clsql-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; - sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; - system = "clsql-tests"; - asd = "clsql-tests"; - }); - systems = [ "clsql-tests" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "rt" self) (getAttr "uffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clsql-uffi = (build-asdf-system { - pname = "clsql-uffi"; - version = "20221106-git"; - asds = [ "clsql-uffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; - sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; - system = "clsql-uffi"; - asd = "clsql-uffi"; - }); - systems = [ "clsql-uffi" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "uffi" self) ]; - meta = {}; - }); - clss = (build-asdf-system { - pname = "clss"; - version = "20241012-git"; - asds = [ "clss" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clss/2024-10-12/clss-20241012-git.tgz"; - sha256 = "1l2yq6wi8wmb7l8fy6w4xb3mb2yd9d14ijgqdsbnwb5k2hbmndbf"; - system = "clss"; - asd = "clss"; - }); - systems = [ "clss" ]; - lispLibs = [ (getAttr "array-utils" self) (getAttr "plump" self) ]; - meta = {}; - }); - cltcl = (build-asdf-system { - pname = "cltcl"; - version = "20161204-git"; - asds = [ "cltcl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cltcl/2016-12-04/cltcl-20161204-git.tgz"; - sha256 = "18b7fa7m9h9xfhnkxa6r3xzj86p1fvq0mh5q8vdrdv3vxfyc2l68"; - system = "cltcl"; - asd = "cltcl"; - }); - systems = [ "cltcl" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cluffer = (build-asdf-system { - pname = "cluffer"; - version = "20241012-git"; - asds = [ "cluffer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; - sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; - system = "cluffer"; - asd = "cluffer"; - }); - systems = [ "cluffer" ]; - lispLibs = [ (getAttr "cluffer-base" self) (getAttr "cluffer-simple-buffer" self) (getAttr "cluffer-simple-line" self) (getAttr "cluffer-standard-buffer" self) (getAttr "cluffer-standard-line" self) ]; - meta = {}; - }); - cluffer-base = (build-asdf-system { - pname = "cluffer-base"; - version = "20241012-git"; - asds = [ "cluffer-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; - sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; - system = "cluffer-base"; - asd = "cluffer-base"; - }); - systems = [ "cluffer-base" ]; - lispLibs = [ (getAttr "acclimation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cluffer-simple-buffer = (build-asdf-system { - pname = "cluffer-simple-buffer"; - version = "20241012-git"; - asds = [ "cluffer-simple-buffer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; - sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; - system = "cluffer-simple-buffer"; - asd = "cluffer-simple-buffer"; - }); - systems = [ "cluffer-simple-buffer" ]; - lispLibs = [ (getAttr "cluffer-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cluffer-simple-line = (build-asdf-system { - pname = "cluffer-simple-line"; - version = "20241012-git"; - asds = [ "cluffer-simple-line" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; - sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; - system = "cluffer-simple-line"; - asd = "cluffer-simple-line"; - }); - systems = [ "cluffer-simple-line" ]; - lispLibs = [ (getAttr "cluffer-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cluffer-standard-buffer = (build-asdf-system { - pname = "cluffer-standard-buffer"; - version = "20241012-git"; - asds = [ "cluffer-standard-buffer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; - sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; - system = "cluffer-standard-buffer"; - asd = "cluffer-standard-buffer"; - }); - systems = [ "cluffer-standard-buffer" ]; - lispLibs = [ (getAttr "cluffer-base" self) (getAttr "clump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cluffer-standard-line = (build-asdf-system { - pname = "cluffer-standard-line"; - version = "20241012-git"; - asds = [ "cluffer-standard-line" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; - sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; - system = "cluffer-standard-line"; - asd = "cluffer-standard-line"; - }); - systems = [ "cluffer-standard-line" ]; - lispLibs = [ (getAttr "cluffer-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cluffer-test = (build-asdf-system { - pname = "cluffer-test"; - version = "20241012-git"; - asds = [ "cluffer-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; - sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; - system = "cluffer-test"; - asd = "cluffer-test"; - }); - systems = [ "cluffer-test" ]; - lispLibs = [ (getAttr "cluffer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clump = (build-asdf-system { - pname = "clump"; - version = "20160825-git"; - asds = [ "clump" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clump/2016-08-25/clump-20160825-git.tgz"; - sha256 = "1639msyagsswj85gc0wd90jgh8588j3qg5q70by9s2brf2q6w4lh"; - system = "clump"; - asd = "clump"; - }); - systems = [ "clump" ]; - lispLibs = [ (getAttr "clump-2-3-tree" self) (getAttr "clump-binary-tree" self) ]; - meta = {}; - }); - clump-2-3-tree = (build-asdf-system { - pname = "clump-2-3-tree"; - version = "20160825-git"; - asds = [ "clump-2-3-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clump/2016-08-25/clump-20160825-git.tgz"; - sha256 = "1639msyagsswj85gc0wd90jgh8588j3qg5q70by9s2brf2q6w4lh"; - system = "clump-2-3-tree"; - asd = "clump-2-3-tree"; - }); - systems = [ "clump-2-3-tree" ]; - lispLibs = [ (getAttr "acclimation" self) ]; - meta = {}; - }); - clump-binary-tree = (build-asdf-system { - pname = "clump-binary-tree"; - version = "20160825-git"; - asds = [ "clump-binary-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clump/2016-08-25/clump-20160825-git.tgz"; - sha256 = "1639msyagsswj85gc0wd90jgh8588j3qg5q70by9s2brf2q6w4lh"; - system = "clump-binary-tree"; - asd = "clump-binary-tree"; - }); - systems = [ "clump-binary-tree" ]; - lispLibs = [ (getAttr "acclimation" self) ]; - meta = {}; - }); - clump-test = (build-asdf-system { - pname = "clump-test"; - version = "20160825-git"; - asds = [ "clump-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clump/2016-08-25/clump-20160825-git.tgz"; - sha256 = "1639msyagsswj85gc0wd90jgh8588j3qg5q70by9s2brf2q6w4lh"; - system = "clump-test"; - asd = "clump-test"; - }); - systems = [ "clump-test" ]; - lispLibs = [ (getAttr "clump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clunit = (build-asdf-system { - pname = "clunit"; - version = "20171019-git"; - asds = [ "clunit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clunit/2017-10-19/clunit-20171019-git.tgz"; - sha256 = "1idf2xnqzlhi8rbrqmzpmb3i1l6pbdzhhajkmhwbp6qjkmxa4h85"; - system = "clunit"; - asd = "clunit"; - }); - systems = [ "clunit" ]; - lispLibs = [ ]; - meta = {}; - }); - clunit2 = (build-asdf-system { - pname = "clunit2"; - version = "20241012-git"; - asds = [ "clunit2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clunit2/2024-10-12/clunit2-20241012-git.tgz"; - sha256 = "03k4wc2zz31wcqcxy8fhq095i8xzcaxrzgrlrn2va10lcjs4v51b"; - system = "clunit2"; - asd = "clunit2"; - }); - systems = [ "clunit2" ]; - lispLibs = [ ]; - meta = {}; - }); - clustered-intset = (build-asdf-system { - pname = "clustered-intset"; - version = "20220707-git"; - asds = [ "clustered-intset" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clustered-intset/2022-07-07/clustered-intset-20220707-git.tgz"; - sha256 = "035s2gn59l8389b0ypnb4qna7zplz9rxk05aw88qf8g4b7wyba1h"; - system = "clustered-intset"; - asd = "clustered-intset"; - }); - systems = [ "clustered-intset" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clustered-intset-test = (build-asdf-system { - pname = "clustered-intset-test"; - version = "20220707-git"; - asds = [ "clustered-intset-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clustered-intset/2022-07-07/clustered-intset-20220707-git.tgz"; - sha256 = "035s2gn59l8389b0ypnb4qna7zplz9rxk05aw88qf8g4b7wyba1h"; - system = "clustered-intset-test"; - asd = "clustered-intset-test"; - }); - systems = [ "clustered-intset-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "clustered-intset" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clusters = (build-asdf-system { - pname = "clusters"; - version = "20220331-git"; - asds = [ "clusters" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clusters/2022-03-31/clusters-20220331-git.tgz"; - sha256 = "1x78ihrrah0rrb2ddxmxqcqpkswdvb3f0via56bkf1f3f5kqmsb8"; - system = "clusters"; - asd = "clusters"; - }); - systems = [ "clusters" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-data-structures" self) (getAttr "documentation-utils-extensions" self) (getAttr "iterate" self) (getAttr "lparallel" self) (getAttr "metabang-bind" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clusters-tests = (build-asdf-system { - pname = "clusters-tests"; - version = "20220331-git"; - asds = [ "clusters-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clusters/2022-03-31/clusters-20220331-git.tgz"; - sha256 = "1x78ihrrah0rrb2ddxmxqcqpkswdvb3f0via56bkf1f3f5kqmsb8"; - system = "clusters-tests"; - asd = "clusters-tests"; - }); - systems = [ "clusters-tests" ]; - lispLibs = [ (getAttr "clusters" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clutter = (build-asdf-system { - pname = "clutter"; - version = "v1.0.0"; - asds = [ "clutter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clutter/2021-10-20/clutter-v1.0.0.tgz"; - sha256 = "1q9mg4d0nja9ypm13i24wymhjwziw6n7r7p1dzw6xc5zhavqsni7"; - system = "clutter"; - asd = "clutter"; - }); - systems = [ "clutter" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "doplus" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clweb = (build-asdf-system { - pname = "clweb"; - version = "20201220-git"; - asds = [ "clweb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clweb/2020-12-20/clweb-20201220-git.tgz"; - sha256 = "0hqyrglgsgal5s8f0n247hg0hqlw6l6w1r5i8lzf0a0xvcz49f48"; - system = "clweb"; - asd = "clweb"; - }); - systems = [ "clweb" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clws = (build-asdf-system { - pname = "clws"; - version = "20130813-git"; - asds = [ "clws" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clws/2013-08-13/clws-20130813-git.tgz"; - sha256 = "1svj025zwsbkb0hrbz1nj0x306hkhy9xinq0x1qdflc9vg169dh6"; - system = "clws"; - asd = "clws"; - }); - systems = [ "clws" ]; - lispLibs = [ (getAttr "chunga" self) (getAttr "cl-base64" self) (getAttr "flexi-streams" self) (getAttr "iolib" self) (getAttr "ironclad" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - clx = (build-asdf-system { - pname = "clx"; - version = "20241012-git"; - asds = [ "clx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clx/2024-10-12/clx-20241012-git.tgz"; - sha256 = "16l0badm7dxwi7x5ynk1scrbrilnxi1nzz79h1v15xi6b41pf65w"; - system = "clx"; - asd = "clx"; - }); - systems = [ "clx" ]; - lispLibs = [ ]; - meta = {}; - }); - cmake-parser = (build-asdf-system { - pname = "cmake-parser"; - version = "20180831-git"; - asds = [ "cmake-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cmake-parser/2018-08-31/cmake-parser-20180831-git.tgz"; - sha256 = "1sb5pwxhg7k41202kvxj1b60c5pxnl0mfbqdz53xayddngn2brgl"; - system = "cmake-parser"; - asd = "cmake-parser"; - }); - systems = [ "cmake-parser" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "esrap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cmark = (build-asdf-system { - pname = "cmark"; - version = "20241012-git"; - asds = [ "cmark" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cmark/2024-10-12/cl-cmark-20241012-git.tgz"; - sha256 = "1l4i530161ppfz0wn1da7g7dwf644ppp1afrq2p7qfkajm7dcfg5"; - system = "cmark"; - asd = "cmark"; - }); - systems = [ "cmark" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "flexi-streams" self) (getAttr "libcmark" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cmd = (build-asdf-system { - pname = "cmd"; - version = "20241012-git"; - asds = [ "cmd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cmd/2024-10-12/cmd-20241012-git.tgz"; - sha256 = "0rs2priccm34yx8cj29214i4bwa908gqs1ss23gyjb7v5qcq1sj7"; - system = "cmd"; - asd = "cmd"; - }); - systems = [ "cmd" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "serapeum" self) (getAttr "shlex" self) (getAttr "trivia" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cmu-infix = (build-asdf-system { - pname = "cmu-infix"; - version = "20180228-git"; - asds = [ "cmu-infix" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cmu-infix/2018-02-28/cmu-infix-20180228-git.tgz"; - sha256 = "0macs398088cfif1dkjrpmidk515sjl7ld96f9ys5cpzx8sc5gib"; - system = "cmu-infix"; - asd = "cmu-infix"; - }); - systems = [ "cmu-infix" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cmu-infix-tests = (build-asdf-system { - pname = "cmu-infix-tests"; - version = "20180228-git"; - asds = [ "cmu-infix-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cmu-infix/2018-02-28/cmu-infix-20180228-git.tgz"; - sha256 = "0macs398088cfif1dkjrpmidk515sjl7ld96f9ys5cpzx8sc5gib"; - system = "cmu-infix-tests"; - asd = "cmu-infix-tests"; - }); - systems = [ "cmu-infix-tests" ]; - lispLibs = [ (getAttr "cmu-infix" self) (getAttr "fiasco" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - coalton = (build-asdf-system { - pname = "coalton"; - version = "20241012-git"; - asds = [ "coalton" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; - sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; - system = "coalton"; - asd = "coalton"; - }); - systems = [ "coalton" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "coalton-asdf" self) (getAttr "coalton-compiler" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - coalton-asdf = (build-asdf-system { - pname = "coalton-asdf"; - version = "20241012-git"; - asds = [ "coalton-asdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; - sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; - system = "coalton-asdf"; - asd = "coalton-asdf"; - }); - systems = [ "coalton-asdf" ]; - lispLibs = [ (getAttr "coalton-compiler" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - coalton-compiler = (build-asdf-system { - pname = "coalton-compiler"; - version = "20241012-git"; - asds = [ "coalton-compiler" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; - sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; - system = "coalton-compiler"; - asd = "coalton-compiler"; - }); - systems = [ "coalton-compiler" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "concrete-syntax-tree" self) (getAttr "eclector" self) (getAttr "eclector-concrete-syntax-tree" self) (getAttr "float-features" self) (getAttr "fset" self) (getAttr "named-readtables" self) (getAttr "source-error" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - coalton-testing-example-project = (build-asdf-system { - pname = "coalton-testing-example-project"; - version = "20241012-git"; - asds = [ "coalton-testing-example-project" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; - sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; - system = "coalton-testing-example-project"; - asd = "coalton-testing-example-project"; - }); - systems = [ "coalton-testing-example-project" ]; - lispLibs = [ (getAttr "coalton" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cocoahelper = (build-asdf-system { - pname = "cocoahelper"; - version = "20210807-git"; - asds = [ "cocoahelper" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "cocoahelper"; - asd = "cocoahelper"; - }); - systems = [ "cocoahelper" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl-binaries" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cocoas = (build-asdf-system { - pname = "cocoas"; - version = "20241012-git"; - asds = [ "cocoas" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cocoas/2024-10-12/cocoas-20241012-git.tgz"; - sha256 = "0a3jpni8hnzd6103qj3nywy61c3jq6j9yzmg35wy4b8j94pgyvj5"; - system = "cocoas"; - asd = "cocoas"; - }); - systems = [ "cocoas" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "float-features" self) (getAttr "trivial-main-thread" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - codata-recommended-values = (build-asdf-system { - pname = "codata-recommended-values"; - version = "20241012-git"; - asds = [ "codata-recommended-values" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/codata-recommended-values/2024-10-12/codata-recommended-values-20241012-git.tgz"; - sha256 = "0mks9hzw5wkdjkqkcfbafm9rvbfgkn2na4bajfrhs4mn7bg4bv74"; - system = "codata-recommended-values"; - asd = "codata-recommended-values"; - }); - systems = [ "codata-recommended-values" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - codex = (build-asdf-system { - pname = "codex"; - version = "20241012-git"; - asds = [ "codex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/codex/2024-10-12/codex-20241012-git.tgz"; - sha256 = "06d1qscqnkd24fhpvsm0206a4cj3wsxma7amazhvzqy1y4girgc3"; - system = "codex"; - asd = "codex"; - }); - systems = [ "codex" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "cl-slug" self) (getAttr "codex-templates" self) (getAttr "common-doc" self) (getAttr "common-doc-contrib" self) (getAttr "docparser" self) (getAttr "pandocl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - codex-templates = (build-asdf-system { - pname = "codex-templates"; - version = "20241012-git"; - asds = [ "codex-templates" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/codex/2024-10-12/codex-20241012-git.tgz"; - sha256 = "06d1qscqnkd24fhpvsm0206a4cj3wsxma7amazhvzqy1y4girgc3"; - system = "codex-templates"; - asd = "codex-templates"; - }); - systems = [ "codex-templates" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "common-html" self) (getAttr "djula" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - coleslaw = (build-asdf-system { - pname = "coleslaw"; - version = "20241012-git"; - asds = [ "coleslaw" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/coleslaw/2024-10-12/coleslaw-20241012-git.tgz"; - sha256 = "1p9hg5qnymxzx2bzcvkzjarwxw383misq0cmqgggpzyhignx80av"; - system = "coleslaw"; - asd = "coleslaw"; - }); - systems = [ "coleslaw" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "_3bmd-ext-code-blocks" self) (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "cl-unicode" self) (getAttr "closer-mop" self) (getAttr "closure-template" self) (getAttr "inferior-shell" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - coleslaw-cli = (build-asdf-system { - pname = "coleslaw-cli"; - version = "20241012-git"; - asds = [ "coleslaw-cli" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/coleslaw/2024-10-12/coleslaw-20241012-git.tgz"; - sha256 = "1p9hg5qnymxzx2bzcvkzjarwxw383misq0cmqgggpzyhignx80av"; - system = "coleslaw-cli"; - asd = "coleslaw-cli"; - }); - systems = [ "coleslaw-cli" ]; - lispLibs = [ (getAttr "clack" self) (getAttr "coleslaw" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - coleslaw-test = (build-asdf-system { - pname = "coleslaw-test"; - version = "20241012-git"; - asds = [ "coleslaw-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/coleslaw/2024-10-12/coleslaw-20241012-git.tgz"; - sha256 = "1p9hg5qnymxzx2bzcvkzjarwxw383misq0cmqgggpzyhignx80av"; - system = "coleslaw-test"; - asd = "coleslaw-test"; - }); - systems = [ "coleslaw-test" ]; - lispLibs = [ (getAttr "coleslaw" self) (getAttr "coleslaw-cli" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - collectors = (build-asdf-system { - pname = "collectors"; - version = "20241012-git"; - asds = [ "collectors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/collectors/2024-10-12/collectors-20241012-git.tgz"; - sha256 = "1kc9q05wyp8yjz5wqc73nar7l49vcnfhj4924li81v76hlb03665"; - system = "collectors"; - asd = "collectors"; - }); - systems = [ "collectors" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "symbol-munger" self) ]; - meta = {}; - }); - colliflower = (build-asdf-system { - pname = "colliflower"; - version = "20211020-git"; - asds = [ "colliflower" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/colliflower/2021-10-20/colliflower-20211020-git.tgz"; - sha256 = "1fzn9s7wm7wmffrdm21lpvry9jb320456cmmprn976a533lp704r"; - system = "colliflower"; - asd = "colliflower"; - }); - systems = [ "colliflower" ]; - lispLibs = [ (getAttr "asdf-package-system" self) (getAttr "garten" self) (getAttr "liter" self) (getAttr "silo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - colliflower-fset = (build-asdf-system { - pname = "colliflower-fset"; - version = "20211020-git"; - asds = [ "colliflower-fset" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/colliflower/2021-10-20/colliflower-20211020-git.tgz"; - sha256 = "1fzn9s7wm7wmffrdm21lpvry9jb320456cmmprn976a533lp704r"; - system = "colliflower-fset"; - asd = "colliflower-fset"; - }); - systems = [ "colliflower-fset" ]; - lispLibs = [ (getAttr "colliflower" self) (getAttr "fset" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - colliflower-test = (build-asdf-system { - pname = "colliflower-test"; - version = "20211020-git"; - asds = [ "colliflower-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/colliflower/2021-10-20/colliflower-20211020-git.tgz"; - sha256 = "1fzn9s7wm7wmffrdm21lpvry9jb320456cmmprn976a533lp704r"; - system = "colliflower-test"; - asd = "colliflower-test"; - }); - systems = [ "colliflower-test" ]; - lispLibs = [ (getAttr "colliflower" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - colnew = (build-asdf-system { - pname = "colnew"; - version = "20231021-git"; - asds = [ "colnew" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "colnew"; - asd = "colnew"; - }); - systems = [ "colnew" ]; - lispLibs = [ (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - colored = (build-asdf-system { - pname = "colored"; - version = "20241012-git"; - asds = [ "colored" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/colored/2024-10-12/colored-20241012-git.tgz"; - sha256 = "0msw83gs5m887n1ha54jhflqjxb2mc7yv1hifspv9g16fn6h355c"; - system = "colored"; - asd = "colored"; - }); - systems = [ "colored" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - colored-test = (build-asdf-system { - pname = "colored-test"; - version = "20241012-git"; - asds = [ "colored-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/colored/2024-10-12/colored-20241012-git.tgz"; - sha256 = "0msw83gs5m887n1ha54jhflqjxb2mc7yv1hifspv9g16fn6h355c"; - system = "colored-test"; - asd = "colored-test"; - }); - systems = [ "colored-test" ]; - lispLibs = [ (getAttr "colored" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - colorize = (build-asdf-system { - pname = "colorize"; - version = "20230214-git"; - asds = [ "colorize" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/colorize/2023-02-14/colorize-20230214-git.tgz"; - sha256 = "1gbg11ghs4iak3n4c66qn6yvrcsg71xcbnjjf8qks0y4c8573fyf"; - system = "colorize"; - asd = "colorize"; - }); - systems = [ "colorize" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "html-encode" self) (getAttr "split-sequence" self) ]; - meta = {}; - }); - com-on = (build-asdf-system { - pname = "com-on"; - version = "20241012-git"; - asds = [ "com-on" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/com-on/2024-10-12/com-on-20241012-git.tgz"; - sha256 = "1a3by2kx3iq0zl4304zhs89dfkp8xdjmdlnfmgywdg3wjdkxakci"; - system = "com-on"; - asd = "com-on"; - }); - systems = [ "com-on" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com-on-test = (build-asdf-system { - pname = "com-on-test"; - version = "20241012-git"; - asds = [ "com-on-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/com-on/2024-10-12/com-on-20241012-git.tgz"; - sha256 = "1a3by2kx3iq0zl4304zhs89dfkp8xdjmdlnfmgywdg3wjdkxakci"; - system = "com-on-test"; - asd = "com-on-test"; - }); - systems = [ "com-on-test" ]; - lispLibs = [ (getAttr "com-on" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_clearly-useful_dot_generic-collection-interface = (build-asdf-system { - pname = "com.clearly-useful.generic-collection-interface"; - version = "20190710-git"; - asds = [ "com.clearly-useful.generic-collection-interface" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/com.clearly-useful.generic-collection-interface/2019-07-10/com.clearly-useful.generic-collection-interface-20190710-git.tgz"; - sha256 = "1yfxwqgvrb1nwryymsl4s3h1lr8yskb9c76lxqy3mw5l0vwvl5zl"; - system = "com.clearly-useful.generic-collection-interface"; - asd = "com.clearly-useful.generic-collection-interface"; - }); - systems = [ "com.clearly-useful.generic-collection-interface" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "com_dot_clearly-useful_dot_protocols" self) (getAttr "lparallel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_clearly-useful_dot_generic-collection-interface_dot_test = (build-asdf-system { - pname = "com.clearly-useful.generic-collection-interface.test"; - version = "20190710-git"; - asds = [ "com.clearly-useful.generic-collection-interface.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/com.clearly-useful.generic-collection-interface/2019-07-10/com.clearly-useful.generic-collection-interface-20190710-git.tgz"; - sha256 = "1yfxwqgvrb1nwryymsl4s3h1lr8yskb9c76lxqy3mw5l0vwvl5zl"; - system = "com.clearly-useful.generic-collection-interface.test"; - asd = "com.clearly-useful.generic-collection-interface.test"; - }); - systems = [ "com.clearly-useful.generic-collection-interface.test" ]; - lispLibs = [ (getAttr "com_dot_clearly-useful_dot_generic-collection-interface" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_clearly-useful_dot_iterate_plus = (build-asdf-system { - pname = "com.clearly-useful.iterate+"; - version = "20121013-git"; - asds = [ "com.clearly-useful.iterate+" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/com.clearly-useful.iterate-plus/2012-10-13/com.clearly-useful.iterate-plus-20121013-git.tgz"; - sha256 = "0fpymg6p9zglkclfn035agcs5k83fakad7dj2612v5p1snzzcika"; - system = "com.clearly-useful.iterate+"; - asd = "com.clearly-useful.iterate+"; - }); - systems = [ "com.clearly-useful.iterate+" ]; - lispLibs = [ (getAttr "com_dot_clearly-useful_dot_generic-collection-interface" self) (getAttr "com_dot_clearly-useful_dot_iterator-protocol" self) (getAttr "com_dot_clearly-useful_dot_protocols" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_clearly-useful_dot_iterator-protocol = (build-asdf-system { - pname = "com.clearly-useful.iterator-protocol"; - version = "20130312-git"; - asds = [ "com.clearly-useful.iterator-protocol" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/com.clearly-useful.iterator-protocol/2013-03-12/com.clearly-useful.iterator-protocol-20130312-git.tgz"; - sha256 = "1wgksgpck6na1ygdnln5n1y8rj2kylg3lpbkyrhdka2cgsqiqs4a"; - system = "com.clearly-useful.iterator-protocol"; - asd = "com.clearly-useful.iterator-protocol"; - }); - systems = [ "com.clearly-useful.iterator-protocol" ]; - lispLibs = [ (getAttr "com_dot_clearly-useful_dot_generic-collection-interface" self) (getAttr "com_dot_clearly-useful_dot_protocols" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_clearly-useful_dot_protocols = (build-asdf-system { - pname = "com.clearly-useful.protocols"; - version = "20130312-git"; - asds = [ "com.clearly-useful.protocols" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/com.clearly-useful.protocols/2013-03-12/com.clearly-useful.protocols-20130312-git.tgz"; - sha256 = "0az9rs98chjj2fdmpapqkv4sgfs84n9s7vvngcl05hcbsldm0xvn"; - system = "com.clearly-useful.protocols"; - asd = "com.clearly-useful.protocols"; - }); - systems = [ "com.clearly-useful.protocols" ]; - lispLibs = [ (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_danielkeogh_dot_graph = (build-asdf-system { - pname = "com.danielkeogh.graph"; - version = "20241012-git"; - asds = [ "com.danielkeogh.graph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/com.danielkeogh.graph/2024-10-12/com.danielkeogh.graph-20241012-git.tgz"; - sha256 = "1hy9g49aqi1li0cdxzjmzgiskh00vlxbp1kjwiyk8a8kqzg69hj2"; - system = "com.danielkeogh.graph"; - asd = "com.danielkeogh.graph"; - }); - systems = [ "com.danielkeogh.graph" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-speedy-queue" self) (getAttr "trivial-indent" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_danielkeogh_dot_graph-tests = (build-asdf-system { - pname = "com.danielkeogh.graph-tests"; - version = "20241012-git"; - asds = [ "com.danielkeogh.graph-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/com.danielkeogh.graph/2024-10-12/com.danielkeogh.graph-20241012-git.tgz"; - sha256 = "1hy9g49aqi1li0cdxzjmzgiskh00vlxbp1kjwiyk8a8kqzg69hj2"; - system = "com.danielkeogh.graph-tests"; - asd = "com.danielkeogh.graph-tests"; - }); - systems = [ "com.danielkeogh.graph-tests" ]; - lispLibs = [ (getAttr "com_dot_danielkeogh_dot_graph" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_dvlsoft_dot_rcfiles = (build-asdf-system { - pname = "com.dvlsoft.rcfiles"; - version = "20111203-http"; - asds = [ "com.dvlsoft.rcfiles" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rcfiles/2011-12-03/cl-rcfiles-20111203-http.tgz"; - sha256 = "06ahp9jaim216k7vbya1kp8iy5yb1i7axwrsjx7gwhl2b2q63r0a"; - system = "com.dvlsoft.rcfiles"; - asd = "com.dvlsoft.rcfiles"; - }); - systems = [ "com.dvlsoft.rcfiles" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_elbeno_dot_curve = (build-asdf-system { - pname = "com.elbeno.curve"; - version = "20130128-git"; - asds = [ "com.elbeno.curve" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/curve/2013-01-28/curve-20130128-git.tgz"; - sha256 = "0223sxrdixjg0bmy76a9kiv7g4zjkqxs92x6kys5dnaywx7mjb6j"; - system = "com.elbeno.curve"; - asd = "com.elbeno.curve"; - }); - systems = [ "com.elbeno.curve" ]; - lispLibs = [ (getAttr "com_dot_elbeno_dot_vector" self) (getAttr "vecto" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_elbeno_dot_vector = (build-asdf-system { - pname = "com.elbeno.vector"; - version = "20130128-git"; - asds = [ "com.elbeno.vector" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vector/2013-01-28/vector-20130128-git.tgz"; - sha256 = "04czvqycn9j2hzbjmrp9fgqlgns5l7vbb73dgv3zqmiwzdb66qr5"; - system = "com.elbeno.vector"; - asd = "com.elbeno.vector"; - }); - systems = [ "com.elbeno.vector" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_gigamonkeys_dot_binary-data = (build-asdf-system { - pname = "com.gigamonkeys.binary-data"; - version = "20111203-git"; - asds = [ "com.gigamonkeys.binary-data" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-binary-data/2011-12-03/monkeylib-binary-data-20111203-git.tgz"; - sha256 = "072v417vmcnvmyh8ddq9vmwwrizm7zwz9dpzi14qy9nsw8q649zw"; - system = "com.gigamonkeys.binary-data"; - asd = "com.gigamonkeys.binary-data"; - }); - systems = [ "com.gigamonkeys.binary-data" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_gigamonkeys_dot_json = (build-asdf-system { - pname = "com.gigamonkeys.json"; - version = "20180228-git"; - asds = [ "com.gigamonkeys.json" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-json/2018-02-28/monkeylib-json-20180228-git.tgz"; - sha256 = "188717pmyhpgwg9ncc1fbqvbvw5fikbfhvchsy9gg4haxhdgpzsn"; - system = "com.gigamonkeys.json"; - asd = "com.gigamonkeys.json"; - }); - systems = [ "com.gigamonkeys.json" ]; - lispLibs = [ (getAttr "com_dot_gigamonkeys_dot_parser" self) (getAttr "com_dot_gigamonkeys_dot_utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_gigamonkeys_dot_macro-utilities = (build-asdf-system { - pname = "com.gigamonkeys.macro-utilities"; - version = "20111203-git"; - asds = [ "com.gigamonkeys.macro-utilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-macro-utilities/2011-12-03/monkeylib-macro-utilities-20111203-git.tgz"; - sha256 = "0l3m44zlzrvyn6fyvxslga8cppp4mh8dkgqzy297nnm0vnij5r8w"; - system = "com.gigamonkeys.macro-utilities"; - asd = "com.gigamonkeys.macro-utilities"; - }); - systems = [ "com.gigamonkeys.macro-utilities" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_gigamonkeys_dot_markup = (build-asdf-system { - pname = "com.gigamonkeys.markup"; - version = "20120909-git"; - asds = [ "com.gigamonkeys.markup" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-markup/2012-09-09/monkeylib-markup-20120909-git.tgz"; - sha256 = "049zqgnprvddn2zp1a8g862m3ikll3a3lpi1k2vimjmx1bkc0vs0"; - system = "com.gigamonkeys.markup"; - asd = "com.gigamonkeys.markup"; - }); - systems = [ "com.gigamonkeys.markup" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "com_dot_gigamonkeys_dot_pathnames" self) (getAttr "com_dot_gigamonkeys_dot_utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_gigamonkeys_dot_parser = (build-asdf-system { - pname = "com.gigamonkeys.parser"; - version = "20120208-git"; - asds = [ "com.gigamonkeys.parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-parser/2012-02-08/monkeylib-parser-20120208-git.tgz"; - sha256 = "1xvzrih813311p48bzlm0z0592lx6iss3m36vz55qsw4sr397ncd"; - system = "com.gigamonkeys.parser"; - asd = "com.gigamonkeys.parser"; - }); - systems = [ "com.gigamonkeys.parser" ]; - lispLibs = [ (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) (getAttr "com_dot_gigamonkeys_dot_utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_gigamonkeys_dot_pathnames = (build-asdf-system { - pname = "com.gigamonkeys.pathnames"; - version = "20120208-git"; - asds = [ "com.gigamonkeys.pathnames" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-pathnames/2012-02-08/monkeylib-pathnames-20120208-git.tgz"; - sha256 = "108cc39g7razng316df4d47zzpj2zr576wzwwrpggdkm4q599gvk"; - system = "com.gigamonkeys.pathnames"; - asd = "com.gigamonkeys.pathnames"; - }); - systems = [ "com.gigamonkeys.pathnames" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_gigamonkeys_dot_prose-diff = (build-asdf-system { - pname = "com.gigamonkeys.prose-diff"; - version = "20140713-git"; - asds = [ "com.gigamonkeys.prose-diff" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-prose-diff/2014-07-13/monkeylib-prose-diff-20140713-git.tgz"; - sha256 = "1zwaa8qmpbdpdg8zzk3as73i55c54k9m694gx4bla1xxli5f8ijc"; - system = "com.gigamonkeys.prose-diff"; - asd = "com.gigamonkeys.prose-diff"; - }); - systems = [ "com.gigamonkeys.prose-diff" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) (getAttr "com_dot_gigamonkeys_dot_markup" self) (getAttr "com_dot_gigamonkeys_dot_pathnames" self) (getAttr "com_dot_gigamonkeys_dot_utilities" self) (getAttr "monkeylib-markup-html" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_gigamonkeys_dot_test-framework = (build-asdf-system { - pname = "com.gigamonkeys.test-framework"; - version = "20101207-git"; - asds = [ "com.gigamonkeys.test-framework" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-test-framework/2010-12-07/monkeylib-test-framework-20101207-git.tgz"; - sha256 = "1d6b8zg0vnbqxxsbbjr3b4r46d8whj84h9yqnqw3ii0bwr8hn82v"; - system = "com.gigamonkeys.test-framework"; - asd = "com.gigamonkeys.test-framework"; - }); - systems = [ "com.gigamonkeys.test-framework" ]; - lispLibs = [ (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_gigamonkeys_dot_utilities = (build-asdf-system { - pname = "com.gigamonkeys.utilities"; - version = "20170403-git"; - asds = [ "com.gigamonkeys.utilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-utilities/2017-04-03/monkeylib-utilities-20170403-git.tgz"; - sha256 = "0d0h1y43mn6r8s4g9gbr02d09565p0gig21jfnk7zf1dl6rnvkvm"; - system = "com.gigamonkeys.utilities"; - asd = "com.gigamonkeys.utilities"; - }); - systems = [ "com.gigamonkeys.utilities" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_google_dot_base = (build-asdf-system { - pname = "com.google.base"; - version = "20200925-git"; - asds = [ "com.google.base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/com.google.base/2020-09-25/com.google.base-20200925-git.tgz"; - sha256 = "1drc341sqmrmyvdgqpdy066f0z0ia0kl3ppq0rlxznlxhn17x3xj"; - system = "com.google.base"; - asd = "com.google.base"; - }); - systems = [ "com.google.base" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_google_dot_flag = (build-asdf-system { - pname = "com.google.flag"; - version = "20201220-git"; - asds = [ "com.google.flag" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-gflags/2020-12-20/lisp-gflags-20201220-git.tgz"; - sha256 = "06p70v1wv0ynr6ng6vr6krc5773xphvkv2nfxvnschc1bzqhds5k"; - system = "com.google.flag"; - asd = "com.google.flag"; - }); - systems = [ "com.google.flag" ]; - lispLibs = [ (getAttr "com_dot_google_dot_base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - com_dot_inuoe_dot_jzon = (build-asdf-system { - pname = "com.inuoe.jzon"; - version = "v1.1.4"; - asds = [ "com.inuoe.jzon" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jzon/2024-10-12/jzon-v1.1.4.tgz"; - sha256 = "0z7xpylyk8rakz449rxqpz4hazn91ap2dnf0689iigdvvl3yqz3g"; - system = "com.inuoe.jzon"; - asd = "com.inuoe.jzon"; - }); - systems = [ "com.inuoe.jzon" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "flexi-streams" self) (getAttr "float-features" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - com_dot_inuoe_dot_jzon-tests = (build-asdf-system { - pname = "com.inuoe.jzon-tests"; - version = "v1.1.4"; - asds = [ "com.inuoe.jzon-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jzon/2024-10-12/jzon-v1.1.4.tgz"; - sha256 = "0z7xpylyk8rakz449rxqpz4hazn91ap2dnf0689iigdvvl3yqz3g"; - system = "com.inuoe.jzon-tests"; - asd = "com.inuoe.jzon-tests"; - }); - systems = [ "com.inuoe.jzon-tests" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "com_dot_inuoe_dot_jzon" self) (getAttr "fiveam" self) (getAttr "flexi-streams" self) (getAttr "float-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - command-line-arguments = (build-asdf-system { - pname = "command-line-arguments"; - version = "20210807-git"; - asds = [ "command-line-arguments" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/command-line-arguments/2021-08-07/command-line-arguments-20210807-git.tgz"; - sha256 = "1wbb83b559nfv65rsxz3jrixic9gndk2whj40hhwb0s13rf5a62y"; - system = "command-line-arguments"; - asd = "command-line-arguments"; - }); - systems = [ "command-line-arguments" ]; - lispLibs = [ ]; - meta = {}; - }); - common-doc = (build-asdf-system { - pname = "common-doc"; - version = "20230214-git"; - asds = [ "common-doc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; - sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; - system = "common-doc"; - asd = "common-doc"; - }); - systems = [ "common-doc" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "closer-mop" self) (getAttr "local-time" self) (getAttr "quri" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-doc-contrib = (build-asdf-system { - pname = "common-doc-contrib"; - version = "20230214-git"; - asds = [ "common-doc-contrib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; - sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; - system = "common-doc-contrib"; - asd = "common-doc-contrib"; - }); - systems = [ "common-doc-contrib" ]; - lispLibs = [ (getAttr "common-doc-gnuplot" self) (getAttr "common-doc-graphviz" self) (getAttr "common-doc-include" self) (getAttr "common-doc-plantuml" self) (getAttr "common-doc-split-paragraphs" self) (getAttr "common-doc-tex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-doc-gnuplot = (build-asdf-system { - pname = "common-doc-gnuplot"; - version = "20230214-git"; - asds = [ "common-doc-gnuplot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; - sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; - system = "common-doc-gnuplot"; - asd = "common-doc-gnuplot"; - }); - systems = [ "common-doc-gnuplot" ]; - lispLibs = [ (getAttr "common-doc" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-doc-graphviz = (build-asdf-system { - pname = "common-doc-graphviz"; - version = "20230214-git"; - asds = [ "common-doc-graphviz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; - sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; - system = "common-doc-graphviz"; - asd = "common-doc-graphviz"; - }); - systems = [ "common-doc-graphviz" ]; - lispLibs = [ (getAttr "common-doc" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-doc-include = (build-asdf-system { - pname = "common-doc-include"; - version = "20230214-git"; - asds = [ "common-doc-include" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; - sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; - system = "common-doc-include"; - asd = "common-doc-include"; - }); - systems = [ "common-doc-include" ]; - lispLibs = [ (getAttr "common-doc" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-doc-plantuml = (build-asdf-system { - pname = "common-doc-plantuml"; - version = "20230214-git"; - asds = [ "common-doc-plantuml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; - sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; - system = "common-doc-plantuml"; - asd = "common-doc-plantuml"; - }); - systems = [ "common-doc-plantuml" ]; - lispLibs = [ (getAttr "common-doc" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-doc-plump = (build-asdf-system { - pname = "common-doc-plump"; - version = "20160421-git"; - asds = [ "common-doc-plump" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-doc-plump/2016-04-21/common-doc-plump-20160421-git.tgz"; - sha256 = "08h7m4c599rf2kz4wkpbj05441ax0vb3bd88a7dw5x57djf765r6"; - system = "common-doc-plump"; - asd = "common-doc-plump"; - }); - systems = [ "common-doc-plump" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "cl-markup" self) (getAttr "common-doc" self) (getAttr "common-doc-split-paragraphs" self) (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-doc-plump-test = (build-asdf-system { - pname = "common-doc-plump-test"; - version = "20160421-git"; - asds = [ "common-doc-plump-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-doc-plump/2016-04-21/common-doc-plump-20160421-git.tgz"; - sha256 = "08h7m4c599rf2kz4wkpbj05441ax0vb3bd88a7dw5x57djf765r6"; - system = "common-doc-plump-test"; - asd = "common-doc-plump-test"; - }); - systems = [ "common-doc-plump-test" ]; - lispLibs = [ (getAttr "common-doc-plump" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-doc-split-paragraphs = (build-asdf-system { - pname = "common-doc-split-paragraphs"; - version = "20230214-git"; - asds = [ "common-doc-split-paragraphs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; - sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; - system = "common-doc-split-paragraphs"; - asd = "common-doc-split-paragraphs"; - }); - systems = [ "common-doc-split-paragraphs" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "common-doc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-doc-test = (build-asdf-system { - pname = "common-doc-test"; - version = "20230214-git"; - asds = [ "common-doc-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; - sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; - system = "common-doc-test"; - asd = "common-doc-test"; - }); - systems = [ "common-doc-test" ]; - lispLibs = [ (getAttr "common-doc" self) (getAttr "common-doc-contrib" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-doc-tex = (build-asdf-system { - pname = "common-doc-tex"; - version = "20230214-git"; - asds = [ "common-doc-tex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; - sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; - system = "common-doc-tex"; - asd = "common-doc-tex"; - }); - systems = [ "common-doc-tex" ]; - lispLibs = [ (getAttr "common-doc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-html = (build-asdf-system { - pname = "common-html"; - version = "20210807-git"; - asds = [ "common-html" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-html/2021-08-07/common-html-20210807-git.tgz"; - sha256 = "1i11w4l95nybz5ibnaxrnrkfhch2s9wynqrg6kx6sl6y47khq1xz"; - system = "common-html"; - asd = "common-html"; - }); - systems = [ "common-html" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "common-doc" self) (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-html-test = (build-asdf-system { - pname = "common-html-test"; - version = "20210807-git"; - asds = [ "common-html-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-html/2021-08-07/common-html-20210807-git.tgz"; - sha256 = "1i11w4l95nybz5ibnaxrnrkfhch2s9wynqrg6kx6sl6y47khq1xz"; - system = "common-html-test"; - asd = "common-html-test"; - }); - systems = [ "common-html-test" ]; - lispLibs = [ (getAttr "common-html" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - common-lisp-jupyter = (build-asdf-system { - pname = "common-lisp-jupyter"; - version = "20241012-git"; - asds = [ "common-lisp-jupyter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-lisp-jupyter/2024-10-12/common-lisp-jupyter-20241012-git.tgz"; - sha256 = "1qbrzv0myxfxq7rzm2y9cm2xymkl982982h2kbsl7d1yd5hrjvl6"; - system = "common-lisp-jupyter"; - asd = "common-lisp-jupyter"; - }); - systems = [ "common-lisp-jupyter" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "cl-base64" self) (getAttr "cl-indentify" self) (getAttr "closer-mop" self) (getAttr "dissect" self) (getAttr "eclector" self) (getAttr "ironclad" self) (getAttr "jupyter-lab-extension" self) (getAttr "multilang-documentation" self) (getAttr "nontrivial-gray-streams" self) (getAttr "puri" self) (getAttr "pzmq" self) (getAttr "shasht" self) (getAttr "static-vectors" self) (getAttr "trivial-do" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) (getAttr "trivial-mimes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - commondoc-markdown = (build-asdf-system { - pname = "commondoc-markdown"; - version = "20241012-git"; - asds = [ "commondoc-markdown" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/commondoc-markdown/2024-10-12/commondoc-markdown-20241012-git.tgz"; - sha256 = "12n8yx8jhz8713r63gmrymplm1mfczm7q7a343d13wl6gng1gjs1"; - system = "commondoc-markdown"; - asd = "commondoc-markdown"; - }); - systems = [ "commondoc-markdown" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "_3bmd-ext-code-blocks" self) (getAttr "_3bmd-ext-tables" self) (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "common-doc" self) (getAttr "common-html" self) (getAttr "esrap" self) (getAttr "ironclad" self) (getAttr "plump" self) (getAttr "quri" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - commondoc-markdown-docs = (build-asdf-system { - pname = "commondoc-markdown-docs"; - version = "20241012-git"; - asds = [ "commondoc-markdown-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/commondoc-markdown/2024-10-12/commondoc-markdown-20241012-git.tgz"; - sha256 = "12n8yx8jhz8713r63gmrymplm1mfczm7q7a343d13wl6gng1gjs1"; - system = "commondoc-markdown-docs"; - asd = "commondoc-markdown-docs"; - }); - systems = [ "commondoc-markdown-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - commondoc-markdown-test = (build-asdf-system { - pname = "commondoc-markdown-test"; - version = "20241012-git"; - asds = [ "commondoc-markdown-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/commondoc-markdown/2024-10-12/commondoc-markdown-20241012-git.tgz"; - sha256 = "12n8yx8jhz8713r63gmrymplm1mfczm7q7a343d13wl6gng1gjs1"; - system = "commondoc-markdown-test"; - asd = "commondoc-markdown-test"; - }); - systems = [ "commondoc-markdown-test" ]; - lispLibs = [ (getAttr "common-doc" self) (getAttr "commondoc-markdown" self) (getAttr "hamcrest" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - commonqt = (build-asdf-system { - pname = "commonqt"; - version = "20210531-git"; - asds = [ "commonqt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "commonqt"; - asd = "commonqt"; - }); - systems = [ "commonqt" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "smokebase" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - comp-set = (build-asdf-system { - pname = "comp-set"; - version = "20210807-git"; - asds = [ "comp-set" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; - sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; - system = "comp-set"; - asd = "comp-set"; - }); - systems = [ "comp-set" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - compatible-metaclasses = (build-asdf-system { - pname = "compatible-metaclasses"; - version = "1.0"; - asds = [ "compatible-metaclasses" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/compatible-metaclasses/2020-09-25/compatible-metaclasses_1.0.tgz"; - sha256 = "17cf74j400cl6sjslfhkv13lir85k705v63mx3dd4y6dl5hvsdh6"; - system = "compatible-metaclasses"; - asd = "compatible-metaclasses"; - }); - systems = [ "compatible-metaclasses" ]; - lispLibs = [ (getAttr "class-options" self) (getAttr "closer-mop" self) (getAttr "enhanced-find-class" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - compatible-metaclasses__tests = (build-asdf-system { - pname = "compatible-metaclasses_tests"; - version = "1.0"; - asds = [ "compatible-metaclasses_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/compatible-metaclasses/2020-09-25/compatible-metaclasses_1.0.tgz"; - sha256 = "17cf74j400cl6sjslfhkv13lir85k705v63mx3dd4y6dl5hvsdh6"; - system = "compatible-metaclasses_tests"; - asd = "compatible-metaclasses_tests"; - }); - systems = [ "compatible-metaclasses_tests" ]; - lispLibs = [ (getAttr "compatible-metaclasses" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - compiler-macro-notes = (build-asdf-system { - pname = "compiler-macro-notes"; - version = "v0.3.1"; - asds = [ "compiler-macro-notes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/compiler-macro-notes/2024-10-12/compiler-macro-notes-v0.3.1.tgz"; - sha256 = "0pchhvk14fx54p7qq92dnf0g4jnapqr6p2a4za6bhzd8im1d9gad"; - system = "compiler-macro-notes"; - asd = "compiler-macro-notes"; - }); - systems = [ "compiler-macro-notes" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-environments" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - computable-reals = (build-asdf-system { - pname = "computable-reals"; - version = "20231021-git"; - asds = [ "computable-reals" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/computable-reals/2023-10-21/computable-reals-20231021-git.tgz"; - sha256 = "1x8kkdyjil0zzg8fq9b76z12kmfrqwhsxnr6qqnlrg0c8c5bzz9c"; - system = "computable-reals"; - asd = "computable-reals"; - }); - systems = [ "computable-reals" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - concrete-syntax-tree = (build-asdf-system { - pname = "concrete-syntax-tree"; - version = "20230618-git"; - asds = [ "concrete-syntax-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/concrete-syntax-tree/2023-06-18/concrete-syntax-tree-20230618-git.tgz"; - sha256 = "15q9jyqsh2z921li9my8c840cj2ci7k217x5frfiyk0kymkx4rgv"; - system = "concrete-syntax-tree"; - asd = "concrete-syntax-tree"; - }); - systems = [ "concrete-syntax-tree" ]; - lispLibs = [ (getAttr "concrete-syntax-tree-base" self) (getAttr "concrete-syntax-tree-lambda-list" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - concrete-syntax-tree-base = (build-asdf-system { - pname = "concrete-syntax-tree-base"; - version = "20230618-git"; - asds = [ "concrete-syntax-tree-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/concrete-syntax-tree/2023-06-18/concrete-syntax-tree-20230618-git.tgz"; - sha256 = "15q9jyqsh2z921li9my8c840cj2ci7k217x5frfiyk0kymkx4rgv"; - system = "concrete-syntax-tree-base"; - asd = "concrete-syntax-tree-base"; - }); - systems = [ "concrete-syntax-tree-base" ]; - lispLibs = [ (getAttr "acclimation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - concrete-syntax-tree-destructuring = (build-asdf-system { - pname = "concrete-syntax-tree-destructuring"; - version = "20230618-git"; - asds = [ "concrete-syntax-tree-destructuring" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/concrete-syntax-tree/2023-06-18/concrete-syntax-tree-20230618-git.tgz"; - sha256 = "15q9jyqsh2z921li9my8c840cj2ci7k217x5frfiyk0kymkx4rgv"; - system = "concrete-syntax-tree-destructuring"; - asd = "concrete-syntax-tree-destructuring"; - }); - systems = [ "concrete-syntax-tree-destructuring" ]; - lispLibs = [ (getAttr "concrete-syntax-tree-lambda-list" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - concrete-syntax-tree-lambda-list = (build-asdf-system { - pname = "concrete-syntax-tree-lambda-list"; - version = "20230618-git"; - asds = [ "concrete-syntax-tree-lambda-list" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/concrete-syntax-tree/2023-06-18/concrete-syntax-tree-20230618-git.tgz"; - sha256 = "15q9jyqsh2z921li9my8c840cj2ci7k217x5frfiyk0kymkx4rgv"; - system = "concrete-syntax-tree-lambda-list"; - asd = "concrete-syntax-tree-lambda-list"; - }); - systems = [ "concrete-syntax-tree-lambda-list" ]; - lispLibs = [ (getAttr "concrete-syntax-tree-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - concrete-syntax-tree-lambda-list-test = (build-asdf-system { - pname = "concrete-syntax-tree-lambda-list-test"; - version = "20230618-git"; - asds = [ "concrete-syntax-tree-lambda-list-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/concrete-syntax-tree/2023-06-18/concrete-syntax-tree-20230618-git.tgz"; - sha256 = "15q9jyqsh2z921li9my8c840cj2ci7k217x5frfiyk0kymkx4rgv"; - system = "concrete-syntax-tree-lambda-list-test"; - asd = "concrete-syntax-tree-lambda-list-test"; - }); - systems = [ "concrete-syntax-tree-lambda-list-test" ]; - lispLibs = [ (getAttr "concrete-syntax-tree-lambda-list" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - concrete-syntax-tree-source-info = (build-asdf-system { - pname = "concrete-syntax-tree-source-info"; - version = "20230618-git"; - asds = [ "concrete-syntax-tree-source-info" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/concrete-syntax-tree/2023-06-18/concrete-syntax-tree-20230618-git.tgz"; - sha256 = "15q9jyqsh2z921li9my8c840cj2ci7k217x5frfiyk0kymkx4rgv"; - system = "concrete-syntax-tree-source-info"; - asd = "concrete-syntax-tree-source-info"; - }); - systems = [ "concrete-syntax-tree-source-info" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - conditional-commands = (build-asdf-system { - pname = "conditional-commands"; - version = "20241012-git"; - asds = [ "conditional-commands" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "conditional-commands"; - asd = "conditional-commands"; - }); - systems = [ "conditional-commands" ]; - lispLibs = [ (getAttr "clim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - conf = (build-asdf-system { - pname = "conf"; - version = "20191227-git"; - asds = [ "conf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/conf/2019-12-27/conf-20191227-git.tgz"; - sha256 = "0mif91gb6yqg2qrzd2p6n83w9injikm5gggzv2mgxkiyzmr5gnay"; - system = "conf"; - asd = "conf"; - }); - systems = [ "conf" ]; - lispLibs = [ (getAttr "cl-fad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - configuration_dot_options = (build-asdf-system { - pname = "configuration.options"; - version = "20210531-git"; - asds = [ "configuration.options" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; - sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; - system = "configuration.options"; - asd = "configuration.options"; - }); - systems = [ "configuration.options" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "architecture_dot_service-provider" self) (getAttr "cl-hooks" self) (getAttr "esrap" self) (getAttr "let-plus" self) (getAttr "log4cl" self) (getAttr "more-conditions" self) (getAttr "split-sequence" self) (getAttr "utilities_dot_print-items" self) (getAttr "utilities_dot_print-tree" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - configuration_dot_options-and-mop = (build-asdf-system { - pname = "configuration.options-and-mop"; - version = "20210531-git"; - asds = [ "configuration.options-and-mop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; - sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; - system = "configuration.options-and-mop"; - asd = "configuration.options-and-mop"; - }); - systems = [ "configuration.options-and-mop" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "configuration_dot_options" self) (getAttr "let-plus" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - configuration_dot_options-and-puri = (build-asdf-system { - pname = "configuration.options-and-puri"; - version = "20210531-git"; - asds = [ "configuration.options-and-puri" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; - sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; - system = "configuration.options-and-puri"; - asd = "configuration.options-and-puri"; - }); - systems = [ "configuration.options-and-puri" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "configuration_dot_options" self) (getAttr "let-plus" self) (getAttr "puri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - configuration_dot_options-and-quri = (build-asdf-system { - pname = "configuration.options-and-quri"; - version = "20210531-git"; - asds = [ "configuration.options-and-quri" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; - sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; - system = "configuration.options-and-quri"; - asd = "configuration.options-and-quri"; - }); - systems = [ "configuration.options-and-quri" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "configuration_dot_options" self) (getAttr "let-plus" self) (getAttr "quri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - configuration_dot_options-and-service-provider = (build-asdf-system { - pname = "configuration.options-and-service-provider"; - version = "20210531-git"; - asds = [ "configuration.options-and-service-provider" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; - sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; - system = "configuration.options-and-service-provider"; - asd = "configuration.options-and-service-provider"; - }); - systems = [ "configuration.options-and-service-provider" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "architecture_dot_service-provider" self) (getAttr "architecture_dot_service-provider-and-hooks" self) (getAttr "configuration_dot_options" self) (getAttr "configuration_dot_options-and-mop" self) (getAttr "let-plus" self) (getAttr "log4cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - configuration_dot_options-syntax-ini = (build-asdf-system { - pname = "configuration.options-syntax-ini"; - version = "20210531-git"; - asds = [ "configuration.options-syntax-ini" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; - sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; - system = "configuration.options-syntax-ini"; - asd = "configuration.options-syntax-ini"; - }); - systems = [ "configuration.options-syntax-ini" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "configuration_dot_options" self) (getAttr "let-plus" self) (getAttr "parser_dot_ini" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - configuration_dot_options-syntax-xml = (build-asdf-system { - pname = "configuration.options-syntax-xml"; - version = "20210531-git"; - asds = [ "configuration.options-syntax-xml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; - sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; - system = "configuration.options-syntax-xml"; - asd = "configuration.options-syntax-xml"; - }); - systems = [ "configuration.options-syntax-xml" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "configuration_dot_options" self) (getAttr "let-plus" self) (getAttr "xml_dot_location" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - conium = (build-asdf-system { - pname = "conium"; - version = "20210630-git"; - asds = [ "conium" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/conium/2021-06-30/conium-20210630-git.tgz"; - sha256 = "0y31za8xr8734p2pf8mrw1jd1fksh2d4y1p12wwjyn8hxxsvsx1w"; - system = "conium"; - asd = "conium"; - }); - systems = [ "conium" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - consfigurator = (build-asdf-system { - pname = "consfigurator"; - version = "v1.4.4"; - asds = [ "consfigurator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/consfigurator/2024-10-12/consfigurator-v1.4.4.tgz"; - sha256 = "1f4q5w58phj5a6i2fj712ggz2p8b5m4v77qzsvbb3xmy2vhppvv0"; - system = "consfigurator"; - asd = "consfigurator"; - }); - systems = [ "consfigurator" ]; - lispLibs = [ (getAttr "agnostic-lizard" self) (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "babel" self) (getAttr "babel-streams" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-heredoc" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "named-readtables" self) (getAttr "osicat" self) (getAttr "parse-number" self) (getAttr "trivial-backtrace" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - consix = (build-asdf-system { - pname = "consix"; - version = "20201220-git"; - asds = [ "consix" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/consix/2020-12-20/consix-20201220-git.tgz"; - sha256 = "0zpcaxgq9jx0baj5sid8rnzq8ygsmd8yzb0x37nkaiwa67x5jjck"; - system = "consix"; - asd = "consix"; - }); - systems = [ "consix" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-glu" self) (getAttr "cl-glut" self) (getAttr "cl-opengl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - constantfold = (build-asdf-system { - pname = "constantfold"; - version = "20191227-git"; - asds = [ "constantfold" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/constantfold/2019-12-27/constantfold-20191227-git.tgz"; - sha256 = "153h0569z6bff1qbad0bdssplwwny75l7ilqwcfqfdvzsxf9jh06"; - system = "constantfold"; - asd = "constantfold"; - }); - systems = [ "constantfold" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "lisp-namespace" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - constantfold_dot_test = (build-asdf-system { - pname = "constantfold.test"; - version = "20191227-git"; - asds = [ "constantfold.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/constantfold/2019-12-27/constantfold-20191227-git.tgz"; - sha256 = "153h0569z6bff1qbad0bdssplwwny75l7ilqwcfqfdvzsxf9jh06"; - system = "constantfold.test"; - asd = "constantfold.test"; - }); - systems = [ "constantfold.test" ]; - lispLibs = [ (getAttr "constantfold" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - context-lite = (build-asdf-system { - pname = "context-lite"; - version = "20220331-git"; - asds = [ "context-lite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/context-lite/2022-03-31/context-lite-20220331-git.tgz"; - sha256 = "16hmid3adimn10c0y4p6hg7n42al2qgsy7wxlpargk0xbn4h3km4"; - system = "context-lite"; - asd = "context-lite"; - }); - systems = [ "context-lite" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - contextl = (build-asdf-system { - pname = "contextl"; - version = "20241012-git"; - asds = [ "contextl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/contextl/2024-10-12/contextl-20241012-git.tgz"; - sha256 = "1jsa5wyjzzfw9pii3d6x20mh8ijnpb291g3i0y2ccj0x8z3xfyyk"; - system = "contextl"; - asd = "contextl"; - }); - systems = [ "contextl" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "lw-compat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - control = (build-asdf-system { - pname = "control"; - version = "20200427-git"; - asds = [ "control" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "control"; - asd = "control"; - }); - systems = [ "control" ]; - lispLibs = [ (getAttr "character-modifier-bits" self) (getAttr "utility" self) (getAttr "window" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - copy-directory = (build-asdf-system { - pname = "copy-directory"; - version = "20160628-git"; - asds = [ "copy-directory" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/copy-directory/2016-06-28/copy-directory-20160628-git.tgz"; - sha256 = "19wvzb046lcyifhx26ydzf7ngfa52n64nyx76k3lh02x7ahhpc93"; - system = "copy-directory"; - asd = "copy-directory"; - }); - systems = [ "copy-directory" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "which" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - copy-directory-test = (build-asdf-system { - pname = "copy-directory-test"; - version = "20160628-git"; - asds = [ "copy-directory-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/copy-directory/2016-06-28/copy-directory-20160628-git.tgz"; - sha256 = "19wvzb046lcyifhx26ydzf7ngfa52n64nyx76k3lh02x7ahhpc93"; - system = "copy-directory-test"; - asd = "copy-directory-test"; - }); - systems = [ "copy-directory-test" ]; - lispLibs = [ (getAttr "copy-directory" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - core-reader = (build-asdf-system { - pname = "core-reader"; - version = "20220707-git"; - asds = [ "core-reader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/core-reader/2022-07-07/core-reader-20220707-git.tgz"; - sha256 = "1f2cm44r3pnahgx1b3c3psf6myaliwsrvfcgz8c9ydqi5qlx49gb"; - system = "core-reader"; - asd = "core-reader"; - }); - systems = [ "core-reader" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - core-reader_dot_test = (build-asdf-system { - pname = "core-reader.test"; - version = "20220707-git"; - asds = [ "core-reader.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/core-reader/2022-07-07/core-reader-20220707-git.tgz"; - sha256 = "1f2cm44r3pnahgx1b3c3psf6myaliwsrvfcgz8c9ydqi5qlx49gb"; - system = "core-reader.test"; - asd = "core-reader.test"; - }); - systems = [ "core-reader.test" ]; - lispLibs = [ (getAttr "core-reader" self) (getAttr "jingoh" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cover = (build-asdf-system { - pname = "cover"; - version = "20230618-git"; - asds = [ "cover" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cover/2023-06-18/cover-20230618-git.tgz"; - sha256 = "0152zzdszhiblzm3a80x8bnalip7gnzyvvwnlswsnnlb509nby89"; - system = "cover"; - asd = "cover"; - }); - systems = [ "cover" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cqlcl = (build-asdf-system { - pname = "cqlcl"; - version = "20141106-git"; - asds = [ "cqlcl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cqlcl/2014-11-06/cqlcl-20141106-git.tgz"; - sha256 = "0ppdsrrf2hz0s4y02a2p5mgms92znrj7hz7x9j6azppfkal25zid"; - system = "cqlcl"; - asd = "cqlcl"; - }); - systems = [ "cqlcl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "fiveam" self) (getAttr "flexi-streams" self) (getAttr "lparallel" self) (getAttr "pooler" self) (getAttr "split-sequence" self) (getAttr "usocket" self) (getAttr "uuid" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cqlcl-test = (build-asdf-system { - pname = "cqlcl-test"; - version = "20141106-git"; - asds = [ "cqlcl-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cqlcl/2014-11-06/cqlcl-20141106-git.tgz"; - sha256 = "0ppdsrrf2hz0s4y02a2p5mgms92znrj7hz7x9j6azppfkal25zid"; - system = "cqlcl-test"; - asd = "cqlcl"; - }); - systems = [ "cqlcl-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cqlcl" self) (getAttr "fiveam" self) (getAttr "flexi-streams" self) (getAttr "uuid" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - crane = (build-asdf-system { - pname = "crane"; - version = "20160208-git"; - asds = [ "crane" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/crane/2016-02-08/crane-20160208-git.tgz"; - sha256 = "1wai4h7vz5i0ld1fnnbcmpz5d67dmykyxx0ay0fkclkwvpj7gh5n"; - system = "crane"; - asd = "crane"; - }); - systems = [ "crane" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "cl-fad" self) (getAttr "clos-fixtures" self) (getAttr "closer-mop" self) (getAttr "dbi" self) (getAttr "iterate" self) (getAttr "local-time" self) (getAttr "sxql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - crane-test = (build-asdf-system { - pname = "crane-test"; - version = "20160208-git"; - asds = [ "crane-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/crane/2016-02-08/crane-20160208-git.tgz"; - sha256 = "1wai4h7vz5i0ld1fnnbcmpz5d67dmykyxx0ay0fkclkwvpj7gh5n"; - system = "crane-test"; - asd = "crane-test"; - }); - systems = [ "crane-test" ]; - lispLibs = [ (getAttr "crane" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cricket = (build-asdf-system { - pname = "cricket"; - version = "20220707-git"; - asds = [ "cricket" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cricket/2022-07-07/cricket-20220707-git.tgz"; - sha256 = "0wdpzdmalbnfjmd9s7yalris4i1vvc2klnhfl8g0h2ahq0mqv9p9"; - system = "cricket"; - asd = "cricket"; - }); - systems = [ "cricket" ]; - lispLibs = [ (getAttr "arrow-macros" self) (getAttr "cl-cpus" self) (getAttr "lparallel" self) (getAttr "mfiano-utils" self) (getAttr "seedable-rng" self) (getAttr "zpng" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cricket_dot_test = (build-asdf-system { - pname = "cricket.test"; - version = "20220707-git"; - asds = [ "cricket.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cricket/2022-07-07/cricket-20220707-git.tgz"; - sha256 = "0wdpzdmalbnfjmd9s7yalris4i1vvc2klnhfl8g0h2ahq0mqv9p9"; - system = "cricket.test"; - asd = "cricket.test"; - }); - systems = [ "cricket.test" ]; - lispLibs = [ (getAttr "cricket" self) (getAttr "mfiano-utils" self) (getAttr "pngload" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - croatoan = (build-asdf-system { - pname = "croatoan"; - version = "20241012-git"; - asds = [ "croatoan" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/croatoan/2024-10-12/croatoan-20241012-git.tgz"; - sha256 = "04776x4i8inxs8n4mgy9xf0q39bzv4mfz4cl880sxwk6mnhwnn4c"; - system = "croatoan"; - asd = "croatoan"; - }); - systems = [ "croatoan" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "croatoan-ncurses" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - croatoan-ncurses = (build-asdf-system { - pname = "croatoan-ncurses"; - version = "20241012-git"; - asds = [ "croatoan-ncurses" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/croatoan/2024-10-12/croatoan-20241012-git.tgz"; - sha256 = "04776x4i8inxs8n4mgy9xf0q39bzv4mfz4cl880sxwk6mnhwnn4c"; - system = "croatoan-ncurses"; - asd = "croatoan-ncurses"; - }); - systems = [ "croatoan-ncurses" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - croatoan-test = (build-asdf-system { - pname = "croatoan-test"; - version = "20241012-git"; - asds = [ "croatoan-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/croatoan/2024-10-12/croatoan-20241012-git.tgz"; - sha256 = "04776x4i8inxs8n4mgy9xf0q39bzv4mfz4cl880sxwk6mnhwnn4c"; - system = "croatoan-test"; - asd = "croatoan-test"; - }); - systems = [ "croatoan-test" ]; - lispLibs = [ (getAttr "croatoan" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - crud = (build-asdf-system { - pname = "crud"; - version = "20200427-git"; - asds = [ "crud" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "crud"; - asd = "crud"; - }); - systems = [ "crud" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "base64" self) (getAttr "lparallel" self) (getAttr "sqlite" self) (getAttr "sucle-serialize" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - crypt = (build-asdf-system { - pname = "crypt"; - version = "20120520-git"; - asds = [ "crypt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-crypt/2012-05-20/cl-crypt-20120520-git.tgz"; - sha256 = "02fc3aqfbbwjpz79a4mwffv33pnmmknpkmd1r8v9mkn9a6c1ssmh"; - system = "crypt"; - asd = "crypt"; - }); - systems = [ "crypt" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - crypto-shortcuts = (build-asdf-system { - pname = "crypto-shortcuts"; - version = "20231021-git"; - asds = [ "crypto-shortcuts" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/crypto-shortcuts/2023-10-21/crypto-shortcuts-20231021-git.tgz"; - sha256 = "0ghih34xlf9vgbh8arsqjbgf8iymvs5s0ys0n2bm73b1z0632ygr"; - system = "crypto-shortcuts"; - asd = "crypto-shortcuts"; - }); - systems = [ "crypto-shortcuts" ]; - lispLibs = [ (getAttr "cl-base32" self) (getAttr "cl-base64" self) (getAttr "flexi-streams" self) (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cserial-port = (build-asdf-system { - pname = "cserial-port"; - version = "20230214-git"; - asds = [ "cserial-port" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cserial-port/2023-02-14/cserial-port-20230214-git.tgz"; - sha256 = "0l38qh66g2iba7kjw6fml3q55ax6vkk0khbwrsvkglwhpan79fsm"; - system = "cserial-port"; - asd = "cserial-port"; - }); - systems = [ "cserial-port" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "osicat" self) (getAttr "trivial-features" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - css-lite = (build-asdf-system { - pname = "css-lite"; - version = "20230618-git"; - asds = [ "css-lite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/css-lite/2023-06-18/css-lite-20230618-git.tgz"; - sha256 = "1pvvwd6ysdc7m5945vkwdbq4jjmcszmkxp9jhgi0lba23si07dp5"; - system = "css-lite"; - asd = "css-lite"; - }); - systems = [ "css-lite" ]; - lispLibs = [ (getAttr "parenscript" self) ]; - meta = {}; - }); - css-selectors = (build-asdf-system { - pname = "css-selectors"; - version = "20160628-git"; - asds = [ "css-selectors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/css-selectors/2016-06-28/css-selectors-20160628-git.tgz"; - sha256 = "0x0a5jq4kdw8zrkljmhijcbvjj09iyrwwgryc6kvzl5g7wzg2xr6"; - system = "css-selectors"; - asd = "css-selectors"; - }); - systems = [ "css-selectors" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "buildnode" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "cxml" self) (getAttr "iterate" self) (getAttr "symbol-munger" self) (getAttr "yacc" self) ]; - meta = {}; - }); - css-selectors-simple-tree = (build-asdf-system { - pname = "css-selectors-simple-tree"; - version = "20160628-git"; - asds = [ "css-selectors-simple-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/css-selectors/2016-06-28/css-selectors-20160628-git.tgz"; - sha256 = "0x0a5jq4kdw8zrkljmhijcbvjj09iyrwwgryc6kvzl5g7wzg2xr6"; - system = "css-selectors-simple-tree"; - asd = "css-selectors-simple-tree"; - }); - systems = [ "css-selectors-simple-tree" ]; - lispLibs = [ (getAttr "cl-html5-parser" self) (getAttr "css-selectors" self) ]; - meta = {}; - }); - css-selectors-stp = (build-asdf-system { - pname = "css-selectors-stp"; - version = "20160628-git"; - asds = [ "css-selectors-stp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/css-selectors/2016-06-28/css-selectors-20160628-git.tgz"; - sha256 = "0x0a5jq4kdw8zrkljmhijcbvjj09iyrwwgryc6kvzl5g7wzg2xr6"; - system = "css-selectors-stp"; - asd = "css-selectors-stp"; - }); - systems = [ "css-selectors-stp" ]; - lispLibs = [ (getAttr "css-selectors" self) (getAttr "cxml-stp" self) ]; - meta = {}; - }); - css-selectors-test = (build-asdf-system { - pname = "css-selectors-test"; - version = "20160628-git"; - asds = [ "css-selectors-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/css-selectors/2016-06-28/css-selectors-20160628-git.tgz"; - sha256 = "0x0a5jq4kdw8zrkljmhijcbvjj09iyrwwgryc6kvzl5g7wzg2xr6"; - system = "css-selectors-test"; - asd = "css-selectors"; - }); - systems = [ "css-selectors-test" ]; - lispLibs = [ (getAttr "buildnode-xhtml" self) (getAttr "css-selectors" self) (getAttr "lisp-unit2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - csv = (build-asdf-system { - pname = "csv"; - version = "20190710-git"; - asds = [ "csv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/csv/2019-07-10/csv-20190710-git.tgz"; - sha256 = "0jykv91w7anisac2aip38vnj7ywi567rcp4n8nv3lz5qb7g1dpy4"; - system = "csv"; - asd = "csv"; - }); - systems = [ "csv" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - csv-parser = (build-asdf-system { - pname = "csv-parser"; - version = "20140713-git"; - asds = [ "csv-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/csv-parser/2014-07-13/csv-parser-20140713-git.tgz"; - sha256 = "0pcp709dwxi3p2vrmx5qiy571pybfs1hpv9z8g4i1ig2l4mc3djh"; - system = "csv-parser"; - asd = "csv-parser"; - }); - systems = [ "csv-parser" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - csv-validator = (build-asdf-system { - pname = "csv-validator"; - version = "20230618-git"; - asds = [ "csv-validator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/csv-validator/2023-06-18/csv-validator-20230618-git.tgz"; - sha256 = "14cwjc43q05a1gdl0m79sps59605dfrhd4mjhcxh7gxyj8x7x1k2"; - system = "csv-validator"; - asd = "csv-validator"; - }); - systems = [ "csv-validator" ]; - lispLibs = [ (getAttr "local-time" self) (getAttr "lparallel" self) (getAttr "parse-float" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - csv-validator-tests = (build-asdf-system { - pname = "csv-validator-tests"; - version = "20230618-git"; - asds = [ "csv-validator-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/csv-validator/2023-06-18/csv-validator-20230618-git.tgz"; - sha256 = "14cwjc43q05a1gdl0m79sps59605dfrhd4mjhcxh7gxyj8x7x1k2"; - system = "csv-validator-tests"; - asd = "csv-validator-tests"; - }); - systems = [ "csv-validator-tests" ]; - lispLibs = [ (getAttr "csv-validator" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ctype = (build-asdf-system { - pname = "ctype"; - version = "20241012-git"; - asds = [ "ctype" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ctype/2024-10-12/ctype-20241012-git.tgz"; - sha256 = "0qnssrjssb7258i3a1s1bv3z6plx4pzrkg65i8an25bvwrjwpvqv"; - system = "ctype"; - asd = "ctype"; - }); - systems = [ "ctype" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cubic-bezier = (build-asdf-system { - pname = "cubic-bezier"; - version = "20220707-git"; - asds = [ "cubic-bezier" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cubic-bezier/2022-07-07/cubic-bezier-20220707-git.tgz"; - sha256 = "08byf1pw2s5sz97bk0sp2a6gdx5dkankbbg14azafd1k0vfh7vcr"; - system = "cubic-bezier"; - asd = "cubic-bezier"; - }); - systems = [ "cubic-bezier" ]; - lispLibs = [ (getAttr "mfiano-utils" self) (getAttr "origin" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cue-parser = (build-asdf-system { - pname = "cue-parser"; - version = "20180228-git"; - asds = [ "cue-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cue-parser/2018-02-28/cue-parser-20180228-git.tgz"; - sha256 = "1zl3a02b68yywchd1aldls07b4qgrf08xpb4xiaaw8njk2qa0lz1"; - system = "cue-parser"; - asd = "cue-parser"; - }); - systems = [ "cue-parser" ]; - lispLibs = [ (getAttr "esrap" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - curly = (build-asdf-system { - pname = "curly"; - version = "20120407-git"; - asds = [ "curly" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/curly/2012-04-07/curly-20120407-git.tgz"; - sha256 = "04gpkq6hd7wvvny0p3lgn87bfalswqc67sbg4p35j52w51mqd8vf"; - system = "curly"; - asd = "curly"; - }); - systems = [ "curly" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - curly_dot_test = (build-asdf-system { - pname = "curly.test"; - version = "20120407-git"; - asds = [ "curly.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/curly/2012-04-07/curly-20120407-git.tgz"; - sha256 = "04gpkq6hd7wvvny0p3lgn87bfalswqc67sbg4p35j52w51mqd8vf"; - system = "curly.test"; - asd = "curly"; - }); - systems = [ "curly.test" ]; - lispLibs = [ (getAttr "curly" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - curry-compose-reader-macros = (build-asdf-system { - pname = "curry-compose-reader-macros"; - version = "20201220-git"; - asds = [ "curry-compose-reader-macros" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/curry-compose-reader-macros/2020-12-20/curry-compose-reader-macros-20201220-git.tgz"; - sha256 = "0j4qfwpw4ykf5npiln54w7jcnj46p7xf9d4p3jpx4a67fdkrlxd1"; - system = "curry-compose-reader-macros"; - asd = "curry-compose-reader-macros"; - }); - systems = [ "curry-compose-reader-macros" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cxml = (build-asdf-system { - pname = "cxml"; - version = "20200610-git"; - asds = [ "cxml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cxml/2020-06-10/cxml-20200610-git.tgz"; - sha256 = "18fls3bx7vmnxfa6qara8fxp316d8kb3izar0kysvqg6l0a45a51"; - system = "cxml"; - asd = "cxml"; - }); - systems = [ "cxml" ]; - lispLibs = [ (getAttr "closure-common" self) (getAttr "puri" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - cxml-dom = (build-asdf-system { - pname = "cxml-dom"; - version = "20200610-git"; - asds = [ "cxml-dom" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cxml/2020-06-10/cxml-20200610-git.tgz"; - sha256 = "18fls3bx7vmnxfa6qara8fxp316d8kb3izar0kysvqg6l0a45a51"; - system = "cxml-dom"; - asd = "cxml-dom"; - }); - systems = [ "cxml-dom" ]; - lispLibs = [ (getAttr "closure-common" self) (getAttr "puri" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cxml-klacks = (build-asdf-system { - pname = "cxml-klacks"; - version = "20200610-git"; - asds = [ "cxml-klacks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cxml/2020-06-10/cxml-20200610-git.tgz"; - sha256 = "18fls3bx7vmnxfa6qara8fxp316d8kb3izar0kysvqg6l0a45a51"; - system = "cxml-klacks"; - asd = "cxml-klacks"; - }); - systems = [ "cxml-klacks" ]; - lispLibs = [ (getAttr "closure-common" self) (getAttr "puri" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cxml-rng = (build-asdf-system { - pname = "cxml-rng"; - version = "20190710-git"; - asds = [ "cxml-rng" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cxml-rng/2019-07-10/cxml-rng-20190710-git.tgz"; - sha256 = "0pjb5268spiwq6b0cly8nfajr6rsh2wf6si646bzzjrxbgs51sxa"; - system = "cxml-rng"; - asd = "cxml-rng"; - }); - systems = [ "cxml-rng" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "cl-ppcre" self) (getAttr "cxml" self) (getAttr "parse-number" self) (getAttr "yacc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cxml-rpc = (build-asdf-system { - pname = "cxml-rpc"; - version = "20121013-git"; - asds = [ "cxml-rpc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cxml-rpc/2012-10-13/cxml-rpc-20121013-git.tgz"; - sha256 = "1ihd8rg0shy7nykqcbvvx5px7sw8wr1nwz70jdrh6ibq74yr8flh"; - system = "cxml-rpc"; - asd = "cxml-rpc"; - }); - systems = [ "cxml-rpc" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "cxml" self) (getAttr "drakma" self) (getAttr "hunchentoot" self) (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cxml-stp = (build-asdf-system { - pname = "cxml-stp"; - version = "20200325-git"; - asds = [ "cxml-stp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cxml-stp/2020-03-25/cxml-stp-20200325-git.tgz"; - sha256 = "01yfxxvb144i2mlp06fxx410mf3phxz5qaqvk90pp4dzdl883knv"; - system = "cxml-stp"; - asd = "cxml-stp"; - }); - systems = [ "cxml-stp" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cxml" self) (getAttr "xpath" self) ]; - meta = {}; - }); - cxml-test = (build-asdf-system { - pname = "cxml-test"; - version = "20200610-git"; - asds = [ "cxml-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cxml/2020-06-10/cxml-20200610-git.tgz"; - sha256 = "18fls3bx7vmnxfa6qara8fxp316d8kb3izar0kysvqg6l0a45a51"; - system = "cxml-test"; - asd = "cxml-test"; - }); - systems = [ "cxml-test" ]; - lispLibs = [ (getAttr "closure-common" self) (getAttr "puri" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cxx = (build-asdf-system { - pname = "cxx"; - version = "20230214-git"; - asds = [ "cxx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cxx/2023-02-14/cl-cxx-20230214-git.tgz"; - sha256 = "08jh7ajgfdr3cqla02c4d2y06y0imkky5d4mwnlph01nczzf85cy"; - system = "cxx"; - asd = "cxx"; - }); - systems = [ "cxx" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cxx-jit = (build-asdf-system { - pname = "cxx-jit"; - version = "20241012-git"; - asds = [ "cxx-jit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cxx-jit/2024-10-12/cl-cxx-jit-20241012-git.tgz"; - sha256 = "1xnhkhynikqs61s488jjzklbvwb46yxqx3zi98ifszj4r8ndi3ym"; - system = "cxx-jit"; - asd = "cxx-jit"; - }); - systems = [ "cxx-jit" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cxx-jit-test = (build-asdf-system { - pname = "cxx-jit-test"; - version = "20241012-git"; - asds = [ "cxx-jit-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cxx-jit/2024-10-12/cl-cxx-jit-20241012-git.tgz"; - sha256 = "1xnhkhynikqs61s488jjzklbvwb46yxqx3zi98ifszj4r8ndi3ym"; - system = "cxx-jit-test"; - asd = "cxx-jit-test"; - }); - systems = [ "cxx-jit-test" ]; - lispLibs = [ (getAttr "cxx-jit" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cxx-test = (build-asdf-system { - pname = "cxx-test"; - version = "20230214-git"; - asds = [ "cxx-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cxx/2023-02-14/cl-cxx-20230214-git.tgz"; - sha256 = "08jh7ajgfdr3cqla02c4d2y06y0imkky5d4mwnlph01nczzf85cy"; - system = "cxx-test"; - asd = "cxx-test"; - }); - systems = [ "cxx-test" ]; - lispLibs = [ (getAttr "cxx" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - cytoscape-clj = (build-asdf-system { - pname = "cytoscape-clj"; - version = "20241012-git"; - asds = [ "cytoscape-clj" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cytoscape-clj/2024-10-12/cytoscape-clj-20241012-git.tgz"; - sha256 = "0kyjgffm8nlvz75dbyz4fp1v8sr7j2bd7axxyn226s30gwzhihck"; - system = "cytoscape-clj"; - asd = "cytoscape-clj"; - }); - systems = [ "cytoscape-clj" ]; - lispLibs = [ (getAttr "common-lisp-jupyter" self) (getAttr "jupyter-lab-extension" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - daemon = (build-asdf-system { - pname = "daemon"; - version = "20170403-git"; - asds = [ "daemon" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/daemon/2017-04-03/daemon-20170403-git.tgz"; - sha256 = "1kdxfnhh9fz34j8qs7pn7mwjz3v33q4v9nh0hqkyzraq5xs2j3f4"; - system = "daemon"; - asd = "daemon"; - }); - systems = [ "daemon" ]; - lispLibs = [ (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - damn-fast-priority-queue = (build-asdf-system { - pname = "damn-fast-priority-queue"; - version = "20241012-git"; - asds = [ "damn-fast-priority-queue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/damn-fast-priority-queue/2024-10-12/damn-fast-priority-queue-20241012-git.tgz"; - sha256 = "1mbigpgi7qbqvpj59l1f7p2qcg00ybvqzdca1j1b9hx62h224ndw"; - system = "damn-fast-priority-queue"; - asd = "damn-fast-priority-queue"; - }); - systems = [ "damn-fast-priority-queue" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - damn-fast-stable-priority-queue = (build-asdf-system { - pname = "damn-fast-stable-priority-queue"; - version = "20241012-git"; - asds = [ "damn-fast-stable-priority-queue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/damn-fast-priority-queue/2024-10-12/damn-fast-priority-queue-20241012-git.tgz"; - sha256 = "1mbigpgi7qbqvpj59l1f7p2qcg00ybvqzdca1j1b9hx62h224ndw"; - system = "damn-fast-stable-priority-queue"; - asd = "damn-fast-stable-priority-queue"; - }); - systems = [ "damn-fast-stable-priority-queue" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - darts_dot_lib_dot_email-address = (build-asdf-system { - pname = "darts.lib.email-address"; - version = "quicklisp-release-48464635-git"; - asds = [ "darts.lib.email-address" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dartsclemailaddress/2016-04-21/dartsclemailaddress-quicklisp-release-48464635-git.tgz"; - sha256 = "15155nqi9q7ilaf14p4yi4iga8203rl7fn9v2iaxcfm18gsvqcjd"; - system = "darts.lib.email-address"; - asd = "darts.lib.email-address"; - }); - systems = [ "darts.lib.email-address" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - darts_dot_lib_dot_email-address-test = (build-asdf-system { - pname = "darts.lib.email-address-test"; - version = "quicklisp-release-48464635-git"; - asds = [ "darts.lib.email-address-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dartsclemailaddress/2016-04-21/dartsclemailaddress-quicklisp-release-48464635-git.tgz"; - sha256 = "15155nqi9q7ilaf14p4yi4iga8203rl7fn9v2iaxcfm18gsvqcjd"; - system = "darts.lib.email-address-test"; - asd = "darts.lib.email-address-test"; - }); - systems = [ "darts.lib.email-address-test" ]; - lispLibs = [ (getAttr "darts_dot_lib_dot_email-address" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - darts_dot_lib_dot_hashtree-test = (build-asdf-system { - pname = "darts.lib.hashtree-test"; - version = "20231021-git"; - asds = [ "darts.lib.hashtree-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dartsclhashtree/2023-10-21/dartsclhashtree-20231021-git.tgz"; - sha256 = "1kbxk7vnpv9zy6pm004cyyp9mbb4n845pfdv4wxngaj96ndi5v6j"; - system = "darts.lib.hashtree-test"; - asd = "darts.lib.hashtree-test"; - }); - systems = [ "darts.lib.hashtree-test" ]; - lispLibs = [ (getAttr "darts_dot_lib_dot_hashtrie" self) (getAttr "darts_dot_lib_dot_wbtree" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - darts_dot_lib_dot_hashtrie = (build-asdf-system { - pname = "darts.lib.hashtrie"; - version = "20231021-git"; - asds = [ "darts.lib.hashtrie" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dartsclhashtree/2023-10-21/dartsclhashtree-20231021-git.tgz"; - sha256 = "1kbxk7vnpv9zy6pm004cyyp9mbb4n845pfdv4wxngaj96ndi5v6j"; - system = "darts.lib.hashtrie"; - asd = "darts.lib.hashtrie"; - }); - systems = [ "darts.lib.hashtrie" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - darts_dot_lib_dot_message-pack = (build-asdf-system { - pname = "darts.lib.message-pack"; - version = "20200325-git"; - asds = [ "darts.lib.message-pack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dartsclmessagepack/2020-03-25/dartsclmessagepack-20200325-git.tgz"; - sha256 = "0i9jnvq6dp5zya1ijj3z7s10803jk8rb4nrjrzcgcfhkczd5si6y"; - system = "darts.lib.message-pack"; - asd = "darts.lib.message-pack"; - }); - systems = [ "darts.lib.message-pack" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "ieee-floats" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - darts_dot_lib_dot_message-pack-test = (build-asdf-system { - pname = "darts.lib.message-pack-test"; - version = "20200325-git"; - asds = [ "darts.lib.message-pack-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dartsclmessagepack/2020-03-25/dartsclmessagepack-20200325-git.tgz"; - sha256 = "0i9jnvq6dp5zya1ijj3z7s10803jk8rb4nrjrzcgcfhkczd5si6y"; - system = "darts.lib.message-pack-test"; - asd = "darts.lib.message-pack-test"; - }); - systems = [ "darts.lib.message-pack-test" ]; - lispLibs = [ (getAttr "darts_dot_lib_dot_message-pack" self) (getAttr "stefil" self) (getAttr "trivial-octet-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - darts_dot_lib_dot_sequence-metrics = (build-asdf-system { - pname = "darts.lib.sequence-metrics"; - version = "20130312-git"; - asds = [ "darts.lib.sequence-metrics" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dartsclsequencemetrics/2013-03-12/dartsclsequencemetrics-20130312-git.tgz"; - sha256 = "1x99gj5dfgiaraawx1nd157g5ajygfxz47cz8jgi1fh52fp1p969"; - system = "darts.lib.sequence-metrics"; - asd = "darts.lib.sequence-metrics"; - }); - systems = [ "darts.lib.sequence-metrics" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - darts_dot_lib_dot_tools = (build-asdf-system { - pname = "darts.lib.tools"; - version = "20201220-git"; - asds = [ "darts.lib.tools" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dartscltools/2020-12-20/dartscltools-20201220-git.tgz"; - sha256 = "0mbz7ak03qsw41fgybdw4mbibr656y9xl9bfgr2rmkdkgxbicys9"; - system = "darts.lib.tools"; - asd = "darts.lib.tools"; - }); - systems = [ "darts.lib.tools" ]; - lispLibs = [ (getAttr "atomics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - darts_dot_lib_dot_tools_dot_test = (build-asdf-system { - pname = "darts.lib.tools.test"; - version = "20201220-git"; - asds = [ "darts.lib.tools.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dartscltools/2020-12-20/dartscltools-20201220-git.tgz"; - sha256 = "0mbz7ak03qsw41fgybdw4mbibr656y9xl9bfgr2rmkdkgxbicys9"; - system = "darts.lib.tools.test"; - asd = "darts.lib.tools.test"; - }); - systems = [ "darts.lib.tools.test" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "darts_dot_lib_dot_tools" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - darts_dot_lib_dot_uuid = (build-asdf-system { - pname = "darts.lib.uuid"; - version = "20241012-git"; - asds = [ "darts.lib.uuid" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dartscluuid/2024-10-12/dartscluuid-20241012-git.tgz"; - sha256 = "17i2icz6k6vb5mp95rsjr8ldzhjjlcn7dyylvxjrccbxbrblnnsl"; - system = "darts.lib.uuid"; - asd = "darts.lib.uuid"; - }); - systems = [ "darts.lib.uuid" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "ironclad" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - darts_dot_lib_dot_uuid-test = (build-asdf-system { - pname = "darts.lib.uuid-test"; - version = "20241012-git"; - asds = [ "darts.lib.uuid-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dartscluuid/2024-10-12/dartscluuid-20241012-git.tgz"; - sha256 = "17i2icz6k6vb5mp95rsjr8ldzhjjlcn7dyylvxjrccbxbrblnnsl"; - system = "darts.lib.uuid-test"; - asd = "darts.lib.uuid-test"; - }); - systems = [ "darts.lib.uuid-test" ]; - lispLibs = [ (getAttr "darts_dot_lib_dot_uuid" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - darts_dot_lib_dot_wbtree = (build-asdf-system { - pname = "darts.lib.wbtree"; - version = "20231021-git"; - asds = [ "darts.lib.wbtree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dartsclhashtree/2023-10-21/dartsclhashtree-20231021-git.tgz"; - sha256 = "1kbxk7vnpv9zy6pm004cyyp9mbb4n845pfdv4wxngaj96ndi5v6j"; - system = "darts.lib.wbtree"; - asd = "darts.lib.wbtree"; - }); - systems = [ "darts.lib.wbtree" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - data-format-validation = (build-asdf-system { - pname = "data-format-validation"; - version = "20140713-git"; - asds = [ "data-format-validation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-data-format-validation/2014-07-13/cl-data-format-validation-20140713-git.tgz"; - sha256 = "0zmk47xmicyqvp1impn8kgh5373ysmx3gfpqcvbi9r31qsir2nqa"; - system = "data-format-validation"; - asd = "data-format-validation"; - }); - systems = [ "data-format-validation" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - data-frame = (build-asdf-system { - pname = "data-frame"; - version = "20241012-git"; - asds = [ "data-frame" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/data-frame/2024-10-12/data-frame-20241012-git.tgz"; - sha256 = "1sqyvb6hscz070d5ap5v5yvql4nx69c7jkp29za5dj84rsvbckcp"; - system = "data-frame"; - asd = "data-frame"; - }); - systems = [ "data-frame" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "alexandria_plus" self) (getAttr "anaphora" self) (getAttr "array-operations" self) (getAttr "duologue" self) (getAttr "let-plus" self) (getAttr "num-utils" self) (getAttr "select" self) (getAttr "statistics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - data-lens = (build-asdf-system { - pname = "data-lens"; - version = "20241012-git"; - asds = [ "data-lens" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/data-lens/2024-10-12/data-lens-20241012-git.tgz"; - sha256 = "1bark9r3br5ndcbkiagq891gn82xdiy8hrgzp72656yyadsrid5i"; - system = "data-lens"; - asd = "data-lens"; - }); - systems = [ "data-lens" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - data-lens_plus_fset = (build-asdf-system { - pname = "data-lens+fset"; - version = "20241012-git"; - asds = [ "data-lens+fset" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/data-lens/2024-10-12/data-lens-20241012-git.tgz"; - sha256 = "1bark9r3br5ndcbkiagq891gn82xdiy8hrgzp72656yyadsrid5i"; - system = "data-lens+fset"; - asd = "data-lens+fset"; - }); - systems = [ "data-lens+fset" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "data-lens" self) (getAttr "fset" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - data-sift = (build-asdf-system { - pname = "data-sift"; - version = "20130128-git"; - asds = [ "data-sift" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/data-sift/2013-01-28/data-sift-20130128-git.tgz"; - sha256 = "1v7gf0x4ibjzp0c56n9m77hxdgwcm9356zlk5n4l3fx4i0hj6146"; - system = "data-sift"; - asd = "data-sift"; - }); - systems = [ "data-sift" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "parse-number" self) (getAttr "puri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - data-sift-test = (build-asdf-system { - pname = "data-sift-test"; - version = "20130128-git"; - asds = [ "data-sift-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/data-sift/2013-01-28/data-sift-20130128-git.tgz"; - sha256 = "1v7gf0x4ibjzp0c56n9m77hxdgwcm9356zlk5n4l3fx4i0hj6146"; - system = "data-sift-test"; - asd = "data-sift"; - }); - systems = [ "data-sift-test" ]; - lispLibs = [ (getAttr "data-sift" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - data-table = (build-asdf-system { - pname = "data-table"; - version = "20231021-git"; - asds = [ "data-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/data-table/2023-10-21/data-table-20231021-git.tgz"; - sha256 = "1x64s3r2p28wgx7ffm205i90am2azfqkl6zlkrnjhppp82xan8yd"; - system = "data-table"; - asd = "data-table"; - }); - systems = [ "data-table" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-interpol" self) (getAttr "iterate" self) (getAttr "symbol-munger" self) ]; - meta = {}; - }); - data-table-clsql = (build-asdf-system { - pname = "data-table-clsql"; - version = "20231021-git"; - asds = [ "data-table-clsql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/data-table/2023-10-21/data-table-20231021-git.tgz"; - sha256 = "1x64s3r2p28wgx7ffm205i90am2azfqkl6zlkrnjhppp82xan8yd"; - system = "data-table-clsql"; - asd = "data-table-clsql"; - }); - systems = [ "data-table-clsql" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "clsql-helper" self) (getAttr "collectors" self) (getAttr "data-table" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - data-table-test = (build-asdf-system { - pname = "data-table-test"; - version = "20231021-git"; - asds = [ "data-table-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/data-table/2023-10-21/data-table-20231021-git.tgz"; - sha256 = "1x64s3r2p28wgx7ffm205i90am2azfqkl6zlkrnjhppp82xan8yd"; - system = "data-table-test"; - asd = "data-table"; - }); - systems = [ "data-table-test" ]; - lispLibs = [ (getAttr "data-table" self) (getAttr "lisp-unit2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - database-migrations = (build-asdf-system { - pname = "database-migrations"; - version = "20230214-git"; - asds = [ "database-migrations" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/database-migrations/2023-02-14/database-migrations-20230214-git.tgz"; - sha256 = "1mm5adjhqy0djr8fxpdsamc2ry2x5krc9w0s5nnfvyc4yqs0bwaa"; - system = "database-migrations"; - asd = "database-migrations"; - }); - systems = [ "database-migrations" ]; - lispLibs = [ (getAttr "postmodern" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - datafly = (build-asdf-system { - pname = "datafly"; - version = "20241012-git"; - asds = [ "datafly" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/datafly/2024-10-12/datafly-20241012-git.tgz"; - sha256 = "103zp5s778lys4lsn7hvyis65757338n0l9gzl595qfim4apx8g0"; - system = "datafly"; - asd = "datafly"; - }); - systems = [ "datafly" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "closer-mop" self) (getAttr "dbi" self) (getAttr "function-cache" self) (getAttr "iterate" self) (getAttr "jonathan" self) (getAttr "kebab" self) (getAttr "local-time" self) (getAttr "log4cl" self) (getAttr "named-readtables" self) (getAttr "optima" self) (getAttr "sxql" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - datafly-test = (build-asdf-system { - pname = "datafly-test"; - version = "20241012-git"; - asds = [ "datafly-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/datafly/2024-10-12/datafly-20241012-git.tgz"; - sha256 = "103zp5s778lys4lsn7hvyis65757338n0l9gzl595qfim4apx8g0"; - system = "datafly-test"; - asd = "datafly-test"; - }); - systems = [ "datafly-test" ]; - lispLibs = [ (getAttr "datafly" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "sxql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dataloader = (build-asdf-system { - pname = "dataloader"; - version = "20210531-git"; - asds = [ "dataloader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dataloader/2021-05-31/dataloader-20210531-git.tgz"; - sha256 = "1a7nap2yp0jjd9r3xpkj0a6z0m3gshz73abm8kfza4kf31ipzyik"; - system = "dataloader"; - asd = "dataloader"; - }); - systems = [ "dataloader" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-csv" self) (getAttr "cl-jpeg" self) (getAttr "cl-wav" self) (getAttr "iterate" self) (getAttr "magicffi" self) (getAttr "numcl" self) (getAttr "numpy-file-format" self) (getAttr "png" self) (getAttr "retrospectiff" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dataloader_dot_test = (build-asdf-system { - pname = "dataloader.test"; - version = "20210531-git"; - asds = [ "dataloader.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dataloader/2021-05-31/dataloader-20210531-git.tgz"; - sha256 = "1a7nap2yp0jjd9r3xpkj0a6z0m3gshz73abm8kfza4kf31ipzyik"; - system = "dataloader.test"; - asd = "dataloader.test"; - }); - systems = [ "dataloader.test" ]; - lispLibs = [ (getAttr "dataloader" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - datamuse = (build-asdf-system { - pname = "datamuse"; - version = "20231021-git"; - asds = [ "datamuse" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/datamuse/2023-10-21/datamuse-20231021-git.tgz"; - sha256 = "18mminvwv6wql6qh9kxxkhjfbxfz37gr125wy9h6za83vn1rkpwc"; - system = "datamuse"; - asd = "datamuse"; - }); - systems = [ "datamuse" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "drakma" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - date-calc = (build-asdf-system { - pname = "date-calc"; - version = "20191227-git"; - asds = [ "date-calc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/date-calc/2019-12-27/date-calc-20191227-git.tgz"; - sha256 = "09wmjp3ypxigcmx4mvc0yjnj56wkjjchhssdmklbaswy5mi7xc9s"; - system = "date-calc"; - asd = "date-calc"; - }); - systems = [ "date-calc" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - datum-comments = (build-asdf-system { - pname = "datum-comments"; - version = "20210228-git"; - asds = [ "datum-comments" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/datum-comments/2021-02-28/datum-comments-20210228-git.tgz"; - sha256 = "07zzlhphcmwimp4pjckhnbjbn127lcpafi7j0l74137dz9pimjik"; - system = "datum-comments"; - asd = "datum-comments"; - }); - systems = [ "datum-comments" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - db3 = (build-asdf-system { - pname = "db3"; - version = "20200218-git"; - asds = [ "db3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-db3/2020-02-18/cl-db3-20200218-git.tgz"; - sha256 = "1i7j0mlri6kbklcx1lsm464s8kmyhhij5c4xh4aybrw8m4ixn1s5"; - system = "db3"; - asd = "db3"; - }); - systems = [ "db3" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dbd-mysql = (build-asdf-system { - pname = "dbd-mysql"; - version = "20241012-git"; - asds = [ "dbd-mysql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dbi/2024-10-12/cl-dbi-20241012-git.tgz"; - sha256 = "17szd6sz1hlwl5fm4qjgyd8ax01wkbhv8hxcyy8qscx39sc0cnpy"; - system = "dbd-mysql"; - asd = "dbd-mysql"; - }); - systems = [ "dbd-mysql" ]; - lispLibs = [ (getAttr "cl-mysql" self) (getAttr "dbi" self) ]; - meta = {}; - }); - dbd-postgres = (build-asdf-system { - pname = "dbd-postgres"; - version = "20241012-git"; - asds = [ "dbd-postgres" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dbi/2024-10-12/cl-dbi-20241012-git.tgz"; - sha256 = "17szd6sz1hlwl5fm4qjgyd8ax01wkbhv8hxcyy8qscx39sc0cnpy"; - system = "dbd-postgres"; - asd = "dbd-postgres"; - }); - systems = [ "dbd-postgres" ]; - lispLibs = [ (getAttr "cl-postgres" self) (getAttr "dbi" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - dbd-sqlite3 = (build-asdf-system { - pname = "dbd-sqlite3"; - version = "20241012-git"; - asds = [ "dbd-sqlite3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dbi/2024-10-12/cl-dbi-20241012-git.tgz"; - sha256 = "17szd6sz1hlwl5fm4qjgyd8ax01wkbhv8hxcyy8qscx39sc0cnpy"; - system = "dbd-sqlite3"; - asd = "dbd-sqlite3"; - }); - systems = [ "dbd-sqlite3" ]; - lispLibs = [ (getAttr "dbi" self) (getAttr "sqlite" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - dbi = (build-asdf-system { - pname = "dbi"; - version = "20241012-git"; - asds = [ "dbi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dbi/2024-10-12/cl-dbi-20241012-git.tgz"; - sha256 = "17szd6sz1hlwl5fm4qjgyd8ax01wkbhv8hxcyy8qscx39sc0cnpy"; - system = "dbi"; - asd = "dbi"; - }); - systems = [ "dbi" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "split-sequence" self) ]; - meta = {}; - }); - dbi-test = (build-asdf-system { - pname = "dbi-test"; - version = "20241012-git"; - asds = [ "dbi-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dbi/2024-10-12/cl-dbi-20241012-git.tgz"; - sha256 = "17szd6sz1hlwl5fm4qjgyd8ax01wkbhv8hxcyy8qscx39sc0cnpy"; - system = "dbi-test"; - asd = "dbi-test"; - }); - systems = [ "dbi-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "dbi" self) (getAttr "rove" self) (getAttr "trivial-types" self) ]; - meta = {}; - }); - dbus = (build-asdf-system { - pname = "dbus"; - version = "20241012-git"; - asds = [ "dbus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dbus/2024-10-12/dbus-20241012-git.tgz"; - sha256 = "1y880074m9g0swxrzpbplmkdxc6r62gzyigglf4x2i0zyss3gf65"; - system = "dbus"; - asd = "dbus"; - }); - systems = [ "dbus" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "asdf-package-system" self) (getAttr "babel" self) (getAttr "cl-xmlspam" self) (getAttr "cxml" self) (getAttr "flexi-streams" self) (getAttr "ieee-floats" self) (getAttr "iolib" self) (getAttr "ironclad" self) (getAttr "split-sequence" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - dct = (build-asdf-system { - pname = "dct"; - version = "20220331-git"; - asds = [ "dct" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dct/2022-03-31/cl-dct-20220331-git.tgz"; - sha256 = "1rzq4vdhvr454668a3xf56mha061d27ymsgawmxikgk86wi8biin"; - system = "dct"; - asd = "dct"; - }); - systems = [ "dct" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dct-test = (build-asdf-system { - pname = "dct-test"; - version = "20220331-git"; - asds = [ "dct-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-dct/2022-03-31/cl-dct-20220331-git.tgz"; - sha256 = "1rzq4vdhvr454668a3xf56mha061d27ymsgawmxikgk86wi8biin"; - system = "dct-test"; - asd = "dct-test"; - }); - systems = [ "dct-test" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-coveralls" self) (getAttr "dct" self) (getAttr "lisp-unit" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ddo = (build-asdf-system { - pname = "ddo"; - version = "20210411-git"; - asds = [ "ddo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; - sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; - system = "ddo"; - asd = "ddo"; - }); - systems = [ "ddo" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-mpi" self) (getAttr "cl-mpi-extensions" self) (getAttr "femlisp-basic" self) (getAttr "femlisp-dictionary" self) (getAttr "femlisp-parallel" self) (getAttr "lfarm-admin" self) (getAttr "lfarm-client" self) (getAttr "lfarm-server" self) (getAttr "trees" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - de-mock-racy = (build-asdf-system { - pname = "de-mock-racy"; - version = "20221106-git"; - asds = [ "de-mock-racy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/de-mock-racy/2022-11-06/de-mock-racy-20221106-git.tgz"; - sha256 = "02rkg1i5r8fgyhaipb0mkz543c8r81kqmwmmvywnnw8hpyvav2xb"; - system = "de-mock-racy"; - asd = "de-mock-racy"; - }); - systems = [ "de-mock-racy" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dealii-tutorial = (build-asdf-system { - pname = "dealii-tutorial"; - version = "20210411-git"; - asds = [ "dealii-tutorial" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; - sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; - system = "dealii-tutorial"; - asd = "dealii-tutorial"; - }); - systems = [ "dealii-tutorial" ]; - lispLibs = [ (getAttr "femlisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - decimals = (build-asdf-system { - pname = "decimals"; - version = "20211209-git"; - asds = [ "decimals" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-decimals/2021-12-09/cl-decimals-20211209-git.tgz"; - sha256 = "0wn5hq1pwd3wpjqqhpjzarcdk1q6416g8y447iaf55j5nbhlmbn6"; - system = "decimals"; - asd = "decimals"; - }); - systems = [ "decimals" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deeds = (build-asdf-system { - pname = "deeds"; - version = "20231021-git"; - asds = [ "deeds" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deeds/2023-10-21/deeds-20231021-git.tgz"; - sha256 = "0pd178wydg2zld8pvfm7ss5qvbjh4g8klqbhx2k7h68hn2q1xnn8"; - system = "deeds"; - asd = "deeds"; - }); - systems = [ "deeds" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "form-fiddle" self) (getAttr "lambda-fiddle" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - def-properties = (build-asdf-system { - pname = "def-properties"; - version = "20230618-git"; - asds = [ "def-properties" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-def-properties/2023-06-18/cl-def-properties-20230618-git.tgz"; - sha256 = "0yvii6llhmjv1k7hli6waj1bprj8fqhncgnk8mdlg08wwa27a2j8"; - system = "def-properties"; - asd = "def-properties"; - }); - systems = [ "def-properties" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defclass-std = (build-asdf-system { - pname = "defclass-std"; - version = "20201220-git"; - asds = [ "defclass-std" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defclass-std/2020-12-20/defclass-std-20201220-git.tgz"; - sha256 = "1c0ymb49wd205lzxmnmsrpqyv0pn61snn2xvsbk5iis135r4fr18"; - system = "defclass-std"; - asd = "defclass-std"; - }); - systems = [ "defclass-std" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) ]; - meta = {}; - }); - defclass-std-test = (build-asdf-system { - pname = "defclass-std-test"; - version = "20201220-git"; - asds = [ "defclass-std-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defclass-std/2020-12-20/defclass-std-20201220-git.tgz"; - sha256 = "1c0ymb49wd205lzxmnmsrpqyv0pn61snn2xvsbk5iis135r4fr18"; - system = "defclass-std-test"; - asd = "defclass-std-test"; - }); - systems = [ "defclass-std-test" ]; - lispLibs = [ (getAttr "defclass-std" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defconfig = (build-asdf-system { - pname = "defconfig"; - version = "20211209-git"; - asds = [ "defconfig" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defconfig/2021-12-09/defconfig-20211209-git.tgz"; - sha256 = "1gvgni43fxknj800k2k7jhgayzqqqp3s321sw4qmsjxpv479hcqy"; - system = "defconfig"; - asd = "defconfig"; - }); - systems = [ "defconfig" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-cltl2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defenum = (build-asdf-system { - pname = "defenum"; - version = "20241012-git"; - asds = [ "defenum" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defenum/2024-10-12/defenum-20241012-git.tgz"; - sha256 = "1856w0vsjj9fcyqrry5k4b2iv87xms5wlw8xbqawjax6w5hdsrhk"; - system = "defenum"; - asd = "defenum"; - }); - systems = [ "defenum" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deferred = (build-asdf-system { - pname = "deferred"; - version = "20231021-git"; - asds = [ "deferred" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deferred/2023-10-21/deferred-20231021-git.tgz"; - sha256 = "0npsxxapah8c3sxmfmi0djvw5kw5pj03dk5ia4yh3q2v7mwzpqy2"; - system = "deferred"; - asd = "deferred"; - }); - systems = [ "deferred" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - define-json-expander = (build-asdf-system { - pname = "define-json-expander"; - version = "20140713-git"; - asds = [ "define-json-expander" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/define-json-expander/2014-07-13/define-json-expander-20140713-git.tgz"; - sha256 = "193mhjcy1qnfd7r7zia3qs8p7gllvq6s0b2wcqmkh0y17aw8brkh"; - system = "define-json-expander"; - asd = "define-json-expander"; - }); - systems = [ "define-json-expander" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - definer = (build-asdf-system { - pname = "definer"; - version = "20241012-git"; - asds = [ "definer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/definer/2024-10-12/definer-20241012-git.tgz"; - sha256 = "0vd7gcj55pdzgxq2309pxshplg3rjx95xikkc2ylqrcm9nf3d2zb"; - system = "definer"; - asd = "definer"; - }); - systems = [ "definer" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - definitions = (build-asdf-system { - pname = "definitions"; - version = "20241012-git"; - asds = [ "definitions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/definitions/2024-10-12/definitions-20241012-git.tgz"; - sha256 = "16wg9rzxc193qvhzay69czr19wzy16b53vm1gy6p25gqvz90zryd"; - system = "definitions"; - asd = "definitions"; - }); - systems = [ "definitions" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - definitions-systems = (build-asdf-system { - pname = "definitions-systems"; - version = "3.0"; - asds = [ "definitions-systems" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/definitions-systems/2023-06-18/definitions-systems_3.0.tgz"; - sha256 = "0wly8hr9gfxhdz4l46xsh4vj99q9aq7p3cfsglbgv19kdsvv217r"; - system = "definitions-systems"; - asd = "definitions-systems"; - }); - systems = [ "definitions-systems" ]; - lispLibs = [ (getAttr "canonicalized-initargs" self) (getAttr "closer-mop" self) (getAttr "enhanced-defclass" self) (getAttr "enhanced-find-class" self) (getAttr "shared-preferences" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - definitions-systems__tests = (build-asdf-system { - pname = "definitions-systems_tests"; - version = "3.0"; - asds = [ "definitions-systems_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/definitions-systems/2023-06-18/definitions-systems_3.0.tgz"; - sha256 = "0wly8hr9gfxhdz4l46xsh4vj99q9aq7p3cfsglbgv19kdsvv217r"; - system = "definitions-systems_tests"; - asd = "definitions-systems_tests"; - }); - systems = [ "definitions-systems_tests" ]; - lispLibs = [ (getAttr "definitions-systems" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deflate = (build-asdf-system { - pname = "deflate"; - version = "20241012-git"; - asds = [ "deflate" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deflate/2024-10-12/deflate-20241012-git.tgz"; - sha256 = "1b225rgc3b2b2k941aj8mz4fkyysi0my368r042wzykq28lwwwij"; - system = "deflate"; - asd = "deflate"; - }); - systems = [ "deflate" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deflazy = (build-asdf-system { - pname = "deflazy"; - version = "20200427-git"; - asds = [ "deflazy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "deflazy"; - asd = "deflazy"; - }); - systems = [ "deflazy" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "uncommon-lisp" self) (getAttr "utility" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defmain = (build-asdf-system { - pname = "defmain"; - version = "20241012-git"; - asds = [ "defmain" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defmain/2024-10-12/defmain-20241012-git.tgz"; - sha256 = "0lb45xmpan188vcysc7d579gg1mc7qi3xyyqc6mqr49571zshzb1"; - system = "defmain"; - asd = "defmain"; - }); - systems = [ "defmain" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "alexandria" self) (getAttr "cl-inflector" self) (getAttr "cl-strings" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "net_dot_didierverna_dot_clon_dot_core" self) (getAttr "pythonic-string-reader" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defmain-test = (build-asdf-system { - pname = "defmain-test"; - version = "20241012-git"; - asds = [ "defmain-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defmain/2024-10-12/defmain-20241012-git.tgz"; - sha256 = "0lb45xmpan188vcysc7d579gg1mc7qi3xyyqc6mqr49571zshzb1"; - system = "defmain-test"; - asd = "defmain-test"; - }); - systems = [ "defmain-test" ]; - lispLibs = [ (getAttr "defmain" self) (getAttr "hamcrest" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defmemo = (build-asdf-system { - pname = "defmemo"; - version = "20120407-git"; - asds = [ "defmemo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defmemo/2012-04-07/defmemo-20120407-git.tgz"; - sha256 = "0rkvnjfb6fajzfzislz6z372bqpkj6wfbf0sxmzhhigni4wnil27"; - system = "defmemo"; - asd = "defmemo"; - }); - systems = [ "defmemo" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defmemo-test = (build-asdf-system { - pname = "defmemo-test"; - version = "20120407-git"; - asds = [ "defmemo-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defmemo/2012-04-07/defmemo-20120407-git.tgz"; - sha256 = "0rkvnjfb6fajzfzislz6z372bqpkj6wfbf0sxmzhhigni4wnil27"; - system = "defmemo-test"; - asd = "defmemo"; - }); - systems = [ "defmemo-test" ]; - lispLibs = [ (getAttr "defmemo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defpackage-plus = (build-asdf-system { - pname = "defpackage-plus"; - version = "20180131-git"; - asds = [ "defpackage-plus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defpackage-plus/2018-01-31/defpackage-plus-20180131-git.tgz"; - sha256 = "0lzljvf343xb6mlh6lni2i27hpm5qd376522mk6hr2pa20vd6rdq"; - system = "defpackage-plus"; - asd = "defpackage-plus"; - }); - systems = [ "defpackage-plus" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defrec = (build-asdf-system { - pname = "defrec"; - version = "20230618-git"; - asds = [ "defrec" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defrec/2023-06-18/defrec-20230618-git.tgz"; - sha256 = "04wd43z2k5cv4a55x532y3aqc7gf1ksndvndvy0y6bslxqqgv63m"; - system = "defrec"; - asd = "defrec"; - }); - systems = [ "defrec" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defrest = (build-asdf-system { - pname = "defrest"; - version = "20210531-git"; - asds = [ "defrest" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defrest/2021-05-31/defrest-20210531-git.tgz"; - sha256 = "14pap344a0549mb7p79jf87ibfxmymk0hf9i7galcfi4s8nqq45g"; - system = "defrest"; - asd = "defrest"; - }); - systems = [ "defrest" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "hunchentoot" self) (getAttr "quri" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defrest_dot_test = (build-asdf-system { - pname = "defrest.test"; - version = "20210531-git"; - asds = [ "defrest.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defrest/2021-05-31/defrest-20210531-git.tgz"; - sha256 = "14pap344a0549mb7p79jf87ibfxmymk0hf9i7galcfi4s8nqq45g"; - system = "defrest.test"; - asd = "defrest"; - }); - systems = [ "defrest.test" ]; - lispLibs = [ (getAttr "defrest" self) (getAttr "drakma" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defstar = (build-asdf-system { - pname = "defstar"; - version = "20140713-git"; - asds = [ "defstar" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defstar/2014-07-13/defstar-20140713-git.tgz"; - sha256 = "0n6m3aqvdfnsrhlhqjcy72d1i55lbkjg13ij5c7vw003p1n78wxi"; - system = "defstar"; - asd = "defstar"; - }); - systems = [ "defstar" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defsystem-compatibility = (build-asdf-system { - pname = "defsystem-compatibility"; - version = "20101006-darcs"; - asds = [ "defsystem-compatibility" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defsystem-compatibility/2010-10-06/defsystem-compatibility-20101006-darcs.tgz"; - sha256 = "0bw0c69zyika19rvzl8xplwrqsgznhnlbj40fcszfw0vxh2czj0f"; - system = "defsystem-compatibility"; - asd = "defsystem-compatibility"; - }); - systems = [ "defsystem-compatibility" ]; - lispLibs = [ (getAttr "metatilities-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defsystem-compatibility-test = (build-asdf-system { - pname = "defsystem-compatibility-test"; - version = "20101006-darcs"; - asds = [ "defsystem-compatibility-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defsystem-compatibility/2010-10-06/defsystem-compatibility-20101006-darcs.tgz"; - sha256 = "0bw0c69zyika19rvzl8xplwrqsgznhnlbj40fcszfw0vxh2czj0f"; - system = "defsystem-compatibility-test"; - asd = "defsystem-compatibility-test"; - }); - systems = [ "defsystem-compatibility-test" ]; - lispLibs = [ (getAttr "defsystem-compatibility" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - defvariant = (build-asdf-system { - pname = "defvariant"; - version = "20140713-git"; - asds = [ "defvariant" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/defvariant/2014-07-13/defvariant-20140713-git.tgz"; - sha256 = "0rma557l2irjyzrswcd7329iic2pjxw0jgk3m2inag39l6wyqsr1"; - system = "defvariant"; - asd = "defvariant"; - }); - systems = [ "defvariant" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - delorean = (build-asdf-system { - pname = "delorean"; - version = "20130615-git"; - asds = [ "delorean" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/delorean/2013-06-15/delorean-20130615-git.tgz"; - sha256 = "0q11wqdlvis91i996mar72icw07yf7mwmsnlmsbsya9kaqj7n3cd"; - system = "delorean"; - asd = "delorean"; - }); - systems = [ "delorean" ]; - lispLibs = [ (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - delorean-test = (build-asdf-system { - pname = "delorean-test"; - version = "20130615-git"; - asds = [ "delorean-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/delorean/2013-06-15/delorean-20130615-git.tgz"; - sha256 = "0q11wqdlvis91i996mar72icw07yf7mwmsnlmsbsya9kaqj7n3cd"; - system = "delorean-test"; - asd = "delorean"; - }); - systems = [ "delorean-test" ]; - lispLibs = [ (getAttr "delorean" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - delta-debug = (build-asdf-system { - pname = "delta-debug"; - version = "20180831-git"; - asds = [ "delta-debug" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/delta-debug/2018-08-31/delta-debug-20180831-git.tgz"; - sha256 = "0dm33v8ipkpr23mjb9s6z2c7gmxwjbd5khc7c1vangba18nzm7ir"; - system = "delta-debug"; - asd = "delta-debug"; - }); - systems = [ "delta-debug" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "curry-compose-reader-macros" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dendrite = (build-asdf-system { - pname = "dendrite"; - version = "release-quicklisp-409b1061-git"; - asds = [ "dendrite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dendrite/2017-10-23/dendrite-release-quicklisp-409b1061-git.tgz"; - sha256 = "1fsi77w2yamis2707f1hx09pmyjaxqpzl8s0h182vpz159lkxdy5"; - system = "dendrite"; - asd = "dendrite"; - }); - systems = [ "dendrite" ]; - lispLibs = [ (getAttr "dendrite_dot_micro-l-system" self) (getAttr "dendrite_dot_primitives" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dendrite_dot_micro-l-system = (build-asdf-system { - pname = "dendrite.micro-l-system"; - version = "release-quicklisp-409b1061-git"; - asds = [ "dendrite.micro-l-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dendrite/2017-10-23/dendrite-release-quicklisp-409b1061-git.tgz"; - sha256 = "1fsi77w2yamis2707f1hx09pmyjaxqpzl8s0h182vpz159lkxdy5"; - system = "dendrite.micro-l-system"; - asd = "dendrite.micro-l-system"; - }); - systems = [ "dendrite.micro-l-system" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dendrite_dot_primitives = (build-asdf-system { - pname = "dendrite.primitives"; - version = "release-quicklisp-409b1061-git"; - asds = [ "dendrite.primitives" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dendrite/2017-10-23/dendrite-release-quicklisp-409b1061-git.tgz"; - sha256 = "1fsi77w2yamis2707f1hx09pmyjaxqpzl8s0h182vpz159lkxdy5"; - system = "dendrite.primitives"; - asd = "dendrite.primitives"; - }); - systems = [ "dendrite.primitives" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "rtg-math" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deoxybyte-gzip = (build-asdf-system { - pname = "deoxybyte-gzip"; - version = "20140113-git"; - asds = [ "deoxybyte-gzip" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deoxybyte-gzip/2014-01-13/deoxybyte-gzip-20140113-git.tgz"; - sha256 = "0ccci902nxqhdlskw3pghcjg0vgl10xlh16cb5b631j3n2ajfa16"; - system = "deoxybyte-gzip"; - asd = "deoxybyte-gzip"; - }); - systems = [ "deoxybyte-gzip" ]; - lispLibs = [ (getAttr "deoxybyte-io" self) (getAttr "deoxybyte-systems" self) (getAttr "deoxybyte-unix" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deoxybyte-gzip-test = (build-asdf-system { - pname = "deoxybyte-gzip-test"; - version = "20140113-git"; - asds = [ "deoxybyte-gzip-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deoxybyte-gzip/2014-01-13/deoxybyte-gzip-20140113-git.tgz"; - sha256 = "0ccci902nxqhdlskw3pghcjg0vgl10xlh16cb5b631j3n2ajfa16"; - system = "deoxybyte-gzip-test"; - asd = "deoxybyte-gzip-test"; - }); - systems = [ "deoxybyte-gzip-test" ]; - lispLibs = [ (getAttr "deoxybyte-gzip" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deoxybyte-io = (build-asdf-system { - pname = "deoxybyte-io"; - version = "20140113-git"; - asds = [ "deoxybyte-io" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deoxybyte-io/2014-01-13/deoxybyte-io-20140113-git.tgz"; - sha256 = "0pjx96g50yqhdk0l1y970hc22fc1bl8ppyklhp62l41b4fb7hbbv"; - system = "deoxybyte-io"; - asd = "deoxybyte-io"; - }); - systems = [ "deoxybyte-io" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "deoxybyte-systems" self) (getAttr "deoxybyte-utilities" self) (getAttr "getopt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deoxybyte-io-test = (build-asdf-system { - pname = "deoxybyte-io-test"; - version = "20140113-git"; - asds = [ "deoxybyte-io-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deoxybyte-io/2014-01-13/deoxybyte-io-20140113-git.tgz"; - sha256 = "0pjx96g50yqhdk0l1y970hc22fc1bl8ppyklhp62l41b4fb7hbbv"; - system = "deoxybyte-io-test"; - asd = "deoxybyte-io-test"; - }); - systems = [ "deoxybyte-io-test" ]; - lispLibs = [ (getAttr "deoxybyte-io" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deoxybyte-systems = (build-asdf-system { - pname = "deoxybyte-systems"; - version = "20140113-git"; - asds = [ "deoxybyte-systems" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deoxybyte-systems/2014-01-13/deoxybyte-systems-20140113-git.tgz"; - sha256 = "0sbzl0ngz85mvkghcy8y94hk34v5hvi41b111mb76f2jvdq9jjr8"; - system = "deoxybyte-systems"; - asd = "deoxybyte-systems"; - }); - systems = [ "deoxybyte-systems" ]; - lispLibs = [ (getAttr "cl-fad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deoxybyte-unix = (build-asdf-system { - pname = "deoxybyte-unix"; - version = "20140113-git"; - asds = [ "deoxybyte-unix" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deoxybyte-unix/2014-01-13/deoxybyte-unix-20140113-git.tgz"; - sha256 = "016lgb8vcnn7qwhndan1d61wbb10xmsczqp7h2kkfnhlvkr484qf"; - system = "deoxybyte-unix"; - asd = "deoxybyte-unix"; - }); - systems = [ "deoxybyte-unix" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "deoxybyte-io" self) (getAttr "deoxybyte-systems" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deoxybyte-unix-test = (build-asdf-system { - pname = "deoxybyte-unix-test"; - version = "20140113-git"; - asds = [ "deoxybyte-unix-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deoxybyte-unix/2014-01-13/deoxybyte-unix-20140113-git.tgz"; - sha256 = "016lgb8vcnn7qwhndan1d61wbb10xmsczqp7h2kkfnhlvkr484qf"; - system = "deoxybyte-unix-test"; - asd = "deoxybyte-unix-test"; - }); - systems = [ "deoxybyte-unix-test" ]; - lispLibs = [ (getAttr "deoxybyte-unix" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deoxybyte-utilities = (build-asdf-system { - pname = "deoxybyte-utilities"; - version = "20140113-git"; - asds = [ "deoxybyte-utilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deoxybyte-utilities/2014-01-13/deoxybyte-utilities-20140113-git.tgz"; - sha256 = "054mvn27d9xdsal87avyxzphgv6pk96a0c1icpkldqczlmzl9j0g"; - system = "deoxybyte-utilities"; - asd = "deoxybyte-utilities"; - }); - systems = [ "deoxybyte-utilities" ]; - lispLibs = [ (getAttr "deoxybyte-systems" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deoxybyte-utilities-test = (build-asdf-system { - pname = "deoxybyte-utilities-test"; - version = "20140113-git"; - asds = [ "deoxybyte-utilities-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deoxybyte-utilities/2014-01-13/deoxybyte-utilities-20140113-git.tgz"; - sha256 = "054mvn27d9xdsal87avyxzphgv6pk96a0c1icpkldqczlmzl9j0g"; - system = "deoxybyte-utilities-test"; - asd = "deoxybyte-utilities-test"; - }); - systems = [ "deoxybyte-utilities-test" ]; - lispLibs = [ (getAttr "deoxybyte-utilities" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deploy = (build-asdf-system { - pname = "deploy"; - version = "20241012-git"; - asds = [ "deploy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deploy/2024-10-12/deploy-20241012-git.tgz"; - sha256 = "1ysi8fjgb7kq3cycb6ms44j0m70xbd140fh4qgcpj7fm26p2a59p"; - system = "deploy"; - asd = "deploy"; - }); - systems = [ "deploy" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "sha3" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deploy-test = (build-asdf-system { - pname = "deploy-test"; - version = "20241012-git"; - asds = [ "deploy-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deploy/2024-10-12/deploy-20241012-git.tgz"; - sha256 = "1ysi8fjgb7kq3cycb6ms44j0m70xbd140fh4qgcpj7fm26p2a59p"; - system = "deploy-test"; - asd = "deploy-test"; - }); - systems = [ "deploy-test" ]; - lispLibs = [ (getAttr "cl-mpg123" self) (getAttr "cl-out123" self) (getAttr "deploy" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - depot = (build-asdf-system { - pname = "depot"; - version = "20241012-git"; - asds = [ "depot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/depot/2024-10-12/depot-20241012-git.tgz"; - sha256 = "1k9p4jqylh7i53sngi0yn2hww6y6lxqc7c0hd3j3p8jc4q3h4zn4"; - system = "depot"; - asd = "depot"; - }); - systems = [ "depot" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "trivial-features" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - depot-in-memory = (build-asdf-system { - pname = "depot-in-memory"; - version = "20241012-git"; - asds = [ "depot-in-memory" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/depot/2024-10-12/depot-20241012-git.tgz"; - sha256 = "1k9p4jqylh7i53sngi0yn2hww6y6lxqc7c0hd3j3p8jc4q3h4zn4"; - system = "depot-in-memory"; - asd = "depot-in-memory"; - }); - systems = [ "depot-in-memory" ]; - lispLibs = [ (getAttr "atomics" self) (getAttr "depot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - depot-test = (build-asdf-system { - pname = "depot-test"; - version = "20241012-git"; - asds = [ "depot-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/depot/2024-10-12/depot-20241012-git.tgz"; - sha256 = "1k9p4jqylh7i53sngi0yn2hww6y6lxqc7c0hd3j3p8jc4q3h4zn4"; - system = "depot-test"; - asd = "depot-test"; - }); - systems = [ "depot-test" ]; - lispLibs = [ (getAttr "depot" self) (getAttr "depot-in-memory" self) (getAttr "depot-zip" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - depot-virtual = (build-asdf-system { - pname = "depot-virtual"; - version = "20241012-git"; - asds = [ "depot-virtual" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/depot/2024-10-12/depot-20241012-git.tgz"; - sha256 = "1k9p4jqylh7i53sngi0yn2hww6y6lxqc7c0hd3j3p8jc4q3h4zn4"; - system = "depot-virtual"; - asd = "depot-virtual"; - }); - systems = [ "depot-virtual" ]; - lispLibs = [ (getAttr "depot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - depot-zip = (build-asdf-system { - pname = "depot-zip"; - version = "20241012-git"; - asds = [ "depot-zip" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/depot/2024-10-12/depot-20241012-git.tgz"; - sha256 = "1k9p4jqylh7i53sngi0yn2hww6y6lxqc7c0hd3j3p8jc4q3h4zn4"; - system = "depot-zip"; - asd = "depot-zip"; - }); - systems = [ "depot-zip" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "depot" self) (getAttr "zippy" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - deptree = (build-asdf-system { - pname = "deptree"; - version = "20241012-git"; - asds = [ "deptree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/deptree/2024-10-12/deptree-20241012-git.tgz"; - sha256 = "10ybmw28c52ahbm7xjn795367lssp6088v6705fmqbl0fgjpvxnw"; - system = "deptree"; - asd = "deptree"; - }); - systems = [ "deptree" ]; - lispLibs = [ (getAttr "tar" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - descriptions = (build-asdf-system { - pname = "descriptions"; - version = "20150302-git"; - asds = [ "descriptions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/descriptions/2015-03-02/descriptions-20150302-git.tgz"; - sha256 = "0h44gxilwmzk8cbxb81047cjndksvf8vw2s3pcy2diw9aqiacg7f"; - system = "descriptions"; - asd = "descriptions"; - }); - systems = [ "descriptions" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "closer-mop" self) (getAttr "sheeple" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - descriptions-test = (build-asdf-system { - pname = "descriptions-test"; - version = "20150302-git"; - asds = [ "descriptions-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/descriptions/2015-03-02/descriptions-20150302-git.tgz"; - sha256 = "0h44gxilwmzk8cbxb81047cjndksvf8vw2s3pcy2diw9aqiacg7f"; - system = "descriptions-test"; - asd = "descriptions-test"; - }); - systems = [ "descriptions-test" ]; - lispLibs = [ (getAttr "descriptions" self) (getAttr "descriptions_dot_serialization" self) (getAttr "descriptions_dot_validation" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - descriptions_dot_serialization = (build-asdf-system { - pname = "descriptions.serialization"; - version = "20150302-git"; - asds = [ "descriptions.serialization" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/descriptions/2015-03-02/descriptions-20150302-git.tgz"; - sha256 = "0h44gxilwmzk8cbxb81047cjndksvf8vw2s3pcy2diw9aqiacg7f"; - system = "descriptions.serialization"; - asd = "descriptions.serialization"; - }); - systems = [ "descriptions.serialization" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "descriptions" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - descriptions_dot_validation = (build-asdf-system { - pname = "descriptions.validation"; - version = "20150302-git"; - asds = [ "descriptions.validation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/descriptions/2015-03-02/descriptions-20150302-git.tgz"; - sha256 = "0h44gxilwmzk8cbxb81047cjndksvf8vw2s3pcy2diw9aqiacg7f"; - system = "descriptions.validation"; - asd = "descriptions.validation"; - }); - systems = [ "descriptions.validation" ]; - lispLibs = [ (getAttr "clavier" self) (getAttr "descriptions" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - destructuring-bind-star = (build-asdf-system { - pname = "destructuring-bind-star"; - version = "20200610-git"; - asds = [ "destructuring-bind-star" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/destructuring-bind-star/2020-06-10/destructuring-bind-star-20200610-git.tgz"; - sha256 = "1j1xnhvb6pm9q291aawbrcwp8bgbmiij9a53gifxhr4kp934ciz2"; - system = "destructuring-bind-star"; - asd = "destructuring-bind-star"; - }); - systems = [ "destructuring-bind-star" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dexador = (build-asdf-system { - pname = "dexador"; - version = "20241012-git"; - asds = [ "dexador" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dexador/2024-10-12/dexador-20241012-git.tgz"; - sha256 = "19y95k821665vcy7gbxhh4rqwk7fh4brv1sgkaykncpw2l2lll5r"; - system = "dexador"; - asd = "dexador"; - }); - systems = [ "dexador" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "chipz" self) (getAttr "chunga" self) (getAttr "cl_plus_ssl" self) (getAttr "cl-base64" self) (getAttr "cl-cookie" self) (getAttr "cl-ppcre" self) (getAttr "fast-http" self) (getAttr "fast-io" self) (getAttr "quri" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) (getAttr "trivial-gray-streams" self) (getAttr "trivial-mimes" self) (getAttr "usocket" self) ]; - meta = {}; - }); - dexador-test = (build-asdf-system { - pname = "dexador-test"; - version = "20241012-git"; - asds = [ "dexador-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dexador/2024-10-12/dexador-20241012-git.tgz"; - sha256 = "19y95k821665vcy7gbxhh4rqwk7fh4brv1sgkaykncpw2l2lll5r"; - system = "dexador-test"; - asd = "dexador-test"; - }); - systems = [ "dexador-test" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-cookie" self) (getAttr "clack-test" self) (getAttr "dexador" self) (getAttr "lack-request" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dexador-usocket = (build-asdf-system { - pname = "dexador-usocket"; - version = "20241012-git"; - asds = [ "dexador-usocket" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dexador/2024-10-12/dexador-20241012-git.tgz"; - sha256 = "19y95k821665vcy7gbxhh4rqwk7fh4brv1sgkaykncpw2l2lll5r"; - system = "dexador-usocket"; - asd = "dexador-usocket"; - }); - systems = [ "dexador-usocket" ]; - lispLibs = [ (getAttr "cl_plus_ssl" self) (getAttr "dexador" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dfio = (build-asdf-system { - pname = "dfio"; - version = "20221106-git"; - asds = [ "dfio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dfio/2022-11-06/dfio-20221106-git.tgz"; - sha256 = "1p53r7773939jnap518xp4b4wfvc1kbrz9jp6yd40xq0jpf9pbqg"; - system = "dfio"; - asd = "dfio"; - }); - systems = [ "dfio" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "data-frame" self) (getAttr "dexador" self) (getAttr "fare-csv" self) (getAttr "let-plus" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - diff = (build-asdf-system { - pname = "diff"; - version = "20130813-git"; - asds = [ "diff" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/diff/2013-08-13/diff-20130813-git.tgz"; - sha256 = "1giafck8qfvb688kx5bn9g32rfc12jjywg8vdav36aqbd6lxf5z5"; - system = "diff"; - asd = "diff"; - }); - systems = [ "diff" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - diff-match-patch = (build-asdf-system { - pname = "diff-match-patch"; - version = "20210531-git"; - asds = [ "diff-match-patch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/diff-match-patch/2021-05-31/diff-match-patch-20210531-git.tgz"; - sha256 = "0wxz2q9sd2v8fg521f7bzv6wi3za7saz2j2snsnw2p1kcsj6zqa4"; - system = "diff-match-patch"; - asd = "diff-match-patch"; - }); - systems = [ "diff-match-patch" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dirt = (build-asdf-system { - pname = "dirt"; - version = "release-quicklisp-0d13ebc2-git"; - asds = [ "dirt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dirt/2017-10-19/dirt-release-quicklisp-0d13ebc2-git.tgz"; - sha256 = "1lqxfdzn9rh7rzsq97d4hp6fl4g9fs6s0n2pvf460d6ri6p40xna"; - system = "dirt"; - asd = "dirt"; - }); - systems = [ "dirt" ]; - lispLibs = [ (getAttr "cepl" self) (getAttr "cl-soil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dispatch = (build-asdf-system { - pname = "dispatch"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "dispatch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "dispatch"; - asd = "dispatch"; - }); - systems = [ "dispatch" ]; - lispLibs = [ (getAttr "adjuvant" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dispatch-test = (build-asdf-system { - pname = "dispatch-test"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "dispatch-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "dispatch-test"; - asd = "dispatch-test"; - }); - systems = [ "dispatch-test" ]; - lispLibs = [ (getAttr "dispatch" self) (getAttr "scrutiny" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - disposable = (build-asdf-system { - pname = "disposable"; - version = "20160208-git"; - asds = [ "disposable" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/disposable/2016-02-08/disposable-20160208-git.tgz"; - sha256 = "18synnlg4b8203rgww644dj7ghb4m1j33lb4zm64850vqy5b3pz7"; - system = "disposable"; - asd = "disposable"; - }); - systems = [ "disposable" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dissect = (build-asdf-system { - pname = "dissect"; - version = "20241012-git"; - asds = [ "dissect" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dissect/2024-10-12/dissect-20241012-git.tgz"; - sha256 = "1ym1zggwrj15l7y2mcz5l2gfk68prqxhdswffd9s5014pa6zyysr"; - system = "dissect"; - asd = "dissect"; - }); - systems = [ "dissect" ]; - lispLibs = [ ]; - meta = {}; - }); - distributions = (build-asdf-system { - pname = "distributions"; - version = "20221106-git"; - asds = [ "distributions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/distributions/2022-11-06/distributions-20221106-git.tgz"; - sha256 = "1fkzigd0s0s0mvszgmv04yc8jp9gm4812445hfh6kpz6cjy5zpsk"; - system = "distributions"; - asd = "distributions"; - }); - systems = [ "distributions" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "array-operations" self) (getAttr "cephes" self) (getAttr "float-features" self) (getAttr "let-plus" self) (getAttr "num-utils" self) (getAttr "special-functions" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - djula = (build-asdf-system { - pname = "djula"; - version = "20241012-git"; - asds = [ "djula" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/djula/2024-10-12/djula-20241012-git.tgz"; - sha256 = "1m4k0ywkpvbpljd8r9vfmsw2zkphwcfwgbdp911zkiv5rcnmgykw"; - system = "djula"; - asd = "djula"; - }); - systems = [ "djula" ]; - lispLibs = [ (getAttr "access" self) (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-locale" self) (getAttr "cl-ppcre" self) (getAttr "cl-slice" self) (getAttr "closer-mop" self) (getAttr "gettext" self) (getAttr "iterate" self) (getAttr "local-time" self) (getAttr "parser-combinators" self) (getAttr "split-sequence" self) (getAttr "trivial-backtrace" self) ]; - meta = {}; - }); - djula-demo = (build-asdf-system { - pname = "djula-demo"; - version = "20241012-git"; - asds = [ "djula-demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/djula/2024-10-12/djula-20241012-git.tgz"; - sha256 = "1m4k0ywkpvbpljd8r9vfmsw2zkphwcfwgbdp911zkiv5rcnmgykw"; - system = "djula-demo"; - asd = "djula-demo"; - }); - systems = [ "djula-demo" ]; - lispLibs = [ (getAttr "djula" self) (getAttr "hunchentoot" self) (getAttr "trivial-open-browser" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - djula-gettext = (build-asdf-system { - pname = "djula-gettext"; - version = "20241012-git"; - asds = [ "djula-gettext" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/djula/2024-10-12/djula-20241012-git.tgz"; - sha256 = "1m4k0ywkpvbpljd8r9vfmsw2zkphwcfwgbdp911zkiv5rcnmgykw"; - system = "djula-gettext"; - asd = "djula-gettext"; - }); - systems = [ "djula-gettext" ]; - lispLibs = [ (getAttr "djula" self) (getAttr "gettext" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - djula-locale = (build-asdf-system { - pname = "djula-locale"; - version = "20241012-git"; - asds = [ "djula-locale" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/djula/2024-10-12/djula-20241012-git.tgz"; - sha256 = "1m4k0ywkpvbpljd8r9vfmsw2zkphwcfwgbdp911zkiv5rcnmgykw"; - system = "djula-locale"; - asd = "djula-locale"; - }); - systems = [ "djula-locale" ]; - lispLibs = [ (getAttr "cl-locale" self) (getAttr "djula" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - djula-test = (build-asdf-system { - pname = "djula-test"; - version = "20241012-git"; - asds = [ "djula-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/djula/2024-10-12/djula-20241012-git.tgz"; - sha256 = "1m4k0ywkpvbpljd8r9vfmsw2zkphwcfwgbdp911zkiv5rcnmgykw"; - system = "djula-test"; - asd = "djula-test"; - }); - systems = [ "djula-test" ]; - lispLibs = [ (getAttr "djula" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - djula-translate = (build-asdf-system { - pname = "djula-translate"; - version = "20241012-git"; - asds = [ "djula-translate" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/djula/2024-10-12/djula-20241012-git.tgz"; - sha256 = "1m4k0ywkpvbpljd8r9vfmsw2zkphwcfwgbdp911zkiv5rcnmgykw"; - system = "djula-translate"; - asd = "djula-translate"; - }); - systems = [ "djula-translate" ]; - lispLibs = [ (getAttr "djula" self) (getAttr "translate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dlist = (build-asdf-system { - pname = "dlist"; - version = "20121125-git"; - asds = [ "dlist" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dlist/2012-11-25/dlist-20121125-git.tgz"; - sha256 = "1ycgjmbxpj0bj95xg0x7m30yz8y73s7mnqs0dzam00rkf8g00h89"; - system = "dlist"; - asd = "dlist"; - }); - systems = [ "dlist" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dlist-test = (build-asdf-system { - pname = "dlist-test"; - version = "20121125-git"; - asds = [ "dlist-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dlist/2012-11-25/dlist-20121125-git.tgz"; - sha256 = "1ycgjmbxpj0bj95xg0x7m30yz8y73s7mnqs0dzam00rkf8g00h89"; - system = "dlist-test"; - asd = "dlist"; - }); - systems = [ "dlist-test" ]; - lispLibs = [ (getAttr "dlist" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dml = (build-asdf-system { - pname = "dml"; - version = "20231021-git"; - asds = [ "dml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dml/2023-10-21/dml-20231021-git.tgz"; - sha256 = "15yxfgmzxpn3hr3kfmw7iid652v1v1v0fw7ngvs1ig6693kci72h"; - system = "dml"; - asd = "dml"; - }); - systems = [ "dml" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-cairo2" self) (getAttr "cl-ppcre" self) (getAttr "donuts" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dns-client = (build-asdf-system { - pname = "dns-client"; - version = "20241012-git"; - asds = [ "dns-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dns-client/2024-10-12/dns-client-20241012-git.tgz"; - sha256 = "1lbxryi0hx1i0ib3rz3ci89pfdyzikhv4dg0lk5piggrkdji2fx3"; - system = "dns-client"; - asd = "dns-client"; - }); - systems = [ "dns-client" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "punycode" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - do-urlencode = (build-asdf-system { - pname = "do-urlencode"; - version = "20181018-git"; - asds = [ "do-urlencode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/do-urlencode/2018-10-18/do-urlencode-20181018-git.tgz"; - sha256 = "0k2i3d4k9cpci235mwfm0c5a4yqfkijr716bjv7cdlpzx88lazm9"; - system = "do-urlencode"; - asd = "do-urlencode"; - }); - systems = [ "do-urlencode" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) ]; - meta = {}; - }); - docbrowser = (build-asdf-system { - pname = "docbrowser"; - version = "20200610-git"; - asds = [ "docbrowser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/docbrowser/2020-06-10/docbrowser-20200610-git.tgz"; - sha256 = "0k7gkyciqfbwdmvip2s8h4k21a63h45bj3qydq3jbvkhaq4gj9x1"; - system = "docbrowser"; - asd = "docbrowser"; - }); - systems = [ "docbrowser" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "cl-json" self) (getAttr "closer-mop" self) (getAttr "colorize" self) (getAttr "flexi-streams" self) (getAttr "hunchentoot" self) (getAttr "parse-number" self) (getAttr "split-sequence" self) (getAttr "string-case" self) (getAttr "swank" self) (getAttr "yacc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - docparser = (build-asdf-system { - pname = "docparser"; - version = "20230214-git"; - asds = [ "docparser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/docparser/2023-02-14/docparser-20230214-git.tgz"; - sha256 = "1ix8n6albgl34kwvk2f3vfz9afi6y4m9dd6k3axlm9g16zhmhma1"; - system = "docparser"; - asd = "docparser"; - }); - systems = [ "docparser" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cffi" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - docparser-test = (build-asdf-system { - pname = "docparser-test"; - version = "20230214-git"; - asds = [ "docparser-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/docparser/2023-02-14/docparser-20230214-git.tgz"; - sha256 = "1ix8n6albgl34kwvk2f3vfz9afi6y4m9dd6k3axlm9g16zhmhma1"; - system = "docparser-test"; - asd = "docparser-test"; - }); - systems = [ "docparser-test" ]; - lispLibs = [ (getAttr "docparser" self) (getAttr "docparser-test-system" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - docparser-test-system = (build-asdf-system { - pname = "docparser-test-system"; - version = "20230214-git"; - asds = [ "docparser-test-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/docparser/2023-02-14/docparser-20230214-git.tgz"; - sha256 = "1ix8n6albgl34kwvk2f3vfz9afi6y4m9dd6k3axlm9g16zhmhma1"; - system = "docparser-test-system"; - asd = "docparser-test-system"; - }); - systems = [ "docparser-test-system" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - docs-builder = (build-asdf-system { - pname = "docs-builder"; - version = "20241012-git"; - asds = [ "docs-builder" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/docs-builder/2024-10-12/docs-builder-20241012-git.tgz"; - sha256 = "09pg4frik728g7njrpkb8jmzw6q9f47ng4c123lmqlmjha9bs03c"; - system = "docs-builder"; - asd = "docs-builder"; - }); - systems = [ "docs-builder" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "alexandria" self) (getAttr "docs-config" self) (getAttr "log4cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - docs-config = (build-asdf-system { - pname = "docs-config"; - version = "20241012-git"; - asds = [ "docs-config" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/docs-builder/2024-10-12/docs-builder-20241012-git.tgz"; - sha256 = "09pg4frik728g7njrpkb8jmzw6q9f47ng4c123lmqlmjha9bs03c"; - system = "docs-config"; - asd = "docs-config"; - }); - systems = [ "docs-config" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - documentation-template = (build-asdf-system { - pname = "documentation-template"; - version = "0.4.4"; - asds = [ "documentation-template" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/documentation-template/2014-12-17/documentation-template-0.4.4.tgz"; - sha256 = "0pfcg38ws0syhg2l15nwslfyj175dq1dvjip64nx02knw26zj56y"; - system = "documentation-template"; - asd = "documentation-template"; - }); - systems = [ "documentation-template" ]; - lispLibs = [ (getAttr "cl-who" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - documentation-utils = (build-asdf-system { - pname = "documentation-utils"; - version = "20231021-git"; - asds = [ "documentation-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/documentation-utils/2023-10-21/documentation-utils-20231021-git.tgz"; - sha256 = "0nzkjzvcqi1l2ywiz17h1f54vgvbkywv95in4yww6lyzqjqsqqhy"; - system = "documentation-utils"; - asd = "documentation-utils"; - }); - systems = [ "documentation-utils" ]; - lispLibs = [ (getAttr "trivial-indent" self) ]; - meta = {}; - }); - documentation-utils-extensions = (build-asdf-system { - pname = "documentation-utils-extensions"; - version = "20220707-git"; - asds = [ "documentation-utils-extensions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/documentation-utils-extensions/2022-07-07/documentation-utils-extensions-20220707-git.tgz"; - sha256 = "1bv8y1hbn6fivvsanaci19k47vfdchj3argz92az3izmar9ybp4f"; - system = "documentation-utils-extensions"; - asd = "documentation-utils-extensions"; - }); - systems = [ "documentation-utils-extensions" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - docutils = (build-asdf-system { - pname = "docutils"; - version = "20130128-git"; - asds = [ "docutils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-docutils/2013-01-28/cl-docutils-20130128-git.tgz"; - sha256 = "132bxlj0jlhiabi29mygmkcbbgyb5s1yz1xdfhm3pgrf9f8605gg"; - system = "docutils"; - asd = "docutils"; - }); - systems = [ "docutils" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "data-format-validation" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dom = (build-asdf-system { - pname = "dom"; - version = "master-fe503896-git"; - asds = [ "dom" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "dom"; - asd = "dom"; - }); - systems = [ "dom" ]; - lispLibs = [ (getAttr "cl-who" self) (getAttr "yadd" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - donuts = (build-asdf-system { - pname = "donuts"; - version = "20120703-git"; - asds = [ "donuts" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/donuts/2012-07-03/donuts-20120703-git.tgz"; - sha256 = "1arjlwic0gk28ja1ql5k1r3v0pqzg42ds8vzq9266hq5lp06q3ii"; - system = "donuts"; - asd = "donuts"; - }); - systems = [ "donuts" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - doplus = (build-asdf-system { - pname = "doplus"; - version = "v1.1.0"; - asds = [ "doplus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/doplus/2021-10-20/doplus-v1.1.0.tgz"; - sha256 = "1yvda9psw9m08d3bzdb8a2drvhrnr07a0rhza5ibk30v1dkwfw7c"; - system = "doplus"; - asd = "doplus"; - }); - systems = [ "doplus" ]; - lispLibs = [ (getAttr "parse-declarations-1_dot_0" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - doplus-fset = (build-asdf-system { - pname = "doplus-fset"; - version = "v1.1.0"; - asds = [ "doplus-fset" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/doplus/2021-10-20/doplus-v1.1.0.tgz"; - sha256 = "1yvda9psw9m08d3bzdb8a2drvhrnr07a0rhza5ibk30v1dkwfw7c"; - system = "doplus-fset"; - asd = "doplus-fset"; - }); - systems = [ "doplus-fset" ]; - lispLibs = [ (getAttr "doplus" self) (getAttr "fset" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dotenv = (build-asdf-system { - pname = "dotenv"; - version = "20211209-git"; - asds = [ "dotenv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dotenv/2021-12-09/dotenv-20211209-git.tgz"; - sha256 = "0g19svpxy2169rym532gjwsg1zybinpc99mjsy6im4n6zdd57hzh"; - system = "dotenv"; - asd = "dotenv"; - }); - systems = [ "dotenv" ]; - lispLibs = [ (getAttr "prove-asdf" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dotenv-test = (build-asdf-system { - pname = "dotenv-test"; - version = "20211209-git"; - asds = [ "dotenv-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dotenv/2021-12-09/dotenv-20211209-git.tgz"; - sha256 = "0g19svpxy2169rym532gjwsg1zybinpc99mjsy6im4n6zdd57hzh"; - system = "dotenv-test"; - asd = "dotenv"; - }); - systems = [ "dotenv-test" ]; - lispLibs = [ (getAttr "dotenv" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - doubly-linked-list = (build-asdf-system { - pname = "doubly-linked-list"; - version = "20220707-git"; - asds = [ "doubly-linked-list" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/doubly-linked-list/2022-07-07/doubly-linked-list-20220707-git.tgz"; - sha256 = "073r1zyp0slzzvcyj7ibjs85bss1iqh42zn5dvkjd6ls78v2bn9f"; - system = "doubly-linked-list"; - asd = "doubly-linked-list"; - }); - systems = [ "doubly-linked-list" ]; - lispLibs = [ (getAttr "mfiano-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - drakma = (build-asdf-system { - pname = "drakma"; - version = "v2.0.10"; - asds = [ "drakma" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/drakma/2023-10-21/drakma-v2.0.10.tgz"; - sha256 = "0clj7c1hysisdvkidvx7m0702alsksna6iiqlk499hn3hjpafmln"; - system = "drakma"; - asd = "drakma"; - }); - systems = [ "drakma" ]; - lispLibs = [ (getAttr "chipz" self) (getAttr "chunga" self) (getAttr "cl_plus_ssl" self) (getAttr "cl-base64" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "puri" self) (getAttr "usocket" self) ]; - meta = {}; - }); - drakma-async = (build-asdf-system { - pname = "drakma-async"; - version = "20210807-git"; - asds = [ "drakma-async" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/drakma-async/2021-08-07/drakma-async-20210807-git.tgz"; - sha256 = "19cd4xrcx3mz86sl0326x5lcrh9jizrwzi6p7pd856nrmx7ynf4w"; - system = "drakma-async"; - asd = "drakma-async"; - }); - systems = [ "drakma-async" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-async-future" self) (getAttr "cl-async-ssl" self) (getAttr "drakma" self) (getAttr "fast-http" self) (getAttr "fast-io" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - drakma-test = (build-asdf-system { - pname = "drakma-test"; - version = "v2.0.10"; - asds = [ "drakma-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/drakma/2023-10-21/drakma-v2.0.10.tgz"; - sha256 = "0clj7c1hysisdvkidvx7m0702alsksna6iiqlk499hn3hjpafmln"; - system = "drakma-test"; - asd = "drakma-test"; - }); - systems = [ "drakma-test" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "easy-routes" self) (getAttr "fiveam" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - draw-cons-tree = (build-asdf-system { - pname = "draw-cons-tree"; - version = "20230618-git"; - asds = [ "draw-cons-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/draw-cons-tree/2023-06-18/draw-cons-tree-20230618-git.tgz"; - sha256 = "1523bdkq8a5qn0qp9q7r16w47y6jb0hkfj7hbjfj6mg3xv001s3x"; - system = "draw-cons-tree"; - asd = "draw-cons-tree"; - }); - systems = [ "draw-cons-tree" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dref = (build-asdf-system { - pname = "dref"; - version = "20241012-git"; - asds = [ "dref" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mgl-pax/2024-10-12/mgl-pax-20241012-git.tgz"; - sha256 = "17szk2ijccssa9n7zg8qh6hc706hahvzcrzlx716hmgq2hfwvvy0"; - system = "dref"; - asd = "dref"; - }); - systems = [ "dref" ]; - lispLibs = [ (getAttr "mgl-pax-bootstrap" self) (getAttr "mgl-pax_dot_asdf" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dref-test = (build-asdf-system { - pname = "dref-test"; - version = "20241012-git"; - asds = [ "dref-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mgl-pax/2024-10-12/mgl-pax-20241012-git.tgz"; - sha256 = "17szk2ijccssa9n7zg8qh6hc706hahvzcrzlx716hmgq2hfwvvy0"; - system = "dref-test"; - asd = "dref-test"; - }); - systems = [ "dref-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "dref" self) (getAttr "mgl-pax" self) (getAttr "mgl-pax_dot_asdf" self) (getAttr "swank" self) (getAttr "try" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - drei-mcclim = (build-asdf-system { - pname = "drei-mcclim"; - version = "20241012-git"; - asds = [ "drei-mcclim" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "drei-mcclim"; - asd = "drei-mcclim"; - }); - systems = [ "drei-mcclim" ]; - lispLibs = [ (getAttr "automaton" self) (getAttr "clim-core" self) (getAttr "esa-mcclim" self) (getAttr "flexichain" self) (getAttr "persistent" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dso-lex = (build-asdf-system { - pname = "dso-lex"; - version = "0.3.2"; - asds = [ "dso-lex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dso-lex/2011-01-10/dso-lex-0.3.2.tgz"; - sha256 = "09vx0dsfaj1c5ivfkx9zl9s2yxmqpdc2v41fhpq75anq9ffr6qyr"; - system = "dso-lex"; - asd = "dso-lex"; - }); - systems = [ "dso-lex" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "dso-util" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dso-util = (build-asdf-system { - pname = "dso-util"; - version = "0.1.2"; - asds = [ "dso-util" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dso-util/2011-01-10/dso-util-0.1.2.tgz"; - sha256 = "12w1rxxk2hi6k7ng9kqf2yb1kff78bshdfl7bwv6fz8im8vq13b3"; - system = "dso-util"; - asd = "dso-util"; - }); - systems = [ "dso-util" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - duckdb = (build-asdf-system { - pname = "duckdb"; - version = "20241012-git"; - asds = [ "duckdb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-duckdb/2024-10-12/cl-duckdb-20241012-git.tgz"; - sha256 = "144c8c4m8vwmdg1ny5hjsvxmm8k6jijmrabyf2hmcnvk7hdy5sq0"; - system = "duckdb"; - asd = "duckdb"; - }); - systems = [ "duckdb" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cffi-libffi" self) (getAttr "cl-ascii-table" self) (getAttr "cl-ppcre" self) (getAttr "cl-spark" self) (getAttr "float-features" self) (getAttr "frugal-uuid" self) (getAttr "let-plus" self) (getAttr "local-time" self) (getAttr "local-time-duration" self) (getAttr "periods" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dufy = (build-asdf-system { - pname = "dufy"; - version = "20241012-git"; - asds = [ "dufy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dufy/2024-10-12/dufy-20241012-git.tgz"; - sha256 = "1fj1ad7jh8i72jvdc5ypdk1j1mlkr7dc9xs4khii9adj3jl1nb0v"; - system = "dufy"; - asd = "dufy"; - }); - systems = [ "dufy" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dungen = (build-asdf-system { - pname = "dungen"; - version = "20220707-git"; - asds = [ "dungen" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dungen/2022-07-07/dungen-20220707-git.tgz"; - sha256 = "1yvkch227g0yawv2682ysdv9q2g5yyyxjvfpx3hijl0mm0awgxv5"; - system = "dungen"; - asd = "dungen"; - }); - systems = [ "dungen" ]; - lispLibs = [ (getAttr "graph" self) (getAttr "mfiano-utils" self) (getAttr "seedable-rng" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - duologue = (build-asdf-system { - pname = "duologue"; - version = "20230214-git"; - asds = [ "duologue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/duologue/2023-02-14/duologue-20230214-git.tgz"; - sha256 = "1yg7f27im9h0m6jihcay1p7alfhzm9hafwm5dw5hsyacy8f2cwk2"; - system = "duologue"; - asd = "duologue"; - }); - systems = [ "duologue" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "chronicity" self) (getAttr "cl-ansi-text" self) (getAttr "cl-fad" self) (getAttr "clavier" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - duologue-readline = (build-asdf-system { - pname = "duologue-readline"; - version = "20230214-git"; - asds = [ "duologue-readline" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/duologue/2023-02-14/duologue-20230214-git.tgz"; - sha256 = "1yg7f27im9h0m6jihcay1p7alfhzm9hafwm5dw5hsyacy8f2cwk2"; - system = "duologue-readline"; - asd = "duologue-readline"; - }); - systems = [ "duologue-readline" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "chronicity" self) (getAttr "cl-ansi-text" self) (getAttr "cl-fad" self) (getAttr "cl-readline" self) (getAttr "clavier" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - duologue-test = (build-asdf-system { - pname = "duologue-test"; - version = "20230214-git"; - asds = [ "duologue-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/duologue/2023-02-14/duologue-20230214-git.tgz"; - sha256 = "1yg7f27im9h0m6jihcay1p7alfhzm9hafwm5dw5hsyacy8f2cwk2"; - system = "duologue-test"; - asd = "duologue-test"; - }); - systems = [ "duologue-test" ]; - lispLibs = [ (getAttr "duologue" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dweet = (build-asdf-system { - pname = "dweet"; - version = "20141217-git"; - asds = [ "dweet" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dweet/2014-12-17/dweet-20141217-git.tgz"; - sha256 = "1i3ab3igvdy6fhq3zlx1vaswhvm9dlp6fagzxbrqhqj6jsbhiwv7"; - system = "dweet"; - asd = "dweet"; - }); - systems = [ "dweet" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "com_dot_gigamonkeys_dot_json" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dynamic-array = (build-asdf-system { - pname = "dynamic-array"; - version = "20220707-git"; - asds = [ "dynamic-array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dynamic-array/2022-07-07/dynamic-array-20220707-git.tgz"; - sha256 = "02kg1m5xscg521074nasx3f04784jbm0x61a7skixbdprpg6hhnh"; - system = "dynamic-array"; - asd = "dynamic-array"; - }); - systems = [ "dynamic-array" ]; - lispLibs = [ (getAttr "mfiano-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dynamic-classes = (build-asdf-system { - pname = "dynamic-classes"; - version = "20231021-git"; - asds = [ "dynamic-classes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dynamic-classes/2023-10-21/dynamic-classes-20231021-git.tgz"; - sha256 = "1k9lkchwyi2xhygp2v8ifq3kg1l3wcnihhzgr06jrivjxgdqpc1a"; - system = "dynamic-classes"; - asd = "dynamic-classes"; - }); - systems = [ "dynamic-classes" ]; - lispLibs = [ (getAttr "metatilities-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dynamic-classes-test = (build-asdf-system { - pname = "dynamic-classes-test"; - version = "20231021-git"; - asds = [ "dynamic-classes-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dynamic-classes/2023-10-21/dynamic-classes-20231021-git.tgz"; - sha256 = "1k9lkchwyi2xhygp2v8ifq3kg1l3wcnihhzgr06jrivjxgdqpc1a"; - system = "dynamic-classes-test"; - asd = "dynamic-classes-test"; - }); - systems = [ "dynamic-classes-test" ]; - lispLibs = [ (getAttr "dynamic-classes" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dynamic-collect = (build-asdf-system { - pname = "dynamic-collect"; - version = "20230618-git"; - asds = [ "dynamic-collect" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dynamic-collect/2023-06-18/dynamic-collect-20230618-git.tgz"; - sha256 = "0p1ylba1myby21jg8x9lgwxfv958za32qsz426yd2vc485j887iw"; - system = "dynamic-collect"; - asd = "dynamic-collect"; - }); - systems = [ "dynamic-collect" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dynamic-mixins = (build-asdf-system { - pname = "dynamic-mixins"; - version = "20181018-git"; - asds = [ "dynamic-mixins" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dynamic-mixins/2018-10-18/dynamic-mixins-20181018-git.tgz"; - sha256 = "00g3s509ysh2jp1qwsgb5bwl6qvhzcljwjz3z4mspbcak51484zj"; - system = "dynamic-mixins"; - asd = "dynamic-mixins"; - }); - systems = [ "dynamic-mixins" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dynamic-mixins-swm = (build-asdf-system { - pname = "dynamic-mixins-swm"; - version = "20231021-git"; - asds = [ "dynamic-mixins-swm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stumpwm/2023-10-21/stumpwm-20231021-git.tgz"; - sha256 = "114kicsziqvm15x15yhc39j8qzv6gxz4wxc40xp968pprzr4a4d1"; - system = "dynamic-mixins-swm"; - asd = "dynamic-mixins-swm"; - }); - systems = [ "dynamic-mixins-swm" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - dynamic-wind = (build-asdf-system { - pname = "dynamic-wind"; - version = "20241012-git"; - asds = [ "dynamic-wind" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/contextl/2024-10-12/contextl-20241012-git.tgz"; - sha256 = "1jsa5wyjzzfw9pii3d6x20mh8ijnpb291g3i0y2ccj0x8z3xfyyk"; - system = "dynamic-wind"; - asd = "dynamic-wind"; - }); - systems = [ "dynamic-wind" ]; - lispLibs = [ (getAttr "lw-compat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eager-future = (build-asdf-system { - pname = "eager-future"; - version = "20101006-darcs"; - asds = [ "eager-future" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eager-future/2010-10-06/eager-future-20101006-darcs.tgz"; - sha256 = "0l7khqfqfchk7j24fk7rwagwanjargxsrzr6g1h4ainqjajd91jl"; - system = "eager-future"; - asd = "eager-future"; - }); - systems = [ "eager-future" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eager-future_dot_test = (build-asdf-system { - pname = "eager-future.test"; - version = "20101006-darcs"; - asds = [ "eager-future.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eager-future/2010-10-06/eager-future-20101006-darcs.tgz"; - sha256 = "0l7khqfqfchk7j24fk7rwagwanjargxsrzr6g1h4ainqjajd91jl"; - system = "eager-future.test"; - asd = "eager-future"; - }); - systems = [ "eager-future.test" ]; - lispLibs = [ (getAttr "eager-future" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eager-future2 = (build-asdf-system { - pname = "eager-future2"; - version = "20191130-git"; - asds = [ "eager-future2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eager-future2/2019-11-30/eager-future2-20191130-git.tgz"; - sha256 = "1qs1bv3m0ki8l5czhsflxcryh22r9d9g9a3a3b0cr0pl954q5rld"; - system = "eager-future2"; - asd = "eager-future2"; - }); - systems = [ "eager-future2" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - easing = (build-asdf-system { - pname = "easing"; - version = "20180228-git"; - asds = [ "easing" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/easing/2018-02-28/easing-20180228-git.tgz"; - sha256 = "0750cs5kij8hi53960lzih57xrf92fj23i3hxzhqzcyla4wi4jv5"; - system = "easing"; - asd = "easing"; - }); - systems = [ "easing" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - easing-demo = (build-asdf-system { - pname = "easing-demo"; - version = "20180228-git"; - asds = [ "easing-demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/easing/2018-02-28/easing-20180228-git.tgz"; - sha256 = "0750cs5kij8hi53960lzih57xrf92fj23i3hxzhqzcyla4wi4jv5"; - system = "easing-demo"; - asd = "easing-demo"; - }); - systems = [ "easing-demo" ]; - lispLibs = [ (getAttr "easing" self) (getAttr "sketch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - easing-test = (build-asdf-system { - pname = "easing-test"; - version = "20180228-git"; - asds = [ "easing-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/easing/2018-02-28/easing-20180228-git.tgz"; - sha256 = "0750cs5kij8hi53960lzih57xrf92fj23i3hxzhqzcyla4wi4jv5"; - system = "easing-test"; - asd = "easing-test"; - }); - systems = [ "easing-test" ]; - lispLibs = [ (getAttr "easing" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - easter-gauss = (build-asdf-system { - pname = "easter-gauss"; - version = "20241012-git"; - asds = [ "easter-gauss" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/easter-gauss/2024-10-12/easter-gauss-20241012-git.tgz"; - sha256 = "1wgr7j8b32yq0ajy4a3g08yr7z4p987gfjsrd6gai5i9zqxkbyih"; - system = "easter-gauss"; - asd = "easter-gauss"; - }); - systems = [ "easter-gauss" ]; - lispLibs = [ (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - easy-audio = (build-asdf-system { - pname = "easy-audio"; - version = "20241012-git"; - asds = [ "easy-audio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/easy-audio/2024-10-12/easy-audio-20241012-git.tgz"; - sha256 = "1vlk2lzipz7sspizv4fiv6nmxhgq9piangc6gfxz6m5k3r74mwrg"; - system = "easy-audio"; - asd = "easy-audio"; - }); - systems = [ "easy-audio" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "flexi-streams" self) (getAttr "nibbles-streams" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - easy-bind = (build-asdf-system { - pname = "easy-bind"; - version = "20190202-git"; - asds = [ "easy-bind" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/easy-bind/2019-02-02/easy-bind-20190202-git.tgz"; - sha256 = "0z7mqm7vnk8jcsmawlyhzg81v2bmgdbxmx3jkf2m74170q78jhkl"; - system = "easy-bind"; - asd = "easy-bind"; - }); - systems = [ "easy-bind" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - easy-macros = (build-asdf-system { - pname = "easy-macros"; - version = "20241012-git"; - asds = [ "easy-macros" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/easy-macros/2024-10-12/easy-macros-20241012-git.tgz"; - sha256 = "12ixfmxbxszhdcv2fnd9q8m573bn6q2nvn656bpwnzvka9si6vrq"; - system = "easy-macros"; - asd = "easy-macros"; - }); - systems = [ "easy-macros" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - easy-routes = (build-asdf-system { - pname = "easy-routes"; - version = "20241012-git"; - asds = [ "easy-routes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/easy-routes/2024-10-12/easy-routes-20241012-git.tgz"; - sha256 = "0bz91g0vd1nn9b23npmrjw2ig6fahjs3b6iiw7ncajc2w5x9w1y4"; - system = "easy-routes"; - asd = "easy-routes"; - }); - systems = [ "easy-routes" ]; - lispLibs = [ (getAttr "hunchentoot" self) (getAttr "routes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - easy-routes_plus_djula = (build-asdf-system { - pname = "easy-routes+djula"; - version = "20241012-git"; - asds = [ "easy-routes+djula" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/easy-routes/2024-10-12/easy-routes-20241012-git.tgz"; - sha256 = "0bz91g0vd1nn9b23npmrjw2ig6fahjs3b6iiw7ncajc2w5x9w1y4"; - system = "easy-routes+djula"; - asd = "easy-routes+djula"; - }); - systems = [ "easy-routes+djula" ]; - lispLibs = [ (getAttr "djula" self) (getAttr "easy-routes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - easy-routes_plus_errors = (build-asdf-system { - pname = "easy-routes+errors"; - version = "20241012-git"; - asds = [ "easy-routes+errors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/easy-routes/2024-10-12/easy-routes-20241012-git.tgz"; - sha256 = "0bz91g0vd1nn9b23npmrjw2ig6fahjs3b6iiw7ncajc2w5x9w1y4"; - system = "easy-routes+errors"; - asd = "easy-routes+errors"; - }); - systems = [ "easy-routes+errors" ]; - lispLibs = [ (getAttr "easy-routes" self) (getAttr "hunchentoot-errors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eazy-documentation = (build-asdf-system { - pname = "eazy-documentation"; - version = "20210411-git"; - asds = [ "eazy-documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eazy-documentation/2021-04-11/eazy-documentation-20210411-git.tgz"; - sha256 = "0wqd6jih98ab8qpajmcmbj0cwa3g6jjbr7v0wp5gqn1wllwn70ix"; - system = "eazy-documentation"; - asd = "eazy-documentation"; - }); - systems = [ "eazy-documentation" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "cl-who" self) (getAttr "common-doc" self) (getAttr "common-doc-split-paragraphs" self) (getAttr "common-html" self) (getAttr "iterate" self) (getAttr "trivia" self) (getAttr "trivia_dot_ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eazy-gnuplot = (build-asdf-system { - pname = "eazy-gnuplot"; - version = "20220331-git"; - asds = [ "eazy-gnuplot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eazy-gnuplot/2022-03-31/eazy-gnuplot-20220331-git.tgz"; - sha256 = "0mpkx1z52riahydzvqv7kk15p0pv2k7k5a7j65fg571kcxmssx8s"; - system = "eazy-gnuplot"; - asd = "eazy-gnuplot"; - }); - systems = [ "eazy-gnuplot" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eazy-gnuplot_dot_test = (build-asdf-system { - pname = "eazy-gnuplot.test"; - version = "20220331-git"; - asds = [ "eazy-gnuplot.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eazy-gnuplot/2022-03-31/eazy-gnuplot-20220331-git.tgz"; - sha256 = "0mpkx1z52riahydzvqv7kk15p0pv2k7k5a7j65fg571kcxmssx8s"; - system = "eazy-gnuplot.test"; - asd = "eazy-gnuplot.test"; - }); - systems = [ "eazy-gnuplot.test" ]; - lispLibs = [ (getAttr "eazy-gnuplot" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eazy-process = (build-asdf-system { - pname = "eazy-process"; - version = "20200925-git"; - asds = [ "eazy-process" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eazy-process/2020-09-25/eazy-process-20200925-git.tgz"; - sha256 = "1fvc613jg3b0kra664lbyyzvig7sm1xzaawack28c5m61yiwakiw"; - system = "eazy-process"; - asd = "eazy-process"; - }); - systems = [ "eazy-process" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-ppcre" self) (getAttr "cl-rlimit" self) (getAttr "iolib" self) (getAttr "iterate" self) (getAttr "trivia" self) (getAttr "trivia_dot_ppcre" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eazy-process_dot_test = (build-asdf-system { - pname = "eazy-process.test"; - version = "20200925-git"; - asds = [ "eazy-process.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eazy-process/2020-09-25/eazy-process-20200925-git.tgz"; - sha256 = "1fvc613jg3b0kra664lbyyzvig7sm1xzaawack28c5m61yiwakiw"; - system = "eazy-process.test"; - asd = "eazy-process.test"; - }); - systems = [ "eazy-process.test" ]; - lispLibs = [ (getAttr "eazy-process" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eazy-project = (build-asdf-system { - pname = "eazy-project"; - version = "20190710-git"; - asds = [ "eazy-project" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eazy-project/2019-07-10/eazy-project-20190710-git.tgz"; - sha256 = "1dfzvsvzdwcfvynvik9kwhgil9m08jx8r0vwqj7l1m2d9zm4db3b"; - system = "eazy-project"; - asd = "eazy-project"; - }); - systems = [ "eazy-project" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-emb" self) (getAttr "cl-ppcre" self) (getAttr "cl-syntax" self) (getAttr "cl-syntax-annot" self) (getAttr "introspect-environment" self) (getAttr "iterate" self) (getAttr "lisp-namespace" self) (getAttr "local-time" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eazy-project_dot_autoload = (build-asdf-system { - pname = "eazy-project.autoload"; - version = "20190710-git"; - asds = [ "eazy-project.autoload" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eazy-project/2019-07-10/eazy-project-20190710-git.tgz"; - sha256 = "1dfzvsvzdwcfvynvik9kwhgil9m08jx8r0vwqj7l1m2d9zm4db3b"; - system = "eazy-project.autoload"; - asd = "eazy-project.autoload"; - }); - systems = [ "eazy-project.autoload" ]; - lispLibs = [ (getAttr "eazy-project" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eazy-project_dot_test = (build-asdf-system { - pname = "eazy-project.test"; - version = "20190710-git"; - asds = [ "eazy-project.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eazy-project/2019-07-10/eazy-project-20190710-git.tgz"; - sha256 = "1dfzvsvzdwcfvynvik9kwhgil9m08jx8r0vwqj7l1m2d9zm4db3b"; - system = "eazy-project.test"; - asd = "eazy-project.test"; - }); - systems = [ "eazy-project.test" ]; - lispLibs = [ (getAttr "eazy-project" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ec2 = (build-asdf-system { - pname = "ec2"; - version = "20120909-git"; - asds = [ "ec2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ec2/2012-09-09/ec2-20120909-git.tgz"; - sha256 = "1z9yv1b8ckyvla80rha7amfhhy57kylkscf504rpfx8994fnfbsy"; - system = "ec2"; - asd = "ec2"; - }); - systems = [ "ec2" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "ironclad" self) (getAttr "s-base64" self) (getAttr "s-xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ec2-price-finder = (build-asdf-system { - pname = "ec2-price-finder"; - version = "20210531-git"; - asds = [ "ec2-price-finder" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ec2-price-finder/2021-05-31/ec2-price-finder-20210531-git.tgz"; - sha256 = "1511py79fj0xpzzjlfk6fchp6lmikvhy42s3p6s85fbq4dyj4mpj"; - system = "ec2-price-finder"; - asd = "ec2-price-finder"; - }); - systems = [ "ec2-price-finder" ]; - lispLibs = [ (getAttr "easy-routes" self) (getAttr "hunchentoot" self) (getAttr "lass" self) (getAttr "local-time" self) (getAttr "parse-float" self) (getAttr "read-csv" self) (getAttr "spinneret" self) (getAttr "wu-decimal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ecclesia = (build-asdf-system { - pname = "ecclesia"; - version = "20231021-git"; - asds = [ "ecclesia" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ecclesia/2023-10-21/ecclesia-20231021-git.tgz"; - sha256 = "0hamxgkqq833m02wjnghnjq9ny9k8xk3qx1wffm809qsm9ivwah8"; - system = "ecclesia"; - asd = "ecclesia"; - }); - systems = [ "ecclesia" ]; - lispLibs = [ (getAttr "acclimation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eclecticse_dot_iso-8601-date = (build-asdf-system { - pname = "eclecticse.iso-8601-date"; - version = "20190107-git"; - asds = [ "eclecticse.iso-8601-date" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/iso-8601-date/2019-01-07/iso-8601-date-20190107-git.tgz"; - sha256 = "12d6jyznglm13sb04xh5l0d0bwi4y449wdyifvfy7r03qy8wypdx"; - system = "eclecticse.iso-8601-date"; - asd = "eclecticse.iso-8601-date"; - }); - systems = [ "eclecticse.iso-8601-date" ]; - lispLibs = [ (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eclecticse_dot_omer = (build-asdf-system { - pname = "eclecticse.omer"; - version = "20210411-git"; - asds = [ "eclecticse.omer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/omer-count/2021-04-11/omer-count-20210411-git.tgz"; - sha256 = "1rvg7rfalvi28x3jkknfdyf4y7zjrqdx073iqi2gin4amin6n7jv"; - system = "eclecticse.omer"; - asd = "eclecticse.omer"; - }); - systems = [ "eclecticse.omer" ]; - lispLibs = [ (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eclecticse_dot_slk-581 = (build-asdf-system { - pname = "eclecticse.slk-581"; - version = "20190107-git"; - asds = [ "eclecticse.slk-581" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/slk-581/2019-01-07/slk-581-20190107-git.tgz"; - sha256 = "1pxyr1gi4ppnfld399wiypqqkgm3bqd9kpizpwgll2fd10yh2qmf"; - system = "eclecticse.slk-581"; - asd = "eclecticse.slk-581"; - }); - systems = [ "eclecticse.slk-581" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eclector = (build-asdf-system { - pname = "eclector"; - version = "20241012-git"; - asds = [ "eclector" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eclector/2024-10-12/eclector-20241012-git.tgz"; - sha256 = "06qhll5k0hq652gdzvvhcv4amqg9z7qillnn3z9cm8z9sv1n912v"; - system = "eclector"; - asd = "eclector"; - }); - systems = [ "eclector" ]; - lispLibs = [ (getAttr "acclimation" self) (getAttr "alexandria" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eclector-concrete-syntax-tree = (build-asdf-system { - pname = "eclector-concrete-syntax-tree"; - version = "20241012-git"; - asds = [ "eclector-concrete-syntax-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eclector/2024-10-12/eclector-20241012-git.tgz"; - sha256 = "06qhll5k0hq652gdzvvhcv4amqg9z7qillnn3z9cm8z9sv1n912v"; - system = "eclector-concrete-syntax-tree"; - asd = "eclector-concrete-syntax-tree"; - }); - systems = [ "eclector-concrete-syntax-tree" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "concrete-syntax-tree" self) (getAttr "eclector" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eclector_dot_syntax-extensions = (build-asdf-system { - pname = "eclector.syntax-extensions"; - version = "20241012-git"; - asds = [ "eclector.syntax-extensions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eclector/2024-10-12/eclector-20241012-git.tgz"; - sha256 = "06qhll5k0hq652gdzvvhcv4amqg9z7qillnn3z9cm8z9sv1n912v"; - system = "eclector.syntax-extensions"; - asd = "eclector.syntax-extensions"; - }); - systems = [ "eclector.syntax-extensions" ]; - lispLibs = [ (getAttr "eclector" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eco = (build-asdf-system { - pname = "eco"; - version = "20190813-git"; - asds = [ "eco" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eco/2019-08-13/eco-20190813-git.tgz"; - sha256 = "13fsv9v7fhf05p7j1hrfy2sg813wmgsp9aw4ng4cpzdss24zvf7q"; - system = "eco"; - asd = "eco"; - }); - systems = [ "eco" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-who" self) (getAttr "esrap" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eco-test = (build-asdf-system { - pname = "eco-test"; - version = "20190813-git"; - asds = [ "eco-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eco/2019-08-13/eco-20190813-git.tgz"; - sha256 = "13fsv9v7fhf05p7j1hrfy2sg813wmgsp9aw4ng4cpzdss24zvf7q"; - system = "eco-test"; - asd = "eco-test"; - }); - systems = [ "eco-test" ]; - lispLibs = [ (getAttr "eco" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - edit-distance = (build-asdf-system { - pname = "edit-distance"; - version = "20220331-git"; - asds = [ "edit-distance" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-editdistance/2022-03-31/cl-editdistance-20220331-git.tgz"; - sha256 = "0nzbgq69wak18vwpk0fp68x8shdxq5vy70213dc2r0hwfzzc10v9"; - system = "edit-distance"; - asd = "edit-distance"; - }); - systems = [ "edit-distance" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - edit-distance-test = (build-asdf-system { - pname = "edit-distance-test"; - version = "20220331-git"; - asds = [ "edit-distance-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-editdistance/2022-03-31/cl-editdistance-20220331-git.tgz"; - sha256 = "0nzbgq69wak18vwpk0fp68x8shdxq5vy70213dc2r0hwfzzc10v9"; - system = "edit-distance-test"; - asd = "edit-distance-test"; - }); - systems = [ "edit-distance-test" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-coveralls" self) (getAttr "edit-distance" self) (getAttr "lisp-unit" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - elb-log = (build-asdf-system { - pname = "elb-log"; - version = "20150923-git"; - asds = [ "elb-log" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/elb-log/2015-09-23/elb-log-20150923-git.tgz"; - sha256 = "1d0vkmkjr6d96j7cggw5frj50jf14brbm63is41zwfkfl9r4i6bp"; - system = "elb-log"; - asd = "elb-log"; - }); - systems = [ "elb-log" ]; - lispLibs = [ (getAttr "cl-annot-prove" self) (getAttr "cl-ppcre" self) (getAttr "cl-syntax" self) (getAttr "cl-syntax-annot" self) (getAttr "cl-syntax-interpol" self) (getAttr "local-time" self) (getAttr "zs3" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - elb-log-test = (build-asdf-system { - pname = "elb-log-test"; - version = "20150923-git"; - asds = [ "elb-log-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/elb-log/2015-09-23/elb-log-20150923-git.tgz"; - sha256 = "1d0vkmkjr6d96j7cggw5frj50jf14brbm63is41zwfkfl9r4i6bp"; - system = "elb-log-test"; - asd = "elb-log-test"; - }); - systems = [ "elb-log-test" ]; - lispLibs = [ (getAttr "elb-log" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - electron-tools = (build-asdf-system { - pname = "electron-tools"; - version = "20160421-git"; - asds = [ "electron-tools" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/electron-tools/2016-04-21/electron-tools-20160421-git.tgz"; - sha256 = "0fr16gsbn87vyyjpn2gndhpjg7yzsn4j7skyn0py252cvdk5ygf7"; - system = "electron-tools"; - asd = "electron-tools"; - }); - systems = [ "electron-tools" ]; - lispLibs = [ (getAttr "osicat" self) (getAttr "trivial-download" self) (getAttr "trivial-exe" self) (getAttr "trivial-extract" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - electron-tools-test = (build-asdf-system { - pname = "electron-tools-test"; - version = "20160421-git"; - asds = [ "electron-tools-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/electron-tools/2016-04-21/electron-tools-20160421-git.tgz"; - sha256 = "0fr16gsbn87vyyjpn2gndhpjg7yzsn4j7skyn0py252cvdk5ygf7"; - system = "electron-tools-test"; - asd = "electron-tools-test"; - }); - systems = [ "electron-tools-test" ]; - lispLibs = [ (getAttr "electron-tools" self) (getAttr "fiveam" self) (getAttr "trivial-extract" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - elf = (build-asdf-system { - pname = "elf"; - version = "20190710-git"; - asds = [ "elf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/elf/2019-07-10/elf-20190710-git.tgz"; - sha256 = "0rd1qcczr2gx76fmxia0kix0p5b49myc9fndibkvwc94cxg085gk"; - system = "elf"; - asd = "elf"; - }); - systems = [ "elf" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "com_dot_gigamonkeys_dot_binary-data" self) (getAttr "flexi-streams" self) (getAttr "metabang-bind" self) (getAttr "split-sequence" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enchant = (build-asdf-system { - pname = "enchant"; - version = "20241012-git"; - asds = [ "enchant" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-enchant/2024-10-12/cl-enchant-20241012-git.tgz"; - sha256 = "1fcxyb9b8g0v2il2q4xj7z19y1qfxvgd34zax8sdjvl4rp66b08v"; - system = "enchant"; - asd = "enchant"; - }); - systems = [ "enchant" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = {}; - }); - enhanced-boolean = (build-asdf-system { - pname = "enhanced-boolean"; - version = "1.0"; - asds = [ "enhanced-boolean" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-boolean/2020-03-25/enhanced-boolean_1.0.tgz"; - sha256 = "17l18lz07fk2kg835vs6c3189d230n1rm9vghk3ls4i356gbq0gy"; - system = "enhanced-boolean"; - asd = "enhanced-boolean"; - }); - systems = [ "enhanced-boolean" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-boolean__tests = (build-asdf-system { - pname = "enhanced-boolean_tests"; - version = "1.0"; - asds = [ "enhanced-boolean_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-boolean/2020-03-25/enhanced-boolean_1.0.tgz"; - sha256 = "17l18lz07fk2kg835vs6c3189d230n1rm9vghk3ls4i356gbq0gy"; - system = "enhanced-boolean_tests"; - asd = "enhanced-boolean_tests"; - }); - systems = [ "enhanced-boolean_tests" ]; - lispLibs = [ (getAttr "enhanced-boolean" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-defclass = (build-asdf-system { - pname = "enhanced-defclass"; - version = "2.1"; - asds = [ "enhanced-defclass" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-defclass/2021-04-11/enhanced-defclass_2.1.tgz"; - sha256 = "142s5c3pl3x7xdawzsj8pdxiqp4wh6fcajf4la5msvnxgf66d8wg"; - system = "enhanced-defclass"; - asd = "enhanced-defclass"; - }); - systems = [ "enhanced-defclass" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "compatible-metaclasses" self) (getAttr "enhanced-eval-when" self) (getAttr "enhanced-find-class" self) (getAttr "evaled-when" self) (getAttr "shared-preferences" self) (getAttr "simple-guess" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-defclass__tests = (build-asdf-system { - pname = "enhanced-defclass_tests"; - version = "2.1"; - asds = [ "enhanced-defclass_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-defclass/2021-04-11/enhanced-defclass_2.1.tgz"; - sha256 = "142s5c3pl3x7xdawzsj8pdxiqp4wh6fcajf4la5msvnxgf66d8wg"; - system = "enhanced-defclass_tests"; - asd = "enhanced-defclass_tests"; - }); - systems = [ "enhanced-defclass_tests" ]; - lispLibs = [ (getAttr "enhanced-defclass" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-eval-when = (build-asdf-system { - pname = "enhanced-eval-when"; - version = "2.0"; - asds = [ "enhanced-eval-when" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-eval-when/2023-10-21/enhanced-eval-when_2.0.tgz"; - sha256 = "1l7n04pzcwsxvw6m4pcksmlx525ijbgh5n28h56clpvpwlwnzjs3"; - system = "enhanced-eval-when"; - asd = "enhanced-eval-when"; - }); - systems = [ "enhanced-eval-when" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-eval-when__tests = (build-asdf-system { - pname = "enhanced-eval-when_tests"; - version = "2.0"; - asds = [ "enhanced-eval-when_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-eval-when/2023-10-21/enhanced-eval-when_2.0.tgz"; - sha256 = "1l7n04pzcwsxvw6m4pcksmlx525ijbgh5n28h56clpvpwlwnzjs3"; - system = "enhanced-eval-when_tests"; - asd = "enhanced-eval-when_tests"; - }); - systems = [ "enhanced-eval-when_tests" ]; - lispLibs = [ (getAttr "enhanced-eval-when" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-find-class = (build-asdf-system { - pname = "enhanced-find-class"; - version = "1.0"; - asds = [ "enhanced-find-class" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-find-class/2020-09-25/enhanced-find-class_1.0.tgz"; - sha256 = "1pf1mxb238zrmvgm9s0456s1x0m317ls23ls1d987riw69y3w9vx"; - system = "enhanced-find-class"; - asd = "enhanced-find-class"; - }); - systems = [ "enhanced-find-class" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-find-class__tests = (build-asdf-system { - pname = "enhanced-find-class_tests"; - version = "1.0"; - asds = [ "enhanced-find-class_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-find-class/2020-09-25/enhanced-find-class_1.0.tgz"; - sha256 = "1pf1mxb238zrmvgm9s0456s1x0m317ls23ls1d987riw69y3w9vx"; - system = "enhanced-find-class_tests"; - asd = "enhanced-find-class_tests"; - }); - systems = [ "enhanced-find-class_tests" ]; - lispLibs = [ (getAttr "enhanced-find-class" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-multiple-value-bind = (build-asdf-system { - pname = "enhanced-multiple-value-bind"; - version = "2.0"; - asds = [ "enhanced-multiple-value-bind" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-multiple-value-bind/2023-10-21/enhanced-multiple-value-bind_2.0.tgz"; - sha256 = "191h0rd3fs5vqc15kvblvvwmvcqddmvj3s8x6xfp78gm69wk9bdq"; - system = "enhanced-multiple-value-bind"; - asd = "enhanced-multiple-value-bind"; - }); - systems = [ "enhanced-multiple-value-bind" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-multiple-value-bind__tests = (build-asdf-system { - pname = "enhanced-multiple-value-bind_tests"; - version = "2.0"; - asds = [ "enhanced-multiple-value-bind_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-multiple-value-bind/2023-10-21/enhanced-multiple-value-bind_2.0.tgz"; - sha256 = "191h0rd3fs5vqc15kvblvvwmvcqddmvj3s8x6xfp78gm69wk9bdq"; - system = "enhanced-multiple-value-bind_tests"; - asd = "enhanced-multiple-value-bind_tests"; - }); - systems = [ "enhanced-multiple-value-bind_tests" ]; - lispLibs = [ (getAttr "enhanced-eval-when" self) (getAttr "enhanced-multiple-value-bind" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-typep = (build-asdf-system { - pname = "enhanced-typep"; - version = "1.0"; - asds = [ "enhanced-typep" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-typep/2020-10-16/enhanced-typep_1.0.tgz"; - sha256 = "0b22gddkbxnhmi71wa2h51495737lrvsqxnri7g1qdsl1hraml21"; - system = "enhanced-typep"; - asd = "enhanced-typep"; - }); - systems = [ "enhanced-typep" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-typep__tests = (build-asdf-system { - pname = "enhanced-typep_tests"; - version = "1.0"; - asds = [ "enhanced-typep_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-typep/2020-10-16/enhanced-typep_1.0.tgz"; - sha256 = "0b22gddkbxnhmi71wa2h51495737lrvsqxnri7g1qdsl1hraml21"; - system = "enhanced-typep_tests"; - asd = "enhanced-typep_tests"; - }); - systems = [ "enhanced-typep_tests" ]; - lispLibs = [ (getAttr "enhanced-boolean" self) (getAttr "enhanced-typep" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-unwind-protect = (build-asdf-system { - pname = "enhanced-unwind-protect"; - version = "1.0"; - asds = [ "enhanced-unwind-protect" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-unwind-protect/2023-10-21/enhanced-unwind-protect_1.0.tgz"; - sha256 = "00yak6ga0rsz58r96clmzvqbcmnfxcdxvn3h3ysirrsfr8rayy5m"; - system = "enhanced-unwind-protect"; - asd = "enhanced-unwind-protect"; - }); - systems = [ "enhanced-unwind-protect" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enhanced-unwind-protect__tests = (build-asdf-system { - pname = "enhanced-unwind-protect_tests"; - version = "1.0"; - asds = [ "enhanced-unwind-protect_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/enhanced-unwind-protect/2023-10-21/enhanced-unwind-protect_1.0.tgz"; - sha256 = "00yak6ga0rsz58r96clmzvqbcmnfxcdxvn3h3ysirrsfr8rayy5m"; - system = "enhanced-unwind-protect_tests"; - asd = "enhanced-unwind-protect_tests"; - }); - systems = [ "enhanced-unwind-protect_tests" ]; - lispLibs = [ (getAttr "enhanced-unwind-protect" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - enumerations = (build-asdf-system { - pname = "enumerations"; - version = "20230214-git"; - asds = [ "enumerations" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-enumeration/2023-02-14/cl-enumeration-20230214-git.tgz"; - sha256 = "08jp5sf1230d4yyr7jyjqv235hdjjbmabh8r5lsqjh4kgqbwrvqr"; - system = "enumerations"; - asd = "enumerations"; - }); - systems = [ "enumerations" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - envy = (build-asdf-system { - pname = "envy"; - version = "20220331-git"; - asds = [ "envy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/envy/2022-03-31/envy-20220331-git.tgz"; - sha256 = "1r0wgimd7z57x8cv69sw76w3y5l70hq50882a9nq5l4v64lg55fq"; - system = "envy"; - asd = "envy"; - }); - systems = [ "envy" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - envy-test = (build-asdf-system { - pname = "envy-test"; - version = "20220331-git"; - asds = [ "envy-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/envy/2022-03-31/envy-20220331-git.tgz"; - sha256 = "1r0wgimd7z57x8cv69sw76w3y5l70hq50882a9nq5l4v64lg55fq"; - system = "envy-test"; - asd = "envy-test"; - }); - systems = [ "envy-test" ]; - lispLibs = [ (getAttr "envy" self) (getAttr "osicat" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eos = (build-asdf-system { - pname = "eos"; - version = "20200925-git"; - asds = [ "eos" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eos/2020-09-25/eos-20200925-git.tgz"; - sha256 = "1afllvmlnx97yzz404gycl3pa3kwx427k3hrbf37rpmjlv47knhk"; - system = "eos"; - asd = "eos"; - }); - systems = [ "eos" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eos-tests = (build-asdf-system { - pname = "eos-tests"; - version = "20200925-git"; - asds = [ "eos-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eos/2020-09-25/eos-20200925-git.tgz"; - sha256 = "1afllvmlnx97yzz404gycl3pa3kwx427k3hrbf37rpmjlv47knhk"; - system = "eos-tests"; - asd = "eos"; - }); - systems = [ "eos-tests" ]; - lispLibs = [ (getAttr "eos" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - epigraph = (build-asdf-system { - pname = "epigraph"; - version = "20200325-git"; - asds = [ "epigraph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/epigraph/2020-03-25/epigraph-20200325-git.tgz"; - sha256 = "0gqiv23grdiz6pfly7mqyfmq4c6nwcamlvgsnixn8qi9md7b9d64"; - system = "epigraph"; - asd = "epigraph"; - }); - systems = [ "epigraph" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - epigraph-test = (build-asdf-system { - pname = "epigraph-test"; - version = "20200325-git"; - asds = [ "epigraph-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/epigraph/2020-03-25/epigraph-20200325-git.tgz"; - sha256 = "0gqiv23grdiz6pfly7mqyfmq4c6nwcamlvgsnixn8qi9md7b9d64"; - system = "epigraph-test"; - asd = "epigraph"; - }); - systems = [ "epigraph-test" ]; - lispLibs = [ (getAttr "epigraph" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - epmd = (build-asdf-system { - pname = "epmd"; - version = "20140211-git"; - asds = [ "epmd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-epmd/2014-02-11/cl-epmd-20140211-git.tgz"; - sha256 = "1334856x7jqhv52wlab6wxmfqslj21pmryx3lwmlsn7c3ypwz4rw"; - system = "epmd"; - asd = "epmd"; - }); - systems = [ "epmd" ]; - lispLibs = [ (getAttr "com_dot_gigamonkeys_dot_binary-data" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - epmd-test = (build-asdf-system { - pname = "epmd-test"; - version = "20140211-git"; - asds = [ "epmd-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-epmd/2014-02-11/cl-epmd-20140211-git.tgz"; - sha256 = "1334856x7jqhv52wlab6wxmfqslj21pmryx3lwmlsn7c3ypwz4rw"; - system = "epmd-test"; - asd = "epmd-test"; - }); - systems = [ "epmd-test" ]; - lispLibs = [ (getAttr "epmd" self) (getAttr "fiveam" self) (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - equals = (build-asdf-system { - pname = "equals"; - version = "20241012-git"; - asds = [ "equals" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/equals/2024-10-12/equals-20241012-git.tgz"; - sha256 = "1pzhj748dgjcw6qffkykxx156y78wy3bsbqmq5ijkybfjpnfsg27"; - system = "equals"; - asd = "equals"; - }); - systems = [ "equals" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - erjoalgo-webutil = (build-asdf-system { - pname = "erjoalgo-webutil"; - version = "20241012-git"; - asds = [ "erjoalgo-webutil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/erjoalgo-webutil/2024-10-12/erjoalgo-webutil-20241012-git.tgz"; - sha256 = "1mf9f23p6pagdi97k306a6122a5djx06nfwsxnx61gbyir2cpl2c"; - system = "erjoalgo-webutil"; - asd = "erjoalgo-webutil"; - }); - systems = [ "erjoalgo-webutil" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "fiasco" self) (getAttr "gzip-stream" self) (getAttr "hunchentoot" self) (getAttr "vom" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - erlang-term = (build-asdf-system { - pname = "erlang-term"; - version = "20220220-git"; - asds = [ "erlang-term" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-erlang-term/2022-02-20/cl-erlang-term-20220220-git.tgz"; - sha256 = "1rmnbirbvwmik3j0xkkn90kzx90klrwx7hmscl0ywcbaprm71wkv"; - system = "erlang-term"; - asd = "erlang-term"; - }); - systems = [ "erlang-term" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "ieee-floats" self) (getAttr "nibbles" self) (getAttr "zlib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - erlang-term-test = (build-asdf-system { - pname = "erlang-term-test"; - version = "20220220-git"; - asds = [ "erlang-term-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-erlang-term/2022-02-20/cl-erlang-term-20220220-git.tgz"; - sha256 = "1rmnbirbvwmik3j0xkkn90kzx90klrwx7hmscl0ywcbaprm71wkv"; - system = "erlang-term-test"; - asd = "erlang-term-test"; - }); - systems = [ "erlang-term-test" ]; - lispLibs = [ (getAttr "erlang-term" self) (getAttr "fiveam" self) (getAttr "nibbles" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ernestine = (build-asdf-system { - pname = "ernestine"; - version = "20220220-git"; - asds = [ "ernestine" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ernestine/2022-02-20/ernestine-20220220-git.tgz"; - sha256 = "1gl8pjp44j01nfw9dzk1qdl6njnqcaccp5czcr5rq47l1aicrymn"; - system = "ernestine"; - asd = "ernestine"; - }); - systems = [ "ernestine" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cl-prevalence" self) (getAttr "drakma" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ernestine-tests = (build-asdf-system { - pname = "ernestine-tests"; - version = "20220220-git"; - asds = [ "ernestine-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ernestine/2022-02-20/ernestine-20220220-git.tgz"; - sha256 = "1gl8pjp44j01nfw9dzk1qdl6njnqcaccp5czcr5rq47l1aicrymn"; - system = "ernestine-tests"; - asd = "ernestine-tests"; - }); - systems = [ "ernestine-tests" ]; - lispLibs = [ (getAttr "ernestine" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - erudite = (build-asdf-system { - pname = "erudite"; - version = "20241012-git"; - asds = [ "erudite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/erudite/2024-10-12/erudite-20241012-git.tgz"; - sha256 = "159fmpm770rnixdpzpmzvqzd2kpns5mglpdxykvv2lqlnac24jn5"; - system = "erudite"; - asd = "erudite"; - }); - systems = [ "erudite" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "cl-template" self) (getAttr "log4cl" self) (getAttr "split-sequence" self) (getAttr "swank-client" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - erudite-test = (build-asdf-system { - pname = "erudite-test"; - version = "20241012-git"; - asds = [ "erudite-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/erudite/2024-10-12/erudite-20241012-git.tgz"; - sha256 = "159fmpm770rnixdpzpmzvqzd2kpns5mglpdxykvv2lqlnac24jn5"; - system = "erudite-test"; - asd = "erudite-test"; - }); - systems = [ "erudite-test" ]; - lispLibs = [ (getAttr "erudite" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - esa-mcclim = (build-asdf-system { - pname = "esa-mcclim"; - version = "20241012-git"; - asds = [ "esa-mcclim" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "esa-mcclim"; - asd = "esa-mcclim"; - }); - systems = [ "esa-mcclim" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "clim-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - escalator = (build-asdf-system { - pname = "escalator"; - version = "20200427-git"; - asds = [ "escalator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/escalator/2020-04-27/escalator-20200427-git.tgz"; - sha256 = "136n4k983f90cqj6na17ff2fvk9rv4ma8l5y66q7lkbb69idipla"; - system = "escalator"; - asd = "escalator"; - }); - systems = [ "escalator" ]; - lispLibs = [ (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - escalator-bench = (build-asdf-system { - pname = "escalator-bench"; - version = "20200427-git"; - asds = [ "escalator-bench" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/escalator/2020-04-27/escalator-20200427-git.tgz"; - sha256 = "136n4k983f90cqj6na17ff2fvk9rv4ma8l5y66q7lkbb69idipla"; - system = "escalator-bench"; - asd = "escalator-bench"; - }); - systems = [ "escalator-bench" ]; - lispLibs = [ (getAttr "escalator" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - esrap = (build-asdf-system { - pname = "esrap"; - version = "20241012-git"; - asds = [ "esrap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/esrap/2024-10-12/esrap-20241012-git.tgz"; - sha256 = "0pvid1hld03vz2zyszvsxckcpjb2lfl2vjfig6dlrmw3dx8grdj0"; - system = "esrap"; - asd = "esrap"; - }); - systems = [ "esrap" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-with-current-source-form" self) ]; - meta = {}; - }); - esrap-liquid = (build-asdf-system { - pname = "esrap-liquid"; - version = "20161031-git"; - asds = [ "esrap-liquid" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/esrap-liquid/2016-10-31/esrap-liquid-20161031-git.tgz"; - sha256 = "0agsi8qx6v3c7r6ri5rp78vdb570pdgkvw80va3045crl61mkjzs"; - system = "esrap-liquid"; - asd = "esrap-liquid"; - }); - systems = [ "esrap-liquid" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - esrap-liquid-tests = (build-asdf-system { - pname = "esrap-liquid-tests"; - version = "20161031-git"; - asds = [ "esrap-liquid-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/esrap-liquid/2016-10-31/esrap-liquid-20161031-git.tgz"; - sha256 = "0agsi8qx6v3c7r6ri5rp78vdb570pdgkvw80va3045crl61mkjzs"; - system = "esrap-liquid-tests"; - asd = "esrap-liquid"; - }); - systems = [ "esrap-liquid-tests" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "esrap-liquid" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - esrap-peg = (build-asdf-system { - pname = "esrap-peg"; - version = "20191007-git"; - asds = [ "esrap-peg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/esrap-peg/2019-10-07/esrap-peg-20191007-git.tgz"; - sha256 = "0540i7whx1w0n9fdakwk8rnn511xga9xfvczq9y1jcgz1hh42w53"; - system = "esrap-peg"; - asd = "esrap-peg"; - }); - systems = [ "esrap-peg" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-unification" self) (getAttr "esrap" self) (getAttr "iterate" self) ]; - meta = {}; - }); - etcd-test = (build-asdf-system { - pname = "etcd-test"; - version = "20230214-git"; - asds = [ "etcd-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-etcd/2023-02-14/cl-etcd-20230214-git.tgz"; - sha256 = "0bals10r07prxvjxd744vz02ri72isf168lkhrx9qkc96hd214ah"; - system = "etcd-test"; - asd = "etcd-test"; - }); - systems = [ "etcd-test" ]; - lispLibs = [ (getAttr "cl-etcd" self) (getAttr "cl-toml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ev = (build-asdf-system { - pname = "ev"; - version = "20150923-git"; - asds = [ "ev" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ev/2015-09-23/cl-ev-20150923-git.tgz"; - sha256 = "0qnkzkw9mn4w6b0q9y207z8ddnd5a2gn42q55yycp2qrvvv47lhp"; - system = "ev"; - asd = "ev"; - }); - systems = [ "ev" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - evaled-when = (build-asdf-system { - pname = "evaled-when"; - version = "1.0"; - asds = [ "evaled-when" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/evaled-when/2020-09-25/evaled-when_1.0.tgz"; - sha256 = "0482s89nb5jyyg5wmb010p914pgq6ls8z5s12hdw7wrpy675kdkh"; - system = "evaled-when"; - asd = "evaled-when"; - }); - systems = [ "evaled-when" ]; - lispLibs = [ (getAttr "trivial-cltl2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - evaled-when__tests = (build-asdf-system { - pname = "evaled-when_tests"; - version = "1.0"; - asds = [ "evaled-when_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/evaled-when/2020-09-25/evaled-when_1.0.tgz"; - sha256 = "0482s89nb5jyyg5wmb010p914pgq6ls8z5s12hdw7wrpy675kdkh"; - system = "evaled-when_tests"; - asd = "evaled-when_tests"; - }); - systems = [ "evaled-when_tests" ]; - lispLibs = [ (getAttr "enhanced-boolean" self) (getAttr "evaled-when" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - event-emitter = (build-asdf-system { - pname = "event-emitter"; - version = "20241012-git"; - asds = [ "event-emitter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/event-emitter/2024-10-12/event-emitter-20241012-git.tgz"; - sha256 = "0kj77r09wbsiq6n62vvgk9fh37p3n3ycmhln1mhswz24rhirnpyn"; - system = "event-emitter"; - asd = "event-emitter"; - }); - systems = [ "event-emitter" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - event-emitter-benchmark = (build-asdf-system { - pname = "event-emitter-benchmark"; - version = "20241012-git"; - asds = [ "event-emitter-benchmark" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/event-emitter/2024-10-12/event-emitter-20241012-git.tgz"; - sha256 = "0kj77r09wbsiq6n62vvgk9fh37p3n3ycmhln1mhswz24rhirnpyn"; - system = "event-emitter-benchmark"; - asd = "event-emitter-benchmark"; - }); - systems = [ "event-emitter-benchmark" ]; - lispLibs = [ (getAttr "event-emitter" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - event-emitter-test = (build-asdf-system { - pname = "event-emitter-test"; - version = "20241012-git"; - asds = [ "event-emitter-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/event-emitter/2024-10-12/event-emitter-20241012-git.tgz"; - sha256 = "0kj77r09wbsiq6n62vvgk9fh37p3n3ycmhln1mhswz24rhirnpyn"; - system = "event-emitter-test"; - asd = "event-emitter-test"; - }); - systems = [ "event-emitter-test" ]; - lispLibs = [ (getAttr "event-emitter" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - event-glue = (build-asdf-system { - pname = "event-glue"; - version = "20150608-git"; - asds = [ "event-glue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/event-glue/2015-06-08/event-glue-20150608-git.tgz"; - sha256 = "1cmxdx5nawzqafz9b6nswp20d3zlaks44ln4n6bf5jxji9n3vany"; - system = "event-glue"; - asd = "event-glue"; - }); - systems = [ "event-glue" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - event-glue-test = (build-asdf-system { - pname = "event-glue-test"; - version = "20150608-git"; - asds = [ "event-glue-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/event-glue/2015-06-08/event-glue-20150608-git.tgz"; - sha256 = "1cmxdx5nawzqafz9b6nswp20d3zlaks44ln4n6bf5jxji9n3vany"; - system = "event-glue-test"; - asd = "event-glue-test"; - }); - systems = [ "event-glue-test" ]; - lispLibs = [ (getAttr "event-glue" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eventbus = (build-asdf-system { - pname = "eventbus"; - version = "20191227-git"; - asds = [ "eventbus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eventbus/2019-12-27/eventbus-20191227-git.tgz"; - sha256 = "0slqx3zq6sbz3rg4g79j8y25sx4405y6ff3x6l5v8v4v42m1s0p2"; - system = "eventbus"; - asd = "eventbus"; - }); - systems = [ "eventbus" ]; - lispLibs = [ (getAttr "simplet-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - eventfd = (build-asdf-system { - pname = "eventfd"; - version = "20171130-git"; - asds = [ "eventfd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eventfd/2017-11-30/eventfd-20171130-git.tgz"; - sha256 = "1zwg043vqzk665k9dxgxhik20wgkl204anjna94zg6037m33vdiw"; - system = "eventfd"; - asd = "eventfd"; - }); - systems = [ "eventfd" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi-grovel" self) (getAttr "iolib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - everblocking-stream = (build-asdf-system { - pname = "everblocking-stream"; - version = "20181018-git"; - asds = [ "everblocking-stream" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/everblocking-stream/2018-10-18/everblocking-stream-20181018-git.tgz"; - sha256 = "1xvfsx2ldwcprlynikn1rikxh3lfdyzl2p72glzvgh20sm93p1rz"; - system = "everblocking-stream"; - asd = "everblocking-stream"; - }); - systems = [ "everblocking-stream" ]; - lispLibs = [ (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - evol = (build-asdf-system { - pname = "evol"; - version = "20101006-git"; - asds = [ "evol" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/evol/2010-10-06/evol-20101006-git.tgz"; - sha256 = "1hp6wygj44llkscqq721xg4a7j5faqjcfc646lvkia5xg81zbf65"; - system = "evol"; - asd = "evol"; - }); - systems = [ "evol" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "external-program" self) (getAttr "patron" self) (getAttr "unix-options" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - evol-test = (build-asdf-system { - pname = "evol-test"; - version = "20101006-git"; - asds = [ "evol-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/evol/2010-10-06/evol-20101006-git.tgz"; - sha256 = "1hp6wygj44llkscqq721xg4a7j5faqjcfc646lvkia5xg81zbf65"; - system = "evol-test"; - asd = "evol-test"; - }); - systems = [ "evol-test" ]; - lispLibs = [ (getAttr "evol" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - example-bot = (build-asdf-system { - pname = "example-bot"; - version = "20241012-git"; - asds = [ "example-bot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispcord/2024-10-12/lispcord-20241012-git.tgz"; - sha256 = "11xwrrvvqdm1wdnxrxqgizgw25plsn28n2k0lm5kakax9n221brn"; - system = "example-bot"; - asd = "example-bot"; - }); - systems = [ "example-bot" ]; - lispLibs = [ (getAttr "lispcord" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - exit-hooks = (build-asdf-system { - pname = "exit-hooks"; - version = "20170403-git"; - asds = [ "exit-hooks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/exit-hooks/2017-04-03/exit-hooks-20170403-git.tgz"; - sha256 = "00rk0pr2cy3hy6giblh166b7yrg06d5lanipjcqv508gkfb0vi47"; - system = "exit-hooks"; - asd = "exit-hooks"; - }); - systems = [ "exit-hooks" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - exponential-backoff = (build-asdf-system { - pname = "exponential-backoff"; - version = "20150113-git"; - asds = [ "exponential-backoff" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/exponential-backoff/2015-01-13/exponential-backoff-20150113-git.tgz"; - sha256 = "1389hm9hxv85s0125ja4js1bvh8ay4dsy9q1gaynjv27ynik6gmv"; - system = "exponential-backoff"; - asd = "exponential-backoff"; - }); - systems = [ "exponential-backoff" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - exscribe = (build-asdf-system { - pname = "exscribe"; - version = "20200925-git"; - asds = [ "exscribe" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/exscribe/2020-09-25/exscribe-20200925-git.tgz"; - sha256 = "02vsavasr5nbhrk86b7d8xpr6sm8cyrg3vs2pbpkls2iypffyd2h"; - system = "exscribe"; - asd = "exscribe"; - }); - systems = [ "exscribe" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "fare-memoization" self) (getAttr "fare-scripts" self) (getAttr "fare-utils" self) (getAttr "quri" self) (getAttr "scribble" self) (getAttr "trivia_dot_quasiquote" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ext-blog = (build-asdf-system { - pname = "ext-blog"; - version = "20160825-git"; - asds = [ "ext-blog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ext-blog/2016-08-25/ext-blog-20160825-git.tgz"; - sha256 = "10qnl3p994wg12c0cn6xgkgmwfip0fk0sjyqyy0j5bdrp32gr5wg"; - system = "ext-blog"; - asd = "ext-blog"; - }); - systems = [ "ext-blog" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cl-store" self) (getAttr "closure-template" self) (getAttr "image" self) (getAttr "kl-verify" self) (getAttr "local-time" self) (getAttr "restas" self) (getAttr "restas_dot_file-publisher" self) (getAttr "s-xml-rpc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - extended-reals = (build-asdf-system { - pname = "extended-reals"; - version = "20180328-git"; - asds = [ "extended-reals" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/extended-reals/2018-03-28/extended-reals-20180328-git.tgz"; - sha256 = "0vq191win5sq37mrwjhvi463jqh1mkwbsa0hja69syq789pgaxmb"; - system = "extended-reals"; - asd = "extended-reals"; - }); - systems = [ "extended-reals" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - extensible-sequences = (build-asdf-system { - pname = "extensible-sequences"; - version = "20130813-darcs"; - asds = [ "extensible-sequences" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sequence-iterators/2013-08-13/sequence-iterators-20130813-darcs.tgz"; - sha256 = "12flvy6hysqw0fa2jfkxrgphlk6b25hg2w2dxm1ylax0gw9fh1l5"; - system = "extensible-sequences"; - asd = "extensible-sequences"; - }); - systems = [ "extensible-sequences" ]; - lispLibs = [ (getAttr "sequence-iterators" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - external-program = (build-asdf-system { - pname = "external-program"; - version = "20241012-git"; - asds = [ "external-program" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/external-program/2024-10-12/external-program-20241012-git.tgz"; - sha256 = "1g7hawsbbfspzljj2spxxv26a5079xsa0kd7dqdclm5n71fypwx6"; - system = "external-program"; - asd = "external-program"; - }); - systems = [ "external-program" ]; - lispLibs = [ (getAttr "trivial-features" self) ]; - meta = {}; - }); - external-program-test = (build-asdf-system { - pname = "external-program-test"; - version = "20241012-git"; - asds = [ "external-program-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/external-program/2024-10-12/external-program-20241012-git.tgz"; - sha256 = "1g7hawsbbfspzljj2spxxv26a5079xsa0kd7dqdclm5n71fypwx6"; - system = "external-program-test"; - asd = "external-program"; - }); - systems = [ "external-program-test" ]; - lispLibs = [ (getAttr "external-program" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - external-symbol-not-found = (build-asdf-system { - pname = "external-symbol-not-found"; - version = "20241012-git"; - asds = [ "external-symbol-not-found" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/external-symbol-not-found/2024-10-12/external-symbol-not-found-20241012-git.tgz"; - sha256 = "1ic982jbcy71wlni60wnb8hqg3cqw488h4jj5pd2sqmjwv1960v7"; - system = "external-symbol-not-found"; - asd = "external-symbol-not-found"; - }); - systems = [ "external-symbol-not-found" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - f-underscore = (build-asdf-system { - pname = "f-underscore"; - version = "20101006-darcs"; - asds = [ "f-underscore" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f-underscore/2010-10-06/f-underscore-20101006-darcs.tgz"; - sha256 = "0mqvb2rxa08y07lj6smp8gf1ig32802fxq7mw5a283f2nkrinnb5"; - system = "f-underscore"; - asd = "f-underscore"; - }); - systems = [ "f-underscore" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - f2cl = (build-asdf-system { - pname = "f2cl"; - version = "20231021-git"; - asds = [ "f2cl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "f2cl"; - asd = "f2cl"; - }); - systems = [ "f2cl" ]; - lispLibs = [ (getAttr "f2cl-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - f2cl-asdf = (build-asdf-system { - pname = "f2cl-asdf"; - version = "20231021-git"; - asds = [ "f2cl-asdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "f2cl-asdf"; - asd = "f2cl-asdf"; - }); - systems = [ "f2cl-asdf" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - f2cl-lib = (build-asdf-system { - pname = "f2cl-lib"; - version = "20220220-git"; - asds = [ "f2cl-lib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "f2cl-lib"; - asd = "f2cl-lib"; - }); - systems = [ "f2cl-lib" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fact-base = (build-asdf-system { - pname = "fact-base"; - version = "20180328-git"; - asds = [ "fact-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fact-base/2018-03-28/fact-base-20180328-git.tgz"; - sha256 = "14i0vqqxszabhas0z9dfxhvnbsxl4iic77m4i76w7iznmrcma2ar"; - system = "fact-base"; - asd = "fact-base"; - }); - systems = [ "fact-base" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "local-time" self) (getAttr "optima" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - factory-alien = (build-asdf-system { - pname = "factory-alien"; - version = "20230618-git"; - asds = [ "factory-alien" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/factory-alien/2023-06-18/factory-alien-20230618-git.tgz"; - sha256 = "0n1fwxapl9vr0cm66gkhihws6zhvg2f4acx017lavn0g42b5fc4a"; - system = "factory-alien"; - asd = "factory-alien"; - }); - systems = [ "factory-alien" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fakenil = (build-asdf-system { - pname = "fakenil"; - version = "1.0"; - asds = [ "fakenil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fakenil/2020-03-25/fakenil_1.0.tgz"; - sha256 = "0ipqax3sgcs1dsgxz8d2pmfg324k6l35pn0nz89w5jl02fia61l3"; - system = "fakenil"; - asd = "fakenil"; - }); - systems = [ "fakenil" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fakenil__tests = (build-asdf-system { - pname = "fakenil_tests"; - version = "1.0"; - asds = [ "fakenil_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fakenil/2020-03-25/fakenil_1.0.tgz"; - sha256 = "0ipqax3sgcs1dsgxz8d2pmfg324k6l35pn0nz89w5jl02fia61l3"; - system = "fakenil_tests"; - asd = "fakenil_tests"; - }); - systems = [ "fakenil_tests" ]; - lispLibs = [ (getAttr "fakenil" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fare-csv = (build-asdf-system { - pname = "fare-csv"; - version = "20241012-git"; - asds = [ "fare-csv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fare-csv/2024-10-12/fare-csv-20241012-git.tgz"; - sha256 = "153sxb0vyd1cnhfw15j3183kqhcnma0ygaf5svzibknclm16n767"; - system = "fare-csv"; - asd = "fare-csv"; - }); - systems = [ "fare-csv" ]; - lispLibs = [ ]; - meta = {}; - }); - fare-memoization = (build-asdf-system { - pname = "fare-memoization"; - version = "20180430-git"; - asds = [ "fare-memoization" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fare-memoization/2018-04-30/fare-memoization-20180430-git.tgz"; - sha256 = "1blmrb4c9gsxj87scz74z1s8w9d1w2r48fyxj0y1sw3vr6bsbb8f"; - system = "fare-memoization"; - asd = "fare-memoization"; - }); - systems = [ "fare-memoization" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fare-mop = (build-asdf-system { - pname = "fare-mop"; - version = "20151218-git"; - asds = [ "fare-mop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fare-mop/2015-12-18/fare-mop-20151218-git.tgz"; - sha256 = "0maxs8392953fhnaa6zwnm2mdbhxjxipp4g4rvypm06ixr6pyv1c"; - system = "fare-mop"; - asd = "fare-mop"; - }); - systems = [ "fare-mop" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "fare-utils" self) ]; - meta = {}; - }); - fare-quasiquote = (build-asdf-system { - pname = "fare-quasiquote"; - version = "20200925-git"; - asds = [ "fare-quasiquote" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fare-quasiquote/2020-09-25/fare-quasiquote-20200925-git.tgz"; - sha256 = "034mw3x0jv6q5nxqq8sz77c44dc115x6y52bnzk31qclib88zl7n"; - system = "fare-quasiquote"; - asd = "fare-quasiquote"; - }); - systems = [ "fare-quasiquote" ]; - lispLibs = [ (getAttr "fare-utils" self) ]; - meta = {}; - }); - fare-quasiquote-extras = (build-asdf-system { - pname = "fare-quasiquote-extras"; - version = "20200925-git"; - asds = [ "fare-quasiquote-extras" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fare-quasiquote/2020-09-25/fare-quasiquote-20200925-git.tgz"; - sha256 = "034mw3x0jv6q5nxqq8sz77c44dc115x6y52bnzk31qclib88zl7n"; - system = "fare-quasiquote-extras"; - asd = "fare-quasiquote-extras"; - }); - systems = [ "fare-quasiquote-extras" ]; - lispLibs = [ (getAttr "fare-quasiquote-optima" self) (getAttr "fare-quasiquote-readtable" self) ]; - meta = {}; - }); - fare-quasiquote-optima = (build-asdf-system { - pname = "fare-quasiquote-optima"; - version = "20200925-git"; - asds = [ "fare-quasiquote-optima" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fare-quasiquote/2020-09-25/fare-quasiquote-20200925-git.tgz"; - sha256 = "034mw3x0jv6q5nxqq8sz77c44dc115x6y52bnzk31qclib88zl7n"; - system = "fare-quasiquote-optima"; - asd = "fare-quasiquote-optima"; - }); - systems = [ "fare-quasiquote-optima" ]; - lispLibs = [ (getAttr "trivia_dot_quasiquote" self) ]; - meta = {}; - }); - fare-quasiquote-readtable = (build-asdf-system { - pname = "fare-quasiquote-readtable"; - version = "20200925-git"; - asds = [ "fare-quasiquote-readtable" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fare-quasiquote/2020-09-25/fare-quasiquote-20200925-git.tgz"; - sha256 = "034mw3x0jv6q5nxqq8sz77c44dc115x6y52bnzk31qclib88zl7n"; - system = "fare-quasiquote-readtable"; - asd = "fare-quasiquote-readtable"; - }); - systems = [ "fare-quasiquote-readtable" ]; - lispLibs = [ (getAttr "fare-quasiquote" self) (getAttr "named-readtables" self) ]; - meta = {}; - }); - fare-scripts = (build-asdf-system { - pname = "fare-scripts"; - version = "20241012-git"; - asds = [ "fare-scripts" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fare-scripts/2024-10-12/fare-scripts-20241012-git.tgz"; - sha256 = "08fq1ry4prlww4gr7zris7vywqs3vm1253mqfgx8vg0awrccmf98"; - system = "fare-scripts"; - asd = "fare-scripts"; - }); - systems = [ "fare-scripts" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "binascii" self) (getAttr "cl-launch" self) (getAttr "cl-mime" self) (getAttr "cl-ppcre" self) (getAttr "cl-scripting" self) (getAttr "cl-unicode" self) (getAttr "command-line-arguments" self) (getAttr "fare-utils" self) (getAttr "inferior-shell" self) (getAttr "optima" self) (getAttr "optima_dot_ppcre" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fare-utils = (build-asdf-system { - pname = "fare-utils"; - version = "20230214-git"; - asds = [ "fare-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fare-utils/2023-02-14/fare-utils-20230214-git.tgz"; - sha256 = "0kw6xzavzvpzac3xa6x4681q6w6v6bjk1g71flr2x9xixxg61sak"; - system = "fare-utils"; - asd = "fare-utils"; - }); - systems = [ "fare-utils" ]; - lispLibs = [ ]; - meta = {}; - }); - fare-utils-test = (build-asdf-system { - pname = "fare-utils-test"; - version = "20230214-git"; - asds = [ "fare-utils-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fare-utils/2023-02-14/fare-utils-20230214-git.tgz"; - sha256 = "0kw6xzavzvpzac3xa6x4681q6w6v6bjk1g71flr2x9xixxg61sak"; - system = "fare-utils-test"; - asd = "fare-utils-test"; - }); - systems = [ "fare-utils-test" ]; - lispLibs = [ (getAttr "fare-utils" self) (getAttr "hu_dot_dwim_dot_stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fast-http = (build-asdf-system { - pname = "fast-http"; - version = "20241012-git"; - asds = [ "fast-http" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fast-http/2024-10-12/fast-http-20241012-git.tgz"; - sha256 = "04cxh2241l9hyzarrxs528v2jjdfm5g3prc2374m4xkrb0wiygh0"; - system = "fast-http"; - asd = "fast-http"; - }); - systems = [ "fast-http" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-utilities" self) (getAttr "proc-parse" self) (getAttr "smart-buffer" self) (getAttr "xsubseq" self) ]; - meta = {}; - }); - fast-http-test = (build-asdf-system { - pname = "fast-http-test"; - version = "20241012-git"; - asds = [ "fast-http-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fast-http/2024-10-12/fast-http-20241012-git.tgz"; - sha256 = "04cxh2241l9hyzarrxs528v2jjdfm5g3prc2374m4xkrb0wiygh0"; - system = "fast-http-test"; - asd = "fast-http-test"; - }); - systems = [ "fast-http-test" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-syntax-interpol" self) (getAttr "fast-http" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "xsubseq" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fast-io = (build-asdf-system { - pname = "fast-io"; - version = "20221106-git"; - asds = [ "fast-io" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fast-io/2022-11-06/fast-io-20221106-git.tgz"; - sha256 = "0wh02yagbqahy9z6787jz5ggpagvr18qd0z13wvwq1vjf8xd2530"; - system = "fast-io"; - asd = "fast-io"; - }); - systems = [ "fast-io" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "static-vectors" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - fast-io-test = (build-asdf-system { - pname = "fast-io-test"; - version = "20221106-git"; - asds = [ "fast-io-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fast-io/2022-11-06/fast-io-20221106-git.tgz"; - sha256 = "0wh02yagbqahy9z6787jz5ggpagvr18qd0z13wvwq1vjf8xd2530"; - system = "fast-io-test"; - asd = "fast-io-test"; - }); - systems = [ "fast-io-test" ]; - lispLibs = [ (getAttr "checkl" self) (getAttr "fast-io" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fast-mpsc-queue = (build-asdf-system { - pname = "fast-mpsc-queue"; - version = "20241012-git"; - asds = [ "fast-mpsc-queue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fast-mpsc-queue/2024-10-12/fast-mpsc-queue-20241012-git.tgz"; - sha256 = "1ggiaryjv3lmzrk6m22y7vvbqn3z0n7ahmkyfjq6iyrd64d77ck7"; - system = "fast-mpsc-queue"; - asd = "fast-mpsc-queue"; - }); - systems = [ "fast-mpsc-queue" ]; - lispLibs = [ (getAttr "metabang-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fast-websocket = (build-asdf-system { - pname = "fast-websocket"; - version = "20241012-git"; - asds = [ "fast-websocket" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fast-websocket/2024-10-12/fast-websocket-20241012-git.tgz"; - sha256 = "102z58d27966lpx08kc6apgaainbsdfhygb67ibyw6lxnaasy3jz"; - system = "fast-websocket"; - asd = "fast-websocket"; - }); - systems = [ "fast-websocket" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "fast-io" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fast-websocket-test = (build-asdf-system { - pname = "fast-websocket-test"; - version = "20241012-git"; - asds = [ "fast-websocket-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fast-websocket/2024-10-12/fast-websocket-20241012-git.tgz"; - sha256 = "102z58d27966lpx08kc6apgaainbsdfhygb67ibyw6lxnaasy3jz"; - system = "fast-websocket-test"; - asd = "fast-websocket-test"; - }); - systems = [ "fast-websocket-test" ]; - lispLibs = [ (getAttr "fast-io" self) (getAttr "fast-websocket" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - feeder = (build-asdf-system { - pname = "feeder"; - version = "20231021-git"; - asds = [ "feeder" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/feeder/2023-10-21/feeder-20231021-git.tgz"; - sha256 = "00j3s98lbh6h2p007s7x48rw0ckd3c1apfwb28y89jxnwqk7sng7"; - system = "feeder"; - asd = "feeder"; - }); - systems = [ "feeder" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "local-time" self) (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - femlisp = (build-asdf-system { - pname = "femlisp"; - version = "20210411-git"; - asds = [ "femlisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; - sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; - system = "femlisp"; - asd = "femlisp"; - }); - systems = [ "femlisp" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "femlisp-basic" self) (getAttr "femlisp-dictionary" self) (getAttr "femlisp-matlisp" self) (getAttr "femlisp-parallel" self) (getAttr "flexi-streams" self) (getAttr "infix" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - femlisp-basic = (build-asdf-system { - pname = "femlisp-basic"; - version = "20210411-git"; - asds = [ "femlisp-basic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; - sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; - system = "femlisp-basic"; - asd = "femlisp-basic"; - }); - systems = [ "femlisp-basic" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - femlisp-dictionary = (build-asdf-system { - pname = "femlisp-dictionary"; - version = "20210411-git"; - asds = [ "femlisp-dictionary" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; - sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; - system = "femlisp-dictionary"; - asd = "femlisp-dictionary"; - }); - systems = [ "femlisp-dictionary" ]; - lispLibs = [ (getAttr "femlisp-basic" self) (getAttr "femlisp-parallel" self) (getAttr "trees" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - femlisp-matlisp = (build-asdf-system { - pname = "femlisp-matlisp"; - version = "20210411-git"; - asds = [ "femlisp-matlisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; - sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; - system = "femlisp-matlisp"; - asd = "femlisp-matlisp"; - }); - systems = [ "femlisp-matlisp" ]; - lispLibs = [ (getAttr "femlisp-basic" self) (getAttr "femlisp-dictionary" self) (getAttr "femlisp-parallel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - femlisp-parallel = (build-asdf-system { - pname = "femlisp-parallel"; - version = "20210411-git"; - asds = [ "femlisp-parallel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; - sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; - system = "femlisp-parallel"; - asd = "femlisp-parallel"; - }); - systems = [ "femlisp-parallel" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-cpu-affinity" self) (getAttr "cl-ppcre" self) (getAttr "femlisp-basic" self) (getAttr "lparallel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - femlisp-picture = (build-asdf-system { - pname = "femlisp-picture"; - version = "20210411-git"; - asds = [ "femlisp-picture" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; - sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; - system = "femlisp-picture"; - asd = "femlisp-picture"; - }); - systems = [ "femlisp-picture" ]; - lispLibs = [ (getAttr "cl-gd" self) (getAttr "femlisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ffa = (build-asdf-system { - pname = "ffa"; - version = "20101006-git"; - asds = [ "ffa" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ffa/2010-10-06/ffa-20101006-git.tgz"; - sha256 = "0l7kqcjp3sn1129hpwq6zhjqc0ydx9gc53z7k13i38x3z1asap7a"; - system = "ffa"; - asd = "ffa"; - }); - systems = [ "ffa" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-utilities" self) (getAttr "iterate" self) (getAttr "metabang-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fft = (build-asdf-system { - pname = "fft"; - version = "20180711-git"; - asds = [ "fft" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fft/2018-07-11/fft-20180711-git.tgz"; - sha256 = "0ymnfplap2cncw49mhq7crapgxphfwsvqdgrcckpgsvw6qsymasd"; - system = "fft"; - asd = "fft"; - }); - systems = [ "fft" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fftpack5 = (build-asdf-system { - pname = "fftpack5"; - version = "20231021-git"; - asds = [ "fftpack5" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "fftpack5"; - asd = "fftpack5"; - }); - systems = [ "fftpack5" ]; - lispLibs = [ (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fftpack5-double = (build-asdf-system { - pname = "fftpack5-double"; - version = "20231021-git"; - asds = [ "fftpack5-double" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "fftpack5-double"; - asd = "fftpack5-double"; - }); - systems = [ "fftpack5-double" ]; - lispLibs = [ (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fiasco = (build-asdf-system { - pname = "fiasco"; - version = "20200610-git"; - asds = [ "fiasco" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fiasco/2020-06-10/fiasco-20200610-git.tgz"; - sha256 = "1k8i2kq57201bvy3zfpsxld530hd104dgbglxigqb6i408c1a7aw"; - system = "fiasco"; - asd = "fiasco"; - }); - systems = [ "fiasco" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - fiasco-self-tests = (build-asdf-system { - pname = "fiasco-self-tests"; - version = "20200610-git"; - asds = [ "fiasco-self-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fiasco/2020-06-10/fiasco-20200610-git.tgz"; - sha256 = "1k8i2kq57201bvy3zfpsxld530hd104dgbglxigqb6i408c1a7aw"; - system = "fiasco-self-tests"; - asd = "fiasco"; - }); - systems = [ "fiasco-self-tests" ]; - lispLibs = [ (getAttr "fiasco" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - file-attributes = (build-asdf-system { - pname = "file-attributes"; - version = "20241012-git"; - asds = [ "file-attributes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/file-attributes/2024-10-12/file-attributes-20241012-git.tgz"; - sha256 = "14jimsmwcp8bygm2f0fjmjv0ncc5yxl7pvh04x0kw6gs1mc7rc9x"; - system = "file-attributes"; - asd = "file-attributes"; - }); - systems = [ "file-attributes" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) ]; - meta = {}; - }); - file-finder = (build-asdf-system { - pname = "file-finder"; - version = "20241012-git"; - asds = [ "file-finder" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/file-finder/2024-10-12/file-finder-20241012-git.tgz"; - sha256 = "11cjyyngvydcq2sbgsqkxd9060a0cb3ndqrqr318djndf30ckmqx"; - system = "file-finder"; - asd = "file-finder"; - }); - systems = [ "file-finder" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "file-attributes" self) (getAttr "local-time" self) (getAttr "named-readtables" self) (getAttr "serapeum" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - file-local-variable = (build-asdf-system { - pname = "file-local-variable"; - version = "20160318-git"; - asds = [ "file-local-variable" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/file-local-variable/2016-03-18/file-local-variable-20160318-git.tgz"; - sha256 = "1jsjd0g41mg76wlqjxliyrfz8fk7ihi06nq2zizmk9np0pmwsxl9"; - system = "file-local-variable"; - asd = "file-local-variable"; - }); - systems = [ "file-local-variable" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - file-local-variable_dot_test = (build-asdf-system { - pname = "file-local-variable.test"; - version = "20160318-git"; - asds = [ "file-local-variable.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/file-local-variable/2016-03-18/file-local-variable-20160318-git.tgz"; - sha256 = "1jsjd0g41mg76wlqjxliyrfz8fk7ihi06nq2zizmk9np0pmwsxl9"; - system = "file-local-variable.test"; - asd = "file-local-variable.test"; - }); - systems = [ "file-local-variable.test" ]; - lispLibs = [ (getAttr "file-local-variable" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - file-lock = (build-asdf-system { - pname = "file-lock"; - version = "20231021-git"; - asds = [ "file-lock" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/file-lock/2023-10-21/file-lock-20231021-git.tgz"; - sha256 = "0n2mn931h83dh2diifsghc78agsz4savlfv5dr9pfmpk16vkwi5b"; - system = "file-lock"; - asd = "file-lock"; - }); - systems = [ "file-lock" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "easy-macros" self) (getAttr "log4cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - file-notify = (build-asdf-system { - pname = "file-notify"; - version = "20241012-git"; - asds = [ "file-notify" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/file-notify/2024-10-12/file-notify-20241012-git.tgz"; - sha256 = "1zxn0smgahbxvy8v2bwmff3262msqhqqc5qpmh4ffinx6azln1hq"; - system = "file-notify"; - asd = "file-notify"; - }); - systems = [ "file-notify" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - file-select = (build-asdf-system { - pname = "file-select"; - version = "20241012-git"; - asds = [ "file-select" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/file-select/2024-10-12/file-select-20241012-git.tgz"; - sha256 = "0vp7qfqymlw21yrlfack799xjwyh23dyxnbc5ix4fnylpi1lxjbn"; - system = "file-select"; - asd = "file-select"; - }); - systems = [ "file-select" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "float-features" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - file-types = (build-asdf-system { - pname = "file-types"; - version = "20160929-git"; - asds = [ "file-types" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/file-types/2016-09-29/file-types-20160929-git.tgz"; - sha256 = "09l67gzjwx7kx237grm709dsj9rkmmm8s3ya6irmcw8nh587inbs"; - system = "file-types"; - asd = "file-types"; - }); - systems = [ "file-types" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - filesystem-utils = (build-asdf-system { - pname = "filesystem-utils"; - version = "20241012-git"; - asds = [ "filesystem-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/filesystem-utils/2024-10-12/filesystem-utils-20241012-git.tgz"; - sha256 = "0h1xqpc11iachb9yg1d2xrzp1df1qadr1call904cjf45xadn62r"; - system = "filesystem-utils"; - asd = "filesystem-utils"; - }); - systems = [ "filesystem-utils" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "pathname-utils" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - filesystem-utils-test = (build-asdf-system { - pname = "filesystem-utils-test"; - version = "20241012-git"; - asds = [ "filesystem-utils-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/filesystem-utils/2024-10-12/filesystem-utils-20241012-git.tgz"; - sha256 = "0h1xqpc11iachb9yg1d2xrzp1df1qadr1call904cjf45xadn62r"; - system = "filesystem-utils-test"; - asd = "filesystem-utils-test"; - }); - systems = [ "filesystem-utils-test" ]; - lispLibs = [ (getAttr "filesystem-utils" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - filter-maker = (build-asdf-system { - pname = "filter-maker"; - version = "20221106-git"; - asds = [ "filter-maker" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/filter-maker/2022-11-06/filter-maker-20221106-git.tgz"; - sha256 = "00algyghniqsvjy5vwx39fd98nd7x4w944ahy981jlh33lzc2qmn"; - system = "filter-maker"; - asd = "filter-maker"; - }); - systems = [ "filter-maker" ]; - lispLibs = [ (getAttr "mcclim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - filtered-functions = (build-asdf-system { - pname = "filtered-functions"; - version = "20160318-git"; - asds = [ "filtered-functions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/filtered-functions/2016-03-18/filtered-functions-20160318-git.tgz"; - sha256 = "0m13k8pl0gfll8ss83c0z3gax7zrrw2i4s26451jfbka1xr4fgy9"; - system = "filtered-functions"; - asd = "filtered-functions"; - }); - systems = [ "filtered-functions" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - find-port = (build-asdf-system { - pname = "find-port"; - version = "20230214-git"; - asds = [ "find-port" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/find-port/2023-02-14/find-port-20230214-git.tgz"; - sha256 = "1hmbkqazk6m7075gmbrwzxkysp9779xm9qxrzj7p85bwlbk5m5i7"; - system = "find-port"; - asd = "find-port"; - }); - systems = [ "find-port" ]; - lispLibs = [ (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - find-port-test = (build-asdf-system { - pname = "find-port-test"; - version = "20230214-git"; - asds = [ "find-port-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/find-port/2023-02-14/find-port-20230214-git.tgz"; - sha256 = "1hmbkqazk6m7075gmbrwzxkysp9779xm9qxrzj7p85bwlbk5m5i7"; - system = "find-port-test"; - asd = "find-port-test"; - }); - systems = [ "find-port-test" ]; - lispLibs = [ (getAttr "find-port" self) (getAttr "fiveam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - finite-state-machine = (build-asdf-system { - pname = "finite-state-machine"; - version = "20200218-git"; - asds = [ "finite-state-machine" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-simple-fsm/2020-02-18/cl-simple-fsm-20200218-git.tgz"; - sha256 = "1w07df7kakjq3r1v5c4gnavp08ngpn2ni85cggnnsqzc27hly07b"; - system = "finite-state-machine"; - asd = "finite-state-machine"; - }); - systems = [ "finite-state-machine" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - firephp = (build-asdf-system { - pname = "firephp"; - version = "20160531-git"; - asds = [ "firephp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/firephp/2016-05-31/firephp-20160531-git.tgz"; - sha256 = "1j98z73c21xcjp4f8qvmv37y9zlsnwxx88nnxc3r1ngvxv23dlgh"; - system = "firephp"; - asd = "firephp"; - }); - systems = [ "firephp" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - firephp-tests = (build-asdf-system { - pname = "firephp-tests"; - version = "20160531-git"; - asds = [ "firephp-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/firephp/2016-05-31/firephp-20160531-git.tgz"; - sha256 = "1j98z73c21xcjp4f8qvmv37y9zlsnwxx88nnxc3r1ngvxv23dlgh"; - system = "firephp-tests"; - asd = "firephp-tests"; - }); - systems = [ "firephp-tests" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "firephp" self) (getAttr "hu_dot_dwim_dot_stefil" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - first-time-value = (build-asdf-system { - pname = "first-time-value"; - version = "1.0.1"; - asds = [ "first-time-value" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/first-time-value/2018-12-10/first-time-value-1.0.1.tgz"; - sha256 = "155mqhnw1307b18a8bv8jhqp20qv83b409mlr61m45nq3sivxxp2"; - system = "first-time-value"; - asd = "first-time-value"; - }); - systems = [ "first-time-value" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - first-time-value__tests = (build-asdf-system { - pname = "first-time-value_tests"; - version = "1.0.1"; - asds = [ "first-time-value_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/first-time-value/2018-12-10/first-time-value-1.0.1.tgz"; - sha256 = "155mqhnw1307b18a8bv8jhqp20qv83b409mlr61m45nq3sivxxp2"; - system = "first-time-value_tests"; - asd = "first-time-value_tests"; - }); - systems = [ "first-time-value_tests" ]; - lispLibs = [ (getAttr "first-time-value" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fishpack = (build-asdf-system { - pname = "fishpack"; - version = "20231021-git"; - asds = [ "fishpack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "fishpack"; - asd = "fishpack"; - }); - systems = [ "fishpack" ]; - lispLibs = [ (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fiveam = (build-asdf-system { - pname = "fiveam"; - version = "20241012-git"; - asds = [ "fiveam" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fiveam/2024-10-12/fiveam-20241012-git.tgz"; - sha256 = "066amfjqhagzhb602y911wbw7jh9cv1fb7bfn2ppjzm5kf7hqbnh"; - system = "fiveam"; - asd = "fiveam"; - }); - systems = [ "fiveam" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "net_dot_didierverna_dot_asdf-flv" self) (getAttr "trivial-backtrace" self) ]; - meta = {}; - }); - fiveam-asdf = (build-asdf-system { - pname = "fiveam-asdf"; - version = "20221106-git"; - asds = [ "fiveam-asdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fiveam-asdf/2022-11-06/fiveam-asdf-20221106-git.tgz"; - sha256 = "18dhyznwl56lpp289dwg9xm9qwwv5062yawfaj6h1b2jwybqfrq7"; - system = "fiveam-asdf"; - asd = "fiveam-asdf"; - }); - systems = [ "fiveam-asdf" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fiveam-matchers = (build-asdf-system { - pname = "fiveam-matchers"; - version = "20241012-git"; - asds = [ "fiveam-matchers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fiveam-matchers/2024-10-12/fiveam-matchers-20241012-git.tgz"; - sha256 = "1kwichcxjmqdi8whx4daggp4fdp53w17jj1rqlph9ixgr4s9kvqv"; - system = "fiveam-matchers"; - asd = "fiveam-matchers"; - }); - systems = [ "fiveam-matchers" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "fiveam" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fixed = (build-asdf-system { - pname = "fixed"; - version = "20170124-git"; - asds = [ "fixed" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fixed/2017-01-24/fixed-20170124-git.tgz"; - sha256 = "0bx8802fmlml5k5xhcm4g5r6c7ambij4gb0b37xljjn3wxgs83dc"; - system = "fixed"; - asd = "fixed"; - }); - systems = [ "fixed" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - flac = (build-asdf-system { - pname = "flac"; - version = "20151218-git"; - asds = [ "flac" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; - sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; - system = "flac"; - asd = "flac"; - }); - systems = [ "flac" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - flare = (build-asdf-system { - pname = "flare"; - version = "20231021-git"; - asds = [ "flare" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/flare/2023-10-21/flare-20231021-git.tgz"; - sha256 = "1ws357819rr9lzh5b2hmqid6vrq8zj46a5dzwqa0fdmxxbam75zm"; - system = "flare"; - asd = "flare"; - }); - systems = [ "flare" ]; - lispLibs = [ (getAttr "_3d-vectors" self) (getAttr "array-utils" self) (getAttr "documentation-utils" self) (getAttr "for" self) (getAttr "lambda-fiddle" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - flare-viewer = (build-asdf-system { - pname = "flare-viewer"; - version = "20231021-git"; - asds = [ "flare-viewer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/flare/2023-10-21/flare-20231021-git.tgz"; - sha256 = "1ws357819rr9lzh5b2hmqid6vrq8zj46a5dzwqa0fdmxxbam75zm"; - system = "flare-viewer"; - asd = "flare-viewer"; - }); - systems = [ "flare-viewer" ]; - lispLibs = [ (getAttr "cl-opengl" self) (getAttr "flare" self) (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtools" self) (getAttr "qtopengl" self) (getAttr "verbose" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - flat-tree = (build-asdf-system { - pname = "flat-tree"; - version = "20190813-git"; - asds = [ "flat-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-flat-tree/2019-08-13/cl-flat-tree-20190813-git.tgz"; - sha256 = "05nw1j0rr0vgz6shkjv87yn2mp0b4s7v5gxxcqcn1qi7fgbn55z7"; - system = "flat-tree"; - asd = "flat-tree"; - }); - systems = [ "flat-tree" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - flexi-streams = (build-asdf-system { - pname = "flexi-streams"; - version = "20241012-git"; - asds = [ "flexi-streams" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/flexi-streams/2024-10-12/flexi-streams-20241012-git.tgz"; - sha256 = "1bk224ryfiwsmnmq2gdfv9gld85z2rvnlx7fxcl2k122vc344akh"; - system = "flexi-streams"; - asd = "flexi-streams"; - }); - systems = [ "flexi-streams" ]; - lispLibs = [ (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - flexi-streams-test = (build-asdf-system { - pname = "flexi-streams-test"; - version = "20241012-git"; - asds = [ "flexi-streams-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/flexi-streams/2024-10-12/flexi-streams-20241012-git.tgz"; - sha256 = "1bk224ryfiwsmnmq2gdfv9gld85z2rvnlx7fxcl2k122vc344akh"; - system = "flexi-streams-test"; - asd = "flexi-streams-test"; - }); - systems = [ "flexi-streams-test" ]; - lispLibs = [ (getAttr "flexi-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - flexichain = (build-asdf-system { - pname = "flexichain"; - version = "20201220-git"; - asds = [ "flexichain" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/flexichain/2020-12-20/flexichain-20201220-git.tgz"; - sha256 = "1ivkffnkc1iqmpl1p1rgyfbbgjmjcid4iszvdql1jjz324lq94g6"; - system = "flexichain"; - asd = "flexichain"; - }); - systems = [ "flexichain" ]; - lispLibs = [ (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - flexichain-doc = (build-asdf-system { - pname = "flexichain-doc"; - version = "20201220-git"; - asds = [ "flexichain-doc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/flexichain/2020-12-20/flexichain-20201220-git.tgz"; - sha256 = "1ivkffnkc1iqmpl1p1rgyfbbgjmjcid4iszvdql1jjz324lq94g6"; - system = "flexichain-doc"; - asd = "flexichain-doc"; - }); - systems = [ "flexichain-doc" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - float-features = (build-asdf-system { - pname = "float-features"; - version = "20241012-git"; - asds = [ "float-features" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/float-features/2024-10-12/float-features-20241012-git.tgz"; - sha256 = "1vxnvaprki5rk3phj20m35pva9dpgsixm8d9rnsixq1qgrv3djjf"; - system = "float-features"; - asd = "float-features"; - }); - systems = [ "float-features" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "trivial-features" self) ]; - meta = {}; - }); - float-features-tests = (build-asdf-system { - pname = "float-features-tests"; - version = "20241012-git"; - asds = [ "float-features-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/float-features/2024-10-12/float-features-20241012-git.tgz"; - sha256 = "1vxnvaprki5rk3phj20m35pva9dpgsixm8d9rnsixq1qgrv3djjf"; - system = "float-features-tests"; - asd = "float-features-tests"; - }); - systems = [ "float-features-tests" ]; - lispLibs = [ (getAttr "float-features" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - floating-point = (build-asdf-system { - pname = "floating-point"; - version = "20141106-git"; - asds = [ "floating-point" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/floating-point/2014-11-06/floating-point-20141106-git.tgz"; - sha256 = "1bqslmykg04innaqlp369pyjh61isj8xgv2h6pm95gsrxnf6wf7s"; - system = "floating-point"; - asd = "floating-point"; - }); - systems = [ "floating-point" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - floating-point-contractions = (build-asdf-system { - pname = "floating-point-contractions"; - version = "20201220-git"; - asds = [ "floating-point-contractions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/floating-point-contractions/2020-12-20/floating-point-contractions-20201220-git.tgz"; - sha256 = "0mr8bnc7hn0ii0cmlfnlwc14zkgbgdf099x5crrf9cp9wda4p082"; - system = "floating-point-contractions"; - asd = "floating-point-contractions"; - }); - systems = [ "floating-point-contractions" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - floating-point-test = (build-asdf-system { - pname = "floating-point-test"; - version = "20141106-git"; - asds = [ "floating-point-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/floating-point/2014-11-06/floating-point-20141106-git.tgz"; - sha256 = "1bqslmykg04innaqlp369pyjh61isj8xgv2h6pm95gsrxnf6wf7s"; - system = "floating-point-test"; - asd = "floating-point-test"; - }); - systems = [ "floating-point-test" ]; - lispLibs = [ (getAttr "floating-point" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - flow = (build-asdf-system { - pname = "flow"; - version = "20241012-git"; - asds = [ "flow" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/flow/2024-10-12/flow-20241012-git.tgz"; - sha256 = "1623kkyygwkqpgrbvv1zqj13mjkycqyh88nwcjsxd0clrlhlyfz3"; - system = "flow"; - asd = "flow"; - }); - systems = [ "flow" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "documentation-utils" self) ]; - meta = {}; - }); - flow-visualizer = (build-asdf-system { - pname = "flow-visualizer"; - version = "20241012-git"; - asds = [ "flow-visualizer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/flow/2024-10-12/flow-20241012-git.tgz"; - sha256 = "1623kkyygwkqpgrbvv1zqj13mjkycqyh88nwcjsxd0clrlhlyfz3"; - system = "flow-visualizer"; - asd = "flow-visualizer"; - }); - systems = [ "flow-visualizer" ]; - lispLibs = [ (getAttr "flow" self) (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtools" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - flute = (build-asdf-system { - pname = "flute"; - version = "20180831-git"; - asds = [ "flute" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/flute/2018-08-31/flute-20180831-git.tgz"; - sha256 = "0q8jhp040cvpppyn820mm6a550yfxyr1lar298x13c42mm807f4f"; - system = "flute"; - asd = "flute"; - }); - systems = [ "flute" ]; - lispLibs = [ (getAttr "assoc-utils" self) (getAttr "let-over-lambda" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - flute-test = (build-asdf-system { - pname = "flute-test"; - version = "20180831-git"; - asds = [ "flute-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/flute/2018-08-31/flute-20180831-git.tgz"; - sha256 = "0q8jhp040cvpppyn820mm6a550yfxyr1lar298x13c42mm807f4f"; - system = "flute-test"; - asd = "flute-test"; - }); - systems = [ "flute-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "flute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - flx = (build-asdf-system { - pname = "flx"; - version = "20241012-git"; - asds = [ "flx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-flx/2024-10-12/cl-flx-20241012-git.tgz"; - sha256 = "02p8qmc6wy3kf6w3rpgjvyg3jb699i5x9zk2f1p2y9h3m86d7hsw"; - system = "flx"; - asd = "flx"; - }); - systems = [ "flx" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fmarshal = (build-asdf-system { - pname = "fmarshal"; - version = "20130720-git"; - asds = [ "fmarshal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/marshal/2013-07-20/marshal-20130720-git.tgz"; - sha256 = "1c0hcf7i9kzgbmayhmcjg0kv5966yqlimvj67gl4mzvwhbdkc2nf"; - system = "fmarshal"; - asd = "fmarshal"; - }); - systems = [ "fmarshal" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fmarshal-test = (build-asdf-system { - pname = "fmarshal-test"; - version = "20130720-git"; - asds = [ "fmarshal-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/marshal/2013-07-20/marshal-20130720-git.tgz"; - sha256 = "1c0hcf7i9kzgbmayhmcjg0kv5966yqlimvj67gl4mzvwhbdkc2nf"; - system = "fmarshal-test"; - asd = "fmarshal-test"; - }); - systems = [ "fmarshal-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "fmarshal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fmcs = (build-asdf-system { - pname = "fmcs"; - version = "20231021-git"; - asds = [ "fmcs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fmcs/2023-10-21/fmcs-20231021-git.tgz"; - sha256 = "1zp73i68f5sl93z10l2f94nylbkaj601ani6yg3bg7iqhs543651"; - system = "fmcs"; - asd = "fmcs"; - }); - systems = [ "fmcs" ]; - lispLibs = [ (getAttr "fare-quasiquote-extras" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fmt = (build-asdf-system { - pname = "fmt"; - version = "20220331-git"; - asds = [ "fmt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fmt/2022-03-31/fmt-20220331-git.tgz"; - sha256 = "078y5yig5fw0jcsjjabaq7dlyxsd10w5k80ywx6gbm0j88al3fzp"; - system = "fmt"; - asd = "fmt"; - }); - systems = [ "fmt" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fmt-test = (build-asdf-system { - pname = "fmt-test"; - version = "20220331-git"; - asds = [ "fmt-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fmt/2022-03-31/fmt-20220331-git.tgz"; - sha256 = "078y5yig5fw0jcsjjabaq7dlyxsd10w5k80ywx6gbm0j88al3fzp"; - system = "fmt-test"; - asd = "fmt-test"; - }); - systems = [ "fmt-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "fmt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fmt-time = (build-asdf-system { - pname = "fmt-time"; - version = "20220331-git"; - asds = [ "fmt-time" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fmt/2022-03-31/fmt-20220331-git.tgz"; - sha256 = "078y5yig5fw0jcsjjabaq7dlyxsd10w5k80ywx6gbm0j88al3fzp"; - system = "fmt-time"; - asd = "fmt-time"; - }); - systems = [ "fmt-time" ]; - lispLibs = [ (getAttr "fmt" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fn = (build-asdf-system { - pname = "fn"; - version = "20241012-git"; - asds = [ "fn" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fn/2024-10-12/fn-20241012-git.tgz"; - sha256 = "08ydmfly5jaisfj8pkksq6npz992zlz4ni1yqlrq5yigwx41xaz0"; - system = "fn"; - asd = "fn"; - }); - systems = [ "fn" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = {}; - }); - fof = (build-asdf-system { - pname = "fof"; - version = "20211230-git"; - asds = [ "fof" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fof/2021-12-30/fof-20211230-git.tgz"; - sha256 = "0ipy51q2fw03xk9rqcyzbq2b9c32npc1gl3c53rdjywpak7zwwg6"; - system = "fof"; - asd = "fof"; - }); - systems = [ "fof" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "hu_dot_dwim_dot_defclass-star" self) (getAttr "local-time" self) (getAttr "magicffi" self) (getAttr "named-readtables" self) (getAttr "osicat" self) (getAttr "serapeum" self) (getAttr "str" self) (getAttr "trivia" self) (getAttr "trivial-package-local-nicknames" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio = (build-asdf-system { - pname = "folio"; - version = "20130128-git"; - asds = [ "folio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio/2013-01-28/folio-20130128-git.tgz"; - sha256 = "061kryjclnkp60r8vhcpzy9q0k755p1jc1vp4vj13k7piwr1bj64"; - system = "folio"; - asd = "folio"; - }); - systems = [ "folio" ]; - lispLibs = [ (getAttr "folio_dot_as" self) (getAttr "folio_dot_boxes" self) (getAttr "folio_dot_collections" self) (getAttr "folio_dot_functions" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio_dot_as = (build-asdf-system { - pname = "folio.as"; - version = "20130128-git"; - asds = [ "folio.as" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio/2013-01-28/folio-20130128-git.tgz"; - sha256 = "061kryjclnkp60r8vhcpzy9q0k755p1jc1vp4vj13k7piwr1bj64"; - system = "folio.as"; - asd = "folio.as"; - }); - systems = [ "folio.as" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio_dot_boxes = (build-asdf-system { - pname = "folio.boxes"; - version = "20130128-git"; - asds = [ "folio.boxes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio/2013-01-28/folio-20130128-git.tgz"; - sha256 = "061kryjclnkp60r8vhcpzy9q0k755p1jc1vp4vj13k7piwr1bj64"; - system = "folio.boxes"; - asd = "folio.boxes"; - }); - systems = [ "folio.boxes" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio_dot_collections = (build-asdf-system { - pname = "folio.collections"; - version = "20130128-git"; - asds = [ "folio.collections" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio/2013-01-28/folio-20130128-git.tgz"; - sha256 = "061kryjclnkp60r8vhcpzy9q0k755p1jc1vp4vj13k7piwr1bj64"; - system = "folio.collections"; - asd = "folio.collections"; - }); - systems = [ "folio.collections" ]; - lispLibs = [ (getAttr "folio_dot_as" self) (getAttr "folio_dot_functions" self) (getAttr "fset" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio_dot_functions = (build-asdf-system { - pname = "folio.functions"; - version = "20130128-git"; - asds = [ "folio.functions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio/2013-01-28/folio-20130128-git.tgz"; - sha256 = "061kryjclnkp60r8vhcpzy9q0k755p1jc1vp4vj13k7piwr1bj64"; - system = "folio.functions"; - asd = "folio.functions"; - }); - systems = [ "folio.functions" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2 = (build-asdf-system { - pname = "folio2"; - version = "20191007-git"; - asds = [ "folio2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2"; - asd = "folio2"; - }); - systems = [ "folio2" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "folio2-as" self) (getAttr "folio2-as-syntax" self) (getAttr "folio2-boxes" self) (getAttr "folio2-functions" self) (getAttr "folio2-functions-syntax" self) (getAttr "folio2-make" self) (getAttr "folio2-maps" self) (getAttr "folio2-maps-syntax" self) (getAttr "folio2-pairs" self) (getAttr "folio2-sequences" self) (getAttr "folio2-sequences-syntax" self) (getAttr "folio2-series" self) (getAttr "folio2-taps" self) (getAttr "fset" self) (getAttr "series" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-as = (build-asdf-system { - pname = "folio2-as"; - version = "20191007-git"; - asds = [ "folio2-as" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-as"; - asd = "folio2-as"; - }); - systems = [ "folio2-as" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-as-syntax = (build-asdf-system { - pname = "folio2-as-syntax"; - version = "20191007-git"; - asds = [ "folio2-as-syntax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-as-syntax"; - asd = "folio2-as-syntax"; - }); - systems = [ "folio2-as-syntax" ]; - lispLibs = [ (getAttr "folio2-as" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-as-tests = (build-asdf-system { - pname = "folio2-as-tests"; - version = "20191007-git"; - asds = [ "folio2-as-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-as-tests"; - asd = "folio2-as-tests"; - }); - systems = [ "folio2-as-tests" ]; - lispLibs = [ (getAttr "folio2-as" self) (getAttr "folio2-as-syntax" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-boxes = (build-asdf-system { - pname = "folio2-boxes"; - version = "20191007-git"; - asds = [ "folio2-boxes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-boxes"; - asd = "folio2-boxes"; - }); - systems = [ "folio2-boxes" ]; - lispLibs = [ (getAttr "folio2-as" self) (getAttr "folio2-make" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-boxes-tests = (build-asdf-system { - pname = "folio2-boxes-tests"; - version = "20191007-git"; - asds = [ "folio2-boxes-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-boxes-tests"; - asd = "folio2-boxes-tests"; - }); - systems = [ "folio2-boxes-tests" ]; - lispLibs = [ (getAttr "folio2-boxes" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-functions = (build-asdf-system { - pname = "folio2-functions"; - version = "20191007-git"; - asds = [ "folio2-functions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-functions"; - asd = "folio2-functions"; - }); - systems = [ "folio2-functions" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "folio2-as" self) (getAttr "folio2-make" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-functions-syntax = (build-asdf-system { - pname = "folio2-functions-syntax"; - version = "20191007-git"; - asds = [ "folio2-functions-syntax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-functions-syntax"; - asd = "folio2-functions-syntax"; - }); - systems = [ "folio2-functions-syntax" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "folio2-functions" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-functions-tests = (build-asdf-system { - pname = "folio2-functions-tests"; - version = "20191007-git"; - asds = [ "folio2-functions-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-functions-tests"; - asd = "folio2-functions-tests"; - }); - systems = [ "folio2-functions-tests" ]; - lispLibs = [ (getAttr "folio2-functions" self) (getAttr "folio2-functions-syntax" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-make = (build-asdf-system { - pname = "folio2-make"; - version = "20191007-git"; - asds = [ "folio2-make" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-make"; - asd = "folio2-make"; - }); - systems = [ "folio2-make" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-make-tests = (build-asdf-system { - pname = "folio2-make-tests"; - version = "20191007-git"; - asds = [ "folio2-make-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-make-tests"; - asd = "folio2-make-tests"; - }); - systems = [ "folio2-make-tests" ]; - lispLibs = [ (getAttr "folio2-make" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-maps = (build-asdf-system { - pname = "folio2-maps"; - version = "20191007-git"; - asds = [ "folio2-maps" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-maps"; - asd = "folio2-maps"; - }); - systems = [ "folio2-maps" ]; - lispLibs = [ (getAttr "folio2-as" self) (getAttr "folio2-make" self) (getAttr "fset" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-maps-syntax = (build-asdf-system { - pname = "folio2-maps-syntax"; - version = "20191007-git"; - asds = [ "folio2-maps-syntax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-maps-syntax"; - asd = "folio2-maps-syntax"; - }); - systems = [ "folio2-maps-syntax" ]; - lispLibs = [ (getAttr "folio2-maps" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-maps-tests = (build-asdf-system { - pname = "folio2-maps-tests"; - version = "20191007-git"; - asds = [ "folio2-maps-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-maps-tests"; - asd = "folio2-maps-tests"; - }); - systems = [ "folio2-maps-tests" ]; - lispLibs = [ (getAttr "folio2-maps" self) (getAttr "folio2-maps-syntax" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-pairs = (build-asdf-system { - pname = "folio2-pairs"; - version = "20191007-git"; - asds = [ "folio2-pairs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-pairs"; - asd = "folio2-pairs"; - }); - systems = [ "folio2-pairs" ]; - lispLibs = [ (getAttr "folio2-as" self) (getAttr "folio2-make" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-pairs-tests = (build-asdf-system { - pname = "folio2-pairs-tests"; - version = "20191007-git"; - asds = [ "folio2-pairs-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-pairs-tests"; - asd = "folio2-pairs-tests"; - }); - systems = [ "folio2-pairs-tests" ]; - lispLibs = [ (getAttr "folio2-pairs" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-sequences = (build-asdf-system { - pname = "folio2-sequences"; - version = "20191007-git"; - asds = [ "folio2-sequences" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-sequences"; - asd = "folio2-sequences"; - }); - systems = [ "folio2-sequences" ]; - lispLibs = [ (getAttr "folio2-as" self) (getAttr "folio2-make" self) (getAttr "folio2-pairs" self) (getAttr "fset" self) (getAttr "series" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-sequences-syntax = (build-asdf-system { - pname = "folio2-sequences-syntax"; - version = "20191007-git"; - asds = [ "folio2-sequences-syntax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-sequences-syntax"; - asd = "folio2-sequences-syntax"; - }); - systems = [ "folio2-sequences-syntax" ]; - lispLibs = [ (getAttr "folio2-sequences" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-sequences-tests = (build-asdf-system { - pname = "folio2-sequences-tests"; - version = "20191007-git"; - asds = [ "folio2-sequences-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-sequences-tests"; - asd = "folio2-sequences-tests"; - }); - systems = [ "folio2-sequences-tests" ]; - lispLibs = [ (getAttr "folio2-sequences" self) (getAttr "folio2-sequences-syntax" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-series = (build-asdf-system { - pname = "folio2-series"; - version = "20191007-git"; - asds = [ "folio2-series" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-series"; - asd = "folio2-series"; - }); - systems = [ "folio2-series" ]; - lispLibs = [ (getAttr "folio2-as" self) (getAttr "folio2-make" self) (getAttr "folio2-pairs" self) (getAttr "folio2-sequences" self) (getAttr "fset" self) (getAttr "series" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-series-tests = (build-asdf-system { - pname = "folio2-series-tests"; - version = "20191007-git"; - asds = [ "folio2-series-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-series-tests"; - asd = "folio2-series-tests"; - }); - systems = [ "folio2-series-tests" ]; - lispLibs = [ (getAttr "folio2-series" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-taps = (build-asdf-system { - pname = "folio2-taps"; - version = "20191007-git"; - asds = [ "folio2-taps" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-taps"; - asd = "folio2-taps"; - }); - systems = [ "folio2-taps" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "folio2-as" self) (getAttr "folio2-make" self) (getAttr "folio2-maps" self) (getAttr "folio2-pairs" self) (getAttr "folio2-sequences" self) (getAttr "folio2-series" self) (getAttr "fset" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-taps-tests = (build-asdf-system { - pname = "folio2-taps-tests"; - version = "20191007-git"; - asds = [ "folio2-taps-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-taps-tests"; - asd = "folio2-taps-tests"; - }); - systems = [ "folio2-taps-tests" ]; - lispLibs = [ (getAttr "folio2-taps" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - folio2-tests = (build-asdf-system { - pname = "folio2-tests"; - version = "20191007-git"; - asds = [ "folio2-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; - sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; - system = "folio2-tests"; - asd = "folio2-tests"; - }); - systems = [ "folio2-tests" ]; - lispLibs = [ (getAttr "folio2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - font-discovery = (build-asdf-system { - pname = "font-discovery"; - version = "20231021-git"; - asds = [ "font-discovery" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/font-discovery/2023-10-21/font-discovery-20231021-git.tgz"; - sha256 = "1kx83564p1w2wka3l6g4rj7zvzi85prvs6yag2qv2a9xh80yv9rz"; - system = "font-discovery"; - asd = "font-discovery"; - }); - systems = [ "font-discovery" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) (getAttr "trivial-indent" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - foo-wild = (build-asdf-system { - pname = "foo-wild"; - version = "20210531-git"; - asds = [ "foo-wild" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/wild-package-inferred-system/2021-05-31/wild-package-inferred-system-20210531-git.tgz"; - sha256 = "0sp3j3i83aqyq9bl3djs490nilryi9sh1wjbcqd9z94d9wfbfz80"; - system = "foo-wild"; - asd = "foo-wild"; - }); - systems = [ "foo-wild" ]; - lispLibs = [ (getAttr "wild-package-inferred-system" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - for = (build-asdf-system { - pname = "for"; - version = "20231021-git"; - asds = [ "for" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/for/2023-10-21/for-20231021-git.tgz"; - sha256 = "07jdwqkyb3qd65mng60cs723z7p0bv2769hhalz4c0mfzn8qrn99"; - system = "for"; - asd = "for"; - }); - systems = [ "for" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "form-fiddle" self) (getAttr "lambda-fiddle" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - foreign-array = (build-asdf-system { - pname = "foreign-array"; - version = "master-df14cb8c-git"; - asds = [ "foreign-array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/antik/2024-10-12/antik-master-df14cb8c-git.tgz"; - sha256 = "1n08cx4n51z8v4bxyak166lp495xda3x7llfxcdpxndxqxcammr0"; - system = "foreign-array"; - asd = "foreign-array"; - }); - systems = [ "foreign-array" ]; - lispLibs = [ (getAttr "antik-base" self) (getAttr "cffi" self) (getAttr "static-vectors" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fork-future = (build-asdf-system { - pname = "fork-future"; - version = "20220220-git"; - asds = [ "fork-future" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "fork-future"; - asd = "fork-future"; - }); - systems = [ "fork-future" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-store" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - form-fiddle = (build-asdf-system { - pname = "form-fiddle"; - version = "20231021-git"; - asds = [ "form-fiddle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/form-fiddle/2023-10-21/form-fiddle-20231021-git.tgz"; - sha256 = "0vl28q8xa42i9gr1bch22jdha9jh8sr2hcv6d9kykj4jsqi9kwbg"; - system = "form-fiddle"; - asd = "form-fiddle"; - }); - systems = [ "form-fiddle" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = {}; - }); - format-string-builder = (build-asdf-system { - pname = "format-string-builder"; - version = "20170124-git"; - asds = [ "format-string-builder" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/format-string-builder/2017-01-24/format-string-builder-20170124-git.tgz"; - sha256 = "1266w5wynfhamxdf8ms2236m202f6982fd9ph8fs98nqccq2pcac"; - system = "format-string-builder"; - asd = "format-string-builder"; - }); - systems = [ "format-string-builder" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - formlets = (build-asdf-system { - pname = "formlets"; - version = "20161204-git"; - asds = [ "formlets" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/formlets/2016-12-04/formlets-20161204-git.tgz"; - sha256 = "0r2afi5lwzxfb8xylx9cs44wqhla4b50k21nzg2dxn7z8m6yspfn"; - system = "formlets"; - asd = "formlets"; - }); - systems = [ "formlets" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cl-who" self) (getAttr "drakma" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - formlets-test = (build-asdf-system { - pname = "formlets-test"; - version = "20161204-git"; - asds = [ "formlets-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/formlets/2016-12-04/formlets-20161204-git.tgz"; - sha256 = "0r2afi5lwzxfb8xylx9cs44wqhla4b50k21nzg2dxn7z8m6yspfn"; - system = "formlets-test"; - asd = "formlets-test"; - }); - systems = [ "formlets-test" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cl-who" self) (getAttr "drakma" self) (getAttr "formlets" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fprog = (build-asdf-system { - pname = "fprog"; - version = "20181210-git"; - asds = [ "fprog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cambl/2018-12-10/cambl-20181210-git.tgz"; - sha256 = "103mry04j2k9vznsxm7wcvccgxkil92cdrv52miwcmxl8daa4jiz"; - system = "fprog"; - asd = "fprog"; - }); - systems = [ "fprog" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fps-independent-timestep = (build-asdf-system { - pname = "fps-independent-timestep"; - version = "20200427-git"; - asds = [ "fps-independent-timestep" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "fps-independent-timestep"; - asd = "fps-independent-timestep"; - }); - systems = [ "fps-independent-timestep" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fred = (build-asdf-system { - pname = "fred"; - version = "20150923-git"; - asds = [ "fred" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fred/2015-09-23/fred-20150923-git.tgz"; - sha256 = "0qn2rd67haz4pvvv4yp2yvbvjhficv8xjm7ijg0r34gxllm6i373"; - system = "fred"; - asd = "fred"; - }); - systems = [ "fred" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "s-xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - freebsd-sysctl = (build-asdf-system { - pname = "freebsd-sysctl"; - version = "20210228-git"; - asds = [ "freebsd-sysctl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/freebsd-sysctl/2021-02-28/freebsd-sysctl-20210228-git.tgz"; - sha256 = "1gzqiqz0pi273ia2q61bhr908ymbl8cll5v2h8lkicr9pff37g91"; - system = "freebsd-sysctl"; - asd = "freebsd-sysctl"; - }); - systems = [ "freebsd-sysctl" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - freesound = (build-asdf-system { - pname = "freesound"; - version = "20210411-git"; - asds = [ "freesound" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/freesound/2021-04-11/freesound-20210411-git.tgz"; - sha256 = "1nsmbz7qx9wn86860zlnw75sdgpr8qfzgqfbwxggc3zr7p83kric"; - system = "freesound"; - asd = "freesound"; - }); - systems = [ "freesound" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "dexador" self) (getAttr "trivial-open-browser" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fresnel = (build-asdf-system { - pname = "fresnel"; - version = "20230618-git"; - asds = [ "fresnel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fresnel/2023-06-18/fresnel-20230618-git.tgz"; - sha256 = "0rzi3pz1cjf8m0fmj7dg7wxbbcmxnbx75hfp9hbmrm9yqsjc4khv"; - system = "fresnel"; - asd = "fresnel"; - }); - systems = [ "fresnel" ]; - lispLibs = [ (getAttr "fare-quasiquote-extras" self) (getAttr "gt" self) (getAttr "trivial-package-local-nicknames" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - froute = (build-asdf-system { - pname = "froute"; - version = "20180711-git"; - asds = [ "froute" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/froute/2018-07-11/froute-20180711-git.tgz"; - sha256 = "1q7xzgn7g5ky1d8m121r8hskcg4gqpripr791k03y7dz5vkfj14x"; - system = "froute"; - asd = "froute"; - }); - systems = [ "froute" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - frpc = (build-asdf-system { - pname = "frpc"; - version = "20151031-git"; - asds = [ "frpc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/frpc/2015-10-31/frpc-20151031-git.tgz"; - sha256 = "0yac1q79kw1w1qd7zjgg912n780v318n2drzdimlv5n3bwd6pm2r"; - system = "frpc"; - asd = "frpc"; - }); - systems = [ "frpc" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "flexi-streams" self) (getAttr "glass" self) (getAttr "nibbles" self) (getAttr "pounds" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - frpc-des = (build-asdf-system { - pname = "frpc-des"; - version = "20151031-git"; - asds = [ "frpc-des" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/frpc/2015-10-31/frpc-20151031-git.tgz"; - sha256 = "0yac1q79kw1w1qd7zjgg912n780v318n2drzdimlv5n3bwd6pm2r"; - system = "frpc-des"; - asd = "frpc"; - }); - systems = [ "frpc-des" ]; - lispLibs = [ (getAttr "frpc" self) (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - frpc-gss = (build-asdf-system { - pname = "frpc-gss"; - version = "20151031-git"; - asds = [ "frpc-gss" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/frpc/2015-10-31/frpc-20151031-git.tgz"; - sha256 = "0yac1q79kw1w1qd7zjgg912n780v318n2drzdimlv5n3bwd6pm2r"; - system = "frpc-gss"; - asd = "frpc"; - }); - systems = [ "frpc-gss" ]; - lispLibs = [ (getAttr "cerberus" self) (getAttr "frpc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - frpcgen = (build-asdf-system { - pname = "frpcgen"; - version = "20151031-git"; - asds = [ "frpcgen" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/frpc/2015-10-31/frpc-20151031-git.tgz"; - sha256 = "0yac1q79kw1w1qd7zjgg912n780v318n2drzdimlv5n3bwd6pm2r"; - system = "frpcgen"; - asd = "frpcgen"; - }); - systems = [ "frpcgen" ]; - lispLibs = [ (getAttr "cl-lex" self) (getAttr "frpc" self) (getAttr "yacc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - frugal-uuid = (build-asdf-system { - pname = "frugal-uuid"; - version = "20241012-git"; - asds = [ "frugal-uuid" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-frugal-uuid/2024-10-12/cl-frugal-uuid-20241012-git.tgz"; - sha256 = "01hli6gh0rr6mizqp1iqfch7rd0jw6ygrskjdr5hf3r8wwwvr9hh"; - system = "frugal-uuid"; - asd = "frugal-uuid"; - }); - systems = [ "frugal-uuid" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fs-watcher = (build-asdf-system { - pname = "fs-watcher"; - version = "20171130-git"; - asds = [ "fs-watcher" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fs-watcher/2017-11-30/fs-watcher-20171130-git.tgz"; - sha256 = "0fr2wb39609z4afk4w21vwnwi4g050x4gag2ykdx6hn9m65cp9db"; - system = "fs-watcher"; - asd = "fs-watcher"; - }); - systems = [ "fs-watcher" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "com_dot_gigamonkeys_dot_pathnames" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fset = (build-asdf-system { - pname = "fset"; - version = "20241012-git"; - asds = [ "fset" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fset/2024-10-12/fset-20241012-git.tgz"; - sha256 = "0h9j5a7vlr8g0hq99y4wgw1l1wialzs6k16nrpmd4pwiyiypzkm6"; - system = "fset"; - asd = "fset"; - }); - systems = [ "fset" ]; - lispLibs = [ (getAttr "misc-extensions" self) (getAttr "named-readtables" self) (getAttr "random-state" self) ]; - meta = {}; - }); - fsocket = (build-asdf-system { - pname = "fsocket"; - version = "20211230-git"; - asds = [ "fsocket" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fsocket/2021-12-30/fsocket-20211230-git.tgz"; - sha256 = "18h3s4bv3243xbp0qdywn9kmqvx8zh9cscc9f6sfyxrz6xhymw6p"; - system = "fsocket"; - asd = "fsocket"; - }); - systems = [ "fsocket" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fsvd = (build-asdf-system { - pname = "fsvd"; - version = "20131211-git"; - asds = [ "fsvd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fsvd/2013-12-11/fsvd-20131211-git.tgz"; - sha256 = "1m22g9x18ixjh5nylm56l5p67ryx9dbd3g6lyzvwk9nayjmqn7x5"; - system = "fsvd"; - asd = "fsvd"; - }); - systems = [ "fsvd" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ftp = (build-asdf-system { - pname = "ftp"; - version = "20150608-http"; - asds = [ "ftp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ftp/2015-06-08/cl-ftp-20150608-http.tgz"; - sha256 = "1m955rjpaynybzmb9q631mll764hm06lydvhra50mfjj75ynwsvw"; - system = "ftp"; - asd = "ftp"; - }); - systems = [ "ftp" ]; - lispLibs = [ (getAttr "cl-ftp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fucc-generator = (build-asdf-system { - pname = "fucc-generator"; - version = "v0.2.2"; - asds = [ "fucc-generator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fucc/2020-04-27/fucc-v0.2.2.tgz"; - sha256 = "10wznxw6yhkyh943xnm694innj13xdlmkx13pr8xwc6zdbdyb32k"; - system = "fucc-generator"; - asd = "fucc-generator"; - }); - systems = [ "fucc-generator" ]; - lispLibs = [ (getAttr "fucc-parser" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fucc-parser = (build-asdf-system { - pname = "fucc-parser"; - version = "v0.2.2"; - asds = [ "fucc-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fucc/2020-04-27/fucc-v0.2.2.tgz"; - sha256 = "10wznxw6yhkyh943xnm694innj13xdlmkx13pr8xwc6zdbdyb32k"; - system = "fucc-parser"; - asd = "fucc-parser"; - }); - systems = [ "fucc-parser" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - function-cache = (build-asdf-system { - pname = "function-cache"; - version = "20231021-git"; - asds = [ "function-cache" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/function-cache/2023-10-21/function-cache-20231021-git.tgz"; - sha256 = "1sk35fd7zw6kx9zpv18wmzmkksbn0ac4ycjzi6hqdgkbyn3l136w"; - system = "function-cache"; - asd = "function-cache"; - }); - systems = [ "function-cache" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-interpol" self) (getAttr "closer-mop" self) (getAttr "iterate" self) (getAttr "symbol-munger" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - function-cache-clsql = (build-asdf-system { - pname = "function-cache-clsql"; - version = "20231021-git"; - asds = [ "function-cache-clsql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/function-cache/2023-10-21/function-cache-20231021-git.tgz"; - sha256 = "1sk35fd7zw6kx9zpv18wmzmkksbn0ac4ycjzi6hqdgkbyn3l136w"; - system = "function-cache-clsql"; - asd = "function-cache-clsql"; - }); - systems = [ "function-cache-clsql" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "clsql-helper" self) (getAttr "function-cache" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - functional-geometry = (build-asdf-system { - pname = "functional-geometry"; - version = "20241012-git"; - asds = [ "functional-geometry" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "functional-geometry"; - asd = "functional-geometry"; - }); - systems = [ "functional-geometry" ]; - lispLibs = [ (getAttr "clim-listener" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - functional-trees = (build-asdf-system { - pname = "functional-trees"; - version = "20241012-git"; - asds = [ "functional-trees" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/functional-trees/2024-10-12/functional-trees-20241012-git.tgz"; - sha256 = "02jhc2c6d7zd75cpjmwck62b3iyzsf5q2yqqpp5ymwjmnx4bnysd"; - system = "functional-trees"; - asd = "functional-trees"; - }); - systems = [ "functional-trees" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "asdf-package-system" self) (getAttr "atomics" self) (getAttr "bordeaux-threads" self) (getAttr "cl-store" self) (getAttr "closer-mop" self) (getAttr "fset" self) (getAttr "iterate" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - funds = (build-asdf-system { - pname = "funds"; - version = "20211020-git"; - asds = [ "funds" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/funds/2021-10-20/funds-20211020-git.tgz"; - sha256 = "13y1jhvnpzrs9daz6f3z67w6h2y21ggb10j3j4vnc5p3m8i7ps4p"; - system = "funds"; - asd = "funds"; - }); - systems = [ "funds" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - future = (build-asdf-system { - pname = "future"; - version = "20220220-git"; - asds = [ "future" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; - sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; - system = "future"; - asd = "future"; - }); - systems = [ "future" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fuzzy-dates = (build-asdf-system { - pname = "fuzzy-dates"; - version = "20241012-git"; - asds = [ "fuzzy-dates" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fuzzy-dates/2024-10-12/fuzzy-dates-20241012-git.tgz"; - sha256 = "1nnwb7dl772zax0ysc9v4z29kq639f3za7k34hdk9fyyqbln9dgl"; - system = "fuzzy-dates"; - asd = "fuzzy-dates"; - }); - systems = [ "fuzzy-dates" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fuzzy-match = (build-asdf-system { - pname = "fuzzy-match"; - version = "20210124-git"; - asds = [ "fuzzy-match" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fuzzy-match/2021-01-24/fuzzy-match-20210124-git.tgz"; - sha256 = "1lawndmzkl6f9sviy7ngn2s3xkc4akp8l505kvpslaz6qq0ayyqv"; - system = "fuzzy-match"; - asd = "fuzzy-match"; - }); - systems = [ "fuzzy-match" ]; - lispLibs = [ (getAttr "mk-string-metrics" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - fxml = (build-asdf-system { - pname = "fxml"; - version = "20210228-git"; - asds = [ "fxml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fxml/2021-02-28/fxml-20210228-git.tgz"; - sha256 = "1vxdb1cjjqi986f72bggnw1s4yzv12g4li7vn4y49b6lphshr8lm"; - system = "fxml"; - asd = "fxml"; - }); - systems = [ "fxml" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "flexi-streams" self) (getAttr "named-readtables" self) (getAttr "quri" self) (getAttr "serapeum" self) (getAttr "split-sequence" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gadgets = (build-asdf-system { - pname = "gadgets"; - version = "20241012-git"; - asds = [ "gadgets" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gadgets/2024-10-12/gadgets-20241012-git.tgz"; - sha256 = "1ba4gj8lh3ihbb66xiz7hc8cdg3gvi3q20w32nmsqdch956is34k"; - system = "gadgets"; - asd = "gadgets"; - }); - systems = [ "gadgets" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-hash-util" self) (getAttr "cl-utilities" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - garbage-pools = (build-asdf-system { - pname = "garbage-pools"; - version = "20210124-git"; - asds = [ "garbage-pools" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/garbage-pools/2021-01-24/garbage-pools-20210124-git.tgz"; - sha256 = "04jqwr6j138him6wc4nrwjzm4lvyj5j31xqab02nkf8h9hmsf5v1"; - system = "garbage-pools"; - asd = "garbage-pools"; - }); - systems = [ "garbage-pools" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - garbage-pools-test = (build-asdf-system { - pname = "garbage-pools-test"; - version = "20210124-git"; - asds = [ "garbage-pools-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/garbage-pools/2021-01-24/garbage-pools-20210124-git.tgz"; - sha256 = "04jqwr6j138him6wc4nrwjzm4lvyj5j31xqab02nkf8h9hmsf5v1"; - system = "garbage-pools-test"; - asd = "garbage-pools-test"; - }); - systems = [ "garbage-pools-test" ]; - lispLibs = [ (getAttr "garbage-pools" self) (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - garten = (build-asdf-system { - pname = "garten"; - version = "20211020-git"; - asds = [ "garten" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/colliflower/2021-10-20/colliflower-20211020-git.tgz"; - sha256 = "1fzn9s7wm7wmffrdm21lpvry9jb320456cmmprn976a533lp704r"; - system = "garten"; - asd = "garten"; - }); - systems = [ "garten" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gcm = (build-asdf-system { - pname = "gcm"; - version = "20141217-git"; - asds = [ "gcm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gcm/2014-12-17/gcm-20141217-git.tgz"; - sha256 = "1xnm1cj417d9syb634zi9w90c2191gxjrixa724s4h3hvj70y0ff"; - system = "gcm"; - asd = "gcm"; - }); - systems = [ "gcm" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "com_dot_gigamonkeys_dot_json" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geco = (build-asdf-system { - pname = "geco"; - version = "20210228-git"; - asds = [ "geco" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/geco/2021-02-28/geco-20210228-git.tgz"; - sha256 = "1ncaf9ab7jz59zmga0p97blsjjb1m6db0qih57wipfhqdb5ylz17"; - system = "geco"; - asd = "geco"; - }); - systems = [ "geco" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gendl = (build-asdf-system { - pname = "gendl"; - version = "master-fe503896-git"; - asds = [ "gendl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "gendl"; - asd = "gendl"; - }); - systems = [ "gendl" ]; - lispLibs = [ (getAttr "cl-lite" self) (getAttr "geysr" self) (getAttr "gwl-graphics" self) (getAttr "robot" self) (getAttr "yadd" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gendl-asdf = (build-asdf-system { - pname = "gendl-asdf"; - version = "master-fe503896-git"; - asds = [ "gendl-asdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "gendl-asdf"; - asd = "gendl-asdf"; - }); - systems = [ "gendl-asdf" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - general-accumulator = (build-asdf-system { - pname = "general-accumulator"; - version = "20211209-git"; - asds = [ "general-accumulator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-general-accumulator/2021-12-09/cl-general-accumulator-20211209-git.tgz"; - sha256 = "14ybsk1ahgya67clspacqij1lvs5bzv07rdq60nhgqsbc6s56j9g"; - system = "general-accumulator"; - asd = "general-accumulator"; - }); - systems = [ "general-accumulator" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generalized-reference = (build-asdf-system { - pname = "generalized-reference"; - version = "20220707-git"; - asds = [ "generalized-reference" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generalized-reference/2022-07-07/generalized-reference-20220707-git.tgz"; - sha256 = "0q1cm52lijn4p6bjzx2yr2kwy729lcj3f6lsanbnbjw56xgp4cpb"; - system = "generalized-reference"; - asd = "generalized-reference"; - }); - systems = [ "generalized-reference" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "serapeum" self) (getAttr "series" self) (getAttr "split-sequence" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generators = (build-asdf-system { - pname = "generators"; - version = "20130615-git"; - asds = [ "generators" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generators/2013-06-15/generators-20130615-git.tgz"; - sha256 = "1y8jlvv5c3av2ww33rwm2kh9sxmhfykhz235b33fbjpdxpx1r9bs"; - system = "generators"; - asd = "generators"; - }); - systems = [ "generators" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-cont" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl = (build-asdf-system { - pname = "generic-cl"; - version = "20241012-git"; - asds = [ "generic-cl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl"; - asd = "generic-cl"; - }); - systems = [ "generic-cl" ]; - lispLibs = [ (getAttr "agutil" self) (getAttr "generic-cl_dot_arithmetic" self) (getAttr "generic-cl_dot_collector" self) (getAttr "generic-cl_dot_comparison" self) (getAttr "generic-cl_dot_container" self) (getAttr "generic-cl_dot_iterator" self) (getAttr "generic-cl_dot_lazy-seq" self) (getAttr "generic-cl_dot_map" self) (getAttr "generic-cl_dot_math" self) (getAttr "generic-cl_dot_object" self) (getAttr "generic-cl_dot_sequence" self) (getAttr "generic-cl_dot_set" self) ]; - meta = {}; - }); - generic-cl_dot_arithmetic = (build-asdf-system { - pname = "generic-cl.arithmetic"; - version = "20241012-git"; - asds = [ "generic-cl.arithmetic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.arithmetic"; - asd = "generic-cl.arithmetic"; - }); - systems = [ "generic-cl.arithmetic" ]; - lispLibs = [ (getAttr "generic-cl_dot_comparison" self) (getAttr "generic-cl_dot_internal" self) (getAttr "static-dispatch" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl_dot_collector = (build-asdf-system { - pname = "generic-cl.collector"; - version = "20241012-git"; - asds = [ "generic-cl.collector" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.collector"; - asd = "generic-cl.collector"; - }); - systems = [ "generic-cl.collector" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "arrows" self) (getAttr "generic-cl_dot_iterator" self) (getAttr "generic-cl_dot_object" self) (getAttr "static-dispatch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl_dot_comparison = (build-asdf-system { - pname = "generic-cl.comparison"; - version = "20241012-git"; - asds = [ "generic-cl.comparison" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.comparison"; - asd = "generic-cl.comparison"; - }); - systems = [ "generic-cl.comparison" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "generic-cl_dot_internal" self) (getAttr "static-dispatch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl_dot_container = (build-asdf-system { - pname = "generic-cl.container"; - version = "20241012-git"; - asds = [ "generic-cl.container" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.container"; - asd = "generic-cl.container"; - }); - systems = [ "generic-cl.container" ]; - lispLibs = [ (getAttr "generic-cl_dot_object" self) (getAttr "static-dispatch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl_dot_internal = (build-asdf-system { - pname = "generic-cl.internal"; - version = "20241012-git"; - asds = [ "generic-cl.internal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.internal"; - asd = "generic-cl.internal"; - }); - systems = [ "generic-cl.internal" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-form-types" self) (getAttr "static-dispatch" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl_dot_iterator = (build-asdf-system { - pname = "generic-cl.iterator"; - version = "20241012-git"; - asds = [ "generic-cl.iterator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.iterator"; - asd = "generic-cl.iterator"; - }); - systems = [ "generic-cl.iterator" ]; - lispLibs = [ (getAttr "agutil" self) (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "arrows" self) (getAttr "cl-form-types" self) (getAttr "generic-cl_dot_container" self) (getAttr "generic-cl_dot_internal" self) (getAttr "generic-cl_dot_object" self) (getAttr "parse-declarations-1_dot_0" self) (getAttr "static-dispatch" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl_dot_lazy-seq = (build-asdf-system { - pname = "generic-cl.lazy-seq"; - version = "20241012-git"; - asds = [ "generic-cl.lazy-seq" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.lazy-seq"; - asd = "generic-cl.lazy-seq"; - }); - systems = [ "generic-cl.lazy-seq" ]; - lispLibs = [ (getAttr "agutil" self) (getAttr "arrows" self) (getAttr "cl-custom-hash-table" self) (getAttr "generic-cl_dot_collector" self) (getAttr "generic-cl_dot_comparison" self) (getAttr "generic-cl_dot_container" self) (getAttr "generic-cl_dot_iterator" self) (getAttr "generic-cl_dot_map" self) (getAttr "generic-cl_dot_object" self) (getAttr "generic-cl_dot_sequence" self) (getAttr "static-dispatch" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl_dot_map = (build-asdf-system { - pname = "generic-cl.map"; - version = "20241012-git"; - asds = [ "generic-cl.map" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.map"; - asd = "generic-cl.map"; - }); - systems = [ "generic-cl.map" ]; - lispLibs = [ (getAttr "agutil" self) (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "arrows" self) (getAttr "cl-custom-hash-table" self) (getAttr "generic-cl_dot_collector" self) (getAttr "generic-cl_dot_comparison" self) (getAttr "generic-cl_dot_container" self) (getAttr "generic-cl_dot_internal" self) (getAttr "generic-cl_dot_iterator" self) (getAttr "generic-cl_dot_object" self) (getAttr "static-dispatch" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl_dot_math = (build-asdf-system { - pname = "generic-cl.math"; - version = "20241012-git"; - asds = [ "generic-cl.math" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.math"; - asd = "generic-cl.math"; - }); - systems = [ "generic-cl.math" ]; - lispLibs = [ (getAttr "agutil" self) (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "arrows" self) (getAttr "generic-cl_dot_arithmetic" self) (getAttr "static-dispatch" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl_dot_object = (build-asdf-system { - pname = "generic-cl.object"; - version = "20241012-git"; - asds = [ "generic-cl.object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.object"; - asd = "generic-cl.object"; - }); - systems = [ "generic-cl.object" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "arrows" self) (getAttr "generic-cl_dot_comparison" self) (getAttr "static-dispatch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl_dot_sequence = (build-asdf-system { - pname = "generic-cl.sequence"; - version = "20241012-git"; - asds = [ "generic-cl.sequence" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.sequence"; - asd = "generic-cl.sequence"; - }); - systems = [ "generic-cl.sequence" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "arrows" self) (getAttr "cl-custom-hash-table" self) (getAttr "cl-form-types" self) (getAttr "generic-cl_dot_collector" self) (getAttr "generic-cl_dot_comparison" self) (getAttr "generic-cl_dot_container" self) (getAttr "generic-cl_dot_internal" self) (getAttr "generic-cl_dot_iterator" self) (getAttr "generic-cl_dot_map" self) (getAttr "generic-cl_dot_object" self) (getAttr "static-dispatch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl_dot_set = (build-asdf-system { - pname = "generic-cl.set"; - version = "20241012-git"; - asds = [ "generic-cl.set" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.set"; - asd = "generic-cl.set"; - }); - systems = [ "generic-cl.set" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "generic-cl_dot_arithmetic" self) (getAttr "generic-cl_dot_collector" self) (getAttr "generic-cl_dot_comparison" self) (getAttr "generic-cl_dot_container" self) (getAttr "generic-cl_dot_iterator" self) (getAttr "generic-cl_dot_map" self) (getAttr "generic-cl_dot_object" self) (getAttr "generic-cl_dot_sequence" self) (getAttr "static-dispatch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-cl_dot_util = (build-asdf-system { - pname = "generic-cl.util"; - version = "20241012-git"; - asds = [ "generic-cl.util" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; - sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; - system = "generic-cl.util"; - asd = "generic-cl.util"; - }); - systems = [ "generic-cl.util" ]; - lispLibs = [ (getAttr "generic-cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-comparability = (build-asdf-system { - pname = "generic-comparability"; - version = "20180131-git"; - asds = [ "generic-comparability" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-comparability/2018-01-31/generic-comparability-20180131-git.tgz"; - sha256 = "01ma0cwirxarwwmdwflnh8kmysmr2smh5kyvzhb2074ljxg8yq2p"; - system = "generic-comparability"; - asd = "generic-comparability"; - }); - systems = [ "generic-comparability" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-comparability-test = (build-asdf-system { - pname = "generic-comparability-test"; - version = "20180131-git"; - asds = [ "generic-comparability-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-comparability/2018-01-31/generic-comparability-20180131-git.tgz"; - sha256 = "01ma0cwirxarwwmdwflnh8kmysmr2smh5kyvzhb2074ljxg8yq2p"; - system = "generic-comparability-test"; - asd = "generic-comparability"; - }); - systems = [ "generic-comparability-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "fiveam" self) (getAttr "generic-comparability" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-sequences = (build-asdf-system { - pname = "generic-sequences"; - version = "20150709-git"; - asds = [ "generic-sequences" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-sequences/2015-07-09/generic-sequences-20150709-git.tgz"; - sha256 = "09kr0x4kx634rhslal6z2isnbs7v8rn5ic3pvxa3w1mm37lxx7h3"; - system = "generic-sequences"; - asd = "generic-sequences"; - }); - systems = [ "generic-sequences" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-sequences-cont = (build-asdf-system { - pname = "generic-sequences-cont"; - version = "20150709-git"; - asds = [ "generic-sequences-cont" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-sequences/2015-07-09/generic-sequences-20150709-git.tgz"; - sha256 = "09kr0x4kx634rhslal6z2isnbs7v8rn5ic3pvxa3w1mm37lxx7h3"; - system = "generic-sequences-cont"; - asd = "generic-sequences-cont"; - }); - systems = [ "generic-sequences-cont" ]; - lispLibs = [ (getAttr "cl-cont" self) (getAttr "generic-sequences" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-sequences-iterate = (build-asdf-system { - pname = "generic-sequences-iterate"; - version = "20150709-git"; - asds = [ "generic-sequences-iterate" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-sequences/2015-07-09/generic-sequences-20150709-git.tgz"; - sha256 = "09kr0x4kx634rhslal6z2isnbs7v8rn5ic3pvxa3w1mm37lxx7h3"; - system = "generic-sequences-iterate"; - asd = "generic-sequences-iterate"; - }); - systems = [ "generic-sequences-iterate" ]; - lispLibs = [ (getAttr "generic-sequences" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-sequences-stream = (build-asdf-system { - pname = "generic-sequences-stream"; - version = "20150709-git"; - asds = [ "generic-sequences-stream" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-sequences/2015-07-09/generic-sequences-20150709-git.tgz"; - sha256 = "09kr0x4kx634rhslal6z2isnbs7v8rn5ic3pvxa3w1mm37lxx7h3"; - system = "generic-sequences-stream"; - asd = "generic-sequences-stream"; - }); - systems = [ "generic-sequences-stream" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "generic-sequences" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - generic-sequences-test = (build-asdf-system { - pname = "generic-sequences-test"; - version = "20150709-git"; - asds = [ "generic-sequences-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/generic-sequences/2015-07-09/generic-sequences-20150709-git.tgz"; - sha256 = "09kr0x4kx634rhslal6z2isnbs7v8rn5ic3pvxa3w1mm37lxx7h3"; - system = "generic-sequences-test"; - asd = "generic-sequences-test"; - }); - systems = [ "generic-sequences-test" ]; - lispLibs = [ (getAttr "generic-sequences" self) (getAttr "generic-sequences-cont" self) (getAttr "generic-sequences-iterate" self) (getAttr "generic-sequences-stream" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geneva = (build-asdf-system { - pname = "geneva"; - version = "20161204-git"; - asds = [ "geneva" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; - sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; - system = "geneva"; - asd = "geneva"; - }); - systems = [ "geneva" ]; - lispLibs = [ (getAttr "named-readtables" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geneva-cl = (build-asdf-system { - pname = "geneva-cl"; - version = "20161204-git"; - asds = [ "geneva-cl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; - sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; - system = "geneva-cl"; - asd = "geneva-cl"; - }); - systems = [ "geneva-cl" ]; - lispLibs = [ (getAttr "geneva" self) (getAttr "geneva-mk2" self) (getAttr "named-readtables" self) (getAttr "split-sequence" self) (getAttr "trivial-documentation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geneva-html = (build-asdf-system { - pname = "geneva-html"; - version = "20161204-git"; - asds = [ "geneva-html" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; - sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; - system = "geneva-html"; - asd = "geneva-html"; - }); - systems = [ "geneva-html" ]; - lispLibs = [ (getAttr "file-types" self) (getAttr "geneva" self) (getAttr "macro-html" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geneva-latex = (build-asdf-system { - pname = "geneva-latex"; - version = "20161204-git"; - asds = [ "geneva-latex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; - sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; - system = "geneva-latex"; - asd = "geneva-latex"; - }); - systems = [ "geneva-latex" ]; - lispLibs = [ (getAttr "geneva" self) (getAttr "geneva-tex" self) (getAttr "named-readtables" self) (getAttr "texp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geneva-mk2 = (build-asdf-system { - pname = "geneva-mk2"; - version = "20161204-git"; - asds = [ "geneva-mk2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; - sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; - system = "geneva-mk2"; - asd = "geneva-mk2"; - }); - systems = [ "geneva-mk2" ]; - lispLibs = [ (getAttr "geneva" self) (getAttr "maxpc" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geneva-plain-text = (build-asdf-system { - pname = "geneva-plain-text"; - version = "20161204-git"; - asds = [ "geneva-plain-text" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; - sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; - system = "geneva-plain-text"; - asd = "geneva-plain-text"; - }); - systems = [ "geneva-plain-text" ]; - lispLibs = [ (getAttr "geneva" self) (getAttr "geneva-mk2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geneva-tex = (build-asdf-system { - pname = "geneva-tex"; - version = "20161204-git"; - asds = [ "geneva-tex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; - sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; - system = "geneva-tex"; - asd = "geneva-tex"; - }); - systems = [ "geneva-tex" ]; - lispLibs = [ (getAttr "file-types" self) (getAttr "geneva" self) (getAttr "named-readtables" self) (getAttr "texp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - genhash = (build-asdf-system { - pname = "genhash"; - version = "20181210-git"; - asds = [ "genhash" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/genhash/2018-12-10/genhash-20181210-git.tgz"; - sha256 = "1jnk1fix1zydhy0kn3cvlp6dy0241x7v8ahq001nlr6v152z1cwk"; - system = "genhash"; - asd = "genhash"; - }); - systems = [ "genhash" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geodesic = (build-asdf-system { - pname = "geodesic"; - version = "20230618-git"; - asds = [ "geodesic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/geodesic/2023-06-18/geodesic-20230618-git.tgz"; - sha256 = "13hvkf6r1y1yx0zqgkl8yg1fskfp7vpa9p34ar00s4ly432vbpxq"; - system = "geodesic"; - asd = "geodesic"; - }); - systems = [ "geodesic" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geom-base = (build-asdf-system { - pname = "geom-base"; - version = "master-fe503896-git"; - asds = [ "geom-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "geom-base"; - asd = "geom-base"; - }); - systems = [ "geom-base" ]; - lispLibs = [ (getAttr "base" self) (getAttr "cl-pdf" self) (getAttr "cl-typesetting" self) (getAttr "cl-who" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geowkt = (build-asdf-system { - pname = "geowkt"; - version = "20200610-git"; - asds = [ "geowkt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/geowkt/2020-06-10/geowkt-20200610-git.tgz"; - sha256 = "02l8cb2k10j7k6fvhk9dpqmkxs6vb5w5nh3159w7drprvjqhfrjw"; - system = "geowkt"; - asd = "geowkt"; - }); - systems = [ "geowkt" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geowkt-update = (build-asdf-system { - pname = "geowkt-update"; - version = "20200610-git"; - asds = [ "geowkt-update" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/geowkt/2020-06-10/geowkt-20200610-git.tgz"; - sha256 = "02l8cb2k10j7k6fvhk9dpqmkxs6vb5w5nh3159w7drprvjqhfrjw"; - system = "geowkt-update"; - asd = "geowkt-update"; - }); - systems = [ "geowkt-update" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - getopt = (build-asdf-system { - pname = "getopt"; - version = "20150923-git"; - asds = [ "getopt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/getopt/2015-09-23/getopt-20150923-git.tgz"; - sha256 = "1liwzghx2swws84xlxnq756gbass0s916a9sq5mjfnlg3scbwcs3"; - system = "getopt"; - asd = "getopt"; - }); - systems = [ "getopt" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - getopt-tests = (build-asdf-system { - pname = "getopt-tests"; - version = "20150923-git"; - asds = [ "getopt-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/getopt/2015-09-23/getopt-20150923-git.tgz"; - sha256 = "1liwzghx2swws84xlxnq756gbass0s916a9sq5mjfnlg3scbwcs3"; - system = "getopt-tests"; - asd = "getopt"; - }); - systems = [ "getopt-tests" ]; - lispLibs = [ (getAttr "getopt" self) (getAttr "ptester" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gettext = (build-asdf-system { - pname = "gettext"; - version = "20171130-git"; - asds = [ "gettext" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gettext/2017-11-30/gettext-20171130-git.tgz"; - sha256 = "1pzhamgni6k5hi6bbvlb3dm659pcllrrr3vhhn3rpjn238zxg5ar"; - system = "gettext"; - asd = "gettext"; - }); - systems = [ "gettext" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "split-sequence" self) (getAttr "yacc" self) ]; - meta = {}; - }); - gettext-example = (build-asdf-system { - pname = "gettext-example"; - version = "20171130-git"; - asds = [ "gettext-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gettext/2017-11-30/gettext-20171130-git.tgz"; - sha256 = "1pzhamgni6k5hi6bbvlb3dm659pcllrrr3vhhn3rpjn238zxg5ar"; - system = "gettext-example"; - asd = "gettext-example"; - }); - systems = [ "gettext-example" ]; - lispLibs = [ (getAttr "gettext" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gettext-tests = (build-asdf-system { - pname = "gettext-tests"; - version = "20171130-git"; - asds = [ "gettext-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gettext/2017-11-30/gettext-20171130-git.tgz"; - sha256 = "1pzhamgni6k5hi6bbvlb3dm659pcllrrr3vhhn3rpjn238zxg5ar"; - system = "gettext-tests"; - asd = "gettext-tests"; - }); - systems = [ "gettext-tests" ]; - lispLibs = [ (getAttr "gettext" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - geysr = (build-asdf-system { - pname = "geysr"; - version = "master-fe503896-git"; - asds = [ "geysr" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "geysr"; - asd = "geysr"; - }); - systems = [ "geysr" ]; - lispLibs = [ (getAttr "gendl-asdf" self) (getAttr "gwl-graphics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - git-file-history = (build-asdf-system { - pname = "git-file-history"; - version = "20160825-git"; - asds = [ "git-file-history" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/git-file-history/2016-08-25/git-file-history-20160825-git.tgz"; - sha256 = "00kdawcy3mhljv04xpx5n7l2s21qdpbm8i9avjdqbxvfc5j05bq8"; - system = "git-file-history"; - asd = "git-file-history"; - }); - systems = [ "git-file-history" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "legit" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - git-file-history-test = (build-asdf-system { - pname = "git-file-history-test"; - version = "20160825-git"; - asds = [ "git-file-history-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/git-file-history/2016-08-25/git-file-history-20160825-git.tgz"; - sha256 = "00kdawcy3mhljv04xpx5n7l2s21qdpbm8i9avjdqbxvfc5j05bq8"; - system = "git-file-history-test"; - asd = "git-file-history-test"; - }); - systems = [ "git-file-history-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "git-file-history" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - github-api-cl = (build-asdf-system { - pname = "github-api-cl"; - version = "20241012-git"; - asds = [ "github-api-cl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/github-api-cl/2024-10-12/github-api-cl-20241012-git.tgz"; - sha256 = "04kvhap041v26axg4pzzymnibzh430yvja8c6dhic27g2639kswh"; - system = "github-api-cl"; - asd = "github-api-cl"; - }); - systems = [ "github-api-cl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi-grovel" self) (getAttr "cl-base64" self) (getAttr "clack" self) (getAttr "dexador" self) (getAttr "str" self) (getAttr "trivial-features" self) (getAttr "woo" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - github-gist-api-cl = (build-asdf-system { - pname = "github-gist-api-cl"; - version = "20241012-git"; - asds = [ "github-gist-api-cl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/github-api-cl/2024-10-12/github-api-cl-20241012-git.tgz"; - sha256 = "04kvhap041v26axg4pzzymnibzh430yvja8c6dhic27g2639kswh"; - system = "github-gist-api-cl"; - asd = "github-gist-api-cl"; - }); - systems = [ "github-gist-api-cl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi-grovel" self) (getAttr "cl-base64" self) (getAttr "clack" self) (getAttr "dexador" self) (getAttr "github-api-cl" self) (getAttr "str" self) (getAttr "trivial-features" self) (getAttr "woo" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glacier = (build-asdf-system { - pname = "glacier"; - version = "20230214-git"; - asds = [ "glacier" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glacier/2023-02-14/glacier-20230214-git.tgz"; - sha256 = "1h66cd3bn3n8yjd922xsvv0r668cm82106nm2k3fnll67apazlwi"; - system = "glacier"; - asd = "glacier"; - }); - systems = [ "glacier" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "dexador" self) (getAttr "simple-config" self) (getAttr "str" self) (getAttr "tooter" self) (getAttr "websocket-driver" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glad-blob = (build-asdf-system { - pname = "glad-blob"; - version = "stable-git"; - asds = [ "glad-blob" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glad-blob/2020-10-16/glad-blob-stable-git.tgz"; - sha256 = "19vp7nyf4kxhczi8i2w47lvipk1i4psrxlpk4nvbdh97vc12k5a7"; - system = "glad-blob"; - asd = "glad-blob"; - }); - systems = [ "glad-blob" ]; - lispLibs = [ (getAttr "bodge-blobs-support" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glass = (build-asdf-system { - pname = "glass"; - version = "20150709-git"; - asds = [ "glass" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glass/2015-07-09/glass-20150709-git.tgz"; - sha256 = "1xwr6mj25m0z1qhp30hafbbhrfj34dfidy320x5m3lij13vbyb1p"; - system = "glass"; - asd = "glass"; - }); - systems = [ "glass" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glaw = (build-asdf-system { - pname = "glaw"; - version = "20180228-git"; - asds = [ "glaw" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glaw/2018-02-28/glaw-20180228-git.tgz"; - sha256 = "06i9g80hkqgwk5h306wkdpcpv7n229n1ig1hy6697l35v8c4mzmp"; - system = "glaw"; - asd = "glaw"; - }); - systems = [ "glaw" ]; - lispLibs = [ (getAttr "cl-alc" self) (getAttr "cl-openal" self) (getAttr "cl-opengl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glaw-examples = (build-asdf-system { - pname = "glaw-examples"; - version = "20180228-git"; - asds = [ "glaw-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glaw/2018-02-28/glaw-20180228-git.tgz"; - sha256 = "06i9g80hkqgwk5h306wkdpcpv7n229n1ig1hy6697l35v8c4mzmp"; - system = "glaw-examples"; - asd = "glaw-examples"; - }); - systems = [ "glaw-examples" ]; - lispLibs = [ (getAttr "glaw" self) (getAttr "glaw-imago" self) (getAttr "glop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glaw-imago = (build-asdf-system { - pname = "glaw-imago"; - version = "20180228-git"; - asds = [ "glaw-imago" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glaw/2018-02-28/glaw-20180228-git.tgz"; - sha256 = "06i9g80hkqgwk5h306wkdpcpv7n229n1ig1hy6697l35v8c4mzmp"; - system = "glaw-imago"; - asd = "glaw-imago"; - }); - systems = [ "glaw-imago" ]; - lispLibs = [ (getAttr "glaw" self) (getAttr "imago" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glaw-sdl = (build-asdf-system { - pname = "glaw-sdl"; - version = "20180228-git"; - asds = [ "glaw-sdl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glaw/2018-02-28/glaw-20180228-git.tgz"; - sha256 = "06i9g80hkqgwk5h306wkdpcpv7n229n1ig1hy6697l35v8c4mzmp"; - system = "glaw-sdl"; - asd = "glaw-sdl"; - }); - systems = [ "glaw-sdl" ]; - lispLibs = [ (getAttr "glaw" self) (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-image" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glfw = (build-asdf-system { - pname = "glfw"; - version = "20241012-git"; - asds = [ "glfw" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glfw/2024-10-12/glfw-20241012-git.tgz"; - sha256 = "1n421gvrzs76v57icy0c4zhz84ymin91vbv5gkkj4i00cnggwdxv"; - system = "glfw"; - asd = "glfw"; - }); - systems = [ "glfw" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-opengl" self) (getAttr "documentation-utils" self) (getAttr "float-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glfw-blob = (build-asdf-system { - pname = "glfw-blob"; - version = "stable-git"; - asds = [ "glfw-blob" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glfw-blob/2020-10-16/glfw-blob-stable-git.tgz"; - sha256 = "0j953vqsyswipgyhc39swsgwgaqb53wvs80izraknlsp379hzabs"; - system = "glfw-blob"; - asd = "glfw-blob"; - }); - systems = [ "glfw-blob" ]; - lispLibs = [ (getAttr "bodge-blobs-support" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glhelp = (build-asdf-system { - pname = "glhelp"; - version = "20200427-git"; - asds = [ "glhelp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "glhelp"; - asd = "glhelp"; - }); - systems = [ "glhelp" ]; - lispLibs = [ (getAttr "cl-opengl" self) (getAttr "deflazy" self) (getAttr "glsl-toolkit" self) (getAttr "split-sequence" self) (getAttr "uncommon-lisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glisp = (build-asdf-system { - pname = "glisp"; - version = "master-fe503896-git"; - asds = [ "glisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "glisp"; - asd = "glisp"; - }); - systems = [ "glisp" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "base" self) (getAttr "bordeaux-threads" self) (getAttr "cl-base64" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glisph = (build-asdf-system { - pname = "glisph"; - version = "20170403-git"; - asds = [ "glisph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glisph/2017-04-03/glisph-20170403-git.tgz"; - sha256 = "097d6kjk4rndpqn181k9nyr2bps4gf3shq5x2fy1swvks3pvys91"; - system = "glisph"; - asd = "glisph"; - }); - systems = [ "glisph" ]; - lispLibs = [ (getAttr "cl-annot" self) (getAttr "cl-glu" self) (getAttr "cl-opengl" self) (getAttr "cl-reexport" self) (getAttr "zpb-ttf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glisph-test = (build-asdf-system { - pname = "glisph-test"; - version = "20170403-git"; - asds = [ "glisph-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glisph/2017-04-03/glisph-20170403-git.tgz"; - sha256 = "097d6kjk4rndpqn181k9nyr2bps4gf3shq5x2fy1swvks3pvys91"; - system = "glisph-test"; - asd = "glisph-test"; - }); - systems = [ "glisph-test" ]; - lispLibs = [ (getAttr "cl-glut" self) (getAttr "glisph" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glkit = (build-asdf-system { - pname = "glkit"; - version = "20201016-git"; - asds = [ "glkit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glkit/2020-10-16/glkit-20201016-git.tgz"; - sha256 = "1x3y5jcr1f0v9sgn3y5b7b8fhgd6vv37nz73016gdwh511idi8jn"; - system = "glkit"; - asd = "glkit"; - }); - systems = [ "glkit" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-opengl" self) (getAttr "defpackage-plus" self) (getAttr "mathkit" self) (getAttr "static-vectors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glkit-examples = (build-asdf-system { - pname = "glkit-examples"; - version = "20201016-git"; - asds = [ "glkit-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glkit/2020-10-16/glkit-20201016-git.tgz"; - sha256 = "1x3y5jcr1f0v9sgn3y5b7b8fhgd6vv37nz73016gdwh511idi8jn"; - system = "glkit-examples"; - asd = "glkit-examples"; - }); - systems = [ "glkit-examples" ]; - lispLibs = [ (getAttr "glkit" self) (getAttr "sdl2kit-examples" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - global-vars = (build-asdf-system { - pname = "global-vars"; - version = "20141106-git"; - asds = [ "global-vars" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/global-vars/2014-11-06/global-vars-20141106-git.tgz"; - sha256 = "06m3xc8l3pgsapl8fvsi9wf6y46zs75cp9zn7zh6dc65v4s5wz3d"; - system = "global-vars"; - asd = "global-vars"; - }); - systems = [ "global-vars" ]; - lispLibs = [ ]; - meta = {}; - }); - global-vars-test = (build-asdf-system { - pname = "global-vars-test"; - version = "20141106-git"; - asds = [ "global-vars-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/global-vars/2014-11-06/global-vars-20141106-git.tgz"; - sha256 = "06m3xc8l3pgsapl8fvsi9wf6y46zs75cp9zn7zh6dc65v4s5wz3d"; - system = "global-vars-test"; - asd = "global-vars-test"; - }); - systems = [ "global-vars-test" ]; - lispLibs = [ (getAttr "global-vars" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glop = (build-asdf-system { - pname = "glop"; - version = "20171019-git"; - asds = [ "glop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glop/2017-10-19/glop-20171019-git.tgz"; - sha256 = "1nm35kvigflfjlmsa8zwdajc61f02fh4sq08jv0wnqylhx8yg2bv"; - system = "glop"; - asd = "glop"; - }); - systems = [ "glop" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "split-sequence" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glop-test = (build-asdf-system { - pname = "glop-test"; - version = "20171019-git"; - asds = [ "glop-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glop/2017-10-19/glop-20171019-git.tgz"; - sha256 = "1nm35kvigflfjlmsa8zwdajc61f02fh4sq08jv0wnqylhx8yg2bv"; - system = "glop-test"; - asd = "glop-test"; - }); - systems = [ "glop-test" ]; - lispLibs = [ (getAttr "cl-glu" self) (getAttr "cl-opengl" self) (getAttr "glop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glsl-docs = (build-asdf-system { - pname = "glsl-docs"; - version = "release-quicklisp-f04476f7-git"; - asds = [ "glsl-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glsl-spec/2019-10-07/glsl-spec-release-quicklisp-f04476f7-git.tgz"; - sha256 = "01ipspr22fgfj3w8wq2y81lzrjc4vpfiwnr3dqhjlpzzra46am8c"; - system = "glsl-docs"; - asd = "glsl-docs"; - }); - systems = [ "glsl-docs" ]; - lispLibs = [ (getAttr "glsl-symbols" self) ]; - meta = {}; - }); - glsl-packing = (build-asdf-system { - pname = "glsl-packing"; - version = "20180131-git"; - asds = [ "glsl-packing" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glsl-packing/2018-01-31/glsl-packing-20180131-git.tgz"; - sha256 = "0k2f1771wd9kdrcasldy1r00k5bdgi9fd07in52zmjggc0i7dd80"; - system = "glsl-packing"; - asd = "glsl-packing"; - }); - systems = [ "glsl-packing" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glsl-spec = (build-asdf-system { - pname = "glsl-spec"; - version = "release-quicklisp-f04476f7-git"; - asds = [ "glsl-spec" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glsl-spec/2019-10-07/glsl-spec-release-quicklisp-f04476f7-git.tgz"; - sha256 = "01ipspr22fgfj3w8wq2y81lzrjc4vpfiwnr3dqhjlpzzra46am8c"; - system = "glsl-spec"; - asd = "glsl-spec"; - }); - systems = [ "glsl-spec" ]; - lispLibs = [ ]; - meta = {}; - }); - glsl-symbols = (build-asdf-system { - pname = "glsl-symbols"; - version = "release-quicklisp-f04476f7-git"; - asds = [ "glsl-symbols" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glsl-spec/2019-10-07/glsl-spec-release-quicklisp-f04476f7-git.tgz"; - sha256 = "01ipspr22fgfj3w8wq2y81lzrjc4vpfiwnr3dqhjlpzzra46am8c"; - system = "glsl-symbols"; - asd = "glsl-symbols"; - }); - systems = [ "glsl-symbols" ]; - lispLibs = [ ]; - meta = {}; - }); - glsl-toolkit = (build-asdf-system { - pname = "glsl-toolkit"; - version = "20241012-git"; - asds = [ "glsl-toolkit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glsl-toolkit/2024-10-12/glsl-toolkit-20241012-git.tgz"; - sha256 = "0yh6y2k2v5ivzwfnvnprlcih8jn7fv3pzz2wn85fpvbfw4mg120x"; - system = "glsl-toolkit"; - asd = "glsl-toolkit"; - }); - systems = [ "glsl-toolkit" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "documentation-utils" self) (getAttr "parse-float" self) (getAttr "trivial-indent" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glu-tessellate = (build-asdf-system { - pname = "glu-tessellate"; - version = "20150608-git"; - asds = [ "glu-tessellate" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glu-tessellate/2015-06-08/glu-tessellate-20150608-git.tgz"; - sha256 = "1iwnvk341pidxdsjb2c730k6a7nr1knd5ir0v83y6jhsf78r9krh"; - system = "glu-tessellate"; - asd = "glu-tessellate"; - }); - systems = [ "glu-tessellate" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glyphs = (build-asdf-system { - pname = "glyphs"; - version = "20180711-git"; - asds = [ "glyphs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glyphs/2018-07-11/glyphs-20180711-git.tgz"; - sha256 = "17kai1anbkk5dj5sbrsin2fc019cmcbglb900db60v38myj0y0wf"; - system = "glyphs"; - asd = "glyphs"; - }); - systems = [ "glyphs" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "named-readtables" self) (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - glyphs-test = (build-asdf-system { - pname = "glyphs-test"; - version = "20180711-git"; - asds = [ "glyphs-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/glyphs/2018-07-11/glyphs-20180711-git.tgz"; - sha256 = "17kai1anbkk5dj5sbrsin2fc019cmcbglb900db60v38myj0y0wf"; - system = "glyphs-test"; - asd = "glyphs-test"; - }); - systems = [ "glyphs-test" ]; - lispLibs = [ (getAttr "glyphs" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - golden-utils = (build-asdf-system { - pname = "golden-utils"; - version = "20241012-git"; - asds = [ "golden-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/golden-utils/2024-10-12/golden-utils-20241012-git.tgz"; - sha256 = "09vq29wjr3x7h3fshwxg8h1psy4p73yl61cjljarpqjhsgz7lmbp"; - system = "golden-utils"; - asd = "golden-utils"; - }); - systems = [ "golden-utils" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gooptest = (build-asdf-system { - pname = "gooptest"; - version = "20200925-git"; - asds = [ "gooptest" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gooptest/2020-09-25/gooptest-20200925-git.tgz"; - sha256 = "1g9q4frlc79xkmz74ybs954rc5kmfwjsn4xi64aig1fh5wjni5xs"; - system = "gooptest"; - asd = "gooptest"; - }); - systems = [ "gooptest" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cffi" self) (getAttr "cl-autowrap" self) (getAttr "cl-plus-c" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - graph = (build-asdf-system { - pname = "graph"; - version = "20220331-git"; - asds = [ "graph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/graph/2022-03-31/graph-20220331-git.tgz"; - sha256 = "0m76vb0mk7rlbv9xhnix001gxik9f7vy9lspradcvzbk1rfxyyf7"; - system = "graph"; - asd = "graph"; - }); - systems = [ "graph" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "asdf-package-system" self) (getAttr "curry-compose-reader-macros" self) (getAttr "damn-fast-priority-queue" self) (getAttr "metabang-bind" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - graphs = (build-asdf-system { - pname = "graphs"; - version = "master-fe503896-git"; - asds = [ "graphs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "graphs"; - asd = "graphs"; - }); - systems = [ "graphs" ]; - lispLibs = [ (getAttr "gwl-graphics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gravatar = (build-asdf-system { - pname = "gravatar"; - version = "20110320-git"; - asds = [ "gravatar" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gravatar/2011-03-20/cl-gravatar-20110320-git.tgz"; - sha256 = "1r9fq1zaywlhpxr3s3wgajhxf1kgwsgsql0a7ccfgsbwkgy2qzfs"; - system = "gravatar"; - asd = "gravatar"; - }); - systems = [ "gravatar" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-json" self) (getAttr "drakma" self) (getAttr "md5" self) (getAttr "puri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - graylex = (build-asdf-system { - pname = "graylex"; - version = "20110522-git"; - asds = [ "graylex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/graylex/2011-05-22/graylex-20110522-git.tgz"; - sha256 = "0s1mpz6cpx3fywznxc8kzkhbb4fpmzyjpfgc85lnxqmri8wy6xqy"; - system = "graylex"; - asd = "graylex"; - }); - systems = [ "graylex" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - graylex-m4-example = (build-asdf-system { - pname = "graylex-m4-example"; - version = "20110522-git"; - asds = [ "graylex-m4-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/graylex/2011-05-22/graylex-20110522-git.tgz"; - sha256 = "0s1mpz6cpx3fywznxc8kzkhbb4fpmzyjpfgc85lnxqmri8wy6xqy"; - system = "graylex-m4-example"; - asd = "graylex-m4-example"; - }); - systems = [ "graylex-m4-example" ]; - lispLibs = [ (getAttr "cl-heredoc" self) (getAttr "graylex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - graylog = (build-asdf-system { - pname = "graylog"; - version = "20180430-git"; - asds = [ "graylog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-graylog/2018-04-30/cl-graylog-20180430-git.tgz"; - sha256 = "1bj1v6vwz8w78h0bkjv5614gq50jdpjix88rbn3nvh81cfjvsqdg"; - system = "graylog"; - asd = "graylog"; - }); - systems = [ "graylog" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-json" self) (getAttr "local-time" self) (getAttr "salza2" self) (getAttr "trivial-backtrace" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - graylog-log5 = (build-asdf-system { - pname = "graylog-log5"; - version = "20180430-git"; - asds = [ "graylog-log5" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-graylog/2018-04-30/cl-graylog-20180430-git.tgz"; - sha256 = "1bj1v6vwz8w78h0bkjv5614gq50jdpjix88rbn3nvh81cfjvsqdg"; - system = "graylog-log5"; - asd = "graylog-log5"; - }); - systems = [ "graylog-log5" ]; - lispLibs = [ (getAttr "graylog" self) (getAttr "log5" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - green-threads = (build-asdf-system { - pname = "green-threads"; - version = "20141217-git"; - asds = [ "green-threads" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/green-threads/2014-12-17/green-threads-20141217-git.tgz"; - sha256 = "1czw7nr0dwfps76h8hjvglk1wdh53yqbfbvv30whwbgqx33iippz"; - system = "green-threads"; - asd = "green-threads"; - }); - systems = [ "green-threads" ]; - lispLibs = [ (getAttr "cl-async-future" self) (getAttr "cl-cont" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - grid-formation = (build-asdf-system { - pname = "grid-formation"; - version = "20220707-git"; - asds = [ "grid-formation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/grid-formation/2022-07-07/grid-formation-20220707-git.tgz"; - sha256 = "0s5picmkn7gn98k23axadbc0mlzlrbadi1ln85gpqp17k3cmd54m"; - system = "grid-formation"; - asd = "grid-formation"; - }); - systems = [ "grid-formation" ]; - lispLibs = [ (getAttr "mfiano-utils" self) (getAttr "origin" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - group-by = (build-asdf-system { - pname = "group-by"; - version = "20140211-git"; - asds = [ "group-by" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/group-by/2014-02-11/group-by-20140211-git.tgz"; - sha256 = "1p1qprb57fjd6sj8ws6c7y40ab38mym65wni8xivdy89i3d63dz4"; - system = "group-by"; - asd = "group-by"; - }); - systems = [ "group-by" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - group-by-test = (build-asdf-system { - pname = "group-by-test"; - version = "20140211-git"; - asds = [ "group-by-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/group-by/2014-02-11/group-by-20140211-git.tgz"; - sha256 = "1p1qprb57fjd6sj8ws6c7y40ab38mym65wni8xivdy89i3d63dz4"; - system = "group-by-test"; - asd = "group-by"; - }); - systems = [ "group-by-test" ]; - lispLibs = [ (getAttr "group-by" self) (getAttr "lisp-unit2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - groupby = (build-asdf-system { - pname = "groupby"; - version = "20170830-git"; - asds = [ "groupby" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-groupby/2017-08-30/cl-groupby-20170830-git.tgz"; - sha256 = "1ra4zi9ifrhxxsj4svg1iqqzzsv9aqqa76pswygp7g084x6kn5km"; - system = "groupby"; - asd = "groupby"; - }); - systems = [ "groupby" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - grovel-locally = (build-asdf-system { - pname = "grovel-locally"; - version = "20180228-git"; - asds = [ "grovel-locally" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/grovel-locally/2018-02-28/grovel-locally-20180228-git.tgz"; - sha256 = "07q7zjgv3d1f35zwxpzcz020z0gcqi6m2l2szw99bsqk5hn93szl"; - system = "grovel-locally"; - asd = "grovel-locally"; - }); - systems = [ "grovel-locally" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-ppcre" self) (getAttr "with-cached-reader-conditionals" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gsll = (build-asdf-system { - pname = "gsll"; - version = "quicklisp-eeeda841-git"; - asds = [ "gsll" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gsll/2018-08-31/gsll-quicklisp-eeeda841-git.tgz"; - sha256 = "0zsjvi1f62hjgfjk4wqg13d4r53bli9nglkwnd31qrygn8pmzlhi"; - system = "gsll"; - asd = "gsll"; - }); - systems = [ "gsll" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi-grovel" self) (getAttr "cffi-libffi" self) (getAttr "foreign-array" self) (getAttr "lisp-unit" self) (getAttr "metabang-bind" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - gt = (build-asdf-system { - pname = "gt"; - version = "20241012-git"; - asds = [ "gt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-utils/2024-10-12/cl-utils-20241012-git.tgz"; - sha256 = "133alv8368k9pjkvh3vsfsk50whw7si4i2i7b8z256knpb2d35gh"; - system = "gt"; - asd = "gt"; - }); - systems = [ "gt" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "asdf-package-system" self) (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "curry-compose-reader-macros" self) (getAttr "fset" self) (getAttr "functional-trees" self) (getAttr "iterate" self) (getAttr "misc-extensions" self) (getAttr "named-readtables" self) (getAttr "serapeum" self) (getAttr "split-sequence" self) (getAttr "trivia" self) (getAttr "trivia_dot_ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gtirb = (build-asdf-system { - pname = "gtirb"; - version = "quicklisp-dd18337d-git"; - asds = [ "gtirb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gtirb/2021-10-20/gtirb-quicklisp-dd18337d-git.tgz"; - sha256 = "0dpchsshnlh3jb9rg1zdf63mr5l33vhjdxgxx2vqg0nh1sh41zn1"; - system = "gtirb"; - asd = "gtirb"; - }); - systems = [ "gtirb" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "asdf-package-system" self) (getAttr "cl-intbytes" self) (getAttr "cl-interval" self) (getAttr "curry-compose-reader-macros" self) (getAttr "graph" self) (getAttr "named-readtables" self) (getAttr "proto" self) (getAttr "protobuf" self) (getAttr "trivia" self) (getAttr "trivial-package-local-nicknames" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gtirb-capstone = (build-asdf-system { - pname = "gtirb-capstone"; - version = "20231021-git"; - asds = [ "gtirb-capstone" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gtirb-capstone/2023-10-21/gtirb-capstone-20231021-git.tgz"; - sha256 = "1i65iay3pkc0q00inqyykjpv38jj0abz7j7dbsm6bamjvrh8n1v8"; - system = "gtirb-capstone"; - asd = "gtirb-capstone"; - }); - systems = [ "gtirb-capstone" ]; - lispLibs = [ (getAttr "asdf-package-system" self) (getAttr "capstone" self) (getAttr "graph" self) (getAttr "gt" self) (getAttr "gtirb" self) (getAttr "keystone" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gtirb-functions = (build-asdf-system { - pname = "gtirb-functions"; - version = "20230618-git"; - asds = [ "gtirb-functions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gtirb-functions/2023-06-18/gtirb-functions-20230618-git.tgz"; - sha256 = "19w18vfqrkjrsn4i4i3ppw5q80557pj0844r4zr3pbr0l8ypjcnp"; - system = "gtirb-functions"; - asd = "gtirb-functions"; - }); - systems = [ "gtirb-functions" ]; - lispLibs = [ (getAttr "asdf-package-system" self) (getAttr "graph" self) (getAttr "gt" self) (getAttr "gtirb" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gtk-tagged-streams = (build-asdf-system { - pname = "gtk-tagged-streams"; - version = "quicklisp-d1c2b827-git"; - asds = [ "gtk-tagged-streams" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gtk-tagged-streams/2018-02-28/gtk-tagged-streams-quicklisp-d1c2b827-git.tgz"; - sha256 = "0ciw4ydcb8clsqb338hxpzncj2m59i6scnqlgbwkznm5i9dxvkyd"; - system = "gtk-tagged-streams"; - asd = "gtk-tagged-streams"; - }); - systems = [ "gtk-tagged-streams" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-cffi-gtk" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gtwiwtg = (build-asdf-system { - pname = "gtwiwtg"; - version = "20231021-git"; - asds = [ "gtwiwtg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gtwiwtg/2023-10-21/gtwiwtg-20231021-git.tgz"; - sha256 = "0pp28s2bydqcd850kyk4jjvjky692lqgld9lc9v64lb96ibxzplk"; - system = "gtwiwtg"; - asd = "gtwiwtg"; - }); - systems = [ "gtwiwtg" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gtype = (build-asdf-system { - pname = "gtype"; - version = "20200610-git"; - asds = [ "gtype" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gtype/2020-06-10/gtype-20200610-git.tgz"; - sha256 = "0hbkfdw00v7bsa6zbric34p5w6hfwxycccg8wc2faq0cxhsvpv9h"; - system = "gtype"; - asd = "gtype"; - }); - systems = [ "gtype" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "trivia" self) (getAttr "trivial-cltl2" self) (getAttr "trivialib_dot_type-unify" self) (getAttr "type-r" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gtype_dot_test = (build-asdf-system { - pname = "gtype.test"; - version = "20200610-git"; - asds = [ "gtype.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gtype/2020-06-10/gtype-20200610-git.tgz"; - sha256 = "0hbkfdw00v7bsa6zbric34p5w6hfwxycccg8wc2faq0cxhsvpv9h"; - system = "gtype.test"; - asd = "gtype.test"; - }); - systems = [ "gtype.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "gtype" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gute = (build-asdf-system { - pname = "gute"; - version = "20221106-git"; - asds = [ "gute" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gute/2022-11-06/gute-20221106-git.tgz"; - sha256 = "1d1m4qaygvmkglwdqlnhkvwq0wrig13h97w8ansfkyig359vpzy0"; - system = "gute"; - asd = "gute"; - }); - systems = [ "gute" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-mathstats" self) (getAttr "cl-ppcre" self) (getAttr "cl-strings" self) (getAttr "conium" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gwl = (build-asdf-system { - pname = "gwl"; - version = "master-fe503896-git"; - asds = [ "gwl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "gwl"; - asd = "gwl"; - }); - systems = [ "gwl" ]; - lispLibs = [ (getAttr "cl-html-parse" self) (getAttr "cl-markdown" self) (getAttr "cl-who" self) (getAttr "glisp" self) (getAttr "yason" self) (getAttr "zaserve" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gwl-graphics = (build-asdf-system { - pname = "gwl-graphics"; - version = "master-fe503896-git"; - asds = [ "gwl-graphics" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "gwl-graphics"; - asd = "gwl-graphics"; - }); - systems = [ "gwl-graphics" ]; - lispLibs = [ (getAttr "geom-base" self) (getAttr "gwl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - gzip-stream = (build-asdf-system { - pname = "gzip-stream"; - version = "0.2.8"; - asds = [ "gzip-stream" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gzip-stream/2010-10-06/gzip-stream_0.2.8.tgz"; - sha256 = "1m2x685mk9zp8vq45r4gf6mlbzmzr79mvdxibw1fqzv7r1bqrwrs"; - system = "gzip-stream"; - asd = "gzip-stream"; - }); - systems = [ "gzip-stream" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "salza2" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hamcrest = (build-asdf-system { - pname = "hamcrest"; - version = "20241012-git"; - asds = [ "hamcrest" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-hamcrest/2024-10-12/cl-hamcrest-20241012-git.tgz"; - sha256 = "05l5i5cmm1yqg8x9ayffaf3a9xf742k02wkxwpkc125ih5x0ggws"; - system = "hamcrest"; - asd = "hamcrest"; - }); - systems = [ "hamcrest" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "iterate" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hamcrest-ci = (build-asdf-system { - pname = "hamcrest-ci"; - version = "20241012-git"; - asds = [ "hamcrest-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-hamcrest/2024-10-12/cl-hamcrest-20241012-git.tgz"; - sha256 = "05l5i5cmm1yqg8x9ayffaf3a9xf742k02wkxwpkc125ih5x0ggws"; - system = "hamcrest-ci"; - asd = "hamcrest-ci"; - }); - systems = [ "hamcrest-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hamcrest-tests = (build-asdf-system { - pname = "hamcrest-tests"; - version = "20241012-git"; - asds = [ "hamcrest-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-hamcrest/2024-10-12/cl-hamcrest-20241012-git.tgz"; - sha256 = "05l5i5cmm1yqg8x9ayffaf3a9xf742k02wkxwpkc125ih5x0ggws"; - system = "hamcrest-tests"; - asd = "hamcrest-tests"; - }); - systems = [ "hamcrest-tests" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "prove" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - harmony = (build-asdf-system { - pname = "harmony"; - version = "20241012-git"; - asds = [ "harmony" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/harmony/2024-10-12/harmony-20241012-git.tgz"; - sha256 = "0bzqwcbnpb529bdp35c4s3p4p6rsrjnsvll2bkkrwpxlwzdd3fim"; - system = "harmony"; - asd = "harmony"; - }); - systems = [ "harmony" ]; - lispLibs = [ (getAttr "atomics" self) (getAttr "bordeaux-threads" self) (getAttr "cl-mixed" self) (getAttr "cl-mixed-alsa" self) (getAttr "cl-mixed-pulse" self) (getAttr "stealth-mixin" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hash-set = (build-asdf-system { - pname = "hash-set"; - version = "20211230-git"; - asds = [ "hash-set" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hash-set/2021-12-30/hash-set-20211230-git.tgz"; - sha256 = "0a966y9yfarhmki4wwzg371ziaygnp13yc6r13w9zz327fkhz8na"; - system = "hash-set"; - asd = "hash-set"; - }); - systems = [ "hash-set" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hash-set-tests = (build-asdf-system { - pname = "hash-set-tests"; - version = "20211230-git"; - asds = [ "hash-set-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hash-set/2021-12-30/hash-set-20211230-git.tgz"; - sha256 = "0a966y9yfarhmki4wwzg371ziaygnp13yc6r13w9zz327fkhz8na"; - system = "hash-set-tests"; - asd = "hash-set-tests"; - }); - systems = [ "hash-set-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "hash-set" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hash-table-ext = (build-asdf-system { - pname = "hash-table-ext"; - version = "20211020-git"; - asds = [ "hash-table-ext" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hash-table-ext/2021-10-20/hash-table-ext-20211020-git.tgz"; - sha256 = "00pafnjy5w9yhbzzdvgg4wwb8yicjjshgzxnn0by3d9qknxc7539"; - system = "hash-table-ext"; - asd = "hash-table-ext"; - }); - systems = [ "hash-table-ext" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "jingoh_dot_documentizer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hash-table-ext_dot_test = (build-asdf-system { - pname = "hash-table-ext.test"; - version = "20211020-git"; - asds = [ "hash-table-ext.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hash-table-ext/2021-10-20/hash-table-ext-20211020-git.tgz"; - sha256 = "00pafnjy5w9yhbzzdvgg4wwb8yicjjshgzxnn0by3d9qknxc7539"; - system = "hash-table-ext.test"; - asd = "hash-table-ext.test"; - }); - systems = [ "hash-table-ext.test" ]; - lispLibs = [ (getAttr "hash-table-ext" self) (getAttr "jingoh" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hashtrie = (build-asdf-system { - pname = "hashtrie"; - version = "20241012-git"; - asds = [ "hashtrie" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hashtrie/2024-10-12/hashtrie-20241012-git.tgz"; - sha256 = "1qn7azbl2p3hjvrb87bb06d3njsi5ksmdcv4mk80iadq06w0rn0n"; - system = "hashtrie"; - asd = "hashtrie"; - }); - systems = [ "hashtrie" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hashtrie-tests = (build-asdf-system { - pname = "hashtrie-tests"; - version = "20241012-git"; - asds = [ "hashtrie-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hashtrie/2024-10-12/hashtrie-20241012-git.tgz"; - sha256 = "1qn7azbl2p3hjvrb87bb06d3njsi5ksmdcv4mk80iadq06w0rn0n"; - system = "hashtrie-tests"; - asd = "hashtrie-tests"; - }); - systems = [ "hashtrie-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "hashtrie" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hdf5-cffi = (build-asdf-system { - pname = "hdf5-cffi"; - version = "20180228-git"; - asds = [ "hdf5-cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hdf5-cffi/2018-02-28/hdf5-cffi-20180228-git.tgz"; - sha256 = "0vda3075423xz83qky998lpac5b04dwfv7bwgh9jq8cs5v0zrxjf"; - system = "hdf5-cffi"; - asd = "hdf5-cffi"; - }); - systems = [ "hdf5-cffi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hdf5-cffi_dot_examples = (build-asdf-system { - pname = "hdf5-cffi.examples"; - version = "20180228-git"; - asds = [ "hdf5-cffi.examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hdf5-cffi/2018-02-28/hdf5-cffi-20180228-git.tgz"; - sha256 = "0vda3075423xz83qky998lpac5b04dwfv7bwgh9jq8cs5v0zrxjf"; - system = "hdf5-cffi.examples"; - asd = "hdf5-cffi.examples"; - }); - systems = [ "hdf5-cffi.examples" ]; - lispLibs = [ (getAttr "hdf5-cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hdf5-cffi_dot_test = (build-asdf-system { - pname = "hdf5-cffi.test"; - version = "20180228-git"; - asds = [ "hdf5-cffi.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hdf5-cffi/2018-02-28/hdf5-cffi-20180228-git.tgz"; - sha256 = "0vda3075423xz83qky998lpac5b04dwfv7bwgh9jq8cs5v0zrxjf"; - system = "hdf5-cffi.test"; - asd = "hdf5-cffi.test"; - }); - systems = [ "hdf5-cffi.test" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "fiveam" self) (getAttr "hdf5-cffi" self) (getAttr "hdf5-cffi_dot_examples" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - heap = (build-asdf-system { - pname = "heap"; - version = "20181018-git"; - asds = [ "heap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/heap/2018-10-18/heap-20181018-git.tgz"; - sha256 = "0jkgazjnjip7y41zd8rpy89ymh75yimk1q24qbddcisq5rzdl52k"; - system = "heap"; - asd = "heap"; - }); - systems = [ "heap" ]; - lispLibs = [ ]; - meta = {}; - }); - helambdap = (build-asdf-system { - pname = "helambdap"; - version = "20241012-git"; - asds = [ "helambdap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/helambdap/2024-10-12/helambdap-20241012-git.tgz"; - sha256 = "0z7hnphjxfr5z5h9gp5940pbbh163w3nnis2fan2wrrh0l88scn3"; - system = "helambdap"; - asd = "helambdap"; - }); - systems = [ "helambdap" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "clad" self) (getAttr "split-sequence" self) (getAttr "xhtmlambda" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hello-builder = (build-asdf-system { - pname = "hello-builder"; - version = "20241012-git"; - asds = [ "hello-builder" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clog/2024-10-12/clog-20241012-git.tgz"; - sha256 = "0hqpj9ji7kfqgcxdfnc7x202qzmb7zdkmjwcyhdllqs6b0ssw5lx"; - system = "hello-builder"; - asd = "hello-builder"; - }); - systems = [ "hello-builder" ]; - lispLibs = [ (getAttr "clog" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hello-clog = (build-asdf-system { - pname = "hello-clog"; - version = "20241012-git"; - asds = [ "hello-clog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clog/2024-10-12/clog-20241012-git.tgz"; - sha256 = "0hqpj9ji7kfqgcxdfnc7x202qzmb7zdkmjwcyhdllqs6b0ssw5lx"; - system = "hello-clog"; - asd = "hello-clog"; - }); - systems = [ "hello-clog" ]; - lispLibs = [ (getAttr "clog" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hemlock_dot_base = (build-asdf-system { - pname = "hemlock.base"; - version = "20231021-git"; - asds = [ "hemlock.base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hemlock/2023-10-21/hemlock-20231021-git.tgz"; - sha256 = "0c1lmznz1md7r9jbyg2n22h1svw8pvqjxyp7mvxgvqp34mmbf5ad"; - system = "hemlock.base"; - asd = "hemlock.base"; - }); - systems = [ "hemlock.base" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "command-line-arguments" self) (getAttr "conium" self) (getAttr "iolib" self) (getAttr "iterate" self) (getAttr "osicat" self) (getAttr "prepl" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hemlock_dot_clx = (build-asdf-system { - pname = "hemlock.clx"; - version = "20231021-git"; - asds = [ "hemlock.clx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hemlock/2023-10-21/hemlock-20231021-git.tgz"; - sha256 = "0c1lmznz1md7r9jbyg2n22h1svw8pvqjxyp7mvxgvqp34mmbf5ad"; - system = "hemlock.clx"; - asd = "hemlock.clx"; - }); - systems = [ "hemlock.clx" ]; - lispLibs = [ (getAttr "clx" self) (getAttr "hemlock_dot_base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hemlock_dot_tty = (build-asdf-system { - pname = "hemlock.tty"; - version = "20231021-git"; - asds = [ "hemlock.tty" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hemlock/2023-10-21/hemlock-20231021-git.tgz"; - sha256 = "0c1lmznz1md7r9jbyg2n22h1svw8pvqjxyp7mvxgvqp34mmbf5ad"; - system = "hemlock.tty"; - asd = "hemlock.tty"; - }); - systems = [ "hemlock.tty" ]; - lispLibs = [ (getAttr "hemlock_dot_base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hermetic = (build-asdf-system { - pname = "hermetic"; - version = "20191007-git"; - asds = [ "hermetic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hermetic/2019-10-07/hermetic-20191007-git.tgz"; - sha256 = "1sndxkkj45sqr13xw9kvnhj25an96q4la70ni3w468yrcbf782pi"; - system = "hermetic"; - asd = "hermetic"; - }); - systems = [ "hermetic" ]; - lispLibs = [ (getAttr "cl-pass" self) (getAttr "clack" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - herodotus = (build-asdf-system { - pname = "herodotus"; - version = "20220331-git"; - asds = [ "herodotus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/herodotus/2022-03-31/herodotus-20220331-git.tgz"; - sha256 = "085r6b8fydac2a939r80vlavs1ij5ij5li5xnl5q8qvn9dl4rr5k"; - system = "herodotus"; - asd = "herodotus"; - }); - systems = [ "herodotus" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hh-aws = (build-asdf-system { - pname = "hh-aws"; - version = "20150804-git"; - asds = [ "hh-aws" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hh-aws/2015-08-04/hh-aws-20150804-git.tgz"; - sha256 = "02kfq7krn8788iphzcxnf0da88sy30gxpj1acgy9fl2n8qc03qdp"; - system = "hh-aws"; - asd = "hh-aws"; - }); - systems = [ "hh-aws" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "drakma" self) (getAttr "ironclad" self) (getAttr "puri" self) (getAttr "s-xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hh-aws-tests = (build-asdf-system { - pname = "hh-aws-tests"; - version = "20150804-git"; - asds = [ "hh-aws-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hh-aws/2015-08-04/hh-aws-20150804-git.tgz"; - sha256 = "02kfq7krn8788iphzcxnf0da88sy30gxpj1acgy9fl2n8qc03qdp"; - system = "hh-aws-tests"; - asd = "hh-aws"; - }); - systems = [ "hh-aws-tests" ]; - lispLibs = [ (getAttr "hh-aws" self) (getAttr "lisp-unit" self) (getAttr "uuid" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hh-redblack = (build-asdf-system { - pname = "hh-redblack"; - version = "20151031-git"; - asds = [ "hh-redblack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hh-redblack/2015-10-31/hh-redblack-20151031-git.tgz"; - sha256 = "1klr78m4g60c82dnxksb7710jjj35rnfl4gl3dx3nrx0nb04bam6"; - system = "hh-redblack"; - asd = "hh-redblack"; - }); - systems = [ "hh-redblack" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hh-redblack-tests = (build-asdf-system { - pname = "hh-redblack-tests"; - version = "20151031-git"; - asds = [ "hh-redblack-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hh-redblack/2015-10-31/hh-redblack-20151031-git.tgz"; - sha256 = "1klr78m4g60c82dnxksb7710jjj35rnfl4gl3dx3nrx0nb04bam6"; - system = "hh-redblack-tests"; - asd = "hh-redblack"; - }); - systems = [ "hh-redblack-tests" ]; - lispLibs = [ (getAttr "hh-redblack" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hh-web = (build-asdf-system { - pname = "hh-web"; - version = "20141106-git"; - asds = [ "hh-web" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hh-web/2014-11-06/hh-web-20141106-git.tgz"; - sha256 = "1i3jyifayczm9b7rvw3fafiisxvjq87xd9z0hdf957qc2albsq87"; - system = "hh-web"; - asd = "hh-web"; - }); - systems = [ "hh-web" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-base64" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "hunchentoot" self) (getAttr "ironclad" self) (getAttr "local-time" self) (getAttr "log5" self) (getAttr "parenscript" self) (getAttr "trivial-backtrace" self) (getAttr "uuid" self) (getAttr "vecto" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hiccl = (build-asdf-system { - pname = "hiccl"; - version = "20241012-git"; - asds = [ "hiccl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hiccl/2024-10-12/hiccl-20241012-git.tgz"; - sha256 = "0d92q8kb8xn6c9gsm822339f9qmpf9lpzy6s6abvxbhhyfk136yp"; - system = "hiccl"; - asd = "hiccl"; - }); - systems = [ "hiccl" ]; - lispLibs = [ (getAttr "serapeum" self) (getAttr "str" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hiccl-test = (build-asdf-system { - pname = "hiccl-test"; - version = "20241012-git"; - asds = [ "hiccl-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hiccl/2024-10-12/hiccl-20241012-git.tgz"; - sha256 = "0d92q8kb8xn6c9gsm822339f9qmpf9lpzy6s6abvxbhhyfk136yp"; - system = "hiccl-test"; - asd = "hiccl-test"; - }); - systems = [ "hiccl-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "fiveam" self) (getAttr "hiccl" self) (getAttr "lquery" self) (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hl7-client = (build-asdf-system { - pname = "hl7-client"; - version = "20150407-git"; - asds = [ "hl7-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hl7-client/2015-04-07/hl7-client-20150407-git.tgz"; - sha256 = "0hq5ip6f1hbdiydml5f1z7qsjaq1v3a3g4y5a87jaif027pwhd89"; - system = "hl7-client"; - asd = "hl7-client"; - }); - systems = [ "hl7-client" ]; - lispLibs = [ (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hl7-parser = (build-asdf-system { - pname = "hl7-parser"; - version = "20160531-git"; - asds = [ "hl7-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hl7-parser/2016-05-31/hl7-parser-20160531-git.tgz"; - sha256 = "1lcyvk3vap73d23s6pk8p1ficqhl2gs84nan6d0yy0hx8c4gip0x"; - system = "hl7-parser"; - asd = "hl7-parser"; - }); - systems = [ "hl7-parser" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hompack = (build-asdf-system { - pname = "hompack"; - version = "20231021-git"; - asds = [ "hompack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "hompack"; - asd = "hompack"; - }); - systems = [ "hompack" ]; - lispLibs = [ (getAttr "blas-hompack" self) (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - horner = (build-asdf-system { - pname = "horner"; - version = "20191130-git"; - asds = [ "horner" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/horner/2019-11-30/horner-20191130-git.tgz"; - sha256 = "05afvf7sxn1db7xxw7qmys1dwbgsx53iw4w556r277da6bpyacr9"; - system = "horner"; - asd = "horner"; - }); - systems = [ "horner" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "infix-math" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - horse-html = (build-asdf-system { - pname = "horse-html"; - version = "20191007-git"; - asds = [ "horse-html" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/horse-html/2019-10-07/horse-html-20191007-git.tgz"; - sha256 = "0g6cs38123ajf1hvv056df9d8gy5ajarg0f5gywzhmmf0rhr9br5"; - system = "horse-html"; - asd = "horse-html"; - }); - systems = [ "horse-html" ]; - lispLibs = [ (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - house = (build-asdf-system { - pname = "house"; - version = "20210124-git"; - asds = [ "house" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/house/2021-01-24/house-20210124-git.tgz"; - sha256 = "1x3dprg5j5rhbf8r1nr6py6g8wgfb9zysbqbjdcyh91szg7w80mb"; - system = "house"; - asd = "house"; - }); - systems = [ "house" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "bordeaux-threads" self) (getAttr "cl-fad" self) (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "lisp-unit" self) (getAttr "optima" self) (getAttr "prove-asdf" self) (getAttr "quri" self) (getAttr "session-token" self) (getAttr "split-sequence" self) (getAttr "trivial-features" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hsx = (build-asdf-system { - pname = "hsx"; - version = "20241012-git"; - asds = [ "hsx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hsx/2024-10-12/hsx-20241012-git.tgz"; - sha256 = "0aldv9cjzl9n4p1arlmvbjdy3zwhxcmx1ajp5lwdz5vq4mivw3zy"; - system = "hsx"; - asd = "hsx"; - }); - systems = [ "hsx" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hsx-test = (build-asdf-system { - pname = "hsx-test"; - version = "20241012-git"; - asds = [ "hsx-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hsx/2024-10-12/hsx-20241012-git.tgz"; - sha256 = "0aldv9cjzl9n4p1arlmvbjdy3zwhxcmx1ajp5lwdz5vq4mivw3zy"; - system = "hsx-test"; - asd = "hsx-test"; - }); - systems = [ "hsx-test" ]; - lispLibs = [ (getAttr "mstrings" self) (getAttr "named-readtables" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ht-simple-ajax = (build-asdf-system { - pname = "ht-simple-ajax"; - version = "20130421-git"; - asds = [ "ht-simple-ajax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ht-simple-ajax/2013-04-21/ht-simple-ajax-20130421-git.tgz"; - sha256 = "1l87c0arjzyrp3g6ay189fjkqmy81b7i35rfrcs9b269n7d4iis4"; - system = "ht-simple-ajax"; - asd = "ht-simple-ajax"; - }); - systems = [ "ht-simple-ajax" ]; - lispLibs = [ (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - html-encode = (build-asdf-system { - pname = "html-encode"; - version = "1.2"; - asds = [ "html-encode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/html-encode/2010-10-06/html-encode-1.2.tgz"; - sha256 = "1ydgb5xnbj1qbvzn7x32dm38gpqg5h0pjxc31f8df3j8sar843db"; - system = "html-encode"; - asd = "html-encode"; - }); - systems = [ "html-encode" ]; - lispLibs = [ ]; - meta = {}; - }); - html-entities = (build-asdf-system { - pname = "html-entities"; - version = "20171019-git"; - asds = [ "html-entities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/html-entities/2017-10-19/html-entities-20171019-git.tgz"; - sha256 = "1b2yl6lf6vis17y4n5s505p7ica96bdafcl6vydy1hg50fy33nfr"; - system = "html-entities"; - asd = "html-entities"; - }); - systems = [ "html-entities" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - html-entities-tests = (build-asdf-system { - pname = "html-entities-tests"; - version = "20171019-git"; - asds = [ "html-entities-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/html-entities/2017-10-19/html-entities-20171019-git.tgz"; - sha256 = "1b2yl6lf6vis17y4n5s505p7ica96bdafcl6vydy1hg50fy33nfr"; - system = "html-entities-tests"; - asd = "html-entities"; - }); - systems = [ "html-entities-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "html-entities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - html-match = (build-asdf-system { - pname = "html-match"; - version = "20140713-git"; - asds = [ "html-match" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-web/2014-07-13/bknr-web-20140713-git.tgz"; - sha256 = "1m73z0hv7qsc9yddrg8zs7n3zmn9h64v4d62239wrvfnmzqk75x2"; - system = "html-match"; - asd = "html-match"; - }); - systems = [ "html-match" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "unit-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - html-match_dot_test = (build-asdf-system { - pname = "html-match.test"; - version = "20140713-git"; - asds = [ "html-match.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-web/2014-07-13/bknr-web-20140713-git.tgz"; - sha256 = "1m73z0hv7qsc9yddrg8zs7n3zmn9h64v4d62239wrvfnmzqk75x2"; - system = "html-match.test"; - asd = "html-match"; - }); - systems = [ "html-match.test" ]; - lispLibs = [ (getAttr "html-match" self) (getAttr "unit-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - html-template = (build-asdf-system { - pname = "html-template"; - version = "20171227-git"; - asds = [ "html-template" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/html-template/2017-12-27/html-template-20171227-git.tgz"; - sha256 = "0g700zlyjjba17nbmw1adspw7r9s0321xhayfiqh0drg20zixaf7"; - system = "html-template"; - asd = "html-template"; - }); - systems = [ "html-template" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - htmlgen = (build-asdf-system { - pname = "htmlgen"; - version = "20190813-git"; - asds = [ "htmlgen" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/portableaserve/2019-08-13/portableaserve-20190813-git.tgz"; - sha256 = "0ak6mqp84sjr0a7h5svr16vra4bf4fcx6wpir0n88dc1vjwy5xqa"; - system = "htmlgen"; - asd = "htmlgen"; - }); - systems = [ "htmlgen" ]; - lispLibs = [ (getAttr "acl-compat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - http-body = (build-asdf-system { - pname = "http-body"; - version = "20190813-git"; - asds = [ "http-body" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/http-body/2019-08-13/http-body-20190813-git.tgz"; - sha256 = "0kcg43l5674drzid9cj938q0ki5z25glx296rl239dm7yfmxlzz2"; - system = "http-body"; - asd = "http-body"; - }); - systems = [ "http-body" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-ppcre" self) (getAttr "cl-utilities" self) (getAttr "fast-http" self) (getAttr "flexi-streams" self) (getAttr "jonathan" self) (getAttr "quri" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - http-body-test = (build-asdf-system { - pname = "http-body-test"; - version = "20190813-git"; - asds = [ "http-body-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/http-body/2019-08-13/http-body-20190813-git.tgz"; - sha256 = "0kcg43l5674drzid9cj938q0ki5z25glx296rl239dm7yfmxlzz2"; - system = "http-body-test"; - asd = "http-body-test"; - }); - systems = [ "http-body-test" ]; - lispLibs = [ (getAttr "assoc-utils" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "http-body" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - http-get-cache = (build-asdf-system { - pname = "http-get-cache"; - version = "20180228-git"; - asds = [ "http-get-cache" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/http-get-cache/2018-02-28/http-get-cache-20180228-git.tgz"; - sha256 = "03bw4zf4hlxyrqm5mq53z0qksb9jbrcc5nv90y7qry83kxic2cgv"; - system = "http-get-cache"; - asd = "http-get-cache"; - }); - systems = [ "http-get-cache" ]; - lispLibs = [ (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - http-parse = (build-asdf-system { - pname = "http-parse"; - version = "20150608-git"; - asds = [ "http-parse" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/http-parse/2015-06-08/http-parse-20150608-git.tgz"; - sha256 = "1plycsx2kch2l143s56hvi5dqx51n5bvp7vazmphqj5skmnw4576"; - system = "http-parse"; - asd = "http-parse"; - }); - systems = [ "http-parse" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - http-parse-test = (build-asdf-system { - pname = "http-parse-test"; - version = "20150608-git"; - asds = [ "http-parse-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/http-parse/2015-06-08/http-parse-20150608-git.tgz"; - sha256 = "1plycsx2kch2l143s56hvi5dqx51n5bvp7vazmphqj5skmnw4576"; - system = "http-parse-test"; - asd = "http-parse-test"; - }); - systems = [ "http-parse-test" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "eos" self) (getAttr "http-parse" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - http2 = (build-asdf-system { - pname = "http2"; - version = "20241012-git"; - asds = [ "http2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/http2/2024-10-12/http2-20241012-git.tgz"; - sha256 = "1zb21np8rksz7b0vkfr3hg8y1a4m20vgkks3v39cc1yclnrfavii"; - system = "http2"; - asd = "http2"; - }); - systems = [ "http2" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "flexi-streams" self) (getAttr "gzip-stream" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_asdf = (build-asdf-system { - pname = "hu.dwim.asdf"; - version = "stable-git"; - asds = [ "hu.dwim.asdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.asdf/2021-12-30/hu.dwim.asdf-stable-git.tgz"; - sha256 = "0zfwdsvcywvwzkn0a80ghi5kn1hs4iwinvi17ld58gyskf15frx9"; - system = "hu.dwim.asdf"; - asd = "hu.dwim.asdf"; - }); - systems = [ "hu.dwim.asdf" ]; - lispLibs = [ ]; - meta = {}; - }); - hu_dot_dwim_dot_asdf_dot_documentation = (build-asdf-system { - pname = "hu.dwim.asdf.documentation"; - version = "stable-git"; - asds = [ "hu.dwim.asdf.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.asdf/2021-12-30/hu.dwim.asdf-stable-git.tgz"; - sha256 = "0zfwdsvcywvwzkn0a80ghi5kn1hs4iwinvi17ld58gyskf15frx9"; - system = "hu.dwim.asdf.documentation"; - asd = "hu.dwim.asdf.documentation"; - }); - systems = [ "hu.dwim.asdf.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_presentation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_bluez = (build-asdf-system { - pname = "hu.dwim.bluez"; - version = "stable-git"; - asds = [ "hu.dwim.bluez" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.bluez/2021-02-28/hu.dwim.bluez-stable-git.tgz"; - sha256 = "0gjh3bgmdz4aabdavbd5m27r273hna47vs388r4m7l2xnd3b3j55"; - system = "hu.dwim.bluez"; - asd = "hu.dwim.bluez"; - }); - systems = [ "hu.dwim.bluez" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-libffi" self) (getAttr "hu_dot_dwim_dot_asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_common = (build-asdf-system { - pname = "hu.dwim.common"; - version = "20150709-darcs"; - asds = [ "hu.dwim.common" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.common/2015-07-09/hu.dwim.common-20150709-darcs.tgz"; - sha256 = "0mkhq6bqysdy09gswgxm1s50xrq7gimdyqiq84xk8vpyp2hv6hqq"; - system = "hu.dwim.common"; - asd = "hu.dwim.common"; - }); - systems = [ "hu.dwim.common" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "closer-mop" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common-lisp" self) (getAttr "iterate" self) (getAttr "metabang-bind" self) ]; - meta = {}; - }); - hu_dot_dwim_dot_common-lisp = (build-asdf-system { - pname = "hu.dwim.common-lisp"; - version = "stable-git"; - asds = [ "hu.dwim.common-lisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.common-lisp/2021-02-28/hu.dwim.common-lisp-stable-git.tgz"; - sha256 = "06zkdw3scnaw0d4nmsgkv7pi7sw00dikdgfgsqmbqfbz2yrsdabk"; - system = "hu.dwim.common-lisp"; - asd = "hu.dwim.common-lisp"; - }); - systems = [ "hu.dwim.common-lisp" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) ]; - meta = {}; - }); - hu_dot_dwim_dot_common-lisp_dot_documentation = (build-asdf-system { - pname = "hu.dwim.common-lisp.documentation"; - version = "stable-git"; - asds = [ "hu.dwim.common-lisp.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.common-lisp/2021-02-28/hu.dwim.common-lisp-stable-git.tgz"; - sha256 = "06zkdw3scnaw0d4nmsgkv7pi7sw00dikdgfgsqmbqfbz2yrsdabk"; - system = "hu.dwim.common-lisp.documentation"; - asd = "hu.dwim.common-lisp.documentation"; - }); - systems = [ "hu.dwim.common-lisp.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common-lisp" self) (getAttr "hu_dot_dwim_dot_presentation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_common_dot_documentation = (build-asdf-system { - pname = "hu.dwim.common.documentation"; - version = "20150709-darcs"; - asds = [ "hu.dwim.common.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.common/2015-07-09/hu.dwim.common-20150709-darcs.tgz"; - sha256 = "0mkhq6bqysdy09gswgxm1s50xrq7gimdyqiq84xk8vpyp2hv6hqq"; - system = "hu.dwim.common.documentation"; - asd = "hu.dwim.common.documentation"; - }); - systems = [ "hu.dwim.common.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_presentation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_computed-class = (build-asdf-system { - pname = "hu.dwim.computed-class"; - version = "20200427-darcs"; - asds = [ "hu.dwim.computed-class" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.computed-class/2020-04-27/hu.dwim.computed-class-20200427-darcs.tgz"; - sha256 = "1frr37g79x08pm7vkpyhnmzbbcgzxvz3vldm8skknpi790vxbpr1"; - system = "hu.dwim.computed-class"; - asd = "hu.dwim.computed-class"; - }); - systems = [ "hu.dwim.computed-class" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_syntax-sugar" self) (getAttr "hu_dot_dwim_dot_util" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_computed-class_plus_hu_dot_dwim_dot_logger = (build-asdf-system { - pname = "hu.dwim.computed-class+hu.dwim.logger"; - version = "20200427-darcs"; - asds = [ "hu.dwim.computed-class+hu.dwim.logger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.computed-class/2020-04-27/hu.dwim.computed-class-20200427-darcs.tgz"; - sha256 = "1frr37g79x08pm7vkpyhnmzbbcgzxvz3vldm8skknpi790vxbpr1"; - system = "hu.dwim.computed-class+hu.dwim.logger"; - asd = "hu.dwim.computed-class+hu.dwim.logger"; - }); - systems = [ "hu.dwim.computed-class+hu.dwim.logger" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_computed-class" self) (getAttr "hu_dot_dwim_dot_logger" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_computed-class_plus_swank = (build-asdf-system { - pname = "hu.dwim.computed-class+swank"; - version = "20200427-darcs"; - asds = [ "hu.dwim.computed-class+swank" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.computed-class/2020-04-27/hu.dwim.computed-class-20200427-darcs.tgz"; - sha256 = "1frr37g79x08pm7vkpyhnmzbbcgzxvz3vldm8skknpi790vxbpr1"; - system = "hu.dwim.computed-class+swank"; - asd = "hu.dwim.computed-class+swank"; - }); - systems = [ "hu.dwim.computed-class+swank" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_computed-class" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_computed-class_dot_documentation = (build-asdf-system { - pname = "hu.dwim.computed-class.documentation"; - version = "20200427-darcs"; - asds = [ "hu.dwim.computed-class.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.computed-class/2020-04-27/hu.dwim.computed-class-20200427-darcs.tgz"; - sha256 = "1frr37g79x08pm7vkpyhnmzbbcgzxvz3vldm8skknpi790vxbpr1"; - system = "hu.dwim.computed-class.documentation"; - asd = "hu.dwim.computed-class.documentation"; - }); - systems = [ "hu.dwim.computed-class.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_computed-class_dot_test" self) (getAttr "hu_dot_dwim_dot_presentation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_computed-class_dot_test = (build-asdf-system { - pname = "hu.dwim.computed-class.test"; - version = "20200427-darcs"; - asds = [ "hu.dwim.computed-class.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.computed-class/2020-04-27/hu.dwim.computed-class-20200427-darcs.tgz"; - sha256 = "1frr37g79x08pm7vkpyhnmzbbcgzxvz3vldm8skknpi790vxbpr1"; - system = "hu.dwim.computed-class.test"; - asd = "hu.dwim.computed-class.test"; - }); - systems = [ "hu.dwim.computed-class.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_computed-class_plus_hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_debug = (build-asdf-system { - pname = "hu.dwim.debug"; - version = "20190107-darcs"; - asds = [ "hu.dwim.debug" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.debug/2019-01-07/hu.dwim.debug-20190107-darcs.tgz"; - sha256 = "0ad606bmrif82fyikb2hgwzh3y6nlrlsprb5yi86qwa2a2fvak4b"; - system = "hu.dwim.debug"; - asd = "hu.dwim.debug"; - }); - systems = [ "hu.dwim.debug" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_def_plus_swank" self) (getAttr "hu_dot_dwim_dot_defclass-star" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "hu_dot_dwim_dot_walker" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_debug_dot_documentation = (build-asdf-system { - pname = "hu.dwim.debug.documentation"; - version = "20190107-darcs"; - asds = [ "hu.dwim.debug.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.debug/2019-01-07/hu.dwim.debug-20190107-darcs.tgz"; - sha256 = "0ad606bmrif82fyikb2hgwzh3y6nlrlsprb5yi86qwa2a2fvak4b"; - system = "hu.dwim.debug.documentation"; - asd = "hu.dwim.debug.documentation"; - }); - systems = [ "hu.dwim.debug.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_debug_dot_test" self) (getAttr "hu_dot_dwim_dot_presentation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_debug_dot_test = (build-asdf-system { - pname = "hu.dwim.debug.test"; - version = "20190107-darcs"; - asds = [ "hu.dwim.debug.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.debug/2019-01-07/hu.dwim.debug-20190107-darcs.tgz"; - sha256 = "0ad606bmrif82fyikb2hgwzh3y6nlrlsprb5yi86qwa2a2fvak4b"; - system = "hu.dwim.debug.test"; - asd = "hu.dwim.debug.test"; - }); - systems = [ "hu.dwim.debug.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_debug" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_def = (build-asdf-system { - pname = "hu.dwim.def"; - version = "stable-git"; - asds = [ "hu.dwim.def" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.def/2021-12-30/hu.dwim.def-stable-git.tgz"; - sha256 = "1scjj9g2bn58l8i1g1brdqzrajy4bb63dqkwlcydcvk36iskpyab"; - system = "hu.dwim.def"; - asd = "hu.dwim.def"; - }); - systems = [ "hu.dwim.def" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "iterate" self) (getAttr "metabang-bind" self) ]; - meta = {}; - }); - hu_dot_dwim_dot_def_plus_cl-l10n = (build-asdf-system { - pname = "hu.dwim.def+cl-l10n"; - version = "stable-git"; - asds = [ "hu.dwim.def+cl-l10n" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.def/2021-12-30/hu.dwim.def-stable-git.tgz"; - sha256 = "1scjj9g2bn58l8i1g1brdqzrajy4bb63dqkwlcydcvk36iskpyab"; - system = "hu.dwim.def+cl-l10n"; - asd = "hu.dwim.def+cl-l10n"; - }); - systems = [ "hu.dwim.def+cl-l10n" ]; - lispLibs = [ (getAttr "cl-l10n" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_def_plus_contextl = (build-asdf-system { - pname = "hu.dwim.def+contextl"; - version = "stable-git"; - asds = [ "hu.dwim.def+contextl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.def/2021-12-30/hu.dwim.def-stable-git.tgz"; - sha256 = "1scjj9g2bn58l8i1g1brdqzrajy4bb63dqkwlcydcvk36iskpyab"; - system = "hu.dwim.def+contextl"; - asd = "hu.dwim.def+contextl"; - }); - systems = [ "hu.dwim.def+contextl" ]; - lispLibs = [ (getAttr "contextl" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common = (build-asdf-system { - pname = "hu.dwim.def+hu.dwim.common"; - version = "stable-git"; - asds = [ "hu.dwim.def+hu.dwim.common" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.def/2021-12-30/hu.dwim.def-stable-git.tgz"; - sha256 = "1scjj9g2bn58l8i1g1brdqzrajy4bb63dqkwlcydcvk36iskpyab"; - system = "hu.dwim.def+hu.dwim.common"; - asd = "hu.dwim.def+hu.dwim.common"; - }); - systems = [ "hu.dwim.def+hu.dwim.common" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_def" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_delico = (build-asdf-system { - pname = "hu.dwim.def+hu.dwim.delico"; - version = "stable-git"; - asds = [ "hu.dwim.def+hu.dwim.delico" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.def/2021-12-30/hu.dwim.def-stable-git.tgz"; - sha256 = "1scjj9g2bn58l8i1g1brdqzrajy4bb63dqkwlcydcvk36iskpyab"; - system = "hu.dwim.def+hu.dwim.delico"; - asd = "hu.dwim.def+hu.dwim.delico"; - }); - systems = [ "hu.dwim.def+hu.dwim.delico" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_delico" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_def_plus_swank = (build-asdf-system { - pname = "hu.dwim.def+swank"; - version = "stable-git"; - asds = [ "hu.dwim.def+swank" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.def/2021-12-30/hu.dwim.def-stable-git.tgz"; - sha256 = "1scjj9g2bn58l8i1g1brdqzrajy4bb63dqkwlcydcvk36iskpyab"; - system = "hu.dwim.def+swank"; - asd = "hu.dwim.def+swank"; - }); - systems = [ "hu.dwim.def+swank" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def" self) (getAttr "swank" self) ]; - meta = {}; - }); - hu_dot_dwim_dot_defclass-star = (build-asdf-system { - pname = "hu.dwim.defclass-star"; - version = "stable-git"; - asds = [ "hu.dwim.defclass-star" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.defclass-star/2021-12-30/hu.dwim.defclass-star-stable-git.tgz"; - sha256 = "1lbmsn9s7v88w934r8rp4d59vsj1jg8p2cz9g5kl1n9vff5sxxw2"; - system = "hu.dwim.defclass-star"; - asd = "hu.dwim.defclass-star"; - }); - systems = [ "hu.dwim.defclass-star" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) ]; - meta = {}; - }); - hu_dot_dwim_dot_defclass-star_plus_contextl = (build-asdf-system { - pname = "hu.dwim.defclass-star+contextl"; - version = "stable-git"; - asds = [ "hu.dwim.defclass-star+contextl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.defclass-star/2021-12-30/hu.dwim.defclass-star-stable-git.tgz"; - sha256 = "1lbmsn9s7v88w934r8rp4d59vsj1jg8p2cz9g5kl1n9vff5sxxw2"; - system = "hu.dwim.defclass-star+contextl"; - asd = "hu.dwim.defclass-star+contextl"; - }); - systems = [ "hu.dwim.defclass-star+contextl" ]; - lispLibs = [ (getAttr "contextl" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_defclass-star" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def = (build-asdf-system { - pname = "hu.dwim.defclass-star+hu.dwim.def"; - version = "stable-git"; - asds = [ "hu.dwim.defclass-star+hu.dwim.def" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.defclass-star/2021-12-30/hu.dwim.defclass-star-stable-git.tgz"; - sha256 = "1lbmsn9s7v88w934r8rp4d59vsj1jg8p2cz9g5kl1n9vff5sxxw2"; - system = "hu.dwim.defclass-star+hu.dwim.def"; - asd = "hu.dwim.defclass-star+hu.dwim.def"; - }); - systems = [ "hu.dwim.defclass-star+hu.dwim.def" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_defclass-star" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def_plus_contextl = (build-asdf-system { - pname = "hu.dwim.defclass-star+hu.dwim.def+contextl"; - version = "stable-git"; - asds = [ "hu.dwim.defclass-star+hu.dwim.def+contextl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.defclass-star/2021-12-30/hu.dwim.defclass-star-stable-git.tgz"; - sha256 = "1lbmsn9s7v88w934r8rp4d59vsj1jg8p2cz9g5kl1n9vff5sxxw2"; - system = "hu.dwim.defclass-star+hu.dwim.def+contextl"; - asd = "hu.dwim.defclass-star+hu.dwim.def+contextl"; - }); - systems = [ "hu.dwim.defclass-star+hu.dwim.def+contextl" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_defclass-star_plus_contextl" self) (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_defclass-star_plus_swank = (build-asdf-system { - pname = "hu.dwim.defclass-star+swank"; - version = "stable-git"; - asds = [ "hu.dwim.defclass-star+swank" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.defclass-star/2021-12-30/hu.dwim.defclass-star-stable-git.tgz"; - sha256 = "1lbmsn9s7v88w934r8rp4d59vsj1jg8p2cz9g5kl1n9vff5sxxw2"; - system = "hu.dwim.defclass-star+swank"; - asd = "hu.dwim.defclass-star+swank"; - }); - systems = [ "hu.dwim.defclass-star+swank" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_defclass-star" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_delico = (build-asdf-system { - pname = "hu.dwim.delico"; - version = "20200925-darcs"; - asds = [ "hu.dwim.delico" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.delico/2020-09-25/hu.dwim.delico-20200925-darcs.tgz"; - sha256 = "12n5cddg7vd3y4dqjcf4wayxwj905ja8jh90ixvrhgnvs559lbnl"; - system = "hu.dwim.delico"; - asd = "hu.dwim.delico"; - }); - systems = [ "hu.dwim.delico" ]; - lispLibs = [ (getAttr "contextl" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_walker" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_graphviz = (build-asdf-system { - pname = "hu.dwim.graphviz"; - version = "stable-git"; - asds = [ "hu.dwim.graphviz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.graphviz/2021-12-30/hu.dwim.graphviz-stable-git.tgz"; - sha256 = "0cz5g7d6817ajypp876k9m65sxxlf42x4bg04ya73aqci5s1vjwy"; - system = "hu.dwim.graphviz"; - asd = "hu.dwim.graphviz"; - }); - systems = [ "hu.dwim.graphviz" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "metabang-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_graphviz_dot_documentation = (build-asdf-system { - pname = "hu.dwim.graphviz.documentation"; - version = "stable-git"; - asds = [ "hu.dwim.graphviz.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.graphviz/2021-12-30/hu.dwim.graphviz-stable-git.tgz"; - sha256 = "0cz5g7d6817ajypp876k9m65sxxlf42x4bg04ya73aqci5s1vjwy"; - system = "hu.dwim.graphviz.documentation"; - asd = "hu.dwim.graphviz.documentation"; - }); - systems = [ "hu.dwim.graphviz.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_graphviz_dot_test" self) (getAttr "hu_dot_dwim_dot_presentation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_graphviz_dot_test = (build-asdf-system { - pname = "hu.dwim.graphviz.test"; - version = "stable-git"; - asds = [ "hu.dwim.graphviz.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.graphviz/2021-12-30/hu.dwim.graphviz-stable-git.tgz"; - sha256 = "0cz5g7d6817ajypp876k9m65sxxlf42x4bg04ya73aqci5s1vjwy"; - system = "hu.dwim.graphviz.test"; - asd = "hu.dwim.graphviz.test"; - }); - systems = [ "hu.dwim.graphviz.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_graphviz" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_logger = (build-asdf-system { - pname = "hu.dwim.logger"; - version = "stable-git"; - asds = [ "hu.dwim.logger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.logger/2021-12-30/hu.dwim.logger-stable-git.tgz"; - sha256 = "17b7m86pggg85lczww7nvswz0nj9qg1fxwv1l9wn31jfcf061h74"; - system = "hu.dwim.logger"; - asd = "hu.dwim.logger"; - }); - systems = [ "hu.dwim.logger" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "local-time" self) ]; - meta = { - broken = true; - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_logger_plus_iolib = (build-asdf-system { - pname = "hu.dwim.logger+iolib"; - version = "stable-git"; - asds = [ "hu.dwim.logger+iolib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.logger/2021-12-30/hu.dwim.logger-stable-git.tgz"; - sha256 = "17b7m86pggg85lczww7nvswz0nj9qg1fxwv1l9wn31jfcf061h74"; - system = "hu.dwim.logger+iolib"; - asd = "hu.dwim.logger+iolib"; - }); - systems = [ "hu.dwim.logger+iolib" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_util_plus_iolib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_logger_plus_swank = (build-asdf-system { - pname = "hu.dwim.logger+swank"; - version = "stable-git"; - asds = [ "hu.dwim.logger+swank" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.logger/2021-12-30/hu.dwim.logger-stable-git.tgz"; - sha256 = "17b7m86pggg85lczww7nvswz0nj9qg1fxwv1l9wn31jfcf061h74"; - system = "hu.dwim.logger+swank"; - asd = "hu.dwim.logger+swank"; - }); - systems = [ "hu.dwim.logger+swank" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_logger_dot_documentation = (build-asdf-system { - pname = "hu.dwim.logger.documentation"; - version = "stable-git"; - asds = [ "hu.dwim.logger.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.logger/2021-12-30/hu.dwim.logger-stable-git.tgz"; - sha256 = "17b7m86pggg85lczww7nvswz0nj9qg1fxwv1l9wn31jfcf061h74"; - system = "hu.dwim.logger.documentation"; - asd = "hu.dwim.logger.documentation"; - }); - systems = [ "hu.dwim.logger.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_logger_dot_test" self) (getAttr "hu_dot_dwim_dot_presentation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_logger_dot_test = (build-asdf-system { - pname = "hu.dwim.logger.test"; - version = "stable-git"; - asds = [ "hu.dwim.logger.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.logger/2021-12-30/hu.dwim.logger-stable-git.tgz"; - sha256 = "17b7m86pggg85lczww7nvswz0nj9qg1fxwv1l9wn31jfcf061h74"; - system = "hu.dwim.logger.test"; - asd = "hu.dwim.logger.test"; - }); - systems = [ "hu.dwim.logger.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_partial-eval = (build-asdf-system { - pname = "hu.dwim.partial-eval"; - version = "stable-git"; - asds = [ "hu.dwim.partial-eval" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.partial-eval/2024-10-12/hu.dwim.partial-eval-stable-git.tgz"; - sha256 = "1zsh1rk9rcxkrqavhx2slpczii23y51fn66n68vsw5d97g9k6gzz"; - system = "hu.dwim.partial-eval"; - asd = "hu.dwim.partial-eval"; - }); - systems = [ "hu.dwim.partial-eval" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def_plus_contextl" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_syntax-sugar" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "hu_dot_dwim_dot_walker" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec = (build-asdf-system { - pname = "hu.dwim.perec"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec"; - asd = "hu.dwim.perec"; - }); - systems = [ "hu.dwim.perec" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-containers" self) (getAttr "cl-ppcre" self) (getAttr "contextl" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_computed-class" self) (getAttr "hu_dot_dwim_dot_def_plus_contextl" self) (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_delico" self) (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_rdbms" self) (getAttr "hu_dot_dwim_dot_serializer" self) (getAttr "hu_dot_dwim_dot_syntax-sugar" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "hu_dot_dwim_dot_walker" self) (getAttr "ironclad" self) (getAttr "local-time" self) (getAttr "metacopy-with-contextl" self) (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_plus_hu_dot_dwim_dot_quasi-quote_dot_xml = (build-asdf-system { - pname = "hu.dwim.perec+hu.dwim.quasi-quote.xml"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec+hu.dwim.quasi-quote.xml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec+hu.dwim.quasi-quote.xml"; - asd = "hu.dwim.perec+hu.dwim.quasi-quote.xml"; - }); - systems = [ "hu.dwim.perec+hu.dwim.quasi-quote.xml" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec" self) (getAttr "hu_dot_dwim_dot_quasi-quote_dot_xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_plus_iolib = (build-asdf-system { - pname = "hu.dwim.perec+iolib"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec+iolib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec+iolib"; - asd = "hu.dwim.perec+iolib"; - }); - systems = [ "hu.dwim.perec+iolib" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec" self) (getAttr "iolib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_plus_swank = (build-asdf-system { - pname = "hu.dwim.perec+swank"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec+swank" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec+swank"; - asd = "hu.dwim.perec+swank"; - }); - systems = [ "hu.dwim.perec+swank" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_dot_all = (build-asdf-system { - pname = "hu.dwim.perec.all"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec.all" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec.all"; - asd = "hu.dwim.perec.all"; - }); - systems = [ "hu.dwim.perec.all" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec_dot_oracle" self) (getAttr "hu_dot_dwim_dot_perec_dot_postgresql" self) (getAttr "hu_dot_dwim_dot_perec_dot_sqlite" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_dot_all_dot_test = (build-asdf-system { - pname = "hu.dwim.perec.all.test"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec.all.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec.all.test"; - asd = "hu.dwim.perec.all.test"; - }); - systems = [ "hu.dwim.perec.all.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec_dot_oracle_dot_test" self) (getAttr "hu_dot_dwim_dot_perec_dot_postgresql_dot_test" self) (getAttr "hu_dot_dwim_dot_perec_dot_sqlite_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_dot_documentation = (build-asdf-system { - pname = "hu.dwim.perec.documentation"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec.documentation"; - asd = "hu.dwim.perec.documentation"; - }); - systems = [ "hu.dwim.perec.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec_dot_all_dot_test" self) (getAttr "hu_dot_dwim_dot_presentation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_dot_oracle = (build-asdf-system { - pname = "hu.dwim.perec.oracle"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec.oracle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec.oracle"; - asd = "hu.dwim.perec.oracle"; - }); - systems = [ "hu.dwim.perec.oracle" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_oracle" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_dot_oracle_dot_test = (build-asdf-system { - pname = "hu.dwim.perec.oracle.test"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec.oracle.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec.oracle.test"; - asd = "hu.dwim.perec.oracle.test"; - }); - systems = [ "hu.dwim.perec.oracle.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec_dot_oracle" self) (getAttr "hu_dot_dwim_dot_perec_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_dot_postgresql = (build-asdf-system { - pname = "hu.dwim.perec.postgresql"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec.postgresql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec.postgresql"; - asd = "hu.dwim.perec.postgresql"; - }); - systems = [ "hu.dwim.perec.postgresql" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_postgresql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_dot_postgresql_dot_test = (build-asdf-system { - pname = "hu.dwim.perec.postgresql.test"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec.postgresql.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec.postgresql.test"; - asd = "hu.dwim.perec.postgresql.test"; - }); - systems = [ "hu.dwim.perec.postgresql.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec_dot_postgresql" self) (getAttr "hu_dot_dwim_dot_perec_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_dot_sqlite = (build-asdf-system { - pname = "hu.dwim.perec.sqlite"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec.sqlite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec.sqlite"; - asd = "hu.dwim.perec.sqlite"; - }); - systems = [ "hu.dwim.perec.sqlite" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_sqlite" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_dot_sqlite_dot_test = (build-asdf-system { - pname = "hu.dwim.perec.sqlite.test"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec.sqlite.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec.sqlite.test"; - asd = "hu.dwim.perec.sqlite.test"; - }); - systems = [ "hu.dwim.perec.sqlite.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec_dot_sqlite" self) (getAttr "hu_dot_dwim_dot_perec_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_perec_dot_test = (build-asdf-system { - pname = "hu.dwim.perec.test"; - version = "20211209-darcs"; - asds = [ "hu.dwim.perec.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; - sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; - system = "hu.dwim.perec.test"; - asd = "hu.dwim.perec.test"; - }); - systems = [ "hu.dwim.perec.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec_plus_hu_dot_dwim_dot_quasi-quote_dot_xml" self) (getAttr "hu_dot_dwim_dot_perec_plus_iolib" self) (getAttr "hu_dot_dwim_dot_perec_plus_swank" self) (getAttr "hu_dot_dwim_dot_util_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_presentation = (build-asdf-system { - pname = "hu.dwim.presentation"; - version = "20211230-darcs"; - asds = [ "hu.dwim.presentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.presentation/2021-12-30/hu.dwim.presentation-20211230-darcs.tgz"; - sha256 = "06y08z2pa3ra8hwn46n4kygf6vhq68nh73x4gzh4skx379hb4fgp"; - system = "hu.dwim.presentation"; - asd = "hu.dwim.presentation"; - }); - systems = [ "hu.dwim.presentation" ]; - lispLibs = [ (getAttr "cl-graph_plus_hu_dot_dwim_dot_graphviz" self) (getAttr "contextl" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def_plus_contextl" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "hu_dot_dwim_dot_web-server_dot_application" self) (getAttr "iolib" self) (getAttr "moptilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_presentation_plus_cl-graph_plus_cl-typesetting = (build-asdf-system { - pname = "hu.dwim.presentation+cl-graph+cl-typesetting"; - version = "20211230-darcs"; - asds = [ "hu.dwim.presentation+cl-graph+cl-typesetting" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.presentation/2021-12-30/hu.dwim.presentation-20211230-darcs.tgz"; - sha256 = "06y08z2pa3ra8hwn46n4kygf6vhq68nh73x4gzh4skx379hb4fgp"; - system = "hu.dwim.presentation+cl-graph+cl-typesetting"; - asd = "hu.dwim.presentation+cl-graph+cl-typesetting"; - }); - systems = [ "hu.dwim.presentation+cl-graph+cl-typesetting" ]; - lispLibs = [ (getAttr "cl-graph" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_presentation_plus_cl-typesetting" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_presentation_plus_cl-typesetting = (build-asdf-system { - pname = "hu.dwim.presentation+cl-typesetting"; - version = "20211230-darcs"; - asds = [ "hu.dwim.presentation+cl-typesetting" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.presentation/2021-12-30/hu.dwim.presentation-20211230-darcs.tgz"; - sha256 = "06y08z2pa3ra8hwn46n4kygf6vhq68nh73x4gzh4skx379hb4fgp"; - system = "hu.dwim.presentation+cl-typesetting"; - asd = "hu.dwim.presentation+cl-typesetting"; - }); - systems = [ "hu.dwim.presentation+cl-typesetting" ]; - lispLibs = [ (getAttr "cl-typesetting" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_presentation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_presentation_plus_hu_dot_dwim_dot_stefil = (build-asdf-system { - pname = "hu.dwim.presentation+hu.dwim.stefil"; - version = "20211230-darcs"; - asds = [ "hu.dwim.presentation+hu.dwim.stefil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.presentation/2021-12-30/hu.dwim.presentation-20211230-darcs.tgz"; - sha256 = "06y08z2pa3ra8hwn46n4kygf6vhq68nh73x4gzh4skx379hb4fgp"; - system = "hu.dwim.presentation+hu.dwim.stefil"; - asd = "hu.dwim.presentation+hu.dwim.stefil"; - }); - systems = [ "hu.dwim.presentation+hu.dwim.stefil" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_presentation" self) (getAttr "hu_dot_dwim_dot_stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_presentation_plus_hu_dot_dwim_dot_web-server = (build-asdf-system { - pname = "hu.dwim.presentation+hu.dwim.web-server"; - version = "20211230-darcs"; - asds = [ "hu.dwim.presentation+hu.dwim.web-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.presentation/2021-12-30/hu.dwim.presentation-20211230-darcs.tgz"; - sha256 = "06y08z2pa3ra8hwn46n4kygf6vhq68nh73x4gzh4skx379hb4fgp"; - system = "hu.dwim.presentation+hu.dwim.web-server"; - asd = "hu.dwim.presentation+hu.dwim.web-server"; - }); - systems = [ "hu.dwim.presentation+hu.dwim.web-server" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_presentation" self) (getAttr "hu_dot_dwim_dot_web-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_quasi-quote = (build-asdf-system { - pname = "hu.dwim.quasi-quote"; - version = "stable-git"; - asds = [ "hu.dwim.quasi-quote" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; - sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; - system = "hu.dwim.quasi-quote"; - asd = "hu.dwim.quasi-quote"; - }); - systems = [ "hu.dwim.quasi-quote" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "babel-streams" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_syntax-sugar" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "hu_dot_dwim_dot_walker" self) ]; - meta = { - broken = true; - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_quasi-quote_dot_css = (build-asdf-system { - pname = "hu.dwim.quasi-quote.css"; - version = "stable-git"; - asds = [ "hu.dwim.quasi-quote.css" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; - sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; - system = "hu.dwim.quasi-quote.css"; - asd = "hu.dwim.quasi-quote.css"; - }); - systems = [ "hu.dwim.quasi-quote.css" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_quasi-quote" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_quasi-quote_dot_js = (build-asdf-system { - pname = "hu.dwim.quasi-quote.js"; - version = "stable-git"; - asds = [ "hu.dwim.quasi-quote.js" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; - sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; - system = "hu.dwim.quasi-quote.js"; - asd = "hu.dwim.quasi-quote.js"; - }); - systems = [ "hu.dwim.quasi-quote.js" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_quasi-quote" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "hu_dot_dwim_dot_walker" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_quasi-quote_dot_pdf = (build-asdf-system { - pname = "hu.dwim.quasi-quote.pdf"; - version = "stable-git"; - asds = [ "hu.dwim.quasi-quote.pdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; - sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; - system = "hu.dwim.quasi-quote.pdf"; - asd = "hu.dwim.quasi-quote.pdf"; - }); - systems = [ "hu.dwim.quasi-quote.pdf" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_quasi-quote" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_quasi-quote_dot_xml = (build-asdf-system { - pname = "hu.dwim.quasi-quote.xml"; - version = "stable-git"; - asds = [ "hu.dwim.quasi-quote.xml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; - sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; - system = "hu.dwim.quasi-quote.xml"; - asd = "hu.dwim.quasi-quote.xml"; - }); - systems = [ "hu.dwim.quasi-quote.xml" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_quasi-quote" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_quasi-quote_dot_xml_plus_cxml = (build-asdf-system { - pname = "hu.dwim.quasi-quote.xml+cxml"; - version = "stable-git"; - asds = [ "hu.dwim.quasi-quote.xml+cxml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; - sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; - system = "hu.dwim.quasi-quote.xml+cxml"; - asd = "hu.dwim.quasi-quote.xml+cxml"; - }); - systems = [ "hu.dwim.quasi-quote.xml+cxml" ]; - lispLibs = [ (getAttr "cxml" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_quasi-quote_dot_xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_quasi-quote_dot_xml_plus_hu_dot_dwim_dot_quasi-quote_dot_js = (build-asdf-system { - pname = "hu.dwim.quasi-quote.xml+hu.dwim.quasi-quote.js"; - version = "stable-git"; - asds = [ "hu.dwim.quasi-quote.xml+hu.dwim.quasi-quote.js" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; - sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; - system = "hu.dwim.quasi-quote.xml+hu.dwim.quasi-quote.js"; - asd = "hu.dwim.quasi-quote.xml+hu.dwim.quasi-quote.js"; - }); - systems = [ "hu.dwim.quasi-quote.xml+hu.dwim.quasi-quote.js" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_quasi-quote_dot_js" self) (getAttr "hu_dot_dwim_dot_quasi-quote_dot_xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_rdbms = (build-asdf-system { - pname = "hu.dwim.rdbms"; - version = "20201016-darcs"; - asds = [ "hu.dwim.rdbms" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; - sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; - system = "hu.dwim.rdbms"; - asd = "hu.dwim.rdbms"; - }); - systems = [ "hu.dwim.rdbms" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_syntax-sugar" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "hu_dot_dwim_dot_walker" self) (getAttr "ironclad" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_rdbms_dot_all = (build-asdf-system { - pname = "hu.dwim.rdbms.all"; - version = "20201016-darcs"; - asds = [ "hu.dwim.rdbms.all" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; - sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; - system = "hu.dwim.rdbms.all"; - asd = "hu.dwim.rdbms.all"; - }); - systems = [ "hu.dwim.rdbms.all" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_oracle" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_postgresql" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_sqlite" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_rdbms_dot_all_dot_test = (build-asdf-system { - pname = "hu.dwim.rdbms.all.test"; - version = "20201016-darcs"; - asds = [ "hu.dwim.rdbms.all.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; - sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; - system = "hu.dwim.rdbms.all.test"; - asd = "hu.dwim.rdbms.all.test"; - }); - systems = [ "hu.dwim.rdbms.all.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_oracle_dot_test" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_postgresql_dot_test" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_sqlite_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_rdbms_dot_documentation = (build-asdf-system { - pname = "hu.dwim.rdbms.documentation"; - version = "20201016-darcs"; - asds = [ "hu.dwim.rdbms.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; - sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; - system = "hu.dwim.rdbms.documentation"; - asd = "hu.dwim.rdbms.documentation"; - }); - systems = [ "hu.dwim.rdbms.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_presentation" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_all_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_rdbms_dot_oracle = (build-asdf-system { - pname = "hu.dwim.rdbms.oracle"; - version = "20201016-darcs"; - asds = [ "hu.dwim.rdbms.oracle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; - sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; - system = "hu.dwim.rdbms.oracle"; - asd = "hu.dwim.rdbms.oracle"; - }); - systems = [ "hu.dwim.rdbms.oracle" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_rdbms" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_rdbms_dot_oracle_dot_test = (build-asdf-system { - pname = "hu.dwim.rdbms.oracle.test"; - version = "20201016-darcs"; - asds = [ "hu.dwim.rdbms.oracle.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; - sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; - system = "hu.dwim.rdbms.oracle.test"; - asd = "hu.dwim.rdbms.oracle.test"; - }); - systems = [ "hu.dwim.rdbms.oracle.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_oracle" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_rdbms_dot_postgresql = (build-asdf-system { - pname = "hu.dwim.rdbms.postgresql"; - version = "20201016-darcs"; - asds = [ "hu.dwim.rdbms.postgresql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; - sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; - system = "hu.dwim.rdbms.postgresql"; - asd = "hu.dwim.rdbms.postgresql"; - }); - systems = [ "hu.dwim.rdbms.postgresql" ]; - lispLibs = [ (getAttr "cl-postgres_plus_local-time" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_rdbms" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_rdbms_dot_postgresql_dot_test = (build-asdf-system { - pname = "hu.dwim.rdbms.postgresql.test"; - version = "20201016-darcs"; - asds = [ "hu.dwim.rdbms.postgresql.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; - sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; - system = "hu.dwim.rdbms.postgresql.test"; - asd = "hu.dwim.rdbms.postgresql.test"; - }); - systems = [ "hu.dwim.rdbms.postgresql.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_postgresql" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_rdbms_dot_sqlite = (build-asdf-system { - pname = "hu.dwim.rdbms.sqlite"; - version = "20201016-darcs"; - asds = [ "hu.dwim.rdbms.sqlite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; - sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; - system = "hu.dwim.rdbms.sqlite"; - asd = "hu.dwim.rdbms.sqlite"; - }); - systems = [ "hu.dwim.rdbms.sqlite" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_rdbms" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_rdbms_dot_sqlite_dot_test = (build-asdf-system { - pname = "hu.dwim.rdbms.sqlite.test"; - version = "20201016-darcs"; - asds = [ "hu.dwim.rdbms.sqlite.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; - sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; - system = "hu.dwim.rdbms.sqlite.test"; - asd = "hu.dwim.rdbms.sqlite.test"; - }); - systems = [ "hu.dwim.rdbms.sqlite.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_sqlite" self) (getAttr "hu_dot_dwim_dot_rdbms_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_rdbms_dot_test = (build-asdf-system { - pname = "hu.dwim.rdbms.test"; - version = "20201016-darcs"; - asds = [ "hu.dwim.rdbms.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; - sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; - system = "hu.dwim.rdbms.test"; - asd = "hu.dwim.rdbms.test"; - }); - systems = [ "hu.dwim.rdbms.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_rdbms" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_reiterate = (build-asdf-system { - pname = "hu.dwim.reiterate"; - version = "stable-git"; - asds = [ "hu.dwim.reiterate" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.reiterate/2021-12-30/hu.dwim.reiterate-stable-git.tgz"; - sha256 = "0h6cgg385ivgc6942xal09c7n9vmy6gn4y3zz4zafc1qyl5jwyv9"; - system = "hu.dwim.reiterate"; - asd = "hu.dwim.reiterate"; - }); - systems = [ "hu.dwim.reiterate" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common-lisp" self) (getAttr "hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_defclass-star" self) (getAttr "hu_dot_dwim_dot_syntax-sugar" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "metabang-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_reiterate_plus_hu_dot_dwim_dot_logger = (build-asdf-system { - pname = "hu.dwim.reiterate+hu.dwim.logger"; - version = "stable-git"; - asds = [ "hu.dwim.reiterate+hu.dwim.logger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.reiterate/2021-12-30/hu.dwim.reiterate-stable-git.tgz"; - sha256 = "0h6cgg385ivgc6942xal09c7n9vmy6gn4y3zz4zafc1qyl5jwyv9"; - system = "hu.dwim.reiterate+hu.dwim.logger"; - asd = "hu.dwim.reiterate+hu.dwim.logger"; - }); - systems = [ "hu.dwim.reiterate+hu.dwim.logger" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_reiterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_sdl = (build-asdf-system { - pname = "hu.dwim.sdl"; - version = "stable-git"; - asds = [ "hu.dwim.sdl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.sdl/2022-07-07/hu.dwim.sdl-stable-git.tgz"; - sha256 = "175kha5f7kvis2nlxbzrybswbr62lgmjh691ajwl5i9y7andqhq2"; - system = "hu.dwim.sdl"; - asd = "hu.dwim.sdl"; - }); - systems = [ "hu.dwim.sdl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-libffi" self) (getAttr "hu_dot_dwim_dot_asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_serializer = (build-asdf-system { - pname = "hu.dwim.serializer"; - version = "20161204-darcs"; - asds = [ "hu.dwim.serializer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.serializer/2016-12-04/hu.dwim.serializer-20161204-darcs.tgz"; - sha256 = "1c4zl2ql4w7nw8vrcrhhq45c5yhbcp4z5qpp1yxjpd3002q2lbh2"; - system = "hu.dwim.serializer"; - asd = "hu.dwim.serializer"; - }); - systems = [ "hu.dwim.serializer" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_syntax-sugar" self) (getAttr "hu_dot_dwim_dot_util" self) ]; - meta = { - broken = true; - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_serializer_dot_documentation = (build-asdf-system { - pname = "hu.dwim.serializer.documentation"; - version = "20161204-darcs"; - asds = [ "hu.dwim.serializer.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.serializer/2016-12-04/hu.dwim.serializer-20161204-darcs.tgz"; - sha256 = "1c4zl2ql4w7nw8vrcrhhq45c5yhbcp4z5qpp1yxjpd3002q2lbh2"; - system = "hu.dwim.serializer.documentation"; - asd = "hu.dwim.serializer.documentation"; - }); - systems = [ "hu.dwim.serializer.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_presentation" self) (getAttr "hu_dot_dwim_dot_serializer_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_serializer_dot_test = (build-asdf-system { - pname = "hu.dwim.serializer.test"; - version = "20161204-darcs"; - asds = [ "hu.dwim.serializer.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.serializer/2016-12-04/hu.dwim.serializer-20161204-darcs.tgz"; - sha256 = "1c4zl2ql4w7nw8vrcrhhq45c5yhbcp4z5qpp1yxjpd3002q2lbh2"; - system = "hu.dwim.serializer.test"; - asd = "hu.dwim.serializer.test"; - }); - systems = [ "hu.dwim.serializer.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_serializer" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_stefil = (build-asdf-system { - pname = "hu.dwim.stefil"; - version = "stable-git"; - asds = [ "hu.dwim.stefil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.stefil/2021-12-30/hu.dwim.stefil-stable-git.tgz"; - sha256 = "0sra6psvrlpx9w7xjikm6ph2qlmgi9lr1kagpsiafxq4dnqlxjsx"; - system = "hu.dwim.stefil"; - asd = "hu.dwim.stefil"; - }); - systems = [ "hu.dwim.stefil" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = {}; - }); - hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def = (build-asdf-system { - pname = "hu.dwim.stefil+hu.dwim.def"; - version = "stable-git"; - asds = [ "hu.dwim.stefil+hu.dwim.def" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.stefil/2021-12-30/hu.dwim.stefil-stable-git.tgz"; - sha256 = "0sra6psvrlpx9w7xjikm6ph2qlmgi9lr1kagpsiafxq4dnqlxjsx"; - system = "hu.dwim.stefil+hu.dwim.def"; - asd = "hu.dwim.stefil+hu.dwim.def"; - }); - systems = [ "hu.dwim.stefil+hu.dwim.def" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_stefil" self) ]; - meta = {}; - }); - hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank = (build-asdf-system { - pname = "hu.dwim.stefil+hu.dwim.def+swank"; - version = "stable-git"; - asds = [ "hu.dwim.stefil+hu.dwim.def+swank" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.stefil/2021-12-30/hu.dwim.stefil-stable-git.tgz"; - sha256 = "0sra6psvrlpx9w7xjikm6ph2qlmgi9lr1kagpsiafxq4dnqlxjsx"; - system = "hu.dwim.stefil+hu.dwim.def+swank"; - asd = "hu.dwim.stefil+hu.dwim.def+swank"; - }); - systems = [ "hu.dwim.stefil+hu.dwim.def+swank" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def_plus_swank" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_stefil_plus_swank" self) ]; - meta = {}; - }); - hu_dot_dwim_dot_stefil_plus_swank = (build-asdf-system { - pname = "hu.dwim.stefil+swank"; - version = "stable-git"; - asds = [ "hu.dwim.stefil+swank" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.stefil/2021-12-30/hu.dwim.stefil-stable-git.tgz"; - sha256 = "0sra6psvrlpx9w7xjikm6ph2qlmgi9lr1kagpsiafxq4dnqlxjsx"; - system = "hu.dwim.stefil+swank"; - asd = "hu.dwim.stefil+swank"; - }); - systems = [ "hu.dwim.stefil+swank" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_stefil" self) (getAttr "swank" self) ]; - meta = {}; - }); - hu_dot_dwim_dot_syntax-sugar = (build-asdf-system { - pname = "hu.dwim.syntax-sugar"; - version = "stable-git"; - asds = [ "hu.dwim.syntax-sugar" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.syntax-sugar/2023-02-14/hu.dwim.syntax-sugar-stable-git.tgz"; - sha256 = "1cy474di8njy4s39n7kn2w9jw39n4rssrk0fghrj0gabfxiz4wv9"; - system = "hu.dwim.syntax-sugar"; - asd = "hu.dwim.syntax-sugar"; - }); - systems = [ "hu.dwim.syntax-sugar" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_syntax-sugar_dot_documentation = (build-asdf-system { - pname = "hu.dwim.syntax-sugar.documentation"; - version = "stable-git"; - asds = [ "hu.dwim.syntax-sugar.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.syntax-sugar/2023-02-14/hu.dwim.syntax-sugar-stable-git.tgz"; - sha256 = "1cy474di8njy4s39n7kn2w9jw39n4rssrk0fghrj0gabfxiz4wv9"; - system = "hu.dwim.syntax-sugar.documentation"; - asd = "hu.dwim.syntax-sugar.documentation"; - }); - systems = [ "hu.dwim.syntax-sugar.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_presentation" self) (getAttr "hu_dot_dwim_dot_syntax-sugar_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_syntax-sugar_dot_test = (build-asdf-system { - pname = "hu.dwim.syntax-sugar.test"; - version = "stable-git"; - asds = [ "hu.dwim.syntax-sugar.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.syntax-sugar/2023-02-14/hu.dwim.syntax-sugar-stable-git.tgz"; - sha256 = "1cy474di8njy4s39n7kn2w9jw39n4rssrk0fghrj0gabfxiz4wv9"; - system = "hu.dwim.syntax-sugar.test"; - asd = "hu.dwim.syntax-sugar.test"; - }); - systems = [ "hu.dwim.syntax-sugar.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) (getAttr "hu_dot_dwim_dot_syntax-sugar" self) (getAttr "hu_dot_dwim_dot_walker" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_uri = (build-asdf-system { - pname = "hu.dwim.uri"; - version = "20180228-darcs"; - asds = [ "hu.dwim.uri" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.uri/2018-02-28/hu.dwim.uri-20180228-darcs.tgz"; - sha256 = "0wvai7djmbry0b0j8vhzw3s8m30ghs2sml29gw6snh1pynh3c2ir"; - system = "hu.dwim.uri"; - asd = "hu.dwim.uri"; - }); - systems = [ "hu.dwim.uri" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-ppcre" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "iolib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_uri_dot_test = (build-asdf-system { - pname = "hu.dwim.uri.test"; - version = "20180228-darcs"; - asds = [ "hu.dwim.uri.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.uri/2018-02-28/hu.dwim.uri-20180228-darcs.tgz"; - sha256 = "0wvai7djmbry0b0j8vhzw3s8m30ghs2sml29gw6snh1pynh3c2ir"; - system = "hu.dwim.uri.test"; - asd = "hu.dwim.uri.test"; - }); - systems = [ "hu.dwim.uri.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) (getAttr "hu_dot_dwim_dot_uri" self) (getAttr "hu_dot_dwim_dot_util" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_util = (build-asdf-system { - pname = "hu.dwim.util"; - version = "stable-git"; - asds = [ "hu.dwim.util" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.util/2021-12-30/hu.dwim.util-stable-git.tgz"; - sha256 = "01f0kvvaa94zkz5zzfaf8cbiihlp0l6627q3hmc0k154j3mdarmi"; - system = "hu.dwim.util"; - asd = "hu.dwim.util"; - }); - systems = [ "hu.dwim.util" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_syntax-sugar" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_util_plus_iolib = (build-asdf-system { - pname = "hu.dwim.util+iolib"; - version = "stable-git"; - asds = [ "hu.dwim.util+iolib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.util/2021-12-30/hu.dwim.util-stable-git.tgz"; - sha256 = "01f0kvvaa94zkz5zzfaf8cbiihlp0l6627q3hmc0k154j3mdarmi"; - system = "hu.dwim.util+iolib"; - asd = "hu.dwim.util+iolib"; - }); - systems = [ "hu.dwim.util+iolib" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "iolib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_util_dot_documentation = (build-asdf-system { - pname = "hu.dwim.util.documentation"; - version = "stable-git"; - asds = [ "hu.dwim.util.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.util/2021-12-30/hu.dwim.util-stable-git.tgz"; - sha256 = "01f0kvvaa94zkz5zzfaf8cbiihlp0l6627q3hmc0k154j3mdarmi"; - system = "hu.dwim.util.documentation"; - asd = "hu.dwim.util.documentation"; - }); - systems = [ "hu.dwim.util.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_presentation" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_util_dot_test = (build-asdf-system { - pname = "hu.dwim.util.test"; - version = "stable-git"; - asds = [ "hu.dwim.util.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.util/2021-12-30/hu.dwim.util-stable-git.tgz"; - sha256 = "01f0kvvaa94zkz5zzfaf8cbiihlp0l6627q3hmc0k154j3mdarmi"; - system = "hu.dwim.util.test"; - asd = "hu.dwim.util.test"; - }); - systems = [ "hu.dwim.util.test" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "babel-streams" self) (getAttr "bordeaux-threads" self) (getAttr "cl-l10n" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "command-line-arguments" self) (getAttr "cxml" self) (getAttr "drakma" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_delico" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_perec_dot_postgresql" self) (getAttr "hu_dot_dwim_dot_quasi-quote_dot_xml" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) (getAttr "hu_dot_dwim_dot_syntax-sugar" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "hu_dot_dwim_dot_util_plus_iolib" self) (getAttr "hu_dot_dwim_dot_web-server_dot_application" self) (getAttr "iolib" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_walker = (build-asdf-system { - pname = "hu.dwim.walker"; - version = "stable-git"; - asds = [ "hu.dwim.walker" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.walker/2022-07-07/hu.dwim.walker-stable-git.tgz"; - sha256 = "0sw7z5iml82sklxjy1wr42mbp2qqml49ci36d6xsckar0sqsc8vr"; - system = "hu.dwim.walker"; - asd = "hu.dwim.walker"; - }); - systems = [ "hu.dwim.walker" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "closer-mop" self) (getAttr "contextl" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def_plus_contextl" self) (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "metabang-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_web-server = (build-asdf-system { - pname = "hu.dwim.web-server"; - version = "20220707-darcs"; - asds = [ "hu.dwim.web-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; - sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; - system = "hu.dwim.web-server"; - asd = "hu.dwim.web-server"; - }); - systems = [ "hu.dwim.web-server" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "babel-streams" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cl_plus_ssl" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_computed-class" self) (getAttr "hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_def_plus_cl-l10n" self) (getAttr "hu_dot_dwim_dot_def_plus_contextl" self) (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_delico" self) (getAttr "hu_dot_dwim_dot_logger_plus_iolib" self) (getAttr "hu_dot_dwim_dot_quasi-quote_dot_xml_plus_hu_dot_dwim_dot_quasi-quote_dot_js" self) (getAttr "hu_dot_dwim_dot_syntax-sugar" self) (getAttr "hu_dot_dwim_dot_uri" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "hu_dot_dwim_dot_zlib" self) (getAttr "iolib" self) (getAttr "local-time" self) (getAttr "parse-number" self) (getAttr "rfc2109" self) (getAttr "rfc2388-binary" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_web-server_plus_swank = (build-asdf-system { - pname = "hu.dwim.web-server+swank"; - version = "20220707-darcs"; - asds = [ "hu.dwim.web-server+swank" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; - sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; - system = "hu.dwim.web-server+swank"; - asd = "hu.dwim.web-server+swank"; - }); - systems = [ "hu.dwim.web-server+swank" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_def_plus_swank" self) (getAttr "hu_dot_dwim_dot_web-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_web-server_dot_application = (build-asdf-system { - pname = "hu.dwim.web-server.application"; - version = "20220707-darcs"; - asds = [ "hu.dwim.web-server.application" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; - sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; - system = "hu.dwim.web-server.application"; - asd = "hu.dwim.web-server.application"; - }); - systems = [ "hu.dwim.web-server.application" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_web-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_web-server_dot_application_plus_hu_dot_dwim_dot_perec = (build-asdf-system { - pname = "hu.dwim.web-server.application+hu.dwim.perec"; - version = "20220707-darcs"; - asds = [ "hu.dwim.web-server.application+hu.dwim.perec" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; - sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; - system = "hu.dwim.web-server.application+hu.dwim.perec"; - asd = "hu.dwim.web-server.application+hu.dwim.perec"; - }); - systems = [ "hu.dwim.web-server.application+hu.dwim.perec" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_perec" self) (getAttr "hu_dot_dwim_dot_web-server_dot_application" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_web-server_dot_application_dot_test = (build-asdf-system { - pname = "hu.dwim.web-server.application.test"; - version = "20220707-darcs"; - asds = [ "hu.dwim.web-server.application.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; - sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; - system = "hu.dwim.web-server.application.test"; - asd = "hu.dwim.web-server.application.test"; - }); - systems = [ "hu.dwim.web-server.application.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_web-server_dot_application" self) (getAttr "hu_dot_dwim_dot_web-server_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_web-server_dot_documentation = (build-asdf-system { - pname = "hu.dwim.web-server.documentation"; - version = "20220707-darcs"; - asds = [ "hu.dwim.web-server.documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; - sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; - system = "hu.dwim.web-server.documentation"; - asd = "hu.dwim.web-server.documentation"; - }); - systems = [ "hu.dwim.web-server.documentation" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_presentation" self) (getAttr "hu_dot_dwim_dot_web-server_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_web-server_dot_test = (build-asdf-system { - pname = "hu.dwim.web-server.test"; - version = "20220707-darcs"; - asds = [ "hu.dwim.web-server.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; - sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; - system = "hu.dwim.web-server.test"; - asd = "hu.dwim.web-server.test"; - }); - systems = [ "hu.dwim.web-server.test" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_computed-class_plus_hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) (getAttr "hu_dot_dwim_dot_web-server" self) (getAttr "hu_dot_dwim_dot_web-server_plus_swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_web-server_dot_websocket = (build-asdf-system { - pname = "hu.dwim.web-server.websocket"; - version = "20220707-darcs"; - asds = [ "hu.dwim.web-server.websocket" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; - sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; - system = "hu.dwim.web-server.websocket"; - asd = "hu.dwim.web-server.websocket"; - }); - systems = [ "hu.dwim.web-server.websocket" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_web-server" self) (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hu_dot_dwim_dot_zlib = (build-asdf-system { - pname = "hu.dwim.zlib"; - version = "stable-git"; - asds = [ "hu.dwim.zlib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hu.dwim.zlib/2022-07-07/hu.dwim.zlib-stable-git.tgz"; - sha256 = "1yrsbl6rmsp6sdaj9yzwx1bpbs529akndxnpplafw31195khnxm1"; - system = "hu.dwim.zlib"; - asd = "hu.dwim.zlib"; - }); - systems = [ "hu.dwim.zlib" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-libffi" self) (getAttr "hu_dot_dwim_dot_asdf" self) ]; - meta = { - broken = true; - hydraPlatforms = [ ]; - }; - }); - huffman = (build-asdf-system { - pname = "huffman"; - version = "20181018-git"; - asds = [ "huffman" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/huffman/2018-10-18/huffman-20181018-git.tgz"; - sha256 = "05b3ql5szzi4vsry76i76483mxf9m5i9620hdshykh5rbfiarvcx"; - system = "huffman"; - asd = "huffman"; - }); - systems = [ "huffman" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - humbler = (build-asdf-system { - pname = "humbler"; - version = "20231021-git"; - asds = [ "humbler" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/humbler/2023-10-21/humbler-20231021-git.tgz"; - sha256 = "15fdvlrhdvr58i2rwa87i4is2rgh9xzjag0sqhga8ri7a8i63fgf"; - system = "humbler"; - asd = "humbler"; - }); - systems = [ "humbler" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "local-time" self) (getAttr "north-core" self) (getAttr "trivial-mimes" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hunchensocket = (build-asdf-system { - pname = "hunchensocket"; - version = "20221106-git"; - asds = [ "hunchensocket" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hunchensocket/2022-11-06/hunchensocket-20221106-git.tgz"; - sha256 = "1vhd009lwl62l1czmhsalblxmyz4x9v3nspjflpajwm1db5rnd7h"; - system = "hunchensocket"; - asd = "hunchensocket"; - }); - systems = [ "hunchensocket" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "chunga" self) (getAttr "cl-base64" self) (getAttr "cl-fad" self) (getAttr "flexi-streams" self) (getAttr "hunchentoot" self) (getAttr "sha1" self) (getAttr "trivial-backtrace" self) (getAttr "trivial-utf-8" self) ]; - meta = {}; - }); - hunchensocket-tests = (build-asdf-system { - pname = "hunchensocket-tests"; - version = "20221106-git"; - asds = [ "hunchensocket-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hunchensocket/2022-11-06/hunchensocket-20221106-git.tgz"; - sha256 = "1vhd009lwl62l1czmhsalblxmyz4x9v3nspjflpajwm1db5rnd7h"; - system = "hunchensocket-tests"; - asd = "hunchensocket"; - }); - systems = [ "hunchensocket-tests" ]; - lispLibs = [ (getAttr "fiasco" self) (getAttr "hunchensocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hunchentools = (build-asdf-system { - pname = "hunchentools"; - version = "20161204-git"; - asds = [ "hunchentools" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hunchentools/2016-12-04/hunchentools-20161204-git.tgz"; - sha256 = "12r1ml1xxhyz646nnxqzixfisljjaracwp9jhwl3wb285qbmai4b"; - system = "hunchentools"; - asd = "hunchentools"; - }); - systems = [ "hunchentools" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "hunchentoot" self) (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hunchentoot = (build-asdf-system { - pname = "hunchentoot"; - version = "v1.3.1"; - asds = [ "hunchentoot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hunchentoot/2024-10-12/hunchentoot-v1.3.1.tgz"; - sha256 = "0g4lh26l2vd10ilk1hrfmpj6hpjb986jp191ha2j6p2q1pil3kgc"; - system = "hunchentoot"; - asd = "hunchentoot"; - }); - systems = [ "hunchentoot" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "chunga" self) (getAttr "cl_plus_ssl" self) (getAttr "cl-base64" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "md5" self) (getAttr "rfc2388" self) (getAttr "trivial-backtrace" self) (getAttr "usocket" self) ]; - meta = {}; - }); - hunchentoot-auth = (build-asdf-system { - pname = "hunchentoot-auth"; - version = "20140113-git"; - asds = [ "hunchentoot-auth" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hunchentoot-auth/2014-01-13/hunchentoot-auth-20140113-git.tgz"; - sha256 = "1bc70lh2jvk6gqmhczgv0indxk6j5whxbh7gylrlbv16041sdkbj"; - system = "hunchentoot-auth"; - asd = "hunchentoot-auth"; - }); - systems = [ "hunchentoot-auth" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-store" self) (getAttr "cl-who" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hunchentoot-cgi = (build-asdf-system { - pname = "hunchentoot-cgi"; - version = "20140211-git"; - asds = [ "hunchentoot-cgi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hunchentoot-cgi/2014-02-11/hunchentoot-cgi-20140211-git.tgz"; - sha256 = "0al6qfs6661avhywsqxh3nwyhl1d1gip3yx57b8siczjarpgpawc"; - system = "hunchentoot-cgi"; - asd = "hunchentoot-cgi"; - }); - systems = [ "hunchentoot-cgi" ]; - lispLibs = [ (getAttr "hunchentoot" self) (getAttr "puri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hunchentoot-errors = (build-asdf-system { - pname = "hunchentoot-errors"; - version = "20231021-git"; - asds = [ "hunchentoot-errors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hunchentoot-errors/2023-10-21/hunchentoot-errors-20231021-git.tgz"; - sha256 = "0fab7s8qhhs713cw014qqvzm5z61wmxm2fcbkarhg41cz3li9k1j"; - system = "hunchentoot-errors"; - asd = "hunchentoot-errors"; - }); - systems = [ "hunchentoot-errors" ]; - lispLibs = [ (getAttr "cl-mimeparse" self) (getAttr "hunchentoot" self) (getAttr "parse-number" self) (getAttr "string-case" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hunchentoot-multi-acceptor = (build-asdf-system { - pname = "hunchentoot-multi-acceptor"; - version = "20220331-git"; - asds = [ "hunchentoot-multi-acceptor" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hunchentoot-multi-acceptor/2022-03-31/hunchentoot-multi-acceptor-20220331-git.tgz"; - sha256 = "0m42dw8x0bp03n4hx4ppf45gjg14igf69z4rn7dslch6km58mrha"; - system = "hunchentoot-multi-acceptor"; - asd = "hunchentoot-multi-acceptor"; - }); - systems = [ "hunchentoot-multi-acceptor" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "hunchentoot" self) (getAttr "str" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hunchentoot-single-signon = (build-asdf-system { - pname = "hunchentoot-single-signon"; - version = "20131111-git"; - asds = [ "hunchentoot-single-signon" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hunchentoot-single-signon/2013-11-11/hunchentoot-single-signon-20131111-git.tgz"; - sha256 = "0dh16k4105isqwnkl52m55m6cbl7g8wmcrym8175r2zr6qcbghq8"; - system = "hunchentoot-single-signon"; - asd = "hunchentoot-single-signon"; - }); - systems = [ "hunchentoot-single-signon" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "cl-gss" self) (getAttr "hunchentoot" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hunchentoot-stuck-connection-monitor = (build-asdf-system { - pname = "hunchentoot-stuck-connection-monitor"; - version = "20241012-git"; - asds = [ "hunchentoot-stuck-connection-monitor" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hunchentoot-stuck-connection-monitor/2024-10-12/hunchentoot-stuck-connection-monitor-20241012-git.tgz"; - sha256 = "1zbpxcym8pi9bf3m7f8f5aa2xhq048kx54sj1ka1vnz7rgccghc6"; - system = "hunchentoot-stuck-connection-monitor"; - asd = "hunchentoot-stuck-connection-monitor"; - }); - systems = [ "hunchentoot-stuck-connection-monitor" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "hunchentoot" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hyperlattices = (build-asdf-system { - pname = "hyperlattices"; - version = "20231021-git"; - asds = [ "hyperlattices" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hyperlattices/2023-10-21/hyperlattices-20231021-git.tgz"; - sha256 = "1d0jhy7yv5917bgx1b8r8ch5b94zbg933kx8ak2sbpgsf16pqf2h"; - system = "hyperlattices"; - asd = "hyperlattices"; - }); - systems = [ "hyperlattices" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "serapeum" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hyperluminal-mem = (build-asdf-system { - pname = "hyperluminal-mem"; - version = "20210630-git"; - asds = [ "hyperluminal-mem" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hyperluminal-mem/2021-06-30/hyperluminal-mem-20210630-git.tgz"; - sha256 = "0qp00g43v518j0wccqnpglkrpikagnn9naphb29wbil6k7y9y7r9"; - system = "hyperluminal-mem"; - asd = "hyperluminal-mem"; - }); - systems = [ "hyperluminal-mem" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "osicat" self) (getAttr "stmx" self) (getAttr "swap-bytes" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hyperluminal-mem-test = (build-asdf-system { - pname = "hyperluminal-mem-test"; - version = "20210630-git"; - asds = [ "hyperluminal-mem-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hyperluminal-mem/2021-06-30/hyperluminal-mem-20210630-git.tgz"; - sha256 = "0qp00g43v518j0wccqnpglkrpikagnn9naphb29wbil6k7y9y7r9"; - system = "hyperluminal-mem-test"; - asd = "hyperluminal-mem-test"; - }); - systems = [ "hyperluminal-mem-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "hyperluminal-mem" self) (getAttr "log4cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hyperobject = (build-asdf-system { - pname = "hyperobject"; - version = "20201016-git"; - asds = [ "hyperobject" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hyperobject/2020-10-16/hyperobject-20201016-git.tgz"; - sha256 = "1ggqlvwcd52c2d4k8csy7qciaq7lyldi0rpk3b9x4rw4gllcch8n"; - system = "hyperobject"; - asd = "hyperobject"; - }); - systems = [ "hyperobject" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "kmrcl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - hyperspec = (build-asdf-system { - pname = "hyperspec"; - version = "20181210-git"; - asds = [ "hyperspec" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hyperspec/2018-12-10/hyperspec-20181210-git.tgz"; - sha256 = "0zh1dq2451xw7yiycdr2mrcjx6rgnqnm8c8l9zhhn7hnf51b4x5l"; - system = "hyperspec"; - asd = "hyperspec"; - }); - systems = [ "hyperspec" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ia-hash-table = (build-asdf-system { - pname = "ia-hash-table"; - version = "20160318-git"; - asds = [ "ia-hash-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ia-hash-table/2016-03-18/ia-hash-table-20160318-git.tgz"; - sha256 = "11wnwjxa528yyjnfsvw315hyvq3lc996dwx83isdg4hlirj3amy4"; - system = "ia-hash-table"; - asd = "ia-hash-table"; - }); - systems = [ "ia-hash-table" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ia-hash-table_dot_test = (build-asdf-system { - pname = "ia-hash-table.test"; - version = "20160318-git"; - asds = [ "ia-hash-table.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ia-hash-table/2016-03-18/ia-hash-table-20160318-git.tgz"; - sha256 = "11wnwjxa528yyjnfsvw315hyvq3lc996dwx83isdg4hlirj3amy4"; - system = "ia-hash-table.test"; - asd = "ia-hash-table.test"; - }); - systems = [ "ia-hash-table.test" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "ia-hash-table" self) (getAttr "log4cl" self) (getAttr "mw-equiv" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - iclendar = (build-asdf-system { - pname = "iclendar"; - version = "20231021-git"; - asds = [ "iclendar" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/iclendar/2023-10-21/iclendar-20231021-git.tgz"; - sha256 = "13ic0zlwrlf6k08x7c8v96kjpbh1dmap15q4cv4in7rkx6rn2rsa"; - system = "iclendar"; - asd = "iclendar"; - }); - systems = [ "iclendar" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "closer-mop" self) (getAttr "documentation-utils" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - iconv = (build-asdf-system { - pname = "iconv"; - version = "20171227-git"; - asds = [ "iconv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-iconv/2017-12-27/cl-iconv-20171227-git.tgz"; - sha256 = "1lpw95c02inifhdh9kkab9q92i5w9zd788dww1wly2p0a6kyx9wg"; - system = "iconv"; - asd = "iconv"; - }); - systems = [ "iconv" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - id3v2 = (build-asdf-system { - pname = "id3v2"; - version = "20160208-git"; - asds = [ "id3v2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/id3v2/2016-02-08/id3v2-20160208-git.tgz"; - sha256 = "0x017dfh9m80b8ml2vsgdcfs4kv7p06yzmwdilf1k8nfsilwpfra"; - system = "id3v2"; - asd = "id3v2"; - }); - systems = [ "id3v2" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - id3v2-test = (build-asdf-system { - pname = "id3v2-test"; - version = "20160208-git"; - asds = [ "id3v2-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/id3v2/2016-02-08/id3v2-20160208-git.tgz"; - sha256 = "0x017dfh9m80b8ml2vsgdcfs4kv7p06yzmwdilf1k8nfsilwpfra"; - system = "id3v2-test"; - asd = "id3v2-test"; - }); - systems = [ "id3v2-test" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "id3v2" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - identifier-pool = (build-asdf-system { - pname = "identifier-pool"; - version = "20220707-git"; - asds = [ "identifier-pool" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/identifier-pool/2022-07-07/identifier-pool-20220707-git.tgz"; - sha256 = "01fs960s02nf8m3a5v95r12magq9rvgcc3awcppqa7c8yg7qdc55"; - system = "identifier-pool"; - asd = "identifier-pool"; - }); - systems = [ "identifier-pool" ]; - lispLibs = [ (getAttr "dynamic-array" self) (getAttr "mfiano-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - idna = (build-asdf-system { - pname = "idna"; - version = "20120107-git"; - asds = [ "idna" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/idna/2012-01-07/idna-20120107-git.tgz"; - sha256 = "00nbr3mffxhlq14gg9d16pa6691s4qh35inyw76v906s77khm5a2"; - system = "idna"; - asd = "idna"; - }); - systems = [ "idna" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = {}; - }); - ieee-floats = (build-asdf-system { - pname = "ieee-floats"; - version = "20220220-git"; - asds = [ "ieee-floats" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ieee-floats/2022-02-20/ieee-floats-20220220-git.tgz"; - sha256 = "0qp2dxq9jzndjfmc8nh0fvcwrrxjm7f012biczipifjckp9gxw7d"; - system = "ieee-floats"; - asd = "ieee-floats"; - }); - systems = [ "ieee-floats" ]; - lispLibs = [ ]; - meta = {}; - }); - illogical-pathnames = (build-asdf-system { - pname = "illogical-pathnames"; - version = "20160825-git"; - asds = [ "illogical-pathnames" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/illogical-pathnames/2016-08-25/illogical-pathnames-20160825-git.tgz"; - sha256 = "1yjs1lzgak1d3hz2q6sbac98vqgdxp0dz72fskpz73vrbp6h6da5"; - system = "illogical-pathnames"; - asd = "illogical-pathnames"; - }); - systems = [ "illogical-pathnames" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - illusion = (build-asdf-system { - pname = "illusion"; - version = "20180831-git"; - asds = [ "illusion" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/illusion/2018-08-31/illusion-20180831-git.tgz"; - sha256 = "05wik6q8hlhm7szzymkljfigcp7z35j6rz2ihsmng1y6zq9crk7z"; - system = "illusion"; - asd = "illusion"; - }); - systems = [ "illusion" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "let-over-lambda" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - illusion-test = (build-asdf-system { - pname = "illusion-test"; - version = "20180831-git"; - asds = [ "illusion-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/illusion/2018-08-31/illusion-20180831-git.tgz"; - sha256 = "05wik6q8hlhm7szzymkljfigcp7z35j6rz2ihsmng1y6zq9crk7z"; - system = "illusion-test"; - asd = "illusion-test"; - }); - systems = [ "illusion-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "illusion" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - image = (build-asdf-system { - pname = "image"; - version = "20120107-git"; - asds = [ "image" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/image/2012-01-07/image-20120107-git.tgz"; - sha256 = "04by1snzw2kpw208fdi2azxbq5y2q2r6x8zkdh7jk43amkr18f5k"; - system = "image"; - asd = "image"; - }); - systems = [ "image" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "gzip-stream" self) (getAttr "skippy" self) (getAttr "zpng" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - image-test = (build-asdf-system { - pname = "image-test"; - version = "20211020-git"; - asds = [ "image-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-png/2021-10-20/cl-png-20211020-git.tgz"; - sha256 = "17xcb9ps5vf3if61blmx7cpfrz3gsw7jk8d5zv3f4cq8jrriqdx4"; - system = "image-test"; - asd = "image-test"; - }); - systems = [ "image-test" ]; - lispLibs = [ (getAttr "png" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - image-utility = (build-asdf-system { - pname = "image-utility"; - version = "20200427-git"; - asds = [ "image-utility" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "image-utility"; - asd = "image-utility"; - }); - systems = [ "image-utility" ]; - lispLibs = [ (getAttr "opticl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - imago = (build-asdf-system { - pname = "imago"; - version = "20241012-git"; - asds = [ "imago" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/imago/2024-10-12/imago-20241012-git.tgz"; - sha256 = "1jhhlqbzdd68n8scl98dxfr92s1rgd43isgd317l3ynfjwz63wq1"; - system = "imago"; - asd = "imago"; - }); - systems = [ "imago" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "array-operations" self) (getAttr "cl-jpeg" self) (getAttr "flexi-streams" self) (getAttr "serapeum" self) (getAttr "trivial-gray-streams" self) (getAttr "zlib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - immutable-struct = (build-asdf-system { - pname = "immutable-struct"; - version = "20150709-git"; - asds = [ "immutable-struct" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/immutable-struct/2015-07-09/immutable-struct-20150709-git.tgz"; - sha256 = "02868d21hcc0kc3jw8afx23kj6iy1vyf2pddn8yqfrkpldhd0rv9"; - system = "immutable-struct"; - asd = "immutable-struct"; - }); - systems = [ "immutable-struct" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - in-nomine = (build-asdf-system { - pname = "in-nomine"; - version = "20241012-git"; - asds = [ "in-nomine" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/in-nomine/2024-10-12/in-nomine-20241012-git.tgz"; - sha256 = "1wcfxqj5dfmkg94rnz2nsmyw8iwicncxmklnirlngqqvlcrd0rv4"; - system = "in-nomine"; - asd = "in-nomine"; - }); - systems = [ "in-nomine" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-arguments" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - incf-cl = (build-asdf-system { - pname = "incf-cl"; - version = "20190710-git"; - asds = [ "incf-cl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/incf-cl/2019-07-10/incf-cl-20190710-git.tgz"; - sha256 = "1yvwb57dzccvd2lw2h3mwxgbi8ml3cgkyy8kl8hwhd4s8c016ibb"; - system = "incf-cl"; - asd = "incf-cl"; - }); - systems = [ "incf-cl" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - incless = (build-asdf-system { - pname = "incless"; - version = "20241012-git"; - asds = [ "incless" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/incless/2024-10-12/incless-20241012-git.tgz"; - sha256 = "1ypxhsx3fqwfng3b425bsgxbra7asny9261amdbfd6p59r51cyiy"; - system = "incless"; - asd = "incless"; - }); - systems = [ "incless" ]; - lispLibs = [ (getAttr "quaviver" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - incless-extrinsic = (build-asdf-system { - pname = "incless-extrinsic"; - version = "20241012-git"; - asds = [ "incless-extrinsic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/incless/2024-10-12/incless-20241012-git.tgz"; - sha256 = "1ypxhsx3fqwfng3b425bsgxbra7asny9261amdbfd6p59r51cyiy"; - system = "incless-extrinsic"; - asd = "incless-extrinsic"; - }); - systems = [ "incless-extrinsic" ]; - lispLibs = [ (getAttr "incless" self) (getAttr "quaviver" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - incless-native = (build-asdf-system { - pname = "incless-native"; - version = "20241012-git"; - asds = [ "incless-native" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/incless/2024-10-12/incless-20241012-git.tgz"; - sha256 = "1ypxhsx3fqwfng3b425bsgxbra7asny9261amdbfd6p59r51cyiy"; - system = "incless-native"; - asd = "incless-native"; - }); - systems = [ "incless-native" ]; - lispLibs = [ (getAttr "incless" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - incognito-keywords = (build-asdf-system { - pname = "incognito-keywords"; - version = "1.1"; - asds = [ "incognito-keywords" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/incognito-keywords/2013-01-28/incognito-keywords-1.1.tgz"; - sha256 = "1ignvz8v7bq8z9x22skzp1xsna2bxqcw22zh5sp9v2ndbjhqri5c"; - system = "incognito-keywords"; - asd = "incognito-keywords"; - }); - systems = [ "incognito-keywords" ]; - lispLibs = [ (getAttr "enhanced-eval-when" self) (getAttr "map-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - incongruent-methods = (build-asdf-system { - pname = "incongruent-methods"; - version = "20130312-git"; - asds = [ "incongruent-methods" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/incongruent-methods/2013-03-12/incongruent-methods-20130312-git.tgz"; - sha256 = "15xfbpnqymbkk92vbirvccxcphyvjmxcw02yv1zs6c78aaf4ms9z"; - system = "incongruent-methods"; - asd = "incongruent-methods"; - }); - systems = [ "incongruent-methods" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inferior-shell = (build-asdf-system { - pname = "inferior-shell"; - version = "20241012-git"; - asds = [ "inferior-shell" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inferior-shell/2024-10-12/inferior-shell-20241012-git.tgz"; - sha256 = "1bmw0jjcpssahymqidz159pqbz5ficz56w7b97hfy1xnwkd2fwg5"; - system = "inferior-shell"; - asd = "inferior-shell"; - }); - systems = [ "inferior-shell" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "fare-mop" self) (getAttr "fare-quasiquote-extras" self) (getAttr "fare-utils" self) (getAttr "trivia" self) (getAttr "trivia_dot_quasiquote" self) ]; - meta = {}; - }); - infix = (build-asdf-system { - pname = "infix"; - version = "20210411-git"; - asds = [ "infix" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; - sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; - system = "infix"; - asd = "infix"; - }); - systems = [ "infix" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - infix-dollar-reader = (build-asdf-system { - pname = "infix-dollar-reader"; - version = "20121013-git"; - asds = [ "infix-dollar-reader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/infix-dollar-reader/2012-10-13/infix-dollar-reader-20121013-git.tgz"; - sha256 = "11sf4kqcw8s0zcjz1qpbhkn33rizvq5ijl6xp59q9wadvkd0wx0w"; - system = "infix-dollar-reader"; - asd = "infix-dollar-reader"; - }); - systems = [ "infix-dollar-reader" ]; - lispLibs = [ (getAttr "cl-syntax" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - infix-dollar-reader-test = (build-asdf-system { - pname = "infix-dollar-reader-test"; - version = "20121013-git"; - asds = [ "infix-dollar-reader-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/infix-dollar-reader/2012-10-13/infix-dollar-reader-20121013-git.tgz"; - sha256 = "11sf4kqcw8s0zcjz1qpbhkn33rizvq5ijl6xp59q9wadvkd0wx0w"; - system = "infix-dollar-reader-test"; - asd = "infix-dollar-reader-test"; - }); - systems = [ "infix-dollar-reader-test" ]; - lispLibs = [ (getAttr "infix-dollar-reader" self) (getAttr "rt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - infix-math = (build-asdf-system { - pname = "infix-math"; - version = "20211020-git"; - asds = [ "infix-math" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/infix-math/2021-10-20/infix-math-20211020-git.tgz"; - sha256 = "1h6p254xl793wfq3qla5y95k6zimy477f8brblx6ran3rg3bydbg"; - system = "infix-math"; - asd = "infix-math"; - }); - systems = [ "infix-math" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "asdf-package-system" self) (getAttr "parse-number" self) (getAttr "serapeum" self) (getAttr "wu-decimal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - infix-reader = (build-asdf-system { - pname = "infix-reader"; - version = "20221106-git"; - asds = [ "infix-reader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/infix-reader/2022-11-06/infix-reader-20221106-git.tgz"; - sha256 = "16b6cw4w80p3yxsv0pqaiq0ay1v3jswlav2mlfsmhawpvhxsmb7z"; - system = "infix-reader"; - asd = "infix-reader"; - }); - systems = [ "infix-reader" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inheriting-readers = (build-asdf-system { - pname = "inheriting-readers"; - version = "1.0.1"; - asds = [ "inheriting-readers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inheriting-readers/2021-01-24/inheriting-readers_1.0.1.tgz"; - sha256 = "0km3mq6vx1q9qv6j3r4sqqcsdbnb5jar66bl0mzzpaacfvzbx68p"; - system = "inheriting-readers"; - asd = "inheriting-readers"; - }); - systems = [ "inheriting-readers" ]; - lispLibs = [ (getAttr "class-options" self) (getAttr "closer-mop" self) (getAttr "compatible-metaclasses" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inheriting-readers__tests = (build-asdf-system { - pname = "inheriting-readers_tests"; - version = "1.0.1"; - asds = [ "inheriting-readers_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inheriting-readers/2021-01-24/inheriting-readers_1.0.1.tgz"; - sha256 = "0km3mq6vx1q9qv6j3r4sqqcsdbnb5jar66bl0mzzpaacfvzbx68p"; - system = "inheriting-readers_tests"; - asd = "inheriting-readers_tests"; - }); - systems = [ "inheriting-readers_tests" ]; - lispLibs = [ (getAttr "compatible-metaclasses" self) (getAttr "inheriting-readers" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - injection = (build-asdf-system { - pname = "injection"; - version = "20160531-git"; - asds = [ "injection" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/injection/2016-05-31/injection-20160531-git.tgz"; - sha256 = "12f838ikgyl7gzh2dnqh54hfa8rncbkk266bsibmbbqxz0cn2da7"; - system = "injection"; - asd = "injection"; - }); - systems = [ "injection" ]; - lispLibs = [ (getAttr "cl-yaml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - injection-test = (build-asdf-system { - pname = "injection-test"; - version = "20160531-git"; - asds = [ "injection-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/injection/2016-05-31/injection-20160531-git.tgz"; - sha256 = "12f838ikgyl7gzh2dnqh54hfa8rncbkk266bsibmbbqxz0cn2da7"; - system = "injection-test"; - asd = "injection-test"; - }); - systems = [ "injection-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "injection" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inkwell = (build-asdf-system { - pname = "inkwell"; - version = "20231021-git"; - asds = [ "inkwell" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inkwell/2023-10-21/inkwell-20231021-git.tgz"; - sha256 = "07yxgs2zfnyr158v8q2s4npvzjzmpifx61hg7fc17dsmqgw296yc"; - system = "inkwell"; - asd = "inkwell"; - }); - systems = [ "inkwell" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "documentation-utils" self) (getAttr "drakma" self) (getAttr "local-time" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inlined-generic-function = (build-asdf-system { - pname = "inlined-generic-function"; - version = "20190521-git"; - asds = [ "inlined-generic-function" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inlined-generic-function/2019-05-21/inlined-generic-function-20190521-git.tgz"; - sha256 = "0kj9p99m9hwx4lx95npfln5dc5ip884f8agjc6h4y0rhnpj7r8gk"; - system = "inlined-generic-function"; - asd = "inlined-generic-function"; - }); - systems = [ "inlined-generic-function" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "introspect-environment" self) (getAttr "iterate" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inlined-generic-function_dot_test = (build-asdf-system { - pname = "inlined-generic-function.test"; - version = "20190521-git"; - asds = [ "inlined-generic-function.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inlined-generic-function/2019-05-21/inlined-generic-function-20190521-git.tgz"; - sha256 = "0kj9p99m9hwx4lx95npfln5dc5ip884f8agjc6h4y0rhnpj7r8gk"; - system = "inlined-generic-function.test"; - asd = "inlined-generic-function.test"; - }); - systems = [ "inlined-generic-function.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "inlined-generic-function" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inner-conditional = (build-asdf-system { - pname = "inner-conditional"; - version = "20200925-git"; - asds = [ "inner-conditional" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inner-conditional/2020-09-25/inner-conditional-20200925-git.tgz"; - sha256 = "08vaq29l2bhv4n1c6zb3syddwpad66rghfy71fqidjvbag0ji71k"; - system = "inner-conditional"; - asd = "inner-conditional"; - }); - systems = [ "inner-conditional" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-syntax-annot" self) (getAttr "iterate" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inner-conditional-test = (build-asdf-system { - pname = "inner-conditional-test"; - version = "20200925-git"; - asds = [ "inner-conditional-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inner-conditional/2020-09-25/inner-conditional-20200925-git.tgz"; - sha256 = "08vaq29l2bhv4n1c6zb3syddwpad66rghfy71fqidjvbag0ji71k"; - system = "inner-conditional-test"; - asd = "inner-conditional-test"; - }); - systems = [ "inner-conditional-test" ]; - lispLibs = [ (getAttr "cl-test-more" self) (getAttr "inner-conditional" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inotify = (build-asdf-system { - pname = "inotify"; - version = "20150608-git"; - asds = [ "inotify" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inotify/2015-06-08/inotify-20150608-git.tgz"; - sha256 = "0jill05wsa7xbnkycc1ik1a05slv2h34fpyap2rxbnxvfjvyzw98"; - system = "inotify"; - asd = "inotify"; - }); - systems = [ "inotify" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "iolib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - input-event-codes = (build-asdf-system { - pname = "input-event-codes"; - version = "20221106-git"; - asds = [ "input-event-codes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/input-event-codes/2022-11-06/input-event-codes-20221106-git.tgz"; - sha256 = "1m96m9ia4frcn2xqaw4mfspjjzwl8gyj4k4rv0lq28va4s6mkgii"; - system = "input-event-codes"; - asd = "input-event-codes"; - }); - systems = [ "input-event-codes" ]; - lispLibs = [ (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inquisitor = (build-asdf-system { - pname = "inquisitor"; - version = "20190521-git"; - asds = [ "inquisitor" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inquisitor/2019-05-21/inquisitor-20190521-git.tgz"; - sha256 = "08rkmqnwlq6v84wcz9yp31j5lxrsy33kv3dh7n3ccsg4kc54slzw"; - system = "inquisitor"; - asd = "inquisitor"; - }); - systems = [ "inquisitor" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inquisitor-flexi = (build-asdf-system { - pname = "inquisitor-flexi"; - version = "20190521-git"; - asds = [ "inquisitor-flexi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inquisitor/2019-05-21/inquisitor-20190521-git.tgz"; - sha256 = "08rkmqnwlq6v84wcz9yp31j5lxrsy33kv3dh7n3ccsg4kc54slzw"; - system = "inquisitor-flexi"; - asd = "inquisitor-flexi"; - }); - systems = [ "inquisitor-flexi" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "inquisitor" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inquisitor-flexi-test = (build-asdf-system { - pname = "inquisitor-flexi-test"; - version = "20190521-git"; - asds = [ "inquisitor-flexi-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inquisitor/2019-05-21/inquisitor-20190521-git.tgz"; - sha256 = "08rkmqnwlq6v84wcz9yp31j5lxrsy33kv3dh7n3ccsg4kc54slzw"; - system = "inquisitor-flexi-test"; - asd = "inquisitor-flexi-test"; - }); - systems = [ "inquisitor-flexi-test" ]; - lispLibs = [ (getAttr "inquisitor-flexi" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inquisitor-test = (build-asdf-system { - pname = "inquisitor-test"; - version = "20190521-git"; - asds = [ "inquisitor-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inquisitor/2019-05-21/inquisitor-20190521-git.tgz"; - sha256 = "08rkmqnwlq6v84wcz9yp31j5lxrsy33kv3dh7n3ccsg4kc54slzw"; - system = "inquisitor-test"; - asd = "inquisitor-test"; - }); - systems = [ "inquisitor-test" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "flexi-streams" self) (getAttr "inquisitor" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inravina = (build-asdf-system { - pname = "inravina"; - version = "20241012-git"; - asds = [ "inravina" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inravina/2024-10-12/inravina-20241012-git.tgz"; - sha256 = "16kbxzsbb4vdhbf1dzgsgwj9n3cizk3sjixjgrfa8fal4nys7sa3"; - system = "inravina"; - asd = "inravina"; - }); - systems = [ "inravina" ]; - lispLibs = [ (getAttr "incless" self) (getAttr "nontrivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inravina-examples = (build-asdf-system { - pname = "inravina-examples"; - version = "20241012-git"; - asds = [ "inravina-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inravina/2024-10-12/inravina-20241012-git.tgz"; - sha256 = "16kbxzsbb4vdhbf1dzgsgwj9n3cizk3sjixjgrfa8fal4nys7sa3"; - system = "inravina-examples"; - asd = "inravina-examples"; - }); - systems = [ "inravina-examples" ]; - lispLibs = [ (getAttr "cl-pdf" self) (getAttr "inravina-extrinsic" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inravina-extrinsic = (build-asdf-system { - pname = "inravina-extrinsic"; - version = "20241012-git"; - asds = [ "inravina-extrinsic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inravina/2024-10-12/inravina-20241012-git.tgz"; - sha256 = "16kbxzsbb4vdhbf1dzgsgwj9n3cizk3sjixjgrfa8fal4nys7sa3"; - system = "inravina-extrinsic"; - asd = "inravina-extrinsic"; - }); - systems = [ "inravina-extrinsic" ]; - lispLibs = [ (getAttr "incless-extrinsic" self) (getAttr "inravina" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inravina-native = (build-asdf-system { - pname = "inravina-native"; - version = "20241012-git"; - asds = [ "inravina-native" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inravina/2024-10-12/inravina-20241012-git.tgz"; - sha256 = "16kbxzsbb4vdhbf1dzgsgwj9n3cizk3sjixjgrfa8fal4nys7sa3"; - system = "inravina-native"; - asd = "inravina-native"; - }); - systems = [ "inravina-native" ]; - lispLibs = [ (getAttr "inravina" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - inravina-shim = (build-asdf-system { - pname = "inravina-shim"; - version = "20241012-git"; - asds = [ "inravina-shim" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/inravina/2024-10-12/inravina-20241012-git.tgz"; - sha256 = "16kbxzsbb4vdhbf1dzgsgwj9n3cizk3sjixjgrfa8fal4nys7sa3"; - system = "inravina-shim"; - asd = "inravina-shim"; - }); - systems = [ "inravina-shim" ]; - lispLibs = [ (getAttr "incless-native" self) (getAttr "inravina" self) (getAttr "trivial-package-locks" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - instance-tracking = (build-asdf-system { - pname = "instance-tracking"; - version = "20221106-git"; - asds = [ "instance-tracking" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/instance-tracking/2022-11-06/instance-tracking-20221106-git.tgz"; - sha256 = "0bbxvl14ahws30x5dgjhilhybjgn1jfcbxwr8ji1ls31zf88fphr"; - system = "instance-tracking"; - asd = "instance-tracking"; - }); - systems = [ "instance-tracking" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - integral = (build-asdf-system { - pname = "integral"; - version = "20200325-git"; - asds = [ "integral" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/integral/2020-03-25/integral-20200325-git.tgz"; - sha256 = "17a9wg7n3f81fsi5mlsdxain1fw7ggfniipfrb9sr1ajff6lx9gs"; - system = "integral"; - asd = "integral"; - }); - systems = [ "integral" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "cl-syntax-annot" self) (getAttr "clos-fixtures" self) (getAttr "closer-mop" self) (getAttr "dbi" self) (getAttr "group-by" self) (getAttr "iterate" self) (getAttr "split-sequence" self) (getAttr "sxql" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - integral-rest = (build-asdf-system { - pname = "integral-rest"; - version = "20150923-git"; - asds = [ "integral-rest" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/integral-rest/2015-09-23/integral-rest-20150923-git.tgz"; - sha256 = "0187d9i7acw2v1hhy7wcz0vk90ji7cdgpaikb7admvzq0nnbzrmm"; - system = "integral-rest"; - asd = "integral-rest"; - }); - systems = [ "integral-rest" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-inflector" self) (getAttr "closer-mop" self) (getAttr "integral" self) (getAttr "jonathan" self) (getAttr "map-set" self) (getAttr "ningle" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - integral-rest-test = (build-asdf-system { - pname = "integral-rest-test"; - version = "20150923-git"; - asds = [ "integral-rest-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/integral-rest/2015-09-23/integral-rest-20150923-git.tgz"; - sha256 = "0187d9i7acw2v1hhy7wcz0vk90ji7cdgpaikb7admvzq0nnbzrmm"; - system = "integral-rest-test"; - asd = "integral-rest-test"; - }); - systems = [ "integral-rest-test" ]; - lispLibs = [ (getAttr "integral" self) (getAttr "integral-rest" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - integral-test = (build-asdf-system { - pname = "integral-test"; - version = "20200325-git"; - asds = [ "integral-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/integral/2020-03-25/integral-20200325-git.tgz"; - sha256 = "17a9wg7n3f81fsi5mlsdxain1fw7ggfniipfrb9sr1ajff6lx9gs"; - system = "integral-test"; - asd = "integral-test"; - }); - systems = [ "integral-test" ]; - lispLibs = [ (getAttr "integral" self) (getAttr "local-time" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - intel-hex = (build-asdf-system { - pname = "intel-hex"; - version = "20160318-git"; - asds = [ "intel-hex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/intel-hex/2016-03-18/intel-hex-20160318-git.tgz"; - sha256 = "0sz51qw262nh6ziwpy1kgv257nj56rp42s0g6g2rx3xv1ijdy395"; - system = "intel-hex"; - asd = "intel-hex"; - }); - systems = [ "intel-hex" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - intel-hex-test = (build-asdf-system { - pname = "intel-hex-test"; - version = "20160318-git"; - asds = [ "intel-hex-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/intel-hex/2016-03-18/intel-hex-20160318-git.tgz"; - sha256 = "0sz51qw262nh6ziwpy1kgv257nj56rp42s0g6g2rx3xv1ijdy395"; - system = "intel-hex-test"; - asd = "intel-hex-test"; - }); - systems = [ "intel-hex-test" ]; - lispLibs = [ (getAttr "intel-hex" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - intercom = (build-asdf-system { - pname = "intercom"; - version = "20130615-git"; - asds = [ "intercom" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/intercom/2013-06-15/intercom-20130615-git.tgz"; - sha256 = "017klgjsza4cxdxms4hxgrfrwjshkcr2yyxnhg14zs9w0vjwkikl"; - system = "intercom"; - asd = "intercom"; - }); - systems = [ "intercom" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "hunchentoot" self) (getAttr "jsown" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - intercom-examples = (build-asdf-system { - pname = "intercom-examples"; - version = "20130615-git"; - asds = [ "intercom-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/intercom/2013-06-15/intercom-20130615-git.tgz"; - sha256 = "017klgjsza4cxdxms4hxgrfrwjshkcr2yyxnhg14zs9w0vjwkikl"; - system = "intercom-examples"; - asd = "intercom-examples"; - }); - systems = [ "intercom-examples" ]; - lispLibs = [ (getAttr "intercom" self) (getAttr "jsown" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - interface = (build-asdf-system { - pname = "interface"; - version = "20230618-git"; - asds = [ "interface" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/interface/2023-06-18/interface-20230618-git.tgz"; - sha256 = "0h1bckhyig2znl6nrd3agjzz7knrm2kyh2vfyk7j60kzki9rpzxy"; - system = "interface"; - asd = "interface"; - }); - systems = [ "interface" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "global-vars" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - interfaces-test-implementation = (build-asdf-system { - pname = "interfaces-test-implementation"; - version = "20231021-git"; - asds = [ "interfaces-test-implementation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/modularize-interfaces/2023-10-21/modularize-interfaces-20231021-git.tgz"; - sha256 = "0lmq2jbkbr5wrrjl2qb1x64fcvl0lmii0h9301b9bq4d47s4w8sh"; - system = "interfaces-test-implementation"; - asd = "interfaces-test-implementation"; - }); - systems = [ "interfaces-test-implementation" ]; - lispLibs = [ (getAttr "modularize" self) (getAttr "modularize-interfaces" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - introspect-environment = (build-asdf-system { - pname = "introspect-environment"; - version = "20241012-git"; - asds = [ "introspect-environment" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/introspect-environment/2024-10-12/introspect-environment-20241012-git.tgz"; - sha256 = "1jll8h1fmf9i8nk3j3hrh62s858fzmly22zb690a2hnb685w3zlf"; - system = "introspect-environment"; - asd = "introspect-environment"; - }); - systems = [ "introspect-environment" ]; - lispLibs = [ ]; - meta = {}; - }); - introspect-environment-test = (build-asdf-system { - pname = "introspect-environment-test"; - version = "20241012-git"; - asds = [ "introspect-environment-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/introspect-environment/2024-10-12/introspect-environment-20241012-git.tgz"; - sha256 = "1jll8h1fmf9i8nk3j3hrh62s858fzmly22zb690a2hnb685w3zlf"; - system = "introspect-environment-test"; - asd = "introspect-environment-test"; - }); - systems = [ "introspect-environment-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "introspect-environment" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - invistra = (build-asdf-system { - pname = "invistra"; - version = "20241012-git"; - asds = [ "invistra" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/invistra/2024-10-12/invistra-20241012-git.tgz"; - sha256 = "14ja35zqa85hjl9wxkwrff2wnlfflxi6lnkw0ic7jp7b59f80qas"; - system = "invistra"; - asd = "invistra"; - }); - systems = [ "invistra" ]; - lispLibs = [ (getAttr "acclimation" self) (getAttr "incless" self) (getAttr "inravina" self) (getAttr "nontrivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - invistra-extrinsic = (build-asdf-system { - pname = "invistra-extrinsic"; - version = "20241012-git"; - asds = [ "invistra-extrinsic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/invistra/2024-10-12/invistra-20241012-git.tgz"; - sha256 = "14ja35zqa85hjl9wxkwrff2wnlfflxi6lnkw0ic7jp7b59f80qas"; - system = "invistra-extrinsic"; - asd = "invistra-extrinsic"; - }); - systems = [ "invistra-extrinsic" ]; - lispLibs = [ (getAttr "inravina-extrinsic" self) (getAttr "invistra" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - invistra-numeral = (build-asdf-system { - pname = "invistra-numeral"; - version = "20241012-git"; - asds = [ "invistra-numeral" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/invistra/2024-10-12/invistra-20241012-git.tgz"; - sha256 = "14ja35zqa85hjl9wxkwrff2wnlfflxi6lnkw0ic7jp7b59f80qas"; - system = "invistra-numeral"; - asd = "invistra-numeral"; - }); - systems = [ "invistra-numeral" ]; - lispLibs = [ (getAttr "invistra" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - iolib = (build-asdf-system { - pname = "iolib"; - version = "v0.8.4"; - asds = [ "iolib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/iolib/2021-06-30/iolib-v0.8.4.tgz"; - sha256 = "1f43jqqqwp9n7xksqxw91myapsdbc2dxck6nd6flakbnp9haylyq"; - system = "iolib"; - asd = "iolib"; - }); - systems = [ "iolib" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "idna" self) (getAttr "iolib_dot_asdf" self) (getAttr "iolib_dot_base" self) (getAttr "iolib_dot_conf" self) (getAttr "swap-bytes" self) (getAttr "trivial-features" self) ]; - meta = {}; - }); - iolib_dot_asdf = (build-asdf-system { - pname = "iolib.asdf"; - version = "v0.8.4"; - asds = [ "iolib.asdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/iolib/2021-06-30/iolib-v0.8.4.tgz"; - sha256 = "1f43jqqqwp9n7xksqxw91myapsdbc2dxck6nd6flakbnp9haylyq"; - system = "iolib.asdf"; - asd = "iolib.asdf"; - }); - systems = [ "iolib.asdf" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = {}; - }); - iolib_dot_base = (build-asdf-system { - pname = "iolib.base"; - version = "v0.8.4"; - asds = [ "iolib.base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/iolib/2021-06-30/iolib-v0.8.4.tgz"; - sha256 = "1f43jqqqwp9n7xksqxw91myapsdbc2dxck6nd6flakbnp9haylyq"; - system = "iolib.base"; - asd = "iolib.base"; - }); - systems = [ "iolib.base" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iolib_dot_asdf" self) (getAttr "iolib_dot_common-lisp" self) (getAttr "iolib_dot_conf" self) (getAttr "split-sequence" self) ]; - meta = {}; - }); - iolib_dot_common-lisp = (build-asdf-system { - pname = "iolib.common-lisp"; - version = "v0.8.4"; - asds = [ "iolib.common-lisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/iolib/2021-06-30/iolib-v0.8.4.tgz"; - sha256 = "1f43jqqqwp9n7xksqxw91myapsdbc2dxck6nd6flakbnp9haylyq"; - system = "iolib.common-lisp"; - asd = "iolib.common-lisp"; - }); - systems = [ "iolib.common-lisp" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iolib_dot_asdf" self) (getAttr "iolib_dot_conf" self) ]; - meta = {}; - }); - iolib_dot_conf = (build-asdf-system { - pname = "iolib.conf"; - version = "v0.8.4"; - asds = [ "iolib.conf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/iolib/2021-06-30/iolib-v0.8.4.tgz"; - sha256 = "1f43jqqqwp9n7xksqxw91myapsdbc2dxck6nd6flakbnp9haylyq"; - system = "iolib.conf"; - asd = "iolib.conf"; - }); - systems = [ "iolib.conf" ]; - lispLibs = [ (getAttr "iolib_dot_asdf" self) ]; - meta = {}; - }); - iolib_dot_examples = (build-asdf-system { - pname = "iolib.examples"; - version = "v0.8.4"; - asds = [ "iolib.examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/iolib/2021-06-30/iolib-v0.8.4.tgz"; - sha256 = "1f43jqqqwp9n7xksqxw91myapsdbc2dxck6nd6flakbnp9haylyq"; - system = "iolib.examples"; - asd = "iolib.examples"; - }); - systems = [ "iolib.examples" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "iolib" self) (getAttr "iolib_dot_asdf" self) (getAttr "iolib_dot_base" self) (getAttr "iolib_dot_conf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ip-interfaces = (build-asdf-system { - pname = "ip-interfaces"; - version = "0.2.1"; - asds = [ "ip-interfaces" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ip-interfaces/2018-12-10/ip-interfaces-0.2.1.tgz"; - sha256 = "035sc4li0qz4lzjn555h8r2qkhc8a65zglk30f1b3pi9p44g91mw"; - system = "ip-interfaces"; - asd = "ip-interfaces"; - }); - systems = [ "ip-interfaces" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ip-interfaces-test = (build-asdf-system { - pname = "ip-interfaces-test"; - version = "0.2.1"; - asds = [ "ip-interfaces-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ip-interfaces/2018-12-10/ip-interfaces-0.2.1.tgz"; - sha256 = "035sc4li0qz4lzjn555h8r2qkhc8a65zglk30f1b3pi9p44g91mw"; - system = "ip-interfaces-test"; - asd = "ip-interfaces-test"; - }); - systems = [ "ip-interfaces-test" ]; - lispLibs = [ (getAttr "ip-interfaces" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - irc-logger = (build-asdf-system { - pname = "irc-logger"; - version = "20150923-git"; - asds = [ "irc-logger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/irc-logger/2015-09-23/irc-logger-20150923-git.tgz"; - sha256 = "1ylq8qnf29dij7133p19cmmmw3i7w6azncsdvpd4j0k1fqp14bq7"; - system = "irc-logger"; - asd = "irc-logger"; - }); - systems = [ "irc-logger" ]; - lispLibs = [ (getAttr "cl-irc" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ironclad = (build-asdf-system { - pname = "ironclad"; - version = "v0.61"; - asds = [ "ironclad" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ironclad/2024-10-12/ironclad-v0.61.tgz"; - sha256 = "1yszjy6a0q1jvdgd7fpmnvi9851s8ivp4plscw27lbnl7jlj1pmk"; - system = "ironclad"; - asd = "ironclad"; - }); - systems = [ "ironclad" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = {}; - }); - ironclad-text = (build-asdf-system { - pname = "ironclad-text"; - version = "v0.61"; - asds = [ "ironclad-text" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ironclad/2024-10-12/ironclad-v0.61.tgz"; - sha256 = "1yszjy6a0q1jvdgd7fpmnvi9851s8ivp4plscw27lbnl7jlj1pmk"; - system = "ironclad-text"; - asd = "ironclad-text"; - }); - systems = [ "ironclad-text" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - isolated = (build-asdf-system { - pname = "isolated"; - version = "20200218-git"; - asds = [ "isolated" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-isolated/2020-02-18/cl-isolated-20200218-git.tgz"; - sha256 = "01wbis4dw2cy7d2yh30rwvmlx3dr5s9dx8hs19xhjpznjbqfyksi"; - system = "isolated"; - asd = "isolated"; - }); - systems = [ "isolated" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - issr = (build-asdf-system { - pname = "issr"; - version = "20211020-git"; - asds = [ "issr" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/hunchenissr/2021-10-20/hunchenissr-20211020-git.tgz"; - sha256 = "1dfm7zdvyj14my8giznq1vsy20nj7my71y7a657slhf6v2cap5vs"; - system = "issr"; - asd = "issr"; - }); - systems = [ "issr" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-base64" self) (getAttr "do-urlencode" self) (getAttr "hunchentoot" self) (getAttr "jonathan" self) (getAttr "plump" self) (getAttr "portal" self) (getAttr "str" self) (getAttr "trivia" self) (getAttr "trivial-garbage" self) (getAttr "yxorp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - issr-core = (build-asdf-system { - pname = "issr-core"; - version = "20210228-git"; - asds = [ "issr-core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/core/2021-02-28/core-20210228-git.tgz"; - sha256 = "1bajb09crzadkirdpd6jrpcc55irjd4sxzavygr25l85pafyhniw"; - system = "issr-core"; - asd = "issr-core"; - }); - systems = [ "issr-core" ]; - lispLibs = [ (getAttr "global-vars" self) (getAttr "plump" self) (getAttr "str" self) (getAttr "tailrec" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - iterate = (build-asdf-system { - pname = "iterate"; - version = "release-b0f9a9c6-git"; - asds = [ "iterate" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/iterate/2021-05-31/iterate-release-b0f9a9c6-git.tgz"; - sha256 = "09xq2mdr97hagjrjpc47mp8l9wfp697aa9qaqmsy0yskayzg6xsc"; - system = "iterate"; - asd = "iterate"; - }); - systems = [ "iterate" ]; - lispLibs = [ ]; - meta = {}; - }); - iterate-clsql = (build-asdf-system { - pname = "iterate-clsql"; - version = "20130312-http"; - asds = [ "iterate-clsql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/iterate-clsql/2013-03-12/iterate-clsql-20130312-http.tgz"; - sha256 = "0adfs31zin5kkg9z5kyzykf8gmcgr600vvi4mjx7nixybh326h3h"; - system = "iterate-clsql"; - asd = "iterate-clsql"; - }); - systems = [ "iterate-clsql" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ixf = (build-asdf-system { - pname = "ixf"; - version = "20180228-git"; - asds = [ "ixf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-ixf/2018-02-28/cl-ixf-20180228-git.tgz"; - sha256 = "1wjdnf4vr9z7lcfc49kl43g6l2i23q9n81siy494k17d766cdvqa"; - system = "ixf"; - asd = "ixf"; - }); - systems = [ "ixf" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-ppcre" self) (getAttr "ieee-floats" self) (getAttr "local-time" self) (getAttr "md5" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jenkins_dot_api = (build-asdf-system { - pname = "jenkins.api"; - version = "20130312-git"; - asds = [ "jenkins.api" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jenkins/2013-03-12/jenkins-20130312-git.tgz"; - sha256 = "1kis95k3fwlaq2jbpia0wps4gq461w6p57dxlbvb0c6a5dgh4dwf"; - system = "jenkins.api"; - asd = "jenkins.api"; - }); - systems = [ "jenkins.api" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "drakma" self) (getAttr "iterate" self) (getAttr "let-plus" self) (getAttr "more-conditions" self) (getAttr "puri" self) (getAttr "split-sequence" self) (getAttr "xml_dot_location" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingle = (build-asdf-system { - pname = "jingle"; - version = "20231021-git"; - asds = [ "jingle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-jingle/2023-10-21/cl-jingle-20231021-git.tgz"; - sha256 = "0g64y9nzkdrb2yjp0lvhfc0qm3595n6w76hk9hd1v0ril78vzybc"; - system = "jingle"; - asd = "jingle"; - }); - systems = [ "jingle" ]; - lispLibs = [ (getAttr "cl-reexport" self) (getAttr "clack" self) (getAttr "find-port" self) (getAttr "jonathan" self) (getAttr "lack" self) (getAttr "lack-app-directory" self) (getAttr "lack-middleware-mount" self) (getAttr "lack-middleware-static" self) (getAttr "local-time" self) (getAttr "myway" self) (getAttr "ningle" self) (getAttr "quri" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingle_dot_demo = (build-asdf-system { - pname = "jingle.demo"; - version = "20231021-git"; - asds = [ "jingle.demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-jingle/2023-10-21/cl-jingle-20231021-git.tgz"; - sha256 = "0g64y9nzkdrb2yjp0lvhfc0qm3595n6w76hk9hd1v0ril78vzybc"; - system = "jingle.demo"; - asd = "jingle.demo"; - }); - systems = [ "jingle.demo" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-ascii-table" self) (getAttr "clack-handler-hunchentoot" self) (getAttr "clingon" self) (getAttr "dexador" self) (getAttr "jingle" self) (getAttr "jonathan" self) (getAttr "lack-middleware-accesslog" self) (getAttr "local-time" self) (getAttr "quri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingle_dot_demo_dot_test = (build-asdf-system { - pname = "jingle.demo.test"; - version = "20231021-git"; - asds = [ "jingle.demo.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-jingle/2023-10-21/cl-jingle-20231021-git.tgz"; - sha256 = "0g64y9nzkdrb2yjp0lvhfc0qm3595n6w76hk9hd1v0ril78vzybc"; - system = "jingle.demo.test"; - asd = "jingle.demo.test"; - }); - systems = [ "jingle.demo.test" ]; - lispLibs = [ (getAttr "jingle_dot_demo" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingle_dot_test = (build-asdf-system { - pname = "jingle.test"; - version = "20231021-git"; - asds = [ "jingle.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-jingle/2023-10-21/cl-jingle-20231021-git.tgz"; - sha256 = "0g64y9nzkdrb2yjp0lvhfc0qm3595n6w76hk9hd1v0ril78vzybc"; - system = "jingle.test"; - asd = "jingle.test"; - }); - systems = [ "jingle.test" ]; - lispLibs = [ (getAttr "jingle" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh = (build-asdf-system { - pname = "jingoh"; - version = "20220707-git"; - asds = [ "jingoh" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh"; - asd = "jingoh"; - }); - systems = [ "jingoh" ]; - lispLibs = [ (getAttr "jingoh_dot_examiner" self) (getAttr "jingoh_dot_org" self) (getAttr "jingoh_dot_reader" self) (getAttr "jingoh_dot_tester" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_documentizer = (build-asdf-system { - pname = "jingoh.documentizer"; - version = "20220707-git"; - asds = [ "jingoh.documentizer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.documentizer"; - asd = "jingoh.documentizer"; - }); - systems = [ "jingoh.documentizer" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "_3bmd-ext-code-blocks" self) (getAttr "cl-ppcre" self) (getAttr "eclector" self) (getAttr "read-as-string" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_documentizer_dot_test = (build-asdf-system { - pname = "jingoh.documentizer.test"; - version = "20220707-git"; - asds = [ "jingoh.documentizer.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.documentizer.test"; - asd = "jingoh.documentizer.test"; - }); - systems = [ "jingoh.documentizer.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "jingoh_dot_documentizer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_examiner = (build-asdf-system { - pname = "jingoh.examiner"; - version = "20220707-git"; - asds = [ "jingoh.examiner" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.examiner"; - asd = "jingoh.examiner"; - }); - systems = [ "jingoh.examiner" ]; - lispLibs = [ (getAttr "cl-ansi-text" self) (getAttr "jingoh_dot_documentizer" self) (getAttr "jingoh_dot_org" self) (getAttr "jingoh_dot_tester" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_examiner_dot_test = (build-asdf-system { - pname = "jingoh.examiner.test"; - version = "20220707-git"; - asds = [ "jingoh.examiner.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.examiner.test"; - asd = "jingoh.examiner.test"; - }); - systems = [ "jingoh.examiner.test" ]; - lispLibs = [ (getAttr "cl-ansi-text" self) (getAttr "jingoh" self) (getAttr "jingoh_dot_examiner" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_generator = (build-asdf-system { - pname = "jingoh.generator"; - version = "20220707-git"; - asds = [ "jingoh.generator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.generator"; - asd = "jingoh.generator"; - }); - systems = [ "jingoh.generator" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-unification" self) (getAttr "closer-mop" self) (getAttr "jingoh_dot_documentizer" self) (getAttr "lambda-fiddle" self) (getAttr "millet" self) (getAttr "named-readtables" self) (getAttr "prompt-for" self) (getAttr "trivial-cltl2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_generator_dot_test = (build-asdf-system { - pname = "jingoh.generator.test"; - version = "20220707-git"; - asds = [ "jingoh.generator.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.generator.test"; - asd = "jingoh.generator.test"; - }); - systems = [ "jingoh.generator.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "jingoh_dot_generator" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_org = (build-asdf-system { - pname = "jingoh.org"; - version = "20220707-git"; - asds = [ "jingoh.org" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.org"; - asd = "jingoh.org"; - }); - systems = [ "jingoh.org" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "check-bnf" self) (getAttr "jingoh_dot_documentizer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_org_dot_test = (build-asdf-system { - pname = "jingoh.org.test"; - version = "20220707-git"; - asds = [ "jingoh.org.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.org.test"; - asd = "jingoh.org.test"; - }); - systems = [ "jingoh.org.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "jingoh_dot_org" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_parallel = (build-asdf-system { - pname = "jingoh.parallel"; - version = "20220707-git"; - asds = [ "jingoh.parallel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.parallel"; - asd = "jingoh.parallel"; - }); - systems = [ "jingoh.parallel" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-cpus" self) (getAttr "jingoh" self) (getAttr "lparallel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_parallel_dot_test = (build-asdf-system { - pname = "jingoh.parallel.test"; - version = "20220707-git"; - asds = [ "jingoh.parallel.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.parallel.test"; - asd = "jingoh.parallel.test"; - }); - systems = [ "jingoh.parallel.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "jingoh_dot_parallel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_reader = (build-asdf-system { - pname = "jingoh.reader"; - version = "20220707-git"; - asds = [ "jingoh.reader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.reader"; - asd = "jingoh.reader"; - }); - systems = [ "jingoh.reader" ]; - lispLibs = [ (getAttr "eclector" self) (getAttr "jingoh_dot_documentizer" self) (getAttr "jingoh_dot_tester" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_reader_dot_test = (build-asdf-system { - pname = "jingoh.reader.test"; - version = "20220707-git"; - asds = [ "jingoh.reader.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.reader.test"; - asd = "jingoh.reader.test"; - }); - systems = [ "jingoh.reader.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "jingoh_dot_reader" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_tester = (build-asdf-system { - pname = "jingoh.tester"; - version = "20220707-git"; - asds = [ "jingoh.tester" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.tester"; - asd = "jingoh.tester"; - }); - systems = [ "jingoh.tester" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "check-bnf" self) (getAttr "cl-ansi-text" self) (getAttr "cl-colors2" self) (getAttr "closer-mop" self) (getAttr "fuzzy-match" self) (getAttr "jingoh_dot_documentizer" self) (getAttr "jingoh_dot_org" self) (getAttr "structure-ext" self) (getAttr "vivid-colors" self) (getAttr "vivid-diff" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jingoh_dot_tester_dot_test = (build-asdf-system { - pname = "jingoh.tester.test"; - version = "20220707-git"; - asds = [ "jingoh.tester.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; - sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; - system = "jingoh.tester.test"; - asd = "jingoh.tester.test"; - }); - systems = [ "jingoh.tester.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "jingoh_dot_tester" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jonathan = (build-asdf-system { - pname = "jonathan"; - version = "20200925-git"; - asds = [ "jonathan" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jonathan/2020-09-25/jonathan-20200925-git.tgz"; - sha256 = "1l4sfxfmijibsvkbszikzslw1yy8z52ml9may1w2s0ay7lg7rsng"; - system = "jonathan"; - asd = "jonathan"; - }); - systems = [ "jonathan" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-annot" self) (getAttr "cl-ppcre" self) (getAttr "cl-syntax" self) (getAttr "cl-syntax-annot" self) (getAttr "fast-io" self) (getAttr "proc-parse" self) (getAttr "trivial-types" self) ]; - meta = {}; - }); - jonathan-test = (build-asdf-system { - pname = "jonathan-test"; - version = "20200925-git"; - asds = [ "jonathan-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jonathan/2020-09-25/jonathan-20200925-git.tgz"; - sha256 = "1l4sfxfmijibsvkbszikzslw1yy8z52ml9may1w2s0ay7lg7rsng"; - system = "jonathan-test"; - asd = "jonathan-test"; - }); - systems = [ "jonathan-test" ]; - lispLibs = [ (getAttr "jonathan" self) (getAttr "legion" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jose = (build-asdf-system { - pname = "jose"; - version = "20241012-git"; - asds = [ "jose" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jose/2024-10-12/jose-20241012-git.tgz"; - sha256 = "1z7xjy4ihxa8ay5vznhnxkjflfx6xmfpgwxdakk9wmkw30p2yn4h"; - system = "jose"; - asd = "jose"; - }); - systems = [ "jose" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "assoc-utils" self) (getAttr "cl-base64" self) (getAttr "ironclad" self) (getAttr "jonathan" self) (getAttr "split-sequence" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - journal = (build-asdf-system { - pname = "journal"; - version = "20231021-git"; - asds = [ "journal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/journal/2023-10-21/journal-20231021-git.tgz"; - sha256 = "0h55mi3n0cwsl3gb9v7xsl9jzq0x5fbv2s8a0haby7g9995jr98v"; - system = "journal"; - asd = "journal"; - }); - systems = [ "journal" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "local-time" self) (getAttr "mgl-pax" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jp-numeral = (build-asdf-system { - pname = "jp-numeral"; - version = "20221106-git"; - asds = [ "jp-numeral" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jp-numeral/2022-11-06/jp-numeral-20221106-git.tgz"; - sha256 = "1xqvah6mjd8lb2n19wzsn29q6az9kx1c48js3yj0ij73kjncby30"; - system = "jp-numeral"; - asd = "jp-numeral"; - }); - systems = [ "jp-numeral" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jp-numeral-test = (build-asdf-system { - pname = "jp-numeral-test"; - version = "20221106-git"; - asds = [ "jp-numeral-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jp-numeral/2022-11-06/jp-numeral-20221106-git.tgz"; - sha256 = "1xqvah6mjd8lb2n19wzsn29q6az9kx1c48js3yj0ij73kjncby30"; - system = "jp-numeral-test"; - asd = "jp-numeral-test"; - }); - systems = [ "jp-numeral-test" ]; - lispLibs = [ (getAttr "_1am" self) (getAttr "alexandria" self) (getAttr "jp-numeral" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jpeg-turbo = (build-asdf-system { - pname = "jpeg-turbo"; - version = "20201220-git"; - asds = [ "jpeg-turbo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jpeg-turbo/2020-12-20/jpeg-turbo-20201220-git.tgz"; - sha256 = "1andd1ibbk3224idnpsnrn96flr5d1wm9ja3di57fs04wn577sag"; - system = "jpeg-turbo"; - asd = "jpeg-turbo"; - }); - systems = [ "jpeg-turbo" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jpl-queues = (build-asdf-system { - pname = "jpl-queues"; - version = "0.1"; - asds = [ "jpl-queues" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jpl-queues/2010-10-06/jpl-queues-0.1.tgz"; - sha256 = "1xgddsfa1gr0cjmdlc304j3msxi8w2fyk9i497x56kmkif7pkj88"; - system = "jpl-queues"; - asd = "jpl-queues"; - }); - systems = [ "jpl-queues" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "jpl-util" self) ]; - meta = {}; - }); - jpl-util = (build-asdf-system { - pname = "jpl-util"; - version = "20151031-git"; - asds = [ "jpl-util" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-jpl-util/2015-10-31/cl-jpl-util-20151031-git.tgz"; - sha256 = "0nc0rk9n8grkg3045xsw34whmcmddn2sfrxki4268g7kpgz0d2yz"; - system = "jpl-util"; - asd = "jpl-util"; - }); - systems = [ "jpl-util" ]; - lispLibs = [ ]; - meta = {}; - }); - js-parser = (build-asdf-system { - pname = "js-parser"; - version = "20150407-git"; - asds = [ "js-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/js-parser/2015-04-07/js-parser-20150407-git.tgz"; - sha256 = "0hqw515vyhrv1as5sfn3l792ddjps85zbzpblr2cjyq9dmdrg89a"; - system = "js-parser"; - asd = "js-parser"; - }); - systems = [ "js-parser" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - js-parser-tests = (build-asdf-system { - pname = "js-parser-tests"; - version = "20150407-git"; - asds = [ "js-parser-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/js-parser/2015-04-07/js-parser-20150407-git.tgz"; - sha256 = "0hqw515vyhrv1as5sfn3l792ddjps85zbzpblr2cjyq9dmdrg89a"; - system = "js-parser-tests"; - asd = "js-parser-tests"; - }); - systems = [ "js-parser-tests" ]; - lispLibs = [ (getAttr "js-parser" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - json-lib = (build-asdf-system { - pname = "json-lib"; - version = "20230618-git"; - asds = [ "json-lib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/json-lib/2023-06-18/json-lib-20230618-git.tgz"; - sha256 = "08cbnj6h53ifwm6kk5pvpxmy2a11kiph9zjccd2ml3fj6257krpv"; - system = "json-lib"; - asd = "json-lib"; - }); - systems = [ "json-lib" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-fad" self) (getAttr "parse-float" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - json-mop = (build-asdf-system { - pname = "json-mop"; - version = "20241012-git"; - asds = [ "json-mop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/json-mop/2024-10-12/json-mop-20241012-git.tgz"; - sha256 = "1q6mmq64hf4v448bnzfh8nxsxg5h18a9snh785r1fnvv1aij3fi1"; - system = "json-mop"; - asd = "json-mop"; - }); - systems = [ "json-mop" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "closer-mop" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - json-mop-tests = (build-asdf-system { - pname = "json-mop-tests"; - version = "20241012-git"; - asds = [ "json-mop-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/json-mop/2024-10-12/json-mop-20241012-git.tgz"; - sha256 = "1q6mmq64hf4v448bnzfh8nxsxg5h18a9snh785r1fnvv1aij3fi1"; - system = "json-mop-tests"; - asd = "json-mop-tests"; - }); - systems = [ "json-mop-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "json-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - json-responses = (build-asdf-system { - pname = "json-responses"; - version = "20190307-hg"; - asds = [ "json-responses" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/json-responses/2019-03-07/json-responses-20190307-hg.tgz"; - sha256 = "0f1hrs3rhi6qn0r8qd3fbsknn417b8v8b4s4989yfwfvnf922g05"; - system = "json-responses"; - asd = "json-responses"; - }); - systems = [ "json-responses" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - json-responses-test = (build-asdf-system { - pname = "json-responses-test"; - version = "20190307-hg"; - asds = [ "json-responses-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/json-responses/2019-03-07/json-responses-20190307-hg.tgz"; - sha256 = "0f1hrs3rhi6qn0r8qd3fbsknn417b8v8b4s4989yfwfvnf922g05"; - system = "json-responses-test"; - asd = "json-responses"; - }); - systems = [ "json-responses-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "json-responses" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - json-schema = (build-asdf-system { - pname = "json-schema"; - version = "20221106-git"; - asds = [ "json-schema" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/json-schema/2022-11-06/json-schema-20221106-git.tgz"; - sha256 = "11rgnj14p8x059zx8hs02jji1p69v8kix783vf557zpcbydrw2mn"; - system = "json-schema"; - asd = "json-schema"; - }); - systems = [ "json-schema" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "arrows" self) (getAttr "cl-ppcre" self) (getAttr "dexador" self) (getAttr "function-cache" self) (getAttr "local-time" self) (getAttr "local-time-duration" self) (getAttr "quri" self) (getAttr "sanity-clause" self) (getAttr "st-json" self) (getAttr "str" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - json-streams = (build-asdf-system { - pname = "json-streams"; - version = "20171019-git"; - asds = [ "json-streams" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/json-streams/2017-10-19/json-streams-20171019-git.tgz"; - sha256 = "0cia3721im04q73dfkd688d8splgpz03qa4h8s3r39kar4w3xll2"; - system = "json-streams"; - asd = "json-streams"; - }); - systems = [ "json-streams" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - json-streams-tests = (build-asdf-system { - pname = "json-streams-tests"; - version = "20171019-git"; - asds = [ "json-streams-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/json-streams/2017-10-19/json-streams-20171019-git.tgz"; - sha256 = "0cia3721im04q73dfkd688d8splgpz03qa4h8s3r39kar4w3xll2"; - system = "json-streams-tests"; - asd = "json-streams-tests"; - }); - systems = [ "json-streams-tests" ]; - lispLibs = [ (getAttr "cl-quickcheck" self) (getAttr "flexi-streams" self) (getAttr "json-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - json-test-suite = (build-asdf-system { - pname = "json-test-suite"; - version = "20230618-git"; - asds = [ "json-test-suite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rs-json/2023-06-18/rs-json-20230618-git.tgz"; - sha256 = "0y71as0sg5vfijpzdhv6pj6yv064ldn2shx0y4da8kvaqv949dnq"; - system = "json-test-suite"; - asd = "json-test-suite"; - }); - systems = [ "json-test-suite" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jsonrpc = (build-asdf-system { - pname = "jsonrpc"; - version = "20241012-git"; - asds = [ "jsonrpc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jsonrpc/2024-10-12/jsonrpc-20241012-git.tgz"; - sha256 = "1wsc6bv8xpzad0lgrlldzrpb9r4aksnw7ss2ifwa7ykbzfxcr8gi"; - system = "jsonrpc"; - asd = "jsonrpc"; - }); - systems = [ "jsonrpc" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "chanl" self) (getAttr "dissect" self) (getAttr "trivial-timeout" self) (getAttr "usocket" self) (getAttr "vom" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jsown = (build-asdf-system { - pname = "jsown"; - version = "20200218-git"; - asds = [ "jsown" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jsown/2020-02-18/jsown-20200218-git.tgz"; - sha256 = "0gadvmf1d9bq35s61z76psrsnzwwk12svi66jigf491hv48wigw7"; - system = "jsown"; - asd = "jsown"; - }); - systems = [ "jsown" ]; - lispLibs = [ ]; - meta = {}; - }); - jsown-tests = (build-asdf-system { - pname = "jsown-tests"; - version = "20200218-git"; - asds = [ "jsown-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jsown/2020-02-18/jsown-20200218-git.tgz"; - sha256 = "0gadvmf1d9bq35s61z76psrsnzwwk12svi66jigf491hv48wigw7"; - system = "jsown-tests"; - asd = "jsown-tests"; - }); - systems = [ "jsown-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "jsown" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jsown-utils = (build-asdf-system { - pname = "jsown-utils"; - version = "20220707-git"; - asds = [ "jsown-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jsown-utils/2022-07-07/jsown-utils-20220707-git.tgz"; - sha256 = "046a18fywkim0jbnpls5zqdv65j1kwl268p4dbdd2dxgx050fwak"; - system = "jsown-utils"; - asd = "jsown-utils"; - }); - systems = [ "jsown-utils" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "jsown" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jupyter-lab-extension = (build-asdf-system { - pname = "jupyter-lab-extension"; - version = "20241012-git"; - asds = [ "jupyter-lab-extension" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/common-lisp-jupyter/2024-10-12/common-lisp-jupyter-20241012-git.tgz"; - sha256 = "1qbrzv0myxfxq7rzm2y9cm2xymkl982982h2kbsl7d1yd5hrjvl6"; - system = "jupyter-lab-extension"; - asd = "jupyter-lab-extension"; - }); - systems = [ "jupyter-lab-extension" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - just-getopt-parser = (build-asdf-system { - pname = "just-getopt-parser"; - version = "20211209-git"; - asds = [ "just-getopt-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-just-getopt-parser/2021-12-09/cl-just-getopt-parser-20211209-git.tgz"; - sha256 = "0ngh8b51ngh3bqacl40j6wwiinhwxswsy02d9k7qlzv9sbjxay4s"; - system = "just-getopt-parser"; - asd = "just-getopt-parser"; - }); - systems = [ "just-getopt-parser" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jwacs = (build-asdf-system { - pname = "jwacs"; - version = "20180228-git"; - asds = [ "jwacs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jwacs/2018-02-28/jwacs-20180228-git.tgz"; - sha256 = "1wzln3bjjmdv040i339dsm48a1sc2cnwhh4z066x2wkl5ka7j5b2"; - system = "jwacs"; - asd = "jwacs"; - }); - systems = [ "jwacs" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - jwacs-tests = (build-asdf-system { - pname = "jwacs-tests"; - version = "20180228-git"; - asds = [ "jwacs-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/jwacs/2018-02-28/jwacs-20180228-git.tgz"; - sha256 = "1wzln3bjjmdv040i339dsm48a1sc2cnwhh4z066x2wkl5ka7j5b2"; - system = "jwacs-tests"; - asd = "jwacs-tests"; - }); - systems = [ "jwacs-tests" ]; - lispLibs = [ (getAttr "jwacs" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - kanren-trs = (build-asdf-system { - pname = "kanren-trs"; - version = "20120305-svn"; - asds = [ "kanren-trs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-kanren-trs/2012-03-05/cl-kanren-trs-20120305-svn.tgz"; - sha256 = "1r9xyickdkkqcaa7abvks4hqwjb7s95lcrym026c1w6ciibiypr7"; - system = "kanren-trs"; - asd = "kanren-trs"; - }); - systems = [ "kanren-trs" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - kanren-trs-test = (build-asdf-system { - pname = "kanren-trs-test"; - version = "20120305-svn"; - asds = [ "kanren-trs-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-kanren-trs/2012-03-05/cl-kanren-trs-20120305-svn.tgz"; - sha256 = "1r9xyickdkkqcaa7abvks4hqwjb7s95lcrym026c1w6ciibiypr7"; - system = "kanren-trs-test"; - asd = "kanren-trs-test"; - }); - systems = [ "kanren-trs-test" ]; - lispLibs = [ (getAttr "kanren-trs" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - kaputt = (build-asdf-system { - pname = "kaputt"; - version = "20221106-git"; - asds = [ "kaputt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-kaputt/2022-11-06/cl-kaputt-20221106-git.tgz"; - sha256 = "1jd9lmdzkjm6mawsxczg6czyv7zbmaplq0ikmda0ysh4aq3apnnj"; - system = "kaputt"; - asd = "kaputt"; - }); - systems = [ "kaputt" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - kdl = (build-asdf-system { - pname = "kdl"; - version = "20230618-git"; - asds = [ "kdl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/kdlcl/2023-06-18/kdlcl-20230618-git.tgz"; - sha256 = "0bqqxkd6s420ld2hmhvbbvpzss0m2kimmxaqhz7j1ksmq86bvvmj"; - system = "kdl"; - asd = "kdl"; - }); - systems = [ "kdl" ]; - lispLibs = [ (getAttr "esrap" self) (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - kdtree-jk = (build-asdf-system { - pname = "kdtree-jk"; - version = "20230618-git"; - asds = [ "kdtree-jk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/kdtree-jk/2023-06-18/kdtree-jk-20230618-git.tgz"; - sha256 = "0l311lmwp4sminl0k534s1kvfwmlk56bfnj7367zd7jl0hvs06ck"; - system = "kdtree-jk"; - asd = "kdtree-jk"; - }); - systems = [ "kdtree-jk" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - kebab = (build-asdf-system { - pname = "kebab"; - version = "20150608-git"; - asds = [ "kebab" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/kebab/2015-06-08/kebab-20150608-git.tgz"; - sha256 = "0j5haabnvj0vz0rx9mwyfsb3qzpga9nickbjw8xs6vypkdzlqv1b"; - system = "kebab"; - asd = "kebab"; - }); - systems = [ "kebab" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - kebab-test = (build-asdf-system { - pname = "kebab-test"; - version = "20150608-git"; - asds = [ "kebab-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/kebab/2015-06-08/kebab-20150608-git.tgz"; - sha256 = "0j5haabnvj0vz0rx9mwyfsb3qzpga9nickbjw8xs6vypkdzlqv1b"; - system = "kebab-test"; - asd = "kebab-test"; - }); - systems = [ "kebab-test" ]; - lispLibs = [ (getAttr "kebab" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - kekule-clj = (build-asdf-system { - pname = "kekule-clj"; - version = "20231021-git"; - asds = [ "kekule-clj" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/kekule-clj/2023-10-21/kekule-clj-20231021-git.tgz"; - sha256 = "1901b11ilknd4gy7r5b00yq6syb6qsh0xalkdw4g0dqzvqqxnfj5"; - system = "kekule-clj"; - asd = "kekule-clj"; - }); - systems = [ "kekule-clj" ]; - lispLibs = [ (getAttr "common-lisp-jupyter" self) (getAttr "jupyter-lab-extension" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - kenzo = (build-asdf-system { - pname = "kenzo"; - version = "20200325-git"; - asds = [ "kenzo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/kenzo/2020-03-25/kenzo-20200325-git.tgz"; - sha256 = "0dg70p5pxvx2ksr66z3p2nkxxwkjd852pkckr15j6cwfaji9fr8r"; - system = "kenzo"; - asd = "kenzo"; - }); - systems = [ "kenzo" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - kenzo-test = (build-asdf-system { - pname = "kenzo-test"; - version = "20200325-git"; - asds = [ "kenzo-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/kenzo/2020-03-25/kenzo-20200325-git.tgz"; - sha256 = "0dg70p5pxvx2ksr66z3p2nkxxwkjd852pkckr15j6cwfaji9fr8r"; - system = "kenzo-test"; - asd = "kenzo-test"; - }); - systems = [ "kenzo-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "kenzo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - keystone = (build-asdf-system { - pname = "keystone"; - version = "20200427-git"; - asds = [ "keystone" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/keystone/2020-04-27/keystone-20200427-git.tgz"; - sha256 = "04fczbkihf87qyp9f1sv45h69xrvdmcmxkv4m868q8zqw6z48hlj"; - system = "keystone"; - asd = "keystone"; - }); - systems = [ "keystone" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "gt" self) (getAttr "static-vectors" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - khazern = (build-asdf-system { - pname = "khazern"; - version = "20241012-git"; - asds = [ "khazern" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/khazern/2024-10-12/khazern-20241012-git.tgz"; - sha256 = "1kc15gc0kahp8w9qfyb4yr1gnwqhk8dcvi5gm678bsnbqipaj30h"; - system = "khazern"; - asd = "khazern"; - }); - systems = [ "khazern" ]; - lispLibs = [ (getAttr "acclimation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - khazern-extrinsic = (build-asdf-system { - pname = "khazern-extrinsic"; - version = "20241012-git"; - asds = [ "khazern-extrinsic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/khazern/2024-10-12/khazern-20241012-git.tgz"; - sha256 = "1kc15gc0kahp8w9qfyb4yr1gnwqhk8dcvi5gm678bsnbqipaj30h"; - system = "khazern-extrinsic"; - asd = "khazern-extrinsic"; - }); - systems = [ "khazern-extrinsic" ]; - lispLibs = [ (getAttr "khazern" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - khazern-intrinsic = (build-asdf-system { - pname = "khazern-intrinsic"; - version = "20241012-git"; - asds = [ "khazern-intrinsic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/khazern/2024-10-12/khazern-20241012-git.tgz"; - sha256 = "1kc15gc0kahp8w9qfyb4yr1gnwqhk8dcvi5gm678bsnbqipaj30h"; - system = "khazern-intrinsic"; - asd = "khazern-intrinsic"; - }); - systems = [ "khazern-intrinsic" ]; - lispLibs = [ (getAttr "khazern" self) (getAttr "trivial-package-locks" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - khazern-sequence = (build-asdf-system { - pname = "khazern-sequence"; - version = "20241012-git"; - asds = [ "khazern-sequence" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/khazern/2024-10-12/khazern-20241012-git.tgz"; - sha256 = "1kc15gc0kahp8w9qfyb4yr1gnwqhk8dcvi5gm678bsnbqipaj30h"; - system = "khazern-sequence"; - asd = "khazern-sequence"; - }); - systems = [ "khazern-sequence" ]; - lispLibs = [ (getAttr "khazern" self) (getAttr "trivial-extensible-sequences" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - khazern-sequence-extrinsic = (build-asdf-system { - pname = "khazern-sequence-extrinsic"; - version = "20241012-git"; - asds = [ "khazern-sequence-extrinsic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/khazern/2024-10-12/khazern-20241012-git.tgz"; - sha256 = "1kc15gc0kahp8w9qfyb4yr1gnwqhk8dcvi5gm678bsnbqipaj30h"; - system = "khazern-sequence-extrinsic"; - asd = "khazern-sequence-extrinsic"; - }); - systems = [ "khazern-sequence-extrinsic" ]; - lispLibs = [ (getAttr "khazern-extrinsic" self) (getAttr "khazern-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - khazern-sequence-intrinsic = (build-asdf-system { - pname = "khazern-sequence-intrinsic"; - version = "20241012-git"; - asds = [ "khazern-sequence-intrinsic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/khazern/2024-10-12/khazern-20241012-git.tgz"; - sha256 = "1kc15gc0kahp8w9qfyb4yr1gnwqhk8dcvi5gm678bsnbqipaj30h"; - system = "khazern-sequence-intrinsic"; - asd = "khazern-sequence-intrinsic"; - }); - systems = [ "khazern-sequence-intrinsic" ]; - lispLibs = [ (getAttr "khazern-intrinsic" self) (getAttr "khazern-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - kl-verify = (build-asdf-system { - pname = "kl-verify"; - version = "20120909-git"; - asds = [ "kl-verify" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/kl-verify/2012-09-09/kl-verify-20120909-git.tgz"; - sha256 = "1m5jyvvfb24idw0xzi92diyrygmq638dwxg0sl247yyvmwsqb8yj"; - system = "kl-verify"; - asd = "kl-verify"; - }); - systems = [ "kl-verify" ]; - lispLibs = [ (getAttr "image" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - km = (build-asdf-system { - pname = "km"; - version = "2-5-33"; - asds = [ "km" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/km/2011-05-22/km-2-5-33.tgz"; - sha256 = "0vl4g7vg20l14xc1b5g1d0scak6ck5028q5s5c75pr8fp15m7wyb"; - system = "km"; - asd = "km"; - }); - systems = [ "km" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - kmrcl = (build-asdf-system { - pname = "kmrcl"; - version = "20201016-git"; - asds = [ "kmrcl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/kmrcl/2020-10-16/kmrcl-20201016-git.tgz"; - sha256 = "06gx04mah5nc8w78s0j8628divbf1s5w7af8w7pvzb2d5mgvrbd2"; - system = "kmrcl"; - asd = "kmrcl"; - }); - systems = [ "kmrcl" ]; - lispLibs = [ ]; - meta = {}; - }); - knx-conn = (build-asdf-system { - pname = "knx-conn"; - version = "20241012-git"; - asds = [ "knx-conn" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/knx-conn/2024-10-12/knx-conn-20241012-git.tgz"; - sha256 = "1zq716fr1mq096hbpndfawyi1a7pr6gsyxnv2g1b00vpgyf37c4r"; - system = "knx-conn"; - asd = "knx-conn"; - }); - systems = [ "knx-conn" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "binding-arrows" self) (getAttr "local-time" self) (getAttr "log4cl" self) (getAttr "sento" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - l-math = (build-asdf-system { - pname = "l-math"; - version = "20190307-git"; - asds = [ "l-math" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/l-math/2019-03-07/l-math-20190307-git.tgz"; - sha256 = "12nhj1hrvgvmichrjf46fi0f1lzrjajw7k9i1f6qycnnqw45qan1"; - system = "l-math"; - asd = "l-math"; - }); - systems = [ "l-math" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - l-system = (build-asdf-system { - pname = "l-system"; - version = "20180228-git"; - asds = [ "l-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/l-system/2018-02-28/l-system-20180228-git.tgz"; - sha256 = "1zvd90s7y936bx7sirc38vs8r2rs62064ndj06ahrc38vagv4qwd"; - system = "l-system"; - asd = "l-system"; - }); - systems = [ "l-system" ]; - lispLibs = [ (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - l-system-examples = (build-asdf-system { - pname = "l-system-examples"; - version = "20180228-git"; - asds = [ "l-system-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/l-system/2018-02-28/l-system-20180228-git.tgz"; - sha256 = "1zvd90s7y936bx7sirc38vs8r2rs62064ndj06ahrc38vagv4qwd"; - system = "l-system-examples"; - asd = "l-system-examples"; - }); - systems = [ "l-system-examples" ]; - lispLibs = [ (getAttr "l-system" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - laap = (build-asdf-system { - pname = "laap"; - version = "20170830-git"; - asds = [ "laap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/laap/2017-08-30/laap-20170830-git.tgz"; - sha256 = "0rzjdi4qcv2l99mk4bk94xlpfx1mav0kvd7crpax7dx4dfwkq8k5"; - system = "laap"; - asd = "laap"; - }); - systems = [ "laap" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cl-base32" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack = (build-asdf-system { - pname = "lack"; - version = "20241012-git"; - asds = [ "lack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack"; - asd = "lack"; - }); - systems = [ "lack" ]; - lispLibs = [ (getAttr "lack-component" self) (getAttr "lack-util" self) ]; - meta = {}; - }); - lack-app-directory = (build-asdf-system { - pname = "lack-app-directory"; - version = "20241012-git"; - asds = [ "lack-app-directory" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-app-directory"; - asd = "lack-app-directory"; - }); - systems = [ "lack-app-directory" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "lack-app-file" self) (getAttr "quri" self) (getAttr "trivial-mimes" self) (getAttr "trivial-rfc-1123" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-app-file = (build-asdf-system { - pname = "lack-app-file"; - version = "20241012-git"; - asds = [ "lack-app-file" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-app-file"; - asd = "lack-app-file"; - }); - systems = [ "lack-app-file" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "lack-component" self) (getAttr "trivial-mimes" self) (getAttr "trivial-rfc-1123" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-component = (build-asdf-system { - pname = "lack-component"; - version = "20241012-git"; - asds = [ "lack-component" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-component"; - asd = "lack-component"; - }); - systems = [ "lack-component" ]; - lispLibs = [ ]; - meta = {}; - }); - lack-middleware-accesslog = (build-asdf-system { - pname = "lack-middleware-accesslog"; - version = "20241012-git"; - asds = [ "lack-middleware-accesslog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-middleware-accesslog"; - asd = "lack-middleware-accesslog"; - }); - systems = [ "lack-middleware-accesslog" ]; - lispLibs = [ (getAttr "lack-util" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-middleware-anypool = (build-asdf-system { - pname = "lack-middleware-anypool"; - version = "20241012-git"; - asds = [ "lack-middleware-anypool" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/anypool/2024-10-12/anypool-20241012-git.tgz"; - sha256 = "1ffssc5fzh7gj0z94xxfb3mk5cwja65lrhxyfgib15a6yxqf1kk1"; - system = "lack-middleware-anypool"; - asd = "lack-middleware-anypool"; - }); - systems = [ "lack-middleware-anypool" ]; - lispLibs = [ (getAttr "anypool" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-middleware-auth-basic = (build-asdf-system { - pname = "lack-middleware-auth-basic"; - version = "20241012-git"; - asds = [ "lack-middleware-auth-basic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-middleware-auth-basic"; - asd = "lack-middleware-auth-basic"; - }); - systems = [ "lack-middleware-auth-basic" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-middleware-backtrace = (build-asdf-system { - pname = "lack-middleware-backtrace"; - version = "20241012-git"; - asds = [ "lack-middleware-backtrace" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-middleware-backtrace"; - asd = "lack-middleware-backtrace"; - }); - systems = [ "lack-middleware-backtrace" ]; - lispLibs = [ ]; - meta = {}; - }); - lack-middleware-clack-errors = (build-asdf-system { - pname = "lack-middleware-clack-errors"; - version = "20190813-git"; - asds = [ "lack-middleware-clack-errors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack-errors/2019-08-13/clack-errors-20190813-git.tgz"; - sha256 = "0z6jyn37phnpq02l5wml8z0593g8ps95c0c2lzkhi3is2wcj9cpf"; - system = "lack-middleware-clack-errors"; - asd = "lack-middleware-clack-errors"; - }); - systems = [ "lack-middleware-clack-errors" ]; - lispLibs = [ (getAttr "clack-errors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-middleware-csrf = (build-asdf-system { - pname = "lack-middleware-csrf"; - version = "20241012-git"; - asds = [ "lack-middleware-csrf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-middleware-csrf"; - asd = "lack-middleware-csrf"; - }); - systems = [ "lack-middleware-csrf" ]; - lispLibs = [ (getAttr "lack-request" self) (getAttr "lack-util" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-middleware-dbpool = (build-asdf-system { - pname = "lack-middleware-dbpool"; - version = "20241012-git"; - asds = [ "lack-middleware-dbpool" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-middleware-dbpool"; - asd = "lack-middleware-dbpool"; - }); - systems = [ "lack-middleware-dbpool" ]; - lispLibs = [ (getAttr "anypool" self) (getAttr "dbi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-middleware-mito = (build-asdf-system { - pname = "lack-middleware-mito"; - version = "20241012-git"; - asds = [ "lack-middleware-mito" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mito/2024-10-12/mito-20241012-git.tgz"; - sha256 = "0nz72qss2jji0narxffpnpfgz74grvhmwqqlydpw6wv3ji1rrrq3"; - system = "lack-middleware-mito"; - asd = "lack-middleware-mito"; - }); - systems = [ "lack-middleware-mito" ]; - lispLibs = [ (getAttr "dbi" self) (getAttr "mito-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-middleware-mount = (build-asdf-system { - pname = "lack-middleware-mount"; - version = "20241012-git"; - asds = [ "lack-middleware-mount" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-middleware-mount"; - asd = "lack-middleware-mount"; - }); - systems = [ "lack-middleware-mount" ]; - lispLibs = [ (getAttr "lack-component" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-middleware-session = (build-asdf-system { - pname = "lack-middleware-session"; - version = "20241012-git"; - asds = [ "lack-middleware-session" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-middleware-session"; - asd = "lack-middleware-session"; - }); - systems = [ "lack-middleware-session" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "lack-request" self) (getAttr "lack-response" self) (getAttr "lack-util" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-middleware-static = (build-asdf-system { - pname = "lack-middleware-static"; - version = "20241012-git"; - asds = [ "lack-middleware-static" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-middleware-static"; - asd = "lack-middleware-static"; - }); - systems = [ "lack-middleware-static" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "lack-app-file" self) (getAttr "lack-component" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-request = (build-asdf-system { - pname = "lack-request"; - version = "20241012-git"; - asds = [ "lack-request" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-request"; - asd = "lack-request"; - }); - systems = [ "lack-request" ]; - lispLibs = [ (getAttr "circular-streams" self) (getAttr "cl-ppcre" self) (getAttr "http-body" self) (getAttr "quri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-response = (build-asdf-system { - pname = "lack-response"; - version = "20241012-git"; - asds = [ "lack-response" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-response"; - asd = "lack-response"; - }); - systems = [ "lack-response" ]; - lispLibs = [ (getAttr "local-time" self) (getAttr "quri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-session-store-dbi = (build-asdf-system { - pname = "lack-session-store-dbi"; - version = "20241012-git"; - asds = [ "lack-session-store-dbi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-session-store-dbi"; - asd = "lack-session-store-dbi"; - }); - systems = [ "lack-session-store-dbi" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "dbi" self) (getAttr "lack-middleware-session" self) (getAttr "marshal" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-session-store-redis = (build-asdf-system { - pname = "lack-session-store-redis"; - version = "20241012-git"; - asds = [ "lack-session-store-redis" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-session-store-redis"; - asd = "lack-session-store-redis"; - }); - systems = [ "lack-session-store-redis" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "cl-redis" self) (getAttr "lack-middleware-session" self) (getAttr "marshal" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-test = (build-asdf-system { - pname = "lack-test"; - version = "20241012-git"; - asds = [ "lack-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-test"; - asd = "lack-test"; - }); - systems = [ "lack-test" ]; - lispLibs = [ (getAttr "cl-cookie" self) (getAttr "flexi-streams" self) (getAttr "lack" self) (getAttr "quri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lack-util = (build-asdf-system { - pname = "lack-util"; - version = "20241012-git"; - asds = [ "lack-util" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-util"; - asd = "lack-util"; - }); - systems = [ "lack-util" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-isaac" self) ]; - meta = {}; - }); - lack-util-writer-stream = (build-asdf-system { - pname = "lack-util-writer-stream"; - version = "20241012-git"; - asds = [ "lack-util-writer-stream" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; - sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; - system = "lack-util-writer-stream"; - asd = "lack-util-writer-stream"; - }); - systems = [ "lack-util-writer-stream" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lake = (build-asdf-system { - pname = "lake"; - version = "20220220-git"; - asds = [ "lake" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lake/2022-02-20/lake-20220220-git.tgz"; - sha256 = "1g6rr4d5vjx487ym5qjlnw5sd6rwx6l4zx1l9mj0j30lpm1k4il0"; - system = "lake"; - asd = "lake"; - }); - systems = [ "lake" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "cl-syntax" self) (getAttr "cl-syntax-interpol" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lake-cli = (build-asdf-system { - pname = "lake-cli"; - version = "20220220-git"; - asds = [ "lake-cli" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lake/2022-02-20/lake-20220220-git.tgz"; - sha256 = "1g6rr4d5vjx487ym5qjlnw5sd6rwx6l4zx1l9mj0j30lpm1k4il0"; - system = "lake-cli"; - asd = "lake-cli"; - }); - systems = [ "lake-cli" ]; - lispLibs = [ (getAttr "deploy" self) (getAttr "lake" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lake-test = (build-asdf-system { - pname = "lake-test"; - version = "20220220-git"; - asds = [ "lake-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lake/2022-02-20/lake-20220220-git.tgz"; - sha256 = "1g6rr4d5vjx487ym5qjlnw5sd6rwx6l4zx1l9mj0j30lpm1k4il0"; - system = "lake-test"; - asd = "lake-test"; - }); - systems = [ "lake-test" ]; - lispLibs = [ (getAttr "lake" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lambda-fiddle = (build-asdf-system { - pname = "lambda-fiddle"; - version = "20231021-git"; - asds = [ "lambda-fiddle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lambda-fiddle/2023-10-21/lambda-fiddle-20231021-git.tgz"; - sha256 = "1hh0192qvymn3zwy9a0rsg98wgb8mnb9z2jzl2a2n1ssvpx61gpj"; - system = "lambda-fiddle"; - asd = "lambda-fiddle"; - }); - systems = [ "lambda-fiddle" ]; - lispLibs = [ ]; - meta = {}; - }); - lambda-reader = (build-asdf-system { - pname = "lambda-reader"; - version = "20170124-git"; - asds = [ "lambda-reader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lambda-reader/2017-01-24/lambda-reader-20170124-git.tgz"; - sha256 = "0s73nrnvr0d2ql1gabcasmfnckzq0f2qs9317hv2mrrh0q1giq1w"; - system = "lambda-reader"; - asd = "lambda-reader"; - }); - systems = [ "lambda-reader" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lambda-reader-8bit = (build-asdf-system { - pname = "lambda-reader-8bit"; - version = "20170124-git"; - asds = [ "lambda-reader-8bit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lambda-reader/2017-01-24/lambda-reader-20170124-git.tgz"; - sha256 = "0s73nrnvr0d2ql1gabcasmfnckzq0f2qs9317hv2mrrh0q1giq1w"; - system = "lambda-reader-8bit"; - asd = "lambda-reader-8bit"; - }); - systems = [ "lambda-reader-8bit" ]; - lispLibs = [ (getAttr "asdf-encodings" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lambdalite = (build-asdf-system { - pname = "lambdalite"; - version = "20141217-git"; - asds = [ "lambdalite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lambdalite/2014-12-17/lambdalite-20141217-git.tgz"; - sha256 = "0bvhix74afak5bpaa4x3p1b7gskpvzvw78aqkml9d40gpd1ky8lh"; - system = "lambdalite"; - asd = "lambdalite"; - }); - systems = [ "lambdalite" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "wu-sugar" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - language-codes = (build-asdf-system { - pname = "language-codes"; - version = "20231021-git"; - asds = [ "language-codes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/language-codes/2023-10-21/language-codes-20231021-git.tgz"; - sha256 = "0qbv0x0w415m48c6gjaw7ncnb1446q9sswr2p3svx7ijiwd19kja"; - system = "language-codes"; - asd = "language-codes"; - }); - systems = [ "language-codes" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - langutils = (build-asdf-system { - pname = "langutils"; - version = "20121125-git"; - asds = [ "langutils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-langutils/2012-11-25/cl-langutils-20121125-git.tgz"; - sha256 = "15y9x5wkg3fqndc04w2sc650fnwimxp4gjgpv9xvvdm9x4v433x6"; - system = "langutils"; - asd = "langutils"; - }); - systems = [ "langutils" ]; - lispLibs = [ (getAttr "s-xml-rpc" self) (getAttr "stdutils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lapack = (build-asdf-system { - pname = "lapack"; - version = "20231021-git"; - asds = [ "lapack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "lapack"; - asd = "lapack"; - }); - systems = [ "lapack" ]; - lispLibs = [ (getAttr "blas-complex" self) (getAttr "blas-package" self) (getAttr "blas-real" self) (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lass = (build-asdf-system { - pname = "lass"; - version = "20241012-git"; - asds = [ "lass" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lass/2024-10-12/lass-20241012-git.tgz"; - sha256 = "1b6a3v763i5fcdxczffd59kh4m73p4ilz6az85apd22apc8lr80z"; - system = "lass"; - asd = "lass"; - }); - systems = [ "lass" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "trivial-indent" self) (getAttr "trivial-mimes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lass-flexbox = (build-asdf-system { - pname = "lass-flexbox"; - version = "20160208-git"; - asds = [ "lass-flexbox" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lass-flexbox/2016-02-08/lass-flexbox-20160208-git.tgz"; - sha256 = "143rkff1ybi3b07qyzndxxndp7j4nw1biyp51rkl0yvsk85kj1jp"; - system = "lass-flexbox"; - asd = "lass-flexbox"; - }); - systems = [ "lass-flexbox" ]; - lispLibs = [ (getAttr "lass" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lass-flexbox-test = (build-asdf-system { - pname = "lass-flexbox-test"; - version = "20160208-git"; - asds = [ "lass-flexbox-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lass-flexbox/2016-02-08/lass-flexbox-20160208-git.tgz"; - sha256 = "143rkff1ybi3b07qyzndxxndp7j4nw1biyp51rkl0yvsk85kj1jp"; - system = "lass-flexbox-test"; - asd = "lass-flexbox-test"; - }); - systems = [ "lass-flexbox-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "lass-flexbox" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lassie = (build-asdf-system { - pname = "lassie"; - version = "20140713-git"; - asds = [ "lassie" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lassie/2014-07-13/lassie-20140713-git.tgz"; - sha256 = "06ps25422ymp9n35745xhg3qsclfli52b7mxhw58wwz9q1v1n0rn"; - system = "lassie"; - asd = "lassie"; - }); - systems = [ "lassie" ]; - lispLibs = [ (getAttr "fsvd" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lastfm = (build-asdf-system { - pname = "lastfm"; - version = "20191007-git"; - asds = [ "lastfm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lastfm/2019-10-07/lastfm-20191007-git.tgz"; - sha256 = "1crg82fyzkm9a0czsf5vq6nwndg6gy7zqb2glbp3yaw6p2hrwkp4"; - system = "lastfm"; - asd = "lastfm"; - }); - systems = [ "lastfm" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "defmemo" self) (getAttr "drakma" self) (getAttr "generators" self) (getAttr "ironclad" self) (getAttr "lquery" self) (getAttr "plump" self) (getAttr "trivial-open-browser" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - latex-table = (build-asdf-system { - pname = "latex-table"; - version = "20180328-git"; - asds = [ "latex-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/latex-table/2018-03-28/latex-table-20180328-git.tgz"; - sha256 = "04qqr62pdi7qs9p74a4a014l6sl6bk6hrlb7b7pknxx5c15xvcgv"; - system = "latex-table"; - asd = "latex-table"; - }); - systems = [ "latex-table" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "array-operations" self) (getAttr "let-plus" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - latter-day-paypal = (build-asdf-system { - pname = "latter-day-paypal"; - version = "20221106-git"; - asds = [ "latter-day-paypal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/latter-day-paypal/2022-11-06/latter-day-paypal-20221106-git.tgz"; - sha256 = "0a4xji2ymmr7s4gq0gc3bhbf62gwfs93ymmpvgsmb0afcsi5099q"; - system = "latter-day-paypal"; - asd = "latter-day-paypal"; - }); - systems = [ "latter-day-paypal" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "cl-tls" self) (getAttr "closer-mop" self) (getAttr "dexador" self) (getAttr "do-urlencode" self) (getAttr "hunchentoot" self) (getAttr "ironclad" self) (getAttr "jonathan" self) (getAttr "local-time" self) (getAttr "ningle" self) (getAttr "quri" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lazy = (build-asdf-system { - pname = "lazy"; - version = "20200925-git"; - asds = [ "lazy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lazy/2020-09-25/lazy-20200925-git.tgz"; - sha256 = "0m099rwr7k17v984n4jnq4hadf19vza5qilxdyrr43scxbbrmw1n"; - system = "lazy"; - asd = "lazy"; - }); - systems = [ "lazy" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ledger = (build-asdf-system { - pname = "ledger"; - version = "master-fe503896-git"; - asds = [ "ledger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "ledger"; - asd = "ledger"; - }); - systems = [ "ledger" ]; - lispLibs = [ (getAttr "gwl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - leech = (build-asdf-system { - pname = "leech"; - version = "20140713-git"; - asds = [ "leech" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/bknr-web/2014-07-13/bknr-web-20140713-git.tgz"; - sha256 = "1m73z0hv7qsc9yddrg8zs7n3zmn9h64v4d62239wrvfnmzqk75x2"; - system = "leech"; - asd = "leech"; - }); - systems = [ "leech" ]; - lispLibs = [ (getAttr "aserve" self) (getAttr "unit-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - legion = (build-asdf-system { - pname = "legion"; - version = "20231021-git"; - asds = [ "legion" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/legion/2023-10-21/legion-20231021-git.tgz"; - sha256 = "0mf29w6s45dwkjvvirqk7b87swb5wvaffgb836s6sx74wwdgyyk8"; - system = "legion"; - asd = "legion"; - }); - systems = [ "legion" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-speedy-queue" self) (getAttr "vom" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - legion-test = (build-asdf-system { - pname = "legion-test"; - version = "20231021-git"; - asds = [ "legion-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/legion/2023-10-21/legion-20231021-git.tgz"; - sha256 = "0mf29w6s45dwkjvvirqk7b87swb5wvaffgb836s6sx74wwdgyyk8"; - system = "legion-test"; - asd = "legion-test"; - }); - systems = [ "legion-test" ]; - lispLibs = [ (getAttr "legion" self) (getAttr "local-time" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - legit = (build-asdf-system { - pname = "legit"; - version = "20231021-git"; - asds = [ "legit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/legit/2023-10-21/legit-20231021-git.tgz"; - sha256 = "0jy021ywrbnkgbgb63ip6j7kr40m4wz2pz1v5ybn6xkkn6dyprsz"; - system = "legit"; - asd = "legit"; - }); - systems = [ "legit" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "documentation-utils" self) (getAttr "lambda-fiddle" self) (getAttr "simple-inferiors" self) ]; - meta = {}; - }); - lem-opengl = (build-asdf-system { - pname = "lem-opengl"; - version = "20200427-git"; - asds = [ "lem-opengl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "lem-opengl"; - asd = "lem-opengl"; - }); - systems = [ "lem-opengl" ]; - lispLibs = [ (getAttr "application" self) (getAttr "control" self) (getAttr "livesupport" self) (getAttr "minilem" self) (getAttr "ncurses-clone-for-lem" self) (getAttr "sucle" self) (getAttr "trivial-clipboard" self) (getAttr "uncommon-lisp" self) (getAttr "utility" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lemmy-api = (build-asdf-system { - pname = "lemmy-api"; - version = "20241012-git"; - asds = [ "lemmy-api" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lemmy-api/2024-10-12/lemmy-api-20241012-git.tgz"; - sha256 = "0krlf3zw4snpkgqb564xk82b1d0q2scqs05s1kalr773a5d801s7"; - system = "lemmy-api"; - asd = "lemmy-api"; - }); - systems = [ "lemmy-api" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "dexador" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lemmy-api-bindings-generator = (build-asdf-system { - pname = "lemmy-api-bindings-generator"; - version = "20241012-git"; - asds = [ "lemmy-api-bindings-generator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lemmy-api/2024-10-12/lemmy-api-20241012-git.tgz"; - sha256 = "0krlf3zw4snpkgqb564xk82b1d0q2scqs05s1kalr773a5d801s7"; - system = "lemmy-api-bindings-generator"; - asd = "lemmy-api-bindings-generator"; - }); - systems = [ "lemmy-api-bindings-generator" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lense = (build-asdf-system { - pname = "lense"; - version = "20201220-git"; - asds = [ "lense" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lense/2020-12-20/lense-20201220-git.tgz"; - sha256 = "0j11m93an38d1cl6b1kaaj5azhkn64wpiiprlj2c4cjfzrc32ffv"; - system = "lense"; - asd = "lense"; - }); - systems = [ "lense" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "documentation-utils-extensions" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - let-over-lambda = (build-asdf-system { - pname = "let-over-lambda"; - version = "20231021-git"; - asds = [ "let-over-lambda" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/let-over-lambda/2023-10-21/let-over-lambda-20231021-git.tgz"; - sha256 = "0inzbmxlx5cvvx1isv827c2zr4qixcb47n6l6qjvc11gnwihdfjf"; - system = "let-over-lambda"; - asd = "let-over-lambda"; - }); - systems = [ "let-over-lambda" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "fare-quasiquote-extras" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - let-over-lambda-test = (build-asdf-system { - pname = "let-over-lambda-test"; - version = "20231021-git"; - asds = [ "let-over-lambda-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/let-over-lambda/2023-10-21/let-over-lambda-20231021-git.tgz"; - sha256 = "0inzbmxlx5cvvx1isv827c2zr4qixcb47n6l6qjvc11gnwihdfjf"; - system = "let-over-lambda-test"; - asd = "let-over-lambda-test"; - }); - systems = [ "let-over-lambda-test" ]; - lispLibs = [ (getAttr "let-over-lambda" self) (getAttr "named-readtables" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - let-plus = (build-asdf-system { - pname = "let-plus"; - version = "20191130-git"; - asds = [ "let-plus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/let-plus/2019-11-30/let-plus-20191130-git.tgz"; - sha256 = "00c0nq6l4zb692rzsc9aliqzj3avrssfyz4bhxzl7f1jsz3m29jb"; - system = "let-plus"; - asd = "let-plus"; - }); - systems = [ "let-plus" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) ]; - meta = {}; - }); - letrec = (build-asdf-system { - pname = "letrec"; - version = "20230618-git"; - asds = [ "letrec" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/letrec/2023-06-18/letrec-20230618-git.tgz"; - sha256 = "1iwpqrpjbapdxq37g2w65r966f5nhj5466wwvd7lb1jgb03kaghn"; - system = "letrec"; - asd = "letrec"; - }); - systems = [ "letrec" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - letv = (build-asdf-system { - pname = "letv"; - version = "20241012-git"; - asds = [ "letv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/letv/2024-10-12/letv-20241012-git.tgz"; - sha256 = "000alkhqb2n47y6849pswp7dg9pd0wwgswfrcm0sm4bz3r7dyjx1"; - system = "letv"; - asd = "letv"; - }); - systems = [ "letv" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lev = (build-asdf-system { - pname = "lev"; - version = "20231021-git"; - asds = [ "lev" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lev/2023-10-21/lev-20231021-git.tgz"; - sha256 = "1lr3lzghvl5mbg9cp66carmawbzg64yd8vyivf1df10vllc7ngd6"; - system = "lev"; - asd = "lev"; - }); - systems = [ "lev" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lev-config" self) ]; - meta = {}; - }); - lev-config = (build-asdf-system { - pname = "lev-config"; - version = "20231021-git"; - asds = [ "lev-config" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lev/2023-10-21/lev-20231021-git.tgz"; - sha256 = "1lr3lzghvl5mbg9cp66carmawbzg64yd8vyivf1df10vllc7ngd6"; - system = "lev-config"; - asd = "lev-config"; - }); - systems = [ "lev-config" ]; - lispLibs = [ (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - leveldb = (build-asdf-system { - pname = "leveldb"; - version = "20160531-git"; - asds = [ "leveldb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/leveldb/2016-05-31/leveldb-20160531-git.tgz"; - sha256 = "03i4qr3g8ga2vpc8qbnipan3i7y4809i036wppkkixcsbckslckv"; - system = "leveldb"; - asd = "leveldb"; - }); - systems = [ "leveldb" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - levenshtein = (build-asdf-system { - pname = "levenshtein"; - version = "1.0"; - asds = [ "levenshtein" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/levenshtein/2010-10-06/levenshtein-1.0.tgz"; - sha256 = "0b4hdv55qcjlh3ixy3fglvb90ggmm79nl02nxkly2ls6cd7rbf5i"; - system = "levenshtein"; - asd = "levenshtein"; - }); - systems = [ "levenshtein" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lfarm-admin = (build-asdf-system { - pname = "lfarm-admin"; - version = "20150608-git"; - asds = [ "lfarm-admin" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; - sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; - system = "lfarm-admin"; - asd = "lfarm-admin"; - }); - systems = [ "lfarm-admin" ]; - lispLibs = [ (getAttr "lfarm-common" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lfarm-client = (build-asdf-system { - pname = "lfarm-client"; - version = "20150608-git"; - asds = [ "lfarm-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; - sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; - system = "lfarm-client"; - asd = "lfarm-client"; - }); - systems = [ "lfarm-client" ]; - lispLibs = [ (getAttr "lfarm-common" self) (getAttr "lparallel" self) (getAttr "usocket" self) ]; - meta = {}; - }); - lfarm-common = (build-asdf-system { - pname = "lfarm-common"; - version = "20150608-git"; - asds = [ "lfarm-common" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; - sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; - system = "lfarm-common"; - asd = "lfarm-common"; - }); - systems = [ "lfarm-common" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-store" self) (getAttr "flexi-streams" self) (getAttr "usocket" self) ]; - meta = {}; - }); - lfarm-gss = (build-asdf-system { - pname = "lfarm-gss"; - version = "20150608-git"; - asds = [ "lfarm-gss" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; - sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; - system = "lfarm-gss"; - asd = "lfarm-gss"; - }); - systems = [ "lfarm-gss" ]; - lispLibs = [ (getAttr "cl-gss" self) (getAttr "lfarm-common" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lfarm-launcher = (build-asdf-system { - pname = "lfarm-launcher"; - version = "20150608-git"; - asds = [ "lfarm-launcher" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; - sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; - system = "lfarm-launcher"; - asd = "lfarm-launcher"; - }); - systems = [ "lfarm-launcher" ]; - lispLibs = [ (getAttr "external-program" self) (getAttr "lfarm-admin" self) (getAttr "lfarm-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lfarm-server = (build-asdf-system { - pname = "lfarm-server"; - version = "20150608-git"; - asds = [ "lfarm-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; - sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; - system = "lfarm-server"; - asd = "lfarm-server"; - }); - systems = [ "lfarm-server" ]; - lispLibs = [ (getAttr "lfarm-common" self) (getAttr "usocket" self) ]; - meta = {}; - }); - lfarm-ssl = (build-asdf-system { - pname = "lfarm-ssl"; - version = "20150608-git"; - asds = [ "lfarm-ssl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; - sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; - system = "lfarm-ssl"; - asd = "lfarm-ssl"; - }); - systems = [ "lfarm-ssl" ]; - lispLibs = [ (getAttr "cl_plus_ssl" self) (getAttr "lfarm-common" self) ]; - meta = {}; - }); - lfarm-test = (build-asdf-system { - pname = "lfarm-test"; - version = "20150608-git"; - asds = [ "lfarm-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; - sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; - system = "lfarm-test"; - asd = "lfarm-test"; - }); - systems = [ "lfarm-test" ]; - lispLibs = [ (getAttr "lfarm-admin" self) (getAttr "lfarm-client" self) (getAttr "lfarm-launcher" self) (getAttr "lfarm-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lhstats = (build-asdf-system { - pname = "lhstats"; - version = "20120107-git"; - asds = [ "lhstats" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lhstats/2012-01-07/lhstats-20120107-git.tgz"; - sha256 = "1x8h37vm9yd0a2g7qzili673n1c3a9rzawq27rxyzjrggv9wdnlz"; - system = "lhstats"; - asd = "lhstats"; - }); - systems = [ "lhstats" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lib-helper = (build-asdf-system { - pname = "lib-helper"; - version = "20241012-git"; - asds = [ "lib-helper" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-lib-helper/2024-10-12/cl-lib-helper-20241012-git.tgz"; - sha256 = "11aq60cs510kx9gj709q3kkgddk8aqb32pdzyikr9jylig050wyk"; - system = "lib-helper"; - asd = "lib-helper"; - }); - systems = [ "lib-helper" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-containers" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lib-helper-test-system = (build-asdf-system { - pname = "lib-helper-test-system"; - version = "20241012-git"; - asds = [ "lib-helper-test-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-lib-helper/2024-10-12/cl-lib-helper-20241012-git.tgz"; - sha256 = "11aq60cs510kx9gj709q3kkgddk8aqb32pdzyikr9jylig050wyk"; - system = "lib-helper-test-system"; - asd = "lib-helper-test-system"; - }); - systems = [ "lib-helper-test-system" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - libcmark = (build-asdf-system { - pname = "libcmark"; - version = "20241012-git"; - asds = [ "libcmark" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-cmark/2024-10-12/cl-cmark-20241012-git.tgz"; - sha256 = "1l4i530161ppfz0wn1da7g7dwf644ppp1afrq2p7qfkajm7dcfg5"; - system = "libcmark"; - asd = "libcmark"; - }); - systems = [ "libcmark" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - liblmdb = (build-asdf-system { - pname = "liblmdb"; - version = "20170830-git"; - asds = [ "liblmdb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/liblmdb/2017-08-30/liblmdb-20170830-git.tgz"; - sha256 = "0484245fcbqza40n377qhsr2v838cih6pziav5vlnml1y0cgv62b"; - system = "liblmdb"; - asd = "liblmdb"; - }); - systems = [ "liblmdb" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - libssh2 = (build-asdf-system { - pname = "libssh2"; - version = "20160531-git"; - asds = [ "libssh2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libssh2/2016-05-31/cl-libssh2-20160531-git.tgz"; - sha256 = "1f2zq30zli0gnawclpasxsajpn20cpyy9d3q9zpqyw1sfrsn0hmk"; - system = "libssh2"; - asd = "libssh2"; - }); - systems = [ "libssh2" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-fad" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "split-sequence" self) (getAttr "trivial-gray-streams" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - libssh2_dot_test = (build-asdf-system { - pname = "libssh2.test"; - version = "20160531-git"; - asds = [ "libssh2.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libssh2/2016-05-31/cl-libssh2-20160531-git.tgz"; - sha256 = "1f2zq30zli0gnawclpasxsajpn20cpyy9d3q9zpqyw1sfrsn0hmk"; - system = "libssh2.test"; - asd = "libssh2.test"; - }); - systems = [ "libssh2.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_stefil" self) (getAttr "libssh2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - libusb-ffi = (build-asdf-system { - pname = "libusb-ffi"; - version = "20210228-git"; - asds = [ "libusb-ffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libusb/2021-02-28/cl-libusb-20210228-git.tgz"; - sha256 = "0kyzgcflwb85q58fgn82sp0bipnq5bprg5i4h0h3jxafqqyagbnk"; - system = "libusb-ffi"; - asd = "libusb-ffi"; - }); - systems = [ "libusb-ffi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "static-vectors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lichat-ldap = (build-asdf-system { - pname = "lichat-ldap"; - version = "20231021-git"; - asds = [ "lichat-ldap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lichat-ldap/2023-10-21/lichat-ldap-20231021-git.tgz"; - sha256 = "1jgj5c0sgr4rw9vsjhz71k3ld7hp8fbbmzrn3g11fq8jl4c4iai1"; - system = "lichat-ldap"; - asd = "lichat-ldap"; - }); - systems = [ "lichat-ldap" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "lichat-serverlib" self) (getAttr "trivial-ldap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lichat-protocol = (build-asdf-system { - pname = "lichat-protocol"; - version = "20241012-git"; - asds = [ "lichat-protocol" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lichat-protocol/2024-10-12/lichat-protocol-20241012-git.tgz"; - sha256 = "0y8546aaf539jnl29r4a8sa975jak1ld4d62w2n1kp8s9nb80z11"; - system = "lichat-protocol"; - asd = "lichat-protocol"; - }); - systems = [ "lichat-protocol" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "documentation-utils" self) (getAttr "trivial-package-local-nicknames" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lichat-serverlib = (build-asdf-system { - pname = "lichat-serverlib"; - version = "20231021-git"; - asds = [ "lichat-serverlib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lichat-serverlib/2023-10-21/lichat-serverlib-20231021-git.tgz"; - sha256 = "04830z49lczgdf8gval4j3s0fp5p6pfgvy783mrkcdfal2dcwacq"; - system = "lichat-serverlib"; - asd = "lichat-serverlib"; - }); - systems = [ "lichat-serverlib" ]; - lispLibs = [ (getAttr "crypto-shortcuts" self) (getAttr "documentation-utils" self) (getAttr "lichat-protocol" self) (getAttr "trivial-mimes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lichat-tcp-client = (build-asdf-system { - pname = "lichat-tcp-client"; - version = "20241012-git"; - asds = [ "lichat-tcp-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lichat-tcp-client/2024-10-12/lichat-tcp-client-20241012-git.tgz"; - sha256 = "1wwh396z7185nylrsz47b6l45hyfq6mjrm620fk5bsxr3jrzxs25"; - system = "lichat-tcp-client"; - asd = "lichat-tcp-client"; - }); - systems = [ "lichat-tcp-client" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-base64" self) (getAttr "documentation-utils" self) (getAttr "lichat-protocol" self) (getAttr "trivial-mimes" self) (getAttr "usocket" self) (getAttr "verbose" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lichat-tcp-server = (build-asdf-system { - pname = "lichat-tcp-server"; - version = "20231021-git"; - asds = [ "lichat-tcp-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lichat-tcp-server/2023-10-21/lichat-tcp-server-20231021-git.tgz"; - sha256 = "18dys957iw678y6bqfq9x85m2bnb0ck8gr6l4b61vv3g2yl2w53y"; - system = "lichat-tcp-server"; - asd = "lichat-tcp-server"; - }); - systems = [ "lichat-tcp-server" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "documentation-utils" self) (getAttr "lichat-protocol" self) (getAttr "lichat-serverlib" self) (getAttr "usocket" self) (getAttr "verbose" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lichat-ws-server = (build-asdf-system { - pname = "lichat-ws-server"; - version = "20231021-git"; - asds = [ "lichat-ws-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lichat-ws-server/2023-10-21/lichat-ws-server-20231021-git.tgz"; - sha256 = "05vmc9b8b5igifm6lb5p3fssmny6ils7aimsizql3gay4nycvxgp"; - system = "lichat-ws-server"; - asd = "lichat-ws-server"; - }); - systems = [ "lichat-ws-server" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "documentation-utils" self) (getAttr "hunchensocket" self) (getAttr "lichat-protocol" self) (getAttr "lichat-serverlib" self) (getAttr "verbose" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lift = (build-asdf-system { - pname = "lift"; - version = "20231021-git"; - asds = [ "lift" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lift/2023-10-21/lift-20231021-git.tgz"; - sha256 = "1513n46fkqw8rnvz69s7xnwj476qm8ibdlwsr63qj9yh0mib0q6x"; - system = "lift"; - asd = "lift"; - }); - systems = [ "lift" ]; - lispLibs = [ ]; - meta = {}; - }); - lift-documentation = (build-asdf-system { - pname = "lift-documentation"; - version = "20231021-git"; - asds = [ "lift-documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lift/2023-10-21/lift-20231021-git.tgz"; - sha256 = "1513n46fkqw8rnvz69s7xnwj476qm8ibdlwsr63qj9yh0mib0q6x"; - system = "lift-documentation"; - asd = "lift-documentation"; - }); - systems = [ "lift-documentation" ]; - lispLibs = [ (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lift-test = (build-asdf-system { - pname = "lift-test"; - version = "20231021-git"; - asds = [ "lift-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lift/2023-10-21/lift-20231021-git.tgz"; - sha256 = "1513n46fkqw8rnvz69s7xnwj476qm8ibdlwsr63qj9yh0mib0q6x"; - system = "lift-test"; - asd = "lift-test"; - }); - systems = [ "lift-test" ]; - lispLibs = [ (getAttr "lift" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lil = (build-asdf-system { - pname = "lil"; - version = "20231021-git"; - asds = [ "lil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-interface-library/2023-10-21/lisp-interface-library-20231021-git.tgz"; - sha256 = "0krh8z696a0p894vmqdw9clzhpqfqff4c4rd7s8d8hd5jwjm40aq"; - system = "lil"; - asd = "lil"; - }); - systems = [ "lil" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "fare-memoization" self) (getAttr "fare-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lila = (build-asdf-system { - pname = "lila"; - version = "20191007-git"; - asds = [ "lila" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lila/2019-10-07/lila-20191007-git.tgz"; - sha256 = "0n29ipbcxh4fm8f1vpaywv02iaayqqk61zsfk051ksjfl5kyqypq"; - system = "lila"; - asd = "lila"; - }); - systems = [ "lila" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lime = (build-asdf-system { - pname = "lime"; - version = "20230618-git"; - asds = [ "lime" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lime/2023-06-18/lime-20230618-git.tgz"; - sha256 = "1af1m3nxxqpaw85s1cc4qf0fkv3z061xk5k17ygfmchmv8sj1agp"; - system = "lime"; - asd = "lime"; - }); - systems = [ "lime" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "swank-protocol" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lime-example = (build-asdf-system { - pname = "lime-example"; - version = "20230618-git"; - asds = [ "lime-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lime/2023-06-18/lime-20230618-git.tgz"; - sha256 = "1af1m3nxxqpaw85s1cc4qf0fkv3z061xk5k17ygfmchmv8sj1agp"; - system = "lime-example"; - asd = "lime-example"; - }); - systems = [ "lime-example" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "lime" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lime-test = (build-asdf-system { - pname = "lime-test"; - version = "20230618-git"; - asds = [ "lime-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lime/2023-06-18/lime-20230618-git.tgz"; - sha256 = "1af1m3nxxqpaw85s1cc4qf0fkv3z061xk5k17ygfmchmv8sj1agp"; - system = "lime-test"; - asd = "lime-test"; - }); - systems = [ "lime-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "external-program" self) (getAttr "fiveam" self) (getAttr "lime" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - linear-programming = (build-asdf-system { - pname = "linear-programming"; - version = "20241012-git"; - asds = [ "linear-programming" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/linear-programming/2024-10-12/linear-programming-20241012-git.tgz"; - sha256 = "01dy54ycmalqlk4wrkw1y6vixr0mk0nxmfy3p1w5kpdwp3642h9g"; - system = "linear-programming"; - asd = "linear-programming"; - }); - systems = [ "linear-programming" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - linear-programming-glpk = (build-asdf-system { - pname = "linear-programming-glpk"; - version = "20221106-git"; - asds = [ "linear-programming-glpk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/linear-programming-glpk/2022-11-06/linear-programming-glpk-20221106-git.tgz"; - sha256 = "0vm4qgjvw5k3v62h78j6802dm075aif06hbjw600m3hybn84rs3l"; - system = "linear-programming-glpk"; - asd = "linear-programming-glpk"; - }); - systems = [ "linear-programming-glpk" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "linear-programming" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - linear-programming-test = (build-asdf-system { - pname = "linear-programming-test"; - version = "20241012-git"; - asds = [ "linear-programming-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/linear-programming/2024-10-12/linear-programming-20241012-git.tgz"; - sha256 = "01dy54ycmalqlk4wrkw1y6vixr0mk0nxmfy3p1w5kpdwp3642h9g"; - system = "linear-programming-test"; - asd = "linear-programming-test"; - }); - systems = [ "linear-programming-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "iterate" self) (getAttr "linear-programming" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - linedit = (build-asdf-system { - pname = "linedit"; - version = "20180430-git"; - asds = [ "linedit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/linedit/2018-04-30/linedit-20180430-git.tgz"; - sha256 = "0hhh7xn6q12rviayfihg1ym6x6csa0pdjgb88ykqbrz2rs3pgpz5"; - system = "linedit"; - asd = "linedit"; - }); - systems = [ "linedit" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "osicat" self) (getAttr "terminfo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lineva = (build-asdf-system { - pname = "lineva"; - version = "20221106-git"; - asds = [ "lineva" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lineva/2022-11-06/lineva-20221106-git.tgz"; - sha256 = "193v40llsi51b4zk93fyrg5ll2309waw7ibl4z75bbw73kc4f2wx"; - system = "lineva"; - asd = "lineva"; - }); - systems = [ "lineva" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - linewise-template = (build-asdf-system { - pname = "linewise-template"; - version = "20230618-git"; - asds = [ "linewise-template" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/linewise-template/2023-06-18/linewise-template-20230618-git.tgz"; - sha256 = "08i2426lkcfcydmm9ca71whvyairrd0lklr6w7w17zbg0bsxsaaa"; - system = "linewise-template"; - asd = "linewise-template"; - }); - systems = [ "linewise-template" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - linux-packaging = (build-asdf-system { - pname = "linux-packaging"; - version = "20211020-git"; - asds = [ "linux-packaging" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/linux-packaging/2021-10-20/linux-packaging-20211020-git.tgz"; - sha256 = "0hmahs2slfs1bznn6zdljc5yjlg16ml795rcxnmafq7941lgqjs5"; - system = "linux-packaging"; - asd = "linux-packaging"; - }); - systems = [ "linux-packaging" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cffi-toolchain" self) (getAttr "cl-ppcre" self) (getAttr "wild-package-inferred-system" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - linux-packaging-tests = (build-asdf-system { - pname = "linux-packaging-tests"; - version = "20211020-git"; - asds = [ "linux-packaging-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/linux-packaging/2021-10-20/linux-packaging-20211020-git.tgz"; - sha256 = "0hmahs2slfs1bznn6zdljc5yjlg16ml795rcxnmafq7941lgqjs5"; - system = "linux-packaging-tests"; - asd = "linux-packaging-tests"; - }); - systems = [ "linux-packaging-tests" ]; - lispLibs = [ (getAttr "linux-packaging" self) (getAttr "osicat" self) (getAttr "sqlite" self) (getAttr "wild-package-inferred-system" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisa = (build-asdf-system { - pname = "lisa"; - version = "20120407-git"; - asds = [ "lisa" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisa/2012-04-07/lisa-20120407-git.tgz"; - sha256 = "12mpwxpczfq2hridjspbg51121hngbcnji37fhlr0vv4dqrg1z15"; - system = "lisa"; - asd = "lisa"; - }); - systems = [ "lisa" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-binary = (build-asdf-system { - pname = "lisp-binary"; - version = "20241012-git"; - asds = [ "lisp-binary" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-binary/2024-10-12/lisp-binary-20241012-git.tgz"; - sha256 = "1zgk6pbhjj4agazffv6mc3hjzyg4xh256sla83iqy5mwm172d810"; - system = "lisp-binary"; - asd = "lisp-binary"; - }); - systems = [ "lisp-binary" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "closer-mop" self) (getAttr "flexi-streams" self) (getAttr "moptilities" self) (getAttr "quasiquote-2_dot_0" self) ]; - meta = {}; - }); - lisp-binary-test = (build-asdf-system { - pname = "lisp-binary-test"; - version = "20241012-git"; - asds = [ "lisp-binary-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-binary/2024-10-12/lisp-binary-20241012-git.tgz"; - sha256 = "1zgk6pbhjj4agazffv6mc3hjzyg4xh256sla83iqy5mwm172d810"; - system = "lisp-binary-test"; - asd = "lisp-binary-test"; - }); - systems = [ "lisp-binary-test" ]; - lispLibs = [ (getAttr "lisp-binary" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-chat = (build-asdf-system { - pname = "lisp-chat"; - version = "20241012-git"; - asds = [ "lisp-chat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-chat/2024-10-12/lisp-chat-20241012-git.tgz"; - sha256 = "16ckgxg0c3rx6qvwj5cn6rmfgxbj7587r9g342bw3nfxab0sqlzd"; - system = "lisp-chat"; - asd = "lisp-chat"; - }); - systems = [ "lisp-chat" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-readline" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-critic = (build-asdf-system { - pname = "lisp-critic"; - version = "20241012-git"; - asds = [ "lisp-critic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-critic/2024-10-12/lisp-critic-20241012-git.tgz"; - sha256 = "19czs2m8h3kgwjd10pdk9r5kazbgly8g82a5q3bs7pqkja42i7x7"; - system = "lisp-critic"; - asd = "lisp-critic"; - }); - systems = [ "lisp-critic" ]; - lispLibs = [ (getAttr "ckr-tables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-executable = (build-asdf-system { - pname = "lisp-executable"; - version = "20180831-git"; - asds = [ "lisp-executable" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-executable/2018-08-31/lisp-executable-20180831-git.tgz"; - sha256 = "1309f7w0hks3agkhcn8nwm83yssdfrr9b5bjqkjg3rrhxs86c0z7"; - system = "lisp-executable"; - asd = "lisp-executable"; - }); - systems = [ "lisp-executable" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-executable-example = (build-asdf-system { - pname = "lisp-executable-example"; - version = "20180831-git"; - asds = [ "lisp-executable-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-executable/2018-08-31/lisp-executable-20180831-git.tgz"; - sha256 = "1309f7w0hks3agkhcn8nwm83yssdfrr9b5bjqkjg3rrhxs86c0z7"; - system = "lisp-executable-example"; - asd = "lisp-executable-example"; - }); - systems = [ "lisp-executable-example" ]; - lispLibs = [ (getAttr "lisp-executable" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-executable-tests = (build-asdf-system { - pname = "lisp-executable-tests"; - version = "20180831-git"; - asds = [ "lisp-executable-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-executable/2018-08-31/lisp-executable-20180831-git.tgz"; - sha256 = "1309f7w0hks3agkhcn8nwm83yssdfrr9b5bjqkjg3rrhxs86c0z7"; - system = "lisp-executable-tests"; - asd = "lisp-executable-tests"; - }); - systems = [ "lisp-executable-tests" ]; - lispLibs = [ (getAttr "lisp-executable" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-interface-library = (build-asdf-system { - pname = "lisp-interface-library"; - version = "20231021-git"; - asds = [ "lisp-interface-library" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-interface-library/2023-10-21/lisp-interface-library-20231021-git.tgz"; - sha256 = "0krh8z696a0p894vmqdw9clzhpqfqff4c4rd7s8d8hd5jwjm40aq"; - system = "lisp-interface-library"; - asd = "lisp-interface-library"; - }); - systems = [ "lisp-interface-library" ]; - lispLibs = [ (getAttr "lil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-invocation = (build-asdf-system { - pname = "lisp-invocation"; - version = "20180228-git"; - asds = [ "lisp-invocation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-invocation/2018-02-28/lisp-invocation-20180228-git.tgz"; - sha256 = "1qwvczjd5w6mrkz7ip3gl46f72dnxgngdc5bla35l2g7br96kzsl"; - system = "lisp-invocation"; - asd = "lisp-invocation"; - }); - systems = [ "lisp-invocation" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-namespace = (build-asdf-system { - pname = "lisp-namespace"; - version = "20221106-git"; - asds = [ "lisp-namespace" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-namespace/2022-11-06/lisp-namespace-20221106-git.tgz"; - sha256 = "1p5db9mab4whapy1pl38ajw5fkrrdw266n05mnhf4xx2fb9sbx6p"; - system = "lisp-namespace"; - asd = "lisp-namespace"; - }); - systems = [ "lisp-namespace" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = {}; - }); - lisp-namespace_dot_test = (build-asdf-system { - pname = "lisp-namespace.test"; - version = "20221106-git"; - asds = [ "lisp-namespace.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-namespace/2022-11-06/lisp-namespace-20221106-git.tgz"; - sha256 = "1p5db9mab4whapy1pl38ajw5fkrrdw266n05mnhf4xx2fb9sbx6p"; - system = "lisp-namespace.test"; - asd = "lisp-namespace.test"; - }); - systems = [ "lisp-namespace.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "lisp-namespace" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-pay = (build-asdf-system { - pname = "lisp-pay"; - version = "20241012-git"; - asds = [ "lisp-pay" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-pay/2024-10-12/lisp-pay-20241012-git.tgz"; - sha256 = "1rbkzngas67ras5cf90y3dk99md05jmnjgsh45khj4b6kzw5a4v5"; - system = "lisp-pay"; - asd = "lisp-pay"; - }); - systems = [ "lisp-pay" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-base64" self) (getAttr "cl-tls" self) (getAttr "closer-mop" self) (getAttr "dexador" self) (getAttr "hu_dot_dwim_dot_defclass-star" self) (getAttr "hunchentoot" self) (getAttr "ironclad" self) (getAttr "jonathan" self) (getAttr "lack" self) (getAttr "ningle" self) (getAttr "shasht" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-preprocessor = (build-asdf-system { - pname = "lisp-preprocessor"; - version = "20200715-git"; - asds = [ "lisp-preprocessor" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-preprocessor/2020-07-15/lisp-preprocessor-20200715-git.tgz"; - sha256 = "0v0qhawcvgbxk06nfwyvcqwmqvzn2svq80l2rb12myr0znschhpi"; - system = "lisp-preprocessor"; - asd = "lisp-preprocessor"; - }); - systems = [ "lisp-preprocessor" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "split-sequence" self) (getAttr "trivia" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-preprocessor-tests = (build-asdf-system { - pname = "lisp-preprocessor-tests"; - version = "20200715-git"; - asds = [ "lisp-preprocessor-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-preprocessor/2020-07-15/lisp-preprocessor-20200715-git.tgz"; - sha256 = "0v0qhawcvgbxk06nfwyvcqwmqvzn2svq80l2rb12myr0znschhpi"; - system = "lisp-preprocessor-tests"; - asd = "lisp-preprocessor"; - }); - systems = [ "lisp-preprocessor-tests" ]; - lispLibs = [ (getAttr "lisp-preprocessor" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-stat = (build-asdf-system { - pname = "lisp-stat"; - version = "20241012-git"; - asds = [ "lisp-stat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-stat/2024-10-12/lisp-stat-20241012-git.tgz"; - sha256 = "0igrrwlfvdqxdqwqij819zlkma6b815d10v3kzh1r6hp9fhn0r3p"; - system = "lisp-stat"; - asd = "lisp-stat"; - }); - systems = [ "lisp-stat" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "alexandria_plus" self) (getAttr "array-operations" self) (getAttr "data-frame" self) (getAttr "dexador" self) (getAttr "dfio" self) (getAttr "distributions" self) (getAttr "num-utils" self) (getAttr "org_dot_tfeb_dot_conduit-packages" self) (getAttr "select" self) (getAttr "statistics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-types = (build-asdf-system { - pname = "lisp-types"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "lisp-types" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "lisp-types"; - asd = "lisp-types"; - }); - systems = [ "lisp-types" ]; - lispLibs = [ (getAttr "adjuvant" self) (getAttr "cl-robdd" self) (getAttr "dispatch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-types-analysis = (build-asdf-system { - pname = "lisp-types-analysis"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "lisp-types-analysis" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "lisp-types-analysis"; - asd = "lisp-types-analysis"; - }); - systems = [ "lisp-types-analysis" ]; - lispLibs = [ (getAttr "adjuvant" self) (getAttr "cl-fad" self) (getAttr "cl-robdd" self) (getAttr "cl-robdd-analysis" self) (getAttr "lisp-types" self) (getAttr "scrutiny" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-types-test = (build-asdf-system { - pname = "lisp-types-test"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "lisp-types-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "lisp-types-test"; - asd = "lisp-types-test"; - }); - systems = [ "lisp-types-test" ]; - lispLibs = [ (getAttr "adjuvant" self) (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "lisp-types" self) (getAttr "lisp-types-analysis" self) (getAttr "scrutiny" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lisp-unit = (build-asdf-system { - pname = "lisp-unit"; - version = "20170124-git"; - asds = [ "lisp-unit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-unit/2017-01-24/lisp-unit-20170124-git.tgz"; - sha256 = "0p6gdmgr7p383nvd66c9y9fp2bjk4jx1lpa5p09g43hr9y9pp9ry"; - system = "lisp-unit"; - asd = "lisp-unit"; - }); - systems = [ "lisp-unit" ]; - lispLibs = [ ]; - meta = {}; - }); - lisp-unit2 = (build-asdf-system { - pname = "lisp-unit2"; - version = "20230214-git"; - asds = [ "lisp-unit2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-unit2/2023-02-14/lisp-unit2-20230214-git.tgz"; - sha256 = "140nn22n1xv3qaash3x6h2h7xmys44s3f42b7bakfhpc4qlx0b69"; - system = "lisp-unit2"; - asd = "lisp-unit2"; - }); - systems = [ "lisp-unit2" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-interpol" self) (getAttr "iterate" self) (getAttr "symbol-munger" self) ]; - meta = {}; - }); - lispbuilder-lexer = (build-asdf-system { - pname = "lispbuilder-lexer"; - version = "20210807-git"; - asds = [ "lispbuilder-lexer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-lexer"; - asd = "lispbuilder-lexer"; - }); - systems = [ "lispbuilder-lexer" ]; - lispLibs = [ (getAttr "lispbuilder-regex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-net = (build-asdf-system { - pname = "lispbuilder-net"; - version = "20210807-git"; - asds = [ "lispbuilder-net" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-net"; - asd = "lispbuilder-net"; - }); - systems = [ "lispbuilder-net" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-net-cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-net-cffi = (build-asdf-system { - pname = "lispbuilder-net-cffi"; - version = "20210807-git"; - asds = [ "lispbuilder-net-cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-net-cffi"; - asd = "lispbuilder-net-cffi"; - }); - systems = [ "lispbuilder-net-cffi" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-opengl-1-1 = (build-asdf-system { - pname = "lispbuilder-opengl-1-1"; - version = "20210807-git"; - asds = [ "lispbuilder-opengl-1-1" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-opengl-1-1"; - asd = "lispbuilder-opengl-1-1"; - }); - systems = [ "lispbuilder-opengl-1-1" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-opengl-examples = (build-asdf-system { - pname = "lispbuilder-opengl-examples"; - version = "20210807-git"; - asds = [ "lispbuilder-opengl-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-opengl-examples"; - asd = "lispbuilder-opengl-examples"; - }); - systems = [ "lispbuilder-opengl-examples" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-opengl-1-1" self) (getAttr "lispbuilder-sdl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-regex = (build-asdf-system { - pname = "lispbuilder-regex"; - version = "20210807-git"; - asds = [ "lispbuilder-regex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-regex"; - asd = "lispbuilder-regex"; - }); - systems = [ "lispbuilder-regex" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl = (build-asdf-system { - pname = "lispbuilder-sdl"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl"; - asd = "lispbuilder-sdl"; - }); - systems = [ "lispbuilder-sdl" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl-assets" self) (getAttr "lispbuilder-sdl-base" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-assets = (build-asdf-system { - pname = "lispbuilder-sdl-assets"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-assets" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-assets"; - asd = "lispbuilder-sdl-assets"; - }); - systems = [ "lispbuilder-sdl-assets" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-base = (build-asdf-system { - pname = "lispbuilder-sdl-base"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-base"; - asd = "lispbuilder-sdl-base"; - }); - systems = [ "lispbuilder-sdl-base" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl-cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-binaries = (build-asdf-system { - pname = "lispbuilder-sdl-binaries"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-binaries" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-binaries"; - asd = "lispbuilder-sdl-binaries"; - }); - systems = [ "lispbuilder-sdl-binaries" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-cffi = (build-asdf-system { - pname = "lispbuilder-sdl-cffi"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-cffi"; - asd = "lispbuilder-sdl-cffi"; - }); - systems = [ "lispbuilder-sdl-cffi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl-binaries" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-cl-vectors = (build-asdf-system { - pname = "lispbuilder-sdl-cl-vectors"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-cl-vectors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-cl-vectors"; - asd = "lispbuilder-sdl-cl-vectors"; - }); - systems = [ "lispbuilder-sdl-cl-vectors" ]; - lispLibs = [ (getAttr "cl-aa-misc" self) (getAttr "cl-paths-ttf" self) (getAttr "cl-vectors" self) (getAttr "lispbuilder-sdl" self) (getAttr "zpb-ttf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-cl-vectors-examples = (build-asdf-system { - pname = "lispbuilder-sdl-cl-vectors-examples"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-cl-vectors-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-cl-vectors-examples"; - asd = "lispbuilder-sdl-cl-vectors-examples"; - }); - systems = [ "lispbuilder-sdl-cl-vectors-examples" ]; - lispLibs = [ (getAttr "lispbuilder-sdl-cl-vectors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-examples = (build-asdf-system { - pname = "lispbuilder-sdl-examples"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-examples"; - asd = "lispbuilder-sdl-examples"; - }); - systems = [ "lispbuilder-sdl-examples" ]; - lispLibs = [ (getAttr "lispbuilder-sdl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-gfx = (build-asdf-system { - pname = "lispbuilder-sdl-gfx"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-gfx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-gfx"; - asd = "lispbuilder-sdl-gfx"; - }); - systems = [ "lispbuilder-sdl-gfx" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-gfx-cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-gfx-binaries = (build-asdf-system { - pname = "lispbuilder-sdl-gfx-binaries"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-gfx-binaries" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-gfx-binaries"; - asd = "lispbuilder-sdl-gfx-binaries"; - }); - systems = [ "lispbuilder-sdl-gfx-binaries" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-gfx-cffi = (build-asdf-system { - pname = "lispbuilder-sdl-gfx-cffi"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-gfx-cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-gfx-cffi"; - asd = "lispbuilder-sdl-gfx-cffi"; - }); - systems = [ "lispbuilder-sdl-gfx-cffi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-gfx-examples = (build-asdf-system { - pname = "lispbuilder-sdl-gfx-examples"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-gfx-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-gfx-examples"; - asd = "lispbuilder-sdl-gfx-examples"; - }); - systems = [ "lispbuilder-sdl-gfx-examples" ]; - lispLibs = [ (getAttr "lispbuilder-sdl-gfx" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-image = (build-asdf-system { - pname = "lispbuilder-sdl-image"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-image" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-image"; - asd = "lispbuilder-sdl-image"; - }); - systems = [ "lispbuilder-sdl-image" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-image-cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-image-binaries = (build-asdf-system { - pname = "lispbuilder-sdl-image-binaries"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-image-binaries" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-image-binaries"; - asd = "lispbuilder-sdl-image-binaries"; - }); - systems = [ "lispbuilder-sdl-image-binaries" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-image-cffi = (build-asdf-system { - pname = "lispbuilder-sdl-image-cffi"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-image-cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-image-cffi"; - asd = "lispbuilder-sdl-image-cffi"; - }); - systems = [ "lispbuilder-sdl-image-cffi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-image-binaries" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-image-examples = (build-asdf-system { - pname = "lispbuilder-sdl-image-examples"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-image-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-image-examples"; - asd = "lispbuilder-sdl-image-examples"; - }); - systems = [ "lispbuilder-sdl-image-examples" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-image" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-mixer = (build-asdf-system { - pname = "lispbuilder-sdl-mixer"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-mixer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-mixer"; - asd = "lispbuilder-sdl-mixer"; - }); - systems = [ "lispbuilder-sdl-mixer" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-mixer-cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-mixer-binaries = (build-asdf-system { - pname = "lispbuilder-sdl-mixer-binaries"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-mixer-binaries" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-mixer-binaries"; - asd = "lispbuilder-sdl-mixer-binaries"; - }); - systems = [ "lispbuilder-sdl-mixer-binaries" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-mixer-cffi = (build-asdf-system { - pname = "lispbuilder-sdl-mixer-cffi"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-mixer-cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-mixer-cffi"; - asd = "lispbuilder-sdl-mixer-cffi"; - }); - systems = [ "lispbuilder-sdl-mixer-cffi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-mixer-binaries" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-mixer-examples = (build-asdf-system { - pname = "lispbuilder-sdl-mixer-examples"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-mixer-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-mixer-examples"; - asd = "lispbuilder-sdl-mixer-examples"; - }); - systems = [ "lispbuilder-sdl-mixer-examples" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-mixer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-ttf = (build-asdf-system { - pname = "lispbuilder-sdl-ttf"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-ttf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-ttf"; - asd = "lispbuilder-sdl-ttf"; - }); - systems = [ "lispbuilder-sdl-ttf" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-ttf-cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-ttf-binaries = (build-asdf-system { - pname = "lispbuilder-sdl-ttf-binaries"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-ttf-binaries" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-ttf-binaries"; - asd = "lispbuilder-sdl-ttf-binaries"; - }); - systems = [ "lispbuilder-sdl-ttf-binaries" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-ttf-cffi = (build-asdf-system { - pname = "lispbuilder-sdl-ttf-cffi"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-ttf-cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-ttf-cffi"; - asd = "lispbuilder-sdl-ttf-cffi"; - }); - systems = [ "lispbuilder-sdl-ttf-cffi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-ttf-binaries" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-ttf-examples = (build-asdf-system { - pname = "lispbuilder-sdl-ttf-examples"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-ttf-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-ttf-examples"; - asd = "lispbuilder-sdl-ttf-examples"; - }); - systems = [ "lispbuilder-sdl-ttf-examples" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-ttf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-vecto = (build-asdf-system { - pname = "lispbuilder-sdl-vecto"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-vecto" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-vecto"; - asd = "lispbuilder-sdl-vecto"; - }); - systems = [ "lispbuilder-sdl-vecto" ]; - lispLibs = [ (getAttr "lispbuilder-sdl" self) (getAttr "lispbuilder-sdl-cl-vectors" self) (getAttr "vecto" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-sdl-vecto-examples = (build-asdf-system { - pname = "lispbuilder-sdl-vecto-examples"; - version = "20210807-git"; - asds = [ "lispbuilder-sdl-vecto-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-sdl-vecto-examples"; - asd = "lispbuilder-sdl-vecto-examples"; - }); - systems = [ "lispbuilder-sdl-vecto-examples" ]; - lispLibs = [ (getAttr "lispbuilder-sdl-vecto" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-windows = (build-asdf-system { - pname = "lispbuilder-windows"; - version = "20210807-git"; - asds = [ "lispbuilder-windows" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-windows"; - asd = "lispbuilder-windows"; - }); - systems = [ "lispbuilder-windows" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispbuilder-yacc = (build-asdf-system { - pname = "lispbuilder-yacc"; - version = "20210807-git"; - asds = [ "lispbuilder-yacc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; - sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; - system = "lispbuilder-yacc"; - asd = "lispbuilder-yacc"; - }); - systems = [ "lispbuilder-yacc" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispcord = (build-asdf-system { - pname = "lispcord"; - version = "20241012-git"; - asds = [ "lispcord" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispcord/2024-10-12/lispcord-20241012-git.tgz"; - sha256 = "11xwrrvvqdm1wdnxrxqgizgw25plsn28n2k0lm5kakax9n221brn"; - system = "lispcord"; - asd = "lispcord"; - }); - systems = [ "lispcord" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "drakma" self) (getAttr "jonathan" self) (getAttr "split-sequence" self) (getAttr "verbose" self) (getAttr "websocket-driver-client" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lispqr = (build-asdf-system { - pname = "lispqr"; - version = "20210630-git"; - asds = [ "lispqr" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lispqr/2021-06-30/lispqr-20210630-git.tgz"; - sha256 = "06v1xpw5r4nxll286frhkc3ysvr50m904d33marnjmiax41y8qkc"; - system = "lispqr"; - asd = "lispqr"; - }); - systems = [ "lispqr" ]; - lispLibs = [ (getAttr "zpng" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - list-named-class = (build-asdf-system { - pname = "list-named-class"; - version = "20200325-git"; - asds = [ "list-named-class" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/list-named-class/2020-03-25/list-named-class-20200325-git.tgz"; - sha256 = "1bdi9q9wvfj66jji3n9hpjrj9271ial2awsb0xw80bmy6wqbg8kq"; - system = "list-named-class"; - asd = "list-named-class"; - }); - systems = [ "list-named-class" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - list-of = (build-asdf-system { - pname = "list-of"; - version = "20221106-git"; - asds = [ "list-of" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-finalizers/2022-11-06/asdf-finalizers-20221106-git.tgz"; - sha256 = "1w56c9yjjydjshsgqxz57qlp2v3r4ilbisnsgiqphvxnhvd41y0v"; - system = "list-of"; - asd = "list-of"; - }); - systems = [ "list-of" ]; - lispLibs = [ (getAttr "asdf-finalizers" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - listopia = (build-asdf-system { - pname = "listopia"; - version = "20210411-git"; - asds = [ "listopia" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/listopia/2021-04-11/listopia-20210411-git.tgz"; - sha256 = "0jd3mdv0ia8mfgdbpndzm3rdgc6nn9d9xpjzqjx582qhbnc0yji0"; - system = "listopia"; - asd = "listopia"; - }); - systems = [ "listopia" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - listopia-bench = (build-asdf-system { - pname = "listopia-bench"; - version = "20210411-git"; - asds = [ "listopia-bench" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/listopia/2021-04-11/listopia-20210411-git.tgz"; - sha256 = "0jd3mdv0ia8mfgdbpndzm3rdgc6nn9d9xpjzqjx582qhbnc0yji0"; - system = "listopia-bench"; - asd = "listopia-bench"; - }); - systems = [ "listopia-bench" ]; - lispLibs = [ (getAttr "listopia" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "trivial-benchmark" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - liter = (build-asdf-system { - pname = "liter"; - version = "20211020-git"; - asds = [ "liter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/colliflower/2021-10-20/colliflower-20211020-git.tgz"; - sha256 = "1fzn9s7wm7wmffrdm21lpvry9jb320456cmmprn976a533lp704r"; - system = "liter"; - asd = "liter"; - }); - systems = [ "liter" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "iterate" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - literate-demo = (build-asdf-system { - pname = "literate-demo"; - version = "20230618-git"; - asds = [ "literate-demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/literate-lisp/2023-06-18/literate-lisp-20230618-git.tgz"; - sha256 = "0smxf0a62dnwcfxsbsdkx4n5nqx9dlxdz6c2vfivxpqld6d6ap02"; - system = "literate-demo"; - asd = "literate-demo"; - }); - systems = [ "literate-demo" ]; - lispLibs = [ (getAttr "iterate" self) (getAttr "literate-lisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - literate-lisp = (build-asdf-system { - pname = "literate-lisp"; - version = "20230618-git"; - asds = [ "literate-lisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/literate-lisp/2023-06-18/literate-lisp-20230618-git.tgz"; - sha256 = "0smxf0a62dnwcfxsbsdkx4n5nqx9dlxdz6c2vfivxpqld6d6ap02"; - system = "literate-lisp"; - asd = "literate-lisp"; - }); - systems = [ "literate-lisp" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - litterae = (build-asdf-system { - pname = "litterae"; - version = "20200715-git"; - asds = [ "litterae" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/litterae/2020-07-15/litterae-20200715-git.tgz"; - sha256 = "05q6apkcxacis4llq8xjp468yg5v6za0ispcy5wqsb44ic0vhmsl"; - system = "litterae"; - asd = "litterae"; - }); - systems = [ "litterae" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "_3bmd-ext-code-blocks" self) (getAttr "cl-yaml" self) (getAttr "docparser" self) (getAttr "lsx" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - litterae-test-system = (build-asdf-system { - pname = "litterae-test-system"; - version = "20200715-git"; - asds = [ "litterae-test-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/litterae/2020-07-15/litterae-20200715-git.tgz"; - sha256 = "05q6apkcxacis4llq8xjp468yg5v6za0ispcy5wqsb44ic0vhmsl"; - system = "litterae-test-system"; - asd = "litterae-test-system"; - }); - systems = [ "litterae-test-system" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - livesupport = (build-asdf-system { - pname = "livesupport"; - version = "release-quicklisp-71e6e412-git"; - asds = [ "livesupport" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/livesupport/2019-05-21/livesupport-release-quicklisp-71e6e412-git.tgz"; - sha256 = "1rvnl0mncylbx63608pz5llss7y92j7z3ydambk9mcnjg2mjaapg"; - system = "livesupport"; - asd = "livesupport"; - }); - systems = [ "livesupport" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lla = (build-asdf-system { - pname = "lla"; - version = "20241012-git"; - asds = [ "lla" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lla/2024-10-12/lla-20241012-git.tgz"; - sha256 = "19j11z8m00ry2bfn3ahai155b6qz995qqg7ipzvjdr05sj4gfb58"; - system = "lla"; - asd = "lla"; - }); - systems = [ "lla" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cffi" self) (getAttr "let-plus" self) (getAttr "num-utils" self) (getAttr "select" self) ]; - meta = {}; - }); - lmdb = (build-asdf-system { - pname = "lmdb"; - version = "20230214-git"; - asds = [ "lmdb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lmdb/2023-02-14/lmdb-20230214-git.tgz"; - sha256 = "1mccswfdgg7pxvnq3rds2zh0257853zqf81q4igfpjh5lhg3czgh"; - system = "lmdb"; - asd = "lmdb"; - }); - systems = [ "lmdb" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-reexport" self) (getAttr "mgl-pax" self) (getAttr "osicat" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lml = (build-asdf-system { - pname = "lml"; - version = "20150923-git"; - asds = [ "lml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lml/2015-09-23/lml-20150923-git.tgz"; - sha256 = "1s8v9p08vwl08y6ssxn4l088zz57d6fr13lzdz93i9jb8w8884wk"; - system = "lml"; - asd = "lml"; - }); - systems = [ "lml" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lml-tests = (build-asdf-system { - pname = "lml-tests"; - version = "20150923-git"; - asds = [ "lml-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lml/2015-09-23/lml-20150923-git.tgz"; - sha256 = "1s8v9p08vwl08y6ssxn4l088zz57d6fr13lzdz93i9jb8w8884wk"; - system = "lml-tests"; - asd = "lml-tests"; - }); - systems = [ "lml-tests" ]; - lispLibs = [ (getAttr "lml" self) (getAttr "rt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lml2 = (build-asdf-system { - pname = "lml2"; - version = "20150923-git"; - asds = [ "lml2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lml2/2015-09-23/lml2-20150923-git.tgz"; - sha256 = "0v4d30x5zq1asp4r91nrzljpk2pm1plr0jns7a5wrf1n9fay57a6"; - system = "lml2"; - asd = "lml2"; - }); - systems = [ "lml2" ]; - lispLibs = [ (getAttr "kmrcl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lml2-tests = (build-asdf-system { - pname = "lml2-tests"; - version = "20150923-git"; - asds = [ "lml2-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lml2/2015-09-23/lml2-20150923-git.tgz"; - sha256 = "0v4d30x5zq1asp4r91nrzljpk2pm1plr0jns7a5wrf1n9fay57a6"; - system = "lml2-tests"; - asd = "lml2-tests"; - }); - systems = [ "lml2-tests" ]; - lispLibs = [ (getAttr "lml2" self) (getAttr "rt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - local-package-aliases = (build-asdf-system { - pname = "local-package-aliases"; - version = "20201220-git"; - asds = [ "local-package-aliases" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/local-package-aliases/2020-12-20/local-package-aliases-20201220-git.tgz"; - sha256 = "01knnxnximj2qyg8lhv0ijw69hfwqbfbmgvfjwnm7jbdgcp9wxnr"; - system = "local-package-aliases"; - asd = "local-package-aliases"; - }); - systems = [ "local-package-aliases" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - local-time = (build-asdf-system { - pname = "local-time"; - version = "20241012-git"; - asds = [ "local-time" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/local-time/2024-10-12/local-time-20241012-git.tgz"; - sha256 = "0jb1mb5zs4ryiah8zjzhpln1z686mfmpmvg1phgpr2mh9vvlgjk2"; - system = "local-time"; - asd = "local-time"; - }); - systems = [ "local-time" ]; - lispLibs = [ ]; - meta = {}; - }); - local-time-duration = (build-asdf-system { - pname = "local-time-duration"; - version = "20180430-git"; - asds = [ "local-time-duration" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/local-time-duration/2018-04-30/local-time-duration-20180430-git.tgz"; - sha256 = "0f13mg18lv31lclz9jvqyj8d85p1jj1366nlld8m3dxnnwsbbkd6"; - system = "local-time-duration"; - asd = "local-time-duration"; - }); - systems = [ "local-time-duration" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "esrap" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - log4cl = (build-asdf-system { - pname = "log4cl"; - version = "20230618-git"; - asds = [ "log4cl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/log4cl/2023-06-18/log4cl-20230618-git.tgz"; - sha256 = "0n119sy35k9yl4n18az1sw9a7saa5jh3v44863b305by1p5xdy7k"; - system = "log4cl"; - asd = "log4cl"; - }); - systems = [ "log4cl" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = {}; - }); - log4cl-examples = (build-asdf-system { - pname = "log4cl-examples"; - version = "20230618-git"; - asds = [ "log4cl-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/log4cl/2023-06-18/log4cl-20230618-git.tgz"; - sha256 = "0n119sy35k9yl4n18az1sw9a7saa5jh3v44863b305by1p5xdy7k"; - system = "log4cl-examples"; - asd = "log4cl-examples"; - }); - systems = [ "log4cl-examples" ]; - lispLibs = [ (getAttr "log4cl" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - log4cl-extras = (build-asdf-system { - pname = "log4cl-extras"; - version = "20241012-git"; - asds = [ "log4cl-extras" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/log4cl-extras/2024-10-12/log4cl-extras-20241012-git.tgz"; - sha256 = "17p8y884163j0gab0idra297kivzdgagl2im0gkmdhgrh0dw3b53"; - system = "log4cl-extras"; - asd = "log4cl-extras"; - }); - systems = [ "log4cl-extras" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "_40ants-doc" self) (getAttr "alexandria" self) (getAttr "cl-strings" self) (getAttr "dissect" self) (getAttr "global-vars" self) (getAttr "jonathan" self) (getAttr "local-time" self) (getAttr "log4cl" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) (getAttr "with-output-to-stream" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - log4cl-extras-test = (build-asdf-system { - pname = "log4cl-extras-test"; - version = "20241012-git"; - asds = [ "log4cl-extras-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/log4cl-extras/2024-10-12/log4cl-extras-20241012-git.tgz"; - sha256 = "17p8y884163j0gab0idra297kivzdgagl2im0gkmdhgrh0dw3b53"; - system = "log4cl-extras-test"; - asd = "log4cl-extras-test"; - }); - systems = [ "log4cl-extras-test" ]; - lispLibs = [ (getAttr "hamcrest" self) (getAttr "jonathan" self) (getAttr "rove" self) (getAttr "secret-values" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - log4cl_dot_log4slime = (build-asdf-system { - pname = "log4cl.log4slime"; - version = "20230618-git"; - asds = [ "log4cl.log4slime" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/log4cl/2023-06-18/log4cl-20230618-git.tgz"; - sha256 = "0n119sy35k9yl4n18az1sw9a7saa5jh3v44863b305by1p5xdy7k"; - system = "log4cl.log4slime"; - asd = "log4cl.log4slime"; - }); - systems = [ "log4cl.log4slime" ]; - lispLibs = [ (getAttr "log4cl" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - log4cl_dot_log4sly = (build-asdf-system { - pname = "log4cl.log4sly"; - version = "20230618-git"; - asds = [ "log4cl.log4sly" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/log4cl/2023-06-18/log4cl-20230618-git.tgz"; - sha256 = "0n119sy35k9yl4n18az1sw9a7saa5jh3v44863b305by1p5xdy7k"; - system = "log4cl.log4sly"; - asd = "log4cl.log4sly"; - }); - systems = [ "log4cl.log4sly" ]; - lispLibs = [ (getAttr "log4cl" self) (getAttr "slynk" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - log5 = (build-asdf-system { - pname = "log5"; - version = "20110619-git"; - asds = [ "log5" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/log5/2011-06-19/log5-20110619-git.tgz"; - sha256 = "0f7qhhphijwk6a4hq18gpgifld7hwwpma6md845hgjmpvyqvrw2g"; - system = "log5"; - asd = "log5"; - }); - systems = [ "log5" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lorem-ipsum = (build-asdf-system { - pname = "lorem-ipsum"; - version = "20181018-git"; - asds = [ "lorem-ipsum" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lorem-ipsum/2018-10-18/lorem-ipsum-20181018-git.tgz"; - sha256 = "1530qq0bk3xr25m77q96pbi1idnxdkax8cwmvq4ch03rfjy34j7n"; - system = "lorem-ipsum"; - asd = "lorem-ipsum"; - }); - systems = [ "lorem-ipsum" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lowlight = (build-asdf-system { - pname = "lowlight"; - version = "20131211-git"; - asds = [ "lowlight" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lowlight/2013-12-11/lowlight-20131211-git.tgz"; - sha256 = "1i27hdac7aqb27rn5cslpf5lwvkrfz52b6rf7zqq0fi42zmvgb4p"; - system = "lowlight"; - asd = "lowlight"; - }); - systems = [ "lowlight" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "cl-who" self) (getAttr "graylex" self) (getAttr "spinneret" self) (getAttr "yacc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lowlight_dot_doc = (build-asdf-system { - pname = "lowlight.doc"; - version = "20131211-git"; - asds = [ "lowlight.doc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lowlight/2013-12-11/lowlight-20131211-git.tgz"; - sha256 = "1i27hdac7aqb27rn5cslpf5lwvkrfz52b6rf7zqq0fi42zmvgb4p"; - system = "lowlight.doc"; - asd = "lowlight.doc"; - }); - systems = [ "lowlight.doc" ]; - lispLibs = [ (getAttr "cl-gendoc" self) (getAttr "lowlight" self) (getAttr "lowlight_dot_tests" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lowlight_dot_old = (build-asdf-system { - pname = "lowlight.old"; - version = "20131211-git"; - asds = [ "lowlight.old" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lowlight/2013-12-11/lowlight-20131211-git.tgz"; - sha256 = "1i27hdac7aqb27rn5cslpf5lwvkrfz52b6rf7zqq0fi42zmvgb4p"; - system = "lowlight.old"; - asd = "lowlight.old"; - }); - systems = [ "lowlight.old" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "cl-who" self) (getAttr "spinneret" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lowlight_dot_tests = (build-asdf-system { - pname = "lowlight.tests"; - version = "20131211-git"; - asds = [ "lowlight.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lowlight/2013-12-11/lowlight-20131211-git.tgz"; - sha256 = "1i27hdac7aqb27rn5cslpf5lwvkrfz52b6rf7zqq0fi42zmvgb4p"; - system = "lowlight.tests"; - asd = "lowlight.tests"; - }); - systems = [ "lowlight.tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "lowlight" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lparallel = (build-asdf-system { - pname = "lparallel"; - version = "20160825-git"; - asds = [ "lparallel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lparallel/2016-08-25/lparallel-20160825-git.tgz"; - sha256 = "0g0aylrbbrqsz0ahmwhvnk4cmc2931fllbpcfgzsprwnqqd7vwq9"; - system = "lparallel"; - asd = "lparallel"; - }); - systems = [ "lparallel" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) ]; - meta = {}; - }); - lparallel-bench = (build-asdf-system { - pname = "lparallel-bench"; - version = "20160825-git"; - asds = [ "lparallel-bench" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lparallel/2016-08-25/lparallel-20160825-git.tgz"; - sha256 = "0g0aylrbbrqsz0ahmwhvnk4cmc2931fllbpcfgzsprwnqqd7vwq9"; - system = "lparallel-bench"; - asd = "lparallel-bench"; - }); - systems = [ "lparallel-bench" ]; - lispLibs = [ (getAttr "lparallel" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lparallel-test = (build-asdf-system { - pname = "lparallel-test"; - version = "20160825-git"; - asds = [ "lparallel-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lparallel/2016-08-25/lparallel-20160825-git.tgz"; - sha256 = "0g0aylrbbrqsz0ahmwhvnk4cmc2931fllbpcfgzsprwnqqd7vwq9"; - system = "lparallel-test"; - asd = "lparallel-test"; - }); - systems = [ "lparallel-test" ]; - lispLibs = [ (getAttr "lparallel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lquery = (build-asdf-system { - pname = "lquery"; - version = "20231021-git"; - asds = [ "lquery" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lquery/2023-10-21/lquery-20231021-git.tgz"; - sha256 = "124cjp4a99cicdk18rwz2slcyzvm982saddrvqcr97fi4i2nhnsg"; - system = "lquery"; - asd = "lquery"; - }); - systems = [ "lquery" ]; - lispLibs = [ (getAttr "array-utils" self) (getAttr "clss" self) (getAttr "form-fiddle" self) (getAttr "plump" self) ]; - meta = {}; - }); - lquery-test = (build-asdf-system { - pname = "lquery-test"; - version = "20231021-git"; - asds = [ "lquery-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lquery/2023-10-21/lquery-20231021-git.tgz"; - sha256 = "124cjp4a99cicdk18rwz2slcyzvm982saddrvqcr97fi4i2nhnsg"; - system = "lquery-test"; - asd = "lquery-test"; - }); - systems = [ "lquery-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "lquery" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lracer = (build-asdf-system { - pname = "lracer"; - version = "20241012-git"; - asds = [ "lracer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/racer/2024-10-12/racer-20241012-git.tgz"; - sha256 = "120x046c6vcrj70vb6ryf04mwbr8c6a15llb68x7h1siij8vwgvk"; - system = "lracer"; - asd = "lracer"; - }); - systems = [ "lracer" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lredis = (build-asdf-system { - pname = "lredis"; - version = "20141106-git"; - asds = [ "lredis" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lredis/2014-11-06/lredis-20141106-git.tgz"; - sha256 = "08srvlys0fyslfpmhc740cana7fkxm2kc7mxds4083wgxw3prhf2"; - system = "lredis"; - asd = "lredis"; - }); - systems = [ "lredis" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "babel-streams" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lru-cache = (build-asdf-system { - pname = "lru-cache"; - version = "20241012-git"; - asds = [ "lru-cache" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lru-cache/2024-10-12/lru-cache-20241012-git.tgz"; - sha256 = "035pl11j1l129akgf33w5c0b8c6gxw1xpj54r0fzxz3dw7cs8pg1"; - system = "lru-cache"; - asd = "lru-cache"; - }); - systems = [ "lru-cache" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lru-cache-test = (build-asdf-system { - pname = "lru-cache-test"; - version = "20241012-git"; - asds = [ "lru-cache-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lru-cache/2024-10-12/lru-cache-20241012-git.tgz"; - sha256 = "035pl11j1l129akgf33w5c0b8c6gxw1xpj54r0fzxz3dw7cs8pg1"; - system = "lru-cache-test"; - asd = "lru-cache-test"; - }); - systems = [ "lru-cache-test" ]; - lispLibs = [ (getAttr "lru-cache" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lsx = (build-asdf-system { - pname = "lsx"; - version = "20220220-git"; - asds = [ "lsx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lsx/2022-02-20/lsx-20220220-git.tgz"; - sha256 = "1pdq6csr8pkzcq2zkhhm6wkp9zxx2aypjd16rcw4q43mff09y041"; - system = "lsx"; - asd = "lsx"; - }); - systems = [ "lsx" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ltk = (build-asdf-system { - pname = "ltk"; - version = "20221106-git"; - asds = [ "ltk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ltk/2022-11-06/ltk-20221106-git.tgz"; - sha256 = "0vqmdq3k235hd8d9cg0ipv0kw28aiydvr9j1igfnrs1ns9sm79va"; - system = "ltk"; - asd = "ltk"; - }); - systems = [ "ltk" ]; - lispLibs = [ ]; - meta = {}; - }); - ltk-mw = (build-asdf-system { - pname = "ltk-mw"; - version = "20221106-git"; - asds = [ "ltk-mw" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ltk/2022-11-06/ltk-20221106-git.tgz"; - sha256 = "0vqmdq3k235hd8d9cg0ipv0kw28aiydvr9j1igfnrs1ns9sm79va"; - system = "ltk-mw"; - asd = "ltk-mw"; - }); - systems = [ "ltk-mw" ]; - lispLibs = [ (getAttr "ltk" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ltk-remote = (build-asdf-system { - pname = "ltk-remote"; - version = "20221106-git"; - asds = [ "ltk-remote" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ltk/2022-11-06/ltk-20221106-git.tgz"; - sha256 = "0vqmdq3k235hd8d9cg0ipv0kw28aiydvr9j1igfnrs1ns9sm79va"; - system = "ltk-remote"; - asd = "ltk-remote"; - }); - systems = [ "ltk-remote" ]; - lispLibs = [ (getAttr "ltk" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lucene-in-action-tests = (build-asdf-system { - pname = "lucene-in-action-tests"; - version = "20180228-git"; - asds = [ "lucene-in-action-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/montezuma/2018-02-28/montezuma-20180228-git.tgz"; - sha256 = "0svmvsbsirydk3c1spzfvj8qmkzcs9i69anpfvk1843i62wb7x2c"; - system = "lucene-in-action-tests"; - asd = "lucene-in-action-tests"; - }); - systems = [ "lucene-in-action-tests" ]; - lispLibs = [ (getAttr "lift" self) (getAttr "montezuma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lunamech-matrix-api = (build-asdf-system { - pname = "lunamech-matrix-api"; - version = "20230214-git"; - asds = [ "lunamech-matrix-api" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lunamech-matrix-api/2023-02-14/lunamech-matrix-api-20230214-git.tgz"; - sha256 = "0a664qq4m5gk4iv5ck63gmsl3218jhjsalawklj56wn2pw0cf8a0"; - system = "lunamech-matrix-api"; - asd = "lunamech-matrix-api"; - }); - systems = [ "lunamech-matrix-api" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "closer-mop" self) (getAttr "dexador" self) (getAttr "do-urlencode" self) (getAttr "drakma" self) (getAttr "jonathan" self) (getAttr "plump" self) (getAttr "quri" self) (getAttr "reader" self) (getAttr "shasht" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lw-compat = (build-asdf-system { - pname = "lw-compat"; - version = "20160318-git"; - asds = [ "lw-compat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lw-compat/2016-03-18/lw-compat-20160318-git.tgz"; - sha256 = "131rq5k2mlv9bfhmafiv6nfsivl4cxx13d9wr06v5jrqnckh4aav"; - system = "lw-compat"; - asd = "lw-compat"; - }); - systems = [ "lw-compat" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lyrics = (build-asdf-system { - pname = "lyrics"; - version = "20210807-git"; - asds = [ "lyrics" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lyrics/2021-08-07/lyrics-20210807-git.tgz"; - sha256 = "1xdhl53i9pim2mbviwqahlkgfsja7ihyvvrwz8q22ljv6bnb6011"; - system = "lyrics"; - asd = "lyrics"; - }); - systems = [ "lyrics" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "defmemo" self) (getAttr "drakma" self) (getAttr "lquery" self) (getAttr "plump" self) (getAttr "sqlite" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lzlib = (build-asdf-system { - pname = "lzlib"; - version = "20230618-git"; - asds = [ "lzlib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-lzlib/2023-06-18/cl-lzlib-20230618-git.tgz"; - sha256 = "1nb2g6a7l1qzm1bwv8b15nflgv8rv478x0n7viv6rlwzgqs5q3b8"; - system = "lzlib"; - asd = "lzlib"; - }); - systems = [ "lzlib" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-octet-streams" self) (getAttr "lparallel" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - lzlib-tests = (build-asdf-system { - pname = "lzlib-tests"; - version = "20230618-git"; - asds = [ "lzlib-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-lzlib/2023-06-18/cl-lzlib-20230618-git.tgz"; - sha256 = "1nb2g6a7l1qzm1bwv8b15nflgv8rv478x0n7viv6rlwzgqs5q3b8"; - system = "lzlib-tests"; - asd = "lzlib-tests"; - }); - systems = [ "lzlib-tests" ]; - lispLibs = [ (getAttr "cl-octet-streams" self) (getAttr "fiveam" self) (getAttr "lzlib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - machine-state = (build-asdf-system { - pname = "machine-state"; - version = "20241012-git"; - asds = [ "machine-state" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/machine-state/2024-10-12/machine-state-20241012-git.tgz"; - sha256 = "1zmag6j9zfpnv9xfdjzb6dfg3jzvhandm1plyv50i619p0w0nagk"; - system = "machine-state"; - asd = "machine-state"; - }); - systems = [ "machine-state" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "pathname-utils" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - macro-html = (build-asdf-system { - pname = "macro-html"; - version = "20151218-git"; - asds = [ "macro-html" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/macro-html/2015-12-18/macro-html-20151218-git.tgz"; - sha256 = "05gzgijz8r3dw3ilz7d5i0g0mbcyv9k8w2dgvw7n478njp1gfj4b"; - system = "macro-html"; - asd = "macro-html"; - }); - systems = [ "macro-html" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - macro-level = (build-asdf-system { - pname = "macro-level"; - version = "1.1"; - asds = [ "macro-level" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/macro-level/2023-10-21/macro-level_1.1.tgz"; - sha256 = "1jcidyf4kfzzj5vj4i3l1vw0sbj9njaminb6j1bcq70y9w15qm68"; - system = "macro-level"; - asd = "macro-level"; - }); - systems = [ "macro-level" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - macro-level__tests = (build-asdf-system { - pname = "macro-level_tests"; - version = "1.1"; - asds = [ "macro-level_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/macro-level/2023-10-21/macro-level_1.1.tgz"; - sha256 = "1jcidyf4kfzzj5vj4i3l1vw0sbj9njaminb6j1bcq70y9w15qm68"; - system = "macro-level_tests"; - asd = "macro-level_tests"; - }); - systems = [ "macro-level_tests" ]; - lispLibs = [ (getAttr "macro-level" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - macrodynamics = (build-asdf-system { - pname = "macrodynamics"; - version = "20180228-git"; - asds = [ "macrodynamics" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/macrodynamics/2018-02-28/macrodynamics-20180228-git.tgz"; - sha256 = "1ysgin8lzd4fdl5c63v3ga9v6lzk3gyl1h8jhl0ar6wyhd3023l4"; - system = "macrodynamics"; - asd = "macrodynamics"; - }); - systems = [ "macrodynamics" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - macroexpand-dammit = (build-asdf-system { - pname = "macroexpand-dammit"; - version = "20131111-http"; - asds = [ "macroexpand-dammit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/macroexpand-dammit/2013-11-11/macroexpand-dammit-20131111-http.tgz"; - sha256 = "10avpq3qffrc51hrfjwp3vi5vv9b1aip1dnwncnlc3yd498b3pfl"; - system = "macroexpand-dammit"; - asd = "macroexpand-dammit"; - }); - systems = [ "macroexpand-dammit" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - madeira-port = (build-asdf-system { - pname = "madeira-port"; - version = "20150709-git"; - asds = [ "madeira-port" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/madeira-port/2015-07-09/madeira-port-20150709-git.tgz"; - sha256 = "0zl6i11vm1akr0382zh582v3vkxjwmabsnfjcfgrp2wbkq4mvdgq"; - system = "madeira-port"; - asd = "madeira-port"; - }); - systems = [ "madeira-port" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - madeira-port-tests = (build-asdf-system { - pname = "madeira-port-tests"; - version = "20150709-git"; - asds = [ "madeira-port-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/madeira-port/2015-07-09/madeira-port-20150709-git.tgz"; - sha256 = "0zl6i11vm1akr0382zh582v3vkxjwmabsnfjcfgrp2wbkq4mvdgq"; - system = "madeira-port-tests"; - asd = "madeira-port"; - }); - systems = [ "madeira-port-tests" ]; - lispLibs = [ (getAttr "eos" self) (getAttr "madeira-port" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - magic-ed = (build-asdf-system { - pname = "magic-ed"; - version = "20200325-git"; - asds = [ "magic-ed" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/magic-ed/2020-03-25/magic-ed-20200325-git.tgz"; - sha256 = "1j6il4lif0dy6hqiz6n91yl8dvii9pk1i9vz0faq5mnr42mr7i5f"; - system = "magic-ed"; - asd = "magic-ed"; - }); - systems = [ "magic-ed" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - magicffi = (build-asdf-system { - pname = "magicffi"; - version = "20210531-git"; - asds = [ "magicffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/magicffi/2021-05-31/magicffi-20210531-git.tgz"; - sha256 = "0l2b2irpb19b9pyxbmkxi4i5y6crx8nk7qrbihsdqahlkrwsk1il"; - system = "magicffi"; - asd = "magicffi"; - }); - systems = [ "magicffi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - magicl = (build-asdf-system { - pname = "magicl"; - version = "v0.11.0"; - asds = [ "magicl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/magicl/2024-10-12/magicl-v0.11.0.tgz"; - sha256 = "10scw5qhrgjhfrlia5iqn2yy2zj1d57m45g479vg56lw849whscw"; - system = "magicl"; - asd = "magicl"; - }); - systems = [ "magicl" ]; - lispLibs = [ (getAttr "abstract-classes" self) (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-libffi" self) (getAttr "interface" self) (getAttr "policy-cond" self) (getAttr "static-vectors" self) (getAttr "trivial-garbage" self) ]; - meta = { - broken = true; - hydraPlatforms = [ ]; - }; - }); - magicl-examples = (build-asdf-system { - pname = "magicl-examples"; - version = "v0.11.0"; - asds = [ "magicl-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/magicl/2024-10-12/magicl-v0.11.0.tgz"; - sha256 = "10scw5qhrgjhfrlia5iqn2yy2zj1d57m45g479vg56lw849whscw"; - system = "magicl-examples"; - asd = "magicl-examples"; - }); - systems = [ "magicl-examples" ]; - lispLibs = [ (getAttr "magicl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - magicl-gen = (build-asdf-system { - pname = "magicl-gen"; - version = "v0.11.0"; - asds = [ "magicl-gen" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/magicl/2024-10-12/magicl-v0.11.0.tgz"; - sha256 = "10scw5qhrgjhfrlia5iqn2yy2zj1d57m45g479vg56lw849whscw"; - system = "magicl-gen"; - asd = "magicl-gen"; - }); - systems = [ "magicl-gen" ]; - lispLibs = [ (getAttr "abstract-classes" self) (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-libffi" self) (getAttr "interface" self) (getAttr "policy-cond" self) (getAttr "static-vectors" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - magicl-tests = (build-asdf-system { - pname = "magicl-tests"; - version = "v0.11.0"; - asds = [ "magicl-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/magicl/2024-10-12/magicl-v0.11.0.tgz"; - sha256 = "10scw5qhrgjhfrlia5iqn2yy2zj1d57m45g479vg56lw849whscw"; - system = "magicl-tests"; - asd = "magicl-tests"; - }); - systems = [ "magicl-tests" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "fiasco" self) (getAttr "magicl" self) (getAttr "magicl-examples" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - magicl-transcendental = (build-asdf-system { - pname = "magicl-transcendental"; - version = "v0.11.0"; - asds = [ "magicl-transcendental" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/magicl/2024-10-12/magicl-v0.11.0.tgz"; - sha256 = "10scw5qhrgjhfrlia5iqn2yy2zj1d57m45g479vg56lw849whscw"; - system = "magicl-transcendental"; - asd = "magicl-transcendental"; - }); - systems = [ "magicl-transcendental" ]; - lispLibs = [ (getAttr "abstract-classes" self) (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-libffi" self) (getAttr "interface" self) (getAttr "policy-cond" self) (getAttr "static-vectors" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden = (build-asdf-system { - pname = "maiden"; - version = "20241012-git"; - asds = [ "maiden" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden"; - asd = "maiden"; - }); - systems = [ "maiden" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "deeds" self) (getAttr "documentation-utils" self) (getAttr "form-fiddle" self) (getAttr "lambda-fiddle" self) (getAttr "trivial-garbage" self) (getAttr "trivial-indent" self) (getAttr "uuid" self) (getAttr "verbose" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-accounts = (build-asdf-system { - pname = "maiden-accounts"; - version = "20241012-git"; - asds = [ "maiden-accounts" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-accounts"; - asd = "maiden-accounts"; - }); - systems = [ "maiden-accounts" ]; - lispLibs = [ (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-activatable = (build-asdf-system { - pname = "maiden-activatable"; - version = "20241012-git"; - asds = [ "maiden-activatable" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-activatable"; - asd = "maiden-activatable"; - }); - systems = [ "maiden-activatable" ]; - lispLibs = [ (getAttr "maiden" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-api-access = (build-asdf-system { - pname = "maiden-api-access"; - version = "20241012-git"; - asds = [ "maiden-api-access" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-api-access"; - asd = "maiden-api-access"; - }); - systems = [ "maiden-api-access" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "jsown" self) (getAttr "maiden" self) (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-blocker = (build-asdf-system { - pname = "maiden-blocker"; - version = "20241012-git"; - asds = [ "maiden-blocker" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-blocker"; - asd = "maiden-blocker"; - }); - systems = [ "maiden-blocker" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-channel-relay = (build-asdf-system { - pname = "maiden-channel-relay"; - version = "20241012-git"; - asds = [ "maiden-channel-relay" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-channel-relay"; - asd = "maiden-channel-relay"; - }); - systems = [ "maiden-channel-relay" ]; - lispLibs = [ (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-chatlog = (build-asdf-system { - pname = "maiden-chatlog"; - version = "20241012-git"; - asds = [ "maiden-chatlog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-chatlog"; - asd = "maiden-chatlog"; - }); - systems = [ "maiden-chatlog" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) (getAttr "postmodern" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-client-entities = (build-asdf-system { - pname = "maiden-client-entities"; - version = "20241012-git"; - asds = [ "maiden-client-entities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-client-entities"; - asd = "maiden-client-entities"; - }); - systems = [ "maiden-client-entities" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "maiden" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-commands = (build-asdf-system { - pname = "maiden-commands"; - version = "20241012-git"; - asds = [ "maiden-commands" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-commands"; - asd = "maiden-commands"; - }); - systems = [ "maiden-commands" ]; - lispLibs = [ (getAttr "lambda-fiddle" self) (getAttr "maiden" self) (getAttr "maiden-client-entities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-core-manager = (build-asdf-system { - pname = "maiden-core-manager"; - version = "20241012-git"; - asds = [ "maiden-core-manager" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-core-manager"; - asd = "maiden-core-manager"; - }); - systems = [ "maiden-core-manager" ]; - lispLibs = [ (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-counter = (build-asdf-system { - pname = "maiden-counter"; - version = "20241012-git"; - asds = [ "maiden-counter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-counter"; - asd = "maiden-counter"; - }); - systems = [ "maiden-counter" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "maiden-activatable" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-crimes = (build-asdf-system { - pname = "maiden-crimes"; - version = "20241012-git"; - asds = [ "maiden-crimes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-crimes"; - asd = "maiden-crimes"; - }); - systems = [ "maiden-crimes" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "maiden-api-access" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-dictionary = (build-asdf-system { - pname = "maiden-dictionary"; - version = "20241012-git"; - asds = [ "maiden-dictionary" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-dictionary"; - asd = "maiden-dictionary"; - }); - systems = [ "maiden-dictionary" ]; - lispLibs = [ (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) (getAttr "oxenfurt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-emoticon = (build-asdf-system { - pname = "maiden-emoticon"; - version = "20241012-git"; - asds = [ "maiden-emoticon" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-emoticon"; - asd = "maiden-emoticon"; - }); - systems = [ "maiden-emoticon" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "maiden-activatable" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-help = (build-asdf-system { - pname = "maiden-help"; - version = "20241012-git"; - asds = [ "maiden-help" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-help"; - asd = "maiden-help"; - }); - systems = [ "maiden-help" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-irc = (build-asdf-system { - pname = "maiden-irc"; - version = "20241012-git"; - asds = [ "maiden-irc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-irc"; - asd = "maiden-irc"; - }); - systems = [ "maiden-irc" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-base64" self) (getAttr "cl-ppcre" self) (getAttr "form-fiddle" self) (getAttr "lambda-fiddle" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-networking" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-lastfm = (build-asdf-system { - pname = "maiden-lastfm"; - version = "20241012-git"; - asds = [ "maiden-lastfm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-lastfm"; - asd = "maiden-lastfm"; - }); - systems = [ "maiden-lastfm" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "maiden-api-access" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-lichat = (build-asdf-system { - pname = "maiden-lichat"; - version = "20241012-git"; - asds = [ "maiden-lichat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-lichat"; - asd = "maiden-lichat"; - }); - systems = [ "maiden-lichat" ]; - lispLibs = [ (getAttr "lichat-protocol" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-networking" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-location = (build-asdf-system { - pname = "maiden-location"; - version = "20241012-git"; - asds = [ "maiden-location" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-location"; - asd = "maiden-location"; - }); - systems = [ "maiden-location" ]; - lispLibs = [ (getAttr "maiden-api-access" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-lookup = (build-asdf-system { - pname = "maiden-lookup"; - version = "20241012-git"; - asds = [ "maiden-lookup" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-lookup"; - asd = "maiden-lookup"; - }); - systems = [ "maiden-lookup" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "lquery" self) (getAttr "maiden-api-access" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-markov = (build-asdf-system { - pname = "maiden-markov"; - version = "20241012-git"; - asds = [ "maiden-markov" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-markov"; - asd = "maiden-markov"; - }); - systems = [ "maiden-markov" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-ppcre" self) (getAttr "fast-io" self) (getAttr "maiden-activatable" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-medals = (build-asdf-system { - pname = "maiden-medals"; - version = "20241012-git"; - asds = [ "maiden-medals" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-medals"; - asd = "maiden-medals"; - }); - systems = [ "maiden-medals" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "maiden-accounts" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-networking = (build-asdf-system { - pname = "maiden-networking"; - version = "20241012-git"; - asds = [ "maiden-networking" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-networking"; - asd = "maiden-networking"; - }); - systems = [ "maiden-networking" ]; - lispLibs = [ (getAttr "cl_plus_ssl" self) (getAttr "maiden" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-notify = (build-asdf-system { - pname = "maiden-notify"; - version = "20241012-git"; - asds = [ "maiden-notify" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-notify"; - asd = "maiden-notify"; - }); - systems = [ "maiden-notify" ]; - lispLibs = [ (getAttr "maiden-accounts" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-permissions = (build-asdf-system { - pname = "maiden-permissions"; - version = "20241012-git"; - asds = [ "maiden-permissions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-permissions"; - asd = "maiden-permissions"; - }); - systems = [ "maiden-permissions" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "documentation-utils" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-relay = (build-asdf-system { - pname = "maiden-relay"; - version = "20241012-git"; - asds = [ "maiden-relay" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-relay"; - asd = "maiden-relay"; - }); - systems = [ "maiden-relay" ]; - lispLibs = [ (getAttr "maiden-networking" self) (getAttr "maiden-serialize" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-serialize = (build-asdf-system { - pname = "maiden-serialize"; - version = "20241012-git"; - asds = [ "maiden-serialize" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-serialize"; - asd = "maiden-serialize"; - }); - systems = [ "maiden-serialize" ]; - lispLibs = [ (getAttr "cl-store" self) (getAttr "gzip-stream" self) (getAttr "maiden" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-silly = (build-asdf-system { - pname = "maiden-silly"; - version = "20241012-git"; - asds = [ "maiden-silly" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-silly"; - asd = "maiden-silly"; - }); - systems = [ "maiden-silly" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "lquery" self) (getAttr "maiden-activatable" self) (getAttr "maiden-api-access" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-storage = (build-asdf-system { - pname = "maiden-storage"; - version = "20241012-git"; - asds = [ "maiden-storage" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-storage"; - asd = "maiden-storage"; - }); - systems = [ "maiden-storage" ]; - lispLibs = [ (getAttr "maiden" self) (getAttr "pathname-utils" self) (getAttr "ubiquitous-concurrent" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-talk = (build-asdf-system { - pname = "maiden-talk"; - version = "20241012-git"; - asds = [ "maiden-talk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-talk"; - asd = "maiden-talk"; - }); - systems = [ "maiden-talk" ]; - lispLibs = [ (getAttr "array-utils" self) (getAttr "cl-mixed-mpg123" self) (getAttr "drakma" self) (getAttr "harmony" self) (getAttr "maiden-commands" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-throttle = (build-asdf-system { - pname = "maiden-throttle"; - version = "20241012-git"; - asds = [ "maiden-throttle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-throttle"; - asd = "maiden-throttle"; - }); - systems = [ "maiden-throttle" ]; - lispLibs = [ (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-time = (build-asdf-system { - pname = "maiden-time"; - version = "20241012-git"; - asds = [ "maiden-time" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-time"; - asd = "maiden-time"; - }); - systems = [ "maiden-time" ]; - lispLibs = [ (getAttr "maiden-api-access" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-location" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-trivia = (build-asdf-system { - pname = "maiden-trivia"; - version = "20241012-git"; - asds = [ "maiden-trivia" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-trivia"; - asd = "maiden-trivia"; - }); - systems = [ "maiden-trivia" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-twitter = (build-asdf-system { - pname = "maiden-twitter"; - version = "20241012-git"; - asds = [ "maiden-twitter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-twitter"; - asd = "maiden-twitter"; - }); - systems = [ "maiden-twitter" ]; - lispLibs = [ (getAttr "chirp" self) (getAttr "maiden-client-entities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-urlinfo = (build-asdf-system { - pname = "maiden-urlinfo"; - version = "20241012-git"; - asds = [ "maiden-urlinfo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-urlinfo"; - asd = "maiden-urlinfo"; - }); - systems = [ "maiden-urlinfo" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "maiden-activatable" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-vote = (build-asdf-system { - pname = "maiden-vote"; - version = "20241012-git"; - asds = [ "maiden-vote" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-vote"; - asd = "maiden-vote"; - }); - systems = [ "maiden-vote" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maiden-weather = (build-asdf-system { - pname = "maiden-weather"; - version = "20241012-git"; - asds = [ "maiden-weather" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; - sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; - system = "maiden-weather"; - asd = "maiden-weather"; - }); - systems = [ "maiden-weather" ]; - lispLibs = [ (getAttr "local-time" self) (getAttr "maiden-api-access" self) (getAttr "maiden-client-entities" self) (getAttr "maiden-commands" self) (getAttr "maiden-location" self) (getAttr "maiden-storage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maidenhead = (build-asdf-system { - pname = "maidenhead"; - version = "20241012-git"; - asds = [ "maidenhead" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maidenhead/2024-10-12/maidenhead-20241012-git.tgz"; - sha256 = "10pcx2ngyj6lkfbg1b58lzcm02xl1a3smnad5lvvw30pbalwcq46"; - system = "maidenhead"; - asd = "maidenhead"; - }); - systems = [ "maidenhead" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mailbox = (build-asdf-system { - pname = "mailbox"; - version = "20131003-git"; - asds = [ "mailbox" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mailbox/2013-10-03/mailbox-20131003-git.tgz"; - sha256 = "1qgkcss8m2q29kr9d040dnjmzl17vb7zzvlz5ry3z3zgbdwgj1sy"; - system = "mailbox"; - asd = "mailbox"; - }); - systems = [ "mailbox" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mailgun = (build-asdf-system { - pname = "mailgun"; - version = "20220707-git"; - asds = [ "mailgun" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mailgun/2022-07-07/mailgun-20220707-git.tgz"; - sha256 = "1wadkm5r2hmyz40m4kwg5rv4g4dwn3h2d8l2mn9dncg5qy37x2vl"; - system = "mailgun"; - asd = "mailgun"; - }); - systems = [ "mailgun" ]; - lispLibs = [ (getAttr "dexador" self) (getAttr "log4cl" self) (getAttr "secret-values" self) (getAttr "spinneret" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - make-hash = (build-asdf-system { - pname = "make-hash"; - version = "20130615-git"; - asds = [ "make-hash" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/make-hash/2013-06-15/make-hash-20130615-git.tgz"; - sha256 = "1qa4mcmb3pv44py0j129dd8hjx09c2akpnds53b69151mgwv5qz8"; - system = "make-hash"; - asd = "make-hash"; - }); - systems = [ "make-hash" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - make-hash-tests = (build-asdf-system { - pname = "make-hash-tests"; - version = "20130615-git"; - asds = [ "make-hash-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/make-hash/2013-06-15/make-hash-20130615-git.tgz"; - sha256 = "1qa4mcmb3pv44py0j129dd8hjx09c2akpnds53b69151mgwv5qz8"; - system = "make-hash-tests"; - asd = "make-hash-tests"; - }); - systems = [ "make-hash-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "make-hash" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - manifest = (build-asdf-system { - pname = "manifest"; - version = "20120208-git"; - asds = [ "manifest" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/manifest/2012-02-08/manifest-20120208-git.tgz"; - sha256 = "0dswslnskskdbsln6vi7w8cbypw001d81xaxkfn4g7m15m9pzkgf"; - system = "manifest"; - asd = "manifest"; - }); - systems = [ "manifest" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "monkeylib-html" self) (getAttr "puri" self) (getAttr "split-sequence" self) (getAttr "toot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - manifolds = (build-asdf-system { - pname = "manifolds"; - version = "20241012-git"; - asds = [ "manifolds" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/manifolds/2024-10-12/manifolds-20241012-git.tgz"; - sha256 = "1q9hy2k1xabf8whnyxjiaqypbnbq84q94z1gmqgicxyzn7h3ybw4"; - system = "manifolds"; - asd = "manifolds"; - }); - systems = [ "manifolds" ]; - lispLibs = [ (getAttr "_3d-math" self) (getAttr "_3d-spaces" self) (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - manifolds-test = (build-asdf-system { - pname = "manifolds-test"; - version = "20241012-git"; - asds = [ "manifolds-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/manifolds/2024-10-12/manifolds-20241012-git.tgz"; - sha256 = "1q9hy2k1xabf8whnyxjiaqypbnbq84q94z1gmqgicxyzn7h3ybw4"; - system = "manifolds-test"; - asd = "manifolds-test"; - }); - systems = [ "manifolds-test" ]; - lispLibs = [ (getAttr "cl-wavefront" self) (getAttr "manifolds" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - map-bind = (build-asdf-system { - pname = "map-bind"; - version = "20120811-git"; - asds = [ "map-bind" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/map-bind/2012-08-11/map-bind-20120811-git.tgz"; - sha256 = "06z02c0ypfrd789glbidnhf95839hardd7nr3i95l1adm8pas30f"; - system = "map-bind"; - asd = "map-bind"; - }); - systems = [ "map-bind" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - map-set = (build-asdf-system { - pname = "map-set"; - version = "20230618-git"; - asds = [ "map-set" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/map-set/2023-06-18/map-set-20230618-git.tgz"; - sha256 = "1jlvgyvw9v49x65xvcc6vyy5nfgih43yysqj5v2555rm75p5ipgg"; - system = "map-set"; - asd = "map-set"; - }); - systems = [ "map-set" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - marching-cubes = (build-asdf-system { - pname = "marching-cubes"; - version = "20150709-git"; - asds = [ "marching-cubes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/marching-cubes/2015-07-09/marching-cubes-20150709-git.tgz"; - sha256 = "013wyr4g82b2gk0j5jbkkshg9lal2m34px37blyclf6kr5sk6azh"; - system = "marching-cubes"; - asd = "marching-cubes"; - }); - systems = [ "marching-cubes" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - marching-cubes-example = (build-asdf-system { - pname = "marching-cubes-example"; - version = "20150709-git"; - asds = [ "marching-cubes-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/marching-cubes/2015-07-09/marching-cubes-20150709-git.tgz"; - sha256 = "013wyr4g82b2gk0j5jbkkshg9lal2m34px37blyclf6kr5sk6azh"; - system = "marching-cubes-example"; - asd = "marching-cubes-example"; - }); - systems = [ "marching-cubes-example" ]; - lispLibs = [ (getAttr "marching-cubes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - marching-cubes-test = (build-asdf-system { - pname = "marching-cubes-test"; - version = "20150709-git"; - asds = [ "marching-cubes-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/marching-cubes/2015-07-09/marching-cubes-20150709-git.tgz"; - sha256 = "013wyr4g82b2gk0j5jbkkshg9lal2m34px37blyclf6kr5sk6azh"; - system = "marching-cubes-test"; - asd = "marching-cubes-test"; - }); - systems = [ "marching-cubes-test" ]; - lispLibs = [ (getAttr "cl-test-more" self) (getAttr "marching-cubes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - markdown_dot_cl = (build-asdf-system { - pname = "markdown.cl"; - version = "20210228-git"; - asds = [ "markdown.cl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/markdown.cl/2021-02-28/markdown.cl-20210228-git.tgz"; - sha256 = "00yxg67skx3navq7fdsjy0wds16n9n12bhdzv08f43bgbwali7v8"; - system = "markdown.cl"; - asd = "markdown.cl"; - }); - systems = [ "markdown.cl" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "split-sequence" self) (getAttr "xmls" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - markdown_dot_cl-test = (build-asdf-system { - pname = "markdown.cl-test"; - version = "20210228-git"; - asds = [ "markdown.cl-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/markdown.cl/2021-02-28/markdown.cl-20210228-git.tgz"; - sha256 = "00yxg67skx3navq7fdsjy0wds16n9n12bhdzv08f43bgbwali7v8"; - system = "markdown.cl-test"; - asd = "markdown.cl-test"; - }); - systems = [ "markdown.cl-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "markdown_dot_cl" self) (getAttr "xmls" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - markup = (build-asdf-system { - pname = "markup"; - version = "20230618-git"; - asds = [ "markup" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/markup/2023-06-18/markup-20230618-git.tgz"; - sha256 = "1paj76r1bfq4pr6m6j1mgik8b97sl2zgzy7rvvwwfrs2j1mf8byd"; - system = "markup"; - asd = "markup"; - }); - systems = [ "markup" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "named-readtables" self) (getAttr "str" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - markup_dot_test = (build-asdf-system { - pname = "markup.test"; - version = "20230618-git"; - asds = [ "markup.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/markup/2023-06-18/markup-20230618-git.tgz"; - sha256 = "1paj76r1bfq4pr6m6j1mgik8b97sl2zgzy7rvvwwfrs2j1mf8byd"; - system = "markup.test"; - asd = "markup.test"; - }); - systems = [ "markup.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "markup" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - marshal = (build-asdf-system { - pname = "marshal"; - version = "20241012-git"; - asds = [ "marshal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-marshal/2024-10-12/cl-marshal-20241012-git.tgz"; - sha256 = "081j2gfjdg05xzcq0jzqxjb874wkjdbxk9vah7hmlw9d767mzs5b"; - system = "marshal"; - asd = "marshal"; - }); - systems = [ "marshal" ]; - lispLibs = [ ]; - meta = {}; - }); - marshal-tests = (build-asdf-system { - pname = "marshal-tests"; - version = "20241012-git"; - asds = [ "marshal-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-marshal/2024-10-12/cl-marshal-20241012-git.tgz"; - sha256 = "081j2gfjdg05xzcq0jzqxjb874wkjdbxk9vah7hmlw9d767mzs5b"; - system = "marshal-tests"; - asd = "marshal-tests"; - }); - systems = [ "marshal-tests" ]; - lispLibs = [ (getAttr "marshal" self) (getAttr "xlunit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - math = (build-asdf-system { - pname = "math"; - version = "20241012-git"; - asds = [ "math" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/math/2024-10-12/math-20241012-git.tgz"; - sha256 = "104rga7fqq3xvdxryhmgdq8zygd00zk5xb05glwqw01ygl3bc0r3"; - system = "math"; - asd = "math"; - }); - systems = [ "math" ]; - lispLibs = [ (getAttr "cl-utilities" self) (getAttr "closer-mop" self) (getAttr "font-discovery" self) (getAttr "gsll" self) (getAttr "vgplot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mathkit = (build-asdf-system { - pname = "mathkit"; - version = "20160208-git"; - asds = [ "mathkit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mathkit/2016-02-08/mathkit-20160208-git.tgz"; - sha256 = "174y6ndmf52h8sml87qjfl48llmynvdizzk2h0mr85zbaysx73i3"; - system = "mathkit"; - asd = "mathkit"; - }); - systems = [ "mathkit" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - matrix-case = (build-asdf-system { - pname = "matrix-case"; - version = "20211020-git"; - asds = [ "matrix-case" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/matrix-case/2021-10-20/matrix-case-20211020-git.tgz"; - sha256 = "17k7x7wcl78xw4ajd38gva2dw7snsm9jppbnnl4by2s0grsqg50a"; - system = "matrix-case"; - asd = "matrix-case"; - }); - systems = [ "matrix-case" ]; - lispLibs = [ (getAttr "jingoh_dot_documentizer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - matrix-case_dot_test = (build-asdf-system { - pname = "matrix-case.test"; - version = "20211020-git"; - asds = [ "matrix-case.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/matrix-case/2021-10-20/matrix-case-20211020-git.tgz"; - sha256 = "17k7x7wcl78xw4ajd38gva2dw7snsm9jppbnnl4by2s0grsqg50a"; - system = "matrix-case.test"; - asd = "matrix-case.test"; - }); - systems = [ "matrix-case.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "matrix-case" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maxpc = (build-asdf-system { - pname = "maxpc"; - version = "20200427-git"; - asds = [ "maxpc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maxpc/2020-04-27/maxpc-20200427-git.tgz"; - sha256 = "15wrjbr2js6j67c1dd4p2qxj49q9iqv1lhb7cwdcwpn79crr39gf"; - system = "maxpc"; - asd = "maxpc"; - }); - systems = [ "maxpc" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maxpc-apache = (build-asdf-system { - pname = "maxpc-apache"; - version = "20241012-git"; - asds = [ "maxpc-apache" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "maxpc-apache"; - asd = "maxpc-apache"; - }); - systems = [ "maxpc-apache" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maxpc-apache-test = (build-asdf-system { - pname = "maxpc-apache-test"; - version = "20241012-git"; - asds = [ "maxpc-apache-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "maxpc-apache-test"; - asd = "maxpc-apache-test"; - }); - systems = [ "maxpc-apache-test" ]; - lispLibs = [ (getAttr "maxpc-apache" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - maxpc-test = (build-asdf-system { - pname = "maxpc-test"; - version = "20200427-git"; - asds = [ "maxpc-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/maxpc/2020-04-27/maxpc-20200427-git.tgz"; - sha256 = "15wrjbr2js6j67c1dd4p2qxj49q9iqv1lhb7cwdcwpn79crr39gf"; - system = "maxpc-test"; - asd = "maxpc-test"; - }); - systems = [ "maxpc-test" ]; - lispLibs = [ (getAttr "maxpc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mbe = (build-asdf-system { - pname = "mbe"; - version = "20200218-git"; - asds = [ "mbe" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mbe/2020-02-18/mbe-20200218-git.tgz"; - sha256 = "1wlhlddfv0jbqliqlvhxkmmj9pfym0f9qlvjjmlrkvx6fxpv0450"; - system = "mbe"; - asd = "mbe"; - }); - systems = [ "mbe" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcase = (build-asdf-system { - pname = "mcase"; - version = "20211020-git"; - asds = [ "mcase" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcase/2021-10-20/mcase-20211020-git.tgz"; - sha256 = "1k0agm57xbzlskdi8cgsg2z9lsamm4jl6fw7687z3bw1s2dbsm59"; - system = "mcase"; - asd = "mcase"; - }); - systems = [ "mcase" ]; - lispLibs = [ (getAttr "jingoh_dot_documentizer" self) (getAttr "millet" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcase_dot_test = (build-asdf-system { - pname = "mcase.test"; - version = "20211020-git"; - asds = [ "mcase.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcase/2021-10-20/mcase-20211020-git.tgz"; - sha256 = "1k0agm57xbzlskdi8cgsg2z9lsamm4jl6fw7687z3bw1s2dbsm59"; - system = "mcase.test"; - asd = "mcase.test"; - }); - systems = [ "mcase.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "mcase" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim = (build-asdf-system { - pname = "mcclim"; - version = "20241012-git"; - asds = [ "mcclim" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim"; - asd = "mcclim"; - }); - systems = [ "mcclim" ]; - lispLibs = [ (getAttr "clim" self) (getAttr "clim-pdf" self) (getAttr "clim-postscript" self) (getAttr "conditional-commands" self) (getAttr "mcclim-bezier" self) (getAttr "mcclim-bitmaps" self) (getAttr "mcclim-clx" self) (getAttr "mcclim-clx-fb" self) (getAttr "mcclim-franz" self) (getAttr "mcclim-null" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-bezier = (build-asdf-system { - pname = "mcclim-bezier"; - version = "20241012-git"; - asds = [ "mcclim-bezier" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-bezier"; - asd = "mcclim-bezier"; - }); - systems = [ "mcclim-bezier" ]; - lispLibs = [ (getAttr "clim" self) (getAttr "clim-pdf" self) (getAttr "clim-postscript" self) (getAttr "flexichain" self) (getAttr "mcclim-clx" self) (getAttr "mcclim-null" self) (getAttr "mcclim-render" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-bitmaps = (build-asdf-system { - pname = "mcclim-bitmaps"; - version = "20241012-git"; - asds = [ "mcclim-bitmaps" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-bitmaps"; - asd = "mcclim-bitmaps"; - }); - systems = [ "mcclim-bitmaps" ]; - lispLibs = [ (getAttr "clim" self) (getAttr "opticl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-clx = (build-asdf-system { - pname = "mcclim-clx"; - version = "20241012-git"; - asds = [ "mcclim-clx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-clx"; - asd = "mcclim-clx"; - }); - systems = [ "mcclim-clx" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-aa" self) (getAttr "cl-dejavu" self) (getAttr "cl-paths-ttf" self) (getAttr "cl-unicode" self) (getAttr "cl-vectors" self) (getAttr "clim" self) (getAttr "clx" self) (getAttr "flexi-streams" self) (getAttr "trivial-garbage" self) (getAttr "zpb-ttf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-clx-fb = (build-asdf-system { - pname = "mcclim-clx-fb"; - version = "20241012-git"; - asds = [ "mcclim-clx-fb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-clx-fb"; - asd = "mcclim-clx-fb"; - }); - systems = [ "mcclim-clx-fb" ]; - lispLibs = [ (getAttr "mcclim-clx" self) (getAttr "mcclim-render" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-dot = (build-asdf-system { - pname = "mcclim-dot"; - version = "20241012-git"; - asds = [ "mcclim-dot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-dot"; - asd = "mcclim-dot"; - }); - systems = [ "mcclim-dot" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-dot" self) (getAttr "closer-mop" self) (getAttr "mcclim" self) (getAttr "parse-number" self) (getAttr "shasht" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-fontconfig = (build-asdf-system { - pname = "mcclim-fontconfig"; - version = "20241012-git"; - asds = [ "mcclim-fontconfig" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-fontconfig"; - asd = "mcclim-fontconfig"; - }); - systems = [ "mcclim-fontconfig" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-fonts = (build-asdf-system { - pname = "mcclim-fonts"; - version = "20241012-git"; - asds = [ "mcclim-fonts" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-fonts"; - asd = "mcclim-fonts"; - }); - systems = [ "mcclim-fonts" ]; - lispLibs = [ (getAttr "clim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-franz = (build-asdf-system { - pname = "mcclim-franz"; - version = "20241012-git"; - asds = [ "mcclim-franz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-franz"; - asd = "mcclim-franz"; - }); - systems = [ "mcclim-franz" ]; - lispLibs = [ (getAttr "clim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-harfbuzz = (build-asdf-system { - pname = "mcclim-harfbuzz"; - version = "20241012-git"; - asds = [ "mcclim-harfbuzz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-harfbuzz"; - asd = "mcclim-harfbuzz"; - }); - systems = [ "mcclim-harfbuzz" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-layouts = (build-asdf-system { - pname = "mcclim-layouts"; - version = "20241012-git"; - asds = [ "mcclim-layouts" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-layouts"; - asd = "mcclim-layouts"; - }); - systems = [ "mcclim-layouts" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-null = (build-asdf-system { - pname = "mcclim-null"; - version = "20241012-git"; - asds = [ "mcclim-null" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-null"; - asd = "mcclim-null"; - }); - systems = [ "mcclim-null" ]; - lispLibs = [ (getAttr "clim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-raster-image = (build-asdf-system { - pname = "mcclim-raster-image"; - version = "20241012-git"; - asds = [ "mcclim-raster-image" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-raster-image"; - asd = "mcclim-raster-image"; - }); - systems = [ "mcclim-raster-image" ]; - lispLibs = [ (getAttr "clim" self) (getAttr "mcclim-render" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-render = (build-asdf-system { - pname = "mcclim-render"; - version = "20241012-git"; - asds = [ "mcclim-render" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-render"; - asd = "mcclim-render"; - }); - systems = [ "mcclim-render" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-aa" self) (getAttr "cl-dejavu" self) (getAttr "cl-paths-ttf" self) (getAttr "cl-vectors" self) (getAttr "clim" self) (getAttr "flexi-streams" self) (getAttr "zpb-ttf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-svg = (build-asdf-system { - pname = "mcclim-svg"; - version = "20241012-git"; - asds = [ "mcclim-svg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-svg"; - asd = "mcclim-svg"; - }); - systems = [ "mcclim-svg" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-aa" self) (getAttr "cl-base64" self) (getAttr "cl-dejavu" self) (getAttr "cl-paths-ttf" self) (getAttr "cl-vectors" self) (getAttr "cl-who" self) (getAttr "clim" self) (getAttr "flexi-streams" self) (getAttr "mcclim" self) (getAttr "mcclim-bitmaps" self) (getAttr "zpb-ttf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-tooltips = (build-asdf-system { - pname = "mcclim-tooltips"; - version = "20241012-git"; - asds = [ "mcclim-tooltips" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-tooltips"; - asd = "mcclim-tooltips"; - }); - systems = [ "mcclim-tooltips" ]; - lispLibs = [ (getAttr "clim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mcclim-tree-with-cross-edges = (build-asdf-system { - pname = "mcclim-tree-with-cross-edges"; - version = "20241012-git"; - asds = [ "mcclim-tree-with-cross-edges" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "mcclim-tree-with-cross-edges"; - asd = "mcclim-tree-with-cross-edges"; - }); - systems = [ "mcclim-tree-with-cross-edges" ]; - lispLibs = [ (getAttr "mcclim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - md5 = (build-asdf-system { - pname = "md5"; - version = "20210630-git"; - asds = [ "md5" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/md5/2021-06-30/md5-20210630-git.tgz"; - sha256 = "1g20np6rhn3y08z8mlmlk721mw2207s52v2pwp4smm3lz25sx3q5"; - system = "md5"; - asd = "md5"; - }); - systems = [ "md5" ]; - lispLibs = [ ]; - meta = {}; - }); - media-types = (build-asdf-system { - pname = "media-types"; - version = "20220331-git"; - asds = [ "media-types" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/media-types/2022-03-31/media-types-20220331-git.tgz"; - sha256 = "07ly7jr0ff2ks4gyjpq2jyj9gm47frllal5is3iqhc4xrmpyzrqc"; - system = "media-types"; - asd = "media-types"; - }); - systems = [ "media-types" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mel-base = (build-asdf-system { - pname = "mel-base"; - version = "20180228-git"; - asds = [ "mel-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mel-base/2018-02-28/mel-base-20180228-git.tgz"; - sha256 = "1dvhmlkxasww3kb7xnwqlmdvi31w2awjrbkgk5d0hsfzqmyhhjh0"; - system = "mel-base"; - asd = "mel-base"; - }); - systems = [ "mel-base" ]; - lispLibs = [ (getAttr "cl_plus_ssl" self) (getAttr "flexi-streams" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - memoize = (build-asdf-system { - pname = "memoize"; - version = "20140826-http"; - asds = [ "memoize" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/memoize/2014-08-26/memoize-20140826-http.tgz"; - sha256 = "1f1plqy9xdv40235b7kkm63gsgssk8l81azhfniy8j9yww39gihf"; - system = "memoize"; - asd = "memoize"; - }); - systems = [ "memoize" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - memory-regions = (build-asdf-system { - pname = "memory-regions"; - version = "20241012-git"; - asds = [ "memory-regions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/memory-regions/2024-10-12/memory-regions-20241012-git.tgz"; - sha256 = "0j2qfbh2kwl8k6v0h0pbh5hml8aia888kaq4kgb12nfslim81iyd"; - system = "memory-regions"; - asd = "memory-regions"; - }); - systems = [ "memory-regions" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "closer-mop" self) (getAttr "documentation-utils" self) (getAttr "mmap" self) (getAttr "static-vectors" self) (getAttr "trivial-extensible-sequences" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - message-oo = (build-asdf-system { - pname = "message-oo"; - version = "20130615-git"; - asds = [ "message-oo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/message-oo/2013-06-15/message-oo-20130615-git.tgz"; - sha256 = "164yypzhr6pxb84x47s9vjl97imbq5r8sxan22101q0y1jn3dznp"; - system = "message-oo"; - asd = "message-oo"; - }); - systems = [ "message-oo" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - messagebox = (build-asdf-system { - pname = "messagebox"; - version = "20241012-git"; - asds = [ "messagebox" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/messagebox/2024-10-12/messagebox-20241012-git.tgz"; - sha256 = "0wf25rfx7vg0l1mnzjjzwjqcjaa96a95k9diijppn7y9v2knr1qq"; - system = "messagebox"; - asd = "messagebox"; - }); - systems = [ "messagebox" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - meta = (build-asdf-system { - pname = "meta"; - version = "20150608-git"; - asds = [ "meta" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/meta/2015-06-08/meta-20150608-git.tgz"; - sha256 = "08s53zj3mcx82kszp1bg2vsb4kydvkc70kj4hpq9h1l5a1wh44cy"; - system = "meta"; - asd = "meta"; - }); - systems = [ "meta" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - meta-sexp = (build-asdf-system { - pname = "meta-sexp"; - version = "20201016-git"; - asds = [ "meta-sexp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/meta-sexp/2020-10-16/meta-sexp-20201016-git.tgz"; - sha256 = "14z4xglybsj4pdaifhjvnki0vm0wg985x00n94djc0fdcclczv1c"; - system = "meta-sexp"; - asd = "meta-sexp"; - }); - systems = [ "meta-sexp" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - metabang-bind = (build-asdf-system { - pname = "metabang-bind"; - version = "20230618-git"; - asds = [ "metabang-bind" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/metabang-bind/2023-06-18/metabang-bind-20230618-git.tgz"; - sha256 = "14g7k3zhm8cd6bssc5mm5h6iq1dv5lfhiq33aimcmj5a6vbiq47d"; - system = "metabang-bind"; - asd = "metabang-bind"; - }); - systems = [ "metabang-bind" ]; - lispLibs = [ ]; - meta = {}; - }); - metabang-bind-test = (build-asdf-system { - pname = "metabang-bind-test"; - version = "20230618-git"; - asds = [ "metabang-bind-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/metabang-bind/2023-06-18/metabang-bind-20230618-git.tgz"; - sha256 = "14g7k3zhm8cd6bssc5mm5h6iq1dv5lfhiq33aimcmj5a6vbiq47d"; - system = "metabang-bind-test"; - asd = "metabang-bind-test"; - }); - systems = [ "metabang-bind-test" ]; - lispLibs = [ (getAttr "lift" self) (getAttr "metabang-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - metacopy = (build-asdf-system { - pname = "metacopy"; - version = "20170403-darcs"; - asds = [ "metacopy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/metacopy/2017-04-03/metacopy-20170403-darcs.tgz"; - sha256 = "1xwvc18l5fc33ffqa6jz5g0qz6mpabia81bcmqf3sz24apkpr49x"; - system = "metacopy"; - asd = "metacopy"; - }); - systems = [ "metacopy" ]; - lispLibs = [ (getAttr "moptilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - metacopy-with-contextl = (build-asdf-system { - pname = "metacopy-with-contextl"; - version = "20170403-darcs"; - asds = [ "metacopy-with-contextl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/metacopy/2017-04-03/metacopy-20170403-darcs.tgz"; - sha256 = "1xwvc18l5fc33ffqa6jz5g0qz6mpabia81bcmqf3sz24apkpr49x"; - system = "metacopy-with-contextl"; - asd = "metacopy-with-contextl"; - }); - systems = [ "metacopy-with-contextl" ]; - lispLibs = [ (getAttr "contextl" self) (getAttr "metacopy" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - metalock = (build-asdf-system { - pname = "metalock"; - version = "20200925-git"; - asds = [ "metalock" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/metalock/2020-09-25/metalock-20200925-git.tgz"; - sha256 = "0z2vk0s694zhnkai593q42vln5a6ykm8pilyikc4qp9aw9r43lc5"; - system = "metalock"; - asd = "metalock"; - }); - systems = [ "metalock" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - metap = (build-asdf-system { - pname = "metap"; - version = "20150505-git"; - asds = [ "metap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/metap/2015-05-05/metap-20150505-git.tgz"; - sha256 = "0drqyjscl0lmhgplld6annmlqma83q76xkxnahcq4ksnhpbsz9wx"; - system = "metap"; - asd = "metap"; - }); - systems = [ "metap" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - metap-test = (build-asdf-system { - pname = "metap-test"; - version = "20150505-git"; - asds = [ "metap-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/metap/2015-05-05/metap-20150505-git.tgz"; - sha256 = "0drqyjscl0lmhgplld6annmlqma83q76xkxnahcq4ksnhpbsz9wx"; - system = "metap-test"; - asd = "metap-test"; - }); - systems = [ "metap-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "metap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - metatilities = (build-asdf-system { - pname = "metatilities"; - version = "20180228-git"; - asds = [ "metatilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/metatilities/2018-02-28/metatilities-20180228-git.tgz"; - sha256 = "0vqhndnhrv40ixkj5lslr0h2fy79609gi0wgbqzcz82vkyx9d6vd"; - system = "metatilities"; - asd = "metatilities"; - }); - systems = [ "metatilities" ]; - lispLibs = [ (getAttr "asdf-system-connections" self) (getAttr "cl-containers" self) (getAttr "metabang-bind" self) (getAttr "metatilities-base" self) (getAttr "moptilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - metatilities-base = (build-asdf-system { - pname = "metatilities-base"; - version = "20191227-git"; - asds = [ "metatilities-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/metatilities-base/2019-12-27/metatilities-base-20191227-git.tgz"; - sha256 = "069rk5ncwvjnnzvvky6xiriynl72yzvjpnzl6jw9jf3b8na14zrk"; - system = "metatilities-base"; - asd = "metatilities-base"; - }); - systems = [ "metatilities-base" ]; - lispLibs = [ ]; - meta = {}; - }); - metatilities-base-test = (build-asdf-system { - pname = "metatilities-base-test"; - version = "20191227-git"; - asds = [ "metatilities-base-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/metatilities-base/2019-12-27/metatilities-base-20191227-git.tgz"; - sha256 = "069rk5ncwvjnnzvvky6xiriynl72yzvjpnzl6jw9jf3b8na14zrk"; - system = "metatilities-base-test"; - asd = "metatilities-base-test"; - }); - systems = [ "metatilities-base-test" ]; - lispLibs = [ (getAttr "lift" self) (getAttr "metatilities-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - metatilities-test = (build-asdf-system { - pname = "metatilities-test"; - version = "20180228-git"; - asds = [ "metatilities-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/metatilities/2018-02-28/metatilities-20180228-git.tgz"; - sha256 = "0vqhndnhrv40ixkj5lslr0h2fy79609gi0wgbqzcz82vkyx9d6vd"; - system = "metatilities-test"; - asd = "metatilities-test"; - }); - systems = [ "metatilities-test" ]; - lispLibs = [ (getAttr "lift" self) (getAttr "metatilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - metering = (build-asdf-system { - pname = "metering"; - version = "20200218-git"; - asds = [ "metering" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/metering/2020-02-18/metering-20200218-git.tgz"; - sha256 = "0jx3ypk8m815yp7208xkcxkvila847mvna25a2p22ihnj0ms9rn1"; - system = "metering"; - asd = "metering"; - }); - systems = [ "metering" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - method-combination-utilities = (build-asdf-system { - pname = "method-combination-utilities"; - version = "20241012-git"; - asds = [ "method-combination-utilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/method-combination-utilities/2024-10-12/method-combination-utilities-20241012-git.tgz"; - sha256 = "15wjzf6r9kkfw89rgzhrr60p5b4i15b90nr3wz6idkv3n4j7fsjl"; - system = "method-combination-utilities"; - asd = "method-combination-utilities"; - }); - systems = [ "method-combination-utilities" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - method-combination-utilities_dot_tests = (build-asdf-system { - pname = "method-combination-utilities.tests"; - version = "20241012-git"; - asds = [ "method-combination-utilities.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/method-combination-utilities/2024-10-12/method-combination-utilities-20241012-git.tgz"; - sha256 = "15wjzf6r9kkfw89rgzhrr60p5b4i15b90nr3wz6idkv3n4j7fsjl"; - system = "method-combination-utilities.tests"; - asd = "method-combination-utilities"; - }); - systems = [ "method-combination-utilities.tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "method-combination-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - method-hooks = (build-asdf-system { - pname = "method-hooks"; - version = "20200925-git"; - asds = [ "method-hooks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/method-hooks/2020-09-25/method-hooks-20200925-git.tgz"; - sha256 = "0kzijk02wjzms3hihmn6n6p9r6awkrsqlkghf6ixzf6400fiy212"; - system = "method-hooks"; - asd = "method-hooks"; - }); - systems = [ "method-hooks" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - method-hooks-test = (build-asdf-system { - pname = "method-hooks-test"; - version = "20200925-git"; - asds = [ "method-hooks-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/method-hooks/2020-09-25/method-hooks-20200925-git.tgz"; - sha256 = "0kzijk02wjzms3hihmn6n6p9r6awkrsqlkghf6ixzf6400fiy212"; - system = "method-hooks-test"; - asd = "method-hooks-test"; - }); - systems = [ "method-hooks-test" ]; - lispLibs = [ (getAttr "method-hooks" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - method-versions = (build-asdf-system { - pname = "method-versions"; - version = "0.1.2011.05.18"; - asds = [ "method-versions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/method-versions/2011-05-22/method-versions_0.1.2011.05.18.tgz"; - sha256 = "119x3dbjry25issq2m8xcacknd1y9mcnla5rhqzcsrj58zsmwmwf"; - system = "method-versions"; - asd = "method-versions"; - }); - systems = [ "method-versions" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mexpr = (build-asdf-system { - pname = "mexpr"; - version = "20150709-git"; - asds = [ "mexpr" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mexpr/2015-07-09/mexpr-20150709-git.tgz"; - sha256 = "0ri9cp7vhnn9sah1lhvxn523c342n0q4v0xzi6fzlfvpj84jfzqk"; - system = "mexpr"; - asd = "mexpr"; - }); - systems = [ "mexpr" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-syntax" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mexpr-tests = (build-asdf-system { - pname = "mexpr-tests"; - version = "20150709-git"; - asds = [ "mexpr-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mexpr/2015-07-09/mexpr-20150709-git.tgz"; - sha256 = "0ri9cp7vhnn9sah1lhvxn523c342n0q4v0xzi6fzlfvpj84jfzqk"; - system = "mexpr-tests"; - asd = "mexpr-tests"; - }); - systems = [ "mexpr-tests" ]; - lispLibs = [ (getAttr "mexpr" self) (getAttr "named-readtables" self) (getAttr "should-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mfiano-utils = (build-asdf-system { - pname = "mfiano-utils"; - version = "20230214-git"; - asds = [ "mfiano-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mfiano-utils/2023-02-14/mfiano-utils-20230214-git.tgz"; - sha256 = "06nrrwwlrwi4w87y6888759b5vpa5264lli5m4crl9r9lr9bnay9"; - system = "mfiano-utils"; - asd = "mfiano-utils"; - }); - systems = [ "mfiano-utils" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mgl = (build-asdf-system { - pname = "mgl"; - version = "20230618-git"; - asds = [ "mgl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mgl/2023-06-18/mgl-20230618-git.tgz"; - sha256 = "1jr2jill9b1rq0msy0bzzl0q2w0bm3gpd0dwrmkyazzjym2rdsjx"; - system = "mgl"; - asd = "mgl"; - }); - systems = [ "mgl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "array-operations" self) (getAttr "cl-reexport" self) (getAttr "closer-mop" self) (getAttr "lla" self) (getAttr "mgl-gnuplot" self) (getAttr "mgl-mat" self) (getAttr "mgl-pax" self) (getAttr "named-readtables" self) (getAttr "num-utils" self) (getAttr "pythonic-string-reader" self) (getAttr "swank" self) ]; - meta = {}; - }); - mgl-example = (build-asdf-system { - pname = "mgl-example"; - version = "20230618-git"; - asds = [ "mgl-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mgl/2023-06-18/mgl-20230618-git.tgz"; - sha256 = "1jr2jill9b1rq0msy0bzzl0q2w0bm3gpd0dwrmkyazzjym2rdsjx"; - system = "mgl-example"; - asd = "mgl-example"; - }); - systems = [ "mgl-example" ]; - lispLibs = [ (getAttr "mgl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mgl-gnuplot = (build-asdf-system { - pname = "mgl-gnuplot"; - version = "20230618-git"; - asds = [ "mgl-gnuplot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mgl/2023-06-18/mgl-20230618-git.tgz"; - sha256 = "1jr2jill9b1rq0msy0bzzl0q2w0bm3gpd0dwrmkyazzjym2rdsjx"; - system = "mgl-gnuplot"; - asd = "mgl-gnuplot"; - }); - systems = [ "mgl-gnuplot" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "external-program" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mgl-mat = (build-asdf-system { - pname = "mgl-mat"; - version = "20231021-git"; - asds = [ "mgl-mat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mgl-mat/2023-10-21/mgl-mat-20231021-git.tgz"; - sha256 = "0pl9ksdjr57sg2w85ql6y9pgbzrxcsz6irb7i0s1q3d08f87il1i"; - system = "mgl-mat"; - asd = "mgl-mat"; - }); - systems = [ "mgl-mat" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-cuda" self) (getAttr "flexi-streams" self) (getAttr "ieee-floats" self) (getAttr "lla" self) (getAttr "mgl-pax" self) (getAttr "num-utils" self) (getAttr "static-vectors" self) (getAttr "trivial-garbage" self) ]; - meta = {}; - }); - mgl-pax = (build-asdf-system { - pname = "mgl-pax"; - version = "20241012-git"; - asds = [ "mgl-pax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mgl-pax/2024-10-12/mgl-pax-20241012-git.tgz"; - sha256 = "17szk2ijccssa9n7zg8qh6hc706hahvzcrzlx716hmgq2hfwvvy0"; - system = "mgl-pax"; - asd = "mgl-pax"; - }); - systems = [ "mgl-pax" ]; - lispLibs = [ (getAttr "dref" self) (getAttr "mgl-pax-bootstrap" self) (getAttr "mgl-pax_dot_asdf" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) ]; - meta = {}; - }); - mgl-pax-bootstrap = (build-asdf-system { - pname = "mgl-pax-bootstrap"; - version = "20241012-git"; - asds = [ "mgl-pax-bootstrap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mgl-pax/2024-10-12/mgl-pax-20241012-git.tgz"; - sha256 = "17szk2ijccssa9n7zg8qh6hc706hahvzcrzlx716hmgq2hfwvvy0"; - system = "mgl-pax-bootstrap"; - asd = "mgl-pax-bootstrap"; - }); - systems = [ "mgl-pax-bootstrap" ]; - lispLibs = [ (getAttr "mgl-pax_dot_asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mgl-pax-test = (build-asdf-system { - pname = "mgl-pax-test"; - version = "20241012-git"; - asds = [ "mgl-pax-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mgl-pax/2024-10-12/mgl-pax-20241012-git.tgz"; - sha256 = "17szk2ijccssa9n7zg8qh6hc706hahvzcrzlx716hmgq2hfwvvy0"; - system = "mgl-pax-test"; - asd = "mgl-pax-test"; - }); - systems = [ "mgl-pax-test" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "_3bmd-ext-code-blocks" self) (getAttr "alexandria" self) (getAttr "colorize" self) (getAttr "dref" self) (getAttr "dref-test" self) (getAttr "md5" self) (getAttr "mgl-pax" self) (getAttr "mgl-pax_dot_asdf" self) (getAttr "swank" self) (getAttr "trivial-utf-8" self) (getAttr "try" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mgl-pax_dot_asdf = (build-asdf-system { - pname = "mgl-pax.asdf"; - version = "20241012-git"; - asds = [ "mgl-pax.asdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mgl-pax/2024-10-12/mgl-pax-20241012-git.tgz"; - sha256 = "17szk2ijccssa9n7zg8qh6hc706hahvzcrzlx716hmgq2hfwvvy0"; - system = "mgl-pax.asdf"; - asd = "mgl-pax.asdf"; - }); - systems = [ "mgl-pax.asdf" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mgrs = (build-asdf-system { - pname = "mgrs"; - version = "20220331-git"; - asds = [ "mgrs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mgrs/2022-03-31/mgrs-20220331-git.tgz"; - sha256 = "1n4kd734qjj7mrcg0q28hml3npam1rm067iwljwc87zshnxh5gmn"; - system = "mgrs"; - asd = "mgrs"; - }); - systems = [ "mgrs" ]; - lispLibs = [ (getAttr "utm-ups" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - micmac = (build-asdf-system { - pname = "micmac"; - version = "20230618-git"; - asds = [ "micmac" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/micmac/2023-06-18/micmac-20230618-git.tgz"; - sha256 = "10zjxqc7y5spr3y5yrnfqmv881ia168scbhiq8i98rvizabgxf6x"; - system = "micmac"; - asd = "micmac"; - }); - systems = [ "micmac" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "mgl-pax" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - midi = (build-asdf-system { - pname = "midi"; - version = "20070618"; - asds = [ "midi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/midi/2010-10-06/midi-20070618.tgz"; - sha256 = "06hb6vm4dckhr1ln5jn3b31x1yampkl5fl0lfbg9zyazli7fgl87"; - system = "midi"; - asd = "midi"; - }); - systems = [ "midi" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - millet = (build-asdf-system { - pname = "millet"; - version = "20211209-git"; - asds = [ "millet" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/millet/2021-12-09/millet-20211209-git.tgz"; - sha256 = "1jdqyr1f9a6083k7n88rwc6mjmgccj6za50ybl1dlnxqvqj2pw80"; - system = "millet"; - asd = "millet"; - }); - systems = [ "millet" ]; - lispLibs = [ (getAttr "jingoh_dot_documentizer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - millet_dot_test = (build-asdf-system { - pname = "millet.test"; - version = "20211209-git"; - asds = [ "millet.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/millet/2021-12-09/millet-20211209-git.tgz"; - sha256 = "1jdqyr1f9a6083k7n88rwc6mjmgccj6za50ybl1dlnxqvqj2pw80"; - system = "millet.test"; - asd = "millet.test"; - }); - systems = [ "millet.test" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "jingoh" self) (getAttr "millet" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - minheap = (build-asdf-system { - pname = "minheap"; - version = "20160628-git"; - asds = [ "minheap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/minheap/2016-06-28/minheap-20160628-git.tgz"; - sha256 = "03v0dqxg4kmwvfrlrkq8bmfcv70k9n9f48p9p3z8kmfbc4p3f1vd"; - system = "minheap"; - asd = "minheap"; - }); - systems = [ "minheap" ]; - lispLibs = [ ]; - meta = {}; - }); - minheap-tests = (build-asdf-system { - pname = "minheap-tests"; - version = "20160628-git"; - asds = [ "minheap-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/minheap/2016-06-28/minheap-20160628-git.tgz"; - sha256 = "03v0dqxg4kmwvfrlrkq8bmfcv70k9n9f48p9p3z8kmfbc4p3f1vd"; - system = "minheap-tests"; - asd = "minheap-tests"; - }); - systems = [ "minheap-tests" ]; - lispLibs = [ (getAttr "lisp-unit" self) (getAttr "minheap" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mini-cas = (build-asdf-system { - pname = "mini-cas"; - version = "20150923-git"; - asds = [ "mini-cas" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mini-cas/2015-09-23/mini-cas-20150923-git.tgz"; - sha256 = "1y9a111877lkpssi651q684mj052vp6qr9pz5gl47s6swiqvqp24"; - system = "mini-cas"; - asd = "mini-cas"; - }); - systems = [ "mini-cas" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - minilem = (build-asdf-system { - pname = "minilem"; - version = "20200218-git"; - asds = [ "minilem" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/minilem/2020-02-18/minilem-20200218-git.tgz"; - sha256 = "1hpcgj8k5m11nk1pfd479hrbh15dcas7z1s8w877rqmlf69ga4cp"; - system = "minilem"; - asd = "minilem"; - }); - systems = [ "minilem" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "esrap" self) (getAttr "inquisitor" self) (getAttr "iterate" self) (getAttr "log4cl" self) (getAttr "optima" self) (getAttr "swank" self) (getAttr "trivial-gray-streams" self) (getAttr "trivial-types" self) (getAttr "usocket" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - minpack = (build-asdf-system { - pname = "minpack"; - version = "20231021-git"; - asds = [ "minpack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "minpack"; - asd = "minpack"; - }); - systems = [ "minpack" ]; - lispLibs = [ (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - misc-extensions = (build-asdf-system { - pname = "misc-extensions"; - version = "20241012-git"; - asds = [ "misc-extensions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/misc-extensions/2024-10-12/misc-extensions-20241012-git.tgz"; - sha256 = "0pvgg376vkydp2831bnnvwrv27m4ivc78c0nhvb4848c3ik1hn5j"; - system = "misc-extensions"; - asd = "misc-extensions"; - }); - systems = [ "misc-extensions" ]; - lispLibs = [ ]; - meta = {}; - }); - mito = (build-asdf-system { - pname = "mito"; - version = "20241012-git"; - asds = [ "mito" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mito/2024-10-12/mito-20241012-git.tgz"; - sha256 = "0nz72qss2jji0narxffpnpfgz74grvhmwqqlydpw6wv3ji1rrrq3"; - system = "mito"; - asd = "mito"; - }); - systems = [ "mito" ]; - lispLibs = [ (getAttr "cl-package-locks" self) (getAttr "lack-middleware-mito" self) (getAttr "mito-core" self) (getAttr "mito-migration" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mito-attachment = (build-asdf-system { - pname = "mito-attachment"; - version = "20230214-git"; - asds = [ "mito-attachment" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mito-attachment/2023-02-14/mito-attachment-20230214-git.tgz"; - sha256 = "0an744m6wmnbb5zrxqxcf719r7im1n7p63z632p3m5sqv8d86fm1"; - system = "mito-attachment"; - asd = "mito-attachment"; - }); - systems = [ "mito-attachment" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "aws-sign4" self) (getAttr "lack-component" self) (getAttr "mito" self) (getAttr "quri" self) (getAttr "trivial-mimes" self) (getAttr "uuid" self) (getAttr "zs3" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mito-auth = (build-asdf-system { - pname = "mito-auth"; - version = "20171019-git"; - asds = [ "mito-auth" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mito-auth/2017-10-19/mito-auth-20171019-git.tgz"; - sha256 = "1q1yxjpnshzmia34a68dlscjadzynzyzz14sr4mkkkjyg5dhkazi"; - system = "mito-auth"; - asd = "mito-auth"; - }); - systems = [ "mito-auth" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "ironclad" self) (getAttr "mito" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mito-core = (build-asdf-system { - pname = "mito-core"; - version = "20241012-git"; - asds = [ "mito-core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mito/2024-10-12/mito-20241012-git.tgz"; - sha256 = "0nz72qss2jji0narxffpnpfgz74grvhmwqqlydpw6wv3ji1rrrq3"; - system = "mito-core"; - asd = "mito-core"; - }); - systems = [ "mito-core" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "dbi" self) (getAttr "dissect" self) (getAttr "local-time" self) (getAttr "sxql" self) (getAttr "trivia" self) (getAttr "uuid" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mito-migration = (build-asdf-system { - pname = "mito-migration"; - version = "20241012-git"; - asds = [ "mito-migration" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mito/2024-10-12/mito-20241012-git.tgz"; - sha256 = "0nz72qss2jji0narxffpnpfgz74grvhmwqqlydpw6wv3ji1rrrq3"; - system = "mito-migration"; - asd = "mito-migration"; - }); - systems = [ "mito-migration" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "chipz" self) (getAttr "closer-mop" self) (getAttr "dbi" self) (getAttr "esrap" self) (getAttr "mito-core" self) (getAttr "sxql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mito-test = (build-asdf-system { - pname = "mito-test"; - version = "20241012-git"; - asds = [ "mito-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mito/2024-10-12/mito-20241012-git.tgz"; - sha256 = "0nz72qss2jji0narxffpnpfgz74grvhmwqqlydpw6wv3ji1rrrq3"; - system = "mito-test"; - asd = "mito-test"; - }); - systems = [ "mito-test" ]; - lispLibs = [ (getAttr "dbd-mysql" self) (getAttr "dbd-postgres" self) (getAttr "dbd-sqlite3" self) (getAttr "mito" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mixalot = (build-asdf-system { - pname = "mixalot"; - version = "20151218-git"; - asds = [ "mixalot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; - sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; - system = "mixalot"; - asd = "mixalot"; - }); - systems = [ "mixalot" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mixalot-flac = (build-asdf-system { - pname = "mixalot-flac"; - version = "20151218-git"; - asds = [ "mixalot-flac" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; - sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; - system = "mixalot-flac"; - asd = "mixalot-flac"; - }); - systems = [ "mixalot-flac" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "flac" self) (getAttr "mixalot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mixalot-mp3 = (build-asdf-system { - pname = "mixalot-mp3"; - version = "20151218-git"; - asds = [ "mixalot-mp3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; - sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; - system = "mixalot-mp3"; - asd = "mixalot-mp3"; - }); - systems = [ "mixalot-mp3" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "mixalot" self) (getAttr "mpg123-ffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mixalot-vorbis = (build-asdf-system { - pname = "mixalot-vorbis"; - version = "20151218-git"; - asds = [ "mixalot-vorbis" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; - sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; - system = "mixalot-vorbis"; - asd = "mixalot-vorbis"; - }); - systems = [ "mixalot-vorbis" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "mixalot" self) (getAttr "vorbisfile-ffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mk-defsystem = (build-asdf-system { - pname = "mk-defsystem"; - version = "20241012-git"; - asds = [ "mk-defsystem" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mk-defsystem/2024-10-12/mk-defsystem-20241012-git.tgz"; - sha256 = "0zrr11szr50bqaxybm66ggj5bmchwljjafhxcwsyzgpqbnf06740"; - system = "mk-defsystem"; - asd = "mk-defsystem"; - }); - systems = [ "mk-defsystem" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mk-string-metrics = (build-asdf-system { - pname = "mk-string-metrics"; - version = "20180131-git"; - asds = [ "mk-string-metrics" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mk-string-metrics/2018-01-31/mk-string-metrics-20180131-git.tgz"; - sha256 = "0c50hjpylhkh5phcxxcwqdzpa94vk5pq1j7c6x0d3wfpb2yx0wkd"; - system = "mk-string-metrics"; - asd = "mk-string-metrics"; - }); - systems = [ "mk-string-metrics" ]; - lispLibs = [ ]; - meta = {}; - }); - mk-string-metrics-tests = (build-asdf-system { - pname = "mk-string-metrics-tests"; - version = "20180131-git"; - asds = [ "mk-string-metrics-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mk-string-metrics/2018-01-31/mk-string-metrics-20180131-git.tgz"; - sha256 = "0c50hjpylhkh5phcxxcwqdzpa94vk5pq1j7c6x0d3wfpb2yx0wkd"; - system = "mk-string-metrics-tests"; - asd = "mk-string-metrics-tests"; - }); - systems = [ "mk-string-metrics-tests" ]; - lispLibs = [ (getAttr "mk-string-metrics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ml-dsl = (build-asdf-system { - pname = "ml-dsl"; - version = "20210124-git"; - asds = [ "ml-dsl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-marklogic/2021-01-24/cl-marklogic-20210124-git.tgz"; - sha256 = "0baq2ccb88zyr2dqdvpm32lsin4zalv11w48x4xm80cr4kw45fk5"; - system = "ml-dsl"; - asd = "ml-dsl"; - }); - systems = [ "ml-dsl" ]; - lispLibs = [ (getAttr "cl-marklogic" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ml-optimizer = (build-asdf-system { - pname = "ml-optimizer"; - version = "20210124-git"; - asds = [ "ml-optimizer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-marklogic/2021-01-24/cl-marklogic-20210124-git.tgz"; - sha256 = "0baq2ccb88zyr2dqdvpm32lsin4zalv11w48x4xm80cr4kw45fk5"; - system = "ml-optimizer"; - asd = "ml-optimizer"; - }); - systems = [ "ml-optimizer" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "cl-marklogic" self) (getAttr "cl-opsresearch" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ml-test = (build-asdf-system { - pname = "ml-test"; - version = "20210124-git"; - asds = [ "ml-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-marklogic/2021-01-24/cl-marklogic-20210124-git.tgz"; - sha256 = "0baq2ccb88zyr2dqdvpm32lsin4zalv11w48x4xm80cr4kw45fk5"; - system = "ml-test"; - asd = "ml-test"; - }); - systems = [ "ml-test" ]; - lispLibs = [ (getAttr "cl-marklogic" self) (getAttr "fiveam" self) (getAttr "ml-optimizer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mlep = (build-asdf-system { - pname = "mlep"; - version = "20231021-git"; - asds = [ "mlep" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mlep/2023-10-21/cl-mlep-20231021-git.tgz"; - sha256 = "0na6hjjp1a3bril14v878h9198zrbymnfw7nybgcll0kwv90815g"; - system = "mlep"; - asd = "mlep"; - }); - systems = [ "mlep" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mlep-add = (build-asdf-system { - pname = "mlep-add"; - version = "20231021-git"; - asds = [ "mlep-add" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mlep/2023-10-21/cl-mlep-20231021-git.tgz"; - sha256 = "0na6hjjp1a3bril14v878h9198zrbymnfw7nybgcll0kwv90815g"; - system = "mlep-add"; - asd = "mlep-add"; - }); - systems = [ "mlep-add" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "lla" self) (getAttr "mlep" self) (getAttr "num-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mmap = (build-asdf-system { - pname = "mmap"; - version = "20241012-git"; - asds = [ "mmap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mmap/2024-10-12/mmap-20241012-git.tgz"; - sha256 = "1wlxymkkbjyyp6fikxi94q26pjfz656y4d8kgm22xxvw70hppgc3"; - system = "mmap"; - asd = "mmap"; - }); - systems = [ "mmap" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) ]; - meta = {}; - }); - mmap-test = (build-asdf-system { - pname = "mmap-test"; - version = "20241012-git"; - asds = [ "mmap-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mmap/2024-10-12/mmap-20241012-git.tgz"; - sha256 = "1wlxymkkbjyyp6fikxi94q26pjfz656y4d8kgm22xxvw70hppgc3"; - system = "mmap-test"; - asd = "mmap-test"; - }); - systems = [ "mmap-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "mmap" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mnas-graph = (build-asdf-system { - pname = "mnas-graph"; - version = "20230618-git"; - asds = [ "mnas-graph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mnas-graph/2023-06-18/mnas-graph-20230618-git.tgz"; - sha256 = "1psz8vh8s8zv9hh5pr0753r0baavfb1v6v9nc9kw50hkjvkchc1q"; - system = "mnas-graph"; - asd = "mnas-graph"; - }); - systems = [ "mnas-graph" ]; - lispLibs = [ (getAttr "mnas-hash-table" self) (getAttr "mnas-string" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mnas-hash-table = (build-asdf-system { - pname = "mnas-hash-table"; - version = "20230618-git"; - asds = [ "mnas-hash-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mnas-hash-table/2023-06-18/mnas-hash-table-20230618-git.tgz"; - sha256 = "107fqc2wipvs2ifj12sqizv3gc7j3yqww529vkp92xhkmrnkp833"; - system = "mnas-hash-table"; - asd = "mnas-hash-table"; - }); - systems = [ "mnas-hash-table" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mnas-package = (build-asdf-system { - pname = "mnas-package"; - version = "20241012-git"; - asds = [ "mnas-package" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mnas-package/2024-10-12/mnas-package-20241012-git.tgz"; - sha256 = "05wkh2rzlp3csnk3p50rp3jv4jycdqa5hylqf93b2q8vjxvv67wm"; - system = "mnas-package"; - asd = "mnas-package"; - }); - systems = [ "mnas-package" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "inferior-shell" self) (getAttr "mnas-graph" self) (getAttr "mnas-string" self) (getAttr "slynk" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mnas-path = (build-asdf-system { - pname = "mnas-path"; - version = "20231021-git"; - asds = [ "mnas-path" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mnas-path/2023-10-21/mnas-path-20231021-git.tgz"; - sha256 = "10hijr71nlnl9wf15ahzjgynvq1n1y8446fxk7pkfwcw832x874z"; - system = "mnas-path"; - asd = "mnas-path"; - }); - systems = [ "mnas-path" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "mnas-string" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mnas-string = (build-asdf-system { - pname = "mnas-string"; - version = "20241012-git"; - asds = [ "mnas-string" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mnas-string/2024-10-12/mnas-string-20241012-git.tgz"; - sha256 = "1pk0fyi3pjq7h9x40hixapsa06s0dah6xd4d63jpyhp7y6fa8w6f"; - system = "mnas-string"; - asd = "mnas-string"; - }); - systems = [ "mnas-string" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "mnas-hash-table" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mnst-relay = (build-asdf-system { - pname = "mnst-relay"; - version = "20210807-git"; - asds = [ "mnst-relay" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; - sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; - system = "mnst-relay"; - asd = "mnst-relay"; - }); - systems = [ "mnst-relay" ]; - lispLibs = [ (getAttr "asdf-nst" self) (getAttr "nst" self) (getAttr "nst-selftest-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mockingbird = (build-asdf-system { - pname = "mockingbird"; - version = "20211020-git"; - asds = [ "mockingbird" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mockingbird/2021-10-20/mockingbird-20211020-git.tgz"; - sha256 = "1n1mxl2qk7g63z92d943ysn12axw0bx5dvw0cmm3cs1hjpx5rdly"; - system = "mockingbird"; - asd = "mockingbird"; - }); - systems = [ "mockingbird" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "fare-utils" self) (getAttr "trivial-arguments" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mockingbird-test = (build-asdf-system { - pname = "mockingbird-test"; - version = "20211020-git"; - asds = [ "mockingbird-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mockingbird/2021-10-20/mockingbird-20211020-git.tgz"; - sha256 = "1n1mxl2qk7g63z92d943ysn12axw0bx5dvw0cmm3cs1hjpx5rdly"; - system = "mockingbird-test"; - asd = "mockingbird-test"; - }); - systems = [ "mockingbird-test" ]; - lispLibs = [ (getAttr "mockingbird" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - modest-config = (build-asdf-system { - pname = "modest-config"; - version = "20180228-git"; - asds = [ "modest-config" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/modest-config/2018-02-28/modest-config-20180228-git.tgz"; - sha256 = "0ali9lvg7ngzmpgaxmbc4adp4djznavbywiig8x94c2xwicvjh83"; - system = "modest-config"; - asd = "modest-config"; - }); - systems = [ "modest-config" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - modest-config-test = (build-asdf-system { - pname = "modest-config-test"; - version = "20180228-git"; - asds = [ "modest-config-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/modest-config/2018-02-28/modest-config-20180228-git.tgz"; - sha256 = "0ali9lvg7ngzmpgaxmbc4adp4djznavbywiig8x94c2xwicvjh83"; - system = "modest-config-test"; - asd = "modest-config-test"; - }); - systems = [ "modest-config-test" ]; - lispLibs = [ (getAttr "modest-config" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - modf = (build-asdf-system { - pname = "modf"; - version = "20200925-git"; - asds = [ "modf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/modf/2020-09-25/modf-20200925-git.tgz"; - sha256 = "1aap7ldy7lv942khp026pgndgdzfkkqa9xcq1ykinrmflrgdazay"; - system = "modf"; - asd = "modf"; - }); - systems = [ "modf" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - modf-fset = (build-asdf-system { - pname = "modf-fset"; - version = "20150608-git"; - asds = [ "modf-fset" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/modf-fset/2015-06-08/modf-fset-20150608-git.tgz"; - sha256 = "0xdlwsw3b31l9c6db7rgvikn42ncqk98s45zcq116f51ph3dr95y"; - system = "modf-fset"; - asd = "modf-fset"; - }); - systems = [ "modf-fset" ]; - lispLibs = [ (getAttr "fset" self) (getAttr "modf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - modf-fset-test = (build-asdf-system { - pname = "modf-fset-test"; - version = "20150608-git"; - asds = [ "modf-fset-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/modf-fset/2015-06-08/modf-fset-20150608-git.tgz"; - sha256 = "0xdlwsw3b31l9c6db7rgvikn42ncqk98s45zcq116f51ph3dr95y"; - system = "modf-fset-test"; - asd = "modf-fset-test"; - }); - systems = [ "modf-fset-test" ]; - lispLibs = [ (getAttr "modf" self) (getAttr "modf-fset" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - modf-test = (build-asdf-system { - pname = "modf-test"; - version = "20200925-git"; - asds = [ "modf-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/modf/2020-09-25/modf-20200925-git.tgz"; - sha256 = "1aap7ldy7lv942khp026pgndgdzfkkqa9xcq1ykinrmflrgdazay"; - system = "modf-test"; - asd = "modf-test"; - }); - systems = [ "modf-test" ]; - lispLibs = [ (getAttr "iterate" self) (getAttr "modf" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - modlisp = (build-asdf-system { - pname = "modlisp"; - version = "20150923-git"; - asds = [ "modlisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-modlisp/2015-09-23/cl-modlisp-20150923-git.tgz"; - sha256 = "14gfhhy8blyrhpb1jk17bq4vazgwmzgcx3misw48ja77x17bl1zf"; - system = "modlisp"; - asd = "modlisp"; - }); - systems = [ "modlisp" ]; - lispLibs = [ (getAttr "kmrcl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - modularize = (build-asdf-system { - pname = "modularize"; - version = "20231021-git"; - asds = [ "modularize" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/modularize/2023-10-21/modularize-20231021-git.tgz"; - sha256 = "1i660gpljl97j51sj4mx8pk91v96zddww24rbwz0p20cl9hfp0xj"; - system = "modularize"; - asd = "modularize"; - }); - systems = [ "modularize" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "trivial-package-local-nicknames" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - modularize-hooks = (build-asdf-system { - pname = "modularize-hooks"; - version = "20231021-git"; - asds = [ "modularize-hooks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/modularize-hooks/2023-10-21/modularize-hooks-20231021-git.tgz"; - sha256 = "0f60rk9753vil56wyi54db35ffanjw5fmkyn79jc5hnlab78ffhy"; - system = "modularize-hooks"; - asd = "modularize-hooks"; - }); - systems = [ "modularize-hooks" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "lambda-fiddle" self) (getAttr "modularize" self) (getAttr "trivial-arguments" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - modularize-interfaces = (build-asdf-system { - pname = "modularize-interfaces"; - version = "20231021-git"; - asds = [ "modularize-interfaces" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/modularize-interfaces/2023-10-21/modularize-interfaces-20231021-git.tgz"; - sha256 = "0lmq2jbkbr5wrrjl2qb1x64fcvl0lmii0h9301b9bq4d47s4w8sh"; - system = "modularize-interfaces"; - asd = "modularize-interfaces"; - }); - systems = [ "modularize-interfaces" ]; - lispLibs = [ (getAttr "lambda-fiddle" self) (getAttr "modularize" self) (getAttr "trivial-arguments" self) (getAttr "trivial-indent" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - modularize-test-module = (build-asdf-system { - pname = "modularize-test-module"; - version = "20231021-git"; - asds = [ "modularize-test-module" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/modularize/2023-10-21/modularize-20231021-git.tgz"; - sha256 = "1i660gpljl97j51sj4mx8pk91v96zddww24rbwz0p20cl9hfp0xj"; - system = "modularize-test-module"; - asd = "modularize-test-module"; - }); - systems = [ "modularize-test-module" ]; - lispLibs = [ (getAttr "modularize" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - moira = (build-asdf-system { - pname = "moira"; - version = "20241012-git"; - asds = [ "moira" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/moira/2024-10-12/moira-20241012-git.tgz"; - sha256 = "01wxjg122flla4pgys57hya3fwrkyjkpp26j5ypl5885zz1ip5b7"; - system = "moira"; - asd = "moira"; - }); - systems = [ "moira" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "osicat" self) (getAttr "serapeum" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - monkeylib-html = (build-asdf-system { - pname = "monkeylib-html"; - version = "20180228-git"; - asds = [ "monkeylib-html" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-html/2018-02-28/monkeylib-html-20180228-git.tgz"; - sha256 = "11a778ynyb8mhiy9fkpyg2x1p53hi1i9mry9gfin2r28mjgwj096"; - system = "monkeylib-html"; - asd = "monkeylib-html"; - }); - systems = [ "monkeylib-html" ]; - lispLibs = [ (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) (getAttr "com_dot_gigamonkeys_dot_pathnames" self) (getAttr "com_dot_gigamonkeys_dot_test-framework" self) (getAttr "com_dot_gigamonkeys_dot_utilities" self) (getAttr "monkeylib-text-languages" self) (getAttr "monkeylib-text-output" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - monkeylib-markup-html = (build-asdf-system { - pname = "monkeylib-markup-html"; - version = "20120208-git"; - asds = [ "monkeylib-markup-html" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-markup-html/2012-02-08/monkeylib-markup-html-20120208-git.tgz"; - sha256 = "1kwnlb7dka9bqyc8a06lbsap8j83kdayk4m9a1m3mazjgaxlpv2a"; - system = "monkeylib-markup-html"; - asd = "monkeylib-markup-html"; - }); - systems = [ "monkeylib-markup-html" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) (getAttr "com_dot_gigamonkeys_dot_markup" self) (getAttr "com_dot_gigamonkeys_dot_utilities" self) (getAttr "monkeylib-html" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - monkeylib-text-languages = (build-asdf-system { - pname = "monkeylib-text-languages"; - version = "20111203-git"; - asds = [ "monkeylib-text-languages" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-text-languages/2011-12-03/monkeylib-text-languages-20111203-git.tgz"; - sha256 = "1f6hb3r2s5phz5z4rv3llyfi30vbxlq9qpipsq9vppmw51fvdsdk"; - system = "monkeylib-text-languages"; - asd = "monkeylib-text-languages"; - }); - systems = [ "monkeylib-text-languages" ]; - lispLibs = [ (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) (getAttr "monkeylib-text-output" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - monkeylib-text-output = (build-asdf-system { - pname = "monkeylib-text-output"; - version = "20111203-git"; - asds = [ "monkeylib-text-output" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/monkeylib-text-output/2011-12-03/monkeylib-text-output-20111203-git.tgz"; - sha256 = "0lygfxap2ppxxi0sbz8lig1h878ad84jwbp3c895r7h9svjh1ffm"; - system = "monkeylib-text-output"; - asd = "monkeylib-text-output"; - }); - systems = [ "monkeylib-text-output" ]; - lispLibs = [ (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) (getAttr "com_dot_gigamonkeys_dot_pathnames" self) (getAttr "com_dot_gigamonkeys_dot_test-framework" self) (getAttr "com_dot_gigamonkeys_dot_utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - montezuma = (build-asdf-system { - pname = "montezuma"; - version = "20180228-git"; - asds = [ "montezuma" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/montezuma/2018-02-28/montezuma-20180228-git.tgz"; - sha256 = "0svmvsbsirydk3c1spzfvj8qmkzcs9i69anpfvk1843i62wb7x2c"; - system = "montezuma"; - asd = "montezuma"; - }); - systems = [ "montezuma" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - montezuma-indexfiles = (build-asdf-system { - pname = "montezuma-indexfiles"; - version = "20180228-git"; - asds = [ "montezuma-indexfiles" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/montezuma/2018-02-28/montezuma-20180228-git.tgz"; - sha256 = "0svmvsbsirydk3c1spzfvj8qmkzcs9i69anpfvk1843i62wb7x2c"; - system = "montezuma-indexfiles"; - asd = "montezuma-indexfiles"; - }); - systems = [ "montezuma-indexfiles" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "montezuma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - montezuma-tests = (build-asdf-system { - pname = "montezuma-tests"; - version = "20180228-git"; - asds = [ "montezuma-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/montezuma/2018-02-28/montezuma-20180228-git.tgz"; - sha256 = "0svmvsbsirydk3c1spzfvj8qmkzcs9i69anpfvk1843i62wb7x2c"; - system = "montezuma-tests"; - asd = "montezuma"; - }); - systems = [ "montezuma-tests" ]; - lispLibs = [ (getAttr "montezuma" self) (getAttr "trivial-timeout" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - moptilities = (build-asdf-system { - pname = "moptilities"; - version = "20170403-git"; - asds = [ "moptilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/moptilities/2017-04-03/moptilities-20170403-git.tgz"; - sha256 = "1q12bqjbj47lx98yim1kfnnhgfhkl80102fkgp9pdqxg0fp6g5fc"; - system = "moptilities"; - asd = "moptilities"; - }); - systems = [ "moptilities" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = {}; - }); - moptilities-test = (build-asdf-system { - pname = "moptilities-test"; - version = "20170403-git"; - asds = [ "moptilities-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/moptilities/2017-04-03/moptilities-20170403-git.tgz"; - sha256 = "1q12bqjbj47lx98yim1kfnnhgfhkl80102fkgp9pdqxg0fp6g5fc"; - system = "moptilities-test"; - asd = "moptilities-test"; - }); - systems = [ "moptilities-test" ]; - lispLibs = [ (getAttr "lift" self) (getAttr "moptilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - more-conditions = (build-asdf-system { - pname = "more-conditions"; - version = "20180831-git"; - asds = [ "more-conditions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/more-conditions/2018-08-31/more-conditions-20180831-git.tgz"; - sha256 = "1n0xbz0yiqn9dxf0ycm57wqvsr4gh2q4hs5fskjbv87c47d7l7zr"; - system = "more-conditions"; - asd = "more-conditions"; - }); - systems = [ "more-conditions" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) ]; - meta = {}; - }); - mp3-duration = (build-asdf-system { - pname = "mp3-duration"; - version = "20160208-git"; - asds = [ "mp3-duration" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mp3-duration/2016-02-08/mp3-duration-20160208-git.tgz"; - sha256 = "1mhn9g1kz2yan178m2adg0pz3dx2nmg7hq4gfmfz7lrlsxm08bs7"; - system = "mp3-duration"; - asd = "mp3-duration"; - }); - systems = [ "mp3-duration" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mp3-duration-test = (build-asdf-system { - pname = "mp3-duration-test"; - version = "20160208-git"; - asds = [ "mp3-duration-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mp3-duration/2016-02-08/mp3-duration-20160208-git.tgz"; - sha256 = "1mhn9g1kz2yan178m2adg0pz3dx2nmg7hq4gfmfz7lrlsxm08bs7"; - system = "mp3-duration-test"; - asd = "mp3-duration-test"; - }); - systems = [ "mp3-duration-test" ]; - lispLibs = [ (getAttr "mp3-duration" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mpc = (build-asdf-system { - pname = "mpc"; - version = "20160929-git"; - asds = [ "mpc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mpc/2016-09-29/mpc-20160929-git.tgz"; - sha256 = "1nig0v91m4ybcr19s50xijwv488qlma0b36zy6cric2y8wgclmsx"; - system = "mpc"; - asd = "mpc"; - }); - systems = [ "mpc" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mpg123-ffi = (build-asdf-system { - pname = "mpg123-ffi"; - version = "20151218-git"; - asds = [ "mpg123-ffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; - sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; - system = "mpg123-ffi"; - asd = "mpg123-ffi"; - }); - systems = [ "mpg123-ffi" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mra-wavelet-plot = (build-asdf-system { - pname = "mra-wavelet-plot"; - version = "20181210-git"; - asds = [ "mra-wavelet-plot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mra-wavelet-plot/2018-12-10/mra-wavelet-plot-20181210-git.tgz"; - sha256 = "0d6sdgj1zvkliga9drsqnj4l748vbcwwz744ayq5nnvp5fvhnc29"; - system = "mra-wavelet-plot"; - asd = "mra-wavelet-plot"; - }); - systems = [ "mra-wavelet-plot" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mssql = (build-asdf-system { - pname = "mssql"; - version = "20241012-git"; - asds = [ "mssql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-mssql/2024-10-12/cl-mssql-20241012-git.tgz"; - sha256 = "15hnlkx6d2vw46v7h01wljzag33j5is679amv74kzk4qq91wfkx2"; - system = "mssql"; - asd = "mssql"; - }); - systems = [ "mssql" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "garbage-pools" self) (getAttr "iterate" self) (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mstrings = (build-asdf-system { - pname = "mstrings"; - version = "20220707-git"; - asds = [ "mstrings" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mstrings/2022-07-07/mstrings-20220707-git.tgz"; - sha256 = "0s1zqwnv9agvlp79gh7y06rmly56v8nm1l594rry9gzwvvx1jj1k"; - system = "mstrings"; - asd = "mstrings"; - }); - systems = [ "mstrings" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mt19937 = (build-asdf-system { - pname = "mt19937"; - version = "1.1.1"; - asds = [ "mt19937" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mt19937/2011-02-19/mt19937-1.1.1.tgz"; - sha256 = "0h02ssnncc760b68ipm0sbrzrbnllp6fqabvw98w43af08s36xlg"; - system = "mt19937"; - asd = "mt19937"; - }); - systems = [ "mt19937" ]; - lispLibs = [ ]; - meta = {}; - }); - mtif = (build-asdf-system { - pname = "mtif"; - version = "20171130-git"; - asds = [ "mtif" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mtif/2017-11-30/mtif-20171130-git.tgz"; - sha256 = "0fzlf0xawv579i4jp5l994d7m220py5j169klaj0l43frgxb4n7y"; - system = "mtif"; - asd = "mtif"; - }); - systems = [ "mtif" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mtlisp = (build-asdf-system { - pname = "mtlisp"; - version = "20130615-git"; - asds = [ "mtlisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mtlisp/2013-06-15/mtlisp-20130615-git.tgz"; - sha256 = "0qpbhiy2z2q7mf4lf2lpj66a13xj7bj0c584d1i7zi156s2hcnvs"; - system = "mtlisp"; - asd = "mtlisp"; - }); - systems = [ "mtlisp" ]; - lispLibs = [ (getAttr "acl-compat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - multilang-documentation = (build-asdf-system { - pname = "multilang-documentation"; - version = "20231021-git"; - asds = [ "multilang-documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/multilang-documentation/2023-10-21/multilang-documentation-20231021-git.tgz"; - sha256 = "1v9sv81lx0ms9djz0hqhwdswg0rmzqv47g57k5jmzkx6lbjsya7z"; - system = "multilang-documentation"; - asd = "multilang-documentation"; - }); - systems = [ "multilang-documentation" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "language-codes" self) (getAttr "system-locale" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - multilang-documentation-utils = (build-asdf-system { - pname = "multilang-documentation-utils"; - version = "20231021-git"; - asds = [ "multilang-documentation-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/documentation-utils/2023-10-21/documentation-utils-20231021-git.tgz"; - sha256 = "0nzkjzvcqi1l2ywiz17h1f54vgvbkywv95in4yww6lyzqjqsqqhy"; - system = "multilang-documentation-utils"; - asd = "multilang-documentation-utils"; - }); - systems = [ "multilang-documentation-utils" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "multilang-documentation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - multiple-value-variants = (build-asdf-system { - pname = "multiple-value-variants"; - version = "1.0.1"; - asds = [ "multiple-value-variants" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/multiple-value-variants/2014-08-26/multiple-value-variants-1.0.1.tgz"; - sha256 = "0kb7bkgg2iri89ph2lcgfk57pf8h4r6471sn2jcyp5sz13g4f6yw"; - system = "multiple-value-variants"; - asd = "multiple-value-variants"; - }); - systems = [ "multiple-value-variants" ]; - lispLibs = [ (getAttr "enhanced-multiple-value-bind" self) (getAttr "map-bind" self) (getAttr "positional-lambda" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - multiposter = (build-asdf-system { - pname = "multiposter"; - version = "20241012-git"; - asds = [ "multiposter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/multiposter/2024-10-12/multiposter-20241012-git.tgz"; - sha256 = "1q1zinv4csnb0yjlndym5dlf7apax3f5qdiids3dlai09jb4hbjg"; - system = "multiposter"; - asd = "multiposter"; - }); - systems = [ "multiposter" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "clohost" self) (getAttr "closer-mop" self) (getAttr "documentation-utils" self) (getAttr "fuzzy-dates" self) (getAttr "humbler" self) (getAttr "lichat-tcp-client" self) (getAttr "lquery" self) (getAttr "north-drakma" self) (getAttr "pathname-utils" self) (getAttr "studio-client" self) (getAttr "tooter" self) (getAttr "trivial-arguments" self) (getAttr "trivial-mimes" self) (getAttr "ubiquitous" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - multival-plist = (build-asdf-system { - pname = "multival-plist"; - version = "20120305-git"; - asds = [ "multival-plist" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/multival-plist/2012-03-05/multival-plist-20120305-git.tgz"; - sha256 = "0cfca0qvngbvs9v4z8qpzr6wsjvf01jzaszagmasa4zkvmjycx1b"; - system = "multival-plist"; - asd = "multival-plist"; - }); - systems = [ "multival-plist" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-annot" self) (getAttr "cl-syntax-annot" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - multival-plist-test = (build-asdf-system { - pname = "multival-plist-test"; - version = "20120305-git"; - asds = [ "multival-plist-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/multival-plist/2012-03-05/multival-plist-20120305-git.tgz"; - sha256 = "0cfca0qvngbvs9v4z8qpzr6wsjvf01jzaszagmasa4zkvmjycx1b"; - system = "multival-plist-test"; - asd = "multival-plist-test"; - }); - systems = [ "multival-plist-test" ]; - lispLibs = [ (getAttr "cl-test-more" self) (getAttr "multival-plist" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - music-spelling = (build-asdf-system { - pname = "music-spelling"; - version = "20230214-git"; - asds = [ "music-spelling" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/music-spelling/2023-02-14/music-spelling-20230214-git.tgz"; - sha256 = "0fgahb0jjr4sp2739d55gylmx8alsghnx3spyaqfqci4cxfrys52"; - system = "music-spelling"; - asd = "music-spelling"; - }); - systems = [ "music-spelling" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mutility = (build-asdf-system { - pname = "mutility"; - version = "20241012-git"; - asds = [ "mutility" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mutility/2024-10-12/mutility-20241012-git.tgz"; - sha256 = "17ip4rkvval66k9r3a2hvpr4pqa087b3rqjdayl115fi6bfzncr4"; - system = "mutility"; - asd = "mutility"; - }); - systems = [ "mutility" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mutils = (build-asdf-system { - pname = "mutils"; - version = "20241012-git"; - asds = [ "mutils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mutils/2024-10-12/mutils-20241012-git.tgz"; - sha256 = "1xmqms002bafrdrpzgqq5dr0qfiywg3p7mhvb6xny1jrk3qdqz75"; - system = "mutils"; - asd = "mutils"; - }); - systems = [ "mutils" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mw-equiv = (build-asdf-system { - pname = "mw-equiv"; - version = "0.1.3"; - asds = [ "mw-equiv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mw-equiv/2010-10-06/mw-equiv-0.1.3.tgz"; - sha256 = "1fl90wp0jp7l90mps53fq0kzb28f10qfr739527h03xwqccyylad"; - system = "mw-equiv"; - asd = "mw-equiv"; - }); - systems = [ "mw-equiv" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - my-cool-system = (build-asdf-system { - pname = "my-cool-system"; - version = "20231021-git"; - asds = [ "my-cool-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/super-loader/2023-10-21/super-loader-20231021-git.tgz"; - sha256 = "0jicqg3w1yhwkmjfag0lvlhw83w2hpanwav1gzyf4s58sng6cxf4"; - system = "my-cool-system"; - asd = "my-cool-system"; - }); - systems = [ "my-cool-system" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - my-secret-system = (build-asdf-system { - pname = "my-secret-system"; - version = "20231021-git"; - asds = [ "my-secret-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/super-loader/2023-10-21/super-loader-20231021-git.tgz"; - sha256 = "0jicqg3w1yhwkmjfag0lvlhw83w2hpanwav1gzyf4s58sng6cxf4"; - system = "my-secret-system"; - asd = "my-secret-system"; - }); - systems = [ "my-secret-system" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mystic = (build-asdf-system { - pname = "mystic"; - version = "20230618-git"; - asds = [ "mystic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; - sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; - system = "mystic"; - asd = "mystic"; - }); - systems = [ "mystic" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cl-mustache" self) (getAttr "local-time" self) (getAttr "split-sequence" self) (getAttr "ubiquitous" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mystic-file-mixin = (build-asdf-system { - pname = "mystic-file-mixin"; - version = "20230618-git"; - asds = [ "mystic-file-mixin" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; - sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; - system = "mystic-file-mixin"; - asd = "mystic-file-mixin"; - }); - systems = [ "mystic-file-mixin" ]; - lispLibs = [ (getAttr "mystic" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mystic-fiveam-mixin = (build-asdf-system { - pname = "mystic-fiveam-mixin"; - version = "20230618-git"; - asds = [ "mystic-fiveam-mixin" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; - sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; - system = "mystic-fiveam-mixin"; - asd = "mystic-fiveam-mixin"; - }); - systems = [ "mystic-fiveam-mixin" ]; - lispLibs = [ (getAttr "mystic" self) (getAttr "mystic-file-mixin" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mystic-gitignore-mixin = (build-asdf-system { - pname = "mystic-gitignore-mixin"; - version = "20230618-git"; - asds = [ "mystic-gitignore-mixin" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; - sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; - system = "mystic-gitignore-mixin"; - asd = "mystic-gitignore-mixin"; - }); - systems = [ "mystic-gitignore-mixin" ]; - lispLibs = [ (getAttr "mystic" self) (getAttr "mystic-file-mixin" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mystic-library-template = (build-asdf-system { - pname = "mystic-library-template"; - version = "20230618-git"; - asds = [ "mystic-library-template" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; - sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; - system = "mystic-library-template"; - asd = "mystic-library-template"; - }); - systems = [ "mystic-library-template" ]; - lispLibs = [ (getAttr "mystic" self) (getAttr "mystic-fiveam-mixin" self) (getAttr "mystic-gitignore-mixin" self) (getAttr "mystic-readme-mixin" self) (getAttr "mystic-travis-mixin" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mystic-readme-mixin = (build-asdf-system { - pname = "mystic-readme-mixin"; - version = "20230618-git"; - asds = [ "mystic-readme-mixin" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; - sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; - system = "mystic-readme-mixin"; - asd = "mystic-readme-mixin"; - }); - systems = [ "mystic-readme-mixin" ]; - lispLibs = [ (getAttr "mystic" self) (getAttr "mystic-file-mixin" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mystic-test = (build-asdf-system { - pname = "mystic-test"; - version = "20230618-git"; - asds = [ "mystic-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; - sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; - system = "mystic-test"; - asd = "mystic-test"; - }); - systems = [ "mystic-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "mystic" self) (getAttr "mystic-library-template" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - mystic-travis-mixin = (build-asdf-system { - pname = "mystic-travis-mixin"; - version = "20230618-git"; - asds = [ "mystic-travis-mixin" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; - sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; - system = "mystic-travis-mixin"; - asd = "mystic-travis-mixin"; - }); - systems = [ "mystic-travis-mixin" ]; - lispLibs = [ (getAttr "mystic" self) (getAttr "mystic-file-mixin" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - myway = (build-asdf-system { - pname = "myway"; - version = "20221106-git"; - asds = [ "myway" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/myway/2022-11-06/myway-20221106-git.tgz"; - sha256 = "0xac8xpbcvq457f2jzzkf46mh5ganf1k2ix8sg61hqqmld5z4dag"; - system = "myway"; - asd = "myway"; - }); - systems = [ "myway" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "cl-utilities" self) (getAttr "map-set" self) (getAttr "quri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - myway-test = (build-asdf-system { - pname = "myway-test"; - version = "20221106-git"; - asds = [ "myway-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/myway/2022-11-06/myway-20221106-git.tgz"; - sha256 = "0xac8xpbcvq457f2jzzkf46mh5ganf1k2ix8sg61hqqmld5z4dag"; - system = "myway-test"; - asd = "myway-test"; - }); - systems = [ "myway-test" ]; - lispLibs = [ (getAttr "myway" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - myweb = (build-asdf-system { - pname = "myweb"; - version = "20241012-git"; - asds = [ "myweb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/myweb/2024-10-12/myweb-20241012-git.tgz"; - sha256 = "10r67w3cgrq0r7qmqdnv4c3pjz7kkhz9q3jj0amlknr0nsr4y2zp"; - system = "myweb"; - asd = "myweb"; - }); - systems = [ "myweb" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-log" self) (getAttr "local-time" self) (getAttr "trivial-utf-8" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nail = (build-asdf-system { - pname = "nail"; - version = "20230214-git"; - asds = [ "nail" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nail/2023-02-14/nail-20230214-git.tgz"; - sha256 = "0m5a1zx9s033mz3ypx27c26z5bvc8mcpnpzslypzdp6xah1nv0g3"; - system = "nail"; - asd = "nail"; - }); - systems = [ "nail" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cl-reexport" self) (getAttr "eazy-gnuplot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - named-closure = (build-asdf-system { - pname = "named-closure"; - version = "20241012-git"; - asds = [ "named-closure" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/named-closure/2024-10-12/named-closure-20241012-git.tgz"; - sha256 = "1ja7lvid589n3r25vh7j21wji60dm2qika2jn51jvfbbii853x09"; - system = "named-closure"; - asd = "named-closure"; - }); - systems = [ "named-closure" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "hu_dot_dwim_dot_walker" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - named-read-macros = (build-asdf-system { - pname = "named-read-macros"; - version = "20210228-git"; - asds = [ "named-read-macros" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/named-read-macros/2021-02-28/named-read-macros-20210228-git.tgz"; - sha256 = "0bgqy43h06nq2p9avqix2k15ab306sghrz2pkr17pli87q0qkxhi"; - system = "named-read-macros"; - asd = "named-read-macros"; - }); - systems = [ "named-read-macros" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - named-read-macros-test = (build-asdf-system { - pname = "named-read-macros-test"; - version = "20210228-git"; - asds = [ "named-read-macros-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/named-read-macros/2021-02-28/named-read-macros-20210228-git.tgz"; - sha256 = "0bgqy43h06nq2p9avqix2k15ab306sghrz2pkr17pli87q0qkxhi"; - system = "named-read-macros-test"; - asd = "named-read-macros-test"; - }); - systems = [ "named-read-macros-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "named-read-macros" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - named-readtables = (build-asdf-system { - pname = "named-readtables"; - version = "20231021-git"; - asds = [ "named-readtables" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/named-readtables/2023-10-21/named-readtables-20231021-git.tgz"; - sha256 = "0cnxs13qf0y1r05mhhf54jihvv7pqk1a2p3x5jzs4y8ld1in6xzp"; - system = "named-readtables"; - asd = "named-readtables"; - }); - systems = [ "named-readtables" ]; - lispLibs = [ (getAttr "mgl-pax-bootstrap" self) ]; - meta = {}; - }); - named-readtables-test = (build-asdf-system { - pname = "named-readtables-test"; - version = "20231021-git"; - asds = [ "named-readtables-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/named-readtables/2023-10-21/named-readtables-20231021-git.tgz"; - sha256 = "0cnxs13qf0y1r05mhhf54jihvv7pqk1a2p3x5jzs4y8ld1in6xzp"; - system = "named-readtables-test"; - asd = "named-readtables-test"; - }); - systems = [ "named-readtables-test" ]; - lispLibs = [ (getAttr "named-readtables" self) (getAttr "try" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nanovg-blob = (build-asdf-system { - pname = "nanovg-blob"; - version = "stable-git"; - asds = [ "nanovg-blob" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nanovg-blob/2020-10-16/nanovg-blob-stable-git.tgz"; - sha256 = "1q80inrlfcqqqc912jcskfn667jgq6lcw0jvhk270x5qpj8z2pfj"; - system = "nanovg-blob"; - asd = "nanovg-blob"; - }); - systems = [ "nanovg-blob" ]; - lispLibs = [ (getAttr "bodge-blobs-support" self) (getAttr "glad-blob" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - napa-fft3 = (build-asdf-system { - pname = "napa-fft3"; - version = "20151218-git"; - asds = [ "napa-fft3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/napa-fft3/2015-12-18/napa-fft3-20151218-git.tgz"; - sha256 = "1hxjf599xgwm28gbryy7q96j9ys6hfszmv0qxpr5698hxnhknscp"; - system = "napa-fft3"; - asd = "napa-fft3"; - }); - systems = [ "napa-fft3" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - narrowed-types = (build-asdf-system { - pname = "narrowed-types"; - version = "20180228-git"; - asds = [ "narrowed-types" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/narrowed-types/2018-02-28/narrowed-types-20180228-git.tgz"; - sha256 = "03v4jgdysapj3ndg2qij7liqc6n9zb07r5j4k1jhmhpml86jxg4g"; - system = "narrowed-types"; - asd = "narrowed-types"; - }); - systems = [ "narrowed-types" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - narrowed-types-test = (build-asdf-system { - pname = "narrowed-types-test"; - version = "20180228-git"; - asds = [ "narrowed-types-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/narrowed-types/2018-02-28/narrowed-types-20180228-git.tgz"; - sha256 = "03v4jgdysapj3ndg2qij7liqc6n9zb07r5j4k1jhmhpml86jxg4g"; - system = "narrowed-types-test"; - asd = "narrowed-types-test"; - }); - systems = [ "narrowed-types-test" ]; - lispLibs = [ (getAttr "narrowed-types" self) (getAttr "rt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - native-lazy-seq = (build-asdf-system { - pname = "native-lazy-seq"; - version = "20230618-git"; - asds = [ "native-lazy-seq" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/native-lazy-seq/2023-06-18/native-lazy-seq-20230618-git.tgz"; - sha256 = "1p5zja0qg61girf67ic8j6wv9s1faxki0mazxmydbm92ckrns2rp"; - system = "native-lazy-seq"; - asd = "native-lazy-seq"; - }); - systems = [ "native-lazy-seq" ]; - lispLibs = [ (getAttr "iterate" self) (getAttr "serapeum" self) (getAttr "trivial-extensible-sequences" self) (getAttr "trivial-package-local-nicknames" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nbd = (build-asdf-system { - pname = "nbd"; - version = "20211020-git"; - asds = [ "nbd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nbd/2021-10-20/nbd-20211020-git.tgz"; - sha256 = "1p9dpyvlpjm32a2ymhps782dp5pjya5bnky6sb20gf4zyw6r826n"; - system = "nbd"; - asd = "nbd"; - }); - systems = [ "nbd" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "flexi-streams" self) (getAttr "lisp-binary" self) (getAttr "wild-package-inferred-system" self) ]; - meta = {}; - }); - ncurses-clone-for-lem = (build-asdf-system { - pname = "ncurses-clone-for-lem"; - version = "20200427-git"; - asds = [ "ncurses-clone-for-lem" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "ncurses-clone-for-lem"; - asd = "ncurses-clone-for-lem"; - }); - systems = [ "ncurses-clone-for-lem" ]; - lispLibs = [ (getAttr "application" self) (getAttr "cffi" self) (getAttr "cl-ppcre" self) (getAttr "lparallel" self) (getAttr "nsb-cga" self) (getAttr "text-subsystem" self) (getAttr "utility" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ndebug = (build-asdf-system { - pname = "ndebug"; - version = "20241012-git"; - asds = [ "ndebug" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ndebug/2024-10-12/ndebug-20241012-git.tgz"; - sha256 = "168khn4190p55fjhbpnbq130lbaafq7cw0131x7n650d9f4h2hyq"; - system = "ndebug"; - asd = "ndebug"; - }); - systems = [ "ndebug" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "dissect" self) (getAttr "trivial-custom-debugger" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ndfa = (build-asdf-system { - pname = "ndfa"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "ndfa" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "ndfa"; - asd = "ndfa"; - }); - systems = [ "ndfa" ]; - lispLibs = [ (getAttr "adjuvant" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ndfa-test = (build-asdf-system { - pname = "ndfa-test"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "ndfa-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "ndfa-test"; - asd = "ndfa-test"; - }); - systems = [ "ndfa-test" ]; - lispLibs = [ (getAttr "adjuvant" self) (getAttr "ndfa" self) (getAttr "scrutiny" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net-telent-date = (build-asdf-system { - pname = "net-telent-date"; - version = "0.42"; - asds = [ "net-telent-date" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/net-telent-date/2010-10-06/net-telent-date_0.42.tgz"; - sha256 = "0vgibf76hy3zy39pix367xnvpwxiqsxvv6w0gqdxprd5ljpb7g2j"; - system = "net-telent-date"; - asd = "net-telent-date"; - }); - systems = [ "net-telent-date" ]; - lispLibs = [ ]; - meta = {}; - }); - net_dot_didierverna_dot_asdf-flv = (build-asdf-system { - pname = "net.didierverna.asdf-flv"; - version = "version-2.2"; - asds = [ "net.didierverna.asdf-flv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-flv/2023-10-21/asdf-flv-version-2.2.tgz"; - sha256 = "1svcjhdlsdayr07qa38kj8n5m40qplklspmlrkmvc5wdhk9jz8sw"; - system = "net.didierverna.asdf-flv"; - asd = "net.didierverna.asdf-flv"; - }); - systems = [ "net.didierverna.asdf-flv" ]; - lispLibs = [ ]; - meta = {}; - }); - net_dot_didierverna_dot_clon = (build-asdf-system { - pname = "net.didierverna.clon"; - version = "version-1.0b27"; - asds = [ "net.didierverna.clon" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-clon/2023-10-21/cl-clon-version-1.0b27.tgz"; - sha256 = "0cyh5z78r7qhv2rzghkhksgg848d6iy1xv7y87p3aivd23c916b1"; - system = "net.didierverna.clon"; - asd = "net.didierverna.clon"; - }); - systems = [ "net.didierverna.clon" ]; - lispLibs = [ (getAttr "net_dot_didierverna_dot_clon_dot_core" self) (getAttr "net_dot_didierverna_dot_clon_dot_setup" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_clon_dot_core = (build-asdf-system { - pname = "net.didierverna.clon.core"; - version = "version-1.0b27"; - asds = [ "net.didierverna.clon.core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-clon/2023-10-21/cl-clon-version-1.0b27.tgz"; - sha256 = "0cyh5z78r7qhv2rzghkhksgg848d6iy1xv7y87p3aivd23c916b1"; - system = "net.didierverna.clon.core"; - asd = "net.didierverna.clon.core"; - }); - systems = [ "net.didierverna.clon.core" ]; - lispLibs = [ (getAttr "net_dot_didierverna_dot_clon_dot_setup" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_clon_dot_demo_dot_advanced = (build-asdf-system { - pname = "net.didierverna.clon.demo.advanced"; - version = "version-1.0b27"; - asds = [ "net.didierverna.clon.demo.advanced" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-clon/2023-10-21/cl-clon-version-1.0b27.tgz"; - sha256 = "0cyh5z78r7qhv2rzghkhksgg848d6iy1xv7y87p3aivd23c916b1"; - system = "net.didierverna.clon.demo.advanced"; - asd = "net.didierverna.clon.demo.advanced"; - }); - systems = [ "net.didierverna.clon.demo.advanced" ]; - lispLibs = [ (getAttr "net_dot_didierverna_dot_clon" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_clon_dot_demo_dot_simple = (build-asdf-system { - pname = "net.didierverna.clon.demo.simple"; - version = "version-1.0b27"; - asds = [ "net.didierverna.clon.demo.simple" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-clon/2023-10-21/cl-clon-version-1.0b27.tgz"; - sha256 = "0cyh5z78r7qhv2rzghkhksgg848d6iy1xv7y87p3aivd23c916b1"; - system = "net.didierverna.clon.demo.simple"; - asd = "net.didierverna.clon.demo.simple"; - }); - systems = [ "net.didierverna.clon.demo.simple" ]; - lispLibs = [ (getAttr "net_dot_didierverna_dot_clon" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_clon_dot_setup = (build-asdf-system { - pname = "net.didierverna.clon.setup"; - version = "version-1.0b27"; - asds = [ "net.didierverna.clon.setup" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-clon/2023-10-21/cl-clon-version-1.0b27.tgz"; - sha256 = "0cyh5z78r7qhv2rzghkhksgg848d6iy1xv7y87p3aivd23c916b1"; - system = "net.didierverna.clon.setup"; - asd = "net.didierverna.clon.setup"; - }); - systems = [ "net.didierverna.clon.setup" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_clon_dot_termio = (build-asdf-system { - pname = "net.didierverna.clon.termio"; - version = "version-1.0b27"; - asds = [ "net.didierverna.clon.termio" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-clon/2023-10-21/cl-clon-version-1.0b27.tgz"; - sha256 = "0cyh5z78r7qhv2rzghkhksgg848d6iy1xv7y87p3aivd23c916b1"; - system = "net.didierverna.clon.termio"; - asd = "net.didierverna.clon.termio"; - }); - systems = [ "net.didierverna.clon.termio" ]; - lispLibs = [ (getAttr "net_dot_didierverna_dot_clon_dot_core" self) (getAttr "net_dot_didierverna_dot_clon_dot_setup" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_declt_dot_setup = (build-asdf-system { - pname = "net.didierverna.declt.setup"; - version = "4.0b2"; - asds = [ "net.didierverna.declt.setup" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/declt/2024-10-12/declt-4.0b2.tgz"; - sha256 = "1xkbf1xqrkmr8na09b0spmrznsx2ml10i9q026zv9mpbsc7gh0i6"; - system = "net.didierverna.declt.setup"; - asd = "net.didierverna.declt.setup"; - }); - systems = [ "net.didierverna.declt.setup" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_focus = (build-asdf-system { - pname = "net.didierverna.focus"; - version = "20170403-git"; - asds = [ "net.didierverna.focus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/focus/2017-04-03/focus-20170403-git.tgz"; - sha256 = "0b7nxqlkfi7irdmhsbp15r63c8fcg8q0ahmwmq5cmkf8ffq8dspc"; - system = "net.didierverna.focus"; - asd = "net.didierverna.focus"; - }); - systems = [ "net.didierverna.focus" ]; - lispLibs = [ (getAttr "net_dot_didierverna_dot_focus_dot_core" self) (getAttr "net_dot_didierverna_dot_focus_dot_flv" self) (getAttr "net_dot_didierverna_dot_focus_dot_setup" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_focus_dot_core = (build-asdf-system { - pname = "net.didierverna.focus.core"; - version = "20170403-git"; - asds = [ "net.didierverna.focus.core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/focus/2017-04-03/focus-20170403-git.tgz"; - sha256 = "0b7nxqlkfi7irdmhsbp15r63c8fcg8q0ahmwmq5cmkf8ffq8dspc"; - system = "net.didierverna.focus.core"; - asd = "net.didierverna.focus.core"; - }); - systems = [ "net.didierverna.focus.core" ]; - lispLibs = [ (getAttr "net_dot_didierverna_dot_focus_dot_setup" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_focus_dot_demos_dot_quotation = (build-asdf-system { - pname = "net.didierverna.focus.demos.quotation"; - version = "20170403-git"; - asds = [ "net.didierverna.focus.demos.quotation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/focus/2017-04-03/focus-20170403-git.tgz"; - sha256 = "0b7nxqlkfi7irdmhsbp15r63c8fcg8q0ahmwmq5cmkf8ffq8dspc"; - system = "net.didierverna.focus.demos.quotation"; - asd = "net.didierverna.focus.demos.quotation"; - }); - systems = [ "net.didierverna.focus.demos.quotation" ]; - lispLibs = [ (getAttr "net_dot_didierverna_dot_focus_dot_flv" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_focus_dot_flv = (build-asdf-system { - pname = "net.didierverna.focus.flv"; - version = "20170403-git"; - asds = [ "net.didierverna.focus.flv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/focus/2017-04-03/focus-20170403-git.tgz"; - sha256 = "0b7nxqlkfi7irdmhsbp15r63c8fcg8q0ahmwmq5cmkf8ffq8dspc"; - system = "net.didierverna.focus.flv"; - asd = "net.didierverna.focus.flv"; - }); - systems = [ "net.didierverna.focus.flv" ]; - lispLibs = [ (getAttr "net_dot_didierverna_dot_asdf-flv" self) (getAttr "net_dot_didierverna_dot_focus_dot_core" self) (getAttr "net_dot_didierverna_dot_focus_dot_setup" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_focus_dot_setup = (build-asdf-system { - pname = "net.didierverna.focus.setup"; - version = "20170403-git"; - asds = [ "net.didierverna.focus.setup" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/focus/2017-04-03/focus-20170403-git.tgz"; - sha256 = "0b7nxqlkfi7irdmhsbp15r63c8fcg8q0ahmwmq5cmkf8ffq8dspc"; - system = "net.didierverna.focus.setup"; - asd = "net.didierverna.focus.setup"; - }); - systems = [ "net.didierverna.focus.setup" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_tfm = (build-asdf-system { - pname = "net.didierverna.tfm"; - version = "20241012-git"; - asds = [ "net.didierverna.tfm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfm/2024-10-12/tfm-20241012-git.tgz"; - sha256 = "15lnp9w9z5ar64bynb365n4wqh8wa7z4m4dzy320xrxnnc1w2sn2"; - system = "net.didierverna.tfm"; - asd = "net.didierverna.tfm"; - }); - systems = [ "net.didierverna.tfm" ]; - lispLibs = [ (getAttr "net_dot_didierverna_dot_tfm_dot_core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_tfm_dot_core = (build-asdf-system { - pname = "net.didierverna.tfm.core"; - version = "20241012-git"; - asds = [ "net.didierverna.tfm.core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfm/2024-10-12/tfm-20241012-git.tgz"; - sha256 = "15lnp9w9z5ar64bynb365n4wqh8wa7z4m4dzy320xrxnnc1w2sn2"; - system = "net.didierverna.tfm.core"; - asd = "net.didierverna.tfm.core"; - }); - systems = [ "net.didierverna.tfm.core" ]; - lispLibs = [ (getAttr "net_dot_didierverna_dot_tfm_dot_setup" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_didierverna_dot_tfm_dot_setup = (build-asdf-system { - pname = "net.didierverna.tfm.setup"; - version = "20241012-git"; - asds = [ "net.didierverna.tfm.setup" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfm/2024-10-12/tfm-20241012-git.tgz"; - sha256 = "15lnp9w9z5ar64bynb365n4wqh8wa7z4m4dzy320xrxnnc1w2sn2"; - system = "net.didierverna.tfm.setup"; - asd = "net.didierverna.tfm.setup"; - }); - systems = [ "net.didierverna.tfm.setup" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - net_dot_scipolis_dot_graphs = (build-asdf-system { - pname = "net.scipolis.graphs"; - version = "20210411-git"; - asds = [ "net.scipolis.graphs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; - sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; - system = "net.scipolis.graphs"; - asd = "net.scipolis.graphs"; - }); - systems = [ "net.scipolis.graphs" ]; - lispLibs = [ (getAttr "femlisp-basic" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - network-addresses = (build-asdf-system { - pname = "network-addresses"; - version = "20160628-git"; - asds = [ "network-addresses" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/network-addresses/2016-06-28/network-addresses-20160628-git.tgz"; - sha256 = "0zkyfdvfy9pz08vrgz40qpnqx0y7vf92aarp9dq2wipimnwy8df2"; - system = "network-addresses"; - asd = "network-addresses"; - }); - systems = [ "network-addresses" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - network-addresses-test = (build-asdf-system { - pname = "network-addresses-test"; - version = "20160628-git"; - asds = [ "network-addresses-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/network-addresses/2016-06-28/network-addresses-20160628-git.tgz"; - sha256 = "0zkyfdvfy9pz08vrgz40qpnqx0y7vf92aarp9dq2wipimnwy8df2"; - system = "network-addresses-test"; - asd = "network-addresses-test"; - }); - systems = [ "network-addresses-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "network-addresses" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - neural-classifier = (build-asdf-system { - pname = "neural-classifier"; - version = "20241012-git"; - asds = [ "neural-classifier" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/neural-classifier/2024-10-12/neural-classifier-20241012-git.tgz"; - sha256 = "0aq7m781c27di7lfs1a7di55f31i7x490yfd2033738biqn0x019"; - system = "neural-classifier"; - asd = "neural-classifier"; - }); - systems = [ "neural-classifier" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "magicl" self) (getAttr "serapeum" self) (getAttr "snakes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - new-op = (build-asdf-system { - pname = "new-op"; - version = "20241012-git"; - asds = [ "new-op" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/new-op/2024-10-12/new-op-20241012-git.tgz"; - sha256 = "1jrnn4xbx5gc1202hqpinh0q1gm2wcv28jr8fl6g7wm6170nscxh"; - system = "new-op"; - asd = "new-op"; - }); - systems = [ "new-op" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nibbles = (build-asdf-system { - pname = "nibbles"; - version = "20241012-git"; - asds = [ "nibbles" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nibbles/2024-10-12/nibbles-20241012-git.tgz"; - sha256 = "00j464l3l1rx2x9gzx45gz7wcpplk1wmfh5liigzlxqq0ybjc7lr"; - system = "nibbles"; - asd = "nibbles"; - }); - systems = [ "nibbles" ]; - lispLibs = [ ]; - meta = {}; - }); - nibbles-streams = (build-asdf-system { - pname = "nibbles-streams"; - version = "20241012-git"; - asds = [ "nibbles-streams" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nibbles-streams/2024-10-12/nibbles-streams-20241012-git.tgz"; - sha256 = "1m1i9nivpahk11rzdwy3xxdcdwmkx3xzb4kqcz3gh3prwhyg83a1"; - system = "nibbles-streams"; - asd = "nibbles-streams"; - }); - systems = [ "nibbles-streams" ]; - lispLibs = [ (getAttr "nibbles" self) (getAttr "serapeum" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nineveh = (build-asdf-system { - pname = "nineveh"; - version = "release-quicklisp-0a10a846-git"; - asds = [ "nineveh" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nineveh/2019-10-07/nineveh-release-quicklisp-0a10a846-git.tgz"; - sha256 = "0bpdgqc9iz37240ypirpi489pnqpb92i94snyhjbh87i50y4br2l"; - system = "nineveh"; - asd = "nineveh"; - }); - systems = [ "nineveh" ]; - lispLibs = [ (getAttr "cepl" self) (getAttr "cl-soil" self) (getAttr "dendrite_dot_primitives" self) (getAttr "documentation-utils" self) (getAttr "easing" self) (getAttr "livesupport" self) (getAttr "rtg-math_dot_vari" self) (getAttr "with-setf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ningle = (build-asdf-system { - pname = "ningle"; - version = "20241012-git"; - asds = [ "ningle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ningle/2024-10-12/ningle-20241012-git.tgz"; - sha256 = "1ym6phipbg94q7344ng9yf02ykh0x5ldx8nfrbsh8p15qajsw7hc"; - system = "ningle"; - asd = "ningle"; - }); - systems = [ "ningle" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "lack-component" self) (getAttr "lack-request" self) (getAttr "lack-response" self) (getAttr "myway" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ningle-test = (build-asdf-system { - pname = "ningle-test"; - version = "20241012-git"; - asds = [ "ningle-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ningle/2024-10-12/ningle-20241012-git.tgz"; - sha256 = "1ym6phipbg94q7344ng9yf02ykh0x5ldx8nfrbsh8p15qajsw7hc"; - system = "ningle-test"; - asd = "ningle-test"; - }); - systems = [ "ningle-test" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "lack-component" self) (getAttr "lack-test" self) (getAttr "ningle" self) (getAttr "prove" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nlopt = (build-asdf-system { - pname = "nlopt"; - version = "20220707-git"; - asds = [ "nlopt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nlopt/2022-07-07/nlopt-20220707-git.tgz"; - sha256 = "01zw4yx38kc8x3by0m3dw5j87hwb180ggp4njfnzi1qjq1fdczp5"; - system = "nlopt"; - asd = "nlopt"; - }); - systems = [ "nlopt" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nodgui = (build-asdf-system { - pname = "nodgui"; - version = "20241012-git"; - asds = [ "nodgui" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nodgui/2024-10-12/nodgui-20241012-git.tgz"; - sha256 = "088dkpqsxc4dmfsbz24wrgi192xrn8116p4zpklwfqa0fblmfzpb"; - system = "nodgui"; - asd = "nodgui"; - }); - systems = [ "nodgui" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-colors2" self) (getAttr "cl-opengl" self) (getAttr "cl-ppcre-unicode" self) (getAttr "cl-unicode" self) (getAttr "esrap" self) (getAttr "flexi-streams" self) (getAttr "jpeg-turbo" self) (getAttr "named-readtables" self) (getAttr "parse-number" self) (getAttr "pngload" self) (getAttr "sdl2" self) (getAttr "sdl2-ttf" self) (getAttr "static-vectors" self) (getAttr "trivial-garbage" self) (getAttr "zpng" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nodgui-lite = (build-asdf-system { - pname = "nodgui-lite"; - version = "20241012-git"; - asds = [ "nodgui-lite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nodgui/2024-10-12/nodgui-20241012-git.tgz"; - sha256 = "088dkpqsxc4dmfsbz24wrgi192xrn8116p4zpklwfqa0fblmfzpb"; - system = "nodgui-lite"; - asd = "nodgui-lite"; - }); - systems = [ "nodgui-lite" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-colors2" self) (getAttr "cl-ppcre-unicode" self) (getAttr "cl-unicode" self) (getAttr "esrap" self) (getAttr "flexi-streams" self) (getAttr "named-readtables" self) (getAttr "parse-number" self) (getAttr "pngload" self) (getAttr "static-vectors" self) (getAttr "trivial-garbage" self) (getAttr "zpng" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - noisy = (build-asdf-system { - pname = "noisy"; - version = "20241012-git"; - asds = [ "noisy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/noisy/2024-10-12/noisy-20241012-git.tgz"; - sha256 = "0qr29rxbrrlgd3k7hb6c62yzgflaygvxabq2sbhs90r0bi3cs0dj"; - system = "noisy"; - asd = "noisy"; - }); - systems = [ "noisy" ]; - lispLibs = [ (getAttr "random-state" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nontrivial-gray-streams = (build-asdf-system { - pname = "nontrivial-gray-streams"; - version = "20241012-git"; - asds = [ "nontrivial-gray-streams" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nontrivial-gray-streams/2024-10-12/nontrivial-gray-streams-20241012-git.tgz"; - sha256 = "0v49nqsc5jbrg499qhk550zg4v5arjh9nch33n5g4f5bfgw7lzh3"; - system = "nontrivial-gray-streams"; - asd = "nontrivial-gray-streams"; - }); - systems = [ "nontrivial-gray-streams" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - north = (build-asdf-system { - pname = "north"; - version = "20241012-git"; - asds = [ "north" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/north/2024-10-12/north-20241012-git.tgz"; - sha256 = "0ml49xixdr1aagj580dr0dzx7dvdqrf45yyh3pzdzbp0pzqbpjz2"; - system = "north"; - asd = "north"; - }); - systems = [ "north" ]; - lispLibs = [ (getAttr "north-drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - north-core = (build-asdf-system { - pname = "north-core"; - version = "20241012-git"; - asds = [ "north-core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/north/2024-10-12/north-20241012-git.tgz"; - sha256 = "0ml49xixdr1aagj580dr0dzx7dvdqrf45yyh3pzdzbp0pzqbpjz2"; - system = "north-core"; - asd = "north-core"; - }); - systems = [ "north-core" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "crypto-shortcuts" self) (getAttr "documentation-utils" self) (getAttr "uuid" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - north-dexador = (build-asdf-system { - pname = "north-dexador"; - version = "20241012-git"; - asds = [ "north-dexador" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/north/2024-10-12/north-20241012-git.tgz"; - sha256 = "0ml49xixdr1aagj580dr0dzx7dvdqrf45yyh3pzdzbp0pzqbpjz2"; - system = "north-dexador"; - asd = "north-dexador"; - }); - systems = [ "north-dexador" ]; - lispLibs = [ (getAttr "dexador" self) (getAttr "north-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - north-drakma = (build-asdf-system { - pname = "north-drakma"; - version = "20241012-git"; - asds = [ "north-drakma" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/north/2024-10-12/north-20241012-git.tgz"; - sha256 = "0ml49xixdr1aagj580dr0dzx7dvdqrf45yyh3pzdzbp0pzqbpjz2"; - system = "north-drakma"; - asd = "north-drakma"; - }); - systems = [ "north-drakma" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "north-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - north-example = (build-asdf-system { - pname = "north-example"; - version = "20241012-git"; - asds = [ "north-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/north/2024-10-12/north-20241012-git.tgz"; - sha256 = "0ml49xixdr1aagj580dr0dzx7dvdqrf45yyh3pzdzbp0pzqbpjz2"; - system = "north-example"; - asd = "north-example"; - }); - systems = [ "north-example" ]; - lispLibs = [ (getAttr "clip" self) (getAttr "drakma" self) (getAttr "hunchentoot" self) (getAttr "north" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nsb-cga = (build-asdf-system { - pname = "nsb-cga"; - version = "20200427-git"; - asds = [ "nsb-cga" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "nsb-cga"; - asd = "nsb-cga"; - }); - systems = [ "nsb-cga" ]; - lispLibs = [ (getAttr "cl-reexport" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nsort = (build-asdf-system { - pname = "nsort"; - version = "20150505-git"; - asds = [ "nsort" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nsort/2015-05-05/nsort-20150505-git.tgz"; - sha256 = "1q58slg8pl390av8pv16xb8g9qibgy3pm6vyl1fw75mx37yqkyd3"; - system = "nsort"; - asd = "nsort"; - }); - systems = [ "nsort" ]; - lispLibs = [ (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nst = (build-asdf-system { - pname = "nst"; - version = "20210807-git"; - asds = [ "nst" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; - sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; - system = "nst"; - asd = "nst"; - }); - systems = [ "nst" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "org-sampler" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nst-manual-tests = (build-asdf-system { - pname = "nst-manual-tests"; - version = "20210807-git"; - asds = [ "nst-manual-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; - sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; - system = "nst-manual-tests"; - asd = "nst-manual-tests"; - }); - systems = [ "nst-manual-tests" ]; - lispLibs = [ (getAttr "asdf-nst" self) (getAttr "nst" self) (getAttr "nst-selftest-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nst-meta-tests = (build-asdf-system { - pname = "nst-meta-tests"; - version = "20210807-git"; - asds = [ "nst-meta-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; - sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; - system = "nst-meta-tests"; - asd = "nst-meta-tests"; - }); - systems = [ "nst-meta-tests" ]; - lispLibs = [ (getAttr "asdf-nst" self) (getAttr "nst" self) (getAttr "nst-selftest-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nst-mop-utils = (build-asdf-system { - pname = "nst-mop-utils"; - version = "20210807-git"; - asds = [ "nst-mop-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; - sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; - system = "nst-mop-utils"; - asd = "nst-mop-utils"; - }); - systems = [ "nst-mop-utils" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "nst" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nst-selftest-utils = (build-asdf-system { - pname = "nst-selftest-utils"; - version = "20210807-git"; - asds = [ "nst-selftest-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; - sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; - system = "nst-selftest-utils"; - asd = "nst-selftest-utils"; - }); - systems = [ "nst-selftest-utils" ]; - lispLibs = [ (getAttr "nst" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nst-simple-tests = (build-asdf-system { - pname = "nst-simple-tests"; - version = "20210807-git"; - asds = [ "nst-simple-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; - sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; - system = "nst-simple-tests"; - asd = "nst-simple-tests"; - }); - systems = [ "nst-simple-tests" ]; - lispLibs = [ (getAttr "asdf-nst" self) (getAttr "nst" self) (getAttr "nst-selftest-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nst-test = (build-asdf-system { - pname = "nst-test"; - version = "20210807-git"; - asds = [ "nst-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; - sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; - system = "nst-test"; - asd = "nst-test"; - }); - systems = [ "nst-test" ]; - lispLibs = [ (getAttr "asdf-nst" self) (getAttr "nst" self) (getAttr "nst-meta-tests" self) (getAttr "nst-simple-tests" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nst-test-jenkins = (build-asdf-system { - pname = "nst-test-jenkins"; - version = "20210807-git"; - asds = [ "nst-test-jenkins" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; - sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; - system = "nst-test-jenkins"; - asd = "nst-test-jenkins"; - }); - systems = [ "nst-test-jenkins" ]; - lispLibs = [ (getAttr "asdf-nst" self) (getAttr "nst" self) (getAttr "nst-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nuclblog = (build-asdf-system { - pname = "nuclblog"; - version = "20140826-git"; - asds = [ "nuclblog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nuclblog/2014-08-26/nuclblog-20140826-git.tgz"; - sha256 = "03ngrxas65l7h9ykyy100arm0imvnrxxyyf809l8iqqv87b3k1hz"; - system = "nuclblog"; - asd = "nuclblog"; - }); - systems = [ "nuclblog" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-markdown" self) (getAttr "cl-store" self) (getAttr "cl-who" self) (getAttr "hunchentoot" self) (getAttr "hunchentoot-auth" self) (getAttr "md5" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nuklear-blob = (build-asdf-system { - pname = "nuklear-blob"; - version = "stable-git"; - asds = [ "nuklear-blob" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nuklear-blob/2020-10-16/nuklear-blob-stable-git.tgz"; - sha256 = "1qqx08sd74ix027p6w35yr0ycp72swy1zzps015hwkiwxsawkncm"; - system = "nuklear-blob"; - asd = "nuklear-blob"; - }); - systems = [ "nuklear-blob" ]; - lispLibs = [ (getAttr "bodge-blobs-support" self) (getAttr "glad-blob" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nuklear-renderer-blob = (build-asdf-system { - pname = "nuklear-renderer-blob"; - version = "stable-git"; - asds = [ "nuklear-renderer-blob" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nuklear-renderer-blob/2020-10-16/nuklear-renderer-blob-stable-git.tgz"; - sha256 = "0f73ns9dq02v7ixpbnvrfgp52cjdvmbbbhhfwjyv0ywxx30mrdq4"; - system = "nuklear-renderer-blob"; - asd = "nuklear-renderer-blob"; - }); - systems = [ "nuklear-renderer-blob" ]; - lispLibs = [ (getAttr "bodge-blobs-support" self) (getAttr "glad-blob" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - null-package = (build-asdf-system { - pname = "null-package"; - version = "20220707-git"; - asds = [ "null-package" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/null-package/2022-07-07/null-package-20220707-git.tgz"; - sha256 = "1ildain46gw0nfnxdwfvasr5vg1fs93afni3k65sl5imc82g910f"; - system = "null-package"; - asd = "null-package"; - }); - systems = [ "null-package" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "core-reader" self) (getAttr "named-readtables" self) (getAttr "read-as-string" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - null-package_dot_test = (build-asdf-system { - pname = "null-package.test"; - version = "20220707-git"; - asds = [ "null-package.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/null-package/2022-07-07/null-package-20220707-git.tgz"; - sha256 = "1ildain46gw0nfnxdwfvasr5vg1fs93afni3k65sl5imc82g910f"; - system = "null-package.test"; - asd = "null-package.test"; - }); - systems = [ "null-package.test" ]; - lispLibs = [ (getAttr "bnf" self) (getAttr "jingoh" self) (getAttr "null-package" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - num-utils = (build-asdf-system { - pname = "num-utils"; - version = "20241012-git"; - asds = [ "num-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/numerical-utilities/2024-10-12/numerical-utilities-20241012-git.tgz"; - sha256 = "00ck2bj4pqir2aan26xhirk41wzrfaziqmnngabhmwi0hz81bjs6"; - system = "num-utils"; - asd = "num-utils"; - }); - systems = [ "num-utils" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "alexandria_plus" self) (getAttr "anaphora" self) (getAttr "array-operations" self) (getAttr "let-plus" self) (getAttr "select" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - numcl = (build-asdf-system { - pname = "numcl"; - version = "20221106-git"; - asds = [ "numcl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/numcl/2022-11-06/numcl-20221106-git.tgz"; - sha256 = "1x0j4vx5w3rn18pssfwys3ghfxr2lkkrv37y47144kr890jrcad9"; - system = "numcl"; - asd = "numcl"; - }); - systems = [ "numcl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-randist" self) (getAttr "constantfold" self) (getAttr "float-features" self) (getAttr "function-cache" self) (getAttr "gtype" self) (getAttr "iterate" self) (getAttr "lisp-namespace" self) (getAttr "specialized-function" self) (getAttr "trivia" self) (getAttr "type-r" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - numcl_dot_test = (build-asdf-system { - pname = "numcl.test"; - version = "20221106-git"; - asds = [ "numcl.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/numcl/2022-11-06/numcl-20221106-git.tgz"; - sha256 = "1x0j4vx5w3rn18pssfwys3ghfxr2lkkrv37y47144kr890jrcad9"; - system = "numcl.test"; - asd = "numcl.test"; - }); - systems = [ "numcl.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "numcl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - numpy-file-format = (build-asdf-system { - pname = "numpy-file-format"; - version = "20231021-git"; - asds = [ "numpy-file-format" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/numpy-file-format/2023-10-21/numpy-file-format-20231021-git.tgz"; - sha256 = "1n0nixc44z1cymm20wif0l2100ydv0h69l6i6xz5bmwcb2zc4gqr"; - system = "numpy-file-format"; - asd = "numpy-file-format"; - }); - systems = [ "numpy-file-format" ]; - lispLibs = [ (getAttr "ieee-floats" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nxt = (build-asdf-system { - pname = "nxt"; - version = "20150608-git"; - asds = [ "nxt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nxt/2015-06-08/cl-nxt-20150608-git.tgz"; - sha256 = "1r9004ra140i9v2pmxnjv86dix4040jr0rgww2zwk370zxys7h2g"; - system = "nxt"; - asd = "nxt"; - }); - systems = [ "nxt" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cffi" self) (getAttr "static-vectors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nxt-proxy = (build-asdf-system { - pname = "nxt-proxy"; - version = "20150608-git"; - asds = [ "nxt-proxy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-nxt/2015-06-08/cl-nxt-20150608-git.tgz"; - sha256 = "1r9004ra140i9v2pmxnjv86dix4040jr0rgww2zwk370zxys7h2g"; - system = "nxt-proxy"; - asd = "nxt-proxy"; - }); - systems = [ "nxt-proxy" ]; - lispLibs = [ (getAttr "nxt" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nyaml = (build-asdf-system { - pname = "nyaml"; - version = "20211230-git"; - asds = [ "nyaml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nyaml/2021-12-30/nyaml-20211230-git.tgz"; - sha256 = "1gdsxhgqx9ynzrxwjidgljlkmz35wx83r6gwslxgg4v0g4vix9da"; - system = "nyaml"; - asd = "nyaml"; - }); - systems = [ "nyaml" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-ppcre" self) (getAttr "esrap" self) (getAttr "fare-quasiquote" self) (getAttr "fare-quasiquote-extras" self) (getAttr "parse-number" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - nytpu_dot_lisp-utils = (build-asdf-system { - pname = "nytpu.lisp-utils"; - version = "20241012-git"; - asds = [ "nytpu.lisp-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/nytpu.lisp-utils/2024-10-12/nytpu.lisp-utils-20241012-git.tgz"; - sha256 = "11mn2xf0nlaqmni0s22n4jbdy8rkqkin1sqni90drd8cs6mccmsd"; - system = "nytpu.lisp-utils"; - asd = "nytpu.lisp-utils"; - }); - systems = [ "nytpu.lisp-utils" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - object-class = (build-asdf-system { - pname = "object-class"; - version = "1.0"; - asds = [ "object-class" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/object-class/2020-09-25/object-class_1.0.tgz"; - sha256 = "0qagmd2mxbr8b60l0y3jccj0maxjchds96p935pd3q805ry50683"; - system = "object-class"; - asd = "object-class"; - }); - systems = [ "object-class" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "compatible-metaclasses" self) (getAttr "enhanced-find-class" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - object-class__tests = (build-asdf-system { - pname = "object-class_tests"; - version = "1.0"; - asds = [ "object-class_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/object-class/2020-09-25/object-class_1.0.tgz"; - sha256 = "0qagmd2mxbr8b60l0y3jccj0maxjchds96p935pd3q805ry50683"; - system = "object-class_tests"; - asd = "object-class_tests"; - }); - systems = [ "object-class_tests" ]; - lispLibs = [ (getAttr "compatible-metaclasses" self) (getAttr "object-class" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - oclcl = (build-asdf-system { - pname = "oclcl"; - version = "20190521-git"; - asds = [ "oclcl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/oclcl/2019-05-21/oclcl-20190521-git.tgz"; - sha256 = "1ccyrv4fknpln5askl8cpnwbp28sikrs6i3dwzm86jwhv272zc8q"; - system = "oclcl"; - asd = "oclcl"; - }); - systems = [ "oclcl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-pattern" self) (getAttr "cl-ppcre" self) (getAttr "cl-reexport" self) (getAttr "external-program" self) (getAttr "lisp-namespace" self) (getAttr "osicat" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - oclcl-examples = (build-asdf-system { - pname = "oclcl-examples"; - version = "20190521-git"; - asds = [ "oclcl-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/oclcl/2019-05-21/oclcl-20190521-git.tgz"; - sha256 = "1ccyrv4fknpln5askl8cpnwbp28sikrs6i3dwzm86jwhv272zc8q"; - system = "oclcl-examples"; - asd = "oclcl-examples"; - }); - systems = [ "oclcl-examples" ]; - lispLibs = [ (getAttr "cl-oclapi" self) (getAttr "imago" self) (getAttr "oclcl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - oclcl-test = (build-asdf-system { - pname = "oclcl-test"; - version = "20190521-git"; - asds = [ "oclcl-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/oclcl/2019-05-21/oclcl-20190521-git.tgz"; - sha256 = "1ccyrv4fknpln5askl8cpnwbp28sikrs6i3dwzm86jwhv272zc8q"; - system = "oclcl-test"; - asd = "oclcl-test"; - }); - systems = [ "oclcl-test" ]; - lispLibs = [ (getAttr "arrow-macros" self) (getAttr "oclcl" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ode-blob = (build-asdf-system { - pname = "ode-blob"; - version = "stable-git"; - asds = [ "ode-blob" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ode-blob/2020-10-16/ode-blob-stable-git.tgz"; - sha256 = "1l2zq27zmivmr6h66kadbh3isnbdmkxvc7wq16wwmsvq23bhpss6"; - system = "ode-blob"; - asd = "ode-blob"; - }); - systems = [ "ode-blob" ]; - lispLibs = [ (getAttr "base-blobs" self) (getAttr "bodge-blobs-support" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - odepack = (build-asdf-system { - pname = "odepack"; - version = "20231021-git"; - asds = [ "odepack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "odepack"; - asd = "odepack"; - }); - systems = [ "odepack" ]; - lispLibs = [ (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - odesk = (build-asdf-system { - pname = "odesk"; - version = "20150608-git"; - asds = [ "odesk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-odesk/2015-06-08/cl-odesk-20150608-git.tgz"; - sha256 = "1j5pjq4aw83m1in0l7ljn7jq4ixckg91p4h0lwf420xks3lhi4ka"; - system = "odesk"; - asd = "odesk"; - }); - systems = [ "odesk" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "iterate" self) (getAttr "md5" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - oe-encode = (build-asdf-system { - pname = "oe-encode"; - version = "20150804-git"; - asds = [ "oe-encode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/oe-encode/2015-08-04/oe-encode-20150804-git.tgz"; - sha256 = "18hd97509vpg04gaf8lzjr2jfyj3w4ql1ydb5202p2r9k4qpvnj9"; - system = "oe-encode"; - asd = "oe-encode"; - }); - systems = [ "oe-encode" ]; - lispLibs = [ (getAttr "babel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - oe-encode-test = (build-asdf-system { - pname = "oe-encode-test"; - version = "20150804-git"; - asds = [ "oe-encode-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/oe-encode/2015-08-04/oe-encode-20150804-git.tgz"; - sha256 = "18hd97509vpg04gaf8lzjr2jfyj3w4ql1ydb5202p2r9k4qpvnj9"; - system = "oe-encode-test"; - asd = "oe-encode"; - }); - systems = [ "oe-encode-test" ]; - lispLibs = [ (getAttr "clunit" self) (getAttr "oe-encode" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - olc = (build-asdf-system { - pname = "olc"; - version = "20220331-git"; - asds = [ "olc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/olc/2022-03-31/olc-20220331-git.tgz"; - sha256 = "02r6w9kfa6v4a12y2azmyjkxbn54r1y18c6a024vq4y6zp20fqnz"; - system = "olc"; - asd = "olc"; - }); - systems = [ "olc" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - omg = (build-asdf-system { - pname = "omg"; - version = "20241012-git"; - asds = [ "omg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/omglib/2024-10-12/omglib-20241012-git.tgz"; - sha256 = "0jp68w3sw9z8gn3498lrmysf93f22a71hsr9c886wix5zpwgqpx7"; - system = "omg"; - asd = "omg"; - }); - systems = [ "omg" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-jpeg" self) (getAttr "cl-parallel" self) (getAttr "clack" self) (getAttr "hunchentoot" self) (getAttr "media-types" self) (getAttr "pngload" self) (getAttr "skippy" self) (getAttr "trivial-utf-8" self) (getAttr "websocket-driver-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - omgdaemon = (build-asdf-system { - pname = "omgdaemon"; - version = "20241012-git"; - asds = [ "omgdaemon" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/omglib/2024-10-12/omglib-20241012-git.tgz"; - sha256 = "0jp68w3sw9z8gn3498lrmysf93f22a71hsr9c886wix5zpwgqpx7"; - system = "omgdaemon"; - asd = "omgdaemon"; - }); - systems = [ "omgdaemon" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "find-port" self) (getAttr "inferior-shell" self) (getAttr "iolib" self) (getAttr "log4cl" self) (getAttr "omg" self) (getAttr "osicat" self) (getAttr "swank" self) (getAttr "trivial-dump-core" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ook = (build-asdf-system { - pname = "ook"; - version = "20241012-git"; - asds = [ "ook" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ook/2024-10-12/ook-20241012-git.tgz"; - sha256 = "0vh6g6a392z77yd4vgj3izajyai7pckr90ij1xns6cf9w505aq8w"; - system = "ook"; - asd = "ook"; - }); - systems = [ "ook" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - oook = (build-asdf-system { - pname = "oook"; - version = "20171130-git"; - asds = [ "oook" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/oook/2017-11-30/oook-20171130-git.tgz"; - sha256 = "0vxw160kbb2b624lc2aqvrx91xnmfhwz8nrzjvmbk5m55q1s4hxr"; - system = "oook"; - asd = "oook"; - }); - systems = [ "oook" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cl-inflector" self) (getAttr "closer-mop" self) (getAttr "clsql" self) (getAttr "jonathan" self) (getAttr "parse-number" self) (getAttr "semantic-spinneret" self) (getAttr "spinneret" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - open-geneva = (build-asdf-system { - pname = "open-geneva"; - version = "20161204-git"; - asds = [ "open-geneva" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; - sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; - system = "open-geneva"; - asd = "open-geneva"; - }); - systems = [ "open-geneva" ]; - lispLibs = [ (getAttr "geneva" self) (getAttr "geneva-cl" self) (getAttr "geneva-html" self) (getAttr "geneva-latex" self) (getAttr "geneva-mk2" self) (getAttr "geneva-plain-text" self) (getAttr "geneva-tex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - open-location-code = (build-asdf-system { - pname = "open-location-code"; - version = "20241012-git"; - asds = [ "open-location-code" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/open-location-code/2024-10-12/open-location-code-20241012-git.tgz"; - sha256 = "17ip3xzqr2jk9br39d58grrjbk6gsh2mq1a9irjg9a5fig0jlyb2"; - system = "open-location-code"; - asd = "open-location-code"; - }); - systems = [ "open-location-code" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - open-vrp = (build-asdf-system { - pname = "open-vrp"; - version = "20140914-git"; - asds = [ "open-vrp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/open-vrp/2014-09-14/open-vrp-20140914-git.tgz"; - sha256 = "04k0kp18gpr4cfpsck7pjizawwswh372df4pvm5v87brm6xdw1fr"; - system = "open-vrp"; - asd = "open-vrp"; - }); - systems = [ "open-vrp" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "fiveam" self) (getAttr "open-vrp-lib" self) (getAttr "vecto" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - open-vrp-lib = (build-asdf-system { - pname = "open-vrp-lib"; - version = "20140914-git"; - asds = [ "open-vrp-lib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/open-vrp/2014-09-14/open-vrp-20140914-git.tgz"; - sha256 = "04k0kp18gpr4cfpsck7pjizawwswh372df4pvm5v87brm6xdw1fr"; - system = "open-vrp-lib"; - asd = "open-vrp-lib"; - }); - systems = [ "open-vrp-lib" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "fiveam" self) (getAttr "vecto" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - open-with = (build-asdf-system { - pname = "open-with"; - version = "20241012-git"; - asds = [ "open-with" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/open-with/2024-10-12/open-with-20241012-git.tgz"; - sha256 = "0bc0p8nigmfq4axx6qmlxdkm4sb0d2mdi1h7bwmnh0irvmrgdy33"; - system = "open-with"; - asd = "open-with"; - }); - systems = [ "open-with" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openai-openapi-client = (build-asdf-system { - pname = "openai-openapi-client"; - version = "20241012-git"; - asds = [ "openai-openapi-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/openai-openapi-client/2024-10-12/openai-openapi-client-20241012-git.tgz"; - sha256 = "0qyd9i0y75gf92kf8v22n6wmh63791115r7gmg9ca9pl0dgbpmg9"; - system = "openai-openapi-client"; - asd = "openai-openapi-client"; - }); - systems = [ "openai-openapi-client" ]; - lispLibs = [ (getAttr "com_dot_inuoe_dot_jzon" self) (getAttr "dexador" self) (getAttr "openapi-generator" self) (getAttr "quri" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openal-blob = (build-asdf-system { - pname = "openal-blob"; - version = "stable-git"; - asds = [ "openal-blob" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/openal-blob/2020-10-16/openal-blob-stable-git.tgz"; - sha256 = "0bspdqb0xbvwvi6xkn88n4jswpds8fzbgj44ygm7mi6lpwp7lmv2"; - system = "openal-blob"; - asd = "openal-blob"; - }); - systems = [ "openal-blob" ]; - lispLibs = [ (getAttr "base-blobs" self) (getAttr "bodge-blobs-support" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openapi-generator = (build-asdf-system { - pname = "openapi-generator"; - version = "20241012-git"; - asds = [ "openapi-generator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/openapi-generator/2024-10-12/openapi-generator-20241012-git.tgz"; - sha256 = "0zc0y8frcnsqj76sqmqsgfv0zhdz5kkpynwan3sigc78fl1nrs3q"; - system = "openapi-generator"; - asd = "openapi-generator"; - }); - systems = [ "openapi-generator" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-hash-util" self) (getAttr "cl-json-pointer" self) (getAttr "cl-project" self) (getAttr "cl-semver" self) (getAttr "cl-yaml" self) (getAttr "com_dot_inuoe_dot_jzon" self) (getAttr "dexador" self) (getAttr "json-mop" self) (getAttr "listopia" self) (getAttr "moptilities" self) (getAttr "parse-float" self) (getAttr "pathname-utils" self) (getAttr "quri" self) (getAttr "serapeum" self) (getAttr "str" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openapi-parser = (build-asdf-system { - pname = "openapi-parser"; - version = "20230618-git"; - asds = [ "openapi-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-openapi-parser/2023-06-18/cl-openapi-parser-20230618-git.tgz"; - sha256 = "1vjqmxgkd8zvsfa1m6jzp6adwv1hz79z1x662v0f567iar01rzyz"; - system = "openapi-parser"; - asd = "openapi-parser"; - }); - systems = [ "openapi-parser" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-change-case" self) (getAttr "cl-package-locks" self) (getAttr "cl-yaml" self) (getAttr "closer-mop" self) (getAttr "esrap" self) (getAttr "str" self) (getAttr "trivia" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openapi-parser-tests = (build-asdf-system { - pname = "openapi-parser-tests"; - version = "20230618-git"; - asds = [ "openapi-parser-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-openapi-parser/2023-06-18/cl-openapi-parser-20230618-git.tgz"; - sha256 = "1vjqmxgkd8zvsfa1m6jzp6adwv1hz79z1x662v0f567iar01rzyz"; - system = "openapi-parser-tests"; - asd = "openapi-parser"; - }); - systems = [ "openapi-parser-tests" ]; - lispLibs = [ (getAttr "openapi-parser" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openid-key = (build-asdf-system { - pname = "openid-key"; - version = "20181210-git"; - asds = [ "openid-key" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/openid-key/2018-12-10/openid-key-20181210-git.tgz"; - sha256 = "0ja1g4f8nrcn965376j7lnhha9krx4wjqxrg6vc57k7rmkhkzm1z"; - system = "openid-key"; - asd = "openid-key"; - }); - systems = [ "openid-key" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "dexador" self) (getAttr "ironclad" self) (getAttr "jonathan" self) (getAttr "local-time" self) (getAttr "quri" self) (getAttr "trivial-rfc-1123" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openid-key-test = (build-asdf-system { - pname = "openid-key-test"; - version = "20181210-git"; - asds = [ "openid-key-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/openid-key/2018-12-10/openid-key-20181210-git.tgz"; - sha256 = "0ja1g4f8nrcn965376j7lnhha9krx4wjqxrg6vc57k7rmkhkzm1z"; - system = "openid-key-test"; - asd = "openid-key-test"; - }); - systems = [ "openid-key-test" ]; - lispLibs = [ (getAttr "_1am" self) (getAttr "openid-key" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openrpc-ci = (build-asdf-system { - pname = "openrpc-ci"; - version = "20241012-git"; - asds = [ "openrpc-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/openrpc/2024-10-12/openrpc-20241012-git.tgz"; - sha256 = "1s3c5yzfdzvv9wdfjl6lmap7dv5wqz6ywnxl1sbahy1k2xm3fg1s"; - system = "openrpc-ci"; - asd = "openrpc-ci"; - }); - systems = [ "openrpc-ci" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openrpc-client = (build-asdf-system { - pname = "openrpc-client"; - version = "20241012-git"; - asds = [ "openrpc-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/openrpc/2024-10-12/openrpc-20241012-git.tgz"; - sha256 = "1s3c5yzfdzvv9wdfjl6lmap7dv5wqz6ywnxl1sbahy1k2xm3fg1s"; - system = "openrpc-client"; - asd = "openrpc-client"; - }); - systems = [ "openrpc-client" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "dexador" self) (getAttr "jsonrpc" self) (getAttr "kebab" self) (getAttr "log4cl" self) (getAttr "serapeum" self) (getAttr "str" self) (getAttr "usocket" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openrpc-deps = (build-asdf-system { - pname = "openrpc-deps"; - version = "20241012-git"; - asds = [ "openrpc-deps" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/openrpc/2024-10-12/openrpc-20241012-git.tgz"; - sha256 = "1s3c5yzfdzvv9wdfjl6lmap7dv5wqz6ywnxl1sbahy1k2xm3fg1s"; - system = "openrpc-deps"; - asd = "openrpc-deps"; - }); - systems = [ "openrpc-deps" ]; - lispLibs = [ (getAttr "jsonrpc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openrpc-docs = (build-asdf-system { - pname = "openrpc-docs"; - version = "20241012-git"; - asds = [ "openrpc-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/openrpc/2024-10-12/openrpc-20241012-git.tgz"; - sha256 = "1s3c5yzfdzvv9wdfjl6lmap7dv5wqz6ywnxl1sbahy1k2xm3fg1s"; - system = "openrpc-docs"; - asd = "openrpc-docs"; - }); - systems = [ "openrpc-docs" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "_40ants-doc" self) (getAttr "docs-config" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openrpc-example = (build-asdf-system { - pname = "openrpc-example"; - version = "20241012-git"; - asds = [ "openrpc-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/openrpc/2024-10-12/openrpc-20241012-git.tgz"; - sha256 = "1s3c5yzfdzvv9wdfjl6lmap7dv5wqz6ywnxl1sbahy1k2xm3fg1s"; - system = "openrpc-example"; - asd = "openrpc-example"; - }); - systems = [ "openrpc-example" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "alexandria" self) (getAttr "clack" self) (getAttr "clack-handler-hunchentoot" self) (getAttr "jsonrpc" self) (getAttr "openrpc-client" self) (getAttr "openrpc-server" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - openrpc-server = (build-asdf-system { - pname = "openrpc-server"; - version = "20241012-git"; - asds = [ "openrpc-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/openrpc/2024-10-12/openrpc-20241012-git.tgz"; - sha256 = "1s3c5yzfdzvv9wdfjl6lmap7dv5wqz6ywnxl1sbahy1k2xm3fg1s"; - system = "openrpc-server"; - asd = "openrpc-server"; - }); - systems = [ "openrpc-server" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "alexandria" self) (getAttr "clack-cors" self) (getAttr "clack-prometheus" self) (getAttr "closer-mop" self) (getAttr "jsonrpc" self) (getAttr "lack-request" self) (getAttr "lambda-fiddle" self) (getAttr "local-time" self) (getAttr "log4cl" self) (getAttr "log4cl-extras" self) (getAttr "serapeum" self) (getAttr "str" self) (getAttr "websocket-driver" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ops-test = (build-asdf-system { - pname = "ops-test"; - version = "20211020-git"; - asds = [ "ops-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-png/2021-10-20/cl-png-20211020-git.tgz"; - sha256 = "17xcb9ps5vf3if61blmx7cpfrz3gsw7jk8d5zv3f4cq8jrriqdx4"; - system = "ops-test"; - asd = "ops-test"; - }); - systems = [ "ops-test" ]; - lispLibs = [ (getAttr "png" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ops5 = (build-asdf-system { - pname = "ops5"; - version = "20200218-git"; - asds = [ "ops5" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ops5/2020-02-18/ops5-20200218-git.tgz"; - sha256 = "1q2mrza40qvhny06f4ks2dghyk8a7pjjsi3vj83b9if7fmyj152a"; - system = "ops5"; - asd = "ops5"; - }); - systems = [ "ops5" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - opticl = (build-asdf-system { - pname = "opticl"; - version = "20220220-git"; - asds = [ "opticl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/opticl/2022-02-20/opticl-20220220-git.tgz"; - sha256 = "1jx9n78d4lf53iz24yid34l92zrpqxfihv6049ixcy0xigf7j4ac"; - system = "opticl"; - asd = "opticl"; - }); - systems = [ "opticl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-jpeg" self) (getAttr "cl-tga" self) (getAttr "opticl-core" self) (getAttr "pngload" self) (getAttr "retrospectiff" self) (getAttr "skippy" self) (getAttr "zpng" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - opticl-core = (build-asdf-system { - pname = "opticl-core"; - version = "20171019-git"; - asds = [ "opticl-core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/opticl-core/2017-10-19/opticl-core-20171019-git.tgz"; - sha256 = "0458bllabcdjghfrqx6aki49c9qmvfmkk8jl75cfpi7q0i12kh95"; - system = "opticl-core"; - asd = "opticl-core"; - }); - systems = [ "opticl-core" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - opticl-doc = (build-asdf-system { - pname = "opticl-doc"; - version = "20220220-git"; - asds = [ "opticl-doc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/opticl/2022-02-20/opticl-20220220-git.tgz"; - sha256 = "1jx9n78d4lf53iz24yid34l92zrpqxfihv6049ixcy0xigf7j4ac"; - system = "opticl-doc"; - asd = "opticl-doc"; - }); - systems = [ "opticl-doc" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-containers" self) (getAttr "cl-markdown" self) (getAttr "opticl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - optima = (build-asdf-system { - pname = "optima"; - version = "20150709-git"; - asds = [ "optima" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/optima/2015-07-09/optima-20150709-git.tgz"; - sha256 = "1yw4ymq7ms89342kkvb3aqxgv0w38m9kd8ikdqxxzyybnkjhndal"; - system = "optima"; - asd = "optima"; - }); - systems = [ "optima" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) ]; - meta = {}; - }); - optima_dot_ppcre = (build-asdf-system { - pname = "optima.ppcre"; - version = "20150709-git"; - asds = [ "optima.ppcre" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/optima/2015-07-09/optima-20150709-git.tgz"; - sha256 = "1yw4ymq7ms89342kkvb3aqxgv0w38m9kd8ikdqxxzyybnkjhndal"; - system = "optima.ppcre"; - asd = "optima.ppcre"; - }); - systems = [ "optima.ppcre" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "optima" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - optima_dot_test = (build-asdf-system { - pname = "optima.test"; - version = "20150709-git"; - asds = [ "optima.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/optima/2015-07-09/optima-20150709-git.tgz"; - sha256 = "1yw4ymq7ms89342kkvb3aqxgv0w38m9kd8ikdqxxzyybnkjhndal"; - system = "optima.test"; - asd = "optima.test"; - }); - systems = [ "optima.test" ]; - lispLibs = [ (getAttr "eos" self) (getAttr "optima" self) (getAttr "optima_dot_ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - or-cluster = (build-asdf-system { - pname = "or-cluster"; - version = "20170403-git"; - asds = [ "or-cluster" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opsresearch/2017-04-03/cl-opsresearch-20170403-git.tgz"; - sha256 = "1fipw6qjggswzcg8ifwx5qnhnc7mmi53s6h14l0vzj6afa5rdpm7"; - system = "or-cluster"; - asd = "or-cluster"; - }); - systems = [ "or-cluster" ]; - lispLibs = [ (getAttr "cl-opsresearch" self) (getAttr "drakma" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - or-fann = (build-asdf-system { - pname = "or-fann"; - version = "20170403-git"; - asds = [ "or-fann" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opsresearch/2017-04-03/cl-opsresearch-20170403-git.tgz"; - sha256 = "1fipw6qjggswzcg8ifwx5qnhnc7mmi53s6h14l0vzj6afa5rdpm7"; - system = "or-fann"; - asd = "or-fann"; - }); - systems = [ "or-fann" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-opsresearch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - or-glpk = (build-asdf-system { - pname = "or-glpk"; - version = "20170403-git"; - asds = [ "or-glpk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opsresearch/2017-04-03/cl-opsresearch-20170403-git.tgz"; - sha256 = "1fipw6qjggswzcg8ifwx5qnhnc7mmi53s6h14l0vzj6afa5rdpm7"; - system = "or-glpk"; - asd = "or-glpk"; - }); - systems = [ "or-glpk" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-opsresearch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - or-gsl = (build-asdf-system { - pname = "or-gsl"; - version = "20170403-git"; - asds = [ "or-gsl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opsresearch/2017-04-03/cl-opsresearch-20170403-git.tgz"; - sha256 = "1fipw6qjggswzcg8ifwx5qnhnc7mmi53s6h14l0vzj6afa5rdpm7"; - system = "or-gsl"; - asd = "or-gsl"; - }); - systems = [ "or-gsl" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-opsresearch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - or-test = (build-asdf-system { - pname = "or-test"; - version = "20170403-git"; - asds = [ "or-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-opsresearch/2017-04-03/cl-opsresearch-20170403-git.tgz"; - sha256 = "1fipw6qjggswzcg8ifwx5qnhnc7mmi53s6h14l0vzj6afa5rdpm7"; - system = "or-test"; - asd = "or-test"; - }); - systems = [ "or-test" ]; - lispLibs = [ (getAttr "cl-opsresearch" self) (getAttr "fiveam" self) (getAttr "or-fann" self) (getAttr "or-glpk" self) (getAttr "or-gsl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org-davep-dict = (build-asdf-system { - pname = "org-davep-dict"; - version = "20190521-git"; - asds = [ "org-davep-dict" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/org-davep-dict/2019-05-21/org-davep-dict-20190521-git.tgz"; - sha256 = "09dryqlprssrw0jpcg2313cc1hmlsasxvp1rs5z7axhasc16kl31"; - system = "org-davep-dict"; - asd = "org-davep-dict"; - }); - systems = [ "org-davep-dict" ]; - lispLibs = [ (getAttr "acl-compat" self) (getAttr "cl-ppcre" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org-davep-dictrepl = (build-asdf-system { - pname = "org-davep-dictrepl"; - version = "20190521-git"; - asds = [ "org-davep-dictrepl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/org-davep-dictrepl/2019-05-21/org-davep-dictrepl-20190521-git.tgz"; - sha256 = "1s461asil8cxsbcpyxsw3g7phdn5c3mwv6wswp86hsxiga5hi327"; - system = "org-davep-dictrepl"; - asd = "org-davep-dictrepl"; - }); - systems = [ "org-davep-dictrepl" ]; - lispLibs = [ (getAttr "org-davep-dict" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org-sampler = (build-asdf-system { - pname = "org-sampler"; - version = "0.2.0"; - asds = [ "org-sampler" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/org-sampler/2016-03-18/org-sampler-0.2.0.tgz"; - sha256 = "1j2i24x9afxp6s5gyqlvy11c0lq9rzhmdj1bf0qpxcaa4znj48c3"; - system = "org-sampler"; - asd = "org-sampler"; - }); - systems = [ "org-sampler" ]; - lispLibs = [ (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_melusina_dot_atelier = (build-asdf-system { - pname = "org.melusina.atelier"; - version = "20241012-git"; - asds = [ "org.melusina.atelier" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-atelier/2024-10-12/cl-atelier-20241012-git.tgz"; - sha256 = "0n8v4f7xq1szxhipmkvg4x5s41vqllcq6hxzcd7r0rbxi9i57pqz"; - system = "org.melusina.atelier"; - asd = "org.melusina.atelier"; - }); - systems = [ "org.melusina.atelier" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "org_dot_melusina_dot_rashell" self) (getAttr "osicat" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_melusina_dot_confidence = (build-asdf-system { - pname = "org.melusina.confidence"; - version = "20241012-git"; - asds = [ "org.melusina.confidence" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-confidence/2024-10-12/cl-confidence-20241012-git.tgz"; - sha256 = "1azvv54zchw88gpzh4dkflz6y0pvf7wq433yc7m90fs3c70wmsjl"; - system = "org.melusina.confidence"; - asd = "org.melusina.confidence"; - }); - systems = [ "org.melusina.confidence" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_melusina_dot_rashell = (build-asdf-system { - pname = "org.melusina.rashell"; - version = "20241012-git"; - asds = [ "org.melusina.rashell" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rashell/2024-10-12/cl-rashell-20241012-git.tgz"; - sha256 = "0fpdyhfc68xy6m0ixfvcnczlmlwasby24k47nc25x73swshlxqwq"; - system = "org.melusina.rashell"; - asd = "org.melusina.rashell"; - }); - systems = [ "org.melusina.rashell" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "parse-float" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_melusina_dot_webmachine = (build-asdf-system { - pname = "org.melusina.webmachine"; - version = "20241012-git"; - asds = [ "org.melusina.webmachine" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-webmachine/2024-10-12/cl-webmachine-20241012-git.tgz"; - sha256 = "0k31fbwsv0zdixzis625dsk9zlz04g4908wzwb8p593dksqa0sr8"; - system = "org.melusina.webmachine"; - asd = "org.melusina.webmachine"; - }); - systems = [ "org.melusina.webmachine" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "hunchentoot" self) (getAttr "parse-number" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_conduit-packages = (build-asdf-system { - pname = "org.tfeb.conduit-packages"; - version = "20241012-git"; - asds = [ "org.tfeb.conduit-packages" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/conduit-packages/2024-10-12/conduit-packages-20241012-git.tgz"; - sha256 = "1x89maglc4cw2c87y23zrsvh8mk22ik1anmps462w3a0j3c1ly12"; - system = "org.tfeb.conduit-packages"; - asd = "org.tfeb.conduit-packages"; - }); - systems = [ "org.tfeb.conduit-packages" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_dsm = (build-asdf-system { - pname = "org.tfeb.dsm"; - version = "20241012-git"; - asds = [ "org.tfeb.dsm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/dsm/2024-10-12/dsm-20241012-git.tgz"; - sha256 = "033swj37bgbzn35fjndxqsk89i17bhsim12j8mciiziykx62c4pw"; - system = "org.tfeb.dsm"; - asd = "org.tfeb.dsm"; - }); - systems = [ "org.tfeb.dsm" ]; - lispLibs = [ (getAttr "org_dot_tfeb_dot_hax_dot_collecting" self) (getAttr "org_dot_tfeb_dot_hax_dot_iterate" self) (getAttr "org_dot_tfeb_dot_hax_dot_simple-loops" self) (getAttr "org_dot_tfeb_dot_hax_dot_spam" self) (getAttr "org_dot_tfeb_dot_hax_dot_utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax = (build-asdf-system { - pname = "org.tfeb.hax"; - version = "20241012-git"; - asds = [ "org.tfeb.hax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax"; - asd = "org.tfeb.hax"; - }); - systems = [ "org.tfeb.hax" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_abstract-classes = (build-asdf-system { - pname = "org.tfeb.hax.abstract-classes"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.abstract-classes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.abstract-classes"; - asd = "org.tfeb.hax.abstract-classes"; - }); - systems = [ "org.tfeb.hax.abstract-classes" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_binding = (build-asdf-system { - pname = "org.tfeb.hax.binding"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.binding" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.binding"; - asd = "org.tfeb.hax.binding"; - }); - systems = [ "org.tfeb.hax.binding" ]; - lispLibs = [ (getAttr "org_dot_tfeb_dot_hax_dot_collecting" self) (getAttr "org_dot_tfeb_dot_hax_dot_iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_collecting = (build-asdf-system { - pname = "org.tfeb.hax.collecting"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.collecting" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.collecting"; - asd = "org.tfeb.hax.collecting"; - }); - systems = [ "org.tfeb.hax.collecting" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_comment-form = (build-asdf-system { - pname = "org.tfeb.hax.comment-form"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.comment-form" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.comment-form"; - asd = "org.tfeb.hax.comment-form"; - }); - systems = [ "org.tfeb.hax.comment-form" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_cs-forms = (build-asdf-system { - pname = "org.tfeb.hax.cs-forms"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.cs-forms" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.cs-forms"; - asd = "org.tfeb.hax.cs-forms"; - }); - systems = [ "org.tfeb.hax.cs-forms" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_define-functions = (build-asdf-system { - pname = "org.tfeb.hax.define-functions"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.define-functions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.define-functions"; - asd = "org.tfeb.hax.define-functions"; - }); - systems = [ "org.tfeb.hax.define-functions" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_dynamic-state = (build-asdf-system { - pname = "org.tfeb.hax.dynamic-state"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.dynamic-state" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.dynamic-state"; - asd = "org.tfeb.hax.dynamic-state"; - }); - systems = [ "org.tfeb.hax.dynamic-state" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_iterate = (build-asdf-system { - pname = "org.tfeb.hax.iterate"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.iterate" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.iterate"; - asd = "org.tfeb.hax.iterate"; - }); - systems = [ "org.tfeb.hax.iterate" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_memoize = (build-asdf-system { - pname = "org.tfeb.hax.memoize"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.memoize" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.memoize"; - asd = "org.tfeb.hax.memoize"; - }); - systems = [ "org.tfeb.hax.memoize" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_metatronic = (build-asdf-system { - pname = "org.tfeb.hax.metatronic"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.metatronic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.metatronic"; - asd = "org.tfeb.hax.metatronic"; - }); - systems = [ "org.tfeb.hax.metatronic" ]; - lispLibs = [ (getAttr "org_dot_tfeb_dot_hax_dot_utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_object-accessors = (build-asdf-system { - pname = "org.tfeb.hax.object-accessors"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.object-accessors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.object-accessors"; - asd = "org.tfeb.hax.object-accessors"; - }); - systems = [ "org.tfeb.hax.object-accessors" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_read-package = (build-asdf-system { - pname = "org.tfeb.hax.read-package"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.read-package" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.read-package"; - asd = "org.tfeb.hax.read-package"; - }); - systems = [ "org.tfeb.hax.read-package" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_simple-loops = (build-asdf-system { - pname = "org.tfeb.hax.simple-loops"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.simple-loops" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.simple-loops"; - asd = "org.tfeb.hax.simple-loops"; - }); - systems = [ "org.tfeb.hax.simple-loops" ]; - lispLibs = [ (getAttr "org_dot_tfeb_dot_hax_dot_collecting" self) (getAttr "org_dot_tfeb_dot_hax_dot_iterate" self) (getAttr "org_dot_tfeb_dot_hax_dot_utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_singleton-classes = (build-asdf-system { - pname = "org.tfeb.hax.singleton-classes"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.singleton-classes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.singleton-classes"; - asd = "org.tfeb.hax.singleton-classes"; - }); - systems = [ "org.tfeb.hax.singleton-classes" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_slog = (build-asdf-system { - pname = "org.tfeb.hax.slog"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.slog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.slog"; - asd = "org.tfeb.hax.slog"; - }); - systems = [ "org.tfeb.hax.slog" ]; - lispLibs = [ (getAttr "org_dot_tfeb_dot_hax_dot_collecting" self) (getAttr "org_dot_tfeb_dot_hax_dot_metatronic" self) (getAttr "org_dot_tfeb_dot_hax_dot_simple-loops" self) (getAttr "org_dot_tfeb_dot_hax_dot_spam" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_spam = (build-asdf-system { - pname = "org.tfeb.hax.spam"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.spam" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.spam"; - asd = "org.tfeb.hax.spam"; - }); - systems = [ "org.tfeb.hax.spam" ]; - lispLibs = [ (getAttr "org_dot_tfeb_dot_hax_dot_simple-loops" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_stringtable = (build-asdf-system { - pname = "org.tfeb.hax.stringtable"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.stringtable" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.stringtable"; - asd = "org.tfeb.hax.stringtable"; - }); - systems = [ "org.tfeb.hax.stringtable" ]; - lispLibs = [ (getAttr "org_dot_tfeb_dot_hax_dot_collecting" self) (getAttr "org_dot_tfeb_dot_hax_dot_iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_trace-macroexpand = (build-asdf-system { - pname = "org.tfeb.hax.trace-macroexpand"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.trace-macroexpand" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.trace-macroexpand"; - asd = "org.tfeb.hax.trace-macroexpand"; - }); - systems = [ "org.tfeb.hax.trace-macroexpand" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_utilities = (build-asdf-system { - pname = "org.tfeb.hax.utilities"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.utilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.utilities"; - asd = "org.tfeb.hax.utilities"; - }); - systems = [ "org.tfeb.hax.utilities" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_hax_dot_wrapping-standard = (build-asdf-system { - pname = "org.tfeb.hax.wrapping-standard"; - version = "20241012-git"; - asds = [ "org.tfeb.hax.wrapping-standard" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; - sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; - system = "org.tfeb.hax.wrapping-standard"; - asd = "org.tfeb.hax.wrapping-standard"; - }); - systems = [ "org.tfeb.hax.wrapping-standard" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_tools = (build-asdf-system { - pname = "org.tfeb.tools"; - version = "20231021-git"; - asds = [ "org.tfeb.tools" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; - sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; - system = "org.tfeb.tools"; - asd = "org.tfeb.tools"; - }); - systems = [ "org.tfeb.tools" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_tools_dot_asdf-module-sysdcls = (build-asdf-system { - pname = "org.tfeb.tools.asdf-module-sysdcls"; - version = "20231021-git"; - asds = [ "org.tfeb.tools.asdf-module-sysdcls" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; - sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; - system = "org.tfeb.tools.asdf-module-sysdcls"; - asd = "org.tfeb.tools.asdf-module-sysdcls"; - }); - systems = [ "org.tfeb.tools.asdf-module-sysdcls" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_tools_dot_build-modules = (build-asdf-system { - pname = "org.tfeb.tools.build-modules"; - version = "20231021-git"; - asds = [ "org.tfeb.tools.build-modules" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; - sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; - system = "org.tfeb.tools.build-modules"; - asd = "org.tfeb.tools.build-modules"; - }); - systems = [ "org.tfeb.tools.build-modules" ]; - lispLibs = [ (getAttr "org_dot_tfeb_dot_tools_dot_require-module" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_tools_dot_deprecations = (build-asdf-system { - pname = "org.tfeb.tools.deprecations"; - version = "20231021-git"; - asds = [ "org.tfeb.tools.deprecations" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; - sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; - system = "org.tfeb.tools.deprecations"; - asd = "org.tfeb.tools.deprecations"; - }); - systems = [ "org.tfeb.tools.deprecations" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_tools_dot_feature-expressions = (build-asdf-system { - pname = "org.tfeb.tools.feature-expressions"; - version = "20231021-git"; - asds = [ "org.tfeb.tools.feature-expressions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; - sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; - system = "org.tfeb.tools.feature-expressions"; - asd = "org.tfeb.tools.feature-expressions"; - }); - systems = [ "org.tfeb.tools.feature-expressions" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_tools_dot_install-providers = (build-asdf-system { - pname = "org.tfeb.tools.install-providers"; - version = "20231021-git"; - asds = [ "org.tfeb.tools.install-providers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; - sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; - system = "org.tfeb.tools.install-providers"; - asd = "org.tfeb.tools.install-providers"; - }); - systems = [ "org.tfeb.tools.install-providers" ]; - lispLibs = [ (getAttr "org_dot_tfeb_dot_tools_dot_require-module" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - org_dot_tfeb_dot_tools_dot_require-module = (build-asdf-system { - pname = "org.tfeb.tools.require-module"; - version = "20231021-git"; - asds = [ "org.tfeb.tools.require-module" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; - sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; - system = "org.tfeb.tools.require-module"; - asd = "org.tfeb.tools.require-module"; - }); - systems = [ "org.tfeb.tools.require-module" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - origin = (build-asdf-system { - pname = "origin"; - version = "20220707-git"; - asds = [ "origin" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/origin/2022-07-07/origin-20220707-git.tgz"; - sha256 = "01b5rn83w85fnd92x5jgan2a092y7ir420r55p2b0a98xpvb4a71"; - system = "origin"; - asd = "origin"; - }); - systems = [ "origin" ]; - lispLibs = [ (getAttr "mfiano-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - origin_dot_test = (build-asdf-system { - pname = "origin.test"; - version = "20220707-git"; - asds = [ "origin.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/origin/2022-07-07/origin-20220707-git.tgz"; - sha256 = "01b5rn83w85fnd92x5jgan2a092y7ir420r55p2b0a98xpvb4a71"; - system = "origin.test"; - asd = "origin.test"; - }); - systems = [ "origin.test" ]; - lispLibs = [ (getAttr "origin" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - orizuru-orm = (build-asdf-system { - pname = "orizuru-orm"; - version = "20241012-git"; - asds = [ "orizuru-orm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/orizuru-orm/2024-10-12/orizuru-orm-20241012-git.tgz"; - sha256 = "064sr0nxz884vrh550d8v3v9pqgs65d97lrr3828qn6bgaxwm1va"; - system = "orizuru-orm"; - asd = "orizuru-orm"; - }); - systems = [ "orizuru-orm" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre-unicode" self) (getAttr "clos-fixtures" self) (getAttr "closer-mop" self) (getAttr "clunit2" self) (getAttr "dbi" self) (getAttr "iterate" self) (getAttr "local-time" self) (getAttr "sxql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - osc = (build-asdf-system { - pname = "osc"; - version = "20230618-git"; - asds = [ "osc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/osc/2023-06-18/osc-20230618-git.tgz"; - sha256 = "0gh29zcl9pmy3xlmwzpf9www2z06ah6b4jk06sj2cvxbc15nblqa"; - system = "osc"; - asd = "osc"; - }); - systems = [ "osc" ]; - lispLibs = [ (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - osicat = (build-asdf-system { - pname = "osicat"; - version = "20231021-git"; - asds = [ "osicat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/osicat/2023-10-21/osicat-20231021-git.tgz"; - sha256 = "10q1dfkhrvp5ia860q10y4wdm11fmxf7xv8zl4viz2np9xzf5v22"; - system = "osicat"; - asd = "osicat"; - }); - systems = [ "osicat" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "trivial-features" self) ]; - meta = {}; - }); - ospm = (build-asdf-system { - pname = "ospm"; - version = "20231021-git"; - asds = [ "ospm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ospm/2023-10-21/ospm-20231021-git.tgz"; - sha256 = "1z2wz2xg7rn7p1lladdhj789iz2f3wfjgpi2hjr08vkf1pkp15xf"; - system = "ospm"; - asd = "ospm"; - }); - systems = [ "ospm" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "calispel" self) (getAttr "hu_dot_dwim_dot_defclass-star" self) (getAttr "local-time" self) (getAttr "moptilities" self) (getAttr "named-readtables" self) (getAttr "serapeum" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - overlord = (build-asdf-system { - pname = "overlord"; - version = "20241012-git"; - asds = [ "overlord" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/overlord/2024-10-12/overlord-20241012-git.tgz"; - sha256 = "1afhqx6wdqdah1fpapvr6zxpzkkqmhbrxkqxam523fqjyg4a6941"; - system = "overlord"; - asd = "overlord"; - }); - systems = [ "overlord" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "bit-smasher" self) (getAttr "bordeaux-threads" self) (getAttr "cl-murmurhash" self) (getAttr "cl-ppcre" self) (getAttr "cl-strftime" self) (getAttr "cmd" self) (getAttr "exit-hooks" self) (getAttr "fset" self) (getAttr "global-vars" self) (getAttr "local-time" self) (getAttr "lparallel" self) (getAttr "named-readtables" self) (getAttr "quickproject" self) (getAttr "serapeum" self) (getAttr "trivia" self) (getAttr "trivial-file-size" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - oxenfurt = (build-asdf-system { - pname = "oxenfurt"; - version = "20231021-git"; - asds = [ "oxenfurt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/oxenfurt/2023-10-21/oxenfurt-20231021-git.tgz"; - sha256 = "1yqw21l19091aghvnfpdp62zs8scspaas4syn2yajm1b55jzxvya"; - system = "oxenfurt"; - asd = "oxenfurt"; - }); - systems = [ "oxenfurt" ]; - lispLibs = [ (getAttr "oxenfurt-dexador" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - oxenfurt-core = (build-asdf-system { - pname = "oxenfurt-core"; - version = "20231021-git"; - asds = [ "oxenfurt-core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/oxenfurt/2023-10-21/oxenfurt-20231021-git.tgz"; - sha256 = "1yqw21l19091aghvnfpdp62zs8scspaas4syn2yajm1b55jzxvya"; - system = "oxenfurt-core"; - asd = "oxenfurt-core"; - }); - systems = [ "oxenfurt-core" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "documentation-utils" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - oxenfurt-dexador = (build-asdf-system { - pname = "oxenfurt-dexador"; - version = "20231021-git"; - asds = [ "oxenfurt-dexador" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/oxenfurt/2023-10-21/oxenfurt-20231021-git.tgz"; - sha256 = "1yqw21l19091aghvnfpdp62zs8scspaas4syn2yajm1b55jzxvya"; - system = "oxenfurt-dexador"; - asd = "oxenfurt-dexador"; - }); - systems = [ "oxenfurt-dexador" ]; - lispLibs = [ (getAttr "dexador" self) (getAttr "oxenfurt-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - oxenfurt-drakma = (build-asdf-system { - pname = "oxenfurt-drakma"; - version = "20231021-git"; - asds = [ "oxenfurt-drakma" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/oxenfurt/2023-10-21/oxenfurt-20231021-git.tgz"; - sha256 = "1yqw21l19091aghvnfpdp62zs8scspaas4syn2yajm1b55jzxvya"; - system = "oxenfurt-drakma"; - asd = "oxenfurt-drakma"; - }); - systems = [ "oxenfurt-drakma" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "oxenfurt-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pack = (build-asdf-system { - pname = "pack"; - version = "20110619-git"; - asds = [ "pack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pack/2011-06-19/pack-20110619-git.tgz"; - sha256 = "1b3qi04v1wj9nig0mx591sl4phqcalwdl0vsnf4kqp4d2qx2czi1"; - system = "pack"; - asd = "pack"; - }); - systems = [ "pack" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "ieee-floats" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - package-renaming = (build-asdf-system { - pname = "package-renaming"; - version = "20120407-git"; - asds = [ "package-renaming" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/package-renaming/2012-04-07/package-renaming-20120407-git.tgz"; - sha256 = "15kgd15r9bib8wfnn3hmv42rlifr4ph3rv2mji5i9d5ixhyqqwgq"; - system = "package-renaming"; - asd = "package-renaming"; - }); - systems = [ "package-renaming" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - package-renaming-test = (build-asdf-system { - pname = "package-renaming-test"; - version = "20120407-git"; - asds = [ "package-renaming-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/package-renaming/2012-04-07/package-renaming-20120407-git.tgz"; - sha256 = "15kgd15r9bib8wfnn3hmv42rlifr4ph3rv2mji5i9d5ixhyqqwgq"; - system = "package-renaming-test"; - asd = "package-renaming-test"; - }); - systems = [ "package-renaming-test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_stefil" self) (getAttr "package-renaming" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - packet = (build-asdf-system { - pname = "packet"; - version = "20150302-git"; - asds = [ "packet" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/packet/2015-03-02/packet-20150302-git.tgz"; - sha256 = "1vcmxwrliwczz161nz3ysx9cbfia4cmlqgnjgrx5016lp394pnx1"; - system = "packet"; - asd = "packet"; - }); - systems = [ "packet" ]; - lispLibs = [ (getAttr "ieee-floats" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - packet-crafting = (build-asdf-system { - pname = "packet-crafting"; - version = "20200610-git"; - asds = [ "packet-crafting" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/packet-crafting/2020-06-10/packet-crafting-20200610-git.tgz"; - sha256 = "1ivnvkbqckqf5hm6khffc2wkbjl64fn03w9i0kypkb0mrazxdpdq"; - system = "packet-crafting"; - asd = "packet-crafting"; - }); - systems = [ "packet-crafting" ]; - lispLibs = [ (getAttr "lisp-binary" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - paiprolog = (build-asdf-system { - pname = "paiprolog"; - version = "20180228-git"; - asds = [ "paiprolog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/paiprolog/2018-02-28/paiprolog-20180228-git.tgz"; - sha256 = "1nxz01i6f8s920gm69r2kwjdpq9pli8b2ayqwijhzgjwi0r4jj9r"; - system = "paiprolog"; - asd = "paiprolog"; - }); - systems = [ "paiprolog" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pal = (build-asdf-system { - pname = "pal"; - version = "20150608-git"; - asds = [ "pal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pal/2015-06-08/pal-20150608-git.tgz"; - sha256 = "0kn6jxirrn7wzqymzsi0kx2ivl0nrrcgbl4dm1714s48qw0jwhcw"; - system = "pal"; - asd = "pal"; - }); - systems = [ "pal" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pandocl = (build-asdf-system { - pname = "pandocl"; - version = "20150923-git"; - asds = [ "pandocl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pandocl/2015-09-23/pandocl-20150923-git.tgz"; - sha256 = "1fmlpx5m7ivdkqss1fa3xqbpcwzqrpyyx2nny12aqxn8f13vpvmg"; - system = "pandocl"; - asd = "pandocl"; - }); - systems = [ "pandocl" ]; - lispLibs = [ (getAttr "common-doc" self) (getAttr "common-doc-contrib" self) (getAttr "common-html" self) (getAttr "parenml" self) (getAttr "scriba" self) (getAttr "thorn" self) (getAttr "vertex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pango-markup = (build-asdf-system { - pname = "pango-markup"; - version = "20231021-git"; - asds = [ "pango-markup" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pango-markup/2023-10-21/pango-markup-20231021-git.tgz"; - sha256 = "1165z3ycbkgr9g3ni1z59r258c1jd2viyf3mj8a5p72kx6dqb8gf"; - system = "pango-markup"; - asd = "pango-markup"; - }); - systems = [ "pango-markup" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - papyrus = (build-asdf-system { - pname = "papyrus"; - version = "20241012-git"; - asds = [ "papyrus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/papyrus/2024-10-12/papyrus-20241012-git.tgz"; - sha256 = "0cnhdl2x5vs91srlfjnaznwj5vrg6qlyn2xjbyy40p8yvr5pny88"; - system = "papyrus"; - asd = "papyrus"; - }); - systems = [ "papyrus" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parachute = (build-asdf-system { - pname = "parachute"; - version = "20241012-git"; - asds = [ "parachute" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parachute/2024-10-12/parachute-20241012-git.tgz"; - sha256 = "1hghjrv5d5w9nz27lhwz8vvbdcjl2skm76r8adpzmi7s1f9ww121"; - system = "parachute"; - asd = "parachute"; - }); - systems = [ "parachute" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "form-fiddle" self) (getAttr "trivial-custom-debugger" self) ]; - meta = {}; - }); - parachute-fiveam = (build-asdf-system { - pname = "parachute-fiveam"; - version = "20241012-git"; - asds = [ "parachute-fiveam" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parachute/2024-10-12/parachute-20241012-git.tgz"; - sha256 = "1hghjrv5d5w9nz27lhwz8vvbdcjl2skm76r8adpzmi7s1f9ww121"; - system = "parachute-fiveam"; - asd = "parachute-fiveam"; - }); - systems = [ "parachute-fiveam" ]; - lispLibs = [ (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parachute-lisp-unit = (build-asdf-system { - pname = "parachute-lisp-unit"; - version = "20241012-git"; - asds = [ "parachute-lisp-unit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parachute/2024-10-12/parachute-20241012-git.tgz"; - sha256 = "1hghjrv5d5w9nz27lhwz8vvbdcjl2skm76r8adpzmi7s1f9ww121"; - system = "parachute-lisp-unit"; - asd = "parachute-lisp-unit"; - }); - systems = [ "parachute-lisp-unit" ]; - lispLibs = [ (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parachute-prove = (build-asdf-system { - pname = "parachute-prove"; - version = "20241012-git"; - asds = [ "parachute-prove" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parachute/2024-10-12/parachute-20241012-git.tgz"; - sha256 = "1hghjrv5d5w9nz27lhwz8vvbdcjl2skm76r8adpzmi7s1f9ww121"; - system = "parachute-prove"; - asd = "parachute-prove"; - }); - systems = [ "parachute-prove" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "parachute" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parameterized-function = (build-asdf-system { - pname = "parameterized-function"; - version = "20230618-git"; - asds = [ "parameterized-function" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parameterized-function/2023-06-18/parameterized-function-20230618-git.tgz"; - sha256 = "0pjdk4il83izd4iiavg6z7ighmjfmg39j8gp82qq2kikzlmklxxf"; - system = "parameterized-function"; - asd = "parameterized-function"; - }); - systems = [ "parameterized-function" ]; - lispLibs = [ (getAttr "interface" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - paren-files = (build-asdf-system { - pname = "paren-files"; - version = "20110418-git"; - asds = [ "paren-files" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/paren-files/2011-04-18/paren-files-20110418-git.tgz"; - sha256 = "19lwzvdn9gpn28x6ismkwzs49vr4cbc6drsivkmll3dxb950wgw9"; - system = "paren-files"; - asd = "paren-files"; - }); - systems = [ "paren-files" ]; - lispLibs = [ (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - paren-test = (build-asdf-system { - pname = "paren-test"; - version = "20170830-git"; - asds = [ "paren-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/paren-test/2017-08-30/paren-test-20170830-git.tgz"; - sha256 = "0b2d3kcv3n4b0dm67pzhxx8wxjsgnb32bw2dsprblc7149gaczdr"; - system = "paren-test"; - asd = "paren-test"; - }); - systems = [ "paren-test" ]; - lispLibs = [ (getAttr "paren-files" self) (getAttr "parenscript" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - paren-util = (build-asdf-system { - pname = "paren-util"; - version = "20110418-git"; - asds = [ "paren-util" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/paren-util/2011-04-18/paren-util-20110418-git.tgz"; - sha256 = "0jn7sgndhpn9ndn3xfmsp03alj2qksqz6p1c5h6x8hvi46caqvpy"; - system = "paren-util"; - asd = "paren-util"; - }); - systems = [ "paren-util" ]; - lispLibs = [ (getAttr "paren-files" self) (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - paren6 = (build-asdf-system { - pname = "paren6"; - version = "20220331-git"; - asds = [ "paren6" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/paren6/2022-03-31/paren6-20220331-git.tgz"; - sha256 = "0m7z7zkc1vrwmp68f3yx0mdsb0j45dmw3iddnbvf94dpv8aywwpx"; - system = "paren6"; - asd = "paren6"; - }); - systems = [ "paren6" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parenml = (build-asdf-system { - pname = "parenml"; - version = "20150923-git"; - asds = [ "parenml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parenml/2015-09-23/parenml-20150923-git.tgz"; - sha256 = "0g6s5phinpcfhixgsfqniwxd3kd4bwh78s90ixs2fwk3qjhh9zsb"; - system = "parenml"; - asd = "parenml"; - }); - systems = [ "parenml" ]; - lispLibs = [ (getAttr "common-doc-plump" self) (getAttr "esrap" self) (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parenml-test = (build-asdf-system { - pname = "parenml-test"; - version = "20150923-git"; - asds = [ "parenml-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parenml/2015-09-23/parenml-20150923-git.tgz"; - sha256 = "0g6s5phinpcfhixgsfqniwxd3kd4bwh78s90ixs2fwk3qjhh9zsb"; - system = "parenml-test"; - asd = "parenml-test"; - }); - systems = [ "parenml-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "parenml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parenscript = (build-asdf-system { - pname = "parenscript"; - version = "Parenscript-2.7.1"; - asds = [ "parenscript" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parenscript/2018-12-10/Parenscript-2.7.1.tgz"; - sha256 = "0vg9b9j5psil5iba1d9k6vfxl5rn133qvy750dny20qkp9mf3a13"; - system = "parenscript"; - asd = "parenscript"; - }); - systems = [ "parenscript" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "cl-ppcre" self) (getAttr "named-readtables" self) ]; - meta = {}; - }); - parenscript-classic = (build-asdf-system { - pname = "parenscript-classic"; - version = "20111203-darcs"; - asds = [ "parenscript-classic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parenscript-classic/2011-12-03/parenscript-classic-20111203-darcs.tgz"; - sha256 = "19zsiyjlz938la2dd39cy6lwh95m10j4nx8837xm6qk8rz5f8dgy"; - system = "parenscript-classic"; - asd = "parenscript-classic"; - }); - systems = [ "parenscript-classic" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parenscript_dot_tests = (build-asdf-system { - pname = "parenscript.tests"; - version = "Parenscript-2.7.1"; - asds = [ "parenscript.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parenscript/2018-12-10/Parenscript-2.7.1.tgz"; - sha256 = "0vg9b9j5psil5iba1d9k6vfxl5rn133qvy750dny20qkp9mf3a13"; - system = "parenscript.tests"; - asd = "parenscript.tests"; - }); - systems = [ "parenscript.tests" ]; - lispLibs = [ (getAttr "cl-js" self) (getAttr "fiveam" self) (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parse = (build-asdf-system { - pname = "parse"; - version = "20200925-git"; - asds = [ "parse" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parse/2020-09-25/parse-20200925-git.tgz"; - sha256 = "0l18yabyh7jizm5lgvra0jxi8s1cfwghidi6ix1pyixjkdbjlmvy"; - system = "parse"; - asd = "parse"; - }); - systems = [ "parse" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parse-declarations-1_dot_0 = (build-asdf-system { - pname = "parse-declarations-1.0"; - version = "20101006-darcs"; - asds = [ "parse-declarations-1.0" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parse-declarations/2010-10-06/parse-declarations-20101006-darcs.tgz"; - sha256 = "04l3s180wxq6xyhgd77mbd03a1w1m0j9snag961g2f9dd77w6q1r"; - system = "parse-declarations-1.0"; - asd = "parse-declarations-1.0"; - }); - systems = [ "parse-declarations-1.0" ]; - lispLibs = [ ]; - meta = {}; - }); - parse-float = (build-asdf-system { - pname = "parse-float"; - version = "20200218-git"; - asds = [ "parse-float" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parse-float/2020-02-18/parse-float-20200218-git.tgz"; - sha256 = "0jd2spawc3v8vzqf8ky4cngl45jm65fhkrdf20mf6dcbn3mzpkmr"; - system = "parse-float"; - asd = "parse-float"; - }); - systems = [ "parse-float" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = {}; - }); - parse-float-tests = (build-asdf-system { - pname = "parse-float-tests"; - version = "20200218-git"; - asds = [ "parse-float-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parse-float/2020-02-18/parse-float-20200218-git.tgz"; - sha256 = "0jd2spawc3v8vzqf8ky4cngl45jm65fhkrdf20mf6dcbn3mzpkmr"; - system = "parse-float-tests"; - asd = "parse-float"; - }); - systems = [ "parse-float-tests" ]; - lispLibs = [ (getAttr "lisp-unit" self) (getAttr "parse-float" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parse-front-matter = (build-asdf-system { - pname = "parse-front-matter"; - version = "20160825-git"; - asds = [ "parse-front-matter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parse-front-matter/2016-08-25/parse-front-matter-20160825-git.tgz"; - sha256 = "1yzadrjwycvyzlzb0mixxmwi5bjzkjwylnv3aslnr1j14q44vq58"; - system = "parse-front-matter"; - asd = "parse-front-matter"; - }); - systems = [ "parse-front-matter" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parse-front-matter-test = (build-asdf-system { - pname = "parse-front-matter-test"; - version = "20160825-git"; - asds = [ "parse-front-matter-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parse-front-matter/2016-08-25/parse-front-matter-20160825-git.tgz"; - sha256 = "1yzadrjwycvyzlzb0mixxmwi5bjzkjwylnv3aslnr1j14q44vq58"; - system = "parse-front-matter-test"; - asd = "parse-front-matter-test"; - }); - systems = [ "parse-front-matter-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "parse-front-matter" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parse-js = (build-asdf-system { - pname = "parse-js"; - version = "20160421-git"; - asds = [ "parse-js" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parse-js/2016-04-21/parse-js-20160421-git.tgz"; - sha256 = "1wddrnr5kiya5s3gp4cdq6crbfy9fqcz7fr44p81502sj3bvdv39"; - system = "parse-js"; - asd = "parse-js"; - }); - systems = [ "parse-js" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parse-number = (build-asdf-system { - pname = "parse-number"; - version = "v1.8"; - asds = [ "parse-number" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parse-number/2024-10-12/parse-number-v1.8.tgz"; - sha256 = "1yh54v02i9b55bmkfkz59qd14irw8llasp48drbilkbz1az1qg2p"; - system = "parse-number"; - asd = "parse-number"; - }); - systems = [ "parse-number" ]; - lispLibs = [ ]; - meta = {}; - }); - parse-number-range = (build-asdf-system { - pname = "parse-number-range"; - version = "1.0.1"; - asds = [ "parse-number-range" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parse-number-range/2024-10-12/parse-number-range_1.0.1.tgz"; - sha256 = "1kd0l3bcywhwmnjil0zzvq4cjlhpj2g1wiy7h7860nflzfz7qvds"; - system = "parse-number-range"; - asd = "parse-number-range"; - }); - systems = [ "parse-number-range" ]; - lispLibs = [ (getAttr "cartesian-product-switch" self) (getAttr "enhanced-multiple-value-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parse-number-range__tests = (build-asdf-system { - pname = "parse-number-range_tests"; - version = "1.0.1"; - asds = [ "parse-number-range_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parse-number-range/2024-10-12/parse-number-range_1.0.1.tgz"; - sha256 = "1kd0l3bcywhwmnjil0zzvq4cjlhpj2g1wiy7h7860nflzfz7qvds"; - system = "parse-number-range_tests"; - asd = "parse-number-range_tests"; - }); - systems = [ "parse-number-range_tests" ]; - lispLibs = [ (getAttr "parachute" self) (getAttr "parse-number-range" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parse-rgb = (build-asdf-system { - pname = "parse-rgb"; - version = "20231021-git"; - asds = [ "parse-rgb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tcod/2023-10-21/cl-tcod-20231021-git.tgz"; - sha256 = "1r4ip16dlzr56p94b0grw6nmkykbmgb04jsqdvgl1ypcmbpfr3i1"; - system = "parse-rgb"; - asd = "parse-rgb"; - }); - systems = [ "parse-rgb" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "tcod" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parseltongue = (build-asdf-system { - pname = "parseltongue"; - version = "20130312-git"; - asds = [ "parseltongue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parseltongue/2013-03-12/parseltongue-20130312-git.tgz"; - sha256 = "1cjy7p0snms604zp6x0jlm4v9divqc5r38ns737hffj9q6pi1nlx"; - system = "parseltongue"; - asd = "parseltongue"; - }); - systems = [ "parseltongue" ]; - lispLibs = [ (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parseq = (build-asdf-system { - pname = "parseq"; - version = "20231021-git"; - asds = [ "parseq" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parseq/2023-10-21/parseq-20231021-git.tgz"; - sha256 = "13bdv9slnkf4b3py5dfvdnxvyb7zxwf2apcbr2p3s7ij26qslbbw"; - system = "parseq"; - asd = "parseq"; - }); - systems = [ "parseq" ]; - lispLibs = [ ]; - meta = {}; - }); - parser-combinators = (build-asdf-system { - pname = "parser-combinators"; - version = "20131111-git"; - asds = [ "parser-combinators" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-parser-combinators/2013-11-11/cl-parser-combinators-20131111-git.tgz"; - sha256 = "1k49vha5xm2cklayzpqwg73n4v93xwsbs5in6342pkkiimnidhs8"; - system = "parser-combinators"; - asd = "parser-combinators"; - }); - systems = [ "parser-combinators" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) ]; - meta = {}; - }); - parser-combinators-cl-ppcre = (build-asdf-system { - pname = "parser-combinators-cl-ppcre"; - version = "20131111-git"; - asds = [ "parser-combinators-cl-ppcre" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-parser-combinators/2013-11-11/cl-parser-combinators-20131111-git.tgz"; - sha256 = "1k49vha5xm2cklayzpqwg73n4v93xwsbs5in6342pkkiimnidhs8"; - system = "parser-combinators-cl-ppcre"; - asd = "parser-combinators-cl-ppcre"; - }); - systems = [ "parser-combinators-cl-ppcre" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "iterate" self) (getAttr "parser-combinators" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parser-combinators-debug = (build-asdf-system { - pname = "parser-combinators-debug"; - version = "20131111-git"; - asds = [ "parser-combinators-debug" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-parser-combinators/2013-11-11/cl-parser-combinators-20131111-git.tgz"; - sha256 = "1k49vha5xm2cklayzpqwg73n4v93xwsbs5in6342pkkiimnidhs8"; - system = "parser-combinators-debug"; - asd = "parser-combinators-debug"; - }); - systems = [ "parser-combinators-debug" ]; - lispLibs = [ (getAttr "cl-containers" self) (getAttr "parser-combinators" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parser-combinators-tests = (build-asdf-system { - pname = "parser-combinators-tests"; - version = "20131111-git"; - asds = [ "parser-combinators-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-parser-combinators/2013-11-11/cl-parser-combinators-20131111-git.tgz"; - sha256 = "1k49vha5xm2cklayzpqwg73n4v93xwsbs5in6342pkkiimnidhs8"; - system = "parser-combinators-tests"; - asd = "parser-combinators-tests"; - }); - systems = [ "parser-combinators-tests" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "hu_dot_dwim_dot_stefil" self) (getAttr "infix" self) (getAttr "iterate" self) (getAttr "parser-combinators" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parser_dot_common-rules = (build-asdf-system { - pname = "parser.common-rules"; - version = "20200715-git"; - asds = [ "parser.common-rules" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parser.common-rules/2020-07-15/parser.common-rules-20200715-git.tgz"; - sha256 = "138ygj0qp58jl4h79szg3i2gnwzywwc48qn1gj6dw113wasrnkwa"; - system = "parser.common-rules"; - asd = "parser.common-rules"; - }); - systems = [ "parser.common-rules" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "esrap" self) (getAttr "let-plus" self) (getAttr "split-sequence" self) ]; - meta = {}; - }); - parser_dot_common-rules_dot_operators = (build-asdf-system { - pname = "parser.common-rules.operators"; - version = "20200715-git"; - asds = [ "parser.common-rules.operators" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parser.common-rules/2020-07-15/parser.common-rules-20200715-git.tgz"; - sha256 = "138ygj0qp58jl4h79szg3i2gnwzywwc48qn1gj6dw113wasrnkwa"; - system = "parser.common-rules.operators"; - asd = "parser.common-rules.operators"; - }); - systems = [ "parser.common-rules.operators" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "architecture_dot_builder-protocol" self) (getAttr "esrap" self) (getAttr "let-plus" self) (getAttr "parser_dot_common-rules" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parser_dot_ini = (build-asdf-system { - pname = "parser.ini"; - version = "20181018-git"; - asds = [ "parser.ini" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parser.ini/2018-10-18/parser.ini-20181018-git.tgz"; - sha256 = "0ri4c7877i9val67z5sm8nfhz04p9l6brajx2fkavs8556l1wm1d"; - system = "parser.ini"; - asd = "parser.ini"; - }); - systems = [ "parser.ini" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "architecture_dot_builder-protocol" self) (getAttr "esrap" self) (getAttr "let-plus" self) (getAttr "more-conditions" self) (getAttr "parser_dot_common-rules" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - parsnip = (build-asdf-system { - pname = "parsnip"; - version = "20220331-git"; - asds = [ "parsnip" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/parsnip/2022-03-31/parsnip-20220331-git.tgz"; - sha256 = "0gl7z8kn37qiz0vab89wawn78iczii7iqw43jy2ls7nw0l5jv13w"; - system = "parsnip"; - asd = "parsnip"; - }); - systems = [ "parsnip" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - patchwork = (build-asdf-system { - pname = "patchwork"; - version = "20220707-git"; - asds = [ "patchwork" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/patchwork/2022-07-07/patchwork-20220707-git.tgz"; - sha256 = "08d08hslcs69509wj56mlklv1cz5lq2rz0sl870zcxyn4j1nnf3f"; - system = "patchwork"; - asd = "patchwork"; - }); - systems = [ "patchwork" ]; - lispLibs = [ (getAttr "binpack" self) (getAttr "mfiano-utils" self) (getAttr "opticl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - path-parse = (build-asdf-system { - pname = "path-parse"; - version = "20160421-git"; - asds = [ "path-parse" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/path-parse/2016-04-21/path-parse-20160421-git.tgz"; - sha256 = "10mxm6q62cfpv3hw2w8k968ba8a1xglqdkwlkqs4l4nby3b11aaq"; - system = "path-parse"; - asd = "path-parse"; - }); - systems = [ "path-parse" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - path-parse-test = (build-asdf-system { - pname = "path-parse-test"; - version = "20160421-git"; - asds = [ "path-parse-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/path-parse/2016-04-21/path-parse-20160421-git.tgz"; - sha256 = "10mxm6q62cfpv3hw2w8k968ba8a1xglqdkwlkqs4l4nby3b11aaq"; - system = "path-parse-test"; - asd = "path-parse-test"; - }); - systems = [ "path-parse-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "path-parse" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - path-string = (build-asdf-system { - pname = "path-string"; - version = "20160825-git"; - asds = [ "path-string" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/path-string/2016-08-25/path-string-20160825-git.tgz"; - sha256 = "0hs36kf4njxafxrngs1m1sh9c7b9wv7sa8n316dq4icx3kf3v6yp"; - system = "path-string"; - asd = "path-string"; - }); - systems = [ "path-string" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - path-string-test = (build-asdf-system { - pname = "path-string-test"; - version = "20160825-git"; - asds = [ "path-string-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/path-string/2016-08-25/path-string-20160825-git.tgz"; - sha256 = "0hs36kf4njxafxrngs1m1sh9c7b9wv7sa8n316dq4icx3kf3v6yp"; - system = "path-string-test"; - asd = "path-string-test"; - }); - systems = [ "path-string-test" ]; - lispLibs = [ (getAttr "path-string" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pathname-utils = (build-asdf-system { - pname = "pathname-utils"; - version = "20241012-git"; - asds = [ "pathname-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pathname-utils/2024-10-12/pathname-utils-20241012-git.tgz"; - sha256 = "1z1z3dar6g2ybxgk9zgcyb8bh5g6rh12bwl3ik6rdwy3rdd5b1q5"; - system = "pathname-utils"; - asd = "pathname-utils"; - }); - systems = [ "pathname-utils" ]; - lispLibs = [ (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pathname-utils-test = (build-asdf-system { - pname = "pathname-utils-test"; - version = "20241012-git"; - asds = [ "pathname-utils-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pathname-utils/2024-10-12/pathname-utils-20241012-git.tgz"; - sha256 = "1z1z3dar6g2ybxgk9zgcyb8bh5g6rh12bwl3ik6rdwy3rdd5b1q5"; - system = "pathname-utils-test"; - asd = "pathname-utils-test"; - }); - systems = [ "pathname-utils-test" ]; - lispLibs = [ (getAttr "parachute" self) (getAttr "pathname-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - patron = (build-asdf-system { - pname = "patron"; - version = "20130420-git"; - asds = [ "patron" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/patron/2013-04-20/patron-20130420-git.tgz"; - sha256 = "0i2vlwspnssjxdnq7dsrb98q3y8c8drd0a11nxn9808q76sqzsqc"; - system = "patron"; - asd = "patron"; - }); - systems = [ "patron" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcall = (build-asdf-system { - pname = "pcall"; - version = "0.3"; - asds = [ "pcall" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pcall/2010-10-06/pcall-0.3.tgz"; - sha256 = "00ix5d9ljymrrpwsri0hhh3d592jqr2lvgbvkhav3k96rwq974ps"; - system = "pcall"; - asd = "pcall"; - }); - systems = [ "pcall" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "pcall-queue" self) ]; - meta = {}; - }); - pcall-queue = (build-asdf-system { - pname = "pcall-queue"; - version = "0.3"; - asds = [ "pcall-queue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pcall/2010-10-06/pcall-0.3.tgz"; - sha256 = "00ix5d9ljymrrpwsri0hhh3d592jqr2lvgbvkhav3k96rwq974ps"; - system = "pcall-queue"; - asd = "pcall-queue"; - }); - systems = [ "pcall-queue" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = {}; - }); - pcall-tests = (build-asdf-system { - pname = "pcall-tests"; - version = "0.3"; - asds = [ "pcall-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pcall/2010-10-06/pcall-0.3.tgz"; - sha256 = "00ix5d9ljymrrpwsri0hhh3d592jqr2lvgbvkhav3k96rwq974ps"; - system = "pcall-tests"; - asd = "pcall"; - }); - systems = [ "pcall-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "pcall" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-binary-data = (build-asdf-system { - pname = "pcl-binary-data"; - version = "20180430-git"; - asds = [ "pcl-binary-data" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "pcl-binary-data"; - asd = "pcl-binary-data"; - }); - systems = [ "pcl-binary-data" ]; - lispLibs = [ (getAttr "pcl-macro-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-html = (build-asdf-system { - pname = "pcl-html"; - version = "20180430-git"; - asds = [ "pcl-html" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "pcl-html"; - asd = "pcl-html"; - }); - systems = [ "pcl-html" ]; - lispLibs = [ (getAttr "pcl-macro-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-id3v2 = (build-asdf-system { - pname = "pcl-id3v2"; - version = "20180430-git"; - asds = [ "pcl-id3v2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "pcl-id3v2"; - asd = "pcl-id3v2"; - }); - systems = [ "pcl-id3v2" ]; - lispLibs = [ (getAttr "pcl-binary-data" self) (getAttr "pcl-pathnames" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-macro-utilities = (build-asdf-system { - pname = "pcl-macro-utilities"; - version = "20180430-git"; - asds = [ "pcl-macro-utilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "pcl-macro-utilities"; - asd = "pcl-macro-utilities"; - }); - systems = [ "pcl-macro-utilities" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-mp3-browser = (build-asdf-system { - pname = "pcl-mp3-browser"; - version = "20180430-git"; - asds = [ "pcl-mp3-browser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "pcl-mp3-browser"; - asd = "pcl-mp3-browser"; - }); - systems = [ "pcl-mp3-browser" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "pcl-html" self) (getAttr "pcl-id3v2" self) (getAttr "pcl-mp3-database" self) (getAttr "pcl-shoutcast" self) (getAttr "pcl-url-function" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-mp3-database = (build-asdf-system { - pname = "pcl-mp3-database"; - version = "20180430-git"; - asds = [ "pcl-mp3-database" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "pcl-mp3-database"; - asd = "pcl-mp3-database"; - }); - systems = [ "pcl-mp3-database" ]; - lispLibs = [ (getAttr "pcl-id3v2" self) (getAttr "pcl-macro-utilities" self) (getAttr "pcl-pathnames" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-pathnames = (build-asdf-system { - pname = "pcl-pathnames"; - version = "20180430-git"; - asds = [ "pcl-pathnames" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "pcl-pathnames"; - asd = "pcl-pathnames"; - }); - systems = [ "pcl-pathnames" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-shoutcast = (build-asdf-system { - pname = "pcl-shoutcast"; - version = "20180430-git"; - asds = [ "pcl-shoutcast" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "pcl-shoutcast"; - asd = "pcl-shoutcast"; - }); - systems = [ "pcl-shoutcast" ]; - lispLibs = [ (getAttr "pcl-html" self) (getAttr "pcl-id3v2" self) (getAttr "pcl-macro-utilities" self) (getAttr "pcl-mp3-database" self) (getAttr "pcl-pathnames" self) (getAttr "pcl-url-function" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-simple-database = (build-asdf-system { - pname = "pcl-simple-database"; - version = "20180430-git"; - asds = [ "pcl-simple-database" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "pcl-simple-database"; - asd = "pcl-simple-database"; - }); - systems = [ "pcl-simple-database" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-spam = (build-asdf-system { - pname = "pcl-spam"; - version = "20180430-git"; - asds = [ "pcl-spam" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "pcl-spam"; - asd = "pcl-spam"; - }); - systems = [ "pcl-spam" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "pcl-pathnames" self) (getAttr "pcl-test-framework" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-test-framework = (build-asdf-system { - pname = "pcl-test-framework"; - version = "20180430-git"; - asds = [ "pcl-test-framework" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "pcl-test-framework"; - asd = "pcl-test-framework"; - }); - systems = [ "pcl-test-framework" ]; - lispLibs = [ (getAttr "pcl-macro-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-unit-test = (build-asdf-system { - pname = "pcl-unit-test"; - version = "20121125-git"; - asds = [ "pcl-unit-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-match/2012-11-25/cl-match-20121125-git.tgz"; - sha256 = "1qc8gzp7f4phgyi5whkxacrqzdqs0y1hvkf71m8n7l303jly9wjf"; - system = "pcl-unit-test"; - asd = "pcl-unit-test"; - }); - systems = [ "pcl-unit-test" ]; - lispLibs = [ (getAttr "standard-cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pcl-url-function = (build-asdf-system { - pname = "pcl-url-function"; - version = "20180430-git"; - asds = [ "pcl-url-function" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "pcl-url-function"; - asd = "pcl-url-function"; - }); - systems = [ "pcl-url-function" ]; - lispLibs = [ (getAttr "aserve" self) (getAttr "pcl-html" self) (getAttr "pcl-macro-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - peppol = (build-asdf-system { - pname = "peppol"; - version = "20201016-git"; - asds = [ "peppol" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-peppol/2020-10-16/cl-peppol-20201016-git.tgz"; - sha256 = "02wc6h1fiaqzf14py2kwsvx0dmb22wdkd54pl0ixnmivj436ln99"; - system = "peppol"; - asd = "peppol"; - }); - systems = [ "peppol" ]; - lispLibs = [ (getAttr "cxml" self) (getAttr "xpath" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - percent-encoding = (build-asdf-system { - pname = "percent-encoding"; - version = "20121013-git"; - asds = [ "percent-encoding" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/percent-encoding/2012-10-13/percent-encoding-20121013-git.tgz"; - sha256 = "0q1lh3sa6mkjr5gcdkgimkpc29rgf9cjhv90f61h8ridj28grq0h"; - system = "percent-encoding"; - asd = "percent-encoding"; - }); - systems = [ "percent-encoding" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "babel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - percent-encoding-test = (build-asdf-system { - pname = "percent-encoding-test"; - version = "20121013-git"; - asds = [ "percent-encoding-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/percent-encoding/2012-10-13/percent-encoding-20121013-git.tgz"; - sha256 = "0q1lh3sa6mkjr5gcdkgimkpc29rgf9cjhv90f61h8ridj28grq0h"; - system = "percent-encoding-test"; - asd = "percent-encoding"; - }); - systems = [ "percent-encoding-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "percent-encoding" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - perceptual-hashes = (build-asdf-system { - pname = "perceptual-hashes"; - version = "20220707-git"; - asds = [ "perceptual-hashes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/perceptual-hashes/2022-07-07/perceptual-hashes-20220707-git.tgz"; - sha256 = "1hg2vxi4avmjwscgab7wqf3c4d60x933lac4d86fmfk0wgl5nzzd"; - system = "perceptual-hashes"; - asd = "perceptual-hashes"; - }); - systems = [ "perceptual-hashes" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "array-operations" self) (getAttr "imago" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - periodic-table = (build-asdf-system { - pname = "periodic-table"; - version = "1.0"; - asds = [ "periodic-table" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/periodic-table/2011-10-01/periodic-table-1.0.tgz"; - sha256 = "147j9kn0afsvlz09vdjmvw5si08ix3dyypg21vrc5xvn9nsalrxx"; - system = "periodic-table"; - asd = "periodic-table"; - }); - systems = [ "periodic-table" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - periods = (build-asdf-system { - pname = "periods"; - version = "20221106-git"; - asds = [ "periods" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/periods/2022-11-06/periods-20221106-git.tgz"; - sha256 = "0ynhdmlzb499mlm7c7zy6vgw8vglkkf14zr0v40jcl1sgq3236ry"; - system = "periods"; - asd = "periods"; - }); - systems = [ "periods" ]; - lispLibs = [ (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - periods-series = (build-asdf-system { - pname = "periods-series"; - version = "20221106-git"; - asds = [ "periods-series" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/periods/2022-11-06/periods-20221106-git.tgz"; - sha256 = "0ynhdmlzb499mlm7c7zy6vgw8vglkkf14zr0v40jcl1sgq3236ry"; - system = "periods-series"; - asd = "periods-series"; - }); - systems = [ "periods-series" ]; - lispLibs = [ (getAttr "periods" self) (getAttr "series" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - perlre = (build-asdf-system { - pname = "perlre"; - version = "20200715-git"; - asds = [ "perlre" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/perlre/2020-07-15/perlre-20200715-git.tgz"; - sha256 = "1izhrn1xd0mi2nl0p6930ln3nb4wp3y5ngg81wy5g5s4vqy2h54a"; - system = "perlre"; - asd = "perlre"; - }); - systems = [ "perlre" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "let-over-lambda" self) (getAttr "prove" self) (getAttr "trivia" self) (getAttr "trivia_dot_ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pero = (build-asdf-system { - pname = "pero"; - version = "20230214-git"; - asds = [ "pero" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pero/2023-02-14/pero-20230214-git.tgz"; - sha256 = "1q513lvnq4m8l332glriid0vxcdcnakcdag3lck1wmrfaxhdpnmc"; - system = "pero"; - asd = "pero"; - }); - systems = [ "pero" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - persistent = (build-asdf-system { - pname = "persistent"; - version = "20241012-git"; - asds = [ "persistent" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "persistent"; - asd = "persistent"; - }); - systems = [ "persistent" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - persistent-tables = (build-asdf-system { - pname = "persistent-tables"; - version = "20120208-git"; - asds = [ "persistent-tables" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/persistent-tables/2012-02-08/persistent-tables-20120208-git.tgz"; - sha256 = "0klfjza85mgj2z42x2lhcqy9q66avac7zw0cpbmwwng3m7679hpa"; - system = "persistent-tables"; - asd = "persistent-tables"; - }); - systems = [ "persistent-tables" ]; - lispLibs = [ (getAttr "lisp-unit" self) (getAttr "random-access-lists" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - persistent-variables = (build-asdf-system { - pname = "persistent-variables"; - version = "20130312-git"; - asds = [ "persistent-variables" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/persistent-variables/2013-03-12/persistent-variables-20130312-git.tgz"; - sha256 = "0r72cbjkb5q4sn109svlcsvrwgvwdsn5c63rv5cpaf3jrfv1z8xn"; - system = "persistent-variables"; - asd = "persistent-variables"; - }); - systems = [ "persistent-variables" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - persistent-variables_dot_test = (build-asdf-system { - pname = "persistent-variables.test"; - version = "20130312-git"; - asds = [ "persistent-variables.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/persistent-variables/2013-03-12/persistent-variables-20130312-git.tgz"; - sha256 = "0r72cbjkb5q4sn109svlcsvrwgvwdsn5c63rv5cpaf3jrfv1z8xn"; - system = "persistent-variables.test"; - asd = "persistent-variables"; - }); - systems = [ "persistent-variables.test" ]; - lispLibs = [ (getAttr "persistent-variables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petalisp = (build-asdf-system { - pname = "petalisp"; - version = "20241012-git"; - asds = [ "petalisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; - sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; - system = "petalisp"; - asd = "petalisp"; - }); - systems = [ "petalisp" ]; - lispLibs = [ (getAttr "petalisp_dot_api" self) (getAttr "petalisp_dot_test-suite" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petalisp_dot_api = (build-asdf-system { - pname = "petalisp.api"; - version = "20241012-git"; - asds = [ "petalisp.api" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; - sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; - system = "petalisp.api"; - asd = "petalisp.api"; - }); - systems = [ "petalisp.api" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "petalisp_dot_codegen" self) (getAttr "petalisp_dot_core" self) (getAttr "petalisp_dot_ir" self) (getAttr "petalisp_dot_native-backend" self) (getAttr "petalisp_dot_packages" self) (getAttr "petalisp_dot_utilities" self) (getAttr "split-sequence" self) (getAttr "trivia" self) (getAttr "trivial-macroexpand-all" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petalisp_dot_codegen = (build-asdf-system { - pname = "petalisp.codegen"; - version = "20241012-git"; - asds = [ "petalisp.codegen" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; - sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; - system = "petalisp.codegen"; - asd = "petalisp.codegen"; - }); - systems = [ "petalisp.codegen" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "petalisp_dot_core" self) (getAttr "petalisp_dot_ir" self) (getAttr "petalisp_dot_utilities" self) (getAttr "trivia" self) (getAttr "trivial-macroexpand-all" self) (getAttr "ucons" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petalisp_dot_core = (build-asdf-system { - pname = "petalisp.core"; - version = "20241012-git"; - asds = [ "petalisp.core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; - sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; - system = "petalisp.core"; - asd = "petalisp.core"; - }); - systems = [ "petalisp.core" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "lparallel" self) (getAttr "petalisp_dot_packages" self) (getAttr "petalisp_dot_utilities" self) (getAttr "trivia" self) (getAttr "typo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petalisp_dot_examples = (build-asdf-system { - pname = "petalisp.examples"; - version = "20241012-git"; - asds = [ "petalisp.examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; - sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; - system = "petalisp.examples"; - asd = "petalisp.examples"; - }); - systems = [ "petalisp.examples" ]; - lispLibs = [ (getAttr "numpy-file-format" self) (getAttr "petalisp_dot_api" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petalisp_dot_ir = (build-asdf-system { - pname = "petalisp.ir"; - version = "20241012-git"; - asds = [ "petalisp.ir" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; - sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; - system = "petalisp.ir"; - asd = "petalisp.ir"; - }); - systems = [ "petalisp.ir" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "petalisp_dot_core" self) (getAttr "petalisp_dot_utilities" self) (getAttr "priority-queue" self) (getAttr "split-sequence" self) (getAttr "ucons" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petalisp_dot_native-backend = (build-asdf-system { - pname = "petalisp.native-backend"; - version = "20241012-git"; - asds = [ "petalisp.native-backend" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; - sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; - system = "petalisp.native-backend"; - asd = "petalisp.native-backend"; - }); - systems = [ "petalisp.native-backend" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "lparallel" self) (getAttr "petalisp_dot_codegen" self) (getAttr "petalisp_dot_core" self) (getAttr "petalisp_dot_ir" self) (getAttr "petalisp_dot_utilities" self) (getAttr "static-vectors" self) (getAttr "trivia" self) (getAttr "trivial-garbage" self) (getAttr "typo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petalisp_dot_packages = (build-asdf-system { - pname = "petalisp.packages"; - version = "20241012-git"; - asds = [ "petalisp.packages" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; - sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; - system = "petalisp.packages"; - asd = "petalisp.packages"; - }); - systems = [ "petalisp.packages" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petalisp_dot_test-suite = (build-asdf-system { - pname = "petalisp.test-suite"; - version = "20241012-git"; - asds = [ "petalisp.test-suite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; - sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; - system = "petalisp.test-suite"; - asd = "petalisp.test-suite"; - }); - systems = [ "petalisp.test-suite" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "petalisp_dot_api" self) (getAttr "petalisp_dot_examples" self) (getAttr "petalisp_dot_native-backend" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petalisp_dot_utilities = (build-asdf-system { - pname = "petalisp.utilities"; - version = "20241012-git"; - asds = [ "petalisp.utilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; - sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; - system = "petalisp.utilities"; - asd = "petalisp.utilities"; - }); - systems = [ "petalisp.utilities" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "queues_dot_priority-queue" self) (getAttr "trivia" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petit_dot_package-utils = (build-asdf-system { - pname = "petit.package-utils"; - version = "20140826-git"; - asds = [ "petit.package-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petit.package-utils/2014-08-26/petit.package-utils-20140826-git.tgz"; - sha256 = "0jj4c1jpcqfy9mrlxhjmq4ypwlzk84h09i8nr34wjwh6z7idhpyv"; - system = "petit.package-utils"; - asd = "petit.package-utils"; - }); - systems = [ "petit.package-utils" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petit_dot_string-utils = (build-asdf-system { - pname = "petit.string-utils"; - version = "20141106-git"; - asds = [ "petit.string-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petit.string-utils/2014-11-06/petit.string-utils-20141106-git.tgz"; - sha256 = "04kqdj69x53wzvpp54zp6767186in24p8yrr82wdg2bwzw4qh4yl"; - system = "petit.string-utils"; - asd = "petit.string-utils"; - }); - systems = [ "petit.string-utils" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petit_dot_string-utils-test = (build-asdf-system { - pname = "petit.string-utils-test"; - version = "20141106-git"; - asds = [ "petit.string-utils-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petit.string-utils/2014-11-06/petit.string-utils-20141106-git.tgz"; - sha256 = "04kqdj69x53wzvpp54zp6767186in24p8yrr82wdg2bwzw4qh4yl"; - system = "petit.string-utils-test"; - asd = "petit.string-utils-test"; - }); - systems = [ "petit.string-utils-test" ]; - lispLibs = [ (getAttr "petit_dot_string-utils" self) (getAttr "rt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - petri = (build-asdf-system { - pname = "petri"; - version = "20200427-git"; - asds = [ "petri" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/petri/2020-04-27/petri-20200427-git.tgz"; - sha256 = "1y78s3jndyxll46zq7s5is9pwv8f6jr2npjkcpd48ik7xkj2269b"; - system = "petri"; - asd = "petri"; - }); - systems = [ "petri" ]; - lispLibs = [ (getAttr "_1am" self) (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "phoe-toolbox" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pettomato-deque = (build-asdf-system { - pname = "pettomato-deque"; - version = "20120107-git"; - asds = [ "pettomato-deque" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pettomato-deque/2012-01-07/pettomato-deque-20120107-git.tgz"; - sha256 = "07ai4fa64cg6shfvnx9xk7pscbsz64ys80482zz2fb9q0rba80b7"; - system = "pettomato-deque"; - asd = "pettomato-deque"; - }); - systems = [ "pettomato-deque" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pettomato-deque-tests = (build-asdf-system { - pname = "pettomato-deque-tests"; - version = "20120107-git"; - asds = [ "pettomato-deque-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pettomato-deque/2012-01-07/pettomato-deque-20120107-git.tgz"; - sha256 = "07ai4fa64cg6shfvnx9xk7pscbsz64ys80482zz2fb9q0rba80b7"; - system = "pettomato-deque-tests"; - asd = "pettomato-deque-tests"; - }); - systems = [ "pettomato-deque-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "pettomato-deque" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pettomato-indexed-priority-queue = (build-asdf-system { - pname = "pettomato-indexed-priority-queue"; - version = "20120909-git"; - asds = [ "pettomato-indexed-priority-queue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pettomato-indexed-priority-queue/2012-09-09/pettomato-indexed-priority-queue-20120909-git.tgz"; - sha256 = "14i36qbdnif28xcbxdbr5abzmzxr7vzv64n1aix0f6khxg99pylz"; - system = "pettomato-indexed-priority-queue"; - asd = "pettomato-indexed-priority-queue"; - }); - systems = [ "pettomato-indexed-priority-queue" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pettomato-indexed-priority-queue-tests = (build-asdf-system { - pname = "pettomato-indexed-priority-queue-tests"; - version = "20120909-git"; - asds = [ "pettomato-indexed-priority-queue-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pettomato-indexed-priority-queue/2012-09-09/pettomato-indexed-priority-queue-20120909-git.tgz"; - sha256 = "14i36qbdnif28xcbxdbr5abzmzxr7vzv64n1aix0f6khxg99pylz"; - system = "pettomato-indexed-priority-queue-tests"; - asd = "pettomato-indexed-priority-queue-tests"; - }); - systems = [ "pettomato-indexed-priority-queue-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "pettomato-indexed-priority-queue" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pfft = (build-asdf-system { - pname = "pfft"; - version = "20180711-git"; - asds = [ "pfft" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/fft/2018-07-11/fft-20180711-git.tgz"; - sha256 = "0ymnfplap2cncw49mhq7crapgxphfwsvqdgrcckpgsvw6qsymasd"; - system = "pfft"; - asd = "pfft"; - }); - systems = [ "pfft" ]; - lispLibs = [ (getAttr "fft" self) (getAttr "pcall" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pg = (build-asdf-system { - pname = "pg"; - version = "20150608-git"; - asds = [ "pg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pg/2015-06-08/pg-20150608-git.tgz"; - sha256 = "1c7axd2yxw9lxf7l5djrnfkp197mmr88qpigy2cjgim8vxab4n2l"; - system = "pg"; - asd = "pg"; - }); - systems = [ "pg" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pgloader = (build-asdf-system { - pname = "pgloader"; - version = "v3.6.9"; - asds = [ "pgloader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pgloader/2022-11-06/pgloader-v3.6.9.tgz"; - sha256 = "03kp3ms2sjz4gwb94xs404mi63fnv1bq00hyqxyvc9csmicxzawn"; - system = "pgloader"; - asd = "pgloader"; - }); - systems = [ "pgloader" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-base64" self) (getAttr "cl-csv" self) (getAttr "cl-fad" self) (getAttr "cl-log" self) (getAttr "cl-markdown" self) (getAttr "cl-mustache" self) (getAttr "cl-postgres" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "command-line-arguments" self) (getAttr "db3" self) (getAttr "drakma" self) (getAttr "esrap" self) (getAttr "flexi-streams" self) (getAttr "ixf" self) (getAttr "local-time" self) (getAttr "lparallel" self) (getAttr "metabang-bind" self) (getAttr "mssql" self) (getAttr "postmodern" self) (getAttr "py-configparser" self) (getAttr "qmynd" self) (getAttr "quri" self) (getAttr "simple-date" self) (getAttr "split-sequence" self) (getAttr "sqlite" self) (getAttr "trivial-backtrace" self) (getAttr "usocket" self) (getAttr "uuid" self) (getAttr "yason" self) (getAttr "zs3" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - phoe-toolbox = (build-asdf-system { - pname = "phoe-toolbox"; - version = "20210124-git"; - asds = [ "phoe-toolbox" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/phoe-toolbox/2021-01-24/phoe-toolbox-20210124-git.tgz"; - sha256 = "0bzbgs4lkhw93y1cwrs9kp5yiyz8sg4885cnvi83dzzbla9b74kv"; - system = "phoe-toolbox"; - asd = "phoe-toolbox"; - }); - systems = [ "phoe-toolbox" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "trivial-indent" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - phonon = (build-asdf-system { - pname = "phonon"; - version = "20210531-git"; - asds = [ "phonon" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "phonon"; - asd = "phonon"; - }); - systems = [ "phonon" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtdbus" self) (getAttr "qtgui" self) (getAttr "qtxml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - phos = (build-asdf-system { - pname = "phos"; - version = "20241012-git"; - asds = [ "phos" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/phos/2024-10-12/phos-20241012-git.tgz"; - sha256 = "0lnv54iczidjpskciw7y2faazgxjwpncggdh5kggpjziq03pr7lv"; - system = "phos"; - asd = "phos"; - }); - systems = [ "phos" ]; - lispLibs = [ (getAttr "cl_plus_ssl" self) (getAttr "cl-ppcre" self) (getAttr "quri" self) (getAttr "trivia" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - physical-dimension = (build-asdf-system { - pname = "physical-dimension"; - version = "master-df14cb8c-git"; - asds = [ "physical-dimension" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/antik/2024-10-12/antik-master-df14cb8c-git.tgz"; - sha256 = "1n08cx4n51z8v4bxyak166lp495xda3x7llfxcdpxndxqxcammr0"; - system = "physical-dimension"; - asd = "physical-dimension"; - }); - systems = [ "physical-dimension" ]; - lispLibs = [ (getAttr "fare-utils" self) (getAttr "foreign-array" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - physical-quantities = (build-asdf-system { - pname = "physical-quantities"; - version = "20211020-git"; - asds = [ "physical-quantities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/physical-quantities/2021-10-20/physical-quantities-20211020-git.tgz"; - sha256 = "0mb2s94s6fhw5vfa89naalw7ld11sdsszlqpz0c65dvpfyfmmdmh"; - system = "physical-quantities"; - asd = "physical-quantities"; - }); - systems = [ "physical-quantities" ]; - lispLibs = [ (getAttr "parseq" self) ]; - meta = {}; - }); - picl = (build-asdf-system { - pname = "picl"; - version = "20241012-git"; - asds = [ "picl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/picl/2024-10-12/picl-20241012-git.tgz"; - sha256 = "0pdzlmphf1bqk5xdvwf1m1l3s5whwm4ysnpl5kpwq70adx38rysk"; - system = "picl"; - asd = "picl"; - }); - systems = [ "picl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "defclass-std" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - piggyback-parameters = (build-asdf-system { - pname = "piggyback-parameters"; - version = "20200610-git"; - asds = [ "piggyback-parameters" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/piggyback-parameters/2020-06-10/piggyback-parameters-20200610-git.tgz"; - sha256 = "1187bgnz9pvs8xdxapqhrm4yqzwlp368ijmc5szm8r8q3zrb219n"; - system = "piggyback-parameters"; - asd = "piggyback-parameters"; - }); - systems = [ "piggyback-parameters" ]; - lispLibs = [ (getAttr "trivial-hashtable-serialize" self) (getAttr "trivial-json-codec" self) (getAttr "trivial-pooled-database" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pileup = (build-asdf-system { - pname = "pileup"; - version = "20150709-git"; - asds = [ "pileup" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pileup/2015-07-09/pileup-20150709-git.tgz"; - sha256 = "01gvshpxil0ggjgfmgcymbgmpsfaxy6aggm0bywkn40rck3038vb"; - system = "pileup"; - asd = "pileup"; - }); - systems = [ "pileup" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pileup-tests = (build-asdf-system { - pname = "pileup-tests"; - version = "20150709-git"; - asds = [ "pileup-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pileup/2015-07-09/pileup-20150709-git.tgz"; - sha256 = "01gvshpxil0ggjgfmgcymbgmpsfaxy6aggm0bywkn40rck3038vb"; - system = "pileup-tests"; - asd = "pileup"; - }); - systems = [ "pileup-tests" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_stefil" self) (getAttr "pileup" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pipes = (build-asdf-system { - pname = "pipes"; - version = "20150923-git"; - asds = [ "pipes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pipes/2015-09-23/pipes-20150923-git.tgz"; - sha256 = "17qcxalbdip20nkbwiv3kpdjjsy0g1y9s4a0zv38ch47bdl9yxpc"; - system = "pipes"; - asd = "pipes"; - }); - systems = [ "pipes" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - piping = (build-asdf-system { - pname = "piping"; - version = "20231021-git"; - asds = [ "piping" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/piping/2023-10-21/piping-20231021-git.tgz"; - sha256 = "0g0k6w7xa0xyzlr3j5j85b91kazbba4rxwplmqcb5ns3shk8745g"; - system = "piping"; - asd = "piping"; - }); - systems = [ "piping" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pithy-xml = (build-asdf-system { - pname = "pithy-xml"; - version = "20101006-git"; - asds = [ "pithy-xml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pithy-xml/2010-10-06/pithy-xml-20101006-git.tgz"; - sha256 = "05zw5adiw7jgvi9w9c661s4r49fidpcxn6m7azmn0pzc936dg17h"; - system = "pithy-xml"; - asd = "pithy-xml"; - }); - systems = [ "pithy-xml" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pixman = (build-asdf-system { - pname = "pixman"; - version = "20170830-git"; - asds = [ "pixman" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-pixman/2017-08-30/cl-pixman-20170830-git.tgz"; - sha256 = "068hh7cv6f2wqwd8092wqh3rgdix6sa319qpm648mss8jfnjjbgj"; - system = "pixman"; - asd = "pixman"; - }); - systems = [ "pixman" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pjlink = (build-asdf-system { - pname = "pjlink"; - version = "20220331-git"; - asds = [ "pjlink" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pjlink/2022-03-31/pjlink-20220331-git.tgz"; - sha256 = "1rsmg0x7fd32na36x9ahj6vji3xs6ckg5pyng8nf33fmdj8dscbc"; - system = "pjlink"; - asd = "pjlink"; - }); - systems = [ "pjlink" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "ip-interfaces" self) (getAttr "md5" self) (getAttr "split-sequence" self) (getAttr "trivial-garbage" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pk-serialize = (build-asdf-system { - pname = "pk-serialize"; - version = "20221106-git"; - asds = [ "pk-serialize" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pk-serialize/2022-11-06/pk-serialize-20221106-git.tgz"; - sha256 = "1fi9xxdlg2z9dnqb2sc7wg37aqzqjz43h2l1wxa5zvk73qqzapyn"; - system = "pk-serialize"; - asd = "pk-serialize"; - }); - systems = [ "pk-serialize" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pkg-doc = (build-asdf-system { - pname = "pkg-doc"; - version = "20200925-git"; - asds = [ "pkg-doc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pkg-doc/2020-09-25/pkg-doc-20200925-git.tgz"; - sha256 = "1y4dcc0q3iizgvavnkl8q4bjxq0dngvqw5dhrf9bxf4d3q3vrbd4"; - system = "pkg-doc"; - asd = "pkg-doc"; - }); - systems = [ "pkg-doc" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "clim-widgets" self) (getAttr "manifest" self) (getAttr "nsort" self) (getAttr "repl-utilities" self) (getAttr "stdutils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - place-modifiers = (build-asdf-system { - pname = "place-modifiers"; - version = "2.1"; - asds = [ "place-modifiers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/place-modifiers/2012-11-25/place-modifiers-2.1.tgz"; - sha256 = "13nd911h6i7gks78l30bzdqzygcqh47946jwaf50ak2iraagknvf"; - system = "place-modifiers"; - asd = "place-modifiers"; - }); - systems = [ "place-modifiers" ]; - lispLibs = [ (getAttr "cartesian-product-switch" self) (getAttr "map-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - place-utils = (build-asdf-system { - pname = "place-utils"; - version = "0.2"; - asds = [ "place-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/place-utils/2018-10-18/place-utils-0.2.tgz"; - sha256 = "1riaxxafn2xbyy6776yqns1bhz5jnzzpd177wb5xzvwlxiix6yf9"; - system = "place-utils"; - asd = "place-utils"; - }); - systems = [ "place-utils" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - planks = (build-asdf-system { - pname = "planks"; - version = "20110522-git"; - asds = [ "planks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/planks/2011-05-22/planks-20110522-git.tgz"; - sha256 = "1y7cg9xb75j1yslbxsmw0fyg738f4d28lnlm7w7hzgc51fc7875k"; - system = "planks"; - asd = "planks"; - }); - systems = [ "planks" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "ironclad" self) (getAttr "rucksack" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - plokami = (build-asdf-system { - pname = "plokami"; - version = "20200218-git"; - asds = [ "plokami" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/plokami/2020-02-18/plokami-20200218-git.tgz"; - sha256 = "1k78lpbaqqa2gnwi9k0y646md4s9xnijm774knl11p05r83w5ycb"; - system = "plokami"; - asd = "plokami"; - }); - systems = [ "plokami" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - plot = (build-asdf-system { - pname = "plot"; - version = "20241012-git"; - asds = [ "plot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/plot/2024-10-12/plot-20241012-git.tgz"; - sha256 = "1x5kc5y0s082y24qgq138331qmfs0xxxj43ss3aw0kgx7wfpxlms"; - system = "plot"; - asd = "plot"; - }); - systems = [ "plot" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "alexandria_plus" self) (getAttr "cl-ppcre" self) (getAttr "data-frame" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - plplot-examples = (build-asdf-system { - pname = "plplot-examples"; - version = "20180228-git"; - asds = [ "plplot-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-plplot/2018-02-28/cl-plplot-20180228-git.tgz"; - sha256 = "0hfgq47ga2r764jfc3ywaz5ynnvp701fjhbw0s4j1mrw4gaf6y6w"; - system = "plplot-examples"; - asd = "cl-plplot"; - }); - systems = [ "plplot-examples" ]; - lispLibs = [ (getAttr "cl-plplot" self) (getAttr "png" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pludeck = (build-asdf-system { - pname = "pludeck"; - version = "20180831-git"; - asds = [ "pludeck" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pludeck/2018-08-31/pludeck-20180831-git.tgz"; - sha256 = "0p6v7fxs48fxr76kvkh6z2mjjyz3vf2rp698jq1fl6p3hihbgl0m"; - system = "pludeck"; - asd = "pludeck"; - }); - systems = [ "pludeck" ]; - lispLibs = [ (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - plump = (build-asdf-system { - pname = "plump"; - version = "20241012-git"; - asds = [ "plump" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/plump/2024-10-12/plump-20241012-git.tgz"; - sha256 = "04wy2v69zal186gg0pvcj60184gi7cpkpx3h1w93c9nilmla0dv9"; - system = "plump"; - asd = "plump"; - }); - systems = [ "plump" ]; - lispLibs = [ (getAttr "array-utils" self) (getAttr "documentation-utils" self) ]; - meta = {}; - }); - plump-bundle = (build-asdf-system { - pname = "plump-bundle"; - version = "20231021-git"; - asds = [ "plump-bundle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/plump-bundle/2023-10-21/plump-bundle-20231021-git.tgz"; - sha256 = "0qknmdryyynjk5g0zda2788p4j0s6w4fj27kdca22z0n8r8yfhhk"; - system = "plump-bundle"; - asd = "plump-bundle"; - }); - systems = [ "plump-bundle" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "closer-mop" self) (getAttr "fast-io" self) (getAttr "plump-dom" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - plump-dom = (build-asdf-system { - pname = "plump-dom"; - version = "20241012-git"; - asds = [ "plump-dom" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/plump/2024-10-12/plump-20241012-git.tgz"; - sha256 = "04wy2v69zal186gg0pvcj60184gi7cpkpx3h1w93c9nilmla0dv9"; - system = "plump-dom"; - asd = "plump-dom"; - }); - systems = [ "plump-dom" ]; - lispLibs = [ (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - plump-lexer = (build-asdf-system { - pname = "plump-lexer"; - version = "20241012-git"; - asds = [ "plump-lexer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/plump/2024-10-12/plump-20241012-git.tgz"; - sha256 = "04wy2v69zal186gg0pvcj60184gi7cpkpx3h1w93c9nilmla0dv9"; - system = "plump-lexer"; - asd = "plump-lexer"; - }); - systems = [ "plump-lexer" ]; - lispLibs = [ (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - plump-parser = (build-asdf-system { - pname = "plump-parser"; - version = "20241012-git"; - asds = [ "plump-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/plump/2024-10-12/plump-20241012-git.tgz"; - sha256 = "04wy2v69zal186gg0pvcj60184gi7cpkpx3h1w93c9nilmla0dv9"; - system = "plump-parser"; - asd = "plump-parser"; - }); - systems = [ "plump-parser" ]; - lispLibs = [ (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - plump-sexp = (build-asdf-system { - pname = "plump-sexp"; - version = "20241012-git"; - asds = [ "plump-sexp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/plump-sexp/2024-10-12/plump-sexp-20241012-git.tgz"; - sha256 = "19gihmsbwv42zwyc4rd1pcvj5yzf1vnhpci7r5kz1dnrmz9gzy3l"; - system = "plump-sexp"; - asd = "plump-sexp"; - }); - systems = [ "plump-sexp" ]; - lispLibs = [ (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - plump-tex = (build-asdf-system { - pname = "plump-tex"; - version = "20231021-git"; - asds = [ "plump-tex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/plump-tex/2023-10-21/plump-tex-20231021-git.tgz"; - sha256 = "1k0cmk5sbn042bx7nxiw0rvsjmgmj221zim1hg23r0485jbx0r3h"; - system = "plump-tex"; - asd = "plump-tex"; - }); - systems = [ "plump-tex" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - plump-tex-test = (build-asdf-system { - pname = "plump-tex-test"; - version = "20231021-git"; - asds = [ "plump-tex-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/plump-tex/2023-10-21/plump-tex-20231021-git.tgz"; - sha256 = "1k0cmk5sbn042bx7nxiw0rvsjmgmj221zim1hg23r0485jbx0r3h"; - system = "plump-tex-test"; - asd = "plump-tex-test"; - }); - systems = [ "plump-tex-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "plump-tex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - png = (build-asdf-system { - pname = "png"; - version = "20211020-git"; - asds = [ "png" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-png/2021-10-20/cl-png-20211020-git.tgz"; - sha256 = "17xcb9ps5vf3if61blmx7cpfrz3gsw7jk8d5zv3f4cq8jrriqdx4"; - system = "png"; - asd = "png"; - }); - systems = [ "png" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - png-read = (build-asdf-system { - pname = "png-read"; - version = "20170830-git"; - asds = [ "png-read" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/png-read/2017-08-30/png-read-20170830-git.tgz"; - sha256 = "0vyczbcwskrygrf1hgrsnk0jil8skmvf1kiaalw5jps4fjrfdkw0"; - system = "png-read"; - asd = "png-read"; - }); - systems = [ "png-read" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "chipz" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - png-test = (build-asdf-system { - pname = "png-test"; - version = "20211020-git"; - asds = [ "png-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-png/2021-10-20/cl-png-20211020-git.tgz"; - sha256 = "17xcb9ps5vf3if61blmx7cpfrz3gsw7jk8d5zv3f4cq8jrriqdx4"; - system = "png-test"; - asd = "png-test"; - }); - systems = [ "png-test" ]; - lispLibs = [ (getAttr "png" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pngload = (build-asdf-system { - pname = "pngload"; - version = "20241012-git"; - asds = [ "pngload" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pngload/2024-10-12/pngload-20241012-git.tgz"; - sha256 = "1j5j8n8xa8hgc413lfxij3wmkwyal13p0a5q6n74zzr61f1kn6vc"; - system = "pngload"; - asd = "pngload"; - }); - systems = [ "pngload" ]; - lispLibs = [ (getAttr "_3bz" self) (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "mmap" self) (getAttr "parse-float" self) (getAttr "static-vectors" self) (getAttr "swap-bytes" self) (getAttr "zpb-exif" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pngload_dot_test = (build-asdf-system { - pname = "pngload.test"; - version = "20241012-git"; - asds = [ "pngload.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pngload/2024-10-12/pngload-20241012-git.tgz"; - sha256 = "1j5j8n8xa8hgc413lfxij3wmkwyal13p0a5q6n74zzr61f1kn6vc"; - system = "pngload.test"; - asd = "pngload.test"; - }); - systems = [ "pngload.test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "local-time" self) (getAttr "opticl" self) (getAttr "png-read" self) (getAttr "pngload" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - poler = (build-asdf-system { - pname = "poler"; - version = "20181210-git"; - asds = [ "poler" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/poler/2018-12-10/poler-20181210-git.tgz"; - sha256 = "1lcyjxmz5vm5is1kgxqjvpkllywvbsj6wqx5v2ac0py5vqws1l8z"; - system = "poler"; - asd = "poler"; - }); - systems = [ "poler" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - poler-test = (build-asdf-system { - pname = "poler-test"; - version = "20181210-git"; - asds = [ "poler-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/poler/2018-12-10/poler-20181210-git.tgz"; - sha256 = "1lcyjxmz5vm5is1kgxqjvpkllywvbsj6wqx5v2ac0py5vqws1l8z"; - system = "poler-test"; - asd = "poler-test"; - }); - systems = [ "poler-test" ]; - lispLibs = [ (getAttr "poler" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - policy-cond = (build-asdf-system { - pname = "policy-cond"; - version = "20241012-git"; - asds = [ "policy-cond" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/policy-cond/2024-10-12/policy-cond-20241012-git.tgz"; - sha256 = "17gm4alfb8nf85963ckahipx61xfffj0ra2cnn6yra32krzj7gnk"; - system = "policy-cond"; - asd = "policy-cond"; - }); - systems = [ "policy-cond" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - polisher = (build-asdf-system { - pname = "polisher"; - version = "20211230-git"; - asds = [ "polisher" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/polisher/2021-12-30/polisher-20211230-git.tgz"; - sha256 = "1i63kgk4vfisiyrfqdz0wc8ldvfh9jpkivsasgdhc97cad095ln0"; - system = "polisher"; - asd = "polisher"; - }); - systems = [ "polisher" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - polisher_dot_test = (build-asdf-system { - pname = "polisher.test"; - version = "20211230-git"; - asds = [ "polisher.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/polisher/2021-12-30/polisher-20211230-git.tgz"; - sha256 = "1i63kgk4vfisiyrfqdz0wc8ldvfh9jpkivsasgdhc97cad095ln0"; - system = "polisher.test"; - asd = "polisher.test"; - }); - systems = [ "polisher.test" ]; - lispLibs = [ (getAttr "_1am" self) (getAttr "polisher" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - polymorphic-functions-lite = (build-asdf-system { - pname = "polymorphic-functions-lite"; - version = "20241012-git"; - asds = [ "polymorphic-functions-lite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/polymorphic-functions/2024-10-12/polymorphic-functions-20241012-git.tgz"; - sha256 = "1bawhbj5rh1q6qrcjnx48n78841mgri5n63pmicxxyhif2il0zq3"; - system = "polymorphic-functions-lite"; - asd = "polymorphic-functions-lite"; - }); - systems = [ "polymorphic-functions-lite" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "fiveam" self) (getAttr "introspect-environment" self) (getAttr "optima" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pooler = (build-asdf-system { - pname = "pooler"; - version = "20150608-git"; - asds = [ "pooler" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pooler/2015-06-08/pooler-20150608-git.tgz"; - sha256 = "18vdl06cckk07m7r477qzcz24j3sid1agfa69fp91jna5aqi46kb"; - system = "pooler"; - asd = "pooler"; - }); - systems = [ "pooler" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - portable-condition-system = (build-asdf-system { - pname = "portable-condition-system"; - version = "20210807-git"; - asds = [ "portable-condition-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/portable-condition-system/2021-08-07/portable-condition-system-20210807-git.tgz"; - sha256 = "099lb9f4bavj95wik99wla5rf6fk1gdw9pvn0cqlaf0wf20csd3h"; - system = "portable-condition-system"; - asd = "portable-condition-system"; - }); - systems = [ "portable-condition-system" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - portable-condition-system_dot_integration = (build-asdf-system { - pname = "portable-condition-system.integration"; - version = "20210807-git"; - asds = [ "portable-condition-system.integration" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/portable-condition-system/2021-08-07/portable-condition-system-20210807-git.tgz"; - sha256 = "099lb9f4bavj95wik99wla5rf6fk1gdw9pvn0cqlaf0wf20csd3h"; - system = "portable-condition-system.integration"; - asd = "portable-condition-system.integration"; - }); - systems = [ "portable-condition-system.integration" ]; - lispLibs = [ (getAttr "portable-condition-system" self) (getAttr "trivial-custom-debugger" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - portable-threads = (build-asdf-system { - pname = "portable-threads"; - version = "20210531-git"; - asds = [ "portable-threads" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/portable-threads/2021-05-31/portable-threads-20210531-git.tgz"; - sha256 = "05y00mlvwlfas4jj50qas2v2rxa0hyc9834lpnbh61a3g8sz0d1f"; - system = "portable-threads"; - asd = "portable-threads"; - }); - systems = [ "portable-threads" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - portal = (build-asdf-system { - pname = "portal"; - version = "20211209-git"; - asds = [ "portal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/portal/2021-12-09/portal-20211209-git.tgz"; - sha256 = "1012jc068qdd8df6mmbn8vmmqlniqm5j2jbyrraw3yz8c13c8280"; - system = "portal"; - asd = "portal"; - }); - systems = [ "portal" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "arrows" self) (getAttr "cl-base64" self) (getAttr "flexi-streams" self) (getAttr "global-vars" self) (getAttr "ironclad" self) (getAttr "parse-float" self) (getAttr "str" self) (getAttr "usocket-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - portmanteau = (build-asdf-system { - pname = "portmanteau"; - version = "20181018-git"; - asds = [ "portmanteau" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-portmanteau/2018-10-18/cl-portmanteau-20181018-git.tgz"; - sha256 = "0430yixy722zkiljc6kh68hx2pyf2pbylgyp7n4qnnky86c0z0ip"; - system = "portmanteau"; - asd = "portmanteau"; - }); - systems = [ "portmanteau" ]; - lispLibs = [ (getAttr "vom" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - portmanteau-tests = (build-asdf-system { - pname = "portmanteau-tests"; - version = "20181018-git"; - asds = [ "portmanteau-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-portmanteau/2018-10-18/cl-portmanteau-20181018-git.tgz"; - sha256 = "0430yixy722zkiljc6kh68hx2pyf2pbylgyp7n4qnnky86c0z0ip"; - system = "portmanteau-tests"; - asd = "portmanteau-tests"; - }); - systems = [ "portmanteau-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "portmanteau" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - positional-lambda = (build-asdf-system { - pname = "positional-lambda"; - version = "2.0"; - asds = [ "positional-lambda" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/positional-lambda/2012-10-13/positional-lambda-2.0.tgz"; - sha256 = "00jbr42czv7piza5sm5hmmls7xnhq1pnzl09j6c28xrknr61cj8r"; - system = "positional-lambda"; - asd = "positional-lambda"; - }); - systems = [ "positional-lambda" ]; - lispLibs = [ (getAttr "map-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - posix-shm = (build-asdf-system { - pname = "posix-shm"; - version = "20231021-git"; - asds = [ "posix-shm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/posix-shm/2023-10-21/posix-shm-20231021-git.tgz"; - sha256 = "0ah7xh7dxvdk58slic60gx7k56idjw5x30q5ifg90hxfhd32qz6l"; - system = "posix-shm"; - asd = "posix-shm"; - }); - systems = [ "posix-shm" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - postmodern = (build-asdf-system { - pname = "postmodern"; - version = "20241012-git"; - asds = [ "postmodern" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/postmodern/2024-10-12/postmodern-20241012-git.tgz"; - sha256 = "1hj0dpclzihy1rcnwhiv16abmaa54wygxyib3j2h9q4qs26w7pzb"; - system = "postmodern"; - asd = "postmodern"; - }); - systems = [ "postmodern" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-postgres" self) (getAttr "closer-mop" self) (getAttr "global-vars" self) (getAttr "s-sql" self) (getAttr "split-sequence" self) ]; - meta = {}; - }); - postmodernity = (build-asdf-system { - pname = "postmodernity"; - version = "20170124-git"; - asds = [ "postmodernity" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/postmodernity/2017-01-24/postmodernity-20170124-git.tgz"; - sha256 = "06mwlp79dgzsgfhgbhvqk4691nm52v3lqm99y72dm7pm4gmc2m9m"; - system = "postmodernity"; - asd = "postmodernity"; - }); - systems = [ "postmodernity" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "postmodern" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - postoffice = (build-asdf-system { - pname = "postoffice"; - version = "20120909-git"; - asds = [ "postoffice" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/postoffice/2012-09-09/postoffice-20120909-git.tgz"; - sha256 = "041k8nc969xyjdmbn6348pra3v5jb1sw4mrnxmamv0flngyv12fg"; - system = "postoffice"; - asd = "postoffice"; - }); - systems = [ "postoffice" ]; - lispLibs = [ (getAttr "acl-compat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pounds = (build-asdf-system { - pname = "pounds"; - version = "20160208-git"; - asds = [ "pounds" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pounds/2016-02-08/pounds-20160208-git.tgz"; - sha256 = "17hz0ywzfirmlwkrd9zrbl07ihhm03zhzqrz3rkmh1j9v95sy2kl"; - system = "pounds"; - asd = "pounds"; - }); - systems = [ "pounds" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "nibbles" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pp-toml = (build-asdf-system { - pname = "pp-toml"; - version = "20221106-git"; - asds = [ "pp-toml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pp-toml/2022-11-06/pp-toml-20221106-git.tgz"; - sha256 = "136d7jzz7l2ck9wwld0ac46jmpm94lvja6m50sy73s232slka2hg"; - system = "pp-toml"; - asd = "pp-toml"; - }); - systems = [ "pp-toml" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "esrap" self) (getAttr "generic-comparability" self) (getAttr "local-time" self) (getAttr "parse-number" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pp-toml-tests = (build-asdf-system { - pname = "pp-toml-tests"; - version = "20221106-git"; - asds = [ "pp-toml-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pp-toml/2022-11-06/pp-toml-20221106-git.tgz"; - sha256 = "136d7jzz7l2ck9wwld0ac46jmpm94lvja6m50sy73s232slka2hg"; - system = "pp-toml-tests"; - asd = "pp-toml-tests"; - }); - systems = [ "pp-toml-tests" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "esrap" self) (getAttr "fiveam" self) (getAttr "generic-comparability" self) (getAttr "local-time" self) (getAttr "parse-number" self) (getAttr "pp-toml" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ppath = (build-asdf-system { - pname = "ppath"; - version = "20241012-git"; - asds = [ "ppath" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ppath/2024-10-12/ppath-20241012-git.tgz"; - sha256 = "122h2xlr9435gjim567cyry13ylbsixziy5bi1n4lzpfjnkq68qg"; - system = "ppath"; - asd = "ppath"; - }); - systems = [ "ppath" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-ppcre" self) (getAttr "osicat" self) (getAttr "split-sequence" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ppath-test = (build-asdf-system { - pname = "ppath-test"; - version = "20241012-git"; - asds = [ "ppath-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ppath/2024-10-12/ppath-20241012-git.tgz"; - sha256 = "122h2xlr9435gjim567cyry13ylbsixziy5bi1n4lzpfjnkq68qg"; - system = "ppath-test"; - asd = "ppath-test"; - }); - systems = [ "ppath-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fad" self) (getAttr "ppath" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - practical-cl = (build-asdf-system { - pname = "practical-cl"; - version = "20180430-git"; - asds = [ "practical-cl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; - sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; - system = "practical-cl"; - asd = "practical-cl"; - }); - systems = [ "practical-cl" ]; - lispLibs = [ (getAttr "pcl-binary-data" self) (getAttr "pcl-html" self) (getAttr "pcl-id3v2" self) (getAttr "pcl-macro-utilities" self) (getAttr "pcl-mp3-browser" self) (getAttr "pcl-mp3-database" self) (getAttr "pcl-pathnames" self) (getAttr "pcl-shoutcast" self) (getAttr "pcl-simple-database" self) (getAttr "pcl-spam" self) (getAttr "pcl-test-framework" self) (getAttr "pcl-url-function" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prbs = (build-asdf-system { - pname = "prbs"; - version = "20180228-git"; - asds = [ "prbs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prbs/2018-02-28/prbs-20180228-git.tgz"; - sha256 = "0qbvbmxa66b367z9px4nyxqb21b9w2hr82rw7hfq5aynmwfk3fzi"; - system = "prbs"; - asd = "prbs"; - }); - systems = [ "prbs" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prbs-docs = (build-asdf-system { - pname = "prbs-docs"; - version = "20180228-git"; - asds = [ "prbs-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prbs/2018-02-28/prbs-20180228-git.tgz"; - sha256 = "0qbvbmxa66b367z9px4nyxqb21b9w2hr82rw7hfq5aynmwfk3fzi"; - system = "prbs-docs"; - asd = "prbs-docs"; - }); - systems = [ "prbs-docs" ]; - lispLibs = [ (getAttr "cl-gendoc" self) (getAttr "prbs" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - precise-time = (build-asdf-system { - pname = "precise-time"; - version = "20241012-git"; - asds = [ "precise-time" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/precise-time/2024-10-12/precise-time-20241012-git.tgz"; - sha256 = "114ix5nldfg301g0af8lsnc129i7hnhgdzmnznda2fv92zf3vn8g"; - system = "precise-time"; - asd = "precise-time"; - }); - systems = [ "precise-time" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pregexp = (build-asdf-system { - pname = "pregexp"; - version = "20241012-git"; - asds = [ "pregexp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pregexp/2024-10-12/pregexp-20241012-git.tgz"; - sha256 = "10l9hj7a812km1hygg6iwwl1bf8jgsfyfr1ixj7bif8k8502h4nz"; - system = "pregexp"; - asd = "pregexp"; - }); - systems = [ "pregexp" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prepl = (build-asdf-system { - pname = "prepl"; - version = "20231021-git"; - asds = [ "prepl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prepl/2023-10-21/prepl-20231021-git.tgz"; - sha256 = "0sbqlqbk9xrl30iklp3vs493zq4bc2nxv6q435cspicwz6igbjdw"; - system = "prepl"; - asd = "prepl"; - }); - systems = [ "prepl" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "conium" self) (getAttr "iterate" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prettier-builtins = (build-asdf-system { - pname = "prettier-builtins"; - version = "20231021-git"; - asds = [ "prettier-builtins" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prettier-builtins/2023-10-21/prettier-builtins-20231021-git.tgz"; - sha256 = "15lbf0zi1vxqpxwsfgkq7dlg5c9m1b2a4hvcfm3qlh9ir7ahggck"; - system = "prettier-builtins"; - asd = "prettier-builtins"; - }); - systems = [ "prettier-builtins" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pretty-function = (build-asdf-system { - pname = "pretty-function"; - version = "20130615-git"; - asds = [ "pretty-function" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pretty-function/2013-06-15/pretty-function-20130615-git.tgz"; - sha256 = "1hzfjwsp6r5nki6h8kry8k2bgj19mrp0jbq7jhsz3kz6y4ll0hb5"; - system = "pretty-function"; - asd = "pretty-function"; - }); - systems = [ "pretty-function" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - primecount = (build-asdf-system { - pname = "primecount"; - version = "20200325-git"; - asds = [ "primecount" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/primecount/2020-03-25/primecount-20200325-git.tgz"; - sha256 = "1fw855qp82b887azww7z3yhd2zafaxjnzyff1ldf2wa6mb4f0dj8"; - system = "primecount"; - asd = "primecount"; - }); - systems = [ "primecount" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - print-html = (build-asdf-system { - pname = "print-html"; - version = "20181018-git"; - asds = [ "print-html" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/print-html/2018-10-18/print-html-20181018-git.tgz"; - sha256 = "1ihr2yy6fvli3awrkfn4v8pm41wab5wsj30v84rr75v4p5irqmz8"; - system = "print-html"; - asd = "print-html"; - }); - systems = [ "print-html" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - print-licenses = (build-asdf-system { - pname = "print-licenses"; - version = "20230618-git"; - asds = [ "print-licenses" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/print-licenses/2023-06-18/print-licenses-20230618-git.tgz"; - sha256 = "14i6r6mf16dlj1g4xk0alg2912y3wy0qbfpyvvgsgxkkar63cmi5"; - system = "print-licenses"; - asd = "print-licenses"; - }); - systems = [ "print-licenses" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - printv = (build-asdf-system { - pname = "printv"; - version = "20211230-git"; - asds = [ "printv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/printv/2021-12-30/printv-20211230-git.tgz"; - sha256 = "07agyzkwp3w2r4d2anrmr8h00yngpr5dq9mjd3m4kzhn1jcmilfb"; - system = "printv"; - asd = "printv"; - }); - systems = [ "printv" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - priority-queue = (build-asdf-system { - pname = "priority-queue"; - version = "20150709-git"; - asds = [ "priority-queue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/priority-queue/2015-07-09/priority-queue-20150709-git.tgz"; - sha256 = "0y5a1fid8xzzl58hfdj64n8mrzq0kr06a0lnmdjpgi0czc3x0jcy"; - system = "priority-queue"; - asd = "priority-queue"; - }); - systems = [ "priority-queue" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - priority-queue-benchmark = (build-asdf-system { - pname = "priority-queue-benchmark"; - version = "20241012-git"; - asds = [ "priority-queue-benchmark" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/damn-fast-priority-queue/2024-10-12/damn-fast-priority-queue-20241012-git.tgz"; - sha256 = "1mbigpgi7qbqvpj59l1f7p2qcg00ybvqzdca1j1b9hx62h224ndw"; - system = "priority-queue-benchmark"; - asd = "priority-queue-benchmark"; - }); - systems = [ "priority-queue-benchmark" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bodge-heap" self) (getAttr "cl-heap" self) (getAttr "damn-fast-priority-queue" self) (getAttr "damn-fast-stable-priority-queue" self) (getAttr "heap" self) (getAttr "minheap" self) (getAttr "pettomato-indexed-priority-queue" self) (getAttr "pileup" self) (getAttr "priority-queue" self) (getAttr "queues_dot_priority-queue" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - proc-parse = (build-asdf-system { - pname = "proc-parse"; - version = "20190813-git"; - asds = [ "proc-parse" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/proc-parse/2019-08-13/proc-parse-20190813-git.tgz"; - sha256 = "07vbj26bfq4ywlcmamsqyac29rsdsa8lamjqx1ycla1bcvgmi4w2"; - system = "proc-parse"; - asd = "proc-parse"; - }); - systems = [ "proc-parse" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) ]; - meta = {}; - }); - proc-parse-test = (build-asdf-system { - pname = "proc-parse-test"; - version = "20190813-git"; - asds = [ "proc-parse-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/proc-parse/2019-08-13/proc-parse-20190813-git.tgz"; - sha256 = "07vbj26bfq4ywlcmamsqyac29rsdsa8lamjqx1ycla1bcvgmi4w2"; - system = "proc-parse-test"; - asd = "proc-parse-test"; - }); - systems = [ "proc-parse-test" ]; - lispLibs = [ (getAttr "proc-parse" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - progressons = (build-asdf-system { - pname = "progressons"; - version = "20241012-git"; - asds = [ "progressons" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/progressons/2024-10-12/progressons-20241012-git.tgz"; - sha256 = "1i93khd0l1aphzh6qb4yy9cpi2nmqac08b90yx95p4zymap03nly"; - system = "progressons"; - asd = "progressons"; - }); - systems = [ "progressons" ]; - lispLibs = [ (getAttr "cl-ansi-text" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - projectured_dot_document = (build-asdf-system { - pname = "projectured.document"; - version = "quicklisp-c3a60e76-git"; - asds = [ "projectured.document" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; - sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; - system = "projectured.document"; - asd = "projectured.document"; - }); - systems = [ "projectured.document" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "parse-number" self) (getAttr "projectured_dot_editor" self) (getAttr "s-xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - projectured_dot_editor = (build-asdf-system { - pname = "projectured.editor"; - version = "quicklisp-c3a60e76-git"; - asds = [ "projectured.editor" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; - sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; - system = "projectured.editor"; - asd = "projectured.editor"; - }); - systems = [ "projectured.editor" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_common" self) (getAttr "hu_dot_dwim_dot_def" self) (getAttr "hu_dot_dwim_dot_defclass-star" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_serializer" self) (getAttr "hu_dot_dwim_dot_syntax-sugar" self) (getAttr "hu_dot_dwim_dot_util" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - projectured_dot_executable = (build-asdf-system { - pname = "projectured.executable"; - version = "quicklisp-c3a60e76-git"; - asds = [ "projectured.executable" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; - sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; - system = "projectured.executable"; - asd = "projectured.executable"; - }); - systems = [ "projectured.executable" ]; - lispLibs = [ (getAttr "command-line-arguments" self) (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "projectured_dot_sdl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - projectured_dot_projection = (build-asdf-system { - pname = "projectured.projection"; - version = "quicklisp-c3a60e76-git"; - asds = [ "projectured.projection" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; - sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; - system = "projectured.projection"; - asd = "projectured.projection"; - }); - systems = [ "projectured.projection" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "projectured_dot_document" self) (getAttr "projectured_dot_editor" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - projectured_dot_sdl = (build-asdf-system { - pname = "projectured.sdl"; - version = "quicklisp-c3a60e76-git"; - asds = [ "projectured.sdl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; - sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; - system = "projectured.sdl"; - asd = "projectured.sdl"; - }); - systems = [ "projectured.sdl" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_sdl" self) (getAttr "projectured_dot_document" self) (getAttr "projectured_dot_editor" self) (getAttr "projectured_dot_projection" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - projectured_dot_sdl_dot_test = (build-asdf-system { - pname = "projectured.sdl.test"; - version = "quicklisp-c3a60e76-git"; - asds = [ "projectured.sdl.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; - sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; - system = "projectured.sdl.test"; - asd = "projectured.sdl.test"; - }); - systems = [ "projectured.sdl.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "projectured_dot_sdl" self) (getAttr "projectured_dot_test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - projectured_dot_swank = (build-asdf-system { - pname = "projectured.swank"; - version = "quicklisp-c3a60e76-git"; - asds = [ "projectured.swank" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; - sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; - system = "projectured.swank"; - asd = "projectured.swank"; - }); - systems = [ "projectured.swank" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "projectured_dot_editor" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - projectured_dot_test = (build-asdf-system { - pname = "projectured.test"; - version = "quicklisp-c3a60e76-git"; - asds = [ "projectured.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; - sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; - system = "projectured.test"; - asd = "projectured.test"; - }); - systems = [ "projectured.test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) (getAttr "hu_dot_dwim_dot_logger" self) (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) (getAttr "projectured_dot_document" self) (getAttr "projectured_dot_editor" self) (getAttr "projectured_dot_projection" self) (getAttr "projectured_dot_swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus = (build-asdf-system { - pname = "prometheus"; - version = "20201220-git"; - asds = [ "prometheus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus"; - asd = "prometheus"; - }); - systems = [ "prometheus" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "local-time" self) (getAttr "quantile-estimator" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus-gc = (build-asdf-system { - pname = "prometheus-gc"; - version = "20241012-git"; - asds = [ "prometheus-gc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus-gc/2024-10-12/prometheus-gc-20241012-git.tgz"; - sha256 = "0lfdh7j7jzklhr76fdw1z3a777h5sr5c9h1i6nv1knnm36l44zpj"; - system = "prometheus-gc"; - asd = "prometheus-gc"; - }); - systems = [ "prometheus-gc" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "prometheus" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus-gc-ci = (build-asdf-system { - pname = "prometheus-gc-ci"; - version = "20241012-git"; - asds = [ "prometheus-gc-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus-gc/2024-10-12/prometheus-gc-20241012-git.tgz"; - sha256 = "0lfdh7j7jzklhr76fdw1z3a777h5sr5c9h1i6nv1knnm36l44zpj"; - system = "prometheus-gc-ci"; - asd = "prometheus-gc-ci"; - }); - systems = [ "prometheus-gc-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus-gc-tests = (build-asdf-system { - pname = "prometheus-gc-tests"; - version = "20241012-git"; - asds = [ "prometheus-gc-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus-gc/2024-10-12/prometheus-gc-20241012-git.tgz"; - sha256 = "0lfdh7j7jzklhr76fdw1z3a777h5sr5c9h1i6nv1knnm36l44zpj"; - system = "prometheus-gc-tests"; - asd = "prometheus-gc-tests"; - }); - systems = [ "prometheus-gc-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_collectors_dot_process = (build-asdf-system { - pname = "prometheus.collectors.process"; - version = "20201220-git"; - asds = [ "prometheus.collectors.process" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.collectors.process"; - asd = "prometheus.collectors.process"; - }); - systems = [ "prometheus.collectors.process" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-fad" self) (getAttr "prometheus" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_collectors_dot_process_dot_test = (build-asdf-system { - pname = "prometheus.collectors.process.test"; - version = "20201220-git"; - asds = [ "prometheus.collectors.process.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.collectors.process.test"; - asd = "prometheus.collectors.process.test"; - }); - systems = [ "prometheus.collectors.process.test" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "log4cl" self) (getAttr "mw-equiv" self) (getAttr "prometheus_dot_collectors_dot_process" self) (getAttr "prometheus_dot_test_dot_support" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_collectors_dot_sbcl = (build-asdf-system { - pname = "prometheus.collectors.sbcl"; - version = "20201220-git"; - asds = [ "prometheus.collectors.sbcl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.collectors.sbcl"; - asd = "prometheus.collectors.sbcl"; - }); - systems = [ "prometheus.collectors.sbcl" ]; - lispLibs = [ (getAttr "prometheus" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_collectors_dot_sbcl_dot_test = (build-asdf-system { - pname = "prometheus.collectors.sbcl.test"; - version = "20201220-git"; - asds = [ "prometheus.collectors.sbcl.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.collectors.sbcl.test"; - asd = "prometheus.collectors.sbcl.test"; - }); - systems = [ "prometheus.collectors.sbcl.test" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "log4cl" self) (getAttr "mw-equiv" self) (getAttr "prometheus_dot_collectors_dot_sbcl" self) (getAttr "prometheus_dot_test_dot_support" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_examples = (build-asdf-system { - pname = "prometheus.examples"; - version = "20201220-git"; - asds = [ "prometheus.examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.examples"; - asd = "prometheus.examples"; - }); - systems = [ "prometheus.examples" ]; - lispLibs = [ (getAttr "prometheus" self) (getAttr "prometheus_dot_collectors_dot_process" self) (getAttr "prometheus_dot_collectors_dot_sbcl" self) (getAttr "prometheus_dot_exposers_dot_hunchentoot" self) (getAttr "prometheus_dot_formats_dot_text" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_exposers_dot_hunchentoot = (build-asdf-system { - pname = "prometheus.exposers.hunchentoot"; - version = "20201220-git"; - asds = [ "prometheus.exposers.hunchentoot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.exposers.hunchentoot"; - asd = "prometheus.exposers.hunchentoot"; - }); - systems = [ "prometheus.exposers.hunchentoot" ]; - lispLibs = [ (getAttr "hunchentoot" self) (getAttr "prometheus" self) (getAttr "prometheus_dot_formats_dot_text" self) (getAttr "salza2" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_exposers_dot_hunchentoot_dot_test = (build-asdf-system { - pname = "prometheus.exposers.hunchentoot.test"; - version = "20201220-git"; - asds = [ "prometheus.exposers.hunchentoot.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.exposers.hunchentoot.test"; - asd = "prometheus.exposers.hunchentoot.test"; - }); - systems = [ "prometheus.exposers.hunchentoot.test" ]; - lispLibs = [ (getAttr "chipz" self) (getAttr "cl-interpol" self) (getAttr "drakma" self) (getAttr "log4cl" self) (getAttr "mw-equiv" self) (getAttr "prometheus_dot_exposers_dot_hunchentoot" self) (getAttr "prometheus_dot_formats_dot_text" self) (getAttr "prometheus_dot_test_dot_support" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_formats_dot_text = (build-asdf-system { - pname = "prometheus.formats.text"; - version = "20201220-git"; - asds = [ "prometheus.formats.text" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.formats.text"; - asd = "prometheus.formats.text"; - }); - systems = [ "prometheus.formats.text" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "prometheus" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_formats_dot_text_dot_test = (build-asdf-system { - pname = "prometheus.formats.text.test"; - version = "20201220-git"; - asds = [ "prometheus.formats.text.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.formats.text.test"; - asd = "prometheus.formats.text.test"; - }); - systems = [ "prometheus.formats.text.test" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "log4cl" self) (getAttr "mw-equiv" self) (getAttr "prometheus_dot_formats_dot_text" self) (getAttr "prometheus_dot_test_dot_support" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_pushgateway = (build-asdf-system { - pname = "prometheus.pushgateway"; - version = "20201220-git"; - asds = [ "prometheus.pushgateway" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.pushgateway"; - asd = "prometheus.pushgateway"; - }); - systems = [ "prometheus.pushgateway" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "prometheus" self) (getAttr "prometheus_dot_formats_dot_text" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_pushgateway_dot_test = (build-asdf-system { - pname = "prometheus.pushgateway.test"; - version = "20201220-git"; - asds = [ "prometheus.pushgateway.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.pushgateway.test"; - asd = "prometheus.pushgateway.test"; - }); - systems = [ "prometheus.pushgateway.test" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "hunchentoot" self) (getAttr "log4cl" self) (getAttr "mw-equiv" self) (getAttr "prometheus_dot_pushgateway" self) (getAttr "prometheus_dot_test_dot_support" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_test = (build-asdf-system { - pname = "prometheus.test"; - version = "20201220-git"; - asds = [ "prometheus.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.test"; - asd = "prometheus.test"; - }); - systems = [ "prometheus.test" ]; - lispLibs = [ (getAttr "cl-interpol" self) (getAttr "log4cl" self) (getAttr "mw-equiv" self) (getAttr "prometheus" self) (getAttr "prometheus_dot_test_dot_support" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_test_dot_all = (build-asdf-system { - pname = "prometheus.test.all"; - version = "20201220-git"; - asds = [ "prometheus.test.all" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.test.all"; - asd = "prometheus.test.all"; - }); - systems = [ "prometheus.test.all" ]; - lispLibs = [ (getAttr "cl-coveralls" self) (getAttr "prometheus_dot_collectors_dot_process_dot_test" self) (getAttr "prometheus_dot_collectors_dot_sbcl_dot_test" self) (getAttr "prometheus_dot_exposers_dot_hunchentoot_dot_test" self) (getAttr "prometheus_dot_formats_dot_text_dot_test" self) (getAttr "prometheus_dot_pushgateway_dot_test" self) (getAttr "prometheus_dot_test" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prometheus_dot_test_dot_support = (build-asdf-system { - pname = "prometheus.test.support"; - version = "20201220-git"; - asds = [ "prometheus.test.support" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; - sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; - system = "prometheus.test.support"; - asd = "prometheus.test.support"; - }); - systems = [ "prometheus.test.support" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "prometheus" self) (getAttr "prove" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - promise = (build-asdf-system { - pname = "promise"; - version = "20231021-git"; - asds = [ "promise" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/promise/2023-10-21/promise-20231021-git.tgz"; - sha256 = "1xm10s89a2f7ydzayjgg94y9plrz1jnyvi6yzhk5v3vrbnmpggh1"; - system = "promise"; - asd = "promise"; - }); - systems = [ "promise" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - promise-test = (build-asdf-system { - pname = "promise-test"; - version = "20231021-git"; - asds = [ "promise-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/promise/2023-10-21/promise-20231021-git.tgz"; - sha256 = "1xm10s89a2f7ydzayjgg94y9plrz1jnyvi6yzhk5v3vrbnmpggh1"; - system = "promise-test"; - asd = "promise-test"; - }); - systems = [ "promise-test" ]; - lispLibs = [ (getAttr "parachute" self) (getAttr "promise" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prompt-for = (build-asdf-system { - pname = "prompt-for"; - version = "20220707-git"; - asds = [ "prompt-for" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prompt-for/2022-07-07/prompt-for-20220707-git.tgz"; - sha256 = "1zjc96ryyzsr5519s7yji40askqyymjrbdwx3r2r7bv146siqs5m"; - system = "prompt-for"; - asd = "prompt-for"; - }); - systems = [ "prompt-for" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prompt-for_dot_test = (build-asdf-system { - pname = "prompt-for.test"; - version = "20220707-git"; - asds = [ "prompt-for.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prompt-for/2022-07-07/prompt-for-20220707-git.tgz"; - sha256 = "1zjc96ryyzsr5519s7yji40askqyymjrbdwx3r2r7bv146siqs5m"; - system = "prompt-for.test"; - asd = "prompt-for.test"; - }); - systems = [ "prompt-for.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "prompt-for" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - protest = (build-asdf-system { - pname = "protest"; - version = "20201220-git"; - asds = [ "protest" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/protest/2020-12-20/protest-20201220-git.tgz"; - sha256 = "0q7vk7ji4mjd0xfp18sim5daqzgb3k7mmbm93vvwz18bdwy6cj9h"; - system = "protest"; - asd = "protest"; - }); - systems = [ "protest" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "moptilities" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - proto = (build-asdf-system { - pname = "proto"; - version = "quicklisp-dd18337d-git"; - asds = [ "proto" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gtirb/2021-10-20/gtirb-quicklisp-dd18337d-git.tgz"; - sha256 = "0dpchsshnlh3jb9rg1zdf63mr5l33vhjdxgxx2vqg0nh1sh41zn1"; - system = "proto"; - asd = "gtirb"; - }); - systems = [ "proto" ]; - lispLibs = [ (getAttr "protobuf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - proto-v0 = (build-asdf-system { - pname = "proto-v0"; - version = "quicklisp-dd18337d-git"; - asds = [ "proto-v0" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gtirb/2021-10-20/gtirb-quicklisp-dd18337d-git.tgz"; - sha256 = "0dpchsshnlh3jb9rg1zdf63mr5l33vhjdxgxx2vqg0nh1sh41zn1"; - system = "proto-v0"; - asd = "gtirb"; - }); - systems = [ "proto-v0" ]; - lispLibs = [ (getAttr "protobuf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - protobuf = (build-asdf-system { - pname = "protobuf"; - version = "20230618-git"; - asds = [ "protobuf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/protobuf/2023-06-18/protobuf-20230618-git.tgz"; - sha256 = "0pp8i2i72p6cng11sxj83klw45jqv05l5024h7c2rl0pvsg8f6bc"; - system = "protobuf"; - asd = "protobuf"; - }); - systems = [ "protobuf" ]; - lispLibs = [ (getAttr "com_dot_google_dot_base" self) (getAttr "varint" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - protobuf-conformance = (build-asdf-system { - pname = "protobuf-conformance"; - version = "20230618-git"; - asds = [ "protobuf-conformance" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/protobuf/2023-06-18/protobuf-20230618-git.tgz"; - sha256 = "0pp8i2i72p6cng11sxj83klw45jqv05l5024h7c2rl0pvsg8f6bc"; - system = "protobuf-conformance"; - asd = "protobuf-conformance"; - }); - systems = [ "protobuf-conformance" ]; - lispLibs = [ (getAttr "com_dot_google_dot_base" self) (getAttr "nibbles" self) (getAttr "protobuf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - prove = (build-asdf-system { - pname = "prove"; - version = "20200218-git"; - asds = [ "prove" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prove/2020-02-18/prove-20200218-git.tgz"; - sha256 = "0ca6ha3zhmckq3ad9lxm6sbg4i0hg3m81xhan4dkxd3x9898jzpc"; - system = "prove"; - asd = "prove"; - }); - systems = [ "prove" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ansi-text" self) (getAttr "cl-colors" self) (getAttr "cl-ppcre" self) ]; - meta = {}; - }); - prove-asdf = (build-asdf-system { - pname = "prove-asdf"; - version = "20200218-git"; - asds = [ "prove-asdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prove/2020-02-18/prove-20200218-git.tgz"; - sha256 = "0ca6ha3zhmckq3ad9lxm6sbg4i0hg3m81xhan4dkxd3x9898jzpc"; - system = "prove-asdf"; - asd = "prove-asdf"; - }); - systems = [ "prove-asdf" ]; - lispLibs = [ ]; - meta = {}; - }); - prove-test = (build-asdf-system { - pname = "prove-test"; - version = "20200218-git"; - asds = [ "prove-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/prove/2020-02-18/prove-20200218-git.tgz"; - sha256 = "0ca6ha3zhmckq3ad9lxm6sbg4i0hg3m81xhan4dkxd3x9898jzpc"; - system = "prove-test"; - asd = "prove-test"; - }); - systems = [ "prove-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pseudonyms = (build-asdf-system { - pname = "pseudonyms"; - version = "20200325-git"; - asds = [ "pseudonyms" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pseudonyms/2020-03-25/pseudonyms-20200325-git.tgz"; - sha256 = "0ph7l130hr8gz88gw8i15zbsbq96519srfhzgm6zzkw85vab1ysn"; - system = "pseudonyms"; - asd = "pseudonyms"; - }); - systems = [ "pseudonyms" ]; - lispLibs = [ (getAttr "named-readtables" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - psgraph = (build-asdf-system { - pname = "psgraph"; - version = "1.2"; - asds = [ "psgraph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/psgraph/2010-10-06/psgraph-1.2.tgz"; - sha256 = "19x1lvzfj2c2h83y5bng6jsp2300qfvd25mmf157qiss15al22vs"; - system = "psgraph"; - asd = "psgraph"; - }); - systems = [ "psgraph" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - psychiq = (build-asdf-system { - pname = "psychiq"; - version = "20241012-git"; - asds = [ "psychiq" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/psychiq/2024-10-12/psychiq-20241012-git.tgz"; - sha256 = "1036yyrzvyqszn037y4189h12221mkxdyp0nlyj26qjyil3qizbl"; - system = "psychiq"; - asd = "psychiq"; - }); - systems = [ "psychiq" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-redis" self) (getAttr "cl-reexport" self) (getAttr "dissect" self) (getAttr "jonathan" self) (getAttr "local-time" self) (getAttr "vom" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - psychiq-test = (build-asdf-system { - pname = "psychiq-test"; - version = "20241012-git"; - asds = [ "psychiq-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/psychiq/2024-10-12/psychiq-20241012-git.tgz"; - sha256 = "1036yyrzvyqszn037y4189h12221mkxdyp0nlyj26qjyil3qizbl"; - system = "psychiq-test"; - asd = "psychiq-test"; - }); - systems = [ "psychiq-test" ]; - lispLibs = [ (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "psychiq" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ptc = (build-asdf-system { - pname = "ptc"; - version = "20231021-git"; - asds = [ "ptc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ptc/2023-10-21/ptc-20231021-git.tgz"; - sha256 = "1r4izrc6dhz3pqpcqn3y0sga4f77s2vzd1xpl8fsr41rfpyiff3x"; - system = "ptc"; - asd = "ptc"; - }); - systems = [ "ptc" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ptester = (build-asdf-system { - pname = "ptester"; - version = "20160929-git"; - asds = [ "ptester" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ptester/2016-09-29/ptester-20160929-git.tgz"; - sha256 = "1l0lfl7cdnr2qf4zh38hi4llxg22c49zkm639bdkmvlkzwj3ndwf"; - system = "ptester"; - asd = "ptester"; - }); - systems = [ "ptester" ]; - lispLibs = [ ]; - meta = {}; - }); - punycode = (build-asdf-system { - pname = "punycode"; - version = "20231021-git"; - asds = [ "punycode" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/punycode/2023-10-21/punycode-20231021-git.tgz"; - sha256 = "0779aj2bqsz7qb475x5sacr5q254wjar74sab04zfhrlpkgij9xh"; - system = "punycode"; - asd = "punycode"; - }); - systems = [ "punycode" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - punycode-test = (build-asdf-system { - pname = "punycode-test"; - version = "20231021-git"; - asds = [ "punycode-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/punycode/2023-10-21/punycode-20231021-git.tgz"; - sha256 = "0779aj2bqsz7qb475x5sacr5q254wjar74sab04zfhrlpkgij9xh"; - system = "punycode-test"; - asd = "punycode-test"; - }); - systems = [ "punycode-test" ]; - lispLibs = [ (getAttr "parachute" self) (getAttr "punycode" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - purgatory = (build-asdf-system { - pname = "purgatory"; - version = "20241012-git"; - asds = [ "purgatory" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/purgatory/2024-10-12/purgatory-20241012-git.tgz"; - sha256 = "1srafcpl01a1dv84z3sqc1wl23r8hz1nm3rrmmqiilfh2r4jfw6f"; - system = "purgatory"; - asd = "purgatory"; - }); - systems = [ "purgatory" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-ppcre" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - purgatory-tests = (build-asdf-system { - pname = "purgatory-tests"; - version = "20241012-git"; - asds = [ "purgatory-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/purgatory/2024-10-12/purgatory-20241012-git.tgz"; - sha256 = "1srafcpl01a1dv84z3sqc1wl23r8hz1nm3rrmmqiilfh2r4jfw6f"; - system = "purgatory-tests"; - asd = "purgatory-tests"; - }); - systems = [ "purgatory-tests" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl_plus_ssl" self) (getAttr "cl-ppcre" self) (getAttr "clunit2" self) (getAttr "purgatory" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - puri = (build-asdf-system { - pname = "puri"; - version = "20201016-git"; - asds = [ "puri" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/puri/2020-10-16/puri-20201016-git.tgz"; - sha256 = "0gq2rsr0aihs0z20v4zqvmdl4szq53b52rh97pvnmwrlbn4mapmd"; - system = "puri"; - asd = "puri"; - }); - systems = [ "puri" ]; - lispLibs = [ ]; - meta = {}; - }); - purl = (build-asdf-system { - pname = "purl"; - version = "20160929-git"; - asds = [ "purl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/purl/2016-09-29/purl-20160929-git.tgz"; - sha256 = "1fw3ip4b7n3q6kimh683apg381p7y4w6s4mb8mmv9n3dw0p0sdww"; - system = "purl"; - asd = "purl"; - }); - systems = [ "purl" ]; - lispLibs = [ (getAttr "maxpc" self) (getAttr "percent-encoding" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pvars = (build-asdf-system { - pname = "pvars"; - version = "20210228-git"; - asds = [ "pvars" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pvars/2021-02-28/pvars-20210228-git.tgz"; - sha256 = "1x9mmz53sj0mgd288pa65x963mrd27sw47a8vbggsc4ykwacqf1d"; - system = "pvars"; - asd = "pvars"; - }); - systems = [ "pvars" ]; - lispLibs = [ (getAttr "cl-store" self) (getAttr "global-vars" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - py-configparser = (build-asdf-system { - pname = "py-configparser"; - version = "20170830-svn"; - asds = [ "py-configparser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/py-configparser/2017-08-30/py-configparser-20170830-svn.tgz"; - sha256 = "1mpzhrys1b1mp1kp2xvryl6v01gfqfccb1zdiib49nf4bms4irvw"; - system = "py-configparser"; - asd = "py-configparser"; - }); - systems = [ "py-configparser" ]; - lispLibs = [ (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - py4cl = (build-asdf-system { - pname = "py4cl"; - version = "20241012-git"; - asds = [ "py4cl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/py4cl/2024-10-12/py4cl-20241012-git.tgz"; - sha256 = "0i2zg58zgcyw68m846sqwjb77mvps766xlp30i65h18plc8yqmpg"; - system = "py4cl"; - asd = "py4cl"; - }); - systems = [ "py4cl" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "numpy-file-format" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - py4cl2 = (build-asdf-system { - pname = "py4cl2"; - version = "v2.9.3"; - asds = [ "py4cl2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/py4cl2/2024-10-12/py4cl2-v2.9.3.tgz"; - sha256 = "0g7qhwnyi1la22k90z8993q8knr117f40jk73wjsvixicqc4awqq"; - system = "py4cl2"; - asd = "py4cl2"; - }); - systems = [ "py4cl2" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-json" self) (getAttr "float-features" self) (getAttr "iterate" self) (getAttr "numpy-file-format" self) (getAttr "parse-number" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - py4cl2-cffi = (build-asdf-system { - pname = "py4cl2-cffi"; - version = "20241012-git"; - asds = [ "py4cl2-cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/py4cl2-cffi/2024-10-12/py4cl2-cffi-20241012-git.tgz"; - sha256 = "12ggqz8ibbzsmym51yfd19dlw751s7a1i6ra4z8m2ml3zw1k63zr"; - system = "py4cl2-cffi"; - asd = "py4cl2-cffi"; - }); - systems = [ "py4cl2-cffi" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cl-ppcre" self) (getAttr "float-features" self) (getAttr "iterate" self) (getAttr "optima" self) (getAttr "parse-number" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - pythonic-string-reader = (build-asdf-system { - pname = "pythonic-string-reader"; - version = "20180711-git"; - asds = [ "pythonic-string-reader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pythonic-string-reader/2018-07-11/pythonic-string-reader-20180711-git.tgz"; - sha256 = "1b5iryqw8xsh36swckmz8rrngmc39k92si33fgy5pml3n9l5rq3j"; - system = "pythonic-string-reader"; - asd = "pythonic-string-reader"; - }); - systems = [ "pythonic-string-reader" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = {}; - }); - pzmq = (build-asdf-system { - pname = "pzmq"; - version = "20210531-git"; - asds = [ "pzmq" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pzmq/2021-05-31/pzmq-20210531-git.tgz"; - sha256 = "19mdhxhzzghlmff1fic4chg5iz0psglkim09z6dgpijm26biny05"; - system = "pzmq"; - asd = "pzmq"; - }); - systems = [ "pzmq" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = {}; - }); - pzmq-compat = (build-asdf-system { - pname = "pzmq-compat"; - version = "20210531-git"; - asds = [ "pzmq-compat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pzmq/2021-05-31/pzmq-20210531-git.tgz"; - sha256 = "19mdhxhzzghlmff1fic4chg5iz0psglkim09z6dgpijm26biny05"; - system = "pzmq-compat"; - asd = "pzmq"; - }); - systems = [ "pzmq-compat" ]; - lispLibs = [ (getAttr "pzmq" self) ]; - meta = {}; - }); - pzmq-examples = (build-asdf-system { - pname = "pzmq-examples"; - version = "20210531-git"; - asds = [ "pzmq-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pzmq/2021-05-31/pzmq-20210531-git.tgz"; - sha256 = "19mdhxhzzghlmff1fic4chg5iz0psglkim09z6dgpijm26biny05"; - system = "pzmq-examples"; - asd = "pzmq"; - }); - systems = [ "pzmq-examples" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "iterate" self) (getAttr "local-time" self) (getAttr "pzmq" self) (getAttr "split-sequence" self) ]; - meta = {}; - }); - pzmq-test = (build-asdf-system { - pname = "pzmq-test"; - version = "20210531-git"; - asds = [ "pzmq-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/pzmq/2021-05-31/pzmq-20210531-git.tgz"; - sha256 = "19mdhxhzzghlmff1fic4chg5iz0psglkim09z6dgpijm26biny05"; - system = "pzmq-test"; - asd = "pzmq"; - }); - systems = [ "pzmq-test" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "fiveam" self) (getAttr "let-plus" self) (getAttr "pzmq" self) ]; - meta = {}; - }); - q_plus = (build-asdf-system { - pname = "q+"; - version = "20230214-git"; - asds = [ "q+" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; - sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; - system = "q+"; - asd = "q+"; - }); - systems = [ "q+" ]; - lispLibs = [ (getAttr "qtools" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qbase64 = (build-asdf-system { - pname = "qbase64"; - version = "20220220-git"; - asds = [ "qbase64" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qbase64/2022-02-20/qbase64-20220220-git.tgz"; - sha256 = "06daqqfdd51wkx0pyxgz7zq4ibzsqsgn3qs04jabx67gyybgnmjm"; - system = "qbase64"; - asd = "qbase64"; - }); - systems = [ "qbase64" ]; - lispLibs = [ (getAttr "metabang-bind" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qbook = (build-asdf-system { - pname = "qbook"; - version = "20130312-darcs"; - asds = [ "qbook" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qbook/2013-03-12/qbook-20130312-darcs.tgz"; - sha256 = "0l5hc2v73416jpwc2nsnj03z85fisirgm4av2anvlpv5m1291p6g"; - system = "qbook"; - asd = "qbook"; - }); - systems = [ "qbook" ]; - lispLibs = [ (getAttr "arnesi" self) (getAttr "cl-ppcre" self) (getAttr "iterate" self) (getAttr "yaclml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qimageblitz = (build-asdf-system { - pname = "qimageblitz"; - version = "20210531-git"; - asds = [ "qimageblitz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qimageblitz"; - asd = "qimageblitz"; - }); - systems = [ "qimageblitz" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtgui" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ql-checkout = (build-asdf-system { - pname = "ql-checkout"; - version = "20190521-git"; - asds = [ "ql-checkout" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ql-checkout/2019-05-21/ql-checkout-20190521-git.tgz"; - sha256 = "1zp3wa7g1wn7sypfsla7510ywvldqavlmv90pncanwpwn79klyhw"; - system = "ql-checkout"; - asd = "ql-checkout"; - }); - systems = [ "ql-checkout" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qlot = (build-asdf-system { - pname = "qlot"; - version = "1.5.14"; - asds = [ "qlot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qlot/2024-10-12/qlot-1.5.14.tgz"; - sha256 = "15rg8gjwisi2gp7a0pfgdvs9mjs1xxff0a58b14nm8sf11cdggkr"; - system = "qlot"; - asd = "qlot"; - }); - systems = [ "qlot" ]; - lispLibs = [ (getAttr "archive" self) (getAttr "bordeaux-threads" self) (getAttr "cl_plus_ssl" self) (getAttr "deflate" self) (getAttr "dexador" self) (getAttr "fuzzy-match" self) (getAttr "ironclad" self) (getAttr "lparallel" self) (getAttr "quri" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qmynd = (build-asdf-system { - pname = "qmynd"; - version = "20190710-git"; - asds = [ "qmynd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qmynd/2019-07-10/qmynd-20190710-git.tgz"; - sha256 = "06gw5wxcpdclb6a5i5k9lbmdlyqsp182czrm9bm1cpklzbj0ihrl"; - system = "qmynd"; - asd = "qmynd"; - }); - systems = [ "qmynd" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "chipz" self) (getAttr "cl_plus_ssl" self) (getAttr "flexi-streams" self) (getAttr "ironclad" self) (getAttr "list-of" self) (getAttr "salza2" self) (getAttr "trivial-gray-streams" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qmynd-test = (build-asdf-system { - pname = "qmynd-test"; - version = "20190710-git"; - asds = [ "qmynd-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qmynd/2019-07-10/qmynd-20190710-git.tgz"; - sha256 = "06gw5wxcpdclb6a5i5k9lbmdlyqsp182czrm9bm1cpklzbj0ihrl"; - system = "qmynd-test"; - asd = "qmynd-test"; - }); - systems = [ "qmynd-test" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "flexi-streams" self) (getAttr "qmynd" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qoi = (build-asdf-system { - pname = "qoi"; - version = "20241012-git"; - asds = [ "qoi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qoi/2024-10-12/qoi-20241012-git.tgz"; - sha256 = "06akq38q7m648c3kpx1pzw21fwqry7fkg6sfgbap0b7bifzg1dsn"; - system = "qoi"; - asd = "qoi"; - }); - systems = [ "qoi" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qsci = (build-asdf-system { - pname = "qsci"; - version = "20210531-git"; - asds = [ "qsci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qsci"; - asd = "qsci"; - }); - systems = [ "qsci" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtgui" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qt_plus_libs = (build-asdf-system { - pname = "qt+libs"; - version = "20230214-git"; - asds = [ "qt+libs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/commonqt/2023-02-14/commonqt-20230214-git.tgz"; - sha256 = "1s66z48plfwiq4qhf6whpvnjy4n7r9zhipri7lc8k67x817k020q"; - system = "qt+libs"; - asd = "qt+libs"; - }); - systems = [ "qt+libs" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "iterate" self) (getAttr "named-readtables" self) (getAttr "qt-libs" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qt-lib-generator = (build-asdf-system { - pname = "qt-lib-generator"; - version = "20210531-git"; - asds = [ "qt-lib-generator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qt-lib-generator"; - asd = "qt-lib-generator"; - }); - systems = [ "qt-lib-generator" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "pathname-utils" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qt-libs = (build-asdf-system { - pname = "qt-libs"; - version = "20210531-git"; - asds = [ "qt-libs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qt-libs"; - asd = "qt-libs"; - }); - systems = [ "qt-libs" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-ppcre" self) (getAttr "qt-lib-generator" self) ]; - meta = {}; - }); - qt3support = (build-asdf-system { - pname = "qt3support"; - version = "20210531-git"; - asds = [ "qt3support" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qt3support"; - asd = "qt3support"; - }); - systems = [ "qt3support" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtnetwork" self) (getAttr "qtsql" self) (getAttr "qtxml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtcore = (build-asdf-system { - pname = "qtcore"; - version = "20210531-git"; - asds = [ "qtcore" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtcore"; - asd = "qtcore"; - }); - systems = [ "qtcore" ]; - lispLibs = [ (getAttr "commonqt" self) (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtdbus = (build-asdf-system { - pname = "qtdbus"; - version = "20210531-git"; - asds = [ "qtdbus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtdbus"; - asd = "qtdbus"; - }); - systems = [ "qtdbus" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtxml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtdeclarative = (build-asdf-system { - pname = "qtdeclarative"; - version = "20210531-git"; - asds = [ "qtdeclarative" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtdeclarative"; - asd = "qtdeclarative"; - }); - systems = [ "qtdeclarative" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtnetwork" self) (getAttr "qtscript" self) (getAttr "qtsql" self) (getAttr "qtxmlpatterns" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtgui = (build-asdf-system { - pname = "qtgui"; - version = "20210531-git"; - asds = [ "qtgui" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtgui"; - asd = "qtgui"; - }); - systems = [ "qtgui" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qthelp = (build-asdf-system { - pname = "qthelp"; - version = "20210531-git"; - asds = [ "qthelp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qthelp"; - asd = "qthelp"; - }); - systems = [ "qthelp" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtnetwork" self) (getAttr "qtsql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtnetwork = (build-asdf-system { - pname = "qtnetwork"; - version = "20210531-git"; - asds = [ "qtnetwork" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtnetwork"; - asd = "qtnetwork"; - }); - systems = [ "qtnetwork" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools = (build-asdf-system { - pname = "qtools"; - version = "20230214-git"; - asds = [ "qtools" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; - sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; - system = "qtools"; - asd = "qtools"; - }); - systems = [ "qtools" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "deploy" self) (getAttr "documentation-utils" self) (getAttr "form-fiddle" self) (getAttr "named-readtables" self) (getAttr "qt_plus_libs" self) (getAttr "trivial-garbage" self) (getAttr "trivial-indent" self) (getAttr "trivial-main-thread" self) ]; - meta = {}; - }); - qtools-evaluator = (build-asdf-system { - pname = "qtools-evaluator"; - version = "20230214-git"; - asds = [ "qtools-evaluator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; - sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; - system = "qtools-evaluator"; - asd = "qtools-evaluator"; - }); - systems = [ "qtools-evaluator" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtools" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-game = (build-asdf-system { - pname = "qtools-game"; - version = "20230214-git"; - asds = [ "qtools-game" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; - sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; - system = "qtools-game"; - asd = "qtools-game"; - }); - systems = [ "qtools-game" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtools" self) (getAttr "qtopengl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-helloworld = (build-asdf-system { - pname = "qtools-helloworld"; - version = "20230214-git"; - asds = [ "qtools-helloworld" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; - sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; - system = "qtools-helloworld"; - asd = "qtools-helloworld"; - }); - systems = [ "qtools-helloworld" ]; - lispLibs = [ (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtools" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-melody = (build-asdf-system { - pname = "qtools-melody"; - version = "20230214-git"; - asds = [ "qtools-melody" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; - sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; - system = "qtools-melody"; - asd = "qtools-melody"; - }); - systems = [ "qtools-melody" ]; - lispLibs = [ (getAttr "phonon" self) (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtools" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-opengl = (build-asdf-system { - pname = "qtools-opengl"; - version = "20230214-git"; - asds = [ "qtools-opengl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; - sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; - system = "qtools-opengl"; - asd = "qtools-opengl"; - }); - systems = [ "qtools-opengl" ]; - lispLibs = [ (getAttr "cl-opengl" self) (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtools" self) (getAttr "qtopengl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-titter = (build-asdf-system { - pname = "qtools-titter"; - version = "20230214-git"; - asds = [ "qtools-titter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; - sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; - system = "qtools-titter"; - asd = "qtools-titter"; - }); - systems = [ "qtools-titter" ]; - lispLibs = [ (getAttr "chirp" self) (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtools" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui = (build-asdf-system { - pname = "qtools-ui"; - version = "20200218-git"; - asds = [ "qtools-ui" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui"; - asd = "qtools-ui"; - }); - systems = [ "qtools-ui" ]; - lispLibs = [ (getAttr "qtools-ui-auto-resizing-textedit" self) (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-cell" self) (getAttr "qtools-ui-color-history" self) (getAttr "qtools-ui-color-picker" self) (getAttr "qtools-ui-color-sliders" self) (getAttr "qtools-ui-color-triangle" self) (getAttr "qtools-ui-compass" self) (getAttr "qtools-ui-container" self) (getAttr "qtools-ui-debugger" self) (getAttr "qtools-ui-dialog" self) (getAttr "qtools-ui-dictionary" self) (getAttr "qtools-ui-drag-and-drop" self) (getAttr "qtools-ui-fixed-qtextedit" self) (getAttr "qtools-ui-flow-layout" self) (getAttr "qtools-ui-helpers" self) (getAttr "qtools-ui-imagetools" self) (getAttr "qtools-ui-keychord-editor" self) (getAttr "qtools-ui-layout" self) (getAttr "qtools-ui-listing" self) (getAttr "qtools-ui-notification" self) (getAttr "qtools-ui-options" self) (getAttr "qtools-ui-panels" self) (getAttr "qtools-ui-placeholder-text-edit" self) (getAttr "qtools-ui-plot" self) (getAttr "qtools-ui-repl" self) (getAttr "qtools-ui-slider" self) (getAttr "qtools-ui-spellchecked-text-edit" self) (getAttr "qtools-ui-splitter" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-auto-resizing-textedit = (build-asdf-system { - pname = "qtools-ui-auto-resizing-textedit"; - version = "20200218-git"; - asds = [ "qtools-ui-auto-resizing-textedit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-auto-resizing-textedit"; - asd = "qtools-ui-auto-resizing-textedit"; - }); - systems = [ "qtools-ui-auto-resizing-textedit" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-fixed-qtextedit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-base = (build-asdf-system { - pname = "qtools-ui-base"; - version = "20200218-git"; - asds = [ "qtools-ui-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-base"; - asd = "qtools-ui-base"; - }); - systems = [ "qtools-ui-base" ]; - lispLibs = [ (getAttr "array-utils" self) (getAttr "documentation-utils" self) (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtools" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-bytearray = (build-asdf-system { - pname = "qtools-ui-bytearray"; - version = "20200218-git"; - asds = [ "qtools-ui-bytearray" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-bytearray"; - asd = "qtools-ui-bytearray"; - }); - systems = [ "qtools-ui-bytearray" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-cell = (build-asdf-system { - pname = "qtools-ui-cell"; - version = "20200218-git"; - asds = [ "qtools-ui-cell" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-cell"; - asd = "qtools-ui-cell"; - }); - systems = [ "qtools-ui-cell" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-helpers" self) (getAttr "qtools-ui-layout" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-color-history = (build-asdf-system { - pname = "qtools-ui-color-history"; - version = "20200218-git"; - asds = [ "qtools-ui-color-history" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-color-history"; - asd = "qtools-ui-color-history"; - }); - systems = [ "qtools-ui-color-history" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-flow-layout" self) (getAttr "qtools-ui-helpers" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-color-picker = (build-asdf-system { - pname = "qtools-ui-color-picker"; - version = "20200218-git"; - asds = [ "qtools-ui-color-picker" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-color-picker"; - asd = "qtools-ui-color-picker"; - }); - systems = [ "qtools-ui-color-picker" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-color-history" self) (getAttr "qtools-ui-color-sliders" self) (getAttr "qtools-ui-color-triangle" self) (getAttr "qtools-ui-dialog" self) (getAttr "qtools-ui-helpers" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-color-sliders = (build-asdf-system { - pname = "qtools-ui-color-sliders"; - version = "20200218-git"; - asds = [ "qtools-ui-color-sliders" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-color-sliders"; - asd = "qtools-ui-color-sliders"; - }); - systems = [ "qtools-ui-color-sliders" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-helpers" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-color-triangle = (build-asdf-system { - pname = "qtools-ui-color-triangle"; - version = "20200218-git"; - asds = [ "qtools-ui-color-triangle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-color-triangle"; - asd = "qtools-ui-color-triangle"; - }); - systems = [ "qtools-ui-color-triangle" ]; - lispLibs = [ (getAttr "cl-opengl" self) (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-helpers" self) (getAttr "qtopengl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-compass = (build-asdf-system { - pname = "qtools-ui-compass"; - version = "20200218-git"; - asds = [ "qtools-ui-compass" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-compass"; - asd = "qtools-ui-compass"; - }); - systems = [ "qtools-ui-compass" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-layout" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-container = (build-asdf-system { - pname = "qtools-ui-container"; - version = "20200218-git"; - asds = [ "qtools-ui-container" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-container"; - asd = "qtools-ui-container"; - }); - systems = [ "qtools-ui-container" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-layout" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-debugger = (build-asdf-system { - pname = "qtools-ui-debugger"; - version = "20200218-git"; - asds = [ "qtools-ui-debugger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-debugger"; - asd = "qtools-ui-debugger"; - }); - systems = [ "qtools-ui-debugger" ]; - lispLibs = [ (getAttr "dissect" self) (getAttr "qtools-ui-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-dialog = (build-asdf-system { - pname = "qtools-ui-dialog"; - version = "20200218-git"; - asds = [ "qtools-ui-dialog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-dialog"; - asd = "qtools-ui-dialog"; - }); - systems = [ "qtools-ui-dialog" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-helpers" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-dictionary = (build-asdf-system { - pname = "qtools-ui-dictionary"; - version = "20200218-git"; - asds = [ "qtools-ui-dictionary" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-dictionary"; - asd = "qtools-ui-dictionary"; - }); - systems = [ "qtools-ui-dictionary" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-fixed-qtextedit" self) (getAttr "qtools-ui-helpers" self) (getAttr "wordnet" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-drag-and-drop = (build-asdf-system { - pname = "qtools-ui-drag-and-drop"; - version = "20200218-git"; - asds = [ "qtools-ui-drag-and-drop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-drag-and-drop"; - asd = "qtools-ui-drag-and-drop"; - }); - systems = [ "qtools-ui-drag-and-drop" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-helpers" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-executable = (build-asdf-system { - pname = "qtools-ui-executable"; - version = "20200218-git"; - asds = [ "qtools-ui-executable" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-executable"; - asd = "qtools-ui-executable"; - }); - systems = [ "qtools-ui-executable" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "qtools-ui-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-fixed-qtextedit = (build-asdf-system { - pname = "qtools-ui-fixed-qtextedit"; - version = "20200218-git"; - asds = [ "qtools-ui-fixed-qtextedit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-fixed-qtextedit"; - asd = "qtools-ui-fixed-qtextedit"; - }); - systems = [ "qtools-ui-fixed-qtextedit" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-flow-layout = (build-asdf-system { - pname = "qtools-ui-flow-layout"; - version = "20200218-git"; - asds = [ "qtools-ui-flow-layout" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-flow-layout"; - asd = "qtools-ui-flow-layout"; - }); - systems = [ "qtools-ui-flow-layout" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-container" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-helpers = (build-asdf-system { - pname = "qtools-ui-helpers"; - version = "20200218-git"; - asds = [ "qtools-ui-helpers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-helpers"; - asd = "qtools-ui-helpers"; - }); - systems = [ "qtools-ui-helpers" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-layout" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-imagetools = (build-asdf-system { - pname = "qtools-ui-imagetools"; - version = "20200218-git"; - asds = [ "qtools-ui-imagetools" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-imagetools"; - asd = "qtools-ui-imagetools"; - }); - systems = [ "qtools-ui-imagetools" ]; - lispLibs = [ (getAttr "qimageblitz" self) (getAttr "qtools-ui-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-keychord-editor = (build-asdf-system { - pname = "qtools-ui-keychord-editor"; - version = "20200218-git"; - asds = [ "qtools-ui-keychord-editor" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-keychord-editor"; - asd = "qtools-ui-keychord-editor"; - }); - systems = [ "qtools-ui-keychord-editor" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-layout = (build-asdf-system { - pname = "qtools-ui-layout"; - version = "20200218-git"; - asds = [ "qtools-ui-layout" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-layout"; - asd = "qtools-ui-layout"; - }); - systems = [ "qtools-ui-layout" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-listing = (build-asdf-system { - pname = "qtools-ui-listing"; - version = "20200218-git"; - asds = [ "qtools-ui-listing" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-listing"; - asd = "qtools-ui-listing"; - }); - systems = [ "qtools-ui-listing" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-cell" self) (getAttr "qtools-ui-container" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-notification = (build-asdf-system { - pname = "qtools-ui-notification"; - version = "20200218-git"; - asds = [ "qtools-ui-notification" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-notification"; - asd = "qtools-ui-notification"; - }); - systems = [ "qtools-ui-notification" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-options = (build-asdf-system { - pname = "qtools-ui-options"; - version = "20200218-git"; - asds = [ "qtools-ui-options" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-options"; - asd = "qtools-ui-options"; - }); - systems = [ "qtools-ui-options" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-color-picker" self) (getAttr "qtools-ui-color-triangle" self) (getAttr "qtools-ui-helpers" self) (getAttr "qtools-ui-listing" self) (getAttr "qtools-ui-slider" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-panels = (build-asdf-system { - pname = "qtools-ui-panels"; - version = "20200218-git"; - asds = [ "qtools-ui-panels" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-panels"; - asd = "qtools-ui-panels"; - }); - systems = [ "qtools-ui-panels" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-compass" self) (getAttr "qtools-ui-helpers" self) (getAttr "qtools-ui-splitter" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-placeholder-text-edit = (build-asdf-system { - pname = "qtools-ui-placeholder-text-edit"; - version = "20200218-git"; - asds = [ "qtools-ui-placeholder-text-edit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-placeholder-text-edit"; - asd = "qtools-ui-placeholder-text-edit"; - }); - systems = [ "qtools-ui-placeholder-text-edit" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-fixed-qtextedit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-plot = (build-asdf-system { - pname = "qtools-ui-plot"; - version = "20200218-git"; - asds = [ "qtools-ui-plot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-plot"; - asd = "qtools-ui-plot"; - }); - systems = [ "qtools-ui-plot" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-helpers" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-progress-bar = (build-asdf-system { - pname = "qtools-ui-progress-bar"; - version = "20200218-git"; - asds = [ "qtools-ui-progress-bar" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-progress-bar"; - asd = "qtools-ui-progress-bar"; - }); - systems = [ "qtools-ui-progress-bar" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-repl = (build-asdf-system { - pname = "qtools-ui-repl"; - version = "20200218-git"; - asds = [ "qtools-ui-repl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-repl"; - asd = "qtools-ui-repl"; - }); - systems = [ "qtools-ui-repl" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "qtools-ui-base" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-slider = (build-asdf-system { - pname = "qtools-ui-slider"; - version = "20200218-git"; - asds = [ "qtools-ui-slider" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-slider"; - asd = "qtools-ui-slider"; - }); - systems = [ "qtools-ui-slider" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-helpers" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-spellchecked-text-edit = (build-asdf-system { - pname = "qtools-ui-spellchecked-text-edit"; - version = "20200218-git"; - asds = [ "qtools-ui-spellchecked-text-edit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-spellchecked-text-edit"; - asd = "qtools-ui-spellchecked-text-edit"; - }); - systems = [ "qtools-ui-spellchecked-text-edit" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-fixed-qtextedit" self) (getAttr "qtools-ui-helpers" self) (getAttr "spell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-splitter = (build-asdf-system { - pname = "qtools-ui-splitter"; - version = "20200218-git"; - asds = [ "qtools-ui-splitter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-splitter"; - asd = "qtools-ui-splitter"; - }); - systems = [ "qtools-ui-splitter" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtools-ui-container" self) (getAttr "qtools-ui-helpers" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtools-ui-svgtools = (build-asdf-system { - pname = "qtools-ui-svgtools"; - version = "20200218-git"; - asds = [ "qtools-ui-svgtools" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; - sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; - system = "qtools-ui-svgtools"; - asd = "qtools-ui-svgtools"; - }); - systems = [ "qtools-ui-svgtools" ]; - lispLibs = [ (getAttr "qtools-ui-base" self) (getAttr "qtsvg" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtopengl = (build-asdf-system { - pname = "qtopengl"; - version = "20210531-git"; - asds = [ "qtopengl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtopengl"; - asd = "qtopengl"; - }); - systems = [ "qtopengl" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtgui" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtscript = (build-asdf-system { - pname = "qtscript"; - version = "20210531-git"; - asds = [ "qtscript" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtscript"; - asd = "qtscript"; - }); - systems = [ "qtscript" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtsql = (build-asdf-system { - pname = "qtsql"; - version = "20210531-git"; - asds = [ "qtsql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtsql"; - asd = "qtsql"; - }); - systems = [ "qtsql" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtgui" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtsvg = (build-asdf-system { - pname = "qtsvg"; - version = "20210531-git"; - asds = [ "qtsvg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtsvg"; - asd = "qtsvg"; - }); - systems = [ "qtsvg" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtgui" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qttest = (build-asdf-system { - pname = "qttest"; - version = "20210531-git"; - asds = [ "qttest" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qttest"; - asd = "qttest"; - }); - systems = [ "qttest" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtgui" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtuitools = (build-asdf-system { - pname = "qtuitools"; - version = "20210531-git"; - asds = [ "qtuitools" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtuitools"; - asd = "qtuitools"; - }); - systems = [ "qtuitools" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtgui" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtwebkit = (build-asdf-system { - pname = "qtwebkit"; - version = "20210531-git"; - asds = [ "qtwebkit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtwebkit"; - asd = "qtwebkit"; - }); - systems = [ "qtwebkit" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtgui" self) (getAttr "qtnetwork" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtxml = (build-asdf-system { - pname = "qtxml"; - version = "20210531-git"; - asds = [ "qtxml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtxml"; - asd = "qtxml"; - }); - systems = [ "qtxml" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qtxmlpatterns = (build-asdf-system { - pname = "qtxmlpatterns"; - version = "20210531-git"; - asds = [ "qtxmlpatterns" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qtxmlpatterns"; - asd = "qtxmlpatterns"; - }); - systems = [ "qtxmlpatterns" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtnetwork" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quad-tree = (build-asdf-system { - pname = "quad-tree"; - version = "20220707-git"; - asds = [ "quad-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quad-tree/2022-07-07/quad-tree-20220707-git.tgz"; - sha256 = "1pg43zw75dbqxs8vca3fynqfvza59v1fmwh9m4x0jrnw7ysgkl6j"; - system = "quad-tree"; - asd = "quad-tree"; - }); - systems = [ "quad-tree" ]; - lispLibs = [ (getAttr "mfiano-utils" self) (getAttr "origin" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quadpack = (build-asdf-system { - pname = "quadpack"; - version = "20231021-git"; - asds = [ "quadpack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "quadpack"; - asd = "quadpack"; - }); - systems = [ "quadpack" ]; - lispLibs = [ (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quads = (build-asdf-system { - pname = "quads"; - version = "20200427-git"; - asds = [ "quads" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "quads"; - asd = "quads"; - }); - systems = [ "quads" ]; - lispLibs = [ (getAttr "utility" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quadtree = (build-asdf-system { - pname = "quadtree"; - version = "20150709-git"; - asds = [ "quadtree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quadtree/2015-07-09/quadtree-20150709-git.tgz"; - sha256 = "0590f0sbv4qg590d2bb7ypncg3wn5xjapi24w78mnzr9bdnhh4vx"; - system = "quadtree"; - asd = "quadtree"; - }); - systems = [ "quadtree" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quadtree-test = (build-asdf-system { - pname = "quadtree-test"; - version = "20150709-git"; - asds = [ "quadtree-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quadtree/2015-07-09/quadtree-20150709-git.tgz"; - sha256 = "0590f0sbv4qg590d2bb7ypncg3wn5xjapi24w78mnzr9bdnhh4vx"; - system = "quadtree-test"; - asd = "quadtree-test"; - }); - systems = [ "quadtree-test" ]; - lispLibs = [ (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "quadtree" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quantile-estimator = (build-asdf-system { - pname = "quantile-estimator"; - version = "20160825-git"; - asds = [ "quantile-estimator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quantile-estimator.cl/2016-08-25/quantile-estimator.cl-20160825-git.tgz"; - sha256 = "1rrazbl0gbsymynlxp7ild6wvwp6csmdig4hwrp3wjvqhdl8j3mj"; - system = "quantile-estimator"; - asd = "quantile-estimator"; - }); - systems = [ "quantile-estimator" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quantile-estimator_dot_test = (build-asdf-system { - pname = "quantile-estimator.test"; - version = "20160825-git"; - asds = [ "quantile-estimator.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quantile-estimator.cl/2016-08-25/quantile-estimator.cl-20160825-git.tgz"; - sha256 = "1rrazbl0gbsymynlxp7ild6wvwp6csmdig4hwrp3wjvqhdl8j3mj"; - system = "quantile-estimator.test"; - asd = "quantile-estimator.test"; - }); - systems = [ "quantile-estimator.test" ]; - lispLibs = [ (getAttr "log4cl" self) (getAttr "mw-equiv" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "quantile-estimator" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quasiquote-2_dot_0 = (build-asdf-system { - pname = "quasiquote-2.0"; - version = "20150505-git"; - asds = [ "quasiquote-2.0" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quasiquote-2.0/2015-05-05/quasiquote-2.0-20150505-git.tgz"; - sha256 = "1g0s3aplrgmdjj8k1wrx3dkqdsl4lka2nmgdng0rcd93xp11q6hn"; - system = "quasiquote-2.0"; - asd = "quasiquote-2.0"; - }); - systems = [ "quasiquote-2.0" ]; - lispLibs = [ (getAttr "iterate" self) ]; - meta = {}; - }); - quasiquote-2_dot_0-tests = (build-asdf-system { - pname = "quasiquote-2.0-tests"; - version = "20150505-git"; - asds = [ "quasiquote-2.0-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quasiquote-2.0/2015-05-05/quasiquote-2.0-20150505-git.tgz"; - sha256 = "1g0s3aplrgmdjj8k1wrx3dkqdsl4lka2nmgdng0rcd93xp11q6hn"; - system = "quasiquote-2.0-tests"; - asd = "quasiquote-2.0"; - }); - systems = [ "quasiquote-2.0-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "quasiquote-2_dot_0" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quaviver = (build-asdf-system { - pname = "quaviver"; - version = "20241012-git"; - asds = [ "quaviver" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quaviver/2024-10-12/quaviver-20241012-git.tgz"; - sha256 = "17kixyznxfwlxkfl2d2ngxas3vi7r21bgfy4g7xlngvakxw3zfzp"; - system = "quaviver"; - asd = "quaviver"; - }); - systems = [ "quaviver" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - queen = (build-asdf-system { - pname = "queen"; - version = "20230618-git"; - asds = [ "queen" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/queen.lisp/2023-06-18/queen.lisp-20230618-git.tgz"; - sha256 = "14y4688f9gazdxh03k2jnxnla2bygcsz6wk55yc0id1achak95fa"; - system = "queen"; - asd = "queen"; - }); - systems = [ "queen" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cl-ppcre-unicode" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - query-fs = (build-asdf-system { - pname = "query-fs"; - version = "20241012-git"; - asds = [ "query-fs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/query-fs/2024-10-12/query-fs-20241012-git.tgz"; - sha256 = "09gz8xrjg9r5bclphgwjdnif8qx4qnx518jragq3znwvlzfb34fw"; - system = "query-fs"; - asd = "query-fs"; - }); - systems = [ "query-fs" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-fuse" self) (getAttr "cl-fuse-meta-fs" self) (getAttr "cl-ppcre" self) (getAttr "command-line-arguments" self) (getAttr "iterate" self) (getAttr "trivial-backtrace" self) ]; - meta = {}; - }); - query-repl = (build-asdf-system { - pname = "query-repl"; - version = "20220331-git"; - asds = [ "query-repl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/query-repl/2022-03-31/query-repl-20220331-git.tgz"; - sha256 = "0gzrr1k7071hdmd64i5lqmg62i3yqim7nmcc9r94sry47bkp16v2"; - system = "query-repl"; - asd = "query-repl"; - }); - systems = [ "query-repl" ]; - lispLibs = [ (getAttr "check-bnf" self) (getAttr "jingoh_dot_documentizer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - query-repl_dot_test = (build-asdf-system { - pname = "query-repl.test"; - version = "20220331-git"; - asds = [ "query-repl.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/query-repl/2022-03-31/query-repl-20220331-git.tgz"; - sha256 = "0gzrr1k7071hdmd64i5lqmg62i3yqim7nmcc9r94sry47bkp16v2"; - system = "query-repl.test"; - asd = "query-repl.test"; - }); - systems = [ "query-repl.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "query-repl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - queues = (build-asdf-system { - pname = "queues"; - version = "20170124-git"; - asds = [ "queues" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/queues/2017-01-24/queues-20170124-git.tgz"; - sha256 = "0wdhfnzi4v6d97pggzj2aw55si94w4327br94jrmyvwf351wqjvv"; - system = "queues"; - asd = "queues"; - }); - systems = [ "queues" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - queues_dot_priority-cqueue = (build-asdf-system { - pname = "queues.priority-cqueue"; - version = "20170124-git"; - asds = [ "queues.priority-cqueue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/queues/2017-01-24/queues-20170124-git.tgz"; - sha256 = "0wdhfnzi4v6d97pggzj2aw55si94w4327br94jrmyvwf351wqjvv"; - system = "queues.priority-cqueue"; - asd = "queues.priority-cqueue"; - }); - systems = [ "queues.priority-cqueue" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "queues" self) (getAttr "queues_dot_priority-queue" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - queues_dot_priority-queue = (build-asdf-system { - pname = "queues.priority-queue"; - version = "20170124-git"; - asds = [ "queues.priority-queue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/queues/2017-01-24/queues-20170124-git.tgz"; - sha256 = "0wdhfnzi4v6d97pggzj2aw55si94w4327br94jrmyvwf351wqjvv"; - system = "queues.priority-queue"; - asd = "queues.priority-queue"; - }); - systems = [ "queues.priority-queue" ]; - lispLibs = [ (getAttr "queues" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - queues_dot_simple-cqueue = (build-asdf-system { - pname = "queues.simple-cqueue"; - version = "20170124-git"; - asds = [ "queues.simple-cqueue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/queues/2017-01-24/queues-20170124-git.tgz"; - sha256 = "0wdhfnzi4v6d97pggzj2aw55si94w4327br94jrmyvwf351wqjvv"; - system = "queues.simple-cqueue"; - asd = "queues.simple-cqueue"; - }); - systems = [ "queues.simple-cqueue" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "queues" self) (getAttr "queues_dot_simple-queue" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - queues_dot_simple-queue = (build-asdf-system { - pname = "queues.simple-queue"; - version = "20170124-git"; - asds = [ "queues.simple-queue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/queues/2017-01-24/queues-20170124-git.tgz"; - sha256 = "0wdhfnzi4v6d97pggzj2aw55si94w4327br94jrmyvwf351wqjvv"; - system = "queues.simple-queue"; - asd = "queues.simple-queue"; - }); - systems = [ "queues.simple-queue" ]; - lispLibs = [ (getAttr "queues" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quick-patch = (build-asdf-system { - pname = "quick-patch"; - version = "20241012-git"; - asds = [ "quick-patch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quick-patch/2024-10-12/quick-patch-20241012-git.tgz"; - sha256 = "0a2wkqn65kl88yz7a8728x9gjy4w37hjavfqx4hyijhs1ph38wdi"; - system = "quick-patch"; - asd = "quick-patch"; - }); - systems = [ "quick-patch" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quickapp = (build-asdf-system { - pname = "quickapp"; - version = "20160825-git"; - asds = [ "quickapp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quickapp/2016-08-25/quickapp-20160825-git.tgz"; - sha256 = "0rhhxwggbh9sf3c4c9fv39c5imy48416mwf0dkhqpnm8x55xbw22"; - system = "quickapp"; - asd = "quickapp"; - }); - systems = [ "quickapp" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quickhull = (build-asdf-system { - pname = "quickhull"; - version = "20241012-git"; - asds = [ "quickhull" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quickhull/2024-10-12/quickhull-20241012-git.tgz"; - sha256 = "1814qq23dg2shnfdkw9w9ap53qzg2igy119bwslvflmcb1jd7bpm"; - system = "quickhull"; - asd = "quickhull"; - }); - systems = [ "quickhull" ]; - lispLibs = [ (getAttr "_3d-math" self) (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quicklisp-slime-helper = (build-asdf-system { - pname = "quicklisp-slime-helper"; - version = "20150709-git"; - asds = [ "quicklisp-slime-helper" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quicklisp-slime-helper/2015-07-09/quicklisp-slime-helper-20150709-git.tgz"; - sha256 = "14b1zg26h75pnhj3ic0h9i5jbmwf8wjp91scbcg1ra9fyhh73pa6"; - system = "quicklisp-slime-helper"; - asd = "quicklisp-slime-helper"; - }); - systems = [ "quicklisp-slime-helper" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quicklisp-starter = (build-asdf-system { - pname = "quicklisp-starter"; - version = "20241012-git"; - asds = [ "quicklisp-starter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-brewer/2024-10-12/cl-brewer-20241012-git.tgz"; - sha256 = "0izf6v4qx82jhk7ln28jhdmnr3lb0r5iqjj0by9igq5sk3y1my4x"; - system = "quicklisp-starter"; - asd = "quicklisp-starter"; - }); - systems = [ "quicklisp-starter" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quicklisp-stats = (build-asdf-system { - pname = "quicklisp-stats"; - version = "20210411-git"; - asds = [ "quicklisp-stats" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quicklisp-stats/2021-04-11/quicklisp-stats-20210411-git.tgz"; - sha256 = "0v8dgmlgd283n1g486q4sj2mghgdvgywg2nqp43nnrfc04mkvgc0"; - system = "quicklisp-stats"; - asd = "quicklisp-stats"; - }); - systems = [ "quicklisp-stats" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "drakma" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quickproject = (build-asdf-system { - pname = "quickproject"; - version = "1.4.1"; - asds = [ "quickproject" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quickproject/2019-12-27/quickproject-1.4.1.tgz"; - sha256 = "1szs8p2wr1yr9mjmj3h3557l6wxzzga0iszimb68z0hb1jj3lva6"; - system = "quickproject"; - asd = "quickproject"; - }); - systems = [ "quickproject" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "html-template" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quicksearch = (build-asdf-system { - pname = "quicksearch"; - version = "20171019-git"; - asds = [ "quicksearch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quicksearch/2017-10-19/quicksearch-20171019-git.tgz"; - sha256 = "16k19zjkhh7r64vjq371k5jwjs7cdfjz83flh561n4h4v1z89fps"; - system = "quicksearch"; - asd = "quicksearch"; - }); - systems = [ "quicksearch" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "do-urlencode" self) (getAttr "drakma" self) (getAttr "flexi-streams" self) (getAttr "html-entities" self) (getAttr "iterate" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quickutil = (build-asdf-system { - pname = "quickutil"; - version = "20210807-git"; - asds = [ "quickutil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quickutil/2021-08-07/quickutil-20210807-git.tgz"; - sha256 = "0d4xrgsh5pj4cgj1mqsdyi4xvq04jyb2m4c3sdx94jsx3r83hldz"; - system = "quickutil"; - asd = "quickutil"; - }); - systems = [ "quickutil" ]; - lispLibs = [ (getAttr "quickutil-client" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quickutil-client = (build-asdf-system { - pname = "quickutil-client"; - version = "20210807-git"; - asds = [ "quickutil-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quickutil/2021-08-07/quickutil-20210807-git.tgz"; - sha256 = "0d4xrgsh5pj4cgj1mqsdyi4xvq04jyb2m4c3sdx94jsx3r83hldz"; - system = "quickutil-client"; - asd = "quickutil-client"; - }); - systems = [ "quickutil-client" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "quickutil-client-management" self) (getAttr "quickutil-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quickutil-client-management = (build-asdf-system { - pname = "quickutil-client-management"; - version = "20210807-git"; - asds = [ "quickutil-client-management" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quickutil/2021-08-07/quickutil-20210807-git.tgz"; - sha256 = "0d4xrgsh5pj4cgj1mqsdyi4xvq04jyb2m4c3sdx94jsx3r83hldz"; - system = "quickutil-client-management"; - asd = "quickutil-client-management"; - }); - systems = [ "quickutil-client-management" ]; - lispLibs = [ (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quickutil-server = (build-asdf-system { - pname = "quickutil-server"; - version = "20210807-git"; - asds = [ "quickutil-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quickutil/2021-08-07/quickutil-20210807-git.tgz"; - sha256 = "0d4xrgsh5pj4cgj1mqsdyi4xvq04jyb2m4c3sdx94jsx3r83hldz"; - system = "quickutil-server"; - asd = "quickutil-server"; - }); - systems = [ "quickutil-server" ]; - lispLibs = [ (getAttr "assoc-utils" self) (getAttr "cl-fad" self) (getAttr "cl-markdown" self) (getAttr "cl-ppcre" self) (getAttr "cl-syntax" self) (getAttr "cl-syntax-annot" self) (getAttr "clack" self) (getAttr "closure-template" self) (getAttr "dbi" self) (getAttr "lack" self) (getAttr "lack-component" self) (getAttr "lack-middleware-csrf" self) (getAttr "lack-request" self) (getAttr "lack-response" self) (getAttr "ningle" self) (getAttr "quickutil-utilities" self) (getAttr "trivial-shell" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quickutil-utilities = (build-asdf-system { - pname = "quickutil-utilities"; - version = "20210807-git"; - asds = [ "quickutil-utilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quickutil/2021-08-07/quickutil-20210807-git.tgz"; - sha256 = "0d4xrgsh5pj4cgj1mqsdyi4xvq04jyb2m4c3sdx94jsx3r83hldz"; - system = "quickutil-utilities"; - asd = "quickutil-utilities"; - }); - systems = [ "quickutil-utilities" ]; - lispLibs = [ (getAttr "cl-heredoc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quickutil-utilities-test = (build-asdf-system { - pname = "quickutil-utilities-test"; - version = "20210807-git"; - asds = [ "quickutil-utilities-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quickutil/2021-08-07/quickutil-20210807-git.tgz"; - sha256 = "0d4xrgsh5pj4cgj1mqsdyi4xvq04jyb2m4c3sdx94jsx3r83hldz"; - system = "quickutil-utilities-test"; - asd = "quickutil-utilities-test"; - }); - systems = [ "quickutil-utilities-test" ]; - lispLibs = [ (getAttr "quickutil-client" self) (getAttr "quickutil-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quil-coalton = (build-asdf-system { - pname = "quil-coalton"; - version = "20241012-git"; - asds = [ "quil-coalton" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; - sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; - system = "quil-coalton"; - asd = "quil-coalton"; - }); - systems = [ "quil-coalton" ]; - lispLibs = [ (getAttr "coalton" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quine-mccluskey = (build-asdf-system { - pname = "quine-mccluskey"; - version = "20141217-git"; - asds = [ "quine-mccluskey" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-logic/2014-12-17/cl-logic-20141217-git.tgz"; - sha256 = "17n2wzqali3j6b7pqbydipwlxgwdrj4mdnsgwjdyz32n8jvfyjwh"; - system = "quine-mccluskey"; - asd = "cl-logic"; - }); - systems = [ "quine-mccluskey" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quri = (build-asdf-system { - pname = "quri"; - version = "20241012-git"; - asds = [ "quri" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quri/2024-10-12/quri-20241012-git.tgz"; - sha256 = "0vismgg72xrflzdsrv8ybq3cxf717k5296g9b731974vwlf7ibh0"; - system = "quri"; - asd = "quri"; - }); - systems = [ "quri" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-utilities" self) (getAttr "idna" self) (getAttr "split-sequence" self) ]; - meta = {}; - }); - quri-test = (build-asdf-system { - pname = "quri-test"; - version = "20241012-git"; - asds = [ "quri-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quri/2024-10-12/quri-20241012-git.tgz"; - sha256 = "0vismgg72xrflzdsrv8ybq3cxf717k5296g9b731974vwlf7ibh0"; - system = "quri-test"; - asd = "quri-test"; - }); - systems = [ "quri-test" ]; - lispLibs = [ (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "quri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quux-hunchentoot = (build-asdf-system { - pname = "quux-hunchentoot"; - version = "20211230-git"; - asds = [ "quux-hunchentoot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quux-hunchentoot/2021-12-30/quux-hunchentoot-20211230-git.tgz"; - sha256 = "0v0x4hzzfm835blqbp00vmj74gaq8wyldrnfj0x5s6zfl64w135y"; - system = "quux-hunchentoot"; - asd = "quux-hunchentoot"; - }); - systems = [ "quux-hunchentoot" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "hunchentoot" self) (getAttr "lil" self) (getAttr "lparallel" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - quux-time = (build-asdf-system { - pname = "quux-time"; - version = "20150407-git"; - asds = [ "quux-time" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/quux-time/2015-04-07/quux-time-20150407-git.tgz"; - sha256 = "0hsa2n1j0abhw8na9fql47rq1rxpf2vkwg2mbb1c3ax56r8dsh0v"; - system = "quux-time"; - asd = "quux-time"; - }); - systems = [ "quux-time" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - qwt = (build-asdf-system { - pname = "qwt"; - version = "20210531-git"; - asds = [ "qwt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "qwt"; - asd = "qwt"; - }); - systems = [ "qwt" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) (getAttr "qtcore" self) (getAttr "qtgui" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rail = (build-asdf-system { - pname = "rail"; - version = "20171227-git"; - asds = [ "rail" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rail/2017-12-27/cl-rail-20171227-git.tgz"; - sha256 = "0vxbxyfl5lw7na8iki1cjp0cd31z2bnxcpdv0x25hq0vch1cb5rj"; - system = "rail"; - asd = "rail"; - }); - systems = [ "rail" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rail-test = (build-asdf-system { - pname = "rail-test"; - version = "20171227-git"; - asds = [ "rail-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rail/2017-12-27/cl-rail-20171227-git.tgz"; - sha256 = "0vxbxyfl5lw7na8iki1cjp0cd31z2bnxcpdv0x25hq0vch1cb5rj"; - system = "rail-test"; - asd = "rail"; - }); - systems = [ "rail-test" ]; - lispLibs = [ (getAttr "fiasco" self) (getAttr "rail" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - random = (build-asdf-system { - pname = "random"; - version = "20191007-git"; - asds = [ "random" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/random/2019-10-07/random-20191007-git.tgz"; - sha256 = "1fb4mnp85jm9s667y4dgz07klhkr9pvi5xbxws28lbb8iip75y2p"; - system = "random"; - asd = "random"; - }); - systems = [ "random" ]; - lispLibs = [ (getAttr "com_dot_google_dot_base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - random-access-lists = (build-asdf-system { - pname = "random-access-lists"; - version = "20120208-git"; - asds = [ "random-access-lists" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/random-access-lists/2012-02-08/random-access-lists-20120208-git.tgz"; - sha256 = "0wslxxdmmr25hvmcyscph1bjlknm3nzh5g79cif22was1z411m5c"; - system = "random-access-lists"; - asd = "random-access-lists"; - }); - systems = [ "random-access-lists" ]; - lispLibs = [ (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - random-sample = (build-asdf-system { - pname = "random-sample"; - version = "20230618-git"; - asds = [ "random-sample" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/random-sample/2023-06-18/random-sample-20230618-git.tgz"; - sha256 = "13g5wgq6z3gx07qr3q17mgwfn2rsck5p1b9cfswajagl0m8z3f51"; - system = "random-sample"; - asd = "random-sample"; - }); - systems = [ "random-sample" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "infix-math" self) (getAttr "named-readtables" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - random-sampling = (build-asdf-system { - pname = "random-sampling"; - version = "20241012-git"; - asds = [ "random-sampling" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/random-sampling/2024-10-12/random-sampling-20241012-git.tgz"; - sha256 = "0c5cf7k37fh8h9dhcj9bfk9zx245i806wh7qkvh1g659kvl2gamj"; - system = "random-sampling"; - asd = "random-sampling"; - }); - systems = [ "random-sampling" ]; - lispLibs = [ (getAttr "_3d-math" self) (getAttr "documentation-utils" self) (getAttr "random-state" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - random-state = (build-asdf-system { - pname = "random-state"; - version = "20241012-git"; - asds = [ "random-state" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/random-state/2024-10-12/random-state-20241012-git.tgz"; - sha256 = "1iwcrn2fqvsw651wk60nm6x5hlmlvj04v8xxfxmzhqmx5f081f1g"; - system = "random-state"; - asd = "random-state"; - }); - systems = [ "random-state" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - random-state-test = (build-asdf-system { - pname = "random-state-test"; - version = "20241012-git"; - asds = [ "random-state-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/random-state/2024-10-12/random-state-20241012-git.tgz"; - sha256 = "1iwcrn2fqvsw651wk60nm6x5hlmlvj04v8xxfxmzhqmx5f081f1g"; - system = "random-state-test"; - asd = "random-state-test"; - }); - systems = [ "random-state-test" ]; - lispLibs = [ (getAttr "parachute" self) (getAttr "random-state" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - random-state-viewer = (build-asdf-system { - pname = "random-state-viewer"; - version = "20241012-git"; - asds = [ "random-state-viewer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/random-state/2024-10-12/random-state-20241012-git.tgz"; - sha256 = "1iwcrn2fqvsw651wk60nm6x5hlmlvj04v8xxfxmzhqmx5f081f1g"; - system = "random-state-viewer"; - asd = "random-state-viewer"; - }); - systems = [ "random-state-viewer" ]; - lispLibs = [ (getAttr "random-state" self) (getAttr "trivial-features" self) (getAttr "zpng" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - random-test = (build-asdf-system { - pname = "random-test"; - version = "20191007-git"; - asds = [ "random-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/random/2019-10-07/random-20191007-git.tgz"; - sha256 = "1fb4mnp85jm9s667y4dgz07klhkr9pvi5xbxws28lbb8iip75y2p"; - system = "random-test"; - asd = "random-test"; - }); - systems = [ "random-test" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_stefil" self) (getAttr "random" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - random-uuid = (build-asdf-system { - pname = "random-uuid"; - version = "20220707-git"; - asds = [ "random-uuid" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/random-uuid/2022-07-07/random-uuid-20220707-git.tgz"; - sha256 = "09yfi16gh12qg4pi13gbr5n881q5zvw7acq27a6sbqbkny35a6wj"; - system = "random-uuid"; - asd = "random-uuid"; - }); - systems = [ "random-uuid" ]; - lispLibs = [ (getAttr "mfiano-utils" self) (getAttr "seedable-rng" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rate-monotonic = (build-asdf-system { - pname = "rate-monotonic"; - version = "20200325-git"; - asds = [ "rate-monotonic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rate-monotonic/2020-03-25/rate-monotonic-20200325-git.tgz"; - sha256 = "0v9m704zy3834whldx2fbs8x92hp7hlrzdlcxm1rd17wqpv7pvrv"; - system = "rate-monotonic"; - asd = "rate-monotonic"; - }); - systems = [ "rate-monotonic" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "timer-wheel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rate-monotonic_dot_examples = (build-asdf-system { - pname = "rate-monotonic.examples"; - version = "20200325-git"; - asds = [ "rate-monotonic.examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rate-monotonic/2020-03-25/rate-monotonic-20200325-git.tgz"; - sha256 = "0v9m704zy3834whldx2fbs8x92hp7hlrzdlcxm1rd17wqpv7pvrv"; - system = "rate-monotonic.examples"; - asd = "rate-monotonic.examples"; - }); - systems = [ "rate-monotonic.examples" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "rate-monotonic" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ratify = (build-asdf-system { - pname = "ratify"; - version = "20231021-git"; - asds = [ "ratify" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ratify/2023-10-21/ratify-20231021-git.tgz"; - sha256 = "11fsamjjbc77kjhbsh0w9wkwbdq51paa07sxjb2brvcm0ji4hynf"; - system = "ratify"; - asd = "ratify"; - }); - systems = [ "ratify" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "local-time" self) (getAttr "parse-float" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ratmath = (build-asdf-system { - pname = "ratmath"; - version = "20200218-git"; - asds = [ "ratmath" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ratmath/2020-02-18/ratmath-20200218-git.tgz"; - sha256 = "1p5rl1bam8qjsgscn7gwk2w55hdjawfgjikka59lwb6ia13v4rj9"; - system = "ratmath"; - asd = "ratmath"; - }); - systems = [ "ratmath" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rcl = (build-asdf-system { - pname = "rcl"; - version = "20201220-http"; - asds = [ "rcl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rcl/2020-12-20/rcl-20201220-http.tgz"; - sha256 = "1s6cvqs0s7fxh63zwc5zj7ryrffmv780rscm7aq3alzb9njwmg14"; - system = "rcl"; - asd = "rcl"; - }); - systems = [ "rcl" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "named-readtables" self) (getAttr "prove-asdf" self) (getAttr "simple-tasks" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - re = (build-asdf-system { - pname = "re"; - version = "20210630-git"; - asds = [ "re" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/re/2021-06-30/re-20210630-git.tgz"; - sha256 = "15q4zvvzkxf1j0wxw0b1kz4d03js9cbgv82ndl8z6riz40kbffdp"; - system = "re"; - asd = "re"; - }); - systems = [ "re" ]; - lispLibs = [ (getAttr "parse" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - read-as-string = (build-asdf-system { - pname = "read-as-string"; - version = "20220707-git"; - asds = [ "read-as-string" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/read-as-string/2022-07-07/read-as-string-20220707-git.tgz"; - sha256 = "08dnnqmbadsrbsqr4n1x7rf0p46j9al0hw6la0z3jclp604dd0k3"; - system = "read-as-string"; - asd = "read-as-string"; - }); - systems = [ "read-as-string" ]; - lispLibs = [ (getAttr "core-reader" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - read-as-string_dot_test = (build-asdf-system { - pname = "read-as-string.test"; - version = "20220707-git"; - asds = [ "read-as-string.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/read-as-string/2022-07-07/read-as-string-20220707-git.tgz"; - sha256 = "08dnnqmbadsrbsqr4n1x7rf0p46j9al0hw6la0z3jclp604dd0k3"; - system = "read-as-string.test"; - asd = "read-as-string.test"; - }); - systems = [ "read-as-string.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "read-as-string" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - read-csv = (build-asdf-system { - pname = "read-csv"; - version = "20181018-git"; - asds = [ "read-csv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/read-csv/2018-10-18/read-csv-20181018-git.tgz"; - sha256 = "1wr6n8z7jm611xf2jwp3pw03qzq76440cmb75495l5p907lmrbcs"; - system = "read-csv"; - asd = "read-csv"; - }); - systems = [ "read-csv" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - read-csv_dot_test = (build-asdf-system { - pname = "read-csv.test"; - version = "20181018-git"; - asds = [ "read-csv.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/read-csv/2018-10-18/read-csv-20181018-git.tgz"; - sha256 = "1wr6n8z7jm611xf2jwp3pw03qzq76440cmb75495l5p907lmrbcs"; - system = "read-csv.test"; - asd = "read-csv"; - }); - systems = [ "read-csv.test" ]; - lispLibs = [ (getAttr "read-csv" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - read-number = (build-asdf-system { - pname = "read-number"; - version = "20230214-git"; - asds = [ "read-number" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/read-number/2023-02-14/read-number-20230214-git.tgz"; - sha256 = "1y2g2vbg9zccm9h8r7dabgb315z7jhr91d81wa2cccibpgccdyac"; - system = "read-number"; - asd = "read-number"; - }); - systems = [ "read-number" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reader = (build-asdf-system { - pname = "reader"; - version = "v0.10.0"; - asds = [ "reader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reader/2020-12-20/reader-v0.10.0.tgz"; - sha256 = "0pbv6w0d8d4qmfkdsz2rk21bp1las9r7pyvpmd95qjz7kpxrirl7"; - system = "reader"; - asd = "reader"; - }); - systems = [ "reader" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "fiveam" self) (getAttr "hash-set" self) (getAttr "iterate" self) (getAttr "split-sequence" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reader_plus_swank = (build-asdf-system { - pname = "reader+swank"; - version = "v0.10.0"; - asds = [ "reader+swank" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reader/2020-12-20/reader-v0.10.0.tgz"; - sha256 = "0pbv6w0d8d4qmfkdsz2rk21bp1las9r7pyvpmd95qjz7kpxrirl7"; - system = "reader+swank"; - asd = "reader+swank"; - }); - systems = [ "reader+swank" ]; - lispLibs = [ (getAttr "reader" self) (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reader-interception = (build-asdf-system { - pname = "reader-interception"; - version = "20150608-git"; - asds = [ "reader-interception" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reader-interception/2015-06-08/reader-interception-20150608-git.tgz"; - sha256 = "1f6xblayqb9q01qclvqx2gllqxm0qk8rmlp38rz433vgjxbq79y0"; - system = "reader-interception"; - asd = "reader-interception"; - }); - systems = [ "reader-interception" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reader-interception-test = (build-asdf-system { - pname = "reader-interception-test"; - version = "20150608-git"; - asds = [ "reader-interception-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reader-interception/2015-06-08/reader-interception-20150608-git.tgz"; - sha256 = "1f6xblayqb9q01qclvqx2gllqxm0qk8rmlp38rz433vgjxbq79y0"; - system = "reader-interception-test"; - asd = "reader-interception-test"; - }); - systems = [ "reader-interception-test" ]; - lispLibs = [ (getAttr "fare-utils" self) (getAttr "hu_dot_dwim_dot_stefil" self) (getAttr "reader-interception" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks = (build-asdf-system { - pname = "reblocks"; - version = "20241012-git"; - asds = [ "reblocks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks/2024-10-12/reblocks-20241012-git.tgz"; - sha256 = "0s8npy7bh013qhm6ngvi7ar117ja2m098nr4krnzlcg2ivxdff3i"; - system = "reblocks"; - asd = "reblocks"; - }); - systems = [ "reblocks" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "cl-cookie" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "cl-strings" self) (getAttr "clack" self) (getAttr "closer-mop" self) (getAttr "dexador" self) (getAttr "f-underscore" self) (getAttr "find-port" self) (getAttr "ironclad" self) (getAttr "jonathan" self) (getAttr "lack" self) (getAttr "lack-middleware-session" self) (getAttr "lack-request" self) (getAttr "lack-response" self) (getAttr "lack-util" self) (getAttr "local-time" self) (getAttr "log4cl" self) (getAttr "log4cl-extras" self) (getAttr "metacopy" self) (getAttr "metatilities" self) (getAttr "named-readtables" self) (getAttr "parenscript" self) (getAttr "puri" self) (getAttr "pythonic-string-reader" self) (getAttr "quri" self) (getAttr "routes" self) (getAttr "salza2" self) (getAttr "serapeum" self) (getAttr "spinneret" self) (getAttr "str" self) (getAttr "trivial-garbage" self) (getAttr "trivial-open-browser" self) (getAttr "trivial-timeout" self) (getAttr "uuid" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-auth = (build-asdf-system { - pname = "reblocks-auth"; - version = "20241012-git"; - asds = [ "reblocks-auth" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-auth/2024-10-12/reblocks-auth-20241012-git.tgz"; - sha256 = "1qydbk61a5xb2a61gj8mal0bmanhzynky1rh6lzwa10r5ybls4dq"; - system = "reblocks-auth"; - asd = "reblocks-auth"; - }); - systems = [ "reblocks-auth" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "alexandria" self) (getAttr "cl-strings" self) (getAttr "dexador" self) (getAttr "jonathan" self) (getAttr "local-time" self) (getAttr "log4cl" self) (getAttr "mailgun" self) (getAttr "mito" self) (getAttr "quri" self) (getAttr "reblocks" self) (getAttr "reblocks-lass" self) (getAttr "reblocks-ui" self) (getAttr "secret-values" self) (getAttr "serapeum" self) (getAttr "uuid" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-auth-ci = (build-asdf-system { - pname = "reblocks-auth-ci"; - version = "20241012-git"; - asds = [ "reblocks-auth-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-auth/2024-10-12/reblocks-auth-20241012-git.tgz"; - sha256 = "1qydbk61a5xb2a61gj8mal0bmanhzynky1rh6lzwa10r5ybls4dq"; - system = "reblocks-auth-ci"; - asd = "reblocks-auth-ci"; - }); - systems = [ "reblocks-auth-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-auth-example = (build-asdf-system { - pname = "reblocks-auth-example"; - version = "20241012-git"; - asds = [ "reblocks-auth-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-auth/2024-10-12/reblocks-auth-20241012-git.tgz"; - sha256 = "1qydbk61a5xb2a61gj8mal0bmanhzynky1rh6lzwa10r5ybls4dq"; - system = "reblocks-auth-example"; - asd = "reblocks-auth-example"; - }); - systems = [ "reblocks-auth-example" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "_40ants-logging" self) (getAttr "_40ants-slynk" self) (getAttr "cl_plus_ssl" self) (getAttr "clack-handler-hunchentoot" self) (getAttr "local-time" self) (getAttr "mito" self) (getAttr "reblocks" self) (getAttr "reblocks-auth" self) (getAttr "reblocks-lass" self) (getAttr "reblocks-navigation-widget" self) (getAttr "reblocks-prometheus" self) (getAttr "reblocks-ui" self) (getAttr "serapeum" self) (getAttr "spinneret" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-auth-tests = (build-asdf-system { - pname = "reblocks-auth-tests"; - version = "20241012-git"; - asds = [ "reblocks-auth-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-auth/2024-10-12/reblocks-auth-20241012-git.tgz"; - sha256 = "1qydbk61a5xb2a61gj8mal0bmanhzynky1rh6lzwa10r5ybls4dq"; - system = "reblocks-auth-tests"; - asd = "reblocks-auth-tests"; - }); - systems = [ "reblocks-auth-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-docs = (build-asdf-system { - pname = "reblocks-docs"; - version = "20241012-git"; - asds = [ "reblocks-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks/2024-10-12/reblocks-20241012-git.tgz"; - sha256 = "0s8npy7bh013qhm6ngvi7ar117ja2m098nr4krnzlcg2ivxdff3i"; - system = "reblocks-docs"; - asd = "reblocks-docs"; - }); - systems = [ "reblocks-docs" ]; - lispLibs = [ (getAttr "reblocks" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-file-server = (build-asdf-system { - pname = "reblocks-file-server"; - version = "20241012-git"; - asds = [ "reblocks-file-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-file-server/2024-10-12/reblocks-file-server-20241012-git.tgz"; - sha256 = "1v17v0474k845l0s0bgly3zbgq2rjn5fyh8zmjnisszgkdd3bh13"; - system = "reblocks-file-server"; - asd = "reblocks-file-server"; - }); - systems = [ "reblocks-file-server" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "log4cl" self) (getAttr "reblocks" self) (getAttr "routes" self) (getAttr "trivial-mimes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-file-server-ci = (build-asdf-system { - pname = "reblocks-file-server-ci"; - version = "20241012-git"; - asds = [ "reblocks-file-server-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-file-server/2024-10-12/reblocks-file-server-20241012-git.tgz"; - sha256 = "1v17v0474k845l0s0bgly3zbgq2rjn5fyh8zmjnisszgkdd3bh13"; - system = "reblocks-file-server-ci"; - asd = "reblocks-file-server-ci"; - }); - systems = [ "reblocks-file-server-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-file-server-docs = (build-asdf-system { - pname = "reblocks-file-server-docs"; - version = "20241012-git"; - asds = [ "reblocks-file-server-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-file-server/2024-10-12/reblocks-file-server-20241012-git.tgz"; - sha256 = "1v17v0474k845l0s0bgly3zbgq2rjn5fyh8zmjnisszgkdd3bh13"; - system = "reblocks-file-server-docs"; - asd = "reblocks-file-server-docs"; - }); - systems = [ "reblocks-file-server-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) (getAttr "reblocks-file-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-file-server-tests = (build-asdf-system { - pname = "reblocks-file-server-tests"; - version = "20241012-git"; - asds = [ "reblocks-file-server-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-file-server/2024-10-12/reblocks-file-server-20241012-git.tgz"; - sha256 = "1v17v0474k845l0s0bgly3zbgq2rjn5fyh8zmjnisszgkdd3bh13"; - system = "reblocks-file-server-tests"; - asd = "reblocks-file-server-tests"; - }); - systems = [ "reblocks-file-server-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-lass = (build-asdf-system { - pname = "reblocks-lass"; - version = "20241012-git"; - asds = [ "reblocks-lass" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-lass/2024-10-12/reblocks-lass-20241012-git.tgz"; - sha256 = "0aic2dnsp4hkc26fpnn0p493psz1fip9rfhbacfwaaqyxdgrh9cl"; - system = "reblocks-lass"; - asd = "reblocks-lass"; - }); - systems = [ "reblocks-lass" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "lass" self) (getAttr "reblocks" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-lass-ci = (build-asdf-system { - pname = "reblocks-lass-ci"; - version = "20241012-git"; - asds = [ "reblocks-lass-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-lass/2024-10-12/reblocks-lass-20241012-git.tgz"; - sha256 = "0aic2dnsp4hkc26fpnn0p493psz1fip9rfhbacfwaaqyxdgrh9cl"; - system = "reblocks-lass-ci"; - asd = "reblocks-lass-ci"; - }); - systems = [ "reblocks-lass-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-lass-docs = (build-asdf-system { - pname = "reblocks-lass-docs"; - version = "20241012-git"; - asds = [ "reblocks-lass-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-lass/2024-10-12/reblocks-lass-20241012-git.tgz"; - sha256 = "0aic2dnsp4hkc26fpnn0p493psz1fip9rfhbacfwaaqyxdgrh9cl"; - system = "reblocks-lass-docs"; - asd = "reblocks-lass-docs"; - }); - systems = [ "reblocks-lass-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) (getAttr "reblocks-lass" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-lass-tests = (build-asdf-system { - pname = "reblocks-lass-tests"; - version = "20241012-git"; - asds = [ "reblocks-lass-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-lass/2024-10-12/reblocks-lass-20241012-git.tgz"; - sha256 = "0aic2dnsp4hkc26fpnn0p493psz1fip9rfhbacfwaaqyxdgrh9cl"; - system = "reblocks-lass-tests"; - asd = "reblocks-lass-tests"; - }); - systems = [ "reblocks-lass-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-navigation-widget = (build-asdf-system { - pname = "reblocks-navigation-widget"; - version = "20241012-git"; - asds = [ "reblocks-navigation-widget" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-navigation-widget/2024-10-12/reblocks-navigation-widget-20241012-git.tgz"; - sha256 = "0gwfzlf8054g3iizbkbbzkxfmr8xlcvgcqycx7crlgzc8qksrqhm"; - system = "reblocks-navigation-widget"; - asd = "reblocks-navigation-widget"; - }); - systems = [ "reblocks-navigation-widget" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "log4cl" self) (getAttr "reblocks" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-navigation-widget-ci = (build-asdf-system { - pname = "reblocks-navigation-widget-ci"; - version = "20241012-git"; - asds = [ "reblocks-navigation-widget-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-navigation-widget/2024-10-12/reblocks-navigation-widget-20241012-git.tgz"; - sha256 = "0gwfzlf8054g3iizbkbbzkxfmr8xlcvgcqycx7crlgzc8qksrqhm"; - system = "reblocks-navigation-widget-ci"; - asd = "reblocks-navigation-widget-ci"; - }); - systems = [ "reblocks-navigation-widget-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-navigation-widget-docs = (build-asdf-system { - pname = "reblocks-navigation-widget-docs"; - version = "20241012-git"; - asds = [ "reblocks-navigation-widget-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-navigation-widget/2024-10-12/reblocks-navigation-widget-20241012-git.tgz"; - sha256 = "0gwfzlf8054g3iizbkbbzkxfmr8xlcvgcqycx7crlgzc8qksrqhm"; - system = "reblocks-navigation-widget-docs"; - asd = "reblocks-navigation-widget-docs"; - }); - systems = [ "reblocks-navigation-widget-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) (getAttr "reblocks-navigation-widget" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-navigation-widget-tests = (build-asdf-system { - pname = "reblocks-navigation-widget-tests"; - version = "20241012-git"; - asds = [ "reblocks-navigation-widget-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-navigation-widget/2024-10-12/reblocks-navigation-widget-20241012-git.tgz"; - sha256 = "0gwfzlf8054g3iizbkbbzkxfmr8xlcvgcqycx7crlgzc8qksrqhm"; - system = "reblocks-navigation-widget-tests"; - asd = "reblocks-navigation-widget-tests"; - }); - systems = [ "reblocks-navigation-widget-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-parenscript = (build-asdf-system { - pname = "reblocks-parenscript"; - version = "20241012-git"; - asds = [ "reblocks-parenscript" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-parenscript/2024-10-12/reblocks-parenscript-20241012-git.tgz"; - sha256 = "0c29y7k6kczzcz1fgsk0iyf93qsx4nmw3iir807zicya8dkvvpk6"; - system = "reblocks-parenscript"; - asd = "reblocks-parenscript"; - }); - systems = [ "reblocks-parenscript" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "parenscript" self) (getAttr "reblocks" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-parenscript-ci = (build-asdf-system { - pname = "reblocks-parenscript-ci"; - version = "20241012-git"; - asds = [ "reblocks-parenscript-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-parenscript/2024-10-12/reblocks-parenscript-20241012-git.tgz"; - sha256 = "0c29y7k6kczzcz1fgsk0iyf93qsx4nmw3iir807zicya8dkvvpk6"; - system = "reblocks-parenscript-ci"; - asd = "reblocks-parenscript-ci"; - }); - systems = [ "reblocks-parenscript-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-parenscript-docs = (build-asdf-system { - pname = "reblocks-parenscript-docs"; - version = "20241012-git"; - asds = [ "reblocks-parenscript-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-parenscript/2024-10-12/reblocks-parenscript-20241012-git.tgz"; - sha256 = "0c29y7k6kczzcz1fgsk0iyf93qsx4nmw3iir807zicya8dkvvpk6"; - system = "reblocks-parenscript-docs"; - asd = "reblocks-parenscript-docs"; - }); - systems = [ "reblocks-parenscript-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) (getAttr "reblocks-parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-parenscript-tests = (build-asdf-system { - pname = "reblocks-parenscript-tests"; - version = "20241012-git"; - asds = [ "reblocks-parenscript-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-parenscript/2024-10-12/reblocks-parenscript-20241012-git.tgz"; - sha256 = "0c29y7k6kczzcz1fgsk0iyf93qsx4nmw3iir807zicya8dkvvpk6"; - system = "reblocks-parenscript-tests"; - asd = "reblocks-parenscript-tests"; - }); - systems = [ "reblocks-parenscript-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-prometheus = (build-asdf-system { - pname = "reblocks-prometheus"; - version = "20241012-git"; - asds = [ "reblocks-prometheus" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-prometheus/2024-10-12/reblocks-prometheus-20241012-git.tgz"; - sha256 = "0bjzwk28csfdvnic2znil6cxk8fmh5p49n971q5pjs0dmwdzmwra"; - system = "reblocks-prometheus"; - asd = "reblocks-prometheus"; - }); - systems = [ "reblocks-prometheus" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "cffi-grovel" self) (getAttr "log4cl-extras" self) (getAttr "prometheus" self) (getAttr "prometheus-gc" self) (getAttr "prometheus_dot_collectors_dot_process" self) (getAttr "prometheus_dot_collectors_dot_sbcl" self) (getAttr "prometheus_dot_formats_dot_text" self) (getAttr "reblocks" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-prometheus-ci = (build-asdf-system { - pname = "reblocks-prometheus-ci"; - version = "20241012-git"; - asds = [ "reblocks-prometheus-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-prometheus/2024-10-12/reblocks-prometheus-20241012-git.tgz"; - sha256 = "0bjzwk28csfdvnic2znil6cxk8fmh5p49n971q5pjs0dmwdzmwra"; - system = "reblocks-prometheus-ci"; - asd = "reblocks-prometheus-ci"; - }); - systems = [ "reblocks-prometheus-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-prometheus-docs = (build-asdf-system { - pname = "reblocks-prometheus-docs"; - version = "20241012-git"; - asds = [ "reblocks-prometheus-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-prometheus/2024-10-12/reblocks-prometheus-20241012-git.tgz"; - sha256 = "0bjzwk28csfdvnic2znil6cxk8fmh5p49n971q5pjs0dmwdzmwra"; - system = "reblocks-prometheus-docs"; - asd = "reblocks-prometheus-docs"; - }); - systems = [ "reblocks-prometheus-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) (getAttr "reblocks-prometheus" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-prometheus-tests = (build-asdf-system { - pname = "reblocks-prometheus-tests"; - version = "20241012-git"; - asds = [ "reblocks-prometheus-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-prometheus/2024-10-12/reblocks-prometheus-20241012-git.tgz"; - sha256 = "0bjzwk28csfdvnic2znil6cxk8fmh5p49n971q5pjs0dmwdzmwra"; - system = "reblocks-prometheus-tests"; - asd = "reblocks-prometheus-tests"; - }); - systems = [ "reblocks-prometheus-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-tests = (build-asdf-system { - pname = "reblocks-tests"; - version = "20241012-git"; - asds = [ "reblocks-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks/2024-10-12/reblocks-20241012-git.tgz"; - sha256 = "0s8npy7bh013qhm6ngvi7ar117ja2m098nr4krnzlcg2ivxdff3i"; - system = "reblocks-tests"; - asd = "reblocks-tests"; - }); - systems = [ "reblocks-tests" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-mock" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "hamcrest" self) (getAttr "lack-request" self) (getAttr "lack-test" self) (getAttr "reblocks" self) (getAttr "rove" self) (getAttr "serapeum" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-typeahead = (build-asdf-system { - pname = "reblocks-typeahead"; - version = "20241012-git"; - asds = [ "reblocks-typeahead" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-typeahead/2024-10-12/reblocks-typeahead-20241012-git.tgz"; - sha256 = "150msgfsagpcpbgfva3hgnw3jhd3rg13g0ham9ns0lhf1lb3777m"; - system = "reblocks-typeahead"; - asd = "reblocks-typeahead"; - }); - systems = [ "reblocks-typeahead" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "parenscript" self) (getAttr "reblocks" self) (getAttr "reblocks-lass" self) (getAttr "reblocks-parenscript" self) (getAttr "reblocks-ui" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-typeahead-ci = (build-asdf-system { - pname = "reblocks-typeahead-ci"; - version = "20241012-git"; - asds = [ "reblocks-typeahead-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-typeahead/2024-10-12/reblocks-typeahead-20241012-git.tgz"; - sha256 = "150msgfsagpcpbgfva3hgnw3jhd3rg13g0ham9ns0lhf1lb3777m"; - system = "reblocks-typeahead-ci"; - asd = "reblocks-typeahead-ci"; - }); - systems = [ "reblocks-typeahead-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-typeahead-docs = (build-asdf-system { - pname = "reblocks-typeahead-docs"; - version = "20241012-git"; - asds = [ "reblocks-typeahead-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-typeahead/2024-10-12/reblocks-typeahead-20241012-git.tgz"; - sha256 = "150msgfsagpcpbgfva3hgnw3jhd3rg13g0ham9ns0lhf1lb3777m"; - system = "reblocks-typeahead-docs"; - asd = "reblocks-typeahead-docs"; - }); - systems = [ "reblocks-typeahead-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) (getAttr "reblocks-typeahead" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-typeahead-example = (build-asdf-system { - pname = "reblocks-typeahead-example"; - version = "20241012-git"; - asds = [ "reblocks-typeahead-example" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-typeahead/2024-10-12/reblocks-typeahead-20241012-git.tgz"; - sha256 = "150msgfsagpcpbgfva3hgnw3jhd3rg13g0ham9ns0lhf1lb3777m"; - system = "reblocks-typeahead-example"; - asd = "reblocks-typeahead-example"; - }); - systems = [ "reblocks-typeahead-example" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "_40ants-logging" self) (getAttr "_40ants-slynk" self) (getAttr "alexandria" self) (getAttr "clack-handler-hunchentoot" self) (getAttr "mito" self) (getAttr "reblocks" self) (getAttr "reblocks-auth" self) (getAttr "reblocks-lass" self) (getAttr "reblocks-navigation-widget" self) (getAttr "reblocks-prometheus" self) (getAttr "reblocks-typeahead" self) (getAttr "reblocks-ui" self) (getAttr "serapeum" self) (getAttr "spinneret" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-typeahead-tests = (build-asdf-system { - pname = "reblocks-typeahead-tests"; - version = "20241012-git"; - asds = [ "reblocks-typeahead-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-typeahead/2024-10-12/reblocks-typeahead-20241012-git.tgz"; - sha256 = "150msgfsagpcpbgfva3hgnw3jhd3rg13g0ham9ns0lhf1lb3777m"; - system = "reblocks-typeahead-tests"; - asd = "reblocks-typeahead-tests"; - }); - systems = [ "reblocks-typeahead-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-ui = (build-asdf-system { - pname = "reblocks-ui"; - version = "20241012-git"; - asds = [ "reblocks-ui" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-ui/2024-10-12/reblocks-ui-20241012-git.tgz"; - sha256 = "1iwq62ba0rsiqw34d681nzg88wzps1f3d1ahl99crrk9xpy1c3y5"; - system = "reblocks-ui"; - asd = "reblocks-ui"; - }); - systems = [ "reblocks-ui" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "log4cl" self) (getAttr "log4cl-extras" self) (getAttr "parenscript" self) (getAttr "quri" self) (getAttr "reblocks" self) (getAttr "reblocks-parenscript" self) (getAttr "serapeum" self) (getAttr "spinneret" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-ui-docs = (build-asdf-system { - pname = "reblocks-ui-docs"; - version = "20241012-git"; - asds = [ "reblocks-ui-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-ui/2024-10-12/reblocks-ui-20241012-git.tgz"; - sha256 = "1iwq62ba0rsiqw34d681nzg88wzps1f3d1ahl99crrk9xpy1c3y5"; - system = "reblocks-ui-docs"; - asd = "reblocks-ui-docs"; - }); - systems = [ "reblocks-ui-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "docs-config" self) (getAttr "reblocks" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-ui-examples = (build-asdf-system { - pname = "reblocks-ui-examples"; - version = "20241012-git"; - asds = [ "reblocks-ui-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-ui/2024-10-12/reblocks-ui-20241012-git.tgz"; - sha256 = "1iwq62ba0rsiqw34d681nzg88wzps1f3d1ahl99crrk9xpy1c3y5"; - system = "reblocks-ui-examples"; - asd = "reblocks-ui-examples"; - }); - systems = [ "reblocks-ui-examples" ]; - lispLibs = [ (getAttr "reblocks" self) (getAttr "reblocks-lass" self) (getAttr "reblocks-ui" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-websocket = (build-asdf-system { - pname = "reblocks-websocket"; - version = "20241012-git"; - asds = [ "reblocks-websocket" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-websocket/2024-10-12/reblocks-websocket-20241012-git.tgz"; - sha256 = "0zn14if637cfadz93cgyk79hqrjyzddwc483gl10386rj9nvcf6b"; - system = "reblocks-websocket"; - asd = "reblocks-websocket"; - }); - systems = [ "reblocks-websocket" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "jonathan" self) (getAttr "log4cl-extras" self) (getAttr "parenscript" self) (getAttr "reblocks" self) (getAttr "reblocks-parenscript" self) (getAttr "serapeum" self) (getAttr "websocket-driver" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-websocket-ci = (build-asdf-system { - pname = "reblocks-websocket-ci"; - version = "20241012-git"; - asds = [ "reblocks-websocket-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-websocket/2024-10-12/reblocks-websocket-20241012-git.tgz"; - sha256 = "0zn14if637cfadz93cgyk79hqrjyzddwc483gl10386rj9nvcf6b"; - system = "reblocks-websocket-ci"; - asd = "reblocks-websocket-ci"; - }); - systems = [ "reblocks-websocket-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-websocket-docs = (build-asdf-system { - pname = "reblocks-websocket-docs"; - version = "20241012-git"; - asds = [ "reblocks-websocket-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-websocket/2024-10-12/reblocks-websocket-20241012-git.tgz"; - sha256 = "0zn14if637cfadz93cgyk79hqrjyzddwc483gl10386rj9nvcf6b"; - system = "reblocks-websocket-docs"; - asd = "reblocks-websocket-docs"; - }); - systems = [ "reblocks-websocket-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) (getAttr "reblocks-websocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reblocks-websocket-tests = (build-asdf-system { - pname = "reblocks-websocket-tests"; - version = "20241012-git"; - asds = [ "reblocks-websocket-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reblocks-websocket/2024-10-12/reblocks-websocket-20241012-git.tgz"; - sha256 = "0zn14if637cfadz93cgyk79hqrjyzddwc483gl10386rj9nvcf6b"; - system = "reblocks-websocket-tests"; - asd = "reblocks-websocket-tests"; - }); - systems = [ "reblocks-websocket-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rectangle-packing = (build-asdf-system { - pname = "rectangle-packing"; - version = "20130615-git"; - asds = [ "rectangle-packing" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rectangle-packing/2013-06-15/rectangle-packing-20130615-git.tgz"; - sha256 = "1m31qbgkrgbp753mr012hpzjfddwmfzvazaadp3s6wd34vmbbv01"; - system = "rectangle-packing"; - asd = "rectangle-packing"; - }); - systems = [ "rectangle-packing" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - recur = (build-asdf-system { - pname = "recur"; - version = "20230618-git"; - asds = [ "recur" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/recur/2023-06-18/recur-20230618-git.tgz"; - sha256 = "1wlw378h3k4ganw49kk5zrhx3w692yfdb4zaiciwqzviwz52c7gc"; - system = "recur"; - asd = "recur"; - }); - systems = [ "recur" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - recursive-regex = (build-asdf-system { - pname = "recursive-regex"; - version = "20120407-git"; - asds = [ "recursive-regex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/recursive-regex/2012-04-07/recursive-regex-20120407-git.tgz"; - sha256 = "1alsfqfa85dwms7i3xrbp6ahlqk9a3sl8d4llxy1ydb0rlb09l4r"; - system = "recursive-regex"; - asd = "recursive-regex"; - }); - systems = [ "recursive-regex" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "iterate" self) (getAttr "symbol-munger" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - recursive-regex-test = (build-asdf-system { - pname = "recursive-regex-test"; - version = "20120407-git"; - asds = [ "recursive-regex-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/recursive-regex/2012-04-07/recursive-regex-20120407-git.tgz"; - sha256 = "1alsfqfa85dwms7i3xrbp6ahlqk9a3sl8d4llxy1ydb0rlb09l4r"; - system = "recursive-regex-test"; - asd = "recursive-regex"; - }); - systems = [ "recursive-regex-test" ]; - lispLibs = [ (getAttr "lisp-unit" self) (getAttr "recursive-regex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - recursive-restart = (build-asdf-system { - pname = "recursive-restart"; - version = "20161031-git"; - asds = [ "recursive-restart" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/recursive-restart/2016-10-31/recursive-restart-20161031-git.tgz"; - sha256 = "0lgw95bnzw99avrb7vcg02fbw3y5mazfgnkim8gsazfjliaj21m7"; - system = "recursive-restart"; - asd = "recursive-restart"; - }); - systems = [ "recursive-restart" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - red-black-tree = (build-asdf-system { - pname = "red-black-tree"; - version = "20220707-git"; - asds = [ "red-black-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/red-black-tree/2022-07-07/red-black-tree-20220707-git.tgz"; - sha256 = "0dbl6y4l7k30a13d6rfdfby6p27li5b17nvz7xgyajxl9q5zz5kk"; - system = "red-black-tree"; - asd = "red-black-tree"; - }); - systems = [ "red-black-tree" ]; - lispLibs = [ (getAttr "mfiano-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - redirect-stream = (build-asdf-system { - pname = "redirect-stream"; - version = "20231021-git"; - asds = [ "redirect-stream" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/redirect-stream/2023-10-21/redirect-stream-20231021-git.tgz"; - sha256 = "1x8m2jk02dmsc2y8kq5h1bkdl51qz3ldg58hdzj6dpyi6ciykj28"; - system = "redirect-stream"; - asd = "redirect-stream"; - }); - systems = [ "redirect-stream" ]; - lispLibs = [ (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - regex = (build-asdf-system { - pname = "regex"; - version = "20120909-git"; - asds = [ "regex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regex/2012-09-09/regex-20120909-git.tgz"; - sha256 = "0wq5wlafrxv13wg28hg5b10sc48b88swsvznpy2zg7x37m4nmm6a"; - system = "regex"; - asd = "regex"; - }); - systems = [ "regex" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - remote-js = (build-asdf-system { - pname = "remote-js"; - version = "20190710-git"; - asds = [ "remote-js" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/remote-js/2019-07-10/remote-js-20190710-git.tgz"; - sha256 = "1z8apvfng8i7x4dsnz9da4y2l9mr7jykm19lmq3070qra7r3lby6"; - system = "remote-js"; - asd = "remote-js"; - }); - systems = [ "remote-js" ]; - lispLibs = [ (getAttr "cl-markup" self) (getAttr "find-port" self) (getAttr "trivial-ws" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - remote-js-test = (build-asdf-system { - pname = "remote-js-test"; - version = "20190710-git"; - asds = [ "remote-js-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/remote-js/2019-07-10/remote-js-20190710-git.tgz"; - sha256 = "1z8apvfng8i7x4dsnz9da4y2l9mr7jykm19lmq3070qra7r3lby6"; - system = "remote-js-test"; - asd = "remote-js-test"; - }); - systems = [ "remote-js-test" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "fiveam" self) (getAttr "remote-js" self) (getAttr "trivial-open-browser" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - repl-utilities = (build-asdf-system { - pname = "repl-utilities"; - version = "20210228-git"; - asds = [ "repl-utilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/repl-utilities/2021-02-28/repl-utilities-20210228-git.tgz"; - sha256 = "1hh56pq5nw3l4b83dzlyss69f06r038byj2cnjwvci4hfjhdfcc3"; - system = "repl-utilities"; - asd = "repl-utilities"; - }); - systems = [ "repl-utilities" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - replic = (build-asdf-system { - pname = "replic"; - version = "20230214-git"; - asds = [ "replic" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/replic/2023-02-14/replic-20230214-git.tgz"; - sha256 = "1jq0ysgpkcsw2fbxjy0v9kqvfnrdwzvrzc1a7fykihds548z3slf"; - system = "replic"; - asd = "replic"; - }); - systems = [ "replic" ]; - lispLibs = [ (getAttr "cl-ansi-text" self) (getAttr "cl-readline" self) (getAttr "py-configparser" self) (getAttr "shlex" self) (getAttr "str" self) (getAttr "unix-opts" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - replic-test = (build-asdf-system { - pname = "replic-test"; - version = "20230214-git"; - asds = [ "replic-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/replic/2023-02-14/replic-20230214-git.tgz"; - sha256 = "1jq0ysgpkcsw2fbxjy0v9kqvfnrdwzvrzc1a7fykihds548z3slf"; - system = "replic-test"; - asd = "replic-test"; - }); - systems = [ "replic-test" ]; - lispLibs = [ (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "replic" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - research = (build-asdf-system { - pname = "research"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "research" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "research"; - asd = "research"; - }); - systems = [ "research" ]; - lispLibs = [ (getAttr "_2d-array-test" self) (getAttr "adjuvant" self) (getAttr "adjuvant-test" self) (getAttr "dispatch-test" self) (getAttr "ndfa-test" self) (getAttr "rte-regexp-test" self) (getAttr "rte-test" self) (getAttr "scrutiny" self) (getAttr "scrutiny-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - resignal-bind = (build-asdf-system { - pname = "resignal-bind"; - version = "20211020-git"; - asds = [ "resignal-bind" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/resignal-bind/2021-10-20/resignal-bind-20211020-git.tgz"; - sha256 = "109b5bf2h3yqax87r16dsbnb0xdd9kqi0zdisy0wja1h622yrxhc"; - system = "resignal-bind"; - asd = "resignal-bind"; - }); - systems = [ "resignal-bind" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "jingoh_dot_documentizer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - resignal-bind_dot_test = (build-asdf-system { - pname = "resignal-bind.test"; - version = "20211020-git"; - asds = [ "resignal-bind.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/resignal-bind/2021-10-20/resignal-bind-20211020-git.tgz"; - sha256 = "109b5bf2h3yqax87r16dsbnb0xdd9kqi0zdisy0wja1h622yrxhc"; - system = "resignal-bind.test"; - asd = "resignal-bind.test"; - }); - systems = [ "resignal-bind.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "resignal-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - restas = (build-asdf-system { - pname = "restas"; - version = "20191008-git"; - asds = [ "restas" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/restas/2019-10-08/restas-20191008-git.tgz"; - sha256 = "00ng6jik1lwjw3bbxhijy8s0ml24lgm73liwrr01gcsb0r6wrjjn"; - system = "restas"; - asd = "restas"; - }); - systems = [ "restas" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "data-sift" self) (getAttr "hunchentoot" self) (getAttr "routes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - restas-directory-publisher = (build-asdf-system { - pname = "restas-directory-publisher"; - version = "20130128-git"; - asds = [ "restas-directory-publisher" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/restas-directory-publisher/2013-01-28/restas-directory-publisher-20130128-git.tgz"; - sha256 = "1ra4bxsg9v507zrqjx78ak3797clagl6n62d3bx0aghrnkal1gmp"; - system = "restas-directory-publisher"; - asd = "restas-directory-publisher"; - }); - systems = [ "restas-directory-publisher" ]; - lispLibs = [ (getAttr "closure-template" self) (getAttr "local-time" self) (getAttr "restas" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - restas-doc = (build-asdf-system { - pname = "restas-doc"; - version = "20191008-git"; - asds = [ "restas-doc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/restas/2019-10-08/restas-20191008-git.tgz"; - sha256 = "00ng6jik1lwjw3bbxhijy8s0ml24lgm73liwrr01gcsb0r6wrjjn"; - system = "restas-doc"; - asd = "restas-doc"; - }); - systems = [ "restas-doc" ]; - lispLibs = [ (getAttr "restas" self) (getAttr "restas-directory-publisher" self) (getAttr "sphinx" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - restas_dot_file-publisher = (build-asdf-system { - pname = "restas.file-publisher"; - version = "20120107-git"; - asds = [ "restas.file-publisher" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/restas.file-publisher/2012-01-07/restas.file-publisher-20120107-git.tgz"; - sha256 = "12h291as21ziqb1l6p2p4hy429z6zznacp1gn0m2vah7f811q75l"; - system = "restas.file-publisher"; - asd = "restas.file-publisher"; - }); - systems = [ "restas.file-publisher" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "restas" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - restful = (build-asdf-system { - pname = "restful"; - version = "20150608-git"; - asds = [ "restful" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/restful/2015-06-08/restful-20150608-git.tgz"; - sha256 = "1imcpd9zm1dbb1675pf3g3d6w9vyxk07g7r33174qdw470j8ml5n"; - system = "restful"; - asd = "restful"; - }); - systems = [ "restful" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "hunchentoot" self) (getAttr "jonathan" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - restful-test = (build-asdf-system { - pname = "restful-test"; - version = "20150608-git"; - asds = [ "restful-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/restful/2015-06-08/restful-20150608-git.tgz"; - sha256 = "1imcpd9zm1dbb1675pf3g3d6w9vyxk07g7r33174qdw470j8ml5n"; - system = "restful-test"; - asd = "restful-test"; - }); - systems = [ "restful-test" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "restful" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - restricted-functions = (build-asdf-system { - pname = "restricted-functions"; - version = "20190521-git"; - asds = [ "restricted-functions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/restricted-functions/2019-05-21/restricted-functions-20190521-git.tgz"; - sha256 = "092k7bp6n8kppf2wdqf1kf1h8lrww6k1dcxp05dby779b8c6kfz4"; - system = "restricted-functions"; - asd = "restricted-functions"; - }); - systems = [ "restricted-functions" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "simplified-types" self) (getAttr "trivia" self) (getAttr "trivial-arguments" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - retrospectiff = (build-asdf-system { - pname = "retrospectiff"; - version = "20211209-git"; - asds = [ "retrospectiff" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/retrospectiff/2021-12-09/retrospectiff-20211209-git.tgz"; - sha256 = "1vfcbfzhkm2wkxnjg7y6gg93wlib9cqpbdbhyqcm5kc7170ci3vz"; - system = "retrospectiff"; - asd = "retrospectiff"; - }); - systems = [ "retrospectiff" ]; - lispLibs = [ (getAttr "cl-jpeg" self) (getAttr "com_dot_gigamonkeys_dot_binary-data" self) (getAttr "deflate" self) (getAttr "flexi-streams" self) (getAttr "ieee-floats" self) (getAttr "opticl-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - reversi = (build-asdf-system { - pname = "reversi"; - version = "20201016-git"; - asds = [ "reversi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/reversi/2020-10-16/reversi-20201016-git.tgz"; - sha256 = "1vwjk207hvn5skazmkrcifkv4ia9nm5312rj0fr3w5423dr56swx"; - system = "reversi"; - asd = "reversi"; - }); - systems = [ "reversi" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rfc2109 = (build-asdf-system { - pname = "rfc2109"; - version = "20151218-darcs"; - asds = [ "rfc2109" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rfc2109/2015-12-18/rfc2109-20151218-darcs.tgz"; - sha256 = "1y767qjv5jxyfqzp0zpw96yz95mb8hhpjj9dn2i6b92r0z2vr42d"; - system = "rfc2109"; - asd = "rfc2109"; - }); - systems = [ "rfc2109" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rfc2388 = (build-asdf-system { - pname = "rfc2388"; - version = "20180831-git"; - asds = [ "rfc2388" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rfc2388/2018-08-31/rfc2388-20180831-git.tgz"; - sha256 = "0phh5n3clhl9ji8jaxrajidn22d3f0aq87mlbfkkxlnx2pnw694k"; - system = "rfc2388"; - asd = "rfc2388"; - }); - systems = [ "rfc2388" ]; - lispLibs = [ ]; - meta = {}; - }); - rfc2388-binary = (build-asdf-system { - pname = "rfc2388-binary"; - version = "20170124-darcs"; - asds = [ "rfc2388-binary" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rfc2388-binary/2017-01-24/rfc2388-binary-20170124-darcs.tgz"; - sha256 = "1ddjhd9vqramg93963d4py9a2hqpy1fr1ly517r3bpjx7a5mffwk"; - system = "rfc2388-binary"; - asd = "rfc2388-binary"; - }); - systems = [ "rfc2388-binary" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rlc = (build-asdf-system { - pname = "rlc"; - version = "20150923-git"; - asds = [ "rlc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rlc/2015-09-23/rlc-20150923-git.tgz"; - sha256 = "1c37as5x45yizs76s7115a0w3fgas80bjb8xzq7yylpmxq44s2rk"; - system = "rlc"; - asd = "rlc"; - }); - systems = [ "rlc" ]; - lispLibs = [ (getAttr "kmrcl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - roan = (build-asdf-system { - pname = "roan"; - version = "20201220-git"; - asds = [ "roan" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/roan/2020-12-20/roan-20201220-git.tgz"; - sha256 = "032znprz03x4apzssb5vzs55cfdfyvca56bcrwxwm9dgkh3cnh7z"; - system = "roan"; - asd = "roan"; - }); - systems = [ "roan" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "asdf-encodings" self) (getAttr "binascii" self) (getAttr "cl-fad" self) (getAttr "cl-interpol" self) (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "iterate" self) (getAttr "local-time" self) (getAttr "named-readtables" self) (getAttr "plump" self) (getAttr "uuid" self) (getAttr "zip" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - robot = (build-asdf-system { - pname = "robot"; - version = "master-fe503896-git"; - asds = [ "robot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "robot"; - asd = "robot"; - }); - systems = [ "robot" ]; - lispLibs = [ (getAttr "gwl-graphics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rock = (build-asdf-system { - pname = "rock"; - version = "20150608-git"; - asds = [ "rock" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rock/2015-06-08/rock-20150608-git.tgz"; - sha256 = "1ckvxswinv25vzwmyrr6k7m9cx99kl04b4543mlxad9688np91y8"; - system = "rock"; - asd = "rock"; - }); - systems = [ "rock" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "trivial-download" self) (getAttr "trivial-extract" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rock-test = (build-asdf-system { - pname = "rock-test"; - version = "20150608-git"; - asds = [ "rock-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rock/2015-06-08/rock-20150608-git.tgz"; - sha256 = "1ckvxswinv25vzwmyrr6k7m9cx99kl04b4543mlxad9688np91y8"; - system = "rock-test"; - asd = "rock-test"; - }); - systems = [ "rock-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "rock" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rock-web = (build-asdf-system { - pname = "rock-web"; - version = "20150608-git"; - asds = [ "rock-web" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rock/2015-06-08/rock-20150608-git.tgz"; - sha256 = "1ckvxswinv25vzwmyrr6k7m9cx99kl04b4543mlxad9688np91y8"; - system = "rock-web"; - asd = "rock-web"; - }); - systems = [ "rock-web" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "_3bmd-ext-code-blocks" self) (getAttr "_3bmd-ext-definition-lists" self) (getAttr "cl-markup" self) (getAttr "lass" self) (getAttr "rock" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - romreader = (build-asdf-system { - pname = "romreader"; - version = "20140713-git"; - asds = [ "romreader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/romreader/2014-07-13/romreader-20140713-git.tgz"; - sha256 = "1k3fnh48vy5wdbqif4hmflmxc3xnihyi1222cldcjvxl294yk6xx"; - system = "romreader"; - asd = "romreader"; - }); - systems = [ "romreader" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - routes = (build-asdf-system { - pname = "routes"; - version = "20170124-git"; - asds = [ "routes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-routes/2017-01-24/cl-routes-20170124-git.tgz"; - sha256 = "1zpk3cp2v8hm50ppjl10yxr437vv4552r8hylvizglzrq2ibsbr1"; - system = "routes"; - asd = "routes"; - }); - systems = [ "routes" ]; - lispLibs = [ (getAttr "iterate" self) (getAttr "puri" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - routes-test = (build-asdf-system { - pname = "routes-test"; - version = "20170124-git"; - asds = [ "routes-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-routes/2017-01-24/cl-routes-20170124-git.tgz"; - sha256 = "1zpk3cp2v8hm50ppjl10yxr437vv4552r8hylvizglzrq2ibsbr1"; - system = "routes-test"; - asd = "routes"; - }); - systems = [ "routes-test" ]; - lispLibs = [ (getAttr "lift" self) (getAttr "routes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rove = (build-asdf-system { - pname = "rove"; - version = "20241012-git"; - asds = [ "rove" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rove/2024-10-12/rove-20241012-git.tgz"; - sha256 = "1cx55d8frlk8rzdwbf1698rsvy34gx0ws2ix257qsh7gxy2mld05"; - system = "rove"; - asd = "rove"; - }); - systems = [ "rove" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "dissect" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - rovers-problem-translator = (build-asdf-system { - pname = "rovers-problem-translator"; - version = "20241012-git"; - asds = [ "rovers-problem-translator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/shop3/2024-10-12/shop3-20241012-git.tgz"; - sha256 = "1sdyyyd82fqmm9lcqmg7k8yy3l3891m2gjwidibzvk95bp4xf9sd"; - system = "rovers-problem-translator"; - asd = "rovers-problem-translator"; - }); - systems = [ "rovers-problem-translator" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "shop3" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rpcq = (build-asdf-system { - pname = "rpcq"; - version = "v3.10.0"; - asds = [ "rpcq" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rpcq/2022-07-07/rpcq-v3.10.0.tgz"; - sha256 = "1bvppxlacvp0pfdbpn7ls1zxd127jacl225ds7lph5s8f8cyvf17"; - system = "rpcq"; - asd = "rpcq"; - }); - systems = [ "rpcq" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-messagepack" self) (getAttr "cl-ppcre" self) (getAttr "cl-syslog" self) (getAttr "flexi-streams" self) (getAttr "local-time" self) (getAttr "parse-float" self) (getAttr "pzmq" self) (getAttr "trivial-backtrace" self) (getAttr "uuid" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rpcq-tests = (build-asdf-system { - pname = "rpcq-tests"; - version = "v3.10.0"; - asds = [ "rpcq-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rpcq/2022-07-07/rpcq-v3.10.0.tgz"; - sha256 = "1bvppxlacvp0pfdbpn7ls1zxd127jacl225ds7lph5s8f8cyvf17"; - system = "rpcq-tests"; - asd = "rpcq-tests"; - }); - systems = [ "rpcq-tests" ]; - lispLibs = [ (getAttr "cl-messagepack" self) (getAttr "cl-syslog" self) (getAttr "fiasco" self) (getAttr "rpcq" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rpm = (build-asdf-system { - pname = "rpm"; - version = "20160421-git"; - asds = [ "rpm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rpm/2016-04-21/rpm-20160421-git.tgz"; - sha256 = "0qn4vw3pvjm0maksl57mwikcmv7calzlblp5s01ixrn3nrgxmd9k"; - system = "rpm"; - asd = "rpm"; - }); - systems = [ "rpm" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "fare-utils" self) (getAttr "inferior-shell" self) (getAttr "lambda-reader" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rs-colors = (build-asdf-system { - pname = "rs-colors"; - version = "20220331-git"; - asds = [ "rs-colors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; - sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; - system = "rs-colors"; - asd = "rs-colors"; - }); - systems = [ "rs-colors" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "iterate" self) (getAttr "read-number" self) (getAttr "rs-colors-internal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rs-colors-html = (build-asdf-system { - pname = "rs-colors-html"; - version = "20220331-git"; - asds = [ "rs-colors-html" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; - sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; - system = "rs-colors-html"; - asd = "rs-colors-html"; - }); - systems = [ "rs-colors-html" ]; - lispLibs = [ (getAttr "rs-colors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rs-colors-internal = (build-asdf-system { - pname = "rs-colors-internal"; - version = "20220331-git"; - asds = [ "rs-colors-internal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; - sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; - system = "rs-colors-internal"; - asd = "rs-colors-internal"; - }); - systems = [ "rs-colors-internal" ]; - lispLibs = [ (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rs-colors-material-io = (build-asdf-system { - pname = "rs-colors-material-io"; - version = "20220331-git"; - asds = [ "rs-colors-material-io" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; - sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; - system = "rs-colors-material-io"; - asd = "rs-colors-material-io"; - }); - systems = [ "rs-colors-material-io" ]; - lispLibs = [ (getAttr "rs-colors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rs-colors-ral = (build-asdf-system { - pname = "rs-colors-ral"; - version = "20220331-git"; - asds = [ "rs-colors-ral" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; - sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; - system = "rs-colors-ral"; - asd = "rs-colors-ral"; - }); - systems = [ "rs-colors-ral" ]; - lispLibs = [ (getAttr "rs-colors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rs-colors-ral-design = (build-asdf-system { - pname = "rs-colors-ral-design"; - version = "20220331-git"; - asds = [ "rs-colors-ral-design" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; - sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; - system = "rs-colors-ral-design"; - asd = "rs-colors-ral-design"; - }); - systems = [ "rs-colors-ral-design" ]; - lispLibs = [ (getAttr "rs-colors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rs-colors-svg = (build-asdf-system { - pname = "rs-colors-svg"; - version = "20220331-git"; - asds = [ "rs-colors-svg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; - sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; - system = "rs-colors-svg"; - asd = "rs-colors-svg"; - }); - systems = [ "rs-colors-svg" ]; - lispLibs = [ (getAttr "rs-colors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rs-colors-tango = (build-asdf-system { - pname = "rs-colors-tango"; - version = "20220331-git"; - asds = [ "rs-colors-tango" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; - sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; - system = "rs-colors-tango"; - asd = "rs-colors-tango"; - }); - systems = [ "rs-colors-tango" ]; - lispLibs = [ (getAttr "rs-colors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rs-colors-x11 = (build-asdf-system { - pname = "rs-colors-x11"; - version = "20220331-git"; - asds = [ "rs-colors-x11" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; - sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; - system = "rs-colors-x11"; - asd = "rs-colors-x11"; - }); - systems = [ "rs-colors-x11" ]; - lispLibs = [ (getAttr "rs-colors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rs-dlx = (build-asdf-system { - pname = "rs-dlx"; - version = "20241012-git"; - asds = [ "rs-dlx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rs-dlx/2024-10-12/rs-dlx-20241012-git.tgz"; - sha256 = "003ykkh61hg5q9lxjckqp8njhpgg21j9008gcsw60hnxdipmanaf"; - system = "rs-dlx"; - asd = "rs-dlx"; - }); - systems = [ "rs-dlx" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rs-json = (build-asdf-system { - pname = "rs-json"; - version = "20230618-git"; - asds = [ "rs-json" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rs-json/2023-06-18/rs-json-20230618-git.tgz"; - sha256 = "0y71as0sg5vfijpzdhv6pj6yv064ldn2shx0y4da8kvaqv949dnq"; - system = "rs-json"; - asd = "rs-json"; - }); - systems = [ "rs-json" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-unicode" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rss = (build-asdf-system { - pname = "rss"; - version = "20201016-git"; - asds = [ "rss" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-rss/2020-10-16/cl-rss-20201016-git.tgz"; - sha256 = "0wv3j13fj73gigriw5r9vi920hz05ld7zllsvbxdxvmyfy9k1kly"; - system = "rss"; - asd = "rss"; - }); - systems = [ "rss" ]; - lispLibs = [ (getAttr "aserve" self) (getAttr "kmrcl" self) (getAttr "xmls" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rt = (build-asdf-system { - pname = "rt"; - version = "20101006-git"; - asds = [ "rt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rt/2010-10-06/rt-20101006-git.tgz"; - sha256 = "13si2rrxaagbr0bkvg6sqicxxpyshabx6ad6byc9n2ik5ysna69b"; - system = "rt"; - asd = "rt"; - }); - systems = [ "rt" ]; - lispLibs = [ ]; - meta = {}; - }); - rt-events = (build-asdf-system { - pname = "rt-events"; - version = "20160318-git"; - asds = [ "rt-events" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rt-events/2016-03-18/rt-events-20160318-git.tgz"; - sha256 = "17wqhczsi4mq00fp5hfc38b9ijdiaqjh7cvxhy714qqz3f5mxzdw"; - system = "rt-events"; - asd = "rt-events"; - }); - systems = [ "rt-events" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rt-events_dot_examples = (build-asdf-system { - pname = "rt-events.examples"; - version = "20160318-git"; - asds = [ "rt-events.examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rt-events/2016-03-18/rt-events-20160318-git.tgz"; - sha256 = "17wqhczsi4mq00fp5hfc38b9ijdiaqjh7cvxhy714qqz3f5mxzdw"; - system = "rt-events.examples"; - asd = "rt-events.examples"; - }); - systems = [ "rt-events.examples" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "rt-events" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rte = (build-asdf-system { - pname = "rte"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "rte" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "rte"; - asd = "rte"; - }); - systems = [ "rte" ]; - lispLibs = [ (getAttr "adjuvant" self) (getAttr "lisp-types" self) (getAttr "ndfa" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rte-regexp = (build-asdf-system { - pname = "rte-regexp"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "rte-regexp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "rte-regexp"; - asd = "rte-regexp"; - }); - systems = [ "rte-regexp" ]; - lispLibs = [ (getAttr "adjuvant" self) (getAttr "rte" self) (getAttr "yacc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rte-regexp-test = (build-asdf-system { - pname = "rte-regexp-test"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "rte-regexp-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "rte-regexp-test"; - asd = "rte-regexp-test"; - }); - systems = [ "rte-regexp-test" ]; - lispLibs = [ (getAttr "adjuvant" self) (getAttr "rte" self) (getAttr "rte-regexp" self) (getAttr "scrutiny" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rte-test = (build-asdf-system { - pname = "rte-test"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "rte-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "rte-test"; - asd = "rte-test"; - }); - systems = [ "rte-test" ]; - lispLibs = [ (getAttr "_2d-array" self) (getAttr "_2d-array-test" self) (getAttr "adjuvant" self) (getAttr "lisp-types-test" self) (getAttr "ndfa-test" self) (getAttr "rte" self) (getAttr "rte-regexp-test" self) (getAttr "scrutiny" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rtg-math = (build-asdf-system { - pname = "rtg-math"; - version = "release-quicklisp-29fc5b3d-git"; - asds = [ "rtg-math" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rtg-math/2019-10-07/rtg-math-release-quicklisp-29fc5b3d-git.tgz"; - sha256 = "0bhxxnv7ldkkb18zdxyz2rj2a3iawzq2kcp7cn5i91iby7n0082x"; - system = "rtg-math"; - asd = "rtg-math"; - }); - systems = [ "rtg-math" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "documentation-utils" self) (getAttr "glsl-symbols" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rtg-math_dot_vari = (build-asdf-system { - pname = "rtg-math.vari"; - version = "release-quicklisp-29fc5b3d-git"; - asds = [ "rtg-math.vari" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rtg-math/2019-10-07/rtg-math-release-quicklisp-29fc5b3d-git.tgz"; - sha256 = "0bhxxnv7ldkkb18zdxyz2rj2a3iawzq2kcp7cn5i91iby7n0082x"; - system = "rtg-math.vari"; - asd = "rtg-math.vari"; - }); - systems = [ "rtg-math.vari" ]; - lispLibs = [ (getAttr "glsl-symbols" self) (getAttr "rtg-math" self) (getAttr "varjo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rucksack = (build-asdf-system { - pname = "rucksack"; - version = "20150608-git"; - asds = [ "rucksack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rucksack/2015-06-08/rucksack-20150608-git.tgz"; - sha256 = "0d6lvhc18i0brh75vp3n974ssx52b42rvwd24llhnphlnhryxh86"; - system = "rucksack"; - asd = "rucksack"; - }); - systems = [ "rucksack" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rucksack-test = (build-asdf-system { - pname = "rucksack-test"; - version = "20150608-git"; - asds = [ "rucksack-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rucksack/2015-06-08/rucksack-20150608-git.tgz"; - sha256 = "0d6lvhc18i0brh75vp3n974ssx52b42rvwd24llhnphlnhryxh86"; - system = "rucksack-test"; - asd = "rucksack-test"; - }); - systems = [ "rucksack-test" ]; - lispLibs = [ (getAttr "rucksack" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rutils = (build-asdf-system { - pname = "rutils"; - version = "20221106-git"; - asds = [ "rutils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rutils/2022-11-06/rutils-20221106-git.tgz"; - sha256 = "108l64k7qhbhmgp0wa4krm23wakyfc41wzyl2fgc9k59gf47axhq"; - system = "rutils"; - asd = "rutils"; - }); - systems = [ "rutils" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rutils-test = (build-asdf-system { - pname = "rutils-test"; - version = "20221106-git"; - asds = [ "rutils-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rutils/2022-11-06/rutils-20221106-git.tgz"; - sha256 = "108l64k7qhbhmgp0wa4krm23wakyfc41wzyl2fgc9k59gf47axhq"; - system = "rutils-test"; - asd = "rutils-test"; - }); - systems = [ "rutils-test" ]; - lispLibs = [ (getAttr "rutils" self) (getAttr "should-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - rutilsx = (build-asdf-system { - pname = "rutilsx"; - version = "20221106-git"; - asds = [ "rutilsx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/rutils/2022-11-06/rutils-20221106-git.tgz"; - sha256 = "108l64k7qhbhmgp0wa4krm23wakyfc41wzyl2fgc9k59gf47axhq"; - system = "rutilsx"; - asd = "rutilsx"; - }); - systems = [ "rutilsx" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "named-readtables" self) (getAttr "rutils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ryeboy = (build-asdf-system { - pname = "ryeboy"; - version = "20201016-git"; - asds = [ "ryeboy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ryeboy/2020-10-16/ryeboy-20201016-git.tgz"; - sha256 = "0div6m6861damksxdxcycpdyyjn50bjsxfdkksm34w6162zdjcla"; - system = "ryeboy"; - asd = "ryeboy"; - }); - systems = [ "ryeboy" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "com_dot_google_dot_base" self) (getAttr "protobuf" self) (getAttr "prove-asdf" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - s-base64 = (build-asdf-system { - pname = "s-base64"; - version = "20130128-git"; - asds = [ "s-base64" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/s-base64/2013-01-28/s-base64-20130128-git.tgz"; - sha256 = "0zrr8zhnkdy97c5g54605nhjlf7fly79ylr1yf6wwyssia04cagg"; - system = "s-base64"; - asd = "s-base64"; - }); - systems = [ "s-base64" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - s-dot2 = (build-asdf-system { - pname = "s-dot2"; - version = "20241012-git"; - asds = [ "s-dot2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/s-dot2/2024-10-12/s-dot2-20241012-git.tgz"; - sha256 = "0zc833sc7szwyrrcinl84q3b0y9akh7hd5lhq3vxclk4zgb9n4nf"; - system = "s-dot2"; - asd = "s-dot2"; - }); - systems = [ "s-dot2" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - s-graphviz = (build-asdf-system { - pname = "s-graphviz"; - version = "20201220-git"; - asds = [ "s-graphviz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/s-graphviz/2020-12-20/s-graphviz-20201220-git.tgz"; - sha256 = "1841xwci6y1gfhg15464wrlnw8xgsh1mwbg4yy2y7di02q4fbma2"; - system = "s-graphviz"; - asd = "s-graphviz"; - }); - systems = [ "s-graphviz" ]; - lispLibs = [ (getAttr "iterate" self) (getAttr "literate-lisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - s-http-client = (build-asdf-system { - pname = "s-http-client"; - version = "20200427-git"; - asds = [ "s-http-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/s-http-client/2020-04-27/s-http-client-20200427-git.tgz"; - sha256 = "1fb2901h91rgfxz3cm1lb2dnd84m1fr745nd2kswd1mj2xz94zn8"; - system = "s-http-client"; - asd = "s-http-client"; - }); - systems = [ "s-http-client" ]; - lispLibs = [ (getAttr "chipz" self) (getAttr "puri" self) (getAttr "s-base64" self) (getAttr "s-sysdeps" self) (getAttr "s-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - s-http-server = (build-asdf-system { - pname = "s-http-server"; - version = "20200427-git"; - asds = [ "s-http-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/s-http-server/2020-04-27/s-http-server-20200427-git.tgz"; - sha256 = "025mvnqhxx2c092aam3s4fk9v0p65hzdw39y4lamm0bdralda4bk"; - system = "s-http-server"; - asd = "s-http-server"; - }); - systems = [ "s-http-server" ]; - lispLibs = [ (getAttr "puri" self) (getAttr "s-base64" self) (getAttr "s-sysdeps" self) (getAttr "s-utils" self) (getAttr "salza2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - s-sql = (build-asdf-system { - pname = "s-sql"; - version = "20241012-git"; - asds = [ "s-sql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/postmodern/2024-10-12/postmodern-20241012-git.tgz"; - sha256 = "1hj0dpclzihy1rcnwhiv16abmaa54wygxyib3j2h9q4qs26w7pzb"; - system = "s-sql"; - asd = "s-sql"; - }); - systems = [ "s-sql" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-postgres" self) ]; - meta = {}; - }); - s-sysdeps = (build-asdf-system { - pname = "s-sysdeps"; - version = "20210228-git"; - asds = [ "s-sysdeps" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/s-sysdeps/2021-02-28/s-sysdeps-20210228-git.tgz"; - sha256 = "0rp81iq0rgl48qdwbmfy89glga81hmry2lp8adjbr5h5ybr92b4n"; - system = "s-sysdeps"; - asd = "s-sysdeps"; - }); - systems = [ "s-sysdeps" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "usocket" self) (getAttr "usocket-server" self) ]; - meta = {}; - }); - s-utils = (build-asdf-system { - pname = "s-utils"; - version = "20200427-git"; - asds = [ "s-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/s-utils/2020-04-27/s-utils-20200427-git.tgz"; - sha256 = "0xggbcvjmj4sdqcs6vaccryqp2piaqxkc0ygkczrd5m14bwrmlp6"; - system = "s-utils"; - asd = "s-utils"; - }); - systems = [ "s-utils" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - s-xml = (build-asdf-system { - pname = "s-xml"; - version = "20150608-git"; - asds = [ "s-xml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/s-xml/2015-06-08/s-xml-20150608-git.tgz"; - sha256 = "1zsf5zrlf47g5cp70kb9b8d4v88315g633q5jcdx22csw7sd7if1"; - system = "s-xml"; - asd = "s-xml"; - }); - systems = [ "s-xml" ]; - lispLibs = [ ]; - meta = {}; - }); - s-xml-rpc = (build-asdf-system { - pname = "s-xml-rpc"; - version = "20190521-git"; - asds = [ "s-xml-rpc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/s-xml-rpc/2019-05-21/s-xml-rpc-20190521-git.tgz"; - sha256 = "0z42awkz124xphkahw0mhg1pk029l2799rhyy51387ndd6gbqscx"; - system = "s-xml-rpc"; - asd = "s-xml-rpc"; - }); - systems = [ "s-xml-rpc" ]; - lispLibs = [ (getAttr "s-xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - s-xml_dot_examples = (build-asdf-system { - pname = "s-xml.examples"; - version = "20150608-git"; - asds = [ "s-xml.examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/s-xml/2015-06-08/s-xml-20150608-git.tgz"; - sha256 = "1zsf5zrlf47g5cp70kb9b8d4v88315g633q5jcdx22csw7sd7if1"; - system = "s-xml.examples"; - asd = "s-xml"; - }); - systems = [ "s-xml.examples" ]; - lispLibs = [ (getAttr "s-xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - s-xml_dot_test = (build-asdf-system { - pname = "s-xml.test"; - version = "20150608-git"; - asds = [ "s-xml.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/s-xml/2015-06-08/s-xml-20150608-git.tgz"; - sha256 = "1zsf5zrlf47g5cp70kb9b8d4v88315g633q5jcdx22csw7sd7if1"; - system = "s-xml.test"; - asd = "s-xml"; - }); - systems = [ "s-xml.test" ]; - lispLibs = [ (getAttr "s-xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - safe-queue = (build-asdf-system { - pname = "safe-queue"; - version = "20200325-git"; - asds = [ "safe-queue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/safe-queue/2020-03-25/safe-queue-20200325-git.tgz"; - sha256 = "1agvp8y2k5c6w35kly6d9a7hi1y6csn4k0hqqdv7i87lgjdi7vrq"; - system = "safe-queue"; - asd = "safe-queue"; - }); - systems = [ "safe-queue" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - safe-read = (build-asdf-system { - pname = "safe-read"; - version = "20220220-git"; - asds = [ "safe-read" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/safe-read/2022-02-20/safe-read-20220220-git.tgz"; - sha256 = "1r9k8danfnqgpbn2vb90n6wdc6jd92h1ig565yplrbh6232lhi26"; - system = "safe-read"; - asd = "safe-read"; - }); - systems = [ "safe-read" ]; - lispLibs = [ (getAttr "local-time" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - safety-params = (build-asdf-system { - pname = "safety-params"; - version = "20190202-git"; - asds = [ "safety-params" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/safety-params/2019-02-02/safety-params-20190202-git.tgz"; - sha256 = "1y69b9aw3vsnsk0vdjyxw011j0lgc5gdwv6ay6vzfipa9gzi92ki"; - system = "safety-params"; - asd = "safety-params"; - }); - systems = [ "safety-params" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - salza2 = (build-asdf-system { - pname = "salza2"; - version = "2.1"; - asds = [ "salza2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/salza2/2021-10-20/salza2-2.1.tgz"; - sha256 = "1p48lxdibnps5rpyh5cmnk0vc77bmmxb32qdzfz93zadr8wwas10"; - system = "salza2"; - asd = "salza2"; - }); - systems = [ "salza2" ]; - lispLibs = [ (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - sandalphon_dot_lambda-list = (build-asdf-system { - pname = "sandalphon.lambda-list"; - version = "20241012-git"; - asds = [ "sandalphon.lambda-list" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sandalphon.lambda-list/2024-10-12/sandalphon.lambda-list-20241012-git.tgz"; - sha256 = "1j4xfcb1n71kh95v0y495snkna5avdp0inbiaia7r5fsxlcf4s45"; - system = "sandalphon.lambda-list"; - asd = "sandalphon.lambda-list"; - }); - systems = [ "sandalphon.lambda-list" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sanitize = (build-asdf-system { - pname = "sanitize"; - version = "20130720-git"; - asds = [ "sanitize" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sanitize/2013-07-20/cl-sanitize-20130720-git.tgz"; - sha256 = "101qqgi53scz3aaca57yg5wk9ana2axpwssmgrcb5c2ip5a2lwi3"; - system = "sanitize"; - asd = "sanitize"; - }); - systems = [ "sanitize" ]; - lispLibs = [ (getAttr "cl-libxml2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sanitize-test = (build-asdf-system { - pname = "sanitize-test"; - version = "20130720-git"; - asds = [ "sanitize-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sanitize/2013-07-20/cl-sanitize-20130720-git.tgz"; - sha256 = "101qqgi53scz3aaca57yg5wk9ana2axpwssmgrcb5c2ip5a2lwi3"; - system = "sanitize-test"; - asd = "sanitize"; - }); - systems = [ "sanitize-test" ]; - lispLibs = [ (getAttr "eos" self) (getAttr "sanitize" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sanity-clause = (build-asdf-system { - pname = "sanity-clause"; - version = "20210807-git"; - asds = [ "sanity-clause" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sanity-clause/2021-08-07/sanity-clause-20210807-git.tgz"; - sha256 = "0dzh00zpaqv48pn0xhbibiy33j8fwd2scsy5i466c9x9mcbhjz4f"; - system = "sanity-clause"; - asd = "sanity-clause"; - }); - systems = [ "sanity-clause" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "arrows" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "local-time" self) (getAttr "parse-float" self) (getAttr "quri" self) (getAttr "str" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sapaclisp = (build-asdf-system { - pname = "sapaclisp"; - version = "1.0a"; - asds = [ "sapaclisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sapaclisp/2012-05-20/sapaclisp-1.0a.tgz"; - sha256 = "1bgqvwvjq8g5wrmp5r1dn1v99hgin9gihwkihz455n9dn90l3pyq"; - system = "sapaclisp"; - asd = "sapaclisp"; - }); - systems = [ "sapaclisp" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sb-cga = (build-asdf-system { - pname = "sb-cga"; - version = "20210531-git"; - asds = [ "sb-cga" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sb-cga/2021-05-31/sb-cga-20210531-git.tgz"; - sha256 = "1y54qlwfrhch9aghk7nsbdx7x2qsvgsws1g2k631l9dsgdakw4w8"; - system = "sb-cga"; - asd = "sb-cga"; - }); - systems = [ "sb-cga" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sb-fastcgi = (build-asdf-system { - pname = "sb-fastcgi"; - version = "20241012-git"; - asds = [ "sb-fastcgi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sb-fastcgi/2024-10-12/sb-fastcgi-20241012-git.tgz"; - sha256 = "1jw5bmim4ll3a1bqlw02ksgw58cv1qr5li0gbczj7g9fjfk3r64z"; - system = "sb-fastcgi"; - asd = "sb-fastcgi"; - }); - systems = [ "sb-fastcgi" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sb-vector-io = (build-asdf-system { - pname = "sb-vector-io"; - version = "20110829-git"; - asds = [ "sb-vector-io" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sb-vector-io/2011-08-29/sb-vector-io-20110829-git.tgz"; - sha256 = "0pwc0nxhv8ba33i8z2f1y7r7ldik4a4xrqrb69dvvasz838k6r22"; - system = "sb-vector-io"; - asd = "sb-vector-io"; - }); - systems = [ "sb-vector-io" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sc-extensions = (build-asdf-system { - pname = "sc-extensions"; - version = "20241012-git"; - asds = [ "sc-extensions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sc-extensions/2024-10-12/sc-extensions-20241012-git.tgz"; - sha256 = "1va153gr7002j5hshalq13gk6jpij29h613nm47aimj01hjy9p0n"; - system = "sc-extensions"; - asd = "sc-extensions"; - }); - systems = [ "sc-extensions" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-collider" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sc-osc = (build-asdf-system { - pname = "sc-osc"; - version = "20241012-git"; - asds = [ "sc-osc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-collider/2024-10-12/cl-collider-20241012-git.tgz"; - sha256 = "0h0fyx7glxnzwyam2aflma6003h8fcvcf5nj5f7svarw9brcc2xa"; - system = "sc-osc"; - asd = "sc-osc"; - }); - systems = [ "sc-osc" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "ieee-floats" self) (getAttr "osc" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - schannel = (build-asdf-system { - pname = "schannel"; - version = "20211230-git"; - asds = [ "schannel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/schannel/2021-12-30/schannel-20211230-git.tgz"; - sha256 = "1f7dncrjsswrr8wrm7qzxdvrmzg3n2ap607ad74mnfd806rwldnw"; - system = "schannel"; - asd = "schannel"; - }); - systems = [ "schannel" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scheduler = (build-asdf-system { - pname = "scheduler"; - version = "20230618-git"; - asds = [ "scheduler" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/scheduler/2023-06-18/scheduler-20230618-git.tgz"; - sha256 = "0559hxypgyg9863mb51wil777prspfsjbslj6psm3wndvl6xiprg"; - system = "scheduler"; - asd = "scheduler"; - }); - systems = [ "scheduler" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "local-time" self) (getAttr "optima" self) (getAttr "optima_dot_ppcre" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - science-data = (build-asdf-system { - pname = "science-data"; - version = "master-df14cb8c-git"; - asds = [ "science-data" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/antik/2024-10-12/antik-master-df14cb8c-git.tgz"; - sha256 = "1n08cx4n51z8v4bxyak166lp495xda3x7llfxcdpxndxqxcammr0"; - system = "science-data"; - asd = "science-data"; - }); - systems = [ "science-data" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "physical-dimension" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scigraph = (build-asdf-system { - pname = "scigraph"; - version = "20241012-git"; - asds = [ "scigraph" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "scigraph"; - asd = "scigraph"; - }); - systems = [ "scigraph" ]; - lispLibs = [ (getAttr "mcclim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scrapycl = (build-asdf-system { - pname = "scrapycl"; - version = "20241012-git"; - asds = [ "scrapycl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/scrapycl/2024-10-12/scrapycl-20241012-git.tgz"; - sha256 = "0qlvsc5qr8vyyrsasp041ydlfx8vgsy191m0nhab487fzmrlbzwp"; - system = "scrapycl"; - asd = "scrapycl"; - }); - systems = [ "scrapycl" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) (getAttr "_40ants-doc" self) (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "dexador" self) (getAttr "log4cl" self) (getAttr "log4cl-extras" self) (getAttr "lquery" self) (getAttr "plump" self) (getAttr "quri" self) (getAttr "serapeum" self) (getAttr "spinneret" self) (getAttr "str" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scrapycl-ci = (build-asdf-system { - pname = "scrapycl-ci"; - version = "20241012-git"; - asds = [ "scrapycl-ci" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/scrapycl/2024-10-12/scrapycl-20241012-git.tgz"; - sha256 = "0qlvsc5qr8vyyrsasp041ydlfx8vgsy191m0nhab487fzmrlbzwp"; - system = "scrapycl-ci"; - asd = "scrapycl-ci"; - }); - systems = [ "scrapycl-ci" ]; - lispLibs = [ (getAttr "_40ants-ci" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scrapycl-docs = (build-asdf-system { - pname = "scrapycl-docs"; - version = "20241012-git"; - asds = [ "scrapycl-docs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/scrapycl/2024-10-12/scrapycl-20241012-git.tgz"; - sha256 = "0qlvsc5qr8vyyrsasp041ydlfx8vgsy191m0nhab487fzmrlbzwp"; - system = "scrapycl-docs"; - asd = "scrapycl-docs"; - }); - systems = [ "scrapycl-docs" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "docs-config" self) (getAttr "named-readtables" self) (getAttr "pythonic-string-reader" self) (getAttr "scrapycl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scrapycl-tests = (build-asdf-system { - pname = "scrapycl-tests"; - version = "20241012-git"; - asds = [ "scrapycl-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/scrapycl/2024-10-12/scrapycl-20241012-git.tgz"; - sha256 = "0qlvsc5qr8vyyrsasp041ydlfx8vgsy191m0nhab487fzmrlbzwp"; - system = "scrapycl-tests"; - asd = "scrapycl-tests"; - }); - systems = [ "scrapycl-tests" ]; - lispLibs = [ (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scratch-buffer = (build-asdf-system { - pname = "scratch-buffer"; - version = "20200427-git"; - asds = [ "scratch-buffer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "scratch-buffer"; - asd = "scratch-buffer"; - }); - systems = [ "scratch-buffer" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "utility" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - screamer = (build-asdf-system { - pname = "screamer"; - version = "20210807-git"; - asds = [ "screamer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/screamer/2021-08-07/screamer-20210807-git.tgz"; - sha256 = "0913wmy0fpf6shvbz40ay9gnjhgyjglf661d1p5ld2glkw1ky8hm"; - system = "screamer"; - asd = "screamer"; - }); - systems = [ "screamer" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - screamer-tests = (build-asdf-system { - pname = "screamer-tests"; - version = "20210807-git"; - asds = [ "screamer-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/screamer/2021-08-07/screamer-20210807-git.tgz"; - sha256 = "0913wmy0fpf6shvbz40ay9gnjhgyjglf661d1p5ld2glkw1ky8hm"; - system = "screamer-tests"; - asd = "screamer-tests"; - }); - systems = [ "screamer-tests" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_stefil" self) (getAttr "iterate" self) (getAttr "screamer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scriba = (build-asdf-system { - pname = "scriba"; - version = "20220707-git"; - asds = [ "scriba" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/scriba/2022-07-07/scriba-20220707-git.tgz"; - sha256 = "1n32bxf3b1cgb7y4015y3vahjgnbw59pi6d08by78pnpa2nx43sa"; - system = "scriba"; - asd = "scriba"; - }); - systems = [ "scriba" ]; - lispLibs = [ (getAttr "common-doc-plump" self) (getAttr "esrap" self) (getAttr "plump-sexp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scriba-test = (build-asdf-system { - pname = "scriba-test"; - version = "20220707-git"; - asds = [ "scriba-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/scriba/2022-07-07/scriba-20220707-git.tgz"; - sha256 = "1n32bxf3b1cgb7y4015y3vahjgnbw59pi6d08by78pnpa2nx43sa"; - system = "scriba-test"; - asd = "scriba-test"; - }); - systems = [ "scriba-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "scriba" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scribble = (build-asdf-system { - pname = "scribble"; - version = "20231021-git"; - asds = [ "scribble" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/scribble/2023-10-21/scribble-20231021-git.tgz"; - sha256 = "1ng56lzfva5231lkjls18mw7gcfc3vzksyh6habk0x5dff92cwvw"; - system = "scribble"; - asd = "scribble"; - }); - systems = [ "scribble" ]; - lispLibs = [ (getAttr "fare-memoization" self) (getAttr "fare-quasiquote-readtable" self) (getAttr "fare-utils" self) (getAttr "meta" self) (getAttr "ptc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scriptl = (build-asdf-system { - pname = "scriptl"; - version = "20180228-git"; - asds = [ "scriptl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/scriptl/2018-02-28/scriptl-20180228-git.tgz"; - sha256 = "1q0d64syglfdjrzx2x7hlvznljpfwr9scn7rliigbm5z326lygg4"; - system = "scriptl"; - asd = "scriptl"; - }); - systems = [ "scriptl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "defpackage-plus" self) (getAttr "iolib" self) (getAttr "osicat" self) (getAttr "trivial-backtrace" self) (getAttr "trivial-gray-streams" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scriptl-examples = (build-asdf-system { - pname = "scriptl-examples"; - version = "20180228-git"; - asds = [ "scriptl-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/scriptl/2018-02-28/scriptl-20180228-git.tgz"; - sha256 = "1q0d64syglfdjrzx2x7hlvznljpfwr9scn7rliigbm5z326lygg4"; - system = "scriptl-examples"; - asd = "scriptl-examples"; - }); - systems = [ "scriptl-examples" ]; - lispLibs = [ (getAttr "scriptl" self) (getAttr "unix-options" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scriptl-util = (build-asdf-system { - pname = "scriptl-util"; - version = "20180228-git"; - asds = [ "scriptl-util" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/scriptl/2018-02-28/scriptl-20180228-git.tgz"; - sha256 = "1q0d64syglfdjrzx2x7hlvznljpfwr9scn7rliigbm5z326lygg4"; - system = "scriptl-util"; - asd = "scriptl-util"; - }); - systems = [ "scriptl-util" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "scriptl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scrutiny = (build-asdf-system { - pname = "scrutiny"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "scrutiny" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "scrutiny"; - asd = "scrutiny"; - }); - systems = [ "scrutiny" ]; - lispLibs = [ (getAttr "adjuvant" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - scrutiny-test = (build-asdf-system { - pname = "scrutiny-test"; - version = "export-to-quicklisp-502a46e2-git"; - asds = [ "scrutiny-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; - sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; - system = "scrutiny-test"; - asd = "scrutiny-test"; - }); - systems = [ "scrutiny-test" ]; - lispLibs = [ (getAttr "scrutiny" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sdl2 = (build-asdf-system { - pname = "sdl2"; - version = "20231021-git"; - asds = [ "sdl2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sdl2/2023-10-21/cl-sdl2-20231021-git.tgz"; - sha256 = "189awhgxnqdyvypmw9k39542whb1jcpxx4psy6196qdbrgab8lc7"; - system = "sdl2"; - asd = "sdl2"; - }); - systems = [ "sdl2" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-autowrap" self) (getAttr "cl-plus-c" self) (getAttr "cl-ppcre" self) (getAttr "trivial-channels" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sdl2-game-controller-db = (build-asdf-system { - pname = "sdl2-game-controller-db"; - version = "release-quicklisp-335d2b68-git"; - asds = [ "sdl2-game-controller-db" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sdl2-game-controller-db/2018-02-28/sdl2-game-controller-db-release-quicklisp-335d2b68-git.tgz"; - sha256 = "0yf4ygndmacs0pf3ws5197k51c4fdximvxcmvn56bqmsvil56kcd"; - system = "sdl2-game-controller-db"; - asd = "sdl2-game-controller-db"; - }); - systems = [ "sdl2-game-controller-db" ]; - lispLibs = [ (getAttr "sdl2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sdl2-image = (build-asdf-system { - pname = "sdl2-image"; - version = "20241012-git"; - asds = [ "sdl2-image" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sdl2-image/2024-10-12/cl-sdl2-image-20241012-git.tgz"; - sha256 = "1jzrz3ppr5nbh0w6cvbbpv5x6gdq71a6v2qanvnjvcjs0zwf97iq"; - system = "sdl2-image"; - asd = "sdl2-image"; - }); - systems = [ "sdl2-image" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-autowrap" self) (getAttr "defpackage-plus" self) (getAttr "sdl2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sdl2-mixer = (build-asdf-system { - pname = "sdl2-mixer"; - version = "20241012-git"; - asds = [ "sdl2-mixer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sdl2-mixer/2024-10-12/cl-sdl2-mixer-20241012-git.tgz"; - sha256 = "0d33pmyrcni90qfj0d4hxf97may1bv7i9z4a6rj02dw254n9r9lh"; - system = "sdl2-mixer"; - asd = "sdl2-mixer"; - }); - systems = [ "sdl2-mixer" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-autowrap" self) (getAttr "sdl2" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sdl2-ttf = (build-asdf-system { - pname = "sdl2-ttf"; - version = "20241012-git"; - asds = [ "sdl2-ttf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sdl2-ttf/2024-10-12/cl-sdl2-ttf-20241012-git.tgz"; - sha256 = "1asdymsn65a06qr1c8fknakdvpjwxsvl69py6fsz21nirxyha5nc"; - system = "sdl2-ttf"; - asd = "sdl2-ttf"; - }); - systems = [ "sdl2-ttf" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi-libffi" self) (getAttr "cl-autowrap" self) (getAttr "defpackage-plus" self) (getAttr "sdl2" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sdl2-ttf-examples = (build-asdf-system { - pname = "sdl2-ttf-examples"; - version = "20241012-git"; - asds = [ "sdl2-ttf-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sdl2-ttf/2024-10-12/cl-sdl2-ttf-20241012-git.tgz"; - sha256 = "1asdymsn65a06qr1c8fknakdvpjwxsvl69py6fsz21nirxyha5nc"; - system = "sdl2-ttf-examples"; - asd = "sdl2-ttf-examples"; - }); - systems = [ "sdl2-ttf-examples" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-opengl" self) (getAttr "mathkit" self) (getAttr "sdl2" self) (getAttr "sdl2-ttf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sdl2kit = (build-asdf-system { - pname = "sdl2kit"; - version = "20171130-git"; - asds = [ "sdl2kit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sdl2kit/2017-11-30/sdl2kit-20171130-git.tgz"; - sha256 = "10ymmxqsvdn7ndda9k2qcixj75l7namgqdxc5y2w3v5r1313fy2d"; - system = "sdl2kit"; - asd = "sdl2kit"; - }); - systems = [ "sdl2kit" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-opengl" self) (getAttr "defpackage-plus" self) (getAttr "sdl2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sdl2kit-examples = (build-asdf-system { - pname = "sdl2kit-examples"; - version = "20171130-git"; - asds = [ "sdl2kit-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sdl2kit/2017-11-30/sdl2kit-20171130-git.tgz"; - sha256 = "10ymmxqsvdn7ndda9k2qcixj75l7namgqdxc5y2w3v5r1313fy2d"; - system = "sdl2kit-examples"; - asd = "sdl2kit-examples"; - }); - systems = [ "sdl2kit-examples" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "defpackage-plus" self) (getAttr "glkit" self) (getAttr "mathkit" self) (getAttr "sdl2kit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sealable-metaobjects = (build-asdf-system { - pname = "sealable-metaobjects"; - version = "20200610-git"; - asds = [ "sealable-metaobjects" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sealable-metaobjects/2020-06-10/sealable-metaobjects-20200610-git.tgz"; - sha256 = "0hz1ivlpfhnk1w2cw4q2i000j2dc7maay06ndzziyywg7li6zf2p"; - system = "sealable-metaobjects"; - asd = "sealable-metaobjects"; - }); - systems = [ "sealable-metaobjects" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - secp256k1 = (build-asdf-system { - pname = "secp256k1"; - version = "20220707-git"; - asds = [ "secp256k1" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-secp256k1/2022-07-07/cl-secp256k1-20220707-git.tgz"; - sha256 = "0lg84jkwwp95nnk865yfhg16z0d04wk3dzf5yilkfm2yxnmjnv85"; - system = "secp256k1"; - asd = "secp256k1"; - }); - systems = [ "secp256k1" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - secret-values = (build-asdf-system { - pname = "secret-values"; - version = "20201220-git"; - asds = [ "secret-values" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/secret-values/2020-12-20/secret-values-20201220-git.tgz"; - sha256 = "07ph49s27gvjzx60yy094bb9ddwiys34r8cx5l837i34nm2fn3nh"; - system = "secret-values"; - asd = "secret-values"; - }); - systems = [ "secret-values" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - secure-random = (build-asdf-system { - pname = "secure-random"; - version = "20160208-git"; - asds = [ "secure-random" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/secure-random/2016-02-08/secure-random-20160208-git.tgz"; - sha256 = "09cnclnivkc87ja3z12ihcm02vkwp0cflcfa6hpjlbd5m75hvgsd"; - system = "secure-random"; - asd = "secure-random"; - }); - systems = [ "secure-random" ]; - lispLibs = [ (getAttr "cl_plus_ssl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - seedable-rng = (build-asdf-system { - pname = "seedable-rng"; - version = "20220707-git"; - asds = [ "seedable-rng" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/seedable-rng/2022-07-07/seedable-rng-20220707-git.tgz"; - sha256 = "1pr2flvrj32m055apwn5f2cddki2ws5xldmj2v367iyry3lz2vm1"; - system = "seedable-rng"; - asd = "seedable-rng"; - }); - systems = [ "seedable-rng" ]; - lispLibs = [ (getAttr "cl-pcg" self) (getAttr "ironclad" self) (getAttr "mfiano-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - select = (build-asdf-system { - pname = "select"; - version = "20241012-git"; - asds = [ "select" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/select/2024-10-12/select-20241012-git.tgz"; - sha256 = "1js02xgfd488lhv90rgxw0cvfbsarlpakydwrg1jr2hh5bhqyifh"; - system = "select"; - asd = "select"; - }); - systems = [ "select" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "alexandria_plus" self) (getAttr "anaphora" self) (getAttr "let-plus" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - select-file = (build-asdf-system { - pname = "select-file"; - version = "20200427-git"; - asds = [ "select-file" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/select-file/2020-04-27/select-file-20200427-git.tgz"; - sha256 = "1v89k5vvn1a3gdhlwbb4wxggzzr1ic7iqzvrrxgsh90fr129rmzq"; - system = "select-file"; - asd = "select-file"; - }); - systems = [ "select-file" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "mcclim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - selenium = (build-asdf-system { - pname = "selenium"; - version = "20160531-git"; - asds = [ "selenium" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-selenium/2016-05-31/cl-selenium-20160531-git.tgz"; - sha256 = "1wx3343gkmyb25vbbpv6g5d1m2c5qxrkq7hsz1v2fcchgdgvwgxl"; - system = "selenium"; - asd = "selenium"; - }); - systems = [ "selenium" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cxml" self) (getAttr "drakma" self) (getAttr "puri" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - semantic-spinneret = (build-asdf-system { - pname = "semantic-spinneret"; - version = "20170830-git"; - asds = [ "semantic-spinneret" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/semantic-spinneret/2017-08-30/semantic-spinneret-20170830-git.tgz"; - sha256 = "0ghd4lwwcbcidj70j26hj9vic1nqrj78ksrqlxj29q61bnji05ix"; - system = "semantic-spinneret"; - asd = "semantic-spinneret"; - }); - systems = [ "semantic-spinneret" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "spinneret" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - semz_dot_decompress = (build-asdf-system { - pname = "semz.decompress"; - version = "20241012-git"; - asds = [ "semz.decompress" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/decompress/2024-10-12/decompress-20241012-git.tgz"; - sha256 = "0nzz6r57v94kyl5r77yawalnjszw93qjiqqargl3vjrmiga37gjp"; - system = "semz.decompress"; - asd = "semz.decompress"; - }); - systems = [ "semz.decompress" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sendgrid = (build-asdf-system { - pname = "sendgrid"; - version = "20241012-git"; - asds = [ "sendgrid" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sendgrid/2024-10-12/cl-sendgrid-20241012-git.tgz"; - sha256 = "02wwi2fwfd21aisf1y6ngypg7dmfvlf3bgxhqhrp1vpw8b34ha4w"; - system = "sendgrid"; - asd = "sendgrid"; - }); - systems = [ "sendgrid" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "dexador" self) (getAttr "jonathan" self) (getAttr "qbase64" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sento = (build-asdf-system { - pname = "sento"; - version = "20241012-git"; - asds = [ "sento" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-gserver/2024-10-12/cl-gserver-20241012-git.tgz"; - sha256 = "1281iir75ccr5ilh2jv9xh1w446492gywvady48xggqyh6idaz9k"; - system = "sento"; - asd = "sento"; - }); - systems = [ "sento" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "atomics" self) (getAttr "binding-arrows" self) (getAttr "blackbird" self) (getAttr "bordeaux-threads" self) (getAttr "cl-speedy-queue" self) (getAttr "local-time-duration" self) (getAttr "log4cl" self) (getAttr "str" self) (getAttr "timer-wheel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sentry-client = (build-asdf-system { - pname = "sentry-client"; - version = "20241012-git"; - asds = [ "sentry-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sentry-client/2024-10-12/cl-sentry-client-20241012-git.tgz"; - sha256 = "0i83kgrjznffj6z5ryxnxlk995937askhilsbfa2nixakwal2c5h"; - system = "sentry-client"; - asd = "sentry-client"; - }); - systems = [ "sentry-client" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "dexador" self) (getAttr "local-time" self) (getAttr "salza2" self) (getAttr "swank" self) (getAttr "trivial-backtrace" self) (getAttr "uuid" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sentry-client_dot_async = (build-asdf-system { - pname = "sentry-client.async"; - version = "20241012-git"; - asds = [ "sentry-client.async" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sentry-client/2024-10-12/cl-sentry-client-20241012-git.tgz"; - sha256 = "0i83kgrjznffj6z5ryxnxlk995937askhilsbfa2nixakwal2c5h"; - system = "sentry-client.async"; - asd = "sentry-client.async"; - }); - systems = [ "sentry-client.async" ]; - lispLibs = [ (getAttr "sentry-client" self) (getAttr "simple-tasks" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sentry-client_dot_hunchentoot = (build-asdf-system { - pname = "sentry-client.hunchentoot"; - version = "20241012-git"; - asds = [ "sentry-client.hunchentoot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sentry-client/2024-10-12/cl-sentry-client-20241012-git.tgz"; - sha256 = "0i83kgrjznffj6z5ryxnxlk995937askhilsbfa2nixakwal2c5h"; - system = "sentry-client.hunchentoot"; - asd = "sentry-client.hunchentoot"; - }); - systems = [ "sentry-client.hunchentoot" ]; - lispLibs = [ (getAttr "hunchentoot" self) (getAttr "sentry-client" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sequence-iterators = (build-asdf-system { - pname = "sequence-iterators"; - version = "20130813-darcs"; - asds = [ "sequence-iterators" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sequence-iterators/2013-08-13/sequence-iterators-20130813-darcs.tgz"; - sha256 = "12flvy6hysqw0fa2jfkxrgphlk6b25hg2w2dxm1ylax0gw9fh1l5"; - system = "sequence-iterators"; - asd = "sequence-iterators"; - }); - systems = [ "sequence-iterators" ]; - lispLibs = [ (getAttr "parse-declarations-1_dot_0" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sequence-iterators-test = (build-asdf-system { - pname = "sequence-iterators-test"; - version = "20130813-darcs"; - asds = [ "sequence-iterators-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sequence-iterators/2013-08-13/sequence-iterators-20130813-darcs.tgz"; - sha256 = "12flvy6hysqw0fa2jfkxrgphlk6b25hg2w2dxm1ylax0gw9fh1l5"; - system = "sequence-iterators-test"; - asd = "sequence-iterators"; - }); - systems = [ "sequence-iterators-test" ]; - lispLibs = [ (getAttr "sequence-iterators" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - serapeum = (build-asdf-system { - pname = "serapeum"; - version = "20241012-git"; - asds = [ "serapeum" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/serapeum/2024-10-12/serapeum-20241012-git.tgz"; - sha256 = "12dc4p3i82p3jhxpp5wd6xiwy2fgdjybgfgj54nv8ya75rl9a64z"; - system = "serapeum"; - asd = "serapeum"; - }); - systems = [ "serapeum" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "global-vars" self) (getAttr "introspect-environment" self) (getAttr "parse-declarations-1_dot_0" self) (getAttr "parse-number" self) (getAttr "split-sequence" self) (getAttr "string-case" self) (getAttr "trivia" self) (getAttr "trivial-cltl2" self) (getAttr "trivial-file-size" self) (getAttr "trivial-garbage" self) (getAttr "trivial-macroexpand-all" self) ]; - meta = {}; - }); - serializable-object = (build-asdf-system { - pname = "serializable-object"; - version = "20191227-git"; - asds = [ "serializable-object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/serializable-object/2019-12-27/serializable-object-20191227-git.tgz"; - sha256 = "0978ljw998ypryiiqmb1s11ymwg4h5qz9bv7ig1i29wf5s14s2i0"; - system = "serializable-object"; - asd = "serializable-object"; - }); - systems = [ "serializable-object" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - serializable-object_dot_test = (build-asdf-system { - pname = "serializable-object.test"; - version = "20191227-git"; - asds = [ "serializable-object.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/serializable-object/2019-12-27/serializable-object-20191227-git.tgz"; - sha256 = "0978ljw998ypryiiqmb1s11ymwg4h5qz9bv7ig1i29wf5s14s2i0"; - system = "serializable-object.test"; - asd = "serializable-object.test"; - }); - systems = [ "serializable-object.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "serializable-object" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - series = (build-asdf-system { - pname = "series"; - version = "20131111-git"; - asds = [ "series" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/series/2013-11-11/series-20131111-git.tgz"; - sha256 = "07hk2lhfx42zk018pxqvn4gs77vd4n4g8m4xxbqaxgca76mifwfw"; - system = "series"; - asd = "series"; - }); - systems = [ "series" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - series-tests = (build-asdf-system { - pname = "series-tests"; - version = "20131111-git"; - asds = [ "series-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/series/2013-11-11/series-20131111-git.tgz"; - sha256 = "07hk2lhfx42zk018pxqvn4gs77vd4n4g8m4xxbqaxgca76mifwfw"; - system = "series-tests"; - asd = "series"; - }); - systems = [ "series-tests" ]; - lispLibs = [ (getAttr "series" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - session-token = (build-asdf-system { - pname = "session-token"; - version = "20141106-git"; - asds = [ "session-token" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/session-token/2014-11-06/session-token-20141106-git.tgz"; - sha256 = "1yb6m8nbh4gaskplrd2bwsnpkq6dl9dkvbjmvhzls6vh4lp6cc2z"; - system = "session-token"; - asd = "session-token"; - }); - systems = [ "session-token" ]; - lispLibs = [ (getAttr "cl-isaac" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - setup-cl_plus_ssl = (build-asdf-system { - pname = "setup-cl+ssl"; - version = "20230618-git"; - asds = [ "setup-cl+ssl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zacl/2023-06-18/zacl-20230618-git.tgz"; - sha256 = "1s31d47zx8hczim78zrqzg4bvj4bshj31gmrff065q6racx3q1dk"; - system = "setup-cl+ssl"; - asd = "setup-cl+ssl"; - }); - systems = [ "setup-cl+ssl" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sexml = (build-asdf-system { - pname = "sexml"; - version = "20140713-git"; - asds = [ "sexml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sexml/2014-07-13/sexml-20140713-git.tgz"; - sha256 = "1s7isk9v7qh03sf60zw32kaa1rgvdh24bsc37q173r282m8plbk3"; - system = "sexml"; - asd = "sexml"; - }); - systems = [ "sexml" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "contextl" self) (getAttr "cxml" self) (getAttr "macroexpand-dammit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sexml-objects = (build-asdf-system { - pname = "sexml-objects"; - version = "20140713-git"; - asds = [ "sexml-objects" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sexml/2014-07-13/sexml-20140713-git.tgz"; - sha256 = "1s7isk9v7qh03sf60zw32kaa1rgvdh24bsc37q173r282m8plbk3"; - system = "sexml-objects"; - asd = "sexml-objects"; - }); - systems = [ "sexml-objects" ]; - lispLibs = [ (getAttr "sexml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sha1 = (build-asdf-system { - pname = "sha1"; - version = "20211020-git"; - asds = [ "sha1" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sha1/2021-10-20/sha1-20211020-git.tgz"; - sha256 = "1cfn0j5yfwqkwr2dm73wr9hz8dmws3ngxlbk9886ahxkg544qx4z"; - system = "sha1"; - asd = "sha1"; - }); - systems = [ "sha1" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sha3 = (build-asdf-system { - pname = "sha3"; - version = "20231021-git"; - asds = [ "sha3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sha3/2023-10-21/sha3-20231021-git.tgz"; - sha256 = "0jl59js4n1gc08j2bcwf0d1gy82lf7g53b639dwh6b0milbqh7gz"; - system = "sha3"; - asd = "sha3"; - }); - systems = [ "sha3" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - shadchen = (build-asdf-system { - pname = "shadchen"; - version = "20131003-git"; - asds = [ "shadchen" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/shadchen/2013-10-03/shadchen-20131003-git.tgz"; - sha256 = "0731hrpzf9pn1hyvs9wl0w3mnv13mr9ky3jx3dc4baj4nmjyb1k6"; - system = "shadchen"; - asd = "shadchen"; - }); - systems = [ "shadchen" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - shadow = (build-asdf-system { - pname = "shadow"; - version = "20220707-git"; - asds = [ "shadow" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/shadow/2022-07-07/shadow-20220707-git.tgz"; - sha256 = "1lw98ir9381kmmranaa111f8jh47adsx0v4hzlw3qkf2xjcfah3l"; - system = "shadow"; - asd = "shadow"; - }); - systems = [ "shadow" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-opengl" self) (getAttr "glsl-packing" self) (getAttr "mfiano-utils" self) (getAttr "static-vectors" self) (getAttr "varjo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - shared-preferences = (build-asdf-system { - pname = "shared-preferences"; - version = "1.1.1"; - asds = [ "shared-preferences" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/shared-preferences/2021-02-28/shared-preferences_1.1.1.tgz"; - sha256 = "12m4kaba2lxndkjw30a6y2rq16fflh5016lp74l7pf3v0y3j1ydf"; - system = "shared-preferences"; - asd = "shared-preferences"; - }); - systems = [ "shared-preferences" ]; - lispLibs = [ (getAttr "inheriting-readers" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - shared-preferences__tests = (build-asdf-system { - pname = "shared-preferences_tests"; - version = "1.1.1"; - asds = [ "shared-preferences_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/shared-preferences/2021-02-28/shared-preferences_1.1.1.tgz"; - sha256 = "12m4kaba2lxndkjw30a6y2rq16fflh5016lp74l7pf3v0y3j1ydf"; - system = "shared-preferences_tests"; - asd = "shared-preferences_tests"; - }); - systems = [ "shared-preferences_tests" ]; - lispLibs = [ (getAttr "parachute" self) (getAttr "shared-preferences" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - shasht = (build-asdf-system { - pname = "shasht"; - version = "20241012-git"; - asds = [ "shasht" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/shasht/2024-10-12/shasht-20241012-git.tgz"; - sha256 = "0i4k6w5r74f2a0i3ffian715v057w63psywk89ih0hl9xxpc4pga"; - system = "shasht"; - asd = "shasht"; - }); - systems = [ "shasht" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "trivial-do" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sheeple = (build-asdf-system { - pname = "sheeple"; - version = "20210124-git"; - asds = [ "sheeple" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sheeple/2021-01-24/sheeple-20210124-git.tgz"; - sha256 = "13k6xm8a29xxkrwgc5j3bk2wr9skg4bzdnc4krrzgcdmx4gbcca3"; - system = "sheeple"; - asd = "sheeple"; - }); - systems = [ "sheeple" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sheeple-tests = (build-asdf-system { - pname = "sheeple-tests"; - version = "20210124-git"; - asds = [ "sheeple-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sheeple/2021-01-24/sheeple-20210124-git.tgz"; - sha256 = "13k6xm8a29xxkrwgc5j3bk2wr9skg4bzdnc4krrzgcdmx4gbcca3"; - system = "sheeple-tests"; - asd = "sheeple"; - }); - systems = [ "sheeple-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "sheeple" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - shellpool = (build-asdf-system { - pname = "shellpool"; - version = "20200925-git"; - asds = [ "shellpool" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/shellpool/2020-09-25/shellpool-20200925-git.tgz"; - sha256 = "1bpv58i2l2a3ayk3jvi2wwd90gjczp0qk24bj82775qp8miw9vz0"; - system = "shellpool"; - asd = "shellpool"; - }); - systems = [ "shellpool" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "bt-semaphore" self) (getAttr "cl-fad" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - shelly = (build-asdf-system { - pname = "shelly"; - version = "20141106-git"; - asds = [ "shelly" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/shelly/2014-11-06/shelly-20141106-git.tgz"; - sha256 = "07whfcd2ygq07lw73bqby74cqbp2bx0rnyx7c0v7s16y9xfqxw7b"; - system = "shelly"; - asd = "shelly"; - }); - systems = [ "shelly" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "bordeaux-threads" self) (getAttr "cl-fad" self) (getAttr "local-time" self) (getAttr "split-sequence" self) (getAttr "trivial-signal" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - shelly-test = (build-asdf-system { - pname = "shelly-test"; - version = "20141106-git"; - asds = [ "shelly-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/shelly/2014-11-06/shelly-20141106-git.tgz"; - sha256 = "07whfcd2ygq07lw73bqby74cqbp2bx0rnyx7c0v7s16y9xfqxw7b"; - system = "shelly-test"; - asd = "shelly-test"; - }); - systems = [ "shelly-test" ]; - lispLibs = [ (getAttr "cl-test-more" self) (getAttr "shelly" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - shlex = (build-asdf-system { - pname = "shlex"; - version = "20210411-git"; - asds = [ "shlex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-shlex/2021-04-11/cl-shlex-20210411-git.tgz"; - sha256 = "16ag48sswgimr1fzr582vhym4s03idpd4lkydw5s58lv80ibpim8"; - system = "shlex"; - asd = "shlex"; - }); - systems = [ "shlex" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "cl-unicode" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - shop3 = (build-asdf-system { - pname = "shop3"; - version = "20241012-git"; - asds = [ "shop3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/shop3/2024-10-12/shop3-20241012-git.tgz"; - sha256 = "1sdyyyd82fqmm9lcqmg7k8yy3l3891m2gjwidibzvk95bp4xf9sd"; - system = "shop3"; - asd = "shop3"; - }); - systems = [ "shop3" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "fiveam-asdf" self) (getAttr "iterate" self) (getAttr "random-state" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - shop3-thmpr-api = (build-asdf-system { - pname = "shop3-thmpr-api"; - version = "20241012-git"; - asds = [ "shop3-thmpr-api" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/shop3/2024-10-12/shop3-20241012-git.tgz"; - sha256 = "1sdyyyd82fqmm9lcqmg7k8yy3l3891m2gjwidibzvk95bp4xf9sd"; - system = "shop3-thmpr-api"; - asd = "shop3-thmpr-api"; - }); - systems = [ "shop3-thmpr-api" ]; - lispLibs = [ (getAttr "shop3" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - should-test = (build-asdf-system { - pname = "should-test"; - version = "20191007-git"; - asds = [ "should-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/should-test/2019-10-07/should-test-20191007-git.tgz"; - sha256 = "1fqqa7lhf28qg60ji9libkylkcy747x576qpjn1y7c945j2fxmnm"; - system = "should-test"; - asd = "should-test"; - }); - systems = [ "should-test" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "local-time" self) (getAttr "osicat" self) (getAttr "rutils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - shuffletron = (build-asdf-system { - pname = "shuffletron"; - version = "20181018-git"; - asds = [ "shuffletron" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/shuffletron/2018-10-18/shuffletron-20181018-git.tgz"; - sha256 = "10626wp2xdk0wxj0kl49m9gyb2bp6f0vp67563mw6zrzfs7ynpkb"; - system = "shuffletron"; - asd = "shuffletron"; - }); - systems = [ "shuffletron" ]; - lispLibs = [ (getAttr "mixalot" self) (getAttr "mixalot-flac" self) (getAttr "mixalot-mp3" self) (getAttr "mixalot-vorbis" self) (getAttr "osicat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - si-kanren = (build-asdf-system { - pname = "si-kanren"; - version = "20241012-git"; - asds = [ "si-kanren" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/si-kanren/2024-10-12/si-kanren-20241012-git.tgz"; - sha256 = "1m99ryyfjxbjbmswprz8gr9hl3srwz74fwjna35wf8d41ns5ajlj"; - system = "si-kanren"; - asd = "si-kanren"; - }); - systems = [ "si-kanren" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - silo = (build-asdf-system { - pname = "silo"; - version = "20211020-git"; - asds = [ "silo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/colliflower/2021-10-20/colliflower-20211020-git.tgz"; - sha256 = "1fzn9s7wm7wmffrdm21lpvry9jb320456cmmprn976a533lp704r"; - system = "silo"; - asd = "silo"; - }); - systems = [ "silo" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-actors = (build-asdf-system { - pname = "simple-actors"; - version = "20200925-git"; - asds = [ "simple-actors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-actors/2020-09-25/simple-actors-20200925-git.tgz"; - sha256 = "1q843l1bh0xipp535gwm7713gpp04cycvq0i8yz54b6ym3dzkql4"; - system = "simple-actors"; - asd = "simple-actors"; - }); - systems = [ "simple-actors" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-config = (build-asdf-system { - pname = "simple-config"; - version = "20230618-git"; - asds = [ "simple-config" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-config/2023-06-18/simple-config-20230618-git.tgz"; - sha256 = "1ihw5yr5jwlpixaa011611q6i4j406rvc42bkm0da1arzd76pfhn"; - system = "simple-config"; - asd = "simple-config"; - }); - systems = [ "simple-config" ]; - lispLibs = [ (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-config-test = (build-asdf-system { - pname = "simple-config-test"; - version = "20230618-git"; - asds = [ "simple-config-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-config/2023-06-18/simple-config-20230618-git.tgz"; - sha256 = "1ihw5yr5jwlpixaa011611q6i4j406rvc42bkm0da1arzd76pfhn"; - system = "simple-config-test"; - asd = "simple-config-test"; - }); - systems = [ "simple-config-test" ]; - lispLibs = [ (getAttr "prove" self) (getAttr "simple-config" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-currency = (build-asdf-system { - pname = "simple-currency"; - version = "20171130-git"; - asds = [ "simple-currency" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-currency/2017-11-30/simple-currency-20171130-git.tgz"; - sha256 = "1qrxaj5v25165vyjp2fmasasjri2cn53y6ckv3rlv04skifvnq2s"; - system = "simple-currency"; - asd = "simple-currency"; - }); - systems = [ "simple-currency" ]; - lispLibs = [ (getAttr "cl-store" self) (getAttr "dexador" self) (getAttr "plump" self) (getAttr "simple-date" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-date = (build-asdf-system { - pname = "simple-date"; - version = "20241012-git"; - asds = [ "simple-date" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/postmodern/2024-10-12/postmodern-20241012-git.tgz"; - sha256 = "1hj0dpclzihy1rcnwhiv16abmaa54wygxyib3j2h9q4qs26w7pzb"; - system = "simple-date"; - asd = "simple-date"; - }); - systems = [ "simple-date" ]; - lispLibs = [ ]; - meta = {}; - }); - simple-date-time = (build-asdf-system { - pname = "simple-date-time"; - version = "20160421-git"; - asds = [ "simple-date-time" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-date-time/2016-04-21/simple-date-time-20160421-git.tgz"; - sha256 = "06iwf13gcdyqhkzfkcsfdl8iqbdl44cx01c3fjsmhl0v1pp8h2m4"; - system = "simple-date-time"; - asd = "simple-date-time"; - }); - systems = [ "simple-date-time" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = {}; - }); - simple-finalizer = (build-asdf-system { - pname = "simple-finalizer"; - version = "20101006-git"; - asds = [ "simple-finalizer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-finalizer/2010-10-06/simple-finalizer-20101006-git.tgz"; - sha256 = "1qdm48zjlkbygz9ip006xwpas59fhijrswv1k7pzvhdwl04vkq65"; - system = "simple-finalizer"; - asd = "simple-finalizer"; - }); - systems = [ "simple-finalizer" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-flow-dispatcher = (build-asdf-system { - pname = "simple-flow-dispatcher"; - version = "stable-git"; - asds = [ "simple-flow-dispatcher" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-flow-dispatcher/2020-10-16/simple-flow-dispatcher-stable-git.tgz"; - sha256 = "11k16svq4mgf0pagrs4drvf57hawffghv9g96b1n071nqyk2ald2"; - system = "simple-flow-dispatcher"; - asd = "simple-flow-dispatcher"; - }); - systems = [ "simple-flow-dispatcher" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bodge-queue" self) (getAttr "cl-muth" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-guess = (build-asdf-system { - pname = "simple-guess"; - version = "1.0"; - asds = [ "simple-guess" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-guess/2020-09-25/simple-guess_1.0.tgz"; - sha256 = "11v3wxj3k036r0kazn69vi580qm593ir1yf7j5d737j4rb382682"; - system = "simple-guess"; - asd = "simple-guess"; - }); - systems = [ "simple-guess" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-guess__tests = (build-asdf-system { - pname = "simple-guess_tests"; - version = "1.0"; - asds = [ "simple-guess_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-guess/2020-09-25/simple-guess_1.0.tgz"; - sha256 = "11v3wxj3k036r0kazn69vi580qm593ir1yf7j5d737j4rb382682"; - system = "simple-guess_tests"; - asd = "simple-guess_tests"; - }); - systems = [ "simple-guess_tests" ]; - lispLibs = [ (getAttr "fakenil" self) (getAttr "parachute" self) (getAttr "simple-guess" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-inferiors = (build-asdf-system { - pname = "simple-inferiors"; - version = "20231021-git"; - asds = [ "simple-inferiors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-inferiors/2023-10-21/simple-inferiors-20231021-git.tgz"; - sha256 = "1b7y44r2ncpfc5766pw56k07036qjvwqdbycizldfk9rjam2afa6"; - system = "simple-inferiors"; - asd = "simple-inferiors"; - }); - systems = [ "simple-inferiors" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "documentation-utils" self) ]; - meta = {}; - }); - simple-neural-network = (build-asdf-system { - pname = "simple-neural-network"; - version = "20230214-git"; - asds = [ "simple-neural-network" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-neural-network/2023-02-14/simple-neural-network-20230214-git.tgz"; - sha256 = "14ix2f560bhvccfzi30ghmmg79785nmg8c3lpq5hg99djgigxyfw"; - system = "simple-neural-network"; - asd = "simple-neural-network"; - }); - systems = [ "simple-neural-network" ]; - lispLibs = [ (getAttr "cl-store" self) (getAttr "lparallel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-parallel-tasks = (build-asdf-system { - pname = "simple-parallel-tasks"; - version = "20201220-git"; - asds = [ "simple-parallel-tasks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-parallel-tasks/2020-12-20/simple-parallel-tasks-20201220-git.tgz"; - sha256 = "0gvbpyff4siifp3cp86cpr9ksmakn66fx21f3h0hpn647zl07nj7"; - system = "simple-parallel-tasks"; - asd = "simple-parallel-tasks"; - }); - systems = [ "simple-parallel-tasks" ]; - lispLibs = [ (getAttr "chanl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-parallel-tasks-tests = (build-asdf-system { - pname = "simple-parallel-tasks-tests"; - version = "20201220-git"; - asds = [ "simple-parallel-tasks-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-parallel-tasks/2020-12-20/simple-parallel-tasks-20201220-git.tgz"; - sha256 = "0gvbpyff4siifp3cp86cpr9ksmakn66fx21f3h0hpn647zl07nj7"; - system = "simple-parallel-tasks-tests"; - asd = "simple-parallel-tasks-tests"; - }); - systems = [ "simple-parallel-tasks-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "simple-parallel-tasks" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-rgb = (build-asdf-system { - pname = "simple-rgb"; - version = "20190521-git"; - asds = [ "simple-rgb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-rgb/2019-05-21/simple-rgb-20190521-git.tgz"; - sha256 = "0ggv0h2n4mvwnggjr1b40gw667gnyykzki2zadaczi38ydzyzlp1"; - system = "simple-rgb"; - asd = "simple-rgb"; - }); - systems = [ "simple-rgb" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-routes = (build-asdf-system { - pname = "simple-routes"; - version = "20180228-git"; - asds = [ "simple-routes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-routes/2018-02-28/simple-routes-20180228-git.tgz"; - sha256 = "0zkjl69zf1ynmqmvwccdbip3wxfyi7xplivv70qwxzd27mc0kh3k"; - system = "simple-routes"; - asd = "simple-routes"; - }); - systems = [ "simple-routes" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "hunchentoot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-scanf = (build-asdf-system { - pname = "simple-scanf"; - version = "20211209-git"; - asds = [ "simple-scanf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-string-match/2021-12-09/cl-string-match-20211209-git.tgz"; - sha256 = "0zndlkw3qy3vw4px4qv884z6232w8zfaliyc88irjwizdv35wcq9"; - system = "simple-scanf"; - asd = "simple-scanf"; - }); - systems = [ "simple-scanf" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "parse-float" self) (getAttr "proc-parse" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simple-tasks = (build-asdf-system { - pname = "simple-tasks"; - version = "20231021-git"; - asds = [ "simple-tasks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-tasks/2023-10-21/simple-tasks-20231021-git.tgz"; - sha256 = "14j0sbi9zv22rrcp3wvjzmrgk6f75zydhs50cbmspr2r0c9s5c6n"; - system = "simple-tasks"; - asd = "simple-tasks"; - }); - systems = [ "simple-tasks" ]; - lispLibs = [ (getAttr "array-utils" self) (getAttr "bordeaux-threads" self) (getAttr "dissect" self) ]; - meta = {}; - }); - simpleroutes-demo = (build-asdf-system { - pname = "simpleroutes-demo"; - version = "20180228-git"; - asds = [ "simpleroutes-demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-routes/2018-02-28/simple-routes-20180228-git.tgz"; - sha256 = "0zkjl69zf1ynmqmvwccdbip3wxfyi7xplivv70qwxzd27mc0kh3k"; - system = "simpleroutes-demo"; - asd = "simple-routes"; - }); - systems = [ "simpleroutes-demo" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "cl-who" self) (getAttr "hunchentoot" self) (getAttr "simple-routes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simpleroutes-test = (build-asdf-system { - pname = "simpleroutes-test"; - version = "20180228-git"; - asds = [ "simpleroutes-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simple-routes/2018-02-28/simple-routes-20180228-git.tgz"; - sha256 = "0zkjl69zf1ynmqmvwccdbip3wxfyi7xplivv70qwxzd27mc0kh3k"; - system = "simpleroutes-test"; - asd = "simple-routes"; - }); - systems = [ "simpleroutes-test" ]; - lispLibs = [ (getAttr "simple-routes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simplet = (build-asdf-system { - pname = "simplet"; - version = "20191227-git"; - asds = [ "simplet" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simplet/2019-12-27/simplet-20191227-git.tgz"; - sha256 = "1scsalzbwxk6z48b61zq532c02l36yr3vl2jdy0xjm2diycq6jgs"; - system = "simplet"; - asd = "simplet"; - }); - systems = [ "simplet" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simplet-asdf = (build-asdf-system { - pname = "simplet-asdf"; - version = "20191227-git"; - asds = [ "simplet-asdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simplet/2019-12-27/simplet-20191227-git.tgz"; - sha256 = "1scsalzbwxk6z48b61zq532c02l36yr3vl2jdy0xjm2diycq6jgs"; - system = "simplet-asdf"; - asd = "simplet-asdf"; - }); - systems = [ "simplet-asdf" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simplified-types = (build-asdf-system { - pname = "simplified-types"; - version = "20190813-git"; - asds = [ "simplified-types" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simplified-types/2019-08-13/simplified-types-20190813-git.tgz"; - sha256 = "1hdwmn5lz717aj6qdqmfmr3cbjl8l3giwn0fb5ca9pj83cx7fg8y"; - system = "simplified-types"; - asd = "simplified-types"; - }); - systems = [ "simplified-types" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "introspect-environment" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simplified-types-test-suite = (build-asdf-system { - pname = "simplified-types-test-suite"; - version = "20190813-git"; - asds = [ "simplified-types-test-suite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simplified-types/2019-08-13/simplified-types-20190813-git.tgz"; - sha256 = "1hdwmn5lz717aj6qdqmfmr3cbjl8l3giwn0fb5ca9pj83cx7fg8y"; - system = "simplified-types-test-suite"; - asd = "simplified-types-test-suite"; - }); - systems = [ "simplified-types-test-suite" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "simplified-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - simpsamp = (build-asdf-system { - pname = "simpsamp"; - version = "0.1"; - asds = [ "simpsamp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/simpsamp/2010-10-06/simpsamp-0.1.tgz"; - sha256 = "0i85andjaz16lh4wwpdvd5kgg7lsfp206g7kniy16gs78xjy5jlc"; - system = "simpsamp"; - asd = "simpsamp"; - }); - systems = [ "simpsamp" ]; - lispLibs = [ (getAttr "jpl-util" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - single-threaded-ccl = (build-asdf-system { - pname = "single-threaded-ccl"; - version = "20150608-git"; - asds = [ "single-threaded-ccl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/single-threaded-ccl/2015-06-08/single-threaded-ccl-20150608-git.tgz"; - sha256 = "0d8cf8x77b3f7qh2cr3fnkc6i7dm7pwlnldmv9k4q033rmmhnfxb"; - system = "single-threaded-ccl"; - asd = "single-threaded-ccl"; - }); - systems = [ "single-threaded-ccl" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - singleton-classes = (build-asdf-system { - pname = "singleton-classes"; - version = "20190307-hg"; - asds = [ "singleton-classes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-abstract-classes/2019-03-07/cl-abstract-classes-20190307-hg.tgz"; - sha256 = "0q03j3ksgn56j9xvs3d3hhasplj3hvg488f4cx1z97nlyqxr5w1d"; - system = "singleton-classes"; - asd = "singleton-classes"; - }); - systems = [ "singleton-classes" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sip-hash = (build-asdf-system { - pname = "sip-hash"; - version = "20200610-git"; - asds = [ "sip-hash" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sip-hash/2020-06-10/sip-hash-20200610-git.tgz"; - sha256 = "0cd6g37lxd5i5fyg9my4jja27ki5agbpr9d635rcwpf32yhc4sh9"; - system = "sip-hash"; - asd = "sip-hash"; - }); - systems = [ "sip-hash" ]; - lispLibs = [ (getAttr "com_dot_google_dot_base" self) (getAttr "nibbles" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - skeleton-creator = (build-asdf-system { - pname = "skeleton-creator"; - version = "20191227-git"; - asds = [ "skeleton-creator" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/skeleton-creator/2019-12-27/skeleton-creator-20191227-git.tgz"; - sha256 = "1yj8w9lpb2jzyf02zg65ngmjfsakzc7k1kcw90w52gk14hv1lk6s"; - system = "skeleton-creator"; - asd = "skeleton-creator"; - }); - systems = [ "skeleton-creator" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "conf" self) (getAttr "simplet-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sketch = (build-asdf-system { - pname = "sketch"; - version = "20241012-git"; - asds = [ "sketch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sketch/2024-10-12/sketch-20241012-git.tgz"; - sha256 = "1bq0ljb2awzkk4shsd0w4v2hc2abmkwfv7nz8d88hglrvar8qbnl"; - system = "sketch"; - asd = "sketch"; - }); - systems = [ "sketch" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-plus-c" self) (getAttr "closer-mop" self) (getAttr "glkit" self) (getAttr "glu-tessellate" self) (getAttr "mathkit" self) (getAttr "md5" self) (getAttr "sdl2" self) (getAttr "sdl2-image" self) (getAttr "sdl2-ttf" self) (getAttr "sdl2kit" self) (getAttr "split-sequence" self) (getAttr "static-vectors" self) (getAttr "trivial-garbage" self) (getAttr "zpng" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sketch-examples = (build-asdf-system { - pname = "sketch-examples"; - version = "20241012-git"; - asds = [ "sketch-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sketch/2024-10-12/sketch-20241012-git.tgz"; - sha256 = "1bq0ljb2awzkk4shsd0w4v2hc2abmkwfv7nz8d88hglrvar8qbnl"; - system = "sketch-examples"; - asd = "sketch-examples"; - }); - systems = [ "sketch-examples" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "sketch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - skippy = (build-asdf-system { - pname = "skippy"; - version = "1.3.12"; - asds = [ "skippy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/skippy/2015-04-07/skippy-1.3.12.tgz"; - sha256 = "1n8925qz19w00qc67z3hc97fpmfhi0r54dd50fzqm24vhyb7qwc2"; - system = "skippy"; - asd = "skippy"; - }); - systems = [ "skippy" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - skippy-renderer = (build-asdf-system { - pname = "skippy-renderer"; - version = "20221106-git"; - asds = [ "skippy-renderer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/skippy-renderer/2022-11-06/skippy-renderer-20221106-git.tgz"; - sha256 = "0x9zv8zchxn48axl5rwfnywg9kb9m0pz3gwjk7gpg9m574jw8x0c"; - system = "skippy-renderer"; - asd = "skippy-renderer"; - }); - systems = [ "skippy-renderer" ]; - lispLibs = [ (getAttr "skippy" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - skitter = (build-asdf-system { - pname = "skitter"; - version = "release-quicklisp-620772ae-git"; - asds = [ "skitter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/skitter/2018-02-28/skitter-release-quicklisp-620772ae-git.tgz"; - sha256 = "1rixcav388fnal9v139kvagjfc60sbwd8ikbmd48lppq2nq5anwl"; - system = "skitter"; - asd = "skitter"; - }); - systems = [ "skitter" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "rtg-math" self) (getAttr "structy-defclass" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - skitter_dot_glop = (build-asdf-system { - pname = "skitter.glop"; - version = "release-quicklisp-620772ae-git"; - asds = [ "skitter.glop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/skitter/2018-02-28/skitter-release-quicklisp-620772ae-git.tgz"; - sha256 = "1rixcav388fnal9v139kvagjfc60sbwd8ikbmd48lppq2nq5anwl"; - system = "skitter.glop"; - asd = "skitter.glop"; - }); - systems = [ "skitter.glop" ]; - lispLibs = [ (getAttr "glop" self) (getAttr "skitter" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - skitter_dot_sdl2 = (build-asdf-system { - pname = "skitter.sdl2"; - version = "release-quicklisp-620772ae-git"; - asds = [ "skitter.sdl2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/skitter/2018-02-28/skitter-release-quicklisp-620772ae-git.tgz"; - sha256 = "1rixcav388fnal9v139kvagjfc60sbwd8ikbmd48lppq2nq5anwl"; - system = "skitter.sdl2"; - asd = "skitter.sdl2"; - }); - systems = [ "skitter.sdl2" ]; - lispLibs = [ (getAttr "sdl2" self) (getAttr "skitter" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - slack-client = (build-asdf-system { - pname = "slack-client"; - version = "20160825-git"; - asds = [ "slack-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/slack-client/2016-08-25/slack-client-20160825-git.tgz"; - sha256 = "1yl2wqhx1h2kw3s5dkkq5c4hk1r7679yzq41j2j2bscbl3xk3jp9"; - system = "slack-client"; - asd = "slack-client"; - }); - systems = [ "slack-client" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "blackbird" self) (getAttr "cl-async" self) (getAttr "drakma-async" self) (getAttr "event-glue" self) (getAttr "jonathan" self) (getAttr "safe-queue" self) (getAttr "websocket-driver" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - slack-client-test = (build-asdf-system { - pname = "slack-client-test"; - version = "20160825-git"; - asds = [ "slack-client-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/slack-client/2016-08-25/slack-client-20160825-git.tgz"; - sha256 = "1yl2wqhx1h2kw3s5dkkq5c4hk1r7679yzq41j2j2bscbl3xk3jp9"; - system = "slack-client-test"; - asd = "slack-client-test"; - }); - systems = [ "slack-client-test" ]; - lispLibs = [ (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "slack-client" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - slim = (build-asdf-system { - pname = "slim"; - version = "20241012-git"; - asds = [ "slim" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; - sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; - system = "slim"; - asd = "slim"; - }); - systems = [ "slim" ]; - lispLibs = [ (getAttr "mcclim" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - slite = (build-asdf-system { - pname = "slite"; - version = "20241012-git"; - asds = [ "slite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/slite/2024-10-12/slite-20241012-git.tgz"; - sha256 = "1ij1qxp20p7zfxm453v42z27ff3z6lk7hly8knk5fj3awj9nvljd"; - system = "slite"; - asd = "slite"; - }); - systems = [ "slite" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - slot-extra-options = (build-asdf-system { - pname = "slot-extra-options"; - version = "20210411-git"; - asds = [ "slot-extra-options" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/slot-extra-options/2021-04-11/slot-extra-options-20210411-git.tgz"; - sha256 = "1b2swhjjs0w1034cy045q8l3ndmci7rjawka39q23vncy6d90497"; - system = "slot-extra-options"; - asd = "slot-extra-options"; - }); - systems = [ "slot-extra-options" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "iterate" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - slot-extra-options-tests = (build-asdf-system { - pname = "slot-extra-options-tests"; - version = "20210411-git"; - asds = [ "slot-extra-options-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/slot-extra-options/2021-04-11/slot-extra-options-20210411-git.tgz"; - sha256 = "1b2swhjjs0w1034cy045q8l3ndmci7rjawka39q23vncy6d90497"; - system = "slot-extra-options-tests"; - asd = "slot-extra-options-tests"; - }); - systems = [ "slot-extra-options-tests" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "iterate" self) (getAttr "parachute" self) (getAttr "serapeum" self) (getAttr "slot-extra-options" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - slot-map = (build-asdf-system { - pname = "slot-map"; - version = "20220707-git"; - asds = [ "slot-map" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/slot-map/2022-07-07/slot-map-20220707-git.tgz"; - sha256 = "1z9qprjqj3pwqf469bxj0fvvjni1ncap6g7w5q9gmv5hnf2a4yjb"; - system = "slot-map"; - asd = "slot-map"; - }); - systems = [ "slot-map" ]; - lispLibs = [ (getAttr "dynamic-array" self) (getAttr "mfiano-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - slynk = (build-asdf-system { - pname = "slynk"; - version = "20241012-git"; - asds = [ "slynk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sly/2024-10-12/sly-20241012-git.tgz"; - sha256 = "1mxkcgh7g76mqn148zm2mhsh09whwh89wldlyfhq0d9h96zch451"; - system = "slynk"; - asd = "slynk"; - }); - systems = [ "slynk" ]; - lispLibs = [ ]; - meta = {}; - }); - slynk-macrostep = (build-asdf-system { - pname = "slynk-macrostep"; - version = "20230618-git"; - asds = [ "slynk-macrostep" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sly-macrostep/2023-06-18/sly-macrostep-20230618-git.tgz"; - sha256 = "1nxf28gn4f3n0wnv7nb5sgl36fz175y470zs9hig4kq8cp0yal0r"; - system = "slynk-macrostep"; - asd = "slynk-macrostep"; - }); - systems = [ "slynk-macrostep" ]; - lispLibs = [ (getAttr "slynk" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - slynk-named-readtables = (build-asdf-system { - pname = "slynk-named-readtables"; - version = "20230618-git"; - asds = [ "slynk-named-readtables" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sly-named-readtables/2023-06-18/sly-named-readtables-20230618-git.tgz"; - sha256 = "16asd119rzqrlclps2q6yrkis8jy5an5xgzzqvb7jdyq39zxg54q"; - system = "slynk-named-readtables"; - asd = "slynk-named-readtables"; - }); - systems = [ "slynk-named-readtables" ]; - lispLibs = [ (getAttr "slynk" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - smackjack = (build-asdf-system { - pname = "smackjack"; - version = "20180228-git"; - asds = [ "smackjack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/smackjack/2018-02-28/smackjack-20180228-git.tgz"; - sha256 = "1n2x7qij2ci70axd2xn295qqgqrvbfbpvv2438lhwd8qa92dhk8b"; - system = "smackjack"; - asd = "smackjack"; - }); - systems = [ "smackjack" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-containers" self) (getAttr "cl-json" self) (getAttr "hunchentoot" self) (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - smackjack-demo = (build-asdf-system { - pname = "smackjack-demo"; - version = "20180228-git"; - asds = [ "smackjack-demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/smackjack/2018-02-28/smackjack-20180228-git.tgz"; - sha256 = "1n2x7qij2ci70axd2xn295qqgqrvbfbpvv2438lhwd8qa92dhk8b"; - system = "smackjack-demo"; - asd = "smackjack-demo"; - }); - systems = [ "smackjack-demo" ]; - lispLibs = [ (getAttr "cl-containers" self) (getAttr "cl-who" self) (getAttr "local-time" self) (getAttr "smackjack" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - small-coalton-programs = (build-asdf-system { - pname = "small-coalton-programs"; - version = "20241012-git"; - asds = [ "small-coalton-programs" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; - sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; - system = "small-coalton-programs"; - asd = "small-coalton-programs"; - }); - systems = [ "small-coalton-programs" ]; - lispLibs = [ (getAttr "coalton" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - smart-buffer = (build-asdf-system { - pname = "smart-buffer"; - version = "20211020-git"; - asds = [ "smart-buffer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/smart-buffer/2021-10-20/smart-buffer-20211020-git.tgz"; - sha256 = "1r9y61a791m7aqgg2ixs86lc63y78w7n6dwipakcpjzscqmprppr"; - system = "smart-buffer"; - asd = "smart-buffer"; - }); - systems = [ "smart-buffer" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "xsubseq" self) ]; - meta = {}; - }); - smart-buffer-test = (build-asdf-system { - pname = "smart-buffer-test"; - version = "20211020-git"; - asds = [ "smart-buffer-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/smart-buffer/2021-10-20/smart-buffer-20211020-git.tgz"; - sha256 = "1r9y61a791m7aqgg2ixs86lc63y78w7n6dwipakcpjzscqmprppr"; - system = "smart-buffer-test"; - asd = "smart-buffer-test"; - }); - systems = [ "smart-buffer-test" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "smart-buffer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - smokebase = (build-asdf-system { - pname = "smokebase"; - version = "20210531-git"; - asds = [ "smokebase" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; - sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; - system = "smokebase"; - asd = "smokebase"; - }); - systems = [ "smokebase" ]; - lispLibs = [ (getAttr "qt_plus_libs" self) (getAttr "qt-libs" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - smoothers = (build-asdf-system { - pname = "smoothers"; - version = "20241012-git"; - asds = [ "smoothers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/smoothers/2024-10-12/smoothers-20241012-git.tgz"; - sha256 = "0byqn3xni83jkbzc0jllpyfsgjaiifsjr55aaf90pbi71as39xfd"; - system = "smoothers"; - asd = "smoothers"; - }); - systems = [ "smoothers" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "alexandria_plus" self) (getAttr "array-operations" self) (getAttr "lla" self) (getAttr "num-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - smug = (build-asdf-system { - pname = "smug"; - version = "20211230-git"; - asds = [ "smug" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/smug/2021-12-30/smug-20211230-git.tgz"; - sha256 = "13gzkj9skya2ziwclk041v7sif392ydbvhvikhg2raa3qjcxb3rq"; - system = "smug"; - asd = "smug"; - }); - systems = [ "smug" ]; - lispLibs = [ (getAttr "asdf-package-system" self) ]; - meta = {}; - }); - snakes = (build-asdf-system { - pname = "snakes"; - version = "20221106-git"; - asds = [ "snakes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snakes/2022-11-06/snakes-20221106-git.tgz"; - sha256 = "17fqkw256c2iacy5g37sv9h0mbrmb3fg2s9sd83gj9clrg5r4wkl"; - system = "snakes"; - asd = "snakes"; - }); - systems = [ "snakes" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-cont" self) (getAttr "cl-utilities" self) (getAttr "closer-mop" self) (getAttr "fiveam" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snappy = (build-asdf-system { - pname = "snappy"; - version = "20211209-git"; - asds = [ "snappy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snappy/2021-12-09/snappy-20211209-git.tgz"; - sha256 = "1g0d8icbqmahywqczb8pimr63970dil6mnlxkv3y9ng31dg0npy6"; - system = "snappy"; - asd = "snappy"; - }); - systems = [ "snappy" ]; - lispLibs = [ (getAttr "com_dot_google_dot_base" self) (getAttr "nibbles" self) (getAttr "varint" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark = (build-asdf-system { - pname = "snark"; - version = "20160421-git"; - asds = [ "snark" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark"; - asd = "snark"; - }); - systems = [ "snark" ]; - lispLibs = [ (getAttr "snark-implementation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-agenda = (build-asdf-system { - pname = "snark-agenda"; - version = "20160421-git"; - asds = [ "snark-agenda" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-agenda"; - asd = "snark-agenda"; - }); - systems = [ "snark-agenda" ]; - lispLibs = [ (getAttr "snark-auxiliary-packages" self) (getAttr "snark-deque" self) (getAttr "snark-lisp" self) (getAttr "snark-sparse-array" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-auxiliary-packages = (build-asdf-system { - pname = "snark-auxiliary-packages"; - version = "20160421-git"; - asds = [ "snark-auxiliary-packages" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-auxiliary-packages"; - asd = "snark-auxiliary-packages"; - }); - systems = [ "snark-auxiliary-packages" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-deque = (build-asdf-system { - pname = "snark-deque"; - version = "20160421-git"; - asds = [ "snark-deque" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-deque"; - asd = "snark-deque"; - }); - systems = [ "snark-deque" ]; - lispLibs = [ (getAttr "snark-auxiliary-packages" self) (getAttr "snark-lisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-dpll = (build-asdf-system { - pname = "snark-dpll"; - version = "20160421-git"; - asds = [ "snark-dpll" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-dpll"; - asd = "snark-dpll"; - }); - systems = [ "snark-dpll" ]; - lispLibs = [ (getAttr "snark-auxiliary-packages" self) (getAttr "snark-lisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-examples = (build-asdf-system { - pname = "snark-examples"; - version = "20160421-git"; - asds = [ "snark-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-examples"; - asd = "snark-examples"; - }); - systems = [ "snark-examples" ]; - lispLibs = [ (getAttr "snark" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-feature = (build-asdf-system { - pname = "snark-feature"; - version = "20160421-git"; - asds = [ "snark-feature" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-feature"; - asd = "snark-feature"; - }); - systems = [ "snark-feature" ]; - lispLibs = [ (getAttr "snark-auxiliary-packages" self) (getAttr "snark-lisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-implementation = (build-asdf-system { - pname = "snark-implementation"; - version = "20160421-git"; - asds = [ "snark-implementation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-implementation"; - asd = "snark-implementation"; - }); - systems = [ "snark-implementation" ]; - lispLibs = [ (getAttr "snark-agenda" self) (getAttr "snark-auxiliary-packages" self) (getAttr "snark-deque" self) (getAttr "snark-dpll" self) (getAttr "snark-feature" self) (getAttr "snark-infix-reader" self) (getAttr "snark-lisp" self) (getAttr "snark-numbering" self) (getAttr "snark-pkg" self) (getAttr "snark-sparse-array" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-infix-reader = (build-asdf-system { - pname = "snark-infix-reader"; - version = "20160421-git"; - asds = [ "snark-infix-reader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-infix-reader"; - asd = "snark-infix-reader"; - }); - systems = [ "snark-infix-reader" ]; - lispLibs = [ (getAttr "snark-auxiliary-packages" self) (getAttr "snark-lisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-lisp = (build-asdf-system { - pname = "snark-lisp"; - version = "20160421-git"; - asds = [ "snark-lisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-lisp"; - asd = "snark-lisp"; - }); - systems = [ "snark-lisp" ]; - lispLibs = [ (getAttr "snark-auxiliary-packages" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-loads = (build-asdf-system { - pname = "snark-loads"; - version = "20160421-git"; - asds = [ "snark-loads" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-loads"; - asd = "snark-loads"; - }); - systems = [ "snark-loads" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-numbering = (build-asdf-system { - pname = "snark-numbering"; - version = "20160421-git"; - asds = [ "snark-numbering" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-numbering"; - asd = "snark-numbering"; - }); - systems = [ "snark-numbering" ]; - lispLibs = [ (getAttr "snark-auxiliary-packages" self) (getAttr "snark-lisp" self) (getAttr "snark-sparse-array" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-pkg = (build-asdf-system { - pname = "snark-pkg"; - version = "20160421-git"; - asds = [ "snark-pkg" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-pkg"; - asd = "snark-pkg"; - }); - systems = [ "snark-pkg" ]; - lispLibs = [ (getAttr "snark-dpll" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snark-sparse-array = (build-asdf-system { - pname = "snark-sparse-array"; - version = "20160421-git"; - asds = [ "snark-sparse-array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; - sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; - system = "snark-sparse-array"; - asd = "snark-sparse-array"; - }); - systems = [ "snark-sparse-array" ]; - lispLibs = [ (getAttr "snark-auxiliary-packages" self) (getAttr "snark-lisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sndfile-blob = (build-asdf-system { - pname = "sndfile-blob"; - version = "stable-git"; - asds = [ "sndfile-blob" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sndfile-blob/2020-10-16/sndfile-blob-stable-git.tgz"; - sha256 = "1csbm2cgj76smia59044vx8698w9dy223cmwv8l4i8kb95m1i3l0"; - system = "sndfile-blob"; - asd = "sndfile-blob"; - }); - systems = [ "sndfile-blob" ]; - lispLibs = [ (getAttr "bodge-blobs-support" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snmp = (build-asdf-system { - pname = "snmp"; - version = "6.1"; - asds = [ "snmp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snmp/2016-10-31/snmp-6.1.tgz"; - sha256 = "0qpy6jfp0v9i80gli1gf98sj0h67x9g5a8bqxrsxnqyi3h59di5s"; - system = "snmp"; - asd = "snmp"; - }); - systems = [ "snmp" ]; - lispLibs = [ (getAttr "ieee-floats" self) (getAttr "ironclad" self) (getAttr "portable-threads" self) (getAttr "trivial-gray-streams" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snmp-server = (build-asdf-system { - pname = "snmp-server"; - version = "6.1"; - asds = [ "snmp-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snmp/2016-10-31/snmp-6.1.tgz"; - sha256 = "0qpy6jfp0v9i80gli1gf98sj0h67x9g5a8bqxrsxnqyi3h59di5s"; - system = "snmp-server"; - asd = "snmp-server"; - }); - systems = [ "snmp-server" ]; - lispLibs = [ (getAttr "snmp" self) (getAttr "usocket-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snmp-test = (build-asdf-system { - pname = "snmp-test"; - version = "6.1"; - asds = [ "snmp-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snmp/2016-10-31/snmp-6.1.tgz"; - sha256 = "0qpy6jfp0v9i80gli1gf98sj0h67x9g5a8bqxrsxnqyi3h59di5s"; - system = "snmp-test"; - asd = "snmp-test"; - }); - systems = [ "snmp-test" ]; - lispLibs = [ (getAttr "snmp" self) (getAttr "snmp-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snmp-ui = (build-asdf-system { - pname = "snmp-ui"; - version = "6.1"; - asds = [ "snmp-ui" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snmp/2016-10-31/snmp-6.1.tgz"; - sha256 = "0qpy6jfp0v9i80gli1gf98sj0h67x9g5a8bqxrsxnqyi3h59di5s"; - system = "snmp-ui"; - asd = "snmp-ui"; - }); - systems = [ "snmp-ui" ]; - lispLibs = [ (getAttr "snmp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snooze = (build-asdf-system { - pname = "snooze"; - version = "20241012-git"; - asds = [ "snooze" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snooze/2024-10-12/snooze-20241012-git.tgz"; - sha256 = "0gm9vxi7lcir80snka3qkl6sw8z90jaqf31c72bgyk9j8qkf7xvc"; - system = "snooze"; - asd = "snooze"; - }); - systems = [ "snooze" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "parse-float" self) (getAttr "quri" self) (getAttr "rfc2388" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snooze-demo = (build-asdf-system { - pname = "snooze-demo"; - version = "20241012-git"; - asds = [ "snooze-demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snooze/2024-10-12/snooze-20241012-git.tgz"; - sha256 = "0gm9vxi7lcir80snka3qkl6sw8z90jaqf31c72bgyk9j8qkf7xvc"; - system = "snooze-demo"; - asd = "snooze"; - }); - systems = [ "snooze-demo" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-css" self) (getAttr "cl-fad" self) (getAttr "cl-json" self) (getAttr "cl-who" self) (getAttr "hunchentoot" self) (getAttr "local-time" self) (getAttr "local-time-duration" self) (getAttr "snooze" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - snooze-tests = (build-asdf-system { - pname = "snooze-tests"; - version = "20241012-git"; - asds = [ "snooze-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/snooze/2024-10-12/snooze-20241012-git.tgz"; - sha256 = "0gm9vxi7lcir80snka3qkl6sw8z90jaqf31c72bgyk9j8qkf7xvc"; - system = "snooze-tests"; - asd = "snooze"; - }); - systems = [ "snooze-tests" ]; - lispLibs = [ (getAttr "fiasco" self) (getAttr "snooze" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - softdrink = (build-asdf-system { - pname = "softdrink"; - version = "20231021-git"; - asds = [ "softdrink" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/softdrink/2023-10-21/softdrink-20231021-git.tgz"; - sha256 = "1454mqpwb2s7m1myhibj2mrlm64wng1jgbv94mhs6hpzj2r2mgdi"; - system = "softdrink"; - asd = "softdrink"; - }); - systems = [ "softdrink" ]; - lispLibs = [ (getAttr "lass" self) (getAttr "lquery" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - software-evolution-library = (build-asdf-system { - pname = "software-evolution-library"; - version = "20241012-git"; - asds = [ "software-evolution-library" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sel/2024-10-12/sel-20241012-git.tgz"; - sha256 = "1j1disr1wcql30hdj3f49ss41843wlmqx486nkna6qbnnsfay66w"; - system = "software-evolution-library"; - asd = "software-evolution-library"; - }); - systems = [ "software-evolution-library" ]; - lispLibs = [ (getAttr "asdf-package-system" self) (getAttr "atomics" self) (getAttr "cffi-grovel" self) (getAttr "deploy" self) (getAttr "gt" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - solid-engine = (build-asdf-system { - pname = "solid-engine"; - version = "20190521-git"; - asds = [ "solid-engine" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/solid-engine/2019-05-21/solid-engine-20190521-git.tgz"; - sha256 = "1pxrgxfqz8br258jy35qyimsrz544fg9k7lw2jshkj4jr2pswsv0"; - system = "solid-engine"; - asd = "solid-engine"; - }); - systems = [ "solid-engine" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - soundex = (build-asdf-system { - pname = "soundex"; - version = "1.0"; - asds = [ "soundex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/soundex/2010-10-06/soundex-1.0.tgz"; - sha256 = "00ar2x7ja35337v6gwa4h2b8w7gf7dwx5mdfz91dqay43kx1pjsi"; - system = "soundex"; - asd = "soundex"; - }); - systems = [ "soundex" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - source-error = (build-asdf-system { - pname = "source-error"; - version = "20241012-git"; - asds = [ "source-error" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; - sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; - system = "source-error"; - asd = "source-error"; - }); - systems = [ "source-error" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - south = (build-asdf-system { - pname = "south"; - version = "20231021-git"; - asds = [ "south" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/south/2023-10-21/south-20231021-git.tgz"; - sha256 = "0acvi3nwddwphxm92i8bbv1nbb9zzx7gbcza5cr68rs8wydsr8h3"; - system = "south"; - asd = "south"; - }); - systems = [ "south" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "ironclad" self) (getAttr "uuid" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sparse-set = (build-asdf-system { - pname = "sparse-set"; - version = "20220707-git"; - asds = [ "sparse-set" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sparse-set/2022-07-07/sparse-set-20220707-git.tgz"; - sha256 = "0czms03lrvg20hw3sz7wzzkl1z0vm0ndb3dmbvwsjd7m89fag793"; - system = "sparse-set"; - asd = "sparse-set"; - }); - systems = [ "sparse-set" ]; - lispLibs = [ (getAttr "mfiano-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - spatial-trees = (build-asdf-system { - pname = "spatial-trees"; - version = "20140826-git"; - asds = [ "spatial-trees" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/spatial-trees/2014-08-26/spatial-trees-20140826-git.tgz"; - sha256 = "11rhc6h501dwcik2igkszz7b9n515cr99m5pjh4r2qfwgiri6ysa"; - system = "spatial-trees"; - asd = "spatial-trees"; - }); - systems = [ "spatial-trees" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - spatial-trees_dot_nns = (build-asdf-system { - pname = "spatial-trees.nns"; - version = "20140826-git"; - asds = [ "spatial-trees.nns" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/spatial-trees/2014-08-26/spatial-trees-20140826-git.tgz"; - sha256 = "11rhc6h501dwcik2igkszz7b9n515cr99m5pjh4r2qfwgiri6ysa"; - system = "spatial-trees.nns"; - asd = "spatial-trees.nns"; - }); - systems = [ "spatial-trees.nns" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "optima" self) (getAttr "spatial-trees" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - spatial-trees_dot_nns_dot_test = (build-asdf-system { - pname = "spatial-trees.nns.test"; - version = "20140826-git"; - asds = [ "spatial-trees.nns.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/spatial-trees/2014-08-26/spatial-trees-20140826-git.tgz"; - sha256 = "11rhc6h501dwcik2igkszz7b9n515cr99m5pjh4r2qfwgiri6ysa"; - system = "spatial-trees.nns.test"; - asd = "spatial-trees.nns.test"; - }); - systems = [ "spatial-trees.nns.test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "fiveam" self) (getAttr "iterate" self) (getAttr "optima" self) (getAttr "spatial-trees" self) (getAttr "spatial-trees_dot_nns" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - spatial-trees_dot_test = (build-asdf-system { - pname = "spatial-trees.test"; - version = "20140826-git"; - asds = [ "spatial-trees.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/spatial-trees/2014-08-26/spatial-trees-20140826-git.tgz"; - sha256 = "11rhc6h501dwcik2igkszz7b9n515cr99m5pjh4r2qfwgiri6ysa"; - system = "spatial-trees.test"; - asd = "spatial-trees.test"; - }); - systems = [ "spatial-trees.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "spatial-trees" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - special-functions = (build-asdf-system { - pname = "special-functions"; - version = "20221106-git"; - asds = [ "special-functions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/special-functions/2022-11-06/special-functions-20221106-git.tgz"; - sha256 = "092szffy7zfxgrvfck11wnj8l0mgcym13yiafj01ad02lbj1fnnv"; - system = "special-functions"; - asd = "special-functions"; - }); - systems = [ "special-functions" ]; - lispLibs = [ (getAttr "alexandria_plus" self) (getAttr "float-features" self) (getAttr "let-plus" self) (getAttr "num-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - specialization-store = (build-asdf-system { - pname = "specialization-store"; - version = "v0.0.5"; - asds = [ "specialization-store" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/specialization-store/2020-06-10/specialization-store-v0.0.5.tgz"; - sha256 = "03q0szyz8ygqmg10q4j97dy7gfr9icxay9s8bgs883yncbk42y6c"; - system = "specialization-store"; - asd = "specialization-store"; - }); - systems = [ "specialization-store" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "introspect-environment" self) (getAttr "specialization-store-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - specialization-store-features = (build-asdf-system { - pname = "specialization-store-features"; - version = "v0.0.5"; - asds = [ "specialization-store-features" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/specialization-store/2020-06-10/specialization-store-v0.0.5.tgz"; - sha256 = "03q0szyz8ygqmg10q4j97dy7gfr9icxay9s8bgs883yncbk42y6c"; - system = "specialization-store-features"; - asd = "specialization-store-features"; - }); - systems = [ "specialization-store-features" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "introspect-environment" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - specialization-store-tests = (build-asdf-system { - pname = "specialization-store-tests"; - version = "v0.0.5"; - asds = [ "specialization-store-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/specialization-store/2020-06-10/specialization-store-v0.0.5.tgz"; - sha256 = "03q0szyz8ygqmg10q4j97dy7gfr9icxay9s8bgs883yncbk42y6c"; - system = "specialization-store-tests"; - asd = "specialization-store-tests"; - }); - systems = [ "specialization-store-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "specialization-store" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - specialized-function = (build-asdf-system { - pname = "specialized-function"; - version = "20210531-git"; - asds = [ "specialized-function" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/specialized-function/2021-05-31/specialized-function-20210531-git.tgz"; - sha256 = "19hfgc83b7as630r1w9r8yl0v6xq3dn01vcrl0bd4pza5hgjn4la"; - system = "specialized-function"; - asd = "specialized-function"; - }); - systems = [ "specialized-function" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "lisp-namespace" self) (getAttr "trivia" self) (getAttr "trivial-cltl2" self) (getAttr "type-r" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - specialized-function_dot_test = (build-asdf-system { - pname = "specialized-function.test"; - version = "20210531-git"; - asds = [ "specialized-function.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/specialized-function/2021-05-31/specialized-function-20210531-git.tgz"; - sha256 = "19hfgc83b7as630r1w9r8yl0v6xq3dn01vcrl0bd4pza5hgjn4la"; - system = "specialized-function.test"; - asd = "specialized-function.test"; - }); - systems = [ "specialized-function.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "specialized-function" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - speechless = (build-asdf-system { - pname = "speechless"; - version = "20231021-git"; - asds = [ "speechless" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/speechless/2023-10-21/speechless-20231021-git.tgz"; - sha256 = "0x1v3gf0f0xpyxs8392r4xaqz214zmd1j89l61x9bg2h30k8ls37"; - system = "speechless"; - asd = "speechless"; - }); - systems = [ "speechless" ]; - lispLibs = [ (getAttr "cl-markless" self) (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - spell = (build-asdf-system { - pname = "spell"; - version = "20190307-git"; - asds = [ "spell" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/spell/2019-03-07/spell-20190307-git.tgz"; - sha256 = "1ifhx5q0iz80i9zwgcpv3w7xpp92ar9grz25008wnqzaayhfl020"; - system = "spell"; - asd = "spell"; - }); - systems = [ "spell" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - spellcheck = (build-asdf-system { - pname = "spellcheck"; - version = "20131003-git"; - asds = [ "spellcheck" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/spellcheck/2013-10-03/spellcheck-20131003-git.tgz"; - sha256 = "0a0r1dgh7y06s7j9mzxrryri8fhajzjsrrsh3i6vv65vq5zzxlka"; - system = "spellcheck"; - asd = "spellcheck"; - }); - systems = [ "spellcheck" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sphinx = (build-asdf-system { - pname = "sphinx"; - version = "20110619-git"; - asds = [ "sphinx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sphinx/2011-06-19/cl-sphinx-20110619-git.tgz"; - sha256 = "0z1ksxz1gh12ly6lbc77l0d5f380s81vx44qakm2dl1398lgb7x1"; - system = "sphinx"; - asd = "sphinx"; - }); - systems = [ "sphinx" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "closure-template" self) (getAttr "colorize" self) (getAttr "docutils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - spinneret = (build-asdf-system { - pname = "spinneret"; - version = "20241012-git"; - asds = [ "spinneret" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/spinneret/2024-10-12/spinneret-20241012-git.tgz"; - sha256 = "09ak35p487bwlwbv0vcdg9h869n8m7i3j1qj4f53lh1bm5s1zi5n"; - system = "spinneret"; - asd = "spinneret"; - }); - systems = [ "spinneret" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "global-vars" self) (getAttr "in-nomine" self) (getAttr "parenscript" self) (getAttr "serapeum" self) (getAttr "trivia" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - split-sequence = (build-asdf-system { - pname = "split-sequence"; - version = "v2.0.1"; - asds = [ "split-sequence" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/split-sequence/2021-05-31/split-sequence-v2.0.1.tgz"; - sha256 = "172k7iv775kwism6304p6z7mqpjvipl57nq1bgvmbk445943fmhq"; - system = "split-sequence"; - asd = "split-sequence"; - }); - systems = [ "split-sequence" ]; - lispLibs = [ ]; - meta = {}; - }); - sqlite = (build-asdf-system { - pname = "sqlite"; - version = "20190813-git"; - asds = [ "sqlite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sqlite/2019-08-13/cl-sqlite-20190813-git.tgz"; - sha256 = "08iv7b4m0hh7qx2cvq4f510nrgdld0vicnvmqsh9w0fgrcgmyg4k"; - system = "sqlite"; - asd = "sqlite"; - }); - systems = [ "sqlite" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "iterate" self) ]; - meta = {}; - }); - srfi-1 = (build-asdf-system { - pname = "srfi-1"; - version = "20200218-git"; - asds = [ "srfi-1" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/srfi-1/2020-02-18/srfi-1-20200218-git.tgz"; - sha256 = "00r2ikf1ck1zz3mx3jgk3plf3ibfhhrr8sc8hzr6ix34sbfvdadg"; - system = "srfi-1"; - asd = "srfi-1"; - }); - systems = [ "srfi-1" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - srfi-1_dot_test = (build-asdf-system { - pname = "srfi-1.test"; - version = "20200218-git"; - asds = [ "srfi-1.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/srfi-1/2020-02-18/srfi-1-20200218-git.tgz"; - sha256 = "00r2ikf1ck1zz3mx3jgk3plf3ibfhhrr8sc8hzr6ix34sbfvdadg"; - system = "srfi-1.test"; - asd = "srfi-1"; - }); - systems = [ "srfi-1.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "srfi-1" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - srfi-23 = (build-asdf-system { - pname = "srfi-23"; - version = "20200218-git"; - asds = [ "srfi-23" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/srfi-23/2020-02-18/srfi-23-20200218-git.tgz"; - sha256 = "0hgq2bdpdjp550kk9xlrxh82n45ldb42j2zzhkndmffh4rp9hd13"; - system = "srfi-23"; - asd = "srfi-23"; - }); - systems = [ "srfi-23" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - srfi-6 = (build-asdf-system { - pname = "srfi-6"; - version = "20200218-git"; - asds = [ "srfi-6" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/srfi-6/2020-02-18/srfi-6-20200218-git.tgz"; - sha256 = "1m9316r75haig84fhcrfm69gq0zfh5xqwqw8wsccc6z6vpz7pfwm"; - system = "srfi-6"; - asd = "srfi-6"; - }); - systems = [ "srfi-6" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - srfi-98 = (build-asdf-system { - pname = "srfi-98"; - version = "20200218-git"; - asds = [ "srfi-98" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/srfi-98/2020-02-18/srfi-98-20200218-git.tgz"; - sha256 = "0qqa7c6nas85n8mdpmk996jh12xm0nf63nhj1chi9qkwgm924fj3"; - system = "srfi-98"; - asd = "srfi-98"; - }); - systems = [ "srfi-98" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - srfi-98_dot_test = (build-asdf-system { - pname = "srfi-98.test"; - version = "20200218-git"; - asds = [ "srfi-98.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/srfi-98/2020-02-18/srfi-98-20200218-git.tgz"; - sha256 = "0qqa7c6nas85n8mdpmk996jh12xm0nf63nhj1chi9qkwgm924fj3"; - system = "srfi-98.test"; - asd = "srfi-98"; - }); - systems = [ "srfi-98.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "srfi-98" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sse-client = (build-asdf-system { - pname = "sse-client"; - version = "20210807-git"; - asds = [ "sse-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sse/2021-08-07/cl-sse-20210807-git.tgz"; - sha256 = "1by7xx397fyplxrydhfjm7nkxb6gmqh0h5f0rp4kh5dx45gk59gl"; - system = "sse-client"; - asd = "sse-client"; - }); - systems = [ "sse-client" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sse-client-test = (build-asdf-system { - pname = "sse-client-test"; - version = "20210807-git"; - asds = [ "sse-client-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sse/2021-08-07/cl-sse-20210807-git.tgz"; - sha256 = "1by7xx397fyplxrydhfjm7nkxb6gmqh0h5f0rp4kh5dx45gk59gl"; - system = "sse-client-test"; - asd = "sse-client-test"; - }); - systems = [ "sse-client-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "sse-client" self) (getAttr "trivial-escapes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sse-demo = (build-asdf-system { - pname = "sse-demo"; - version = "20210807-git"; - asds = [ "sse-demo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sse/2021-08-07/cl-sse-20210807-git.tgz"; - sha256 = "1by7xx397fyplxrydhfjm7nkxb6gmqh0h5f0rp4kh5dx45gk59gl"; - system = "sse-demo"; - asd = "sse-demo"; - }); - systems = [ "sse-demo" ]; - lispLibs = [ (getAttr "easy-routes" self) (getAttr "flexi-streams" self) (getAttr "hunchentoot" self) (getAttr "sse-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sse-server = (build-asdf-system { - pname = "sse-server"; - version = "20210807-git"; - asds = [ "sse-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sse/2021-08-07/cl-sse-20210807-git.tgz"; - sha256 = "1by7xx397fyplxrydhfjm7nkxb6gmqh0h5f0rp4kh5dx45gk59gl"; - system = "sse-server"; - asd = "sse-server"; - }); - systems = [ "sse-server" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "trivial-escapes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sse-server-test = (build-asdf-system { - pname = "sse-server-test"; - version = "20210807-git"; - asds = [ "sse-server-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sse/2021-08-07/cl-sse-20210807-git.tgz"; - sha256 = "1by7xx397fyplxrydhfjm7nkxb6gmqh0h5f0rp4kh5dx45gk59gl"; - system = "sse-server-test"; - asd = "sse-server-test"; - }); - systems = [ "sse-server-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "sse-server" self) (getAttr "trivial-escapes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - st-json = (build-asdf-system { - pname = "st-json"; - version = "20210630-git"; - asds = [ "st-json" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/st-json/2021-06-30/st-json-20210630-git.tgz"; - sha256 = "06qrhr5iw73k96lai2x9w52l6gnmlxy7fsr0r35gz6nz1f71x7gx"; - system = "st-json"; - asd = "st-json"; - }); - systems = [ "st-json" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - standard-cl = (build-asdf-system { - pname = "standard-cl"; - version = "20121125-git"; - asds = [ "standard-cl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-match/2012-11-25/cl-match-20121125-git.tgz"; - sha256 = "1qc8gzp7f4phgyi5whkxacrqzdqs0y1hvkf71m8n7l303jly9wjf"; - system = "standard-cl"; - asd = "standard-cl"; - }); - systems = [ "standard-cl" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - staple = (build-asdf-system { - pname = "staple"; - version = "20241012-git"; - asds = [ "staple" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; - sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; - system = "staple"; - asd = "staple"; - }); - systems = [ "staple" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-ppcre" self) (getAttr "clip" self) (getAttr "definitions" self) (getAttr "documentation-utils" self) (getAttr "language-codes" self) (getAttr "pathname-utils" self) (getAttr "staple-code-parser" self) (getAttr "staple-package-recording" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - staple-code-parser = (build-asdf-system { - pname = "staple-code-parser"; - version = "20241012-git"; - asds = [ "staple-code-parser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; - sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; - system = "staple-code-parser"; - asd = "staple-code-parser"; - }); - systems = [ "staple-code-parser" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "concrete-syntax-tree" self) (getAttr "concrete-syntax-tree-destructuring" self) (getAttr "concrete-syntax-tree-lambda-list" self) (getAttr "definitions" self) (getAttr "documentation-utils" self) (getAttr "eclector" self) (getAttr "eclector-concrete-syntax-tree" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - staple-markdown = (build-asdf-system { - pname = "staple-markdown"; - version = "20241012-git"; - asds = [ "staple-markdown" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; - sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; - system = "staple-markdown"; - asd = "staple-markdown"; - }); - systems = [ "staple-markdown" ]; - lispLibs = [ (getAttr "_3bmd" self) (getAttr "_3bmd-ext-code-blocks" self) (getAttr "staple" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - staple-markless = (build-asdf-system { - pname = "staple-markless"; - version = "20241012-git"; - asds = [ "staple-markless" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; - sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; - system = "staple-markless"; - asd = "staple-markless"; - }); - systems = [ "staple-markless" ]; - lispLibs = [ (getAttr "cl-markless-plump" self) (getAttr "staple" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - staple-package-recording = (build-asdf-system { - pname = "staple-package-recording"; - version = "20241012-git"; - asds = [ "staple-package-recording" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; - sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; - system = "staple-package-recording"; - asd = "staple-package-recording"; - }); - systems = [ "staple-package-recording" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - staple-restructured-text = (build-asdf-system { - pname = "staple-restructured-text"; - version = "20241012-git"; - asds = [ "staple-restructured-text" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; - sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; - system = "staple-restructured-text"; - asd = "staple-restructured-text"; - }); - systems = [ "staple-restructured-text" ]; - lispLibs = [ (getAttr "docutils" self) (getAttr "staple" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - staple-server = (build-asdf-system { - pname = "staple-server"; - version = "20241012-git"; - asds = [ "staple-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; - sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; - system = "staple-server"; - asd = "staple-server"; - }); - systems = [ "staple-server" ]; - lispLibs = [ (getAttr "dissect" self) (getAttr "documentation-utils" self) (getAttr "hunchentoot" self) (getAttr "staple-markdown" self) (getAttr "staple-markless" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stars = (build-asdf-system { - pname = "stars"; - version = "20180831-git"; - asds = [ "stars" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sprint-stars/2018-08-31/sprint-stars-20180831-git.tgz"; - sha256 = "1pm6wvywfgy0vlb0b2lbybpvhw9xzyn1nlpy0wpcglxxig6mnrgi"; - system = "stars"; - asd = "stars"; - }); - systems = [ "stars" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "drakma" self) (getAttr "xmls" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - static-dispatch = (build-asdf-system { - pname = "static-dispatch"; - version = "20211209-git"; - asds = [ "static-dispatch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/static-dispatch/2021-12-09/static-dispatch-20211209-git.tgz"; - sha256 = "1cishp7nckda5hav6c907axdfn1zpmzxpsy6hk7kkb69qn81yn2i"; - system = "static-dispatch"; - asd = "static-dispatch"; - }); - systems = [ "static-dispatch" ]; - lispLibs = [ (getAttr "agutil" self) (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "arrows" self) (getAttr "cl-environments" self) (getAttr "cl-form-types" self) (getAttr "closer-mop" self) (getAttr "iterate" self) (getAttr "optima" self) ]; - meta = {}; - }); - static-vectors = (build-asdf-system { - pname = "static-vectors"; - version = "v1.9.3"; - asds = [ "static-vectors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/static-vectors/2024-10-12/static-vectors-v1.9.3.tgz"; - sha256 = "1sn37hyf6x56irn2qqc51ncqswa3n94j6cxwcj2ixgxmszcyzx5h"; - system = "static-vectors"; - asd = "static-vectors"; - }); - systems = [ "static-vectors" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) ]; - meta = {}; - }); - statistics = (build-asdf-system { - pname = "statistics"; - version = "20241012-git"; - asds = [ "statistics" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/statistics/2024-10-12/statistics-20241012-git.tgz"; - sha256 = "00dir3sif9jqc0b48vsk8r41h4zmf95jj4nqrc45mbnr80pmdrsl"; - system = "statistics"; - asd = "statistics"; - }); - systems = [ "statistics" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "distributions" self) (getAttr "let-plus" self) (getAttr "num-utils" self) (getAttr "org_dot_tfeb_dot_conduit-packages" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - statusor = (build-asdf-system { - pname = "statusor"; - version = "20230618-git"; - asds = [ "statusor" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/statusor/2023-06-18/statusor-20230618-git.tgz"; - sha256 = "1mxj4q7grvma6q05vj6sw4h4f2s121mnd77271lwnp74kjwh17cq"; - system = "statusor"; - asd = "statusor"; - }); - systems = [ "statusor" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stdutils = (build-asdf-system { - pname = "stdutils"; - version = "20111001-git"; - asds = [ "stdutils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-stdutils/2011-10-01/cl-stdutils-20111001-git.tgz"; - sha256 = "16vxxphqdq8264x0aanm36x9r6d3ci1gjf4vf46mwl59gcff4wcj"; - system = "stdutils"; - asd = "stdutils"; - }); - systems = [ "stdutils" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stealth-mixin = (build-asdf-system { - pname = "stealth-mixin"; - version = "20211020-git"; - asds = [ "stealth-mixin" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stealth-mixin/2021-10-20/stealth-mixin-20211020-git.tgz"; - sha256 = "0ar9cdmbmdnqz1ywpw34n47hlh0vqmb6pl76f5vbfgip3c81xwyi"; - system = "stealth-mixin"; - asd = "stealth-mixin"; - }); - systems = [ "stealth-mixin" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stefil = (build-asdf-system { - pname = "stefil"; - version = "20181210-git"; - asds = [ "stefil" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stefil/2018-12-10/stefil-20181210-git.tgz"; - sha256 = "0bqz64q2szzhf91zyqyssmvrz7da6442rs01808pf3wrdq28bclh"; - system = "stefil"; - asd = "stefil"; - }); - systems = [ "stefil" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "metabang-bind" self) (getAttr "swank" self) ]; - meta = {}; - }); - stefil_plus = (build-asdf-system { - pname = "stefil+"; - version = "20211209-git"; - asds = [ "stefil+" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stefil-/2021-12-09/stefil--20211209-git.tgz"; - sha256 = "039jjhcb3ka6vag39hz5v1bi81x444rqj6rb3np5qbm07dh1aij0"; - system = "stefil+"; - asd = "stefil+"; - }); - systems = [ "stefil+" ]; - lispLibs = [ (getAttr "asdf-package-system" self) (getAttr "gt" self) (getAttr "metabang-bind" self) (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stefil-test = (build-asdf-system { - pname = "stefil-test"; - version = "20181210-git"; - asds = [ "stefil-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stefil/2018-12-10/stefil-20181210-git.tgz"; - sha256 = "0bqz64q2szzhf91zyqyssmvrz7da6442rs01808pf3wrdq28bclh"; - system = "stefil-test"; - asd = "stefil"; - }); - systems = [ "stefil-test" ]; - lispLibs = [ (getAttr "stefil" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stem = (build-asdf-system { - pname = "stem"; - version = "20150608-git"; - asds = [ "stem" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stem/2015-06-08/stem-20150608-git.tgz"; - sha256 = "0a2kr09c3qcwg16n8rm15qgy5p9l6z4m72jray0846hqbnji77mp"; - system = "stem"; - asd = "stem"; - }); - systems = [ "stem" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stepster = (build-asdf-system { - pname = "stepster"; - version = "20241012-git"; - asds = [ "stepster" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stepster/2024-10-12/stepster-20241012-git.tgz"; - sha256 = "027psal692mvpaj8bzp8fkkrsy5pgyrg8sr21xgc4m8ypp0shvw3"; - system = "stepster"; - asd = "stepster"; - }); - systems = [ "stepster" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-ppcre" self) (getAttr "cl-reexport" self) (getAttr "clss" self) (getAttr "dexador" self) (getAttr "jonathan" self) (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stl = (build-asdf-system { - pname = "stl"; - version = "20171019-git"; - asds = [ "stl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stl/2017-10-19/stl-20171019-git.tgz"; - sha256 = "12v11bsarlnx5k930gx116wbgv41kwm45ysdikq3am4x3lqsjz2n"; - system = "stl"; - asd = "stl"; - }); - systems = [ "stl" ]; - lispLibs = [ (getAttr "_3d-vectors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stmx = (build-asdf-system { - pname = "stmx"; - version = "stable-95f7dea8-git"; - asds = [ "stmx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stmx/2024-10-12/stmx-stable-95f7dea8-git.tgz"; - sha256 = "1qq25y79casaa56a76gj9hk2f3hjcc5z3f4na4vy3sw99km54hn9"; - system = "stmx"; - asd = "stmx"; - }); - systems = [ "stmx" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "closer-mop" self) (getAttr "log4cl" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stmx_dot_test = (build-asdf-system { - pname = "stmx.test"; - version = "stable-95f7dea8-git"; - asds = [ "stmx.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stmx/2024-10-12/stmx-stable-95f7dea8-git.tgz"; - sha256 = "1qq25y79casaa56a76gj9hk2f3hjcc5z3f4na4vy3sw99km54hn9"; - system = "stmx.test"; - asd = "stmx.test"; - }); - systems = [ "stmx.test" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "fiveam" self) (getAttr "log4cl" self) (getAttr "stmx" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stopclock = (build-asdf-system { - pname = "stopclock"; - version = "v1.0.2"; - asds = [ "stopclock" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stopclock/2023-10-21/stopclock-v1.0.2.tgz"; - sha256 = "1p5lygznfasad1sw8whd2bg9bwi3z7nbncr3samd55nsi5yr3hfd"; - system = "stopclock"; - asd = "stopclock"; - }); - systems = [ "stopclock" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - str = (build-asdf-system { - pname = "str"; - version = "20241012-git"; - asds = [ "str" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-str/2024-10-12/cl-str-20241012-git.tgz"; - sha256 = "1c9vcrm4gy3ljwnzjimsxswszfs2im1a4iqalpn1mhv8ddwavb2j"; - system = "str"; - asd = "str"; - }); - systems = [ "str" ]; - lispLibs = [ (getAttr "cl-change-case" self) (getAttr "cl-ppcre" self) (getAttr "cl-ppcre-unicode" self) ]; - meta = {}; - }); - str_dot_test = (build-asdf-system { - pname = "str.test"; - version = "20241012-git"; - asds = [ "str.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-str/2024-10-12/cl-str-20241012-git.tgz"; - sha256 = "1c9vcrm4gy3ljwnzjimsxswszfs2im1a4iqalpn1mhv8ddwavb2j"; - system = "str.test"; - asd = "str.test"; - }); - systems = [ "str.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - strict-function = (build-asdf-system { - pname = "strict-function"; - version = "20211020-git"; - asds = [ "strict-function" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/strict-function/2021-10-20/strict-function-20211020-git.tgz"; - sha256 = "176l5024qa72my7wiag0w6mmwys1q4yk6b4n944378qbqr2zpq2a"; - system = "strict-function"; - asd = "strict-function"; - }); - systems = [ "strict-function" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - string-case = (build-asdf-system { - pname = "string-case"; - version = "20180711-git"; - asds = [ "string-case" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/string-case/2018-07-11/string-case-20180711-git.tgz"; - sha256 = "1n5i3yh0h5s636rcnwn7jwqy3rjflikra04lymimhpcshhjsk0md"; - system = "string-case"; - asd = "string-case"; - }); - systems = [ "string-case" ]; - lispLibs = [ ]; - meta = {}; - }); - string-escape = (build-asdf-system { - pname = "string-escape"; - version = "20150407-http"; - asds = [ "string-escape" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/string-escape/2015-04-07/string-escape-20150407-http.tgz"; - sha256 = "0r7b699332hy3qj17jax9jdhq4jx6rbw5xf0j43bwg79wddk0rq3"; - system = "string-escape"; - asd = "string-escape"; - }); - systems = [ "string-escape" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stripe = (build-asdf-system { - pname = "stripe"; - version = "20241012-git"; - asds = [ "stripe" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stripe/2024-10-12/stripe-20241012-git.tgz"; - sha256 = "1ng1381pg0mj1ba0ndxvhaqmm0w64v0gq0qsxbfm9kr6hq46gsf9"; - system = "stripe"; - asd = "stripe"; - }); - systems = [ "stripe" ]; - lispLibs = [ (getAttr "dexador" self) (getAttr "golden-utils" self) (getAttr "local-time" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stripe-against-the-modern-world = (build-asdf-system { - pname = "stripe-against-the-modern-world"; - version = "20221106-git"; - asds = [ "stripe-against-the-modern-world" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stripe-against-the-modern-world/2022-11-06/stripe-against-the-modern-world-20221106-git.tgz"; - sha256 = "1qp714y7b7vfdafirlphk02gixa4jffs0xgcy96fncxs6r2zq3q9"; - system = "stripe-against-the-modern-world"; - asd = "stripe-against-the-modern-world"; - }); - systems = [ "stripe-against-the-modern-world" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "dexador" self) (getAttr "do-urlencode" self) (getAttr "ironclad" self) (getAttr "jonathan" self) (getAttr "local-time" self) (getAttr "ningle" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - structure-ext = (build-asdf-system { - pname = "structure-ext"; - version = "20211209-git"; - asds = [ "structure-ext" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; - sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; - system = "structure-ext"; - asd = "structure-ext"; - }); - systems = [ "structure-ext" ]; - lispLibs = [ (getAttr "structure-ext_dot_as-class" self) (getAttr "structure-ext_dot_left-arrow-accessors" self) (getAttr "structure-ext_dot_make-instance" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - structure-ext_dot_as-class = (build-asdf-system { - pname = "structure-ext.as-class"; - version = "20211209-git"; - asds = [ "structure-ext.as-class" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; - sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; - system = "structure-ext.as-class"; - asd = "structure-ext.as-class"; - }); - systems = [ "structure-ext.as-class" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "jingoh_dot_documentizer" self) (getAttr "lambda-fiddle" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - structure-ext_dot_as-class_dot_test = (build-asdf-system { - pname = "structure-ext.as-class.test"; - version = "20211209-git"; - asds = [ "structure-ext.as-class.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; - sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; - system = "structure-ext.as-class.test"; - asd = "structure-ext.as-class.test"; - }); - systems = [ "structure-ext.as-class.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "structure-ext_dot_as-class" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - structure-ext_dot_left-arrow-accessors = (build-asdf-system { - pname = "structure-ext.left-arrow-accessors"; - version = "20211209-git"; - asds = [ "structure-ext.left-arrow-accessors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; - sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; - system = "structure-ext.left-arrow-accessors"; - asd = "structure-ext.left-arrow-accessors"; - }); - systems = [ "structure-ext.left-arrow-accessors" ]; - lispLibs = [ (getAttr "jingoh_dot_documentizer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - structure-ext_dot_left-arrow-accessors_dot_test = (build-asdf-system { - pname = "structure-ext.left-arrow-accessors.test"; - version = "20211209-git"; - asds = [ "structure-ext.left-arrow-accessors.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; - sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; - system = "structure-ext.left-arrow-accessors.test"; - asd = "structure-ext.left-arrow-accessors.test"; - }); - systems = [ "structure-ext.left-arrow-accessors.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "structure-ext_dot_left-arrow-accessors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - structure-ext_dot_make-instance = (build-asdf-system { - pname = "structure-ext.make-instance"; - version = "20211209-git"; - asds = [ "structure-ext.make-instance" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; - sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; - system = "structure-ext.make-instance"; - asd = "structure-ext.make-instance"; - }); - systems = [ "structure-ext.make-instance" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "jingoh_dot_documentizer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - structure-ext_dot_make-instance_dot_test = (build-asdf-system { - pname = "structure-ext.make-instance.test"; - version = "20211209-git"; - asds = [ "structure-ext.make-instance.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; - sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; - system = "structure-ext.make-instance.test"; - asd = "structure-ext.make-instance.test"; - }); - systems = [ "structure-ext.make-instance.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "structure-ext_dot_make-instance" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - structy-defclass = (build-asdf-system { - pname = "structy-defclass"; - version = "20170630-git"; - asds = [ "structy-defclass" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/structy-defclass/2017-06-30/structy-defclass-20170630-git.tgz"; - sha256 = "0fdlj45xzyghmg65dvs7ww7dxji84iid2y6rh9j77aip7v0l5q63"; - system = "structy-defclass"; - asd = "structy-defclass"; - }); - systems = [ "structy-defclass" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - studio-client = (build-asdf-system { - pname = "studio-client"; - version = "20231021-git"; - asds = [ "studio-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/studio-client/2023-10-21/studio-client-20231021-git.tgz"; - sha256 = "0wxakd5jd0y6h2ii4690qav7zna6iyamdyksw5zjyz4xmsg4by2l"; - system = "studio-client"; - asd = "studio-client"; - }); - systems = [ "studio-client" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "com_dot_inuoe_dot_jzon" self) (getAttr "documentation-utils" self) (getAttr "north-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - stumpwm = (build-asdf-system { - pname = "stumpwm"; - version = "20231021-git"; - asds = [ "stumpwm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stumpwm/2023-10-21/stumpwm-20231021-git.tgz"; - sha256 = "114kicsziqvm15x15yhc39j8qzv6gxz4wxc40xp968pprzr4a4d1"; - system = "stumpwm"; - asd = "stumpwm"; - }); - systems = [ "stumpwm" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "clx" self) (getAttr "dynamic-mixins-swm" self) ]; - meta = {}; - }); - stumpwm-tests = (build-asdf-system { - pname = "stumpwm-tests"; - version = "20231021-git"; - asds = [ "stumpwm-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/stumpwm/2023-10-21/stumpwm-20231021-git.tgz"; - sha256 = "114kicsziqvm15x15yhc39j8qzv6gxz4wxc40xp968pprzr4a4d1"; - system = "stumpwm-tests"; - asd = "stumpwm-tests"; - }); - systems = [ "stumpwm-tests" ]; - lispLibs = [ (getAttr "fiasco" self) (getAttr "stumpwm" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sucle = (build-asdf-system { - pname = "sucle"; - version = "20200427-git"; - asds = [ "sucle" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "sucle"; - asd = "sucle"; - }); - systems = [ "sucle" ]; - lispLibs = [ (getAttr "aabbcc" self) (getAttr "alexandria" self) (getAttr "application" self) (getAttr "black-tie" self) (getAttr "camera-matrix" self) (getAttr "cl-opengl" self) (getAttr "control" self) (getAttr "crud" self) (getAttr "fps-independent-timestep" self) (getAttr "glhelp" self) (getAttr "image-utility" self) (getAttr "livesupport" self) (getAttr "ncurses-clone-for-lem" self) (getAttr "nsb-cga" self) (getAttr "quads" self) (getAttr "scratch-buffer" self) (getAttr "sucle-multiprocessing" self) (getAttr "sucle-temp" self) (getAttr "text-subsystem" self) (getAttr "uncommon-lisp" self) (getAttr "utility" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sucle-multiprocessing = (build-asdf-system { - pname = "sucle-multiprocessing"; - version = "20200427-git"; - asds = [ "sucle-multiprocessing" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "sucle-multiprocessing"; - asd = "sucle-multiprocessing"; - }); - systems = [ "sucle-multiprocessing" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-cpus" self) (getAttr "lparallel" self) (getAttr "uncommon-lisp" self) (getAttr "utility" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sucle-serialize = (build-asdf-system { - pname = "sucle-serialize"; - version = "20200427-git"; - asds = [ "sucle-serialize" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "sucle-serialize"; - asd = "sucle-serialize"; - }); - systems = [ "sucle-serialize" ]; - lispLibs = [ (getAttr "chipz" self) (getAttr "cl-conspack" self) (getAttr "salza2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sucle-temp = (build-asdf-system { - pname = "sucle-temp"; - version = "20200427-git"; - asds = [ "sucle-temp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "sucle-temp"; - asd = "sucle-temp"; - }); - systems = [ "sucle-temp" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sucle-test = (build-asdf-system { - pname = "sucle-test"; - version = "20200427-git"; - asds = [ "sucle-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "sucle-test"; - asd = "sucle-test"; - }); - systems = [ "sucle-test" ]; - lispLibs = [ (getAttr "aabbcc" self) (getAttr "alexandria" self) (getAttr "application" self) (getAttr "camera-matrix" self) (getAttr "character-modifier-bits" self) (getAttr "cl-opengl" self) (getAttr "control" self) (getAttr "deflazy" self) (getAttr "fps-independent-timestep" self) (getAttr "image-utility" self) (getAttr "ncurses-clone-for-lem" self) (getAttr "nsb-cga" self) (getAttr "quads" self) (getAttr "scratch-buffer" self) (getAttr "sucle" self) (getAttr "sucle-multiprocessing" self) (getAttr "sucle-serialize" self) (getAttr "text-subsystem" self) (getAttr "uncommon-lisp" self) (getAttr "window" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - surf = (build-asdf-system { - pname = "surf"; - version = "master-fe503896-git"; - asds = [ "surf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "surf"; - asd = "surf"; - }); - systems = [ "surf" ]; - lispLibs = [ (getAttr "geom-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - swank = (build-asdf-system { - pname = "swank"; - version = "v2.30"; - asds = [ "swank" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/slime/2024-10-12/slime-v2.30.tgz"; - sha256 = "0qb7m65gq0mbxfrdppkh3k4jn13i14i07ziga4r8b3rmrxhrmlv0"; - system = "swank"; - asd = "swank"; - }); - systems = [ "swank" ]; - lispLibs = [ ]; - meta = {}; - }); - swank-client = (build-asdf-system { - pname = "swank-client"; - version = "20230618-git"; - asds = [ "swank-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/swank-client/2023-06-18/swank-client-20230618-git.tgz"; - sha256 = "0sd0xblaxj8zi03acmfq4pwv84jcl04fvyp1jqlb7d6iq0mbxvan"; - system = "swank-client"; - asd = "swank-client"; - }); - systems = [ "swank-client" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "com_dot_google_dot_base" self) (getAttr "swank" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - swank-crew = (build-asdf-system { - pname = "swank-crew"; - version = "20241012-git"; - asds = [ "swank-crew" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/swank-crew/2024-10-12/swank-crew-20241012-git.tgz"; - sha256 = "0v0gg9d74x28xw3n12nrvkdnnvz0m972l4rymfansfaawiqm7ssz"; - system = "swank-crew"; - asd = "swank-crew"; - }); - systems = [ "swank-crew" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "com_dot_google_dot_base" self) (getAttr "swank-client" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - swank-protocol = (build-asdf-system { - pname = "swank-protocol"; - version = "20241012-git"; - asds = [ "swank-protocol" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/swank-protocol/2024-10-12/swank-protocol-20241012-git.tgz"; - sha256 = "0vqcdxp228fk3snay90ml33r1y03l5k05snq633f95his8ffxknl"; - system = "swank-protocol"; - asd = "swank-protocol"; - }); - systems = [ "swank-protocol" ]; - lispLibs = [ (getAttr "swank" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - swank_dot_live = (build-asdf-system { - pname = "swank.live"; - version = "20160208-git"; - asds = [ "swank.live" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/swank.live/2016-02-08/swank.live-20160208-git.tgz"; - sha256 = "0p7jyf07symfan6lmbhd3r42kf5vrsbmmh9li0n1kky8rd6fhgls"; - system = "swank.live"; - asd = "swank.live"; - }); - systems = [ "swank.live" ]; - lispLibs = [ (getAttr "swank" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - swap-bytes = (build-asdf-system { - pname = "swap-bytes"; - version = "v1.2"; - asds = [ "swap-bytes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/swap-bytes/2019-11-30/swap-bytes-v1.2.tgz"; - sha256 = "1hw1v1lw26rifyznpnj1csphha9jgzwpiic16ni3pvs6hcsni9rz"; - system = "swap-bytes"; - asd = "swap-bytes"; - }); - systems = [ "swap-bytes" ]; - lispLibs = [ (getAttr "trivial-features" self) ]; - meta = {}; - }); - sxql = (build-asdf-system { - pname = "sxql"; - version = "20241012-git"; - asds = [ "sxql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sxql/2024-10-12/sxql-20241012-git.tgz"; - sha256 = "11x4qgdwbddbk0a8avrirp1ksmphfxlimirfwvmiwi0jc4zd5csa"; - system = "sxql"; - asd = "sxql"; - }); - systems = [ "sxql" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-annot" self) (getAttr "cl-package-locks" self) (getAttr "iterate" self) (getAttr "named-readtables" self) (getAttr "split-sequence" self) (getAttr "trivia" self) (getAttr "trivial-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sxql-composer = (build-asdf-system { - pname = "sxql-composer"; - version = "20200325-git"; - asds = [ "sxql-composer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sxql-composer/2020-03-25/sxql-composer-20200325-git.tgz"; - sha256 = "1agkrj3ymskzc3c7pxbrj123d1kygjqcls145m0ap3i07q96hh1r"; - system = "sxql-composer"; - asd = "sxql-composer"; - }); - systems = [ "sxql-composer" ]; - lispLibs = [ (getAttr "sxql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sxql-test = (build-asdf-system { - pname = "sxql-test"; - version = "20241012-git"; - asds = [ "sxql-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sxql/2024-10-12/sxql-20241012-git.tgz"; - sha256 = "11x4qgdwbddbk0a8avrirp1ksmphfxlimirfwvmiwi0jc4zd5csa"; - system = "sxql-test"; - asd = "sxql-test"; - }); - systems = [ "sxql-test" ]; - lispLibs = [ (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "sxql" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sycamore = (build-asdf-system { - pname = "sycamore"; - version = "20211020-git"; - asds = [ "sycamore" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sycamore/2021-10-20/sycamore-20211020-git.tgz"; - sha256 = "0icw7fba1ch51w24f4sinvy4xg3zc7zif0aqcjfrzxj14x108hai"; - system = "sycamore"; - asd = "sycamore"; - }); - systems = [ "sycamore" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-fuzz" self) (getAttr "cl-ppcre" self) (getAttr "lisp-unit" self) ]; - meta = {}; - }); - symath = (build-asdf-system { - pname = "symath"; - version = "20241012-git"; - asds = [ "symath" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/symath/2024-10-12/symath-20241012-git.tgz"; - sha256 = "1bxggf9kn4bhx877hyj4kpr76p47d8cd35lgv224hri5211fqyaz"; - system = "symath"; - asd = "symath"; - }); - systems = [ "symath" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - symbol-munger = (build-asdf-system { - pname = "symbol-munger"; - version = "20220220-git"; - asds = [ "symbol-munger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/symbol-munger/2022-02-20/symbol-munger-20220220-git.tgz"; - sha256 = "16fshnxp9212503z1vjlmx5pafv14bzpihn486x1ljakqjigfnfz"; - system = "symbol-munger"; - asd = "symbol-munger"; - }); - systems = [ "symbol-munger" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) ]; - meta = {}; - }); - symbol-namespaces = (build-asdf-system { - pname = "symbol-namespaces"; - version = "1.0"; - asds = [ "symbol-namespaces" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/symbol-namespaces/2013-01-28/symbol-namespaces-1.0.tgz"; - sha256 = "0rw4ndhg669rkpjmv5n0zh69bzar60zn3bb4vs5ijgvxyl5f7xp1"; - system = "symbol-namespaces"; - asd = "symbol-namespaces"; - }); - systems = [ "symbol-namespaces" ]; - lispLibs = [ (getAttr "map-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - synonyms = (build-asdf-system { - pname = "synonyms"; - version = "20230618-git"; - asds = [ "synonyms" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/synonyms/2023-06-18/synonyms-20230618-git.tgz"; - sha256 = "1373m0h765r60lif0jz3frqbq7phrm2jhc30b5dh51spd7732v3x"; - system = "synonyms"; - asd = "synonyms"; - }); - systems = [ "synonyms" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - sysexits = (build-asdf-system { - pname = "sysexits"; - version = "20220707-git"; - asds = [ "sysexits" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-sysexits/2022-07-07/cl-sysexits-20220707-git.tgz"; - sha256 = "1khkj0qqvmgylnvl32sks8v3iabasbcr9sj9zl89xh3rajc67z73"; - system = "sysexits"; - asd = "sysexits"; - }); - systems = [ "sysexits" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - system-locale = (build-asdf-system { - pname = "system-locale"; - version = "20241012-git"; - asds = [ "system-locale" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/system-locale/2024-10-12/system-locale-20241012-git.tgz"; - sha256 = "1q91vyvsh787fz3j49lmyw2lx85288cmamb11h99wdmbmf61rdgr"; - system = "system-locale"; - asd = "system-locale"; - }); - systems = [ "system-locale" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - t-clack-handler-hunchentoot = (build-asdf-system { - pname = "t-clack-handler-hunchentoot"; - version = "20241012-git"; - asds = [ "t-clack-handler-hunchentoot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; - sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; - system = "t-clack-handler-hunchentoot"; - asd = "t-clack-handler-hunchentoot"; - }); - systems = [ "t-clack-handler-hunchentoot" ]; - lispLibs = [ (getAttr "clack-handler-hunchentoot" self) (getAttr "clack-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - t-clack-handler-toot = (build-asdf-system { - pname = "t-clack-handler-toot"; - version = "20241012-git"; - asds = [ "t-clack-handler-toot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; - sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; - system = "t-clack-handler-toot"; - asd = "t-clack-handler-toot"; - }); - systems = [ "t-clack-handler-toot" ]; - lispLibs = [ (getAttr "clack-handler-toot" self) (getAttr "clack-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - t-clack-handler-wookie = (build-asdf-system { - pname = "t-clack-handler-wookie"; - version = "20241012-git"; - asds = [ "t-clack-handler-wookie" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; - sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; - system = "t-clack-handler-wookie"; - asd = "t-clack-handler-wookie"; - }); - systems = [ "t-clack-handler-wookie" ]; - lispLibs = [ (getAttr "clack-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ta2 = (build-asdf-system { - pname = "ta2"; - version = "master-fe503896-git"; - asds = [ "ta2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "ta2"; - asd = "ta2"; - }); - systems = [ "ta2" ]; - lispLibs = [ (getAttr "gwl-graphics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tagger = (build-asdf-system { - pname = "tagger"; - version = "20200715-git"; - asds = [ "tagger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tagger/2020-07-15/tagger-20200715-git.tgz"; - sha256 = "1mxkr5hx8p4rxc7vajgrpl49zh018wyspvww5fg50164if0n7j2q"; - system = "tagger"; - asd = "tagger"; - }); - systems = [ "tagger" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - taglib = (build-asdf-system { - pname = "taglib"; - version = "20241012-git"; - asds = [ "taglib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/taglib/2024-10-12/taglib-20241012-git.tgz"; - sha256 = "1jhi38g2ngmbsv71chxyavgf4fzb64nr7z648ia01qxii0435csb"; - system = "taglib"; - asd = "taglib"; - }); - systems = [ "taglib" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "flexi-streams" self) (getAttr "optima" self) (getAttr "optima_dot_ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - taglib-tests = (build-asdf-system { - pname = "taglib-tests"; - version = "20241012-git"; - asds = [ "taglib-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/taglib/2024-10-12/taglib-20241012-git.tgz"; - sha256 = "1jhi38g2ngmbsv71chxyavgf4fzb64nr7z648ia01qxii0435csb"; - system = "taglib-tests"; - asd = "taglib-tests"; - }); - systems = [ "taglib-tests" ]; - lispLibs = [ (getAttr "chanl" self) (getAttr "cl-fad" self) (getAttr "taglib" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tailrec = (build-asdf-system { - pname = "tailrec"; - version = "20210807-git"; - asds = [ "tailrec" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tailrec/2021-08-07/tailrec-20210807-git.tgz"; - sha256 = "1h8m2npdzd2cpnl75pvv4yvvfwxa7kl6qvalc9s0y4yws0kaih3i"; - system = "tailrec"; - asd = "tailrec"; - }); - systems = [ "tailrec" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-macroexpand-all" self) (getAttr "trivial-with-current-source-form" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - talcl = (build-asdf-system { - pname = "talcl"; - version = "20180228-git"; - asds = [ "talcl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/talcl/2018-02-28/talcl-20180228-git.tgz"; - sha256 = "18pm3vz82dwcckhp4lkwjv8431hkdj3ghxb4v5qdjsyw2jm56v1p"; - system = "talcl"; - asd = "talcl"; - }); - systems = [ "talcl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "buildnode" self) (getAttr "cl-ppcre" self) (getAttr "cxml" self) (getAttr "iterate" self) (getAttr "symbol-munger" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - talcl-examples = (build-asdf-system { - pname = "talcl-examples"; - version = "20180228-git"; - asds = [ "talcl-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/talcl/2018-02-28/talcl-20180228-git.tgz"; - sha256 = "18pm3vz82dwcckhp4lkwjv8431hkdj3ghxb4v5qdjsyw2jm56v1p"; - system = "talcl-examples"; - asd = "talcl"; - }); - systems = [ "talcl-examples" ]; - lispLibs = [ (getAttr "buildnode-xhtml" self) (getAttr "talcl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - talcl-speed-tests = (build-asdf-system { - pname = "talcl-speed-tests"; - version = "20180228-git"; - asds = [ "talcl-speed-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/talcl/2018-02-28/talcl-20180228-git.tgz"; - sha256 = "18pm3vz82dwcckhp4lkwjv8431hkdj3ghxb4v5qdjsyw2jm56v1p"; - system = "talcl-speed-tests"; - asd = "talcl"; - }); - systems = [ "talcl-speed-tests" ]; - lispLibs = [ (getAttr "buildnode-xhtml" self) (getAttr "lisp-unit2" self) (getAttr "talcl" self) (getAttr "talcl-examples" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - talcl-test = (build-asdf-system { - pname = "talcl-test"; - version = "20180228-git"; - asds = [ "talcl-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/talcl/2018-02-28/talcl-20180228-git.tgz"; - sha256 = "18pm3vz82dwcckhp4lkwjv8431hkdj3ghxb4v5qdjsyw2jm56v1p"; - system = "talcl-test"; - asd = "talcl"; - }); - systems = [ "talcl-test" ]; - lispLibs = [ (getAttr "buildnode-xhtml" self) (getAttr "lisp-unit2" self) (getAttr "talcl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tap-unit-test = (build-asdf-system { - pname = "tap-unit-test"; - version = "20171227-git"; - asds = [ "tap-unit-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tap-unit-test/2017-12-27/tap-unit-test-20171227-git.tgz"; - sha256 = "1fzsnpng7y4sghasl29sjicbs4v6m5mgfj8wf2izhhcn1hbhr694"; - system = "tap-unit-test"; - asd = "tap-unit-test"; - }); - systems = [ "tap-unit-test" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tar = (build-asdf-system { - pname = "tar"; - version = "20230618-git"; - asds = [ "tar" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tar/2023-06-18/cl-tar-20230618-git.tgz"; - sha256 = "0wp23cs3i6a89dibifiz6559la5nk58d1n17xvbxq4nrl8cqsllf"; - system = "tar"; - asd = "tar"; - }); - systems = [ "tar" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "local-time" self) (getAttr "split-sequence" self) (getAttr "tar-file" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tar-file = (build-asdf-system { - pname = "tar-file"; - version = "20220220-git"; - asds = [ "tar-file" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tar-file/2022-02-20/cl-tar-file-20220220-git.tgz"; - sha256 = "0i8j05fkgdqy4c4pqj0c68sh4s3klpx9kc5wp73qwzrl3xqd2svy"; - system = "tar-file"; - asd = "tar-file"; - }); - systems = [ "tar-file" ]; - lispLibs = [ (getAttr "_40ants-doc" self) (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "chipz" self) (getAttr "flexi-streams" self) (getAttr "salza2" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - targa = (build-asdf-system { - pname = "targa"; - version = "20181018-git"; - asds = [ "targa" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/targa/2018-10-18/targa-20181018-git.tgz"; - sha256 = "0fslb2alp4pfmp8md2q89xh8n43r8awwf343wfvkywwqdnls2zws"; - system = "targa"; - asd = "targa"; - }); - systems = [ "targa" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tasty = (build-asdf-system { - pname = "tasty"; - version = "master-fe503896-git"; - asds = [ "tasty" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "tasty"; - asd = "tasty"; - }); - systems = [ "tasty" ]; - lispLibs = [ (getAttr "gwl-graphics" self) (getAttr "tree" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tclcs-code = (build-asdf-system { - pname = "tclcs-code"; - version = "20210124-git"; - asds = [ "tclcs-code" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tclcs-code/2021-01-24/tclcs-code-20210124-git.tgz"; - sha256 = "0p0g8shy284sj9ncq27zn8yj7xsrdcg2aiy2q783l6sl2ip6nfxa"; - system = "tclcs-code"; - asd = "tclcs-code"; - }); - systems = [ "tclcs-code" ]; - lispLibs = [ (getAttr "trivial-custom-debugger" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tcod = (build-asdf-system { - pname = "tcod"; - version = "20231021-git"; - asds = [ "tcod" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-tcod/2023-10-21/cl-tcod-20231021-git.tgz"; - sha256 = "1r4ip16dlzr56p94b0grw6nmkykbmgb04jsqdvgl1ypcmbpfr3i1"; - system = "tcod"; - asd = "tcod"; - }); - systems = [ "tcod" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-libffi" self) (getAttr "defstar" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - teddy = (build-asdf-system { - pname = "teddy"; - version = "20241012-git"; - asds = [ "teddy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/teddy/2024-10-12/teddy-20241012-git.tgz"; - sha256 = "0qg83khyny5pw9lk3ysid32wl1wds43ja35qx72mxpli3nhj7nhq"; - system = "teddy"; - asd = "teddy"; - }); - systems = [ "teddy" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "asdf-finalizers" self) (getAttr "cl-ascii-table" self) (getAttr "eazy-gnuplot" self) (getAttr "hu_dot_dwim_dot_def" self) (getAttr "lhstats" self) (getAttr "list-of" self) (getAttr "rutils" self) (getAttr "simplified-types" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - teepeedee2 = (build-asdf-system { - pname = "teepeedee2"; - version = "20230214-git"; - asds = [ "teepeedee2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/teepeedee2/2023-02-14/teepeedee2-20230214-git.tgz"; - sha256 = "16mfc1hcjdjcj1iiihdn9a725xry8hpvxijf5ic6yi4ydcv84pni"; - system = "teepeedee2"; - asd = "teepeedee2"; - }); - systems = [ "teepeedee2" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-cont" self) (getAttr "cl-fad" self) (getAttr "cl-irregsexp" self) (getAttr "iterate" self) (getAttr "parenscript" self) (getAttr "trivial-backtrace" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - teepeedee2-test = (build-asdf-system { - pname = "teepeedee2-test"; - version = "20230214-git"; - asds = [ "teepeedee2-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/teepeedee2/2023-02-14/teepeedee2-20230214-git.tgz"; - sha256 = "16mfc1hcjdjcj1iiihdn9a725xry8hpvxijf5ic6yi4ydcv84pni"; - system = "teepeedee2-test"; - asd = "teepeedee2-test"; - }); - systems = [ "teepeedee2-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "teepeedee2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - telnetlib = (build-asdf-system { - pname = "telnetlib"; - version = "20141217-git"; - asds = [ "telnetlib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/telnetlib/2014-12-17/telnetlib-20141217-git.tgz"; - sha256 = "1gdf6i352qkmp27nqbv6qfi7sqn5wjzdaffh6ls1y5jznqh3nb0h"; - system = "telnetlib"; - asd = "telnetlib"; - }); - systems = [ "telnetlib" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - template = (build-asdf-system { - pname = "template"; - version = "20230618-git"; - asds = [ "template" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/template/2023-06-18/template-20230618-git.tgz"; - sha256 = "1ccnjawxwjqk8gavqga7waqrxv0pmncbycyfwylyly7a1c7zjadr"; - system = "template"; - asd = "template"; - }); - systems = [ "template" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "parameterized-function" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - template-function = (build-asdf-system { - pname = "template-function"; - version = "v0.0.1-git"; - asds = [ "template-function" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/template-function/2017-11-30/template-function-v0.0.1-git.tgz"; - sha256 = "1nq782cdi9vr3hgqqyzvvng2sbyc09biggwq4zp7k1vmqnm6qdaf"; - system = "template-function"; - asd = "template-function"; - }); - systems = [ "template-function" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "introspect-environment" self) (getAttr "specialization-store" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - template-function-tests = (build-asdf-system { - pname = "template-function-tests"; - version = "v0.0.1-git"; - asds = [ "template-function-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/template-function/2017-11-30/template-function-v0.0.1-git.tgz"; - sha256 = "1nq782cdi9vr3hgqqyzvvng2sbyc09biggwq4zp7k1vmqnm6qdaf"; - system = "template-function-tests"; - asd = "template-function-tests"; - }); - systems = [ "template-function-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "template-function" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - temporal-functions = (build-asdf-system { - pname = "temporal-functions"; - version = "20171019-git"; - asds = [ "temporal-functions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/temporal-functions/2017-10-19/temporal-functions-20171019-git.tgz"; - sha256 = "03cbgw949g68n72nqp0nmjq9nx0kfz5zs6kpk0pwchy3i8bwf22j"; - system = "temporal-functions"; - asd = "temporal-functions"; - }); - systems = [ "temporal-functions" ]; - lispLibs = [ (getAttr "fn" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - temporary-file = (build-asdf-system { - pname = "temporary-file"; - version = "20150608-git"; - asds = [ "temporary-file" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/temporary-file/2015-06-08/temporary-file-20150608-git.tgz"; - sha256 = "0m38lncj6bmj7gwq8vp7l0gwzmk7pfasl4samzgl2fah8hzb064a"; - system = "temporary-file"; - asd = "temporary-file"; - }); - systems = [ "temporary-file" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "unit-test" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ten = (build-asdf-system { - pname = "ten"; - version = "20241012-git"; - asds = [ "ten" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ten/2024-10-12/ten-20241012-git.tgz"; - sha256 = "0zrbgyvc21gq8r507jm664zd4r9q206g2ah1yybwi32lgzify6nk"; - system = "ten"; - asd = "ten"; - }); - systems = [ "ten" ]; - lispLibs = [ (getAttr "access" self) (getAttr "cl-who" self) (getAttr "esrap" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ten_dot_examples = (build-asdf-system { - pname = "ten.examples"; - version = "20241012-git"; - asds = [ "ten.examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ten/2024-10-12/ten-20241012-git.tgz"; - sha256 = "0zrbgyvc21gq8r507jm664zd4r9q206g2ah1yybwi32lgzify6nk"; - system = "ten.examples"; - asd = "ten.examples"; - }); - systems = [ "ten.examples" ]; - lispLibs = [ (getAttr "ten" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ten_dot_i18n_dot_cl-locale = (build-asdf-system { - pname = "ten.i18n.cl-locale"; - version = "20241012-git"; - asds = [ "ten.i18n.cl-locale" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ten/2024-10-12/ten-20241012-git.tgz"; - sha256 = "0zrbgyvc21gq8r507jm664zd4r9q206g2ah1yybwi32lgzify6nk"; - system = "ten.i18n.cl-locale"; - asd = "ten.i18n.cl-locale"; - }); - systems = [ "ten.i18n.cl-locale" ]; - lispLibs = [ (getAttr "cl-locale" self) (getAttr "ten" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ten_dot_i18n_dot_gettext = (build-asdf-system { - pname = "ten.i18n.gettext"; - version = "20241012-git"; - asds = [ "ten.i18n.gettext" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ten/2024-10-12/ten-20241012-git.tgz"; - sha256 = "0zrbgyvc21gq8r507jm664zd4r9q206g2ah1yybwi32lgzify6nk"; - system = "ten.i18n.gettext"; - asd = "ten.i18n.gettext"; - }); - systems = [ "ten.i18n.gettext" ]; - lispLibs = [ (getAttr "gettext" self) (getAttr "ten" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ten_dot_tests = (build-asdf-system { - pname = "ten.tests"; - version = "20241012-git"; - asds = [ "ten.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ten/2024-10-12/ten-20241012-git.tgz"; - sha256 = "0zrbgyvc21gq8r507jm664zd4r9q206g2ah1yybwi32lgzify6nk"; - system = "ten.tests"; - asd = "ten.tests"; - }); - systems = [ "ten.tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "ten" self) (getAttr "ten_dot_examples" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - terminfo = (build-asdf-system { - pname = "terminfo"; - version = "20210124-git"; - asds = [ "terminfo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/terminfo/2021-01-24/terminfo-20210124-git.tgz"; - sha256 = "1nmin9rr6f75xdhxysba66xa1dh62fh27w9ad1cvmj0062armf6b"; - system = "terminfo"; - asd = "terminfo"; - }); - systems = [ "terminfo" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - terrable = (build-asdf-system { - pname = "terrable"; - version = "20231021-git"; - asds = [ "terrable" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/terrable/2023-10-21/terrable-20231021-git.tgz"; - sha256 = "03fjfdffr5lf12llqbf3d07dd87ykfyw525dxnwm6gpyvg49wlgl"; - system = "terrable"; - asd = "terrable"; - }); - systems = [ "terrable" ]; - lispLibs = [ (getAttr "documentation-utils" self) (getAttr "fast-io" self) (getAttr "ieee-floats" self) (getAttr "static-vectors" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tesseract-capi = (build-asdf-system { - pname = "tesseract-capi"; - version = "20201220-git"; - asds = [ "tesseract-capi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tesseract-capi/2020-12-20/tesseract-capi-20201220-git.tgz"; - sha256 = "1g8afgzbvfk80gi05nbwp9cmmrsqm5knhqi04v1cx556vrbp6ks1"; - system = "tesseract-capi"; - asd = "tesseract-capi"; - }); - systems = [ "tesseract-capi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - test-40ants-system = (build-asdf-system { - pname = "test-40ants-system"; - version = "20241012-git"; - asds = [ "test-40ants-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/40ants-asdf-system/2024-10-12/40ants-asdf-system-20241012-git.tgz"; - sha256 = "0wi575m0s0a9fvp1wy5ga760f71la16z1633qk6s2f87rwcjs8kw"; - system = "test-40ants-system"; - asd = "test-40ants-system"; - }); - systems = [ "test-40ants-system" ]; - lispLibs = [ (getAttr "_40ants-asdf-system" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - test-gadgets = (build-asdf-system { - pname = "test-gadgets"; - version = "20241012-git"; - asds = [ "test-gadgets" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gadgets/2024-10-12/gadgets-20241012-git.tgz"; - sha256 = "1ba4gj8lh3ihbb66xiz7hc8cdg3gvi3q20w32nmsqdch956is34k"; - system = "test-gadgets"; - asd = "test-gadgets"; - }); - systems = [ "test-gadgets" ]; - lispLibs = [ (getAttr "gadgets" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - test-paren6 = (build-asdf-system { - pname = "test-paren6"; - version = "20220331-git"; - asds = [ "test-paren6" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/paren6/2022-03-31/paren6-20220331-git.tgz"; - sha256 = "0m7z7zkc1vrwmp68f3yx0mdsb0j45dmw3iddnbvf94dpv8aywwpx"; - system = "test-paren6"; - asd = "test-paren6"; - }); - systems = [ "test-paren6" ]; - lispLibs = [ (getAttr "external-program" self) (getAttr "paren6" self) (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - test-serial-system = (build-asdf-system { - pname = "test-serial-system"; - version = "20170403-git"; - asds = [ "test-serial-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/asdf-dependency-grovel/2017-04-03/asdf-dependency-grovel-20170403-git.tgz"; - sha256 = "1y4kdqsda4ira4r9dws6kxzzv6mg45q3lkmb2c9mg9q7ksc5glif"; - system = "test-serial-system"; - asd = "test-serial-system"; - }); - systems = [ "test-serial-system" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - test-utils = (build-asdf-system { - pname = "test-utils"; - version = "20200610-git"; - asds = [ "test-utils" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/test-utils/2020-06-10/test-utils-20200610-git.tgz"; - sha256 = "036a8wvs37lnsf9dy3c810qk54963v7hnxx0zas25b50ikcmiqm5"; - system = "test-utils"; - asd = "test-utils"; - }); - systems = [ "test-utils" ]; - lispLibs = [ (getAttr "agnostic-lizard" self) (getAttr "alexandria" self) (getAttr "cl-quickcheck" self) (getAttr "prove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - test_dot_eager-future2 = (build-asdf-system { - pname = "test.eager-future2"; - version = "20191130-git"; - asds = [ "test.eager-future2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/eager-future2/2019-11-30/eager-future2-20191130-git.tgz"; - sha256 = "1qs1bv3m0ki8l5czhsflxcryh22r9d9g9a3a3b0cr0pl954q5rld"; - system = "test.eager-future2"; - asd = "test.eager-future2"; - }); - systems = [ "test.eager-future2" ]; - lispLibs = [ (getAttr "eager-future2" self) (getAttr "eos" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - test_dot_vas-string-metrics = (build-asdf-system { - pname = "test.vas-string-metrics"; - version = "20211209-git"; - asds = [ "test.vas-string-metrics" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vas-string-metrics/2021-12-09/vas-string-metrics-20211209-git.tgz"; - sha256 = "1yvkwc939dckv070nlgqfj5ys9ii2rm32m5wfx7qxdjrb4n19sx9"; - system = "test.vas-string-metrics"; - asd = "test.vas-string-metrics"; - }); - systems = [ "test.vas-string-metrics" ]; - lispLibs = [ (getAttr "vas-string-metrics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - testbild = (build-asdf-system { - pname = "testbild"; - version = "20101207-git"; - asds = [ "testbild" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/testbild/2010-12-07/testbild-20101207-git.tgz"; - sha256 = "024b6rlgljcjazwg302zkdmkpxs2hirjg7g39ypppz81ns2v65sw"; - system = "testbild"; - asd = "testbild"; - }); - systems = [ "testbild" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "graylex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - testbild-test = (build-asdf-system { - pname = "testbild-test"; - version = "20101207-git"; - asds = [ "testbild-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/testbild/2010-12-07/testbild-20101207-git.tgz"; - sha256 = "024b6rlgljcjazwg302zkdmkpxs2hirjg7g39ypppz81ns2v65sw"; - system = "testbild-test"; - asd = "testbild-test"; - }); - systems = [ "testbild-test" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-heredoc" self) (getAttr "testbild" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - testiere = (build-asdf-system { - pname = "testiere"; - version = "20241012-git"; - asds = [ "testiere" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/testiere/2024-10-12/testiere-20241012-git.tgz"; - sha256 = "0sfsk7i5kxk8s1273i9vwz49hak0qdrr9asq70kdiwq0lfd56kgg"; - system = "testiere"; - asd = "testiere"; - }); - systems = [ "testiere" ]; - lispLibs = [ (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - texp = (build-asdf-system { - pname = "texp"; - version = "20151218-git"; - asds = [ "texp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/texp/2015-12-18/texp-20151218-git.tgz"; - sha256 = "1sbll7jwmzd86hg0zva8r7db2565nnliasv2x6rkrm9xl97q0kg5"; - system = "texp"; - asd = "texp"; - }); - systems = [ "texp" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - text-query = (build-asdf-system { - pname = "text-query"; - version = "1.1"; - asds = [ "text-query" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/text-query/2011-11-05/text-query-1.1.tgz"; - sha256 = "082xqpfchmg2752m1lw78q6c0z3walzsmqk8gl6qnj6bdwbhf4dm"; - system = "text-query"; - asd = "text-query"; - }); - systems = [ "text-query" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - text-subsystem = (build-asdf-system { - pname = "text-subsystem"; - version = "20200427-git"; - asds = [ "text-subsystem" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "text-subsystem"; - asd = "text-subsystem"; - }); - systems = [ "text-subsystem" ]; - lispLibs = [ (getAttr "application" self) (getAttr "deflazy" self) (getAttr "image-utility" self) (getAttr "nsb-cga" self) (getAttr "quads" self) (getAttr "sucle-temp" self) (getAttr "utility" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - text-subsystem-generate-font = (build-asdf-system { - pname = "text-subsystem-generate-font"; - version = "20200427-git"; - asds = [ "text-subsystem-generate-font" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "text-subsystem-generate-font"; - asd = "text-subsystem-generate-font"; - }); - systems = [ "text-subsystem-generate-font" ]; - lispLibs = [ (getAttr "cl-freetype2" self) (getAttr "opticl" self) (getAttr "utility" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - textery = (build-asdf-system { - pname = "textery"; - version = "20201220-git"; - asds = [ "textery" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/textery/2020-12-20/textery-20201220-git.tgz"; - sha256 = "0v8zk1s18fi462qwvjbci8nikgs5wqjpl97ckfk0spvhybrdgwcc"; - system = "textery"; - asd = "textery"; - }); - systems = [ "textery" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "str" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - the-cost-of-nothing = (build-asdf-system { - pname = "the-cost-of-nothing"; - version = "20191130-git"; - asds = [ "the-cost-of-nothing" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/the-cost-of-nothing/2019-11-30/the-cost-of-nothing-20191130-git.tgz"; - sha256 = "1ccrglyr1wnnfp218w1qj7yfl4yzlxkki3hqaifi5axgbi5dmmh8"; - system = "the-cost-of-nothing"; - asd = "the-cost-of-nothing"; - }); - systems = [ "the-cost-of-nothing" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "local-time" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - thih-coalton = (build-asdf-system { - pname = "thih-coalton"; - version = "20241012-git"; - asds = [ "thih-coalton" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; - sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; - system = "thih-coalton"; - asd = "thih-coalton"; - }); - systems = [ "thih-coalton" ]; - lispLibs = [ (getAttr "coalton" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - thnappy = (build-asdf-system { - pname = "thnappy"; - version = "20180831-git"; - asds = [ "thnappy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/thnappy/2018-08-31/thnappy-20180831-git.tgz"; - sha256 = "0p03w2mcc655gm9x3rpgixhap9l56imjyblkwv05rk6mjx7wfnrp"; - system = "thnappy"; - asd = "thnappy"; - }); - systems = [ "thnappy" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - thorn = (build-asdf-system { - pname = "thorn"; - version = "20150608-git"; - asds = [ "thorn" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/thorn/2015-06-08/thorn-20150608-git.tgz"; - sha256 = "1d4w5358yxgccna91pxz9526w932j5ig17gp19zysjxvca57hqy7"; - system = "thorn"; - asd = "thorn"; - }); - systems = [ "thorn" ]; - lispLibs = [ (getAttr "common-doc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - thorn-doc = (build-asdf-system { - pname = "thorn-doc"; - version = "20150608-git"; - asds = [ "thorn-doc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/thorn/2015-06-08/thorn-20150608-git.tgz"; - sha256 = "1d4w5358yxgccna91pxz9526w932j5ig17gp19zysjxvca57hqy7"; - system = "thorn-doc"; - asd = "thorn-doc"; - }); - systems = [ "thorn-doc" ]; - lispLibs = [ (getAttr "thorn" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - thorn-test = (build-asdf-system { - pname = "thorn-test"; - version = "20150608-git"; - asds = [ "thorn-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/thorn/2015-06-08/thorn-20150608-git.tgz"; - sha256 = "1d4w5358yxgccna91pxz9526w932j5ig17gp19zysjxvca57hqy7"; - system = "thorn-test"; - asd = "thorn-test"; - }); - systems = [ "thorn-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "thorn" self) (getAttr "thorn-doc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - thread-pool = (build-asdf-system { - pname = "thread-pool"; - version = "20120107-git"; - asds = [ "thread-pool" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/thread-pool/2012-01-07/thread-pool-20120107-git.tgz"; - sha256 = "0wi9l0m660332w9pnc3w08m5hlsry9s0cgc3rznb5kyap68iv847"; - system = "thread-pool"; - asd = "thread-pool"; - }); - systems = [ "thread-pool" ]; - lispLibs = [ (getAttr "arnesi" self) (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - thread_dot_comm_dot_rendezvous = (build-asdf-system { - pname = "thread.comm.rendezvous"; - version = "20121013-git"; - asds = [ "thread.comm.rendezvous" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/thread.comm.rendezvous/2012-10-13/thread.comm.rendezvous-20121013-git.tgz"; - sha256 = "16crdy09zm20iclgln1vj0psd8ifz4rqb6g9255p0d2rkjk2rgfx"; - system = "thread.comm.rendezvous"; - asd = "thread.comm.rendezvous"; - }); - systems = [ "thread.comm.rendezvous" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-annot" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - thread_dot_comm_dot_rendezvous_dot_test = (build-asdf-system { - pname = "thread.comm.rendezvous.test"; - version = "20121013-git"; - asds = [ "thread.comm.rendezvous.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/thread.comm.rendezvous/2012-10-13/thread.comm.rendezvous-20121013-git.tgz"; - sha256 = "16crdy09zm20iclgln1vj0psd8ifz4rqb6g9255p0d2rkjk2rgfx"; - system = "thread.comm.rendezvous.test"; - asd = "thread.comm.rendezvous.test"; - }); - systems = [ "thread.comm.rendezvous.test" ]; - lispLibs = [ (getAttr "cl-test-more" self) (getAttr "thread_dot_comm_dot_rendezvous" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tile-grid = (build-asdf-system { - pname = "tile-grid"; - version = "20220707-git"; - asds = [ "tile-grid" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tile-grid/2022-07-07/tile-grid-20220707-git.tgz"; - sha256 = "10sqiqspiljnk4i1v4w0dkr640cgf9nvkgmkaww3smmhyjsd9270"; - system = "tile-grid"; - asd = "tile-grid"; - }); - systems = [ "tile-grid" ]; - lispLibs = [ (getAttr "mfiano-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - time-interval = (build-asdf-system { - pname = "time-interval"; - version = "20190202-git"; - asds = [ "time-interval" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/time-interval/2019-02-02/time-interval-20190202-git.tgz"; - sha256 = "0dydlg42bwcd7sr57v8hhrd86n80d5cb5r6r2id0zyqbrijabdw5"; - system = "time-interval"; - asd = "time-interval"; - }); - systems = [ "time-interval" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - timer-wheel = (build-asdf-system { - pname = "timer-wheel"; - version = "20180228-git"; - asds = [ "timer-wheel" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/timer-wheel/2018-02-28/timer-wheel-20180228-git.tgz"; - sha256 = "12pc1dpnkwj43n1sdqhg8n8h0mb16zcx4wxly85b7bqf00s962bc"; - system = "timer-wheel"; - asd = "timer-wheel"; - }); - systems = [ "timer-wheel" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - timer-wheel_dot_examples = (build-asdf-system { - pname = "timer-wheel.examples"; - version = "20180228-git"; - asds = [ "timer-wheel.examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/timer-wheel/2018-02-28/timer-wheel-20180228-git.tgz"; - sha256 = "12pc1dpnkwj43n1sdqhg8n8h0mb16zcx4wxly85b7bqf00s962bc"; - system = "timer-wheel.examples"; - asd = "timer-wheel.examples"; - }); - systems = [ "timer-wheel.examples" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "timer-wheel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tinaa = (build-asdf-system { - pname = "tinaa"; - version = "20171227-git"; - asds = [ "tinaa" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tinaa/2017-12-27/tinaa-20171227-git.tgz"; - sha256 = "10r1ypxphs5h7xxkl7v7r9pi2wdz1ik948mp63006hn44j7s1sa1"; - system = "tinaa"; - asd = "tinaa"; - }); - systems = [ "tinaa" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "asdf-system-connections" self) (getAttr "cl-containers" self) (getAttr "cl-graph" self) (getAttr "defsystem-compatibility" self) (getAttr "dynamic-classes" self) (getAttr "lml2" self) (getAttr "metatilities" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tinaa-test = (build-asdf-system { - pname = "tinaa-test"; - version = "20171227-git"; - asds = [ "tinaa-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tinaa/2017-12-27/tinaa-20171227-git.tgz"; - sha256 = "10r1ypxphs5h7xxkl7v7r9pi2wdz1ik948mp63006hn44j7s1sa1"; - system = "tinaa-test"; - asd = "tinaa-test"; - }); - systems = [ "tinaa-test" ]; - lispLibs = [ (getAttr "lift" self) (getAttr "tinaa" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tiny-routes = (build-asdf-system { - pname = "tiny-routes"; - version = "20241012-git"; - asds = [ "tiny-routes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tiny-routes/2024-10-12/tiny-routes-20241012-git.tgz"; - sha256 = "1wswzz7d26ic9izls7pnkybm8ryf5j0ksv55gr6k5nji9x8r5jqx"; - system = "tiny-routes"; - asd = "tiny-routes"; - }); - systems = [ "tiny-routes" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tiny-routes-middleware-cookie = (build-asdf-system { - pname = "tiny-routes-middleware-cookie"; - version = "20241012-git"; - asds = [ "tiny-routes-middleware-cookie" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tiny-routes/2024-10-12/tiny-routes-20241012-git.tgz"; - sha256 = "1wswzz7d26ic9izls7pnkybm8ryf5j0ksv55gr6k5nji9x8r5jqx"; - system = "tiny-routes-middleware-cookie"; - asd = "tiny-routes-middleware-cookie"; - }); - systems = [ "tiny-routes-middleware-cookie" ]; - lispLibs = [ (getAttr "cl-cookie" self) (getAttr "tiny-routes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tm = (build-asdf-system { - pname = "tm"; - version = "v0.8"; - asds = [ "tm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tm/2018-02-28/tm-v0.8.tgz"; - sha256 = "0lhqg5jpkzni1vzni0nnw7jb8ick1pbp04gfij2iczbi82qsw8x1"; - system = "tm"; - asd = "tm"; - }); - systems = [ "tm" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tmpdir = (build-asdf-system { - pname = "tmpdir"; - version = "20200218-git"; - asds = [ "tmpdir" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tmpdir/2020-02-18/tmpdir-20200218-git.tgz"; - sha256 = "11yshmg2wyd75ywwfybklm131d5rdw246pg35a6ksndiq3w5n4k8"; - system = "tmpdir"; - asd = "tmpdir"; - }); - systems = [ "tmpdir" ]; - lispLibs = [ (getAttr "cl-fad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tmpdir_dot_tests = (build-asdf-system { - pname = "tmpdir.tests"; - version = "20200218-git"; - asds = [ "tmpdir.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tmpdir/2020-02-18/tmpdir-20200218-git.tgz"; - sha256 = "11yshmg2wyd75ywwfybklm131d5rdw246pg35a6ksndiq3w5n4k8"; - system = "tmpdir.tests"; - asd = "tmpdir.tests"; - }); - systems = [ "tmpdir.tests" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "fiveam" self) (getAttr "osicat" self) (getAttr "tmpdir" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - toadstool = (build-asdf-system { - pname = "toadstool"; - version = "20130615-git"; - asds = [ "toadstool" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/toadstool/2013-06-15/toadstool-20130615-git.tgz"; - sha256 = "0njb1mdzk0247h87db90zv7bk40mw54pq8sj35l1dwa30d5yhi6r"; - system = "toadstool"; - asd = "toadstool"; - }); - systems = [ "toadstool" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - toadstool-tests = (build-asdf-system { - pname = "toadstool-tests"; - version = "20130615-git"; - asds = [ "toadstool-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/toadstool/2013-06-15/toadstool-20130615-git.tgz"; - sha256 = "0njb1mdzk0247h87db90zv7bk40mw54pq8sj35l1dwa30d5yhi6r"; - system = "toadstool-tests"; - asd = "toadstool-tests"; - }); - systems = [ "toadstool-tests" ]; - lispLibs = [ (getAttr "stefil" self) (getAttr "toadstool" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - toms419 = (build-asdf-system { - pname = "toms419"; - version = "20231021-git"; - asds = [ "toms419" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "toms419"; - asd = "toms419"; - }); - systems = [ "toms419" ]; - lispLibs = [ (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - toms715 = (build-asdf-system { - pname = "toms715"; - version = "20231021-git"; - asds = [ "toms715" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "toms715"; - asd = "toms715"; - }); - systems = [ "toms715" ]; - lispLibs = [ (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - toms717 = (build-asdf-system { - pname = "toms717"; - version = "20231021-git"; - asds = [ "toms717" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; - sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; - system = "toms717"; - asd = "toms717"; - }); - systems = [ "toms717" ]; - lispLibs = [ (getAttr "f2cl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - toot = (build-asdf-system { - pname = "toot"; - version = "20121125-git"; - asds = [ "toot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/toot/2012-11-25/toot-20121125-git.tgz"; - sha256 = "1235qhkjrg1mmy6kx1vhsqvgjjgc7hk2sjssapv7xr43m71n6ivx"; - system = "toot"; - asd = "toot"; - }); - systems = [ "toot" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "chunga" self) (getAttr "cl_plus_ssl" self) (getAttr "cl-base64" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "md5" self) (getAttr "puri" self) (getAttr "trivial-backtrace" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tooter = (build-asdf-system { - pname = "tooter"; - version = "20241012-git"; - asds = [ "tooter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tooter/2024-10-12/tooter-20241012-git.tgz"; - sha256 = "03ymavph34248lh18jycsky55dg83kjr6k5a9bib5wh2idswrfxp"; - system = "tooter"; - asd = "tooter"; - }); - systems = [ "tooter" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "documentation-utils" self) (getAttr "drakma" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - torrents = (build-asdf-system { - pname = "torrents"; - version = "20241012-git"; - asds = [ "torrents" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-torrents/2024-10-12/cl-torrents-20241012-git.tgz"; - sha256 = "1xigzskksgn8pg18v2dncfapdn94zv0djr4yi8nmkqbv8ljx93l4"; - system = "torrents"; - asd = "torrents"; - }); - systems = [ "torrents" ]; - lispLibs = [ (getAttr "access" self) (getAttr "cl-ansi-text" self) (getAttr "cl-readline" self) (getAttr "cl-transmission" self) (getAttr "clache" self) (getAttr "dexador" self) (getAttr "jonathan" self) (getAttr "log4cl" self) (getAttr "lparallel" self) (getAttr "lquery" self) (getAttr "mockingbird" self) (getAttr "parse-float" self) (getAttr "plump" self) (getAttr "py-configparser" self) (getAttr "replic" self) (getAttr "str" self) (getAttr "unix-opts" self) (getAttr "x_dot_let-star" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - torrents-test = (build-asdf-system { - pname = "torrents-test"; - version = "20241012-git"; - asds = [ "torrents-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-torrents/2024-10-12/cl-torrents-20241012-git.tgz"; - sha256 = "1xigzskksgn8pg18v2dncfapdn94zv0djr4yi8nmkqbv8ljx93l4"; - system = "torrents-test"; - asd = "torrents-test"; - }); - systems = [ "torrents-test" ]; - lispLibs = [ (getAttr "mockingbird" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "torrents" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - towers = (build-asdf-system { - pname = "towers"; - version = "20141217-git"; - asds = [ "towers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/towers/2014-12-17/towers-20141217-git.tgz"; - sha256 = "0r89z1hfb7kmj0a4qm7ih599hlin8rhxk6pb7nnvsdjgn436dkga"; - system = "towers"; - asd = "towers"; - }); - systems = [ "towers" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-glu" self) (getAttr "cl-glut" self) (getAttr "cl-opengl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trace-db = (build-asdf-system { - pname = "trace-db"; - version = "20230618-git"; - asds = [ "trace-db" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trace-db/2023-06-18/trace-db-20230618-git.tgz"; - sha256 = "1n2mj8nzd0c3clz5xjllajfad50i6yhir27i9q41r4sc5z1k0x63"; - system = "trace-db"; - asd = "trace-db"; - }); - systems = [ "trace-db" ]; - lispLibs = [ (getAttr "asdf-package-system" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - track-best = (build-asdf-system { - pname = "track-best"; - version = "20220220-git"; - asds = [ "track-best" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/track-best/2022-02-20/track-best-20220220-git.tgz"; - sha256 = "1f59bn57y1mdq18l1ji5q8yazv73g85y1mns2xzwbmx8sgxsa6pq"; - system = "track-best"; - asd = "track-best"; - }); - systems = [ "track-best" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trainable-object = (build-asdf-system { - pname = "trainable-object"; - version = "20191227-git"; - asds = [ "trainable-object" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trainable-object/2019-12-27/trainable-object-20191227-git.tgz"; - sha256 = "06hfv039xx5vwm3qpm4kwlzlxc4zxlfcpxnbbq8x12a32ngqykwm"; - system = "trainable-object"; - asd = "trainable-object"; - }); - systems = [ "trainable-object" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "serializable-object" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trainable-object_dot_test = (build-asdf-system { - pname = "trainable-object.test"; - version = "20191227-git"; - asds = [ "trainable-object.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trainable-object/2019-12-27/trainable-object-20191227-git.tgz"; - sha256 = "06hfv039xx5vwm3qpm4kwlzlxc4zxlfcpxnbbq8x12a32ngqykwm"; - system = "trainable-object.test"; - asd = "trainable-object.test"; - }); - systems = [ "trainable-object.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "trainable-object" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - transducers = (build-asdf-system { - pname = "transducers"; - version = "20241012-git"; - asds = [ "transducers" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-transducers/2024-10-12/cl-transducers-20241012-git.tgz"; - sha256 = "1n7g2fr5bxyq1axp3a1pw01c5v167njhd7i0gbpq35s1fxvqw6ik"; - system = "transducers"; - asd = "transducers"; - }); - systems = [ "transducers" ]; - lispLibs = [ (getAttr "sycamore" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - transducers-jzon = (build-asdf-system { - pname = "transducers-jzon"; - version = "20241012-git"; - asds = [ "transducers-jzon" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-transducers/2024-10-12/cl-transducers-20241012-git.tgz"; - sha256 = "1n7g2fr5bxyq1axp3a1pw01c5v167njhd7i0gbpq35s1fxvqw6ik"; - system = "transducers-jzon"; - asd = "transducers"; - }); - systems = [ "transducers-jzon" ]; - lispLibs = [ (getAttr "com_dot_inuoe_dot_jzon" self) (getAttr "transducers" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - transit = (build-asdf-system { - pname = "transit"; - version = "20241012-git"; - asds = [ "transit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-transit/2024-10-12/cl-transit-20241012-git.tgz"; - sha256 = "09rlajmcljl43n5866ackbdjkdz19sd12wzdzxnk2l7bjx3khqm4"; - system = "transit"; - asd = "transit"; - }); - systems = [ "transit" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bit-smasher" self) (getAttr "cl-messagepack" self) (getAttr "com_dot_inuoe_dot_jzon" self) (getAttr "flexi-streams" self) (getAttr "frugal-uuid" self) (getAttr "fset" self) (getAttr "local-time" self) (getAttr "parse-float" self) (getAttr "quri" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - transit-tests = (build-asdf-system { - pname = "transit-tests"; - version = "20241012-git"; - asds = [ "transit-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-transit/2024-10-12/cl-transit-20241012-git.tgz"; - sha256 = "09rlajmcljl43n5866ackbdjkdz19sd12wzdzxnk2l7bjx3khqm4"; - system = "transit-tests"; - asd = "transit-tests"; - }); - systems = [ "transit-tests" ]; - lispLibs = [ (getAttr "dexador" self) (getAttr "fiveam" self) (getAttr "marshal" self) (getAttr "transit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - translate = (build-asdf-system { - pname = "translate"; - version = "20180228-git"; - asds = [ "translate" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/translate/2018-02-28/translate-20180228-git.tgz"; - sha256 = "07bvdmj8x77k8pw24yhfp1xv9h40n5w717vgj3wmq703159kyjia"; - system = "translate"; - asd = "translate"; - }); - systems = [ "translate" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - translate-client = (build-asdf-system { - pname = "translate-client"; - version = "20180228-git"; - asds = [ "translate-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/translate-client/2018-02-28/translate-client-20180228-git.tgz"; - sha256 = "0mjzzahy5wrycik37dirwnvcd5bj5xm20cnw6cmzh0ncvb442mdx"; - system = "translate-client"; - asd = "translate-client"; - }); - systems = [ "translate-client" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "assoc-utils" self) (getAttr "dexador" self) (getAttr "quri" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - translators = (build-asdf-system { - pname = "translators"; - version = "master-fe503896-git"; - asds = [ "translators" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "translators"; - asd = "translators"; - }); - systems = [ "translators" ]; - lispLibs = [ (getAttr "gwl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - transparent-wrap = (build-asdf-system { - pname = "transparent-wrap"; - version = "20200925-git"; - asds = [ "transparent-wrap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/transparent-wrap/2020-09-25/transparent-wrap-20200925-git.tgz"; - sha256 = "0ghva34ksdvczfwpjdaf97bkjxrp35fjqkxamyqf7fbadh4wmfqj"; - system = "transparent-wrap"; - asd = "transparent-wrap"; - }); - systems = [ "transparent-wrap" ]; - lispLibs = [ (getAttr "fare-quasiquote-extras" self) (getAttr "named-readtables" self) (getAttr "optima" self) (getAttr "trivial-arguments" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tree = (build-asdf-system { - pname = "tree"; - version = "master-fe503896-git"; - asds = [ "tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "tree"; - asd = "tree"; - }); - systems = [ "tree" ]; - lispLibs = [ (getAttr "gwl-graphics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tree-search = (build-asdf-system { - pname = "tree-search"; - version = "0.0.1"; - asds = [ "tree-search" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tree-search/2020-12-20/tree-search-0.0.1.tgz"; - sha256 = "10qgd5yj3n2w4j6wsq1xly0hnpdi1bhhzpia4s1gpkywhglw84zq"; - system = "tree-search"; - asd = "tree-search"; - }); - systems = [ "tree-search" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - treedb = (build-asdf-system { - pname = "treedb"; - version = "20160825-git"; - asds = [ "treedb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/treedb/2016-08-25/treedb-20160825-git.tgz"; - sha256 = "02xsm4han0m0vj1j2ly2a6ncjcv7z8p3lcpkyj27xygag2vlchbq"; - system = "treedb"; - asd = "treedb"; - }); - systems = [ "treedb" ]; - lispLibs = [ (getAttr "cl-json" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - treedb_dot_doc = (build-asdf-system { - pname = "treedb.doc"; - version = "20160825-git"; - asds = [ "treedb.doc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/treedb/2016-08-25/treedb-20160825-git.tgz"; - sha256 = "02xsm4han0m0vj1j2ly2a6ncjcv7z8p3lcpkyj27xygag2vlchbq"; - system = "treedb.doc"; - asd = "treedb.doc"; - }); - systems = [ "treedb.doc" ]; - lispLibs = [ (getAttr "cl-gendoc" self) (getAttr "treedb" self) (getAttr "treedb_dot_tests" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - treedb_dot_tests = (build-asdf-system { - pname = "treedb.tests"; - version = "20160825-git"; - asds = [ "treedb.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/treedb/2016-08-25/treedb-20160825-git.tgz"; - sha256 = "02xsm4han0m0vj1j2ly2a6ncjcv7z8p3lcpkyj27xygag2vlchbq"; - system = "treedb.tests"; - asd = "treedb.tests"; - }); - systems = [ "treedb.tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "treedb" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trees = (build-asdf-system { - pname = "trees"; - version = "20180131-git"; - asds = [ "trees" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trees/2018-01-31/trees-20180131-git.tgz"; - sha256 = "1xvydf3qc17rd7ia8sffxcpclgm3l0iyhx8k72ddk59v3pg5is4k"; - system = "trees"; - asd = "trees"; - }); - systems = [ "trees" ]; - lispLibs = [ ]; - meta = {}; - }); - trees-tests = (build-asdf-system { - pname = "trees-tests"; - version = "20180131-git"; - asds = [ "trees-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trees/2018-01-31/trees-20180131-git.tgz"; - sha256 = "1xvydf3qc17rd7ia8sffxcpclgm3l0iyhx8k72ddk59v3pg5is4k"; - system = "trees-tests"; - asd = "trees"; - }); - systems = [ "trees-tests" ]; - lispLibs = [ (getAttr "trees" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trestrul = (build-asdf-system { - pname = "trestrul"; - version = "20211020-git"; - asds = [ "trestrul" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trestrul/2021-10-20/trestrul-20211020-git.tgz"; - sha256 = "12bghcfnfxq8l4a1jzh6vx4yna9da1xvp0b7kfdcfylnyga9ivy6"; - system = "trestrul"; - asd = "trestrul"; - }); - systems = [ "trestrul" ]; - lispLibs = [ (getAttr "jingoh_dot_documentizer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trestrul_dot_test = (build-asdf-system { - pname = "trestrul.test"; - version = "20211020-git"; - asds = [ "trestrul.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trestrul/2021-10-20/trestrul-20211020-git.tgz"; - sha256 = "12bghcfnfxq8l4a1jzh6vx4yna9da1xvp0b7kfdcfylnyga9ivy6"; - system = "trestrul.test"; - asd = "trestrul.test"; - }); - systems = [ "trestrul.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "trestrul" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivia = (build-asdf-system { - pname = "trivia"; - version = "20241012-git"; - asds = [ "trivia" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; - sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; - system = "trivia"; - asd = "trivia"; - }); - systems = [ "trivia" ]; - lispLibs = [ (getAttr "trivia_dot_balland2006" self) ]; - meta = {}; - }); - trivia_dot_balland2006 = (build-asdf-system { - pname = "trivia.balland2006"; - version = "20241012-git"; - asds = [ "trivia.balland2006" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; - sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; - system = "trivia.balland2006"; - asd = "trivia.balland2006"; - }); - systems = [ "trivia.balland2006" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) (getAttr "trivia_dot_trivial" self) (getAttr "type-i" self) ]; - meta = {}; - }); - trivia_dot_benchmark = (build-asdf-system { - pname = "trivia.benchmark"; - version = "20241012-git"; - asds = [ "trivia.benchmark" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; - sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; - system = "trivia.benchmark"; - asd = "trivia.benchmark"; - }); - systems = [ "trivia.benchmark" ]; - lispLibs = [ (getAttr "iterate" self) (getAttr "optima" self) (getAttr "trivia" self) (getAttr "trivia_dot_balland2006" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivia_dot_cffi = (build-asdf-system { - pname = "trivia.cffi"; - version = "20241012-git"; - asds = [ "trivia.cffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; - sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; - system = "trivia.cffi"; - asd = "trivia.cffi"; - }); - systems = [ "trivia.cffi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "trivia_dot_trivial" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivia_dot_fset = (build-asdf-system { - pname = "trivia.fset"; - version = "20241012-git"; - asds = [ "trivia.fset" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; - sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; - system = "trivia.fset"; - asd = "trivia.fset"; - }); - systems = [ "trivia.fset" ]; - lispLibs = [ (getAttr "fset" self) (getAttr "trivia_dot_trivial" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivia_dot_level0 = (build-asdf-system { - pname = "trivia.level0"; - version = "20241012-git"; - asds = [ "trivia.level0" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; - sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; - system = "trivia.level0"; - asd = "trivia.level0"; - }); - systems = [ "trivia.level0" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = {}; - }); - trivia_dot_level1 = (build-asdf-system { - pname = "trivia.level1"; - version = "20241012-git"; - asds = [ "trivia.level1" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; - sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; - system = "trivia.level1"; - asd = "trivia.level1"; - }); - systems = [ "trivia.level1" ]; - lispLibs = [ (getAttr "trivia_dot_level0" self) ]; - meta = {}; - }); - trivia_dot_level2 = (build-asdf-system { - pname = "trivia.level2"; - version = "20241012-git"; - asds = [ "trivia.level2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; - sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; - system = "trivia.level2"; - asd = "trivia.level2"; - }); - systems = [ "trivia.level2" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "lisp-namespace" self) (getAttr "trivia_dot_level1" self) (getAttr "trivial-cltl2" self) ]; - meta = {}; - }); - trivia_dot_ppcre = (build-asdf-system { - pname = "trivia.ppcre"; - version = "20241012-git"; - asds = [ "trivia.ppcre" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; - sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; - system = "trivia.ppcre"; - asd = "trivia.ppcre"; - }); - systems = [ "trivia.ppcre" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "trivia_dot_trivial" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivia_dot_quasiquote = (build-asdf-system { - pname = "trivia.quasiquote"; - version = "20241012-git"; - asds = [ "trivia.quasiquote" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; - sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; - system = "trivia.quasiquote"; - asd = "trivia.quasiquote"; - }); - systems = [ "trivia.quasiquote" ]; - lispLibs = [ (getAttr "fare-quasiquote-readtable" self) (getAttr "trivia_dot_trivial" self) ]; - meta = {}; - }); - trivia_dot_test = (build-asdf-system { - pname = "trivia.test"; - version = "20241012-git"; - asds = [ "trivia.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; - sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; - system = "trivia.test"; - asd = "trivia.test"; - }); - systems = [ "trivia.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "optima" self) (getAttr "trivia" self) (getAttr "trivia_dot_cffi" self) (getAttr "trivia_dot_fset" self) (getAttr "trivia_dot_ppcre" self) (getAttr "trivia_dot_quasiquote" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivia_dot_trivial = (build-asdf-system { - pname = "trivia.trivial"; - version = "20241012-git"; - asds = [ "trivia.trivial" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; - sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; - system = "trivia.trivial"; - asd = "trivia.trivial"; - }); - systems = [ "trivia.trivial" ]; - lispLibs = [ (getAttr "trivia_dot_level2" self) ]; - meta = {}; - }); - trivial-adjust-simple-array = (build-asdf-system { - pname = "trivial-adjust-simple-array"; - version = "20241012-git"; - asds = [ "trivial-adjust-simple-array" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-adjust-simple-array/2024-10-12/trivial-adjust-simple-array-20241012-git.tgz"; - sha256 = "05yifs4b44whqz4bgv4wys6kvza8y7z5w52kh55ch7krpv61ncy6"; - system = "trivial-adjust-simple-array"; - asd = "trivial-adjust-simple-array"; - }); - systems = [ "trivial-adjust-simple-array" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-arguments = (build-asdf-system { - pname = "trivial-arguments"; - version = "20241012-git"; - asds = [ "trivial-arguments" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-arguments/2024-10-12/trivial-arguments-20241012-git.tgz"; - sha256 = "1x1jifrw4ryyqgbln07znrc1drl4gxvzhbhv5gl1kgp2xm0rvr7j"; - system = "trivial-arguments"; - asd = "trivial-arguments"; - }); - systems = [ "trivial-arguments" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-backtrace = (build-asdf-system { - pname = "trivial-backtrace"; - version = "20230214-git"; - asds = [ "trivial-backtrace" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-backtrace/2023-02-14/trivial-backtrace-20230214-git.tgz"; - sha256 = "11j0p3vgmnn5q84xw7sacr5p3cvff2hfhsh2is8xpm2iwxc723kn"; - system = "trivial-backtrace"; - asd = "trivial-backtrace"; - }); - systems = [ "trivial-backtrace" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-backtrace-test = (build-asdf-system { - pname = "trivial-backtrace-test"; - version = "20230214-git"; - asds = [ "trivial-backtrace-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-backtrace/2023-02-14/trivial-backtrace-20230214-git.tgz"; - sha256 = "11j0p3vgmnn5q84xw7sacr5p3cvff2hfhsh2is8xpm2iwxc723kn"; - system = "trivial-backtrace-test"; - asd = "trivial-backtrace-test"; - }); - systems = [ "trivial-backtrace-test" ]; - lispLibs = [ (getAttr "lift" self) (getAttr "trivial-backtrace" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-battery = (build-asdf-system { - pname = "trivial-battery"; - version = "20211020-git"; - asds = [ "trivial-battery" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-battery/2021-10-20/trivial-battery-20211020-git.tgz"; - sha256 = "12ni2502v9gjszhjsh0aai08cm64gl8g815xghdjhcf7y34ffl2b"; - system = "trivial-battery"; - asd = "trivial-battery"; - }); - systems = [ "trivial-battery" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-benchmark = (build-asdf-system { - pname = "trivial-benchmark"; - version = "20231021-git"; - asds = [ "trivial-benchmark" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-benchmark/2023-10-21/trivial-benchmark-20231021-git.tgz"; - sha256 = "1p48wgpady0n8frdcgp7sbg93b0fbvpx1qk5valmanhwr9j3xh88"; - system = "trivial-benchmark"; - asd = "trivial-benchmark"; - }); - systems = [ "trivial-benchmark" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-bit-streams = (build-asdf-system { - pname = "trivial-bit-streams"; - version = "20190710-git"; - asds = [ "trivial-bit-streams" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-bit-streams/2019-07-10/trivial-bit-streams-20190710-git.tgz"; - sha256 = "01xcs069934pzm8gi1xkwgd4lw37ams30i6rcgrlw8gnx4zc4zc9"; - system = "trivial-bit-streams"; - asd = "trivial-bit-streams"; - }); - systems = [ "trivial-bit-streams" ]; - lispLibs = [ (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-bit-streams-tests = (build-asdf-system { - pname = "trivial-bit-streams-tests"; - version = "20190710-git"; - asds = [ "trivial-bit-streams-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-bit-streams/2019-07-10/trivial-bit-streams-20190710-git.tgz"; - sha256 = "01xcs069934pzm8gi1xkwgd4lw37ams30i6rcgrlw8gnx4zc4zc9"; - system = "trivial-bit-streams-tests"; - asd = "trivial-bit-streams-tests"; - }); - systems = [ "trivial-bit-streams-tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "flexi-streams" self) (getAttr "trivial-bit-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-build = (build-asdf-system { - pname = "trivial-build"; - version = "20151218-git"; - asds = [ "trivial-build" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-build/2015-12-18/trivial-build-20151218-git.tgz"; - sha256 = "10h1igvryaqz6f72i57ppifysnw8swnss9395sijnk595icja7q0"; - system = "trivial-build"; - asd = "trivial-build"; - }); - systems = [ "trivial-build" ]; - lispLibs = [ (getAttr "lisp-invocation" self) (getAttr "trivial-exe" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-build-test = (build-asdf-system { - pname = "trivial-build-test"; - version = "20151218-git"; - asds = [ "trivial-build-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-build/2015-12-18/trivial-build-20151218-git.tgz"; - sha256 = "10h1igvryaqz6f72i57ppifysnw8swnss9395sijnk595icja7q0"; - system = "trivial-build-test"; - asd = "trivial-build-test"; - }); - systems = [ "trivial-build-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "trivial-build" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-channels = (build-asdf-system { - pname = "trivial-channels"; - version = "20160421-git"; - asds = [ "trivial-channels" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-channels/2016-04-21/trivial-channels-20160421-git.tgz"; - sha256 = "04wnxcgk40x8p0gxnz9arv1a5wasdqrdxa8c4p5v7r2mycfps6jj"; - system = "trivial-channels"; - asd = "trivial-channels"; - }); - systems = [ "trivial-channels" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "trivial-timeout" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-clipboard = (build-asdf-system { - pname = "trivial-clipboard"; - version = "20241012-git"; - asds = [ "trivial-clipboard" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-clipboard/2024-10-12/trivial-clipboard-20241012-git.tgz"; - sha256 = "1agj4nvw4qq7k4vp64y15gq5h5g22zasys48c2bvzqjr0n9d4lj1"; - system = "trivial-clipboard"; - asd = "trivial-clipboard"; - }); - systems = [ "trivial-clipboard" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-clipboard-test = (build-asdf-system { - pname = "trivial-clipboard-test"; - version = "20241012-git"; - asds = [ "trivial-clipboard-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-clipboard/2024-10-12/trivial-clipboard-20241012-git.tgz"; - sha256 = "1agj4nvw4qq7k4vp64y15gq5h5g22zasys48c2bvzqjr0n9d4lj1"; - system = "trivial-clipboard-test"; - asd = "trivial-clipboard-test"; - }); - systems = [ "trivial-clipboard-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "trivial-clipboard" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-clock = (build-asdf-system { - pname = "trivial-clock"; - version = "20241012-git"; - asds = [ "trivial-clock" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-trivial-clock/2024-10-12/cl-trivial-clock-20241012-git.tgz"; - sha256 = "1m1351j3xvrf6631gmf99xaxb3dhh4ak657p1hac3b9f9a5h85nd"; - system = "trivial-clock"; - asd = "trivial-clock"; - }); - systems = [ "trivial-clock" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-cltl2 = (build-asdf-system { - pname = "trivial-cltl2"; - version = "20211230-git"; - asds = [ "trivial-cltl2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-cltl2/2021-12-30/trivial-cltl2-20211230-git.tgz"; - sha256 = "0xx5vr0dp623m111zbfdk6x7l4jgd4wwyp6iarbj6ijq514wi3a3"; - system = "trivial-cltl2"; - asd = "trivial-cltl2"; - }); - systems = [ "trivial-cltl2" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-compress = (build-asdf-system { - pname = "trivial-compress"; - version = "20201220-git"; - asds = [ "trivial-compress" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-compress/2020-12-20/trivial-compress-20201220-git.tgz"; - sha256 = "1pbaz0phvzi27dgnfknscak1h27bsi16gys23kchg8y8zbm0z0g7"; - system = "trivial-compress"; - asd = "trivial-compress"; - }); - systems = [ "trivial-compress" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "archive" self) (getAttr "which" self) (getAttr "zip" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-compress-test = (build-asdf-system { - pname = "trivial-compress-test"; - version = "20201220-git"; - asds = [ "trivial-compress-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-compress/2020-12-20/trivial-compress-20201220-git.tgz"; - sha256 = "1pbaz0phvzi27dgnfknscak1h27bsi16gys23kchg8y8zbm0z0g7"; - system = "trivial-compress-test"; - asd = "trivial-compress-test"; - }); - systems = [ "trivial-compress-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "trivial-compress" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-continuation = (build-asdf-system { - pname = "trivial-continuation"; - version = "20191007-git"; - asds = [ "trivial-continuation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-continuation/2019-10-07/trivial-continuation-20191007-git.tgz"; - sha256 = "1j8d8q86r60qr9pi5p3q7rqn16xpzbzygs0i9b8sn3qyxnnz5037"; - system = "trivial-continuation"; - asd = "trivial-continuation"; - }); - systems = [ "trivial-continuation" ]; - lispLibs = [ (getAttr "log4cl" self) (getAttr "trivial-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-coverage = (build-asdf-system { - pname = "trivial-coverage"; - version = "20200218-git"; - asds = [ "trivial-coverage" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-coverage/2020-02-18/trivial-coverage-20200218-git.tgz"; - sha256 = "1ak4mjcvzdjsjjh7j89zlnwgaamfrspxmjh2i9kg67kqn36prbsp"; - system = "trivial-coverage"; - asd = "trivial-coverage"; - }); - systems = [ "trivial-coverage" ]; - lispLibs = [ (getAttr "lquery" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-custom-debugger = (build-asdf-system { - pname = "trivial-custom-debugger"; - version = "20231021-git"; - asds = [ "trivial-custom-debugger" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-custom-debugger/2023-10-21/trivial-custom-debugger-20231021-git.tgz"; - sha256 = "11x0wpnfllazaqlrgv9xx1mb5q62dx6ny08hpwgkq3jpvqbhxs3b"; - system = "trivial-custom-debugger"; - asd = "trivial-custom-debugger"; - }); - systems = [ "trivial-custom-debugger" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-debug-console = (build-asdf-system { - pname = "trivial-debug-console"; - version = "20150407-git"; - asds = [ "trivial-debug-console" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-debug-console/2015-04-07/trivial-debug-console-20150407-git.tgz"; - sha256 = "07r42k57vldg01hfwjhkic2hsy84c2s5zj7pl60xjl960i0lqnam"; - system = "trivial-debug-console"; - asd = "trivial-debug-console"; - }); - systems = [ "trivial-debug-console" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-do = (build-asdf-system { - pname = "trivial-do"; - version = "20220331-git"; - asds = [ "trivial-do" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-do/2022-03-31/trivial-do-20220331-git.tgz"; - sha256 = "0vql7am4zyg6zav3l6n6q3qgdxlnchdxpgdxp8lr9sm7jra7sdsf"; - system = "trivial-do"; - asd = "trivial-do"; - }); - systems = [ "trivial-do" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-documentation = (build-asdf-system { - pname = "trivial-documentation"; - version = "20161204-git"; - asds = [ "trivial-documentation" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-documentation/2016-12-04/trivial-documentation-20161204-git.tgz"; - sha256 = "0y90zi6kaw7226xc089dl47677fz594a5ck1ld8yggk9ww7cdaav"; - system = "trivial-documentation"; - asd = "trivial-documentation"; - }); - systems = [ "trivial-documentation" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-documentation-test = (build-asdf-system { - pname = "trivial-documentation-test"; - version = "20161204-git"; - asds = [ "trivial-documentation-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-documentation/2016-12-04/trivial-documentation-20161204-git.tgz"; - sha256 = "0y90zi6kaw7226xc089dl47677fz594a5ck1ld8yggk9ww7cdaav"; - system = "trivial-documentation-test"; - asd = "trivial-documentation-test"; - }); - systems = [ "trivial-documentation-test" ]; - lispLibs = [ (getAttr "trivial-documentation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-download = (build-asdf-system { - pname = "trivial-download"; - version = "20230214-git"; - asds = [ "trivial-download" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-download/2023-02-14/trivial-download-20230214-git.tgz"; - sha256 = "17kag2zi1r766n2mg4knz4ix268bll2acl0150cksibfa4dbq1k7"; - system = "trivial-download"; - asd = "trivial-download"; - }); - systems = [ "trivial-download" ]; - lispLibs = [ (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-dump-core = (build-asdf-system { - pname = "trivial-dump-core"; - version = "20170227-git"; - asds = [ "trivial-dump-core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-dump-core/2017-02-27/trivial-dump-core-20170227-git.tgz"; - sha256 = "08lnp84gbf3yd3gpnbjbl8jm9p42j3m4hf2f355l7lylb8kabxn8"; - system = "trivial-dump-core"; - asd = "trivial-dump-core"; - }); - systems = [ "trivial-dump-core" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-ed-functions = (build-asdf-system { - pname = "trivial-ed-functions"; - version = "20210807-git"; - asds = [ "trivial-ed-functions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-ed-functions/2021-08-07/trivial-ed-functions-20210807-git.tgz"; - sha256 = "05r8n4jjcg2lci5qrjwqz913wivckgk01ivjg1barpnm0nr29qn1"; - system = "trivial-ed-functions"; - asd = "trivial-ed-functions"; - }); - systems = [ "trivial-ed-functions" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-escapes = (build-asdf-system { - pname = "trivial-escapes"; - version = "20180228-git"; - asds = [ "trivial-escapes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-escapes/2018-02-28/trivial-escapes-20180228-git.tgz"; - sha256 = "0v6h8lk17iqv1qkxgqjyzn8gi6v0hvq2vmfbb01md3zjvjqxn6lr"; - system = "trivial-escapes"; - asd = "trivial-escapes"; - }); - systems = [ "trivial-escapes" ]; - lispLibs = [ (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-escapes-test = (build-asdf-system { - pname = "trivial-escapes-test"; - version = "20180228-git"; - asds = [ "trivial-escapes-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-escapes/2018-02-28/trivial-escapes-20180228-git.tgz"; - sha256 = "0v6h8lk17iqv1qkxgqjyzn8gi6v0hvq2vmfbb01md3zjvjqxn6lr"; - system = "trivial-escapes-test"; - asd = "trivial-escapes-test"; - }); - systems = [ "trivial-escapes-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "trivial-escapes" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-exe = (build-asdf-system { - pname = "trivial-exe"; - version = "20151218-git"; - asds = [ "trivial-exe" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-exe/2015-12-18/trivial-exe-20151218-git.tgz"; - sha256 = "1ryn7gh3n057czj3hwq6lx7h25ipfjxsvddywpm2ngfdwywaqzvc"; - system = "trivial-exe"; - asd = "trivial-exe"; - }); - systems = [ "trivial-exe" ]; - lispLibs = [ (getAttr "osicat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-exe-test = (build-asdf-system { - pname = "trivial-exe-test"; - version = "20151218-git"; - asds = [ "trivial-exe-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-exe/2015-12-18/trivial-exe-20151218-git.tgz"; - sha256 = "1ryn7gh3n057czj3hwq6lx7h25ipfjxsvddywpm2ngfdwywaqzvc"; - system = "trivial-exe-test"; - asd = "trivial-exe-test"; - }); - systems = [ "trivial-exe-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "trivial-exe" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-extensible-sequences = (build-asdf-system { - pname = "trivial-extensible-sequences"; - version = "20231021-git"; - asds = [ "trivial-extensible-sequences" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-extensible-sequences/2023-10-21/trivial-extensible-sequences-20231021-git.tgz"; - sha256 = "1mgfvyvy3dkn8wyjqc49czl990rbbfkz7sfrhz9641dilasmw9s6"; - system = "trivial-extensible-sequences"; - asd = "trivial-extensible-sequences"; - }); - systems = [ "trivial-extensible-sequences" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-extract = (build-asdf-system { - pname = "trivial-extract"; - version = "20160421-git"; - asds = [ "trivial-extract" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-extract/2016-04-21/trivial-extract-20160421-git.tgz"; - sha256 = "0083x71f4x6b64wd8ywgaiqi0ygmdhl5rv101jcv44l3l61839sx"; - system = "trivial-extract"; - asd = "trivial-extract"; - }); - systems = [ "trivial-extract" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "archive" self) (getAttr "cl-fad" self) (getAttr "deflate" self) (getAttr "which" self) (getAttr "zip" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-extract-test = (build-asdf-system { - pname = "trivial-extract-test"; - version = "20160421-git"; - asds = [ "trivial-extract-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-extract/2016-04-21/trivial-extract-20160421-git.tgz"; - sha256 = "0083x71f4x6b64wd8ywgaiqi0ygmdhl5rv101jcv44l3l61839sx"; - system = "trivial-extract-test"; - asd = "trivial-extract-test"; - }); - systems = [ "trivial-extract-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "trivial-extract" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-features = (build-asdf-system { - pname = "trivial-features"; - version = "20230618-git"; - asds = [ "trivial-features" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-features/2023-06-18/trivial-features-20230618-git.tgz"; - sha256 = "0r33ycg1wsmglbsychglzkd6fachnnqfzd0w9mhpwi6cz94hx7c3"; - system = "trivial-features"; - asd = "trivial-features"; - }); - systems = [ "trivial-features" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-features-tests = (build-asdf-system { - pname = "trivial-features-tests"; - version = "20230618-git"; - asds = [ "trivial-features-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-features/2023-06-18/trivial-features-20230618-git.tgz"; - sha256 = "0r33ycg1wsmglbsychglzkd6fachnnqfzd0w9mhpwi6cz94hx7c3"; - system = "trivial-features-tests"; - asd = "trivial-features-tests"; - }); - systems = [ "trivial-features-tests" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "rt" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-file-size = (build-asdf-system { - pname = "trivial-file-size"; - version = "20241012-git"; - asds = [ "trivial-file-size" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-file-size/2024-10-12/trivial-file-size-20241012-git.tgz"; - sha256 = "08dbyrrgvvl459lk3pcq0j7qryb20hdh946y42h4jsp5crhbi71z"; - system = "trivial-file-size"; - asd = "trivial-file-size"; - }); - systems = [ "trivial-file-size" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-garbage = (build-asdf-system { - pname = "trivial-garbage"; - version = "20231021-git"; - asds = [ "trivial-garbage" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-garbage/2023-10-21/trivial-garbage-20231021-git.tgz"; - sha256 = "0rfwxvwg0kpcaa0hsi035yrkfdfks4bq8d9azmrww2f0rmv9g6sd"; - system = "trivial-garbage"; - asd = "trivial-garbage"; - }); - systems = [ "trivial-garbage" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-gray-streams = (build-asdf-system { - pname = "trivial-gray-streams"; - version = "20241012-git"; - asds = [ "trivial-gray-streams" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-gray-streams/2024-10-12/trivial-gray-streams-20241012-git.tgz"; - sha256 = "0iw6q5hx7x8sc5s7ikvsjccsksbm0rd13d54mkrg62sc56hjywrm"; - system = "trivial-gray-streams"; - asd = "trivial-gray-streams"; - }); - systems = [ "trivial-gray-streams" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-gray-streams-test = (build-asdf-system { - pname = "trivial-gray-streams-test"; - version = "20241012-git"; - asds = [ "trivial-gray-streams-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-gray-streams/2024-10-12/trivial-gray-streams-20241012-git.tgz"; - sha256 = "0iw6q5hx7x8sc5s7ikvsjccsksbm0rd13d54mkrg62sc56hjywrm"; - system = "trivial-gray-streams-test"; - asd = "trivial-gray-streams-test"; - }); - systems = [ "trivial-gray-streams-test" ]; - lispLibs = [ (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-hashtable-serialize = (build-asdf-system { - pname = "trivial-hashtable-serialize"; - version = "20191007-git"; - asds = [ "trivial-hashtable-serialize" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-hashtable-serialize/2019-10-07/trivial-hashtable-serialize-20191007-git.tgz"; - sha256 = "06xdci47h6rpfkmrf7p9kd217jbkmkmf90ygqcmkkgf3sv5623bh"; - system = "trivial-hashtable-serialize"; - asd = "trivial-hashtable-serialize"; - }); - systems = [ "trivial-hashtable-serialize" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-http = (build-asdf-system { - pname = "trivial-http"; - version = "20110219-http"; - asds = [ "trivial-http" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-http/2011-02-19/trivial-http-20110219-http.tgz"; - sha256 = "06mrh2bjzhfdzi48dnq0bhl2cac4v41aqck53rfm4rnsygcjsn78"; - system = "trivial-http"; - asd = "trivial-http"; - }); - systems = [ "trivial-http" ]; - lispLibs = [ (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-http-test = (build-asdf-system { - pname = "trivial-http-test"; - version = "20110219-http"; - asds = [ "trivial-http-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-http/2011-02-19/trivial-http-20110219-http.tgz"; - sha256 = "06mrh2bjzhfdzi48dnq0bhl2cac4v41aqck53rfm4rnsygcjsn78"; - system = "trivial-http-test"; - asd = "trivial-http-test"; - }); - systems = [ "trivial-http-test" ]; - lispLibs = [ (getAttr "lift" self) (getAttr "trivial-http" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-indent = (build-asdf-system { - pname = "trivial-indent"; - version = "20231021-git"; - asds = [ "trivial-indent" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-indent/2023-10-21/trivial-indent-20231021-git.tgz"; - sha256 = "08qgx34zbpafzws96nq68bgpynddf22ibliqni2jnvhwv74lcpiw"; - system = "trivial-indent"; - asd = "trivial-indent"; - }); - systems = [ "trivial-indent" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-inspector-hook = (build-asdf-system { - pname = "trivial-inspector-hook"; - version = "20210807-git"; - asds = [ "trivial-inspector-hook" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-inspector-hook/2021-08-07/trivial-inspector-hook-20210807-git.tgz"; - sha256 = "0h9m1ps5sqgrr171czj6rq84wpy2xvggfzspvy667xsldv4xi0c2"; - system = "trivial-inspector-hook"; - asd = "trivial-inspector-hook"; - }); - systems = [ "trivial-inspector-hook" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-irc = (build-asdf-system { - pname = "trivial-irc"; - version = "20171019-git"; - asds = [ "trivial-irc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-irc/2017-10-19/trivial-irc-20171019-git.tgz"; - sha256 = "0jjgx6ld2gcr0w0g5k62dr0rl6202ydih6ylmypv6m5jmrarcbza"; - system = "trivial-irc"; - asd = "trivial-irc"; - }); - systems = [ "trivial-irc" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "split-sequence" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-irc-echobot = (build-asdf-system { - pname = "trivial-irc-echobot"; - version = "20171019-git"; - asds = [ "trivial-irc-echobot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-irc/2017-10-19/trivial-irc-20171019-git.tgz"; - sha256 = "0jjgx6ld2gcr0w0g5k62dr0rl6202ydih6ylmypv6m5jmrarcbza"; - system = "trivial-irc-echobot"; - asd = "trivial-irc-echobot"; - }); - systems = [ "trivial-irc-echobot" ]; - lispLibs = [ (getAttr "trivial-irc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-json-codec = (build-asdf-system { - pname = "trivial-json-codec"; - version = "20220707-git"; - asds = [ "trivial-json-codec" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-json-codec/2022-07-07/trivial-json-codec-20220707-git.tgz"; - sha256 = "1k0nnsn3nsb83gzmkrf81zqz6ydn21gzfq96r2d5690v5zkrg1kg"; - system = "trivial-json-codec"; - asd = "trivial-json-codec"; - }); - systems = [ "trivial-json-codec" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "iterate" self) (getAttr "log4cl" self) (getAttr "parse-number" self) (getAttr "trivial-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-jumptables = (build-asdf-system { - pname = "trivial-jumptables"; - version = "1.1"; - asds = [ "trivial-jumptables" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-jumptables/2019-11-30/trivial-jumptables_1.1.tgz"; - sha256 = "10ih84hkscj0l4ki3s196d9b85iil8f56ps5r8ng222i0lln1ni9"; - system = "trivial-jumptables"; - asd = "trivial-jumptables"; - }); - systems = [ "trivial-jumptables" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-jumptables__tests = (build-asdf-system { - pname = "trivial-jumptables_tests"; - version = "1.1"; - asds = [ "trivial-jumptables_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-jumptables/2019-11-30/trivial-jumptables_1.1.tgz"; - sha256 = "10ih84hkscj0l4ki3s196d9b85iil8f56ps5r8ng222i0lln1ni9"; - system = "trivial-jumptables_tests"; - asd = "trivial-jumptables_tests"; - }); - systems = [ "trivial-jumptables_tests" ]; - lispLibs = [ (getAttr "bubble-operator-upwards" self) (getAttr "parachute" self) (getAttr "trivial-jumptables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-lazy = (build-asdf-system { - pname = "trivial-lazy"; - version = "20150709-git"; - asds = [ "trivial-lazy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-lazy/2015-07-09/trivial-lazy-20150709-git.tgz"; - sha256 = "0fnsz2kdb0v5cz4xl5a2c1szcif7jmnkxhbzvk6lrhzjccgyhjc7"; - system = "trivial-lazy"; - asd = "trivial-lazy"; - }); - systems = [ "trivial-lazy" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-ldap = (build-asdf-system { - pname = "trivial-ldap"; - version = "20180711-git"; - asds = [ "trivial-ldap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-ldap/2018-07-11/trivial-ldap-20180711-git.tgz"; - sha256 = "1zaa4wnk5y5ff211pkg6dl27j4pjwh56hq0246slxsdxv6kvp1z9"; - system = "trivial-ldap"; - asd = "trivial-ldap"; - }); - systems = [ "trivial-ldap" ]; - lispLibs = [ (getAttr "cl_plus_ssl" self) (getAttr "usocket" self) (getAttr "yacc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-left-pad = (build-asdf-system { - pname = "trivial-left-pad"; - version = "20190813-git"; - asds = [ "trivial-left-pad" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-left-pad/2019-08-13/trivial-left-pad-20190813-git.tgz"; - sha256 = "0q68j0x0x3z8rl577jsl3y0s3x5xiqv54sla6kds43q7821qfnwk"; - system = "trivial-left-pad"; - asd = "trivial-left-pad"; - }); - systems = [ "trivial-left-pad" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "prove-asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-left-pad-test = (build-asdf-system { - pname = "trivial-left-pad-test"; - version = "20190813-git"; - asds = [ "trivial-left-pad-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-left-pad/2019-08-13/trivial-left-pad-20190813-git.tgz"; - sha256 = "0q68j0x0x3z8rl577jsl3y0s3x5xiqv54sla6kds43q7821qfnwk"; - system = "trivial-left-pad-test"; - asd = "trivial-left-pad"; - }); - systems = [ "trivial-left-pad-test" ]; - lispLibs = [ (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "trivial-left-pad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-macroexpand-all = (build-asdf-system { - pname = "trivial-macroexpand-all"; - version = "20171023-git"; - asds = [ "trivial-macroexpand-all" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-macroexpand-all/2017-10-23/trivial-macroexpand-all-20171023-git.tgz"; - sha256 = "191hnn4b5j4i3crydmlzbm231kj0h7l8zj6mzj69r1npbzkas4bd"; - system = "trivial-macroexpand-all"; - asd = "trivial-macroexpand-all"; - }); - systems = [ "trivial-macroexpand-all" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-main-thread = (build-asdf-system { - pname = "trivial-main-thread"; - version = "20241012-git"; - asds = [ "trivial-main-thread" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-main-thread/2024-10-12/trivial-main-thread-20241012-git.tgz"; - sha256 = "0vxr82ald41355hvlg0ngrpzkz9y3nyl24h58306kmg982xk4hnk"; - system = "trivial-main-thread"; - asd = "trivial-main-thread"; - }); - systems = [ "trivial-main-thread" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "documentation-utils" self) (getAttr "trivial-features" self) ]; - meta = {}; - }); - trivial-method-combinations = (build-asdf-system { - pname = "trivial-method-combinations"; - version = "20191130-git"; - asds = [ "trivial-method-combinations" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-method-combinations/2019-11-30/trivial-method-combinations-20191130-git.tgz"; - sha256 = "0w9w8bj835sfp797rdm7b5crpnz0xrz2q5vgbzm2p9n9jskxnxnv"; - system = "trivial-method-combinations"; - asd = "trivial-method-combinations"; - }); - systems = [ "trivial-method-combinations" ]; - lispLibs = [ (getAttr "closer-mop" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-mimes = (build-asdf-system { - pname = "trivial-mimes"; - version = "20231021-git"; - asds = [ "trivial-mimes" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-mimes/2023-10-21/trivial-mimes-20231021-git.tgz"; - sha256 = "05cqbg9bh4r9av675vrzgw4p3s1dxb74r2ygvbfkych79kdik871"; - system = "trivial-mimes"; - asd = "trivial-mimes"; - }); - systems = [ "trivial-mimes" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-mmap = (build-asdf-system { - pname = "trivial-mmap"; - version = "20210124-git"; - asds = [ "trivial-mmap" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-mmap/2021-01-24/trivial-mmap-20210124-git.tgz"; - sha256 = "1ckhd7b0ll9xcmwdh42g0v38grk2acs3kv66k1gwh539f99kzcps"; - system = "trivial-mmap"; - asd = "trivial-mmap"; - }); - systems = [ "trivial-mmap" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "osicat" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-monitored-thread = (build-asdf-system { - pname = "trivial-monitored-thread"; - version = "20220707-git"; - asds = [ "trivial-monitored-thread" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-monitored-thread/2022-07-07/trivial-monitored-thread-20220707-git.tgz"; - sha256 = "1vmhc5id0qk5yh8az4j1znqc73r18pygmrnfxmwwndh1a9yf98z4"; - system = "trivial-monitored-thread"; - asd = "trivial-monitored-thread"; - }); - systems = [ "trivial-monitored-thread" ]; - lispLibs = [ (getAttr "iterate" self) (getAttr "log4cl" self) (getAttr "trivial-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-msi = (build-asdf-system { - pname = "trivial-msi"; - version = "20160208-git"; - asds = [ "trivial-msi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-msi/2016-02-08/trivial-msi-20160208-git.tgz"; - sha256 = "1mbpwnsvv30gf7z8m96kv8933s6csg4q0frx03vazp4ckplwff8w"; - system = "trivial-msi"; - asd = "trivial-msi"; - }); - systems = [ "trivial-msi" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-msi-test = (build-asdf-system { - pname = "trivial-msi-test"; - version = "20160208-git"; - asds = [ "trivial-msi-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-msi/2016-02-08/trivial-msi-20160208-git.tgz"; - sha256 = "1mbpwnsvv30gf7z8m96kv8933s6csg4q0frx03vazp4ckplwff8w"; - system = "trivial-msi-test"; - asd = "trivial-msi-test"; - }); - systems = [ "trivial-msi-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "trivial-msi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-nntp = (build-asdf-system { - pname = "trivial-nntp"; - version = "20161204-git"; - asds = [ "trivial-nntp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-nntp/2016-12-04/trivial-nntp-20161204-git.tgz"; - sha256 = "0ywwrjx4vaz117zaxqhk2b4xrb75cw1ac5xir9zhvgzkyl6wf867"; - system = "trivial-nntp"; - asd = "trivial-nntp"; - }); - systems = [ "trivial-nntp" ]; - lispLibs = [ (getAttr "cl_plus_ssl" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-object-lock = (build-asdf-system { - pname = "trivial-object-lock"; - version = "20220707-git"; - asds = [ "trivial-object-lock" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-object-lock/2022-07-07/trivial-object-lock-20220707-git.tgz"; - sha256 = "18xwwgvshib4l2bs6m16mk0kzdp40482yf7v72nzk13v0bgnw91s"; - system = "trivial-object-lock"; - asd = "trivial-object-lock"; - }); - systems = [ "trivial-object-lock" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "iterate" self) (getAttr "log4cl" self) (getAttr "trivial-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-octet-streams = (build-asdf-system { - pname = "trivial-octet-streams"; - version = "20241012-git"; - asds = [ "trivial-octet-streams" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-octet-streams/2024-10-12/trivial-octet-streams-20241012-git.tgz"; - sha256 = "0zj7aijn10hflr87774hwi5k1jzq6j5bgh2hm70ixxhcmaq7lqk5"; - system = "trivial-octet-streams"; - asd = "trivial-octet-streams"; - }); - systems = [ "trivial-octet-streams" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-open-browser = (build-asdf-system { - pname = "trivial-open-browser"; - version = "20160825-git"; - asds = [ "trivial-open-browser" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-open-browser/2016-08-25/trivial-open-browser-20160825-git.tgz"; - sha256 = "0ixay1piq420i6adx642qhw45l6ik7rvgk52lyz27dvx5f8yqsdb"; - system = "trivial-open-browser"; - asd = "trivial-open-browser"; - }); - systems = [ "trivial-open-browser" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-openstack = (build-asdf-system { - pname = "trivial-openstack"; - version = "20160628-git"; - asds = [ "trivial-openstack" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-openstack/2016-06-28/trivial-openstack-20160628-git.tgz"; - sha256 = "0sdc6rhjqv1i7wknn44jg5xxnz70087bhfslh0izggny9d9s015i"; - system = "trivial-openstack"; - asd = "trivial-openstack"; - }); - systems = [ "trivial-openstack" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "drakma" self) (getAttr "local-time" self) (getAttr "st-json" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-openstack-test = (build-asdf-system { - pname = "trivial-openstack-test"; - version = "20160628-git"; - asds = [ "trivial-openstack-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-openstack/2016-06-28/trivial-openstack-20160628-git.tgz"; - sha256 = "0sdc6rhjqv1i7wknn44jg5xxnz70087bhfslh0izggny9d9s015i"; - system = "trivial-openstack-test"; - asd = "trivial-openstack-test"; - }); - systems = [ "trivial-openstack-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "hunchentoot" self) (getAttr "local-time" self) (getAttr "st-json" self) (getAttr "trivial-openstack" self) (getAttr "uri-template" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-package-local-nicknames = (build-asdf-system { - pname = "trivial-package-local-nicknames"; - version = "20220220-git"; - asds = [ "trivial-package-local-nicknames" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-package-local-nicknames/2022-02-20/trivial-package-local-nicknames-20220220-git.tgz"; - sha256 = "0p80s474czfqh7phd4qq5yjcy8q2160vxmn8pi6qlkqgdd7ix37r"; - system = "trivial-package-local-nicknames"; - asd = "trivial-package-local-nicknames"; - }); - systems = [ "trivial-package-local-nicknames" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-package-locks = (build-asdf-system { - pname = "trivial-package-locks"; - version = "20241012-git"; - asds = [ "trivial-package-locks" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-package-locks/2024-10-12/trivial-package-locks-20241012-git.tgz"; - sha256 = "09zhirygjmwr4xvwp1zx9b17mkxml7f7rni1xiwxg5vfgn0y1bi3"; - system = "trivial-package-locks"; - asd = "trivial-package-locks"; - }); - systems = [ "trivial-package-locks" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-package-manager = (build-asdf-system { - pname = "trivial-package-manager"; - version = "20241012-git"; - asds = [ "trivial-package-manager" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-package-manager/2024-10-12/trivial-package-manager-20241012-git.tgz"; - sha256 = "1q71r9h5xra0bg5c5v2gzjjswfv626gfg9sxn59w645g30xn1sph"; - system = "trivial-package-manager"; - asd = "trivial-package-manager"; - }); - systems = [ "trivial-package-manager" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-features" self) (getAttr "trivial-open-browser" self) ]; - meta = {}; - }); - trivial-package-manager_dot_test = (build-asdf-system { - pname = "trivial-package-manager.test"; - version = "20241012-git"; - asds = [ "trivial-package-manager.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-package-manager/2024-10-12/trivial-package-manager-20241012-git.tgz"; - sha256 = "1q71r9h5xra0bg5c5v2gzjjswfv626gfg9sxn59w645g30xn1sph"; - system = "trivial-package-manager.test"; - asd = "trivial-package-manager.test"; - }); - systems = [ "trivial-package-manager.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "trivial-package-manager" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-pooled-database = (build-asdf-system { - pname = "trivial-pooled-database"; - version = "20201220-git"; - asds = [ "trivial-pooled-database" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-pooled-database/2020-12-20/trivial-pooled-database-20201220-git.tgz"; - sha256 = "0a7c8bjl13k37b83lksklcw9sch570wgqv58cgs0dw9jcmsihqmx"; - system = "trivial-pooled-database"; - asd = "trivial-pooled-database"; - }); - systems = [ "trivial-pooled-database" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-dbi" self) (getAttr "iterate" self) (getAttr "log4cl" self) (getAttr "parse-number" self) (getAttr "trivial-object-lock" self) (getAttr "trivial-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-project = (build-asdf-system { - pname = "trivial-project"; - version = "quicklisp-9e3fe231-git"; - asds = [ "trivial-project" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-project/2017-08-30/trivial-project-quicklisp-9e3fe231-git.tgz"; - sha256 = "1s5h0fgs0rq00j492xln716w9i52v90rnfcr0idjzyimicx7hk22"; - system = "trivial-project"; - asd = "trivial-project"; - }); - systems = [ "trivial-project" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-raw-io = (build-asdf-system { - pname = "trivial-raw-io"; - version = "20141217-git"; - asds = [ "trivial-raw-io" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-raw-io/2014-12-17/trivial-raw-io-20141217-git.tgz"; - sha256 = "19290zw2b64k78wr62gv30pp7cmqg07q85vfwjknaffjdd73xwi1"; - system = "trivial-raw-io"; - asd = "trivial-raw-io"; - }); - systems = [ "trivial-raw-io" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-renamer = (build-asdf-system { - pname = "trivial-renamer"; - version = "quicklisp-1282597d-git"; - asds = [ "trivial-renamer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-renamer/2017-08-30/trivial-renamer-quicklisp-1282597d-git.tgz"; - sha256 = "1nlgsayx4iw6gskg0d5vc823p0lmh414k9jiccvcsk1r17684mp8"; - system = "trivial-renamer"; - asd = "trivial-renamer"; - }); - systems = [ "trivial-renamer" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-rfc-1123 = (build-asdf-system { - pname = "trivial-rfc-1123"; - version = "20220707-git"; - asds = [ "trivial-rfc-1123" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-rfc-1123/2022-07-07/trivial-rfc-1123-20220707-git.tgz"; - sha256 = "1w4ywpj10fnp7cya62dzlxlg8nyk4lppn2pnmfixsndwr4ib1h6x"; - system = "trivial-rfc-1123"; - asd = "trivial-rfc-1123"; - }); - systems = [ "trivial-rfc-1123" ]; - lispLibs = [ (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-sanitize = (build-asdf-system { - pname = "trivial-sanitize"; - version = "20241012-git"; - asds = [ "trivial-sanitize" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-sanitize/2024-10-12/trivial-sanitize-20241012-git.tgz"; - sha256 = "18pc1diq0mfmr3ql79islv2mfm4y791vg9xwz3dwp8wa912dd93h"; - system = "trivial-sanitize"; - asd = "trivial-sanitize"; - }); - systems = [ "trivial-sanitize" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-html5-parser" self) (getAttr "cl-ppcre-unicode" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-sanitize-tests = (build-asdf-system { - pname = "trivial-sanitize-tests"; - version = "20241012-git"; - asds = [ "trivial-sanitize-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-sanitize/2024-10-12/trivial-sanitize-20241012-git.tgz"; - sha256 = "18pc1diq0mfmr3ql79islv2mfm4y791vg9xwz3dwp8wa912dd93h"; - system = "trivial-sanitize-tests"; - asd = "trivial-sanitize-tests"; - }); - systems = [ "trivial-sanitize-tests" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "clunit2" self) (getAttr "trivial-sanitize" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-shell = (build-asdf-system { - pname = "trivial-shell"; - version = "20241012-git"; - asds = [ "trivial-shell" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-shell/2024-10-12/trivial-shell-20241012-git.tgz"; - sha256 = "0cqfipcywi1ndl43walw7d54rd7layjq3wv2wpz5rlprv7dhpb2p"; - system = "trivial-shell"; - asd = "trivial-shell"; - }); - systems = [ "trivial-shell" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-shell-test = (build-asdf-system { - pname = "trivial-shell-test"; - version = "20241012-git"; - asds = [ "trivial-shell-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-shell/2024-10-12/trivial-shell-20241012-git.tgz"; - sha256 = "0cqfipcywi1ndl43walw7d54rd7layjq3wv2wpz5rlprv7dhpb2p"; - system = "trivial-shell-test"; - asd = "trivial-shell-test"; - }); - systems = [ "trivial-shell-test" ]; - lispLibs = [ (getAttr "lift" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-signal = (build-asdf-system { - pname = "trivial-signal"; - version = "20190710-git"; - asds = [ "trivial-signal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-signal/2019-07-10/trivial-signal-20190710-git.tgz"; - sha256 = "13rh1jwh786xg235rkgqbdqga4b9jwn99zlxm0wr73rs2a5ga8ad"; - system = "trivial-signal"; - asd = "trivial-signal"; - }); - systems = [ "trivial-signal" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-sockets = (build-asdf-system { - pname = "trivial-sockets"; - version = "20190107-git"; - asds = [ "trivial-sockets" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-sockets/2019-01-07/trivial-sockets-20190107-git.tgz"; - sha256 = "0xj9x5z3psxqap9c29qz1xswx5fiqxyzd35kmbw2g6z08cgb7nd0"; - system = "trivial-sockets"; - asd = "trivial-sockets"; - }); - systems = [ "trivial-sockets" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-ssh = (build-asdf-system { - pname = "trivial-ssh"; - version = "20191130-git"; - asds = [ "trivial-ssh" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-ssh/2019-11-30/trivial-ssh-20191130-git.tgz"; - sha256 = "1hjd8bhbymq4s2jglid5i9m2b19cnf6c793gvkh6mawcjd37vjmb"; - system = "trivial-ssh"; - asd = "trivial-ssh"; - }); - systems = [ "trivial-ssh" ]; - lispLibs = [ (getAttr "trivial-ssh-libssh2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-ssh-libssh2 = (build-asdf-system { - pname = "trivial-ssh-libssh2"; - version = "20191130-git"; - asds = [ "trivial-ssh-libssh2" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-ssh/2019-11-30/trivial-ssh-20191130-git.tgz"; - sha256 = "1hjd8bhbymq4s2jglid5i9m2b19cnf6c793gvkh6mawcjd37vjmb"; - system = "trivial-ssh-libssh2"; - asd = "trivial-ssh-libssh2"; - }); - systems = [ "trivial-ssh-libssh2" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-fad" self) (getAttr "split-sequence" self) (getAttr "trivial-gray-streams" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-ssh-test = (build-asdf-system { - pname = "trivial-ssh-test"; - version = "20191130-git"; - asds = [ "trivial-ssh-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-ssh/2019-11-30/trivial-ssh-20191130-git.tgz"; - sha256 = "1hjd8bhbymq4s2jglid5i9m2b19cnf6c793gvkh6mawcjd37vjmb"; - system = "trivial-ssh-test"; - asd = "trivial-ssh-test"; - }); - systems = [ "trivial-ssh-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "trivial-ssh" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-system-loader = (build-asdf-system { - pname = "trivial-system-loader"; - version = "20241012-git"; - asds = [ "trivial-system-loader" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-system-loader/2024-10-12/trivial-system-loader-20241012-git.tgz"; - sha256 = "094j50asfgyhqcm86p47azviivap0hni2gjp3khdxcn4f9i9d2b0"; - system = "trivial-system-loader"; - asd = "trivial-system-loader"; - }); - systems = [ "trivial-system-loader" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-tco = (build-asdf-system { - pname = "trivial-tco"; - version = "20131003-git"; - asds = [ "trivial-tco" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-tco/2013-10-03/trivial-tco-20131003-git.tgz"; - sha256 = "0j6mkchrk6bzkpdkrahagip9lxxr8rx3qj4547wg8bdqr7mm2nmi"; - system = "trivial-tco"; - asd = "trivial-tco"; - }); - systems = [ "trivial-tco" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-tco-test = (build-asdf-system { - pname = "trivial-tco-test"; - version = "20131003-git"; - asds = [ "trivial-tco-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-tco/2013-10-03/trivial-tco-20131003-git.tgz"; - sha256 = "0j6mkchrk6bzkpdkrahagip9lxxr8rx3qj4547wg8bdqr7mm2nmi"; - system = "trivial-tco-test"; - asd = "trivial-tco-test"; - }); - systems = [ "trivial-tco-test" ]; - lispLibs = [ (getAttr "clunit" self) (getAttr "trivial-tco" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-thumbnail = (build-asdf-system { - pname = "trivial-thumbnail"; - version = "20231021-git"; - asds = [ "trivial-thumbnail" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-thumbnail/2023-10-21/trivial-thumbnail-20231021-git.tgz"; - sha256 = "1asa8vg8cyfr0kl86xrpywk0cpqym9lzhkhxb829lqr49vr8zfa7"; - system = "trivial-thumbnail"; - asd = "trivial-thumbnail"; - }); - systems = [ "trivial-thumbnail" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-timeout = (build-asdf-system { - pname = "trivial-timeout"; - version = "20231021-git"; - asds = [ "trivial-timeout" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-timeout/2023-10-21/trivial-timeout-20231021-git.tgz"; - sha256 = "0s8z9aj6b3kv21yiyk13cjylzf5zlnw9v86vcff477m1gk9yddjs"; - system = "trivial-timeout"; - asd = "trivial-timeout"; - }); - systems = [ "trivial-timeout" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-timer = (build-asdf-system { - pname = "trivial-timer"; - version = "20210531-git"; - asds = [ "trivial-timer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-timer/2021-05-31/trivial-timer-20210531-git.tgz"; - sha256 = "1b8pnw613h1dngzmv3qglmfrl1jdjbxrsbqnh7rfdj0lnv43h1il"; - system = "trivial-timer"; - asd = "trivial-timer"; - }); - systems = [ "trivial-timer" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "chanl" self) (getAttr "iterate" self) (getAttr "log4cl" self) (getAttr "trivial-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-toplevel-commands = (build-asdf-system { - pname = "trivial-toplevel-commands"; - version = "20241012-git"; - asds = [ "trivial-toplevel-commands" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-toplevel-commands/2024-10-12/trivial-toplevel-commands-20241012-git.tgz"; - sha256 = "03n0dpzgdgghc7cxj1s19w2wlx6r8f1s983f5a6cix5rigx9r834"; - system = "trivial-toplevel-commands"; - asd = "trivial-toplevel-commands"; - }); - systems = [ "trivial-toplevel-commands" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-toplevel-prompt = (build-asdf-system { - pname = "trivial-toplevel-prompt"; - version = "20241012-git"; - asds = [ "trivial-toplevel-prompt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-toplevel-prompt/2024-10-12/trivial-toplevel-prompt-20241012-git.tgz"; - sha256 = "07gvazwqiw37sic9zz8qnl3gz0b8n4qzrwbmg4wy3rlkps98i4s2"; - system = "trivial-toplevel-prompt"; - asd = "trivial-toplevel-prompt"; - }); - systems = [ "trivial-toplevel-prompt" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-types = (build-asdf-system { - pname = "trivial-types"; - version = "20120407-git"; - asds = [ "trivial-types" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-types/2012-04-07/trivial-types-20120407-git.tgz"; - sha256 = "1s4cp9bdlbn8447q7w7f1wkgwrbvfzp20mgs307l5pxvdslin341"; - system = "trivial-types"; - asd = "trivial-types"; - }); - systems = [ "trivial-types" ]; - lispLibs = [ ]; - meta = {}; - }); - trivial-update = (build-asdf-system { - pname = "trivial-update"; - version = "20180131-git"; - asds = [ "trivial-update" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-update/2018-01-31/trivial-update-20180131-git.tgz"; - sha256 = "0dpijh9alljk0jmnkp37hfliylscs7xwvlmjkfshizmyh0qjjxir"; - system = "trivial-update"; - asd = "trivial-update"; - }); - systems = [ "trivial-update" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-utf-8 = (build-asdf-system { - pname = "trivial-utf-8"; - version = "20231021-git"; - asds = [ "trivial-utf-8" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-utf-8/2023-10-21/trivial-utf-8-20231021-git.tgz"; - sha256 = "0paf7ldw6ffl5xilyri3rfygz1v1npagf186i1z8hyxxjkri4q9s"; - system = "trivial-utf-8"; - asd = "trivial-utf-8"; - }); - systems = [ "trivial-utf-8" ]; - lispLibs = [ (getAttr "mgl-pax-bootstrap" self) ]; - meta = {}; - }); - trivial-utilities = (build-asdf-system { - pname = "trivial-utilities"; - version = "20220707-git"; - asds = [ "trivial-utilities" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-utilities/2022-07-07/trivial-utilities-20220707-git.tgz"; - sha256 = "0k1xmn5f5dik7scadw0vyy67mik4ypnfqbhlv2vsg9afxzbpx2dz"; - system = "trivial-utilities"; - asd = "trivial-utilities"; - }); - systems = [ "trivial-utilities" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-variable-bindings = (build-asdf-system { - pname = "trivial-variable-bindings"; - version = "20191007-git"; - asds = [ "trivial-variable-bindings" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-variable-bindings/2019-10-07/trivial-variable-bindings-20191007-git.tgz"; - sha256 = "08lx5m1bspxsnv572zma1hxk3yfyk9fkmi5cvcr5riannyimdqgy"; - system = "trivial-variable-bindings"; - asd = "trivial-variable-bindings"; - }); - systems = [ "trivial-variable-bindings" ]; - lispLibs = [ (getAttr "iterate" self) (getAttr "trivial-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-wish = (build-asdf-system { - pname = "trivial-wish"; - version = "quicklisp-910afeea-git"; - asds = [ "trivial-wish" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-wish/2017-06-30/trivial-wish-quicklisp-910afeea-git.tgz"; - sha256 = "1ydb9vsanrv6slbddhxc38pq5s88k0rzgqnwabw5cgc8cp5gqvyp"; - system = "trivial-wish"; - asd = "trivial-wish"; - }); - systems = [ "trivial-wish" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-with = (build-asdf-system { - pname = "trivial-with"; - version = "quicklisp-2fd8ca54-git"; - asds = [ "trivial-with" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-with/2017-08-30/trivial-with-quicklisp-2fd8ca54-git.tgz"; - sha256 = "1h880j9k7piq6y5a6sywn1r43h439dd6vfymqvhgnbx458wy69sq"; - system = "trivial-with"; - asd = "trivial-with"; - }); - systems = [ "trivial-with" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-with-current-source-form = (build-asdf-system { - pname = "trivial-with-current-source-form"; - version = "20230618-git"; - asds = [ "trivial-with-current-source-form" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-with-current-source-form/2023-06-18/trivial-with-current-source-form-20230618-git.tgz"; - sha256 = "1856m234mcg8l0p63h0j76isx8n2iji569b4r4zf7qs135xbw930"; - system = "trivial-with-current-source-form"; - asd = "trivial-with-current-source-form"; - }); - systems = [ "trivial-with-current-source-form" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = {}; - }); - trivial-ws = (build-asdf-system { - pname = "trivial-ws"; - version = "20180131-git"; - asds = [ "trivial-ws" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-ws/2018-01-31/trivial-ws-20180131-git.tgz"; - sha256 = "0qmsf0dhmyhjgqjzdgj2yb1nkrijwp4p1j411613i45xjc2zd6m7"; - system = "trivial-ws"; - asd = "trivial-ws"; - }); - systems = [ "trivial-ws" ]; - lispLibs = [ (getAttr "hunchensocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-ws-client = (build-asdf-system { - pname = "trivial-ws-client"; - version = "20180131-git"; - asds = [ "trivial-ws-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-ws/2018-01-31/trivial-ws-20180131-git.tgz"; - sha256 = "0qmsf0dhmyhjgqjzdgj2yb1nkrijwp4p1j411613i45xjc2zd6m7"; - system = "trivial-ws-client"; - asd = "trivial-ws-client"; - }); - systems = [ "trivial-ws-client" ]; - lispLibs = [ (getAttr "cl-async" self) (getAttr "websocket-driver" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-ws-test = (build-asdf-system { - pname = "trivial-ws-test"; - version = "20180131-git"; - asds = [ "trivial-ws-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-ws/2018-01-31/trivial-ws-20180131-git.tgz"; - sha256 = "0qmsf0dhmyhjgqjzdgj2yb1nkrijwp4p1j411613i45xjc2zd6m7"; - system = "trivial-ws-test"; - asd = "trivial-ws-test"; - }); - systems = [ "trivial-ws-test" ]; - lispLibs = [ (getAttr "find-port" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "trivial-ws" self) (getAttr "trivial-ws-client" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivial-yenc = (build-asdf-system { - pname = "trivial-yenc"; - version = "20161204-git"; - asds = [ "trivial-yenc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivial-yenc/2016-12-04/trivial-yenc-20161204-git.tgz"; - sha256 = "0jsqwixgikdinc1rq22c4dh9kgg6z0kvw9rh9sbssbmxv99sb5bf"; - system = "trivial-yenc"; - asd = "trivial-yenc"; - }); - systems = [ "trivial-yenc" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivialib_dot_bdd = (build-asdf-system { - pname = "trivialib.bdd"; - version = "20211209-git"; - asds = [ "trivialib.bdd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivialib.bdd/2021-12-09/trivialib.bdd-20211209-git.tgz"; - sha256 = "1iqpcihpm6glr0afi35z6qifj0ppl7s4h1k94fn6lqpv2js6lzbr"; - system = "trivialib.bdd"; - asd = "trivialib.bdd"; - }); - systems = [ "trivialib.bdd" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "immutable-struct" self) (getAttr "trivia" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivialib_dot_bdd_dot_test = (build-asdf-system { - pname = "trivialib.bdd.test"; - version = "20211209-git"; - asds = [ "trivialib.bdd.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivialib.bdd/2021-12-09/trivialib.bdd-20211209-git.tgz"; - sha256 = "1iqpcihpm6glr0afi35z6qifj0ppl7s4h1k94fn6lqpv2js6lzbr"; - system = "trivialib.bdd.test"; - asd = "trivialib.bdd.test"; - }); - systems = [ "trivialib.bdd.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "trivialib_dot_bdd" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivialib_dot_type-unify = (build-asdf-system { - pname = "trivialib.type-unify"; - version = "20200325-git"; - asds = [ "trivialib.type-unify" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivialib.type-unify/2020-03-25/trivialib.type-unify-20200325-git.tgz"; - sha256 = "0b5ck9ldn1w3imgpxyh164bypy28kvjzkwlcyyfsc0h1njnm5jmy"; - system = "trivialib.type-unify"; - asd = "trivialib.type-unify"; - }); - systems = [ "trivialib.type-unify" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "introspect-environment" self) (getAttr "trivia" self) (getAttr "type-r" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trivialib_dot_type-unify_dot_test = (build-asdf-system { - pname = "trivialib.type-unify.test"; - version = "20200325-git"; - asds = [ "trivialib.type-unify.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trivialib.type-unify/2020-03-25/trivialib.type-unify-20200325-git.tgz"; - sha256 = "0b5ck9ldn1w3imgpxyh164bypy28kvjzkwlcyyfsc0h1njnm5jmy"; - system = "trivialib.type-unify.test"; - asd = "trivialib.type-unify.test"; - }); - systems = [ "trivialib.type-unify.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "trivialib_dot_type-unify" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trucler = (build-asdf-system { - pname = "trucler"; - version = "20231021-git"; - asds = [ "trucler" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trucler/2023-10-21/trucler-20231021-git.tgz"; - sha256 = "16cxx9pgpn3bkrmazc4lqhmaf20c0rhp1vaj78ms8ldwfqqrgznr"; - system = "trucler"; - asd = "trucler"; - }); - systems = [ "trucler" ]; - lispLibs = [ (getAttr "trucler-base" self) (getAttr "trucler-native" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trucler-base = (build-asdf-system { - pname = "trucler-base"; - version = "20231021-git"; - asds = [ "trucler-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trucler/2023-10-21/trucler-20231021-git.tgz"; - sha256 = "16cxx9pgpn3bkrmazc4lqhmaf20c0rhp1vaj78ms8ldwfqqrgznr"; - system = "trucler-base"; - asd = "trucler-base"; - }); - systems = [ "trucler-base" ]; - lispLibs = [ (getAttr "acclimation" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trucler-native = (build-asdf-system { - pname = "trucler-native"; - version = "20231021-git"; - asds = [ "trucler-native" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trucler/2023-10-21/trucler-20231021-git.tgz"; - sha256 = "16cxx9pgpn3bkrmazc4lqhmaf20c0rhp1vaj78ms8ldwfqqrgznr"; - system = "trucler-native"; - asd = "trucler-native"; - }); - systems = [ "trucler-native" ]; - lispLibs = [ (getAttr "trucler-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trucler-native-test = (build-asdf-system { - pname = "trucler-native-test"; - version = "20231021-git"; - asds = [ "trucler-native-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trucler/2023-10-21/trucler-20231021-git.tgz"; - sha256 = "16cxx9pgpn3bkrmazc4lqhmaf20c0rhp1vaj78ms8ldwfqqrgznr"; - system = "trucler-native-test"; - asd = "trucler-native-test"; - }); - systems = [ "trucler-native-test" ]; - lispLibs = [ (getAttr "trucler-base" self) (getAttr "trucler-native" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - trucler-reference = (build-asdf-system { - pname = "trucler-reference"; - version = "20231021-git"; - asds = [ "trucler-reference" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/trucler/2023-10-21/trucler-20231021-git.tgz"; - sha256 = "16cxx9pgpn3bkrmazc4lqhmaf20c0rhp1vaj78ms8ldwfqqrgznr"; - system = "trucler-reference"; - asd = "trucler-reference"; - }); - systems = [ "trucler-reference" ]; - lispLibs = [ (getAttr "trucler-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - truetype-clx = (build-asdf-system { - pname = "truetype-clx"; - version = "20200218-git"; - asds = [ "truetype-clx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/truetype-clx/2020-02-18/truetype-clx-20200218-git.tgz"; - sha256 = "1k46xa0nclj0mpd7khnlpam6q5hgnp23jixryhvv96gx47swhddr"; - system = "truetype-clx"; - asd = "truetype-clx"; - }); - systems = [ "truetype-clx" ]; - lispLibs = [ (getAttr "cl-aa" self) (getAttr "cl-paths-ttf" self) (getAttr "cl-vectors" self) (getAttr "zpb-ttf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - try = (build-asdf-system { - pname = "try"; - version = "20231021-git"; - asds = [ "try" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/try/2023-10-21/try-20231021-git.tgz"; - sha256 = "166i3fqwxfv9skz6yf95c95nx0jjqy1ak1131bd0sqmd582gi9mg"; - system = "try"; - asd = "try"; - }); - systems = [ "try" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "ieee-floats" self) (getAttr "mgl-pax" self) (getAttr "trivial-gray-streams" self) (getAttr "try_dot_asdf" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - try_dot_asdf = (build-asdf-system { - pname = "try.asdf"; - version = "20231021-git"; - asds = [ "try.asdf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/try/2023-10-21/try-20231021-git.tgz"; - sha256 = "166i3fqwxfv9skz6yf95c95nx0jjqy1ak1131bd0sqmd582gi9mg"; - system = "try.asdf"; - asd = "try.asdf"; - }); - systems = [ "try.asdf" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - tsqueue = (build-asdf-system { - pname = "tsqueue"; - version = "20221106-git"; - asds = [ "tsqueue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/tsqueue/2022-11-06/tsqueue-20221106-git.tgz"; - sha256 = "1ifq53b95a1sdpgx1hlz31pjbh0z6izh3wrgsiqvzgkbiyxq513q"; - system = "tsqueue"; - asd = "tsqueue"; - }); - systems = [ "tsqueue" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ttt = (build-asdf-system { - pname = "ttt"; - version = "20220707-git"; - asds = [ "ttt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ttt/2022-07-07/ttt-20220707-git.tgz"; - sha256 = "0g6p8gpl8hl427mfrrf8824zq6wmkj11v1xq7pyv7v0b5cwp5ccv"; - system = "ttt"; - asd = "ttt"; - }); - systems = [ "ttt" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - twfy = (build-asdf-system { - pname = "twfy"; - version = "20130420-git"; - asds = [ "twfy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/twfy/2013-04-20/twfy-20130420-git.tgz"; - sha256 = "1srns5ayg7q8dzviizgm7j767dxbbyzh2ca8a5wdz3bc0qmwrsbs"; - system = "twfy"; - asd = "twfy"; - }); - systems = [ "twfy" ]; - lispLibs = [ (getAttr "cl-json" self) (getAttr "drakma" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - twitter-mongodb-driver = (build-asdf-system { - pname = "twitter-mongodb-driver"; - version = "20180228-git"; - asds = [ "twitter-mongodb-driver" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-twitter/2018-02-28/cl-twitter-20180228-git.tgz"; - sha256 = "07l86c63ssahpz3s9f7d99mbzmh60askkpdrhjrdbzd1vxlwkhcr"; - system = "twitter-mongodb-driver"; - asd = "twitter-mongodb-driver"; - }); - systems = [ "twitter-mongodb-driver" ]; - lispLibs = [ (getAttr "cl-mongo" self) (getAttr "cl-twitter" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - type-i = (build-asdf-system { - pname = "type-i"; - version = "20230214-git"; - asds = [ "type-i" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/type-i/2023-02-14/type-i-20230214-git.tgz"; - sha256 = "1y9dh1iziv3gwpf5yls0amwjhdqjidfibcla04mz6dqdv3zrg3hs"; - system = "type-i"; - asd = "type-i"; - }); - systems = [ "type-i" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "introspect-environment" self) (getAttr "lisp-namespace" self) (getAttr "trivia_dot_trivial" self) ]; - meta = {}; - }); - type-i_dot_test = (build-asdf-system { - pname = "type-i.test"; - version = "20230214-git"; - asds = [ "type-i.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/type-i/2023-02-14/type-i-20230214-git.tgz"; - sha256 = "1y9dh1iziv3gwpf5yls0amwjhdqjidfibcla04mz6dqdv3zrg3hs"; - system = "type-i.test"; - asd = "type-i.test"; - }); - systems = [ "type-i.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "type-i" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - type-r = (build-asdf-system { - pname = "type-r"; - version = "20191227-git"; - asds = [ "type-r" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/type-r/2019-12-27/type-r-20191227-git.tgz"; - sha256 = "1arsxc2539rg8vbrdirz4xxj1b06mc6g6rqndz7a02g127qvk2sm"; - system = "type-r"; - asd = "type-r"; - }); - systems = [ "type-r" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - type-r_dot_test = (build-asdf-system { - pname = "type-r.test"; - version = "20191227-git"; - asds = [ "type-r.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/type-r/2019-12-27/type-r-20191227-git.tgz"; - sha256 = "1arsxc2539rg8vbrdirz4xxj1b06mc6g6rqndz7a02g127qvk2sm"; - system = "type-r.test"; - asd = "type-r.test"; - }); - systems = [ "type-r.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "type-r" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - type-templates = (build-asdf-system { - pname = "type-templates"; - version = "20241012-git"; - asds = [ "type-templates" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/type-templates/2024-10-12/type-templates-20241012-git.tgz"; - sha256 = "1zmz3bmwg8ncqbnjwimn8n7q9ik9arnhd5ijd22ap1nwhbnmk1rj"; - system = "type-templates"; - asd = "type-templates"; - }); - systems = [ "type-templates" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "documentation-utils" self) (getAttr "form-fiddle" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - typo = (build-asdf-system { - pname = "typo"; - version = "20241012-git"; - asds = [ "typo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/typo/2024-10-12/typo-20241012-git.tgz"; - sha256 = "1xgrfj1yxay04zf1ppf56b4j5p1wn67zfhiwpfd30dvk53mcrlik"; - system = "typo"; - asd = "typo"; - }); - systems = [ "typo" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "introspect-environment" self) (getAttr "trivia" self) (getAttr "trivial-arguments" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - typo_dot_test-suite = (build-asdf-system { - pname = "typo.test-suite"; - version = "20241012-git"; - asds = [ "typo.test-suite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/typo/2024-10-12/typo-20241012-git.tgz"; - sha256 = "1xgrfj1yxay04zf1ppf56b4j5p1wn67zfhiwpfd30dvk53mcrlik"; - system = "typo.test-suite"; - asd = "typo.test-suite"; - }); - systems = [ "typo.test-suite" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "typo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - uax-14 = (build-asdf-system { - pname = "uax-14"; - version = "20231021-git"; - asds = [ "uax-14" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uax-14/2023-10-21/uax-14-20231021-git.tgz"; - sha256 = "1k9cqs9lb5i2y9b3zgrr1kq2w8bcr3h362105ykz0if5yz8m59fq"; - system = "uax-14"; - asd = "uax-14"; - }); - systems = [ "uax-14" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - uax-14-test = (build-asdf-system { - pname = "uax-14-test"; - version = "20231021-git"; - asds = [ "uax-14-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uax-14/2023-10-21/uax-14-20231021-git.tgz"; - sha256 = "1k9cqs9lb5i2y9b3zgrr1kq2w8bcr3h362105ykz0if5yz8m59fq"; - system = "uax-14-test"; - asd = "uax-14-test"; - }); - systems = [ "uax-14-test" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "parachute" self) (getAttr "uax-14" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - uax-15 = (build-asdf-system { - pname = "uax-15"; - version = "20241012-git"; - asds = [ "uax-15" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uax-15/2024-10-12/uax-15-20241012-git.tgz"; - sha256 = "12qkq4r6qv5cn535bwpkq7zfahajlrv8v7661x4wzf4pp0avx7n6"; - system = "uax-15"; - asd = "uax-15"; - }); - systems = [ "uax-15" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "split-sequence" self) ]; - meta = {}; - }); - uax-9 = (build-asdf-system { - pname = "uax-9"; - version = "20231021-git"; - asds = [ "uax-9" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uax-9/2023-10-21/uax-9-20231021-git.tgz"; - sha256 = "1kbq8v45pxhmwqn6is5lfsp51h80kns4s1cqbh9z0xdmxzw63ip1"; - system = "uax-9"; - asd = "uax-9"; - }); - systems = [ "uax-9" ]; - lispLibs = [ (getAttr "documentation-utils" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - uax-9-test = (build-asdf-system { - pname = "uax-9-test"; - version = "20231021-git"; - asds = [ "uax-9-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uax-9/2023-10-21/uax-9-20231021-git.tgz"; - sha256 = "1kbq8v45pxhmwqn6is5lfsp51h80kns4s1cqbh9z0xdmxzw63ip1"; - system = "uax-9-test"; - asd = "uax-9-test"; - }); - systems = [ "uax-9-test" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "parachute" self) (getAttr "uax-9" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ubiquitous = (build-asdf-system { - pname = "ubiquitous"; - version = "20231021-git"; - asds = [ "ubiquitous" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ubiquitous/2023-10-21/ubiquitous-20231021-git.tgz"; - sha256 = "02q6yz9j374q23avi06lddy6gkzza0xn3855n7dqgy34fv1shw1i"; - system = "ubiquitous"; - asd = "ubiquitous"; - }); - systems = [ "ubiquitous" ]; - lispLibs = [ ]; - meta = { - broken = true; - hydraPlatforms = [ ]; - }; - }); - ubiquitous-concurrent = (build-asdf-system { - pname = "ubiquitous-concurrent"; - version = "20231021-git"; - asds = [ "ubiquitous-concurrent" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ubiquitous/2023-10-21/ubiquitous-20231021-git.tgz"; - sha256 = "02q6yz9j374q23avi06lddy6gkzza0xn3855n7dqgy34fv1shw1i"; - system = "ubiquitous-concurrent"; - asd = "ubiquitous-concurrent"; - }); - systems = [ "ubiquitous-concurrent" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "ubiquitous" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ucons = (build-asdf-system { - pname = "ucons"; - version = "20230618-git"; - asds = [ "ucons" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ucons/2023-06-18/ucons-20230618-git.tgz"; - sha256 = "0pisf8sswh1wainabpnczla8c98kr0lv0qvh0zapwkf1lq1drzp1"; - system = "ucons"; - asd = "ucons"; - }); - systems = [ "ucons" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "atomics" self) (getAttr "bordeaux-threads" self) (getAttr "named-readtables" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ucw = (build-asdf-system { - pname = "ucw"; - version = "20160208-darcs"; - asds = [ "ucw" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ucw/2016-02-08/ucw-20160208-darcs.tgz"; - sha256 = "0wd7816zr53bw9z9a48cx1khj15d1jii5wzgqns1c5x70brgy89z"; - system = "ucw"; - asd = "ucw"; - }); - systems = [ "ucw" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "ucw-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ucw-core = (build-asdf-system { - pname = "ucw-core"; - version = "20160208-darcs"; - asds = [ "ucw-core" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ucw/2016-02-08/ucw-20160208-darcs.tgz"; - sha256 = "0wd7816zr53bw9z9a48cx1khj15d1jii5wzgqns1c5x70brgy89z"; - system = "ucw-core"; - asd = "ucw-core"; - }); - systems = [ "ucw-core" ]; - lispLibs = [ (getAttr "arnesi" self) (getAttr "bordeaux-threads" self) (getAttr "cl-fad" self) (getAttr "closer-mop" self) (getAttr "iterate" self) (getAttr "local-time" self) (getAttr "net-telent-date" self) (getAttr "rfc2109" self) (getAttr "swank" self) (getAttr "trivial-garbage" self) (getAttr "usocket" self) (getAttr "yaclml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ucw-core_dot_test = (build-asdf-system { - pname = "ucw-core.test"; - version = "20160208-darcs"; - asds = [ "ucw-core.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ucw/2016-02-08/ucw-20160208-darcs.tgz"; - sha256 = "0wd7816zr53bw9z9a48cx1khj15d1jii5wzgqns1c5x70brgy89z"; - system = "ucw-core.test"; - asd = "ucw-core"; - }); - systems = [ "ucw-core.test" ]; - lispLibs = [ (getAttr "arnesi" self) (getAttr "cxml" self) (getAttr "drakma" self) (getAttr "iterate" self) (getAttr "stefil" self) (getAttr "ucw-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ucw_dot_examples = (build-asdf-system { - pname = "ucw.examples"; - version = "20160208-darcs"; - asds = [ "ucw.examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ucw/2016-02-08/ucw-20160208-darcs.tgz"; - sha256 = "0wd7816zr53bw9z9a48cx1khj15d1jii5wzgqns1c5x70brgy89z"; - system = "ucw.examples"; - asd = "ucw"; - }); - systems = [ "ucw.examples" ]; - lispLibs = [ (getAttr "ucw" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ucw_dot_httpd = (build-asdf-system { - pname = "ucw.httpd"; - version = "20160208-darcs"; - asds = [ "ucw.httpd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ucw/2016-02-08/ucw-20160208-darcs.tgz"; - sha256 = "0wd7816zr53bw9z9a48cx1khj15d1jii5wzgqns1c5x70brgy89z"; - system = "ucw.httpd"; - asd = "ucw-core"; - }); - systems = [ "ucw.httpd" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "puri" self) (getAttr "rfc2388-binary" self) (getAttr "ucw-core" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ucw_dot_manual-examples = (build-asdf-system { - pname = "ucw.manual-examples"; - version = "20160208-darcs"; - asds = [ "ucw.manual-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ucw/2016-02-08/ucw-20160208-darcs.tgz"; - sha256 = "0wd7816zr53bw9z9a48cx1khj15d1jii5wzgqns1c5x70brgy89z"; - system = "ucw.manual-examples"; - asd = "ucw"; - }); - systems = [ "ucw.manual-examples" ]; - lispLibs = [ (getAttr "ucw" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - uffi = (build-asdf-system { - pname = "uffi"; - version = "20180228-git"; - asds = [ "uffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uffi/2018-02-28/uffi-20180228-git.tgz"; - sha256 = "0ywly04k8vir39ld7ids80yjn34y3y3mlpky1pr1fh9p8q412a85"; - system = "uffi"; - asd = "uffi"; - }); - systems = [ "uffi" ]; - lispLibs = [ ]; - meta = {}; - }); - uffi-tests = (build-asdf-system { - pname = "uffi-tests"; - version = "20180228-git"; - asds = [ "uffi-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uffi/2018-02-28/uffi-20180228-git.tgz"; - sha256 = "0ywly04k8vir39ld7ids80yjn34y3y3mlpky1pr1fh9p8q412a85"; - system = "uffi-tests"; - asd = "uffi-tests"; - }); - systems = [ "uffi-tests" ]; - lispLibs = [ (getAttr "uffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ufo = (build-asdf-system { - pname = "ufo"; - version = "20210807-git"; - asds = [ "ufo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ufo/2021-08-07/ufo-20210807-git.tgz"; - sha256 = "0bbq4pjnbmf1zpmh11jlriv0qnvrhw1xxnjj2y35gk75rr8rvizy"; - system = "ufo"; - asd = "ufo"; - }); - systems = [ "ufo" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ufo-test = (build-asdf-system { - pname = "ufo-test"; - version = "20210807-git"; - asds = [ "ufo-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ufo/2021-08-07/ufo-20210807-git.tgz"; - sha256 = "0bbq4pjnbmf1zpmh11jlriv0qnvrhw1xxnjj2y35gk75rr8rvizy"; - system = "ufo-test"; - asd = "ufo-test"; - }); - systems = [ "ufo-test" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "ufo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ugly-tiny-infix-macro = (build-asdf-system { - pname = "ugly-tiny-infix-macro"; - version = "20160825-git"; - asds = [ "ugly-tiny-infix-macro" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ugly-tiny-infix-macro/2016-08-25/ugly-tiny-infix-macro-20160825-git.tgz"; - sha256 = "15bbnr3kzy3p35skm6bkyyl5ck4d264am0zyjsix5k58d9fli3ii"; - system = "ugly-tiny-infix-macro"; - asd = "ugly-tiny-infix-macro"; - }); - systems = [ "ugly-tiny-infix-macro" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - umbra = (build-asdf-system { - pname = "umbra"; - version = "20220707-git"; - asds = [ "umbra" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/umbra/2022-07-07/umbra-20220707-git.tgz"; - sha256 = "125bsf69gzdy0r6jh6fz8000rqww1rji354x0yrgmkz9x3mvz4k4"; - system = "umbra"; - asd = "umbra"; - }); - systems = [ "umbra" ]; - lispLibs = [ (getAttr "mfiano-utils" self) (getAttr "shadow" self) (getAttr "varjo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - umlisp = (build-asdf-system { - pname = "umlisp"; - version = "20210411-git"; - asds = [ "umlisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/umlisp/2021-04-11/umlisp-20210411-git.tgz"; - sha256 = "1yyyn1qka4iw3hwii7i8k939dbwvhn543m8qclk2ajggkdky4mqb"; - system = "umlisp"; - asd = "umlisp"; - }); - systems = [ "umlisp" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "clsql-mysql" self) (getAttr "hyperobject" self) (getAttr "kmrcl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - umlisp-orf = (build-asdf-system { - pname = "umlisp-orf"; - version = "20150923-git"; - asds = [ "umlisp-orf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/umlisp-orf/2015-09-23/umlisp-orf-20150923-git.tgz"; - sha256 = "187i9rcj3rymi8hmlvglvig7yqandzzx57x0rzr4yfv8sgnb82qx"; - system = "umlisp-orf"; - asd = "umlisp-orf"; - }); - systems = [ "umlisp-orf" ]; - lispLibs = [ (getAttr "clsql" self) (getAttr "clsql-postgresql-socket" self) (getAttr "hyperobject" self) (getAttr "kmrcl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - umlisp-tests = (build-asdf-system { - pname = "umlisp-tests"; - version = "20210411-git"; - asds = [ "umlisp-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/umlisp/2021-04-11/umlisp-20210411-git.tgz"; - sha256 = "1yyyn1qka4iw3hwii7i8k939dbwvhn543m8qclk2ajggkdky4mqb"; - system = "umlisp-tests"; - asd = "umlisp-tests"; - }); - systems = [ "umlisp-tests" ]; - lispLibs = [ (getAttr "rt" self) (getAttr "umlisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - unboxables = (build-asdf-system { - pname = "unboxables"; - version = "20231021-git"; - asds = [ "unboxables" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/unboxables/2023-10-21/unboxables-20231021-git.tgz"; - sha256 = "099qcsc9q9q5cz2qlvkylc2g8g80fqzrxyq4lc072bmw96wy27fs"; - system = "unboxables"; - asd = "unboxables"; - }); - systems = [ "unboxables" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - uncommon-lisp = (build-asdf-system { - pname = "uncommon-lisp"; - version = "20200427-git"; - asds = [ "uncommon-lisp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "uncommon-lisp"; - asd = "uncommon-lisp"; - }); - systems = [ "uncommon-lisp" ]; - lispLibs = [ (getAttr "structy-defclass" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - uncursed = (build-asdf-system { - pname = "uncursed"; - version = "20220220-git"; - asds = [ "uncursed" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uncursed/2022-02-20/uncursed-20220220-git.tgz"; - sha256 = "1hydiwh12851rrm12y0a6pb2jml2cjdk8wxvz4c00d2xwraqc6mr"; - system = "uncursed"; - asd = "uncursed"; - }); - systems = [ "uncursed" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl-setlocale" self) (getAttr "terminfo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - uncursed-examples = (build-asdf-system { - pname = "uncursed-examples"; - version = "20220220-git"; - asds = [ "uncursed-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uncursed/2022-02-20/uncursed-20220220-git.tgz"; - sha256 = "1hydiwh12851rrm12y0a6pb2jml2cjdk8wxvz4c00d2xwraqc6mr"; - system = "uncursed-examples"; - asd = "uncursed-examples"; - }); - systems = [ "uncursed-examples" ]; - lispLibs = [ (getAttr "cffi-grovel" self) (getAttr "uncursed" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - unifgram = (build-asdf-system { - pname = "unifgram"; - version = "20180228-git"; - asds = [ "unifgram" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/paiprolog/2018-02-28/paiprolog-20180228-git.tgz"; - sha256 = "1nxz01i6f8s920gm69r2kwjdpq9pli8b2ayqwijhzgjwi0r4jj9r"; - system = "unifgram"; - asd = "unifgram"; - }); - systems = [ "unifgram" ]; - lispLibs = [ (getAttr "paiprolog" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - unit-formulas = (build-asdf-system { - pname = "unit-formulas"; - version = "20180711-git"; - asds = [ "unit-formulas" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/unit-formula/2018-07-11/unit-formula-20180711-git.tgz"; - sha256 = "1j9zcnyj2ik7f2130pkfwr2bhh5ldlgc83n1024w0dy95ksl1f20"; - system = "unit-formulas"; - asd = "unit-formulas"; - }); - systems = [ "unit-formulas" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - unit-test = (build-asdf-system { - pname = "unit-test"; - version = "20120520-git"; - asds = [ "unit-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/unit-test/2012-05-20/unit-test-20120520-git.tgz"; - sha256 = "11hpksz56iqkv7jw25p2a8r3n9dj922fyarn16d98589g6hdskj9"; - system = "unit-test"; - asd = "unit-test"; - }); - systems = [ "unit-test" ]; - lispLibs = [ ]; - meta = {}; - }); - universal-config = (build-asdf-system { - pname = "universal-config"; - version = "20180430-git"; - asds = [ "universal-config" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/universal-config/2018-04-30/universal-config-20180430-git.tgz"; - sha256 = "17sjd37jwsi47yhsj9qsnfyhyrlhlxdrxa4szklwjh489hf01hd0"; - system = "universal-config"; - asd = "universal-config"; - }); - systems = [ "universal-config" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "parse-float" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - unix-options = (build-asdf-system { - pname = "unix-options"; - version = "20151031-git"; - asds = [ "unix-options" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/unix-options/2015-10-31/unix-options-20151031-git.tgz"; - sha256 = "17q7irrbmaja7gj86h01ali9n9p782jxisgkb1r2q5ajf4lr1rsv"; - system = "unix-options"; - asd = "unix-options"; - }); - systems = [ "unix-options" ]; - lispLibs = [ ]; - meta = {}; - }); - unix-opts = (build-asdf-system { - pname = "unix-opts"; - version = "20210124-git"; - asds = [ "unix-opts" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/unix-opts/2021-01-24/unix-opts-20210124-git.tgz"; - sha256 = "16mcqpzwrz808p9n3wwl99ckg3hg7yihw08y1i4l7c92aldbkasq"; - system = "unix-opts"; - asd = "unix-opts"; - }); - systems = [ "unix-opts" ]; - lispLibs = [ ]; - meta = {}; - }); - unix-sockets = (build-asdf-system { - pname = "unix-sockets"; - version = "20241012-git"; - asds = [ "unix-sockets" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-unix-sockets/2024-10-12/cl-unix-sockets-20241012-git.tgz"; - sha256 = "09l3032p3gavyin1hn45yqv6b3vrg74vzcz85ppqg4nzpmp44845"; - system = "unix-sockets"; - asd = "unix-sockets"; - }); - systems = [ "unix-sockets" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "flexi-streams" self) (getAttr "log4cl" self) (getAttr "trivial-garbage" self) (getAttr "trivial-gray-streams" self) (getAttr "uffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - unix-sockets_dot_tests = (build-asdf-system { - pname = "unix-sockets.tests"; - version = "20241012-git"; - asds = [ "unix-sockets.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-unix-sockets/2024-10-12/cl-unix-sockets-20241012-git.tgz"; - sha256 = "09l3032p3gavyin1hn45yqv6b3vrg74vzcz85ppqg4nzpmp44845"; - system = "unix-sockets.tests"; - asd = "unix-sockets.tests"; - }); - systems = [ "unix-sockets.tests" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "fiveam" self) (getAttr "tmpdir" self) (getAttr "trivial-timeout" self) (getAttr "unix-sockets" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - uri-template = (build-asdf-system { - pname = "uri-template"; - version = "1.3.1"; - asds = [ "uri-template" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uri-template/2019-08-13/uri-template-1.3.1.tgz"; - sha256 = "06n5kmjax64kv57ng5g2030a67z131i4wm53npg9zq2xlj9sprd8"; - system = "uri-template"; - asd = "uri-template"; - }); - systems = [ "uri-template" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "named-readtables" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - uri-template_dot_test = (build-asdf-system { - pname = "uri-template.test"; - version = "1.3.1"; - asds = [ "uri-template.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uri-template/2019-08-13/uri-template-1.3.1.tgz"; - sha256 = "06n5kmjax64kv57ng5g2030a67z131i4wm53npg9zq2xlj9sprd8"; - system = "uri-template.test"; - asd = "uri-template.test"; - }); - systems = [ "uri-template.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "uri-template" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - url-rewrite = (build-asdf-system { - pname = "url-rewrite"; - version = "20171227-git"; - asds = [ "url-rewrite" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/url-rewrite/2017-12-27/url-rewrite-20171227-git.tgz"; - sha256 = "0d3awcb938ajiylyfnbqsc7nndy6csx0qz1bcyr4f0p862w3xbqf"; - system = "url-rewrite"; - asd = "url-rewrite"; - }); - systems = [ "url-rewrite" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - userial = (build-asdf-system { - pname = "userial"; - version = "0.8.2011.06.02"; - asds = [ "userial" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/userial/2011-06-19/userial_0.8.2011.06.02.tgz"; - sha256 = "08f8hc1f81gyn4br9p732p8r2gl6cvccd4yzc9ydz4i0ijclpp2m"; - system = "userial"; - asd = "userial"; - }); - systems = [ "userial" ]; - lispLibs = [ (getAttr "contextl" self) (getAttr "ieee-floats" self) (getAttr "trivial-utf-8" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - userial-tests = (build-asdf-system { - pname = "userial-tests"; - version = "0.8.2011.06.02"; - asds = [ "userial-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/userial/2011-06-19/userial_0.8.2011.06.02.tgz"; - sha256 = "08f8hc1f81gyn4br9p732p8r2gl6cvccd4yzc9ydz4i0ijclpp2m"; - system = "userial-tests"; - asd = "userial-tests"; - }); - systems = [ "userial-tests" ]; - lispLibs = [ (getAttr "nst" self) (getAttr "userial" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - usocket = (build-asdf-system { - pname = "usocket"; - version = "0.8.8"; - asds = [ "usocket" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/usocket/2024-10-12/usocket-0.8.8.tgz"; - sha256 = "13j2hyl7j06vl8hh3930wd3bi2p0pcg4dcd243al31fgw4m0bvag"; - system = "usocket"; - asd = "usocket"; - }); - systems = [ "usocket" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = {}; - }); - usocket-server = (build-asdf-system { - pname = "usocket-server"; - version = "0.8.8"; - asds = [ "usocket-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/usocket/2024-10-12/usocket-0.8.8.tgz"; - sha256 = "13j2hyl7j06vl8hh3930wd3bi2p0pcg4dcd243al31fgw4m0bvag"; - system = "usocket-server"; - asd = "usocket-server"; - }); - systems = [ "usocket-server" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "usocket" self) ]; - meta = {}; - }); - usocket-test = (build-asdf-system { - pname = "usocket-test"; - version = "0.8.8"; - asds = [ "usocket-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/usocket/2024-10-12/usocket-0.8.8.tgz"; - sha256 = "13j2hyl7j06vl8hh3930wd3bi2p0pcg4dcd243al31fgw4m0bvag"; - system = "usocket-test"; - asd = "usocket-test"; - }); - systems = [ "usocket-test" ]; - lispLibs = [ (getAttr "rt" self) (getAttr "usocket-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - utf8-input-stream = (build-asdf-system { - pname = "utf8-input-stream"; - version = "20241012-git"; - asds = [ "utf8-input-stream" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/utf8-input-stream/2024-10-12/utf8-input-stream-20241012-git.tgz"; - sha256 = "06fk8fsz9nngdfjymg93h1l5m4yhfg4w8as68zlaj698xf9ry3i5"; - system = "utf8-input-stream"; - asd = "utf8-input-stream"; - }); - systems = [ "utf8-input-stream" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - utf8-input-stream_dot_tests = (build-asdf-system { - pname = "utf8-input-stream.tests"; - version = "20241012-git"; - asds = [ "utf8-input-stream.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/utf8-input-stream/2024-10-12/utf8-input-stream-20241012-git.tgz"; - sha256 = "06fk8fsz9nngdfjymg93h1l5m4yhfg4w8as68zlaj698xf9ry3i5"; - system = "utf8-input-stream.tests"; - asd = "utf8-input-stream.tests"; - }); - systems = [ "utf8-input-stream.tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "flexi-streams" self) (getAttr "utf8-input-stream" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - utilities_dot_binary-dump = (build-asdf-system { - pname = "utilities.binary-dump"; - version = "20181210-git"; - asds = [ "utilities.binary-dump" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/utilities.binary-dump/2018-12-10/utilities.binary-dump-20181210-git.tgz"; - sha256 = "1l20r1782bskyy50ca6vsyxrvbxlgfq4nm33wl8as761dcjpj4d4"; - system = "utilities.binary-dump"; - asd = "utilities.binary-dump"; - }); - systems = [ "utilities.binary-dump" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "let-plus" self) (getAttr "nibbles" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - utilities_dot_print-items = (build-asdf-system { - pname = "utilities.print-items"; - version = "20221106-git"; - asds = [ "utilities.print-items" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/utilities.print-items/2022-11-06/utilities.print-items-20221106-git.tgz"; - sha256 = "0qn0w7cyl76c3ssipqsx4ngb1641ajfkaihnb31w374zrzbns8wi"; - system = "utilities.print-items"; - asd = "utilities.print-items"; - }); - systems = [ "utilities.print-items" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = {}; - }); - utilities_dot_print-tree = (build-asdf-system { - pname = "utilities.print-tree"; - version = "20221106-git"; - asds = [ "utilities.print-tree" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/utilities.print-tree/2022-11-06/utilities.print-tree-20221106-git.tgz"; - sha256 = "0i7371qvlnwjcybh3c2ac88xz39vjdynhgxwz4acjbcnsw0jqsls"; - system = "utilities.print-tree"; - asd = "utilities.print-tree"; - }); - systems = [ "utilities.print-tree" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = {}; - }); - utility = (build-asdf-system { - pname = "utility"; - version = "20190202-git"; - asds = [ "utility" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/utility/2019-02-02/utility-20190202-git.tgz"; - sha256 = "0nc83kxp2c0wy5ai7dm6w4anx5266j99pxzr0c7fxgllc7d0g1qd"; - system = "utility"; - asd = "utility"; - }); - systems = [ "utility" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - utility-arguments = (build-asdf-system { - pname = "utility-arguments"; - version = "20161204-git"; - asds = [ "utility-arguments" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/utility-arguments/2016-12-04/utility-arguments-20161204-git.tgz"; - sha256 = "0dzbzzrla9709zl5dqdfw02mxa3rvcpca466qrcprgs3hnxdvgwb"; - system = "utility-arguments"; - asd = "utility-arguments"; - }); - systems = [ "utility-arguments" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - utils-kt = (build-asdf-system { - pname = "utils-kt"; - version = "20200218-git"; - asds = [ "utils-kt" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/utils-kt/2020-02-18/utils-kt-20200218-git.tgz"; - sha256 = "016x3w034brz02z9mrsrkhk2djizg3yqsvhl9k62xqcnpy3b87dn"; - system = "utils-kt"; - asd = "utils-kt"; - }); - systems = [ "utils-kt" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - utm = (build-asdf-system { - pname = "utm"; - version = "20200218-git"; - asds = [ "utm" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/utm/2020-02-18/utm-20200218-git.tgz"; - sha256 = "1a5dp5fls26ppc6fnvd941nfvk2qs72grl0a3pycq7vzw6580v01"; - system = "utm"; - asd = "utm"; - }); - systems = [ "utm" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - utm-ups = (build-asdf-system { - pname = "utm-ups"; - version = "20230618-git"; - asds = [ "utm-ups" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/utm-ups/2023-06-18/utm-ups-20230618-git.tgz"; - sha256 = "19nnnqagfg1c1vzwlqpp8mq2d0hrk8r6r07a46nvdyzmwbnmbwyr"; - system = "utm-ups"; - asd = "utm-ups"; - }); - systems = [ "utm-ups" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - utm_dot_test = (build-asdf-system { - pname = "utm.test"; - version = "20200218-git"; - asds = [ "utm.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/utm/2020-02-18/utm-20200218-git.tgz"; - sha256 = "1a5dp5fls26ppc6fnvd941nfvk2qs72grl0a3pycq7vzw6580v01"; - system = "utm.test"; - asd = "utm.test"; - }); - systems = [ "utm.test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "utm" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - uuid = (build-asdf-system { - pname = "uuid"; - version = "20200715-git"; - asds = [ "uuid" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uuid/2020-07-15/uuid-20200715-git.tgz"; - sha256 = "1ncwhyw0zggwpkzjsw7d4pkrlldi34xvb69c0bzxmyz2krg8rpx0"; - system = "uuid"; - asd = "uuid"; - }); - systems = [ "uuid" ]; - lispLibs = [ (getAttr "ironclad" self) (getAttr "trivial-utf-8" self) ]; - meta = {}; - }); - uuidv7 = (build-asdf-system { - pname = "uuidv7"; - version = "20241012-git"; - asds = [ "uuidv7" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/uuidv7.lisp/2024-10-12/uuidv7.lisp-20241012-git.tgz"; - sha256 = "1lirb92a1b3hpf66gndas4yix0smfckg9arzk69lpcvxsidzc66l"; - system = "uuidv7"; - asd = "uuidv7"; - }); - systems = [ "uuidv7" ]; - lispLibs = [ (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - validate-list = (build-asdf-system { - pname = "validate-list"; - version = "20210411-git"; - asds = [ "validate-list" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/validate-list/2021-04-11/validate-list-20210411-git.tgz"; - sha256 = "1rb7glqvlaz84cfd2wjk49si9jh4ffysmva5007gjhqfhr9z23lj"; - system = "validate-list"; - asd = "validate-list"; - }); - systems = [ "validate-list" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "arithmetic-operators-as-words" self) (getAttr "lisp-unit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - varint = (build-asdf-system { - pname = "varint"; - version = "20230618-git"; - asds = [ "varint" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/protobuf/2023-06-18/protobuf-20230618-git.tgz"; - sha256 = "0pp8i2i72p6cng11sxj83klw45jqv05l5024h7c2rl0pvsg8f6bc"; - system = "varint"; - asd = "varint"; - }); - systems = [ "varint" ]; - lispLibs = [ (getAttr "com_dot_google_dot_base" self) (getAttr "nibbles" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - varjo = (build-asdf-system { - pname = "varjo"; - version = "release-quicklisp-92f9c75b-git"; - asds = [ "varjo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/varjo/2021-01-24/varjo-release-quicklisp-92f9c75b-git.tgz"; - sha256 = "0gga4wq74qxql4zxh8zq1ab2xnsz8ygdaf8wxy7w15vv4czgamr9"; - system = "varjo"; - asd = "varjo"; - }); - systems = [ "varjo" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "documentation-utils" self) (getAttr "fn" self) (getAttr "glsl-docs" self) (getAttr "glsl-spec" self) (getAttr "glsl-symbols" self) (getAttr "named-readtables" self) (getAttr "parse-float" self) (getAttr "vas-string-metrics" self) ]; - meta = {}; - }); - varjo_dot_import = (build-asdf-system { - pname = "varjo.import"; - version = "release-quicklisp-92f9c75b-git"; - asds = [ "varjo.import" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/varjo/2021-01-24/varjo-release-quicklisp-92f9c75b-git.tgz"; - sha256 = "0gga4wq74qxql4zxh8zq1ab2xnsz8ygdaf8wxy7w15vv4czgamr9"; - system = "varjo.import"; - asd = "varjo.import"; - }); - systems = [ "varjo.import" ]; - lispLibs = [ (getAttr "fare-quasiquote-extras" self) (getAttr "glsl-toolkit" self) (getAttr "rtg-math_dot_vari" self) (getAttr "split-sequence" self) (getAttr "varjo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - varjo_dot_tests = (build-asdf-system { - pname = "varjo.tests"; - version = "release-quicklisp-92f9c75b-git"; - asds = [ "varjo.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/varjo/2021-01-24/varjo-release-quicklisp-92f9c75b-git.tgz"; - sha256 = "0gga4wq74qxql4zxh8zq1ab2xnsz8ygdaf8wxy7w15vv4czgamr9"; - system = "varjo.tests"; - asd = "varjo.tests"; - }); - systems = [ "varjo.tests" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "rtg-math_dot_vari" self) (getAttr "varjo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - varray = (build-asdf-system { - pname = "varray"; - version = "20241012-git"; - asds = [ "varray" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "varray"; - asd = "varray"; - }); - systems = [ "varray" ]; - lispLibs = [ (getAttr "aplesque" self) (getAttr "lparallel" self) (getAttr "random-state" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vas-string-metrics = (build-asdf-system { - pname = "vas-string-metrics"; - version = "20211209-git"; - asds = [ "vas-string-metrics" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vas-string-metrics/2021-12-09/vas-string-metrics-20211209-git.tgz"; - sha256 = "1yvkwc939dckv070nlgqfj5ys9ii2rm32m5wfx7qxdjrb4n19sx9"; - system = "vas-string-metrics"; - asd = "vas-string-metrics"; - }); - systems = [ "vas-string-metrics" ]; - lispLibs = [ ]; - meta = {}; - }); - vecto = (build-asdf-system { - pname = "vecto"; - version = "1.6"; - asds = [ "vecto" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vecto/2021-12-30/vecto-1.6.tgz"; - sha256 = "1s3ii9absili7yiv89byjikxcxlbagsvcxdwkxgsm1rahgggyk5x"; - system = "vecto"; - asd = "vecto"; - }); - systems = [ "vecto" ]; - lispLibs = [ (getAttr "cl-vectors" self) (getAttr "zpb-ttf" self) (getAttr "zpng" self) ]; - meta = {}; - }); - vectometry = (build-asdf-system { - pname = "vectometry"; - version = "1.6"; - asds = [ "vectometry" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vecto/2021-12-30/vecto-1.6.tgz"; - sha256 = "1s3ii9absili7yiv89byjikxcxlbagsvcxdwkxgsm1rahgggyk5x"; - system = "vectometry"; - asd = "vectometry"; - }); - systems = [ "vectometry" ]; - lispLibs = [ (getAttr "vecto" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vectors = (build-asdf-system { - pname = "vectors"; - version = "20171227-git"; - asds = [ "vectors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vectors/2017-12-27/vectors-20171227-git.tgz"; - sha256 = "1sflb1wz6fcszdbqrcfh52bp5ch6wbizzp7jx97ni8lrqq2r6cqy"; - system = "vectors"; - asd = "vectors"; - }); - systems = [ "vectors" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vellum = (build-asdf-system { - pname = "vellum"; - version = "20241012-git"; - asds = [ "vellum" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vellum/2024-10-12/vellum-20241012-git.tgz"; - sha256 = "0qy5hsyy3qf5245n5lfnhsfdjmsdjmwa2d3jp8gr6zg71npfx926"; - system = "vellum"; - asd = "vellum"; - }); - systems = [ "vellum" ]; - lispLibs = [ (getAttr "agnostic-lizard" self) (getAttr "alexandria" self) (getAttr "cl-data-structures" self) (getAttr "closer-mop" self) (getAttr "documentation-utils-extensions" self) (getAttr "iterate" self) (getAttr "lparallel" self) (getAttr "metabang-bind" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vellum-binary = (build-asdf-system { - pname = "vellum-binary"; - version = "20241012-git"; - asds = [ "vellum-binary" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vellum-binary/2024-10-12/vellum-binary-20241012-git.tgz"; - sha256 = "15kv5vzzrf6c3nvibz3p3d9arxmvwska37p5s13g9d2z1k3wyag1"; - system = "vellum-binary"; - asd = "vellum-binary"; - }); - systems = [ "vellum-binary" ]; - lispLibs = [ (getAttr "chipz" self) (getAttr "cl-conspack" self) (getAttr "ieee-floats" self) (getAttr "nibbles" self) (getAttr "salza2" self) (getAttr "trivial-utf-8" self) (getAttr "vellum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vellum-clim = (build-asdf-system { - pname = "vellum-clim"; - version = "20210531-git"; - asds = [ "vellum-clim" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vellum-clim/2021-05-31/vellum-clim-20210531-git.tgz"; - sha256 = "06g1pw0r60yd13hzbjrbpa1p0pnlwkqfn06ipk1gs0kc76gf2im5"; - system = "vellum-clim"; - asd = "vellum-clim"; - }); - systems = [ "vellum-clim" ]; - lispLibs = [ (getAttr "iterate" self) (getAttr "mcclim" self) (getAttr "vellum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vellum-csv = (build-asdf-system { - pname = "vellum-csv"; - version = "20241012-git"; - asds = [ "vellum-csv" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vellum-csv/2024-10-12/vellum-csv-20241012-git.tgz"; - sha256 = "0xk4n6w3hsnn8cl34x8vigzmqnkdn04j6831095yyqk7373hvfql"; - system = "vellum-csv"; - asd = "vellum-csv"; - }); - systems = [ "vellum-csv" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "documentation-utils-extensions" self) (getAttr "iterate" self) (getAttr "parse-float" self) (getAttr "serapeum" self) (getAttr "vellum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vellum-csv-tests = (build-asdf-system { - pname = "vellum-csv-tests"; - version = "20241012-git"; - asds = [ "vellum-csv-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vellum-csv/2024-10-12/vellum-csv-20241012-git.tgz"; - sha256 = "0xk4n6w3hsnn8cl34x8vigzmqnkdn04j6831095yyqk7373hvfql"; - system = "vellum-csv-tests"; - asd = "vellum-csv-tests"; - }); - systems = [ "vellum-csv-tests" ]; - lispLibs = [ (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "vellum-csv" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vellum-postmodern = (build-asdf-system { - pname = "vellum-postmodern"; - version = "20241012-git"; - asds = [ "vellum-postmodern" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vellum-postmodern/2024-10-12/vellum-postmodern-20241012-git.tgz"; - sha256 = "1q7s57vfcs01nl03kjkyjk9ya68cnl9p6mf1z864imfd04ssy9gr"; - system = "vellum-postmodern"; - asd = "vellum-postmodern"; - }); - systems = [ "vellum-postmodern" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-postgres" self) (getAttr "documentation-utils-extensions" self) (getAttr "iterate" self) (getAttr "postmodern" self) (getAttr "s-sql" self) (getAttr "serapeum" self) (getAttr "vellum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vellum-tests = (build-asdf-system { - pname = "vellum-tests"; - version = "20241012-git"; - asds = [ "vellum-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vellum/2024-10-12/vellum-20241012-git.tgz"; - sha256 = "0qy5hsyy3qf5245n5lfnhsfdjmsdjmwa2d3jp8gr6zg71npfx926"; - system = "vellum-tests"; - asd = "vellum-tests"; - }); - systems = [ "vellum-tests" ]; - lispLibs = [ (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "vellum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - veq = (build-asdf-system { - pname = "veq"; - version = "v4.5.5"; - asds = [ "veq" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-veq/2023-10-21/cl-veq-v4.5.5.tgz"; - sha256 = "0sk6rvqck47ym7ryy0smya1vwgpksxzal1xcwmwl106nxi9l7m34"; - system = "veq"; - asd = "veq"; - }); - systems = [ "veq" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - verbose = (build-asdf-system { - pname = "verbose"; - version = "20241012-git"; - asds = [ "verbose" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/verbose/2024-10-12/verbose-20241012-git.tgz"; - sha256 = "1q0knjk1nlnvlg9kydyxzd4sd2v8vm9dx10zqz2bpihd5nyhz3nv"; - system = "verbose"; - asd = "verbose"; - }); - systems = [ "verbose" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "dissect" self) (getAttr "documentation-utils" self) (getAttr "local-time" self) (getAttr "piping" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - verlet = (build-asdf-system { - pname = "verlet"; - version = "20211209-git"; - asds = [ "verlet" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/verlet/2021-12-09/verlet-20211209-git.tgz"; - sha256 = "0n6wgjwwbrr13ldwa4y59n2ixn47rr0ad7n3jbb58635z6ahfvd4"; - system = "verlet"; - asd = "verlet"; - }); - systems = [ "verlet" ]; - lispLibs = [ (getAttr "chain" self) (getAttr "fset" self) (getAttr "metabang-bind" self) (getAttr "mgl-pax" self) (getAttr "rtg-math" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vernacular = (build-asdf-system { - pname = "vernacular"; - version = "20241012-git"; - asds = [ "vernacular" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vernacular/2024-10-12/vernacular-20241012-git.tgz"; - sha256 = "09jz68lms82vxq672pars6hqapvdl4z8z2v1s9kmzvgxm2khw8pw"; - system = "vernacular"; - asd = "vernacular"; - }); - systems = [ "vernacular" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "local-time" self) (getAttr "named-readtables" self) (getAttr "overlord" self) (getAttr "serapeum" self) (getAttr "trivia" self) (getAttr "trivial-garbage" self) (getAttr "trivial-macroexpand-all" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - verrazano = (build-asdf-system { - pname = "verrazano"; - version = "20120909-darcs"; - asds = [ "verrazano" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/verrazano/2012-09-09/verrazano-20120909-darcs.tgz"; - sha256 = "0d7qv5jwv5p1r64g4rfqb844b5fh71p82b5983gjz0a5p391p270"; - system = "verrazano"; - asd = "verrazano"; - }); - systems = [ "verrazano" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "cl-ppcre" self) (getAttr "closer-mop" self) (getAttr "cxml" self) (getAttr "iterate" self) (getAttr "metabang-bind" self) (getAttr "parse-number" self) (getAttr "trivial-shell" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - verrazano-runtime = (build-asdf-system { - pname = "verrazano-runtime"; - version = "20120909-darcs"; - asds = [ "verrazano-runtime" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/verrazano/2012-09-09/verrazano-20120909-darcs.tgz"; - sha256 = "0d7qv5jwv5p1r64g4rfqb844b5fh71p82b5983gjz0a5p391p270"; - system = "verrazano-runtime"; - asd = "verrazano-runtime"; - }); - systems = [ "verrazano-runtime" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vertex = (build-asdf-system { - pname = "vertex"; - version = "20150608-git"; - asds = [ "vertex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vertex/2015-06-08/vertex-20150608-git.tgz"; - sha256 = "0g3ck1kvp6x9874ffizjz3fsd35a3m4hcr2x5gq9fdql680ic4k2"; - system = "vertex"; - asd = "vertex"; - }); - systems = [ "vertex" ]; - lispLibs = [ (getAttr "common-doc" self) (getAttr "common-doc-plump" self) (getAttr "plump-tex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vertex-test = (build-asdf-system { - pname = "vertex-test"; - version = "20150608-git"; - asds = [ "vertex-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vertex/2015-06-08/vertex-20150608-git.tgz"; - sha256 = "0g3ck1kvp6x9874ffizjz3fsd35a3m4hcr2x5gq9fdql680ic4k2"; - system = "vertex-test"; - asd = "vertex-test"; - }); - systems = [ "vertex-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "vertex" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vex = (build-asdf-system { - pname = "vex"; - version = "20241012-git"; - asds = [ "vex" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; - sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; - system = "vex"; - asd = "vex"; - }); - systems = [ "vex" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "array-operations" self) (getAttr "cl-ppcre" self) (getAttr "maxpc-apache" self) (getAttr "prove" self) (getAttr "symbol-munger" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vgplot = (build-asdf-system { - pname = "vgplot"; - version = "20220707-git"; - asds = [ "vgplot" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vgplot/2022-07-07/vgplot-20220707-git.tgz"; - sha256 = "1vc5fd787xa8831wjbmwrpg17f9isi5k8dmb85fsysz47plbvi1y"; - system = "vgplot"; - asd = "vgplot"; - }); - systems = [ "vgplot" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "ltk" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-colors = (build-asdf-system { - pname = "vivid-colors"; - version = "20220707-git"; - asds = [ "vivid-colors" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; - sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; - system = "vivid-colors"; - asd = "vivid-colors"; - }); - systems = [ "vivid-colors" ]; - lispLibs = [ (getAttr "cl-colors2" self) (getAttr "closer-mop" self) (getAttr "jingoh_dot_documentizer" self) (getAttr "lambda-fiddle" self) (getAttr "millet" self) (getAttr "vivid-colors_dot_content" self) (getAttr "vivid-colors_dot_dispatch" self) (getAttr "vivid-colors_dot_stream" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-colors_dot_content = (build-asdf-system { - pname = "vivid-colors.content"; - version = "20220707-git"; - asds = [ "vivid-colors.content" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; - sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; - system = "vivid-colors.content"; - asd = "vivid-colors.content"; - }); - systems = [ "vivid-colors.content" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ansi-text" self) (getAttr "jingoh_dot_documentizer" self) (getAttr "mcase" self) (getAttr "vivid-colors_dot_queue" self) (getAttr "vivid-colors_dot_shared" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-colors_dot_content_dot_test = (build-asdf-system { - pname = "vivid-colors.content.test"; - version = "20220707-git"; - asds = [ "vivid-colors.content.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; - sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; - system = "vivid-colors.content.test"; - asd = "vivid-colors.content.test"; - }); - systems = [ "vivid-colors.content.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "vivid-colors_dot_content" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-colors_dot_dispatch = (build-asdf-system { - pname = "vivid-colors.dispatch"; - version = "20220707-git"; - asds = [ "vivid-colors.dispatch" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; - sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; - system = "vivid-colors.dispatch"; - asd = "vivid-colors.dispatch"; - }); - systems = [ "vivid-colors.dispatch" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "jingoh_dot_documentizer" self) (getAttr "millet" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-colors_dot_dispatch_dot_test = (build-asdf-system { - pname = "vivid-colors.dispatch.test"; - version = "20220707-git"; - asds = [ "vivid-colors.dispatch.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; - sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; - system = "vivid-colors.dispatch.test"; - asd = "vivid-colors.dispatch.test"; - }); - systems = [ "vivid-colors.dispatch.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "vivid-colors_dot_dispatch" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-colors_dot_queue = (build-asdf-system { - pname = "vivid-colors.queue"; - version = "20220707-git"; - asds = [ "vivid-colors.queue" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; - sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; - system = "vivid-colors.queue"; - asd = "vivid-colors.queue"; - }); - systems = [ "vivid-colors.queue" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "jingoh_dot_documentizer" self) (getAttr "millet" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-colors_dot_queue_dot_test = (build-asdf-system { - pname = "vivid-colors.queue.test"; - version = "20220707-git"; - asds = [ "vivid-colors.queue.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; - sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; - system = "vivid-colors.queue.test"; - asd = "vivid-colors.queue.test"; - }); - systems = [ "vivid-colors.queue.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "vivid-colors_dot_queue" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-colors_dot_shared = (build-asdf-system { - pname = "vivid-colors.shared"; - version = "20220707-git"; - asds = [ "vivid-colors.shared" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; - sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; - system = "vivid-colors.shared"; - asd = "vivid-colors.shared"; - }); - systems = [ "vivid-colors.shared" ]; - lispLibs = [ (getAttr "jingoh_dot_documentizer" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-colors_dot_shared_dot_test = (build-asdf-system { - pname = "vivid-colors.shared.test"; - version = "20220707-git"; - asds = [ "vivid-colors.shared.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; - sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; - system = "vivid-colors.shared.test"; - asd = "vivid-colors.shared.test"; - }); - systems = [ "vivid-colors.shared.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "vivid-colors_dot_shared" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-colors_dot_stream = (build-asdf-system { - pname = "vivid-colors.stream"; - version = "20220707-git"; - asds = [ "vivid-colors.stream" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; - sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; - system = "vivid-colors.stream"; - asd = "vivid-colors.stream"; - }); - systems = [ "vivid-colors.stream" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ansi-text" self) (getAttr "jingoh_dot_documentizer" self) (getAttr "trivial-gray-streams" self) (getAttr "vivid-colors_dot_content" self) (getAttr "vivid-colors_dot_dispatch" self) (getAttr "vivid-colors_dot_shared" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-colors_dot_stream_dot_test = (build-asdf-system { - pname = "vivid-colors.stream.test"; - version = "20220707-git"; - asds = [ "vivid-colors.stream.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; - sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; - system = "vivid-colors.stream.test"; - asd = "vivid-colors.stream.test"; - }); - systems = [ "vivid-colors.stream.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "vivid-colors_dot_stream" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-colors_dot_test = (build-asdf-system { - pname = "vivid-colors.test"; - version = "20220707-git"; - asds = [ "vivid-colors.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; - sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; - system = "vivid-colors.test"; - asd = "vivid-colors.test"; - }); - systems = [ "vivid-colors.test" ]; - lispLibs = [ (getAttr "jingoh" self) (getAttr "vivid-colors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-diff = (build-asdf-system { - pname = "vivid-diff"; - version = "20220707-git"; - asds = [ "vivid-diff" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-diff/2022-07-07/vivid-diff-20220707-git.tgz"; - sha256 = "195hqx304x4na56qpiblz30ahp1qj55kan50mkr0xyjhcx75nsdk"; - system = "vivid-diff"; - asd = "vivid-diff"; - }); - systems = [ "vivid-diff" ]; - lispLibs = [ (getAttr "cl-colors2" self) (getAttr "closer-mop" self) (getAttr "jingoh_dot_documentizer" self) (getAttr "matrix-case" self) (getAttr "vivid-colors" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vivid-diff_dot_test = (build-asdf-system { - pname = "vivid-diff.test"; - version = "20220707-git"; - asds = [ "vivid-diff.test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vivid-diff/2022-07-07/vivid-diff-20220707-git.tgz"; - sha256 = "195hqx304x4na56qpiblz30ahp1qj55kan50mkr0xyjhcx75nsdk"; - system = "vivid-diff.test"; - asd = "vivid-diff.test"; - }); - systems = [ "vivid-diff.test" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "jingoh" self) (getAttr "vivid-diff" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vk = (build-asdf-system { - pname = "vk"; - version = "20230214-git"; - asds = [ "vk" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vk/2023-02-14/vk-20230214-git.tgz"; - sha256 = "14986kss2rggdjiql3rr34qnfjwb8w73j0ggn6c3w4y9dny3l31j"; - system = "vk"; - asd = "vk"; - }); - systems = [ "vk" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cffi" self) (getAttr "rove" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - voipms = (build-asdf-system { - pname = "voipms"; - version = "20231021-git"; - asds = [ "voipms" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-voipms/2023-10-21/cl-voipms-20231021-git.tgz"; - sha256 = "05jrpd9vc95hqxq3nbwv0qpsfj3winwx2n5a5933919gfanxrslk"; - system = "voipms"; - asd = "voipms"; - }); - systems = [ "voipms" ]; - lispLibs = [ (getAttr "cl-date-time-parser" self) (getAttr "erjoalgo-webutil" self) (getAttr "local-time" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vom = (build-asdf-system { - pname = "vom"; - version = "20241012-git"; - asds = [ "vom" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vom/2024-10-12/vom-20241012-git.tgz"; - sha256 = "1rnrr69h3j8phm6z3cfagv2bjh71wbzx9acnas9fn33j3q94gr95"; - system = "vom"; - asd = "vom"; - }); - systems = [ "vom" ]; - lispLibs = [ ]; - meta = {}; - }); - vom-json = (build-asdf-system { - pname = "vom-json"; - version = "20200610-git"; - asds = [ "vom-json" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vom-json/2020-06-10/vom-json-20200610-git.tgz"; - sha256 = "14b39kqbjpibh545gh9mb6w5g0kz7fhd5zxfmlf9a0fpdbwhw41c"; - system = "vom-json"; - asd = "vom-json"; - }); - systems = [ "vom-json" ]; - lispLibs = [ (getAttr "jonathan" self) (getAttr "local-time" self) (getAttr "vom" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vorbisfile-ffi = (build-asdf-system { - pname = "vorbisfile-ffi"; - version = "20151218-git"; - asds = [ "vorbisfile-ffi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; - sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; - system = "vorbisfile-ffi"; - asd = "vorbisfile-ffi"; - }); - systems = [ "vorbisfile-ffi" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - vp-trees = (build-asdf-system { - pname = "vp-trees"; - version = "20230214-git"; - asds = [ "vp-trees" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/vp-trees/2023-02-14/vp-trees-20230214-git.tgz"; - sha256 = "0fk41c97p5ck5g9nsvq6h9hzxz7yssyqz3v4f4qiavdnw6a9va1m"; - system = "vp-trees"; - asd = "vp-trees"; - }); - systems = [ "vp-trees" ]; - lispLibs = [ (getAttr "float-features" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - wallstreetflets = (build-asdf-system { - pname = "wallstreetflets"; - version = "20211209-git"; - asds = [ "wallstreetflets" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/wallstreetflets/2021-12-09/wallstreetflets-20211209-git.tgz"; - sha256 = "0d9anws4gk16an1kl4kads6lhm8a4mpiwxg74i3235d5874gbdj5"; - system = "wallstreetflets"; - asd = "wallstreetflets"; - }); - systems = [ "wallstreetflets" ]; - lispLibs = [ (getAttr "dexador" self) (getAttr "lquery" self) (getAttr "parse-number" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - wasm-encoder = (build-asdf-system { - pname = "wasm-encoder"; - version = "20210630-git"; - asds = [ "wasm-encoder" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/wasm-encoder/2021-06-30/wasm-encoder-20210630-git.tgz"; - sha256 = "1h094d8www9ydg96fjj17pi0lb63ikgyp5237cl6n3rmg4jpy9w6"; - system = "wasm-encoder"; - asd = "wasm-encoder"; - }); - systems = [ "wasm-encoder" ]; - lispLibs = [ (getAttr "agutil" self) (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "flexi-streams" self) (getAttr "generic-cl" self) (getAttr "ieee-floats" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - water = (build-asdf-system { - pname = "water"; - version = "20190107-git"; - asds = [ "water" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/water/2019-01-07/water-20190107-git.tgz"; - sha256 = "0w9b6mh10rfv7rg1zq28pivad6435i9h839km6nlbhq9xmx0g27s"; - system = "water"; - asd = "water"; - }); - systems = [ "water" ]; - lispLibs = [ (getAttr "parenscript" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - wayflan = (build-asdf-system { - pname = "wayflan"; - version = "20230214-git"; - asds = [ "wayflan" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/wayflan/2023-02-14/wayflan-20230214-git.tgz"; - sha256 = "0y6hzskp1vgaigzj5b3i695sc6dn5mk7nlxs21nh5ybzmf4chhyy"; - system = "wayflan"; - asd = "wayflan"; - }); - systems = [ "wayflan" ]; - lispLibs = [ (getAttr "cffi-grovel" self) (getAttr "wayflan-client" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - wayflan-client = (build-asdf-system { - pname = "wayflan-client"; - version = "20230214-git"; - asds = [ "wayflan-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/wayflan/2023-02-14/wayflan-20230214-git.tgz"; - sha256 = "0y6hzskp1vgaigzj5b3i695sc6dn5mk7nlxs21nh5ybzmf4chhyy"; - system = "wayflan-client"; - asd = "wayflan-client"; - }); - systems = [ "wayflan-client" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "closer-mop" self) (getAttr "plump" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - webactions = (build-asdf-system { - pname = "webactions"; - version = "20190813-git"; - asds = [ "webactions" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/portableaserve/2019-08-13/portableaserve-20190813-git.tgz"; - sha256 = "0ak6mqp84sjr0a7h5svr16vra4bf4fcx6wpir0n88dc1vjwy5xqa"; - system = "webactions"; - asd = "webactions"; - }); - systems = [ "webactions" ]; - lispLibs = [ (getAttr "acl-compat" self) (getAttr "aserve" self) (getAttr "htmlgen" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - webapi = (build-asdf-system { - pname = "webapi"; - version = "20230618-git"; - asds = [ "webapi" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/webapi/2023-06-18/webapi-20230618-git.tgz"; - sha256 = "1irp18a0rq61xfr3944ahy2spj0095l15xf7j0245jd0qw7gmg03"; - system = "webapi"; - asd = "webapi"; - }); - systems = [ "webapi" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "dexador" self) (getAttr "kebab" self) (getAttr "quri" self) (getAttr "st-json" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - weblocks-clsql = (build-asdf-system { - pname = "weblocks-clsql"; - version = "20211020-git"; - asds = [ "weblocks-clsql" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/weblocks-stores/2021-10-20/weblocks-stores-20211020-git.tgz"; - sha256 = "1k44dad18fkp80xjm04fiy6bciirs71ljvm8a2rb33xndrbxiiya"; - system = "weblocks-clsql"; - asd = "weblocks-clsql"; - }); - systems = [ "weblocks-clsql" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "clsql" self) (getAttr "clsql-fluid" self) (getAttr "metatilities" self) (getAttr "weblocks-stores" self) (getAttr "weblocks-util" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - weblocks-memory = (build-asdf-system { - pname = "weblocks-memory"; - version = "20211020-git"; - asds = [ "weblocks-memory" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/weblocks-stores/2021-10-20/weblocks-stores-20211020-git.tgz"; - sha256 = "1k44dad18fkp80xjm04fiy6bciirs71ljvm8a2rb33xndrbxiiya"; - system = "weblocks-memory"; - asd = "weblocks-memory"; - }); - systems = [ "weblocks-memory" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "metatilities" self) (getAttr "weblocks-stores" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - weblocks-montezuma = (build-asdf-system { - pname = "weblocks-montezuma"; - version = "20211020-git"; - asds = [ "weblocks-montezuma" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/weblocks-stores/2021-10-20/weblocks-stores-20211020-git.tgz"; - sha256 = "1k44dad18fkp80xjm04fiy6bciirs71ljvm8a2rb33xndrbxiiya"; - system = "weblocks-montezuma"; - asd = "weblocks-montezuma"; - }); - systems = [ "weblocks-montezuma" ]; - lispLibs = [ (getAttr "montezuma" self) (getAttr "weblocks-stores" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - weblocks-perec = (build-asdf-system { - pname = "weblocks-perec"; - version = "20211020-git"; - asds = [ "weblocks-perec" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/weblocks-stores/2021-10-20/weblocks-stores-20211020-git.tgz"; - sha256 = "1k44dad18fkp80xjm04fiy6bciirs71ljvm8a2rb33xndrbxiiya"; - system = "weblocks-perec"; - asd = "weblocks-perec"; - }); - systems = [ "weblocks-perec" ]; - lispLibs = [ (getAttr "hu_dot_dwim_dot_perec" self) (getAttr "weblocks-stores" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - weblocks-prevalence = (build-asdf-system { - pname = "weblocks-prevalence"; - version = "20211020-git"; - asds = [ "weblocks-prevalence" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/weblocks-stores/2021-10-20/weblocks-stores-20211020-git.tgz"; - sha256 = "1k44dad18fkp80xjm04fiy6bciirs71ljvm8a2rb33xndrbxiiya"; - system = "weblocks-prevalence"; - asd = "weblocks-prevalence"; - }); - systems = [ "weblocks-prevalence" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "cl-prevalence" self) (getAttr "metatilities" self) (getAttr "weblocks-memory" self) (getAttr "weblocks-stores" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - weblocks-scripts = (build-asdf-system { - pname = "weblocks-scripts"; - version = "20211020-git"; - asds = [ "weblocks-scripts" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/weblocks/2021-10-20/weblocks-20211020-git.tgz"; - sha256 = "1hilpzm1p3hrp2hxghjr9y8sy5a9bgk96n8kc8bphvn7dvlbm78j"; - system = "weblocks-scripts"; - asd = "weblocks-scripts"; - }); - systems = [ "weblocks-scripts" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - weblocks-stores = (build-asdf-system { - pname = "weblocks-stores"; - version = "20211020-git"; - asds = [ "weblocks-stores" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/weblocks-stores/2021-10-20/weblocks-stores-20211020-git.tgz"; - sha256 = "1k44dad18fkp80xjm04fiy6bciirs71ljvm8a2rb33xndrbxiiya"; - system = "weblocks-stores"; - asd = "weblocks-stores"; - }); - systems = [ "weblocks-stores" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "metatilities" self) (getAttr "weblocks-util" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - weblocks-util = (build-asdf-system { - pname = "weblocks-util"; - version = "20211020-git"; - asds = [ "weblocks-util" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/weblocks/2021-10-20/weblocks-20211020-git.tgz"; - sha256 = "1hilpzm1p3hrp2hxghjr9y8sy5a9bgk96n8kc8bphvn7dvlbm78j"; - system = "weblocks-util"; - asd = "weblocks-util"; - }); - systems = [ "weblocks-util" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "bordeaux-threads" self) (getAttr "cl-cont" self) (getAttr "cl-fad" self) (getAttr "cl-json" self) (getAttr "cl-ppcre" self) (getAttr "cl-who" self) (getAttr "closer-mop" self) (getAttr "f-underscore" self) (getAttr "html-template" self) (getAttr "hunchentoot" self) (getAttr "ironclad" self) (getAttr "metatilities" self) (getAttr "optima" self) (getAttr "parenscript" self) (getAttr "parse-number" self) (getAttr "pretty-function" self) (getAttr "puri" self) (getAttr "salza2" self) (getAttr "trivial-backtrace" self) (getAttr "trivial-timeout" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - websocket-driver = (build-asdf-system { - pname = "websocket-driver"; - version = "20241012-git"; - asds = [ "websocket-driver" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/websocket-driver/2024-10-12/websocket-driver-20241012-git.tgz"; - sha256 = "1lj6xarr62199ladkml7qpgi86w94j4djrp54v9ch0zakni3rhj2"; - system = "websocket-driver"; - asd = "websocket-driver"; - }); - systems = [ "websocket-driver" ]; - lispLibs = [ (getAttr "websocket-driver-client" self) (getAttr "websocket-driver-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - websocket-driver-base = (build-asdf-system { - pname = "websocket-driver-base"; - version = "20241012-git"; - asds = [ "websocket-driver-base" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/websocket-driver/2024-10-12/websocket-driver-20241012-git.tgz"; - sha256 = "1lj6xarr62199ladkml7qpgi86w94j4djrp54v9ch0zakni3rhj2"; - system = "websocket-driver-base"; - asd = "websocket-driver-base"; - }); - systems = [ "websocket-driver-base" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-base64" self) (getAttr "event-emitter" self) (getAttr "fast-io" self) (getAttr "fast-websocket" self) (getAttr "sha1" self) (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - websocket-driver-client = (build-asdf-system { - pname = "websocket-driver-client"; - version = "20241012-git"; - asds = [ "websocket-driver-client" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/websocket-driver/2024-10-12/websocket-driver-20241012-git.tgz"; - sha256 = "1lj6xarr62199ladkml7qpgi86w94j4djrp54v9ch0zakni3rhj2"; - system = "websocket-driver-client"; - asd = "websocket-driver-client"; - }); - systems = [ "websocket-driver-client" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl_plus_ssl" self) (getAttr "cl-base64" self) (getAttr "fast-http" self) (getAttr "fast-io" self) (getAttr "fast-websocket" self) (getAttr "quri" self) (getAttr "usocket" self) (getAttr "websocket-driver-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - websocket-driver-server = (build-asdf-system { - pname = "websocket-driver-server"; - version = "20241012-git"; - asds = [ "websocket-driver-server" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/websocket-driver/2024-10-12/websocket-driver-20241012-git.tgz"; - sha256 = "1lj6xarr62199ladkml7qpgi86w94j4djrp54v9ch0zakni3rhj2"; - system = "websocket-driver-server"; - asd = "websocket-driver-server"; - }); - systems = [ "websocket-driver-server" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "clack-socket" self) (getAttr "fast-io" self) (getAttr "fast-websocket" self) (getAttr "websocket-driver-base" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - weft = (build-asdf-system { - pname = "weft"; - version = "20180228-git"; - asds = [ "weft" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/weft/2018-02-28/weft-20180228-git.tgz"; - sha256 = "1ia38xcpp9g4v6sij99lyl9b8p59ysg2cj9k92nb683f8pzv9pl3"; - system = "weft"; - asd = "weft"; - }); - systems = [ "weft" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "log4cl" self) (getAttr "trivial-timeout" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - westbrook = (build-asdf-system { - pname = "westbrook"; - version = "20180131-git"; - asds = [ "westbrook" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/westbrook/2018-01-31/westbrook-20180131-git.tgz"; - sha256 = "08qs5lpg34d1mn6warrrq1wimyqqrjb8jih62g1pbysgni4ihm2v"; - system = "westbrook"; - asd = "westbrook"; - }); - systems = [ "westbrook" ]; - lispLibs = [ (getAttr "cxml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - westbrook-tests = (build-asdf-system { - pname = "westbrook-tests"; - version = "20180131-git"; - asds = [ "westbrook-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/westbrook/2018-01-31/westbrook-20180131-git.tgz"; - sha256 = "08qs5lpg34d1mn6warrrq1wimyqqrjb8jih62g1pbysgni4ihm2v"; - system = "westbrook-tests"; - asd = "westbrook-tests"; - }); - systems = [ "westbrook-tests" ]; - lispLibs = [ (getAttr "fiasco" self) (getAttr "westbrook" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - what3words = (build-asdf-system { - pname = "what3words"; - version = "20161204-git"; - asds = [ "what3words" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/what3words/2016-12-04/what3words-20161204-git.tgz"; - sha256 = "0nlrpi8phrf2mpgbw9bj9w4vksqb0baj542bhnq39sjalc8bj73r"; - system = "what3words"; - asd = "what3words"; - }); - systems = [ "what3words" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "drakma" self) (getAttr "jsown" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - whereiseveryone_dot_command-line-args = (build-asdf-system { - pname = "whereiseveryone.command-line-args"; - version = "20241012-git"; - asds = [ "whereiseveryone.command-line-args" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/whereiseveryone.command-line-args/2024-10-12/whereiseveryone.command-line-args-20241012-git.tgz"; - sha256 = "140xnz2v0v3hfg3dp2fhidw8ns6lxd3a5knm07wqdp48ksg119wy"; - system = "whereiseveryone.command-line-args"; - asd = "whereiseveryone.command-line-args"; - }); - systems = [ "whereiseveryone.command-line-args" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "charje_dot_documentation" self) (getAttr "serapeum" self) (getAttr "str" self) (getAttr "trivia" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - which = (build-asdf-system { - pname = "which"; - version = "20160421-git"; - asds = [ "which" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/which/2016-04-21/which-20160421-git.tgz"; - sha256 = "127pm9h4rm4w9aadw5yvamnfzhk2rr69kchx10rf9k7sk7izqqfk"; - system = "which"; - asd = "which"; - }); - systems = [ "which" ]; - lispLibs = [ (getAttr "cl-fad" self) (getAttr "path-parse" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - which-test = (build-asdf-system { - pname = "which-test"; - version = "20160421-git"; - asds = [ "which-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/which/2016-04-21/which-20160421-git.tgz"; - sha256 = "127pm9h4rm4w9aadw5yvamnfzhk2rr69kchx10rf9k7sk7izqqfk"; - system = "which-test"; - asd = "which-test"; - }); - systems = [ "which-test" ]; - lispLibs = [ (getAttr "fiveam" self) (getAttr "which" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - whirlog = (build-asdf-system { - pname = "whirlog"; - version = "20211020-git"; - asds = [ "whirlog" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/whirlog/2021-10-20/whirlog-20211020-git.tgz"; - sha256 = "0sf1kc8ln1gszzrz3qh3bx11k42lpccrv6kp2ihlrg3d6lsa6i26"; - system = "whirlog"; - asd = "whirlog"; - }); - systems = [ "whirlog" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - whofields = (build-asdf-system { - pname = "whofields"; - version = "20211020-git"; - asds = [ "whofields" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/whofields/2021-10-20/whofields-20211020-git.tgz"; - sha256 = "1scpzzfdw5g7qsayhznjyzns8lxx4fvv2jxd0vr9vnxad3vm977x"; - system = "whofields"; - asd = "whofields"; - }); - systems = [ "whofields" ]; - lispLibs = [ (getAttr "asdf-package-system" self) (getAttr "cl-who" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - wilbur = (build-asdf-system { - pname = "wilbur"; - version = "20181210-git"; - asds = [ "wilbur" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/de.setf.wilbur/2018-12-10/de.setf.wilbur-20181210-git.tgz"; - sha256 = "0w4qssyarim4v64vv7jmspmyba7xghx9bkalyyhvccf6zrf7b2v7"; - system = "wilbur"; - asd = "wilbur"; - }); - systems = [ "wilbur" ]; - lispLibs = [ (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - wild-package-inferred-system = (build-asdf-system { - pname = "wild-package-inferred-system"; - version = "20210531-git"; - asds = [ "wild-package-inferred-system" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/wild-package-inferred-system/2021-05-31/wild-package-inferred-system-20210531-git.tgz"; - sha256 = "0sp3j3i83aqyq9bl3djs490nilryi9sh1wjbcqd9z94d9wfbfz80"; - system = "wild-package-inferred-system"; - asd = "wild-package-inferred-system"; - }); - systems = [ "wild-package-inferred-system" ]; - lispLibs = [ ]; - meta = {}; - }); - window = (build-asdf-system { - pname = "window"; - version = "20200427-git"; - asds = [ "window" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; - sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; - system = "window"; - asd = "window"; - }); - systems = [ "window" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bodge-glfw" self) (getAttr "cffi" self) (getAttr "trivial-features" self) (getAttr "utility" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - winhttp = (build-asdf-system { - pname = "winhttp"; - version = "20241012-git"; - asds = [ "winhttp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/winhttp/2024-10-12/winhttp-20241012-git.tgz"; - sha256 = "1g4prr0x2cyc58wcpa3kfiwcs9f536bzfmsnlwnh3yn9aqndg67c"; - system = "winhttp"; - asd = "winhttp"; - }); - systems = [ "winhttp" ]; - lispLibs = [ (getAttr "cffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - winlock = (build-asdf-system { - pname = "winlock"; - version = "20191130-git"; - asds = [ "winlock" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/winlock/2019-11-30/winlock-20191130-git.tgz"; - sha256 = "0sgjq1cjbmshnh2zwyqws7rkr93zkjl0rrzyf04542gb1grj0vd8"; - system = "winlock"; - asd = "winlock"; - }); - systems = [ "winlock" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "named-readtables" self) (getAttr "serapeum" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - wire-world = (build-asdf-system { - pname = "wire-world"; - version = "master-fe503896-git"; - asds = [ "wire-world" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "wire-world"; - asd = "wire-world"; - }); - systems = [ "wire-world" ]; - lispLibs = [ (getAttr "gwl-graphics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - with-branching = (build-asdf-system { - pname = "with-branching"; - version = "20241012-git"; - asds = [ "with-branching" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/with-branching/2024-10-12/with-branching-20241012-git.tgz"; - sha256 = "0rhmlg1nbbhaa5jflhnydsqs7aqwg8d7ijxxcqa8lkcq49wvm647"; - system = "with-branching"; - asd = "with-branching"; - }); - systems = [ "with-branching" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-indent" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - with-c-syntax = (build-asdf-system { - pname = "with-c-syntax"; - version = "20221106-git"; - asds = [ "with-c-syntax" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/with-c-syntax/2022-11-06/with-c-syntax-20221106-git.tgz"; - sha256 = "12gdwdyxyl9xm8n04qvmvyc1s06dkckb87i6hdysal5lsf1gwc41"; - system = "with-c-syntax"; - asd = "with-c-syntax"; - }); - systems = [ "with-c-syntax" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-ppcre" self) (getAttr "float-features" self) (getAttr "floating-point-contractions" self) (getAttr "named-readtables" self) (getAttr "split-sequence" self) (getAttr "trivial-gray-streams" self) (getAttr "yacc" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - with-c-syntax-test = (build-asdf-system { - pname = "with-c-syntax-test"; - version = "20221106-git"; - asds = [ "with-c-syntax-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/with-c-syntax/2022-11-06/with-c-syntax-20221106-git.tgz"; - sha256 = "12gdwdyxyl9xm8n04qvmvyc1s06dkckb87i6hdysal5lsf1gwc41"; - system = "with-c-syntax-test"; - asd = "with-c-syntax-test"; - }); - systems = [ "with-c-syntax-test" ]; - lispLibs = [ (getAttr "_1am" self) (getAttr "floating-point" self) (getAttr "trivial-cltl2" self) (getAttr "with-c-syntax" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - with-cached-reader-conditionals = (build-asdf-system { - pname = "with-cached-reader-conditionals"; - version = "20170630-git"; - asds = [ "with-cached-reader-conditionals" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/with-cached-reader-conditionals/2017-06-30/with-cached-reader-conditionals-20170630-git.tgz"; - sha256 = "0n7a089d0wb13l1nsdh3xlgwxwlqynkbjl8fg2x56h52a5i9gkv4"; - system = "with-cached-reader-conditionals"; - asd = "with-cached-reader-conditionals"; - }); - systems = [ "with-cached-reader-conditionals" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - with-contexts = (build-asdf-system { - pname = "with-contexts"; - version = "20241012-git"; - asds = [ "with-contexts" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/with-contexts/2024-10-12/with-contexts-20241012-git.tgz"; - sha256 = "1biz33wxg312zsmpyjqfcmq4vnixxz3g4hp9krc61977d5n4fxwj"; - system = "with-contexts"; - asd = "with-contexts"; - }); - systems = [ "with-contexts" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - with-output-to-stream = (build-asdf-system { - pname = "with-output-to-stream"; - version = "1.0"; - asds = [ "with-output-to-stream" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/with-output-to-stream/2019-10-07/with-output-to-stream_1.0.tgz"; - sha256 = "0pv9kccjbxkgcv7wbcfpnzas9pq0n2rs2aq9kdnqkx55k12366sm"; - system = "with-output-to-stream"; - asd = "with-output-to-stream"; - }); - systems = [ "with-output-to-stream" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - with-output-to-stream__tests = (build-asdf-system { - pname = "with-output-to-stream_tests"; - version = "1.0"; - asds = [ "with-output-to-stream_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/with-output-to-stream/2019-10-07/with-output-to-stream_1.0.tgz"; - sha256 = "0pv9kccjbxkgcv7wbcfpnzas9pq0n2rs2aq9kdnqkx55k12366sm"; - system = "with-output-to-stream_tests"; - asd = "with-output-to-stream_tests"; - }); - systems = [ "with-output-to-stream_tests" ]; - lispLibs = [ (getAttr "parachute" self) (getAttr "with-output-to-stream" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - with-setf = (build-asdf-system { - pname = "with-setf"; - version = "release-quicklisp-df3eed9d-git"; - asds = [ "with-setf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/with-setf/2018-02-28/with-setf-release-quicklisp-df3eed9d-git.tgz"; - sha256 = "090v39kdxk4py3axjrjjac2pn1p0109q14hvl818pik479xr4inz"; - system = "with-setf"; - asd = "with-setf"; - }); - systems = [ "with-setf" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - with-shadowed-bindings = (build-asdf-system { - pname = "with-shadowed-bindings"; - version = "1.0"; - asds = [ "with-shadowed-bindings" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/with-shadowed-bindings/2019-01-07/with-shadowed-bindings-1.0.tgz"; - sha256 = "0kxy86a21v4fm4xwd44c6kpdadgkcj8iv6a68xavhirhjhngcwy5"; - system = "with-shadowed-bindings"; - asd = "with-shadowed-bindings"; - }); - systems = [ "with-shadowed-bindings" ]; - lispLibs = [ (getAttr "map-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - with-shadowed-bindings__tests = (build-asdf-system { - pname = "with-shadowed-bindings_tests"; - version = "1.0"; - asds = [ "with-shadowed-bindings_tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/with-shadowed-bindings/2019-01-07/with-shadowed-bindings-1.0.tgz"; - sha256 = "0kxy86a21v4fm4xwd44c6kpdadgkcj8iv6a68xavhirhjhngcwy5"; - system = "with-shadowed-bindings_tests"; - asd = "with-shadowed-bindings_tests"; - }); - systems = [ "with-shadowed-bindings_tests" ]; - lispLibs = [ (getAttr "parachute" self) (getAttr "with-shadowed-bindings" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - with-user-abort = (build-asdf-system { - pname = "with-user-abort"; - version = "20230214-git"; - asds = [ "with-user-abort" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/with-user-abort/2023-02-14/with-user-abort-20230214-git.tgz"; - sha256 = "0yidlm92dk8kvz137zlm2f0d198kmgqpdswkinr2x4snbgkhd98j"; - system = "with-user-abort"; - asd = "with-user-abort"; - }); - systems = [ "with-user-abort" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - woo = (build-asdf-system { - pname = "woo"; - version = "20241012-git"; - asds = [ "woo" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/woo/2024-10-12/woo-20241012-git.tgz"; - sha256 = "0nhxlb1qhkl20vknm44gx0cq5cks33rcljczfhgbnmpkzrdpdrrl"; - system = "woo"; - asd = "woo"; - }); - systems = [ "woo" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "cl_plus_ssl" self) (getAttr "clack-socket" self) (getAttr "fast-http" self) (getAttr "fast-io" self) (getAttr "lev" self) (getAttr "quri" self) (getAttr "smart-buffer" self) (getAttr "static-vectors" self) (getAttr "swap-bytes" self) (getAttr "trivial-mimes" self) (getAttr "trivial-utf-8" self) (getAttr "vom" self) ]; - meta = {}; - }); - woo-test = (build-asdf-system { - pname = "woo-test"; - version = "20241012-git"; - asds = [ "woo-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/woo/2024-10-12/woo-20241012-git.tgz"; - sha256 = "0nhxlb1qhkl20vknm44gx0cq5cks33rcljczfhgbnmpkzrdpdrrl"; - system = "woo-test"; - asd = "woo-test"; - }); - systems = [ "woo-test" ]; - lispLibs = [ (getAttr "clack-test" self) (getAttr "rove" self) (getAttr "woo" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - wookie = (build-asdf-system { - pname = "wookie"; - version = "20230214-git"; - asds = [ "wookie" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/wookie/2023-02-14/wookie-20230214-git.tgz"; - sha256 = "1i5l9isahww9zwizj6dmdcplck8wr8gxm31i43i8hf3rfxmvfjwn"; - system = "wookie"; - asd = "wookie"; - }); - systems = [ "wookie" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "blackbird" self) (getAttr "chunga" self) (getAttr "cl-async" self) (getAttr "cl-async-ssl" self) (getAttr "cl-fad" self) (getAttr "cl-ppcre" self) (getAttr "do-urlencode" self) (getAttr "fast-http" self) (getAttr "fast-io" self) (getAttr "quri" self) (getAttr "vom" self) ]; - meta = {}; - }); - wordnet = (build-asdf-system { - pname = "wordnet"; - version = "20220220-git"; - asds = [ "wordnet" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/wordnet/2022-02-20/wordnet-20220220-git.tgz"; - sha256 = "07p60k295fsfcp0gmkqhrxd68hb38aqva8f4k8xk8bqqxxf42vkq"; - system = "wordnet"; - asd = "wordnet"; - }); - systems = [ "wordnet" ]; - lispLibs = [ (getAttr "split-sequence" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - workout-timer = (build-asdf-system { - pname = "workout-timer"; - version = "20230214-git"; - asds = [ "workout-timer" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/workout-timer/2023-02-14/workout-timer-20230214-git.tgz"; - sha256 = "1f8qj6la93k95xqkliv59r6dkyhyhzqp2zgk0s893a3mrar0gfrx"; - system = "workout-timer"; - asd = "workout-timer"; - }); - systems = [ "workout-timer" ]; - lispLibs = [ (getAttr "cffi-toolchain" self) (getAttr "command-line-arguments" self) (getAttr "local-time" self) (getAttr "mixalot" self) (getAttr "mixalot-vorbis" self) (getAttr "vorbisfile-ffi" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - wu-decimal = (build-asdf-system { - pname = "wu-decimal"; - version = "20130128-git"; - asds = [ "wu-decimal" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/wu-decimal/2013-01-28/wu-decimal-20130128-git.tgz"; - sha256 = "1p7na4hic7297amwm4idfwkyx664ny8cdssncyra37pmv4wzp8dm"; - system = "wu-decimal"; - asd = "wu-decimal"; - }); - systems = [ "wu-decimal" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - wu-sugar = (build-asdf-system { - pname = "wu-sugar"; - version = "20160825-git"; - asds = [ "wu-sugar" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/wu-sugar/2016-08-25/wu-sugar-20160825-git.tgz"; - sha256 = "0ypn5195krfd1rva5myla8j7n2ilfs5gxh81flx7v0mr4r70fayl"; - system = "wu-sugar"; - asd = "wu-sugar"; - }); - systems = [ "wu-sugar" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - wuwei = (build-asdf-system { - pname = "wuwei"; - version = "20221106-git"; - asds = [ "wuwei" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/wuwei/2022-11-06/wuwei-20221106-git.tgz"; - sha256 = "1k5yhxdqcx250kd56qgbch5z0hvjpjwch38c3949nf790pmrhl8f"; - system = "wuwei"; - asd = "wuwei"; - }); - systems = [ "wuwei" ]; - lispLibs = [ (getAttr "aserve" self) (getAttr "cl-json" self) (getAttr "drakma" self) (getAttr "ironclad" self) (getAttr "mtlisp" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - wuwei-examples = (build-asdf-system { - pname = "wuwei-examples"; - version = "20221106-git"; - asds = [ "wuwei-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/wuwei/2022-11-06/wuwei-20221106-git.tgz"; - sha256 = "1k5yhxdqcx250kd56qgbch5z0hvjpjwch38c3949nf790pmrhl8f"; - system = "wuwei-examples"; - asd = "wuwei"; - }); - systems = [ "wuwei-examples" ]; - lispLibs = [ (getAttr "drakma" self) (getAttr "wuwei" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - x_dot_let-star = (build-asdf-system { - pname = "x.let-star"; - version = "20200325-git"; - asds = [ "x.let-star" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/x.let-star/2020-03-25/x.let-star-20200325-git.tgz"; - sha256 = "0qk0rpqzb7vaivggsqch06nmdjzp6b31a88w40y3864clajpcrnr"; - system = "x.let-star"; - asd = "x.let-star"; - }); - systems = [ "x.let-star" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xarray = (build-asdf-system { - pname = "xarray"; - version = "20140113-git"; - asds = [ "xarray" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xarray/2014-01-13/xarray-20140113-git.tgz"; - sha256 = "031h1bvy9s6qas2160dgf7gc0y6inrhpzp8j3wrb6fjxkb0524yl"; - system = "xarray"; - asd = "xarray"; - }); - systems = [ "xarray" ]; - lispLibs = [ (getAttr "anaphora" self) (getAttr "cl-utilities" self) (getAttr "iterate" self) (getAttr "metabang-bind" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xarray-test = (build-asdf-system { - pname = "xarray-test"; - version = "20140113-git"; - asds = [ "xarray-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xarray/2014-01-13/xarray-20140113-git.tgz"; - sha256 = "031h1bvy9s6qas2160dgf7gc0y6inrhpzp8j3wrb6fjxkb0524yl"; - system = "xarray-test"; - asd = "xarray-test"; - }); - systems = [ "xarray-test" ]; - lispLibs = [ (getAttr "lift" self) (getAttr "xarray" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xcat = (build-asdf-system { - pname = "xcat"; - version = "20200925-git"; - asds = [ "xcat" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xcat/2020-09-25/xcat-20200925-git.tgz"; - sha256 = "1v8mcz8bidcbfl587b5lm07l91xan6z1y3zikjkyzagiigd4byvi"; - system = "xcat"; - asd = "xcat"; - }); - systems = [ "xcat" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "flexi-streams" self) (getAttr "log4cl" self) (getAttr "trivial-features" self) (getAttr "trivial-garbage" self) (getAttr "usocket-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xecto = (build-asdf-system { - pname = "xecto"; - version = "20151218-git"; - asds = [ "xecto" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xecto/2015-12-18/xecto-20151218-git.tgz"; - sha256 = "1m81cl02k28v9sgscl8qhig735x5qybhw69szs6bkkqml7hbl12q"; - system = "xecto"; - asd = "xecto"; - }); - systems = [ "xecto" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xembed = (build-asdf-system { - pname = "xembed"; - version = "20191130-git"; - asds = [ "xembed" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clx-xembed/2019-11-30/clx-xembed-20191130-git.tgz"; - sha256 = "1abx4v36ycmfjdwpjk4hh8058ya8whwia7ds9vd96q2qsrs57f12"; - system = "xembed"; - asd = "xembed"; - }); - systems = [ "xembed" ]; - lispLibs = [ (getAttr "clx" self) ]; - meta = {}; - }); - xfactory = (build-asdf-system { - pname = "xfactory"; - version = "20130615-git"; - asds = [ "xfactory" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libxml2/2013-06-15/cl-libxml2-20130615-git.tgz"; - sha256 = "09049c13cfp5sc6x9lrw762jd7a9qkfq5jgngqgrzn4kn9qscarw"; - system = "xfactory"; - asd = "xfactory"; - }); - systems = [ "xfactory" ]; - lispLibs = [ (getAttr "cl-libxml2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xfactory-test = (build-asdf-system { - pname = "xfactory-test"; - version = "20130615-git"; - asds = [ "xfactory-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libxml2/2013-06-15/cl-libxml2-20130615-git.tgz"; - sha256 = "09049c13cfp5sc6x9lrw762jd7a9qkfq5jgngqgrzn4kn9qscarw"; - system = "xfactory-test"; - asd = "xfactory"; - }); - systems = [ "xfactory-test" ]; - lispLibs = [ (getAttr "lift" self) (getAttr "xfactory" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xhtmlambda = (build-asdf-system { - pname = "xhtmlambda"; - version = "20241012-git"; - asds = [ "xhtmlambda" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xhtmlambda/2024-10-12/xhtmlambda-20241012-git.tgz"; - sha256 = "1xqwps5lr66lhqiczvccxrpy8kff15fx6qr9nh1i65wi4p68i1bb"; - system = "xhtmlambda"; - asd = "xhtmlambda"; - }); - systems = [ "xhtmlambda" ]; - lispLibs = [ (getAttr "cl-unicode" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xhtmlgen = (build-asdf-system { - pname = "xhtmlgen"; - version = "20170124-git"; - asds = [ "xhtmlgen" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xhtmlgen/2017-01-24/xhtmlgen-20170124-git.tgz"; - sha256 = "0br4pqhl7y7rd95l9xx2p96gds3dh4pgk9v038wbshl2dnhjv82k"; - system = "xhtmlgen"; - asd = "xhtmlgen"; - }); - systems = [ "xhtmlgen" ]; - lispLibs = [ (getAttr "cxml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xhtmlgen-test = (build-asdf-system { - pname = "xhtmlgen-test"; - version = "20170124-git"; - asds = [ "xhtmlgen-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xhtmlgen/2017-01-24/xhtmlgen-20170124-git.tgz"; - sha256 = "0br4pqhl7y7rd95l9xx2p96gds3dh4pgk9v038wbshl2dnhjv82k"; - system = "xhtmlgen-test"; - asd = "xhtmlgen"; - }); - systems = [ "xhtmlgen-test" ]; - lispLibs = [ (getAttr "rt" self) (getAttr "xhtmlgen" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xkeyboard = (build-asdf-system { - pname = "xkeyboard"; - version = "20120811-git"; - asds = [ "xkeyboard" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clx-xkeyboard/2012-08-11/clx-xkeyboard-20120811-git.tgz"; - sha256 = "1nxky9wsmm7nmwz372jgb4iy0ywlm22jw0vl8yi0k9slsfklvcqi"; - system = "xkeyboard"; - asd = "xkeyboard"; - }); - systems = [ "xkeyboard" ]; - lispLibs = [ (getAttr "clx" self) ]; - meta = {}; - }); - xkeyboard-test = (build-asdf-system { - pname = "xkeyboard-test"; - version = "20120811-git"; - asds = [ "xkeyboard-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/clx-xkeyboard/2012-08-11/clx-xkeyboard-20120811-git.tgz"; - sha256 = "1nxky9wsmm7nmwz372jgb4iy0ywlm22jw0vl8yi0k9slsfklvcqi"; - system = "xkeyboard-test"; - asd = "xkeyboard"; - }); - systems = [ "xkeyboard-test" ]; - lispLibs = [ (getAttr "xkeyboard" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xlsx = (build-asdf-system { - pname = "xlsx"; - version = "20180711-git"; - asds = [ "xlsx" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xlsx/2018-07-11/xlsx-20180711-git.tgz"; - sha256 = "15vw5zl13jg9b1rla7w2wv6ss93mijrnn9fzsh0fakgvfikqq1n6"; - system = "xlsx"; - asd = "xlsx"; - }); - systems = [ "xlsx" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "xmls" self) (getAttr "zip" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xlunit = (build-asdf-system { - pname = "xlunit"; - version = "20150923-git"; - asds = [ "xlunit" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xlunit/2015-09-23/xlunit-20150923-git.tgz"; - sha256 = "0argfmp9nghs4sihyj3f8ch9qfib2b7ll07v5m9ziajgzsfl5xw3"; - system = "xlunit"; - asd = "xlunit"; - }); - systems = [ "xlunit" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xlunit-tests = (build-asdf-system { - pname = "xlunit-tests"; - version = "20150923-git"; - asds = [ "xlunit-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xlunit/2015-09-23/xlunit-20150923-git.tgz"; - sha256 = "0argfmp9nghs4sihyj3f8ch9qfib2b7ll07v5m9ziajgzsfl5xw3"; - system = "xlunit-tests"; - asd = "xlunit"; - }); - systems = [ "xlunit-tests" ]; - lispLibs = [ (getAttr "xlunit" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xml-emitter = (build-asdf-system { - pname = "xml-emitter"; - version = "20241012-git"; - asds = [ "xml-emitter" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xml-emitter/2024-10-12/xml-emitter-20241012-git.tgz"; - sha256 = "1q7iygd1v857a3c72kv4zxm9nhx94kkam4p8z5v10q2r2cwfps1w"; - system = "xml-emitter"; - asd = "xml-emitter"; - }); - systems = [ "xml-emitter" ]; - lispLibs = [ (getAttr "cl-utilities" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xml-mop = (build-asdf-system { - pname = "xml-mop"; - version = "20110418-git"; - asds = [ "xml-mop" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xml-mop/2011-04-18/xml-mop-20110418-git.tgz"; - sha256 = "1vfa3h5dghnpc7qbqqm80mm1ri6x7x5r528kvkwzngghrbxyhgjr"; - system = "xml-mop"; - asd = "xml-mop"; - }); - systems = [ "xml-mop" ]; - lispLibs = [ (getAttr "closer-mop" self) (getAttr "s-xml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xml-render = (build-asdf-system { - pname = "xml-render"; - version = "20210531-git"; - asds = [ "xml-render" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-typesetting/2021-05-31/cl-typesetting-20210531-git.tgz"; - sha256 = "0fcs5mq0gxfczbrg7ay8r4bf5r4g6blvpdbjkhcl8dapcikyn35h"; - system = "xml-render"; - asd = "xml-render"; - }); - systems = [ "xml-render" ]; - lispLibs = [ (getAttr "cl-typesetting" self) (getAttr "xmls" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xml_dot_location = (build-asdf-system { - pname = "xml.location"; - version = "20200325-git"; - asds = [ "xml.location" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xml.location/2020-03-25/xml.location-20200325-git.tgz"; - sha256 = "0ajl03k7krns6b0z3ykmngq3i77yd2j85z3h76drlc9whxvm2kii"; - system = "xml.location"; - asd = "xml.location"; - }); - systems = [ "xml.location" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "closer-mop" self) (getAttr "cxml-stp" self) (getAttr "iterate" self) (getAttr "let-plus" self) (getAttr "more-conditions" self) (getAttr "split-sequence" self) (getAttr "xpath" self) ]; - meta = {}; - }); - xml_dot_location-and-local-time = (build-asdf-system { - pname = "xml.location-and-local-time"; - version = "20200325-git"; - asds = [ "xml.location-and-local-time" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xml.location/2020-03-25/xml.location-20200325-git.tgz"; - sha256 = "0ajl03k7krns6b0z3ykmngq3i77yd2j85z3h76drlc9whxvm2kii"; - system = "xml.location-and-local-time"; - asd = "xml.location-and-local-time"; - }); - systems = [ "xml.location-and-local-time" ]; - lispLibs = [ (getAttr "local-time" self) (getAttr "xml_dot_location" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xmls = (build-asdf-system { - pname = "xmls"; - version = "release-310ba849-git"; - asds = [ "xmls" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xmls/2023-10-21/xmls-release-310ba849-git.tgz"; - sha256 = "0s1acd2r77v6x9f2kmd15njkmvvx3ivivlk509ndgmdhnn2jd776"; - system = "xmls"; - asd = "xmls"; - }); - systems = [ "xmls" ]; - lispLibs = [ ]; - meta = {}; - }); - xoverlay = (build-asdf-system { - pname = "xoverlay"; - version = "20130615-git"; - asds = [ "xoverlay" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-libxml2/2013-06-15/cl-libxml2-20130615-git.tgz"; - sha256 = "09049c13cfp5sc6x9lrw762jd7a9qkfq5jgngqgrzn4kn9qscarw"; - system = "xoverlay"; - asd = "xoverlay"; - }); - systems = [ "xoverlay" ]; - lispLibs = [ (getAttr "cl-libxml2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xpath = (build-asdf-system { - pname = "xpath"; - version = "20190521-git"; - asds = [ "xpath" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/plexippus-xpath/2019-05-21/plexippus-xpath-20190521-git.tgz"; - sha256 = "1fb03fgnzrvh22lw1jdg04pmyja5fib5n42rzwp5mhr829yvxkvp"; - system = "xpath"; - asd = "xpath"; - }); - systems = [ "xpath" ]; - lispLibs = [ (getAttr "cl-ppcre" self) (getAttr "cxml" self) (getAttr "parse-number" self) (getAttr "yacc" self) ]; - meta = {}; - }); - xptest = (build-asdf-system { - pname = "xptest"; - version = "20150923-git"; - asds = [ "xptest" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xptest/2015-09-23/xptest-20150923-git.tgz"; - sha256 = "02jwncq5d60l77gf87ahabzg6k6c878gfc4x1mf6ld97rj5lzp3b"; - system = "xptest"; - asd = "xptest"; - }); - systems = [ "xptest" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xsubseq = (build-asdf-system { - pname = "xsubseq"; - version = "20170830-git"; - asds = [ "xsubseq" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xsubseq/2017-08-30/xsubseq-20170830-git.tgz"; - sha256 = "1xz79q0p2mclf3sqjiwf6izdpb6xrsr350bv4mlmdlm6rg5r99px"; - system = "xsubseq"; - asd = "xsubseq"; - }); - systems = [ "xsubseq" ]; - lispLibs = [ ]; - meta = {}; - }); - xsubseq-test = (build-asdf-system { - pname = "xsubseq-test"; - version = "20170830-git"; - asds = [ "xsubseq-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xsubseq/2017-08-30/xsubseq-20170830-git.tgz"; - sha256 = "1xz79q0p2mclf3sqjiwf6izdpb6xrsr350bv4mlmdlm6rg5r99px"; - system = "xsubseq-test"; - asd = "xsubseq-test"; - }); - systems = [ "xsubseq-test" ]; - lispLibs = [ (getAttr "prove" self) (getAttr "prove-asdf" self) (getAttr "xsubseq" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - xuriella = (build-asdf-system { - pname = "xuriella"; - version = "20120305-git"; - asds = [ "xuriella" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/xuriella/2012-03-05/xuriella-20120305-git.tgz"; - sha256 = "0wz98bfvr7h7g0r7dy815brq5sz3x40281hp0qk801q17aa4qhqh"; - system = "xuriella"; - asd = "xuriella"; - }); - systems = [ "xuriella" ]; - lispLibs = [ (getAttr "closure-html" self) (getAttr "cxml" self) (getAttr "cxml-stp" self) (getAttr "split-sequence" self) (getAttr "xpath" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - yacc = (build-asdf-system { - pname = "yacc"; - version = "20230214-git"; - asds = [ "yacc" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-yacc/2023-02-14/cl-yacc-20230214-git.tgz"; - sha256 = "1f974ysi7mlrksnqg63iwwxgbypkng4n240q29imkrz6m5pwdig7"; - system = "yacc"; - asd = "yacc"; - }); - systems = [ "yacc" ]; - lispLibs = [ ]; - meta = {}; - }); - yaclml = (build-asdf-system { - pname = "yaclml"; - version = "20180131-git"; - asds = [ "yaclml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/yaclml/2018-01-31/yaclml-20180131-git.tgz"; - sha256 = "0wq6clk4qwbdaf0hcfjz4vg27nyf6ng0rrip1ay4rlkb03hdnssq"; - system = "yaclml"; - asd = "yaclml"; - }); - systems = [ "yaclml" ]; - lispLibs = [ (getAttr "arnesi" self) (getAttr "iterate" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - yadd = (build-asdf-system { - pname = "yadd"; - version = "master-fe503896-git"; - asds = [ "yadd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; - sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; - system = "yadd"; - asd = "yadd"; - }); - systems = [ "yadd" ]; - lispLibs = [ (getAttr "cl-html-parse" self) (getAttr "gwl-graphics" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - yah = (build-asdf-system { - pname = "yah"; - version = "20231021-git"; - asds = [ "yah" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/yah/2023-10-21/yah-20231021-git.tgz"; - sha256 = "1sklx9ak2rh9h19805i9wbym889pwd1qh3d4c4fsk9cbj2i9yxx5"; - system = "yah"; - asd = "yah"; - }); - systems = [ "yah" ]; - lispLibs = [ (getAttr "mgl-pax" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - yason = (build-asdf-system { - pname = "yason"; - version = "20241012-git"; - asds = [ "yason" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/yason/2024-10-12/yason-20241012-git.tgz"; - sha256 = "00hqii9n6ay5cq1ahbqpnw3l3v0mmz5s1f9kn6l35g8zxj1nlpa7"; - system = "yason"; - asd = "yason"; - }); - systems = [ "yason" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "trivial-gray-streams" self) ]; - meta = {}; - }); - yason-tests = (build-asdf-system { - pname = "yason-tests"; - version = "20241012-git"; - asds = [ "yason-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/yason/2024-10-12/yason-20241012-git.tgz"; - sha256 = "00hqii9n6ay5cq1ahbqpnw3l3v0mmz5s1f9kn6l35g8zxj1nlpa7"; - system = "yason-tests"; - asd = "yason-tests"; - }); - systems = [ "yason-tests" ]; - lispLibs = [ (getAttr "unit-test" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - youtube = (build-asdf-system { - pname = "youtube"; - version = "20191227-git"; - asds = [ "youtube" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/youtube/2019-12-27/youtube-20191227-git.tgz"; - sha256 = "0rqbyxgb9v3m8rwx2agaz7cq83w9k8gy5wl5wbw0rfg7r88ah5z0"; - system = "youtube"; - asd = "youtube"; - }); - systems = [ "youtube" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "cl-ppcre" self) (getAttr "yason" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - yxorp = (build-asdf-system { - pname = "yxorp"; - version = "20231021-git"; - asds = [ "yxorp" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-yxorp/2023-10-21/cl-yxorp-20231021-git.tgz"; - sha256 = "0l84icr1d3z2k6rs92lgkghwqm6w3i87d1sz4c8mpfcyfb5shgzn"; - system = "yxorp"; - asd = "yxorp"; - }); - systems = [ "yxorp" ]; - lispLibs = [ (getAttr "binding-arrows" self) (getAttr "chipz" self) (getAttr "chunga" self) (getAttr "cl_plus_ssl" self) (getAttr "flexi-streams" self) (getAttr "rutils" self) (getAttr "salza2" self) (getAttr "smart-buffer" self) (getAttr "str" self) (getAttr "trivial-garbage" self) (getAttr "usocket" self) (getAttr "usocket-server" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zacl = (build-asdf-system { - pname = "zacl"; - version = "20230618-git"; - asds = [ "zacl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zacl/2023-06-18/zacl-20230618-git.tgz"; - sha256 = "1s31d47zx8hczim78zrqzg4bvj4bshj31gmrff065q6racx3q1dk"; - system = "zacl"; - asd = "zacl"; - }); - systems = [ "zacl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "atomics" self) (getAttr "babel-streams" self) (getAttr "bordeaux-threads" self) (getAttr "cl_plus_ssl" self) (getAttr "cl-base64" self) (getAttr "cl-ppcre" self) (getAttr "cl-store" self) (getAttr "local-time" self) (getAttr "md5" self) (getAttr "queues_dot_simple-queue" self) (getAttr "quri" self) (getAttr "setup-cl_plus_ssl" self) (getAttr "split-sequence" self) (getAttr "trivial-backtrace" self) (getAttr "trivial-garbage" self) (getAttr "usocket" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zaserve = (build-asdf-system { - pname = "zaserve"; - version = "20230618-git"; - asds = [ "zaserve" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/aserve/2023-06-18/aserve-20230618-git.tgz"; - sha256 = "1i88264yghlb4brdh58hn9cps695gh63b6w6i8dmsd9rqwhlsibi"; - system = "zaserve"; - asd = "zaserve"; - }); - systems = [ "zaserve" ]; - lispLibs = [ (getAttr "setup-cl_plus_ssl" self) (getAttr "zacl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zaws = (build-asdf-system { - pname = "zaws"; - version = "20150407-git"; - asds = [ "zaws" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zaws/2015-04-07/zaws-20150407-git.tgz"; - sha256 = "1iwjyqzm4b44in7i53z5lp8n4gzsi27ch02ql6y2vxbmq3sqffaw"; - system = "zaws"; - asd = "zaws"; - }); - systems = [ "zaws" ]; - lispLibs = [ (getAttr "cl-base64" self) (getAttr "drakma" self) (getAttr "flexi-streams" self) (getAttr "ironclad" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zaws-xml = (build-asdf-system { - pname = "zaws-xml"; - version = "20150407-git"; - asds = [ "zaws-xml" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zaws/2015-04-07/zaws-20150407-git.tgz"; - sha256 = "1iwjyqzm4b44in7i53z5lp8n4gzsi27ch02ql6y2vxbmq3sqffaw"; - system = "zaws-xml"; - asd = "zaws-xml"; - }); - systems = [ "zaws-xml" ]; - lispLibs = [ (getAttr "cxml" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zbucium = (build-asdf-system { - pname = "zbucium"; - version = "20190710-git"; - asds = [ "zbucium" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zbucium/2019-07-10/zbucium-20190710-git.tgz"; - sha256 = "112qx8lwcsaipnnypv2jr57lwhlgzb5n53wgck3r66b8vjjb91gy"; - system = "zbucium"; - asd = "zbucium"; - }); - systems = [ "zbucium" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "bordeaux-threads" self) (getAttr "drakma" self) (getAttr "fare-memoization" self) (getAttr "generators" self) (getAttr "lastfm" self) (getAttr "local-time" self) (getAttr "lquery" self) (getAttr "lyrics" self) (getAttr "plump" self) (getAttr "yason" self) (getAttr "youtube" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zcdb = (build-asdf-system { - pname = "zcdb"; - version = "1.0.4"; - asds = [ "zcdb" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zcdb/2015-04-07/zcdb-1.0.4.tgz"; - sha256 = "1g83hqivh40xrpifm9v1vx92h13g5kzn12fjrlk57fyl1qwjqdi7"; - system = "zcdb"; - asd = "zcdb"; - }); - systems = [ "zcdb" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zenekindarl = (build-asdf-system { - pname = "zenekindarl"; - version = "20171130-git"; - asds = [ "zenekindarl" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zenekindarl/2017-11-30/zenekindarl-20171130-git.tgz"; - sha256 = "104y98j8fjj4wry55mhgv3g6358h5n1qcbhpn19b27b8cs8gqwib"; - system = "zenekindarl"; - asd = "zenekindarl"; - }); - systems = [ "zenekindarl" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "anaphora" self) (getAttr "babel" self) (getAttr "cl-annot" self) (getAttr "cl-ppcre" self) (getAttr "fast-io" self) (getAttr "html-encode" self) (getAttr "maxpc" self) (getAttr "optima" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zenekindarl-test = (build-asdf-system { - pname = "zenekindarl-test"; - version = "20171130-git"; - asds = [ "zenekindarl-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zenekindarl/2017-11-30/zenekindarl-20171130-git.tgz"; - sha256 = "104y98j8fjj4wry55mhgv3g6358h5n1qcbhpn19b27b8cs8gqwib"; - system = "zenekindarl-test"; - asd = "zenekindarl-test"; - }); - systems = [ "zenekindarl-test" ]; - lispLibs = [ (getAttr "flexi-streams" self) (getAttr "prove" self) (getAttr "zenekindarl" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zeromq = (build-asdf-system { - pname = "zeromq"; - version = "20160318-git"; - asds = [ "zeromq" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-zmq/2016-03-18/cl-zmq-20160318-git.tgz"; - sha256 = "0g19ych3n57qdd42m0bcdcrq8c1p0fqzz07xrxl0s0g8bms3a3ga"; - system = "zeromq"; - asd = "zeromq"; - }); - systems = [ "zeromq" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zeromq_dot_tests = (build-asdf-system { - pname = "zeromq.tests"; - version = "20160318-git"; - asds = [ "zeromq.tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-zmq/2016-03-18/cl-zmq-20160318-git.tgz"; - sha256 = "0g19ych3n57qdd42m0bcdcrq8c1p0fqzz07xrxl0s0g8bms3a3ga"; - system = "zeromq.tests"; - asd = "zeromq"; - }); - systems = [ "zeromq.tests" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "fiveam" self) (getAttr "zeromq" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zip = (build-asdf-system { - pname = "zip"; - version = "20150608-git"; - asds = [ "zip" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zip/2015-06-08/zip-20150608-git.tgz"; - sha256 = "0s08a6fq182fzsbfyvihqbdllq6gxcwkvphxnrd9wwz65dhg5y66"; - system = "zip"; - asd = "zip"; - }); - systems = [ "zip" ]; - lispLibs = [ (getAttr "babel" self) (getAttr "cl-fad" self) (getAttr "salza2" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zippy = (build-asdf-system { - pname = "zippy"; - version = "20241012-git"; - asds = [ "zippy" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zippy/2024-10-12/zippy-20241012-git.tgz"; - sha256 = "06znhzi4zjg2p2858cwnlslqvx28zlmqr9jqij0rkvnn7ysa7qcg"; - system = "zippy"; - asd = "zippy"; - }); - systems = [ "zippy" ]; - lispLibs = [ (getAttr "_3bz" self) (getAttr "alexandria" self) (getAttr "babel" self) (getAttr "documentation-utils" self) (getAttr "file-attributes" self) (getAttr "filesystem-utils" self) (getAttr "nibbles" self) (getAttr "pathname-utils" self) (getAttr "salza2" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zippy-dwim = (build-asdf-system { - pname = "zippy-dwim"; - version = "20241012-git"; - asds = [ "zippy-dwim" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zippy/2024-10-12/zippy-20241012-git.tgz"; - sha256 = "06znhzi4zjg2p2858cwnlslqvx28zlmqr9jqij0rkvnn7ysa7qcg"; - system = "zippy-dwim"; - asd = "zippy-dwim"; - }); - systems = [ "zippy-dwim" ]; - lispLibs = [ (getAttr "deploy" self) (getAttr "zippy" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - ziz = (build-asdf-system { - pname = "ziz"; - version = "20191007-git"; - asds = [ "ziz" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/ziz/2019-10-07/ziz-20191007-git.tgz"; - sha256 = "1rh6ixkyyj7y9jkw046m4ilmr8a12ylzm0a7sm8mjybdpkh6bk30"; - system = "ziz"; - asd = "ziz"; - }); - systems = [ "ziz" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "hunchentoot" self) (getAttr "ironclad" self) (getAttr "trivial-file-size" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zlib = (build-asdf-system { - pname = "zlib"; - version = "20170403-git"; - asds = [ "zlib" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zlib/2017-04-03/zlib-20170403-git.tgz"; - sha256 = "1gz771h2q3xhw1yxpwki5zr9mqysa818vn21501w6fsi8wlmlffa"; - system = "zlib"; - asd = "zlib"; - }); - systems = [ "zlib" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zmq = (build-asdf-system { - pname = "zmq"; - version = "20200218-git"; - asds = [ "zmq" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-zmq/2020-02-18/lisp-zmq-20200218-git.tgz"; - sha256 = "01aavmnn2lbsaq957p1qll21hmhvhkrqhq3kazmz88sc40x1n0ld"; - system = "zmq"; - asd = "zmq"; - }); - systems = [ "zmq" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "trivial-features" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zmq-examples = (build-asdf-system { - pname = "zmq-examples"; - version = "20200218-git"; - asds = [ "zmq-examples" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-zmq/2020-02-18/lisp-zmq-20200218-git.tgz"; - sha256 = "01aavmnn2lbsaq957p1qll21hmhvhkrqhq3kazmz88sc40x1n0ld"; - system = "zmq-examples"; - asd = "zmq-examples"; - }); - systems = [ "zmq-examples" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "zmq" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zmq-test = (build-asdf-system { - pname = "zmq-test"; - version = "20200218-git"; - asds = [ "zmq-test" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/lisp-zmq/2020-02-18/lisp-zmq-20200218-git.tgz"; - sha256 = "01aavmnn2lbsaq957p1qll21hmhvhkrqhq3kazmz88sc40x1n0ld"; - system = "zmq-test"; - asd = "zmq-test"; - }); - systems = [ "zmq-test" ]; - lispLibs = [ (getAttr "bordeaux-threads" self) (getAttr "fiveam" self) (getAttr "zmq" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zpb-exif = (build-asdf-system { - pname = "zpb-exif"; - version = "release-1.2.5"; - asds = [ "zpb-exif" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zpb-exif/2021-01-24/zpb-exif-release-1.2.5.tgz"; - sha256 = "0h1n36lfl8xn8rfyl5jxz9m8zlg0if2avmryas79f684yczrvdnd"; - system = "zpb-exif"; - asd = "zpb-exif"; - }); - systems = [ "zpb-exif" ]; - lispLibs = [ ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zpb-ttf = (build-asdf-system { - pname = "zpb-ttf"; - version = "release-1.0.7"; - asds = [ "zpb-ttf" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zpb-ttf/2024-10-12/zpb-ttf-release-1.0.7.tgz"; - sha256 = "04lph7i153zlswvpgg76fxazyswj8j0idqm4ysn8qmflb7xcvd78"; - system = "zpb-ttf"; - asd = "zpb-ttf"; - }); - systems = [ "zpb-ttf" ]; - lispLibs = [ ]; - meta = {}; - }); - zpng = (build-asdf-system { - pname = "zpng"; - version = "1.2.2"; - asds = [ "zpng" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zpng/2015-04-07/zpng-1.2.2.tgz"; - sha256 = "0b3ag3jhl3z7kdls3ahdsdxsfhhw5qrizk769984f4wkxhb69rcm"; - system = "zpng"; - asd = "zpng"; - }); - systems = [ "zpng" ]; - lispLibs = [ (getAttr "salza2" self) ]; - meta = {}; - }); - zs3 = (build-asdf-system { - pname = "zs3"; - version = "1.3.3"; - asds = [ "zs3" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zs3/2019-10-07/zs3-1.3.3.tgz"; - sha256 = "186v95wgsj2hkxdw2jl9x1w4fddjclp7arp0rrd9vf5ly8h8sbf3"; - system = "zs3"; - asd = "zs3"; - }); - systems = [ "zs3" ]; - lispLibs = [ (getAttr "alexandria" self) (getAttr "cl-base64" self) (getAttr "cxml" self) (getAttr "drakma" self) (getAttr "ironclad" self) (getAttr "puri" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zsort = (build-asdf-system { - pname = "zsort"; - version = "20120520-git"; - asds = [ "zsort" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/zsort/2012-05-20/zsort-20120520-git.tgz"; - sha256 = "1vyklyh99712zsll4qi0m4mm8yb1nz04403vl8i57bjv5p5max49"; - system = "zsort"; - asd = "zsort"; - }); - systems = [ "zsort" ]; - lispLibs = [ (getAttr "alexandria" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zstd = (build-asdf-system { - pname = "zstd"; - version = "20230618-git"; - asds = [ "zstd" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-zstd/2023-06-18/cl-zstd-20230618-git.tgz"; - sha256 = "037igr1v849smcs6svjb5s850k5s5yfg74d4gb3ir4b4v9g4k97i"; - system = "zstd"; - asd = "zstd"; - }); - systems = [ "zstd" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cl-octet-streams" self) (getAttr "trivial-gray-streams" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zstd-tests = (build-asdf-system { - pname = "zstd-tests"; - version = "20230618-git"; - asds = [ "zstd-tests" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-zstd/2023-06-18/cl-zstd-20230618-git.tgz"; - sha256 = "037igr1v849smcs6svjb5s850k5s5yfg74d4gb3ir4b4v9g4k97i"; - system = "zstd-tests"; - asd = "zstd-tests"; - }); - systems = [ "zstd-tests" ]; - lispLibs = [ (getAttr "cl-octet-streams" self) (getAttr "fiveam" self) (getAttr "zstd" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); - zyre = (build-asdf-system { - pname = "zyre"; - version = "20200925-git"; - asds = [ "zyre" ]; - src = (createAsd { - url = "http://beta.quicklisp.org/archive/cl-zyre/2020-09-25/cl-zyre-20200925-git.tgz"; - sha256 = "1pfb176k655hxksyrans5j43ridvpkl8q8h6d37zgi2z4iiz15wv"; - system = "zyre"; - asd = "zyre"; - }); - systems = [ "zyre" ]; - lispLibs = [ (getAttr "cffi" self) (getAttr "cffi-grovel" self) (getAttr "trivia" self) (getAttr "trivial-garbage" self) ]; - meta = { - hydraPlatforms = [ ]; - }; - }); + # Ensures that every non-slashy `system` exists in a unique .asd file. + # (Think cl-async-base being declared in cl-async.asd upstream) + # + # This is required because we're building and loading a system called + # `system`, not `asd`, so otherwise `system` would not be loadable + # without building and loading `asd` first. + # + createAsd = + { + url, + sha256, + asd, + system, + }: + let + src = fetchzip { inherit url sha256; }; + in + if asd == system then + src + else + runCommand "source" { } '' + mkdir -pv $out + cp -r ${src}/* $out + find $out -name "${asd}.asd" | while read f; do mv -fv $f $(dirname $f)/${system}.asd || true; done + ''; +in +lib.makeScope pkgs.newScope (self: { + _1am = ( + build-asdf-system { + pname = "1am"; + version = "20141106-git"; + asds = [ "1am" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/1am/2014-11-06/1am-20141106-git.tgz"; + sha256 = "05ss4nz1jb9kb796295482b62w5cj29msfj8zis33sp2rw2vmv2g"; + system = "1am"; + asd = "1am"; + } + ); + systems = [ "1am" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _2d-array = ( + build-asdf-system { + pname = "2d-array"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "2d-array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "2d-array"; + asd = "2d-array"; + } + ); + systems = [ "2d-array" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _2d-array-test = ( + build-asdf-system { + pname = "2d-array-test"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "2d-array-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "2d-array-test"; + asd = "2d-array-test"; + } + ); + systems = [ "2d-array-test" ]; + lispLibs = [ + (getAttr "_2d-array" self) + (getAttr "scrutiny" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3b-bmfont = ( + build-asdf-system { + pname = "3b-bmfont"; + version = "20241012-git"; + asds = [ "3b-bmfont" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3b-bmfont/2024-10-12/3b-bmfont-20241012-git.tgz"; + sha256 = "1zmkmhw8ma2j8p6crw0x6am6fx95rxkb1n3fqlgvs2rxdk273dan"; + system = "3b-bmfont"; + asd = "3b-bmfont"; + } + ); + systems = [ "3b-bmfont" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "parse-number" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3b-hdr = ( + build-asdf-system { + pname = "3b-hdr"; + version = "20200925-git"; + asds = [ "3b-hdr" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3b-hdr/2020-09-25/3b-hdr-20200925-git.tgz"; + sha256 = "0bvpdzz88xjwvqapjnkdr44ds3gh5xl3r6r1c2y7x9d6lnvc38jq"; + system = "3b-hdr"; + asd = "3b-hdr"; + } + ); + systems = [ "3b-hdr" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "parse-number" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3b-swf = ( + build-asdf-system { + pname = "3b-swf"; + version = "20120107-git"; + asds = [ "3b-swf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3b-swf/2012-01-07/3b-swf-20120107-git.tgz"; + sha256 = "1d74045b6zfxjf0as8n5ji14j5cxsdi3qkqkzcdy3i83whbxkcbm"; + system = "3b-swf"; + asd = "3b-swf"; + } + ); + systems = [ "3b-swf" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "chipz" self) + (getAttr "cl-jpeg" self) + (getAttr "cxml" self) + (getAttr "flexi-streams" self) + (getAttr "ieee-floats" self) + (getAttr "salza2" self) + (getAttr "vecto" self) + (getAttr "zpng" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3b-swf-swc = ( + build-asdf-system { + pname = "3b-swf-swc"; + version = "20120107-git"; + asds = [ "3b-swf-swc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3b-swf/2012-01-07/3b-swf-20120107-git.tgz"; + sha256 = "1d74045b6zfxjf0as8n5ji14j5cxsdi3qkqkzcdy3i83whbxkcbm"; + system = "3b-swf-swc"; + asd = "3b-swf-swc"; + } + ); + systems = [ "3b-swf-swc" ]; + lispLibs = [ + (getAttr "_3b-swf" self) + (getAttr "cxml" self) + (getAttr "zip" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3bgl-shader = ( + build-asdf-system { + pname = "3bgl-shader"; + version = "20241012-git"; + asds = [ "3bgl-shader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3bgl-shader/2024-10-12/3bgl-shader-20241012-git.tgz"; + sha256 = "06v9a3m0cwhj2m5nz20shzgz3362sd7bv011rlknm4nz6i4q5bzz"; + system = "3bgl-shader"; + asd = "3bgl-shader"; + } + ); + systems = [ "3bgl-shader" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-opengl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3bgl-shader-example = ( + build-asdf-system { + pname = "3bgl-shader-example"; + version = "20241012-git"; + asds = [ "3bgl-shader-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3bgl-shader/2024-10-12/3bgl-shader-20241012-git.tgz"; + sha256 = "06v9a3m0cwhj2m5nz20shzgz3362sd7bv011rlknm4nz6i4q5bzz"; + system = "3bgl-shader-example"; + asd = "3bgl-shader-example"; + } + ); + systems = [ "3bgl-shader-example" ]; + lispLibs = [ + (getAttr "_3bgl-shader" self) + (getAttr "cl-glu" self) + (getAttr "cl-glut" self) + (getAttr "mathkit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3bmd = ( + build-asdf-system { + pname = "3bmd"; + version = "20241012-git"; + asds = [ "3bmd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; + sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; + system = "3bmd"; + asd = "3bmd"; + } + ); + systems = [ "3bmd" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "esrap" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3bmd-ext-code-blocks = ( + build-asdf-system { + pname = "3bmd-ext-code-blocks"; + version = "20241012-git"; + asds = [ "3bmd-ext-code-blocks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; + sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; + system = "3bmd-ext-code-blocks"; + asd = "3bmd-ext-code-blocks"; + } + ); + systems = [ "3bmd-ext-code-blocks" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "alexandria" self) + (getAttr "colorize" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3bmd-ext-definition-lists = ( + build-asdf-system { + pname = "3bmd-ext-definition-lists"; + version = "20241012-git"; + asds = [ "3bmd-ext-definition-lists" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; + sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; + system = "3bmd-ext-definition-lists"; + asd = "3bmd-ext-definition-lists"; + } + ); + systems = [ "3bmd-ext-definition-lists" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "alexandria" self) + (getAttr "colorize" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3bmd-ext-math = ( + build-asdf-system { + pname = "3bmd-ext-math"; + version = "20241012-git"; + asds = [ "3bmd-ext-math" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; + sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; + system = "3bmd-ext-math"; + asd = "3bmd-ext-math"; + } + ); + systems = [ "3bmd-ext-math" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "esrap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3bmd-ext-tables = ( + build-asdf-system { + pname = "3bmd-ext-tables"; + version = "20241012-git"; + asds = [ "3bmd-ext-tables" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; + sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; + system = "3bmd-ext-tables"; + asd = "3bmd-ext-tables"; + } + ); + systems = [ "3bmd-ext-tables" ]; + lispLibs = [ (getAttr "_3bmd" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3bmd-ext-wiki-links = ( + build-asdf-system { + pname = "3bmd-ext-wiki-links"; + version = "20241012-git"; + asds = [ "3bmd-ext-wiki-links" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; + sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; + system = "3bmd-ext-wiki-links"; + asd = "3bmd-ext-wiki-links"; + } + ); + systems = [ "3bmd-ext-wiki-links" ]; + lispLibs = [ (getAttr "_3bmd" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3bmd-tests = ( + build-asdf-system { + pname = "3bmd-tests"; + version = "20241012-git"; + asds = [ "3bmd-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; + sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; + system = "3bmd-tests"; + asd = "3bmd-tests"; + } + ); + systems = [ "3bmd-tests" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "_3bmd-ext-code-blocks" self) + (getAttr "fiasco" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3bmd-youtube = ( + build-asdf-system { + pname = "3bmd-youtube"; + version = "20241012-git"; + asds = [ "3bmd-youtube" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; + sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; + system = "3bmd-youtube"; + asd = "3bmd-youtube"; + } + ); + systems = [ "3bmd-youtube" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "esrap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3bmd-youtube-tests = ( + build-asdf-system { + pname = "3bmd-youtube-tests"; + version = "20241012-git"; + asds = [ "3bmd-youtube-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3bmd/2024-10-12/3bmd-20241012-git.tgz"; + sha256 = "166pn6qr8n3513673afmln2ayy7kgbgfx45hfmvhmk71xjvq19zv"; + system = "3bmd-youtube-tests"; + asd = "3bmd-youtube-tests"; + } + ); + systems = [ "3bmd-youtube-tests" ]; + lispLibs = [ + (getAttr "_3bmd-youtube" self) + (getAttr "fiasco" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3bz = ( + build-asdf-system { + pname = "3bz"; + version = "20230618-git"; + asds = [ "3bz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3bz/2023-06-18/3bz-20230618-git.tgz"; + sha256 = "0qdnxj2sn185l0jnp4zjlh5la14pxkgp1hmcyw4d2zwx30sc37p7"; + system = "3bz"; + asd = "3bz"; + } + ); + systems = [ "3bz" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "mmap" self) + (getAttr "nibbles" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3d-math = ( + build-asdf-system { + pname = "3d-math"; + version = "20241012-git"; + asds = [ "3d-math" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3d-math/2024-10-12/3d-math-20241012-git.tgz"; + sha256 = "01xnzizy76ypypzpqrg9fwnxfl5mlldc554b0791rsckkhh35xvd"; + system = "3d-math"; + asd = "3d-math"; + } + ); + systems = [ "3d-math" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "type-templates" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3d-math-test = ( + build-asdf-system { + pname = "3d-math-test"; + version = "20241012-git"; + asds = [ "3d-math-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3d-math/2024-10-12/3d-math-20241012-git.tgz"; + sha256 = "01xnzizy76ypypzpqrg9fwnxfl5mlldc554b0791rsckkhh35xvd"; + system = "3d-math-test"; + asd = "3d-math-test"; + } + ); + systems = [ "3d-math-test" ]; + lispLibs = [ + (getAttr "_3d-math" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3d-matrices = ( + build-asdf-system { + pname = "3d-matrices"; + version = "20231021-git"; + asds = [ "3d-matrices" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3d-matrices/2023-10-21/3d-matrices-20231021-git.tgz"; + sha256 = "0kn68awww0h8gwiqih8a65d2p34q3qh4z5ji2g5ja99vgpr1498q"; + system = "3d-matrices"; + asd = "3d-matrices"; + } + ); + systems = [ "3d-matrices" ]; + lispLibs = [ + (getAttr "_3d-vectors" self) + (getAttr "documentation-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3d-matrices-test = ( + build-asdf-system { + pname = "3d-matrices-test"; + version = "20231021-git"; + asds = [ "3d-matrices-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3d-matrices/2023-10-21/3d-matrices-20231021-git.tgz"; + sha256 = "0kn68awww0h8gwiqih8a65d2p34q3qh4z5ji2g5ja99vgpr1498q"; + system = "3d-matrices-test"; + asd = "3d-matrices-test"; + } + ); + systems = [ "3d-matrices-test" ]; + lispLibs = [ + (getAttr "_3d-matrices" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3d-quaternions = ( + build-asdf-system { + pname = "3d-quaternions"; + version = "20231021-git"; + asds = [ "3d-quaternions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3d-quaternions/2023-10-21/3d-quaternions-20231021-git.tgz"; + sha256 = "1m72g2rn1n5xsqaa50qbj6hcp8b4gk7xsld4qaly788bwscparl8"; + system = "3d-quaternions"; + asd = "3d-quaternions"; + } + ); + systems = [ "3d-quaternions" ]; + lispLibs = [ + (getAttr "_3d-matrices" self) + (getAttr "_3d-vectors" self) + (getAttr "documentation-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3d-quaternions-test = ( + build-asdf-system { + pname = "3d-quaternions-test"; + version = "20231021-git"; + asds = [ "3d-quaternions-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3d-quaternions/2023-10-21/3d-quaternions-20231021-git.tgz"; + sha256 = "1m72g2rn1n5xsqaa50qbj6hcp8b4gk7xsld4qaly788bwscparl8"; + system = "3d-quaternions-test"; + asd = "3d-quaternions-test"; + } + ); + systems = [ "3d-quaternions-test" ]; + lispLibs = [ + (getAttr "_3d-quaternions" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3d-spaces = ( + build-asdf-system { + pname = "3d-spaces"; + version = "20241012-git"; + asds = [ "3d-spaces" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3d-spaces/2024-10-12/3d-spaces-20241012-git.tgz"; + sha256 = "170f2hyvrf3mvkfg9mj7rg2zafcnqbm9h9c29y716ppq1vk1pxhc"; + system = "3d-spaces"; + asd = "3d-spaces"; + } + ); + systems = [ "3d-spaces" ]; + lispLibs = [ + (getAttr "_3d-math" self) + (getAttr "documentation-utils" self) + (getAttr "for" self) + (getAttr "trivial-extensible-sequences" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3d-spaces-test = ( + build-asdf-system { + pname = "3d-spaces-test"; + version = "20241012-git"; + asds = [ "3d-spaces-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3d-spaces/2024-10-12/3d-spaces-20241012-git.tgz"; + sha256 = "170f2hyvrf3mvkfg9mj7rg2zafcnqbm9h9c29y716ppq1vk1pxhc"; + system = "3d-spaces-test"; + asd = "3d-spaces-test"; + } + ); + systems = [ "3d-spaces-test" ]; + lispLibs = [ + (getAttr "_3d-spaces" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3d-transforms = ( + build-asdf-system { + pname = "3d-transforms"; + version = "20231021-git"; + asds = [ "3d-transforms" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3d-transforms/2023-10-21/3d-transforms-20231021-git.tgz"; + sha256 = "0876pih289fgn8maclihiz9xl66zbi4nbznpdq2xpfbsr1k4sihy"; + system = "3d-transforms"; + asd = "3d-transforms"; + } + ); + systems = [ "3d-transforms" ]; + lispLibs = [ + (getAttr "_3d-matrices" self) + (getAttr "_3d-quaternions" self) + (getAttr "_3d-vectors" self) + (getAttr "documentation-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3d-transforms-test = ( + build-asdf-system { + pname = "3d-transforms-test"; + version = "20231021-git"; + asds = [ "3d-transforms-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3d-transforms/2023-10-21/3d-transforms-20231021-git.tgz"; + sha256 = "0876pih289fgn8maclihiz9xl66zbi4nbznpdq2xpfbsr1k4sihy"; + system = "3d-transforms-test"; + asd = "3d-transforms-test"; + } + ); + systems = [ "3d-transforms-test" ]; + lispLibs = [ + (getAttr "_3d-transforms" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3d-vectors = ( + build-asdf-system { + pname = "3d-vectors"; + version = "20231021-git"; + asds = [ "3d-vectors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3d-vectors/2023-10-21/3d-vectors-20231021-git.tgz"; + sha256 = "0y3iwb0bvxf8ixgsbg3idlx91k3lim9na53fasb4scnhlmpsbk28"; + system = "3d-vectors"; + asd = "3d-vectors"; + } + ); + systems = [ "3d-vectors" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _3d-vectors-test = ( + build-asdf-system { + pname = "3d-vectors-test"; + version = "20231021-git"; + asds = [ "3d-vectors-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/3d-vectors/2023-10-21/3d-vectors-20231021-git.tgz"; + sha256 = "0y3iwb0bvxf8ixgsbg3idlx91k3lim9na53fasb4scnhlmpsbk28"; + system = "3d-vectors-test"; + asd = "3d-vectors-test"; + } + ); + systems = [ "3d-vectors-test" ]; + lispLibs = [ + (getAttr "_3d-vectors" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-asdf-system = ( + build-asdf-system { + pname = "40ants-asdf-system"; + version = "20241012-git"; + asds = [ "40ants-asdf-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/40ants-asdf-system/2024-10-12/40ants-asdf-system-20241012-git.tgz"; + sha256 = "0wi575m0s0a9fvp1wy5ga760f71la16z1633qk6s2f87rwcjs8kw"; + system = "40ants-asdf-system"; + asd = "40ants-asdf-system"; + } + ); + systems = [ "40ants-asdf-system" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-asdf-system-ci = ( + build-asdf-system { + pname = "40ants-asdf-system-ci"; + version = "20241012-git"; + asds = [ "40ants-asdf-system-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/40ants-asdf-system/2024-10-12/40ants-asdf-system-20241012-git.tgz"; + sha256 = "0wi575m0s0a9fvp1wy5ga760f71la16z1633qk6s2f87rwcjs8kw"; + system = "40ants-asdf-system-ci"; + asd = "40ants-asdf-system-ci"; + } + ); + systems = [ "40ants-asdf-system-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-asdf-system-tests = ( + build-asdf-system { + pname = "40ants-asdf-system-tests"; + version = "20241012-git"; + asds = [ "40ants-asdf-system-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/40ants-asdf-system/2024-10-12/40ants-asdf-system-20241012-git.tgz"; + sha256 = "0wi575m0s0a9fvp1wy5ga760f71la16z1633qk6s2f87rwcjs8kw"; + system = "40ants-asdf-system-tests"; + asd = "40ants-asdf-system-tests"; + } + ); + systems = [ "40ants-asdf-system-tests" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-ci = ( + build-asdf-system { + pname = "40ants-ci"; + version = "20241012-git"; + asds = [ "40ants-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ci/2024-10-12/ci-20241012-git.tgz"; + sha256 = "0fmy1302c89qbhn4zc58cydcv8qc3qrl6cjbf2fy53sphnmj0wgm"; + system = "40ants-ci"; + asd = "40ants-ci"; + } + ); + systems = [ "40ants-ci" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "alexandria" self) + (getAttr "serapeum" self) + (getAttr "str" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-ci-docs = ( + build-asdf-system { + pname = "40ants-ci-docs"; + version = "20241012-git"; + asds = [ "40ants-ci-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ci/2024-10-12/ci-20241012-git.tgz"; + sha256 = "0fmy1302c89qbhn4zc58cydcv8qc3qrl6cjbf2fy53sphnmj0wgm"; + system = "40ants-ci-docs"; + asd = "40ants-ci-docs"; + } + ); + systems = [ "40ants-ci-docs" ]; + lispLibs = [ + (getAttr "_40ants-ci" self) + (getAttr "_40ants-doc" self) + (getAttr "_40ants-logging-docs" self) + (getAttr "docs-config" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-ci-tests = ( + build-asdf-system { + pname = "40ants-ci-tests"; + version = "20241012-git"; + asds = [ "40ants-ci-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ci/2024-10-12/ci-20241012-git.tgz"; + sha256 = "0fmy1302c89qbhn4zc58cydcv8qc3qrl6cjbf2fy53sphnmj0wgm"; + system = "40ants-ci-tests"; + asd = "40ants-ci-tests"; + } + ); + systems = [ "40ants-ci-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-doc = ( + build-asdf-system { + pname = "40ants-doc"; + version = "20241012-git"; + asds = [ "40ants-doc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/doc/2024-10-12/doc-20241012-git.tgz"; + sha256 = "1vkczfcdgg1dmzb5jzxvc50kywbz7il130qrj0smlg1grwgw10a2"; + system = "40ants-doc"; + asd = "40ants-doc"; + } + ); + systems = [ "40ants-doc" ]; + lispLibs = [ + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-doc-full = ( + build-asdf-system { + pname = "40ants-doc-full"; + version = "20241012-git"; + asds = [ "40ants-doc-full" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/doc/2024-10-12/doc-20241012-git.tgz"; + sha256 = "1vkczfcdgg1dmzb5jzxvc50kywbz7il130qrj0smlg1grwgw10a2"; + system = "40ants-doc-full"; + asd = "40ants-doc-full"; + } + ); + systems = [ "40ants-doc-full" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "common-doc" self) + (getAttr "common-html" self) + (getAttr "commondoc-markdown" self) + (getAttr "dexador" self) + (getAttr "docs-config" self) + (getAttr "fare-utils" self) + (getAttr "jonathan" self) + (getAttr "lass" self) + (getAttr "local-time" self) + (getAttr "log4cl" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + (getAttr "slynk" self) + (getAttr "spinneret" self) + (getAttr "stem" self) + (getAttr "str" self) + (getAttr "swank" self) + (getAttr "tmpdir" self) + (getAttr "which" self) + (getAttr "xml-emitter" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-doc-test = ( + build-asdf-system { + pname = "40ants-doc-test"; + version = "20241012-git"; + asds = [ "40ants-doc-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/doc/2024-10-12/doc-20241012-git.tgz"; + sha256 = "1vkczfcdgg1dmzb5jzxvc50kywbz7il130qrj0smlg1grwgw10a2"; + system = "40ants-doc-test"; + asd = "40ants-doc-test"; + } + ); + systems = [ "40ants-doc-test" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "alexandria" self) + (getAttr "common-doc" self) + (getAttr "common-html" self) + (getAttr "commondoc-markdown" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-logging = ( + build-asdf-system { + pname = "40ants-logging"; + version = "20241012-git"; + asds = [ "40ants-logging" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/logging/2024-10-12/logging-20241012-git.tgz"; + sha256 = "1rkh0ls12qkwxs7szvnr5fz2bi1wwxsz7z72ywnin13hisvgkkwz"; + system = "40ants-logging"; + asd = "40ants-logging"; + } + ); + systems = [ "40ants-logging" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "global-vars" self) + (getAttr "log4cl-extras" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-logging-ci = ( + build-asdf-system { + pname = "40ants-logging-ci"; + version = "20241012-git"; + asds = [ "40ants-logging-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/logging/2024-10-12/logging-20241012-git.tgz"; + sha256 = "1rkh0ls12qkwxs7szvnr5fz2bi1wwxsz7z72ywnin13hisvgkkwz"; + system = "40ants-logging-ci"; + asd = "40ants-logging-ci"; + } + ); + systems = [ "40ants-logging-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-logging-docs = ( + build-asdf-system { + pname = "40ants-logging-docs"; + version = "20241012-git"; + asds = [ "40ants-logging-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/logging/2024-10-12/logging-20241012-git.tgz"; + sha256 = "1rkh0ls12qkwxs7szvnr5fz2bi1wwxsz7z72ywnin13hisvgkkwz"; + system = "40ants-logging-docs"; + asd = "40ants-logging-docs"; + } + ); + systems = [ "40ants-logging-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "_40ants-logging" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-logging-example = ( + build-asdf-system { + pname = "40ants-logging-example"; + version = "20241012-git"; + asds = [ "40ants-logging-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/logging/2024-10-12/logging-20241012-git.tgz"; + sha256 = "1rkh0ls12qkwxs7szvnr5fz2bi1wwxsz7z72ywnin13hisvgkkwz"; + system = "40ants-logging-example"; + asd = "40ants-logging-example"; + } + ); + systems = [ "40ants-logging-example" ]; + lispLibs = [ + (getAttr "_40ants-logging" self) + (getAttr "_40ants-slynk" self) + (getAttr "defmain" self) + (getAttr "log4cl" self) + (getAttr "log4cl-extras" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-logging-tests = ( + build-asdf-system { + pname = "40ants-logging-tests"; + version = "20241012-git"; + asds = [ "40ants-logging-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/logging/2024-10-12/logging-20241012-git.tgz"; + sha256 = "1rkh0ls12qkwxs7szvnr5fz2bi1wwxsz7z72ywnin13hisvgkkwz"; + system = "40ants-logging-tests"; + asd = "40ants-logging-tests"; + } + ); + systems = [ "40ants-logging-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-slynk = ( + build-asdf-system { + pname = "40ants-slynk"; + version = "20241012-git"; + asds = [ "40ants-slynk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/40ants-slynk/2024-10-12/40ants-slynk-20241012-git.tgz"; + sha256 = "0rz32aaya177s8c4lsasyfff91b2ancjlw8bi50xz150kwqqqmmx"; + system = "40ants-slynk"; + asd = "40ants-slynk"; + } + ); + systems = [ "40ants-slynk" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "_40ants-logging" self) + (getAttr "global-vars" self) + (getAttr "log4cl" self) + (getAttr "slynk" self) + (getAttr "slynk-macrostep" self) + (getAttr "slynk-named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-slynk-ci = ( + build-asdf-system { + pname = "40ants-slynk-ci"; + version = "20241012-git"; + asds = [ "40ants-slynk-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/40ants-slynk/2024-10-12/40ants-slynk-20241012-git.tgz"; + sha256 = "0rz32aaya177s8c4lsasyfff91b2ancjlw8bi50xz150kwqqqmmx"; + system = "40ants-slynk-ci"; + asd = "40ants-slynk-ci"; + } + ); + systems = [ "40ants-slynk-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-slynk-docs = ( + build-asdf-system { + pname = "40ants-slynk-docs"; + version = "20241012-git"; + asds = [ "40ants-slynk-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/40ants-slynk/2024-10-12/40ants-slynk-20241012-git.tgz"; + sha256 = "0rz32aaya177s8c4lsasyfff91b2ancjlw8bi50xz150kwqqqmmx"; + system = "40ants-slynk-docs"; + asd = "40ants-slynk-docs"; + } + ); + systems = [ "40ants-slynk-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "_40ants-slynk" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + _40ants-slynk-tests = ( + build-asdf-system { + pname = "40ants-slynk-tests"; + version = "20241012-git"; + asds = [ "40ants-slynk-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/40ants-slynk/2024-10-12/40ants-slynk-20241012-git.tgz"; + sha256 = "0rz32aaya177s8c4lsasyfff91b2ancjlw8bi50xz150kwqqqmmx"; + system = "40ants-slynk-tests"; + asd = "40ants-slynk-tests"; + } + ); + systems = [ "40ants-slynk-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + a-cl-cairo2-loader = ( + build-asdf-system { + pname = "a-cl-cairo2-loader"; + version = "20211020-git"; + asds = [ "a-cl-cairo2-loader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cairo2/2021-10-20/cl-cairo2-20211020-git.tgz"; + sha256 = "0cpfgyxw6pz7y033dlya8c4vjmkpw127zdq3a9xclp9q8jbdlb7q"; + system = "a-cl-cairo2-loader"; + asd = "a-cl-cairo2-loader"; + } + ); + systems = [ "a-cl-cairo2-loader" ]; + lispLibs = [ (getAttr "cl-cairo2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + a-cl-logger = ( + build-asdf-system { + pname = "a-cl-logger"; + version = "20220331-git"; + asds = [ "a-cl-logger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/a-cl-logger/2022-03-31/a-cl-logger-20220331-git.tgz"; + sha256 = "0vhhbnh4akxh0ivqh8r0f2djv2nbf3l9hbbi0b5fdk9bdpziqkb4"; + system = "a-cl-logger"; + asd = "a-cl-logger"; + } + ); + systems = [ "a-cl-logger" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-interpol" self) + (getAttr "cl-json" self) + (getAttr "closer-mop" self) + (getAttr "exit-hooks" self) + (getAttr "iterate" self) + (getAttr "local-time" self) + (getAttr "osicat" self) + (getAttr "symbol-munger" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + a-cl-logger-logstash = ( + build-asdf-system { + pname = "a-cl-logger-logstash"; + version = "20220331-git"; + asds = [ "a-cl-logger-logstash" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/a-cl-logger/2022-03-31/a-cl-logger-20220331-git.tgz"; + sha256 = "0vhhbnh4akxh0ivqh8r0f2djv2nbf3l9hbbi0b5fdk9bdpziqkb4"; + system = "a-cl-logger-logstash"; + asd = "a-cl-logger-logstash"; + } + ); + systems = [ "a-cl-logger-logstash" ]; + lispLibs = [ + (getAttr "a-cl-logger" self) + (getAttr "cl-json" self) + (getAttr "zmq" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + a-cl-logger-tests = ( + build-asdf-system { + pname = "a-cl-logger-tests"; + version = "20220331-git"; + asds = [ "a-cl-logger-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/a-cl-logger/2022-03-31/a-cl-logger-20220331-git.tgz"; + sha256 = "0vhhbnh4akxh0ivqh8r0f2djv2nbf3l9hbbi0b5fdk9bdpziqkb4"; + system = "a-cl-logger-tests"; + asd = "a-cl-logger"; + } + ); + systems = [ "a-cl-logger-tests" ]; + lispLibs = [ + (getAttr "a-cl-logger" self) + (getAttr "lisp-unit2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + aabbcc = ( + build-asdf-system { + pname = "aabbcc"; + version = "20200427-git"; + asds = [ "aabbcc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "aabbcc"; + asd = "aabbcc"; + } + ); + systems = [ "aabbcc" ]; + lispLibs = [ + (getAttr "quads" self) + (getAttr "utility" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + able = ( + build-asdf-system { + pname = "able"; + version = "20171227-git"; + asds = [ "able" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/able/2017-12-27/able-20171227-git.tgz"; + sha256 = "1fbcmr6hy7bwlnsnrml3j4b2jkkj8ddxw27l8hr2z6l3fi3qw4hh"; + system = "able"; + asd = "able"; + } + ); + systems = [ "able" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "ltk" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + abnf = ( + build-asdf-system { + pname = "abnf"; + version = "20200325-git"; + asds = [ "abnf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-abnf/2020-03-25/cl-abnf-20200325-git.tgz"; + sha256 = "0f09nsndxa90acm71zd4qdnp40v705a4sqm04mnv9x76h6dlggmz"; + system = "abnf"; + asd = "abnf"; + } + ); + systems = [ "abnf" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "esrap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + abstract-classes = ( + build-asdf-system { + pname = "abstract-classes"; + version = "20190307-hg"; + asds = [ "abstract-classes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-abstract-classes/2019-03-07/cl-abstract-classes-20190307-hg.tgz"; + sha256 = "0q03j3ksgn56j9xvs3d3hhasplj3hvg488f4cx1z97nlyqxr5w1d"; + system = "abstract-classes"; + asd = "abstract-classes"; + } + ); + systems = [ "abstract-classes" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + access = ( + build-asdf-system { + pname = "access"; + version = "20241012-git"; + asds = [ "access" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/access/2024-10-12/access-20241012-git.tgz"; + sha256 = "0zdjqhb9rvnlq6nzmsp7372gi91k1rq9bz510m6hcki7g3r01iv5"; + system = "access"; + asd = "access"; + } + ); + systems = [ "access" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + ]; + meta = { }; + } + ); + acclimation = ( + build-asdf-system { + pname = "acclimation"; + version = "20241012-git"; + asds = [ "acclimation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/acclimation/2024-10-12/acclimation-20241012-git.tgz"; + sha256 = "1rp4794czi01hlv67mgykxym1hqsyn04ldgwiqjwf4lj5d3p7aj4"; + system = "acclimation"; + asd = "acclimation"; + } + ); + systems = [ "acclimation" ]; + lispLibs = [ ]; + meta = { }; + } + ); + acclimation-temperature = ( + build-asdf-system { + pname = "acclimation-temperature"; + version = "20241012-git"; + asds = [ "acclimation-temperature" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/acclimation/2024-10-12/acclimation-20241012-git.tgz"; + sha256 = "1rp4794czi01hlv67mgykxym1hqsyn04ldgwiqjwf4lj5d3p7aj4"; + system = "acclimation-temperature"; + asd = "acclimation-temperature"; + } + ); + systems = [ "acclimation-temperature" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + acl-compat = ( + build-asdf-system { + pname = "acl-compat"; + version = "20190813-git"; + asds = [ "acl-compat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/portableaserve/2019-08-13/portableaserve-20190813-git.tgz"; + sha256 = "0ak6mqp84sjr0a7h5svr16vra4bf4fcx6wpir0n88dc1vjwy5xqa"; + system = "acl-compat"; + asd = "acl-compat"; + } + ); + systems = [ "acl-compat" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "ironclad" self) + (getAttr "puri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + acm-random = ( + build-asdf-system { + pname = "acm-random"; + version = "20191007-git"; + asds = [ "acm-random" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/random/2019-10-07/random-20191007-git.tgz"; + sha256 = "1fb4mnp85jm9s667y4dgz07klhkr9pvi5xbxws28lbb8iip75y2p"; + system = "acm-random"; + asd = "acm-random"; + } + ); + systems = [ "acm-random" ]; + lispLibs = [ + (getAttr "com_dot_google_dot_base" self) + (getAttr "random" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + acm-random-test = ( + build-asdf-system { + pname = "acm-random-test"; + version = "20191007-git"; + asds = [ "acm-random-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/random/2019-10-07/random-20191007-git.tgz"; + sha256 = "1fb4mnp85jm9s667y4dgz07klhkr9pvi5xbxws28lbb8iip75y2p"; + system = "acm-random-test"; + asd = "acm-random-test"; + } + ); + systems = [ "acm-random-test" ]; + lispLibs = [ + (getAttr "acm-random" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + action-list = ( + build-asdf-system { + pname = "action-list"; + version = "20241012-git"; + asds = [ "action-list" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/action-list/2024-10-12/action-list-20241012-git.tgz"; + sha256 = "0ky38svlm0xhgsmh5maqj314q4wl3apg7532q8apy37axg1y3xvh"; + system = "action-list"; + asd = "action-list"; + } + ); + systems = [ "action-list" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "trivial-extensible-sequences" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + add-two = ( + build-asdf-system { + pname = "add-two"; + version = "20241012-git"; + asds = [ "add-two" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/whereiseveryone.command-line-args/2024-10-12/whereiseveryone.command-line-args-20241012-git.tgz"; + sha256 = "140xnz2v0v3hfg3dp2fhidw8ns6lxd3a5knm07wqdp48ksg119wy"; + system = "add-two"; + asd = "add-two"; + } + ); + systems = [ "add-two" ]; + lispLibs = [ + (getAttr "cl-annot" self) + (getAttr "whereiseveryone_dot_command-line-args" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + adhoc = ( + build-asdf-system { + pname = "adhoc"; + version = "20241012-git"; + asds = [ "adhoc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/adhoc/2024-10-12/adhoc-20241012-git.tgz"; + sha256 = "1h7mnwybapxzpv0zlwr1mr91lsd7wiv722ifa21gczllvrg5qai6"; + system = "adhoc"; + asd = "adhoc"; + } + ); + systems = [ "adhoc" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + adhoc-tests = ( + build-asdf-system { + pname = "adhoc-tests"; + version = "20241012-git"; + asds = [ "adhoc-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/adhoc/2024-10-12/adhoc-20241012-git.tgz"; + sha256 = "1h7mnwybapxzpv0zlwr1mr91lsd7wiv722ifa21gczllvrg5qai6"; + system = "adhoc-tests"; + asd = "adhoc-tests"; + } + ); + systems = [ "adhoc-tests" ]; + lispLibs = [ + (getAttr "adhoc" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + adjuvant = ( + build-asdf-system { + pname = "adjuvant"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "adjuvant" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "adjuvant"; + asd = "adjuvant"; + } + ); + systems = [ "adjuvant" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + adjuvant-test = ( + build-asdf-system { + pname = "adjuvant-test"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "adjuvant-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "adjuvant-test"; + asd = "adjuvant-test"; + } + ); + systems = [ "adjuvant-test" ]; + lispLibs = [ + (getAttr "adjuvant" self) + (getAttr "scrutiny" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + adopt = ( + build-asdf-system { + pname = "adopt"; + version = "20241012-hg"; + asds = [ "adopt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/adopt/2024-10-12/adopt-20241012-hg.tgz"; + sha256 = "1q36b9bp76daprnhd97h00x56kccmii8pc9w2ra6yihkfbcas41q"; + system = "adopt"; + asd = "adopt"; + } + ); + systems = [ "adopt" ]; + lispLibs = [ + (getAttr "bobbin" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + adopt-subcommands = ( + build-asdf-system { + pname = "adopt-subcommands"; + version = "v0.2.2"; + asds = [ "adopt-subcommands" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/adopt-subcommands/2021-05-31/adopt-subcommands-v0.2.2.tgz"; + sha256 = "0q35s3ihhlshakjalq5pgf14x502qnj8jimim8yf7bp1p9sn83h8"; + system = "adopt-subcommands"; + asd = "adopt-subcommands"; + } + ); + systems = [ "adopt-subcommands" ]; + lispLibs = [ + (getAttr "adopt" self) + (getAttr "bobbin" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + adopt-subcommands-test = ( + build-asdf-system { + pname = "adopt-subcommands-test"; + version = "v0.2.2"; + asds = [ "adopt-subcommands-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/adopt-subcommands/2021-05-31/adopt-subcommands-v0.2.2.tgz"; + sha256 = "0q35s3ihhlshakjalq5pgf14x502qnj8jimim8yf7bp1p9sn83h8"; + system = "adopt-subcommands-test"; + asd = "adopt-subcommands-test"; + } + ); + systems = [ "adopt-subcommands-test" ]; + lispLibs = [ + (getAttr "adopt-subcommands" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + adp = ( + build-asdf-system { + pname = "adp"; + version = "20241012-git"; + asds = [ "adp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/adp/2024-10-12/adp-20241012-git.tgz"; + sha256 = "04h91m2x1vcn8iidhx1y2cwb8j55siiifhx1ksy7hyn9hf39b2kv"; + system = "adp"; + asd = "adp"; + } + ); + systems = [ "adp" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "named-readtables" self) + (getAttr "scribble" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + adp-github = ( + build-asdf-system { + pname = "adp-github"; + version = "20241012-git"; + asds = [ "adp-github" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/adp-github/2024-10-12/adp-github-20241012-git.tgz"; + sha256 = "1g33l2k6pc5m8d0d3dl4rf8p364563jpyk22rywrh5188m9nayjc"; + system = "adp-github"; + asd = "adp-github"; + } + ); + systems = [ "adp-github" ]; + lispLibs = [ + (getAttr "adp" self) + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "trivial-arguments" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + adp-plain = ( + build-asdf-system { + pname = "adp-plain"; + version = "20241012-git"; + asds = [ "adp-plain" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/adp-plain/2024-10-12/adp-plain-20241012-git.tgz"; + sha256 = "0dnfx7hhdibkg0qphs3wsfll2kmpkfpg4hxfjv2paxnsmqdhspnz"; + system = "adp-plain"; + asd = "adp-plain"; + } + ); + systems = [ "adp-plain" ]; + lispLibs = [ (getAttr "adp" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + advanced-readtable = ( + build-asdf-system { + pname = "advanced-readtable"; + version = "20130720-git"; + asds = [ "advanced-readtable" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/advanced-readtable/2013-07-20/advanced-readtable-20130720-git.tgz"; + sha256 = "0dgm3lp9s6792g22swcb085f67q68jsyqj71vicb1wdr9qslvgwm"; + system = "advanced-readtable"; + asd = "advanced-readtable"; + } + ); + systems = [ "advanced-readtable" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + aether = ( + build-asdf-system { + pname = "aether"; + version = "v1.1.0"; + asds = [ "aether" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/aether/2021-12-09/aether-v1.1.0.tgz"; + sha256 = "0q60gc4lsxpvv4g572mnhpzkziq1412k1q0xm4y2d1zigryg30bb"; + system = "aether"; + asd = "aether"; + } + ); + systems = [ "aether" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-heap" self) + (getAttr "global-vars" self) + (getAttr "policy-cond" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + aether-tests = ( + build-asdf-system { + pname = "aether-tests"; + version = "v1.1.0"; + asds = [ "aether-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/aether/2021-12-09/aether-v1.1.0.tgz"; + sha256 = "0q60gc4lsxpvv4g572mnhpzkziq1412k1q0xm4y2d1zigryg30bb"; + system = "aether-tests"; + asd = "aether-tests"; + } + ); + systems = [ "aether-tests" ]; + lispLibs = [ + (getAttr "aether" self) + (getAttr "fiasco" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + agnostic-lizard = ( + build-asdf-system { + pname = "agnostic-lizard"; + version = "20241012-git"; + asds = [ "agnostic-lizard" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/agnostic-lizard/2024-10-12/agnostic-lizard-20241012-git.tgz"; + sha256 = "0amzshh6v3mp24j0h2cinv4zvdlg4kih04md5biakwhnmcw4j4pr"; + system = "agnostic-lizard"; + asd = "agnostic-lizard"; + } + ); + systems = [ "agnostic-lizard" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + agnostic-lizard-debugger-prototype = ( + build-asdf-system { + pname = "agnostic-lizard-debugger-prototype"; + version = "20241012-git"; + asds = [ "agnostic-lizard-debugger-prototype" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/agnostic-lizard/2024-10-12/agnostic-lizard-20241012-git.tgz"; + sha256 = "0amzshh6v3mp24j0h2cinv4zvdlg4kih04md5biakwhnmcw4j4pr"; + system = "agnostic-lizard-debugger-prototype"; + asd = "agnostic-lizard-debugger-prototype"; + } + ); + systems = [ "agnostic-lizard-debugger-prototype" ]; + lispLibs = [ + (getAttr "agnostic-lizard" self) + (getAttr "bordeaux-threads" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + agutil = ( + build-asdf-system { + pname = "agutil"; + version = "20210531-git"; + asds = [ "agutil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/agutil/2021-05-31/agutil-20210531-git.tgz"; + sha256 = "10lccrqkaqq0h1p79gjqsqk1nqa6c25n0w7pj39y2gs14s5qr5q9"; + system = "agutil"; + asd = "agutil"; + } + ); + systems = [ "agutil" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "optima" self) + ]; + meta = { }; + } + ); + alexa = ( + build-asdf-system { + pname = "alexa"; + version = "20180831-git"; + asds = [ "alexa" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/alexa/2018-08-31/alexa-20180831-git.tgz"; + sha256 = "1y9jyz9gfmd02h492kf7v3mmpbhc0yfh4ka2rzd1vczq6fl8qgqv"; + system = "alexa"; + asd = "alexa"; + } + ); + systems = [ "alexa" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + alexa-tests = ( + build-asdf-system { + pname = "alexa-tests"; + version = "20180831-git"; + asds = [ "alexa-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/alexa/2018-08-31/alexa-20180831-git.tgz"; + sha256 = "1y9jyz9gfmd02h492kf7v3mmpbhc0yfh4ka2rzd1vczq6fl8qgqv"; + system = "alexa-tests"; + asd = "alexa-tests"; + } + ); + systems = [ "alexa-tests" ]; + lispLibs = [ + (getAttr "alexa" self) + (getAttr "fiasco" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + alexandria = ( + build-asdf-system { + pname = "alexandria"; + version = "20241012-git"; + asds = [ "alexandria" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/alexandria/2024-10-12/alexandria-20241012-git.tgz"; + sha256 = "0jq0n59s0r9yl374f0zpdnaflb5g853yqvax7ka8rnypspyykwdw"; + system = "alexandria"; + asd = "alexandria"; + } + ); + systems = [ "alexandria" ]; + lispLibs = [ ]; + meta = { }; + } + ); + alexandria_plus = ( + build-asdf-system { + pname = "alexandria+"; + version = "20241012-git"; + asds = [ "alexandria+" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/alexandria-plus/2024-10-12/alexandria-plus-20241012-git.tgz"; + sha256 = "05j88i289nx2dgc8r3n3h8x3ma31gk8xk2bpvxc5y9yzfl2mp0hk"; + system = "alexandria+"; + asd = "alexandria+"; + } + ); + systems = [ "alexandria+" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + algebraic-data-library = ( + build-asdf-system { + pname = "algebraic-data-library"; + version = "20180831-git"; + asds = [ "algebraic-data-library" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/algebraic-data-library/2018-08-31/algebraic-data-library-20180831-git.tgz"; + sha256 = "0mmakfdwgfjl812ydzbbl81lkv41zfnqhw9ydjk1w63lq8c11cmn"; + system = "algebraic-data-library"; + asd = "algebraic-data-library"; + } + ); + systems = [ "algebraic-data-library" ]; + lispLibs = [ (getAttr "cl-algebraic-data-type" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + allioli = ( + build-asdf-system { + pname = "allioli"; + version = "20241012-git"; + asds = [ "allioli" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/allioli/2024-10-12/allioli-20241012-git.tgz"; + sha256 = "00504wf4rxrwpc171czlk56zzbf798c39jzhbipm7ba3iz28qkai"; + system = "allioli"; + asd = "allioli"; + } + ); + systems = [ "allioli" ]; + lispLibs = [ + (getAttr "fare-quasiquote-extras" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + also-alsa = ( + build-asdf-system { + pname = "also-alsa"; + version = "20231021-git"; + asds = [ "also-alsa" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/also-alsa/2023-10-21/also-alsa-20231021-git.tgz"; + sha256 = "17xvq04nnw2kmxvahj56ja5k21d3wg3fzclbfm36fn641lr6l7dx"; + system = "also-alsa"; + asd = "also-alsa"; + } + ); + systems = [ "also-alsa" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + alternate-asdf-system-connections = ( + build-asdf-system { + pname = "alternate-asdf-system-connections"; + version = "20241012-git"; + asds = [ "alternate-asdf-system-connections" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/alternate-asdf-system-connections/2024-10-12/alternate-asdf-system-connections-20241012-git.tgz"; + sha256 = "0wlmr29a8azs5kjvwdaqmfn2iwqid0f659cmj34ywchgxahdr6p6"; + system = "alternate-asdf-system-connections"; + asd = "alternate-asdf-system-connections"; + } + ); + systems = [ "alternate-asdf-system-connections" ]; + lispLibs = [ (getAttr "asdf-system-connections" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + amazon-ecs = ( + build-asdf-system { + pname = "amazon-ecs"; + version = "20110418-git"; + asds = [ "amazon-ecs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/amazon-ecs/2011-04-18/amazon-ecs-20110418-git.tgz"; + sha256 = "1gi3ybfkdfqvgmwgf0l77xpp5xgmkbycdpz6kn79vm0iga3kd2mz"; + system = "amazon-ecs"; + asd = "amazon-ecs"; + } + ); + systems = [ "amazon-ecs" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "hunchentoot" self) + (getAttr "ironclad" self) + (getAttr "net-telent-date" self) + (getAttr "parse-number" self) + (getAttr "trivial-http" self) + (getAttr "xml-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + amb = ( + build-asdf-system { + pname = "amb"; + version = "20230214-git"; + asds = [ "amb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/amb/2023-02-14/amb-20230214-git.tgz"; + sha256 = "014vpsqxjnsr0x2zql6xpz0kh448p3lqw521amsf6700jqa2s1wp"; + system = "amb"; + asd = "amb"; + } + ); + systems = [ "amb" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + anaphora = ( + build-asdf-system { + pname = "anaphora"; + version = "20220220-git"; + asds = [ "anaphora" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/anaphora/2022-02-20/anaphora-20220220-git.tgz"; + sha256 = "1ds5ab0rzkrhfl29xpvmvyxmkdyj9mi19p330pz603lx95njjc0b"; + system = "anaphora"; + asd = "anaphora"; + } + ); + systems = [ "anaphora" ]; + lispLibs = [ ]; + meta = { }; + } + ); + anaphoric-variants = ( + build-asdf-system { + pname = "anaphoric-variants"; + version = "1.0.1"; + asds = [ "anaphoric-variants" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/anaphoric-variants/2012-10-13/anaphoric-variants-1.0.1.tgz"; + sha256 = "02ms01w09b9bzsdsr0icd3ggyl86kyxk164kf0759k2k9y6kjsp5"; + system = "anaphoric-variants"; + asd = "anaphoric-variants"; + } + ); + systems = [ "anaphoric-variants" ]; + lispLibs = [ (getAttr "map-bind" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + anatevka = ( + build-asdf-system { + pname = "anatevka"; + version = "v1.0.1"; + asds = [ "anatevka" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/anatevka/2024-10-12/anatevka-v1.0.1.tgz"; + sha256 = "1cxrbbb947pccy6532cxqrdlkfpm0m6z135mnyaiplfsd77jy772"; + system = "anatevka"; + asd = "anatevka"; + } + ); + systems = [ "anatevka" ]; + lispLibs = [ + (getAttr "aether" self) + (getAttr "alexandria" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + anatevka-tests = ( + build-asdf-system { + pname = "anatevka-tests"; + version = "v1.0.1"; + asds = [ "anatevka-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/anatevka/2024-10-12/anatevka-v1.0.1.tgz"; + sha256 = "1cxrbbb947pccy6532cxqrdlkfpm0m6z135mnyaiplfsd77jy772"; + system = "anatevka-tests"; + asd = "anatevka-tests"; + } + ); + systems = [ "anatevka-tests" ]; + lispLibs = [ + (getAttr "anatevka" self) + (getAttr "closer-mop" self) + (getAttr "fiasco" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ansi-escape = ( + build-asdf-system { + pname = "ansi-escape"; + version = "20241012-git"; + asds = [ "ansi-escape" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/croatoan/2024-10-12/croatoan-20241012-git.tgz"; + sha256 = "04776x4i8inxs8n4mgy9xf0q39bzv4mfz4cl880sxwk6mnhwnn4c"; + system = "ansi-escape"; + asd = "ansi-escape"; + } + ); + systems = [ "ansi-escape" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ansi-escape-test = ( + build-asdf-system { + pname = "ansi-escape-test"; + version = "20241012-git"; + asds = [ "ansi-escape-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/croatoan/2024-10-12/croatoan-20241012-git.tgz"; + sha256 = "04776x4i8inxs8n4mgy9xf0q39bzv4mfz4cl880sxwk6mnhwnn4c"; + system = "ansi-escape-test"; + asd = "ansi-escape-test"; + } + ); + systems = [ "ansi-escape-test" ]; + lispLibs = [ (getAttr "ansi-escape" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ansi-test-harness = ( + build-asdf-system { + pname = "ansi-test-harness"; + version = "20231021-git"; + asds = [ "ansi-test-harness" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ansi-test-harness/2023-10-21/ansi-test-harness-20231021-git.tgz"; + sha256 = "168q2358ag5lf7k8378462279q0izllbwqr1axljm0nsn6d4g0yl"; + system = "ansi-test-harness"; + asd = "ansi-test-harness"; + } + ); + systems = [ "ansi-test-harness" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + antik = ( + build-asdf-system { + pname = "antik"; + version = "master-df14cb8c-git"; + asds = [ "antik" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/antik/2024-10-12/antik-master-df14cb8c-git.tgz"; + sha256 = "1n08cx4n51z8v4bxyak166lp495xda3x7llfxcdpxndxqxcammr0"; + system = "antik"; + asd = "antik"; + } + ); + systems = [ "antik" ]; + lispLibs = [ + (getAttr "gsll" self) + (getAttr "physical-dimension" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + antik-base = ( + build-asdf-system { + pname = "antik-base"; + version = "master-df14cb8c-git"; + asds = [ "antik-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/antik/2024-10-12/antik-master-df14cb8c-git.tgz"; + sha256 = "1n08cx4n51z8v4bxyak166lp495xda3x7llfxcdpxndxqxcammr0"; + system = "antik-base"; + asd = "antik-base"; + } + ); + systems = [ "antik-base" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "iterate" self) + (getAttr "lisp-unit" self) + (getAttr "metabang-bind" self) + (getAttr "named-readtables" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + anypool = ( + build-asdf-system { + pname = "anypool"; + version = "20241012-git"; + asds = [ "anypool" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/anypool/2024-10-12/anypool-20241012-git.tgz"; + sha256 = "1ffssc5fzh7gj0z94xxfb3mk5cwja65lrhxyfgib15a6yxqf1kk1"; + system = "anypool"; + asd = "anypool"; + } + ); + systems = [ "anypool" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-speedy-queue" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + aplesque = ( + build-asdf-system { + pname = "aplesque"; + version = "20241012-git"; + asds = [ "aplesque" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "aplesque"; + asd = "aplesque"; + } + ); + systems = [ "aplesque" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "array-operations" self) + (getAttr "cl-ppcre" self) + (getAttr "lparallel" self) + (getAttr "parse-number" self) + (getAttr "symbol-munger" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + application = ( + build-asdf-system { + pname = "application"; + version = "20200427-git"; + asds = [ "application" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "application"; + asd = "application"; + } + ); + systems = [ "application" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-opengl" self) + (getAttr "deflazy" self) + (getAttr "glhelp" self) + (getAttr "scratch-buffer" self) + (getAttr "utility" self) + (getAttr "window" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + apply-argv = ( + build-asdf-system { + pname = "apply-argv"; + version = "20150608-git"; + asds = [ "apply-argv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/apply-argv/2015-06-08/apply-argv-20150608-git.tgz"; + sha256 = "19qj847vyawjgm5iwk96469c0plnxj37948ac1bcd86hgpbm75w0"; + system = "apply-argv"; + asd = "apply-argv"; + } + ); + systems = [ "apply-argv" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + apply-argv-tests = ( + build-asdf-system { + pname = "apply-argv-tests"; + version = "20150608-git"; + asds = [ "apply-argv-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/apply-argv/2015-06-08/apply-argv-20150608-git.tgz"; + sha256 = "19qj847vyawjgm5iwk96469c0plnxj37948ac1bcd86hgpbm75w0"; + system = "apply-argv-tests"; + asd = "apply-argv"; + } + ); + systems = [ "apply-argv-tests" ]; + lispLibs = [ + (getAttr "apply-argv" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + april = ( + build-asdf-system { + pname = "april"; + version = "20241012-git"; + asds = [ "april" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "april"; + asd = "april"; + } + ); + systems = [ "april" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "aplesque" self) + (getAttr "array-operations" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-unicode" self) + (getAttr "lparallel" self) + (getAttr "parse-number" self) + (getAttr "prove" self) + (getAttr "random-state" self) + (getAttr "simple-date-time" self) + (getAttr "symbol-munger" self) + (getAttr "trivia" self) + (getAttr "varray" self) + (getAttr "vex" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + april-demo_dot_cnn = ( + build-asdf-system { + pname = "april-demo.cnn"; + version = "20241012-git"; + asds = [ "april-demo.cnn" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "april-demo.cnn"; + asd = "april-demo.cnn"; + } + ); + systems = [ "april-demo.cnn" ]; + lispLibs = [ + (getAttr "april" self) + (getAttr "lisp-binary" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + april-demo_dot_fnn = ( + build-asdf-system { + pname = "april-demo.fnn"; + version = "20241012-git"; + asds = [ "april-demo.fnn" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "april-demo.fnn"; + asd = "april-demo.fnn"; + } + ); + systems = [ "april-demo.fnn" ]; + lispLibs = [ + (getAttr "april" self) + (getAttr "april-lib_dot_dfns_dot_array" self) + (getAttr "lisp-binary" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + april-lib_dot_dfns_dot_array = ( + build-asdf-system { + pname = "april-lib.dfns.array"; + version = "20241012-git"; + asds = [ "april-lib.dfns.array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "april-lib.dfns.array"; + asd = "april-lib.dfns.array"; + } + ); + systems = [ "april-lib.dfns.array" ]; + lispLibs = [ (getAttr "april" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + april-lib_dot_dfns_dot_graph = ( + build-asdf-system { + pname = "april-lib.dfns.graph"; + version = "20241012-git"; + asds = [ "april-lib.dfns.graph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "april-lib.dfns.graph"; + asd = "april-lib.dfns.graph"; + } + ); + systems = [ "april-lib.dfns.graph" ]; + lispLibs = [ + (getAttr "april" self) + (getAttr "april-lib_dot_dfns_dot_array" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + april-lib_dot_dfns_dot_numeric = ( + build-asdf-system { + pname = "april-lib.dfns.numeric"; + version = "20241012-git"; + asds = [ "april-lib.dfns.numeric" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "april-lib.dfns.numeric"; + asd = "april-lib.dfns.numeric"; + } + ); + systems = [ "april-lib.dfns.numeric" ]; + lispLibs = [ + (getAttr "april" self) + (getAttr "april-lib_dot_dfns_dot_graph" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + april-lib_dot_dfns_dot_power = ( + build-asdf-system { + pname = "april-lib.dfns.power"; + version = "20241012-git"; + asds = [ "april-lib.dfns.power" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "april-lib.dfns.power"; + asd = "april-lib.dfns.power"; + } + ); + systems = [ "april-lib.dfns.power" ]; + lispLibs = [ + (getAttr "april" self) + (getAttr "april-lib_dot_dfns_dot_array" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + april-lib_dot_dfns_dot_string = ( + build-asdf-system { + pname = "april-lib.dfns.string"; + version = "20241012-git"; + asds = [ "april-lib.dfns.string" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "april-lib.dfns.string"; + asd = "april-lib.dfns.string"; + } + ); + systems = [ "april-lib.dfns.string" ]; + lispLibs = [ + (getAttr "april" self) + (getAttr "april-lib_dot_dfns_dot_array" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + april-lib_dot_dfns_dot_tree = ( + build-asdf-system { + pname = "april-lib.dfns.tree"; + version = "20241012-git"; + asds = [ "april-lib.dfns.tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "april-lib.dfns.tree"; + asd = "april-lib.dfns.tree"; + } + ); + systems = [ "april-lib.dfns.tree" ]; + lispLibs = [ + (getAttr "april" self) + (getAttr "april-lib_dot_dfns_dot_array" self) + (getAttr "april-lib_dot_dfns_dot_power" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + april-xt_dot_uzuki = ( + build-asdf-system { + pname = "april-xt.uzuki"; + version = "20241012-git"; + asds = [ "april-xt.uzuki" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "april-xt.uzuki"; + asd = "april-xt.uzuki"; + } + ); + systems = [ "april-xt.uzuki" ]; + lispLibs = [ (getAttr "april" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + arc-compat = ( + build-asdf-system { + pname = "arc-compat"; + version = "20241012-git"; + asds = [ "arc-compat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/arc-compat/2024-10-12/arc-compat-20241012-git.tgz"; + sha256 = "1wmq5mvlkvdbl4562p3n7x8bhv3swjj0yqbly07y8mv0snasns8d"; + system = "arc-compat"; + asd = "arc-compat"; + } + ); + systems = [ "arc-compat" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-fad" self) + (getAttr "fiveam" self) + (getAttr "ironclad" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + architecture_dot_builder-protocol = ( + build-asdf-system { + pname = "architecture.builder-protocol"; + version = "20241012-git"; + asds = [ "architecture.builder-protocol" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/architecture.builder-protocol/2024-10-12/architecture.builder-protocol-20241012-git.tgz"; + sha256 = "1ckrv0ca57xvsvd9rwjcq0yljiv76wj22p1pjpjbjfr5clb9gl0q"; + system = "architecture.builder-protocol"; + asd = "architecture.builder-protocol"; + } + ); + systems = [ "architecture.builder-protocol" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + architecture_dot_builder-protocol_dot_inspection = ( + build-asdf-system { + pname = "architecture.builder-protocol.inspection"; + version = "20241012-git"; + asds = [ "architecture.builder-protocol.inspection" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/architecture.builder-protocol/2024-10-12/architecture.builder-protocol-20241012-git.tgz"; + sha256 = "1ckrv0ca57xvsvd9rwjcq0yljiv76wj22p1pjpjbjfr5clb9gl0q"; + system = "architecture.builder-protocol.inspection"; + asd = "architecture.builder-protocol.inspection"; + } + ); + systems = [ "architecture.builder-protocol.inspection" ]; + lispLibs = [ + (getAttr "architecture_dot_builder-protocol" self) + (getAttr "clouseau" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + architecture_dot_builder-protocol_dot_json = ( + build-asdf-system { + pname = "architecture.builder-protocol.json"; + version = "20241012-git"; + asds = [ "architecture.builder-protocol.json" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/architecture.builder-protocol/2024-10-12/architecture.builder-protocol-20241012-git.tgz"; + sha256 = "1ckrv0ca57xvsvd9rwjcq0yljiv76wj22p1pjpjbjfr5clb9gl0q"; + system = "architecture.builder-protocol.json"; + asd = "architecture.builder-protocol.json"; + } + ); + systems = [ "architecture.builder-protocol.json" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "architecture_dot_builder-protocol" self) + (getAttr "cl-json" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + architecture_dot_builder-protocol_dot_print-tree = ( + build-asdf-system { + pname = "architecture.builder-protocol.print-tree"; + version = "20241012-git"; + asds = [ "architecture.builder-protocol.print-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/architecture.builder-protocol/2024-10-12/architecture.builder-protocol-20241012-git.tgz"; + sha256 = "1ckrv0ca57xvsvd9rwjcq0yljiv76wj22p1pjpjbjfr5clb9gl0q"; + system = "architecture.builder-protocol.print-tree"; + asd = "architecture.builder-protocol.print-tree"; + } + ); + systems = [ "architecture.builder-protocol.print-tree" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "architecture_dot_builder-protocol" self) + (getAttr "utilities_dot_print-tree" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + architecture_dot_builder-protocol_dot_universal-builder = ( + build-asdf-system { + pname = "architecture.builder-protocol.universal-builder"; + version = "20241012-git"; + asds = [ "architecture.builder-protocol.universal-builder" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/architecture.builder-protocol/2024-10-12/architecture.builder-protocol-20241012-git.tgz"; + sha256 = "1ckrv0ca57xvsvd9rwjcq0yljiv76wj22p1pjpjbjfr5clb9gl0q"; + system = "architecture.builder-protocol.universal-builder"; + asd = "architecture.builder-protocol.universal-builder"; + } + ); + systems = [ "architecture.builder-protocol.universal-builder" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "architecture_dot_builder-protocol" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + architecture_dot_builder-protocol_dot_xpath = ( + build-asdf-system { + pname = "architecture.builder-protocol.xpath"; + version = "20241012-git"; + asds = [ "architecture.builder-protocol.xpath" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/architecture.builder-protocol/2024-10-12/architecture.builder-protocol-20241012-git.tgz"; + sha256 = "1ckrv0ca57xvsvd9rwjcq0yljiv76wj22p1pjpjbjfr5clb9gl0q"; + system = "architecture.builder-protocol.xpath"; + asd = "architecture.builder-protocol.xpath"; + } + ); + systems = [ "architecture.builder-protocol.xpath" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "architecture_dot_builder-protocol" self) + (getAttr "xpath" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + architecture_dot_service-provider = ( + build-asdf-system { + pname = "architecture.service-provider"; + version = "20191007-git"; + asds = [ "architecture.service-provider" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/architecture.service-provider/2019-10-07/architecture.service-provider-20191007-git.tgz"; + sha256 = "0n4a299md5z0wvk6j3my4ii6cs198fqgizz1swic89p1qz5n2fjm"; + system = "architecture.service-provider"; + asd = "architecture.service-provider"; + } + ); + systems = [ "architecture.service-provider" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "let-plus" self) + (getAttr "more-conditions" self) + (getAttr "utilities_dot_print-items" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + architecture_dot_service-provider-and-hooks = ( + build-asdf-system { + pname = "architecture.service-provider-and-hooks"; + version = "20191007-git"; + asds = [ "architecture.service-provider-and-hooks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/architecture.service-provider/2019-10-07/architecture.service-provider-20191007-git.tgz"; + sha256 = "0n4a299md5z0wvk6j3my4ii6cs198fqgizz1swic89p1qz5n2fjm"; + system = "architecture.service-provider-and-hooks"; + asd = "architecture.service-provider-and-hooks"; + } + ); + systems = [ "architecture.service-provider-and-hooks" ]; + lispLibs = [ + (getAttr "architecture_dot_service-provider" self) + (getAttr "cl-hooks" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + archive = ( + build-asdf-system { + pname = "archive"; + version = "20160318-git"; + asds = [ "archive" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/archive/2016-03-18/archive-20160318-git.tgz"; + sha256 = "0pvsc9fmybx7rxd0kmzq4shi6hszdpwdc1sfy7jwyfxf8n3hnv4p"; + system = "archive"; + asd = "archive"; + } + ); + systems = [ "archive" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + arith = ( + build-asdf-system { + pname = "arith"; + version = "20170830-git"; + asds = [ "arith" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/paren-test/2017-08-30/paren-test-20170830-git.tgz"; + sha256 = "0b2d3kcv3n4b0dm67pzhxx8wxjsgnb32bw2dsprblc7149gaczdr"; + system = "arith"; + asd = "arith"; + } + ); + systems = [ "arith" ]; + lispLibs = [ + (getAttr "paren-files" self) + (getAttr "paren-test" self) + (getAttr "parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + arithmetic-operators-as-words = ( + build-asdf-system { + pname = "arithmetic-operators-as-words"; + version = "20200610-git"; + asds = [ "arithmetic-operators-as-words" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/arithmetic-operators-as-words/2020-06-10/arithmetic-operators-as-words-20200610-git.tgz"; + sha256 = "1bcfkbq3kqns2ng0cdmj81c72j63641pqlskg4xrzkgkh25bhkks"; + system = "arithmetic-operators-as-words"; + asd = "arithmetic-operators-as-words"; + } + ); + systems = [ "arithmetic-operators-as-words" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + arnesi = ( + build-asdf-system { + pname = "arnesi"; + version = "20170403-git"; + asds = [ "arnesi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/arnesi/2017-04-03/arnesi-20170403-git.tgz"; + sha256 = "0jgj2xgd1gq6rf8ia43lkmbrbxnp8rgs053br9azfa25ygk3ikbh"; + system = "arnesi"; + asd = "arnesi"; + } + ); + systems = [ "arnesi" ]; + lispLibs = [ (getAttr "collectors" self) ]; + meta = { }; + } + ); + array-operations = ( + build-asdf-system { + pname = "array-operations"; + version = "1.2.1"; + asds = [ "array-operations" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/array-operations/2023-10-21/array-operations-1.2.1.tgz"; + sha256 = "06zg7ds7c1vi59zxzrd52a9zfpw8x0jsf1hqcdgaz8s3dcfma3mn"; + system = "array-operations"; + asd = "array-operations"; + } + ); + systems = [ "array-operations" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "let-plus" self) + ]; + meta = { }; + } + ); + array-utils = ( + build-asdf-system { + pname = "array-utils"; + version = "20241012-git"; + asds = [ "array-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/array-utils/2024-10-12/array-utils-20241012-git.tgz"; + sha256 = "0rya7k9sfpyrn5vrn12wywpgsr2f0pmcywv51ixzb0sv8ska0mhs"; + system = "array-utils"; + asd = "array-utils"; + } + ); + systems = [ "array-utils" ]; + lispLibs = [ ]; + meta = { }; + } + ); + array-utils-test = ( + build-asdf-system { + pname = "array-utils-test"; + version = "20241012-git"; + asds = [ "array-utils-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/array-utils/2024-10-12/array-utils-20241012-git.tgz"; + sha256 = "0rya7k9sfpyrn5vrn12wywpgsr2f0pmcywv51ixzb0sv8ska0mhs"; + system = "array-utils-test"; + asd = "array-utils-test"; + } + ); + systems = [ "array-utils-test" ]; + lispLibs = [ + (getAttr "array-utils" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + arrival = ( + build-asdf-system { + pname = "arrival"; + version = "20211209-git"; + asds = [ "arrival" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/arrival/2021-12-09/arrival-20211209-git.tgz"; + sha256 = "1iwdk5fdismw91ln5wdnn8c8xv06fbgiwbvdj2gy2hpp8f3qk00b"; + system = "arrival"; + asd = "arrival"; + } + ); + systems = [ "arrival" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "log4cl" self) + (getAttr "trivia" self) + (getAttr "trivia_dot_quasiquote" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + arrow-macros = ( + build-asdf-system { + pname = "arrow-macros"; + version = "20241012-git"; + asds = [ "arrow-macros" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/arrow-macros/2024-10-12/arrow-macros-20241012-git.tgz"; + sha256 = "0q4vpysk4h9ghs5zmnzzilky9jyz7i8n0x0p98nq528crbrkh6c4"; + system = "arrow-macros"; + asd = "arrow-macros"; + } + ); + systems = [ "arrow-macros" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + arrow-macros-test = ( + build-asdf-system { + pname = "arrow-macros-test"; + version = "20241012-git"; + asds = [ "arrow-macros-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/arrow-macros/2024-10-12/arrow-macros-20241012-git.tgz"; + sha256 = "0q4vpysk4h9ghs5zmnzzilky9jyz7i8n0x0p98nq528crbrkh6c4"; + system = "arrow-macros-test"; + asd = "arrow-macros-test"; + } + ); + systems = [ "arrow-macros-test" ]; + lispLibs = [ + (getAttr "arrow-macros" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + arrows = ( + build-asdf-system { + pname = "arrows"; + version = "20181018-git"; + asds = [ "arrows" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/arrows/2018-10-18/arrows-20181018-git.tgz"; + sha256 = "042k9vkssrqx9nhp14wdzm942zgdxvp35mba0p2syz98i75im2yy"; + system = "arrows"; + asd = "arrows"; + } + ); + systems = [ "arrows" ]; + lispLibs = [ ]; + meta = { }; + } + ); + ascii-strings = ( + build-asdf-system { + pname = "ascii-strings"; + version = "20211209-git"; + asds = [ "ascii-strings" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-string-match/2021-12-09/cl-string-match-20211209-git.tgz"; + sha256 = "0zndlkw3qy3vw4px4qv884z6232w8zfaliyc88irjwizdv35wcq9"; + system = "ascii-strings"; + asd = "ascii-strings"; + } + ); + systems = [ "ascii-strings" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asd-generator = ( + build-asdf-system { + pname = "asd-generator"; + version = "20190107-git"; + asds = [ "asd-generator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asd-generator/2019-01-07/asd-generator-20190107-git.tgz"; + sha256 = "0yiybl7b9x1f85v0drj0yw9821y3yfhya4n6gycnv5vvx6jp9by4"; + system = "asd-generator"; + asd = "asd-generator"; + } + ); + systems = [ "asd-generator" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "iterate" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asd-generator-test = ( + build-asdf-system { + pname = "asd-generator-test"; + version = "20190107-git"; + asds = [ "asd-generator-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asd-generator/2019-01-07/asd-generator-20190107-git.tgz"; + sha256 = "0yiybl7b9x1f85v0drj0yw9821y3yfhya4n6gycnv5vvx6jp9by4"; + system = "asd-generator-test"; + asd = "asd-generator-test"; + } + ); + systems = [ "asd-generator-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asdf-dependency-graph = ( + build-asdf-system { + pname = "asdf-dependency-graph"; + version = "20230618-git"; + asds = [ "asdf-dependency-graph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-dependency-graph/2023-06-18/asdf-dependency-graph-20230618-git.tgz"; + sha256 = "1m3cgjmr5fzyas33gjnahcbjiiksr02h2lwdxxl35y2dbip8pygp"; + system = "asdf-dependency-graph"; + asd = "asdf-dependency-graph"; + } + ); + systems = [ "asdf-dependency-graph" ]; + lispLibs = [ (getAttr "optima" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asdf-dependency-grovel = ( + build-asdf-system { + pname = "asdf-dependency-grovel"; + version = "20170403-git"; + asds = [ "asdf-dependency-grovel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-dependency-grovel/2017-04-03/asdf-dependency-grovel-20170403-git.tgz"; + sha256 = "1y4kdqsda4ira4r9dws6kxzzv6mg45q3lkmb2c9mg9q7ksc5glif"; + system = "asdf-dependency-grovel"; + asd = "asdf-dependency-grovel"; + } + ); + systems = [ "asdf-dependency-grovel" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asdf-driver = ( + build-asdf-system { + pname = "asdf-driver"; + version = "3.3.7"; + asds = [ "asdf-driver" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uiop/2024-10-12/uiop-3.3.7.tgz"; + sha256 = "0xvzxglkf9hlly7if0l307k31kwglk2ay4k393545c1l5l1ac584"; + system = "asdf-driver"; + asd = "asdf-driver"; + } + ); + systems = [ "asdf-driver" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asdf-encodings = ( + build-asdf-system { + pname = "asdf-encodings"; + version = "20191007-git"; + asds = [ "asdf-encodings" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-encodings/2019-10-07/asdf-encodings-20191007-git.tgz"; + sha256 = "1yn77nhrz5w2s7nlafxjnk9j8fsrz7ivrm7nbj4r726bwc5knky6"; + system = "asdf-encodings"; + asd = "asdf-encodings"; + } + ); + systems = [ "asdf-encodings" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asdf-finalizers = ( + build-asdf-system { + pname = "asdf-finalizers"; + version = "20221106-git"; + asds = [ "asdf-finalizers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-finalizers/2022-11-06/asdf-finalizers-20221106-git.tgz"; + sha256 = "1w56c9yjjydjshsgqxz57qlp2v3r4ilbisnsgiqphvxnhvd41y0v"; + system = "asdf-finalizers"; + asd = "asdf-finalizers"; + } + ); + systems = [ "asdf-finalizers" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asdf-linguist = ( + build-asdf-system { + pname = "asdf-linguist"; + version = "20150923-git"; + asds = [ "asdf-linguist" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-linguist/2015-09-23/asdf-linguist-20150923-git.tgz"; + sha256 = "14jaqmxxh70f1jf58mxb117951iql2sjxymmbjyqniqwazznbd9a"; + system = "asdf-linguist"; + asd = "asdf-linguist"; + } + ); + systems = [ "asdf-linguist" ]; + lispLibs = [ + (getAttr "inferior-shell" self) + (getAttr "parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asdf-manager = ( + build-asdf-system { + pname = "asdf-manager"; + version = "20160208-git"; + asds = [ "asdf-manager" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-manager/2016-02-08/asdf-manager-20160208-git.tgz"; + sha256 = "0jw7d0vg13v1l1fwwhsw04n6w3c49vsbmq6vrlrkh95aayc5413w"; + system = "asdf-manager"; + asd = "asdf-manager"; + } + ); + systems = [ "asdf-manager" ]; + lispLibs = [ + (getAttr "trivial-download" self) + (getAttr "trivial-extract" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asdf-manager-test = ( + build-asdf-system { + pname = "asdf-manager-test"; + version = "20160208-git"; + asds = [ "asdf-manager-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-manager/2016-02-08/asdf-manager-20160208-git.tgz"; + sha256 = "0jw7d0vg13v1l1fwwhsw04n6w3c49vsbmq6vrlrkh95aayc5413w"; + system = "asdf-manager-test"; + asd = "asdf-manager-test"; + } + ); + systems = [ "asdf-manager-test" ]; + lispLibs = [ + (getAttr "asdf-manager" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asdf-nst = ( + build-asdf-system { + pname = "asdf-nst"; + version = "20210807-git"; + asds = [ "asdf-nst" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; + sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; + system = "asdf-nst"; + asd = "asdf-nst"; + } + ); + systems = [ "asdf-nst" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asdf-package-system = ( + build-asdf-system { + pname = "asdf-package-system"; + version = "20150608-git"; + asds = [ "asdf-package-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-package-system/2015-06-08/asdf-package-system-20150608-git.tgz"; + sha256 = "1q4qgvbl64c4zdbq91by1la8licdgam7ybnhvg2bixdhq4v693sj"; + system = "asdf-package-system"; + asd = "asdf-package-system"; + } + ); + systems = [ "asdf-package-system" ]; + lispLibs = [ ]; + meta = { }; + } + ); + asdf-system-connections = ( + build-asdf-system { + pname = "asdf-system-connections"; + version = "20170124-git"; + asds = [ "asdf-system-connections" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-system-connections/2017-01-24/asdf-system-connections-20170124-git.tgz"; + sha256 = "06kg0m8bv383qq3r34x0f8hz6p6zxcw02qn7kj960vcnrp5a5b3y"; + system = "asdf-system-connections"; + asd = "asdf-system-connections"; + } + ); + systems = [ "asdf-system-connections" ]; + lispLibs = [ ]; + meta = { }; + } + ); + asdf-viz = ( + build-asdf-system { + pname = "asdf-viz"; + version = "20200610-git"; + asds = [ "asdf-viz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-viz/2020-06-10/asdf-viz-20200610-git.tgz"; + sha256 = "1hj9ac1m2kz8x65n62gd1s2k2x9pip9a85pnmib53qsks3a9sc4z"; + system = "asdf-viz"; + asd = "asdf-viz"; + } + ); + systems = [ "asdf-viz" ]; + lispLibs = [ + (getAttr "cl-dot" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + (getAttr "swank" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + aserve = ( + build-asdf-system { + pname = "aserve"; + version = "20190813-git"; + asds = [ "aserve" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/portableaserve/2019-08-13/portableaserve-20190813-git.tgz"; + sha256 = "0ak6mqp84sjr0a7h5svr16vra4bf4fcx6wpir0n88dc1vjwy5xqa"; + system = "aserve"; + asd = "aserve"; + } + ); + systems = [ "aserve" ]; + lispLibs = [ + (getAttr "acl-compat" self) + (getAttr "htmlgen" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asn1 = ( + build-asdf-system { + pname = "asn1"; + version = "20220331-git"; + asds = [ "asn1" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asn1/2022-03-31/asn1-20220331-git.tgz"; + sha256 = "16gs4xznmg19ii0cg7g2yxrk9ls5vah8ynjj80s99rv8wi3789z1"; + system = "asn1"; + asd = "asn1"; + } + ); + systems = [ "asn1" ]; + lispLibs = [ + (getAttr "fast-io" self) + (getAttr "ironclad" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + assert-p = ( + build-asdf-system { + pname = "assert-p"; + version = "20200610-git"; + asds = [ "assert-p" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/assert-p/2020-06-10/assert-p-20200610-git.tgz"; + sha256 = "1x24rkqkqiw8zd26swi9rmhfplkmr5scz3bhjwccah9d2s36b1xs"; + system = "assert-p"; + asd = "assert-p"; + } + ); + systems = [ "assert-p" ]; + lispLibs = [ + (getAttr "assertion-error" self) + (getAttr "simplet-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + assertion-error = ( + build-asdf-system { + pname = "assertion-error"; + version = "20191227-git"; + asds = [ "assertion-error" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/assertion-error/2019-12-27/assertion-error-20191227-git.tgz"; + sha256 = "0ix23kkakmf4nwx852zsssb831jvajr3qyppqfyks7y1ls617svn"; + system = "assertion-error"; + asd = "assertion-error"; + } + ); + systems = [ "assertion-error" ]; + lispLibs = [ (getAttr "dissect" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + assoc-utils = ( + build-asdf-system { + pname = "assoc-utils"; + version = "20241012-git"; + asds = [ "assoc-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/assoc-utils/2024-10-12/assoc-utils-20241012-git.tgz"; + sha256 = "0rgfv9qni9dnmm3qnaf1x67h0z38vw2zbmbsdk3a4x5s8ckxln6r"; + system = "assoc-utils"; + asd = "assoc-utils"; + } + ); + systems = [ "assoc-utils" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + assoc-utils-test = ( + build-asdf-system { + pname = "assoc-utils-test"; + version = "20241012-git"; + asds = [ "assoc-utils-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/assoc-utils/2024-10-12/assoc-utils-20241012-git.tgz"; + sha256 = "0rgfv9qni9dnmm3qnaf1x67h0z38vw2zbmbsdk3a4x5s8ckxln6r"; + system = "assoc-utils-test"; + asd = "assoc-utils-test"; + } + ); + systems = [ "assoc-utils-test" ]; + lispLibs = [ + (getAttr "assoc-utils" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + asteroids = ( + build-asdf-system { + pname = "asteroids"; + version = "20191007-git"; + asds = [ "asteroids" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asteroids/2019-10-07/asteroids-20191007-git.tgz"; + sha256 = "1wdzwpizgy477ny6pxjshj3q25phdxsjfq8cvrbx0x7k5w8fkg50"; + system = "asteroids"; + asd = "asteroids"; + } + ); + systems = [ "asteroids" ]; + lispLibs = [ + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-gfx" self) + (getAttr "lispbuilder-sdl-mixer" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + astonish = ( + build-asdf-system { + pname = "astonish"; + version = "20210124-git"; + asds = [ "astonish" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/astonish/2021-01-24/astonish-20210124-git.tgz"; + sha256 = "14qphx97q4gqcc71figc6r3cgy89rn9c43sh35fzxkln9ydk2pr6"; + system = "astonish"; + asd = "astonish"; + } + ); + systems = [ "astonish" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + async-process = ( + build-asdf-system { + pname = "async-process"; + version = "20241012-git"; + asds = [ "async-process" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/async-process/2024-10-12/async-process-20241012-git.tgz"; + sha256 = "0691z0vs5c65m24p1yi12iy27j59layzvzyy1yl19704x05442qh"; + system = "async-process"; + asd = "async-process"; + } + ); + systems = [ "async-process" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + atdoc = ( + build-asdf-system { + pname = "atdoc"; + version = "20120305-git"; + asds = [ "atdoc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/atdoc/2012-03-05/atdoc-20120305-git.tgz"; + sha256 = "1w54phadjj00sy5qz5n0hmhzyjrx26h9hw06756zdpfbzk4f5il6"; + system = "atdoc"; + asd = "atdoc"; + } + ); + systems = [ "atdoc" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "cxml" self) + (getAttr "split-sequence" self) + (getAttr "swank" self) + (getAttr "xuriella" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + atomics = ( + build-asdf-system { + pname = "atomics"; + version = "20241012-git"; + asds = [ "atomics" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/atomics/2024-10-12/atomics-20241012-git.tgz"; + sha256 = "1ah6fgvfva0axnhj4sp1qy6gjyw41fkhpnv998di0wbp6hls8j39"; + system = "atomics"; + asd = "atomics"; + } + ); + systems = [ "atomics" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + atomics-test = ( + build-asdf-system { + pname = "atomics-test"; + version = "20241012-git"; + asds = [ "atomics-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/atomics/2024-10-12/atomics-20241012-git.tgz"; + sha256 = "1ah6fgvfva0axnhj4sp1qy6gjyw41fkhpnv998di0wbp6hls8j39"; + system = "atomics-test"; + asd = "atomics-test"; + } + ); + systems = [ "atomics-test" ]; + lispLibs = [ + (getAttr "atomics" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + audio-tag = ( + build-asdf-system { + pname = "audio-tag"; + version = "20210531-git"; + asds = [ "audio-tag" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/audio-tag/2021-05-31/audio-tag-20210531-git.tgz"; + sha256 = "1k9152wakazr34q4q5x8zzv3mjjkf0n9xdg7c2qqwigwws0ysgzh"; + system = "audio-tag"; + asd = "audio-tag"; + } + ); + systems = [ "audio-tag" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "osicat" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + authenticated-encryption = ( + build-asdf-system { + pname = "authenticated-encryption"; + version = "20181018-git"; + asds = [ "authenticated-encryption" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/authenticated-encryption/2018-10-18/authenticated-encryption-20181018-git.tgz"; + sha256 = "0cvl4g0g59z5dicg7q3f9hhqshz2m0a6l2fzic75c3yv28q8m2vr"; + system = "authenticated-encryption"; + asd = "authenticated-encryption"; + } + ); + systems = [ "authenticated-encryption" ]; + lispLibs = [ (getAttr "ironclad" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + authenticated-encryption-test = ( + build-asdf-system { + pname = "authenticated-encryption-test"; + version = "20181018-git"; + asds = [ "authenticated-encryption-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/authenticated-encryption/2018-10-18/authenticated-encryption-20181018-git.tgz"; + sha256 = "0cvl4g0g59z5dicg7q3f9hhqshz2m0a6l2fzic75c3yv28q8m2vr"; + system = "authenticated-encryption-test"; + asd = "authenticated-encryption-test"; + } + ); + systems = [ "authenticated-encryption-test" ]; + lispLibs = [ + (getAttr "_1am" self) + (getAttr "authenticated-encryption" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + auto-restart = ( + build-asdf-system { + pname = "auto-restart"; + version = "20241012-git"; + asds = [ "auto-restart" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/auto-restart/2024-10-12/auto-restart-20241012-git.tgz"; + sha256 = "1kz50w4x7glin8fyrfysazz07r4rrk90daml35yrwnz08vi3dfw7"; + system = "auto-restart"; + asd = "auto-restart"; + } + ); + systems = [ "auto-restart" ]; + lispLibs = [ (getAttr "iterate" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + autoexport = ( + build-asdf-system { + pname = "autoexport"; + version = "20211020-git"; + asds = [ "autoexport" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/autoexport/2021-10-20/autoexport-20211020-git.tgz"; + sha256 = "15kzq4hfsracxapxik3i6sxqqnwl7cb9lisgk9krrsk13d97l844"; + system = "autoexport"; + asd = "autoexport"; + } + ); + systems = [ "autoexport" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + automaton = ( + build-asdf-system { + pname = "automaton"; + version = "20241012-git"; + asds = [ "automaton" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "automaton"; + asd = "automaton"; + } + ); + systems = [ "automaton" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + avatar-api = ( + build-asdf-system { + pname = "avatar-api"; + version = "20150608-git"; + asds = [ "avatar-api" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/avatar-api/2015-06-08/avatar-api-20150608-git.tgz"; + sha256 = "026s8m0bl13iqyakfxc6zwacvpj2bxxipms1kl3k9ql99yn8imvr"; + system = "avatar-api"; + asd = "avatar-api"; + } + ); + systems = [ "avatar-api" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "crypto-shortcuts" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + avatar-api-test = ( + build-asdf-system { + pname = "avatar-api-test"; + version = "20150608-git"; + asds = [ "avatar-api-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/avatar-api/2015-06-08/avatar-api-20150608-git.tgz"; + sha256 = "026s8m0bl13iqyakfxc6zwacvpj2bxxipms1kl3k9ql99yn8imvr"; + system = "avatar-api-test"; + asd = "avatar-api-test"; + } + ); + systems = [ "avatar-api-test" ]; + lispLibs = [ + (getAttr "avatar-api" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + avl-tree = ( + build-asdf-system { + pname = "avl-tree"; + version = "20220707-git"; + asds = [ "avl-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/avl-tree/2022-07-07/avl-tree-20220707-git.tgz"; + sha256 = "1xvh5rpz0kwzx42jrnh3kgqa87z5kmgd7f3fkkydiqj04hknsj7k"; + system = "avl-tree"; + asd = "avl-tree"; + } + ); + systems = [ "avl-tree" ]; + lispLibs = [ (getAttr "mfiano-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + aws-foundation = ( + build-asdf-system { + pname = "aws-foundation"; + version = "20180711-git"; + asds = [ "aws-foundation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/aws-foundation/2018-07-11/aws-foundation-20180711-git.tgz"; + sha256 = "1f5af22qw583frqjhnkf9wcccdkkpjiv0bbnlqqk7fxzm9pqpvhb"; + system = "aws-foundation"; + asd = "aws-foundation"; + } + ); + systems = [ "aws-foundation" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-json" self) + (getAttr "cl-json-helper" self) + (getAttr "dexador" self) + (getAttr "ironclad" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + aws-sdk = ( + build-asdf-system { + pname = "aws-sdk"; + version = "20241012-git"; + asds = [ "aws-sdk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/aws-sdk-lisp/2024-10-12/aws-sdk-lisp-20241012-git.tgz"; + sha256 = "0iqm441fr1qx5py7cvrv4jl9zgfsm813igwvq3rj90606g6lyxjc"; + system = "aws-sdk"; + asd = "aws-sdk"; + } + ); + systems = [ "aws-sdk" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "assoc-utils" self) + (getAttr "aws-sign4" self) + (getAttr "babel" self) + (getAttr "cl-base64" self) + (getAttr "cl-ppcre" self) + (getAttr "dexador" self) + (getAttr "ironclad" self) + (getAttr "kebab" self) + (getAttr "local-time" self) + (getAttr "parser_dot_ini" self) + (getAttr "quri" self) + (getAttr "trivial-timeout" self) + (getAttr "trivial-types" self) + (getAttr "xmls" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + aws-sign4 = ( + build-asdf-system { + pname = "aws-sign4"; + version = "20201220-git"; + asds = [ "aws-sign4" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/aws-sign4/2020-12-20/aws-sign4-20201220-git.tgz"; + sha256 = "1bwqmy9vlq0ilwhp48y05cdfav9inwv4kai8mjj1a95776xjmjnk"; + system = "aws-sign4"; + asd = "aws-sign4"; + } + ); + systems = [ "aws-sign4" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "ironclad" self) + (getAttr "local-time" self) + (getAttr "secret-values" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + aws-sign4-example = ( + build-asdf-system { + pname = "aws-sign4-example"; + version = "20201220-git"; + asds = [ "aws-sign4-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/aws-sign4/2020-12-20/aws-sign4-20201220-git.tgz"; + sha256 = "1bwqmy9vlq0ilwhp48y05cdfav9inwv4kai8mjj1a95776xjmjnk"; + system = "aws-sign4-example"; + asd = "aws-sign4"; + } + ); + systems = [ "aws-sign4-example" ]; + lispLibs = [ + (getAttr "aws-sign4" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + aws-sign4-tests = ( + build-asdf-system { + pname = "aws-sign4-tests"; + version = "20201220-git"; + asds = [ "aws-sign4-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/aws-sign4/2020-12-20/aws-sign4-20201220-git.tgz"; + sha256 = "1bwqmy9vlq0ilwhp48y05cdfav9inwv4kai8mjj1a95776xjmjnk"; + system = "aws-sign4-tests"; + asd = "aws-sign4"; + } + ); + systems = [ "aws-sign4-tests" ]; + lispLibs = [ (getAttr "aws-sign4" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ayah-captcha = ( + build-asdf-system { + pname = "ayah-captcha"; + version = "20180228-git"; + asds = [ "ayah-captcha" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ayah-captcha/2018-02-28/ayah-captcha-20180228-git.tgz"; + sha256 = "1l9zg0hj5cd1yda1nnab7byrgkakh5vn3qcd4lmfidbijk6kiamw"; + system = "ayah-captcha"; + asd = "ayah-captcha"; + } + ); + systems = [ "ayah-captcha" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ayah-captcha-demo = ( + build-asdf-system { + pname = "ayah-captcha-demo"; + version = "20180228-git"; + asds = [ "ayah-captcha-demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ayah-captcha/2018-02-28/ayah-captcha-20180228-git.tgz"; + sha256 = "1l9zg0hj5cd1yda1nnab7byrgkakh5vn3qcd4lmfidbijk6kiamw"; + system = "ayah-captcha-demo"; + asd = "ayah-captcha-demo"; + } + ); + systems = [ "ayah-captcha-demo" ]; + lispLibs = [ + (getAttr "ayah-captcha" self) + (getAttr "cl-who" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + babel = ( + build-asdf-system { + pname = "babel"; + version = "20241012-git"; + asds = [ "babel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/babel/2024-10-12/babel-20241012-git.tgz"; + sha256 = "0359bj3yr6frybcmg8qr5vi4q8hzbsb7hmvxdc0jgkfz3c33q667"; + system = "babel"; + asd = "babel"; + } + ); + systems = [ "babel" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-features" self) + ]; + meta = { }; + } + ); + babel-streams = ( + build-asdf-system { + pname = "babel-streams"; + version = "20241012-git"; + asds = [ "babel-streams" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/babel/2024-10-12/babel-20241012-git.tgz"; + sha256 = "0359bj3yr6frybcmg8qr5vi4q8hzbsb7hmvxdc0jgkfz3c33q667"; + system = "babel-streams"; + asd = "babel-streams"; + } + ); + systems = [ "babel-streams" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + babel-tests = ( + build-asdf-system { + pname = "babel-tests"; + version = "20241012-git"; + asds = [ "babel-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/babel/2024-10-12/babel-20241012-git.tgz"; + sha256 = "0359bj3yr6frybcmg8qr5vi4q8hzbsb7hmvxdc0jgkfz3c33q667"; + system = "babel-tests"; + asd = "babel-tests"; + } + ); + systems = [ "babel-tests" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + babylon = ( + build-asdf-system { + pname = "babylon"; + version = "20231021-git"; + asds = [ "babylon" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/babylon/2023-10-21/babylon-20231021-git.tgz"; + sha256 = "14k9kvcfyfpn74l5ij5mdc7zlj9vnlnig8piqw0wm5gq9pxmhydg"; + system = "babylon"; + asd = "babylon"; + } + ); + systems = [ "babylon" ]; + lispLibs = [ + (getAttr "fare-quasiquote-extras" self) + (getAttr "fmcs" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + base = ( + build-asdf-system { + pname = "base"; + version = "master-fe503896-git"; + asds = [ "base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "base"; + asd = "base"; + } + ); + systems = [ "base" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + base-blobs = ( + build-asdf-system { + pname = "base-blobs"; + version = "stable-git"; + asds = [ "base-blobs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/base-blobs/2020-10-16/base-blobs-stable-git.tgz"; + sha256 = "06m8rvczj309wq8by697gvrklhff5mnn5n5sky7i11bnszrxysys"; + system = "base-blobs"; + asd = "base-blobs"; + } + ); + systems = [ "base-blobs" ]; + lispLibs = [ + (getAttr "bodge-blobs-support" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + base64 = ( + build-asdf-system { + pname = "base64"; + version = "20181018-git"; + asds = [ "base64" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/base64/2018-10-18/base64-20181018-git.tgz"; + sha256 = "0qkqcrgmcqshcsnzn4pcyk8d1j9c7pks2qf51p1hfybz5shxkqkh"; + system = "base64"; + asd = "base64"; + } + ); + systems = [ "base64" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + basic-binary-ipc = ( + build-asdf-system { + pname = "basic-binary-ipc"; + version = "20211209-git"; + asds = [ "basic-binary-ipc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/basic-binary-ipc/2021-12-09/basic-binary-ipc-20211209-git.tgz"; + sha256 = "0bsxy27mnmzr6vys96cs2is57zvk0n9hlif9llnp4q9m2wzycbwm"; + system = "basic-binary-ipc"; + asd = "basic-binary-ipc"; + } + ); + systems = [ "basic-binary-ipc" ]; + lispLibs = [ (getAttr "cffi-grovel" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + basic-binary-ipc-tests = ( + build-asdf-system { + pname = "basic-binary-ipc-tests"; + version = "20211209-git"; + asds = [ "basic-binary-ipc-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/basic-binary-ipc/2021-12-09/basic-binary-ipc-20211209-git.tgz"; + sha256 = "0bsxy27mnmzr6vys96cs2is57zvk0n9hlif9llnp4q9m2wzycbwm"; + system = "basic-binary-ipc-tests"; + asd = "basic-binary-ipc-tests"; + } + ); + systems = [ "basic-binary-ipc-tests" ]; + lispLibs = [ + (getAttr "basic-binary-ipc" self) + (getAttr "bordeaux-threads" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bdef = ( + build-asdf-system { + pname = "bdef"; + version = "20241012-git"; + asds = [ "bdef" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bdef/2024-10-12/bdef-20241012-git.tgz"; + sha256 = "16jz9fxxjcpnmhx0yagv8xs7l0b7qh8yx7i7p8fnlxz3pn7726y6"; + system = "bdef"; + asd = "bdef"; + } + ); + systems = [ "bdef" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "eager-future2" self) + (getAttr "jsown" self) + (getAttr "mutility" self) + (getAttr "parse-float" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + beast = ( + build-asdf-system { + pname = "beast"; + version = "20211020-hg"; + asds = [ "beast" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/beast/2021-10-20/beast-20211020-hg.tgz"; + sha256 = "0rb7yxr4clsdbgyjz9d8inxgj7zs0knrngl7gb6b8ky1vyrv12k4"; + system = "beast"; + asd = "beast"; + } + ); + systems = [ "beast" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + beirc = ( + build-asdf-system { + pname = "beirc"; + version = "20150505-git"; + asds = [ "beirc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/beirc/2015-05-05/beirc-20150505-git.tgz"; + sha256 = "1jmxihxln51vxy85r3zx0gfrzs9ng8nmj87j5ws1fg8bwv8b2zc4"; + system = "beirc"; + asd = "beirc"; + } + ); + systems = [ "beirc" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cl-irc" self) + (getAttr "cl-ppcre" self) + (getAttr "mcclim" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bencode = ( + build-asdf-system { + pname = "bencode"; + version = "20180228-git"; + asds = [ "bencode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bencode/2018-02-28/cl-bencode-20180228-git.tgz"; + sha256 = "02n9cv5jbgzjwmw11c1a557r62m4i4gmmx38csscbq0cv6vzys1j"; + system = "bencode"; + asd = "bencode"; + } + ); + systems = [ "bencode" ]; + lispLibs = [ (getAttr "flexi-streams" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bencode-test = ( + build-asdf-system { + pname = "bencode-test"; + version = "20180228-git"; + asds = [ "bencode-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bencode/2018-02-28/cl-bencode-20180228-git.tgz"; + sha256 = "02n9cv5jbgzjwmw11c1a557r62m4i4gmmx38csscbq0cv6vzys1j"; + system = "bencode-test"; + asd = "bencode"; + } + ); + systems = [ "bencode-test" ]; + lispLibs = [ + (getAttr "bencode" self) + (getAttr "check-it" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bermuda = ( + build-asdf-system { + pname = "bermuda"; + version = "20150608-git"; + asds = [ "bermuda" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pal/2015-06-08/pal-20150608-git.tgz"; + sha256 = "0kn6jxirrn7wzqymzsi0kx2ivl0nrrcgbl4dm1714s48qw0jwhcw"; + system = "bermuda"; + asd = "bermuda"; + } + ); + systems = [ "bermuda" ]; + lispLibs = [ (getAttr "pal" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bert = ( + build-asdf-system { + pname = "bert"; + version = "20141106-git"; + asds = [ "bert" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bert/2014-11-06/cl-bert-20141106-git.tgz"; + sha256 = "18cyk63dmcqqwsld4h65mzscgjsc085ws69z097naqm1r70kkygr"; + system = "bert"; + asd = "bert"; + } + ); + systems = [ "bert" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "erlang-term" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bibtex = ( + build-asdf-system { + pname = "bibtex"; + version = "20181210-git"; + asds = [ "bibtex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bibtex/2018-12-10/cl-bibtex-20181210-git.tgz"; + sha256 = "1rb4yf1z0vvl6z4kyj0s81kq1pvxwpvbgiaraqllgj1wpf51m78h"; + system = "bibtex"; + asd = "bibtex"; + } + ); + systems = [ "bibtex" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + big-string = ( + build-asdf-system { + pname = "big-string"; + version = "20230618-git"; + asds = [ "big-string" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/big-string/2023-06-18/big-string-20230618-git.tgz"; + sha256 = "03w0y3x9sm0fv0dclmrnh55i83nviz7pw7mdg6di05gw03bnslrc"; + system = "big-string"; + asd = "big-string"; + } + ); + systems = [ "big-string" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bike-internals = ( + build-asdf-system { + pname = "bike-internals"; + version = "20241012-git"; + asds = [ "bike-internals" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bike/2024-10-12/bike-20241012-git.tgz"; + sha256 = "0ssv4n39wl3i0r8gy2sg6rxfz571jcfsd6db9ndy13drqnhyda6s"; + system = "bike-internals"; + asd = "bike-internals"; + } + ); + systems = [ "bike-internals" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "flexi-streams" self) + (getAttr "global-vars" self) + (getAttr "split-sequence" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + binary-io = ( + build-asdf-system { + pname = "binary-io"; + version = "20201016-git"; + asds = [ "binary-io" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/binary-io/2020-10-16/binary-io-20201016-git.tgz"; + sha256 = "0gxnl12nydh8aslw78jc4cmq8licj342y2f04jalqb4d9m9jbri2"; + system = "binary-io"; + asd = "binary-io"; + } + ); + systems = [ "binary-io" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "ieee-floats" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + binary-lass = ( + build-asdf-system { + pname = "binary-lass"; + version = "20241012-git"; + asds = [ "binary-lass" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lass/2024-10-12/lass-20241012-git.tgz"; + sha256 = "1b6a3v763i5fcdxczffd59kh4m73p4ilz6az85apd22apc8lr80z"; + system = "binary-lass"; + asd = "binary-lass"; + } + ); + systems = [ "binary-lass" ]; + lispLibs = [ (getAttr "lass" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + binary-parser = ( + build-asdf-system { + pname = "binary-parser"; + version = "20230214-git"; + asds = [ "binary-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/binary-parser/2023-02-14/binary-parser-20230214-git.tgz"; + sha256 = "06lq5iv0ap6qnsrc73rmnr9qirllyz4yxsvimj6ny5wl2hn8i9jl"; + system = "binary-parser"; + asd = "binary-parser"; + } + ); + systems = [ "binary-parser" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "bitio" self) + (getAttr "chipz" self) + (getAttr "fast-io" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + binary-search-tree = ( + build-asdf-system { + pname = "binary-search-tree"; + version = "20220707-git"; + asds = [ "binary-search-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/binary-search-tree/2022-07-07/binary-search-tree-20220707-git.tgz"; + sha256 = "1k7p5dgziwni5yma7q3sbnr23kk2730vzb7ap6knnazpp0smgclf"; + system = "binary-search-tree"; + asd = "binary-search-tree"; + } + ); + systems = [ "binary-search-tree" ]; + lispLibs = [ (getAttr "mfiano-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + binary-structures = ( + build-asdf-system { + pname = "binary-structures"; + version = "20241012-git"; + asds = [ "binary-structures" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/binary-structures/2024-10-12/binary-structures-20241012-git.tgz"; + sha256 = "1ygfa4xgd0wliggmmxlqqh9nd7hfsgjwl168l8s9r595vx6fnzmb"; + system = "binary-structures"; + asd = "binary-structures"; + } + ); + systems = [ "binary-structures" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "form-fiddle" self) + (getAttr "nibbles" self) + (getAttr "trivial-extensible-sequences" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + binary-types = ( + build-asdf-system { + pname = "binary-types"; + version = "20130615-git"; + asds = [ "binary-types" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/binary-types/2013-06-15/binary-types-20130615-git.tgz"; + sha256 = "1bh65p9vg2kgh4m8q1a4jiyncnp5prdzh0d0l4pzh3jvfhgbm0gh"; + system = "binary-types"; + asd = "binary-types"; + } + ); + systems = [ "binary-types" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + binascii = ( + build-asdf-system { + pname = "binascii"; + version = "20150709-git"; + asds = [ "binascii" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/binascii/2015-07-09/binascii-20150709-git.tgz"; + sha256 = "000rcdl8qshr7n48zq9bzrc4lkjx4ylb3r3w9x9syhiwfla9j4b7"; + system = "binascii"; + asd = "binascii"; + } + ); + systems = [ "binascii" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + binascii-tests = ( + build-asdf-system { + pname = "binascii-tests"; + version = "20150709-git"; + asds = [ "binascii-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/binascii/2015-07-09/binascii-20150709-git.tgz"; + sha256 = "000rcdl8qshr7n48zq9bzrc4lkjx4ylb3r3w9x9syhiwfla9j4b7"; + system = "binascii-tests"; + asd = "binascii"; + } + ); + systems = [ "binascii-tests" ]; + lispLibs = [ (getAttr "binascii" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + binding-arrows = ( + build-asdf-system { + pname = "binding-arrows"; + version = "20241012-git"; + asds = [ "binding-arrows" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/binding-arrows/2024-10-12/binding-arrows-20241012-git.tgz"; + sha256 = "0kzybw5qlb49czh9v2lnxniz9jzqx306a6lnarfv59x48a7cch22"; + system = "binding-arrows"; + asd = "binding-arrows"; + } + ); + systems = [ "binding-arrows" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + binding-knx = ( + build-asdf-system { + pname = "binding-knx"; + version = "20241012-git"; + asds = [ "binding-knx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chipi/2024-10-12/chipi-20241012-git.tgz"; + sha256 = "0xpfclvl5v031cjnjvr3bcfc87rayw624m9yrw35f5r31p8m283g"; + system = "binding-knx"; + asd = "binding-knx"; + } + ); + systems = [ "binding-knx" ]; + lispLibs = [ + (getAttr "chipi" self) + (getAttr "knx-conn" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + binfix = ( + build-asdf-system { + pname = "binfix"; + version = "20190813-git"; + asds = [ "binfix" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/binfix/2019-08-13/binfix-20190813-git.tgz"; + sha256 = "07925kj32y7ppwmz62c08gd0s6yp12s6nz1wh0pzh0ccq9nwgzhz"; + system = "binfix"; + asd = "binfix"; + } + ); + systems = [ "binfix" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + binomial-heap = ( + build-asdf-system { + pname = "binomial-heap"; + version = "20130420-git"; + asds = [ "binomial-heap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/binomial-heap/2013-04-20/binomial-heap-20130420-git.tgz"; + sha256 = "1d4jrlkdjdppnvqpqkr7i7djpgmrvrbky4pc1pxvqci5jx7xlkk6"; + system = "binomial-heap"; + asd = "binomial-heap"; + } + ); + systems = [ "binomial-heap" ]; + lispLibs = [ ]; + meta = { }; + } + ); + binpack = ( + build-asdf-system { + pname = "binpack"; + version = "20230214-git"; + asds = [ "binpack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/binpack/2023-02-14/binpack-20230214-git.tgz"; + sha256 = "0cfflx7aqmkzsljjaw0dwk49ii0vxm7d07s4gyrszb7zbpmz0jri"; + system = "binpack"; + asd = "binpack"; + } + ); + systems = [ "binpack" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { }; + } + ); + binpack-test = ( + build-asdf-system { + pname = "binpack-test"; + version = "20230214-git"; + asds = [ "binpack-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/binpack/2023-02-14/binpack-20230214-git.tgz"; + sha256 = "0cfflx7aqmkzsljjaw0dwk49ii0vxm7d07s4gyrszb7zbpmz0jri"; + system = "binpack-test"; + asd = "binpack-test"; + } + ); + systems = [ "binpack-test" ]; + lispLibs = [ + (getAttr "binpack" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + birch = ( + build-asdf-system { + pname = "birch"; + version = "20241012-git"; + asds = [ "birch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/birch/2024-10-12/birch-20241012-git.tgz"; + sha256 = "1b24xng92ra7420s3zy44pybk4h7xg4kjwdk35arl46badgi28r1"; + system = "birch"; + asd = "birch"; + } + ); + systems = [ "birch" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl_plus_ssl" self) + (getAttr "flexi-streams" self) + (getAttr "split-sequence" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + birch_dot_test = ( + build-asdf-system { + pname = "birch.test"; + version = "20241012-git"; + asds = [ "birch.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/birch/2024-10-12/birch-20241012-git.tgz"; + sha256 = "1b24xng92ra7420s3zy44pybk4h7xg4kjwdk35arl46badgi28r1"; + system = "birch.test"; + asd = "birch.test"; + } + ); + systems = [ "birch.test" ]; + lispLibs = [ + (getAttr "birch" self) + (getAttr "flexi-streams" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bit-ops = ( + build-asdf-system { + pname = "bit-ops"; + version = "20180228-git"; + asds = [ "bit-ops" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bit-ops/2018-02-28/bit-ops-20180228-git.tgz"; + sha256 = "0rwmm438bgxfl5ab1vnrsxgimxnr3d5kjv9a0yzmlnbg9i2hyhz7"; + system = "bit-ops"; + asd = "bit-ops"; + } + ); + systems = [ "bit-ops" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "immutable-struct" self) + (getAttr "iterate" self) + (getAttr "lisp-namespace" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bit-ops_dot_test = ( + build-asdf-system { + pname = "bit-ops.test"; + version = "20180228-git"; + asds = [ "bit-ops.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bit-ops/2018-02-28/bit-ops-20180228-git.tgz"; + sha256 = "0rwmm438bgxfl5ab1vnrsxgimxnr3d5kjv9a0yzmlnbg9i2hyhz7"; + system = "bit-ops.test"; + asd = "bit-ops.test"; + } + ); + systems = [ "bit-ops.test" ]; + lispLibs = [ + (getAttr "bit-ops" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bit-smasher = ( + build-asdf-system { + pname = "bit-smasher"; + version = "20221106-git"; + asds = [ "bit-smasher" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bit-smasher/2022-11-06/bit-smasher-20221106-git.tgz"; + sha256 = "1dad4x9sjq45zz8rys6rflsklmw77631r3k4g248ynmaqkdaqjyd"; + system = "bit-smasher"; + asd = "bit-smasher"; + } + ); + systems = [ "bit-smasher" ]; + lispLibs = [ + (getAttr "cl-base58" self) + (getAttr "cl-base64" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bit-smasher-test = ( + build-asdf-system { + pname = "bit-smasher-test"; + version = "20221106-git"; + asds = [ "bit-smasher-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bit-smasher/2022-11-06/bit-smasher-20221106-git.tgz"; + sha256 = "1dad4x9sjq45zz8rys6rflsklmw77631r3k4g248ynmaqkdaqjyd"; + system = "bit-smasher-test"; + asd = "bit-smasher-test"; + } + ); + systems = [ "bit-smasher-test" ]; + lispLibs = [ + (getAttr "bit-smasher" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bitfield = ( + build-asdf-system { + pname = "bitfield"; + version = "20211230-git"; + asds = [ "bitfield" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bitfield/2021-12-30/bitfield-20211230-git.tgz"; + sha256 = "1137kdj5imc5gj9g6hj4w6ksqnqppgm3knzv7j2f8r5qpfl8rfl2"; + system = "bitfield"; + asd = "bitfield"; + } + ); + systems = [ "bitfield" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bitfield-schema = ( + build-asdf-system { + pname = "bitfield-schema"; + version = "20120107-git"; + asds = [ "bitfield-schema" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bitfield-schema/2012-01-07/bitfield-schema-20120107-git.tgz"; + sha256 = "08xkl7rbfhrx8vj98zj1lmhv6pfg2f5gk14xj7qys7mkj2iv4li6"; + system = "bitfield-schema"; + asd = "bitfield-schema"; + } + ); + systems = [ "bitfield-schema" ]; + lispLibs = [ (getAttr "iterate" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bitio = ( + build-asdf-system { + pname = "bitio"; + version = "20220220-git"; + asds = [ "bitio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bitio/2022-02-20/bitio-20220220-git.tgz"; + sha256 = "0z2yn19nxg46j274nxzry255z86p0y3p68s1f2sg7rx9y2nx3rjg"; + system = "bitio"; + asd = "bitio"; + } + ); + systems = [ "bitio" ]; + lispLibs = [ + (getAttr "checkl" self) + (getAttr "cl-package-locks" self) + (getAttr "fast-io" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bk-tree = ( + build-asdf-system { + pname = "bk-tree"; + version = "20130420-git"; + asds = [ "bk-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bk-tree/2013-04-20/bk-tree-20130420-git.tgz"; + sha256 = "1nrz6fwzvkzvs6ipc5rgas77p5hv5bnaw2in5760v240gg7lxqzz"; + system = "bk-tree"; + asd = "bk-tree"; + } + ); + systems = [ "bk-tree" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bknr_dot_data_dot_impex = ( + build-asdf-system { + pname = "bknr.data.impex"; + version = "20220220-git"; + asds = [ "bknr.data.impex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; + sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; + system = "bknr.data.impex"; + asd = "bknr.data.impex"; + } + ); + systems = [ "bknr.data.impex" ]; + lispLibs = [ + (getAttr "bknr_dot_datastore" self) + (getAttr "bknr_dot_impex" self) + (getAttr "bknr_dot_indices" self) + (getAttr "bknr_dot_utils" self) + (getAttr "cl-interpol" self) + (getAttr "unit-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bknr_dot_datastore = ( + build-asdf-system { + pname = "bknr.datastore"; + version = "20220220-git"; + asds = [ "bknr.datastore" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; + sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; + system = "bknr.datastore"; + asd = "bknr.datastore"; + } + ); + systems = [ "bknr.datastore" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bknr_dot_indices" self) + (getAttr "bknr_dot_utils" self) + (getAttr "cl-interpol" self) + (getAttr "closer-mop" self) + (getAttr "trivial-utf-8" self) + (getAttr "unit-test" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bknr_dot_impex = ( + build-asdf-system { + pname = "bknr.impex"; + version = "20220220-git"; + asds = [ "bknr.impex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; + sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; + system = "bknr.impex"; + asd = "bknr.impex"; + } + ); + systems = [ "bknr.impex" ]; + lispLibs = [ + (getAttr "bknr_dot_indices" self) + (getAttr "bknr_dot_utils" self) + (getAttr "bknr_dot_xml" self) + (getAttr "cl-interpol" self) + (getAttr "closer-mop" self) + (getAttr "cxml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bknr_dot_indices = ( + build-asdf-system { + pname = "bknr.indices"; + version = "20220220-git"; + asds = [ "bknr.indices" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; + sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; + system = "bknr.indices"; + asd = "bknr.indices"; + } + ); + systems = [ "bknr.indices" ]; + lispLibs = [ + (getAttr "bknr_dot_skip-list" self) + (getAttr "bknr_dot_utils" self) + (getAttr "cl-interpol" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bknr_dot_modules = ( + build-asdf-system { + pname = "bknr.modules"; + version = "20140713-git"; + asds = [ "bknr.modules" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-web/2014-07-13/bknr-web-20140713-git.tgz"; + sha256 = "1m73z0hv7qsc9yddrg8zs7n3zmn9h64v4d62239wrvfnmzqk75x2"; + system = "bknr.modules"; + asd = "bknr.modules"; + } + ); + systems = [ "bknr.modules" ]; + lispLibs = [ + (getAttr "bknr_dot_utils" self) + (getAttr "bknr_dot_web" self) + (getAttr "cl-gd" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-smtp" self) + (getAttr "closer-mop" self) + (getAttr "cxml" self) + (getAttr "md5" self) + (getAttr "parenscript" self) + (getAttr "puri" self) + (getAttr "stem" self) + (getAttr "unit-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bknr_dot_skip-list = ( + build-asdf-system { + pname = "bknr.skip-list"; + version = "20220220-git"; + asds = [ "bknr.skip-list" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; + sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; + system = "bknr.skip-list"; + asd = "bknr.skip-list"; + } + ); + systems = [ "bknr.skip-list" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bknr_dot_skip-list_dot_test = ( + build-asdf-system { + pname = "bknr.skip-list.test"; + version = "20220220-git"; + asds = [ "bknr.skip-list.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; + sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; + system = "bknr.skip-list.test"; + asd = "bknr.skip-list"; + } + ); + systems = [ "bknr.skip-list.test" ]; + lispLibs = [ + (getAttr "bknr_dot_skip-list" self) + (getAttr "unit-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bknr_dot_utils = ( + build-asdf-system { + pname = "bknr.utils"; + version = "20220220-git"; + asds = [ "bknr.utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; + sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; + system = "bknr.utils"; + asd = "bknr.utils"; + } + ); + systems = [ "bknr.utils" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "md5" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bknr_dot_web = ( + build-asdf-system { + pname = "bknr.web"; + version = "20140713-git"; + asds = [ "bknr.web" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-web/2014-07-13/bknr-web-20140713-git.tgz"; + sha256 = "1m73z0hv7qsc9yddrg8zs7n3zmn9h64v4d62239wrvfnmzqk75x2"; + system = "bknr.web"; + asd = "bknr.web"; + } + ); + systems = [ "bknr.web" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bknr_dot_data_dot_impex" self) + (getAttr "bknr_dot_datastore" self) + (getAttr "bknr_dot_utils" self) + (getAttr "bknr_dot_xml" self) + (getAttr "cl-gd" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "cxml" self) + (getAttr "drakma" self) + (getAttr "hunchentoot" self) + (getAttr "md5" self) + (getAttr "parenscript" self) + (getAttr "puri" self) + (getAttr "unit-test" self) + (getAttr "usocket" self) + (getAttr "xhtmlgen" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bknr_dot_xml = ( + build-asdf-system { + pname = "bknr.xml"; + version = "20220220-git"; + asds = [ "bknr.xml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-datastore/2022-02-20/bknr-datastore-20220220-git.tgz"; + sha256 = "1vi3w65fnczqvswkm381n6liqfrzjrg40y698qvj7skj28dm5vrm"; + system = "bknr.xml"; + asd = "bknr.xml"; + } + ); + systems = [ "bknr.xml" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "cxml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + black-tie = ( + build-asdf-system { + pname = "black-tie"; + version = "20220707-git"; + asds = [ "black-tie" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/black-tie/2022-07-07/black-tie-20220707-git.tgz"; + sha256 = "0a1zczxp4wkqs4cmwc4rnsgwwc2h4zqmg58cjykfzz4jh31fa43a"; + system = "black-tie"; + asd = "black-tie"; + } + ); + systems = [ "black-tie" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + blackbird = ( + build-asdf-system { + pname = "blackbird"; + version = "20241012-git"; + asds = [ "blackbird" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/blackbird/2024-10-12/blackbird-20241012-git.tgz"; + sha256 = "0bqg8sn816qfar410w2c2k07vqh9sig8zbkvlmwj1bk33snvmam8"; + system = "blackbird"; + asd = "blackbird"; + } + ); + systems = [ "blackbird" ]; + lispLibs = [ (getAttr "vom" self) ]; + meta = { }; + } + ); + blackbird-test = ( + build-asdf-system { + pname = "blackbird-test"; + version = "20241012-git"; + asds = [ "blackbird-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/blackbird/2024-10-12/blackbird-20241012-git.tgz"; + sha256 = "0bqg8sn816qfar410w2c2k07vqh9sig8zbkvlmwj1bk33snvmam8"; + system = "blackbird-test"; + asd = "blackbird-test"; + } + ); + systems = [ "blackbird-test" ]; + lispLibs = [ + (getAttr "blackbird" self) + (getAttr "cl-async" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + blas = ( + build-asdf-system { + pname = "blas"; + version = "20231021-git"; + asds = [ "blas" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "blas"; + asd = "blas"; + } + ); + systems = [ "blas" ]; + lispLibs = [ + (getAttr "blas-complex" self) + (getAttr "blas-package" self) + (getAttr "blas-real" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + blas-complex = ( + build-asdf-system { + pname = "blas-complex"; + version = "20231021-git"; + asds = [ "blas-complex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "blas-complex"; + asd = "blas-complex"; + } + ); + systems = [ "blas-complex" ]; + lispLibs = [ + (getAttr "blas-real" self) + (getAttr "f2cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + blas-hompack = ( + build-asdf-system { + pname = "blas-hompack"; + version = "20231021-git"; + asds = [ "blas-hompack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "blas-hompack"; + asd = "blas-hompack"; + } + ); + systems = [ "blas-hompack" ]; + lispLibs = [ + (getAttr "blas-package" self) + (getAttr "f2cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + blas-package = ( + build-asdf-system { + pname = "blas-package"; + version = "20231021-git"; + asds = [ "blas-package" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "blas-package"; + asd = "blas-package"; + } + ); + systems = [ "blas-package" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + blas-real = ( + build-asdf-system { + pname = "blas-real"; + version = "20231021-git"; + asds = [ "blas-real" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "blas-real"; + asd = "blas-real"; + } + ); + systems = [ "blas-real" ]; + lispLibs = [ + (getAttr "blas-hompack" self) + (getAttr "f2cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + blocks-world = ( + build-asdf-system { + pname = "blocks-world"; + version = "20120305-git"; + asds = [ "blocks-world" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/atdoc/2012-03-05/atdoc-20120305-git.tgz"; + sha256 = "1w54phadjj00sy5qz5n0hmhzyjrx26h9hw06756zdpfbzk4f5il6"; + system = "blocks-world"; + asd = "blocks-world"; + } + ); + systems = [ "blocks-world" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bmas = ( + build-asdf-system { + pname = "bmas"; + version = "20241012-git"; + asds = [ "bmas" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bmas/2024-10-12/cl-bmas-20241012-git.tgz"; + sha256 = "1j4wniwcxz4kqzw7q3ac8rpz2xhd0qfdgl5dylswh02ifdgq9z4m"; + system = "bmas"; + asd = "bmas"; + } + ); + systems = [ "bmas" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-autowrap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bmp-test = ( + build-asdf-system { + pname = "bmp-test"; + version = "20211020-git"; + asds = [ "bmp-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-png/2021-10-20/cl-png-20211020-git.tgz"; + sha256 = "17xcb9ps5vf3if61blmx7cpfrz3gsw7jk8d5zv3f4cq8jrriqdx4"; + system = "bmp-test"; + asd = "bmp-test"; + } + ); + systems = [ "bmp-test" ]; + lispLibs = [ (getAttr "png" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bnf = ( + build-asdf-system { + pname = "bnf"; + version = "20220220-git"; + asds = [ "bnf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bnf/2022-02-20/bnf-20220220-git.tgz"; + sha256 = "1kr6k9qs9bbza591hi1c2mlxqd5yz3nrvyd3cw7139iz1z2m7dbg"; + system = "bnf"; + asd = "bnf"; + } + ); + systems = [ "bnf" ]; + lispLibs = [ (getAttr "trestrul" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bnf_dot_test = ( + build-asdf-system { + pname = "bnf.test"; + version = "20220220-git"; + asds = [ "bnf.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bnf/2022-02-20/bnf-20220220-git.tgz"; + sha256 = "1kr6k9qs9bbza591hi1c2mlxqd5yz3nrvyd3cw7139iz1z2m7dbg"; + system = "bnf.test"; + asd = "bnf.test"; + } + ); + systems = [ "bnf.test" ]; + lispLibs = [ + (getAttr "bnf" self) + (getAttr "jingoh" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bobbin = ( + build-asdf-system { + pname = "bobbin"; + version = "20201016-hg"; + asds = [ "bobbin" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bobbin/2020-10-16/bobbin-20201016-hg.tgz"; + sha256 = "1yvx7d0cx5b119r4aays2rck33088bp7spaydnvkc329hfq1ahc2"; + system = "bobbin"; + asd = "bobbin"; + } + ); + systems = [ "bobbin" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-blobs-support = ( + build-asdf-system { + pname = "bodge-blobs-support"; + version = "stable-git"; + asds = [ "bodge-blobs-support" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-blobs-support/2020-10-16/bodge-blobs-support-stable-git.tgz"; + sha256 = "02nd1x6y1akp1ymv1y4z9ympwbnpd1drwi4f86xbjszxqff6jyj8"; + system = "bodge-blobs-support"; + asd = "bodge-blobs-support"; + } + ); + systems = [ "bodge-blobs-support" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-chipmunk = ( + build-asdf-system { + pname = "bodge-chipmunk"; + version = "stable-git"; + asds = [ "bodge-chipmunk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-chipmunk/2020-10-16/bodge-chipmunk-stable-git.tgz"; + sha256 = "06zkia7rrhn1961jmayyvdbbbnf2rnr84lbd1x6gq8psfb2rif2f"; + system = "bodge-chipmunk"; + asd = "bodge-chipmunk"; + } + ); + systems = [ "bodge-chipmunk" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-c-ref" self) + (getAttr "claw" self) + (getAttr "claw-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-concurrency = ( + build-asdf-system { + pname = "bodge-concurrency"; + version = "stable-git"; + asds = [ "bodge-concurrency" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-concurrency/2020-10-16/bodge-concurrency-stable-git.tgz"; + sha256 = "06v2h7vassp5v50qsqxkmshcrlrzlhqaga4z7lnidfniw7f8d5vd"; + system = "bodge-concurrency"; + asd = "bodge-concurrency"; + } + ); + systems = [ "bodge-concurrency" ]; + lispLibs = [ + (getAttr "bodge-memory" self) + (getAttr "bodge-queue" self) + (getAttr "bodge-utilities" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-flow" self) + (getAttr "cl-muth" self) + (getAttr "simple-flow-dispatcher" self) + (getAttr "trivial-main-thread" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-glad = ( + build-asdf-system { + pname = "bodge-glad"; + version = "stable-git"; + asds = [ "bodge-glad" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-glad/2020-10-16/bodge-glad-stable-git.tgz"; + sha256 = "0ghrg0z5pj36igp5wpvp1iwnvjbca3wfb60kvirhv3l9ww51jg9g"; + system = "bodge-glad"; + asd = "bodge-glad"; + } + ); + systems = [ "bodge-glad" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-glfw = ( + build-asdf-system { + pname = "bodge-glfw"; + version = "stable-git"; + asds = [ "bodge-glfw" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-glfw/2020-10-16/bodge-glfw-stable-git.tgz"; + sha256 = "1xjg75grndl2mbfql1g2qgx810kg6wxrnhxb406m9lisd112i0m8"; + system = "bodge-glfw"; + asd = "bodge-glfw"; + } + ); + systems = [ "bodge-glfw" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-c-ref" self) + (getAttr "claw" self) + (getAttr "claw-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-heap = ( + build-asdf-system { + pname = "bodge-heap"; + version = "stable-git"; + asds = [ "bodge-heap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-heap/2020-10-16/bodge-heap-stable-git.tgz"; + sha256 = "1ngi9ccr9iz93mm3b4hgh2fj39vqpjrpkcfza5vly16z3r7gxca4"; + system = "bodge-heap"; + asd = "bodge-heap"; + } + ); + systems = [ "bodge-heap" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-host = ( + build-asdf-system { + pname = "bodge-host"; + version = "stable-git"; + asds = [ "bodge-host" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-host/2021-12-09/bodge-host-stable-git.tgz"; + sha256 = "0piayirpbh91klrk3pg0g1vxhlk8yxvbr2wv923awdalwy0fn73n"; + system = "bodge-host"; + asd = "bodge-host"; + } + ); + systems = [ "bodge-host" ]; + lispLibs = [ + (getAttr "bodge-concurrency" self) + (getAttr "bodge-glfw" self) + (getAttr "bodge-libc-essentials" self) + (getAttr "bodge-math" self) + (getAttr "bodge-utilities" self) + (getAttr "cffi-c-ref" self) + (getAttr "float-features" self) + (getAttr "glfw-blob" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-libc-essentials = ( + build-asdf-system { + pname = "bodge-libc-essentials"; + version = "stable-git"; + asds = [ "bodge-libc-essentials" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-libc-essentials/2020-10-16/bodge-libc-essentials-stable-git.tgz"; + sha256 = "1nkjhkaap78xk9rkvnnnkchphiz0qwrsfp4jsvcl6mvv3rb4gp2k"; + system = "bodge-libc-essentials"; + asd = "bodge-libc-essentials"; + } + ); + systems = [ "bodge-libc-essentials" ]; + lispLibs = [ (getAttr "claw" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-math = ( + build-asdf-system { + pname = "bodge-math"; + version = "stable-git"; + asds = [ "bodge-math" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-math/2020-10-16/bodge-math-stable-git.tgz"; + sha256 = "0r3vnl9lywn4ksy34apcv6j825qp7l1naddawr14v4lwacndb80v"; + system = "bodge-math"; + asd = "bodge-math"; + } + ); + systems = [ "bodge-math" ]; + lispLibs = [ + (getAttr "bodge-utilities" self) + (getAttr "rtg-math" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-memory = ( + build-asdf-system { + pname = "bodge-memory"; + version = "stable-git"; + asds = [ "bodge-memory" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-memory/2020-10-16/bodge-memory-stable-git.tgz"; + sha256 = "19fn3dw5z6f2kpar0jx7ysy5zvqjv7yv0ca7njgaam3p891yy2j9"; + system = "bodge-memory"; + asd = "bodge-memory"; + } + ); + systems = [ "bodge-memory" ]; + lispLibs = [ + (getAttr "bodge-utilities" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-nanovg = ( + build-asdf-system { + pname = "bodge-nanovg"; + version = "stable-git"; + asds = [ "bodge-nanovg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-nanovg/2020-10-16/bodge-nanovg-stable-git.tgz"; + sha256 = "0cg4rlsddjrn0ps891n29xnd14xiis20ka5gafbz9npbj6nrc4v1"; + system = "bodge-nanovg"; + asd = "bodge-nanovg"; + } + ); + systems = [ "bodge-nanovg" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-c-ref" self) + (getAttr "claw" self) + (getAttr "claw-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-nuklear = ( + build-asdf-system { + pname = "bodge-nuklear"; + version = "stable-git"; + asds = [ "bodge-nuklear" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-nuklear/2020-10-16/bodge-nuklear-stable-git.tgz"; + sha256 = "15q89dz2zi99yyxhb90wyydy24y2lj5xm2mzh1mrw4v8rz9aqhc2"; + system = "bodge-nuklear"; + asd = "bodge-nuklear"; + } + ); + systems = [ "bodge-nuklear" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-c-ref" self) + (getAttr "claw" self) + (getAttr "claw-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-ode = ( + build-asdf-system { + pname = "bodge-ode"; + version = "stable-git"; + asds = [ "bodge-ode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-ode/2020-10-16/bodge-ode-stable-git.tgz"; + sha256 = "1c051ljn5x7ssysia7lil0ykjdnbx8dfkr45ck77plv39acgicbs"; + system = "bodge-ode"; + asd = "bodge-ode"; + } + ); + systems = [ "bodge-ode" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-c-ref" self) + (getAttr "claw" self) + (getAttr "claw-utils" self) + (getAttr "float-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-openal = ( + build-asdf-system { + pname = "bodge-openal"; + version = "stable-git"; + asds = [ "bodge-openal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-openal/2020-10-16/bodge-openal-stable-git.tgz"; + sha256 = "0051pwifygj1ijv5b39ldmfrka2yrj8rpap04bw3w9cckbkp6bnw"; + system = "bodge-openal"; + asd = "bodge-openal"; + } + ); + systems = [ "bodge-openal" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "claw" self) + (getAttr "claw-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-queue = ( + build-asdf-system { + pname = "bodge-queue"; + version = "stable-git"; + asds = [ "bodge-queue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-queue/2020-10-16/bodge-queue-stable-git.tgz"; + sha256 = "0f4252i8pfy5s4v7w1bpjawysn4cw7di405mqsx2h7skv27hvpz6"; + system = "bodge-queue"; + asd = "bodge-queue"; + } + ); + systems = [ "bodge-queue" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-sndfile = ( + build-asdf-system { + pname = "bodge-sndfile"; + version = "stable-git"; + asds = [ "bodge-sndfile" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-sndfile/2020-10-16/bodge-sndfile-stable-git.tgz"; + sha256 = "0chdasp4zvr5n34x037lhymh90wg5xwbpr5flwj8aw0cw2nlg485"; + system = "bodge-sndfile"; + asd = "bodge-sndfile"; + } + ); + systems = [ "bodge-sndfile" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bodge-libc-essentials" self) + (getAttr "cffi" self) + (getAttr "cffi-c-ref" self) + (getAttr "claw" self) + (getAttr "claw-utils" self) + (getAttr "static-vectors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bodge-utilities = ( + build-asdf-system { + pname = "bodge-utilities"; + version = "stable-git"; + asds = [ "bodge-utilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bodge-utilities/2022-07-07/bodge-utilities-stable-git.tgz"; + sha256 = "0jmz7zb5ahg2kfd5nrh9nb7dda5szamjv7iv9skgcvf7rwn8qf0g"; + system = "bodge-utilities"; + asd = "bodge-utilities"; + } + ); + systems = [ "bodge-utilities" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "claw" self) + (getAttr "dissect" self) + (getAttr "local-time" self) + (getAttr "log4cl" self) + (getAttr "split-sequence" self) + (getAttr "static-vectors" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bordeaux-fft = ( + build-asdf-system { + pname = "bordeaux-fft"; + version = "20150608-http"; + asds = [ "bordeaux-fft" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bordeaux-fft/2015-06-08/bordeaux-fft-20150608-http.tgz"; + sha256 = "0kmz0wv34p8wixph5i6vj6p60xa48fflh9aq6kismlb0q4a1amp3"; + system = "bordeaux-fft"; + asd = "bordeaux-fft"; + } + ); + systems = [ "bordeaux-fft" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bordeaux-threads = ( + build-asdf-system { + pname = "bordeaux-threads"; + version = "v0.9.4"; + asds = [ "bordeaux-threads" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bordeaux-threads/2024-10-12/bordeaux-threads-v0.9.4.tgz"; + sha256 = "1ds1aa3rd38hq5i1nwd9qi8icxmdag0shcwwsf7km91v9214385d"; + system = "bordeaux-threads"; + asd = "bordeaux-threads"; + } + ); + systems = [ "bordeaux-threads" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "global-vars" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + bourbaki = ( + build-asdf-system { + pname = "bourbaki"; + version = "20110110-http"; + asds = [ "bourbaki" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bourbaki/2011-01-10/bourbaki-20110110-http.tgz"; + sha256 = "0d222kjk1h60467bkjpxglds3gykily5pyrnb45yvx86shkiv4lp"; + system = "bourbaki"; + asd = "bourbaki"; + } + ); + systems = [ "bourbaki" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bp = ( + build-asdf-system { + pname = "bp"; + version = "20231021-git"; + asds = [ "bp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bp/2023-10-21/bp-20231021-git.tgz"; + sha256 = "1l58bf2fq0807id4cs39sajsfw0z7zz4gxb2vpcvfa9nxcbyziqx"; + system = "bp"; + asd = "bp"; + } + ); + systems = [ "bp" ]; + lispLibs = [ + (getAttr "aserve" self) + (getAttr "cffi" self) + (getAttr "ironclad" self) + (getAttr "jsown" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bst = ( + build-asdf-system { + pname = "bst"; + version = "20221106-git"; + asds = [ "bst" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bst/2022-11-06/bst-20221106-git.tgz"; + sha256 = "0y052jf3gkqhb7rfx72961kg42dnqhmizk7cxlv87d1jr2906d1d"; + system = "bst"; + asd = "bst"; + } + ); + systems = [ "bst" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bt-semaphore = ( + build-asdf-system { + pname = "bt-semaphore"; + version = "20180711-git"; + asds = [ "bt-semaphore" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bt-semaphore/2018-07-11/bt-semaphore-20180711-git.tgz"; + sha256 = "0rl7yp36225z975hg069pywwlpchwn4086cgxwsi2db5mhghpr7l"; + system = "bt-semaphore"; + asd = "bt-semaphore"; + } + ); + systems = [ "bt-semaphore" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bt-semaphore-test = ( + build-asdf-system { + pname = "bt-semaphore-test"; + version = "20180711-git"; + asds = [ "bt-semaphore-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bt-semaphore/2018-07-11/bt-semaphore-20180711-git.tgz"; + sha256 = "0rl7yp36225z975hg069pywwlpchwn4086cgxwsi2db5mhghpr7l"; + system = "bt-semaphore-test"; + asd = "bt-semaphore-test"; + } + ); + systems = [ "bt-semaphore-test" ]; + lispLibs = [ + (getAttr "bt-semaphore" self) + (getAttr "clunit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + btrie = ( + build-asdf-system { + pname = "btrie"; + version = "20140713-git"; + asds = [ "btrie" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/btrie/2014-07-13/btrie-20140713-git.tgz"; + sha256 = "0f1rs2zlpi2bcyba951h3cnyz2mfsxr2i6icmqbam5acqjdrmp30"; + system = "btrie"; + asd = "btrie"; + } + ); + systems = [ "btrie" ]; + lispLibs = [ + (getAttr "arnesi" self) + (getAttr "lift" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + btrie-tests = ( + build-asdf-system { + pname = "btrie-tests"; + version = "20140713-git"; + asds = [ "btrie-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/btrie/2014-07-13/btrie-20140713-git.tgz"; + sha256 = "0f1rs2zlpi2bcyba951h3cnyz2mfsxr2i6icmqbam5acqjdrmp30"; + system = "btrie-tests"; + asd = "btrie"; + } + ); + systems = [ "btrie-tests" ]; + lispLibs = [ + (getAttr "btrie" self) + (getAttr "lift" self) + (getAttr "metabang-bind" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bubble-operator-upwards = ( + build-asdf-system { + pname = "bubble-operator-upwards"; + version = "1.1"; + asds = [ "bubble-operator-upwards" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bubble-operator-upwards/2023-10-21/bubble-operator-upwards_1.1.tgz"; + sha256 = "1k6rvhlx4z0xb460dyg6blvqkwxakvqxslky69ld8p2yni1qar5p"; + system = "bubble-operator-upwards"; + asd = "bubble-operator-upwards"; + } + ); + systems = [ "bubble-operator-upwards" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bubble-operator-upwards__tests = ( + build-asdf-system { + pname = "bubble-operator-upwards_tests"; + version = "1.1"; + asds = [ "bubble-operator-upwards_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bubble-operator-upwards/2023-10-21/bubble-operator-upwards_1.1.tgz"; + sha256 = "1k6rvhlx4z0xb460dyg6blvqkwxakvqxslky69ld8p2yni1qar5p"; + system = "bubble-operator-upwards_tests"; + asd = "bubble-operator-upwards_tests"; + } + ); + systems = [ "bubble-operator-upwards_tests" ]; + lispLibs = [ + (getAttr "bubble-operator-upwards" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + buildapp = ( + build-asdf-system { + pname = "buildapp"; + version = "1.5.6"; + asds = [ "buildapp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/buildapp/2015-12-18/buildapp-1.5.6.tgz"; + sha256 = "020ipjfqa3l8skd97cj5kq837wgpj28ygfxnkv64cnjrlbnzh161"; + system = "buildapp"; + asd = "buildapp"; + } + ); + systems = [ "buildapp" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + buildnode = ( + build-asdf-system { + pname = "buildnode"; + version = "20170403-git"; + asds = [ "buildnode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; + sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; + system = "buildnode"; + asd = "buildnode"; + } + ); + systems = [ "buildnode" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "closure-html" self) + (getAttr "collectors" self) + (getAttr "cxml" self) + (getAttr "flexi-streams" self) + (getAttr "iterate" self) + (getAttr "split-sequence" self) + (getAttr "swank" self) + (getAttr "symbol-munger" self) + ]; + meta = { }; + } + ); + buildnode-excel = ( + build-asdf-system { + pname = "buildnode-excel"; + version = "20170403-git"; + asds = [ "buildnode-excel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; + sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; + system = "buildnode-excel"; + asd = "buildnode-excel"; + } + ); + systems = [ "buildnode-excel" ]; + lispLibs = [ (getAttr "buildnode" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + buildnode-html5 = ( + build-asdf-system { + pname = "buildnode-html5"; + version = "20170403-git"; + asds = [ "buildnode-html5" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; + sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; + system = "buildnode-html5"; + asd = "buildnode-html5"; + } + ); + systems = [ "buildnode-html5" ]; + lispLibs = [ (getAttr "buildnode" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + buildnode-kml = ( + build-asdf-system { + pname = "buildnode-kml"; + version = "20170403-git"; + asds = [ "buildnode-kml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; + sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; + system = "buildnode-kml"; + asd = "buildnode-kml"; + } + ); + systems = [ "buildnode-kml" ]; + lispLibs = [ (getAttr "buildnode" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + buildnode-test = ( + build-asdf-system { + pname = "buildnode-test"; + version = "20170403-git"; + asds = [ "buildnode-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; + sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; + system = "buildnode-test"; + asd = "buildnode"; + } + ); + systems = [ "buildnode-test" ]; + lispLibs = [ + (getAttr "buildnode" self) + (getAttr "buildnode-xhtml" self) + (getAttr "lisp-unit2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + buildnode-xhtml = ( + build-asdf-system { + pname = "buildnode-xhtml"; + version = "20170403-git"; + asds = [ "buildnode-xhtml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; + sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; + system = "buildnode-xhtml"; + asd = "buildnode-xhtml"; + } + ); + systems = [ "buildnode-xhtml" ]; + lispLibs = [ (getAttr "buildnode" self) ]; + meta = { }; + } + ); + buildnode-xul = ( + build-asdf-system { + pname = "buildnode-xul"; + version = "20170403-git"; + asds = [ "buildnode-xul" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/buildnode/2017-04-03/buildnode-20170403-git.tgz"; + sha256 = "09pd3mkjd278dl1hq30mxh6m2iyyfha4byadyb9drw4n7ncnjggs"; + system = "buildnode-xul"; + asd = "buildnode-xul"; + } + ); + systems = [ "buildnode-xul" ]; + lispLibs = [ (getAttr "buildnode" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + burgled-batteries = ( + build-asdf-system { + pname = "burgled-batteries"; + version = "20160825-git"; + asds = [ "burgled-batteries" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/burgled-batteries/2016-08-25/burgled-batteries-20160825-git.tgz"; + sha256 = "080ff1yrmfb87pqq1jqr35djjkh3fh8i6cbhv3d1md5qy7hhgdaj"; + system = "burgled-batteries"; + asd = "burgled-batteries"; + } + ); + systems = [ "burgled-batteries" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-fad" self) + (getAttr "parse-declarations-1_dot_0" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + burgled-batteries-tests = ( + build-asdf-system { + pname = "burgled-batteries-tests"; + version = "20160825-git"; + asds = [ "burgled-batteries-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/burgled-batteries/2016-08-25/burgled-batteries-20160825-git.tgz"; + sha256 = "080ff1yrmfb87pqq1jqr35djjkh3fh8i6cbhv3d1md5qy7hhgdaj"; + system = "burgled-batteries-tests"; + asd = "burgled-batteries-tests"; + } + ); + systems = [ "burgled-batteries-tests" ]; + lispLibs = [ + (getAttr "burgled-batteries" self) + (getAttr "cl-quickcheck" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + burgled-batteries_dot_syntax = ( + build-asdf-system { + pname = "burgled-batteries.syntax"; + version = "20210531-git"; + asds = [ "burgled-batteries.syntax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/burgled-batteries.syntax/2021-05-31/burgled-batteries.syntax-20210531-git.tgz"; + sha256 = "1hx8w74cgx1qbk6r2p7lzygjqxs5mzxh7w73zrmdibny64akir9a"; + system = "burgled-batteries.syntax"; + asd = "burgled-batteries.syntax"; + } + ); + systems = [ "burgled-batteries.syntax" ]; + lispLibs = [ + (getAttr "burgled-batteries" self) + (getAttr "esrap" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + burgled-batteries_dot_syntax-test = ( + build-asdf-system { + pname = "burgled-batteries.syntax-test"; + version = "20210531-git"; + asds = [ "burgled-batteries.syntax-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/burgled-batteries.syntax/2021-05-31/burgled-batteries.syntax-20210531-git.tgz"; + sha256 = "1hx8w74cgx1qbk6r2p7lzygjqxs5mzxh7w73zrmdibny64akir9a"; + system = "burgled-batteries.syntax-test"; + asd = "burgled-batteries.syntax-test"; + } + ); + systems = [ "burgled-batteries.syntax-test" ]; + lispLibs = [ + (getAttr "burgled-batteries_dot_syntax" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bus = ( + build-asdf-system { + pname = "bus"; + version = "master-fe503896-git"; + asds = [ "bus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "bus"; + asd = "bus"; + } + ); + systems = [ "bus" ]; + lispLibs = [ (getAttr "gwl-graphics" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bytecurry_dot_asdf-ext = ( + build-asdf-system { + pname = "bytecurry.asdf-ext"; + version = "20150505-git"; + asds = [ "bytecurry.asdf-ext" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bytecurry.asdf-ext/2015-05-05/bytecurry.asdf-ext-20150505-git.tgz"; + sha256 = "07w2lz9mq35sgzzvmz9084l1sia40zkhlvfblkpzxfwyzr6cxrxa"; + system = "bytecurry.asdf-ext"; + asd = "bytecurry.asdf-ext"; + } + ); + systems = [ "bytecurry.asdf-ext" ]; + lispLibs = [ (getAttr "asdf-package-system" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + bytecurry_dot_mocks = ( + build-asdf-system { + pname = "bytecurry.mocks"; + version = "20200325-git"; + asds = [ "bytecurry.mocks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bytecurry.mocks/2020-03-25/bytecurry.mocks-20200325-git.tgz"; + sha256 = "0md2j6iggmfm1v7nzcmz7f0xy2jxrsg77iszpisdzmwnijfy8ks0"; + system = "bytecurry.mocks"; + asd = "bytecurry.mocks"; + } + ); + systems = [ "bytecurry.mocks" ]; + lispLibs = [ + (getAttr "asdf-package-system" self) + (getAttr "bytecurry_dot_asdf-ext" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + c2ffi-blob = ( + build-asdf-system { + pname = "c2ffi-blob"; + version = "stable-git"; + asds = [ "c2ffi-blob" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/c2ffi-blob/2020-10-16/c2ffi-blob-stable-git.tgz"; + sha256 = "1rk89nycdvcb4a50zm3wdmrbz8w5xk4jgvjg2wib1dnslwnwdivc"; + system = "c2ffi-blob"; + asd = "c2ffi-blob"; + } + ); + systems = [ "c2ffi-blob" ]; + lispLibs = [ + (getAttr "claw-support" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cacau = ( + build-asdf-system { + pname = "cacau"; + version = "20200610-git"; + asds = [ "cacau" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cacau/2020-06-10/cacau-20200610-git.tgz"; + sha256 = "0m8v1xw68cr5ldv045rxgvnhigr4iahh7v6v32z6xlq2sj6r55x0"; + system = "cacau"; + asd = "cacau"; + } + ); + systems = [ "cacau" ]; + lispLibs = [ + (getAttr "assertion-error" self) + (getAttr "eventbus" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cacau-asdf = ( + build-asdf-system { + pname = "cacau-asdf"; + version = "20200610-git"; + asds = [ "cacau-asdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cacau/2020-06-10/cacau-20200610-git.tgz"; + sha256 = "0m8v1xw68cr5ldv045rxgvnhigr4iahh7v6v32z6xlq2sj6r55x0"; + system = "cacau-asdf"; + asd = "cacau-asdf"; + } + ); + systems = [ "cacau-asdf" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cacau-examples-asdf-integration = ( + build-asdf-system { + pname = "cacau-examples-asdf-integration"; + version = "20200610-git"; + asds = [ "cacau-examples-asdf-integration" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cacau/2020-06-10/cacau-20200610-git.tgz"; + sha256 = "0m8v1xw68cr5ldv045rxgvnhigr4iahh7v6v32z6xlq2sj6r55x0"; + system = "cacau-examples-asdf-integration"; + asd = "cacau-examples-asdf-integration"; + } + ); + systems = [ "cacau-examples-asdf-integration" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cacau-examples-asdf-integration-test = ( + build-asdf-system { + pname = "cacau-examples-asdf-integration-test"; + version = "20200610-git"; + asds = [ "cacau-examples-asdf-integration-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cacau/2020-06-10/cacau-20200610-git.tgz"; + sha256 = "0m8v1xw68cr5ldv045rxgvnhigr4iahh7v6v32z6xlq2sj6r55x0"; + system = "cacau-examples-asdf-integration-test"; + asd = "cacau-examples-asdf-integration-test"; + } + ); + systems = [ "cacau-examples-asdf-integration-test" ]; + lispLibs = [ + (getAttr "assert-p" self) + (getAttr "cacau" self) + (getAttr "cacau-asdf" self) + (getAttr "cacau-examples-asdf-integration" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cacau-test = ( + build-asdf-system { + pname = "cacau-test"; + version = "20200610-git"; + asds = [ "cacau-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cacau/2020-06-10/cacau-20200610-git.tgz"; + sha256 = "0m8v1xw68cr5ldv045rxgvnhigr4iahh7v6v32z6xlq2sj6r55x0"; + system = "cacau-test"; + asd = "cacau-test"; + } + ); + systems = [ "cacau-test" ]; + lispLibs = [ + (getAttr "assert-p" self) + (getAttr "cacau" self) + (getAttr "cacau-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cache-while = ( + build-asdf-system { + pname = "cache-while"; + version = "20210807-git"; + asds = [ "cache-while" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cache-while/2021-08-07/cache-while-20210807-git.tgz"; + sha256 = "1qil68rfn5irmkb0jk1f6g1zy80wgc3skl8cr4rfgh7ywgm5izx3"; + system = "cache-while"; + asd = "cache-while"; + } + ); + systems = [ "cache-while" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cacle = ( + build-asdf-system { + pname = "cacle"; + version = "20190521-git"; + asds = [ "cacle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cacle/2019-05-21/cacle-20190521-git.tgz"; + sha256 = "0h0dk0sfkfl8g0sbrs76ydb9l4znssqhx8nc5k1sg7zxpni5a4qy"; + system = "cacle"; + asd = "cacle"; + } + ); + systems = [ "cacle" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + calispel = ( + build-asdf-system { + pname = "calispel"; + version = "20170830-git"; + asds = [ "calispel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/calispel/2017-08-30/calispel-20170830-git.tgz"; + sha256 = "08bmf3pi7n5hadpmqqkg65cxcj6kbvm997wcs1f53ml1nb79d9z8"; + system = "calispel"; + asd = "calispel"; + } + ); + systems = [ "calispel" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "jpl-queues" self) + (getAttr "jpl-util" self) + ]; + meta = { }; + } + ); + calispel-test = ( + build-asdf-system { + pname = "calispel-test"; + version = "20170830-git"; + asds = [ "calispel-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/calispel/2017-08-30/calispel-20170830-git.tgz"; + sha256 = "08bmf3pi7n5hadpmqqkg65cxcj6kbvm997wcs1f53ml1nb79d9z8"; + system = "calispel-test"; + asd = "calispel"; + } + ); + systems = [ "calispel-test" ]; + lispLibs = [ + (getAttr "calispel" self) + (getAttr "eager-future2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + calm = ( + build-asdf-system { + pname = "calm"; + version = "20241012-git"; + asds = [ "calm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/calm/2024-10-12/calm-20241012-git.tgz"; + sha256 = "0c8d7aagx02cqk42pyj62hpqz3yarncigsw0g2ccc64sk74v67js"; + system = "calm"; + asd = "calm"; + } + ); + systems = [ "calm" ]; + lispLibs = [ + (getAttr "bt-semaphore" self) + (getAttr "cl-cairo2" self) + (getAttr "cl-gobject-introspection" self) + (getAttr "sdl2" self) + (getAttr "sdl2-image" self) + (getAttr "sdl2-mixer" self) + (getAttr "str" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cambl = ( + build-asdf-system { + pname = "cambl"; + version = "20181210-git"; + asds = [ "cambl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cambl/2018-12-10/cambl-20181210-git.tgz"; + sha256 = "103mry04j2k9vznsxm7wcvccgxkil92cdrv52miwcmxl8daa4jiz"; + system = "cambl"; + asd = "cambl"; + } + ); + systems = [ "cambl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-containers" self) + (getAttr "fprog" self) + (getAttr "local-time" self) + (getAttr "periods" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cambl-test = ( + build-asdf-system { + pname = "cambl-test"; + version = "20181210-git"; + asds = [ "cambl-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cambl/2018-12-10/cambl-20181210-git.tgz"; + sha256 = "103mry04j2k9vznsxm7wcvccgxkil92cdrv52miwcmxl8daa4jiz"; + system = "cambl-test"; + asd = "cambl-test"; + } + ); + systems = [ "cambl-test" ]; + lispLibs = [ + (getAttr "cambl" self) + (getAttr "xlunit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + camera-matrix = ( + build-asdf-system { + pname = "camera-matrix"; + version = "20200427-git"; + asds = [ "camera-matrix" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "camera-matrix"; + asd = "camera-matrix"; + } + ); + systems = [ "camera-matrix" ]; + lispLibs = [ + (getAttr "nsb-cga" self) + (getAttr "uncommon-lisp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + can = ( + build-asdf-system { + pname = "can"; + version = "20180328-git"; + asds = [ "can" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/can/2018-03-28/can-20180328-git.tgz"; + sha256 = "0m3lqc56aw46cj2z379a19fh7f1h0vaxn78xpvbxq3bwar46jzqh"; + system = "can"; + asd = "can"; + } + ); + systems = [ "can" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + can-test = ( + build-asdf-system { + pname = "can-test"; + version = "20180328-git"; + asds = [ "can-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/can/2018-03-28/can-20180328-git.tgz"; + sha256 = "0m3lqc56aw46cj2z379a19fh7f1h0vaxn78xpvbxq3bwar46jzqh"; + system = "can-test"; + asd = "can-test"; + } + ); + systems = [ "can-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "can" self) + (getAttr "mito" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + canonicalized-initargs = ( + build-asdf-system { + pname = "canonicalized-initargs"; + version = "2.0"; + asds = [ "canonicalized-initargs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/canonicalized-initargs/2021-04-11/canonicalized-initargs_2.0.tgz"; + sha256 = "0jmmjw86x9mmlfla4kdmdqf1fjrj0p2fmv1lc4k555mcf67mj2fq"; + system = "canonicalized-initargs"; + asd = "canonicalized-initargs"; + } + ); + systems = [ "canonicalized-initargs" ]; + lispLibs = [ + (getAttr "cesdi" self) + (getAttr "closer-mop" self) + (getAttr "compatible-metaclasses" self) + (getAttr "enhanced-defclass" self) + (getAttr "enhanced-typep" self) + (getAttr "object-class" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + canonicalized-initargs__tests = ( + build-asdf-system { + pname = "canonicalized-initargs_tests"; + version = "2.0"; + asds = [ "canonicalized-initargs_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/canonicalized-initargs/2021-04-11/canonicalized-initargs_2.0.tgz"; + sha256 = "0jmmjw86x9mmlfla4kdmdqf1fjrj0p2fmv1lc4k555mcf67mj2fq"; + system = "canonicalized-initargs_tests"; + asd = "canonicalized-initargs_tests"; + } + ); + systems = [ "canonicalized-initargs_tests" ]; + lispLibs = [ + (getAttr "canonicalized-initargs" self) + (getAttr "enhanced-boolean" self) + (getAttr "enhanced-eval-when" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + capstone = ( + build-asdf-system { + pname = "capstone"; + version = "20220331-git"; + asds = [ "capstone" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-capstone/2022-03-31/cl-capstone-20220331-git.tgz"; + sha256 = "1jbhp1sf7mr6yrqkdyjl93m1dl901ka6gkgdj20nv2bgp400ycmp"; + system = "capstone"; + asd = "capstone"; + } + ); + systems = [ "capstone" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "gt" self) + (getAttr "static-vectors" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + caramel = ( + build-asdf-system { + pname = "caramel"; + version = "20130420-git"; + asds = [ "caramel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/caramel/2013-04-20/caramel-20130420-git.tgz"; + sha256 = "08kyjxd8hyk5xnnq0p0w4aqpvisv278h38pqjkz04a032dn5b87a"; + system = "caramel"; + asd = "caramel"; + } + ); + systems = [ "caramel" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "buildnode" self) + (getAttr "closure-html" self) + (getAttr "css-selectors" self) + (getAttr "cxml" self) + (getAttr "cxml-dom" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cardioex = ( + build-asdf-system { + pname = "cardioex"; + version = "20211020-git"; + asds = [ "cardioex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cardiogram/2021-10-20/cardiogram-20211020-git.tgz"; + sha256 = "08kqcj3c4vkx5s6ba9m67xh7w7paaavp2ds072crp1x7pjkh4n5i"; + system = "cardioex"; + asd = "cardioex"; + } + ); + systems = [ "cardioex" ]; + lispLibs = [ (getAttr "cardiogram" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cardiogram = ( + build-asdf-system { + pname = "cardiogram"; + version = "20211020-git"; + asds = [ "cardiogram" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cardiogram/2021-10-20/cardiogram-20211020-git.tgz"; + sha256 = "08kqcj3c4vkx5s6ba9m67xh7w7paaavp2ds072crp1x7pjkh4n5i"; + system = "cardiogram"; + asd = "cardiogram"; + } + ); + systems = [ "cardiogram" ]; + lispLibs = [ + (getAttr "cl-annot" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cari3s = ( + build-asdf-system { + pname = "cari3s"; + version = "20231021-git"; + asds = [ "cari3s" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cari3s/2023-10-21/cari3s-20231021-git.tgz"; + sha256 = "1q977ykj4fb095ilr1x4g0nrhqmipcgmdxbxn4gmlksg457sb4lm"; + system = "cari3s"; + asd = "cari3s"; + } + ); + systems = [ "cari3s" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "closer-mop" self) + (getAttr "com_dot_inuoe_dot_jzon" self) + (getAttr "documentation-utils" self) + (getAttr "drakma" self) + (getAttr "pango-markup" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + carrier = ( + build-asdf-system { + pname = "carrier"; + version = "20241012-git"; + asds = [ "carrier" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/carrier/2024-10-12/carrier-20241012-git.tgz"; + sha256 = "04w6hzqqbcvi8niqj35xz098gjfg4pdv6fbihfbna3c5v7q59gr1"; + system = "carrier"; + asd = "carrier"; + } + ); + systems = [ "carrier" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "blackbird" self) + (getAttr "cl-async" self) + (getAttr "cl-async-ssl" self) + (getAttr "cl-cookie" self) + (getAttr "fast-http" self) + (getAttr "fast-io" self) + (getAttr "quri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cartesian-product-switch = ( + build-asdf-system { + pname = "cartesian-product-switch"; + version = "2.0"; + asds = [ "cartesian-product-switch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cartesian-product-switch/2012-09-09/cartesian-product-switch-2.0.tgz"; + sha256 = "18cxslj2753k6h666j0mmzg0h0z9l6ddi24gqls6h5d5svd7l3xk"; + system = "cartesian-product-switch"; + asd = "cartesian-product-switch"; + } + ); + systems = [ "cartesian-product-switch" ]; + lispLibs = [ (getAttr "map-bind" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + caveman-middleware-dbimanager = ( + build-asdf-system { + pname = "caveman-middleware-dbimanager"; + version = "20241012-git"; + asds = [ "caveman-middleware-dbimanager" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/caveman/2024-10-12/caveman-20241012-git.tgz"; + sha256 = "1q07mmm41zymh464j4mldf3lv1sb9amzdcwinkywqhwnjmnx6axi"; + system = "caveman-middleware-dbimanager"; + asd = "caveman-middleware-dbimanager"; + } + ); + systems = [ "caveman-middleware-dbimanager" ]; + lispLibs = [ (getAttr "dbi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + caveman2 = ( + build-asdf-system { + pname = "caveman2"; + version = "20241012-git"; + asds = [ "caveman2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/caveman/2024-10-12/caveman-20241012-git.tgz"; + sha256 = "1q07mmm41zymh464j4mldf3lv1sb9amzdcwinkywqhwnjmnx6axi"; + system = "caveman2"; + asd = "caveman2"; + } + ); + systems = [ "caveman2" ]; + lispLibs = [ + (getAttr "cl-project" self) + (getAttr "cl-syntax-annot" self) + (getAttr "dbi" self) + (getAttr "lack-request" self) + (getAttr "lack-response" self) + (getAttr "myway" self) + (getAttr "ningle" self) + (getAttr "quri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + caveman2-db = ( + build-asdf-system { + pname = "caveman2-db"; + version = "20241012-git"; + asds = [ "caveman2-db" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/caveman/2024-10-12/caveman-20241012-git.tgz"; + sha256 = "1q07mmm41zymh464j4mldf3lv1sb9amzdcwinkywqhwnjmnx6axi"; + system = "caveman2-db"; + asd = "caveman2-db"; + } + ); + systems = [ "caveman2-db" ]; + lispLibs = [ + (getAttr "caveman-middleware-dbimanager" self) + (getAttr "dbi" self) + (getAttr "sxql" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + caveman2-test = ( + build-asdf-system { + pname = "caveman2-test"; + version = "20241012-git"; + asds = [ "caveman2-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/caveman/2024-10-12/caveman-20241012-git.tgz"; + sha256 = "1q07mmm41zymh464j4mldf3lv1sb9amzdcwinkywqhwnjmnx6axi"; + system = "caveman2-test"; + asd = "caveman2-test"; + } + ); + systems = [ "caveman2-test" ]; + lispLibs = [ + (getAttr "caveman2" self) + (getAttr "dexador" self) + (getAttr "lack-component" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "trivial-types" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + caveman2-widgets = ( + build-asdf-system { + pname = "caveman2-widgets"; + version = "20180228-git"; + asds = [ "caveman2-widgets" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/caveman2-widgets/2018-02-28/caveman2-widgets-20180228-git.tgz"; + sha256 = "1rzb868m3f28z1hcr3nzlprgqqq1kwg3qyh24p36fv76b4g96wkq"; + system = "caveman2-widgets"; + asd = "caveman2-widgets"; + } + ); + systems = [ "caveman2-widgets" ]; + lispLibs = [ + (getAttr "caveman2" self) + (getAttr "moptilities" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + caveman2-widgets-bootstrap = ( + build-asdf-system { + pname = "caveman2-widgets-bootstrap"; + version = "20180228-git"; + asds = [ "caveman2-widgets-bootstrap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/caveman2-widgets-bootstrap/2018-02-28/caveman2-widgets-bootstrap-20180228-git.tgz"; + sha256 = "1xh3x7r7givxxyrkh4ngx098s35qz98gcz7yjyf4dp0psfkk65xj"; + system = "caveman2-widgets-bootstrap"; + asd = "caveman2-widgets-bootstrap"; + } + ); + systems = [ "caveman2-widgets-bootstrap" ]; + lispLibs = [ + (getAttr "caveman2" self) + (getAttr "caveman2-widgets" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + caveman2-widgets-bootstrap-test = ( + build-asdf-system { + pname = "caveman2-widgets-bootstrap-test"; + version = "20180228-git"; + asds = [ "caveman2-widgets-bootstrap-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/caveman2-widgets-bootstrap/2018-02-28/caveman2-widgets-bootstrap-20180228-git.tgz"; + sha256 = "1xh3x7r7givxxyrkh4ngx098s35qz98gcz7yjyf4dp0psfkk65xj"; + system = "caveman2-widgets-bootstrap-test"; + asd = "caveman2-widgets-bootstrap-test"; + } + ); + systems = [ "caveman2-widgets-bootstrap-test" ]; + lispLibs = [ + (getAttr "caveman2-widgets-bootstrap" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + caveman2-widgets-test = ( + build-asdf-system { + pname = "caveman2-widgets-test"; + version = "20180228-git"; + asds = [ "caveman2-widgets-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/caveman2-widgets/2018-02-28/caveman2-widgets-20180228-git.tgz"; + sha256 = "1rzb868m3f28z1hcr3nzlprgqqq1kwg3qyh24p36fv76b4g96wkq"; + system = "caveman2-widgets-test"; + asd = "caveman2-widgets-test"; + } + ); + systems = [ "caveman2-widgets-test" ]; + lispLibs = [ + (getAttr "caveman2-widgets" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cblas = ( + build-asdf-system { + pname = "cblas"; + version = "20221106-git"; + asds = [ "cblas" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cblas/2022-11-06/cl-cblas-20221106-git.tgz"; + sha256 = "1bd2w51r71pgm6sc6m2fms4j1bbnli023j4w3rbxw9cln0g7badp"; + system = "cblas"; + asd = "cblas"; + } + ); + systems = [ "cblas" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-autowrap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cbor = ( + build-asdf-system { + pname = "cbor"; + version = "20241012-git"; + asds = [ "cbor" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cbor/2024-10-12/cbor-20241012-git.tgz"; + sha256 = "0bkjfi449m651hbsm39dc9863mcry3ynz1j59wb2kl8zwxm1qg2r"; + system = "cbor"; + asd = "cbor"; + } + ); + systems = [ "cbor" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "ieee-floats" self) + (getAttr "local-time" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ccl-compat = ( + build-asdf-system { + pname = "ccl-compat"; + version = "20171130-git"; + asds = [ "ccl-compat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ccl-compat/2017-11-30/ccl-compat-20171130-git.tgz"; + sha256 = "15402373wprmyx4l7zgpv64vj3c11xvxnnpzqbmq4j6rljpb40da"; + system = "ccl-compat"; + asd = "ccl-compat"; + } + ); + systems = [ "ccl-compat" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ccldoc = ( + build-asdf-system { + pname = "ccldoc"; + version = "20241012-git"; + asds = [ "ccldoc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ccldoc/2024-10-12/ccldoc-20241012-git.tgz"; + sha256 = "15pc25pwnlg2lhzxniln53fr2i2cqa6fpr60nv4i1743x9ahp35l"; + system = "ccldoc"; + asd = "ccldoc"; + } + ); + systems = [ "ccldoc" ]; + lispLibs = [ (getAttr "ccl-compat" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ccldoc-docbook = ( + build-asdf-system { + pname = "ccldoc-docbook"; + version = "20241012-git"; + asds = [ "ccldoc-docbook" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ccldoc/2024-10-12/ccldoc-20241012-git.tgz"; + sha256 = "15pc25pwnlg2lhzxniln53fr2i2cqa6fpr60nv4i1743x9ahp35l"; + system = "ccldoc-docbook"; + asd = "ccldoc-docbook"; + } + ); + systems = [ "ccldoc-docbook" ]; + lispLibs = [ + (getAttr "ccldoc" self) + (getAttr "s-xml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ccldoc-libraries = ( + build-asdf-system { + pname = "ccldoc-libraries"; + version = "20241012-git"; + asds = [ "ccldoc-libraries" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ccldoc/2024-10-12/ccldoc-20241012-git.tgz"; + sha256 = "15pc25pwnlg2lhzxniln53fr2i2cqa6fpr60nv4i1743x9ahp35l"; + system = "ccldoc-libraries"; + asd = "ccldoc-libraries"; + } + ); + systems = [ "ccldoc-libraries" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "s-xml" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ceigen-lite = ( + build-asdf-system { + pname = "ceigen-lite"; + version = "20241012-git"; + asds = [ "ceigen-lite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ceigen-lite/2024-10-12/cl-ceigen-lite-20241012-git.tgz"; + sha256 = "0k2b6x913mnv1f5712xvvv7d6j3lrja4isjg6cyad694py59d09q"; + system = "ceigen-lite"; + asd = "ceigen-lite"; + } + ); + systems = [ "ceigen-lite" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-autowrap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cells = ( + build-asdf-system { + pname = "cells"; + version = "20230618-git"; + asds = [ "cells" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cells/2023-06-18/cells-20230618-git.tgz"; + sha256 = "1mh14g8x2mpb8qdngqxgnkawqbv4xxxr3bgn01jm5d6c8jn6ph3f"; + system = "cells"; + asd = "cells"; + } + ); + systems = [ "cells" ]; + lispLibs = [ (getAttr "utils-kt" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cells-test = ( + build-asdf-system { + pname = "cells-test"; + version = "20230618-git"; + asds = [ "cells-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cells/2023-06-18/cells-20230618-git.tgz"; + sha256 = "1mh14g8x2mpb8qdngqxgnkawqbv4xxxr3bgn01jm5d6c8jn6ph3f"; + system = "cells-test"; + asd = "cells-test"; + } + ); + systems = [ "cells-test" ]; + lispLibs = [ (getAttr "cells" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cephes = ( + build-asdf-system { + pname = "cephes"; + version = "20241012-git"; + asds = [ "cephes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cephes.cl/2024-10-12/cephes.cl-20241012-git.tgz"; + sha256 = "1p0npidiy9zjb90gyihdmx0nmm87a5akph1jhs6y7z50fx8470hb"; + system = "cephes"; + asd = "cephes"; + } + ); + systems = [ "cephes" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cepl = ( + build-asdf-system { + pname = "cepl"; + version = "release-quicklisp-543c9fc1-git"; + asds = [ "cepl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cepl/2024-10-12/cepl-release-quicklisp-543c9fc1-git.tgz"; + sha256 = "0g5frci6ljmy6pyyrjhh2kw894l3fl3wsz27k75xw49cd8xm24mh"; + system = "cepl"; + asd = "cepl"; + } + ); + systems = [ "cepl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cepl_dot_build" self) + (getAttr "cffi" self) + (getAttr "cl-opengl" self) + (getAttr "cl-ppcre" self) + (getAttr "documentation-utils" self) + (getAttr "float-features" self) + (getAttr "ieee-floats" self) + (getAttr "split-sequence" self) + (getAttr "varjo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cepl_dot_build = ( + build-asdf-system { + pname = "cepl.build"; + version = "release-quicklisp-543c9fc1-git"; + asds = [ "cepl.build" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cepl/2024-10-12/cepl-release-quicklisp-543c9fc1-git.tgz"; + sha256 = "0g5frci6ljmy6pyyrjhh2kw894l3fl3wsz27k75xw49cd8xm24mh"; + system = "cepl.build"; + asd = "cepl.build"; + } + ); + systems = [ "cepl.build" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cepl_dot_camera = ( + build-asdf-system { + pname = "cepl.camera"; + version = "release-quicklisp-1292212a-git"; + asds = [ "cepl.camera" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cepl.camera/2018-02-28/cepl.camera-release-quicklisp-1292212a-git.tgz"; + sha256 = "0z73f95bxr2vn47g8qrvf9gzy1my25mkg7hl7kpib21yahfpzzvb"; + system = "cepl.camera"; + asd = "cepl.camera"; + } + ); + systems = [ "cepl.camera" ]; + lispLibs = [ + (getAttr "cepl" self) + (getAttr "cepl_dot_spaces" self) + (getAttr "rtg-math" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cepl_dot_devil = ( + build-asdf-system { + pname = "cepl.devil"; + version = "release-quicklisp-ea5f8514-git"; + asds = [ "cepl.devil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cepl.devil/2018-02-28/cepl.devil-release-quicklisp-ea5f8514-git.tgz"; + sha256 = "1b64vfjchkwppcp3j4krwx2x9nj29llisqy1yc9ncbnmi9xs38a0"; + system = "cepl.devil"; + asd = "cepl.devil"; + } + ); + systems = [ "cepl.devil" ]; + lispLibs = [ + (getAttr "cepl" self) + (getAttr "cl-devil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cepl_dot_drm-gbm = ( + build-asdf-system { + pname = "cepl.drm-gbm"; + version = "20190521-git"; + asds = [ "cepl.drm-gbm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cepl.drm-gbm/2019-05-21/cepl.drm-gbm-20190521-git.tgz"; + sha256 = "00csd2f6z13rjqipaf02w87phn2xynmzf1jcrrshbibs204m4nmy"; + system = "cepl.drm-gbm"; + asd = "cepl.drm-gbm"; + } + ); + systems = [ "cepl.drm-gbm" ]; + lispLibs = [ + (getAttr "cepl" self) + (getAttr "cl-drm" self) + (getAttr "cl-egl" self) + (getAttr "cl-gbm" self) + (getAttr "osicat" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cepl_dot_glop = ( + build-asdf-system { + pname = "cepl.glop"; + version = "release-quicklisp-8ec09801-git"; + asds = [ "cepl.glop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cepl.glop/2018-02-28/cepl.glop-release-quicklisp-8ec09801-git.tgz"; + sha256 = "1dq727v2s22yna6ycxxs79pg13b0cyh1lfrk6hsb6vizgiks20jw"; + system = "cepl.glop"; + asd = "cepl.glop"; + } + ); + systems = [ "cepl.glop" ]; + lispLibs = [ + (getAttr "cepl" self) + (getAttr "glop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cepl_dot_sdl2 = ( + build-asdf-system { + pname = "cepl.sdl2"; + version = "release-quicklisp-6da5a030-git"; + asds = [ "cepl.sdl2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cepl.sdl2/2018-02-28/cepl.sdl2-release-quicklisp-6da5a030-git.tgz"; + sha256 = "0lz8yxm1g2ch0w779lhrs2xkfciy3iz6viz7cdgyd2824isvinjf"; + system = "cepl.sdl2"; + asd = "cepl.sdl2"; + } + ); + systems = [ "cepl.sdl2" ]; + lispLibs = [ + (getAttr "cepl" self) + (getAttr "sdl2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cepl_dot_sdl2-image = ( + build-asdf-system { + pname = "cepl.sdl2-image"; + version = "release-quicklisp-94a77649-git"; + asds = [ "cepl.sdl2-image" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cepl.sdl2-image/2018-02-28/cepl.sdl2-image-release-quicklisp-94a77649-git.tgz"; + sha256 = "16dzjk2q658xr1v9rk2iny70rjhxbgi4lcp59s5mkdfs2k3a2637"; + system = "cepl.sdl2-image"; + asd = "cepl.sdl2-image"; + } + ); + systems = [ "cepl.sdl2-image" ]; + lispLibs = [ + (getAttr "cepl" self) + (getAttr "sdl2" self) + (getAttr "sdl2-image" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cepl_dot_sdl2-ttf = ( + build-asdf-system { + pname = "cepl.sdl2-ttf"; + version = "release-quicklisp-11b498a3-git"; + asds = [ "cepl.sdl2-ttf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cepl.sdl2-ttf/2018-01-31/cepl.sdl2-ttf-release-quicklisp-11b498a3-git.tgz"; + sha256 = "1fxj3rdv2rlyks00h18dpd42xywgnydgyvb1s4d67hjk7fl19a5p"; + system = "cepl.sdl2-ttf"; + asd = "cepl.sdl2-ttf"; + } + ); + systems = [ "cepl.sdl2-ttf" ]; + lispLibs = [ + (getAttr "cepl_dot_sdl2" self) + (getAttr "rtg-math" self) + (getAttr "sdl2-ttf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cepl_dot_skitter_dot_glop = ( + build-asdf-system { + pname = "cepl.skitter.glop"; + version = "release-quicklisp-f52b9240-git"; + asds = [ "cepl.skitter.glop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cepl.skitter/2018-02-28/cepl.skitter-release-quicklisp-f52b9240-git.tgz"; + sha256 = "1xz53q8klzrd7cr586jd16pypxgpy68vlvfirqhlv6jc7k99sjvs"; + system = "cepl.skitter.glop"; + asd = "cepl.skitter.glop"; + } + ); + systems = [ "cepl.skitter.glop" ]; + lispLibs = [ + (getAttr "cepl_dot_glop" self) + (getAttr "skitter_dot_glop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cepl_dot_skitter_dot_sdl2 = ( + build-asdf-system { + pname = "cepl.skitter.sdl2"; + version = "release-quicklisp-f52b9240-git"; + asds = [ "cepl.skitter.sdl2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cepl.skitter/2018-02-28/cepl.skitter-release-quicklisp-f52b9240-git.tgz"; + sha256 = "1xz53q8klzrd7cr586jd16pypxgpy68vlvfirqhlv6jc7k99sjvs"; + system = "cepl.skitter.sdl2"; + asd = "cepl.skitter.sdl2"; + } + ); + systems = [ "cepl.skitter.sdl2" ]; + lispLibs = [ + (getAttr "cepl_dot_sdl2" self) + (getAttr "skitter_dot_sdl2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cepl_dot_spaces = ( + build-asdf-system { + pname = "cepl.spaces"; + version = "release-quicklisp-c7f83f26-git"; + asds = [ "cepl.spaces" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cepl.spaces/2018-03-28/cepl.spaces-release-quicklisp-c7f83f26-git.tgz"; + sha256 = "0z74ipd4j2spjwl6h625azdczpds3v44iin77q685ldx9rwx3k8y"; + system = "cepl.spaces"; + asd = "cepl.spaces"; + } + ); + systems = [ "cepl.spaces" ]; + lispLibs = [ + (getAttr "cepl" self) + (getAttr "documentation-utils" self) + (getAttr "fn" self) + (getAttr "rtg-math" self) + (getAttr "rtg-math_dot_vari" self) + (getAttr "varjo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ceramic = ( + build-asdf-system { + pname = "ceramic"; + version = "20210807-git"; + asds = [ "ceramic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ceramic/2021-08-07/ceramic-20210807-git.tgz"; + sha256 = "0hd553gj4cwmli45pfwhqpz7sg6kzn31iv8akaxr5ba3hssa1aap"; + system = "ceramic"; + asd = "ceramic"; + } + ); + systems = [ "ceramic" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "clack-handler-hunchentoot" self) + (getAttr "copy-directory" self) + (getAttr "electron-tools" self) + (getAttr "external-program" self) + (getAttr "remote-js" self) + (getAttr "trivial-build" self) + (getAttr "trivial-compress" self) + (getAttr "trivial-download" self) + (getAttr "trivial-exe" self) + (getAttr "trivial-extract" self) + (getAttr "uuid" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ceramic-test-app = ( + build-asdf-system { + pname = "ceramic-test-app"; + version = "20210807-git"; + asds = [ "ceramic-test-app" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ceramic/2021-08-07/ceramic-20210807-git.tgz"; + sha256 = "0hd553gj4cwmli45pfwhqpz7sg6kzn31iv8akaxr5ba3hssa1aap"; + system = "ceramic-test-app"; + asd = "ceramic-test-app"; + } + ); + systems = [ "ceramic-test-app" ]; + lispLibs = [ + (getAttr "ceramic" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cerberus = ( + build-asdf-system { + pname = "cerberus"; + version = "20241012-git"; + asds = [ "cerberus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cerberus/2024-10-12/cerberus-20241012-git.tgz"; + sha256 = "131x0raccj5majd72hmmlp67dsj2zdizm2xzdhw6s0jbxjbhdgfs"; + system = "cerberus"; + asd = "cerberus"; + } + ); + systems = [ "cerberus" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "flexi-streams" self) + (getAttr "glass" self) + (getAttr "ironclad" self) + (getAttr "nibbles" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cerberus-kdc = ( + build-asdf-system { + pname = "cerberus-kdc"; + version = "20241012-git"; + asds = [ "cerberus-kdc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cerberus/2024-10-12/cerberus-20241012-git.tgz"; + sha256 = "131x0raccj5majd72hmmlp67dsj2zdizm2xzdhw6s0jbxjbhdgfs"; + system = "cerberus-kdc"; + asd = "cerberus"; + } + ); + systems = [ "cerberus-kdc" ]; + lispLibs = [ + (getAttr "cerberus" self) + (getAttr "frpc" self) + (getAttr "pounds" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cesdi = ( + build-asdf-system { + pname = "cesdi"; + version = "1.0.1"; + asds = [ "cesdi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cesdi/2020-07-15/cesdi_1.0.1.tgz"; + sha256 = "02f2pz5rw79ljkkx1ywh8nkpjj4g3z3s1lyvzqb8krbnx11wl0q9"; + system = "cesdi"; + asd = "cesdi"; + } + ); + systems = [ "cesdi" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cesdi__tests = ( + build-asdf-system { + pname = "cesdi_tests"; + version = "1.0.1"; + asds = [ "cesdi_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cesdi/2020-07-15/cesdi_1.0.1.tgz"; + sha256 = "02f2pz5rw79ljkkx1ywh8nkpjj4g3z3s1lyvzqb8krbnx11wl0q9"; + system = "cesdi_tests"; + asd = "cesdi_tests"; + } + ); + systems = [ "cesdi_tests" ]; + lispLibs = [ + (getAttr "cesdi" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cf = ( + build-asdf-system { + pname = "cf"; + version = "20241012-git"; + asds = [ "cf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cf/2024-10-12/cl-cf-20241012-git.tgz"; + sha256 = "1w4asb8v81q2rf8fhhq88c2ib4ax5fbm0655kvdpfvkz1457yi25"; + system = "cf"; + asd = "cf"; + } + ); + systems = [ "cf" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cf-tests = ( + build-asdf-system { + pname = "cf-tests"; + version = "20241012-git"; + asds = [ "cf-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cf/2024-10-12/cl-cf-20241012-git.tgz"; + sha256 = "1w4asb8v81q2rf8fhhq88c2ib4ax5fbm0655kvdpfvkz1457yi25"; + system = "cf-tests"; + asd = "cf-tests"; + } + ); + systems = [ "cf-tests" ]; + lispLibs = [ + (getAttr "cf" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cffi = ( + build-asdf-system { + pname = "cffi"; + version = "20241012-git"; + asds = [ "cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; + sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; + system = "cffi"; + asd = "cffi"; + } + ); + systems = [ "cffi" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "trivial-features" self) + ]; + meta = { }; + } + ); + cffi-c-ref = ( + build-asdf-system { + pname = "cffi-c-ref"; + version = "stable-git"; + asds = [ "cffi-c-ref" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cffi-c-ref/2020-10-16/cffi-c-ref-stable-git.tgz"; + sha256 = "1a3pp6xcisabqir3rp1gvvjfdxcvpm8yr35p38nri9azsinmmc7z"; + system = "cffi-c-ref"; + asd = "cffi-c-ref"; + } + ); + systems = [ "cffi-c-ref" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cffi-examples = ( + build-asdf-system { + pname = "cffi-examples"; + version = "20241012-git"; + asds = [ "cffi-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; + sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; + system = "cffi-examples"; + asd = "cffi-examples"; + } + ); + systems = [ "cffi-examples" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cffi-grovel = ( + build-asdf-system { + pname = "cffi-grovel"; + version = "20241012-git"; + asds = [ "cffi-grovel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; + sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; + system = "cffi-grovel"; + asd = "cffi-grovel"; + } + ); + systems = [ "cffi-grovel" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-toolchain" self) + ]; + meta = { }; + } + ); + cffi-libffi = ( + build-asdf-system { + pname = "cffi-libffi"; + version = "20241012-git"; + asds = [ "cffi-libffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; + sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; + system = "cffi-libffi"; + asd = "cffi-libffi"; + } + ); + systems = [ "cffi-libffi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cffi-object = ( + build-asdf-system { + pname = "cffi-object"; + version = "20241012-git"; + asds = [ "cffi-object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cffi-object/2024-10-12/cffi-object-20241012-git.tgz"; + sha256 = "0hdxy2lqf0q04j57y6plnlh2v6w7y7prsypxk9f4vdlnp2ah3lln"; + system = "cffi-object"; + asd = "cffi-object"; + } + ); + systems = [ "cffi-object" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cffi-object_dot_ops = ( + build-asdf-system { + pname = "cffi-object.ops"; + version = "20241012-git"; + asds = [ "cffi-object.ops" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cffi-object/2024-10-12/cffi-object-20241012-git.tgz"; + sha256 = "0hdxy2lqf0q04j57y6plnlh2v6w7y7prsypxk9f4vdlnp2ah3lln"; + system = "cffi-object.ops"; + asd = "cffi-object.ops"; + } + ); + systems = [ "cffi-object.ops" ]; + lispLibs = [ + (getAttr "cffi-object" self) + (getAttr "cffi-ops" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cffi-ops = ( + build-asdf-system { + pname = "cffi-ops"; + version = "20241012-git"; + asds = [ "cffi-ops" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cffi-ops/2024-10-12/cffi-ops-20241012-git.tgz"; + sha256 = "0hi3svwfb7m1wq892wlrsgj52jkh3x6msnimax28221baj6g64gg"; + system = "cffi-ops"; + asd = "cffi-ops"; + } + ); + systems = [ "cffi-ops" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "arrow-macros" self) + (getAttr "cffi" self) + (getAttr "trivial-macroexpand-all" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cffi-tests = ( + build-asdf-system { + pname = "cffi-tests"; + version = "20241012-git"; + asds = [ "cffi-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; + sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; + system = "cffi-tests"; + asd = "cffi-tests"; + } + ); + systems = [ "cffi-tests" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi-grovel" self) + (getAttr "cffi-libffi" self) + (getAttr "rt" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cffi-toolchain = ( + build-asdf-system { + pname = "cffi-toolchain"; + version = "20241012-git"; + asds = [ "cffi-toolchain" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; + sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; + system = "cffi-toolchain"; + asd = "cffi-toolchain"; + } + ); + systems = [ "cffi-toolchain" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { }; + } + ); + cffi-uffi-compat = ( + build-asdf-system { + pname = "cffi-uffi-compat"; + version = "20241012-git"; + asds = [ "cffi-uffi-compat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cffi/2024-10-12/cffi-20241012-git.tgz"; + sha256 = "1b2j32rapgw8rn7m9sm2k8r8x9jds7vshkm90i5lw9v4xnp8x4m7"; + system = "cffi-uffi-compat"; + asd = "cffi-uffi-compat"; + } + ); + systems = [ "cffi-uffi-compat" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { }; + } + ); + chain = ( + build-asdf-system { + pname = "chain"; + version = "20211209-git"; + asds = [ "chain" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chain/2021-12-09/chain-20211209-git.tgz"; + sha256 = "0x8b2cbp1xq61fpbk0mqwbksnfynlgai3782rafsywka8rgfhmjh"; + system = "chain"; + asd = "chain"; + } + ); + systems = [ "chain" ]; + lispLibs = [ (getAttr "metabang-bind" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chameleon = ( + build-asdf-system { + pname = "chameleon"; + version = "v2.1.1"; + asds = [ "chameleon" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chameleon/2022-02-20/chameleon-v2.1.1.tgz"; + sha256 = "1bqminvhx3hlqzxvy2a105gm9d2dxl5cy6ls5rm9wmkvw7gyza6c"; + system = "chameleon"; + asd = "chameleon"; + } + ); + systems = [ "chameleon" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chancery = ( + build-asdf-system { + pname = "chancery"; + version = "20201016-hg"; + asds = [ "chancery" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chancery/2020-10-16/chancery-20201016-hg.tgz"; + sha256 = "1g0jgrih7q14gizy481j9z2s15pmv6iwymnpddbyqfja9miv61lw"; + system = "chancery"; + asd = "chancery"; + } + ); + systems = [ "chancery" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chancery_dot_test = ( + build-asdf-system { + pname = "chancery.test"; + version = "20201016-hg"; + asds = [ "chancery.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chancery/2020-10-16/chancery-20201016-hg.tgz"; + sha256 = "1g0jgrih7q14gizy481j9z2s15pmv6iwymnpddbyqfja9miv61lw"; + system = "chancery.test"; + asd = "chancery.test"; + } + ); + systems = [ "chancery.test" ]; + lispLibs = [ + (getAttr "_1am" self) + (getAttr "chancery" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + changed-stream = ( + build-asdf-system { + pname = "changed-stream"; + version = "20130128-git"; + asds = [ "changed-stream" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/changed-stream/2013-01-28/changed-stream-20130128-git.tgz"; + sha256 = "1cll7xclg9jr55swhi3g6z567bxvb9kmljh67091xazcfacz732i"; + system = "changed-stream"; + asd = "changed-stream"; + } + ); + systems = [ "changed-stream" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + changed-stream_dot_test = ( + build-asdf-system { + pname = "changed-stream.test"; + version = "20130128-git"; + asds = [ "changed-stream.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/changed-stream/2013-01-28/changed-stream-20130128-git.tgz"; + sha256 = "1cll7xclg9jr55swhi3g6z567bxvb9kmljh67091xazcfacz732i"; + system = "changed-stream.test"; + asd = "changed-stream.test"; + } + ); + systems = [ "changed-stream.test" ]; + lispLibs = [ (getAttr "changed-stream" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chanl = ( + build-asdf-system { + pname = "chanl"; + version = "20241012-git"; + asds = [ "chanl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chanl/2024-10-12/chanl-20241012-git.tgz"; + sha256 = "1gyvsajvqjzfmcbccnysw7qyvhyqdlfcwl57lhsfwz9gif50y1fw"; + system = "chanl"; + asd = "chanl"; + } + ); + systems = [ "chanl" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { }; + } + ); + character-modifier-bits = ( + build-asdf-system { + pname = "character-modifier-bits"; + version = "20200427-git"; + asds = [ "character-modifier-bits" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "character-modifier-bits"; + asd = "character-modifier-bits"; + } + ); + systems = [ "character-modifier-bits" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + charje_dot_documentation = ( + build-asdf-system { + pname = "charje.documentation"; + version = "20241012-git"; + asds = [ "charje.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/charje.documentation/2024-10-12/charje.documentation-20241012-git.tgz"; + sha256 = "0rdfi4sj5ad6krwypmsr934ic6y5xlj6iixdwwxrxj9fihfq47zb"; + system = "charje.documentation"; + asd = "charje.documentation"; + } + ); + systems = [ "charje.documentation" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cheat-js = ( + build-asdf-system { + pname = "cheat-js"; + version = "20121013-git"; + asds = [ "cheat-js" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cheat-js/2012-10-13/cheat-js-20121013-git.tgz"; + sha256 = "1h73kx0iii4y4gslz6f8kvf980bnypsras6xj38apm0fcwm93w03"; + system = "cheat-js"; + asd = "cheat-js"; + } + ); + systems = [ "cheat-js" ]; + lispLibs = [ + (getAttr "cl-uglify-js" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + check-bnf = ( + build-asdf-system { + pname = "check-bnf"; + version = "20220707-git"; + asds = [ "check-bnf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/check-bnf/2022-07-07/check-bnf-20220707-git.tgz"; + sha256 = "1dpp0xzj51a7fg9yw0xsipnsa54xj1axvkk55n0yxq9yv9ih3rb0"; + system = "check-bnf"; + asd = "check-bnf"; + } + ); + systems = [ "check-bnf" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "jingoh_dot_documentizer" self) + (getAttr "matrix-case" self) + (getAttr "millet" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + check-bnf_dot_test = ( + build-asdf-system { + pname = "check-bnf.test"; + version = "20220707-git"; + asds = [ "check-bnf.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/check-bnf/2022-07-07/check-bnf-20220707-git.tgz"; + sha256 = "1dpp0xzj51a7fg9yw0xsipnsa54xj1axvkk55n0yxq9yv9ih3rb0"; + system = "check-bnf.test"; + asd = "check-bnf.test"; + } + ); + systems = [ "check-bnf.test" ]; + lispLibs = [ + (getAttr "check-bnf" self) + (getAttr "jingoh" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + check-it = ( + build-asdf-system { + pname = "check-it"; + version = "20150709-git"; + asds = [ "check-it" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/check-it/2015-07-09/check-it-20150709-git.tgz"; + sha256 = "1kbjwpniffdpv003igmlz5r0vy65m7wpfnhg54fhwirp1227hgg7"; + system = "check-it"; + asd = "check-it"; + } + ); + systems = [ "check-it" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "optima" self) + ]; + meta = { }; + } + ); + check-it-test = ( + build-asdf-system { + pname = "check-it-test"; + version = "20150709-git"; + asds = [ "check-it-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/check-it/2015-07-09/check-it-20150709-git.tgz"; + sha256 = "1kbjwpniffdpv003igmlz5r0vy65m7wpfnhg54fhwirp1227hgg7"; + system = "check-it-test"; + asd = "check-it"; + } + ); + systems = [ "check-it-test" ]; + lispLibs = [ + (getAttr "check-it" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + checkl = ( + build-asdf-system { + pname = "checkl"; + version = "20180328-git"; + asds = [ "checkl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/checkl/2018-03-28/checkl-20180328-git.tgz"; + sha256 = "0bpisihx1gay44xmyr1dmhlwh00j0zzi04rp9fy35i95l2r4xdlx"; + system = "checkl"; + asd = "checkl"; + } + ); + systems = [ "checkl" ]; + lispLibs = [ (getAttr "marshal" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + checkl-docs = ( + build-asdf-system { + pname = "checkl-docs"; + version = "20180328-git"; + asds = [ "checkl-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/checkl/2018-03-28/checkl-20180328-git.tgz"; + sha256 = "0bpisihx1gay44xmyr1dmhlwh00j0zzi04rp9fy35i95l2r4xdlx"; + system = "checkl-docs"; + asd = "checkl-docs"; + } + ); + systems = [ "checkl-docs" ]; + lispLibs = [ + (getAttr "checkl" self) + (getAttr "cl-gendoc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + checkl-test = ( + build-asdf-system { + pname = "checkl-test"; + version = "20180328-git"; + asds = [ "checkl-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/checkl/2018-03-28/checkl-20180328-git.tgz"; + sha256 = "0bpisihx1gay44xmyr1dmhlwh00j0zzi04rp9fy35i95l2r4xdlx"; + system = "checkl-test"; + asd = "checkl-test"; + } + ); + systems = [ "checkl-test" ]; + lispLibs = [ + (getAttr "checkl" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chemical-compounds = ( + build-asdf-system { + pname = "chemical-compounds"; + version = "1.0.2"; + asds = [ "chemical-compounds" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chemical-compounds/2011-10-01/chemical-compounds-1.0.2.tgz"; + sha256 = "047z1lab08y4nsb32rnzqfpb6akyhibzjgmmr1bnwrh9pmhv3s2k"; + system = "chemical-compounds"; + asd = "chemical-compounds"; + } + ); + systems = [ "chemical-compounds" ]; + lispLibs = [ (getAttr "periodic-table" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chillax = ( + build-asdf-system { + pname = "chillax"; + version = "20150302-git"; + asds = [ "chillax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chillax/2015-03-02/chillax-20150302-git.tgz"; + sha256 = "1is3qm68wyfi3rmpn8mw0x9861951a2w60snsdippikygm3smzr1"; + system = "chillax"; + asd = "chillax"; + } + ); + systems = [ "chillax" ]; + lispLibs = [ + (getAttr "chillax_dot_core" self) + (getAttr "chillax_dot_yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chillax_dot_core = ( + build-asdf-system { + pname = "chillax.core"; + version = "20150302-git"; + asds = [ "chillax.core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chillax/2015-03-02/chillax-20150302-git.tgz"; + sha256 = "1is3qm68wyfi3rmpn8mw0x9861951a2w60snsdippikygm3smzr1"; + system = "chillax.core"; + asd = "chillax.core"; + } + ); + systems = [ "chillax.core" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chillax_dot_jsown = ( + build-asdf-system { + pname = "chillax.jsown"; + version = "20150302-git"; + asds = [ "chillax.jsown" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chillax/2015-03-02/chillax-20150302-git.tgz"; + sha256 = "1is3qm68wyfi3rmpn8mw0x9861951a2w60snsdippikygm3smzr1"; + system = "chillax.jsown"; + asd = "chillax.jsown"; + } + ); + systems = [ "chillax.jsown" ]; + lispLibs = [ + (getAttr "chillax_dot_core" self) + (getAttr "jsown" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chillax_dot_view-server = ( + build-asdf-system { + pname = "chillax.view-server"; + version = "20150302-git"; + asds = [ "chillax.view-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chillax/2015-03-02/chillax-20150302-git.tgz"; + sha256 = "1is3qm68wyfi3rmpn8mw0x9861951a2w60snsdippikygm3smzr1"; + system = "chillax.view-server"; + asd = "chillax.view-server"; + } + ); + systems = [ "chillax.view-server" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chillax_dot_yason = ( + build-asdf-system { + pname = "chillax.yason"; + version = "20150302-git"; + asds = [ "chillax.yason" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chillax/2015-03-02/chillax-20150302-git.tgz"; + sha256 = "1is3qm68wyfi3rmpn8mw0x9861951a2w60snsdippikygm3smzr1"; + system = "chillax.yason"; + asd = "chillax.yason"; + } + ); + systems = [ "chillax.yason" ]; + lispLibs = [ + (getAttr "chillax_dot_core" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chipi = ( + build-asdf-system { + pname = "chipi"; + version = "20241012-git"; + asds = [ "chipi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chipi/2024-10-12/chipi-20241012-git.tgz"; + sha256 = "0xpfclvl5v031cjnjvr3bcfc87rayw624m9yrw35f5r31p8m283g"; + system = "chipi"; + asd = "chipi"; + } + ); + systems = [ "chipi" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "binding-arrows" self) + (getAttr "cl-cron" self) + (getAttr "drakma" self) + (getAttr "local-time" self) + (getAttr "parse-float" self) + (getAttr "sento" self) + (getAttr "timer-wheel" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chipi-web = ( + build-asdf-system { + pname = "chipi-web"; + version = "20241012-git"; + asds = [ "chipi-web" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chipi/2024-10-12/chipi-20241012-git.tgz"; + sha256 = "0xpfclvl5v031cjnjvr3bcfc87rayw624m9yrw35f5r31p8m283g"; + system = "chipi-web"; + asd = "chipi-web"; + } + ); + systems = [ "chipi-web" ]; + lispLibs = [ + (getAttr "chipi" self) + (getAttr "cl-base64" self) + (getAttr "cl-ppcre" self) + (getAttr "com_dot_inuoe_dot_jzon" self) + (getAttr "drakma" self) + (getAttr "hunchentoot" self) + (getAttr "ironclad" self) + (getAttr "marshal" self) + (getAttr "snooze" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chipmunk-blob = ( + build-asdf-system { + pname = "chipmunk-blob"; + version = "stable-git"; + asds = [ "chipmunk-blob" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chipmunk-blob/2020-10-16/chipmunk-blob-stable-git.tgz"; + sha256 = "0kdi1al1cn90hzjfnjhkxp3k5ibp6l73k3m04mkpzkzpjy7jc80d"; + system = "chipmunk-blob"; + asd = "chipmunk-blob"; + } + ); + systems = [ "chipmunk-blob" ]; + lispLibs = [ + (getAttr "bodge-blobs-support" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chipz = ( + build-asdf-system { + pname = "chipz"; + version = "20230618-git"; + asds = [ "chipz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chipz/2023-06-18/chipz-20230618-git.tgz"; + sha256 = "04ysl1lz47dd8p1cbm637kpyf84hl74xvcdpqhdyxwh4n97csm5h"; + system = "chipz"; + asd = "chipz"; + } + ); + systems = [ "chipz" ]; + lispLibs = [ ]; + meta = { }; + } + ); + chirp = ( + build-asdf-system { + pname = "chirp"; + version = "20231021-git"; + asds = [ "chirp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chirp/2023-10-21/chirp-20231021-git.tgz"; + sha256 = "00vin2svx54wpk2yv9645y3gfy5pg78pfpr79srqk7jklr1wwa1m"; + system = "chirp"; + asd = "chirp"; + } + ); + systems = [ "chirp" ]; + lispLibs = [ (getAttr "chirp-drakma" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chirp-core = ( + build-asdf-system { + pname = "chirp-core"; + version = "20231021-git"; + asds = [ "chirp-core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chirp/2023-10-21/chirp-20231021-git.tgz"; + sha256 = "00vin2svx54wpk2yv9645y3gfy5pg78pfpr79srqk7jklr1wwa1m"; + system = "chirp-core"; + asd = "chirp-core"; + } + ); + systems = [ "chirp-core" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-base64" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "ironclad" self) + (getAttr "local-time" self) + (getAttr "split-sequence" self) + (getAttr "uuid" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chirp-dexador = ( + build-asdf-system { + pname = "chirp-dexador"; + version = "20231021-git"; + asds = [ "chirp-dexador" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chirp/2023-10-21/chirp-20231021-git.tgz"; + sha256 = "00vin2svx54wpk2yv9645y3gfy5pg78pfpr79srqk7jklr1wwa1m"; + system = "chirp-dexador"; + asd = "chirp-dexador"; + } + ); + systems = [ "chirp-dexador" ]; + lispLibs = [ + (getAttr "chirp-core" self) + (getAttr "dexador" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chirp-drakma = ( + build-asdf-system { + pname = "chirp-drakma"; + version = "20231021-git"; + asds = [ "chirp-drakma" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chirp/2023-10-21/chirp-20231021-git.tgz"; + sha256 = "00vin2svx54wpk2yv9645y3gfy5pg78pfpr79srqk7jklr1wwa1m"; + system = "chirp-drakma"; + asd = "chirp-drakma"; + } + ); + systems = [ "chirp-drakma" ]; + lispLibs = [ + (getAttr "chirp-core" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chlorophyll = ( + build-asdf-system { + pname = "chlorophyll"; + version = "20231021-git"; + asds = [ "chlorophyll" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chlorophyll/2023-10-21/chlorophyll-20231021-git.tgz"; + sha256 = "0q681pbcx4vcshrlligd5h07kakbjprb0kpf48z4glswy59vg8mg"; + system = "chlorophyll"; + asd = "chlorophyll"; + } + ); + systems = [ "chlorophyll" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chlorophyll-test = ( + build-asdf-system { + pname = "chlorophyll-test"; + version = "20231021-git"; + asds = [ "chlorophyll-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chlorophyll/2023-10-21/chlorophyll-20231021-git.tgz"; + sha256 = "0q681pbcx4vcshrlligd5h07kakbjprb0kpf48z4glswy59vg8mg"; + system = "chlorophyll-test"; + asd = "chlorophyll-test"; + } + ); + systems = [ "chlorophyll-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "chlorophyll" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chrome-native-messaging = ( + build-asdf-system { + pname = "chrome-native-messaging"; + version = "20150302-git"; + asds = [ "chrome-native-messaging" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chrome-native-messaging/2015-03-02/chrome-native-messaging-20150302-git.tgz"; + sha256 = "1fw02w5brpwa0kl7sx5b13fbcfv1ny8rwcj11ayj2q528i2xmpx5"; + system = "chrome-native-messaging"; + asd = "chrome-native-messaging"; + } + ); + systems = [ "chrome-native-messaging" ]; + lispLibs = [ (getAttr "trivial-utf-8" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chronicity = ( + build-asdf-system { + pname = "chronicity"; + version = "20190202-git"; + asds = [ "chronicity" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chronicity/2019-02-02/chronicity-20190202-git.tgz"; + sha256 = "1h5dlgvccffd8sqszqwilscysklzfcp374zl48rq14ywgv3rnwhl"; + system = "chronicity"; + asd = "chronicity"; + } + ); + systems = [ "chronicity" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chronicity-test = ( + build-asdf-system { + pname = "chronicity-test"; + version = "20190202-git"; + asds = [ "chronicity-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chronicity/2019-02-02/chronicity-20190202-git.tgz"; + sha256 = "1h5dlgvccffd8sqszqwilscysklzfcp374zl48rq14ywgv3rnwhl"; + system = "chronicity-test"; + asd = "chronicity-test"; + } + ); + systems = [ "chronicity-test" ]; + lispLibs = [ + (getAttr "chronicity" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chtml-matcher = ( + build-asdf-system { + pname = "chtml-matcher"; + version = "20111001-git"; + asds = [ "chtml-matcher" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chtml-matcher/2011-10-01/chtml-matcher-20111001-git.tgz"; + sha256 = "1q1ksy2w0c4dcmq8543scl11x4crh1m5w29p1wjpqhxk826jx7fd"; + system = "chtml-matcher"; + asd = "chtml-matcher"; + } + ); + systems = [ "chtml-matcher" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "closure-html" self) + (getAttr "f-underscore" self) + (getAttr "stdutils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + chunga = ( + build-asdf-system { + pname = "chunga"; + version = "20241012-git"; + asds = [ "chunga" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/chunga/2024-10-12/chunga-20241012-git.tgz"; + sha256 = "17jswsp31dh1jpg2n60nn34wxf4z6vvxjq1avy50z9fnzywvikyi"; + system = "chunga"; + asd = "chunga"; + } + ); + systems = [ "chunga" ]; + lispLibs = [ (getAttr "trivial-gray-streams" self) ]; + meta = { }; + } + ); + ci-utils = ( + build-asdf-system { + pname = "ci-utils"; + version = "20241012-git"; + asds = [ "ci-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ci-utils/2024-10-12/ci-utils-20241012-git.tgz"; + sha256 = "1wrr1v2r7kd668hyz54x28xh153l2qkl1gra3bk4wmqi3x7xyxdg"; + system = "ci-utils"; + asd = "ci-utils"; + } + ); + systems = [ "ci-utils" ]; + lispLibs = [ (getAttr "ci-utils-features" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ci-utils-features = ( + build-asdf-system { + pname = "ci-utils-features"; + version = "20241012-git"; + asds = [ "ci-utils-features" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ci-utils/2024-10-12/ci-utils-20241012-git.tgz"; + sha256 = "1wrr1v2r7kd668hyz54x28xh153l2qkl1gra3bk4wmqi3x7xyxdg"; + system = "ci-utils-features"; + asd = "ci-utils-features"; + } + ); + systems = [ "ci-utils-features" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ciao = ( + build-asdf-system { + pname = "ciao"; + version = "20241012-git"; + asds = [ "ciao" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ciao/2024-10-12/ciao-20241012-git.tgz"; + sha256 = "1x443k02kl5iyq6awv2vqm08d9x9f92hjivqv2c5xdamki7y513s"; + system = "ciao"; + asd = "ciao"; + } + ); + systems = [ "ciao" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "dexador" self) + (getAttr "hunchentoot" self) + (getAttr "trivial-open-browser" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + circular-streams = ( + build-asdf-system { + pname = "circular-streams"; + version = "20161204-git"; + asds = [ "circular-streams" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/circular-streams/2016-12-04/circular-streams-20161204-git.tgz"; + sha256 = "1wpw6d5cciyqcf92f7mvihak52pd5s47kk4qq6f0r2z2as68p5rs"; + system = "circular-streams"; + asd = "circular-streams"; + } + ); + systems = [ "circular-streams" ]; + lispLibs = [ + (getAttr "fast-io" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + circular-streams-test = ( + build-asdf-system { + pname = "circular-streams-test"; + version = "20161204-git"; + asds = [ "circular-streams-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/circular-streams/2016-12-04/circular-streams-20161204-git.tgz"; + sha256 = "1wpw6d5cciyqcf92f7mvihak52pd5s47kk4qq6f0r2z2as68p5rs"; + system = "circular-streams-test"; + asd = "circular-streams-test"; + } + ); + systems = [ "circular-streams-test" ]; + lispLibs = [ + (getAttr "circular-streams" self) + (getAttr "cl-test-more" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + city-hash = ( + build-asdf-system { + pname = "city-hash"; + version = "20200925-git"; + asds = [ "city-hash" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/city-hash/2020-09-25/city-hash-20200925-git.tgz"; + sha256 = "10ksl402aa37sn78hnvlvpqibr66qzpjvf2x4a789gnl411cf44a"; + system = "city-hash"; + asd = "city-hash"; + } + ); + systems = [ "city-hash" ]; + lispLibs = [ + (getAttr "com_dot_google_dot_base" self) + (getAttr "nibbles" self) + (getAttr "swap-bytes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + city-hash-test = ( + build-asdf-system { + pname = "city-hash-test"; + version = "20200925-git"; + asds = [ "city-hash-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/city-hash/2020-09-25/city-hash-20200925-git.tgz"; + sha256 = "10ksl402aa37sn78hnvlvpqibr66qzpjvf2x4a789gnl411cf44a"; + system = "city-hash-test"; + asd = "city-hash-test"; + } + ); + systems = [ "city-hash-test" ]; + lispLibs = [ + (getAttr "city-hash" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ckr-tables = ( + build-asdf-system { + pname = "ckr-tables"; + version = "20241012-git"; + asds = [ "ckr-tables" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-critic/2024-10-12/lisp-critic-20241012-git.tgz"; + sha256 = "19czs2m8h3kgwjd10pdk9r5kazbgly8g82a5q3bs7pqkja42i7x7"; + system = "ckr-tables"; + asd = "ckr-tables"; + } + ); + systems = [ "ckr-tables" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl_plus_ssl = ( + build-asdf-system { + pname = "cl+ssl"; + version = "20231021-git"; + asds = [ "cl+ssl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl+ssl/2023-10-21/cl+ssl-20231021-git.tgz"; + sha256 = "0v0kx2m5355jkdshmj0z923c5rlvdl2n11rb3hjbv3kssdfsbs0s"; + system = "cl+ssl"; + asd = "cl+ssl"; + } + ); + systems = [ "cl+ssl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "flexi-streams" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-gray-streams" self) + (getAttr "usocket" self) + ]; + meta = { }; + } + ); + cl_plus_ssl_dot_test = ( + build-asdf-system { + pname = "cl+ssl.test"; + version = "20231021-git"; + asds = [ "cl+ssl.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl+ssl/2023-10-21/cl+ssl-20231021-git.tgz"; + sha256 = "0v0kx2m5355jkdshmj0z923c5rlvdl2n11rb3hjbv3kssdfsbs0s"; + system = "cl+ssl.test"; + asd = "cl+ssl.test"; + } + ); + systems = [ "cl+ssl.test" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl_plus_ssl" self) + (getAttr "cl-coveralls" self) + (getAttr "fiveam" self) + (getAttr "trivial-sockets" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-6502 = ( + build-asdf-system { + pname = "cl-6502"; + version = "20241012-git"; + asds = [ "cl-6502" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-6502/2024-10-12/cl-6502-20241012-git.tgz"; + sha256 = "1cj38bi12i7ji3m8dd8gxb17dlna2v8s3b3h6b0a9pvmv6wchpmz"; + system = "cl-6502"; + asd = "cl-6502"; + } + ); + systems = [ "cl-6502" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-aa = ( + build-asdf-system { + pname = "cl-aa"; + version = "20241012-git"; + asds = [ "cl-aa" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-vectors/2024-10-12/cl-vectors-20241012-git.tgz"; + sha256 = "1nkmmn38y6af10ysff3g2qkf5lb2601dcjp5rffsjh6bv2ik2jd5"; + system = "cl-aa"; + asd = "cl-aa"; + } + ); + systems = [ "cl-aa" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-aa-misc = ( + build-asdf-system { + pname = "cl-aa-misc"; + version = "20241012-git"; + asds = [ "cl-aa-misc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-vectors/2024-10-12/cl-vectors-20241012-git.tgz"; + sha256 = "1nkmmn38y6af10ysff3g2qkf5lb2601dcjp5rffsjh6bv2ik2jd5"; + system = "cl-aa-misc"; + asd = "cl-aa-misc"; + } + ); + systems = [ "cl-aa-misc" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-acronyms = ( + build-asdf-system { + pname = "cl-acronyms"; + version = "20150302-git"; + asds = [ "cl-acronyms" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-acronyms/2015-03-02/cl-acronyms-20150302-git.tgz"; + sha256 = "1b827g6n87i81wbqzvmlq0yn41kfa502v5ssbh2wh1b4xznhn8cc"; + system = "cl-acronyms"; + asd = "cl-acronyms"; + } + ); + systems = [ "cl-acronyms" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-actors = ( + build-asdf-system { + pname = "cl-actors"; + version = "20191130-git"; + asds = [ "cl-actors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-lisp-actors/2019-11-30/common-lisp-actors-20191130-git.tgz"; + sha256 = "0snf91yivxq6jcbvm3l6b05lcka7jrzciqd4m841amghfw32clfn"; + system = "cl-actors"; + asd = "cl-actors"; + } + ); + systems = [ "cl-actors" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-advice = ( + build-asdf-system { + pname = "cl-advice"; + version = "20230214-git"; + asds = [ "cl-advice" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-advice/2023-02-14/cl-advice-20230214-git.tgz"; + sha256 = "038fhy7chgn9racrcikqncyiq5yqngs6d5ahxz7jkypixcdz48jx"; + system = "cl-advice"; + asd = "cl-advice"; + } + ); + systems = [ "cl-advice" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-advice-tests = ( + build-asdf-system { + pname = "cl-advice-tests"; + version = "20230214-git"; + asds = [ "cl-advice-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-advice/2023-02-14/cl-advice-20230214-git.tgz"; + sha256 = "038fhy7chgn9racrcikqncyiq5yqngs6d5ahxz7jkypixcdz48jx"; + system = "cl-advice-tests"; + asd = "cl-advice-tests"; + } + ); + systems = [ "cl-advice-tests" ]; + lispLibs = [ + (getAttr "cl-advice" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-alc = ( + build-asdf-system { + pname = "cl-alc"; + version = "20221106-git"; + asds = [ "cl-alc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-openal/2022-11-06/cl-openal-20221106-git.tgz"; + sha256 = "0jmp81mf23ckcm4knnh0q7zpmyls5220imaqbmnl0xvvra10b1zy"; + system = "cl-alc"; + asd = "cl-alc"; + } + ); + systems = [ "cl-alc" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-openal" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-algebraic-data-type = ( + build-asdf-system { + pname = "cl-algebraic-data-type"; + version = "20241012-git"; + asds = [ "cl-algebraic-data-type" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-algebraic-data-type/2024-10-12/cl-algebraic-data-type-20241012-git.tgz"; + sha256 = "02bfx9g4267f7f85banmfy15adyvlzaz3flia8zmhlzhpx7j4bj6"; + system = "cl-algebraic-data-type"; + asd = "cl-algebraic-data-type"; + } + ); + systems = [ "cl-algebraic-data-type" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "global-vars" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-all = ( + build-asdf-system { + pname = "cl-all"; + version = "20241012-git"; + asds = [ "cl-all" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-all/2024-10-12/cl-all-20241012-git.tgz"; + sha256 = "02n30b3yp949fxwnb9wr3m9hd5h1kcmxcbjc8c5fj4ihphf8sd7d"; + system = "cl-all"; + asd = "cl-all"; + } + ); + systems = [ "cl-all" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-alut = ( + build-asdf-system { + pname = "cl-alut"; + version = "20221106-git"; + asds = [ "cl-alut" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-openal/2022-11-06/cl-openal-20221106-git.tgz"; + sha256 = "0jmp81mf23ckcm4knnh0q7zpmyls5220imaqbmnl0xvvra10b1zy"; + system = "cl-alut"; + asd = "cl-alut"; + } + ); + systems = [ "cl-alut" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-openal" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-amqp = ( + build-asdf-system { + pname = "cl-amqp"; + version = "v0.4.1"; + asds = [ "cl-amqp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-amqp/2019-10-08/cl-amqp-v0.4.1.tgz"; + sha256 = "1ggd77ckfr54z7z5yi8d04k310x2dhf53qija8dzjhk1r9py20vz"; + system = "cl-amqp"; + asd = "cl-amqp"; + } + ); + systems = [ "cl-amqp" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-interpol" self) + (getAttr "collectors" self) + (getAttr "fast-io" self) + (getAttr "local-time" self) + (getAttr "log4cl" self) + (getAttr "nibbles" self) + (getAttr "trivial-utf-8" self) + (getAttr "wu-decimal" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-amqp_dot_test = ( + build-asdf-system { + pname = "cl-amqp.test"; + version = "v0.4.1"; + asds = [ "cl-amqp.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-amqp/2019-10-08/cl-amqp-v0.4.1.tgz"; + sha256 = "1ggd77ckfr54z7z5yi8d04k310x2dhf53qija8dzjhk1r9py20vz"; + system = "cl-amqp.test"; + asd = "cl-amqp.test"; + } + ); + systems = [ "cl-amqp.test" ]; + lispLibs = [ + (getAttr "cl-amqp" self) + (getAttr "cl-interpol" self) + (getAttr "log4cl" self) + (getAttr "mw-equiv" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana = ( + build-asdf-system { + pname = "cl-ana"; + version = "20220707-git"; + asds = [ "cl-ana" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana"; + asd = "cl-ana"; + } + ); + systems = [ "cl-ana" ]; + lispLibs = [ + (getAttr "cl-ana_dot_array-utils" self) + (getAttr "cl-ana_dot_binary-tree" self) + (getAttr "cl-ana_dot_calculus" self) + (getAttr "cl-ana_dot_clos-utils" self) + (getAttr "cl-ana_dot_columnar-table" self) + (getAttr "cl-ana_dot_csv-table" self) + (getAttr "cl-ana_dot_error-propogation" self) + (getAttr "cl-ana_dot_file-utils" self) + (getAttr "cl-ana_dot_fitting" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_hash-table-utils" self) + (getAttr "cl-ana_dot_hdf-table" self) + (getAttr "cl-ana_dot_histogram" self) + (getAttr "cl-ana_dot_int-char" self) + (getAttr "cl-ana_dot_linear-algebra" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_lorentz" self) + (getAttr "cl-ana_dot_makeres" self) + (getAttr "cl-ana_dot_makeres-block" self) + (getAttr "cl-ana_dot_makeres-branch" self) + (getAttr "cl-ana_dot_makeres-graphviz" self) + (getAttr "cl-ana_dot_makeres-macro" self) + (getAttr "cl-ana_dot_makeres-progress" self) + (getAttr "cl-ana_dot_makeres-table" self) + (getAttr "cl-ana_dot_makeres-utils" self) + (getAttr "cl-ana_dot_map" self) + (getAttr "cl-ana_dot_math-functions" self) + (getAttr "cl-ana_dot_ntuple-table" self) + (getAttr "cl-ana_dot_package-utils" self) + (getAttr "cl-ana_dot_pathname-utils" self) + (getAttr "cl-ana_dot_plotting" self) + (getAttr "cl-ana_dot_quantity" self) + (getAttr "cl-ana_dot_reusable-table" self) + (getAttr "cl-ana_dot_serialization" self) + (getAttr "cl-ana_dot_spline" self) + (getAttr "cl-ana_dot_statistical-learning" self) + (getAttr "cl-ana_dot_statistics" self) + (getAttr "cl-ana_dot_table" self) + (getAttr "cl-ana_dot_table-utils" self) + (getAttr "cl-ana_dot_table-viewing" self) + (getAttr "cl-ana_dot_tensor" self) + ]; + meta = { }; + } + ); + cl-ana_dot_array-utils = ( + build-asdf-system { + pname = "cl-ana.array-utils"; + version = "20220707-git"; + asds = [ "cl-ana.array-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.array-utils"; + asd = "cl-ana.array-utils"; + } + ); + systems = [ "cl-ana.array-utils" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_binary-tree = ( + build-asdf-system { + pname = "cl-ana.binary-tree"; + version = "20220707-git"; + asds = [ "cl-ana.binary-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.binary-tree"; + asd = "cl-ana.binary-tree"; + } + ); + systems = [ "cl-ana.binary-tree" ]; + lispLibs = [ + (getAttr "cl-ana_dot_functional-utils" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_calculus = ( + build-asdf-system { + pname = "cl-ana.calculus"; + version = "20220707-git"; + asds = [ "cl-ana.calculus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.calculus"; + asd = "cl-ana.calculus"; + } + ); + systems = [ "cl-ana.calculus" ]; + lispLibs = [ + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_linear-algebra" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_clos-utils = ( + build-asdf-system { + pname = "cl-ana.clos-utils"; + version = "20220707-git"; + asds = [ "cl-ana.clos-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.clos-utils"; + asd = "cl-ana.clos-utils"; + } + ); + systems = [ "cl-ana.clos-utils" ]; + lispLibs = [ + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_symbol-utils" self) + (getAttr "cl-ana_dot_tensor" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_columnar-table = ( + build-asdf-system { + pname = "cl-ana.columnar-table"; + version = "20220707-git"; + asds = [ "cl-ana.columnar-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.columnar-table"; + asd = "cl-ana.columnar-table"; + } + ); + systems = [ "cl-ana.columnar-table" ]; + lispLibs = [ + (getAttr "cl-ana_dot_reusable-table" self) + (getAttr "cl-ana_dot_table" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_csv-table = ( + build-asdf-system { + pname = "cl-ana.csv-table"; + version = "20220707-git"; + asds = [ "cl-ana.csv-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.csv-table"; + asd = "cl-ana.csv-table"; + } + ); + systems = [ "cl-ana.csv-table" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "antik" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_table" self) + (getAttr "cl-csv" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_error-propogation = ( + build-asdf-system { + pname = "cl-ana.error-propogation"; + version = "20220707-git"; + asds = [ "cl-ana.error-propogation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.error-propogation"; + asd = "cl-ana.error-propogation"; + } + ); + systems = [ "cl-ana.error-propogation" ]; + lispLibs = [ + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_math-functions" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_file-utils = ( + build-asdf-system { + pname = "cl-ana.file-utils"; + version = "20220707-git"; + asds = [ "cl-ana.file-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.file-utils"; + asd = "cl-ana.file-utils"; + } + ); + systems = [ "cl-ana.file-utils" ]; + lispLibs = [ + (getAttr "external-program" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_fitting = ( + build-asdf-system { + pname = "cl-ana.fitting"; + version = "20220707-git"; + asds = [ "cl-ana.fitting" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.fitting"; + asd = "cl-ana.fitting"; + } + ); + systems = [ "cl-ana.fitting" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_error-propogation" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_map" self) + (getAttr "cl-ana_dot_math-functions" self) + (getAttr "gsll" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_functional-utils = ( + build-asdf-system { + pname = "cl-ana.functional-utils"; + version = "20220707-git"; + asds = [ "cl-ana.functional-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.functional-utils"; + asd = "cl-ana.functional-utils"; + } + ); + systems = [ "cl-ana.functional-utils" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_generic-math = ( + build-asdf-system { + pname = "cl-ana.generic-math"; + version = "20220707-git"; + asds = [ "cl-ana.generic-math" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.generic-math"; + asd = "cl-ana.generic-math"; + } + ); + systems = [ "cl-ana.generic-math" ]; + lispLibs = [ + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_package-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_gnuplot-interface = ( + build-asdf-system { + pname = "cl-ana.gnuplot-interface"; + version = "20220707-git"; + asds = [ "cl-ana.gnuplot-interface" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.gnuplot-interface"; + asd = "cl-ana.gnuplot-interface"; + } + ); + systems = [ "cl-ana.gnuplot-interface" ]; + lispLibs = [ (getAttr "external-program" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_gsl-cffi = ( + build-asdf-system { + pname = "cl-ana.gsl-cffi"; + version = "20220707-git"; + asds = [ "cl-ana.gsl-cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.gsl-cffi"; + asd = "cl-ana.gsl-cffi"; + } + ); + systems = [ "cl-ana.gsl-cffi" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_hash-table-utils = ( + build-asdf-system { + pname = "cl-ana.hash-table-utils"; + version = "20220707-git"; + asds = [ "cl-ana.hash-table-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.hash-table-utils"; + asd = "cl-ana.hash-table-utils"; + } + ); + systems = [ "cl-ana.hash-table-utils" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_hdf-cffi = ( + build-asdf-system { + pname = "cl-ana.hdf-cffi"; + version = "20220707-git"; + asds = [ "cl-ana.hdf-cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.hdf-cffi"; + asd = "cl-ana.hdf-cffi"; + } + ); + systems = [ "cl-ana.hdf-cffi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_hdf-table = ( + build-asdf-system { + pname = "cl-ana.hdf-table"; + version = "20220707-git"; + asds = [ "cl-ana.hdf-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.hdf-table"; + asd = "cl-ana.hdf-table"; + } + ); + systems = [ "cl-ana.hdf-table" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_binary-tree" self) + (getAttr "cl-ana_dot_hdf-typespec" self) + (getAttr "cl-ana_dot_hdf-utils" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_memoization" self) + (getAttr "cl-ana_dot_table" self) + (getAttr "cl-ana_dot_typed-table" self) + (getAttr "cl-ana_dot_typespec" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_hdf-typespec = ( + build-asdf-system { + pname = "cl-ana.hdf-typespec"; + version = "20220707-git"; + asds = [ "cl-ana.hdf-typespec" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.hdf-typespec"; + asd = "cl-ana.hdf-typespec"; + } + ); + systems = [ "cl-ana.hdf-typespec" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-ana_dot_hdf-cffi" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_memoization" self) + (getAttr "cl-ana_dot_string-utils" self) + (getAttr "cl-ana_dot_symbol-utils" self) + (getAttr "cl-ana_dot_typespec" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_hdf-utils = ( + build-asdf-system { + pname = "cl-ana.hdf-utils"; + version = "20220707-git"; + asds = [ "cl-ana.hdf-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.hdf-utils"; + asd = "cl-ana.hdf-utils"; + } + ); + systems = [ "cl-ana.hdf-utils" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-ana_dot_hdf-cffi" self) + (getAttr "cl-ana_dot_hdf-typespec" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_memoization" self) + (getAttr "cl-ana_dot_pathname-utils" self) + (getAttr "cl-ana_dot_string-utils" self) + (getAttr "cl-ana_dot_typespec" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_histogram = ( + build-asdf-system { + pname = "cl-ana.histogram"; + version = "20220707-git"; + asds = [ "cl-ana.histogram" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.histogram"; + asd = "cl-ana.histogram"; + } + ); + systems = [ "cl-ana.histogram" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_binary-tree" self) + (getAttr "cl-ana_dot_clos-utils" self) + (getAttr "cl-ana_dot_fitting" self) + (getAttr "cl-ana_dot_functional-utils" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_hash-table-utils" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_map" self) + (getAttr "cl-ana_dot_symbol-utils" self) + (getAttr "cl-ana_dot_tensor" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_int-char = ( + build-asdf-system { + pname = "cl-ana.int-char"; + version = "20220707-git"; + asds = [ "cl-ana.int-char" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.int-char"; + asd = "cl-ana.int-char"; + } + ); + systems = [ "cl-ana.int-char" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_linear-algebra = ( + build-asdf-system { + pname = "cl-ana.linear-algebra"; + version = "20220707-git"; + asds = [ "cl-ana.linear-algebra" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.linear-algebra"; + asd = "cl-ana.linear-algebra"; + } + ); + systems = [ "cl-ana.linear-algebra" ]; + lispLibs = [ + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_math-functions" self) + (getAttr "cl-ana_dot_tensor" self) + (getAttr "gsll" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_list-utils = ( + build-asdf-system { + pname = "cl-ana.list-utils"; + version = "20220707-git"; + asds = [ "cl-ana.list-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.list-utils"; + asd = "cl-ana.list-utils"; + } + ); + systems = [ "cl-ana.list-utils" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_functional-utils" self) + (getAttr "cl-ana_dot_string-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_lorentz = ( + build-asdf-system { + pname = "cl-ana.lorentz"; + version = "20220707-git"; + asds = [ "cl-ana.lorentz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.lorentz"; + asd = "cl-ana.lorentz"; + } + ); + systems = [ "cl-ana.lorentz" ]; + lispLibs = [ + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_linear-algebra" self) + (getAttr "cl-ana_dot_tensor" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_macro-utils = ( + build-asdf-system { + pname = "cl-ana.macro-utils"; + version = "20220707-git"; + asds = [ "cl-ana.macro-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.macro-utils"; + asd = "cl-ana.macro-utils"; + } + ); + systems = [ "cl-ana.macro-utils" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_string-utils" self) + (getAttr "cl-ana_dot_symbol-utils" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_makeres = ( + build-asdf-system { + pname = "cl-ana.makeres"; + version = "20220707-git"; + asds = [ "cl-ana.makeres" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.makeres"; + asd = "cl-ana.makeres"; + } + ); + systems = [ "cl-ana.makeres" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_error-propogation" self) + (getAttr "cl-ana_dot_file-utils" self) + (getAttr "cl-ana_dot_functional-utils" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_hash-table-utils" self) + (getAttr "cl-ana_dot_hdf-utils" self) + (getAttr "cl-ana_dot_histogram" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_map" self) + (getAttr "cl-ana_dot_memoization" self) + (getAttr "cl-ana_dot_pathname-utils" self) + (getAttr "cl-ana_dot_plotting" self) + (getAttr "cl-ana_dot_reusable-table" self) + (getAttr "cl-ana_dot_serialization" self) + (getAttr "cl-ana_dot_string-utils" self) + (getAttr "cl-ana_dot_symbol-utils" self) + (getAttr "cl-ana_dot_table" self) + (getAttr "cl-fad" self) + (getAttr "external-program" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_makeres-block = ( + build-asdf-system { + pname = "cl-ana.makeres-block"; + version = "20220707-git"; + asds = [ "cl-ana.makeres-block" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.makeres-block"; + asd = "cl-ana.makeres-block"; + } + ); + systems = [ "cl-ana.makeres-block" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_makeres" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_makeres-branch = ( + build-asdf-system { + pname = "cl-ana.makeres-branch"; + version = "20220707-git"; + asds = [ "cl-ana.makeres-branch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.makeres-branch"; + asd = "cl-ana.makeres-branch"; + } + ); + systems = [ "cl-ana.makeres-branch" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_hash-table-utils" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_makeres" self) + (getAttr "cl-ana_dot_map" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_makeres-graphviz = ( + build-asdf-system { + pname = "cl-ana.makeres-graphviz"; + version = "20220707-git"; + asds = [ "cl-ana.makeres-graphviz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.makeres-graphviz"; + asd = "cl-ana.makeres-graphviz"; + } + ); + systems = [ "cl-ana.makeres-graphviz" ]; + lispLibs = [ + (getAttr "cl-ana_dot_makeres" self) + (getAttr "external-program" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_makeres-macro = ( + build-asdf-system { + pname = "cl-ana.makeres-macro"; + version = "20220707-git"; + asds = [ "cl-ana.makeres-macro" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.makeres-macro"; + asd = "cl-ana.makeres-macro"; + } + ); + systems = [ "cl-ana.makeres-macro" ]; + lispLibs = [ + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_makeres" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_makeres-progress = ( + build-asdf-system { + pname = "cl-ana.makeres-progress"; + version = "20220707-git"; + asds = [ "cl-ana.makeres-progress" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.makeres-progress"; + asd = "cl-ana.makeres-progress"; + } + ); + systems = [ "cl-ana.makeres-progress" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_makeres" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_makeres-table = ( + build-asdf-system { + pname = "cl-ana.makeres-table"; + version = "20220707-git"; + asds = [ "cl-ana.makeres-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.makeres-table"; + asd = "cl-ana.makeres-table"; + } + ); + systems = [ "cl-ana.makeres-table" ]; + lispLibs = [ + (getAttr "cl-ana_dot_csv-table" self) + (getAttr "cl-ana_dot_hash-table-utils" self) + (getAttr "cl-ana_dot_hdf-table" self) + (getAttr "cl-ana_dot_hdf-utils" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_makeres" self) + (getAttr "cl-ana_dot_makeres-macro" self) + (getAttr "cl-ana_dot_memoization" self) + (getAttr "cl-ana_dot_ntuple-table" self) + (getAttr "cl-ana_dot_reusable-table" self) + (getAttr "cl-ana_dot_string-utils" self) + (getAttr "cl-ana_dot_table" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_makeres-utils = ( + build-asdf-system { + pname = "cl-ana.makeres-utils"; + version = "20220707-git"; + asds = [ "cl-ana.makeres-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.makeres-utils"; + asd = "cl-ana.makeres-utils"; + } + ); + systems = [ "cl-ana.makeres-utils" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_file-utils" self) + (getAttr "cl-ana_dot_fitting" self) + (getAttr "cl-ana_dot_functional-utils" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_histogram" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_makeres" self) + (getAttr "cl-ana_dot_map" self) + (getAttr "cl-ana_dot_pathname-utils" self) + (getAttr "cl-ana_dot_plotting" self) + (getAttr "cl-ana_dot_reusable-table" self) + (getAttr "cl-ana_dot_string-utils" self) + (getAttr "cl-ana_dot_symbol-utils" self) + (getAttr "cl-ana_dot_table" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_map = ( + build-asdf-system { + pname = "cl-ana.map"; + version = "20220707-git"; + asds = [ "cl-ana.map" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.map"; + asd = "cl-ana.map"; + } + ); + systems = [ "cl-ana.map" ]; + lispLibs = [ (getAttr "cl-ana_dot_hash-table-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_math-functions = ( + build-asdf-system { + pname = "cl-ana.math-functions"; + version = "20220707-git"; + asds = [ "cl-ana.math-functions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.math-functions"; + asd = "cl-ana.math-functions"; + } + ); + systems = [ "cl-ana.math-functions" ]; + lispLibs = [ + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "gsll" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_memoization = ( + build-asdf-system { + pname = "cl-ana.memoization"; + version = "20220707-git"; + asds = [ "cl-ana.memoization" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.memoization"; + asd = "cl-ana.memoization"; + } + ); + systems = [ "cl-ana.memoization" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_ntuple-table = ( + build-asdf-system { + pname = "cl-ana.ntuple-table"; + version = "20220707-git"; + asds = [ "cl-ana.ntuple-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.ntuple-table"; + asd = "cl-ana.ntuple-table"; + } + ); + systems = [ "cl-ana.ntuple-table" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-ana_dot_gsl-cffi" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_table" self) + (getAttr "cl-ana_dot_typed-table" self) + (getAttr "cl-ana_dot_typespec" self) + (getAttr "gsll" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_package-utils = ( + build-asdf-system { + pname = "cl-ana.package-utils"; + version = "20220707-git"; + asds = [ "cl-ana.package-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.package-utils"; + asd = "cl-ana.package-utils"; + } + ); + systems = [ "cl-ana.package-utils" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_pathname-utils = ( + build-asdf-system { + pname = "cl-ana.pathname-utils"; + version = "20220707-git"; + asds = [ "cl-ana.pathname-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.pathname-utils"; + asd = "cl-ana.pathname-utils"; + } + ); + systems = [ "cl-ana.pathname-utils" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_plotting = ( + build-asdf-system { + pname = "cl-ana.plotting"; + version = "20220707-git"; + asds = [ "cl-ana.plotting" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.plotting"; + asd = "cl-ana.plotting"; + } + ); + systems = [ "cl-ana.plotting" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_error-propogation" self) + (getAttr "cl-ana_dot_functional-utils" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_gnuplot-interface" self) + (getAttr "cl-ana_dot_histogram" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_map" self) + (getAttr "cl-ana_dot_math-functions" self) + (getAttr "cl-ana_dot_pathname-utils" self) + (getAttr "cl-ana_dot_string-utils" self) + (getAttr "cl-ana_dot_tensor" self) + (getAttr "external-program" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_quantity = ( + build-asdf-system { + pname = "cl-ana.quantity"; + version = "20220707-git"; + asds = [ "cl-ana.quantity" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.quantity"; + asd = "cl-ana.quantity"; + } + ); + systems = [ "cl-ana.quantity" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_error-propogation" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_math-functions" self) + (getAttr "cl-ana_dot_symbol-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_reusable-table = ( + build-asdf-system { + pname = "cl-ana.reusable-table"; + version = "20220707-git"; + asds = [ "cl-ana.reusable-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.reusable-table"; + asd = "cl-ana.reusable-table"; + } + ); + systems = [ "cl-ana.reusable-table" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_table" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_serialization = ( + build-asdf-system { + pname = "cl-ana.serialization"; + version = "20220707-git"; + asds = [ "cl-ana.serialization" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.serialization"; + asd = "cl-ana.serialization"; + } + ); + systems = [ "cl-ana.serialization" ]; + lispLibs = [ + (getAttr "cl-ana_dot_error-propogation" self) + (getAttr "cl-ana_dot_hdf-table" self) + (getAttr "cl-ana_dot_hdf-utils" self) + (getAttr "cl-ana_dot_histogram" self) + (getAttr "cl-ana_dot_int-char" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_typespec" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_spline = ( + build-asdf-system { + pname = "cl-ana.spline"; + version = "20220707-git"; + asds = [ "cl-ana.spline" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.spline"; + asd = "cl-ana.spline"; + } + ); + systems = [ "cl-ana.spline" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-ana_dot_fitting" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_math-functions" self) + (getAttr "cl-ana_dot_tensor" self) + (getAttr "gsll" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_statistical-learning = ( + build-asdf-system { + pname = "cl-ana.statistical-learning"; + version = "20220707-git"; + asds = [ "cl-ana.statistical-learning" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.statistical-learning"; + asd = "cl-ana.statistical-learning"; + } + ); + systems = [ "cl-ana.statistical-learning" ]; + lispLibs = [ + (getAttr "cl-ana_dot_functional-utils" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_histogram" self) + (getAttr "cl-ana_dot_linear-algebra" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_map" self) + (getAttr "cl-ana_dot_math-functions" self) + (getAttr "cl-ana_dot_statistics" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_statistics = ( + build-asdf-system { + pname = "cl-ana.statistics"; + version = "20220707-git"; + asds = [ "cl-ana.statistics" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.statistics"; + asd = "cl-ana.statistics"; + } + ); + systems = [ "cl-ana.statistics" ]; + lispLibs = [ + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_histogram" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_map" self) + (getAttr "cl-ana_dot_math-functions" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_string-utils = ( + build-asdf-system { + pname = "cl-ana.string-utils"; + version = "20220707-git"; + asds = [ "cl-ana.string-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.string-utils"; + asd = "cl-ana.string-utils"; + } + ); + systems = [ "cl-ana.string-utils" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_symbol-utils = ( + build-asdf-system { + pname = "cl-ana.symbol-utils"; + version = "20220707-git"; + asds = [ "cl-ana.symbol-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.symbol-utils"; + asd = "cl-ana.symbol-utils"; + } + ); + systems = [ "cl-ana.symbol-utils" ]; + lispLibs = [ (getAttr "cl-ana_dot_list-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_table = ( + build-asdf-system { + pname = "cl-ana.table"; + version = "20220707-git"; + asds = [ "cl-ana.table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.table"; + asd = "cl-ana.table"; + } + ); + systems = [ "cl-ana.table" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_functional-utils" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_string-utils" self) + (getAttr "cl-ana_dot_symbol-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_table-utils = ( + build-asdf-system { + pname = "cl-ana.table-utils"; + version = "20220707-git"; + asds = [ "cl-ana.table-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.table-utils"; + asd = "cl-ana.table-utils"; + } + ); + systems = [ "cl-ana.table-utils" ]; + lispLibs = [ + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_hash-table-utils" self) + (getAttr "cl-ana_dot_statistics" self) + (getAttr "cl-ana_dot_string-utils" self) + (getAttr "cl-ana_dot_symbol-utils" self) + (getAttr "cl-ana_dot_table" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_table-viewing = ( + build-asdf-system { + pname = "cl-ana.table-viewing"; + version = "20220707-git"; + asds = [ "cl-ana.table-viewing" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.table-viewing"; + asd = "cl-ana.table-viewing"; + } + ); + systems = [ "cl-ana.table-viewing" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_histogram" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_plotting" self) + (getAttr "cl-ana_dot_string-utils" self) + (getAttr "cl-ana_dot_table" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_tensor = ( + build-asdf-system { + pname = "cl-ana.tensor"; + version = "20220707-git"; + asds = [ "cl-ana.tensor" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.tensor"; + asd = "cl-ana.tensor"; + } + ); + systems = [ "cl-ana.tensor" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_generic-math" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_macro-utils" self) + (getAttr "cl-ana_dot_symbol-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_typed-table = ( + build-asdf-system { + pname = "cl-ana.typed-table"; + version = "20220707-git"; + asds = [ "cl-ana.typed-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.typed-table"; + asd = "cl-ana.typed-table"; + } + ); + systems = [ "cl-ana.typed-table" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_string-utils" self) + (getAttr "cl-ana_dot_symbol-utils" self) + (getAttr "cl-ana_dot_table" self) + (getAttr "cl-ana_dot_typespec" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ana_dot_typespec = ( + build-asdf-system { + pname = "cl-ana.typespec"; + version = "20220707-git"; + asds = [ "cl-ana.typespec" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ana/2022-07-07/cl-ana-20220707-git.tgz"; + sha256 = "1dg8wkc2bv66lykr2fjgn91jw7aa9xnpk20h0g8pp2xr6981gfl9"; + system = "cl-ana.typespec"; + asd = "cl-ana.typespec"; + } + ); + systems = [ "cl-ana.typespec" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-ana_dot_int-char" self) + (getAttr "cl-ana_dot_list-utils" self) + (getAttr "cl-ana_dot_memoization" self) + (getAttr "cl-ana_dot_string-utils" self) + (getAttr "cl-ana_dot_symbol-utils" self) + (getAttr "cl-ana_dot_tensor" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-android = ( + build-asdf-system { + pname = "cl-android"; + version = "20150804-git"; + asds = [ "cl-android" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sl4a/2015-08-04/cl-sl4a-20150804-git.tgz"; + sha256 = "0lqla60apkc8xfiyi43w18dldf0m8z5q290wv3d89qf0n9gwk3cr"; + system = "cl-android"; + asd = "cl-android"; + } + ); + systems = [ "cl-android" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-annot = ( + build-asdf-system { + pname = "cl-annot"; + version = "20150608-git"; + asds = [ "cl-annot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-annot/2015-06-08/cl-annot-20150608-git.tgz"; + sha256 = "1wq1gs9jjd5m6iwrv06c2d7i5dvqsfjcljgbspfbc93cg5xahk4n"; + system = "cl-annot"; + asd = "cl-annot"; + } + ); + systems = [ "cl-annot" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { }; + } + ); + cl-annot-prove = ( + build-asdf-system { + pname = "cl-annot-prove"; + version = "20150923-git"; + asds = [ "cl-annot-prove" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-annot-prove/2015-09-23/cl-annot-prove-20150923-git.tgz"; + sha256 = "000nlxxs1id1pccp3y5s9xnm76fc5r87q0bxmjrpklxwwf5y8wwy"; + system = "cl-annot-prove"; + asd = "cl-annot-prove"; + } + ); + systems = [ "cl-annot-prove" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-syntax" self) + (getAttr "cl-syntax-annot" self) + (getAttr "prove" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-annot-prove-test = ( + build-asdf-system { + pname = "cl-annot-prove-test"; + version = "20150923-git"; + asds = [ "cl-annot-prove-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-annot-prove/2015-09-23/cl-annot-prove-20150923-git.tgz"; + sha256 = "000nlxxs1id1pccp3y5s9xnm76fc5r87q0bxmjrpklxwwf5y8wwy"; + system = "cl-annot-prove-test"; + asd = "cl-annot-prove-test"; + } + ); + systems = [ "cl-annot-prove-test" ]; + lispLibs = [ + (getAttr "cl-annot-prove" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-annot-revisit = ( + build-asdf-system { + pname = "cl-annot-revisit"; + version = "20221106-git"; + asds = [ "cl-annot-revisit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-annot-revisit/2022-11-06/cl-annot-revisit-20221106-git.tgz"; + sha256 = "0jlllgq14bi1rddzlmq9wfs4vb24apgqz17wfd79kjjcmnzzjp4m"; + system = "cl-annot-revisit"; + asd = "cl-annot-revisit"; + } + ); + systems = [ "cl-annot-revisit" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-annot-revisit-compat = ( + build-asdf-system { + pname = "cl-annot-revisit-compat"; + version = "20221106-git"; + asds = [ "cl-annot-revisit-compat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-annot-revisit/2022-11-06/cl-annot-revisit-20221106-git.tgz"; + sha256 = "0jlllgq14bi1rddzlmq9wfs4vb24apgqz17wfd79kjjcmnzzjp4m"; + system = "cl-annot-revisit-compat"; + asd = "cl-annot-revisit-compat"; + } + ); + systems = [ "cl-annot-revisit-compat" ]; + lispLibs = [ (getAttr "cl-annot-revisit" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-annot-revisit-test = ( + build-asdf-system { + pname = "cl-annot-revisit-test"; + version = "20221106-git"; + asds = [ "cl-annot-revisit-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-annot-revisit/2022-11-06/cl-annot-revisit-20221106-git.tgz"; + sha256 = "0jlllgq14bi1rddzlmq9wfs4vb24apgqz17wfd79kjjcmnzzjp4m"; + system = "cl-annot-revisit-test"; + asd = "cl-annot-revisit-test"; + } + ); + systems = [ "cl-annot-revisit-test" ]; + lispLibs = [ + (getAttr "_1am" self) + (getAttr "cl-annot-revisit" self) + (getAttr "cl-annot-revisit-compat" self) + (getAttr "trivial-macroexpand-all" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-anonfun = ( + build-asdf-system { + pname = "cl-anonfun"; + version = "20111203-git"; + asds = [ "cl-anonfun" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-anonfun/2011-12-03/cl-anonfun-20111203-git.tgz"; + sha256 = "086x2vjvasdy9bhikvdzx34nrq008c0sfkq3ncv0i9mhfk5xwp2j"; + system = "cl-anonfun"; + asd = "cl-anonfun"; + } + ); + systems = [ "cl-anonfun" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-ansi-term = ( + build-asdf-system { + pname = "cl-ansi-term"; + version = "20241012-git"; + asds = [ "cl-ansi-term" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ansi-term/2024-10-12/cl-ansi-term-20241012-git.tgz"; + sha256 = "01nrlyb8lqca9z16ndlyy22wqy83ixcr02yibfypj255x6xbql1x"; + system = "cl-ansi-term"; + asd = "cl-ansi-term"; + } + ); + systems = [ "cl-ansi-term" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ansi-text = ( + build-asdf-system { + pname = "cl-ansi-text"; + version = "20211020-git"; + asds = [ "cl-ansi-text" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ansi-text/2021-10-20/cl-ansi-text-20211020-git.tgz"; + sha256 = "0nk7ajqfa937w1iy3zy86jjbw8yffm05cqs4wxkgl97v6kmmya14"; + system = "cl-ansi-text"; + asd = "cl-ansi-text"; + } + ); + systems = [ "cl-ansi-text" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-colors2" self) + ]; + meta = { }; + } + ); + cl-ansi-text_dot_test = ( + build-asdf-system { + pname = "cl-ansi-text.test"; + version = "20211020-git"; + asds = [ "cl-ansi-text.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ansi-text/2021-10-20/cl-ansi-text-20211020-git.tgz"; + sha256 = "0nk7ajqfa937w1iy3zy86jjbw8yffm05cqs4wxkgl97v6kmmya14"; + system = "cl-ansi-text.test"; + asd = "cl-ansi-text.test"; + } + ); + systems = [ "cl-ansi-text.test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ansi-text" self) + (getAttr "cl-colors2" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-apertium-stream = ( + build-asdf-system { + pname = "cl-apertium-stream"; + version = "20230618-git"; + asds = [ "cl-apertium-stream" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-apertium-stream-parser/2023-06-18/cl-apertium-stream-parser-20230618-git.tgz"; + sha256 = "1f3v5pgar83iw443haa4nlzy1qvr55xxqggq9klvsji1a3jdypqy"; + system = "cl-apertium-stream"; + asd = "cl-apertium-stream"; + } + ); + systems = [ "cl-apertium-stream" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "esrap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-apple-plist = ( + build-asdf-system { + pname = "cl-apple-plist"; + version = "20111105-git"; + asds = [ "cl-apple-plist" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-apple-plist/2011-11-05/cl-apple-plist-20111105-git.tgz"; + sha256 = "104j5lvvp7apdx59kbwc6kpa8b82y20w03627ml91lpbqk9bq63f"; + system = "cl-apple-plist"; + asd = "cl-apple-plist"; + } + ); + systems = [ "cl-apple-plist" ]; + lispLibs = [ (getAttr "html-encode" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-arff-parser = ( + build-asdf-system { + pname = "cl-arff-parser"; + version = "20130421-git"; + asds = [ "cl-arff-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-arff-parser/2013-04-21/cl-arff-parser-20130421-git.tgz"; + sha256 = "0rn76r48b2y2richfy3si4r8kbwkvm7q15g34sxi0fkfmx15z4jx"; + system = "cl-arff-parser"; + asd = "cl-arff-parser"; + } + ); + systems = [ "cl-arff-parser" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-argparse = ( + build-asdf-system { + pname = "cl-argparse"; + version = "20210531-git"; + asds = [ "cl-argparse" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-argparse/2021-05-31/cl-argparse-20210531-git.tgz"; + sha256 = "05vy2iaqr7yiaw0ykzwm0ml0mil5qagy87b8hqx4vvb3lq1qpn14"; + system = "cl-argparse"; + asd = "cl-argparse"; + } + ); + systems = [ "cl-argparse" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-aristid = ( + build-asdf-system { + pname = "cl-aristid"; + version = "20200925-git"; + asds = [ "cl-aristid" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-aristid/2020-09-25/cl-aristid-20200925-git.tgz"; + sha256 = "0k573k3wydy6dd5pmvqdxmlwk0n5kq2wsk86syddhqyjgx2jmw98"; + system = "cl-aristid"; + asd = "cl-aristid"; + } + ); + systems = [ "cl-aristid" ]; + lispLibs = [ + (getAttr "cl-colors" self) + (getAttr "cl-svg" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-arxiv-api = ( + build-asdf-system { + pname = "cl-arxiv-api"; + version = "20170403-git"; + asds = [ "cl-arxiv-api" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-arxiv-api/2017-04-03/cl-arxiv-api-20170403-git.tgz"; + sha256 = "1id95gszqxmmjydv1vjv2vyxz0svqvnx74bmgy63xnajb4kfnpq3"; + system = "cl-arxiv-api"; + asd = "cl-arxiv-api"; + } + ); + systems = [ "cl-arxiv-api" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "cxml" self) + (getAttr "iterate" self) + (getAttr "trivial-http" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ascii-art = ( + build-asdf-system { + pname = "cl-ascii-art"; + version = "20171019-git"; + asds = [ "cl-ascii-art" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ascii-art/2017-10-19/cl-ascii-art-20171019-git.tgz"; + sha256 = "03d3bd8m7dd2l4170vky8y8ini3giqhjpd06rlswz287mkvzq8aa"; + system = "cl-ascii-art"; + asd = "cl-ascii-art"; + } + ); + systems = [ "cl-ascii-art" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ansi-text" self) + (getAttr "cl-ppcre" self) + (getAttr "inferior-shell" self) + (getAttr "iterate" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ascii-table = ( + build-asdf-system { + pname = "cl-ascii-table"; + version = "20200610-git"; + asds = [ "cl-ascii-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ascii-table/2020-06-10/cl-ascii-table-20200610-git.tgz"; + sha256 = "1nclyypd2p06hyfydcv16m9lbj1xmrpmf00wp8mfyhwimv021zlp"; + system = "cl-ascii-table"; + asd = "cl-ascii-table"; + } + ); + systems = [ "cl-ascii-table" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-aseprite = ( + build-asdf-system { + pname = "cl-aseprite"; + version = "20241012-git"; + asds = [ "cl-aseprite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-aseprite/2024-10-12/cl-aseprite-20241012-git.tgz"; + sha256 = "0xjrfi232d0my4ncafp1l2yfas8nj0k8nsbppkq70anic5ihbhch"; + system = "cl-aseprite"; + asd = "cl-aseprite"; + } + ); + systems = [ "cl-aseprite" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "chipz" self) + (getAttr "let-plus" self) + (getAttr "lisp-binary" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-association-rules = ( + build-asdf-system { + pname = "cl-association-rules"; + version = "20170403-git"; + asds = [ "cl-association-rules" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-association-rules/2017-04-03/cl-association-rules-20170403-git.tgz"; + sha256 = "1d4sg9j30ydk1m17byacww8l2x9ggb82iay507g08ij0jxdky86z"; + system = "cl-association-rules"; + asd = "cl-association-rules"; + } + ); + systems = [ "cl-association-rules" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-association-rules-tests = ( + build-asdf-system { + pname = "cl-association-rules-tests"; + version = "20170403-git"; + asds = [ "cl-association-rules-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-association-rules/2017-04-03/cl-association-rules-20170403-git.tgz"; + sha256 = "1d4sg9j30ydk1m17byacww8l2x9ggb82iay507g08ij0jxdky86z"; + system = "cl-association-rules-tests"; + asd = "cl-association-rules"; + } + ); + systems = [ "cl-association-rules-tests" ]; + lispLibs = [ + (getAttr "cl-association-rules" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-astar = ( + build-asdf-system { + pname = "cl-astar"; + version = "20241012-git"; + asds = [ "cl-astar" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-astar/2024-10-12/cl-astar-20241012-git.tgz"; + sha256 = "0fdwyg3xnj5sxn4cqycydg0cp1l3ii0brk7ad1sh28m703zmndxv"; + system = "cl-astar"; + asd = "cl-astar"; + } + ); + systems = [ "cl-astar" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "float-features" self) + (getAttr "let-plus" self) + (getAttr "trivial-adjust-simple-array" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-async = ( + build-asdf-system { + pname = "cl-async"; + version = "20241012-git"; + asds = [ "cl-async" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-async/2024-10-12/cl-async-20241012-git.tgz"; + sha256 = "0z0gnwfb0flrxpbjmvzap0kmyz8r898x5jriyna365plc50hlcdr"; + system = "cl-async"; + asd = "cl-async"; + } + ); + systems = [ "cl-async" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "cl-async-base" self) + (getAttr "cl-async-util" self) + (getAttr "cl-libuv" self) + (getAttr "cl-ppcre" self) + (getAttr "static-vectors" self) + (getAttr "trivial-features" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + cl-async-await = ( + build-asdf-system { + pname = "cl-async-await"; + version = "20201016-git"; + asds = [ "cl-async-await" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-async-await/2020-10-16/cl-async-await-20201016-git.tgz"; + sha256 = "1slhn9z4hljvad3hd8jmvw4q4m6310s04yh3212wvbfar8q0yasj"; + system = "cl-async-await"; + asd = "cl-async-await"; + } + ); + systems = [ "cl-async-await" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "simple-actors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-async-base = ( + build-asdf-system { + pname = "cl-async-base"; + version = "20241012-git"; + asds = [ "cl-async-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-async/2024-10-12/cl-async-20241012-git.tgz"; + sha256 = "0z0gnwfb0flrxpbjmvzap0kmyz8r898x5jriyna365plc50hlcdr"; + system = "cl-async-base"; + asd = "cl-async"; + } + ); + systems = [ "cl-async-base" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cl-libuv" self) + ]; + meta = { }; + } + ); + cl-async-future = ( + build-asdf-system { + pname = "cl-async-future"; + version = "20150113-git"; + asds = [ "cl-async-future" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-async-future/2015-01-13/cl-async-future-20150113-git.tgz"; + sha256 = "0z0sc7qlzzxk99f4l26zp6rai9kv0kj0f599sxai5s44p17zbbvh"; + system = "cl-async-future"; + asd = "cl-async-future"; + } + ); + systems = [ "cl-async-future" ]; + lispLibs = [ (getAttr "blackbird" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-async-repl = ( + build-asdf-system { + pname = "cl-async-repl"; + version = "20241012-git"; + asds = [ "cl-async-repl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-async/2024-10-12/cl-async-20241012-git.tgz"; + sha256 = "0z0gnwfb0flrxpbjmvzap0kmyz8r898x5jriyna365plc50hlcdr"; + system = "cl-async-repl"; + asd = "cl-async-repl"; + } + ); + systems = [ "cl-async-repl" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-async" self) + ]; + meta = { }; + } + ); + cl-async-ssl = ( + build-asdf-system { + pname = "cl-async-ssl"; + version = "20241012-git"; + asds = [ "cl-async-ssl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-async/2024-10-12/cl-async-20241012-git.tgz"; + sha256 = "0z0gnwfb0flrxpbjmvzap0kmyz8r898x5jriyna365plc50hlcdr"; + system = "cl-async-ssl"; + asd = "cl-async-ssl"; + } + ); + systems = [ "cl-async-ssl" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-async" self) + (getAttr "vom" self) + ]; + meta = { }; + } + ); + cl-async-test = ( + build-asdf-system { + pname = "cl-async-test"; + version = "20241012-git"; + asds = [ "cl-async-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-async/2024-10-12/cl-async-20241012-git.tgz"; + sha256 = "0z0gnwfb0flrxpbjmvzap0kmyz8r898x5jriyna365plc50hlcdr"; + system = "cl-async-test"; + asd = "cl-async-test"; + } + ); + systems = [ "cl-async-test" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cl-async" self) + (getAttr "cl-async-ssl" self) + (getAttr "fiveam" self) + (getAttr "flexi-streams" self) + (getAttr "ironclad" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-async-util = ( + build-asdf-system { + pname = "cl-async-util"; + version = "20241012-git"; + asds = [ "cl-async-util" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-async/2024-10-12/cl-async-20241012-git.tgz"; + sha256 = "0z0gnwfb0flrxpbjmvzap0kmyz8r898x5jriyna365plc50hlcdr"; + system = "cl-async-util"; + asd = "cl-async"; + } + ); + systems = [ "cl-async-util" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-async-base" self) + (getAttr "cl-libuv" self) + (getAttr "cl-ppcre" self) + (getAttr "fast-io" self) + (getAttr "vom" self) + ]; + meta = { }; + } + ); + cl-aubio = ( + build-asdf-system { + pname = "cl-aubio"; + version = "20200427-git"; + asds = [ "cl-aubio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-aubio/2020-04-27/cl-aubio-20200427-git.tgz"; + sha256 = "1xyflxy46z4487dbnizhv058y2mdka9iyikl097m60w42blidpn3"; + system = "cl-aubio"; + asd = "cl-aubio"; + } + ); + systems = [ "cl-aubio" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-authorize-net = ( + build-asdf-system { + pname = "cl-authorize-net"; + version = "20150113-git"; + asds = [ "cl-authorize-net" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-creditcard/2015-01-13/cl-creditcard-20150113-git.tgz"; + sha256 = "1qq9r7q50k7jw6sv65aqi9xalaw8m6aqsbb0cgpjxv8wdhy934cr"; + system = "cl-authorize-net"; + asd = "cl-authorize-net"; + } + ); + systems = [ "cl-authorize-net" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-creditcard" self) + (getAttr "drakma" self) + (getAttr "split-sequence" self) + (getAttr "symbol-munger" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-authorize-net-tests = ( + build-asdf-system { + pname = "cl-authorize-net-tests"; + version = "20150113-git"; + asds = [ "cl-authorize-net-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-creditcard/2015-01-13/cl-creditcard-20150113-git.tgz"; + sha256 = "1qq9r7q50k7jw6sv65aqi9xalaw8m6aqsbb0cgpjxv8wdhy934cr"; + system = "cl-authorize-net-tests"; + asd = "cl-authorize-net"; + } + ); + systems = [ "cl-authorize-net-tests" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-authorize-net" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-autorepo = ( + build-asdf-system { + pname = "cl-autorepo"; + version = "20180711-git"; + asds = [ "cl-autorepo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-autorepo/2018-07-11/cl-autorepo-20180711-git.tgz"; + sha256 = "01hpg3r3493mri44kxp8sjy8i5kfvjklmnksvm0727i6bhpf8cz9"; + system = "cl-autorepo"; + asd = "cl-autorepo"; + } + ); + systems = [ "cl-autorepo" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-autowrap = ( + build-asdf-system { + pname = "cl-autowrap"; + version = "20241012-git"; + asds = [ "cl-autowrap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-autowrap/2024-10-12/cl-autowrap-20241012-git.tgz"; + sha256 = "1sfvhyrwm9dhxi0y42xp7mx8mvs6lmq3bzxdx34frxni5srcgly0"; + system = "cl-autowrap"; + asd = "cl-autowrap"; + } + ); + systems = [ "cl-autowrap" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "defpackage-plus" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-autowrap-test = ( + build-asdf-system { + pname = "cl-autowrap-test"; + version = "20241012-git"; + asds = [ "cl-autowrap-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-autowrap/2024-10-12/cl-autowrap-20241012-git.tgz"; + sha256 = "1sfvhyrwm9dhxi0y42xp7mx8mvs6lmq3bzxdx34frxni5srcgly0"; + system = "cl-autowrap-test"; + asd = "cl-autowrap-test"; + } + ); + systems = [ "cl-autowrap-test" ]; + lispLibs = [ (getAttr "cl-autowrap" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-azure = ( + build-asdf-system { + pname = "cl-azure"; + version = "20160825-git"; + asds = [ "cl-azure" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-azure/2016-08-25/cl-azure-20160825-git.tgz"; + sha256 = "19sgzbvgs1f1h3qhx11xhpia2x3n8x729h9fsqkc7fap0ak1h31d"; + system = "cl-azure"; + asd = "cl-azure"; + } + ); + systems = [ "cl-azure" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-base64" self) + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "cxml" self) + (getAttr "drakma" self) + (getAttr "ironclad" self) + (getAttr "puri" self) + (getAttr "rt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-base16 = ( + build-asdf-system { + pname = "cl-base16"; + version = "20200925-git"; + asds = [ "cl-base16" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-base16/2020-09-25/cl-base16-20200925-git.tgz"; + sha256 = "0m7ndmk4xhizn3q3ywjvw8sg4pfgp6lrd0wac5d1bf7wbw6afh5q"; + system = "cl-base16"; + asd = "cl-base16"; + } + ); + systems = [ "cl-base16" ]; + lispLibs = [ + (getAttr "cl-mustache" self) + (getAttr "cl-slug" self) + (getAttr "cl-yaml" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-base32 = ( + build-asdf-system { + pname = "cl-base32"; + version = "20241012-git"; + asds = [ "cl-base32" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-base32/2024-10-12/cl-base32-20241012-git.tgz"; + sha256 = "0kc0rxwx2ak5kvrzl8y8x3csm0d6appi5k0as2jgm3ig5vgcs5cn"; + system = "cl-base32"; + asd = "cl-base32"; + } + ); + systems = [ "cl-base32" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-base58 = ( + build-asdf-system { + pname = "cl-base58"; + version = "20150113-git"; + asds = [ "cl-base58" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-base58/2015-01-13/cl-base58-20150113-git.tgz"; + sha256 = "01wiiyz1jzxx3zhxi2hpq5n8hv28g1mn0adk793vwjzh4v5bi5zz"; + system = "cl-base58"; + asd = "cl-base58"; + } + ); + systems = [ "cl-base58" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-base58-test = ( + build-asdf-system { + pname = "cl-base58-test"; + version = "20150113-git"; + asds = [ "cl-base58-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-base58/2015-01-13/cl-base58-20150113-git.tgz"; + sha256 = "01wiiyz1jzxx3zhxi2hpq5n8hv28g1mn0adk793vwjzh4v5bi5zz"; + system = "cl-base58-test"; + asd = "cl-base58-test"; + } + ); + systems = [ "cl-base58-test" ]; + lispLibs = [ + (getAttr "cl-base58" self) + (getAttr "cl-test-more" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-base64 = ( + build-asdf-system { + pname = "cl-base64"; + version = "20201016-git"; + asds = [ "cl-base64" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-base64/2020-10-16/cl-base64-20201016-git.tgz"; + sha256 = "12jj54h0fs6n237cvnp8v6hn0imfksammq22ys6pi0gwz2w47rbj"; + system = "cl-base64"; + asd = "cl-base64"; + } + ); + systems = [ "cl-base64" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-bayesnet = ( + build-asdf-system { + pname = "cl-bayesnet"; + version = "20130420-git"; + asds = [ "cl-bayesnet" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bayesnet/2013-04-20/cl-bayesnet-20130420-git.tgz"; + sha256 = "02as2isvgm89qpyj49ccs1cg4fl9iswxi26w4j0svsha0q1dh5m8"; + system = "cl-bayesnet"; + asd = "cl-bayesnet"; + } + ); + systems = [ "cl-bayesnet" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "s-xml" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bcrypt = ( + build-asdf-system { + pname = "cl-bcrypt"; + version = "20231021-git"; + asds = [ "cl-bcrypt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bcrypt/2023-10-21/cl-bcrypt-20231021-git.tgz"; + sha256 = "0mfs1jwf1xi6za61hfc7dgf1g5lqqsqdclnnspncvdg6l137013n"; + system = "cl-bcrypt"; + asd = "cl-bcrypt"; + } + ); + systems = [ "cl-bcrypt" ]; + lispLibs = [ + (getAttr "binascii" self) + (getAttr "cl-ppcre" self) + (getAttr "ironclad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bcrypt_dot_test = ( + build-asdf-system { + pname = "cl-bcrypt.test"; + version = "20231021-git"; + asds = [ "cl-bcrypt.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bcrypt/2023-10-21/cl-bcrypt-20231021-git.tgz"; + sha256 = "0mfs1jwf1xi6za61hfc7dgf1g5lqqsqdclnnspncvdg6l137013n"; + system = "cl-bcrypt.test"; + asd = "cl-bcrypt.test"; + } + ); + systems = [ "cl-bcrypt.test" ]; + lispLibs = [ + (getAttr "cl-bcrypt" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-beanstalk = ( + build-asdf-system { + pname = "cl-beanstalk"; + version = "20220707-git"; + asds = [ "cl-beanstalk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-beanstalk/2022-07-07/cl-beanstalk-20220707-git.tgz"; + sha256 = "0vca8dw2l765m7g7xcpzi80m8f3145hhshh8ym602336fhiz61q1"; + system = "cl-beanstalk"; + asd = "cl-beanstalk"; + } + ); + systems = [ "cl-beanstalk" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "split-sequence" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bip39 = ( + build-asdf-system { + pname = "cl-bip39"; + version = "20180711-git"; + asds = [ "cl-bip39" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bip39/2018-07-11/cl-bip39-20180711-git.tgz"; + sha256 = "04h4lhppvavvqknp11gaj4ka2wpn9i883w1w27llblkg2vnn0816"; + system = "cl-bip39"; + asd = "cl-bip39"; + } + ); + systems = [ "cl-bip39" ]; + lispLibs = [ + (getAttr "ironclad" self) + (getAttr "secure-random" self) + (getAttr "split-sequence" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bloggy = ( + build-asdf-system { + pname = "cl-bloggy"; + version = "20211020-git"; + asds = [ "cl-bloggy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bloggy/2021-10-20/cl-bloggy-20211020-git.tgz"; + sha256 = "1clz2a0s3g3jbsrpypb4byb432l0yb4658riqs6ckin57c4bzxc8"; + system = "cl-bloggy"; + asd = "cl-bloggy"; + } + ); + systems = [ "cl-bloggy" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "do-urlencode" self) + (getAttr "hunchentoot" self) + (getAttr "lass" self) + (getAttr "local-time" self) + (getAttr "lorem-ipsum" self) + (getAttr "spinneret" self) + (getAttr "str" self) + (getAttr "xml-emitter" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bloom = ( + build-asdf-system { + pname = "cl-bloom"; + version = "20180228-git"; + asds = [ "cl-bloom" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bloom/2018-02-28/cl-bloom-20180228-git.tgz"; + sha256 = "1ircc5sa0a2xlx0fca0is6inwrk311hbj8jx6r4sas5pfv78k4am"; + system = "cl-bloom"; + asd = "cl-bloom"; + } + ); + systems = [ "cl-bloom" ]; + lispLibs = [ + (getAttr "cl-murmurhash" self) + (getAttr "static-vectors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bloom-filter = ( + build-asdf-system { + pname = "cl-bloom-filter"; + version = "20221106-git"; + asds = [ "cl-bloom-filter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bloom-filter/2022-11-06/cl-bloom-filter-20221106-git.tgz"; + sha256 = "1s9m617fh3krh2klc2nx7jf89nk43cvvrnvqrhvw9jprw7gqanvq"; + system = "cl-bloom-filter"; + asd = "cl-bloom-filter"; + } + ); + systems = [ "cl-bloom-filter" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bmp = ( + build-asdf-system { + pname = "cl-bmp"; + version = "20241012-git"; + asds = [ "cl-bmp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bmp/2024-10-12/cl-bmp-20241012-git.tgz"; + sha256 = "1mcayxjppka40q9xx1qwdvrjjblclnggnicg70i95xqnv5sdwdhz"; + system = "cl-bmp"; + asd = "cl-bmp"; + } + ); + systems = [ "cl-bmp" ]; + lispLibs = [ + (getAttr "binary-structures" self) + (getAttr "documentation-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bnf = ( + build-asdf-system { + pname = "cl-bnf"; + version = "20241012-git"; + asds = [ "cl-bnf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bnf/2024-10-12/cl-bnf-20241012-git.tgz"; + sha256 = "0aa7hnkj71f37lxzlhsppwcmk3yv42hclq08c4jrdnv8jmdb8r0l"; + system = "cl-bnf"; + asd = "cl-bnf"; + } + ); + systems = [ "cl-bnf" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "utf8-input-stream" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bnf-examples = ( + build-asdf-system { + pname = "cl-bnf-examples"; + version = "20241012-git"; + asds = [ "cl-bnf-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bnf/2024-10-12/cl-bnf-20241012-git.tgz"; + sha256 = "0aa7hnkj71f37lxzlhsppwcmk3yv42hclq08c4jrdnv8jmdb8r0l"; + system = "cl-bnf-examples"; + asd = "cl-bnf-examples"; + } + ); + systems = [ "cl-bnf-examples" ]; + lispLibs = [ (getAttr "cl-bnf" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bnf-tests = ( + build-asdf-system { + pname = "cl-bnf-tests"; + version = "20241012-git"; + asds = [ "cl-bnf-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bnf/2024-10-12/cl-bnf-20241012-git.tgz"; + sha256 = "0aa7hnkj71f37lxzlhsppwcmk3yv42hclq08c4jrdnv8jmdb8r0l"; + system = "cl-bnf-tests"; + asd = "cl-bnf-tests"; + } + ); + systems = [ "cl-bnf-tests" ]; + lispLibs = [ + (getAttr "cl-bnf" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bootstrap = ( + build-asdf-system { + pname = "cl-bootstrap"; + version = "20180831-git"; + asds = [ "cl-bootstrap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bootstrap/2018-08-31/cl-bootstrap-20180831-git.tgz"; + sha256 = "0pk7wx4arsljxlnbx1hzcgxwsvhdp3gn22wv43xls2jv1rdi2xry"; + system = "cl-bootstrap"; + asd = "cl-bootstrap"; + } + ); + systems = [ "cl-bootstrap" ]; + lispLibs = [ + (getAttr "cl-who" self) + (getAttr "parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bootstrap-demo = ( + build-asdf-system { + pname = "cl-bootstrap-demo"; + version = "20180831-git"; + asds = [ "cl-bootstrap-demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bootstrap/2018-08-31/cl-bootstrap-20180831-git.tgz"; + sha256 = "0pk7wx4arsljxlnbx1hzcgxwsvhdp3gn22wv43xls2jv1rdi2xry"; + system = "cl-bootstrap-demo"; + asd = "cl-bootstrap-demo"; + } + ); + systems = [ "cl-bootstrap-demo" ]; + lispLibs = [ + (getAttr "cl-bootstrap" self) + (getAttr "cl-who" self) + (getAttr "hunchentoot" self) + (getAttr "parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bootstrap-test = ( + build-asdf-system { + pname = "cl-bootstrap-test"; + version = "20180831-git"; + asds = [ "cl-bootstrap-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bootstrap/2018-08-31/cl-bootstrap-20180831-git.tgz"; + sha256 = "0pk7wx4arsljxlnbx1hzcgxwsvhdp3gn22wv43xls2jv1rdi2xry"; + system = "cl-bootstrap-test"; + asd = "cl-bootstrap-test"; + } + ); + systems = [ "cl-bootstrap-test" ]; + lispLibs = [ + (getAttr "cl-bootstrap" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bplustree = ( + build-asdf-system { + pname = "cl-bplustree"; + version = "20180328-git"; + asds = [ "cl-bplustree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bplustree/2018-03-28/cl-bplustree-20180328-git.tgz"; + sha256 = "1d9pm9fi9bhh73bhcgig0wq5i4fvc4551kxvny3di6x6yr7j2kbl"; + system = "cl-bplustree"; + asd = "cl-bplustree"; + } + ); + systems = [ "cl-bplustree" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bplustree-test = ( + build-asdf-system { + pname = "cl-bplustree-test"; + version = "20180328-git"; + asds = [ "cl-bplustree-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bplustree/2018-03-28/cl-bplustree-20180328-git.tgz"; + sha256 = "1d9pm9fi9bhh73bhcgig0wq5i4fvc4551kxvny3di6x6yr7j2kbl"; + system = "cl-bplustree-test"; + asd = "cl-bplustree"; + } + ); + systems = [ "cl-bplustree-test" ]; + lispLibs = [ (getAttr "cl-bplustree" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-brewer-ci = ( + build-asdf-system { + pname = "cl-brewer-ci"; + version = "20241012-git"; + asds = [ "cl-brewer-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-brewer/2024-10-12/cl-brewer-20241012-git.tgz"; + sha256 = "0izf6v4qx82jhk7ln28jhdmnr3lb0r5iqjj0by9igq5sk3y1my4x"; + system = "cl-brewer-ci"; + asd = "cl-brewer-ci"; + } + ); + systems = [ "cl-brewer-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-brewer-deploy-hooks = ( + build-asdf-system { + pname = "cl-brewer-deploy-hooks"; + version = "20241012-git"; + asds = [ "cl-brewer-deploy-hooks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-brewer/2024-10-12/cl-brewer-20241012-git.tgz"; + sha256 = "0izf6v4qx82jhk7ln28jhdmnr3lb0r5iqjj0by9igq5sk3y1my4x"; + system = "cl-brewer-deploy-hooks"; + asd = "cl-brewer-deploy-hooks"; + } + ); + systems = [ "cl-brewer-deploy-hooks" ]; + lispLibs = [ (getAttr "deploy" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-brewer-tests = ( + build-asdf-system { + pname = "cl-brewer-tests"; + version = "20241012-git"; + asds = [ "cl-brewer-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-brewer/2024-10-12/cl-brewer-20241012-git.tgz"; + sha256 = "0izf6v4qx82jhk7ln28jhdmnr3lb0r5iqjj0by9igq5sk3y1my4x"; + system = "cl-brewer-tests"; + asd = "cl-brewer-tests"; + } + ); + systems = [ "cl-brewer-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-buchberger = ( + build-asdf-system { + pname = "cl-buchberger"; + version = "20241012-git"; + asds = [ "cl-buchberger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-buchberger/2024-10-12/cl-buchberger-20241012-git.tgz"; + sha256 = "0hn340y52xfgj788zh449jrh7blfv6yqfnkmqg2vghy92s8jcr1i"; + system = "cl-buchberger"; + asd = "cl-buchberger"; + } + ); + systems = [ "cl-buchberger" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-bus = ( + build-asdf-system { + pname = "cl-bus"; + version = "20211209-git"; + asds = [ "cl-bus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-bus/2021-12-09/cl-bus-20211209-git.tgz"; + sha256 = "1galzqm1qv2slibn3awfyxnmlslxmzw09a8fidmbdy1r0ppp5r7z"; + system = "cl-bus"; + asd = "cl-bus"; + } + ); + systems = [ "cl-bus" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ca = ( + build-asdf-system { + pname = "cl-ca"; + version = "20161204-git"; + asds = [ "cl-ca" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ca/2016-12-04/cl-ca-20161204-git.tgz"; + sha256 = "0kpwpxw3c8q7b2ajyj9rzhs1r1h6kipdm9qjkgsn0sqrmx9acfnz"; + system = "cl-ca"; + asd = "cl-ca"; + } + ); + systems = [ "cl-ca" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cache-tables = ( + build-asdf-system { + pname = "cl-cache-tables"; + version = "20171019-git"; + asds = [ "cl-cache-tables" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cache-tables/2017-10-19/cl-cache-tables-20171019-git.tgz"; + sha256 = "008m7v39mq2475y1f4if5iazb15rm02g22id4q4qgig1zx2vfpg1"; + system = "cl-cache-tables"; + asd = "cl-cache-tables"; + } + ); + systems = [ "cl-cache-tables" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cache-tables-tests = ( + build-asdf-system { + pname = "cl-cache-tables-tests"; + version = "20171019-git"; + asds = [ "cl-cache-tables-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cache-tables/2017-10-19/cl-cache-tables-20171019-git.tgz"; + sha256 = "008m7v39mq2475y1f4if5iazb15rm02g22id4q4qgig1zx2vfpg1"; + system = "cl-cache-tables-tests"; + asd = "cl-cache-tables"; + } + ); + systems = [ "cl-cache-tables-tests" ]; + lispLibs = [ + (getAttr "cl-cache-tables" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cairo2 = ( + build-asdf-system { + pname = "cl-cairo2"; + version = "20211020-git"; + asds = [ "cl-cairo2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cairo2/2021-10-20/cl-cairo2-20211020-git.tgz"; + sha256 = "0cpfgyxw6pz7y033dlya8c4vjmkpw127zdq3a9xclp9q8jbdlb7q"; + system = "cl-cairo2"; + asd = "cl-cairo2"; + } + ); + systems = [ "cl-cairo2" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-colors" self) + (getAttr "cl-utilities" self) + (getAttr "metabang-bind" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + cl-cairo2-demos = ( + build-asdf-system { + pname = "cl-cairo2-demos"; + version = "20211020-git"; + asds = [ "cl-cairo2-demos" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cairo2/2021-10-20/cl-cairo2-20211020-git.tgz"; + sha256 = "0cpfgyxw6pz7y033dlya8c4vjmkpw127zdq3a9xclp9q8jbdlb7q"; + system = "cl-cairo2-demos"; + asd = "cl-cairo2-demos"; + } + ); + systems = [ "cl-cairo2-demos" ]; + lispLibs = [ (getAttr "cl-cairo2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cairo2-xlib = ( + build-asdf-system { + pname = "cl-cairo2-xlib"; + version = "20211020-git"; + asds = [ "cl-cairo2-xlib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cairo2/2021-10-20/cl-cairo2-20211020-git.tgz"; + sha256 = "0cpfgyxw6pz7y033dlya8c4vjmkpw127zdq3a9xclp9q8jbdlb7q"; + system = "cl-cairo2-xlib"; + asd = "cl-cairo2-xlib"; + } + ); + systems = [ "cl-cairo2-xlib" ]; + lispLibs = [ + (getAttr "cl-cairo2" self) + (getAttr "cl-freetype2" self) + ]; + meta = { }; + } + ); + cl-case-control = ( + build-asdf-system { + pname = "cl-case-control"; + version = "20141106-git"; + asds = [ "cl-case-control" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-case-control/2014-11-06/cl-case-control-20141106-git.tgz"; + sha256 = "0510m1dfz4abw3s7w0axr1b1nsmi72avr850r0sn6p2pq091pc71"; + system = "cl-case-control"; + asd = "cl-case-control"; + } + ); + systems = [ "cl-case-control" ]; + lispLibs = [ (getAttr "trivial-types" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-catmull-rom-spline = ( + build-asdf-system { + pname = "cl-catmull-rom-spline"; + version = "20220220-git"; + asds = [ "cl-catmull-rom-spline" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-catmull-rom-spline/2022-02-20/cl-catmull-rom-spline-20220220-git.tgz"; + sha256 = "0702swja11zpfdx04l0901ipvi0acg17mk9ryvhibnbzq70npyjs"; + system = "cl-catmull-rom-spline"; + asd = "cl-catmull-rom-spline"; + } + ); + systems = [ "cl-catmull-rom-spline" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cerf = ( + build-asdf-system { + pname = "cl-cerf"; + version = "20210531-git"; + asds = [ "cl-cerf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cerf/2021-05-31/cl-cerf-20210531-git.tgz"; + sha256 = "0n1b6ig1d0dqkjn06iqsk0m4y7j7msi2gcq7niivcwc4s0ry0ljn"; + system = "cl-cerf"; + asd = "cl-cerf"; + } + ); + systems = [ "cl-cerf" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cffi-gtk = ( + build-asdf-system { + pname = "cl-cffi-gtk"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk"; + asd = "cl-cffi-gtk"; + } + ); + systems = [ "cl-cffi-gtk" ]; + lispLibs = [ + (getAttr "cl-cffi-gtk-cairo" self) + (getAttr "cl-cffi-gtk-gdk" self) + (getAttr "cl-cffi-gtk-gdk-pixbuf" self) + (getAttr "cl-cffi-gtk-gio" self) + (getAttr "cl-cffi-gtk-glib" self) + (getAttr "cl-cffi-gtk-gobject" self) + (getAttr "cl-cffi-gtk-pango" self) + ]; + meta = { }; + } + ); + cl-cffi-gtk-cairo = ( + build-asdf-system { + pname = "cl-cffi-gtk-cairo"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk-cairo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk-cairo"; + asd = "cl-cffi-gtk-cairo"; + } + ); + systems = [ "cl-cffi-gtk-cairo" ]; + lispLibs = [ (getAttr "cl-cffi-gtk-glib" self) ]; + meta = { }; + } + ); + cl-cffi-gtk-demo-cairo = ( + build-asdf-system { + pname = "cl-cffi-gtk-demo-cairo"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk-demo-cairo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk-demo-cairo"; + asd = "cl-cffi-gtk-demo-cairo"; + } + ); + systems = [ "cl-cffi-gtk-demo-cairo" ]; + lispLibs = [ (getAttr "cl-cffi-gtk" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cffi-gtk-demo-glib = ( + build-asdf-system { + pname = "cl-cffi-gtk-demo-glib"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk-demo-glib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk-demo-glib"; + asd = "cl-cffi-gtk-demo-glib"; + } + ); + systems = [ "cl-cffi-gtk-demo-glib" ]; + lispLibs = [ (getAttr "cl-cffi-gtk" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cffi-gtk-demo-gobject = ( + build-asdf-system { + pname = "cl-cffi-gtk-demo-gobject"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk-demo-gobject" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk-demo-gobject"; + asd = "cl-cffi-gtk-demo-gobject"; + } + ); + systems = [ "cl-cffi-gtk-demo-gobject" ]; + lispLibs = [ (getAttr "cl-cffi-gtk-gobject" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cffi-gtk-example-gtk = ( + build-asdf-system { + pname = "cl-cffi-gtk-example-gtk"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk-example-gtk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk-example-gtk"; + asd = "cl-cffi-gtk-example-gtk"; + } + ); + systems = [ "cl-cffi-gtk-example-gtk" ]; + lispLibs = [ (getAttr "cl-cffi-gtk" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cffi-gtk-gdk = ( + build-asdf-system { + pname = "cl-cffi-gtk-gdk"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk-gdk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk-gdk"; + asd = "cl-cffi-gtk-gdk"; + } + ); + systems = [ "cl-cffi-gtk-gdk" ]; + lispLibs = [ + (getAttr "cl-cffi-gtk-cairo" self) + (getAttr "cl-cffi-gtk-gdk-pixbuf" self) + (getAttr "cl-cffi-gtk-gio" self) + (getAttr "cl-cffi-gtk-glib" self) + (getAttr "cl-cffi-gtk-gobject" self) + (getAttr "cl-cffi-gtk-pango" self) + ]; + meta = { }; + } + ); + cl-cffi-gtk-gdk-pixbuf = ( + build-asdf-system { + pname = "cl-cffi-gtk-gdk-pixbuf"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk-gdk-pixbuf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk-gdk-pixbuf"; + asd = "cl-cffi-gtk-gdk-pixbuf"; + } + ); + systems = [ "cl-cffi-gtk-gdk-pixbuf" ]; + lispLibs = [ + (getAttr "cl-cffi-gtk-glib" self) + (getAttr "cl-cffi-gtk-gobject" self) + ]; + meta = { }; + } + ); + cl-cffi-gtk-gio = ( + build-asdf-system { + pname = "cl-cffi-gtk-gio"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk-gio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk-gio"; + asd = "cl-cffi-gtk-gio"; + } + ); + systems = [ "cl-cffi-gtk-gio" ]; + lispLibs = [ + (getAttr "cl-cffi-gtk-glib" self) + (getAttr "cl-cffi-gtk-gobject" self) + ]; + meta = { }; + } + ); + cl-cffi-gtk-glib = ( + build-asdf-system { + pname = "cl-cffi-gtk-glib"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk-glib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk-glib"; + asd = "cl-cffi-gtk-glib"; + } + ); + systems = [ "cl-cffi-gtk-glib" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "iterate" self) + (getAttr "trivial-features" self) + ]; + meta = { }; + } + ); + cl-cffi-gtk-gobject = ( + build-asdf-system { + pname = "cl-cffi-gtk-gobject"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk-gobject" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk-gobject"; + asd = "cl-cffi-gtk-gobject"; + } + ); + systems = [ "cl-cffi-gtk-gobject" ]; + lispLibs = [ + (getAttr "cl-cffi-gtk-glib" self) + (getAttr "closer-mop" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + cl-cffi-gtk-opengl-demo = ( + build-asdf-system { + pname = "cl-cffi-gtk-opengl-demo"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk-opengl-demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk-opengl-demo"; + asd = "cl-cffi-gtk-opengl-demo"; + } + ); + systems = [ "cl-cffi-gtk-opengl-demo" ]; + lispLibs = [ + (getAttr "cl-cffi-gtk" self) + (getAttr "cl-opengl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cffi-gtk-pango = ( + build-asdf-system { + pname = "cl-cffi-gtk-pango"; + version = "20230214-git"; + asds = [ "cl-cffi-gtk-pango" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cffi-gtk/2023-02-14/cl-cffi-gtk-20230214-git.tgz"; + sha256 = "1cn2f6b62axjzdzfv971218ably32dvqfdy499li25vjd8nb2qm3"; + system = "cl-cffi-gtk-pango"; + asd = "cl-cffi-gtk-pango"; + } + ); + systems = [ "cl-cffi-gtk-pango" ]; + lispLibs = [ + (getAttr "cl-cffi-gtk-cairo" self) + (getAttr "cl-cffi-gtk-glib" self) + (getAttr "cl-cffi-gtk-gobject" self) + ]; + meta = { }; + } + ); + cl-change-case = ( + build-asdf-system { + pname = "cl-change-case"; + version = "20231021-git"; + asds = [ "cl-change-case" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-change-case/2023-10-21/cl-change-case-20231021-git.tgz"; + sha256 = "0g17n80jmaiyqsx8r35v6p0axb03s6j9wywlf8qkvw8rm848pp7s"; + system = "cl-change-case"; + asd = "cl-change-case"; + } + ); + systems = [ "cl-change-case" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cl-ppcre-unicode" self) + ]; + meta = { }; + } + ); + cl-charms = ( + build-asdf-system { + pname = "cl-charms"; + version = "20230618-git"; + asds = [ "cl-charms" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-charms/2023-06-18/cl-charms-20230618-git.tgz"; + sha256 = "0g6kw0b3b8wjb89rv6slyjl55pymadkcf35ig4d22z8igac7kj8b"; + system = "cl-charms"; + asd = "cl-charms"; + } + ); + systems = [ "cl-charms" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-charms-marquee = ( + build-asdf-system { + pname = "cl-charms-marquee"; + version = "20230618-git"; + asds = [ "cl-charms-marquee" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-charms/2023-06-18/cl-charms-20230618-git.tgz"; + sha256 = "0g6kw0b3b8wjb89rv6slyjl55pymadkcf35ig4d22z8igac7kj8b"; + system = "cl-charms-marquee"; + asd = "cl-charms-marquee"; + } + ); + systems = [ "cl-charms-marquee" ]; + lispLibs = [ (getAttr "cl-charms" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-charms-paint = ( + build-asdf-system { + pname = "cl-charms-paint"; + version = "20230618-git"; + asds = [ "cl-charms-paint" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-charms/2023-06-18/cl-charms-20230618-git.tgz"; + sha256 = "0g6kw0b3b8wjb89rv6slyjl55pymadkcf35ig4d22z8igac7kj8b"; + system = "cl-charms-paint"; + asd = "cl-charms-paint"; + } + ); + systems = [ "cl-charms-paint" ]; + lispLibs = [ (getAttr "cl-charms" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-charms-timer = ( + build-asdf-system { + pname = "cl-charms-timer"; + version = "20230618-git"; + asds = [ "cl-charms-timer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-charms/2023-06-18/cl-charms-20230618-git.tgz"; + sha256 = "0g6kw0b3b8wjb89rv6slyjl55pymadkcf35ig4d22z8igac7kj8b"; + system = "cl-charms-timer"; + asd = "cl-charms-timer"; + } + ); + systems = [ "cl-charms-timer" ]; + lispLibs = [ (getAttr "cl-charms" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-clblas = ( + build-asdf-system { + pname = "cl-clblas"; + version = "20181018-git"; + asds = [ "cl-clblas" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-clblas/2018-10-18/cl-clblas-20181018-git.tgz"; + sha256 = "0cn4hvywaw97ccnj2wxjf20lh7h7n5fs6rq6kgjyfs9cxcixmvrj"; + system = "cl-clblas"; + asd = "cl-clblas"; + } + ); + systems = [ "cl-clblas" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-clblas-test = ( + build-asdf-system { + pname = "cl-clblas-test"; + version = "20181018-git"; + asds = [ "cl-clblas-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-clblas/2018-10-18/cl-clblas-20181018-git.tgz"; + sha256 = "0cn4hvywaw97ccnj2wxjf20lh7h7n5fs6rq6kgjyfs9cxcixmvrj"; + system = "cl-clblas-test"; + asd = "cl-clblas-test"; + } + ); + systems = [ "cl-clblas-test" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-clblas" self) + (getAttr "cl-oclapi" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cli = ( + build-asdf-system { + pname = "cl-cli"; + version = "20151218-git"; + asds = [ "cl-cli" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cli/2015-12-18/cl-cli-20151218-git.tgz"; + sha256 = "0zlifq55r78vfdlqf8jy6rkny73438f1i9cp9a8vybmila5dij3q"; + system = "cl-cli"; + asd = "cl-cli"; + } + ); + systems = [ "cl-cli" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { }; + } + ); + cl-clsparse = ( + build-asdf-system { + pname = "cl-clsparse"; + version = "20190813-git"; + asds = [ "cl-clsparse" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-clsparse/2019-08-13/cl-clsparse-20190813-git.tgz"; + sha256 = "0cmmwx2ka1jp5711x21knw3zi6kcpkpcs39dm62w82s97bv794gz"; + system = "cl-clsparse"; + asd = "cl-clsparse"; + } + ); + systems = [ "cl-clsparse" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cognito = ( + build-asdf-system { + pname = "cl-cognito"; + version = "20181210-git"; + asds = [ "cl-cognito" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cognito/2018-12-10/cl-cognito-20181210-git.tgz"; + sha256 = "0zy4yg4zggvxwbvkjkd89d2ps236kz6pvz90zn6gzq812wnidsd3"; + system = "cl-cognito"; + asd = "cl-cognito"; + } + ); + systems = [ "cl-cognito" ]; + lispLibs = [ + (getAttr "aws-foundation" self) + (getAttr "cl-base64" self) + (getAttr "cl-json-helper" self) + (getAttr "ironclad" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-coinpayments = ( + build-asdf-system { + pname = "cl-coinpayments"; + version = "20210807-git"; + asds = [ "cl-coinpayments" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-coinpayments/2021-08-07/cl-coinpayments-20210807-git.tgz"; + sha256 = "1vgsh95vjqqg0a6lqg1ivs36yjx6ck8cqhsmlr5l3ldfd8yr65q7"; + system = "cl-coinpayments"; + asd = "cl-coinpayments"; + } + ); + systems = [ "cl-coinpayments" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "closer-mop" self) + (getAttr "dexador" self) + (getAttr "ironclad" self) + (getAttr "jonathan" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-collider = ( + build-asdf-system { + pname = "cl-collider"; + version = "20241012-git"; + asds = [ "cl-collider" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-collider/2024-10-12/cl-collider-20241012-git.tgz"; + sha256 = "0h0fyx7glxnzwyam2aflma6003h8fcvcf5nj5f7svarw9brcc2xa"; + system = "cl-collider"; + asd = "cl-collider"; + } + ); + systems = [ "cl-collider" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "named-readtables" self) + (getAttr "pileup" self) + (getAttr "sc-osc" self) + (getAttr "simple-inferiors" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-colors = ( + build-asdf-system { + pname = "cl-colors"; + version = "20180328-git"; + asds = [ "cl-colors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-colors/2018-03-28/cl-colors-20180328-git.tgz"; + sha256 = "0l446lday4hybsm9bq3jli97fvv8jb1d33abg79vbylpwjmf3y9a"; + system = "cl-colors"; + asd = "cl-colors"; + } + ); + systems = [ "cl-colors" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "let-plus" self) + ]; + meta = { }; + } + ); + cl-colors-tests = ( + build-asdf-system { + pname = "cl-colors-tests"; + version = "20180328-git"; + asds = [ "cl-colors-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-colors/2018-03-28/cl-colors-20180328-git.tgz"; + sha256 = "0l446lday4hybsm9bq3jli97fvv8jb1d33abg79vbylpwjmf3y9a"; + system = "cl-colors-tests"; + asd = "cl-colors"; + } + ); + systems = [ "cl-colors-tests" ]; + lispLibs = [ + (getAttr "cl-colors" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-colors2 = ( + build-asdf-system { + pname = "cl-colors2"; + version = "20241012-git"; + asds = [ "cl-colors2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-colors2/2024-10-12/cl-colors2-20241012-git.tgz"; + sha256 = "053bidgbqziv5visdq09gy8zf30cvqh1w06l23yygn1yrg7m7302"; + system = "cl-colors2"; + asd = "cl-colors2"; + } + ); + systems = [ "cl-colors2" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "parse-number" self) + ]; + meta = { }; + } + ); + cl-concord = ( + build-asdf-system { + pname = "cl-concord"; + version = "20241012-git"; + asds = [ "cl-concord" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-concord/2024-10-12/cl-concord-20241012-git.tgz"; + sha256 = "01i13lp3z2v2w165h0xh72r1vyfbjr6k1gwk4hff1rf2yx2yg9k1"; + system = "cl-concord"; + asd = "cl-concord"; + } + ); + systems = [ "cl-concord" ]; + lispLibs = [ (getAttr "cl-redis" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-conllu = ( + build-asdf-system { + pname = "cl-conllu"; + version = "20211209-git"; + asds = [ "cl-conllu" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-conllu/2021-12-09/cl-conllu-20211209-git.tgz"; + sha256 = "0n69k0apifnirs2g3rfdsxiwy6dimd9qqxaqywaingvbd7yn42jn"; + system = "cl-conllu"; + asd = "cl-conllu"; + } + ); + systems = [ "cl-conllu" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-log" self) + (getAttr "cl-markup" self) + (getAttr "cl-ppcre" self) + (getAttr "lispbuilder-lexer" self) + (getAttr "optima_dot_ppcre" self) + (getAttr "split-sequence" self) + (getAttr "uuid" self) + (getAttr "wilbur" self) + (getAttr "xmls" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-conspack = ( + build-asdf-system { + pname = "cl-conspack"; + version = "20230214-git"; + asds = [ "cl-conspack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-conspack/2023-02-14/cl-conspack-20230214-git.tgz"; + sha256 = "0y5wp5c89ph44k2xjppy1c1jf2ac3q9yrk22da2rkwnbxn0h1a8d"; + system = "cl-conspack"; + asd = "cl-conspack"; + } + ); + systems = [ "cl-conspack" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "fast-io" self) + (getAttr "ieee-floats" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-conspack-test = ( + build-asdf-system { + pname = "cl-conspack-test"; + version = "20230214-git"; + asds = [ "cl-conspack-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-conspack/2023-02-14/cl-conspack-20230214-git.tgz"; + sha256 = "0y5wp5c89ph44k2xjppy1c1jf2ac3q9yrk22da2rkwnbxn0h1a8d"; + system = "cl-conspack-test"; + asd = "cl-conspack-test"; + } + ); + systems = [ "cl-conspack-test" ]; + lispLibs = [ + (getAttr "cl-conspack" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cont = ( + build-asdf-system { + pname = "cl-cont"; + version = "20110219-darcs"; + asds = [ "cl-cont" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cont/2011-02-19/cl-cont-20110219-darcs.tgz"; + sha256 = "1zf8zvb0i6jm3hhfks4w74hibm6avgc6f9s1qwgjrn2bcik8lrvz"; + system = "cl-cont"; + asd = "cl-cont"; + } + ); + systems = [ "cl-cont" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cont-test = ( + build-asdf-system { + pname = "cl-cont-test"; + version = "20110219-darcs"; + asds = [ "cl-cont-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cont/2011-02-19/cl-cont-20110219-darcs.tgz"; + sha256 = "1zf8zvb0i6jm3hhfks4w74hibm6avgc6f9s1qwgjrn2bcik8lrvz"; + system = "cl-cont-test"; + asd = "cl-cont-test"; + } + ); + systems = [ "cl-cont-test" ]; + lispLibs = [ + (getAttr "cl-cont" self) + (getAttr "rt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-containers = ( + build-asdf-system { + pname = "cl-containers"; + version = "20241012-git"; + asds = [ "cl-containers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-containers/2024-10-12/cl-containers-20241012-git.tgz"; + sha256 = "0xpa5yhsndh33cs4q6vgjc8jxwlmv8lxkg4bamfi0f3ad4smi7zl"; + system = "cl-containers"; + asd = "cl-containers"; + } + ); + systems = [ "cl-containers" ]; + lispLibs = [ + (getAttr "asdf-system-connections" self) + (getAttr "metatilities-base" self) + ]; + meta = { }; + } + ); + cl-containers-test = ( + build-asdf-system { + pname = "cl-containers-test"; + version = "20241012-git"; + asds = [ "cl-containers-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-containers/2024-10-12/cl-containers-20241012-git.tgz"; + sha256 = "0xpa5yhsndh33cs4q6vgjc8jxwlmv8lxkg4bamfi0f3ad4smi7zl"; + system = "cl-containers-test"; + asd = "cl-containers-test"; + } + ); + systems = [ "cl-containers-test" ]; + lispLibs = [ + (getAttr "cl-containers" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cookie = ( + build-asdf-system { + pname = "cl-cookie"; + version = "20241012-git"; + asds = [ "cl-cookie" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cookie/2024-10-12/cl-cookie-20241012-git.tgz"; + sha256 = "172lw0sm6i9nvlx0iv0851rsm5pc28xqqf6a75pwv1fvr6srq8qh"; + system = "cl-cookie"; + asd = "cl-cookie"; + } + ); + systems = [ "cl-cookie" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "local-time" self) + (getAttr "proc-parse" self) + (getAttr "quri" self) + ]; + meta = { }; + } + ); + cl-cookie-test = ( + build-asdf-system { + pname = "cl-cookie-test"; + version = "20241012-git"; + asds = [ "cl-cookie-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cookie/2024-10-12/cl-cookie-20241012-git.tgz"; + sha256 = "172lw0sm6i9nvlx0iv0851rsm5pc28xqqf6a75pwv1fvr6srq8qh"; + system = "cl-cookie-test"; + asd = "cl-cookie-test"; + } + ); + systems = [ "cl-cookie-test" ]; + lispLibs = [ + (getAttr "cl-cookie" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-coroutine = ( + build-asdf-system { + pname = "cl-coroutine"; + version = "20160929-git"; + asds = [ "cl-coroutine" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-coroutine/2016-09-29/cl-coroutine-20160929-git.tgz"; + sha256 = "1cqdhdjxffgfs116l1swjlsmcbly0xgcgrckvaajd566idj9yj4l"; + system = "cl-coroutine"; + asd = "cl-coroutine"; + } + ); + systems = [ "cl-coroutine" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-cont" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-coroutine-test = ( + build-asdf-system { + pname = "cl-coroutine-test"; + version = "20160929-git"; + asds = [ "cl-coroutine-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-coroutine/2016-09-29/cl-coroutine-20160929-git.tgz"; + sha256 = "1cqdhdjxffgfs116l1swjlsmcbly0xgcgrckvaajd566idj9yj4l"; + system = "cl-coroutine-test"; + asd = "cl-coroutine-test"; + } + ); + systems = [ "cl-coroutine-test" ]; + lispLibs = [ + (getAttr "cl-coroutine" self) + (getAttr "cl-test-more" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-coveralls = ( + build-asdf-system { + pname = "cl-coveralls"; + version = "20210411-git"; + asds = [ "cl-coveralls" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-coveralls/2021-04-11/cl-coveralls-20210411-git.tgz"; + sha256 = "1n4jks92827xbi2zzy6gsx3r2gl97difl04da9wz94n9rjj3bcz0"; + system = "cl-coveralls"; + asd = "cl-coveralls"; + } + ); + systems = [ "cl-coveralls" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "dexador" self) + (getAttr "flexi-streams" self) + (getAttr "ironclad" self) + (getAttr "jonathan" self) + (getAttr "lquery" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-coveralls-test = ( + build-asdf-system { + pname = "cl-coveralls-test"; + version = "20210411-git"; + asds = [ "cl-coveralls-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-coveralls/2021-04-11/cl-coveralls-20210411-git.tgz"; + sha256 = "1n4jks92827xbi2zzy6gsx3r2gl97difl04da9wz94n9rjj3bcz0"; + system = "cl-coveralls-test"; + asd = "cl-coveralls-test"; + } + ); + systems = [ "cl-coveralls-test" ]; + lispLibs = [ + (getAttr "cl-coveralls" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-covid19 = ( + build-asdf-system { + pname = "cl-covid19"; + version = "20220331-git"; + asds = [ "cl-covid19" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-covid19/2022-03-31/cl-covid19-20220331-git.tgz"; + sha256 = "0nxdharz29nrdylrwnhgdayfsfwm0vd5g487mi4i5lly8q0i9vl0"; + system = "cl-covid19"; + asd = "cl-covid19"; + } + ); + systems = [ "cl-covid19" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ascii-table" self) + (getAttr "cl-csv" self) + (getAttr "cl-migratum" self) + (getAttr "cl-migratum_dot_driver_dot_dbi" self) + (getAttr "cl-migratum_dot_provider_dot_local-path" self) + (getAttr "dexador" self) + (getAttr "djula" self) + (getAttr "jonathan" self) + (getAttr "quri" self) + (getAttr "tmpdir" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cpu-affinity = ( + build-asdf-system { + pname = "cl-cpu-affinity"; + version = "20210411-git"; + asds = [ "cl-cpu-affinity" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; + sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; + system = "cl-cpu-affinity"; + asd = "cl-cpu-affinity"; + } + ); + systems = [ "cl-cpu-affinity" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cpus = ( + build-asdf-system { + pname = "cl-cpus"; + version = "20230618-git"; + asds = [ "cl-cpus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cpus/2023-06-18/cl-cpus-20230618-git.tgz"; + sha256 = "1gxyb85hpjmhz7vhny9cscrzldx06f7c5q93pl1qs0s3b7avh5vd"; + system = "cl-cpus"; + asd = "cl-cpus"; + } + ); + systems = [ "cl-cpus" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cram = ( + build-asdf-system { + pname = "cl-cram"; + version = "20230618-git"; + asds = [ "cl-cram" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cram/2023-06-18/cl-cram-20230618-git.tgz"; + sha256 = "139p4hbb6ac57ay5vgr969d3rki9ypk9ninaqm5vkax2hcx7mq3i"; + system = "cl-cram"; + asd = "cl-cram"; + } + ); + systems = [ "cl-cram" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-crc64 = ( + build-asdf-system { + pname = "cl-crc64"; + version = "20140713-git"; + asds = [ "cl-crc64" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-crc64/2014-07-13/cl-crc64-20140713-git.tgz"; + sha256 = "1cqky5ps28r49z6ib4vjwfjpq3ml81p2ayf0nqppf2lc4vf3kb20"; + system = "cl-crc64"; + asd = "cl-crc64"; + } + ); + systems = [ "cl-crc64" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-creditcard = ( + build-asdf-system { + pname = "cl-creditcard"; + version = "20150113-git"; + asds = [ "cl-creditcard" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-creditcard/2015-01-13/cl-creditcard-20150113-git.tgz"; + sha256 = "1qq9r7q50k7jw6sv65aqi9xalaw8m6aqsbb0cgpjxv8wdhy934cr"; + system = "cl-creditcard"; + asd = "cl-creditcard"; + } + ); + systems = [ "cl-creditcard" ]; + lispLibs = [ (getAttr "iterate" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cron = ( + build-asdf-system { + pname = "cl-cron"; + version = "20231021-git"; + asds = [ "cl-cron" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cron/2023-10-21/cl-cron-20231021-git.tgz"; + sha256 = "0l1jg2sqdqniaqsaywy0ar49m10gzls8i31gpxmd7c4yzazy4fib"; + system = "cl-cron"; + asd = "cl-cron"; + } + ); + systems = [ "cl-cron" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-css = ( + build-asdf-system { + pname = "cl-css"; + version = "20140914-git"; + asds = [ "cl-css" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-css/2014-09-14/cl-css-20140914-git.tgz"; + sha256 = "1lc42zi2sw11fl2589sc19nr5sd2p0wy7wgvgwaggxa5f3ajhsmd"; + system = "cl-css"; + asd = "cl-css"; + } + ); + systems = [ "cl-css" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-csv = ( + build-asdf-system { + pname = "cl-csv"; + version = "20241012-git"; + asds = [ "cl-csv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-csv/2024-10-12/cl-csv-20241012-git.tgz"; + sha256 = "0pb89l3bi2cnk7sav2w0dmlvjxij1wpy3w6n9c4b6imjs0pznrxi"; + system = "cl-csv"; + asd = "cl-csv"; + } + ); + systems = [ "cl-csv" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-interpol" self) + (getAttr "iterate" self) + ]; + meta = { }; + } + ); + cl-csv-clsql = ( + build-asdf-system { + pname = "cl-csv-clsql"; + version = "20241012-git"; + asds = [ "cl-csv-clsql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-csv/2024-10-12/cl-csv-20241012-git.tgz"; + sha256 = "0pb89l3bi2cnk7sav2w0dmlvjxij1wpy3w6n9c4b6imjs0pznrxi"; + system = "cl-csv-clsql"; + asd = "cl-csv-clsql"; + } + ); + systems = [ "cl-csv-clsql" ]; + lispLibs = [ + (getAttr "cl-csv" self) + (getAttr "clsql-helper" self) + (getAttr "data-table-clsql" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-csv-data-table = ( + build-asdf-system { + pname = "cl-csv-data-table"; + version = "20241012-git"; + asds = [ "cl-csv-data-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-csv/2024-10-12/cl-csv-20241012-git.tgz"; + sha256 = "0pb89l3bi2cnk7sav2w0dmlvjxij1wpy3w6n9c4b6imjs0pznrxi"; + system = "cl-csv-data-table"; + asd = "cl-csv-data-table"; + } + ); + systems = [ "cl-csv-data-table" ]; + lispLibs = [ + (getAttr "cl-csv" self) + (getAttr "data-table" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cuda = ( + build-asdf-system { + pname = "cl-cuda"; + version = "20210807-git"; + asds = [ "cl-cuda" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cuda/2021-08-07/cl-cuda-20210807-git.tgz"; + sha256 = "019m2khbiadm0yxfhbbfsidnmxq9spn3hn8r6vx4cw3i22jin0hg"; + system = "cl-cuda"; + asd = "cl-cuda"; + } + ); + systems = [ "cl-cuda" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-pattern" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-reexport" self) + (getAttr "external-program" self) + (getAttr "osicat" self) + (getAttr "split-sequence" self) + ]; + meta = { }; + } + ); + cl-cuda-examples = ( + build-asdf-system { + pname = "cl-cuda-examples"; + version = "20210807-git"; + asds = [ "cl-cuda-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cuda/2021-08-07/cl-cuda-20210807-git.tgz"; + sha256 = "019m2khbiadm0yxfhbbfsidnmxq9spn3hn8r6vx4cw3i22jin0hg"; + system = "cl-cuda-examples"; + asd = "cl-cuda-examples"; + } + ); + systems = [ "cl-cuda-examples" ]; + lispLibs = [ + (getAttr "cl-cuda" self) + (getAttr "imago" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cuda-interop = ( + build-asdf-system { + pname = "cl-cuda-interop"; + version = "20210807-git"; + asds = [ "cl-cuda-interop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cuda/2021-08-07/cl-cuda-20210807-git.tgz"; + sha256 = "019m2khbiadm0yxfhbbfsidnmxq9spn3hn8r6vx4cw3i22jin0hg"; + system = "cl-cuda-interop"; + asd = "cl-cuda-interop"; + } + ); + systems = [ "cl-cuda-interop" ]; + lispLibs = [ + (getAttr "cl-cuda" self) + (getAttr "cl-glu" self) + (getAttr "cl-glut" self) + (getAttr "cl-opengl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cuda-interop-examples = ( + build-asdf-system { + pname = "cl-cuda-interop-examples"; + version = "20210807-git"; + asds = [ "cl-cuda-interop-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cuda/2021-08-07/cl-cuda-20210807-git.tgz"; + sha256 = "019m2khbiadm0yxfhbbfsidnmxq9spn3hn8r6vx4cw3i22jin0hg"; + system = "cl-cuda-interop-examples"; + asd = "cl-cuda-interop-examples"; + } + ); + systems = [ "cl-cuda-interop-examples" ]; + lispLibs = [ (getAttr "cl-cuda-interop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-cuda-misc = ( + build-asdf-system { + pname = "cl-cuda-misc"; + version = "20210807-git"; + asds = [ "cl-cuda-misc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cuda/2021-08-07/cl-cuda-20210807-git.tgz"; + sha256 = "019m2khbiadm0yxfhbbfsidnmxq9spn3hn8r6vx4cw3i22jin0hg"; + system = "cl-cuda-misc"; + asd = "cl-cuda-misc"; + } + ); + systems = [ "cl-cuda-misc" ]; + lispLibs = [ + (getAttr "cl-emb" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-custom-hash-table = ( + build-asdf-system { + pname = "cl-custom-hash-table"; + version = "20241012-git"; + asds = [ "cl-custom-hash-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-custom-hash-table/2024-10-12/cl-custom-hash-table-20241012-git.tgz"; + sha256 = "1sb5anv9kh7wv165nra95v0qkk1gvp3mn461zi7m0fla1290g598"; + system = "cl-custom-hash-table"; + asd = "cl-custom-hash-table"; + } + ); + systems = [ "cl-custom-hash-table" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-custom-hash-table-test = ( + build-asdf-system { + pname = "cl-custom-hash-table-test"; + version = "20241012-git"; + asds = [ "cl-custom-hash-table-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-custom-hash-table/2024-10-12/cl-custom-hash-table-20241012-git.tgz"; + sha256 = "1sb5anv9kh7wv165nra95v0qkk1gvp3mn461zi7m0fla1290g598"; + system = "cl-custom-hash-table-test"; + asd = "cl-custom-hash-table-test"; + } + ); + systems = [ "cl-custom-hash-table-test" ]; + lispLibs = [ + (getAttr "cl-custom-hash-table" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-data-structures = ( + build-asdf-system { + pname = "cl-data-structures"; + version = "20241012-git"; + asds = [ "cl-data-structures" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-data-structures/2024-10-12/cl-data-structures-20241012-git.tgz"; + sha256 = "0h49h1x9dgr53imj0r4lgx0zvdsv3mnh7lyayzy9hlysy2ixp425"; + system = "cl-data-structures"; + asd = "cl-data-structures"; + } + ); + systems = [ "cl-data-structures" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "documentation-utils-extensions" self) + (getAttr "flexichain" self) + (getAttr "iterate" self) + (getAttr "lparallel" self) + (getAttr "metabang-bind" self) + (getAttr "more-conditions" self) + (getAttr "serapeum" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-data-structures-tests = ( + build-asdf-system { + pname = "cl-data-structures-tests"; + version = "20241012-git"; + asds = [ "cl-data-structures-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-data-structures/2024-10-12/cl-data-structures-20241012-git.tgz"; + sha256 = "0h49h1x9dgr53imj0r4lgx0zvdsv3mnh7lyayzy9hlysy2ixp425"; + system = "cl-data-structures-tests"; + asd = "cl-data-structures-tests"; + } + ); + systems = [ "cl-data-structures-tests" ]; + lispLibs = [ + (getAttr "cl-data-structures" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-date-time-parser = ( + build-asdf-system { + pname = "cl-date-time-parser"; + version = "20140713-git"; + asds = [ "cl-date-time-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-date-time-parser/2014-07-13/cl-date-time-parser-20140713-git.tgz"; + sha256 = "0dswpbbb57jm609xxfah25dxxhjzc7qh5lr1a1ffkpms84l0r7m5"; + system = "cl-date-time-parser"; + asd = "cl-date-time-parser"; + } + ); + systems = [ "cl-date-time-parser" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cl-ppcre" self) + (getAttr "local-time" self) + (getAttr "parse-float" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-dbi = ( + build-asdf-system { + pname = "cl-dbi"; + version = "20241012-git"; + asds = [ "cl-dbi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dbi/2024-10-12/cl-dbi-20241012-git.tgz"; + sha256 = "17szd6sz1hlwl5fm4qjgyd8ax01wkbhv8hxcyy8qscx39sc0cnpy"; + system = "cl-dbi"; + asd = "cl-dbi"; + } + ); + systems = [ "cl-dbi" ]; + lispLibs = [ (getAttr "dbi" self) ]; + meta = { }; + } + ); + cl-debug-print = ( + build-asdf-system { + pname = "cl-debug-print"; + version = "20210807-git"; + asds = [ "cl-debug-print" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-debug-print/2021-08-07/cl-debug-print-20210807-git.tgz"; + sha256 = "1cm5nybmv0pq9s4lrwhd01rjj1wlcj1sjcrcakabi7w7b5zw4cyh"; + system = "cl-debug-print"; + asd = "cl-debug-print"; + } + ); + systems = [ "cl-debug-print" ]; + lispLibs = [ (getAttr "cl-syntax" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-debug-print-test = ( + build-asdf-system { + pname = "cl-debug-print-test"; + version = "20210807-git"; + asds = [ "cl-debug-print-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-debug-print/2021-08-07/cl-debug-print-20210807-git.tgz"; + sha256 = "1cm5nybmv0pq9s4lrwhd01rjj1wlcj1sjcrcakabi7w7b5zw4cyh"; + system = "cl-debug-print-test"; + asd = "cl-debug-print-test"; + } + ); + systems = [ "cl-debug-print-test" ]; + lispLibs = [ + (getAttr "cl-debug-print" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-dejavu = ( + build-asdf-system { + pname = "cl-dejavu"; + version = "20210124-git"; + asds = [ "cl-dejavu" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dejavu/2021-01-24/cl-dejavu-20210124-git.tgz"; + sha256 = "1lbxiq21bxj8r11c58cqskgn8gnl2p8q1ydkhdsv7i7xnhv2y7r0"; + system = "cl-dejavu"; + asd = "cl-dejavu"; + } + ); + systems = [ "cl-dejavu" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-devil = ( + build-asdf-system { + pname = "cl-devil"; + version = "20150302-git"; + asds = [ "cl-devil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-devil/2015-03-02/cl-devil-20150302-git.tgz"; + sha256 = "1qdjb7xwzjkv99s8q0834lfdq4ch5j2ymrmqsvwzhg47ys17pvvf"; + system = "cl-devil"; + asd = "cl-devil"; + } + ); + systems = [ "cl-devil" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-diceware = ( + build-asdf-system { + pname = "cl-diceware"; + version = "20150923-git"; + asds = [ "cl-diceware" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-diceware/2015-09-23/cl-diceware-20150923-git.tgz"; + sha256 = "0560ji51ksp8kngn2pyi41vw9zlnwiqj64ici43lzjx0qgv5v84l"; + system = "cl-diceware"; + asd = "cl-diceware"; + } + ); + systems = [ "cl-diceware" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-difflib = ( + build-asdf-system { + pname = "cl-difflib"; + version = "20130128-git"; + asds = [ "cl-difflib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-difflib/2013-01-28/cl-difflib-20130128-git.tgz"; + sha256 = "08if0abhqg191xcz9s7xv8faqq51nswzp8hw423fkqjzr24pmq48"; + system = "cl-difflib"; + asd = "cl-difflib"; + } + ); + systems = [ "cl-difflib" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-difflib-tests = ( + build-asdf-system { + pname = "cl-difflib-tests"; + version = "20130128-git"; + asds = [ "cl-difflib-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-difflib/2013-01-28/cl-difflib-20130128-git.tgz"; + sha256 = "08if0abhqg191xcz9s7xv8faqq51nswzp8hw423fkqjzr24pmq48"; + system = "cl-difflib-tests"; + asd = "cl-difflib-tests"; + } + ); + systems = [ "cl-difflib-tests" ]; + lispLibs = [ (getAttr "cl-difflib" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-digraph = ( + build-asdf-system { + pname = "cl-digraph"; + version = "20241012-hg"; + asds = [ "cl-digraph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-digraph/2024-10-12/cl-digraph-20241012-hg.tgz"; + sha256 = "18avbb608rv5radbczilfzb2857wz7pad49hwhr5za5qycjam8ss"; + system = "cl-digraph"; + asd = "cl-digraph"; + } + ); + systems = [ "cl-digraph" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-digraph_dot_dot = ( + build-asdf-system { + pname = "cl-digraph.dot"; + version = "20241012-hg"; + asds = [ "cl-digraph.dot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-digraph/2024-10-12/cl-digraph-20241012-hg.tgz"; + sha256 = "18avbb608rv5radbczilfzb2857wz7pad49hwhr5za5qycjam8ss"; + system = "cl-digraph.dot"; + asd = "cl-digraph.dot"; + } + ); + systems = [ "cl-digraph.dot" ]; + lispLibs = [ + (getAttr "cl-digraph" self) + (getAttr "cl-dot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-digraph_dot_test = ( + build-asdf-system { + pname = "cl-digraph.test"; + version = "20241012-hg"; + asds = [ "cl-digraph.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-digraph/2024-10-12/cl-digraph-20241012-hg.tgz"; + sha256 = "18avbb608rv5radbczilfzb2857wz7pad49hwhr5za5qycjam8ss"; + system = "cl-digraph.test"; + asd = "cl-digraph.test"; + } + ); + systems = [ "cl-digraph.test" ]; + lispLibs = [ + (getAttr "_1am" self) + (getAttr "alexandria" self) + (getAttr "cl-digraph" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-diskspace = ( + build-asdf-system { + pname = "cl-diskspace"; + version = "20220331-git"; + asds = [ "cl-diskspace" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-diskspace/2022-03-31/cl-diskspace-20220331-git.tgz"; + sha256 = "0l19hxqw6b8i5i1jdbr45k1xib9axcwdagsp3y8wkb35g6wwc0s7"; + system = "cl-diskspace"; + asd = "cl-diskspace"; + } + ); + systems = [ "cl-diskspace" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-disque = ( + build-asdf-system { + pname = "cl-disque"; + version = "20171227-git"; + asds = [ "cl-disque" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-disque/2017-12-27/cl-disque-20171227-git.tgz"; + sha256 = "0z26ls9vzlq43fwn307nb7xvqck5h3l9yygf93b0filki83krg3s"; + system = "cl-disque"; + asd = "cl-disque"; + } + ); + systems = [ "cl-disque" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "rutils" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-disque-test = ( + build-asdf-system { + pname = "cl-disque-test"; + version = "20171227-git"; + asds = [ "cl-disque-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-disque/2017-12-27/cl-disque-20171227-git.tgz"; + sha256 = "0z26ls9vzlq43fwn307nb7xvqck5h3l9yygf93b0filki83krg3s"; + system = "cl-disque-test"; + asd = "cl-disque-test"; + } + ); + systems = [ "cl-disque-test" ]; + lispLibs = [ + (getAttr "cl-disque" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-djula-svg = ( + build-asdf-system { + pname = "cl-djula-svg"; + version = "20221106-git"; + asds = [ "cl-djula-svg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-djula-svg/2022-11-06/cl-djula-svg-20221106-git.tgz"; + sha256 = "1jxgngr51ars234by4vnczfqmkwi2iy94sdxnj3pkjrdximy5any"; + system = "cl-djula-svg"; + asd = "cl-djula-svg"; + } + ); + systems = [ "cl-djula-svg" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "xmls" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-djula-tailwind = ( + build-asdf-system { + pname = "cl-djula-tailwind"; + version = "20221106-git"; + asds = [ "cl-djula-tailwind" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-djula-tailwind/2022-11-06/cl-djula-tailwind-20221106-git.tgz"; + sha256 = "059mfgh53gpj74rgr7b61fnm24bwx8hdrw15mjk687y9sna3avda"; + system = "cl-djula-tailwind"; + asd = "cl-djula-tailwind"; + } + ); + systems = [ "cl-djula-tailwind" ]; + lispLibs = [ + (getAttr "cl-css" self) + (getAttr "cl-minify-css" self) + (getAttr "cl-ppcre" self) + (getAttr "djula" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-dot = ( + build-asdf-system { + pname = "cl-dot"; + version = "20241012-git"; + asds = [ "cl-dot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dot/2024-10-12/cl-dot-20241012-git.tgz"; + sha256 = "1874jsc51pkyh6rz27qdhhsdyzx1mr7zx7v65m849wp49qlxs1ya"; + system = "cl-dot"; + asd = "cl-dot"; + } + ); + systems = [ "cl-dot" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-dotenv = ( + build-asdf-system { + pname = "cl-dotenv"; + version = "20181018-git"; + asds = [ "cl-dotenv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dotenv/2018-10-18/cl-dotenv-20181018-git.tgz"; + sha256 = "0cdbk886aizsnqqs3z4jfn8nyrnxj4yb3y00av49xc4h83h6xn53"; + system = "cl-dotenv"; + asd = "cl-dotenv"; + } + ); + systems = [ "cl-dotenv" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-dotenv-test = ( + build-asdf-system { + pname = "cl-dotenv-test"; + version = "20181018-git"; + asds = [ "cl-dotenv-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dotenv/2018-10-18/cl-dotenv-20181018-git.tgz"; + sha256 = "0cdbk886aizsnqqs3z4jfn8nyrnxj4yb3y00av49xc4h83h6xn53"; + system = "cl-dotenv-test"; + asd = "cl-dotenv-test"; + } + ); + systems = [ "cl-dotenv-test" ]; + lispLibs = [ + (getAttr "cl-dotenv" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-drawille = ( + build-asdf-system { + pname = "cl-drawille"; + version = "20210807-git"; + asds = [ "cl-drawille" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-drawille/2021-08-07/cl-drawille-20210807-git.tgz"; + sha256 = "0wmiz0c7h2zsfj7inzzn8jivnfsc94rq8pczfi44h36n2jg6hdys"; + system = "cl-drawille"; + asd = "cl-drawille"; + } + ); + systems = [ "cl-drawille" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "osicat" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-drm = ( + build-asdf-system { + pname = "cl-drm"; + version = "20161204-git"; + asds = [ "cl-drm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-drm/2016-12-04/cl-drm-20161204-git.tgz"; + sha256 = "018jsdi9hs71x14mq18k08hwrgdvvbc2yqbqww6gara0bg9cl3l6"; + system = "cl-drm"; + asd = "cl-drm"; + } + ); + systems = [ "cl-drm" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-dropbox = ( + build-asdf-system { + pname = "cl-dropbox"; + version = "20150608-git"; + asds = [ "cl-dropbox" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dropbox/2015-06-08/cl-dropbox-20150608-git.tgz"; + sha256 = "09giwr1wlz42flrpy71gv60p53nixjk9jaj4lirgf59dkh718f9x"; + system = "cl-dropbox"; + asd = "cl-dropbox"; + } + ); + systems = [ "cl-dropbox" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "cl-oauth" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-dsl = ( + build-asdf-system { + pname = "cl-dsl"; + version = "20130720-git"; + asds = [ "cl-dsl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dsl/2013-07-20/cl-dsl-20130720-git.tgz"; + sha256 = "1bj5yp20r8z6gi6rpf88kpy4i06c8i2d3cg5sjlq7d1ninkb4gg4"; + system = "cl-dsl"; + asd = "cl-dsl"; + } + ); + systems = [ "cl-dsl" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-dsl-tests = ( + build-asdf-system { + pname = "cl-dsl-tests"; + version = "20130720-git"; + asds = [ "cl-dsl-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dsl/2013-07-20/cl-dsl-20130720-git.tgz"; + sha256 = "1bj5yp20r8z6gi6rpf88kpy4i06c8i2d3cg5sjlq7d1ninkb4gg4"; + system = "cl-dsl-tests"; + asd = "cl-dsl"; + } + ); + systems = [ "cl-dsl-tests" ]; + lispLibs = [ + (getAttr "cl-dsl" self) + (getAttr "eos" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-durian = ( + build-asdf-system { + pname = "cl-durian"; + version = "20150608-git"; + asds = [ "cl-durian" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-durian/2015-06-08/cl-durian-20150608-git.tgz"; + sha256 = "0s89gr5gwwkyirrv7l5fzk9ws7fhy087c3myksblsh00z1xcrvng"; + system = "cl-durian"; + asd = "cl-durian"; + } + ); + systems = [ "cl-durian" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-earley-parser = ( + build-asdf-system { + pname = "cl-earley-parser"; + version = "20211020-git"; + asds = [ "cl-earley-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-earley-parser/2021-10-20/cl-earley-parser-20211020-git.tgz"; + sha256 = "1pkry3ynxn2y3nf13lc3zjqgf4hx43d9zb0w0m34s51xd4xp2h1x"; + system = "cl-earley-parser"; + asd = "cl-earley-parser"; + } + ); + systems = [ "cl-earley-parser" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ecma-48 = ( + build-asdf-system { + pname = "cl-ecma-48"; + version = "20200218-http"; + asds = [ "cl-ecma-48" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ecma-48/2020-02-18/cl-ecma-48-20200218-http.tgz"; + sha256 = "1y3srzahci25qp959b87m82d1i1i8jmq039yp9nf0hifxyhw6dgy"; + system = "cl-ecma-48"; + asd = "cl-ecma-48"; + } + ); + systems = [ "cl-ecma-48" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-egl = ( + build-asdf-system { + pname = "cl-egl"; + version = "20190521-git"; + asds = [ "cl-egl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-egl/2019-05-21/cl-egl-20190521-git.tgz"; + sha256 = "19shhzmdc9f1128slc9m4ns6zraka99awqgb4dkrwzgv7w3miqfl"; + system = "cl-egl"; + asd = "cl-egl"; + } + ); + systems = [ "cl-egl" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-elastic = ( + build-asdf-system { + pname = "cl-elastic"; + version = "20200218-git"; + asds = [ "cl-elastic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-elastic/2020-02-18/cl-elastic-20200218-git.tgz"; + sha256 = "107ha226n3mxzvm0cp8kvgybcv4rr0b4lwik4f4j7lrhz6xvnncq"; + system = "cl-elastic"; + asd = "cl-elastic"; + } + ); + systems = [ "cl-elastic" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "named-readtables" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-elastic-test = ( + build-asdf-system { + pname = "cl-elastic-test"; + version = "20200218-git"; + asds = [ "cl-elastic-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-elastic/2020-02-18/cl-elastic-20200218-git.tgz"; + sha256 = "107ha226n3mxzvm0cp8kvgybcv4rr0b4lwik4f4j7lrhz6xvnncq"; + system = "cl-elastic-test"; + asd = "cl-elastic-test"; + } + ); + systems = [ "cl-elastic-test" ]; + lispLibs = [ + (getAttr "cl-elastic" self) + (getAttr "named-readtables" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-emacs-if = ( + build-asdf-system { + pname = "cl-emacs-if"; + version = "20120305-git"; + asds = [ "cl-emacs-if" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-emacs-if/2012-03-05/cl-emacs-if-20120305-git.tgz"; + sha256 = "0br3jvihq24ymqjn2r2qnl3l099r329bsqh18nmkk3yw3kclrcfv"; + system = "cl-emacs-if"; + asd = "cl-emacs-if"; + } + ); + systems = [ "cl-emacs-if" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-emb = ( + build-asdf-system { + pname = "cl-emb"; + version = "20190521-git"; + asds = [ "cl-emb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-emb/2019-05-21/cl-emb-20190521-git.tgz"; + sha256 = "1xcm31n7afh5316lwz8iqbjx7kn5lw0l11arg8mhdmkx42aj4gkk"; + system = "cl-emb"; + asd = "cl-emb"; + } + ); + systems = [ "cl-emb" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { }; + } + ); + cl-emoji = ( + build-asdf-system { + pname = "cl-emoji"; + version = "20200218-git"; + asds = [ "cl-emoji" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-emoji/2020-02-18/cl-emoji-20200218-git.tgz"; + sha256 = "1v91kzx42qyjm936frvfsr0cgnj9g197x78xlda6x7x6xri2r9gm"; + system = "cl-emoji"; + asd = "cl-emoji"; + } + ); + systems = [ "cl-emoji" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-emoji-test = ( + build-asdf-system { + pname = "cl-emoji-test"; + version = "20200218-git"; + asds = [ "cl-emoji-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-emoji/2020-02-18/cl-emoji-20200218-git.tgz"; + sha256 = "1v91kzx42qyjm936frvfsr0cgnj9g197x78xlda6x7x6xri2r9gm"; + system = "cl-emoji-test"; + asd = "cl-emoji-test"; + } + ); + systems = [ "cl-emoji-test" ]; + lispLibs = [ + (getAttr "cl-emoji" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-env = ( + build-asdf-system { + pname = "cl-env"; + version = "20180430-git"; + asds = [ "cl-env" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-env/2018-04-30/cl-env-20180430-git.tgz"; + sha256 = "1r0d004gr1za9ib53jhxkx315wd4av0ar2063dcvs9g4nahk2d07"; + system = "cl-env"; + asd = "cl-env"; + } + ); + systems = [ "cl-env" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-environments = ( + build-asdf-system { + pname = "cl-environments"; + version = "20241012-git"; + asds = [ "cl-environments" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-environments/2024-10-12/cl-environments-20241012-git.tgz"; + sha256 = "0pafk4c0qdzqp0l23fi1pgrqycbcrwm51wq0x0jvr7975yfx2lim"; + system = "cl-environments"; + asd = "cl-environments"; + } + ); + systems = [ "cl-environments" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "collectors" self) + (getAttr "optima" self) + (getAttr "parse-declarations-1_dot_0" self) + ]; + meta = { }; + } + ); + cl-etcd = ( + build-asdf-system { + pname = "cl-etcd"; + version = "20230214-git"; + asds = [ "cl-etcd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-etcd/2023-02-14/cl-etcd-20230214-git.tgz"; + sha256 = "0bals10r07prxvjxd744vz02ri72isf168lkhrx9qkc96hd214ah"; + system = "cl-etcd"; + asd = "cl-etcd"; + } + ); + systems = [ "cl-etcd" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "async-process" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-base64" self) + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + (getAttr "split-sequence" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-events = ( + build-asdf-system { + pname = "cl-events"; + version = "20160318-git"; + asds = [ "cl-events" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-events/2016-03-18/cl-events-20160318-git.tgz"; + sha256 = "1r847q1bwblnb2395dsydylr9nxgjx7gdwc9dx1051zhvi9in36g"; + system = "cl-events"; + asd = "cl-events"; + } + ); + systems = [ "cl-events" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "blackbird" self) + (getAttr "iterate" self) + (getAttr "log4cl" self) + (getAttr "lparallel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-events_dot_test = ( + build-asdf-system { + pname = "cl-events.test"; + version = "20160318-git"; + asds = [ "cl-events.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-events/2016-03-18/cl-events-20160318-git.tgz"; + sha256 = "1r847q1bwblnb2395dsydylr9nxgjx7gdwc9dx1051zhvi9in36g"; + system = "cl-events.test"; + asd = "cl-events.test"; + } + ); + systems = [ "cl-events.test" ]; + lispLibs = [ + (getAttr "cl-events" self) + (getAttr "log4cl" self) + (getAttr "mw-equiv" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ewkb = ( + build-asdf-system { + pname = "cl-ewkb"; + version = "20110619-git"; + asds = [ "cl-ewkb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ewkb/2011-06-19/cl-ewkb-20110619-git.tgz"; + sha256 = "1mk5j34m9gkwl7c4d464l42gclxlrcpifp2nq41z3fsfl8badn6w"; + system = "cl-ewkb"; + asd = "cl-ewkb"; + } + ); + systems = [ "cl-ewkb" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "ieee-floats" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ewkb-tests = ( + build-asdf-system { + pname = "cl-ewkb-tests"; + version = "20110619-git"; + asds = [ "cl-ewkb-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ewkb/2011-06-19/cl-ewkb-20110619-git.tgz"; + sha256 = "1mk5j34m9gkwl7c4d464l42gclxlrcpifp2nq41z3fsfl8badn6w"; + system = "cl-ewkb-tests"; + asd = "cl-ewkb"; + } + ); + systems = [ "cl-ewkb-tests" ]; + lispLibs = [ + (getAttr "cl-ewkb" self) + (getAttr "postmodern" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-factoring = ( + build-asdf-system { + pname = "cl-factoring"; + version = "20221106-git"; + asds = [ "cl-factoring" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-factoring/2022-11-06/cl-factoring-20221106-git.tgz"; + sha256 = "0vn3kb8mmi93pr76lx1mbwp7qc2krzb0ayzcrffwq2aw2q201fhd"; + system = "cl-factoring"; + asd = "cl-factoring"; + } + ); + systems = [ "cl-factoring" ]; + lispLibs = [ + (getAttr "cl-primality" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fad = ( + build-asdf-system { + pname = "cl-fad"; + version = "20220220-git"; + asds = [ "cl-fad" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fad/2022-02-20/cl-fad-20220220-git.tgz"; + sha256 = "0a1xqldrq170lflnns3xp6swpnvsvllf5vq0h7sz8jqh4riqlny6"; + system = "cl-fad"; + asd = "cl-fad"; + } + ); + systems = [ "cl-fad" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + ]; + meta = { }; + } + ); + cl-fam = ( + build-asdf-system { + pname = "cl-fam"; + version = "20121125-git"; + asds = [ "cl-fam" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fam/2012-11-25/cl-fam-20121125-git.tgz"; + sha256 = "1imv87imhxvigghx3l28kbsldz6hpqd32280wjwffqwvadhx0gng"; + system = "cl-fam"; + asd = "cl-fam"; + } + ); + systems = [ "cl-fam" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fast-ecs = ( + build-asdf-system { + pname = "cl-fast-ecs"; + version = "20241012-git"; + asds = [ "cl-fast-ecs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fast-ecs/2024-10-12/cl-fast-ecs-20241012-git.tgz"; + sha256 = "0hwprzq6dnbfh4y08db615gzpdpr8vphy27whgsjhyg980503hxv"; + system = "cl-fast-ecs"; + asd = "cl-fast-ecs"; + } + ); + systems = [ "cl-fast-ecs" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fastcgi = ( + build-asdf-system { + pname = "cl-fastcgi"; + version = "20241012-git"; + asds = [ "cl-fastcgi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fastcgi/2024-10-12/cl-fastcgi-20241012-git.tgz"; + sha256 = "0hf6a8jrz8dx91px8q4201k3y919ls7cgn4qjmkqxqhjk2gxy5k7"; + system = "cl-fastcgi"; + asd = "cl-fastcgi"; + } + ); + systems = [ "cl-fastcgi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fbclient = ( + build-asdf-system { + pname = "cl-fbclient"; + version = "20140113-git"; + asds = [ "cl-fbclient" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fbclient/2014-01-13/cl-fbclient-20140113-git.tgz"; + sha256 = "1q2dwizrjnal3fdcdgim4kdq0dma71p3s8w6i8bjkg4fs49k5p9j"; + system = "cl-fbclient"; + asd = "cl-fbclient"; + } + ); + systems = [ "cl-fbclient" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fbx = ( + build-asdf-system { + pname = "cl-fbx"; + version = "20241012-git"; + asds = [ "cl-fbx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fbx/2024-10-12/cl-fbx-20241012-git.tgz"; + sha256 = "1g6s3ili3fcxy37g34ykmf2zc6nm70sh5q0diqbikikaly8kfi50"; + system = "cl-fbx"; + asd = "cl-fbx"; + } + ); + systems = [ "cl-fbx" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "float-features" self) + (getAttr "static-vectors" self) + (getAttr "trivial-extensible-sequences" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-feedparser = ( + build-asdf-system { + pname = "cl-feedparser"; + version = "20230618-git"; + asds = [ "cl-feedparser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-feedparser/2023-06-18/cl-feedparser-20230618-git.tgz"; + sha256 = "18cl4318g8szhdsqvg68ajry91m1hn0znmsqd0r2ikq6l5wpixmb"; + system = "cl-feedparser"; + asd = "cl-feedparser"; + } + ); + systems = [ "cl-feedparser" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "asdf-package-system" self) + (getAttr "cl-html5-parser" self) + (getAttr "cl-ppcre" self) + (getAttr "fset" self) + (getAttr "fxml" self) + (getAttr "local-time" self) + (getAttr "net-telent-date" self) + (getAttr "plump" self) + (getAttr "quri" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-feedparser-tests = ( + build-asdf-system { + pname = "cl-feedparser-tests"; + version = "20230618-git"; + asds = [ "cl-feedparser-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-feedparser/2023-06-18/cl-feedparser-20230618-git.tgz"; + sha256 = "18cl4318g8szhdsqvg68ajry91m1hn0znmsqd0r2ikq6l5wpixmb"; + system = "cl-feedparser-tests"; + asd = "cl-feedparser-tests"; + } + ); + systems = [ "cl-feedparser-tests" ]; + lispLibs = [ + (getAttr "cl-feedparser" self) + (getAttr "fiveam" self) + (getAttr "fxml" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fix = ( + build-asdf-system { + pname = "cl-fix"; + version = "20230214-git"; + asds = [ "cl-fix" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fix/2023-02-14/cl-fix-20230214-git.tgz"; + sha256 = "0hw9sms558vn964sw5bav74wmfahf066nqj1xyd6b3f1lz3jarbb"; + system = "cl-fix"; + asd = "cl-fix"; + } + ); + systems = [ "cl-fix" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "arrow-macros" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "local-time" self) + (getAttr "log4cl" self) + (getAttr "parse-number" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fixtures = ( + build-asdf-system { + pname = "cl-fixtures"; + version = "20200325-git"; + asds = [ "cl-fixtures" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fixtures/2020-03-25/cl-fixtures-20200325-git.tgz"; + sha256 = "01z8brw32lv8lqn6r9srwrna5gkd4cyncpbpg6pc0khgdxzpzaag"; + system = "cl-fixtures"; + asd = "cl-fixtures"; + } + ); + systems = [ "cl-fixtures" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fixtures-test = ( + build-asdf-system { + pname = "cl-fixtures-test"; + version = "20200325-git"; + asds = [ "cl-fixtures-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fixtures/2020-03-25/cl-fixtures-20200325-git.tgz"; + sha256 = "01z8brw32lv8lqn6r9srwrna5gkd4cyncpbpg6pc0khgdxzpzaag"; + system = "cl-fixtures-test"; + asd = "cl-fixtures-test"; + } + ); + systems = [ "cl-fixtures-test" ]; + lispLibs = [ + (getAttr "cl-fixtures" self) + (getAttr "incf-cl" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "rutils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-flac = ( + build-asdf-system { + pname = "cl-flac"; + version = "20231021-git"; + asds = [ "cl-flac" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-flac/2023-10-21/cl-flac-20231021-git.tgz"; + sha256 = "1p6hrg9j58yyml78l82zd6p33apbbnbw24slxw876n2j30qiyc84"; + system = "cl-flac"; + asd = "cl-flac"; + } + ); + systems = [ "cl-flac" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-flow = ( + build-asdf-system { + pname = "cl-flow"; + version = "stable-git"; + asds = [ "cl-flow" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-flow/2022-07-07/cl-flow-stable-git.tgz"; + sha256 = "0mh9g0zj2kwnsq31zg4af5k9jvfbwp28zx02f0r1jlg2rha87vlg"; + system = "cl-flow"; + asd = "cl-flow"; + } + ); + systems = [ "cl-flow" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-muth" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-flowd = ( + build-asdf-system { + pname = "cl-flowd"; + version = "20140713-git"; + asds = [ "cl-flowd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-flowd/2014-07-13/cl-flowd-20140713-git.tgz"; + sha256 = "0qppiqgy4fgvkm519bqjrw1mfp90q8fs1spvawf24d1nzslf51pj"; + system = "cl-flowd"; + asd = "cl-flowd"; + } + ); + systems = [ "cl-flowd" ]; + lispLibs = [ (getAttr "cl-annot" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fluent-logger = ( + build-asdf-system { + pname = "cl-fluent-logger"; + version = "20241012-git"; + asds = [ "cl-fluent-logger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fluent-logger/2024-10-12/cl-fluent-logger-20241012-git.tgz"; + sha256 = "0dqmx28d49fraqymrvaxq19d1x5nd6sb30bza7s9vgcyz404hzg4"; + system = "cl-fluent-logger"; + asd = "cl-fluent-logger"; + } + ); + systems = [ "cl-fluent-logger" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "chanl" self) + (getAttr "cl-messagepack" self) + (getAttr "jonathan" self) + (getAttr "local-time" self) + (getAttr "pack" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fluiddb = ( + build-asdf-system { + pname = "cl-fluiddb"; + version = "20130312-git"; + asds = [ "cl-fluiddb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fluidinfo/2013-03-12/cl-fluidinfo-20130312-git.tgz"; + sha256 = "0npkkp2w88f6vb9pckjp4q4d4idx9p2s4s4imljs2vfym2j3w0wb"; + system = "cl-fluiddb"; + asd = "cl-fluiddb"; + } + ); + systems = [ "cl-fluiddb" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-json" self) + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fluiddb-test = ( + build-asdf-system { + pname = "cl-fluiddb-test"; + version = "20130312-git"; + asds = [ "cl-fluiddb-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fluidinfo/2013-03-12/cl-fluidinfo-20130312-git.tgz"; + sha256 = "0npkkp2w88f6vb9pckjp4q4d4idx9p2s4s4imljs2vfym2j3w0wb"; + system = "cl-fluiddb-test"; + asd = "cl-fluiddb-test"; + } + ); + systems = [ "cl-fluiddb-test" ]; + lispLibs = [ + (getAttr "cl-fluiddb" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fluidinfo = ( + build-asdf-system { + pname = "cl-fluidinfo"; + version = "20130312-git"; + asds = [ "cl-fluidinfo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fluidinfo/2013-03-12/cl-fluidinfo-20130312-git.tgz"; + sha256 = "0npkkp2w88f6vb9pckjp4q4d4idx9p2s4s4imljs2vfym2j3w0wb"; + system = "cl-fluidinfo"; + asd = "cl-fluidinfo"; + } + ); + systems = [ "cl-fluidinfo" ]; + lispLibs = [ (getAttr "cl-fluiddb" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fond = ( + build-asdf-system { + pname = "cl-fond"; + version = "20191130-git"; + asds = [ "cl-fond" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fond/2019-11-30/cl-fond-20191130-git.tgz"; + sha256 = "03ygcw1azb44bhdsqcq99xi4ci0by76ap5jf5l2d1vfxq04v8grq"; + system = "cl-fond"; + asd = "cl-fond"; + } + ); + systems = [ "cl-fond" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-opengl" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-form-types = ( + build-asdf-system { + pname = "cl-form-types"; + version = "20241012-git"; + asds = [ "cl-form-types" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-form-types/2024-10-12/cl-form-types-20241012-git.tgz"; + sha256 = "1qc9dy9ji14nz5k2i17idbfks3ddwrwy9bf60rq95pnngkzqs3d1"; + system = "cl-form-types"; + asd = "cl-form-types"; + } + ); + systems = [ "cl-form-types" ]; + lispLibs = [ + (getAttr "agutil" self) + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "arrows" self) + (getAttr "cl-environments" self) + (getAttr "introspect-environment" self) + (getAttr "optima" self) + ]; + meta = { }; + } + ); + cl-forms = ( + build-asdf-system { + pname = "cl-forms"; + version = "20241012-git"; + asds = [ "cl-forms" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; + sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; + system = "cl-forms"; + asd = "cl-forms"; + } + ); + systems = [ "cl-forms" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "clavier" self) + (getAttr "fmt" self) + (getAttr "hunchentoot" self) + (getAttr "ironclad" self) + (getAttr "str" self) + (getAttr "uuid" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-forms_dot_demo = ( + build-asdf-system { + pname = "cl-forms.demo"; + version = "20241012-git"; + asds = [ "cl-forms.demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; + sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; + system = "cl-forms.demo"; + asd = "cl-forms.demo"; + } + ); + systems = [ "cl-forms.demo" ]; + lispLibs = [ + (getAttr "cl-css" self) + (getAttr "cl-forms" self) + (getAttr "cl-forms_dot_djula" self) + (getAttr "cl-forms_dot_test" self) + (getAttr "cl-forms_dot_who" self) + (getAttr "cl-forms_dot_who_dot_bootstrap" self) + (getAttr "cl-who" self) + (getAttr "djula" self) + (getAttr "hunchentoot" self) + (getAttr "trivial-open-browser" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-forms_dot_djula = ( + build-asdf-system { + pname = "cl-forms.djula"; + version = "20241012-git"; + asds = [ "cl-forms.djula" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; + sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; + system = "cl-forms.djula"; + asd = "cl-forms.djula"; + } + ); + systems = [ "cl-forms.djula" ]; + lispLibs = [ + (getAttr "cl-forms" self) + (getAttr "cl-forms_dot_who" self) + (getAttr "djula" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-forms_dot_peppol = ( + build-asdf-system { + pname = "cl-forms.peppol"; + version = "20241012-git"; + asds = [ "cl-forms.peppol" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; + sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; + system = "cl-forms.peppol"; + asd = "cl-forms.peppol"; + } + ); + systems = [ "cl-forms.peppol" ]; + lispLibs = [ + (getAttr "cl-forms" self) + (getAttr "peppol" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-forms_dot_test = ( + build-asdf-system { + pname = "cl-forms.test"; + version = "20241012-git"; + asds = [ "cl-forms.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; + sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; + system = "cl-forms.test"; + asd = "cl-forms.test"; + } + ); + systems = [ "cl-forms.test" ]; + lispLibs = [ + (getAttr "cl-forms" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-forms_dot_who = ( + build-asdf-system { + pname = "cl-forms.who"; + version = "20241012-git"; + asds = [ "cl-forms.who" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; + sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; + system = "cl-forms.who"; + asd = "cl-forms.who"; + } + ); + systems = [ "cl-forms.who" ]; + lispLibs = [ + (getAttr "cl-forms" self) + (getAttr "cl-who" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-forms_dot_who_dot_bootstrap = ( + build-asdf-system { + pname = "cl-forms.who.bootstrap"; + version = "20241012-git"; + asds = [ "cl-forms.who.bootstrap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-forms/2024-10-12/cl-forms-20241012-git.tgz"; + sha256 = "19ldfrsa0nvbr0mlzy4cm9fmvxfmh6x9cn0nawaypbsrwpybfslc"; + system = "cl-forms.who.bootstrap"; + asd = "cl-forms.who.bootstrap"; + } + ); + systems = [ "cl-forms.who.bootstrap" ]; + lispLibs = [ (getAttr "cl-forms_dot_who" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-freeimage = ( + build-asdf-system { + pname = "cl-freeimage"; + version = "20170403-git"; + asds = [ "cl-freeimage" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-freeimage/2017-04-03/cl-freeimage-20170403-git.tgz"; + sha256 = "1333i8sh670nkb0c35xp511xjlafn5zh8a6gk3wnh19gffvj63hq"; + system = "cl-freeimage"; + asd = "cl-freeimage"; + } + ); + systems = [ "cl-freeimage" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-freetype2 = ( + build-asdf-system { + pname = "cl-freetype2"; + version = "20241012-git"; + asds = [ "cl-freetype2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-freetype2/2024-10-12/cl-freetype2-20241012-git.tgz"; + sha256 = "00lkmawhjgqzfrsaaqmnffm7mmn3b31gzwz8g51kdjm9s16vwpjs"; + system = "cl-freetype2"; + asd = "cl-freetype2"; + } + ); + systems = [ "cl-freetype2" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + cl-freetype2-tests = ( + build-asdf-system { + pname = "cl-freetype2-tests"; + version = "20241012-git"; + asds = [ "cl-freetype2-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-freetype2/2024-10-12/cl-freetype2-20241012-git.tgz"; + sha256 = "00lkmawhjgqzfrsaaqmnffm7mmn3b31gzwz8g51kdjm9s16vwpjs"; + system = "cl-freetype2-tests"; + asd = "cl-freetype2-tests"; + } + ); + systems = [ "cl-freetype2-tests" ]; + lispLibs = [ + (getAttr "cl-freetype2" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fsnotify = ( + build-asdf-system { + pname = "cl-fsnotify"; + version = "20150302-git"; + asds = [ "cl-fsnotify" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fsnotify/2015-03-02/cl-fsnotify-20150302-git.tgz"; + sha256 = "0693ga1xqcvi89j3aw0lmyi3a1yl3hrfwli2jiwxv0mgpcaxz0yr"; + system = "cl-fsnotify"; + asd = "cl-fsnotify"; + } + ); + systems = [ "cl-fsnotify" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ftp = ( + build-asdf-system { + pname = "cl-ftp"; + version = "20150608-http"; + asds = [ "cl-ftp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ftp/2015-06-08/cl-ftp-20150608-http.tgz"; + sha256 = "1m955rjpaynybzmb9q631mll764hm06lydvhra50mfjj75ynwsvw"; + system = "cl-ftp"; + asd = "cl-ftp"; + } + ); + systems = [ "cl-ftp" ]; + lispLibs = [ + (getAttr "split-sequence" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-fuse = ( + build-asdf-system { + pname = "cl-fuse"; + version = "20200925-git"; + asds = [ "cl-fuse" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fuse/2020-09-25/cl-fuse-20200925-git.tgz"; + sha256 = "1qxvf8ybn0v1hiaz11k1h47y0dksj8ah9v8jdfrjp9ad1rrrnxqs"; + system = "cl-fuse"; + asd = "cl-fuse"; + } + ); + systems = [ "cl-fuse" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-utilities" self) + (getAttr "iterate" self) + (getAttr "trivial-backtrace" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { }; + } + ); + cl-fuse-meta-fs = ( + build-asdf-system { + pname = "cl-fuse-meta-fs"; + version = "20190710-git"; + asds = [ "cl-fuse-meta-fs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fuse-meta-fs/2019-07-10/cl-fuse-meta-fs-20190710-git.tgz"; + sha256 = "1wbi7lvczfn09qb72rg1bps9w51mz42dwa7lyjl2hp8lbwc2a5a9"; + system = "cl-fuse-meta-fs"; + asd = "cl-fuse-meta-fs"; + } + ); + systems = [ "cl-fuse-meta-fs" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-fuse" self) + (getAttr "iterate" self) + (getAttr "pcall" self) + ]; + meta = { }; + } + ); + cl-fuzz = ( + build-asdf-system { + pname = "cl-fuzz"; + version = "20181018-git"; + asds = [ "cl-fuzz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fuzz/2018-10-18/cl-fuzz-20181018-git.tgz"; + sha256 = "1zvlh0nh4iip75p6dblx5kajqaa3hhv6mdjbx9cids8491r388rz"; + system = "cl-fuzz"; + asd = "cl-fuzz"; + } + ); + systems = [ "cl-fuzz" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { }; + } + ); + cl-fxml = ( + build-asdf-system { + pname = "cl-fxml"; + version = "20220331-git"; + asds = [ "cl-fxml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-fxml/2022-03-31/cl-fxml-20220331-git.tgz"; + sha256 = "0i5w3z0rgyi42rlhvf92k95w6bajf3m1x9g4zprwf602kp7abr3c"; + system = "cl-fxml"; + asd = "cl-fxml"; + } + ); + systems = [ "cl-fxml" ]; + lispLibs = [ + (getAttr "agnostic-lizard" self) + (getAttr "alexandria" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gamepad = ( + build-asdf-system { + pname = "cl-gamepad"; + version = "20241012-git"; + asds = [ "cl-gamepad" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gamepad/2024-10-12/cl-gamepad-20241012-git.tgz"; + sha256 = "015qx89rnkkqaa6qsl78zvb3sb1m4xdgjpgzn5ip5i27gw94770g"; + system = "cl-gamepad"; + asd = "cl-gamepad"; + } + ); + systems = [ "cl-gamepad" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gap-buffer = ( + build-asdf-system { + pname = "cl-gap-buffer"; + version = "20230618-git"; + asds = [ "cl-gap-buffer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gap-buffer/2023-06-18/cl-gap-buffer-20230618-git.tgz"; + sha256 = "0dzwhzv139z9pspnh1krnldnk4nfrj8f5khh08085xkc5bgg1jfv"; + system = "cl-gap-buffer"; + asd = "cl-gap-buffer"; + } + ); + systems = [ "cl-gap-buffer" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gbm = ( + build-asdf-system { + pname = "cl-gbm"; + version = "20180430-git"; + asds = [ "cl-gbm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gbm/2018-04-30/cl-gbm-20180430-git.tgz"; + sha256 = "14bshi7q1hhyag8va9javjjn5cnhmwyjlw8vvvb4fyzfspz3kpdx"; + system = "cl-gbm"; + asd = "cl-gbm"; + } + ); + systems = [ "cl-gbm" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gcrypt = ( + build-asdf-system { + pname = "cl-gcrypt"; + version = "20211209-git"; + asds = [ "cl-gcrypt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gcrypt/2021-12-09/cl-gcrypt-20211209-git.tgz"; + sha256 = "1f4gx5ssirr4f3n68i2da6ad7hbhgsk18zv0gfqy3q635zai0z3w"; + system = "cl-gcrypt"; + asd = "cl-gcrypt"; + } + ); + systems = [ "cl-gcrypt" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gcrypt-test = ( + build-asdf-system { + pname = "cl-gcrypt-test"; + version = "20211209-git"; + asds = [ "cl-gcrypt-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gcrypt/2021-12-09/cl-gcrypt-20211209-git.tgz"; + sha256 = "1f4gx5ssirr4f3n68i2da6ad7hbhgsk18zv0gfqy3q635zai0z3w"; + system = "cl-gcrypt-test"; + asd = "cl-gcrypt-test"; + } + ); + systems = [ "cl-gcrypt-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "cl-gcrypt" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gd = ( + build-asdf-system { + pname = "cl-gd"; + version = "20201220-git"; + asds = [ "cl-gd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gd/2020-12-20/cl-gd-20201220-git.tgz"; + sha256 = "1wa6nv5bdf0v38hzr6cfadkk6mhvvnj9lpl9igcxygdjbnn2a3y6"; + system = "cl-gd"; + asd = "cl-gd"; + } + ); + systems = [ "cl-gd" ]; + lispLibs = [ (getAttr "uffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gd-test = ( + build-asdf-system { + pname = "cl-gd-test"; + version = "20201220-git"; + asds = [ "cl-gd-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gd/2020-12-20/cl-gd-20201220-git.tgz"; + sha256 = "1wa6nv5bdf0v38hzr6cfadkk6mhvvnj9lpl9igcxygdjbnn2a3y6"; + system = "cl-gd-test"; + asd = "cl-gd-test"; + } + ); + systems = [ "cl-gd-test" ]; + lispLibs = [ (getAttr "cl-gd" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gdata = ( + build-asdf-system { + pname = "cl-gdata"; + version = "20171130-git"; + asds = [ "cl-gdata" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gdata/2017-11-30/cl-gdata-20171130-git.tgz"; + sha256 = "0x2sq03nacjbq7p9baxlhr7bb0xg7v1ljq7qj1b3xrd4rbcibxi9"; + system = "cl-gdata"; + asd = "cl-gdata"; + } + ); + systems = [ "cl-gdata" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "cxml" self) + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + (getAttr "gzip-stream" self) + (getAttr "local-time" self) + (getAttr "parse-number" self) + (getAttr "split-sequence" self) + (getAttr "string-case" self) + (getAttr "trivial-utf-8" self) + (getAttr "url-rewrite" self) + (getAttr "xpath" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gearman = ( + build-asdf-system { + pname = "cl-gearman"; + version = "20211020-git"; + asds = [ "cl-gearman" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gearman/2021-10-20/cl-gearman-20211020-git.tgz"; + sha256 = "0cnkpqn43p55xlhdi8bws2ssa1ahvzbgggh3pam0zbqma2m525j6"; + system = "cl-gearman"; + asd = "cl-gearman"; + } + ); + systems = [ "cl-gearman" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "split-sequence" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gearman-test = ( + build-asdf-system { + pname = "cl-gearman-test"; + version = "20211020-git"; + asds = [ "cl-gearman-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gearman/2021-10-20/cl-gearman-20211020-git.tgz"; + sha256 = "0cnkpqn43p55xlhdi8bws2ssa1ahvzbgggh3pam0zbqma2m525j6"; + system = "cl-gearman-test"; + asd = "cl-gearman-test"; + } + ); + systems = [ "cl-gearman-test" ]; + lispLibs = [ + (getAttr "cl-gearman" self) + (getAttr "cl-test-more" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gendoc = ( + build-asdf-system { + pname = "cl-gendoc"; + version = "20180831-git"; + asds = [ "cl-gendoc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gendoc/2018-08-31/cl-gendoc-20180831-git.tgz"; + sha256 = "19f8fmz2hj332kh3y3fbil2dchpckdsqci6ljhadymd8p2h6w4ws"; + system = "cl-gendoc"; + asd = "cl-gendoc"; + } + ); + systems = [ "cl-gendoc" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "_3bmd-ext-code-blocks" self) + (getAttr "cl-who" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gendoc-docs = ( + build-asdf-system { + pname = "cl-gendoc-docs"; + version = "20180831-git"; + asds = [ "cl-gendoc-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gendoc/2018-08-31/cl-gendoc-20180831-git.tgz"; + sha256 = "19f8fmz2hj332kh3y3fbil2dchpckdsqci6ljhadymd8p2h6w4ws"; + system = "cl-gendoc-docs"; + asd = "cl-gendoc"; + } + ); + systems = [ "cl-gendoc-docs" ]; + lispLibs = [ (getAttr "cl-gendoc" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gene-searcher = ( + build-asdf-system { + pname = "cl-gene-searcher"; + version = "20111001-git"; + asds = [ "cl-gene-searcher" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gene-searcher/2011-10-01/cl-gene-searcher-20111001-git.tgz"; + sha256 = "0n8p6yk600h7m050bjxazmcxdrcfrkcklrcj8ncflyshm72qv1yk"; + system = "cl-gene-searcher"; + asd = "cl-gene-searcher"; + } + ); + systems = [ "cl-gene-searcher" ]; + lispLibs = [ (getAttr "clsql-sqlite3" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-generator = ( + build-asdf-system { + pname = "cl-generator"; + version = "20221106-git"; + asds = [ "cl-generator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-generator/2022-11-06/cl-generator-20221106-git.tgz"; + sha256 = "0aa5prw6f4fqw9j8m6kvdb3h3lqyvi15dd1l6437p9408mmyxk30"; + system = "cl-generator"; + asd = "cl-generator"; + } + ); + systems = [ "cl-generator" ]; + lispLibs = [ (getAttr "cl-cont" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-generator-test = ( + build-asdf-system { + pname = "cl-generator-test"; + version = "20221106-git"; + asds = [ "cl-generator-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-generator/2022-11-06/cl-generator-20221106-git.tgz"; + sha256 = "0aa5prw6f4fqw9j8m6kvdb3h3lqyvi15dd1l6437p9408mmyxk30"; + system = "cl-generator-test"; + asd = "cl-generator-test"; + } + ); + systems = [ "cl-generator-test" ]; + lispLibs = [ + (getAttr "cl-generator" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-geocode = ( + build-asdf-system { + pname = "cl-geocode"; + version = "20190813-git"; + asds = [ "cl-geocode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-geocode/2019-08-13/cl-geocode-20190813-git.tgz"; + sha256 = "17z0v29rrhsfjikg4sn9ynxckh5i3ahjn7c8qs381n1p9fbd668l"; + system = "cl-geocode"; + asd = "cl-geocode"; + } + ); + systems = [ "cl-geocode" ]; + lispLibs = [ + (getAttr "acl-compat" self) + (getAttr "aserve" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-geoip = ( + build-asdf-system { + pname = "cl-geoip"; + version = "20130615-git"; + asds = [ "cl-geoip" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-geoip/2013-06-15/cl-geoip-20130615-git.tgz"; + sha256 = "0ys8wysppx06j3s0dc9lc9zjizr1fmj388fiigyn1wrdyyka41y2"; + system = "cl-geoip"; + asd = "cl-geoip"; + } + ); + systems = [ "cl-geoip" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-geometry = ( + build-asdf-system { + pname = "cl-geometry"; + version = "20160531-git"; + asds = [ "cl-geometry" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-geometry/2016-05-31/cl-geometry-20160531-git.tgz"; + sha256 = "188xrd8plvc34gz7q01zmkdrzxbpwzln103l5dl78pa4a6vzz34h"; + system = "cl-geometry"; + asd = "cl-geometry"; + } + ); + systems = [ "cl-geometry" ]; + lispLibs = [ + (getAttr "iterate" self) + (getAttr "trees" self) + ]; + meta = { }; + } + ); + cl-geometry-tests = ( + build-asdf-system { + pname = "cl-geometry-tests"; + version = "20160531-git"; + asds = [ "cl-geometry-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-geometry/2016-05-31/cl-geometry-20160531-git.tgz"; + sha256 = "188xrd8plvc34gz7q01zmkdrzxbpwzln103l5dl78pa4a6vzz34h"; + system = "cl-geometry-tests"; + asd = "cl-geometry-tests"; + } + ); + systems = [ "cl-geometry-tests" ]; + lispLibs = [ + (getAttr "cl-geometry" self) + (getAttr "iterate" self) + (getAttr "vecto" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-geos = ( + build-asdf-system { + pname = "cl-geos"; + version = "20180711-git"; + asds = [ "cl-geos" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-geos/2018-07-11/cl-geos-20180711-git.tgz"; + sha256 = "0igq2c1p82pbkyc7zg90fm3lbsmhwnfmb3q8jc8baklb958555ck"; + system = "cl-geos"; + asd = "cl-geos"; + } + ); + systems = [ "cl-geos" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "trivial-garbage" self) + (getAttr "xarray" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-getopt = ( + build-asdf-system { + pname = "cl-getopt"; + version = "20211209-git"; + asds = [ "cl-getopt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-getopt/2021-12-09/cl-getopt-20211209-git.tgz"; + sha256 = "16qkpg2qln7q9j5614py00zwsnmxcy3xcmhb4m8f0w0zbnpvkjxl"; + system = "cl-getopt"; + asd = "cl-getopt"; + } + ); + systems = [ "cl-getopt" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-getx = ( + build-asdf-system { + pname = "cl-getx"; + version = "20200925-git"; + asds = [ "cl-getx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-getx/2020-09-25/cl-getx-20200925-git.tgz"; + sha256 = "07gi346vqrhnbkdk4l6g06z4shhnx7f4l44jgayzfdd0xkv02brv"; + system = "cl-getx"; + asd = "cl-getx"; + } + ); + systems = [ "cl-getx" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gimei = ( + build-asdf-system { + pname = "cl-gimei"; + version = "20211020-git"; + asds = [ "cl-gimei" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gimei/2021-10-20/cl-gimei-20211020-git.tgz"; + sha256 = "1405qbqrrrmanmg2dl7yfdj8z4vcsj1silpsa7i1y00pd18xgk8q"; + system = "cl-gimei"; + asd = "cl-gimei"; + } + ); + systems = [ "cl-gimei" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-yaml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gio = ( + build-asdf-system { + pname = "cl-gio"; + version = "20231021-git"; + asds = [ "cl-gio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glib/2023-10-21/cl-glib-20231021-git.tgz"; + sha256 = "07y8hpvdl490p8j4k8y47raqqwnpym9scz7jlg2f1jx897dkssjb"; + system = "cl-gio"; + asd = "cl-gio"; + } + ); + systems = [ "cl-gio" ]; + lispLibs = [ (getAttr "cl-gobject-introspection-wrapper" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gists = ( + build-asdf-system { + pname = "cl-gists"; + version = "20231021-git"; + asds = [ "cl-gists" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gists/2023-10-21/cl-gists-20231021-git.tgz"; + sha256 = "0kza5y6jckvydaw9bw8va5kli5d3ybyvil6w2bhf411crd2z15vc"; + system = "cl-gists"; + asd = "cl-gists"; + } + ); + systems = [ "cl-gists" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "alexandria_plus" self) + (getAttr "babel" self) + (getAttr "dexador" self) + (getAttr "local-time" self) + (getAttr "quri" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-git = ( + build-asdf-system { + pname = "cl-git"; + version = "20230618-git"; + asds = [ "cl-git" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-git/2023-06-18/cl-git-20230618-git.tgz"; + sha256 = "13h7n3nbpf2qq0vq0dz33r0468baskw83pjfxb3hik4rllrv04h6"; + system = "cl-git"; + asd = "cl-git"; + } + ); + systems = [ "cl-git" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-fad" self) + (getAttr "closer-mop" self) + (getAttr "flexi-streams" self) + (getAttr "local-time" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-github-v3 = ( + build-asdf-system { + pname = "cl-github-v3"; + version = "20241012-git"; + asds = [ "cl-github-v3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-github-v3/2024-10-12/cl-github-v3-20241012-git.tgz"; + sha256 = "0ayhnildyjjmnyk0a1sx7qxg6vq9kcggaprqf37s5qi4kadvcsr2"; + system = "cl-github-v3"; + asd = "cl-github-v3"; + } + ); + systems = [ "cl-github-v3" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw = ( + build-asdf-system { + pname = "cl-glfw"; + version = "20150302-git"; + asds = [ "cl-glfw" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw"; + asd = "cl-glfw"; + } + ); + systems = [ "cl-glfw" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-glfw-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-ftgl = ( + build-asdf-system { + pname = "cl-glfw-ftgl"; + version = "20150302-git"; + asds = [ "cl-glfw-ftgl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-ftgl"; + asd = "cl-glfw-ftgl"; + } + ); + systems = [ "cl-glfw-ftgl" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-glu = ( + build-asdf-system { + pname = "cl-glfw-glu"; + version = "20150302-git"; + asds = [ "cl-glfw-glu" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-glu"; + asd = "cl-glfw-glu"; + } + ); + systems = [ "cl-glfw-glu" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-glfw-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-3dfx__multisample = ( + build-asdf-system { + pname = "cl-glfw-opengl-3dfx_multisample"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-3dfx_multisample" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-3dfx_multisample"; + asd = "cl-glfw-opengl-3dfx_multisample"; + } + ); + systems = [ "cl-glfw-opengl-3dfx_multisample" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-3dfx__tbuffer = ( + build-asdf-system { + pname = "cl-glfw-opengl-3dfx_tbuffer"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-3dfx_tbuffer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-3dfx_tbuffer"; + asd = "cl-glfw-opengl-3dfx_tbuffer"; + } + ); + systems = [ "cl-glfw-opengl-3dfx_tbuffer" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-3dfx__texture__compression__fxt1 = ( + build-asdf-system { + pname = "cl-glfw-opengl-3dfx_texture_compression_fxt1"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-3dfx_texture_compression_fxt1" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-3dfx_texture_compression_fxt1"; + asd = "cl-glfw-opengl-3dfx_texture_compression_fxt1"; + } + ); + systems = [ "cl-glfw-opengl-3dfx_texture_compression_fxt1" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-amd__blend__minmax__factor = ( + build-asdf-system { + pname = "cl-glfw-opengl-amd_blend_minmax_factor"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-amd_blend_minmax_factor" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-amd_blend_minmax_factor"; + asd = "cl-glfw-opengl-amd_blend_minmax_factor"; + } + ); + systems = [ "cl-glfw-opengl-amd_blend_minmax_factor" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-amd__depth__clamp__separate = ( + build-asdf-system { + pname = "cl-glfw-opengl-amd_depth_clamp_separate"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-amd_depth_clamp_separate" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-amd_depth_clamp_separate"; + asd = "cl-glfw-opengl-amd_depth_clamp_separate"; + } + ); + systems = [ "cl-glfw-opengl-amd_depth_clamp_separate" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-amd__draw__buffers__blend = ( + build-asdf-system { + pname = "cl-glfw-opengl-amd_draw_buffers_blend"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-amd_draw_buffers_blend" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-amd_draw_buffers_blend"; + asd = "cl-glfw-opengl-amd_draw_buffers_blend"; + } + ); + systems = [ "cl-glfw-opengl-amd_draw_buffers_blend" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-amd__multi__draw__indirect = ( + build-asdf-system { + pname = "cl-glfw-opengl-amd_multi_draw_indirect"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-amd_multi_draw_indirect" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-amd_multi_draw_indirect"; + asd = "cl-glfw-opengl-amd_multi_draw_indirect"; + } + ); + systems = [ "cl-glfw-opengl-amd_multi_draw_indirect" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-amd__name__gen__delete = ( + build-asdf-system { + pname = "cl-glfw-opengl-amd_name_gen_delete"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-amd_name_gen_delete" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-amd_name_gen_delete"; + asd = "cl-glfw-opengl-amd_name_gen_delete"; + } + ); + systems = [ "cl-glfw-opengl-amd_name_gen_delete" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-amd__performance__monitor = ( + build-asdf-system { + pname = "cl-glfw-opengl-amd_performance_monitor"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-amd_performance_monitor" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-amd_performance_monitor"; + asd = "cl-glfw-opengl-amd_performance_monitor"; + } + ); + systems = [ "cl-glfw-opengl-amd_performance_monitor" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-amd__sample__positions = ( + build-asdf-system { + pname = "cl-glfw-opengl-amd_sample_positions"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-amd_sample_positions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-amd_sample_positions"; + asd = "cl-glfw-opengl-amd_sample_positions"; + } + ); + systems = [ "cl-glfw-opengl-amd_sample_positions" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-amd__seamless__cubemap__per__texture = ( + build-asdf-system { + pname = "cl-glfw-opengl-amd_seamless_cubemap_per_texture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-amd_seamless_cubemap_per_texture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-amd_seamless_cubemap_per_texture"; + asd = "cl-glfw-opengl-amd_seamless_cubemap_per_texture"; + } + ); + systems = [ "cl-glfw-opengl-amd_seamless_cubemap_per_texture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-amd__vertex__shader__tesselator = ( + build-asdf-system { + pname = "cl-glfw-opengl-amd_vertex_shader_tesselator"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-amd_vertex_shader_tesselator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-amd_vertex_shader_tesselator"; + asd = "cl-glfw-opengl-amd_vertex_shader_tesselator"; + } + ); + systems = [ "cl-glfw-opengl-amd_vertex_shader_tesselator" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__aux__depth__stencil = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_aux_depth_stencil"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_aux_depth_stencil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_aux_depth_stencil"; + asd = "cl-glfw-opengl-apple_aux_depth_stencil"; + } + ); + systems = [ "cl-glfw-opengl-apple_aux_depth_stencil" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__client__storage = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_client_storage"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_client_storage" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_client_storage"; + asd = "cl-glfw-opengl-apple_client_storage"; + } + ); + systems = [ "cl-glfw-opengl-apple_client_storage" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__element__array = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_element_array"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_element_array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_element_array"; + asd = "cl-glfw-opengl-apple_element_array"; + } + ); + systems = [ "cl-glfw-opengl-apple_element_array" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__fence = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_fence"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_fence" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_fence"; + asd = "cl-glfw-opengl-apple_fence"; + } + ); + systems = [ "cl-glfw-opengl-apple_fence" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__float__pixels = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_float_pixels"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_float_pixels" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_float_pixels"; + asd = "cl-glfw-opengl-apple_float_pixels"; + } + ); + systems = [ "cl-glfw-opengl-apple_float_pixels" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__flush__buffer__range = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_flush_buffer_range"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_flush_buffer_range" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_flush_buffer_range"; + asd = "cl-glfw-opengl-apple_flush_buffer_range"; + } + ); + systems = [ "cl-glfw-opengl-apple_flush_buffer_range" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__object__purgeable = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_object_purgeable"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_object_purgeable" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_object_purgeable"; + asd = "cl-glfw-opengl-apple_object_purgeable"; + } + ); + systems = [ "cl-glfw-opengl-apple_object_purgeable" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__rgb__422 = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_rgb_422"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_rgb_422" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_rgb_422"; + asd = "cl-glfw-opengl-apple_rgb_422"; + } + ); + systems = [ "cl-glfw-opengl-apple_rgb_422" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__row__bytes = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_row_bytes"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_row_bytes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_row_bytes"; + asd = "cl-glfw-opengl-apple_row_bytes"; + } + ); + systems = [ "cl-glfw-opengl-apple_row_bytes" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__specular__vector = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_specular_vector"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_specular_vector" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_specular_vector"; + asd = "cl-glfw-opengl-apple_specular_vector"; + } + ); + systems = [ "cl-glfw-opengl-apple_specular_vector" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__texture__range = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_texture_range"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_texture_range" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_texture_range"; + asd = "cl-glfw-opengl-apple_texture_range"; + } + ); + systems = [ "cl-glfw-opengl-apple_texture_range" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__transform__hint = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_transform_hint"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_transform_hint" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_transform_hint"; + asd = "cl-glfw-opengl-apple_transform_hint"; + } + ); + systems = [ "cl-glfw-opengl-apple_transform_hint" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__vertex__array__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_vertex_array_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_vertex_array_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_vertex_array_object"; + asd = "cl-glfw-opengl-apple_vertex_array_object"; + } + ); + systems = [ "cl-glfw-opengl-apple_vertex_array_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__vertex__array__range = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_vertex_array_range"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_vertex_array_range" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_vertex_array_range"; + asd = "cl-glfw-opengl-apple_vertex_array_range"; + } + ); + systems = [ "cl-glfw-opengl-apple_vertex_array_range" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__vertex__program__evaluators = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_vertex_program_evaluators"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_vertex_program_evaluators" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_vertex_program_evaluators"; + asd = "cl-glfw-opengl-apple_vertex_program_evaluators"; + } + ); + systems = [ "cl-glfw-opengl-apple_vertex_program_evaluators" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-apple__ycbcr__422 = ( + build-asdf-system { + pname = "cl-glfw-opengl-apple_ycbcr_422"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-apple_ycbcr_422" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-apple_ycbcr_422"; + asd = "cl-glfw-opengl-apple_ycbcr_422"; + } + ); + systems = [ "cl-glfw-opengl-apple_ycbcr_422" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__blend__func__extended = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_blend_func_extended"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_blend_func_extended" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_blend_func_extended"; + asd = "cl-glfw-opengl-arb_blend_func_extended"; + } + ); + systems = [ "cl-glfw-opengl-arb_blend_func_extended" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__color__buffer__float = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_color_buffer_float"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_color_buffer_float" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_color_buffer_float"; + asd = "cl-glfw-opengl-arb_color_buffer_float"; + } + ); + systems = [ "cl-glfw-opengl-arb_color_buffer_float" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__copy__buffer = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_copy_buffer"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_copy_buffer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_copy_buffer"; + asd = "cl-glfw-opengl-arb_copy_buffer"; + } + ); + systems = [ "cl-glfw-opengl-arb_copy_buffer" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__depth__buffer__float = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_depth_buffer_float"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_depth_buffer_float" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_depth_buffer_float"; + asd = "cl-glfw-opengl-arb_depth_buffer_float"; + } + ); + systems = [ "cl-glfw-opengl-arb_depth_buffer_float" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__depth__clamp = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_depth_clamp"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_depth_clamp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_depth_clamp"; + asd = "cl-glfw-opengl-arb_depth_clamp"; + } + ); + systems = [ "cl-glfw-opengl-arb_depth_clamp" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__depth__texture = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_depth_texture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_depth_texture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_depth_texture"; + asd = "cl-glfw-opengl-arb_depth_texture"; + } + ); + systems = [ "cl-glfw-opengl-arb_depth_texture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__draw__buffers = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_draw_buffers"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_draw_buffers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_draw_buffers"; + asd = "cl-glfw-opengl-arb_draw_buffers"; + } + ); + systems = [ "cl-glfw-opengl-arb_draw_buffers" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__draw__buffers__blend = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_draw_buffers_blend"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_draw_buffers_blend" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_draw_buffers_blend"; + asd = "cl-glfw-opengl-arb_draw_buffers_blend"; + } + ); + systems = [ "cl-glfw-opengl-arb_draw_buffers_blend" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__draw__elements__base__vertex = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_draw_elements_base_vertex"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_draw_elements_base_vertex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_draw_elements_base_vertex"; + asd = "cl-glfw-opengl-arb_draw_elements_base_vertex"; + } + ); + systems = [ "cl-glfw-opengl-arb_draw_elements_base_vertex" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__draw__indirect = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_draw_indirect"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_draw_indirect" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_draw_indirect"; + asd = "cl-glfw-opengl-arb_draw_indirect"; + } + ); + systems = [ "cl-glfw-opengl-arb_draw_indirect" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__draw__instanced = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_draw_instanced"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_draw_instanced" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_draw_instanced"; + asd = "cl-glfw-opengl-arb_draw_instanced"; + } + ); + systems = [ "cl-glfw-opengl-arb_draw_instanced" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__es2__compatibility = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_es2_compatibility"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_es2_compatibility" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_es2_compatibility"; + asd = "cl-glfw-opengl-arb_es2_compatibility"; + } + ); + systems = [ "cl-glfw-opengl-arb_es2_compatibility" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__fragment__program = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_fragment_program"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_fragment_program" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_fragment_program"; + asd = "cl-glfw-opengl-arb_fragment_program"; + } + ); + systems = [ "cl-glfw-opengl-arb_fragment_program" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__fragment__shader = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_fragment_shader"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_fragment_shader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_fragment_shader"; + asd = "cl-glfw-opengl-arb_fragment_shader"; + } + ); + systems = [ "cl-glfw-opengl-arb_fragment_shader" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__framebuffer__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_framebuffer_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_framebuffer_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_framebuffer_object"; + asd = "cl-glfw-opengl-arb_framebuffer_object"; + } + ); + systems = [ "cl-glfw-opengl-arb_framebuffer_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__framebuffer__object__deprecated = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_framebuffer_object_deprecated"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_framebuffer_object_deprecated" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_framebuffer_object_deprecated"; + asd = "cl-glfw-opengl-arb_framebuffer_object_deprecated"; + } + ); + systems = [ "cl-glfw-opengl-arb_framebuffer_object_deprecated" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__framebuffer__srgb = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_framebuffer_srgb"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_framebuffer_srgb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_framebuffer_srgb"; + asd = "cl-glfw-opengl-arb_framebuffer_srgb"; + } + ); + systems = [ "cl-glfw-opengl-arb_framebuffer_srgb" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__geometry__shader4 = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_geometry_shader4"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_geometry_shader4" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_geometry_shader4"; + asd = "cl-glfw-opengl-arb_geometry_shader4"; + } + ); + systems = [ "cl-glfw-opengl-arb_geometry_shader4" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__get__program__binary = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_get_program_binary"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_get_program_binary" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_get_program_binary"; + asd = "cl-glfw-opengl-arb_get_program_binary"; + } + ); + systems = [ "cl-glfw-opengl-arb_get_program_binary" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__gpu__shader5 = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_gpu_shader5"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_gpu_shader5" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_gpu_shader5"; + asd = "cl-glfw-opengl-arb_gpu_shader5"; + } + ); + systems = [ "cl-glfw-opengl-arb_gpu_shader5" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__gpu__shader__fp64 = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_gpu_shader_fp64"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_gpu_shader_fp64" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_gpu_shader_fp64"; + asd = "cl-glfw-opengl-arb_gpu_shader_fp64"; + } + ); + systems = [ "cl-glfw-opengl-arb_gpu_shader_fp64" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__half__float__pixel = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_half_float_pixel"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_half_float_pixel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_half_float_pixel"; + asd = "cl-glfw-opengl-arb_half_float_pixel"; + } + ); + systems = [ "cl-glfw-opengl-arb_half_float_pixel" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__half__float__vertex = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_half_float_vertex"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_half_float_vertex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_half_float_vertex"; + asd = "cl-glfw-opengl-arb_half_float_vertex"; + } + ); + systems = [ "cl-glfw-opengl-arb_half_float_vertex" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__imaging = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_imaging"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_imaging" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_imaging"; + asd = "cl-glfw-opengl-arb_imaging"; + } + ); + systems = [ "cl-glfw-opengl-arb_imaging" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__imaging__deprecated = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_imaging_deprecated"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_imaging_deprecated" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_imaging_deprecated"; + asd = "cl-glfw-opengl-arb_imaging_deprecated"; + } + ); + systems = [ "cl-glfw-opengl-arb_imaging_deprecated" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__instanced__arrays = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_instanced_arrays"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_instanced_arrays" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_instanced_arrays"; + asd = "cl-glfw-opengl-arb_instanced_arrays"; + } + ); + systems = [ "cl-glfw-opengl-arb_instanced_arrays" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__map__buffer__range = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_map_buffer_range"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_map_buffer_range" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_map_buffer_range"; + asd = "cl-glfw-opengl-arb_map_buffer_range"; + } + ); + systems = [ "cl-glfw-opengl-arb_map_buffer_range" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__matrix__palette = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_matrix_palette"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_matrix_palette" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_matrix_palette"; + asd = "cl-glfw-opengl-arb_matrix_palette"; + } + ); + systems = [ "cl-glfw-opengl-arb_matrix_palette" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__multisample = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_multisample"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_multisample" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_multisample"; + asd = "cl-glfw-opengl-arb_multisample"; + } + ); + systems = [ "cl-glfw-opengl-arb_multisample" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__multitexture = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_multitexture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_multitexture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_multitexture"; + asd = "cl-glfw-opengl-arb_multitexture"; + } + ); + systems = [ "cl-glfw-opengl-arb_multitexture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__occlusion__query = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_occlusion_query"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_occlusion_query" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_occlusion_query"; + asd = "cl-glfw-opengl-arb_occlusion_query"; + } + ); + systems = [ "cl-glfw-opengl-arb_occlusion_query" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__occlusion__query2 = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_occlusion_query2"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_occlusion_query2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_occlusion_query2"; + asd = "cl-glfw-opengl-arb_occlusion_query2"; + } + ); + systems = [ "cl-glfw-opengl-arb_occlusion_query2" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__pixel__buffer__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_pixel_buffer_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_pixel_buffer_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_pixel_buffer_object"; + asd = "cl-glfw-opengl-arb_pixel_buffer_object"; + } + ); + systems = [ "cl-glfw-opengl-arb_pixel_buffer_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__point__parameters = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_point_parameters"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_point_parameters" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_point_parameters"; + asd = "cl-glfw-opengl-arb_point_parameters"; + } + ); + systems = [ "cl-glfw-opengl-arb_point_parameters" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__point__sprite = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_point_sprite"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_point_sprite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_point_sprite"; + asd = "cl-glfw-opengl-arb_point_sprite"; + } + ); + systems = [ "cl-glfw-opengl-arb_point_sprite" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__provoking__vertex = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_provoking_vertex"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_provoking_vertex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_provoking_vertex"; + asd = "cl-glfw-opengl-arb_provoking_vertex"; + } + ); + systems = [ "cl-glfw-opengl-arb_provoking_vertex" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__robustness = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_robustness"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_robustness" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_robustness"; + asd = "cl-glfw-opengl-arb_robustness"; + } + ); + systems = [ "cl-glfw-opengl-arb_robustness" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__sample__shading = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_sample_shading"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_sample_shading" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_sample_shading"; + asd = "cl-glfw-opengl-arb_sample_shading"; + } + ); + systems = [ "cl-glfw-opengl-arb_sample_shading" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__sampler__objects = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_sampler_objects"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_sampler_objects" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_sampler_objects"; + asd = "cl-glfw-opengl-arb_sampler_objects"; + } + ); + systems = [ "cl-glfw-opengl-arb_sampler_objects" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__seamless__cube__map = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_seamless_cube_map"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_seamless_cube_map" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_seamless_cube_map"; + asd = "cl-glfw-opengl-arb_seamless_cube_map"; + } + ); + systems = [ "cl-glfw-opengl-arb_seamless_cube_map" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__separate__shader__objects = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_separate_shader_objects"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_separate_shader_objects" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_separate_shader_objects"; + asd = "cl-glfw-opengl-arb_separate_shader_objects"; + } + ); + systems = [ "cl-glfw-opengl-arb_separate_shader_objects" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__shader__objects = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_shader_objects"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_shader_objects" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_shader_objects"; + asd = "cl-glfw-opengl-arb_shader_objects"; + } + ); + systems = [ "cl-glfw-opengl-arb_shader_objects" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__shader__subroutine = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_shader_subroutine"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_shader_subroutine" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_shader_subroutine"; + asd = "cl-glfw-opengl-arb_shader_subroutine"; + } + ); + systems = [ "cl-glfw-opengl-arb_shader_subroutine" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__shading__language__100 = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_shading_language_100"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_shading_language_100" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_shading_language_100"; + asd = "cl-glfw-opengl-arb_shading_language_100"; + } + ); + systems = [ "cl-glfw-opengl-arb_shading_language_100" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__shading__language__include = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_shading_language_include"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_shading_language_include" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_shading_language_include"; + asd = "cl-glfw-opengl-arb_shading_language_include"; + } + ); + systems = [ "cl-glfw-opengl-arb_shading_language_include" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__shadow = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_shadow"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_shadow" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_shadow"; + asd = "cl-glfw-opengl-arb_shadow"; + } + ); + systems = [ "cl-glfw-opengl-arb_shadow" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__shadow__ambient = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_shadow_ambient"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_shadow_ambient" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_shadow_ambient"; + asd = "cl-glfw-opengl-arb_shadow_ambient"; + } + ); + systems = [ "cl-glfw-opengl-arb_shadow_ambient" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__tessellation__shader = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_tessellation_shader"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_tessellation_shader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_tessellation_shader"; + asd = "cl-glfw-opengl-arb_tessellation_shader"; + } + ); + systems = [ "cl-glfw-opengl-arb_tessellation_shader" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__border__clamp = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_border_clamp"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_border_clamp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_border_clamp"; + asd = "cl-glfw-opengl-arb_texture_border_clamp"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_border_clamp" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__buffer__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_buffer_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_buffer_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_buffer_object"; + asd = "cl-glfw-opengl-arb_texture_buffer_object"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_buffer_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__buffer__object__rgb32 = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_buffer_object_rgb32"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_buffer_object_rgb32" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_buffer_object_rgb32"; + asd = "cl-glfw-opengl-arb_texture_buffer_object_rgb32"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_buffer_object_rgb32" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__compression = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_compression"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_compression" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_compression"; + asd = "cl-glfw-opengl-arb_texture_compression"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_compression" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__compression__bptc = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_compression_bptc"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_compression_bptc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_compression_bptc"; + asd = "cl-glfw-opengl-arb_texture_compression_bptc"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_compression_bptc" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__compression__rgtc = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_compression_rgtc"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_compression_rgtc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_compression_rgtc"; + asd = "cl-glfw-opengl-arb_texture_compression_rgtc"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_compression_rgtc" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__cube__map = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_cube_map"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_cube_map" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_cube_map"; + asd = "cl-glfw-opengl-arb_texture_cube_map"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_cube_map" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__cube__map__array = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_cube_map_array"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_cube_map_array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_cube_map_array"; + asd = "cl-glfw-opengl-arb_texture_cube_map_array"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_cube_map_array" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__env__combine = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_env_combine"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_env_combine" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_env_combine"; + asd = "cl-glfw-opengl-arb_texture_env_combine"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_env_combine" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__env__dot3 = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_env_dot3"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_env_dot3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_env_dot3"; + asd = "cl-glfw-opengl-arb_texture_env_dot3"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_env_dot3" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__float = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_float"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_float" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_float"; + asd = "cl-glfw-opengl-arb_texture_float"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_float" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__gather = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_gather"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_gather" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_gather"; + asd = "cl-glfw-opengl-arb_texture_gather"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_gather" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__mirrored__repeat = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_mirrored_repeat"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_mirrored_repeat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_mirrored_repeat"; + asd = "cl-glfw-opengl-arb_texture_mirrored_repeat"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_mirrored_repeat" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__multisample = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_multisample"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_multisample" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_multisample"; + asd = "cl-glfw-opengl-arb_texture_multisample"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_multisample" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__rectangle = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_rectangle"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_rectangle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_rectangle"; + asd = "cl-glfw-opengl-arb_texture_rectangle"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_rectangle" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__rg = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_rg"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_rg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_rg"; + asd = "cl-glfw-opengl-arb_texture_rg"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_rg" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__rgb10__a2ui = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_rgb10_a2ui"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_rgb10_a2ui" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_rgb10_a2ui"; + asd = "cl-glfw-opengl-arb_texture_rgb10_a2ui"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_rgb10_a2ui" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__texture__swizzle = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_texture_swizzle"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_texture_swizzle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_texture_swizzle"; + asd = "cl-glfw-opengl-arb_texture_swizzle"; + } + ); + systems = [ "cl-glfw-opengl-arb_texture_swizzle" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__timer__query = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_timer_query"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_timer_query" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_timer_query"; + asd = "cl-glfw-opengl-arb_timer_query"; + } + ); + systems = [ "cl-glfw-opengl-arb_timer_query" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__transform__feedback2 = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_transform_feedback2"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_transform_feedback2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_transform_feedback2"; + asd = "cl-glfw-opengl-arb_transform_feedback2"; + } + ); + systems = [ "cl-glfw-opengl-arb_transform_feedback2" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__transpose__matrix = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_transpose_matrix"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_transpose_matrix" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_transpose_matrix"; + asd = "cl-glfw-opengl-arb_transpose_matrix"; + } + ); + systems = [ "cl-glfw-opengl-arb_transpose_matrix" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__uniform__buffer__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_uniform_buffer_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_uniform_buffer_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_uniform_buffer_object"; + asd = "cl-glfw-opengl-arb_uniform_buffer_object"; + } + ); + systems = [ "cl-glfw-opengl-arb_uniform_buffer_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__vertex__array__bgra = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_vertex_array_bgra"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_vertex_array_bgra" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_vertex_array_bgra"; + asd = "cl-glfw-opengl-arb_vertex_array_bgra"; + } + ); + systems = [ "cl-glfw-opengl-arb_vertex_array_bgra" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__vertex__array__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_vertex_array_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_vertex_array_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_vertex_array_object"; + asd = "cl-glfw-opengl-arb_vertex_array_object"; + } + ); + systems = [ "cl-glfw-opengl-arb_vertex_array_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__vertex__attrib__64bit = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_vertex_attrib_64bit"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_vertex_attrib_64bit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_vertex_attrib_64bit"; + asd = "cl-glfw-opengl-arb_vertex_attrib_64bit"; + } + ); + systems = [ "cl-glfw-opengl-arb_vertex_attrib_64bit" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__vertex__blend = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_vertex_blend"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_vertex_blend" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_vertex_blend"; + asd = "cl-glfw-opengl-arb_vertex_blend"; + } + ); + systems = [ "cl-glfw-opengl-arb_vertex_blend" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__vertex__buffer__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_vertex_buffer_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_vertex_buffer_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_vertex_buffer_object"; + asd = "cl-glfw-opengl-arb_vertex_buffer_object"; + } + ); + systems = [ "cl-glfw-opengl-arb_vertex_buffer_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__vertex__program = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_vertex_program"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_vertex_program" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_vertex_program"; + asd = "cl-glfw-opengl-arb_vertex_program"; + } + ); + systems = [ "cl-glfw-opengl-arb_vertex_program" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__vertex__shader = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_vertex_shader"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_vertex_shader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_vertex_shader"; + asd = "cl-glfw-opengl-arb_vertex_shader"; + } + ); + systems = [ "cl-glfw-opengl-arb_vertex_shader" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__vertex__type__2__10__10__10__rev = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_vertex_type_2_10_10_10_rev"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_vertex_type_2_10_10_10_rev" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_vertex_type_2_10_10_10_rev"; + asd = "cl-glfw-opengl-arb_vertex_type_2_10_10_10_rev"; + } + ); + systems = [ "cl-glfw-opengl-arb_vertex_type_2_10_10_10_rev" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__viewport__array = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_viewport_array"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_viewport_array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_viewport_array"; + asd = "cl-glfw-opengl-arb_viewport_array"; + } + ); + systems = [ "cl-glfw-opengl-arb_viewport_array" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-arb__window__pos = ( + build-asdf-system { + pname = "cl-glfw-opengl-arb_window_pos"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-arb_window_pos" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-arb_window_pos"; + asd = "cl-glfw-opengl-arb_window_pos"; + } + ); + systems = [ "cl-glfw-opengl-arb_window_pos" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__draw__buffers = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_draw_buffers"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_draw_buffers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_draw_buffers"; + asd = "cl-glfw-opengl-ati_draw_buffers"; + } + ); + systems = [ "cl-glfw-opengl-ati_draw_buffers" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__element__array = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_element_array"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_element_array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_element_array"; + asd = "cl-glfw-opengl-ati_element_array"; + } + ); + systems = [ "cl-glfw-opengl-ati_element_array" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__envmap__bumpmap = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_envmap_bumpmap"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_envmap_bumpmap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_envmap_bumpmap"; + asd = "cl-glfw-opengl-ati_envmap_bumpmap"; + } + ); + systems = [ "cl-glfw-opengl-ati_envmap_bumpmap" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__fragment__shader = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_fragment_shader"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_fragment_shader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_fragment_shader"; + asd = "cl-glfw-opengl-ati_fragment_shader"; + } + ); + systems = [ "cl-glfw-opengl-ati_fragment_shader" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__map__object__buffer = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_map_object_buffer"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_map_object_buffer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_map_object_buffer"; + asd = "cl-glfw-opengl-ati_map_object_buffer"; + } + ); + systems = [ "cl-glfw-opengl-ati_map_object_buffer" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__meminfo = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_meminfo"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_meminfo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_meminfo"; + asd = "cl-glfw-opengl-ati_meminfo"; + } + ); + systems = [ "cl-glfw-opengl-ati_meminfo" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__pixel__format__float = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_pixel_format_float"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_pixel_format_float" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_pixel_format_float"; + asd = "cl-glfw-opengl-ati_pixel_format_float"; + } + ); + systems = [ "cl-glfw-opengl-ati_pixel_format_float" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__pn__triangles = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_pn_triangles"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_pn_triangles" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_pn_triangles"; + asd = "cl-glfw-opengl-ati_pn_triangles"; + } + ); + systems = [ "cl-glfw-opengl-ati_pn_triangles" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__separate__stencil = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_separate_stencil"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_separate_stencil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_separate_stencil"; + asd = "cl-glfw-opengl-ati_separate_stencil"; + } + ); + systems = [ "cl-glfw-opengl-ati_separate_stencil" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__text__fragment__shader = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_text_fragment_shader"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_text_fragment_shader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_text_fragment_shader"; + asd = "cl-glfw-opengl-ati_text_fragment_shader"; + } + ); + systems = [ "cl-glfw-opengl-ati_text_fragment_shader" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__texture__env__combine3 = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_texture_env_combine3"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_texture_env_combine3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_texture_env_combine3"; + asd = "cl-glfw-opengl-ati_texture_env_combine3"; + } + ); + systems = [ "cl-glfw-opengl-ati_texture_env_combine3" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__texture__float = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_texture_float"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_texture_float" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_texture_float"; + asd = "cl-glfw-opengl-ati_texture_float"; + } + ); + systems = [ "cl-glfw-opengl-ati_texture_float" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__texture__mirror__once = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_texture_mirror_once"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_texture_mirror_once" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_texture_mirror_once"; + asd = "cl-glfw-opengl-ati_texture_mirror_once"; + } + ); + systems = [ "cl-glfw-opengl-ati_texture_mirror_once" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__vertex__array__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_vertex_array_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_vertex_array_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_vertex_array_object"; + asd = "cl-glfw-opengl-ati_vertex_array_object"; + } + ); + systems = [ "cl-glfw-opengl-ati_vertex_array_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__vertex__attrib__array__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_vertex_attrib_array_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_vertex_attrib_array_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_vertex_attrib_array_object"; + asd = "cl-glfw-opengl-ati_vertex_attrib_array_object"; + } + ); + systems = [ "cl-glfw-opengl-ati_vertex_attrib_array_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ati__vertex__streams = ( + build-asdf-system { + pname = "cl-glfw-opengl-ati_vertex_streams"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ati_vertex_streams" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ati_vertex_streams"; + asd = "cl-glfw-opengl-ati_vertex_streams"; + } + ); + systems = [ "cl-glfw-opengl-ati_vertex_streams" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-core = ( + build-asdf-system { + pname = "cl-glfw-opengl-core"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-core"; + asd = "cl-glfw-opengl-core"; + } + ); + systems = [ "cl-glfw-opengl-core" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-glfw-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__422__pixels = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_422_pixels"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_422_pixels" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_422_pixels"; + asd = "cl-glfw-opengl-ext_422_pixels"; + } + ); + systems = [ "cl-glfw-opengl-ext_422_pixels" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__abgr = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_abgr"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_abgr" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_abgr"; + asd = "cl-glfw-opengl-ext_abgr"; + } + ); + systems = [ "cl-glfw-opengl-ext_abgr" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__bgra = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_bgra"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_bgra" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_bgra"; + asd = "cl-glfw-opengl-ext_bgra"; + } + ); + systems = [ "cl-glfw-opengl-ext_bgra" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__bindable__uniform = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_bindable_uniform"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_bindable_uniform" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_bindable_uniform"; + asd = "cl-glfw-opengl-ext_bindable_uniform"; + } + ); + systems = [ "cl-glfw-opengl-ext_bindable_uniform" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__blend__color = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_blend_color"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_blend_color" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_blend_color"; + asd = "cl-glfw-opengl-ext_blend_color"; + } + ); + systems = [ "cl-glfw-opengl-ext_blend_color" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__blend__equation__separate = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_blend_equation_separate"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_blend_equation_separate" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_blend_equation_separate"; + asd = "cl-glfw-opengl-ext_blend_equation_separate"; + } + ); + systems = [ "cl-glfw-opengl-ext_blend_equation_separate" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__blend__func__separate = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_blend_func_separate"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_blend_func_separate" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_blend_func_separate"; + asd = "cl-glfw-opengl-ext_blend_func_separate"; + } + ); + systems = [ "cl-glfw-opengl-ext_blend_func_separate" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__blend__minmax = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_blend_minmax"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_blend_minmax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_blend_minmax"; + asd = "cl-glfw-opengl-ext_blend_minmax"; + } + ); + systems = [ "cl-glfw-opengl-ext_blend_minmax" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__blend__subtract = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_blend_subtract"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_blend_subtract" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_blend_subtract"; + asd = "cl-glfw-opengl-ext_blend_subtract"; + } + ); + systems = [ "cl-glfw-opengl-ext_blend_subtract" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__clip__volume__hint = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_clip_volume_hint"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_clip_volume_hint" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_clip_volume_hint"; + asd = "cl-glfw-opengl-ext_clip_volume_hint"; + } + ); + systems = [ "cl-glfw-opengl-ext_clip_volume_hint" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__cmyka = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_cmyka"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_cmyka" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_cmyka"; + asd = "cl-glfw-opengl-ext_cmyka"; + } + ); + systems = [ "cl-glfw-opengl-ext_cmyka" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__color__subtable = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_color_subtable"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_color_subtable" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_color_subtable"; + asd = "cl-glfw-opengl-ext_color_subtable"; + } + ); + systems = [ "cl-glfw-opengl-ext_color_subtable" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__compiled__vertex__array = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_compiled_vertex_array"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_compiled_vertex_array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_compiled_vertex_array"; + asd = "cl-glfw-opengl-ext_compiled_vertex_array"; + } + ); + systems = [ "cl-glfw-opengl-ext_compiled_vertex_array" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__convolution = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_convolution"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_convolution" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_convolution"; + asd = "cl-glfw-opengl-ext_convolution"; + } + ); + systems = [ "cl-glfw-opengl-ext_convolution" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__coordinate__frame = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_coordinate_frame"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_coordinate_frame" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_coordinate_frame"; + asd = "cl-glfw-opengl-ext_coordinate_frame"; + } + ); + systems = [ "cl-glfw-opengl-ext_coordinate_frame" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__copy__texture = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_copy_texture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_copy_texture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_copy_texture"; + asd = "cl-glfw-opengl-ext_copy_texture"; + } + ); + systems = [ "cl-glfw-opengl-ext_copy_texture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__cull__vertex = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_cull_vertex"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_cull_vertex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_cull_vertex"; + asd = "cl-glfw-opengl-ext_cull_vertex"; + } + ); + systems = [ "cl-glfw-opengl-ext_cull_vertex" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__depth__bounds__test = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_depth_bounds_test"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_depth_bounds_test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_depth_bounds_test"; + asd = "cl-glfw-opengl-ext_depth_bounds_test"; + } + ); + systems = [ "cl-glfw-opengl-ext_depth_bounds_test" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__direct__state__access = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_direct_state_access"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_direct_state_access" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_direct_state_access"; + asd = "cl-glfw-opengl-ext_direct_state_access"; + } + ); + systems = [ "cl-glfw-opengl-ext_direct_state_access" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__draw__buffers2 = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_draw_buffers2"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_draw_buffers2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_draw_buffers2"; + asd = "cl-glfw-opengl-ext_draw_buffers2"; + } + ); + systems = [ "cl-glfw-opengl-ext_draw_buffers2" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__draw__instanced = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_draw_instanced"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_draw_instanced" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_draw_instanced"; + asd = "cl-glfw-opengl-ext_draw_instanced"; + } + ); + systems = [ "cl-glfw-opengl-ext_draw_instanced" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__draw__range__elements = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_draw_range_elements"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_draw_range_elements" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_draw_range_elements"; + asd = "cl-glfw-opengl-ext_draw_range_elements"; + } + ); + systems = [ "cl-glfw-opengl-ext_draw_range_elements" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__fog__coord = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_fog_coord"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_fog_coord" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_fog_coord"; + asd = "cl-glfw-opengl-ext_fog_coord"; + } + ); + systems = [ "cl-glfw-opengl-ext_fog_coord" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__framebuffer__blit = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_framebuffer_blit"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_framebuffer_blit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_framebuffer_blit"; + asd = "cl-glfw-opengl-ext_framebuffer_blit"; + } + ); + systems = [ "cl-glfw-opengl-ext_framebuffer_blit" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__framebuffer__multisample = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_framebuffer_multisample"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_framebuffer_multisample" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_framebuffer_multisample"; + asd = "cl-glfw-opengl-ext_framebuffer_multisample"; + } + ); + systems = [ "cl-glfw-opengl-ext_framebuffer_multisample" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__framebuffer__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_framebuffer_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_framebuffer_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_framebuffer_object"; + asd = "cl-glfw-opengl-ext_framebuffer_object"; + } + ); + systems = [ "cl-glfw-opengl-ext_framebuffer_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__framebuffer__srgb = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_framebuffer_srgb"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_framebuffer_srgb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_framebuffer_srgb"; + asd = "cl-glfw-opengl-ext_framebuffer_srgb"; + } + ); + systems = [ "cl-glfw-opengl-ext_framebuffer_srgb" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__geometry__shader4 = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_geometry_shader4"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_geometry_shader4" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_geometry_shader4"; + asd = "cl-glfw-opengl-ext_geometry_shader4"; + } + ); + systems = [ "cl-glfw-opengl-ext_geometry_shader4" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__gpu__program__parameters = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_gpu_program_parameters"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_gpu_program_parameters" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_gpu_program_parameters"; + asd = "cl-glfw-opengl-ext_gpu_program_parameters"; + } + ); + systems = [ "cl-glfw-opengl-ext_gpu_program_parameters" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__gpu__shader4 = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_gpu_shader4"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_gpu_shader4" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_gpu_shader4"; + asd = "cl-glfw-opengl-ext_gpu_shader4"; + } + ); + systems = [ "cl-glfw-opengl-ext_gpu_shader4" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__histogram = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_histogram"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_histogram" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_histogram"; + asd = "cl-glfw-opengl-ext_histogram"; + } + ); + systems = [ "cl-glfw-opengl-ext_histogram" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__index__array__formats = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_index_array_formats"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_index_array_formats" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_index_array_formats"; + asd = "cl-glfw-opengl-ext_index_array_formats"; + } + ); + systems = [ "cl-glfw-opengl-ext_index_array_formats" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__index__func = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_index_func"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_index_func" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_index_func"; + asd = "cl-glfw-opengl-ext_index_func"; + } + ); + systems = [ "cl-glfw-opengl-ext_index_func" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__index__material = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_index_material"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_index_material" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_index_material"; + asd = "cl-glfw-opengl-ext_index_material"; + } + ); + systems = [ "cl-glfw-opengl-ext_index_material" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__light__texture = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_light_texture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_light_texture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_light_texture"; + asd = "cl-glfw-opengl-ext_light_texture"; + } + ); + systems = [ "cl-glfw-opengl-ext_light_texture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__multi__draw__arrays = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_multi_draw_arrays"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_multi_draw_arrays" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_multi_draw_arrays"; + asd = "cl-glfw-opengl-ext_multi_draw_arrays"; + } + ); + systems = [ "cl-glfw-opengl-ext_multi_draw_arrays" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__multisample = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_multisample"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_multisample" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_multisample"; + asd = "cl-glfw-opengl-ext_multisample"; + } + ); + systems = [ "cl-glfw-opengl-ext_multisample" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__packed__depth__stencil = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_packed_depth_stencil"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_packed_depth_stencil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_packed_depth_stencil"; + asd = "cl-glfw-opengl-ext_packed_depth_stencil"; + } + ); + systems = [ "cl-glfw-opengl-ext_packed_depth_stencil" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__packed__float = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_packed_float"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_packed_float" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_packed_float"; + asd = "cl-glfw-opengl-ext_packed_float"; + } + ); + systems = [ "cl-glfw-opengl-ext_packed_float" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__packed__pixels = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_packed_pixels"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_packed_pixels" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_packed_pixels"; + asd = "cl-glfw-opengl-ext_packed_pixels"; + } + ); + systems = [ "cl-glfw-opengl-ext_packed_pixels" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__paletted__texture = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_paletted_texture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_paletted_texture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_paletted_texture"; + asd = "cl-glfw-opengl-ext_paletted_texture"; + } + ); + systems = [ "cl-glfw-opengl-ext_paletted_texture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__pixel__buffer__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_pixel_buffer_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_pixel_buffer_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_pixel_buffer_object"; + asd = "cl-glfw-opengl-ext_pixel_buffer_object"; + } + ); + systems = [ "cl-glfw-opengl-ext_pixel_buffer_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__pixel__transform = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_pixel_transform"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_pixel_transform" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_pixel_transform"; + asd = "cl-glfw-opengl-ext_pixel_transform"; + } + ); + systems = [ "cl-glfw-opengl-ext_pixel_transform" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__point__parameters = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_point_parameters"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_point_parameters" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_point_parameters"; + asd = "cl-glfw-opengl-ext_point_parameters"; + } + ); + systems = [ "cl-glfw-opengl-ext_point_parameters" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__polygon__offset = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_polygon_offset"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_polygon_offset" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_polygon_offset"; + asd = "cl-glfw-opengl-ext_polygon_offset"; + } + ); + systems = [ "cl-glfw-opengl-ext_polygon_offset" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__provoking__vertex = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_provoking_vertex"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_provoking_vertex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_provoking_vertex"; + asd = "cl-glfw-opengl-ext_provoking_vertex"; + } + ); + systems = [ "cl-glfw-opengl-ext_provoking_vertex" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__secondary__color = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_secondary_color"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_secondary_color" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_secondary_color"; + asd = "cl-glfw-opengl-ext_secondary_color"; + } + ); + systems = [ "cl-glfw-opengl-ext_secondary_color" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__separate__shader__objects = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_separate_shader_objects"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_separate_shader_objects" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_separate_shader_objects"; + asd = "cl-glfw-opengl-ext_separate_shader_objects"; + } + ); + systems = [ "cl-glfw-opengl-ext_separate_shader_objects" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__separate__specular__color = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_separate_specular_color"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_separate_specular_color" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_separate_specular_color"; + asd = "cl-glfw-opengl-ext_separate_specular_color"; + } + ); + systems = [ "cl-glfw-opengl-ext_separate_specular_color" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__shader__image__load__store = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_shader_image_load_store"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_shader_image_load_store" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_shader_image_load_store"; + asd = "cl-glfw-opengl-ext_shader_image_load_store"; + } + ); + systems = [ "cl-glfw-opengl-ext_shader_image_load_store" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__stencil__clear__tag = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_stencil_clear_tag"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_stencil_clear_tag" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_stencil_clear_tag"; + asd = "cl-glfw-opengl-ext_stencil_clear_tag"; + } + ); + systems = [ "cl-glfw-opengl-ext_stencil_clear_tag" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__stencil__two__side = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_stencil_two_side"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_stencil_two_side" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_stencil_two_side"; + asd = "cl-glfw-opengl-ext_stencil_two_side"; + } + ); + systems = [ "cl-glfw-opengl-ext_stencil_two_side" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__stencil__wrap = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_stencil_wrap"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_stencil_wrap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_stencil_wrap"; + asd = "cl-glfw-opengl-ext_stencil_wrap"; + } + ); + systems = [ "cl-glfw-opengl-ext_stencil_wrap" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__subtexture = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_subtexture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_subtexture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_subtexture"; + asd = "cl-glfw-opengl-ext_subtexture"; + } + ); + systems = [ "cl-glfw-opengl-ext_subtexture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture"; + asd = "cl-glfw-opengl-ext_texture"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture3d = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture3d"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture3d" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture3d"; + asd = "cl-glfw-opengl-ext_texture3d"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture3d" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__array = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_array"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_array"; + asd = "cl-glfw-opengl-ext_texture_array"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_array" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__buffer__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_buffer_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_buffer_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_buffer_object"; + asd = "cl-glfw-opengl-ext_texture_buffer_object"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_buffer_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__compression__latc = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_compression_latc"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_compression_latc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_compression_latc"; + asd = "cl-glfw-opengl-ext_texture_compression_latc"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_compression_latc" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__compression__rgtc = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_compression_rgtc"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_compression_rgtc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_compression_rgtc"; + asd = "cl-glfw-opengl-ext_texture_compression_rgtc"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_compression_rgtc" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__compression__s3tc = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_compression_s3tc"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_compression_s3tc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_compression_s3tc"; + asd = "cl-glfw-opengl-ext_texture_compression_s3tc"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_compression_s3tc" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__cube__map = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_cube_map"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_cube_map" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_cube_map"; + asd = "cl-glfw-opengl-ext_texture_cube_map"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_cube_map" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__env__combine = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_env_combine"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_env_combine" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_env_combine"; + asd = "cl-glfw-opengl-ext_texture_env_combine"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_env_combine" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__env__dot3 = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_env_dot3"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_env_dot3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_env_dot3"; + asd = "cl-glfw-opengl-ext_texture_env_dot3"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_env_dot3" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__filter__anisotropic = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_filter_anisotropic"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_filter_anisotropic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_filter_anisotropic"; + asd = "cl-glfw-opengl-ext_texture_filter_anisotropic"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_filter_anisotropic" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__integer = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_integer"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_integer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_integer"; + asd = "cl-glfw-opengl-ext_texture_integer"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_integer" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__lod__bias = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_lod_bias"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_lod_bias" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_lod_bias"; + asd = "cl-glfw-opengl-ext_texture_lod_bias"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_lod_bias" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__mirror__clamp = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_mirror_clamp"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_mirror_clamp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_mirror_clamp"; + asd = "cl-glfw-opengl-ext_texture_mirror_clamp"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_mirror_clamp" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_object"; + asd = "cl-glfw-opengl-ext_texture_object"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__perturb__normal = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_perturb_normal"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_perturb_normal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_perturb_normal"; + asd = "cl-glfw-opengl-ext_texture_perturb_normal"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_perturb_normal" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__shared__exponent = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_shared_exponent"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_shared_exponent" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_shared_exponent"; + asd = "cl-glfw-opengl-ext_texture_shared_exponent"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_shared_exponent" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__snorm = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_snorm"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_snorm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_snorm"; + asd = "cl-glfw-opengl-ext_texture_snorm"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_snorm" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__srgb = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_srgb"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_srgb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_srgb"; + asd = "cl-glfw-opengl-ext_texture_srgb"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_srgb" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__srgb__decode = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_srgb_decode"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_srgb_decode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_srgb_decode"; + asd = "cl-glfw-opengl-ext_texture_srgb_decode"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_srgb_decode" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__texture__swizzle = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_texture_swizzle"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_texture_swizzle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_texture_swizzle"; + asd = "cl-glfw-opengl-ext_texture_swizzle"; + } + ); + systems = [ "cl-glfw-opengl-ext_texture_swizzle" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__timer__query = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_timer_query"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_timer_query" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_timer_query"; + asd = "cl-glfw-opengl-ext_timer_query"; + } + ); + systems = [ "cl-glfw-opengl-ext_timer_query" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__transform__feedback = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_transform_feedback"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_transform_feedback" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_transform_feedback"; + asd = "cl-glfw-opengl-ext_transform_feedback"; + } + ); + systems = [ "cl-glfw-opengl-ext_transform_feedback" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__vertex__array = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_vertex_array"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_vertex_array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_vertex_array"; + asd = "cl-glfw-opengl-ext_vertex_array"; + } + ); + systems = [ "cl-glfw-opengl-ext_vertex_array" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__vertex__array__bgra = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_vertex_array_bgra"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_vertex_array_bgra" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_vertex_array_bgra"; + asd = "cl-glfw-opengl-ext_vertex_array_bgra"; + } + ); + systems = [ "cl-glfw-opengl-ext_vertex_array_bgra" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__vertex__attrib__64bit = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_vertex_attrib_64bit"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_vertex_attrib_64bit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_vertex_attrib_64bit"; + asd = "cl-glfw-opengl-ext_vertex_attrib_64bit"; + } + ); + systems = [ "cl-glfw-opengl-ext_vertex_attrib_64bit" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__vertex__shader = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_vertex_shader"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_vertex_shader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_vertex_shader"; + asd = "cl-glfw-opengl-ext_vertex_shader"; + } + ); + systems = [ "cl-glfw-opengl-ext_vertex_shader" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ext__vertex__weighting = ( + build-asdf-system { + pname = "cl-glfw-opengl-ext_vertex_weighting"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ext_vertex_weighting" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ext_vertex_weighting"; + asd = "cl-glfw-opengl-ext_vertex_weighting"; + } + ); + systems = [ "cl-glfw-opengl-ext_vertex_weighting" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-gremedy__frame__terminator = ( + build-asdf-system { + pname = "cl-glfw-opengl-gremedy_frame_terminator"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-gremedy_frame_terminator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-gremedy_frame_terminator"; + asd = "cl-glfw-opengl-gremedy_frame_terminator"; + } + ); + systems = [ "cl-glfw-opengl-gremedy_frame_terminator" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-gremedy__string__marker = ( + build-asdf-system { + pname = "cl-glfw-opengl-gremedy_string_marker"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-gremedy_string_marker" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-gremedy_string_marker"; + asd = "cl-glfw-opengl-gremedy_string_marker"; + } + ); + systems = [ "cl-glfw-opengl-gremedy_string_marker" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-hp__convolution__border__modes = ( + build-asdf-system { + pname = "cl-glfw-opengl-hp_convolution_border_modes"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-hp_convolution_border_modes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-hp_convolution_border_modes"; + asd = "cl-glfw-opengl-hp_convolution_border_modes"; + } + ); + systems = [ "cl-glfw-opengl-hp_convolution_border_modes" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-hp__image__transform = ( + build-asdf-system { + pname = "cl-glfw-opengl-hp_image_transform"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-hp_image_transform" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-hp_image_transform"; + asd = "cl-glfw-opengl-hp_image_transform"; + } + ); + systems = [ "cl-glfw-opengl-hp_image_transform" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-hp__occlusion__test = ( + build-asdf-system { + pname = "cl-glfw-opengl-hp_occlusion_test"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-hp_occlusion_test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-hp_occlusion_test"; + asd = "cl-glfw-opengl-hp_occlusion_test"; + } + ); + systems = [ "cl-glfw-opengl-hp_occlusion_test" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-hp__texture__lighting = ( + build-asdf-system { + pname = "cl-glfw-opengl-hp_texture_lighting"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-hp_texture_lighting" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-hp_texture_lighting"; + asd = "cl-glfw-opengl-hp_texture_lighting"; + } + ); + systems = [ "cl-glfw-opengl-hp_texture_lighting" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ibm__cull__vertex = ( + build-asdf-system { + pname = "cl-glfw-opengl-ibm_cull_vertex"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ibm_cull_vertex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ibm_cull_vertex"; + asd = "cl-glfw-opengl-ibm_cull_vertex"; + } + ); + systems = [ "cl-glfw-opengl-ibm_cull_vertex" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ibm__multimode__draw__arrays = ( + build-asdf-system { + pname = "cl-glfw-opengl-ibm_multimode_draw_arrays"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ibm_multimode_draw_arrays" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ibm_multimode_draw_arrays"; + asd = "cl-glfw-opengl-ibm_multimode_draw_arrays"; + } + ); + systems = [ "cl-glfw-opengl-ibm_multimode_draw_arrays" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ibm__rasterpos__clip = ( + build-asdf-system { + pname = "cl-glfw-opengl-ibm_rasterpos_clip"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ibm_rasterpos_clip" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ibm_rasterpos_clip"; + asd = "cl-glfw-opengl-ibm_rasterpos_clip"; + } + ); + systems = [ "cl-glfw-opengl-ibm_rasterpos_clip" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ibm__texture__mirrored__repeat = ( + build-asdf-system { + pname = "cl-glfw-opengl-ibm_texture_mirrored_repeat"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ibm_texture_mirrored_repeat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ibm_texture_mirrored_repeat"; + asd = "cl-glfw-opengl-ibm_texture_mirrored_repeat"; + } + ); + systems = [ "cl-glfw-opengl-ibm_texture_mirrored_repeat" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ibm__vertex__array__lists = ( + build-asdf-system { + pname = "cl-glfw-opengl-ibm_vertex_array_lists"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ibm_vertex_array_lists" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ibm_vertex_array_lists"; + asd = "cl-glfw-opengl-ibm_vertex_array_lists"; + } + ); + systems = [ "cl-glfw-opengl-ibm_vertex_array_lists" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ingr__blend__func__separate = ( + build-asdf-system { + pname = "cl-glfw-opengl-ingr_blend_func_separate"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ingr_blend_func_separate" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ingr_blend_func_separate"; + asd = "cl-glfw-opengl-ingr_blend_func_separate"; + } + ); + systems = [ "cl-glfw-opengl-ingr_blend_func_separate" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ingr__color__clamp = ( + build-asdf-system { + pname = "cl-glfw-opengl-ingr_color_clamp"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ingr_color_clamp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ingr_color_clamp"; + asd = "cl-glfw-opengl-ingr_color_clamp"; + } + ); + systems = [ "cl-glfw-opengl-ingr_color_clamp" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-ingr__interlace__read = ( + build-asdf-system { + pname = "cl-glfw-opengl-ingr_interlace_read"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-ingr_interlace_read" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-ingr_interlace_read"; + asd = "cl-glfw-opengl-ingr_interlace_read"; + } + ); + systems = [ "cl-glfw-opengl-ingr_interlace_read" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-intel__parallel__arrays = ( + build-asdf-system { + pname = "cl-glfw-opengl-intel_parallel_arrays"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-intel_parallel_arrays" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-intel_parallel_arrays"; + asd = "cl-glfw-opengl-intel_parallel_arrays"; + } + ); + systems = [ "cl-glfw-opengl-intel_parallel_arrays" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-mesa__pack__invert = ( + build-asdf-system { + pname = "cl-glfw-opengl-mesa_pack_invert"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-mesa_pack_invert" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-mesa_pack_invert"; + asd = "cl-glfw-opengl-mesa_pack_invert"; + } + ); + systems = [ "cl-glfw-opengl-mesa_pack_invert" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-mesa__packed__depth__stencil = ( + build-asdf-system { + pname = "cl-glfw-opengl-mesa_packed_depth_stencil"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-mesa_packed_depth_stencil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-mesa_packed_depth_stencil"; + asd = "cl-glfw-opengl-mesa_packed_depth_stencil"; + } + ); + systems = [ "cl-glfw-opengl-mesa_packed_depth_stencil" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-mesa__program__debug = ( + build-asdf-system { + pname = "cl-glfw-opengl-mesa_program_debug"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-mesa_program_debug" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-mesa_program_debug"; + asd = "cl-glfw-opengl-mesa_program_debug"; + } + ); + systems = [ "cl-glfw-opengl-mesa_program_debug" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-mesa__resize__buffers = ( + build-asdf-system { + pname = "cl-glfw-opengl-mesa_resize_buffers"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-mesa_resize_buffers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-mesa_resize_buffers"; + asd = "cl-glfw-opengl-mesa_resize_buffers"; + } + ); + systems = [ "cl-glfw-opengl-mesa_resize_buffers" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-mesa__shader__debug = ( + build-asdf-system { + pname = "cl-glfw-opengl-mesa_shader_debug"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-mesa_shader_debug" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-mesa_shader_debug"; + asd = "cl-glfw-opengl-mesa_shader_debug"; + } + ); + systems = [ "cl-glfw-opengl-mesa_shader_debug" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-mesa__trace = ( + build-asdf-system { + pname = "cl-glfw-opengl-mesa_trace"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-mesa_trace" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-mesa_trace"; + asd = "cl-glfw-opengl-mesa_trace"; + } + ); + systems = [ "cl-glfw-opengl-mesa_trace" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-mesa__window__pos = ( + build-asdf-system { + pname = "cl-glfw-opengl-mesa_window_pos"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-mesa_window_pos" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-mesa_window_pos"; + asd = "cl-glfw-opengl-mesa_window_pos"; + } + ); + systems = [ "cl-glfw-opengl-mesa_window_pos" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-mesa__ycbcr__texture = ( + build-asdf-system { + pname = "cl-glfw-opengl-mesa_ycbcr_texture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-mesa_ycbcr_texture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-mesa_ycbcr_texture"; + asd = "cl-glfw-opengl-mesa_ycbcr_texture"; + } + ); + systems = [ "cl-glfw-opengl-mesa_ycbcr_texture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-mesax__texture__stack = ( + build-asdf-system { + pname = "cl-glfw-opengl-mesax_texture_stack"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-mesax_texture_stack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-mesax_texture_stack"; + asd = "cl-glfw-opengl-mesax_texture_stack"; + } + ); + systems = [ "cl-glfw-opengl-mesax_texture_stack" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__conditional__render = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_conditional_render"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_conditional_render" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_conditional_render"; + asd = "cl-glfw-opengl-nv_conditional_render"; + } + ); + systems = [ "cl-glfw-opengl-nv_conditional_render" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__copy__depth__to__color = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_copy_depth_to_color"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_copy_depth_to_color" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_copy_depth_to_color"; + asd = "cl-glfw-opengl-nv_copy_depth_to_color"; + } + ); + systems = [ "cl-glfw-opengl-nv_copy_depth_to_color" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__copy__image = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_copy_image"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_copy_image" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_copy_image"; + asd = "cl-glfw-opengl-nv_copy_image"; + } + ); + systems = [ "cl-glfw-opengl-nv_copy_image" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__depth__buffer__float = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_depth_buffer_float"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_depth_buffer_float" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_depth_buffer_float"; + asd = "cl-glfw-opengl-nv_depth_buffer_float"; + } + ); + systems = [ "cl-glfw-opengl-nv_depth_buffer_float" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__depth__clamp = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_depth_clamp"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_depth_clamp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_depth_clamp"; + asd = "cl-glfw-opengl-nv_depth_clamp"; + } + ); + systems = [ "cl-glfw-opengl-nv_depth_clamp" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__evaluators = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_evaluators"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_evaluators" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_evaluators"; + asd = "cl-glfw-opengl-nv_evaluators"; + } + ); + systems = [ "cl-glfw-opengl-nv_evaluators" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__explicit__multisample = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_explicit_multisample"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_explicit_multisample" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_explicit_multisample"; + asd = "cl-glfw-opengl-nv_explicit_multisample"; + } + ); + systems = [ "cl-glfw-opengl-nv_explicit_multisample" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__fence = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_fence"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_fence" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_fence"; + asd = "cl-glfw-opengl-nv_fence"; + } + ); + systems = [ "cl-glfw-opengl-nv_fence" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__float__buffer = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_float_buffer"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_float_buffer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_float_buffer"; + asd = "cl-glfw-opengl-nv_float_buffer"; + } + ); + systems = [ "cl-glfw-opengl-nv_float_buffer" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__fog__distance = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_fog_distance"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_fog_distance" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_fog_distance"; + asd = "cl-glfw-opengl-nv_fog_distance"; + } + ); + systems = [ "cl-glfw-opengl-nv_fog_distance" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__fragment__program = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_fragment_program"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_fragment_program" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_fragment_program"; + asd = "cl-glfw-opengl-nv_fragment_program"; + } + ); + systems = [ "cl-glfw-opengl-nv_fragment_program" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__fragment__program2 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_fragment_program2"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_fragment_program2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_fragment_program2"; + asd = "cl-glfw-opengl-nv_fragment_program2"; + } + ); + systems = [ "cl-glfw-opengl-nv_fragment_program2" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__framebuffer__multisample__coverage = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_framebuffer_multisample_coverage"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_framebuffer_multisample_coverage" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_framebuffer_multisample_coverage"; + asd = "cl-glfw-opengl-nv_framebuffer_multisample_coverage"; + } + ); + systems = [ "cl-glfw-opengl-nv_framebuffer_multisample_coverage" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__geometry__program4 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_geometry_program4"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_geometry_program4" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_geometry_program4"; + asd = "cl-glfw-opengl-nv_geometry_program4"; + } + ); + systems = [ "cl-glfw-opengl-nv_geometry_program4" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__gpu__program4 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_gpu_program4"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_gpu_program4" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_gpu_program4"; + asd = "cl-glfw-opengl-nv_gpu_program4"; + } + ); + systems = [ "cl-glfw-opengl-nv_gpu_program4" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__gpu__program5 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_gpu_program5"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_gpu_program5" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_gpu_program5"; + asd = "cl-glfw-opengl-nv_gpu_program5"; + } + ); + systems = [ "cl-glfw-opengl-nv_gpu_program5" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__gpu__shader5 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_gpu_shader5"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_gpu_shader5" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_gpu_shader5"; + asd = "cl-glfw-opengl-nv_gpu_shader5"; + } + ); + systems = [ "cl-glfw-opengl-nv_gpu_shader5" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__half__float = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_half_float"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_half_float" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_half_float"; + asd = "cl-glfw-opengl-nv_half_float"; + } + ); + systems = [ "cl-glfw-opengl-nv_half_float" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__light__max__exponent = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_light_max_exponent"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_light_max_exponent" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_light_max_exponent"; + asd = "cl-glfw-opengl-nv_light_max_exponent"; + } + ); + systems = [ "cl-glfw-opengl-nv_light_max_exponent" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__multisample__coverage = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_multisample_coverage"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_multisample_coverage" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_multisample_coverage"; + asd = "cl-glfw-opengl-nv_multisample_coverage"; + } + ); + systems = [ "cl-glfw-opengl-nv_multisample_coverage" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__multisample__filter__hint = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_multisample_filter_hint"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_multisample_filter_hint" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_multisample_filter_hint"; + asd = "cl-glfw-opengl-nv_multisample_filter_hint"; + } + ); + systems = [ "cl-glfw-opengl-nv_multisample_filter_hint" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__occlusion__query = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_occlusion_query"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_occlusion_query" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_occlusion_query"; + asd = "cl-glfw-opengl-nv_occlusion_query"; + } + ); + systems = [ "cl-glfw-opengl-nv_occlusion_query" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__packed__depth__stencil = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_packed_depth_stencil"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_packed_depth_stencil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_packed_depth_stencil"; + asd = "cl-glfw-opengl-nv_packed_depth_stencil"; + } + ); + systems = [ "cl-glfw-opengl-nv_packed_depth_stencil" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__parameter__buffer__object = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_parameter_buffer_object"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_parameter_buffer_object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_parameter_buffer_object"; + asd = "cl-glfw-opengl-nv_parameter_buffer_object"; + } + ); + systems = [ "cl-glfw-opengl-nv_parameter_buffer_object" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__pixel__data__range = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_pixel_data_range"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_pixel_data_range" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_pixel_data_range"; + asd = "cl-glfw-opengl-nv_pixel_data_range"; + } + ); + systems = [ "cl-glfw-opengl-nv_pixel_data_range" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__point__sprite = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_point_sprite"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_point_sprite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_point_sprite"; + asd = "cl-glfw-opengl-nv_point_sprite"; + } + ); + systems = [ "cl-glfw-opengl-nv_point_sprite" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__present__video = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_present_video"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_present_video" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_present_video"; + asd = "cl-glfw-opengl-nv_present_video"; + } + ); + systems = [ "cl-glfw-opengl-nv_present_video" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__primitive__restart = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_primitive_restart"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_primitive_restart" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_primitive_restart"; + asd = "cl-glfw-opengl-nv_primitive_restart"; + } + ); + systems = [ "cl-glfw-opengl-nv_primitive_restart" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__register__combiners = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_register_combiners"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_register_combiners" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_register_combiners"; + asd = "cl-glfw-opengl-nv_register_combiners"; + } + ); + systems = [ "cl-glfw-opengl-nv_register_combiners" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__register__combiners2 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_register_combiners2"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_register_combiners2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_register_combiners2"; + asd = "cl-glfw-opengl-nv_register_combiners2"; + } + ); + systems = [ "cl-glfw-opengl-nv_register_combiners2" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__shader__buffer__load = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_shader_buffer_load"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_shader_buffer_load" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_shader_buffer_load"; + asd = "cl-glfw-opengl-nv_shader_buffer_load"; + } + ); + systems = [ "cl-glfw-opengl-nv_shader_buffer_load" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__shader__buffer__store = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_shader_buffer_store"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_shader_buffer_store" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_shader_buffer_store"; + asd = "cl-glfw-opengl-nv_shader_buffer_store"; + } + ); + systems = [ "cl-glfw-opengl-nv_shader_buffer_store" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__tessellation__program5 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_tessellation_program5"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_tessellation_program5" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_tessellation_program5"; + asd = "cl-glfw-opengl-nv_tessellation_program5"; + } + ); + systems = [ "cl-glfw-opengl-nv_tessellation_program5" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__texgen__emboss = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_texgen_emboss"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_texgen_emboss" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_texgen_emboss"; + asd = "cl-glfw-opengl-nv_texgen_emboss"; + } + ); + systems = [ "cl-glfw-opengl-nv_texgen_emboss" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__texgen__reflection = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_texgen_reflection"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_texgen_reflection" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_texgen_reflection"; + asd = "cl-glfw-opengl-nv_texgen_reflection"; + } + ); + systems = [ "cl-glfw-opengl-nv_texgen_reflection" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__texture__barrier = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_texture_barrier"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_texture_barrier" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_texture_barrier"; + asd = "cl-glfw-opengl-nv_texture_barrier"; + } + ); + systems = [ "cl-glfw-opengl-nv_texture_barrier" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__texture__env__combine4 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_texture_env_combine4"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_texture_env_combine4" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_texture_env_combine4"; + asd = "cl-glfw-opengl-nv_texture_env_combine4"; + } + ); + systems = [ "cl-glfw-opengl-nv_texture_env_combine4" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__texture__expand__normal = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_texture_expand_normal"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_texture_expand_normal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_texture_expand_normal"; + asd = "cl-glfw-opengl-nv_texture_expand_normal"; + } + ); + systems = [ "cl-glfw-opengl-nv_texture_expand_normal" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__texture__multisample = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_texture_multisample"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_texture_multisample" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_texture_multisample"; + asd = "cl-glfw-opengl-nv_texture_multisample"; + } + ); + systems = [ "cl-glfw-opengl-nv_texture_multisample" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__texture__rectangle = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_texture_rectangle"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_texture_rectangle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_texture_rectangle"; + asd = "cl-glfw-opengl-nv_texture_rectangle"; + } + ); + systems = [ "cl-glfw-opengl-nv_texture_rectangle" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__texture__shader = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_texture_shader"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_texture_shader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_texture_shader"; + asd = "cl-glfw-opengl-nv_texture_shader"; + } + ); + systems = [ "cl-glfw-opengl-nv_texture_shader" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__texture__shader2 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_texture_shader2"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_texture_shader2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_texture_shader2"; + asd = "cl-glfw-opengl-nv_texture_shader2"; + } + ); + systems = [ "cl-glfw-opengl-nv_texture_shader2" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__texture__shader3 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_texture_shader3"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_texture_shader3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_texture_shader3"; + asd = "cl-glfw-opengl-nv_texture_shader3"; + } + ); + systems = [ "cl-glfw-opengl-nv_texture_shader3" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__transform__feedback = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_transform_feedback"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_transform_feedback" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_transform_feedback"; + asd = "cl-glfw-opengl-nv_transform_feedback"; + } + ); + systems = [ "cl-glfw-opengl-nv_transform_feedback" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__transform__feedback2 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_transform_feedback2"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_transform_feedback2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_transform_feedback2"; + asd = "cl-glfw-opengl-nv_transform_feedback2"; + } + ); + systems = [ "cl-glfw-opengl-nv_transform_feedback2" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__vertex__array__range = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_vertex_array_range"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_vertex_array_range" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_vertex_array_range"; + asd = "cl-glfw-opengl-nv_vertex_array_range"; + } + ); + systems = [ "cl-glfw-opengl-nv_vertex_array_range" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__vertex__array__range2 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_vertex_array_range2"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_vertex_array_range2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_vertex_array_range2"; + asd = "cl-glfw-opengl-nv_vertex_array_range2"; + } + ); + systems = [ "cl-glfw-opengl-nv_vertex_array_range2" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__vertex__attrib__integer__64bit = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_vertex_attrib_integer_64bit"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_vertex_attrib_integer_64bit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_vertex_attrib_integer_64bit"; + asd = "cl-glfw-opengl-nv_vertex_attrib_integer_64bit"; + } + ); + systems = [ "cl-glfw-opengl-nv_vertex_attrib_integer_64bit" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__vertex__buffer__unified__memory = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_vertex_buffer_unified_memory"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_vertex_buffer_unified_memory" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_vertex_buffer_unified_memory"; + asd = "cl-glfw-opengl-nv_vertex_buffer_unified_memory"; + } + ); + systems = [ "cl-glfw-opengl-nv_vertex_buffer_unified_memory" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__vertex__program = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_vertex_program"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_vertex_program" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_vertex_program"; + asd = "cl-glfw-opengl-nv_vertex_program"; + } + ); + systems = [ "cl-glfw-opengl-nv_vertex_program" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__vertex__program2__option = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_vertex_program2_option"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_vertex_program2_option" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_vertex_program2_option"; + asd = "cl-glfw-opengl-nv_vertex_program2_option"; + } + ); + systems = [ "cl-glfw-opengl-nv_vertex_program2_option" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__vertex__program3 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_vertex_program3"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_vertex_program3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_vertex_program3"; + asd = "cl-glfw-opengl-nv_vertex_program3"; + } + ); + systems = [ "cl-glfw-opengl-nv_vertex_program3" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-nv__vertex__program4 = ( + build-asdf-system { + pname = "cl-glfw-opengl-nv_vertex_program4"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-nv_vertex_program4" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-nv_vertex_program4"; + asd = "cl-glfw-opengl-nv_vertex_program4"; + } + ); + systems = [ "cl-glfw-opengl-nv_vertex_program4" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-oes__read__format = ( + build-asdf-system { + pname = "cl-glfw-opengl-oes_read_format"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-oes_read_format" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-oes_read_format"; + asd = "cl-glfw-opengl-oes_read_format"; + } + ); + systems = [ "cl-glfw-opengl-oes_read_format" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-oml__interlace = ( + build-asdf-system { + pname = "cl-glfw-opengl-oml_interlace"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-oml_interlace" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-oml_interlace"; + asd = "cl-glfw-opengl-oml_interlace"; + } + ); + systems = [ "cl-glfw-opengl-oml_interlace" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-oml__resample = ( + build-asdf-system { + pname = "cl-glfw-opengl-oml_resample"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-oml_resample" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-oml_resample"; + asd = "cl-glfw-opengl-oml_resample"; + } + ); + systems = [ "cl-glfw-opengl-oml_resample" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-oml__subsample = ( + build-asdf-system { + pname = "cl-glfw-opengl-oml_subsample"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-oml_subsample" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-oml_subsample"; + asd = "cl-glfw-opengl-oml_subsample"; + } + ); + systems = [ "cl-glfw-opengl-oml_subsample" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-pgi__misc__hints = ( + build-asdf-system { + pname = "cl-glfw-opengl-pgi_misc_hints"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-pgi_misc_hints" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-pgi_misc_hints"; + asd = "cl-glfw-opengl-pgi_misc_hints"; + } + ); + systems = [ "cl-glfw-opengl-pgi_misc_hints" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-pgi__vertex__hints = ( + build-asdf-system { + pname = "cl-glfw-opengl-pgi_vertex_hints"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-pgi_vertex_hints" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-pgi_vertex_hints"; + asd = "cl-glfw-opengl-pgi_vertex_hints"; + } + ); + systems = [ "cl-glfw-opengl-pgi_vertex_hints" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-rend__screen__coordinates = ( + build-asdf-system { + pname = "cl-glfw-opengl-rend_screen_coordinates"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-rend_screen_coordinates" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-rend_screen_coordinates"; + asd = "cl-glfw-opengl-rend_screen_coordinates"; + } + ); + systems = [ "cl-glfw-opengl-rend_screen_coordinates" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-s3__s3tc = ( + build-asdf-system { + pname = "cl-glfw-opengl-s3_s3tc"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-s3_s3tc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-s3_s3tc"; + asd = "cl-glfw-opengl-s3_s3tc"; + } + ); + systems = [ "cl-glfw-opengl-s3_s3tc" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgi__color__table = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgi_color_table"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgi_color_table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgi_color_table"; + asd = "cl-glfw-opengl-sgi_color_table"; + } + ); + systems = [ "cl-glfw-opengl-sgi_color_table" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgi__depth__pass__instrument = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgi_depth_pass_instrument"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgi_depth_pass_instrument" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgi_depth_pass_instrument"; + asd = "cl-glfw-opengl-sgi_depth_pass_instrument"; + } + ); + systems = [ "cl-glfw-opengl-sgi_depth_pass_instrument" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgis__detail__texture = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgis_detail_texture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgis_detail_texture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgis_detail_texture"; + asd = "cl-glfw-opengl-sgis_detail_texture"; + } + ); + systems = [ "cl-glfw-opengl-sgis_detail_texture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgis__fog__function = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgis_fog_function"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgis_fog_function" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgis_fog_function"; + asd = "cl-glfw-opengl-sgis_fog_function"; + } + ); + systems = [ "cl-glfw-opengl-sgis_fog_function" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgis__multisample = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgis_multisample"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgis_multisample" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgis_multisample"; + asd = "cl-glfw-opengl-sgis_multisample"; + } + ); + systems = [ "cl-glfw-opengl-sgis_multisample" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgis__pixel__texture = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgis_pixel_texture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgis_pixel_texture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgis_pixel_texture"; + asd = "cl-glfw-opengl-sgis_pixel_texture"; + } + ); + systems = [ "cl-glfw-opengl-sgis_pixel_texture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgis__point__parameters = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgis_point_parameters"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgis_point_parameters" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgis_point_parameters"; + asd = "cl-glfw-opengl-sgis_point_parameters"; + } + ); + systems = [ "cl-glfw-opengl-sgis_point_parameters" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgis__sharpen__texture = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgis_sharpen_texture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgis_sharpen_texture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgis_sharpen_texture"; + asd = "cl-glfw-opengl-sgis_sharpen_texture"; + } + ); + systems = [ "cl-glfw-opengl-sgis_sharpen_texture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgis__texture4d = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgis_texture4d"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgis_texture4d" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgis_texture4d"; + asd = "cl-glfw-opengl-sgis_texture4d"; + } + ); + systems = [ "cl-glfw-opengl-sgis_texture4d" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgis__texture__color__mask = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgis_texture_color_mask"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgis_texture_color_mask" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgis_texture_color_mask"; + asd = "cl-glfw-opengl-sgis_texture_color_mask"; + } + ); + systems = [ "cl-glfw-opengl-sgis_texture_color_mask" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgis__texture__filter4 = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgis_texture_filter4"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgis_texture_filter4" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgis_texture_filter4"; + asd = "cl-glfw-opengl-sgis_texture_filter4"; + } + ); + systems = [ "cl-glfw-opengl-sgis_texture_filter4" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgis__texture__select = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgis_texture_select"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgis_texture_select" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgis_texture_select"; + asd = "cl-glfw-opengl-sgis_texture_select"; + } + ); + systems = [ "cl-glfw-opengl-sgis_texture_select" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__async = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_async"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_async" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_async"; + asd = "cl-glfw-opengl-sgix_async"; + } + ); + systems = [ "cl-glfw-opengl-sgix_async" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__depth__texture = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_depth_texture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_depth_texture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_depth_texture"; + asd = "cl-glfw-opengl-sgix_depth_texture"; + } + ); + systems = [ "cl-glfw-opengl-sgix_depth_texture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__flush__raster = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_flush_raster"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_flush_raster" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_flush_raster"; + asd = "cl-glfw-opengl-sgix_flush_raster"; + } + ); + systems = [ "cl-glfw-opengl-sgix_flush_raster" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__fog__scale = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_fog_scale"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_fog_scale" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_fog_scale"; + asd = "cl-glfw-opengl-sgix_fog_scale"; + } + ); + systems = [ "cl-glfw-opengl-sgix_fog_scale" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__fragment__lighting = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_fragment_lighting"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_fragment_lighting" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_fragment_lighting"; + asd = "cl-glfw-opengl-sgix_fragment_lighting"; + } + ); + systems = [ "cl-glfw-opengl-sgix_fragment_lighting" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__framezoom = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_framezoom"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_framezoom" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_framezoom"; + asd = "cl-glfw-opengl-sgix_framezoom"; + } + ); + systems = [ "cl-glfw-opengl-sgix_framezoom" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__igloo__interface = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_igloo_interface"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_igloo_interface" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_igloo_interface"; + asd = "cl-glfw-opengl-sgix_igloo_interface"; + } + ); + systems = [ "cl-glfw-opengl-sgix_igloo_interface" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__instruments = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_instruments"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_instruments" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_instruments"; + asd = "cl-glfw-opengl-sgix_instruments"; + } + ); + systems = [ "cl-glfw-opengl-sgix_instruments" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__line__quality__hint = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_line_quality_hint"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_line_quality_hint" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_line_quality_hint"; + asd = "cl-glfw-opengl-sgix_line_quality_hint"; + } + ); + systems = [ "cl-glfw-opengl-sgix_line_quality_hint" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__list__priority = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_list_priority"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_list_priority" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_list_priority"; + asd = "cl-glfw-opengl-sgix_list_priority"; + } + ); + systems = [ "cl-glfw-opengl-sgix_list_priority" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__pixel__texture = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_pixel_texture"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_pixel_texture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_pixel_texture"; + asd = "cl-glfw-opengl-sgix_pixel_texture"; + } + ); + systems = [ "cl-glfw-opengl-sgix_pixel_texture" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__polynomial__ffd = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_polynomial_ffd"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_polynomial_ffd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_polynomial_ffd"; + asd = "cl-glfw-opengl-sgix_polynomial_ffd"; + } + ); + systems = [ "cl-glfw-opengl-sgix_polynomial_ffd" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__reference__plane = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_reference_plane"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_reference_plane" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_reference_plane"; + asd = "cl-glfw-opengl-sgix_reference_plane"; + } + ); + systems = [ "cl-glfw-opengl-sgix_reference_plane" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__resample = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_resample"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_resample" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_resample"; + asd = "cl-glfw-opengl-sgix_resample"; + } + ); + systems = [ "cl-glfw-opengl-sgix_resample" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__scalebias__hint = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_scalebias_hint"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_scalebias_hint" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_scalebias_hint"; + asd = "cl-glfw-opengl-sgix_scalebias_hint"; + } + ); + systems = [ "cl-glfw-opengl-sgix_scalebias_hint" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__shadow = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_shadow"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_shadow" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_shadow"; + asd = "cl-glfw-opengl-sgix_shadow"; + } + ); + systems = [ "cl-glfw-opengl-sgix_shadow" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__shadow__ambient = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_shadow_ambient"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_shadow_ambient" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_shadow_ambient"; + asd = "cl-glfw-opengl-sgix_shadow_ambient"; + } + ); + systems = [ "cl-glfw-opengl-sgix_shadow_ambient" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__slim = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_slim"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_slim" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_slim"; + asd = "cl-glfw-opengl-sgix_slim"; + } + ); + systems = [ "cl-glfw-opengl-sgix_slim" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__sprite = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_sprite"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_sprite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_sprite"; + asd = "cl-glfw-opengl-sgix_sprite"; + } + ); + systems = [ "cl-glfw-opengl-sgix_sprite" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__tag__sample__buffer = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_tag_sample_buffer"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_tag_sample_buffer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_tag_sample_buffer"; + asd = "cl-glfw-opengl-sgix_tag_sample_buffer"; + } + ); + systems = [ "cl-glfw-opengl-sgix_tag_sample_buffer" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__texture__coordinate__clamp = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_texture_coordinate_clamp"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_texture_coordinate_clamp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_texture_coordinate_clamp"; + asd = "cl-glfw-opengl-sgix_texture_coordinate_clamp"; + } + ); + systems = [ "cl-glfw-opengl-sgix_texture_coordinate_clamp" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__texture__lod__bias = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_texture_lod_bias"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_texture_lod_bias" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_texture_lod_bias"; + asd = "cl-glfw-opengl-sgix_texture_lod_bias"; + } + ); + systems = [ "cl-glfw-opengl-sgix_texture_lod_bias" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__texture__multi__buffer = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_texture_multi_buffer"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_texture_multi_buffer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_texture_multi_buffer"; + asd = "cl-glfw-opengl-sgix_texture_multi_buffer"; + } + ); + systems = [ "cl-glfw-opengl-sgix_texture_multi_buffer" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sgix__ycrcba = ( + build-asdf-system { + pname = "cl-glfw-opengl-sgix_ycrcba"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sgix_ycrcba" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sgix_ycrcba"; + asd = "cl-glfw-opengl-sgix_ycrcba"; + } + ); + systems = [ "cl-glfw-opengl-sgix_ycrcba" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sun__convolution__border__modes = ( + build-asdf-system { + pname = "cl-glfw-opengl-sun_convolution_border_modes"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sun_convolution_border_modes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sun_convolution_border_modes"; + asd = "cl-glfw-opengl-sun_convolution_border_modes"; + } + ); + systems = [ "cl-glfw-opengl-sun_convolution_border_modes" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sun__global__alpha = ( + build-asdf-system { + pname = "cl-glfw-opengl-sun_global_alpha"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sun_global_alpha" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sun_global_alpha"; + asd = "cl-glfw-opengl-sun_global_alpha"; + } + ); + systems = [ "cl-glfw-opengl-sun_global_alpha" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sun__mesh__array = ( + build-asdf-system { + pname = "cl-glfw-opengl-sun_mesh_array"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sun_mesh_array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sun_mesh_array"; + asd = "cl-glfw-opengl-sun_mesh_array"; + } + ); + systems = [ "cl-glfw-opengl-sun_mesh_array" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sun__slice__accum = ( + build-asdf-system { + pname = "cl-glfw-opengl-sun_slice_accum"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sun_slice_accum" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sun_slice_accum"; + asd = "cl-glfw-opengl-sun_slice_accum"; + } + ); + systems = [ "cl-glfw-opengl-sun_slice_accum" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sun__triangle__list = ( + build-asdf-system { + pname = "cl-glfw-opengl-sun_triangle_list"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sun_triangle_list" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sun_triangle_list"; + asd = "cl-glfw-opengl-sun_triangle_list"; + } + ); + systems = [ "cl-glfw-opengl-sun_triangle_list" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sun__vertex = ( + build-asdf-system { + pname = "cl-glfw-opengl-sun_vertex"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sun_vertex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sun_vertex"; + asd = "cl-glfw-opengl-sun_vertex"; + } + ); + systems = [ "cl-glfw-opengl-sun_vertex" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-sunx__constant__data = ( + build-asdf-system { + pname = "cl-glfw-opengl-sunx_constant_data"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-sunx_constant_data" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-sunx_constant_data"; + asd = "cl-glfw-opengl-sunx_constant_data"; + } + ); + systems = [ "cl-glfw-opengl-sunx_constant_data" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-version__1__0 = ( + build-asdf-system { + pname = "cl-glfw-opengl-version_1_0"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-version_1_0" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-version_1_0"; + asd = "cl-glfw-opengl-version_1_0"; + } + ); + systems = [ "cl-glfw-opengl-version_1_0" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-version__1__1 = ( + build-asdf-system { + pname = "cl-glfw-opengl-version_1_1"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-version_1_1" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-version_1_1"; + asd = "cl-glfw-opengl-version_1_1"; + } + ); + systems = [ "cl-glfw-opengl-version_1_1" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-version__1__2 = ( + build-asdf-system { + pname = "cl-glfw-opengl-version_1_2"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-version_1_2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-version_1_2"; + asd = "cl-glfw-opengl-version_1_2"; + } + ); + systems = [ "cl-glfw-opengl-version_1_2" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-version__1__3 = ( + build-asdf-system { + pname = "cl-glfw-opengl-version_1_3"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-version_1_3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-version_1_3"; + asd = "cl-glfw-opengl-version_1_3"; + } + ); + systems = [ "cl-glfw-opengl-version_1_3" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-version__1__4 = ( + build-asdf-system { + pname = "cl-glfw-opengl-version_1_4"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-version_1_4" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-version_1_4"; + asd = "cl-glfw-opengl-version_1_4"; + } + ); + systems = [ "cl-glfw-opengl-version_1_4" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-version__1__5 = ( + build-asdf-system { + pname = "cl-glfw-opengl-version_1_5"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-version_1_5" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-version_1_5"; + asd = "cl-glfw-opengl-version_1_5"; + } + ); + systems = [ "cl-glfw-opengl-version_1_5" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-version__2__0 = ( + build-asdf-system { + pname = "cl-glfw-opengl-version_2_0"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-version_2_0" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-version_2_0"; + asd = "cl-glfw-opengl-version_2_0"; + } + ); + systems = [ "cl-glfw-opengl-version_2_0" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-version__2__1 = ( + build-asdf-system { + pname = "cl-glfw-opengl-version_2_1"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-version_2_1" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-version_2_1"; + asd = "cl-glfw-opengl-version_2_1"; + } + ); + systems = [ "cl-glfw-opengl-version_2_1" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-win__phong__shading = ( + build-asdf-system { + pname = "cl-glfw-opengl-win_phong_shading"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-win_phong_shading" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-win_phong_shading"; + asd = "cl-glfw-opengl-win_phong_shading"; + } + ); + systems = [ "cl-glfw-opengl-win_phong_shading" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-opengl-win__specular__fog = ( + build-asdf-system { + pname = "cl-glfw-opengl-win_specular_fog"; + version = "20150302-git"; + asds = [ "cl-glfw-opengl-win_specular_fog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-opengl-win_specular_fog"; + asd = "cl-glfw-opengl-win_specular_fog"; + } + ); + systems = [ "cl-glfw-opengl-win_specular_fog" ]; + lispLibs = [ (getAttr "cl-glfw-opengl-core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw-types = ( + build-asdf-system { + pname = "cl-glfw-types"; + version = "20150302-git"; + asds = [ "cl-glfw-types" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw/2015-03-02/cl-glfw-20150302-git.tgz"; + sha256 = "07zgrvv480h1xid1f50vj61d1xcrick2dqw04swac4137w9rwpj6"; + system = "cl-glfw-types"; + asd = "cl-glfw-types"; + } + ); + systems = [ "cl-glfw-types" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw3 = ( + build-asdf-system { + pname = "cl-glfw3"; + version = "20210531-git"; + asds = [ "cl-glfw3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw3/2021-05-31/cl-glfw3-20210531-git.tgz"; + sha256 = "1wzr43nckdx4rlgxzhm1r4kfc264q969mc43y0js9ramh7l8gba5"; + system = "cl-glfw3"; + asd = "cl-glfw3"; + } + ); + systems = [ "cl-glfw3" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glfw3-examples = ( + build-asdf-system { + pname = "cl-glfw3-examples"; + version = "20210531-git"; + asds = [ "cl-glfw3-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glfw3/2021-05-31/cl-glfw3-20210531-git.tgz"; + sha256 = "1wzr43nckdx4rlgxzhm1r4kfc264q969mc43y0js9ramh7l8gba5"; + system = "cl-glfw3-examples"; + asd = "cl-glfw3-examples"; + } + ); + systems = [ "cl-glfw3-examples" ]; + lispLibs = [ + (getAttr "cl-glfw3" self) + (getAttr "cl-opengl" self) + (getAttr "trivial-main-thread" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glib = ( + build-asdf-system { + pname = "cl-glib"; + version = "20231021-git"; + asds = [ "cl-glib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glib/2023-10-21/cl-glib-20231021-git.tgz"; + sha256 = "07y8hpvdl490p8j4k8y47raqqwnpym9scz7jlg2f1jx897dkssjb"; + system = "cl-glib"; + asd = "cl-glib"; + } + ); + systems = [ "cl-glib" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-gobject-introspection-wrapper" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gltf = ( + build-asdf-system { + pname = "cl-gltf"; + version = "20241012-git"; + asds = [ "cl-gltf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gltf/2024-10-12/cl-gltf-20241012-git.tgz"; + sha256 = "0s7q6zsy85wryy3wb2hn3nprh1m4vmjzsai1mdcqlhzqyh5rm6jq"; + system = "cl-gltf"; + asd = "cl-gltf"; + } + ); + systems = [ "cl-gltf" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "com_dot_inuoe_dot_jzon" self) + (getAttr "documentation-utils" self) + (getAttr "mmap" self) + (getAttr "nibbles" self) + (getAttr "qbase64" self) + (getAttr "static-vectors" self) + (getAttr "trivial-extensible-sequences" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glu = ( + build-asdf-system { + pname = "cl-glu"; + version = "20241012-git"; + asds = [ "cl-glu" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opengl/2024-10-12/cl-opengl-20241012-git.tgz"; + sha256 = "1xpa3x9fx7wxrs5xmkj13yzh2wjfnlb0ihirfr9clngpv1y4gcm6"; + system = "cl-glu"; + asd = "cl-glu"; + } + ); + systems = [ "cl-glu" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-opengl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glut = ( + build-asdf-system { + pname = "cl-glut"; + version = "20241012-git"; + asds = [ "cl-glut" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opengl/2024-10-12/cl-opengl-20241012-git.tgz"; + sha256 = "1xpa3x9fx7wxrs5xmkj13yzh2wjfnlb0ihirfr9clngpv1y4gcm6"; + system = "cl-glut"; + asd = "cl-glut"; + } + ); + systems = [ "cl-glut" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-opengl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-glut-examples = ( + build-asdf-system { + pname = "cl-glut-examples"; + version = "20241012-git"; + asds = [ "cl-glut-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opengl/2024-10-12/cl-opengl-20241012-git.tgz"; + sha256 = "1xpa3x9fx7wxrs5xmkj13yzh2wjfnlb0ihirfr9clngpv1y4gcm6"; + system = "cl-glut-examples"; + asd = "cl-glut-examples"; + } + ); + systems = [ "cl-glut-examples" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-glu" self) + (getAttr "cl-glut" self) + (getAttr "cl-opengl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gobject = ( + build-asdf-system { + pname = "cl-gobject"; + version = "20231021-git"; + asds = [ "cl-gobject" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-glib/2023-10-21/cl-glib-20231021-git.tgz"; + sha256 = "07y8hpvdl490p8j4k8y47raqqwnpym9scz7jlg2f1jx897dkssjb"; + system = "cl-gobject"; + asd = "cl-gobject"; + } + ); + systems = [ "cl-gobject" ]; + lispLibs = [ (getAttr "cl-gobject-introspection-wrapper" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gobject-introspection = ( + build-asdf-system { + pname = "cl-gobject-introspection"; + version = "20241012-git"; + asds = [ "cl-gobject-introspection" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gobject-introspection/2024-10-12/cl-gobject-introspection-20241012-git.tgz"; + sha256 = "0iw8fciydh9bi2svq30hi029df16arpspk0mjzh0cm1c6kjm9dcj"; + system = "cl-gobject-introspection"; + asd = "cl-gobject-introspection"; + } + ); + systems = [ "cl-gobject-introspection" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "iterate" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + cl-gobject-introspection-test = ( + build-asdf-system { + pname = "cl-gobject-introspection-test"; + version = "20241012-git"; + asds = [ "cl-gobject-introspection-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gobject-introspection/2024-10-12/cl-gobject-introspection-20241012-git.tgz"; + sha256 = "0iw8fciydh9bi2svq30hi029df16arpspk0mjzh0cm1c6kjm9dcj"; + system = "cl-gobject-introspection-test"; + asd = "cl-gobject-introspection-test"; + } + ); + systems = [ "cl-gobject-introspection-test" ]; + lispLibs = [ + (getAttr "cl-gobject-introspection" self) + (getAttr "fiveam" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gobject-introspection-wrapper = ( + build-asdf-system { + pname = "cl-gobject-introspection-wrapper"; + version = "20231021-git"; + asds = [ "cl-gobject-introspection-wrapper" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gobject-introspection-wrapper/2023-10-21/cl-gobject-introspection-wrapper-20231021-git.tgz"; + sha256 = "0x1nryxkv6i0bzn2zmlsgbq0impni4drzawy3wc7zy5nr2qnd1x5"; + system = "cl-gobject-introspection-wrapper"; + asd = "cl-gobject-introspection-wrapper"; + } + ); + systems = [ "cl-gobject-introspection-wrapper" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-gobject-introspection" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gog-galaxy = ( + build-asdf-system { + pname = "cl-gog-galaxy"; + version = "20241012-git"; + asds = [ "cl-gog-galaxy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gog-galaxy/2024-10-12/cl-gog-galaxy-20241012-git.tgz"; + sha256 = "0pb8q4q1gj4n8ll5cglip4rl9gqy8y0g9kpqn2xkc3lssvxkkh63"; + system = "cl-gog-galaxy"; + asd = "cl-gog-galaxy"; + } + ); + systems = [ "cl-gog-galaxy" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + (getAttr "trivial-indent" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gopher = ( + build-asdf-system { + pname = "cl-gopher"; + version = "20231021-git"; + asds = [ "cl-gopher" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gopher/2023-10-21/cl-gopher-20231021-git.tgz"; + sha256 = "0x8rj4icrx04rfh9qlh7hp2c0zyk4ii6s4wqwhqjxh5580mwblgb"; + system = "cl-gopher"; + asd = "cl-gopher"; + } + ); + systems = [ "cl-gopher" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + (getAttr "quri" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gpio = ( + build-asdf-system { + pname = "cl-gpio"; + version = "20231021-git"; + asds = [ "cl-gpio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gpio/2023-10-21/cl-gpio-20231021-git.tgz"; + sha256 = "0sh40fg9gcz72xsfi17zh1b1wckw4fsyx75kkm2w3757lx69wkmh"; + system = "cl-gpio"; + asd = "cl-gpio"; + } + ); + systems = [ "cl-gpio" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-graph = ( + build-asdf-system { + pname = "cl-graph"; + version = "20241012-git"; + asds = [ "cl-graph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-graph/2024-10-12/cl-graph-20241012-git.tgz"; + sha256 = "1adwlkj2qp73irsswfi50ayjvz3di8fh1sqavsdl7l2d6k7yipdg"; + system = "cl-graph"; + asd = "cl-graph"; + } + ); + systems = [ "cl-graph" ]; + lispLibs = [ + (getAttr "asdf-system-connections" self) + (getAttr "cl-containers" self) + (getAttr "metabang-bind" self) + (getAttr "metatilities-base" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-graph_plus_hu_dot_dwim_dot_graphviz = ( + build-asdf-system { + pname = "cl-graph+hu.dwim.graphviz"; + version = "20241012-git"; + asds = [ "cl-graph+hu.dwim.graphviz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-graph/2024-10-12/cl-graph-20241012-git.tgz"; + sha256 = "1adwlkj2qp73irsswfi50ayjvz3di8fh1sqavsdl7l2d6k7yipdg"; + system = "cl-graph+hu.dwim.graphviz"; + asd = "cl-graph+hu.dwim.graphviz"; + } + ); + systems = [ "cl-graph+hu.dwim.graphviz" ]; + lispLibs = [ + (getAttr "cl-graph" self) + (getAttr "hu_dot_dwim_dot_graphviz" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-grip = ( + build-asdf-system { + pname = "cl-grip"; + version = "20241012-git"; + asds = [ "cl-grip" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-grip/2024-10-12/cl-grip-20241012-git.tgz"; + sha256 = "0k9qg6pdj4xs5rshf78jmiasyqj4sy5r5hhrccskfsajw6wfmbc9"; + system = "cl-grip"; + asd = "cl-grip"; + } + ); + systems = [ "cl-grip" ]; + lispLibs = [ + (getAttr "cl-strings" self) + (getAttr "local-time" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-grnm = ( + build-asdf-system { + pname = "cl-grnm"; + version = "20180131-git"; + asds = [ "cl-grnm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-grnm/2018-01-31/cl-grnm-20180131-git.tgz"; + sha256 = "1hb5n37n3x2ylrghcqsia2g9a6f5wg24l659jiz4ncpi5bsv4m3s"; + system = "cl-grnm"; + asd = "cl-grnm"; + } + ); + systems = [ "cl-grnm" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-growl = ( + build-asdf-system { + pname = "cl-growl"; + version = "20161208-git"; + asds = [ "cl-growl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-growl/2016-12-08/cl-growl-20161208-git.tgz"; + sha256 = "1qgj3sq22dznwxj1b3rw0099fsf6wgfbc63r376pab74kdnji3n6"; + system = "cl-growl"; + asd = "cl-growl"; + } + ); + systems = [ "cl-growl" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "ironclad" self) + (getAttr "trivial-utf-8" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gss = ( + build-asdf-system { + pname = "cl-gss"; + version = "20180228-git"; + asds = [ "cl-gss" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gss/2018-02-28/cl-gss-20180228-git.tgz"; + sha256 = "0zhxxn3zarird255s9i56bz0fm6dkv00mn8bbsjrhskg3wpcg4pb"; + system = "cl-gss"; + asd = "cl-gss"; + } + ); + systems = [ "cl-gss" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-gtk2-gdk = ( + build-asdf-system { + pname = "cl-gtk2-gdk"; + version = "20211020-git"; + asds = [ "cl-gtk2-gdk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gtk2/2021-10-20/cl-gtk2-20211020-git.tgz"; + sha256 = "1lnrwd7s47cmksllim56mcg9l5m6jrwv6f0q1hq5lr8xpi5ix9vx"; + system = "cl-gtk2-gdk"; + asd = "cl-gtk2-gdk"; + } + ); + systems = [ "cl-gtk2-gdk" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-gtk2-glib" self) + (getAttr "cl-gtk2-pango" self) + ]; + meta = { }; + } + ); + cl-gtk2-glib = ( + build-asdf-system { + pname = "cl-gtk2-glib"; + version = "20211020-git"; + asds = [ "cl-gtk2-glib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gtk2/2021-10-20/cl-gtk2-20211020-git.tgz"; + sha256 = "1lnrwd7s47cmksllim56mcg9l5m6jrwv6f0q1hq5lr8xpi5ix9vx"; + system = "cl-gtk2-glib"; + asd = "cl-gtk2-glib"; + } + ); + systems = [ "cl-gtk2-glib" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + cl-gtk2-pango = ( + build-asdf-system { + pname = "cl-gtk2-pango"; + version = "20211020-git"; + asds = [ "cl-gtk2-pango" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gtk2/2021-10-20/cl-gtk2-20211020-git.tgz"; + sha256 = "1lnrwd7s47cmksllim56mcg9l5m6jrwv6f0q1hq5lr8xpi5ix9vx"; + system = "cl-gtk2-pango"; + asd = "cl-gtk2-pango"; + } + ); + systems = [ "cl-gtk2-pango" ]; + lispLibs = [ + (getAttr "cl-gtk2-glib" self) + (getAttr "iterate" self) + ]; + meta = { }; + } + ); + cl-haml = ( + build-asdf-system { + pname = "cl-haml"; + version = "20180228-git"; + asds = [ "cl-haml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-haml/2018-02-28/cl-haml-20180228-git.tgz"; + sha256 = "017qr3509ha2680h3c8ip5rqyfaz7v9hfjmx0pg1wrjqw8vyjyb5"; + system = "cl-haml"; + asd = "cl-haml"; + } + ); + systems = [ "cl-haml" ]; + lispLibs = [ (getAttr "cl-who" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-haml-test = ( + build-asdf-system { + pname = "cl-haml-test"; + version = "20180228-git"; + asds = [ "cl-haml-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-haml/2018-02-28/cl-haml-20180228-git.tgz"; + sha256 = "017qr3509ha2680h3c8ip5rqyfaz7v9hfjmx0pg1wrjqw8vyjyb5"; + system = "cl-haml-test"; + asd = "cl-haml"; + } + ); + systems = [ "cl-haml-test" ]; + lispLibs = [ + (getAttr "cl-haml" self) + (getAttr "cl-test-more" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-hamt = ( + build-asdf-system { + pname = "cl-hamt"; + version = "20200325-git"; + asds = [ "cl-hamt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-hamt/2020-03-25/cl-hamt-20200325-git.tgz"; + sha256 = "1ycbd73ykfj5j9sdhlzamyv18qbjj6xqf7fhm4fa0nsyr6sr3rf5"; + system = "cl-hamt"; + asd = "cl-hamt"; + } + ); + systems = [ "cl-hamt" ]; + lispLibs = [ (getAttr "cl-murmurhash" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-hamt-examples = ( + build-asdf-system { + pname = "cl-hamt-examples"; + version = "20200325-git"; + asds = [ "cl-hamt-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-hamt/2020-03-25/cl-hamt-20200325-git.tgz"; + sha256 = "1ycbd73ykfj5j9sdhlzamyv18qbjj6xqf7fhm4fa0nsyr6sr3rf5"; + system = "cl-hamt-examples"; + asd = "cl-hamt-examples"; + } + ); + systems = [ "cl-hamt-examples" ]; + lispLibs = [ + (getAttr "cl-hamt" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-hamt-test = ( + build-asdf-system { + pname = "cl-hamt-test"; + version = "20200325-git"; + asds = [ "cl-hamt-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-hamt/2020-03-25/cl-hamt-20200325-git.tgz"; + sha256 = "1ycbd73ykfj5j9sdhlzamyv18qbjj6xqf7fhm4fa0nsyr6sr3rf5"; + system = "cl-hamt-test"; + asd = "cl-hamt-test"; + } + ); + systems = [ "cl-hamt-test" ]; + lispLibs = [ + (getAttr "cl-hamt" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-hash-table-destructuring = ( + build-asdf-system { + pname = "cl-hash-table-destructuring"; + version = "20160531-git"; + asds = [ "cl-hash-table-destructuring" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-hash-table-destructuring/2016-05-31/cl-hash-table-destructuring-20160531-git.tgz"; + sha256 = "0za8jlqfvsilmnidk429509vbdd18w7ykcycni411pjpz0lxrh1v"; + system = "cl-hash-table-destructuring"; + asd = "cl-hash-table-destructuring"; + } + ); + systems = [ "cl-hash-table-destructuring" ]; + lispLibs = [ (getAttr "prove-asdf" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-hash-table-destructuring-test = ( + build-asdf-system { + pname = "cl-hash-table-destructuring-test"; + version = "20160531-git"; + asds = [ "cl-hash-table-destructuring-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-hash-table-destructuring/2016-05-31/cl-hash-table-destructuring-20160531-git.tgz"; + sha256 = "0za8jlqfvsilmnidk429509vbdd18w7ykcycni411pjpz0lxrh1v"; + system = "cl-hash-table-destructuring-test"; + asd = "cl-hash-table-destructuring"; + } + ); + systems = [ "cl-hash-table-destructuring-test" ]; + lispLibs = [ + (getAttr "cl-hash-table-destructuring" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-hash-util = ( + build-asdf-system { + pname = "cl-hash-util"; + version = "20241012-git"; + asds = [ "cl-hash-util" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-hash-util/2024-10-12/cl-hash-util-20241012-git.tgz"; + sha256 = "1xab7v2mav241rs8w68qmg485g4f75nrac3hjcnm0cb19ickbs1m"; + system = "cl-hash-util"; + asd = "cl-hash-util"; + } + ); + systems = [ "cl-hash-util" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-hash-util-test = ( + build-asdf-system { + pname = "cl-hash-util-test"; + version = "20241012-git"; + asds = [ "cl-hash-util-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-hash-util/2024-10-12/cl-hash-util-20241012-git.tgz"; + sha256 = "1xab7v2mav241rs8w68qmg485g4f75nrac3hjcnm0cb19ickbs1m"; + system = "cl-hash-util-test"; + asd = "cl-hash-util-test"; + } + ); + systems = [ "cl-hash-util-test" ]; + lispLibs = [ + (getAttr "cl-hash-util" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-heap = ( + build-asdf-system { + pname = "cl-heap"; + version = "0.1.6"; + asds = [ "cl-heap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-heap/2013-03-12/cl-heap-0.1.6.tgz"; + sha256 = "01bss182x9i167lfv0lr8ylavk2m42s84vz6629kspgjhczm52w7"; + system = "cl-heap"; + asd = "cl-heap"; + } + ); + systems = [ "cl-heap" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-heap-tests = ( + build-asdf-system { + pname = "cl-heap-tests"; + version = "0.1.6"; + asds = [ "cl-heap-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-heap/2013-03-12/cl-heap-0.1.6.tgz"; + sha256 = "01bss182x9i167lfv0lr8ylavk2m42s84vz6629kspgjhczm52w7"; + system = "cl-heap-tests"; + asd = "cl-heap-tests"; + } + ); + systems = [ "cl-heap-tests" ]; + lispLibs = [ + (getAttr "cl-heap" self) + (getAttr "xlunit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-heredoc = ( + build-asdf-system { + pname = "cl-heredoc"; + version = "20220707-git"; + asds = [ "cl-heredoc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-heredoc/2022-07-07/cl-heredoc-20220707-git.tgz"; + sha256 = "0hj9y6drd93nwcbmwwhnc30flm48ppw4rhfgfyqfc02fq2wnc83z"; + system = "cl-heredoc"; + asd = "cl-heredoc"; + } + ); + systems = [ "cl-heredoc" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-heredoc-test = ( + build-asdf-system { + pname = "cl-heredoc-test"; + version = "20220707-git"; + asds = [ "cl-heredoc-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-heredoc/2022-07-07/cl-heredoc-20220707-git.tgz"; + sha256 = "0hj9y6drd93nwcbmwwhnc30flm48ppw4rhfgfyqfc02fq2wnc83z"; + system = "cl-heredoc-test"; + asd = "cl-heredoc-test"; + } + ); + systems = [ "cl-heredoc-test" ]; + lispLibs = [ + (getAttr "cl-heredoc" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-hooks = ( + build-asdf-system { + pname = "cl-hooks"; + version = "20181210-git"; + asds = [ "cl-hooks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/architecture.hooks/2018-12-10/architecture.hooks-20181210-git.tgz"; + sha256 = "0bg3l0a28lw5gqqjp6p6b5nhwqk46sgkb7184w5qbfngw1hk8x9y"; + system = "cl-hooks"; + asd = "cl-hooks"; + } + ); + systems = [ "cl-hooks" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "let-plus" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + cl-html-diff = ( + build-asdf-system { + pname = "cl-html-diff"; + version = "20130128-git"; + asds = [ "cl-html-diff" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-html-diff/2013-01-28/cl-html-diff-20130128-git.tgz"; + sha256 = "1varnijivzd4jpimn1cz8p5ks713zzha5cgl4vmb0xr8ahravwzb"; + system = "cl-html-diff"; + asd = "cl-html-diff"; + } + ); + systems = [ "cl-html-diff" ]; + lispLibs = [ (getAttr "cl-difflib" self) ]; + meta = { }; + } + ); + cl-html-parse = ( + build-asdf-system { + pname = "cl-html-parse"; + version = "20231021-git"; + asds = [ "cl-html-parse" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-html-parse/2023-10-21/cl-html-parse-20231021-git.tgz"; + sha256 = "1qgjaq45lvqrsw4rrnyy4d5bwlmb7vd45ibdzgbxx5az02x3ahmy"; + system = "cl-html-parse"; + asd = "cl-html-parse"; + } + ); + systems = [ "cl-html-parse" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-html-readme = ( + build-asdf-system { + pname = "cl-html-readme"; + version = "quicklisp-current-release-f8aed591-git"; + asds = [ "cl-html-readme" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-html-readme/2024-10-12/cl-html-readme-quicklisp-current-release-f8aed591-git.tgz"; + sha256 = "1q23fdbhmra7hl12vd70m7q350wych6f739l8xmz6f84dwm9i8c7"; + system = "cl-html-readme"; + asd = "cl-html-readme"; + } + ); + systems = [ "cl-html-readme" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-html5-parser = ( + build-asdf-system { + pname = "cl-html5-parser"; + version = "20190521-git"; + asds = [ "cl-html5-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-html5-parser/2019-05-21/cl-html5-parser-20190521-git.tgz"; + sha256 = "04if61wigylsmn996rbfl8ylsd0d9hzdmg7p2wiglncibjzcl5k9"; + system = "cl-html5-parser"; + asd = "cl-html5-parser"; + } + ); + systems = [ "cl-html5-parser" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "string-case" self) + ]; + meta = { }; + } + ); + cl-html5-parser-cxml = ( + build-asdf-system { + pname = "cl-html5-parser-cxml"; + version = "20190521-git"; + asds = [ "cl-html5-parser-cxml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-html5-parser/2019-05-21/cl-html5-parser-20190521-git.tgz"; + sha256 = "04if61wigylsmn996rbfl8ylsd0d9hzdmg7p2wiglncibjzcl5k9"; + system = "cl-html5-parser-cxml"; + asd = "cl-html5-parser-cxml"; + } + ); + systems = [ "cl-html5-parser-cxml" ]; + lispLibs = [ + (getAttr "cl-html5-parser" self) + (getAttr "cxml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-html5-parser-tests = ( + build-asdf-system { + pname = "cl-html5-parser-tests"; + version = "20190521-git"; + asds = [ "cl-html5-parser-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-html5-parser/2019-05-21/cl-html5-parser-20190521-git.tgz"; + sha256 = "04if61wigylsmn996rbfl8ylsd0d9hzdmg7p2wiglncibjzcl5k9"; + system = "cl-html5-parser-tests"; + asd = "cl-html5-parser-tests"; + } + ); + systems = [ "cl-html5-parser-tests" ]; + lispLibs = [ + (getAttr "cl-html5-parser" self) + (getAttr "json-streams" self) + (getAttr "split-sequence" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-htmlprag = ( + build-asdf-system { + pname = "cl-htmlprag"; + version = "20160628-git"; + asds = [ "cl-htmlprag" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-htmlprag/2016-06-28/cl-htmlprag-20160628-git.tgz"; + sha256 = "1akfy9rldx5a2h34vf7y02pj2j7b5anbxja53m41ism4vklgqg1c"; + system = "cl-htmlprag"; + asd = "cl-htmlprag"; + } + ); + systems = [ "cl-htmlprag" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "optima" self) + (getAttr "parse-number" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-httpsqs = ( + build-asdf-system { + pname = "cl-httpsqs"; + version = "20180228-git"; + asds = [ "cl-httpsqs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-httpsqs/2018-02-28/cl-httpsqs-20180228-git.tgz"; + sha256 = "14nhr03lm8012crczjpgsmf0ydipqf3kggayshm7w72vkyf0haj7"; + system = "cl-httpsqs"; + asd = "cl-httpsqs"; + } + ); + systems = [ "cl-httpsqs" ]; + lispLibs = [ (getAttr "drakma" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-hue = ( + build-asdf-system { + pname = "cl-hue"; + version = "20150113-git"; + asds = [ "cl-hue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-hue/2015-01-13/cl-hue-20150113-git.tgz"; + sha256 = "0d2qv60pih1xmk0zzbdwcsyk8k9abjzilcmhz3jdicinl8jinfr4"; + system = "cl-hue"; + asd = "cl-hue"; + } + ); + systems = [ "cl-hue" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "drakma" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-i18n = ( + build-asdf-system { + pname = "cl-i18n"; + version = "20241012-git"; + asds = [ "cl-i18n" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-i18n/2024-10-12/cl-i18n-20241012-git.tgz"; + sha256 = "1gp4ncf7ywyyh2f0zdkqibvn0wxm4hvsj672ni2vfqvhcivqfdza"; + system = "cl-i18n"; + asd = "cl-i18n"; + } + ); + systems = [ "cl-i18n" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-ppcre-unicode" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-id3 = ( + build-asdf-system { + pname = "cl-id3"; + version = "20230618-git"; + asds = [ "cl-id3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-id3/2023-06-18/cl-id3-20230618-git.tgz"; + sha256 = "0p5rcxy6zy8jq673yphbq5dq0g28vx9g7kfklfhicg2blpzy2yf5"; + system = "cl-id3"; + asd = "cl-id3"; + } + ); + systems = [ "cl-id3" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ilu = ( + build-asdf-system { + pname = "cl-ilu"; + version = "20150302-git"; + asds = [ "cl-ilu" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-devil/2015-03-02/cl-devil-20150302-git.tgz"; + sha256 = "1qdjb7xwzjkv99s8q0834lfdq4ch5j2ymrmqsvwzhg47ys17pvvf"; + system = "cl-ilu"; + asd = "cl-ilu"; + } + ); + systems = [ "cl-ilu" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-devil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ilut = ( + build-asdf-system { + pname = "cl-ilut"; + version = "20150302-git"; + asds = [ "cl-ilut" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-devil/2015-03-02/cl-devil-20150302-git.tgz"; + sha256 = "1qdjb7xwzjkv99s8q0834lfdq4ch5j2ymrmqsvwzhg47ys17pvvf"; + system = "cl-ilut"; + asd = "cl-ilut"; + } + ); + systems = [ "cl-ilut" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-devil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-incognia = ( + build-asdf-system { + pname = "cl-incognia"; + version = "20211230-git"; + asds = [ "cl-incognia" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-incognia/2021-12-30/cl-incognia-20211230-git.tgz"; + sha256 = "0c5v7vqh26vg4mzzz7rkq3r29ygj2q4fw6v56pi79bbszyklfs21"; + system = "cl-incognia"; + asd = "cl-incognia"; + } + ); + systems = [ "cl-incognia" ]; + lispLibs = [ + (getAttr "dexador" self) + (getAttr "jonathan" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-indentify = ( + build-asdf-system { + pname = "cl-indentify"; + version = "20230214-git"; + asds = [ "cl-indentify" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-indentify/2023-02-14/cl-indentify-20230214-git.tgz"; + sha256 = "1np7b3mh3wd5dv7nvwmjl5rgy7m0qf0fx61s04yazlh46k3d0nxd"; + system = "cl-indentify"; + asd = "cl-indentify"; + } + ); + systems = [ "cl-indentify" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-inflector = ( + build-asdf-system { + pname = "cl-inflector"; + version = "20150113-git"; + asds = [ "cl-inflector" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-inflector/2015-01-13/cl-inflector-20150113-git.tgz"; + sha256 = "1xwwlhik1la4fp984qnx2dqq24v012qv4x0y49sngfpwg7n0ya7y"; + system = "cl-inflector"; + asd = "cl-inflector"; + } + ); + systems = [ "cl-inflector" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-inflector-test = ( + build-asdf-system { + pname = "cl-inflector-test"; + version = "20150113-git"; + asds = [ "cl-inflector-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-inflector/2015-01-13/cl-inflector-20150113-git.tgz"; + sha256 = "1xwwlhik1la4fp984qnx2dqq24v012qv4x0y49sngfpwg7n0ya7y"; + system = "cl-inflector-test"; + asd = "cl-inflector"; + } + ); + systems = [ "cl-inflector-test" ]; + lispLibs = [ + (getAttr "cl-inflector" self) + (getAttr "lisp-unit2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-influxdb = ( + build-asdf-system { + pname = "cl-influxdb"; + version = "20180131-git"; + asds = [ "cl-influxdb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-influxdb/2018-01-31/cl-influxdb-20180131-git.tgz"; + sha256 = "0fqnsdw6x79qsvw7l6xp1gxgzcj6jwpa4mn0z2gbbipff4g7k527"; + system = "cl-influxdb"; + asd = "cl-influxdb"; + } + ); + systems = [ "cl-influxdb" ]; + lispLibs = [ + (getAttr "cl-annot" self) + (getAttr "cl-json" self) + (getAttr "do-urlencode" self) + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-info = ( + build-asdf-system { + pname = "cl-info"; + version = "20241012-git"; + asds = [ "cl-info" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-info/2024-10-12/cl-info-20241012-git.tgz"; + sha256 = "0vrrlcwdqnw8v34zd7wkjxh02zysam5c5s5n4l5q6s2jy0gmai0y"; + system = "cl-info"; + asd = "cl-info"; + } + ); + systems = [ "cl-info" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "docs-config" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-info-test = ( + build-asdf-system { + pname = "cl-info-test"; + version = "20241012-git"; + asds = [ "cl-info-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-info/2024-10-12/cl-info-20241012-git.tgz"; + sha256 = "0vrrlcwdqnw8v34zd7wkjxh02zysam5c5s5n4l5q6s2jy0gmai0y"; + system = "cl-info-test"; + asd = "cl-info-test"; + } + ); + systems = [ "cl-info-test" ]; + lispLibs = [ + (getAttr "cl-info" self) + (getAttr "hamcrest" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ini = ( + build-asdf-system { + pname = "cl-ini"; + version = "20241012-git"; + asds = [ "cl-ini" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ini/2024-10-12/cl-ini-20241012-git.tgz"; + sha256 = "1dj2w1fs1j52wxy91qy2jrn88aqggrvsg4fngl90ssvfh3awk4wm"; + system = "cl-ini"; + asd = "cl-ini"; + } + ); + systems = [ "cl-ini" ]; + lispLibs = [ (getAttr "str" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ini-test = ( + build-asdf-system { + pname = "cl-ini-test"; + version = "20241012-git"; + asds = [ "cl-ini-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ini/2024-10-12/cl-ini-20241012-git.tgz"; + sha256 = "1dj2w1fs1j52wxy91qy2jrn88aqggrvsg4fngl90ssvfh3awk4wm"; + system = "cl-ini-test"; + asd = "cl-ini-test"; + } + ); + systems = [ "cl-ini-test" ]; + lispLibs = [ + (getAttr "cl-ini" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-inotify = ( + build-asdf-system { + pname = "cl-inotify"; + version = "20220707-git"; + asds = [ "cl-inotify" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-inotify/2022-07-07/cl-inotify-20220707-git.tgz"; + sha256 = "0d3bvp5lqnddzhk1w9yyli03njbkhc8d129a058g0j49kgd47c7v"; + system = "cl-inotify"; + asd = "cl-inotify"; + } + ); + systems = [ "cl-inotify" ]; + lispLibs = [ + (getAttr "binary-types" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "iolib" self) + (getAttr "iolib_dot_asdf" self) + (getAttr "iolib_dot_base" self) + (getAttr "iolib_dot_conf" self) + (getAttr "osicat" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-inotify-tests = ( + build-asdf-system { + pname = "cl-inotify-tests"; + version = "20220707-git"; + asds = [ "cl-inotify-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-inotify/2022-07-07/cl-inotify-20220707-git.tgz"; + sha256 = "0d3bvp5lqnddzhk1w9yyli03njbkhc8d129a058g0j49kgd47c7v"; + system = "cl-inotify-tests"; + asd = "cl-inotify-tests"; + } + ); + systems = [ "cl-inotify-tests" ]; + lispLibs = [ + (getAttr "cl-inotify" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-intbytes = ( + build-asdf-system { + pname = "cl-intbytes"; + version = "20150923-git"; + asds = [ "cl-intbytes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-intbytes/2015-09-23/cl-intbytes-20150923-git.tgz"; + sha256 = "0chwfda7pi8mrgwj31li7f0x0hr5yrp4csiq8hwkgd4c1ag1z9fx"; + system = "cl-intbytes"; + asd = "cl-intbytes"; + } + ); + systems = [ "cl-intbytes" ]; + lispLibs = [ (getAttr "fast-io" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-intbytes-test = ( + build-asdf-system { + pname = "cl-intbytes-test"; + version = "20150923-git"; + asds = [ "cl-intbytes-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-intbytes/2015-09-23/cl-intbytes-20150923-git.tgz"; + sha256 = "0chwfda7pi8mrgwj31li7f0x0hr5yrp4csiq8hwkgd4c1ag1z9fx"; + system = "cl-intbytes-test"; + asd = "cl-intbytes-test"; + } + ); + systems = [ "cl-intbytes-test" ]; + lispLibs = [ + (getAttr "cl-intbytes" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-interpol = ( + build-asdf-system { + pname = "cl-interpol"; + version = "20221106-git"; + asds = [ "cl-interpol" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-interpol/2022-11-06/cl-interpol-20221106-git.tgz"; + sha256 = "1nkjn8byyfdxhi84rbpqs87bb5m478lvphfgxqqv0q37rn75c946"; + system = "cl-interpol"; + asd = "cl-interpol"; + } + ); + systems = [ "cl-interpol" ]; + lispLibs = [ + (getAttr "cl-unicode" self) + (getAttr "named-readtables" self) + ]; + meta = { }; + } + ); + cl-interval = ( + build-asdf-system { + pname = "cl-interval"; + version = "20200715-git"; + asds = [ "cl-interval" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-interval/2020-07-15/cl-interval-20200715-git.tgz"; + sha256 = "1425l6xmrqadjqgqb5qasisf14pbr6zpj30bpxfv8hhnxs5njq4p"; + system = "cl-interval"; + asd = "cl-interval"; + } + ); + systems = [ "cl-interval" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-interval-docs = ( + build-asdf-system { + pname = "cl-interval-docs"; + version = "20200715-git"; + asds = [ "cl-interval-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-interval/2020-07-15/cl-interval-20200715-git.tgz"; + sha256 = "1425l6xmrqadjqgqb5qasisf14pbr6zpj30bpxfv8hhnxs5njq4p"; + system = "cl-interval-docs"; + asd = "cl-interval-docs"; + } + ); + systems = [ "cl-interval-docs" ]; + lispLibs = [ + (getAttr "cl-gendoc" self) + (getAttr "cl-interval" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ipfs-api2 = ( + build-asdf-system { + pname = "cl-ipfs-api2"; + version = "20241012-git"; + asds = [ "cl-ipfs-api2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ipfs-api2/2024-10-12/cl-ipfs-api2-20241012-git.tgz"; + sha256 = "0lz19ayvcdhakckxp6z6gzlglhvnaj0qqyx1jmp211fms7dzyl0x"; + system = "cl-ipfs-api2"; + asd = "cl-ipfs-api2"; + } + ); + systems = [ "cl-ipfs-api2" ]; + lispLibs = [ + (getAttr "arnesi" self) + (getAttr "drakma" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-irc = ( + build-asdf-system { + pname = "cl-irc"; + version = "0.9.2"; + asds = [ "cl-irc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-irc/2015-09-23/cl-irc-0.9.2.tgz"; + sha256 = "15h3ram8b6vyg4718ad2m92xgilda2x3zmkzbjnijk69kkqsq01r"; + system = "cl-irc"; + asd = "cl-irc"; + } + ); + systems = [ "cl-irc" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "split-sequence" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-irc-test = ( + build-asdf-system { + pname = "cl-irc-test"; + version = "0.9.2"; + asds = [ "cl-irc-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-irc/2015-09-23/cl-irc-0.9.2.tgz"; + sha256 = "15h3ram8b6vyg4718ad2m92xgilda2x3zmkzbjnijk69kkqsq01r"; + system = "cl-irc-test"; + asd = "cl-irc-test"; + } + ); + systems = [ "cl-irc-test" ]; + lispLibs = [ + (getAttr "cl-irc" self) + (getAttr "rt" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-irregsexp = ( + build-asdf-system { + pname = "cl-irregsexp"; + version = "20160825-git"; + asds = [ "cl-irregsexp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-irregsexp/2016-08-25/cl-irregsexp-20160825-git.tgz"; + sha256 = "09pf3jlqskcs32shbj9q3m0zww5pxyrizbvk2nxiwwnbl1rdb406"; + system = "cl-irregsexp"; + asd = "cl-irregsexp"; + } + ); + systems = [ "cl-irregsexp" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-isaac = ( + build-asdf-system { + pname = "cl-isaac"; + version = "20231021-git"; + asds = [ "cl-isaac" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-isaac/2023-10-21/cl-isaac-20231021-git.tgz"; + sha256 = "07gjfynhqwwsa839i24h08xd9w7kn5g02rm35x96hq1qrfv1v0fn"; + system = "cl-isaac"; + asd = "cl-isaac"; + } + ); + systems = [ "cl-isaac" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-iterative = ( + build-asdf-system { + pname = "cl-iterative"; + version = "20160318-git"; + asds = [ "cl-iterative" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-iterative/2016-03-18/cl-iterative-20160318-git.tgz"; + sha256 = "01h2fs7nq2wivjwh9swsmfdvsdmd7j9dvzgrq0ijbq456zm8vilq"; + system = "cl-iterative"; + asd = "cl-iterative"; + } + ); + systems = [ "cl-iterative" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "optima" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-iterative-tests = ( + build-asdf-system { + pname = "cl-iterative-tests"; + version = "20160318-git"; + asds = [ "cl-iterative-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-iterative/2016-03-18/cl-iterative-20160318-git.tgz"; + sha256 = "01h2fs7nq2wivjwh9swsmfdvsdmd7j9dvzgrq0ijbq456zm8vilq"; + system = "cl-iterative-tests"; + asd = "cl-iterative-tests"; + } + ); + systems = [ "cl-iterative-tests" ]; + lispLibs = [ + (getAttr "cl-iterative" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-itertools = ( + build-asdf-system { + pname = "cl-itertools"; + version = "20160421-git"; + asds = [ "cl-itertools" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-itertools/2016-04-21/cl-itertools-20160421-git.tgz"; + sha256 = "0m1g7nxqnz03bcj46skcr2d50pi3lb4hwizna5d4mvl5hk4zwbxr"; + system = "cl-itertools"; + asd = "cl-itertools"; + } + ); + systems = [ "cl-itertools" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-coroutine" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-itertools-tests = ( + build-asdf-system { + pname = "cl-itertools-tests"; + version = "20160421-git"; + asds = [ "cl-itertools-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-itertools/2016-04-21/cl-itertools-20160421-git.tgz"; + sha256 = "0m1g7nxqnz03bcj46skcr2d50pi3lb4hwizna5d4mvl5hk4zwbxr"; + system = "cl-itertools-tests"; + asd = "cl-itertools"; + } + ); + systems = [ "cl-itertools-tests" ]; + lispLibs = [ + (getAttr "cl-itertools" self) + (getAttr "fiveam" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-jpeg = ( + build-asdf-system { + pname = "cl-jpeg"; + version = "20230214-git"; + asds = [ "cl-jpeg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-jpeg/2023-02-14/cl-jpeg-20230214-git.tgz"; + sha256 = "1xl1id4k1bdw6hf24ndkzr6nxi30yw7xlr1fhfmxnwjqwy5hcq14"; + system = "cl-jpeg"; + asd = "cl-jpeg"; + } + ); + systems = [ "cl-jpeg" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-js = ( + build-asdf-system { + pname = "cl-js"; + version = "20241012-git"; + asds = [ "cl-js" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/js/2024-10-12/js-20241012-git.tgz"; + sha256 = "084rfqxbhrwqb3xfcx3kzmnyzacr2wb8bkxzl0srdgn17pl7hkx3"; + system = "cl-js"; + asd = "cl-js"; + } + ); + systems = [ "cl-js" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "local-time" self) + (getAttr "parse-js" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-jschema = ( + build-asdf-system { + pname = "cl-jschema"; + version = "v1.1.1"; + asds = [ "cl-jschema" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-jschema/2023-06-18/cl-jschema-v1.1.1.tgz"; + sha256 = "0awc7hy07sg4h8k58xxxy578a5qklpkj3slslp7ghfzfdbi7nz11"; + system = "cl-jschema"; + asd = "cl-jschema"; + } + ); + systems = [ "cl-jschema" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "com_dot_inuoe_dot_jzon" self) + (getAttr "puri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-json = ( + build-asdf-system { + pname = "cl-json"; + version = "20220707-git"; + asds = [ "cl-json" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-json/2022-07-07/cl-json-20220707-git.tgz"; + sha256 = "12vakz47d1i7pywgb9cm2364fzykidc9m7l7b6n9lx0gn2qx9ar5"; + system = "cl-json"; + asd = "cl-json"; + } + ); + systems = [ "cl-json" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-json-helper = ( + build-asdf-system { + pname = "cl-json-helper"; + version = "20181210-git"; + asds = [ "cl-json-helper" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-json-helper/2018-12-10/cl-json-helper-20181210-git.tgz"; + sha256 = "1dhv5lh514m7bvl77xjhb4ky7nf4bskgpld7rqg3rq24k4y0c79a"; + system = "cl-json-helper"; + asd = "cl-json-helper"; + } + ); + systems = [ "cl-json-helper" ]; + lispLibs = [ (getAttr "cl-json" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-json-pointer = ( + build-asdf-system { + pname = "cl-json-pointer"; + version = "20221106-git"; + asds = [ "cl-json-pointer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-json-pointer/2022-11-06/cl-json-pointer-20221106-git.tgz"; + sha256 = "0b7a755wc2ghsd1pv7d32877b21h4nssp41xs017anbmj55czb2h"; + system = "cl-json-pointer"; + asd = "cl-json-pointer"; + } + ); + systems = [ "cl-json-pointer" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "st-json" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-json-schema = ( + build-asdf-system { + pname = "cl-json-schema"; + version = "20210228-git"; + asds = [ "cl-json-schema" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-json-schema/2021-02-28/cl-json-schema-20210228-git.tgz"; + sha256 = "1c90c9j6d2b02zyyqd07200waqa4saq0svps7vfy5a3lxp9vag9i"; + system = "cl-json-schema"; + asd = "cl-json-schema"; + } + ); + systems = [ "cl-json-schema" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "trivial-do" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-json-schema-tests = ( + build-asdf-system { + pname = "cl-json-schema-tests"; + version = "20210228-git"; + asds = [ "cl-json-schema-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-json-schema/2021-02-28/cl-json-schema-20210228-git.tgz"; + sha256 = "1c90c9j6d2b02zyyqd07200waqa4saq0svps7vfy5a3lxp9vag9i"; + system = "cl-json-schema-tests"; + asd = "cl-json-schema-tests"; + } + ); + systems = [ "cl-json-schema-tests" ]; + lispLibs = [ + (getAttr "cl-json-schema" self) + (getAttr "cl-ppcre" self) + (getAttr "fiasco" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-jsonl = ( + build-asdf-system { + pname = "cl-jsonl"; + version = "20231021-git"; + asds = [ "cl-jsonl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-jsonl/2023-10-21/cl-jsonl-20231021-git.tgz"; + sha256 = "0mwszi9r88p21rl6x7gh0cjgmfmzvgs34257h88m6zr7q7h7djw4"; + system = "cl-jsonl"; + asd = "cl-jsonl"; + } + ); + systems = [ "cl-jsonl" ]; + lispLibs = [ + (getAttr "gtwiwtg" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-jsx = ( + build-asdf-system { + pname = "cl-jsx"; + version = "20160208-git"; + asds = [ "cl-jsx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-jsx/2016-02-08/cl-jsx-20160208-git.tgz"; + sha256 = "1vkqs65sqnfkfka2p93ibfrgg3wps3qhlcgcd8j40h0bv3phcjp7"; + system = "cl-jsx"; + asd = "cl-jsx"; + } + ); + systems = [ "cl-jsx" ]; + lispLibs = [ + (getAttr "cl-who" self) + (getAttr "esrap" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-jsx-test = ( + build-asdf-system { + pname = "cl-jsx-test"; + version = "20160208-git"; + asds = [ "cl-jsx-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-jsx/2016-02-08/cl-jsx-20160208-git.tgz"; + sha256 = "1vkqs65sqnfkfka2p93ibfrgg3wps3qhlcgcd8j40h0bv3phcjp7"; + system = "cl-jsx-test"; + asd = "cl-jsx-test"; + } + ); + systems = [ "cl-jsx-test" ]; + lispLibs = [ + (getAttr "cl-jsx" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-junit-xml = ( + build-asdf-system { + pname = "cl-junit-xml"; + version = "20150113-git"; + asds = [ "cl-junit-xml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-junit-xml/2015-01-13/cl-junit-xml-20150113-git.tgz"; + sha256 = "1ssrcgw5bhfsb5lk7jb8jyz77mj6sg23wc3gmnw747iqvpikwakr"; + system = "cl-junit-xml"; + asd = "cl-junit-xml"; + } + ); + systems = [ "cl-junit-xml" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cxml" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-junit-xml_dot_lisp-unit = ( + build-asdf-system { + pname = "cl-junit-xml.lisp-unit"; + version = "20150113-git"; + asds = [ "cl-junit-xml.lisp-unit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-junit-xml/2015-01-13/cl-junit-xml-20150113-git.tgz"; + sha256 = "1ssrcgw5bhfsb5lk7jb8jyz77mj6sg23wc3gmnw747iqvpikwakr"; + system = "cl-junit-xml.lisp-unit"; + asd = "cl-junit-xml.lisp-unit"; + } + ); + systems = [ "cl-junit-xml.lisp-unit" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-junit-xml" self) + (getAttr "cl-ppcre" self) + (getAttr "iterate" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-junit-xml_dot_lisp-unit2 = ( + build-asdf-system { + pname = "cl-junit-xml.lisp-unit2"; + version = "20150113-git"; + asds = [ "cl-junit-xml.lisp-unit2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-junit-xml/2015-01-13/cl-junit-xml-20150113-git.tgz"; + sha256 = "1ssrcgw5bhfsb5lk7jb8jyz77mj6sg23wc3gmnw747iqvpikwakr"; + system = "cl-junit-xml.lisp-unit2"; + asd = "cl-junit-xml.lisp-unit2"; + } + ); + systems = [ "cl-junit-xml.lisp-unit2" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-junit-xml" self) + (getAttr "cl-ppcre" self) + (getAttr "iterate" self) + (getAttr "lisp-unit2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-junit-xml_dot_test = ( + build-asdf-system { + pname = "cl-junit-xml.test"; + version = "20150113-git"; + asds = [ "cl-junit-xml.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-junit-xml/2015-01-13/cl-junit-xml-20150113-git.tgz"; + sha256 = "1ssrcgw5bhfsb5lk7jb8jyz77mj6sg23wc3gmnw747iqvpikwakr"; + system = "cl-junit-xml.test"; + asd = "cl-junit-xml"; + } + ); + systems = [ "cl-junit-xml.test" ]; + lispLibs = [ + (getAttr "cl-junit-xml" self) + (getAttr "lisp-unit2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-jwk = ( + build-asdf-system { + pname = "cl-jwk"; + version = "20231021-git"; + asds = [ "cl-jwk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-jwk/2023-10-21/cl-jwk-20231021-git.tgz"; + sha256 = "07hphgx40583hpvzj2xnk73lypfp1iq40nfpv3gf3hba4x54c17a"; + system = "cl-jwk"; + asd = "cl-jwk"; + } + ); + systems = [ "cl-jwk" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "binascii" self) + (getAttr "cl-reexport" self) + (getAttr "dexador" self) + (getAttr "ironclad" self) + (getAttr "jonathan" self) + (getAttr "jose" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-jwk_dot_test = ( + build-asdf-system { + pname = "cl-jwk.test"; + version = "20231021-git"; + asds = [ "cl-jwk.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-jwk/2023-10-21/cl-jwk-20231021-git.tgz"; + sha256 = "07hphgx40583hpvzj2xnk73lypfp1iq40nfpv3gf3hba4x54c17a"; + system = "cl-jwk.test"; + asd = "cl-jwk.test"; + } + ); + systems = [ "cl-jwk.test" ]; + lispLibs = [ + (getAttr "cl-jwk" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-k8055 = ( + build-asdf-system { + pname = "cl-k8055"; + version = "20231021-git"; + asds = [ "cl-k8055" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-k8055/2023-10-21/cl-k8055-20231021-git.tgz"; + sha256 = "1qap7pf90l89lqb8asnnnc0qfaabd6p179vmdq1z7n5wxdwsw2b3"; + system = "cl-k8055"; + asd = "cl-k8055"; + } + ); + systems = [ "cl-k8055" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-kanren = ( + build-asdf-system { + pname = "cl-kanren"; + version = "20241012-git"; + asds = [ "cl-kanren" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-kanren/2024-10-12/cl-kanren-20241012-git.tgz"; + sha256 = "136jdgh23vb7imihk9dqwpk8wzjmpvkqfhah3qrxpsw0xpir29sh"; + system = "cl-kanren"; + asd = "cl-kanren"; + } + ); + systems = [ "cl-kanren" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-kanren-test = ( + build-asdf-system { + pname = "cl-kanren-test"; + version = "20241012-git"; + asds = [ "cl-kanren-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-kanren/2024-10-12/cl-kanren-20241012-git.tgz"; + sha256 = "136jdgh23vb7imihk9dqwpk8wzjmpvkqfhah3qrxpsw0xpir29sh"; + system = "cl-kanren-test"; + asd = "cl-kanren-test"; + } + ); + systems = [ "cl-kanren-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-kanren" self) + (getAttr "clunit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-keycloak = ( + build-asdf-system { + pname = "cl-keycloak"; + version = "20190710-git"; + asds = [ "cl-keycloak" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-keycloak/2019-07-10/cl-keycloak-20190710-git.tgz"; + sha256 = "052x10xj951061xa80kp1ziwrr8hskjsr7q2ni1d1ab26rkmhb9q"; + system = "cl-keycloak"; + asd = "cl-keycloak"; + } + ); + systems = [ "cl-keycloak" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-kraken = ( + build-asdf-system { + pname = "cl-kraken"; + version = "20220331-git"; + asds = [ "cl-kraken" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-kraken/2022-03-31/cl-kraken-20220331-git.tgz"; + sha256 = "07a9a7yqii0gsiaf4r6jfz2nb2m8766rv4acqcdjm8zmsllwx7jz"; + system = "cl-kraken"; + asd = "cl-kraken"; + } + ); + systems = [ "cl-kraken" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "dexador" self) + (getAttr "ironclad" self) + (getAttr "jsown" self) + (getAttr "quri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ksuid = ( + build-asdf-system { + pname = "cl-ksuid"; + version = "20170830-git"; + asds = [ "cl-ksuid" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ksuid/2017-08-30/cl-ksuid-20170830-git.tgz"; + sha256 = "142fr8l6aa6wxnjxv04f61hy9504cx9x1r10byhmj475s5pfr6gl"; + system = "cl-ksuid"; + asd = "cl-ksuid"; + } + ); + systems = [ "cl-ksuid" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "ironclad" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ksuid-test = ( + build-asdf-system { + pname = "cl-ksuid-test"; + version = "20170830-git"; + asds = [ "cl-ksuid-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ksuid/2017-08-30/cl-ksuid-20170830-git.tgz"; + sha256 = "142fr8l6aa6wxnjxv04f61hy9504cx9x1r10byhmj475s5pfr6gl"; + system = "cl-ksuid-test"; + asd = "cl-ksuid"; + } + ); + systems = [ "cl-ksuid-test" ]; + lispLibs = [ + (getAttr "cl-ksuid" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ktx = ( + build-asdf-system { + pname = "cl-ktx"; + version = "20231021-git"; + asds = [ "cl-ktx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ktx/2023-10-21/cl-ktx-20231021-git.tgz"; + sha256 = "1nggg3qixnmv9gisj0aqd369z1rm2qqdf17xnsxcpzz1d9lvxqhq"; + system = "cl-ktx"; + asd = "cl-ktx"; + } + ); + systems = [ "cl-ktx" ]; + lispLibs = [ + (getAttr "binary-structures" self) + (getAttr "cl-opengl" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-kyoto-cabinet = ( + build-asdf-system { + pname = "cl-kyoto-cabinet"; + version = "20191130-git"; + asds = [ "cl-kyoto-cabinet" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-kyoto-cabinet/2019-11-30/cl-kyoto-cabinet-20191130-git.tgz"; + sha256 = "0ayp87ggayaf8d1dblpv90a87fmgh9vhhcah3ch6jvcw6zzb9lcr"; + system = "cl-kyoto-cabinet"; + asd = "cl-kyoto-cabinet"; + } + ); + systems = [ "cl-kyoto-cabinet" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-l10n = ( + build-asdf-system { + pname = "cl-l10n"; + version = "20211209-git"; + asds = [ "cl-l10n" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-l10n/2021-12-09/cl-l10n-20211209-git.tgz"; + sha256 = "10yknvjcbgc82a6k6yzj2diki2z2s04q5kg642f2gfj2rl3bjyz7"; + system = "cl-l10n"; + asd = "cl-l10n"; + } + ); + systems = [ "cl-l10n" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "cl-l10n-cldr" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "cxml" self) + (getAttr "flexi-streams" self) + (getAttr "iterate" self) + (getAttr "local-time" self) + (getAttr "metabang-bind" self) + ]; + meta = { }; + } + ); + cl-l10n-cldr = ( + build-asdf-system { + pname = "cl-l10n-cldr"; + version = "20120909-darcs"; + asds = [ "cl-l10n-cldr" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-l10n-cldr/2012-09-09/cl-l10n-cldr-20120909-darcs.tgz"; + sha256 = "1mwkjdc51158v9rpdpsc1qzqqs0x8hb9k1k7b0pm8q7dp9rrb53v"; + system = "cl-l10n-cldr"; + asd = "cl-l10n-cldr"; + } + ); + systems = [ "cl-l10n-cldr" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-lambdacalc = ( + build-asdf-system { + pname = "cl-lambdacalc"; + version = "20230214-git"; + asds = [ "cl-lambdacalc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-lambdacalc/2023-02-14/cl-lambdacalc-20230214-git.tgz"; + sha256 = "0ja08d6p1dnbpf8yl8n59vis5lzr3x32in3iin72zmhj5n60axbd"; + system = "cl-lambdacalc"; + asd = "cl-lambdacalc"; + } + ); + systems = [ "cl-lambdacalc" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-lambdacalc-test = ( + build-asdf-system { + pname = "cl-lambdacalc-test"; + version = "20230214-git"; + asds = [ "cl-lambdacalc-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-lambdacalc/2023-02-14/cl-lambdacalc-20230214-git.tgz"; + sha256 = "0ja08d6p1dnbpf8yl8n59vis5lzr3x32in3iin72zmhj5n60axbd"; + system = "cl-lambdacalc-test"; + asd = "cl-lambdacalc-test"; + } + ); + systems = [ "cl-lambdacalc-test" ]; + lispLibs = [ + (getAttr "cl-lambdacalc" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-las = ( + build-asdf-system { + pname = "cl-las"; + version = "20221106-git"; + asds = [ "cl-las" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-las/2022-11-06/cl-las-20221106-git.tgz"; + sha256 = "119v5mrvxhz8b3alqj9gzfbzhigdm1n1hmwyylncn5w5dkq3jc9k"; + system = "cl-las"; + asd = "cl-las"; + } + ); + systems = [ "cl-las" ]; + lispLibs = [ (getAttr "binary-io" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-lastfm = ( + build-asdf-system { + pname = "cl-lastfm"; + version = "0.2.1"; + asds = [ "cl-lastfm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-lastfm/2014-07-13/cl-lastfm-0.2.1.tgz"; + sha256 = "0f37b8swgfz57bffcypjhcgzj5dhanssiraahkianj65a6zbindl"; + system = "cl-lastfm"; + asd = "cl-lastfm"; + } + ); + systems = [ "cl-lastfm" ]; + lispLibs = [ + (getAttr "cxml-stp" self) + (getAttr "drakma" self) + (getAttr "trivial-utf-8" self) + (getAttr "url-rewrite" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-lastfm-test = ( + build-asdf-system { + pname = "cl-lastfm-test"; + version = "0.2.1"; + asds = [ "cl-lastfm-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-lastfm/2014-07-13/cl-lastfm-0.2.1.tgz"; + sha256 = "0f37b8swgfz57bffcypjhcgzj5dhanssiraahkianj65a6zbindl"; + system = "cl-lastfm-test"; + asd = "cl-lastfm-test"; + } + ); + systems = [ "cl-lastfm-test" ]; + lispLibs = [ + (getAttr "cl-lastfm" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-launch = ( + build-asdf-system { + pname = "cl-launch"; + version = "4.1.4.1"; + asds = [ "cl-launch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-launch/2015-10-31/cl-launch-4.1.4.1.tgz"; + sha256 = "041nh1sh9rqdk9c1kr63n3g2pn11i68x9plzyfq36wmyhz2aypnr"; + system = "cl-launch"; + asd = "cl-launch"; + } + ); + systems = [ "cl-launch" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-lc = ( + build-asdf-system { + pname = "cl-lc"; + version = "20241012-git"; + asds = [ "cl-lc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-lc/2024-10-12/cl-lc-20241012-git.tgz"; + sha256 = "07wpbwgjybhp6vdr2rbd93jwakqixr9dyymp3yz1h684ln7wvfkb"; + system = "cl-lc"; + asd = "cl-lc"; + } + ); + systems = [ "cl-lc" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "optima" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ledger = ( + build-asdf-system { + pname = "cl-ledger"; + version = "20200218-git"; + asds = [ "cl-ledger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ledger/2020-02-18/cl-ledger-20200218-git.tgz"; + sha256 = "1dpxna9s0rgshqbc58h698ihwyk34a3napb8zrm8vbq8aigjrrzs"; + system = "cl-ledger"; + asd = "cl-ledger"; + } + ); + systems = [ "cl-ledger" ]; + lispLibs = [ + (getAttr "cambl" self) + (getAttr "cl-ppcre" self) + (getAttr "local-time" self) + (getAttr "periods-series" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-lex = ( + build-asdf-system { + pname = "cl-lex"; + version = "20160929-git"; + asds = [ "cl-lex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-lex/2016-09-29/cl-lex-20160929-git.tgz"; + sha256 = "1kg50f76bfpfxcv4dfivq1n9a0xlsra2ajb0vd68lxwgbidgyc2y"; + system = "cl-lex"; + asd = "cl-lex"; + } + ); + systems = [ "cl-lex" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-lexer = ( + build-asdf-system { + pname = "cl-lexer"; + version = "20191007-git"; + asds = [ "cl-lexer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-lexer/2019-10-07/cl-lexer-20191007-git.tgz"; + sha256 = "182fnmazfmc3zdp14lvpxlaxrwwsjp8mbjn8sdzywjxcnvlpkdmk"; + system = "cl-lexer"; + asd = "cl-lexer"; + } + ); + systems = [ "cl-lexer" ]; + lispLibs = [ (getAttr "regex" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-liballegro = ( + build-asdf-system { + pname = "cl-liballegro"; + version = "20241012-git"; + asds = [ "cl-liballegro" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-liballegro/2024-10-12/cl-liballegro-20241012-git.tgz"; + sha256 = "1q263wzm25rynyhcym216l3swhrz6fhiwhdbh4iz212hw9w0kn71"; + system = "cl-liballegro"; + asd = "cl-liballegro"; + } + ); + systems = [ "cl-liballegro" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + (getAttr "float-features" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-gray-streams" self) + (getAttr "trivial-main-thread" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-liballegro-nuklear = ( + build-asdf-system { + pname = "cl-liballegro-nuklear"; + version = "20241012-git"; + asds = [ "cl-liballegro-nuklear" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-liballegro-nuklear/2024-10-12/cl-liballegro-nuklear-20241012-git.tgz"; + sha256 = "15wbs1jfl60dnyzgzdibw2hkl64cx3n3v90i5jp0vd123kix217j"; + system = "cl-liballegro-nuklear"; + asd = "cl-liballegro-nuklear"; + } + ); + systems = [ "cl-liballegro-nuklear" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + (getAttr "cl-liballegro" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libevent2 = ( + build-asdf-system { + pname = "cl-libevent2"; + version = "20190107-git"; + asds = [ "cl-libevent2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libevent2/2019-01-07/cl-libevent2-20190107-git.tgz"; + sha256 = "18c8cxlh0vmyca7ihj8dz3f1j31h7y0kcis6qr6mpkzyi0k2cf0g"; + system = "cl-libevent2"; + asd = "cl-libevent2"; + } + ); + systems = [ "cl-libevent2" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libevent2-ssl = ( + build-asdf-system { + pname = "cl-libevent2-ssl"; + version = "20190107-git"; + asds = [ "cl-libevent2-ssl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libevent2/2019-01-07/cl-libevent2-20190107-git.tgz"; + sha256 = "18c8cxlh0vmyca7ihj8dz3f1j31h7y0kcis6qr6mpkzyi0k2cf0g"; + system = "cl-libevent2-ssl"; + asd = "cl-libevent2-ssl"; + } + ); + systems = [ "cl-libevent2-ssl" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-libevent2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libiio = ( + build-asdf-system { + pname = "cl-libiio"; + version = "20191130-git"; + asds = [ "cl-libiio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libiio/2019-11-30/cl-libiio-20191130-git.tgz"; + sha256 = "1z1jslm303c22imhshr92j1mq7g3j81xa5rk5psj3x00papncwmr"; + system = "cl-libiio"; + asd = "cl-libiio"; + } + ); + systems = [ "cl-libiio" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libinput = ( + build-asdf-system { + pname = "cl-libinput"; + version = "20220707-git"; + asds = [ "cl-libinput" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libinput/2022-07-07/cl-libinput-20220707-git.tgz"; + sha256 = "18c3rl3d2bizbp3607gnn9j50x84f2mkypj9rqbry56i5gcw8zkh"; + system = "cl-libinput"; + asd = "cl-libinput"; + } + ); + systems = [ "cl-libinput" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "osicat" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-liblinear = ( + build-asdf-system { + pname = "cl-liblinear"; + version = "20211020-git"; + asds = [ "cl-liblinear" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libsvm/2021-10-20/cl-libsvm-20211020-git.tgz"; + sha256 = "0fpcw82hz6bp2hicjhvhxwcj4azprcl911n8q941lk8xcld3pmi0"; + system = "cl-liblinear"; + asd = "cl-liblinear"; + } + ); + systems = [ "cl-liblinear" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libpuzzle = ( + build-asdf-system { + pname = "cl-libpuzzle"; + version = "20150608-git"; + asds = [ "cl-libpuzzle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libpuzzle/2015-06-08/cl-libpuzzle-20150608-git.tgz"; + sha256 = "0qgpdg4lni4sq6jp23qcd1jldsnrsn4h5b14ddmc8mb7va4qshlp"; + system = "cl-libpuzzle"; + asd = "cl-libpuzzle"; + } + ); + systems = [ "cl-libpuzzle" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libpuzzle-test = ( + build-asdf-system { + pname = "cl-libpuzzle-test"; + version = "20150608-git"; + asds = [ "cl-libpuzzle-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libpuzzle/2015-06-08/cl-libpuzzle-20150608-git.tgz"; + sha256 = "0qgpdg4lni4sq6jp23qcd1jldsnrsn4h5b14ddmc8mb7va4qshlp"; + system = "cl-libpuzzle-test"; + asd = "cl-libpuzzle-test"; + } + ); + systems = [ "cl-libpuzzle-test" ]; + lispLibs = [ + (getAttr "cl-libpuzzle" self) + (getAttr "cl-test-more" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libsvm = ( + build-asdf-system { + pname = "cl-libsvm"; + version = "20211020-git"; + asds = [ "cl-libsvm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libsvm/2021-10-20/cl-libsvm-20211020-git.tgz"; + sha256 = "0fpcw82hz6bp2hicjhvhxwcj4azprcl911n8q941lk8xcld3pmi0"; + system = "cl-libsvm"; + asd = "cl-libsvm"; + } + ); + systems = [ "cl-libsvm" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libsvm-format = ( + build-asdf-system { + pname = "cl-libsvm-format"; + version = "20180711-git"; + asds = [ "cl-libsvm-format" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libsvm-format/2018-07-11/cl-libsvm-format-20180711-git.tgz"; + sha256 = "0284aj84xszhkhlivaigf9qj855fxad3mzmv3zfr0qzb5k0nzwrg"; + system = "cl-libsvm-format"; + asd = "cl-libsvm-format"; + } + ); + systems = [ "cl-libsvm-format" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libsvm-format-test = ( + build-asdf-system { + pname = "cl-libsvm-format-test"; + version = "20180711-git"; + asds = [ "cl-libsvm-format-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libsvm-format/2018-07-11/cl-libsvm-format-20180711-git.tgz"; + sha256 = "0284aj84xszhkhlivaigf9qj855fxad3mzmv3zfr0qzb5k0nzwrg"; + system = "cl-libsvm-format-test"; + asd = "cl-libsvm-format-test"; + } + ); + systems = [ "cl-libsvm-format-test" ]; + lispLibs = [ + (getAttr "cl-libsvm-format" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libusb = ( + build-asdf-system { + pname = "cl-libusb"; + version = "20210228-git"; + asds = [ "cl-libusb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libusb/2021-02-28/cl-libusb-20210228-git.tgz"; + sha256 = "0kyzgcflwb85q58fgn82sp0bipnq5bprg5i4h0h3jxafqqyagbnk"; + system = "cl-libusb"; + asd = "cl-libusb"; + } + ); + systems = [ "cl-libusb" ]; + lispLibs = [ + (getAttr "libusb-ffi" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libuv = ( + build-asdf-system { + pname = "cl-libuv"; + version = "20230618-git"; + asds = [ "cl-libuv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libuv/2023-06-18/cl-libuv-20230618-git.tgz"; + sha256 = "13kymryibhlq7jc8q3yar0c676srx82axfmz0x2r5kq7k94cknl9"; + system = "cl-libuv"; + asd = "cl-libuv"; + } + ); + systems = [ "cl-libuv" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { }; + } + ); + cl-libuv-config = ( + build-asdf-system { + pname = "cl-libuv-config"; + version = "20230618-git"; + asds = [ "cl-libuv-config" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libuv/2023-06-18/cl-libuv-20230618-git.tgz"; + sha256 = "13kymryibhlq7jc8q3yar0c676srx82axfmz0x2r5kq7k94cknl9"; + system = "cl-libuv-config"; + asd = "cl-libuv-config"; + } + ); + systems = [ "cl-libuv-config" ]; + lispLibs = [ (getAttr "cffi-grovel" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libxml2 = ( + build-asdf-system { + pname = "cl-libxml2"; + version = "20130615-git"; + asds = [ "cl-libxml2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libxml2/2013-06-15/cl-libxml2-20130615-git.tgz"; + sha256 = "09049c13cfp5sc6x9lrw762jd7a9qkfq5jgngqgrzn4kn9qscarw"; + system = "cl-libxml2"; + asd = "cl-libxml2"; + } + ); + systems = [ "cl-libxml2" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "flexi-streams" self) + (getAttr "garbage-pools" self) + (getAttr "iterate" self) + (getAttr "metabang-bind" self) + (getAttr "puri" self) + ]; + meta = { }; + } + ); + cl-libxml2-test = ( + build-asdf-system { + pname = "cl-libxml2-test"; + version = "20130615-git"; + asds = [ "cl-libxml2-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libxml2/2013-06-15/cl-libxml2-20130615-git.tgz"; + sha256 = "09049c13cfp5sc6x9lrw762jd7a9qkfq5jgngqgrzn4kn9qscarw"; + system = "cl-libxml2-test"; + asd = "cl-libxml2"; + } + ); + systems = [ "cl-libxml2-test" ]; + lispLibs = [ + (getAttr "cl-libxml2" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-libyaml = ( + build-asdf-system { + pname = "cl-libyaml"; + version = "20201220-git"; + asds = [ "cl-libyaml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libyaml/2020-12-20/cl-libyaml-20201220-git.tgz"; + sha256 = "06pvmackyhq03rjmihpx6w63m6cy8wx78ll5xpwwvd85bgrqq817"; + system = "cl-libyaml"; + asd = "cl-libyaml"; + } + ); + systems = [ "cl-libyaml" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { }; + } + ); + cl-libyaml-test = ( + build-asdf-system { + pname = "cl-libyaml-test"; + version = "20201220-git"; + asds = [ "cl-libyaml-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libyaml/2020-12-20/cl-libyaml-20201220-git.tgz"; + sha256 = "06pvmackyhq03rjmihpx6w63m6cy8wx78ll5xpwwvd85bgrqq817"; + system = "cl-libyaml-test"; + asd = "cl-libyaml-test"; + } + ); + systems = [ "cl-libyaml-test" ]; + lispLibs = [ + (getAttr "cl-libyaml" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-lite = ( + build-asdf-system { + pname = "cl-lite"; + version = "master-fe503896-git"; + asds = [ "cl-lite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "cl-lite"; + asd = "cl-lite"; + } + ); + systems = [ "cl-lite" ]; + lispLibs = [ (getAttr "glisp" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-locale = ( + build-asdf-system { + pname = "cl-locale"; + version = "20151031-git"; + asds = [ "cl-locale" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-locale/2015-10-31/cl-locale-20151031-git.tgz"; + sha256 = "1rhannhpsw1yg1fpflam483a3w9qb1izgyvmnmiddv3dn4qsmn9p"; + system = "cl-locale"; + asd = "cl-locale"; + } + ); + systems = [ "cl-locale" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "arnesi" self) + (getAttr "cl-annot" self) + (getAttr "cl-syntax" self) + (getAttr "cl-syntax-annot" self) + ]; + meta = { }; + } + ); + cl-locale-syntax = ( + build-asdf-system { + pname = "cl-locale-syntax"; + version = "20151031-git"; + asds = [ "cl-locale-syntax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-locale/2015-10-31/cl-locale-20151031-git.tgz"; + sha256 = "1rhannhpsw1yg1fpflam483a3w9qb1izgyvmnmiddv3dn4qsmn9p"; + system = "cl-locale-syntax"; + asd = "cl-locale-syntax"; + } + ); + systems = [ "cl-locale-syntax" ]; + lispLibs = [ + (getAttr "cl-locale" self) + (getAttr "cl-syntax" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-locale-test = ( + build-asdf-system { + pname = "cl-locale-test"; + version = "20151031-git"; + asds = [ "cl-locale-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-locale/2015-10-31/cl-locale-20151031-git.tgz"; + sha256 = "1rhannhpsw1yg1fpflam483a3w9qb1izgyvmnmiddv3dn4qsmn9p"; + system = "cl-locale-test"; + asd = "cl-locale-test"; + } + ); + systems = [ "cl-locale-test" ]; + lispLibs = [ + (getAttr "cl-locale" self) + (getAttr "cl-syntax" self) + (getAttr "flexi-streams" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-locatives = ( + build-asdf-system { + pname = "cl-locatives"; + version = "20230618-git"; + asds = [ "cl-locatives" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-locatives/2023-06-18/cl-locatives-20230618-git.tgz"; + sha256 = "05avna8fj3bicdhbcvnjmv9dnqq10g26m9pwgmrh6a4hyxz9zdaq"; + system = "cl-locatives"; + asd = "cl-locatives"; + } + ); + systems = [ "cl-locatives" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-log = ( + build-asdf-system { + pname = "cl-log"; + version = "20241012-git"; + asds = [ "cl-log" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-log/2024-10-12/cl-log-20241012-git.tgz"; + sha256 = "1r3z9swy1b59swvaa5b97is9ysrfmjvjjhhw56p7p5hqg93b92ak"; + system = "cl-log"; + asd = "cl-log"; + } + ); + systems = [ "cl-log" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-logic = ( + build-asdf-system { + pname = "cl-logic"; + version = "20141217-git"; + asds = [ "cl-logic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-logic/2014-12-17/cl-logic-20141217-git.tgz"; + sha256 = "17n2wzqali3j6b7pqbydipwlxgwdrj4mdnsgwjdyz32n8jvfyjwh"; + system = "cl-logic"; + asd = "cl-logic"; + } + ); + systems = [ "cl-logic" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "quine-mccluskey" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ltsv = ( + build-asdf-system { + pname = "cl-ltsv"; + version = "20140713-git"; + asds = [ "cl-ltsv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ltsv/2014-07-13/cl-ltsv-20140713-git.tgz"; + sha256 = "1bjvnwxyaaw3yrq5hws2fr4qmk5938hdh2np2bqpm4m3b2c94n22"; + system = "cl-ltsv"; + asd = "cl-ltsv"; + } + ); + systems = [ "cl-ltsv" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ltsv-test = ( + build-asdf-system { + pname = "cl-ltsv-test"; + version = "20140713-git"; + asds = [ "cl-ltsv-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ltsv/2014-07-13/cl-ltsv-20140713-git.tgz"; + sha256 = "1bjvnwxyaaw3yrq5hws2fr4qmk5938hdh2np2bqpm4m3b2c94n22"; + system = "cl-ltsv-test"; + asd = "cl-ltsv-test"; + } + ); + systems = [ "cl-ltsv-test" ]; + lispLibs = [ + (getAttr "cl-ltsv" self) + (getAttr "cl-test-more" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-lzma = ( + build-asdf-system { + pname = "cl-lzma"; + version = "20191130-git"; + asds = [ "cl-lzma" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-lzma/2019-11-30/cl-lzma-20191130-git.tgz"; + sha256 = "17fdinmi2ffdga17slv86van0sp9gkvlmjprfdwak2jzziz6fxx6"; + system = "cl-lzma"; + asd = "cl-lzma"; + } + ); + systems = [ "cl-lzma" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-autowrap" self) + (getAttr "fast-io" self) + (getAttr "static-vectors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-m4 = ( + build-asdf-system { + pname = "cl-m4"; + version = "20130312-git"; + asds = [ "cl-m4" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-m4/2013-03-12/cl-m4-20130312-git.tgz"; + sha256 = "1dqdhxb45j4vqmx38xkq32gsckldca8rxpf2idg4b61wd21c0ci6"; + system = "cl-m4"; + asd = "cl-m4"; + } + ); + systems = [ "cl-m4" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "external-program" self) + (getAttr "graylex" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-m4-test = ( + build-asdf-system { + pname = "cl-m4-test"; + version = "20130312-git"; + asds = [ "cl-m4-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-m4/2013-03-12/cl-m4-20130312-git.tgz"; + sha256 = "1dqdhxb45j4vqmx38xkq32gsckldca8rxpf2idg4b61wd21c0ci6"; + system = "cl-m4-test"; + asd = "cl-m4-test"; + } + ); + systems = [ "cl-m4-test" ]; + lispLibs = [ + (getAttr "cl-heredoc" self) + (getAttr "cl-m4" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mango = ( + build-asdf-system { + pname = "cl-mango"; + version = "20200925-git"; + asds = [ "cl-mango" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mango/2020-09-25/cl-mango-20200925-git.tgz"; + sha256 = "0ipa1azakzqigq103m1j2z597bp2i34kx4z1418kp2jn8zwbdz5s"; + system = "cl-mango"; + asd = "cl-mango"; + } + ); + systems = [ "cl-mango" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "json-mop" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-markdown = ( + build-asdf-system { + pname = "cl-markdown"; + version = "20191227-git"; + asds = [ "cl-markdown" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-markdown/2019-12-27/cl-markdown-20191227-git.tgz"; + sha256 = "1wksi765nk8kf5qm2chh7dcn6k562kvc108dzdb9y5iwp97lqqvg"; + system = "cl-markdown"; + asd = "cl-markdown"; + } + ); + systems = [ "cl-markdown" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "cl-containers" self) + (getAttr "cl-ppcre" self) + (getAttr "dynamic-classes" self) + (getAttr "metabang-bind" self) + (getAttr "metatilities-base" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-markdown-comparisons = ( + build-asdf-system { + pname = "cl-markdown-comparisons"; + version = "20191227-git"; + asds = [ "cl-markdown-comparisons" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-markdown/2019-12-27/cl-markdown-20191227-git.tgz"; + sha256 = "1wksi765nk8kf5qm2chh7dcn6k562kvc108dzdb9y5iwp97lqqvg"; + system = "cl-markdown-comparisons"; + asd = "cl-markdown-comparisons"; + } + ); + systems = [ "cl-markdown-comparisons" ]; + lispLibs = [ + (getAttr "cl-html-diff" self) + (getAttr "cl-markdown" self) + (getAttr "html-encode" self) + (getAttr "lift" self) + (getAttr "lml2" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-markdown-test = ( + build-asdf-system { + pname = "cl-markdown-test"; + version = "20191227-git"; + asds = [ "cl-markdown-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-markdown/2019-12-27/cl-markdown-20191227-git.tgz"; + sha256 = "1wksi765nk8kf5qm2chh7dcn6k562kvc108dzdb9y5iwp97lqqvg"; + system = "cl-markdown-test"; + asd = "cl-markdown-test"; + } + ); + systems = [ "cl-markdown-test" ]; + lispLibs = [ + (getAttr "cl-markdown" self) + (getAttr "lift" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-markless = ( + build-asdf-system { + pname = "cl-markless"; + version = "20241012-git"; + asds = [ "cl-markless" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; + sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; + system = "cl-markless"; + asd = "cl-markless"; + } + ); + systems = [ "cl-markless" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "trivial-indent" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-markless-epub = ( + build-asdf-system { + pname = "cl-markless-epub"; + version = "20241012-git"; + asds = [ "cl-markless-epub" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; + sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; + system = "cl-markless-epub"; + asd = "cl-markless-epub"; + } + ); + systems = [ "cl-markless-epub" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-markless-plump" self) + (getAttr "trivial-gray-streams" self) + (getAttr "trivial-indent" self) + (getAttr "trivial-mimes" self) + (getAttr "zip" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-markless-latex = ( + build-asdf-system { + pname = "cl-markless-latex"; + version = "20241012-git"; + asds = [ "cl-markless-latex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; + sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; + system = "cl-markless-latex"; + asd = "cl-markless-latex"; + } + ); + systems = [ "cl-markless-latex" ]; + lispLibs = [ (getAttr "cl-markless" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-markless-markdown = ( + build-asdf-system { + pname = "cl-markless-markdown"; + version = "20241012-git"; + asds = [ "cl-markless-markdown" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; + sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; + system = "cl-markless-markdown"; + asd = "cl-markless-markdown"; + } + ); + systems = [ "cl-markless-markdown" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "_3bmd-ext-code-blocks" self) + (getAttr "cl-markless" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-markless-plump = ( + build-asdf-system { + pname = "cl-markless-plump"; + version = "20241012-git"; + asds = [ "cl-markless-plump" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; + sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; + system = "cl-markless-plump"; + asd = "cl-markless-plump"; + } + ); + systems = [ "cl-markless-plump" ]; + lispLibs = [ + (getAttr "cl-markless" self) + (getAttr "plump-dom" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-markless-standalone = ( + build-asdf-system { + pname = "cl-markless-standalone"; + version = "20241012-git"; + asds = [ "cl-markless-standalone" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; + sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; + system = "cl-markless-standalone"; + asd = "cl-markless-standalone"; + } + ); + systems = [ "cl-markless-standalone" ]; + lispLibs = [ + (getAttr "cl-markless" self) + (getAttr "cl-markless-epub" self) + (getAttr "cl-markless-latex" self) + (getAttr "cl-markless-markdown" self) + (getAttr "cl-markless-plump" self) + (getAttr "command-line-arguments" self) + (getAttr "pathname-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-markless-test = ( + build-asdf-system { + pname = "cl-markless-test"; + version = "20241012-git"; + asds = [ "cl-markless-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-markless/2024-10-12/cl-markless-20241012-git.tgz"; + sha256 = "0csbqglj5ccjw7j95a6cb8pj195lrdk1pn0y3f37w3pjy4pg782g"; + system = "cl-markless-test"; + asd = "cl-markless-test"; + } + ); + systems = [ "cl-markless-test" ]; + lispLibs = [ + (getAttr "cl-markless" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-marklogic = ( + build-asdf-system { + pname = "cl-marklogic"; + version = "20210124-git"; + asds = [ "cl-marklogic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-marklogic/2021-01-24/cl-marklogic-20210124-git.tgz"; + sha256 = "0baq2ccb88zyr2dqdvpm32lsin4zalv11w48x4xm80cr4kw45fk5"; + system = "cl-marklogic"; + asd = "cl-marklogic"; + } + ); + systems = [ "cl-marklogic" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "drakma" self) + (getAttr "fiveam" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-markup = ( + build-asdf-system { + pname = "cl-markup"; + version = "20131003-git"; + asds = [ "cl-markup" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-markup/2013-10-03/cl-markup-20131003-git.tgz"; + sha256 = "10l6k45971dl13fkdmva7zc6i453lmq9j4xax2ci6pjzlc6xjhp7"; + system = "cl-markup"; + asd = "cl-markup"; + } + ); + systems = [ "cl-markup" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-markup-test = ( + build-asdf-system { + pname = "cl-markup-test"; + version = "20131003-git"; + asds = [ "cl-markup-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-markup/2013-10-03/cl-markup-20131003-git.tgz"; + sha256 = "10l6k45971dl13fkdmva7zc6i453lmq9j4xax2ci6pjzlc6xjhp7"; + system = "cl-markup-test"; + asd = "cl-markup-test"; + } + ); + systems = [ "cl-markup-test" ]; + lispLibs = [ + (getAttr "cl-markup" self) + (getAttr "cl-test-more" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-match = ( + build-asdf-system { + pname = "cl-match"; + version = "20121125-git"; + asds = [ "cl-match" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-match/2012-11-25/cl-match-20121125-git.tgz"; + sha256 = "1qc8gzp7f4phgyi5whkxacrqzdqs0y1hvkf71m8n7l303jly9wjf"; + system = "cl-match"; + asd = "cl-match"; + } + ); + systems = [ "cl-match" ]; + lispLibs = [ (getAttr "standard-cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-match-test = ( + build-asdf-system { + pname = "cl-match-test"; + version = "20121125-git"; + asds = [ "cl-match-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-match/2012-11-25/cl-match-20121125-git.tgz"; + sha256 = "1qc8gzp7f4phgyi5whkxacrqzdqs0y1hvkf71m8n7l303jly9wjf"; + system = "cl-match-test"; + asd = "cl-match-test"; + } + ); + systems = [ "cl-match-test" ]; + lispLibs = [ + (getAttr "cl-match" self) + (getAttr "pcl-unit-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mathstats = ( + build-asdf-system { + pname = "cl-mathstats"; + version = "20230214-git"; + asds = [ "cl-mathstats" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mathstats/2023-02-14/cl-mathstats-20230214-git.tgz"; + sha256 = "17ic625bdsvgfjndl4zzxkjy7dcl54alg2pdr0jjn4cpysffga6z"; + system = "cl-mathstats"; + asd = "cl-mathstats"; + } + ); + systems = [ "cl-mathstats" ]; + lispLibs = [ + (getAttr "cl-containers" self) + (getAttr "metatilities-base" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mathstats-test = ( + build-asdf-system { + pname = "cl-mathstats-test"; + version = "20230214-git"; + asds = [ "cl-mathstats-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mathstats/2023-02-14/cl-mathstats-20230214-git.tgz"; + sha256 = "17ic625bdsvgfjndl4zzxkjy7dcl54alg2pdr0jjn4cpysffga6z"; + system = "cl-mathstats-test"; + asd = "cl-mathstats-test"; + } + ); + systems = [ "cl-mathstats-test" ]; + lispLibs = [ + (getAttr "cl-mathstats" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-maxminddb = ( + build-asdf-system { + pname = "cl-maxminddb"; + version = "20210630-git"; + asds = [ "cl-maxminddb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-maxminddb/2021-06-30/cl-maxminddb-20210630-git.tgz"; + sha256 = "1mm7cpiygcka39pj4a0rvhayfl4wh0zfjkda60yshq24xmml84pw"; + system = "cl-maxminddb"; + asd = "cl-maxminddb"; + } + ); + systems = [ "cl-maxminddb" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + (getAttr "ieee-floats" self) + (getAttr "iterate" self) + (getAttr "metabang-bind" self) + (getAttr "mmap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-maxsat = ( + build-asdf-system { + pname = "cl-maxsat"; + version = "20200218-git"; + asds = [ "cl-maxsat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-maxsat/2020-02-18/cl-maxsat-20200218-git.tgz"; + sha256 = "0qy4hhi8y3wv88x3s88g2hl2cz25cjp26xapd3z4h7lrx7cy786i"; + system = "cl-maxsat"; + asd = "cl-maxsat"; + } + ); + systems = [ "cl-maxsat" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-sat" self) + (getAttr "iterate" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-maxsat_dot_test = ( + build-asdf-system { + pname = "cl-maxsat.test"; + version = "20200218-git"; + asds = [ "cl-maxsat.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-maxsat/2020-02-18/cl-maxsat-20200218-git.tgz"; + sha256 = "0qy4hhi8y3wv88x3s88g2hl2cz25cjp26xapd3z4h7lrx7cy786i"; + system = "cl-maxsat.test"; + asd = "cl-maxsat.test"; + } + ); + systems = [ "cl-maxsat.test" ]; + lispLibs = [ + (getAttr "cl-maxsat" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mdb = ( + build-asdf-system { + pname = "cl-mdb"; + version = "20220707-git"; + asds = [ "cl-mdb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mdb/2022-07-07/cl-mdb-20220707-git.tgz"; + sha256 = "1xkhk39485yv3j9bshnnv74c95asf9704g80wb8vwvwsvqi7ym2a"; + system = "cl-mdb"; + asd = "cl-mdb"; + } + ); + systems = [ "cl-mdb" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mecab = ( + build-asdf-system { + pname = "cl-mecab"; + version = "20181018-git"; + asds = [ "cl-mecab" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mecab/2018-10-18/cl-mecab-20181018-git.tgz"; + sha256 = "0lfan9p8dsniyp60g6n8awfjvv8lyickc40qdxiry6kmp65636ps"; + system = "cl-mecab"; + asd = "cl-mecab"; + } + ); + systems = [ "cl-mecab" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mecab-test = ( + build-asdf-system { + pname = "cl-mecab-test"; + version = "20181018-git"; + asds = [ "cl-mecab-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mecab/2018-10-18/cl-mecab-20181018-git.tgz"; + sha256 = "0lfan9p8dsniyp60g6n8awfjvv8lyickc40qdxiry6kmp65636ps"; + system = "cl-mecab-test"; + asd = "cl-mecab-test"; + } + ); + systems = [ "cl-mecab-test" ]; + lispLibs = [ + (getAttr "cl-mecab" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mechanize = ( + build-asdf-system { + pname = "cl-mechanize"; + version = "20180711-git"; + asds = [ "cl-mechanize" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mechanize/2018-07-11/cl-mechanize-20180711-git.tgz"; + sha256 = "0y86sdi2nl3jv6n535cd62jax0mpc0cckrhffaqacbgbdjc875sn"; + system = "cl-mechanize"; + asd = "cl-mechanize"; + } + ); + systems = [ "cl-mechanize" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "closure-html" self) + (getAttr "cxml-stp" self) + (getAttr "drakma" self) + (getAttr "puri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mediawiki = ( + build-asdf-system { + pname = "cl-mediawiki"; + version = "20161204-git"; + asds = [ "cl-mediawiki" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mediawiki/2016-12-04/cl-mediawiki-20161204-git.tgz"; + sha256 = "1wrysj9l64k3xx152yw1arvn1glnx60j730qvj8prm65iid95xgm"; + system = "cl-mediawiki"; + asd = "cl-mediawiki"; + } + ); + systems = [ "cl-mediawiki" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cxml" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mediawiki-test = ( + build-asdf-system { + pname = "cl-mediawiki-test"; + version = "20161204-git"; + asds = [ "cl-mediawiki-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mediawiki/2016-12-04/cl-mediawiki-20161204-git.tgz"; + sha256 = "1wrysj9l64k3xx152yw1arvn1glnx60j730qvj8prm65iid95xgm"; + system = "cl-mediawiki-test"; + asd = "cl-mediawiki-test"; + } + ); + systems = [ "cl-mediawiki-test" ]; + lispLibs = [ + (getAttr "cl-mediawiki" self) + (getAttr "lisp-unit2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-megolm = ( + build-asdf-system { + pname = "cl-megolm"; + version = "20230214-git"; + asds = [ "cl-megolm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-megolm/2023-02-14/cl-megolm-20230214-git.tgz"; + sha256 = "1n80v63pw2ck419fglgdhhqnc06jmams6mnxb8sqdg966qxhql2k"; + system = "cl-megolm"; + asd = "cl-megolm"; + } + ); + systems = [ "cl-megolm" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "claw-olm" self) + (getAttr "ironclad" self) + (getAttr "jonathan" self) + (getAttr "lisp-unit" self) + (getAttr "s-base64" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-memcached = ( + build-asdf-system { + pname = "cl-memcached"; + version = "20150608-git"; + asds = [ "cl-memcached" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-memcached/2015-06-08/cl-memcached-20150608-git.tgz"; + sha256 = "0g66m0yiazzh0447qbmgxjn4kxjcx9bk2l8cimyzmriz5d0j2q3i"; + system = "cl-memcached"; + asd = "cl-memcached"; + } + ); + systems = [ "cl-memcached" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "pooler" self) + (getAttr "split-sequence" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-messagepack = ( + build-asdf-system { + pname = "cl-messagepack"; + version = "20231021-git"; + asds = [ "cl-messagepack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-messagepack/2023-10-21/cl-messagepack-20231021-git.tgz"; + sha256 = "1hjd1q18lz46k46afz94ljflp76mfr30d6z4jrsgd26y2lc4gchc"; + system = "cl-messagepack"; + asd = "cl-messagepack"; + } + ); + systems = [ "cl-messagepack" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "closer-mop" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-messagepack-rpc = ( + build-asdf-system { + pname = "cl-messagepack-rpc"; + version = "20171227-git"; + asds = [ "cl-messagepack-rpc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-messagepack-rpc/2017-12-27/cl-messagepack-rpc-20171227-git.tgz"; + sha256 = "02nrnhav28v5vwig9mmmmax59nl0sbjkmdzwakzpj6y1gafiqgy9"; + system = "cl-messagepack-rpc"; + asd = "cl-messagepack-rpc"; + } + ); + systems = [ "cl-messagepack-rpc" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-async" self) + (getAttr "cl-libuv" self) + (getAttr "cl-messagepack" self) + (getAttr "flexi-streams" self) + (getAttr "trivial-backtrace" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-messagepack-rpc-tests = ( + build-asdf-system { + pname = "cl-messagepack-rpc-tests"; + version = "20171227-git"; + asds = [ "cl-messagepack-rpc-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-messagepack-rpc/2017-12-27/cl-messagepack-rpc-20171227-git.tgz"; + sha256 = "02nrnhav28v5vwig9mmmmax59nl0sbjkmdzwakzpj6y1gafiqgy9"; + system = "cl-messagepack-rpc-tests"; + asd = "cl-messagepack-rpc-tests"; + } + ); + systems = [ "cl-messagepack-rpc-tests" ]; + lispLibs = [ + (getAttr "cl-messagepack-rpc" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-messagepack-tests = ( + build-asdf-system { + pname = "cl-messagepack-tests"; + version = "20231021-git"; + asds = [ "cl-messagepack-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-messagepack/2023-10-21/cl-messagepack-20231021-git.tgz"; + sha256 = "1hjd1q18lz46k46afz94ljflp76mfr30d6z4jrsgd26y2lc4gchc"; + system = "cl-messagepack-tests"; + asd = "cl-messagepack-tests"; + } + ); + systems = [ "cl-messagepack-tests" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "cl-messagepack" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-migrations = ( + build-asdf-system { + pname = "cl-migrations"; + version = "20110110-http"; + asds = [ "cl-migrations" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-migrations/2011-01-10/cl-migrations-20110110-http.tgz"; + sha256 = "0mq3ir1kffw921q5a878964ghnrhcrh79p6yxsrb25bzkwpnfx02"; + system = "cl-migrations"; + asd = "cl-migrations"; + } + ); + systems = [ "cl-migrations" ]; + lispLibs = [ (getAttr "clsql" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-migratum = ( + build-asdf-system { + pname = "cl-migratum"; + version = "20241012-git"; + asds = [ "cl-migratum" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; + sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; + system = "cl-migratum"; + asd = "cl-migratum"; + } + ); + systems = [ "cl-migratum" ]; + lispLibs = [ + (getAttr "cl-ascii-table" self) + (getAttr "cl-reexport" self) + (getAttr "local-time" self) + (getAttr "log4cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-migratum_dot_cli = ( + build-asdf-system { + pname = "cl-migratum.cli"; + version = "20241012-git"; + asds = [ "cl-migratum.cli" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; + sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; + system = "cl-migratum.cli"; + asd = "cl-migratum.cli"; + } + ); + systems = [ "cl-migratum.cli" ]; + lispLibs = [ + (getAttr "cl-migratum" self) + (getAttr "cl-migratum_dot_driver_dot_dbi" self) + (getAttr "cl-migratum_dot_driver_dot_rdbms-postgresql" self) + (getAttr "cl-migratum_dot_provider_dot_local-path" self) + (getAttr "clingon" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-migratum_dot_driver_dot_dbi = ( + build-asdf-system { + pname = "cl-migratum.driver.dbi"; + version = "20241012-git"; + asds = [ "cl-migratum.driver.dbi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; + sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; + system = "cl-migratum.driver.dbi"; + asd = "cl-migratum.driver.dbi"; + } + ); + systems = [ "cl-migratum.driver.dbi" ]; + lispLibs = [ + (getAttr "cl-dbi" self) + (getAttr "cl-migratum" self) + (getAttr "cl-migratum_dot_driver_dot_mixins" self) + (getAttr "cl-ppcre" self) + (getAttr "log4cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-migratum_dot_driver_dot_mixins = ( + build-asdf-system { + pname = "cl-migratum.driver.mixins"; + version = "20241012-git"; + asds = [ "cl-migratum.driver.mixins" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; + sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; + system = "cl-migratum.driver.mixins"; + asd = "cl-migratum.driver.mixins"; + } + ); + systems = [ "cl-migratum.driver.mixins" ]; + lispLibs = [ (getAttr "cl-migratum" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-migratum_dot_driver_dot_postmodern-postgresql = ( + build-asdf-system { + pname = "cl-migratum.driver.postmodern-postgresql"; + version = "20241012-git"; + asds = [ "cl-migratum.driver.postmodern-postgresql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; + sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; + system = "cl-migratum.driver.postmodern-postgresql"; + asd = "cl-migratum.driver.postmodern-postgresql"; + } + ); + systems = [ "cl-migratum.driver.postmodern-postgresql" ]; + lispLibs = [ + (getAttr "cl-migratum" self) + (getAttr "cl-migratum_dot_driver_dot_mixins" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "log4cl" self) + (getAttr "postmodern" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-migratum_dot_driver_dot_rdbms-postgresql = ( + build-asdf-system { + pname = "cl-migratum.driver.rdbms-postgresql"; + version = "20241012-git"; + asds = [ "cl-migratum.driver.rdbms-postgresql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; + sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; + system = "cl-migratum.driver.rdbms-postgresql"; + asd = "cl-migratum.driver.rdbms-postgresql"; + } + ); + systems = [ "cl-migratum.driver.rdbms-postgresql" ]; + lispLibs = [ + (getAttr "cl-migratum" self) + (getAttr "cl-migratum_dot_driver_dot_mixins" self) + (getAttr "cl-ppcre" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_postgresql" self) + (getAttr "log4cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-migratum_dot_provider_dot_local-path = ( + build-asdf-system { + pname = "cl-migratum.provider.local-path"; + version = "20241012-git"; + asds = [ "cl-migratum.provider.local-path" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; + sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; + system = "cl-migratum.provider.local-path"; + asd = "cl-migratum.provider.local-path"; + } + ); + systems = [ "cl-migratum.provider.local-path" ]; + lispLibs = [ + (getAttr "cl-migratum" self) + (getAttr "cl-ppcre" self) + (getAttr "log4cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-migratum_dot_test = ( + build-asdf-system { + pname = "cl-migratum.test"; + version = "20241012-git"; + asds = [ "cl-migratum.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-migratum/2024-10-12/cl-migratum-20241012-git.tgz"; + sha256 = "0bkzbvv3s2j5gs032nj82b0p3x6j3in54kqyg74x54b25q75ymvw"; + system = "cl-migratum.test"; + asd = "cl-migratum.test"; + } + ); + systems = [ "cl-migratum.test" ]; + lispLibs = [ + (getAttr "cl-migratum" self) + (getAttr "cl-migratum_dot_driver_dot_dbi" self) + (getAttr "cl-migratum_dot_driver_dot_postmodern-postgresql" self) + (getAttr "cl-migratum_dot_driver_dot_rdbms-postgresql" self) + (getAttr "cl-migratum_dot_provider_dot_local-path" self) + (getAttr "dbd-sqlite3" self) + (getAttr "rove" self) + (getAttr "tmpdir" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mime = ( + build-asdf-system { + pname = "cl-mime"; + version = "20201220-git"; + asds = [ "cl-mime" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mime/2020-12-20/cl-mime-20201220-git.tgz"; + sha256 = "0i2vyc1d4qp36f3c3qfpx9rkp3d2ka80r40wc9lsvhqn1hjxa2gv"; + system = "cl-mime"; + asd = "cl-mime"; + } + ); + systems = [ "cl-mime" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-qprint" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mime-from-string = ( + build-asdf-system { + pname = "cl-mime-from-string"; + version = "20200427-git"; + asds = [ "cl-mime-from-string" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mime-from-string/2020-04-27/cl-mime-from-string-20200427-git.tgz"; + sha256 = "1pzhfbv6j3b0vvf4rxxd56v54lh6v7cs16nq2d64cawn6qzmk4bp"; + system = "cl-mime-from-string"; + asd = "cl-mime-from-string"; + } + ); + systems = [ "cl-mime-from-string" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mime-test = ( + build-asdf-system { + pname = "cl-mime-test"; + version = "20201220-git"; + asds = [ "cl-mime-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mime/2020-12-20/cl-mime-20201220-git.tgz"; + sha256 = "0i2vyc1d4qp36f3c3qfpx9rkp3d2ka80r40wc9lsvhqn1hjxa2gv"; + system = "cl-mime-test"; + asd = "cl-mime-test"; + } + ); + systems = [ "cl-mime-test" ]; + lispLibs = [ + (getAttr "cl-mime" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mimeparse = ( + build-asdf-system { + pname = "cl-mimeparse"; + version = "20210531-git"; + asds = [ "cl-mimeparse" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mimeparse/2021-05-31/cl-mimeparse-20210531-git.tgz"; + sha256 = "0gdkpi3620va0a3q56svcn1q9f5w0pqfhx30lnldg8fjnrdfiwkk"; + system = "cl-mimeparse"; + asd = "cl-mimeparse"; + } + ); + systems = [ "cl-mimeparse" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "parse-number" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mimeparse-tests = ( + build-asdf-system { + pname = "cl-mimeparse-tests"; + version = "20210531-git"; + asds = [ "cl-mimeparse-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mimeparse/2021-05-31/cl-mimeparse-20210531-git.tgz"; + sha256 = "0gdkpi3620va0a3q56svcn1q9f5w0pqfhx30lnldg8fjnrdfiwkk"; + system = "cl-mimeparse-tests"; + asd = "cl-mimeparse-tests"; + } + ); + systems = [ "cl-mimeparse-tests" ]; + lispLibs = [ + (getAttr "cl-mimeparse" self) + (getAttr "rt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-minify-css = ( + build-asdf-system { + pname = "cl-minify-css"; + version = "20200925-git"; + asds = [ "cl-minify-css" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-minify-css/2020-09-25/cl-minify-css-20200925-git.tgz"; + sha256 = "1wj1mh7qzr8ybqyx7kxnpsmj3d9lylnzmq1qmycdyf2llqkcdxgd"; + system = "cl-minify-css"; + asd = "cl-minify-css"; + } + ); + systems = [ "cl-minify-css" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-minify-css-test = ( + build-asdf-system { + pname = "cl-minify-css-test"; + version = "20200925-git"; + asds = [ "cl-minify-css-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-minify-css/2020-09-25/cl-minify-css-20200925-git.tgz"; + sha256 = "1wj1mh7qzr8ybqyx7kxnpsmj3d9lylnzmq1qmycdyf2llqkcdxgd"; + system = "cl-minify-css-test"; + asd = "cl-minify-css-test"; + } + ); + systems = [ "cl-minify-css-test" ]; + lispLibs = [ + (getAttr "assert-p" self) + (getAttr "cacau" self) + (getAttr "cacau-asdf" self) + (getAttr "cl-minify-css" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed = ( + build-asdf-system { + pname = "cl-mixed"; + version = "20241012-git"; + asds = [ "cl-mixed" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed"; + asd = "cl-mixed"; + } + ); + systems = [ "cl-mixed" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "static-vectors" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-aaudio = ( + build-asdf-system { + pname = "cl-mixed-aaudio"; + version = "20241012-git"; + asds = [ "cl-mixed-aaudio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-aaudio"; + asd = "cl-mixed-aaudio"; + } + ); + systems = [ "cl-mixed-aaudio" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-mixed" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-alsa = ( + build-asdf-system { + pname = "cl-mixed-alsa"; + version = "20241012-git"; + asds = [ "cl-mixed-alsa" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-alsa"; + asd = "cl-mixed-alsa"; + } + ); + systems = [ "cl-mixed-alsa" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-mixed" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-coreaudio = ( + build-asdf-system { + pname = "cl-mixed-coreaudio"; + version = "20241012-git"; + asds = [ "cl-mixed-coreaudio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-coreaudio"; + asd = "cl-mixed-coreaudio"; + } + ); + systems = [ "cl-mixed-coreaudio" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cl-mixed" self) + (getAttr "float-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-examples = ( + build-asdf-system { + pname = "cl-mixed-examples"; + version = "20241012-git"; + asds = [ "cl-mixed-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-examples"; + asd = "cl-mixed-examples"; + } + ); + systems = [ "cl-mixed-examples" ]; + lispLibs = [ + (getAttr "cl-mixed" self) + (getAttr "cl-mixed-mpg123" self) + (getAttr "cl-mixed-out123" self) + (getAttr "cl-mixed-pulse" self) + (getAttr "cl-mixed-wav" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-flac = ( + build-asdf-system { + pname = "cl-mixed-flac"; + version = "20241012-git"; + asds = [ "cl-mixed-flac" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-flac"; + asd = "cl-mixed-flac"; + } + ); + systems = [ "cl-mixed-flac" ]; + lispLibs = [ + (getAttr "cl-flac" self) + (getAttr "cl-mixed" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-jack = ( + build-asdf-system { + pname = "cl-mixed-jack"; + version = "20241012-git"; + asds = [ "cl-mixed-jack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-jack"; + asd = "cl-mixed-jack"; + } + ); + systems = [ "cl-mixed-jack" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-mixed" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-mpg123 = ( + build-asdf-system { + pname = "cl-mixed-mpg123"; + version = "20241012-git"; + asds = [ "cl-mixed-mpg123" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-mpg123"; + asd = "cl-mixed-mpg123"; + } + ); + systems = [ "cl-mixed-mpg123" ]; + lispLibs = [ + (getAttr "cl-mixed" self) + (getAttr "cl-mpg123" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-mpt = ( + build-asdf-system { + pname = "cl-mixed-mpt"; + version = "20241012-git"; + asds = [ "cl-mixed-mpt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-mpt"; + asd = "cl-mixed-mpt"; + } + ); + systems = [ "cl-mixed-mpt" ]; + lispLibs = [ + (getAttr "cl-mixed" self) + (getAttr "static-vectors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-nxau = ( + build-asdf-system { + pname = "cl-mixed-nxau"; + version = "20241012-git"; + asds = [ "cl-mixed-nxau" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-nxau"; + asd = "cl-mixed-nxau"; + } + ); + systems = [ "cl-mixed-nxau" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-mixed" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-opus = ( + build-asdf-system { + pname = "cl-mixed-opus"; + version = "20241012-git"; + asds = [ "cl-mixed-opus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-opus"; + asd = "cl-mixed-opus"; + } + ); + systems = [ "cl-mixed-opus" ]; + lispLibs = [ + (getAttr "cl-mixed" self) + (getAttr "cl-opus" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-oss = ( + build-asdf-system { + pname = "cl-mixed-oss"; + version = "20241012-git"; + asds = [ "cl-mixed-oss" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-oss"; + asd = "cl-mixed-oss"; + } + ); + systems = [ "cl-mixed-oss" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-mixed" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-out123 = ( + build-asdf-system { + pname = "cl-mixed-out123"; + version = "20241012-git"; + asds = [ "cl-mixed-out123" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-out123"; + asd = "cl-mixed-out123"; + } + ); + systems = [ "cl-mixed-out123" ]; + lispLibs = [ + (getAttr "cl-mixed" self) + (getAttr "cl-out123" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-pulse = ( + build-asdf-system { + pname = "cl-mixed-pulse"; + version = "20241012-git"; + asds = [ "cl-mixed-pulse" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-pulse"; + asd = "cl-mixed-pulse"; + } + ); + systems = [ "cl-mixed-pulse" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-mixed" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-qoa = ( + build-asdf-system { + pname = "cl-mixed-qoa"; + version = "20241012-git"; + asds = [ "cl-mixed-qoa" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-qoa"; + asd = "cl-mixed-qoa"; + } + ); + systems = [ "cl-mixed-qoa" ]; + lispLibs = [ + (getAttr "cl-mixed" self) + (getAttr "cl-qoa" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-sdl2 = ( + build-asdf-system { + pname = "cl-mixed-sdl2"; + version = "20241012-git"; + asds = [ "cl-mixed-sdl2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-sdl2"; + asd = "cl-mixed-sdl2"; + } + ); + systems = [ "cl-mixed-sdl2" ]; + lispLibs = [ + (getAttr "cl-mixed" self) + (getAttr "sdl2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-vorbis = ( + build-asdf-system { + pname = "cl-mixed-vorbis"; + version = "20241012-git"; + asds = [ "cl-mixed-vorbis" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-vorbis"; + asd = "cl-mixed-vorbis"; + } + ); + systems = [ "cl-mixed-vorbis" ]; + lispLibs = [ + (getAttr "cl-mixed" self) + (getAttr "cl-vorbis" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-wasapi = ( + build-asdf-system { + pname = "cl-mixed-wasapi"; + version = "20241012-git"; + asds = [ "cl-mixed-wasapi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-wasapi"; + asd = "cl-mixed-wasapi"; + } + ); + systems = [ "cl-mixed-wasapi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-mixed" self) + (getAttr "com-on" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-wav = ( + build-asdf-system { + pname = "cl-mixed-wav"; + version = "20241012-git"; + asds = [ "cl-mixed-wav" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-wav"; + asd = "cl-mixed-wav"; + } + ); + systems = [ "cl-mixed-wav" ]; + lispLibs = [ (getAttr "cl-mixed" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-winmm = ( + build-asdf-system { + pname = "cl-mixed-winmm"; + version = "20241012-git"; + asds = [ "cl-mixed-winmm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-winmm"; + asd = "cl-mixed-winmm"; + } + ); + systems = [ "cl-mixed-winmm" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-mixed" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mixed-xaudio2 = ( + build-asdf-system { + pname = "cl-mixed-xaudio2"; + version = "20241012-git"; + asds = [ "cl-mixed-xaudio2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mixed/2024-10-12/cl-mixed-20241012-git.tgz"; + sha256 = "1wianjcr1ha9lb46q0i05fwn5cl4yzkg78mqk0ib564fbyx4y0q9"; + system = "cl-mixed-xaudio2"; + asd = "cl-mixed-xaudio2"; + } + ); + systems = [ "cl-mixed-xaudio2" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-mixed" self) + (getAttr "com-on" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mock = ( + build-asdf-system { + pname = "cl-mock"; + version = "20221106-git"; + asds = [ "cl-mock" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mock/2022-11-06/cl-mock-20221106-git.tgz"; + sha256 = "19641sm3klx9yfk8lr376rfkd26vy72yp1hkpkqcw3q3m1xrf9xp"; + system = "cl-mock"; + asd = "cl-mock"; + } + ); + systems = [ "cl-mock" ]; + lispLibs = [ + (getAttr "cl-mock-basic" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mock-basic = ( + build-asdf-system { + pname = "cl-mock-basic"; + version = "20221106-git"; + asds = [ "cl-mock-basic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mock/2022-11-06/cl-mock-20221106-git.tgz"; + sha256 = "19641sm3klx9yfk8lr376rfkd26vy72yp1hkpkqcw3q3m1xrf9xp"; + system = "cl-mock-basic"; + asd = "cl-mock-basic"; + } + ); + systems = [ "cl-mock-basic" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mock-tests = ( + build-asdf-system { + pname = "cl-mock-tests"; + version = "20221106-git"; + asds = [ "cl-mock-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mock/2022-11-06/cl-mock-20221106-git.tgz"; + sha256 = "19641sm3klx9yfk8lr376rfkd26vy72yp1hkpkqcw3q3m1xrf9xp"; + system = "cl-mock-tests"; + asd = "cl-mock-tests"; + } + ); + systems = [ "cl-mock-tests" ]; + lispLibs = [ + (getAttr "cl-mock" self) + (getAttr "cl-mock-tests-basic" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mock-tests-basic = ( + build-asdf-system { + pname = "cl-mock-tests-basic"; + version = "20221106-git"; + asds = [ "cl-mock-tests-basic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mock/2022-11-06/cl-mock-20221106-git.tgz"; + sha256 = "19641sm3klx9yfk8lr376rfkd26vy72yp1hkpkqcw3q3m1xrf9xp"; + system = "cl-mock-tests-basic"; + asd = "cl-mock-tests-basic"; + } + ); + systems = [ "cl-mock-tests-basic" ]; + lispLibs = [ + (getAttr "cl-mock-basic" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-modio = ( + build-asdf-system { + pname = "cl-modio"; + version = "20241012-git"; + asds = [ "cl-modio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-modio/2024-10-12/cl-modio-20241012-git.tgz"; + sha256 = "1f755xqpibdrxiqclnsiba36bl8xgw958h0lb0rw6hjsvrx9z8dg"; + system = "cl-modio"; + asd = "cl-modio"; + } + ); + systems = [ "cl-modio" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "com_dot_inuoe_dot_jzon" self) + (getAttr "documentation-utils" self) + (getAttr "drakma" self) + (getAttr "language-codes" self) + (getAttr "zippy" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-monad-macros = ( + build-asdf-system { + pname = "cl-monad-macros"; + version = "20110619-svn"; + asds = [ "cl-monad-macros" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-monad-macros/2011-06-19/cl-monad-macros-20110619-svn.tgz"; + sha256 = "184p018xb07yd04bpscrwrnwv1cdxh9hxggmrnj95lhlr6r97l1z"; + system = "cl-monad-macros"; + asd = "cl-monad-macros"; + } + ); + systems = [ "cl-monad-macros" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-moneris = ( + build-asdf-system { + pname = "cl-moneris"; + version = "20231021-git"; + asds = [ "cl-moneris" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-moneris/2023-10-21/cl-moneris-20231021-git.tgz"; + sha256 = "1ajxqdgqy7cnkq6qz18xayw5z1idz3slzj7nc7pcv4ha7h3ak63k"; + system = "cl-moneris"; + asd = "cl-moneris"; + } + ); + systems = [ "cl-moneris" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "s-xml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-moneris-test = ( + build-asdf-system { + pname = "cl-moneris-test"; + version = "20231021-git"; + asds = [ "cl-moneris-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-moneris/2023-10-21/cl-moneris-20231021-git.tgz"; + sha256 = "1ajxqdgqy7cnkq6qz18xayw5z1idz3slzj7nc7pcv4ha7h3ak63k"; + system = "cl-moneris-test"; + asd = "cl-moneris-test"; + } + ); + systems = [ "cl-moneris-test" ]; + lispLibs = [ + (getAttr "cl-moneris" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mongo = ( + build-asdf-system { + pname = "cl-mongo"; + version = "20160531-git"; + asds = [ "cl-mongo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mongo/2016-05-31/cl-mongo-20160531-git.tgz"; + sha256 = "1l3kydbxbxhs1z76v6qpwjnabv8wf0mff1pfjkrpjfz6bia1svx6"; + system = "cl-mongo"; + asd = "cl-mongo"; + } + ); + systems = [ "cl-mongo" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "documentation-template" self) + (getAttr "lisp-unit" self) + (getAttr "parenscript" self) + (getAttr "split-sequence" self) + (getAttr "usocket" self) + (getAttr "uuid" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mongo-id = ( + build-asdf-system { + pname = "cl-mongo-id"; + version = "20201220-git"; + asds = [ "cl-mongo-id" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mongo-id/2020-12-20/cl-mongo-id-20201220-git.tgz"; + sha256 = "1bpwmh5970rpr6ayygcgdg96hq2dlrksgpa1vdmy5l6vdbw9xrys"; + system = "cl-mongo-id"; + asd = "cl-mongo-id"; + } + ); + systems = [ "cl-mongo-id" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "local-time" self) + (getAttr "md5" self) + (getAttr "secure-random" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-monitors = ( + build-asdf-system { + pname = "cl-monitors"; + version = "20231021-git"; + asds = [ "cl-monitors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-monitors/2023-10-21/cl-monitors-20231021-git.tgz"; + sha256 = "09ddgs7sbqjx91bajpk5qf6716vnx63mfg9yw0biw16mnfjhrg4i"; + system = "cl-monitors"; + asd = "cl-monitors"; + } + ); + systems = [ "cl-monitors" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mop = ( + build-asdf-system { + pname = "cl-mop"; + version = "20150113-git"; + asds = [ "cl-mop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mop/2015-01-13/cl-mop-20150113-git.tgz"; + sha256 = "0wqjbp6jr868a89hklf1ppxkdfbznafrdpriakqiraicvr9kvksg"; + system = "cl-mop"; + asd = "cl-mop"; + } + ); + systems = [ "cl-mop" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-morse = ( + build-asdf-system { + pname = "cl-morse"; + version = "v1.0.0"; + asds = [ "cl-morse" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-morse/2022-07-07/cl-morse-v1.0.0.tgz"; + sha256 = "01sh34nhbsx2dsrb2r1vkd4j8lzm9gjd5jfi8a4cs4m3djjwhh5i"; + system = "cl-morse"; + asd = "cl-morse"; + } + ); + systems = [ "cl-morse" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-moss = ( + build-asdf-system { + pname = "cl-moss"; + version = "20171019-git"; + asds = [ "cl-moss" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-moss/2017-10-19/cl-moss-20171019-git.tgz"; + sha256 = "1qxzppnyxc8lkhfbbp5m3dbhp4rfkyc2lfrry2448i5w5icrigzd"; + system = "cl-moss"; + asd = "cl-moss"; + } + ); + systems = [ "cl-moss" ]; + lispLibs = [ (getAttr "usocket" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mount-info = ( + build-asdf-system { + pname = "cl-mount-info"; + version = "20241012-git"; + asds = [ "cl-mount-info" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mount-info/2024-10-12/cl-mount-info-20241012-git.tgz"; + sha256 = "0i5vpr0s27gqrskl5qkbw23ba00abbmsskgvg2zhpdljg5qiwlcw"; + system = "cl-mount-info"; + asd = "cl-mount-info"; + } + ); + systems = [ "cl-mount-info" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mpg123 = ( + build-asdf-system { + pname = "cl-mpg123"; + version = "20241012-git"; + asds = [ "cl-mpg123" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mpg123/2024-10-12/cl-mpg123-20241012-git.tgz"; + sha256 = "03ysv3psfj4agf62gn1skc26qzd9g9zx6yjxxs9lrjz7g9kwf1xk"; + system = "cl-mpg123"; + asd = "cl-mpg123"; + } + ); + systems = [ "cl-mpg123" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mpg123-example = ( + build-asdf-system { + pname = "cl-mpg123-example"; + version = "20241012-git"; + asds = [ "cl-mpg123-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mpg123/2024-10-12/cl-mpg123-20241012-git.tgz"; + sha256 = "03ysv3psfj4agf62gn1skc26qzd9g9zx6yjxxs9lrjz7g9kwf1xk"; + system = "cl-mpg123-example"; + asd = "cl-mpg123-example"; + } + ); + systems = [ "cl-mpg123-example" ]; + lispLibs = [ + (getAttr "cl-mpg123" self) + (getAttr "cl-out123" self) + (getAttr "verbose" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mpi = ( + build-asdf-system { + pname = "cl-mpi"; + version = "20190710-git"; + asds = [ "cl-mpi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mpi/2019-07-10/cl-mpi-20190710-git.tgz"; + sha256 = "1ykwk7acjhzpsjgm2b5svdpyw2qgrh860gkx3n2ckyrgd9l9q6jb"; + system = "cl-mpi"; + asd = "cl-mpi"; + } + ); + systems = [ "cl-mpi" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-mpi-asdf-integration" self) + (getAttr "static-vectors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mpi-asdf-integration = ( + build-asdf-system { + pname = "cl-mpi-asdf-integration"; + version = "20190710-git"; + asds = [ "cl-mpi-asdf-integration" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mpi/2019-07-10/cl-mpi-20190710-git.tgz"; + sha256 = "1ykwk7acjhzpsjgm2b5svdpyw2qgrh860gkx3n2ckyrgd9l9q6jb"; + system = "cl-mpi-asdf-integration"; + asd = "cl-mpi-asdf-integration"; + } + ); + systems = [ "cl-mpi-asdf-integration" ]; + lispLibs = [ + (getAttr "cffi-grovel" self) + (getAttr "cffi-toolchain" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mpi-examples = ( + build-asdf-system { + pname = "cl-mpi-examples"; + version = "20190710-git"; + asds = [ "cl-mpi-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mpi/2019-07-10/cl-mpi-20190710-git.tgz"; + sha256 = "1ykwk7acjhzpsjgm2b5svdpyw2qgrh860gkx3n2ckyrgd9l9q6jb"; + system = "cl-mpi-examples"; + asd = "cl-mpi-examples"; + } + ); + systems = [ "cl-mpi-examples" ]; + lispLibs = [ + (getAttr "cl-mpi" self) + (getAttr "cl-mpi-asdf-integration" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mpi-extensions = ( + build-asdf-system { + pname = "cl-mpi-extensions"; + version = "20190710-git"; + asds = [ "cl-mpi-extensions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mpi/2019-07-10/cl-mpi-20190710-git.tgz"; + sha256 = "1ykwk7acjhzpsjgm2b5svdpyw2qgrh860gkx3n2ckyrgd9l9q6jb"; + system = "cl-mpi-extensions"; + asd = "cl-mpi-extensions"; + } + ); + systems = [ "cl-mpi-extensions" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-conspack" self) + (getAttr "cl-mpi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mpi-test-suite = ( + build-asdf-system { + pname = "cl-mpi-test-suite"; + version = "20190710-git"; + asds = [ "cl-mpi-test-suite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mpi/2019-07-10/cl-mpi-20190710-git.tgz"; + sha256 = "1ykwk7acjhzpsjgm2b5svdpyw2qgrh860gkx3n2ckyrgd9l9q6jb"; + system = "cl-mpi-test-suite"; + asd = "cl-mpi-test-suite"; + } + ); + systems = [ "cl-mpi-test-suite" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-mpi" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mtgnet = ( + build-asdf-system { + pname = "cl-mtgnet"; + version = "20180711-git"; + asds = [ "cl-mtgnet" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mtgnet/2018-07-11/cl-mtgnet-20180711-git.tgz"; + sha256 = "08mwkfa9s51is6npn7al4rn5a65ip2bq0psb1pdvh111h5zqxdrb"; + system = "cl-mtgnet"; + asd = "cl-mtgnet"; + } + ); + systems = [ "cl-mtgnet" ]; + lispLibs = [ + (getAttr "blackbird" self) + (getAttr "cl-json" self) + (getAttr "cl-netstring_plus" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mtgnet-async = ( + build-asdf-system { + pname = "cl-mtgnet-async"; + version = "20180711-git"; + asds = [ "cl-mtgnet-async" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mtgnet/2018-07-11/cl-mtgnet-20180711-git.tgz"; + sha256 = "08mwkfa9s51is6npn7al4rn5a65ip2bq0psb1pdvh111h5zqxdrb"; + system = "cl-mtgnet-async"; + asd = "cl-mtgnet-async"; + } + ); + systems = [ "cl-mtgnet-async" ]; + lispLibs = [ + (getAttr "cl-async" self) + (getAttr "cl-mtgnet" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mtgnet-sync = ( + build-asdf-system { + pname = "cl-mtgnet-sync"; + version = "20180711-git"; + asds = [ "cl-mtgnet-sync" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mtgnet/2018-07-11/cl-mtgnet-20180711-git.tgz"; + sha256 = "08mwkfa9s51is6npn7al4rn5a65ip2bq0psb1pdvh111h5zqxdrb"; + system = "cl-mtgnet-sync"; + asd = "cl-mtgnet-sync"; + } + ); + systems = [ "cl-mtgnet-sync" ]; + lispLibs = [ + (getAttr "cl-mtgnet" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-murmurhash = ( + build-asdf-system { + pname = "cl-murmurhash"; + version = "20210630-git"; + asds = [ "cl-murmurhash" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-murmurhash/2021-06-30/cl-murmurhash-20210630-git.tgz"; + sha256 = "0251r0mpjm0y3qsm4lm7ncvrkxvgwc53spdm1p2mpayhvkkqqsws"; + system = "cl-murmurhash"; + asd = "cl-murmurhash"; + } + ); + systems = [ "cl-murmurhash" ]; + lispLibs = [ (getAttr "babel" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mustache = ( + build-asdf-system { + pname = "cl-mustache"; + version = "20241012-git"; + asds = [ "cl-mustache" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mustache/2024-10-12/cl-mustache-20241012-git.tgz"; + sha256 = "0isdrz1dgjvmfqvsgs2pmrran41w9n6f44r9fpdhdkjxa5zvy46b"; + system = "cl-mustache"; + asd = "cl-mustache"; + } + ); + systems = [ "cl-mustache" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-mustache-test = ( + build-asdf-system { + pname = "cl-mustache-test"; + version = "20241012-git"; + asds = [ "cl-mustache-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mustache/2024-10-12/cl-mustache-20241012-git.tgz"; + sha256 = "0isdrz1dgjvmfqvsgs2pmrran41w9n6f44r9fpdhdkjxa5zvy46b"; + system = "cl-mustache-test"; + asd = "cl-mustache-test"; + } + ); + systems = [ "cl-mustache-test" ]; + lispLibs = [ + (getAttr "cl-mustache" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-muth = ( + build-asdf-system { + pname = "cl-muth"; + version = "stable-git"; + asds = [ "cl-muth" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-muth/2022-07-07/cl-muth-stable-git.tgz"; + sha256 = "0409arzy51chgi9anj9s2zn0qkx9wnphlbwcdvpamr4b51b60xjz"; + system = "cl-muth"; + asd = "cl-muth"; + } + ); + systems = [ "cl-muth" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bodge-heap" self) + (getAttr "bodge-queue" self) + (getAttr "bordeaux-threads" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mw = ( + build-asdf-system { + pname = "cl-mw"; + version = "20150407-git"; + asds = [ "cl-mw" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; + sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; + system = "cl-mw"; + asd = "cl-mw"; + } + ); + systems = [ "cl-mw" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + (getAttr "hu_dot_dwim_dot_serializer" self) + (getAttr "iolib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mw_dot_examples_dot_argument-processing = ( + build-asdf-system { + pname = "cl-mw.examples.argument-processing"; + version = "20150407-git"; + asds = [ "cl-mw.examples.argument-processing" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; + sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; + system = "cl-mw.examples.argument-processing"; + asd = "cl-mw.examples.argument-processing"; + } + ); + systems = [ "cl-mw.examples.argument-processing" ]; + lispLibs = [ (getAttr "cl-mw" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mw_dot_examples_dot_hello-world = ( + build-asdf-system { + pname = "cl-mw.examples.hello-world"; + version = "20150407-git"; + asds = [ "cl-mw.examples.hello-world" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; + sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; + system = "cl-mw.examples.hello-world"; + asd = "cl-mw.examples.hello-world"; + } + ); + systems = [ "cl-mw.examples.hello-world" ]; + lispLibs = [ (getAttr "cl-mw" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mw_dot_examples_dot_higher-order = ( + build-asdf-system { + pname = "cl-mw.examples.higher-order"; + version = "20150407-git"; + asds = [ "cl-mw.examples.higher-order" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; + sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; + system = "cl-mw.examples.higher-order"; + asd = "cl-mw.examples.higher-order"; + } + ); + systems = [ "cl-mw.examples.higher-order" ]; + lispLibs = [ (getAttr "cl-mw" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mw_dot_examples_dot_monte-carlo-pi = ( + build-asdf-system { + pname = "cl-mw.examples.monte-carlo-pi"; + version = "20150407-git"; + asds = [ "cl-mw.examples.monte-carlo-pi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; + sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; + system = "cl-mw.examples.monte-carlo-pi"; + asd = "cl-mw.examples.monte-carlo-pi"; + } + ); + systems = [ "cl-mw.examples.monte-carlo-pi" ]; + lispLibs = [ (getAttr "cl-mw" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mw_dot_examples_dot_ping = ( + build-asdf-system { + pname = "cl-mw.examples.ping"; + version = "20150407-git"; + asds = [ "cl-mw.examples.ping" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; + sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; + system = "cl-mw.examples.ping"; + asd = "cl-mw.examples.ping"; + } + ); + systems = [ "cl-mw.examples.ping" ]; + lispLibs = [ (getAttr "cl-mw" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mw_dot_examples_dot_with-task-policy = ( + build-asdf-system { + pname = "cl-mw.examples.with-task-policy"; + version = "20150407-git"; + asds = [ "cl-mw.examples.with-task-policy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mw/2015-04-07/cl-mw-20150407-git.tgz"; + sha256 = "1bpkpb86hpp7sz9mk19rbdlfcis2npc3a7w6jlph7s8brxl1h1jn"; + system = "cl-mw.examples.with-task-policy"; + asd = "cl-mw.examples.with-task-policy"; + } + ); + systems = [ "cl-mw.examples.with-task-policy" ]; + lispLibs = [ (getAttr "cl-mw" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-myriam = ( + build-asdf-system { + pname = "cl-myriam"; + version = "20220331-git"; + asds = [ "cl-myriam" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-myriam/2022-03-31/cl-myriam-20220331-git.tgz"; + sha256 = "0vyyyy6yj62id5m1a98rbq3pz7hm74znnawxh4apqhrff37xcs1l"; + system = "cl-myriam"; + asd = "cl-myriam"; + } + ); + systems = [ "cl-myriam" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-conspack" self) + (getAttr "cl-ppcre" self) + (getAttr "lparallel" self) + (getAttr "pzmq" self) + (getAttr "serapeum" self) + (getAttr "sha3" self) + (getAttr "str" self) + (getAttr "usocket" self) + (getAttr "uuid" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-mysql = ( + build-asdf-system { + pname = "cl-mysql"; + version = "20241012-git"; + asds = [ "cl-mysql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mysql/2024-10-12/cl-mysql-20241012-git.tgz"; + sha256 = "0ibxfjnvcgpibsfqjx2d3dcjcabiw6dj43vmr76b55fc4qlkjvz5"; + system = "cl-mysql"; + asd = "cl-mysql"; + } + ); + systems = [ "cl-mysql" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { }; + } + ); + cl-mysql-test = ( + build-asdf-system { + pname = "cl-mysql-test"; + version = "20241012-git"; + asds = [ "cl-mysql-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mysql/2024-10-12/cl-mysql-20241012-git.tgz"; + sha256 = "0ibxfjnvcgpibsfqjx2d3dcjcabiw6dj43vmr76b55fc4qlkjvz5"; + system = "cl-mysql-test"; + asd = "cl-mysql-test"; + } + ); + systems = [ "cl-mysql-test" ]; + lispLibs = [ + (getAttr "cl-mysql" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-naive-deprecation = ( + build-asdf-system { + pname = "cl-naive-deprecation"; + version = "20241012-git"; + asds = [ "cl-naive-deprecation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-naive-deprecation/2024-10-12/cl-naive-deprecation-20241012-git.tgz"; + sha256 = "17x6b5sr34qjfzbn2r6f5n4xa4p1qi438k792b48qiqnalkfp29m"; + system = "cl-naive-deprecation"; + asd = "cl-naive-deprecation"; + } + ); + systems = [ "cl-naive-deprecation" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-naive-ptrees = ( + build-asdf-system { + pname = "cl-naive-ptrees"; + version = "20241012-git"; + asds = [ "cl-naive-ptrees" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-naive-ptrees/2024-10-12/cl-naive-ptrees-20241012-git.tgz"; + sha256 = "10548wm3mpjxmjibidv1dd8wzcn3nn12pzwlpdd1li362v8l9n6y"; + system = "cl-naive-ptrees"; + asd = "cl-naive-ptrees"; + } + ); + systems = [ "cl-naive-ptrees" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-naive-ptrees_dot_tests = ( + build-asdf-system { + pname = "cl-naive-ptrees.tests"; + version = "20241012-git"; + asds = [ "cl-naive-ptrees.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-naive-ptrees/2024-10-12/cl-naive-ptrees-20241012-git.tgz"; + sha256 = "10548wm3mpjxmjibidv1dd8wzcn3nn12pzwlpdd1li362v8l9n6y"; + system = "cl-naive-ptrees.tests"; + asd = "cl-naive-ptrees.tests"; + } + ); + systems = [ "cl-naive-ptrees.tests" ]; + lispLibs = [ + (getAttr "cl-naive-ptrees" self) + (getAttr "cl-naive-tests" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-naive-tests = ( + build-asdf-system { + pname = "cl-naive-tests"; + version = "20241012-git"; + asds = [ "cl-naive-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-naive-tests/2024-10-12/cl-naive-tests-20241012-git.tgz"; + sha256 = "1b7vvl5myybx92k778p3ca5367g4m6rh5k3rpr6qp9p4amd0yy2f"; + system = "cl-naive-tests"; + asd = "cl-naive-tests"; + } + ); + systems = [ "cl-naive-tests" ]; + lispLibs = [ (getAttr "cl-who" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-naive-tests_dot_tests = ( + build-asdf-system { + pname = "cl-naive-tests.tests"; + version = "20241012-git"; + asds = [ "cl-naive-tests.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-naive-tests/2024-10-12/cl-naive-tests-20241012-git.tgz"; + sha256 = "1b7vvl5myybx92k778p3ca5367g4m6rh5k3rpr6qp9p4amd0yy2f"; + system = "cl-naive-tests.tests"; + asd = "cl-naive-tests.tests"; + } + ); + systems = [ "cl-naive-tests.tests" ]; + lispLibs = [ (getAttr "cl-naive-tests" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ncurses = ( + build-asdf-system { + pname = "cl-ncurses"; + version = "0.1.4"; + asds = [ "cl-ncurses" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ncurses/2010-10-06/cl-ncurses_0.1.4.tgz"; + sha256 = "1frcap93i4ni3d648rrbnjjpz7p4cxlv57mmzlpxpzchzbcga026"; + system = "cl-ncurses"; + asd = "cl-ncurses"; + } + ); + systems = [ "cl-ncurses" ]; + lispLibs = [ (getAttr "uffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-neo4j = ( + build-asdf-system { + pname = "cl-neo4j"; + version = "release-b8ad637a-git"; + asds = [ "cl-neo4j" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-neo4j/2013-01-28/cl-neo4j-release-b8ad637a-git.tgz"; + sha256 = "061xqjn08aqynfqygk48pwjp1d1mnhcb6fnl4lcfyw261dxsp871"; + system = "cl-neo4j"; + asd = "cl-neo4j"; + } + ); + systems = [ "cl-neo4j" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "babel" self) + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-neo4j_dot_tests = ( + build-asdf-system { + pname = "cl-neo4j.tests"; + version = "release-b8ad637a-git"; + asds = [ "cl-neo4j.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-neo4j/2013-01-28/cl-neo4j-release-b8ad637a-git.tgz"; + sha256 = "061xqjn08aqynfqygk48pwjp1d1mnhcb6fnl4lcfyw261dxsp871"; + system = "cl-neo4j.tests"; + asd = "cl-neo4j"; + } + ); + systems = [ "cl-neo4j.tests" ]; + lispLibs = [ + (getAttr "cl-neo4j" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-neovim = ( + build-asdf-system { + pname = "cl-neovim"; + version = "20241012-git"; + asds = [ "cl-neovim" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-neovim/2024-10-12/cl-neovim-20241012-git.tgz"; + sha256 = "1c72qy10kmccpfl90q4c0yinmy9z9mdqniqx24269h91xd3jyagc"; + system = "cl-neovim"; + asd = "cl-neovim"; + } + ); + systems = [ "cl-neovim" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-messagepack-rpc" self) + (getAttr "form-fiddle" self) + (getAttr "split-sequence" self) + (getAttr "vom" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-netpbm = ( + build-asdf-system { + pname = "cl-netpbm"; + version = "20241012-hg"; + asds = [ "cl-netpbm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-netpbm/2024-10-12/cl-netpbm-20241012-hg.tgz"; + sha256 = "16dv3d6x62vvc9wdvm2dc9mrm29ypzjzn2fvy46kl0h0wg7hjz92"; + system = "cl-netpbm"; + asd = "cl-netpbm"; + } + ); + systems = [ "cl-netpbm" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-netstring_plus = ( + build-asdf-system { + pname = "cl-netstring+"; + version = "20150709-git"; + asds = [ "cl-netstring+" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-netstring-plus/2015-07-09/cl-netstring-plus-20150709-git.tgz"; + sha256 = "03nxhgkab8lsx8mvavd4yny1894yxl5bllvqb12hyjdgg1v8whrr"; + system = "cl-netstring+"; + asd = "cl-netstring+"; + } + ); + systems = [ "cl-netstring+" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-netstrings = ( + build-asdf-system { + pname = "cl-netstrings"; + version = "20121013-git"; + asds = [ "cl-netstrings" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-netstrings/2012-10-13/cl-netstrings-20121013-git.tgz"; + sha256 = "1mprrb8i3fjpmw7w461ib8zrcjwx77sqwaxyqq7i8yqkbhk7p1ql"; + system = "cl-netstrings"; + asd = "cl-netstrings"; + } + ); + systems = [ "cl-netstrings" ]; + lispLibs = [ + (getAttr "arnesi" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-notebook = ( + build-asdf-system { + pname = "cl-notebook"; + version = "20201220-git"; + asds = [ "cl-notebook" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-notebook/2020-12-20/cl-notebook-20201220-git.tgz"; + sha256 = "0kg5wdclz9i64gcx27z5bs739hsvjrfl9kf1awi31x4142yxrva8"; + system = "cl-notebook"; + asd = "cl-notebook"; + } + ); + systems = [ "cl-notebook" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cl-css" self) + (getAttr "cl-fad" self) + (getAttr "cl-who" self) + (getAttr "closer-mop" self) + (getAttr "fact-base" self) + (getAttr "house" self) + (getAttr "parenscript" self) + (getAttr "prove-asdf" self) + (getAttr "qlot" self) + (getAttr "quri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ntp-client = ( + build-asdf-system { + pname = "cl-ntp-client"; + version = "20210630-git"; + asds = [ "cl-ntp-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ntp-client/2021-06-30/cl-ntp-client-20210630-git.tgz"; + sha256 = "1mc16bvs0l8srnxjcjg4m192rw5waq291zks2jslxmxij0pa28cm"; + system = "cl-ntp-client"; + asd = "cl-ntp-client"; + } + ); + systems = [ "cl-ntp-client" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ntriples = ( + build-asdf-system { + pname = "cl-ntriples"; + version = "20190307-hg"; + asds = [ "cl-ntriples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ntriples/2019-03-07/cl-ntriples-20190307-hg.tgz"; + sha256 = "0k8q2r2nxkgxp91398gb0iwfy9kd2mn519nxxa3zq831c433l2mq"; + system = "cl-ntriples"; + asd = "cl-ntriples"; + } + ); + systems = [ "cl-ntriples" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-oauth = ( + build-asdf-system { + pname = "cl-oauth"; + version = "20150804-git"; + asds = [ "cl-oauth" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-oauth/2015-08-04/cl-oauth-20150804-git.tgz"; + sha256 = "1q4r5i3099684q5x9wqddrm9g88qm16nnra9glvxngywfjc5zzkk"; + system = "cl-oauth"; + asd = "cl-oauth"; + } + ); + systems = [ "cl-oauth" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "babel" self) + (getAttr "cl-base64" self) + (getAttr "closer-mop" self) + (getAttr "drakma" self) + (getAttr "f-underscore" self) + (getAttr "hunchentoot" self) + (getAttr "ironclad" self) + (getAttr "puri" self) + (getAttr "split-sequence" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-oauth_dot_tests = ( + build-asdf-system { + pname = "cl-oauth.tests"; + version = "20150804-git"; + asds = [ "cl-oauth.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-oauth/2015-08-04/cl-oauth-20150804-git.tgz"; + sha256 = "1q4r5i3099684q5x9wqddrm9g88qm16nnra9glvxngywfjc5zzkk"; + system = "cl-oauth.tests"; + asd = "cl-oauth"; + } + ); + systems = [ "cl-oauth.tests" ]; + lispLibs = [ + (getAttr "cl-oauth" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-oclapi = ( + build-asdf-system { + pname = "cl-oclapi"; + version = "20180831-git"; + asds = [ "cl-oclapi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-oclapi/2018-08-31/cl-oclapi-20180831-git.tgz"; + sha256 = "0aix5ipw98fsnvg1w7qmrjbwgn70gn7vf5av21xsgblp2sd7w2aw"; + system = "cl-oclapi"; + asd = "cl-oclapi"; + } + ); + systems = [ "cl-oclapi" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-annot" self) + (getAttr "cl-reexport" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-oclapi-test = ( + build-asdf-system { + pname = "cl-oclapi-test"; + version = "20180831-git"; + asds = [ "cl-oclapi-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-oclapi/2018-08-31/cl-oclapi-20180831-git.tgz"; + sha256 = "0aix5ipw98fsnvg1w7qmrjbwgn70gn7vf5av21xsgblp2sd7w2aw"; + system = "cl-oclapi-test"; + asd = "cl-oclapi-test"; + } + ); + systems = [ "cl-oclapi-test" ]; + lispLibs = [ + (getAttr "cl-annot" self) + (getAttr "cl-oclapi" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-octet-streams = ( + build-asdf-system { + pname = "cl-octet-streams"; + version = "20201220-git"; + asds = [ "cl-octet-streams" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-octet-streams/2020-12-20/cl-octet-streams-20201220-git.tgz"; + sha256 = "1hffh98bv4w5yrchagzwqrc43d2p473pvw7ka4kyyvhrr52dk2f8"; + system = "cl-octet-streams"; + asd = "cl-octet-streams"; + } + ); + systems = [ "cl-octet-streams" ]; + lispLibs = [ (getAttr "trivial-gray-streams" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ode = ( + build-asdf-system { + pname = "cl-ode"; + version = "20160628-git"; + asds = [ "cl-ode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ode/2016-06-28/cl-ode-20160628-git.tgz"; + sha256 = "1pxm2pq0br0rhdfnvs5jqfkxfs8bc9wdqrzwyv83l8n7pax941b0"; + system = "cl-ode"; + asd = "cl-ode"; + } + ); + systems = [ "cl-ode" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ohm = ( + build-asdf-system { + pname = "cl-ohm"; + version = "20180228-git"; + asds = [ "cl-ohm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ohm/2018-02-28/cl-ohm-20180228-git.tgz"; + sha256 = "00gdfsiba761gk7xw91wfnr9yv84maagf9idh55bk5bs4ws1ymyp"; + system = "cl-ohm"; + asd = "cl-ohm"; + } + ); + systems = [ "cl-ohm" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-redis" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-oju = ( + build-asdf-system { + pname = "cl-oju"; + version = "20241012-git"; + asds = [ "cl-oju" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-oju/2024-10-12/cl-oju-20241012-git.tgz"; + sha256 = "0gwzxl4pj45jq7vx6vssgzsp4xxc99bzfi6fbklc5nnlfkqq0v62"; + system = "cl-oju"; + asd = "cl-oju"; + } + ); + systems = [ "cl-oju" ]; + lispLibs = [ (getAttr "_1am" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-olefs = ( + build-asdf-system { + pname = "cl-olefs"; + version = "20150709-git"; + asds = [ "cl-olefs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-olefs/2015-07-09/cl-olefs-20150709-git.tgz"; + sha256 = "0cqna6zzfrjmsq17yc4wg204kr77riczqjpm1w5cj1mba43zcac7"; + system = "cl-olefs"; + asd = "cl-olefs"; + } + ); + systems = [ "cl-olefs" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-one-time-passwords = ( + build-asdf-system { + pname = "cl-one-time-passwords"; + version = "20171019-git"; + asds = [ "cl-one-time-passwords" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-one-time-passwords/2017-10-19/cl-one-time-passwords-20171019-git.tgz"; + sha256 = "1nhq2jij257cfaadh9k421qaisicxpmx3wsc4kivf1psgbrc56lg"; + system = "cl-one-time-passwords"; + asd = "cl-one-time-passwords"; + } + ); + systems = [ "cl-one-time-passwords" ]; + lispLibs = [ (getAttr "ironclad" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-one-time-passwords-test = ( + build-asdf-system { + pname = "cl-one-time-passwords-test"; + version = "20171019-git"; + asds = [ "cl-one-time-passwords-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-one-time-passwords/2017-10-19/cl-one-time-passwords-20171019-git.tgz"; + sha256 = "1nhq2jij257cfaadh9k421qaisicxpmx3wsc4kivf1psgbrc56lg"; + system = "cl-one-time-passwords-test"; + asd = "cl-one-time-passwords-test"; + } + ); + systems = [ "cl-one-time-passwords-test" ]; + lispLibs = [ + (getAttr "cl-one-time-passwords" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-oneliner = ( + build-asdf-system { + pname = "cl-oneliner"; + version = "20131003-git"; + asds = [ "cl-oneliner" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/oneliner/2013-10-03/oneliner-20131003-git.tgz"; + sha256 = "0q9350s0r9yjmfc2360g35qi04b3867gd7hw5ada4176whinmjxb"; + system = "cl-oneliner"; + asd = "cl-oneliner"; + } + ); + systems = [ "cl-oneliner" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "lisp-unit" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-online-learning = ( + build-asdf-system { + pname = "cl-online-learning"; + version = "20220331-git"; + asds = [ "cl-online-learning" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-online-learning/2022-03-31/cl-online-learning-20220331-git.tgz"; + sha256 = "136v9kxcy53qar2j4y38awnw2idnf0lwxqwx7wgak664w3hxs6k8"; + system = "cl-online-learning"; + asd = "cl-online-learning"; + } + ); + systems = [ "cl-online-learning" ]; + lispLibs = [ + (getAttr "cl-libsvm-format" self) + (getAttr "cl-store" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-online-learning-test = ( + build-asdf-system { + pname = "cl-online-learning-test"; + version = "20220331-git"; + asds = [ "cl-online-learning-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-online-learning/2022-03-31/cl-online-learning-20220331-git.tgz"; + sha256 = "136v9kxcy53qar2j4y38awnw2idnf0lwxqwx7wgak664w3hxs6k8"; + system = "cl-online-learning-test"; + asd = "cl-online-learning-test"; + } + ); + systems = [ "cl-online-learning-test" ]; + lispLibs = [ + (getAttr "cl-online-learning" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-openal = ( + build-asdf-system { + pname = "cl-openal"; + version = "20221106-git"; + asds = [ "cl-openal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-openal/2022-11-06/cl-openal-20221106-git.tgz"; + sha256 = "0jmp81mf23ckcm4knnh0q7zpmyls5220imaqbmnl0xvvra10b1zy"; + system = "cl-openal"; + asd = "cl-openal"; + } + ); + systems = [ "cl-openal" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-openal-examples = ( + build-asdf-system { + pname = "cl-openal-examples"; + version = "20221106-git"; + asds = [ "cl-openal-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-openal/2022-11-06/cl-openal-20221106-git.tgz"; + sha256 = "0jmp81mf23ckcm4knnh0q7zpmyls5220imaqbmnl0xvvra10b1zy"; + system = "cl-openal-examples"; + asd = "cl-openal-examples"; + } + ); + systems = [ "cl-openal-examples" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-alc" self) + (getAttr "cl-alut" self) + (getAttr "cl-openal" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-opencl = ( + build-asdf-system { + pname = "cl-opencl"; + version = "20211209-git"; + asds = [ "cl-opencl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opencl/2021-12-09/cl-opencl-20211209-git.tgz"; + sha256 = "1agg6rg7lsbq2jgarx25bwm1nw22jpl20bzhyn4ivygcgzp2mv29"; + system = "cl-opencl"; + asd = "cl-opencl"; + } + ); + systems = [ "cl-opencl" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-opencl-utils = ( + build-asdf-system { + pname = "cl-opencl-utils"; + version = "20230214-git"; + asds = [ "cl-opencl-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opencl-utils/2023-02-14/cl-opencl-utils-20230214-git.tgz"; + sha256 = "17l4wsvhjj3zvhl5nsigh9fwnv7s7xiqfk2998gh86j32a02r95y"; + system = "cl-opencl-utils"; + asd = "cl-opencl-utils"; + } + ); + systems = [ "cl-opencl-utils" ]; + lispLibs = [ (getAttr "cl-opencl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-opengl = ( + build-asdf-system { + pname = "cl-opengl"; + version = "20241012-git"; + asds = [ "cl-opengl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opengl/2024-10-12/cl-opengl-20241012-git.tgz"; + sha256 = "1xpa3x9fx7wxrs5xmkj13yzh2wjfnlb0ihirfr9clngpv1y4gcm6"; + system = "cl-opengl"; + asd = "cl-opengl"; + } + ); + systems = [ "cl-opengl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "float-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-opensearch-query-builder = ( + build-asdf-system { + pname = "cl-opensearch-query-builder"; + version = "20241012-git"; + asds = [ "cl-opensearch-query-builder" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opensearch-query-builder/2024-10-12/cl-opensearch-query-builder-20241012-git.tgz"; + sha256 = "1pxlafahhgwyfhila0ikbpljcxgi59cqd2m6dvlib6ii90yq5dqx"; + system = "cl-opensearch-query-builder"; + asd = "cl-opensearch-query-builder"; + } + ); + systems = [ "cl-opensearch-query-builder" ]; + lispLibs = [ (getAttr "com_dot_inuoe_dot_jzon" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-openstack-client = ( + build-asdf-system { + pname = "cl-openstack-client"; + version = "20191007-git"; + asds = [ "cl-openstack-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-openstack-client/2019-10-07/cl-openstack-client-20191007-git.tgz"; + sha256 = "1sak75i82vn3acg7bxx8vjbw2y35wbq1vkh1yqhs68ksnph6d097"; + system = "cl-openstack-client"; + asd = "cl-openstack-client"; + } + ); + systems = [ "cl-openstack-client" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-json" self) + (getAttr "drakma" self) + (getAttr "local-time" self) + (getAttr "uri-template" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-openstack-client-test = ( + build-asdf-system { + pname = "cl-openstack-client-test"; + version = "20191007-git"; + asds = [ "cl-openstack-client-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-openstack-client/2019-10-07/cl-openstack-client-20191007-git.tgz"; + sha256 = "1sak75i82vn3acg7bxx8vjbw2y35wbq1vkh1yqhs68ksnph6d097"; + system = "cl-openstack-client-test"; + asd = "cl-openstack-client-test"; + } + ); + systems = [ "cl-openstack-client-test" ]; + lispLibs = [ + (getAttr "chunga" self) + (getAttr "cl-openstack-client" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "fiveam" self) + (getAttr "flexi-streams" self) + (getAttr "local-time" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-opsresearch = ( + build-asdf-system { + pname = "cl-opsresearch"; + version = "20170403-git"; + asds = [ "cl-opsresearch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opsresearch/2017-04-03/cl-opsresearch-20170403-git.tgz"; + sha256 = "1fipw6qjggswzcg8ifwx5qnhnc7mmi53s6h14l0vzj6afa5rdpm7"; + system = "cl-opsresearch"; + asd = "cl-opsresearch"; + } + ); + systems = [ "cl-opsresearch" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-opus = ( + build-asdf-system { + pname = "cl-opus"; + version = "20241012-git"; + asds = [ "cl-opus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opus/2024-10-12/cl-opus-20241012-git.tgz"; + sha256 = "183xjlqjwildm1fb8piiic1f6l9fx4mxf9gcagpav8r60d1wmbpm"; + system = "cl-opus"; + asd = "cl-opus"; + } + ); + systems = [ "cl-opus" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "static-vectors" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-org-mode = ( + build-asdf-system { + pname = "cl-org-mode"; + version = "20101207-git"; + asds = [ "cl-org-mode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-org-mode/2010-12-07/cl-org-mode-20101207-git.tgz"; + sha256 = "1fvwl9jlbpd352b5zn2d45mabsim5xvzabwyz1h10hwv4gviymzf"; + system = "cl-org-mode"; + asd = "cl-org-mode"; + } + ); + systems = [ "cl-org-mode" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-out123 = ( + build-asdf-system { + pname = "cl-out123"; + version = "20231021-git"; + asds = [ "cl-out123" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-out123/2023-10-21/cl-out123-20231021-git.tgz"; + sha256 = "1h48hfd956799wx9kmkmb9azg01jmjbnj16b6z9ciw9y9k5jlzsh"; + system = "cl-out123"; + asd = "cl-out123"; + } + ); + systems = [ "cl-out123" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-pack = ( + build-asdf-system { + pname = "cl-pack"; + version = "20200427-git"; + asds = [ "cl-pack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pack/2020-04-27/cl-pack-20200427-git.tgz"; + sha256 = "0q7gawy0cwy49m1mxgj0jqnzzckk2ps74ncfaw1pqiqilfyx7np6"; + system = "cl-pack"; + asd = "cl-pack"; + } + ); + systems = [ "cl-pack" ]; + lispLibs = [ (getAttr "ieee-floats" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-pack-test = ( + build-asdf-system { + pname = "cl-pack-test"; + version = "20200427-git"; + asds = [ "cl-pack-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pack/2020-04-27/cl-pack-20200427-git.tgz"; + sha256 = "0q7gawy0cwy49m1mxgj0jqnzzckk2ps74ncfaw1pqiqilfyx7np6"; + system = "cl-pack-test"; + asd = "cl-pack"; + } + ); + systems = [ "cl-pack-test" ]; + lispLibs = [ (getAttr "cl-pack" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-package-locks = ( + build-asdf-system { + pname = "cl-package-locks"; + version = "20111203-git"; + asds = [ "cl-package-locks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-package-locks/2011-12-03/cl-package-locks-20111203-git.tgz"; + sha256 = "0g3gfljnvpgd66ccd2sqawlkwqx4a0wsdrg5180va61w869cgxqq"; + system = "cl-package-locks"; + asd = "cl-package-locks"; + } + ); + systems = [ "cl-package-locks" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-pango = ( + build-asdf-system { + pname = "cl-pango"; + version = "20170403-git"; + asds = [ "cl-pango" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pango/2017-04-03/cl-pango-20170403-git.tgz"; + sha256 = "0zkn4yn8nkkjr0x1vcy856cvbmnyhdidqz0in8xvd2i93jvw5w0i"; + system = "cl-pango"; + asd = "cl-pango"; + } + ); + systems = [ "cl-pango" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-cairo2" self) + (getAttr "xmls" self) + ]; + meta = { }; + } + ); + cl-parallel = ( + build-asdf-system { + pname = "cl-parallel"; + version = "20130312-git"; + asds = [ "cl-parallel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-parallel/2013-03-12/cl-parallel-20130312-git.tgz"; + sha256 = "1hmkcbwkj7rx8zg5wf2w06nvbabldpr7hbbg1ycj0fss86s2cx2c"; + system = "cl-parallel"; + asd = "cl-parallel"; + } + ); + systems = [ "cl-parallel" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-pass = ( + build-asdf-system { + pname = "cl-pass"; + version = "20201220-git"; + asds = [ "cl-pass" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pass/2020-12-20/cl-pass-20201220-git.tgz"; + sha256 = "05qx4jrkxqbqi72cxgswbpnifbdvp9mh7apc7566v522899bh0hb"; + system = "cl-pass"; + asd = "cl-pass"; + } + ); + systems = [ "cl-pass" ]; + lispLibs = [ + (getAttr "ironclad" self) + (getAttr "split-sequence" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-pass-test = ( + build-asdf-system { + pname = "cl-pass-test"; + version = "20201220-git"; + asds = [ "cl-pass-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pass/2020-12-20/cl-pass-20201220-git.tgz"; + sha256 = "05qx4jrkxqbqi72cxgswbpnifbdvp9mh7apc7566v522899bh0hb"; + system = "cl-pass-test"; + asd = "cl-pass-test"; + } + ); + systems = [ "cl-pass-test" ]; + lispLibs = [ + (getAttr "cl-pass" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-paths = ( + build-asdf-system { + pname = "cl-paths"; + version = "20241012-git"; + asds = [ "cl-paths" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-vectors/2024-10-12/cl-vectors-20241012-git.tgz"; + sha256 = "1nkmmn38y6af10ysff3g2qkf5lb2601dcjp5rffsjh6bv2ik2jd5"; + system = "cl-paths"; + asd = "cl-paths"; + } + ); + systems = [ "cl-paths" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-paths-ttf = ( + build-asdf-system { + pname = "cl-paths-ttf"; + version = "20241012-git"; + asds = [ "cl-paths-ttf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-vectors/2024-10-12/cl-vectors-20241012-git.tgz"; + sha256 = "1nkmmn38y6af10ysff3g2qkf5lb2601dcjp5rffsjh6bv2ik2jd5"; + system = "cl-paths-ttf"; + asd = "cl-paths-ttf"; + } + ); + systems = [ "cl-paths-ttf" ]; + lispLibs = [ + (getAttr "cl-paths" self) + (getAttr "zpb-ttf" self) + ]; + meta = { }; + } + ); + cl-pattern = ( + build-asdf-system { + pname = "cl-pattern"; + version = "20140713-git"; + asds = [ "cl-pattern" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pattern/2014-07-13/cl-pattern-20140713-git.tgz"; + sha256 = "0kc1yynn1ysa7bcaazhi1pq8l3hj3jq6p835kh5di7g1imrfkrny"; + system = "cl-pattern"; + asd = "cl-pattern"; + } + ); + systems = [ "cl-pattern" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-annot" self) + (getAttr "cl-syntax" self) + (getAttr "cl-syntax-annot" self) + ]; + meta = { }; + } + ); + cl-pattern-benchmark = ( + build-asdf-system { + pname = "cl-pattern-benchmark"; + version = "20140713-git"; + asds = [ "cl-pattern-benchmark" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pattern/2014-07-13/cl-pattern-20140713-git.tgz"; + sha256 = "0kc1yynn1ysa7bcaazhi1pq8l3hj3jq6p835kh5di7g1imrfkrny"; + system = "cl-pattern-benchmark"; + asd = "cl-pattern-benchmark"; + } + ); + systems = [ "cl-pattern-benchmark" ]; + lispLibs = [ (getAttr "cl-pattern" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-patterns = ( + build-asdf-system { + pname = "cl-patterns"; + version = "20241012-git"; + asds = [ "cl-patterns" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-patterns/2024-10-12/cl-patterns-20241012-git.tgz"; + sha256 = "0g0q514fn1hxq518358yy2va4cb9xxqwds9cglw133qxy0wsjllh"; + system = "cl-patterns"; + asd = "cl-patterns"; + } + ); + systems = [ "cl-patterns" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "local-time" self) + (getAttr "mutility" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-paymill = ( + build-asdf-system { + pname = "cl-paymill"; + version = "20131111-git"; + asds = [ "cl-paymill" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-paymill/2013-11-11/cl-paymill-20131111-git.tgz"; + sha256 = "1dhddmw7gxfxbv1vfqi6nzyh8m5n3b160ch6ianf5sn6apmi92nw"; + system = "cl-paymill"; + asd = "cl-paymill"; + } + ); + systems = [ "cl-paymill" ]; + lispLibs = [ + (getAttr "cl_plus_ssl" self) + (getAttr "drakma" self) + (getAttr "st-json" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-paypal = ( + build-asdf-system { + pname = "cl-paypal"; + version = "20101006-git"; + asds = [ "cl-paypal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-paypal/2010-10-06/cl-paypal-20101006-git.tgz"; + sha256 = "0cc6zv17klgiyj1mbbrkbvajkr6dwsjv3iilh57vhdqd01lrhnb2"; + system = "cl-paypal"; + asd = "cl-paypal"; + } + ); + systems = [ "cl-paypal" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-pcg = ( + build-asdf-system { + pname = "cl-pcg"; + version = "20201016-hg"; + asds = [ "cl-pcg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pcg/2020-10-16/cl-pcg-20201016-hg.tgz"; + sha256 = "1w2b2y5fgjc6z8akvlmwasj90dnjv55nvb8pghq4xpv43hfy73mp"; + system = "cl-pcg"; + asd = "cl-pcg"; + } + ); + systems = [ "cl-pcg" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-pcg_dot_test = ( + build-asdf-system { + pname = "cl-pcg.test"; + version = "20201016-hg"; + asds = [ "cl-pcg.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pcg/2020-10-16/cl-pcg-20201016-hg.tgz"; + sha256 = "1w2b2y5fgjc6z8akvlmwasj90dnjv55nvb8pghq4xpv43hfy73mp"; + system = "cl-pcg.test"; + asd = "cl-pcg.test"; + } + ); + systems = [ "cl-pcg.test" ]; + lispLibs = [ + (getAttr "_1am" self) + (getAttr "cl-pcg" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-pdf = ( + build-asdf-system { + pname = "cl-pdf"; + version = "20231021-git"; + asds = [ "cl-pdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pdf/2023-10-21/cl-pdf-20231021-git.tgz"; + sha256 = "1x88fvk3kxi3k6a84iajb6myw67z8n3plfidq8d4c26ymiz0kvfm"; + system = "cl-pdf"; + asd = "cl-pdf"; + } + ); + systems = [ "cl-pdf" ]; + lispLibs = [ + (getAttr "iterate" self) + (getAttr "zpb-ttf" self) + ]; + meta = { }; + } + ); + cl-pdf-doc = ( + build-asdf-system { + pname = "cl-pdf-doc"; + version = "20210531-git"; + asds = [ "cl-pdf-doc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-typesetting/2021-05-31/cl-typesetting-20210531-git.tgz"; + sha256 = "0fcs5mq0gxfczbrg7ay8r4bf5r4g6blvpdbjkhcl8dapcikyn35h"; + system = "cl-pdf-doc"; + asd = "cl-pdf-doc"; + } + ); + systems = [ "cl-pdf-doc" ]; + lispLibs = [ + (getAttr "cl-pdf" self) + (getAttr "cl-typesetting" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-pdf-parser = ( + build-asdf-system { + pname = "cl-pdf-parser"; + version = "20231021-git"; + asds = [ "cl-pdf-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pdf/2023-10-21/cl-pdf-20231021-git.tgz"; + sha256 = "1x88fvk3kxi3k6a84iajb6myw67z8n3plfidq8d4c26ymiz0kvfm"; + system = "cl-pdf-parser"; + asd = "cl-pdf-parser"; + } + ); + systems = [ "cl-pdf-parser" ]; + lispLibs = [ (getAttr "cl-pdf" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-performance-tuning-helper = ( + build-asdf-system { + pname = "cl-performance-tuning-helper"; + version = "20130615-git"; + asds = [ "cl-performance-tuning-helper" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-performance-tuning-helper/2013-06-15/cl-performance-tuning-helper-20130615-git.tgz"; + sha256 = "1j0k319il271grm6hjqq2bazp5l105lazayqsmpsy8lsy4lmy0c3"; + system = "cl-performance-tuning-helper"; + asd = "cl-performance-tuning-helper"; + } + ); + systems = [ "cl-performance-tuning-helper" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-performance-tuning-helper-test = ( + build-asdf-system { + pname = "cl-performance-tuning-helper-test"; + version = "20130615-git"; + asds = [ "cl-performance-tuning-helper-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-performance-tuning-helper/2013-06-15/cl-performance-tuning-helper-20130615-git.tgz"; + sha256 = "1j0k319il271grm6hjqq2bazp5l105lazayqsmpsy8lsy4lmy0c3"; + system = "cl-performance-tuning-helper-test"; + asd = "cl-performance-tuning-helper-test"; + } + ); + systems = [ "cl-performance-tuning-helper-test" ]; + lispLibs = [ + (getAttr "cl-performance-tuning-helper" self) + (getAttr "rt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-permutation = ( + build-asdf-system { + pname = "cl-permutation"; + version = "20231021-git"; + asds = [ "cl-permutation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-permutation/2023-10-21/cl-permutation-20231021-git.tgz"; + sha256 = "1zq7hjfn854jr1sglagvdpn749ihxki0l1wcbg9nd2i7ds1g5h4y"; + system = "cl-permutation"; + asd = "cl-permutation"; + } + ); + systems = [ "cl-permutation" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-fft" self) + (getAttr "cl-algebraic-data-type" self) + (getAttr "cl-cont" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + (getAttr "priority-queue" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-permutation-examples = ( + build-asdf-system { + pname = "cl-permutation-examples"; + version = "20231021-git"; + asds = [ "cl-permutation-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-permutation/2023-10-21/cl-permutation-20231021-git.tgz"; + sha256 = "1zq7hjfn854jr1sglagvdpn749ihxki0l1wcbg9nd2i7ds1g5h4y"; + system = "cl-permutation-examples"; + asd = "cl-permutation-examples"; + } + ); + systems = [ "cl-permutation-examples" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-permutation" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-permutation-tests = ( + build-asdf-system { + pname = "cl-permutation-tests"; + version = "20231021-git"; + asds = [ "cl-permutation-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-permutation/2023-10-21/cl-permutation-20231021-git.tgz"; + sha256 = "1zq7hjfn854jr1sglagvdpn749ihxki0l1wcbg9nd2i7ds1g5h4y"; + system = "cl-permutation-tests"; + asd = "cl-permutation-tests"; + } + ); + systems = [ "cl-permutation-tests" ]; + lispLibs = [ + (getAttr "cl-permutation" self) + (getAttr "cl-permutation-examples" self) + (getAttr "fiasco" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-photo = ( + build-asdf-system { + pname = "cl-photo"; + version = "20150923-git"; + asds = [ "cl-photo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-photo/2015-09-23/cl-photo-20150923-git.tgz"; + sha256 = "03rzsi1rqvlnw43z7kh5sy1h8gjxc5n0cfryfkkqnhym9q9186mj"; + system = "cl-photo"; + asd = "cl-photo"; + } + ); + systems = [ "cl-photo" ]; + lispLibs = [ (getAttr "kmrcl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-photo-tests = ( + build-asdf-system { + pname = "cl-photo-tests"; + version = "20150923-git"; + asds = [ "cl-photo-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-photo/2015-09-23/cl-photo-20150923-git.tgz"; + sha256 = "03rzsi1rqvlnw43z7kh5sy1h8gjxc5n0cfryfkkqnhym9q9186mj"; + system = "cl-photo-tests"; + asd = "cl-photo-tests"; + } + ); + systems = [ "cl-photo-tests" ]; + lispLibs = [ + (getAttr "cl-photo" self) + (getAttr "rt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-plplot = ( + build-asdf-system { + pname = "cl-plplot"; + version = "20180228-git"; + asds = [ "cl-plplot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-plplot/2018-02-28/cl-plplot-20180228-git.tgz"; + sha256 = "0hfgq47ga2r764jfc3ywaz5ynnvp701fjhbw0s4j1mrw4gaf6y6w"; + system = "cl-plplot"; + asd = "cl-plplot"; + } + ); + systems = [ "cl-plplot" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-plumbing = ( + build-asdf-system { + pname = "cl-plumbing"; + version = "20181018-git"; + asds = [ "cl-plumbing" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-plumbing/2018-10-18/cl-plumbing-20181018-git.tgz"; + sha256 = "0bc4qqj0c4hghwx8jm3vg422c3i8livv3vvzfzi0gw79khaqdiyr"; + system = "cl-plumbing"; + asd = "cl-plumbing"; + } + ); + systems = [ "cl-plumbing" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "iterate" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-plumbing-test = ( + build-asdf-system { + pname = "cl-plumbing-test"; + version = "20181018-git"; + asds = [ "cl-plumbing-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-plumbing/2018-10-18/cl-plumbing-20181018-git.tgz"; + sha256 = "0bc4qqj0c4hghwx8jm3vg422c3i8livv3vvzfzi0gw79khaqdiyr"; + system = "cl-plumbing-test"; + asd = "cl-plumbing-test"; + } + ); + systems = [ "cl-plumbing-test" ]; + lispLibs = [ + (getAttr "cl-plumbing" self) + (getAttr "iterate" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-plus-c = ( + build-asdf-system { + pname = "cl-plus-c"; + version = "20241012-git"; + asds = [ "cl-plus-c" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-autowrap/2024-10-12/cl-autowrap-20241012-git.tgz"; + sha256 = "1sfvhyrwm9dhxi0y42xp7mx8mvs6lmq3bzxdx34frxni5srcgly0"; + system = "cl-plus-c"; + asd = "cl-plus-c"; + } + ); + systems = [ "cl-plus-c" ]; + lispLibs = [ (getAttr "cl-autowrap" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-plus-ssl-osx-fix = ( + build-asdf-system { + pname = "cl-plus-ssl-osx-fix"; + version = "20241012-git"; + asds = [ "cl-plus-ssl-osx-fix" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-plus-ssl-osx-fix/2024-10-12/cl-plus-ssl-osx-fix-20241012-git.tgz"; + sha256 = "0rkrazia05zzwzd9vx2kl1azwgjy0d4pvfmwp5mjmqsvpklgacwv"; + system = "cl-plus-ssl-osx-fix"; + asd = "cl-plus-ssl-osx-fix"; + } + ); + systems = [ "cl-plus-ssl-osx-fix" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "cl_plus_ssl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-plus-ssl-osx-fix-ci = ( + build-asdf-system { + pname = "cl-plus-ssl-osx-fix-ci"; + version = "20241012-git"; + asds = [ "cl-plus-ssl-osx-fix-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-plus-ssl-osx-fix/2024-10-12/cl-plus-ssl-osx-fix-20241012-git.tgz"; + sha256 = "0rkrazia05zzwzd9vx2kl1azwgjy0d4pvfmwp5mjmqsvpklgacwv"; + system = "cl-plus-ssl-osx-fix-ci"; + asd = "cl-plus-ssl-osx-fix-ci"; + } + ); + systems = [ "cl-plus-ssl-osx-fix-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-plus-ssl-osx-fix-docs = ( + build-asdf-system { + pname = "cl-plus-ssl-osx-fix-docs"; + version = "20241012-git"; + asds = [ "cl-plus-ssl-osx-fix-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-plus-ssl-osx-fix/2024-10-12/cl-plus-ssl-osx-fix-20241012-git.tgz"; + sha256 = "0rkrazia05zzwzd9vx2kl1azwgjy0d4pvfmwp5mjmqsvpklgacwv"; + system = "cl-plus-ssl-osx-fix-docs"; + asd = "cl-plus-ssl-osx-fix-docs"; + } + ); + systems = [ "cl-plus-ssl-osx-fix-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "cl-plus-ssl-osx-fix" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-plus-ssl-osx-fix-tests = ( + build-asdf-system { + pname = "cl-plus-ssl-osx-fix-tests"; + version = "20241012-git"; + asds = [ "cl-plus-ssl-osx-fix-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-plus-ssl-osx-fix/2024-10-12/cl-plus-ssl-osx-fix-20241012-git.tgz"; + sha256 = "0rkrazia05zzwzd9vx2kl1azwgjy0d4pvfmwp5mjmqsvpklgacwv"; + system = "cl-plus-ssl-osx-fix-tests"; + asd = "cl-plus-ssl-osx-fix-tests"; + } + ); + systems = [ "cl-plus-ssl-osx-fix-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ply = ( + build-asdf-system { + pname = "cl-ply"; + version = "20150505-git"; + asds = [ "cl-ply" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ply/2015-05-05/cl-ply-20150505-git.tgz"; + sha256 = "1va3il5ahvziwm6i3f2zy3vchv0qkh1l7jci7gnfam43gf88fl12"; + system = "cl-ply"; + asd = "cl-ply"; + } + ); + systems = [ "cl-ply" ]; + lispLibs = [ + (getAttr "cl-pattern" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ply-test = ( + build-asdf-system { + pname = "cl-ply-test"; + version = "20150505-git"; + asds = [ "cl-ply-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ply/2015-05-05/cl-ply-20150505-git.tgz"; + sha256 = "1va3il5ahvziwm6i3f2zy3vchv0qkh1l7jci7gnfam43gf88fl12"; + system = "cl-ply-test"; + asd = "cl-ply-test"; + } + ); + systems = [ "cl-ply-test" ]; + lispLibs = [ + (getAttr "cl-ply" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-poker-eval = ( + build-asdf-system { + pname = "cl-poker-eval"; + version = "20150804-git"; + asds = [ "cl-poker-eval" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-poker-eval/2015-08-04/cl-poker-eval-20150804-git.tgz"; + sha256 = "1w4dsr4j7r3n7p0jbp8ccwwk83wcjjiz1rhhfrqpsd9v263v7kw8"; + system = "cl-poker-eval"; + asd = "cl-poker-eval"; + } + ); + systems = [ "cl-poker-eval" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-pop = ( + build-asdf-system { + pname = "cl-pop"; + version = "20110418-http"; + asds = [ "cl-pop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pop/2011-04-18/cl-pop-20110418-http.tgz"; + sha256 = "1g47p9w2pzf7glx92cz859di9pz454xpaq97p76lcvyilxk6q819"; + system = "cl-pop"; + asd = "cl-pop"; + } + ); + systems = [ "cl-pop" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-portaudio = ( + build-asdf-system { + pname = "cl-portaudio"; + version = "20201220-git"; + asds = [ "cl-portaudio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-portaudio/2020-12-20/cl-portaudio-20201220-git.tgz"; + sha256 = "177c6bgf30caj5qpzfnzhbamax7c5zm2p4911mw7fay94vjs7zyb"; + system = "cl-portaudio"; + asd = "cl-portaudio"; + } + ); + systems = [ "cl-portaudio" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "ffa" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-postgres = ( + build-asdf-system { + pname = "cl-postgres"; + version = "20241012-git"; + asds = [ "cl-postgres" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/postmodern/2024-10-12/postmodern-20241012-git.tgz"; + sha256 = "1hj0dpclzihy1rcnwhiv16abmaa54wygxyib3j2h9q4qs26w7pzb"; + system = "cl-postgres"; + asd = "cl-postgres"; + } + ); + systems = [ "cl-postgres" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "ironclad" self) + (getAttr "md5" self) + (getAttr "split-sequence" self) + (getAttr "uax-15" self) + ]; + meta = { }; + } + ); + cl-postgres_plus_local-time = ( + build-asdf-system { + pname = "cl-postgres+local-time"; + version = "20241012-git"; + asds = [ "cl-postgres+local-time" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/local-time/2024-10-12/local-time-20241012-git.tgz"; + sha256 = "0jb1mb5zs4ryiah8zjzhpln1z686mfmpmvg1phgpr2mh9vvlgjk2"; + system = "cl-postgres+local-time"; + asd = "cl-postgres+local-time"; + } + ); + systems = [ "cl-postgres+local-time" ]; + lispLibs = [ + (getAttr "cl-postgres" self) + (getAttr "local-time" self) + ]; + meta = { }; + } + ); + cl-postgres_plus_local-time-duration = ( + build-asdf-system { + pname = "cl-postgres+local-time-duration"; + version = "20180430-git"; + asds = [ "cl-postgres+local-time-duration" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/local-time-duration/2018-04-30/local-time-duration-20180430-git.tgz"; + sha256 = "0f13mg18lv31lclz9jvqyj8d85p1jj1366nlld8m3dxnnwsbbkd6"; + system = "cl-postgres+local-time-duration"; + asd = "cl-postgres+local-time-duration"; + } + ); + systems = [ "cl-postgres+local-time-duration" ]; + lispLibs = [ + (getAttr "cl-postgres" self) + (getAttr "local-time-duration" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-postgres-datetime = ( + build-asdf-system { + pname = "cl-postgres-datetime"; + version = "20190521-git"; + asds = [ "cl-postgres-datetime" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-postgres-datetime/2019-05-21/cl-postgres-datetime-20190521-git.tgz"; + sha256 = "1vwv5j1i968927j070bagqx9i114a8phmx7k9ankj9j5zg5dj0l3"; + system = "cl-postgres-datetime"; + asd = "cl-postgres-datetime"; + } + ); + systems = [ "cl-postgres-datetime" ]; + lispLibs = [ + (getAttr "cl-postgres" self) + (getAttr "local-time" self) + (getAttr "simple-date" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-postgres-plus-uuid = ( + build-asdf-system { + pname = "cl-postgres-plus-uuid"; + version = "20181018-git"; + asds = [ "cl-postgres-plus-uuid" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-postgres-plus-uuid/2018-10-18/cl-postgres-plus-uuid-20181018-git.tgz"; + sha256 = "1iw11v67gpwgpa5dw3d7chjmkc4d7sdwrqvnx0vg0m2qf4j7azmi"; + system = "cl-postgres-plus-uuid"; + asd = "cl-postgres-plus-uuid"; + } + ); + systems = [ "cl-postgres-plus-uuid" ]; + lispLibs = [ + (getAttr "cl-postgres" self) + (getAttr "uuid" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ppcre = ( + build-asdf-system { + pname = "cl-ppcre"; + version = "20241012-git"; + asds = [ "cl-ppcre" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ppcre/2024-10-12/cl-ppcre-20241012-git.tgz"; + sha256 = "0aw7lh79wgn18c75v29md2x8irl8v7f96lj1mfkp7x0mkqsb0cs8"; + system = "cl-ppcre"; + asd = "cl-ppcre"; + } + ); + systems = [ "cl-ppcre" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-ppcre-template = ( + build-asdf-system { + pname = "cl-ppcre-template"; + version = "20241012-git"; + asds = [ "cl-ppcre-template" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-unification/2024-10-12/cl-unification-20241012-git.tgz"; + sha256 = "1q7bjj9dzazhgj32291rqy4lld1ilrpck374c21864qn3pmz31ag"; + system = "cl-ppcre-template"; + asd = "cl-ppcre-template"; + } + ); + systems = [ "cl-ppcre-template" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cl-unification" self) + ]; + meta = { }; + } + ); + cl-ppcre-unicode = ( + build-asdf-system { + pname = "cl-ppcre-unicode"; + version = "20241012-git"; + asds = [ "cl-ppcre-unicode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ppcre/2024-10-12/cl-ppcre-20241012-git.tgz"; + sha256 = "0aw7lh79wgn18c75v29md2x8irl8v7f96lj1mfkp7x0mkqsb0cs8"; + system = "cl-ppcre-unicode"; + asd = "cl-ppcre-unicode"; + } + ); + systems = [ "cl-ppcre-unicode" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cl-unicode" self) + ]; + meta = { }; + } + ); + cl-prevalence = ( + build-asdf-system { + pname = "cl-prevalence"; + version = "20230214-git"; + asds = [ "cl-prevalence" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prevalence/2023-02-14/cl-prevalence-20230214-git.tgz"; + sha256 = "1lb957ivshgp56phqhvhsmnc4r55x5shvi3mpsan2xsm4hvqspp0"; + system = "cl-prevalence"; + asd = "cl-prevalence"; + } + ); + systems = [ "cl-prevalence" ]; + lispLibs = [ + (getAttr "moptilities" self) + (getAttr "s-sysdeps" self) + (getAttr "s-xml" self) + ]; + meta = { }; + } + ); + cl-prevalence-test = ( + build-asdf-system { + pname = "cl-prevalence-test"; + version = "20230214-git"; + asds = [ "cl-prevalence-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prevalence/2023-02-14/cl-prevalence-20230214-git.tgz"; + sha256 = "1lb957ivshgp56phqhvhsmnc4r55x5shvi3mpsan2xsm4hvqspp0"; + system = "cl-prevalence-test"; + asd = "cl-prevalence-test"; + } + ); + systems = [ "cl-prevalence-test" ]; + lispLibs = [ + (getAttr "cl-prevalence" self) + (getAttr "find-port" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-primality = ( + build-asdf-system { + pname = "cl-primality"; + version = "20150608-git"; + asds = [ "cl-primality" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-primality/2015-06-08/cl-primality-20150608-git.tgz"; + sha256 = "1hvbsd5x7yrrrh7jjq0p8ign3ppzzpacmmz7nps60wgk38q1b618"; + system = "cl-primality"; + asd = "cl-primality"; + } + ); + systems = [ "cl-primality" ]; + lispLibs = [ (getAttr "iterate" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-primality-test = ( + build-asdf-system { + pname = "cl-primality-test"; + version = "20150608-git"; + asds = [ "cl-primality-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-primality/2015-06-08/cl-primality-20150608-git.tgz"; + sha256 = "1hvbsd5x7yrrrh7jjq0p8ign3ppzzpacmmz7nps60wgk38q1b618"; + system = "cl-primality-test"; + asd = "cl-primality-test"; + } + ); + systems = [ "cl-primality-test" ]; + lispLibs = [ + (getAttr "cl-primality" self) + (getAttr "iterate" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prime-maker = ( + build-asdf-system { + pname = "cl-prime-maker"; + version = "20150302-git"; + asds = [ "cl-prime-maker" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prime-maker/2015-03-02/cl-prime-maker-20150302-git.tgz"; + sha256 = "0hs95zs990aiwspss2dzmjvl18ipvlkx3p9cgmcncqxhgkizds9s"; + system = "cl-prime-maker"; + asd = "cl-prime-maker"; + } + ); + systems = [ "cl-prime-maker" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-progress-bar = ( + build-asdf-system { + pname = "cl-progress-bar"; + version = "20211209-git"; + asds = [ "cl-progress-bar" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-progress-bar/2021-12-09/cl-progress-bar-20211209-git.tgz"; + sha256 = "1y4kg4qb4bxkqnc84mczx5fhqlr6qbagxwsn93xrilv8lqg8ymiv"; + system = "cl-progress-bar"; + asd = "cl-progress-bar"; + } + ); + systems = [ "cl-progress-bar" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "documentation-utils-extensions" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-project = ( + build-asdf-system { + pname = "cl-project"; + version = "20241012-git"; + asds = [ "cl-project" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-project/2024-10-12/cl-project-20241012-git.tgz"; + sha256 = "12bvhs1ll6wxwgarvyxbrm978jxpvgj9vyqcbnwqmf5kqxjlrh0j"; + system = "cl-project"; + asd = "cl-project"; + } + ); + systems = [ "cl-project" ]; + lispLibs = [ + (getAttr "cl-emb" self) + (getAttr "cl-ppcre" self) + (getAttr "local-time" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-project-test = ( + build-asdf-system { + pname = "cl-project-test"; + version = "20241012-git"; + asds = [ "cl-project-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-project/2024-10-12/cl-project-20241012-git.tgz"; + sha256 = "12bvhs1ll6wxwgarvyxbrm978jxpvgj9vyqcbnwqmf5kqxjlrh0j"; + system = "cl-project-test"; + asd = "cl-project-test"; + } + ); + systems = [ "cl-project-test" ]; + lispLibs = [ + (getAttr "caveman2" self) + (getAttr "cl-project" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prolog2 = ( + build-asdf-system { + pname = "cl-prolog2"; + version = "20211209-git"; + asds = [ "cl-prolog2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; + sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; + system = "cl-prolog2"; + asd = "cl-prolog2"; + } + ); + systems = [ "cl-prolog2" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "external-program" self) + (getAttr "trivia" self) + (getAttr "trivia_dot_quasiquote" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prolog2_dot_bprolog = ( + build-asdf-system { + pname = "cl-prolog2.bprolog"; + version = "20211209-git"; + asds = [ "cl-prolog2.bprolog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; + sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; + system = "cl-prolog2.bprolog"; + asd = "cl-prolog2.bprolog"; + } + ); + systems = [ "cl-prolog2.bprolog" ]; + lispLibs = [ (getAttr "cl-prolog2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prolog2_dot_bprolog_dot_test = ( + build-asdf-system { + pname = "cl-prolog2.bprolog.test"; + version = "20211209-git"; + asds = [ "cl-prolog2.bprolog.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; + sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; + system = "cl-prolog2.bprolog.test"; + asd = "cl-prolog2.bprolog.test"; + } + ); + systems = [ "cl-prolog2.bprolog.test" ]; + lispLibs = [ + (getAttr "cl-prolog2_dot_bprolog" self) + (getAttr "cl-prolog2_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prolog2_dot_gprolog = ( + build-asdf-system { + pname = "cl-prolog2.gprolog"; + version = "20211209-git"; + asds = [ "cl-prolog2.gprolog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; + sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; + system = "cl-prolog2.gprolog"; + asd = "cl-prolog2.gprolog"; + } + ); + systems = [ "cl-prolog2.gprolog" ]; + lispLibs = [ (getAttr "cl-prolog2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prolog2_dot_gprolog_dot_test = ( + build-asdf-system { + pname = "cl-prolog2.gprolog.test"; + version = "20211209-git"; + asds = [ "cl-prolog2.gprolog.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; + sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; + system = "cl-prolog2.gprolog.test"; + asd = "cl-prolog2.gprolog.test"; + } + ); + systems = [ "cl-prolog2.gprolog.test" ]; + lispLibs = [ + (getAttr "cl-prolog2_dot_gprolog" self) + (getAttr "cl-prolog2_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prolog2_dot_swi = ( + build-asdf-system { + pname = "cl-prolog2.swi"; + version = "20211209-git"; + asds = [ "cl-prolog2.swi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; + sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; + system = "cl-prolog2.swi"; + asd = "cl-prolog2.swi"; + } + ); + systems = [ "cl-prolog2.swi" ]; + lispLibs = [ (getAttr "cl-prolog2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prolog2_dot_swi_dot_test = ( + build-asdf-system { + pname = "cl-prolog2.swi.test"; + version = "20211209-git"; + asds = [ "cl-prolog2.swi.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; + sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; + system = "cl-prolog2.swi.test"; + asd = "cl-prolog2.swi.test"; + } + ); + systems = [ "cl-prolog2.swi.test" ]; + lispLibs = [ + (getAttr "cl-prolog2_dot_swi" self) + (getAttr "cl-prolog2_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prolog2_dot_test = ( + build-asdf-system { + pname = "cl-prolog2.test"; + version = "20211209-git"; + asds = [ "cl-prolog2.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; + sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; + system = "cl-prolog2.test"; + asd = "cl-prolog2.test"; + } + ); + systems = [ "cl-prolog2.test" ]; + lispLibs = [ + (getAttr "cl-prolog2" self) + (getAttr "fiveam" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prolog2_dot_xsb = ( + build-asdf-system { + pname = "cl-prolog2.xsb"; + version = "20211209-git"; + asds = [ "cl-prolog2.xsb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; + sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; + system = "cl-prolog2.xsb"; + asd = "cl-prolog2.xsb"; + } + ); + systems = [ "cl-prolog2.xsb" ]; + lispLibs = [ (getAttr "cl-prolog2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prolog2_dot_xsb_dot_test = ( + build-asdf-system { + pname = "cl-prolog2.xsb.test"; + version = "20211209-git"; + asds = [ "cl-prolog2.xsb.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; + sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; + system = "cl-prolog2.xsb.test"; + asd = "cl-prolog2.xsb.test"; + } + ); + systems = [ "cl-prolog2.xsb.test" ]; + lispLibs = [ + (getAttr "cl-prolog2_dot_test" self) + (getAttr "cl-prolog2_dot_xsb" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prolog2_dot_yap = ( + build-asdf-system { + pname = "cl-prolog2.yap"; + version = "20211209-git"; + asds = [ "cl-prolog2.yap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; + sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; + system = "cl-prolog2.yap"; + asd = "cl-prolog2.yap"; + } + ); + systems = [ "cl-prolog2.yap" ]; + lispLibs = [ (getAttr "cl-prolog2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-prolog2_dot_yap_dot_test = ( + build-asdf-system { + pname = "cl-prolog2.yap.test"; + version = "20211209-git"; + asds = [ "cl-prolog2.yap.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-prolog2/2021-12-09/cl-prolog2-20211209-git.tgz"; + sha256 = "15xa1i2r72ll6zfhq6gkv0h36kifqjvbsmnycd145vgd0dvh5pgg"; + system = "cl-prolog2.yap.test"; + asd = "cl-prolog2.yap.test"; + } + ); + systems = [ "cl-prolog2.yap.test" ]; + lispLibs = [ + (getAttr "cl-prolog2_dot_test" self) + (getAttr "cl-prolog2_dot_yap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-protobufs_dot_asdf = ( + build-asdf-system { + pname = "cl-protobufs.asdf"; + version = "20241012-git"; + asds = [ "cl-protobufs.asdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-protobufs/2024-10-12/cl-protobufs-20241012-git.tgz"; + sha256 = "08digcsyxs46pl7r5d945db5r2hbrxydqqcmzbgziq61ca4p0ifn"; + system = "cl-protobufs.asdf"; + asd = "cl-protobufs.asdf"; + } + ); + systems = [ "cl-protobufs.asdf" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-pslib = ( + build-asdf-system { + pname = "cl-pslib"; + version = "20241012-git"; + asds = [ "cl-pslib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pslib/2024-10-12/cl-pslib-20241012-git.tgz"; + sha256 = "12lg64nbjkxmaf212qr4i0msnsixc2cbqmxkdgqjii9rsyqdvrn6"; + system = "cl-pslib"; + asd = "cl-pslib"; + } + ); + systems = [ "cl-pslib" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-colors2" self) + (getAttr "cl-ppcre-unicode" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-pslib-barcode = ( + build-asdf-system { + pname = "cl-pslib-barcode"; + version = "20241012-git"; + asds = [ "cl-pslib-barcode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pslib-barcode/2024-10-12/cl-pslib-barcode-20241012-git.tgz"; + sha256 = "1n17yv7qr6i6dhbjrcc1binlxxkc1p5blj9nwn6g26fyvakgwrsb"; + system = "cl-pslib-barcode"; + asd = "cl-pslib-barcode"; + } + ); + systems = [ "cl-pslib-barcode" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-colors2" self) + (getAttr "cl-ppcre-unicode" self) + (getAttr "cl-pslib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-punch = ( + build-asdf-system { + pname = "cl-punch"; + version = "20190107-git"; + asds = [ "cl-punch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-punch/2019-01-07/cl-punch-20190107-git.tgz"; + sha256 = "1sjgwn6c77n8pgs0rrw70xfl18rps6a0dlf2chfsbgk8shz6qyl2"; + system = "cl-punch"; + asd = "cl-punch"; + } + ); + systems = [ "cl-punch" ]; + lispLibs = [ (getAttr "cl-syntax" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-punch-test = ( + build-asdf-system { + pname = "cl-punch-test"; + version = "20190107-git"; + asds = [ "cl-punch-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-punch/2019-01-07/cl-punch-20190107-git.tgz"; + sha256 = "1sjgwn6c77n8pgs0rrw70xfl18rps6a0dlf2chfsbgk8shz6qyl2"; + system = "cl-punch-test"; + asd = "cl-punch-test"; + } + ); + systems = [ "cl-punch-test" ]; + lispLibs = [ + (getAttr "cl-punch" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-qoa = ( + build-asdf-system { + pname = "cl-qoa"; + version = "20241012-git"; + asds = [ "cl-qoa" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-qoa/2024-10-12/cl-qoa-20241012-git.tgz"; + sha256 = "0gxrra0mvvkyvhvg7cc4bvi3nwdsnx0dbjszp41ch6dsdhd3pcpy"; + system = "cl-qoa"; + asd = "cl-qoa"; + } + ); + systems = [ "cl-qoa" ]; + lispLibs = [ + (getAttr "binary-structures" self) + (getAttr "documentation-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-qprint = ( + build-asdf-system { + pname = "cl-qprint"; + version = "20150804-git"; + asds = [ "cl-qprint" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-qprint/2015-08-04/cl-qprint-20150804-git.tgz"; + sha256 = "099h0rrdzxnlmn8avi72mg2dl0kccp7w01b2p9nwyy4b8yr32cir"; + system = "cl-qprint"; + asd = "cl-qprint"; + } + ); + systems = [ "cl-qprint" ]; + lispLibs = [ (getAttr "flexi-streams" self) ]; + meta = { }; + } + ); + cl-qrencode = ( + build-asdf-system { + pname = "cl-qrencode"; + version = "20191007-git"; + asds = [ "cl-qrencode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-qrencode/2019-10-07/cl-qrencode-20191007-git.tgz"; + sha256 = "1l5k131dchbf6cj8a8xqa731790p01p3qa1kdy2wa9dawy3ymkxr"; + system = "cl-qrencode"; + asd = "cl-qrencode"; + } + ); + systems = [ "cl-qrencode" ]; + lispLibs = [ (getAttr "zpng" self) ]; + meta = { }; + } + ); + cl-qrencode-test = ( + build-asdf-system { + pname = "cl-qrencode-test"; + version = "20191007-git"; + asds = [ "cl-qrencode-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-qrencode/2019-10-07/cl-qrencode-20191007-git.tgz"; + sha256 = "1l5k131dchbf6cj8a8xqa731790p01p3qa1kdy2wa9dawy3ymkxr"; + system = "cl-qrencode-test"; + asd = "cl-qrencode-test"; + } + ); + systems = [ "cl-qrencode-test" ]; + lispLibs = [ + (getAttr "cl-qrencode" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-quickcheck = ( + build-asdf-system { + pname = "cl-quickcheck"; + version = "20200610-git"; + asds = [ "cl-quickcheck" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-quickcheck/2020-06-10/cl-quickcheck-20200610-git.tgz"; + sha256 = "0cfyxbdhklvdk3qdzyxxaq9q6cxnsvqjfi86nay1vc7h6ziysb60"; + system = "cl-quickcheck"; + asd = "cl-quickcheck"; + } + ); + systems = [ "cl-quickcheck" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rabbit = ( + build-asdf-system { + pname = "cl-rabbit"; + version = "20210411-git"; + asds = [ "cl-rabbit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rabbit/2021-04-11/cl-rabbit-20210411-git.tgz"; + sha256 = "1q1mhqxqvxbr6ak7j0ym6mjhhq6r0pqk1l7az9hfajmqmw3xfija"; + system = "cl-rabbit"; + asd = "cl-rabbit"; + } + ); + systems = [ "cl-rabbit" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cffi-libffi" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rabbit-tests = ( + build-asdf-system { + pname = "cl-rabbit-tests"; + version = "20210411-git"; + asds = [ "cl-rabbit-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rabbit/2021-04-11/cl-rabbit-20210411-git.tgz"; + sha256 = "1q1mhqxqvxbr6ak7j0ym6mjhhq6r0pqk1l7az9hfajmqmw3xfija"; + system = "cl-rabbit-tests"; + asd = "cl-rabbit-tests"; + } + ); + systems = [ "cl-rabbit-tests" ]; + lispLibs = [ + (getAttr "cl-rabbit" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-randist = ( + build-asdf-system { + pname = "cl-randist"; + version = "20221106-git"; + asds = [ "cl-randist" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-randist/2022-11-06/cl-randist-20221106-git.tgz"; + sha256 = "1r0d76n5zjqg5fb2ypqx5i1wg4hsg5g0c126ylqb28wdaf2yjz5a"; + system = "cl-randist"; + asd = "cl-randist"; + } + ); + systems = [ "cl-randist" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-random-forest = ( + build-asdf-system { + pname = "cl-random-forest"; + version = "20221106-git"; + asds = [ "cl-random-forest" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-random-forest/2022-11-06/cl-random-forest-20221106-git.tgz"; + sha256 = "0jn5f3s1zvjql35c4m67lqc0vjr7sm7kzf8w4jfbfabcnxf3y6jx"; + system = "cl-random-forest"; + asd = "cl-random-forest"; + } + ); + systems = [ "cl-random-forest" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-libsvm-format" self) + (getAttr "cl-online-learning" self) + (getAttr "lparallel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-random-forest-test = ( + build-asdf-system { + pname = "cl-random-forest-test"; + version = "20221106-git"; + asds = [ "cl-random-forest-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-random-forest/2022-11-06/cl-random-forest-20221106-git.tgz"; + sha256 = "0jn5f3s1zvjql35c4m67lqc0vjr7sm7kzf8w4jfbfabcnxf3y6jx"; + system = "cl-random-forest-test"; + asd = "cl-random-forest-test"; + } + ); + systems = [ "cl-random-forest-test" ]; + lispLibs = [ + (getAttr "cl-random-forest" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rdfxml = ( + build-asdf-system { + pname = "cl-rdfxml"; + version = "20140713-git"; + asds = [ "cl-rdfxml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rdfxml/2014-07-13/cl-rdfxml-20140713-git.tgz"; + sha256 = "09v76qg6l3y1llapnkfqrfgib67h7lpkzrdmfimwk49bi80iii8v"; + system = "cl-rdfxml"; + asd = "cl-rdfxml"; + } + ); + systems = [ "cl-rdfxml" ]; + lispLibs = [ + (getAttr "cxml" self) + (getAttr "puri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rdkafka = ( + build-asdf-system { + pname = "cl-rdkafka"; + version = "20230214-git"; + asds = [ "cl-rdkafka" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rdkafka/2023-02-14/cl-rdkafka-20230214-git.tgz"; + sha256 = "10y56avak66k2la9bmfzrni01wybi86avxjh64hz57b351bf2s55"; + system = "cl-rdkafka"; + asd = "cl-rdkafka"; + } + ); + systems = [ "cl-rdkafka" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "lparallel" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-readline = ( + build-asdf-system { + pname = "cl-readline"; + version = "20241012-git"; + asds = [ "cl-readline" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-readline/2024-10-12/cl-readline-20241012-git.tgz"; + sha256 = "0law12vnj1d5174kk9l949mgkkxm1x6kpcw5wixxjavmxxwqwric"; + system = "cl-readline"; + asd = "cl-readline"; + } + ); + systems = [ "cl-readline" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + ]; + meta = { }; + } + ); + cl-recaptcha = ( + build-asdf-system { + pname = "cl-recaptcha"; + version = "20150608-git"; + asds = [ "cl-recaptcha" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-recaptcha/2015-06-08/cl-recaptcha-20150608-git.tgz"; + sha256 = "09qdmzbhc5hikay31mbsfd7dps72rm4gcdbbi0b6gkb6qbia6m71"; + system = "cl-recaptcha"; + asd = "cl-recaptcha"; + } + ); + systems = [ "cl-recaptcha" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + (getAttr "jsown" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-reddit = ( + build-asdf-system { + pname = "cl-reddit"; + version = "20241012-git"; + asds = [ "cl-reddit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-reddit/2024-10-12/cl-reddit-20241012-git.tgz"; + sha256 = "0jnc88mdz7hsmsncqrqmc8m8f1yd3n9087750kqpnn1sp1cwskk1"; + system = "cl-reddit"; + asd = "cl-reddit"; + } + ); + systems = [ "cl-reddit" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-redis = ( + build-asdf-system { + pname = "cl-redis"; + version = "20200925-git"; + asds = [ "cl-redis" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-redis/2020-09-25/cl-redis-20200925-git.tgz"; + sha256 = "0x5ahxb5cx37biyn3cjycshhm1rr9p5cf1a9l5hd1n1xjxm2f8vi"; + system = "cl-redis"; + asd = "cl-redis"; + } + ); + systems = [ "cl-redis" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "rutils" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-redis-test = ( + build-asdf-system { + pname = "cl-redis-test"; + version = "20200925-git"; + asds = [ "cl-redis-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-redis/2020-09-25/cl-redis-20200925-git.tgz"; + sha256 = "0x5ahxb5cx37biyn3cjycshhm1rr9p5cf1a9l5hd1n1xjxm2f8vi"; + system = "cl-redis-test"; + asd = "cl-redis"; + } + ); + systems = [ "cl-redis-test" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-redis" self) + (getAttr "flexi-streams" self) + (getAttr "should-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-reexport = ( + build-asdf-system { + pname = "cl-reexport"; + version = "20210228-git"; + asds = [ "cl-reexport" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-reexport/2021-02-28/cl-reexport-20210228-git.tgz"; + sha256 = "02la6z3ickhmh2m87ymm2ijh9nkn7l6slskj99l8a1rhps394qqc"; + system = "cl-reexport"; + asd = "cl-reexport"; + } + ); + systems = [ "cl-reexport" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { }; + } + ); + cl-reexport-test = ( + build-asdf-system { + pname = "cl-reexport-test"; + version = "20210228-git"; + asds = [ "cl-reexport-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-reexport/2021-02-28/cl-reexport-20210228-git.tgz"; + sha256 = "02la6z3ickhmh2m87ymm2ijh9nkn7l6slskj99l8a1rhps394qqc"; + system = "cl-reexport-test"; + asd = "cl-reexport-test"; + } + ); + systems = [ "cl-reexport-test" ]; + lispLibs = [ + (getAttr "cl-reexport" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-renderdoc = ( + build-asdf-system { + pname = "cl-renderdoc"; + version = "20200925-git"; + asds = [ "cl-renderdoc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-renderdoc/2020-09-25/cl-renderdoc-20200925-git.tgz"; + sha256 = "0rrcp4y1f07x8h0ikvf5ncc3pbqj6vaciblab9qghmgdglnn7akx"; + system = "cl-renderdoc"; + asd = "cl-renderdoc"; + } + ); + systems = [ "cl-renderdoc" ]; + lispLibs = [ (getAttr "cl-autowrap" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-replica = ( + build-asdf-system { + pname = "cl-replica"; + version = "20230618-git"; + asds = [ "cl-replica" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-replica/2023-06-18/cl-replica-20230618-git.tgz"; + sha256 = "06nywqz7il4dk79s3ga8115s5cr9bpz1fh8b7jms5wxlc1h5p0mn"; + system = "cl-replica"; + asd = "cl-replica"; + } + ); + systems = [ "cl-replica" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-resvg = ( + build-asdf-system { + pname = "cl-resvg"; + version = "20241012-git"; + asds = [ "cl-resvg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-resvg/2024-10-12/cl-resvg-20241012-git.tgz"; + sha256 = "0263na51qs0wrc9r2dqigj4a1h70pjf0mqsgbnd6hfshvx0kq1cl"; + system = "cl-resvg"; + asd = "cl-resvg"; + } + ); + systems = [ "cl-resvg" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "float-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rethinkdb = ( + build-asdf-system { + pname = "cl-rethinkdb"; + version = "20160825-git"; + asds = [ "cl-rethinkdb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rethinkdb/2016-08-25/cl-rethinkdb-20160825-git.tgz"; + sha256 = "0sps1p203gn7i123w96pj5ggpncmkngkfdb6zfnm5yjq544sjjf7"; + system = "cl-rethinkdb"; + asd = "cl-rethinkdb"; + } + ); + systems = [ "cl-rethinkdb" ]; + lispLibs = [ + (getAttr "blackbird" self) + (getAttr "cl-async" self) + (getAttr "cl-base64" self) + (getAttr "cl-hash-util" self) + (getAttr "cl-ppcre" self) + (getAttr "event-glue" self) + (getAttr "fast-io" self) + (getAttr "jonathan" self) + (getAttr "local-time" self) + (getAttr "vom" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rethinkdb-test = ( + build-asdf-system { + pname = "cl-rethinkdb-test"; + version = "20160825-git"; + asds = [ "cl-rethinkdb-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rethinkdb/2016-08-25/cl-rethinkdb-20160825-git.tgz"; + sha256 = "0sps1p203gn7i123w96pj5ggpncmkngkfdb6zfnm5yjq544sjjf7"; + system = "cl-rethinkdb-test"; + asd = "cl-rethinkdb-test"; + } + ); + systems = [ "cl-rethinkdb-test" ]; + lispLibs = [ + (getAttr "blackbird" self) + (getAttr "cl-async" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-rethinkdb" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rfc2047 = ( + build-asdf-system { + pname = "cl-rfc2047"; + version = "20150804-git"; + asds = [ "cl-rfc2047" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rfc2047/2015-08-04/cl-rfc2047-20150804-git.tgz"; + sha256 = "1kh48p5i7lmv1hcdsddlcjavhai9gi54jndnbpm9r55a6ladi8gv"; + system = "cl-rfc2047"; + asd = "cl-rfc2047"; + } + ); + systems = [ "cl-rfc2047" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-base64" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rfc2047-test = ( + build-asdf-system { + pname = "cl-rfc2047-test"; + version = "20150804-git"; + asds = [ "cl-rfc2047-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rfc2047/2015-08-04/cl-rfc2047-20150804-git.tgz"; + sha256 = "1kh48p5i7lmv1hcdsddlcjavhai9gi54jndnbpm9r55a6ladi8gv"; + system = "cl-rfc2047-test"; + asd = "cl-rfc2047-test"; + } + ); + systems = [ "cl-rfc2047-test" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cl-rfc2047" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rfc4251 = ( + build-asdf-system { + pname = "cl-rfc4251"; + version = "20231021-git"; + asds = [ "cl-rfc4251" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rfc4251/2023-10-21/cl-rfc4251-20231021-git.tgz"; + sha256 = "11xz6w1gvyj5a01yjfy52byfrq6v8k1mzkp3wajhzhg60nkhn4jh"; + system = "cl-rfc4251"; + asd = "cl-rfc4251"; + } + ); + systems = [ "cl-rfc4251" ]; + lispLibs = [ (getAttr "trivial-gray-streams" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rfc4251_dot_test = ( + build-asdf-system { + pname = "cl-rfc4251.test"; + version = "20231021-git"; + asds = [ "cl-rfc4251.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rfc4251/2023-10-21/cl-rfc4251-20231021-git.tgz"; + sha256 = "11xz6w1gvyj5a01yjfy52byfrq6v8k1mzkp3wajhzhg60nkhn4jh"; + system = "cl-rfc4251.test"; + asd = "cl-rfc4251.test"; + } + ); + systems = [ "cl-rfc4251.test" ]; + lispLibs = [ + (getAttr "cl-rfc4251" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-riff = ( + build-asdf-system { + pname = "cl-riff"; + version = "20220707-git"; + asds = [ "cl-riff" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-riff/2022-07-07/cl-riff-20220707-git.tgz"; + sha256 = "0b2j6yw3xkv6611snn7cy56vmnjfgi58wyvfr9lx82xkakd9rw3z"; + system = "cl-riff"; + asd = "cl-riff"; + } + ); + systems = [ "cl-riff" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rlimit = ( + build-asdf-system { + pname = "cl-rlimit"; + version = "20150608-git"; + asds = [ "cl-rlimit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rlimit/2015-06-08/cl-rlimit-20150608-git.tgz"; + sha256 = "19p02r380qhs76qlcb3jp4lm4nsnpy7zch01fdiwn7l7xgxkzxh0"; + system = "cl-rlimit"; + asd = "cl-rlimit"; + } + ); + systems = [ "cl-rlimit" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rmath = ( + build-asdf-system { + pname = "cl-rmath"; + version = "20180328-git"; + asds = [ "cl-rmath" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rmath/2018-03-28/cl-rmath-20180328-git.tgz"; + sha256 = "1ld8vbpy10paymx2hn0mcgd21i7cjhdrayln1jx0kayqxm12mmk4"; + system = "cl-rmath"; + asd = "cl-rmath"; + } + ); + systems = [ "cl-rmath" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-robdd = ( + build-asdf-system { + pname = "cl-robdd"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "cl-robdd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "cl-robdd"; + asd = "cl-robdd"; + } + ); + systems = [ "cl-robdd" ]; + lispLibs = [ (getAttr "adjuvant" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-robdd-analysis = ( + build-asdf-system { + pname = "cl-robdd-analysis"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "cl-robdd-analysis" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "cl-robdd-analysis"; + asd = "cl-robdd-analysis"; + } + ); + systems = [ "cl-robdd-analysis" ]; + lispLibs = [ + (getAttr "adjuvant" self) + (getAttr "cl-fad" self) + (getAttr "cl-robdd" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-robdd-analysis-test = ( + build-asdf-system { + pname = "cl-robdd-analysis-test"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "cl-robdd-analysis-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "cl-robdd-analysis-test"; + asd = "cl-robdd-analysis-test"; + } + ); + systems = [ "cl-robdd-analysis-test" ]; + lispLibs = [ + (getAttr "adjuvant" self) + (getAttr "cl-robdd-analysis" self) + (getAttr "scrutiny" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-robdd-test = ( + build-asdf-system { + pname = "cl-robdd-test"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "cl-robdd-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "cl-robdd-test"; + asd = "cl-robdd-test"; + } + ); + systems = [ "cl-robdd-test" ]; + lispLibs = [ + (getAttr "adjuvant" self) + (getAttr "cl-fad" self) + (getAttr "cl-robdd" self) + (getAttr "scrutiny" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rrd = ( + build-asdf-system { + pname = "cl-rrd"; + version = "20130128-git"; + asds = [ "cl-rrd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rrd/2013-01-28/cl-rrd-20130128-git.tgz"; + sha256 = "0a7fs46q41qzi6k8q9lvxryn2m90vamcsw7vl9kcjivyckjqrsm2"; + system = "cl-rrd"; + asd = "cl-rrd"; + } + ); + systems = [ "cl-rrd" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rrt = ( + build-asdf-system { + pname = "cl-rrt"; + version = "20200925-git"; + asds = [ "cl-rrt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rrt/2020-09-25/cl-rrt-20200925-git.tgz"; + sha256 = "0lf1dvw5j9awy7ic1i4j5wd7657a170ywxihinmsdn4bwd4fynv0"; + system = "cl-rrt"; + asd = "cl-rrt"; + } + ); + systems = [ "cl-rrt" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cl-syntax-annot" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rrt_dot_benchmark = ( + build-asdf-system { + pname = "cl-rrt.benchmark"; + version = "20200925-git"; + asds = [ "cl-rrt.benchmark" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rrt/2020-09-25/cl-rrt-20200925-git.tgz"; + sha256 = "0lf1dvw5j9awy7ic1i4j5wd7657a170ywxihinmsdn4bwd4fynv0"; + system = "cl-rrt.benchmark"; + asd = "cl-rrt.benchmark"; + } + ); + systems = [ "cl-rrt.benchmark" ]; + lispLibs = [ + (getAttr "cl-rrt" self) + (getAttr "cl-rrt_dot_rtree" self) + (getAttr "cl-rrt_dot_test" self) + (getAttr "fiveam" self) + (getAttr "vecto" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rrt_dot_rtree = ( + build-asdf-system { + pname = "cl-rrt.rtree"; + version = "20200925-git"; + asds = [ "cl-rrt.rtree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rrt/2020-09-25/cl-rrt-20200925-git.tgz"; + sha256 = "0lf1dvw5j9awy7ic1i4j5wd7657a170ywxihinmsdn4bwd4fynv0"; + system = "cl-rrt.rtree"; + asd = "cl-rrt.rtree"; + } + ); + systems = [ "cl-rrt.rtree" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cl-rrt" self) + (getAttr "cl-syntax-annot" self) + (getAttr "iterate" self) + (getAttr "spatial-trees" self) + (getAttr "spatial-trees_dot_nns" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rrt_dot_test = ( + build-asdf-system { + pname = "cl-rrt.test"; + version = "20200925-git"; + asds = [ "cl-rrt.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rrt/2020-09-25/cl-rrt-20200925-git.tgz"; + sha256 = "0lf1dvw5j9awy7ic1i4j5wd7657a170ywxihinmsdn4bwd4fynv0"; + system = "cl-rrt.test"; + asd = "cl-rrt.test"; + } + ); + systems = [ "cl-rrt.test" ]; + lispLibs = [ + (getAttr "cl-rrt" self) + (getAttr "cl-rrt_dot_rtree" self) + (getAttr "fiveam" self) + (getAttr "vecto" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rsvg2 = ( + build-asdf-system { + pname = "cl-rsvg2"; + version = "20200925-git"; + asds = [ "cl-rsvg2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rsvg2/2020-09-25/cl-rsvg2-20200925-git.tgz"; + sha256 = "1amq4q27lj0nzffvwmqrkg8v9pdcf0281zzrvxl9w6vdm9qy1v3n"; + system = "cl-rsvg2"; + asd = "cl-rsvg2"; + } + ); + systems = [ "cl-rsvg2" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-cairo2" self) + (getAttr "cl-gtk2-glib" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + cl-rsvg2-pixbuf = ( + build-asdf-system { + pname = "cl-rsvg2-pixbuf"; + version = "20200925-git"; + asds = [ "cl-rsvg2-pixbuf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rsvg2/2020-09-25/cl-rsvg2-20200925-git.tgz"; + sha256 = "1amq4q27lj0nzffvwmqrkg8v9pdcf0281zzrvxl9w6vdm9qy1v3n"; + system = "cl-rsvg2-pixbuf"; + asd = "cl-rsvg2-pixbuf"; + } + ); + systems = [ "cl-rsvg2-pixbuf" ]; + lispLibs = [ + (getAttr "cl-gtk2-gdk" self) + (getAttr "cl-rsvg2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rsvg2-test = ( + build-asdf-system { + pname = "cl-rsvg2-test"; + version = "20200925-git"; + asds = [ "cl-rsvg2-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rsvg2/2020-09-25/cl-rsvg2-20200925-git.tgz"; + sha256 = "1amq4q27lj0nzffvwmqrkg8v9pdcf0281zzrvxl9w6vdm9qy1v3n"; + system = "cl-rsvg2-test"; + asd = "cl-rsvg2-test"; + } + ); + systems = [ "cl-rsvg2-test" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-rsvg2" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rules = ( + build-asdf-system { + pname = "cl-rules"; + version = "20190710-git"; + asds = [ "cl-rules" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rules/2019-07-10/cl-rules-20190710-git.tgz"; + sha256 = "0jidck62n0jkfqwrpqjn43zmjb3jlfaxxhn2lsyfwy2740i8ppr1"; + system = "cl-rules"; + asd = "cl-rules"; + } + ); + systems = [ "cl-rules" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-yaml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-rules-test = ( + build-asdf-system { + pname = "cl-rules-test"; + version = "20190710-git"; + asds = [ "cl-rules-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rules/2019-07-10/cl-rules-20190710-git.tgz"; + sha256 = "0jidck62n0jkfqwrpqjn43zmjb3jlfaxxhn2lsyfwy2740i8ppr1"; + system = "cl-rules-test"; + asd = "cl-rules-test"; + } + ); + systems = [ "cl-rules-test" ]; + lispLibs = [ + (getAttr "cl-rules" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-s3 = ( + build-asdf-system { + pname = "cl-s3"; + version = "20130128-git"; + asds = [ "cl-s3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-s3/2013-01-28/cl-s3-20130128-git.tgz"; + sha256 = "1lbvf7phkm5vjk013p484rh4vh33i58jlqq3z4cv2yxqcw6r639d"; + system = "cl-s3"; + asd = "cl-s3"; + } + ); + systems = [ "cl-s3" ]; + lispLibs = [ + (getAttr "ironclad" self) + (getAttr "s-base64" self) + (getAttr "s-http-client" self) + (getAttr "s-utils" self) + (getAttr "s-xml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sam = ( + build-asdf-system { + pname = "cl-sam"; + version = "20150608-git"; + asds = [ "cl-sam" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sam/2015-06-08/cl-sam-20150608-git.tgz"; + sha256 = "0frrxz70jin4sa5n087zm4ikckf1zdjqqpjq3llrv46753c62fc6"; + system = "cl-sam"; + asd = "cl-sam"; + } + ); + systems = [ "cl-sam" ]; + lispLibs = [ + (getAttr "deoxybyte-gzip" self) + (getAttr "deoxybyte-systems" self) + (getAttr "deoxybyte-unix" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sam-test = ( + build-asdf-system { + pname = "cl-sam-test"; + version = "20150608-git"; + asds = [ "cl-sam-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sam/2015-06-08/cl-sam-20150608-git.tgz"; + sha256 = "0frrxz70jin4sa5n087zm4ikckf1zdjqqpjq3llrv46753c62fc6"; + system = "cl-sam-test"; + asd = "cl-sam-test"; + } + ); + systems = [ "cl-sam-test" ]; + lispLibs = [ + (getAttr "cl-sam" self) + (getAttr "deoxybyte-io" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sandbox = ( + build-asdf-system { + pname = "cl-sandbox"; + version = "20180131-git"; + asds = [ "cl-sandbox" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sandbox/2018-01-31/cl-sandbox-20180131-git.tgz"; + sha256 = "053zxy3zi5jvlbg8zxlf922sxb32mq34zvwfhgpj4rcmgvgmqnxv"; + system = "cl-sandbox"; + asd = "cl-sandbox"; + } + ); + systems = [ "cl-sandbox" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sasl = ( + build-asdf-system { + pname = "cl-sasl"; + version = "v0.3.2"; + asds = [ "cl-sasl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sasl/2019-05-21/cl-sasl-v0.3.2.tgz"; + sha256 = "0a05q8rls2hn46rbbk6w5km9kqvhsj365zlw6hp32724xy2nd98w"; + system = "cl-sasl"; + asd = "cl-sasl"; + } + ); + systems = [ "cl-sasl" ]; + lispLibs = [ (getAttr "ironclad" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sat = ( + build-asdf-system { + pname = "cl-sat"; + version = "20220707-git"; + asds = [ "cl-sat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sat/2022-07-07/cl-sat-20220707-git.tgz"; + sha256 = "1fcvxpmja757vyyhcpb00g150dyx90jsg9z8s596vy1nb0z81f49"; + system = "cl-sat"; + asd = "cl-sat"; + } + ); + systems = [ "cl-sat" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "trivia" self) + (getAttr "trivial-features" self) + ]; + meta = { }; + } + ); + cl-sat_dot_glucose = ( + build-asdf-system { + pname = "cl-sat.glucose"; + version = "20220331-git"; + asds = [ "cl-sat.glucose" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sat.glucose/2022-03-31/cl-sat.glucose-20220331-git.tgz"; + sha256 = "11hbhsjzw3xzz6i6niisk5h271kg52y3y77sl6ljnszfgp9xjfxy"; + system = "cl-sat.glucose"; + asd = "cl-sat.glucose"; + } + ); + systems = [ "cl-sat.glucose" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-sat" self) + (getAttr "iterate" self) + (getAttr "trivia" self) + (getAttr "trivial-package-manager" self) + ]; + meta = { }; + } + ); + cl-sat_dot_glucose_dot_test = ( + build-asdf-system { + pname = "cl-sat.glucose.test"; + version = "20220331-git"; + asds = [ "cl-sat.glucose.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sat.glucose/2022-03-31/cl-sat.glucose-20220331-git.tgz"; + sha256 = "11hbhsjzw3xzz6i6niisk5h271kg52y3y77sl6ljnszfgp9xjfxy"; + system = "cl-sat.glucose.test"; + asd = "cl-sat.glucose.test"; + } + ); + systems = [ "cl-sat.glucose.test" ]; + lispLibs = [ + (getAttr "cl-sat_dot_glucose" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sat_dot_minisat = ( + build-asdf-system { + pname = "cl-sat.minisat"; + version = "20241012-git"; + asds = [ "cl-sat.minisat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sat.minisat/2024-10-12/cl-sat.minisat-20241012-git.tgz"; + sha256 = "00h5smjs60r1abq27w2ayg55ypsw32769pkk72mrikyn29r6z9ni"; + system = "cl-sat.minisat"; + asd = "cl-sat.minisat"; + } + ); + systems = [ "cl-sat.minisat" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-sat" self) + (getAttr "iterate" self) + (getAttr "trivia" self) + (getAttr "trivial-package-manager" self) + ]; + meta = { }; + } + ); + cl-sat_dot_minisat_dot_test = ( + build-asdf-system { + pname = "cl-sat.minisat.test"; + version = "20241012-git"; + asds = [ "cl-sat.minisat.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sat.minisat/2024-10-12/cl-sat.minisat-20241012-git.tgz"; + sha256 = "00h5smjs60r1abq27w2ayg55ypsw32769pkk72mrikyn29r6z9ni"; + system = "cl-sat.minisat.test"; + asd = "cl-sat.minisat.test"; + } + ); + systems = [ "cl-sat.minisat.test" ]; + lispLibs = [ + (getAttr "cl-sat_dot_minisat" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sat_dot_test = ( + build-asdf-system { + pname = "cl-sat.test"; + version = "20220707-git"; + asds = [ "cl-sat.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sat/2022-07-07/cl-sat-20220707-git.tgz"; + sha256 = "1fcvxpmja757vyyhcpb00g150dyx90jsg9z8s596vy1nb0z81f49"; + system = "cl-sat.test"; + asd = "cl-sat.test"; + } + ); + systems = [ "cl-sat.test" ]; + lispLibs = [ + (getAttr "cl-sat" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-scram = ( + build-asdf-system { + pname = "cl-scram"; + version = "20150923-git"; + asds = [ "cl-scram" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-scram/2015-09-23/cl-scram-20150923-git.tgz"; + sha256 = "1absr9h9z79f1fbs4g33y2rc9jsqjs7vd2l5sl8dvqq4fyx8v6g0"; + system = "cl-scram"; + asd = "cl-scram"; + } + ); + systems = [ "cl-scram" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "cl-sasl" self) + (getAttr "ironclad" self) + (getAttr "secure-random" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-scribd = ( + build-asdf-system { + pname = "cl-scribd"; + version = "20130312-git"; + asds = [ "cl-scribd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-scribd/2013-03-12/cl-scribd-20130312-git.tgz"; + sha256 = "0r4ah3f1ndi66bm1mir3ldl31sfbmav0kdfpb16f1n9931452mry"; + system = "cl-scribd"; + asd = "cl-scribd"; + } + ); + systems = [ "cl-scribd" ]; + lispLibs = [ + (getAttr "cxml" self) + (getAttr "drakma" self) + (getAttr "ironclad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-scripting = ( + build-asdf-system { + pname = "cl-scripting"; + version = "20211020-git"; + asds = [ "cl-scripting" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-scripting/2021-10-20/cl-scripting-20211020-git.tgz"; + sha256 = "1xi8klkn4fhmcrnhxzxvl0rj68dc7az6l2hc10560g9jvblcmmpp"; + system = "cl-scripting"; + asd = "cl-scripting"; + } + ); + systems = [ "cl-scripting" ]; + lispLibs = [ + (getAttr "cl-launch" self) + (getAttr "fare-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-scrobbler = ( + build-asdf-system { + pname = "cl-scrobbler"; + version = "20111105-git"; + asds = [ "cl-scrobbler" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-scrobbler/2011-11-05/cl-scrobbler-20111105-git.tgz"; + sha256 = "0cd0zfmhxf5chcg7hncavfjr8m06cjbiyqylk76z8mprdsv1n062"; + system = "cl-scrobbler"; + asd = "cl-scrobbler"; + } + ); + systems = [ "cl-scrobbler" ]; + lispLibs = [ + (getAttr "arnesi" self) + (getAttr "cl-store" self) + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + (getAttr "md5" self) + (getAttr "st-json" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-scrobbler-tests = ( + build-asdf-system { + pname = "cl-scrobbler-tests"; + version = "20111105-git"; + asds = [ "cl-scrobbler-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-scrobbler/2011-11-05/cl-scrobbler-20111105-git.tgz"; + sha256 = "0cd0zfmhxf5chcg7hncavfjr8m06cjbiyqylk76z8mprdsv1n062"; + system = "cl-scrobbler-tests"; + asd = "cl-scrobbler"; + } + ); + systems = [ "cl-scrobbler-tests" ]; + lispLibs = [ + (getAttr "cl-scrobbler" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-scsu = ( + build-asdf-system { + pname = "cl-scsu"; + version = "20221106-git"; + asds = [ "cl-scsu" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-scsu/2022-11-06/cl-scsu-20221106-git.tgz"; + sha256 = "0jiqyayflyyrdks4yl894vzw2bkxkd87w4sy4n6ikjz450xk3yxf"; + system = "cl-scsu"; + asd = "cl-scsu"; + } + ); + systems = [ "cl-scsu" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-scsu-test = ( + build-asdf-system { + pname = "cl-scsu-test"; + version = "20221106-git"; + asds = [ "cl-scsu-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-scsu/2022-11-06/cl-scsu-20221106-git.tgz"; + sha256 = "0jiqyayflyyrdks4yl894vzw2bkxkd87w4sy4n6ikjz450xk3yxf"; + system = "cl-scsu-test"; + asd = "cl-scsu-test"; + } + ); + systems = [ "cl-scsu-test" ]; + lispLibs = [ + (getAttr "_1am" self) + (getAttr "alexandria" self) + (getAttr "cl-scsu" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-selenium = ( + build-asdf-system { + pname = "cl-selenium"; + version = "20180328-git"; + asds = [ "cl-selenium" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-selenium-webdriver/2018-03-28/cl-selenium-webdriver-20180328-git.tgz"; + sha256 = "0216vqg1ax5gcqahclii7ifqpc92rbi86rfcf1qn8bdahmfjccbb"; + system = "cl-selenium"; + asd = "cl-selenium"; + } + ); + systems = [ "cl-selenium" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-json" self) + (getAttr "dexador" self) + (getAttr "quri" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-selenium-test = ( + build-asdf-system { + pname = "cl-selenium-test"; + version = "20180328-git"; + asds = [ "cl-selenium-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-selenium-webdriver/2018-03-28/cl-selenium-webdriver-20180328-git.tgz"; + sha256 = "0216vqg1ax5gcqahclii7ifqpc92rbi86rfcf1qn8bdahmfjccbb"; + system = "cl-selenium-test"; + asd = "cl-selenium-test"; + } + ); + systems = [ "cl-selenium-test" ]; + lispLibs = [ + (getAttr "cl-selenium" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-semver = ( + build-asdf-system { + pname = "cl-semver"; + version = "20230618-git"; + asds = [ "cl-semver" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-semver/2023-06-18/cl-semver-20230618-git.tgz"; + sha256 = "1zlcn7lrpvjiixgqm4yxnqqwak1hxfmxmchkpvrly41yhl586ril"; + system = "cl-semver"; + asd = "cl-semver"; + } + ); + systems = [ "cl-semver" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "esrap" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-semver-test = ( + build-asdf-system { + pname = "cl-semver-test"; + version = "20230618-git"; + asds = [ "cl-semver-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-semver/2023-06-18/cl-semver-20230618-git.tgz"; + sha256 = "1zlcn7lrpvjiixgqm4yxnqqwak1hxfmxmchkpvrly41yhl586ril"; + system = "cl-semver-test"; + asd = "cl-semver-test"; + } + ); + systems = [ "cl-semver-test" ]; + lispLibs = [ + (getAttr "cl-semver" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sentiment = ( + build-asdf-system { + pname = "cl-sentiment"; + version = "20130128-git"; + asds = [ "cl-sentiment" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sentiment/2013-01-28/cl-sentiment-20130128-git.tgz"; + sha256 = "18jx6ivbzcg9bsmp1pmlqvzr4kfxzll75b4viz1hrkq78nsnpp5v"; + system = "cl-sentiment"; + asd = "cl-sentiment"; + } + ); + systems = [ "cl-sentiment" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "rt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-server-manager = ( + build-asdf-system { + pname = "cl-server-manager"; + version = "20231021-git"; + asds = [ "cl-server-manager" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-server-manager/2023-10-21/cl-server-manager-20231021-git.tgz"; + sha256 = "0vrdn9iiwmx2zg7lrw56dqjaxbb9fvn4107qxgp3n3z8zxhiw03s"; + system = "cl-server-manager"; + asd = "cl-server-manager"; + } + ); + systems = [ "cl-server-manager" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "hunchentoot" self) + (getAttr "prepl" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ses4 = ( + build-asdf-system { + pname = "cl-ses4"; + version = "20221106-git"; + asds = [ "cl-ses4" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ses4/2022-11-06/cl-ses4-20221106-git.tgz"; + sha256 = "1n31k81i19hx26h9wcz39fsciq92hbblnbd15krblx9g877a1598"; + system = "cl-ses4"; + asd = "cl-ses4"; + } + ); + systems = [ "cl-ses4" ]; + lispLibs = [ + (getAttr "arrow-macros" self) + (getAttr "cl-base64" self) + (getAttr "cl-ppcre" self) + (getAttr "dexador" self) + (getAttr "ironclad" self) + (getAttr "local-time" self) + (getAttr "quickapp" self) + (getAttr "quri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-setlocale = ( + build-asdf-system { + pname = "cl-setlocale"; + version = "20201220-git"; + asds = [ "cl-setlocale" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-setlocale/2020-12-20/cl-setlocale-20201220-git.tgz"; + sha256 = "0g1b89yj6n42ayf2074krk3h9yvglqxn54a6i3sxgpsqww2ll2a1"; + system = "cl-setlocale"; + asd = "cl-setlocale"; + } + ); + systems = [ "cl-setlocale" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sha1 = ( + build-asdf-system { + pname = "cl-sha1"; + version = "20210807-git"; + asds = [ "cl-sha1" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sha1/2021-08-07/cl-sha1-20210807-git.tgz"; + sha256 = "16hczcr7ghah0p9fi29ddrw5c4zbb2d4765iigfx7yrgk5z5jb8p"; + system = "cl-sha1"; + asd = "cl-sha1"; + } + ); + systems = [ "cl-sha1" ]; + lispLibs = [ (getAttr "cl-base64" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-shellwords = ( + build-asdf-system { + pname = "cl-shellwords"; + version = "20150923-git"; + asds = [ "cl-shellwords" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-shellwords/2015-09-23/cl-shellwords-20150923-git.tgz"; + sha256 = "0im8cni1ig5zaha9gbmma7zk1xxa4xajvzfgalvl2f0fhvksl4pn"; + system = "cl-shellwords"; + asd = "cl-shellwords"; + } + ); + systems = [ "cl-shellwords" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { }; + } + ); + cl-shellwords-test = ( + build-asdf-system { + pname = "cl-shellwords-test"; + version = "20150923-git"; + asds = [ "cl-shellwords-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-shellwords/2015-09-23/cl-shellwords-20150923-git.tgz"; + sha256 = "0im8cni1ig5zaha9gbmma7zk1xxa4xajvzfgalvl2f0fhvksl4pn"; + system = "cl-shellwords-test"; + asd = "cl-shellwords-test"; + } + ); + systems = [ "cl-shellwords-test" ]; + lispLibs = [ + (getAttr "cl-shellwords" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-simple-concurrent-jobs = ( + build-asdf-system { + pname = "cl-simple-concurrent-jobs"; + version = "20150505-git"; + asds = [ "cl-simple-concurrent-jobs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-simple-concurrent-jobs/2015-05-05/cl-simple-concurrent-jobs-20150505-git.tgz"; + sha256 = "0mv7svsil58h8v8kq9965bpbradmhfpyrmi61dbzp5mbw8c5mrwj"; + system = "cl-simple-concurrent-jobs"; + asd = "cl-simple-concurrent-jobs"; + } + ); + systems = [ "cl-simple-concurrent-jobs" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "chanl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-simple-table = ( + build-asdf-system { + pname = "cl-simple-table"; + version = "20130312-git"; + asds = [ "cl-simple-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-simple-table/2013-03-12/cl-simple-table-20130312-git.tgz"; + sha256 = "1pnczi5hbqlyxxvzlpy6vc58qc9hh9mdm5rgq304bp3v2qajh0b7"; + system = "cl-simple-table"; + asd = "cl-simple-table"; + } + ); + systems = [ "cl-simple-table" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-singleton-mixin = ( + build-asdf-system { + pname = "cl-singleton-mixin"; + version = "20150505-git"; + asds = [ "cl-singleton-mixin" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-singleton-mixin/2015-05-05/cl-singleton-mixin-20150505-git.tgz"; + sha256 = "10dvwzx1kw9ac163i6sc8yfg3hpkn0dlq4hf6qipb46b4mcib01s"; + system = "cl-singleton-mixin"; + asd = "cl-singleton-mixin"; + } + ); + systems = [ "cl-singleton-mixin" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "metap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-singleton-mixin-test = ( + build-asdf-system { + pname = "cl-singleton-mixin-test"; + version = "20150505-git"; + asds = [ "cl-singleton-mixin-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-singleton-mixin/2015-05-05/cl-singleton-mixin-20150505-git.tgz"; + sha256 = "10dvwzx1kw9ac163i6sc8yfg3hpkn0dlq4hf6qipb46b4mcib01s"; + system = "cl-singleton-mixin-test"; + asd = "cl-singleton-mixin-test"; + } + ); + systems = [ "cl-singleton-mixin-test" ]; + lispLibs = [ + (getAttr "cl-singleton-mixin" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-skip-list = ( + build-asdf-system { + pname = "cl-skip-list"; + version = "20220707-git"; + asds = [ "cl-skip-list" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-skip-list/2022-07-07/cl-skip-list-20220707-git.tgz"; + sha256 = "1k3hbi9n1yzky3hjcg48jkkkp2jx5vm7bsywhnyyb1z6hz5phakd"; + system = "cl-skip-list"; + asd = "cl-skip-list"; + } + ); + systems = [ "cl-skip-list" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-skkserv = ( + build-asdf-system { + pname = "cl-skkserv"; + version = "20241012-git"; + asds = [ "cl-skkserv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-skkserv/2024-10-12/cl-skkserv-20241012-git.tgz"; + sha256 = "1fnar6iw6hr5w37sc96zk9kdcgam8bm71l26l7c6f5daxk57labi"; + system = "cl-skkserv"; + asd = "cl-skkserv"; + } + ); + systems = [ "cl-skkserv" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "esrap" self) + (getAttr "flexi-streams" self) + (getAttr "jp-numeral" self) + (getAttr "named-readtables" self) + (getAttr "papyrus" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-slice = ( + build-asdf-system { + pname = "cl-slice"; + version = "20210531-git"; + asds = [ "cl-slice" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-slice/2021-05-31/cl-slice-20210531-git.tgz"; + sha256 = "1ybznf4y5lda6bn163jcvj281qzhm24dfcwhbgxmm5n6f27gdccl"; + system = "cl-slice"; + asd = "cl-slice"; + } + ); + systems = [ "cl-slice" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "let-plus" self) + ]; + meta = { }; + } + ); + cl-slice-tests = ( + build-asdf-system { + pname = "cl-slice-tests"; + version = "20210531-git"; + asds = [ "cl-slice-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-slice/2021-05-31/cl-slice-20210531-git.tgz"; + sha256 = "1ybznf4y5lda6bn163jcvj281qzhm24dfcwhbgxmm5n6f27gdccl"; + system = "cl-slice-tests"; + asd = "cl-slice"; + } + ); + systems = [ "cl-slice-tests" ]; + lispLibs = [ + (getAttr "cl-slice" self) + (getAttr "clunit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-slp = ( + build-asdf-system { + pname = "cl-slp"; + version = "20140826-git"; + asds = [ "cl-slp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-slp/2014-08-26/cl-slp-20140826-git.tgz"; + sha256 = "10wfrw6r6w646lzx0nasnfvjpy63icxl8qm4888dpcjc57y1cd1w"; + system = "cl-slp"; + asd = "cl-slp"; + } + ); + systems = [ "cl-slp" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-slug = ( + build-asdf-system { + pname = "cl-slug"; + version = "20180228-git"; + asds = [ "cl-slug" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-slug/2018-02-28/cl-slug-20180228-git.tgz"; + sha256 = "1asdq6xllmsvfw5fky9wblqcx9isac9jrrlkfl7vyxcq1wxrnflx"; + system = "cl-slug"; + asd = "cl-slug"; + } + ); + systems = [ "cl-slug" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-slug-test = ( + build-asdf-system { + pname = "cl-slug-test"; + version = "20180228-git"; + asds = [ "cl-slug-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-slug/2018-02-28/cl-slug-20180228-git.tgz"; + sha256 = "1asdq6xllmsvfw5fky9wblqcx9isac9jrrlkfl7vyxcq1wxrnflx"; + system = "cl-slug-test"; + asd = "cl-slug-test"; + } + ); + systems = [ "cl-slug-test" ]; + lispLibs = [ + (getAttr "cl-slug" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-slugify = ( + build-asdf-system { + pname = "cl-slugify"; + version = "20230618-git"; + asds = [ "cl-slugify" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-slugify/2023-06-18/cl-slugify-20230618-git.tgz"; + sha256 = "18vjz9xb8q73j2bd609if2r6svljsnivl3sniz2p7j7w0qppps72"; + system = "cl-slugify"; + asd = "cl-slugify"; + } + ); + systems = [ "cl-slugify" ]; + lispLibs = [ (getAttr "cl-unac" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-slugify_dot_tests = ( + build-asdf-system { + pname = "cl-slugify.tests"; + version = "20230618-git"; + asds = [ "cl-slugify.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-slugify/2023-06-18/cl-slugify-20230618-git.tgz"; + sha256 = "18vjz9xb8q73j2bd609if2r6svljsnivl3sniz2p7j7w0qppps72"; + system = "cl-slugify.tests"; + asd = "cl-slugify.tests"; + } + ); + systems = [ "cl-slugify.tests" ]; + lispLibs = [ + (getAttr "cl-slugify" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-smt-lib = ( + build-asdf-system { + pname = "cl-smt-lib"; + version = "20220331-git"; + asds = [ "cl-smt-lib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-smt-lib/2022-03-31/cl-smt-lib-20220331-git.tgz"; + sha256 = "09xqpmzd8rmp4dkj6mzwlwnhqk266abqvskz9dm6mr3cnf2r774z"; + system = "cl-smt-lib"; + asd = "cl-smt-lib"; + } + ); + systems = [ "cl-smt-lib" ]; + lispLibs = [ + (getAttr "asdf-package-system" self) + (getAttr "named-readtables" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + cl-smtp = ( + build-asdf-system { + pname = "cl-smtp"; + version = "20241012-git"; + asds = [ "cl-smtp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-smtp/2024-10-12/cl-smtp-20241012-git.tgz"; + sha256 = "1r4gsklf4p163hn4ylabx7lp5zkz27v6gq3rkyrvwb7qz6sv8ws4"; + system = "cl-smtp"; + asd = "cl-smtp"; + } + ); + systems = [ "cl-smtp" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl_plus_ssl" self) + (getAttr "cl-base64" self) + (getAttr "flexi-streams" self) + (getAttr "frugal-uuid" self) + (getAttr "usocket" self) + ]; + meta = { }; + } + ); + cl-smtp-tests = ( + build-asdf-system { + pname = "cl-smtp-tests"; + version = "20241012-git"; + asds = [ "cl-smtp-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-smtp/2024-10-12/cl-smtp-20241012-git.tgz"; + sha256 = "1r4gsklf4p163hn4ylabx7lp5zkz27v6gq3rkyrvwb7qz6sv8ws4"; + system = "cl-smtp-tests"; + asd = "cl-smtp-tests"; + } + ); + systems = [ "cl-smtp-tests" ]; + lispLibs = [ (getAttr "cl-smtp" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-soil = ( + build-asdf-system { + pname = "cl-soil"; + version = "release-quicklisp-f27087ce-git"; + asds = [ "cl-soil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-soil/2018-08-31/cl-soil-release-quicklisp-f27087ce-git.tgz"; + sha256 = "0mnz5yaw3kc14ja9g4j7dxh96kd82ifj25gy0dil7kqjd08lwcq9"; + system = "cl-soil"; + asd = "cl-soil"; + } + ); + systems = [ "cl-soil" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-opengl" self) + (getAttr "documentation-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-soloud = ( + build-asdf-system { + pname = "cl-soloud"; + version = "20231021-git"; + asds = [ "cl-soloud" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-soloud/2023-10-21/cl-soloud-20231021-git.tgz"; + sha256 = "0r0z365gcgf93vy8g2nbjwgh5r04gv0l645l2knvip420jxqqp1c"; + system = "cl-soloud"; + asd = "cl-soloud"; + } + ); + systems = [ "cl-soloud" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-mpg123" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-indent" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sophia = ( + build-asdf-system { + pname = "cl-sophia"; + version = "20150608-git"; + asds = [ "cl-sophia" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sophia/2015-06-08/cl-sophia-20150608-git.tgz"; + sha256 = "1x027mr7lg5fs0d82n5mshnd19kan76y3zb9yxbcnq222l4j8j00"; + system = "cl-sophia"; + asd = "cl-sophia"; + } + ); + systems = [ "cl-sophia" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-fad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sophia-test = ( + build-asdf-system { + pname = "cl-sophia-test"; + version = "20150608-git"; + asds = [ "cl-sophia-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sophia/2015-06-08/cl-sophia-20150608-git.tgz"; + sha256 = "1x027mr7lg5fs0d82n5mshnd19kan76y3zb9yxbcnq222l4j8j00"; + system = "cl-sophia-test"; + asd = "cl-sophia"; + } + ); + systems = [ "cl-sophia-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "cl-sophia" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-spark = ( + build-asdf-system { + pname = "cl-spark"; + version = "20150709-git"; + asds = [ "cl-spark" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-spark/2015-07-09/cl-spark-20150709-git.tgz"; + sha256 = "0my1fsgi2rjaqkpk934f2bjy63pmnj7faza3fzvnk6k3l66y19nk"; + system = "cl-spark"; + asd = "cl-spark"; + } + ); + systems = [ "cl-spark" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-spark-test = ( + build-asdf-system { + pname = "cl-spark-test"; + version = "20150709-git"; + asds = [ "cl-spark-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-spark/2015-07-09/cl-spark-20150709-git.tgz"; + sha256 = "0my1fsgi2rjaqkpk934f2bjy63pmnj7faza3fzvnk6k3l66y19nk"; + system = "cl-spark-test"; + asd = "cl-spark-test"; + } + ); + systems = [ "cl-spark-test" ]; + lispLibs = [ + (getAttr "cl-spark" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sparql = ( + build-asdf-system { + pname = "cl-sparql"; + version = "20220331-git"; + asds = [ "cl-sparql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sparql/2022-03-31/cl-sparql-20220331-git.tgz"; + sha256 = "1fjp5a25yly3l3pg07gzhz8q830fcaz0dwspigw8v90sx4insz0p"; + system = "cl-sparql"; + asd = "cl-sparql"; + } + ); + systems = [ "cl-sparql" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "parser-combinators" self) + (getAttr "puri" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sparql-tests = ( + build-asdf-system { + pname = "cl-sparql-tests"; + version = "20220331-git"; + asds = [ "cl-sparql-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sparql/2022-03-31/cl-sparql-20220331-git.tgz"; + sha256 = "1fjp5a25yly3l3pg07gzhz8q830fcaz0dwspigw8v90sx4insz0p"; + system = "cl-sparql-tests"; + asd = "cl-sparql-tests"; + } + ); + systems = [ "cl-sparql-tests" ]; + lispLibs = [ + (getAttr "cl-sparql" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-speedy-queue = ( + build-asdf-system { + pname = "cl-speedy-queue"; + version = "20150302-git"; + asds = [ "cl-speedy-queue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-speedy-queue/2015-03-02/cl-speedy-queue-20150302-git.tgz"; + sha256 = "0czhnvxn9lvbjz9h1lb7y18nqrsq3drq5icd3lqdaa07362alriq"; + system = "cl-speedy-queue"; + asd = "cl-speedy-queue"; + } + ); + systems = [ "cl-speedy-queue" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-spidev = ( + build-asdf-system { + pname = "cl-spidev"; + version = "20231021-git"; + asds = [ "cl-spidev" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-spidev/2023-10-21/cl-spidev-20231021-git.tgz"; + sha256 = "1dhh6hb2myw8p04psdhdjmikl02r66szpg70yapgyqpycb9yg0l3"; + system = "cl-spidev"; + asd = "cl-spidev"; + } + ); + systems = [ "cl-spidev" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ssdb = ( + build-asdf-system { + pname = "cl-ssdb"; + version = "20210124-git"; + asds = [ "cl-ssdb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ssdb/2021-01-24/cl-ssdb-20210124-git.tgz"; + sha256 = "05l0wg4a1kxgggmg1nalq811by76lja0gpa2c4i999h74bf4n3dc"; + system = "cl-ssdb"; + asd = "cl-ssdb"; + } + ); + systems = [ "cl-ssdb" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "parse-number" self) + (getAttr "rutils" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ssdb-test = ( + build-asdf-system { + pname = "cl-ssdb-test"; + version = "20210124-git"; + asds = [ "cl-ssdb-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ssdb/2021-01-24/cl-ssdb-20210124-git.tgz"; + sha256 = "05l0wg4a1kxgggmg1nalq811by76lja0gpa2c4i999h74bf4n3dc"; + system = "cl-ssdb-test"; + asd = "cl-ssdb-test"; + } + ); + systems = [ "cl-ssdb-test" ]; + lispLibs = [ + (getAttr "cl-ssdb" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ssh-keys = ( + build-asdf-system { + pname = "cl-ssh-keys"; + version = "20241012-git"; + asds = [ "cl-ssh-keys" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ssh-keys/2024-10-12/cl-ssh-keys-20241012-git.tgz"; + sha256 = "037j89fjjrld46m9j71x6zfixdm7irwd58c08j0gq6w09qjlk5l2"; + system = "cl-ssh-keys"; + asd = "cl-ssh-keys"; + } + ); + systems = [ "cl-ssh-keys" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-base64" self) + (getAttr "cl-rfc4251" self) + (getAttr "ironclad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-ssh-keys_dot_test = ( + build-asdf-system { + pname = "cl-ssh-keys.test"; + version = "20241012-git"; + asds = [ "cl-ssh-keys.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ssh-keys/2024-10-12/cl-ssh-keys-20241012-git.tgz"; + sha256 = "037j89fjjrld46m9j71x6zfixdm7irwd58c08j0gq6w09qjlk5l2"; + system = "cl-ssh-keys.test"; + asd = "cl-ssh-keys.test"; + } + ); + systems = [ "cl-ssh-keys.test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ssh-keys" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-statsd = ( + build-asdf-system { + pname = "cl-statsd"; + version = "20170124-git"; + asds = [ "cl-statsd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-statsd/2017-01-24/cl-statsd-20170124-git.tgz"; + sha256 = "1l2sxbzhp7wwalxn8k0k1gis9c9w462fygfw4ps0s1bnhgbvr6qb"; + system = "cl-statsd"; + asd = "cl-statsd"; + } + ); + systems = [ "cl-statsd" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-interpol" self) + (getAttr "local-time" self) + (getAttr "log4cl" self) + (getAttr "safe-queue" self) + (getAttr "trivial-utf-8" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-statsd_dot_test = ( + build-asdf-system { + pname = "cl-statsd.test"; + version = "20170124-git"; + asds = [ "cl-statsd.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-statsd/2017-01-24/cl-statsd-20170124-git.tgz"; + sha256 = "1l2sxbzhp7wwalxn8k0k1gis9c9w462fygfw4ps0s1bnhgbvr6qb"; + system = "cl-statsd.test"; + asd = "cl-statsd.test"; + } + ); + systems = [ "cl-statsd.test" ]; + lispLibs = [ + (getAttr "cl-statsd" self) + (getAttr "log4cl" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-steamworks = ( + build-asdf-system { + pname = "cl-steamworks"; + version = "20241012-git"; + asds = [ "cl-steamworks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-steamworks/2024-10-12/cl-steamworks-20241012-git.tgz"; + sha256 = "0401gfmzcc29pm15yyl0p36id0yza2i02wixma2zl8ah3cxb39w5"; + system = "cl-steamworks"; + asd = "cl-steamworks"; + } + ); + systems = [ "cl-steamworks" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "float-features" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-steamworks-generator = ( + build-asdf-system { + pname = "cl-steamworks-generator"; + version = "20241012-git"; + asds = [ "cl-steamworks-generator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-steamworks/2024-10-12/cl-steamworks-20241012-git.tgz"; + sha256 = "0401gfmzcc29pm15yyl0p36id0yza2i02wixma2zl8ah3cxb39w5"; + system = "cl-steamworks-generator"; + asd = "cl-steamworks-generator"; + } + ); + systems = [ "cl-steamworks-generator" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + (getAttr "parse-number" self) + (getAttr "pathname-utils" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-stomp = ( + build-asdf-system { + pname = "cl-stomp"; + version = "20200925-git"; + asds = [ "cl-stomp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-stomp/2020-09-25/cl-stomp-20200925-git.tgz"; + sha256 = "180y0x53ghsvz6n0bz67aw69p962bsslarikk89rf41kcv998xvw"; + system = "cl-stomp"; + asd = "cl-stomp"; + } + ); + systems = [ "cl-stomp" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-stopwatch = ( + build-asdf-system { + pname = "cl-stopwatch"; + version = "20230618-git"; + asds = [ "cl-stopwatch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-stopwatch/2023-06-18/cl-stopwatch-20230618-git.tgz"; + sha256 = "14jmylqk1kijbhhn897r76ii4xg32k22p4v7h29jbcs9y2mn2day"; + system = "cl-stopwatch"; + asd = "cl-stopwatch"; + } + ); + systems = [ "cl-stopwatch" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-store = ( + build-asdf-system { + pname = "cl-store"; + version = "20230214-git"; + asds = [ "cl-store" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-store/2023-02-14/cl-store-20230214-git.tgz"; + sha256 = "1kw39lmbiaksrxsq8pf5np8vjarymcvlc451z83275194av3imix"; + system = "cl-store"; + asd = "cl-store"; + } + ); + systems = [ "cl-store" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-store-tests = ( + build-asdf-system { + pname = "cl-store-tests"; + version = "20230214-git"; + asds = [ "cl-store-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-store/2023-02-14/cl-store-20230214-git.tgz"; + sha256 = "1kw39lmbiaksrxsq8pf5np8vjarymcvlc451z83275194av3imix"; + system = "cl-store-tests"; + asd = "cl-store"; + } + ); + systems = [ "cl-store-tests" ]; + lispLibs = [ + (getAttr "cl-store" self) + (getAttr "rt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-stream = ( + build-asdf-system { + pname = "cl-stream"; + version = "20190521-git"; + asds = [ "cl-stream" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-stream/2019-05-21/cl-stream-20190521-git.tgz"; + sha256 = "1r2spbcx3ifz51yq2pxkdb1n2k5fvyg3pz3w42mnw99pq78cbasv"; + system = "cl-stream"; + asd = "cl-stream"; + } + ); + systems = [ "cl-stream" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-strftime = ( + build-asdf-system { + pname = "cl-strftime"; + version = "20160318-git"; + asds = [ "cl-strftime" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-strftime/2016-03-18/cl-strftime-20160318-git.tgz"; + sha256 = "00c8hq7vzgb89ab3q7mrp60x743kiqmsk1g51ynhxlqhph2bnslf"; + system = "cl-strftime"; + asd = "cl-strftime"; + } + ); + systems = [ "cl-strftime" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "local-time" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-string-complete = ( + build-asdf-system { + pname = "cl-string-complete"; + version = "20230618-git"; + asds = [ "cl-string-complete" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-string-complete/2023-06-18/cl-string-complete-20230618-git.tgz"; + sha256 = "14l1yyz5fakz5xn31yjfn4mz7j9rcbijw1sp4mdfizfvjbbwcixl"; + system = "cl-string-complete"; + asd = "cl-string-complete"; + } + ); + systems = [ "cl-string-complete" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-string-generator = ( + build-asdf-system { + pname = "cl-string-generator"; + version = "20210630-git"; + asds = [ "cl-string-generator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-string-generator/2021-06-30/cl-string-generator-20210630-git.tgz"; + sha256 = "0zm6lyzd205lw30fdvnhrrlv9fylpfqksqxl32zvj9vzcn8qc1vi"; + system = "cl-string-generator"; + asd = "cl-string-generator"; + } + ); + systems = [ "cl-string-generator" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-string-match = ( + build-asdf-system { + pname = "cl-string-match"; + version = "20211209-git"; + asds = [ "cl-string-match" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-string-match/2021-12-09/cl-string-match-20211209-git.tgz"; + sha256 = "0zndlkw3qy3vw4px4qv884z6232w8zfaliyc88irjwizdv35wcq9"; + system = "cl-string-match"; + asd = "cl-string-match"; + } + ); + systems = [ "cl-string-match" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "ascii-strings" self) + (getAttr "iterate" self) + (getAttr "jpl-queues" self) + (getAttr "mgl-pax" self) + (getAttr "yacc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-string-match-test = ( + build-asdf-system { + pname = "cl-string-match-test"; + version = "20211209-git"; + asds = [ "cl-string-match-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-string-match/2021-12-09/cl-string-match-20211209-git.tgz"; + sha256 = "0zndlkw3qy3vw4px4qv884z6232w8zfaliyc88irjwizdv35wcq9"; + system = "cl-string-match-test"; + asd = "cl-string-match-test"; + } + ); + systems = [ "cl-string-match-test" ]; + lispLibs = [ + (getAttr "ascii-strings" self) + (getAttr "cl-string-match" self) + (getAttr "lisp-unit" self) + (getAttr "simple-scanf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-strings = ( + build-asdf-system { + pname = "cl-strings"; + version = "20210411-git"; + asds = [ "cl-strings" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-strings/2021-04-11/cl-strings-20210411-git.tgz"; + sha256 = "1j8hs54fn0wsf5zfzhhgiva47n9hsmfa74iinahz6nmcs8iy75aj"; + system = "cl-strings"; + asd = "cl-strings"; + } + ); + systems = [ "cl-strings" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-strings-tests = ( + build-asdf-system { + pname = "cl-strings-tests"; + version = "20210411-git"; + asds = [ "cl-strings-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-strings/2021-04-11/cl-strings-20210411-git.tgz"; + sha256 = "1j8hs54fn0wsf5zfzhhgiva47n9hsmfa74iinahz6nmcs8iy75aj"; + system = "cl-strings-tests"; + asd = "cl-strings"; + } + ); + systems = [ "cl-strings-tests" ]; + lispLibs = [ + (getAttr "cl-strings" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-svg = ( + build-asdf-system { + pname = "cl-svg"; + version = "20241012-git"; + asds = [ "cl-svg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-svg/2024-10-12/cl-svg-20241012-git.tgz"; + sha256 = "05zrg6sxi01xn940c7lygfgxwjkq0zmlkihbhm7lhfaszg2xj8bh"; + system = "cl-svg"; + asd = "cl-svg"; + } + ); + systems = [ "cl-svg" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-svm = ( + build-asdf-system { + pname = "cl-svm"; + version = "20110418-git"; + asds = [ "cl-svm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-svm/2011-04-18/cl-svm-20110418-git.tgz"; + sha256 = "03d070k3bl5c0b2f6bzig5gkhlj074v74f7kg8hh3znrbmwji2wv"; + system = "cl-svm"; + asd = "cl-svm"; + } + ); + systems = [ "cl-svm" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-swagger = ( + build-asdf-system { + pname = "cl-swagger"; + version = "20180831-git"; + asds = [ "cl-swagger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-swagger-codegen/2018-08-31/cl-swagger-codegen-20180831-git.tgz"; + sha256 = "1lkp69n7wscyf2az3h2bmxmvzzppdfxcq5s0m607b1f7nfmxzjsq"; + system = "cl-swagger"; + asd = "cl-swagger"; + } + ); + systems = [ "cl-swagger" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "cl-mustache" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sxml = ( + build-asdf-system { + pname = "cl-sxml"; + version = "20200325-git"; + asds = [ "cl-sxml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sxml/2020-03-25/cl-sxml-20200325-git.tgz"; + sha256 = "1105s9whidq1lf0lli2wdhcfcs5gwzxa0h1x3izx4mp2p7psvciz"; + system = "cl-sxml"; + asd = "cl-sxml"; + } + ); + systems = [ "cl-sxml" ]; + lispLibs = [ (getAttr "cxml" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-sxml-test = ( + build-asdf-system { + pname = "cl-sxml-test"; + version = "20200325-git"; + asds = [ "cl-sxml-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sxml/2020-03-25/cl-sxml-20200325-git.tgz"; + sha256 = "1105s9whidq1lf0lli2wdhcfcs5gwzxa0h1x3izx4mp2p7psvciz"; + system = "cl-sxml-test"; + asd = "cl-sxml"; + } + ); + systems = [ "cl-sxml-test" ]; + lispLibs = [ + (getAttr "cl-sxml" self) + (getAttr "fiveam" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-syntax = ( + build-asdf-system { + pname = "cl-syntax"; + version = "20150407-git"; + asds = [ "cl-syntax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; + sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; + system = "cl-syntax"; + asd = "cl-syntax"; + } + ); + systems = [ "cl-syntax" ]; + lispLibs = [ + (getAttr "named-readtables" self) + (getAttr "trivial-types" self) + ]; + meta = { }; + } + ); + cl-syntax-annot = ( + build-asdf-system { + pname = "cl-syntax-annot"; + version = "20150407-git"; + asds = [ "cl-syntax-annot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; + sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; + system = "cl-syntax-annot"; + asd = "cl-syntax-annot"; + } + ); + systems = [ "cl-syntax-annot" ]; + lispLibs = [ + (getAttr "cl-annot" self) + (getAttr "cl-syntax" self) + ]; + meta = { }; + } + ); + cl-syntax-anonfun = ( + build-asdf-system { + pname = "cl-syntax-anonfun"; + version = "20150407-git"; + asds = [ "cl-syntax-anonfun" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; + sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; + system = "cl-syntax-anonfun"; + asd = "cl-syntax-anonfun"; + } + ); + systems = [ "cl-syntax-anonfun" ]; + lispLibs = [ + (getAttr "cl-anonfun" self) + (getAttr "cl-syntax" self) + ]; + meta = { }; + } + ); + cl-syntax-clsql = ( + build-asdf-system { + pname = "cl-syntax-clsql"; + version = "20150407-git"; + asds = [ "cl-syntax-clsql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; + sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; + system = "cl-syntax-clsql"; + asd = "cl-syntax-clsql"; + } + ); + systems = [ "cl-syntax-clsql" ]; + lispLibs = [ + (getAttr "cl-syntax" self) + (getAttr "clsql" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-syntax-debug-print = ( + build-asdf-system { + pname = "cl-syntax-debug-print"; + version = "20210807-git"; + asds = [ "cl-syntax-debug-print" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-debug-print/2021-08-07/cl-debug-print-20210807-git.tgz"; + sha256 = "1cm5nybmv0pq9s4lrwhd01rjj1wlcj1sjcrcakabi7w7b5zw4cyh"; + system = "cl-syntax-debug-print"; + asd = "cl-syntax-debug-print"; + } + ); + systems = [ "cl-syntax-debug-print" ]; + lispLibs = [ + (getAttr "cl-debug-print" self) + (getAttr "cl-syntax" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-syntax-fare-quasiquote = ( + build-asdf-system { + pname = "cl-syntax-fare-quasiquote"; + version = "20150407-git"; + asds = [ "cl-syntax-fare-quasiquote" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; + sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; + system = "cl-syntax-fare-quasiquote"; + asd = "cl-syntax-fare-quasiquote"; + } + ); + systems = [ "cl-syntax-fare-quasiquote" ]; + lispLibs = [ + (getAttr "cl-syntax" self) + (getAttr "fare-quasiquote" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-syntax-interpol = ( + build-asdf-system { + pname = "cl-syntax-interpol"; + version = "20150407-git"; + asds = [ "cl-syntax-interpol" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; + sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; + system = "cl-syntax-interpol"; + asd = "cl-syntax-interpol"; + } + ); + systems = [ "cl-syntax-interpol" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "cl-syntax" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-syntax-lsx = ( + build-asdf-system { + pname = "cl-syntax-lsx"; + version = "20220220-git"; + asds = [ "cl-syntax-lsx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lsx/2022-02-20/lsx-20220220-git.tgz"; + sha256 = "1pdq6csr8pkzcq2zkhhm6wkp9zxx2aypjd16rcw4q43mff09y041"; + system = "cl-syntax-lsx"; + asd = "cl-syntax-lsx"; + } + ); + systems = [ "cl-syntax-lsx" ]; + lispLibs = [ + (getAttr "cl-syntax" self) + (getAttr "lsx" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-syntax-markup = ( + build-asdf-system { + pname = "cl-syntax-markup"; + version = "20150407-git"; + asds = [ "cl-syntax-markup" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-syntax/2015-04-07/cl-syntax-20150407-git.tgz"; + sha256 = "17ran8xp77asagl31xv8w819wafh6whwfc9p6dgx22ca537gyl4y"; + system = "cl-syntax-markup"; + asd = "cl-syntax-markup"; + } + ); + systems = [ "cl-syntax-markup" ]; + lispLibs = [ + (getAttr "cl-markup" self) + (getAttr "cl-syntax" self) + ]; + meta = { }; + } + ); + cl-syslog = ( + build-asdf-system { + pname = "cl-syslog"; + version = "20190202-git"; + asds = [ "cl-syslog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-syslog/2019-02-02/cl-syslog-20190202-git.tgz"; + sha256 = "1qcz55jiqwk91b01hsahxnha884f6zf2883j2m51sqph0mvj69mh"; + system = "cl-syslog"; + asd = "cl-syslog"; + } + ); + systems = [ "cl-syslog" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "global-vars" self) + (getAttr "local-time" self) + (getAttr "split-sequence" self) + (getAttr "usocket" self) + ]; + meta = { }; + } + ); + cl-table = ( + build-asdf-system { + pname = "cl-table"; + version = "20130128-git"; + asds = [ "cl-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-table/2013-01-28/cl-table-20130128-git.tgz"; + sha256 = "0c7bdnpi473grayycdcdh4q8fi137i3c80k05k87pvjdrl1qnkpn"; + system = "cl-table"; + asd = "cl-table"; + } + ); + systems = [ "cl-table" ]; + lispLibs = [ (getAttr "iterate" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tasukete = ( + build-asdf-system { + pname = "cl-tasukete"; + version = "20180228-git"; + asds = [ "cl-tasukete" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tasukete/2018-02-28/cl-tasukete-20180228-git.tgz"; + sha256 = "0i8ibg2a33mb32vr2b70psb5dvh47r52lfhkh84rxzmcsk6ww230"; + system = "cl-tasukete"; + asd = "cl-tasukete"; + } + ); + systems = [ "cl-tasukete" ]; + lispLibs = [ + (getAttr "cl-annot" self) + (getAttr "cl-gists" self) + (getAttr "dissect" self) + (getAttr "jonathan" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tasukete-test = ( + build-asdf-system { + pname = "cl-tasukete-test"; + version = "20180228-git"; + asds = [ "cl-tasukete-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tasukete/2018-02-28/cl-tasukete-20180228-git.tgz"; + sha256 = "0i8ibg2a33mb32vr2b70psb5dvh47r52lfhkh84rxzmcsk6ww230"; + system = "cl-tasukete-test"; + asd = "cl-tasukete-test"; + } + ); + systems = [ "cl-tasukete-test" ]; + lispLibs = [ + (getAttr "cl-tasukete" self) + (getAttr "dissect" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-telebot = ( + build-asdf-system { + pname = "cl-telebot"; + version = "20211020-git"; + asds = [ "cl-telebot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-telebot/2021-10-20/cl-telebot-20211020-git.tgz"; + sha256 = "0nl002l4f3x6843s6h5w2iz2hganxb369k8c2hbbgqq7plb4mdf1"; + system = "cl-telebot"; + asd = "cl-telebot"; + } + ); + systems = [ "cl-telebot" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "dexador" self) + (getAttr "jonathan" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-telegram-bot = ( + build-asdf-system { + pname = "cl-telegram-bot"; + version = "20241012-git"; + asds = [ "cl-telegram-bot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-telegram-bot/2024-10-12/cl-telegram-bot-20241012-git.tgz"; + sha256 = "1i1g9ax46b5jyx2nckp2q00asb46wwlin0hj5wlqlp7cb27r3dqj"; + system = "cl-telegram-bot"; + asd = "cl-telegram-bot"; + } + ); + systems = [ "cl-telegram-bot" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "alexandria" self) + (getAttr "arrows" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-strings" self) + (getAttr "closer-mop" self) + (getAttr "dexador" self) + (getAttr "jonathan" self) + (getAttr "kebab" self) + (getAttr "log4cl" self) + (getAttr "serapeum" self) + (getAttr "str" self) + (getAttr "trivial-backtrace" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-telegram-bot-ci = ( + build-asdf-system { + pname = "cl-telegram-bot-ci"; + version = "20241012-git"; + asds = [ "cl-telegram-bot-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-telegram-bot/2024-10-12/cl-telegram-bot-20241012-git.tgz"; + sha256 = "1i1g9ax46b5jyx2nckp2q00asb46wwlin0hj5wlqlp7cb27r3dqj"; + system = "cl-telegram-bot-ci"; + asd = "cl-telegram-bot-ci"; + } + ); + systems = [ "cl-telegram-bot-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-telegram-bot-docs = ( + build-asdf-system { + pname = "cl-telegram-bot-docs"; + version = "20241012-git"; + asds = [ "cl-telegram-bot-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-telegram-bot/2024-10-12/cl-telegram-bot-20241012-git.tgz"; + sha256 = "1i1g9ax46b5jyx2nckp2q00asb46wwlin0hj5wlqlp7cb27r3dqj"; + system = "cl-telegram-bot-docs"; + asd = "cl-telegram-bot-docs"; + } + ); + systems = [ "cl-telegram-bot-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "cl-telegram-bot" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-telegram-bot-tests = ( + build-asdf-system { + pname = "cl-telegram-bot-tests"; + version = "20241012-git"; + asds = [ "cl-telegram-bot-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-telegram-bot/2024-10-12/cl-telegram-bot-20241012-git.tgz"; + sha256 = "1i1g9ax46b5jyx2nckp2q00asb46wwlin0hj5wlqlp7cb27r3dqj"; + system = "cl-telegram-bot-tests"; + asd = "cl-telegram-bot-tests"; + } + ); + systems = [ "cl-telegram-bot-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-template = ( + build-asdf-system { + pname = "cl-template"; + version = "20130615-git"; + asds = [ "cl-template" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-template/2013-06-15/cl-template-20130615-git.tgz"; + sha256 = "1rhg023a2nxsk5x6abd6i0a8sh36aj0bgsh80w60m3b7xlsva2x2"; + system = "cl-template"; + asd = "cl-template"; + } + ); + systems = [ "cl-template" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-template-tests = ( + build-asdf-system { + pname = "cl-template-tests"; + version = "20130615-git"; + asds = [ "cl-template-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-template/2013-06-15/cl-template-20130615-git.tgz"; + sha256 = "1rhg023a2nxsk5x6abd6i0a8sh36aj0bgsh80w60m3b7xlsva2x2"; + system = "cl-template-tests"; + asd = "cl-template"; + } + ); + systems = [ "cl-template-tests" ]; + lispLibs = [ + (getAttr "cl-template" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-termbox = ( + build-asdf-system { + pname = "cl-termbox"; + version = "20211020-git"; + asds = [ "cl-termbox" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-termbox/2021-10-20/cl-termbox-20211020-git.tgz"; + sha256 = "1igmq64zndkgchmzggp34jrmxa81dqlhz2il8qizrpfw5a39cpld"; + system = "cl-termbox"; + asd = "cl-termbox"; + } + ); + systems = [ "cl-termbox" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tesseract = ( + build-asdf-system { + pname = "cl-tesseract"; + version = "20171130-git"; + asds = [ "cl-tesseract" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tesseract/2017-11-30/cl-tesseract-20171130-git.tgz"; + sha256 = "086627k8whbj60bpw9r3jrdifr4bigqpnp9hxsi7r6702gixz50x"; + system = "cl-tesseract"; + asd = "cl-tesseract"; + } + ); + systems = [ "cl-tesseract" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-test-more = ( + build-asdf-system { + pname = "cl-test-more"; + version = "20200218-git"; + asds = [ "cl-test-more" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prove/2020-02-18/prove-20200218-git.tgz"; + sha256 = "0ca6ha3zhmckq3ad9lxm6sbg4i0hg3m81xhan4dkxd3x9898jzpc"; + system = "cl-test-more"; + asd = "cl-test-more"; + } + ); + systems = [ "cl-test-more" ]; + lispLibs = [ (getAttr "prove" self) ]; + meta = { }; + } + ); + cl-tetris3d = ( + build-asdf-system { + pname = "cl-tetris3d"; + version = "20181210-git"; + asds = [ "cl-tetris3d" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tetris3d/2018-12-10/cl-tetris3d-20181210-git.tgz"; + sha256 = "09n7344is2vfbp32cd22ynk14h4vqs4xw3plbhga8q25ghhx5y9p"; + system = "cl-tetris3d"; + asd = "cl-tetris3d"; + } + ); + systems = [ "cl-tetris3d" ]; + lispLibs = [ + (getAttr "cl-glu" self) + (getAttr "cl-opengl" self) + (getAttr "iterate" self) + (getAttr "lispbuilder-sdl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-textmagic = ( + build-asdf-system { + pname = "cl-textmagic"; + version = "20151218-git"; + asds = [ "cl-textmagic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-textmagic/2015-12-18/cl-textmagic-20151218-git.tgz"; + sha256 = "0xw6g1r5vxmnbz3kxf2q6s9dr9l2aacyri1wchzw4jx5wlcnkshw"; + system = "cl-textmagic"; + asd = "cl-textmagic"; + } + ); + systems = [ "cl-textmagic" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "dexador" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-textmagic-test = ( + build-asdf-system { + pname = "cl-textmagic-test"; + version = "20151218-git"; + asds = [ "cl-textmagic-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-textmagic/2015-12-18/cl-textmagic-20151218-git.tgz"; + sha256 = "0xw6g1r5vxmnbz3kxf2q6s9dr9l2aacyri1wchzw4jx5wlcnkshw"; + system = "cl-textmagic-test"; + asd = "cl-textmagic-test"; + } + ); + systems = [ "cl-textmagic-test" ]; + lispLibs = [ + (getAttr "cl-textmagic" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tga = ( + build-asdf-system { + pname = "cl-tga"; + version = "20160318-git"; + asds = [ "cl-tga" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tga/2016-03-18/cl-tga-20160318-git.tgz"; + sha256 = "03k3npmn0xd3fd2m7vwxph82av2xrfb150imqrinlzqmzvz1v1br"; + system = "cl-tga"; + asd = "cl-tga"; + } + ); + systems = [ "cl-tga" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-threadpool = ( + build-asdf-system { + pname = "cl-threadpool"; + version = "quickload-current-release-feda6ff9-git"; + asds = [ "cl-threadpool" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-threadpool/2024-10-12/cl-threadpool-quickload-current-release-feda6ff9-git.tgz"; + sha256 = "0y2kai8ijz0y6j54svvdrl2f2v96pz0pl652x86lz7pl4yyg99vr"; + system = "cl-threadpool"; + asd = "cl-threadpool"; + } + ); + systems = [ "cl-threadpool" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "queues_dot_simple-cqueue" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tidy = ( + build-asdf-system { + pname = "cl-tidy"; + version = "20170830-git"; + asds = [ "cl-tidy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tidy/2017-08-30/cl-tidy-20170830-git.tgz"; + sha256 = "13j0jgf6czb24148w2wxfwlji6vnc49qvyr5wzq5ps55b27ddlz6"; + system = "cl-tidy"; + asd = "cl-tidy"; + } + ); + systems = [ "cl-tidy" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tiled = ( + build-asdf-system { + pname = "cl-tiled"; + version = "20241012-git"; + asds = [ "cl-tiled" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tiled/2024-10-12/cl-tiled-20241012-git.tgz"; + sha256 = "0ni61iahr58i44psk4z3q1w9nsxbc49m5wbb8w0icm4f7x0ijn07"; + system = "cl-tiled"; + asd = "cl-tiled"; + } + ); + systems = [ "cl-tiled" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "chipz" self) + (getAttr "cl-base64" self) + (getAttr "cl-json" self) + (getAttr "nibbles" self) + (getAttr "parse-float" self) + (getAttr "split-sequence" self) + (getAttr "xmls" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tk = ( + build-asdf-system { + pname = "cl-tk"; + version = "20150608-git"; + asds = [ "cl-tk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tk/2015-06-08/cl-tk-20150608-git.tgz"; + sha256 = "0fm4q4pkzbyxr6227vavvy4lm7rfw214lp2dylgzjzcp6f5r4n7w"; + system = "cl-tk"; + asd = "cl-tk"; + } + ); + systems = [ "cl-tk" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tld = ( + build-asdf-system { + pname = "cl-tld"; + version = "20220220-git"; + asds = [ "cl-tld" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tld/2022-02-20/cl-tld-20220220-git.tgz"; + sha256 = "1xm471p92in5g4fcxgqshwgr2d7937jw7jv6j473slwkxjvx8dp6"; + system = "cl-tld"; + asd = "cl-tld"; + } + ); + systems = [ "cl-tld" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tls = ( + build-asdf-system { + pname = "cl-tls"; + version = "20231021-git"; + asds = [ "cl-tls" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tls/2023-10-21/cl-tls-20231021-git.tgz"; + sha256 = "1gq7m5wmsrjmyhrk9xljxz9ickahwzl1anz2fcns5q2nj0j6d9bx"; + system = "cl-tls"; + asd = "cl-tls"; + } + ); + systems = [ "cl-tls" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-base64" self) + (getAttr "fast-io" self) + (getAttr "ironclad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tokyo-cabinet = ( + build-asdf-system { + pname = "cl-tokyo-cabinet"; + version = "20160825-git"; + asds = [ "cl-tokyo-cabinet" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tokyo-cabinet/2016-08-25/cl-tokyo-cabinet-20160825-git.tgz"; + sha256 = "07961in8fa09bjnpwkdn0w6dj37nppzmgg50kf8khspnjh1sjsr2"; + system = "cl-tokyo-cabinet"; + asd = "cl-tokyo-cabinet"; + } + ); + systems = [ "cl-tokyo-cabinet" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "deoxybyte-systems" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tokyo-cabinet-test = ( + build-asdf-system { + pname = "cl-tokyo-cabinet-test"; + version = "20160825-git"; + asds = [ "cl-tokyo-cabinet-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tokyo-cabinet/2016-08-25/cl-tokyo-cabinet-20160825-git.tgz"; + sha256 = "07961in8fa09bjnpwkdn0w6dj37nppzmgg50kf8khspnjh1sjsr2"; + system = "cl-tokyo-cabinet-test"; + asd = "cl-tokyo-cabinet-test"; + } + ); + systems = [ "cl-tokyo-cabinet-test" ]; + lispLibs = [ + (getAttr "cl-tokyo-cabinet" self) + (getAttr "deoxybyte-io" self) + (getAttr "deoxybyte-utilities" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-toml = ( + build-asdf-system { + pname = "cl-toml"; + version = "20191130-git"; + asds = [ "cl-toml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-toml/2019-11-30/cl-toml-20191130-git.tgz"; + sha256 = "1g5i60i78s0ms608fyc6sgaaqr6jdsln75n26lmfbcaqw2g1q9dk"; + system = "cl-toml"; + asd = "cl-toml"; + } + ); + systems = [ "cl-toml" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "esrap" self) + (getAttr "local-time" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-toml-test = ( + build-asdf-system { + pname = "cl-toml-test"; + version = "20191130-git"; + asds = [ "cl-toml-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-toml/2019-11-30/cl-toml-20191130-git.tgz"; + sha256 = "1g5i60i78s0ms608fyc6sgaaqr6jdsln75n26lmfbcaqw2g1q9dk"; + system = "cl-toml-test"; + asd = "cl-toml-test"; + } + ); + systems = [ "cl-toml-test" ]; + lispLibs = [ + (getAttr "cl-toml" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tqdm = ( + build-asdf-system { + pname = "cl-tqdm"; + version = "20241012-git"; + asds = [ "cl-tqdm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tqdm/2024-10-12/cl-tqdm-20241012-git.tgz"; + sha256 = "0wlbgs7wfiy149d7zq5bpkm8g3785b1crcf2m802f9qhin2r0nzg"; + system = "cl-tqdm"; + asd = "cl-tqdm"; + } + ); + systems = [ "cl-tqdm" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-transmission = ( + build-asdf-system { + pname = "cl-transmission"; + version = "20200325-git"; + asds = [ "cl-transmission" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-transmission/2020-03-25/cl-transmission-20200325-git.tgz"; + sha256 = "0sg3f2jqs2z3mvscjhc43hkd34vlcc4c8hq8rhh5w1gjg19z57hb"; + system = "cl-transmission"; + asd = "cl-transmission"; + } + ); + systems = [ "cl-transmission" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "jonathan" self) + (getAttr "named-readtables" self) + (getAttr "rutils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-transmission-test = ( + build-asdf-system { + pname = "cl-transmission-test"; + version = "20200325-git"; + asds = [ "cl-transmission-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-transmission/2020-03-25/cl-transmission-20200325-git.tgz"; + sha256 = "0sg3f2jqs2z3mvscjhc43hkd34vlcc4c8hq8rhh5w1gjg19z57hb"; + system = "cl-transmission-test"; + asd = "cl-transmission-test"; + } + ); + systems = [ "cl-transmission-test" ]; + lispLibs = [ + (getAttr "cl-transmission" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-trie = ( + build-asdf-system { + pname = "cl-trie"; + version = "20230214-git"; + asds = [ "cl-trie" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-trie/2023-02-14/cl-trie-20230214-git.tgz"; + sha256 = "0d0mnac9rbqvwr45650yimfw4fyldbgasj139g7y1wzrranrcldf"; + system = "cl-trie"; + asd = "cl-trie"; + } + ); + systems = [ "cl-trie" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-trie-examples = ( + build-asdf-system { + pname = "cl-trie-examples"; + version = "20230214-git"; + asds = [ "cl-trie-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-trie/2023-02-14/cl-trie-20230214-git.tgz"; + sha256 = "0d0mnac9rbqvwr45650yimfw4fyldbgasj139g7y1wzrranrcldf"; + system = "cl-trie-examples"; + asd = "cl-trie-examples"; + } + ); + systems = [ "cl-trie-examples" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cl-trie" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tui = ( + build-asdf-system { + pname = "cl-tui"; + version = "20200427-git"; + asds = [ "cl-tui" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tui/2020-04-27/cl-tui-20200427-git.tgz"; + sha256 = "1s0z7sjb3p1fxypc2x9fl0y094qa1a2iqjbn5him4hs8z7xm5kz8"; + system = "cl-tui"; + asd = "cl-tui"; + } + ); + systems = [ "cl-tui" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cl-charms" self) + (getAttr "cl-containers" self) + (getAttr "osicat" self) + (getAttr "split-sequence" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tulip-graph = ( + build-asdf-system { + pname = "cl-tulip-graph"; + version = "20130615-git"; + asds = [ "cl-tulip-graph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tulip-graph/2013-06-15/cl-tulip-graph-20130615-git.tgz"; + sha256 = "0zmmwqabbyzdikn8x0xqrj192wr5w87l828nwandqg59af2isxav"; + system = "cl-tulip-graph"; + asd = "cl-tulip-graph"; + } + ); + systems = [ "cl-tulip-graph" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-tuples = ( + build-asdf-system { + pname = "cl-tuples"; + version = "20140713-git"; + asds = [ "cl-tuples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tuples/2014-07-13/cl-tuples-20140713-git.tgz"; + sha256 = "060xmr03y8n0mnf4x4fnrirljcjk1jcir7jsjq4w9d5vzq3aqm9m"; + system = "cl-tuples"; + asd = "cl-tuples"; + } + ); + systems = [ "cl-tuples" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-twit-repl = ( + build-asdf-system { + pname = "cl-twit-repl"; + version = "20180228-git"; + asds = [ "cl-twit-repl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-twitter/2018-02-28/cl-twitter-20180228-git.tgz"; + sha256 = "07l86c63ssahpz3s9f7d99mbzmh60askkpdrhjrdbzd1vxlwkhcr"; + system = "cl-twit-repl"; + asd = "cl-twit-repl"; + } + ); + systems = [ "cl-twit-repl" ]; + lispLibs = [ (getAttr "cl-twitter" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-twitter = ( + build-asdf-system { + pname = "cl-twitter"; + version = "20180228-git"; + asds = [ "cl-twitter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-twitter/2018-02-28/cl-twitter-20180228-git.tgz"; + sha256 = "07l86c63ssahpz3s9f7d99mbzmh60askkpdrhjrdbzd1vxlwkhcr"; + system = "cl-twitter"; + asd = "cl-twitter"; + } + ); + systems = [ "cl-twitter" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "cl-json" self) + (getAttr "cl-oauth" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "drakma" self) + (getAttr "trivial-http" self) + (getAttr "url-rewrite" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-typesetting = ( + build-asdf-system { + pname = "cl-typesetting"; + version = "20210531-git"; + asds = [ "cl-typesetting" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-typesetting/2021-05-31/cl-typesetting-20210531-git.tgz"; + sha256 = "0fcs5mq0gxfczbrg7ay8r4bf5r4g6blvpdbjkhcl8dapcikyn35h"; + system = "cl-typesetting"; + asd = "cl-typesetting"; + } + ); + systems = [ "cl-typesetting" ]; + lispLibs = [ (getAttr "cl-pdf" self) ]; + meta = { }; + } + ); + cl-uglify-js = ( + build-asdf-system { + pname = "cl-uglify-js"; + version = "20150709-git"; + asds = [ "cl-uglify-js" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-uglify-js/2015-07-09/cl-uglify-js-20150709-git.tgz"; + sha256 = "0k39y3c93jgxpr7gwz7w0d8yknn1fdnxrjhd03057lvk5w8js27a"; + system = "cl-uglify-js"; + asd = "cl-uglify-js"; + } + ); + systems = [ "cl-uglify-js" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cl-ppcre-unicode" self) + (getAttr "iterate" self) + (getAttr "parse-js" self) + (getAttr "parse-number" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-unac = ( + build-asdf-system { + pname = "cl-unac"; + version = "20230618-git"; + asds = [ "cl-unac" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-unac/2023-06-18/cl-unac-20230618-git.tgz"; + sha256 = "16i4lwg70k05dw3vynyyz09ldgr4zzd1ar68g4jcxk7q4ijfdw9m"; + system = "cl-unac"; + asd = "cl-unac"; + } + ); + systems = [ "cl-unac" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-unac_dot_config" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-unac_dot_config = ( + build-asdf-system { + pname = "cl-unac.config"; + version = "20230618-git"; + asds = [ "cl-unac.config" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-unac/2023-06-18/cl-unac-20230618-git.tgz"; + sha256 = "16i4lwg70k05dw3vynyyz09ldgr4zzd1ar68g4jcxk7q4ijfdw9m"; + system = "cl-unac.config"; + asd = "cl-unac.config"; + } + ); + systems = [ "cl-unac.config" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-unac_dot_tests = ( + build-asdf-system { + pname = "cl-unac.tests"; + version = "20230618-git"; + asds = [ "cl-unac.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-unac/2023-06-18/cl-unac-20230618-git.tgz"; + sha256 = "16i4lwg70k05dw3vynyyz09ldgr4zzd1ar68g4jcxk7q4ijfdw9m"; + system = "cl-unac.tests"; + asd = "cl-unac.tests"; + } + ); + systems = [ "cl-unac.tests" ]; + lispLibs = [ + (getAttr "cl-unac" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-unicode = ( + build-asdf-system { + pname = "cl-unicode"; + version = "20241012-git"; + asds = [ "cl-unicode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-unicode/2024-10-12/cl-unicode-20241012-git.tgz"; + sha256 = "14ydcjkj94mmx40vs27w8137lgmw16jjhpr5m46mm6gqv46yvr6l"; + system = "cl-unicode"; + asd = "cl-unicode"; + } + ); + systems = [ "cl-unicode" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { }; + } + ); + cl-unification = ( + build-asdf-system { + pname = "cl-unification"; + version = "20241012-git"; + asds = [ "cl-unification" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-unification/2024-10-12/cl-unification-20241012-git.tgz"; + sha256 = "1q7bjj9dzazhgj32291rqy4lld1ilrpck374c21864qn3pmz31ag"; + system = "cl-unification"; + asd = "cl-unification"; + } + ); + systems = [ "cl-unification" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-unification-lib = ( + build-asdf-system { + pname = "cl-unification-lib"; + version = "20241012-git"; + asds = [ "cl-unification-lib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-unification/2024-10-12/cl-unification-20241012-git.tgz"; + sha256 = "1q7bjj9dzazhgj32291rqy4lld1ilrpck374c21864qn3pmz31ag"; + system = "cl-unification-lib"; + asd = "cl-unification-lib"; + } + ); + systems = [ "cl-unification-lib" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cl-unification" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-unification-test = ( + build-asdf-system { + pname = "cl-unification-test"; + version = "20241012-git"; + asds = [ "cl-unification-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-unification/2024-10-12/cl-unification-20241012-git.tgz"; + sha256 = "1q7bjj9dzazhgj32291rqy4lld1ilrpck374c21864qn3pmz31ag"; + system = "cl-unification-test"; + asd = "cl-unification-test"; + } + ); + systems = [ "cl-unification-test" ]; + lispLibs = [ + (getAttr "cl-unification" self) + (getAttr "ptester" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-union-find = ( + build-asdf-system { + pname = "cl-union-find"; + version = "20221106-git"; + asds = [ "cl-union-find" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-union-find/2022-11-06/cl-union-find-20221106-git.tgz"; + sha256 = "14xciva5v3c4zi4vzp1vfhs82a2654yhkfyllr3b0cr7x36jdm7y"; + system = "cl-union-find"; + asd = "cl-union-find"; + } + ); + systems = [ "cl-union-find" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-utilities = ( + build-asdf-system { + pname = "cl-utilities"; + version = "1.2.4"; + asds = [ "cl-utilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-utilities/2010-10-06/cl-utilities-1.2.4.tgz"; + sha256 = "1dmbkdr8xm2jw5yx1makqbf1ypqbm0hpkd7zyknxv3cblvz0a87w"; + system = "cl-utilities"; + asd = "cl-utilities"; + } + ); + systems = [ "cl-utilities" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-variates = ( + build-asdf-system { + pname = "cl-variates"; + version = "20180131-darcs"; + asds = [ "cl-variates" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-variates/2018-01-31/cl-variates-20180131-darcs.tgz"; + sha256 = "02pd02isfxrn3h8h5kh369rwy17hfjkmd7j24pcihfskamgcqgfx"; + system = "cl-variates"; + asd = "cl-variates"; + } + ); + systems = [ "cl-variates" ]; + lispLibs = [ (getAttr "asdf-system-connections" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-vectors = ( + build-asdf-system { + pname = "cl-vectors"; + version = "20241012-git"; + asds = [ "cl-vectors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-vectors/2024-10-12/cl-vectors-20241012-git.tgz"; + sha256 = "1nkmmn38y6af10ysff3g2qkf5lb2601dcjp5rffsjh6bv2ik2jd5"; + system = "cl-vectors"; + asd = "cl-vectors"; + } + ); + systems = [ "cl-vectors" ]; + lispLibs = [ + (getAttr "cl-aa" self) + (getAttr "cl-paths" self) + ]; + meta = { }; + } + ); + cl-vhdl = ( + build-asdf-system { + pname = "cl-vhdl"; + version = "20160421-git"; + asds = [ "cl-vhdl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-vhdl/2016-04-21/cl-vhdl-20160421-git.tgz"; + sha256 = "0i2780ljak8kcqa2zm24dk2fk771m2mvmnbq4xd4vvx9z87lbnvi"; + system = "cl-vhdl"; + asd = "cl-vhdl"; + } + ); + systems = [ "cl-vhdl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-interpol" self) + (getAttr "cl-itertools" self) + (getAttr "cl-ppcre" self) + (getAttr "esrap-liquid" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-vhdl-tests = ( + build-asdf-system { + pname = "cl-vhdl-tests"; + version = "20160421-git"; + asds = [ "cl-vhdl-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-vhdl/2016-04-21/cl-vhdl-20160421-git.tgz"; + sha256 = "0i2780ljak8kcqa2zm24dk2fk771m2mvmnbq4xd4vvx9z87lbnvi"; + system = "cl-vhdl-tests"; + asd = "cl-vhdl"; + } + ); + systems = [ "cl-vhdl-tests" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "cl-vhdl" self) + (getAttr "fare-quasiquote-optima" self) + (getAttr "fiveam" self) + (getAttr "optima" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-video = ( + build-asdf-system { + pname = "cl-video"; + version = "20180228-git"; + asds = [ "cl-video" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-video/2018-02-28/cl-video-20180228-git.tgz"; + sha256 = "1azldcp6r0j1kw6rczicmnv4m0d7rq4m5axz48ny6r2qybha80lr"; + system = "cl-video"; + asd = "cl-video"; + } + ); + systems = [ "cl-video" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-video-avi = ( + build-asdf-system { + pname = "cl-video-avi"; + version = "20180228-git"; + asds = [ "cl-video-avi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-video/2018-02-28/cl-video-20180228-git.tgz"; + sha256 = "1azldcp6r0j1kw6rczicmnv4m0d7rq4m5axz48ny6r2qybha80lr"; + system = "cl-video-avi"; + asd = "cl-video-avi"; + } + ); + systems = [ "cl-video-avi" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-jpeg" self) + (getAttr "cl-riff" self) + (getAttr "cl-video" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-video-gif = ( + build-asdf-system { + pname = "cl-video-gif"; + version = "20180228-git"; + asds = [ "cl-video-gif" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-video/2018-02-28/cl-video-20180228-git.tgz"; + sha256 = "1azldcp6r0j1kw6rczicmnv4m0d7rq4m5axz48ny6r2qybha80lr"; + system = "cl-video-gif"; + asd = "cl-video-gif"; + } + ); + systems = [ "cl-video-gif" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-video" self) + (getAttr "skippy" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-video-player = ( + build-asdf-system { + pname = "cl-video-player"; + version = "20180228-git"; + asds = [ "cl-video-player" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-video/2018-02-28/cl-video-20180228-git.tgz"; + sha256 = "1azldcp6r0j1kw6rczicmnv4m0d7rq4m5axz48ny6r2qybha80lr"; + system = "cl-video-player"; + asd = "cl-video-player"; + } + ); + systems = [ "cl-video-player" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-portaudio" self) + (getAttr "cl-video-avi" self) + (getAttr "cl-video-gif" self) + (getAttr "cl-video-wav" self) + (getAttr "clx" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-video-wav = ( + build-asdf-system { + pname = "cl-video-wav"; + version = "20180228-git"; + asds = [ "cl-video-wav" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-video/2018-02-28/cl-video-20180228-git.tgz"; + sha256 = "1azldcp6r0j1kw6rczicmnv4m0d7rq4m5axz48ny6r2qybha80lr"; + system = "cl-video-wav"; + asd = "cl-video-wav"; + } + ); + systems = [ "cl-video-wav" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-riff" self) + (getAttr "cl-video" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-virtualbox = ( + build-asdf-system { + pname = "cl-virtualbox"; + version = "20180831-git"; + asds = [ "cl-virtualbox" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-virtualbox/2018-08-31/cl-virtualbox-20180831-git.tgz"; + sha256 = "1jzn8jjn9yn9vgnn1r6h0iyxb6j17wm8lmf9j5hk4yqwdzb2nidv"; + system = "cl-virtualbox"; + asd = "cl-virtualbox"; + } + ); + systems = [ "cl-virtualbox" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-vorbis = ( + build-asdf-system { + pname = "cl-vorbis"; + version = "20241012-git"; + asds = [ "cl-vorbis" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-vorbis/2024-10-12/cl-vorbis-20241012-git.tgz"; + sha256 = "04p0ix2mxa8iv2dab19mlix6m3inwyb0rs5wsrf8r9l1n41dyp2p"; + system = "cl-vorbis"; + asd = "cl-vorbis"; + } + ); + systems = [ "cl-vorbis" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "static-vectors" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-voxelize = ( + build-asdf-system { + pname = "cl-voxelize"; + version = "20150709-git"; + asds = [ "cl-voxelize" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-voxelize/2015-07-09/cl-voxelize-20150709-git.tgz"; + sha256 = "1sim8n175dgy0i0dxi1vsqzgjx07lgsnrgn3bizzka58ni5y8xdm"; + system = "cl-voxelize"; + asd = "cl-voxelize"; + } + ); + systems = [ "cl-voxelize" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-voxelize-examples = ( + build-asdf-system { + pname = "cl-voxelize-examples"; + version = "20150709-git"; + asds = [ "cl-voxelize-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-voxelize/2015-07-09/cl-voxelize-20150709-git.tgz"; + sha256 = "1sim8n175dgy0i0dxi1vsqzgjx07lgsnrgn3bizzka58ni5y8xdm"; + system = "cl-voxelize-examples"; + asd = "cl-voxelize-examples"; + } + ); + systems = [ "cl-voxelize-examples" ]; + lispLibs = [ + (getAttr "cl-ply" self) + (getAttr "cl-voxelize" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-voxelize-test = ( + build-asdf-system { + pname = "cl-voxelize-test"; + version = "20150709-git"; + asds = [ "cl-voxelize-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-voxelize/2015-07-09/cl-voxelize-20150709-git.tgz"; + sha256 = "1sim8n175dgy0i0dxi1vsqzgjx07lgsnrgn3bizzka58ni5y8xdm"; + system = "cl-voxelize-test"; + asd = "cl-voxelize-test"; + } + ); + systems = [ "cl-voxelize-test" ]; + lispLibs = [ + (getAttr "cl-voxelize" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-wadler-pprint = ( + build-asdf-system { + pname = "cl-wadler-pprint"; + version = "20191007-git"; + asds = [ "cl-wadler-pprint" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-wadler-pprint/2019-10-07/cl-wadler-pprint-20191007-git.tgz"; + sha256 = "0y5jxk7yiw8wng7hg91cwibh6d2hf1sv2mzqhkds6l4myhzxb4jr"; + system = "cl-wadler-pprint"; + asd = "cl-wadler-pprint"; + } + ); + systems = [ "cl-wadler-pprint" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-wav = ( + build-asdf-system { + pname = "cl-wav"; + version = "20221106-git"; + asds = [ "cl-wav" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-wav/2022-11-06/cl-wav-20221106-git.tgz"; + sha256 = "1nf4zw72v0c9fl8mr4si5cr2xz753ydzv19mfzy5dqqx0k1g7wyl"; + system = "cl-wav"; + asd = "cl-wav"; + } + ); + systems = [ "cl-wav" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-riff" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-wave-file-writer = ( + build-asdf-system { + pname = "cl-wave-file-writer"; + version = "quickload-current-release-42cde6cf-git"; + asds = [ "cl-wave-file-writer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-wave-file-writer/2021-10-20/cl-wave-file-writer-quickload-current-release-42cde6cf-git.tgz"; + sha256 = "0mxzp6rm7ah86vp1xj67q43al71k62x407m5vmbldvyb6pmx37fp"; + system = "cl-wave-file-writer"; + asd = "cl-wave-file-writer"; + } + ); + systems = [ "cl-wave-file-writer" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-wavefront = ( + build-asdf-system { + pname = "cl-wavefront"; + version = "20241012-git"; + asds = [ "cl-wavefront" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-wavefront/2024-10-12/cl-wavefront-20241012-git.tgz"; + sha256 = "1il5i04x2ff3pnjm2pgvq0hryd9rnjdbczvinj3l3w30lj553g83"; + system = "cl-wavefront"; + asd = "cl-wavefront"; + } + ); + systems = [ "cl-wavefront" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "documentation-utils" self) + (getAttr "parse-float" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-wavelets = ( + build-asdf-system { + pname = "cl-wavelets"; + version = "20220707-git"; + asds = [ "cl-wavelets" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-wavelets/2022-07-07/cl-wavelets-20220707-git.tgz"; + sha256 = "0z4r01d5mv4rachz5rr5zvnv94q7ka17138vcpsb05sz00vv03ba"; + system = "cl-wavelets"; + asd = "cl-wavelets"; + } + ); + systems = [ "cl-wavelets" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-wayland = ( + build-asdf-system { + pname = "cl-wayland"; + version = "20190307-git"; + asds = [ "cl-wayland" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-wayland/2019-03-07/cl-wayland-20190307-git.tgz"; + sha256 = "1axdkdm5d2bvj674jq6ylwhfwbzzs7yjj6f04c519qbdq9sknbcn"; + system = "cl-wayland"; + asd = "cl-wayland"; + } + ); + systems = [ "cl-wayland" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-weather-jp = ( + build-asdf-system { + pname = "cl-weather-jp"; + version = "20160208-git"; + asds = [ "cl-weather-jp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-weather-jp/2016-02-08/cl-weather-jp-20160208-git.tgz"; + sha256 = "15bp7gdk7ck9xs9lx2rrzqw6awlk6nz03cqy14wv2lvy3j84dc01"; + system = "cl-weather-jp"; + asd = "cl-weather-jp"; + } + ); + systems = [ "cl-weather-jp" ]; + lispLibs = [ + (getAttr "clss" self) + (getAttr "dexador" self) + (getAttr "function-cache" self) + (getAttr "jonathan" self) + (getAttr "plump" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-weather-jp-test = ( + build-asdf-system { + pname = "cl-weather-jp-test"; + version = "20160208-git"; + asds = [ "cl-weather-jp-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-weather-jp/2016-02-08/cl-weather-jp-20160208-git.tgz"; + sha256 = "15bp7gdk7ck9xs9lx2rrzqw6awlk6nz03cqy14wv2lvy3j84dc01"; + system = "cl-weather-jp-test"; + asd = "cl-weather-jp-test"; + } + ); + systems = [ "cl-weather-jp-test" ]; + lispLibs = [ + (getAttr "cl-weather-jp" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-webdav = ( + build-asdf-system { + pname = "cl-webdav"; + version = "20170830-git"; + asds = [ "cl-webdav" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-webdav/2017-08-30/cl-webdav-20170830-git.tgz"; + sha256 = "1cmzv763k4s5blfhx2p8s7q9gk20p8mj9p34dngydc14d2acrxmg"; + system = "cl-webdav"; + asd = "cl-webdav"; + } + ); + systems = [ "cl-webdav" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cxml" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-webdriver-client = ( + build-asdf-system { + pname = "cl-webdriver-client"; + version = "20241012-git"; + asds = [ "cl-webdriver-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-webdriver-client/2024-10-12/cl-webdriver-client-20241012-git.tgz"; + sha256 = "1975yyvvdxg11vgpyx93nkqr5x6i1xy47230vc40yd0c9bn6lpbr"; + system = "cl-webdriver-client"; + asd = "cl-webdriver-client"; + } + ); + systems = [ "cl-webdriver-client" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "assoc-utils" self) + (getAttr "cl-json" self) + (getAttr "dexador" self) + (getAttr "quri" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-webdriver-client-test = ( + build-asdf-system { + pname = "cl-webdriver-client-test"; + version = "20241012-git"; + asds = [ "cl-webdriver-client-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-webdriver-client/2024-10-12/cl-webdriver-client-20241012-git.tgz"; + sha256 = "1975yyvvdxg11vgpyx93nkqr5x6i1xy47230vc40yd0c9bn6lpbr"; + system = "cl-webdriver-client-test"; + asd = "cl-webdriver-client-test"; + } + ); + systems = [ "cl-webdriver-client-test" ]; + lispLibs = [ + (getAttr "cl-webdriver-client" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-webkit2 = ( + build-asdf-system { + pname = "cl-webkit2"; + version = "20241012-git"; + asds = [ "cl-webkit2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-webkit/2024-10-12/cl-webkit-20241012-git.tgz"; + sha256 = "1ppx4pdnx3c41hp1j8msvpyw22ck2lll2f4ap5hyfvhadp07g3m5"; + system = "cl-webkit2"; + asd = "cl-webkit2"; + } + ); + systems = [ "cl-webkit2" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-cffi-gtk" self) + ]; + meta = { }; + } + ); + cl-who = ( + build-asdf-system { + pname = "cl-who"; + version = "20241012-git"; + asds = [ "cl-who" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-who/2024-10-12/cl-who-20241012-git.tgz"; + sha256 = "1kfpy69dw0g7w7k0akimncpkxfqq85r08i2da8nw1dhk2hp6l8jc"; + system = "cl-who"; + asd = "cl-who"; + } + ); + systems = [ "cl-who" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cl-who-test = ( + build-asdf-system { + pname = "cl-who-test"; + version = "20241012-git"; + asds = [ "cl-who-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-who/2024-10-12/cl-who-20241012-git.tgz"; + sha256 = "1kfpy69dw0g7w7k0akimncpkxfqq85r08i2da8nw1dhk2hp6l8jc"; + system = "cl-who-test"; + asd = "cl-who"; + } + ); + systems = [ "cl-who-test" ]; + lispLibs = [ + (getAttr "cl-who" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-why = ( + build-asdf-system { + pname = "cl-why"; + version = "20180228-git"; + asds = [ "cl-why" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-why/2018-02-28/cl-why-20180228-git.tgz"; + sha256 = "01xm7gj1wwd7i3r49jfdm96gwl7nvrn0h6q22kpzrb8zs48wj947"; + system = "cl-why"; + asd = "cl-why"; + } + ); + systems = [ "cl-why" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-why-test = ( + build-asdf-system { + pname = "cl-why-test"; + version = "20180228-git"; + asds = [ "cl-why-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-why/2018-02-28/cl-why-20180228-git.tgz"; + sha256 = "01xm7gj1wwd7i3r49jfdm96gwl7nvrn0h6q22kpzrb8zs48wj947"; + system = "cl-why-test"; + asd = "cl-why"; + } + ); + systems = [ "cl-why-test" ]; + lispLibs = [ + (getAttr "cl-why" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-with = ( + build-asdf-system { + pname = "cl-with"; + version = "20211020-git"; + asds = [ "cl-with" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-with/2021-10-20/cl-with-20211020-git.tgz"; + sha256 = "1x4laq7zi12xb28rfrh8hcy92pkfvjxsp2nn6jkmrhfynky5180w"; + system = "cl-with"; + asd = "cl-with"; + } + ); + systems = [ "cl-with" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-wol_dot_cli = ( + build-asdf-system { + pname = "cl-wol.cli"; + version = "20231021-git"; + asds = [ "cl-wol.cli" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-wol/2023-10-21/cl-wol-20231021-git.tgz"; + sha256 = "1gfrih0899i7280169cjp6bg3zmrx6znrr3i9qjgda0jk4dn5rp4"; + system = "cl-wol.cli"; + asd = "cl-wol.cli"; + } + ); + systems = [ "cl-wol.cli" ]; + lispLibs = [ + (getAttr "cl-ascii-table" self) + (getAttr "cl-migratum" self) + (getAttr "cl-migratum_dot_driver_dot_dbi" self) + (getAttr "cl-migratum_dot_provider_dot_local-path" self) + (getAttr "cl-wol_dot_core" self) + (getAttr "clingon" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-wol_dot_core = ( + build-asdf-system { + pname = "cl-wol.core"; + version = "20231021-git"; + asds = [ "cl-wol.core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-wol/2023-10-21/cl-wol-20231021-git.tgz"; + sha256 = "1gfrih0899i7280169cjp6bg3zmrx6znrr3i9qjgda0jk4dn5rp4"; + system = "cl-wol.core"; + asd = "cl-wol.core"; + } + ); + systems = [ "cl-wol.core" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-wol_dot_test = ( + build-asdf-system { + pname = "cl-wol.test"; + version = "20231021-git"; + asds = [ "cl-wol.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-wol/2023-10-21/cl-wol-20231021-git.tgz"; + sha256 = "1gfrih0899i7280169cjp6bg3zmrx6znrr3i9qjgda0jk4dn5rp4"; + system = "cl-wol.test"; + asd = "cl-wol.test"; + } + ); + systems = [ "cl-wol.test" ]; + lispLibs = [ + (getAttr "cl-wol_dot_core" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-wordcut = ( + build-asdf-system { + pname = "cl-wordcut"; + version = "20160421-git"; + asds = [ "cl-wordcut" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-wordcut/2016-04-21/cl-wordcut-20160421-git.tgz"; + sha256 = "1b8b3b1rgk0y87l54325ilcly8rq9qxalcsmw6rk8q6dq13lgv78"; + system = "cl-wordcut"; + asd = "cl-wordcut"; + } + ); + systems = [ "cl-wordcut" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-xdg = ( + build-asdf-system { + pname = "cl-xdg"; + version = "20170124-git"; + asds = [ "cl-xdg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-xdg/2017-01-24/cl-xdg-20170124-git.tgz"; + sha256 = "078hgsab0gl6s96wq09ibq5alzyyqh6wwc3yjs44fv18561p5jgc"; + system = "cl-xdg"; + asd = "cl-xdg"; + } + ); + systems = [ "cl-xdg" ]; + lispLibs = [ + (getAttr "cl-sxml" self) + (getAttr "cl-xmlspam" self) + (getAttr "flexi-streams" self) + (getAttr "parse-number" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-xdg-test = ( + build-asdf-system { + pname = "cl-xdg-test"; + version = "20170124-git"; + asds = [ "cl-xdg-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-xdg/2017-01-24/cl-xdg-20170124-git.tgz"; + sha256 = "078hgsab0gl6s96wq09ibq5alzyyqh6wwc3yjs44fv18561p5jgc"; + system = "cl-xdg-test"; + asd = "cl-xdg"; + } + ); + systems = [ "cl-xdg-test" ]; + lispLibs = [ + (getAttr "cl-xdg" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-xkb = ( + build-asdf-system { + pname = "cl-xkb"; + version = "20230214-git"; + asds = [ "cl-xkb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-xkb/2023-02-14/cl-xkb-20230214-git.tgz"; + sha256 = "002bskv0dvq2hahz7dah2zwwkp2zrkf98w7lm96jmqfn8vyp4k75"; + system = "cl-xkb"; + asd = "cl-xkb"; + } + ); + systems = [ "cl-xkb" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-xkeysym = ( + build-asdf-system { + pname = "cl-xkeysym"; + version = "20140914-git"; + asds = [ "cl-xkeysym" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-xkeysym/2014-09-14/cl-xkeysym-20140914-git.tgz"; + sha256 = "0yxijl6xb5apb6v6qm8g3kfdr90slgg6vsnx4d1ps9z4zhrjlc6c"; + system = "cl-xkeysym"; + asd = "cl-xkeysym"; + } + ); + systems = [ "cl-xkeysym" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-xmlspam = ( + build-asdf-system { + pname = "cl-xmlspam"; + version = "20101006-http"; + asds = [ "cl-xmlspam" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-xmlspam/2010-10-06/cl-xmlspam-20101006-http.tgz"; + sha256 = "03jw57889b60nsqgb13vrf5q1g2fasah7qv7knjlx2w4mc1ci7ks"; + system = "cl-xmlspam"; + asd = "cl-xmlspam"; + } + ); + systems = [ "cl-xmlspam" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cxml" self) + ]; + meta = { }; + } + ); + cl-xmpp = ( + build-asdf-system { + pname = "cl-xmpp"; + version = "0.8.1"; + asds = [ "cl-xmpp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-xmpp/2010-10-06/cl-xmpp-0.8.1.tgz"; + sha256 = "1kzzq1y0625zlg83ppcpb0aqzvqbga9x3gm826grmy4rf5jrhz5f"; + system = "cl-xmpp"; + asd = "cl-xmpp"; + } + ); + systems = [ "cl-xmpp" ]; + lispLibs = [ + (getAttr "cxml" self) + (getAttr "ironclad" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-xmpp-sasl = ( + build-asdf-system { + pname = "cl-xmpp-sasl"; + version = "0.8.1"; + asds = [ "cl-xmpp-sasl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-xmpp/2010-10-06/cl-xmpp-0.8.1.tgz"; + sha256 = "1kzzq1y0625zlg83ppcpb0aqzvqbga9x3gm826grmy4rf5jrhz5f"; + system = "cl-xmpp-sasl"; + asd = "cl-xmpp-sasl"; + } + ); + systems = [ "cl-xmpp-sasl" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "cl-sasl" self) + (getAttr "cl-xmpp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-xmpp-tls = ( + build-asdf-system { + pname = "cl-xmpp-tls"; + version = "0.8.1"; + asds = [ "cl-xmpp-tls" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-xmpp/2010-10-06/cl-xmpp-0.8.1.tgz"; + sha256 = "1kzzq1y0625zlg83ppcpb0aqzvqbga9x3gm826grmy4rf5jrhz5f"; + system = "cl-xmpp-tls"; + asd = "cl-xmpp-tls"; + } + ); + systems = [ "cl-xmpp-tls" ]; + lispLibs = [ + (getAttr "cl_plus_ssl" self) + (getAttr "cl-xmpp-sasl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-xul = ( + build-asdf-system { + pname = "cl-xul"; + version = "20160318-git"; + asds = [ "cl-xul" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-xul/2016-03-18/cl-xul-20160318-git.tgz"; + sha256 = "0ldny4bjfndrkyqcq6klqxvqkpb0lhcqlj52y89ybl9w7dkl2d9p"; + system = "cl-xul"; + asd = "cl-xul"; + } + ); + systems = [ "cl-xul" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "cl-json" self) + (getAttr "closer-mop" self) + (getAttr "clws" self) + (getAttr "cxml" self) + (getAttr "log5" self) + (getAttr "md5" self) + (getAttr "parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-xul-test = ( + build-asdf-system { + pname = "cl-xul-test"; + version = "20160318-git"; + asds = [ "cl-xul-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-xul/2016-03-18/cl-xul-20160318-git.tgz"; + sha256 = "0ldny4bjfndrkyqcq6klqxvqkpb0lhcqlj52y89ybl9w7dkl2d9p"; + system = "cl-xul-test"; + asd = "cl-xul-test"; + } + ); + systems = [ "cl-xul-test" ]; + lispLibs = [ + (getAttr "cl-xul" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-yaclyaml = ( + build-asdf-system { + pname = "cl-yaclyaml"; + version = "20160825-git"; + asds = [ "cl-yaclyaml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-yaclyaml/2016-08-25/cl-yaclyaml-20160825-git.tgz"; + sha256 = "1clfhz4ii2p11yc3bm23ib4rx0rfxsh18ddc2br82i7mbwks3pll"; + system = "cl-yaclyaml"; + asd = "cl-yaclyaml"; + } + ); + systems = [ "cl-yaclyaml" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-test-more" self) + (getAttr "esrap-liquid" self) + (getAttr "iterate" self) + (getAttr "parse-number" self) + (getAttr "rutils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-yaclyaml-tests = ( + build-asdf-system { + pname = "cl-yaclyaml-tests"; + version = "20160825-git"; + asds = [ "cl-yaclyaml-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-yaclyaml/2016-08-25/cl-yaclyaml-20160825-git.tgz"; + sha256 = "1clfhz4ii2p11yc3bm23ib4rx0rfxsh18ddc2br82i7mbwks3pll"; + system = "cl-yaclyaml-tests"; + asd = "cl-yaclyaml"; + } + ); + systems = [ "cl-yaclyaml-tests" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "cl-yaclyaml" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-yahoo-finance = ( + build-asdf-system { + pname = "cl-yahoo-finance"; + version = "20130312-git"; + asds = [ "cl-yahoo-finance" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-yahoo-finance/2013-03-12/cl-yahoo-finance-20130312-git.tgz"; + sha256 = "1qhs4j00iw1w81lx0vmyiayzqyvixaxc5j2rc89qlr1gx12mqadl"; + system = "cl-yahoo-finance"; + asd = "cl-yahoo-finance"; + } + ); + systems = [ "cl-yahoo-finance" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-csv" self) + (getAttr "drakma" self) + (getAttr "url-rewrite" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-yaml = ( + build-asdf-system { + pname = "cl-yaml"; + version = "20221106-git"; + asds = [ "cl-yaml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-yaml/2022-11-06/cl-yaml-20221106-git.tgz"; + sha256 = "053fvrrd0p2xx4zxbz4kg9469895ypwsbjfd3nwpi7lwcll2bir5"; + system = "cl-yaml"; + asd = "cl-yaml"; + } + ); + systems = [ "cl-yaml" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-libyaml" self) + (getAttr "cl-ppcre" self) + (getAttr "parse-number" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-yaml-test = ( + build-asdf-system { + pname = "cl-yaml-test"; + version = "20221106-git"; + asds = [ "cl-yaml-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-yaml/2022-11-06/cl-yaml-20221106-git.tgz"; + sha256 = "053fvrrd0p2xx4zxbz4kg9469895ypwsbjfd3nwpi7lwcll2bir5"; + system = "cl-yaml-test"; + asd = "cl-yaml-test"; + } + ); + systems = [ "cl-yaml-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "cl-yaml" self) + (getAttr "fiveam" self) + (getAttr "generic-comparability" self) + (getAttr "trivial-benchmark" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-yesql = ( + build-asdf-system { + pname = "cl-yesql"; + version = "20211020-git"; + asds = [ "cl-yesql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-yesql/2021-10-20/cl-yesql-20211020-git.tgz"; + sha256 = "0bg133kprbssv0z4ir2hkhf72fbmnz9v9861ncs1isqaby2d4xlj"; + system = "cl-yesql"; + asd = "cl-yesql"; + } + ); + systems = [ "cl-yesql" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "asdf-package-system" self) + (getAttr "esrap" self) + (getAttr "serapeum" self) + (getAttr "trivia" self) + (getAttr "vernacular" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-zipper = ( + build-asdf-system { + pname = "cl-zipper"; + version = "20200610-git"; + asds = [ "cl-zipper" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-zipper/2020-06-10/cl-zipper-20200610-git.tgz"; + sha256 = "1zcfy97l40ynbldxpx8nad81jlrfp0k2vic10wbkrqdfkr696xkg"; + system = "cl-zipper"; + asd = "cl-zipper"; + } + ); + systems = [ "cl-zipper" ]; + lispLibs = [ (getAttr "prove-asdf" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl-zipper-test = ( + build-asdf-system { + pname = "cl-zipper-test"; + version = "20200610-git"; + asds = [ "cl-zipper-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-zipper/2020-06-10/cl-zipper-20200610-git.tgz"; + sha256 = "1zcfy97l40ynbldxpx8nad81jlrfp0k2vic10wbkrqdfkr696xkg"; + system = "cl-zipper-test"; + asd = "cl-zipper"; + } + ); + systems = [ "cl-zipper-test" ]; + lispLibs = [ + (getAttr "cl-zipper" self) + (getAttr "prove-asdf" self) + (getAttr "test-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cl4store = ( + build-asdf-system { + pname = "cl4store"; + version = "20200325-git"; + asds = [ "cl4store" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl4store/2020-03-25/cl4store-20200325-git.tgz"; + sha256 = "0qajxwlvmb5vd9qynnl0n62bcl1xhin49xk0p44v6pig8q2jzc26"; + system = "cl4store"; + asd = "cl4store"; + } + ); + systems = [ "cl4store" ]; + lispLibs = [ + (getAttr "cl-rdfxml" self) + (getAttr "cl-sparql" self) + (getAttr "drakma" self) + (getAttr "log5" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clache = ( + build-asdf-system { + pname = "clache"; + version = "20171130-git"; + asds = [ "clache" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clache/2017-11-30/clache-20171130-git.tgz"; + sha256 = "0wxg004bsay58vr6xr6mlk7wj415qmvisqxvpnjsg6glfwca86ys"; + system = "clache"; + asd = "clache"; + } + ); + systems = [ "clache" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-annot" self) + (getAttr "cl-fad" self) + (getAttr "cl-store" self) + (getAttr "cl-syntax" self) + (getAttr "cl-syntax-annot" self) + (getAttr "ironclad" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clache-test = ( + build-asdf-system { + pname = "clache-test"; + version = "20171130-git"; + asds = [ "clache-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clache/2017-11-30/clache-20171130-git.tgz"; + sha256 = "0wxg004bsay58vr6xr6mlk7wj415qmvisqxvpnjsg6glfwca86ys"; + system = "clache-test"; + asd = "clache-test"; + } + ); + systems = [ "clache-test" ]; + lispLibs = [ + (getAttr "cl-test-more" self) + (getAttr "clache" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack = ( + build-asdf-system { + pname = "clack"; + version = "20241012-git"; + asds = [ "clack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; + sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; + system = "clack"; + asd = "clack"; + } + ); + systems = [ "clack" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "lack" self) + (getAttr "lack-middleware-backtrace" self) + (getAttr "lack-util" self) + (getAttr "swank" self) + (getAttr "usocket" self) + ]; + meta = { }; + } + ); + clack-cors = ( + build-asdf-system { + pname = "clack-cors"; + version = "20241012-git"; + asds = [ "clack-cors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-cors/2024-10-12/clack-cors-20241012-git.tgz"; + sha256 = "0bndzkrqmdq5cz7wfzr7kw2gy5vk8h1hmf3vplc6mqk7vr3zm6m2"; + system = "clack-cors"; + asd = "clack-cors"; + } + ); + systems = [ "clack-cors" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "alexandria" self) + (getAttr "log4cl" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-cors-ci = ( + build-asdf-system { + pname = "clack-cors-ci"; + version = "20241012-git"; + asds = [ "clack-cors-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-cors/2024-10-12/clack-cors-20241012-git.tgz"; + sha256 = "0bndzkrqmdq5cz7wfzr7kw2gy5vk8h1hmf3vplc6mqk7vr3zm6m2"; + system = "clack-cors-ci"; + asd = "clack-cors-ci"; + } + ); + systems = [ "clack-cors-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-cors-docs = ( + build-asdf-system { + pname = "clack-cors-docs"; + version = "20241012-git"; + asds = [ "clack-cors-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-cors/2024-10-12/clack-cors-20241012-git.tgz"; + sha256 = "0bndzkrqmdq5cz7wfzr7kw2gy5vk8h1hmf3vplc6mqk7vr3zm6m2"; + system = "clack-cors-docs"; + asd = "clack-cors-docs"; + } + ); + systems = [ "clack-cors-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "clack-cors" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-cors-tests = ( + build-asdf-system { + pname = "clack-cors-tests"; + version = "20241012-git"; + asds = [ "clack-cors-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-cors/2024-10-12/clack-cors-20241012-git.tgz"; + sha256 = "0bndzkrqmdq5cz7wfzr7kw2gy5vk8h1hmf3vplc6mqk7vr3zm6m2"; + system = "clack-cors-tests"; + asd = "clack-cors-tests"; + } + ); + systems = [ "clack-cors-tests" ]; + lispLibs = [ + (getAttr "clack-test" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-errors = ( + build-asdf-system { + pname = "clack-errors"; + version = "20190813-git"; + asds = [ "clack-errors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-errors/2019-08-13/clack-errors-20190813-git.tgz"; + sha256 = "0z6jyn37phnpq02l5wml8z0593g8ps95c0c2lzkhi3is2wcj9cpf"; + system = "clack-errors"; + asd = "clack-errors"; + } + ); + systems = [ "clack-errors" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "clack" self) + (getAttr "closer-mop" self) + (getAttr "djula" self) + (getAttr "local-time" self) + (getAttr "trivial-backtrace" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-errors-demo = ( + build-asdf-system { + pname = "clack-errors-demo"; + version = "20190813-git"; + asds = [ "clack-errors-demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-errors/2019-08-13/clack-errors-20190813-git.tgz"; + sha256 = "0z6jyn37phnpq02l5wml8z0593g8ps95c0c2lzkhi3is2wcj9cpf"; + system = "clack-errors-demo"; + asd = "clack-errors-demo"; + } + ); + systems = [ "clack-errors-demo" ]; + lispLibs = [ + (getAttr "cl-markup" self) + (getAttr "clack-errors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-errors-test = ( + build-asdf-system { + pname = "clack-errors-test"; + version = "20190813-git"; + asds = [ "clack-errors-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-errors/2019-08-13/clack-errors-20190813-git.tgz"; + sha256 = "0z6jyn37phnpq02l5wml8z0593g8ps95c0c2lzkhi3is2wcj9cpf"; + system = "clack-errors-test"; + asd = "clack-errors-test"; + } + ); + systems = [ "clack-errors-test" ]; + lispLibs = [ + (getAttr "clack" self) + (getAttr "clack-errors" self) + (getAttr "drakma" self) + (getAttr "fiveam" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-handler-hunchentoot = ( + build-asdf-system { + pname = "clack-handler-hunchentoot"; + version = "20241012-git"; + asds = [ "clack-handler-hunchentoot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; + sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; + system = "clack-handler-hunchentoot"; + asd = "clack-handler-hunchentoot"; + } + ); + systems = [ "clack-handler-hunchentoot" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "clack-socket" self) + (getAttr "flexi-streams" self) + (getAttr "hunchentoot" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-handler-toot = ( + build-asdf-system { + pname = "clack-handler-toot"; + version = "20241012-git"; + asds = [ "clack-handler-toot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; + sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; + system = "clack-handler-toot"; + asd = "clack-handler-toot"; + } + ); + systems = [ "clack-handler-toot" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "split-sequence" self) + (getAttr "toot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-handler-woo = ( + build-asdf-system { + pname = "clack-handler-woo"; + version = "20241012-git"; + asds = [ "clack-handler-woo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/woo/2024-10-12/woo-20241012-git.tgz"; + sha256 = "0nhxlb1qhkl20vknm44gx0cq5cks33rcljczfhgbnmpkzrdpdrrl"; + system = "clack-handler-woo"; + asd = "clack-handler-woo"; + } + ); + systems = [ "clack-handler-woo" ]; + lispLibs = [ (getAttr "woo" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-handler-wookie = ( + build-asdf-system { + pname = "clack-handler-wookie"; + version = "20241012-git"; + asds = [ "clack-handler-wookie" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; + sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; + system = "clack-handler-wookie"; + asd = "clack-handler-wookie"; + } + ); + systems = [ "clack-handler-wookie" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-async" self) + (getAttr "clack-socket" self) + (getAttr "fast-http" self) + (getAttr "fast-io" self) + (getAttr "flexi-streams" self) + (getAttr "quri" self) + (getAttr "split-sequence" self) + (getAttr "wookie" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-pretend = ( + build-asdf-system { + pname = "clack-pretend"; + version = "20241012-git"; + asds = [ "clack-pretend" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-pretend/2024-10-12/clack-pretend-20241012-git.tgz"; + sha256 = "0f9y264bdxspd3sfzf9hq7v0myvq5va0drw8kji1b4gyprmg995k"; + system = "clack-pretend"; + asd = "clack-pretend"; + } + ); + systems = [ "clack-pretend" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "circular-streams" self) + (getAttr "cl-hash-util" self) + (getAttr "clack" self) + (getAttr "lack-request" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-prometheus = ( + build-asdf-system { + pname = "clack-prometheus"; + version = "20241012-git"; + asds = [ "clack-prometheus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-prometheus/2024-10-12/clack-prometheus-20241012-git.tgz"; + sha256 = "1zkflszvxyhxn7m9c2f1k2snqwdzasbvscw5vpsglb50pczs9g0d"; + system = "clack-prometheus"; + asd = "clack-prometheus"; + } + ); + systems = [ "clack-prometheus" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "cffi-grovel" self) + (getAttr "lack-middleware-mount" self) + (getAttr "prometheus" self) + (getAttr "prometheus-gc" self) + (getAttr "prometheus_dot_collectors_dot_process" self) + (getAttr "prometheus_dot_collectors_dot_sbcl" self) + (getAttr "prometheus_dot_formats_dot_text" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-prometheus-ci = ( + build-asdf-system { + pname = "clack-prometheus-ci"; + version = "20241012-git"; + asds = [ "clack-prometheus-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-prometheus/2024-10-12/clack-prometheus-20241012-git.tgz"; + sha256 = "1zkflszvxyhxn7m9c2f1k2snqwdzasbvscw5vpsglb50pczs9g0d"; + system = "clack-prometheus-ci"; + asd = "clack-prometheus-ci"; + } + ); + systems = [ "clack-prometheus-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-prometheus-docs = ( + build-asdf-system { + pname = "clack-prometheus-docs"; + version = "20241012-git"; + asds = [ "clack-prometheus-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-prometheus/2024-10-12/clack-prometheus-20241012-git.tgz"; + sha256 = "1zkflszvxyhxn7m9c2f1k2snqwdzasbvscw5vpsglb50pczs9g0d"; + system = "clack-prometheus-docs"; + asd = "clack-prometheus-docs"; + } + ); + systems = [ "clack-prometheus-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "clack-prometheus" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-prometheus-tests = ( + build-asdf-system { + pname = "clack-prometheus-tests"; + version = "20241012-git"; + asds = [ "clack-prometheus-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-prometheus/2024-10-12/clack-prometheus-20241012-git.tgz"; + sha256 = "1zkflszvxyhxn7m9c2f1k2snqwdzasbvscw5vpsglb50pczs9g0d"; + system = "clack-prometheus-tests"; + asd = "clack-prometheus-tests"; + } + ); + systems = [ "clack-prometheus-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-socket = ( + build-asdf-system { + pname = "clack-socket"; + version = "20241012-git"; + asds = [ "clack-socket" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; + sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; + system = "clack-socket"; + asd = "clack-socket"; + } + ); + systems = [ "clack-socket" ]; + lispLibs = [ ]; + meta = { }; + } + ); + clack-static-asset-djula-helpers = ( + build-asdf-system { + pname = "clack-static-asset-djula-helpers"; + version = "20211209-git"; + asds = [ "clack-static-asset-djula-helpers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-static-asset-middleware/2021-12-09/clack-static-asset-middleware-20211209-git.tgz"; + sha256 = "0fk288812sdm012knqx4qqdhggdqbfgd0zfb6mc06xig20wj02hc"; + system = "clack-static-asset-djula-helpers"; + asd = "clack-static-asset-djula-helpers"; + } + ); + systems = [ "clack-static-asset-djula-helpers" ]; + lispLibs = [ + (getAttr "clack-static-asset-middleware" self) + (getAttr "djula" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-static-asset-middleware = ( + build-asdf-system { + pname = "clack-static-asset-middleware"; + version = "20211209-git"; + asds = [ "clack-static-asset-middleware" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-static-asset-middleware/2021-12-09/clack-static-asset-middleware-20211209-git.tgz"; + sha256 = "0fk288812sdm012knqx4qqdhggdqbfgd0zfb6mc06xig20wj02hc"; + system = "clack-static-asset-middleware"; + asd = "clack-static-asset-middleware"; + } + ); + systems = [ "clack-static-asset-middleware" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "ironclad" self) + (getAttr "local-time" self) + (getAttr "trivial-mimes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-static-asset-middleware-test = ( + build-asdf-system { + pname = "clack-static-asset-middleware-test"; + version = "20211209-git"; + asds = [ "clack-static-asset-middleware-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-static-asset-middleware/2021-12-09/clack-static-asset-middleware-20211209-git.tgz"; + sha256 = "0fk288812sdm012knqx4qqdhggdqbfgd0zfb6mc06xig20wj02hc"; + system = "clack-static-asset-middleware-test"; + asd = "clack-static-asset-middleware-test"; + } + ); + systems = [ "clack-static-asset-middleware-test" ]; + lispLibs = [ + (getAttr "clack-static-asset-djula-helpers" self) + (getAttr "clack-static-asset-middleware" self) + (getAttr "lack-test" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clack-test = ( + build-asdf-system { + pname = "clack-test"; + version = "20241012-git"; + asds = [ "clack-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; + sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; + system = "clack-test"; + asd = "clack-test"; + } + ); + systems = [ "clack-test" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "clack" self) + (getAttr "clack-handler-hunchentoot" self) + (getAttr "dexador" self) + (getAttr "flexi-streams" self) + (getAttr "http-body" self) + (getAttr "ironclad" self) + (getAttr "rove" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clad = ( + build-asdf-system { + pname = "clad"; + version = "20241012-git"; + asds = [ "clad" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clad/2024-10-12/clad-20241012-git.tgz"; + sha256 = "1ah8d4wyd7yqchcnyjcnd27gx2m410cgybyp194ng1ipdpa4mm6n"; + system = "clad"; + asd = "clad"; + } + ); + systems = [ "clad" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + class-options = ( + build-asdf-system { + pname = "class-options"; + version = "1.0.1"; + asds = [ "class-options" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/class-options/2020-10-16/class-options_1.0.1.tgz"; + sha256 = "1dkgr1vbrsra44jznzz2bvdf8nlpdrrkjcqrfs8aa7axksda3bqk"; + system = "class-options"; + asd = "class-options"; + } + ); + systems = [ "class-options" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + class-options__tests = ( + build-asdf-system { + pname = "class-options_tests"; + version = "1.0.1"; + asds = [ "class-options_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/class-options/2020-10-16/class-options_1.0.1.tgz"; + sha256 = "1dkgr1vbrsra44jznzz2bvdf8nlpdrrkjcqrfs8aa7axksda3bqk"; + system = "class-options_tests"; + asd = "class-options_tests"; + } + ); + systems = [ "class-options_tests" ]; + lispLibs = [ + (getAttr "class-options" self) + (getAttr "closer-mop" self) + (getAttr "enhanced-boolean" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + classimp = ( + build-asdf-system { + pname = "classimp"; + version = "20241012-git"; + asds = [ "classimp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/classimp/2024-10-12/classimp-20241012-git.tgz"; + sha256 = "1sq34s5yrljh7fffllsscay7xi11lg03alrkyrh6xfwa2w7cnqmx"; + system = "classimp"; + asd = "classimp"; + } + ); + systems = [ "classimp" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + classimp-samples = ( + build-asdf-system { + pname = "classimp-samples"; + version = "20241012-git"; + asds = [ "classimp-samples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/classimp/2024-10-12/classimp-20241012-git.tgz"; + sha256 = "1sq34s5yrljh7fffllsscay7xi11lg03alrkyrh6xfwa2w7cnqmx"; + system = "classimp-samples"; + asd = "classimp-samples"; + } + ); + systems = [ "classimp-samples" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cl-glu" self) + (getAttr "cl-glut" self) + (getAttr "cl-ilut" self) + (getAttr "classimp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + classowary = ( + build-asdf-system { + pname = "classowary"; + version = "20231021-git"; + asds = [ "classowary" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/classowary/2023-10-21/classowary-20231021-git.tgz"; + sha256 = "099zhf41d4frlrm99ldzypqjh03ijrvfn29f2pb0j6664h65bcsm"; + system = "classowary"; + asd = "classowary"; + } + ); + systems = [ "classowary" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { }; + } + ); + classowary-test = ( + build-asdf-system { + pname = "classowary-test"; + version = "20231021-git"; + asds = [ "classowary-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/classowary/2023-10-21/classowary-20231021-git.tgz"; + sha256 = "099zhf41d4frlrm99ldzypqjh03ijrvfn29f2pb0j6664h65bcsm"; + system = "classowary-test"; + asd = "classowary-test"; + } + ); + systems = [ "classowary-test" ]; + lispLibs = [ + (getAttr "classowary" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clast = ( + build-asdf-system { + pname = "clast"; + version = "20241012-git"; + asds = [ "clast" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clast/2024-10-12/clast-20241012-git.tgz"; + sha256 = "0509hrpd049s62s03wwb2mp24dfw8f0l8cg0vgq3s8wrsch7af2m"; + system = "clast"; + asd = "clast"; + } + ); + systems = [ "clast" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clath = ( + build-asdf-system { + pname = "clath"; + version = "20241012-git"; + asds = [ "clath" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clath/2024-10-12/clath-20241012-git.tgz"; + sha256 = "0519jzm8r55am6f5w11pfbyq0bvn8jxkcz33kbrznwrf43xz5fcv"; + system = "clath"; + asd = "clath"; + } + ); + systems = [ "clath" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-hash-util" self) + (getAttr "cl-json" self) + (getAttr "cl-who" self) + (getAttr "clack" self) + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + (getAttr "ironclad" self) + (getAttr "jose" self) + (getAttr "ningle" self) + (getAttr "north" self) + (getAttr "ubiquitous" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clavatar = ( + build-asdf-system { + pname = "clavatar"; + version = "20121013-git"; + asds = [ "clavatar" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clavatar/2012-10-13/clavatar-20121013-git.tgz"; + sha256 = "07r58d4dk5nr3aimrryzbf3jw6580b5gkkbpw74ax4nmm8hz6v5y"; + system = "clavatar"; + asd = "clavatar"; + } + ); + systems = [ "clavatar" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "drakma" self) + (getAttr "iolib" self) + (getAttr "ironclad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clavier = ( + build-asdf-system { + pname = "clavier"; + version = "20241012-git"; + asds = [ "clavier" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clavier/2024-10-12/clavier-20241012-git.tgz"; + sha256 = "0v81ql9bbnsqaxcrv0ynm82xwifxvc6ysmfrn1lgphn4szx1p230"; + system = "clavier"; + asd = "clavier"; + } + ); + systems = [ "clavier" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "chronicity" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clavier_dot_test = ( + build-asdf-system { + pname = "clavier.test"; + version = "20241012-git"; + asds = [ "clavier.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clavier/2024-10-12/clavier-20241012-git.tgz"; + sha256 = "0v81ql9bbnsqaxcrv0ynm82xwifxvc6ysmfrn1lgphn4szx1p230"; + system = "clavier.test"; + asd = "clavier.test"; + } + ); + systems = [ "clavier.test" ]; + lispLibs = [ + (getAttr "clavier" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + claw = ( + build-asdf-system { + pname = "claw"; + version = "stable-git"; + asds = [ "claw" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/claw/2020-10-16/claw-stable-git.tgz"; + sha256 = "146yv0hc4hmk72562ssj2d41143pp84dcbd1h7f4nx1c7hf2bb0d"; + system = "claw"; + asd = "claw"; + } + ); + systems = [ "claw" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "claw-support" self) + (getAttr "local-time" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + claw-olm = ( + build-asdf-system { + pname = "claw-olm"; + version = "20210531-git"; + asds = [ "claw-olm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/claw-olm/2021-05-31/claw-olm-20210531-git.tgz"; + sha256 = "04r6d8infhcc7vz95asrvlpc0wzkzq1blaza74nd62alakr6mmrr"; + system = "claw-olm"; + asd = "claw-olm"; + } + ); + systems = [ "claw-olm" ]; + lispLibs = [ (getAttr "claw-olm-bindings" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + claw-olm-bindings = ( + build-asdf-system { + pname = "claw-olm-bindings"; + version = "20210531-git"; + asds = [ "claw-olm-bindings" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/claw-olm/2021-05-31/claw-olm-20210531-git.tgz"; + sha256 = "04r6d8infhcc7vz95asrvlpc0wzkzq1blaza74nd62alakr6mmrr"; + system = "claw-olm-bindings"; + asd = "claw-olm-bindings"; + } + ); + systems = [ "claw-olm-bindings" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + claw-support = ( + build-asdf-system { + pname = "claw-support"; + version = "stable-git"; + asds = [ "claw-support" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/claw-support/2020-10-16/claw-support-stable-git.tgz"; + sha256 = "1my2ka7h72ipx5n3b465g6kjkasrhsvhqlijwcg6dhlzs5yygl23"; + system = "claw-support"; + asd = "claw-support"; + } + ); + systems = [ "claw-support" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + claw-utils = ( + build-asdf-system { + pname = "claw-utils"; + version = "stable-git"; + asds = [ "claw-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/claw-utils/2020-10-16/claw-utils-stable-git.tgz"; + sha256 = "01df3kyf2qs3czi332dnz2s35x2j0fq46vgmsw7wjrrvnqc22mk5"; + system = "claw-utils"; + asd = "claw-utils"; + } + ); + systems = [ "claw-utils" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "claw" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clawk = ( + build-asdf-system { + pname = "clawk"; + version = "20200925-git"; + asds = [ "clawk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clawk/2020-09-25/clawk-20200925-git.tgz"; + sha256 = "1ph3xjqilvinvgr9q3w47zxqyz1sqnq030nlx7kgkkv8j3bnqk7a"; + system = "clawk"; + asd = "clawk"; + } + ); + systems = [ "clawk" ]; + lispLibs = [ (getAttr "regex" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + claxy = ( + build-asdf-system { + pname = "claxy"; + version = "20220220-git"; + asds = [ "claxy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/claxy/2022-02-20/claxy-20220220-git.tgz"; + sha256 = "1n6zbsfp0zkndw7r3nar8srjj1wmfgngia3p7z756mmsvp1l68va"; + system = "claxy"; + asd = "claxy"; + } + ); + systems = [ "claxy" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "dexador" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clazy = ( + build-asdf-system { + pname = "clazy"; + version = "20241012-git"; + asds = [ "clazy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clazy/2024-10-12/clazy-20241012-git.tgz"; + sha256 = "0z9iy89p4grj2a803nlrnvj335c6knmnlbicpf0b4br41j6q74xj"; + system = "clazy"; + asd = "clazy"; + } + ); + systems = [ "clazy" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clem = ( + build-asdf-system { + pname = "clem"; + version = "20210807-git"; + asds = [ "clem" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clem/2021-08-07/clem-20210807-git.tgz"; + sha256 = "0vmsgxdpxrqkx3xp9n8b0fwkzk1r2dwcwjlc8yy5w2m2sighh2rk"; + system = "clem"; + asd = "clem"; + } + ); + systems = [ "clem" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clem-benchmark = ( + build-asdf-system { + pname = "clem-benchmark"; + version = "20210807-git"; + asds = [ "clem-benchmark" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clem/2021-08-07/clem-20210807-git.tgz"; + sha256 = "0vmsgxdpxrqkx3xp9n8b0fwkzk1r2dwcwjlc8yy5w2m2sighh2rk"; + system = "clem-benchmark"; + asd = "clem-benchmark"; + } + ); + systems = [ "clem-benchmark" ]; + lispLibs = [ (getAttr "clem" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clem-test = ( + build-asdf-system { + pname = "clem-test"; + version = "20210807-git"; + asds = [ "clem-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clem/2021-08-07/clem-20210807-git.tgz"; + sha256 = "0vmsgxdpxrqkx3xp9n8b0fwkzk1r2dwcwjlc8yy5w2m2sighh2rk"; + system = "clem-test"; + asd = "clem-test"; + } + ); + systems = [ "clem-test" ]; + lispLibs = [ (getAttr "clem" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cleric = ( + build-asdf-system { + pname = "cleric"; + version = "20220220-git"; + asds = [ "cleric" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cleric/2022-02-20/cleric-20220220-git.tgz"; + sha256 = "0a0xqr0bpp0v62f8d13yflz3vz6j4fa9icgc134ajaqxcfa7k0vp"; + system = "cleric"; + asd = "cleric"; + } + ); + systems = [ "cleric" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "com_dot_gigamonkeys_dot_binary-data" self) + (getAttr "epmd" self) + (getAttr "erlang-term" self) + (getAttr "md5" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cleric-test = ( + build-asdf-system { + pname = "cleric-test"; + version = "20220220-git"; + asds = [ "cleric-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cleric/2022-02-20/cleric-20220220-git.tgz"; + sha256 = "0a0xqr0bpp0v62f8d13yflz3vz6j4fa9icgc134ajaqxcfa7k0vp"; + system = "cleric-test"; + asd = "cleric-test"; + } + ); + systems = [ "cleric-test" ]; + lispLibs = [ + (getAttr "cleric" self) + (getAttr "erlang-term-test" self) + (getAttr "fiveam" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clerk = ( + build-asdf-system { + pname = "clerk"; + version = "20241012-git"; + asds = [ "clerk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clerk/2024-10-12/clerk-20241012-git.tgz"; + sha256 = "0p81ha537bfs8421y74vrvhi1h61f38djr3iwgab30f6sdfj4k8j"; + system = "clerk"; + asd = "clerk"; + } + ); + systems = [ "clerk" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clerk-test = ( + build-asdf-system { + pname = "clerk-test"; + version = "20241012-git"; + asds = [ "clerk-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clerk/2024-10-12/clerk-20241012-git.tgz"; + sha256 = "0p81ha537bfs8421y74vrvhi1h61f38djr3iwgab30f6sdfj4k8j"; + system = "clerk-test"; + asd = "clerk"; + } + ); + systems = [ "clerk-test" ]; + lispLibs = [ + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clesh = ( + build-asdf-system { + pname = "clesh"; + version = "20201220-git"; + asds = [ "clesh" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clesh/2020-12-20/clesh-20201220-git.tgz"; + sha256 = "012ry02djnqyvvs61wbbqj3saz621w2l9gczrywdxhi5p4ycx318"; + system = "clesh"; + asd = "clesh"; + } + ); + systems = [ "clesh" ]; + lispLibs = [ + (getAttr "named-readtables" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clesh-tests = ( + build-asdf-system { + pname = "clesh-tests"; + version = "20201220-git"; + asds = [ "clesh-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clesh/2020-12-20/clesh-20201220-git.tgz"; + sha256 = "012ry02djnqyvvs61wbbqj3saz621w2l9gczrywdxhi5p4ycx318"; + system = "clesh-tests"; + asd = "clesh-tests"; + } + ); + systems = [ "clesh-tests" ]; + lispLibs = [ + (getAttr "clesh" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cletris = ( + build-asdf-system { + pname = "cletris"; + version = "20211020-git"; + asds = [ "cletris" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cletris/2021-10-20/cletris-20211020-git.tgz"; + sha256 = "0k7j0jg4dc6q7p7h3vin3hs0f7q8d7yarg2mw0c3hng19r4q9p8v"; + system = "cletris"; + asd = "cletris"; + } + ); + systems = [ "cletris" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "pal" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cletris-network = ( + build-asdf-system { + pname = "cletris-network"; + version = "20211020-git"; + asds = [ "cletris-network" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cletris/2021-10-20/cletris-20211020-git.tgz"; + sha256 = "0k7j0jg4dc6q7p7h3vin3hs0f7q8d7yarg2mw0c3hng19r4q9p8v"; + system = "cletris-network"; + asd = "cletris-network"; + } + ); + systems = [ "cletris-network" ]; + lispLibs = [ + (getAttr "cl-log" self) + (getAttr "cl-ppcre" self) + (getAttr "cletris" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cletris-test = ( + build-asdf-system { + pname = "cletris-test"; + version = "20211020-git"; + asds = [ "cletris-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cletris/2021-10-20/cletris-20211020-git.tgz"; + sha256 = "0k7j0jg4dc6q7p7h3vin3hs0f7q8d7yarg2mw0c3hng19r4q9p8v"; + system = "cletris-test"; + asd = "cletris-test"; + } + ); + systems = [ "cletris-test" ]; + lispLibs = [ + (getAttr "cletris" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clfswm = ( + build-asdf-system { + pname = "clfswm"; + version = "20161204-git"; + asds = [ "clfswm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clfswm/2016-12-04/clfswm-20161204-git.tgz"; + sha256 = "1r84cpcs74avkjw18ckz3r3836xhky2fcf5ypbfmajpjzxwn5dzc"; + system = "clfswm"; + asd = "clfswm"; + } + ); + systems = [ "clfswm" ]; + lispLibs = [ (getAttr "clx" self) ]; + meta = { }; + } + ); + clgplot = ( + build-asdf-system { + pname = "clgplot"; + version = "20241012-git"; + asds = [ "clgplot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clgplot/2024-10-12/clgplot-20241012-git.tgz"; + sha256 = "0sl5g33v1lpkjimmcs22f32hgnlfhz0ydd5rgy0ykwb7jf7x3pv7"; + system = "clgplot"; + asd = "clgplot"; + } + ); + systems = [ "clgplot" ]; + lispLibs = [ (getAttr "iterate" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clgplot-test = ( + build-asdf-system { + pname = "clgplot-test"; + version = "20241012-git"; + asds = [ "clgplot-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clgplot/2024-10-12/clgplot-20241012-git.tgz"; + sha256 = "0sl5g33v1lpkjimmcs22f32hgnlfhz0ydd5rgy0ykwb7jf7x3pv7"; + system = "clgplot-test"; + asd = "clgplot-test"; + } + ); + systems = [ "clgplot-test" ]; + lispLibs = [ + (getAttr "clgplot" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clhs = ( + build-asdf-system { + pname = "clhs"; + version = "0.6.3"; + asds = [ "clhs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clhs/2015-04-07/clhs-0.6.3.tgz"; + sha256 = "1jffq2w9yql4cvxy2g5c2v402014306qklp4xhddjjlfvs30sfjd"; + system = "clhs"; + asd = "clhs"; + } + ); + systems = [ "clhs" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cli-parser = ( + build-asdf-system { + pname = "cli-parser"; + version = "20150608-git"; + asds = [ "cli-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cli-parser/2015-06-08/cl-cli-parser-20150608-git.tgz"; + sha256 = "0gnpakzakkb2j67v2wh4q87k6mmrv0c0fg56m4vx88kgpxp7f90f"; + system = "cli-parser"; + asd = "cli-parser"; + } + ); + systems = [ "cli-parser" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clickr = ( + build-asdf-system { + pname = "clickr"; + version = "20140713-git"; + asds = [ "clickr" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clickr/2014-07-13/clickr-20140713-git.tgz"; + sha256 = "0sykp4aaxjf8xcyiqyqs6967f0fna8ahjqi7ij5z79fd530sxz2s"; + system = "clickr"; + asd = "clickr"; + } + ); + systems = [ "clickr" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "md5" self) + (getAttr "s-xml" self) + (getAttr "s-xml-rpc" self) + (getAttr "trivial-http" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clim = ( + build-asdf-system { + pname = "clim"; + version = "20241012-git"; + asds = [ "clim" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "clim"; + asd = "clim"; + } + ); + systems = [ "clim" ]; + lispLibs = [ + (getAttr "clim-core" self) + (getAttr "drei-mcclim" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clim-core = ( + build-asdf-system { + pname = "clim-core"; + version = "20241012-git"; + asds = [ "clim-core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "clim-core"; + asd = "clim-core"; + } + ); + systems = [ "clim-core" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "cluffer" self) + (getAttr "spatial-trees" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clim-debugger = ( + build-asdf-system { + pname = "clim-debugger"; + version = "20241012-git"; + asds = [ "clim-debugger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "clim-debugger"; + asd = "clim-debugger"; + } + ); + systems = [ "clim-debugger" ]; + lispLibs = [ + (getAttr "clouseau" self) + (getAttr "mcclim" self) + (getAttr "slim" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clim-examples = ( + build-asdf-system { + pname = "clim-examples"; + version = "20241012-git"; + asds = [ "clim-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "clim-examples"; + asd = "clim-examples"; + } + ); + systems = [ "clim-examples" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "clim" self) + (getAttr "closer-mop" self) + (getAttr "lorem-ipsum" self) + (getAttr "mcclim" self) + (getAttr "mcclim-raster-image" self) + (getAttr "mcclim-svg" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clim-lisp = ( + build-asdf-system { + pname = "clim-lisp"; + version = "20241012-git"; + asds = [ "clim-lisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "clim-lisp"; + asd = "clim-lisp"; + } + ); + systems = [ "clim-lisp" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "cluffer" self) + (getAttr "trivial-features" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clim-listener = ( + build-asdf-system { + pname = "clim-listener"; + version = "20241012-git"; + asds = [ "clim-listener" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "clim-listener"; + asd = "clim-listener"; + } + ); + systems = [ "clim-listener" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "clim-debugger" self) + (getAttr "mcclim" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clim-pdf = ( + build-asdf-system { + pname = "clim-pdf"; + version = "20241012-git"; + asds = [ "clim-pdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "clim-pdf"; + asd = "clim-pdf"; + } + ); + systems = [ "clim-pdf" ]; + lispLibs = [ + (getAttr "cl-pdf" self) + (getAttr "cl-pdf-parser" self) + (getAttr "clim" self) + (getAttr "clim-postscript" self) + (getAttr "clim-postscript-font" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clim-postscript = ( + build-asdf-system { + pname = "clim-postscript"; + version = "20241012-git"; + asds = [ "clim-postscript" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "clim-postscript"; + asd = "clim-postscript"; + } + ); + systems = [ "clim-postscript" ]; + lispLibs = [ + (getAttr "clim" self) + (getAttr "clim-postscript-font" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clim-postscript-font = ( + build-asdf-system { + pname = "clim-postscript-font"; + version = "20241012-git"; + asds = [ "clim-postscript-font" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "clim-postscript-font"; + asd = "clim-postscript-font"; + } + ); + systems = [ "clim-postscript-font" ]; + lispLibs = [ (getAttr "clim" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clim-widgets = ( + build-asdf-system { + pname = "clim-widgets"; + version = "20200715-git"; + asds = [ "clim-widgets" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clim-widgets/2020-07-15/clim-widgets-20200715-git.tgz"; + sha256 = "0cpr8xn5a33sy75d06b95cfd3b1h9m5iixgg5h4isavpx3aglmy2"; + system = "clim-widgets"; + asd = "clim-widgets"; + } + ); + systems = [ "clim-widgets" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "closer-mop" self) + (getAttr "local-time" self) + (getAttr "manifest" self) + (getAttr "mcclim" self) + (getAttr "nsort" self) + (getAttr "perlre" self) + (getAttr "simple-date-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + climacs = ( + build-asdf-system { + pname = "climacs"; + version = "20241012-git"; + asds = [ "climacs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/climacs/2024-10-12/climacs-20241012-git.tgz"; + sha256 = "0swbnsnavwaxpdcdsdag6iadc6v436pawbrzz6p8lkkbmbmc7yf8"; + system = "climacs"; + asd = "climacs"; + } + ); + systems = [ "climacs" ]; + lispLibs = [ + (getAttr "flexichain" self) + (getAttr "mcclim" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + climc = ( + build-asdf-system { + pname = "climc"; + version = "20230214-git"; + asds = [ "climc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/climc/2023-02-14/climc-20230214-git.tgz"; + sha256 = "0wnsyxkff5i4n36rwb5z54j4gi0j9n8459wcm6cj3lg77njmpasb"; + system = "climc"; + asd = "climc"; + } + ); + systems = [ "climc" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cl-xmpp-tls" self) + (getAttr "mcclim" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + climc-test = ( + build-asdf-system { + pname = "climc-test"; + version = "20230214-git"; + asds = [ "climc-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/climc/2023-02-14/climc-20230214-git.tgz"; + sha256 = "0wnsyxkff5i4n36rwb5z54j4gi0j9n8459wcm6cj3lg77njmpasb"; + system = "climc-test"; + asd = "climc-test"; + } + ); + systems = [ "climc-test" ]; + lispLibs = [ + (getAttr "climc" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + climon = ( + build-asdf-system { + pname = "climon"; + version = "20220220-git"; + asds = [ "climon" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/climon/2022-02-20/climon-20220220-git.tgz"; + sha256 = "00bdxpzgvmf5yg785xc9454nv7x5n314kywjd0f12mbvrgklb818"; + system = "climon"; + asd = "climon"; + } + ); + systems = [ "climon" ]; + lispLibs = [ (getAttr "pal" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + climon-test = ( + build-asdf-system { + pname = "climon-test"; + version = "20220220-git"; + asds = [ "climon-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/climon/2022-02-20/climon-20220220-git.tgz"; + sha256 = "00bdxpzgvmf5yg785xc9454nv7x5n314kywjd0f12mbvrgklb818"; + system = "climon-test"; + asd = "climon-test"; + } + ); + systems = [ "climon-test" ]; + lispLibs = [ + (getAttr "climon" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clinch = ( + build-asdf-system { + pname = "clinch"; + version = "20180228-git"; + asds = [ "clinch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clinch/2018-02-28/clinch-20180228-git.tgz"; + sha256 = "0hrj3kdxnazffrax3jmr6pgfahpj94lg43lczha6xpayhl49bqik"; + system = "clinch"; + asd = "clinch"; + } + ); + systems = [ "clinch" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-opengl" self) + (getAttr "rtg-math" self) + (getAttr "sdl2" self) + (getAttr "swank" self) + (getAttr "trivial-channels" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clinch-cairo = ( + build-asdf-system { + pname = "clinch-cairo"; + version = "20180228-git"; + asds = [ "clinch-cairo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clinch/2018-02-28/clinch-20180228-git.tgz"; + sha256 = "0hrj3kdxnazffrax3jmr6pgfahpj94lg43lczha6xpayhl49bqik"; + system = "clinch-cairo"; + asd = "clinch-cairo"; + } + ); + systems = [ "clinch-cairo" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-cairo2" self) + (getAttr "clinch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clinch-classimp = ( + build-asdf-system { + pname = "clinch-classimp"; + version = "20180228-git"; + asds = [ "clinch-classimp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clinch/2018-02-28/clinch-20180228-git.tgz"; + sha256 = "0hrj3kdxnazffrax3jmr6pgfahpj94lg43lczha6xpayhl49bqik"; + system = "clinch-classimp"; + asd = "clinch-classimp"; + } + ); + systems = [ "clinch-classimp" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "classimp" self) + (getAttr "clinch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clinch-freeimage = ( + build-asdf-system { + pname = "clinch-freeimage"; + version = "20180228-git"; + asds = [ "clinch-freeimage" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clinch/2018-02-28/clinch-20180228-git.tgz"; + sha256 = "0hrj3kdxnazffrax3jmr6pgfahpj94lg43lczha6xpayhl49bqik"; + system = "clinch-freeimage"; + asd = "clinch-freeimage"; + } + ); + systems = [ "clinch-freeimage" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-freeimage" self) + (getAttr "clinch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clinch-pango = ( + build-asdf-system { + pname = "clinch-pango"; + version = "20180228-git"; + asds = [ "clinch-pango" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clinch/2018-02-28/clinch-20180228-git.tgz"; + sha256 = "0hrj3kdxnazffrax3jmr6pgfahpj94lg43lczha6xpayhl49bqik"; + system = "clinch-pango"; + asd = "clinch-pango"; + } + ); + systems = [ "clinch-pango" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-cairo2" self) + (getAttr "cl-pango" self) + (getAttr "clinch" self) + (getAttr "clinch-cairo" self) + (getAttr "xmls" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clinenoise = ( + build-asdf-system { + pname = "clinenoise"; + version = "20200427-git"; + asds = [ "clinenoise" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clinenoise/2020-04-27/clinenoise-20200427-git.tgz"; + sha256 = "0ydlirfk4dbpqqjwwph99v5swcrhd8v9g8q24fvs35wn2vm08lh1"; + system = "clinenoise"; + asd = "clinenoise"; + } + ); + systems = [ "clinenoise" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clingon = ( + build-asdf-system { + pname = "clingon"; + version = "20241012-git"; + asds = [ "clingon" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clingon/2024-10-12/clingon-20241012-git.tgz"; + sha256 = "0p8i9bkzzy4v0pg15dldrl73xri4kxyxa7si82bawh1dnnm53jgc"; + system = "clingon"; + asd = "clingon"; + } + ); + systems = [ "clingon" ]; + lispLibs = [ + (getAttr "bobbin" self) + (getAttr "cl-reexport" self) + (getAttr "split-sequence" self) + (getAttr "with-user-abort" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clingon_dot_demo = ( + build-asdf-system { + pname = "clingon.demo"; + version = "20241012-git"; + asds = [ "clingon.demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clingon/2024-10-12/clingon-20241012-git.tgz"; + sha256 = "0p8i9bkzzy4v0pg15dldrl73xri4kxyxa7si82bawh1dnnm53jgc"; + system = "clingon.demo"; + asd = "clingon.demo"; + } + ); + systems = [ "clingon.demo" ]; + lispLibs = [ (getAttr "clingon" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clingon_dot_intro = ( + build-asdf-system { + pname = "clingon.intro"; + version = "20241012-git"; + asds = [ "clingon.intro" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clingon/2024-10-12/clingon-20241012-git.tgz"; + sha256 = "0p8i9bkzzy4v0pg15dldrl73xri4kxyxa7si82bawh1dnnm53jgc"; + system = "clingon.intro"; + asd = "clingon.intro"; + } + ); + systems = [ "clingon.intro" ]; + lispLibs = [ (getAttr "clingon" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clingon_dot_test = ( + build-asdf-system { + pname = "clingon.test"; + version = "20241012-git"; + asds = [ "clingon.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clingon/2024-10-12/clingon-20241012-git.tgz"; + sha256 = "0p8i9bkzzy4v0pg15dldrl73xri4kxyxa7si82bawh1dnnm53jgc"; + system = "clingon.test"; + asd = "clingon.test"; + } + ); + systems = [ "clingon.test" ]; + lispLibs = [ + (getAttr "clingon" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clip = ( + build-asdf-system { + pname = "clip"; + version = "20241012-git"; + asds = [ "clip" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clip/2024-10-12/clip-20241012-git.tgz"; + sha256 = "1ikzfza4s5xl67bz4vi05hmqmkvs5qr2ycy1f6vi1ihsdvjfify0"; + system = "clip"; + asd = "clip"; + } + ); + systems = [ "clip" ]; + lispLibs = [ + (getAttr "array-utils" self) + (getAttr "lquery" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clipper = ( + build-asdf-system { + pname = "clipper"; + version = "20150923-git"; + asds = [ "clipper" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clipper/2015-09-23/clipper-20150923-git.tgz"; + sha256 = "0xx1z7xjy2qkb6hx4bjjxcpv180lynpxrmx0741zk0qcxf32y56n"; + system = "clipper"; + asd = "clipper"; + } + ); + systems = [ "clipper" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "cl-syntax-annot" self) + (getAttr "closer-mop" self) + (getAttr "dexador" self) + (getAttr "fast-io" self) + (getAttr "opticl" self) + (getAttr "quri" self) + (getAttr "split-sequence" self) + (getAttr "zs3" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clipper-test = ( + build-asdf-system { + pname = "clipper-test"; + version = "20150923-git"; + asds = [ "clipper-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clipper/2015-09-23/clipper-20150923-git.tgz"; + sha256 = "0xx1z7xjy2qkb6hx4bjjxcpv180lynpxrmx0741zk0qcxf32y56n"; + system = "clipper-test"; + asd = "clipper-test"; + } + ); + systems = [ "clipper-test" ]; + lispLibs = [ + (getAttr "clipper" self) + (getAttr "integral" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clite = ( + build-asdf-system { + pname = "clite"; + version = "20130615-git"; + asds = [ "clite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clite/2013-06-15/clite-20130615-git.tgz"; + sha256 = "0q73vzm55i7m6in9i3fwwaqxvwm3pr7mm7gh7qsvfya61248ynrz"; + system = "clite"; + asd = "clite"; + } + ); + systems = [ "clite" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clith = ( + build-asdf-system { + pname = "clith"; + version = "20241012-git"; + asds = [ "clith" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clith/2024-10-12/clith-20241012-git.tgz"; + sha256 = "02qfyrnihx9x6nwxgzlh2x6ymz90i524jg8gc5zsy9rcfqj2sfa7"; + system = "clith"; + asd = "clith"; + } + ); + systems = [ "clith" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clj = ( + build-asdf-system { + pname = "clj"; + version = "20201220-git"; + asds = [ "clj" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clj/2020-12-20/clj-20201220-git.tgz"; + sha256 = "0yic6w2n09w3v2r1dlg9a7z59j9rapj4hpz8whcxlw6zs4wrwib2"; + system = "clj"; + asd = "clj"; + } + ); + systems = [ "clj" ]; + lispLibs = [ + (getAttr "agnostic-lizard" self) + (getAttr "arrow-macros" self) + (getAttr "cl-hamt" self) + (getAttr "local-package-aliases" self) + (getAttr "named-readtables" self) + (getAttr "optima" self) + (getAttr "prove-asdf" self) + (getAttr "test-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clj-arrows = ( + build-asdf-system { + pname = "clj-arrows"; + version = "20241012-git"; + asds = [ "clj-arrows" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clj-arrows/2024-10-12/clj-arrows-20241012-git.tgz"; + sha256 = "0b0dpjbyk41h32laqa4hwlgximafkjgrgdahabyc3blkg5v7lill"; + system = "clj-arrows"; + asd = "clj-arrows"; + } + ); + systems = [ "clj-arrows" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clj-arrows-test = ( + build-asdf-system { + pname = "clj-arrows-test"; + version = "20241012-git"; + asds = [ "clj-arrows-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clj-arrows/2024-10-12/clj-arrows-20241012-git.tgz"; + sha256 = "0b0dpjbyk41h32laqa4hwlgximafkjgrgdahabyc3blkg5v7lill"; + system = "clj-arrows-test"; + asd = "clj-arrows-test"; + } + ); + systems = [ "clj-arrows-test" ]; + lispLibs = [ + (getAttr "clj-arrows" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clj-con = ( + build-asdf-system { + pname = "clj-con"; + version = "20241012-git"; + asds = [ "clj-con" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clj-con/2024-10-12/clj-con-20241012-git.tgz"; + sha256 = "05zjw4ncwwpmckxqv61zhv1lcyfm7w4ic59ypcw5bypxwgkapa7c"; + system = "clj-con"; + asd = "clj-con"; + } + ); + systems = [ "clj-con" ]; + lispLibs = [ + (getAttr "atomics" self) + (getAttr "bordeaux-threads" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clj-con-test = ( + build-asdf-system { + pname = "clj-con-test"; + version = "20241012-git"; + asds = [ "clj-con-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clj-con/2024-10-12/clj-con-20241012-git.tgz"; + sha256 = "05zjw4ncwwpmckxqv61zhv1lcyfm7w4ic59ypcw5bypxwgkapa7c"; + system = "clj-con-test"; + asd = "clj-con-test"; + } + ); + systems = [ "clj-con-test" ]; + lispLibs = [ + (getAttr "clj-con" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clj-re = ( + build-asdf-system { + pname = "clj-re"; + version = "20241012-git"; + asds = [ "clj-re" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clj-re/2024-10-12/clj-re-20241012-git.tgz"; + sha256 = "05d0xqnhd50hmvicaq3a08m52c12j7cmxz99mpmk10mp0cv572bl"; + system = "clj-re"; + asd = "clj-re"; + } + ); + systems = [ "clj-re" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clj-re-test = ( + build-asdf-system { + pname = "clj-re-test"; + version = "20241012-git"; + asds = [ "clj-re-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clj-re/2024-10-12/clj-re-20241012-git.tgz"; + sha256 = "05d0xqnhd50hmvicaq3a08m52c12j7cmxz99mpmk10mp0cv572bl"; + system = "clj-re-test"; + asd = "clj-re-test"; + } + ); + systems = [ "clj-re-test" ]; + lispLibs = [ + (getAttr "clj-re" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml = ( + build-asdf-system { + pname = "clml"; + version = "20220220-git"; + asds = [ "clml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml"; + asd = "clml"; + } + ); + systems = [ "clml" ]; + lispLibs = [ + (getAttr "clml_dot_association-rule" self) + (getAttr "clml_dot_blas" self) + (getAttr "clml_dot_classifiers" self) + (getAttr "clml_dot_clustering" self) + (getAttr "clml_dot_data" self) + (getAttr "clml_dot_decision-tree" self) + (getAttr "clml_dot_graph" self) + (getAttr "clml_dot_hjs" self) + (getAttr "clml_dot_lapack" self) + (getAttr "clml_dot_nearest-search" self) + (getAttr "clml_dot_nonparametric" self) + (getAttr "clml_dot_numeric" self) + (getAttr "clml_dot_pca" self) + (getAttr "clml_dot_som" self) + (getAttr "clml_dot_statistics" self) + (getAttr "clml_dot_svm" self) + (getAttr "clml_dot_text" self) + (getAttr "clml_dot_time-series" self) + (getAttr "clml_dot_utility" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_association-rule = ( + build-asdf-system { + pname = "clml.association-rule"; + version = "20220220-git"; + asds = [ "clml.association-rule" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.association-rule"; + asd = "clml.association-rule"; + } + ); + systems = [ "clml.association-rule" ]; + lispLibs = [ (getAttr "clml_dot_hjs" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_blas = ( + build-asdf-system { + pname = "clml.blas"; + version = "20220220-git"; + asds = [ "clml.blas" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.blas"; + asd = "clml.blas"; + } + ); + systems = [ "clml.blas" ]; + lispLibs = [ + (getAttr "clml_dot_blas_dot_complex" self) + (getAttr "clml_dot_blas_dot_hompack" self) + (getAttr "clml_dot_blas_dot_real" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_blas_dot_complex = ( + build-asdf-system { + pname = "clml.blas.complex"; + version = "20220220-git"; + asds = [ "clml.blas.complex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.blas.complex"; + asd = "clml.blas"; + } + ); + systems = [ "clml.blas.complex" ]; + lispLibs = [ (getAttr "f2cl-lib" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_blas_dot_hompack = ( + build-asdf-system { + pname = "clml.blas.hompack"; + version = "20220220-git"; + asds = [ "clml.blas.hompack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.blas.hompack"; + asd = "clml.blas"; + } + ); + systems = [ "clml.blas.hompack" ]; + lispLibs = [ (getAttr "f2cl-lib" self) ]; + meta = { + broken = true; + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_blas_dot_real = ( + build-asdf-system { + pname = "clml.blas.real"; + version = "20220220-git"; + asds = [ "clml.blas.real" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.blas.real"; + asd = "clml.blas"; + } + ); + systems = [ "clml.blas.real" ]; + lispLibs = [ (getAttr "f2cl-lib" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_classifiers = ( + build-asdf-system { + pname = "clml.classifiers"; + version = "20220220-git"; + asds = [ "clml.classifiers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.classifiers"; + asd = "clml.classifiers"; + } + ); + systems = [ "clml.classifiers" ]; + lispLibs = [ + (getAttr "clml_dot_clustering" self) + (getAttr "clml_dot_hjs" self) + (getAttr "clml_dot_svm" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_clustering = ( + build-asdf-system { + pname = "clml.clustering"; + version = "20220220-git"; + asds = [ "clml.clustering" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.clustering"; + asd = "clml.clustering"; + } + ); + systems = [ "clml.clustering" ]; + lispLibs = [ + (getAttr "clml_dot_blas" self) + (getAttr "clml_dot_hjs" self) + (getAttr "clml_dot_nearest-search" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_data = ( + build-asdf-system { + pname = "clml.data"; + version = "20220220-git"; + asds = [ "clml.data" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.data"; + asd = "clml.data"; + } + ); + systems = [ "clml.data" ]; + lispLibs = [ (getAttr "clml_dot_data_dot_r-datasets" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_data_dot_r-datasets = ( + build-asdf-system { + pname = "clml.data.r-datasets"; + version = "20220220-git"; + asds = [ "clml.data.r-datasets" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.data.r-datasets"; + asd = "clml.data.r-datasets"; + } + ); + systems = [ "clml.data.r-datasets" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "clml_dot_hjs" self) + (getAttr "clml_dot_utility" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_decision-tree = ( + build-asdf-system { + pname = "clml.decision-tree"; + version = "20220220-git"; + asds = [ "clml.decision-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.decision-tree"; + asd = "clml.decision-tree"; + } + ); + systems = [ "clml.decision-tree" ]; + lispLibs = [ + (getAttr "clml_dot_hjs" self) + (getAttr "lparallel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_docs = ( + build-asdf-system { + pname = "clml.docs"; + version = "20220220-git"; + asds = [ "clml.docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.docs"; + asd = "clml.docs"; + } + ); + systems = [ "clml.docs" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "clml" self) + (getAttr "clod" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_graph = ( + build-asdf-system { + pname = "clml.graph"; + version = "20220220-git"; + asds = [ "clml.graph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.graph"; + asd = "clml.graph"; + } + ); + systems = [ "clml.graph" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "clml_dot_hjs" self) + (getAttr "clml_dot_statistics" self) + (getAttr "clml_dot_time-series" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_hjs = ( + build-asdf-system { + pname = "clml.hjs"; + version = "20220220-git"; + asds = [ "clml.hjs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.hjs"; + asd = "clml.hjs"; + } + ); + systems = [ "clml.hjs" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "clml_dot_blas" self) + (getAttr "clml_dot_lapack" self) + (getAttr "clml_dot_statistics" self) + (getAttr "clml_dot_utility" self) + (getAttr "future" self) + (getAttr "introspect-environment" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_lapack = ( + build-asdf-system { + pname = "clml.lapack"; + version = "20220220-git"; + asds = [ "clml.lapack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.lapack"; + asd = "clml.lapack"; + } + ); + systems = [ "clml.lapack" ]; + lispLibs = [ + (getAttr "clml_dot_blas" self) + (getAttr "clml_dot_lapack-real" self) + (getAttr "f2cl-lib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_lapack-real = ( + build-asdf-system { + pname = "clml.lapack-real"; + version = "20220220-git"; + asds = [ "clml.lapack-real" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.lapack-real"; + asd = "clml.lapack"; + } + ); + systems = [ "clml.lapack-real" ]; + lispLibs = [ + (getAttr "clml_dot_blas" self) + (getAttr "f2cl-lib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_nearest-search = ( + build-asdf-system { + pname = "clml.nearest-search"; + version = "20220220-git"; + asds = [ "clml.nearest-search" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.nearest-search"; + asd = "clml.nearest-search"; + } + ); + systems = [ "clml.nearest-search" ]; + lispLibs = [ + (getAttr "clml_dot_hjs" self) + (getAttr "clml_dot_nonparametric" self) + (getAttr "clml_dot_pca" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_nonparametric = ( + build-asdf-system { + pname = "clml.nonparametric"; + version = "20220220-git"; + asds = [ "clml.nonparametric" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.nonparametric"; + asd = "clml.nonparametric"; + } + ); + systems = [ "clml.nonparametric" ]; + lispLibs = [ (getAttr "clml_dot_hjs" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_numeric = ( + build-asdf-system { + pname = "clml.numeric"; + version = "20220220-git"; + asds = [ "clml.numeric" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.numeric"; + asd = "clml.numeric"; + } + ); + systems = [ "clml.numeric" ]; + lispLibs = [ (getAttr "clml_dot_hjs" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_pca = ( + build-asdf-system { + pname = "clml.pca"; + version = "20220220-git"; + asds = [ "clml.pca" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.pca"; + asd = "clml.pca"; + } + ); + systems = [ "clml.pca" ]; + lispLibs = [ + (getAttr "clml_dot_decision-tree" self) + (getAttr "clml_dot_hjs" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_pca_dot_examples = ( + build-asdf-system { + pname = "clml.pca.examples"; + version = "20220220-git"; + asds = [ "clml.pca.examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.pca.examples"; + asd = "clml.pca"; + } + ); + systems = [ "clml.pca.examples" ]; + lispLibs = [ + (getAttr "clml_dot_hjs" self) + (getAttr "clml_dot_pca" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_som = ( + build-asdf-system { + pname = "clml.som"; + version = "20220220-git"; + asds = [ "clml.som" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.som"; + asd = "clml.som"; + } + ); + systems = [ "clml.som" ]; + lispLibs = [ + (getAttr "clml_dot_hjs" self) + (getAttr "clml_dot_statistics" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_som_dot_example = ( + build-asdf-system { + pname = "clml.som.example"; + version = "20220220-git"; + asds = [ "clml.som.example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.som.example"; + asd = "clml.som"; + } + ); + systems = [ "clml.som.example" ]; + lispLibs = [ + (getAttr "clml_dot_hjs" self) + (getAttr "clml_dot_som" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_statistics = ( + build-asdf-system { + pname = "clml.statistics"; + version = "20220220-git"; + asds = [ "clml.statistics" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.statistics"; + asd = "clml.statistics"; + } + ); + systems = [ "clml.statistics" ]; + lispLibs = [ (getAttr "clml_dot_statistics_dot_rand" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_statistics_dot_rand = ( + build-asdf-system { + pname = "clml.statistics.rand"; + version = "20220220-git"; + asds = [ "clml.statistics.rand" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.statistics.rand"; + asd = "clml.statistics.rand"; + } + ); + systems = [ "clml.statistics.rand" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_svm = ( + build-asdf-system { + pname = "clml.svm"; + version = "20220220-git"; + asds = [ "clml.svm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.svm"; + asd = "clml.svm"; + } + ); + systems = [ "clml.svm" ]; + lispLibs = [ + (getAttr "clml_dot_decision-tree" self) + (getAttr "clml_dot_hjs" self) + (getAttr "future" self) + (getAttr "lparallel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_svm_dot_examples = ( + build-asdf-system { + pname = "clml.svm.examples"; + version = "20220220-git"; + asds = [ "clml.svm.examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.svm.examples"; + asd = "clml.svm"; + } + ); + systems = [ "clml.svm.examples" ]; + lispLibs = [ + (getAttr "clml_dot_hjs" self) + (getAttr "clml_dot_svm" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_test = ( + build-asdf-system { + pname = "clml.test"; + version = "20220220-git"; + asds = [ "clml.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.test"; + asd = "clml.test"; + } + ); + systems = [ "clml.test" ]; + lispLibs = [ + (getAttr "clml" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_text = ( + build-asdf-system { + pname = "clml.text"; + version = "20220220-git"; + asds = [ "clml.text" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.text"; + asd = "clml.text"; + } + ); + systems = [ "clml.text" ]; + lispLibs = [ + (getAttr "clml_dot_hjs" self) + (getAttr "clml_dot_nonparametric" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_time-series = ( + build-asdf-system { + pname = "clml.time-series"; + version = "20220220-git"; + asds = [ "clml.time-series" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.time-series"; + asd = "clml.time-series"; + } + ); + systems = [ "clml.time-series" ]; + lispLibs = [ + (getAttr "array-operations" self) + (getAttr "clml_dot_hjs" self) + (getAttr "clml_dot_numeric" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clml_dot_utility = ( + build-asdf-system { + pname = "clml.utility"; + version = "20220220-git"; + asds = [ "clml.utility" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "clml.utility"; + asd = "clml.utility"; + } + ); + systems = [ "clml.utility" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "iterate" self) + (getAttr "parse-number" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clnuplot = ( + build-asdf-system { + pname = "clnuplot"; + version = "20130128-darcs"; + asds = [ "clnuplot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clnuplot/2013-01-28/clnuplot-20130128-darcs.tgz"; + sha256 = "0yfaay5idv9lq4ilafj305sg349c960n3q400kdayr0gda6pqlqr"; + system = "clnuplot"; + asd = "clnuplot"; + } + ); + systems = [ "clnuplot" ]; + lispLibs = [ + (getAttr "cl-containers" self) + (getAttr "cl-mathstats" self) + (getAttr "metabang-bind" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clobber = ( + build-asdf-system { + pname = "clobber"; + version = "20241012-git"; + asds = [ "clobber" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clobber/2024-10-12/clobber-20241012-git.tgz"; + sha256 = "1n6j9q0czrzigw7vfahlylm1g8hmk7b1wm84jm94cgl8r5r3s8ra"; + system = "clobber"; + asd = "clobber"; + } + ); + systems = [ "clobber" ]; + lispLibs = [ (getAttr "clobber-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clobber-base = ( + build-asdf-system { + pname = "clobber-base"; + version = "20241012-git"; + asds = [ "clobber-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clobber/2024-10-12/clobber-20241012-git.tgz"; + sha256 = "1n6j9q0czrzigw7vfahlylm1g8hmk7b1wm84jm94cgl8r5r3s8ra"; + system = "clobber-base"; + asd = "clobber-base"; + } + ); + systems = [ "clobber-base" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clobber-test = ( + build-asdf-system { + pname = "clobber-test"; + version = "20241012-git"; + asds = [ "clobber-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clobber/2024-10-12/clobber-20241012-git.tgz"; + sha256 = "1n6j9q0czrzigw7vfahlylm1g8hmk7b1wm84jm94cgl8r5r3s8ra"; + system = "clobber-test"; + asd = "clobber-test"; + } + ); + systems = [ "clobber-test" ]; + lispLibs = [ (getAttr "clobber" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clod = ( + build-asdf-system { + pname = "clod"; + version = "20190307-hg"; + asds = [ "clod" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clod/2019-03-07/clod-20190307-hg.tgz"; + sha256 = "0sdlr6jlqnbiyf06648zhq8dpni3zy0n5rwjcrvm4hw7vcy8vhy1"; + system = "clod"; + asd = "clod"; + } + ); + systems = [ "clod" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clods-export = ( + build-asdf-system { + pname = "clods-export"; + version = "20210411-git"; + asds = [ "clods-export" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clods-export/2021-04-11/clods-export-20210411-git.tgz"; + sha256 = "1bbzrl855qjs88ni548filghb2y8fvklkik22amwzi6dbzvq48qx"; + system = "clods-export"; + asd = "clods-export"; + } + ); + systems = [ "clods-export" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "cxml" self) + (getAttr "iterate" self) + (getAttr "local-time" self) + (getAttr "zip" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clog = ( + build-asdf-system { + pname = "clog"; + version = "20241012-git"; + asds = [ "clog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clog/2024-10-12/clog-20241012-git.tgz"; + sha256 = "0hqpj9ji7kfqgcxdfnc7x202qzmb7zdkmjwcyhdllqs6b0ssw5lx"; + system = "clog"; + asd = "clog"; + } + ); + systems = [ "clog" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "atomics" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-dbi" self) + (getAttr "cl-isaac" self) + (getAttr "cl-pass" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-template" self) + (getAttr "clack" self) + (getAttr "closer-mop" self) + (getAttr "hunchentoot" self) + (getAttr "lack-middleware-static" self) + (getAttr "lack-request" self) + (getAttr "lack-util-writer-stream" self) + (getAttr "mgl-pax" self) + (getAttr "parse-float" self) + (getAttr "quri" self) + (getAttr "sqlite" self) + (getAttr "trivial-gray-streams" self) + (getAttr "websocket-driver" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clog-ace = ( + build-asdf-system { + pname = "clog-ace"; + version = "20241012-git"; + asds = [ "clog-ace" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clog-ace/2024-10-12/clog-ace-20241012-git.tgz"; + sha256 = "01hwaiccy5i81w22kya00jscgpjw6iib2hnklqwky88i35kbb4sj"; + system = "clog-ace"; + asd = "clog-ace"; + } + ); + systems = [ "clog-ace" ]; + lispLibs = [ (getAttr "clog" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clog-collection = ( + build-asdf-system { + pname = "clog-collection"; + version = "20241012-git"; + asds = [ "clog-collection" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clog-collection/2024-10-12/clog-collection-20241012-git.tgz"; + sha256 = "0f6rw9sla5f7jglbisving0c97vz3a5bbn59li0jzngqp8rqwsqx"; + system = "clog-collection"; + asd = "clog-collection"; + } + ); + systems = [ "clog-collection" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "clog" self) + (getAttr "iterate" self) + (getAttr "literate-lisp" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clog-plotly = ( + build-asdf-system { + pname = "clog-plotly"; + version = "20241012-git"; + asds = [ "clog-plotly" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clog-plotly/2024-10-12/clog-plotly-20241012-git.tgz"; + sha256 = "064fhfhh5nr1g9f4pn9x2ydmxdnxmvyxhwgbl3dgqm416scjzzs1"; + system = "clog-plotly"; + asd = "clog-plotly"; + } + ); + systems = [ "clog-plotly" ]; + lispLibs = [ (getAttr "clog" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clog-terminal = ( + build-asdf-system { + pname = "clog-terminal"; + version = "20241012-git"; + asds = [ "clog-terminal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clog-terminal/2024-10-12/clog-terminal-20241012-git.tgz"; + sha256 = "1pvrja8fvdzqmiqzl23lb7665vcpx9lhwxahns81wlykkyx7cjd5"; + system = "clog-terminal"; + asd = "clog-terminal"; + } + ); + systems = [ "clog-terminal" ]; + lispLibs = [ (getAttr "clog" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clohost = ( + build-asdf-system { + pname = "clohost"; + version = "20241012-git"; + asds = [ "clohost" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clohost/2024-10-12/clohost-20241012-git.tgz"; + sha256 = "1qph7nrjb62qxwkv5wbzqkycdavsjvi39b97qvs5g8jsrvbl50lh"; + system = "clohost"; + asd = "clohost"; + } + ); + systems = [ "clohost" ]; + lispLibs = [ + (getAttr "com_dot_inuoe_dot_jzon" self) + (getAttr "crypto-shortcuts" self) + (getAttr "documentation-utils" self) + (getAttr "drakma" self) + (getAttr "trivial-mimes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clonsigna = ( + build-asdf-system { + pname = "clonsigna"; + version = "20120909-git"; + asds = [ "clonsigna" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clonsigna/2012-09-09/clonsigna-20120909-git.tgz"; + sha256 = "052vdch0q07sx3j615qgw8z536fmqz8fm3qv7f298ql3wcskrj7j"; + system = "clonsigna"; + asd = "clonsigna"; + } + ); + systems = [ "clonsigna" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl_plus_ssl" self) + (getAttr "cl-base64" self) + (getAttr "cl-ppcre" self) + (getAttr "iolib" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clop = ( + build-asdf-system { + pname = "clop"; + version = "v1.0.1"; + asds = [ "clop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clop/2022-02-20/clop-v1.0.1.tgz"; + sha256 = "1q7rlizr8gcbfz4a9660gdbw7d2zbld18akjpibg54j7jh5kb8gc"; + system = "clop"; + asd = "clop"; + } + ); + systems = [ "clop" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "esrap" self) + (getAttr "local-time" self) + (getAttr "parse-number" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clop-tests = ( + build-asdf-system { + pname = "clop-tests"; + version = "v1.0.1"; + asds = [ "clop-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clop/2022-02-20/clop-v1.0.1.tgz"; + sha256 = "1q7rlizr8gcbfz4a9660gdbw7d2zbld18akjpibg54j7jh5kb8gc"; + system = "clop-tests"; + asd = "clop"; + } + ); + systems = [ "clop-tests" ]; + lispLibs = [ + (getAttr "clop" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clos-diff = ( + build-asdf-system { + pname = "clos-diff"; + version = "20150608-git"; + asds = [ "clos-diff" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clos-diff/2015-06-08/clos-diff-20150608-git.tgz"; + sha256 = "0y6chxzqwwwkrrmxxb74wwci6i4ck6i3fq36w9gl03qbrksfyjkz"; + system = "clos-diff"; + asd = "clos-diff"; + } + ); + systems = [ "clos-diff" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clos-encounters = ( + build-asdf-system { + pname = "clos-encounters"; + version = "20241012-git"; + asds = [ "clos-encounters" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clos-encounters/2024-10-12/clos-encounters-20241012-git.tgz"; + sha256 = "021ygh6s5qb7l155bcp9qv1w2dhq9csscasp77vjlms1ahpq9ixf"; + system = "clos-encounters"; + asd = "clos-encounters"; + } + ); + systems = [ "clos-encounters" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clos-fixtures = ( + build-asdf-system { + pname = "clos-fixtures"; + version = "20160825-git"; + asds = [ "clos-fixtures" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clos-fixtures/2016-08-25/clos-fixtures-20160825-git.tgz"; + sha256 = "1a3yvqszdwnsnk5hr4zrdpaqxb8vlxpl2nhxjl0j97fnmfaiqjhk"; + system = "clos-fixtures"; + asd = "clos-fixtures"; + } + ); + systems = [ "clos-fixtures" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clos-fixtures-test = ( + build-asdf-system { + pname = "clos-fixtures-test"; + version = "20160825-git"; + asds = [ "clos-fixtures-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clos-fixtures/2016-08-25/clos-fixtures-20160825-git.tgz"; + sha256 = "1a3yvqszdwnsnk5hr4zrdpaqxb8vlxpl2nhxjl0j97fnmfaiqjhk"; + system = "clos-fixtures-test"; + asd = "clos-fixtures-test"; + } + ); + systems = [ "clos-fixtures-test" ]; + lispLibs = [ + (getAttr "clos-fixtures" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + closer-mop = ( + build-asdf-system { + pname = "closer-mop"; + version = "20241012-git"; + asds = [ "closer-mop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/closer-mop/2024-10-12/closer-mop-20241012-git.tgz"; + sha256 = "1affaqh0sm1phs6qa12vbhf69abssjcpy55cwf4fi4nd6hgcrfqr"; + system = "closer-mop"; + asd = "closer-mop"; + } + ); + systems = [ "closer-mop" ]; + lispLibs = [ ]; + meta = { }; + } + ); + closure-common = ( + build-asdf-system { + pname = "closure-common"; + version = "20181018-git"; + asds = [ "closure-common" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/closure-common/2018-10-18/closure-common-20181018-git.tgz"; + sha256 = "0k5r2qxn122pxi301ijir3nayi9sg4d7yiy276l36qmzwhp4mg5n"; + system = "closure-common"; + asd = "closure-common"; + } + ); + systems = [ "closure-common" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + closure-html = ( + build-asdf-system { + pname = "closure-html"; + version = "20180711-git"; + asds = [ "closure-html" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/closure-html/2018-07-11/closure-html-20180711-git.tgz"; + sha256 = "105vm29qnxh6zj3rh4jwpm8dyp3b9bsva64c8a78cr270p28d032"; + system = "closure-html"; + asd = "closure-html"; + } + ); + systems = [ "closure-html" ]; + lispLibs = [ + (getAttr "closure-common" self) + (getAttr "flexi-streams" self) + ]; + meta = { }; + } + ); + closure-template = ( + build-asdf-system { + pname = "closure-template"; + version = "20150804-git"; + asds = [ "closure-template" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-closure-template/2015-08-04/cl-closure-template-20150804-git.tgz"; + sha256 = "16h0fs6bjjd4n9pbkwcprpgyj26vsw2akk3q08m7xmsmqi05dppv"; + system = "closure-template"; + asd = "closure-template"; + } + ); + systems = [ "closure-template" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "closer-mop" self) + (getAttr "esrap" self) + (getAttr "iterate" self) + (getAttr "parse-number" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + closure-template-test = ( + build-asdf-system { + pname = "closure-template-test"; + version = "20150804-git"; + asds = [ "closure-template-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-closure-template/2015-08-04/cl-closure-template-20150804-git.tgz"; + sha256 = "16h0fs6bjjd4n9pbkwcprpgyj26vsw2akk3q08m7xmsmqi05dppv"; + system = "closure-template-test"; + asd = "closure-template"; + } + ); + systems = [ "closure-template-test" ]; + lispLibs = [ + (getAttr "closure-template" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clouchdb = ( + build-asdf-system { + pname = "clouchdb"; + version = "0.0.16"; + asds = [ "clouchdb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clouchdb/2012-04-07/clouchdb_0.0.16.tgz"; + sha256 = "1zfk4wkz0k5gbfznnbds0gcpc2y08p47rq7mhchf27v6rqg4kd7d"; + system = "clouchdb"; + asd = "clouchdb"; + } + ); + systems = [ "clouchdb" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + (getAttr "parenscript" self) + (getAttr "s-base64" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clouchdb-examples = ( + build-asdf-system { + pname = "clouchdb-examples"; + version = "0.0.16"; + asds = [ "clouchdb-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clouchdb/2012-04-07/clouchdb_0.0.16.tgz"; + sha256 = "1zfk4wkz0k5gbfznnbds0gcpc2y08p47rq7mhchf27v6rqg4kd7d"; + system = "clouchdb-examples"; + asd = "clouchdb-examples"; + } + ); + systems = [ "clouchdb-examples" ]; + lispLibs = [ + (getAttr "clouchdb" self) + (getAttr "parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clouseau = ( + build-asdf-system { + pname = "clouseau"; + version = "20241012-git"; + asds = [ "clouseau" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "clouseau"; + asd = "clouseau"; + } + ); + systems = [ "clouseau" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "mcclim" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clpython = ( + build-asdf-system { + pname = "clpython"; + version = "20220331-git"; + asds = [ "clpython" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-python/2022-03-31/cl-python-20220331-git.tgz"; + sha256 = "1liskpyfd8rbqn45xbymwvh4vic05pyvvf3hnq2ybyixwnkan9i9"; + system = "clpython"; + asd = "clpython"; + } + ); + systems = [ "clpython" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "closer-mop" self) + (getAttr "yacc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql = ( + build-asdf-system { + pname = "clsql"; + version = "20221106-git"; + asds = [ "clsql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; + sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; + system = "clsql"; + asd = "clsql"; + } + ); + systems = [ "clsql" ]; + lispLibs = [ (getAttr "uffi" self) ]; + meta = { }; + } + ); + clsql-aodbc = ( + build-asdf-system { + pname = "clsql-aodbc"; + version = "20221106-git"; + asds = [ "clsql-aodbc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; + sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; + system = "clsql-aodbc"; + asd = "clsql-aodbc"; + } + ); + systems = [ "clsql-aodbc" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-cffi = ( + build-asdf-system { + pname = "clsql-cffi"; + version = "20221106-git"; + asds = [ "clsql-cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; + sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; + system = "clsql-cffi"; + asd = "clsql-cffi"; + } + ); + systems = [ "clsql-cffi" ]; + lispLibs = [ (getAttr "clsql" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-fluid = ( + build-asdf-system { + pname = "clsql-fluid"; + version = "20170830-git"; + asds = [ "clsql-fluid" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql-fluid/2017-08-30/clsql-fluid-20170830-git.tgz"; + sha256 = "0i7x1xbh83wfr3k4ddsdy57yf0nqfhdxcbwv1na1ina6m5javg11"; + system = "clsql-fluid"; + asd = "clsql-fluid"; + } + ); + systems = [ "clsql-fluid" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "clsql" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-helper = ( + build-asdf-system { + pname = "clsql-helper"; + version = "20180131-git"; + asds = [ "clsql-helper" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql-helper/2018-01-31/clsql-helper-20180131-git.tgz"; + sha256 = "0yc6m8yh0gcark98wvjjwdq3xxy308x15pb7fzha6svxa06hf27g"; + system = "clsql-helper"; + asd = "clsql-helper"; + } + ); + systems = [ "clsql-helper" ]; + lispLibs = [ + (getAttr "access" self) + (getAttr "alexandria" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "clsql" self) + (getAttr "collectors" self) + (getAttr "iterate" self) + (getAttr "md5" self) + (getAttr "symbol-munger" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-helper-slot-coercer = ( + build-asdf-system { + pname = "clsql-helper-slot-coercer"; + version = "20180131-git"; + asds = [ "clsql-helper-slot-coercer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql-helper/2018-01-31/clsql-helper-20180131-git.tgz"; + sha256 = "0yc6m8yh0gcark98wvjjwdq3xxy308x15pb7fzha6svxa06hf27g"; + system = "clsql-helper-slot-coercer"; + asd = "clsql-helper-slot-coercer"; + } + ); + systems = [ "clsql-helper-slot-coercer" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "clsql-helper" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-helper-slot-coercer-test = ( + build-asdf-system { + pname = "clsql-helper-slot-coercer-test"; + version = "20180131-git"; + asds = [ "clsql-helper-slot-coercer-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql-helper/2018-01-31/clsql-helper-20180131-git.tgz"; + sha256 = "0yc6m8yh0gcark98wvjjwdq3xxy308x15pb7fzha6svxa06hf27g"; + system = "clsql-helper-slot-coercer-test"; + asd = "clsql-helper-slot-coercer"; + } + ); + systems = [ "clsql-helper-slot-coercer-test" ]; + lispLibs = [ + (getAttr "clsql-helper-slot-coercer" self) + (getAttr "lisp-unit2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-helper-test = ( + build-asdf-system { + pname = "clsql-helper-test"; + version = "20180131-git"; + asds = [ "clsql-helper-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql-helper/2018-01-31/clsql-helper-20180131-git.tgz"; + sha256 = "0yc6m8yh0gcark98wvjjwdq3xxy308x15pb7fzha6svxa06hf27g"; + system = "clsql-helper-test"; + asd = "clsql-helper"; + } + ); + systems = [ "clsql-helper-test" ]; + lispLibs = [ + (getAttr "clsql-helper" self) + (getAttr "clsql-tests" self) + (getAttr "lisp-unit2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-local-time = ( + build-asdf-system { + pname = "clsql-local-time"; + version = "20201016-git"; + asds = [ "clsql-local-time" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql-local-time/2020-10-16/clsql-local-time-20201016-git.tgz"; + sha256 = "1ipv6ij1md5mw44cbif31hiccrric3302rhssj8f7kg3s8n6mphv"; + system = "clsql-local-time"; + asd = "clsql-local-time"; + } + ); + systems = [ "clsql-local-time" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-mysql = ( + build-asdf-system { + pname = "clsql-mysql"; + version = "20221106-git"; + asds = [ "clsql-mysql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; + sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; + system = "clsql-mysql"; + asd = "clsql-mysql"; + } + ); + systems = [ "clsql-mysql" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "clsql-uffi" self) + (getAttr "uffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-odbc = ( + build-asdf-system { + pname = "clsql-odbc"; + version = "20221106-git"; + asds = [ "clsql-odbc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; + sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; + system = "clsql-odbc"; + asd = "clsql-odbc"; + } + ); + systems = [ "clsql-odbc" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "clsql-uffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-orm = ( + build-asdf-system { + pname = "clsql-orm"; + version = "20160208-git"; + asds = [ "clsql-orm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql-orm/2016-02-08/clsql-orm-20160208-git.tgz"; + sha256 = "1y9604k0mj8h03p85l5nrjkihr3yfj5fp910db9f4ksd1ln2qkka"; + system = "clsql-orm"; + asd = "clsql-orm"; + } + ); + systems = [ "clsql-orm" ]; + lispLibs = [ + (getAttr "cl-inflector" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "clsql" self) + (getAttr "iterate" self) + (getAttr "symbol-munger" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-postgresql = ( + build-asdf-system { + pname = "clsql-postgresql"; + version = "20221106-git"; + asds = [ "clsql-postgresql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; + sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; + system = "clsql-postgresql"; + asd = "clsql-postgresql"; + } + ); + systems = [ "clsql-postgresql" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "clsql-uffi" self) + ]; + meta = { }; + } + ); + clsql-postgresql-socket = ( + build-asdf-system { + pname = "clsql-postgresql-socket"; + version = "20221106-git"; + asds = [ "clsql-postgresql-socket" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; + sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; + system = "clsql-postgresql-socket"; + asd = "clsql-postgresql-socket"; + } + ); + systems = [ "clsql-postgresql-socket" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "md5" self) + (getAttr "uffi" self) + ]; + meta = { }; + } + ); + clsql-postgresql-socket3 = ( + build-asdf-system { + pname = "clsql-postgresql-socket3"; + version = "20221106-git"; + asds = [ "clsql-postgresql-socket3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; + sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; + system = "clsql-postgresql-socket3"; + asd = "clsql-postgresql-socket3"; + } + ); + systems = [ "clsql-postgresql-socket3" ]; + lispLibs = [ + (getAttr "cl-postgres" self) + (getAttr "clsql" self) + (getAttr "md5" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-sqlite = ( + build-asdf-system { + pname = "clsql-sqlite"; + version = "20221106-git"; + asds = [ "clsql-sqlite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; + sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; + system = "clsql-sqlite"; + asd = "clsql-sqlite"; + } + ); + systems = [ "clsql-sqlite" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "clsql-uffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-sqlite3 = ( + build-asdf-system { + pname = "clsql-sqlite3"; + version = "20221106-git"; + asds = [ "clsql-sqlite3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; + sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; + system = "clsql-sqlite3"; + asd = "clsql-sqlite3"; + } + ); + systems = [ "clsql-sqlite3" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "clsql-uffi" self) + ]; + meta = { }; + } + ); + clsql-tests = ( + build-asdf-system { + pname = "clsql-tests"; + version = "20221106-git"; + asds = [ "clsql-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; + sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; + system = "clsql-tests"; + asd = "clsql-tests"; + } + ); + systems = [ "clsql-tests" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "rt" self) + (getAttr "uffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clsql-uffi = ( + build-asdf-system { + pname = "clsql-uffi"; + version = "20221106-git"; + asds = [ "clsql-uffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clsql/2022-11-06/clsql-20221106-git.tgz"; + sha256 = "15kxrjv88ai9nvzxswa6rp8dbd1ad3816r4c5zb8xynsd8i5vpz0"; + system = "clsql-uffi"; + asd = "clsql-uffi"; + } + ); + systems = [ "clsql-uffi" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "uffi" self) + ]; + meta = { }; + } + ); + clss = ( + build-asdf-system { + pname = "clss"; + version = "20241012-git"; + asds = [ "clss" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clss/2024-10-12/clss-20241012-git.tgz"; + sha256 = "1l2yq6wi8wmb7l8fy6w4xb3mb2yd9d14ijgqdsbnwb5k2hbmndbf"; + system = "clss"; + asd = "clss"; + } + ); + systems = [ "clss" ]; + lispLibs = [ + (getAttr "array-utils" self) + (getAttr "plump" self) + ]; + meta = { }; + } + ); + cltcl = ( + build-asdf-system { + pname = "cltcl"; + version = "20161204-git"; + asds = [ "cltcl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cltcl/2016-12-04/cltcl-20161204-git.tgz"; + sha256 = "18b7fa7m9h9xfhnkxa6r3xzj86p1fvq0mh5q8vdrdv3vxfyc2l68"; + system = "cltcl"; + asd = "cltcl"; + } + ); + systems = [ "cltcl" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cluffer = ( + build-asdf-system { + pname = "cluffer"; + version = "20241012-git"; + asds = [ "cluffer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; + sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; + system = "cluffer"; + asd = "cluffer"; + } + ); + systems = [ "cluffer" ]; + lispLibs = [ + (getAttr "cluffer-base" self) + (getAttr "cluffer-simple-buffer" self) + (getAttr "cluffer-simple-line" self) + (getAttr "cluffer-standard-buffer" self) + (getAttr "cluffer-standard-line" self) + ]; + meta = { }; + } + ); + cluffer-base = ( + build-asdf-system { + pname = "cluffer-base"; + version = "20241012-git"; + asds = [ "cluffer-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; + sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; + system = "cluffer-base"; + asd = "cluffer-base"; + } + ); + systems = [ "cluffer-base" ]; + lispLibs = [ (getAttr "acclimation" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cluffer-simple-buffer = ( + build-asdf-system { + pname = "cluffer-simple-buffer"; + version = "20241012-git"; + asds = [ "cluffer-simple-buffer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; + sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; + system = "cluffer-simple-buffer"; + asd = "cluffer-simple-buffer"; + } + ); + systems = [ "cluffer-simple-buffer" ]; + lispLibs = [ (getAttr "cluffer-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cluffer-simple-line = ( + build-asdf-system { + pname = "cluffer-simple-line"; + version = "20241012-git"; + asds = [ "cluffer-simple-line" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; + sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; + system = "cluffer-simple-line"; + asd = "cluffer-simple-line"; + } + ); + systems = [ "cluffer-simple-line" ]; + lispLibs = [ (getAttr "cluffer-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cluffer-standard-buffer = ( + build-asdf-system { + pname = "cluffer-standard-buffer"; + version = "20241012-git"; + asds = [ "cluffer-standard-buffer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; + sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; + system = "cluffer-standard-buffer"; + asd = "cluffer-standard-buffer"; + } + ); + systems = [ "cluffer-standard-buffer" ]; + lispLibs = [ + (getAttr "cluffer-base" self) + (getAttr "clump" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cluffer-standard-line = ( + build-asdf-system { + pname = "cluffer-standard-line"; + version = "20241012-git"; + asds = [ "cluffer-standard-line" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; + sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; + system = "cluffer-standard-line"; + asd = "cluffer-standard-line"; + } + ); + systems = [ "cluffer-standard-line" ]; + lispLibs = [ (getAttr "cluffer-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cluffer-test = ( + build-asdf-system { + pname = "cluffer-test"; + version = "20241012-git"; + asds = [ "cluffer-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cluffer/2024-10-12/cluffer-20241012-git.tgz"; + sha256 = "1q5232v9vkjmiks2ciqj1fa1h3gh53rfhl301wp46jwra3r7qqyg"; + system = "cluffer-test"; + asd = "cluffer-test"; + } + ); + systems = [ "cluffer-test" ]; + lispLibs = [ (getAttr "cluffer" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clump = ( + build-asdf-system { + pname = "clump"; + version = "20160825-git"; + asds = [ "clump" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clump/2016-08-25/clump-20160825-git.tgz"; + sha256 = "1639msyagsswj85gc0wd90jgh8588j3qg5q70by9s2brf2q6w4lh"; + system = "clump"; + asd = "clump"; + } + ); + systems = [ "clump" ]; + lispLibs = [ + (getAttr "clump-2-3-tree" self) + (getAttr "clump-binary-tree" self) + ]; + meta = { }; + } + ); + clump-2-3-tree = ( + build-asdf-system { + pname = "clump-2-3-tree"; + version = "20160825-git"; + asds = [ "clump-2-3-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clump/2016-08-25/clump-20160825-git.tgz"; + sha256 = "1639msyagsswj85gc0wd90jgh8588j3qg5q70by9s2brf2q6w4lh"; + system = "clump-2-3-tree"; + asd = "clump-2-3-tree"; + } + ); + systems = [ "clump-2-3-tree" ]; + lispLibs = [ (getAttr "acclimation" self) ]; + meta = { }; + } + ); + clump-binary-tree = ( + build-asdf-system { + pname = "clump-binary-tree"; + version = "20160825-git"; + asds = [ "clump-binary-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clump/2016-08-25/clump-20160825-git.tgz"; + sha256 = "1639msyagsswj85gc0wd90jgh8588j3qg5q70by9s2brf2q6w4lh"; + system = "clump-binary-tree"; + asd = "clump-binary-tree"; + } + ); + systems = [ "clump-binary-tree" ]; + lispLibs = [ (getAttr "acclimation" self) ]; + meta = { }; + } + ); + clump-test = ( + build-asdf-system { + pname = "clump-test"; + version = "20160825-git"; + asds = [ "clump-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clump/2016-08-25/clump-20160825-git.tgz"; + sha256 = "1639msyagsswj85gc0wd90jgh8588j3qg5q70by9s2brf2q6w4lh"; + system = "clump-test"; + asd = "clump-test"; + } + ); + systems = [ "clump-test" ]; + lispLibs = [ (getAttr "clump" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clunit = ( + build-asdf-system { + pname = "clunit"; + version = "20171019-git"; + asds = [ "clunit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clunit/2017-10-19/clunit-20171019-git.tgz"; + sha256 = "1idf2xnqzlhi8rbrqmzpmb3i1l6pbdzhhajkmhwbp6qjkmxa4h85"; + system = "clunit"; + asd = "clunit"; + } + ); + systems = [ "clunit" ]; + lispLibs = [ ]; + meta = { }; + } + ); + clunit2 = ( + build-asdf-system { + pname = "clunit2"; + version = "20241012-git"; + asds = [ "clunit2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clunit2/2024-10-12/clunit2-20241012-git.tgz"; + sha256 = "03k4wc2zz31wcqcxy8fhq095i8xzcaxrzgrlrn2va10lcjs4v51b"; + system = "clunit2"; + asd = "clunit2"; + } + ); + systems = [ "clunit2" ]; + lispLibs = [ ]; + meta = { }; + } + ); + clustered-intset = ( + build-asdf-system { + pname = "clustered-intset"; + version = "20220707-git"; + asds = [ "clustered-intset" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clustered-intset/2022-07-07/clustered-intset-20220707-git.tgz"; + sha256 = "035s2gn59l8389b0ypnb4qna7zplz9rxk05aw88qf8g4b7wyba1h"; + system = "clustered-intset"; + asd = "clustered-intset"; + } + ); + systems = [ "clustered-intset" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clustered-intset-test = ( + build-asdf-system { + pname = "clustered-intset-test"; + version = "20220707-git"; + asds = [ "clustered-intset-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clustered-intset/2022-07-07/clustered-intset-20220707-git.tgz"; + sha256 = "035s2gn59l8389b0ypnb4qna7zplz9rxk05aw88qf8g4b7wyba1h"; + system = "clustered-intset-test"; + asd = "clustered-intset-test"; + } + ); + systems = [ "clustered-intset-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "clustered-intset" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clusters = ( + build-asdf-system { + pname = "clusters"; + version = "20220331-git"; + asds = [ "clusters" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clusters/2022-03-31/clusters-20220331-git.tgz"; + sha256 = "1x78ihrrah0rrb2ddxmxqcqpkswdvb3f0via56bkf1f3f5kqmsb8"; + system = "clusters"; + asd = "clusters"; + } + ); + systems = [ "clusters" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-data-structures" self) + (getAttr "documentation-utils-extensions" self) + (getAttr "iterate" self) + (getAttr "lparallel" self) + (getAttr "metabang-bind" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clusters-tests = ( + build-asdf-system { + pname = "clusters-tests"; + version = "20220331-git"; + asds = [ "clusters-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clusters/2022-03-31/clusters-20220331-git.tgz"; + sha256 = "1x78ihrrah0rrb2ddxmxqcqpkswdvb3f0via56bkf1f3f5kqmsb8"; + system = "clusters-tests"; + asd = "clusters-tests"; + } + ); + systems = [ "clusters-tests" ]; + lispLibs = [ + (getAttr "clusters" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clutter = ( + build-asdf-system { + pname = "clutter"; + version = "v1.0.0"; + asds = [ "clutter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clutter/2021-10-20/clutter-v1.0.0.tgz"; + sha256 = "1q9mg4d0nja9ypm13i24wymhjwziw6n7r7p1dzw6xc5zhavqsni7"; + system = "clutter"; + asd = "clutter"; + } + ); + systems = [ "clutter" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "doplus" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clweb = ( + build-asdf-system { + pname = "clweb"; + version = "20201220-git"; + asds = [ "clweb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clweb/2020-12-20/clweb-20201220-git.tgz"; + sha256 = "0hqyrglgsgal5s8f0n247hg0hqlw6l6w1r5i8lzf0a0xvcz49f48"; + system = "clweb"; + asd = "clweb"; + } + ); + systems = [ "clweb" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clws = ( + build-asdf-system { + pname = "clws"; + version = "20130813-git"; + asds = [ "clws" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clws/2013-08-13/clws-20130813-git.tgz"; + sha256 = "1svj025zwsbkb0hrbz1nj0x306hkhy9xinq0x1qdflc9vg169dh6"; + system = "clws"; + asd = "clws"; + } + ); + systems = [ "clws" ]; + lispLibs = [ + (getAttr "chunga" self) + (getAttr "cl-base64" self) + (getAttr "flexi-streams" self) + (getAttr "iolib" self) + (getAttr "ironclad" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + clx = ( + build-asdf-system { + pname = "clx"; + version = "20241012-git"; + asds = [ "clx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clx/2024-10-12/clx-20241012-git.tgz"; + sha256 = "16l0badm7dxwi7x5ynk1scrbrilnxi1nzz79h1v15xi6b41pf65w"; + system = "clx"; + asd = "clx"; + } + ); + systems = [ "clx" ]; + lispLibs = [ ]; + meta = { }; + } + ); + cmake-parser = ( + build-asdf-system { + pname = "cmake-parser"; + version = "20180831-git"; + asds = [ "cmake-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cmake-parser/2018-08-31/cmake-parser-20180831-git.tgz"; + sha256 = "1sb5pwxhg7k41202kvxj1b60c5pxnl0mfbqdz53xayddngn2brgl"; + system = "cmake-parser"; + asd = "cmake-parser"; + } + ); + systems = [ "cmake-parser" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "esrap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cmark = ( + build-asdf-system { + pname = "cmark"; + version = "20241012-git"; + asds = [ "cmark" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cmark/2024-10-12/cl-cmark-20241012-git.tgz"; + sha256 = "1l4i530161ppfz0wn1da7g7dwf644ppp1afrq2p7qfkajm7dcfg5"; + system = "cmark"; + asd = "cmark"; + } + ); + systems = [ "cmark" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "flexi-streams" self) + (getAttr "libcmark" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cmd = ( + build-asdf-system { + pname = "cmd"; + version = "20241012-git"; + asds = [ "cmd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cmd/2024-10-12/cmd-20241012-git.tgz"; + sha256 = "0rs2priccm34yx8cj29214i4bwa908gqs1ss23gyjb7v5qcq1sj7"; + system = "cmd"; + asd = "cmd"; + } + ); + systems = [ "cmd" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "serapeum" self) + (getAttr "shlex" self) + (getAttr "trivia" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cmu-infix = ( + build-asdf-system { + pname = "cmu-infix"; + version = "20180228-git"; + asds = [ "cmu-infix" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cmu-infix/2018-02-28/cmu-infix-20180228-git.tgz"; + sha256 = "0macs398088cfif1dkjrpmidk515sjl7ld96f9ys5cpzx8sc5gib"; + system = "cmu-infix"; + asd = "cmu-infix"; + } + ); + systems = [ "cmu-infix" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cmu-infix-tests = ( + build-asdf-system { + pname = "cmu-infix-tests"; + version = "20180228-git"; + asds = [ "cmu-infix-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cmu-infix/2018-02-28/cmu-infix-20180228-git.tgz"; + sha256 = "0macs398088cfif1dkjrpmidk515sjl7ld96f9ys5cpzx8sc5gib"; + system = "cmu-infix-tests"; + asd = "cmu-infix-tests"; + } + ); + systems = [ "cmu-infix-tests" ]; + lispLibs = [ + (getAttr "cmu-infix" self) + (getAttr "fiasco" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + coalton = ( + build-asdf-system { + pname = "coalton"; + version = "20241012-git"; + asds = [ "coalton" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; + sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; + system = "coalton"; + asd = "coalton"; + } + ); + systems = [ "coalton" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "coalton-asdf" self) + (getAttr "coalton-compiler" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + coalton-asdf = ( + build-asdf-system { + pname = "coalton-asdf"; + version = "20241012-git"; + asds = [ "coalton-asdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; + sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; + system = "coalton-asdf"; + asd = "coalton-asdf"; + } + ); + systems = [ "coalton-asdf" ]; + lispLibs = [ (getAttr "coalton-compiler" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + coalton-compiler = ( + build-asdf-system { + pname = "coalton-compiler"; + version = "20241012-git"; + asds = [ "coalton-compiler" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; + sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; + system = "coalton-compiler"; + asd = "coalton-compiler"; + } + ); + systems = [ "coalton-compiler" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "concrete-syntax-tree" self) + (getAttr "eclector" self) + (getAttr "eclector-concrete-syntax-tree" self) + (getAttr "float-features" self) + (getAttr "fset" self) + (getAttr "named-readtables" self) + (getAttr "source-error" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + coalton-testing-example-project = ( + build-asdf-system { + pname = "coalton-testing-example-project"; + version = "20241012-git"; + asds = [ "coalton-testing-example-project" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; + sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; + system = "coalton-testing-example-project"; + asd = "coalton-testing-example-project"; + } + ); + systems = [ "coalton-testing-example-project" ]; + lispLibs = [ + (getAttr "coalton" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cocoahelper = ( + build-asdf-system { + pname = "cocoahelper"; + version = "20210807-git"; + asds = [ "cocoahelper" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "cocoahelper"; + asd = "cocoahelper"; + } + ); + systems = [ "cocoahelper" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl-binaries" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cocoas = ( + build-asdf-system { + pname = "cocoas"; + version = "20241012-git"; + asds = [ "cocoas" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cocoas/2024-10-12/cocoas-20241012-git.tgz"; + sha256 = "0a3jpni8hnzd6103qj3nywy61c3jq6j9yzmg35wy4b8j94pgyvj5"; + system = "cocoas"; + asd = "cocoas"; + } + ); + systems = [ "cocoas" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "float-features" self) + (getAttr "trivial-main-thread" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + codata-recommended-values = ( + build-asdf-system { + pname = "codata-recommended-values"; + version = "20241012-git"; + asds = [ "codata-recommended-values" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/codata-recommended-values/2024-10-12/codata-recommended-values-20241012-git.tgz"; + sha256 = "0mks9hzw5wkdjkqkcfbafm9rvbfgkn2na4bajfrhs4mn7bg4bv74"; + system = "codata-recommended-values"; + asd = "codata-recommended-values"; + } + ); + systems = [ "codata-recommended-values" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + codex = ( + build-asdf-system { + pname = "codex"; + version = "20241012-git"; + asds = [ "codex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/codex/2024-10-12/codex-20241012-git.tgz"; + sha256 = "06d1qscqnkd24fhpvsm0206a4cj3wsxma7amazhvzqy1y4girgc3"; + system = "codex"; + asd = "codex"; + } + ); + systems = [ "codex" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-slug" self) + (getAttr "codex-templates" self) + (getAttr "common-doc" self) + (getAttr "common-doc-contrib" self) + (getAttr "docparser" self) + (getAttr "pandocl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + codex-templates = ( + build-asdf-system { + pname = "codex-templates"; + version = "20241012-git"; + asds = [ "codex-templates" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/codex/2024-10-12/codex-20241012-git.tgz"; + sha256 = "06d1qscqnkd24fhpvsm0206a4cj3wsxma7amazhvzqy1y4girgc3"; + system = "codex-templates"; + asd = "codex-templates"; + } + ); + systems = [ "codex-templates" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "common-html" self) + (getAttr "djula" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + coleslaw = ( + build-asdf-system { + pname = "coleslaw"; + version = "20241012-git"; + asds = [ "coleslaw" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/coleslaw/2024-10-12/coleslaw-20241012-git.tgz"; + sha256 = "1p9hg5qnymxzx2bzcvkzjarwxw383misq0cmqgggpzyhignx80av"; + system = "coleslaw"; + asd = "coleslaw"; + } + ); + systems = [ "coleslaw" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "_3bmd-ext-code-blocks" self) + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-unicode" self) + (getAttr "closer-mop" self) + (getAttr "closure-template" self) + (getAttr "inferior-shell" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + coleslaw-cli = ( + build-asdf-system { + pname = "coleslaw-cli"; + version = "20241012-git"; + asds = [ "coleslaw-cli" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/coleslaw/2024-10-12/coleslaw-20241012-git.tgz"; + sha256 = "1p9hg5qnymxzx2bzcvkzjarwxw383misq0cmqgggpzyhignx80av"; + system = "coleslaw-cli"; + asd = "coleslaw-cli"; + } + ); + systems = [ "coleslaw-cli" ]; + lispLibs = [ + (getAttr "clack" self) + (getAttr "coleslaw" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + coleslaw-test = ( + build-asdf-system { + pname = "coleslaw-test"; + version = "20241012-git"; + asds = [ "coleslaw-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/coleslaw/2024-10-12/coleslaw-20241012-git.tgz"; + sha256 = "1p9hg5qnymxzx2bzcvkzjarwxw383misq0cmqgggpzyhignx80av"; + system = "coleslaw-test"; + asd = "coleslaw-test"; + } + ); + systems = [ "coleslaw-test" ]; + lispLibs = [ + (getAttr "coleslaw" self) + (getAttr "coleslaw-cli" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + collectors = ( + build-asdf-system { + pname = "collectors"; + version = "20241012-git"; + asds = [ "collectors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/collectors/2024-10-12/collectors-20241012-git.tgz"; + sha256 = "1kc9q05wyp8yjz5wqc73nar7l49vcnfhj4924li81v76hlb03665"; + system = "collectors"; + asd = "collectors"; + } + ); + systems = [ "collectors" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "symbol-munger" self) + ]; + meta = { }; + } + ); + colliflower = ( + build-asdf-system { + pname = "colliflower"; + version = "20211020-git"; + asds = [ "colliflower" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/colliflower/2021-10-20/colliflower-20211020-git.tgz"; + sha256 = "1fzn9s7wm7wmffrdm21lpvry9jb320456cmmprn976a533lp704r"; + system = "colliflower"; + asd = "colliflower"; + } + ); + systems = [ "colliflower" ]; + lispLibs = [ + (getAttr "asdf-package-system" self) + (getAttr "garten" self) + (getAttr "liter" self) + (getAttr "silo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + colliflower-fset = ( + build-asdf-system { + pname = "colliflower-fset"; + version = "20211020-git"; + asds = [ "colliflower-fset" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/colliflower/2021-10-20/colliflower-20211020-git.tgz"; + sha256 = "1fzn9s7wm7wmffrdm21lpvry9jb320456cmmprn976a533lp704r"; + system = "colliflower-fset"; + asd = "colliflower-fset"; + } + ); + systems = [ "colliflower-fset" ]; + lispLibs = [ + (getAttr "colliflower" self) + (getAttr "fset" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + colliflower-test = ( + build-asdf-system { + pname = "colliflower-test"; + version = "20211020-git"; + asds = [ "colliflower-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/colliflower/2021-10-20/colliflower-20211020-git.tgz"; + sha256 = "1fzn9s7wm7wmffrdm21lpvry9jb320456cmmprn976a533lp704r"; + system = "colliflower-test"; + asd = "colliflower-test"; + } + ); + systems = [ "colliflower-test" ]; + lispLibs = [ + (getAttr "colliflower" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + colnew = ( + build-asdf-system { + pname = "colnew"; + version = "20231021-git"; + asds = [ "colnew" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "colnew"; + asd = "colnew"; + } + ); + systems = [ "colnew" ]; + lispLibs = [ (getAttr "f2cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + colored = ( + build-asdf-system { + pname = "colored"; + version = "20241012-git"; + asds = [ "colored" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/colored/2024-10-12/colored-20241012-git.tgz"; + sha256 = "0msw83gs5m887n1ha54jhflqjxb2mc7yv1hifspv9g16fn6h355c"; + system = "colored"; + asd = "colored"; + } + ); + systems = [ "colored" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + colored-test = ( + build-asdf-system { + pname = "colored-test"; + version = "20241012-git"; + asds = [ "colored-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/colored/2024-10-12/colored-20241012-git.tgz"; + sha256 = "0msw83gs5m887n1ha54jhflqjxb2mc7yv1hifspv9g16fn6h355c"; + system = "colored-test"; + asd = "colored-test"; + } + ); + systems = [ "colored-test" ]; + lispLibs = [ + (getAttr "colored" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + colorize = ( + build-asdf-system { + pname = "colorize"; + version = "20230214-git"; + asds = [ "colorize" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/colorize/2023-02-14/colorize-20230214-git.tgz"; + sha256 = "1gbg11ghs4iak3n4c66qn6yvrcsg71xcbnjjf8qks0y4c8573fyf"; + system = "colorize"; + asd = "colorize"; + } + ); + systems = [ "colorize" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "html-encode" self) + (getAttr "split-sequence" self) + ]; + meta = { }; + } + ); + com-on = ( + build-asdf-system { + pname = "com-on"; + version = "20241012-git"; + asds = [ "com-on" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/com-on/2024-10-12/com-on-20241012-git.tgz"; + sha256 = "1a3by2kx3iq0zl4304zhs89dfkp8xdjmdlnfmgywdg3wjdkxakci"; + system = "com-on"; + asd = "com-on"; + } + ); + systems = [ "com-on" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com-on-test = ( + build-asdf-system { + pname = "com-on-test"; + version = "20241012-git"; + asds = [ "com-on-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/com-on/2024-10-12/com-on-20241012-git.tgz"; + sha256 = "1a3by2kx3iq0zl4304zhs89dfkp8xdjmdlnfmgywdg3wjdkxakci"; + system = "com-on-test"; + asd = "com-on-test"; + } + ); + systems = [ "com-on-test" ]; + lispLibs = [ + (getAttr "com-on" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_clearly-useful_dot_generic-collection-interface = ( + build-asdf-system { + pname = "com.clearly-useful.generic-collection-interface"; + version = "20190710-git"; + asds = [ "com.clearly-useful.generic-collection-interface" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/com.clearly-useful.generic-collection-interface/2019-07-10/com.clearly-useful.generic-collection-interface-20190710-git.tgz"; + sha256 = "1yfxwqgvrb1nwryymsl4s3h1lr8yskb9c76lxqy3mw5l0vwvl5zl"; + system = "com.clearly-useful.generic-collection-interface"; + asd = "com.clearly-useful.generic-collection-interface"; + } + ); + systems = [ "com.clearly-useful.generic-collection-interface" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "com_dot_clearly-useful_dot_protocols" self) + (getAttr "lparallel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_clearly-useful_dot_generic-collection-interface_dot_test = ( + build-asdf-system { + pname = "com.clearly-useful.generic-collection-interface.test"; + version = "20190710-git"; + asds = [ "com.clearly-useful.generic-collection-interface.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/com.clearly-useful.generic-collection-interface/2019-07-10/com.clearly-useful.generic-collection-interface-20190710-git.tgz"; + sha256 = "1yfxwqgvrb1nwryymsl4s3h1lr8yskb9c76lxqy3mw5l0vwvl5zl"; + system = "com.clearly-useful.generic-collection-interface.test"; + asd = "com.clearly-useful.generic-collection-interface.test"; + } + ); + systems = [ "com.clearly-useful.generic-collection-interface.test" ]; + lispLibs = [ (getAttr "com_dot_clearly-useful_dot_generic-collection-interface" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_clearly-useful_dot_iterate_plus = ( + build-asdf-system { + pname = "com.clearly-useful.iterate+"; + version = "20121013-git"; + asds = [ "com.clearly-useful.iterate+" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/com.clearly-useful.iterate-plus/2012-10-13/com.clearly-useful.iterate-plus-20121013-git.tgz"; + sha256 = "0fpymg6p9zglkclfn035agcs5k83fakad7dj2612v5p1snzzcika"; + system = "com.clearly-useful.iterate+"; + asd = "com.clearly-useful.iterate+"; + } + ); + systems = [ "com.clearly-useful.iterate+" ]; + lispLibs = [ + (getAttr "com_dot_clearly-useful_dot_generic-collection-interface" self) + (getAttr "com_dot_clearly-useful_dot_iterator-protocol" self) + (getAttr "com_dot_clearly-useful_dot_protocols" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_clearly-useful_dot_iterator-protocol = ( + build-asdf-system { + pname = "com.clearly-useful.iterator-protocol"; + version = "20130312-git"; + asds = [ "com.clearly-useful.iterator-protocol" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/com.clearly-useful.iterator-protocol/2013-03-12/com.clearly-useful.iterator-protocol-20130312-git.tgz"; + sha256 = "1wgksgpck6na1ygdnln5n1y8rj2kylg3lpbkyrhdka2cgsqiqs4a"; + system = "com.clearly-useful.iterator-protocol"; + asd = "com.clearly-useful.iterator-protocol"; + } + ); + systems = [ "com.clearly-useful.iterator-protocol" ]; + lispLibs = [ + (getAttr "com_dot_clearly-useful_dot_generic-collection-interface" self) + (getAttr "com_dot_clearly-useful_dot_protocols" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_clearly-useful_dot_protocols = ( + build-asdf-system { + pname = "com.clearly-useful.protocols"; + version = "20130312-git"; + asds = [ "com.clearly-useful.protocols" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/com.clearly-useful.protocols/2013-03-12/com.clearly-useful.protocols-20130312-git.tgz"; + sha256 = "0az9rs98chjj2fdmpapqkv4sgfs84n9s7vvngcl05hcbsldm0xvn"; + system = "com.clearly-useful.protocols"; + asd = "com.clearly-useful.protocols"; + } + ); + systems = [ "com.clearly-useful.protocols" ]; + lispLibs = [ (getAttr "iterate" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_danielkeogh_dot_graph = ( + build-asdf-system { + pname = "com.danielkeogh.graph"; + version = "20241012-git"; + asds = [ "com.danielkeogh.graph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/com.danielkeogh.graph/2024-10-12/com.danielkeogh.graph-20241012-git.tgz"; + sha256 = "1hy9g49aqi1li0cdxzjmzgiskh00vlxbp1kjwiyk8a8kqzg69hj2"; + system = "com.danielkeogh.graph"; + asd = "com.danielkeogh.graph"; + } + ); + systems = [ "com.danielkeogh.graph" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-speedy-queue" self) + (getAttr "trivial-indent" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_danielkeogh_dot_graph-tests = ( + build-asdf-system { + pname = "com.danielkeogh.graph-tests"; + version = "20241012-git"; + asds = [ "com.danielkeogh.graph-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/com.danielkeogh.graph/2024-10-12/com.danielkeogh.graph-20241012-git.tgz"; + sha256 = "1hy9g49aqi1li0cdxzjmzgiskh00vlxbp1kjwiyk8a8kqzg69hj2"; + system = "com.danielkeogh.graph-tests"; + asd = "com.danielkeogh.graph-tests"; + } + ); + systems = [ "com.danielkeogh.graph-tests" ]; + lispLibs = [ + (getAttr "com_dot_danielkeogh_dot_graph" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_dvlsoft_dot_rcfiles = ( + build-asdf-system { + pname = "com.dvlsoft.rcfiles"; + version = "20111203-http"; + asds = [ "com.dvlsoft.rcfiles" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rcfiles/2011-12-03/cl-rcfiles-20111203-http.tgz"; + sha256 = "06ahp9jaim216k7vbya1kp8iy5yb1i7axwrsjx7gwhl2b2q63r0a"; + system = "com.dvlsoft.rcfiles"; + asd = "com.dvlsoft.rcfiles"; + } + ); + systems = [ "com.dvlsoft.rcfiles" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_elbeno_dot_curve = ( + build-asdf-system { + pname = "com.elbeno.curve"; + version = "20130128-git"; + asds = [ "com.elbeno.curve" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/curve/2013-01-28/curve-20130128-git.tgz"; + sha256 = "0223sxrdixjg0bmy76a9kiv7g4zjkqxs92x6kys5dnaywx7mjb6j"; + system = "com.elbeno.curve"; + asd = "com.elbeno.curve"; + } + ); + systems = [ "com.elbeno.curve" ]; + lispLibs = [ + (getAttr "com_dot_elbeno_dot_vector" self) + (getAttr "vecto" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_elbeno_dot_vector = ( + build-asdf-system { + pname = "com.elbeno.vector"; + version = "20130128-git"; + asds = [ "com.elbeno.vector" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vector/2013-01-28/vector-20130128-git.tgz"; + sha256 = "04czvqycn9j2hzbjmrp9fgqlgns5l7vbb73dgv3zqmiwzdb66qr5"; + system = "com.elbeno.vector"; + asd = "com.elbeno.vector"; + } + ); + systems = [ "com.elbeno.vector" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_gigamonkeys_dot_binary-data = ( + build-asdf-system { + pname = "com.gigamonkeys.binary-data"; + version = "20111203-git"; + asds = [ "com.gigamonkeys.binary-data" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-binary-data/2011-12-03/monkeylib-binary-data-20111203-git.tgz"; + sha256 = "072v417vmcnvmyh8ddq9vmwwrizm7zwz9dpzi14qy9nsw8q649zw"; + system = "com.gigamonkeys.binary-data"; + asd = "com.gigamonkeys.binary-data"; + } + ); + systems = [ "com.gigamonkeys.binary-data" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_gigamonkeys_dot_json = ( + build-asdf-system { + pname = "com.gigamonkeys.json"; + version = "20180228-git"; + asds = [ "com.gigamonkeys.json" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-json/2018-02-28/monkeylib-json-20180228-git.tgz"; + sha256 = "188717pmyhpgwg9ncc1fbqvbvw5fikbfhvchsy9gg4haxhdgpzsn"; + system = "com.gigamonkeys.json"; + asd = "com.gigamonkeys.json"; + } + ); + systems = [ "com.gigamonkeys.json" ]; + lispLibs = [ + (getAttr "com_dot_gigamonkeys_dot_parser" self) + (getAttr "com_dot_gigamonkeys_dot_utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_gigamonkeys_dot_macro-utilities = ( + build-asdf-system { + pname = "com.gigamonkeys.macro-utilities"; + version = "20111203-git"; + asds = [ "com.gigamonkeys.macro-utilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-macro-utilities/2011-12-03/monkeylib-macro-utilities-20111203-git.tgz"; + sha256 = "0l3m44zlzrvyn6fyvxslga8cppp4mh8dkgqzy297nnm0vnij5r8w"; + system = "com.gigamonkeys.macro-utilities"; + asd = "com.gigamonkeys.macro-utilities"; + } + ); + systems = [ "com.gigamonkeys.macro-utilities" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_gigamonkeys_dot_markup = ( + build-asdf-system { + pname = "com.gigamonkeys.markup"; + version = "20120909-git"; + asds = [ "com.gigamonkeys.markup" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-markup/2012-09-09/monkeylib-markup-20120909-git.tgz"; + sha256 = "049zqgnprvddn2zp1a8g862m3ikll3a3lpi1k2vimjmx1bkc0vs0"; + system = "com.gigamonkeys.markup"; + asd = "com.gigamonkeys.markup"; + } + ); + systems = [ "com.gigamonkeys.markup" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "com_dot_gigamonkeys_dot_pathnames" self) + (getAttr "com_dot_gigamonkeys_dot_utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_gigamonkeys_dot_parser = ( + build-asdf-system { + pname = "com.gigamonkeys.parser"; + version = "20120208-git"; + asds = [ "com.gigamonkeys.parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-parser/2012-02-08/monkeylib-parser-20120208-git.tgz"; + sha256 = "1xvzrih813311p48bzlm0z0592lx6iss3m36vz55qsw4sr397ncd"; + system = "com.gigamonkeys.parser"; + asd = "com.gigamonkeys.parser"; + } + ); + systems = [ "com.gigamonkeys.parser" ]; + lispLibs = [ + (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) + (getAttr "com_dot_gigamonkeys_dot_utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_gigamonkeys_dot_pathnames = ( + build-asdf-system { + pname = "com.gigamonkeys.pathnames"; + version = "20120208-git"; + asds = [ "com.gigamonkeys.pathnames" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-pathnames/2012-02-08/monkeylib-pathnames-20120208-git.tgz"; + sha256 = "108cc39g7razng316df4d47zzpj2zr576wzwwrpggdkm4q599gvk"; + system = "com.gigamonkeys.pathnames"; + asd = "com.gigamonkeys.pathnames"; + } + ); + systems = [ "com.gigamonkeys.pathnames" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_gigamonkeys_dot_prose-diff = ( + build-asdf-system { + pname = "com.gigamonkeys.prose-diff"; + version = "20140713-git"; + asds = [ "com.gigamonkeys.prose-diff" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-prose-diff/2014-07-13/monkeylib-prose-diff-20140713-git.tgz"; + sha256 = "1zwaa8qmpbdpdg8zzk3as73i55c54k9m694gx4bla1xxli5f8ijc"; + system = "com.gigamonkeys.prose-diff"; + asd = "com.gigamonkeys.prose-diff"; + } + ); + systems = [ "com.gigamonkeys.prose-diff" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) + (getAttr "com_dot_gigamonkeys_dot_markup" self) + (getAttr "com_dot_gigamonkeys_dot_pathnames" self) + (getAttr "com_dot_gigamonkeys_dot_utilities" self) + (getAttr "monkeylib-markup-html" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_gigamonkeys_dot_test-framework = ( + build-asdf-system { + pname = "com.gigamonkeys.test-framework"; + version = "20101207-git"; + asds = [ "com.gigamonkeys.test-framework" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-test-framework/2010-12-07/monkeylib-test-framework-20101207-git.tgz"; + sha256 = "1d6b8zg0vnbqxxsbbjr3b4r46d8whj84h9yqnqw3ii0bwr8hn82v"; + system = "com.gigamonkeys.test-framework"; + asd = "com.gigamonkeys.test-framework"; + } + ); + systems = [ "com.gigamonkeys.test-framework" ]; + lispLibs = [ (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_gigamonkeys_dot_utilities = ( + build-asdf-system { + pname = "com.gigamonkeys.utilities"; + version = "20170403-git"; + asds = [ "com.gigamonkeys.utilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-utilities/2017-04-03/monkeylib-utilities-20170403-git.tgz"; + sha256 = "0d0h1y43mn6r8s4g9gbr02d09565p0gig21jfnk7zf1dl6rnvkvm"; + system = "com.gigamonkeys.utilities"; + asd = "com.gigamonkeys.utilities"; + } + ); + systems = [ "com.gigamonkeys.utilities" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_google_dot_base = ( + build-asdf-system { + pname = "com.google.base"; + version = "20200925-git"; + asds = [ "com.google.base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/com.google.base/2020-09-25/com.google.base-20200925-git.tgz"; + sha256 = "1drc341sqmrmyvdgqpdy066f0z0ia0kl3ppq0rlxznlxhn17x3xj"; + system = "com.google.base"; + asd = "com.google.base"; + } + ); + systems = [ "com.google.base" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_google_dot_flag = ( + build-asdf-system { + pname = "com.google.flag"; + version = "20201220-git"; + asds = [ "com.google.flag" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-gflags/2020-12-20/lisp-gflags-20201220-git.tgz"; + sha256 = "06p70v1wv0ynr6ng6vr6krc5773xphvkv2nfxvnschc1bzqhds5k"; + system = "com.google.flag"; + asd = "com.google.flag"; + } + ); + systems = [ "com.google.flag" ]; + lispLibs = [ (getAttr "com_dot_google_dot_base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + com_dot_inuoe_dot_jzon = ( + build-asdf-system { + pname = "com.inuoe.jzon"; + version = "v1.1.4"; + asds = [ "com.inuoe.jzon" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jzon/2024-10-12/jzon-v1.1.4.tgz"; + sha256 = "0z7xpylyk8rakz449rxqpz4hazn91ap2dnf0689iigdvvl3yqz3g"; + system = "com.inuoe.jzon"; + asd = "com.inuoe.jzon"; + } + ); + systems = [ "com.inuoe.jzon" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "flexi-streams" self) + (getAttr "float-features" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + com_dot_inuoe_dot_jzon-tests = ( + build-asdf-system { + pname = "com.inuoe.jzon-tests"; + version = "v1.1.4"; + asds = [ "com.inuoe.jzon-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jzon/2024-10-12/jzon-v1.1.4.tgz"; + sha256 = "0z7xpylyk8rakz449rxqpz4hazn91ap2dnf0689iigdvvl3yqz3g"; + system = "com.inuoe.jzon-tests"; + asd = "com.inuoe.jzon-tests"; + } + ); + systems = [ "com.inuoe.jzon-tests" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "com_dot_inuoe_dot_jzon" self) + (getAttr "fiveam" self) + (getAttr "flexi-streams" self) + (getAttr "float-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + command-line-arguments = ( + build-asdf-system { + pname = "command-line-arguments"; + version = "20210807-git"; + asds = [ "command-line-arguments" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/command-line-arguments/2021-08-07/command-line-arguments-20210807-git.tgz"; + sha256 = "1wbb83b559nfv65rsxz3jrixic9gndk2whj40hhwb0s13rf5a62y"; + system = "command-line-arguments"; + asd = "command-line-arguments"; + } + ); + systems = [ "command-line-arguments" ]; + lispLibs = [ ]; + meta = { }; + } + ); + common-doc = ( + build-asdf-system { + pname = "common-doc"; + version = "20230214-git"; + asds = [ "common-doc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; + sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; + system = "common-doc"; + asd = "common-doc"; + } + ); + systems = [ "common-doc" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "closer-mop" self) + (getAttr "local-time" self) + (getAttr "quri" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-doc-contrib = ( + build-asdf-system { + pname = "common-doc-contrib"; + version = "20230214-git"; + asds = [ "common-doc-contrib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; + sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; + system = "common-doc-contrib"; + asd = "common-doc-contrib"; + } + ); + systems = [ "common-doc-contrib" ]; + lispLibs = [ + (getAttr "common-doc-gnuplot" self) + (getAttr "common-doc-graphviz" self) + (getAttr "common-doc-include" self) + (getAttr "common-doc-plantuml" self) + (getAttr "common-doc-split-paragraphs" self) + (getAttr "common-doc-tex" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-doc-gnuplot = ( + build-asdf-system { + pname = "common-doc-gnuplot"; + version = "20230214-git"; + asds = [ "common-doc-gnuplot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; + sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; + system = "common-doc-gnuplot"; + asd = "common-doc-gnuplot"; + } + ); + systems = [ "common-doc-gnuplot" ]; + lispLibs = [ + (getAttr "common-doc" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-doc-graphviz = ( + build-asdf-system { + pname = "common-doc-graphviz"; + version = "20230214-git"; + asds = [ "common-doc-graphviz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; + sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; + system = "common-doc-graphviz"; + asd = "common-doc-graphviz"; + } + ); + systems = [ "common-doc-graphviz" ]; + lispLibs = [ + (getAttr "common-doc" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-doc-include = ( + build-asdf-system { + pname = "common-doc-include"; + version = "20230214-git"; + asds = [ "common-doc-include" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; + sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; + system = "common-doc-include"; + asd = "common-doc-include"; + } + ); + systems = [ "common-doc-include" ]; + lispLibs = [ + (getAttr "common-doc" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-doc-plantuml = ( + build-asdf-system { + pname = "common-doc-plantuml"; + version = "20230214-git"; + asds = [ "common-doc-plantuml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; + sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; + system = "common-doc-plantuml"; + asd = "common-doc-plantuml"; + } + ); + systems = [ "common-doc-plantuml" ]; + lispLibs = [ + (getAttr "common-doc" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-doc-plump = ( + build-asdf-system { + pname = "common-doc-plump"; + version = "20160421-git"; + asds = [ "common-doc-plump" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-doc-plump/2016-04-21/common-doc-plump-20160421-git.tgz"; + sha256 = "08h7m4c599rf2kz4wkpbj05441ax0vb3bd88a7dw5x57djf765r6"; + system = "common-doc-plump"; + asd = "common-doc-plump"; + } + ); + systems = [ "common-doc-plump" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "cl-markup" self) + (getAttr "common-doc" self) + (getAttr "common-doc-split-paragraphs" self) + (getAttr "plump" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-doc-plump-test = ( + build-asdf-system { + pname = "common-doc-plump-test"; + version = "20160421-git"; + asds = [ "common-doc-plump-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-doc-plump/2016-04-21/common-doc-plump-20160421-git.tgz"; + sha256 = "08h7m4c599rf2kz4wkpbj05441ax0vb3bd88a7dw5x57djf765r6"; + system = "common-doc-plump-test"; + asd = "common-doc-plump-test"; + } + ); + systems = [ "common-doc-plump-test" ]; + lispLibs = [ + (getAttr "common-doc-plump" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-doc-split-paragraphs = ( + build-asdf-system { + pname = "common-doc-split-paragraphs"; + version = "20230214-git"; + asds = [ "common-doc-split-paragraphs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; + sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; + system = "common-doc-split-paragraphs"; + asd = "common-doc-split-paragraphs"; + } + ); + systems = [ "common-doc-split-paragraphs" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "common-doc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-doc-test = ( + build-asdf-system { + pname = "common-doc-test"; + version = "20230214-git"; + asds = [ "common-doc-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; + sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; + system = "common-doc-test"; + asd = "common-doc-test"; + } + ); + systems = [ "common-doc-test" ]; + lispLibs = [ + (getAttr "common-doc" self) + (getAttr "common-doc-contrib" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-doc-tex = ( + build-asdf-system { + pname = "common-doc-tex"; + version = "20230214-git"; + asds = [ "common-doc-tex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-doc/2023-02-14/common-doc-20230214-git.tgz"; + sha256 = "0bzc4w37cq5mbkd15vxziks6nq58yad04mki4nwy5w6pza7z0faa"; + system = "common-doc-tex"; + asd = "common-doc-tex"; + } + ); + systems = [ "common-doc-tex" ]; + lispLibs = [ (getAttr "common-doc" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-html = ( + build-asdf-system { + pname = "common-html"; + version = "20210807-git"; + asds = [ "common-html" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-html/2021-08-07/common-html-20210807-git.tgz"; + sha256 = "1i11w4l95nybz5ibnaxrnrkfhch2s9wynqrg6kx6sl6y47khq1xz"; + system = "common-html"; + asd = "common-html"; + } + ); + systems = [ "common-html" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "common-doc" self) + (getAttr "plump" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-html-test = ( + build-asdf-system { + pname = "common-html-test"; + version = "20210807-git"; + asds = [ "common-html-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-html/2021-08-07/common-html-20210807-git.tgz"; + sha256 = "1i11w4l95nybz5ibnaxrnrkfhch2s9wynqrg6kx6sl6y47khq1xz"; + system = "common-html-test"; + asd = "common-html-test"; + } + ); + systems = [ "common-html-test" ]; + lispLibs = [ + (getAttr "common-html" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + common-lisp-jupyter = ( + build-asdf-system { + pname = "common-lisp-jupyter"; + version = "20241012-git"; + asds = [ "common-lisp-jupyter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-lisp-jupyter/2024-10-12/common-lisp-jupyter-20241012-git.tgz"; + sha256 = "1qbrzv0myxfxq7rzm2y9cm2xymkl982982h2kbsl7d1yd5hrjvl6"; + system = "common-lisp-jupyter"; + asd = "common-lisp-jupyter"; + } + ); + systems = [ "common-lisp-jupyter" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-base64" self) + (getAttr "cl-indentify" self) + (getAttr "closer-mop" self) + (getAttr "dissect" self) + (getAttr "eclector" self) + (getAttr "ironclad" self) + (getAttr "jupyter-lab-extension" self) + (getAttr "multilang-documentation" self) + (getAttr "nontrivial-gray-streams" self) + (getAttr "puri" self) + (getAttr "pzmq" self) + (getAttr "shasht" self) + (getAttr "static-vectors" self) + (getAttr "trivial-do" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-mimes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + commondoc-markdown = ( + build-asdf-system { + pname = "commondoc-markdown"; + version = "20241012-git"; + asds = [ "commondoc-markdown" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/commondoc-markdown/2024-10-12/commondoc-markdown-20241012-git.tgz"; + sha256 = "12n8yx8jhz8713r63gmrymplm1mfczm7q7a343d13wl6gng1gjs1"; + system = "commondoc-markdown"; + asd = "commondoc-markdown"; + } + ); + systems = [ "commondoc-markdown" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "_3bmd-ext-code-blocks" self) + (getAttr "_3bmd-ext-tables" self) + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "common-doc" self) + (getAttr "common-html" self) + (getAttr "esrap" self) + (getAttr "ironclad" self) + (getAttr "plump" self) + (getAttr "quri" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + commondoc-markdown-docs = ( + build-asdf-system { + pname = "commondoc-markdown-docs"; + version = "20241012-git"; + asds = [ "commondoc-markdown-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/commondoc-markdown/2024-10-12/commondoc-markdown-20241012-git.tgz"; + sha256 = "12n8yx8jhz8713r63gmrymplm1mfczm7q7a343d13wl6gng1gjs1"; + system = "commondoc-markdown-docs"; + asd = "commondoc-markdown-docs"; + } + ); + systems = [ "commondoc-markdown-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + commondoc-markdown-test = ( + build-asdf-system { + pname = "commondoc-markdown-test"; + version = "20241012-git"; + asds = [ "commondoc-markdown-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/commondoc-markdown/2024-10-12/commondoc-markdown-20241012-git.tgz"; + sha256 = "12n8yx8jhz8713r63gmrymplm1mfczm7q7a343d13wl6gng1gjs1"; + system = "commondoc-markdown-test"; + asd = "commondoc-markdown-test"; + } + ); + systems = [ "commondoc-markdown-test" ]; + lispLibs = [ + (getAttr "common-doc" self) + (getAttr "commondoc-markdown" self) + (getAttr "hamcrest" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + commonqt = ( + build-asdf-system { + pname = "commonqt"; + version = "20210531-git"; + asds = [ "commonqt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "commonqt"; + asd = "commonqt"; + } + ); + systems = [ "commonqt" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "smokebase" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + comp-set = ( + build-asdf-system { + pname = "comp-set"; + version = "20210807-git"; + asds = [ "comp-set" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; + sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; + system = "comp-set"; + asd = "comp-set"; + } + ); + systems = [ "comp-set" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + compatible-metaclasses = ( + build-asdf-system { + pname = "compatible-metaclasses"; + version = "1.0"; + asds = [ "compatible-metaclasses" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/compatible-metaclasses/2020-09-25/compatible-metaclasses_1.0.tgz"; + sha256 = "17cf74j400cl6sjslfhkv13lir85k705v63mx3dd4y6dl5hvsdh6"; + system = "compatible-metaclasses"; + asd = "compatible-metaclasses"; + } + ); + systems = [ "compatible-metaclasses" ]; + lispLibs = [ + (getAttr "class-options" self) + (getAttr "closer-mop" self) + (getAttr "enhanced-find-class" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + compatible-metaclasses__tests = ( + build-asdf-system { + pname = "compatible-metaclasses_tests"; + version = "1.0"; + asds = [ "compatible-metaclasses_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/compatible-metaclasses/2020-09-25/compatible-metaclasses_1.0.tgz"; + sha256 = "17cf74j400cl6sjslfhkv13lir85k705v63mx3dd4y6dl5hvsdh6"; + system = "compatible-metaclasses_tests"; + asd = "compatible-metaclasses_tests"; + } + ); + systems = [ "compatible-metaclasses_tests" ]; + lispLibs = [ + (getAttr "compatible-metaclasses" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + compiler-macro-notes = ( + build-asdf-system { + pname = "compiler-macro-notes"; + version = "v0.3.1"; + asds = [ "compiler-macro-notes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/compiler-macro-notes/2024-10-12/compiler-macro-notes-v0.3.1.tgz"; + sha256 = "0pchhvk14fx54p7qq92dnf0g4jnapqr6p2a4za6bhzd8im1d9gad"; + system = "compiler-macro-notes"; + asd = "compiler-macro-notes"; + } + ); + systems = [ "compiler-macro-notes" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-environments" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + computable-reals = ( + build-asdf-system { + pname = "computable-reals"; + version = "20231021-git"; + asds = [ "computable-reals" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/computable-reals/2023-10-21/computable-reals-20231021-git.tgz"; + sha256 = "1x8kkdyjil0zzg8fq9b76z12kmfrqwhsxnr6qqnlrg0c8c5bzz9c"; + system = "computable-reals"; + asd = "computable-reals"; + } + ); + systems = [ "computable-reals" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + concrete-syntax-tree = ( + build-asdf-system { + pname = "concrete-syntax-tree"; + version = "20230618-git"; + asds = [ "concrete-syntax-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/concrete-syntax-tree/2023-06-18/concrete-syntax-tree-20230618-git.tgz"; + sha256 = "15q9jyqsh2z921li9my8c840cj2ci7k217x5frfiyk0kymkx4rgv"; + system = "concrete-syntax-tree"; + asd = "concrete-syntax-tree"; + } + ); + systems = [ "concrete-syntax-tree" ]; + lispLibs = [ + (getAttr "concrete-syntax-tree-base" self) + (getAttr "concrete-syntax-tree-lambda-list" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + concrete-syntax-tree-base = ( + build-asdf-system { + pname = "concrete-syntax-tree-base"; + version = "20230618-git"; + asds = [ "concrete-syntax-tree-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/concrete-syntax-tree/2023-06-18/concrete-syntax-tree-20230618-git.tgz"; + sha256 = "15q9jyqsh2z921li9my8c840cj2ci7k217x5frfiyk0kymkx4rgv"; + system = "concrete-syntax-tree-base"; + asd = "concrete-syntax-tree-base"; + } + ); + systems = [ "concrete-syntax-tree-base" ]; + lispLibs = [ (getAttr "acclimation" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + concrete-syntax-tree-destructuring = ( + build-asdf-system { + pname = "concrete-syntax-tree-destructuring"; + version = "20230618-git"; + asds = [ "concrete-syntax-tree-destructuring" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/concrete-syntax-tree/2023-06-18/concrete-syntax-tree-20230618-git.tgz"; + sha256 = "15q9jyqsh2z921li9my8c840cj2ci7k217x5frfiyk0kymkx4rgv"; + system = "concrete-syntax-tree-destructuring"; + asd = "concrete-syntax-tree-destructuring"; + } + ); + systems = [ "concrete-syntax-tree-destructuring" ]; + lispLibs = [ (getAttr "concrete-syntax-tree-lambda-list" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + concrete-syntax-tree-lambda-list = ( + build-asdf-system { + pname = "concrete-syntax-tree-lambda-list"; + version = "20230618-git"; + asds = [ "concrete-syntax-tree-lambda-list" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/concrete-syntax-tree/2023-06-18/concrete-syntax-tree-20230618-git.tgz"; + sha256 = "15q9jyqsh2z921li9my8c840cj2ci7k217x5frfiyk0kymkx4rgv"; + system = "concrete-syntax-tree-lambda-list"; + asd = "concrete-syntax-tree-lambda-list"; + } + ); + systems = [ "concrete-syntax-tree-lambda-list" ]; + lispLibs = [ (getAttr "concrete-syntax-tree-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + concrete-syntax-tree-lambda-list-test = ( + build-asdf-system { + pname = "concrete-syntax-tree-lambda-list-test"; + version = "20230618-git"; + asds = [ "concrete-syntax-tree-lambda-list-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/concrete-syntax-tree/2023-06-18/concrete-syntax-tree-20230618-git.tgz"; + sha256 = "15q9jyqsh2z921li9my8c840cj2ci7k217x5frfiyk0kymkx4rgv"; + system = "concrete-syntax-tree-lambda-list-test"; + asd = "concrete-syntax-tree-lambda-list-test"; + } + ); + systems = [ "concrete-syntax-tree-lambda-list-test" ]; + lispLibs = [ (getAttr "concrete-syntax-tree-lambda-list" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + concrete-syntax-tree-source-info = ( + build-asdf-system { + pname = "concrete-syntax-tree-source-info"; + version = "20230618-git"; + asds = [ "concrete-syntax-tree-source-info" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/concrete-syntax-tree/2023-06-18/concrete-syntax-tree-20230618-git.tgz"; + sha256 = "15q9jyqsh2z921li9my8c840cj2ci7k217x5frfiyk0kymkx4rgv"; + system = "concrete-syntax-tree-source-info"; + asd = "concrete-syntax-tree-source-info"; + } + ); + systems = [ "concrete-syntax-tree-source-info" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + conditional-commands = ( + build-asdf-system { + pname = "conditional-commands"; + version = "20241012-git"; + asds = [ "conditional-commands" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "conditional-commands"; + asd = "conditional-commands"; + } + ); + systems = [ "conditional-commands" ]; + lispLibs = [ (getAttr "clim" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + conf = ( + build-asdf-system { + pname = "conf"; + version = "20191227-git"; + asds = [ "conf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/conf/2019-12-27/conf-20191227-git.tgz"; + sha256 = "0mif91gb6yqg2qrzd2p6n83w9injikm5gggzv2mgxkiyzmr5gnay"; + system = "conf"; + asd = "conf"; + } + ); + systems = [ "conf" ]; + lispLibs = [ (getAttr "cl-fad" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + configuration_dot_options = ( + build-asdf-system { + pname = "configuration.options"; + version = "20210531-git"; + asds = [ "configuration.options" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; + sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; + system = "configuration.options"; + asd = "configuration.options"; + } + ); + systems = [ "configuration.options" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "architecture_dot_service-provider" self) + (getAttr "cl-hooks" self) + (getAttr "esrap" self) + (getAttr "let-plus" self) + (getAttr "log4cl" self) + (getAttr "more-conditions" self) + (getAttr "split-sequence" self) + (getAttr "utilities_dot_print-items" self) + (getAttr "utilities_dot_print-tree" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + configuration_dot_options-and-mop = ( + build-asdf-system { + pname = "configuration.options-and-mop"; + version = "20210531-git"; + asds = [ "configuration.options-and-mop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; + sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; + system = "configuration.options-and-mop"; + asd = "configuration.options-and-mop"; + } + ); + systems = [ "configuration.options-and-mop" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "configuration_dot_options" self) + (getAttr "let-plus" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + configuration_dot_options-and-puri = ( + build-asdf-system { + pname = "configuration.options-and-puri"; + version = "20210531-git"; + asds = [ "configuration.options-and-puri" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; + sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; + system = "configuration.options-and-puri"; + asd = "configuration.options-and-puri"; + } + ); + systems = [ "configuration.options-and-puri" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "configuration_dot_options" self) + (getAttr "let-plus" self) + (getAttr "puri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + configuration_dot_options-and-quri = ( + build-asdf-system { + pname = "configuration.options-and-quri"; + version = "20210531-git"; + asds = [ "configuration.options-and-quri" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; + sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; + system = "configuration.options-and-quri"; + asd = "configuration.options-and-quri"; + } + ); + systems = [ "configuration.options-and-quri" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "configuration_dot_options" self) + (getAttr "let-plus" self) + (getAttr "quri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + configuration_dot_options-and-service-provider = ( + build-asdf-system { + pname = "configuration.options-and-service-provider"; + version = "20210531-git"; + asds = [ "configuration.options-and-service-provider" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; + sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; + system = "configuration.options-and-service-provider"; + asd = "configuration.options-and-service-provider"; + } + ); + systems = [ "configuration.options-and-service-provider" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "architecture_dot_service-provider" self) + (getAttr "architecture_dot_service-provider-and-hooks" self) + (getAttr "configuration_dot_options" self) + (getAttr "configuration_dot_options-and-mop" self) + (getAttr "let-plus" self) + (getAttr "log4cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + configuration_dot_options-syntax-ini = ( + build-asdf-system { + pname = "configuration.options-syntax-ini"; + version = "20210531-git"; + asds = [ "configuration.options-syntax-ini" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; + sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; + system = "configuration.options-syntax-ini"; + asd = "configuration.options-syntax-ini"; + } + ); + systems = [ "configuration.options-syntax-ini" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "configuration_dot_options" self) + (getAttr "let-plus" self) + (getAttr "parser_dot_ini" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + configuration_dot_options-syntax-xml = ( + build-asdf-system { + pname = "configuration.options-syntax-xml"; + version = "20210531-git"; + asds = [ "configuration.options-syntax-xml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/configuration.options/2021-05-31/configuration.options-20210531-git.tgz"; + sha256 = "1wh07llx4k66wwabxajdc6cy0sdxbrydxi51gs7hrsyrp9gvym9g"; + system = "configuration.options-syntax-xml"; + asd = "configuration.options-syntax-xml"; + } + ); + systems = [ "configuration.options-syntax-xml" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "configuration_dot_options" self) + (getAttr "let-plus" self) + (getAttr "xml_dot_location" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + conium = ( + build-asdf-system { + pname = "conium"; + version = "20210630-git"; + asds = [ "conium" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/conium/2021-06-30/conium-20210630-git.tgz"; + sha256 = "0y31za8xr8734p2pf8mrw1jd1fksh2d4y1p12wwjyn8hxxsvsx1w"; + system = "conium"; + asd = "conium"; + } + ); + systems = [ "conium" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + consfigurator = ( + build-asdf-system { + pname = "consfigurator"; + version = "v1.4.4"; + asds = [ "consfigurator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/consfigurator/2024-10-12/consfigurator-v1.4.4.tgz"; + sha256 = "1f4q5w58phj5a6i2fj712ggz2p8b5m4v77qzsvbb3xmy2vhppvv0"; + system = "consfigurator"; + asd = "consfigurator"; + } + ); + systems = [ "consfigurator" ]; + lispLibs = [ + (getAttr "agnostic-lizard" self) + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "babel" self) + (getAttr "babel-streams" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-heredoc" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "named-readtables" self) + (getAttr "osicat" self) + (getAttr "parse-number" self) + (getAttr "trivial-backtrace" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + consix = ( + build-asdf-system { + pname = "consix"; + version = "20201220-git"; + asds = [ "consix" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/consix/2020-12-20/consix-20201220-git.tgz"; + sha256 = "0zpcaxgq9jx0baj5sid8rnzq8ygsmd8yzb0x37nkaiwa67x5jjck"; + system = "consix"; + asd = "consix"; + } + ); + systems = [ "consix" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-glu" self) + (getAttr "cl-glut" self) + (getAttr "cl-opengl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + constantfold = ( + build-asdf-system { + pname = "constantfold"; + version = "20191227-git"; + asds = [ "constantfold" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/constantfold/2019-12-27/constantfold-20191227-git.tgz"; + sha256 = "153h0569z6bff1qbad0bdssplwwny75l7ilqwcfqfdvzsxf9jh06"; + system = "constantfold"; + asd = "constantfold"; + } + ); + systems = [ "constantfold" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "lisp-namespace" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + constantfold_dot_test = ( + build-asdf-system { + pname = "constantfold.test"; + version = "20191227-git"; + asds = [ "constantfold.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/constantfold/2019-12-27/constantfold-20191227-git.tgz"; + sha256 = "153h0569z6bff1qbad0bdssplwwny75l7ilqwcfqfdvzsxf9jh06"; + system = "constantfold.test"; + asd = "constantfold.test"; + } + ); + systems = [ "constantfold.test" ]; + lispLibs = [ + (getAttr "constantfold" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + context-lite = ( + build-asdf-system { + pname = "context-lite"; + version = "20220331-git"; + asds = [ "context-lite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/context-lite/2022-03-31/context-lite-20220331-git.tgz"; + sha256 = "16hmid3adimn10c0y4p6hg7n42al2qgsy7wxlpargk0xbn4h3km4"; + system = "context-lite"; + asd = "context-lite"; + } + ); + systems = [ "context-lite" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + contextl = ( + build-asdf-system { + pname = "contextl"; + version = "20241012-git"; + asds = [ "contextl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/contextl/2024-10-12/contextl-20241012-git.tgz"; + sha256 = "1jsa5wyjzzfw9pii3d6x20mh8ijnpb291g3i0y2ccj0x8z3xfyyk"; + system = "contextl"; + asd = "contextl"; + } + ); + systems = [ "contextl" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "lw-compat" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + control = ( + build-asdf-system { + pname = "control"; + version = "20200427-git"; + asds = [ "control" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "control"; + asd = "control"; + } + ); + systems = [ "control" ]; + lispLibs = [ + (getAttr "character-modifier-bits" self) + (getAttr "utility" self) + (getAttr "window" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + copy-directory = ( + build-asdf-system { + pname = "copy-directory"; + version = "20160628-git"; + asds = [ "copy-directory" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/copy-directory/2016-06-28/copy-directory-20160628-git.tgz"; + sha256 = "19wvzb046lcyifhx26ydzf7ngfa52n64nyx76k3lh02x7ahhpc93"; + system = "copy-directory"; + asd = "copy-directory"; + } + ); + systems = [ "copy-directory" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "which" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + copy-directory-test = ( + build-asdf-system { + pname = "copy-directory-test"; + version = "20160628-git"; + asds = [ "copy-directory-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/copy-directory/2016-06-28/copy-directory-20160628-git.tgz"; + sha256 = "19wvzb046lcyifhx26ydzf7ngfa52n64nyx76k3lh02x7ahhpc93"; + system = "copy-directory-test"; + asd = "copy-directory-test"; + } + ); + systems = [ "copy-directory-test" ]; + lispLibs = [ + (getAttr "copy-directory" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + core-reader = ( + build-asdf-system { + pname = "core-reader"; + version = "20220707-git"; + asds = [ "core-reader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/core-reader/2022-07-07/core-reader-20220707-git.tgz"; + sha256 = "1f2cm44r3pnahgx1b3c3psf6myaliwsrvfcgz8c9ydqi5qlx49gb"; + system = "core-reader"; + asd = "core-reader"; + } + ); + systems = [ "core-reader" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + core-reader_dot_test = ( + build-asdf-system { + pname = "core-reader.test"; + version = "20220707-git"; + asds = [ "core-reader.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/core-reader/2022-07-07/core-reader-20220707-git.tgz"; + sha256 = "1f2cm44r3pnahgx1b3c3psf6myaliwsrvfcgz8c9ydqi5qlx49gb"; + system = "core-reader.test"; + asd = "core-reader.test"; + } + ); + systems = [ "core-reader.test" ]; + lispLibs = [ + (getAttr "core-reader" self) + (getAttr "jingoh" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cover = ( + build-asdf-system { + pname = "cover"; + version = "20230618-git"; + asds = [ "cover" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cover/2023-06-18/cover-20230618-git.tgz"; + sha256 = "0152zzdszhiblzm3a80x8bnalip7gnzyvvwnlswsnnlb509nby89"; + system = "cover"; + asd = "cover"; + } + ); + systems = [ "cover" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cqlcl = ( + build-asdf-system { + pname = "cqlcl"; + version = "20141106-git"; + asds = [ "cqlcl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cqlcl/2014-11-06/cqlcl-20141106-git.tgz"; + sha256 = "0ppdsrrf2hz0s4y02a2p5mgms92znrj7hz7x9j6azppfkal25zid"; + system = "cqlcl"; + asd = "cqlcl"; + } + ); + systems = [ "cqlcl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "fiveam" self) + (getAttr "flexi-streams" self) + (getAttr "lparallel" self) + (getAttr "pooler" self) + (getAttr "split-sequence" self) + (getAttr "usocket" self) + (getAttr "uuid" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cqlcl-test = ( + build-asdf-system { + pname = "cqlcl-test"; + version = "20141106-git"; + asds = [ "cqlcl-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cqlcl/2014-11-06/cqlcl-20141106-git.tgz"; + sha256 = "0ppdsrrf2hz0s4y02a2p5mgms92znrj7hz7x9j6azppfkal25zid"; + system = "cqlcl-test"; + asd = "cqlcl"; + } + ); + systems = [ "cqlcl-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cqlcl" self) + (getAttr "fiveam" self) + (getAttr "flexi-streams" self) + (getAttr "uuid" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + crane = ( + build-asdf-system { + pname = "crane"; + version = "20160208-git"; + asds = [ "crane" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/crane/2016-02-08/crane-20160208-git.tgz"; + sha256 = "1wai4h7vz5i0ld1fnnbcmpz5d67dmykyxx0ay0fkclkwvpj7gh5n"; + system = "crane"; + asd = "crane"; + } + ); + systems = [ "crane" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "cl-fad" self) + (getAttr "clos-fixtures" self) + (getAttr "closer-mop" self) + (getAttr "dbi" self) + (getAttr "iterate" self) + (getAttr "local-time" self) + (getAttr "sxql" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + crane-test = ( + build-asdf-system { + pname = "crane-test"; + version = "20160208-git"; + asds = [ "crane-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/crane/2016-02-08/crane-20160208-git.tgz"; + sha256 = "1wai4h7vz5i0ld1fnnbcmpz5d67dmykyxx0ay0fkclkwvpj7gh5n"; + system = "crane-test"; + asd = "crane-test"; + } + ); + systems = [ "crane-test" ]; + lispLibs = [ + (getAttr "crane" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cricket = ( + build-asdf-system { + pname = "cricket"; + version = "20220707-git"; + asds = [ "cricket" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cricket/2022-07-07/cricket-20220707-git.tgz"; + sha256 = "0wdpzdmalbnfjmd9s7yalris4i1vvc2klnhfl8g0h2ahq0mqv9p9"; + system = "cricket"; + asd = "cricket"; + } + ); + systems = [ "cricket" ]; + lispLibs = [ + (getAttr "arrow-macros" self) + (getAttr "cl-cpus" self) + (getAttr "lparallel" self) + (getAttr "mfiano-utils" self) + (getAttr "seedable-rng" self) + (getAttr "zpng" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cricket_dot_test = ( + build-asdf-system { + pname = "cricket.test"; + version = "20220707-git"; + asds = [ "cricket.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cricket/2022-07-07/cricket-20220707-git.tgz"; + sha256 = "0wdpzdmalbnfjmd9s7yalris4i1vvc2klnhfl8g0h2ahq0mqv9p9"; + system = "cricket.test"; + asd = "cricket.test"; + } + ); + systems = [ "cricket.test" ]; + lispLibs = [ + (getAttr "cricket" self) + (getAttr "mfiano-utils" self) + (getAttr "pngload" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + croatoan = ( + build-asdf-system { + pname = "croatoan"; + version = "20241012-git"; + asds = [ "croatoan" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/croatoan/2024-10-12/croatoan-20241012-git.tgz"; + sha256 = "04776x4i8inxs8n4mgy9xf0q39bzv4mfz4cl880sxwk6mnhwnn4c"; + system = "croatoan"; + asd = "croatoan"; + } + ); + systems = [ "croatoan" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "croatoan-ncurses" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + croatoan-ncurses = ( + build-asdf-system { + pname = "croatoan-ncurses"; + version = "20241012-git"; + asds = [ "croatoan-ncurses" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/croatoan/2024-10-12/croatoan-20241012-git.tgz"; + sha256 = "04776x4i8inxs8n4mgy9xf0q39bzv4mfz4cl880sxwk6mnhwnn4c"; + system = "croatoan-ncurses"; + asd = "croatoan-ncurses"; + } + ); + systems = [ "croatoan-ncurses" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + croatoan-test = ( + build-asdf-system { + pname = "croatoan-test"; + version = "20241012-git"; + asds = [ "croatoan-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/croatoan/2024-10-12/croatoan-20241012-git.tgz"; + sha256 = "04776x4i8inxs8n4mgy9xf0q39bzv4mfz4cl880sxwk6mnhwnn4c"; + system = "croatoan-test"; + asd = "croatoan-test"; + } + ); + systems = [ "croatoan-test" ]; + lispLibs = [ (getAttr "croatoan" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + crud = ( + build-asdf-system { + pname = "crud"; + version = "20200427-git"; + asds = [ "crud" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "crud"; + asd = "crud"; + } + ); + systems = [ "crud" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "base64" self) + (getAttr "lparallel" self) + (getAttr "sqlite" self) + (getAttr "sucle-serialize" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + crypt = ( + build-asdf-system { + pname = "crypt"; + version = "20120520-git"; + asds = [ "crypt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-crypt/2012-05-20/cl-crypt-20120520-git.tgz"; + sha256 = "02fc3aqfbbwjpz79a4mwffv33pnmmknpkmd1r8v9mkn9a6c1ssmh"; + system = "crypt"; + asd = "crypt"; + } + ); + systems = [ "crypt" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + crypto-shortcuts = ( + build-asdf-system { + pname = "crypto-shortcuts"; + version = "20231021-git"; + asds = [ "crypto-shortcuts" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/crypto-shortcuts/2023-10-21/crypto-shortcuts-20231021-git.tgz"; + sha256 = "0ghih34xlf9vgbh8arsqjbgf8iymvs5s0ys0n2bm73b1z0632ygr"; + system = "crypto-shortcuts"; + asd = "crypto-shortcuts"; + } + ); + systems = [ "crypto-shortcuts" ]; + lispLibs = [ + (getAttr "cl-base32" self) + (getAttr "cl-base64" self) + (getAttr "flexi-streams" self) + (getAttr "ironclad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cserial-port = ( + build-asdf-system { + pname = "cserial-port"; + version = "20230214-git"; + asds = [ "cserial-port" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cserial-port/2023-02-14/cserial-port-20230214-git.tgz"; + sha256 = "0l38qh66g2iba7kjw6fml3q55ax6vkk0khbwrsvkglwhpan79fsm"; + system = "cserial-port"; + asd = "cserial-port"; + } + ); + systems = [ "cserial-port" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "osicat" self) + (getAttr "trivial-features" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + css-lite = ( + build-asdf-system { + pname = "css-lite"; + version = "20230618-git"; + asds = [ "css-lite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/css-lite/2023-06-18/css-lite-20230618-git.tgz"; + sha256 = "1pvvwd6ysdc7m5945vkwdbq4jjmcszmkxp9jhgi0lba23si07dp5"; + system = "css-lite"; + asd = "css-lite"; + } + ); + systems = [ "css-lite" ]; + lispLibs = [ (getAttr "parenscript" self) ]; + meta = { }; + } + ); + css-selectors = ( + build-asdf-system { + pname = "css-selectors"; + version = "20160628-git"; + asds = [ "css-selectors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/css-selectors/2016-06-28/css-selectors-20160628-git.tgz"; + sha256 = "0x0a5jq4kdw8zrkljmhijcbvjj09iyrwwgryc6kvzl5g7wzg2xr6"; + system = "css-selectors"; + asd = "css-selectors"; + } + ); + systems = [ "css-selectors" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "buildnode" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "cxml" self) + (getAttr "iterate" self) + (getAttr "symbol-munger" self) + (getAttr "yacc" self) + ]; + meta = { }; + } + ); + css-selectors-simple-tree = ( + build-asdf-system { + pname = "css-selectors-simple-tree"; + version = "20160628-git"; + asds = [ "css-selectors-simple-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/css-selectors/2016-06-28/css-selectors-20160628-git.tgz"; + sha256 = "0x0a5jq4kdw8zrkljmhijcbvjj09iyrwwgryc6kvzl5g7wzg2xr6"; + system = "css-selectors-simple-tree"; + asd = "css-selectors-simple-tree"; + } + ); + systems = [ "css-selectors-simple-tree" ]; + lispLibs = [ + (getAttr "cl-html5-parser" self) + (getAttr "css-selectors" self) + ]; + meta = { }; + } + ); + css-selectors-stp = ( + build-asdf-system { + pname = "css-selectors-stp"; + version = "20160628-git"; + asds = [ "css-selectors-stp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/css-selectors/2016-06-28/css-selectors-20160628-git.tgz"; + sha256 = "0x0a5jq4kdw8zrkljmhijcbvjj09iyrwwgryc6kvzl5g7wzg2xr6"; + system = "css-selectors-stp"; + asd = "css-selectors-stp"; + } + ); + systems = [ "css-selectors-stp" ]; + lispLibs = [ + (getAttr "css-selectors" self) + (getAttr "cxml-stp" self) + ]; + meta = { }; + } + ); + css-selectors-test = ( + build-asdf-system { + pname = "css-selectors-test"; + version = "20160628-git"; + asds = [ "css-selectors-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/css-selectors/2016-06-28/css-selectors-20160628-git.tgz"; + sha256 = "0x0a5jq4kdw8zrkljmhijcbvjj09iyrwwgryc6kvzl5g7wzg2xr6"; + system = "css-selectors-test"; + asd = "css-selectors"; + } + ); + systems = [ "css-selectors-test" ]; + lispLibs = [ + (getAttr "buildnode-xhtml" self) + (getAttr "css-selectors" self) + (getAttr "lisp-unit2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + csv = ( + build-asdf-system { + pname = "csv"; + version = "20190710-git"; + asds = [ "csv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/csv/2019-07-10/csv-20190710-git.tgz"; + sha256 = "0jykv91w7anisac2aip38vnj7ywi567rcp4n8nv3lz5qb7g1dpy4"; + system = "csv"; + asd = "csv"; + } + ); + systems = [ "csv" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + csv-parser = ( + build-asdf-system { + pname = "csv-parser"; + version = "20140713-git"; + asds = [ "csv-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/csv-parser/2014-07-13/csv-parser-20140713-git.tgz"; + sha256 = "0pcp709dwxi3p2vrmx5qiy571pybfs1hpv9z8g4i1ig2l4mc3djh"; + system = "csv-parser"; + asd = "csv-parser"; + } + ); + systems = [ "csv-parser" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + csv-validator = ( + build-asdf-system { + pname = "csv-validator"; + version = "20230618-git"; + asds = [ "csv-validator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/csv-validator/2023-06-18/csv-validator-20230618-git.tgz"; + sha256 = "14cwjc43q05a1gdl0m79sps59605dfrhd4mjhcxh7gxyj8x7x1k2"; + system = "csv-validator"; + asd = "csv-validator"; + } + ); + systems = [ "csv-validator" ]; + lispLibs = [ + (getAttr "local-time" self) + (getAttr "lparallel" self) + (getAttr "parse-float" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + csv-validator-tests = ( + build-asdf-system { + pname = "csv-validator-tests"; + version = "20230618-git"; + asds = [ "csv-validator-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/csv-validator/2023-06-18/csv-validator-20230618-git.tgz"; + sha256 = "14cwjc43q05a1gdl0m79sps59605dfrhd4mjhcxh7gxyj8x7x1k2"; + system = "csv-validator-tests"; + asd = "csv-validator-tests"; + } + ); + systems = [ "csv-validator-tests" ]; + lispLibs = [ + (getAttr "csv-validator" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ctype = ( + build-asdf-system { + pname = "ctype"; + version = "20241012-git"; + asds = [ "ctype" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ctype/2024-10-12/ctype-20241012-git.tgz"; + sha256 = "0qnssrjssb7258i3a1s1bv3z6plx4pzrkg65i8an25bvwrjwpvqv"; + system = "ctype"; + asd = "ctype"; + } + ); + systems = [ "ctype" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cubic-bezier = ( + build-asdf-system { + pname = "cubic-bezier"; + version = "20220707-git"; + asds = [ "cubic-bezier" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cubic-bezier/2022-07-07/cubic-bezier-20220707-git.tgz"; + sha256 = "08byf1pw2s5sz97bk0sp2a6gdx5dkankbbg14azafd1k0vfh7vcr"; + system = "cubic-bezier"; + asd = "cubic-bezier"; + } + ); + systems = [ "cubic-bezier" ]; + lispLibs = [ + (getAttr "mfiano-utils" self) + (getAttr "origin" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cue-parser = ( + build-asdf-system { + pname = "cue-parser"; + version = "20180228-git"; + asds = [ "cue-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cue-parser/2018-02-28/cue-parser-20180228-git.tgz"; + sha256 = "1zl3a02b68yywchd1aldls07b4qgrf08xpb4xiaaw8njk2qa0lz1"; + system = "cue-parser"; + asd = "cue-parser"; + } + ); + systems = [ "cue-parser" ]; + lispLibs = [ + (getAttr "esrap" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + curly = ( + build-asdf-system { + pname = "curly"; + version = "20120407-git"; + asds = [ "curly" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/curly/2012-04-07/curly-20120407-git.tgz"; + sha256 = "04gpkq6hd7wvvny0p3lgn87bfalswqc67sbg4p35j52w51mqd8vf"; + system = "curly"; + asd = "curly"; + } + ); + systems = [ "curly" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + curly_dot_test = ( + build-asdf-system { + pname = "curly.test"; + version = "20120407-git"; + asds = [ "curly.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/curly/2012-04-07/curly-20120407-git.tgz"; + sha256 = "04gpkq6hd7wvvny0p3lgn87bfalswqc67sbg4p35j52w51mqd8vf"; + system = "curly.test"; + asd = "curly"; + } + ); + systems = [ "curly.test" ]; + lispLibs = [ + (getAttr "curly" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + curry-compose-reader-macros = ( + build-asdf-system { + pname = "curry-compose-reader-macros"; + version = "20201220-git"; + asds = [ "curry-compose-reader-macros" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/curry-compose-reader-macros/2020-12-20/curry-compose-reader-macros-20201220-git.tgz"; + sha256 = "0j4qfwpw4ykf5npiln54w7jcnj46p7xf9d4p3jpx4a67fdkrlxd1"; + system = "curry-compose-reader-macros"; + asd = "curry-compose-reader-macros"; + } + ); + systems = [ "curry-compose-reader-macros" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cxml = ( + build-asdf-system { + pname = "cxml"; + version = "20200610-git"; + asds = [ "cxml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cxml/2020-06-10/cxml-20200610-git.tgz"; + sha256 = "18fls3bx7vmnxfa6qara8fxp316d8kb3izar0kysvqg6l0a45a51"; + system = "cxml"; + asd = "cxml"; + } + ); + systems = [ "cxml" ]; + lispLibs = [ + (getAttr "closure-common" self) + (getAttr "puri" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + cxml-dom = ( + build-asdf-system { + pname = "cxml-dom"; + version = "20200610-git"; + asds = [ "cxml-dom" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cxml/2020-06-10/cxml-20200610-git.tgz"; + sha256 = "18fls3bx7vmnxfa6qara8fxp316d8kb3izar0kysvqg6l0a45a51"; + system = "cxml-dom"; + asd = "cxml-dom"; + } + ); + systems = [ "cxml-dom" ]; + lispLibs = [ + (getAttr "closure-common" self) + (getAttr "puri" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cxml-klacks = ( + build-asdf-system { + pname = "cxml-klacks"; + version = "20200610-git"; + asds = [ "cxml-klacks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cxml/2020-06-10/cxml-20200610-git.tgz"; + sha256 = "18fls3bx7vmnxfa6qara8fxp316d8kb3izar0kysvqg6l0a45a51"; + system = "cxml-klacks"; + asd = "cxml-klacks"; + } + ); + systems = [ "cxml-klacks" ]; + lispLibs = [ + (getAttr "closure-common" self) + (getAttr "puri" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cxml-rng = ( + build-asdf-system { + pname = "cxml-rng"; + version = "20190710-git"; + asds = [ "cxml-rng" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cxml-rng/2019-07-10/cxml-rng-20190710-git.tgz"; + sha256 = "0pjb5268spiwq6b0cly8nfajr6rsh2wf6si646bzzjrxbgs51sxa"; + system = "cxml-rng"; + asd = "cxml-rng"; + } + ); + systems = [ "cxml-rng" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "cl-ppcre" self) + (getAttr "cxml" self) + (getAttr "parse-number" self) + (getAttr "yacc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cxml-rpc = ( + build-asdf-system { + pname = "cxml-rpc"; + version = "20121013-git"; + asds = [ "cxml-rpc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cxml-rpc/2012-10-13/cxml-rpc-20121013-git.tgz"; + sha256 = "1ihd8rg0shy7nykqcbvvx5px7sw8wr1nwz70jdrh6ibq74yr8flh"; + system = "cxml-rpc"; + asd = "cxml-rpc"; + } + ); + systems = [ "cxml-rpc" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "cxml" self) + (getAttr "drakma" self) + (getAttr "hunchentoot" self) + (getAttr "parse-number" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cxml-stp = ( + build-asdf-system { + pname = "cxml-stp"; + version = "20200325-git"; + asds = [ "cxml-stp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cxml-stp/2020-03-25/cxml-stp-20200325-git.tgz"; + sha256 = "01yfxxvb144i2mlp06fxx410mf3phxz5qaqvk90pp4dzdl883knv"; + system = "cxml-stp"; + asd = "cxml-stp"; + } + ); + systems = [ "cxml-stp" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cxml" self) + (getAttr "xpath" self) + ]; + meta = { }; + } + ); + cxml-test = ( + build-asdf-system { + pname = "cxml-test"; + version = "20200610-git"; + asds = [ "cxml-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cxml/2020-06-10/cxml-20200610-git.tgz"; + sha256 = "18fls3bx7vmnxfa6qara8fxp316d8kb3izar0kysvqg6l0a45a51"; + system = "cxml-test"; + asd = "cxml-test"; + } + ); + systems = [ "cxml-test" ]; + lispLibs = [ + (getAttr "closure-common" self) + (getAttr "puri" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cxx = ( + build-asdf-system { + pname = "cxx"; + version = "20230214-git"; + asds = [ "cxx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cxx/2023-02-14/cl-cxx-20230214-git.tgz"; + sha256 = "08jh7ajgfdr3cqla02c4d2y06y0imkky5d4mwnlph01nczzf85cy"; + system = "cxx"; + asd = "cxx"; + } + ); + systems = [ "cxx" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cxx-jit = ( + build-asdf-system { + pname = "cxx-jit"; + version = "20241012-git"; + asds = [ "cxx-jit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cxx-jit/2024-10-12/cl-cxx-jit-20241012-git.tgz"; + sha256 = "1xnhkhynikqs61s488jjzklbvwb46yxqx3zi98ifszj4r8ndi3ym"; + system = "cxx-jit"; + asd = "cxx-jit"; + } + ); + systems = [ "cxx-jit" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cxx-jit-test = ( + build-asdf-system { + pname = "cxx-jit-test"; + version = "20241012-git"; + asds = [ "cxx-jit-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cxx-jit/2024-10-12/cl-cxx-jit-20241012-git.tgz"; + sha256 = "1xnhkhynikqs61s488jjzklbvwb46yxqx3zi98ifszj4r8ndi3ym"; + system = "cxx-jit-test"; + asd = "cxx-jit-test"; + } + ); + systems = [ "cxx-jit-test" ]; + lispLibs = [ + (getAttr "cxx-jit" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cxx-test = ( + build-asdf-system { + pname = "cxx-test"; + version = "20230214-git"; + asds = [ "cxx-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cxx/2023-02-14/cl-cxx-20230214-git.tgz"; + sha256 = "08jh7ajgfdr3cqla02c4d2y06y0imkky5d4mwnlph01nczzf85cy"; + system = "cxx-test"; + asd = "cxx-test"; + } + ); + systems = [ "cxx-test" ]; + lispLibs = [ + (getAttr "cxx" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + cytoscape-clj = ( + build-asdf-system { + pname = "cytoscape-clj"; + version = "20241012-git"; + asds = [ "cytoscape-clj" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cytoscape-clj/2024-10-12/cytoscape-clj-20241012-git.tgz"; + sha256 = "0kyjgffm8nlvz75dbyz4fp1v8sr7j2bd7axxyn226s30gwzhihck"; + system = "cytoscape-clj"; + asd = "cytoscape-clj"; + } + ); + systems = [ "cytoscape-clj" ]; + lispLibs = [ + (getAttr "common-lisp-jupyter" self) + (getAttr "jupyter-lab-extension" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + daemon = ( + build-asdf-system { + pname = "daemon"; + version = "20170403-git"; + asds = [ "daemon" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/daemon/2017-04-03/daemon-20170403-git.tgz"; + sha256 = "1kdxfnhh9fz34j8qs7pn7mwjz3v33q4v9nh0hqkyzraq5xs2j3f4"; + system = "daemon"; + asd = "daemon"; + } + ); + systems = [ "daemon" ]; + lispLibs = [ (getAttr "trivial-features" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + damn-fast-priority-queue = ( + build-asdf-system { + pname = "damn-fast-priority-queue"; + version = "20241012-git"; + asds = [ "damn-fast-priority-queue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/damn-fast-priority-queue/2024-10-12/damn-fast-priority-queue-20241012-git.tgz"; + sha256 = "1mbigpgi7qbqvpj59l1f7p2qcg00ybvqzdca1j1b9hx62h224ndw"; + system = "damn-fast-priority-queue"; + asd = "damn-fast-priority-queue"; + } + ); + systems = [ "damn-fast-priority-queue" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + damn-fast-stable-priority-queue = ( + build-asdf-system { + pname = "damn-fast-stable-priority-queue"; + version = "20241012-git"; + asds = [ "damn-fast-stable-priority-queue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/damn-fast-priority-queue/2024-10-12/damn-fast-priority-queue-20241012-git.tgz"; + sha256 = "1mbigpgi7qbqvpj59l1f7p2qcg00ybvqzdca1j1b9hx62h224ndw"; + system = "damn-fast-stable-priority-queue"; + asd = "damn-fast-stable-priority-queue"; + } + ); + systems = [ "damn-fast-stable-priority-queue" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + darts_dot_lib_dot_email-address = ( + build-asdf-system { + pname = "darts.lib.email-address"; + version = "quicklisp-release-48464635-git"; + asds = [ "darts.lib.email-address" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dartsclemailaddress/2016-04-21/dartsclemailaddress-quicklisp-release-48464635-git.tgz"; + sha256 = "15155nqi9q7ilaf14p4yi4iga8203rl7fn9v2iaxcfm18gsvqcjd"; + system = "darts.lib.email-address"; + asd = "darts.lib.email-address"; + } + ); + systems = [ "darts.lib.email-address" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + darts_dot_lib_dot_email-address-test = ( + build-asdf-system { + pname = "darts.lib.email-address-test"; + version = "quicklisp-release-48464635-git"; + asds = [ "darts.lib.email-address-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dartsclemailaddress/2016-04-21/dartsclemailaddress-quicklisp-release-48464635-git.tgz"; + sha256 = "15155nqi9q7ilaf14p4yi4iga8203rl7fn9v2iaxcfm18gsvqcjd"; + system = "darts.lib.email-address-test"; + asd = "darts.lib.email-address-test"; + } + ); + systems = [ "darts.lib.email-address-test" ]; + lispLibs = [ + (getAttr "darts_dot_lib_dot_email-address" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + darts_dot_lib_dot_hashtree-test = ( + build-asdf-system { + pname = "darts.lib.hashtree-test"; + version = "20231021-git"; + asds = [ "darts.lib.hashtree-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dartsclhashtree/2023-10-21/dartsclhashtree-20231021-git.tgz"; + sha256 = "1kbxk7vnpv9zy6pm004cyyp9mbb4n845pfdv4wxngaj96ndi5v6j"; + system = "darts.lib.hashtree-test"; + asd = "darts.lib.hashtree-test"; + } + ); + systems = [ "darts.lib.hashtree-test" ]; + lispLibs = [ + (getAttr "darts_dot_lib_dot_hashtrie" self) + (getAttr "darts_dot_lib_dot_wbtree" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + darts_dot_lib_dot_hashtrie = ( + build-asdf-system { + pname = "darts.lib.hashtrie"; + version = "20231021-git"; + asds = [ "darts.lib.hashtrie" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dartsclhashtree/2023-10-21/dartsclhashtree-20231021-git.tgz"; + sha256 = "1kbxk7vnpv9zy6pm004cyyp9mbb4n845pfdv4wxngaj96ndi5v6j"; + system = "darts.lib.hashtrie"; + asd = "darts.lib.hashtrie"; + } + ); + systems = [ "darts.lib.hashtrie" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + darts_dot_lib_dot_message-pack = ( + build-asdf-system { + pname = "darts.lib.message-pack"; + version = "20200325-git"; + asds = [ "darts.lib.message-pack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dartsclmessagepack/2020-03-25/dartsclmessagepack-20200325-git.tgz"; + sha256 = "0i9jnvq6dp5zya1ijj3z7s10803jk8rb4nrjrzcgcfhkczd5si6y"; + system = "darts.lib.message-pack"; + asd = "darts.lib.message-pack"; + } + ); + systems = [ "darts.lib.message-pack" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "ieee-floats" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + darts_dot_lib_dot_message-pack-test = ( + build-asdf-system { + pname = "darts.lib.message-pack-test"; + version = "20200325-git"; + asds = [ "darts.lib.message-pack-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dartsclmessagepack/2020-03-25/dartsclmessagepack-20200325-git.tgz"; + sha256 = "0i9jnvq6dp5zya1ijj3z7s10803jk8rb4nrjrzcgcfhkczd5si6y"; + system = "darts.lib.message-pack-test"; + asd = "darts.lib.message-pack-test"; + } + ); + systems = [ "darts.lib.message-pack-test" ]; + lispLibs = [ + (getAttr "darts_dot_lib_dot_message-pack" self) + (getAttr "stefil" self) + (getAttr "trivial-octet-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + darts_dot_lib_dot_sequence-metrics = ( + build-asdf-system { + pname = "darts.lib.sequence-metrics"; + version = "20130312-git"; + asds = [ "darts.lib.sequence-metrics" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dartsclsequencemetrics/2013-03-12/dartsclsequencemetrics-20130312-git.tgz"; + sha256 = "1x99gj5dfgiaraawx1nd157g5ajygfxz47cz8jgi1fh52fp1p969"; + system = "darts.lib.sequence-metrics"; + asd = "darts.lib.sequence-metrics"; + } + ); + systems = [ "darts.lib.sequence-metrics" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + darts_dot_lib_dot_tools = ( + build-asdf-system { + pname = "darts.lib.tools"; + version = "20201220-git"; + asds = [ "darts.lib.tools" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dartscltools/2020-12-20/dartscltools-20201220-git.tgz"; + sha256 = "0mbz7ak03qsw41fgybdw4mbibr656y9xl9bfgr2rmkdkgxbicys9"; + system = "darts.lib.tools"; + asd = "darts.lib.tools"; + } + ); + systems = [ "darts.lib.tools" ]; + lispLibs = [ (getAttr "atomics" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + darts_dot_lib_dot_tools_dot_test = ( + build-asdf-system { + pname = "darts.lib.tools.test"; + version = "20201220-git"; + asds = [ "darts.lib.tools.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dartscltools/2020-12-20/dartscltools-20201220-git.tgz"; + sha256 = "0mbz7ak03qsw41fgybdw4mbibr656y9xl9bfgr2rmkdkgxbicys9"; + system = "darts.lib.tools.test"; + asd = "darts.lib.tools.test"; + } + ); + systems = [ "darts.lib.tools.test" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "darts_dot_lib_dot_tools" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + darts_dot_lib_dot_uuid = ( + build-asdf-system { + pname = "darts.lib.uuid"; + version = "20241012-git"; + asds = [ "darts.lib.uuid" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dartscluuid/2024-10-12/dartscluuid-20241012-git.tgz"; + sha256 = "17i2icz6k6vb5mp95rsjr8ldzhjjlcn7dyylvxjrccbxbrblnnsl"; + system = "darts.lib.uuid"; + asd = "darts.lib.uuid"; + } + ); + systems = [ "darts.lib.uuid" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "ironclad" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + darts_dot_lib_dot_uuid-test = ( + build-asdf-system { + pname = "darts.lib.uuid-test"; + version = "20241012-git"; + asds = [ "darts.lib.uuid-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dartscluuid/2024-10-12/dartscluuid-20241012-git.tgz"; + sha256 = "17i2icz6k6vb5mp95rsjr8ldzhjjlcn7dyylvxjrccbxbrblnnsl"; + system = "darts.lib.uuid-test"; + asd = "darts.lib.uuid-test"; + } + ); + systems = [ "darts.lib.uuid-test" ]; + lispLibs = [ + (getAttr "darts_dot_lib_dot_uuid" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + darts_dot_lib_dot_wbtree = ( + build-asdf-system { + pname = "darts.lib.wbtree"; + version = "20231021-git"; + asds = [ "darts.lib.wbtree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dartsclhashtree/2023-10-21/dartsclhashtree-20231021-git.tgz"; + sha256 = "1kbxk7vnpv9zy6pm004cyyp9mbb4n845pfdv4wxngaj96ndi5v6j"; + system = "darts.lib.wbtree"; + asd = "darts.lib.wbtree"; + } + ); + systems = [ "darts.lib.wbtree" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + data-format-validation = ( + build-asdf-system { + pname = "data-format-validation"; + version = "20140713-git"; + asds = [ "data-format-validation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-data-format-validation/2014-07-13/cl-data-format-validation-20140713-git.tgz"; + sha256 = "0zmk47xmicyqvp1impn8kgh5373ysmx3gfpqcvbi9r31qsir2nqa"; + system = "data-format-validation"; + asd = "data-format-validation"; + } + ); + systems = [ "data-format-validation" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + data-frame = ( + build-asdf-system { + pname = "data-frame"; + version = "20241012-git"; + asds = [ "data-frame" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/data-frame/2024-10-12/data-frame-20241012-git.tgz"; + sha256 = "1sqyvb6hscz070d5ap5v5yvql4nx69c7jkp29za5dj84rsvbckcp"; + system = "data-frame"; + asd = "data-frame"; + } + ); + systems = [ "data-frame" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "alexandria_plus" self) + (getAttr "anaphora" self) + (getAttr "array-operations" self) + (getAttr "duologue" self) + (getAttr "let-plus" self) + (getAttr "num-utils" self) + (getAttr "select" self) + (getAttr "statistics" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + data-lens = ( + build-asdf-system { + pname = "data-lens"; + version = "20241012-git"; + asds = [ "data-lens" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/data-lens/2024-10-12/data-lens-20241012-git.tgz"; + sha256 = "1bark9r3br5ndcbkiagq891gn82xdiy8hrgzp72656yyadsrid5i"; + system = "data-lens"; + asd = "data-lens"; + } + ); + systems = [ "data-lens" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + data-lens_plus_fset = ( + build-asdf-system { + pname = "data-lens+fset"; + version = "20241012-git"; + asds = [ "data-lens+fset" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/data-lens/2024-10-12/data-lens-20241012-git.tgz"; + sha256 = "1bark9r3br5ndcbkiagq891gn82xdiy8hrgzp72656yyadsrid5i"; + system = "data-lens+fset"; + asd = "data-lens+fset"; + } + ); + systems = [ "data-lens+fset" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "data-lens" self) + (getAttr "fset" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + data-sift = ( + build-asdf-system { + pname = "data-sift"; + version = "20130128-git"; + asds = [ "data-sift" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/data-sift/2013-01-28/data-sift-20130128-git.tgz"; + sha256 = "1v7gf0x4ibjzp0c56n9m77hxdgwcm9356zlk5n4l3fx4i0hj6146"; + system = "data-sift"; + asd = "data-sift"; + } + ); + systems = [ "data-sift" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "parse-number" self) + (getAttr "puri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + data-sift-test = ( + build-asdf-system { + pname = "data-sift-test"; + version = "20130128-git"; + asds = [ "data-sift-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/data-sift/2013-01-28/data-sift-20130128-git.tgz"; + sha256 = "1v7gf0x4ibjzp0c56n9m77hxdgwcm9356zlk5n4l3fx4i0hj6146"; + system = "data-sift-test"; + asd = "data-sift"; + } + ); + systems = [ "data-sift-test" ]; + lispLibs = [ + (getAttr "data-sift" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + data-table = ( + build-asdf-system { + pname = "data-table"; + version = "20231021-git"; + asds = [ "data-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/data-table/2023-10-21/data-table-20231021-git.tgz"; + sha256 = "1x64s3r2p28wgx7ffm205i90am2azfqkl6zlkrnjhppp82xan8yd"; + system = "data-table"; + asd = "data-table"; + } + ); + systems = [ "data-table" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-interpol" self) + (getAttr "iterate" self) + (getAttr "symbol-munger" self) + ]; + meta = { }; + } + ); + data-table-clsql = ( + build-asdf-system { + pname = "data-table-clsql"; + version = "20231021-git"; + asds = [ "data-table-clsql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/data-table/2023-10-21/data-table-20231021-git.tgz"; + sha256 = "1x64s3r2p28wgx7ffm205i90am2azfqkl6zlkrnjhppp82xan8yd"; + system = "data-table-clsql"; + asd = "data-table-clsql"; + } + ); + systems = [ "data-table-clsql" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "clsql-helper" self) + (getAttr "collectors" self) + (getAttr "data-table" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + data-table-test = ( + build-asdf-system { + pname = "data-table-test"; + version = "20231021-git"; + asds = [ "data-table-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/data-table/2023-10-21/data-table-20231021-git.tgz"; + sha256 = "1x64s3r2p28wgx7ffm205i90am2azfqkl6zlkrnjhppp82xan8yd"; + system = "data-table-test"; + asd = "data-table"; + } + ); + systems = [ "data-table-test" ]; + lispLibs = [ + (getAttr "data-table" self) + (getAttr "lisp-unit2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + database-migrations = ( + build-asdf-system { + pname = "database-migrations"; + version = "20230214-git"; + asds = [ "database-migrations" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/database-migrations/2023-02-14/database-migrations-20230214-git.tgz"; + sha256 = "1mm5adjhqy0djr8fxpdsamc2ry2x5krc9w0s5nnfvyc4yqs0bwaa"; + system = "database-migrations"; + asd = "database-migrations"; + } + ); + systems = [ "database-migrations" ]; + lispLibs = [ (getAttr "postmodern" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + datafly = ( + build-asdf-system { + pname = "datafly"; + version = "20241012-git"; + asds = [ "datafly" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/datafly/2024-10-12/datafly-20241012-git.tgz"; + sha256 = "103zp5s778lys4lsn7hvyis65757338n0l9gzl595qfim4apx8g0"; + system = "datafly"; + asd = "datafly"; + } + ); + systems = [ "datafly" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "closer-mop" self) + (getAttr "dbi" self) + (getAttr "function-cache" self) + (getAttr "iterate" self) + (getAttr "jonathan" self) + (getAttr "kebab" self) + (getAttr "local-time" self) + (getAttr "log4cl" self) + (getAttr "named-readtables" self) + (getAttr "optima" self) + (getAttr "sxql" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + datafly-test = ( + build-asdf-system { + pname = "datafly-test"; + version = "20241012-git"; + asds = [ "datafly-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/datafly/2024-10-12/datafly-20241012-git.tgz"; + sha256 = "103zp5s778lys4lsn7hvyis65757338n0l9gzl595qfim4apx8g0"; + system = "datafly-test"; + asd = "datafly-test"; + } + ); + systems = [ "datafly-test" ]; + lispLibs = [ + (getAttr "datafly" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "sxql" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dataloader = ( + build-asdf-system { + pname = "dataloader"; + version = "20210531-git"; + asds = [ "dataloader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dataloader/2021-05-31/dataloader-20210531-git.tgz"; + sha256 = "1a7nap2yp0jjd9r3xpkj0a6z0m3gshz73abm8kfza4kf31ipzyik"; + system = "dataloader"; + asd = "dataloader"; + } + ); + systems = [ "dataloader" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-csv" self) + (getAttr "cl-jpeg" self) + (getAttr "cl-wav" self) + (getAttr "iterate" self) + (getAttr "magicffi" self) + (getAttr "numcl" self) + (getAttr "numpy-file-format" self) + (getAttr "png" self) + (getAttr "retrospectiff" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dataloader_dot_test = ( + build-asdf-system { + pname = "dataloader.test"; + version = "20210531-git"; + asds = [ "dataloader.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dataloader/2021-05-31/dataloader-20210531-git.tgz"; + sha256 = "1a7nap2yp0jjd9r3xpkj0a6z0m3gshz73abm8kfza4kf31ipzyik"; + system = "dataloader.test"; + asd = "dataloader.test"; + } + ); + systems = [ "dataloader.test" ]; + lispLibs = [ + (getAttr "dataloader" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + datamuse = ( + build-asdf-system { + pname = "datamuse"; + version = "20231021-git"; + asds = [ "datamuse" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/datamuse/2023-10-21/datamuse-20231021-git.tgz"; + sha256 = "18mminvwv6wql6qh9kxxkhjfbxfz37gr125wy9h6za83vn1rkpwc"; + system = "datamuse"; + asd = "datamuse"; + } + ); + systems = [ "datamuse" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "drakma" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + date-calc = ( + build-asdf-system { + pname = "date-calc"; + version = "20191227-git"; + asds = [ "date-calc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/date-calc/2019-12-27/date-calc-20191227-git.tgz"; + sha256 = "09wmjp3ypxigcmx4mvc0yjnj56wkjjchhssdmklbaswy5mi7xc9s"; + system = "date-calc"; + asd = "date-calc"; + } + ); + systems = [ "date-calc" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + datum-comments = ( + build-asdf-system { + pname = "datum-comments"; + version = "20210228-git"; + asds = [ "datum-comments" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/datum-comments/2021-02-28/datum-comments-20210228-git.tgz"; + sha256 = "07zzlhphcmwimp4pjckhnbjbn127lcpafi7j0l74137dz9pimjik"; + system = "datum-comments"; + asd = "datum-comments"; + } + ); + systems = [ "datum-comments" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + db3 = ( + build-asdf-system { + pname = "db3"; + version = "20200218-git"; + asds = [ "db3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-db3/2020-02-18/cl-db3-20200218-git.tgz"; + sha256 = "1i7j0mlri6kbklcx1lsm464s8kmyhhij5c4xh4aybrw8m4ixn1s5"; + system = "db3"; + asd = "db3"; + } + ); + systems = [ "db3" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dbd-mysql = ( + build-asdf-system { + pname = "dbd-mysql"; + version = "20241012-git"; + asds = [ "dbd-mysql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dbi/2024-10-12/cl-dbi-20241012-git.tgz"; + sha256 = "17szd6sz1hlwl5fm4qjgyd8ax01wkbhv8hxcyy8qscx39sc0cnpy"; + system = "dbd-mysql"; + asd = "dbd-mysql"; + } + ); + systems = [ "dbd-mysql" ]; + lispLibs = [ + (getAttr "cl-mysql" self) + (getAttr "dbi" self) + ]; + meta = { }; + } + ); + dbd-postgres = ( + build-asdf-system { + pname = "dbd-postgres"; + version = "20241012-git"; + asds = [ "dbd-postgres" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dbi/2024-10-12/cl-dbi-20241012-git.tgz"; + sha256 = "17szd6sz1hlwl5fm4qjgyd8ax01wkbhv8hxcyy8qscx39sc0cnpy"; + system = "dbd-postgres"; + asd = "dbd-postgres"; + } + ); + systems = [ "dbd-postgres" ]; + lispLibs = [ + (getAttr "cl-postgres" self) + (getAttr "dbi" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + dbd-sqlite3 = ( + build-asdf-system { + pname = "dbd-sqlite3"; + version = "20241012-git"; + asds = [ "dbd-sqlite3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dbi/2024-10-12/cl-dbi-20241012-git.tgz"; + sha256 = "17szd6sz1hlwl5fm4qjgyd8ax01wkbhv8hxcyy8qscx39sc0cnpy"; + system = "dbd-sqlite3"; + asd = "dbd-sqlite3"; + } + ); + systems = [ "dbd-sqlite3" ]; + lispLibs = [ + (getAttr "dbi" self) + (getAttr "sqlite" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + dbi = ( + build-asdf-system { + pname = "dbi"; + version = "20241012-git"; + asds = [ "dbi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dbi/2024-10-12/cl-dbi-20241012-git.tgz"; + sha256 = "17szd6sz1hlwl5fm4qjgyd8ax01wkbhv8hxcyy8qscx39sc0cnpy"; + system = "dbi"; + asd = "dbi"; + } + ); + systems = [ "dbi" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "split-sequence" self) + ]; + meta = { }; + } + ); + dbi-test = ( + build-asdf-system { + pname = "dbi-test"; + version = "20241012-git"; + asds = [ "dbi-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dbi/2024-10-12/cl-dbi-20241012-git.tgz"; + sha256 = "17szd6sz1hlwl5fm4qjgyd8ax01wkbhv8hxcyy8qscx39sc0cnpy"; + system = "dbi-test"; + asd = "dbi-test"; + } + ); + systems = [ "dbi-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "dbi" self) + (getAttr "rove" self) + (getAttr "trivial-types" self) + ]; + meta = { }; + } + ); + dbus = ( + build-asdf-system { + pname = "dbus"; + version = "20241012-git"; + asds = [ "dbus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dbus/2024-10-12/dbus-20241012-git.tgz"; + sha256 = "1y880074m9g0swxrzpbplmkdxc6r62gzyigglf4x2i0zyss3gf65"; + system = "dbus"; + asd = "dbus"; + } + ); + systems = [ "dbus" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "asdf-package-system" self) + (getAttr "babel" self) + (getAttr "cl-xmlspam" self) + (getAttr "cxml" self) + (getAttr "flexi-streams" self) + (getAttr "ieee-floats" self) + (getAttr "iolib" self) + (getAttr "ironclad" self) + (getAttr "split-sequence" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + dct = ( + build-asdf-system { + pname = "dct"; + version = "20220331-git"; + asds = [ "dct" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dct/2022-03-31/cl-dct-20220331-git.tgz"; + sha256 = "1rzq4vdhvr454668a3xf56mha061d27ymsgawmxikgk86wi8biin"; + system = "dct"; + asd = "dct"; + } + ); + systems = [ "dct" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dct-test = ( + build-asdf-system { + pname = "dct-test"; + version = "20220331-git"; + asds = [ "dct-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-dct/2022-03-31/cl-dct-20220331-git.tgz"; + sha256 = "1rzq4vdhvr454668a3xf56mha061d27ymsgawmxikgk86wi8biin"; + system = "dct-test"; + asd = "dct-test"; + } + ); + systems = [ "dct-test" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-coveralls" self) + (getAttr "dct" self) + (getAttr "lisp-unit" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ddo = ( + build-asdf-system { + pname = "ddo"; + version = "20210411-git"; + asds = [ "ddo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; + sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; + system = "ddo"; + asd = "ddo"; + } + ); + systems = [ "ddo" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-mpi" self) + (getAttr "cl-mpi-extensions" self) + (getAttr "femlisp-basic" self) + (getAttr "femlisp-dictionary" self) + (getAttr "femlisp-parallel" self) + (getAttr "lfarm-admin" self) + (getAttr "lfarm-client" self) + (getAttr "lfarm-server" self) + (getAttr "trees" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + de-mock-racy = ( + build-asdf-system { + pname = "de-mock-racy"; + version = "20221106-git"; + asds = [ "de-mock-racy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/de-mock-racy/2022-11-06/de-mock-racy-20221106-git.tgz"; + sha256 = "02rkg1i5r8fgyhaipb0mkz543c8r81kqmwmmvywnnw8hpyvav2xb"; + system = "de-mock-racy"; + asd = "de-mock-racy"; + } + ); + systems = [ "de-mock-racy" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dealii-tutorial = ( + build-asdf-system { + pname = "dealii-tutorial"; + version = "20210411-git"; + asds = [ "dealii-tutorial" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; + sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; + system = "dealii-tutorial"; + asd = "dealii-tutorial"; + } + ); + systems = [ "dealii-tutorial" ]; + lispLibs = [ (getAttr "femlisp" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + decimals = ( + build-asdf-system { + pname = "decimals"; + version = "20211209-git"; + asds = [ "decimals" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-decimals/2021-12-09/cl-decimals-20211209-git.tgz"; + sha256 = "0wn5hq1pwd3wpjqqhpjzarcdk1q6416g8y447iaf55j5nbhlmbn6"; + system = "decimals"; + asd = "decimals"; + } + ); + systems = [ "decimals" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deeds = ( + build-asdf-system { + pname = "deeds"; + version = "20231021-git"; + asds = [ "deeds" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deeds/2023-10-21/deeds-20231021-git.tgz"; + sha256 = "0pd178wydg2zld8pvfm7ss5qvbjh4g8klqbhx2k7h68hn2q1xnn8"; + system = "deeds"; + asd = "deeds"; + } + ); + systems = [ "deeds" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "form-fiddle" self) + (getAttr "lambda-fiddle" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + def-properties = ( + build-asdf-system { + pname = "def-properties"; + version = "20230618-git"; + asds = [ "def-properties" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-def-properties/2023-06-18/cl-def-properties-20230618-git.tgz"; + sha256 = "0yvii6llhmjv1k7hli6waj1bprj8fqhncgnk8mdlg08wwa27a2j8"; + system = "def-properties"; + asd = "def-properties"; + } + ); + systems = [ "def-properties" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defclass-std = ( + build-asdf-system { + pname = "defclass-std"; + version = "20201220-git"; + asds = [ "defclass-std" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defclass-std/2020-12-20/defclass-std-20201220-git.tgz"; + sha256 = "1c0ymb49wd205lzxmnmsrpqyv0pn61snn2xvsbk5iis135r4fr18"; + system = "defclass-std"; + asd = "defclass-std"; + } + ); + systems = [ "defclass-std" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + ]; + meta = { }; + } + ); + defclass-std-test = ( + build-asdf-system { + pname = "defclass-std-test"; + version = "20201220-git"; + asds = [ "defclass-std-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defclass-std/2020-12-20/defclass-std-20201220-git.tgz"; + sha256 = "1c0ymb49wd205lzxmnmsrpqyv0pn61snn2xvsbk5iis135r4fr18"; + system = "defclass-std-test"; + asd = "defclass-std-test"; + } + ); + systems = [ "defclass-std-test" ]; + lispLibs = [ + (getAttr "defclass-std" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defconfig = ( + build-asdf-system { + pname = "defconfig"; + version = "20211209-git"; + asds = [ "defconfig" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defconfig/2021-12-09/defconfig-20211209-git.tgz"; + sha256 = "1gvgni43fxknj800k2k7jhgayzqqqp3s321sw4qmsjxpv479hcqy"; + system = "defconfig"; + asd = "defconfig"; + } + ); + systems = [ "defconfig" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-cltl2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defenum = ( + build-asdf-system { + pname = "defenum"; + version = "20241012-git"; + asds = [ "defenum" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defenum/2024-10-12/defenum-20241012-git.tgz"; + sha256 = "1856w0vsjj9fcyqrry5k4b2iv87xms5wlw8xbqawjax6w5hdsrhk"; + system = "defenum"; + asd = "defenum"; + } + ); + systems = [ "defenum" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deferred = ( + build-asdf-system { + pname = "deferred"; + version = "20231021-git"; + asds = [ "deferred" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deferred/2023-10-21/deferred-20231021-git.tgz"; + sha256 = "0npsxxapah8c3sxmfmi0djvw5kw5pj03dk5ia4yh3q2v7mwzpqy2"; + system = "deferred"; + asd = "deferred"; + } + ); + systems = [ "deferred" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + define-json-expander = ( + build-asdf-system { + pname = "define-json-expander"; + version = "20140713-git"; + asds = [ "define-json-expander" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/define-json-expander/2014-07-13/define-json-expander-20140713-git.tgz"; + sha256 = "193mhjcy1qnfd7r7zia3qs8p7gllvq6s0b2wcqmkh0y17aw8brkh"; + system = "define-json-expander"; + asd = "define-json-expander"; + } + ); + systems = [ "define-json-expander" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + definer = ( + build-asdf-system { + pname = "definer"; + version = "20241012-git"; + asds = [ "definer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/definer/2024-10-12/definer-20241012-git.tgz"; + sha256 = "0vd7gcj55pdzgxq2309pxshplg3rjx95xikkc2ylqrcm9nf3d2zb"; + system = "definer"; + asd = "definer"; + } + ); + systems = [ "definer" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + definitions = ( + build-asdf-system { + pname = "definitions"; + version = "20241012-git"; + asds = [ "definitions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/definitions/2024-10-12/definitions-20241012-git.tgz"; + sha256 = "16wg9rzxc193qvhzay69czr19wzy16b53vm1gy6p25gqvz90zryd"; + system = "definitions"; + asd = "definitions"; + } + ); + systems = [ "definitions" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + definitions-systems = ( + build-asdf-system { + pname = "definitions-systems"; + version = "3.0"; + asds = [ "definitions-systems" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/definitions-systems/2023-06-18/definitions-systems_3.0.tgz"; + sha256 = "0wly8hr9gfxhdz4l46xsh4vj99q9aq7p3cfsglbgv19kdsvv217r"; + system = "definitions-systems"; + asd = "definitions-systems"; + } + ); + systems = [ "definitions-systems" ]; + lispLibs = [ + (getAttr "canonicalized-initargs" self) + (getAttr "closer-mop" self) + (getAttr "enhanced-defclass" self) + (getAttr "enhanced-find-class" self) + (getAttr "shared-preferences" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + definitions-systems__tests = ( + build-asdf-system { + pname = "definitions-systems_tests"; + version = "3.0"; + asds = [ "definitions-systems_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/definitions-systems/2023-06-18/definitions-systems_3.0.tgz"; + sha256 = "0wly8hr9gfxhdz4l46xsh4vj99q9aq7p3cfsglbgv19kdsvv217r"; + system = "definitions-systems_tests"; + asd = "definitions-systems_tests"; + } + ); + systems = [ "definitions-systems_tests" ]; + lispLibs = [ + (getAttr "definitions-systems" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deflate = ( + build-asdf-system { + pname = "deflate"; + version = "20241012-git"; + asds = [ "deflate" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deflate/2024-10-12/deflate-20241012-git.tgz"; + sha256 = "1b225rgc3b2b2k941aj8mz4fkyysi0my368r042wzykq28lwwwij"; + system = "deflate"; + asd = "deflate"; + } + ); + systems = [ "deflate" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deflazy = ( + build-asdf-system { + pname = "deflazy"; + version = "20200427-git"; + asds = [ "deflazy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "deflazy"; + asd = "deflazy"; + } + ); + systems = [ "deflazy" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "uncommon-lisp" self) + (getAttr "utility" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defmain = ( + build-asdf-system { + pname = "defmain"; + version = "20241012-git"; + asds = [ "defmain" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defmain/2024-10-12/defmain-20241012-git.tgz"; + sha256 = "0lb45xmpan188vcysc7d579gg1mc7qi3xyyqc6mqr49571zshzb1"; + system = "defmain"; + asd = "defmain"; + } + ); + systems = [ "defmain" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "alexandria" self) + (getAttr "cl-inflector" self) + (getAttr "cl-strings" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "net_dot_didierverna_dot_clon_dot_core" self) + (getAttr "pythonic-string-reader" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defmain-test = ( + build-asdf-system { + pname = "defmain-test"; + version = "20241012-git"; + asds = [ "defmain-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defmain/2024-10-12/defmain-20241012-git.tgz"; + sha256 = "0lb45xmpan188vcysc7d579gg1mc7qi3xyyqc6mqr49571zshzb1"; + system = "defmain-test"; + asd = "defmain-test"; + } + ); + systems = [ "defmain-test" ]; + lispLibs = [ + (getAttr "defmain" self) + (getAttr "hamcrest" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defmemo = ( + build-asdf-system { + pname = "defmemo"; + version = "20120407-git"; + asds = [ "defmemo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defmemo/2012-04-07/defmemo-20120407-git.tgz"; + sha256 = "0rkvnjfb6fajzfzislz6z372bqpkj6wfbf0sxmzhhigni4wnil27"; + system = "defmemo"; + asd = "defmemo"; + } + ); + systems = [ "defmemo" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defmemo-test = ( + build-asdf-system { + pname = "defmemo-test"; + version = "20120407-git"; + asds = [ "defmemo-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defmemo/2012-04-07/defmemo-20120407-git.tgz"; + sha256 = "0rkvnjfb6fajzfzislz6z372bqpkj6wfbf0sxmzhhigni4wnil27"; + system = "defmemo-test"; + asd = "defmemo"; + } + ); + systems = [ "defmemo-test" ]; + lispLibs = [ (getAttr "defmemo" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defpackage-plus = ( + build-asdf-system { + pname = "defpackage-plus"; + version = "20180131-git"; + asds = [ "defpackage-plus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defpackage-plus/2018-01-31/defpackage-plus-20180131-git.tgz"; + sha256 = "0lzljvf343xb6mlh6lni2i27hpm5qd376522mk6hr2pa20vd6rdq"; + system = "defpackage-plus"; + asd = "defpackage-plus"; + } + ); + systems = [ "defpackage-plus" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defrec = ( + build-asdf-system { + pname = "defrec"; + version = "20230618-git"; + asds = [ "defrec" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defrec/2023-06-18/defrec-20230618-git.tgz"; + sha256 = "04wd43z2k5cv4a55x532y3aqc7gf1ksndvndvy0y6bslxqqgv63m"; + system = "defrec"; + asd = "defrec"; + } + ); + systems = [ "defrec" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defrest = ( + build-asdf-system { + pname = "defrest"; + version = "20210531-git"; + asds = [ "defrest" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defrest/2021-05-31/defrest-20210531-git.tgz"; + sha256 = "14pap344a0549mb7p79jf87ibfxmymk0hf9i7galcfi4s8nqq45g"; + system = "defrest"; + asd = "defrest"; + } + ); + systems = [ "defrest" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "hunchentoot" self) + (getAttr "quri" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defrest_dot_test = ( + build-asdf-system { + pname = "defrest.test"; + version = "20210531-git"; + asds = [ "defrest.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defrest/2021-05-31/defrest-20210531-git.tgz"; + sha256 = "14pap344a0549mb7p79jf87ibfxmymk0hf9i7galcfi4s8nqq45g"; + system = "defrest.test"; + asd = "defrest"; + } + ); + systems = [ "defrest.test" ]; + lispLibs = [ + (getAttr "defrest" self) + (getAttr "drakma" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defstar = ( + build-asdf-system { + pname = "defstar"; + version = "20140713-git"; + asds = [ "defstar" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defstar/2014-07-13/defstar-20140713-git.tgz"; + sha256 = "0n6m3aqvdfnsrhlhqjcy72d1i55lbkjg13ij5c7vw003p1n78wxi"; + system = "defstar"; + asd = "defstar"; + } + ); + systems = [ "defstar" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defsystem-compatibility = ( + build-asdf-system { + pname = "defsystem-compatibility"; + version = "20101006-darcs"; + asds = [ "defsystem-compatibility" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defsystem-compatibility/2010-10-06/defsystem-compatibility-20101006-darcs.tgz"; + sha256 = "0bw0c69zyika19rvzl8xplwrqsgznhnlbj40fcszfw0vxh2czj0f"; + system = "defsystem-compatibility"; + asd = "defsystem-compatibility"; + } + ); + systems = [ "defsystem-compatibility" ]; + lispLibs = [ (getAttr "metatilities-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defsystem-compatibility-test = ( + build-asdf-system { + pname = "defsystem-compatibility-test"; + version = "20101006-darcs"; + asds = [ "defsystem-compatibility-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defsystem-compatibility/2010-10-06/defsystem-compatibility-20101006-darcs.tgz"; + sha256 = "0bw0c69zyika19rvzl8xplwrqsgznhnlbj40fcszfw0vxh2czj0f"; + system = "defsystem-compatibility-test"; + asd = "defsystem-compatibility-test"; + } + ); + systems = [ "defsystem-compatibility-test" ]; + lispLibs = [ + (getAttr "defsystem-compatibility" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + defvariant = ( + build-asdf-system { + pname = "defvariant"; + version = "20140713-git"; + asds = [ "defvariant" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/defvariant/2014-07-13/defvariant-20140713-git.tgz"; + sha256 = "0rma557l2irjyzrswcd7329iic2pjxw0jgk3m2inag39l6wyqsr1"; + system = "defvariant"; + asd = "defvariant"; + } + ); + systems = [ "defvariant" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + delorean = ( + build-asdf-system { + pname = "delorean"; + version = "20130615-git"; + asds = [ "delorean" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/delorean/2013-06-15/delorean-20130615-git.tgz"; + sha256 = "0q11wqdlvis91i996mar72icw07yf7mwmsnlmsbsya9kaqj7n3cd"; + system = "delorean"; + asd = "delorean"; + } + ); + systems = [ "delorean" ]; + lispLibs = [ (getAttr "local-time" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + delorean-test = ( + build-asdf-system { + pname = "delorean-test"; + version = "20130615-git"; + asds = [ "delorean-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/delorean/2013-06-15/delorean-20130615-git.tgz"; + sha256 = "0q11wqdlvis91i996mar72icw07yf7mwmsnlmsbsya9kaqj7n3cd"; + system = "delorean-test"; + asd = "delorean"; + } + ); + systems = [ "delorean-test" ]; + lispLibs = [ + (getAttr "delorean" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + delta-debug = ( + build-asdf-system { + pname = "delta-debug"; + version = "20180831-git"; + asds = [ "delta-debug" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/delta-debug/2018-08-31/delta-debug-20180831-git.tgz"; + sha256 = "0dm33v8ipkpr23mjb9s6z2c7gmxwjbd5khc7c1vangba18nzm7ir"; + system = "delta-debug"; + asd = "delta-debug"; + } + ); + systems = [ "delta-debug" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "curry-compose-reader-macros" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dendrite = ( + build-asdf-system { + pname = "dendrite"; + version = "release-quicklisp-409b1061-git"; + asds = [ "dendrite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dendrite/2017-10-23/dendrite-release-quicklisp-409b1061-git.tgz"; + sha256 = "1fsi77w2yamis2707f1hx09pmyjaxqpzl8s0h182vpz159lkxdy5"; + system = "dendrite"; + asd = "dendrite"; + } + ); + systems = [ "dendrite" ]; + lispLibs = [ + (getAttr "dendrite_dot_micro-l-system" self) + (getAttr "dendrite_dot_primitives" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dendrite_dot_micro-l-system = ( + build-asdf-system { + pname = "dendrite.micro-l-system"; + version = "release-quicklisp-409b1061-git"; + asds = [ "dendrite.micro-l-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dendrite/2017-10-23/dendrite-release-quicklisp-409b1061-git.tgz"; + sha256 = "1fsi77w2yamis2707f1hx09pmyjaxqpzl8s0h182vpz159lkxdy5"; + system = "dendrite.micro-l-system"; + asd = "dendrite.micro-l-system"; + } + ); + systems = [ "dendrite.micro-l-system" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dendrite_dot_primitives = ( + build-asdf-system { + pname = "dendrite.primitives"; + version = "release-quicklisp-409b1061-git"; + asds = [ "dendrite.primitives" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dendrite/2017-10-23/dendrite-release-quicklisp-409b1061-git.tgz"; + sha256 = "1fsi77w2yamis2707f1hx09pmyjaxqpzl8s0h182vpz159lkxdy5"; + system = "dendrite.primitives"; + asd = "dendrite.primitives"; + } + ); + systems = [ "dendrite.primitives" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "rtg-math" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deoxybyte-gzip = ( + build-asdf-system { + pname = "deoxybyte-gzip"; + version = "20140113-git"; + asds = [ "deoxybyte-gzip" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deoxybyte-gzip/2014-01-13/deoxybyte-gzip-20140113-git.tgz"; + sha256 = "0ccci902nxqhdlskw3pghcjg0vgl10xlh16cb5b631j3n2ajfa16"; + system = "deoxybyte-gzip"; + asd = "deoxybyte-gzip"; + } + ); + systems = [ "deoxybyte-gzip" ]; + lispLibs = [ + (getAttr "deoxybyte-io" self) + (getAttr "deoxybyte-systems" self) + (getAttr "deoxybyte-unix" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deoxybyte-gzip-test = ( + build-asdf-system { + pname = "deoxybyte-gzip-test"; + version = "20140113-git"; + asds = [ "deoxybyte-gzip-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deoxybyte-gzip/2014-01-13/deoxybyte-gzip-20140113-git.tgz"; + sha256 = "0ccci902nxqhdlskw3pghcjg0vgl10xlh16cb5b631j3n2ajfa16"; + system = "deoxybyte-gzip-test"; + asd = "deoxybyte-gzip-test"; + } + ); + systems = [ "deoxybyte-gzip-test" ]; + lispLibs = [ + (getAttr "deoxybyte-gzip" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deoxybyte-io = ( + build-asdf-system { + pname = "deoxybyte-io"; + version = "20140113-git"; + asds = [ "deoxybyte-io" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deoxybyte-io/2014-01-13/deoxybyte-io-20140113-git.tgz"; + sha256 = "0pjx96g50yqhdk0l1y970hc22fc1bl8ppyklhp62l41b4fb7hbbv"; + system = "deoxybyte-io"; + asd = "deoxybyte-io"; + } + ); + systems = [ "deoxybyte-io" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "deoxybyte-systems" self) + (getAttr "deoxybyte-utilities" self) + (getAttr "getopt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deoxybyte-io-test = ( + build-asdf-system { + pname = "deoxybyte-io-test"; + version = "20140113-git"; + asds = [ "deoxybyte-io-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deoxybyte-io/2014-01-13/deoxybyte-io-20140113-git.tgz"; + sha256 = "0pjx96g50yqhdk0l1y970hc22fc1bl8ppyklhp62l41b4fb7hbbv"; + system = "deoxybyte-io-test"; + asd = "deoxybyte-io-test"; + } + ); + systems = [ "deoxybyte-io-test" ]; + lispLibs = [ + (getAttr "deoxybyte-io" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deoxybyte-systems = ( + build-asdf-system { + pname = "deoxybyte-systems"; + version = "20140113-git"; + asds = [ "deoxybyte-systems" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deoxybyte-systems/2014-01-13/deoxybyte-systems-20140113-git.tgz"; + sha256 = "0sbzl0ngz85mvkghcy8y94hk34v5hvi41b111mb76f2jvdq9jjr8"; + system = "deoxybyte-systems"; + asd = "deoxybyte-systems"; + } + ); + systems = [ "deoxybyte-systems" ]; + lispLibs = [ (getAttr "cl-fad" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deoxybyte-unix = ( + build-asdf-system { + pname = "deoxybyte-unix"; + version = "20140113-git"; + asds = [ "deoxybyte-unix" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deoxybyte-unix/2014-01-13/deoxybyte-unix-20140113-git.tgz"; + sha256 = "016lgb8vcnn7qwhndan1d61wbb10xmsczqp7h2kkfnhlvkr484qf"; + system = "deoxybyte-unix"; + asd = "deoxybyte-unix"; + } + ); + systems = [ "deoxybyte-unix" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "deoxybyte-io" self) + (getAttr "deoxybyte-systems" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deoxybyte-unix-test = ( + build-asdf-system { + pname = "deoxybyte-unix-test"; + version = "20140113-git"; + asds = [ "deoxybyte-unix-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deoxybyte-unix/2014-01-13/deoxybyte-unix-20140113-git.tgz"; + sha256 = "016lgb8vcnn7qwhndan1d61wbb10xmsczqp7h2kkfnhlvkr484qf"; + system = "deoxybyte-unix-test"; + asd = "deoxybyte-unix-test"; + } + ); + systems = [ "deoxybyte-unix-test" ]; + lispLibs = [ + (getAttr "deoxybyte-unix" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deoxybyte-utilities = ( + build-asdf-system { + pname = "deoxybyte-utilities"; + version = "20140113-git"; + asds = [ "deoxybyte-utilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deoxybyte-utilities/2014-01-13/deoxybyte-utilities-20140113-git.tgz"; + sha256 = "054mvn27d9xdsal87avyxzphgv6pk96a0c1icpkldqczlmzl9j0g"; + system = "deoxybyte-utilities"; + asd = "deoxybyte-utilities"; + } + ); + systems = [ "deoxybyte-utilities" ]; + lispLibs = [ (getAttr "deoxybyte-systems" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deoxybyte-utilities-test = ( + build-asdf-system { + pname = "deoxybyte-utilities-test"; + version = "20140113-git"; + asds = [ "deoxybyte-utilities-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deoxybyte-utilities/2014-01-13/deoxybyte-utilities-20140113-git.tgz"; + sha256 = "054mvn27d9xdsal87avyxzphgv6pk96a0c1icpkldqczlmzl9j0g"; + system = "deoxybyte-utilities-test"; + asd = "deoxybyte-utilities-test"; + } + ); + systems = [ "deoxybyte-utilities-test" ]; + lispLibs = [ + (getAttr "deoxybyte-utilities" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deploy = ( + build-asdf-system { + pname = "deploy"; + version = "20241012-git"; + asds = [ "deploy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deploy/2024-10-12/deploy-20241012-git.tgz"; + sha256 = "1ysi8fjgb7kq3cycb6ms44j0m70xbd140fh4qgcpj7fm26p2a59p"; + system = "deploy"; + asd = "deploy"; + } + ); + systems = [ "deploy" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "sha3" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deploy-test = ( + build-asdf-system { + pname = "deploy-test"; + version = "20241012-git"; + asds = [ "deploy-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deploy/2024-10-12/deploy-20241012-git.tgz"; + sha256 = "1ysi8fjgb7kq3cycb6ms44j0m70xbd140fh4qgcpj7fm26p2a59p"; + system = "deploy-test"; + asd = "deploy-test"; + } + ); + systems = [ "deploy-test" ]; + lispLibs = [ + (getAttr "cl-mpg123" self) + (getAttr "cl-out123" self) + (getAttr "deploy" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + depot = ( + build-asdf-system { + pname = "depot"; + version = "20241012-git"; + asds = [ "depot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/depot/2024-10-12/depot-20241012-git.tgz"; + sha256 = "1k9p4jqylh7i53sngi0yn2hww6y6lxqc7c0hd3j3p8jc4q3h4zn4"; + system = "depot"; + asd = "depot"; + } + ); + systems = [ "depot" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + depot-in-memory = ( + build-asdf-system { + pname = "depot-in-memory"; + version = "20241012-git"; + asds = [ "depot-in-memory" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/depot/2024-10-12/depot-20241012-git.tgz"; + sha256 = "1k9p4jqylh7i53sngi0yn2hww6y6lxqc7c0hd3j3p8jc4q3h4zn4"; + system = "depot-in-memory"; + asd = "depot-in-memory"; + } + ); + systems = [ "depot-in-memory" ]; + lispLibs = [ + (getAttr "atomics" self) + (getAttr "depot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + depot-test = ( + build-asdf-system { + pname = "depot-test"; + version = "20241012-git"; + asds = [ "depot-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/depot/2024-10-12/depot-20241012-git.tgz"; + sha256 = "1k9p4jqylh7i53sngi0yn2hww6y6lxqc7c0hd3j3p8jc4q3h4zn4"; + system = "depot-test"; + asd = "depot-test"; + } + ); + systems = [ "depot-test" ]; + lispLibs = [ + (getAttr "depot" self) + (getAttr "depot-in-memory" self) + (getAttr "depot-zip" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + depot-virtual = ( + build-asdf-system { + pname = "depot-virtual"; + version = "20241012-git"; + asds = [ "depot-virtual" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/depot/2024-10-12/depot-20241012-git.tgz"; + sha256 = "1k9p4jqylh7i53sngi0yn2hww6y6lxqc7c0hd3j3p8jc4q3h4zn4"; + system = "depot-virtual"; + asd = "depot-virtual"; + } + ); + systems = [ "depot-virtual" ]; + lispLibs = [ (getAttr "depot" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + depot-zip = ( + build-asdf-system { + pname = "depot-zip"; + version = "20241012-git"; + asds = [ "depot-zip" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/depot/2024-10-12/depot-20241012-git.tgz"; + sha256 = "1k9p4jqylh7i53sngi0yn2hww6y6lxqc7c0hd3j3p8jc4q3h4zn4"; + system = "depot-zip"; + asd = "depot-zip"; + } + ); + systems = [ "depot-zip" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "depot" self) + (getAttr "zippy" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + deptree = ( + build-asdf-system { + pname = "deptree"; + version = "20241012-git"; + asds = [ "deptree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/deptree/2024-10-12/deptree-20241012-git.tgz"; + sha256 = "10ybmw28c52ahbm7xjn795367lssp6088v6705fmqbl0fgjpvxnw"; + system = "deptree"; + asd = "deptree"; + } + ); + systems = [ "deptree" ]; + lispLibs = [ (getAttr "tar" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + descriptions = ( + build-asdf-system { + pname = "descriptions"; + version = "20150302-git"; + asds = [ "descriptions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/descriptions/2015-03-02/descriptions-20150302-git.tgz"; + sha256 = "0h44gxilwmzk8cbxb81047cjndksvf8vw2s3pcy2diw9aqiacg7f"; + system = "descriptions"; + asd = "descriptions"; + } + ); + systems = [ "descriptions" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "closer-mop" self) + (getAttr "sheeple" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + descriptions-test = ( + build-asdf-system { + pname = "descriptions-test"; + version = "20150302-git"; + asds = [ "descriptions-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/descriptions/2015-03-02/descriptions-20150302-git.tgz"; + sha256 = "0h44gxilwmzk8cbxb81047cjndksvf8vw2s3pcy2diw9aqiacg7f"; + system = "descriptions-test"; + asd = "descriptions-test"; + } + ); + systems = [ "descriptions-test" ]; + lispLibs = [ + (getAttr "descriptions" self) + (getAttr "descriptions_dot_serialization" self) + (getAttr "descriptions_dot_validation" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + descriptions_dot_serialization = ( + build-asdf-system { + pname = "descriptions.serialization"; + version = "20150302-git"; + asds = [ "descriptions.serialization" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/descriptions/2015-03-02/descriptions-20150302-git.tgz"; + sha256 = "0h44gxilwmzk8cbxb81047cjndksvf8vw2s3pcy2diw9aqiacg7f"; + system = "descriptions.serialization"; + asd = "descriptions.serialization"; + } + ); + systems = [ "descriptions.serialization" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "descriptions" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + descriptions_dot_validation = ( + build-asdf-system { + pname = "descriptions.validation"; + version = "20150302-git"; + asds = [ "descriptions.validation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/descriptions/2015-03-02/descriptions-20150302-git.tgz"; + sha256 = "0h44gxilwmzk8cbxb81047cjndksvf8vw2s3pcy2diw9aqiacg7f"; + system = "descriptions.validation"; + asd = "descriptions.validation"; + } + ); + systems = [ "descriptions.validation" ]; + lispLibs = [ + (getAttr "clavier" self) + (getAttr "descriptions" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + destructuring-bind-star = ( + build-asdf-system { + pname = "destructuring-bind-star"; + version = "20200610-git"; + asds = [ "destructuring-bind-star" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/destructuring-bind-star/2020-06-10/destructuring-bind-star-20200610-git.tgz"; + sha256 = "1j1xnhvb6pm9q291aawbrcwp8bgbmiij9a53gifxhr4kp934ciz2"; + system = "destructuring-bind-star"; + asd = "destructuring-bind-star"; + } + ); + systems = [ "destructuring-bind-star" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dexador = ( + build-asdf-system { + pname = "dexador"; + version = "20241012-git"; + asds = [ "dexador" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dexador/2024-10-12/dexador-20241012-git.tgz"; + sha256 = "19y95k821665vcy7gbxhh4rqwk7fh4brv1sgkaykncpw2l2lll5r"; + system = "dexador"; + asd = "dexador"; + } + ); + systems = [ "dexador" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "chipz" self) + (getAttr "chunga" self) + (getAttr "cl_plus_ssl" self) + (getAttr "cl-base64" self) + (getAttr "cl-cookie" self) + (getAttr "cl-ppcre" self) + (getAttr "fast-http" self) + (getAttr "fast-io" self) + (getAttr "quri" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-gray-streams" self) + (getAttr "trivial-mimes" self) + (getAttr "usocket" self) + ]; + meta = { }; + } + ); + dexador-test = ( + build-asdf-system { + pname = "dexador-test"; + version = "20241012-git"; + asds = [ "dexador-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dexador/2024-10-12/dexador-20241012-git.tgz"; + sha256 = "19y95k821665vcy7gbxhh4rqwk7fh4brv1sgkaykncpw2l2lll5r"; + system = "dexador-test"; + asd = "dexador-test"; + } + ); + systems = [ "dexador-test" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-cookie" self) + (getAttr "clack-test" self) + (getAttr "dexador" self) + (getAttr "lack-request" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dexador-usocket = ( + build-asdf-system { + pname = "dexador-usocket"; + version = "20241012-git"; + asds = [ "dexador-usocket" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dexador/2024-10-12/dexador-20241012-git.tgz"; + sha256 = "19y95k821665vcy7gbxhh4rqwk7fh4brv1sgkaykncpw2l2lll5r"; + system = "dexador-usocket"; + asd = "dexador-usocket"; + } + ); + systems = [ "dexador-usocket" ]; + lispLibs = [ + (getAttr "cl_plus_ssl" self) + (getAttr "dexador" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dfio = ( + build-asdf-system { + pname = "dfio"; + version = "20221106-git"; + asds = [ "dfio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dfio/2022-11-06/dfio-20221106-git.tgz"; + sha256 = "1p53r7773939jnap518xp4b4wfvc1kbrz9jp6yd40xq0jpf9pbqg"; + system = "dfio"; + asd = "dfio"; + } + ); + systems = [ "dfio" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "data-frame" self) + (getAttr "dexador" self) + (getAttr "fare-csv" self) + (getAttr "let-plus" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + diff = ( + build-asdf-system { + pname = "diff"; + version = "20130813-git"; + asds = [ "diff" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/diff/2013-08-13/diff-20130813-git.tgz"; + sha256 = "1giafck8qfvb688kx5bn9g32rfc12jjywg8vdav36aqbd6lxf5z5"; + system = "diff"; + asd = "diff"; + } + ); + systems = [ "diff" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + diff-match-patch = ( + build-asdf-system { + pname = "diff-match-patch"; + version = "20210531-git"; + asds = [ "diff-match-patch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/diff-match-patch/2021-05-31/diff-match-patch-20210531-git.tgz"; + sha256 = "0wxz2q9sd2v8fg521f7bzv6wi3za7saz2j2snsnw2p1kcsj6zqa4"; + system = "diff-match-patch"; + asd = "diff-match-patch"; + } + ); + systems = [ "diff-match-patch" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dirt = ( + build-asdf-system { + pname = "dirt"; + version = "release-quicklisp-0d13ebc2-git"; + asds = [ "dirt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dirt/2017-10-19/dirt-release-quicklisp-0d13ebc2-git.tgz"; + sha256 = "1lqxfdzn9rh7rzsq97d4hp6fl4g9fs6s0n2pvf460d6ri6p40xna"; + system = "dirt"; + asd = "dirt"; + } + ); + systems = [ "dirt" ]; + lispLibs = [ + (getAttr "cepl" self) + (getAttr "cl-soil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dispatch = ( + build-asdf-system { + pname = "dispatch"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "dispatch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "dispatch"; + asd = "dispatch"; + } + ); + systems = [ "dispatch" ]; + lispLibs = [ + (getAttr "adjuvant" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dispatch-test = ( + build-asdf-system { + pname = "dispatch-test"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "dispatch-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "dispatch-test"; + asd = "dispatch-test"; + } + ); + systems = [ "dispatch-test" ]; + lispLibs = [ + (getAttr "dispatch" self) + (getAttr "scrutiny" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + disposable = ( + build-asdf-system { + pname = "disposable"; + version = "20160208-git"; + asds = [ "disposable" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/disposable/2016-02-08/disposable-20160208-git.tgz"; + sha256 = "18synnlg4b8203rgww644dj7ghb4m1j33lb4zm64850vqy5b3pz7"; + system = "disposable"; + asd = "disposable"; + } + ); + systems = [ "disposable" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dissect = ( + build-asdf-system { + pname = "dissect"; + version = "20241012-git"; + asds = [ "dissect" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dissect/2024-10-12/dissect-20241012-git.tgz"; + sha256 = "1ym1zggwrj15l7y2mcz5l2gfk68prqxhdswffd9s5014pa6zyysr"; + system = "dissect"; + asd = "dissect"; + } + ); + systems = [ "dissect" ]; + lispLibs = [ ]; + meta = { }; + } + ); + distributions = ( + build-asdf-system { + pname = "distributions"; + version = "20221106-git"; + asds = [ "distributions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/distributions/2022-11-06/distributions-20221106-git.tgz"; + sha256 = "1fkzigd0s0s0mvszgmv04yc8jp9gm4812445hfh6kpz6cjy5zpsk"; + system = "distributions"; + asd = "distributions"; + } + ); + systems = [ "distributions" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "array-operations" self) + (getAttr "cephes" self) + (getAttr "float-features" self) + (getAttr "let-plus" self) + (getAttr "num-utils" self) + (getAttr "special-functions" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + djula = ( + build-asdf-system { + pname = "djula"; + version = "20241012-git"; + asds = [ "djula" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/djula/2024-10-12/djula-20241012-git.tgz"; + sha256 = "1m4k0ywkpvbpljd8r9vfmsw2zkphwcfwgbdp911zkiv5rcnmgykw"; + system = "djula"; + asd = "djula"; + } + ); + systems = [ "djula" ]; + lispLibs = [ + (getAttr "access" self) + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-locale" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-slice" self) + (getAttr "closer-mop" self) + (getAttr "gettext" self) + (getAttr "iterate" self) + (getAttr "local-time" self) + (getAttr "parser-combinators" self) + (getAttr "split-sequence" self) + (getAttr "trivial-backtrace" self) + ]; + meta = { }; + } + ); + djula-demo = ( + build-asdf-system { + pname = "djula-demo"; + version = "20241012-git"; + asds = [ "djula-demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/djula/2024-10-12/djula-20241012-git.tgz"; + sha256 = "1m4k0ywkpvbpljd8r9vfmsw2zkphwcfwgbdp911zkiv5rcnmgykw"; + system = "djula-demo"; + asd = "djula-demo"; + } + ); + systems = [ "djula-demo" ]; + lispLibs = [ + (getAttr "djula" self) + (getAttr "hunchentoot" self) + (getAttr "trivial-open-browser" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + djula-gettext = ( + build-asdf-system { + pname = "djula-gettext"; + version = "20241012-git"; + asds = [ "djula-gettext" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/djula/2024-10-12/djula-20241012-git.tgz"; + sha256 = "1m4k0ywkpvbpljd8r9vfmsw2zkphwcfwgbdp911zkiv5rcnmgykw"; + system = "djula-gettext"; + asd = "djula-gettext"; + } + ); + systems = [ "djula-gettext" ]; + lispLibs = [ + (getAttr "djula" self) + (getAttr "gettext" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + djula-locale = ( + build-asdf-system { + pname = "djula-locale"; + version = "20241012-git"; + asds = [ "djula-locale" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/djula/2024-10-12/djula-20241012-git.tgz"; + sha256 = "1m4k0ywkpvbpljd8r9vfmsw2zkphwcfwgbdp911zkiv5rcnmgykw"; + system = "djula-locale"; + asd = "djula-locale"; + } + ); + systems = [ "djula-locale" ]; + lispLibs = [ + (getAttr "cl-locale" self) + (getAttr "djula" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + djula-test = ( + build-asdf-system { + pname = "djula-test"; + version = "20241012-git"; + asds = [ "djula-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/djula/2024-10-12/djula-20241012-git.tgz"; + sha256 = "1m4k0ywkpvbpljd8r9vfmsw2zkphwcfwgbdp911zkiv5rcnmgykw"; + system = "djula-test"; + asd = "djula-test"; + } + ); + systems = [ "djula-test" ]; + lispLibs = [ + (getAttr "djula" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + djula-translate = ( + build-asdf-system { + pname = "djula-translate"; + version = "20241012-git"; + asds = [ "djula-translate" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/djula/2024-10-12/djula-20241012-git.tgz"; + sha256 = "1m4k0ywkpvbpljd8r9vfmsw2zkphwcfwgbdp911zkiv5rcnmgykw"; + system = "djula-translate"; + asd = "djula-translate"; + } + ); + systems = [ "djula-translate" ]; + lispLibs = [ + (getAttr "djula" self) + (getAttr "translate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dlist = ( + build-asdf-system { + pname = "dlist"; + version = "20121125-git"; + asds = [ "dlist" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dlist/2012-11-25/dlist-20121125-git.tgz"; + sha256 = "1ycgjmbxpj0bj95xg0x7m30yz8y73s7mnqs0dzam00rkf8g00h89"; + system = "dlist"; + asd = "dlist"; + } + ); + systems = [ "dlist" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dlist-test = ( + build-asdf-system { + pname = "dlist-test"; + version = "20121125-git"; + asds = [ "dlist-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dlist/2012-11-25/dlist-20121125-git.tgz"; + sha256 = "1ycgjmbxpj0bj95xg0x7m30yz8y73s7mnqs0dzam00rkf8g00h89"; + system = "dlist-test"; + asd = "dlist"; + } + ); + systems = [ "dlist-test" ]; + lispLibs = [ + (getAttr "dlist" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dml = ( + build-asdf-system { + pname = "dml"; + version = "20231021-git"; + asds = [ "dml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dml/2023-10-21/dml-20231021-git.tgz"; + sha256 = "15yxfgmzxpn3hr3kfmw7iid652v1v1v0fw7ngvs1ig6693kci72h"; + system = "dml"; + asd = "dml"; + } + ); + systems = [ "dml" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-cairo2" self) + (getAttr "cl-ppcre" self) + (getAttr "donuts" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dns-client = ( + build-asdf-system { + pname = "dns-client"; + version = "20241012-git"; + asds = [ "dns-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dns-client/2024-10-12/dns-client-20241012-git.tgz"; + sha256 = "1lbxryi0hx1i0ib3rz3ci89pfdyzikhv4dg0lk5piggrkdji2fx3"; + system = "dns-client"; + asd = "dns-client"; + } + ); + systems = [ "dns-client" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "punycode" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + do-urlencode = ( + build-asdf-system { + pname = "do-urlencode"; + version = "20181018-git"; + asds = [ "do-urlencode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/do-urlencode/2018-10-18/do-urlencode-20181018-git.tgz"; + sha256 = "0k2i3d4k9cpci235mwfm0c5a4yqfkijr716bjv7cdlpzx88lazm9"; + system = "do-urlencode"; + asd = "do-urlencode"; + } + ); + systems = [ "do-urlencode" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + ]; + meta = { }; + } + ); + docbrowser = ( + build-asdf-system { + pname = "docbrowser"; + version = "20200610-git"; + asds = [ "docbrowser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/docbrowser/2020-06-10/docbrowser-20200610-git.tgz"; + sha256 = "0k7gkyciqfbwdmvip2s8h4k21a63h45bj3qydq3jbvkhaq4gj9x1"; + system = "docbrowser"; + asd = "docbrowser"; + } + ); + systems = [ "docbrowser" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-json" self) + (getAttr "closer-mop" self) + (getAttr "colorize" self) + (getAttr "flexi-streams" self) + (getAttr "hunchentoot" self) + (getAttr "parse-number" self) + (getAttr "split-sequence" self) + (getAttr "string-case" self) + (getAttr "swank" self) + (getAttr "yacc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + docparser = ( + build-asdf-system { + pname = "docparser"; + version = "20230214-git"; + asds = [ "docparser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/docparser/2023-02-14/docparser-20230214-git.tgz"; + sha256 = "1ix8n6albgl34kwvk2f3vfz9afi6y4m9dd6k3axlm9g16zhmhma1"; + system = "docparser"; + asd = "docparser"; + } + ); + systems = [ "docparser" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cffi" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + docparser-test = ( + build-asdf-system { + pname = "docparser-test"; + version = "20230214-git"; + asds = [ "docparser-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/docparser/2023-02-14/docparser-20230214-git.tgz"; + sha256 = "1ix8n6albgl34kwvk2f3vfz9afi6y4m9dd6k3axlm9g16zhmhma1"; + system = "docparser-test"; + asd = "docparser-test"; + } + ); + systems = [ "docparser-test" ]; + lispLibs = [ + (getAttr "docparser" self) + (getAttr "docparser-test-system" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + docparser-test-system = ( + build-asdf-system { + pname = "docparser-test-system"; + version = "20230214-git"; + asds = [ "docparser-test-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/docparser/2023-02-14/docparser-20230214-git.tgz"; + sha256 = "1ix8n6albgl34kwvk2f3vfz9afi6y4m9dd6k3axlm9g16zhmhma1"; + system = "docparser-test-system"; + asd = "docparser-test-system"; + } + ); + systems = [ "docparser-test-system" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + docs-builder = ( + build-asdf-system { + pname = "docs-builder"; + version = "20241012-git"; + asds = [ "docs-builder" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/docs-builder/2024-10-12/docs-builder-20241012-git.tgz"; + sha256 = "09pg4frik728g7njrpkb8jmzw6q9f47ng4c123lmqlmjha9bs03c"; + system = "docs-builder"; + asd = "docs-builder"; + } + ); + systems = [ "docs-builder" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "alexandria" self) + (getAttr "docs-config" self) + (getAttr "log4cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + docs-config = ( + build-asdf-system { + pname = "docs-config"; + version = "20241012-git"; + asds = [ "docs-config" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/docs-builder/2024-10-12/docs-builder-20241012-git.tgz"; + sha256 = "09pg4frik728g7njrpkb8jmzw6q9f47ng4c123lmqlmjha9bs03c"; + system = "docs-config"; + asd = "docs-config"; + } + ); + systems = [ "docs-config" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + documentation-template = ( + build-asdf-system { + pname = "documentation-template"; + version = "0.4.4"; + asds = [ "documentation-template" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/documentation-template/2014-12-17/documentation-template-0.4.4.tgz"; + sha256 = "0pfcg38ws0syhg2l15nwslfyj175dq1dvjip64nx02knw26zj56y"; + system = "documentation-template"; + asd = "documentation-template"; + } + ); + systems = [ "documentation-template" ]; + lispLibs = [ (getAttr "cl-who" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + documentation-utils = ( + build-asdf-system { + pname = "documentation-utils"; + version = "20231021-git"; + asds = [ "documentation-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/documentation-utils/2023-10-21/documentation-utils-20231021-git.tgz"; + sha256 = "0nzkjzvcqi1l2ywiz17h1f54vgvbkywv95in4yww6lyzqjqsqqhy"; + system = "documentation-utils"; + asd = "documentation-utils"; + } + ); + systems = [ "documentation-utils" ]; + lispLibs = [ (getAttr "trivial-indent" self) ]; + meta = { }; + } + ); + documentation-utils-extensions = ( + build-asdf-system { + pname = "documentation-utils-extensions"; + version = "20220707-git"; + asds = [ "documentation-utils-extensions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/documentation-utils-extensions/2022-07-07/documentation-utils-extensions-20220707-git.tgz"; + sha256 = "1bv8y1hbn6fivvsanaci19k47vfdchj3argz92az3izmar9ybp4f"; + system = "documentation-utils-extensions"; + asd = "documentation-utils-extensions"; + } + ); + systems = [ "documentation-utils-extensions" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + docutils = ( + build-asdf-system { + pname = "docutils"; + version = "20130128-git"; + asds = [ "docutils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-docutils/2013-01-28/cl-docutils-20130128-git.tgz"; + sha256 = "132bxlj0jlhiabi29mygmkcbbgyb5s1yz1xdfhm3pgrf9f8605gg"; + system = "docutils"; + asd = "docutils"; + } + ); + systems = [ "docutils" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "data-format-validation" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dom = ( + build-asdf-system { + pname = "dom"; + version = "master-fe503896-git"; + asds = [ "dom" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "dom"; + asd = "dom"; + } + ); + systems = [ "dom" ]; + lispLibs = [ + (getAttr "cl-who" self) + (getAttr "yadd" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + donuts = ( + build-asdf-system { + pname = "donuts"; + version = "20120703-git"; + asds = [ "donuts" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/donuts/2012-07-03/donuts-20120703-git.tgz"; + sha256 = "1arjlwic0gk28ja1ql5k1r3v0pqzg42ds8vzq9266hq5lp06q3ii"; + system = "donuts"; + asd = "donuts"; + } + ); + systems = [ "donuts" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + doplus = ( + build-asdf-system { + pname = "doplus"; + version = "v1.1.0"; + asds = [ "doplus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/doplus/2021-10-20/doplus-v1.1.0.tgz"; + sha256 = "1yvda9psw9m08d3bzdb8a2drvhrnr07a0rhza5ibk30v1dkwfw7c"; + system = "doplus"; + asd = "doplus"; + } + ); + systems = [ "doplus" ]; + lispLibs = [ (getAttr "parse-declarations-1_dot_0" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + doplus-fset = ( + build-asdf-system { + pname = "doplus-fset"; + version = "v1.1.0"; + asds = [ "doplus-fset" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/doplus/2021-10-20/doplus-v1.1.0.tgz"; + sha256 = "1yvda9psw9m08d3bzdb8a2drvhrnr07a0rhza5ibk30v1dkwfw7c"; + system = "doplus-fset"; + asd = "doplus-fset"; + } + ); + systems = [ "doplus-fset" ]; + lispLibs = [ + (getAttr "doplus" self) + (getAttr "fset" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dotenv = ( + build-asdf-system { + pname = "dotenv"; + version = "20211209-git"; + asds = [ "dotenv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dotenv/2021-12-09/dotenv-20211209-git.tgz"; + sha256 = "0g19svpxy2169rym532gjwsg1zybinpc99mjsy6im4n6zdd57hzh"; + system = "dotenv"; + asd = "dotenv"; + } + ); + systems = [ "dotenv" ]; + lispLibs = [ + (getAttr "prove-asdf" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dotenv-test = ( + build-asdf-system { + pname = "dotenv-test"; + version = "20211209-git"; + asds = [ "dotenv-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dotenv/2021-12-09/dotenv-20211209-git.tgz"; + sha256 = "0g19svpxy2169rym532gjwsg1zybinpc99mjsy6im4n6zdd57hzh"; + system = "dotenv-test"; + asd = "dotenv"; + } + ); + systems = [ "dotenv-test" ]; + lispLibs = [ + (getAttr "dotenv" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + doubly-linked-list = ( + build-asdf-system { + pname = "doubly-linked-list"; + version = "20220707-git"; + asds = [ "doubly-linked-list" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/doubly-linked-list/2022-07-07/doubly-linked-list-20220707-git.tgz"; + sha256 = "073r1zyp0slzzvcyj7ibjs85bss1iqh42zn5dvkjd6ls78v2bn9f"; + system = "doubly-linked-list"; + asd = "doubly-linked-list"; + } + ); + systems = [ "doubly-linked-list" ]; + lispLibs = [ (getAttr "mfiano-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + drakma = ( + build-asdf-system { + pname = "drakma"; + version = "v2.0.10"; + asds = [ "drakma" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/drakma/2023-10-21/drakma-v2.0.10.tgz"; + sha256 = "0clj7c1hysisdvkidvx7m0702alsksna6iiqlk499hn3hjpafmln"; + system = "drakma"; + asd = "drakma"; + } + ); + systems = [ "drakma" ]; + lispLibs = [ + (getAttr "chipz" self) + (getAttr "chunga" self) + (getAttr "cl_plus_ssl" self) + (getAttr "cl-base64" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "puri" self) + (getAttr "usocket" self) + ]; + meta = { }; + } + ); + drakma-async = ( + build-asdf-system { + pname = "drakma-async"; + version = "20210807-git"; + asds = [ "drakma-async" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/drakma-async/2021-08-07/drakma-async-20210807-git.tgz"; + sha256 = "19cd4xrcx3mz86sl0326x5lcrh9jizrwzi6p7pd856nrmx7ynf4w"; + system = "drakma-async"; + asd = "drakma-async"; + } + ); + systems = [ "drakma-async" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-async-future" self) + (getAttr "cl-async-ssl" self) + (getAttr "drakma" self) + (getAttr "fast-http" self) + (getAttr "fast-io" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + drakma-test = ( + build-asdf-system { + pname = "drakma-test"; + version = "v2.0.10"; + asds = [ "drakma-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/drakma/2023-10-21/drakma-v2.0.10.tgz"; + sha256 = "0clj7c1hysisdvkidvx7m0702alsksna6iiqlk499hn3hjpafmln"; + system = "drakma-test"; + asd = "drakma-test"; + } + ); + systems = [ "drakma-test" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "easy-routes" self) + (getAttr "fiveam" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + draw-cons-tree = ( + build-asdf-system { + pname = "draw-cons-tree"; + version = "20230618-git"; + asds = [ "draw-cons-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/draw-cons-tree/2023-06-18/draw-cons-tree-20230618-git.tgz"; + sha256 = "1523bdkq8a5qn0qp9q7r16w47y6jb0hkfj7hbjfj6mg3xv001s3x"; + system = "draw-cons-tree"; + asd = "draw-cons-tree"; + } + ); + systems = [ "draw-cons-tree" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dref = ( + build-asdf-system { + pname = "dref"; + version = "20241012-git"; + asds = [ "dref" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mgl-pax/2024-10-12/mgl-pax-20241012-git.tgz"; + sha256 = "17szk2ijccssa9n7zg8qh6hc706hahvzcrzlx716hmgq2hfwvvy0"; + system = "dref"; + asd = "dref"; + } + ); + systems = [ "dref" ]; + lispLibs = [ + (getAttr "mgl-pax-bootstrap" self) + (getAttr "mgl-pax_dot_asdf" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dref-test = ( + build-asdf-system { + pname = "dref-test"; + version = "20241012-git"; + asds = [ "dref-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mgl-pax/2024-10-12/mgl-pax-20241012-git.tgz"; + sha256 = "17szk2ijccssa9n7zg8qh6hc706hahvzcrzlx716hmgq2hfwvvy0"; + system = "dref-test"; + asd = "dref-test"; + } + ); + systems = [ "dref-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "dref" self) + (getAttr "mgl-pax" self) + (getAttr "mgl-pax_dot_asdf" self) + (getAttr "swank" self) + (getAttr "try" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + drei-mcclim = ( + build-asdf-system { + pname = "drei-mcclim"; + version = "20241012-git"; + asds = [ "drei-mcclim" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "drei-mcclim"; + asd = "drei-mcclim"; + } + ); + systems = [ "drei-mcclim" ]; + lispLibs = [ + (getAttr "automaton" self) + (getAttr "clim-core" self) + (getAttr "esa-mcclim" self) + (getAttr "flexichain" self) + (getAttr "persistent" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dso-lex = ( + build-asdf-system { + pname = "dso-lex"; + version = "0.3.2"; + asds = [ "dso-lex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dso-lex/2011-01-10/dso-lex-0.3.2.tgz"; + sha256 = "09vx0dsfaj1c5ivfkx9zl9s2yxmqpdc2v41fhpq75anq9ffr6qyr"; + system = "dso-lex"; + asd = "dso-lex"; + } + ); + systems = [ "dso-lex" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "dso-util" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dso-util = ( + build-asdf-system { + pname = "dso-util"; + version = "0.1.2"; + asds = [ "dso-util" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dso-util/2011-01-10/dso-util-0.1.2.tgz"; + sha256 = "12w1rxxk2hi6k7ng9kqf2yb1kff78bshdfl7bwv6fz8im8vq13b3"; + system = "dso-util"; + asd = "dso-util"; + } + ); + systems = [ "dso-util" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + duckdb = ( + build-asdf-system { + pname = "duckdb"; + version = "20241012-git"; + asds = [ "duckdb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-duckdb/2024-10-12/cl-duckdb-20241012-git.tgz"; + sha256 = "144c8c4m8vwmdg1ny5hjsvxmm8k6jijmrabyf2hmcnvk7hdy5sq0"; + system = "duckdb"; + asd = "duckdb"; + } + ); + systems = [ "duckdb" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + (getAttr "cl-ascii-table" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-spark" self) + (getAttr "float-features" self) + (getAttr "frugal-uuid" self) + (getAttr "let-plus" self) + (getAttr "local-time" self) + (getAttr "local-time-duration" self) + (getAttr "periods" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dufy = ( + build-asdf-system { + pname = "dufy"; + version = "20241012-git"; + asds = [ "dufy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dufy/2024-10-12/dufy-20241012-git.tgz"; + sha256 = "1fj1ad7jh8i72jvdc5ypdk1j1mlkr7dc9xs4khii9adj3jl1nb0v"; + system = "dufy"; + asd = "dufy"; + } + ); + systems = [ "dufy" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dungen = ( + build-asdf-system { + pname = "dungen"; + version = "20220707-git"; + asds = [ "dungen" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dungen/2022-07-07/dungen-20220707-git.tgz"; + sha256 = "1yvkch227g0yawv2682ysdv9q2g5yyyxjvfpx3hijl0mm0awgxv5"; + system = "dungen"; + asd = "dungen"; + } + ); + systems = [ "dungen" ]; + lispLibs = [ + (getAttr "graph" self) + (getAttr "mfiano-utils" self) + (getAttr "seedable-rng" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + duologue = ( + build-asdf-system { + pname = "duologue"; + version = "20230214-git"; + asds = [ "duologue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/duologue/2023-02-14/duologue-20230214-git.tgz"; + sha256 = "1yg7f27im9h0m6jihcay1p7alfhzm9hafwm5dw5hsyacy8f2cwk2"; + system = "duologue"; + asd = "duologue"; + } + ); + systems = [ "duologue" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "chronicity" self) + (getAttr "cl-ansi-text" self) + (getAttr "cl-fad" self) + (getAttr "clavier" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + duologue-readline = ( + build-asdf-system { + pname = "duologue-readline"; + version = "20230214-git"; + asds = [ "duologue-readline" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/duologue/2023-02-14/duologue-20230214-git.tgz"; + sha256 = "1yg7f27im9h0m6jihcay1p7alfhzm9hafwm5dw5hsyacy8f2cwk2"; + system = "duologue-readline"; + asd = "duologue-readline"; + } + ); + systems = [ "duologue-readline" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "chronicity" self) + (getAttr "cl-ansi-text" self) + (getAttr "cl-fad" self) + (getAttr "cl-readline" self) + (getAttr "clavier" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + duologue-test = ( + build-asdf-system { + pname = "duologue-test"; + version = "20230214-git"; + asds = [ "duologue-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/duologue/2023-02-14/duologue-20230214-git.tgz"; + sha256 = "1yg7f27im9h0m6jihcay1p7alfhzm9hafwm5dw5hsyacy8f2cwk2"; + system = "duologue-test"; + asd = "duologue-test"; + } + ); + systems = [ "duologue-test" ]; + lispLibs = [ + (getAttr "duologue" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dweet = ( + build-asdf-system { + pname = "dweet"; + version = "20141217-git"; + asds = [ "dweet" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dweet/2014-12-17/dweet-20141217-git.tgz"; + sha256 = "1i3ab3igvdy6fhq3zlx1vaswhvm9dlp6fagzxbrqhqj6jsbhiwv7"; + system = "dweet"; + asd = "dweet"; + } + ); + systems = [ "dweet" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "com_dot_gigamonkeys_dot_json" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dynamic-array = ( + build-asdf-system { + pname = "dynamic-array"; + version = "20220707-git"; + asds = [ "dynamic-array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dynamic-array/2022-07-07/dynamic-array-20220707-git.tgz"; + sha256 = "02kg1m5xscg521074nasx3f04784jbm0x61a7skixbdprpg6hhnh"; + system = "dynamic-array"; + asd = "dynamic-array"; + } + ); + systems = [ "dynamic-array" ]; + lispLibs = [ (getAttr "mfiano-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dynamic-classes = ( + build-asdf-system { + pname = "dynamic-classes"; + version = "20231021-git"; + asds = [ "dynamic-classes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dynamic-classes/2023-10-21/dynamic-classes-20231021-git.tgz"; + sha256 = "1k9lkchwyi2xhygp2v8ifq3kg1l3wcnihhzgr06jrivjxgdqpc1a"; + system = "dynamic-classes"; + asd = "dynamic-classes"; + } + ); + systems = [ "dynamic-classes" ]; + lispLibs = [ (getAttr "metatilities-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dynamic-classes-test = ( + build-asdf-system { + pname = "dynamic-classes-test"; + version = "20231021-git"; + asds = [ "dynamic-classes-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dynamic-classes/2023-10-21/dynamic-classes-20231021-git.tgz"; + sha256 = "1k9lkchwyi2xhygp2v8ifq3kg1l3wcnihhzgr06jrivjxgdqpc1a"; + system = "dynamic-classes-test"; + asd = "dynamic-classes-test"; + } + ); + systems = [ "dynamic-classes-test" ]; + lispLibs = [ + (getAttr "dynamic-classes" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dynamic-collect = ( + build-asdf-system { + pname = "dynamic-collect"; + version = "20230618-git"; + asds = [ "dynamic-collect" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dynamic-collect/2023-06-18/dynamic-collect-20230618-git.tgz"; + sha256 = "0p1ylba1myby21jg8x9lgwxfv958za32qsz426yd2vc485j887iw"; + system = "dynamic-collect"; + asd = "dynamic-collect"; + } + ); + systems = [ "dynamic-collect" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dynamic-mixins = ( + build-asdf-system { + pname = "dynamic-mixins"; + version = "20181018-git"; + asds = [ "dynamic-mixins" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dynamic-mixins/2018-10-18/dynamic-mixins-20181018-git.tgz"; + sha256 = "00g3s509ysh2jp1qwsgb5bwl6qvhzcljwjz3z4mspbcak51484zj"; + system = "dynamic-mixins"; + asd = "dynamic-mixins"; + } + ); + systems = [ "dynamic-mixins" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dynamic-mixins-swm = ( + build-asdf-system { + pname = "dynamic-mixins-swm"; + version = "20231021-git"; + asds = [ "dynamic-mixins-swm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stumpwm/2023-10-21/stumpwm-20231021-git.tgz"; + sha256 = "114kicsziqvm15x15yhc39j8qzv6gxz4wxc40xp968pprzr4a4d1"; + system = "dynamic-mixins-swm"; + asd = "dynamic-mixins-swm"; + } + ); + systems = [ "dynamic-mixins-swm" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + dynamic-wind = ( + build-asdf-system { + pname = "dynamic-wind"; + version = "20241012-git"; + asds = [ "dynamic-wind" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/contextl/2024-10-12/contextl-20241012-git.tgz"; + sha256 = "1jsa5wyjzzfw9pii3d6x20mh8ijnpb291g3i0y2ccj0x8z3xfyyk"; + system = "dynamic-wind"; + asd = "dynamic-wind"; + } + ); + systems = [ "dynamic-wind" ]; + lispLibs = [ (getAttr "lw-compat" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eager-future = ( + build-asdf-system { + pname = "eager-future"; + version = "20101006-darcs"; + asds = [ "eager-future" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eager-future/2010-10-06/eager-future-20101006-darcs.tgz"; + sha256 = "0l7khqfqfchk7j24fk7rwagwanjargxsrzr6g1h4ainqjajd91jl"; + system = "eager-future"; + asd = "eager-future"; + } + ); + systems = [ "eager-future" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eager-future_dot_test = ( + build-asdf-system { + pname = "eager-future.test"; + version = "20101006-darcs"; + asds = [ "eager-future.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eager-future/2010-10-06/eager-future-20101006-darcs.tgz"; + sha256 = "0l7khqfqfchk7j24fk7rwagwanjargxsrzr6g1h4ainqjajd91jl"; + system = "eager-future.test"; + asd = "eager-future"; + } + ); + systems = [ "eager-future.test" ]; + lispLibs = [ + (getAttr "eager-future" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eager-future2 = ( + build-asdf-system { + pname = "eager-future2"; + version = "20191130-git"; + asds = [ "eager-future2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eager-future2/2019-11-30/eager-future2-20191130-git.tgz"; + sha256 = "1qs1bv3m0ki8l5czhsflxcryh22r9d9g9a3a3b0cr0pl954q5rld"; + system = "eager-future2"; + asd = "eager-future2"; + } + ); + systems = [ "eager-future2" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + easing = ( + build-asdf-system { + pname = "easing"; + version = "20180228-git"; + asds = [ "easing" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/easing/2018-02-28/easing-20180228-git.tgz"; + sha256 = "0750cs5kij8hi53960lzih57xrf92fj23i3hxzhqzcyla4wi4jv5"; + system = "easing"; + asd = "easing"; + } + ); + systems = [ "easing" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + easing-demo = ( + build-asdf-system { + pname = "easing-demo"; + version = "20180228-git"; + asds = [ "easing-demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/easing/2018-02-28/easing-20180228-git.tgz"; + sha256 = "0750cs5kij8hi53960lzih57xrf92fj23i3hxzhqzcyla4wi4jv5"; + system = "easing-demo"; + asd = "easing-demo"; + } + ); + systems = [ "easing-demo" ]; + lispLibs = [ + (getAttr "easing" self) + (getAttr "sketch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + easing-test = ( + build-asdf-system { + pname = "easing-test"; + version = "20180228-git"; + asds = [ "easing-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/easing/2018-02-28/easing-20180228-git.tgz"; + sha256 = "0750cs5kij8hi53960lzih57xrf92fj23i3hxzhqzcyla4wi4jv5"; + system = "easing-test"; + asd = "easing-test"; + } + ); + systems = [ "easing-test" ]; + lispLibs = [ + (getAttr "easing" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + easter-gauss = ( + build-asdf-system { + pname = "easter-gauss"; + version = "20241012-git"; + asds = [ "easter-gauss" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/easter-gauss/2024-10-12/easter-gauss-20241012-git.tgz"; + sha256 = "1wgr7j8b32yq0ajy4a3g08yr7z4p987gfjsrd6gai5i9zqxkbyih"; + system = "easter-gauss"; + asd = "easter-gauss"; + } + ); + systems = [ "easter-gauss" ]; + lispLibs = [ (getAttr "local-time" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + easy-audio = ( + build-asdf-system { + pname = "easy-audio"; + version = "20241012-git"; + asds = [ "easy-audio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/easy-audio/2024-10-12/easy-audio-20241012-git.tgz"; + sha256 = "1vlk2lzipz7sspizv4fiv6nmxhgq9piangc6gfxz6m5k3r74mwrg"; + system = "easy-audio"; + asd = "easy-audio"; + } + ); + systems = [ "easy-audio" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "flexi-streams" self) + (getAttr "nibbles-streams" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + easy-bind = ( + build-asdf-system { + pname = "easy-bind"; + version = "20190202-git"; + asds = [ "easy-bind" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/easy-bind/2019-02-02/easy-bind-20190202-git.tgz"; + sha256 = "0z7mqm7vnk8jcsmawlyhzg81v2bmgdbxmx3jkf2m74170q78jhkl"; + system = "easy-bind"; + asd = "easy-bind"; + } + ); + systems = [ "easy-bind" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + easy-macros = ( + build-asdf-system { + pname = "easy-macros"; + version = "20241012-git"; + asds = [ "easy-macros" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/easy-macros/2024-10-12/easy-macros-20241012-git.tgz"; + sha256 = "12ixfmxbxszhdcv2fnd9q8m573bn6q2nvn656bpwnzvka9si6vrq"; + system = "easy-macros"; + asd = "easy-macros"; + } + ); + systems = [ "easy-macros" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + easy-routes = ( + build-asdf-system { + pname = "easy-routes"; + version = "20241012-git"; + asds = [ "easy-routes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/easy-routes/2024-10-12/easy-routes-20241012-git.tgz"; + sha256 = "0bz91g0vd1nn9b23npmrjw2ig6fahjs3b6iiw7ncajc2w5x9w1y4"; + system = "easy-routes"; + asd = "easy-routes"; + } + ); + systems = [ "easy-routes" ]; + lispLibs = [ + (getAttr "hunchentoot" self) + (getAttr "routes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + easy-routes_plus_djula = ( + build-asdf-system { + pname = "easy-routes+djula"; + version = "20241012-git"; + asds = [ "easy-routes+djula" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/easy-routes/2024-10-12/easy-routes-20241012-git.tgz"; + sha256 = "0bz91g0vd1nn9b23npmrjw2ig6fahjs3b6iiw7ncajc2w5x9w1y4"; + system = "easy-routes+djula"; + asd = "easy-routes+djula"; + } + ); + systems = [ "easy-routes+djula" ]; + lispLibs = [ + (getAttr "djula" self) + (getAttr "easy-routes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + easy-routes_plus_errors = ( + build-asdf-system { + pname = "easy-routes+errors"; + version = "20241012-git"; + asds = [ "easy-routes+errors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/easy-routes/2024-10-12/easy-routes-20241012-git.tgz"; + sha256 = "0bz91g0vd1nn9b23npmrjw2ig6fahjs3b6iiw7ncajc2w5x9w1y4"; + system = "easy-routes+errors"; + asd = "easy-routes+errors"; + } + ); + systems = [ "easy-routes+errors" ]; + lispLibs = [ + (getAttr "easy-routes" self) + (getAttr "hunchentoot-errors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eazy-documentation = ( + build-asdf-system { + pname = "eazy-documentation"; + version = "20210411-git"; + asds = [ "eazy-documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eazy-documentation/2021-04-11/eazy-documentation-20210411-git.tgz"; + sha256 = "0wqd6jih98ab8qpajmcmbj0cwa3g6jjbr7v0wp5gqn1wllwn70ix"; + system = "eazy-documentation"; + asd = "eazy-documentation"; + } + ); + systems = [ "eazy-documentation" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-who" self) + (getAttr "common-doc" self) + (getAttr "common-doc-split-paragraphs" self) + (getAttr "common-html" self) + (getAttr "iterate" self) + (getAttr "trivia" self) + (getAttr "trivia_dot_ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eazy-gnuplot = ( + build-asdf-system { + pname = "eazy-gnuplot"; + version = "20220331-git"; + asds = [ "eazy-gnuplot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eazy-gnuplot/2022-03-31/eazy-gnuplot-20220331-git.tgz"; + sha256 = "0mpkx1z52riahydzvqv7kk15p0pv2k7k5a7j65fg571kcxmssx8s"; + system = "eazy-gnuplot"; + asd = "eazy-gnuplot"; + } + ); + systems = [ "eazy-gnuplot" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eazy-gnuplot_dot_test = ( + build-asdf-system { + pname = "eazy-gnuplot.test"; + version = "20220331-git"; + asds = [ "eazy-gnuplot.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eazy-gnuplot/2022-03-31/eazy-gnuplot-20220331-git.tgz"; + sha256 = "0mpkx1z52riahydzvqv7kk15p0pv2k7k5a7j65fg571kcxmssx8s"; + system = "eazy-gnuplot.test"; + asd = "eazy-gnuplot.test"; + } + ); + systems = [ "eazy-gnuplot.test" ]; + lispLibs = [ + (getAttr "eazy-gnuplot" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eazy-process = ( + build-asdf-system { + pname = "eazy-process"; + version = "20200925-git"; + asds = [ "eazy-process" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eazy-process/2020-09-25/eazy-process-20200925-git.tgz"; + sha256 = "1fvc613jg3b0kra664lbyyzvig7sm1xzaawack28c5m61yiwakiw"; + system = "eazy-process"; + asd = "eazy-process"; + } + ); + systems = [ "eazy-process" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-rlimit" self) + (getAttr "iolib" self) + (getAttr "iterate" self) + (getAttr "trivia" self) + (getAttr "trivia_dot_ppcre" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eazy-process_dot_test = ( + build-asdf-system { + pname = "eazy-process.test"; + version = "20200925-git"; + asds = [ "eazy-process.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eazy-process/2020-09-25/eazy-process-20200925-git.tgz"; + sha256 = "1fvc613jg3b0kra664lbyyzvig7sm1xzaawack28c5m61yiwakiw"; + system = "eazy-process.test"; + asd = "eazy-process.test"; + } + ); + systems = [ "eazy-process.test" ]; + lispLibs = [ + (getAttr "eazy-process" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eazy-project = ( + build-asdf-system { + pname = "eazy-project"; + version = "20190710-git"; + asds = [ "eazy-project" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eazy-project/2019-07-10/eazy-project-20190710-git.tgz"; + sha256 = "1dfzvsvzdwcfvynvik9kwhgil9m08jx8r0vwqj7l1m2d9zm4db3b"; + system = "eazy-project"; + asd = "eazy-project"; + } + ); + systems = [ "eazy-project" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-emb" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-syntax" self) + (getAttr "cl-syntax-annot" self) + (getAttr "introspect-environment" self) + (getAttr "iterate" self) + (getAttr "lisp-namespace" self) + (getAttr "local-time" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eazy-project_dot_autoload = ( + build-asdf-system { + pname = "eazy-project.autoload"; + version = "20190710-git"; + asds = [ "eazy-project.autoload" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eazy-project/2019-07-10/eazy-project-20190710-git.tgz"; + sha256 = "1dfzvsvzdwcfvynvik9kwhgil9m08jx8r0vwqj7l1m2d9zm4db3b"; + system = "eazy-project.autoload"; + asd = "eazy-project.autoload"; + } + ); + systems = [ "eazy-project.autoload" ]; + lispLibs = [ (getAttr "eazy-project" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eazy-project_dot_test = ( + build-asdf-system { + pname = "eazy-project.test"; + version = "20190710-git"; + asds = [ "eazy-project.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eazy-project/2019-07-10/eazy-project-20190710-git.tgz"; + sha256 = "1dfzvsvzdwcfvynvik9kwhgil9m08jx8r0vwqj7l1m2d9zm4db3b"; + system = "eazy-project.test"; + asd = "eazy-project.test"; + } + ); + systems = [ "eazy-project.test" ]; + lispLibs = [ + (getAttr "eazy-project" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ec2 = ( + build-asdf-system { + pname = "ec2"; + version = "20120909-git"; + asds = [ "ec2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ec2/2012-09-09/ec2-20120909-git.tgz"; + sha256 = "1z9yv1b8ckyvla80rha7amfhhy57kylkscf504rpfx8994fnfbsy"; + system = "ec2"; + asd = "ec2"; + } + ); + systems = [ "ec2" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "ironclad" self) + (getAttr "s-base64" self) + (getAttr "s-xml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ec2-price-finder = ( + build-asdf-system { + pname = "ec2-price-finder"; + version = "20210531-git"; + asds = [ "ec2-price-finder" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ec2-price-finder/2021-05-31/ec2-price-finder-20210531-git.tgz"; + sha256 = "1511py79fj0xpzzjlfk6fchp6lmikvhy42s3p6s85fbq4dyj4mpj"; + system = "ec2-price-finder"; + asd = "ec2-price-finder"; + } + ); + systems = [ "ec2-price-finder" ]; + lispLibs = [ + (getAttr "easy-routes" self) + (getAttr "hunchentoot" self) + (getAttr "lass" self) + (getAttr "local-time" self) + (getAttr "parse-float" self) + (getAttr "read-csv" self) + (getAttr "spinneret" self) + (getAttr "wu-decimal" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ecclesia = ( + build-asdf-system { + pname = "ecclesia"; + version = "20231021-git"; + asds = [ "ecclesia" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ecclesia/2023-10-21/ecclesia-20231021-git.tgz"; + sha256 = "0hamxgkqq833m02wjnghnjq9ny9k8xk3qx1wffm809qsm9ivwah8"; + system = "ecclesia"; + asd = "ecclesia"; + } + ); + systems = [ "ecclesia" ]; + lispLibs = [ (getAttr "acclimation" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eclecticse_dot_iso-8601-date = ( + build-asdf-system { + pname = "eclecticse.iso-8601-date"; + version = "20190107-git"; + asds = [ "eclecticse.iso-8601-date" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/iso-8601-date/2019-01-07/iso-8601-date-20190107-git.tgz"; + sha256 = "12d6jyznglm13sb04xh5l0d0bwi4y449wdyifvfy7r03qy8wypdx"; + system = "eclecticse.iso-8601-date"; + asd = "eclecticse.iso-8601-date"; + } + ); + systems = [ "eclecticse.iso-8601-date" ]; + lispLibs = [ (getAttr "local-time" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eclecticse_dot_omer = ( + build-asdf-system { + pname = "eclecticse.omer"; + version = "20210411-git"; + asds = [ "eclecticse.omer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/omer-count/2021-04-11/omer-count-20210411-git.tgz"; + sha256 = "1rvg7rfalvi28x3jkknfdyf4y7zjrqdx073iqi2gin4amin6n7jv"; + system = "eclecticse.omer"; + asd = "eclecticse.omer"; + } + ); + systems = [ "eclecticse.omer" ]; + lispLibs = [ (getAttr "local-time" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eclecticse_dot_slk-581 = ( + build-asdf-system { + pname = "eclecticse.slk-581"; + version = "20190107-git"; + asds = [ "eclecticse.slk-581" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/slk-581/2019-01-07/slk-581-20190107-git.tgz"; + sha256 = "1pxyr1gi4ppnfld399wiypqqkgm3bqd9kpizpwgll2fd10yh2qmf"; + system = "eclecticse.slk-581"; + asd = "eclecticse.slk-581"; + } + ); + systems = [ "eclecticse.slk-581" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eclector = ( + build-asdf-system { + pname = "eclector"; + version = "20241012-git"; + asds = [ "eclector" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eclector/2024-10-12/eclector-20241012-git.tgz"; + sha256 = "06qhll5k0hq652gdzvvhcv4amqg9z7qillnn3z9cm8z9sv1n912v"; + system = "eclector"; + asd = "eclector"; + } + ); + systems = [ "eclector" ]; + lispLibs = [ + (getAttr "acclimation" self) + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eclector-concrete-syntax-tree = ( + build-asdf-system { + pname = "eclector-concrete-syntax-tree"; + version = "20241012-git"; + asds = [ "eclector-concrete-syntax-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eclector/2024-10-12/eclector-20241012-git.tgz"; + sha256 = "06qhll5k0hq652gdzvvhcv4amqg9z7qillnn3z9cm8z9sv1n912v"; + system = "eclector-concrete-syntax-tree"; + asd = "eclector-concrete-syntax-tree"; + } + ); + systems = [ "eclector-concrete-syntax-tree" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "concrete-syntax-tree" self) + (getAttr "eclector" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eclector_dot_syntax-extensions = ( + build-asdf-system { + pname = "eclector.syntax-extensions"; + version = "20241012-git"; + asds = [ "eclector.syntax-extensions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eclector/2024-10-12/eclector-20241012-git.tgz"; + sha256 = "06qhll5k0hq652gdzvvhcv4amqg9z7qillnn3z9cm8z9sv1n912v"; + system = "eclector.syntax-extensions"; + asd = "eclector.syntax-extensions"; + } + ); + systems = [ "eclector.syntax-extensions" ]; + lispLibs = [ (getAttr "eclector" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eco = ( + build-asdf-system { + pname = "eco"; + version = "20190813-git"; + asds = [ "eco" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eco/2019-08-13/eco-20190813-git.tgz"; + sha256 = "13fsv9v7fhf05p7j1hrfy2sg813wmgsp9aw4ng4cpzdss24zvf7q"; + system = "eco"; + asd = "eco"; + } + ); + systems = [ "eco" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-who" self) + (getAttr "esrap" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eco-test = ( + build-asdf-system { + pname = "eco-test"; + version = "20190813-git"; + asds = [ "eco-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eco/2019-08-13/eco-20190813-git.tgz"; + sha256 = "13fsv9v7fhf05p7j1hrfy2sg813wmgsp9aw4ng4cpzdss24zvf7q"; + system = "eco-test"; + asd = "eco-test"; + } + ); + systems = [ "eco-test" ]; + lispLibs = [ + (getAttr "eco" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + edit-distance = ( + build-asdf-system { + pname = "edit-distance"; + version = "20220331-git"; + asds = [ "edit-distance" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-editdistance/2022-03-31/cl-editdistance-20220331-git.tgz"; + sha256 = "0nzbgq69wak18vwpk0fp68x8shdxq5vy70213dc2r0hwfzzc10v9"; + system = "edit-distance"; + asd = "edit-distance"; + } + ); + systems = [ "edit-distance" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + edit-distance-test = ( + build-asdf-system { + pname = "edit-distance-test"; + version = "20220331-git"; + asds = [ "edit-distance-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-editdistance/2022-03-31/cl-editdistance-20220331-git.tgz"; + sha256 = "0nzbgq69wak18vwpk0fp68x8shdxq5vy70213dc2r0hwfzzc10v9"; + system = "edit-distance-test"; + asd = "edit-distance-test"; + } + ); + systems = [ "edit-distance-test" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-coveralls" self) + (getAttr "edit-distance" self) + (getAttr "lisp-unit" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + elb-log = ( + build-asdf-system { + pname = "elb-log"; + version = "20150923-git"; + asds = [ "elb-log" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/elb-log/2015-09-23/elb-log-20150923-git.tgz"; + sha256 = "1d0vkmkjr6d96j7cggw5frj50jf14brbm63is41zwfkfl9r4i6bp"; + system = "elb-log"; + asd = "elb-log"; + } + ); + systems = [ "elb-log" ]; + lispLibs = [ + (getAttr "cl-annot-prove" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-syntax" self) + (getAttr "cl-syntax-annot" self) + (getAttr "cl-syntax-interpol" self) + (getAttr "local-time" self) + (getAttr "zs3" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + elb-log-test = ( + build-asdf-system { + pname = "elb-log-test"; + version = "20150923-git"; + asds = [ "elb-log-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/elb-log/2015-09-23/elb-log-20150923-git.tgz"; + sha256 = "1d0vkmkjr6d96j7cggw5frj50jf14brbm63is41zwfkfl9r4i6bp"; + system = "elb-log-test"; + asd = "elb-log-test"; + } + ); + systems = [ "elb-log-test" ]; + lispLibs = [ + (getAttr "elb-log" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + electron-tools = ( + build-asdf-system { + pname = "electron-tools"; + version = "20160421-git"; + asds = [ "electron-tools" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/electron-tools/2016-04-21/electron-tools-20160421-git.tgz"; + sha256 = "0fr16gsbn87vyyjpn2gndhpjg7yzsn4j7skyn0py252cvdk5ygf7"; + system = "electron-tools"; + asd = "electron-tools"; + } + ); + systems = [ "electron-tools" ]; + lispLibs = [ + (getAttr "osicat" self) + (getAttr "trivial-download" self) + (getAttr "trivial-exe" self) + (getAttr "trivial-extract" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + electron-tools-test = ( + build-asdf-system { + pname = "electron-tools-test"; + version = "20160421-git"; + asds = [ "electron-tools-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/electron-tools/2016-04-21/electron-tools-20160421-git.tgz"; + sha256 = "0fr16gsbn87vyyjpn2gndhpjg7yzsn4j7skyn0py252cvdk5ygf7"; + system = "electron-tools-test"; + asd = "electron-tools-test"; + } + ); + systems = [ "electron-tools-test" ]; + lispLibs = [ + (getAttr "electron-tools" self) + (getAttr "fiveam" self) + (getAttr "trivial-extract" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + elf = ( + build-asdf-system { + pname = "elf"; + version = "20190710-git"; + asds = [ "elf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/elf/2019-07-10/elf-20190710-git.tgz"; + sha256 = "0rd1qcczr2gx76fmxia0kix0p5b49myc9fndibkvwc94cxg085gk"; + system = "elf"; + asd = "elf"; + } + ); + systems = [ "elf" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "com_dot_gigamonkeys_dot_binary-data" self) + (getAttr "flexi-streams" self) + (getAttr "metabang-bind" self) + (getAttr "split-sequence" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enchant = ( + build-asdf-system { + pname = "enchant"; + version = "20241012-git"; + asds = [ "enchant" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-enchant/2024-10-12/cl-enchant-20241012-git.tgz"; + sha256 = "1fcxyb9b8g0v2il2q4xj7z19y1qfxvgd34zax8sdjvl4rp66b08v"; + system = "enchant"; + asd = "enchant"; + } + ); + systems = [ "enchant" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { }; + } + ); + enhanced-boolean = ( + build-asdf-system { + pname = "enhanced-boolean"; + version = "1.0"; + asds = [ "enhanced-boolean" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-boolean/2020-03-25/enhanced-boolean_1.0.tgz"; + sha256 = "17l18lz07fk2kg835vs6c3189d230n1rm9vghk3ls4i356gbq0gy"; + system = "enhanced-boolean"; + asd = "enhanced-boolean"; + } + ); + systems = [ "enhanced-boolean" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-boolean__tests = ( + build-asdf-system { + pname = "enhanced-boolean_tests"; + version = "1.0"; + asds = [ "enhanced-boolean_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-boolean/2020-03-25/enhanced-boolean_1.0.tgz"; + sha256 = "17l18lz07fk2kg835vs6c3189d230n1rm9vghk3ls4i356gbq0gy"; + system = "enhanced-boolean_tests"; + asd = "enhanced-boolean_tests"; + } + ); + systems = [ "enhanced-boolean_tests" ]; + lispLibs = [ + (getAttr "enhanced-boolean" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-defclass = ( + build-asdf-system { + pname = "enhanced-defclass"; + version = "2.1"; + asds = [ "enhanced-defclass" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-defclass/2021-04-11/enhanced-defclass_2.1.tgz"; + sha256 = "142s5c3pl3x7xdawzsj8pdxiqp4wh6fcajf4la5msvnxgf66d8wg"; + system = "enhanced-defclass"; + asd = "enhanced-defclass"; + } + ); + systems = [ "enhanced-defclass" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "compatible-metaclasses" self) + (getAttr "enhanced-eval-when" self) + (getAttr "enhanced-find-class" self) + (getAttr "evaled-when" self) + (getAttr "shared-preferences" self) + (getAttr "simple-guess" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-defclass__tests = ( + build-asdf-system { + pname = "enhanced-defclass_tests"; + version = "2.1"; + asds = [ "enhanced-defclass_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-defclass/2021-04-11/enhanced-defclass_2.1.tgz"; + sha256 = "142s5c3pl3x7xdawzsj8pdxiqp4wh6fcajf4la5msvnxgf66d8wg"; + system = "enhanced-defclass_tests"; + asd = "enhanced-defclass_tests"; + } + ); + systems = [ "enhanced-defclass_tests" ]; + lispLibs = [ + (getAttr "enhanced-defclass" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-eval-when = ( + build-asdf-system { + pname = "enhanced-eval-when"; + version = "2.0"; + asds = [ "enhanced-eval-when" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-eval-when/2023-10-21/enhanced-eval-when_2.0.tgz"; + sha256 = "1l7n04pzcwsxvw6m4pcksmlx525ijbgh5n28h56clpvpwlwnzjs3"; + system = "enhanced-eval-when"; + asd = "enhanced-eval-when"; + } + ); + systems = [ "enhanced-eval-when" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-eval-when__tests = ( + build-asdf-system { + pname = "enhanced-eval-when_tests"; + version = "2.0"; + asds = [ "enhanced-eval-when_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-eval-when/2023-10-21/enhanced-eval-when_2.0.tgz"; + sha256 = "1l7n04pzcwsxvw6m4pcksmlx525ijbgh5n28h56clpvpwlwnzjs3"; + system = "enhanced-eval-when_tests"; + asd = "enhanced-eval-when_tests"; + } + ); + systems = [ "enhanced-eval-when_tests" ]; + lispLibs = [ + (getAttr "enhanced-eval-when" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-find-class = ( + build-asdf-system { + pname = "enhanced-find-class"; + version = "1.0"; + asds = [ "enhanced-find-class" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-find-class/2020-09-25/enhanced-find-class_1.0.tgz"; + sha256 = "1pf1mxb238zrmvgm9s0456s1x0m317ls23ls1d987riw69y3w9vx"; + system = "enhanced-find-class"; + asd = "enhanced-find-class"; + } + ); + systems = [ "enhanced-find-class" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-find-class__tests = ( + build-asdf-system { + pname = "enhanced-find-class_tests"; + version = "1.0"; + asds = [ "enhanced-find-class_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-find-class/2020-09-25/enhanced-find-class_1.0.tgz"; + sha256 = "1pf1mxb238zrmvgm9s0456s1x0m317ls23ls1d987riw69y3w9vx"; + system = "enhanced-find-class_tests"; + asd = "enhanced-find-class_tests"; + } + ); + systems = [ "enhanced-find-class_tests" ]; + lispLibs = [ + (getAttr "enhanced-find-class" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-multiple-value-bind = ( + build-asdf-system { + pname = "enhanced-multiple-value-bind"; + version = "2.0"; + asds = [ "enhanced-multiple-value-bind" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-multiple-value-bind/2023-10-21/enhanced-multiple-value-bind_2.0.tgz"; + sha256 = "191h0rd3fs5vqc15kvblvvwmvcqddmvj3s8x6xfp78gm69wk9bdq"; + system = "enhanced-multiple-value-bind"; + asd = "enhanced-multiple-value-bind"; + } + ); + systems = [ "enhanced-multiple-value-bind" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-multiple-value-bind__tests = ( + build-asdf-system { + pname = "enhanced-multiple-value-bind_tests"; + version = "2.0"; + asds = [ "enhanced-multiple-value-bind_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-multiple-value-bind/2023-10-21/enhanced-multiple-value-bind_2.0.tgz"; + sha256 = "191h0rd3fs5vqc15kvblvvwmvcqddmvj3s8x6xfp78gm69wk9bdq"; + system = "enhanced-multiple-value-bind_tests"; + asd = "enhanced-multiple-value-bind_tests"; + } + ); + systems = [ "enhanced-multiple-value-bind_tests" ]; + lispLibs = [ + (getAttr "enhanced-eval-when" self) + (getAttr "enhanced-multiple-value-bind" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-typep = ( + build-asdf-system { + pname = "enhanced-typep"; + version = "1.0"; + asds = [ "enhanced-typep" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-typep/2020-10-16/enhanced-typep_1.0.tgz"; + sha256 = "0b22gddkbxnhmi71wa2h51495737lrvsqxnri7g1qdsl1hraml21"; + system = "enhanced-typep"; + asd = "enhanced-typep"; + } + ); + systems = [ "enhanced-typep" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-typep__tests = ( + build-asdf-system { + pname = "enhanced-typep_tests"; + version = "1.0"; + asds = [ "enhanced-typep_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-typep/2020-10-16/enhanced-typep_1.0.tgz"; + sha256 = "0b22gddkbxnhmi71wa2h51495737lrvsqxnri7g1qdsl1hraml21"; + system = "enhanced-typep_tests"; + asd = "enhanced-typep_tests"; + } + ); + systems = [ "enhanced-typep_tests" ]; + lispLibs = [ + (getAttr "enhanced-boolean" self) + (getAttr "enhanced-typep" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-unwind-protect = ( + build-asdf-system { + pname = "enhanced-unwind-protect"; + version = "1.0"; + asds = [ "enhanced-unwind-protect" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-unwind-protect/2023-10-21/enhanced-unwind-protect_1.0.tgz"; + sha256 = "00yak6ga0rsz58r96clmzvqbcmnfxcdxvn3h3ysirrsfr8rayy5m"; + system = "enhanced-unwind-protect"; + asd = "enhanced-unwind-protect"; + } + ); + systems = [ "enhanced-unwind-protect" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enhanced-unwind-protect__tests = ( + build-asdf-system { + pname = "enhanced-unwind-protect_tests"; + version = "1.0"; + asds = [ "enhanced-unwind-protect_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/enhanced-unwind-protect/2023-10-21/enhanced-unwind-protect_1.0.tgz"; + sha256 = "00yak6ga0rsz58r96clmzvqbcmnfxcdxvn3h3ysirrsfr8rayy5m"; + system = "enhanced-unwind-protect_tests"; + asd = "enhanced-unwind-protect_tests"; + } + ); + systems = [ "enhanced-unwind-protect_tests" ]; + lispLibs = [ + (getAttr "enhanced-unwind-protect" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + enumerations = ( + build-asdf-system { + pname = "enumerations"; + version = "20230214-git"; + asds = [ "enumerations" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-enumeration/2023-02-14/cl-enumeration-20230214-git.tgz"; + sha256 = "08jp5sf1230d4yyr7jyjqv235hdjjbmabh8r5lsqjh4kgqbwrvqr"; + system = "enumerations"; + asd = "enumerations"; + } + ); + systems = [ "enumerations" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + envy = ( + build-asdf-system { + pname = "envy"; + version = "20220331-git"; + asds = [ "envy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/envy/2022-03-31/envy-20220331-git.tgz"; + sha256 = "1r0wgimd7z57x8cv69sw76w3y5l70hq50882a9nq5l4v64lg55fq"; + system = "envy"; + asd = "envy"; + } + ); + systems = [ "envy" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + envy-test = ( + build-asdf-system { + pname = "envy-test"; + version = "20220331-git"; + asds = [ "envy-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/envy/2022-03-31/envy-20220331-git.tgz"; + sha256 = "1r0wgimd7z57x8cv69sw76w3y5l70hq50882a9nq5l4v64lg55fq"; + system = "envy-test"; + asd = "envy-test"; + } + ); + systems = [ "envy-test" ]; + lispLibs = [ + (getAttr "envy" self) + (getAttr "osicat" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eos = ( + build-asdf-system { + pname = "eos"; + version = "20200925-git"; + asds = [ "eos" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eos/2020-09-25/eos-20200925-git.tgz"; + sha256 = "1afllvmlnx97yzz404gycl3pa3kwx427k3hrbf37rpmjlv47knhk"; + system = "eos"; + asd = "eos"; + } + ); + systems = [ "eos" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eos-tests = ( + build-asdf-system { + pname = "eos-tests"; + version = "20200925-git"; + asds = [ "eos-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eos/2020-09-25/eos-20200925-git.tgz"; + sha256 = "1afllvmlnx97yzz404gycl3pa3kwx427k3hrbf37rpmjlv47knhk"; + system = "eos-tests"; + asd = "eos"; + } + ); + systems = [ "eos-tests" ]; + lispLibs = [ (getAttr "eos" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + epigraph = ( + build-asdf-system { + pname = "epigraph"; + version = "20200325-git"; + asds = [ "epigraph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/epigraph/2020-03-25/epigraph-20200325-git.tgz"; + sha256 = "0gqiv23grdiz6pfly7mqyfmq4c6nwcamlvgsnixn8qi9md7b9d64"; + system = "epigraph"; + asd = "epigraph"; + } + ); + systems = [ "epigraph" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + epigraph-test = ( + build-asdf-system { + pname = "epigraph-test"; + version = "20200325-git"; + asds = [ "epigraph-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/epigraph/2020-03-25/epigraph-20200325-git.tgz"; + sha256 = "0gqiv23grdiz6pfly7mqyfmq4c6nwcamlvgsnixn8qi9md7b9d64"; + system = "epigraph-test"; + asd = "epigraph"; + } + ); + systems = [ "epigraph-test" ]; + lispLibs = [ + (getAttr "epigraph" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + epmd = ( + build-asdf-system { + pname = "epmd"; + version = "20140211-git"; + asds = [ "epmd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-epmd/2014-02-11/cl-epmd-20140211-git.tgz"; + sha256 = "1334856x7jqhv52wlab6wxmfqslj21pmryx3lwmlsn7c3ypwz4rw"; + system = "epmd"; + asd = "epmd"; + } + ); + systems = [ "epmd" ]; + lispLibs = [ + (getAttr "com_dot_gigamonkeys_dot_binary-data" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + epmd-test = ( + build-asdf-system { + pname = "epmd-test"; + version = "20140211-git"; + asds = [ "epmd-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-epmd/2014-02-11/cl-epmd-20140211-git.tgz"; + sha256 = "1334856x7jqhv52wlab6wxmfqslj21pmryx3lwmlsn7c3ypwz4rw"; + system = "epmd-test"; + asd = "epmd-test"; + } + ); + systems = [ "epmd-test" ]; + lispLibs = [ + (getAttr "epmd" self) + (getAttr "fiveam" self) + (getAttr "flexi-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + equals = ( + build-asdf-system { + pname = "equals"; + version = "20241012-git"; + asds = [ "equals" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/equals/2024-10-12/equals-20241012-git.tgz"; + sha256 = "1pzhj748dgjcw6qffkykxx156y78wy3bsbqmq5ijkybfjpnfsg27"; + system = "equals"; + asd = "equals"; + } + ); + systems = [ "equals" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + erjoalgo-webutil = ( + build-asdf-system { + pname = "erjoalgo-webutil"; + version = "20241012-git"; + asds = [ "erjoalgo-webutil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/erjoalgo-webutil/2024-10-12/erjoalgo-webutil-20241012-git.tgz"; + sha256 = "1mf9f23p6pagdi97k306a6122a5djx06nfwsxnx61gbyir2cpl2c"; + system = "erjoalgo-webutil"; + asd = "erjoalgo-webutil"; + } + ); + systems = [ "erjoalgo-webutil" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "fiasco" self) + (getAttr "gzip-stream" self) + (getAttr "hunchentoot" self) + (getAttr "vom" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + erlang-term = ( + build-asdf-system { + pname = "erlang-term"; + version = "20220220-git"; + asds = [ "erlang-term" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-erlang-term/2022-02-20/cl-erlang-term-20220220-git.tgz"; + sha256 = "1rmnbirbvwmik3j0xkkn90kzx90klrwx7hmscl0ywcbaprm71wkv"; + system = "erlang-term"; + asd = "erlang-term"; + } + ); + systems = [ "erlang-term" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "ieee-floats" self) + (getAttr "nibbles" self) + (getAttr "zlib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + erlang-term-test = ( + build-asdf-system { + pname = "erlang-term-test"; + version = "20220220-git"; + asds = [ "erlang-term-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-erlang-term/2022-02-20/cl-erlang-term-20220220-git.tgz"; + sha256 = "1rmnbirbvwmik3j0xkkn90kzx90klrwx7hmscl0ywcbaprm71wkv"; + system = "erlang-term-test"; + asd = "erlang-term-test"; + } + ); + systems = [ "erlang-term-test" ]; + lispLibs = [ + (getAttr "erlang-term" self) + (getAttr "fiveam" self) + (getAttr "nibbles" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ernestine = ( + build-asdf-system { + pname = "ernestine"; + version = "20220220-git"; + asds = [ "ernestine" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ernestine/2022-02-20/ernestine-20220220-git.tgz"; + sha256 = "1gl8pjp44j01nfw9dzk1qdl6njnqcaccp5czcr5rq47l1aicrymn"; + system = "ernestine"; + asd = "ernestine"; + } + ); + systems = [ "ernestine" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cl-prevalence" self) + (getAttr "drakma" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ernestine-tests = ( + build-asdf-system { + pname = "ernestine-tests"; + version = "20220220-git"; + asds = [ "ernestine-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ernestine/2022-02-20/ernestine-20220220-git.tgz"; + sha256 = "1gl8pjp44j01nfw9dzk1qdl6njnqcaccp5czcr5rq47l1aicrymn"; + system = "ernestine-tests"; + asd = "ernestine-tests"; + } + ); + systems = [ "ernestine-tests" ]; + lispLibs = [ + (getAttr "ernestine" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + erudite = ( + build-asdf-system { + pname = "erudite"; + version = "20241012-git"; + asds = [ "erudite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/erudite/2024-10-12/erudite-20241012-git.tgz"; + sha256 = "159fmpm770rnixdpzpmzvqzd2kpns5mglpdxykvv2lqlnac24jn5"; + system = "erudite"; + asd = "erudite"; + } + ); + systems = [ "erudite" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-template" self) + (getAttr "log4cl" self) + (getAttr "split-sequence" self) + (getAttr "swank-client" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + erudite-test = ( + build-asdf-system { + pname = "erudite-test"; + version = "20241012-git"; + asds = [ "erudite-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/erudite/2024-10-12/erudite-20241012-git.tgz"; + sha256 = "159fmpm770rnixdpzpmzvqzd2kpns5mglpdxykvv2lqlnac24jn5"; + system = "erudite-test"; + asd = "erudite-test"; + } + ); + systems = [ "erudite-test" ]; + lispLibs = [ + (getAttr "erudite" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + esa-mcclim = ( + build-asdf-system { + pname = "esa-mcclim"; + version = "20241012-git"; + asds = [ "esa-mcclim" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "esa-mcclim"; + asd = "esa-mcclim"; + } + ); + systems = [ "esa-mcclim" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "clim-core" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + escalator = ( + build-asdf-system { + pname = "escalator"; + version = "20200427-git"; + asds = [ "escalator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/escalator/2020-04-27/escalator-20200427-git.tgz"; + sha256 = "136n4k983f90cqj6na17ff2fvk9rv4ma8l5y66q7lkbb69idipla"; + system = "escalator"; + asd = "escalator"; + } + ); + systems = [ "escalator" ]; + lispLibs = [ (getAttr "iterate" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + escalator-bench = ( + build-asdf-system { + pname = "escalator-bench"; + version = "20200427-git"; + asds = [ "escalator-bench" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/escalator/2020-04-27/escalator-20200427-git.tgz"; + sha256 = "136n4k983f90cqj6na17ff2fvk9rv4ma8l5y66q7lkbb69idipla"; + system = "escalator-bench"; + asd = "escalator-bench"; + } + ); + systems = [ "escalator-bench" ]; + lispLibs = [ + (getAttr "escalator" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + esrap = ( + build-asdf-system { + pname = "esrap"; + version = "20241012-git"; + asds = [ "esrap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/esrap/2024-10-12/esrap-20241012-git.tgz"; + sha256 = "0pvid1hld03vz2zyszvsxckcpjb2lfl2vjfig6dlrmw3dx8grdj0"; + system = "esrap"; + asd = "esrap"; + } + ); + systems = [ "esrap" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-with-current-source-form" self) + ]; + meta = { }; + } + ); + esrap-liquid = ( + build-asdf-system { + pname = "esrap-liquid"; + version = "20161031-git"; + asds = [ "esrap-liquid" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/esrap-liquid/2016-10-31/esrap-liquid-20161031-git.tgz"; + sha256 = "0agsi8qx6v3c7r6ri5rp78vdb570pdgkvw80va3045crl61mkjzs"; + system = "esrap-liquid"; + asd = "esrap-liquid"; + } + ); + systems = [ "esrap-liquid" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + esrap-liquid-tests = ( + build-asdf-system { + pname = "esrap-liquid-tests"; + version = "20161031-git"; + asds = [ "esrap-liquid-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/esrap-liquid/2016-10-31/esrap-liquid-20161031-git.tgz"; + sha256 = "0agsi8qx6v3c7r6ri5rp78vdb570pdgkvw80va3045crl61mkjzs"; + system = "esrap-liquid-tests"; + asd = "esrap-liquid"; + } + ); + systems = [ "esrap-liquid-tests" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "esrap-liquid" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + esrap-peg = ( + build-asdf-system { + pname = "esrap-peg"; + version = "20191007-git"; + asds = [ "esrap-peg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/esrap-peg/2019-10-07/esrap-peg-20191007-git.tgz"; + sha256 = "0540i7whx1w0n9fdakwk8rnn511xga9xfvczq9y1jcgz1hh42w53"; + system = "esrap-peg"; + asd = "esrap-peg"; + } + ); + systems = [ "esrap-peg" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-unification" self) + (getAttr "esrap" self) + (getAttr "iterate" self) + ]; + meta = { }; + } + ); + etcd-test = ( + build-asdf-system { + pname = "etcd-test"; + version = "20230214-git"; + asds = [ "etcd-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-etcd/2023-02-14/cl-etcd-20230214-git.tgz"; + sha256 = "0bals10r07prxvjxd744vz02ri72isf168lkhrx9qkc96hd214ah"; + system = "etcd-test"; + asd = "etcd-test"; + } + ); + systems = [ "etcd-test" ]; + lispLibs = [ + (getAttr "cl-etcd" self) + (getAttr "cl-toml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ev = ( + build-asdf-system { + pname = "ev"; + version = "20150923-git"; + asds = [ "ev" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ev/2015-09-23/cl-ev-20150923-git.tgz"; + sha256 = "0qnkzkw9mn4w6b0q9y207z8ddnd5a2gn42q55yycp2qrvvv47lhp"; + system = "ev"; + asd = "ev"; + } + ); + systems = [ "ev" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + evaled-when = ( + build-asdf-system { + pname = "evaled-when"; + version = "1.0"; + asds = [ "evaled-when" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/evaled-when/2020-09-25/evaled-when_1.0.tgz"; + sha256 = "0482s89nb5jyyg5wmb010p914pgq6ls8z5s12hdw7wrpy675kdkh"; + system = "evaled-when"; + asd = "evaled-when"; + } + ); + systems = [ "evaled-when" ]; + lispLibs = [ (getAttr "trivial-cltl2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + evaled-when__tests = ( + build-asdf-system { + pname = "evaled-when_tests"; + version = "1.0"; + asds = [ "evaled-when_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/evaled-when/2020-09-25/evaled-when_1.0.tgz"; + sha256 = "0482s89nb5jyyg5wmb010p914pgq6ls8z5s12hdw7wrpy675kdkh"; + system = "evaled-when_tests"; + asd = "evaled-when_tests"; + } + ); + systems = [ "evaled-when_tests" ]; + lispLibs = [ + (getAttr "enhanced-boolean" self) + (getAttr "evaled-when" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + event-emitter = ( + build-asdf-system { + pname = "event-emitter"; + version = "20241012-git"; + asds = [ "event-emitter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/event-emitter/2024-10-12/event-emitter-20241012-git.tgz"; + sha256 = "0kj77r09wbsiq6n62vvgk9fh37p3n3ycmhln1mhswz24rhirnpyn"; + system = "event-emitter"; + asd = "event-emitter"; + } + ); + systems = [ "event-emitter" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + event-emitter-benchmark = ( + build-asdf-system { + pname = "event-emitter-benchmark"; + version = "20241012-git"; + asds = [ "event-emitter-benchmark" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/event-emitter/2024-10-12/event-emitter-20241012-git.tgz"; + sha256 = "0kj77r09wbsiq6n62vvgk9fh37p3n3ycmhln1mhswz24rhirnpyn"; + system = "event-emitter-benchmark"; + asd = "event-emitter-benchmark"; + } + ); + systems = [ "event-emitter-benchmark" ]; + lispLibs = [ (getAttr "event-emitter" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + event-emitter-test = ( + build-asdf-system { + pname = "event-emitter-test"; + version = "20241012-git"; + asds = [ "event-emitter-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/event-emitter/2024-10-12/event-emitter-20241012-git.tgz"; + sha256 = "0kj77r09wbsiq6n62vvgk9fh37p3n3ycmhln1mhswz24rhirnpyn"; + system = "event-emitter-test"; + asd = "event-emitter-test"; + } + ); + systems = [ "event-emitter-test" ]; + lispLibs = [ + (getAttr "event-emitter" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + event-glue = ( + build-asdf-system { + pname = "event-glue"; + version = "20150608-git"; + asds = [ "event-glue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/event-glue/2015-06-08/event-glue-20150608-git.tgz"; + sha256 = "1cmxdx5nawzqafz9b6nswp20d3zlaks44ln4n6bf5jxji9n3vany"; + system = "event-glue"; + asd = "event-glue"; + } + ); + systems = [ "event-glue" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + event-glue-test = ( + build-asdf-system { + pname = "event-glue-test"; + version = "20150608-git"; + asds = [ "event-glue-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/event-glue/2015-06-08/event-glue-20150608-git.tgz"; + sha256 = "1cmxdx5nawzqafz9b6nswp20d3zlaks44ln4n6bf5jxji9n3vany"; + system = "event-glue-test"; + asd = "event-glue-test"; + } + ); + systems = [ "event-glue-test" ]; + lispLibs = [ + (getAttr "event-glue" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eventbus = ( + build-asdf-system { + pname = "eventbus"; + version = "20191227-git"; + asds = [ "eventbus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eventbus/2019-12-27/eventbus-20191227-git.tgz"; + sha256 = "0slqx3zq6sbz3rg4g79j8y25sx4405y6ff3x6l5v8v4v42m1s0p2"; + system = "eventbus"; + asd = "eventbus"; + } + ); + systems = [ "eventbus" ]; + lispLibs = [ (getAttr "simplet-asdf" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + eventfd = ( + build-asdf-system { + pname = "eventfd"; + version = "20171130-git"; + asds = [ "eventfd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eventfd/2017-11-30/eventfd-20171130-git.tgz"; + sha256 = "1zwg043vqzk665k9dxgxhik20wgkl204anjna94zg6037m33vdiw"; + system = "eventfd"; + asd = "eventfd"; + } + ); + systems = [ "eventfd" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi-grovel" self) + (getAttr "iolib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + everblocking-stream = ( + build-asdf-system { + pname = "everblocking-stream"; + version = "20181018-git"; + asds = [ "everblocking-stream" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/everblocking-stream/2018-10-18/everblocking-stream-20181018-git.tgz"; + sha256 = "1xvfsx2ldwcprlynikn1rikxh3lfdyzl2p72glzvgh20sm93p1rz"; + system = "everblocking-stream"; + asd = "everblocking-stream"; + } + ); + systems = [ "everblocking-stream" ]; + lispLibs = [ (getAttr "trivial-gray-streams" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + evol = ( + build-asdf-system { + pname = "evol"; + version = "20101006-git"; + asds = [ "evol" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/evol/2010-10-06/evol-20101006-git.tgz"; + sha256 = "1hp6wygj44llkscqq721xg4a7j5faqjcfc646lvkia5xg81zbf65"; + system = "evol"; + asd = "evol"; + } + ); + systems = [ "evol" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "external-program" self) + (getAttr "patron" self) + (getAttr "unix-options" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + evol-test = ( + build-asdf-system { + pname = "evol-test"; + version = "20101006-git"; + asds = [ "evol-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/evol/2010-10-06/evol-20101006-git.tgz"; + sha256 = "1hp6wygj44llkscqq721xg4a7j5faqjcfc646lvkia5xg81zbf65"; + system = "evol-test"; + asd = "evol-test"; + } + ); + systems = [ "evol-test" ]; + lispLibs = [ + (getAttr "evol" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + example-bot = ( + build-asdf-system { + pname = "example-bot"; + version = "20241012-git"; + asds = [ "example-bot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispcord/2024-10-12/lispcord-20241012-git.tgz"; + sha256 = "11xwrrvvqdm1wdnxrxqgizgw25plsn28n2k0lm5kakax9n221brn"; + system = "example-bot"; + asd = "example-bot"; + } + ); + systems = [ "example-bot" ]; + lispLibs = [ (getAttr "lispcord" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + exit-hooks = ( + build-asdf-system { + pname = "exit-hooks"; + version = "20170403-git"; + asds = [ "exit-hooks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/exit-hooks/2017-04-03/exit-hooks-20170403-git.tgz"; + sha256 = "00rk0pr2cy3hy6giblh166b7yrg06d5lanipjcqv508gkfb0vi47"; + system = "exit-hooks"; + asd = "exit-hooks"; + } + ); + systems = [ "exit-hooks" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + exponential-backoff = ( + build-asdf-system { + pname = "exponential-backoff"; + version = "20150113-git"; + asds = [ "exponential-backoff" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/exponential-backoff/2015-01-13/exponential-backoff-20150113-git.tgz"; + sha256 = "1389hm9hxv85s0125ja4js1bvh8ay4dsy9q1gaynjv27ynik6gmv"; + system = "exponential-backoff"; + asd = "exponential-backoff"; + } + ); + systems = [ "exponential-backoff" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + exscribe = ( + build-asdf-system { + pname = "exscribe"; + version = "20200925-git"; + asds = [ "exscribe" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/exscribe/2020-09-25/exscribe-20200925-git.tgz"; + sha256 = "02vsavasr5nbhrk86b7d8xpr6sm8cyrg3vs2pbpkls2iypffyd2h"; + system = "exscribe"; + asd = "exscribe"; + } + ); + systems = [ "exscribe" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "fare-memoization" self) + (getAttr "fare-scripts" self) + (getAttr "fare-utils" self) + (getAttr "quri" self) + (getAttr "scribble" self) + (getAttr "trivia_dot_quasiquote" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ext-blog = ( + build-asdf-system { + pname = "ext-blog"; + version = "20160825-git"; + asds = [ "ext-blog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ext-blog/2016-08-25/ext-blog-20160825-git.tgz"; + sha256 = "10qnl3p994wg12c0cn6xgkgmwfip0fk0sjyqyy0j5bdrp32gr5wg"; + system = "ext-blog"; + asd = "ext-blog"; + } + ); + systems = [ "ext-blog" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cl-store" self) + (getAttr "closure-template" self) + (getAttr "image" self) + (getAttr "kl-verify" self) + (getAttr "local-time" self) + (getAttr "restas" self) + (getAttr "restas_dot_file-publisher" self) + (getAttr "s-xml-rpc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + extended-reals = ( + build-asdf-system { + pname = "extended-reals"; + version = "20180328-git"; + asds = [ "extended-reals" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/extended-reals/2018-03-28/extended-reals-20180328-git.tgz"; + sha256 = "0vq191win5sq37mrwjhvi463jqh1mkwbsa0hja69syq789pgaxmb"; + system = "extended-reals"; + asd = "extended-reals"; + } + ); + systems = [ "extended-reals" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + extensible-sequences = ( + build-asdf-system { + pname = "extensible-sequences"; + version = "20130813-darcs"; + asds = [ "extensible-sequences" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sequence-iterators/2013-08-13/sequence-iterators-20130813-darcs.tgz"; + sha256 = "12flvy6hysqw0fa2jfkxrgphlk6b25hg2w2dxm1ylax0gw9fh1l5"; + system = "extensible-sequences"; + asd = "extensible-sequences"; + } + ); + systems = [ "extensible-sequences" ]; + lispLibs = [ (getAttr "sequence-iterators" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + external-program = ( + build-asdf-system { + pname = "external-program"; + version = "20241012-git"; + asds = [ "external-program" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/external-program/2024-10-12/external-program-20241012-git.tgz"; + sha256 = "1g7hawsbbfspzljj2spxxv26a5079xsa0kd7dqdclm5n71fypwx6"; + system = "external-program"; + asd = "external-program"; + } + ); + systems = [ "external-program" ]; + lispLibs = [ (getAttr "trivial-features" self) ]; + meta = { }; + } + ); + external-program-test = ( + build-asdf-system { + pname = "external-program-test"; + version = "20241012-git"; + asds = [ "external-program-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/external-program/2024-10-12/external-program-20241012-git.tgz"; + sha256 = "1g7hawsbbfspzljj2spxxv26a5079xsa0kd7dqdclm5n71fypwx6"; + system = "external-program-test"; + asd = "external-program"; + } + ); + systems = [ "external-program-test" ]; + lispLibs = [ + (getAttr "external-program" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + external-symbol-not-found = ( + build-asdf-system { + pname = "external-symbol-not-found"; + version = "20241012-git"; + asds = [ "external-symbol-not-found" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/external-symbol-not-found/2024-10-12/external-symbol-not-found-20241012-git.tgz"; + sha256 = "1ic982jbcy71wlni60wnb8hqg3cqw488h4jj5pd2sqmjwv1960v7"; + system = "external-symbol-not-found"; + asd = "external-symbol-not-found"; + } + ); + systems = [ "external-symbol-not-found" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + f-underscore = ( + build-asdf-system { + pname = "f-underscore"; + version = "20101006-darcs"; + asds = [ "f-underscore" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f-underscore/2010-10-06/f-underscore-20101006-darcs.tgz"; + sha256 = "0mqvb2rxa08y07lj6smp8gf1ig32802fxq7mw5a283f2nkrinnb5"; + system = "f-underscore"; + asd = "f-underscore"; + } + ); + systems = [ "f-underscore" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + f2cl = ( + build-asdf-system { + pname = "f2cl"; + version = "20231021-git"; + asds = [ "f2cl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "f2cl"; + asd = "f2cl"; + } + ); + systems = [ "f2cl" ]; + lispLibs = [ (getAttr "f2cl-asdf" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + f2cl-asdf = ( + build-asdf-system { + pname = "f2cl-asdf"; + version = "20231021-git"; + asds = [ "f2cl-asdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "f2cl-asdf"; + asd = "f2cl-asdf"; + } + ); + systems = [ "f2cl-asdf" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + f2cl-lib = ( + build-asdf-system { + pname = "f2cl-lib"; + version = "20220220-git"; + asds = [ "f2cl-lib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "f2cl-lib"; + asd = "f2cl-lib"; + } + ); + systems = [ "f2cl-lib" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fact-base = ( + build-asdf-system { + pname = "fact-base"; + version = "20180328-git"; + asds = [ "fact-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fact-base/2018-03-28/fact-base-20180328-git.tgz"; + sha256 = "14i0vqqxszabhas0z9dfxhvnbsxl4iic77m4i76w7iznmrcma2ar"; + system = "fact-base"; + asd = "fact-base"; + } + ); + systems = [ "fact-base" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "local-time" self) + (getAttr "optima" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + factory-alien = ( + build-asdf-system { + pname = "factory-alien"; + version = "20230618-git"; + asds = [ "factory-alien" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/factory-alien/2023-06-18/factory-alien-20230618-git.tgz"; + sha256 = "0n1fwxapl9vr0cm66gkhihws6zhvg2f4acx017lavn0g42b5fc4a"; + system = "factory-alien"; + asd = "factory-alien"; + } + ); + systems = [ "factory-alien" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fakenil = ( + build-asdf-system { + pname = "fakenil"; + version = "1.0"; + asds = [ "fakenil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fakenil/2020-03-25/fakenil_1.0.tgz"; + sha256 = "0ipqax3sgcs1dsgxz8d2pmfg324k6l35pn0nz89w5jl02fia61l3"; + system = "fakenil"; + asd = "fakenil"; + } + ); + systems = [ "fakenil" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fakenil__tests = ( + build-asdf-system { + pname = "fakenil_tests"; + version = "1.0"; + asds = [ "fakenil_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fakenil/2020-03-25/fakenil_1.0.tgz"; + sha256 = "0ipqax3sgcs1dsgxz8d2pmfg324k6l35pn0nz89w5jl02fia61l3"; + system = "fakenil_tests"; + asd = "fakenil_tests"; + } + ); + systems = [ "fakenil_tests" ]; + lispLibs = [ + (getAttr "fakenil" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fare-csv = ( + build-asdf-system { + pname = "fare-csv"; + version = "20241012-git"; + asds = [ "fare-csv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fare-csv/2024-10-12/fare-csv-20241012-git.tgz"; + sha256 = "153sxb0vyd1cnhfw15j3183kqhcnma0ygaf5svzibknclm16n767"; + system = "fare-csv"; + asd = "fare-csv"; + } + ); + systems = [ "fare-csv" ]; + lispLibs = [ ]; + meta = { }; + } + ); + fare-memoization = ( + build-asdf-system { + pname = "fare-memoization"; + version = "20180430-git"; + asds = [ "fare-memoization" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fare-memoization/2018-04-30/fare-memoization-20180430-git.tgz"; + sha256 = "1blmrb4c9gsxj87scz74z1s8w9d1w2r48fyxj0y1sw3vr6bsbb8f"; + system = "fare-memoization"; + asd = "fare-memoization"; + } + ); + systems = [ "fare-memoization" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fare-mop = ( + build-asdf-system { + pname = "fare-mop"; + version = "20151218-git"; + asds = [ "fare-mop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fare-mop/2015-12-18/fare-mop-20151218-git.tgz"; + sha256 = "0maxs8392953fhnaa6zwnm2mdbhxjxipp4g4rvypm06ixr6pyv1c"; + system = "fare-mop"; + asd = "fare-mop"; + } + ); + systems = [ "fare-mop" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "fare-utils" self) + ]; + meta = { }; + } + ); + fare-quasiquote = ( + build-asdf-system { + pname = "fare-quasiquote"; + version = "20200925-git"; + asds = [ "fare-quasiquote" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fare-quasiquote/2020-09-25/fare-quasiquote-20200925-git.tgz"; + sha256 = "034mw3x0jv6q5nxqq8sz77c44dc115x6y52bnzk31qclib88zl7n"; + system = "fare-quasiquote"; + asd = "fare-quasiquote"; + } + ); + systems = [ "fare-quasiquote" ]; + lispLibs = [ (getAttr "fare-utils" self) ]; + meta = { }; + } + ); + fare-quasiquote-extras = ( + build-asdf-system { + pname = "fare-quasiquote-extras"; + version = "20200925-git"; + asds = [ "fare-quasiquote-extras" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fare-quasiquote/2020-09-25/fare-quasiquote-20200925-git.tgz"; + sha256 = "034mw3x0jv6q5nxqq8sz77c44dc115x6y52bnzk31qclib88zl7n"; + system = "fare-quasiquote-extras"; + asd = "fare-quasiquote-extras"; + } + ); + systems = [ "fare-quasiquote-extras" ]; + lispLibs = [ + (getAttr "fare-quasiquote-optima" self) + (getAttr "fare-quasiquote-readtable" self) + ]; + meta = { }; + } + ); + fare-quasiquote-optima = ( + build-asdf-system { + pname = "fare-quasiquote-optima"; + version = "20200925-git"; + asds = [ "fare-quasiquote-optima" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fare-quasiquote/2020-09-25/fare-quasiquote-20200925-git.tgz"; + sha256 = "034mw3x0jv6q5nxqq8sz77c44dc115x6y52bnzk31qclib88zl7n"; + system = "fare-quasiquote-optima"; + asd = "fare-quasiquote-optima"; + } + ); + systems = [ "fare-quasiquote-optima" ]; + lispLibs = [ (getAttr "trivia_dot_quasiquote" self) ]; + meta = { }; + } + ); + fare-quasiquote-readtable = ( + build-asdf-system { + pname = "fare-quasiquote-readtable"; + version = "20200925-git"; + asds = [ "fare-quasiquote-readtable" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fare-quasiquote/2020-09-25/fare-quasiquote-20200925-git.tgz"; + sha256 = "034mw3x0jv6q5nxqq8sz77c44dc115x6y52bnzk31qclib88zl7n"; + system = "fare-quasiquote-readtable"; + asd = "fare-quasiquote-readtable"; + } + ); + systems = [ "fare-quasiquote-readtable" ]; + lispLibs = [ + (getAttr "fare-quasiquote" self) + (getAttr "named-readtables" self) + ]; + meta = { }; + } + ); + fare-scripts = ( + build-asdf-system { + pname = "fare-scripts"; + version = "20241012-git"; + asds = [ "fare-scripts" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fare-scripts/2024-10-12/fare-scripts-20241012-git.tgz"; + sha256 = "08fq1ry4prlww4gr7zris7vywqs3vm1253mqfgx8vg0awrccmf98"; + system = "fare-scripts"; + asd = "fare-scripts"; + } + ); + systems = [ "fare-scripts" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "binascii" self) + (getAttr "cl-launch" self) + (getAttr "cl-mime" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-scripting" self) + (getAttr "cl-unicode" self) + (getAttr "command-line-arguments" self) + (getAttr "fare-utils" self) + (getAttr "inferior-shell" self) + (getAttr "optima" self) + (getAttr "optima_dot_ppcre" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fare-utils = ( + build-asdf-system { + pname = "fare-utils"; + version = "20230214-git"; + asds = [ "fare-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fare-utils/2023-02-14/fare-utils-20230214-git.tgz"; + sha256 = "0kw6xzavzvpzac3xa6x4681q6w6v6bjk1g71flr2x9xixxg61sak"; + system = "fare-utils"; + asd = "fare-utils"; + } + ); + systems = [ "fare-utils" ]; + lispLibs = [ ]; + meta = { }; + } + ); + fare-utils-test = ( + build-asdf-system { + pname = "fare-utils-test"; + version = "20230214-git"; + asds = [ "fare-utils-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fare-utils/2023-02-14/fare-utils-20230214-git.tgz"; + sha256 = "0kw6xzavzvpzac3xa6x4681q6w6v6bjk1g71flr2x9xixxg61sak"; + system = "fare-utils-test"; + asd = "fare-utils-test"; + } + ); + systems = [ "fare-utils-test" ]; + lispLibs = [ + (getAttr "fare-utils" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fast-http = ( + build-asdf-system { + pname = "fast-http"; + version = "20241012-git"; + asds = [ "fast-http" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fast-http/2024-10-12/fast-http-20241012-git.tgz"; + sha256 = "04cxh2241l9hyzarrxs528v2jjdfm5g3prc2374m4xkrb0wiygh0"; + system = "fast-http"; + asd = "fast-http"; + } + ); + systems = [ "fast-http" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-utilities" self) + (getAttr "proc-parse" self) + (getAttr "smart-buffer" self) + (getAttr "xsubseq" self) + ]; + meta = { }; + } + ); + fast-http-test = ( + build-asdf-system { + pname = "fast-http-test"; + version = "20241012-git"; + asds = [ "fast-http-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fast-http/2024-10-12/fast-http-20241012-git.tgz"; + sha256 = "04cxh2241l9hyzarrxs528v2jjdfm5g3prc2374m4xkrb0wiygh0"; + system = "fast-http-test"; + asd = "fast-http-test"; + } + ); + systems = [ "fast-http-test" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-syntax-interpol" self) + (getAttr "fast-http" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "xsubseq" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fast-io = ( + build-asdf-system { + pname = "fast-io"; + version = "20221106-git"; + asds = [ "fast-io" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fast-io/2022-11-06/fast-io-20221106-git.tgz"; + sha256 = "0wh02yagbqahy9z6787jz5ggpagvr18qd0z13wvwq1vjf8xd2530"; + system = "fast-io"; + asd = "fast-io"; + } + ); + systems = [ "fast-io" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "static-vectors" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + fast-io-test = ( + build-asdf-system { + pname = "fast-io-test"; + version = "20221106-git"; + asds = [ "fast-io-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fast-io/2022-11-06/fast-io-20221106-git.tgz"; + sha256 = "0wh02yagbqahy9z6787jz5ggpagvr18qd0z13wvwq1vjf8xd2530"; + system = "fast-io-test"; + asd = "fast-io-test"; + } + ); + systems = [ "fast-io-test" ]; + lispLibs = [ + (getAttr "checkl" self) + (getAttr "fast-io" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fast-mpsc-queue = ( + build-asdf-system { + pname = "fast-mpsc-queue"; + version = "20241012-git"; + asds = [ "fast-mpsc-queue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fast-mpsc-queue/2024-10-12/fast-mpsc-queue-20241012-git.tgz"; + sha256 = "1ggiaryjv3lmzrk6m22y7vvbqn3z0n7ahmkyfjq6iyrd64d77ck7"; + system = "fast-mpsc-queue"; + asd = "fast-mpsc-queue"; + } + ); + systems = [ "fast-mpsc-queue" ]; + lispLibs = [ (getAttr "metabang-bind" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fast-websocket = ( + build-asdf-system { + pname = "fast-websocket"; + version = "20241012-git"; + asds = [ "fast-websocket" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fast-websocket/2024-10-12/fast-websocket-20241012-git.tgz"; + sha256 = "102z58d27966lpx08kc6apgaainbsdfhygb67ibyw6lxnaasy3jz"; + system = "fast-websocket"; + asd = "fast-websocket"; + } + ); + systems = [ "fast-websocket" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "fast-io" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fast-websocket-test = ( + build-asdf-system { + pname = "fast-websocket-test"; + version = "20241012-git"; + asds = [ "fast-websocket-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fast-websocket/2024-10-12/fast-websocket-20241012-git.tgz"; + sha256 = "102z58d27966lpx08kc6apgaainbsdfhygb67ibyw6lxnaasy3jz"; + system = "fast-websocket-test"; + asd = "fast-websocket-test"; + } + ); + systems = [ "fast-websocket-test" ]; + lispLibs = [ + (getAttr "fast-io" self) + (getAttr "fast-websocket" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + feeder = ( + build-asdf-system { + pname = "feeder"; + version = "20231021-git"; + asds = [ "feeder" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/feeder/2023-10-21/feeder-20231021-git.tgz"; + sha256 = "00j3s98lbh6h2p007s7x48rw0ckd3c1apfwb28y89jxnwqk7sng7"; + system = "feeder"; + asd = "feeder"; + } + ); + systems = [ "feeder" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "local-time" self) + (getAttr "plump" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + femlisp = ( + build-asdf-system { + pname = "femlisp"; + version = "20210411-git"; + asds = [ "femlisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; + sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; + system = "femlisp"; + asd = "femlisp"; + } + ); + systems = [ "femlisp" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "femlisp-basic" self) + (getAttr "femlisp-dictionary" self) + (getAttr "femlisp-matlisp" self) + (getAttr "femlisp-parallel" self) + (getAttr "flexi-streams" self) + (getAttr "infix" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + femlisp-basic = ( + build-asdf-system { + pname = "femlisp-basic"; + version = "20210411-git"; + asds = [ "femlisp-basic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; + sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; + system = "femlisp-basic"; + asd = "femlisp-basic"; + } + ); + systems = [ "femlisp-basic" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + femlisp-dictionary = ( + build-asdf-system { + pname = "femlisp-dictionary"; + version = "20210411-git"; + asds = [ "femlisp-dictionary" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; + sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; + system = "femlisp-dictionary"; + asd = "femlisp-dictionary"; + } + ); + systems = [ "femlisp-dictionary" ]; + lispLibs = [ + (getAttr "femlisp-basic" self) + (getAttr "femlisp-parallel" self) + (getAttr "trees" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + femlisp-matlisp = ( + build-asdf-system { + pname = "femlisp-matlisp"; + version = "20210411-git"; + asds = [ "femlisp-matlisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; + sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; + system = "femlisp-matlisp"; + asd = "femlisp-matlisp"; + } + ); + systems = [ "femlisp-matlisp" ]; + lispLibs = [ + (getAttr "femlisp-basic" self) + (getAttr "femlisp-dictionary" self) + (getAttr "femlisp-parallel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + femlisp-parallel = ( + build-asdf-system { + pname = "femlisp-parallel"; + version = "20210411-git"; + asds = [ "femlisp-parallel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; + sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; + system = "femlisp-parallel"; + asd = "femlisp-parallel"; + } + ); + systems = [ "femlisp-parallel" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-cpu-affinity" self) + (getAttr "cl-ppcre" self) + (getAttr "femlisp-basic" self) + (getAttr "lparallel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + femlisp-picture = ( + build-asdf-system { + pname = "femlisp-picture"; + version = "20210411-git"; + asds = [ "femlisp-picture" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; + sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; + system = "femlisp-picture"; + asd = "femlisp-picture"; + } + ); + systems = [ "femlisp-picture" ]; + lispLibs = [ + (getAttr "cl-gd" self) + (getAttr "femlisp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ffa = ( + build-asdf-system { + pname = "ffa"; + version = "20101006-git"; + asds = [ "ffa" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ffa/2010-10-06/ffa-20101006-git.tgz"; + sha256 = "0l7kqcjp3sn1129hpwq6zhjqc0ydx9gc53z7k13i38x3z1asap7a"; + system = "ffa"; + asd = "ffa"; + } + ); + systems = [ "ffa" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-utilities" self) + (getAttr "iterate" self) + (getAttr "metabang-bind" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fft = ( + build-asdf-system { + pname = "fft"; + version = "20180711-git"; + asds = [ "fft" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fft/2018-07-11/fft-20180711-git.tgz"; + sha256 = "0ymnfplap2cncw49mhq7crapgxphfwsvqdgrcckpgsvw6qsymasd"; + system = "fft"; + asd = "fft"; + } + ); + systems = [ "fft" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fftpack5 = ( + build-asdf-system { + pname = "fftpack5"; + version = "20231021-git"; + asds = [ "fftpack5" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "fftpack5"; + asd = "fftpack5"; + } + ); + systems = [ "fftpack5" ]; + lispLibs = [ (getAttr "f2cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fftpack5-double = ( + build-asdf-system { + pname = "fftpack5-double"; + version = "20231021-git"; + asds = [ "fftpack5-double" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "fftpack5-double"; + asd = "fftpack5-double"; + } + ); + systems = [ "fftpack5-double" ]; + lispLibs = [ (getAttr "f2cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fiasco = ( + build-asdf-system { + pname = "fiasco"; + version = "20200610-git"; + asds = [ "fiasco" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fiasco/2020-06-10/fiasco-20200610-git.tgz"; + sha256 = "1k8i2kq57201bvy3zfpsxld530hd104dgbglxigqb6i408c1a7aw"; + system = "fiasco"; + asd = "fiasco"; + } + ); + systems = [ "fiasco" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + fiasco-self-tests = ( + build-asdf-system { + pname = "fiasco-self-tests"; + version = "20200610-git"; + asds = [ "fiasco-self-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fiasco/2020-06-10/fiasco-20200610-git.tgz"; + sha256 = "1k8i2kq57201bvy3zfpsxld530hd104dgbglxigqb6i408c1a7aw"; + system = "fiasco-self-tests"; + asd = "fiasco"; + } + ); + systems = [ "fiasco-self-tests" ]; + lispLibs = [ (getAttr "fiasco" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + file-attributes = ( + build-asdf-system { + pname = "file-attributes"; + version = "20241012-git"; + asds = [ "file-attributes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/file-attributes/2024-10-12/file-attributes-20241012-git.tgz"; + sha256 = "14jimsmwcp8bygm2f0fjmjv0ncc5yxl7pvh04x0kw6gs1mc7rc9x"; + system = "file-attributes"; + asd = "file-attributes"; + } + ); + systems = [ "file-attributes" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { }; + } + ); + file-finder = ( + build-asdf-system { + pname = "file-finder"; + version = "20241012-git"; + asds = [ "file-finder" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/file-finder/2024-10-12/file-finder-20241012-git.tgz"; + sha256 = "11cjyyngvydcq2sbgsqkxd9060a0cb3ndqrqr318djndf30ckmqx"; + system = "file-finder"; + asd = "file-finder"; + } + ); + systems = [ "file-finder" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "file-attributes" self) + (getAttr "local-time" self) + (getAttr "named-readtables" self) + (getAttr "serapeum" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + file-local-variable = ( + build-asdf-system { + pname = "file-local-variable"; + version = "20160318-git"; + asds = [ "file-local-variable" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/file-local-variable/2016-03-18/file-local-variable-20160318-git.tgz"; + sha256 = "1jsjd0g41mg76wlqjxliyrfz8fk7ihi06nq2zizmk9np0pmwsxl9"; + system = "file-local-variable"; + asd = "file-local-variable"; + } + ); + systems = [ "file-local-variable" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + file-local-variable_dot_test = ( + build-asdf-system { + pname = "file-local-variable.test"; + version = "20160318-git"; + asds = [ "file-local-variable.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/file-local-variable/2016-03-18/file-local-variable-20160318-git.tgz"; + sha256 = "1jsjd0g41mg76wlqjxliyrfz8fk7ihi06nq2zizmk9np0pmwsxl9"; + system = "file-local-variable.test"; + asd = "file-local-variable.test"; + } + ); + systems = [ "file-local-variable.test" ]; + lispLibs = [ + (getAttr "file-local-variable" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + file-lock = ( + build-asdf-system { + pname = "file-lock"; + version = "20231021-git"; + asds = [ "file-lock" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/file-lock/2023-10-21/file-lock-20231021-git.tgz"; + sha256 = "0n2mn931h83dh2diifsghc78agsz4savlfv5dr9pfmpk16vkwi5b"; + system = "file-lock"; + asd = "file-lock"; + } + ); + systems = [ "file-lock" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "easy-macros" self) + (getAttr "log4cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + file-notify = ( + build-asdf-system { + pname = "file-notify"; + version = "20241012-git"; + asds = [ "file-notify" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/file-notify/2024-10-12/file-notify-20241012-git.tgz"; + sha256 = "1zxn0smgahbxvy8v2bwmff3262msqhqqc5qpmh4ffinx6azln1hq"; + system = "file-notify"; + asd = "file-notify"; + } + ); + systems = [ "file-notify" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + file-select = ( + build-asdf-system { + pname = "file-select"; + version = "20241012-git"; + asds = [ "file-select" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/file-select/2024-10-12/file-select-20241012-git.tgz"; + sha256 = "0vp7qfqymlw21yrlfack799xjwyh23dyxnbc5ix4fnylpi1lxjbn"; + system = "file-select"; + asd = "file-select"; + } + ); + systems = [ "file-select" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "float-features" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + file-types = ( + build-asdf-system { + pname = "file-types"; + version = "20160929-git"; + asds = [ "file-types" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/file-types/2016-09-29/file-types-20160929-git.tgz"; + sha256 = "09l67gzjwx7kx237grm709dsj9rkmmm8s3ya6irmcw8nh587inbs"; + system = "file-types"; + asd = "file-types"; + } + ); + systems = [ "file-types" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + filesystem-utils = ( + build-asdf-system { + pname = "filesystem-utils"; + version = "20241012-git"; + asds = [ "filesystem-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/filesystem-utils/2024-10-12/filesystem-utils-20241012-git.tgz"; + sha256 = "0h1xqpc11iachb9yg1d2xrzp1df1qadr1call904cjf45xadn62r"; + system = "filesystem-utils"; + asd = "filesystem-utils"; + } + ); + systems = [ "filesystem-utils" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "pathname-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + filesystem-utils-test = ( + build-asdf-system { + pname = "filesystem-utils-test"; + version = "20241012-git"; + asds = [ "filesystem-utils-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/filesystem-utils/2024-10-12/filesystem-utils-20241012-git.tgz"; + sha256 = "0h1xqpc11iachb9yg1d2xrzp1df1qadr1call904cjf45xadn62r"; + system = "filesystem-utils-test"; + asd = "filesystem-utils-test"; + } + ); + systems = [ "filesystem-utils-test" ]; + lispLibs = [ + (getAttr "filesystem-utils" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + filter-maker = ( + build-asdf-system { + pname = "filter-maker"; + version = "20221106-git"; + asds = [ "filter-maker" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/filter-maker/2022-11-06/filter-maker-20221106-git.tgz"; + sha256 = "00algyghniqsvjy5vwx39fd98nd7x4w944ahy981jlh33lzc2qmn"; + system = "filter-maker"; + asd = "filter-maker"; + } + ); + systems = [ "filter-maker" ]; + lispLibs = [ (getAttr "mcclim" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + filtered-functions = ( + build-asdf-system { + pname = "filtered-functions"; + version = "20160318-git"; + asds = [ "filtered-functions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/filtered-functions/2016-03-18/filtered-functions-20160318-git.tgz"; + sha256 = "0m13k8pl0gfll8ss83c0z3gax7zrrw2i4s26451jfbka1xr4fgy9"; + system = "filtered-functions"; + asd = "filtered-functions"; + } + ); + systems = [ "filtered-functions" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + find-port = ( + build-asdf-system { + pname = "find-port"; + version = "20230214-git"; + asds = [ "find-port" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/find-port/2023-02-14/find-port-20230214-git.tgz"; + sha256 = "1hmbkqazk6m7075gmbrwzxkysp9779xm9qxrzj7p85bwlbk5m5i7"; + system = "find-port"; + asd = "find-port"; + } + ); + systems = [ "find-port" ]; + lispLibs = [ (getAttr "usocket" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + find-port-test = ( + build-asdf-system { + pname = "find-port-test"; + version = "20230214-git"; + asds = [ "find-port-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/find-port/2023-02-14/find-port-20230214-git.tgz"; + sha256 = "1hmbkqazk6m7075gmbrwzxkysp9779xm9qxrzj7p85bwlbk5m5i7"; + system = "find-port-test"; + asd = "find-port-test"; + } + ); + systems = [ "find-port-test" ]; + lispLibs = [ + (getAttr "find-port" self) + (getAttr "fiveam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + finite-state-machine = ( + build-asdf-system { + pname = "finite-state-machine"; + version = "20200218-git"; + asds = [ "finite-state-machine" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-simple-fsm/2020-02-18/cl-simple-fsm-20200218-git.tgz"; + sha256 = "1w07df7kakjq3r1v5c4gnavp08ngpn2ni85cggnnsqzc27hly07b"; + system = "finite-state-machine"; + asd = "finite-state-machine"; + } + ); + systems = [ "finite-state-machine" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + firephp = ( + build-asdf-system { + pname = "firephp"; + version = "20160531-git"; + asds = [ "firephp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/firephp/2016-05-31/firephp-20160531-git.tgz"; + sha256 = "1j98z73c21xcjp4f8qvmv37y9zlsnwxx88nnxc3r1ngvxv23dlgh"; + system = "firephp"; + asd = "firephp"; + } + ); + systems = [ "firephp" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + firephp-tests = ( + build-asdf-system { + pname = "firephp-tests"; + version = "20160531-git"; + asds = [ "firephp-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/firephp/2016-05-31/firephp-20160531-git.tgz"; + sha256 = "1j98z73c21xcjp4f8qvmv37y9zlsnwxx88nnxc3r1ngvxv23dlgh"; + system = "firephp-tests"; + asd = "firephp-tests"; + } + ); + systems = [ "firephp-tests" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "firephp" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + first-time-value = ( + build-asdf-system { + pname = "first-time-value"; + version = "1.0.1"; + asds = [ "first-time-value" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/first-time-value/2018-12-10/first-time-value-1.0.1.tgz"; + sha256 = "155mqhnw1307b18a8bv8jhqp20qv83b409mlr61m45nq3sivxxp2"; + system = "first-time-value"; + asd = "first-time-value"; + } + ); + systems = [ "first-time-value" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + first-time-value__tests = ( + build-asdf-system { + pname = "first-time-value_tests"; + version = "1.0.1"; + asds = [ "first-time-value_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/first-time-value/2018-12-10/first-time-value-1.0.1.tgz"; + sha256 = "155mqhnw1307b18a8bv8jhqp20qv83b409mlr61m45nq3sivxxp2"; + system = "first-time-value_tests"; + asd = "first-time-value_tests"; + } + ); + systems = [ "first-time-value_tests" ]; + lispLibs = [ + (getAttr "first-time-value" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fishpack = ( + build-asdf-system { + pname = "fishpack"; + version = "20231021-git"; + asds = [ "fishpack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "fishpack"; + asd = "fishpack"; + } + ); + systems = [ "fishpack" ]; + lispLibs = [ (getAttr "f2cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fiveam = ( + build-asdf-system { + pname = "fiveam"; + version = "20241012-git"; + asds = [ "fiveam" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fiveam/2024-10-12/fiveam-20241012-git.tgz"; + sha256 = "066amfjqhagzhb602y911wbw7jh9cv1fb7bfn2ppjzm5kf7hqbnh"; + system = "fiveam"; + asd = "fiveam"; + } + ); + systems = [ "fiveam" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "net_dot_didierverna_dot_asdf-flv" self) + (getAttr "trivial-backtrace" self) + ]; + meta = { }; + } + ); + fiveam-asdf = ( + build-asdf-system { + pname = "fiveam-asdf"; + version = "20221106-git"; + asds = [ "fiveam-asdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fiveam-asdf/2022-11-06/fiveam-asdf-20221106-git.tgz"; + sha256 = "18dhyznwl56lpp289dwg9xm9qwwv5062yawfaj6h1b2jwybqfrq7"; + system = "fiveam-asdf"; + asd = "fiveam-asdf"; + } + ); + systems = [ "fiveam-asdf" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fiveam-matchers = ( + build-asdf-system { + pname = "fiveam-matchers"; + version = "20241012-git"; + asds = [ "fiveam-matchers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fiveam-matchers/2024-10-12/fiveam-matchers-20241012-git.tgz"; + sha256 = "1kwichcxjmqdi8whx4daggp4fdp53w17jj1rqlph9ixgr4s9kvqv"; + system = "fiveam-matchers"; + asd = "fiveam-matchers"; + } + ); + systems = [ "fiveam-matchers" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "fiveam" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fixed = ( + build-asdf-system { + pname = "fixed"; + version = "20170124-git"; + asds = [ "fixed" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fixed/2017-01-24/fixed-20170124-git.tgz"; + sha256 = "0bx8802fmlml5k5xhcm4g5r6c7ambij4gb0b37xljjn3wxgs83dc"; + system = "fixed"; + asd = "fixed"; + } + ); + systems = [ "fixed" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + flac = ( + build-asdf-system { + pname = "flac"; + version = "20151218-git"; + asds = [ "flac" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; + sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; + system = "flac"; + asd = "flac"; + } + ); + systems = [ "flac" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + flare = ( + build-asdf-system { + pname = "flare"; + version = "20231021-git"; + asds = [ "flare" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/flare/2023-10-21/flare-20231021-git.tgz"; + sha256 = "1ws357819rr9lzh5b2hmqid6vrq8zj46a5dzwqa0fdmxxbam75zm"; + system = "flare"; + asd = "flare"; + } + ); + systems = [ "flare" ]; + lispLibs = [ + (getAttr "_3d-vectors" self) + (getAttr "array-utils" self) + (getAttr "documentation-utils" self) + (getAttr "for" self) + (getAttr "lambda-fiddle" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + flare-viewer = ( + build-asdf-system { + pname = "flare-viewer"; + version = "20231021-git"; + asds = [ "flare-viewer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/flare/2023-10-21/flare-20231021-git.tgz"; + sha256 = "1ws357819rr9lzh5b2hmqid6vrq8zj46a5dzwqa0fdmxxbam75zm"; + system = "flare-viewer"; + asd = "flare-viewer"; + } + ); + systems = [ "flare-viewer" ]; + lispLibs = [ + (getAttr "cl-opengl" self) + (getAttr "flare" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtools" self) + (getAttr "qtopengl" self) + (getAttr "verbose" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + flat-tree = ( + build-asdf-system { + pname = "flat-tree"; + version = "20190813-git"; + asds = [ "flat-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-flat-tree/2019-08-13/cl-flat-tree-20190813-git.tgz"; + sha256 = "05nw1j0rr0vgz6shkjv87yn2mp0b4s7v5gxxcqcn1qi7fgbn55z7"; + system = "flat-tree"; + asd = "flat-tree"; + } + ); + systems = [ "flat-tree" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + flexi-streams = ( + build-asdf-system { + pname = "flexi-streams"; + version = "20241012-git"; + asds = [ "flexi-streams" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/flexi-streams/2024-10-12/flexi-streams-20241012-git.tgz"; + sha256 = "1bk224ryfiwsmnmq2gdfv9gld85z2rvnlx7fxcl2k122vc344akh"; + system = "flexi-streams"; + asd = "flexi-streams"; + } + ); + systems = [ "flexi-streams" ]; + lispLibs = [ (getAttr "trivial-gray-streams" self) ]; + meta = { }; + } + ); + flexi-streams-test = ( + build-asdf-system { + pname = "flexi-streams-test"; + version = "20241012-git"; + asds = [ "flexi-streams-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/flexi-streams/2024-10-12/flexi-streams-20241012-git.tgz"; + sha256 = "1bk224ryfiwsmnmq2gdfv9gld85z2rvnlx7fxcl2k122vc344akh"; + system = "flexi-streams-test"; + asd = "flexi-streams-test"; + } + ); + systems = [ "flexi-streams-test" ]; + lispLibs = [ (getAttr "flexi-streams" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + flexichain = ( + build-asdf-system { + pname = "flexichain"; + version = "20201220-git"; + asds = [ "flexichain" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/flexichain/2020-12-20/flexichain-20201220-git.tgz"; + sha256 = "1ivkffnkc1iqmpl1p1rgyfbbgjmjcid4iszvdql1jjz324lq94g6"; + system = "flexichain"; + asd = "flexichain"; + } + ); + systems = [ "flexichain" ]; + lispLibs = [ (getAttr "trivial-garbage" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + flexichain-doc = ( + build-asdf-system { + pname = "flexichain-doc"; + version = "20201220-git"; + asds = [ "flexichain-doc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/flexichain/2020-12-20/flexichain-20201220-git.tgz"; + sha256 = "1ivkffnkc1iqmpl1p1rgyfbbgjmjcid4iszvdql1jjz324lq94g6"; + system = "flexichain-doc"; + asd = "flexichain-doc"; + } + ); + systems = [ "flexichain-doc" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + float-features = ( + build-asdf-system { + pname = "float-features"; + version = "20241012-git"; + asds = [ "float-features" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/float-features/2024-10-12/float-features-20241012-git.tgz"; + sha256 = "1vxnvaprki5rk3phj20m35pva9dpgsixm8d9rnsixq1qgrv3djjf"; + system = "float-features"; + asd = "float-features"; + } + ); + systems = [ "float-features" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { }; + } + ); + float-features-tests = ( + build-asdf-system { + pname = "float-features-tests"; + version = "20241012-git"; + asds = [ "float-features-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/float-features/2024-10-12/float-features-20241012-git.tgz"; + sha256 = "1vxnvaprki5rk3phj20m35pva9dpgsixm8d9rnsixq1qgrv3djjf"; + system = "float-features-tests"; + asd = "float-features-tests"; + } + ); + systems = [ "float-features-tests" ]; + lispLibs = [ + (getAttr "float-features" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + floating-point = ( + build-asdf-system { + pname = "floating-point"; + version = "20141106-git"; + asds = [ "floating-point" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/floating-point/2014-11-06/floating-point-20141106-git.tgz"; + sha256 = "1bqslmykg04innaqlp369pyjh61isj8xgv2h6pm95gsrxnf6wf7s"; + system = "floating-point"; + asd = "floating-point"; + } + ); + systems = [ "floating-point" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + floating-point-contractions = ( + build-asdf-system { + pname = "floating-point-contractions"; + version = "20201220-git"; + asds = [ "floating-point-contractions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/floating-point-contractions/2020-12-20/floating-point-contractions-20201220-git.tgz"; + sha256 = "0mr8bnc7hn0ii0cmlfnlwc14zkgbgdf099x5crrf9cp9wda4p082"; + system = "floating-point-contractions"; + asd = "floating-point-contractions"; + } + ); + systems = [ "floating-point-contractions" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + floating-point-test = ( + build-asdf-system { + pname = "floating-point-test"; + version = "20141106-git"; + asds = [ "floating-point-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/floating-point/2014-11-06/floating-point-20141106-git.tgz"; + sha256 = "1bqslmykg04innaqlp369pyjh61isj8xgv2h6pm95gsrxnf6wf7s"; + system = "floating-point-test"; + asd = "floating-point-test"; + } + ); + systems = [ "floating-point-test" ]; + lispLibs = [ + (getAttr "floating-point" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + flow = ( + build-asdf-system { + pname = "flow"; + version = "20241012-git"; + asds = [ "flow" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/flow/2024-10-12/flow-20241012-git.tgz"; + sha256 = "1623kkyygwkqpgrbvv1zqj13mjkycqyh88nwcjsxd0clrlhlyfz3"; + system = "flow"; + asd = "flow"; + } + ); + systems = [ "flow" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "documentation-utils" self) + ]; + meta = { }; + } + ); + flow-visualizer = ( + build-asdf-system { + pname = "flow-visualizer"; + version = "20241012-git"; + asds = [ "flow-visualizer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/flow/2024-10-12/flow-20241012-git.tgz"; + sha256 = "1623kkyygwkqpgrbvv1zqj13mjkycqyh88nwcjsxd0clrlhlyfz3"; + system = "flow-visualizer"; + asd = "flow-visualizer"; + } + ); + systems = [ "flow-visualizer" ]; + lispLibs = [ + (getAttr "flow" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtools" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + flute = ( + build-asdf-system { + pname = "flute"; + version = "20180831-git"; + asds = [ "flute" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/flute/2018-08-31/flute-20180831-git.tgz"; + sha256 = "0q8jhp040cvpppyn820mm6a550yfxyr1lar298x13c42mm807f4f"; + system = "flute"; + asd = "flute"; + } + ); + systems = [ "flute" ]; + lispLibs = [ + (getAttr "assoc-utils" self) + (getAttr "let-over-lambda" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + flute-test = ( + build-asdf-system { + pname = "flute-test"; + version = "20180831-git"; + asds = [ "flute-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/flute/2018-08-31/flute-20180831-git.tgz"; + sha256 = "0q8jhp040cvpppyn820mm6a550yfxyr1lar298x13c42mm807f4f"; + system = "flute-test"; + asd = "flute-test"; + } + ); + systems = [ "flute-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "flute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + flx = ( + build-asdf-system { + pname = "flx"; + version = "20241012-git"; + asds = [ "flx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-flx/2024-10-12/cl-flx-20241012-git.tgz"; + sha256 = "02p8qmc6wy3kf6w3rpgjvyg3jb699i5x9zk2f1p2y9h3m86d7hsw"; + system = "flx"; + asd = "flx"; + } + ); + systems = [ "flx" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fmarshal = ( + build-asdf-system { + pname = "fmarshal"; + version = "20130720-git"; + asds = [ "fmarshal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/marshal/2013-07-20/marshal-20130720-git.tgz"; + sha256 = "1c0hcf7i9kzgbmayhmcjg0kv5966yqlimvj67gl4mzvwhbdkc2nf"; + system = "fmarshal"; + asd = "fmarshal"; + } + ); + systems = [ "fmarshal" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fmarshal-test = ( + build-asdf-system { + pname = "fmarshal-test"; + version = "20130720-git"; + asds = [ "fmarshal-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/marshal/2013-07-20/marshal-20130720-git.tgz"; + sha256 = "1c0hcf7i9kzgbmayhmcjg0kv5966yqlimvj67gl4mzvwhbdkc2nf"; + system = "fmarshal-test"; + asd = "fmarshal-test"; + } + ); + systems = [ "fmarshal-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "fmarshal" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fmcs = ( + build-asdf-system { + pname = "fmcs"; + version = "20231021-git"; + asds = [ "fmcs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fmcs/2023-10-21/fmcs-20231021-git.tgz"; + sha256 = "1zp73i68f5sl93z10l2f94nylbkaj601ani6yg3bg7iqhs543651"; + system = "fmcs"; + asd = "fmcs"; + } + ); + systems = [ "fmcs" ]; + lispLibs = [ (getAttr "fare-quasiquote-extras" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fmt = ( + build-asdf-system { + pname = "fmt"; + version = "20220331-git"; + asds = [ "fmt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fmt/2022-03-31/fmt-20220331-git.tgz"; + sha256 = "078y5yig5fw0jcsjjabaq7dlyxsd10w5k80ywx6gbm0j88al3fzp"; + system = "fmt"; + asd = "fmt"; + } + ); + systems = [ "fmt" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fmt-test = ( + build-asdf-system { + pname = "fmt-test"; + version = "20220331-git"; + asds = [ "fmt-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fmt/2022-03-31/fmt-20220331-git.tgz"; + sha256 = "078y5yig5fw0jcsjjabaq7dlyxsd10w5k80ywx6gbm0j88al3fzp"; + system = "fmt-test"; + asd = "fmt-test"; + } + ); + systems = [ "fmt-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "fmt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fmt-time = ( + build-asdf-system { + pname = "fmt-time"; + version = "20220331-git"; + asds = [ "fmt-time" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fmt/2022-03-31/fmt-20220331-git.tgz"; + sha256 = "078y5yig5fw0jcsjjabaq7dlyxsd10w5k80ywx6gbm0j88al3fzp"; + system = "fmt-time"; + asd = "fmt-time"; + } + ); + systems = [ "fmt-time" ]; + lispLibs = [ + (getAttr "fmt" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fn = ( + build-asdf-system { + pname = "fn"; + version = "20241012-git"; + asds = [ "fn" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fn/2024-10-12/fn-20241012-git.tgz"; + sha256 = "08ydmfly5jaisfj8pkksq6npz992zlz4ni1yqlrq5yigwx41xaz0"; + system = "fn"; + asd = "fn"; + } + ); + systems = [ "fn" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { }; + } + ); + fof = ( + build-asdf-system { + pname = "fof"; + version = "20211230-git"; + asds = [ "fof" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fof/2021-12-30/fof-20211230-git.tgz"; + sha256 = "0ipy51q2fw03xk9rqcyzbq2b9c32npc1gl3c53rdjywpak7zwwg6"; + system = "fof"; + asd = "fof"; + } + ); + systems = [ "fof" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "hu_dot_dwim_dot_defclass-star" self) + (getAttr "local-time" self) + (getAttr "magicffi" self) + (getAttr "named-readtables" self) + (getAttr "osicat" self) + (getAttr "serapeum" self) + (getAttr "str" self) + (getAttr "trivia" self) + (getAttr "trivial-package-local-nicknames" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio = ( + build-asdf-system { + pname = "folio"; + version = "20130128-git"; + asds = [ "folio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio/2013-01-28/folio-20130128-git.tgz"; + sha256 = "061kryjclnkp60r8vhcpzy9q0k755p1jc1vp4vj13k7piwr1bj64"; + system = "folio"; + asd = "folio"; + } + ); + systems = [ "folio" ]; + lispLibs = [ + (getAttr "folio_dot_as" self) + (getAttr "folio_dot_boxes" self) + (getAttr "folio_dot_collections" self) + (getAttr "folio_dot_functions" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio_dot_as = ( + build-asdf-system { + pname = "folio.as"; + version = "20130128-git"; + asds = [ "folio.as" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio/2013-01-28/folio-20130128-git.tgz"; + sha256 = "061kryjclnkp60r8vhcpzy9q0k755p1jc1vp4vj13k7piwr1bj64"; + system = "folio.as"; + asd = "folio.as"; + } + ); + systems = [ "folio.as" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio_dot_boxes = ( + build-asdf-system { + pname = "folio.boxes"; + version = "20130128-git"; + asds = [ "folio.boxes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio/2013-01-28/folio-20130128-git.tgz"; + sha256 = "061kryjclnkp60r8vhcpzy9q0k755p1jc1vp4vj13k7piwr1bj64"; + system = "folio.boxes"; + asd = "folio.boxes"; + } + ); + systems = [ "folio.boxes" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio_dot_collections = ( + build-asdf-system { + pname = "folio.collections"; + version = "20130128-git"; + asds = [ "folio.collections" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio/2013-01-28/folio-20130128-git.tgz"; + sha256 = "061kryjclnkp60r8vhcpzy9q0k755p1jc1vp4vj13k7piwr1bj64"; + system = "folio.collections"; + asd = "folio.collections"; + } + ); + systems = [ "folio.collections" ]; + lispLibs = [ + (getAttr "folio_dot_as" self) + (getAttr "folio_dot_functions" self) + (getAttr "fset" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio_dot_functions = ( + build-asdf-system { + pname = "folio.functions"; + version = "20130128-git"; + asds = [ "folio.functions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio/2013-01-28/folio-20130128-git.tgz"; + sha256 = "061kryjclnkp60r8vhcpzy9q0k755p1jc1vp4vj13k7piwr1bj64"; + system = "folio.functions"; + asd = "folio.functions"; + } + ); + systems = [ "folio.functions" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2 = ( + build-asdf-system { + pname = "folio2"; + version = "20191007-git"; + asds = [ "folio2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2"; + asd = "folio2"; + } + ); + systems = [ "folio2" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "folio2-as" self) + (getAttr "folio2-as-syntax" self) + (getAttr "folio2-boxes" self) + (getAttr "folio2-functions" self) + (getAttr "folio2-functions-syntax" self) + (getAttr "folio2-make" self) + (getAttr "folio2-maps" self) + (getAttr "folio2-maps-syntax" self) + (getAttr "folio2-pairs" self) + (getAttr "folio2-sequences" self) + (getAttr "folio2-sequences-syntax" self) + (getAttr "folio2-series" self) + (getAttr "folio2-taps" self) + (getAttr "fset" self) + (getAttr "series" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-as = ( + build-asdf-system { + pname = "folio2-as"; + version = "20191007-git"; + asds = [ "folio2-as" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-as"; + asd = "folio2-as"; + } + ); + systems = [ "folio2-as" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-as-syntax = ( + build-asdf-system { + pname = "folio2-as-syntax"; + version = "20191007-git"; + asds = [ "folio2-as-syntax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-as-syntax"; + asd = "folio2-as-syntax"; + } + ); + systems = [ "folio2-as-syntax" ]; + lispLibs = [ (getAttr "folio2-as" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-as-tests = ( + build-asdf-system { + pname = "folio2-as-tests"; + version = "20191007-git"; + asds = [ "folio2-as-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-as-tests"; + asd = "folio2-as-tests"; + } + ); + systems = [ "folio2-as-tests" ]; + lispLibs = [ + (getAttr "folio2-as" self) + (getAttr "folio2-as-syntax" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-boxes = ( + build-asdf-system { + pname = "folio2-boxes"; + version = "20191007-git"; + asds = [ "folio2-boxes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-boxes"; + asd = "folio2-boxes"; + } + ); + systems = [ "folio2-boxes" ]; + lispLibs = [ + (getAttr "folio2-as" self) + (getAttr "folio2-make" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-boxes-tests = ( + build-asdf-system { + pname = "folio2-boxes-tests"; + version = "20191007-git"; + asds = [ "folio2-boxes-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-boxes-tests"; + asd = "folio2-boxes-tests"; + } + ); + systems = [ "folio2-boxes-tests" ]; + lispLibs = [ + (getAttr "folio2-boxes" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-functions = ( + build-asdf-system { + pname = "folio2-functions"; + version = "20191007-git"; + asds = [ "folio2-functions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-functions"; + asd = "folio2-functions"; + } + ); + systems = [ "folio2-functions" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "folio2-as" self) + (getAttr "folio2-make" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-functions-syntax = ( + build-asdf-system { + pname = "folio2-functions-syntax"; + version = "20191007-git"; + asds = [ "folio2-functions-syntax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-functions-syntax"; + asd = "folio2-functions-syntax"; + } + ); + systems = [ "folio2-functions-syntax" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "folio2-functions" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-functions-tests = ( + build-asdf-system { + pname = "folio2-functions-tests"; + version = "20191007-git"; + asds = [ "folio2-functions-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-functions-tests"; + asd = "folio2-functions-tests"; + } + ); + systems = [ "folio2-functions-tests" ]; + lispLibs = [ + (getAttr "folio2-functions" self) + (getAttr "folio2-functions-syntax" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-make = ( + build-asdf-system { + pname = "folio2-make"; + version = "20191007-git"; + asds = [ "folio2-make" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-make"; + asd = "folio2-make"; + } + ); + systems = [ "folio2-make" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-make-tests = ( + build-asdf-system { + pname = "folio2-make-tests"; + version = "20191007-git"; + asds = [ "folio2-make-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-make-tests"; + asd = "folio2-make-tests"; + } + ); + systems = [ "folio2-make-tests" ]; + lispLibs = [ + (getAttr "folio2-make" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-maps = ( + build-asdf-system { + pname = "folio2-maps"; + version = "20191007-git"; + asds = [ "folio2-maps" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-maps"; + asd = "folio2-maps"; + } + ); + systems = [ "folio2-maps" ]; + lispLibs = [ + (getAttr "folio2-as" self) + (getAttr "folio2-make" self) + (getAttr "fset" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-maps-syntax = ( + build-asdf-system { + pname = "folio2-maps-syntax"; + version = "20191007-git"; + asds = [ "folio2-maps-syntax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-maps-syntax"; + asd = "folio2-maps-syntax"; + } + ); + systems = [ "folio2-maps-syntax" ]; + lispLibs = [ (getAttr "folio2-maps" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-maps-tests = ( + build-asdf-system { + pname = "folio2-maps-tests"; + version = "20191007-git"; + asds = [ "folio2-maps-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-maps-tests"; + asd = "folio2-maps-tests"; + } + ); + systems = [ "folio2-maps-tests" ]; + lispLibs = [ + (getAttr "folio2-maps" self) + (getAttr "folio2-maps-syntax" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-pairs = ( + build-asdf-system { + pname = "folio2-pairs"; + version = "20191007-git"; + asds = [ "folio2-pairs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-pairs"; + asd = "folio2-pairs"; + } + ); + systems = [ "folio2-pairs" ]; + lispLibs = [ + (getAttr "folio2-as" self) + (getAttr "folio2-make" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-pairs-tests = ( + build-asdf-system { + pname = "folio2-pairs-tests"; + version = "20191007-git"; + asds = [ "folio2-pairs-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-pairs-tests"; + asd = "folio2-pairs-tests"; + } + ); + systems = [ "folio2-pairs-tests" ]; + lispLibs = [ + (getAttr "folio2-pairs" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-sequences = ( + build-asdf-system { + pname = "folio2-sequences"; + version = "20191007-git"; + asds = [ "folio2-sequences" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-sequences"; + asd = "folio2-sequences"; + } + ); + systems = [ "folio2-sequences" ]; + lispLibs = [ + (getAttr "folio2-as" self) + (getAttr "folio2-make" self) + (getAttr "folio2-pairs" self) + (getAttr "fset" self) + (getAttr "series" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-sequences-syntax = ( + build-asdf-system { + pname = "folio2-sequences-syntax"; + version = "20191007-git"; + asds = [ "folio2-sequences-syntax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-sequences-syntax"; + asd = "folio2-sequences-syntax"; + } + ); + systems = [ "folio2-sequences-syntax" ]; + lispLibs = [ (getAttr "folio2-sequences" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-sequences-tests = ( + build-asdf-system { + pname = "folio2-sequences-tests"; + version = "20191007-git"; + asds = [ "folio2-sequences-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-sequences-tests"; + asd = "folio2-sequences-tests"; + } + ); + systems = [ "folio2-sequences-tests" ]; + lispLibs = [ + (getAttr "folio2-sequences" self) + (getAttr "folio2-sequences-syntax" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-series = ( + build-asdf-system { + pname = "folio2-series"; + version = "20191007-git"; + asds = [ "folio2-series" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-series"; + asd = "folio2-series"; + } + ); + systems = [ "folio2-series" ]; + lispLibs = [ + (getAttr "folio2-as" self) + (getAttr "folio2-make" self) + (getAttr "folio2-pairs" self) + (getAttr "folio2-sequences" self) + (getAttr "fset" self) + (getAttr "series" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-series-tests = ( + build-asdf-system { + pname = "folio2-series-tests"; + version = "20191007-git"; + asds = [ "folio2-series-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-series-tests"; + asd = "folio2-series-tests"; + } + ); + systems = [ "folio2-series-tests" ]; + lispLibs = [ + (getAttr "folio2-series" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-taps = ( + build-asdf-system { + pname = "folio2-taps"; + version = "20191007-git"; + asds = [ "folio2-taps" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-taps"; + asd = "folio2-taps"; + } + ); + systems = [ "folio2-taps" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "folio2-as" self) + (getAttr "folio2-make" self) + (getAttr "folio2-maps" self) + (getAttr "folio2-pairs" self) + (getAttr "folio2-sequences" self) + (getAttr "folio2-series" self) + (getAttr "fset" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-taps-tests = ( + build-asdf-system { + pname = "folio2-taps-tests"; + version = "20191007-git"; + asds = [ "folio2-taps-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-taps-tests"; + asd = "folio2-taps-tests"; + } + ); + systems = [ "folio2-taps-tests" ]; + lispLibs = [ + (getAttr "folio2-taps" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + folio2-tests = ( + build-asdf-system { + pname = "folio2-tests"; + version = "20191007-git"; + asds = [ "folio2-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/folio2/2019-10-07/folio2-20191007-git.tgz"; + sha256 = "0h214bhbxk229p4pyb6cb85gx6jvhzk2brbzhwhixprznilz6shd"; + system = "folio2-tests"; + asd = "folio2-tests"; + } + ); + systems = [ "folio2-tests" ]; + lispLibs = [ (getAttr "folio2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + font-discovery = ( + build-asdf-system { + pname = "font-discovery"; + version = "20231021-git"; + asds = [ "font-discovery" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/font-discovery/2023-10-21/font-discovery-20231021-git.tgz"; + sha256 = "1kx83564p1w2wka3l6g4rj7zvzi85prvs6yag2qv2a9xh80yv9rz"; + system = "font-discovery"; + asd = "font-discovery"; + } + ); + systems = [ "font-discovery" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + (getAttr "trivial-indent" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + foo-wild = ( + build-asdf-system { + pname = "foo-wild"; + version = "20210531-git"; + asds = [ "foo-wild" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/wild-package-inferred-system/2021-05-31/wild-package-inferred-system-20210531-git.tgz"; + sha256 = "0sp3j3i83aqyq9bl3djs490nilryi9sh1wjbcqd9z94d9wfbfz80"; + system = "foo-wild"; + asd = "foo-wild"; + } + ); + systems = [ "foo-wild" ]; + lispLibs = [ (getAttr "wild-package-inferred-system" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + for = ( + build-asdf-system { + pname = "for"; + version = "20231021-git"; + asds = [ "for" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/for/2023-10-21/for-20231021-git.tgz"; + sha256 = "07jdwqkyb3qd65mng60cs723z7p0bv2769hhalz4c0mfzn8qrn99"; + system = "for"; + asd = "for"; + } + ); + systems = [ "for" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "form-fiddle" self) + (getAttr "lambda-fiddle" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + foreign-array = ( + build-asdf-system { + pname = "foreign-array"; + version = "master-df14cb8c-git"; + asds = [ "foreign-array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/antik/2024-10-12/antik-master-df14cb8c-git.tgz"; + sha256 = "1n08cx4n51z8v4bxyak166lp495xda3x7llfxcdpxndxqxcammr0"; + system = "foreign-array"; + asd = "foreign-array"; + } + ); + systems = [ "foreign-array" ]; + lispLibs = [ + (getAttr "antik-base" self) + (getAttr "cffi" self) + (getAttr "static-vectors" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fork-future = ( + build-asdf-system { + pname = "fork-future"; + version = "20220220-git"; + asds = [ "fork-future" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "fork-future"; + asd = "fork-future"; + } + ); + systems = [ "fork-future" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-store" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + form-fiddle = ( + build-asdf-system { + pname = "form-fiddle"; + version = "20231021-git"; + asds = [ "form-fiddle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/form-fiddle/2023-10-21/form-fiddle-20231021-git.tgz"; + sha256 = "0vl28q8xa42i9gr1bch22jdha9jh8sr2hcv6d9kykj4jsqi9kwbg"; + system = "form-fiddle"; + asd = "form-fiddle"; + } + ); + systems = [ "form-fiddle" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { }; + } + ); + format-string-builder = ( + build-asdf-system { + pname = "format-string-builder"; + version = "20170124-git"; + asds = [ "format-string-builder" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/format-string-builder/2017-01-24/format-string-builder-20170124-git.tgz"; + sha256 = "1266w5wynfhamxdf8ms2236m202f6982fd9ph8fs98nqccq2pcac"; + system = "format-string-builder"; + asd = "format-string-builder"; + } + ); + systems = [ "format-string-builder" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + formlets = ( + build-asdf-system { + pname = "formlets"; + version = "20161204-git"; + asds = [ "formlets" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/formlets/2016-12-04/formlets-20161204-git.tgz"; + sha256 = "0r2afi5lwzxfb8xylx9cs44wqhla4b50k21nzg2dxn7z8m6yspfn"; + system = "formlets"; + asd = "formlets"; + } + ); + systems = [ "formlets" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cl-who" self) + (getAttr "drakma" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + formlets-test = ( + build-asdf-system { + pname = "formlets-test"; + version = "20161204-git"; + asds = [ "formlets-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/formlets/2016-12-04/formlets-20161204-git.tgz"; + sha256 = "0r2afi5lwzxfb8xylx9cs44wqhla4b50k21nzg2dxn7z8m6yspfn"; + system = "formlets-test"; + asd = "formlets-test"; + } + ); + systems = [ "formlets-test" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cl-who" self) + (getAttr "drakma" self) + (getAttr "formlets" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fprog = ( + build-asdf-system { + pname = "fprog"; + version = "20181210-git"; + asds = [ "fprog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cambl/2018-12-10/cambl-20181210-git.tgz"; + sha256 = "103mry04j2k9vznsxm7wcvccgxkil92cdrv52miwcmxl8daa4jiz"; + system = "fprog"; + asd = "fprog"; + } + ); + systems = [ "fprog" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fps-independent-timestep = ( + build-asdf-system { + pname = "fps-independent-timestep"; + version = "20200427-git"; + asds = [ "fps-independent-timestep" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "fps-independent-timestep"; + asd = "fps-independent-timestep"; + } + ); + systems = [ "fps-independent-timestep" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fred = ( + build-asdf-system { + pname = "fred"; + version = "20150923-git"; + asds = [ "fred" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fred/2015-09-23/fred-20150923-git.tgz"; + sha256 = "0qn2rd67haz4pvvv4yp2yvbvjhficv8xjm7ijg0r34gxllm6i373"; + system = "fred"; + asd = "fred"; + } + ); + systems = [ "fred" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "s-xml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + freebsd-sysctl = ( + build-asdf-system { + pname = "freebsd-sysctl"; + version = "20210228-git"; + asds = [ "freebsd-sysctl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/freebsd-sysctl/2021-02-28/freebsd-sysctl-20210228-git.tgz"; + sha256 = "1gzqiqz0pi273ia2q61bhr908ymbl8cll5v2h8lkicr9pff37g91"; + system = "freebsd-sysctl"; + asd = "freebsd-sysctl"; + } + ); + systems = [ "freebsd-sysctl" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + freesound = ( + build-asdf-system { + pname = "freesound"; + version = "20210411-git"; + asds = [ "freesound" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/freesound/2021-04-11/freesound-20210411-git.tgz"; + sha256 = "1nsmbz7qx9wn86860zlnw75sdgpr8qfzgqfbwxggc3zr7p83kric"; + system = "freesound"; + asd = "freesound"; + } + ); + systems = [ "freesound" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "dexador" self) + (getAttr "trivial-open-browser" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fresnel = ( + build-asdf-system { + pname = "fresnel"; + version = "20230618-git"; + asds = [ "fresnel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fresnel/2023-06-18/fresnel-20230618-git.tgz"; + sha256 = "0rzi3pz1cjf8m0fmj7dg7wxbbcmxnbx75hfp9hbmrm9yqsjc4khv"; + system = "fresnel"; + asd = "fresnel"; + } + ); + systems = [ "fresnel" ]; + lispLibs = [ + (getAttr "fare-quasiquote-extras" self) + (getAttr "gt" self) + (getAttr "trivial-package-local-nicknames" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + froute = ( + build-asdf-system { + pname = "froute"; + version = "20180711-git"; + asds = [ "froute" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/froute/2018-07-11/froute-20180711-git.tgz"; + sha256 = "1q7xzgn7g5ky1d8m121r8hskcg4gqpripr791k03y7dz5vkfj14x"; + system = "froute"; + asd = "froute"; + } + ); + systems = [ "froute" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + frpc = ( + build-asdf-system { + pname = "frpc"; + version = "20151031-git"; + asds = [ "frpc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/frpc/2015-10-31/frpc-20151031-git.tgz"; + sha256 = "0yac1q79kw1w1qd7zjgg912n780v318n2drzdimlv5n3bwd6pm2r"; + system = "frpc"; + asd = "frpc"; + } + ); + systems = [ "frpc" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "flexi-streams" self) + (getAttr "glass" self) + (getAttr "nibbles" self) + (getAttr "pounds" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + frpc-des = ( + build-asdf-system { + pname = "frpc-des"; + version = "20151031-git"; + asds = [ "frpc-des" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/frpc/2015-10-31/frpc-20151031-git.tgz"; + sha256 = "0yac1q79kw1w1qd7zjgg912n780v318n2drzdimlv5n3bwd6pm2r"; + system = "frpc-des"; + asd = "frpc"; + } + ); + systems = [ "frpc-des" ]; + lispLibs = [ + (getAttr "frpc" self) + (getAttr "ironclad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + frpc-gss = ( + build-asdf-system { + pname = "frpc-gss"; + version = "20151031-git"; + asds = [ "frpc-gss" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/frpc/2015-10-31/frpc-20151031-git.tgz"; + sha256 = "0yac1q79kw1w1qd7zjgg912n780v318n2drzdimlv5n3bwd6pm2r"; + system = "frpc-gss"; + asd = "frpc"; + } + ); + systems = [ "frpc-gss" ]; + lispLibs = [ + (getAttr "cerberus" self) + (getAttr "frpc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + frpcgen = ( + build-asdf-system { + pname = "frpcgen"; + version = "20151031-git"; + asds = [ "frpcgen" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/frpc/2015-10-31/frpc-20151031-git.tgz"; + sha256 = "0yac1q79kw1w1qd7zjgg912n780v318n2drzdimlv5n3bwd6pm2r"; + system = "frpcgen"; + asd = "frpcgen"; + } + ); + systems = [ "frpcgen" ]; + lispLibs = [ + (getAttr "cl-lex" self) + (getAttr "frpc" self) + (getAttr "yacc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + frugal-uuid = ( + build-asdf-system { + pname = "frugal-uuid"; + version = "20241012-git"; + asds = [ "frugal-uuid" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-frugal-uuid/2024-10-12/cl-frugal-uuid-20241012-git.tgz"; + sha256 = "01hli6gh0rr6mizqp1iqfch7rd0jw6ygrskjdr5hf3r8wwwvr9hh"; + system = "frugal-uuid"; + asd = "frugal-uuid"; + } + ); + systems = [ "frugal-uuid" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fs-watcher = ( + build-asdf-system { + pname = "fs-watcher"; + version = "20171130-git"; + asds = [ "fs-watcher" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fs-watcher/2017-11-30/fs-watcher-20171130-git.tgz"; + sha256 = "0fr2wb39609z4afk4w21vwnwi4g050x4gag2ykdx6hn9m65cp9db"; + system = "fs-watcher"; + asd = "fs-watcher"; + } + ); + systems = [ "fs-watcher" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "com_dot_gigamonkeys_dot_pathnames" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fset = ( + build-asdf-system { + pname = "fset"; + version = "20241012-git"; + asds = [ "fset" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fset/2024-10-12/fset-20241012-git.tgz"; + sha256 = "0h9j5a7vlr8g0hq99y4wgw1l1wialzs6k16nrpmd4pwiyiypzkm6"; + system = "fset"; + asd = "fset"; + } + ); + systems = [ "fset" ]; + lispLibs = [ + (getAttr "misc-extensions" self) + (getAttr "named-readtables" self) + (getAttr "random-state" self) + ]; + meta = { }; + } + ); + fsocket = ( + build-asdf-system { + pname = "fsocket"; + version = "20211230-git"; + asds = [ "fsocket" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fsocket/2021-12-30/fsocket-20211230-git.tgz"; + sha256 = "18h3s4bv3243xbp0qdywn9kmqvx8zh9cscc9f6sfyxrz6xhymw6p"; + system = "fsocket"; + asd = "fsocket"; + } + ); + systems = [ "fsocket" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fsvd = ( + build-asdf-system { + pname = "fsvd"; + version = "20131211-git"; + asds = [ "fsvd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fsvd/2013-12-11/fsvd-20131211-git.tgz"; + sha256 = "1m22g9x18ixjh5nylm56l5p67ryx9dbd3g6lyzvwk9nayjmqn7x5"; + system = "fsvd"; + asd = "fsvd"; + } + ); + systems = [ "fsvd" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ftp = ( + build-asdf-system { + pname = "ftp"; + version = "20150608-http"; + asds = [ "ftp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ftp/2015-06-08/cl-ftp-20150608-http.tgz"; + sha256 = "1m955rjpaynybzmb9q631mll764hm06lydvhra50mfjj75ynwsvw"; + system = "ftp"; + asd = "ftp"; + } + ); + systems = [ "ftp" ]; + lispLibs = [ (getAttr "cl-ftp" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fucc-generator = ( + build-asdf-system { + pname = "fucc-generator"; + version = "v0.2.2"; + asds = [ "fucc-generator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fucc/2020-04-27/fucc-v0.2.2.tgz"; + sha256 = "10wznxw6yhkyh943xnm694innj13xdlmkx13pr8xwc6zdbdyb32k"; + system = "fucc-generator"; + asd = "fucc-generator"; + } + ); + systems = [ "fucc-generator" ]; + lispLibs = [ (getAttr "fucc-parser" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fucc-parser = ( + build-asdf-system { + pname = "fucc-parser"; + version = "v0.2.2"; + asds = [ "fucc-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fucc/2020-04-27/fucc-v0.2.2.tgz"; + sha256 = "10wznxw6yhkyh943xnm694innj13xdlmkx13pr8xwc6zdbdyb32k"; + system = "fucc-parser"; + asd = "fucc-parser"; + } + ); + systems = [ "fucc-parser" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + function-cache = ( + build-asdf-system { + pname = "function-cache"; + version = "20231021-git"; + asds = [ "function-cache" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/function-cache/2023-10-21/function-cache-20231021-git.tgz"; + sha256 = "1sk35fd7zw6kx9zpv18wmzmkksbn0ac4ycjzi6hqdgkbyn3l136w"; + system = "function-cache"; + asd = "function-cache"; + } + ); + systems = [ "function-cache" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-interpol" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + (getAttr "symbol-munger" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + function-cache-clsql = ( + build-asdf-system { + pname = "function-cache-clsql"; + version = "20231021-git"; + asds = [ "function-cache-clsql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/function-cache/2023-10-21/function-cache-20231021-git.tgz"; + sha256 = "1sk35fd7zw6kx9zpv18wmzmkksbn0ac4ycjzi6hqdgkbyn3l136w"; + system = "function-cache-clsql"; + asd = "function-cache-clsql"; + } + ); + systems = [ "function-cache-clsql" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "clsql-helper" self) + (getAttr "function-cache" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + functional-geometry = ( + build-asdf-system { + pname = "functional-geometry"; + version = "20241012-git"; + asds = [ "functional-geometry" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "functional-geometry"; + asd = "functional-geometry"; + } + ); + systems = [ "functional-geometry" ]; + lispLibs = [ (getAttr "clim-listener" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + functional-trees = ( + build-asdf-system { + pname = "functional-trees"; + version = "20241012-git"; + asds = [ "functional-trees" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/functional-trees/2024-10-12/functional-trees-20241012-git.tgz"; + sha256 = "02jhc2c6d7zd75cpjmwck62b3iyzsf5q2yqqpp5ymwjmnx4bnysd"; + system = "functional-trees"; + asd = "functional-trees"; + } + ); + systems = [ "functional-trees" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "asdf-package-system" self) + (getAttr "atomics" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-store" self) + (getAttr "closer-mop" self) + (getAttr "fset" self) + (getAttr "iterate" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + funds = ( + build-asdf-system { + pname = "funds"; + version = "20211020-git"; + asds = [ "funds" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/funds/2021-10-20/funds-20211020-git.tgz"; + sha256 = "13y1jhvnpzrs9daz6f3z67w6h2y21ggb10j3j4vnc5p3m8i7ps4p"; + system = "funds"; + asd = "funds"; + } + ); + systems = [ "funds" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + future = ( + build-asdf-system { + pname = "future"; + version = "20220220-git"; + asds = [ "future" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clml/2022-02-20/clml-20220220-git.tgz"; + sha256 = "0m3w59c74z3wdj1g26122svljiq192xhvmx7b2lkb7bxnf4778m1"; + system = "future"; + asd = "future"; + } + ); + systems = [ "future" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fuzzy-dates = ( + build-asdf-system { + pname = "fuzzy-dates"; + version = "20241012-git"; + asds = [ "fuzzy-dates" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fuzzy-dates/2024-10-12/fuzzy-dates-20241012-git.tgz"; + sha256 = "1nnwb7dl772zax0ysc9v4z29kq639f3za7k34hdk9fyyqbln9dgl"; + system = "fuzzy-dates"; + asd = "fuzzy-dates"; + } + ); + systems = [ "fuzzy-dates" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "documentation-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fuzzy-match = ( + build-asdf-system { + pname = "fuzzy-match"; + version = "20210124-git"; + asds = [ "fuzzy-match" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fuzzy-match/2021-01-24/fuzzy-match-20210124-git.tgz"; + sha256 = "1lawndmzkl6f9sviy7ngn2s3xkc4akp8l505kvpslaz6qq0ayyqv"; + system = "fuzzy-match"; + asd = "fuzzy-match"; + } + ); + systems = [ "fuzzy-match" ]; + lispLibs = [ + (getAttr "mk-string-metrics" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + fxml = ( + build-asdf-system { + pname = "fxml"; + version = "20210228-git"; + asds = [ "fxml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fxml/2021-02-28/fxml-20210228-git.tgz"; + sha256 = "1vxdb1cjjqi986f72bggnw1s4yzv12g4li7vn4y49b6lphshr8lm"; + system = "fxml"; + asd = "fxml"; + } + ); + systems = [ "fxml" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "flexi-streams" self) + (getAttr "named-readtables" self) + (getAttr "quri" self) + (getAttr "serapeum" self) + (getAttr "split-sequence" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gadgets = ( + build-asdf-system { + pname = "gadgets"; + version = "20241012-git"; + asds = [ "gadgets" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gadgets/2024-10-12/gadgets-20241012-git.tgz"; + sha256 = "1ba4gj8lh3ihbb66xiz7hc8cdg3gvi3q20w32nmsqdch956is34k"; + system = "gadgets"; + asd = "gadgets"; + } + ); + systems = [ "gadgets" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-hash-util" self) + (getAttr "cl-utilities" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + garbage-pools = ( + build-asdf-system { + pname = "garbage-pools"; + version = "20210124-git"; + asds = [ "garbage-pools" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/garbage-pools/2021-01-24/garbage-pools-20210124-git.tgz"; + sha256 = "04jqwr6j138him6wc4nrwjzm4lvyj5j31xqab02nkf8h9hmsf5v1"; + system = "garbage-pools"; + asd = "garbage-pools"; + } + ); + systems = [ "garbage-pools" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + garbage-pools-test = ( + build-asdf-system { + pname = "garbage-pools-test"; + version = "20210124-git"; + asds = [ "garbage-pools-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/garbage-pools/2021-01-24/garbage-pools-20210124-git.tgz"; + sha256 = "04jqwr6j138him6wc4nrwjzm4lvyj5j31xqab02nkf8h9hmsf5v1"; + system = "garbage-pools-test"; + asd = "garbage-pools-test"; + } + ); + systems = [ "garbage-pools-test" ]; + lispLibs = [ + (getAttr "garbage-pools" self) + (getAttr "lift" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + garten = ( + build-asdf-system { + pname = "garten"; + version = "20211020-git"; + asds = [ "garten" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/colliflower/2021-10-20/colliflower-20211020-git.tgz"; + sha256 = "1fzn9s7wm7wmffrdm21lpvry9jb320456cmmprn976a533lp704r"; + system = "garten"; + asd = "garten"; + } + ); + systems = [ "garten" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gcm = ( + build-asdf-system { + pname = "gcm"; + version = "20141217-git"; + asds = [ "gcm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gcm/2014-12-17/gcm-20141217-git.tgz"; + sha256 = "1xnm1cj417d9syb634zi9w90c2191gxjrixa724s4h3hvj70y0ff"; + system = "gcm"; + asd = "gcm"; + } + ); + systems = [ "gcm" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "com_dot_gigamonkeys_dot_json" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geco = ( + build-asdf-system { + pname = "geco"; + version = "20210228-git"; + asds = [ "geco" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/geco/2021-02-28/geco-20210228-git.tgz"; + sha256 = "1ncaf9ab7jz59zmga0p97blsjjb1m6db0qih57wipfhqdb5ylz17"; + system = "geco"; + asd = "geco"; + } + ); + systems = [ "geco" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gendl = ( + build-asdf-system { + pname = "gendl"; + version = "master-fe503896-git"; + asds = [ "gendl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "gendl"; + asd = "gendl"; + } + ); + systems = [ "gendl" ]; + lispLibs = [ + (getAttr "cl-lite" self) + (getAttr "geysr" self) + (getAttr "gwl-graphics" self) + (getAttr "robot" self) + (getAttr "yadd" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gendl-asdf = ( + build-asdf-system { + pname = "gendl-asdf"; + version = "master-fe503896-git"; + asds = [ "gendl-asdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "gendl-asdf"; + asd = "gendl-asdf"; + } + ); + systems = [ "gendl-asdf" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + general-accumulator = ( + build-asdf-system { + pname = "general-accumulator"; + version = "20211209-git"; + asds = [ "general-accumulator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-general-accumulator/2021-12-09/cl-general-accumulator-20211209-git.tgz"; + sha256 = "14ybsk1ahgya67clspacqij1lvs5bzv07rdq60nhgqsbc6s56j9g"; + system = "general-accumulator"; + asd = "general-accumulator"; + } + ); + systems = [ "general-accumulator" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generalized-reference = ( + build-asdf-system { + pname = "generalized-reference"; + version = "20220707-git"; + asds = [ "generalized-reference" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generalized-reference/2022-07-07/generalized-reference-20220707-git.tgz"; + sha256 = "0q1cm52lijn4p6bjzx2yr2kwy729lcj3f6lsanbnbjw56xgp4cpb"; + system = "generalized-reference"; + asd = "generalized-reference"; + } + ); + systems = [ "generalized-reference" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "serapeum" self) + (getAttr "series" self) + (getAttr "split-sequence" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generators = ( + build-asdf-system { + pname = "generators"; + version = "20130615-git"; + asds = [ "generators" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generators/2013-06-15/generators-20130615-git.tgz"; + sha256 = "1y8jlvv5c3av2ww33rwm2kh9sxmhfykhz235b33fbjpdxpx1r9bs"; + system = "generators"; + asd = "generators"; + } + ); + systems = [ "generators" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-cont" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl = ( + build-asdf-system { + pname = "generic-cl"; + version = "20241012-git"; + asds = [ "generic-cl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl"; + asd = "generic-cl"; + } + ); + systems = [ "generic-cl" ]; + lispLibs = [ + (getAttr "agutil" self) + (getAttr "generic-cl_dot_arithmetic" self) + (getAttr "generic-cl_dot_collector" self) + (getAttr "generic-cl_dot_comparison" self) + (getAttr "generic-cl_dot_container" self) + (getAttr "generic-cl_dot_iterator" self) + (getAttr "generic-cl_dot_lazy-seq" self) + (getAttr "generic-cl_dot_map" self) + (getAttr "generic-cl_dot_math" self) + (getAttr "generic-cl_dot_object" self) + (getAttr "generic-cl_dot_sequence" self) + (getAttr "generic-cl_dot_set" self) + ]; + meta = { }; + } + ); + generic-cl_dot_arithmetic = ( + build-asdf-system { + pname = "generic-cl.arithmetic"; + version = "20241012-git"; + asds = [ "generic-cl.arithmetic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.arithmetic"; + asd = "generic-cl.arithmetic"; + } + ); + systems = [ "generic-cl.arithmetic" ]; + lispLibs = [ + (getAttr "generic-cl_dot_comparison" self) + (getAttr "generic-cl_dot_internal" self) + (getAttr "static-dispatch" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl_dot_collector = ( + build-asdf-system { + pname = "generic-cl.collector"; + version = "20241012-git"; + asds = [ "generic-cl.collector" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.collector"; + asd = "generic-cl.collector"; + } + ); + systems = [ "generic-cl.collector" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "arrows" self) + (getAttr "generic-cl_dot_iterator" self) + (getAttr "generic-cl_dot_object" self) + (getAttr "static-dispatch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl_dot_comparison = ( + build-asdf-system { + pname = "generic-cl.comparison"; + version = "20241012-git"; + asds = [ "generic-cl.comparison" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.comparison"; + asd = "generic-cl.comparison"; + } + ); + systems = [ "generic-cl.comparison" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "generic-cl_dot_internal" self) + (getAttr "static-dispatch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl_dot_container = ( + build-asdf-system { + pname = "generic-cl.container"; + version = "20241012-git"; + asds = [ "generic-cl.container" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.container"; + asd = "generic-cl.container"; + } + ); + systems = [ "generic-cl.container" ]; + lispLibs = [ + (getAttr "generic-cl_dot_object" self) + (getAttr "static-dispatch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl_dot_internal = ( + build-asdf-system { + pname = "generic-cl.internal"; + version = "20241012-git"; + asds = [ "generic-cl.internal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.internal"; + asd = "generic-cl.internal"; + } + ); + systems = [ "generic-cl.internal" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-form-types" self) + (getAttr "static-dispatch" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl_dot_iterator = ( + build-asdf-system { + pname = "generic-cl.iterator"; + version = "20241012-git"; + asds = [ "generic-cl.iterator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.iterator"; + asd = "generic-cl.iterator"; + } + ); + systems = [ "generic-cl.iterator" ]; + lispLibs = [ + (getAttr "agutil" self) + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "arrows" self) + (getAttr "cl-form-types" self) + (getAttr "generic-cl_dot_container" self) + (getAttr "generic-cl_dot_internal" self) + (getAttr "generic-cl_dot_object" self) + (getAttr "parse-declarations-1_dot_0" self) + (getAttr "static-dispatch" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl_dot_lazy-seq = ( + build-asdf-system { + pname = "generic-cl.lazy-seq"; + version = "20241012-git"; + asds = [ "generic-cl.lazy-seq" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.lazy-seq"; + asd = "generic-cl.lazy-seq"; + } + ); + systems = [ "generic-cl.lazy-seq" ]; + lispLibs = [ + (getAttr "agutil" self) + (getAttr "arrows" self) + (getAttr "cl-custom-hash-table" self) + (getAttr "generic-cl_dot_collector" self) + (getAttr "generic-cl_dot_comparison" self) + (getAttr "generic-cl_dot_container" self) + (getAttr "generic-cl_dot_iterator" self) + (getAttr "generic-cl_dot_map" self) + (getAttr "generic-cl_dot_object" self) + (getAttr "generic-cl_dot_sequence" self) + (getAttr "static-dispatch" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl_dot_map = ( + build-asdf-system { + pname = "generic-cl.map"; + version = "20241012-git"; + asds = [ "generic-cl.map" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.map"; + asd = "generic-cl.map"; + } + ); + systems = [ "generic-cl.map" ]; + lispLibs = [ + (getAttr "agutil" self) + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "arrows" self) + (getAttr "cl-custom-hash-table" self) + (getAttr "generic-cl_dot_collector" self) + (getAttr "generic-cl_dot_comparison" self) + (getAttr "generic-cl_dot_container" self) + (getAttr "generic-cl_dot_internal" self) + (getAttr "generic-cl_dot_iterator" self) + (getAttr "generic-cl_dot_object" self) + (getAttr "static-dispatch" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl_dot_math = ( + build-asdf-system { + pname = "generic-cl.math"; + version = "20241012-git"; + asds = [ "generic-cl.math" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.math"; + asd = "generic-cl.math"; + } + ); + systems = [ "generic-cl.math" ]; + lispLibs = [ + (getAttr "agutil" self) + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "arrows" self) + (getAttr "generic-cl_dot_arithmetic" self) + (getAttr "static-dispatch" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl_dot_object = ( + build-asdf-system { + pname = "generic-cl.object"; + version = "20241012-git"; + asds = [ "generic-cl.object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.object"; + asd = "generic-cl.object"; + } + ); + systems = [ "generic-cl.object" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "arrows" self) + (getAttr "generic-cl_dot_comparison" self) + (getAttr "static-dispatch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl_dot_sequence = ( + build-asdf-system { + pname = "generic-cl.sequence"; + version = "20241012-git"; + asds = [ "generic-cl.sequence" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.sequence"; + asd = "generic-cl.sequence"; + } + ); + systems = [ "generic-cl.sequence" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "arrows" self) + (getAttr "cl-custom-hash-table" self) + (getAttr "cl-form-types" self) + (getAttr "generic-cl_dot_collector" self) + (getAttr "generic-cl_dot_comparison" self) + (getAttr "generic-cl_dot_container" self) + (getAttr "generic-cl_dot_internal" self) + (getAttr "generic-cl_dot_iterator" self) + (getAttr "generic-cl_dot_map" self) + (getAttr "generic-cl_dot_object" self) + (getAttr "static-dispatch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl_dot_set = ( + build-asdf-system { + pname = "generic-cl.set"; + version = "20241012-git"; + asds = [ "generic-cl.set" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.set"; + asd = "generic-cl.set"; + } + ); + systems = [ "generic-cl.set" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "generic-cl_dot_arithmetic" self) + (getAttr "generic-cl_dot_collector" self) + (getAttr "generic-cl_dot_comparison" self) + (getAttr "generic-cl_dot_container" self) + (getAttr "generic-cl_dot_iterator" self) + (getAttr "generic-cl_dot_map" self) + (getAttr "generic-cl_dot_object" self) + (getAttr "generic-cl_dot_sequence" self) + (getAttr "static-dispatch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-cl_dot_util = ( + build-asdf-system { + pname = "generic-cl.util"; + version = "20241012-git"; + asds = [ "generic-cl.util" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-cl/2024-10-12/generic-cl-20241012-git.tgz"; + sha256 = "14qlfzfd8gvvbhl766801g9258z1dirmszzp1wrf24wj9yf4m0f4"; + system = "generic-cl.util"; + asd = "generic-cl.util"; + } + ); + systems = [ "generic-cl.util" ]; + lispLibs = [ (getAttr "generic-cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-comparability = ( + build-asdf-system { + pname = "generic-comparability"; + version = "20180131-git"; + asds = [ "generic-comparability" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-comparability/2018-01-31/generic-comparability-20180131-git.tgz"; + sha256 = "01ma0cwirxarwwmdwflnh8kmysmr2smh5kyvzhb2074ljxg8yq2p"; + system = "generic-comparability"; + asd = "generic-comparability"; + } + ); + systems = [ "generic-comparability" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-comparability-test = ( + build-asdf-system { + pname = "generic-comparability-test"; + version = "20180131-git"; + asds = [ "generic-comparability-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-comparability/2018-01-31/generic-comparability-20180131-git.tgz"; + sha256 = "01ma0cwirxarwwmdwflnh8kmysmr2smh5kyvzhb2074ljxg8yq2p"; + system = "generic-comparability-test"; + asd = "generic-comparability"; + } + ); + systems = [ "generic-comparability-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "fiveam" self) + (getAttr "generic-comparability" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-sequences = ( + build-asdf-system { + pname = "generic-sequences"; + version = "20150709-git"; + asds = [ "generic-sequences" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-sequences/2015-07-09/generic-sequences-20150709-git.tgz"; + sha256 = "09kr0x4kx634rhslal6z2isnbs7v8rn5ic3pvxa3w1mm37lxx7h3"; + system = "generic-sequences"; + asd = "generic-sequences"; + } + ); + systems = [ "generic-sequences" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-sequences-cont = ( + build-asdf-system { + pname = "generic-sequences-cont"; + version = "20150709-git"; + asds = [ "generic-sequences-cont" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-sequences/2015-07-09/generic-sequences-20150709-git.tgz"; + sha256 = "09kr0x4kx634rhslal6z2isnbs7v8rn5ic3pvxa3w1mm37lxx7h3"; + system = "generic-sequences-cont"; + asd = "generic-sequences-cont"; + } + ); + systems = [ "generic-sequences-cont" ]; + lispLibs = [ + (getAttr "cl-cont" self) + (getAttr "generic-sequences" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-sequences-iterate = ( + build-asdf-system { + pname = "generic-sequences-iterate"; + version = "20150709-git"; + asds = [ "generic-sequences-iterate" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-sequences/2015-07-09/generic-sequences-20150709-git.tgz"; + sha256 = "09kr0x4kx634rhslal6z2isnbs7v8rn5ic3pvxa3w1mm37lxx7h3"; + system = "generic-sequences-iterate"; + asd = "generic-sequences-iterate"; + } + ); + systems = [ "generic-sequences-iterate" ]; + lispLibs = [ + (getAttr "generic-sequences" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-sequences-stream = ( + build-asdf-system { + pname = "generic-sequences-stream"; + version = "20150709-git"; + asds = [ "generic-sequences-stream" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-sequences/2015-07-09/generic-sequences-20150709-git.tgz"; + sha256 = "09kr0x4kx634rhslal6z2isnbs7v8rn5ic3pvxa3w1mm37lxx7h3"; + system = "generic-sequences-stream"; + asd = "generic-sequences-stream"; + } + ); + systems = [ "generic-sequences-stream" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "generic-sequences" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + generic-sequences-test = ( + build-asdf-system { + pname = "generic-sequences-test"; + version = "20150709-git"; + asds = [ "generic-sequences-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/generic-sequences/2015-07-09/generic-sequences-20150709-git.tgz"; + sha256 = "09kr0x4kx634rhslal6z2isnbs7v8rn5ic3pvxa3w1mm37lxx7h3"; + system = "generic-sequences-test"; + asd = "generic-sequences-test"; + } + ); + systems = [ "generic-sequences-test" ]; + lispLibs = [ + (getAttr "generic-sequences" self) + (getAttr "generic-sequences-cont" self) + (getAttr "generic-sequences-iterate" self) + (getAttr "generic-sequences-stream" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geneva = ( + build-asdf-system { + pname = "geneva"; + version = "20161204-git"; + asds = [ "geneva" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; + sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; + system = "geneva"; + asd = "geneva"; + } + ); + systems = [ "geneva" ]; + lispLibs = [ + (getAttr "named-readtables" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geneva-cl = ( + build-asdf-system { + pname = "geneva-cl"; + version = "20161204-git"; + asds = [ "geneva-cl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; + sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; + system = "geneva-cl"; + asd = "geneva-cl"; + } + ); + systems = [ "geneva-cl" ]; + lispLibs = [ + (getAttr "geneva" self) + (getAttr "geneva-mk2" self) + (getAttr "named-readtables" self) + (getAttr "split-sequence" self) + (getAttr "trivial-documentation" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geneva-html = ( + build-asdf-system { + pname = "geneva-html"; + version = "20161204-git"; + asds = [ "geneva-html" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; + sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; + system = "geneva-html"; + asd = "geneva-html"; + } + ); + systems = [ "geneva-html" ]; + lispLibs = [ + (getAttr "file-types" self) + (getAttr "geneva" self) + (getAttr "macro-html" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geneva-latex = ( + build-asdf-system { + pname = "geneva-latex"; + version = "20161204-git"; + asds = [ "geneva-latex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; + sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; + system = "geneva-latex"; + asd = "geneva-latex"; + } + ); + systems = [ "geneva-latex" ]; + lispLibs = [ + (getAttr "geneva" self) + (getAttr "geneva-tex" self) + (getAttr "named-readtables" self) + (getAttr "texp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geneva-mk2 = ( + build-asdf-system { + pname = "geneva-mk2"; + version = "20161204-git"; + asds = [ "geneva-mk2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; + sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; + system = "geneva-mk2"; + asd = "geneva-mk2"; + } + ); + systems = [ "geneva-mk2" ]; + lispLibs = [ + (getAttr "geneva" self) + (getAttr "maxpc" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geneva-plain-text = ( + build-asdf-system { + pname = "geneva-plain-text"; + version = "20161204-git"; + asds = [ "geneva-plain-text" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; + sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; + system = "geneva-plain-text"; + asd = "geneva-plain-text"; + } + ); + systems = [ "geneva-plain-text" ]; + lispLibs = [ + (getAttr "geneva" self) + (getAttr "geneva-mk2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geneva-tex = ( + build-asdf-system { + pname = "geneva-tex"; + version = "20161204-git"; + asds = [ "geneva-tex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; + sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; + system = "geneva-tex"; + asd = "geneva-tex"; + } + ); + systems = [ "geneva-tex" ]; + lispLibs = [ + (getAttr "file-types" self) + (getAttr "geneva" self) + (getAttr "named-readtables" self) + (getAttr "texp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + genhash = ( + build-asdf-system { + pname = "genhash"; + version = "20181210-git"; + asds = [ "genhash" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/genhash/2018-12-10/genhash-20181210-git.tgz"; + sha256 = "1jnk1fix1zydhy0kn3cvlp6dy0241x7v8ahq001nlr6v152z1cwk"; + system = "genhash"; + asd = "genhash"; + } + ); + systems = [ "genhash" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geodesic = ( + build-asdf-system { + pname = "geodesic"; + version = "20230618-git"; + asds = [ "geodesic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/geodesic/2023-06-18/geodesic-20230618-git.tgz"; + sha256 = "13hvkf6r1y1yx0zqgkl8yg1fskfp7vpa9p34ar00s4ly432vbpxq"; + system = "geodesic"; + asd = "geodesic"; + } + ); + systems = [ "geodesic" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geom-base = ( + build-asdf-system { + pname = "geom-base"; + version = "master-fe503896-git"; + asds = [ "geom-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "geom-base"; + asd = "geom-base"; + } + ); + systems = [ "geom-base" ]; + lispLibs = [ + (getAttr "base" self) + (getAttr "cl-pdf" self) + (getAttr "cl-typesetting" self) + (getAttr "cl-who" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geowkt = ( + build-asdf-system { + pname = "geowkt"; + version = "20200610-git"; + asds = [ "geowkt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/geowkt/2020-06-10/geowkt-20200610-git.tgz"; + sha256 = "02l8cb2k10j7k6fvhk9dpqmkxs6vb5w5nh3159w7drprvjqhfrjw"; + system = "geowkt"; + asd = "geowkt"; + } + ); + systems = [ "geowkt" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geowkt-update = ( + build-asdf-system { + pname = "geowkt-update"; + version = "20200610-git"; + asds = [ "geowkt-update" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/geowkt/2020-06-10/geowkt-20200610-git.tgz"; + sha256 = "02l8cb2k10j7k6fvhk9dpqmkxs6vb5w5nh3159w7drprvjqhfrjw"; + system = "geowkt-update"; + asd = "geowkt-update"; + } + ); + systems = [ "geowkt-update" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "parse-number" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + getopt = ( + build-asdf-system { + pname = "getopt"; + version = "20150923-git"; + asds = [ "getopt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/getopt/2015-09-23/getopt-20150923-git.tgz"; + sha256 = "1liwzghx2swws84xlxnq756gbass0s916a9sq5mjfnlg3scbwcs3"; + system = "getopt"; + asd = "getopt"; + } + ); + systems = [ "getopt" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + getopt-tests = ( + build-asdf-system { + pname = "getopt-tests"; + version = "20150923-git"; + asds = [ "getopt-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/getopt/2015-09-23/getopt-20150923-git.tgz"; + sha256 = "1liwzghx2swws84xlxnq756gbass0s916a9sq5mjfnlg3scbwcs3"; + system = "getopt-tests"; + asd = "getopt"; + } + ); + systems = [ "getopt-tests" ]; + lispLibs = [ + (getAttr "getopt" self) + (getAttr "ptester" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gettext = ( + build-asdf-system { + pname = "gettext"; + version = "20171130-git"; + asds = [ "gettext" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gettext/2017-11-30/gettext-20171130-git.tgz"; + sha256 = "1pzhamgni6k5hi6bbvlb3dm659pcllrrr3vhhn3rpjn238zxg5ar"; + system = "gettext"; + asd = "gettext"; + } + ); + systems = [ "gettext" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "split-sequence" self) + (getAttr "yacc" self) + ]; + meta = { }; + } + ); + gettext-example = ( + build-asdf-system { + pname = "gettext-example"; + version = "20171130-git"; + asds = [ "gettext-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gettext/2017-11-30/gettext-20171130-git.tgz"; + sha256 = "1pzhamgni6k5hi6bbvlb3dm659pcllrrr3vhhn3rpjn238zxg5ar"; + system = "gettext-example"; + asd = "gettext-example"; + } + ); + systems = [ "gettext-example" ]; + lispLibs = [ (getAttr "gettext" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gettext-tests = ( + build-asdf-system { + pname = "gettext-tests"; + version = "20171130-git"; + asds = [ "gettext-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gettext/2017-11-30/gettext-20171130-git.tgz"; + sha256 = "1pzhamgni6k5hi6bbvlb3dm659pcllrrr3vhhn3rpjn238zxg5ar"; + system = "gettext-tests"; + asd = "gettext-tests"; + } + ); + systems = [ "gettext-tests" ]; + lispLibs = [ + (getAttr "gettext" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + geysr = ( + build-asdf-system { + pname = "geysr"; + version = "master-fe503896-git"; + asds = [ "geysr" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "geysr"; + asd = "geysr"; + } + ); + systems = [ "geysr" ]; + lispLibs = [ + (getAttr "gendl-asdf" self) + (getAttr "gwl-graphics" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + git-file-history = ( + build-asdf-system { + pname = "git-file-history"; + version = "20160825-git"; + asds = [ "git-file-history" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/git-file-history/2016-08-25/git-file-history-20160825-git.tgz"; + sha256 = "00kdawcy3mhljv04xpx5n7l2s21qdpbm8i9avjdqbxvfc5j05bq8"; + system = "git-file-history"; + asd = "git-file-history"; + } + ); + systems = [ "git-file-history" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "legit" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + git-file-history-test = ( + build-asdf-system { + pname = "git-file-history-test"; + version = "20160825-git"; + asds = [ "git-file-history-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/git-file-history/2016-08-25/git-file-history-20160825-git.tgz"; + sha256 = "00kdawcy3mhljv04xpx5n7l2s21qdpbm8i9avjdqbxvfc5j05bq8"; + system = "git-file-history-test"; + asd = "git-file-history-test"; + } + ); + systems = [ "git-file-history-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "git-file-history" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + github-api-cl = ( + build-asdf-system { + pname = "github-api-cl"; + version = "20241012-git"; + asds = [ "github-api-cl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/github-api-cl/2024-10-12/github-api-cl-20241012-git.tgz"; + sha256 = "04kvhap041v26axg4pzzymnibzh430yvja8c6dhic27g2639kswh"; + system = "github-api-cl"; + asd = "github-api-cl"; + } + ); + systems = [ "github-api-cl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-base64" self) + (getAttr "clack" self) + (getAttr "dexador" self) + (getAttr "str" self) + (getAttr "trivial-features" self) + (getAttr "woo" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + github-gist-api-cl = ( + build-asdf-system { + pname = "github-gist-api-cl"; + version = "20241012-git"; + asds = [ "github-gist-api-cl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/github-api-cl/2024-10-12/github-api-cl-20241012-git.tgz"; + sha256 = "04kvhap041v26axg4pzzymnibzh430yvja8c6dhic27g2639kswh"; + system = "github-gist-api-cl"; + asd = "github-gist-api-cl"; + } + ); + systems = [ "github-gist-api-cl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-base64" self) + (getAttr "clack" self) + (getAttr "dexador" self) + (getAttr "github-api-cl" self) + (getAttr "str" self) + (getAttr "trivial-features" self) + (getAttr "woo" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glacier = ( + build-asdf-system { + pname = "glacier"; + version = "20230214-git"; + asds = [ "glacier" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glacier/2023-02-14/glacier-20230214-git.tgz"; + sha256 = "1h66cd3bn3n8yjd922xsvv0r668cm82106nm2k3fnll67apazlwi"; + system = "glacier"; + asd = "glacier"; + } + ); + systems = [ "glacier" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "dexador" self) + (getAttr "simple-config" self) + (getAttr "str" self) + (getAttr "tooter" self) + (getAttr "websocket-driver" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glad-blob = ( + build-asdf-system { + pname = "glad-blob"; + version = "stable-git"; + asds = [ "glad-blob" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glad-blob/2020-10-16/glad-blob-stable-git.tgz"; + sha256 = "19vp7nyf4kxhczi8i2w47lvipk1i4psrxlpk4nvbdh97vc12k5a7"; + system = "glad-blob"; + asd = "glad-blob"; + } + ); + systems = [ "glad-blob" ]; + lispLibs = [ + (getAttr "bodge-blobs-support" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glass = ( + build-asdf-system { + pname = "glass"; + version = "20150709-git"; + asds = [ "glass" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glass/2015-07-09/glass-20150709-git.tgz"; + sha256 = "1xwr6mj25m0z1qhp30hafbbhrfj34dfidy320x5m3lij13vbyb1p"; + system = "glass"; + asd = "glass"; + } + ); + systems = [ "glass" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glaw = ( + build-asdf-system { + pname = "glaw"; + version = "20180228-git"; + asds = [ "glaw" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glaw/2018-02-28/glaw-20180228-git.tgz"; + sha256 = "06i9g80hkqgwk5h306wkdpcpv7n229n1ig1hy6697l35v8c4mzmp"; + system = "glaw"; + asd = "glaw"; + } + ); + systems = [ "glaw" ]; + lispLibs = [ + (getAttr "cl-alc" self) + (getAttr "cl-openal" self) + (getAttr "cl-opengl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glaw-examples = ( + build-asdf-system { + pname = "glaw-examples"; + version = "20180228-git"; + asds = [ "glaw-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glaw/2018-02-28/glaw-20180228-git.tgz"; + sha256 = "06i9g80hkqgwk5h306wkdpcpv7n229n1ig1hy6697l35v8c4mzmp"; + system = "glaw-examples"; + asd = "glaw-examples"; + } + ); + systems = [ "glaw-examples" ]; + lispLibs = [ + (getAttr "glaw" self) + (getAttr "glaw-imago" self) + (getAttr "glop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glaw-imago = ( + build-asdf-system { + pname = "glaw-imago"; + version = "20180228-git"; + asds = [ "glaw-imago" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glaw/2018-02-28/glaw-20180228-git.tgz"; + sha256 = "06i9g80hkqgwk5h306wkdpcpv7n229n1ig1hy6697l35v8c4mzmp"; + system = "glaw-imago"; + asd = "glaw-imago"; + } + ); + systems = [ "glaw-imago" ]; + lispLibs = [ + (getAttr "glaw" self) + (getAttr "imago" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glaw-sdl = ( + build-asdf-system { + pname = "glaw-sdl"; + version = "20180228-git"; + asds = [ "glaw-sdl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glaw/2018-02-28/glaw-20180228-git.tgz"; + sha256 = "06i9g80hkqgwk5h306wkdpcpv7n229n1ig1hy6697l35v8c4mzmp"; + system = "glaw-sdl"; + asd = "glaw-sdl"; + } + ); + systems = [ "glaw-sdl" ]; + lispLibs = [ + (getAttr "glaw" self) + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-image" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glfw = ( + build-asdf-system { + pname = "glfw"; + version = "20241012-git"; + asds = [ "glfw" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glfw/2024-10-12/glfw-20241012-git.tgz"; + sha256 = "1n421gvrzs76v57icy0c4zhz84ymin91vbv5gkkj4i00cnggwdxv"; + system = "glfw"; + asd = "glfw"; + } + ); + systems = [ "glfw" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-opengl" self) + (getAttr "documentation-utils" self) + (getAttr "float-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glfw-blob = ( + build-asdf-system { + pname = "glfw-blob"; + version = "stable-git"; + asds = [ "glfw-blob" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glfw-blob/2020-10-16/glfw-blob-stable-git.tgz"; + sha256 = "0j953vqsyswipgyhc39swsgwgaqb53wvs80izraknlsp379hzabs"; + system = "glfw-blob"; + asd = "glfw-blob"; + } + ); + systems = [ "glfw-blob" ]; + lispLibs = [ + (getAttr "bodge-blobs-support" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glhelp = ( + build-asdf-system { + pname = "glhelp"; + version = "20200427-git"; + asds = [ "glhelp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "glhelp"; + asd = "glhelp"; + } + ); + systems = [ "glhelp" ]; + lispLibs = [ + (getAttr "cl-opengl" self) + (getAttr "deflazy" self) + (getAttr "glsl-toolkit" self) + (getAttr "split-sequence" self) + (getAttr "uncommon-lisp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glisp = ( + build-asdf-system { + pname = "glisp"; + version = "master-fe503896-git"; + asds = [ "glisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "glisp"; + asd = "glisp"; + } + ); + systems = [ "glisp" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "base" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-base64" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glisph = ( + build-asdf-system { + pname = "glisph"; + version = "20170403-git"; + asds = [ "glisph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glisph/2017-04-03/glisph-20170403-git.tgz"; + sha256 = "097d6kjk4rndpqn181k9nyr2bps4gf3shq5x2fy1swvks3pvys91"; + system = "glisph"; + asd = "glisph"; + } + ); + systems = [ "glisph" ]; + lispLibs = [ + (getAttr "cl-annot" self) + (getAttr "cl-glu" self) + (getAttr "cl-opengl" self) + (getAttr "cl-reexport" self) + (getAttr "zpb-ttf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glisph-test = ( + build-asdf-system { + pname = "glisph-test"; + version = "20170403-git"; + asds = [ "glisph-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glisph/2017-04-03/glisph-20170403-git.tgz"; + sha256 = "097d6kjk4rndpqn181k9nyr2bps4gf3shq5x2fy1swvks3pvys91"; + system = "glisph-test"; + asd = "glisph-test"; + } + ); + systems = [ "glisph-test" ]; + lispLibs = [ + (getAttr "cl-glut" self) + (getAttr "glisph" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glkit = ( + build-asdf-system { + pname = "glkit"; + version = "20201016-git"; + asds = [ "glkit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glkit/2020-10-16/glkit-20201016-git.tgz"; + sha256 = "1x3y5jcr1f0v9sgn3y5b7b8fhgd6vv37nz73016gdwh511idi8jn"; + system = "glkit"; + asd = "glkit"; + } + ); + systems = [ "glkit" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-opengl" self) + (getAttr "defpackage-plus" self) + (getAttr "mathkit" self) + (getAttr "static-vectors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glkit-examples = ( + build-asdf-system { + pname = "glkit-examples"; + version = "20201016-git"; + asds = [ "glkit-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glkit/2020-10-16/glkit-20201016-git.tgz"; + sha256 = "1x3y5jcr1f0v9sgn3y5b7b8fhgd6vv37nz73016gdwh511idi8jn"; + system = "glkit-examples"; + asd = "glkit-examples"; + } + ); + systems = [ "glkit-examples" ]; + lispLibs = [ + (getAttr "glkit" self) + (getAttr "sdl2kit-examples" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + global-vars = ( + build-asdf-system { + pname = "global-vars"; + version = "20141106-git"; + asds = [ "global-vars" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/global-vars/2014-11-06/global-vars-20141106-git.tgz"; + sha256 = "06m3xc8l3pgsapl8fvsi9wf6y46zs75cp9zn7zh6dc65v4s5wz3d"; + system = "global-vars"; + asd = "global-vars"; + } + ); + systems = [ "global-vars" ]; + lispLibs = [ ]; + meta = { }; + } + ); + global-vars-test = ( + build-asdf-system { + pname = "global-vars-test"; + version = "20141106-git"; + asds = [ "global-vars-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/global-vars/2014-11-06/global-vars-20141106-git.tgz"; + sha256 = "06m3xc8l3pgsapl8fvsi9wf6y46zs75cp9zn7zh6dc65v4s5wz3d"; + system = "global-vars-test"; + asd = "global-vars-test"; + } + ); + systems = [ "global-vars-test" ]; + lispLibs = [ (getAttr "global-vars" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glop = ( + build-asdf-system { + pname = "glop"; + version = "20171019-git"; + asds = [ "glop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glop/2017-10-19/glop-20171019-git.tgz"; + sha256 = "1nm35kvigflfjlmsa8zwdajc61f02fh4sq08jv0wnqylhx8yg2bv"; + system = "glop"; + asd = "glop"; + } + ); + systems = [ "glop" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "split-sequence" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glop-test = ( + build-asdf-system { + pname = "glop-test"; + version = "20171019-git"; + asds = [ "glop-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glop/2017-10-19/glop-20171019-git.tgz"; + sha256 = "1nm35kvigflfjlmsa8zwdajc61f02fh4sq08jv0wnqylhx8yg2bv"; + system = "glop-test"; + asd = "glop-test"; + } + ); + systems = [ "glop-test" ]; + lispLibs = [ + (getAttr "cl-glu" self) + (getAttr "cl-opengl" self) + (getAttr "glop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glsl-docs = ( + build-asdf-system { + pname = "glsl-docs"; + version = "release-quicklisp-f04476f7-git"; + asds = [ "glsl-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glsl-spec/2019-10-07/glsl-spec-release-quicklisp-f04476f7-git.tgz"; + sha256 = "01ipspr22fgfj3w8wq2y81lzrjc4vpfiwnr3dqhjlpzzra46am8c"; + system = "glsl-docs"; + asd = "glsl-docs"; + } + ); + systems = [ "glsl-docs" ]; + lispLibs = [ (getAttr "glsl-symbols" self) ]; + meta = { }; + } + ); + glsl-packing = ( + build-asdf-system { + pname = "glsl-packing"; + version = "20180131-git"; + asds = [ "glsl-packing" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glsl-packing/2018-01-31/glsl-packing-20180131-git.tgz"; + sha256 = "0k2f1771wd9kdrcasldy1r00k5bdgi9fd07in52zmjggc0i7dd80"; + system = "glsl-packing"; + asd = "glsl-packing"; + } + ); + systems = [ "glsl-packing" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glsl-spec = ( + build-asdf-system { + pname = "glsl-spec"; + version = "release-quicklisp-f04476f7-git"; + asds = [ "glsl-spec" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glsl-spec/2019-10-07/glsl-spec-release-quicklisp-f04476f7-git.tgz"; + sha256 = "01ipspr22fgfj3w8wq2y81lzrjc4vpfiwnr3dqhjlpzzra46am8c"; + system = "glsl-spec"; + asd = "glsl-spec"; + } + ); + systems = [ "glsl-spec" ]; + lispLibs = [ ]; + meta = { }; + } + ); + glsl-symbols = ( + build-asdf-system { + pname = "glsl-symbols"; + version = "release-quicklisp-f04476f7-git"; + asds = [ "glsl-symbols" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glsl-spec/2019-10-07/glsl-spec-release-quicklisp-f04476f7-git.tgz"; + sha256 = "01ipspr22fgfj3w8wq2y81lzrjc4vpfiwnr3dqhjlpzzra46am8c"; + system = "glsl-symbols"; + asd = "glsl-symbols"; + } + ); + systems = [ "glsl-symbols" ]; + lispLibs = [ ]; + meta = { }; + } + ); + glsl-toolkit = ( + build-asdf-system { + pname = "glsl-toolkit"; + version = "20241012-git"; + asds = [ "glsl-toolkit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glsl-toolkit/2024-10-12/glsl-toolkit-20241012-git.tgz"; + sha256 = "0yh6y2k2v5ivzwfnvnprlcih8jn7fv3pzz2wn85fpvbfw4mg120x"; + system = "glsl-toolkit"; + asd = "glsl-toolkit"; + } + ); + systems = [ "glsl-toolkit" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "documentation-utils" self) + (getAttr "parse-float" self) + (getAttr "trivial-indent" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glu-tessellate = ( + build-asdf-system { + pname = "glu-tessellate"; + version = "20150608-git"; + asds = [ "glu-tessellate" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glu-tessellate/2015-06-08/glu-tessellate-20150608-git.tgz"; + sha256 = "1iwnvk341pidxdsjb2c730k6a7nr1knd5ir0v83y6jhsf78r9krh"; + system = "glu-tessellate"; + asd = "glu-tessellate"; + } + ); + systems = [ "glu-tessellate" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glyphs = ( + build-asdf-system { + pname = "glyphs"; + version = "20180711-git"; + asds = [ "glyphs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glyphs/2018-07-11/glyphs-20180711-git.tgz"; + sha256 = "17kai1anbkk5dj5sbrsin2fc019cmcbglb900db60v38myj0y0wf"; + system = "glyphs"; + asd = "glyphs"; + } + ); + systems = [ "glyphs" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "named-readtables" self) + (getAttr "parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + glyphs-test = ( + build-asdf-system { + pname = "glyphs-test"; + version = "20180711-git"; + asds = [ "glyphs-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/glyphs/2018-07-11/glyphs-20180711-git.tgz"; + sha256 = "17kai1anbkk5dj5sbrsin2fc019cmcbglb900db60v38myj0y0wf"; + system = "glyphs-test"; + asd = "glyphs-test"; + } + ); + systems = [ "glyphs-test" ]; + lispLibs = [ + (getAttr "glyphs" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + golden-utils = ( + build-asdf-system { + pname = "golden-utils"; + version = "20241012-git"; + asds = [ "golden-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/golden-utils/2024-10-12/golden-utils-20241012-git.tgz"; + sha256 = "09vq29wjr3x7h3fshwxg8h1psy4p73yl61cjljarpqjhsgz7lmbp"; + system = "golden-utils"; + asd = "golden-utils"; + } + ); + systems = [ "golden-utils" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gooptest = ( + build-asdf-system { + pname = "gooptest"; + version = "20200925-git"; + asds = [ "gooptest" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gooptest/2020-09-25/gooptest-20200925-git.tgz"; + sha256 = "1g9q4frlc79xkmz74ybs954rc5kmfwjsn4xi64aig1fh5wjni5xs"; + system = "gooptest"; + asd = "gooptest"; + } + ); + systems = [ "gooptest" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "cl-autowrap" self) + (getAttr "cl-plus-c" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + graph = ( + build-asdf-system { + pname = "graph"; + version = "20220331-git"; + asds = [ "graph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/graph/2022-03-31/graph-20220331-git.tgz"; + sha256 = "0m76vb0mk7rlbv9xhnix001gxik9f7vy9lspradcvzbk1rfxyyf7"; + system = "graph"; + asd = "graph"; + } + ); + systems = [ "graph" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "asdf-package-system" self) + (getAttr "curry-compose-reader-macros" self) + (getAttr "damn-fast-priority-queue" self) + (getAttr "metabang-bind" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + graphs = ( + build-asdf-system { + pname = "graphs"; + version = "master-fe503896-git"; + asds = [ "graphs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "graphs"; + asd = "graphs"; + } + ); + systems = [ "graphs" ]; + lispLibs = [ (getAttr "gwl-graphics" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gravatar = ( + build-asdf-system { + pname = "gravatar"; + version = "20110320-git"; + asds = [ "gravatar" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gravatar/2011-03-20/cl-gravatar-20110320-git.tgz"; + sha256 = "1r9fq1zaywlhpxr3s3wgajhxf1kgwsgsql0a7ccfgsbwkgy2qzfs"; + system = "gravatar"; + asd = "gravatar"; + } + ); + systems = [ "gravatar" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-json" self) + (getAttr "drakma" self) + (getAttr "md5" self) + (getAttr "puri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + graylex = ( + build-asdf-system { + pname = "graylex"; + version = "20110522-git"; + asds = [ "graylex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/graylex/2011-05-22/graylex-20110522-git.tgz"; + sha256 = "0s1mpz6cpx3fywznxc8kzkhbb4fpmzyjpfgc85lnxqmri8wy6xqy"; + system = "graylex"; + asd = "graylex"; + } + ); + systems = [ "graylex" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + graylex-m4-example = ( + build-asdf-system { + pname = "graylex-m4-example"; + version = "20110522-git"; + asds = [ "graylex-m4-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/graylex/2011-05-22/graylex-20110522-git.tgz"; + sha256 = "0s1mpz6cpx3fywznxc8kzkhbb4fpmzyjpfgc85lnxqmri8wy6xqy"; + system = "graylex-m4-example"; + asd = "graylex-m4-example"; + } + ); + systems = [ "graylex-m4-example" ]; + lispLibs = [ + (getAttr "cl-heredoc" self) + (getAttr "graylex" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + graylog = ( + build-asdf-system { + pname = "graylog"; + version = "20180430-git"; + asds = [ "graylog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-graylog/2018-04-30/cl-graylog-20180430-git.tgz"; + sha256 = "1bj1v6vwz8w78h0bkjv5614gq50jdpjix88rbn3nvh81cfjvsqdg"; + system = "graylog"; + asd = "graylog"; + } + ); + systems = [ "graylog" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-json" self) + (getAttr "local-time" self) + (getAttr "salza2" self) + (getAttr "trivial-backtrace" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + graylog-log5 = ( + build-asdf-system { + pname = "graylog-log5"; + version = "20180430-git"; + asds = [ "graylog-log5" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-graylog/2018-04-30/cl-graylog-20180430-git.tgz"; + sha256 = "1bj1v6vwz8w78h0bkjv5614gq50jdpjix88rbn3nvh81cfjvsqdg"; + system = "graylog-log5"; + asd = "graylog-log5"; + } + ); + systems = [ "graylog-log5" ]; + lispLibs = [ + (getAttr "graylog" self) + (getAttr "log5" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + green-threads = ( + build-asdf-system { + pname = "green-threads"; + version = "20141217-git"; + asds = [ "green-threads" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/green-threads/2014-12-17/green-threads-20141217-git.tgz"; + sha256 = "1czw7nr0dwfps76h8hjvglk1wdh53yqbfbvv30whwbgqx33iippz"; + system = "green-threads"; + asd = "green-threads"; + } + ); + systems = [ "green-threads" ]; + lispLibs = [ + (getAttr "cl-async-future" self) + (getAttr "cl-cont" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + grid-formation = ( + build-asdf-system { + pname = "grid-formation"; + version = "20220707-git"; + asds = [ "grid-formation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/grid-formation/2022-07-07/grid-formation-20220707-git.tgz"; + sha256 = "0s5picmkn7gn98k23axadbc0mlzlrbadi1ln85gpqp17k3cmd54m"; + system = "grid-formation"; + asd = "grid-formation"; + } + ); + systems = [ "grid-formation" ]; + lispLibs = [ + (getAttr "mfiano-utils" self) + (getAttr "origin" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + group-by = ( + build-asdf-system { + pname = "group-by"; + version = "20140211-git"; + asds = [ "group-by" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/group-by/2014-02-11/group-by-20140211-git.tgz"; + sha256 = "1p1qprb57fjd6sj8ws6c7y40ab38mym65wni8xivdy89i3d63dz4"; + system = "group-by"; + asd = "group-by"; + } + ); + systems = [ "group-by" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + group-by-test = ( + build-asdf-system { + pname = "group-by-test"; + version = "20140211-git"; + asds = [ "group-by-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/group-by/2014-02-11/group-by-20140211-git.tgz"; + sha256 = "1p1qprb57fjd6sj8ws6c7y40ab38mym65wni8xivdy89i3d63dz4"; + system = "group-by-test"; + asd = "group-by"; + } + ); + systems = [ "group-by-test" ]; + lispLibs = [ + (getAttr "group-by" self) + (getAttr "lisp-unit2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + groupby = ( + build-asdf-system { + pname = "groupby"; + version = "20170830-git"; + asds = [ "groupby" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-groupby/2017-08-30/cl-groupby-20170830-git.tgz"; + sha256 = "1ra4zi9ifrhxxsj4svg1iqqzzsv9aqqa76pswygp7g084x6kn5km"; + system = "groupby"; + asd = "groupby"; + } + ); + systems = [ "groupby" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + grovel-locally = ( + build-asdf-system { + pname = "grovel-locally"; + version = "20180228-git"; + asds = [ "grovel-locally" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/grovel-locally/2018-02-28/grovel-locally-20180228-git.tgz"; + sha256 = "07q7zjgv3d1f35zwxpzcz020z0gcqi6m2l2szw99bsqk5hn93szl"; + system = "grovel-locally"; + asd = "grovel-locally"; + } + ); + systems = [ "grovel-locally" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-ppcre" self) + (getAttr "with-cached-reader-conditionals" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gsll = ( + build-asdf-system { + pname = "gsll"; + version = "quicklisp-eeeda841-git"; + asds = [ "gsll" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gsll/2018-08-31/gsll-quicklisp-eeeda841-git.tgz"; + sha256 = "0zsjvi1f62hjgfjk4wqg13d4r53bli9nglkwnd31qrygn8pmzlhi"; + system = "gsll"; + asd = "gsll"; + } + ); + systems = [ "gsll" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi-grovel" self) + (getAttr "cffi-libffi" self) + (getAttr "foreign-array" self) + (getAttr "lisp-unit" self) + (getAttr "metabang-bind" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + gt = ( + build-asdf-system { + pname = "gt"; + version = "20241012-git"; + asds = [ "gt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-utils/2024-10-12/cl-utils-20241012-git.tgz"; + sha256 = "133alv8368k9pjkvh3vsfsk50whw7si4i2i7b8z256knpb2d35gh"; + system = "gt"; + asd = "gt"; + } + ); + systems = [ "gt" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "asdf-package-system" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "curry-compose-reader-macros" self) + (getAttr "fset" self) + (getAttr "functional-trees" self) + (getAttr "iterate" self) + (getAttr "misc-extensions" self) + (getAttr "named-readtables" self) + (getAttr "serapeum" self) + (getAttr "split-sequence" self) + (getAttr "trivia" self) + (getAttr "trivia_dot_ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gtirb = ( + build-asdf-system { + pname = "gtirb"; + version = "quicklisp-dd18337d-git"; + asds = [ "gtirb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gtirb/2021-10-20/gtirb-quicklisp-dd18337d-git.tgz"; + sha256 = "0dpchsshnlh3jb9rg1zdf63mr5l33vhjdxgxx2vqg0nh1sh41zn1"; + system = "gtirb"; + asd = "gtirb"; + } + ); + systems = [ "gtirb" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "asdf-package-system" self) + (getAttr "cl-intbytes" self) + (getAttr "cl-interval" self) + (getAttr "curry-compose-reader-macros" self) + (getAttr "graph" self) + (getAttr "named-readtables" self) + (getAttr "proto" self) + (getAttr "protobuf" self) + (getAttr "trivia" self) + (getAttr "trivial-package-local-nicknames" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gtirb-capstone = ( + build-asdf-system { + pname = "gtirb-capstone"; + version = "20231021-git"; + asds = [ "gtirb-capstone" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gtirb-capstone/2023-10-21/gtirb-capstone-20231021-git.tgz"; + sha256 = "1i65iay3pkc0q00inqyykjpv38jj0abz7j7dbsm6bamjvrh8n1v8"; + system = "gtirb-capstone"; + asd = "gtirb-capstone"; + } + ); + systems = [ "gtirb-capstone" ]; + lispLibs = [ + (getAttr "asdf-package-system" self) + (getAttr "capstone" self) + (getAttr "graph" self) + (getAttr "gt" self) + (getAttr "gtirb" self) + (getAttr "keystone" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gtirb-functions = ( + build-asdf-system { + pname = "gtirb-functions"; + version = "20230618-git"; + asds = [ "gtirb-functions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gtirb-functions/2023-06-18/gtirb-functions-20230618-git.tgz"; + sha256 = "19w18vfqrkjrsn4i4i3ppw5q80557pj0844r4zr3pbr0l8ypjcnp"; + system = "gtirb-functions"; + asd = "gtirb-functions"; + } + ); + systems = [ "gtirb-functions" ]; + lispLibs = [ + (getAttr "asdf-package-system" self) + (getAttr "graph" self) + (getAttr "gt" self) + (getAttr "gtirb" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gtk-tagged-streams = ( + build-asdf-system { + pname = "gtk-tagged-streams"; + version = "quicklisp-d1c2b827-git"; + asds = [ "gtk-tagged-streams" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gtk-tagged-streams/2018-02-28/gtk-tagged-streams-quicklisp-d1c2b827-git.tgz"; + sha256 = "0ciw4ydcb8clsqb338hxpzncj2m59i6scnqlgbwkznm5i9dxvkyd"; + system = "gtk-tagged-streams"; + asd = "gtk-tagged-streams"; + } + ); + systems = [ "gtk-tagged-streams" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-cffi-gtk" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gtwiwtg = ( + build-asdf-system { + pname = "gtwiwtg"; + version = "20231021-git"; + asds = [ "gtwiwtg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gtwiwtg/2023-10-21/gtwiwtg-20231021-git.tgz"; + sha256 = "0pp28s2bydqcd850kyk4jjvjky692lqgld9lc9v64lb96ibxzplk"; + system = "gtwiwtg"; + asd = "gtwiwtg"; + } + ); + systems = [ "gtwiwtg" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gtype = ( + build-asdf-system { + pname = "gtype"; + version = "20200610-git"; + asds = [ "gtype" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gtype/2020-06-10/gtype-20200610-git.tgz"; + sha256 = "0hbkfdw00v7bsa6zbric34p5w6hfwxycccg8wc2faq0cxhsvpv9h"; + system = "gtype"; + asd = "gtype"; + } + ); + systems = [ "gtype" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "trivia" self) + (getAttr "trivial-cltl2" self) + (getAttr "trivialib_dot_type-unify" self) + (getAttr "type-r" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gtype_dot_test = ( + build-asdf-system { + pname = "gtype.test"; + version = "20200610-git"; + asds = [ "gtype.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gtype/2020-06-10/gtype-20200610-git.tgz"; + sha256 = "0hbkfdw00v7bsa6zbric34p5w6hfwxycccg8wc2faq0cxhsvpv9h"; + system = "gtype.test"; + asd = "gtype.test"; + } + ); + systems = [ "gtype.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "gtype" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gute = ( + build-asdf-system { + pname = "gute"; + version = "20221106-git"; + asds = [ "gute" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gute/2022-11-06/gute-20221106-git.tgz"; + sha256 = "1d1m4qaygvmkglwdqlnhkvwq0wrig13h97w8ansfkyig359vpzy0"; + system = "gute"; + asd = "gute"; + } + ); + systems = [ "gute" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-mathstats" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-strings" self) + (getAttr "conium" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gwl = ( + build-asdf-system { + pname = "gwl"; + version = "master-fe503896-git"; + asds = [ "gwl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "gwl"; + asd = "gwl"; + } + ); + systems = [ "gwl" ]; + lispLibs = [ + (getAttr "cl-html-parse" self) + (getAttr "cl-markdown" self) + (getAttr "cl-who" self) + (getAttr "glisp" self) + (getAttr "yason" self) + (getAttr "zaserve" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gwl-graphics = ( + build-asdf-system { + pname = "gwl-graphics"; + version = "master-fe503896-git"; + asds = [ "gwl-graphics" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "gwl-graphics"; + asd = "gwl-graphics"; + } + ); + systems = [ "gwl-graphics" ]; + lispLibs = [ + (getAttr "geom-base" self) + (getAttr "gwl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + gzip-stream = ( + build-asdf-system { + pname = "gzip-stream"; + version = "0.2.8"; + asds = [ "gzip-stream" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gzip-stream/2010-10-06/gzip-stream_0.2.8.tgz"; + sha256 = "1m2x685mk9zp8vq45r4gf6mlbzmzr79mvdxibw1fqzv7r1bqrwrs"; + system = "gzip-stream"; + asd = "gzip-stream"; + } + ); + systems = [ "gzip-stream" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "salza2" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hamcrest = ( + build-asdf-system { + pname = "hamcrest"; + version = "20241012-git"; + asds = [ "hamcrest" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-hamcrest/2024-10-12/cl-hamcrest-20241012-git.tgz"; + sha256 = "05l5i5cmm1yqg8x9ayffaf3a9xf742k02wkxwpkc125ih5x0ggws"; + system = "hamcrest"; + asd = "hamcrest"; + } + ); + systems = [ "hamcrest" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "iterate" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hamcrest-ci = ( + build-asdf-system { + pname = "hamcrest-ci"; + version = "20241012-git"; + asds = [ "hamcrest-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-hamcrest/2024-10-12/cl-hamcrest-20241012-git.tgz"; + sha256 = "05l5i5cmm1yqg8x9ayffaf3a9xf742k02wkxwpkc125ih5x0ggws"; + system = "hamcrest-ci"; + asd = "hamcrest-ci"; + } + ); + systems = [ "hamcrest-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hamcrest-tests = ( + build-asdf-system { + pname = "hamcrest-tests"; + version = "20241012-git"; + asds = [ "hamcrest-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-hamcrest/2024-10-12/cl-hamcrest-20241012-git.tgz"; + sha256 = "05l5i5cmm1yqg8x9ayffaf3a9xf742k02wkxwpkc125ih5x0ggws"; + system = "hamcrest-tests"; + asd = "hamcrest-tests"; + } + ); + systems = [ "hamcrest-tests" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "prove" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + harmony = ( + build-asdf-system { + pname = "harmony"; + version = "20241012-git"; + asds = [ "harmony" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/harmony/2024-10-12/harmony-20241012-git.tgz"; + sha256 = "0bzqwcbnpb529bdp35c4s3p4p6rsrjnsvll2bkkrwpxlwzdd3fim"; + system = "harmony"; + asd = "harmony"; + } + ); + systems = [ "harmony" ]; + lispLibs = [ + (getAttr "atomics" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-mixed" self) + (getAttr "cl-mixed-alsa" self) + (getAttr "cl-mixed-pulse" self) + (getAttr "stealth-mixin" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hash-set = ( + build-asdf-system { + pname = "hash-set"; + version = "20211230-git"; + asds = [ "hash-set" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hash-set/2021-12-30/hash-set-20211230-git.tgz"; + sha256 = "0a966y9yfarhmki4wwzg371ziaygnp13yc6r13w9zz327fkhz8na"; + system = "hash-set"; + asd = "hash-set"; + } + ); + systems = [ "hash-set" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hash-set-tests = ( + build-asdf-system { + pname = "hash-set-tests"; + version = "20211230-git"; + asds = [ "hash-set-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hash-set/2021-12-30/hash-set-20211230-git.tgz"; + sha256 = "0a966y9yfarhmki4wwzg371ziaygnp13yc6r13w9zz327fkhz8na"; + system = "hash-set-tests"; + asd = "hash-set-tests"; + } + ); + systems = [ "hash-set-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "hash-set" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hash-table-ext = ( + build-asdf-system { + pname = "hash-table-ext"; + version = "20211020-git"; + asds = [ "hash-table-ext" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hash-table-ext/2021-10-20/hash-table-ext-20211020-git.tgz"; + sha256 = "00pafnjy5w9yhbzzdvgg4wwb8yicjjshgzxnn0by3d9qknxc7539"; + system = "hash-table-ext"; + asd = "hash-table-ext"; + } + ); + systems = [ "hash-table-ext" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "jingoh_dot_documentizer" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hash-table-ext_dot_test = ( + build-asdf-system { + pname = "hash-table-ext.test"; + version = "20211020-git"; + asds = [ "hash-table-ext.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hash-table-ext/2021-10-20/hash-table-ext-20211020-git.tgz"; + sha256 = "00pafnjy5w9yhbzzdvgg4wwb8yicjjshgzxnn0by3d9qknxc7539"; + system = "hash-table-ext.test"; + asd = "hash-table-ext.test"; + } + ); + systems = [ "hash-table-ext.test" ]; + lispLibs = [ + (getAttr "hash-table-ext" self) + (getAttr "jingoh" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hashtrie = ( + build-asdf-system { + pname = "hashtrie"; + version = "20241012-git"; + asds = [ "hashtrie" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hashtrie/2024-10-12/hashtrie-20241012-git.tgz"; + sha256 = "1qn7azbl2p3hjvrb87bb06d3njsi5ksmdcv4mk80iadq06w0rn0n"; + system = "hashtrie"; + asd = "hashtrie"; + } + ); + systems = [ "hashtrie" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hashtrie-tests = ( + build-asdf-system { + pname = "hashtrie-tests"; + version = "20241012-git"; + asds = [ "hashtrie-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hashtrie/2024-10-12/hashtrie-20241012-git.tgz"; + sha256 = "1qn7azbl2p3hjvrb87bb06d3njsi5ksmdcv4mk80iadq06w0rn0n"; + system = "hashtrie-tests"; + asd = "hashtrie-tests"; + } + ); + systems = [ "hashtrie-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "hashtrie" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hdf5-cffi = ( + build-asdf-system { + pname = "hdf5-cffi"; + version = "20180228-git"; + asds = [ "hdf5-cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hdf5-cffi/2018-02-28/hdf5-cffi-20180228-git.tgz"; + sha256 = "0vda3075423xz83qky998lpac5b04dwfv7bwgh9jq8cs5v0zrxjf"; + system = "hdf5-cffi"; + asd = "hdf5-cffi"; + } + ); + systems = [ "hdf5-cffi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hdf5-cffi_dot_examples = ( + build-asdf-system { + pname = "hdf5-cffi.examples"; + version = "20180228-git"; + asds = [ "hdf5-cffi.examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hdf5-cffi/2018-02-28/hdf5-cffi-20180228-git.tgz"; + sha256 = "0vda3075423xz83qky998lpac5b04dwfv7bwgh9jq8cs5v0zrxjf"; + system = "hdf5-cffi.examples"; + asd = "hdf5-cffi.examples"; + } + ); + systems = [ "hdf5-cffi.examples" ]; + lispLibs = [ (getAttr "hdf5-cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hdf5-cffi_dot_test = ( + build-asdf-system { + pname = "hdf5-cffi.test"; + version = "20180228-git"; + asds = [ "hdf5-cffi.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hdf5-cffi/2018-02-28/hdf5-cffi-20180228-git.tgz"; + sha256 = "0vda3075423xz83qky998lpac5b04dwfv7bwgh9jq8cs5v0zrxjf"; + system = "hdf5-cffi.test"; + asd = "hdf5-cffi.test"; + } + ); + systems = [ "hdf5-cffi.test" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "fiveam" self) + (getAttr "hdf5-cffi" self) + (getAttr "hdf5-cffi_dot_examples" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + heap = ( + build-asdf-system { + pname = "heap"; + version = "20181018-git"; + asds = [ "heap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/heap/2018-10-18/heap-20181018-git.tgz"; + sha256 = "0jkgazjnjip7y41zd8rpy89ymh75yimk1q24qbddcisq5rzdl52k"; + system = "heap"; + asd = "heap"; + } + ); + systems = [ "heap" ]; + lispLibs = [ ]; + meta = { }; + } + ); + helambdap = ( + build-asdf-system { + pname = "helambdap"; + version = "20241012-git"; + asds = [ "helambdap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/helambdap/2024-10-12/helambdap-20241012-git.tgz"; + sha256 = "0z7hnphjxfr5z5h9gp5940pbbh163w3nnis2fan2wrrh0l88scn3"; + system = "helambdap"; + asd = "helambdap"; + } + ); + systems = [ "helambdap" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "clad" self) + (getAttr "split-sequence" self) + (getAttr "xhtmlambda" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hello-builder = ( + build-asdf-system { + pname = "hello-builder"; + version = "20241012-git"; + asds = [ "hello-builder" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clog/2024-10-12/clog-20241012-git.tgz"; + sha256 = "0hqpj9ji7kfqgcxdfnc7x202qzmb7zdkmjwcyhdllqs6b0ssw5lx"; + system = "hello-builder"; + asd = "hello-builder"; + } + ); + systems = [ "hello-builder" ]; + lispLibs = [ (getAttr "clog" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hello-clog = ( + build-asdf-system { + pname = "hello-clog"; + version = "20241012-git"; + asds = [ "hello-clog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clog/2024-10-12/clog-20241012-git.tgz"; + sha256 = "0hqpj9ji7kfqgcxdfnc7x202qzmb7zdkmjwcyhdllqs6b0ssw5lx"; + system = "hello-clog"; + asd = "hello-clog"; + } + ); + systems = [ "hello-clog" ]; + lispLibs = [ (getAttr "clog" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hemlock_dot_base = ( + build-asdf-system { + pname = "hemlock.base"; + version = "20231021-git"; + asds = [ "hemlock.base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hemlock/2023-10-21/hemlock-20231021-git.tgz"; + sha256 = "0c1lmznz1md7r9jbyg2n22h1svw8pvqjxyp7mvxgvqp34mmbf5ad"; + system = "hemlock.base"; + asd = "hemlock.base"; + } + ); + systems = [ "hemlock.base" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "command-line-arguments" self) + (getAttr "conium" self) + (getAttr "iolib" self) + (getAttr "iterate" self) + (getAttr "osicat" self) + (getAttr "prepl" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hemlock_dot_clx = ( + build-asdf-system { + pname = "hemlock.clx"; + version = "20231021-git"; + asds = [ "hemlock.clx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hemlock/2023-10-21/hemlock-20231021-git.tgz"; + sha256 = "0c1lmznz1md7r9jbyg2n22h1svw8pvqjxyp7mvxgvqp34mmbf5ad"; + system = "hemlock.clx"; + asd = "hemlock.clx"; + } + ); + systems = [ "hemlock.clx" ]; + lispLibs = [ + (getAttr "clx" self) + (getAttr "hemlock_dot_base" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hemlock_dot_tty = ( + build-asdf-system { + pname = "hemlock.tty"; + version = "20231021-git"; + asds = [ "hemlock.tty" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hemlock/2023-10-21/hemlock-20231021-git.tgz"; + sha256 = "0c1lmznz1md7r9jbyg2n22h1svw8pvqjxyp7mvxgvqp34mmbf5ad"; + system = "hemlock.tty"; + asd = "hemlock.tty"; + } + ); + systems = [ "hemlock.tty" ]; + lispLibs = [ (getAttr "hemlock_dot_base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hermetic = ( + build-asdf-system { + pname = "hermetic"; + version = "20191007-git"; + asds = [ "hermetic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hermetic/2019-10-07/hermetic-20191007-git.tgz"; + sha256 = "1sndxkkj45sqr13xw9kvnhj25an96q4la70ni3w468yrcbf782pi"; + system = "hermetic"; + asd = "hermetic"; + } + ); + systems = [ "hermetic" ]; + lispLibs = [ + (getAttr "cl-pass" self) + (getAttr "clack" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + herodotus = ( + build-asdf-system { + pname = "herodotus"; + version = "20220331-git"; + asds = [ "herodotus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/herodotus/2022-03-31/herodotus-20220331-git.tgz"; + sha256 = "085r6b8fydac2a939r80vlavs1ij5ij5li5xnl5q8qvn9dl4rr5k"; + system = "herodotus"; + asd = "herodotus"; + } + ); + systems = [ "herodotus" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hh-aws = ( + build-asdf-system { + pname = "hh-aws"; + version = "20150804-git"; + asds = [ "hh-aws" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hh-aws/2015-08-04/hh-aws-20150804-git.tgz"; + sha256 = "02kfq7krn8788iphzcxnf0da88sy30gxpj1acgy9fl2n8qc03qdp"; + system = "hh-aws"; + asd = "hh-aws"; + } + ); + systems = [ "hh-aws" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "drakma" self) + (getAttr "ironclad" self) + (getAttr "puri" self) + (getAttr "s-xml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hh-aws-tests = ( + build-asdf-system { + pname = "hh-aws-tests"; + version = "20150804-git"; + asds = [ "hh-aws-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hh-aws/2015-08-04/hh-aws-20150804-git.tgz"; + sha256 = "02kfq7krn8788iphzcxnf0da88sy30gxpj1acgy9fl2n8qc03qdp"; + system = "hh-aws-tests"; + asd = "hh-aws"; + } + ); + systems = [ "hh-aws-tests" ]; + lispLibs = [ + (getAttr "hh-aws" self) + (getAttr "lisp-unit" self) + (getAttr "uuid" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hh-redblack = ( + build-asdf-system { + pname = "hh-redblack"; + version = "20151031-git"; + asds = [ "hh-redblack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hh-redblack/2015-10-31/hh-redblack-20151031-git.tgz"; + sha256 = "1klr78m4g60c82dnxksb7710jjj35rnfl4gl3dx3nrx0nb04bam6"; + system = "hh-redblack"; + asd = "hh-redblack"; + } + ); + systems = [ "hh-redblack" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hh-redblack-tests = ( + build-asdf-system { + pname = "hh-redblack-tests"; + version = "20151031-git"; + asds = [ "hh-redblack-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hh-redblack/2015-10-31/hh-redblack-20151031-git.tgz"; + sha256 = "1klr78m4g60c82dnxksb7710jjj35rnfl4gl3dx3nrx0nb04bam6"; + system = "hh-redblack-tests"; + asd = "hh-redblack"; + } + ); + systems = [ "hh-redblack-tests" ]; + lispLibs = [ + (getAttr "hh-redblack" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hh-web = ( + build-asdf-system { + pname = "hh-web"; + version = "20141106-git"; + asds = [ "hh-web" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hh-web/2014-11-06/hh-web-20141106-git.tgz"; + sha256 = "1i3jyifayczm9b7rvw3fafiisxvjq87xd9z0hdf957qc2albsq87"; + system = "hh-web"; + asd = "hh-web"; + } + ); + systems = [ "hh-web" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-base64" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "hunchentoot" self) + (getAttr "ironclad" self) + (getAttr "local-time" self) + (getAttr "log5" self) + (getAttr "parenscript" self) + (getAttr "trivial-backtrace" self) + (getAttr "uuid" self) + (getAttr "vecto" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hiccl = ( + build-asdf-system { + pname = "hiccl"; + version = "20241012-git"; + asds = [ "hiccl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hiccl/2024-10-12/hiccl-20241012-git.tgz"; + sha256 = "0d92q8kb8xn6c9gsm822339f9qmpf9lpzy6s6abvxbhhyfk136yp"; + system = "hiccl"; + asd = "hiccl"; + } + ); + systems = [ "hiccl" ]; + lispLibs = [ + (getAttr "serapeum" self) + (getAttr "str" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hiccl-test = ( + build-asdf-system { + pname = "hiccl-test"; + version = "20241012-git"; + asds = [ "hiccl-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hiccl/2024-10-12/hiccl-20241012-git.tgz"; + sha256 = "0d92q8kb8xn6c9gsm822339f9qmpf9lpzy6s6abvxbhhyfk136yp"; + system = "hiccl-test"; + asd = "hiccl-test"; + } + ); + systems = [ "hiccl-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "fiveam" self) + (getAttr "hiccl" self) + (getAttr "lquery" self) + (getAttr "plump" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hl7-client = ( + build-asdf-system { + pname = "hl7-client"; + version = "20150407-git"; + asds = [ "hl7-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hl7-client/2015-04-07/hl7-client-20150407-git.tgz"; + sha256 = "0hq5ip6f1hbdiydml5f1z7qsjaq1v3a3g4y5a87jaif027pwhd89"; + system = "hl7-client"; + asd = "hl7-client"; + } + ); + systems = [ "hl7-client" ]; + lispLibs = [ (getAttr "usocket" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hl7-parser = ( + build-asdf-system { + pname = "hl7-parser"; + version = "20160531-git"; + asds = [ "hl7-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hl7-parser/2016-05-31/hl7-parser-20160531-git.tgz"; + sha256 = "1lcyvk3vap73d23s6pk8p1ficqhl2gs84nan6d0yy0hx8c4gip0x"; + system = "hl7-parser"; + asd = "hl7-parser"; + } + ); + systems = [ "hl7-parser" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hompack = ( + build-asdf-system { + pname = "hompack"; + version = "20231021-git"; + asds = [ "hompack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "hompack"; + asd = "hompack"; + } + ); + systems = [ "hompack" ]; + lispLibs = [ + (getAttr "blas-hompack" self) + (getAttr "f2cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + horner = ( + build-asdf-system { + pname = "horner"; + version = "20191130-git"; + asds = [ "horner" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/horner/2019-11-30/horner-20191130-git.tgz"; + sha256 = "05afvf7sxn1db7xxw7qmys1dwbgsx53iw4w556r277da6bpyacr9"; + system = "horner"; + asd = "horner"; + } + ); + systems = [ "horner" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "infix-math" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + horse-html = ( + build-asdf-system { + pname = "horse-html"; + version = "20191007-git"; + asds = [ "horse-html" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/horse-html/2019-10-07/horse-html-20191007-git.tgz"; + sha256 = "0g6cs38123ajf1hvv056df9d8gy5ajarg0f5gywzhmmf0rhr9br5"; + system = "horse-html"; + asd = "horse-html"; + } + ); + systems = [ "horse-html" ]; + lispLibs = [ (getAttr "parenscript" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + house = ( + build-asdf-system { + pname = "house"; + version = "20210124-git"; + asds = [ "house" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/house/2021-01-24/house-20210124-git.tgz"; + sha256 = "1x3dprg5j5rhbf8r1nr6py6g8wgfb9zysbqbjdcyh91szg7w80mb"; + system = "house"; + asd = "house"; + } + ); + systems = [ "house" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-fad" self) + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "lisp-unit" self) + (getAttr "optima" self) + (getAttr "prove-asdf" self) + (getAttr "quri" self) + (getAttr "session-token" self) + (getAttr "split-sequence" self) + (getAttr "trivial-features" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hsx = ( + build-asdf-system { + pname = "hsx"; + version = "20241012-git"; + asds = [ "hsx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hsx/2024-10-12/hsx-20241012-git.tgz"; + sha256 = "0aldv9cjzl9n4p1arlmvbjdy3zwhxcmx1ajp5lwdz5vq4mivw3zy"; + system = "hsx"; + asd = "hsx"; + } + ); + systems = [ "hsx" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hsx-test = ( + build-asdf-system { + pname = "hsx-test"; + version = "20241012-git"; + asds = [ "hsx-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hsx/2024-10-12/hsx-20241012-git.tgz"; + sha256 = "0aldv9cjzl9n4p1arlmvbjdy3zwhxcmx1ajp5lwdz5vq4mivw3zy"; + system = "hsx-test"; + asd = "hsx-test"; + } + ); + systems = [ "hsx-test" ]; + lispLibs = [ + (getAttr "mstrings" self) + (getAttr "named-readtables" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ht-simple-ajax = ( + build-asdf-system { + pname = "ht-simple-ajax"; + version = "20130421-git"; + asds = [ "ht-simple-ajax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ht-simple-ajax/2013-04-21/ht-simple-ajax-20130421-git.tgz"; + sha256 = "1l87c0arjzyrp3g6ay189fjkqmy81b7i35rfrcs9b269n7d4iis4"; + system = "ht-simple-ajax"; + asd = "ht-simple-ajax"; + } + ); + systems = [ "ht-simple-ajax" ]; + lispLibs = [ (getAttr "hunchentoot" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + html-encode = ( + build-asdf-system { + pname = "html-encode"; + version = "1.2"; + asds = [ "html-encode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/html-encode/2010-10-06/html-encode-1.2.tgz"; + sha256 = "1ydgb5xnbj1qbvzn7x32dm38gpqg5h0pjxc31f8df3j8sar843db"; + system = "html-encode"; + asd = "html-encode"; + } + ); + systems = [ "html-encode" ]; + lispLibs = [ ]; + meta = { }; + } + ); + html-entities = ( + build-asdf-system { + pname = "html-entities"; + version = "20171019-git"; + asds = [ "html-entities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/html-entities/2017-10-19/html-entities-20171019-git.tgz"; + sha256 = "1b2yl6lf6vis17y4n5s505p7ica96bdafcl6vydy1hg50fy33nfr"; + system = "html-entities"; + asd = "html-entities"; + } + ); + systems = [ "html-entities" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + html-entities-tests = ( + build-asdf-system { + pname = "html-entities-tests"; + version = "20171019-git"; + asds = [ "html-entities-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/html-entities/2017-10-19/html-entities-20171019-git.tgz"; + sha256 = "1b2yl6lf6vis17y4n5s505p7ica96bdafcl6vydy1hg50fy33nfr"; + system = "html-entities-tests"; + asd = "html-entities"; + } + ); + systems = [ "html-entities-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "html-entities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + html-match = ( + build-asdf-system { + pname = "html-match"; + version = "20140713-git"; + asds = [ "html-match" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-web/2014-07-13/bknr-web-20140713-git.tgz"; + sha256 = "1m73z0hv7qsc9yddrg8zs7n3zmn9h64v4d62239wrvfnmzqk75x2"; + system = "html-match"; + asd = "html-match"; + } + ); + systems = [ "html-match" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "unit-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + html-match_dot_test = ( + build-asdf-system { + pname = "html-match.test"; + version = "20140713-git"; + asds = [ "html-match.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-web/2014-07-13/bknr-web-20140713-git.tgz"; + sha256 = "1m73z0hv7qsc9yddrg8zs7n3zmn9h64v4d62239wrvfnmzqk75x2"; + system = "html-match.test"; + asd = "html-match"; + } + ); + systems = [ "html-match.test" ]; + lispLibs = [ + (getAttr "html-match" self) + (getAttr "unit-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + html-template = ( + build-asdf-system { + pname = "html-template"; + version = "20171227-git"; + asds = [ "html-template" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/html-template/2017-12-27/html-template-20171227-git.tgz"; + sha256 = "0g700zlyjjba17nbmw1adspw7r9s0321xhayfiqh0drg20zixaf7"; + system = "html-template"; + asd = "html-template"; + } + ); + systems = [ "html-template" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + htmlgen = ( + build-asdf-system { + pname = "htmlgen"; + version = "20190813-git"; + asds = [ "htmlgen" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/portableaserve/2019-08-13/portableaserve-20190813-git.tgz"; + sha256 = "0ak6mqp84sjr0a7h5svr16vra4bf4fcx6wpir0n88dc1vjwy5xqa"; + system = "htmlgen"; + asd = "htmlgen"; + } + ); + systems = [ "htmlgen" ]; + lispLibs = [ (getAttr "acl-compat" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + http-body = ( + build-asdf-system { + pname = "http-body"; + version = "20190813-git"; + asds = [ "http-body" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/http-body/2019-08-13/http-body-20190813-git.tgz"; + sha256 = "0kcg43l5674drzid9cj938q0ki5z25glx296rl239dm7yfmxlzz2"; + system = "http-body"; + asd = "http-body"; + } + ); + systems = [ "http-body" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-utilities" self) + (getAttr "fast-http" self) + (getAttr "flexi-streams" self) + (getAttr "jonathan" self) + (getAttr "quri" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + http-body-test = ( + build-asdf-system { + pname = "http-body-test"; + version = "20190813-git"; + asds = [ "http-body-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/http-body/2019-08-13/http-body-20190813-git.tgz"; + sha256 = "0kcg43l5674drzid9cj938q0ki5z25glx296rl239dm7yfmxlzz2"; + system = "http-body-test"; + asd = "http-body-test"; + } + ); + systems = [ "http-body-test" ]; + lispLibs = [ + (getAttr "assoc-utils" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "http-body" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + http-get-cache = ( + build-asdf-system { + pname = "http-get-cache"; + version = "20180228-git"; + asds = [ "http-get-cache" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/http-get-cache/2018-02-28/http-get-cache-20180228-git.tgz"; + sha256 = "03bw4zf4hlxyrqm5mq53z0qksb9jbrcc5nv90y7qry83kxic2cgv"; + system = "http-get-cache"; + asd = "http-get-cache"; + } + ); + systems = [ "http-get-cache" ]; + lispLibs = [ (getAttr "drakma" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + http-parse = ( + build-asdf-system { + pname = "http-parse"; + version = "20150608-git"; + asds = [ "http-parse" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/http-parse/2015-06-08/http-parse-20150608-git.tgz"; + sha256 = "1plycsx2kch2l143s56hvi5dqx51n5bvp7vazmphqj5skmnw4576"; + system = "http-parse"; + asd = "http-parse"; + } + ); + systems = [ "http-parse" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + http-parse-test = ( + build-asdf-system { + pname = "http-parse-test"; + version = "20150608-git"; + asds = [ "http-parse-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/http-parse/2015-06-08/http-parse-20150608-git.tgz"; + sha256 = "1plycsx2kch2l143s56hvi5dqx51n5bvp7vazmphqj5skmnw4576"; + system = "http-parse-test"; + asd = "http-parse-test"; + } + ); + systems = [ "http-parse-test" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "eos" self) + (getAttr "http-parse" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + http2 = ( + build-asdf-system { + pname = "http2"; + version = "20241012-git"; + asds = [ "http2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/http2/2024-10-12/http2-20241012-git.tgz"; + sha256 = "1zb21np8rksz7b0vkfr3hg8y1a4m20vgkks3v39cc1yclnrfavii"; + system = "http2"; + asd = "http2"; + } + ); + systems = [ "http2" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "flexi-streams" self) + (getAttr "gzip-stream" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_asdf = ( + build-asdf-system { + pname = "hu.dwim.asdf"; + version = "stable-git"; + asds = [ "hu.dwim.asdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.asdf/2021-12-30/hu.dwim.asdf-stable-git.tgz"; + sha256 = "0zfwdsvcywvwzkn0a80ghi5kn1hs4iwinvi17ld58gyskf15frx9"; + system = "hu.dwim.asdf"; + asd = "hu.dwim.asdf"; + } + ); + systems = [ "hu.dwim.asdf" ]; + lispLibs = [ ]; + meta = { }; + } + ); + hu_dot_dwim_dot_asdf_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.asdf.documentation"; + version = "stable-git"; + asds = [ "hu.dwim.asdf.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.asdf/2021-12-30/hu.dwim.asdf-stable-git.tgz"; + sha256 = "0zfwdsvcywvwzkn0a80ghi5kn1hs4iwinvi17ld58gyskf15frx9"; + system = "hu.dwim.asdf.documentation"; + asd = "hu.dwim.asdf.documentation"; + } + ); + systems = [ "hu.dwim.asdf.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_bluez = ( + build-asdf-system { + pname = "hu.dwim.bluez"; + version = "stable-git"; + asds = [ "hu.dwim.bluez" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.bluez/2021-02-28/hu.dwim.bluez-stable-git.tgz"; + sha256 = "0gjh3bgmdz4aabdavbd5m27r273hna47vs388r4m7l2xnd3b3j55"; + system = "hu.dwim.bluez"; + asd = "hu.dwim.bluez"; + } + ); + systems = [ "hu.dwim.bluez" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_common = ( + build-asdf-system { + pname = "hu.dwim.common"; + version = "20150709-darcs"; + asds = [ "hu.dwim.common" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.common/2015-07-09/hu.dwim.common-20150709-darcs.tgz"; + sha256 = "0mkhq6bqysdy09gswgxm1s50xrq7gimdyqiq84xk8vpyp2hv6hqq"; + system = "hu.dwim.common"; + asd = "hu.dwim.common"; + } + ); + systems = [ "hu.dwim.common" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "closer-mop" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common-lisp" self) + (getAttr "iterate" self) + (getAttr "metabang-bind" self) + ]; + meta = { }; + } + ); + hu_dot_dwim_dot_common-lisp = ( + build-asdf-system { + pname = "hu.dwim.common-lisp"; + version = "stable-git"; + asds = [ "hu.dwim.common-lisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.common-lisp/2021-02-28/hu.dwim.common-lisp-stable-git.tgz"; + sha256 = "06zkdw3scnaw0d4nmsgkv7pi7sw00dikdgfgsqmbqfbz2yrsdabk"; + system = "hu.dwim.common-lisp"; + asd = "hu.dwim.common-lisp"; + } + ); + systems = [ "hu.dwim.common-lisp" ]; + lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) ]; + meta = { }; + } + ); + hu_dot_dwim_dot_common-lisp_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.common-lisp.documentation"; + version = "stable-git"; + asds = [ "hu.dwim.common-lisp.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.common-lisp/2021-02-28/hu.dwim.common-lisp-stable-git.tgz"; + sha256 = "06zkdw3scnaw0d4nmsgkv7pi7sw00dikdgfgsqmbqfbz2yrsdabk"; + system = "hu.dwim.common-lisp.documentation"; + asd = "hu.dwim.common-lisp.documentation"; + } + ); + systems = [ "hu.dwim.common-lisp.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common-lisp" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_common_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.common.documentation"; + version = "20150709-darcs"; + asds = [ "hu.dwim.common.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.common/2015-07-09/hu.dwim.common-20150709-darcs.tgz"; + sha256 = "0mkhq6bqysdy09gswgxm1s50xrq7gimdyqiq84xk8vpyp2hv6hqq"; + system = "hu.dwim.common.documentation"; + asd = "hu.dwim.common.documentation"; + } + ); + systems = [ "hu.dwim.common.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_computed-class = ( + build-asdf-system { + pname = "hu.dwim.computed-class"; + version = "20200427-darcs"; + asds = [ "hu.dwim.computed-class" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.computed-class/2020-04-27/hu.dwim.computed-class-20200427-darcs.tgz"; + sha256 = "1frr37g79x08pm7vkpyhnmzbbcgzxvz3vldm8skknpi790vxbpr1"; + system = "hu.dwim.computed-class"; + asd = "hu.dwim.computed-class"; + } + ); + systems = [ "hu.dwim.computed-class" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar" self) + (getAttr "hu_dot_dwim_dot_util" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_computed-class_plus_hu_dot_dwim_dot_logger = ( + build-asdf-system { + pname = "hu.dwim.computed-class+hu.dwim.logger"; + version = "20200427-darcs"; + asds = [ "hu.dwim.computed-class+hu.dwim.logger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.computed-class/2020-04-27/hu.dwim.computed-class-20200427-darcs.tgz"; + sha256 = "1frr37g79x08pm7vkpyhnmzbbcgzxvz3vldm8skknpi790vxbpr1"; + system = "hu.dwim.computed-class+hu.dwim.logger"; + asd = "hu.dwim.computed-class+hu.dwim.logger"; + } + ); + systems = [ "hu.dwim.computed-class+hu.dwim.logger" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_computed-class" self) + (getAttr "hu_dot_dwim_dot_logger" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_computed-class_plus_swank = ( + build-asdf-system { + pname = "hu.dwim.computed-class+swank"; + version = "20200427-darcs"; + asds = [ "hu.dwim.computed-class+swank" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.computed-class/2020-04-27/hu.dwim.computed-class-20200427-darcs.tgz"; + sha256 = "1frr37g79x08pm7vkpyhnmzbbcgzxvz3vldm8skknpi790vxbpr1"; + system = "hu.dwim.computed-class+swank"; + asd = "hu.dwim.computed-class+swank"; + } + ); + systems = [ "hu.dwim.computed-class+swank" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_computed-class" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_computed-class_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.computed-class.documentation"; + version = "20200427-darcs"; + asds = [ "hu.dwim.computed-class.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.computed-class/2020-04-27/hu.dwim.computed-class-20200427-darcs.tgz"; + sha256 = "1frr37g79x08pm7vkpyhnmzbbcgzxvz3vldm8skknpi790vxbpr1"; + system = "hu.dwim.computed-class.documentation"; + asd = "hu.dwim.computed-class.documentation"; + } + ); + systems = [ "hu.dwim.computed-class.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_computed-class_dot_test" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_computed-class_dot_test = ( + build-asdf-system { + pname = "hu.dwim.computed-class.test"; + version = "20200427-darcs"; + asds = [ "hu.dwim.computed-class.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.computed-class/2020-04-27/hu.dwim.computed-class-20200427-darcs.tgz"; + sha256 = "1frr37g79x08pm7vkpyhnmzbbcgzxvz3vldm8skknpi790vxbpr1"; + system = "hu.dwim.computed-class.test"; + asd = "hu.dwim.computed-class.test"; + } + ); + systems = [ "hu.dwim.computed-class.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_computed-class_plus_hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_debug = ( + build-asdf-system { + pname = "hu.dwim.debug"; + version = "20190107-darcs"; + asds = [ "hu.dwim.debug" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.debug/2019-01-07/hu.dwim.debug-20190107-darcs.tgz"; + sha256 = "0ad606bmrif82fyikb2hgwzh3y6nlrlsprb5yi86qwa2a2fvak4b"; + system = "hu.dwim.debug"; + asd = "hu.dwim.debug"; + } + ); + systems = [ "hu.dwim.debug" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_def_plus_swank" self) + (getAttr "hu_dot_dwim_dot_defclass-star" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "hu_dot_dwim_dot_walker" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_debug_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.debug.documentation"; + version = "20190107-darcs"; + asds = [ "hu.dwim.debug.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.debug/2019-01-07/hu.dwim.debug-20190107-darcs.tgz"; + sha256 = "0ad606bmrif82fyikb2hgwzh3y6nlrlsprb5yi86qwa2a2fvak4b"; + system = "hu.dwim.debug.documentation"; + asd = "hu.dwim.debug.documentation"; + } + ); + systems = [ "hu.dwim.debug.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_debug_dot_test" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_debug_dot_test = ( + build-asdf-system { + pname = "hu.dwim.debug.test"; + version = "20190107-darcs"; + asds = [ "hu.dwim.debug.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.debug/2019-01-07/hu.dwim.debug-20190107-darcs.tgz"; + sha256 = "0ad606bmrif82fyikb2hgwzh3y6nlrlsprb5yi86qwa2a2fvak4b"; + system = "hu.dwim.debug.test"; + asd = "hu.dwim.debug.test"; + } + ); + systems = [ "hu.dwim.debug.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_debug" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_def = ( + build-asdf-system { + pname = "hu.dwim.def"; + version = "stable-git"; + asds = [ "hu.dwim.def" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.def/2021-12-30/hu.dwim.def-stable-git.tgz"; + sha256 = "1scjj9g2bn58l8i1g1brdqzrajy4bb63dqkwlcydcvk36iskpyab"; + system = "hu.dwim.def"; + asd = "hu.dwim.def"; + } + ); + systems = [ "hu.dwim.def" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "iterate" self) + (getAttr "metabang-bind" self) + ]; + meta = { }; + } + ); + hu_dot_dwim_dot_def_plus_cl-l10n = ( + build-asdf-system { + pname = "hu.dwim.def+cl-l10n"; + version = "stable-git"; + asds = [ "hu.dwim.def+cl-l10n" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.def/2021-12-30/hu.dwim.def-stable-git.tgz"; + sha256 = "1scjj9g2bn58l8i1g1brdqzrajy4bb63dqkwlcydcvk36iskpyab"; + system = "hu.dwim.def+cl-l10n"; + asd = "hu.dwim.def+cl-l10n"; + } + ); + systems = [ "hu.dwim.def+cl-l10n" ]; + lispLibs = [ + (getAttr "cl-l10n" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_def_plus_contextl = ( + build-asdf-system { + pname = "hu.dwim.def+contextl"; + version = "stable-git"; + asds = [ "hu.dwim.def+contextl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.def/2021-12-30/hu.dwim.def-stable-git.tgz"; + sha256 = "1scjj9g2bn58l8i1g1brdqzrajy4bb63dqkwlcydcvk36iskpyab"; + system = "hu.dwim.def+contextl"; + asd = "hu.dwim.def+contextl"; + } + ); + systems = [ "hu.dwim.def+contextl" ]; + lispLibs = [ + (getAttr "contextl" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common = ( + build-asdf-system { + pname = "hu.dwim.def+hu.dwim.common"; + version = "stable-git"; + asds = [ "hu.dwim.def+hu.dwim.common" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.def/2021-12-30/hu.dwim.def-stable-git.tgz"; + sha256 = "1scjj9g2bn58l8i1g1brdqzrajy4bb63dqkwlcydcvk36iskpyab"; + system = "hu.dwim.def+hu.dwim.common"; + asd = "hu.dwim.def+hu.dwim.common"; + } + ); + systems = [ "hu.dwim.def+hu.dwim.common" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_def" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_delico = ( + build-asdf-system { + pname = "hu.dwim.def+hu.dwim.delico"; + version = "stable-git"; + asds = [ "hu.dwim.def+hu.dwim.delico" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.def/2021-12-30/hu.dwim.def-stable-git.tgz"; + sha256 = "1scjj9g2bn58l8i1g1brdqzrajy4bb63dqkwlcydcvk36iskpyab"; + system = "hu.dwim.def+hu.dwim.delico"; + asd = "hu.dwim.def+hu.dwim.delico"; + } + ); + systems = [ "hu.dwim.def+hu.dwim.delico" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_delico" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_def_plus_swank = ( + build-asdf-system { + pname = "hu.dwim.def+swank"; + version = "stable-git"; + asds = [ "hu.dwim.def+swank" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.def/2021-12-30/hu.dwim.def-stable-git.tgz"; + sha256 = "1scjj9g2bn58l8i1g1brdqzrajy4bb63dqkwlcydcvk36iskpyab"; + system = "hu.dwim.def+swank"; + asd = "hu.dwim.def+swank"; + } + ); + systems = [ "hu.dwim.def+swank" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def" self) + (getAttr "swank" self) + ]; + meta = { }; + } + ); + hu_dot_dwim_dot_defclass-star = ( + build-asdf-system { + pname = "hu.dwim.defclass-star"; + version = "stable-git"; + asds = [ "hu.dwim.defclass-star" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.defclass-star/2021-12-30/hu.dwim.defclass-star-stable-git.tgz"; + sha256 = "1lbmsn9s7v88w934r8rp4d59vsj1jg8p2cz9g5kl1n9vff5sxxw2"; + system = "hu.dwim.defclass-star"; + asd = "hu.dwim.defclass-star"; + } + ); + systems = [ "hu.dwim.defclass-star" ]; + lispLibs = [ (getAttr "hu_dot_dwim_dot_asdf" self) ]; + meta = { }; + } + ); + hu_dot_dwim_dot_defclass-star_plus_contextl = ( + build-asdf-system { + pname = "hu.dwim.defclass-star+contextl"; + version = "stable-git"; + asds = [ "hu.dwim.defclass-star+contextl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.defclass-star/2021-12-30/hu.dwim.defclass-star-stable-git.tgz"; + sha256 = "1lbmsn9s7v88w934r8rp4d59vsj1jg8p2cz9g5kl1n9vff5sxxw2"; + system = "hu.dwim.defclass-star+contextl"; + asd = "hu.dwim.defclass-star+contextl"; + } + ); + systems = [ "hu.dwim.defclass-star+contextl" ]; + lispLibs = [ + (getAttr "contextl" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_defclass-star" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def = ( + build-asdf-system { + pname = "hu.dwim.defclass-star+hu.dwim.def"; + version = "stable-git"; + asds = [ "hu.dwim.defclass-star+hu.dwim.def" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.defclass-star/2021-12-30/hu.dwim.defclass-star-stable-git.tgz"; + sha256 = "1lbmsn9s7v88w934r8rp4d59vsj1jg8p2cz9g5kl1n9vff5sxxw2"; + system = "hu.dwim.defclass-star+hu.dwim.def"; + asd = "hu.dwim.defclass-star+hu.dwim.def"; + } + ); + systems = [ "hu.dwim.defclass-star+hu.dwim.def" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_defclass-star" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def_plus_contextl = ( + build-asdf-system { + pname = "hu.dwim.defclass-star+hu.dwim.def+contextl"; + version = "stable-git"; + asds = [ "hu.dwim.defclass-star+hu.dwim.def+contextl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.defclass-star/2021-12-30/hu.dwim.defclass-star-stable-git.tgz"; + sha256 = "1lbmsn9s7v88w934r8rp4d59vsj1jg8p2cz9g5kl1n9vff5sxxw2"; + system = "hu.dwim.defclass-star+hu.dwim.def+contextl"; + asd = "hu.dwim.defclass-star+hu.dwim.def+contextl"; + } + ); + systems = [ "hu.dwim.defclass-star+hu.dwim.def+contextl" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_defclass-star_plus_contextl" self) + (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_defclass-star_plus_swank = ( + build-asdf-system { + pname = "hu.dwim.defclass-star+swank"; + version = "stable-git"; + asds = [ "hu.dwim.defclass-star+swank" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.defclass-star/2021-12-30/hu.dwim.defclass-star-stable-git.tgz"; + sha256 = "1lbmsn9s7v88w934r8rp4d59vsj1jg8p2cz9g5kl1n9vff5sxxw2"; + system = "hu.dwim.defclass-star+swank"; + asd = "hu.dwim.defclass-star+swank"; + } + ); + systems = [ "hu.dwim.defclass-star+swank" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_defclass-star" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_delico = ( + build-asdf-system { + pname = "hu.dwim.delico"; + version = "20200925-darcs"; + asds = [ "hu.dwim.delico" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.delico/2020-09-25/hu.dwim.delico-20200925-darcs.tgz"; + sha256 = "12n5cddg7vd3y4dqjcf4wayxwj905ja8jh90ixvrhgnvs559lbnl"; + system = "hu.dwim.delico"; + asd = "hu.dwim.delico"; + } + ); + systems = [ "hu.dwim.delico" ]; + lispLibs = [ + (getAttr "contextl" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_walker" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_graphviz = ( + build-asdf-system { + pname = "hu.dwim.graphviz"; + version = "stable-git"; + asds = [ "hu.dwim.graphviz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.graphviz/2021-12-30/hu.dwim.graphviz-stable-git.tgz"; + sha256 = "0cz5g7d6817ajypp876k9m65sxxlf42x4bg04ya73aqci5s1vjwy"; + system = "hu.dwim.graphviz"; + asd = "hu.dwim.graphviz"; + } + ); + systems = [ "hu.dwim.graphviz" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "metabang-bind" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_graphviz_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.graphviz.documentation"; + version = "stable-git"; + asds = [ "hu.dwim.graphviz.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.graphviz/2021-12-30/hu.dwim.graphviz-stable-git.tgz"; + sha256 = "0cz5g7d6817ajypp876k9m65sxxlf42x4bg04ya73aqci5s1vjwy"; + system = "hu.dwim.graphviz.documentation"; + asd = "hu.dwim.graphviz.documentation"; + } + ); + systems = [ "hu.dwim.graphviz.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_graphviz_dot_test" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_graphviz_dot_test = ( + build-asdf-system { + pname = "hu.dwim.graphviz.test"; + version = "stable-git"; + asds = [ "hu.dwim.graphviz.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.graphviz/2021-12-30/hu.dwim.graphviz-stable-git.tgz"; + sha256 = "0cz5g7d6817ajypp876k9m65sxxlf42x4bg04ya73aqci5s1vjwy"; + system = "hu.dwim.graphviz.test"; + asd = "hu.dwim.graphviz.test"; + } + ); + systems = [ "hu.dwim.graphviz.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_graphviz" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_logger = ( + build-asdf-system { + pname = "hu.dwim.logger"; + version = "stable-git"; + asds = [ "hu.dwim.logger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.logger/2021-12-30/hu.dwim.logger-stable-git.tgz"; + sha256 = "17b7m86pggg85lczww7nvswz0nj9qg1fxwv1l9wn31jfcf061h74"; + system = "hu.dwim.logger"; + asd = "hu.dwim.logger"; + } + ); + systems = [ "hu.dwim.logger" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "local-time" self) + ]; + meta = { + broken = true; + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_logger_plus_iolib = ( + build-asdf-system { + pname = "hu.dwim.logger+iolib"; + version = "stable-git"; + asds = [ "hu.dwim.logger+iolib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.logger/2021-12-30/hu.dwim.logger-stable-git.tgz"; + sha256 = "17b7m86pggg85lczww7nvswz0nj9qg1fxwv1l9wn31jfcf061h74"; + system = "hu.dwim.logger+iolib"; + asd = "hu.dwim.logger+iolib"; + } + ); + systems = [ "hu.dwim.logger+iolib" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_util_plus_iolib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_logger_plus_swank = ( + build-asdf-system { + pname = "hu.dwim.logger+swank"; + version = "stable-git"; + asds = [ "hu.dwim.logger+swank" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.logger/2021-12-30/hu.dwim.logger-stable-git.tgz"; + sha256 = "17b7m86pggg85lczww7nvswz0nj9qg1fxwv1l9wn31jfcf061h74"; + system = "hu.dwim.logger+swank"; + asd = "hu.dwim.logger+swank"; + } + ); + systems = [ "hu.dwim.logger+swank" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_logger_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.logger.documentation"; + version = "stable-git"; + asds = [ "hu.dwim.logger.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.logger/2021-12-30/hu.dwim.logger-stable-git.tgz"; + sha256 = "17b7m86pggg85lczww7nvswz0nj9qg1fxwv1l9wn31jfcf061h74"; + system = "hu.dwim.logger.documentation"; + asd = "hu.dwim.logger.documentation"; + } + ); + systems = [ "hu.dwim.logger.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_logger_dot_test" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_logger_dot_test = ( + build-asdf-system { + pname = "hu.dwim.logger.test"; + version = "stable-git"; + asds = [ "hu.dwim.logger.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.logger/2021-12-30/hu.dwim.logger-stable-git.tgz"; + sha256 = "17b7m86pggg85lczww7nvswz0nj9qg1fxwv1l9wn31jfcf061h74"; + system = "hu.dwim.logger.test"; + asd = "hu.dwim.logger.test"; + } + ); + systems = [ "hu.dwim.logger.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_partial-eval = ( + build-asdf-system { + pname = "hu.dwim.partial-eval"; + version = "stable-git"; + asds = [ "hu.dwim.partial-eval" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.partial-eval/2024-10-12/hu.dwim.partial-eval-stable-git.tgz"; + sha256 = "1zsh1rk9rcxkrqavhx2slpczii23y51fn66n68vsw5d97g9k6gzz"; + system = "hu.dwim.partial-eval"; + asd = "hu.dwim.partial-eval"; + } + ); + systems = [ "hu.dwim.partial-eval" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def_plus_contextl" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "hu_dot_dwim_dot_walker" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec = ( + build-asdf-system { + pname = "hu.dwim.perec"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec"; + asd = "hu.dwim.perec"; + } + ); + systems = [ "hu.dwim.perec" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-containers" self) + (getAttr "cl-ppcre" self) + (getAttr "contextl" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_computed-class" self) + (getAttr "hu_dot_dwim_dot_def_plus_contextl" self) + (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_delico" self) + (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_rdbms" self) + (getAttr "hu_dot_dwim_dot_serializer" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "hu_dot_dwim_dot_walker" self) + (getAttr "ironclad" self) + (getAttr "local-time" self) + (getAttr "metacopy-with-contextl" self) + (getAttr "parse-number" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_plus_hu_dot_dwim_dot_quasi-quote_dot_xml = ( + build-asdf-system { + pname = "hu.dwim.perec+hu.dwim.quasi-quote.xml"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec+hu.dwim.quasi-quote.xml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec+hu.dwim.quasi-quote.xml"; + asd = "hu.dwim.perec+hu.dwim.quasi-quote.xml"; + } + ); + systems = [ "hu.dwim.perec+hu.dwim.quasi-quote.xml" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec" self) + (getAttr "hu_dot_dwim_dot_quasi-quote_dot_xml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_plus_iolib = ( + build-asdf-system { + pname = "hu.dwim.perec+iolib"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec+iolib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec+iolib"; + asd = "hu.dwim.perec+iolib"; + } + ); + systems = [ "hu.dwim.perec+iolib" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec" self) + (getAttr "iolib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_plus_swank = ( + build-asdf-system { + pname = "hu.dwim.perec+swank"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec+swank" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec+swank"; + asd = "hu.dwim.perec+swank"; + } + ); + systems = [ "hu.dwim.perec+swank" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_dot_all = ( + build-asdf-system { + pname = "hu.dwim.perec.all"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec.all" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec.all"; + asd = "hu.dwim.perec.all"; + } + ); + systems = [ "hu.dwim.perec.all" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec_dot_oracle" self) + (getAttr "hu_dot_dwim_dot_perec_dot_postgresql" self) + (getAttr "hu_dot_dwim_dot_perec_dot_sqlite" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_dot_all_dot_test = ( + build-asdf-system { + pname = "hu.dwim.perec.all.test"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec.all.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec.all.test"; + asd = "hu.dwim.perec.all.test"; + } + ); + systems = [ "hu.dwim.perec.all.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec_dot_oracle_dot_test" self) + (getAttr "hu_dot_dwim_dot_perec_dot_postgresql_dot_test" self) + (getAttr "hu_dot_dwim_dot_perec_dot_sqlite_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.perec.documentation"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec.documentation"; + asd = "hu.dwim.perec.documentation"; + } + ); + systems = [ "hu.dwim.perec.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec_dot_all_dot_test" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_dot_oracle = ( + build-asdf-system { + pname = "hu.dwim.perec.oracle"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec.oracle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec.oracle"; + asd = "hu.dwim.perec.oracle"; + } + ); + systems = [ "hu.dwim.perec.oracle" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_oracle" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_dot_oracle_dot_test = ( + build-asdf-system { + pname = "hu.dwim.perec.oracle.test"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec.oracle.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec.oracle.test"; + asd = "hu.dwim.perec.oracle.test"; + } + ); + systems = [ "hu.dwim.perec.oracle.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec_dot_oracle" self) + (getAttr "hu_dot_dwim_dot_perec_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_dot_postgresql = ( + build-asdf-system { + pname = "hu.dwim.perec.postgresql"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec.postgresql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec.postgresql"; + asd = "hu.dwim.perec.postgresql"; + } + ); + systems = [ "hu.dwim.perec.postgresql" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_postgresql" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_dot_postgresql_dot_test = ( + build-asdf-system { + pname = "hu.dwim.perec.postgresql.test"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec.postgresql.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec.postgresql.test"; + asd = "hu.dwim.perec.postgresql.test"; + } + ); + systems = [ "hu.dwim.perec.postgresql.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec_dot_postgresql" self) + (getAttr "hu_dot_dwim_dot_perec_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_dot_sqlite = ( + build-asdf-system { + pname = "hu.dwim.perec.sqlite"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec.sqlite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec.sqlite"; + asd = "hu.dwim.perec.sqlite"; + } + ); + systems = [ "hu.dwim.perec.sqlite" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_sqlite" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_dot_sqlite_dot_test = ( + build-asdf-system { + pname = "hu.dwim.perec.sqlite.test"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec.sqlite.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec.sqlite.test"; + asd = "hu.dwim.perec.sqlite.test"; + } + ); + systems = [ "hu.dwim.perec.sqlite.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec_dot_sqlite" self) + (getAttr "hu_dot_dwim_dot_perec_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_perec_dot_test = ( + build-asdf-system { + pname = "hu.dwim.perec.test"; + version = "20211209-darcs"; + asds = [ "hu.dwim.perec.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.perec/2021-12-09/hu.dwim.perec-20211209-darcs.tgz"; + sha256 = "1m313l0j7jnmw6dlivmxjhcncjwsrzi5zy5g3g3ggzij3fjf9nnz"; + system = "hu.dwim.perec.test"; + asd = "hu.dwim.perec.test"; + } + ); + systems = [ "hu.dwim.perec.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec_plus_hu_dot_dwim_dot_quasi-quote_dot_xml" self) + (getAttr "hu_dot_dwim_dot_perec_plus_iolib" self) + (getAttr "hu_dot_dwim_dot_perec_plus_swank" self) + (getAttr "hu_dot_dwim_dot_util_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_presentation = ( + build-asdf-system { + pname = "hu.dwim.presentation"; + version = "20211230-darcs"; + asds = [ "hu.dwim.presentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.presentation/2021-12-30/hu.dwim.presentation-20211230-darcs.tgz"; + sha256 = "06y08z2pa3ra8hwn46n4kygf6vhq68nh73x4gzh4skx379hb4fgp"; + system = "hu.dwim.presentation"; + asd = "hu.dwim.presentation"; + } + ); + systems = [ "hu.dwim.presentation" ]; + lispLibs = [ + (getAttr "cl-graph_plus_hu_dot_dwim_dot_graphviz" self) + (getAttr "contextl" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def_plus_contextl" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "hu_dot_dwim_dot_web-server_dot_application" self) + (getAttr "iolib" self) + (getAttr "moptilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_presentation_plus_cl-graph_plus_cl-typesetting = ( + build-asdf-system { + pname = "hu.dwim.presentation+cl-graph+cl-typesetting"; + version = "20211230-darcs"; + asds = [ "hu.dwim.presentation+cl-graph+cl-typesetting" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.presentation/2021-12-30/hu.dwim.presentation-20211230-darcs.tgz"; + sha256 = "06y08z2pa3ra8hwn46n4kygf6vhq68nh73x4gzh4skx379hb4fgp"; + system = "hu.dwim.presentation+cl-graph+cl-typesetting"; + asd = "hu.dwim.presentation+cl-graph+cl-typesetting"; + } + ); + systems = [ "hu.dwim.presentation+cl-graph+cl-typesetting" ]; + lispLibs = [ + (getAttr "cl-graph" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_presentation_plus_cl-typesetting" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_presentation_plus_cl-typesetting = ( + build-asdf-system { + pname = "hu.dwim.presentation+cl-typesetting"; + version = "20211230-darcs"; + asds = [ "hu.dwim.presentation+cl-typesetting" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.presentation/2021-12-30/hu.dwim.presentation-20211230-darcs.tgz"; + sha256 = "06y08z2pa3ra8hwn46n4kygf6vhq68nh73x4gzh4skx379hb4fgp"; + system = "hu.dwim.presentation+cl-typesetting"; + asd = "hu.dwim.presentation+cl-typesetting"; + } + ); + systems = [ "hu.dwim.presentation+cl-typesetting" ]; + lispLibs = [ + (getAttr "cl-typesetting" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_presentation_plus_hu_dot_dwim_dot_stefil = ( + build-asdf-system { + pname = "hu.dwim.presentation+hu.dwim.stefil"; + version = "20211230-darcs"; + asds = [ "hu.dwim.presentation+hu.dwim.stefil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.presentation/2021-12-30/hu.dwim.presentation-20211230-darcs.tgz"; + sha256 = "06y08z2pa3ra8hwn46n4kygf6vhq68nh73x4gzh4skx379hb4fgp"; + system = "hu.dwim.presentation+hu.dwim.stefil"; + asd = "hu.dwim.presentation+hu.dwim.stefil"; + } + ); + systems = [ "hu.dwim.presentation+hu.dwim.stefil" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_presentation_plus_hu_dot_dwim_dot_web-server = ( + build-asdf-system { + pname = "hu.dwim.presentation+hu.dwim.web-server"; + version = "20211230-darcs"; + asds = [ "hu.dwim.presentation+hu.dwim.web-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.presentation/2021-12-30/hu.dwim.presentation-20211230-darcs.tgz"; + sha256 = "06y08z2pa3ra8hwn46n4kygf6vhq68nh73x4gzh4skx379hb4fgp"; + system = "hu.dwim.presentation+hu.dwim.web-server"; + asd = "hu.dwim.presentation+hu.dwim.web-server"; + } + ); + systems = [ "hu.dwim.presentation+hu.dwim.web-server" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + (getAttr "hu_dot_dwim_dot_web-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_quasi-quote = ( + build-asdf-system { + pname = "hu.dwim.quasi-quote"; + version = "stable-git"; + asds = [ "hu.dwim.quasi-quote" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; + sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; + system = "hu.dwim.quasi-quote"; + asd = "hu.dwim.quasi-quote"; + } + ); + systems = [ "hu.dwim.quasi-quote" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "babel-streams" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "hu_dot_dwim_dot_walker" self) + ]; + meta = { + broken = true; + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_quasi-quote_dot_css = ( + build-asdf-system { + pname = "hu.dwim.quasi-quote.css"; + version = "stable-git"; + asds = [ "hu.dwim.quasi-quote.css" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; + sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; + system = "hu.dwim.quasi-quote.css"; + asd = "hu.dwim.quasi-quote.css"; + } + ); + systems = [ "hu.dwim.quasi-quote.css" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_quasi-quote" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_quasi-quote_dot_js = ( + build-asdf-system { + pname = "hu.dwim.quasi-quote.js"; + version = "stable-git"; + asds = [ "hu.dwim.quasi-quote.js" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; + sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; + system = "hu.dwim.quasi-quote.js"; + asd = "hu.dwim.quasi-quote.js"; + } + ); + systems = [ "hu.dwim.quasi-quote.js" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_quasi-quote" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "hu_dot_dwim_dot_walker" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_quasi-quote_dot_pdf = ( + build-asdf-system { + pname = "hu.dwim.quasi-quote.pdf"; + version = "stable-git"; + asds = [ "hu.dwim.quasi-quote.pdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; + sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; + system = "hu.dwim.quasi-quote.pdf"; + asd = "hu.dwim.quasi-quote.pdf"; + } + ); + systems = [ "hu.dwim.quasi-quote.pdf" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_quasi-quote" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_quasi-quote_dot_xml = ( + build-asdf-system { + pname = "hu.dwim.quasi-quote.xml"; + version = "stable-git"; + asds = [ "hu.dwim.quasi-quote.xml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; + sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; + system = "hu.dwim.quasi-quote.xml"; + asd = "hu.dwim.quasi-quote.xml"; + } + ); + systems = [ "hu.dwim.quasi-quote.xml" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_quasi-quote" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_quasi-quote_dot_xml_plus_cxml = ( + build-asdf-system { + pname = "hu.dwim.quasi-quote.xml+cxml"; + version = "stable-git"; + asds = [ "hu.dwim.quasi-quote.xml+cxml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; + sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; + system = "hu.dwim.quasi-quote.xml+cxml"; + asd = "hu.dwim.quasi-quote.xml+cxml"; + } + ); + systems = [ "hu.dwim.quasi-quote.xml+cxml" ]; + lispLibs = [ + (getAttr "cxml" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_quasi-quote_dot_xml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_quasi-quote_dot_xml_plus_hu_dot_dwim_dot_quasi-quote_dot_js = ( + build-asdf-system { + pname = "hu.dwim.quasi-quote.xml+hu.dwim.quasi-quote.js"; + version = "stable-git"; + asds = [ "hu.dwim.quasi-quote.xml+hu.dwim.quasi-quote.js" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.quasi-quote/2022-07-07/hu.dwim.quasi-quote-stable-git.tgz"; + sha256 = "1bawkv7ppn6yay1dd6vvmf9bz2400jvks1w8bqmslv8facfhbprm"; + system = "hu.dwim.quasi-quote.xml+hu.dwim.quasi-quote.js"; + asd = "hu.dwim.quasi-quote.xml+hu.dwim.quasi-quote.js"; + } + ); + systems = [ "hu.dwim.quasi-quote.xml+hu.dwim.quasi-quote.js" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_quasi-quote_dot_js" self) + (getAttr "hu_dot_dwim_dot_quasi-quote_dot_xml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_rdbms = ( + build-asdf-system { + pname = "hu.dwim.rdbms"; + version = "20201016-darcs"; + asds = [ "hu.dwim.rdbms" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; + sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; + system = "hu.dwim.rdbms"; + asd = "hu.dwim.rdbms"; + } + ); + systems = [ "hu.dwim.rdbms" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "hu_dot_dwim_dot_walker" self) + (getAttr "ironclad" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_rdbms_dot_all = ( + build-asdf-system { + pname = "hu.dwim.rdbms.all"; + version = "20201016-darcs"; + asds = [ "hu.dwim.rdbms.all" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; + sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; + system = "hu.dwim.rdbms.all"; + asd = "hu.dwim.rdbms.all"; + } + ); + systems = [ "hu.dwim.rdbms.all" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_oracle" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_postgresql" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_sqlite" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_rdbms_dot_all_dot_test = ( + build-asdf-system { + pname = "hu.dwim.rdbms.all.test"; + version = "20201016-darcs"; + asds = [ "hu.dwim.rdbms.all.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; + sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; + system = "hu.dwim.rdbms.all.test"; + asd = "hu.dwim.rdbms.all.test"; + } + ); + systems = [ "hu.dwim.rdbms.all.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_oracle_dot_test" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_postgresql_dot_test" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_sqlite_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_rdbms_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.rdbms.documentation"; + version = "20201016-darcs"; + asds = [ "hu.dwim.rdbms.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; + sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; + system = "hu.dwim.rdbms.documentation"; + asd = "hu.dwim.rdbms.documentation"; + } + ); + systems = [ "hu.dwim.rdbms.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_all_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_rdbms_dot_oracle = ( + build-asdf-system { + pname = "hu.dwim.rdbms.oracle"; + version = "20201016-darcs"; + asds = [ "hu.dwim.rdbms.oracle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; + sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; + system = "hu.dwim.rdbms.oracle"; + asd = "hu.dwim.rdbms.oracle"; + } + ); + systems = [ "hu.dwim.rdbms.oracle" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_rdbms" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_rdbms_dot_oracle_dot_test = ( + build-asdf-system { + pname = "hu.dwim.rdbms.oracle.test"; + version = "20201016-darcs"; + asds = [ "hu.dwim.rdbms.oracle.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; + sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; + system = "hu.dwim.rdbms.oracle.test"; + asd = "hu.dwim.rdbms.oracle.test"; + } + ); + systems = [ "hu.dwim.rdbms.oracle.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_oracle" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_rdbms_dot_postgresql = ( + build-asdf-system { + pname = "hu.dwim.rdbms.postgresql"; + version = "20201016-darcs"; + asds = [ "hu.dwim.rdbms.postgresql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; + sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; + system = "hu.dwim.rdbms.postgresql"; + asd = "hu.dwim.rdbms.postgresql"; + } + ); + systems = [ "hu.dwim.rdbms.postgresql" ]; + lispLibs = [ + (getAttr "cl-postgres_plus_local-time" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_rdbms" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_rdbms_dot_postgresql_dot_test = ( + build-asdf-system { + pname = "hu.dwim.rdbms.postgresql.test"; + version = "20201016-darcs"; + asds = [ "hu.dwim.rdbms.postgresql.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; + sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; + system = "hu.dwim.rdbms.postgresql.test"; + asd = "hu.dwim.rdbms.postgresql.test"; + } + ); + systems = [ "hu.dwim.rdbms.postgresql.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_postgresql" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_rdbms_dot_sqlite = ( + build-asdf-system { + pname = "hu.dwim.rdbms.sqlite"; + version = "20201016-darcs"; + asds = [ "hu.dwim.rdbms.sqlite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; + sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; + system = "hu.dwim.rdbms.sqlite"; + asd = "hu.dwim.rdbms.sqlite"; + } + ); + systems = [ "hu.dwim.rdbms.sqlite" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_rdbms" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_rdbms_dot_sqlite_dot_test = ( + build-asdf-system { + pname = "hu.dwim.rdbms.sqlite.test"; + version = "20201016-darcs"; + asds = [ "hu.dwim.rdbms.sqlite.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; + sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; + system = "hu.dwim.rdbms.sqlite.test"; + asd = "hu.dwim.rdbms.sqlite.test"; + } + ); + systems = [ "hu.dwim.rdbms.sqlite.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_sqlite" self) + (getAttr "hu_dot_dwim_dot_rdbms_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_rdbms_dot_test = ( + build-asdf-system { + pname = "hu.dwim.rdbms.test"; + version = "20201016-darcs"; + asds = [ "hu.dwim.rdbms.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.rdbms/2020-10-16/hu.dwim.rdbms-20201016-darcs.tgz"; + sha256 = "1rklr82ibwmfffijmpy8mlm6vnylykajzk7r1g0mn28si3map3av"; + system = "hu.dwim.rdbms.test"; + asd = "hu.dwim.rdbms.test"; + } + ); + systems = [ "hu.dwim.rdbms.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_rdbms" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_reiterate = ( + build-asdf-system { + pname = "hu.dwim.reiterate"; + version = "stable-git"; + asds = [ "hu.dwim.reiterate" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.reiterate/2021-12-30/hu.dwim.reiterate-stable-git.tgz"; + sha256 = "0h6cgg385ivgc6942xal09c7n9vmy6gn4y3zz4zafc1qyl5jwyv9"; + system = "hu.dwim.reiterate"; + asd = "hu.dwim.reiterate"; + } + ); + systems = [ "hu.dwim.reiterate" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common-lisp" self) + (getAttr "hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_defclass-star" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "metabang-bind" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_reiterate_plus_hu_dot_dwim_dot_logger = ( + build-asdf-system { + pname = "hu.dwim.reiterate+hu.dwim.logger"; + version = "stable-git"; + asds = [ "hu.dwim.reiterate+hu.dwim.logger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.reiterate/2021-12-30/hu.dwim.reiterate-stable-git.tgz"; + sha256 = "0h6cgg385ivgc6942xal09c7n9vmy6gn4y3zz4zafc1qyl5jwyv9"; + system = "hu.dwim.reiterate+hu.dwim.logger"; + asd = "hu.dwim.reiterate+hu.dwim.logger"; + } + ); + systems = [ "hu.dwim.reiterate+hu.dwim.logger" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_reiterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_sdl = ( + build-asdf-system { + pname = "hu.dwim.sdl"; + version = "stable-git"; + asds = [ "hu.dwim.sdl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.sdl/2022-07-07/hu.dwim.sdl-stable-git.tgz"; + sha256 = "175kha5f7kvis2nlxbzrybswbr62lgmjh691ajwl5i9y7andqhq2"; + system = "hu.dwim.sdl"; + asd = "hu.dwim.sdl"; + } + ); + systems = [ "hu.dwim.sdl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_serializer = ( + build-asdf-system { + pname = "hu.dwim.serializer"; + version = "20161204-darcs"; + asds = [ "hu.dwim.serializer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.serializer/2016-12-04/hu.dwim.serializer-20161204-darcs.tgz"; + sha256 = "1c4zl2ql4w7nw8vrcrhhq45c5yhbcp4z5qpp1yxjpd3002q2lbh2"; + system = "hu.dwim.serializer"; + asd = "hu.dwim.serializer"; + } + ); + systems = [ "hu.dwim.serializer" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar" self) + (getAttr "hu_dot_dwim_dot_util" self) + ]; + meta = { + broken = true; + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_serializer_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.serializer.documentation"; + version = "20161204-darcs"; + asds = [ "hu.dwim.serializer.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.serializer/2016-12-04/hu.dwim.serializer-20161204-darcs.tgz"; + sha256 = "1c4zl2ql4w7nw8vrcrhhq45c5yhbcp4z5qpp1yxjpd3002q2lbh2"; + system = "hu.dwim.serializer.documentation"; + asd = "hu.dwim.serializer.documentation"; + } + ); + systems = [ "hu.dwim.serializer.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + (getAttr "hu_dot_dwim_dot_serializer_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_serializer_dot_test = ( + build-asdf-system { + pname = "hu.dwim.serializer.test"; + version = "20161204-darcs"; + asds = [ "hu.dwim.serializer.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.serializer/2016-12-04/hu.dwim.serializer-20161204-darcs.tgz"; + sha256 = "1c4zl2ql4w7nw8vrcrhhq45c5yhbcp4z5qpp1yxjpd3002q2lbh2"; + system = "hu.dwim.serializer.test"; + asd = "hu.dwim.serializer.test"; + } + ); + systems = [ "hu.dwim.serializer.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_serializer" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_stefil = ( + build-asdf-system { + pname = "hu.dwim.stefil"; + version = "stable-git"; + asds = [ "hu.dwim.stefil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.stefil/2021-12-30/hu.dwim.stefil-stable-git.tgz"; + sha256 = "0sra6psvrlpx9w7xjikm6ph2qlmgi9lr1kagpsiafxq4dnqlxjsx"; + system = "hu.dwim.stefil"; + asd = "hu.dwim.stefil"; + } + ); + systems = [ "hu.dwim.stefil" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { }; + } + ); + hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def = ( + build-asdf-system { + pname = "hu.dwim.stefil+hu.dwim.def"; + version = "stable-git"; + asds = [ "hu.dwim.stefil+hu.dwim.def" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.stefil/2021-12-30/hu.dwim.stefil-stable-git.tgz"; + sha256 = "0sra6psvrlpx9w7xjikm6ph2qlmgi9lr1kagpsiafxq4dnqlxjsx"; + system = "hu.dwim.stefil+hu.dwim.def"; + asd = "hu.dwim.stefil+hu.dwim.def"; + } + ); + systems = [ "hu.dwim.stefil+hu.dwim.def" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + ]; + meta = { }; + } + ); + hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank = ( + build-asdf-system { + pname = "hu.dwim.stefil+hu.dwim.def+swank"; + version = "stable-git"; + asds = [ "hu.dwim.stefil+hu.dwim.def+swank" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.stefil/2021-12-30/hu.dwim.stefil-stable-git.tgz"; + sha256 = "0sra6psvrlpx9w7xjikm6ph2qlmgi9lr1kagpsiafxq4dnqlxjsx"; + system = "hu.dwim.stefil+hu.dwim.def+swank"; + asd = "hu.dwim.stefil+hu.dwim.def+swank"; + } + ); + systems = [ "hu.dwim.stefil+hu.dwim.def+swank" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def_plus_swank" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_swank" self) + ]; + meta = { }; + } + ); + hu_dot_dwim_dot_stefil_plus_swank = ( + build-asdf-system { + pname = "hu.dwim.stefil+swank"; + version = "stable-git"; + asds = [ "hu.dwim.stefil+swank" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.stefil/2021-12-30/hu.dwim.stefil-stable-git.tgz"; + sha256 = "0sra6psvrlpx9w7xjikm6ph2qlmgi9lr1kagpsiafxq4dnqlxjsx"; + system = "hu.dwim.stefil+swank"; + asd = "hu.dwim.stefil+swank"; + } + ); + systems = [ "hu.dwim.stefil+swank" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + (getAttr "swank" self) + ]; + meta = { }; + } + ); + hu_dot_dwim_dot_syntax-sugar = ( + build-asdf-system { + pname = "hu.dwim.syntax-sugar"; + version = "stable-git"; + asds = [ "hu.dwim.syntax-sugar" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.syntax-sugar/2023-02-14/hu.dwim.syntax-sugar-stable-git.tgz"; + sha256 = "1cy474di8njy4s39n7kn2w9jw39n4rssrk0fghrj0gabfxiz4wv9"; + system = "hu.dwim.syntax-sugar"; + asd = "hu.dwim.syntax-sugar"; + } + ); + systems = [ "hu.dwim.syntax-sugar" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_syntax-sugar_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.syntax-sugar.documentation"; + version = "stable-git"; + asds = [ "hu.dwim.syntax-sugar.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.syntax-sugar/2023-02-14/hu.dwim.syntax-sugar-stable-git.tgz"; + sha256 = "1cy474di8njy4s39n7kn2w9jw39n4rssrk0fghrj0gabfxiz4wv9"; + system = "hu.dwim.syntax-sugar.documentation"; + asd = "hu.dwim.syntax-sugar.documentation"; + } + ); + systems = [ "hu.dwim.syntax-sugar.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_syntax-sugar_dot_test = ( + build-asdf-system { + pname = "hu.dwim.syntax-sugar.test"; + version = "stable-git"; + asds = [ "hu.dwim.syntax-sugar.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.syntax-sugar/2023-02-14/hu.dwim.syntax-sugar-stable-git.tgz"; + sha256 = "1cy474di8njy4s39n7kn2w9jw39n4rssrk0fghrj0gabfxiz4wv9"; + system = "hu.dwim.syntax-sugar.test"; + asd = "hu.dwim.syntax-sugar.test"; + } + ); + systems = [ "hu.dwim.syntax-sugar.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar" self) + (getAttr "hu_dot_dwim_dot_walker" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_uri = ( + build-asdf-system { + pname = "hu.dwim.uri"; + version = "20180228-darcs"; + asds = [ "hu.dwim.uri" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.uri/2018-02-28/hu.dwim.uri-20180228-darcs.tgz"; + sha256 = "0wvai7djmbry0b0j8vhzw3s8m30ghs2sml29gw6snh1pynh3c2ir"; + system = "hu.dwim.uri"; + asd = "hu.dwim.uri"; + } + ); + systems = [ "hu.dwim.uri" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "iolib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_uri_dot_test = ( + build-asdf-system { + pname = "hu.dwim.uri.test"; + version = "20180228-darcs"; + asds = [ "hu.dwim.uri.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.uri/2018-02-28/hu.dwim.uri-20180228-darcs.tgz"; + sha256 = "0wvai7djmbry0b0j8vhzw3s8m30ghs2sml29gw6snh1pynh3c2ir"; + system = "hu.dwim.uri.test"; + asd = "hu.dwim.uri.test"; + } + ); + systems = [ "hu.dwim.uri.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) + (getAttr "hu_dot_dwim_dot_uri" self) + (getAttr "hu_dot_dwim_dot_util" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_util = ( + build-asdf-system { + pname = "hu.dwim.util"; + version = "stable-git"; + asds = [ "hu.dwim.util" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.util/2021-12-30/hu.dwim.util-stable-git.tgz"; + sha256 = "01f0kvvaa94zkz5zzfaf8cbiihlp0l6627q3hmc0k154j3mdarmi"; + system = "hu.dwim.util"; + asd = "hu.dwim.util"; + } + ); + systems = [ "hu.dwim.util" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_util_plus_iolib = ( + build-asdf-system { + pname = "hu.dwim.util+iolib"; + version = "stable-git"; + asds = [ "hu.dwim.util+iolib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.util/2021-12-30/hu.dwim.util-stable-git.tgz"; + sha256 = "01f0kvvaa94zkz5zzfaf8cbiihlp0l6627q3hmc0k154j3mdarmi"; + system = "hu.dwim.util+iolib"; + asd = "hu.dwim.util+iolib"; + } + ); + systems = [ "hu.dwim.util+iolib" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "iolib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_util_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.util.documentation"; + version = "stable-git"; + asds = [ "hu.dwim.util.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.util/2021-12-30/hu.dwim.util-stable-git.tgz"; + sha256 = "01f0kvvaa94zkz5zzfaf8cbiihlp0l6627q3hmc0k154j3mdarmi"; + system = "hu.dwim.util.documentation"; + asd = "hu.dwim.util.documentation"; + } + ); + systems = [ "hu.dwim.util.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_util_dot_test = ( + build-asdf-system { + pname = "hu.dwim.util.test"; + version = "stable-git"; + asds = [ "hu.dwim.util.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.util/2021-12-30/hu.dwim.util-stable-git.tgz"; + sha256 = "01f0kvvaa94zkz5zzfaf8cbiihlp0l6627q3hmc0k154j3mdarmi"; + system = "hu.dwim.util.test"; + asd = "hu.dwim.util.test"; + } + ); + systems = [ "hu.dwim.util.test" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "babel-streams" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-l10n" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "command-line-arguments" self) + (getAttr "cxml" self) + (getAttr "drakma" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_delico" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_perec_dot_postgresql" self) + (getAttr "hu_dot_dwim_dot_quasi-quote_dot_xml" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "hu_dot_dwim_dot_util_plus_iolib" self) + (getAttr "hu_dot_dwim_dot_web-server_dot_application" self) + (getAttr "iolib" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_walker = ( + build-asdf-system { + pname = "hu.dwim.walker"; + version = "stable-git"; + asds = [ "hu.dwim.walker" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.walker/2022-07-07/hu.dwim.walker-stable-git.tgz"; + sha256 = "0sw7z5iml82sklxjy1wr42mbp2qqml49ci36d6xsckar0sqsc8vr"; + system = "hu.dwim.walker"; + asd = "hu.dwim.walker"; + } + ); + systems = [ "hu.dwim.walker" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "closer-mop" self) + (getAttr "contextl" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def_plus_contextl" self) + (getAttr "hu_dot_dwim_dot_defclass-star_plus_hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "metabang-bind" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_web-server = ( + build-asdf-system { + pname = "hu.dwim.web-server"; + version = "20220707-darcs"; + asds = [ "hu.dwim.web-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; + sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; + system = "hu.dwim.web-server"; + asd = "hu.dwim.web-server"; + } + ); + systems = [ "hu.dwim.web-server" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "babel-streams" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cl_plus_ssl" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_computed-class" self) + (getAttr "hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_def_plus_cl-l10n" self) + (getAttr "hu_dot_dwim_dot_def_plus_contextl" self) + (getAttr "hu_dot_dwim_dot_def_plus_hu_dot_dwim_dot_delico" self) + (getAttr "hu_dot_dwim_dot_logger_plus_iolib" self) + (getAttr "hu_dot_dwim_dot_quasi-quote_dot_xml_plus_hu_dot_dwim_dot_quasi-quote_dot_js" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar" self) + (getAttr "hu_dot_dwim_dot_uri" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "hu_dot_dwim_dot_zlib" self) + (getAttr "iolib" self) + (getAttr "local-time" self) + (getAttr "parse-number" self) + (getAttr "rfc2109" self) + (getAttr "rfc2388-binary" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_web-server_plus_swank = ( + build-asdf-system { + pname = "hu.dwim.web-server+swank"; + version = "20220707-darcs"; + asds = [ "hu.dwim.web-server+swank" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; + sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; + system = "hu.dwim.web-server+swank"; + asd = "hu.dwim.web-server+swank"; + } + ); + systems = [ "hu.dwim.web-server+swank" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_def_plus_swank" self) + (getAttr "hu_dot_dwim_dot_web-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_web-server_dot_application = ( + build-asdf-system { + pname = "hu.dwim.web-server.application"; + version = "20220707-darcs"; + asds = [ "hu.dwim.web-server.application" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; + sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; + system = "hu.dwim.web-server.application"; + asd = "hu.dwim.web-server.application"; + } + ); + systems = [ "hu.dwim.web-server.application" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_web-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_web-server_dot_application_plus_hu_dot_dwim_dot_perec = ( + build-asdf-system { + pname = "hu.dwim.web-server.application+hu.dwim.perec"; + version = "20220707-darcs"; + asds = [ "hu.dwim.web-server.application+hu.dwim.perec" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; + sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; + system = "hu.dwim.web-server.application+hu.dwim.perec"; + asd = "hu.dwim.web-server.application+hu.dwim.perec"; + } + ); + systems = [ "hu.dwim.web-server.application+hu.dwim.perec" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_perec" self) + (getAttr "hu_dot_dwim_dot_web-server_dot_application" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_web-server_dot_application_dot_test = ( + build-asdf-system { + pname = "hu.dwim.web-server.application.test"; + version = "20220707-darcs"; + asds = [ "hu.dwim.web-server.application.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; + sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; + system = "hu.dwim.web-server.application.test"; + asd = "hu.dwim.web-server.application.test"; + } + ); + systems = [ "hu.dwim.web-server.application.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_web-server_dot_application" self) + (getAttr "hu_dot_dwim_dot_web-server_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_web-server_dot_documentation = ( + build-asdf-system { + pname = "hu.dwim.web-server.documentation"; + version = "20220707-darcs"; + asds = [ "hu.dwim.web-server.documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; + sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; + system = "hu.dwim.web-server.documentation"; + asd = "hu.dwim.web-server.documentation"; + } + ); + systems = [ "hu.dwim.web-server.documentation" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_presentation" self) + (getAttr "hu_dot_dwim_dot_web-server_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_web-server_dot_test = ( + build-asdf-system { + pname = "hu.dwim.web-server.test"; + version = "20220707-darcs"; + asds = [ "hu.dwim.web-server.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; + sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; + system = "hu.dwim.web-server.test"; + asd = "hu.dwim.web-server.test"; + } + ); + systems = [ "hu.dwim.web-server.test" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_computed-class_plus_hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) + (getAttr "hu_dot_dwim_dot_web-server" self) + (getAttr "hu_dot_dwim_dot_web-server_plus_swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_web-server_dot_websocket = ( + build-asdf-system { + pname = "hu.dwim.web-server.websocket"; + version = "20220707-darcs"; + asds = [ "hu.dwim.web-server.websocket" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.web-server/2022-07-07/hu.dwim.web-server-20220707-darcs.tgz"; + sha256 = "0kz8v5qlyj96rjvqic031f6c405zrpsyqnlkh2mvlsmc7rqg2zjf"; + system = "hu.dwim.web-server.websocket"; + asd = "hu.dwim.web-server.websocket"; + } + ); + systems = [ "hu.dwim.web-server.websocket" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_web-server" self) + (getAttr "ironclad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hu_dot_dwim_dot_zlib = ( + build-asdf-system { + pname = "hu.dwim.zlib"; + version = "stable-git"; + asds = [ "hu.dwim.zlib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hu.dwim.zlib/2022-07-07/hu.dwim.zlib-stable-git.tgz"; + sha256 = "1yrsbl6rmsp6sdaj9yzwx1bpbs529akndxnpplafw31195khnxm1"; + system = "hu.dwim.zlib"; + asd = "hu.dwim.zlib"; + } + ); + systems = [ "hu.dwim.zlib" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + ]; + meta = { + broken = true; + hydraPlatforms = [ ]; + }; + } + ); + huffman = ( + build-asdf-system { + pname = "huffman"; + version = "20181018-git"; + asds = [ "huffman" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/huffman/2018-10-18/huffman-20181018-git.tgz"; + sha256 = "05b3ql5szzi4vsry76i76483mxf9m5i9620hdshykh5rbfiarvcx"; + system = "huffman"; + asd = "huffman"; + } + ); + systems = [ "huffman" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + humbler = ( + build-asdf-system { + pname = "humbler"; + version = "20231021-git"; + asds = [ "humbler" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/humbler/2023-10-21/humbler-20231021-git.tgz"; + sha256 = "15fdvlrhdvr58i2rwa87i4is2rgh9xzjag0sqhga8ri7a8i63fgf"; + system = "humbler"; + asd = "humbler"; + } + ); + systems = [ "humbler" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "local-time" self) + (getAttr "north-core" self) + (getAttr "trivial-mimes" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hunchensocket = ( + build-asdf-system { + pname = "hunchensocket"; + version = "20221106-git"; + asds = [ "hunchensocket" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hunchensocket/2022-11-06/hunchensocket-20221106-git.tgz"; + sha256 = "1vhd009lwl62l1czmhsalblxmyz4x9v3nspjflpajwm1db5rnd7h"; + system = "hunchensocket"; + asd = "hunchensocket"; + } + ); + systems = [ "hunchensocket" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "chunga" self) + (getAttr "cl-base64" self) + (getAttr "cl-fad" self) + (getAttr "flexi-streams" self) + (getAttr "hunchentoot" self) + (getAttr "sha1" self) + (getAttr "trivial-backtrace" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { }; + } + ); + hunchensocket-tests = ( + build-asdf-system { + pname = "hunchensocket-tests"; + version = "20221106-git"; + asds = [ "hunchensocket-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hunchensocket/2022-11-06/hunchensocket-20221106-git.tgz"; + sha256 = "1vhd009lwl62l1czmhsalblxmyz4x9v3nspjflpajwm1db5rnd7h"; + system = "hunchensocket-tests"; + asd = "hunchensocket"; + } + ); + systems = [ "hunchensocket-tests" ]; + lispLibs = [ + (getAttr "fiasco" self) + (getAttr "hunchensocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hunchentools = ( + build-asdf-system { + pname = "hunchentools"; + version = "20161204-git"; + asds = [ "hunchentools" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hunchentools/2016-12-04/hunchentools-20161204-git.tgz"; + sha256 = "12r1ml1xxhyz646nnxqzixfisljjaracwp9jhwl3wb285qbmai4b"; + system = "hunchentools"; + asd = "hunchentools"; + } + ); + systems = [ "hunchentools" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "hunchentoot" self) + (getAttr "ironclad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hunchentoot = ( + build-asdf-system { + pname = "hunchentoot"; + version = "v1.3.1"; + asds = [ "hunchentoot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hunchentoot/2024-10-12/hunchentoot-v1.3.1.tgz"; + sha256 = "0g4lh26l2vd10ilk1hrfmpj6hpjb986jp191ha2j6p2q1pil3kgc"; + system = "hunchentoot"; + asd = "hunchentoot"; + } + ); + systems = [ "hunchentoot" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "chunga" self) + (getAttr "cl_plus_ssl" self) + (getAttr "cl-base64" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "md5" self) + (getAttr "rfc2388" self) + (getAttr "trivial-backtrace" self) + (getAttr "usocket" self) + ]; + meta = { }; + } + ); + hunchentoot-auth = ( + build-asdf-system { + pname = "hunchentoot-auth"; + version = "20140113-git"; + asds = [ "hunchentoot-auth" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hunchentoot-auth/2014-01-13/hunchentoot-auth-20140113-git.tgz"; + sha256 = "1bc70lh2jvk6gqmhczgv0indxk6j5whxbh7gylrlbv16041sdkbj"; + system = "hunchentoot-auth"; + asd = "hunchentoot-auth"; + } + ); + systems = [ "hunchentoot-auth" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-store" self) + (getAttr "cl-who" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hunchentoot-cgi = ( + build-asdf-system { + pname = "hunchentoot-cgi"; + version = "20140211-git"; + asds = [ "hunchentoot-cgi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hunchentoot-cgi/2014-02-11/hunchentoot-cgi-20140211-git.tgz"; + sha256 = "0al6qfs6661avhywsqxh3nwyhl1d1gip3yx57b8siczjarpgpawc"; + system = "hunchentoot-cgi"; + asd = "hunchentoot-cgi"; + } + ); + systems = [ "hunchentoot-cgi" ]; + lispLibs = [ + (getAttr "hunchentoot" self) + (getAttr "puri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hunchentoot-errors = ( + build-asdf-system { + pname = "hunchentoot-errors"; + version = "20231021-git"; + asds = [ "hunchentoot-errors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hunchentoot-errors/2023-10-21/hunchentoot-errors-20231021-git.tgz"; + sha256 = "0fab7s8qhhs713cw014qqvzm5z61wmxm2fcbkarhg41cz3li9k1j"; + system = "hunchentoot-errors"; + asd = "hunchentoot-errors"; + } + ); + systems = [ "hunchentoot-errors" ]; + lispLibs = [ + (getAttr "cl-mimeparse" self) + (getAttr "hunchentoot" self) + (getAttr "parse-number" self) + (getAttr "string-case" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hunchentoot-multi-acceptor = ( + build-asdf-system { + pname = "hunchentoot-multi-acceptor"; + version = "20220331-git"; + asds = [ "hunchentoot-multi-acceptor" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hunchentoot-multi-acceptor/2022-03-31/hunchentoot-multi-acceptor-20220331-git.tgz"; + sha256 = "0m42dw8x0bp03n4hx4ppf45gjg14igf69z4rn7dslch6km58mrha"; + system = "hunchentoot-multi-acceptor"; + asd = "hunchentoot-multi-acceptor"; + } + ); + systems = [ "hunchentoot-multi-acceptor" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "hunchentoot" self) + (getAttr "str" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hunchentoot-single-signon = ( + build-asdf-system { + pname = "hunchentoot-single-signon"; + version = "20131111-git"; + asds = [ "hunchentoot-single-signon" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hunchentoot-single-signon/2013-11-11/hunchentoot-single-signon-20131111-git.tgz"; + sha256 = "0dh16k4105isqwnkl52m55m6cbl7g8wmcrym8175r2zr6qcbghq8"; + system = "hunchentoot-single-signon"; + asd = "hunchentoot-single-signon"; + } + ); + systems = [ "hunchentoot-single-signon" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "cl-gss" self) + (getAttr "hunchentoot" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hunchentoot-stuck-connection-monitor = ( + build-asdf-system { + pname = "hunchentoot-stuck-connection-monitor"; + version = "20241012-git"; + asds = [ "hunchentoot-stuck-connection-monitor" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hunchentoot-stuck-connection-monitor/2024-10-12/hunchentoot-stuck-connection-monitor-20241012-git.tgz"; + sha256 = "1zbpxcym8pi9bf3m7f8f5aa2xhq048kx54sj1ka1vnz7rgccghc6"; + system = "hunchentoot-stuck-connection-monitor"; + asd = "hunchentoot-stuck-connection-monitor"; + } + ); + systems = [ "hunchentoot-stuck-connection-monitor" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "hunchentoot" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hyperlattices = ( + build-asdf-system { + pname = "hyperlattices"; + version = "20231021-git"; + asds = [ "hyperlattices" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hyperlattices/2023-10-21/hyperlattices-20231021-git.tgz"; + sha256 = "1d0jhy7yv5917bgx1b8r8ch5b94zbg933kx8ak2sbpgsf16pqf2h"; + system = "hyperlattices"; + asd = "hyperlattices"; + } + ); + systems = [ "hyperlattices" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "serapeum" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hyperluminal-mem = ( + build-asdf-system { + pname = "hyperluminal-mem"; + version = "20210630-git"; + asds = [ "hyperluminal-mem" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hyperluminal-mem/2021-06-30/hyperluminal-mem-20210630-git.tgz"; + sha256 = "0qp00g43v518j0wccqnpglkrpikagnn9naphb29wbil6k7y9y7r9"; + system = "hyperluminal-mem"; + asd = "hyperluminal-mem"; + } + ); + systems = [ "hyperluminal-mem" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "osicat" self) + (getAttr "stmx" self) + (getAttr "swap-bytes" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hyperluminal-mem-test = ( + build-asdf-system { + pname = "hyperluminal-mem-test"; + version = "20210630-git"; + asds = [ "hyperluminal-mem-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hyperluminal-mem/2021-06-30/hyperluminal-mem-20210630-git.tgz"; + sha256 = "0qp00g43v518j0wccqnpglkrpikagnn9naphb29wbil6k7y9y7r9"; + system = "hyperluminal-mem-test"; + asd = "hyperluminal-mem-test"; + } + ); + systems = [ "hyperluminal-mem-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "hyperluminal-mem" self) + (getAttr "log4cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hyperobject = ( + build-asdf-system { + pname = "hyperobject"; + version = "20201016-git"; + asds = [ "hyperobject" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hyperobject/2020-10-16/hyperobject-20201016-git.tgz"; + sha256 = "1ggqlvwcd52c2d4k8csy7qciaq7lyldi0rpk3b9x4rw4gllcch8n"; + system = "hyperobject"; + asd = "hyperobject"; + } + ); + systems = [ "hyperobject" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "kmrcl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + hyperspec = ( + build-asdf-system { + pname = "hyperspec"; + version = "20181210-git"; + asds = [ "hyperspec" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hyperspec/2018-12-10/hyperspec-20181210-git.tgz"; + sha256 = "0zh1dq2451xw7yiycdr2mrcjx6rgnqnm8c8l9zhhn7hnf51b4x5l"; + system = "hyperspec"; + asd = "hyperspec"; + } + ); + systems = [ "hyperspec" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ia-hash-table = ( + build-asdf-system { + pname = "ia-hash-table"; + version = "20160318-git"; + asds = [ "ia-hash-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ia-hash-table/2016-03-18/ia-hash-table-20160318-git.tgz"; + sha256 = "11wnwjxa528yyjnfsvw315hyvq3lc996dwx83isdg4hlirj3amy4"; + system = "ia-hash-table"; + asd = "ia-hash-table"; + } + ); + systems = [ "ia-hash-table" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ia-hash-table_dot_test = ( + build-asdf-system { + pname = "ia-hash-table.test"; + version = "20160318-git"; + asds = [ "ia-hash-table.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ia-hash-table/2016-03-18/ia-hash-table-20160318-git.tgz"; + sha256 = "11wnwjxa528yyjnfsvw315hyvq3lc996dwx83isdg4hlirj3amy4"; + system = "ia-hash-table.test"; + asd = "ia-hash-table.test"; + } + ); + systems = [ "ia-hash-table.test" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "ia-hash-table" self) + (getAttr "log4cl" self) + (getAttr "mw-equiv" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + iclendar = ( + build-asdf-system { + pname = "iclendar"; + version = "20231021-git"; + asds = [ "iclendar" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/iclendar/2023-10-21/iclendar-20231021-git.tgz"; + sha256 = "13ic0zlwrlf6k08x7c8v96kjpbh1dmap15q4cv4in7rkx6rn2rsa"; + system = "iclendar"; + asd = "iclendar"; + } + ); + systems = [ "iclendar" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "closer-mop" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + iconv = ( + build-asdf-system { + pname = "iconv"; + version = "20171227-git"; + asds = [ "iconv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-iconv/2017-12-27/cl-iconv-20171227-git.tgz"; + sha256 = "1lpw95c02inifhdh9kkab9q92i5w9zd788dww1wly2p0a6kyx9wg"; + system = "iconv"; + asd = "iconv"; + } + ); + systems = [ "iconv" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + id3v2 = ( + build-asdf-system { + pname = "id3v2"; + version = "20160208-git"; + asds = [ "id3v2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/id3v2/2016-02-08/id3v2-20160208-git.tgz"; + sha256 = "0x017dfh9m80b8ml2vsgdcfs4kv7p06yzmwdilf1k8nfsilwpfra"; + system = "id3v2"; + asd = "id3v2"; + } + ); + systems = [ "id3v2" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + id3v2-test = ( + build-asdf-system { + pname = "id3v2-test"; + version = "20160208-git"; + asds = [ "id3v2-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/id3v2/2016-02-08/id3v2-20160208-git.tgz"; + sha256 = "0x017dfh9m80b8ml2vsgdcfs4kv7p06yzmwdilf1k8nfsilwpfra"; + system = "id3v2-test"; + asd = "id3v2-test"; + } + ); + systems = [ "id3v2-test" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "id3v2" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + identifier-pool = ( + build-asdf-system { + pname = "identifier-pool"; + version = "20220707-git"; + asds = [ "identifier-pool" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/identifier-pool/2022-07-07/identifier-pool-20220707-git.tgz"; + sha256 = "01fs960s02nf8m3a5v95r12magq9rvgcc3awcppqa7c8yg7qdc55"; + system = "identifier-pool"; + asd = "identifier-pool"; + } + ); + systems = [ "identifier-pool" ]; + lispLibs = [ + (getAttr "dynamic-array" self) + (getAttr "mfiano-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + idna = ( + build-asdf-system { + pname = "idna"; + version = "20120107-git"; + asds = [ "idna" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/idna/2012-01-07/idna-20120107-git.tgz"; + sha256 = "00nbr3mffxhlq14gg9d16pa6691s4qh35inyw76v906s77khm5a2"; + system = "idna"; + asd = "idna"; + } + ); + systems = [ "idna" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { }; + } + ); + ieee-floats = ( + build-asdf-system { + pname = "ieee-floats"; + version = "20220220-git"; + asds = [ "ieee-floats" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ieee-floats/2022-02-20/ieee-floats-20220220-git.tgz"; + sha256 = "0qp2dxq9jzndjfmc8nh0fvcwrrxjm7f012biczipifjckp9gxw7d"; + system = "ieee-floats"; + asd = "ieee-floats"; + } + ); + systems = [ "ieee-floats" ]; + lispLibs = [ ]; + meta = { }; + } + ); + illogical-pathnames = ( + build-asdf-system { + pname = "illogical-pathnames"; + version = "20160825-git"; + asds = [ "illogical-pathnames" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/illogical-pathnames/2016-08-25/illogical-pathnames-20160825-git.tgz"; + sha256 = "1yjs1lzgak1d3hz2q6sbac98vqgdxp0dz72fskpz73vrbp6h6da5"; + system = "illogical-pathnames"; + asd = "illogical-pathnames"; + } + ); + systems = [ "illogical-pathnames" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + illusion = ( + build-asdf-system { + pname = "illusion"; + version = "20180831-git"; + asds = [ "illusion" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/illusion/2018-08-31/illusion-20180831-git.tgz"; + sha256 = "05wik6q8hlhm7szzymkljfigcp7z35j6rz2ihsmng1y6zq9crk7z"; + system = "illusion"; + asd = "illusion"; + } + ); + systems = [ "illusion" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "let-over-lambda" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + illusion-test = ( + build-asdf-system { + pname = "illusion-test"; + version = "20180831-git"; + asds = [ "illusion-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/illusion/2018-08-31/illusion-20180831-git.tgz"; + sha256 = "05wik6q8hlhm7szzymkljfigcp7z35j6rz2ihsmng1y6zq9crk7z"; + system = "illusion-test"; + asd = "illusion-test"; + } + ); + systems = [ "illusion-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "illusion" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + image = ( + build-asdf-system { + pname = "image"; + version = "20120107-git"; + asds = [ "image" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/image/2012-01-07/image-20120107-git.tgz"; + sha256 = "04by1snzw2kpw208fdi2azxbq5y2q2r6x8zkdh7jk43amkr18f5k"; + system = "image"; + asd = "image"; + } + ); + systems = [ "image" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "gzip-stream" self) + (getAttr "skippy" self) + (getAttr "zpng" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + image-test = ( + build-asdf-system { + pname = "image-test"; + version = "20211020-git"; + asds = [ "image-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-png/2021-10-20/cl-png-20211020-git.tgz"; + sha256 = "17xcb9ps5vf3if61blmx7cpfrz3gsw7jk8d5zv3f4cq8jrriqdx4"; + system = "image-test"; + asd = "image-test"; + } + ); + systems = [ "image-test" ]; + lispLibs = [ (getAttr "png" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + image-utility = ( + build-asdf-system { + pname = "image-utility"; + version = "20200427-git"; + asds = [ "image-utility" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "image-utility"; + asd = "image-utility"; + } + ); + systems = [ "image-utility" ]; + lispLibs = [ (getAttr "opticl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + imago = ( + build-asdf-system { + pname = "imago"; + version = "20241012-git"; + asds = [ "imago" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/imago/2024-10-12/imago-20241012-git.tgz"; + sha256 = "1jhhlqbzdd68n8scl98dxfr92s1rgd43isgd317l3ynfjwz63wq1"; + system = "imago"; + asd = "imago"; + } + ); + systems = [ "imago" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "array-operations" self) + (getAttr "cl-jpeg" self) + (getAttr "flexi-streams" self) + (getAttr "serapeum" self) + (getAttr "trivial-gray-streams" self) + (getAttr "zlib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + immutable-struct = ( + build-asdf-system { + pname = "immutable-struct"; + version = "20150709-git"; + asds = [ "immutable-struct" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/immutable-struct/2015-07-09/immutable-struct-20150709-git.tgz"; + sha256 = "02868d21hcc0kc3jw8afx23kj6iy1vyf2pddn8yqfrkpldhd0rv9"; + system = "immutable-struct"; + asd = "immutable-struct"; + } + ); + systems = [ "immutable-struct" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + in-nomine = ( + build-asdf-system { + pname = "in-nomine"; + version = "20241012-git"; + asds = [ "in-nomine" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/in-nomine/2024-10-12/in-nomine-20241012-git.tgz"; + sha256 = "1wcfxqj5dfmkg94rnz2nsmyw8iwicncxmklnirlngqqvlcrd0rv4"; + system = "in-nomine"; + asd = "in-nomine"; + } + ); + systems = [ "in-nomine" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-arguments" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + incf-cl = ( + build-asdf-system { + pname = "incf-cl"; + version = "20190710-git"; + asds = [ "incf-cl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/incf-cl/2019-07-10/incf-cl-20190710-git.tgz"; + sha256 = "1yvwb57dzccvd2lw2h3mwxgbi8ml3cgkyy8kl8hwhd4s8c016ibb"; + system = "incf-cl"; + asd = "incf-cl"; + } + ); + systems = [ "incf-cl" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + incless = ( + build-asdf-system { + pname = "incless"; + version = "20241012-git"; + asds = [ "incless" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/incless/2024-10-12/incless-20241012-git.tgz"; + sha256 = "1ypxhsx3fqwfng3b425bsgxbra7asny9261amdbfd6p59r51cyiy"; + system = "incless"; + asd = "incless"; + } + ); + systems = [ "incless" ]; + lispLibs = [ (getAttr "quaviver" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + incless-extrinsic = ( + build-asdf-system { + pname = "incless-extrinsic"; + version = "20241012-git"; + asds = [ "incless-extrinsic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/incless/2024-10-12/incless-20241012-git.tgz"; + sha256 = "1ypxhsx3fqwfng3b425bsgxbra7asny9261amdbfd6p59r51cyiy"; + system = "incless-extrinsic"; + asd = "incless-extrinsic"; + } + ); + systems = [ "incless-extrinsic" ]; + lispLibs = [ + (getAttr "incless" self) + (getAttr "quaviver" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + incless-native = ( + build-asdf-system { + pname = "incless-native"; + version = "20241012-git"; + asds = [ "incless-native" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/incless/2024-10-12/incless-20241012-git.tgz"; + sha256 = "1ypxhsx3fqwfng3b425bsgxbra7asny9261amdbfd6p59r51cyiy"; + system = "incless-native"; + asd = "incless-native"; + } + ); + systems = [ "incless-native" ]; + lispLibs = [ (getAttr "incless" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + incognito-keywords = ( + build-asdf-system { + pname = "incognito-keywords"; + version = "1.1"; + asds = [ "incognito-keywords" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/incognito-keywords/2013-01-28/incognito-keywords-1.1.tgz"; + sha256 = "1ignvz8v7bq8z9x22skzp1xsna2bxqcw22zh5sp9v2ndbjhqri5c"; + system = "incognito-keywords"; + asd = "incognito-keywords"; + } + ); + systems = [ "incognito-keywords" ]; + lispLibs = [ + (getAttr "enhanced-eval-when" self) + (getAttr "map-bind" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + incongruent-methods = ( + build-asdf-system { + pname = "incongruent-methods"; + version = "20130312-git"; + asds = [ "incongruent-methods" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/incongruent-methods/2013-03-12/incongruent-methods-20130312-git.tgz"; + sha256 = "15xfbpnqymbkk92vbirvccxcphyvjmxcw02yv1zs6c78aaf4ms9z"; + system = "incongruent-methods"; + asd = "incongruent-methods"; + } + ); + systems = [ "incongruent-methods" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inferior-shell = ( + build-asdf-system { + pname = "inferior-shell"; + version = "20241012-git"; + asds = [ "inferior-shell" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inferior-shell/2024-10-12/inferior-shell-20241012-git.tgz"; + sha256 = "1bmw0jjcpssahymqidz159pqbz5ficz56w7b97hfy1xnwkd2fwg5"; + system = "inferior-shell"; + asd = "inferior-shell"; + } + ); + systems = [ "inferior-shell" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "fare-mop" self) + (getAttr "fare-quasiquote-extras" self) + (getAttr "fare-utils" self) + (getAttr "trivia" self) + (getAttr "trivia_dot_quasiquote" self) + ]; + meta = { }; + } + ); + infix = ( + build-asdf-system { + pname = "infix"; + version = "20210411-git"; + asds = [ "infix" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; + sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; + system = "infix"; + asd = "infix"; + } + ); + systems = [ "infix" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + infix-dollar-reader = ( + build-asdf-system { + pname = "infix-dollar-reader"; + version = "20121013-git"; + asds = [ "infix-dollar-reader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/infix-dollar-reader/2012-10-13/infix-dollar-reader-20121013-git.tgz"; + sha256 = "11sf4kqcw8s0zcjz1qpbhkn33rizvq5ijl6xp59q9wadvkd0wx0w"; + system = "infix-dollar-reader"; + asd = "infix-dollar-reader"; + } + ); + systems = [ "infix-dollar-reader" ]; + lispLibs = [ (getAttr "cl-syntax" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + infix-dollar-reader-test = ( + build-asdf-system { + pname = "infix-dollar-reader-test"; + version = "20121013-git"; + asds = [ "infix-dollar-reader-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/infix-dollar-reader/2012-10-13/infix-dollar-reader-20121013-git.tgz"; + sha256 = "11sf4kqcw8s0zcjz1qpbhkn33rizvq5ijl6xp59q9wadvkd0wx0w"; + system = "infix-dollar-reader-test"; + asd = "infix-dollar-reader-test"; + } + ); + systems = [ "infix-dollar-reader-test" ]; + lispLibs = [ + (getAttr "infix-dollar-reader" self) + (getAttr "rt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + infix-math = ( + build-asdf-system { + pname = "infix-math"; + version = "20211020-git"; + asds = [ "infix-math" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/infix-math/2021-10-20/infix-math-20211020-git.tgz"; + sha256 = "1h6p254xl793wfq3qla5y95k6zimy477f8brblx6ran3rg3bydbg"; + system = "infix-math"; + asd = "infix-math"; + } + ); + systems = [ "infix-math" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "asdf-package-system" self) + (getAttr "parse-number" self) + (getAttr "serapeum" self) + (getAttr "wu-decimal" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + infix-reader = ( + build-asdf-system { + pname = "infix-reader"; + version = "20221106-git"; + asds = [ "infix-reader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/infix-reader/2022-11-06/infix-reader-20221106-git.tgz"; + sha256 = "16b6cw4w80p3yxsv0pqaiq0ay1v3jswlav2mlfsmhawpvhxsmb7z"; + system = "infix-reader"; + asd = "infix-reader"; + } + ); + systems = [ "infix-reader" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inheriting-readers = ( + build-asdf-system { + pname = "inheriting-readers"; + version = "1.0.1"; + asds = [ "inheriting-readers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inheriting-readers/2021-01-24/inheriting-readers_1.0.1.tgz"; + sha256 = "0km3mq6vx1q9qv6j3r4sqqcsdbnb5jar66bl0mzzpaacfvzbx68p"; + system = "inheriting-readers"; + asd = "inheriting-readers"; + } + ); + systems = [ "inheriting-readers" ]; + lispLibs = [ + (getAttr "class-options" self) + (getAttr "closer-mop" self) + (getAttr "compatible-metaclasses" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inheriting-readers__tests = ( + build-asdf-system { + pname = "inheriting-readers_tests"; + version = "1.0.1"; + asds = [ "inheriting-readers_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inheriting-readers/2021-01-24/inheriting-readers_1.0.1.tgz"; + sha256 = "0km3mq6vx1q9qv6j3r4sqqcsdbnb5jar66bl0mzzpaacfvzbx68p"; + system = "inheriting-readers_tests"; + asd = "inheriting-readers_tests"; + } + ); + systems = [ "inheriting-readers_tests" ]; + lispLibs = [ + (getAttr "compatible-metaclasses" self) + (getAttr "inheriting-readers" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + injection = ( + build-asdf-system { + pname = "injection"; + version = "20160531-git"; + asds = [ "injection" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/injection/2016-05-31/injection-20160531-git.tgz"; + sha256 = "12f838ikgyl7gzh2dnqh54hfa8rncbkk266bsibmbbqxz0cn2da7"; + system = "injection"; + asd = "injection"; + } + ); + systems = [ "injection" ]; + lispLibs = [ (getAttr "cl-yaml" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + injection-test = ( + build-asdf-system { + pname = "injection-test"; + version = "20160531-git"; + asds = [ "injection-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/injection/2016-05-31/injection-20160531-git.tgz"; + sha256 = "12f838ikgyl7gzh2dnqh54hfa8rncbkk266bsibmbbqxz0cn2da7"; + system = "injection-test"; + asd = "injection-test"; + } + ); + systems = [ "injection-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "injection" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inkwell = ( + build-asdf-system { + pname = "inkwell"; + version = "20231021-git"; + asds = [ "inkwell" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inkwell/2023-10-21/inkwell-20231021-git.tgz"; + sha256 = "07yxgs2zfnyr158v8q2s4npvzjzmpifx61hg7fc17dsmqgw296yc"; + system = "inkwell"; + asd = "inkwell"; + } + ); + systems = [ "inkwell" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "documentation-utils" self) + (getAttr "drakma" self) + (getAttr "local-time" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inlined-generic-function = ( + build-asdf-system { + pname = "inlined-generic-function"; + version = "20190521-git"; + asds = [ "inlined-generic-function" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inlined-generic-function/2019-05-21/inlined-generic-function-20190521-git.tgz"; + sha256 = "0kj9p99m9hwx4lx95npfln5dc5ip884f8agjc6h4y0rhnpj7r8gk"; + system = "inlined-generic-function"; + asd = "inlined-generic-function"; + } + ); + systems = [ "inlined-generic-function" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "introspect-environment" self) + (getAttr "iterate" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inlined-generic-function_dot_test = ( + build-asdf-system { + pname = "inlined-generic-function.test"; + version = "20190521-git"; + asds = [ "inlined-generic-function.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inlined-generic-function/2019-05-21/inlined-generic-function-20190521-git.tgz"; + sha256 = "0kj9p99m9hwx4lx95npfln5dc5ip884f8agjc6h4y0rhnpj7r8gk"; + system = "inlined-generic-function.test"; + asd = "inlined-generic-function.test"; + } + ); + systems = [ "inlined-generic-function.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "inlined-generic-function" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inner-conditional = ( + build-asdf-system { + pname = "inner-conditional"; + version = "20200925-git"; + asds = [ "inner-conditional" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inner-conditional/2020-09-25/inner-conditional-20200925-git.tgz"; + sha256 = "08vaq29l2bhv4n1c6zb3syddwpad66rghfy71fqidjvbag0ji71k"; + system = "inner-conditional"; + asd = "inner-conditional"; + } + ); + systems = [ "inner-conditional" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-syntax-annot" self) + (getAttr "iterate" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inner-conditional-test = ( + build-asdf-system { + pname = "inner-conditional-test"; + version = "20200925-git"; + asds = [ "inner-conditional-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inner-conditional/2020-09-25/inner-conditional-20200925-git.tgz"; + sha256 = "08vaq29l2bhv4n1c6zb3syddwpad66rghfy71fqidjvbag0ji71k"; + system = "inner-conditional-test"; + asd = "inner-conditional-test"; + } + ); + systems = [ "inner-conditional-test" ]; + lispLibs = [ + (getAttr "cl-test-more" self) + (getAttr "inner-conditional" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inotify = ( + build-asdf-system { + pname = "inotify"; + version = "20150608-git"; + asds = [ "inotify" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inotify/2015-06-08/inotify-20150608-git.tgz"; + sha256 = "0jill05wsa7xbnkycc1ik1a05slv2h34fpyap2rxbnxvfjvyzw98"; + system = "inotify"; + asd = "inotify"; + } + ); + systems = [ "inotify" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "iolib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + input-event-codes = ( + build-asdf-system { + pname = "input-event-codes"; + version = "20221106-git"; + asds = [ "input-event-codes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/input-event-codes/2022-11-06/input-event-codes-20221106-git.tgz"; + sha256 = "1m96m9ia4frcn2xqaw4mfspjjzwl8gyj4k4rv0lq28va4s6mkgii"; + system = "input-event-codes"; + asd = "input-event-codes"; + } + ); + systems = [ "input-event-codes" ]; + lispLibs = [ (getAttr "trivial-features" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inquisitor = ( + build-asdf-system { + pname = "inquisitor"; + version = "20190521-git"; + asds = [ "inquisitor" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inquisitor/2019-05-21/inquisitor-20190521-git.tgz"; + sha256 = "08rkmqnwlq6v84wcz9yp31j5lxrsy33kv3dh7n3ccsg4kc54slzw"; + system = "inquisitor"; + asd = "inquisitor"; + } + ); + systems = [ "inquisitor" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inquisitor-flexi = ( + build-asdf-system { + pname = "inquisitor-flexi"; + version = "20190521-git"; + asds = [ "inquisitor-flexi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inquisitor/2019-05-21/inquisitor-20190521-git.tgz"; + sha256 = "08rkmqnwlq6v84wcz9yp31j5lxrsy33kv3dh7n3ccsg4kc54slzw"; + system = "inquisitor-flexi"; + asd = "inquisitor-flexi"; + } + ); + systems = [ "inquisitor-flexi" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "inquisitor" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inquisitor-flexi-test = ( + build-asdf-system { + pname = "inquisitor-flexi-test"; + version = "20190521-git"; + asds = [ "inquisitor-flexi-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inquisitor/2019-05-21/inquisitor-20190521-git.tgz"; + sha256 = "08rkmqnwlq6v84wcz9yp31j5lxrsy33kv3dh7n3ccsg4kc54slzw"; + system = "inquisitor-flexi-test"; + asd = "inquisitor-flexi-test"; + } + ); + systems = [ "inquisitor-flexi-test" ]; + lispLibs = [ + (getAttr "inquisitor-flexi" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inquisitor-test = ( + build-asdf-system { + pname = "inquisitor-test"; + version = "20190521-git"; + asds = [ "inquisitor-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inquisitor/2019-05-21/inquisitor-20190521-git.tgz"; + sha256 = "08rkmqnwlq6v84wcz9yp31j5lxrsy33kv3dh7n3ccsg4kc54slzw"; + system = "inquisitor-test"; + asd = "inquisitor-test"; + } + ); + systems = [ "inquisitor-test" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "flexi-streams" self) + (getAttr "inquisitor" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inravina = ( + build-asdf-system { + pname = "inravina"; + version = "20241012-git"; + asds = [ "inravina" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inravina/2024-10-12/inravina-20241012-git.tgz"; + sha256 = "16kbxzsbb4vdhbf1dzgsgwj9n3cizk3sjixjgrfa8fal4nys7sa3"; + system = "inravina"; + asd = "inravina"; + } + ); + systems = [ "inravina" ]; + lispLibs = [ + (getAttr "incless" self) + (getAttr "nontrivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inravina-examples = ( + build-asdf-system { + pname = "inravina-examples"; + version = "20241012-git"; + asds = [ "inravina-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inravina/2024-10-12/inravina-20241012-git.tgz"; + sha256 = "16kbxzsbb4vdhbf1dzgsgwj9n3cizk3sjixjgrfa8fal4nys7sa3"; + system = "inravina-examples"; + asd = "inravina-examples"; + } + ); + systems = [ "inravina-examples" ]; + lispLibs = [ + (getAttr "cl-pdf" self) + (getAttr "inravina-extrinsic" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inravina-extrinsic = ( + build-asdf-system { + pname = "inravina-extrinsic"; + version = "20241012-git"; + asds = [ "inravina-extrinsic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inravina/2024-10-12/inravina-20241012-git.tgz"; + sha256 = "16kbxzsbb4vdhbf1dzgsgwj9n3cizk3sjixjgrfa8fal4nys7sa3"; + system = "inravina-extrinsic"; + asd = "inravina-extrinsic"; + } + ); + systems = [ "inravina-extrinsic" ]; + lispLibs = [ + (getAttr "incless-extrinsic" self) + (getAttr "inravina" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inravina-native = ( + build-asdf-system { + pname = "inravina-native"; + version = "20241012-git"; + asds = [ "inravina-native" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inravina/2024-10-12/inravina-20241012-git.tgz"; + sha256 = "16kbxzsbb4vdhbf1dzgsgwj9n3cizk3sjixjgrfa8fal4nys7sa3"; + system = "inravina-native"; + asd = "inravina-native"; + } + ); + systems = [ "inravina-native" ]; + lispLibs = [ (getAttr "inravina" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + inravina-shim = ( + build-asdf-system { + pname = "inravina-shim"; + version = "20241012-git"; + asds = [ "inravina-shim" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/inravina/2024-10-12/inravina-20241012-git.tgz"; + sha256 = "16kbxzsbb4vdhbf1dzgsgwj9n3cizk3sjixjgrfa8fal4nys7sa3"; + system = "inravina-shim"; + asd = "inravina-shim"; + } + ); + systems = [ "inravina-shim" ]; + lispLibs = [ + (getAttr "incless-native" self) + (getAttr "inravina" self) + (getAttr "trivial-package-locks" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + instance-tracking = ( + build-asdf-system { + pname = "instance-tracking"; + version = "20221106-git"; + asds = [ "instance-tracking" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/instance-tracking/2022-11-06/instance-tracking-20221106-git.tgz"; + sha256 = "0bbxvl14ahws30x5dgjhilhybjgn1jfcbxwr8ji1ls31zf88fphr"; + system = "instance-tracking"; + asd = "instance-tracking"; + } + ); + systems = [ "instance-tracking" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + integral = ( + build-asdf-system { + pname = "integral"; + version = "20200325-git"; + asds = [ "integral" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/integral/2020-03-25/integral-20200325-git.tgz"; + sha256 = "17a9wg7n3f81fsi5mlsdxain1fw7ggfniipfrb9sr1ajff6lx9gs"; + system = "integral"; + asd = "integral"; + } + ); + systems = [ "integral" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-syntax-annot" self) + (getAttr "clos-fixtures" self) + (getAttr "closer-mop" self) + (getAttr "dbi" self) + (getAttr "group-by" self) + (getAttr "iterate" self) + (getAttr "split-sequence" self) + (getAttr "sxql" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + integral-rest = ( + build-asdf-system { + pname = "integral-rest"; + version = "20150923-git"; + asds = [ "integral-rest" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/integral-rest/2015-09-23/integral-rest-20150923-git.tgz"; + sha256 = "0187d9i7acw2v1hhy7wcz0vk90ji7cdgpaikb7admvzq0nnbzrmm"; + system = "integral-rest"; + asd = "integral-rest"; + } + ); + systems = [ "integral-rest" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-inflector" self) + (getAttr "closer-mop" self) + (getAttr "integral" self) + (getAttr "jonathan" self) + (getAttr "map-set" self) + (getAttr "ningle" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + integral-rest-test = ( + build-asdf-system { + pname = "integral-rest-test"; + version = "20150923-git"; + asds = [ "integral-rest-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/integral-rest/2015-09-23/integral-rest-20150923-git.tgz"; + sha256 = "0187d9i7acw2v1hhy7wcz0vk90ji7cdgpaikb7admvzq0nnbzrmm"; + system = "integral-rest-test"; + asd = "integral-rest-test"; + } + ); + systems = [ "integral-rest-test" ]; + lispLibs = [ + (getAttr "integral" self) + (getAttr "integral-rest" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + integral-test = ( + build-asdf-system { + pname = "integral-test"; + version = "20200325-git"; + asds = [ "integral-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/integral/2020-03-25/integral-20200325-git.tgz"; + sha256 = "17a9wg7n3f81fsi5mlsdxain1fw7ggfniipfrb9sr1ajff6lx9gs"; + system = "integral-test"; + asd = "integral-test"; + } + ); + systems = [ "integral-test" ]; + lispLibs = [ + (getAttr "integral" self) + (getAttr "local-time" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + intel-hex = ( + build-asdf-system { + pname = "intel-hex"; + version = "20160318-git"; + asds = [ "intel-hex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/intel-hex/2016-03-18/intel-hex-20160318-git.tgz"; + sha256 = "0sz51qw262nh6ziwpy1kgv257nj56rp42s0g6g2rx3xv1ijdy395"; + system = "intel-hex"; + asd = "intel-hex"; + } + ); + systems = [ "intel-hex" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + intel-hex-test = ( + build-asdf-system { + pname = "intel-hex-test"; + version = "20160318-git"; + asds = [ "intel-hex-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/intel-hex/2016-03-18/intel-hex-20160318-git.tgz"; + sha256 = "0sz51qw262nh6ziwpy1kgv257nj56rp42s0g6g2rx3xv1ijdy395"; + system = "intel-hex-test"; + asd = "intel-hex-test"; + } + ); + systems = [ "intel-hex-test" ]; + lispLibs = [ + (getAttr "intel-hex" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + intercom = ( + build-asdf-system { + pname = "intercom"; + version = "20130615-git"; + asds = [ "intercom" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/intercom/2013-06-15/intercom-20130615-git.tgz"; + sha256 = "017klgjsza4cxdxms4hxgrfrwjshkcr2yyxnhg14zs9w0vjwkikl"; + system = "intercom"; + asd = "intercom"; + } + ); + systems = [ "intercom" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "hunchentoot" self) + (getAttr "jsown" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + intercom-examples = ( + build-asdf-system { + pname = "intercom-examples"; + version = "20130615-git"; + asds = [ "intercom-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/intercom/2013-06-15/intercom-20130615-git.tgz"; + sha256 = "017klgjsza4cxdxms4hxgrfrwjshkcr2yyxnhg14zs9w0vjwkikl"; + system = "intercom-examples"; + asd = "intercom-examples"; + } + ); + systems = [ "intercom-examples" ]; + lispLibs = [ + (getAttr "intercom" self) + (getAttr "jsown" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + interface = ( + build-asdf-system { + pname = "interface"; + version = "20230618-git"; + asds = [ "interface" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/interface/2023-06-18/interface-20230618-git.tgz"; + sha256 = "0h1bckhyig2znl6nrd3agjzz7knrm2kyh2vfyk7j60kzki9rpzxy"; + system = "interface"; + asd = "interface"; + } + ); + systems = [ "interface" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "global-vars" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + interfaces-test-implementation = ( + build-asdf-system { + pname = "interfaces-test-implementation"; + version = "20231021-git"; + asds = [ "interfaces-test-implementation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/modularize-interfaces/2023-10-21/modularize-interfaces-20231021-git.tgz"; + sha256 = "0lmq2jbkbr5wrrjl2qb1x64fcvl0lmii0h9301b9bq4d47s4w8sh"; + system = "interfaces-test-implementation"; + asd = "interfaces-test-implementation"; + } + ); + systems = [ "interfaces-test-implementation" ]; + lispLibs = [ + (getAttr "modularize" self) + (getAttr "modularize-interfaces" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + introspect-environment = ( + build-asdf-system { + pname = "introspect-environment"; + version = "20241012-git"; + asds = [ "introspect-environment" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/introspect-environment/2024-10-12/introspect-environment-20241012-git.tgz"; + sha256 = "1jll8h1fmf9i8nk3j3hrh62s858fzmly22zb690a2hnb685w3zlf"; + system = "introspect-environment"; + asd = "introspect-environment"; + } + ); + systems = [ "introspect-environment" ]; + lispLibs = [ ]; + meta = { }; + } + ); + introspect-environment-test = ( + build-asdf-system { + pname = "introspect-environment-test"; + version = "20241012-git"; + asds = [ "introspect-environment-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/introspect-environment/2024-10-12/introspect-environment-20241012-git.tgz"; + sha256 = "1jll8h1fmf9i8nk3j3hrh62s858fzmly22zb690a2hnb685w3zlf"; + system = "introspect-environment-test"; + asd = "introspect-environment-test"; + } + ); + systems = [ "introspect-environment-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "introspect-environment" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + invistra = ( + build-asdf-system { + pname = "invistra"; + version = "20241012-git"; + asds = [ "invistra" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/invistra/2024-10-12/invistra-20241012-git.tgz"; + sha256 = "14ja35zqa85hjl9wxkwrff2wnlfflxi6lnkw0ic7jp7b59f80qas"; + system = "invistra"; + asd = "invistra"; + } + ); + systems = [ "invistra" ]; + lispLibs = [ + (getAttr "acclimation" self) + (getAttr "incless" self) + (getAttr "inravina" self) + (getAttr "nontrivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + invistra-extrinsic = ( + build-asdf-system { + pname = "invistra-extrinsic"; + version = "20241012-git"; + asds = [ "invistra-extrinsic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/invistra/2024-10-12/invistra-20241012-git.tgz"; + sha256 = "14ja35zqa85hjl9wxkwrff2wnlfflxi6lnkw0ic7jp7b59f80qas"; + system = "invistra-extrinsic"; + asd = "invistra-extrinsic"; + } + ); + systems = [ "invistra-extrinsic" ]; + lispLibs = [ + (getAttr "inravina-extrinsic" self) + (getAttr "invistra" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + invistra-numeral = ( + build-asdf-system { + pname = "invistra-numeral"; + version = "20241012-git"; + asds = [ "invistra-numeral" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/invistra/2024-10-12/invistra-20241012-git.tgz"; + sha256 = "14ja35zqa85hjl9wxkwrff2wnlfflxi6lnkw0ic7jp7b59f80qas"; + system = "invistra-numeral"; + asd = "invistra-numeral"; + } + ); + systems = [ "invistra-numeral" ]; + lispLibs = [ (getAttr "invistra" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + iolib = ( + build-asdf-system { + pname = "iolib"; + version = "v0.8.4"; + asds = [ "iolib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/iolib/2021-06-30/iolib-v0.8.4.tgz"; + sha256 = "1f43jqqqwp9n7xksqxw91myapsdbc2dxck6nd6flakbnp9haylyq"; + system = "iolib"; + asd = "iolib"; + } + ); + systems = [ "iolib" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "idna" self) + (getAttr "iolib_dot_asdf" self) + (getAttr "iolib_dot_base" self) + (getAttr "iolib_dot_conf" self) + (getAttr "swap-bytes" self) + (getAttr "trivial-features" self) + ]; + meta = { }; + } + ); + iolib_dot_asdf = ( + build-asdf-system { + pname = "iolib.asdf"; + version = "v0.8.4"; + asds = [ "iolib.asdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/iolib/2021-06-30/iolib-v0.8.4.tgz"; + sha256 = "1f43jqqqwp9n7xksqxw91myapsdbc2dxck6nd6flakbnp9haylyq"; + system = "iolib.asdf"; + asd = "iolib.asdf"; + } + ); + systems = [ "iolib.asdf" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { }; + } + ); + iolib_dot_base = ( + build-asdf-system { + pname = "iolib.base"; + version = "v0.8.4"; + asds = [ "iolib.base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/iolib/2021-06-30/iolib-v0.8.4.tgz"; + sha256 = "1f43jqqqwp9n7xksqxw91myapsdbc2dxck6nd6flakbnp9haylyq"; + system = "iolib.base"; + asd = "iolib.base"; + } + ); + systems = [ "iolib.base" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iolib_dot_asdf" self) + (getAttr "iolib_dot_common-lisp" self) + (getAttr "iolib_dot_conf" self) + (getAttr "split-sequence" self) + ]; + meta = { }; + } + ); + iolib_dot_common-lisp = ( + build-asdf-system { + pname = "iolib.common-lisp"; + version = "v0.8.4"; + asds = [ "iolib.common-lisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/iolib/2021-06-30/iolib-v0.8.4.tgz"; + sha256 = "1f43jqqqwp9n7xksqxw91myapsdbc2dxck6nd6flakbnp9haylyq"; + system = "iolib.common-lisp"; + asd = "iolib.common-lisp"; + } + ); + systems = [ "iolib.common-lisp" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iolib_dot_asdf" self) + (getAttr "iolib_dot_conf" self) + ]; + meta = { }; + } + ); + iolib_dot_conf = ( + build-asdf-system { + pname = "iolib.conf"; + version = "v0.8.4"; + asds = [ "iolib.conf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/iolib/2021-06-30/iolib-v0.8.4.tgz"; + sha256 = "1f43jqqqwp9n7xksqxw91myapsdbc2dxck6nd6flakbnp9haylyq"; + system = "iolib.conf"; + asd = "iolib.conf"; + } + ); + systems = [ "iolib.conf" ]; + lispLibs = [ (getAttr "iolib_dot_asdf" self) ]; + meta = { }; + } + ); + iolib_dot_examples = ( + build-asdf-system { + pname = "iolib.examples"; + version = "v0.8.4"; + asds = [ "iolib.examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/iolib/2021-06-30/iolib-v0.8.4.tgz"; + sha256 = "1f43jqqqwp9n7xksqxw91myapsdbc2dxck6nd6flakbnp9haylyq"; + system = "iolib.examples"; + asd = "iolib.examples"; + } + ); + systems = [ "iolib.examples" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "iolib" self) + (getAttr "iolib_dot_asdf" self) + (getAttr "iolib_dot_base" self) + (getAttr "iolib_dot_conf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ip-interfaces = ( + build-asdf-system { + pname = "ip-interfaces"; + version = "0.2.1"; + asds = [ "ip-interfaces" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ip-interfaces/2018-12-10/ip-interfaces-0.2.1.tgz"; + sha256 = "035sc4li0qz4lzjn555h8r2qkhc8a65zglk30f1b3pi9p44g91mw"; + system = "ip-interfaces"; + asd = "ip-interfaces"; + } + ); + systems = [ "ip-interfaces" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ip-interfaces-test = ( + build-asdf-system { + pname = "ip-interfaces-test"; + version = "0.2.1"; + asds = [ "ip-interfaces-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ip-interfaces/2018-12-10/ip-interfaces-0.2.1.tgz"; + sha256 = "035sc4li0qz4lzjn555h8r2qkhc8a65zglk30f1b3pi9p44g91mw"; + system = "ip-interfaces-test"; + asd = "ip-interfaces-test"; + } + ); + systems = [ "ip-interfaces-test" ]; + lispLibs = [ + (getAttr "ip-interfaces" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + irc-logger = ( + build-asdf-system { + pname = "irc-logger"; + version = "20150923-git"; + asds = [ "irc-logger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/irc-logger/2015-09-23/irc-logger-20150923-git.tgz"; + sha256 = "1ylq8qnf29dij7133p19cmmmw3i7w6azncsdvpd4j0k1fqp14bq7"; + system = "irc-logger"; + asd = "irc-logger"; + } + ); + systems = [ "irc-logger" ]; + lispLibs = [ + (getAttr "cl-irc" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ironclad = ( + build-asdf-system { + pname = "ironclad"; + version = "v0.61"; + asds = [ "ironclad" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ironclad/2024-10-12/ironclad-v0.61.tgz"; + sha256 = "1yszjy6a0q1jvdgd7fpmnvi9851s8ivp4plscw27lbnl7jlj1pmk"; + system = "ironclad"; + asd = "ironclad"; + } + ); + systems = [ "ironclad" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { }; + } + ); + ironclad-text = ( + build-asdf-system { + pname = "ironclad-text"; + version = "v0.61"; + asds = [ "ironclad-text" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ironclad/2024-10-12/ironclad-v0.61.tgz"; + sha256 = "1yszjy6a0q1jvdgd7fpmnvi9851s8ivp4plscw27lbnl7jlj1pmk"; + system = "ironclad-text"; + asd = "ironclad-text"; + } + ); + systems = [ "ironclad-text" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "ironclad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + isolated = ( + build-asdf-system { + pname = "isolated"; + version = "20200218-git"; + asds = [ "isolated" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-isolated/2020-02-18/cl-isolated-20200218-git.tgz"; + sha256 = "01wbis4dw2cy7d2yh30rwvmlx3dr5s9dx8hs19xhjpznjbqfyksi"; + system = "isolated"; + asd = "isolated"; + } + ); + systems = [ "isolated" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + issr = ( + build-asdf-system { + pname = "issr"; + version = "20211020-git"; + asds = [ "issr" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/hunchenissr/2021-10-20/hunchenissr-20211020-git.tgz"; + sha256 = "1dfm7zdvyj14my8giznq1vsy20nj7my71y7a657slhf6v2cap5vs"; + system = "issr"; + asd = "issr"; + } + ); + systems = [ "issr" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-base64" self) + (getAttr "do-urlencode" self) + (getAttr "hunchentoot" self) + (getAttr "jonathan" self) + (getAttr "plump" self) + (getAttr "portal" self) + (getAttr "str" self) + (getAttr "trivia" self) + (getAttr "trivial-garbage" self) + (getAttr "yxorp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + issr-core = ( + build-asdf-system { + pname = "issr-core"; + version = "20210228-git"; + asds = [ "issr-core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/core/2021-02-28/core-20210228-git.tgz"; + sha256 = "1bajb09crzadkirdpd6jrpcc55irjd4sxzavygr25l85pafyhniw"; + system = "issr-core"; + asd = "issr-core"; + } + ); + systems = [ "issr-core" ]; + lispLibs = [ + (getAttr "global-vars" self) + (getAttr "plump" self) + (getAttr "str" self) + (getAttr "tailrec" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + iterate = ( + build-asdf-system { + pname = "iterate"; + version = "release-b0f9a9c6-git"; + asds = [ "iterate" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/iterate/2021-05-31/iterate-release-b0f9a9c6-git.tgz"; + sha256 = "09xq2mdr97hagjrjpc47mp8l9wfp697aa9qaqmsy0yskayzg6xsc"; + system = "iterate"; + asd = "iterate"; + } + ); + systems = [ "iterate" ]; + lispLibs = [ ]; + meta = { }; + } + ); + iterate-clsql = ( + build-asdf-system { + pname = "iterate-clsql"; + version = "20130312-http"; + asds = [ "iterate-clsql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/iterate-clsql/2013-03-12/iterate-clsql-20130312-http.tgz"; + sha256 = "0adfs31zin5kkg9z5kyzykf8gmcgr600vvi4mjx7nixybh326h3h"; + system = "iterate-clsql"; + asd = "iterate-clsql"; + } + ); + systems = [ "iterate-clsql" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ixf = ( + build-asdf-system { + pname = "ixf"; + version = "20180228-git"; + asds = [ "ixf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-ixf/2018-02-28/cl-ixf-20180228-git.tgz"; + sha256 = "1wjdnf4vr9z7lcfc49kl43g6l2i23q9n81siy494k17d766cdvqa"; + system = "ixf"; + asd = "ixf"; + } + ); + systems = [ "ixf" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + (getAttr "ieee-floats" self) + (getAttr "local-time" self) + (getAttr "md5" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jenkins_dot_api = ( + build-asdf-system { + pname = "jenkins.api"; + version = "20130312-git"; + asds = [ "jenkins.api" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jenkins/2013-03-12/jenkins-20130312-git.tgz"; + sha256 = "1kis95k3fwlaq2jbpia0wps4gq461w6p57dxlbvb0c6a5dgh4dwf"; + system = "jenkins.api"; + asd = "jenkins.api"; + } + ); + systems = [ "jenkins.api" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "drakma" self) + (getAttr "iterate" self) + (getAttr "let-plus" self) + (getAttr "more-conditions" self) + (getAttr "puri" self) + (getAttr "split-sequence" self) + (getAttr "xml_dot_location" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingle = ( + build-asdf-system { + pname = "jingle"; + version = "20231021-git"; + asds = [ "jingle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-jingle/2023-10-21/cl-jingle-20231021-git.tgz"; + sha256 = "0g64y9nzkdrb2yjp0lvhfc0qm3595n6w76hk9hd1v0ril78vzybc"; + system = "jingle"; + asd = "jingle"; + } + ); + systems = [ "jingle" ]; + lispLibs = [ + (getAttr "cl-reexport" self) + (getAttr "clack" self) + (getAttr "find-port" self) + (getAttr "jonathan" self) + (getAttr "lack" self) + (getAttr "lack-app-directory" self) + (getAttr "lack-middleware-mount" self) + (getAttr "lack-middleware-static" self) + (getAttr "local-time" self) + (getAttr "myway" self) + (getAttr "ningle" self) + (getAttr "quri" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingle_dot_demo = ( + build-asdf-system { + pname = "jingle.demo"; + version = "20231021-git"; + asds = [ "jingle.demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-jingle/2023-10-21/cl-jingle-20231021-git.tgz"; + sha256 = "0g64y9nzkdrb2yjp0lvhfc0qm3595n6w76hk9hd1v0ril78vzybc"; + system = "jingle.demo"; + asd = "jingle.demo"; + } + ); + systems = [ "jingle.demo" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-ascii-table" self) + (getAttr "clack-handler-hunchentoot" self) + (getAttr "clingon" self) + (getAttr "dexador" self) + (getAttr "jingle" self) + (getAttr "jonathan" self) + (getAttr "lack-middleware-accesslog" self) + (getAttr "local-time" self) + (getAttr "quri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingle_dot_demo_dot_test = ( + build-asdf-system { + pname = "jingle.demo.test"; + version = "20231021-git"; + asds = [ "jingle.demo.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-jingle/2023-10-21/cl-jingle-20231021-git.tgz"; + sha256 = "0g64y9nzkdrb2yjp0lvhfc0qm3595n6w76hk9hd1v0ril78vzybc"; + system = "jingle.demo.test"; + asd = "jingle.demo.test"; + } + ); + systems = [ "jingle.demo.test" ]; + lispLibs = [ + (getAttr "jingle_dot_demo" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingle_dot_test = ( + build-asdf-system { + pname = "jingle.test"; + version = "20231021-git"; + asds = [ "jingle.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-jingle/2023-10-21/cl-jingle-20231021-git.tgz"; + sha256 = "0g64y9nzkdrb2yjp0lvhfc0qm3595n6w76hk9hd1v0ril78vzybc"; + system = "jingle.test"; + asd = "jingle.test"; + } + ); + systems = [ "jingle.test" ]; + lispLibs = [ + (getAttr "jingle" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh = ( + build-asdf-system { + pname = "jingoh"; + version = "20220707-git"; + asds = [ "jingoh" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh"; + asd = "jingoh"; + } + ); + systems = [ "jingoh" ]; + lispLibs = [ + (getAttr "jingoh_dot_examiner" self) + (getAttr "jingoh_dot_org" self) + (getAttr "jingoh_dot_reader" self) + (getAttr "jingoh_dot_tester" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_documentizer = ( + build-asdf-system { + pname = "jingoh.documentizer"; + version = "20220707-git"; + asds = [ "jingoh.documentizer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.documentizer"; + asd = "jingoh.documentizer"; + } + ); + systems = [ "jingoh.documentizer" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "_3bmd-ext-code-blocks" self) + (getAttr "cl-ppcre" self) + (getAttr "eclector" self) + (getAttr "read-as-string" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_documentizer_dot_test = ( + build-asdf-system { + pname = "jingoh.documentizer.test"; + version = "20220707-git"; + asds = [ "jingoh.documentizer.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.documentizer.test"; + asd = "jingoh.documentizer.test"; + } + ); + systems = [ "jingoh.documentizer.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "jingoh_dot_documentizer" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_examiner = ( + build-asdf-system { + pname = "jingoh.examiner"; + version = "20220707-git"; + asds = [ "jingoh.examiner" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.examiner"; + asd = "jingoh.examiner"; + } + ); + systems = [ "jingoh.examiner" ]; + lispLibs = [ + (getAttr "cl-ansi-text" self) + (getAttr "jingoh_dot_documentizer" self) + (getAttr "jingoh_dot_org" self) + (getAttr "jingoh_dot_tester" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_examiner_dot_test = ( + build-asdf-system { + pname = "jingoh.examiner.test"; + version = "20220707-git"; + asds = [ "jingoh.examiner.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.examiner.test"; + asd = "jingoh.examiner.test"; + } + ); + systems = [ "jingoh.examiner.test" ]; + lispLibs = [ + (getAttr "cl-ansi-text" self) + (getAttr "jingoh" self) + (getAttr "jingoh_dot_examiner" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_generator = ( + build-asdf-system { + pname = "jingoh.generator"; + version = "20220707-git"; + asds = [ "jingoh.generator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.generator"; + asd = "jingoh.generator"; + } + ); + systems = [ "jingoh.generator" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-unification" self) + (getAttr "closer-mop" self) + (getAttr "jingoh_dot_documentizer" self) + (getAttr "lambda-fiddle" self) + (getAttr "millet" self) + (getAttr "named-readtables" self) + (getAttr "prompt-for" self) + (getAttr "trivial-cltl2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_generator_dot_test = ( + build-asdf-system { + pname = "jingoh.generator.test"; + version = "20220707-git"; + asds = [ "jingoh.generator.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.generator.test"; + asd = "jingoh.generator.test"; + } + ); + systems = [ "jingoh.generator.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "jingoh_dot_generator" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_org = ( + build-asdf-system { + pname = "jingoh.org"; + version = "20220707-git"; + asds = [ "jingoh.org" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.org"; + asd = "jingoh.org"; + } + ); + systems = [ "jingoh.org" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "check-bnf" self) + (getAttr "jingoh_dot_documentizer" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_org_dot_test = ( + build-asdf-system { + pname = "jingoh.org.test"; + version = "20220707-git"; + asds = [ "jingoh.org.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.org.test"; + asd = "jingoh.org.test"; + } + ); + systems = [ "jingoh.org.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "jingoh_dot_org" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_parallel = ( + build-asdf-system { + pname = "jingoh.parallel"; + version = "20220707-git"; + asds = [ "jingoh.parallel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.parallel"; + asd = "jingoh.parallel"; + } + ); + systems = [ "jingoh.parallel" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-cpus" self) + (getAttr "jingoh" self) + (getAttr "lparallel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_parallel_dot_test = ( + build-asdf-system { + pname = "jingoh.parallel.test"; + version = "20220707-git"; + asds = [ "jingoh.parallel.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.parallel.test"; + asd = "jingoh.parallel.test"; + } + ); + systems = [ "jingoh.parallel.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "jingoh_dot_parallel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_reader = ( + build-asdf-system { + pname = "jingoh.reader"; + version = "20220707-git"; + asds = [ "jingoh.reader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.reader"; + asd = "jingoh.reader"; + } + ); + systems = [ "jingoh.reader" ]; + lispLibs = [ + (getAttr "eclector" self) + (getAttr "jingoh_dot_documentizer" self) + (getAttr "jingoh_dot_tester" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_reader_dot_test = ( + build-asdf-system { + pname = "jingoh.reader.test"; + version = "20220707-git"; + asds = [ "jingoh.reader.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.reader.test"; + asd = "jingoh.reader.test"; + } + ); + systems = [ "jingoh.reader.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "jingoh_dot_reader" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_tester = ( + build-asdf-system { + pname = "jingoh.tester"; + version = "20220707-git"; + asds = [ "jingoh.tester" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.tester"; + asd = "jingoh.tester"; + } + ); + systems = [ "jingoh.tester" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "check-bnf" self) + (getAttr "cl-ansi-text" self) + (getAttr "cl-colors2" self) + (getAttr "closer-mop" self) + (getAttr "fuzzy-match" self) + (getAttr "jingoh_dot_documentizer" self) + (getAttr "jingoh_dot_org" self) + (getAttr "structure-ext" self) + (getAttr "vivid-colors" self) + (getAttr "vivid-diff" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jingoh_dot_tester_dot_test = ( + build-asdf-system { + pname = "jingoh.tester.test"; + version = "20220707-git"; + asds = [ "jingoh.tester.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jingoh/2022-07-07/jingoh-20220707-git.tgz"; + sha256 = "02wcamw47grg5rz5spn6vl441dk1m82rdrbk6nln69nazj2af76r"; + system = "jingoh.tester.test"; + asd = "jingoh.tester.test"; + } + ); + systems = [ "jingoh.tester.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "jingoh_dot_tester" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jonathan = ( + build-asdf-system { + pname = "jonathan"; + version = "20200925-git"; + asds = [ "jonathan" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jonathan/2020-09-25/jonathan-20200925-git.tgz"; + sha256 = "1l4sfxfmijibsvkbszikzslw1yy8z52ml9may1w2s0ay7lg7rsng"; + system = "jonathan"; + asd = "jonathan"; + } + ); + systems = [ "jonathan" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-annot" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-syntax" self) + (getAttr "cl-syntax-annot" self) + (getAttr "fast-io" self) + (getAttr "proc-parse" self) + (getAttr "trivial-types" self) + ]; + meta = { }; + } + ); + jonathan-test = ( + build-asdf-system { + pname = "jonathan-test"; + version = "20200925-git"; + asds = [ "jonathan-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jonathan/2020-09-25/jonathan-20200925-git.tgz"; + sha256 = "1l4sfxfmijibsvkbszikzslw1yy8z52ml9may1w2s0ay7lg7rsng"; + system = "jonathan-test"; + asd = "jonathan-test"; + } + ); + systems = [ "jonathan-test" ]; + lispLibs = [ + (getAttr "jonathan" self) + (getAttr "legion" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jose = ( + build-asdf-system { + pname = "jose"; + version = "20241012-git"; + asds = [ "jose" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jose/2024-10-12/jose-20241012-git.tgz"; + sha256 = "1z7xjy4ihxa8ay5vznhnxkjflfx6xmfpgwxdakk9wmkw30p2yn4h"; + system = "jose"; + asd = "jose"; + } + ); + systems = [ "jose" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "assoc-utils" self) + (getAttr "cl-base64" self) + (getAttr "ironclad" self) + (getAttr "jonathan" self) + (getAttr "split-sequence" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + journal = ( + build-asdf-system { + pname = "journal"; + version = "20231021-git"; + asds = [ "journal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/journal/2023-10-21/journal-20231021-git.tgz"; + sha256 = "0h55mi3n0cwsl3gb9v7xsl9jzq0x5fbv2s8a0haby7g9995jr98v"; + system = "journal"; + asd = "journal"; + } + ); + systems = [ "journal" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "local-time" self) + (getAttr "mgl-pax" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jp-numeral = ( + build-asdf-system { + pname = "jp-numeral"; + version = "20221106-git"; + asds = [ "jp-numeral" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jp-numeral/2022-11-06/jp-numeral-20221106-git.tgz"; + sha256 = "1xqvah6mjd8lb2n19wzsn29q6az9kx1c48js3yj0ij73kjncby30"; + system = "jp-numeral"; + asd = "jp-numeral"; + } + ); + systems = [ "jp-numeral" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jp-numeral-test = ( + build-asdf-system { + pname = "jp-numeral-test"; + version = "20221106-git"; + asds = [ "jp-numeral-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jp-numeral/2022-11-06/jp-numeral-20221106-git.tgz"; + sha256 = "1xqvah6mjd8lb2n19wzsn29q6az9kx1c48js3yj0ij73kjncby30"; + system = "jp-numeral-test"; + asd = "jp-numeral-test"; + } + ); + systems = [ "jp-numeral-test" ]; + lispLibs = [ + (getAttr "_1am" self) + (getAttr "alexandria" self) + (getAttr "jp-numeral" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jpeg-turbo = ( + build-asdf-system { + pname = "jpeg-turbo"; + version = "20201220-git"; + asds = [ "jpeg-turbo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jpeg-turbo/2020-12-20/jpeg-turbo-20201220-git.tgz"; + sha256 = "1andd1ibbk3224idnpsnrn96flr5d1wm9ja3di57fs04wn577sag"; + system = "jpeg-turbo"; + asd = "jpeg-turbo"; + } + ); + systems = [ "jpeg-turbo" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jpl-queues = ( + build-asdf-system { + pname = "jpl-queues"; + version = "0.1"; + asds = [ "jpl-queues" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jpl-queues/2010-10-06/jpl-queues-0.1.tgz"; + sha256 = "1xgddsfa1gr0cjmdlc304j3msxi8w2fyk9i497x56kmkif7pkj88"; + system = "jpl-queues"; + asd = "jpl-queues"; + } + ); + systems = [ "jpl-queues" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "jpl-util" self) + ]; + meta = { }; + } + ); + jpl-util = ( + build-asdf-system { + pname = "jpl-util"; + version = "20151031-git"; + asds = [ "jpl-util" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-jpl-util/2015-10-31/cl-jpl-util-20151031-git.tgz"; + sha256 = "0nc0rk9n8grkg3045xsw34whmcmddn2sfrxki4268g7kpgz0d2yz"; + system = "jpl-util"; + asd = "jpl-util"; + } + ); + systems = [ "jpl-util" ]; + lispLibs = [ ]; + meta = { }; + } + ); + js-parser = ( + build-asdf-system { + pname = "js-parser"; + version = "20150407-git"; + asds = [ "js-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/js-parser/2015-04-07/js-parser-20150407-git.tgz"; + sha256 = "0hqw515vyhrv1as5sfn3l792ddjps85zbzpblr2cjyq9dmdrg89a"; + system = "js-parser"; + asd = "js-parser"; + } + ); + systems = [ "js-parser" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + js-parser-tests = ( + build-asdf-system { + pname = "js-parser-tests"; + version = "20150407-git"; + asds = [ "js-parser-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/js-parser/2015-04-07/js-parser-20150407-git.tgz"; + sha256 = "0hqw515vyhrv1as5sfn3l792ddjps85zbzpblr2cjyq9dmdrg89a"; + system = "js-parser-tests"; + asd = "js-parser-tests"; + } + ); + systems = [ "js-parser-tests" ]; + lispLibs = [ (getAttr "js-parser" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + json-lib = ( + build-asdf-system { + pname = "json-lib"; + version = "20230618-git"; + asds = [ "json-lib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/json-lib/2023-06-18/json-lib-20230618-git.tgz"; + sha256 = "08cbnj6h53ifwm6kk5pvpxmy2a11kiph9zjccd2ml3fj6257krpv"; + system = "json-lib"; + asd = "json-lib"; + } + ); + systems = [ "json-lib" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-fad" self) + (getAttr "parse-float" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + json-mop = ( + build-asdf-system { + pname = "json-mop"; + version = "20241012-git"; + asds = [ "json-mop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/json-mop/2024-10-12/json-mop-20241012-git.tgz"; + sha256 = "1q6mmq64hf4v448bnzfh8nxsxg5h18a9snh785r1fnvv1aij3fi1"; + system = "json-mop"; + asd = "json-mop"; + } + ); + systems = [ "json-mop" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "closer-mop" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + json-mop-tests = ( + build-asdf-system { + pname = "json-mop-tests"; + version = "20241012-git"; + asds = [ "json-mop-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/json-mop/2024-10-12/json-mop-20241012-git.tgz"; + sha256 = "1q6mmq64hf4v448bnzfh8nxsxg5h18a9snh785r1fnvv1aij3fi1"; + system = "json-mop-tests"; + asd = "json-mop-tests"; + } + ); + systems = [ "json-mop-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "json-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + json-responses = ( + build-asdf-system { + pname = "json-responses"; + version = "20190307-hg"; + asds = [ "json-responses" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/json-responses/2019-03-07/json-responses-20190307-hg.tgz"; + sha256 = "0f1hrs3rhi6qn0r8qd3fbsknn417b8v8b4s4989yfwfvnf922g05"; + system = "json-responses"; + asd = "json-responses"; + } + ); + systems = [ "json-responses" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + json-responses-test = ( + build-asdf-system { + pname = "json-responses-test"; + version = "20190307-hg"; + asds = [ "json-responses-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/json-responses/2019-03-07/json-responses-20190307-hg.tgz"; + sha256 = "0f1hrs3rhi6qn0r8qd3fbsknn417b8v8b4s4989yfwfvnf922g05"; + system = "json-responses-test"; + asd = "json-responses"; + } + ); + systems = [ "json-responses-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "json-responses" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + json-schema = ( + build-asdf-system { + pname = "json-schema"; + version = "20221106-git"; + asds = [ "json-schema" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/json-schema/2022-11-06/json-schema-20221106-git.tgz"; + sha256 = "11rgnj14p8x059zx8hs02jji1p69v8kix783vf557zpcbydrw2mn"; + system = "json-schema"; + asd = "json-schema"; + } + ); + systems = [ "json-schema" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "arrows" self) + (getAttr "cl-ppcre" self) + (getAttr "dexador" self) + (getAttr "function-cache" self) + (getAttr "local-time" self) + (getAttr "local-time-duration" self) + (getAttr "quri" self) + (getAttr "sanity-clause" self) + (getAttr "st-json" self) + (getAttr "str" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + json-streams = ( + build-asdf-system { + pname = "json-streams"; + version = "20171019-git"; + asds = [ "json-streams" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/json-streams/2017-10-19/json-streams-20171019-git.tgz"; + sha256 = "0cia3721im04q73dfkd688d8splgpz03qa4h8s3r39kar4w3xll2"; + system = "json-streams"; + asd = "json-streams"; + } + ); + systems = [ "json-streams" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + json-streams-tests = ( + build-asdf-system { + pname = "json-streams-tests"; + version = "20171019-git"; + asds = [ "json-streams-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/json-streams/2017-10-19/json-streams-20171019-git.tgz"; + sha256 = "0cia3721im04q73dfkd688d8splgpz03qa4h8s3r39kar4w3xll2"; + system = "json-streams-tests"; + asd = "json-streams-tests"; + } + ); + systems = [ "json-streams-tests" ]; + lispLibs = [ + (getAttr "cl-quickcheck" self) + (getAttr "flexi-streams" self) + (getAttr "json-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + json-test-suite = ( + build-asdf-system { + pname = "json-test-suite"; + version = "20230618-git"; + asds = [ "json-test-suite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rs-json/2023-06-18/rs-json-20230618-git.tgz"; + sha256 = "0y71as0sg5vfijpzdhv6pj6yv064ldn2shx0y4da8kvaqv949dnq"; + system = "json-test-suite"; + asd = "json-test-suite"; + } + ); + systems = [ "json-test-suite" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jsonrpc = ( + build-asdf-system { + pname = "jsonrpc"; + version = "20241012-git"; + asds = [ "jsonrpc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jsonrpc/2024-10-12/jsonrpc-20241012-git.tgz"; + sha256 = "1wsc6bv8xpzad0lgrlldzrpb9r4aksnw7ss2ifwa7ykbzfxcr8gi"; + system = "jsonrpc"; + asd = "jsonrpc"; + } + ); + systems = [ "jsonrpc" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "chanl" self) + (getAttr "dissect" self) + (getAttr "trivial-timeout" self) + (getAttr "usocket" self) + (getAttr "vom" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jsown = ( + build-asdf-system { + pname = "jsown"; + version = "20200218-git"; + asds = [ "jsown" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jsown/2020-02-18/jsown-20200218-git.tgz"; + sha256 = "0gadvmf1d9bq35s61z76psrsnzwwk12svi66jigf491hv48wigw7"; + system = "jsown"; + asd = "jsown"; + } + ); + systems = [ "jsown" ]; + lispLibs = [ ]; + meta = { }; + } + ); + jsown-tests = ( + build-asdf-system { + pname = "jsown-tests"; + version = "20200218-git"; + asds = [ "jsown-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jsown/2020-02-18/jsown-20200218-git.tgz"; + sha256 = "0gadvmf1d9bq35s61z76psrsnzwwk12svi66jigf491hv48wigw7"; + system = "jsown-tests"; + asd = "jsown-tests"; + } + ); + systems = [ "jsown-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "jsown" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jsown-utils = ( + build-asdf-system { + pname = "jsown-utils"; + version = "20220707-git"; + asds = [ "jsown-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jsown-utils/2022-07-07/jsown-utils-20220707-git.tgz"; + sha256 = "046a18fywkim0jbnpls5zqdv65j1kwl268p4dbdd2dxgx050fwak"; + system = "jsown-utils"; + asd = "jsown-utils"; + } + ); + systems = [ "jsown-utils" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "jsown" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jupyter-lab-extension = ( + build-asdf-system { + pname = "jupyter-lab-extension"; + version = "20241012-git"; + asds = [ "jupyter-lab-extension" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/common-lisp-jupyter/2024-10-12/common-lisp-jupyter-20241012-git.tgz"; + sha256 = "1qbrzv0myxfxq7rzm2y9cm2xymkl982982h2kbsl7d1yd5hrjvl6"; + system = "jupyter-lab-extension"; + asd = "jupyter-lab-extension"; + } + ); + systems = [ "jupyter-lab-extension" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + just-getopt-parser = ( + build-asdf-system { + pname = "just-getopt-parser"; + version = "20211209-git"; + asds = [ "just-getopt-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-just-getopt-parser/2021-12-09/cl-just-getopt-parser-20211209-git.tgz"; + sha256 = "0ngh8b51ngh3bqacl40j6wwiinhwxswsy02d9k7qlzv9sbjxay4s"; + system = "just-getopt-parser"; + asd = "just-getopt-parser"; + } + ); + systems = [ "just-getopt-parser" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jwacs = ( + build-asdf-system { + pname = "jwacs"; + version = "20180228-git"; + asds = [ "jwacs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jwacs/2018-02-28/jwacs-20180228-git.tgz"; + sha256 = "1wzln3bjjmdv040i339dsm48a1sc2cnwhh4z066x2wkl5ka7j5b2"; + system = "jwacs"; + asd = "jwacs"; + } + ); + systems = [ "jwacs" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + jwacs-tests = ( + build-asdf-system { + pname = "jwacs-tests"; + version = "20180228-git"; + asds = [ "jwacs-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/jwacs/2018-02-28/jwacs-20180228-git.tgz"; + sha256 = "1wzln3bjjmdv040i339dsm48a1sc2cnwhh4z066x2wkl5ka7j5b2"; + system = "jwacs-tests"; + asd = "jwacs-tests"; + } + ); + systems = [ "jwacs-tests" ]; + lispLibs = [ (getAttr "jwacs" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + kanren-trs = ( + build-asdf-system { + pname = "kanren-trs"; + version = "20120305-svn"; + asds = [ "kanren-trs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-kanren-trs/2012-03-05/cl-kanren-trs-20120305-svn.tgz"; + sha256 = "1r9xyickdkkqcaa7abvks4hqwjb7s95lcrym026c1w6ciibiypr7"; + system = "kanren-trs"; + asd = "kanren-trs"; + } + ); + systems = [ "kanren-trs" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + kanren-trs-test = ( + build-asdf-system { + pname = "kanren-trs-test"; + version = "20120305-svn"; + asds = [ "kanren-trs-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-kanren-trs/2012-03-05/cl-kanren-trs-20120305-svn.tgz"; + sha256 = "1r9xyickdkkqcaa7abvks4hqwjb7s95lcrym026c1w6ciibiypr7"; + system = "kanren-trs-test"; + asd = "kanren-trs-test"; + } + ); + systems = [ "kanren-trs-test" ]; + lispLibs = [ (getAttr "kanren-trs" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + kaputt = ( + build-asdf-system { + pname = "kaputt"; + version = "20221106-git"; + asds = [ "kaputt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-kaputt/2022-11-06/cl-kaputt-20221106-git.tgz"; + sha256 = "1jd9lmdzkjm6mawsxczg6czyv7zbmaplq0ikmda0ysh4aq3apnnj"; + system = "kaputt"; + asd = "kaputt"; + } + ); + systems = [ "kaputt" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + kdl = ( + build-asdf-system { + pname = "kdl"; + version = "20230618-git"; + asds = [ "kdl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/kdlcl/2023-06-18/kdlcl-20230618-git.tgz"; + sha256 = "0bqqxkd6s420ld2hmhvbbvpzss0m2kimmxaqhz7j1ksmq86bvvmj"; + system = "kdl"; + asd = "kdl"; + } + ); + systems = [ "kdl" ]; + lispLibs = [ + (getAttr "esrap" self) + (getAttr "parse-number" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + kdtree-jk = ( + build-asdf-system { + pname = "kdtree-jk"; + version = "20230618-git"; + asds = [ "kdtree-jk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/kdtree-jk/2023-06-18/kdtree-jk-20230618-git.tgz"; + sha256 = "0l311lmwp4sminl0k534s1kvfwmlk56bfnj7367zd7jl0hvs06ck"; + system = "kdtree-jk"; + asd = "kdtree-jk"; + } + ); + systems = [ "kdtree-jk" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + kebab = ( + build-asdf-system { + pname = "kebab"; + version = "20150608-git"; + asds = [ "kebab" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/kebab/2015-06-08/kebab-20150608-git.tgz"; + sha256 = "0j5haabnvj0vz0rx9mwyfsb3qzpga9nickbjw8xs6vypkdzlqv1b"; + system = "kebab"; + asd = "kebab"; + } + ); + systems = [ "kebab" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + kebab-test = ( + build-asdf-system { + pname = "kebab-test"; + version = "20150608-git"; + asds = [ "kebab-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/kebab/2015-06-08/kebab-20150608-git.tgz"; + sha256 = "0j5haabnvj0vz0rx9mwyfsb3qzpga9nickbjw8xs6vypkdzlqv1b"; + system = "kebab-test"; + asd = "kebab-test"; + } + ); + systems = [ "kebab-test" ]; + lispLibs = [ + (getAttr "kebab" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + kekule-clj = ( + build-asdf-system { + pname = "kekule-clj"; + version = "20231021-git"; + asds = [ "kekule-clj" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/kekule-clj/2023-10-21/kekule-clj-20231021-git.tgz"; + sha256 = "1901b11ilknd4gy7r5b00yq6syb6qsh0xalkdw4g0dqzvqqxnfj5"; + system = "kekule-clj"; + asd = "kekule-clj"; + } + ); + systems = [ "kekule-clj" ]; + lispLibs = [ + (getAttr "common-lisp-jupyter" self) + (getAttr "jupyter-lab-extension" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + kenzo = ( + build-asdf-system { + pname = "kenzo"; + version = "20200325-git"; + asds = [ "kenzo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/kenzo/2020-03-25/kenzo-20200325-git.tgz"; + sha256 = "0dg70p5pxvx2ksr66z3p2nkxxwkjd852pkckr15j6cwfaji9fr8r"; + system = "kenzo"; + asd = "kenzo"; + } + ); + systems = [ "kenzo" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + kenzo-test = ( + build-asdf-system { + pname = "kenzo-test"; + version = "20200325-git"; + asds = [ "kenzo-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/kenzo/2020-03-25/kenzo-20200325-git.tgz"; + sha256 = "0dg70p5pxvx2ksr66z3p2nkxxwkjd852pkckr15j6cwfaji9fr8r"; + system = "kenzo-test"; + asd = "kenzo-test"; + } + ); + systems = [ "kenzo-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "kenzo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + keystone = ( + build-asdf-system { + pname = "keystone"; + version = "20200427-git"; + asds = [ "keystone" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/keystone/2020-04-27/keystone-20200427-git.tgz"; + sha256 = "04fczbkihf87qyp9f1sv45h69xrvdmcmxkv4m868q8zqw6z48hlj"; + system = "keystone"; + asd = "keystone"; + } + ); + systems = [ "keystone" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "gt" self) + (getAttr "static-vectors" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + khazern = ( + build-asdf-system { + pname = "khazern"; + version = "20241012-git"; + asds = [ "khazern" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/khazern/2024-10-12/khazern-20241012-git.tgz"; + sha256 = "1kc15gc0kahp8w9qfyb4yr1gnwqhk8dcvi5gm678bsnbqipaj30h"; + system = "khazern"; + asd = "khazern"; + } + ); + systems = [ "khazern" ]; + lispLibs = [ (getAttr "acclimation" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + khazern-extrinsic = ( + build-asdf-system { + pname = "khazern-extrinsic"; + version = "20241012-git"; + asds = [ "khazern-extrinsic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/khazern/2024-10-12/khazern-20241012-git.tgz"; + sha256 = "1kc15gc0kahp8w9qfyb4yr1gnwqhk8dcvi5gm678bsnbqipaj30h"; + system = "khazern-extrinsic"; + asd = "khazern-extrinsic"; + } + ); + systems = [ "khazern-extrinsic" ]; + lispLibs = [ (getAttr "khazern" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + khazern-intrinsic = ( + build-asdf-system { + pname = "khazern-intrinsic"; + version = "20241012-git"; + asds = [ "khazern-intrinsic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/khazern/2024-10-12/khazern-20241012-git.tgz"; + sha256 = "1kc15gc0kahp8w9qfyb4yr1gnwqhk8dcvi5gm678bsnbqipaj30h"; + system = "khazern-intrinsic"; + asd = "khazern-intrinsic"; + } + ); + systems = [ "khazern-intrinsic" ]; + lispLibs = [ + (getAttr "khazern" self) + (getAttr "trivial-package-locks" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + khazern-sequence = ( + build-asdf-system { + pname = "khazern-sequence"; + version = "20241012-git"; + asds = [ "khazern-sequence" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/khazern/2024-10-12/khazern-20241012-git.tgz"; + sha256 = "1kc15gc0kahp8w9qfyb4yr1gnwqhk8dcvi5gm678bsnbqipaj30h"; + system = "khazern-sequence"; + asd = "khazern-sequence"; + } + ); + systems = [ "khazern-sequence" ]; + lispLibs = [ + (getAttr "khazern" self) + (getAttr "trivial-extensible-sequences" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + khazern-sequence-extrinsic = ( + build-asdf-system { + pname = "khazern-sequence-extrinsic"; + version = "20241012-git"; + asds = [ "khazern-sequence-extrinsic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/khazern/2024-10-12/khazern-20241012-git.tgz"; + sha256 = "1kc15gc0kahp8w9qfyb4yr1gnwqhk8dcvi5gm678bsnbqipaj30h"; + system = "khazern-sequence-extrinsic"; + asd = "khazern-sequence-extrinsic"; + } + ); + systems = [ "khazern-sequence-extrinsic" ]; + lispLibs = [ + (getAttr "khazern-extrinsic" self) + (getAttr "khazern-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + khazern-sequence-intrinsic = ( + build-asdf-system { + pname = "khazern-sequence-intrinsic"; + version = "20241012-git"; + asds = [ "khazern-sequence-intrinsic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/khazern/2024-10-12/khazern-20241012-git.tgz"; + sha256 = "1kc15gc0kahp8w9qfyb4yr1gnwqhk8dcvi5gm678bsnbqipaj30h"; + system = "khazern-sequence-intrinsic"; + asd = "khazern-sequence-intrinsic"; + } + ); + systems = [ "khazern-sequence-intrinsic" ]; + lispLibs = [ + (getAttr "khazern-intrinsic" self) + (getAttr "khazern-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + kl-verify = ( + build-asdf-system { + pname = "kl-verify"; + version = "20120909-git"; + asds = [ "kl-verify" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/kl-verify/2012-09-09/kl-verify-20120909-git.tgz"; + sha256 = "1m5jyvvfb24idw0xzi92diyrygmq638dwxg0sl247yyvmwsqb8yj"; + system = "kl-verify"; + asd = "kl-verify"; + } + ); + systems = [ "kl-verify" ]; + lispLibs = [ (getAttr "image" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + km = ( + build-asdf-system { + pname = "km"; + version = "2-5-33"; + asds = [ "km" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/km/2011-05-22/km-2-5-33.tgz"; + sha256 = "0vl4g7vg20l14xc1b5g1d0scak6ck5028q5s5c75pr8fp15m7wyb"; + system = "km"; + asd = "km"; + } + ); + systems = [ "km" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + kmrcl = ( + build-asdf-system { + pname = "kmrcl"; + version = "20201016-git"; + asds = [ "kmrcl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/kmrcl/2020-10-16/kmrcl-20201016-git.tgz"; + sha256 = "06gx04mah5nc8w78s0j8628divbf1s5w7af8w7pvzb2d5mgvrbd2"; + system = "kmrcl"; + asd = "kmrcl"; + } + ); + systems = [ "kmrcl" ]; + lispLibs = [ ]; + meta = { }; + } + ); + knx-conn = ( + build-asdf-system { + pname = "knx-conn"; + version = "20241012-git"; + asds = [ "knx-conn" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/knx-conn/2024-10-12/knx-conn-20241012-git.tgz"; + sha256 = "1zq716fr1mq096hbpndfawyi1a7pr6gsyxnv2g1b00vpgyf37c4r"; + system = "knx-conn"; + asd = "knx-conn"; + } + ); + systems = [ "knx-conn" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "binding-arrows" self) + (getAttr "local-time" self) + (getAttr "log4cl" self) + (getAttr "sento" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + l-math = ( + build-asdf-system { + pname = "l-math"; + version = "20190307-git"; + asds = [ "l-math" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/l-math/2019-03-07/l-math-20190307-git.tgz"; + sha256 = "12nhj1hrvgvmichrjf46fi0f1lzrjajw7k9i1f6qycnnqw45qan1"; + system = "l-math"; + asd = "l-math"; + } + ); + systems = [ "l-math" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + l-system = ( + build-asdf-system { + pname = "l-system"; + version = "20180228-git"; + asds = [ "l-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/l-system/2018-02-28/l-system-20180228-git.tgz"; + sha256 = "1zvd90s7y936bx7sirc38vs8r2rs62064ndj06ahrc38vagv4qwd"; + system = "l-system"; + asd = "l-system"; + } + ); + systems = [ "l-system" ]; + lispLibs = [ (getAttr "iterate" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + l-system-examples = ( + build-asdf-system { + pname = "l-system-examples"; + version = "20180228-git"; + asds = [ "l-system-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/l-system/2018-02-28/l-system-20180228-git.tgz"; + sha256 = "1zvd90s7y936bx7sirc38vs8r2rs62064ndj06ahrc38vagv4qwd"; + system = "l-system-examples"; + asd = "l-system-examples"; + } + ); + systems = [ "l-system-examples" ]; + lispLibs = [ (getAttr "l-system" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + laap = ( + build-asdf-system { + pname = "laap"; + version = "20170830-git"; + asds = [ "laap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/laap/2017-08-30/laap-20170830-git.tgz"; + sha256 = "0rzjdi4qcv2l99mk4bk94xlpfx1mav0kvd7crpax7dx4dfwkq8k5"; + system = "laap"; + asd = "laap"; + } + ); + systems = [ "laap" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cl-base32" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack = ( + build-asdf-system { + pname = "lack"; + version = "20241012-git"; + asds = [ "lack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack"; + asd = "lack"; + } + ); + systems = [ "lack" ]; + lispLibs = [ + (getAttr "lack-component" self) + (getAttr "lack-util" self) + ]; + meta = { }; + } + ); + lack-app-directory = ( + build-asdf-system { + pname = "lack-app-directory"; + version = "20241012-git"; + asds = [ "lack-app-directory" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-app-directory"; + asd = "lack-app-directory"; + } + ); + systems = [ "lack-app-directory" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "lack-app-file" self) + (getAttr "quri" self) + (getAttr "trivial-mimes" self) + (getAttr "trivial-rfc-1123" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-app-file = ( + build-asdf-system { + pname = "lack-app-file"; + version = "20241012-git"; + asds = [ "lack-app-file" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-app-file"; + asd = "lack-app-file"; + } + ); + systems = [ "lack-app-file" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "lack-component" self) + (getAttr "trivial-mimes" self) + (getAttr "trivial-rfc-1123" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-component = ( + build-asdf-system { + pname = "lack-component"; + version = "20241012-git"; + asds = [ "lack-component" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-component"; + asd = "lack-component"; + } + ); + systems = [ "lack-component" ]; + lispLibs = [ ]; + meta = { }; + } + ); + lack-middleware-accesslog = ( + build-asdf-system { + pname = "lack-middleware-accesslog"; + version = "20241012-git"; + asds = [ "lack-middleware-accesslog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-middleware-accesslog"; + asd = "lack-middleware-accesslog"; + } + ); + systems = [ "lack-middleware-accesslog" ]; + lispLibs = [ + (getAttr "lack-util" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-middleware-anypool = ( + build-asdf-system { + pname = "lack-middleware-anypool"; + version = "20241012-git"; + asds = [ "lack-middleware-anypool" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/anypool/2024-10-12/anypool-20241012-git.tgz"; + sha256 = "1ffssc5fzh7gj0z94xxfb3mk5cwja65lrhxyfgib15a6yxqf1kk1"; + system = "lack-middleware-anypool"; + asd = "lack-middleware-anypool"; + } + ); + systems = [ "lack-middleware-anypool" ]; + lispLibs = [ (getAttr "anypool" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-middleware-auth-basic = ( + build-asdf-system { + pname = "lack-middleware-auth-basic"; + version = "20241012-git"; + asds = [ "lack-middleware-auth-basic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-middleware-auth-basic"; + asd = "lack-middleware-auth-basic"; + } + ); + systems = [ "lack-middleware-auth-basic" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-middleware-backtrace = ( + build-asdf-system { + pname = "lack-middleware-backtrace"; + version = "20241012-git"; + asds = [ "lack-middleware-backtrace" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-middleware-backtrace"; + asd = "lack-middleware-backtrace"; + } + ); + systems = [ "lack-middleware-backtrace" ]; + lispLibs = [ ]; + meta = { }; + } + ); + lack-middleware-clack-errors = ( + build-asdf-system { + pname = "lack-middleware-clack-errors"; + version = "20190813-git"; + asds = [ "lack-middleware-clack-errors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack-errors/2019-08-13/clack-errors-20190813-git.tgz"; + sha256 = "0z6jyn37phnpq02l5wml8z0593g8ps95c0c2lzkhi3is2wcj9cpf"; + system = "lack-middleware-clack-errors"; + asd = "lack-middleware-clack-errors"; + } + ); + systems = [ "lack-middleware-clack-errors" ]; + lispLibs = [ (getAttr "clack-errors" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-middleware-csrf = ( + build-asdf-system { + pname = "lack-middleware-csrf"; + version = "20241012-git"; + asds = [ "lack-middleware-csrf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-middleware-csrf"; + asd = "lack-middleware-csrf"; + } + ); + systems = [ "lack-middleware-csrf" ]; + lispLibs = [ + (getAttr "lack-request" self) + (getAttr "lack-util" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-middleware-dbpool = ( + build-asdf-system { + pname = "lack-middleware-dbpool"; + version = "20241012-git"; + asds = [ "lack-middleware-dbpool" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-middleware-dbpool"; + asd = "lack-middleware-dbpool"; + } + ); + systems = [ "lack-middleware-dbpool" ]; + lispLibs = [ + (getAttr "anypool" self) + (getAttr "dbi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-middleware-mito = ( + build-asdf-system { + pname = "lack-middleware-mito"; + version = "20241012-git"; + asds = [ "lack-middleware-mito" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mito/2024-10-12/mito-20241012-git.tgz"; + sha256 = "0nz72qss2jji0narxffpnpfgz74grvhmwqqlydpw6wv3ji1rrrq3"; + system = "lack-middleware-mito"; + asd = "lack-middleware-mito"; + } + ); + systems = [ "lack-middleware-mito" ]; + lispLibs = [ + (getAttr "dbi" self) + (getAttr "mito-core" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-middleware-mount = ( + build-asdf-system { + pname = "lack-middleware-mount"; + version = "20241012-git"; + asds = [ "lack-middleware-mount" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-middleware-mount"; + asd = "lack-middleware-mount"; + } + ); + systems = [ "lack-middleware-mount" ]; + lispLibs = [ (getAttr "lack-component" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-middleware-session = ( + build-asdf-system { + pname = "lack-middleware-session"; + version = "20241012-git"; + asds = [ "lack-middleware-session" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-middleware-session"; + asd = "lack-middleware-session"; + } + ); + systems = [ "lack-middleware-session" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "lack-request" self) + (getAttr "lack-response" self) + (getAttr "lack-util" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-middleware-static = ( + build-asdf-system { + pname = "lack-middleware-static"; + version = "20241012-git"; + asds = [ "lack-middleware-static" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-middleware-static"; + asd = "lack-middleware-static"; + } + ); + systems = [ "lack-middleware-static" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "lack-app-file" self) + (getAttr "lack-component" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-request = ( + build-asdf-system { + pname = "lack-request"; + version = "20241012-git"; + asds = [ "lack-request" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-request"; + asd = "lack-request"; + } + ); + systems = [ "lack-request" ]; + lispLibs = [ + (getAttr "circular-streams" self) + (getAttr "cl-ppcre" self) + (getAttr "http-body" self) + (getAttr "quri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-response = ( + build-asdf-system { + pname = "lack-response"; + version = "20241012-git"; + asds = [ "lack-response" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-response"; + asd = "lack-response"; + } + ); + systems = [ "lack-response" ]; + lispLibs = [ + (getAttr "local-time" self) + (getAttr "quri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-session-store-dbi = ( + build-asdf-system { + pname = "lack-session-store-dbi"; + version = "20241012-git"; + asds = [ "lack-session-store-dbi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-session-store-dbi"; + asd = "lack-session-store-dbi"; + } + ); + systems = [ "lack-session-store-dbi" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "dbi" self) + (getAttr "lack-middleware-session" self) + (getAttr "marshal" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-session-store-redis = ( + build-asdf-system { + pname = "lack-session-store-redis"; + version = "20241012-git"; + asds = [ "lack-session-store-redis" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-session-store-redis"; + asd = "lack-session-store-redis"; + } + ); + systems = [ "lack-session-store-redis" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "cl-redis" self) + (getAttr "lack-middleware-session" self) + (getAttr "marshal" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-test = ( + build-asdf-system { + pname = "lack-test"; + version = "20241012-git"; + asds = [ "lack-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-test"; + asd = "lack-test"; + } + ); + systems = [ "lack-test" ]; + lispLibs = [ + (getAttr "cl-cookie" self) + (getAttr "flexi-streams" self) + (getAttr "lack" self) + (getAttr "quri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lack-util = ( + build-asdf-system { + pname = "lack-util"; + version = "20241012-git"; + asds = [ "lack-util" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-util"; + asd = "lack-util"; + } + ); + systems = [ "lack-util" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-isaac" self) + ]; + meta = { }; + } + ); + lack-util-writer-stream = ( + build-asdf-system { + pname = "lack-util-writer-stream"; + version = "20241012-git"; + asds = [ "lack-util-writer-stream" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lack/2024-10-12/lack-20241012-git.tgz"; + sha256 = "0w1gw5sma9lajap0v2fvy7b5nysswrakmqvczhv48wp65i9lvcys"; + system = "lack-util-writer-stream"; + asd = "lack-util-writer-stream"; + } + ); + systems = [ "lack-util-writer-stream" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lake = ( + build-asdf-system { + pname = "lake"; + version = "20220220-git"; + asds = [ "lake" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lake/2022-02-20/lake-20220220-git.tgz"; + sha256 = "1g6rr4d5vjx487ym5qjlnw5sd6rwx6l4zx1l9mj0j30lpm1k4il0"; + system = "lake"; + asd = "lake"; + } + ); + systems = [ "lake" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-syntax" self) + (getAttr "cl-syntax-interpol" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lake-cli = ( + build-asdf-system { + pname = "lake-cli"; + version = "20220220-git"; + asds = [ "lake-cli" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lake/2022-02-20/lake-20220220-git.tgz"; + sha256 = "1g6rr4d5vjx487ym5qjlnw5sd6rwx6l4zx1l9mj0j30lpm1k4il0"; + system = "lake-cli"; + asd = "lake-cli"; + } + ); + systems = [ "lake-cli" ]; + lispLibs = [ + (getAttr "deploy" self) + (getAttr "lake" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lake-test = ( + build-asdf-system { + pname = "lake-test"; + version = "20220220-git"; + asds = [ "lake-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lake/2022-02-20/lake-20220220-git.tgz"; + sha256 = "1g6rr4d5vjx487ym5qjlnw5sd6rwx6l4zx1l9mj0j30lpm1k4il0"; + system = "lake-test"; + asd = "lake-test"; + } + ); + systems = [ "lake-test" ]; + lispLibs = [ + (getAttr "lake" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lambda-fiddle = ( + build-asdf-system { + pname = "lambda-fiddle"; + version = "20231021-git"; + asds = [ "lambda-fiddle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lambda-fiddle/2023-10-21/lambda-fiddle-20231021-git.tgz"; + sha256 = "1hh0192qvymn3zwy9a0rsg98wgb8mnb9z2jzl2a2n1ssvpx61gpj"; + system = "lambda-fiddle"; + asd = "lambda-fiddle"; + } + ); + systems = [ "lambda-fiddle" ]; + lispLibs = [ ]; + meta = { }; + } + ); + lambda-reader = ( + build-asdf-system { + pname = "lambda-reader"; + version = "20170124-git"; + asds = [ "lambda-reader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lambda-reader/2017-01-24/lambda-reader-20170124-git.tgz"; + sha256 = "0s73nrnvr0d2ql1gabcasmfnckzq0f2qs9317hv2mrrh0q1giq1w"; + system = "lambda-reader"; + asd = "lambda-reader"; + } + ); + systems = [ "lambda-reader" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lambda-reader-8bit = ( + build-asdf-system { + pname = "lambda-reader-8bit"; + version = "20170124-git"; + asds = [ "lambda-reader-8bit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lambda-reader/2017-01-24/lambda-reader-20170124-git.tgz"; + sha256 = "0s73nrnvr0d2ql1gabcasmfnckzq0f2qs9317hv2mrrh0q1giq1w"; + system = "lambda-reader-8bit"; + asd = "lambda-reader-8bit"; + } + ); + systems = [ "lambda-reader-8bit" ]; + lispLibs = [ + (getAttr "asdf-encodings" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lambdalite = ( + build-asdf-system { + pname = "lambdalite"; + version = "20141217-git"; + asds = [ "lambdalite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lambdalite/2014-12-17/lambdalite-20141217-git.tgz"; + sha256 = "0bvhix74afak5bpaa4x3p1b7gskpvzvw78aqkml9d40gpd1ky8lh"; + system = "lambdalite"; + asd = "lambdalite"; + } + ); + systems = [ "lambdalite" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "wu-sugar" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + language-codes = ( + build-asdf-system { + pname = "language-codes"; + version = "20231021-git"; + asds = [ "language-codes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/language-codes/2023-10-21/language-codes-20231021-git.tgz"; + sha256 = "0qbv0x0w415m48c6gjaw7ncnb1446q9sswr2p3svx7ijiwd19kja"; + system = "language-codes"; + asd = "language-codes"; + } + ); + systems = [ "language-codes" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + langutils = ( + build-asdf-system { + pname = "langutils"; + version = "20121125-git"; + asds = [ "langutils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-langutils/2012-11-25/cl-langutils-20121125-git.tgz"; + sha256 = "15y9x5wkg3fqndc04w2sc650fnwimxp4gjgpv9xvvdm9x4v433x6"; + system = "langutils"; + asd = "langutils"; + } + ); + systems = [ "langutils" ]; + lispLibs = [ + (getAttr "s-xml-rpc" self) + (getAttr "stdutils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lapack = ( + build-asdf-system { + pname = "lapack"; + version = "20231021-git"; + asds = [ "lapack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "lapack"; + asd = "lapack"; + } + ); + systems = [ "lapack" ]; + lispLibs = [ + (getAttr "blas-complex" self) + (getAttr "blas-package" self) + (getAttr "blas-real" self) + (getAttr "f2cl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lass = ( + build-asdf-system { + pname = "lass"; + version = "20241012-git"; + asds = [ "lass" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lass/2024-10-12/lass-20241012-git.tgz"; + sha256 = "1b6a3v763i5fcdxczffd59kh4m73p4ilz6az85apd22apc8lr80z"; + system = "lass"; + asd = "lass"; + } + ); + systems = [ "lass" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "trivial-indent" self) + (getAttr "trivial-mimes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lass-flexbox = ( + build-asdf-system { + pname = "lass-flexbox"; + version = "20160208-git"; + asds = [ "lass-flexbox" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lass-flexbox/2016-02-08/lass-flexbox-20160208-git.tgz"; + sha256 = "143rkff1ybi3b07qyzndxxndp7j4nw1biyp51rkl0yvsk85kj1jp"; + system = "lass-flexbox"; + asd = "lass-flexbox"; + } + ); + systems = [ "lass-flexbox" ]; + lispLibs = [ (getAttr "lass" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lass-flexbox-test = ( + build-asdf-system { + pname = "lass-flexbox-test"; + version = "20160208-git"; + asds = [ "lass-flexbox-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lass-flexbox/2016-02-08/lass-flexbox-20160208-git.tgz"; + sha256 = "143rkff1ybi3b07qyzndxxndp7j4nw1biyp51rkl0yvsk85kj1jp"; + system = "lass-flexbox-test"; + asd = "lass-flexbox-test"; + } + ); + systems = [ "lass-flexbox-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "lass-flexbox" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lassie = ( + build-asdf-system { + pname = "lassie"; + version = "20140713-git"; + asds = [ "lassie" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lassie/2014-07-13/lassie-20140713-git.tgz"; + sha256 = "06ps25422ymp9n35745xhg3qsclfli52b7mxhw58wwz9q1v1n0rn"; + system = "lassie"; + asd = "lassie"; + } + ); + systems = [ "lassie" ]; + lispLibs = [ (getAttr "fsvd" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lastfm = ( + build-asdf-system { + pname = "lastfm"; + version = "20191007-git"; + asds = [ "lastfm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lastfm/2019-10-07/lastfm-20191007-git.tgz"; + sha256 = "1crg82fyzkm9a0czsf5vq6nwndg6gy7zqb2glbp3yaw6p2hrwkp4"; + system = "lastfm"; + asd = "lastfm"; + } + ); + systems = [ "lastfm" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "defmemo" self) + (getAttr "drakma" self) + (getAttr "generators" self) + (getAttr "ironclad" self) + (getAttr "lquery" self) + (getAttr "plump" self) + (getAttr "trivial-open-browser" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + latex-table = ( + build-asdf-system { + pname = "latex-table"; + version = "20180328-git"; + asds = [ "latex-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/latex-table/2018-03-28/latex-table-20180328-git.tgz"; + sha256 = "04qqr62pdi7qs9p74a4a014l6sl6bk6hrlb7b7pknxx5c15xvcgv"; + system = "latex-table"; + asd = "latex-table"; + } + ); + systems = [ "latex-table" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "array-operations" self) + (getAttr "let-plus" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + latter-day-paypal = ( + build-asdf-system { + pname = "latter-day-paypal"; + version = "20221106-git"; + asds = [ "latter-day-paypal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/latter-day-paypal/2022-11-06/latter-day-paypal-20221106-git.tgz"; + sha256 = "0a4xji2ymmr7s4gq0gc3bhbf62gwfs93ymmpvgsmb0afcsi5099q"; + system = "latter-day-paypal"; + asd = "latter-day-paypal"; + } + ); + systems = [ "latter-day-paypal" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "cl-tls" self) + (getAttr "closer-mop" self) + (getAttr "dexador" self) + (getAttr "do-urlencode" self) + (getAttr "hunchentoot" self) + (getAttr "ironclad" self) + (getAttr "jonathan" self) + (getAttr "local-time" self) + (getAttr "ningle" self) + (getAttr "quri" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lazy = ( + build-asdf-system { + pname = "lazy"; + version = "20200925-git"; + asds = [ "lazy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lazy/2020-09-25/lazy-20200925-git.tgz"; + sha256 = "0m099rwr7k17v984n4jnq4hadf19vza5qilxdyrr43scxbbrmw1n"; + system = "lazy"; + asd = "lazy"; + } + ); + systems = [ "lazy" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ledger = ( + build-asdf-system { + pname = "ledger"; + version = "master-fe503896-git"; + asds = [ "ledger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "ledger"; + asd = "ledger"; + } + ); + systems = [ "ledger" ]; + lispLibs = [ (getAttr "gwl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + leech = ( + build-asdf-system { + pname = "leech"; + version = "20140713-git"; + asds = [ "leech" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/bknr-web/2014-07-13/bknr-web-20140713-git.tgz"; + sha256 = "1m73z0hv7qsc9yddrg8zs7n3zmn9h64v4d62239wrvfnmzqk75x2"; + system = "leech"; + asd = "leech"; + } + ); + systems = [ "leech" ]; + lispLibs = [ + (getAttr "aserve" self) + (getAttr "unit-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + legion = ( + build-asdf-system { + pname = "legion"; + version = "20231021-git"; + asds = [ "legion" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/legion/2023-10-21/legion-20231021-git.tgz"; + sha256 = "0mf29w6s45dwkjvvirqk7b87swb5wvaffgb836s6sx74wwdgyyk8"; + system = "legion"; + asd = "legion"; + } + ); + systems = [ "legion" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-speedy-queue" self) + (getAttr "vom" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + legion-test = ( + build-asdf-system { + pname = "legion-test"; + version = "20231021-git"; + asds = [ "legion-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/legion/2023-10-21/legion-20231021-git.tgz"; + sha256 = "0mf29w6s45dwkjvvirqk7b87swb5wvaffgb836s6sx74wwdgyyk8"; + system = "legion-test"; + asd = "legion-test"; + } + ); + systems = [ "legion-test" ]; + lispLibs = [ + (getAttr "legion" self) + (getAttr "local-time" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + legit = ( + build-asdf-system { + pname = "legit"; + version = "20231021-git"; + asds = [ "legit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/legit/2023-10-21/legit-20231021-git.tgz"; + sha256 = "0jy021ywrbnkgbgb63ip6j7kr40m4wz2pz1v5ybn6xkkn6dyprsz"; + system = "legit"; + asd = "legit"; + } + ); + systems = [ "legit" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "documentation-utils" self) + (getAttr "lambda-fiddle" self) + (getAttr "simple-inferiors" self) + ]; + meta = { }; + } + ); + lem-opengl = ( + build-asdf-system { + pname = "lem-opengl"; + version = "20200427-git"; + asds = [ "lem-opengl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "lem-opengl"; + asd = "lem-opengl"; + } + ); + systems = [ "lem-opengl" ]; + lispLibs = [ + (getAttr "application" self) + (getAttr "control" self) + (getAttr "livesupport" self) + (getAttr "minilem" self) + (getAttr "ncurses-clone-for-lem" self) + (getAttr "sucle" self) + (getAttr "trivial-clipboard" self) + (getAttr "uncommon-lisp" self) + (getAttr "utility" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lemmy-api = ( + build-asdf-system { + pname = "lemmy-api"; + version = "20241012-git"; + asds = [ "lemmy-api" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lemmy-api/2024-10-12/lemmy-api-20241012-git.tgz"; + sha256 = "0krlf3zw4snpkgqb564xk82b1d0q2scqs05s1kalr773a5d801s7"; + system = "lemmy-api"; + asd = "lemmy-api"; + } + ); + systems = [ "lemmy-api" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "dexador" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lemmy-api-bindings-generator = ( + build-asdf-system { + pname = "lemmy-api-bindings-generator"; + version = "20241012-git"; + asds = [ "lemmy-api-bindings-generator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lemmy-api/2024-10-12/lemmy-api-20241012-git.tgz"; + sha256 = "0krlf3zw4snpkgqb564xk82b1d0q2scqs05s1kalr773a5d801s7"; + system = "lemmy-api-bindings-generator"; + asd = "lemmy-api-bindings-generator"; + } + ); + systems = [ "lemmy-api-bindings-generator" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lense = ( + build-asdf-system { + pname = "lense"; + version = "20201220-git"; + asds = [ "lense" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lense/2020-12-20/lense-20201220-git.tgz"; + sha256 = "0j11m93an38d1cl6b1kaaj5azhkn64wpiiprlj2c4cjfzrc32ffv"; + system = "lense"; + asd = "lense"; + } + ); + systems = [ "lense" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "documentation-utils-extensions" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + let-over-lambda = ( + build-asdf-system { + pname = "let-over-lambda"; + version = "20231021-git"; + asds = [ "let-over-lambda" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/let-over-lambda/2023-10-21/let-over-lambda-20231021-git.tgz"; + sha256 = "0inzbmxlx5cvvx1isv827c2zr4qixcb47n6l6qjvc11gnwihdfjf"; + system = "let-over-lambda"; + asd = "let-over-lambda"; + } + ); + systems = [ "let-over-lambda" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "fare-quasiquote-extras" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + let-over-lambda-test = ( + build-asdf-system { + pname = "let-over-lambda-test"; + version = "20231021-git"; + asds = [ "let-over-lambda-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/let-over-lambda/2023-10-21/let-over-lambda-20231021-git.tgz"; + sha256 = "0inzbmxlx5cvvx1isv827c2zr4qixcb47n6l6qjvc11gnwihdfjf"; + system = "let-over-lambda-test"; + asd = "let-over-lambda-test"; + } + ); + systems = [ "let-over-lambda-test" ]; + lispLibs = [ + (getAttr "let-over-lambda" self) + (getAttr "named-readtables" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + let-plus = ( + build-asdf-system { + pname = "let-plus"; + version = "20191130-git"; + asds = [ "let-plus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/let-plus/2019-11-30/let-plus-20191130-git.tgz"; + sha256 = "00c0nq6l4zb692rzsc9aliqzj3avrssfyz4bhxzl7f1jsz3m29jb"; + system = "let-plus"; + asd = "let-plus"; + } + ); + systems = [ "let-plus" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + ]; + meta = { }; + } + ); + letrec = ( + build-asdf-system { + pname = "letrec"; + version = "20230618-git"; + asds = [ "letrec" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/letrec/2023-06-18/letrec-20230618-git.tgz"; + sha256 = "1iwpqrpjbapdxq37g2w65r966f5nhj5466wwvd7lb1jgb03kaghn"; + system = "letrec"; + asd = "letrec"; + } + ); + systems = [ "letrec" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + letv = ( + build-asdf-system { + pname = "letv"; + version = "20241012-git"; + asds = [ "letv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/letv/2024-10-12/letv-20241012-git.tgz"; + sha256 = "000alkhqb2n47y6849pswp7dg9pd0wwgswfrcm0sm4bz3r7dyjx1"; + system = "letv"; + asd = "letv"; + } + ); + systems = [ "letv" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lev = ( + build-asdf-system { + pname = "lev"; + version = "20231021-git"; + asds = [ "lev" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lev/2023-10-21/lev-20231021-git.tgz"; + sha256 = "1lr3lzghvl5mbg9cp66carmawbzg64yd8vyivf1df10vllc7ngd6"; + system = "lev"; + asd = "lev"; + } + ); + systems = [ "lev" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lev-config" self) + ]; + meta = { }; + } + ); + lev-config = ( + build-asdf-system { + pname = "lev-config"; + version = "20231021-git"; + asds = [ "lev-config" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lev/2023-10-21/lev-20231021-git.tgz"; + sha256 = "1lr3lzghvl5mbg9cp66carmawbzg64yd8vyivf1df10vllc7ngd6"; + system = "lev-config"; + asd = "lev-config"; + } + ); + systems = [ "lev-config" ]; + lispLibs = [ (getAttr "cffi-grovel" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + leveldb = ( + build-asdf-system { + pname = "leveldb"; + version = "20160531-git"; + asds = [ "leveldb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/leveldb/2016-05-31/leveldb-20160531-git.tgz"; + sha256 = "03i4qr3g8ga2vpc8qbnipan3i7y4809i036wppkkixcsbckslckv"; + system = "leveldb"; + asd = "leveldb"; + } + ); + systems = [ "leveldb" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + levenshtein = ( + build-asdf-system { + pname = "levenshtein"; + version = "1.0"; + asds = [ "levenshtein" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/levenshtein/2010-10-06/levenshtein-1.0.tgz"; + sha256 = "0b4hdv55qcjlh3ixy3fglvb90ggmm79nl02nxkly2ls6cd7rbf5i"; + system = "levenshtein"; + asd = "levenshtein"; + } + ); + systems = [ "levenshtein" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lfarm-admin = ( + build-asdf-system { + pname = "lfarm-admin"; + version = "20150608-git"; + asds = [ "lfarm-admin" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; + sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; + system = "lfarm-admin"; + asd = "lfarm-admin"; + } + ); + systems = [ "lfarm-admin" ]; + lispLibs = [ + (getAttr "lfarm-common" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lfarm-client = ( + build-asdf-system { + pname = "lfarm-client"; + version = "20150608-git"; + asds = [ "lfarm-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; + sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; + system = "lfarm-client"; + asd = "lfarm-client"; + } + ); + systems = [ "lfarm-client" ]; + lispLibs = [ + (getAttr "lfarm-common" self) + (getAttr "lparallel" self) + (getAttr "usocket" self) + ]; + meta = { }; + } + ); + lfarm-common = ( + build-asdf-system { + pname = "lfarm-common"; + version = "20150608-git"; + asds = [ "lfarm-common" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; + sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; + system = "lfarm-common"; + asd = "lfarm-common"; + } + ); + systems = [ "lfarm-common" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-store" self) + (getAttr "flexi-streams" self) + (getAttr "usocket" self) + ]; + meta = { }; + } + ); + lfarm-gss = ( + build-asdf-system { + pname = "lfarm-gss"; + version = "20150608-git"; + asds = [ "lfarm-gss" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; + sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; + system = "lfarm-gss"; + asd = "lfarm-gss"; + } + ); + systems = [ "lfarm-gss" ]; + lispLibs = [ + (getAttr "cl-gss" self) + (getAttr "lfarm-common" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lfarm-launcher = ( + build-asdf-system { + pname = "lfarm-launcher"; + version = "20150608-git"; + asds = [ "lfarm-launcher" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; + sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; + system = "lfarm-launcher"; + asd = "lfarm-launcher"; + } + ); + systems = [ "lfarm-launcher" ]; + lispLibs = [ + (getAttr "external-program" self) + (getAttr "lfarm-admin" self) + (getAttr "lfarm-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lfarm-server = ( + build-asdf-system { + pname = "lfarm-server"; + version = "20150608-git"; + asds = [ "lfarm-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; + sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; + system = "lfarm-server"; + asd = "lfarm-server"; + } + ); + systems = [ "lfarm-server" ]; + lispLibs = [ + (getAttr "lfarm-common" self) + (getAttr "usocket" self) + ]; + meta = { }; + } + ); + lfarm-ssl = ( + build-asdf-system { + pname = "lfarm-ssl"; + version = "20150608-git"; + asds = [ "lfarm-ssl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; + sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; + system = "lfarm-ssl"; + asd = "lfarm-ssl"; + } + ); + systems = [ "lfarm-ssl" ]; + lispLibs = [ + (getAttr "cl_plus_ssl" self) + (getAttr "lfarm-common" self) + ]; + meta = { }; + } + ); + lfarm-test = ( + build-asdf-system { + pname = "lfarm-test"; + version = "20150608-git"; + asds = [ "lfarm-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lfarm/2015-06-08/lfarm-20150608-git.tgz"; + sha256 = "10kfhfx26wmaa3hk3vc7hc2fzk0rl2xdjwk8ld36x6ivvd48jlkv"; + system = "lfarm-test"; + asd = "lfarm-test"; + } + ); + systems = [ "lfarm-test" ]; + lispLibs = [ + (getAttr "lfarm-admin" self) + (getAttr "lfarm-client" self) + (getAttr "lfarm-launcher" self) + (getAttr "lfarm-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lhstats = ( + build-asdf-system { + pname = "lhstats"; + version = "20120107-git"; + asds = [ "lhstats" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lhstats/2012-01-07/lhstats-20120107-git.tgz"; + sha256 = "1x8h37vm9yd0a2g7qzili673n1c3a9rzawq27rxyzjrggv9wdnlz"; + system = "lhstats"; + asd = "lhstats"; + } + ); + systems = [ "lhstats" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lib-helper = ( + build-asdf-system { + pname = "lib-helper"; + version = "20241012-git"; + asds = [ "lib-helper" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-lib-helper/2024-10-12/cl-lib-helper-20241012-git.tgz"; + sha256 = "11aq60cs510kx9gj709q3kkgddk8aqb32pdzyikr9jylig050wyk"; + system = "lib-helper"; + asd = "lib-helper"; + } + ); + systems = [ "lib-helper" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-containers" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lib-helper-test-system = ( + build-asdf-system { + pname = "lib-helper-test-system"; + version = "20241012-git"; + asds = [ "lib-helper-test-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-lib-helper/2024-10-12/cl-lib-helper-20241012-git.tgz"; + sha256 = "11aq60cs510kx9gj709q3kkgddk8aqb32pdzyikr9jylig050wyk"; + system = "lib-helper-test-system"; + asd = "lib-helper-test-system"; + } + ); + systems = [ "lib-helper-test-system" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + libcmark = ( + build-asdf-system { + pname = "libcmark"; + version = "20241012-git"; + asds = [ "libcmark" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-cmark/2024-10-12/cl-cmark-20241012-git.tgz"; + sha256 = "1l4i530161ppfz0wn1da7g7dwf644ppp1afrq2p7qfkajm7dcfg5"; + system = "libcmark"; + asd = "libcmark"; + } + ); + systems = [ "libcmark" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + liblmdb = ( + build-asdf-system { + pname = "liblmdb"; + version = "20170830-git"; + asds = [ "liblmdb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/liblmdb/2017-08-30/liblmdb-20170830-git.tgz"; + sha256 = "0484245fcbqza40n377qhsr2v838cih6pziav5vlnml1y0cgv62b"; + system = "liblmdb"; + asd = "liblmdb"; + } + ); + systems = [ "liblmdb" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + libssh2 = ( + build-asdf-system { + pname = "libssh2"; + version = "20160531-git"; + asds = [ "libssh2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libssh2/2016-05-31/cl-libssh2-20160531-git.tgz"; + sha256 = "1f2zq30zli0gnawclpasxsajpn20cpyy9d3q9zpqyw1sfrsn0hmk"; + system = "libssh2"; + asd = "libssh2"; + } + ); + systems = [ "libssh2" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-fad" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "split-sequence" self) + (getAttr "trivial-gray-streams" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + libssh2_dot_test = ( + build-asdf-system { + pname = "libssh2.test"; + version = "20160531-git"; + asds = [ "libssh2.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libssh2/2016-05-31/cl-libssh2-20160531-git.tgz"; + sha256 = "1f2zq30zli0gnawclpasxsajpn20cpyy9d3q9zpqyw1sfrsn0hmk"; + system = "libssh2.test"; + asd = "libssh2.test"; + } + ); + systems = [ "libssh2.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_stefil" self) + (getAttr "libssh2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + libusb-ffi = ( + build-asdf-system { + pname = "libusb-ffi"; + version = "20210228-git"; + asds = [ "libusb-ffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libusb/2021-02-28/cl-libusb-20210228-git.tgz"; + sha256 = "0kyzgcflwb85q58fgn82sp0bipnq5bprg5i4h0h3jxafqqyagbnk"; + system = "libusb-ffi"; + asd = "libusb-ffi"; + } + ); + systems = [ "libusb-ffi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "static-vectors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lichat-ldap = ( + build-asdf-system { + pname = "lichat-ldap"; + version = "20231021-git"; + asds = [ "lichat-ldap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lichat-ldap/2023-10-21/lichat-ldap-20231021-git.tgz"; + sha256 = "1jgj5c0sgr4rw9vsjhz71k3ld7hp8fbbmzrn3g11fq8jl4c4iai1"; + system = "lichat-ldap"; + asd = "lichat-ldap"; + } + ); + systems = [ "lichat-ldap" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "lichat-serverlib" self) + (getAttr "trivial-ldap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lichat-protocol = ( + build-asdf-system { + pname = "lichat-protocol"; + version = "20241012-git"; + asds = [ "lichat-protocol" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lichat-protocol/2024-10-12/lichat-protocol-20241012-git.tgz"; + sha256 = "0y8546aaf539jnl29r4a8sa975jak1ld4d62w2n1kp8s9nb80z11"; + system = "lichat-protocol"; + asd = "lichat-protocol"; + } + ); + systems = [ "lichat-protocol" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-package-local-nicknames" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lichat-serverlib = ( + build-asdf-system { + pname = "lichat-serverlib"; + version = "20231021-git"; + asds = [ "lichat-serverlib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lichat-serverlib/2023-10-21/lichat-serverlib-20231021-git.tgz"; + sha256 = "04830z49lczgdf8gval4j3s0fp5p6pfgvy783mrkcdfal2dcwacq"; + system = "lichat-serverlib"; + asd = "lichat-serverlib"; + } + ); + systems = [ "lichat-serverlib" ]; + lispLibs = [ + (getAttr "crypto-shortcuts" self) + (getAttr "documentation-utils" self) + (getAttr "lichat-protocol" self) + (getAttr "trivial-mimes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lichat-tcp-client = ( + build-asdf-system { + pname = "lichat-tcp-client"; + version = "20241012-git"; + asds = [ "lichat-tcp-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lichat-tcp-client/2024-10-12/lichat-tcp-client-20241012-git.tgz"; + sha256 = "1wwh396z7185nylrsz47b6l45hyfq6mjrm620fk5bsxr3jrzxs25"; + system = "lichat-tcp-client"; + asd = "lichat-tcp-client"; + } + ); + systems = [ "lichat-tcp-client" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-base64" self) + (getAttr "documentation-utils" self) + (getAttr "lichat-protocol" self) + (getAttr "trivial-mimes" self) + (getAttr "usocket" self) + (getAttr "verbose" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lichat-tcp-server = ( + build-asdf-system { + pname = "lichat-tcp-server"; + version = "20231021-git"; + asds = [ "lichat-tcp-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lichat-tcp-server/2023-10-21/lichat-tcp-server-20231021-git.tgz"; + sha256 = "18dys957iw678y6bqfq9x85m2bnb0ck8gr6l4b61vv3g2yl2w53y"; + system = "lichat-tcp-server"; + asd = "lichat-tcp-server"; + } + ); + systems = [ "lichat-tcp-server" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "documentation-utils" self) + (getAttr "lichat-protocol" self) + (getAttr "lichat-serverlib" self) + (getAttr "usocket" self) + (getAttr "verbose" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lichat-ws-server = ( + build-asdf-system { + pname = "lichat-ws-server"; + version = "20231021-git"; + asds = [ "lichat-ws-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lichat-ws-server/2023-10-21/lichat-ws-server-20231021-git.tgz"; + sha256 = "05vmc9b8b5igifm6lb5p3fssmny6ils7aimsizql3gay4nycvxgp"; + system = "lichat-ws-server"; + asd = "lichat-ws-server"; + } + ); + systems = [ "lichat-ws-server" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "documentation-utils" self) + (getAttr "hunchensocket" self) + (getAttr "lichat-protocol" self) + (getAttr "lichat-serverlib" self) + (getAttr "verbose" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lift = ( + build-asdf-system { + pname = "lift"; + version = "20231021-git"; + asds = [ "lift" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lift/2023-10-21/lift-20231021-git.tgz"; + sha256 = "1513n46fkqw8rnvz69s7xnwj476qm8ibdlwsr63qj9yh0mib0q6x"; + system = "lift"; + asd = "lift"; + } + ); + systems = [ "lift" ]; + lispLibs = [ ]; + meta = { }; + } + ); + lift-documentation = ( + build-asdf-system { + pname = "lift-documentation"; + version = "20231021-git"; + asds = [ "lift-documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lift/2023-10-21/lift-20231021-git.tgz"; + sha256 = "1513n46fkqw8rnvz69s7xnwj476qm8ibdlwsr63qj9yh0mib0q6x"; + system = "lift-documentation"; + asd = "lift-documentation"; + } + ); + systems = [ "lift-documentation" ]; + lispLibs = [ (getAttr "lift" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lift-test = ( + build-asdf-system { + pname = "lift-test"; + version = "20231021-git"; + asds = [ "lift-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lift/2023-10-21/lift-20231021-git.tgz"; + sha256 = "1513n46fkqw8rnvz69s7xnwj476qm8ibdlwsr63qj9yh0mib0q6x"; + system = "lift-test"; + asd = "lift-test"; + } + ); + systems = [ "lift-test" ]; + lispLibs = [ (getAttr "lift" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lil = ( + build-asdf-system { + pname = "lil"; + version = "20231021-git"; + asds = [ "lil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-interface-library/2023-10-21/lisp-interface-library-20231021-git.tgz"; + sha256 = "0krh8z696a0p894vmqdw9clzhpqfqff4c4rd7s8d8hd5jwjm40aq"; + system = "lil"; + asd = "lil"; + } + ); + systems = [ "lil" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "fare-memoization" self) + (getAttr "fare-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lila = ( + build-asdf-system { + pname = "lila"; + version = "20191007-git"; + asds = [ "lila" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lila/2019-10-07/lila-20191007-git.tgz"; + sha256 = "0n29ipbcxh4fm8f1vpaywv02iaayqqk61zsfk051ksjfl5kyqypq"; + system = "lila"; + asd = "lila"; + } + ); + systems = [ "lila" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lime = ( + build-asdf-system { + pname = "lime"; + version = "20230618-git"; + asds = [ "lime" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lime/2023-06-18/lime-20230618-git.tgz"; + sha256 = "1af1m3nxxqpaw85s1cc4qf0fkv3z061xk5k17ygfmchmv8sj1agp"; + system = "lime"; + asd = "lime"; + } + ); + systems = [ "lime" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "swank-protocol" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lime-example = ( + build-asdf-system { + pname = "lime-example"; + version = "20230618-git"; + asds = [ "lime-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lime/2023-06-18/lime-20230618-git.tgz"; + sha256 = "1af1m3nxxqpaw85s1cc4qf0fkv3z061xk5k17ygfmchmv8sj1agp"; + system = "lime-example"; + asd = "lime-example"; + } + ); + systems = [ "lime-example" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "lime" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lime-test = ( + build-asdf-system { + pname = "lime-test"; + version = "20230618-git"; + asds = [ "lime-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lime/2023-06-18/lime-20230618-git.tgz"; + sha256 = "1af1m3nxxqpaw85s1cc4qf0fkv3z061xk5k17ygfmchmv8sj1agp"; + system = "lime-test"; + asd = "lime-test"; + } + ); + systems = [ "lime-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "external-program" self) + (getAttr "fiveam" self) + (getAttr "lime" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + linear-programming = ( + build-asdf-system { + pname = "linear-programming"; + version = "20241012-git"; + asds = [ "linear-programming" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/linear-programming/2024-10-12/linear-programming-20241012-git.tgz"; + sha256 = "01dy54ycmalqlk4wrkw1y6vixr0mk0nxmfy3p1w5kpdwp3642h9g"; + system = "linear-programming"; + asd = "linear-programming"; + } + ); + systems = [ "linear-programming" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + linear-programming-glpk = ( + build-asdf-system { + pname = "linear-programming-glpk"; + version = "20221106-git"; + asds = [ "linear-programming-glpk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/linear-programming-glpk/2022-11-06/linear-programming-glpk-20221106-git.tgz"; + sha256 = "0vm4qgjvw5k3v62h78j6802dm075aif06hbjw600m3hybn84rs3l"; + system = "linear-programming-glpk"; + asd = "linear-programming-glpk"; + } + ); + systems = [ "linear-programming-glpk" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "linear-programming" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + linear-programming-test = ( + build-asdf-system { + pname = "linear-programming-test"; + version = "20241012-git"; + asds = [ "linear-programming-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/linear-programming/2024-10-12/linear-programming-20241012-git.tgz"; + sha256 = "01dy54ycmalqlk4wrkw1y6vixr0mk0nxmfy3p1w5kpdwp3642h9g"; + system = "linear-programming-test"; + asd = "linear-programming-test"; + } + ); + systems = [ "linear-programming-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "iterate" self) + (getAttr "linear-programming" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + linedit = ( + build-asdf-system { + pname = "linedit"; + version = "20180430-git"; + asds = [ "linedit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/linedit/2018-04-30/linedit-20180430-git.tgz"; + sha256 = "0hhh7xn6q12rviayfihg1ym6x6csa0pdjgb88ykqbrz2rs3pgpz5"; + system = "linedit"; + asd = "linedit"; + } + ); + systems = [ "linedit" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "osicat" self) + (getAttr "terminfo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lineva = ( + build-asdf-system { + pname = "lineva"; + version = "20221106-git"; + asds = [ "lineva" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lineva/2022-11-06/lineva-20221106-git.tgz"; + sha256 = "193v40llsi51b4zk93fyrg5ll2309waw7ibl4z75bbw73kc4f2wx"; + system = "lineva"; + asd = "lineva"; + } + ); + systems = [ "lineva" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + linewise-template = ( + build-asdf-system { + pname = "linewise-template"; + version = "20230618-git"; + asds = [ "linewise-template" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/linewise-template/2023-06-18/linewise-template-20230618-git.tgz"; + sha256 = "08i2426lkcfcydmm9ca71whvyairrd0lklr6w7w17zbg0bsxsaaa"; + system = "linewise-template"; + asd = "linewise-template"; + } + ); + systems = [ "linewise-template" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + linux-packaging = ( + build-asdf-system { + pname = "linux-packaging"; + version = "20211020-git"; + asds = [ "linux-packaging" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/linux-packaging/2021-10-20/linux-packaging-20211020-git.tgz"; + sha256 = "0hmahs2slfs1bznn6zdljc5yjlg16ml795rcxnmafq7941lgqjs5"; + system = "linux-packaging"; + asd = "linux-packaging"; + } + ); + systems = [ "linux-packaging" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cffi-toolchain" self) + (getAttr "cl-ppcre" self) + (getAttr "wild-package-inferred-system" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + linux-packaging-tests = ( + build-asdf-system { + pname = "linux-packaging-tests"; + version = "20211020-git"; + asds = [ "linux-packaging-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/linux-packaging/2021-10-20/linux-packaging-20211020-git.tgz"; + sha256 = "0hmahs2slfs1bznn6zdljc5yjlg16ml795rcxnmafq7941lgqjs5"; + system = "linux-packaging-tests"; + asd = "linux-packaging-tests"; + } + ); + systems = [ "linux-packaging-tests" ]; + lispLibs = [ + (getAttr "linux-packaging" self) + (getAttr "osicat" self) + (getAttr "sqlite" self) + (getAttr "wild-package-inferred-system" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisa = ( + build-asdf-system { + pname = "lisa"; + version = "20120407-git"; + asds = [ "lisa" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisa/2012-04-07/lisa-20120407-git.tgz"; + sha256 = "12mpwxpczfq2hridjspbg51121hngbcnji37fhlr0vv4dqrg1z15"; + system = "lisa"; + asd = "lisa"; + } + ); + systems = [ "lisa" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-binary = ( + build-asdf-system { + pname = "lisp-binary"; + version = "20241012-git"; + asds = [ "lisp-binary" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-binary/2024-10-12/lisp-binary-20241012-git.tgz"; + sha256 = "1zgk6pbhjj4agazffv6mc3hjzyg4xh256sla83iqy5mwm172d810"; + system = "lisp-binary"; + asd = "lisp-binary"; + } + ); + systems = [ "lisp-binary" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "closer-mop" self) + (getAttr "flexi-streams" self) + (getAttr "moptilities" self) + (getAttr "quasiquote-2_dot_0" self) + ]; + meta = { }; + } + ); + lisp-binary-test = ( + build-asdf-system { + pname = "lisp-binary-test"; + version = "20241012-git"; + asds = [ "lisp-binary-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-binary/2024-10-12/lisp-binary-20241012-git.tgz"; + sha256 = "1zgk6pbhjj4agazffv6mc3hjzyg4xh256sla83iqy5mwm172d810"; + system = "lisp-binary-test"; + asd = "lisp-binary-test"; + } + ); + systems = [ "lisp-binary-test" ]; + lispLibs = [ (getAttr "lisp-binary" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-chat = ( + build-asdf-system { + pname = "lisp-chat"; + version = "20241012-git"; + asds = [ "lisp-chat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-chat/2024-10-12/lisp-chat-20241012-git.tgz"; + sha256 = "16ckgxg0c3rx6qvwj5cn6rmfgxbj7587r9g342bw3nfxab0sqlzd"; + system = "lisp-chat"; + asd = "lisp-chat"; + } + ); + systems = [ "lisp-chat" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-readline" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-critic = ( + build-asdf-system { + pname = "lisp-critic"; + version = "20241012-git"; + asds = [ "lisp-critic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-critic/2024-10-12/lisp-critic-20241012-git.tgz"; + sha256 = "19czs2m8h3kgwjd10pdk9r5kazbgly8g82a5q3bs7pqkja42i7x7"; + system = "lisp-critic"; + asd = "lisp-critic"; + } + ); + systems = [ "lisp-critic" ]; + lispLibs = [ (getAttr "ckr-tables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-executable = ( + build-asdf-system { + pname = "lisp-executable"; + version = "20180831-git"; + asds = [ "lisp-executable" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-executable/2018-08-31/lisp-executable-20180831-git.tgz"; + sha256 = "1309f7w0hks3agkhcn8nwm83yssdfrr9b5bjqkjg3rrhxs86c0z7"; + system = "lisp-executable"; + asd = "lisp-executable"; + } + ); + systems = [ "lisp-executable" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-executable-example = ( + build-asdf-system { + pname = "lisp-executable-example"; + version = "20180831-git"; + asds = [ "lisp-executable-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-executable/2018-08-31/lisp-executable-20180831-git.tgz"; + sha256 = "1309f7w0hks3agkhcn8nwm83yssdfrr9b5bjqkjg3rrhxs86c0z7"; + system = "lisp-executable-example"; + asd = "lisp-executable-example"; + } + ); + systems = [ "lisp-executable-example" ]; + lispLibs = [ (getAttr "lisp-executable" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-executable-tests = ( + build-asdf-system { + pname = "lisp-executable-tests"; + version = "20180831-git"; + asds = [ "lisp-executable-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-executable/2018-08-31/lisp-executable-20180831-git.tgz"; + sha256 = "1309f7w0hks3agkhcn8nwm83yssdfrr9b5bjqkjg3rrhxs86c0z7"; + system = "lisp-executable-tests"; + asd = "lisp-executable-tests"; + } + ); + systems = [ "lisp-executable-tests" ]; + lispLibs = [ + (getAttr "lisp-executable" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-interface-library = ( + build-asdf-system { + pname = "lisp-interface-library"; + version = "20231021-git"; + asds = [ "lisp-interface-library" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-interface-library/2023-10-21/lisp-interface-library-20231021-git.tgz"; + sha256 = "0krh8z696a0p894vmqdw9clzhpqfqff4c4rd7s8d8hd5jwjm40aq"; + system = "lisp-interface-library"; + asd = "lisp-interface-library"; + } + ); + systems = [ "lisp-interface-library" ]; + lispLibs = [ (getAttr "lil" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-invocation = ( + build-asdf-system { + pname = "lisp-invocation"; + version = "20180228-git"; + asds = [ "lisp-invocation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-invocation/2018-02-28/lisp-invocation-20180228-git.tgz"; + sha256 = "1qwvczjd5w6mrkz7ip3gl46f72dnxgngdc5bla35l2g7br96kzsl"; + system = "lisp-invocation"; + asd = "lisp-invocation"; + } + ); + systems = [ "lisp-invocation" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-namespace = ( + build-asdf-system { + pname = "lisp-namespace"; + version = "20221106-git"; + asds = [ "lisp-namespace" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-namespace/2022-11-06/lisp-namespace-20221106-git.tgz"; + sha256 = "1p5db9mab4whapy1pl38ajw5fkrrdw266n05mnhf4xx2fb9sbx6p"; + system = "lisp-namespace"; + asd = "lisp-namespace"; + } + ); + systems = [ "lisp-namespace" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { }; + } + ); + lisp-namespace_dot_test = ( + build-asdf-system { + pname = "lisp-namespace.test"; + version = "20221106-git"; + asds = [ "lisp-namespace.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-namespace/2022-11-06/lisp-namespace-20221106-git.tgz"; + sha256 = "1p5db9mab4whapy1pl38ajw5fkrrdw266n05mnhf4xx2fb9sbx6p"; + system = "lisp-namespace.test"; + asd = "lisp-namespace.test"; + } + ); + systems = [ "lisp-namespace.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "lisp-namespace" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-pay = ( + build-asdf-system { + pname = "lisp-pay"; + version = "20241012-git"; + asds = [ "lisp-pay" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-pay/2024-10-12/lisp-pay-20241012-git.tgz"; + sha256 = "1rbkzngas67ras5cf90y3dk99md05jmnjgsh45khj4b6kzw5a4v5"; + system = "lisp-pay"; + asd = "lisp-pay"; + } + ); + systems = [ "lisp-pay" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-base64" self) + (getAttr "cl-tls" self) + (getAttr "closer-mop" self) + (getAttr "dexador" self) + (getAttr "hu_dot_dwim_dot_defclass-star" self) + (getAttr "hunchentoot" self) + (getAttr "ironclad" self) + (getAttr "jonathan" self) + (getAttr "lack" self) + (getAttr "ningle" self) + (getAttr "shasht" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-preprocessor = ( + build-asdf-system { + pname = "lisp-preprocessor"; + version = "20200715-git"; + asds = [ "lisp-preprocessor" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-preprocessor/2020-07-15/lisp-preprocessor-20200715-git.tgz"; + sha256 = "0v0qhawcvgbxk06nfwyvcqwmqvzn2svq80l2rb12myr0znschhpi"; + system = "lisp-preprocessor"; + asd = "lisp-preprocessor"; + } + ); + systems = [ "lisp-preprocessor" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "split-sequence" self) + (getAttr "trivia" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-preprocessor-tests = ( + build-asdf-system { + pname = "lisp-preprocessor-tests"; + version = "20200715-git"; + asds = [ "lisp-preprocessor-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-preprocessor/2020-07-15/lisp-preprocessor-20200715-git.tgz"; + sha256 = "0v0qhawcvgbxk06nfwyvcqwmqvzn2svq80l2rb12myr0znschhpi"; + system = "lisp-preprocessor-tests"; + asd = "lisp-preprocessor"; + } + ); + systems = [ "lisp-preprocessor-tests" ]; + lispLibs = [ + (getAttr "lisp-preprocessor" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-stat = ( + build-asdf-system { + pname = "lisp-stat"; + version = "20241012-git"; + asds = [ "lisp-stat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-stat/2024-10-12/lisp-stat-20241012-git.tgz"; + sha256 = "0igrrwlfvdqxdqwqij819zlkma6b815d10v3kzh1r6hp9fhn0r3p"; + system = "lisp-stat"; + asd = "lisp-stat"; + } + ); + systems = [ "lisp-stat" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "alexandria_plus" self) + (getAttr "array-operations" self) + (getAttr "data-frame" self) + (getAttr "dexador" self) + (getAttr "dfio" self) + (getAttr "distributions" self) + (getAttr "num-utils" self) + (getAttr "org_dot_tfeb_dot_conduit-packages" self) + (getAttr "select" self) + (getAttr "statistics" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-types = ( + build-asdf-system { + pname = "lisp-types"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "lisp-types" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "lisp-types"; + asd = "lisp-types"; + } + ); + systems = [ "lisp-types" ]; + lispLibs = [ + (getAttr "adjuvant" self) + (getAttr "cl-robdd" self) + (getAttr "dispatch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-types-analysis = ( + build-asdf-system { + pname = "lisp-types-analysis"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "lisp-types-analysis" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "lisp-types-analysis"; + asd = "lisp-types-analysis"; + } + ); + systems = [ "lisp-types-analysis" ]; + lispLibs = [ + (getAttr "adjuvant" self) + (getAttr "cl-fad" self) + (getAttr "cl-robdd" self) + (getAttr "cl-robdd-analysis" self) + (getAttr "lisp-types" self) + (getAttr "scrutiny" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-types-test = ( + build-asdf-system { + pname = "lisp-types-test"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "lisp-types-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "lisp-types-test"; + asd = "lisp-types-test"; + } + ); + systems = [ "lisp-types-test" ]; + lispLibs = [ + (getAttr "adjuvant" self) + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "lisp-types" self) + (getAttr "lisp-types-analysis" self) + (getAttr "scrutiny" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lisp-unit = ( + build-asdf-system { + pname = "lisp-unit"; + version = "20170124-git"; + asds = [ "lisp-unit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-unit/2017-01-24/lisp-unit-20170124-git.tgz"; + sha256 = "0p6gdmgr7p383nvd66c9y9fp2bjk4jx1lpa5p09g43hr9y9pp9ry"; + system = "lisp-unit"; + asd = "lisp-unit"; + } + ); + systems = [ "lisp-unit" ]; + lispLibs = [ ]; + meta = { }; + } + ); + lisp-unit2 = ( + build-asdf-system { + pname = "lisp-unit2"; + version = "20230214-git"; + asds = [ "lisp-unit2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-unit2/2023-02-14/lisp-unit2-20230214-git.tgz"; + sha256 = "140nn22n1xv3qaash3x6h2h7xmys44s3f42b7bakfhpc4qlx0b69"; + system = "lisp-unit2"; + asd = "lisp-unit2"; + } + ); + systems = [ "lisp-unit2" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-interpol" self) + (getAttr "iterate" self) + (getAttr "symbol-munger" self) + ]; + meta = { }; + } + ); + lispbuilder-lexer = ( + build-asdf-system { + pname = "lispbuilder-lexer"; + version = "20210807-git"; + asds = [ "lispbuilder-lexer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-lexer"; + asd = "lispbuilder-lexer"; + } + ); + systems = [ "lispbuilder-lexer" ]; + lispLibs = [ (getAttr "lispbuilder-regex" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-net = ( + build-asdf-system { + pname = "lispbuilder-net"; + version = "20210807-git"; + asds = [ "lispbuilder-net" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-net"; + asd = "lispbuilder-net"; + } + ); + systems = [ "lispbuilder-net" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-net-cffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-net-cffi = ( + build-asdf-system { + pname = "lispbuilder-net-cffi"; + version = "20210807-git"; + asds = [ "lispbuilder-net-cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-net-cffi"; + asd = "lispbuilder-net-cffi"; + } + ); + systems = [ "lispbuilder-net-cffi" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-opengl-1-1 = ( + build-asdf-system { + pname = "lispbuilder-opengl-1-1"; + version = "20210807-git"; + asds = [ "lispbuilder-opengl-1-1" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-opengl-1-1"; + asd = "lispbuilder-opengl-1-1"; + } + ); + systems = [ "lispbuilder-opengl-1-1" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-opengl-examples = ( + build-asdf-system { + pname = "lispbuilder-opengl-examples"; + version = "20210807-git"; + asds = [ "lispbuilder-opengl-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-opengl-examples"; + asd = "lispbuilder-opengl-examples"; + } + ); + systems = [ "lispbuilder-opengl-examples" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-opengl-1-1" self) + (getAttr "lispbuilder-sdl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-regex = ( + build-asdf-system { + pname = "lispbuilder-regex"; + version = "20210807-git"; + asds = [ "lispbuilder-regex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-regex"; + asd = "lispbuilder-regex"; + } + ); + systems = [ "lispbuilder-regex" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl = ( + build-asdf-system { + pname = "lispbuilder-sdl"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl"; + asd = "lispbuilder-sdl"; + } + ); + systems = [ "lispbuilder-sdl" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl-assets" self) + (getAttr "lispbuilder-sdl-base" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-assets = ( + build-asdf-system { + pname = "lispbuilder-sdl-assets"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-assets" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-assets"; + asd = "lispbuilder-sdl-assets"; + } + ); + systems = [ "lispbuilder-sdl-assets" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-base = ( + build-asdf-system { + pname = "lispbuilder-sdl-base"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-base"; + asd = "lispbuilder-sdl-base"; + } + ); + systems = [ "lispbuilder-sdl-base" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl-cffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-binaries = ( + build-asdf-system { + pname = "lispbuilder-sdl-binaries"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-binaries" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-binaries"; + asd = "lispbuilder-sdl-binaries"; + } + ); + systems = [ "lispbuilder-sdl-binaries" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-cffi = ( + build-asdf-system { + pname = "lispbuilder-sdl-cffi"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-cffi"; + asd = "lispbuilder-sdl-cffi"; + } + ); + systems = [ "lispbuilder-sdl-cffi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl-binaries" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-cl-vectors = ( + build-asdf-system { + pname = "lispbuilder-sdl-cl-vectors"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-cl-vectors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-cl-vectors"; + asd = "lispbuilder-sdl-cl-vectors"; + } + ); + systems = [ "lispbuilder-sdl-cl-vectors" ]; + lispLibs = [ + (getAttr "cl-aa-misc" self) + (getAttr "cl-paths-ttf" self) + (getAttr "cl-vectors" self) + (getAttr "lispbuilder-sdl" self) + (getAttr "zpb-ttf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-cl-vectors-examples = ( + build-asdf-system { + pname = "lispbuilder-sdl-cl-vectors-examples"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-cl-vectors-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-cl-vectors-examples"; + asd = "lispbuilder-sdl-cl-vectors-examples"; + } + ); + systems = [ "lispbuilder-sdl-cl-vectors-examples" ]; + lispLibs = [ (getAttr "lispbuilder-sdl-cl-vectors" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-examples = ( + build-asdf-system { + pname = "lispbuilder-sdl-examples"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-examples"; + asd = "lispbuilder-sdl-examples"; + } + ); + systems = [ "lispbuilder-sdl-examples" ]; + lispLibs = [ (getAttr "lispbuilder-sdl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-gfx = ( + build-asdf-system { + pname = "lispbuilder-sdl-gfx"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-gfx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-gfx"; + asd = "lispbuilder-sdl-gfx"; + } + ); + systems = [ "lispbuilder-sdl-gfx" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-gfx-cffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-gfx-binaries = ( + build-asdf-system { + pname = "lispbuilder-sdl-gfx-binaries"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-gfx-binaries" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-gfx-binaries"; + asd = "lispbuilder-sdl-gfx-binaries"; + } + ); + systems = [ "lispbuilder-sdl-gfx-binaries" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-gfx-cffi = ( + build-asdf-system { + pname = "lispbuilder-sdl-gfx-cffi"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-gfx-cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-gfx-cffi"; + asd = "lispbuilder-sdl-gfx-cffi"; + } + ); + systems = [ "lispbuilder-sdl-gfx-cffi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-gfx-examples = ( + build-asdf-system { + pname = "lispbuilder-sdl-gfx-examples"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-gfx-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-gfx-examples"; + asd = "lispbuilder-sdl-gfx-examples"; + } + ); + systems = [ "lispbuilder-sdl-gfx-examples" ]; + lispLibs = [ (getAttr "lispbuilder-sdl-gfx" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-image = ( + build-asdf-system { + pname = "lispbuilder-sdl-image"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-image" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-image"; + asd = "lispbuilder-sdl-image"; + } + ); + systems = [ "lispbuilder-sdl-image" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-image-cffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-image-binaries = ( + build-asdf-system { + pname = "lispbuilder-sdl-image-binaries"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-image-binaries" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-image-binaries"; + asd = "lispbuilder-sdl-image-binaries"; + } + ); + systems = [ "lispbuilder-sdl-image-binaries" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-image-cffi = ( + build-asdf-system { + pname = "lispbuilder-sdl-image-cffi"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-image-cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-image-cffi"; + asd = "lispbuilder-sdl-image-cffi"; + } + ); + systems = [ "lispbuilder-sdl-image-cffi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-image-binaries" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-image-examples = ( + build-asdf-system { + pname = "lispbuilder-sdl-image-examples"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-image-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-image-examples"; + asd = "lispbuilder-sdl-image-examples"; + } + ); + systems = [ "lispbuilder-sdl-image-examples" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-image" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-mixer = ( + build-asdf-system { + pname = "lispbuilder-sdl-mixer"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-mixer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-mixer"; + asd = "lispbuilder-sdl-mixer"; + } + ); + systems = [ "lispbuilder-sdl-mixer" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-mixer-cffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-mixer-binaries = ( + build-asdf-system { + pname = "lispbuilder-sdl-mixer-binaries"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-mixer-binaries" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-mixer-binaries"; + asd = "lispbuilder-sdl-mixer-binaries"; + } + ); + systems = [ "lispbuilder-sdl-mixer-binaries" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-mixer-cffi = ( + build-asdf-system { + pname = "lispbuilder-sdl-mixer-cffi"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-mixer-cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-mixer-cffi"; + asd = "lispbuilder-sdl-mixer-cffi"; + } + ); + systems = [ "lispbuilder-sdl-mixer-cffi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-mixer-binaries" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-mixer-examples = ( + build-asdf-system { + pname = "lispbuilder-sdl-mixer-examples"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-mixer-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-mixer-examples"; + asd = "lispbuilder-sdl-mixer-examples"; + } + ); + systems = [ "lispbuilder-sdl-mixer-examples" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-mixer" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-ttf = ( + build-asdf-system { + pname = "lispbuilder-sdl-ttf"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-ttf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-ttf"; + asd = "lispbuilder-sdl-ttf"; + } + ); + systems = [ "lispbuilder-sdl-ttf" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-ttf-cffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-ttf-binaries = ( + build-asdf-system { + pname = "lispbuilder-sdl-ttf-binaries"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-ttf-binaries" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-ttf-binaries"; + asd = "lispbuilder-sdl-ttf-binaries"; + } + ); + systems = [ "lispbuilder-sdl-ttf-binaries" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-ttf-cffi = ( + build-asdf-system { + pname = "lispbuilder-sdl-ttf-cffi"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-ttf-cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-ttf-cffi"; + asd = "lispbuilder-sdl-ttf-cffi"; + } + ); + systems = [ "lispbuilder-sdl-ttf-cffi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-ttf-binaries" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-ttf-examples = ( + build-asdf-system { + pname = "lispbuilder-sdl-ttf-examples"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-ttf-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-ttf-examples"; + asd = "lispbuilder-sdl-ttf-examples"; + } + ); + systems = [ "lispbuilder-sdl-ttf-examples" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-ttf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-vecto = ( + build-asdf-system { + pname = "lispbuilder-sdl-vecto"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-vecto" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-vecto"; + asd = "lispbuilder-sdl-vecto"; + } + ); + systems = [ "lispbuilder-sdl-vecto" ]; + lispLibs = [ + (getAttr "lispbuilder-sdl" self) + (getAttr "lispbuilder-sdl-cl-vectors" self) + (getAttr "vecto" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-sdl-vecto-examples = ( + build-asdf-system { + pname = "lispbuilder-sdl-vecto-examples"; + version = "20210807-git"; + asds = [ "lispbuilder-sdl-vecto-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-sdl-vecto-examples"; + asd = "lispbuilder-sdl-vecto-examples"; + } + ); + systems = [ "lispbuilder-sdl-vecto-examples" ]; + lispLibs = [ (getAttr "lispbuilder-sdl-vecto" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-windows = ( + build-asdf-system { + pname = "lispbuilder-windows"; + version = "20210807-git"; + asds = [ "lispbuilder-windows" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-windows"; + asd = "lispbuilder-windows"; + } + ); + systems = [ "lispbuilder-windows" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispbuilder-yacc = ( + build-asdf-system { + pname = "lispbuilder-yacc"; + version = "20210807-git"; + asds = [ "lispbuilder-yacc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispbuilder/2021-08-07/lispbuilder-20210807-git.tgz"; + sha256 = "0ssm72ss4k6gjkm7nq225miisip6kvhmnnycvxn8x1z20qld03iq"; + system = "lispbuilder-yacc"; + asd = "lispbuilder-yacc"; + } + ); + systems = [ "lispbuilder-yacc" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispcord = ( + build-asdf-system { + pname = "lispcord"; + version = "20241012-git"; + asds = [ "lispcord" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispcord/2024-10-12/lispcord-20241012-git.tgz"; + sha256 = "11xwrrvvqdm1wdnxrxqgizgw25plsn28n2k0lm5kakax9n221brn"; + system = "lispcord"; + asd = "lispcord"; + } + ); + systems = [ "lispcord" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "drakma" self) + (getAttr "jonathan" self) + (getAttr "split-sequence" self) + (getAttr "verbose" self) + (getAttr "websocket-driver-client" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lispqr = ( + build-asdf-system { + pname = "lispqr"; + version = "20210630-git"; + asds = [ "lispqr" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lispqr/2021-06-30/lispqr-20210630-git.tgz"; + sha256 = "06v1xpw5r4nxll286frhkc3ysvr50m904d33marnjmiax41y8qkc"; + system = "lispqr"; + asd = "lispqr"; + } + ); + systems = [ "lispqr" ]; + lispLibs = [ (getAttr "zpng" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + list-named-class = ( + build-asdf-system { + pname = "list-named-class"; + version = "20200325-git"; + asds = [ "list-named-class" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/list-named-class/2020-03-25/list-named-class-20200325-git.tgz"; + sha256 = "1bdi9q9wvfj66jji3n9hpjrj9271ial2awsb0xw80bmy6wqbg8kq"; + system = "list-named-class"; + asd = "list-named-class"; + } + ); + systems = [ "list-named-class" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + list-of = ( + build-asdf-system { + pname = "list-of"; + version = "20221106-git"; + asds = [ "list-of" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-finalizers/2022-11-06/asdf-finalizers-20221106-git.tgz"; + sha256 = "1w56c9yjjydjshsgqxz57qlp2v3r4ilbisnsgiqphvxnhvd41y0v"; + system = "list-of"; + asd = "list-of"; + } + ); + systems = [ "list-of" ]; + lispLibs = [ (getAttr "asdf-finalizers" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + listopia = ( + build-asdf-system { + pname = "listopia"; + version = "20210411-git"; + asds = [ "listopia" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/listopia/2021-04-11/listopia-20210411-git.tgz"; + sha256 = "0jd3mdv0ia8mfgdbpndzm3rdgc6nn9d9xpjzqjx582qhbnc0yji0"; + system = "listopia"; + asd = "listopia"; + } + ); + systems = [ "listopia" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + listopia-bench = ( + build-asdf-system { + pname = "listopia-bench"; + version = "20210411-git"; + asds = [ "listopia-bench" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/listopia/2021-04-11/listopia-20210411-git.tgz"; + sha256 = "0jd3mdv0ia8mfgdbpndzm3rdgc6nn9d9xpjzqjx582qhbnc0yji0"; + system = "listopia-bench"; + asd = "listopia-bench"; + } + ); + systems = [ "listopia-bench" ]; + lispLibs = [ + (getAttr "listopia" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "trivial-benchmark" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + liter = ( + build-asdf-system { + pname = "liter"; + version = "20211020-git"; + asds = [ "liter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/colliflower/2021-10-20/colliflower-20211020-git.tgz"; + sha256 = "1fzn9s7wm7wmffrdm21lpvry9jb320456cmmprn976a533lp704r"; + system = "liter"; + asd = "liter"; + } + ); + systems = [ "liter" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "iterate" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + literate-demo = ( + build-asdf-system { + pname = "literate-demo"; + version = "20230618-git"; + asds = [ "literate-demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/literate-lisp/2023-06-18/literate-lisp-20230618-git.tgz"; + sha256 = "0smxf0a62dnwcfxsbsdkx4n5nqx9dlxdz6c2vfivxpqld6d6ap02"; + system = "literate-demo"; + asd = "literate-demo"; + } + ); + systems = [ "literate-demo" ]; + lispLibs = [ + (getAttr "iterate" self) + (getAttr "literate-lisp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + literate-lisp = ( + build-asdf-system { + pname = "literate-lisp"; + version = "20230618-git"; + asds = [ "literate-lisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/literate-lisp/2023-06-18/literate-lisp-20230618-git.tgz"; + sha256 = "0smxf0a62dnwcfxsbsdkx4n5nqx9dlxdz6c2vfivxpqld6d6ap02"; + system = "literate-lisp"; + asd = "literate-lisp"; + } + ); + systems = [ "literate-lisp" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + litterae = ( + build-asdf-system { + pname = "litterae"; + version = "20200715-git"; + asds = [ "litterae" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/litterae/2020-07-15/litterae-20200715-git.tgz"; + sha256 = "05q6apkcxacis4llq8xjp468yg5v6za0ispcy5wqsb44ic0vhmsl"; + system = "litterae"; + asd = "litterae"; + } + ); + systems = [ "litterae" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "_3bmd-ext-code-blocks" self) + (getAttr "cl-yaml" self) + (getAttr "docparser" self) + (getAttr "lsx" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + litterae-test-system = ( + build-asdf-system { + pname = "litterae-test-system"; + version = "20200715-git"; + asds = [ "litterae-test-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/litterae/2020-07-15/litterae-20200715-git.tgz"; + sha256 = "05q6apkcxacis4llq8xjp468yg5v6za0ispcy5wqsb44ic0vhmsl"; + system = "litterae-test-system"; + asd = "litterae-test-system"; + } + ); + systems = [ "litterae-test-system" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + livesupport = ( + build-asdf-system { + pname = "livesupport"; + version = "release-quicklisp-71e6e412-git"; + asds = [ "livesupport" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/livesupport/2019-05-21/livesupport-release-quicklisp-71e6e412-git.tgz"; + sha256 = "1rvnl0mncylbx63608pz5llss7y92j7z3ydambk9mcnjg2mjaapg"; + system = "livesupport"; + asd = "livesupport"; + } + ); + systems = [ "livesupport" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lla = ( + build-asdf-system { + pname = "lla"; + version = "20241012-git"; + asds = [ "lla" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lla/2024-10-12/lla-20241012-git.tgz"; + sha256 = "19j11z8m00ry2bfn3ahai155b6qz995qqg7ipzvjdr05sj4gfb58"; + system = "lla"; + asd = "lla"; + } + ); + systems = [ "lla" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cffi" self) + (getAttr "let-plus" self) + (getAttr "num-utils" self) + (getAttr "select" self) + ]; + meta = { }; + } + ); + lmdb = ( + build-asdf-system { + pname = "lmdb"; + version = "20230214-git"; + asds = [ "lmdb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lmdb/2023-02-14/lmdb-20230214-git.tgz"; + sha256 = "1mccswfdgg7pxvnq3rds2zh0257853zqf81q4igfpjh5lhg3czgh"; + system = "lmdb"; + asd = "lmdb"; + } + ); + systems = [ "lmdb" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-reexport" self) + (getAttr "mgl-pax" self) + (getAttr "osicat" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lml = ( + build-asdf-system { + pname = "lml"; + version = "20150923-git"; + asds = [ "lml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lml/2015-09-23/lml-20150923-git.tgz"; + sha256 = "1s8v9p08vwl08y6ssxn4l088zz57d6fr13lzdz93i9jb8w8884wk"; + system = "lml"; + asd = "lml"; + } + ); + systems = [ "lml" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lml-tests = ( + build-asdf-system { + pname = "lml-tests"; + version = "20150923-git"; + asds = [ "lml-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lml/2015-09-23/lml-20150923-git.tgz"; + sha256 = "1s8v9p08vwl08y6ssxn4l088zz57d6fr13lzdz93i9jb8w8884wk"; + system = "lml-tests"; + asd = "lml-tests"; + } + ); + systems = [ "lml-tests" ]; + lispLibs = [ + (getAttr "lml" self) + (getAttr "rt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lml2 = ( + build-asdf-system { + pname = "lml2"; + version = "20150923-git"; + asds = [ "lml2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lml2/2015-09-23/lml2-20150923-git.tgz"; + sha256 = "0v4d30x5zq1asp4r91nrzljpk2pm1plr0jns7a5wrf1n9fay57a6"; + system = "lml2"; + asd = "lml2"; + } + ); + systems = [ "lml2" ]; + lispLibs = [ (getAttr "kmrcl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lml2-tests = ( + build-asdf-system { + pname = "lml2-tests"; + version = "20150923-git"; + asds = [ "lml2-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lml2/2015-09-23/lml2-20150923-git.tgz"; + sha256 = "0v4d30x5zq1asp4r91nrzljpk2pm1plr0jns7a5wrf1n9fay57a6"; + system = "lml2-tests"; + asd = "lml2-tests"; + } + ); + systems = [ "lml2-tests" ]; + lispLibs = [ + (getAttr "lml2" self) + (getAttr "rt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + local-package-aliases = ( + build-asdf-system { + pname = "local-package-aliases"; + version = "20201220-git"; + asds = [ "local-package-aliases" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/local-package-aliases/2020-12-20/local-package-aliases-20201220-git.tgz"; + sha256 = "01knnxnximj2qyg8lhv0ijw69hfwqbfbmgvfjwnm7jbdgcp9wxnr"; + system = "local-package-aliases"; + asd = "local-package-aliases"; + } + ); + systems = [ "local-package-aliases" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + local-time = ( + build-asdf-system { + pname = "local-time"; + version = "20241012-git"; + asds = [ "local-time" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/local-time/2024-10-12/local-time-20241012-git.tgz"; + sha256 = "0jb1mb5zs4ryiah8zjzhpln1z686mfmpmvg1phgpr2mh9vvlgjk2"; + system = "local-time"; + asd = "local-time"; + } + ); + systems = [ "local-time" ]; + lispLibs = [ ]; + meta = { }; + } + ); + local-time-duration = ( + build-asdf-system { + pname = "local-time-duration"; + version = "20180430-git"; + asds = [ "local-time-duration" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/local-time-duration/2018-04-30/local-time-duration-20180430-git.tgz"; + sha256 = "0f13mg18lv31lclz9jvqyj8d85p1jj1366nlld8m3dxnnwsbbkd6"; + system = "local-time-duration"; + asd = "local-time-duration"; + } + ); + systems = [ "local-time-duration" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "esrap" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + log4cl = ( + build-asdf-system { + pname = "log4cl"; + version = "20230618-git"; + asds = [ "log4cl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/log4cl/2023-06-18/log4cl-20230618-git.tgz"; + sha256 = "0n119sy35k9yl4n18az1sw9a7saa5jh3v44863b305by1p5xdy7k"; + system = "log4cl"; + asd = "log4cl"; + } + ); + systems = [ "log4cl" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { }; + } + ); + log4cl-examples = ( + build-asdf-system { + pname = "log4cl-examples"; + version = "20230618-git"; + asds = [ "log4cl-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/log4cl/2023-06-18/log4cl-20230618-git.tgz"; + sha256 = "0n119sy35k9yl4n18az1sw9a7saa5jh3v44863b305by1p5xdy7k"; + system = "log4cl-examples"; + asd = "log4cl-examples"; + } + ); + systems = [ "log4cl-examples" ]; + lispLibs = [ + (getAttr "log4cl" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + log4cl-extras = ( + build-asdf-system { + pname = "log4cl-extras"; + version = "20241012-git"; + asds = [ "log4cl-extras" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/log4cl-extras/2024-10-12/log4cl-extras-20241012-git.tgz"; + sha256 = "17p8y884163j0gab0idra297kivzdgagl2im0gkmdhgrh0dw3b53"; + system = "log4cl-extras"; + asd = "log4cl-extras"; + } + ); + systems = [ "log4cl-extras" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "_40ants-doc" self) + (getAttr "alexandria" self) + (getAttr "cl-strings" self) + (getAttr "dissect" self) + (getAttr "global-vars" self) + (getAttr "jonathan" self) + (getAttr "local-time" self) + (getAttr "log4cl" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + (getAttr "with-output-to-stream" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + log4cl-extras-test = ( + build-asdf-system { + pname = "log4cl-extras-test"; + version = "20241012-git"; + asds = [ "log4cl-extras-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/log4cl-extras/2024-10-12/log4cl-extras-20241012-git.tgz"; + sha256 = "17p8y884163j0gab0idra297kivzdgagl2im0gkmdhgrh0dw3b53"; + system = "log4cl-extras-test"; + asd = "log4cl-extras-test"; + } + ); + systems = [ "log4cl-extras-test" ]; + lispLibs = [ + (getAttr "hamcrest" self) + (getAttr "jonathan" self) + (getAttr "rove" self) + (getAttr "secret-values" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + log4cl_dot_log4slime = ( + build-asdf-system { + pname = "log4cl.log4slime"; + version = "20230618-git"; + asds = [ "log4cl.log4slime" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/log4cl/2023-06-18/log4cl-20230618-git.tgz"; + sha256 = "0n119sy35k9yl4n18az1sw9a7saa5jh3v44863b305by1p5xdy7k"; + system = "log4cl.log4slime"; + asd = "log4cl.log4slime"; + } + ); + systems = [ "log4cl.log4slime" ]; + lispLibs = [ + (getAttr "log4cl" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + log4cl_dot_log4sly = ( + build-asdf-system { + pname = "log4cl.log4sly"; + version = "20230618-git"; + asds = [ "log4cl.log4sly" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/log4cl/2023-06-18/log4cl-20230618-git.tgz"; + sha256 = "0n119sy35k9yl4n18az1sw9a7saa5jh3v44863b305by1p5xdy7k"; + system = "log4cl.log4sly"; + asd = "log4cl.log4sly"; + } + ); + systems = [ "log4cl.log4sly" ]; + lispLibs = [ + (getAttr "log4cl" self) + (getAttr "slynk" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + log5 = ( + build-asdf-system { + pname = "log5"; + version = "20110619-git"; + asds = [ "log5" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/log5/2011-06-19/log5-20110619-git.tgz"; + sha256 = "0f7qhhphijwk6a4hq18gpgifld7hwwpma6md845hgjmpvyqvrw2g"; + system = "log5"; + asd = "log5"; + } + ); + systems = [ "log5" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lorem-ipsum = ( + build-asdf-system { + pname = "lorem-ipsum"; + version = "20181018-git"; + asds = [ "lorem-ipsum" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lorem-ipsum/2018-10-18/lorem-ipsum-20181018-git.tgz"; + sha256 = "1530qq0bk3xr25m77q96pbi1idnxdkax8cwmvq4ch03rfjy34j7n"; + system = "lorem-ipsum"; + asd = "lorem-ipsum"; + } + ); + systems = [ "lorem-ipsum" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lowlight = ( + build-asdf-system { + pname = "lowlight"; + version = "20131211-git"; + asds = [ "lowlight" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lowlight/2013-12-11/lowlight-20131211-git.tgz"; + sha256 = "1i27hdac7aqb27rn5cslpf5lwvkrfz52b6rf7zqq0fi42zmvgb4p"; + system = "lowlight"; + asd = "lowlight"; + } + ); + systems = [ "lowlight" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-who" self) + (getAttr "graylex" self) + (getAttr "spinneret" self) + (getAttr "yacc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lowlight_dot_doc = ( + build-asdf-system { + pname = "lowlight.doc"; + version = "20131211-git"; + asds = [ "lowlight.doc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lowlight/2013-12-11/lowlight-20131211-git.tgz"; + sha256 = "1i27hdac7aqb27rn5cslpf5lwvkrfz52b6rf7zqq0fi42zmvgb4p"; + system = "lowlight.doc"; + asd = "lowlight.doc"; + } + ); + systems = [ "lowlight.doc" ]; + lispLibs = [ + (getAttr "cl-gendoc" self) + (getAttr "lowlight" self) + (getAttr "lowlight_dot_tests" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lowlight_dot_old = ( + build-asdf-system { + pname = "lowlight.old"; + version = "20131211-git"; + asds = [ "lowlight.old" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lowlight/2013-12-11/lowlight-20131211-git.tgz"; + sha256 = "1i27hdac7aqb27rn5cslpf5lwvkrfz52b6rf7zqq0fi42zmvgb4p"; + system = "lowlight.old"; + asd = "lowlight.old"; + } + ); + systems = [ "lowlight.old" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-who" self) + (getAttr "spinneret" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lowlight_dot_tests = ( + build-asdf-system { + pname = "lowlight.tests"; + version = "20131211-git"; + asds = [ "lowlight.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lowlight/2013-12-11/lowlight-20131211-git.tgz"; + sha256 = "1i27hdac7aqb27rn5cslpf5lwvkrfz52b6rf7zqq0fi42zmvgb4p"; + system = "lowlight.tests"; + asd = "lowlight.tests"; + } + ); + systems = [ "lowlight.tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "lowlight" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lparallel = ( + build-asdf-system { + pname = "lparallel"; + version = "20160825-git"; + asds = [ "lparallel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lparallel/2016-08-25/lparallel-20160825-git.tgz"; + sha256 = "0g0aylrbbrqsz0ahmwhvnk4cmc2931fllbpcfgzsprwnqqd7vwq9"; + system = "lparallel"; + asd = "lparallel"; + } + ); + systems = [ "lparallel" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + ]; + meta = { }; + } + ); + lparallel-bench = ( + build-asdf-system { + pname = "lparallel-bench"; + version = "20160825-git"; + asds = [ "lparallel-bench" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lparallel/2016-08-25/lparallel-20160825-git.tgz"; + sha256 = "0g0aylrbbrqsz0ahmwhvnk4cmc2931fllbpcfgzsprwnqqd7vwq9"; + system = "lparallel-bench"; + asd = "lparallel-bench"; + } + ); + systems = [ "lparallel-bench" ]; + lispLibs = [ + (getAttr "lparallel" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lparallel-test = ( + build-asdf-system { + pname = "lparallel-test"; + version = "20160825-git"; + asds = [ "lparallel-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lparallel/2016-08-25/lparallel-20160825-git.tgz"; + sha256 = "0g0aylrbbrqsz0ahmwhvnk4cmc2931fllbpcfgzsprwnqqd7vwq9"; + system = "lparallel-test"; + asd = "lparallel-test"; + } + ); + systems = [ "lparallel-test" ]; + lispLibs = [ (getAttr "lparallel" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lquery = ( + build-asdf-system { + pname = "lquery"; + version = "20231021-git"; + asds = [ "lquery" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lquery/2023-10-21/lquery-20231021-git.tgz"; + sha256 = "124cjp4a99cicdk18rwz2slcyzvm982saddrvqcr97fi4i2nhnsg"; + system = "lquery"; + asd = "lquery"; + } + ); + systems = [ "lquery" ]; + lispLibs = [ + (getAttr "array-utils" self) + (getAttr "clss" self) + (getAttr "form-fiddle" self) + (getAttr "plump" self) + ]; + meta = { }; + } + ); + lquery-test = ( + build-asdf-system { + pname = "lquery-test"; + version = "20231021-git"; + asds = [ "lquery-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lquery/2023-10-21/lquery-20231021-git.tgz"; + sha256 = "124cjp4a99cicdk18rwz2slcyzvm982saddrvqcr97fi4i2nhnsg"; + system = "lquery-test"; + asd = "lquery-test"; + } + ); + systems = [ "lquery-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "lquery" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lracer = ( + build-asdf-system { + pname = "lracer"; + version = "20241012-git"; + asds = [ "lracer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/racer/2024-10-12/racer-20241012-git.tgz"; + sha256 = "120x046c6vcrj70vb6ryf04mwbr8c6a15llb68x7h1siij8vwgvk"; + system = "lracer"; + asd = "lracer"; + } + ); + systems = [ "lracer" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lredis = ( + build-asdf-system { + pname = "lredis"; + version = "20141106-git"; + asds = [ "lredis" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lredis/2014-11-06/lredis-20141106-git.tgz"; + sha256 = "08srvlys0fyslfpmhc740cana7fkxm2kc7mxds4083wgxw3prhf2"; + system = "lredis"; + asd = "lredis"; + } + ); + systems = [ "lredis" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "babel-streams" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lru-cache = ( + build-asdf-system { + pname = "lru-cache"; + version = "20241012-git"; + asds = [ "lru-cache" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lru-cache/2024-10-12/lru-cache-20241012-git.tgz"; + sha256 = "035pl11j1l129akgf33w5c0b8c6gxw1xpj54r0fzxz3dw7cs8pg1"; + system = "lru-cache"; + asd = "lru-cache"; + } + ); + systems = [ "lru-cache" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lru-cache-test = ( + build-asdf-system { + pname = "lru-cache-test"; + version = "20241012-git"; + asds = [ "lru-cache-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lru-cache/2024-10-12/lru-cache-20241012-git.tgz"; + sha256 = "035pl11j1l129akgf33w5c0b8c6gxw1xpj54r0fzxz3dw7cs8pg1"; + system = "lru-cache-test"; + asd = "lru-cache-test"; + } + ); + systems = [ "lru-cache-test" ]; + lispLibs = [ + (getAttr "lru-cache" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lsx = ( + build-asdf-system { + pname = "lsx"; + version = "20220220-git"; + asds = [ "lsx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lsx/2022-02-20/lsx-20220220-git.tgz"; + sha256 = "1pdq6csr8pkzcq2zkhhm6wkp9zxx2aypjd16rcw4q43mff09y041"; + system = "lsx"; + asd = "lsx"; + } + ); + systems = [ "lsx" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ltk = ( + build-asdf-system { + pname = "ltk"; + version = "20221106-git"; + asds = [ "ltk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ltk/2022-11-06/ltk-20221106-git.tgz"; + sha256 = "0vqmdq3k235hd8d9cg0ipv0kw28aiydvr9j1igfnrs1ns9sm79va"; + system = "ltk"; + asd = "ltk"; + } + ); + systems = [ "ltk" ]; + lispLibs = [ ]; + meta = { }; + } + ); + ltk-mw = ( + build-asdf-system { + pname = "ltk-mw"; + version = "20221106-git"; + asds = [ "ltk-mw" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ltk/2022-11-06/ltk-20221106-git.tgz"; + sha256 = "0vqmdq3k235hd8d9cg0ipv0kw28aiydvr9j1igfnrs1ns9sm79va"; + system = "ltk-mw"; + asd = "ltk-mw"; + } + ); + systems = [ "ltk-mw" ]; + lispLibs = [ (getAttr "ltk" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ltk-remote = ( + build-asdf-system { + pname = "ltk-remote"; + version = "20221106-git"; + asds = [ "ltk-remote" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ltk/2022-11-06/ltk-20221106-git.tgz"; + sha256 = "0vqmdq3k235hd8d9cg0ipv0kw28aiydvr9j1igfnrs1ns9sm79va"; + system = "ltk-remote"; + asd = "ltk-remote"; + } + ); + systems = [ "ltk-remote" ]; + lispLibs = [ (getAttr "ltk" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lucene-in-action-tests = ( + build-asdf-system { + pname = "lucene-in-action-tests"; + version = "20180228-git"; + asds = [ "lucene-in-action-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/montezuma/2018-02-28/montezuma-20180228-git.tgz"; + sha256 = "0svmvsbsirydk3c1spzfvj8qmkzcs9i69anpfvk1843i62wb7x2c"; + system = "lucene-in-action-tests"; + asd = "lucene-in-action-tests"; + } + ); + systems = [ "lucene-in-action-tests" ]; + lispLibs = [ + (getAttr "lift" self) + (getAttr "montezuma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lunamech-matrix-api = ( + build-asdf-system { + pname = "lunamech-matrix-api"; + version = "20230214-git"; + asds = [ "lunamech-matrix-api" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lunamech-matrix-api/2023-02-14/lunamech-matrix-api-20230214-git.tgz"; + sha256 = "0a664qq4m5gk4iv5ck63gmsl3218jhjsalawklj56wn2pw0cf8a0"; + system = "lunamech-matrix-api"; + asd = "lunamech-matrix-api"; + } + ); + systems = [ "lunamech-matrix-api" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "closer-mop" self) + (getAttr "dexador" self) + (getAttr "do-urlencode" self) + (getAttr "drakma" self) + (getAttr "jonathan" self) + (getAttr "plump" self) + (getAttr "quri" self) + (getAttr "reader" self) + (getAttr "shasht" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lw-compat = ( + build-asdf-system { + pname = "lw-compat"; + version = "20160318-git"; + asds = [ "lw-compat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lw-compat/2016-03-18/lw-compat-20160318-git.tgz"; + sha256 = "131rq5k2mlv9bfhmafiv6nfsivl4cxx13d9wr06v5jrqnckh4aav"; + system = "lw-compat"; + asd = "lw-compat"; + } + ); + systems = [ "lw-compat" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lyrics = ( + build-asdf-system { + pname = "lyrics"; + version = "20210807-git"; + asds = [ "lyrics" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lyrics/2021-08-07/lyrics-20210807-git.tgz"; + sha256 = "1xdhl53i9pim2mbviwqahlkgfsja7ihyvvrwz8q22ljv6bnb6011"; + system = "lyrics"; + asd = "lyrics"; + } + ); + systems = [ "lyrics" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "defmemo" self) + (getAttr "drakma" self) + (getAttr "lquery" self) + (getAttr "plump" self) + (getAttr "sqlite" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lzlib = ( + build-asdf-system { + pname = "lzlib"; + version = "20230618-git"; + asds = [ "lzlib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-lzlib/2023-06-18/cl-lzlib-20230618-git.tgz"; + sha256 = "1nb2g6a7l1qzm1bwv8b15nflgv8rv478x0n7viv6rlwzgqs5q3b8"; + system = "lzlib"; + asd = "lzlib"; + } + ); + systems = [ "lzlib" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-octet-streams" self) + (getAttr "lparallel" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + lzlib-tests = ( + build-asdf-system { + pname = "lzlib-tests"; + version = "20230618-git"; + asds = [ "lzlib-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-lzlib/2023-06-18/cl-lzlib-20230618-git.tgz"; + sha256 = "1nb2g6a7l1qzm1bwv8b15nflgv8rv478x0n7viv6rlwzgqs5q3b8"; + system = "lzlib-tests"; + asd = "lzlib-tests"; + } + ); + systems = [ "lzlib-tests" ]; + lispLibs = [ + (getAttr "cl-octet-streams" self) + (getAttr "fiveam" self) + (getAttr "lzlib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + machine-state = ( + build-asdf-system { + pname = "machine-state"; + version = "20241012-git"; + asds = [ "machine-state" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/machine-state/2024-10-12/machine-state-20241012-git.tgz"; + sha256 = "1zmag6j9zfpnv9xfdjzb6dfg3jzvhandm1plyv50i619p0w0nagk"; + system = "machine-state"; + asd = "machine-state"; + } + ); + systems = [ "machine-state" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "pathname-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + macro-html = ( + build-asdf-system { + pname = "macro-html"; + version = "20151218-git"; + asds = [ "macro-html" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/macro-html/2015-12-18/macro-html-20151218-git.tgz"; + sha256 = "05gzgijz8r3dw3ilz7d5i0g0mbcyv9k8w2dgvw7n478njp1gfj4b"; + system = "macro-html"; + asd = "macro-html"; + } + ); + systems = [ "macro-html" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + macro-level = ( + build-asdf-system { + pname = "macro-level"; + version = "1.1"; + asds = [ "macro-level" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/macro-level/2023-10-21/macro-level_1.1.tgz"; + sha256 = "1jcidyf4kfzzj5vj4i3l1vw0sbj9njaminb6j1bcq70y9w15qm68"; + system = "macro-level"; + asd = "macro-level"; + } + ); + systems = [ "macro-level" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + macro-level__tests = ( + build-asdf-system { + pname = "macro-level_tests"; + version = "1.1"; + asds = [ "macro-level_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/macro-level/2023-10-21/macro-level_1.1.tgz"; + sha256 = "1jcidyf4kfzzj5vj4i3l1vw0sbj9njaminb6j1bcq70y9w15qm68"; + system = "macro-level_tests"; + asd = "macro-level_tests"; + } + ); + systems = [ "macro-level_tests" ]; + lispLibs = [ + (getAttr "macro-level" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + macrodynamics = ( + build-asdf-system { + pname = "macrodynamics"; + version = "20180228-git"; + asds = [ "macrodynamics" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/macrodynamics/2018-02-28/macrodynamics-20180228-git.tgz"; + sha256 = "1ysgin8lzd4fdl5c63v3ga9v6lzk3gyl1h8jhl0ar6wyhd3023l4"; + system = "macrodynamics"; + asd = "macrodynamics"; + } + ); + systems = [ "macrodynamics" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + macroexpand-dammit = ( + build-asdf-system { + pname = "macroexpand-dammit"; + version = "20131111-http"; + asds = [ "macroexpand-dammit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/macroexpand-dammit/2013-11-11/macroexpand-dammit-20131111-http.tgz"; + sha256 = "10avpq3qffrc51hrfjwp3vi5vv9b1aip1dnwncnlc3yd498b3pfl"; + system = "macroexpand-dammit"; + asd = "macroexpand-dammit"; + } + ); + systems = [ "macroexpand-dammit" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + madeira-port = ( + build-asdf-system { + pname = "madeira-port"; + version = "20150709-git"; + asds = [ "madeira-port" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/madeira-port/2015-07-09/madeira-port-20150709-git.tgz"; + sha256 = "0zl6i11vm1akr0382zh582v3vkxjwmabsnfjcfgrp2wbkq4mvdgq"; + system = "madeira-port"; + asd = "madeira-port"; + } + ); + systems = [ "madeira-port" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + madeira-port-tests = ( + build-asdf-system { + pname = "madeira-port-tests"; + version = "20150709-git"; + asds = [ "madeira-port-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/madeira-port/2015-07-09/madeira-port-20150709-git.tgz"; + sha256 = "0zl6i11vm1akr0382zh582v3vkxjwmabsnfjcfgrp2wbkq4mvdgq"; + system = "madeira-port-tests"; + asd = "madeira-port"; + } + ); + systems = [ "madeira-port-tests" ]; + lispLibs = [ + (getAttr "eos" self) + (getAttr "madeira-port" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + magic-ed = ( + build-asdf-system { + pname = "magic-ed"; + version = "20200325-git"; + asds = [ "magic-ed" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/magic-ed/2020-03-25/magic-ed-20200325-git.tgz"; + sha256 = "1j6il4lif0dy6hqiz6n91yl8dvii9pk1i9vz0faq5mnr42mr7i5f"; + system = "magic-ed"; + asd = "magic-ed"; + } + ); + systems = [ "magic-ed" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + magicffi = ( + build-asdf-system { + pname = "magicffi"; + version = "20210531-git"; + asds = [ "magicffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/magicffi/2021-05-31/magicffi-20210531-git.tgz"; + sha256 = "0l2b2irpb19b9pyxbmkxi4i5y6crx8nk7qrbihsdqahlkrwsk1il"; + system = "magicffi"; + asd = "magicffi"; + } + ); + systems = [ "magicffi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + magicl = ( + build-asdf-system { + pname = "magicl"; + version = "v0.11.0"; + asds = [ "magicl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/magicl/2024-10-12/magicl-v0.11.0.tgz"; + sha256 = "10scw5qhrgjhfrlia5iqn2yy2zj1d57m45g479vg56lw849whscw"; + system = "magicl"; + asd = "magicl"; + } + ); + systems = [ "magicl" ]; + lispLibs = [ + (getAttr "abstract-classes" self) + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + (getAttr "interface" self) + (getAttr "policy-cond" self) + (getAttr "static-vectors" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + broken = true; + hydraPlatforms = [ ]; + }; + } + ); + magicl-examples = ( + build-asdf-system { + pname = "magicl-examples"; + version = "v0.11.0"; + asds = [ "magicl-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/magicl/2024-10-12/magicl-v0.11.0.tgz"; + sha256 = "10scw5qhrgjhfrlia5iqn2yy2zj1d57m45g479vg56lw849whscw"; + system = "magicl-examples"; + asd = "magicl-examples"; + } + ); + systems = [ "magicl-examples" ]; + lispLibs = [ (getAttr "magicl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + magicl-gen = ( + build-asdf-system { + pname = "magicl-gen"; + version = "v0.11.0"; + asds = [ "magicl-gen" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/magicl/2024-10-12/magicl-v0.11.0.tgz"; + sha256 = "10scw5qhrgjhfrlia5iqn2yy2zj1d57m45g479vg56lw849whscw"; + system = "magicl-gen"; + asd = "magicl-gen"; + } + ); + systems = [ "magicl-gen" ]; + lispLibs = [ + (getAttr "abstract-classes" self) + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + (getAttr "interface" self) + (getAttr "policy-cond" self) + (getAttr "static-vectors" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + magicl-tests = ( + build-asdf-system { + pname = "magicl-tests"; + version = "v0.11.0"; + asds = [ "magicl-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/magicl/2024-10-12/magicl-v0.11.0.tgz"; + sha256 = "10scw5qhrgjhfrlia5iqn2yy2zj1d57m45g479vg56lw849whscw"; + system = "magicl-tests"; + asd = "magicl-tests"; + } + ); + systems = [ "magicl-tests" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "fiasco" self) + (getAttr "magicl" self) + (getAttr "magicl-examples" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + magicl-transcendental = ( + build-asdf-system { + pname = "magicl-transcendental"; + version = "v0.11.0"; + asds = [ "magicl-transcendental" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/magicl/2024-10-12/magicl-v0.11.0.tgz"; + sha256 = "10scw5qhrgjhfrlia5iqn2yy2zj1d57m45g479vg56lw849whscw"; + system = "magicl-transcendental"; + asd = "magicl-transcendental"; + } + ); + systems = [ "magicl-transcendental" ]; + lispLibs = [ + (getAttr "abstract-classes" self) + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + (getAttr "interface" self) + (getAttr "policy-cond" self) + (getAttr "static-vectors" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden = ( + build-asdf-system { + pname = "maiden"; + version = "20241012-git"; + asds = [ "maiden" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden"; + asd = "maiden"; + } + ); + systems = [ "maiden" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "deeds" self) + (getAttr "documentation-utils" self) + (getAttr "form-fiddle" self) + (getAttr "lambda-fiddle" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-indent" self) + (getAttr "uuid" self) + (getAttr "verbose" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-accounts = ( + build-asdf-system { + pname = "maiden-accounts"; + version = "20241012-git"; + asds = [ "maiden-accounts" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-accounts"; + asd = "maiden-accounts"; + } + ); + systems = [ "maiden-accounts" ]; + lispLibs = [ + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-activatable = ( + build-asdf-system { + pname = "maiden-activatable"; + version = "20241012-git"; + asds = [ "maiden-activatable" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-activatable"; + asd = "maiden-activatable"; + } + ); + systems = [ "maiden-activatable" ]; + lispLibs = [ + (getAttr "maiden" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-api-access = ( + build-asdf-system { + pname = "maiden-api-access"; + version = "20241012-git"; + asds = [ "maiden-api-access" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-api-access"; + asd = "maiden-api-access"; + } + ); + systems = [ "maiden-api-access" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "jsown" self) + (getAttr "maiden" self) + (getAttr "plump" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-blocker = ( + build-asdf-system { + pname = "maiden-blocker"; + version = "20241012-git"; + asds = [ "maiden-blocker" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-blocker"; + asd = "maiden-blocker"; + } + ); + systems = [ "maiden-blocker" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-channel-relay = ( + build-asdf-system { + pname = "maiden-channel-relay"; + version = "20241012-git"; + asds = [ "maiden-channel-relay" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-channel-relay"; + asd = "maiden-channel-relay"; + } + ); + systems = [ "maiden-channel-relay" ]; + lispLibs = [ + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-chatlog = ( + build-asdf-system { + pname = "maiden-chatlog"; + version = "20241012-git"; + asds = [ "maiden-chatlog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-chatlog"; + asd = "maiden-chatlog"; + } + ); + systems = [ "maiden-chatlog" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + (getAttr "postmodern" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-client-entities = ( + build-asdf-system { + pname = "maiden-client-entities"; + version = "20241012-git"; + asds = [ "maiden-client-entities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-client-entities"; + asd = "maiden-client-entities"; + } + ); + systems = [ "maiden-client-entities" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "maiden" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-commands = ( + build-asdf-system { + pname = "maiden-commands"; + version = "20241012-git"; + asds = [ "maiden-commands" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-commands"; + asd = "maiden-commands"; + } + ); + systems = [ "maiden-commands" ]; + lispLibs = [ + (getAttr "lambda-fiddle" self) + (getAttr "maiden" self) + (getAttr "maiden-client-entities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-core-manager = ( + build-asdf-system { + pname = "maiden-core-manager"; + version = "20241012-git"; + asds = [ "maiden-core-manager" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-core-manager"; + asd = "maiden-core-manager"; + } + ); + systems = [ "maiden-core-manager" ]; + lispLibs = [ + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-counter = ( + build-asdf-system { + pname = "maiden-counter"; + version = "20241012-git"; + asds = [ "maiden-counter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-counter"; + asd = "maiden-counter"; + } + ); + systems = [ "maiden-counter" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "maiden-activatable" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-crimes = ( + build-asdf-system { + pname = "maiden-crimes"; + version = "20241012-git"; + asds = [ "maiden-crimes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-crimes"; + asd = "maiden-crimes"; + } + ); + systems = [ "maiden-crimes" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "maiden-api-access" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-dictionary = ( + build-asdf-system { + pname = "maiden-dictionary"; + version = "20241012-git"; + asds = [ "maiden-dictionary" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-dictionary"; + asd = "maiden-dictionary"; + } + ); + systems = [ "maiden-dictionary" ]; + lispLibs = [ + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + (getAttr "oxenfurt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-emoticon = ( + build-asdf-system { + pname = "maiden-emoticon"; + version = "20241012-git"; + asds = [ "maiden-emoticon" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-emoticon"; + asd = "maiden-emoticon"; + } + ); + systems = [ "maiden-emoticon" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "maiden-activatable" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-help = ( + build-asdf-system { + pname = "maiden-help"; + version = "20241012-git"; + asds = [ "maiden-help" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-help"; + asd = "maiden-help"; + } + ); + systems = [ "maiden-help" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-irc = ( + build-asdf-system { + pname = "maiden-irc"; + version = "20241012-git"; + asds = [ "maiden-irc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-irc"; + asd = "maiden-irc"; + } + ); + systems = [ "maiden-irc" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-base64" self) + (getAttr "cl-ppcre" self) + (getAttr "form-fiddle" self) + (getAttr "lambda-fiddle" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-networking" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-lastfm = ( + build-asdf-system { + pname = "maiden-lastfm"; + version = "20241012-git"; + asds = [ "maiden-lastfm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-lastfm"; + asd = "maiden-lastfm"; + } + ); + systems = [ "maiden-lastfm" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "maiden-api-access" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-lichat = ( + build-asdf-system { + pname = "maiden-lichat"; + version = "20241012-git"; + asds = [ "maiden-lichat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-lichat"; + asd = "maiden-lichat"; + } + ); + systems = [ "maiden-lichat" ]; + lispLibs = [ + (getAttr "lichat-protocol" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-networking" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-location = ( + build-asdf-system { + pname = "maiden-location"; + version = "20241012-git"; + asds = [ "maiden-location" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-location"; + asd = "maiden-location"; + } + ); + systems = [ "maiden-location" ]; + lispLibs = [ + (getAttr "maiden-api-access" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-lookup = ( + build-asdf-system { + pname = "maiden-lookup"; + version = "20241012-git"; + asds = [ "maiden-lookup" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-lookup"; + asd = "maiden-lookup"; + } + ); + systems = [ "maiden-lookup" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "lquery" self) + (getAttr "maiden-api-access" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-markov = ( + build-asdf-system { + pname = "maiden-markov"; + version = "20241012-git"; + asds = [ "maiden-markov" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-markov"; + asd = "maiden-markov"; + } + ); + systems = [ "maiden-markov" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + (getAttr "fast-io" self) + (getAttr "maiden-activatable" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + (getAttr "parse-number" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-medals = ( + build-asdf-system { + pname = "maiden-medals"; + version = "20241012-git"; + asds = [ "maiden-medals" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-medals"; + asd = "maiden-medals"; + } + ); + systems = [ "maiden-medals" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "maiden-accounts" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-networking = ( + build-asdf-system { + pname = "maiden-networking"; + version = "20241012-git"; + asds = [ "maiden-networking" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-networking"; + asd = "maiden-networking"; + } + ); + systems = [ "maiden-networking" ]; + lispLibs = [ + (getAttr "cl_plus_ssl" self) + (getAttr "maiden" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-notify = ( + build-asdf-system { + pname = "maiden-notify"; + version = "20241012-git"; + asds = [ "maiden-notify" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-notify"; + asd = "maiden-notify"; + } + ); + systems = [ "maiden-notify" ]; + lispLibs = [ + (getAttr "maiden-accounts" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-permissions = ( + build-asdf-system { + pname = "maiden-permissions"; + version = "20241012-git"; + asds = [ "maiden-permissions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-permissions"; + asd = "maiden-permissions"; + } + ); + systems = [ "maiden-permissions" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "documentation-utils" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-relay = ( + build-asdf-system { + pname = "maiden-relay"; + version = "20241012-git"; + asds = [ "maiden-relay" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-relay"; + asd = "maiden-relay"; + } + ); + systems = [ "maiden-relay" ]; + lispLibs = [ + (getAttr "maiden-networking" self) + (getAttr "maiden-serialize" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-serialize = ( + build-asdf-system { + pname = "maiden-serialize"; + version = "20241012-git"; + asds = [ "maiden-serialize" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-serialize"; + asd = "maiden-serialize"; + } + ); + systems = [ "maiden-serialize" ]; + lispLibs = [ + (getAttr "cl-store" self) + (getAttr "gzip-stream" self) + (getAttr "maiden" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-silly = ( + build-asdf-system { + pname = "maiden-silly"; + version = "20241012-git"; + asds = [ "maiden-silly" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-silly"; + asd = "maiden-silly"; + } + ); + systems = [ "maiden-silly" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "lquery" self) + (getAttr "maiden-activatable" self) + (getAttr "maiden-api-access" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-storage = ( + build-asdf-system { + pname = "maiden-storage"; + version = "20241012-git"; + asds = [ "maiden-storage" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-storage"; + asd = "maiden-storage"; + } + ); + systems = [ "maiden-storage" ]; + lispLibs = [ + (getAttr "maiden" self) + (getAttr "pathname-utils" self) + (getAttr "ubiquitous-concurrent" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-talk = ( + build-asdf-system { + pname = "maiden-talk"; + version = "20241012-git"; + asds = [ "maiden-talk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-talk"; + asd = "maiden-talk"; + } + ); + systems = [ "maiden-talk" ]; + lispLibs = [ + (getAttr "array-utils" self) + (getAttr "cl-mixed-mpg123" self) + (getAttr "drakma" self) + (getAttr "harmony" self) + (getAttr "maiden-commands" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-throttle = ( + build-asdf-system { + pname = "maiden-throttle"; + version = "20241012-git"; + asds = [ "maiden-throttle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-throttle"; + asd = "maiden-throttle"; + } + ); + systems = [ "maiden-throttle" ]; + lispLibs = [ + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-time = ( + build-asdf-system { + pname = "maiden-time"; + version = "20241012-git"; + asds = [ "maiden-time" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-time"; + asd = "maiden-time"; + } + ); + systems = [ "maiden-time" ]; + lispLibs = [ + (getAttr "maiden-api-access" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-location" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-trivia = ( + build-asdf-system { + pname = "maiden-trivia"; + version = "20241012-git"; + asds = [ "maiden-trivia" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-trivia"; + asd = "maiden-trivia"; + } + ); + systems = [ "maiden-trivia" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-twitter = ( + build-asdf-system { + pname = "maiden-twitter"; + version = "20241012-git"; + asds = [ "maiden-twitter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-twitter"; + asd = "maiden-twitter"; + } + ); + systems = [ "maiden-twitter" ]; + lispLibs = [ + (getAttr "chirp" self) + (getAttr "maiden-client-entities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-urlinfo = ( + build-asdf-system { + pname = "maiden-urlinfo"; + version = "20241012-git"; + asds = [ "maiden-urlinfo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-urlinfo"; + asd = "maiden-urlinfo"; + } + ); + systems = [ "maiden-urlinfo" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "maiden-activatable" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "plump" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-vote = ( + build-asdf-system { + pname = "maiden-vote"; + version = "20241012-git"; + asds = [ "maiden-vote" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-vote"; + asd = "maiden-vote"; + } + ); + systems = [ "maiden-vote" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maiden-weather = ( + build-asdf-system { + pname = "maiden-weather"; + version = "20241012-git"; + asds = [ "maiden-weather" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maiden/2024-10-12/maiden-20241012-git.tgz"; + sha256 = "09r11y5j6l72qmalgwvrnbvgx7gxfnlrwjb5sy83krk4cw7hx6fd"; + system = "maiden-weather"; + asd = "maiden-weather"; + } + ); + systems = [ "maiden-weather" ]; + lispLibs = [ + (getAttr "local-time" self) + (getAttr "maiden-api-access" self) + (getAttr "maiden-client-entities" self) + (getAttr "maiden-commands" self) + (getAttr "maiden-location" self) + (getAttr "maiden-storage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maidenhead = ( + build-asdf-system { + pname = "maidenhead"; + version = "20241012-git"; + asds = [ "maidenhead" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maidenhead/2024-10-12/maidenhead-20241012-git.tgz"; + sha256 = "10pcx2ngyj6lkfbg1b58lzcm02xl1a3smnad5lvvw30pbalwcq46"; + system = "maidenhead"; + asd = "maidenhead"; + } + ); + systems = [ "maidenhead" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mailbox = ( + build-asdf-system { + pname = "mailbox"; + version = "20131003-git"; + asds = [ "mailbox" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mailbox/2013-10-03/mailbox-20131003-git.tgz"; + sha256 = "1qgkcss8m2q29kr9d040dnjmzl17vb7zzvlz5ry3z3zgbdwgj1sy"; + system = "mailbox"; + asd = "mailbox"; + } + ); + systems = [ "mailbox" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mailgun = ( + build-asdf-system { + pname = "mailgun"; + version = "20220707-git"; + asds = [ "mailgun" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mailgun/2022-07-07/mailgun-20220707-git.tgz"; + sha256 = "1wadkm5r2hmyz40m4kwg5rv4g4dwn3h2d8l2mn9dncg5qy37x2vl"; + system = "mailgun"; + asd = "mailgun"; + } + ); + systems = [ "mailgun" ]; + lispLibs = [ + (getAttr "dexador" self) + (getAttr "log4cl" self) + (getAttr "secret-values" self) + (getAttr "spinneret" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + make-hash = ( + build-asdf-system { + pname = "make-hash"; + version = "20130615-git"; + asds = [ "make-hash" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/make-hash/2013-06-15/make-hash-20130615-git.tgz"; + sha256 = "1qa4mcmb3pv44py0j129dd8hjx09c2akpnds53b69151mgwv5qz8"; + system = "make-hash"; + asd = "make-hash"; + } + ); + systems = [ "make-hash" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + make-hash-tests = ( + build-asdf-system { + pname = "make-hash-tests"; + version = "20130615-git"; + asds = [ "make-hash-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/make-hash/2013-06-15/make-hash-20130615-git.tgz"; + sha256 = "1qa4mcmb3pv44py0j129dd8hjx09c2akpnds53b69151mgwv5qz8"; + system = "make-hash-tests"; + asd = "make-hash-tests"; + } + ); + systems = [ "make-hash-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "make-hash" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + manifest = ( + build-asdf-system { + pname = "manifest"; + version = "20120208-git"; + asds = [ "manifest" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/manifest/2012-02-08/manifest-20120208-git.tgz"; + sha256 = "0dswslnskskdbsln6vi7w8cbypw001d81xaxkfn4g7m15m9pzkgf"; + system = "manifest"; + asd = "manifest"; + } + ); + systems = [ "manifest" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "monkeylib-html" self) + (getAttr "puri" self) + (getAttr "split-sequence" self) + (getAttr "toot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + manifolds = ( + build-asdf-system { + pname = "manifolds"; + version = "20241012-git"; + asds = [ "manifolds" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/manifolds/2024-10-12/manifolds-20241012-git.tgz"; + sha256 = "1q9hy2k1xabf8whnyxjiaqypbnbq84q94z1gmqgicxyzn7h3ybw4"; + system = "manifolds"; + asd = "manifolds"; + } + ); + systems = [ "manifolds" ]; + lispLibs = [ + (getAttr "_3d-math" self) + (getAttr "_3d-spaces" self) + (getAttr "documentation-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + manifolds-test = ( + build-asdf-system { + pname = "manifolds-test"; + version = "20241012-git"; + asds = [ "manifolds-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/manifolds/2024-10-12/manifolds-20241012-git.tgz"; + sha256 = "1q9hy2k1xabf8whnyxjiaqypbnbq84q94z1gmqgicxyzn7h3ybw4"; + system = "manifolds-test"; + asd = "manifolds-test"; + } + ); + systems = [ "manifolds-test" ]; + lispLibs = [ + (getAttr "cl-wavefront" self) + (getAttr "manifolds" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + map-bind = ( + build-asdf-system { + pname = "map-bind"; + version = "20120811-git"; + asds = [ "map-bind" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/map-bind/2012-08-11/map-bind-20120811-git.tgz"; + sha256 = "06z02c0ypfrd789glbidnhf95839hardd7nr3i95l1adm8pas30f"; + system = "map-bind"; + asd = "map-bind"; + } + ); + systems = [ "map-bind" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + map-set = ( + build-asdf-system { + pname = "map-set"; + version = "20230618-git"; + asds = [ "map-set" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/map-set/2023-06-18/map-set-20230618-git.tgz"; + sha256 = "1jlvgyvw9v49x65xvcc6vyy5nfgih43yysqj5v2555rm75p5ipgg"; + system = "map-set"; + asd = "map-set"; + } + ); + systems = [ "map-set" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + marching-cubes = ( + build-asdf-system { + pname = "marching-cubes"; + version = "20150709-git"; + asds = [ "marching-cubes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/marching-cubes/2015-07-09/marching-cubes-20150709-git.tgz"; + sha256 = "013wyr4g82b2gk0j5jbkkshg9lal2m34px37blyclf6kr5sk6azh"; + system = "marching-cubes"; + asd = "marching-cubes"; + } + ); + systems = [ "marching-cubes" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + marching-cubes-example = ( + build-asdf-system { + pname = "marching-cubes-example"; + version = "20150709-git"; + asds = [ "marching-cubes-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/marching-cubes/2015-07-09/marching-cubes-20150709-git.tgz"; + sha256 = "013wyr4g82b2gk0j5jbkkshg9lal2m34px37blyclf6kr5sk6azh"; + system = "marching-cubes-example"; + asd = "marching-cubes-example"; + } + ); + systems = [ "marching-cubes-example" ]; + lispLibs = [ (getAttr "marching-cubes" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + marching-cubes-test = ( + build-asdf-system { + pname = "marching-cubes-test"; + version = "20150709-git"; + asds = [ "marching-cubes-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/marching-cubes/2015-07-09/marching-cubes-20150709-git.tgz"; + sha256 = "013wyr4g82b2gk0j5jbkkshg9lal2m34px37blyclf6kr5sk6azh"; + system = "marching-cubes-test"; + asd = "marching-cubes-test"; + } + ); + systems = [ "marching-cubes-test" ]; + lispLibs = [ + (getAttr "cl-test-more" self) + (getAttr "marching-cubes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + markdown_dot_cl = ( + build-asdf-system { + pname = "markdown.cl"; + version = "20210228-git"; + asds = [ "markdown.cl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/markdown.cl/2021-02-28/markdown.cl-20210228-git.tgz"; + sha256 = "00yxg67skx3navq7fdsjy0wds16n9n12bhdzv08f43bgbwali7v8"; + system = "markdown.cl"; + asd = "markdown.cl"; + } + ); + systems = [ "markdown.cl" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "split-sequence" self) + (getAttr "xmls" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + markdown_dot_cl-test = ( + build-asdf-system { + pname = "markdown.cl-test"; + version = "20210228-git"; + asds = [ "markdown.cl-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/markdown.cl/2021-02-28/markdown.cl-20210228-git.tgz"; + sha256 = "00yxg67skx3navq7fdsjy0wds16n9n12bhdzv08f43bgbwali7v8"; + system = "markdown.cl-test"; + asd = "markdown.cl-test"; + } + ); + systems = [ "markdown.cl-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "markdown_dot_cl" self) + (getAttr "xmls" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + markup = ( + build-asdf-system { + pname = "markup"; + version = "20230618-git"; + asds = [ "markup" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/markup/2023-06-18/markup-20230618-git.tgz"; + sha256 = "1paj76r1bfq4pr6m6j1mgik8b97sl2zgzy7rvvwwfrs2j1mf8byd"; + system = "markup"; + asd = "markup"; + } + ); + systems = [ "markup" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "named-readtables" self) + (getAttr "str" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + markup_dot_test = ( + build-asdf-system { + pname = "markup.test"; + version = "20230618-git"; + asds = [ "markup.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/markup/2023-06-18/markup-20230618-git.tgz"; + sha256 = "1paj76r1bfq4pr6m6j1mgik8b97sl2zgzy7rvvwwfrs2j1mf8byd"; + system = "markup.test"; + asd = "markup.test"; + } + ); + systems = [ "markup.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "markup" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + marshal = ( + build-asdf-system { + pname = "marshal"; + version = "20241012-git"; + asds = [ "marshal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-marshal/2024-10-12/cl-marshal-20241012-git.tgz"; + sha256 = "081j2gfjdg05xzcq0jzqxjb874wkjdbxk9vah7hmlw9d767mzs5b"; + system = "marshal"; + asd = "marshal"; + } + ); + systems = [ "marshal" ]; + lispLibs = [ ]; + meta = { }; + } + ); + marshal-tests = ( + build-asdf-system { + pname = "marshal-tests"; + version = "20241012-git"; + asds = [ "marshal-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-marshal/2024-10-12/cl-marshal-20241012-git.tgz"; + sha256 = "081j2gfjdg05xzcq0jzqxjb874wkjdbxk9vah7hmlw9d767mzs5b"; + system = "marshal-tests"; + asd = "marshal-tests"; + } + ); + systems = [ "marshal-tests" ]; + lispLibs = [ + (getAttr "marshal" self) + (getAttr "xlunit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + math = ( + build-asdf-system { + pname = "math"; + version = "20241012-git"; + asds = [ "math" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/math/2024-10-12/math-20241012-git.tgz"; + sha256 = "104rga7fqq3xvdxryhmgdq8zygd00zk5xb05glwqw01ygl3bc0r3"; + system = "math"; + asd = "math"; + } + ); + systems = [ "math" ]; + lispLibs = [ + (getAttr "cl-utilities" self) + (getAttr "closer-mop" self) + (getAttr "font-discovery" self) + (getAttr "gsll" self) + (getAttr "vgplot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mathkit = ( + build-asdf-system { + pname = "mathkit"; + version = "20160208-git"; + asds = [ "mathkit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mathkit/2016-02-08/mathkit-20160208-git.tgz"; + sha256 = "174y6ndmf52h8sml87qjfl48llmynvdizzk2h0mr85zbaysx73i3"; + system = "mathkit"; + asd = "mathkit"; + } + ); + systems = [ "mathkit" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + matrix-case = ( + build-asdf-system { + pname = "matrix-case"; + version = "20211020-git"; + asds = [ "matrix-case" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/matrix-case/2021-10-20/matrix-case-20211020-git.tgz"; + sha256 = "17k7x7wcl78xw4ajd38gva2dw7snsm9jppbnnl4by2s0grsqg50a"; + system = "matrix-case"; + asd = "matrix-case"; + } + ); + systems = [ "matrix-case" ]; + lispLibs = [ (getAttr "jingoh_dot_documentizer" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + matrix-case_dot_test = ( + build-asdf-system { + pname = "matrix-case.test"; + version = "20211020-git"; + asds = [ "matrix-case.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/matrix-case/2021-10-20/matrix-case-20211020-git.tgz"; + sha256 = "17k7x7wcl78xw4ajd38gva2dw7snsm9jppbnnl4by2s0grsqg50a"; + system = "matrix-case.test"; + asd = "matrix-case.test"; + } + ); + systems = [ "matrix-case.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "matrix-case" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maxpc = ( + build-asdf-system { + pname = "maxpc"; + version = "20200427-git"; + asds = [ "maxpc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maxpc/2020-04-27/maxpc-20200427-git.tgz"; + sha256 = "15wrjbr2js6j67c1dd4p2qxj49q9iqv1lhb7cwdcwpn79crr39gf"; + system = "maxpc"; + asd = "maxpc"; + } + ); + systems = [ "maxpc" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maxpc-apache = ( + build-asdf-system { + pname = "maxpc-apache"; + version = "20241012-git"; + asds = [ "maxpc-apache" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "maxpc-apache"; + asd = "maxpc-apache"; + } + ); + systems = [ "maxpc-apache" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maxpc-apache-test = ( + build-asdf-system { + pname = "maxpc-apache-test"; + version = "20241012-git"; + asds = [ "maxpc-apache-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "maxpc-apache-test"; + asd = "maxpc-apache-test"; + } + ); + systems = [ "maxpc-apache-test" ]; + lispLibs = [ (getAttr "maxpc-apache" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + maxpc-test = ( + build-asdf-system { + pname = "maxpc-test"; + version = "20200427-git"; + asds = [ "maxpc-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/maxpc/2020-04-27/maxpc-20200427-git.tgz"; + sha256 = "15wrjbr2js6j67c1dd4p2qxj49q9iqv1lhb7cwdcwpn79crr39gf"; + system = "maxpc-test"; + asd = "maxpc-test"; + } + ); + systems = [ "maxpc-test" ]; + lispLibs = [ (getAttr "maxpc" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mbe = ( + build-asdf-system { + pname = "mbe"; + version = "20200218-git"; + asds = [ "mbe" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mbe/2020-02-18/mbe-20200218-git.tgz"; + sha256 = "1wlhlddfv0jbqliqlvhxkmmj9pfym0f9qlvjjmlrkvx6fxpv0450"; + system = "mbe"; + asd = "mbe"; + } + ); + systems = [ "mbe" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcase = ( + build-asdf-system { + pname = "mcase"; + version = "20211020-git"; + asds = [ "mcase" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcase/2021-10-20/mcase-20211020-git.tgz"; + sha256 = "1k0agm57xbzlskdi8cgsg2z9lsamm4jl6fw7687z3bw1s2dbsm59"; + system = "mcase"; + asd = "mcase"; + } + ); + systems = [ "mcase" ]; + lispLibs = [ + (getAttr "jingoh_dot_documentizer" self) + (getAttr "millet" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcase_dot_test = ( + build-asdf-system { + pname = "mcase.test"; + version = "20211020-git"; + asds = [ "mcase.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcase/2021-10-20/mcase-20211020-git.tgz"; + sha256 = "1k0agm57xbzlskdi8cgsg2z9lsamm4jl6fw7687z3bw1s2dbsm59"; + system = "mcase.test"; + asd = "mcase.test"; + } + ); + systems = [ "mcase.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "mcase" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim = ( + build-asdf-system { + pname = "mcclim"; + version = "20241012-git"; + asds = [ "mcclim" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim"; + asd = "mcclim"; + } + ); + systems = [ "mcclim" ]; + lispLibs = [ + (getAttr "clim" self) + (getAttr "clim-pdf" self) + (getAttr "clim-postscript" self) + (getAttr "conditional-commands" self) + (getAttr "mcclim-bezier" self) + (getAttr "mcclim-bitmaps" self) + (getAttr "mcclim-clx" self) + (getAttr "mcclim-clx-fb" self) + (getAttr "mcclim-franz" self) + (getAttr "mcclim-null" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-bezier = ( + build-asdf-system { + pname = "mcclim-bezier"; + version = "20241012-git"; + asds = [ "mcclim-bezier" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-bezier"; + asd = "mcclim-bezier"; + } + ); + systems = [ "mcclim-bezier" ]; + lispLibs = [ + (getAttr "clim" self) + (getAttr "clim-pdf" self) + (getAttr "clim-postscript" self) + (getAttr "flexichain" self) + (getAttr "mcclim-clx" self) + (getAttr "mcclim-null" self) + (getAttr "mcclim-render" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-bitmaps = ( + build-asdf-system { + pname = "mcclim-bitmaps"; + version = "20241012-git"; + asds = [ "mcclim-bitmaps" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-bitmaps"; + asd = "mcclim-bitmaps"; + } + ); + systems = [ "mcclim-bitmaps" ]; + lispLibs = [ + (getAttr "clim" self) + (getAttr "opticl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-clx = ( + build-asdf-system { + pname = "mcclim-clx"; + version = "20241012-git"; + asds = [ "mcclim-clx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-clx"; + asd = "mcclim-clx"; + } + ); + systems = [ "mcclim-clx" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-aa" self) + (getAttr "cl-dejavu" self) + (getAttr "cl-paths-ttf" self) + (getAttr "cl-unicode" self) + (getAttr "cl-vectors" self) + (getAttr "clim" self) + (getAttr "clx" self) + (getAttr "flexi-streams" self) + (getAttr "trivial-garbage" self) + (getAttr "zpb-ttf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-clx-fb = ( + build-asdf-system { + pname = "mcclim-clx-fb"; + version = "20241012-git"; + asds = [ "mcclim-clx-fb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-clx-fb"; + asd = "mcclim-clx-fb"; + } + ); + systems = [ "mcclim-clx-fb" ]; + lispLibs = [ + (getAttr "mcclim-clx" self) + (getAttr "mcclim-render" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-dot = ( + build-asdf-system { + pname = "mcclim-dot"; + version = "20241012-git"; + asds = [ "mcclim-dot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-dot"; + asd = "mcclim-dot"; + } + ); + systems = [ "mcclim-dot" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-dot" self) + (getAttr "closer-mop" self) + (getAttr "mcclim" self) + (getAttr "parse-number" self) + (getAttr "shasht" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-fontconfig = ( + build-asdf-system { + pname = "mcclim-fontconfig"; + version = "20241012-git"; + asds = [ "mcclim-fontconfig" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-fontconfig"; + asd = "mcclim-fontconfig"; + } + ); + systems = [ "mcclim-fontconfig" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-fonts = ( + build-asdf-system { + pname = "mcclim-fonts"; + version = "20241012-git"; + asds = [ "mcclim-fonts" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-fonts"; + asd = "mcclim-fonts"; + } + ); + systems = [ "mcclim-fonts" ]; + lispLibs = [ (getAttr "clim" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-franz = ( + build-asdf-system { + pname = "mcclim-franz"; + version = "20241012-git"; + asds = [ "mcclim-franz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-franz"; + asd = "mcclim-franz"; + } + ); + systems = [ "mcclim-franz" ]; + lispLibs = [ (getAttr "clim" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-harfbuzz = ( + build-asdf-system { + pname = "mcclim-harfbuzz"; + version = "20241012-git"; + asds = [ "mcclim-harfbuzz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-harfbuzz"; + asd = "mcclim-harfbuzz"; + } + ); + systems = [ "mcclim-harfbuzz" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-layouts = ( + build-asdf-system { + pname = "mcclim-layouts"; + version = "20241012-git"; + asds = [ "mcclim-layouts" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-layouts"; + asd = "mcclim-layouts"; + } + ); + systems = [ "mcclim-layouts" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-null = ( + build-asdf-system { + pname = "mcclim-null"; + version = "20241012-git"; + asds = [ "mcclim-null" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-null"; + asd = "mcclim-null"; + } + ); + systems = [ "mcclim-null" ]; + lispLibs = [ (getAttr "clim" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-raster-image = ( + build-asdf-system { + pname = "mcclim-raster-image"; + version = "20241012-git"; + asds = [ "mcclim-raster-image" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-raster-image"; + asd = "mcclim-raster-image"; + } + ); + systems = [ "mcclim-raster-image" ]; + lispLibs = [ + (getAttr "clim" self) + (getAttr "mcclim-render" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-render = ( + build-asdf-system { + pname = "mcclim-render"; + version = "20241012-git"; + asds = [ "mcclim-render" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-render"; + asd = "mcclim-render"; + } + ); + systems = [ "mcclim-render" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-aa" self) + (getAttr "cl-dejavu" self) + (getAttr "cl-paths-ttf" self) + (getAttr "cl-vectors" self) + (getAttr "clim" self) + (getAttr "flexi-streams" self) + (getAttr "zpb-ttf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-svg = ( + build-asdf-system { + pname = "mcclim-svg"; + version = "20241012-git"; + asds = [ "mcclim-svg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-svg"; + asd = "mcclim-svg"; + } + ); + systems = [ "mcclim-svg" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-aa" self) + (getAttr "cl-base64" self) + (getAttr "cl-dejavu" self) + (getAttr "cl-paths-ttf" self) + (getAttr "cl-vectors" self) + (getAttr "cl-who" self) + (getAttr "clim" self) + (getAttr "flexi-streams" self) + (getAttr "mcclim" self) + (getAttr "mcclim-bitmaps" self) + (getAttr "zpb-ttf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-tooltips = ( + build-asdf-system { + pname = "mcclim-tooltips"; + version = "20241012-git"; + asds = [ "mcclim-tooltips" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-tooltips"; + asd = "mcclim-tooltips"; + } + ); + systems = [ "mcclim-tooltips" ]; + lispLibs = [ (getAttr "clim" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mcclim-tree-with-cross-edges = ( + build-asdf-system { + pname = "mcclim-tree-with-cross-edges"; + version = "20241012-git"; + asds = [ "mcclim-tree-with-cross-edges" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "mcclim-tree-with-cross-edges"; + asd = "mcclim-tree-with-cross-edges"; + } + ); + systems = [ "mcclim-tree-with-cross-edges" ]; + lispLibs = [ (getAttr "mcclim" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + md5 = ( + build-asdf-system { + pname = "md5"; + version = "20210630-git"; + asds = [ "md5" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/md5/2021-06-30/md5-20210630-git.tgz"; + sha256 = "1g20np6rhn3y08z8mlmlk721mw2207s52v2pwp4smm3lz25sx3q5"; + system = "md5"; + asd = "md5"; + } + ); + systems = [ "md5" ]; + lispLibs = [ ]; + meta = { }; + } + ); + media-types = ( + build-asdf-system { + pname = "media-types"; + version = "20220331-git"; + asds = [ "media-types" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/media-types/2022-03-31/media-types-20220331-git.tgz"; + sha256 = "07ly7jr0ff2ks4gyjpq2jyj9gm47frllal5is3iqhc4xrmpyzrqc"; + system = "media-types"; + asd = "media-types"; + } + ); + systems = [ "media-types" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mel-base = ( + build-asdf-system { + pname = "mel-base"; + version = "20180228-git"; + asds = [ "mel-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mel-base/2018-02-28/mel-base-20180228-git.tgz"; + sha256 = "1dvhmlkxasww3kb7xnwqlmdvi31w2awjrbkgk5d0hsfzqmyhhjh0"; + system = "mel-base"; + asd = "mel-base"; + } + ); + systems = [ "mel-base" ]; + lispLibs = [ + (getAttr "cl_plus_ssl" self) + (getAttr "flexi-streams" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + memoize = ( + build-asdf-system { + pname = "memoize"; + version = "20140826-http"; + asds = [ "memoize" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/memoize/2014-08-26/memoize-20140826-http.tgz"; + sha256 = "1f1plqy9xdv40235b7kkm63gsgssk8l81azhfniy8j9yww39gihf"; + system = "memoize"; + asd = "memoize"; + } + ); + systems = [ "memoize" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + memory-regions = ( + build-asdf-system { + pname = "memory-regions"; + version = "20241012-git"; + asds = [ "memory-regions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/memory-regions/2024-10-12/memory-regions-20241012-git.tgz"; + sha256 = "0j2qfbh2kwl8k6v0h0pbh5hml8aia888kaq4kgb12nfslim81iyd"; + system = "memory-regions"; + asd = "memory-regions"; + } + ); + systems = [ "memory-regions" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "closer-mop" self) + (getAttr "documentation-utils" self) + (getAttr "mmap" self) + (getAttr "static-vectors" self) + (getAttr "trivial-extensible-sequences" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + message-oo = ( + build-asdf-system { + pname = "message-oo"; + version = "20130615-git"; + asds = [ "message-oo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/message-oo/2013-06-15/message-oo-20130615-git.tgz"; + sha256 = "164yypzhr6pxb84x47s9vjl97imbq5r8sxan22101q0y1jn3dznp"; + system = "message-oo"; + asd = "message-oo"; + } + ); + systems = [ "message-oo" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + messagebox = ( + build-asdf-system { + pname = "messagebox"; + version = "20241012-git"; + asds = [ "messagebox" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/messagebox/2024-10-12/messagebox-20241012-git.tgz"; + sha256 = "0wf25rfx7vg0l1mnzjjzwjqcjaa96a95k9diijppn7y9v2knr1qq"; + system = "messagebox"; + asd = "messagebox"; + } + ); + systems = [ "messagebox" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + meta = ( + build-asdf-system { + pname = "meta"; + version = "20150608-git"; + asds = [ "meta" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/meta/2015-06-08/meta-20150608-git.tgz"; + sha256 = "08s53zj3mcx82kszp1bg2vsb4kydvkc70kj4hpq9h1l5a1wh44cy"; + system = "meta"; + asd = "meta"; + } + ); + systems = [ "meta" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + meta-sexp = ( + build-asdf-system { + pname = "meta-sexp"; + version = "20201016-git"; + asds = [ "meta-sexp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/meta-sexp/2020-10-16/meta-sexp-20201016-git.tgz"; + sha256 = "14z4xglybsj4pdaifhjvnki0vm0wg985x00n94djc0fdcclczv1c"; + system = "meta-sexp"; + asd = "meta-sexp"; + } + ); + systems = [ "meta-sexp" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + metabang-bind = ( + build-asdf-system { + pname = "metabang-bind"; + version = "20230618-git"; + asds = [ "metabang-bind" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/metabang-bind/2023-06-18/metabang-bind-20230618-git.tgz"; + sha256 = "14g7k3zhm8cd6bssc5mm5h6iq1dv5lfhiq33aimcmj5a6vbiq47d"; + system = "metabang-bind"; + asd = "metabang-bind"; + } + ); + systems = [ "metabang-bind" ]; + lispLibs = [ ]; + meta = { }; + } + ); + metabang-bind-test = ( + build-asdf-system { + pname = "metabang-bind-test"; + version = "20230618-git"; + asds = [ "metabang-bind-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/metabang-bind/2023-06-18/metabang-bind-20230618-git.tgz"; + sha256 = "14g7k3zhm8cd6bssc5mm5h6iq1dv5lfhiq33aimcmj5a6vbiq47d"; + system = "metabang-bind-test"; + asd = "metabang-bind-test"; + } + ); + systems = [ "metabang-bind-test" ]; + lispLibs = [ + (getAttr "lift" self) + (getAttr "metabang-bind" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + metacopy = ( + build-asdf-system { + pname = "metacopy"; + version = "20170403-darcs"; + asds = [ "metacopy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/metacopy/2017-04-03/metacopy-20170403-darcs.tgz"; + sha256 = "1xwvc18l5fc33ffqa6jz5g0qz6mpabia81bcmqf3sz24apkpr49x"; + system = "metacopy"; + asd = "metacopy"; + } + ); + systems = [ "metacopy" ]; + lispLibs = [ (getAttr "moptilities" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + metacopy-with-contextl = ( + build-asdf-system { + pname = "metacopy-with-contextl"; + version = "20170403-darcs"; + asds = [ "metacopy-with-contextl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/metacopy/2017-04-03/metacopy-20170403-darcs.tgz"; + sha256 = "1xwvc18l5fc33ffqa6jz5g0qz6mpabia81bcmqf3sz24apkpr49x"; + system = "metacopy-with-contextl"; + asd = "metacopy-with-contextl"; + } + ); + systems = [ "metacopy-with-contextl" ]; + lispLibs = [ + (getAttr "contextl" self) + (getAttr "metacopy" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + metalock = ( + build-asdf-system { + pname = "metalock"; + version = "20200925-git"; + asds = [ "metalock" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/metalock/2020-09-25/metalock-20200925-git.tgz"; + sha256 = "0z2vk0s694zhnkai593q42vln5a6ykm8pilyikc4qp9aw9r43lc5"; + system = "metalock"; + asd = "metalock"; + } + ); + systems = [ "metalock" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + metap = ( + build-asdf-system { + pname = "metap"; + version = "20150505-git"; + asds = [ "metap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/metap/2015-05-05/metap-20150505-git.tgz"; + sha256 = "0drqyjscl0lmhgplld6annmlqma83q76xkxnahcq4ksnhpbsz9wx"; + system = "metap"; + asd = "metap"; + } + ); + systems = [ "metap" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + metap-test = ( + build-asdf-system { + pname = "metap-test"; + version = "20150505-git"; + asds = [ "metap-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/metap/2015-05-05/metap-20150505-git.tgz"; + sha256 = "0drqyjscl0lmhgplld6annmlqma83q76xkxnahcq4ksnhpbsz9wx"; + system = "metap-test"; + asd = "metap-test"; + } + ); + systems = [ "metap-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "metap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + metatilities = ( + build-asdf-system { + pname = "metatilities"; + version = "20180228-git"; + asds = [ "metatilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/metatilities/2018-02-28/metatilities-20180228-git.tgz"; + sha256 = "0vqhndnhrv40ixkj5lslr0h2fy79609gi0wgbqzcz82vkyx9d6vd"; + system = "metatilities"; + asd = "metatilities"; + } + ); + systems = [ "metatilities" ]; + lispLibs = [ + (getAttr "asdf-system-connections" self) + (getAttr "cl-containers" self) + (getAttr "metabang-bind" self) + (getAttr "metatilities-base" self) + (getAttr "moptilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + metatilities-base = ( + build-asdf-system { + pname = "metatilities-base"; + version = "20191227-git"; + asds = [ "metatilities-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/metatilities-base/2019-12-27/metatilities-base-20191227-git.tgz"; + sha256 = "069rk5ncwvjnnzvvky6xiriynl72yzvjpnzl6jw9jf3b8na14zrk"; + system = "metatilities-base"; + asd = "metatilities-base"; + } + ); + systems = [ "metatilities-base" ]; + lispLibs = [ ]; + meta = { }; + } + ); + metatilities-base-test = ( + build-asdf-system { + pname = "metatilities-base-test"; + version = "20191227-git"; + asds = [ "metatilities-base-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/metatilities-base/2019-12-27/metatilities-base-20191227-git.tgz"; + sha256 = "069rk5ncwvjnnzvvky6xiriynl72yzvjpnzl6jw9jf3b8na14zrk"; + system = "metatilities-base-test"; + asd = "metatilities-base-test"; + } + ); + systems = [ "metatilities-base-test" ]; + lispLibs = [ + (getAttr "lift" self) + (getAttr "metatilities-base" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + metatilities-test = ( + build-asdf-system { + pname = "metatilities-test"; + version = "20180228-git"; + asds = [ "metatilities-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/metatilities/2018-02-28/metatilities-20180228-git.tgz"; + sha256 = "0vqhndnhrv40ixkj5lslr0h2fy79609gi0wgbqzcz82vkyx9d6vd"; + system = "metatilities-test"; + asd = "metatilities-test"; + } + ); + systems = [ "metatilities-test" ]; + lispLibs = [ + (getAttr "lift" self) + (getAttr "metatilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + metering = ( + build-asdf-system { + pname = "metering"; + version = "20200218-git"; + asds = [ "metering" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/metering/2020-02-18/metering-20200218-git.tgz"; + sha256 = "0jx3ypk8m815yp7208xkcxkvila847mvna25a2p22ihnj0ms9rn1"; + system = "metering"; + asd = "metering"; + } + ); + systems = [ "metering" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + method-combination-utilities = ( + build-asdf-system { + pname = "method-combination-utilities"; + version = "20241012-git"; + asds = [ "method-combination-utilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/method-combination-utilities/2024-10-12/method-combination-utilities-20241012-git.tgz"; + sha256 = "15wjzf6r9kkfw89rgzhrr60p5b4i15b90nr3wz6idkv3n4j7fsjl"; + system = "method-combination-utilities"; + asd = "method-combination-utilities"; + } + ); + systems = [ "method-combination-utilities" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + method-combination-utilities_dot_tests = ( + build-asdf-system { + pname = "method-combination-utilities.tests"; + version = "20241012-git"; + asds = [ "method-combination-utilities.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/method-combination-utilities/2024-10-12/method-combination-utilities-20241012-git.tgz"; + sha256 = "15wjzf6r9kkfw89rgzhrr60p5b4i15b90nr3wz6idkv3n4j7fsjl"; + system = "method-combination-utilities.tests"; + asd = "method-combination-utilities"; + } + ); + systems = [ "method-combination-utilities.tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "method-combination-utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + method-hooks = ( + build-asdf-system { + pname = "method-hooks"; + version = "20200925-git"; + asds = [ "method-hooks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/method-hooks/2020-09-25/method-hooks-20200925-git.tgz"; + sha256 = "0kzijk02wjzms3hihmn6n6p9r6awkrsqlkghf6ixzf6400fiy212"; + system = "method-hooks"; + asd = "method-hooks"; + } + ); + systems = [ "method-hooks" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + method-hooks-test = ( + build-asdf-system { + pname = "method-hooks-test"; + version = "20200925-git"; + asds = [ "method-hooks-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/method-hooks/2020-09-25/method-hooks-20200925-git.tgz"; + sha256 = "0kzijk02wjzms3hihmn6n6p9r6awkrsqlkghf6ixzf6400fiy212"; + system = "method-hooks-test"; + asd = "method-hooks-test"; + } + ); + systems = [ "method-hooks-test" ]; + lispLibs = [ + (getAttr "method-hooks" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + method-versions = ( + build-asdf-system { + pname = "method-versions"; + version = "0.1.2011.05.18"; + asds = [ "method-versions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/method-versions/2011-05-22/method-versions_0.1.2011.05.18.tgz"; + sha256 = "119x3dbjry25issq2m8xcacknd1y9mcnla5rhqzcsrj58zsmwmwf"; + system = "method-versions"; + asd = "method-versions"; + } + ); + systems = [ "method-versions" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mexpr = ( + build-asdf-system { + pname = "mexpr"; + version = "20150709-git"; + asds = [ "mexpr" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mexpr/2015-07-09/mexpr-20150709-git.tgz"; + sha256 = "0ri9cp7vhnn9sah1lhvxn523c342n0q4v0xzi6fzlfvpj84jfzqk"; + system = "mexpr"; + asd = "mexpr"; + } + ); + systems = [ "mexpr" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-syntax" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mexpr-tests = ( + build-asdf-system { + pname = "mexpr-tests"; + version = "20150709-git"; + asds = [ "mexpr-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mexpr/2015-07-09/mexpr-20150709-git.tgz"; + sha256 = "0ri9cp7vhnn9sah1lhvxn523c342n0q4v0xzi6fzlfvpj84jfzqk"; + system = "mexpr-tests"; + asd = "mexpr-tests"; + } + ); + systems = [ "mexpr-tests" ]; + lispLibs = [ + (getAttr "mexpr" self) + (getAttr "named-readtables" self) + (getAttr "should-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mfiano-utils = ( + build-asdf-system { + pname = "mfiano-utils"; + version = "20230214-git"; + asds = [ "mfiano-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mfiano-utils/2023-02-14/mfiano-utils-20230214-git.tgz"; + sha256 = "06nrrwwlrwi4w87y6888759b5vpa5264lli5m4crl9r9lr9bnay9"; + system = "mfiano-utils"; + asd = "mfiano-utils"; + } + ); + systems = [ "mfiano-utils" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mgl = ( + build-asdf-system { + pname = "mgl"; + version = "20230618-git"; + asds = [ "mgl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mgl/2023-06-18/mgl-20230618-git.tgz"; + sha256 = "1jr2jill9b1rq0msy0bzzl0q2w0bm3gpd0dwrmkyazzjym2rdsjx"; + system = "mgl"; + asd = "mgl"; + } + ); + systems = [ "mgl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "array-operations" self) + (getAttr "cl-reexport" self) + (getAttr "closer-mop" self) + (getAttr "lla" self) + (getAttr "mgl-gnuplot" self) + (getAttr "mgl-mat" self) + (getAttr "mgl-pax" self) + (getAttr "named-readtables" self) + (getAttr "num-utils" self) + (getAttr "pythonic-string-reader" self) + (getAttr "swank" self) + ]; + meta = { }; + } + ); + mgl-example = ( + build-asdf-system { + pname = "mgl-example"; + version = "20230618-git"; + asds = [ "mgl-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mgl/2023-06-18/mgl-20230618-git.tgz"; + sha256 = "1jr2jill9b1rq0msy0bzzl0q2w0bm3gpd0dwrmkyazzjym2rdsjx"; + system = "mgl-example"; + asd = "mgl-example"; + } + ); + systems = [ "mgl-example" ]; + lispLibs = [ (getAttr "mgl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mgl-gnuplot = ( + build-asdf-system { + pname = "mgl-gnuplot"; + version = "20230618-git"; + asds = [ "mgl-gnuplot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mgl/2023-06-18/mgl-20230618-git.tgz"; + sha256 = "1jr2jill9b1rq0msy0bzzl0q2w0bm3gpd0dwrmkyazzjym2rdsjx"; + system = "mgl-gnuplot"; + asd = "mgl-gnuplot"; + } + ); + systems = [ "mgl-gnuplot" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "external-program" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mgl-mat = ( + build-asdf-system { + pname = "mgl-mat"; + version = "20231021-git"; + asds = [ "mgl-mat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mgl-mat/2023-10-21/mgl-mat-20231021-git.tgz"; + sha256 = "0pl9ksdjr57sg2w85ql6y9pgbzrxcsz6irb7i0s1q3d08f87il1i"; + system = "mgl-mat"; + asd = "mgl-mat"; + } + ); + systems = [ "mgl-mat" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-cuda" self) + (getAttr "flexi-streams" self) + (getAttr "ieee-floats" self) + (getAttr "lla" self) + (getAttr "mgl-pax" self) + (getAttr "num-utils" self) + (getAttr "static-vectors" self) + (getAttr "trivial-garbage" self) + ]; + meta = { }; + } + ); + mgl-pax = ( + build-asdf-system { + pname = "mgl-pax"; + version = "20241012-git"; + asds = [ "mgl-pax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mgl-pax/2024-10-12/mgl-pax-20241012-git.tgz"; + sha256 = "17szk2ijccssa9n7zg8qh6hc706hahvzcrzlx716hmgq2hfwvvy0"; + system = "mgl-pax"; + asd = "mgl-pax"; + } + ); + systems = [ "mgl-pax" ]; + lispLibs = [ + (getAttr "dref" self) + (getAttr "mgl-pax-bootstrap" self) + (getAttr "mgl-pax_dot_asdf" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + ]; + meta = { }; + } + ); + mgl-pax-bootstrap = ( + build-asdf-system { + pname = "mgl-pax-bootstrap"; + version = "20241012-git"; + asds = [ "mgl-pax-bootstrap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mgl-pax/2024-10-12/mgl-pax-20241012-git.tgz"; + sha256 = "17szk2ijccssa9n7zg8qh6hc706hahvzcrzlx716hmgq2hfwvvy0"; + system = "mgl-pax-bootstrap"; + asd = "mgl-pax-bootstrap"; + } + ); + systems = [ "mgl-pax-bootstrap" ]; + lispLibs = [ (getAttr "mgl-pax_dot_asdf" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mgl-pax-test = ( + build-asdf-system { + pname = "mgl-pax-test"; + version = "20241012-git"; + asds = [ "mgl-pax-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mgl-pax/2024-10-12/mgl-pax-20241012-git.tgz"; + sha256 = "17szk2ijccssa9n7zg8qh6hc706hahvzcrzlx716hmgq2hfwvvy0"; + system = "mgl-pax-test"; + asd = "mgl-pax-test"; + } + ); + systems = [ "mgl-pax-test" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "_3bmd-ext-code-blocks" self) + (getAttr "alexandria" self) + (getAttr "colorize" self) + (getAttr "dref" self) + (getAttr "dref-test" self) + (getAttr "md5" self) + (getAttr "mgl-pax" self) + (getAttr "mgl-pax_dot_asdf" self) + (getAttr "swank" self) + (getAttr "trivial-utf-8" self) + (getAttr "try" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mgl-pax_dot_asdf = ( + build-asdf-system { + pname = "mgl-pax.asdf"; + version = "20241012-git"; + asds = [ "mgl-pax.asdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mgl-pax/2024-10-12/mgl-pax-20241012-git.tgz"; + sha256 = "17szk2ijccssa9n7zg8qh6hc706hahvzcrzlx716hmgq2hfwvvy0"; + system = "mgl-pax.asdf"; + asd = "mgl-pax.asdf"; + } + ); + systems = [ "mgl-pax.asdf" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mgrs = ( + build-asdf-system { + pname = "mgrs"; + version = "20220331-git"; + asds = [ "mgrs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mgrs/2022-03-31/mgrs-20220331-git.tgz"; + sha256 = "1n4kd734qjj7mrcg0q28hml3npam1rm067iwljwc87zshnxh5gmn"; + system = "mgrs"; + asd = "mgrs"; + } + ); + systems = [ "mgrs" ]; + lispLibs = [ (getAttr "utm-ups" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + micmac = ( + build-asdf-system { + pname = "micmac"; + version = "20230618-git"; + asds = [ "micmac" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/micmac/2023-06-18/micmac-20230618-git.tgz"; + sha256 = "10zjxqc7y5spr3y5yrnfqmv881ia168scbhiq8i98rvizabgxf6x"; + system = "micmac"; + asd = "micmac"; + } + ); + systems = [ "micmac" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "mgl-pax" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + midi = ( + build-asdf-system { + pname = "midi"; + version = "20070618"; + asds = [ "midi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/midi/2010-10-06/midi-20070618.tgz"; + sha256 = "06hb6vm4dckhr1ln5jn3b31x1yampkl5fl0lfbg9zyazli7fgl87"; + system = "midi"; + asd = "midi"; + } + ); + systems = [ "midi" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + millet = ( + build-asdf-system { + pname = "millet"; + version = "20211209-git"; + asds = [ "millet" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/millet/2021-12-09/millet-20211209-git.tgz"; + sha256 = "1jdqyr1f9a6083k7n88rwc6mjmgccj6za50ybl1dlnxqvqj2pw80"; + system = "millet"; + asd = "millet"; + } + ); + systems = [ "millet" ]; + lispLibs = [ (getAttr "jingoh_dot_documentizer" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + millet_dot_test = ( + build-asdf-system { + pname = "millet.test"; + version = "20211209-git"; + asds = [ "millet.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/millet/2021-12-09/millet-20211209-git.tgz"; + sha256 = "1jdqyr1f9a6083k7n88rwc6mjmgccj6za50ybl1dlnxqvqj2pw80"; + system = "millet.test"; + asd = "millet.test"; + } + ); + systems = [ "millet.test" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "jingoh" self) + (getAttr "millet" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + minheap = ( + build-asdf-system { + pname = "minheap"; + version = "20160628-git"; + asds = [ "minheap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/minheap/2016-06-28/minheap-20160628-git.tgz"; + sha256 = "03v0dqxg4kmwvfrlrkq8bmfcv70k9n9f48p9p3z8kmfbc4p3f1vd"; + system = "minheap"; + asd = "minheap"; + } + ); + systems = [ "minheap" ]; + lispLibs = [ ]; + meta = { }; + } + ); + minheap-tests = ( + build-asdf-system { + pname = "minheap-tests"; + version = "20160628-git"; + asds = [ "minheap-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/minheap/2016-06-28/minheap-20160628-git.tgz"; + sha256 = "03v0dqxg4kmwvfrlrkq8bmfcv70k9n9f48p9p3z8kmfbc4p3f1vd"; + system = "minheap-tests"; + asd = "minheap-tests"; + } + ); + systems = [ "minheap-tests" ]; + lispLibs = [ + (getAttr "lisp-unit" self) + (getAttr "minheap" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mini-cas = ( + build-asdf-system { + pname = "mini-cas"; + version = "20150923-git"; + asds = [ "mini-cas" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mini-cas/2015-09-23/mini-cas-20150923-git.tgz"; + sha256 = "1y9a111877lkpssi651q684mj052vp6qr9pz5gl47s6swiqvqp24"; + system = "mini-cas"; + asd = "mini-cas"; + } + ); + systems = [ "mini-cas" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + minilem = ( + build-asdf-system { + pname = "minilem"; + version = "20200218-git"; + asds = [ "minilem" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/minilem/2020-02-18/minilem-20200218-git.tgz"; + sha256 = "1hpcgj8k5m11nk1pfd479hrbh15dcas7z1s8w877rqmlf69ga4cp"; + system = "minilem"; + asd = "minilem"; + } + ); + systems = [ "minilem" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "esrap" self) + (getAttr "inquisitor" self) + (getAttr "iterate" self) + (getAttr "log4cl" self) + (getAttr "optima" self) + (getAttr "swank" self) + (getAttr "trivial-gray-streams" self) + (getAttr "trivial-types" self) + (getAttr "usocket" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + minpack = ( + build-asdf-system { + pname = "minpack"; + version = "20231021-git"; + asds = [ "minpack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "minpack"; + asd = "minpack"; + } + ); + systems = [ "minpack" ]; + lispLibs = [ (getAttr "f2cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + misc-extensions = ( + build-asdf-system { + pname = "misc-extensions"; + version = "20241012-git"; + asds = [ "misc-extensions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/misc-extensions/2024-10-12/misc-extensions-20241012-git.tgz"; + sha256 = "0pvgg376vkydp2831bnnvwrv27m4ivc78c0nhvb4848c3ik1hn5j"; + system = "misc-extensions"; + asd = "misc-extensions"; + } + ); + systems = [ "misc-extensions" ]; + lispLibs = [ ]; + meta = { }; + } + ); + mito = ( + build-asdf-system { + pname = "mito"; + version = "20241012-git"; + asds = [ "mito" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mito/2024-10-12/mito-20241012-git.tgz"; + sha256 = "0nz72qss2jji0narxffpnpfgz74grvhmwqqlydpw6wv3ji1rrrq3"; + system = "mito"; + asd = "mito"; + } + ); + systems = [ "mito" ]; + lispLibs = [ + (getAttr "cl-package-locks" self) + (getAttr "lack-middleware-mito" self) + (getAttr "mito-core" self) + (getAttr "mito-migration" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mito-attachment = ( + build-asdf-system { + pname = "mito-attachment"; + version = "20230214-git"; + asds = [ "mito-attachment" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mito-attachment/2023-02-14/mito-attachment-20230214-git.tgz"; + sha256 = "0an744m6wmnbb5zrxqxcf719r7im1n7p63z632p3m5sqv8d86fm1"; + system = "mito-attachment"; + asd = "mito-attachment"; + } + ); + systems = [ "mito-attachment" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "aws-sign4" self) + (getAttr "lack-component" self) + (getAttr "mito" self) + (getAttr "quri" self) + (getAttr "trivial-mimes" self) + (getAttr "uuid" self) + (getAttr "zs3" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mito-auth = ( + build-asdf-system { + pname = "mito-auth"; + version = "20171019-git"; + asds = [ "mito-auth" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mito-auth/2017-10-19/mito-auth-20171019-git.tgz"; + sha256 = "1q1yxjpnshzmia34a68dlscjadzynzyzz14sr4mkkkjyg5dhkazi"; + system = "mito-auth"; + asd = "mito-auth"; + } + ); + systems = [ "mito-auth" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "ironclad" self) + (getAttr "mito" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mito-core = ( + build-asdf-system { + pname = "mito-core"; + version = "20241012-git"; + asds = [ "mito-core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mito/2024-10-12/mito-20241012-git.tgz"; + sha256 = "0nz72qss2jji0narxffpnpfgz74grvhmwqqlydpw6wv3ji1rrrq3"; + system = "mito-core"; + asd = "mito-core"; + } + ); + systems = [ "mito-core" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "dbi" self) + (getAttr "dissect" self) + (getAttr "local-time" self) + (getAttr "sxql" self) + (getAttr "trivia" self) + (getAttr "uuid" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mito-migration = ( + build-asdf-system { + pname = "mito-migration"; + version = "20241012-git"; + asds = [ "mito-migration" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mito/2024-10-12/mito-20241012-git.tgz"; + sha256 = "0nz72qss2jji0narxffpnpfgz74grvhmwqqlydpw6wv3ji1rrrq3"; + system = "mito-migration"; + asd = "mito-migration"; + } + ); + systems = [ "mito-migration" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "chipz" self) + (getAttr "closer-mop" self) + (getAttr "dbi" self) + (getAttr "esrap" self) + (getAttr "mito-core" self) + (getAttr "sxql" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mito-test = ( + build-asdf-system { + pname = "mito-test"; + version = "20241012-git"; + asds = [ "mito-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mito/2024-10-12/mito-20241012-git.tgz"; + sha256 = "0nz72qss2jji0narxffpnpfgz74grvhmwqqlydpw6wv3ji1rrrq3"; + system = "mito-test"; + asd = "mito-test"; + } + ); + systems = [ "mito-test" ]; + lispLibs = [ + (getAttr "dbd-mysql" self) + (getAttr "dbd-postgres" self) + (getAttr "dbd-sqlite3" self) + (getAttr "mito" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mixalot = ( + build-asdf-system { + pname = "mixalot"; + version = "20151218-git"; + asds = [ "mixalot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; + sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; + system = "mixalot"; + asd = "mixalot"; + } + ); + systems = [ "mixalot" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mixalot-flac = ( + build-asdf-system { + pname = "mixalot-flac"; + version = "20151218-git"; + asds = [ "mixalot-flac" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; + sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; + system = "mixalot-flac"; + asd = "mixalot-flac"; + } + ); + systems = [ "mixalot-flac" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "flac" self) + (getAttr "mixalot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mixalot-mp3 = ( + build-asdf-system { + pname = "mixalot-mp3"; + version = "20151218-git"; + asds = [ "mixalot-mp3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; + sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; + system = "mixalot-mp3"; + asd = "mixalot-mp3"; + } + ); + systems = [ "mixalot-mp3" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "mixalot" self) + (getAttr "mpg123-ffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mixalot-vorbis = ( + build-asdf-system { + pname = "mixalot-vorbis"; + version = "20151218-git"; + asds = [ "mixalot-vorbis" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; + sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; + system = "mixalot-vorbis"; + asd = "mixalot-vorbis"; + } + ); + systems = [ "mixalot-vorbis" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "mixalot" self) + (getAttr "vorbisfile-ffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mk-defsystem = ( + build-asdf-system { + pname = "mk-defsystem"; + version = "20241012-git"; + asds = [ "mk-defsystem" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mk-defsystem/2024-10-12/mk-defsystem-20241012-git.tgz"; + sha256 = "0zrr11szr50bqaxybm66ggj5bmchwljjafhxcwsyzgpqbnf06740"; + system = "mk-defsystem"; + asd = "mk-defsystem"; + } + ); + systems = [ "mk-defsystem" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mk-string-metrics = ( + build-asdf-system { + pname = "mk-string-metrics"; + version = "20180131-git"; + asds = [ "mk-string-metrics" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mk-string-metrics/2018-01-31/mk-string-metrics-20180131-git.tgz"; + sha256 = "0c50hjpylhkh5phcxxcwqdzpa94vk5pq1j7c6x0d3wfpb2yx0wkd"; + system = "mk-string-metrics"; + asd = "mk-string-metrics"; + } + ); + systems = [ "mk-string-metrics" ]; + lispLibs = [ ]; + meta = { }; + } + ); + mk-string-metrics-tests = ( + build-asdf-system { + pname = "mk-string-metrics-tests"; + version = "20180131-git"; + asds = [ "mk-string-metrics-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mk-string-metrics/2018-01-31/mk-string-metrics-20180131-git.tgz"; + sha256 = "0c50hjpylhkh5phcxxcwqdzpa94vk5pq1j7c6x0d3wfpb2yx0wkd"; + system = "mk-string-metrics-tests"; + asd = "mk-string-metrics-tests"; + } + ); + systems = [ "mk-string-metrics-tests" ]; + lispLibs = [ (getAttr "mk-string-metrics" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ml-dsl = ( + build-asdf-system { + pname = "ml-dsl"; + version = "20210124-git"; + asds = [ "ml-dsl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-marklogic/2021-01-24/cl-marklogic-20210124-git.tgz"; + sha256 = "0baq2ccb88zyr2dqdvpm32lsin4zalv11w48x4xm80cr4kw45fk5"; + system = "ml-dsl"; + asd = "ml-dsl"; + } + ); + systems = [ "ml-dsl" ]; + lispLibs = [ (getAttr "cl-marklogic" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ml-optimizer = ( + build-asdf-system { + pname = "ml-optimizer"; + version = "20210124-git"; + asds = [ "ml-optimizer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-marklogic/2021-01-24/cl-marklogic-20210124-git.tgz"; + sha256 = "0baq2ccb88zyr2dqdvpm32lsin4zalv11w48x4xm80cr4kw45fk5"; + system = "ml-optimizer"; + asd = "ml-optimizer"; + } + ); + systems = [ "ml-optimizer" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "cl-marklogic" self) + (getAttr "cl-opsresearch" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ml-test = ( + build-asdf-system { + pname = "ml-test"; + version = "20210124-git"; + asds = [ "ml-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-marklogic/2021-01-24/cl-marklogic-20210124-git.tgz"; + sha256 = "0baq2ccb88zyr2dqdvpm32lsin4zalv11w48x4xm80cr4kw45fk5"; + system = "ml-test"; + asd = "ml-test"; + } + ); + systems = [ "ml-test" ]; + lispLibs = [ + (getAttr "cl-marklogic" self) + (getAttr "fiveam" self) + (getAttr "ml-optimizer" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mlep = ( + build-asdf-system { + pname = "mlep"; + version = "20231021-git"; + asds = [ "mlep" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mlep/2023-10-21/cl-mlep-20231021-git.tgz"; + sha256 = "0na6hjjp1a3bril14v878h9198zrbymnfw7nybgcll0kwv90815g"; + system = "mlep"; + asd = "mlep"; + } + ); + systems = [ "mlep" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mlep-add = ( + build-asdf-system { + pname = "mlep-add"; + version = "20231021-git"; + asds = [ "mlep-add" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mlep/2023-10-21/cl-mlep-20231021-git.tgz"; + sha256 = "0na6hjjp1a3bril14v878h9198zrbymnfw7nybgcll0kwv90815g"; + system = "mlep-add"; + asd = "mlep-add"; + } + ); + systems = [ "mlep-add" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "lla" self) + (getAttr "mlep" self) + (getAttr "num-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mmap = ( + build-asdf-system { + pname = "mmap"; + version = "20241012-git"; + asds = [ "mmap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mmap/2024-10-12/mmap-20241012-git.tgz"; + sha256 = "1wlxymkkbjyyp6fikxi94q26pjfz656y4d8kgm22xxvw70hppgc3"; + system = "mmap"; + asd = "mmap"; + } + ); + systems = [ "mmap" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { }; + } + ); + mmap-test = ( + build-asdf-system { + pname = "mmap-test"; + version = "20241012-git"; + asds = [ "mmap-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mmap/2024-10-12/mmap-20241012-git.tgz"; + sha256 = "1wlxymkkbjyyp6fikxi94q26pjfz656y4d8kgm22xxvw70hppgc3"; + system = "mmap-test"; + asd = "mmap-test"; + } + ); + systems = [ "mmap-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "mmap" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mnas-graph = ( + build-asdf-system { + pname = "mnas-graph"; + version = "20230618-git"; + asds = [ "mnas-graph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mnas-graph/2023-06-18/mnas-graph-20230618-git.tgz"; + sha256 = "1psz8vh8s8zv9hh5pr0753r0baavfb1v6v9nc9kw50hkjvkchc1q"; + system = "mnas-graph"; + asd = "mnas-graph"; + } + ); + systems = [ "mnas-graph" ]; + lispLibs = [ + (getAttr "mnas-hash-table" self) + (getAttr "mnas-string" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mnas-hash-table = ( + build-asdf-system { + pname = "mnas-hash-table"; + version = "20230618-git"; + asds = [ "mnas-hash-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mnas-hash-table/2023-06-18/mnas-hash-table-20230618-git.tgz"; + sha256 = "107fqc2wipvs2ifj12sqizv3gc7j3yqww529vkp92xhkmrnkp833"; + system = "mnas-hash-table"; + asd = "mnas-hash-table"; + } + ); + systems = [ "mnas-hash-table" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mnas-package = ( + build-asdf-system { + pname = "mnas-package"; + version = "20241012-git"; + asds = [ "mnas-package" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mnas-package/2024-10-12/mnas-package-20241012-git.tgz"; + sha256 = "05wkh2rzlp3csnk3p50rp3jv4jycdqa5hylqf93b2q8vjxvv67wm"; + system = "mnas-package"; + asd = "mnas-package"; + } + ); + systems = [ "mnas-package" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "inferior-shell" self) + (getAttr "mnas-graph" self) + (getAttr "mnas-string" self) + (getAttr "slynk" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mnas-path = ( + build-asdf-system { + pname = "mnas-path"; + version = "20231021-git"; + asds = [ "mnas-path" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mnas-path/2023-10-21/mnas-path-20231021-git.tgz"; + sha256 = "10hijr71nlnl9wf15ahzjgynvq1n1y8446fxk7pkfwcw832x874z"; + system = "mnas-path"; + asd = "mnas-path"; + } + ); + systems = [ "mnas-path" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "mnas-string" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mnas-string = ( + build-asdf-system { + pname = "mnas-string"; + version = "20241012-git"; + asds = [ "mnas-string" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mnas-string/2024-10-12/mnas-string-20241012-git.tgz"; + sha256 = "1pk0fyi3pjq7h9x40hixapsa06s0dah6xd4d63jpyhp7y6fa8w6f"; + system = "mnas-string"; + asd = "mnas-string"; + } + ); + systems = [ "mnas-string" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "mnas-hash-table" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mnst-relay = ( + build-asdf-system { + pname = "mnst-relay"; + version = "20210807-git"; + asds = [ "mnst-relay" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; + sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; + system = "mnst-relay"; + asd = "mnst-relay"; + } + ); + systems = [ "mnst-relay" ]; + lispLibs = [ + (getAttr "asdf-nst" self) + (getAttr "nst" self) + (getAttr "nst-selftest-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mockingbird = ( + build-asdf-system { + pname = "mockingbird"; + version = "20211020-git"; + asds = [ "mockingbird" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mockingbird/2021-10-20/mockingbird-20211020-git.tgz"; + sha256 = "1n1mxl2qk7g63z92d943ysn12axw0bx5dvw0cmm3cs1hjpx5rdly"; + system = "mockingbird"; + asd = "mockingbird"; + } + ); + systems = [ "mockingbird" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "fare-utils" self) + (getAttr "trivial-arguments" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mockingbird-test = ( + build-asdf-system { + pname = "mockingbird-test"; + version = "20211020-git"; + asds = [ "mockingbird-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mockingbird/2021-10-20/mockingbird-20211020-git.tgz"; + sha256 = "1n1mxl2qk7g63z92d943ysn12axw0bx5dvw0cmm3cs1hjpx5rdly"; + system = "mockingbird-test"; + asd = "mockingbird-test"; + } + ); + systems = [ "mockingbird-test" ]; + lispLibs = [ + (getAttr "mockingbird" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + modest-config = ( + build-asdf-system { + pname = "modest-config"; + version = "20180228-git"; + asds = [ "modest-config" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/modest-config/2018-02-28/modest-config-20180228-git.tgz"; + sha256 = "0ali9lvg7ngzmpgaxmbc4adp4djznavbywiig8x94c2xwicvjh83"; + system = "modest-config"; + asd = "modest-config"; + } + ); + systems = [ "modest-config" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + modest-config-test = ( + build-asdf-system { + pname = "modest-config-test"; + version = "20180228-git"; + asds = [ "modest-config-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/modest-config/2018-02-28/modest-config-20180228-git.tgz"; + sha256 = "0ali9lvg7ngzmpgaxmbc4adp4djznavbywiig8x94c2xwicvjh83"; + system = "modest-config-test"; + asd = "modest-config-test"; + } + ); + systems = [ "modest-config-test" ]; + lispLibs = [ + (getAttr "modest-config" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + modf = ( + build-asdf-system { + pname = "modf"; + version = "20200925-git"; + asds = [ "modf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/modf/2020-09-25/modf-20200925-git.tgz"; + sha256 = "1aap7ldy7lv942khp026pgndgdzfkkqa9xcq1ykinrmflrgdazay"; + system = "modf"; + asd = "modf"; + } + ); + systems = [ "modf" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + modf-fset = ( + build-asdf-system { + pname = "modf-fset"; + version = "20150608-git"; + asds = [ "modf-fset" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/modf-fset/2015-06-08/modf-fset-20150608-git.tgz"; + sha256 = "0xdlwsw3b31l9c6db7rgvikn42ncqk98s45zcq116f51ph3dr95y"; + system = "modf-fset"; + asd = "modf-fset"; + } + ); + systems = [ "modf-fset" ]; + lispLibs = [ + (getAttr "fset" self) + (getAttr "modf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + modf-fset-test = ( + build-asdf-system { + pname = "modf-fset-test"; + version = "20150608-git"; + asds = [ "modf-fset-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/modf-fset/2015-06-08/modf-fset-20150608-git.tgz"; + sha256 = "0xdlwsw3b31l9c6db7rgvikn42ncqk98s45zcq116f51ph3dr95y"; + system = "modf-fset-test"; + asd = "modf-fset-test"; + } + ); + systems = [ "modf-fset-test" ]; + lispLibs = [ + (getAttr "modf" self) + (getAttr "modf-fset" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + modf-test = ( + build-asdf-system { + pname = "modf-test"; + version = "20200925-git"; + asds = [ "modf-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/modf/2020-09-25/modf-20200925-git.tgz"; + sha256 = "1aap7ldy7lv942khp026pgndgdzfkkqa9xcq1ykinrmflrgdazay"; + system = "modf-test"; + asd = "modf-test"; + } + ); + systems = [ "modf-test" ]; + lispLibs = [ + (getAttr "iterate" self) + (getAttr "modf" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + modlisp = ( + build-asdf-system { + pname = "modlisp"; + version = "20150923-git"; + asds = [ "modlisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-modlisp/2015-09-23/cl-modlisp-20150923-git.tgz"; + sha256 = "14gfhhy8blyrhpb1jk17bq4vazgwmzgcx3misw48ja77x17bl1zf"; + system = "modlisp"; + asd = "modlisp"; + } + ); + systems = [ "modlisp" ]; + lispLibs = [ (getAttr "kmrcl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + modularize = ( + build-asdf-system { + pname = "modularize"; + version = "20231021-git"; + asds = [ "modularize" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/modularize/2023-10-21/modularize-20231021-git.tgz"; + sha256 = "1i660gpljl97j51sj4mx8pk91v96zddww24rbwz0p20cl9hfp0xj"; + system = "modularize"; + asd = "modularize"; + } + ); + systems = [ "modularize" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "trivial-package-local-nicknames" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + modularize-hooks = ( + build-asdf-system { + pname = "modularize-hooks"; + version = "20231021-git"; + asds = [ "modularize-hooks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/modularize-hooks/2023-10-21/modularize-hooks-20231021-git.tgz"; + sha256 = "0f60rk9753vil56wyi54db35ffanjw5fmkyn79jc5hnlab78ffhy"; + system = "modularize-hooks"; + asd = "modularize-hooks"; + } + ); + systems = [ "modularize-hooks" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "lambda-fiddle" self) + (getAttr "modularize" self) + (getAttr "trivial-arguments" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + modularize-interfaces = ( + build-asdf-system { + pname = "modularize-interfaces"; + version = "20231021-git"; + asds = [ "modularize-interfaces" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/modularize-interfaces/2023-10-21/modularize-interfaces-20231021-git.tgz"; + sha256 = "0lmq2jbkbr5wrrjl2qb1x64fcvl0lmii0h9301b9bq4d47s4w8sh"; + system = "modularize-interfaces"; + asd = "modularize-interfaces"; + } + ); + systems = [ "modularize-interfaces" ]; + lispLibs = [ + (getAttr "lambda-fiddle" self) + (getAttr "modularize" self) + (getAttr "trivial-arguments" self) + (getAttr "trivial-indent" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + modularize-test-module = ( + build-asdf-system { + pname = "modularize-test-module"; + version = "20231021-git"; + asds = [ "modularize-test-module" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/modularize/2023-10-21/modularize-20231021-git.tgz"; + sha256 = "1i660gpljl97j51sj4mx8pk91v96zddww24rbwz0p20cl9hfp0xj"; + system = "modularize-test-module"; + asd = "modularize-test-module"; + } + ); + systems = [ "modularize-test-module" ]; + lispLibs = [ (getAttr "modularize" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + moira = ( + build-asdf-system { + pname = "moira"; + version = "20241012-git"; + asds = [ "moira" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/moira/2024-10-12/moira-20241012-git.tgz"; + sha256 = "01wxjg122flla4pgys57hya3fwrkyjkpp26j5ypl5885zz1ip5b7"; + system = "moira"; + asd = "moira"; + } + ); + systems = [ "moira" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "osicat" self) + (getAttr "serapeum" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + monkeylib-html = ( + build-asdf-system { + pname = "monkeylib-html"; + version = "20180228-git"; + asds = [ "monkeylib-html" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-html/2018-02-28/monkeylib-html-20180228-git.tgz"; + sha256 = "11a778ynyb8mhiy9fkpyg2x1p53hi1i9mry9gfin2r28mjgwj096"; + system = "monkeylib-html"; + asd = "monkeylib-html"; + } + ); + systems = [ "monkeylib-html" ]; + lispLibs = [ + (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) + (getAttr "com_dot_gigamonkeys_dot_pathnames" self) + (getAttr "com_dot_gigamonkeys_dot_test-framework" self) + (getAttr "com_dot_gigamonkeys_dot_utilities" self) + (getAttr "monkeylib-text-languages" self) + (getAttr "monkeylib-text-output" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + monkeylib-markup-html = ( + build-asdf-system { + pname = "monkeylib-markup-html"; + version = "20120208-git"; + asds = [ "monkeylib-markup-html" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-markup-html/2012-02-08/monkeylib-markup-html-20120208-git.tgz"; + sha256 = "1kwnlb7dka9bqyc8a06lbsap8j83kdayk4m9a1m3mazjgaxlpv2a"; + system = "monkeylib-markup-html"; + asd = "monkeylib-markup-html"; + } + ); + systems = [ "monkeylib-markup-html" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) + (getAttr "com_dot_gigamonkeys_dot_markup" self) + (getAttr "com_dot_gigamonkeys_dot_utilities" self) + (getAttr "monkeylib-html" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + monkeylib-text-languages = ( + build-asdf-system { + pname = "monkeylib-text-languages"; + version = "20111203-git"; + asds = [ "monkeylib-text-languages" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-text-languages/2011-12-03/monkeylib-text-languages-20111203-git.tgz"; + sha256 = "1f6hb3r2s5phz5z4rv3llyfi30vbxlq9qpipsq9vppmw51fvdsdk"; + system = "monkeylib-text-languages"; + asd = "monkeylib-text-languages"; + } + ); + systems = [ "monkeylib-text-languages" ]; + lispLibs = [ + (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) + (getAttr "monkeylib-text-output" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + monkeylib-text-output = ( + build-asdf-system { + pname = "monkeylib-text-output"; + version = "20111203-git"; + asds = [ "monkeylib-text-output" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/monkeylib-text-output/2011-12-03/monkeylib-text-output-20111203-git.tgz"; + sha256 = "0lygfxap2ppxxi0sbz8lig1h878ad84jwbp3c895r7h9svjh1ffm"; + system = "monkeylib-text-output"; + asd = "monkeylib-text-output"; + } + ); + systems = [ "monkeylib-text-output" ]; + lispLibs = [ + (getAttr "com_dot_gigamonkeys_dot_macro-utilities" self) + (getAttr "com_dot_gigamonkeys_dot_pathnames" self) + (getAttr "com_dot_gigamonkeys_dot_test-framework" self) + (getAttr "com_dot_gigamonkeys_dot_utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + montezuma = ( + build-asdf-system { + pname = "montezuma"; + version = "20180228-git"; + asds = [ "montezuma" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/montezuma/2018-02-28/montezuma-20180228-git.tgz"; + sha256 = "0svmvsbsirydk3c1spzfvj8qmkzcs9i69anpfvk1843i62wb7x2c"; + system = "montezuma"; + asd = "montezuma"; + } + ); + systems = [ "montezuma" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + montezuma-indexfiles = ( + build-asdf-system { + pname = "montezuma-indexfiles"; + version = "20180228-git"; + asds = [ "montezuma-indexfiles" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/montezuma/2018-02-28/montezuma-20180228-git.tgz"; + sha256 = "0svmvsbsirydk3c1spzfvj8qmkzcs9i69anpfvk1843i62wb7x2c"; + system = "montezuma-indexfiles"; + asd = "montezuma-indexfiles"; + } + ); + systems = [ "montezuma-indexfiles" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "montezuma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + montezuma-tests = ( + build-asdf-system { + pname = "montezuma-tests"; + version = "20180228-git"; + asds = [ "montezuma-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/montezuma/2018-02-28/montezuma-20180228-git.tgz"; + sha256 = "0svmvsbsirydk3c1spzfvj8qmkzcs9i69anpfvk1843i62wb7x2c"; + system = "montezuma-tests"; + asd = "montezuma"; + } + ); + systems = [ "montezuma-tests" ]; + lispLibs = [ + (getAttr "montezuma" self) + (getAttr "trivial-timeout" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + moptilities = ( + build-asdf-system { + pname = "moptilities"; + version = "20170403-git"; + asds = [ "moptilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/moptilities/2017-04-03/moptilities-20170403-git.tgz"; + sha256 = "1q12bqjbj47lx98yim1kfnnhgfhkl80102fkgp9pdqxg0fp6g5fc"; + system = "moptilities"; + asd = "moptilities"; + } + ); + systems = [ "moptilities" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { }; + } + ); + moptilities-test = ( + build-asdf-system { + pname = "moptilities-test"; + version = "20170403-git"; + asds = [ "moptilities-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/moptilities/2017-04-03/moptilities-20170403-git.tgz"; + sha256 = "1q12bqjbj47lx98yim1kfnnhgfhkl80102fkgp9pdqxg0fp6g5fc"; + system = "moptilities-test"; + asd = "moptilities-test"; + } + ); + systems = [ "moptilities-test" ]; + lispLibs = [ + (getAttr "lift" self) + (getAttr "moptilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + more-conditions = ( + build-asdf-system { + pname = "more-conditions"; + version = "20180831-git"; + asds = [ "more-conditions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/more-conditions/2018-08-31/more-conditions-20180831-git.tgz"; + sha256 = "1n0xbz0yiqn9dxf0ycm57wqvsr4gh2q4hs5fskjbv87c47d7l7zr"; + system = "more-conditions"; + asd = "more-conditions"; + } + ); + systems = [ "more-conditions" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + ]; + meta = { }; + } + ); + mp3-duration = ( + build-asdf-system { + pname = "mp3-duration"; + version = "20160208-git"; + asds = [ "mp3-duration" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mp3-duration/2016-02-08/mp3-duration-20160208-git.tgz"; + sha256 = "1mhn9g1kz2yan178m2adg0pz3dx2nmg7hq4gfmfz7lrlsxm08bs7"; + system = "mp3-duration"; + asd = "mp3-duration"; + } + ); + systems = [ "mp3-duration" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mp3-duration-test = ( + build-asdf-system { + pname = "mp3-duration-test"; + version = "20160208-git"; + asds = [ "mp3-duration-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mp3-duration/2016-02-08/mp3-duration-20160208-git.tgz"; + sha256 = "1mhn9g1kz2yan178m2adg0pz3dx2nmg7hq4gfmfz7lrlsxm08bs7"; + system = "mp3-duration-test"; + asd = "mp3-duration-test"; + } + ); + systems = [ "mp3-duration-test" ]; + lispLibs = [ + (getAttr "mp3-duration" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mpc = ( + build-asdf-system { + pname = "mpc"; + version = "20160929-git"; + asds = [ "mpc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mpc/2016-09-29/mpc-20160929-git.tgz"; + sha256 = "1nig0v91m4ybcr19s50xijwv488qlma0b36zy6cric2y8wgclmsx"; + system = "mpc"; + asd = "mpc"; + } + ); + systems = [ "mpc" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mpg123-ffi = ( + build-asdf-system { + pname = "mpg123-ffi"; + version = "20151218-git"; + asds = [ "mpg123-ffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; + sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; + system = "mpg123-ffi"; + asd = "mpg123-ffi"; + } + ); + systems = [ "mpg123-ffi" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mra-wavelet-plot = ( + build-asdf-system { + pname = "mra-wavelet-plot"; + version = "20181210-git"; + asds = [ "mra-wavelet-plot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mra-wavelet-plot/2018-12-10/mra-wavelet-plot-20181210-git.tgz"; + sha256 = "0d6sdgj1zvkliga9drsqnj4l748vbcwwz744ayq5nnvp5fvhnc29"; + system = "mra-wavelet-plot"; + asd = "mra-wavelet-plot"; + } + ); + systems = [ "mra-wavelet-plot" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mssql = ( + build-asdf-system { + pname = "mssql"; + version = "20241012-git"; + asds = [ "mssql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-mssql/2024-10-12/cl-mssql-20241012-git.tgz"; + sha256 = "15hnlkx6d2vw46v7h01wljzag33j5is679amv74kzk4qq91wfkx2"; + system = "mssql"; + asd = "mssql"; + } + ); + systems = [ "mssql" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "garbage-pools" self) + (getAttr "iterate" self) + (getAttr "parse-number" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mstrings = ( + build-asdf-system { + pname = "mstrings"; + version = "20220707-git"; + asds = [ "mstrings" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mstrings/2022-07-07/mstrings-20220707-git.tgz"; + sha256 = "0s1zqwnv9agvlp79gh7y06rmly56v8nm1l594rry9gzwvvx1jj1k"; + system = "mstrings"; + asd = "mstrings"; + } + ); + systems = [ "mstrings" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mt19937 = ( + build-asdf-system { + pname = "mt19937"; + version = "1.1.1"; + asds = [ "mt19937" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mt19937/2011-02-19/mt19937-1.1.1.tgz"; + sha256 = "0h02ssnncc760b68ipm0sbrzrbnllp6fqabvw98w43af08s36xlg"; + system = "mt19937"; + asd = "mt19937"; + } + ); + systems = [ "mt19937" ]; + lispLibs = [ ]; + meta = { }; + } + ); + mtif = ( + build-asdf-system { + pname = "mtif"; + version = "20171130-git"; + asds = [ "mtif" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mtif/2017-11-30/mtif-20171130-git.tgz"; + sha256 = "0fzlf0xawv579i4jp5l994d7m220py5j169klaj0l43frgxb4n7y"; + system = "mtif"; + asd = "mtif"; + } + ); + systems = [ "mtif" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mtlisp = ( + build-asdf-system { + pname = "mtlisp"; + version = "20130615-git"; + asds = [ "mtlisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mtlisp/2013-06-15/mtlisp-20130615-git.tgz"; + sha256 = "0qpbhiy2z2q7mf4lf2lpj66a13xj7bj0c584d1i7zi156s2hcnvs"; + system = "mtlisp"; + asd = "mtlisp"; + } + ); + systems = [ "mtlisp" ]; + lispLibs = [ (getAttr "acl-compat" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + multilang-documentation = ( + build-asdf-system { + pname = "multilang-documentation"; + version = "20231021-git"; + asds = [ "multilang-documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/multilang-documentation/2023-10-21/multilang-documentation-20231021-git.tgz"; + sha256 = "1v9sv81lx0ms9djz0hqhwdswg0rmzqv47g57k5jmzkx6lbjsya7z"; + system = "multilang-documentation"; + asd = "multilang-documentation"; + } + ); + systems = [ "multilang-documentation" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "language-codes" self) + (getAttr "system-locale" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + multilang-documentation-utils = ( + build-asdf-system { + pname = "multilang-documentation-utils"; + version = "20231021-git"; + asds = [ "multilang-documentation-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/documentation-utils/2023-10-21/documentation-utils-20231021-git.tgz"; + sha256 = "0nzkjzvcqi1l2ywiz17h1f54vgvbkywv95in4yww6lyzqjqsqqhy"; + system = "multilang-documentation-utils"; + asd = "multilang-documentation-utils"; + } + ); + systems = [ "multilang-documentation-utils" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "multilang-documentation" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + multiple-value-variants = ( + build-asdf-system { + pname = "multiple-value-variants"; + version = "1.0.1"; + asds = [ "multiple-value-variants" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/multiple-value-variants/2014-08-26/multiple-value-variants-1.0.1.tgz"; + sha256 = "0kb7bkgg2iri89ph2lcgfk57pf8h4r6471sn2jcyp5sz13g4f6yw"; + system = "multiple-value-variants"; + asd = "multiple-value-variants"; + } + ); + systems = [ "multiple-value-variants" ]; + lispLibs = [ + (getAttr "enhanced-multiple-value-bind" self) + (getAttr "map-bind" self) + (getAttr "positional-lambda" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + multiposter = ( + build-asdf-system { + pname = "multiposter"; + version = "20241012-git"; + asds = [ "multiposter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/multiposter/2024-10-12/multiposter-20241012-git.tgz"; + sha256 = "1q1zinv4csnb0yjlndym5dlf7apax3f5qdiids3dlai09jb4hbjg"; + system = "multiposter"; + asd = "multiposter"; + } + ); + systems = [ "multiposter" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "clohost" self) + (getAttr "closer-mop" self) + (getAttr "documentation-utils" self) + (getAttr "fuzzy-dates" self) + (getAttr "humbler" self) + (getAttr "lichat-tcp-client" self) + (getAttr "lquery" self) + (getAttr "north-drakma" self) + (getAttr "pathname-utils" self) + (getAttr "studio-client" self) + (getAttr "tooter" self) + (getAttr "trivial-arguments" self) + (getAttr "trivial-mimes" self) + (getAttr "ubiquitous" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + multival-plist = ( + build-asdf-system { + pname = "multival-plist"; + version = "20120305-git"; + asds = [ "multival-plist" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/multival-plist/2012-03-05/multival-plist-20120305-git.tgz"; + sha256 = "0cfca0qvngbvs9v4z8qpzr6wsjvf01jzaszagmasa4zkvmjycx1b"; + system = "multival-plist"; + asd = "multival-plist"; + } + ); + systems = [ "multival-plist" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-annot" self) + (getAttr "cl-syntax-annot" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + multival-plist-test = ( + build-asdf-system { + pname = "multival-plist-test"; + version = "20120305-git"; + asds = [ "multival-plist-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/multival-plist/2012-03-05/multival-plist-20120305-git.tgz"; + sha256 = "0cfca0qvngbvs9v4z8qpzr6wsjvf01jzaszagmasa4zkvmjycx1b"; + system = "multival-plist-test"; + asd = "multival-plist-test"; + } + ); + systems = [ "multival-plist-test" ]; + lispLibs = [ + (getAttr "cl-test-more" self) + (getAttr "multival-plist" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + music-spelling = ( + build-asdf-system { + pname = "music-spelling"; + version = "20230214-git"; + asds = [ "music-spelling" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/music-spelling/2023-02-14/music-spelling-20230214-git.tgz"; + sha256 = "0fgahb0jjr4sp2739d55gylmx8alsghnx3spyaqfqci4cxfrys52"; + system = "music-spelling"; + asd = "music-spelling"; + } + ); + systems = [ "music-spelling" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mutility = ( + build-asdf-system { + pname = "mutility"; + version = "20241012-git"; + asds = [ "mutility" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mutility/2024-10-12/mutility-20241012-git.tgz"; + sha256 = "17ip4rkvval66k9r3a2hvpr4pqa087b3rqjdayl115fi6bfzncr4"; + system = "mutility"; + asd = "mutility"; + } + ); + systems = [ "mutility" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mutils = ( + build-asdf-system { + pname = "mutils"; + version = "20241012-git"; + asds = [ "mutils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mutils/2024-10-12/mutils-20241012-git.tgz"; + sha256 = "1xmqms002bafrdrpzgqq5dr0qfiywg3p7mhvb6xny1jrk3qdqz75"; + system = "mutils"; + asd = "mutils"; + } + ); + systems = [ "mutils" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mw-equiv = ( + build-asdf-system { + pname = "mw-equiv"; + version = "0.1.3"; + asds = [ "mw-equiv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mw-equiv/2010-10-06/mw-equiv-0.1.3.tgz"; + sha256 = "1fl90wp0jp7l90mps53fq0kzb28f10qfr739527h03xwqccyylad"; + system = "mw-equiv"; + asd = "mw-equiv"; + } + ); + systems = [ "mw-equiv" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + my-cool-system = ( + build-asdf-system { + pname = "my-cool-system"; + version = "20231021-git"; + asds = [ "my-cool-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/super-loader/2023-10-21/super-loader-20231021-git.tgz"; + sha256 = "0jicqg3w1yhwkmjfag0lvlhw83w2hpanwav1gzyf4s58sng6cxf4"; + system = "my-cool-system"; + asd = "my-cool-system"; + } + ); + systems = [ "my-cool-system" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + my-secret-system = ( + build-asdf-system { + pname = "my-secret-system"; + version = "20231021-git"; + asds = [ "my-secret-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/super-loader/2023-10-21/super-loader-20231021-git.tgz"; + sha256 = "0jicqg3w1yhwkmjfag0lvlhw83w2hpanwav1gzyf4s58sng6cxf4"; + system = "my-secret-system"; + asd = "my-secret-system"; + } + ); + systems = [ "my-secret-system" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mystic = ( + build-asdf-system { + pname = "mystic"; + version = "20230618-git"; + asds = [ "mystic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; + sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; + system = "mystic"; + asd = "mystic"; + } + ); + systems = [ "mystic" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cl-mustache" self) + (getAttr "local-time" self) + (getAttr "split-sequence" self) + (getAttr "ubiquitous" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mystic-file-mixin = ( + build-asdf-system { + pname = "mystic-file-mixin"; + version = "20230618-git"; + asds = [ "mystic-file-mixin" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; + sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; + system = "mystic-file-mixin"; + asd = "mystic-file-mixin"; + } + ); + systems = [ "mystic-file-mixin" ]; + lispLibs = [ (getAttr "mystic" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mystic-fiveam-mixin = ( + build-asdf-system { + pname = "mystic-fiveam-mixin"; + version = "20230618-git"; + asds = [ "mystic-fiveam-mixin" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; + sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; + system = "mystic-fiveam-mixin"; + asd = "mystic-fiveam-mixin"; + } + ); + systems = [ "mystic-fiveam-mixin" ]; + lispLibs = [ + (getAttr "mystic" self) + (getAttr "mystic-file-mixin" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mystic-gitignore-mixin = ( + build-asdf-system { + pname = "mystic-gitignore-mixin"; + version = "20230618-git"; + asds = [ "mystic-gitignore-mixin" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; + sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; + system = "mystic-gitignore-mixin"; + asd = "mystic-gitignore-mixin"; + } + ); + systems = [ "mystic-gitignore-mixin" ]; + lispLibs = [ + (getAttr "mystic" self) + (getAttr "mystic-file-mixin" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mystic-library-template = ( + build-asdf-system { + pname = "mystic-library-template"; + version = "20230618-git"; + asds = [ "mystic-library-template" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; + sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; + system = "mystic-library-template"; + asd = "mystic-library-template"; + } + ); + systems = [ "mystic-library-template" ]; + lispLibs = [ + (getAttr "mystic" self) + (getAttr "mystic-fiveam-mixin" self) + (getAttr "mystic-gitignore-mixin" self) + (getAttr "mystic-readme-mixin" self) + (getAttr "mystic-travis-mixin" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mystic-readme-mixin = ( + build-asdf-system { + pname = "mystic-readme-mixin"; + version = "20230618-git"; + asds = [ "mystic-readme-mixin" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; + sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; + system = "mystic-readme-mixin"; + asd = "mystic-readme-mixin"; + } + ); + systems = [ "mystic-readme-mixin" ]; + lispLibs = [ + (getAttr "mystic" self) + (getAttr "mystic-file-mixin" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mystic-test = ( + build-asdf-system { + pname = "mystic-test"; + version = "20230618-git"; + asds = [ "mystic-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; + sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; + system = "mystic-test"; + asd = "mystic-test"; + } + ); + systems = [ "mystic-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "mystic" self) + (getAttr "mystic-library-template" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + mystic-travis-mixin = ( + build-asdf-system { + pname = "mystic-travis-mixin"; + version = "20230618-git"; + asds = [ "mystic-travis-mixin" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mystic/2023-06-18/mystic-20230618-git.tgz"; + sha256 = "0fa7mb326vz7ygiwzk0x2y8gna0xnq19cics5vxc6smw6a8mhxi5"; + system = "mystic-travis-mixin"; + asd = "mystic-travis-mixin"; + } + ); + systems = [ "mystic-travis-mixin" ]; + lispLibs = [ + (getAttr "mystic" self) + (getAttr "mystic-file-mixin" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + myway = ( + build-asdf-system { + pname = "myway"; + version = "20221106-git"; + asds = [ "myway" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/myway/2022-11-06/myway-20221106-git.tgz"; + sha256 = "0xac8xpbcvq457f2jzzkf46mh5ganf1k2ix8sg61hqqmld5z4dag"; + system = "myway"; + asd = "myway"; + } + ); + systems = [ "myway" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-utilities" self) + (getAttr "map-set" self) + (getAttr "quri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + myway-test = ( + build-asdf-system { + pname = "myway-test"; + version = "20221106-git"; + asds = [ "myway-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/myway/2022-11-06/myway-20221106-git.tgz"; + sha256 = "0xac8xpbcvq457f2jzzkf46mh5ganf1k2ix8sg61hqqmld5z4dag"; + system = "myway-test"; + asd = "myway-test"; + } + ); + systems = [ "myway-test" ]; + lispLibs = [ + (getAttr "myway" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + myweb = ( + build-asdf-system { + pname = "myweb"; + version = "20241012-git"; + asds = [ "myweb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/myweb/2024-10-12/myweb-20241012-git.tgz"; + sha256 = "10r67w3cgrq0r7qmqdnv4c3pjz7kkhz9q3jj0amlknr0nsr4y2zp"; + system = "myweb"; + asd = "myweb"; + } + ); + systems = [ "myweb" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-log" self) + (getAttr "local-time" self) + (getAttr "trivial-utf-8" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nail = ( + build-asdf-system { + pname = "nail"; + version = "20230214-git"; + asds = [ "nail" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nail/2023-02-14/nail-20230214-git.tgz"; + sha256 = "0m5a1zx9s033mz3ypx27c26z5bvc8mcpnpzslypzdp6xah1nv0g3"; + system = "nail"; + asd = "nail"; + } + ); + systems = [ "nail" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cl-reexport" self) + (getAttr "eazy-gnuplot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + named-closure = ( + build-asdf-system { + pname = "named-closure"; + version = "20241012-git"; + asds = [ "named-closure" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/named-closure/2024-10-12/named-closure-20241012-git.tgz"; + sha256 = "1ja7lvid589n3r25vh7j21wji60dm2qika2jn51jvfbbii853x09"; + system = "named-closure"; + asd = "named-closure"; + } + ); + systems = [ "named-closure" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "hu_dot_dwim_dot_walker" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + named-read-macros = ( + build-asdf-system { + pname = "named-read-macros"; + version = "20210228-git"; + asds = [ "named-read-macros" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/named-read-macros/2021-02-28/named-read-macros-20210228-git.tgz"; + sha256 = "0bgqy43h06nq2p9avqix2k15ab306sghrz2pkr17pli87q0qkxhi"; + system = "named-read-macros"; + asd = "named-read-macros"; + } + ); + systems = [ "named-read-macros" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + named-read-macros-test = ( + build-asdf-system { + pname = "named-read-macros-test"; + version = "20210228-git"; + asds = [ "named-read-macros-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/named-read-macros/2021-02-28/named-read-macros-20210228-git.tgz"; + sha256 = "0bgqy43h06nq2p9avqix2k15ab306sghrz2pkr17pli87q0qkxhi"; + system = "named-read-macros-test"; + asd = "named-read-macros-test"; + } + ); + systems = [ "named-read-macros-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "named-read-macros" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + named-readtables = ( + build-asdf-system { + pname = "named-readtables"; + version = "20231021-git"; + asds = [ "named-readtables" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/named-readtables/2023-10-21/named-readtables-20231021-git.tgz"; + sha256 = "0cnxs13qf0y1r05mhhf54jihvv7pqk1a2p3x5jzs4y8ld1in6xzp"; + system = "named-readtables"; + asd = "named-readtables"; + } + ); + systems = [ "named-readtables" ]; + lispLibs = [ (getAttr "mgl-pax-bootstrap" self) ]; + meta = { }; + } + ); + named-readtables-test = ( + build-asdf-system { + pname = "named-readtables-test"; + version = "20231021-git"; + asds = [ "named-readtables-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/named-readtables/2023-10-21/named-readtables-20231021-git.tgz"; + sha256 = "0cnxs13qf0y1r05mhhf54jihvv7pqk1a2p3x5jzs4y8ld1in6xzp"; + system = "named-readtables-test"; + asd = "named-readtables-test"; + } + ); + systems = [ "named-readtables-test" ]; + lispLibs = [ + (getAttr "named-readtables" self) + (getAttr "try" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nanovg-blob = ( + build-asdf-system { + pname = "nanovg-blob"; + version = "stable-git"; + asds = [ "nanovg-blob" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nanovg-blob/2020-10-16/nanovg-blob-stable-git.tgz"; + sha256 = "1q80inrlfcqqqc912jcskfn667jgq6lcw0jvhk270x5qpj8z2pfj"; + system = "nanovg-blob"; + asd = "nanovg-blob"; + } + ); + systems = [ "nanovg-blob" ]; + lispLibs = [ + (getAttr "bodge-blobs-support" self) + (getAttr "glad-blob" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + napa-fft3 = ( + build-asdf-system { + pname = "napa-fft3"; + version = "20151218-git"; + asds = [ "napa-fft3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/napa-fft3/2015-12-18/napa-fft3-20151218-git.tgz"; + sha256 = "1hxjf599xgwm28gbryy7q96j9ys6hfszmv0qxpr5698hxnhknscp"; + system = "napa-fft3"; + asd = "napa-fft3"; + } + ); + systems = [ "napa-fft3" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + narrowed-types = ( + build-asdf-system { + pname = "narrowed-types"; + version = "20180228-git"; + asds = [ "narrowed-types" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/narrowed-types/2018-02-28/narrowed-types-20180228-git.tgz"; + sha256 = "03v4jgdysapj3ndg2qij7liqc6n9zb07r5j4k1jhmhpml86jxg4g"; + system = "narrowed-types"; + asd = "narrowed-types"; + } + ); + systems = [ "narrowed-types" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + narrowed-types-test = ( + build-asdf-system { + pname = "narrowed-types-test"; + version = "20180228-git"; + asds = [ "narrowed-types-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/narrowed-types/2018-02-28/narrowed-types-20180228-git.tgz"; + sha256 = "03v4jgdysapj3ndg2qij7liqc6n9zb07r5j4k1jhmhpml86jxg4g"; + system = "narrowed-types-test"; + asd = "narrowed-types-test"; + } + ); + systems = [ "narrowed-types-test" ]; + lispLibs = [ + (getAttr "narrowed-types" self) + (getAttr "rt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + native-lazy-seq = ( + build-asdf-system { + pname = "native-lazy-seq"; + version = "20230618-git"; + asds = [ "native-lazy-seq" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/native-lazy-seq/2023-06-18/native-lazy-seq-20230618-git.tgz"; + sha256 = "1p5zja0qg61girf67ic8j6wv9s1faxki0mazxmydbm92ckrns2rp"; + system = "native-lazy-seq"; + asd = "native-lazy-seq"; + } + ); + systems = [ "native-lazy-seq" ]; + lispLibs = [ + (getAttr "iterate" self) + (getAttr "serapeum" self) + (getAttr "trivial-extensible-sequences" self) + (getAttr "trivial-package-local-nicknames" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nbd = ( + build-asdf-system { + pname = "nbd"; + version = "20211020-git"; + asds = [ "nbd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nbd/2021-10-20/nbd-20211020-git.tgz"; + sha256 = "1p9dpyvlpjm32a2ymhps782dp5pjya5bnky6sb20gf4zyw6r826n"; + system = "nbd"; + asd = "nbd"; + } + ); + systems = [ "nbd" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "flexi-streams" self) + (getAttr "lisp-binary" self) + (getAttr "wild-package-inferred-system" self) + ]; + meta = { }; + } + ); + ncurses-clone-for-lem = ( + build-asdf-system { + pname = "ncurses-clone-for-lem"; + version = "20200427-git"; + asds = [ "ncurses-clone-for-lem" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "ncurses-clone-for-lem"; + asd = "ncurses-clone-for-lem"; + } + ); + systems = [ "ncurses-clone-for-lem" ]; + lispLibs = [ + (getAttr "application" self) + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + (getAttr "lparallel" self) + (getAttr "nsb-cga" self) + (getAttr "text-subsystem" self) + (getAttr "utility" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ndebug = ( + build-asdf-system { + pname = "ndebug"; + version = "20241012-git"; + asds = [ "ndebug" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ndebug/2024-10-12/ndebug-20241012-git.tgz"; + sha256 = "168khn4190p55fjhbpnbq130lbaafq7cw0131x7n650d9f4h2hyq"; + system = "ndebug"; + asd = "ndebug"; + } + ); + systems = [ "ndebug" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "dissect" self) + (getAttr "trivial-custom-debugger" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ndfa = ( + build-asdf-system { + pname = "ndfa"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "ndfa" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "ndfa"; + asd = "ndfa"; + } + ); + systems = [ "ndfa" ]; + lispLibs = [ (getAttr "adjuvant" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ndfa-test = ( + build-asdf-system { + pname = "ndfa-test"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "ndfa-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "ndfa-test"; + asd = "ndfa-test"; + } + ); + systems = [ "ndfa-test" ]; + lispLibs = [ + (getAttr "adjuvant" self) + (getAttr "ndfa" self) + (getAttr "scrutiny" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net-telent-date = ( + build-asdf-system { + pname = "net-telent-date"; + version = "0.42"; + asds = [ "net-telent-date" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/net-telent-date/2010-10-06/net-telent-date_0.42.tgz"; + sha256 = "0vgibf76hy3zy39pix367xnvpwxiqsxvv6w0gqdxprd5ljpb7g2j"; + system = "net-telent-date"; + asd = "net-telent-date"; + } + ); + systems = [ "net-telent-date" ]; + lispLibs = [ ]; + meta = { }; + } + ); + net_dot_didierverna_dot_asdf-flv = ( + build-asdf-system { + pname = "net.didierverna.asdf-flv"; + version = "version-2.2"; + asds = [ "net.didierverna.asdf-flv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-flv/2023-10-21/asdf-flv-version-2.2.tgz"; + sha256 = "1svcjhdlsdayr07qa38kj8n5m40qplklspmlrkmvc5wdhk9jz8sw"; + system = "net.didierverna.asdf-flv"; + asd = "net.didierverna.asdf-flv"; + } + ); + systems = [ "net.didierverna.asdf-flv" ]; + lispLibs = [ ]; + meta = { }; + } + ); + net_dot_didierverna_dot_clon = ( + build-asdf-system { + pname = "net.didierverna.clon"; + version = "version-1.0b27"; + asds = [ "net.didierverna.clon" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-clon/2023-10-21/cl-clon-version-1.0b27.tgz"; + sha256 = "0cyh5z78r7qhv2rzghkhksgg848d6iy1xv7y87p3aivd23c916b1"; + system = "net.didierverna.clon"; + asd = "net.didierverna.clon"; + } + ); + systems = [ "net.didierverna.clon" ]; + lispLibs = [ + (getAttr "net_dot_didierverna_dot_clon_dot_core" self) + (getAttr "net_dot_didierverna_dot_clon_dot_setup" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_clon_dot_core = ( + build-asdf-system { + pname = "net.didierverna.clon.core"; + version = "version-1.0b27"; + asds = [ "net.didierverna.clon.core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-clon/2023-10-21/cl-clon-version-1.0b27.tgz"; + sha256 = "0cyh5z78r7qhv2rzghkhksgg848d6iy1xv7y87p3aivd23c916b1"; + system = "net.didierverna.clon.core"; + asd = "net.didierverna.clon.core"; + } + ); + systems = [ "net.didierverna.clon.core" ]; + lispLibs = [ (getAttr "net_dot_didierverna_dot_clon_dot_setup" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_clon_dot_demo_dot_advanced = ( + build-asdf-system { + pname = "net.didierverna.clon.demo.advanced"; + version = "version-1.0b27"; + asds = [ "net.didierverna.clon.demo.advanced" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-clon/2023-10-21/cl-clon-version-1.0b27.tgz"; + sha256 = "0cyh5z78r7qhv2rzghkhksgg848d6iy1xv7y87p3aivd23c916b1"; + system = "net.didierverna.clon.demo.advanced"; + asd = "net.didierverna.clon.demo.advanced"; + } + ); + systems = [ "net.didierverna.clon.demo.advanced" ]; + lispLibs = [ (getAttr "net_dot_didierverna_dot_clon" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_clon_dot_demo_dot_simple = ( + build-asdf-system { + pname = "net.didierverna.clon.demo.simple"; + version = "version-1.0b27"; + asds = [ "net.didierverna.clon.demo.simple" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-clon/2023-10-21/cl-clon-version-1.0b27.tgz"; + sha256 = "0cyh5z78r7qhv2rzghkhksgg848d6iy1xv7y87p3aivd23c916b1"; + system = "net.didierverna.clon.demo.simple"; + asd = "net.didierverna.clon.demo.simple"; + } + ); + systems = [ "net.didierverna.clon.demo.simple" ]; + lispLibs = [ (getAttr "net_dot_didierverna_dot_clon" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_clon_dot_setup = ( + build-asdf-system { + pname = "net.didierverna.clon.setup"; + version = "version-1.0b27"; + asds = [ "net.didierverna.clon.setup" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-clon/2023-10-21/cl-clon-version-1.0b27.tgz"; + sha256 = "0cyh5z78r7qhv2rzghkhksgg848d6iy1xv7y87p3aivd23c916b1"; + system = "net.didierverna.clon.setup"; + asd = "net.didierverna.clon.setup"; + } + ); + systems = [ "net.didierverna.clon.setup" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_clon_dot_termio = ( + build-asdf-system { + pname = "net.didierverna.clon.termio"; + version = "version-1.0b27"; + asds = [ "net.didierverna.clon.termio" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-clon/2023-10-21/cl-clon-version-1.0b27.tgz"; + sha256 = "0cyh5z78r7qhv2rzghkhksgg848d6iy1xv7y87p3aivd23c916b1"; + system = "net.didierverna.clon.termio"; + asd = "net.didierverna.clon.termio"; + } + ); + systems = [ "net.didierverna.clon.termio" ]; + lispLibs = [ + (getAttr "net_dot_didierverna_dot_clon_dot_core" self) + (getAttr "net_dot_didierverna_dot_clon_dot_setup" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_declt_dot_setup = ( + build-asdf-system { + pname = "net.didierverna.declt.setup"; + version = "4.0b2"; + asds = [ "net.didierverna.declt.setup" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/declt/2024-10-12/declt-4.0b2.tgz"; + sha256 = "1xkbf1xqrkmr8na09b0spmrznsx2ml10i9q026zv9mpbsc7gh0i6"; + system = "net.didierverna.declt.setup"; + asd = "net.didierverna.declt.setup"; + } + ); + systems = [ "net.didierverna.declt.setup" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_focus = ( + build-asdf-system { + pname = "net.didierverna.focus"; + version = "20170403-git"; + asds = [ "net.didierverna.focus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/focus/2017-04-03/focus-20170403-git.tgz"; + sha256 = "0b7nxqlkfi7irdmhsbp15r63c8fcg8q0ahmwmq5cmkf8ffq8dspc"; + system = "net.didierverna.focus"; + asd = "net.didierverna.focus"; + } + ); + systems = [ "net.didierverna.focus" ]; + lispLibs = [ + (getAttr "net_dot_didierverna_dot_focus_dot_core" self) + (getAttr "net_dot_didierverna_dot_focus_dot_flv" self) + (getAttr "net_dot_didierverna_dot_focus_dot_setup" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_focus_dot_core = ( + build-asdf-system { + pname = "net.didierverna.focus.core"; + version = "20170403-git"; + asds = [ "net.didierverna.focus.core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/focus/2017-04-03/focus-20170403-git.tgz"; + sha256 = "0b7nxqlkfi7irdmhsbp15r63c8fcg8q0ahmwmq5cmkf8ffq8dspc"; + system = "net.didierverna.focus.core"; + asd = "net.didierverna.focus.core"; + } + ); + systems = [ "net.didierverna.focus.core" ]; + lispLibs = [ (getAttr "net_dot_didierverna_dot_focus_dot_setup" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_focus_dot_demos_dot_quotation = ( + build-asdf-system { + pname = "net.didierverna.focus.demos.quotation"; + version = "20170403-git"; + asds = [ "net.didierverna.focus.demos.quotation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/focus/2017-04-03/focus-20170403-git.tgz"; + sha256 = "0b7nxqlkfi7irdmhsbp15r63c8fcg8q0ahmwmq5cmkf8ffq8dspc"; + system = "net.didierverna.focus.demos.quotation"; + asd = "net.didierverna.focus.demos.quotation"; + } + ); + systems = [ "net.didierverna.focus.demos.quotation" ]; + lispLibs = [ (getAttr "net_dot_didierverna_dot_focus_dot_flv" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_focus_dot_flv = ( + build-asdf-system { + pname = "net.didierverna.focus.flv"; + version = "20170403-git"; + asds = [ "net.didierverna.focus.flv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/focus/2017-04-03/focus-20170403-git.tgz"; + sha256 = "0b7nxqlkfi7irdmhsbp15r63c8fcg8q0ahmwmq5cmkf8ffq8dspc"; + system = "net.didierverna.focus.flv"; + asd = "net.didierverna.focus.flv"; + } + ); + systems = [ "net.didierverna.focus.flv" ]; + lispLibs = [ + (getAttr "net_dot_didierverna_dot_asdf-flv" self) + (getAttr "net_dot_didierverna_dot_focus_dot_core" self) + (getAttr "net_dot_didierverna_dot_focus_dot_setup" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_focus_dot_setup = ( + build-asdf-system { + pname = "net.didierverna.focus.setup"; + version = "20170403-git"; + asds = [ "net.didierverna.focus.setup" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/focus/2017-04-03/focus-20170403-git.tgz"; + sha256 = "0b7nxqlkfi7irdmhsbp15r63c8fcg8q0ahmwmq5cmkf8ffq8dspc"; + system = "net.didierverna.focus.setup"; + asd = "net.didierverna.focus.setup"; + } + ); + systems = [ "net.didierverna.focus.setup" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_tfm = ( + build-asdf-system { + pname = "net.didierverna.tfm"; + version = "20241012-git"; + asds = [ "net.didierverna.tfm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfm/2024-10-12/tfm-20241012-git.tgz"; + sha256 = "15lnp9w9z5ar64bynb365n4wqh8wa7z4m4dzy320xrxnnc1w2sn2"; + system = "net.didierverna.tfm"; + asd = "net.didierverna.tfm"; + } + ); + systems = [ "net.didierverna.tfm" ]; + lispLibs = [ (getAttr "net_dot_didierverna_dot_tfm_dot_core" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_tfm_dot_core = ( + build-asdf-system { + pname = "net.didierverna.tfm.core"; + version = "20241012-git"; + asds = [ "net.didierverna.tfm.core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfm/2024-10-12/tfm-20241012-git.tgz"; + sha256 = "15lnp9w9z5ar64bynb365n4wqh8wa7z4m4dzy320xrxnnc1w2sn2"; + system = "net.didierverna.tfm.core"; + asd = "net.didierverna.tfm.core"; + } + ); + systems = [ "net.didierverna.tfm.core" ]; + lispLibs = [ (getAttr "net_dot_didierverna_dot_tfm_dot_setup" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_didierverna_dot_tfm_dot_setup = ( + build-asdf-system { + pname = "net.didierverna.tfm.setup"; + version = "20241012-git"; + asds = [ "net.didierverna.tfm.setup" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfm/2024-10-12/tfm-20241012-git.tgz"; + sha256 = "15lnp9w9z5ar64bynb365n4wqh8wa7z4m4dzy320xrxnnc1w2sn2"; + system = "net.didierverna.tfm.setup"; + asd = "net.didierverna.tfm.setup"; + } + ); + systems = [ "net.didierverna.tfm.setup" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + net_dot_scipolis_dot_graphs = ( + build-asdf-system { + pname = "net.scipolis.graphs"; + version = "20210411-git"; + asds = [ "net.scipolis.graphs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/femlisp/2021-04-11/femlisp-20210411-git.tgz"; + sha256 = "08l2x1jq3vfhh8m14wijd8c78n589cy5hd2py2jfj3yfiqyipasa"; + system = "net.scipolis.graphs"; + asd = "net.scipolis.graphs"; + } + ); + systems = [ "net.scipolis.graphs" ]; + lispLibs = [ (getAttr "femlisp-basic" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + network-addresses = ( + build-asdf-system { + pname = "network-addresses"; + version = "20160628-git"; + asds = [ "network-addresses" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/network-addresses/2016-06-28/network-addresses-20160628-git.tgz"; + sha256 = "0zkyfdvfy9pz08vrgz40qpnqx0y7vf92aarp9dq2wipimnwy8df2"; + system = "network-addresses"; + asd = "network-addresses"; + } + ); + systems = [ "network-addresses" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + network-addresses-test = ( + build-asdf-system { + pname = "network-addresses-test"; + version = "20160628-git"; + asds = [ "network-addresses-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/network-addresses/2016-06-28/network-addresses-20160628-git.tgz"; + sha256 = "0zkyfdvfy9pz08vrgz40qpnqx0y7vf92aarp9dq2wipimnwy8df2"; + system = "network-addresses-test"; + asd = "network-addresses-test"; + } + ); + systems = [ "network-addresses-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "network-addresses" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + neural-classifier = ( + build-asdf-system { + pname = "neural-classifier"; + version = "20241012-git"; + asds = [ "neural-classifier" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/neural-classifier/2024-10-12/neural-classifier-20241012-git.tgz"; + sha256 = "0aq7m781c27di7lfs1a7di55f31i7x490yfd2033738biqn0x019"; + system = "neural-classifier"; + asd = "neural-classifier"; + } + ); + systems = [ "neural-classifier" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "magicl" self) + (getAttr "serapeum" self) + (getAttr "snakes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + new-op = ( + build-asdf-system { + pname = "new-op"; + version = "20241012-git"; + asds = [ "new-op" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/new-op/2024-10-12/new-op-20241012-git.tgz"; + sha256 = "1jrnn4xbx5gc1202hqpinh0q1gm2wcv28jr8fl6g7wm6170nscxh"; + system = "new-op"; + asd = "new-op"; + } + ); + systems = [ "new-op" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nibbles = ( + build-asdf-system { + pname = "nibbles"; + version = "20241012-git"; + asds = [ "nibbles" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nibbles/2024-10-12/nibbles-20241012-git.tgz"; + sha256 = "00j464l3l1rx2x9gzx45gz7wcpplk1wmfh5liigzlxqq0ybjc7lr"; + system = "nibbles"; + asd = "nibbles"; + } + ); + systems = [ "nibbles" ]; + lispLibs = [ ]; + meta = { }; + } + ); + nibbles-streams = ( + build-asdf-system { + pname = "nibbles-streams"; + version = "20241012-git"; + asds = [ "nibbles-streams" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nibbles-streams/2024-10-12/nibbles-streams-20241012-git.tgz"; + sha256 = "1m1i9nivpahk11rzdwy3xxdcdwmkx3xzb4kqcz3gh3prwhyg83a1"; + system = "nibbles-streams"; + asd = "nibbles-streams"; + } + ); + systems = [ "nibbles-streams" ]; + lispLibs = [ + (getAttr "nibbles" self) + (getAttr "serapeum" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nineveh = ( + build-asdf-system { + pname = "nineveh"; + version = "release-quicklisp-0a10a846-git"; + asds = [ "nineveh" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nineveh/2019-10-07/nineveh-release-quicklisp-0a10a846-git.tgz"; + sha256 = "0bpdgqc9iz37240ypirpi489pnqpb92i94snyhjbh87i50y4br2l"; + system = "nineveh"; + asd = "nineveh"; + } + ); + systems = [ "nineveh" ]; + lispLibs = [ + (getAttr "cepl" self) + (getAttr "cl-soil" self) + (getAttr "dendrite_dot_primitives" self) + (getAttr "documentation-utils" self) + (getAttr "easing" self) + (getAttr "livesupport" self) + (getAttr "rtg-math_dot_vari" self) + (getAttr "with-setf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ningle = ( + build-asdf-system { + pname = "ningle"; + version = "20241012-git"; + asds = [ "ningle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ningle/2024-10-12/ningle-20241012-git.tgz"; + sha256 = "1ym6phipbg94q7344ng9yf02ykh0x5ldx8nfrbsh8p15qajsw7hc"; + system = "ningle"; + asd = "ningle"; + } + ); + systems = [ "ningle" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "lack-component" self) + (getAttr "lack-request" self) + (getAttr "lack-response" self) + (getAttr "myway" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ningle-test = ( + build-asdf-system { + pname = "ningle-test"; + version = "20241012-git"; + asds = [ "ningle-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ningle/2024-10-12/ningle-20241012-git.tgz"; + sha256 = "1ym6phipbg94q7344ng9yf02ykh0x5ldx8nfrbsh8p15qajsw7hc"; + system = "ningle-test"; + asd = "ningle-test"; + } + ); + systems = [ "ningle-test" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "lack-component" self) + (getAttr "lack-test" self) + (getAttr "ningle" self) + (getAttr "prove" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nlopt = ( + build-asdf-system { + pname = "nlopt"; + version = "20220707-git"; + asds = [ "nlopt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nlopt/2022-07-07/nlopt-20220707-git.tgz"; + sha256 = "01zw4yx38kc8x3by0m3dw5j87hwb180ggp4njfnzi1qjq1fdczp5"; + system = "nlopt"; + asd = "nlopt"; + } + ); + systems = [ "nlopt" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nodgui = ( + build-asdf-system { + pname = "nodgui"; + version = "20241012-git"; + asds = [ "nodgui" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nodgui/2024-10-12/nodgui-20241012-git.tgz"; + sha256 = "088dkpqsxc4dmfsbz24wrgi192xrn8116p4zpklwfqa0fblmfzpb"; + system = "nodgui"; + asd = "nodgui"; + } + ); + systems = [ "nodgui" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-colors2" self) + (getAttr "cl-opengl" self) + (getAttr "cl-ppcre-unicode" self) + (getAttr "cl-unicode" self) + (getAttr "esrap" self) + (getAttr "flexi-streams" self) + (getAttr "jpeg-turbo" self) + (getAttr "named-readtables" self) + (getAttr "parse-number" self) + (getAttr "pngload" self) + (getAttr "sdl2" self) + (getAttr "sdl2-ttf" self) + (getAttr "static-vectors" self) + (getAttr "trivial-garbage" self) + (getAttr "zpng" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nodgui-lite = ( + build-asdf-system { + pname = "nodgui-lite"; + version = "20241012-git"; + asds = [ "nodgui-lite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nodgui/2024-10-12/nodgui-20241012-git.tgz"; + sha256 = "088dkpqsxc4dmfsbz24wrgi192xrn8116p4zpklwfqa0fblmfzpb"; + system = "nodgui-lite"; + asd = "nodgui-lite"; + } + ); + systems = [ "nodgui-lite" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-colors2" self) + (getAttr "cl-ppcre-unicode" self) + (getAttr "cl-unicode" self) + (getAttr "esrap" self) + (getAttr "flexi-streams" self) + (getAttr "named-readtables" self) + (getAttr "parse-number" self) + (getAttr "pngload" self) + (getAttr "static-vectors" self) + (getAttr "trivial-garbage" self) + (getAttr "zpng" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + noisy = ( + build-asdf-system { + pname = "noisy"; + version = "20241012-git"; + asds = [ "noisy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/noisy/2024-10-12/noisy-20241012-git.tgz"; + sha256 = "0qr29rxbrrlgd3k7hb6c62yzgflaygvxabq2sbhs90r0bi3cs0dj"; + system = "noisy"; + asd = "noisy"; + } + ); + systems = [ "noisy" ]; + lispLibs = [ (getAttr "random-state" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nontrivial-gray-streams = ( + build-asdf-system { + pname = "nontrivial-gray-streams"; + version = "20241012-git"; + asds = [ "nontrivial-gray-streams" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nontrivial-gray-streams/2024-10-12/nontrivial-gray-streams-20241012-git.tgz"; + sha256 = "0v49nqsc5jbrg499qhk550zg4v5arjh9nch33n5g4f5bfgw7lzh3"; + system = "nontrivial-gray-streams"; + asd = "nontrivial-gray-streams"; + } + ); + systems = [ "nontrivial-gray-streams" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + north = ( + build-asdf-system { + pname = "north"; + version = "20241012-git"; + asds = [ "north" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/north/2024-10-12/north-20241012-git.tgz"; + sha256 = "0ml49xixdr1aagj580dr0dzx7dvdqrf45yyh3pzdzbp0pzqbpjz2"; + system = "north"; + asd = "north"; + } + ); + systems = [ "north" ]; + lispLibs = [ (getAttr "north-drakma" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + north-core = ( + build-asdf-system { + pname = "north-core"; + version = "20241012-git"; + asds = [ "north-core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/north/2024-10-12/north-20241012-git.tgz"; + sha256 = "0ml49xixdr1aagj580dr0dzx7dvdqrf45yyh3pzdzbp0pzqbpjz2"; + system = "north-core"; + asd = "north-core"; + } + ); + systems = [ "north-core" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "crypto-shortcuts" self) + (getAttr "documentation-utils" self) + (getAttr "uuid" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + north-dexador = ( + build-asdf-system { + pname = "north-dexador"; + version = "20241012-git"; + asds = [ "north-dexador" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/north/2024-10-12/north-20241012-git.tgz"; + sha256 = "0ml49xixdr1aagj580dr0dzx7dvdqrf45yyh3pzdzbp0pzqbpjz2"; + system = "north-dexador"; + asd = "north-dexador"; + } + ); + systems = [ "north-dexador" ]; + lispLibs = [ + (getAttr "dexador" self) + (getAttr "north-core" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + north-drakma = ( + build-asdf-system { + pname = "north-drakma"; + version = "20241012-git"; + asds = [ "north-drakma" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/north/2024-10-12/north-20241012-git.tgz"; + sha256 = "0ml49xixdr1aagj580dr0dzx7dvdqrf45yyh3pzdzbp0pzqbpjz2"; + system = "north-drakma"; + asd = "north-drakma"; + } + ); + systems = [ "north-drakma" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "north-core" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + north-example = ( + build-asdf-system { + pname = "north-example"; + version = "20241012-git"; + asds = [ "north-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/north/2024-10-12/north-20241012-git.tgz"; + sha256 = "0ml49xixdr1aagj580dr0dzx7dvdqrf45yyh3pzdzbp0pzqbpjz2"; + system = "north-example"; + asd = "north-example"; + } + ); + systems = [ "north-example" ]; + lispLibs = [ + (getAttr "clip" self) + (getAttr "drakma" self) + (getAttr "hunchentoot" self) + (getAttr "north" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nsb-cga = ( + build-asdf-system { + pname = "nsb-cga"; + version = "20200427-git"; + asds = [ "nsb-cga" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "nsb-cga"; + asd = "nsb-cga"; + } + ); + systems = [ "nsb-cga" ]; + lispLibs = [ (getAttr "cl-reexport" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nsort = ( + build-asdf-system { + pname = "nsort"; + version = "20150505-git"; + asds = [ "nsort" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nsort/2015-05-05/nsort-20150505-git.tgz"; + sha256 = "1q58slg8pl390av8pv16xb8g9qibgy3pm6vyl1fw75mx37yqkyd3"; + system = "nsort"; + asd = "nsort"; + } + ); + systems = [ "nsort" ]; + lispLibs = [ (getAttr "prove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nst = ( + build-asdf-system { + pname = "nst"; + version = "20210807-git"; + asds = [ "nst" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; + sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; + system = "nst"; + asd = "nst"; + } + ); + systems = [ "nst" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "org-sampler" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nst-manual-tests = ( + build-asdf-system { + pname = "nst-manual-tests"; + version = "20210807-git"; + asds = [ "nst-manual-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; + sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; + system = "nst-manual-tests"; + asd = "nst-manual-tests"; + } + ); + systems = [ "nst-manual-tests" ]; + lispLibs = [ + (getAttr "asdf-nst" self) + (getAttr "nst" self) + (getAttr "nst-selftest-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nst-meta-tests = ( + build-asdf-system { + pname = "nst-meta-tests"; + version = "20210807-git"; + asds = [ "nst-meta-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; + sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; + system = "nst-meta-tests"; + asd = "nst-meta-tests"; + } + ); + systems = [ "nst-meta-tests" ]; + lispLibs = [ + (getAttr "asdf-nst" self) + (getAttr "nst" self) + (getAttr "nst-selftest-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nst-mop-utils = ( + build-asdf-system { + pname = "nst-mop-utils"; + version = "20210807-git"; + asds = [ "nst-mop-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; + sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; + system = "nst-mop-utils"; + asd = "nst-mop-utils"; + } + ); + systems = [ "nst-mop-utils" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "nst" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nst-selftest-utils = ( + build-asdf-system { + pname = "nst-selftest-utils"; + version = "20210807-git"; + asds = [ "nst-selftest-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; + sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; + system = "nst-selftest-utils"; + asd = "nst-selftest-utils"; + } + ); + systems = [ "nst-selftest-utils" ]; + lispLibs = [ (getAttr "nst" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nst-simple-tests = ( + build-asdf-system { + pname = "nst-simple-tests"; + version = "20210807-git"; + asds = [ "nst-simple-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; + sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; + system = "nst-simple-tests"; + asd = "nst-simple-tests"; + } + ); + systems = [ "nst-simple-tests" ]; + lispLibs = [ + (getAttr "asdf-nst" self) + (getAttr "nst" self) + (getAttr "nst-selftest-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nst-test = ( + build-asdf-system { + pname = "nst-test"; + version = "20210807-git"; + asds = [ "nst-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; + sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; + system = "nst-test"; + asd = "nst-test"; + } + ); + systems = [ "nst-test" ]; + lispLibs = [ + (getAttr "asdf-nst" self) + (getAttr "nst" self) + (getAttr "nst-meta-tests" self) + (getAttr "nst-simple-tests" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nst-test-jenkins = ( + build-asdf-system { + pname = "nst-test-jenkins"; + version = "20210807-git"; + asds = [ "nst-test-jenkins" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nst/2021-08-07/cl-nst-20210807-git.tgz"; + sha256 = "1hf3r6pqbnd9vsd1i24qmz928kia72hdgmiafiwb6jw1hmj3r6ga"; + system = "nst-test-jenkins"; + asd = "nst-test-jenkins"; + } + ); + systems = [ "nst-test-jenkins" ]; + lispLibs = [ + (getAttr "asdf-nst" self) + (getAttr "nst" self) + (getAttr "nst-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nuclblog = ( + build-asdf-system { + pname = "nuclblog"; + version = "20140826-git"; + asds = [ "nuclblog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nuclblog/2014-08-26/nuclblog-20140826-git.tgz"; + sha256 = "03ngrxas65l7h9ykyy100arm0imvnrxxyyf809l8iqqv87b3k1hz"; + system = "nuclblog"; + asd = "nuclblog"; + } + ); + systems = [ "nuclblog" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-markdown" self) + (getAttr "cl-store" self) + (getAttr "cl-who" self) + (getAttr "hunchentoot" self) + (getAttr "hunchentoot-auth" self) + (getAttr "md5" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nuklear-blob = ( + build-asdf-system { + pname = "nuklear-blob"; + version = "stable-git"; + asds = [ "nuklear-blob" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nuklear-blob/2020-10-16/nuklear-blob-stable-git.tgz"; + sha256 = "1qqx08sd74ix027p6w35yr0ycp72swy1zzps015hwkiwxsawkncm"; + system = "nuklear-blob"; + asd = "nuklear-blob"; + } + ); + systems = [ "nuklear-blob" ]; + lispLibs = [ + (getAttr "bodge-blobs-support" self) + (getAttr "glad-blob" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nuklear-renderer-blob = ( + build-asdf-system { + pname = "nuklear-renderer-blob"; + version = "stable-git"; + asds = [ "nuklear-renderer-blob" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nuklear-renderer-blob/2020-10-16/nuklear-renderer-blob-stable-git.tgz"; + sha256 = "0f73ns9dq02v7ixpbnvrfgp52cjdvmbbbhhfwjyv0ywxx30mrdq4"; + system = "nuklear-renderer-blob"; + asd = "nuklear-renderer-blob"; + } + ); + systems = [ "nuklear-renderer-blob" ]; + lispLibs = [ + (getAttr "bodge-blobs-support" self) + (getAttr "glad-blob" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + null-package = ( + build-asdf-system { + pname = "null-package"; + version = "20220707-git"; + asds = [ "null-package" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/null-package/2022-07-07/null-package-20220707-git.tgz"; + sha256 = "1ildain46gw0nfnxdwfvasr5vg1fs93afni3k65sl5imc82g910f"; + system = "null-package"; + asd = "null-package"; + } + ); + systems = [ "null-package" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "core-reader" self) + (getAttr "named-readtables" self) + (getAttr "read-as-string" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + null-package_dot_test = ( + build-asdf-system { + pname = "null-package.test"; + version = "20220707-git"; + asds = [ "null-package.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/null-package/2022-07-07/null-package-20220707-git.tgz"; + sha256 = "1ildain46gw0nfnxdwfvasr5vg1fs93afni3k65sl5imc82g910f"; + system = "null-package.test"; + asd = "null-package.test"; + } + ); + systems = [ "null-package.test" ]; + lispLibs = [ + (getAttr "bnf" self) + (getAttr "jingoh" self) + (getAttr "null-package" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + num-utils = ( + build-asdf-system { + pname = "num-utils"; + version = "20241012-git"; + asds = [ "num-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/numerical-utilities/2024-10-12/numerical-utilities-20241012-git.tgz"; + sha256 = "00ck2bj4pqir2aan26xhirk41wzrfaziqmnngabhmwi0hz81bjs6"; + system = "num-utils"; + asd = "num-utils"; + } + ); + systems = [ "num-utils" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "alexandria_plus" self) + (getAttr "anaphora" self) + (getAttr "array-operations" self) + (getAttr "let-plus" self) + (getAttr "select" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + numcl = ( + build-asdf-system { + pname = "numcl"; + version = "20221106-git"; + asds = [ "numcl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/numcl/2022-11-06/numcl-20221106-git.tgz"; + sha256 = "1x0j4vx5w3rn18pssfwys3ghfxr2lkkrv37y47144kr890jrcad9"; + system = "numcl"; + asd = "numcl"; + } + ); + systems = [ "numcl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-randist" self) + (getAttr "constantfold" self) + (getAttr "float-features" self) + (getAttr "function-cache" self) + (getAttr "gtype" self) + (getAttr "iterate" self) + (getAttr "lisp-namespace" self) + (getAttr "specialized-function" self) + (getAttr "trivia" self) + (getAttr "type-r" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + numcl_dot_test = ( + build-asdf-system { + pname = "numcl.test"; + version = "20221106-git"; + asds = [ "numcl.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/numcl/2022-11-06/numcl-20221106-git.tgz"; + sha256 = "1x0j4vx5w3rn18pssfwys3ghfxr2lkkrv37y47144kr890jrcad9"; + system = "numcl.test"; + asd = "numcl.test"; + } + ); + systems = [ "numcl.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "numcl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + numpy-file-format = ( + build-asdf-system { + pname = "numpy-file-format"; + version = "20231021-git"; + asds = [ "numpy-file-format" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/numpy-file-format/2023-10-21/numpy-file-format-20231021-git.tgz"; + sha256 = "1n0nixc44z1cymm20wif0l2100ydv0h69l6i6xz5bmwcb2zc4gqr"; + system = "numpy-file-format"; + asd = "numpy-file-format"; + } + ); + systems = [ "numpy-file-format" ]; + lispLibs = [ + (getAttr "ieee-floats" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nxt = ( + build-asdf-system { + pname = "nxt"; + version = "20150608-git"; + asds = [ "nxt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nxt/2015-06-08/cl-nxt-20150608-git.tgz"; + sha256 = "1r9004ra140i9v2pmxnjv86dix4040jr0rgww2zwk370zxys7h2g"; + system = "nxt"; + asd = "nxt"; + } + ); + systems = [ "nxt" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "static-vectors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nxt-proxy = ( + build-asdf-system { + pname = "nxt-proxy"; + version = "20150608-git"; + asds = [ "nxt-proxy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-nxt/2015-06-08/cl-nxt-20150608-git.tgz"; + sha256 = "1r9004ra140i9v2pmxnjv86dix4040jr0rgww2zwk370zxys7h2g"; + system = "nxt-proxy"; + asd = "nxt-proxy"; + } + ); + systems = [ "nxt-proxy" ]; + lispLibs = [ + (getAttr "nxt" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nyaml = ( + build-asdf-system { + pname = "nyaml"; + version = "20211230-git"; + asds = [ "nyaml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nyaml/2021-12-30/nyaml-20211230-git.tgz"; + sha256 = "1gdsxhgqx9ynzrxwjidgljlkmz35wx83r6gwslxgg4v0g4vix9da"; + system = "nyaml"; + asd = "nyaml"; + } + ); + systems = [ "nyaml" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + (getAttr "esrap" self) + (getAttr "fare-quasiquote" self) + (getAttr "fare-quasiquote-extras" self) + (getAttr "parse-number" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + nytpu_dot_lisp-utils = ( + build-asdf-system { + pname = "nytpu.lisp-utils"; + version = "20241012-git"; + asds = [ "nytpu.lisp-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/nytpu.lisp-utils/2024-10-12/nytpu.lisp-utils-20241012-git.tgz"; + sha256 = "11mn2xf0nlaqmni0s22n4jbdy8rkqkin1sqni90drd8cs6mccmsd"; + system = "nytpu.lisp-utils"; + asd = "nytpu.lisp-utils"; + } + ); + systems = [ "nytpu.lisp-utils" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + object-class = ( + build-asdf-system { + pname = "object-class"; + version = "1.0"; + asds = [ "object-class" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/object-class/2020-09-25/object-class_1.0.tgz"; + sha256 = "0qagmd2mxbr8b60l0y3jccj0maxjchds96p935pd3q805ry50683"; + system = "object-class"; + asd = "object-class"; + } + ); + systems = [ "object-class" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "compatible-metaclasses" self) + (getAttr "enhanced-find-class" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + object-class__tests = ( + build-asdf-system { + pname = "object-class_tests"; + version = "1.0"; + asds = [ "object-class_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/object-class/2020-09-25/object-class_1.0.tgz"; + sha256 = "0qagmd2mxbr8b60l0y3jccj0maxjchds96p935pd3q805ry50683"; + system = "object-class_tests"; + asd = "object-class_tests"; + } + ); + systems = [ "object-class_tests" ]; + lispLibs = [ + (getAttr "compatible-metaclasses" self) + (getAttr "object-class" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + oclcl = ( + build-asdf-system { + pname = "oclcl"; + version = "20190521-git"; + asds = [ "oclcl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/oclcl/2019-05-21/oclcl-20190521-git.tgz"; + sha256 = "1ccyrv4fknpln5askl8cpnwbp28sikrs6i3dwzm86jwhv272zc8q"; + system = "oclcl"; + asd = "oclcl"; + } + ); + systems = [ "oclcl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-pattern" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-reexport" self) + (getAttr "external-program" self) + (getAttr "lisp-namespace" self) + (getAttr "osicat" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + oclcl-examples = ( + build-asdf-system { + pname = "oclcl-examples"; + version = "20190521-git"; + asds = [ "oclcl-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/oclcl/2019-05-21/oclcl-20190521-git.tgz"; + sha256 = "1ccyrv4fknpln5askl8cpnwbp28sikrs6i3dwzm86jwhv272zc8q"; + system = "oclcl-examples"; + asd = "oclcl-examples"; + } + ); + systems = [ "oclcl-examples" ]; + lispLibs = [ + (getAttr "cl-oclapi" self) + (getAttr "imago" self) + (getAttr "oclcl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + oclcl-test = ( + build-asdf-system { + pname = "oclcl-test"; + version = "20190521-git"; + asds = [ "oclcl-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/oclcl/2019-05-21/oclcl-20190521-git.tgz"; + sha256 = "1ccyrv4fknpln5askl8cpnwbp28sikrs6i3dwzm86jwhv272zc8q"; + system = "oclcl-test"; + asd = "oclcl-test"; + } + ); + systems = [ "oclcl-test" ]; + lispLibs = [ + (getAttr "arrow-macros" self) + (getAttr "oclcl" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ode-blob = ( + build-asdf-system { + pname = "ode-blob"; + version = "stable-git"; + asds = [ "ode-blob" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ode-blob/2020-10-16/ode-blob-stable-git.tgz"; + sha256 = "1l2zq27zmivmr6h66kadbh3isnbdmkxvc7wq16wwmsvq23bhpss6"; + system = "ode-blob"; + asd = "ode-blob"; + } + ); + systems = [ "ode-blob" ]; + lispLibs = [ + (getAttr "base-blobs" self) + (getAttr "bodge-blobs-support" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + odepack = ( + build-asdf-system { + pname = "odepack"; + version = "20231021-git"; + asds = [ "odepack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "odepack"; + asd = "odepack"; + } + ); + systems = [ "odepack" ]; + lispLibs = [ (getAttr "f2cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + odesk = ( + build-asdf-system { + pname = "odesk"; + version = "20150608-git"; + asds = [ "odesk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-odesk/2015-06-08/cl-odesk-20150608-git.tgz"; + sha256 = "1j5pjq4aw83m1in0l7ljn7jq4ixckg91p4h0lwf420xks3lhi4ka"; + system = "odesk"; + asd = "odesk"; + } + ); + systems = [ "odesk" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "iterate" self) + (getAttr "md5" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + oe-encode = ( + build-asdf-system { + pname = "oe-encode"; + version = "20150804-git"; + asds = [ "oe-encode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/oe-encode/2015-08-04/oe-encode-20150804-git.tgz"; + sha256 = "18hd97509vpg04gaf8lzjr2jfyj3w4ql1ydb5202p2r9k4qpvnj9"; + system = "oe-encode"; + asd = "oe-encode"; + } + ); + systems = [ "oe-encode" ]; + lispLibs = [ (getAttr "babel" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + oe-encode-test = ( + build-asdf-system { + pname = "oe-encode-test"; + version = "20150804-git"; + asds = [ "oe-encode-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/oe-encode/2015-08-04/oe-encode-20150804-git.tgz"; + sha256 = "18hd97509vpg04gaf8lzjr2jfyj3w4ql1ydb5202p2r9k4qpvnj9"; + system = "oe-encode-test"; + asd = "oe-encode"; + } + ); + systems = [ "oe-encode-test" ]; + lispLibs = [ + (getAttr "clunit" self) + (getAttr "oe-encode" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + olc = ( + build-asdf-system { + pname = "olc"; + version = "20220331-git"; + asds = [ "olc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/olc/2022-03-31/olc-20220331-git.tgz"; + sha256 = "02r6w9kfa6v4a12y2azmyjkxbn54r1y18c6a024vq4y6zp20fqnz"; + system = "olc"; + asd = "olc"; + } + ); + systems = [ "olc" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + omg = ( + build-asdf-system { + pname = "omg"; + version = "20241012-git"; + asds = [ "omg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/omglib/2024-10-12/omglib-20241012-git.tgz"; + sha256 = "0jp68w3sw9z8gn3498lrmysf93f22a71hsr9c886wix5zpwgqpx7"; + system = "omg"; + asd = "omg"; + } + ); + systems = [ "omg" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-jpeg" self) + (getAttr "cl-parallel" self) + (getAttr "clack" self) + (getAttr "hunchentoot" self) + (getAttr "media-types" self) + (getAttr "pngload" self) + (getAttr "skippy" self) + (getAttr "trivial-utf-8" self) + (getAttr "websocket-driver-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + omgdaemon = ( + build-asdf-system { + pname = "omgdaemon"; + version = "20241012-git"; + asds = [ "omgdaemon" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/omglib/2024-10-12/omglib-20241012-git.tgz"; + sha256 = "0jp68w3sw9z8gn3498lrmysf93f22a71hsr9c886wix5zpwgqpx7"; + system = "omgdaemon"; + asd = "omgdaemon"; + } + ); + systems = [ "omgdaemon" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "find-port" self) + (getAttr "inferior-shell" self) + (getAttr "iolib" self) + (getAttr "log4cl" self) + (getAttr "omg" self) + (getAttr "osicat" self) + (getAttr "swank" self) + (getAttr "trivial-dump-core" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ook = ( + build-asdf-system { + pname = "ook"; + version = "20241012-git"; + asds = [ "ook" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ook/2024-10-12/ook-20241012-git.tgz"; + sha256 = "0vh6g6a392z77yd4vgj3izajyai7pckr90ij1xns6cf9w505aq8w"; + system = "ook"; + asd = "ook"; + } + ); + systems = [ "ook" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + oook = ( + build-asdf-system { + pname = "oook"; + version = "20171130-git"; + asds = [ "oook" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/oook/2017-11-30/oook-20171130-git.tgz"; + sha256 = "0vxw160kbb2b624lc2aqvrx91xnmfhwz8nrzjvmbk5m55q1s4hxr"; + system = "oook"; + asd = "oook"; + } + ); + systems = [ "oook" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cl-inflector" self) + (getAttr "closer-mop" self) + (getAttr "clsql" self) + (getAttr "jonathan" self) + (getAttr "parse-number" self) + (getAttr "semantic-spinneret" self) + (getAttr "spinneret" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + open-geneva = ( + build-asdf-system { + pname = "open-geneva"; + version = "20161204-git"; + asds = [ "open-geneva" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/geneva/2016-12-04/geneva-20161204-git.tgz"; + sha256 = "1pw18xkbndqssx6iix8a8zcw8bgjh88jxxxrklkgkghk04bmqxw3"; + system = "open-geneva"; + asd = "open-geneva"; + } + ); + systems = [ "open-geneva" ]; + lispLibs = [ + (getAttr "geneva" self) + (getAttr "geneva-cl" self) + (getAttr "geneva-html" self) + (getAttr "geneva-latex" self) + (getAttr "geneva-mk2" self) + (getAttr "geneva-plain-text" self) + (getAttr "geneva-tex" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + open-location-code = ( + build-asdf-system { + pname = "open-location-code"; + version = "20241012-git"; + asds = [ "open-location-code" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/open-location-code/2024-10-12/open-location-code-20241012-git.tgz"; + sha256 = "17ip3xzqr2jk9br39d58grrjbk6gsh2mq1a9irjg9a5fig0jlyb2"; + system = "open-location-code"; + asd = "open-location-code"; + } + ); + systems = [ "open-location-code" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + open-vrp = ( + build-asdf-system { + pname = "open-vrp"; + version = "20140914-git"; + asds = [ "open-vrp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/open-vrp/2014-09-14/open-vrp-20140914-git.tgz"; + sha256 = "04k0kp18gpr4cfpsck7pjizawwswh372df4pvm5v87brm6xdw1fr"; + system = "open-vrp"; + asd = "open-vrp"; + } + ); + systems = [ "open-vrp" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "fiveam" self) + (getAttr "open-vrp-lib" self) + (getAttr "vecto" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + open-vrp-lib = ( + build-asdf-system { + pname = "open-vrp-lib"; + version = "20140914-git"; + asds = [ "open-vrp-lib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/open-vrp/2014-09-14/open-vrp-20140914-git.tgz"; + sha256 = "04k0kp18gpr4cfpsck7pjizawwswh372df4pvm5v87brm6xdw1fr"; + system = "open-vrp-lib"; + asd = "open-vrp-lib"; + } + ); + systems = [ "open-vrp-lib" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "fiveam" self) + (getAttr "vecto" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + open-with = ( + build-asdf-system { + pname = "open-with"; + version = "20241012-git"; + asds = [ "open-with" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/open-with/2024-10-12/open-with-20241012-git.tgz"; + sha256 = "0bc0p8nigmfq4axx6qmlxdkm4sb0d2mdi1h7bwmnh0irvmrgdy33"; + system = "open-with"; + asd = "open-with"; + } + ); + systems = [ "open-with" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openai-openapi-client = ( + build-asdf-system { + pname = "openai-openapi-client"; + version = "20241012-git"; + asds = [ "openai-openapi-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/openai-openapi-client/2024-10-12/openai-openapi-client-20241012-git.tgz"; + sha256 = "0qyd9i0y75gf92kf8v22n6wmh63791115r7gmg9ca9pl0dgbpmg9"; + system = "openai-openapi-client"; + asd = "openai-openapi-client"; + } + ); + systems = [ "openai-openapi-client" ]; + lispLibs = [ + (getAttr "com_dot_inuoe_dot_jzon" self) + (getAttr "dexador" self) + (getAttr "openapi-generator" self) + (getAttr "quri" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openal-blob = ( + build-asdf-system { + pname = "openal-blob"; + version = "stable-git"; + asds = [ "openal-blob" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/openal-blob/2020-10-16/openal-blob-stable-git.tgz"; + sha256 = "0bspdqb0xbvwvi6xkn88n4jswpds8fzbgj44ygm7mi6lpwp7lmv2"; + system = "openal-blob"; + asd = "openal-blob"; + } + ); + systems = [ "openal-blob" ]; + lispLibs = [ + (getAttr "base-blobs" self) + (getAttr "bodge-blobs-support" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openapi-generator = ( + build-asdf-system { + pname = "openapi-generator"; + version = "20241012-git"; + asds = [ "openapi-generator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/openapi-generator/2024-10-12/openapi-generator-20241012-git.tgz"; + sha256 = "0zc0y8frcnsqj76sqmqsgfv0zhdz5kkpynwan3sigc78fl1nrs3q"; + system = "openapi-generator"; + asd = "openapi-generator"; + } + ); + systems = [ "openapi-generator" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-hash-util" self) + (getAttr "cl-json-pointer" self) + (getAttr "cl-project" self) + (getAttr "cl-semver" self) + (getAttr "cl-yaml" self) + (getAttr "com_dot_inuoe_dot_jzon" self) + (getAttr "dexador" self) + (getAttr "json-mop" self) + (getAttr "listopia" self) + (getAttr "moptilities" self) + (getAttr "parse-float" self) + (getAttr "pathname-utils" self) + (getAttr "quri" self) + (getAttr "serapeum" self) + (getAttr "str" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openapi-parser = ( + build-asdf-system { + pname = "openapi-parser"; + version = "20230618-git"; + asds = [ "openapi-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-openapi-parser/2023-06-18/cl-openapi-parser-20230618-git.tgz"; + sha256 = "1vjqmxgkd8zvsfa1m6jzp6adwv1hz79z1x662v0f567iar01rzyz"; + system = "openapi-parser"; + asd = "openapi-parser"; + } + ); + systems = [ "openapi-parser" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-change-case" self) + (getAttr "cl-package-locks" self) + (getAttr "cl-yaml" self) + (getAttr "closer-mop" self) + (getAttr "esrap" self) + (getAttr "str" self) + (getAttr "trivia" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openapi-parser-tests = ( + build-asdf-system { + pname = "openapi-parser-tests"; + version = "20230618-git"; + asds = [ "openapi-parser-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-openapi-parser/2023-06-18/cl-openapi-parser-20230618-git.tgz"; + sha256 = "1vjqmxgkd8zvsfa1m6jzp6adwv1hz79z1x662v0f567iar01rzyz"; + system = "openapi-parser-tests"; + asd = "openapi-parser"; + } + ); + systems = [ "openapi-parser-tests" ]; + lispLibs = [ + (getAttr "openapi-parser" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openid-key = ( + build-asdf-system { + pname = "openid-key"; + version = "20181210-git"; + asds = [ "openid-key" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/openid-key/2018-12-10/openid-key-20181210-git.tgz"; + sha256 = "0ja1g4f8nrcn965376j7lnhha9krx4wjqxrg6vc57k7rmkhkzm1z"; + system = "openid-key"; + asd = "openid-key"; + } + ); + systems = [ "openid-key" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "dexador" self) + (getAttr "ironclad" self) + (getAttr "jonathan" self) + (getAttr "local-time" self) + (getAttr "quri" self) + (getAttr "trivial-rfc-1123" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openid-key-test = ( + build-asdf-system { + pname = "openid-key-test"; + version = "20181210-git"; + asds = [ "openid-key-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/openid-key/2018-12-10/openid-key-20181210-git.tgz"; + sha256 = "0ja1g4f8nrcn965376j7lnhha9krx4wjqxrg6vc57k7rmkhkzm1z"; + system = "openid-key-test"; + asd = "openid-key-test"; + } + ); + systems = [ "openid-key-test" ]; + lispLibs = [ + (getAttr "_1am" self) + (getAttr "openid-key" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openrpc-ci = ( + build-asdf-system { + pname = "openrpc-ci"; + version = "20241012-git"; + asds = [ "openrpc-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/openrpc/2024-10-12/openrpc-20241012-git.tgz"; + sha256 = "1s3c5yzfdzvv9wdfjl6lmap7dv5wqz6ywnxl1sbahy1k2xm3fg1s"; + system = "openrpc-ci"; + asd = "openrpc-ci"; + } + ); + systems = [ "openrpc-ci" ]; + lispLibs = [ (getAttr "_40ants-asdf-system" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openrpc-client = ( + build-asdf-system { + pname = "openrpc-client"; + version = "20241012-git"; + asds = [ "openrpc-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/openrpc/2024-10-12/openrpc-20241012-git.tgz"; + sha256 = "1s3c5yzfdzvv9wdfjl6lmap7dv5wqz6ywnxl1sbahy1k2xm3fg1s"; + system = "openrpc-client"; + asd = "openrpc-client"; + } + ); + systems = [ "openrpc-client" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "dexador" self) + (getAttr "jsonrpc" self) + (getAttr "kebab" self) + (getAttr "log4cl" self) + (getAttr "serapeum" self) + (getAttr "str" self) + (getAttr "usocket" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openrpc-deps = ( + build-asdf-system { + pname = "openrpc-deps"; + version = "20241012-git"; + asds = [ "openrpc-deps" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/openrpc/2024-10-12/openrpc-20241012-git.tgz"; + sha256 = "1s3c5yzfdzvv9wdfjl6lmap7dv5wqz6ywnxl1sbahy1k2xm3fg1s"; + system = "openrpc-deps"; + asd = "openrpc-deps"; + } + ); + systems = [ "openrpc-deps" ]; + lispLibs = [ (getAttr "jsonrpc" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openrpc-docs = ( + build-asdf-system { + pname = "openrpc-docs"; + version = "20241012-git"; + asds = [ "openrpc-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/openrpc/2024-10-12/openrpc-20241012-git.tgz"; + sha256 = "1s3c5yzfdzvv9wdfjl6lmap7dv5wqz6ywnxl1sbahy1k2xm3fg1s"; + system = "openrpc-docs"; + asd = "openrpc-docs"; + } + ); + systems = [ "openrpc-docs" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "_40ants-doc" self) + (getAttr "docs-config" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openrpc-example = ( + build-asdf-system { + pname = "openrpc-example"; + version = "20241012-git"; + asds = [ "openrpc-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/openrpc/2024-10-12/openrpc-20241012-git.tgz"; + sha256 = "1s3c5yzfdzvv9wdfjl6lmap7dv5wqz6ywnxl1sbahy1k2xm3fg1s"; + system = "openrpc-example"; + asd = "openrpc-example"; + } + ); + systems = [ "openrpc-example" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "alexandria" self) + (getAttr "clack" self) + (getAttr "clack-handler-hunchentoot" self) + (getAttr "jsonrpc" self) + (getAttr "openrpc-client" self) + (getAttr "openrpc-server" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + openrpc-server = ( + build-asdf-system { + pname = "openrpc-server"; + version = "20241012-git"; + asds = [ "openrpc-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/openrpc/2024-10-12/openrpc-20241012-git.tgz"; + sha256 = "1s3c5yzfdzvv9wdfjl6lmap7dv5wqz6ywnxl1sbahy1k2xm3fg1s"; + system = "openrpc-server"; + asd = "openrpc-server"; + } + ); + systems = [ "openrpc-server" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "alexandria" self) + (getAttr "clack-cors" self) + (getAttr "clack-prometheus" self) + (getAttr "closer-mop" self) + (getAttr "jsonrpc" self) + (getAttr "lack-request" self) + (getAttr "lambda-fiddle" self) + (getAttr "local-time" self) + (getAttr "log4cl" self) + (getAttr "log4cl-extras" self) + (getAttr "serapeum" self) + (getAttr "str" self) + (getAttr "websocket-driver" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ops-test = ( + build-asdf-system { + pname = "ops-test"; + version = "20211020-git"; + asds = [ "ops-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-png/2021-10-20/cl-png-20211020-git.tgz"; + sha256 = "17xcb9ps5vf3if61blmx7cpfrz3gsw7jk8d5zv3f4cq8jrriqdx4"; + system = "ops-test"; + asd = "ops-test"; + } + ); + systems = [ "ops-test" ]; + lispLibs = [ (getAttr "png" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ops5 = ( + build-asdf-system { + pname = "ops5"; + version = "20200218-git"; + asds = [ "ops5" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ops5/2020-02-18/ops5-20200218-git.tgz"; + sha256 = "1q2mrza40qvhny06f4ks2dghyk8a7pjjsi3vj83b9if7fmyj152a"; + system = "ops5"; + asd = "ops5"; + } + ); + systems = [ "ops5" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + opticl = ( + build-asdf-system { + pname = "opticl"; + version = "20220220-git"; + asds = [ "opticl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/opticl/2022-02-20/opticl-20220220-git.tgz"; + sha256 = "1jx9n78d4lf53iz24yid34l92zrpqxfihv6049ixcy0xigf7j4ac"; + system = "opticl"; + asd = "opticl"; + } + ); + systems = [ "opticl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-jpeg" self) + (getAttr "cl-tga" self) + (getAttr "opticl-core" self) + (getAttr "pngload" self) + (getAttr "retrospectiff" self) + (getAttr "skippy" self) + (getAttr "zpng" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + opticl-core = ( + build-asdf-system { + pname = "opticl-core"; + version = "20171019-git"; + asds = [ "opticl-core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/opticl-core/2017-10-19/opticl-core-20171019-git.tgz"; + sha256 = "0458bllabcdjghfrqx6aki49c9qmvfmkk8jl75cfpi7q0i12kh95"; + system = "opticl-core"; + asd = "opticl-core"; + } + ); + systems = [ "opticl-core" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + opticl-doc = ( + build-asdf-system { + pname = "opticl-doc"; + version = "20220220-git"; + asds = [ "opticl-doc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/opticl/2022-02-20/opticl-20220220-git.tgz"; + sha256 = "1jx9n78d4lf53iz24yid34l92zrpqxfihv6049ixcy0xigf7j4ac"; + system = "opticl-doc"; + asd = "opticl-doc"; + } + ); + systems = [ "opticl-doc" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-containers" self) + (getAttr "cl-markdown" self) + (getAttr "opticl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + optima = ( + build-asdf-system { + pname = "optima"; + version = "20150709-git"; + asds = [ "optima" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/optima/2015-07-09/optima-20150709-git.tgz"; + sha256 = "1yw4ymq7ms89342kkvb3aqxgv0w38m9kd8ikdqxxzyybnkjhndal"; + system = "optima"; + asd = "optima"; + } + ); + systems = [ "optima" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + ]; + meta = { }; + } + ); + optima_dot_ppcre = ( + build-asdf-system { + pname = "optima.ppcre"; + version = "20150709-git"; + asds = [ "optima.ppcre" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/optima/2015-07-09/optima-20150709-git.tgz"; + sha256 = "1yw4ymq7ms89342kkvb3aqxgv0w38m9kd8ikdqxxzyybnkjhndal"; + system = "optima.ppcre"; + asd = "optima.ppcre"; + } + ); + systems = [ "optima.ppcre" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "optima" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + optima_dot_test = ( + build-asdf-system { + pname = "optima.test"; + version = "20150709-git"; + asds = [ "optima.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/optima/2015-07-09/optima-20150709-git.tgz"; + sha256 = "1yw4ymq7ms89342kkvb3aqxgv0w38m9kd8ikdqxxzyybnkjhndal"; + system = "optima.test"; + asd = "optima.test"; + } + ); + systems = [ "optima.test" ]; + lispLibs = [ + (getAttr "eos" self) + (getAttr "optima" self) + (getAttr "optima_dot_ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + or-cluster = ( + build-asdf-system { + pname = "or-cluster"; + version = "20170403-git"; + asds = [ "or-cluster" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opsresearch/2017-04-03/cl-opsresearch-20170403-git.tgz"; + sha256 = "1fipw6qjggswzcg8ifwx5qnhnc7mmi53s6h14l0vzj6afa5rdpm7"; + system = "or-cluster"; + asd = "or-cluster"; + } + ); + systems = [ "or-cluster" ]; + lispLibs = [ + (getAttr "cl-opsresearch" self) + (getAttr "drakma" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + or-fann = ( + build-asdf-system { + pname = "or-fann"; + version = "20170403-git"; + asds = [ "or-fann" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opsresearch/2017-04-03/cl-opsresearch-20170403-git.tgz"; + sha256 = "1fipw6qjggswzcg8ifwx5qnhnc7mmi53s6h14l0vzj6afa5rdpm7"; + system = "or-fann"; + asd = "or-fann"; + } + ); + systems = [ "or-fann" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-opsresearch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + or-glpk = ( + build-asdf-system { + pname = "or-glpk"; + version = "20170403-git"; + asds = [ "or-glpk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opsresearch/2017-04-03/cl-opsresearch-20170403-git.tgz"; + sha256 = "1fipw6qjggswzcg8ifwx5qnhnc7mmi53s6h14l0vzj6afa5rdpm7"; + system = "or-glpk"; + asd = "or-glpk"; + } + ); + systems = [ "or-glpk" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-opsresearch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + or-gsl = ( + build-asdf-system { + pname = "or-gsl"; + version = "20170403-git"; + asds = [ "or-gsl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opsresearch/2017-04-03/cl-opsresearch-20170403-git.tgz"; + sha256 = "1fipw6qjggswzcg8ifwx5qnhnc7mmi53s6h14l0vzj6afa5rdpm7"; + system = "or-gsl"; + asd = "or-gsl"; + } + ); + systems = [ "or-gsl" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-opsresearch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + or-test = ( + build-asdf-system { + pname = "or-test"; + version = "20170403-git"; + asds = [ "or-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-opsresearch/2017-04-03/cl-opsresearch-20170403-git.tgz"; + sha256 = "1fipw6qjggswzcg8ifwx5qnhnc7mmi53s6h14l0vzj6afa5rdpm7"; + system = "or-test"; + asd = "or-test"; + } + ); + systems = [ "or-test" ]; + lispLibs = [ + (getAttr "cl-opsresearch" self) + (getAttr "fiveam" self) + (getAttr "or-fann" self) + (getAttr "or-glpk" self) + (getAttr "or-gsl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org-davep-dict = ( + build-asdf-system { + pname = "org-davep-dict"; + version = "20190521-git"; + asds = [ "org-davep-dict" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/org-davep-dict/2019-05-21/org-davep-dict-20190521-git.tgz"; + sha256 = "09dryqlprssrw0jpcg2313cc1hmlsasxvp1rs5z7axhasc16kl31"; + system = "org-davep-dict"; + asd = "org-davep-dict"; + } + ); + systems = [ "org-davep-dict" ]; + lispLibs = [ + (getAttr "acl-compat" self) + (getAttr "cl-ppcre" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org-davep-dictrepl = ( + build-asdf-system { + pname = "org-davep-dictrepl"; + version = "20190521-git"; + asds = [ "org-davep-dictrepl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/org-davep-dictrepl/2019-05-21/org-davep-dictrepl-20190521-git.tgz"; + sha256 = "1s461asil8cxsbcpyxsw3g7phdn5c3mwv6wswp86hsxiga5hi327"; + system = "org-davep-dictrepl"; + asd = "org-davep-dictrepl"; + } + ); + systems = [ "org-davep-dictrepl" ]; + lispLibs = [ (getAttr "org-davep-dict" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org-sampler = ( + build-asdf-system { + pname = "org-sampler"; + version = "0.2.0"; + asds = [ "org-sampler" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/org-sampler/2016-03-18/org-sampler-0.2.0.tgz"; + sha256 = "1j2i24x9afxp6s5gyqlvy11c0lq9rzhmdj1bf0qpxcaa4znj48c3"; + system = "org-sampler"; + asd = "org-sampler"; + } + ); + systems = [ "org-sampler" ]; + lispLibs = [ (getAttr "iterate" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_melusina_dot_atelier = ( + build-asdf-system { + pname = "org.melusina.atelier"; + version = "20241012-git"; + asds = [ "org.melusina.atelier" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-atelier/2024-10-12/cl-atelier-20241012-git.tgz"; + sha256 = "0n8v4f7xq1szxhipmkvg4x5s41vqllcq6hxzcd7r0rbxi9i57pqz"; + system = "org.melusina.atelier"; + asd = "org.melusina.atelier"; + } + ); + systems = [ "org.melusina.atelier" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "org_dot_melusina_dot_rashell" self) + (getAttr "osicat" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_melusina_dot_confidence = ( + build-asdf-system { + pname = "org.melusina.confidence"; + version = "20241012-git"; + asds = [ "org.melusina.confidence" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-confidence/2024-10-12/cl-confidence-20241012-git.tgz"; + sha256 = "1azvv54zchw88gpzh4dkflz6y0pvf7wq433yc7m90fs3c70wmsjl"; + system = "org.melusina.confidence"; + asd = "org.melusina.confidence"; + } + ); + systems = [ "org.melusina.confidence" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_melusina_dot_rashell = ( + build-asdf-system { + pname = "org.melusina.rashell"; + version = "20241012-git"; + asds = [ "org.melusina.rashell" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rashell/2024-10-12/cl-rashell-20241012-git.tgz"; + sha256 = "0fpdyhfc68xy6m0ixfvcnczlmlwasby24k47nc25x73swshlxqwq"; + system = "org.melusina.rashell"; + asd = "org.melusina.rashell"; + } + ); + systems = [ "org.melusina.rashell" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "parse-float" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_melusina_dot_webmachine = ( + build-asdf-system { + pname = "org.melusina.webmachine"; + version = "20241012-git"; + asds = [ "org.melusina.webmachine" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-webmachine/2024-10-12/cl-webmachine-20241012-git.tgz"; + sha256 = "0k31fbwsv0zdixzis625dsk9zlz04g4908wzwb8p593dksqa0sr8"; + system = "org.melusina.webmachine"; + asd = "org.melusina.webmachine"; + } + ); + systems = [ "org.melusina.webmachine" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "hunchentoot" self) + (getAttr "parse-number" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_conduit-packages = ( + build-asdf-system { + pname = "org.tfeb.conduit-packages"; + version = "20241012-git"; + asds = [ "org.tfeb.conduit-packages" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/conduit-packages/2024-10-12/conduit-packages-20241012-git.tgz"; + sha256 = "1x89maglc4cw2c87y23zrsvh8mk22ik1anmps462w3a0j3c1ly12"; + system = "org.tfeb.conduit-packages"; + asd = "org.tfeb.conduit-packages"; + } + ); + systems = [ "org.tfeb.conduit-packages" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_dsm = ( + build-asdf-system { + pname = "org.tfeb.dsm"; + version = "20241012-git"; + asds = [ "org.tfeb.dsm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/dsm/2024-10-12/dsm-20241012-git.tgz"; + sha256 = "033swj37bgbzn35fjndxqsk89i17bhsim12j8mciiziykx62c4pw"; + system = "org.tfeb.dsm"; + asd = "org.tfeb.dsm"; + } + ); + systems = [ "org.tfeb.dsm" ]; + lispLibs = [ + (getAttr "org_dot_tfeb_dot_hax_dot_collecting" self) + (getAttr "org_dot_tfeb_dot_hax_dot_iterate" self) + (getAttr "org_dot_tfeb_dot_hax_dot_simple-loops" self) + (getAttr "org_dot_tfeb_dot_hax_dot_spam" self) + (getAttr "org_dot_tfeb_dot_hax_dot_utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax = ( + build-asdf-system { + pname = "org.tfeb.hax"; + version = "20241012-git"; + asds = [ "org.tfeb.hax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax"; + asd = "org.tfeb.hax"; + } + ); + systems = [ "org.tfeb.hax" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_abstract-classes = ( + build-asdf-system { + pname = "org.tfeb.hax.abstract-classes"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.abstract-classes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.abstract-classes"; + asd = "org.tfeb.hax.abstract-classes"; + } + ); + systems = [ "org.tfeb.hax.abstract-classes" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_binding = ( + build-asdf-system { + pname = "org.tfeb.hax.binding"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.binding" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.binding"; + asd = "org.tfeb.hax.binding"; + } + ); + systems = [ "org.tfeb.hax.binding" ]; + lispLibs = [ + (getAttr "org_dot_tfeb_dot_hax_dot_collecting" self) + (getAttr "org_dot_tfeb_dot_hax_dot_iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_collecting = ( + build-asdf-system { + pname = "org.tfeb.hax.collecting"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.collecting" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.collecting"; + asd = "org.tfeb.hax.collecting"; + } + ); + systems = [ "org.tfeb.hax.collecting" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_comment-form = ( + build-asdf-system { + pname = "org.tfeb.hax.comment-form"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.comment-form" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.comment-form"; + asd = "org.tfeb.hax.comment-form"; + } + ); + systems = [ "org.tfeb.hax.comment-form" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_cs-forms = ( + build-asdf-system { + pname = "org.tfeb.hax.cs-forms"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.cs-forms" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.cs-forms"; + asd = "org.tfeb.hax.cs-forms"; + } + ); + systems = [ "org.tfeb.hax.cs-forms" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_define-functions = ( + build-asdf-system { + pname = "org.tfeb.hax.define-functions"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.define-functions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.define-functions"; + asd = "org.tfeb.hax.define-functions"; + } + ); + systems = [ "org.tfeb.hax.define-functions" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_dynamic-state = ( + build-asdf-system { + pname = "org.tfeb.hax.dynamic-state"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.dynamic-state" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.dynamic-state"; + asd = "org.tfeb.hax.dynamic-state"; + } + ); + systems = [ "org.tfeb.hax.dynamic-state" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_iterate = ( + build-asdf-system { + pname = "org.tfeb.hax.iterate"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.iterate" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.iterate"; + asd = "org.tfeb.hax.iterate"; + } + ); + systems = [ "org.tfeb.hax.iterate" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_memoize = ( + build-asdf-system { + pname = "org.tfeb.hax.memoize"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.memoize" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.memoize"; + asd = "org.tfeb.hax.memoize"; + } + ); + systems = [ "org.tfeb.hax.memoize" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_metatronic = ( + build-asdf-system { + pname = "org.tfeb.hax.metatronic"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.metatronic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.metatronic"; + asd = "org.tfeb.hax.metatronic"; + } + ); + systems = [ "org.tfeb.hax.metatronic" ]; + lispLibs = [ (getAttr "org_dot_tfeb_dot_hax_dot_utilities" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_object-accessors = ( + build-asdf-system { + pname = "org.tfeb.hax.object-accessors"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.object-accessors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.object-accessors"; + asd = "org.tfeb.hax.object-accessors"; + } + ); + systems = [ "org.tfeb.hax.object-accessors" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_read-package = ( + build-asdf-system { + pname = "org.tfeb.hax.read-package"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.read-package" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.read-package"; + asd = "org.tfeb.hax.read-package"; + } + ); + systems = [ "org.tfeb.hax.read-package" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_simple-loops = ( + build-asdf-system { + pname = "org.tfeb.hax.simple-loops"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.simple-loops" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.simple-loops"; + asd = "org.tfeb.hax.simple-loops"; + } + ); + systems = [ "org.tfeb.hax.simple-loops" ]; + lispLibs = [ + (getAttr "org_dot_tfeb_dot_hax_dot_collecting" self) + (getAttr "org_dot_tfeb_dot_hax_dot_iterate" self) + (getAttr "org_dot_tfeb_dot_hax_dot_utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_singleton-classes = ( + build-asdf-system { + pname = "org.tfeb.hax.singleton-classes"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.singleton-classes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.singleton-classes"; + asd = "org.tfeb.hax.singleton-classes"; + } + ); + systems = [ "org.tfeb.hax.singleton-classes" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_slog = ( + build-asdf-system { + pname = "org.tfeb.hax.slog"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.slog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.slog"; + asd = "org.tfeb.hax.slog"; + } + ); + systems = [ "org.tfeb.hax.slog" ]; + lispLibs = [ + (getAttr "org_dot_tfeb_dot_hax_dot_collecting" self) + (getAttr "org_dot_tfeb_dot_hax_dot_metatronic" self) + (getAttr "org_dot_tfeb_dot_hax_dot_simple-loops" self) + (getAttr "org_dot_tfeb_dot_hax_dot_spam" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_spam = ( + build-asdf-system { + pname = "org.tfeb.hax.spam"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.spam" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.spam"; + asd = "org.tfeb.hax.spam"; + } + ); + systems = [ "org.tfeb.hax.spam" ]; + lispLibs = [ (getAttr "org_dot_tfeb_dot_hax_dot_simple-loops" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_stringtable = ( + build-asdf-system { + pname = "org.tfeb.hax.stringtable"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.stringtable" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.stringtable"; + asd = "org.tfeb.hax.stringtable"; + } + ); + systems = [ "org.tfeb.hax.stringtable" ]; + lispLibs = [ + (getAttr "org_dot_tfeb_dot_hax_dot_collecting" self) + (getAttr "org_dot_tfeb_dot_hax_dot_iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_trace-macroexpand = ( + build-asdf-system { + pname = "org.tfeb.hax.trace-macroexpand"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.trace-macroexpand" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.trace-macroexpand"; + asd = "org.tfeb.hax.trace-macroexpand"; + } + ); + systems = [ "org.tfeb.hax.trace-macroexpand" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_utilities = ( + build-asdf-system { + pname = "org.tfeb.hax.utilities"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.utilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.utilities"; + asd = "org.tfeb.hax.utilities"; + } + ); + systems = [ "org.tfeb.hax.utilities" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_hax_dot_wrapping-standard = ( + build-asdf-system { + pname = "org.tfeb.hax.wrapping-standard"; + version = "20241012-git"; + asds = [ "org.tfeb.hax.wrapping-standard" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-hax/2024-10-12/tfeb-lisp-hax-20241012-git.tgz"; + sha256 = "08rrl3kihqkhxgghdvsd1304i4jcnmag5jzw15pp4rbqvsp36nfa"; + system = "org.tfeb.hax.wrapping-standard"; + asd = "org.tfeb.hax.wrapping-standard"; + } + ); + systems = [ "org.tfeb.hax.wrapping-standard" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_tools = ( + build-asdf-system { + pname = "org.tfeb.tools"; + version = "20231021-git"; + asds = [ "org.tfeb.tools" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; + sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; + system = "org.tfeb.tools"; + asd = "org.tfeb.tools"; + } + ); + systems = [ "org.tfeb.tools" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_tools_dot_asdf-module-sysdcls = ( + build-asdf-system { + pname = "org.tfeb.tools.asdf-module-sysdcls"; + version = "20231021-git"; + asds = [ "org.tfeb.tools.asdf-module-sysdcls" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; + sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; + system = "org.tfeb.tools.asdf-module-sysdcls"; + asd = "org.tfeb.tools.asdf-module-sysdcls"; + } + ); + systems = [ "org.tfeb.tools.asdf-module-sysdcls" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_tools_dot_build-modules = ( + build-asdf-system { + pname = "org.tfeb.tools.build-modules"; + version = "20231021-git"; + asds = [ "org.tfeb.tools.build-modules" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; + sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; + system = "org.tfeb.tools.build-modules"; + asd = "org.tfeb.tools.build-modules"; + } + ); + systems = [ "org.tfeb.tools.build-modules" ]; + lispLibs = [ (getAttr "org_dot_tfeb_dot_tools_dot_require-module" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_tools_dot_deprecations = ( + build-asdf-system { + pname = "org.tfeb.tools.deprecations"; + version = "20231021-git"; + asds = [ "org.tfeb.tools.deprecations" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; + sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; + system = "org.tfeb.tools.deprecations"; + asd = "org.tfeb.tools.deprecations"; + } + ); + systems = [ "org.tfeb.tools.deprecations" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_tools_dot_feature-expressions = ( + build-asdf-system { + pname = "org.tfeb.tools.feature-expressions"; + version = "20231021-git"; + asds = [ "org.tfeb.tools.feature-expressions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; + sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; + system = "org.tfeb.tools.feature-expressions"; + asd = "org.tfeb.tools.feature-expressions"; + } + ); + systems = [ "org.tfeb.tools.feature-expressions" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_tools_dot_install-providers = ( + build-asdf-system { + pname = "org.tfeb.tools.install-providers"; + version = "20231021-git"; + asds = [ "org.tfeb.tools.install-providers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; + sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; + system = "org.tfeb.tools.install-providers"; + asd = "org.tfeb.tools.install-providers"; + } + ); + systems = [ "org.tfeb.tools.install-providers" ]; + lispLibs = [ (getAttr "org_dot_tfeb_dot_tools_dot_require-module" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + org_dot_tfeb_dot_tools_dot_require-module = ( + build-asdf-system { + pname = "org.tfeb.tools.require-module"; + version = "20231021-git"; + asds = [ "org.tfeb.tools.require-module" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tfeb-lisp-tools/2023-10-21/tfeb-lisp-tools-20231021-git.tgz"; + sha256 = "180zg96ln2fp7fzdmf5yiz0dxy36r2ddq0nxl0dkmhbrn03bd4iq"; + system = "org.tfeb.tools.require-module"; + asd = "org.tfeb.tools.require-module"; + } + ); + systems = [ "org.tfeb.tools.require-module" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + origin = ( + build-asdf-system { + pname = "origin"; + version = "20220707-git"; + asds = [ "origin" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/origin/2022-07-07/origin-20220707-git.tgz"; + sha256 = "01b5rn83w85fnd92x5jgan2a092y7ir420r55p2b0a98xpvb4a71"; + system = "origin"; + asd = "origin"; + } + ); + systems = [ "origin" ]; + lispLibs = [ (getAttr "mfiano-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + origin_dot_test = ( + build-asdf-system { + pname = "origin.test"; + version = "20220707-git"; + asds = [ "origin.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/origin/2022-07-07/origin-20220707-git.tgz"; + sha256 = "01b5rn83w85fnd92x5jgan2a092y7ir420r55p2b0a98xpvb4a71"; + system = "origin.test"; + asd = "origin.test"; + } + ); + systems = [ "origin.test" ]; + lispLibs = [ + (getAttr "origin" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + orizuru-orm = ( + build-asdf-system { + pname = "orizuru-orm"; + version = "20241012-git"; + asds = [ "orizuru-orm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/orizuru-orm/2024-10-12/orizuru-orm-20241012-git.tgz"; + sha256 = "064sr0nxz884vrh550d8v3v9pqgs65d97lrr3828qn6bgaxwm1va"; + system = "orizuru-orm"; + asd = "orizuru-orm"; + } + ); + systems = [ "orizuru-orm" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre-unicode" self) + (getAttr "clos-fixtures" self) + (getAttr "closer-mop" self) + (getAttr "clunit2" self) + (getAttr "dbi" self) + (getAttr "iterate" self) + (getAttr "local-time" self) + (getAttr "sxql" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + osc = ( + build-asdf-system { + pname = "osc"; + version = "20230618-git"; + asds = [ "osc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/osc/2023-06-18/osc-20230618-git.tgz"; + sha256 = "0gh29zcl9pmy3xlmwzpf9www2z06ah6b4jk06sj2cvxbc15nblqa"; + system = "osc"; + asd = "osc"; + } + ); + systems = [ "osc" ]; + lispLibs = [ (getAttr "usocket" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + osicat = ( + build-asdf-system { + pname = "osicat"; + version = "20231021-git"; + asds = [ "osicat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/osicat/2023-10-21/osicat-20231021-git.tgz"; + sha256 = "10q1dfkhrvp5ia860q10y4wdm11fmxf7xv8zl4viz2np9xzf5v22"; + system = "osicat"; + asd = "osicat"; + } + ); + systems = [ "osicat" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "trivial-features" self) + ]; + meta = { }; + } + ); + ospm = ( + build-asdf-system { + pname = "ospm"; + version = "20231021-git"; + asds = [ "ospm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ospm/2023-10-21/ospm-20231021-git.tgz"; + sha256 = "1z2wz2xg7rn7p1lladdhj789iz2f3wfjgpi2hjr08vkf1pkp15xf"; + system = "ospm"; + asd = "ospm"; + } + ); + systems = [ "ospm" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "calispel" self) + (getAttr "hu_dot_dwim_dot_defclass-star" self) + (getAttr "local-time" self) + (getAttr "moptilities" self) + (getAttr "named-readtables" self) + (getAttr "serapeum" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + overlord = ( + build-asdf-system { + pname = "overlord"; + version = "20241012-git"; + asds = [ "overlord" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/overlord/2024-10-12/overlord-20241012-git.tgz"; + sha256 = "1afhqx6wdqdah1fpapvr6zxpzkkqmhbrxkqxam523fqjyg4a6941"; + system = "overlord"; + asd = "overlord"; + } + ); + systems = [ "overlord" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "bit-smasher" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-murmurhash" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-strftime" self) + (getAttr "cmd" self) + (getAttr "exit-hooks" self) + (getAttr "fset" self) + (getAttr "global-vars" self) + (getAttr "local-time" self) + (getAttr "lparallel" self) + (getAttr "named-readtables" self) + (getAttr "quickproject" self) + (getAttr "serapeum" self) + (getAttr "trivia" self) + (getAttr "trivial-file-size" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + oxenfurt = ( + build-asdf-system { + pname = "oxenfurt"; + version = "20231021-git"; + asds = [ "oxenfurt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/oxenfurt/2023-10-21/oxenfurt-20231021-git.tgz"; + sha256 = "1yqw21l19091aghvnfpdp62zs8scspaas4syn2yajm1b55jzxvya"; + system = "oxenfurt"; + asd = "oxenfurt"; + } + ); + systems = [ "oxenfurt" ]; + lispLibs = [ (getAttr "oxenfurt-dexador" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + oxenfurt-core = ( + build-asdf-system { + pname = "oxenfurt-core"; + version = "20231021-git"; + asds = [ "oxenfurt-core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/oxenfurt/2023-10-21/oxenfurt-20231021-git.tgz"; + sha256 = "1yqw21l19091aghvnfpdp62zs8scspaas4syn2yajm1b55jzxvya"; + system = "oxenfurt-core"; + asd = "oxenfurt-core"; + } + ); + systems = [ "oxenfurt-core" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "documentation-utils" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + oxenfurt-dexador = ( + build-asdf-system { + pname = "oxenfurt-dexador"; + version = "20231021-git"; + asds = [ "oxenfurt-dexador" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/oxenfurt/2023-10-21/oxenfurt-20231021-git.tgz"; + sha256 = "1yqw21l19091aghvnfpdp62zs8scspaas4syn2yajm1b55jzxvya"; + system = "oxenfurt-dexador"; + asd = "oxenfurt-dexador"; + } + ); + systems = [ "oxenfurt-dexador" ]; + lispLibs = [ + (getAttr "dexador" self) + (getAttr "oxenfurt-core" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + oxenfurt-drakma = ( + build-asdf-system { + pname = "oxenfurt-drakma"; + version = "20231021-git"; + asds = [ "oxenfurt-drakma" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/oxenfurt/2023-10-21/oxenfurt-20231021-git.tgz"; + sha256 = "1yqw21l19091aghvnfpdp62zs8scspaas4syn2yajm1b55jzxvya"; + system = "oxenfurt-drakma"; + asd = "oxenfurt-drakma"; + } + ); + systems = [ "oxenfurt-drakma" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "oxenfurt-core" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pack = ( + build-asdf-system { + pname = "pack"; + version = "20110619-git"; + asds = [ "pack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pack/2011-06-19/pack-20110619-git.tgz"; + sha256 = "1b3qi04v1wj9nig0mx591sl4phqcalwdl0vsnf4kqp4d2qx2czi1"; + system = "pack"; + asd = "pack"; + } + ); + systems = [ "pack" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "ieee-floats" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + package-renaming = ( + build-asdf-system { + pname = "package-renaming"; + version = "20120407-git"; + asds = [ "package-renaming" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/package-renaming/2012-04-07/package-renaming-20120407-git.tgz"; + sha256 = "15kgd15r9bib8wfnn3hmv42rlifr4ph3rv2mji5i9d5ixhyqqwgq"; + system = "package-renaming"; + asd = "package-renaming"; + } + ); + systems = [ "package-renaming" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + package-renaming-test = ( + build-asdf-system { + pname = "package-renaming-test"; + version = "20120407-git"; + asds = [ "package-renaming-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/package-renaming/2012-04-07/package-renaming-20120407-git.tgz"; + sha256 = "15kgd15r9bib8wfnn3hmv42rlifr4ph3rv2mji5i9d5ixhyqqwgq"; + system = "package-renaming-test"; + asd = "package-renaming-test"; + } + ); + systems = [ "package-renaming-test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_stefil" self) + (getAttr "package-renaming" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + packet = ( + build-asdf-system { + pname = "packet"; + version = "20150302-git"; + asds = [ "packet" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/packet/2015-03-02/packet-20150302-git.tgz"; + sha256 = "1vcmxwrliwczz161nz3ysx9cbfia4cmlqgnjgrx5016lp394pnx1"; + system = "packet"; + asd = "packet"; + } + ); + systems = [ "packet" ]; + lispLibs = [ (getAttr "ieee-floats" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + packet-crafting = ( + build-asdf-system { + pname = "packet-crafting"; + version = "20200610-git"; + asds = [ "packet-crafting" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/packet-crafting/2020-06-10/packet-crafting-20200610-git.tgz"; + sha256 = "1ivnvkbqckqf5hm6khffc2wkbjl64fn03w9i0kypkb0mrazxdpdq"; + system = "packet-crafting"; + asd = "packet-crafting"; + } + ); + systems = [ "packet-crafting" ]; + lispLibs = [ (getAttr "lisp-binary" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + paiprolog = ( + build-asdf-system { + pname = "paiprolog"; + version = "20180228-git"; + asds = [ "paiprolog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/paiprolog/2018-02-28/paiprolog-20180228-git.tgz"; + sha256 = "1nxz01i6f8s920gm69r2kwjdpq9pli8b2ayqwijhzgjwi0r4jj9r"; + system = "paiprolog"; + asd = "paiprolog"; + } + ); + systems = [ "paiprolog" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pal = ( + build-asdf-system { + pname = "pal"; + version = "20150608-git"; + asds = [ "pal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pal/2015-06-08/pal-20150608-git.tgz"; + sha256 = "0kn6jxirrn7wzqymzsi0kx2ivl0nrrcgbl4dm1714s48qw0jwhcw"; + system = "pal"; + asd = "pal"; + } + ); + systems = [ "pal" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pandocl = ( + build-asdf-system { + pname = "pandocl"; + version = "20150923-git"; + asds = [ "pandocl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pandocl/2015-09-23/pandocl-20150923-git.tgz"; + sha256 = "1fmlpx5m7ivdkqss1fa3xqbpcwzqrpyyx2nny12aqxn8f13vpvmg"; + system = "pandocl"; + asd = "pandocl"; + } + ); + systems = [ "pandocl" ]; + lispLibs = [ + (getAttr "common-doc" self) + (getAttr "common-doc-contrib" self) + (getAttr "common-html" self) + (getAttr "parenml" self) + (getAttr "scriba" self) + (getAttr "thorn" self) + (getAttr "vertex" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pango-markup = ( + build-asdf-system { + pname = "pango-markup"; + version = "20231021-git"; + asds = [ "pango-markup" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pango-markup/2023-10-21/pango-markup-20231021-git.tgz"; + sha256 = "1165z3ycbkgr9g3ni1z59r258c1jd2viyf3mj8a5p72kx6dqb8gf"; + system = "pango-markup"; + asd = "pango-markup"; + } + ); + systems = [ "pango-markup" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + papyrus = ( + build-asdf-system { + pname = "papyrus"; + version = "20241012-git"; + asds = [ "papyrus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/papyrus/2024-10-12/papyrus-20241012-git.tgz"; + sha256 = "0cnhdl2x5vs91srlfjnaznwj5vrg6qlyn2xjbyy40p8yvr5pny88"; + system = "papyrus"; + asd = "papyrus"; + } + ); + systems = [ "papyrus" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parachute = ( + build-asdf-system { + pname = "parachute"; + version = "20241012-git"; + asds = [ "parachute" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parachute/2024-10-12/parachute-20241012-git.tgz"; + sha256 = "1hghjrv5d5w9nz27lhwz8vvbdcjl2skm76r8adpzmi7s1f9ww121"; + system = "parachute"; + asd = "parachute"; + } + ); + systems = [ "parachute" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "form-fiddle" self) + (getAttr "trivial-custom-debugger" self) + ]; + meta = { }; + } + ); + parachute-fiveam = ( + build-asdf-system { + pname = "parachute-fiveam"; + version = "20241012-git"; + asds = [ "parachute-fiveam" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parachute/2024-10-12/parachute-20241012-git.tgz"; + sha256 = "1hghjrv5d5w9nz27lhwz8vvbdcjl2skm76r8adpzmi7s1f9ww121"; + system = "parachute-fiveam"; + asd = "parachute-fiveam"; + } + ); + systems = [ "parachute-fiveam" ]; + lispLibs = [ (getAttr "parachute" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parachute-lisp-unit = ( + build-asdf-system { + pname = "parachute-lisp-unit"; + version = "20241012-git"; + asds = [ "parachute-lisp-unit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parachute/2024-10-12/parachute-20241012-git.tgz"; + sha256 = "1hghjrv5d5w9nz27lhwz8vvbdcjl2skm76r8adpzmi7s1f9ww121"; + system = "parachute-lisp-unit"; + asd = "parachute-lisp-unit"; + } + ); + systems = [ "parachute-lisp-unit" ]; + lispLibs = [ (getAttr "parachute" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parachute-prove = ( + build-asdf-system { + pname = "parachute-prove"; + version = "20241012-git"; + asds = [ "parachute-prove" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parachute/2024-10-12/parachute-20241012-git.tgz"; + sha256 = "1hghjrv5d5w9nz27lhwz8vvbdcjl2skm76r8adpzmi7s1f9ww121"; + system = "parachute-prove"; + asd = "parachute-prove"; + } + ); + systems = [ "parachute-prove" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "parachute" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parameterized-function = ( + build-asdf-system { + pname = "parameterized-function"; + version = "20230618-git"; + asds = [ "parameterized-function" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parameterized-function/2023-06-18/parameterized-function-20230618-git.tgz"; + sha256 = "0pjdk4il83izd4iiavg6z7ighmjfmg39j8gp82qq2kikzlmklxxf"; + system = "parameterized-function"; + asd = "parameterized-function"; + } + ); + systems = [ "parameterized-function" ]; + lispLibs = [ (getAttr "interface" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + paren-files = ( + build-asdf-system { + pname = "paren-files"; + version = "20110418-git"; + asds = [ "paren-files" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/paren-files/2011-04-18/paren-files-20110418-git.tgz"; + sha256 = "19lwzvdn9gpn28x6ismkwzs49vr4cbc6drsivkmll3dxb950wgw9"; + system = "paren-files"; + asd = "paren-files"; + } + ); + systems = [ "paren-files" ]; + lispLibs = [ (getAttr "parenscript" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + paren-test = ( + build-asdf-system { + pname = "paren-test"; + version = "20170830-git"; + asds = [ "paren-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/paren-test/2017-08-30/paren-test-20170830-git.tgz"; + sha256 = "0b2d3kcv3n4b0dm67pzhxx8wxjsgnb32bw2dsprblc7149gaczdr"; + system = "paren-test"; + asd = "paren-test"; + } + ); + systems = [ "paren-test" ]; + lispLibs = [ + (getAttr "paren-files" self) + (getAttr "parenscript" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + paren-util = ( + build-asdf-system { + pname = "paren-util"; + version = "20110418-git"; + asds = [ "paren-util" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/paren-util/2011-04-18/paren-util-20110418-git.tgz"; + sha256 = "0jn7sgndhpn9ndn3xfmsp03alj2qksqz6p1c5h6x8hvi46caqvpy"; + system = "paren-util"; + asd = "paren-util"; + } + ); + systems = [ "paren-util" ]; + lispLibs = [ + (getAttr "paren-files" self) + (getAttr "parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + paren6 = ( + build-asdf-system { + pname = "paren6"; + version = "20220331-git"; + asds = [ "paren6" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/paren6/2022-03-31/paren6-20220331-git.tgz"; + sha256 = "0m7z7zkc1vrwmp68f3yx0mdsb0j45dmw3iddnbvf94dpv8aywwpx"; + system = "paren6"; + asd = "paren6"; + } + ); + systems = [ "paren6" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parenml = ( + build-asdf-system { + pname = "parenml"; + version = "20150923-git"; + asds = [ "parenml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parenml/2015-09-23/parenml-20150923-git.tgz"; + sha256 = "0g6s5phinpcfhixgsfqniwxd3kd4bwh78s90ixs2fwk3qjhh9zsb"; + system = "parenml"; + asd = "parenml"; + } + ); + systems = [ "parenml" ]; + lispLibs = [ + (getAttr "common-doc-plump" self) + (getAttr "esrap" self) + (getAttr "plump" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parenml-test = ( + build-asdf-system { + pname = "parenml-test"; + version = "20150923-git"; + asds = [ "parenml-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parenml/2015-09-23/parenml-20150923-git.tgz"; + sha256 = "0g6s5phinpcfhixgsfqniwxd3kd4bwh78s90ixs2fwk3qjhh9zsb"; + system = "parenml-test"; + asd = "parenml-test"; + } + ); + systems = [ "parenml-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "parenml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parenscript = ( + build-asdf-system { + pname = "parenscript"; + version = "Parenscript-2.7.1"; + asds = [ "parenscript" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parenscript/2018-12-10/Parenscript-2.7.1.tgz"; + sha256 = "0vg9b9j5psil5iba1d9k6vfxl5rn133qvy750dny20qkp9mf3a13"; + system = "parenscript"; + asd = "parenscript"; + } + ); + systems = [ "parenscript" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "cl-ppcre" self) + (getAttr "named-readtables" self) + ]; + meta = { }; + } + ); + parenscript-classic = ( + build-asdf-system { + pname = "parenscript-classic"; + version = "20111203-darcs"; + asds = [ "parenscript-classic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parenscript-classic/2011-12-03/parenscript-classic-20111203-darcs.tgz"; + sha256 = "19zsiyjlz938la2dd39cy6lwh95m10j4nx8837xm6qk8rz5f8dgy"; + system = "parenscript-classic"; + asd = "parenscript-classic"; + } + ); + systems = [ "parenscript-classic" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parenscript_dot_tests = ( + build-asdf-system { + pname = "parenscript.tests"; + version = "Parenscript-2.7.1"; + asds = [ "parenscript.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parenscript/2018-12-10/Parenscript-2.7.1.tgz"; + sha256 = "0vg9b9j5psil5iba1d9k6vfxl5rn133qvy750dny20qkp9mf3a13"; + system = "parenscript.tests"; + asd = "parenscript.tests"; + } + ); + systems = [ "parenscript.tests" ]; + lispLibs = [ + (getAttr "cl-js" self) + (getAttr "fiveam" self) + (getAttr "parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parse = ( + build-asdf-system { + pname = "parse"; + version = "20200925-git"; + asds = [ "parse" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parse/2020-09-25/parse-20200925-git.tgz"; + sha256 = "0l18yabyh7jizm5lgvra0jxi8s1cfwghidi6ix1pyixjkdbjlmvy"; + system = "parse"; + asd = "parse"; + } + ); + systems = [ "parse" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parse-declarations-1_dot_0 = ( + build-asdf-system { + pname = "parse-declarations-1.0"; + version = "20101006-darcs"; + asds = [ "parse-declarations-1.0" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parse-declarations/2010-10-06/parse-declarations-20101006-darcs.tgz"; + sha256 = "04l3s180wxq6xyhgd77mbd03a1w1m0j9snag961g2f9dd77w6q1r"; + system = "parse-declarations-1.0"; + asd = "parse-declarations-1.0"; + } + ); + systems = [ "parse-declarations-1.0" ]; + lispLibs = [ ]; + meta = { }; + } + ); + parse-float = ( + build-asdf-system { + pname = "parse-float"; + version = "20200218-git"; + asds = [ "parse-float" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parse-float/2020-02-18/parse-float-20200218-git.tgz"; + sha256 = "0jd2spawc3v8vzqf8ky4cngl45jm65fhkrdf20mf6dcbn3mzpkmr"; + system = "parse-float"; + asd = "parse-float"; + } + ); + systems = [ "parse-float" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { }; + } + ); + parse-float-tests = ( + build-asdf-system { + pname = "parse-float-tests"; + version = "20200218-git"; + asds = [ "parse-float-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parse-float/2020-02-18/parse-float-20200218-git.tgz"; + sha256 = "0jd2spawc3v8vzqf8ky4cngl45jm65fhkrdf20mf6dcbn3mzpkmr"; + system = "parse-float-tests"; + asd = "parse-float"; + } + ); + systems = [ "parse-float-tests" ]; + lispLibs = [ + (getAttr "lisp-unit" self) + (getAttr "parse-float" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parse-front-matter = ( + build-asdf-system { + pname = "parse-front-matter"; + version = "20160825-git"; + asds = [ "parse-front-matter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parse-front-matter/2016-08-25/parse-front-matter-20160825-git.tgz"; + sha256 = "1yzadrjwycvyzlzb0mixxmwi5bjzkjwylnv3aslnr1j14q44vq58"; + system = "parse-front-matter"; + asd = "parse-front-matter"; + } + ); + systems = [ "parse-front-matter" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parse-front-matter-test = ( + build-asdf-system { + pname = "parse-front-matter-test"; + version = "20160825-git"; + asds = [ "parse-front-matter-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parse-front-matter/2016-08-25/parse-front-matter-20160825-git.tgz"; + sha256 = "1yzadrjwycvyzlzb0mixxmwi5bjzkjwylnv3aslnr1j14q44vq58"; + system = "parse-front-matter-test"; + asd = "parse-front-matter-test"; + } + ); + systems = [ "parse-front-matter-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "parse-front-matter" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parse-js = ( + build-asdf-system { + pname = "parse-js"; + version = "20160421-git"; + asds = [ "parse-js" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parse-js/2016-04-21/parse-js-20160421-git.tgz"; + sha256 = "1wddrnr5kiya5s3gp4cdq6crbfy9fqcz7fr44p81502sj3bvdv39"; + system = "parse-js"; + asd = "parse-js"; + } + ); + systems = [ "parse-js" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parse-number = ( + build-asdf-system { + pname = "parse-number"; + version = "v1.8"; + asds = [ "parse-number" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parse-number/2024-10-12/parse-number-v1.8.tgz"; + sha256 = "1yh54v02i9b55bmkfkz59qd14irw8llasp48drbilkbz1az1qg2p"; + system = "parse-number"; + asd = "parse-number"; + } + ); + systems = [ "parse-number" ]; + lispLibs = [ ]; + meta = { }; + } + ); + parse-number-range = ( + build-asdf-system { + pname = "parse-number-range"; + version = "1.0.1"; + asds = [ "parse-number-range" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parse-number-range/2024-10-12/parse-number-range_1.0.1.tgz"; + sha256 = "1kd0l3bcywhwmnjil0zzvq4cjlhpj2g1wiy7h7860nflzfz7qvds"; + system = "parse-number-range"; + asd = "parse-number-range"; + } + ); + systems = [ "parse-number-range" ]; + lispLibs = [ + (getAttr "cartesian-product-switch" self) + (getAttr "enhanced-multiple-value-bind" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parse-number-range__tests = ( + build-asdf-system { + pname = "parse-number-range_tests"; + version = "1.0.1"; + asds = [ "parse-number-range_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parse-number-range/2024-10-12/parse-number-range_1.0.1.tgz"; + sha256 = "1kd0l3bcywhwmnjil0zzvq4cjlhpj2g1wiy7h7860nflzfz7qvds"; + system = "parse-number-range_tests"; + asd = "parse-number-range_tests"; + } + ); + systems = [ "parse-number-range_tests" ]; + lispLibs = [ + (getAttr "parachute" self) + (getAttr "parse-number-range" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parse-rgb = ( + build-asdf-system { + pname = "parse-rgb"; + version = "20231021-git"; + asds = [ "parse-rgb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tcod/2023-10-21/cl-tcod-20231021-git.tgz"; + sha256 = "1r4ip16dlzr56p94b0grw6nmkykbmgb04jsqdvgl1ypcmbpfr3i1"; + system = "parse-rgb"; + asd = "parse-rgb"; + } + ); + systems = [ "parse-rgb" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "tcod" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parseltongue = ( + build-asdf-system { + pname = "parseltongue"; + version = "20130312-git"; + asds = [ "parseltongue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parseltongue/2013-03-12/parseltongue-20130312-git.tgz"; + sha256 = "1cjy7p0snms604zp6x0jlm4v9divqc5r38ns737hffj9q6pi1nlx"; + system = "parseltongue"; + asd = "parseltongue"; + } + ); + systems = [ "parseltongue" ]; + lispLibs = [ (getAttr "lisp-unit" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parseq = ( + build-asdf-system { + pname = "parseq"; + version = "20231021-git"; + asds = [ "parseq" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parseq/2023-10-21/parseq-20231021-git.tgz"; + sha256 = "13bdv9slnkf4b3py5dfvdnxvyb7zxwf2apcbr2p3s7ij26qslbbw"; + system = "parseq"; + asd = "parseq"; + } + ); + systems = [ "parseq" ]; + lispLibs = [ ]; + meta = { }; + } + ); + parser-combinators = ( + build-asdf-system { + pname = "parser-combinators"; + version = "20131111-git"; + asds = [ "parser-combinators" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-parser-combinators/2013-11-11/cl-parser-combinators-20131111-git.tgz"; + sha256 = "1k49vha5xm2cklayzpqwg73n4v93xwsbs5in6342pkkiimnidhs8"; + system = "parser-combinators"; + asd = "parser-combinators"; + } + ); + systems = [ "parser-combinators" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + ]; + meta = { }; + } + ); + parser-combinators-cl-ppcre = ( + build-asdf-system { + pname = "parser-combinators-cl-ppcre"; + version = "20131111-git"; + asds = [ "parser-combinators-cl-ppcre" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-parser-combinators/2013-11-11/cl-parser-combinators-20131111-git.tgz"; + sha256 = "1k49vha5xm2cklayzpqwg73n4v93xwsbs5in6342pkkiimnidhs8"; + system = "parser-combinators-cl-ppcre"; + asd = "parser-combinators-cl-ppcre"; + } + ); + systems = [ "parser-combinators-cl-ppcre" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "iterate" self) + (getAttr "parser-combinators" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parser-combinators-debug = ( + build-asdf-system { + pname = "parser-combinators-debug"; + version = "20131111-git"; + asds = [ "parser-combinators-debug" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-parser-combinators/2013-11-11/cl-parser-combinators-20131111-git.tgz"; + sha256 = "1k49vha5xm2cklayzpqwg73n4v93xwsbs5in6342pkkiimnidhs8"; + system = "parser-combinators-debug"; + asd = "parser-combinators-debug"; + } + ); + systems = [ "parser-combinators-debug" ]; + lispLibs = [ + (getAttr "cl-containers" self) + (getAttr "parser-combinators" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parser-combinators-tests = ( + build-asdf-system { + pname = "parser-combinators-tests"; + version = "20131111-git"; + asds = [ "parser-combinators-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-parser-combinators/2013-11-11/cl-parser-combinators-20131111-git.tgz"; + sha256 = "1k49vha5xm2cklayzpqwg73n4v93xwsbs5in6342pkkiimnidhs8"; + system = "parser-combinators-tests"; + asd = "parser-combinators-tests"; + } + ); + systems = [ "parser-combinators-tests" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + (getAttr "infix" self) + (getAttr "iterate" self) + (getAttr "parser-combinators" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parser_dot_common-rules = ( + build-asdf-system { + pname = "parser.common-rules"; + version = "20200715-git"; + asds = [ "parser.common-rules" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parser.common-rules/2020-07-15/parser.common-rules-20200715-git.tgz"; + sha256 = "138ygj0qp58jl4h79szg3i2gnwzywwc48qn1gj6dw113wasrnkwa"; + system = "parser.common-rules"; + asd = "parser.common-rules"; + } + ); + systems = [ "parser.common-rules" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "esrap" self) + (getAttr "let-plus" self) + (getAttr "split-sequence" self) + ]; + meta = { }; + } + ); + parser_dot_common-rules_dot_operators = ( + build-asdf-system { + pname = "parser.common-rules.operators"; + version = "20200715-git"; + asds = [ "parser.common-rules.operators" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parser.common-rules/2020-07-15/parser.common-rules-20200715-git.tgz"; + sha256 = "138ygj0qp58jl4h79szg3i2gnwzywwc48qn1gj6dw113wasrnkwa"; + system = "parser.common-rules.operators"; + asd = "parser.common-rules.operators"; + } + ); + systems = [ "parser.common-rules.operators" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "architecture_dot_builder-protocol" self) + (getAttr "esrap" self) + (getAttr "let-plus" self) + (getAttr "parser_dot_common-rules" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parser_dot_ini = ( + build-asdf-system { + pname = "parser.ini"; + version = "20181018-git"; + asds = [ "parser.ini" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parser.ini/2018-10-18/parser.ini-20181018-git.tgz"; + sha256 = "0ri4c7877i9val67z5sm8nfhz04p9l6brajx2fkavs8556l1wm1d"; + system = "parser.ini"; + asd = "parser.ini"; + } + ); + systems = [ "parser.ini" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "architecture_dot_builder-protocol" self) + (getAttr "esrap" self) + (getAttr "let-plus" self) + (getAttr "more-conditions" self) + (getAttr "parser_dot_common-rules" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + parsnip = ( + build-asdf-system { + pname = "parsnip"; + version = "20220331-git"; + asds = [ "parsnip" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/parsnip/2022-03-31/parsnip-20220331-git.tgz"; + sha256 = "0gl7z8kn37qiz0vab89wawn78iczii7iqw43jy2ls7nw0l5jv13w"; + system = "parsnip"; + asd = "parsnip"; + } + ); + systems = [ "parsnip" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + patchwork = ( + build-asdf-system { + pname = "patchwork"; + version = "20220707-git"; + asds = [ "patchwork" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/patchwork/2022-07-07/patchwork-20220707-git.tgz"; + sha256 = "08d08hslcs69509wj56mlklv1cz5lq2rz0sl870zcxyn4j1nnf3f"; + system = "patchwork"; + asd = "patchwork"; + } + ); + systems = [ "patchwork" ]; + lispLibs = [ + (getAttr "binpack" self) + (getAttr "mfiano-utils" self) + (getAttr "opticl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + path-parse = ( + build-asdf-system { + pname = "path-parse"; + version = "20160421-git"; + asds = [ "path-parse" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/path-parse/2016-04-21/path-parse-20160421-git.tgz"; + sha256 = "10mxm6q62cfpv3hw2w8k968ba8a1xglqdkwlkqs4l4nby3b11aaq"; + system = "path-parse"; + asd = "path-parse"; + } + ); + systems = [ "path-parse" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + path-parse-test = ( + build-asdf-system { + pname = "path-parse-test"; + version = "20160421-git"; + asds = [ "path-parse-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/path-parse/2016-04-21/path-parse-20160421-git.tgz"; + sha256 = "10mxm6q62cfpv3hw2w8k968ba8a1xglqdkwlkqs4l4nby3b11aaq"; + system = "path-parse-test"; + asd = "path-parse-test"; + } + ); + systems = [ "path-parse-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "path-parse" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + path-string = ( + build-asdf-system { + pname = "path-string"; + version = "20160825-git"; + asds = [ "path-string" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/path-string/2016-08-25/path-string-20160825-git.tgz"; + sha256 = "0hs36kf4njxafxrngs1m1sh9c7b9wv7sa8n316dq4icx3kf3v6yp"; + system = "path-string"; + asd = "path-string"; + } + ); + systems = [ "path-string" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + path-string-test = ( + build-asdf-system { + pname = "path-string-test"; + version = "20160825-git"; + asds = [ "path-string-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/path-string/2016-08-25/path-string-20160825-git.tgz"; + sha256 = "0hs36kf4njxafxrngs1m1sh9c7b9wv7sa8n316dq4icx3kf3v6yp"; + system = "path-string-test"; + asd = "path-string-test"; + } + ); + systems = [ "path-string-test" ]; + lispLibs = [ + (getAttr "path-string" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pathname-utils = ( + build-asdf-system { + pname = "pathname-utils"; + version = "20241012-git"; + asds = [ "pathname-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pathname-utils/2024-10-12/pathname-utils-20241012-git.tgz"; + sha256 = "1z1z3dar6g2ybxgk9zgcyb8bh5g6rh12bwl3ik6rdwy3rdd5b1q5"; + system = "pathname-utils"; + asd = "pathname-utils"; + } + ); + systems = [ "pathname-utils" ]; + lispLibs = [ (getAttr "trivial-features" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pathname-utils-test = ( + build-asdf-system { + pname = "pathname-utils-test"; + version = "20241012-git"; + asds = [ "pathname-utils-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pathname-utils/2024-10-12/pathname-utils-20241012-git.tgz"; + sha256 = "1z1z3dar6g2ybxgk9zgcyb8bh5g6rh12bwl3ik6rdwy3rdd5b1q5"; + system = "pathname-utils-test"; + asd = "pathname-utils-test"; + } + ); + systems = [ "pathname-utils-test" ]; + lispLibs = [ + (getAttr "parachute" self) + (getAttr "pathname-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + patron = ( + build-asdf-system { + pname = "patron"; + version = "20130420-git"; + asds = [ "patron" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/patron/2013-04-20/patron-20130420-git.tgz"; + sha256 = "0i2vlwspnssjxdnq7dsrb98q3y8c8drd0a11nxn9808q76sqzsqc"; + system = "patron"; + asd = "patron"; + } + ); + systems = [ "patron" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcall = ( + build-asdf-system { + pname = "pcall"; + version = "0.3"; + asds = [ "pcall" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pcall/2010-10-06/pcall-0.3.tgz"; + sha256 = "00ix5d9ljymrrpwsri0hhh3d592jqr2lvgbvkhav3k96rwq974ps"; + system = "pcall"; + asd = "pcall"; + } + ); + systems = [ "pcall" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "pcall-queue" self) + ]; + meta = { }; + } + ); + pcall-queue = ( + build-asdf-system { + pname = "pcall-queue"; + version = "0.3"; + asds = [ "pcall-queue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pcall/2010-10-06/pcall-0.3.tgz"; + sha256 = "00ix5d9ljymrrpwsri0hhh3d592jqr2lvgbvkhav3k96rwq974ps"; + system = "pcall-queue"; + asd = "pcall-queue"; + } + ); + systems = [ "pcall-queue" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { }; + } + ); + pcall-tests = ( + build-asdf-system { + pname = "pcall-tests"; + version = "0.3"; + asds = [ "pcall-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pcall/2010-10-06/pcall-0.3.tgz"; + sha256 = "00ix5d9ljymrrpwsri0hhh3d592jqr2lvgbvkhav3k96rwq974ps"; + system = "pcall-tests"; + asd = "pcall"; + } + ); + systems = [ "pcall-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "pcall" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-binary-data = ( + build-asdf-system { + pname = "pcl-binary-data"; + version = "20180430-git"; + asds = [ "pcl-binary-data" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "pcl-binary-data"; + asd = "pcl-binary-data"; + } + ); + systems = [ "pcl-binary-data" ]; + lispLibs = [ (getAttr "pcl-macro-utilities" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-html = ( + build-asdf-system { + pname = "pcl-html"; + version = "20180430-git"; + asds = [ "pcl-html" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "pcl-html"; + asd = "pcl-html"; + } + ); + systems = [ "pcl-html" ]; + lispLibs = [ (getAttr "pcl-macro-utilities" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-id3v2 = ( + build-asdf-system { + pname = "pcl-id3v2"; + version = "20180430-git"; + asds = [ "pcl-id3v2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "pcl-id3v2"; + asd = "pcl-id3v2"; + } + ); + systems = [ "pcl-id3v2" ]; + lispLibs = [ + (getAttr "pcl-binary-data" self) + (getAttr "pcl-pathnames" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-macro-utilities = ( + build-asdf-system { + pname = "pcl-macro-utilities"; + version = "20180430-git"; + asds = [ "pcl-macro-utilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "pcl-macro-utilities"; + asd = "pcl-macro-utilities"; + } + ); + systems = [ "pcl-macro-utilities" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-mp3-browser = ( + build-asdf-system { + pname = "pcl-mp3-browser"; + version = "20180430-git"; + asds = [ "pcl-mp3-browser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "pcl-mp3-browser"; + asd = "pcl-mp3-browser"; + } + ); + systems = [ "pcl-mp3-browser" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "pcl-html" self) + (getAttr "pcl-id3v2" self) + (getAttr "pcl-mp3-database" self) + (getAttr "pcl-shoutcast" self) + (getAttr "pcl-url-function" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-mp3-database = ( + build-asdf-system { + pname = "pcl-mp3-database"; + version = "20180430-git"; + asds = [ "pcl-mp3-database" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "pcl-mp3-database"; + asd = "pcl-mp3-database"; + } + ); + systems = [ "pcl-mp3-database" ]; + lispLibs = [ + (getAttr "pcl-id3v2" self) + (getAttr "pcl-macro-utilities" self) + (getAttr "pcl-pathnames" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-pathnames = ( + build-asdf-system { + pname = "pcl-pathnames"; + version = "20180430-git"; + asds = [ "pcl-pathnames" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "pcl-pathnames"; + asd = "pcl-pathnames"; + } + ); + systems = [ "pcl-pathnames" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-shoutcast = ( + build-asdf-system { + pname = "pcl-shoutcast"; + version = "20180430-git"; + asds = [ "pcl-shoutcast" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "pcl-shoutcast"; + asd = "pcl-shoutcast"; + } + ); + systems = [ "pcl-shoutcast" ]; + lispLibs = [ + (getAttr "pcl-html" self) + (getAttr "pcl-id3v2" self) + (getAttr "pcl-macro-utilities" self) + (getAttr "pcl-mp3-database" self) + (getAttr "pcl-pathnames" self) + (getAttr "pcl-url-function" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-simple-database = ( + build-asdf-system { + pname = "pcl-simple-database"; + version = "20180430-git"; + asds = [ "pcl-simple-database" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "pcl-simple-database"; + asd = "pcl-simple-database"; + } + ); + systems = [ "pcl-simple-database" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-spam = ( + build-asdf-system { + pname = "pcl-spam"; + version = "20180430-git"; + asds = [ "pcl-spam" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "pcl-spam"; + asd = "pcl-spam"; + } + ); + systems = [ "pcl-spam" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "pcl-pathnames" self) + (getAttr "pcl-test-framework" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-test-framework = ( + build-asdf-system { + pname = "pcl-test-framework"; + version = "20180430-git"; + asds = [ "pcl-test-framework" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "pcl-test-framework"; + asd = "pcl-test-framework"; + } + ); + systems = [ "pcl-test-framework" ]; + lispLibs = [ (getAttr "pcl-macro-utilities" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-unit-test = ( + build-asdf-system { + pname = "pcl-unit-test"; + version = "20121125-git"; + asds = [ "pcl-unit-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-match/2012-11-25/cl-match-20121125-git.tgz"; + sha256 = "1qc8gzp7f4phgyi5whkxacrqzdqs0y1hvkf71m8n7l303jly9wjf"; + system = "pcl-unit-test"; + asd = "pcl-unit-test"; + } + ); + systems = [ "pcl-unit-test" ]; + lispLibs = [ (getAttr "standard-cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pcl-url-function = ( + build-asdf-system { + pname = "pcl-url-function"; + version = "20180430-git"; + asds = [ "pcl-url-function" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "pcl-url-function"; + asd = "pcl-url-function"; + } + ); + systems = [ "pcl-url-function" ]; + lispLibs = [ + (getAttr "aserve" self) + (getAttr "pcl-html" self) + (getAttr "pcl-macro-utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + peppol = ( + build-asdf-system { + pname = "peppol"; + version = "20201016-git"; + asds = [ "peppol" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-peppol/2020-10-16/cl-peppol-20201016-git.tgz"; + sha256 = "02wc6h1fiaqzf14py2kwsvx0dmb22wdkd54pl0ixnmivj436ln99"; + system = "peppol"; + asd = "peppol"; + } + ); + systems = [ "peppol" ]; + lispLibs = [ + (getAttr "cxml" self) + (getAttr "xpath" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + percent-encoding = ( + build-asdf-system { + pname = "percent-encoding"; + version = "20121013-git"; + asds = [ "percent-encoding" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/percent-encoding/2012-10-13/percent-encoding-20121013-git.tgz"; + sha256 = "0q1lh3sa6mkjr5gcdkgimkpc29rgf9cjhv90f61h8ridj28grq0h"; + system = "percent-encoding"; + asd = "percent-encoding"; + } + ); + systems = [ "percent-encoding" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "babel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + percent-encoding-test = ( + build-asdf-system { + pname = "percent-encoding-test"; + version = "20121013-git"; + asds = [ "percent-encoding-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/percent-encoding/2012-10-13/percent-encoding-20121013-git.tgz"; + sha256 = "0q1lh3sa6mkjr5gcdkgimkpc29rgf9cjhv90f61h8ridj28grq0h"; + system = "percent-encoding-test"; + asd = "percent-encoding"; + } + ); + systems = [ "percent-encoding-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "percent-encoding" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + perceptual-hashes = ( + build-asdf-system { + pname = "perceptual-hashes"; + version = "20220707-git"; + asds = [ "perceptual-hashes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/perceptual-hashes/2022-07-07/perceptual-hashes-20220707-git.tgz"; + sha256 = "1hg2vxi4avmjwscgab7wqf3c4d60x933lac4d86fmfk0wgl5nzzd"; + system = "perceptual-hashes"; + asd = "perceptual-hashes"; + } + ); + systems = [ "perceptual-hashes" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "array-operations" self) + (getAttr "imago" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + periodic-table = ( + build-asdf-system { + pname = "periodic-table"; + version = "1.0"; + asds = [ "periodic-table" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/periodic-table/2011-10-01/periodic-table-1.0.tgz"; + sha256 = "147j9kn0afsvlz09vdjmvw5si08ix3dyypg21vrc5xvn9nsalrxx"; + system = "periodic-table"; + asd = "periodic-table"; + } + ); + systems = [ "periodic-table" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + periods = ( + build-asdf-system { + pname = "periods"; + version = "20221106-git"; + asds = [ "periods" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/periods/2022-11-06/periods-20221106-git.tgz"; + sha256 = "0ynhdmlzb499mlm7c7zy6vgw8vglkkf14zr0v40jcl1sgq3236ry"; + system = "periods"; + asd = "periods"; + } + ); + systems = [ "periods" ]; + lispLibs = [ (getAttr "local-time" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + periods-series = ( + build-asdf-system { + pname = "periods-series"; + version = "20221106-git"; + asds = [ "periods-series" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/periods/2022-11-06/periods-20221106-git.tgz"; + sha256 = "0ynhdmlzb499mlm7c7zy6vgw8vglkkf14zr0v40jcl1sgq3236ry"; + system = "periods-series"; + asd = "periods-series"; + } + ); + systems = [ "periods-series" ]; + lispLibs = [ + (getAttr "periods" self) + (getAttr "series" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + perlre = ( + build-asdf-system { + pname = "perlre"; + version = "20200715-git"; + asds = [ "perlre" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/perlre/2020-07-15/perlre-20200715-git.tgz"; + sha256 = "1izhrn1xd0mi2nl0p6930ln3nb4wp3y5ngg81wy5g5s4vqy2h54a"; + system = "perlre"; + asd = "perlre"; + } + ); + systems = [ "perlre" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "let-over-lambda" self) + (getAttr "prove" self) + (getAttr "trivia" self) + (getAttr "trivia_dot_ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pero = ( + build-asdf-system { + pname = "pero"; + version = "20230214-git"; + asds = [ "pero" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pero/2023-02-14/pero-20230214-git.tgz"; + sha256 = "1q513lvnq4m8l332glriid0vxcdcnakcdag3lck1wmrfaxhdpnmc"; + system = "pero"; + asd = "pero"; + } + ); + systems = [ "pero" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + persistent = ( + build-asdf-system { + pname = "persistent"; + version = "20241012-git"; + asds = [ "persistent" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "persistent"; + asd = "persistent"; + } + ); + systems = [ "persistent" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + persistent-tables = ( + build-asdf-system { + pname = "persistent-tables"; + version = "20120208-git"; + asds = [ "persistent-tables" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/persistent-tables/2012-02-08/persistent-tables-20120208-git.tgz"; + sha256 = "0klfjza85mgj2z42x2lhcqy9q66avac7zw0cpbmwwng3m7679hpa"; + system = "persistent-tables"; + asd = "persistent-tables"; + } + ); + systems = [ "persistent-tables" ]; + lispLibs = [ + (getAttr "lisp-unit" self) + (getAttr "random-access-lists" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + persistent-variables = ( + build-asdf-system { + pname = "persistent-variables"; + version = "20130312-git"; + asds = [ "persistent-variables" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/persistent-variables/2013-03-12/persistent-variables-20130312-git.tgz"; + sha256 = "0r72cbjkb5q4sn109svlcsvrwgvwdsn5c63rv5cpaf3jrfv1z8xn"; + system = "persistent-variables"; + asd = "persistent-variables"; + } + ); + systems = [ "persistent-variables" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + persistent-variables_dot_test = ( + build-asdf-system { + pname = "persistent-variables.test"; + version = "20130312-git"; + asds = [ "persistent-variables.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/persistent-variables/2013-03-12/persistent-variables-20130312-git.tgz"; + sha256 = "0r72cbjkb5q4sn109svlcsvrwgvwdsn5c63rv5cpaf3jrfv1z8xn"; + system = "persistent-variables.test"; + asd = "persistent-variables"; + } + ); + systems = [ "persistent-variables.test" ]; + lispLibs = [ (getAttr "persistent-variables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petalisp = ( + build-asdf-system { + pname = "petalisp"; + version = "20241012-git"; + asds = [ "petalisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; + sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; + system = "petalisp"; + asd = "petalisp"; + } + ); + systems = [ "petalisp" ]; + lispLibs = [ + (getAttr "petalisp_dot_api" self) + (getAttr "petalisp_dot_test-suite" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petalisp_dot_api = ( + build-asdf-system { + pname = "petalisp.api"; + version = "20241012-git"; + asds = [ "petalisp.api" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; + sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; + system = "petalisp.api"; + asd = "petalisp.api"; + } + ); + systems = [ "petalisp.api" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "petalisp_dot_codegen" self) + (getAttr "petalisp_dot_core" self) + (getAttr "petalisp_dot_ir" self) + (getAttr "petalisp_dot_native-backend" self) + (getAttr "petalisp_dot_packages" self) + (getAttr "petalisp_dot_utilities" self) + (getAttr "split-sequence" self) + (getAttr "trivia" self) + (getAttr "trivial-macroexpand-all" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petalisp_dot_codegen = ( + build-asdf-system { + pname = "petalisp.codegen"; + version = "20241012-git"; + asds = [ "petalisp.codegen" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; + sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; + system = "petalisp.codegen"; + asd = "petalisp.codegen"; + } + ); + systems = [ "petalisp.codegen" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "petalisp_dot_core" self) + (getAttr "petalisp_dot_ir" self) + (getAttr "petalisp_dot_utilities" self) + (getAttr "trivia" self) + (getAttr "trivial-macroexpand-all" self) + (getAttr "ucons" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petalisp_dot_core = ( + build-asdf-system { + pname = "petalisp.core"; + version = "20241012-git"; + asds = [ "petalisp.core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; + sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; + system = "petalisp.core"; + asd = "petalisp.core"; + } + ); + systems = [ "petalisp.core" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "lparallel" self) + (getAttr "petalisp_dot_packages" self) + (getAttr "petalisp_dot_utilities" self) + (getAttr "trivia" self) + (getAttr "typo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petalisp_dot_examples = ( + build-asdf-system { + pname = "petalisp.examples"; + version = "20241012-git"; + asds = [ "petalisp.examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; + sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; + system = "petalisp.examples"; + asd = "petalisp.examples"; + } + ); + systems = [ "petalisp.examples" ]; + lispLibs = [ + (getAttr "numpy-file-format" self) + (getAttr "petalisp_dot_api" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petalisp_dot_ir = ( + build-asdf-system { + pname = "petalisp.ir"; + version = "20241012-git"; + asds = [ "petalisp.ir" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; + sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; + system = "petalisp.ir"; + asd = "petalisp.ir"; + } + ); + systems = [ "petalisp.ir" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "petalisp_dot_core" self) + (getAttr "petalisp_dot_utilities" self) + (getAttr "priority-queue" self) + (getAttr "split-sequence" self) + (getAttr "ucons" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petalisp_dot_native-backend = ( + build-asdf-system { + pname = "petalisp.native-backend"; + version = "20241012-git"; + asds = [ "petalisp.native-backend" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; + sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; + system = "petalisp.native-backend"; + asd = "petalisp.native-backend"; + } + ); + systems = [ "petalisp.native-backend" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "lparallel" self) + (getAttr "petalisp_dot_codegen" self) + (getAttr "petalisp_dot_core" self) + (getAttr "petalisp_dot_ir" self) + (getAttr "petalisp_dot_utilities" self) + (getAttr "static-vectors" self) + (getAttr "trivia" self) + (getAttr "trivial-garbage" self) + (getAttr "typo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petalisp_dot_packages = ( + build-asdf-system { + pname = "petalisp.packages"; + version = "20241012-git"; + asds = [ "petalisp.packages" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; + sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; + system = "petalisp.packages"; + asd = "petalisp.packages"; + } + ); + systems = [ "petalisp.packages" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petalisp_dot_test-suite = ( + build-asdf-system { + pname = "petalisp.test-suite"; + version = "20241012-git"; + asds = [ "petalisp.test-suite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; + sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; + system = "petalisp.test-suite"; + asd = "petalisp.test-suite"; + } + ); + systems = [ "petalisp.test-suite" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "petalisp_dot_api" self) + (getAttr "petalisp_dot_examples" self) + (getAttr "petalisp_dot_native-backend" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petalisp_dot_utilities = ( + build-asdf-system { + pname = "petalisp.utilities"; + version = "20241012-git"; + asds = [ "petalisp.utilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petalisp/2024-10-12/petalisp-20241012-git.tgz"; + sha256 = "06njw0jx48rm52zbpwdw442j6rasqsmfd2zsi71y30aij7c9b0h9"; + system = "petalisp.utilities"; + asd = "petalisp.utilities"; + } + ); + systems = [ "petalisp.utilities" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "queues_dot_priority-queue" self) + (getAttr "trivia" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petit_dot_package-utils = ( + build-asdf-system { + pname = "petit.package-utils"; + version = "20140826-git"; + asds = [ "petit.package-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petit.package-utils/2014-08-26/petit.package-utils-20140826-git.tgz"; + sha256 = "0jj4c1jpcqfy9mrlxhjmq4ypwlzk84h09i8nr34wjwh6z7idhpyv"; + system = "petit.package-utils"; + asd = "petit.package-utils"; + } + ); + systems = [ "petit.package-utils" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petit_dot_string-utils = ( + build-asdf-system { + pname = "petit.string-utils"; + version = "20141106-git"; + asds = [ "petit.string-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petit.string-utils/2014-11-06/petit.string-utils-20141106-git.tgz"; + sha256 = "04kqdj69x53wzvpp54zp6767186in24p8yrr82wdg2bwzw4qh4yl"; + system = "petit.string-utils"; + asd = "petit.string-utils"; + } + ); + systems = [ "petit.string-utils" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petit_dot_string-utils-test = ( + build-asdf-system { + pname = "petit.string-utils-test"; + version = "20141106-git"; + asds = [ "petit.string-utils-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petit.string-utils/2014-11-06/petit.string-utils-20141106-git.tgz"; + sha256 = "04kqdj69x53wzvpp54zp6767186in24p8yrr82wdg2bwzw4qh4yl"; + system = "petit.string-utils-test"; + asd = "petit.string-utils-test"; + } + ); + systems = [ "petit.string-utils-test" ]; + lispLibs = [ + (getAttr "petit_dot_string-utils" self) + (getAttr "rt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + petri = ( + build-asdf-system { + pname = "petri"; + version = "20200427-git"; + asds = [ "petri" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/petri/2020-04-27/petri-20200427-git.tgz"; + sha256 = "1y78s3jndyxll46zq7s5is9pwv8f6jr2npjkcpd48ik7xkj2269b"; + system = "petri"; + asd = "petri"; + } + ); + systems = [ "petri" ]; + lispLibs = [ + (getAttr "_1am" self) + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "phoe-toolbox" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pettomato-deque = ( + build-asdf-system { + pname = "pettomato-deque"; + version = "20120107-git"; + asds = [ "pettomato-deque" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pettomato-deque/2012-01-07/pettomato-deque-20120107-git.tgz"; + sha256 = "07ai4fa64cg6shfvnx9xk7pscbsz64ys80482zz2fb9q0rba80b7"; + system = "pettomato-deque"; + asd = "pettomato-deque"; + } + ); + systems = [ "pettomato-deque" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pettomato-deque-tests = ( + build-asdf-system { + pname = "pettomato-deque-tests"; + version = "20120107-git"; + asds = [ "pettomato-deque-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pettomato-deque/2012-01-07/pettomato-deque-20120107-git.tgz"; + sha256 = "07ai4fa64cg6shfvnx9xk7pscbsz64ys80482zz2fb9q0rba80b7"; + system = "pettomato-deque-tests"; + asd = "pettomato-deque-tests"; + } + ); + systems = [ "pettomato-deque-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "pettomato-deque" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pettomato-indexed-priority-queue = ( + build-asdf-system { + pname = "pettomato-indexed-priority-queue"; + version = "20120909-git"; + asds = [ "pettomato-indexed-priority-queue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pettomato-indexed-priority-queue/2012-09-09/pettomato-indexed-priority-queue-20120909-git.tgz"; + sha256 = "14i36qbdnif28xcbxdbr5abzmzxr7vzv64n1aix0f6khxg99pylz"; + system = "pettomato-indexed-priority-queue"; + asd = "pettomato-indexed-priority-queue"; + } + ); + systems = [ "pettomato-indexed-priority-queue" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pettomato-indexed-priority-queue-tests = ( + build-asdf-system { + pname = "pettomato-indexed-priority-queue-tests"; + version = "20120909-git"; + asds = [ "pettomato-indexed-priority-queue-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pettomato-indexed-priority-queue/2012-09-09/pettomato-indexed-priority-queue-20120909-git.tgz"; + sha256 = "14i36qbdnif28xcbxdbr5abzmzxr7vzv64n1aix0f6khxg99pylz"; + system = "pettomato-indexed-priority-queue-tests"; + asd = "pettomato-indexed-priority-queue-tests"; + } + ); + systems = [ "pettomato-indexed-priority-queue-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "pettomato-indexed-priority-queue" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pfft = ( + build-asdf-system { + pname = "pfft"; + version = "20180711-git"; + asds = [ "pfft" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/fft/2018-07-11/fft-20180711-git.tgz"; + sha256 = "0ymnfplap2cncw49mhq7crapgxphfwsvqdgrcckpgsvw6qsymasd"; + system = "pfft"; + asd = "pfft"; + } + ); + systems = [ "pfft" ]; + lispLibs = [ + (getAttr "fft" self) + (getAttr "pcall" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pg = ( + build-asdf-system { + pname = "pg"; + version = "20150608-git"; + asds = [ "pg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pg/2015-06-08/pg-20150608-git.tgz"; + sha256 = "1c7axd2yxw9lxf7l5djrnfkp197mmr88qpigy2cjgim8vxab4n2l"; + system = "pg"; + asd = "pg"; + } + ); + systems = [ "pg" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pgloader = ( + build-asdf-system { + pname = "pgloader"; + version = "v3.6.9"; + asds = [ "pgloader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pgloader/2022-11-06/pgloader-v3.6.9.tgz"; + sha256 = "03kp3ms2sjz4gwb94xs404mi63fnv1bq00hyqxyvc9csmicxzawn"; + system = "pgloader"; + asd = "pgloader"; + } + ); + systems = [ "pgloader" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-base64" self) + (getAttr "cl-csv" self) + (getAttr "cl-fad" self) + (getAttr "cl-log" self) + (getAttr "cl-markdown" self) + (getAttr "cl-mustache" self) + (getAttr "cl-postgres" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "command-line-arguments" self) + (getAttr "db3" self) + (getAttr "drakma" self) + (getAttr "esrap" self) + (getAttr "flexi-streams" self) + (getAttr "ixf" self) + (getAttr "local-time" self) + (getAttr "lparallel" self) + (getAttr "metabang-bind" self) + (getAttr "mssql" self) + (getAttr "postmodern" self) + (getAttr "py-configparser" self) + (getAttr "qmynd" self) + (getAttr "quri" self) + (getAttr "simple-date" self) + (getAttr "split-sequence" self) + (getAttr "sqlite" self) + (getAttr "trivial-backtrace" self) + (getAttr "usocket" self) + (getAttr "uuid" self) + (getAttr "yason" self) + (getAttr "zs3" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + phoe-toolbox = ( + build-asdf-system { + pname = "phoe-toolbox"; + version = "20210124-git"; + asds = [ "phoe-toolbox" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/phoe-toolbox/2021-01-24/phoe-toolbox-20210124-git.tgz"; + sha256 = "0bzbgs4lkhw93y1cwrs9kp5yiyz8sg4885cnvi83dzzbla9b74kv"; + system = "phoe-toolbox"; + asd = "phoe-toolbox"; + } + ); + systems = [ "phoe-toolbox" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "trivial-indent" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + phonon = ( + build-asdf-system { + pname = "phonon"; + version = "20210531-git"; + asds = [ "phonon" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "phonon"; + asd = "phonon"; + } + ); + systems = [ "phonon" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtdbus" self) + (getAttr "qtgui" self) + (getAttr "qtxml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + phos = ( + build-asdf-system { + pname = "phos"; + version = "20241012-git"; + asds = [ "phos" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/phos/2024-10-12/phos-20241012-git.tgz"; + sha256 = "0lnv54iczidjpskciw7y2faazgxjwpncggdh5kggpjziq03pr7lv"; + system = "phos"; + asd = "phos"; + } + ); + systems = [ "phos" ]; + lispLibs = [ + (getAttr "cl_plus_ssl" self) + (getAttr "cl-ppcre" self) + (getAttr "quri" self) + (getAttr "trivia" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + physical-dimension = ( + build-asdf-system { + pname = "physical-dimension"; + version = "master-df14cb8c-git"; + asds = [ "physical-dimension" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/antik/2024-10-12/antik-master-df14cb8c-git.tgz"; + sha256 = "1n08cx4n51z8v4bxyak166lp495xda3x7llfxcdpxndxqxcammr0"; + system = "physical-dimension"; + asd = "physical-dimension"; + } + ); + systems = [ "physical-dimension" ]; + lispLibs = [ + (getAttr "fare-utils" self) + (getAttr "foreign-array" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + physical-quantities = ( + build-asdf-system { + pname = "physical-quantities"; + version = "20211020-git"; + asds = [ "physical-quantities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/physical-quantities/2021-10-20/physical-quantities-20211020-git.tgz"; + sha256 = "0mb2s94s6fhw5vfa89naalw7ld11sdsszlqpz0c65dvpfyfmmdmh"; + system = "physical-quantities"; + asd = "physical-quantities"; + } + ); + systems = [ "physical-quantities" ]; + lispLibs = [ (getAttr "parseq" self) ]; + meta = { }; + } + ); + picl = ( + build-asdf-system { + pname = "picl"; + version = "20241012-git"; + asds = [ "picl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/picl/2024-10-12/picl-20241012-git.tgz"; + sha256 = "0pdzlmphf1bqk5xdvwf1m1l3s5whwm4ysnpl5kpwq70adx38rysk"; + system = "picl"; + asd = "picl"; + } + ); + systems = [ "picl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "defclass-std" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + piggyback-parameters = ( + build-asdf-system { + pname = "piggyback-parameters"; + version = "20200610-git"; + asds = [ "piggyback-parameters" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/piggyback-parameters/2020-06-10/piggyback-parameters-20200610-git.tgz"; + sha256 = "1187bgnz9pvs8xdxapqhrm4yqzwlp368ijmc5szm8r8q3zrb219n"; + system = "piggyback-parameters"; + asd = "piggyback-parameters"; + } + ); + systems = [ "piggyback-parameters" ]; + lispLibs = [ + (getAttr "trivial-hashtable-serialize" self) + (getAttr "trivial-json-codec" self) + (getAttr "trivial-pooled-database" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pileup = ( + build-asdf-system { + pname = "pileup"; + version = "20150709-git"; + asds = [ "pileup" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pileup/2015-07-09/pileup-20150709-git.tgz"; + sha256 = "01gvshpxil0ggjgfmgcymbgmpsfaxy6aggm0bywkn40rck3038vb"; + system = "pileup"; + asd = "pileup"; + } + ); + systems = [ "pileup" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pileup-tests = ( + build-asdf-system { + pname = "pileup-tests"; + version = "20150709-git"; + asds = [ "pileup-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pileup/2015-07-09/pileup-20150709-git.tgz"; + sha256 = "01gvshpxil0ggjgfmgcymbgmpsfaxy6aggm0bywkn40rck3038vb"; + system = "pileup-tests"; + asd = "pileup"; + } + ); + systems = [ "pileup-tests" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_stefil" self) + (getAttr "pileup" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pipes = ( + build-asdf-system { + pname = "pipes"; + version = "20150923-git"; + asds = [ "pipes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pipes/2015-09-23/pipes-20150923-git.tgz"; + sha256 = "17qcxalbdip20nkbwiv3kpdjjsy0g1y9s4a0zv38ch47bdl9yxpc"; + system = "pipes"; + asd = "pipes"; + } + ); + systems = [ "pipes" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + piping = ( + build-asdf-system { + pname = "piping"; + version = "20231021-git"; + asds = [ "piping" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/piping/2023-10-21/piping-20231021-git.tgz"; + sha256 = "0g0k6w7xa0xyzlr3j5j85b91kazbba4rxwplmqcb5ns3shk8745g"; + system = "piping"; + asd = "piping"; + } + ); + systems = [ "piping" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pithy-xml = ( + build-asdf-system { + pname = "pithy-xml"; + version = "20101006-git"; + asds = [ "pithy-xml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pithy-xml/2010-10-06/pithy-xml-20101006-git.tgz"; + sha256 = "05zw5adiw7jgvi9w9c661s4r49fidpcxn6m7azmn0pzc936dg17h"; + system = "pithy-xml"; + asd = "pithy-xml"; + } + ); + systems = [ "pithy-xml" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pixman = ( + build-asdf-system { + pname = "pixman"; + version = "20170830-git"; + asds = [ "pixman" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-pixman/2017-08-30/cl-pixman-20170830-git.tgz"; + sha256 = "068hh7cv6f2wqwd8092wqh3rgdix6sa319qpm648mss8jfnjjbgj"; + system = "pixman"; + asd = "pixman"; + } + ); + systems = [ "pixman" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pjlink = ( + build-asdf-system { + pname = "pjlink"; + version = "20220331-git"; + asds = [ "pjlink" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pjlink/2022-03-31/pjlink-20220331-git.tgz"; + sha256 = "1rsmg0x7fd32na36x9ahj6vji3xs6ckg5pyng8nf33fmdj8dscbc"; + system = "pjlink"; + asd = "pjlink"; + } + ); + systems = [ "pjlink" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "ip-interfaces" self) + (getAttr "md5" self) + (getAttr "split-sequence" self) + (getAttr "trivial-garbage" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pk-serialize = ( + build-asdf-system { + pname = "pk-serialize"; + version = "20221106-git"; + asds = [ "pk-serialize" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pk-serialize/2022-11-06/pk-serialize-20221106-git.tgz"; + sha256 = "1fi9xxdlg2z9dnqb2sc7wg37aqzqjz43h2l1wxa5zvk73qqzapyn"; + system = "pk-serialize"; + asd = "pk-serialize"; + } + ); + systems = [ "pk-serialize" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pkg-doc = ( + build-asdf-system { + pname = "pkg-doc"; + version = "20200925-git"; + asds = [ "pkg-doc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pkg-doc/2020-09-25/pkg-doc-20200925-git.tgz"; + sha256 = "1y4dcc0q3iizgvavnkl8q4bjxq0dngvqw5dhrf9bxf4d3q3vrbd4"; + system = "pkg-doc"; + asd = "pkg-doc"; + } + ); + systems = [ "pkg-doc" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "clim-widgets" self) + (getAttr "manifest" self) + (getAttr "nsort" self) + (getAttr "repl-utilities" self) + (getAttr "stdutils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + place-modifiers = ( + build-asdf-system { + pname = "place-modifiers"; + version = "2.1"; + asds = [ "place-modifiers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/place-modifiers/2012-11-25/place-modifiers-2.1.tgz"; + sha256 = "13nd911h6i7gks78l30bzdqzygcqh47946jwaf50ak2iraagknvf"; + system = "place-modifiers"; + asd = "place-modifiers"; + } + ); + systems = [ "place-modifiers" ]; + lispLibs = [ + (getAttr "cartesian-product-switch" self) + (getAttr "map-bind" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + place-utils = ( + build-asdf-system { + pname = "place-utils"; + version = "0.2"; + asds = [ "place-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/place-utils/2018-10-18/place-utils-0.2.tgz"; + sha256 = "1riaxxafn2xbyy6776yqns1bhz5jnzzpd177wb5xzvwlxiix6yf9"; + system = "place-utils"; + asd = "place-utils"; + } + ); + systems = [ "place-utils" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + planks = ( + build-asdf-system { + pname = "planks"; + version = "20110522-git"; + asds = [ "planks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/planks/2011-05-22/planks-20110522-git.tgz"; + sha256 = "1y7cg9xb75j1yslbxsmw0fyg738f4d28lnlm7w7hzgc51fc7875k"; + system = "planks"; + asd = "planks"; + } + ); + systems = [ "planks" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "ironclad" self) + (getAttr "rucksack" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + plokami = ( + build-asdf-system { + pname = "plokami"; + version = "20200218-git"; + asds = [ "plokami" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/plokami/2020-02-18/plokami-20200218-git.tgz"; + sha256 = "1k78lpbaqqa2gnwi9k0y646md4s9xnijm774knl11p05r83w5ycb"; + system = "plokami"; + asd = "plokami"; + } + ); + systems = [ "plokami" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + plot = ( + build-asdf-system { + pname = "plot"; + version = "20241012-git"; + asds = [ "plot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/plot/2024-10-12/plot-20241012-git.tgz"; + sha256 = "1x5kc5y0s082y24qgq138331qmfs0xxxj43ss3aw0kgx7wfpxlms"; + system = "plot"; + asd = "plot"; + } + ); + systems = [ "plot" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "alexandria_plus" self) + (getAttr "cl-ppcre" self) + (getAttr "data-frame" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + plplot-examples = ( + build-asdf-system { + pname = "plplot-examples"; + version = "20180228-git"; + asds = [ "plplot-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-plplot/2018-02-28/cl-plplot-20180228-git.tgz"; + sha256 = "0hfgq47ga2r764jfc3ywaz5ynnvp701fjhbw0s4j1mrw4gaf6y6w"; + system = "plplot-examples"; + asd = "cl-plplot"; + } + ); + systems = [ "plplot-examples" ]; + lispLibs = [ + (getAttr "cl-plplot" self) + (getAttr "png" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pludeck = ( + build-asdf-system { + pname = "pludeck"; + version = "20180831-git"; + asds = [ "pludeck" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pludeck/2018-08-31/pludeck-20180831-git.tgz"; + sha256 = "0p6v7fxs48fxr76kvkh6z2mjjyz3vf2rp698jq1fl6p3hihbgl0m"; + system = "pludeck"; + asd = "pludeck"; + } + ); + systems = [ "pludeck" ]; + lispLibs = [ (getAttr "plump" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + plump = ( + build-asdf-system { + pname = "plump"; + version = "20241012-git"; + asds = [ "plump" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/plump/2024-10-12/plump-20241012-git.tgz"; + sha256 = "04wy2v69zal186gg0pvcj60184gi7cpkpx3h1w93c9nilmla0dv9"; + system = "plump"; + asd = "plump"; + } + ); + systems = [ "plump" ]; + lispLibs = [ + (getAttr "array-utils" self) + (getAttr "documentation-utils" self) + ]; + meta = { }; + } + ); + plump-bundle = ( + build-asdf-system { + pname = "plump-bundle"; + version = "20231021-git"; + asds = [ "plump-bundle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/plump-bundle/2023-10-21/plump-bundle-20231021-git.tgz"; + sha256 = "0qknmdryyynjk5g0zda2788p4j0s6w4fj27kdca22z0n8r8yfhhk"; + system = "plump-bundle"; + asd = "plump-bundle"; + } + ); + systems = [ "plump-bundle" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "closer-mop" self) + (getAttr "fast-io" self) + (getAttr "plump-dom" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + plump-dom = ( + build-asdf-system { + pname = "plump-dom"; + version = "20241012-git"; + asds = [ "plump-dom" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/plump/2024-10-12/plump-20241012-git.tgz"; + sha256 = "04wy2v69zal186gg0pvcj60184gi7cpkpx3h1w93c9nilmla0dv9"; + system = "plump-dom"; + asd = "plump-dom"; + } + ); + systems = [ "plump-dom" ]; + lispLibs = [ (getAttr "plump" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + plump-lexer = ( + build-asdf-system { + pname = "plump-lexer"; + version = "20241012-git"; + asds = [ "plump-lexer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/plump/2024-10-12/plump-20241012-git.tgz"; + sha256 = "04wy2v69zal186gg0pvcj60184gi7cpkpx3h1w93c9nilmla0dv9"; + system = "plump-lexer"; + asd = "plump-lexer"; + } + ); + systems = [ "plump-lexer" ]; + lispLibs = [ (getAttr "plump" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + plump-parser = ( + build-asdf-system { + pname = "plump-parser"; + version = "20241012-git"; + asds = [ "plump-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/plump/2024-10-12/plump-20241012-git.tgz"; + sha256 = "04wy2v69zal186gg0pvcj60184gi7cpkpx3h1w93c9nilmla0dv9"; + system = "plump-parser"; + asd = "plump-parser"; + } + ); + systems = [ "plump-parser" ]; + lispLibs = [ (getAttr "plump" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + plump-sexp = ( + build-asdf-system { + pname = "plump-sexp"; + version = "20241012-git"; + asds = [ "plump-sexp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/plump-sexp/2024-10-12/plump-sexp-20241012-git.tgz"; + sha256 = "19gihmsbwv42zwyc4rd1pcvj5yzf1vnhpci7r5kz1dnrmz9gzy3l"; + system = "plump-sexp"; + asd = "plump-sexp"; + } + ); + systems = [ "plump-sexp" ]; + lispLibs = [ (getAttr "plump" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + plump-tex = ( + build-asdf-system { + pname = "plump-tex"; + version = "20231021-git"; + asds = [ "plump-tex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/plump-tex/2023-10-21/plump-tex-20231021-git.tgz"; + sha256 = "1k0cmk5sbn042bx7nxiw0rvsjmgmj221zim1hg23r0485jbx0r3h"; + system = "plump-tex"; + asd = "plump-tex"; + } + ); + systems = [ "plump-tex" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "plump" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + plump-tex-test = ( + build-asdf-system { + pname = "plump-tex-test"; + version = "20231021-git"; + asds = [ "plump-tex-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/plump-tex/2023-10-21/plump-tex-20231021-git.tgz"; + sha256 = "1k0cmk5sbn042bx7nxiw0rvsjmgmj221zim1hg23r0485jbx0r3h"; + system = "plump-tex-test"; + asd = "plump-tex-test"; + } + ); + systems = [ "plump-tex-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "plump-tex" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + png = ( + build-asdf-system { + pname = "png"; + version = "20211020-git"; + asds = [ "png" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-png/2021-10-20/cl-png-20211020-git.tgz"; + sha256 = "17xcb9ps5vf3if61blmx7cpfrz3gsw7jk8d5zv3f4cq8jrriqdx4"; + system = "png"; + asd = "png"; + } + ); + systems = [ "png" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + png-read = ( + build-asdf-system { + pname = "png-read"; + version = "20170830-git"; + asds = [ "png-read" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/png-read/2017-08-30/png-read-20170830-git.tgz"; + sha256 = "0vyczbcwskrygrf1hgrsnk0jil8skmvf1kiaalw5jps4fjrfdkw0"; + system = "png-read"; + asd = "png-read"; + } + ); + systems = [ "png-read" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "chipz" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + png-test = ( + build-asdf-system { + pname = "png-test"; + version = "20211020-git"; + asds = [ "png-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-png/2021-10-20/cl-png-20211020-git.tgz"; + sha256 = "17xcb9ps5vf3if61blmx7cpfrz3gsw7jk8d5zv3f4cq8jrriqdx4"; + system = "png-test"; + asd = "png-test"; + } + ); + systems = [ "png-test" ]; + lispLibs = [ (getAttr "png" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pngload = ( + build-asdf-system { + pname = "pngload"; + version = "20241012-git"; + asds = [ "pngload" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pngload/2024-10-12/pngload-20241012-git.tgz"; + sha256 = "1j5j8n8xa8hgc413lfxij3wmkwyal13p0a5q6n74zzr61f1kn6vc"; + system = "pngload"; + asd = "pngload"; + } + ); + systems = [ "pngload" ]; + lispLibs = [ + (getAttr "_3bz" self) + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "mmap" self) + (getAttr "parse-float" self) + (getAttr "static-vectors" self) + (getAttr "swap-bytes" self) + (getAttr "zpb-exif" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pngload_dot_test = ( + build-asdf-system { + pname = "pngload.test"; + version = "20241012-git"; + asds = [ "pngload.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pngload/2024-10-12/pngload-20241012-git.tgz"; + sha256 = "1j5j8n8xa8hgc413lfxij3wmkwyal13p0a5q6n74zzr61f1kn6vc"; + system = "pngload.test"; + asd = "pngload.test"; + } + ); + systems = [ "pngload.test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "local-time" self) + (getAttr "opticl" self) + (getAttr "png-read" self) + (getAttr "pngload" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + poler = ( + build-asdf-system { + pname = "poler"; + version = "20181210-git"; + asds = [ "poler" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/poler/2018-12-10/poler-20181210-git.tgz"; + sha256 = "1lcyjxmz5vm5is1kgxqjvpkllywvbsj6wqx5v2ac0py5vqws1l8z"; + system = "poler"; + asd = "poler"; + } + ); + systems = [ "poler" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + poler-test = ( + build-asdf-system { + pname = "poler-test"; + version = "20181210-git"; + asds = [ "poler-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/poler/2018-12-10/poler-20181210-git.tgz"; + sha256 = "1lcyjxmz5vm5is1kgxqjvpkllywvbsj6wqx5v2ac0py5vqws1l8z"; + system = "poler-test"; + asd = "poler-test"; + } + ); + systems = [ "poler-test" ]; + lispLibs = [ + (getAttr "poler" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + policy-cond = ( + build-asdf-system { + pname = "policy-cond"; + version = "20241012-git"; + asds = [ "policy-cond" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/policy-cond/2024-10-12/policy-cond-20241012-git.tgz"; + sha256 = "17gm4alfb8nf85963ckahipx61xfffj0ra2cnn6yra32krzj7gnk"; + system = "policy-cond"; + asd = "policy-cond"; + } + ); + systems = [ "policy-cond" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + polisher = ( + build-asdf-system { + pname = "polisher"; + version = "20211230-git"; + asds = [ "polisher" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/polisher/2021-12-30/polisher-20211230-git.tgz"; + sha256 = "1i63kgk4vfisiyrfqdz0wc8ldvfh9jpkivsasgdhc97cad095ln0"; + system = "polisher"; + asd = "polisher"; + } + ); + systems = [ "polisher" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + polisher_dot_test = ( + build-asdf-system { + pname = "polisher.test"; + version = "20211230-git"; + asds = [ "polisher.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/polisher/2021-12-30/polisher-20211230-git.tgz"; + sha256 = "1i63kgk4vfisiyrfqdz0wc8ldvfh9jpkivsasgdhc97cad095ln0"; + system = "polisher.test"; + asd = "polisher.test"; + } + ); + systems = [ "polisher.test" ]; + lispLibs = [ + (getAttr "_1am" self) + (getAttr "polisher" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + polymorphic-functions-lite = ( + build-asdf-system { + pname = "polymorphic-functions-lite"; + version = "20241012-git"; + asds = [ "polymorphic-functions-lite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/polymorphic-functions/2024-10-12/polymorphic-functions-20241012-git.tgz"; + sha256 = "1bawhbj5rh1q6qrcjnx48n78841mgri5n63pmicxxyhif2il0zq3"; + system = "polymorphic-functions-lite"; + asd = "polymorphic-functions-lite"; + } + ); + systems = [ "polymorphic-functions-lite" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "fiveam" self) + (getAttr "introspect-environment" self) + (getAttr "optima" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pooler = ( + build-asdf-system { + pname = "pooler"; + version = "20150608-git"; + asds = [ "pooler" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pooler/2015-06-08/pooler-20150608-git.tgz"; + sha256 = "18vdl06cckk07m7r477qzcz24j3sid1agfa69fp91jna5aqi46kb"; + system = "pooler"; + asd = "pooler"; + } + ); + systems = [ "pooler" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + portable-condition-system = ( + build-asdf-system { + pname = "portable-condition-system"; + version = "20210807-git"; + asds = [ "portable-condition-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/portable-condition-system/2021-08-07/portable-condition-system-20210807-git.tgz"; + sha256 = "099lb9f4bavj95wik99wla5rf6fk1gdw9pvn0cqlaf0wf20csd3h"; + system = "portable-condition-system"; + asd = "portable-condition-system"; + } + ); + systems = [ "portable-condition-system" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + portable-condition-system_dot_integration = ( + build-asdf-system { + pname = "portable-condition-system.integration"; + version = "20210807-git"; + asds = [ "portable-condition-system.integration" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/portable-condition-system/2021-08-07/portable-condition-system-20210807-git.tgz"; + sha256 = "099lb9f4bavj95wik99wla5rf6fk1gdw9pvn0cqlaf0wf20csd3h"; + system = "portable-condition-system.integration"; + asd = "portable-condition-system.integration"; + } + ); + systems = [ "portable-condition-system.integration" ]; + lispLibs = [ + (getAttr "portable-condition-system" self) + (getAttr "trivial-custom-debugger" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + portable-threads = ( + build-asdf-system { + pname = "portable-threads"; + version = "20210531-git"; + asds = [ "portable-threads" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/portable-threads/2021-05-31/portable-threads-20210531-git.tgz"; + sha256 = "05y00mlvwlfas4jj50qas2v2rxa0hyc9834lpnbh61a3g8sz0d1f"; + system = "portable-threads"; + asd = "portable-threads"; + } + ); + systems = [ "portable-threads" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + portal = ( + build-asdf-system { + pname = "portal"; + version = "20211209-git"; + asds = [ "portal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/portal/2021-12-09/portal-20211209-git.tgz"; + sha256 = "1012jc068qdd8df6mmbn8vmmqlniqm5j2jbyrraw3yz8c13c8280"; + system = "portal"; + asd = "portal"; + } + ); + systems = [ "portal" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "arrows" self) + (getAttr "cl-base64" self) + (getAttr "flexi-streams" self) + (getAttr "global-vars" self) + (getAttr "ironclad" self) + (getAttr "parse-float" self) + (getAttr "str" self) + (getAttr "usocket-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + portmanteau = ( + build-asdf-system { + pname = "portmanteau"; + version = "20181018-git"; + asds = [ "portmanteau" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-portmanteau/2018-10-18/cl-portmanteau-20181018-git.tgz"; + sha256 = "0430yixy722zkiljc6kh68hx2pyf2pbylgyp7n4qnnky86c0z0ip"; + system = "portmanteau"; + asd = "portmanteau"; + } + ); + systems = [ "portmanteau" ]; + lispLibs = [ (getAttr "vom" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + portmanteau-tests = ( + build-asdf-system { + pname = "portmanteau-tests"; + version = "20181018-git"; + asds = [ "portmanteau-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-portmanteau/2018-10-18/cl-portmanteau-20181018-git.tgz"; + sha256 = "0430yixy722zkiljc6kh68hx2pyf2pbylgyp7n4qnnky86c0z0ip"; + system = "portmanteau-tests"; + asd = "portmanteau-tests"; + } + ); + systems = [ "portmanteau-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "portmanteau" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + positional-lambda = ( + build-asdf-system { + pname = "positional-lambda"; + version = "2.0"; + asds = [ "positional-lambda" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/positional-lambda/2012-10-13/positional-lambda-2.0.tgz"; + sha256 = "00jbr42czv7piza5sm5hmmls7xnhq1pnzl09j6c28xrknr61cj8r"; + system = "positional-lambda"; + asd = "positional-lambda"; + } + ); + systems = [ "positional-lambda" ]; + lispLibs = [ (getAttr "map-bind" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + posix-shm = ( + build-asdf-system { + pname = "posix-shm"; + version = "20231021-git"; + asds = [ "posix-shm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/posix-shm/2023-10-21/posix-shm-20231021-git.tgz"; + sha256 = "0ah7xh7dxvdk58slic60gx7k56idjw5x30q5ifg90hxfhd32qz6l"; + system = "posix-shm"; + asd = "posix-shm"; + } + ); + systems = [ "posix-shm" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + postmodern = ( + build-asdf-system { + pname = "postmodern"; + version = "20241012-git"; + asds = [ "postmodern" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/postmodern/2024-10-12/postmodern-20241012-git.tgz"; + sha256 = "1hj0dpclzihy1rcnwhiv16abmaa54wygxyib3j2h9q4qs26w7pzb"; + system = "postmodern"; + asd = "postmodern"; + } + ); + systems = [ "postmodern" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-postgres" self) + (getAttr "closer-mop" self) + (getAttr "global-vars" self) + (getAttr "s-sql" self) + (getAttr "split-sequence" self) + ]; + meta = { }; + } + ); + postmodernity = ( + build-asdf-system { + pname = "postmodernity"; + version = "20170124-git"; + asds = [ "postmodernity" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/postmodernity/2017-01-24/postmodernity-20170124-git.tgz"; + sha256 = "06mwlp79dgzsgfhgbhvqk4691nm52v3lqm99y72dm7pm4gmc2m9m"; + system = "postmodernity"; + asd = "postmodernity"; + } + ); + systems = [ "postmodernity" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "postmodern" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + postoffice = ( + build-asdf-system { + pname = "postoffice"; + version = "20120909-git"; + asds = [ "postoffice" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/postoffice/2012-09-09/postoffice-20120909-git.tgz"; + sha256 = "041k8nc969xyjdmbn6348pra3v5jb1sw4mrnxmamv0flngyv12fg"; + system = "postoffice"; + asd = "postoffice"; + } + ); + systems = [ "postoffice" ]; + lispLibs = [ (getAttr "acl-compat" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pounds = ( + build-asdf-system { + pname = "pounds"; + version = "20160208-git"; + asds = [ "pounds" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pounds/2016-02-08/pounds-20160208-git.tgz"; + sha256 = "17hz0ywzfirmlwkrd9zrbl07ihhm03zhzqrz3rkmh1j9v95sy2kl"; + system = "pounds"; + asd = "pounds"; + } + ); + systems = [ "pounds" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "nibbles" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pp-toml = ( + build-asdf-system { + pname = "pp-toml"; + version = "20221106-git"; + asds = [ "pp-toml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pp-toml/2022-11-06/pp-toml-20221106-git.tgz"; + sha256 = "136d7jzz7l2ck9wwld0ac46jmpm94lvja6m50sy73s232slka2hg"; + system = "pp-toml"; + asd = "pp-toml"; + } + ); + systems = [ "pp-toml" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "esrap" self) + (getAttr "generic-comparability" self) + (getAttr "local-time" self) + (getAttr "parse-number" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pp-toml-tests = ( + build-asdf-system { + pname = "pp-toml-tests"; + version = "20221106-git"; + asds = [ "pp-toml-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pp-toml/2022-11-06/pp-toml-20221106-git.tgz"; + sha256 = "136d7jzz7l2ck9wwld0ac46jmpm94lvja6m50sy73s232slka2hg"; + system = "pp-toml-tests"; + asd = "pp-toml-tests"; + } + ); + systems = [ "pp-toml-tests" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "esrap" self) + (getAttr "fiveam" self) + (getAttr "generic-comparability" self) + (getAttr "local-time" self) + (getAttr "parse-number" self) + (getAttr "pp-toml" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ppath = ( + build-asdf-system { + pname = "ppath"; + version = "20241012-git"; + asds = [ "ppath" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ppath/2024-10-12/ppath-20241012-git.tgz"; + sha256 = "122h2xlr9435gjim567cyry13ylbsixziy5bi1n4lzpfjnkq68qg"; + system = "ppath"; + asd = "ppath"; + } + ); + systems = [ "ppath" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + (getAttr "osicat" self) + (getAttr "split-sequence" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ppath-test = ( + build-asdf-system { + pname = "ppath-test"; + version = "20241012-git"; + asds = [ "ppath-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ppath/2024-10-12/ppath-20241012-git.tgz"; + sha256 = "122h2xlr9435gjim567cyry13ylbsixziy5bi1n4lzpfjnkq68qg"; + system = "ppath-test"; + asd = "ppath-test"; + } + ); + systems = [ "ppath-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fad" self) + (getAttr "ppath" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + practical-cl = ( + build-asdf-system { + pname = "practical-cl"; + version = "20180430-git"; + asds = [ "practical-cl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/practical-cl/2018-04-30/practical-cl-20180430-git.tgz"; + sha256 = "0bjwnnxkqw0cf2p1fyx9ihy6hgsxhljm4bns2blvgv63s3j1znd9"; + system = "practical-cl"; + asd = "practical-cl"; + } + ); + systems = [ "practical-cl" ]; + lispLibs = [ + (getAttr "pcl-binary-data" self) + (getAttr "pcl-html" self) + (getAttr "pcl-id3v2" self) + (getAttr "pcl-macro-utilities" self) + (getAttr "pcl-mp3-browser" self) + (getAttr "pcl-mp3-database" self) + (getAttr "pcl-pathnames" self) + (getAttr "pcl-shoutcast" self) + (getAttr "pcl-simple-database" self) + (getAttr "pcl-spam" self) + (getAttr "pcl-test-framework" self) + (getAttr "pcl-url-function" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prbs = ( + build-asdf-system { + pname = "prbs"; + version = "20180228-git"; + asds = [ "prbs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prbs/2018-02-28/prbs-20180228-git.tgz"; + sha256 = "0qbvbmxa66b367z9px4nyxqb21b9w2hr82rw7hfq5aynmwfk3fzi"; + system = "prbs"; + asd = "prbs"; + } + ); + systems = [ "prbs" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prbs-docs = ( + build-asdf-system { + pname = "prbs-docs"; + version = "20180228-git"; + asds = [ "prbs-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prbs/2018-02-28/prbs-20180228-git.tgz"; + sha256 = "0qbvbmxa66b367z9px4nyxqb21b9w2hr82rw7hfq5aynmwfk3fzi"; + system = "prbs-docs"; + asd = "prbs-docs"; + } + ); + systems = [ "prbs-docs" ]; + lispLibs = [ + (getAttr "cl-gendoc" self) + (getAttr "prbs" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + precise-time = ( + build-asdf-system { + pname = "precise-time"; + version = "20241012-git"; + asds = [ "precise-time" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/precise-time/2024-10-12/precise-time-20241012-git.tgz"; + sha256 = "114ix5nldfg301g0af8lsnc129i7hnhgdzmnznda2fv92zf3vn8g"; + system = "precise-time"; + asd = "precise-time"; + } + ); + systems = [ "precise-time" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pregexp = ( + build-asdf-system { + pname = "pregexp"; + version = "20241012-git"; + asds = [ "pregexp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pregexp/2024-10-12/pregexp-20241012-git.tgz"; + sha256 = "10l9hj7a812km1hygg6iwwl1bf8jgsfyfr1ixj7bif8k8502h4nz"; + system = "pregexp"; + asd = "pregexp"; + } + ); + systems = [ "pregexp" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prepl = ( + build-asdf-system { + pname = "prepl"; + version = "20231021-git"; + asds = [ "prepl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prepl/2023-10-21/prepl-20231021-git.tgz"; + sha256 = "0sbqlqbk9xrl30iklp3vs493zq4bc2nxv6q435cspicwz6igbjdw"; + system = "prepl"; + asd = "prepl"; + } + ); + systems = [ "prepl" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "conium" self) + (getAttr "iterate" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prettier-builtins = ( + build-asdf-system { + pname = "prettier-builtins"; + version = "20231021-git"; + asds = [ "prettier-builtins" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prettier-builtins/2023-10-21/prettier-builtins-20231021-git.tgz"; + sha256 = "15lbf0zi1vxqpxwsfgkq7dlg5c9m1b2a4hvcfm3qlh9ir7ahggck"; + system = "prettier-builtins"; + asd = "prettier-builtins"; + } + ); + systems = [ "prettier-builtins" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pretty-function = ( + build-asdf-system { + pname = "pretty-function"; + version = "20130615-git"; + asds = [ "pretty-function" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pretty-function/2013-06-15/pretty-function-20130615-git.tgz"; + sha256 = "1hzfjwsp6r5nki6h8kry8k2bgj19mrp0jbq7jhsz3kz6y4ll0hb5"; + system = "pretty-function"; + asd = "pretty-function"; + } + ); + systems = [ "pretty-function" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + primecount = ( + build-asdf-system { + pname = "primecount"; + version = "20200325-git"; + asds = [ "primecount" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/primecount/2020-03-25/primecount-20200325-git.tgz"; + sha256 = "1fw855qp82b887azww7z3yhd2zafaxjnzyff1ldf2wa6mb4f0dj8"; + system = "primecount"; + asd = "primecount"; + } + ); + systems = [ "primecount" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + print-html = ( + build-asdf-system { + pname = "print-html"; + version = "20181018-git"; + asds = [ "print-html" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/print-html/2018-10-18/print-html-20181018-git.tgz"; + sha256 = "1ihr2yy6fvli3awrkfn4v8pm41wab5wsj30v84rr75v4p5irqmz8"; + system = "print-html"; + asd = "print-html"; + } + ); + systems = [ "print-html" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + print-licenses = ( + build-asdf-system { + pname = "print-licenses"; + version = "20230618-git"; + asds = [ "print-licenses" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/print-licenses/2023-06-18/print-licenses-20230618-git.tgz"; + sha256 = "14i6r6mf16dlj1g4xk0alg2912y3wy0qbfpyvvgsgxkkar63cmi5"; + system = "print-licenses"; + asd = "print-licenses"; + } + ); + systems = [ "print-licenses" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + printv = ( + build-asdf-system { + pname = "printv"; + version = "20211230-git"; + asds = [ "printv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/printv/2021-12-30/printv-20211230-git.tgz"; + sha256 = "07agyzkwp3w2r4d2anrmr8h00yngpr5dq9mjd3m4kzhn1jcmilfb"; + system = "printv"; + asd = "printv"; + } + ); + systems = [ "printv" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + priority-queue = ( + build-asdf-system { + pname = "priority-queue"; + version = "20150709-git"; + asds = [ "priority-queue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/priority-queue/2015-07-09/priority-queue-20150709-git.tgz"; + sha256 = "0y5a1fid8xzzl58hfdj64n8mrzq0kr06a0lnmdjpgi0czc3x0jcy"; + system = "priority-queue"; + asd = "priority-queue"; + } + ); + systems = [ "priority-queue" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + priority-queue-benchmark = ( + build-asdf-system { + pname = "priority-queue-benchmark"; + version = "20241012-git"; + asds = [ "priority-queue-benchmark" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/damn-fast-priority-queue/2024-10-12/damn-fast-priority-queue-20241012-git.tgz"; + sha256 = "1mbigpgi7qbqvpj59l1f7p2qcg00ybvqzdca1j1b9hx62h224ndw"; + system = "priority-queue-benchmark"; + asd = "priority-queue-benchmark"; + } + ); + systems = [ "priority-queue-benchmark" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bodge-heap" self) + (getAttr "cl-heap" self) + (getAttr "damn-fast-priority-queue" self) + (getAttr "damn-fast-stable-priority-queue" self) + (getAttr "heap" self) + (getAttr "minheap" self) + (getAttr "pettomato-indexed-priority-queue" self) + (getAttr "pileup" self) + (getAttr "priority-queue" self) + (getAttr "queues_dot_priority-queue" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + proc-parse = ( + build-asdf-system { + pname = "proc-parse"; + version = "20190813-git"; + asds = [ "proc-parse" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/proc-parse/2019-08-13/proc-parse-20190813-git.tgz"; + sha256 = "07vbj26bfq4ywlcmamsqyac29rsdsa8lamjqx1ycla1bcvgmi4w2"; + system = "proc-parse"; + asd = "proc-parse"; + } + ); + systems = [ "proc-parse" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + ]; + meta = { }; + } + ); + proc-parse-test = ( + build-asdf-system { + pname = "proc-parse-test"; + version = "20190813-git"; + asds = [ "proc-parse-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/proc-parse/2019-08-13/proc-parse-20190813-git.tgz"; + sha256 = "07vbj26bfq4ywlcmamsqyac29rsdsa8lamjqx1ycla1bcvgmi4w2"; + system = "proc-parse-test"; + asd = "proc-parse-test"; + } + ); + systems = [ "proc-parse-test" ]; + lispLibs = [ + (getAttr "proc-parse" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + progressons = ( + build-asdf-system { + pname = "progressons"; + version = "20241012-git"; + asds = [ "progressons" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/progressons/2024-10-12/progressons-20241012-git.tgz"; + sha256 = "1i93khd0l1aphzh6qb4yy9cpi2nmqac08b90yx95p4zymap03nly"; + system = "progressons"; + asd = "progressons"; + } + ); + systems = [ "progressons" ]; + lispLibs = [ + (getAttr "cl-ansi-text" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + projectured_dot_document = ( + build-asdf-system { + pname = "projectured.document"; + version = "quicklisp-c3a60e76-git"; + asds = [ "projectured.document" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; + sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; + system = "projectured.document"; + asd = "projectured.document"; + } + ); + systems = [ "projectured.document" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "parse-number" self) + (getAttr "projectured_dot_editor" self) + (getAttr "s-xml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + projectured_dot_editor = ( + build-asdf-system { + pname = "projectured.editor"; + version = "quicklisp-c3a60e76-git"; + asds = [ "projectured.editor" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; + sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; + system = "projectured.editor"; + asd = "projectured.editor"; + } + ); + systems = [ "projectured.editor" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_common" self) + (getAttr "hu_dot_dwim_dot_def" self) + (getAttr "hu_dot_dwim_dot_defclass-star" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_serializer" self) + (getAttr "hu_dot_dwim_dot_syntax-sugar" self) + (getAttr "hu_dot_dwim_dot_util" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + projectured_dot_executable = ( + build-asdf-system { + pname = "projectured.executable"; + version = "quicklisp-c3a60e76-git"; + asds = [ "projectured.executable" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; + sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; + system = "projectured.executable"; + asd = "projectured.executable"; + } + ); + systems = [ "projectured.executable" ]; + lispLibs = [ + (getAttr "command-line-arguments" self) + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "projectured_dot_sdl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + projectured_dot_projection = ( + build-asdf-system { + pname = "projectured.projection"; + version = "quicklisp-c3a60e76-git"; + asds = [ "projectured.projection" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; + sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; + system = "projectured.projection"; + asd = "projectured.projection"; + } + ); + systems = [ "projectured.projection" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "projectured_dot_document" self) + (getAttr "projectured_dot_editor" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + projectured_dot_sdl = ( + build-asdf-system { + pname = "projectured.sdl"; + version = "quicklisp-c3a60e76-git"; + asds = [ "projectured.sdl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; + sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; + system = "projectured.sdl"; + asd = "projectured.sdl"; + } + ); + systems = [ "projectured.sdl" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_sdl" self) + (getAttr "projectured_dot_document" self) + (getAttr "projectured_dot_editor" self) + (getAttr "projectured_dot_projection" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + projectured_dot_sdl_dot_test = ( + build-asdf-system { + pname = "projectured.sdl.test"; + version = "quicklisp-c3a60e76-git"; + asds = [ "projectured.sdl.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; + sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; + system = "projectured.sdl.test"; + asd = "projectured.sdl.test"; + } + ); + systems = [ "projectured.sdl.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "projectured_dot_sdl" self) + (getAttr "projectured_dot_test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + projectured_dot_swank = ( + build-asdf-system { + pname = "projectured.swank"; + version = "quicklisp-c3a60e76-git"; + asds = [ "projectured.swank" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; + sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; + system = "projectured.swank"; + asd = "projectured.swank"; + } + ); + systems = [ "projectured.swank" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "projectured_dot_editor" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + projectured_dot_test = ( + build-asdf-system { + pname = "projectured.test"; + version = "quicklisp-c3a60e76-git"; + asds = [ "projectured.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/projectured/2017-12-27/projectured-quicklisp-c3a60e76-git.tgz"; + sha256 = "1gbsqaw571xgh2glg4386545b5sqjgbaiqa3x4j1gr70kirbzydn"; + system = "projectured.test"; + asd = "projectured.test"; + } + ); + systems = [ "projectured.test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_asdf" self) + (getAttr "hu_dot_dwim_dot_logger" self) + (getAttr "hu_dot_dwim_dot_stefil_plus_hu_dot_dwim_dot_def_plus_swank" self) + (getAttr "projectured_dot_document" self) + (getAttr "projectured_dot_editor" self) + (getAttr "projectured_dot_projection" self) + (getAttr "projectured_dot_swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus = ( + build-asdf-system { + pname = "prometheus"; + version = "20201220-git"; + asds = [ "prometheus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus"; + asd = "prometheus"; + } + ); + systems = [ "prometheus" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "local-time" self) + (getAttr "quantile-estimator" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus-gc = ( + build-asdf-system { + pname = "prometheus-gc"; + version = "20241012-git"; + asds = [ "prometheus-gc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus-gc/2024-10-12/prometheus-gc-20241012-git.tgz"; + sha256 = "0lfdh7j7jzklhr76fdw1z3a777h5sr5c9h1i6nv1knnm36l44zpj"; + system = "prometheus-gc"; + asd = "prometheus-gc"; + } + ); + systems = [ "prometheus-gc" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "prometheus" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus-gc-ci = ( + build-asdf-system { + pname = "prometheus-gc-ci"; + version = "20241012-git"; + asds = [ "prometheus-gc-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus-gc/2024-10-12/prometheus-gc-20241012-git.tgz"; + sha256 = "0lfdh7j7jzklhr76fdw1z3a777h5sr5c9h1i6nv1knnm36l44zpj"; + system = "prometheus-gc-ci"; + asd = "prometheus-gc-ci"; + } + ); + systems = [ "prometheus-gc-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus-gc-tests = ( + build-asdf-system { + pname = "prometheus-gc-tests"; + version = "20241012-git"; + asds = [ "prometheus-gc-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus-gc/2024-10-12/prometheus-gc-20241012-git.tgz"; + sha256 = "0lfdh7j7jzklhr76fdw1z3a777h5sr5c9h1i6nv1knnm36l44zpj"; + system = "prometheus-gc-tests"; + asd = "prometheus-gc-tests"; + } + ); + systems = [ "prometheus-gc-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_collectors_dot_process = ( + build-asdf-system { + pname = "prometheus.collectors.process"; + version = "20201220-git"; + asds = [ "prometheus.collectors.process" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.collectors.process"; + asd = "prometheus.collectors.process"; + } + ); + systems = [ "prometheus.collectors.process" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-fad" self) + (getAttr "prometheus" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_collectors_dot_process_dot_test = ( + build-asdf-system { + pname = "prometheus.collectors.process.test"; + version = "20201220-git"; + asds = [ "prometheus.collectors.process.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.collectors.process.test"; + asd = "prometheus.collectors.process.test"; + } + ); + systems = [ "prometheus.collectors.process.test" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "log4cl" self) + (getAttr "mw-equiv" self) + (getAttr "prometheus_dot_collectors_dot_process" self) + (getAttr "prometheus_dot_test_dot_support" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_collectors_dot_sbcl = ( + build-asdf-system { + pname = "prometheus.collectors.sbcl"; + version = "20201220-git"; + asds = [ "prometheus.collectors.sbcl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.collectors.sbcl"; + asd = "prometheus.collectors.sbcl"; + } + ); + systems = [ "prometheus.collectors.sbcl" ]; + lispLibs = [ (getAttr "prometheus" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_collectors_dot_sbcl_dot_test = ( + build-asdf-system { + pname = "prometheus.collectors.sbcl.test"; + version = "20201220-git"; + asds = [ "prometheus.collectors.sbcl.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.collectors.sbcl.test"; + asd = "prometheus.collectors.sbcl.test"; + } + ); + systems = [ "prometheus.collectors.sbcl.test" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "log4cl" self) + (getAttr "mw-equiv" self) + (getAttr "prometheus_dot_collectors_dot_sbcl" self) + (getAttr "prometheus_dot_test_dot_support" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_examples = ( + build-asdf-system { + pname = "prometheus.examples"; + version = "20201220-git"; + asds = [ "prometheus.examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.examples"; + asd = "prometheus.examples"; + } + ); + systems = [ "prometheus.examples" ]; + lispLibs = [ + (getAttr "prometheus" self) + (getAttr "prometheus_dot_collectors_dot_process" self) + (getAttr "prometheus_dot_collectors_dot_sbcl" self) + (getAttr "prometheus_dot_exposers_dot_hunchentoot" self) + (getAttr "prometheus_dot_formats_dot_text" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_exposers_dot_hunchentoot = ( + build-asdf-system { + pname = "prometheus.exposers.hunchentoot"; + version = "20201220-git"; + asds = [ "prometheus.exposers.hunchentoot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.exposers.hunchentoot"; + asd = "prometheus.exposers.hunchentoot"; + } + ); + systems = [ "prometheus.exposers.hunchentoot" ]; + lispLibs = [ + (getAttr "hunchentoot" self) + (getAttr "prometheus" self) + (getAttr "prometheus_dot_formats_dot_text" self) + (getAttr "salza2" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_exposers_dot_hunchentoot_dot_test = ( + build-asdf-system { + pname = "prometheus.exposers.hunchentoot.test"; + version = "20201220-git"; + asds = [ "prometheus.exposers.hunchentoot.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.exposers.hunchentoot.test"; + asd = "prometheus.exposers.hunchentoot.test"; + } + ); + systems = [ "prometheus.exposers.hunchentoot.test" ]; + lispLibs = [ + (getAttr "chipz" self) + (getAttr "cl-interpol" self) + (getAttr "drakma" self) + (getAttr "log4cl" self) + (getAttr "mw-equiv" self) + (getAttr "prometheus_dot_exposers_dot_hunchentoot" self) + (getAttr "prometheus_dot_formats_dot_text" self) + (getAttr "prometheus_dot_test_dot_support" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_formats_dot_text = ( + build-asdf-system { + pname = "prometheus.formats.text"; + version = "20201220-git"; + asds = [ "prometheus.formats.text" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.formats.text"; + asd = "prometheus.formats.text"; + } + ); + systems = [ "prometheus.formats.text" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "prometheus" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_formats_dot_text_dot_test = ( + build-asdf-system { + pname = "prometheus.formats.text.test"; + version = "20201220-git"; + asds = [ "prometheus.formats.text.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.formats.text.test"; + asd = "prometheus.formats.text.test"; + } + ); + systems = [ "prometheus.formats.text.test" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "log4cl" self) + (getAttr "mw-equiv" self) + (getAttr "prometheus_dot_formats_dot_text" self) + (getAttr "prometheus_dot_test_dot_support" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_pushgateway = ( + build-asdf-system { + pname = "prometheus.pushgateway"; + version = "20201220-git"; + asds = [ "prometheus.pushgateway" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.pushgateway"; + asd = "prometheus.pushgateway"; + } + ); + systems = [ "prometheus.pushgateway" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "prometheus" self) + (getAttr "prometheus_dot_formats_dot_text" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_pushgateway_dot_test = ( + build-asdf-system { + pname = "prometheus.pushgateway.test"; + version = "20201220-git"; + asds = [ "prometheus.pushgateway.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.pushgateway.test"; + asd = "prometheus.pushgateway.test"; + } + ); + systems = [ "prometheus.pushgateway.test" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "hunchentoot" self) + (getAttr "log4cl" self) + (getAttr "mw-equiv" self) + (getAttr "prometheus_dot_pushgateway" self) + (getAttr "prometheus_dot_test_dot_support" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_test = ( + build-asdf-system { + pname = "prometheus.test"; + version = "20201220-git"; + asds = [ "prometheus.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.test"; + asd = "prometheus.test"; + } + ); + systems = [ "prometheus.test" ]; + lispLibs = [ + (getAttr "cl-interpol" self) + (getAttr "log4cl" self) + (getAttr "mw-equiv" self) + (getAttr "prometheus" self) + (getAttr "prometheus_dot_test_dot_support" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_test_dot_all = ( + build-asdf-system { + pname = "prometheus.test.all"; + version = "20201220-git"; + asds = [ "prometheus.test.all" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.test.all"; + asd = "prometheus.test.all"; + } + ); + systems = [ "prometheus.test.all" ]; + lispLibs = [ + (getAttr "cl-coveralls" self) + (getAttr "prometheus_dot_collectors_dot_process_dot_test" self) + (getAttr "prometheus_dot_collectors_dot_sbcl_dot_test" self) + (getAttr "prometheus_dot_exposers_dot_hunchentoot_dot_test" self) + (getAttr "prometheus_dot_formats_dot_text_dot_test" self) + (getAttr "prometheus_dot_pushgateway_dot_test" self) + (getAttr "prometheus_dot_test" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prometheus_dot_test_dot_support = ( + build-asdf-system { + pname = "prometheus.test.support"; + version = "20201220-git"; + asds = [ "prometheus.test.support" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prometheus.cl/2020-12-20/prometheus.cl-20201220-git.tgz"; + sha256 = "15ab4c7yfm83nmfvaq5kbsqrgx558k292szm9frfda7nlycfnmyp"; + system = "prometheus.test.support"; + asd = "prometheus.test.support"; + } + ); + systems = [ "prometheus.test.support" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "prometheus" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + promise = ( + build-asdf-system { + pname = "promise"; + version = "20231021-git"; + asds = [ "promise" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/promise/2023-10-21/promise-20231021-git.tgz"; + sha256 = "1xm10s89a2f7ydzayjgg94y9plrz1jnyvi6yzhk5v3vrbnmpggh1"; + system = "promise"; + asd = "promise"; + } + ); + systems = [ "promise" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + promise-test = ( + build-asdf-system { + pname = "promise-test"; + version = "20231021-git"; + asds = [ "promise-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/promise/2023-10-21/promise-20231021-git.tgz"; + sha256 = "1xm10s89a2f7ydzayjgg94y9plrz1jnyvi6yzhk5v3vrbnmpggh1"; + system = "promise-test"; + asd = "promise-test"; + } + ); + systems = [ "promise-test" ]; + lispLibs = [ + (getAttr "parachute" self) + (getAttr "promise" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prompt-for = ( + build-asdf-system { + pname = "prompt-for"; + version = "20220707-git"; + asds = [ "prompt-for" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prompt-for/2022-07-07/prompt-for-20220707-git.tgz"; + sha256 = "1zjc96ryyzsr5519s7yji40askqyymjrbdwx3r2r7bv146siqs5m"; + system = "prompt-for"; + asd = "prompt-for"; + } + ); + systems = [ "prompt-for" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prompt-for_dot_test = ( + build-asdf-system { + pname = "prompt-for.test"; + version = "20220707-git"; + asds = [ "prompt-for.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prompt-for/2022-07-07/prompt-for-20220707-git.tgz"; + sha256 = "1zjc96ryyzsr5519s7yji40askqyymjrbdwx3r2r7bv146siqs5m"; + system = "prompt-for.test"; + asd = "prompt-for.test"; + } + ); + systems = [ "prompt-for.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "prompt-for" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + protest = ( + build-asdf-system { + pname = "protest"; + version = "20201220-git"; + asds = [ "protest" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/protest/2020-12-20/protest-20201220-git.tgz"; + sha256 = "0q7vk7ji4mjd0xfp18sim5daqzgb3k7mmbm93vvwz18bdwy6cj9h"; + system = "protest"; + asd = "protest"; + } + ); + systems = [ "protest" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "moptilities" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + proto = ( + build-asdf-system { + pname = "proto"; + version = "quicklisp-dd18337d-git"; + asds = [ "proto" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gtirb/2021-10-20/gtirb-quicklisp-dd18337d-git.tgz"; + sha256 = "0dpchsshnlh3jb9rg1zdf63mr5l33vhjdxgxx2vqg0nh1sh41zn1"; + system = "proto"; + asd = "gtirb"; + } + ); + systems = [ "proto" ]; + lispLibs = [ (getAttr "protobuf" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + proto-v0 = ( + build-asdf-system { + pname = "proto-v0"; + version = "quicklisp-dd18337d-git"; + asds = [ "proto-v0" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gtirb/2021-10-20/gtirb-quicklisp-dd18337d-git.tgz"; + sha256 = "0dpchsshnlh3jb9rg1zdf63mr5l33vhjdxgxx2vqg0nh1sh41zn1"; + system = "proto-v0"; + asd = "gtirb"; + } + ); + systems = [ "proto-v0" ]; + lispLibs = [ (getAttr "protobuf" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + protobuf = ( + build-asdf-system { + pname = "protobuf"; + version = "20230618-git"; + asds = [ "protobuf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/protobuf/2023-06-18/protobuf-20230618-git.tgz"; + sha256 = "0pp8i2i72p6cng11sxj83klw45jqv05l5024h7c2rl0pvsg8f6bc"; + system = "protobuf"; + asd = "protobuf"; + } + ); + systems = [ "protobuf" ]; + lispLibs = [ + (getAttr "com_dot_google_dot_base" self) + (getAttr "varint" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + protobuf-conformance = ( + build-asdf-system { + pname = "protobuf-conformance"; + version = "20230618-git"; + asds = [ "protobuf-conformance" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/protobuf/2023-06-18/protobuf-20230618-git.tgz"; + sha256 = "0pp8i2i72p6cng11sxj83klw45jqv05l5024h7c2rl0pvsg8f6bc"; + system = "protobuf-conformance"; + asd = "protobuf-conformance"; + } + ); + systems = [ "protobuf-conformance" ]; + lispLibs = [ + (getAttr "com_dot_google_dot_base" self) + (getAttr "nibbles" self) + (getAttr "protobuf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + prove = ( + build-asdf-system { + pname = "prove"; + version = "20200218-git"; + asds = [ "prove" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prove/2020-02-18/prove-20200218-git.tgz"; + sha256 = "0ca6ha3zhmckq3ad9lxm6sbg4i0hg3m81xhan4dkxd3x9898jzpc"; + system = "prove"; + asd = "prove"; + } + ); + systems = [ "prove" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ansi-text" self) + (getAttr "cl-colors" self) + (getAttr "cl-ppcre" self) + ]; + meta = { }; + } + ); + prove-asdf = ( + build-asdf-system { + pname = "prove-asdf"; + version = "20200218-git"; + asds = [ "prove-asdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prove/2020-02-18/prove-20200218-git.tgz"; + sha256 = "0ca6ha3zhmckq3ad9lxm6sbg4i0hg3m81xhan4dkxd3x9898jzpc"; + system = "prove-asdf"; + asd = "prove-asdf"; + } + ); + systems = [ "prove-asdf" ]; + lispLibs = [ ]; + meta = { }; + } + ); + prove-test = ( + build-asdf-system { + pname = "prove-test"; + version = "20200218-git"; + asds = [ "prove-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/prove/2020-02-18/prove-20200218-git.tgz"; + sha256 = "0ca6ha3zhmckq3ad9lxm6sbg4i0hg3m81xhan4dkxd3x9898jzpc"; + system = "prove-test"; + asd = "prove-test"; + } + ); + systems = [ "prove-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pseudonyms = ( + build-asdf-system { + pname = "pseudonyms"; + version = "20200325-git"; + asds = [ "pseudonyms" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pseudonyms/2020-03-25/pseudonyms-20200325-git.tgz"; + sha256 = "0ph7l130hr8gz88gw8i15zbsbq96519srfhzgm6zzkw85vab1ysn"; + system = "pseudonyms"; + asd = "pseudonyms"; + } + ); + systems = [ "pseudonyms" ]; + lispLibs = [ + (getAttr "named-readtables" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + psgraph = ( + build-asdf-system { + pname = "psgraph"; + version = "1.2"; + asds = [ "psgraph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/psgraph/2010-10-06/psgraph-1.2.tgz"; + sha256 = "19x1lvzfj2c2h83y5bng6jsp2300qfvd25mmf157qiss15al22vs"; + system = "psgraph"; + asd = "psgraph"; + } + ); + systems = [ "psgraph" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + psychiq = ( + build-asdf-system { + pname = "psychiq"; + version = "20241012-git"; + asds = [ "psychiq" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/psychiq/2024-10-12/psychiq-20241012-git.tgz"; + sha256 = "1036yyrzvyqszn037y4189h12221mkxdyp0nlyj26qjyil3qizbl"; + system = "psychiq"; + asd = "psychiq"; + } + ); + systems = [ "psychiq" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-redis" self) + (getAttr "cl-reexport" self) + (getAttr "dissect" self) + (getAttr "jonathan" self) + (getAttr "local-time" self) + (getAttr "vom" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + psychiq-test = ( + build-asdf-system { + pname = "psychiq-test"; + version = "20241012-git"; + asds = [ "psychiq-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/psychiq/2024-10-12/psychiq-20241012-git.tgz"; + sha256 = "1036yyrzvyqszn037y4189h12221mkxdyp0nlyj26qjyil3qizbl"; + system = "psychiq-test"; + asd = "psychiq-test"; + } + ); + systems = [ "psychiq-test" ]; + lispLibs = [ + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "psychiq" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ptc = ( + build-asdf-system { + pname = "ptc"; + version = "20231021-git"; + asds = [ "ptc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ptc/2023-10-21/ptc-20231021-git.tgz"; + sha256 = "1r4izrc6dhz3pqpcqn3y0sga4f77s2vzd1xpl8fsr41rfpyiff3x"; + system = "ptc"; + asd = "ptc"; + } + ); + systems = [ "ptc" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ptester = ( + build-asdf-system { + pname = "ptester"; + version = "20160929-git"; + asds = [ "ptester" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ptester/2016-09-29/ptester-20160929-git.tgz"; + sha256 = "1l0lfl7cdnr2qf4zh38hi4llxg22c49zkm639bdkmvlkzwj3ndwf"; + system = "ptester"; + asd = "ptester"; + } + ); + systems = [ "ptester" ]; + lispLibs = [ ]; + meta = { }; + } + ); + punycode = ( + build-asdf-system { + pname = "punycode"; + version = "20231021-git"; + asds = [ "punycode" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/punycode/2023-10-21/punycode-20231021-git.tgz"; + sha256 = "0779aj2bqsz7qb475x5sacr5q254wjar74sab04zfhrlpkgij9xh"; + system = "punycode"; + asd = "punycode"; + } + ); + systems = [ "punycode" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + punycode-test = ( + build-asdf-system { + pname = "punycode-test"; + version = "20231021-git"; + asds = [ "punycode-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/punycode/2023-10-21/punycode-20231021-git.tgz"; + sha256 = "0779aj2bqsz7qb475x5sacr5q254wjar74sab04zfhrlpkgij9xh"; + system = "punycode-test"; + asd = "punycode-test"; + } + ); + systems = [ "punycode-test" ]; + lispLibs = [ + (getAttr "parachute" self) + (getAttr "punycode" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + purgatory = ( + build-asdf-system { + pname = "purgatory"; + version = "20241012-git"; + asds = [ "purgatory" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/purgatory/2024-10-12/purgatory-20241012-git.tgz"; + sha256 = "1srafcpl01a1dv84z3sqc1wl23r8hz1nm3rrmmqiilfh2r4jfw6f"; + system = "purgatory"; + asd = "purgatory"; + } + ); + systems = [ "purgatory" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + purgatory-tests = ( + build-asdf-system { + pname = "purgatory-tests"; + version = "20241012-git"; + asds = [ "purgatory-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/purgatory/2024-10-12/purgatory-20241012-git.tgz"; + sha256 = "1srafcpl01a1dv84z3sqc1wl23r8hz1nm3rrmmqiilfh2r4jfw6f"; + system = "purgatory-tests"; + asd = "purgatory-tests"; + } + ); + systems = [ "purgatory-tests" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl_plus_ssl" self) + (getAttr "cl-ppcre" self) + (getAttr "clunit2" self) + (getAttr "purgatory" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + puri = ( + build-asdf-system { + pname = "puri"; + version = "20201016-git"; + asds = [ "puri" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/puri/2020-10-16/puri-20201016-git.tgz"; + sha256 = "0gq2rsr0aihs0z20v4zqvmdl4szq53b52rh97pvnmwrlbn4mapmd"; + system = "puri"; + asd = "puri"; + } + ); + systems = [ "puri" ]; + lispLibs = [ ]; + meta = { }; + } + ); + purl = ( + build-asdf-system { + pname = "purl"; + version = "20160929-git"; + asds = [ "purl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/purl/2016-09-29/purl-20160929-git.tgz"; + sha256 = "1fw3ip4b7n3q6kimh683apg381p7y4w6s4mb8mmv9n3dw0p0sdww"; + system = "purl"; + asd = "purl"; + } + ); + systems = [ "purl" ]; + lispLibs = [ + (getAttr "maxpc" self) + (getAttr "percent-encoding" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pvars = ( + build-asdf-system { + pname = "pvars"; + version = "20210228-git"; + asds = [ "pvars" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pvars/2021-02-28/pvars-20210228-git.tgz"; + sha256 = "1x9mmz53sj0mgd288pa65x963mrd27sw47a8vbggsc4ykwacqf1d"; + system = "pvars"; + asd = "pvars"; + } + ); + systems = [ "pvars" ]; + lispLibs = [ + (getAttr "cl-store" self) + (getAttr "global-vars" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + py-configparser = ( + build-asdf-system { + pname = "py-configparser"; + version = "20170830-svn"; + asds = [ "py-configparser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/py-configparser/2017-08-30/py-configparser-20170830-svn.tgz"; + sha256 = "1mpzhrys1b1mp1kp2xvryl6v01gfqfccb1zdiib49nf4bms4irvw"; + system = "py-configparser"; + asd = "py-configparser"; + } + ); + systems = [ "py-configparser" ]; + lispLibs = [ (getAttr "parse-number" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + py4cl = ( + build-asdf-system { + pname = "py4cl"; + version = "20241012-git"; + asds = [ "py4cl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/py4cl/2024-10-12/py4cl-20241012-git.tgz"; + sha256 = "0i2zg58zgcyw68m846sqwjb77mvps766xlp30i65h18plc8yqmpg"; + system = "py4cl"; + asd = "py4cl"; + } + ); + systems = [ "py4cl" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "numpy-file-format" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + py4cl2 = ( + build-asdf-system { + pname = "py4cl2"; + version = "v2.9.3"; + asds = [ "py4cl2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/py4cl2/2024-10-12/py4cl2-v2.9.3.tgz"; + sha256 = "0g7qhwnyi1la22k90z8993q8knr117f40jk73wjsvixicqc4awqq"; + system = "py4cl2"; + asd = "py4cl2"; + } + ); + systems = [ "py4cl2" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-json" self) + (getAttr "float-features" self) + (getAttr "iterate" self) + (getAttr "numpy-file-format" self) + (getAttr "parse-number" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + py4cl2-cffi = ( + build-asdf-system { + pname = "py4cl2-cffi"; + version = "20241012-git"; + asds = [ "py4cl2-cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/py4cl2-cffi/2024-10-12/py4cl2-cffi-20241012-git.tgz"; + sha256 = "12ggqz8ibbzsmym51yfd19dlw751s7a1i6ra4z8m2ml3zw1k63zr"; + system = "py4cl2-cffi"; + asd = "py4cl2-cffi"; + } + ); + systems = [ "py4cl2-cffi" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + (getAttr "float-features" self) + (getAttr "iterate" self) + (getAttr "optima" self) + (getAttr "parse-number" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + pythonic-string-reader = ( + build-asdf-system { + pname = "pythonic-string-reader"; + version = "20180711-git"; + asds = [ "pythonic-string-reader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pythonic-string-reader/2018-07-11/pythonic-string-reader-20180711-git.tgz"; + sha256 = "1b5iryqw8xsh36swckmz8rrngmc39k92si33fgy5pml3n9l5rq3j"; + system = "pythonic-string-reader"; + asd = "pythonic-string-reader"; + } + ); + systems = [ "pythonic-string-reader" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { }; + } + ); + pzmq = ( + build-asdf-system { + pname = "pzmq"; + version = "20210531-git"; + asds = [ "pzmq" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pzmq/2021-05-31/pzmq-20210531-git.tgz"; + sha256 = "19mdhxhzzghlmff1fic4chg5iz0psglkim09z6dgpijm26biny05"; + system = "pzmq"; + asd = "pzmq"; + } + ); + systems = [ "pzmq" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { }; + } + ); + pzmq-compat = ( + build-asdf-system { + pname = "pzmq-compat"; + version = "20210531-git"; + asds = [ "pzmq-compat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pzmq/2021-05-31/pzmq-20210531-git.tgz"; + sha256 = "19mdhxhzzghlmff1fic4chg5iz0psglkim09z6dgpijm26biny05"; + system = "pzmq-compat"; + asd = "pzmq"; + } + ); + systems = [ "pzmq-compat" ]; + lispLibs = [ (getAttr "pzmq" self) ]; + meta = { }; + } + ); + pzmq-examples = ( + build-asdf-system { + pname = "pzmq-examples"; + version = "20210531-git"; + asds = [ "pzmq-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pzmq/2021-05-31/pzmq-20210531-git.tgz"; + sha256 = "19mdhxhzzghlmff1fic4chg5iz0psglkim09z6dgpijm26biny05"; + system = "pzmq-examples"; + asd = "pzmq"; + } + ); + systems = [ "pzmq-examples" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "iterate" self) + (getAttr "local-time" self) + (getAttr "pzmq" self) + (getAttr "split-sequence" self) + ]; + meta = { }; + } + ); + pzmq-test = ( + build-asdf-system { + pname = "pzmq-test"; + version = "20210531-git"; + asds = [ "pzmq-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/pzmq/2021-05-31/pzmq-20210531-git.tgz"; + sha256 = "19mdhxhzzghlmff1fic4chg5iz0psglkim09z6dgpijm26biny05"; + system = "pzmq-test"; + asd = "pzmq"; + } + ); + systems = [ "pzmq-test" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "fiveam" self) + (getAttr "let-plus" self) + (getAttr "pzmq" self) + ]; + meta = { }; + } + ); + q_plus = ( + build-asdf-system { + pname = "q+"; + version = "20230214-git"; + asds = [ "q+" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; + sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; + system = "q+"; + asd = "q+"; + } + ); + systems = [ "q+" ]; + lispLibs = [ (getAttr "qtools" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qbase64 = ( + build-asdf-system { + pname = "qbase64"; + version = "20220220-git"; + asds = [ "qbase64" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qbase64/2022-02-20/qbase64-20220220-git.tgz"; + sha256 = "06daqqfdd51wkx0pyxgz7zq4ibzsqsgn3qs04jabx67gyybgnmjm"; + system = "qbase64"; + asd = "qbase64"; + } + ); + systems = [ "qbase64" ]; + lispLibs = [ + (getAttr "metabang-bind" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qbook = ( + build-asdf-system { + pname = "qbook"; + version = "20130312-darcs"; + asds = [ "qbook" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qbook/2013-03-12/qbook-20130312-darcs.tgz"; + sha256 = "0l5hc2v73416jpwc2nsnj03z85fisirgm4av2anvlpv5m1291p6g"; + system = "qbook"; + asd = "qbook"; + } + ); + systems = [ "qbook" ]; + lispLibs = [ + (getAttr "arnesi" self) + (getAttr "cl-ppcre" self) + (getAttr "iterate" self) + (getAttr "yaclml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qimageblitz = ( + build-asdf-system { + pname = "qimageblitz"; + version = "20210531-git"; + asds = [ "qimageblitz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qimageblitz"; + asd = "qimageblitz"; + } + ); + systems = [ "qimageblitz" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ql-checkout = ( + build-asdf-system { + pname = "ql-checkout"; + version = "20190521-git"; + asds = [ "ql-checkout" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ql-checkout/2019-05-21/ql-checkout-20190521-git.tgz"; + sha256 = "1zp3wa7g1wn7sypfsla7510ywvldqavlmv90pncanwpwn79klyhw"; + system = "ql-checkout"; + asd = "ql-checkout"; + } + ); + systems = [ "ql-checkout" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qlot = ( + build-asdf-system { + pname = "qlot"; + version = "1.5.14"; + asds = [ "qlot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qlot/2024-10-12/qlot-1.5.14.tgz"; + sha256 = "15rg8gjwisi2gp7a0pfgdvs9mjs1xxff0a58b14nm8sf11cdggkr"; + system = "qlot"; + asd = "qlot"; + } + ); + systems = [ "qlot" ]; + lispLibs = [ + (getAttr "archive" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl_plus_ssl" self) + (getAttr "deflate" self) + (getAttr "dexador" self) + (getAttr "fuzzy-match" self) + (getAttr "ironclad" self) + (getAttr "lparallel" self) + (getAttr "quri" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qmynd = ( + build-asdf-system { + pname = "qmynd"; + version = "20190710-git"; + asds = [ "qmynd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qmynd/2019-07-10/qmynd-20190710-git.tgz"; + sha256 = "06gw5wxcpdclb6a5i5k9lbmdlyqsp182czrm9bm1cpklzbj0ihrl"; + system = "qmynd"; + asd = "qmynd"; + } + ); + systems = [ "qmynd" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "chipz" self) + (getAttr "cl_plus_ssl" self) + (getAttr "flexi-streams" self) + (getAttr "ironclad" self) + (getAttr "list-of" self) + (getAttr "salza2" self) + (getAttr "trivial-gray-streams" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qmynd-test = ( + build-asdf-system { + pname = "qmynd-test"; + version = "20190710-git"; + asds = [ "qmynd-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qmynd/2019-07-10/qmynd-20190710-git.tgz"; + sha256 = "06gw5wxcpdclb6a5i5k9lbmdlyqsp182czrm9bm1cpklzbj0ihrl"; + system = "qmynd-test"; + asd = "qmynd-test"; + } + ); + systems = [ "qmynd-test" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "flexi-streams" self) + (getAttr "qmynd" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qoi = ( + build-asdf-system { + pname = "qoi"; + version = "20241012-git"; + asds = [ "qoi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qoi/2024-10-12/qoi-20241012-git.tgz"; + sha256 = "06akq38q7m648c3kpx1pzw21fwqry7fkg6sfgbap0b7bifzg1dsn"; + system = "qoi"; + asd = "qoi"; + } + ); + systems = [ "qoi" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qsci = ( + build-asdf-system { + pname = "qsci"; + version = "20210531-git"; + asds = [ "qsci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qsci"; + asd = "qsci"; + } + ); + systems = [ "qsci" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qt_plus_libs = ( + build-asdf-system { + pname = "qt+libs"; + version = "20230214-git"; + asds = [ "qt+libs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/commonqt/2023-02-14/commonqt-20230214-git.tgz"; + sha256 = "1s66z48plfwiq4qhf6whpvnjy4n7r9zhipri7lc8k67x817k020q"; + system = "qt+libs"; + asd = "qt+libs"; + } + ); + systems = [ "qt+libs" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + (getAttr "named-readtables" self) + (getAttr "qt-libs" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qt-lib-generator = ( + build-asdf-system { + pname = "qt-lib-generator"; + version = "20210531-git"; + asds = [ "qt-lib-generator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qt-lib-generator"; + asd = "qt-lib-generator"; + } + ); + systems = [ "qt-lib-generator" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "pathname-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qt-libs = ( + build-asdf-system { + pname = "qt-libs"; + version = "20210531-git"; + asds = [ "qt-libs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qt-libs"; + asd = "qt-libs"; + } + ); + systems = [ "qt-libs" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + (getAttr "qt-lib-generator" self) + ]; + meta = { }; + } + ); + qt3support = ( + build-asdf-system { + pname = "qt3support"; + version = "20210531-git"; + asds = [ "qt3support" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qt3support"; + asd = "qt3support"; + } + ); + systems = [ "qt3support" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtnetwork" self) + (getAttr "qtsql" self) + (getAttr "qtxml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtcore = ( + build-asdf-system { + pname = "qtcore"; + version = "20210531-git"; + asds = [ "qtcore" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtcore"; + asd = "qtcore"; + } + ); + systems = [ "qtcore" ]; + lispLibs = [ + (getAttr "commonqt" self) + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtdbus = ( + build-asdf-system { + pname = "qtdbus"; + version = "20210531-git"; + asds = [ "qtdbus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtdbus"; + asd = "qtdbus"; + } + ); + systems = [ "qtdbus" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtxml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtdeclarative = ( + build-asdf-system { + pname = "qtdeclarative"; + version = "20210531-git"; + asds = [ "qtdeclarative" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtdeclarative"; + asd = "qtdeclarative"; + } + ); + systems = [ "qtdeclarative" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtnetwork" self) + (getAttr "qtscript" self) + (getAttr "qtsql" self) + (getAttr "qtxmlpatterns" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtgui = ( + build-asdf-system { + pname = "qtgui"; + version = "20210531-git"; + asds = [ "qtgui" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtgui"; + asd = "qtgui"; + } + ); + systems = [ "qtgui" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qthelp = ( + build-asdf-system { + pname = "qthelp"; + version = "20210531-git"; + asds = [ "qthelp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qthelp"; + asd = "qthelp"; + } + ); + systems = [ "qthelp" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtnetwork" self) + (getAttr "qtsql" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtnetwork = ( + build-asdf-system { + pname = "qtnetwork"; + version = "20210531-git"; + asds = [ "qtnetwork" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtnetwork"; + asd = "qtnetwork"; + } + ); + systems = [ "qtnetwork" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools = ( + build-asdf-system { + pname = "qtools"; + version = "20230214-git"; + asds = [ "qtools" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; + sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; + system = "qtools"; + asd = "qtools"; + } + ); + systems = [ "qtools" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "deploy" self) + (getAttr "documentation-utils" self) + (getAttr "form-fiddle" self) + (getAttr "named-readtables" self) + (getAttr "qt_plus_libs" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-indent" self) + (getAttr "trivial-main-thread" self) + ]; + meta = { }; + } + ); + qtools-evaluator = ( + build-asdf-system { + pname = "qtools-evaluator"; + version = "20230214-git"; + asds = [ "qtools-evaluator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; + sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; + system = "qtools-evaluator"; + asd = "qtools-evaluator"; + } + ); + systems = [ "qtools-evaluator" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtools" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-game = ( + build-asdf-system { + pname = "qtools-game"; + version = "20230214-git"; + asds = [ "qtools-game" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; + sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; + system = "qtools-game"; + asd = "qtools-game"; + } + ); + systems = [ "qtools-game" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtools" self) + (getAttr "qtopengl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-helloworld = ( + build-asdf-system { + pname = "qtools-helloworld"; + version = "20230214-git"; + asds = [ "qtools-helloworld" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; + sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; + system = "qtools-helloworld"; + asd = "qtools-helloworld"; + } + ); + systems = [ "qtools-helloworld" ]; + lispLibs = [ + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtools" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-melody = ( + build-asdf-system { + pname = "qtools-melody"; + version = "20230214-git"; + asds = [ "qtools-melody" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; + sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; + system = "qtools-melody"; + asd = "qtools-melody"; + } + ); + systems = [ "qtools-melody" ]; + lispLibs = [ + (getAttr "phonon" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtools" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-opengl = ( + build-asdf-system { + pname = "qtools-opengl"; + version = "20230214-git"; + asds = [ "qtools-opengl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; + sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; + system = "qtools-opengl"; + asd = "qtools-opengl"; + } + ); + systems = [ "qtools-opengl" ]; + lispLibs = [ + (getAttr "cl-opengl" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtools" self) + (getAttr "qtopengl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-titter = ( + build-asdf-system { + pname = "qtools-titter"; + version = "20230214-git"; + asds = [ "qtools-titter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools/2023-02-14/qtools-20230214-git.tgz"; + sha256 = "1w9v2swdqqalvlc36kbb1fbvqmwlndisp2dnqbkx8s8h67k1m4lx"; + system = "qtools-titter"; + asd = "qtools-titter"; + } + ); + systems = [ "qtools-titter" ]; + lispLibs = [ + (getAttr "chirp" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtools" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui = ( + build-asdf-system { + pname = "qtools-ui"; + version = "20200218-git"; + asds = [ "qtools-ui" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui"; + asd = "qtools-ui"; + } + ); + systems = [ "qtools-ui" ]; + lispLibs = [ + (getAttr "qtools-ui-auto-resizing-textedit" self) + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-cell" self) + (getAttr "qtools-ui-color-history" self) + (getAttr "qtools-ui-color-picker" self) + (getAttr "qtools-ui-color-sliders" self) + (getAttr "qtools-ui-color-triangle" self) + (getAttr "qtools-ui-compass" self) + (getAttr "qtools-ui-container" self) + (getAttr "qtools-ui-debugger" self) + (getAttr "qtools-ui-dialog" self) + (getAttr "qtools-ui-dictionary" self) + (getAttr "qtools-ui-drag-and-drop" self) + (getAttr "qtools-ui-fixed-qtextedit" self) + (getAttr "qtools-ui-flow-layout" self) + (getAttr "qtools-ui-helpers" self) + (getAttr "qtools-ui-imagetools" self) + (getAttr "qtools-ui-keychord-editor" self) + (getAttr "qtools-ui-layout" self) + (getAttr "qtools-ui-listing" self) + (getAttr "qtools-ui-notification" self) + (getAttr "qtools-ui-options" self) + (getAttr "qtools-ui-panels" self) + (getAttr "qtools-ui-placeholder-text-edit" self) + (getAttr "qtools-ui-plot" self) + (getAttr "qtools-ui-repl" self) + (getAttr "qtools-ui-slider" self) + (getAttr "qtools-ui-spellchecked-text-edit" self) + (getAttr "qtools-ui-splitter" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-auto-resizing-textedit = ( + build-asdf-system { + pname = "qtools-ui-auto-resizing-textedit"; + version = "20200218-git"; + asds = [ "qtools-ui-auto-resizing-textedit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-auto-resizing-textedit"; + asd = "qtools-ui-auto-resizing-textedit"; + } + ); + systems = [ "qtools-ui-auto-resizing-textedit" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-fixed-qtextedit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-base = ( + build-asdf-system { + pname = "qtools-ui-base"; + version = "20200218-git"; + asds = [ "qtools-ui-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-base"; + asd = "qtools-ui-base"; + } + ); + systems = [ "qtools-ui-base" ]; + lispLibs = [ + (getAttr "array-utils" self) + (getAttr "documentation-utils" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtools" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-bytearray = ( + build-asdf-system { + pname = "qtools-ui-bytearray"; + version = "20200218-git"; + asds = [ "qtools-ui-bytearray" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-bytearray"; + asd = "qtools-ui-bytearray"; + } + ); + systems = [ "qtools-ui-bytearray" ]; + lispLibs = [ (getAttr "qtools-ui-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-cell = ( + build-asdf-system { + pname = "qtools-ui-cell"; + version = "20200218-git"; + asds = [ "qtools-ui-cell" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-cell"; + asd = "qtools-ui-cell"; + } + ); + systems = [ "qtools-ui-cell" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-helpers" self) + (getAttr "qtools-ui-layout" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-color-history = ( + build-asdf-system { + pname = "qtools-ui-color-history"; + version = "20200218-git"; + asds = [ "qtools-ui-color-history" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-color-history"; + asd = "qtools-ui-color-history"; + } + ); + systems = [ "qtools-ui-color-history" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-flow-layout" self) + (getAttr "qtools-ui-helpers" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-color-picker = ( + build-asdf-system { + pname = "qtools-ui-color-picker"; + version = "20200218-git"; + asds = [ "qtools-ui-color-picker" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-color-picker"; + asd = "qtools-ui-color-picker"; + } + ); + systems = [ "qtools-ui-color-picker" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-color-history" self) + (getAttr "qtools-ui-color-sliders" self) + (getAttr "qtools-ui-color-triangle" self) + (getAttr "qtools-ui-dialog" self) + (getAttr "qtools-ui-helpers" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-color-sliders = ( + build-asdf-system { + pname = "qtools-ui-color-sliders"; + version = "20200218-git"; + asds = [ "qtools-ui-color-sliders" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-color-sliders"; + asd = "qtools-ui-color-sliders"; + } + ); + systems = [ "qtools-ui-color-sliders" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-helpers" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-color-triangle = ( + build-asdf-system { + pname = "qtools-ui-color-triangle"; + version = "20200218-git"; + asds = [ "qtools-ui-color-triangle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-color-triangle"; + asd = "qtools-ui-color-triangle"; + } + ); + systems = [ "qtools-ui-color-triangle" ]; + lispLibs = [ + (getAttr "cl-opengl" self) + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-helpers" self) + (getAttr "qtopengl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-compass = ( + build-asdf-system { + pname = "qtools-ui-compass"; + version = "20200218-git"; + asds = [ "qtools-ui-compass" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-compass"; + asd = "qtools-ui-compass"; + } + ); + systems = [ "qtools-ui-compass" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-layout" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-container = ( + build-asdf-system { + pname = "qtools-ui-container"; + version = "20200218-git"; + asds = [ "qtools-ui-container" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-container"; + asd = "qtools-ui-container"; + } + ); + systems = [ "qtools-ui-container" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-layout" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-debugger = ( + build-asdf-system { + pname = "qtools-ui-debugger"; + version = "20200218-git"; + asds = [ "qtools-ui-debugger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-debugger"; + asd = "qtools-ui-debugger"; + } + ); + systems = [ "qtools-ui-debugger" ]; + lispLibs = [ + (getAttr "dissect" self) + (getAttr "qtools-ui-base" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-dialog = ( + build-asdf-system { + pname = "qtools-ui-dialog"; + version = "20200218-git"; + asds = [ "qtools-ui-dialog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-dialog"; + asd = "qtools-ui-dialog"; + } + ); + systems = [ "qtools-ui-dialog" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-helpers" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-dictionary = ( + build-asdf-system { + pname = "qtools-ui-dictionary"; + version = "20200218-git"; + asds = [ "qtools-ui-dictionary" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-dictionary"; + asd = "qtools-ui-dictionary"; + } + ); + systems = [ "qtools-ui-dictionary" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-fixed-qtextedit" self) + (getAttr "qtools-ui-helpers" self) + (getAttr "wordnet" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-drag-and-drop = ( + build-asdf-system { + pname = "qtools-ui-drag-and-drop"; + version = "20200218-git"; + asds = [ "qtools-ui-drag-and-drop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-drag-and-drop"; + asd = "qtools-ui-drag-and-drop"; + } + ); + systems = [ "qtools-ui-drag-and-drop" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-helpers" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-executable = ( + build-asdf-system { + pname = "qtools-ui-executable"; + version = "20200218-git"; + asds = [ "qtools-ui-executable" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-executable"; + asd = "qtools-ui-executable"; + } + ); + systems = [ "qtools-ui-executable" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "qtools-ui-base" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-fixed-qtextedit = ( + build-asdf-system { + pname = "qtools-ui-fixed-qtextedit"; + version = "20200218-git"; + asds = [ "qtools-ui-fixed-qtextedit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-fixed-qtextedit"; + asd = "qtools-ui-fixed-qtextedit"; + } + ); + systems = [ "qtools-ui-fixed-qtextedit" ]; + lispLibs = [ (getAttr "qtools-ui-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-flow-layout = ( + build-asdf-system { + pname = "qtools-ui-flow-layout"; + version = "20200218-git"; + asds = [ "qtools-ui-flow-layout" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-flow-layout"; + asd = "qtools-ui-flow-layout"; + } + ); + systems = [ "qtools-ui-flow-layout" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-container" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-helpers = ( + build-asdf-system { + pname = "qtools-ui-helpers"; + version = "20200218-git"; + asds = [ "qtools-ui-helpers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-helpers"; + asd = "qtools-ui-helpers"; + } + ); + systems = [ "qtools-ui-helpers" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-layout" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-imagetools = ( + build-asdf-system { + pname = "qtools-ui-imagetools"; + version = "20200218-git"; + asds = [ "qtools-ui-imagetools" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-imagetools"; + asd = "qtools-ui-imagetools"; + } + ); + systems = [ "qtools-ui-imagetools" ]; + lispLibs = [ + (getAttr "qimageblitz" self) + (getAttr "qtools-ui-base" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-keychord-editor = ( + build-asdf-system { + pname = "qtools-ui-keychord-editor"; + version = "20200218-git"; + asds = [ "qtools-ui-keychord-editor" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-keychord-editor"; + asd = "qtools-ui-keychord-editor"; + } + ); + systems = [ "qtools-ui-keychord-editor" ]; + lispLibs = [ (getAttr "qtools-ui-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-layout = ( + build-asdf-system { + pname = "qtools-ui-layout"; + version = "20200218-git"; + asds = [ "qtools-ui-layout" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-layout"; + asd = "qtools-ui-layout"; + } + ); + systems = [ "qtools-ui-layout" ]; + lispLibs = [ (getAttr "qtools-ui-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-listing = ( + build-asdf-system { + pname = "qtools-ui-listing"; + version = "20200218-git"; + asds = [ "qtools-ui-listing" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-listing"; + asd = "qtools-ui-listing"; + } + ); + systems = [ "qtools-ui-listing" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-cell" self) + (getAttr "qtools-ui-container" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-notification = ( + build-asdf-system { + pname = "qtools-ui-notification"; + version = "20200218-git"; + asds = [ "qtools-ui-notification" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-notification"; + asd = "qtools-ui-notification"; + } + ); + systems = [ "qtools-ui-notification" ]; + lispLibs = [ (getAttr "qtools-ui-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-options = ( + build-asdf-system { + pname = "qtools-ui-options"; + version = "20200218-git"; + asds = [ "qtools-ui-options" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-options"; + asd = "qtools-ui-options"; + } + ); + systems = [ "qtools-ui-options" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-color-picker" self) + (getAttr "qtools-ui-color-triangle" self) + (getAttr "qtools-ui-helpers" self) + (getAttr "qtools-ui-listing" self) + (getAttr "qtools-ui-slider" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-panels = ( + build-asdf-system { + pname = "qtools-ui-panels"; + version = "20200218-git"; + asds = [ "qtools-ui-panels" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-panels"; + asd = "qtools-ui-panels"; + } + ); + systems = [ "qtools-ui-panels" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-compass" self) + (getAttr "qtools-ui-helpers" self) + (getAttr "qtools-ui-splitter" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-placeholder-text-edit = ( + build-asdf-system { + pname = "qtools-ui-placeholder-text-edit"; + version = "20200218-git"; + asds = [ "qtools-ui-placeholder-text-edit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-placeholder-text-edit"; + asd = "qtools-ui-placeholder-text-edit"; + } + ); + systems = [ "qtools-ui-placeholder-text-edit" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-fixed-qtextedit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-plot = ( + build-asdf-system { + pname = "qtools-ui-plot"; + version = "20200218-git"; + asds = [ "qtools-ui-plot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-plot"; + asd = "qtools-ui-plot"; + } + ); + systems = [ "qtools-ui-plot" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-helpers" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-progress-bar = ( + build-asdf-system { + pname = "qtools-ui-progress-bar"; + version = "20200218-git"; + asds = [ "qtools-ui-progress-bar" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-progress-bar"; + asd = "qtools-ui-progress-bar"; + } + ); + systems = [ "qtools-ui-progress-bar" ]; + lispLibs = [ (getAttr "qtools-ui-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-repl = ( + build-asdf-system { + pname = "qtools-ui-repl"; + version = "20200218-git"; + asds = [ "qtools-ui-repl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-repl"; + asd = "qtools-ui-repl"; + } + ); + systems = [ "qtools-ui-repl" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "qtools-ui-base" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-slider = ( + build-asdf-system { + pname = "qtools-ui-slider"; + version = "20200218-git"; + asds = [ "qtools-ui-slider" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-slider"; + asd = "qtools-ui-slider"; + } + ); + systems = [ "qtools-ui-slider" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-helpers" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-spellchecked-text-edit = ( + build-asdf-system { + pname = "qtools-ui-spellchecked-text-edit"; + version = "20200218-git"; + asds = [ "qtools-ui-spellchecked-text-edit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-spellchecked-text-edit"; + asd = "qtools-ui-spellchecked-text-edit"; + } + ); + systems = [ "qtools-ui-spellchecked-text-edit" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-fixed-qtextedit" self) + (getAttr "qtools-ui-helpers" self) + (getAttr "spell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-splitter = ( + build-asdf-system { + pname = "qtools-ui-splitter"; + version = "20200218-git"; + asds = [ "qtools-ui-splitter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-splitter"; + asd = "qtools-ui-splitter"; + } + ); + systems = [ "qtools-ui-splitter" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtools-ui-container" self) + (getAttr "qtools-ui-helpers" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtools-ui-svgtools = ( + build-asdf-system { + pname = "qtools-ui-svgtools"; + version = "20200218-git"; + asds = [ "qtools-ui-svgtools" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qtools-ui/2020-02-18/qtools-ui-20200218-git.tgz"; + sha256 = "0zlygq42mi2ngk8q7a36k2rp6ydb98gryfxvcbg3dijg34i70f2z"; + system = "qtools-ui-svgtools"; + asd = "qtools-ui-svgtools"; + } + ); + systems = [ "qtools-ui-svgtools" ]; + lispLibs = [ + (getAttr "qtools-ui-base" self) + (getAttr "qtsvg" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtopengl = ( + build-asdf-system { + pname = "qtopengl"; + version = "20210531-git"; + asds = [ "qtopengl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtopengl"; + asd = "qtopengl"; + } + ); + systems = [ "qtopengl" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtscript = ( + build-asdf-system { + pname = "qtscript"; + version = "20210531-git"; + asds = [ "qtscript" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtscript"; + asd = "qtscript"; + } + ); + systems = [ "qtscript" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtsql = ( + build-asdf-system { + pname = "qtsql"; + version = "20210531-git"; + asds = [ "qtsql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtsql"; + asd = "qtsql"; + } + ); + systems = [ "qtsql" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtsvg = ( + build-asdf-system { + pname = "qtsvg"; + version = "20210531-git"; + asds = [ "qtsvg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtsvg"; + asd = "qtsvg"; + } + ); + systems = [ "qtsvg" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qttest = ( + build-asdf-system { + pname = "qttest"; + version = "20210531-git"; + asds = [ "qttest" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qttest"; + asd = "qttest"; + } + ); + systems = [ "qttest" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtuitools = ( + build-asdf-system { + pname = "qtuitools"; + version = "20210531-git"; + asds = [ "qtuitools" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtuitools"; + asd = "qtuitools"; + } + ); + systems = [ "qtuitools" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtwebkit = ( + build-asdf-system { + pname = "qtwebkit"; + version = "20210531-git"; + asds = [ "qtwebkit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtwebkit"; + asd = "qtwebkit"; + } + ); + systems = [ "qtwebkit" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + (getAttr "qtnetwork" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtxml = ( + build-asdf-system { + pname = "qtxml"; + version = "20210531-git"; + asds = [ "qtxml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtxml"; + asd = "qtxml"; + } + ); + systems = [ "qtxml" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qtxmlpatterns = ( + build-asdf-system { + pname = "qtxmlpatterns"; + version = "20210531-git"; + asds = [ "qtxmlpatterns" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qtxmlpatterns"; + asd = "qtxmlpatterns"; + } + ); + systems = [ "qtxmlpatterns" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtnetwork" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quad-tree = ( + build-asdf-system { + pname = "quad-tree"; + version = "20220707-git"; + asds = [ "quad-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quad-tree/2022-07-07/quad-tree-20220707-git.tgz"; + sha256 = "1pg43zw75dbqxs8vca3fynqfvza59v1fmwh9m4x0jrnw7ysgkl6j"; + system = "quad-tree"; + asd = "quad-tree"; + } + ); + systems = [ "quad-tree" ]; + lispLibs = [ + (getAttr "mfiano-utils" self) + (getAttr "origin" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quadpack = ( + build-asdf-system { + pname = "quadpack"; + version = "20231021-git"; + asds = [ "quadpack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "quadpack"; + asd = "quadpack"; + } + ); + systems = [ "quadpack" ]; + lispLibs = [ (getAttr "f2cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quads = ( + build-asdf-system { + pname = "quads"; + version = "20200427-git"; + asds = [ "quads" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "quads"; + asd = "quads"; + } + ); + systems = [ "quads" ]; + lispLibs = [ (getAttr "utility" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quadtree = ( + build-asdf-system { + pname = "quadtree"; + version = "20150709-git"; + asds = [ "quadtree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quadtree/2015-07-09/quadtree-20150709-git.tgz"; + sha256 = "0590f0sbv4qg590d2bb7ypncg3wn5xjapi24w78mnzr9bdnhh4vx"; + system = "quadtree"; + asd = "quadtree"; + } + ); + systems = [ "quadtree" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quadtree-test = ( + build-asdf-system { + pname = "quadtree-test"; + version = "20150709-git"; + asds = [ "quadtree-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quadtree/2015-07-09/quadtree-20150709-git.tgz"; + sha256 = "0590f0sbv4qg590d2bb7ypncg3wn5xjapi24w78mnzr9bdnhh4vx"; + system = "quadtree-test"; + asd = "quadtree-test"; + } + ); + systems = [ "quadtree-test" ]; + lispLibs = [ + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "quadtree" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quantile-estimator = ( + build-asdf-system { + pname = "quantile-estimator"; + version = "20160825-git"; + asds = [ "quantile-estimator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quantile-estimator.cl/2016-08-25/quantile-estimator.cl-20160825-git.tgz"; + sha256 = "1rrazbl0gbsymynlxp7ild6wvwp6csmdig4hwrp3wjvqhdl8j3mj"; + system = "quantile-estimator"; + asd = "quantile-estimator"; + } + ); + systems = [ "quantile-estimator" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quantile-estimator_dot_test = ( + build-asdf-system { + pname = "quantile-estimator.test"; + version = "20160825-git"; + asds = [ "quantile-estimator.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quantile-estimator.cl/2016-08-25/quantile-estimator.cl-20160825-git.tgz"; + sha256 = "1rrazbl0gbsymynlxp7ild6wvwp6csmdig4hwrp3wjvqhdl8j3mj"; + system = "quantile-estimator.test"; + asd = "quantile-estimator.test"; + } + ); + systems = [ "quantile-estimator.test" ]; + lispLibs = [ + (getAttr "log4cl" self) + (getAttr "mw-equiv" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "quantile-estimator" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quasiquote-2_dot_0 = ( + build-asdf-system { + pname = "quasiquote-2.0"; + version = "20150505-git"; + asds = [ "quasiquote-2.0" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quasiquote-2.0/2015-05-05/quasiquote-2.0-20150505-git.tgz"; + sha256 = "1g0s3aplrgmdjj8k1wrx3dkqdsl4lka2nmgdng0rcd93xp11q6hn"; + system = "quasiquote-2.0"; + asd = "quasiquote-2.0"; + } + ); + systems = [ "quasiquote-2.0" ]; + lispLibs = [ (getAttr "iterate" self) ]; + meta = { }; + } + ); + quasiquote-2_dot_0-tests = ( + build-asdf-system { + pname = "quasiquote-2.0-tests"; + version = "20150505-git"; + asds = [ "quasiquote-2.0-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quasiquote-2.0/2015-05-05/quasiquote-2.0-20150505-git.tgz"; + sha256 = "1g0s3aplrgmdjj8k1wrx3dkqdsl4lka2nmgdng0rcd93xp11q6hn"; + system = "quasiquote-2.0-tests"; + asd = "quasiquote-2.0"; + } + ); + systems = [ "quasiquote-2.0-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "quasiquote-2_dot_0" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quaviver = ( + build-asdf-system { + pname = "quaviver"; + version = "20241012-git"; + asds = [ "quaviver" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quaviver/2024-10-12/quaviver-20241012-git.tgz"; + sha256 = "17kixyznxfwlxkfl2d2ngxas3vi7r21bgfy4g7xlngvakxw3zfzp"; + system = "quaviver"; + asd = "quaviver"; + } + ); + systems = [ "quaviver" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + queen = ( + build-asdf-system { + pname = "queen"; + version = "20230618-git"; + asds = [ "queen" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/queen.lisp/2023-06-18/queen.lisp-20230618-git.tgz"; + sha256 = "14y4688f9gazdxh03k2jnxnla2bygcsz6wk55yc0id1achak95fa"; + system = "queen"; + asd = "queen"; + } + ); + systems = [ "queen" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cl-ppcre-unicode" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + query-fs = ( + build-asdf-system { + pname = "query-fs"; + version = "20241012-git"; + asds = [ "query-fs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/query-fs/2024-10-12/query-fs-20241012-git.tgz"; + sha256 = "09gz8xrjg9r5bclphgwjdnif8qx4qnx518jragq3znwvlzfb34fw"; + system = "query-fs"; + asd = "query-fs"; + } + ); + systems = [ "query-fs" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-fuse" self) + (getAttr "cl-fuse-meta-fs" self) + (getAttr "cl-ppcre" self) + (getAttr "command-line-arguments" self) + (getAttr "iterate" self) + (getAttr "trivial-backtrace" self) + ]; + meta = { }; + } + ); + query-repl = ( + build-asdf-system { + pname = "query-repl"; + version = "20220331-git"; + asds = [ "query-repl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/query-repl/2022-03-31/query-repl-20220331-git.tgz"; + sha256 = "0gzrr1k7071hdmd64i5lqmg62i3yqim7nmcc9r94sry47bkp16v2"; + system = "query-repl"; + asd = "query-repl"; + } + ); + systems = [ "query-repl" ]; + lispLibs = [ + (getAttr "check-bnf" self) + (getAttr "jingoh_dot_documentizer" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + query-repl_dot_test = ( + build-asdf-system { + pname = "query-repl.test"; + version = "20220331-git"; + asds = [ "query-repl.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/query-repl/2022-03-31/query-repl-20220331-git.tgz"; + sha256 = "0gzrr1k7071hdmd64i5lqmg62i3yqim7nmcc9r94sry47bkp16v2"; + system = "query-repl.test"; + asd = "query-repl.test"; + } + ); + systems = [ "query-repl.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "query-repl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + queues = ( + build-asdf-system { + pname = "queues"; + version = "20170124-git"; + asds = [ "queues" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/queues/2017-01-24/queues-20170124-git.tgz"; + sha256 = "0wdhfnzi4v6d97pggzj2aw55si94w4327br94jrmyvwf351wqjvv"; + system = "queues"; + asd = "queues"; + } + ); + systems = [ "queues" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + queues_dot_priority-cqueue = ( + build-asdf-system { + pname = "queues.priority-cqueue"; + version = "20170124-git"; + asds = [ "queues.priority-cqueue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/queues/2017-01-24/queues-20170124-git.tgz"; + sha256 = "0wdhfnzi4v6d97pggzj2aw55si94w4327br94jrmyvwf351wqjvv"; + system = "queues.priority-cqueue"; + asd = "queues.priority-cqueue"; + } + ); + systems = [ "queues.priority-cqueue" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "queues" self) + (getAttr "queues_dot_priority-queue" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + queues_dot_priority-queue = ( + build-asdf-system { + pname = "queues.priority-queue"; + version = "20170124-git"; + asds = [ "queues.priority-queue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/queues/2017-01-24/queues-20170124-git.tgz"; + sha256 = "0wdhfnzi4v6d97pggzj2aw55si94w4327br94jrmyvwf351wqjvv"; + system = "queues.priority-queue"; + asd = "queues.priority-queue"; + } + ); + systems = [ "queues.priority-queue" ]; + lispLibs = [ (getAttr "queues" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + queues_dot_simple-cqueue = ( + build-asdf-system { + pname = "queues.simple-cqueue"; + version = "20170124-git"; + asds = [ "queues.simple-cqueue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/queues/2017-01-24/queues-20170124-git.tgz"; + sha256 = "0wdhfnzi4v6d97pggzj2aw55si94w4327br94jrmyvwf351wqjvv"; + system = "queues.simple-cqueue"; + asd = "queues.simple-cqueue"; + } + ); + systems = [ "queues.simple-cqueue" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "queues" self) + (getAttr "queues_dot_simple-queue" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + queues_dot_simple-queue = ( + build-asdf-system { + pname = "queues.simple-queue"; + version = "20170124-git"; + asds = [ "queues.simple-queue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/queues/2017-01-24/queues-20170124-git.tgz"; + sha256 = "0wdhfnzi4v6d97pggzj2aw55si94w4327br94jrmyvwf351wqjvv"; + system = "queues.simple-queue"; + asd = "queues.simple-queue"; + } + ); + systems = [ "queues.simple-queue" ]; + lispLibs = [ (getAttr "queues" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quick-patch = ( + build-asdf-system { + pname = "quick-patch"; + version = "20241012-git"; + asds = [ "quick-patch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quick-patch/2024-10-12/quick-patch-20241012-git.tgz"; + sha256 = "0a2wkqn65kl88yz7a8728x9gjy4w37hjavfqx4hyijhs1ph38wdi"; + system = "quick-patch"; + asd = "quick-patch"; + } + ); + systems = [ "quick-patch" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quickapp = ( + build-asdf-system { + pname = "quickapp"; + version = "20160825-git"; + asds = [ "quickapp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quickapp/2016-08-25/quickapp-20160825-git.tgz"; + sha256 = "0rhhxwggbh9sf3c4c9fv39c5imy48416mwf0dkhqpnm8x55xbw22"; + system = "quickapp"; + asd = "quickapp"; + } + ); + systems = [ "quickapp" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quickhull = ( + build-asdf-system { + pname = "quickhull"; + version = "20241012-git"; + asds = [ "quickhull" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quickhull/2024-10-12/quickhull-20241012-git.tgz"; + sha256 = "1814qq23dg2shnfdkw9w9ap53qzg2igy119bwslvflmcb1jd7bpm"; + system = "quickhull"; + asd = "quickhull"; + } + ); + systems = [ "quickhull" ]; + lispLibs = [ + (getAttr "_3d-math" self) + (getAttr "documentation-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quicklisp-slime-helper = ( + build-asdf-system { + pname = "quicklisp-slime-helper"; + version = "20150709-git"; + asds = [ "quicklisp-slime-helper" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quicklisp-slime-helper/2015-07-09/quicklisp-slime-helper-20150709-git.tgz"; + sha256 = "14b1zg26h75pnhj3ic0h9i5jbmwf8wjp91scbcg1ra9fyhh73pa6"; + system = "quicklisp-slime-helper"; + asd = "quicklisp-slime-helper"; + } + ); + systems = [ "quicklisp-slime-helper" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quicklisp-starter = ( + build-asdf-system { + pname = "quicklisp-starter"; + version = "20241012-git"; + asds = [ "quicklisp-starter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-brewer/2024-10-12/cl-brewer-20241012-git.tgz"; + sha256 = "0izf6v4qx82jhk7ln28jhdmnr3lb0r5iqjj0by9igq5sk3y1my4x"; + system = "quicklisp-starter"; + asd = "quicklisp-starter"; + } + ); + systems = [ "quicklisp-starter" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quicklisp-stats = ( + build-asdf-system { + pname = "quicklisp-stats"; + version = "20210411-git"; + asds = [ "quicklisp-stats" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quicklisp-stats/2021-04-11/quicklisp-stats-20210411-git.tgz"; + sha256 = "0v8dgmlgd283n1g486q4sj2mghgdvgywg2nqp43nnrfc04mkvgc0"; + system = "quicklisp-stats"; + asd = "quicklisp-stats"; + } + ); + systems = [ "quicklisp-stats" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "drakma" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quickproject = ( + build-asdf-system { + pname = "quickproject"; + version = "1.4.1"; + asds = [ "quickproject" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quickproject/2019-12-27/quickproject-1.4.1.tgz"; + sha256 = "1szs8p2wr1yr9mjmj3h3557l6wxzzga0iszimb68z0hb1jj3lva6"; + system = "quickproject"; + asd = "quickproject"; + } + ); + systems = [ "quickproject" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "html-template" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quicksearch = ( + build-asdf-system { + pname = "quicksearch"; + version = "20171019-git"; + asds = [ "quicksearch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quicksearch/2017-10-19/quicksearch-20171019-git.tgz"; + sha256 = "16k19zjkhh7r64vjq371k5jwjs7cdfjz83flh561n4h4v1z89fps"; + system = "quicksearch"; + asd = "quicksearch"; + } + ); + systems = [ "quicksearch" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "do-urlencode" self) + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + (getAttr "html-entities" self) + (getAttr "iterate" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quickutil = ( + build-asdf-system { + pname = "quickutil"; + version = "20210807-git"; + asds = [ "quickutil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quickutil/2021-08-07/quickutil-20210807-git.tgz"; + sha256 = "0d4xrgsh5pj4cgj1mqsdyi4xvq04jyb2m4c3sdx94jsx3r83hldz"; + system = "quickutil"; + asd = "quickutil"; + } + ); + systems = [ "quickutil" ]; + lispLibs = [ (getAttr "quickutil-client" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quickutil-client = ( + build-asdf-system { + pname = "quickutil-client"; + version = "20210807-git"; + asds = [ "quickutil-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quickutil/2021-08-07/quickutil-20210807-git.tgz"; + sha256 = "0d4xrgsh5pj4cgj1mqsdyi4xvq04jyb2m4c3sdx94jsx3r83hldz"; + system = "quickutil-client"; + asd = "quickutil-client"; + } + ); + systems = [ "quickutil-client" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "quickutil-client-management" self) + (getAttr "quickutil-utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quickutil-client-management = ( + build-asdf-system { + pname = "quickutil-client-management"; + version = "20210807-git"; + asds = [ "quickutil-client-management" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quickutil/2021-08-07/quickutil-20210807-git.tgz"; + sha256 = "0d4xrgsh5pj4cgj1mqsdyi4xvq04jyb2m4c3sdx94jsx3r83hldz"; + system = "quickutil-client-management"; + asd = "quickutil-client-management"; + } + ); + systems = [ "quickutil-client-management" ]; + lispLibs = [ (getAttr "trivial-garbage" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quickutil-server = ( + build-asdf-system { + pname = "quickutil-server"; + version = "20210807-git"; + asds = [ "quickutil-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quickutil/2021-08-07/quickutil-20210807-git.tgz"; + sha256 = "0d4xrgsh5pj4cgj1mqsdyi4xvq04jyb2m4c3sdx94jsx3r83hldz"; + system = "quickutil-server"; + asd = "quickutil-server"; + } + ); + systems = [ "quickutil-server" ]; + lispLibs = [ + (getAttr "assoc-utils" self) + (getAttr "cl-fad" self) + (getAttr "cl-markdown" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-syntax" self) + (getAttr "cl-syntax-annot" self) + (getAttr "clack" self) + (getAttr "closure-template" self) + (getAttr "dbi" self) + (getAttr "lack" self) + (getAttr "lack-component" self) + (getAttr "lack-middleware-csrf" self) + (getAttr "lack-request" self) + (getAttr "lack-response" self) + (getAttr "ningle" self) + (getAttr "quickutil-utilities" self) + (getAttr "trivial-shell" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quickutil-utilities = ( + build-asdf-system { + pname = "quickutil-utilities"; + version = "20210807-git"; + asds = [ "quickutil-utilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quickutil/2021-08-07/quickutil-20210807-git.tgz"; + sha256 = "0d4xrgsh5pj4cgj1mqsdyi4xvq04jyb2m4c3sdx94jsx3r83hldz"; + system = "quickutil-utilities"; + asd = "quickutil-utilities"; + } + ); + systems = [ "quickutil-utilities" ]; + lispLibs = [ (getAttr "cl-heredoc" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quickutil-utilities-test = ( + build-asdf-system { + pname = "quickutil-utilities-test"; + version = "20210807-git"; + asds = [ "quickutil-utilities-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quickutil/2021-08-07/quickutil-20210807-git.tgz"; + sha256 = "0d4xrgsh5pj4cgj1mqsdyi4xvq04jyb2m4c3sdx94jsx3r83hldz"; + system = "quickutil-utilities-test"; + asd = "quickutil-utilities-test"; + } + ); + systems = [ "quickutil-utilities-test" ]; + lispLibs = [ + (getAttr "quickutil-client" self) + (getAttr "quickutil-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quil-coalton = ( + build-asdf-system { + pname = "quil-coalton"; + version = "20241012-git"; + asds = [ "quil-coalton" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; + sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; + system = "quil-coalton"; + asd = "quil-coalton"; + } + ); + systems = [ "quil-coalton" ]; + lispLibs = [ (getAttr "coalton" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quine-mccluskey = ( + build-asdf-system { + pname = "quine-mccluskey"; + version = "20141217-git"; + asds = [ "quine-mccluskey" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-logic/2014-12-17/cl-logic-20141217-git.tgz"; + sha256 = "17n2wzqali3j6b7pqbydipwlxgwdrj4mdnsgwjdyz32n8jvfyjwh"; + system = "quine-mccluskey"; + asd = "cl-logic"; + } + ); + systems = [ "quine-mccluskey" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quri = ( + build-asdf-system { + pname = "quri"; + version = "20241012-git"; + asds = [ "quri" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quri/2024-10-12/quri-20241012-git.tgz"; + sha256 = "0vismgg72xrflzdsrv8ybq3cxf717k5296g9b731974vwlf7ibh0"; + system = "quri"; + asd = "quri"; + } + ); + systems = [ "quri" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-utilities" self) + (getAttr "idna" self) + (getAttr "split-sequence" self) + ]; + meta = { }; + } + ); + quri-test = ( + build-asdf-system { + pname = "quri-test"; + version = "20241012-git"; + asds = [ "quri-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quri/2024-10-12/quri-20241012-git.tgz"; + sha256 = "0vismgg72xrflzdsrv8ybq3cxf717k5296g9b731974vwlf7ibh0"; + system = "quri-test"; + asd = "quri-test"; + } + ); + systems = [ "quri-test" ]; + lispLibs = [ + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "quri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quux-hunchentoot = ( + build-asdf-system { + pname = "quux-hunchentoot"; + version = "20211230-git"; + asds = [ "quux-hunchentoot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quux-hunchentoot/2021-12-30/quux-hunchentoot-20211230-git.tgz"; + sha256 = "0v0x4hzzfm835blqbp00vmj74gaq8wyldrnfj0x5s6zfl64w135y"; + system = "quux-hunchentoot"; + asd = "quux-hunchentoot"; + } + ); + systems = [ "quux-hunchentoot" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "hunchentoot" self) + (getAttr "lil" self) + (getAttr "lparallel" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + quux-time = ( + build-asdf-system { + pname = "quux-time"; + version = "20150407-git"; + asds = [ "quux-time" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/quux-time/2015-04-07/quux-time-20150407-git.tgz"; + sha256 = "0hsa2n1j0abhw8na9fql47rq1rxpf2vkwg2mbb1c3ax56r8dsh0v"; + system = "quux-time"; + asd = "quux-time"; + } + ); + systems = [ "quux-time" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + qwt = ( + build-asdf-system { + pname = "qwt"; + version = "20210531-git"; + asds = [ "qwt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "qwt"; + asd = "qwt"; + } + ); + systems = [ "qwt" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + (getAttr "qtcore" self) + (getAttr "qtgui" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rail = ( + build-asdf-system { + pname = "rail"; + version = "20171227-git"; + asds = [ "rail" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rail/2017-12-27/cl-rail-20171227-git.tgz"; + sha256 = "0vxbxyfl5lw7na8iki1cjp0cd31z2bnxcpdv0x25hq0vch1cb5rj"; + system = "rail"; + asd = "rail"; + } + ); + systems = [ "rail" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rail-test = ( + build-asdf-system { + pname = "rail-test"; + version = "20171227-git"; + asds = [ "rail-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rail/2017-12-27/cl-rail-20171227-git.tgz"; + sha256 = "0vxbxyfl5lw7na8iki1cjp0cd31z2bnxcpdv0x25hq0vch1cb5rj"; + system = "rail-test"; + asd = "rail"; + } + ); + systems = [ "rail-test" ]; + lispLibs = [ + (getAttr "fiasco" self) + (getAttr "rail" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + random = ( + build-asdf-system { + pname = "random"; + version = "20191007-git"; + asds = [ "random" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/random/2019-10-07/random-20191007-git.tgz"; + sha256 = "1fb4mnp85jm9s667y4dgz07klhkr9pvi5xbxws28lbb8iip75y2p"; + system = "random"; + asd = "random"; + } + ); + systems = [ "random" ]; + lispLibs = [ (getAttr "com_dot_google_dot_base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + random-access-lists = ( + build-asdf-system { + pname = "random-access-lists"; + version = "20120208-git"; + asds = [ "random-access-lists" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/random-access-lists/2012-02-08/random-access-lists-20120208-git.tgz"; + sha256 = "0wslxxdmmr25hvmcyscph1bjlknm3nzh5g79cif22was1z411m5c"; + system = "random-access-lists"; + asd = "random-access-lists"; + } + ); + systems = [ "random-access-lists" ]; + lispLibs = [ (getAttr "lisp-unit" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + random-sample = ( + build-asdf-system { + pname = "random-sample"; + version = "20230618-git"; + asds = [ "random-sample" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/random-sample/2023-06-18/random-sample-20230618-git.tgz"; + sha256 = "13g5wgq6z3gx07qr3q17mgwfn2rsck5p1b9cfswajagl0m8z3f51"; + system = "random-sample"; + asd = "random-sample"; + } + ); + systems = [ "random-sample" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "infix-math" self) + (getAttr "named-readtables" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + random-sampling = ( + build-asdf-system { + pname = "random-sampling"; + version = "20241012-git"; + asds = [ "random-sampling" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/random-sampling/2024-10-12/random-sampling-20241012-git.tgz"; + sha256 = "0c5cf7k37fh8h9dhcj9bfk9zx245i806wh7qkvh1g659kvl2gamj"; + system = "random-sampling"; + asd = "random-sampling"; + } + ); + systems = [ "random-sampling" ]; + lispLibs = [ + (getAttr "_3d-math" self) + (getAttr "documentation-utils" self) + (getAttr "random-state" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + random-state = ( + build-asdf-system { + pname = "random-state"; + version = "20241012-git"; + asds = [ "random-state" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/random-state/2024-10-12/random-state-20241012-git.tgz"; + sha256 = "1iwcrn2fqvsw651wk60nm6x5hlmlvj04v8xxfxmzhqmx5f081f1g"; + system = "random-state"; + asd = "random-state"; + } + ); + systems = [ "random-state" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + random-state-test = ( + build-asdf-system { + pname = "random-state-test"; + version = "20241012-git"; + asds = [ "random-state-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/random-state/2024-10-12/random-state-20241012-git.tgz"; + sha256 = "1iwcrn2fqvsw651wk60nm6x5hlmlvj04v8xxfxmzhqmx5f081f1g"; + system = "random-state-test"; + asd = "random-state-test"; + } + ); + systems = [ "random-state-test" ]; + lispLibs = [ + (getAttr "parachute" self) + (getAttr "random-state" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + random-state-viewer = ( + build-asdf-system { + pname = "random-state-viewer"; + version = "20241012-git"; + asds = [ "random-state-viewer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/random-state/2024-10-12/random-state-20241012-git.tgz"; + sha256 = "1iwcrn2fqvsw651wk60nm6x5hlmlvj04v8xxfxmzhqmx5f081f1g"; + system = "random-state-viewer"; + asd = "random-state-viewer"; + } + ); + systems = [ "random-state-viewer" ]; + lispLibs = [ + (getAttr "random-state" self) + (getAttr "trivial-features" self) + (getAttr "zpng" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + random-test = ( + build-asdf-system { + pname = "random-test"; + version = "20191007-git"; + asds = [ "random-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/random/2019-10-07/random-20191007-git.tgz"; + sha256 = "1fb4mnp85jm9s667y4dgz07klhkr9pvi5xbxws28lbb8iip75y2p"; + system = "random-test"; + asd = "random-test"; + } + ); + systems = [ "random-test" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_stefil" self) + (getAttr "random" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + random-uuid = ( + build-asdf-system { + pname = "random-uuid"; + version = "20220707-git"; + asds = [ "random-uuid" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/random-uuid/2022-07-07/random-uuid-20220707-git.tgz"; + sha256 = "09yfi16gh12qg4pi13gbr5n881q5zvw7acq27a6sbqbkny35a6wj"; + system = "random-uuid"; + asd = "random-uuid"; + } + ); + systems = [ "random-uuid" ]; + lispLibs = [ + (getAttr "mfiano-utils" self) + (getAttr "seedable-rng" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rate-monotonic = ( + build-asdf-system { + pname = "rate-monotonic"; + version = "20200325-git"; + asds = [ "rate-monotonic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rate-monotonic/2020-03-25/rate-monotonic-20200325-git.tgz"; + sha256 = "0v9m704zy3834whldx2fbs8x92hp7hlrzdlcxm1rd17wqpv7pvrv"; + system = "rate-monotonic"; + asd = "rate-monotonic"; + } + ); + systems = [ "rate-monotonic" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "timer-wheel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rate-monotonic_dot_examples = ( + build-asdf-system { + pname = "rate-monotonic.examples"; + version = "20200325-git"; + asds = [ "rate-monotonic.examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rate-monotonic/2020-03-25/rate-monotonic-20200325-git.tgz"; + sha256 = "0v9m704zy3834whldx2fbs8x92hp7hlrzdlcxm1rd17wqpv7pvrv"; + system = "rate-monotonic.examples"; + asd = "rate-monotonic.examples"; + } + ); + systems = [ "rate-monotonic.examples" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "rate-monotonic" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ratify = ( + build-asdf-system { + pname = "ratify"; + version = "20231021-git"; + asds = [ "ratify" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ratify/2023-10-21/ratify-20231021-git.tgz"; + sha256 = "11fsamjjbc77kjhbsh0w9wkwbdq51paa07sxjb2brvcm0ji4hynf"; + system = "ratify"; + asd = "ratify"; + } + ); + systems = [ "ratify" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "local-time" self) + (getAttr "parse-float" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ratmath = ( + build-asdf-system { + pname = "ratmath"; + version = "20200218-git"; + asds = [ "ratmath" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ratmath/2020-02-18/ratmath-20200218-git.tgz"; + sha256 = "1p5rl1bam8qjsgscn7gwk2w55hdjawfgjikka59lwb6ia13v4rj9"; + system = "ratmath"; + asd = "ratmath"; + } + ); + systems = [ "ratmath" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rcl = ( + build-asdf-system { + pname = "rcl"; + version = "20201220-http"; + asds = [ "rcl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rcl/2020-12-20/rcl-20201220-http.tgz"; + sha256 = "1s6cvqs0s7fxh63zwc5zj7ryrffmv780rscm7aq3alzb9njwmg14"; + system = "rcl"; + asd = "rcl"; + } + ); + systems = [ "rcl" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "named-readtables" self) + (getAttr "prove-asdf" self) + (getAttr "simple-tasks" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + re = ( + build-asdf-system { + pname = "re"; + version = "20210630-git"; + asds = [ "re" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/re/2021-06-30/re-20210630-git.tgz"; + sha256 = "15q4zvvzkxf1j0wxw0b1kz4d03js9cbgv82ndl8z6riz40kbffdp"; + system = "re"; + asd = "re"; + } + ); + systems = [ "re" ]; + lispLibs = [ (getAttr "parse" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + read-as-string = ( + build-asdf-system { + pname = "read-as-string"; + version = "20220707-git"; + asds = [ "read-as-string" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/read-as-string/2022-07-07/read-as-string-20220707-git.tgz"; + sha256 = "08dnnqmbadsrbsqr4n1x7rf0p46j9al0hw6la0z3jclp604dd0k3"; + system = "read-as-string"; + asd = "read-as-string"; + } + ); + systems = [ "read-as-string" ]; + lispLibs = [ + (getAttr "core-reader" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + read-as-string_dot_test = ( + build-asdf-system { + pname = "read-as-string.test"; + version = "20220707-git"; + asds = [ "read-as-string.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/read-as-string/2022-07-07/read-as-string-20220707-git.tgz"; + sha256 = "08dnnqmbadsrbsqr4n1x7rf0p46j9al0hw6la0z3jclp604dd0k3"; + system = "read-as-string.test"; + asd = "read-as-string.test"; + } + ); + systems = [ "read-as-string.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "read-as-string" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + read-csv = ( + build-asdf-system { + pname = "read-csv"; + version = "20181018-git"; + asds = [ "read-csv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/read-csv/2018-10-18/read-csv-20181018-git.tgz"; + sha256 = "1wr6n8z7jm611xf2jwp3pw03qzq76440cmb75495l5p907lmrbcs"; + system = "read-csv"; + asd = "read-csv"; + } + ); + systems = [ "read-csv" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + read-csv_dot_test = ( + build-asdf-system { + pname = "read-csv.test"; + version = "20181018-git"; + asds = [ "read-csv.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/read-csv/2018-10-18/read-csv-20181018-git.tgz"; + sha256 = "1wr6n8z7jm611xf2jwp3pw03qzq76440cmb75495l5p907lmrbcs"; + system = "read-csv.test"; + asd = "read-csv"; + } + ); + systems = [ "read-csv.test" ]; + lispLibs = [ (getAttr "read-csv" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + read-number = ( + build-asdf-system { + pname = "read-number"; + version = "20230214-git"; + asds = [ "read-number" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/read-number/2023-02-14/read-number-20230214-git.tgz"; + sha256 = "1y2g2vbg9zccm9h8r7dabgb315z7jhr91d81wa2cccibpgccdyac"; + system = "read-number"; + asd = "read-number"; + } + ); + systems = [ "read-number" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reader = ( + build-asdf-system { + pname = "reader"; + version = "v0.10.0"; + asds = [ "reader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reader/2020-12-20/reader-v0.10.0.tgz"; + sha256 = "0pbv6w0d8d4qmfkdsz2rk21bp1las9r7pyvpmd95qjz7kpxrirl7"; + system = "reader"; + asd = "reader"; + } + ); + systems = [ "reader" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "fiveam" self) + (getAttr "hash-set" self) + (getAttr "iterate" self) + (getAttr "split-sequence" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reader_plus_swank = ( + build-asdf-system { + pname = "reader+swank"; + version = "v0.10.0"; + asds = [ "reader+swank" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reader/2020-12-20/reader-v0.10.0.tgz"; + sha256 = "0pbv6w0d8d4qmfkdsz2rk21bp1las9r7pyvpmd95qjz7kpxrirl7"; + system = "reader+swank"; + asd = "reader+swank"; + } + ); + systems = [ "reader+swank" ]; + lispLibs = [ + (getAttr "reader" self) + (getAttr "swank" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reader-interception = ( + build-asdf-system { + pname = "reader-interception"; + version = "20150608-git"; + asds = [ "reader-interception" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reader-interception/2015-06-08/reader-interception-20150608-git.tgz"; + sha256 = "1f6xblayqb9q01qclvqx2gllqxm0qk8rmlp38rz433vgjxbq79y0"; + system = "reader-interception"; + asd = "reader-interception"; + } + ); + systems = [ "reader-interception" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reader-interception-test = ( + build-asdf-system { + pname = "reader-interception-test"; + version = "20150608-git"; + asds = [ "reader-interception-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reader-interception/2015-06-08/reader-interception-20150608-git.tgz"; + sha256 = "1f6xblayqb9q01qclvqx2gllqxm0qk8rmlp38rz433vgjxbq79y0"; + system = "reader-interception-test"; + asd = "reader-interception-test"; + } + ); + systems = [ "reader-interception-test" ]; + lispLibs = [ + (getAttr "fare-utils" self) + (getAttr "hu_dot_dwim_dot_stefil" self) + (getAttr "reader-interception" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks = ( + build-asdf-system { + pname = "reblocks"; + version = "20241012-git"; + asds = [ "reblocks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks/2024-10-12/reblocks-20241012-git.tgz"; + sha256 = "0s8npy7bh013qhm6ngvi7ar117ja2m098nr4krnzlcg2ivxdff3i"; + system = "reblocks"; + asd = "reblocks"; + } + ); + systems = [ "reblocks" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-cookie" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-strings" self) + (getAttr "clack" self) + (getAttr "closer-mop" self) + (getAttr "dexador" self) + (getAttr "f-underscore" self) + (getAttr "find-port" self) + (getAttr "ironclad" self) + (getAttr "jonathan" self) + (getAttr "lack" self) + (getAttr "lack-middleware-session" self) + (getAttr "lack-request" self) + (getAttr "lack-response" self) + (getAttr "lack-util" self) + (getAttr "local-time" self) + (getAttr "log4cl" self) + (getAttr "log4cl-extras" self) + (getAttr "metacopy" self) + (getAttr "metatilities" self) + (getAttr "named-readtables" self) + (getAttr "parenscript" self) + (getAttr "puri" self) + (getAttr "pythonic-string-reader" self) + (getAttr "quri" self) + (getAttr "routes" self) + (getAttr "salza2" self) + (getAttr "serapeum" self) + (getAttr "spinneret" self) + (getAttr "str" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-open-browser" self) + (getAttr "trivial-timeout" self) + (getAttr "uuid" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-auth = ( + build-asdf-system { + pname = "reblocks-auth"; + version = "20241012-git"; + asds = [ "reblocks-auth" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-auth/2024-10-12/reblocks-auth-20241012-git.tgz"; + sha256 = "1qydbk61a5xb2a61gj8mal0bmanhzynky1rh6lzwa10r5ybls4dq"; + system = "reblocks-auth"; + asd = "reblocks-auth"; + } + ); + systems = [ "reblocks-auth" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "alexandria" self) + (getAttr "cl-strings" self) + (getAttr "dexador" self) + (getAttr "jonathan" self) + (getAttr "local-time" self) + (getAttr "log4cl" self) + (getAttr "mailgun" self) + (getAttr "mito" self) + (getAttr "quri" self) + (getAttr "reblocks" self) + (getAttr "reblocks-lass" self) + (getAttr "reblocks-ui" self) + (getAttr "secret-values" self) + (getAttr "serapeum" self) + (getAttr "uuid" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-auth-ci = ( + build-asdf-system { + pname = "reblocks-auth-ci"; + version = "20241012-git"; + asds = [ "reblocks-auth-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-auth/2024-10-12/reblocks-auth-20241012-git.tgz"; + sha256 = "1qydbk61a5xb2a61gj8mal0bmanhzynky1rh6lzwa10r5ybls4dq"; + system = "reblocks-auth-ci"; + asd = "reblocks-auth-ci"; + } + ); + systems = [ "reblocks-auth-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-auth-example = ( + build-asdf-system { + pname = "reblocks-auth-example"; + version = "20241012-git"; + asds = [ "reblocks-auth-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-auth/2024-10-12/reblocks-auth-20241012-git.tgz"; + sha256 = "1qydbk61a5xb2a61gj8mal0bmanhzynky1rh6lzwa10r5ybls4dq"; + system = "reblocks-auth-example"; + asd = "reblocks-auth-example"; + } + ); + systems = [ "reblocks-auth-example" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "_40ants-logging" self) + (getAttr "_40ants-slynk" self) + (getAttr "cl_plus_ssl" self) + (getAttr "clack-handler-hunchentoot" self) + (getAttr "local-time" self) + (getAttr "mito" self) + (getAttr "reblocks" self) + (getAttr "reblocks-auth" self) + (getAttr "reblocks-lass" self) + (getAttr "reblocks-navigation-widget" self) + (getAttr "reblocks-prometheus" self) + (getAttr "reblocks-ui" self) + (getAttr "serapeum" self) + (getAttr "spinneret" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-auth-tests = ( + build-asdf-system { + pname = "reblocks-auth-tests"; + version = "20241012-git"; + asds = [ "reblocks-auth-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-auth/2024-10-12/reblocks-auth-20241012-git.tgz"; + sha256 = "1qydbk61a5xb2a61gj8mal0bmanhzynky1rh6lzwa10r5ybls4dq"; + system = "reblocks-auth-tests"; + asd = "reblocks-auth-tests"; + } + ); + systems = [ "reblocks-auth-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-docs = ( + build-asdf-system { + pname = "reblocks-docs"; + version = "20241012-git"; + asds = [ "reblocks-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks/2024-10-12/reblocks-20241012-git.tgz"; + sha256 = "0s8npy7bh013qhm6ngvi7ar117ja2m098nr4krnzlcg2ivxdff3i"; + system = "reblocks-docs"; + asd = "reblocks-docs"; + } + ); + systems = [ "reblocks-docs" ]; + lispLibs = [ (getAttr "reblocks" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-file-server = ( + build-asdf-system { + pname = "reblocks-file-server"; + version = "20241012-git"; + asds = [ "reblocks-file-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-file-server/2024-10-12/reblocks-file-server-20241012-git.tgz"; + sha256 = "1v17v0474k845l0s0bgly3zbgq2rjn5fyh8zmjnisszgkdd3bh13"; + system = "reblocks-file-server"; + asd = "reblocks-file-server"; + } + ); + systems = [ "reblocks-file-server" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "log4cl" self) + (getAttr "reblocks" self) + (getAttr "routes" self) + (getAttr "trivial-mimes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-file-server-ci = ( + build-asdf-system { + pname = "reblocks-file-server-ci"; + version = "20241012-git"; + asds = [ "reblocks-file-server-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-file-server/2024-10-12/reblocks-file-server-20241012-git.tgz"; + sha256 = "1v17v0474k845l0s0bgly3zbgq2rjn5fyh8zmjnisszgkdd3bh13"; + system = "reblocks-file-server-ci"; + asd = "reblocks-file-server-ci"; + } + ); + systems = [ "reblocks-file-server-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-file-server-docs = ( + build-asdf-system { + pname = "reblocks-file-server-docs"; + version = "20241012-git"; + asds = [ "reblocks-file-server-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-file-server/2024-10-12/reblocks-file-server-20241012-git.tgz"; + sha256 = "1v17v0474k845l0s0bgly3zbgq2rjn5fyh8zmjnisszgkdd3bh13"; + system = "reblocks-file-server-docs"; + asd = "reblocks-file-server-docs"; + } + ); + systems = [ "reblocks-file-server-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + (getAttr "reblocks-file-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-file-server-tests = ( + build-asdf-system { + pname = "reblocks-file-server-tests"; + version = "20241012-git"; + asds = [ "reblocks-file-server-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-file-server/2024-10-12/reblocks-file-server-20241012-git.tgz"; + sha256 = "1v17v0474k845l0s0bgly3zbgq2rjn5fyh8zmjnisszgkdd3bh13"; + system = "reblocks-file-server-tests"; + asd = "reblocks-file-server-tests"; + } + ); + systems = [ "reblocks-file-server-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-lass = ( + build-asdf-system { + pname = "reblocks-lass"; + version = "20241012-git"; + asds = [ "reblocks-lass" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-lass/2024-10-12/reblocks-lass-20241012-git.tgz"; + sha256 = "0aic2dnsp4hkc26fpnn0p493psz1fip9rfhbacfwaaqyxdgrh9cl"; + system = "reblocks-lass"; + asd = "reblocks-lass"; + } + ); + systems = [ "reblocks-lass" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "lass" self) + (getAttr "reblocks" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-lass-ci = ( + build-asdf-system { + pname = "reblocks-lass-ci"; + version = "20241012-git"; + asds = [ "reblocks-lass-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-lass/2024-10-12/reblocks-lass-20241012-git.tgz"; + sha256 = "0aic2dnsp4hkc26fpnn0p493psz1fip9rfhbacfwaaqyxdgrh9cl"; + system = "reblocks-lass-ci"; + asd = "reblocks-lass-ci"; + } + ); + systems = [ "reblocks-lass-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-lass-docs = ( + build-asdf-system { + pname = "reblocks-lass-docs"; + version = "20241012-git"; + asds = [ "reblocks-lass-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-lass/2024-10-12/reblocks-lass-20241012-git.tgz"; + sha256 = "0aic2dnsp4hkc26fpnn0p493psz1fip9rfhbacfwaaqyxdgrh9cl"; + system = "reblocks-lass-docs"; + asd = "reblocks-lass-docs"; + } + ); + systems = [ "reblocks-lass-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + (getAttr "reblocks-lass" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-lass-tests = ( + build-asdf-system { + pname = "reblocks-lass-tests"; + version = "20241012-git"; + asds = [ "reblocks-lass-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-lass/2024-10-12/reblocks-lass-20241012-git.tgz"; + sha256 = "0aic2dnsp4hkc26fpnn0p493psz1fip9rfhbacfwaaqyxdgrh9cl"; + system = "reblocks-lass-tests"; + asd = "reblocks-lass-tests"; + } + ); + systems = [ "reblocks-lass-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-navigation-widget = ( + build-asdf-system { + pname = "reblocks-navigation-widget"; + version = "20241012-git"; + asds = [ "reblocks-navigation-widget" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-navigation-widget/2024-10-12/reblocks-navigation-widget-20241012-git.tgz"; + sha256 = "0gwfzlf8054g3iizbkbbzkxfmr8xlcvgcqycx7crlgzc8qksrqhm"; + system = "reblocks-navigation-widget"; + asd = "reblocks-navigation-widget"; + } + ); + systems = [ "reblocks-navigation-widget" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "log4cl" self) + (getAttr "reblocks" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-navigation-widget-ci = ( + build-asdf-system { + pname = "reblocks-navigation-widget-ci"; + version = "20241012-git"; + asds = [ "reblocks-navigation-widget-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-navigation-widget/2024-10-12/reblocks-navigation-widget-20241012-git.tgz"; + sha256 = "0gwfzlf8054g3iizbkbbzkxfmr8xlcvgcqycx7crlgzc8qksrqhm"; + system = "reblocks-navigation-widget-ci"; + asd = "reblocks-navigation-widget-ci"; + } + ); + systems = [ "reblocks-navigation-widget-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-navigation-widget-docs = ( + build-asdf-system { + pname = "reblocks-navigation-widget-docs"; + version = "20241012-git"; + asds = [ "reblocks-navigation-widget-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-navigation-widget/2024-10-12/reblocks-navigation-widget-20241012-git.tgz"; + sha256 = "0gwfzlf8054g3iizbkbbzkxfmr8xlcvgcqycx7crlgzc8qksrqhm"; + system = "reblocks-navigation-widget-docs"; + asd = "reblocks-navigation-widget-docs"; + } + ); + systems = [ "reblocks-navigation-widget-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + (getAttr "reblocks-navigation-widget" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-navigation-widget-tests = ( + build-asdf-system { + pname = "reblocks-navigation-widget-tests"; + version = "20241012-git"; + asds = [ "reblocks-navigation-widget-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-navigation-widget/2024-10-12/reblocks-navigation-widget-20241012-git.tgz"; + sha256 = "0gwfzlf8054g3iizbkbbzkxfmr8xlcvgcqycx7crlgzc8qksrqhm"; + system = "reblocks-navigation-widget-tests"; + asd = "reblocks-navigation-widget-tests"; + } + ); + systems = [ "reblocks-navigation-widget-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-parenscript = ( + build-asdf-system { + pname = "reblocks-parenscript"; + version = "20241012-git"; + asds = [ "reblocks-parenscript" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-parenscript/2024-10-12/reblocks-parenscript-20241012-git.tgz"; + sha256 = "0c29y7k6kczzcz1fgsk0iyf93qsx4nmw3iir807zicya8dkvvpk6"; + system = "reblocks-parenscript"; + asd = "reblocks-parenscript"; + } + ); + systems = [ "reblocks-parenscript" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "parenscript" self) + (getAttr "reblocks" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-parenscript-ci = ( + build-asdf-system { + pname = "reblocks-parenscript-ci"; + version = "20241012-git"; + asds = [ "reblocks-parenscript-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-parenscript/2024-10-12/reblocks-parenscript-20241012-git.tgz"; + sha256 = "0c29y7k6kczzcz1fgsk0iyf93qsx4nmw3iir807zicya8dkvvpk6"; + system = "reblocks-parenscript-ci"; + asd = "reblocks-parenscript-ci"; + } + ); + systems = [ "reblocks-parenscript-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-parenscript-docs = ( + build-asdf-system { + pname = "reblocks-parenscript-docs"; + version = "20241012-git"; + asds = [ "reblocks-parenscript-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-parenscript/2024-10-12/reblocks-parenscript-20241012-git.tgz"; + sha256 = "0c29y7k6kczzcz1fgsk0iyf93qsx4nmw3iir807zicya8dkvvpk6"; + system = "reblocks-parenscript-docs"; + asd = "reblocks-parenscript-docs"; + } + ); + systems = [ "reblocks-parenscript-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + (getAttr "reblocks-parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-parenscript-tests = ( + build-asdf-system { + pname = "reblocks-parenscript-tests"; + version = "20241012-git"; + asds = [ "reblocks-parenscript-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-parenscript/2024-10-12/reblocks-parenscript-20241012-git.tgz"; + sha256 = "0c29y7k6kczzcz1fgsk0iyf93qsx4nmw3iir807zicya8dkvvpk6"; + system = "reblocks-parenscript-tests"; + asd = "reblocks-parenscript-tests"; + } + ); + systems = [ "reblocks-parenscript-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-prometheus = ( + build-asdf-system { + pname = "reblocks-prometheus"; + version = "20241012-git"; + asds = [ "reblocks-prometheus" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-prometheus/2024-10-12/reblocks-prometheus-20241012-git.tgz"; + sha256 = "0bjzwk28csfdvnic2znil6cxk8fmh5p49n971q5pjs0dmwdzmwra"; + system = "reblocks-prometheus"; + asd = "reblocks-prometheus"; + } + ); + systems = [ "reblocks-prometheus" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "cffi-grovel" self) + (getAttr "log4cl-extras" self) + (getAttr "prometheus" self) + (getAttr "prometheus-gc" self) + (getAttr "prometheus_dot_collectors_dot_process" self) + (getAttr "prometheus_dot_collectors_dot_sbcl" self) + (getAttr "prometheus_dot_formats_dot_text" self) + (getAttr "reblocks" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-prometheus-ci = ( + build-asdf-system { + pname = "reblocks-prometheus-ci"; + version = "20241012-git"; + asds = [ "reblocks-prometheus-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-prometheus/2024-10-12/reblocks-prometheus-20241012-git.tgz"; + sha256 = "0bjzwk28csfdvnic2znil6cxk8fmh5p49n971q5pjs0dmwdzmwra"; + system = "reblocks-prometheus-ci"; + asd = "reblocks-prometheus-ci"; + } + ); + systems = [ "reblocks-prometheus-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-prometheus-docs = ( + build-asdf-system { + pname = "reblocks-prometheus-docs"; + version = "20241012-git"; + asds = [ "reblocks-prometheus-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-prometheus/2024-10-12/reblocks-prometheus-20241012-git.tgz"; + sha256 = "0bjzwk28csfdvnic2znil6cxk8fmh5p49n971q5pjs0dmwdzmwra"; + system = "reblocks-prometheus-docs"; + asd = "reblocks-prometheus-docs"; + } + ); + systems = [ "reblocks-prometheus-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + (getAttr "reblocks-prometheus" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-prometheus-tests = ( + build-asdf-system { + pname = "reblocks-prometheus-tests"; + version = "20241012-git"; + asds = [ "reblocks-prometheus-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-prometheus/2024-10-12/reblocks-prometheus-20241012-git.tgz"; + sha256 = "0bjzwk28csfdvnic2znil6cxk8fmh5p49n971q5pjs0dmwdzmwra"; + system = "reblocks-prometheus-tests"; + asd = "reblocks-prometheus-tests"; + } + ); + systems = [ "reblocks-prometheus-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-tests = ( + build-asdf-system { + pname = "reblocks-tests"; + version = "20241012-git"; + asds = [ "reblocks-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks/2024-10-12/reblocks-20241012-git.tgz"; + sha256 = "0s8npy7bh013qhm6ngvi7ar117ja2m098nr4krnzlcg2ivxdff3i"; + system = "reblocks-tests"; + asd = "reblocks-tests"; + } + ); + systems = [ "reblocks-tests" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-mock" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "hamcrest" self) + (getAttr "lack-request" self) + (getAttr "lack-test" self) + (getAttr "reblocks" self) + (getAttr "rove" self) + (getAttr "serapeum" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-typeahead = ( + build-asdf-system { + pname = "reblocks-typeahead"; + version = "20241012-git"; + asds = [ "reblocks-typeahead" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-typeahead/2024-10-12/reblocks-typeahead-20241012-git.tgz"; + sha256 = "150msgfsagpcpbgfva3hgnw3jhd3rg13g0ham9ns0lhf1lb3777m"; + system = "reblocks-typeahead"; + asd = "reblocks-typeahead"; + } + ); + systems = [ "reblocks-typeahead" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "parenscript" self) + (getAttr "reblocks" self) + (getAttr "reblocks-lass" self) + (getAttr "reblocks-parenscript" self) + (getAttr "reblocks-ui" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-typeahead-ci = ( + build-asdf-system { + pname = "reblocks-typeahead-ci"; + version = "20241012-git"; + asds = [ "reblocks-typeahead-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-typeahead/2024-10-12/reblocks-typeahead-20241012-git.tgz"; + sha256 = "150msgfsagpcpbgfva3hgnw3jhd3rg13g0ham9ns0lhf1lb3777m"; + system = "reblocks-typeahead-ci"; + asd = "reblocks-typeahead-ci"; + } + ); + systems = [ "reblocks-typeahead-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-typeahead-docs = ( + build-asdf-system { + pname = "reblocks-typeahead-docs"; + version = "20241012-git"; + asds = [ "reblocks-typeahead-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-typeahead/2024-10-12/reblocks-typeahead-20241012-git.tgz"; + sha256 = "150msgfsagpcpbgfva3hgnw3jhd3rg13g0ham9ns0lhf1lb3777m"; + system = "reblocks-typeahead-docs"; + asd = "reblocks-typeahead-docs"; + } + ); + systems = [ "reblocks-typeahead-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + (getAttr "reblocks-typeahead" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-typeahead-example = ( + build-asdf-system { + pname = "reblocks-typeahead-example"; + version = "20241012-git"; + asds = [ "reblocks-typeahead-example" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-typeahead/2024-10-12/reblocks-typeahead-20241012-git.tgz"; + sha256 = "150msgfsagpcpbgfva3hgnw3jhd3rg13g0ham9ns0lhf1lb3777m"; + system = "reblocks-typeahead-example"; + asd = "reblocks-typeahead-example"; + } + ); + systems = [ "reblocks-typeahead-example" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "_40ants-logging" self) + (getAttr "_40ants-slynk" self) + (getAttr "alexandria" self) + (getAttr "clack-handler-hunchentoot" self) + (getAttr "mito" self) + (getAttr "reblocks" self) + (getAttr "reblocks-auth" self) + (getAttr "reblocks-lass" self) + (getAttr "reblocks-navigation-widget" self) + (getAttr "reblocks-prometheus" self) + (getAttr "reblocks-typeahead" self) + (getAttr "reblocks-ui" self) + (getAttr "serapeum" self) + (getAttr "spinneret" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-typeahead-tests = ( + build-asdf-system { + pname = "reblocks-typeahead-tests"; + version = "20241012-git"; + asds = [ "reblocks-typeahead-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-typeahead/2024-10-12/reblocks-typeahead-20241012-git.tgz"; + sha256 = "150msgfsagpcpbgfva3hgnw3jhd3rg13g0ham9ns0lhf1lb3777m"; + system = "reblocks-typeahead-tests"; + asd = "reblocks-typeahead-tests"; + } + ); + systems = [ "reblocks-typeahead-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-ui = ( + build-asdf-system { + pname = "reblocks-ui"; + version = "20241012-git"; + asds = [ "reblocks-ui" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-ui/2024-10-12/reblocks-ui-20241012-git.tgz"; + sha256 = "1iwq62ba0rsiqw34d681nzg88wzps1f3d1ahl99crrk9xpy1c3y5"; + system = "reblocks-ui"; + asd = "reblocks-ui"; + } + ); + systems = [ "reblocks-ui" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "log4cl" self) + (getAttr "log4cl-extras" self) + (getAttr "parenscript" self) + (getAttr "quri" self) + (getAttr "reblocks" self) + (getAttr "reblocks-parenscript" self) + (getAttr "serapeum" self) + (getAttr "spinneret" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-ui-docs = ( + build-asdf-system { + pname = "reblocks-ui-docs"; + version = "20241012-git"; + asds = [ "reblocks-ui-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-ui/2024-10-12/reblocks-ui-20241012-git.tgz"; + sha256 = "1iwq62ba0rsiqw34d681nzg88wzps1f3d1ahl99crrk9xpy1c3y5"; + system = "reblocks-ui-docs"; + asd = "reblocks-ui-docs"; + } + ); + systems = [ "reblocks-ui-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "docs-config" self) + (getAttr "reblocks" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-ui-examples = ( + build-asdf-system { + pname = "reblocks-ui-examples"; + version = "20241012-git"; + asds = [ "reblocks-ui-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-ui/2024-10-12/reblocks-ui-20241012-git.tgz"; + sha256 = "1iwq62ba0rsiqw34d681nzg88wzps1f3d1ahl99crrk9xpy1c3y5"; + system = "reblocks-ui-examples"; + asd = "reblocks-ui-examples"; + } + ); + systems = [ "reblocks-ui-examples" ]; + lispLibs = [ + (getAttr "reblocks" self) + (getAttr "reblocks-lass" self) + (getAttr "reblocks-ui" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-websocket = ( + build-asdf-system { + pname = "reblocks-websocket"; + version = "20241012-git"; + asds = [ "reblocks-websocket" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-websocket/2024-10-12/reblocks-websocket-20241012-git.tgz"; + sha256 = "0zn14if637cfadz93cgyk79hqrjyzddwc483gl10386rj9nvcf6b"; + system = "reblocks-websocket"; + asd = "reblocks-websocket"; + } + ); + systems = [ "reblocks-websocket" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "jonathan" self) + (getAttr "log4cl-extras" self) + (getAttr "parenscript" self) + (getAttr "reblocks" self) + (getAttr "reblocks-parenscript" self) + (getAttr "serapeum" self) + (getAttr "websocket-driver" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-websocket-ci = ( + build-asdf-system { + pname = "reblocks-websocket-ci"; + version = "20241012-git"; + asds = [ "reblocks-websocket-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-websocket/2024-10-12/reblocks-websocket-20241012-git.tgz"; + sha256 = "0zn14if637cfadz93cgyk79hqrjyzddwc483gl10386rj9nvcf6b"; + system = "reblocks-websocket-ci"; + asd = "reblocks-websocket-ci"; + } + ); + systems = [ "reblocks-websocket-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-websocket-docs = ( + build-asdf-system { + pname = "reblocks-websocket-docs"; + version = "20241012-git"; + asds = [ "reblocks-websocket-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-websocket/2024-10-12/reblocks-websocket-20241012-git.tgz"; + sha256 = "0zn14if637cfadz93cgyk79hqrjyzddwc483gl10386rj9nvcf6b"; + system = "reblocks-websocket-docs"; + asd = "reblocks-websocket-docs"; + } + ); + systems = [ "reblocks-websocket-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + (getAttr "reblocks-websocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reblocks-websocket-tests = ( + build-asdf-system { + pname = "reblocks-websocket-tests"; + version = "20241012-git"; + asds = [ "reblocks-websocket-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reblocks-websocket/2024-10-12/reblocks-websocket-20241012-git.tgz"; + sha256 = "0zn14if637cfadz93cgyk79hqrjyzddwc483gl10386rj9nvcf6b"; + system = "reblocks-websocket-tests"; + asd = "reblocks-websocket-tests"; + } + ); + systems = [ "reblocks-websocket-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rectangle-packing = ( + build-asdf-system { + pname = "rectangle-packing"; + version = "20130615-git"; + asds = [ "rectangle-packing" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rectangle-packing/2013-06-15/rectangle-packing-20130615-git.tgz"; + sha256 = "1m31qbgkrgbp753mr012hpzjfddwmfzvazaadp3s6wd34vmbbv01"; + system = "rectangle-packing"; + asd = "rectangle-packing"; + } + ); + systems = [ "rectangle-packing" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + recur = ( + build-asdf-system { + pname = "recur"; + version = "20230618-git"; + asds = [ "recur" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/recur/2023-06-18/recur-20230618-git.tgz"; + sha256 = "1wlw378h3k4ganw49kk5zrhx3w692yfdb4zaiciwqzviwz52c7gc"; + system = "recur"; + asd = "recur"; + } + ); + systems = [ "recur" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + recursive-regex = ( + build-asdf-system { + pname = "recursive-regex"; + version = "20120407-git"; + asds = [ "recursive-regex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/recursive-regex/2012-04-07/recursive-regex-20120407-git.tgz"; + sha256 = "1alsfqfa85dwms7i3xrbp6ahlqk9a3sl8d4llxy1ydb0rlb09l4r"; + system = "recursive-regex"; + asd = "recursive-regex"; + } + ); + systems = [ "recursive-regex" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "iterate" self) + (getAttr "symbol-munger" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + recursive-regex-test = ( + build-asdf-system { + pname = "recursive-regex-test"; + version = "20120407-git"; + asds = [ "recursive-regex-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/recursive-regex/2012-04-07/recursive-regex-20120407-git.tgz"; + sha256 = "1alsfqfa85dwms7i3xrbp6ahlqk9a3sl8d4llxy1ydb0rlb09l4r"; + system = "recursive-regex-test"; + asd = "recursive-regex"; + } + ); + systems = [ "recursive-regex-test" ]; + lispLibs = [ + (getAttr "lisp-unit" self) + (getAttr "recursive-regex" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + recursive-restart = ( + build-asdf-system { + pname = "recursive-restart"; + version = "20161031-git"; + asds = [ "recursive-restart" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/recursive-restart/2016-10-31/recursive-restart-20161031-git.tgz"; + sha256 = "0lgw95bnzw99avrb7vcg02fbw3y5mazfgnkim8gsazfjliaj21m7"; + system = "recursive-restart"; + asd = "recursive-restart"; + } + ); + systems = [ "recursive-restart" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + red-black-tree = ( + build-asdf-system { + pname = "red-black-tree"; + version = "20220707-git"; + asds = [ "red-black-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/red-black-tree/2022-07-07/red-black-tree-20220707-git.tgz"; + sha256 = "0dbl6y4l7k30a13d6rfdfby6p27li5b17nvz7xgyajxl9q5zz5kk"; + system = "red-black-tree"; + asd = "red-black-tree"; + } + ); + systems = [ "red-black-tree" ]; + lispLibs = [ (getAttr "mfiano-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + redirect-stream = ( + build-asdf-system { + pname = "redirect-stream"; + version = "20231021-git"; + asds = [ "redirect-stream" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/redirect-stream/2023-10-21/redirect-stream-20231021-git.tgz"; + sha256 = "1x8m2jk02dmsc2y8kq5h1bkdl51qz3ldg58hdzj6dpyi6ciykj28"; + system = "redirect-stream"; + asd = "redirect-stream"; + } + ); + systems = [ "redirect-stream" ]; + lispLibs = [ (getAttr "trivial-gray-streams" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + regex = ( + build-asdf-system { + pname = "regex"; + version = "20120909-git"; + asds = [ "regex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regex/2012-09-09/regex-20120909-git.tgz"; + sha256 = "0wq5wlafrxv13wg28hg5b10sc48b88swsvznpy2zg7x37m4nmm6a"; + system = "regex"; + asd = "regex"; + } + ); + systems = [ "regex" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + remote-js = ( + build-asdf-system { + pname = "remote-js"; + version = "20190710-git"; + asds = [ "remote-js" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/remote-js/2019-07-10/remote-js-20190710-git.tgz"; + sha256 = "1z8apvfng8i7x4dsnz9da4y2l9mr7jykm19lmq3070qra7r3lby6"; + system = "remote-js"; + asd = "remote-js"; + } + ); + systems = [ "remote-js" ]; + lispLibs = [ + (getAttr "cl-markup" self) + (getAttr "find-port" self) + (getAttr "trivial-ws" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + remote-js-test = ( + build-asdf-system { + pname = "remote-js-test"; + version = "20190710-git"; + asds = [ "remote-js-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/remote-js/2019-07-10/remote-js-20190710-git.tgz"; + sha256 = "1z8apvfng8i7x4dsnz9da4y2l9mr7jykm19lmq3070qra7r3lby6"; + system = "remote-js-test"; + asd = "remote-js-test"; + } + ); + systems = [ "remote-js-test" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "fiveam" self) + (getAttr "remote-js" self) + (getAttr "trivial-open-browser" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + repl-utilities = ( + build-asdf-system { + pname = "repl-utilities"; + version = "20210228-git"; + asds = [ "repl-utilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/repl-utilities/2021-02-28/repl-utilities-20210228-git.tgz"; + sha256 = "1hh56pq5nw3l4b83dzlyss69f06r038byj2cnjwvci4hfjhdfcc3"; + system = "repl-utilities"; + asd = "repl-utilities"; + } + ); + systems = [ "repl-utilities" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + replic = ( + build-asdf-system { + pname = "replic"; + version = "20230214-git"; + asds = [ "replic" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/replic/2023-02-14/replic-20230214-git.tgz"; + sha256 = "1jq0ysgpkcsw2fbxjy0v9kqvfnrdwzvrzc1a7fykihds548z3slf"; + system = "replic"; + asd = "replic"; + } + ); + systems = [ "replic" ]; + lispLibs = [ + (getAttr "cl-ansi-text" self) + (getAttr "cl-readline" self) + (getAttr "py-configparser" self) + (getAttr "shlex" self) + (getAttr "str" self) + (getAttr "unix-opts" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + replic-test = ( + build-asdf-system { + pname = "replic-test"; + version = "20230214-git"; + asds = [ "replic-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/replic/2023-02-14/replic-20230214-git.tgz"; + sha256 = "1jq0ysgpkcsw2fbxjy0v9kqvfnrdwzvrzc1a7fykihds548z3slf"; + system = "replic-test"; + asd = "replic-test"; + } + ); + systems = [ "replic-test" ]; + lispLibs = [ + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "replic" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + research = ( + build-asdf-system { + pname = "research"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "research" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "research"; + asd = "research"; + } + ); + systems = [ "research" ]; + lispLibs = [ + (getAttr "_2d-array-test" self) + (getAttr "adjuvant" self) + (getAttr "adjuvant-test" self) + (getAttr "dispatch-test" self) + (getAttr "ndfa-test" self) + (getAttr "rte-regexp-test" self) + (getAttr "rte-test" self) + (getAttr "scrutiny" self) + (getAttr "scrutiny-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + resignal-bind = ( + build-asdf-system { + pname = "resignal-bind"; + version = "20211020-git"; + asds = [ "resignal-bind" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/resignal-bind/2021-10-20/resignal-bind-20211020-git.tgz"; + sha256 = "109b5bf2h3yqax87r16dsbnb0xdd9kqi0zdisy0wja1h622yrxhc"; + system = "resignal-bind"; + asd = "resignal-bind"; + } + ); + systems = [ "resignal-bind" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "jingoh_dot_documentizer" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + resignal-bind_dot_test = ( + build-asdf-system { + pname = "resignal-bind.test"; + version = "20211020-git"; + asds = [ "resignal-bind.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/resignal-bind/2021-10-20/resignal-bind-20211020-git.tgz"; + sha256 = "109b5bf2h3yqax87r16dsbnb0xdd9kqi0zdisy0wja1h622yrxhc"; + system = "resignal-bind.test"; + asd = "resignal-bind.test"; + } + ); + systems = [ "resignal-bind.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "resignal-bind" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + restas = ( + build-asdf-system { + pname = "restas"; + version = "20191008-git"; + asds = [ "restas" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/restas/2019-10-08/restas-20191008-git.tgz"; + sha256 = "00ng6jik1lwjw3bbxhijy8s0ml24lgm73liwrr01gcsb0r6wrjjn"; + system = "restas"; + asd = "restas"; + } + ); + systems = [ "restas" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "data-sift" self) + (getAttr "hunchentoot" self) + (getAttr "routes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + restas-directory-publisher = ( + build-asdf-system { + pname = "restas-directory-publisher"; + version = "20130128-git"; + asds = [ "restas-directory-publisher" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/restas-directory-publisher/2013-01-28/restas-directory-publisher-20130128-git.tgz"; + sha256 = "1ra4bxsg9v507zrqjx78ak3797clagl6n62d3bx0aghrnkal1gmp"; + system = "restas-directory-publisher"; + asd = "restas-directory-publisher"; + } + ); + systems = [ "restas-directory-publisher" ]; + lispLibs = [ + (getAttr "closure-template" self) + (getAttr "local-time" self) + (getAttr "restas" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + restas-doc = ( + build-asdf-system { + pname = "restas-doc"; + version = "20191008-git"; + asds = [ "restas-doc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/restas/2019-10-08/restas-20191008-git.tgz"; + sha256 = "00ng6jik1lwjw3bbxhijy8s0ml24lgm73liwrr01gcsb0r6wrjjn"; + system = "restas-doc"; + asd = "restas-doc"; + } + ); + systems = [ "restas-doc" ]; + lispLibs = [ + (getAttr "restas" self) + (getAttr "restas-directory-publisher" self) + (getAttr "sphinx" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + restas_dot_file-publisher = ( + build-asdf-system { + pname = "restas.file-publisher"; + version = "20120107-git"; + asds = [ "restas.file-publisher" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/restas.file-publisher/2012-01-07/restas.file-publisher-20120107-git.tgz"; + sha256 = "12h291as21ziqb1l6p2p4hy429z6zznacp1gn0m2vah7f811q75l"; + system = "restas.file-publisher"; + asd = "restas.file-publisher"; + } + ); + systems = [ "restas.file-publisher" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "restas" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + restful = ( + build-asdf-system { + pname = "restful"; + version = "20150608-git"; + asds = [ "restful" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/restful/2015-06-08/restful-20150608-git.tgz"; + sha256 = "1imcpd9zm1dbb1675pf3g3d6w9vyxk07g7r33174qdw470j8ml5n"; + system = "restful"; + asd = "restful"; + } + ); + systems = [ "restful" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "hunchentoot" self) + (getAttr "jonathan" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + restful-test = ( + build-asdf-system { + pname = "restful-test"; + version = "20150608-git"; + asds = [ "restful-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/restful/2015-06-08/restful-20150608-git.tgz"; + sha256 = "1imcpd9zm1dbb1675pf3g3d6w9vyxk07g7r33174qdw470j8ml5n"; + system = "restful-test"; + asd = "restful-test"; + } + ); + systems = [ "restful-test" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "restful" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + restricted-functions = ( + build-asdf-system { + pname = "restricted-functions"; + version = "20190521-git"; + asds = [ "restricted-functions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/restricted-functions/2019-05-21/restricted-functions-20190521-git.tgz"; + sha256 = "092k7bp6n8kppf2wdqf1kf1h8lrww6k1dcxp05dby779b8c6kfz4"; + system = "restricted-functions"; + asd = "restricted-functions"; + } + ); + systems = [ "restricted-functions" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "simplified-types" self) + (getAttr "trivia" self) + (getAttr "trivial-arguments" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + retrospectiff = ( + build-asdf-system { + pname = "retrospectiff"; + version = "20211209-git"; + asds = [ "retrospectiff" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/retrospectiff/2021-12-09/retrospectiff-20211209-git.tgz"; + sha256 = "1vfcbfzhkm2wkxnjg7y6gg93wlib9cqpbdbhyqcm5kc7170ci3vz"; + system = "retrospectiff"; + asd = "retrospectiff"; + } + ); + systems = [ "retrospectiff" ]; + lispLibs = [ + (getAttr "cl-jpeg" self) + (getAttr "com_dot_gigamonkeys_dot_binary-data" self) + (getAttr "deflate" self) + (getAttr "flexi-streams" self) + (getAttr "ieee-floats" self) + (getAttr "opticl-core" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + reversi = ( + build-asdf-system { + pname = "reversi"; + version = "20201016-git"; + asds = [ "reversi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/reversi/2020-10-16/reversi-20201016-git.tgz"; + sha256 = "1vwjk207hvn5skazmkrcifkv4ia9nm5312rj0fr3w5423dr56swx"; + system = "reversi"; + asd = "reversi"; + } + ); + systems = [ "reversi" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rfc2109 = ( + build-asdf-system { + pname = "rfc2109"; + version = "20151218-darcs"; + asds = [ "rfc2109" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rfc2109/2015-12-18/rfc2109-20151218-darcs.tgz"; + sha256 = "1y767qjv5jxyfqzp0zpw96yz95mb8hhpjj9dn2i6b92r0z2vr42d"; + system = "rfc2109"; + asd = "rfc2109"; + } + ); + systems = [ "rfc2109" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rfc2388 = ( + build-asdf-system { + pname = "rfc2388"; + version = "20180831-git"; + asds = [ "rfc2388" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rfc2388/2018-08-31/rfc2388-20180831-git.tgz"; + sha256 = "0phh5n3clhl9ji8jaxrajidn22d3f0aq87mlbfkkxlnx2pnw694k"; + system = "rfc2388"; + asd = "rfc2388"; + } + ); + systems = [ "rfc2388" ]; + lispLibs = [ ]; + meta = { }; + } + ); + rfc2388-binary = ( + build-asdf-system { + pname = "rfc2388-binary"; + version = "20170124-darcs"; + asds = [ "rfc2388-binary" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rfc2388-binary/2017-01-24/rfc2388-binary-20170124-darcs.tgz"; + sha256 = "1ddjhd9vqramg93963d4py9a2hqpy1fr1ly517r3bpjx7a5mffwk"; + system = "rfc2388-binary"; + asd = "rfc2388-binary"; + } + ); + systems = [ "rfc2388-binary" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rlc = ( + build-asdf-system { + pname = "rlc"; + version = "20150923-git"; + asds = [ "rlc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rlc/2015-09-23/rlc-20150923-git.tgz"; + sha256 = "1c37as5x45yizs76s7115a0w3fgas80bjb8xzq7yylpmxq44s2rk"; + system = "rlc"; + asd = "rlc"; + } + ); + systems = [ "rlc" ]; + lispLibs = [ (getAttr "kmrcl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + roan = ( + build-asdf-system { + pname = "roan"; + version = "20201220-git"; + asds = [ "roan" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/roan/2020-12-20/roan-20201220-git.tgz"; + sha256 = "032znprz03x4apzssb5vzs55cfdfyvca56bcrwxwm9dgkh3cnh7z"; + system = "roan"; + asd = "roan"; + } + ); + systems = [ "roan" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "asdf-encodings" self) + (getAttr "binascii" self) + (getAttr "cl-fad" self) + (getAttr "cl-interpol" self) + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "iterate" self) + (getAttr "local-time" self) + (getAttr "named-readtables" self) + (getAttr "plump" self) + (getAttr "uuid" self) + (getAttr "zip" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + robot = ( + build-asdf-system { + pname = "robot"; + version = "master-fe503896-git"; + asds = [ "robot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "robot"; + asd = "robot"; + } + ); + systems = [ "robot" ]; + lispLibs = [ (getAttr "gwl-graphics" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rock = ( + build-asdf-system { + pname = "rock"; + version = "20150608-git"; + asds = [ "rock" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rock/2015-06-08/rock-20150608-git.tgz"; + sha256 = "1ckvxswinv25vzwmyrr6k7m9cx99kl04b4543mlxad9688np91y8"; + system = "rock"; + asd = "rock"; + } + ); + systems = [ "rock" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "trivial-download" self) + (getAttr "trivial-extract" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rock-test = ( + build-asdf-system { + pname = "rock-test"; + version = "20150608-git"; + asds = [ "rock-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rock/2015-06-08/rock-20150608-git.tgz"; + sha256 = "1ckvxswinv25vzwmyrr6k7m9cx99kl04b4543mlxad9688np91y8"; + system = "rock-test"; + asd = "rock-test"; + } + ); + systems = [ "rock-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "rock" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rock-web = ( + build-asdf-system { + pname = "rock-web"; + version = "20150608-git"; + asds = [ "rock-web" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rock/2015-06-08/rock-20150608-git.tgz"; + sha256 = "1ckvxswinv25vzwmyrr6k7m9cx99kl04b4543mlxad9688np91y8"; + system = "rock-web"; + asd = "rock-web"; + } + ); + systems = [ "rock-web" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "_3bmd-ext-code-blocks" self) + (getAttr "_3bmd-ext-definition-lists" self) + (getAttr "cl-markup" self) + (getAttr "lass" self) + (getAttr "rock" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + romreader = ( + build-asdf-system { + pname = "romreader"; + version = "20140713-git"; + asds = [ "romreader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/romreader/2014-07-13/romreader-20140713-git.tgz"; + sha256 = "1k3fnh48vy5wdbqif4hmflmxc3xnihyi1222cldcjvxl294yk6xx"; + system = "romreader"; + asd = "romreader"; + } + ); + systems = [ "romreader" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + routes = ( + build-asdf-system { + pname = "routes"; + version = "20170124-git"; + asds = [ "routes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-routes/2017-01-24/cl-routes-20170124-git.tgz"; + sha256 = "1zpk3cp2v8hm50ppjl10yxr437vv4552r8hylvizglzrq2ibsbr1"; + system = "routes"; + asd = "routes"; + } + ); + systems = [ "routes" ]; + lispLibs = [ + (getAttr "iterate" self) + (getAttr "puri" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + routes-test = ( + build-asdf-system { + pname = "routes-test"; + version = "20170124-git"; + asds = [ "routes-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-routes/2017-01-24/cl-routes-20170124-git.tgz"; + sha256 = "1zpk3cp2v8hm50ppjl10yxr437vv4552r8hylvizglzrq2ibsbr1"; + system = "routes-test"; + asd = "routes"; + } + ); + systems = [ "routes-test" ]; + lispLibs = [ + (getAttr "lift" self) + (getAttr "routes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rove = ( + build-asdf-system { + pname = "rove"; + version = "20241012-git"; + asds = [ "rove" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rove/2024-10-12/rove-20241012-git.tgz"; + sha256 = "1cx55d8frlk8rzdwbf1698rsvy34gx0ws2ix257qsh7gxy2mld05"; + system = "rove"; + asd = "rove"; + } + ); + systems = [ "rove" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "dissect" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + rovers-problem-translator = ( + build-asdf-system { + pname = "rovers-problem-translator"; + version = "20241012-git"; + asds = [ "rovers-problem-translator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/shop3/2024-10-12/shop3-20241012-git.tgz"; + sha256 = "1sdyyyd82fqmm9lcqmg7k8yy3l3891m2gjwidibzvk95bp4xf9sd"; + system = "rovers-problem-translator"; + asd = "rovers-problem-translator"; + } + ); + systems = [ "rovers-problem-translator" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "shop3" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rpcq = ( + build-asdf-system { + pname = "rpcq"; + version = "v3.10.0"; + asds = [ "rpcq" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rpcq/2022-07-07/rpcq-v3.10.0.tgz"; + sha256 = "1bvppxlacvp0pfdbpn7ls1zxd127jacl225ds7lph5s8f8cyvf17"; + system = "rpcq"; + asd = "rpcq"; + } + ); + systems = [ "rpcq" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-messagepack" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-syslog" self) + (getAttr "flexi-streams" self) + (getAttr "local-time" self) + (getAttr "parse-float" self) + (getAttr "pzmq" self) + (getAttr "trivial-backtrace" self) + (getAttr "uuid" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rpcq-tests = ( + build-asdf-system { + pname = "rpcq-tests"; + version = "v3.10.0"; + asds = [ "rpcq-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rpcq/2022-07-07/rpcq-v3.10.0.tgz"; + sha256 = "1bvppxlacvp0pfdbpn7ls1zxd127jacl225ds7lph5s8f8cyvf17"; + system = "rpcq-tests"; + asd = "rpcq-tests"; + } + ); + systems = [ "rpcq-tests" ]; + lispLibs = [ + (getAttr "cl-messagepack" self) + (getAttr "cl-syslog" self) + (getAttr "fiasco" self) + (getAttr "rpcq" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rpm = ( + build-asdf-system { + pname = "rpm"; + version = "20160421-git"; + asds = [ "rpm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rpm/2016-04-21/rpm-20160421-git.tgz"; + sha256 = "0qn4vw3pvjm0maksl57mwikcmv7calzlblp5s01ixrn3nrgxmd9k"; + system = "rpm"; + asd = "rpm"; + } + ); + systems = [ "rpm" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "fare-utils" self) + (getAttr "inferior-shell" self) + (getAttr "lambda-reader" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rs-colors = ( + build-asdf-system { + pname = "rs-colors"; + version = "20220331-git"; + asds = [ "rs-colors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; + sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; + system = "rs-colors"; + asd = "rs-colors"; + } + ); + systems = [ "rs-colors" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + (getAttr "read-number" self) + (getAttr "rs-colors-internal" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rs-colors-html = ( + build-asdf-system { + pname = "rs-colors-html"; + version = "20220331-git"; + asds = [ "rs-colors-html" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; + sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; + system = "rs-colors-html"; + asd = "rs-colors-html"; + } + ); + systems = [ "rs-colors-html" ]; + lispLibs = [ (getAttr "rs-colors" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rs-colors-internal = ( + build-asdf-system { + pname = "rs-colors-internal"; + version = "20220331-git"; + asds = [ "rs-colors-internal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; + sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; + system = "rs-colors-internal"; + asd = "rs-colors-internal"; + } + ); + systems = [ "rs-colors-internal" ]; + lispLibs = [ (getAttr "iterate" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rs-colors-material-io = ( + build-asdf-system { + pname = "rs-colors-material-io"; + version = "20220331-git"; + asds = [ "rs-colors-material-io" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; + sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; + system = "rs-colors-material-io"; + asd = "rs-colors-material-io"; + } + ); + systems = [ "rs-colors-material-io" ]; + lispLibs = [ (getAttr "rs-colors" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rs-colors-ral = ( + build-asdf-system { + pname = "rs-colors-ral"; + version = "20220331-git"; + asds = [ "rs-colors-ral" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; + sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; + system = "rs-colors-ral"; + asd = "rs-colors-ral"; + } + ); + systems = [ "rs-colors-ral" ]; + lispLibs = [ (getAttr "rs-colors" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rs-colors-ral-design = ( + build-asdf-system { + pname = "rs-colors-ral-design"; + version = "20220331-git"; + asds = [ "rs-colors-ral-design" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; + sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; + system = "rs-colors-ral-design"; + asd = "rs-colors-ral-design"; + } + ); + systems = [ "rs-colors-ral-design" ]; + lispLibs = [ (getAttr "rs-colors" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rs-colors-svg = ( + build-asdf-system { + pname = "rs-colors-svg"; + version = "20220331-git"; + asds = [ "rs-colors-svg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; + sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; + system = "rs-colors-svg"; + asd = "rs-colors-svg"; + } + ); + systems = [ "rs-colors-svg" ]; + lispLibs = [ (getAttr "rs-colors" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rs-colors-tango = ( + build-asdf-system { + pname = "rs-colors-tango"; + version = "20220331-git"; + asds = [ "rs-colors-tango" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; + sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; + system = "rs-colors-tango"; + asd = "rs-colors-tango"; + } + ); + systems = [ "rs-colors-tango" ]; + lispLibs = [ (getAttr "rs-colors" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rs-colors-x11 = ( + build-asdf-system { + pname = "rs-colors-x11"; + version = "20220331-git"; + asds = [ "rs-colors-x11" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rs-colors/2022-03-31/rs-colors-20220331-git.tgz"; + sha256 = "06akjly9s4pfix39yca8n3dpazbby09wc8cj0fsfvkg61lvacic5"; + system = "rs-colors-x11"; + asd = "rs-colors-x11"; + } + ); + systems = [ "rs-colors-x11" ]; + lispLibs = [ (getAttr "rs-colors" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rs-dlx = ( + build-asdf-system { + pname = "rs-dlx"; + version = "20241012-git"; + asds = [ "rs-dlx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rs-dlx/2024-10-12/rs-dlx-20241012-git.tgz"; + sha256 = "003ykkh61hg5q9lxjckqp8njhpgg21j9008gcsw60hnxdipmanaf"; + system = "rs-dlx"; + asd = "rs-dlx"; + } + ); + systems = [ "rs-dlx" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rs-json = ( + build-asdf-system { + pname = "rs-json"; + version = "20230618-git"; + asds = [ "rs-json" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rs-json/2023-06-18/rs-json-20230618-git.tgz"; + sha256 = "0y71as0sg5vfijpzdhv6pj6yv064ldn2shx0y4da8kvaqv949dnq"; + system = "rs-json"; + asd = "rs-json"; + } + ); + systems = [ "rs-json" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-unicode" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rss = ( + build-asdf-system { + pname = "rss"; + version = "20201016-git"; + asds = [ "rss" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-rss/2020-10-16/cl-rss-20201016-git.tgz"; + sha256 = "0wv3j13fj73gigriw5r9vi920hz05ld7zllsvbxdxvmyfy9k1kly"; + system = "rss"; + asd = "rss"; + } + ); + systems = [ "rss" ]; + lispLibs = [ + (getAttr "aserve" self) + (getAttr "kmrcl" self) + (getAttr "xmls" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rt = ( + build-asdf-system { + pname = "rt"; + version = "20101006-git"; + asds = [ "rt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rt/2010-10-06/rt-20101006-git.tgz"; + sha256 = "13si2rrxaagbr0bkvg6sqicxxpyshabx6ad6byc9n2ik5ysna69b"; + system = "rt"; + asd = "rt"; + } + ); + systems = [ "rt" ]; + lispLibs = [ ]; + meta = { }; + } + ); + rt-events = ( + build-asdf-system { + pname = "rt-events"; + version = "20160318-git"; + asds = [ "rt-events" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rt-events/2016-03-18/rt-events-20160318-git.tgz"; + sha256 = "17wqhczsi4mq00fp5hfc38b9ijdiaqjh7cvxhy714qqz3f5mxzdw"; + system = "rt-events"; + asd = "rt-events"; + } + ); + systems = [ "rt-events" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rt-events_dot_examples = ( + build-asdf-system { + pname = "rt-events.examples"; + version = "20160318-git"; + asds = [ "rt-events.examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rt-events/2016-03-18/rt-events-20160318-git.tgz"; + sha256 = "17wqhczsi4mq00fp5hfc38b9ijdiaqjh7cvxhy714qqz3f5mxzdw"; + system = "rt-events.examples"; + asd = "rt-events.examples"; + } + ); + systems = [ "rt-events.examples" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "rt-events" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rte = ( + build-asdf-system { + pname = "rte"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "rte" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "rte"; + asd = "rte"; + } + ); + systems = [ "rte" ]; + lispLibs = [ + (getAttr "adjuvant" self) + (getAttr "lisp-types" self) + (getAttr "ndfa" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rte-regexp = ( + build-asdf-system { + pname = "rte-regexp"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "rte-regexp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "rte-regexp"; + asd = "rte-regexp"; + } + ); + systems = [ "rte-regexp" ]; + lispLibs = [ + (getAttr "adjuvant" self) + (getAttr "rte" self) + (getAttr "yacc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rte-regexp-test = ( + build-asdf-system { + pname = "rte-regexp-test"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "rte-regexp-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "rte-regexp-test"; + asd = "rte-regexp-test"; + } + ); + systems = [ "rte-regexp-test" ]; + lispLibs = [ + (getAttr "adjuvant" self) + (getAttr "rte" self) + (getAttr "rte-regexp" self) + (getAttr "scrutiny" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rte-test = ( + build-asdf-system { + pname = "rte-test"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "rte-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "rte-test"; + asd = "rte-test"; + } + ); + systems = [ "rte-test" ]; + lispLibs = [ + (getAttr "_2d-array" self) + (getAttr "_2d-array-test" self) + (getAttr "adjuvant" self) + (getAttr "lisp-types-test" self) + (getAttr "ndfa-test" self) + (getAttr "rte" self) + (getAttr "rte-regexp-test" self) + (getAttr "scrutiny" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rtg-math = ( + build-asdf-system { + pname = "rtg-math"; + version = "release-quicklisp-29fc5b3d-git"; + asds = [ "rtg-math" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rtg-math/2019-10-07/rtg-math-release-quicklisp-29fc5b3d-git.tgz"; + sha256 = "0bhxxnv7ldkkb18zdxyz2rj2a3iawzq2kcp7cn5i91iby7n0082x"; + system = "rtg-math"; + asd = "rtg-math"; + } + ); + systems = [ "rtg-math" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "documentation-utils" self) + (getAttr "glsl-symbols" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rtg-math_dot_vari = ( + build-asdf-system { + pname = "rtg-math.vari"; + version = "release-quicklisp-29fc5b3d-git"; + asds = [ "rtg-math.vari" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rtg-math/2019-10-07/rtg-math-release-quicklisp-29fc5b3d-git.tgz"; + sha256 = "0bhxxnv7ldkkb18zdxyz2rj2a3iawzq2kcp7cn5i91iby7n0082x"; + system = "rtg-math.vari"; + asd = "rtg-math.vari"; + } + ); + systems = [ "rtg-math.vari" ]; + lispLibs = [ + (getAttr "glsl-symbols" self) + (getAttr "rtg-math" self) + (getAttr "varjo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rucksack = ( + build-asdf-system { + pname = "rucksack"; + version = "20150608-git"; + asds = [ "rucksack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rucksack/2015-06-08/rucksack-20150608-git.tgz"; + sha256 = "0d6lvhc18i0brh75vp3n974ssx52b42rvwd24llhnphlnhryxh86"; + system = "rucksack"; + asd = "rucksack"; + } + ); + systems = [ "rucksack" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rucksack-test = ( + build-asdf-system { + pname = "rucksack-test"; + version = "20150608-git"; + asds = [ "rucksack-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rucksack/2015-06-08/rucksack-20150608-git.tgz"; + sha256 = "0d6lvhc18i0brh75vp3n974ssx52b42rvwd24llhnphlnhryxh86"; + system = "rucksack-test"; + asd = "rucksack-test"; + } + ); + systems = [ "rucksack-test" ]; + lispLibs = [ (getAttr "rucksack" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rutils = ( + build-asdf-system { + pname = "rutils"; + version = "20221106-git"; + asds = [ "rutils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rutils/2022-11-06/rutils-20221106-git.tgz"; + sha256 = "108l64k7qhbhmgp0wa4krm23wakyfc41wzyl2fgc9k59gf47axhq"; + system = "rutils"; + asd = "rutils"; + } + ); + systems = [ "rutils" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rutils-test = ( + build-asdf-system { + pname = "rutils-test"; + version = "20221106-git"; + asds = [ "rutils-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rutils/2022-11-06/rutils-20221106-git.tgz"; + sha256 = "108l64k7qhbhmgp0wa4krm23wakyfc41wzyl2fgc9k59gf47axhq"; + system = "rutils-test"; + asd = "rutils-test"; + } + ); + systems = [ "rutils-test" ]; + lispLibs = [ + (getAttr "rutils" self) + (getAttr "should-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + rutilsx = ( + build-asdf-system { + pname = "rutilsx"; + version = "20221106-git"; + asds = [ "rutilsx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/rutils/2022-11-06/rutils-20221106-git.tgz"; + sha256 = "108l64k7qhbhmgp0wa4krm23wakyfc41wzyl2fgc9k59gf47axhq"; + system = "rutilsx"; + asd = "rutilsx"; + } + ); + systems = [ "rutilsx" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "named-readtables" self) + (getAttr "rutils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ryeboy = ( + build-asdf-system { + pname = "ryeboy"; + version = "20201016-git"; + asds = [ "ryeboy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ryeboy/2020-10-16/ryeboy-20201016-git.tgz"; + sha256 = "0div6m6861damksxdxcycpdyyjn50bjsxfdkksm34w6162zdjcla"; + system = "ryeboy"; + asd = "ryeboy"; + } + ); + systems = [ "ryeboy" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "com_dot_google_dot_base" self) + (getAttr "protobuf" self) + (getAttr "prove-asdf" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + s-base64 = ( + build-asdf-system { + pname = "s-base64"; + version = "20130128-git"; + asds = [ "s-base64" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/s-base64/2013-01-28/s-base64-20130128-git.tgz"; + sha256 = "0zrr8zhnkdy97c5g54605nhjlf7fly79ylr1yf6wwyssia04cagg"; + system = "s-base64"; + asd = "s-base64"; + } + ); + systems = [ "s-base64" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + s-dot2 = ( + build-asdf-system { + pname = "s-dot2"; + version = "20241012-git"; + asds = [ "s-dot2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/s-dot2/2024-10-12/s-dot2-20241012-git.tgz"; + sha256 = "0zc833sc7szwyrrcinl84q3b0y9akh7hd5lhq3vxclk4zgb9n4nf"; + system = "s-dot2"; + asd = "s-dot2"; + } + ); + systems = [ "s-dot2" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + s-graphviz = ( + build-asdf-system { + pname = "s-graphviz"; + version = "20201220-git"; + asds = [ "s-graphviz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/s-graphviz/2020-12-20/s-graphviz-20201220-git.tgz"; + sha256 = "1841xwci6y1gfhg15464wrlnw8xgsh1mwbg4yy2y7di02q4fbma2"; + system = "s-graphviz"; + asd = "s-graphviz"; + } + ); + systems = [ "s-graphviz" ]; + lispLibs = [ + (getAttr "iterate" self) + (getAttr "literate-lisp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + s-http-client = ( + build-asdf-system { + pname = "s-http-client"; + version = "20200427-git"; + asds = [ "s-http-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/s-http-client/2020-04-27/s-http-client-20200427-git.tgz"; + sha256 = "1fb2901h91rgfxz3cm1lb2dnd84m1fr745nd2kswd1mj2xz94zn8"; + system = "s-http-client"; + asd = "s-http-client"; + } + ); + systems = [ "s-http-client" ]; + lispLibs = [ + (getAttr "chipz" self) + (getAttr "puri" self) + (getAttr "s-base64" self) + (getAttr "s-sysdeps" self) + (getAttr "s-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + s-http-server = ( + build-asdf-system { + pname = "s-http-server"; + version = "20200427-git"; + asds = [ "s-http-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/s-http-server/2020-04-27/s-http-server-20200427-git.tgz"; + sha256 = "025mvnqhxx2c092aam3s4fk9v0p65hzdw39y4lamm0bdralda4bk"; + system = "s-http-server"; + asd = "s-http-server"; + } + ); + systems = [ "s-http-server" ]; + lispLibs = [ + (getAttr "puri" self) + (getAttr "s-base64" self) + (getAttr "s-sysdeps" self) + (getAttr "s-utils" self) + (getAttr "salza2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + s-sql = ( + build-asdf-system { + pname = "s-sql"; + version = "20241012-git"; + asds = [ "s-sql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/postmodern/2024-10-12/postmodern-20241012-git.tgz"; + sha256 = "1hj0dpclzihy1rcnwhiv16abmaa54wygxyib3j2h9q4qs26w7pzb"; + system = "s-sql"; + asd = "s-sql"; + } + ); + systems = [ "s-sql" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-postgres" self) + ]; + meta = { }; + } + ); + s-sysdeps = ( + build-asdf-system { + pname = "s-sysdeps"; + version = "20210228-git"; + asds = [ "s-sysdeps" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/s-sysdeps/2021-02-28/s-sysdeps-20210228-git.tgz"; + sha256 = "0rp81iq0rgl48qdwbmfy89glga81hmry2lp8adjbr5h5ybr92b4n"; + system = "s-sysdeps"; + asd = "s-sysdeps"; + } + ); + systems = [ "s-sysdeps" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "usocket" self) + (getAttr "usocket-server" self) + ]; + meta = { }; + } + ); + s-utils = ( + build-asdf-system { + pname = "s-utils"; + version = "20200427-git"; + asds = [ "s-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/s-utils/2020-04-27/s-utils-20200427-git.tgz"; + sha256 = "0xggbcvjmj4sdqcs6vaccryqp2piaqxkc0ygkczrd5m14bwrmlp6"; + system = "s-utils"; + asd = "s-utils"; + } + ); + systems = [ "s-utils" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + s-xml = ( + build-asdf-system { + pname = "s-xml"; + version = "20150608-git"; + asds = [ "s-xml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/s-xml/2015-06-08/s-xml-20150608-git.tgz"; + sha256 = "1zsf5zrlf47g5cp70kb9b8d4v88315g633q5jcdx22csw7sd7if1"; + system = "s-xml"; + asd = "s-xml"; + } + ); + systems = [ "s-xml" ]; + lispLibs = [ ]; + meta = { }; + } + ); + s-xml-rpc = ( + build-asdf-system { + pname = "s-xml-rpc"; + version = "20190521-git"; + asds = [ "s-xml-rpc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/s-xml-rpc/2019-05-21/s-xml-rpc-20190521-git.tgz"; + sha256 = "0z42awkz124xphkahw0mhg1pk029l2799rhyy51387ndd6gbqscx"; + system = "s-xml-rpc"; + asd = "s-xml-rpc"; + } + ); + systems = [ "s-xml-rpc" ]; + lispLibs = [ (getAttr "s-xml" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + s-xml_dot_examples = ( + build-asdf-system { + pname = "s-xml.examples"; + version = "20150608-git"; + asds = [ "s-xml.examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/s-xml/2015-06-08/s-xml-20150608-git.tgz"; + sha256 = "1zsf5zrlf47g5cp70kb9b8d4v88315g633q5jcdx22csw7sd7if1"; + system = "s-xml.examples"; + asd = "s-xml"; + } + ); + systems = [ "s-xml.examples" ]; + lispLibs = [ (getAttr "s-xml" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + s-xml_dot_test = ( + build-asdf-system { + pname = "s-xml.test"; + version = "20150608-git"; + asds = [ "s-xml.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/s-xml/2015-06-08/s-xml-20150608-git.tgz"; + sha256 = "1zsf5zrlf47g5cp70kb9b8d4v88315g633q5jcdx22csw7sd7if1"; + system = "s-xml.test"; + asd = "s-xml"; + } + ); + systems = [ "s-xml.test" ]; + lispLibs = [ (getAttr "s-xml" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + safe-queue = ( + build-asdf-system { + pname = "safe-queue"; + version = "20200325-git"; + asds = [ "safe-queue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/safe-queue/2020-03-25/safe-queue-20200325-git.tgz"; + sha256 = "1agvp8y2k5c6w35kly6d9a7hi1y6csn4k0hqqdv7i87lgjdi7vrq"; + system = "safe-queue"; + asd = "safe-queue"; + } + ); + systems = [ "safe-queue" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + safe-read = ( + build-asdf-system { + pname = "safe-read"; + version = "20220220-git"; + asds = [ "safe-read" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/safe-read/2022-02-20/safe-read-20220220-git.tgz"; + sha256 = "1r9k8danfnqgpbn2vb90n6wdc6jd92h1ig565yplrbh6232lhi26"; + system = "safe-read"; + asd = "safe-read"; + } + ); + systems = [ "safe-read" ]; + lispLibs = [ + (getAttr "local-time" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + safety-params = ( + build-asdf-system { + pname = "safety-params"; + version = "20190202-git"; + asds = [ "safety-params" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/safety-params/2019-02-02/safety-params-20190202-git.tgz"; + sha256 = "1y69b9aw3vsnsk0vdjyxw011j0lgc5gdwv6ay6vzfipa9gzi92ki"; + system = "safety-params"; + asd = "safety-params"; + } + ); + systems = [ "safety-params" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "parse-number" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + salza2 = ( + build-asdf-system { + pname = "salza2"; + version = "2.1"; + asds = [ "salza2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/salza2/2021-10-20/salza2-2.1.tgz"; + sha256 = "1p48lxdibnps5rpyh5cmnk0vc77bmmxb32qdzfz93zadr8wwas10"; + system = "salza2"; + asd = "salza2"; + } + ); + systems = [ "salza2" ]; + lispLibs = [ (getAttr "trivial-gray-streams" self) ]; + meta = { }; + } + ); + sandalphon_dot_lambda-list = ( + build-asdf-system { + pname = "sandalphon.lambda-list"; + version = "20241012-git"; + asds = [ "sandalphon.lambda-list" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sandalphon.lambda-list/2024-10-12/sandalphon.lambda-list-20241012-git.tgz"; + sha256 = "1j4xfcb1n71kh95v0y495snkna5avdp0inbiaia7r5fsxlcf4s45"; + system = "sandalphon.lambda-list"; + asd = "sandalphon.lambda-list"; + } + ); + systems = [ "sandalphon.lambda-list" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sanitize = ( + build-asdf-system { + pname = "sanitize"; + version = "20130720-git"; + asds = [ "sanitize" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sanitize/2013-07-20/cl-sanitize-20130720-git.tgz"; + sha256 = "101qqgi53scz3aaca57yg5wk9ana2axpwssmgrcb5c2ip5a2lwi3"; + system = "sanitize"; + asd = "sanitize"; + } + ); + systems = [ "sanitize" ]; + lispLibs = [ (getAttr "cl-libxml2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sanitize-test = ( + build-asdf-system { + pname = "sanitize-test"; + version = "20130720-git"; + asds = [ "sanitize-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sanitize/2013-07-20/cl-sanitize-20130720-git.tgz"; + sha256 = "101qqgi53scz3aaca57yg5wk9ana2axpwssmgrcb5c2ip5a2lwi3"; + system = "sanitize-test"; + asd = "sanitize"; + } + ); + systems = [ "sanitize-test" ]; + lispLibs = [ + (getAttr "eos" self) + (getAttr "sanitize" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sanity-clause = ( + build-asdf-system { + pname = "sanity-clause"; + version = "20210807-git"; + asds = [ "sanity-clause" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sanity-clause/2021-08-07/sanity-clause-20210807-git.tgz"; + sha256 = "0dzh00zpaqv48pn0xhbibiy33j8fwd2scsy5i466c9x9mcbhjz4f"; + system = "sanity-clause"; + asd = "sanity-clause"; + } + ); + systems = [ "sanity-clause" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "arrows" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "local-time" self) + (getAttr "parse-float" self) + (getAttr "quri" self) + (getAttr "str" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sapaclisp = ( + build-asdf-system { + pname = "sapaclisp"; + version = "1.0a"; + asds = [ "sapaclisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sapaclisp/2012-05-20/sapaclisp-1.0a.tgz"; + sha256 = "1bgqvwvjq8g5wrmp5r1dn1v99hgin9gihwkihz455n9dn90l3pyq"; + system = "sapaclisp"; + asd = "sapaclisp"; + } + ); + systems = [ "sapaclisp" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sb-cga = ( + build-asdf-system { + pname = "sb-cga"; + version = "20210531-git"; + asds = [ "sb-cga" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sb-cga/2021-05-31/sb-cga-20210531-git.tgz"; + sha256 = "1y54qlwfrhch9aghk7nsbdx7x2qsvgsws1g2k631l9dsgdakw4w8"; + system = "sb-cga"; + asd = "sb-cga"; + } + ); + systems = [ "sb-cga" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sb-fastcgi = ( + build-asdf-system { + pname = "sb-fastcgi"; + version = "20241012-git"; + asds = [ "sb-fastcgi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sb-fastcgi/2024-10-12/sb-fastcgi-20241012-git.tgz"; + sha256 = "1jw5bmim4ll3a1bqlw02ksgw58cv1qr5li0gbczj7g9fjfk3r64z"; + system = "sb-fastcgi"; + asd = "sb-fastcgi"; + } + ); + systems = [ "sb-fastcgi" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sb-vector-io = ( + build-asdf-system { + pname = "sb-vector-io"; + version = "20110829-git"; + asds = [ "sb-vector-io" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sb-vector-io/2011-08-29/sb-vector-io-20110829-git.tgz"; + sha256 = "0pwc0nxhv8ba33i8z2f1y7r7ldik4a4xrqrb69dvvasz838k6r22"; + system = "sb-vector-io"; + asd = "sb-vector-io"; + } + ); + systems = [ "sb-vector-io" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sc-extensions = ( + build-asdf-system { + pname = "sc-extensions"; + version = "20241012-git"; + asds = [ "sc-extensions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sc-extensions/2024-10-12/sc-extensions-20241012-git.tgz"; + sha256 = "1va153gr7002j5hshalq13gk6jpij29h613nm47aimj01hjy9p0n"; + system = "sc-extensions"; + asd = "sc-extensions"; + } + ); + systems = [ "sc-extensions" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-collider" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sc-osc = ( + build-asdf-system { + pname = "sc-osc"; + version = "20241012-git"; + asds = [ "sc-osc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-collider/2024-10-12/cl-collider-20241012-git.tgz"; + sha256 = "0h0fyx7glxnzwyam2aflma6003h8fcvcf5nj5f7svarw9brcc2xa"; + system = "sc-osc"; + asd = "sc-osc"; + } + ); + systems = [ "sc-osc" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "ieee-floats" self) + (getAttr "osc" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + schannel = ( + build-asdf-system { + pname = "schannel"; + version = "20211230-git"; + asds = [ "schannel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/schannel/2021-12-30/schannel-20211230-git.tgz"; + sha256 = "1f7dncrjsswrr8wrm7qzxdvrmzg3n2ap607ad74mnfd806rwldnw"; + system = "schannel"; + asd = "schannel"; + } + ); + systems = [ "schannel" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scheduler = ( + build-asdf-system { + pname = "scheduler"; + version = "20230618-git"; + asds = [ "scheduler" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/scheduler/2023-06-18/scheduler-20230618-git.tgz"; + sha256 = "0559hxypgyg9863mb51wil777prspfsjbslj6psm3wndvl6xiprg"; + system = "scheduler"; + asd = "scheduler"; + } + ); + systems = [ "scheduler" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "local-time" self) + (getAttr "optima" self) + (getAttr "optima_dot_ppcre" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + science-data = ( + build-asdf-system { + pname = "science-data"; + version = "master-df14cb8c-git"; + asds = [ "science-data" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/antik/2024-10-12/antik-master-df14cb8c-git.tgz"; + sha256 = "1n08cx4n51z8v4bxyak166lp495xda3x7llfxcdpxndxqxcammr0"; + system = "science-data"; + asd = "science-data"; + } + ); + systems = [ "science-data" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "physical-dimension" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scigraph = ( + build-asdf-system { + pname = "scigraph"; + version = "20241012-git"; + asds = [ "scigraph" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "scigraph"; + asd = "scigraph"; + } + ); + systems = [ "scigraph" ]; + lispLibs = [ (getAttr "mcclim" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scrapycl = ( + build-asdf-system { + pname = "scrapycl"; + version = "20241012-git"; + asds = [ "scrapycl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/scrapycl/2024-10-12/scrapycl-20241012-git.tgz"; + sha256 = "0qlvsc5qr8vyyrsasp041ydlfx8vgsy191m0nhab487fzmrlbzwp"; + system = "scrapycl"; + asd = "scrapycl"; + } + ); + systems = [ "scrapycl" ]; + lispLibs = [ + (getAttr "_40ants-asdf-system" self) + (getAttr "_40ants-doc" self) + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "dexador" self) + (getAttr "log4cl" self) + (getAttr "log4cl-extras" self) + (getAttr "lquery" self) + (getAttr "plump" self) + (getAttr "quri" self) + (getAttr "serapeum" self) + (getAttr "spinneret" self) + (getAttr "str" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scrapycl-ci = ( + build-asdf-system { + pname = "scrapycl-ci"; + version = "20241012-git"; + asds = [ "scrapycl-ci" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/scrapycl/2024-10-12/scrapycl-20241012-git.tgz"; + sha256 = "0qlvsc5qr8vyyrsasp041ydlfx8vgsy191m0nhab487fzmrlbzwp"; + system = "scrapycl-ci"; + asd = "scrapycl-ci"; + } + ); + systems = [ "scrapycl-ci" ]; + lispLibs = [ (getAttr "_40ants-ci" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scrapycl-docs = ( + build-asdf-system { + pname = "scrapycl-docs"; + version = "20241012-git"; + asds = [ "scrapycl-docs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/scrapycl/2024-10-12/scrapycl-20241012-git.tgz"; + sha256 = "0qlvsc5qr8vyyrsasp041ydlfx8vgsy191m0nhab487fzmrlbzwp"; + system = "scrapycl-docs"; + asd = "scrapycl-docs"; + } + ); + systems = [ "scrapycl-docs" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "docs-config" self) + (getAttr "named-readtables" self) + (getAttr "pythonic-string-reader" self) + (getAttr "scrapycl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scrapycl-tests = ( + build-asdf-system { + pname = "scrapycl-tests"; + version = "20241012-git"; + asds = [ "scrapycl-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/scrapycl/2024-10-12/scrapycl-20241012-git.tgz"; + sha256 = "0qlvsc5qr8vyyrsasp041ydlfx8vgsy191m0nhab487fzmrlbzwp"; + system = "scrapycl-tests"; + asd = "scrapycl-tests"; + } + ); + systems = [ "scrapycl-tests" ]; + lispLibs = [ (getAttr "rove" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scratch-buffer = ( + build-asdf-system { + pname = "scratch-buffer"; + version = "20200427-git"; + asds = [ "scratch-buffer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "scratch-buffer"; + asd = "scratch-buffer"; + } + ); + systems = [ "scratch-buffer" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "utility" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + screamer = ( + build-asdf-system { + pname = "screamer"; + version = "20210807-git"; + asds = [ "screamer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/screamer/2021-08-07/screamer-20210807-git.tgz"; + sha256 = "0913wmy0fpf6shvbz40ay9gnjhgyjglf661d1p5ld2glkw1ky8hm"; + system = "screamer"; + asd = "screamer"; + } + ); + systems = [ "screamer" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + screamer-tests = ( + build-asdf-system { + pname = "screamer-tests"; + version = "20210807-git"; + asds = [ "screamer-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/screamer/2021-08-07/screamer-20210807-git.tgz"; + sha256 = "0913wmy0fpf6shvbz40ay9gnjhgyjglf661d1p5ld2glkw1ky8hm"; + system = "screamer-tests"; + asd = "screamer-tests"; + } + ); + systems = [ "screamer-tests" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_stefil" self) + (getAttr "iterate" self) + (getAttr "screamer" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scriba = ( + build-asdf-system { + pname = "scriba"; + version = "20220707-git"; + asds = [ "scriba" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/scriba/2022-07-07/scriba-20220707-git.tgz"; + sha256 = "1n32bxf3b1cgb7y4015y3vahjgnbw59pi6d08by78pnpa2nx43sa"; + system = "scriba"; + asd = "scriba"; + } + ); + systems = [ "scriba" ]; + lispLibs = [ + (getAttr "common-doc-plump" self) + (getAttr "esrap" self) + (getAttr "plump-sexp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scriba-test = ( + build-asdf-system { + pname = "scriba-test"; + version = "20220707-git"; + asds = [ "scriba-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/scriba/2022-07-07/scriba-20220707-git.tgz"; + sha256 = "1n32bxf3b1cgb7y4015y3vahjgnbw59pi6d08by78pnpa2nx43sa"; + system = "scriba-test"; + asd = "scriba-test"; + } + ); + systems = [ "scriba-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "scriba" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scribble = ( + build-asdf-system { + pname = "scribble"; + version = "20231021-git"; + asds = [ "scribble" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/scribble/2023-10-21/scribble-20231021-git.tgz"; + sha256 = "1ng56lzfva5231lkjls18mw7gcfc3vzksyh6habk0x5dff92cwvw"; + system = "scribble"; + asd = "scribble"; + } + ); + systems = [ "scribble" ]; + lispLibs = [ + (getAttr "fare-memoization" self) + (getAttr "fare-quasiquote-readtable" self) + (getAttr "fare-utils" self) + (getAttr "meta" self) + (getAttr "ptc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scriptl = ( + build-asdf-system { + pname = "scriptl"; + version = "20180228-git"; + asds = [ "scriptl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/scriptl/2018-02-28/scriptl-20180228-git.tgz"; + sha256 = "1q0d64syglfdjrzx2x7hlvznljpfwr9scn7rliigbm5z326lygg4"; + system = "scriptl"; + asd = "scriptl"; + } + ); + systems = [ "scriptl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "defpackage-plus" self) + (getAttr "iolib" self) + (getAttr "osicat" self) + (getAttr "trivial-backtrace" self) + (getAttr "trivial-gray-streams" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scriptl-examples = ( + build-asdf-system { + pname = "scriptl-examples"; + version = "20180228-git"; + asds = [ "scriptl-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/scriptl/2018-02-28/scriptl-20180228-git.tgz"; + sha256 = "1q0d64syglfdjrzx2x7hlvznljpfwr9scn7rliigbm5z326lygg4"; + system = "scriptl-examples"; + asd = "scriptl-examples"; + } + ); + systems = [ "scriptl-examples" ]; + lispLibs = [ + (getAttr "scriptl" self) + (getAttr "unix-options" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scriptl-util = ( + build-asdf-system { + pname = "scriptl-util"; + version = "20180228-git"; + asds = [ "scriptl-util" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/scriptl/2018-02-28/scriptl-20180228-git.tgz"; + sha256 = "1q0d64syglfdjrzx2x7hlvznljpfwr9scn7rliigbm5z326lygg4"; + system = "scriptl-util"; + asd = "scriptl-util"; + } + ); + systems = [ "scriptl-util" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "scriptl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scrutiny = ( + build-asdf-system { + pname = "scrutiny"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "scrutiny" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "scrutiny"; + asd = "scrutiny"; + } + ); + systems = [ "scrutiny" ]; + lispLibs = [ (getAttr "adjuvant" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + scrutiny-test = ( + build-asdf-system { + pname = "scrutiny-test"; + version = "export-to-quicklisp-502a46e2-git"; + asds = [ "scrutiny-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/regular-type-expression/2020-02-18/regular-type-expression-export-to-quicklisp-502a46e2-git.tgz"; + sha256 = "1im07p7sbbhdjx9v8fx3v1xdqx1085lra6fsb4sh2bssw7m5xfxi"; + system = "scrutiny-test"; + asd = "scrutiny-test"; + } + ); + systems = [ "scrutiny-test" ]; + lispLibs = [ (getAttr "scrutiny" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sdl2 = ( + build-asdf-system { + pname = "sdl2"; + version = "20231021-git"; + asds = [ "sdl2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sdl2/2023-10-21/cl-sdl2-20231021-git.tgz"; + sha256 = "189awhgxnqdyvypmw9k39542whb1jcpxx4psy6196qdbrgab8lc7"; + system = "sdl2"; + asd = "sdl2"; + } + ); + systems = [ "sdl2" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-autowrap" self) + (getAttr "cl-plus-c" self) + (getAttr "cl-ppcre" self) + (getAttr "trivial-channels" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sdl2-game-controller-db = ( + build-asdf-system { + pname = "sdl2-game-controller-db"; + version = "release-quicklisp-335d2b68-git"; + asds = [ "sdl2-game-controller-db" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sdl2-game-controller-db/2018-02-28/sdl2-game-controller-db-release-quicklisp-335d2b68-git.tgz"; + sha256 = "0yf4ygndmacs0pf3ws5197k51c4fdximvxcmvn56bqmsvil56kcd"; + system = "sdl2-game-controller-db"; + asd = "sdl2-game-controller-db"; + } + ); + systems = [ "sdl2-game-controller-db" ]; + lispLibs = [ (getAttr "sdl2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sdl2-image = ( + build-asdf-system { + pname = "sdl2-image"; + version = "20241012-git"; + asds = [ "sdl2-image" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sdl2-image/2024-10-12/cl-sdl2-image-20241012-git.tgz"; + sha256 = "1jzrz3ppr5nbh0w6cvbbpv5x6gdq71a6v2qanvnjvcjs0zwf97iq"; + system = "sdl2-image"; + asd = "sdl2-image"; + } + ); + systems = [ "sdl2-image" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-autowrap" self) + (getAttr "defpackage-plus" self) + (getAttr "sdl2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sdl2-mixer = ( + build-asdf-system { + pname = "sdl2-mixer"; + version = "20241012-git"; + asds = [ "sdl2-mixer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sdl2-mixer/2024-10-12/cl-sdl2-mixer-20241012-git.tgz"; + sha256 = "0d33pmyrcni90qfj0d4hxf97may1bv7i9z4a6rj02dw254n9r9lh"; + system = "sdl2-mixer"; + asd = "sdl2-mixer"; + } + ); + systems = [ "sdl2-mixer" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-autowrap" self) + (getAttr "sdl2" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sdl2-ttf = ( + build-asdf-system { + pname = "sdl2-ttf"; + version = "20241012-git"; + asds = [ "sdl2-ttf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sdl2-ttf/2024-10-12/cl-sdl2-ttf-20241012-git.tgz"; + sha256 = "1asdymsn65a06qr1c8fknakdvpjwxsvl69py6fsz21nirxyha5nc"; + system = "sdl2-ttf"; + asd = "sdl2-ttf"; + } + ); + systems = [ "sdl2-ttf" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi-libffi" self) + (getAttr "cl-autowrap" self) + (getAttr "defpackage-plus" self) + (getAttr "sdl2" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sdl2-ttf-examples = ( + build-asdf-system { + pname = "sdl2-ttf-examples"; + version = "20241012-git"; + asds = [ "sdl2-ttf-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sdl2-ttf/2024-10-12/cl-sdl2-ttf-20241012-git.tgz"; + sha256 = "1asdymsn65a06qr1c8fknakdvpjwxsvl69py6fsz21nirxyha5nc"; + system = "sdl2-ttf-examples"; + asd = "sdl2-ttf-examples"; + } + ); + systems = [ "sdl2-ttf-examples" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-opengl" self) + (getAttr "mathkit" self) + (getAttr "sdl2" self) + (getAttr "sdl2-ttf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sdl2kit = ( + build-asdf-system { + pname = "sdl2kit"; + version = "20171130-git"; + asds = [ "sdl2kit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sdl2kit/2017-11-30/sdl2kit-20171130-git.tgz"; + sha256 = "10ymmxqsvdn7ndda9k2qcixj75l7namgqdxc5y2w3v5r1313fy2d"; + system = "sdl2kit"; + asd = "sdl2kit"; + } + ); + systems = [ "sdl2kit" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-opengl" self) + (getAttr "defpackage-plus" self) + (getAttr "sdl2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sdl2kit-examples = ( + build-asdf-system { + pname = "sdl2kit-examples"; + version = "20171130-git"; + asds = [ "sdl2kit-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sdl2kit/2017-11-30/sdl2kit-20171130-git.tgz"; + sha256 = "10ymmxqsvdn7ndda9k2qcixj75l7namgqdxc5y2w3v5r1313fy2d"; + system = "sdl2kit-examples"; + asd = "sdl2kit-examples"; + } + ); + systems = [ "sdl2kit-examples" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "defpackage-plus" self) + (getAttr "glkit" self) + (getAttr "mathkit" self) + (getAttr "sdl2kit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sealable-metaobjects = ( + build-asdf-system { + pname = "sealable-metaobjects"; + version = "20200610-git"; + asds = [ "sealable-metaobjects" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sealable-metaobjects/2020-06-10/sealable-metaobjects-20200610-git.tgz"; + sha256 = "0hz1ivlpfhnk1w2cw4q2i000j2dc7maay06ndzziyywg7li6zf2p"; + system = "sealable-metaobjects"; + asd = "sealable-metaobjects"; + } + ); + systems = [ "sealable-metaobjects" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + secp256k1 = ( + build-asdf-system { + pname = "secp256k1"; + version = "20220707-git"; + asds = [ "secp256k1" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-secp256k1/2022-07-07/cl-secp256k1-20220707-git.tgz"; + sha256 = "0lg84jkwwp95nnk865yfhg16z0d04wk3dzf5yilkfm2yxnmjnv85"; + system = "secp256k1"; + asd = "secp256k1"; + } + ); + systems = [ "secp256k1" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + secret-values = ( + build-asdf-system { + pname = "secret-values"; + version = "20201220-git"; + asds = [ "secret-values" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/secret-values/2020-12-20/secret-values-20201220-git.tgz"; + sha256 = "07ph49s27gvjzx60yy094bb9ddwiys34r8cx5l837i34nm2fn3nh"; + system = "secret-values"; + asd = "secret-values"; + } + ); + systems = [ "secret-values" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + secure-random = ( + build-asdf-system { + pname = "secure-random"; + version = "20160208-git"; + asds = [ "secure-random" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/secure-random/2016-02-08/secure-random-20160208-git.tgz"; + sha256 = "09cnclnivkc87ja3z12ihcm02vkwp0cflcfa6hpjlbd5m75hvgsd"; + system = "secure-random"; + asd = "secure-random"; + } + ); + systems = [ "secure-random" ]; + lispLibs = [ (getAttr "cl_plus_ssl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + seedable-rng = ( + build-asdf-system { + pname = "seedable-rng"; + version = "20220707-git"; + asds = [ "seedable-rng" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/seedable-rng/2022-07-07/seedable-rng-20220707-git.tgz"; + sha256 = "1pr2flvrj32m055apwn5f2cddki2ws5xldmj2v367iyry3lz2vm1"; + system = "seedable-rng"; + asd = "seedable-rng"; + } + ); + systems = [ "seedable-rng" ]; + lispLibs = [ + (getAttr "cl-pcg" self) + (getAttr "ironclad" self) + (getAttr "mfiano-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + select = ( + build-asdf-system { + pname = "select"; + version = "20241012-git"; + asds = [ "select" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/select/2024-10-12/select-20241012-git.tgz"; + sha256 = "1js02xgfd488lhv90rgxw0cvfbsarlpakydwrg1jr2hh5bhqyifh"; + system = "select"; + asd = "select"; + } + ); + systems = [ "select" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "alexandria_plus" self) + (getAttr "anaphora" self) + (getAttr "let-plus" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + select-file = ( + build-asdf-system { + pname = "select-file"; + version = "20200427-git"; + asds = [ "select-file" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/select-file/2020-04-27/select-file-20200427-git.tgz"; + sha256 = "1v89k5vvn1a3gdhlwbb4wxggzzr1ic7iqzvrrxgsh90fr129rmzq"; + system = "select-file"; + asd = "select-file"; + } + ); + systems = [ "select-file" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "mcclim" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + selenium = ( + build-asdf-system { + pname = "selenium"; + version = "20160531-git"; + asds = [ "selenium" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-selenium/2016-05-31/cl-selenium-20160531-git.tgz"; + sha256 = "1wx3343gkmyb25vbbpv6g5d1m2c5qxrkq7hsz1v2fcchgdgvwgxl"; + system = "selenium"; + asd = "selenium"; + } + ); + systems = [ "selenium" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cxml" self) + (getAttr "drakma" self) + (getAttr "puri" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + semantic-spinneret = ( + build-asdf-system { + pname = "semantic-spinneret"; + version = "20170830-git"; + asds = [ "semantic-spinneret" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/semantic-spinneret/2017-08-30/semantic-spinneret-20170830-git.tgz"; + sha256 = "0ghd4lwwcbcidj70j26hj9vic1nqrj78ksrqlxj29q61bnji05ix"; + system = "semantic-spinneret"; + asd = "semantic-spinneret"; + } + ); + systems = [ "semantic-spinneret" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "spinneret" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + semz_dot_decompress = ( + build-asdf-system { + pname = "semz.decompress"; + version = "20241012-git"; + asds = [ "semz.decompress" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/decompress/2024-10-12/decompress-20241012-git.tgz"; + sha256 = "0nzz6r57v94kyl5r77yawalnjszw93qjiqqargl3vjrmiga37gjp"; + system = "semz.decompress"; + asd = "semz.decompress"; + } + ); + systems = [ "semz.decompress" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sendgrid = ( + build-asdf-system { + pname = "sendgrid"; + version = "20241012-git"; + asds = [ "sendgrid" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sendgrid/2024-10-12/cl-sendgrid-20241012-git.tgz"; + sha256 = "02wwi2fwfd21aisf1y6ngypg7dmfvlf3bgxhqhrp1vpw8b34ha4w"; + system = "sendgrid"; + asd = "sendgrid"; + } + ); + systems = [ "sendgrid" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "dexador" self) + (getAttr "jonathan" self) + (getAttr "qbase64" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sento = ( + build-asdf-system { + pname = "sento"; + version = "20241012-git"; + asds = [ "sento" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-gserver/2024-10-12/cl-gserver-20241012-git.tgz"; + sha256 = "1281iir75ccr5ilh2jv9xh1w446492gywvady48xggqyh6idaz9k"; + system = "sento"; + asd = "sento"; + } + ); + systems = [ "sento" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "atomics" self) + (getAttr "binding-arrows" self) + (getAttr "blackbird" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-speedy-queue" self) + (getAttr "local-time-duration" self) + (getAttr "log4cl" self) + (getAttr "str" self) + (getAttr "timer-wheel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sentry-client = ( + build-asdf-system { + pname = "sentry-client"; + version = "20241012-git"; + asds = [ "sentry-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sentry-client/2024-10-12/cl-sentry-client-20241012-git.tgz"; + sha256 = "0i83kgrjznffj6z5ryxnxlk995937askhilsbfa2nixakwal2c5h"; + system = "sentry-client"; + asd = "sentry-client"; + } + ); + systems = [ "sentry-client" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "dexador" self) + (getAttr "local-time" self) + (getAttr "salza2" self) + (getAttr "swank" self) + (getAttr "trivial-backtrace" self) + (getAttr "uuid" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sentry-client_dot_async = ( + build-asdf-system { + pname = "sentry-client.async"; + version = "20241012-git"; + asds = [ "sentry-client.async" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sentry-client/2024-10-12/cl-sentry-client-20241012-git.tgz"; + sha256 = "0i83kgrjznffj6z5ryxnxlk995937askhilsbfa2nixakwal2c5h"; + system = "sentry-client.async"; + asd = "sentry-client.async"; + } + ); + systems = [ "sentry-client.async" ]; + lispLibs = [ + (getAttr "sentry-client" self) + (getAttr "simple-tasks" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sentry-client_dot_hunchentoot = ( + build-asdf-system { + pname = "sentry-client.hunchentoot"; + version = "20241012-git"; + asds = [ "sentry-client.hunchentoot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sentry-client/2024-10-12/cl-sentry-client-20241012-git.tgz"; + sha256 = "0i83kgrjznffj6z5ryxnxlk995937askhilsbfa2nixakwal2c5h"; + system = "sentry-client.hunchentoot"; + asd = "sentry-client.hunchentoot"; + } + ); + systems = [ "sentry-client.hunchentoot" ]; + lispLibs = [ + (getAttr "hunchentoot" self) + (getAttr "sentry-client" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sequence-iterators = ( + build-asdf-system { + pname = "sequence-iterators"; + version = "20130813-darcs"; + asds = [ "sequence-iterators" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sequence-iterators/2013-08-13/sequence-iterators-20130813-darcs.tgz"; + sha256 = "12flvy6hysqw0fa2jfkxrgphlk6b25hg2w2dxm1ylax0gw9fh1l5"; + system = "sequence-iterators"; + asd = "sequence-iterators"; + } + ); + systems = [ "sequence-iterators" ]; + lispLibs = [ (getAttr "parse-declarations-1_dot_0" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sequence-iterators-test = ( + build-asdf-system { + pname = "sequence-iterators-test"; + version = "20130813-darcs"; + asds = [ "sequence-iterators-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sequence-iterators/2013-08-13/sequence-iterators-20130813-darcs.tgz"; + sha256 = "12flvy6hysqw0fa2jfkxrgphlk6b25hg2w2dxm1ylax0gw9fh1l5"; + system = "sequence-iterators-test"; + asd = "sequence-iterators"; + } + ); + systems = [ "sequence-iterators-test" ]; + lispLibs = [ (getAttr "sequence-iterators" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + serapeum = ( + build-asdf-system { + pname = "serapeum"; + version = "20241012-git"; + asds = [ "serapeum" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/serapeum/2024-10-12/serapeum-20241012-git.tgz"; + sha256 = "12dc4p3i82p3jhxpp5wd6xiwy2fgdjybgfgj54nv8ya75rl9a64z"; + system = "serapeum"; + asd = "serapeum"; + } + ); + systems = [ "serapeum" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "global-vars" self) + (getAttr "introspect-environment" self) + (getAttr "parse-declarations-1_dot_0" self) + (getAttr "parse-number" self) + (getAttr "split-sequence" self) + (getAttr "string-case" self) + (getAttr "trivia" self) + (getAttr "trivial-cltl2" self) + (getAttr "trivial-file-size" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-macroexpand-all" self) + ]; + meta = { }; + } + ); + serializable-object = ( + build-asdf-system { + pname = "serializable-object"; + version = "20191227-git"; + asds = [ "serializable-object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/serializable-object/2019-12-27/serializable-object-20191227-git.tgz"; + sha256 = "0978ljw998ypryiiqmb1s11ymwg4h5qz9bv7ig1i29wf5s14s2i0"; + system = "serializable-object"; + asd = "serializable-object"; + } + ); + systems = [ "serializable-object" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + serializable-object_dot_test = ( + build-asdf-system { + pname = "serializable-object.test"; + version = "20191227-git"; + asds = [ "serializable-object.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/serializable-object/2019-12-27/serializable-object-20191227-git.tgz"; + sha256 = "0978ljw998ypryiiqmb1s11ymwg4h5qz9bv7ig1i29wf5s14s2i0"; + system = "serializable-object.test"; + asd = "serializable-object.test"; + } + ); + systems = [ "serializable-object.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "serializable-object" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + series = ( + build-asdf-system { + pname = "series"; + version = "20131111-git"; + asds = [ "series" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/series/2013-11-11/series-20131111-git.tgz"; + sha256 = "07hk2lhfx42zk018pxqvn4gs77vd4n4g8m4xxbqaxgca76mifwfw"; + system = "series"; + asd = "series"; + } + ); + systems = [ "series" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + series-tests = ( + build-asdf-system { + pname = "series-tests"; + version = "20131111-git"; + asds = [ "series-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/series/2013-11-11/series-20131111-git.tgz"; + sha256 = "07hk2lhfx42zk018pxqvn4gs77vd4n4g8m4xxbqaxgca76mifwfw"; + system = "series-tests"; + asd = "series"; + } + ); + systems = [ "series-tests" ]; + lispLibs = [ (getAttr "series" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + session-token = ( + build-asdf-system { + pname = "session-token"; + version = "20141106-git"; + asds = [ "session-token" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/session-token/2014-11-06/session-token-20141106-git.tgz"; + sha256 = "1yb6m8nbh4gaskplrd2bwsnpkq6dl9dkvbjmvhzls6vh4lp6cc2z"; + system = "session-token"; + asd = "session-token"; + } + ); + systems = [ "session-token" ]; + lispLibs = [ (getAttr "cl-isaac" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + setup-cl_plus_ssl = ( + build-asdf-system { + pname = "setup-cl+ssl"; + version = "20230618-git"; + asds = [ "setup-cl+ssl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zacl/2023-06-18/zacl-20230618-git.tgz"; + sha256 = "1s31d47zx8hczim78zrqzg4bvj4bshj31gmrff065q6racx3q1dk"; + system = "setup-cl+ssl"; + asd = "setup-cl+ssl"; + } + ); + systems = [ "setup-cl+ssl" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sexml = ( + build-asdf-system { + pname = "sexml"; + version = "20140713-git"; + asds = [ "sexml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sexml/2014-07-13/sexml-20140713-git.tgz"; + sha256 = "1s7isk9v7qh03sf60zw32kaa1rgvdh24bsc37q173r282m8plbk3"; + system = "sexml"; + asd = "sexml"; + } + ); + systems = [ "sexml" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "contextl" self) + (getAttr "cxml" self) + (getAttr "macroexpand-dammit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sexml-objects = ( + build-asdf-system { + pname = "sexml-objects"; + version = "20140713-git"; + asds = [ "sexml-objects" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sexml/2014-07-13/sexml-20140713-git.tgz"; + sha256 = "1s7isk9v7qh03sf60zw32kaa1rgvdh24bsc37q173r282m8plbk3"; + system = "sexml-objects"; + asd = "sexml-objects"; + } + ); + systems = [ "sexml-objects" ]; + lispLibs = [ (getAttr "sexml" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sha1 = ( + build-asdf-system { + pname = "sha1"; + version = "20211020-git"; + asds = [ "sha1" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sha1/2021-10-20/sha1-20211020-git.tgz"; + sha256 = "1cfn0j5yfwqkwr2dm73wr9hz8dmws3ngxlbk9886ahxkg544qx4z"; + system = "sha1"; + asd = "sha1"; + } + ); + systems = [ "sha1" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sha3 = ( + build-asdf-system { + pname = "sha3"; + version = "20231021-git"; + asds = [ "sha3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sha3/2023-10-21/sha3-20231021-git.tgz"; + sha256 = "0jl59js4n1gc08j2bcwf0d1gy82lf7g53b639dwh6b0milbqh7gz"; + system = "sha3"; + asd = "sha3"; + } + ); + systems = [ "sha3" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + shadchen = ( + build-asdf-system { + pname = "shadchen"; + version = "20131003-git"; + asds = [ "shadchen" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/shadchen/2013-10-03/shadchen-20131003-git.tgz"; + sha256 = "0731hrpzf9pn1hyvs9wl0w3mnv13mr9ky3jx3dc4baj4nmjyb1k6"; + system = "shadchen"; + asd = "shadchen"; + } + ); + systems = [ "shadchen" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + shadow = ( + build-asdf-system { + pname = "shadow"; + version = "20220707-git"; + asds = [ "shadow" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/shadow/2022-07-07/shadow-20220707-git.tgz"; + sha256 = "1lw98ir9381kmmranaa111f8jh47adsx0v4hzlw3qkf2xjcfah3l"; + system = "shadow"; + asd = "shadow"; + } + ); + systems = [ "shadow" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-opengl" self) + (getAttr "glsl-packing" self) + (getAttr "mfiano-utils" self) + (getAttr "static-vectors" self) + (getAttr "varjo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + shared-preferences = ( + build-asdf-system { + pname = "shared-preferences"; + version = "1.1.1"; + asds = [ "shared-preferences" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/shared-preferences/2021-02-28/shared-preferences_1.1.1.tgz"; + sha256 = "12m4kaba2lxndkjw30a6y2rq16fflh5016lp74l7pf3v0y3j1ydf"; + system = "shared-preferences"; + asd = "shared-preferences"; + } + ); + systems = [ "shared-preferences" ]; + lispLibs = [ + (getAttr "inheriting-readers" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + shared-preferences__tests = ( + build-asdf-system { + pname = "shared-preferences_tests"; + version = "1.1.1"; + asds = [ "shared-preferences_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/shared-preferences/2021-02-28/shared-preferences_1.1.1.tgz"; + sha256 = "12m4kaba2lxndkjw30a6y2rq16fflh5016lp74l7pf3v0y3j1ydf"; + system = "shared-preferences_tests"; + asd = "shared-preferences_tests"; + } + ); + systems = [ "shared-preferences_tests" ]; + lispLibs = [ + (getAttr "parachute" self) + (getAttr "shared-preferences" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + shasht = ( + build-asdf-system { + pname = "shasht"; + version = "20241012-git"; + asds = [ "shasht" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/shasht/2024-10-12/shasht-20241012-git.tgz"; + sha256 = "0i4k6w5r74f2a0i3ffian715v057w63psywk89ih0hl9xxpc4pga"; + system = "shasht"; + asd = "shasht"; + } + ); + systems = [ "shasht" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "trivial-do" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sheeple = ( + build-asdf-system { + pname = "sheeple"; + version = "20210124-git"; + asds = [ "sheeple" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sheeple/2021-01-24/sheeple-20210124-git.tgz"; + sha256 = "13k6xm8a29xxkrwgc5j3bk2wr9skg4bzdnc4krrzgcdmx4gbcca3"; + system = "sheeple"; + asd = "sheeple"; + } + ); + systems = [ "sheeple" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sheeple-tests = ( + build-asdf-system { + pname = "sheeple-tests"; + version = "20210124-git"; + asds = [ "sheeple-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sheeple/2021-01-24/sheeple-20210124-git.tgz"; + sha256 = "13k6xm8a29xxkrwgc5j3bk2wr9skg4bzdnc4krrzgcdmx4gbcca3"; + system = "sheeple-tests"; + asd = "sheeple"; + } + ); + systems = [ "sheeple-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "sheeple" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + shellpool = ( + build-asdf-system { + pname = "shellpool"; + version = "20200925-git"; + asds = [ "shellpool" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/shellpool/2020-09-25/shellpool-20200925-git.tgz"; + sha256 = "1bpv58i2l2a3ayk3jvi2wwd90gjczp0qk24bj82775qp8miw9vz0"; + system = "shellpool"; + asd = "shellpool"; + } + ); + systems = [ "shellpool" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "bt-semaphore" self) + (getAttr "cl-fad" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + shelly = ( + build-asdf-system { + pname = "shelly"; + version = "20141106-git"; + asds = [ "shelly" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/shelly/2014-11-06/shelly-20141106-git.tgz"; + sha256 = "07whfcd2ygq07lw73bqby74cqbp2bx0rnyx7c0v7s16y9xfqxw7b"; + system = "shelly"; + asd = "shelly"; + } + ); + systems = [ "shelly" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-fad" self) + (getAttr "local-time" self) + (getAttr "split-sequence" self) + (getAttr "trivial-signal" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + shelly-test = ( + build-asdf-system { + pname = "shelly-test"; + version = "20141106-git"; + asds = [ "shelly-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/shelly/2014-11-06/shelly-20141106-git.tgz"; + sha256 = "07whfcd2ygq07lw73bqby74cqbp2bx0rnyx7c0v7s16y9xfqxw7b"; + system = "shelly-test"; + asd = "shelly-test"; + } + ); + systems = [ "shelly-test" ]; + lispLibs = [ + (getAttr "cl-test-more" self) + (getAttr "shelly" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + shlex = ( + build-asdf-system { + pname = "shlex"; + version = "20210411-git"; + asds = [ "shlex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-shlex/2021-04-11/cl-shlex-20210411-git.tgz"; + sha256 = "16ag48sswgimr1fzr582vhym4s03idpd4lkydw5s58lv80ibpim8"; + system = "shlex"; + asd = "shlex"; + } + ); + systems = [ "shlex" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-unicode" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + shop3 = ( + build-asdf-system { + pname = "shop3"; + version = "20241012-git"; + asds = [ "shop3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/shop3/2024-10-12/shop3-20241012-git.tgz"; + sha256 = "1sdyyyd82fqmm9lcqmg7k8yy3l3891m2gjwidibzvk95bp4xf9sd"; + system = "shop3"; + asd = "shop3"; + } + ); + systems = [ "shop3" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "fiveam-asdf" self) + (getAttr "iterate" self) + (getAttr "random-state" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + shop3-thmpr-api = ( + build-asdf-system { + pname = "shop3-thmpr-api"; + version = "20241012-git"; + asds = [ "shop3-thmpr-api" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/shop3/2024-10-12/shop3-20241012-git.tgz"; + sha256 = "1sdyyyd82fqmm9lcqmg7k8yy3l3891m2gjwidibzvk95bp4xf9sd"; + system = "shop3-thmpr-api"; + asd = "shop3-thmpr-api"; + } + ); + systems = [ "shop3-thmpr-api" ]; + lispLibs = [ (getAttr "shop3" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + should-test = ( + build-asdf-system { + pname = "should-test"; + version = "20191007-git"; + asds = [ "should-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/should-test/2019-10-07/should-test-20191007-git.tgz"; + sha256 = "1fqqa7lhf28qg60ji9libkylkcy747x576qpjn1y7c945j2fxmnm"; + system = "should-test"; + asd = "should-test"; + } + ); + systems = [ "should-test" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "local-time" self) + (getAttr "osicat" self) + (getAttr "rutils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + shuffletron = ( + build-asdf-system { + pname = "shuffletron"; + version = "20181018-git"; + asds = [ "shuffletron" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/shuffletron/2018-10-18/shuffletron-20181018-git.tgz"; + sha256 = "10626wp2xdk0wxj0kl49m9gyb2bp6f0vp67563mw6zrzfs7ynpkb"; + system = "shuffletron"; + asd = "shuffletron"; + } + ); + systems = [ "shuffletron" ]; + lispLibs = [ + (getAttr "mixalot" self) + (getAttr "mixalot-flac" self) + (getAttr "mixalot-mp3" self) + (getAttr "mixalot-vorbis" self) + (getAttr "osicat" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + si-kanren = ( + build-asdf-system { + pname = "si-kanren"; + version = "20241012-git"; + asds = [ "si-kanren" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/si-kanren/2024-10-12/si-kanren-20241012-git.tgz"; + sha256 = "1m99ryyfjxbjbmswprz8gr9hl3srwz74fwjna35wf8d41ns5ajlj"; + system = "si-kanren"; + asd = "si-kanren"; + } + ); + systems = [ "si-kanren" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + silo = ( + build-asdf-system { + pname = "silo"; + version = "20211020-git"; + asds = [ "silo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/colliflower/2021-10-20/colliflower-20211020-git.tgz"; + sha256 = "1fzn9s7wm7wmffrdm21lpvry9jb320456cmmprn976a533lp704r"; + system = "silo"; + asd = "silo"; + } + ); + systems = [ "silo" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-actors = ( + build-asdf-system { + pname = "simple-actors"; + version = "20200925-git"; + asds = [ "simple-actors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-actors/2020-09-25/simple-actors-20200925-git.tgz"; + sha256 = "1q843l1bh0xipp535gwm7713gpp04cycvq0i8yz54b6ym3dzkql4"; + system = "simple-actors"; + asd = "simple-actors"; + } + ); + systems = [ "simple-actors" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-config = ( + build-asdf-system { + pname = "simple-config"; + version = "20230618-git"; + asds = [ "simple-config" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-config/2023-06-18/simple-config-20230618-git.tgz"; + sha256 = "1ihw5yr5jwlpixaa011611q6i4j406rvc42bkm0da1arzd76pfhn"; + system = "simple-config"; + asd = "simple-config"; + } + ); + systems = [ "simple-config" ]; + lispLibs = [ (getAttr "str" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-config-test = ( + build-asdf-system { + pname = "simple-config-test"; + version = "20230618-git"; + asds = [ "simple-config-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-config/2023-06-18/simple-config-20230618-git.tgz"; + sha256 = "1ihw5yr5jwlpixaa011611q6i4j406rvc42bkm0da1arzd76pfhn"; + system = "simple-config-test"; + asd = "simple-config-test"; + } + ); + systems = [ "simple-config-test" ]; + lispLibs = [ + (getAttr "prove" self) + (getAttr "simple-config" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-currency = ( + build-asdf-system { + pname = "simple-currency"; + version = "20171130-git"; + asds = [ "simple-currency" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-currency/2017-11-30/simple-currency-20171130-git.tgz"; + sha256 = "1qrxaj5v25165vyjp2fmasasjri2cn53y6ckv3rlv04skifvnq2s"; + system = "simple-currency"; + asd = "simple-currency"; + } + ); + systems = [ "simple-currency" ]; + lispLibs = [ + (getAttr "cl-store" self) + (getAttr "dexador" self) + (getAttr "plump" self) + (getAttr "simple-date" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-date = ( + build-asdf-system { + pname = "simple-date"; + version = "20241012-git"; + asds = [ "simple-date" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/postmodern/2024-10-12/postmodern-20241012-git.tgz"; + sha256 = "1hj0dpclzihy1rcnwhiv16abmaa54wygxyib3j2h9q4qs26w7pzb"; + system = "simple-date"; + asd = "simple-date"; + } + ); + systems = [ "simple-date" ]; + lispLibs = [ ]; + meta = { }; + } + ); + simple-date-time = ( + build-asdf-system { + pname = "simple-date-time"; + version = "20160421-git"; + asds = [ "simple-date-time" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-date-time/2016-04-21/simple-date-time-20160421-git.tgz"; + sha256 = "06iwf13gcdyqhkzfkcsfdl8iqbdl44cx01c3fjsmhl0v1pp8h2m4"; + system = "simple-date-time"; + asd = "simple-date-time"; + } + ); + systems = [ "simple-date-time" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { }; + } + ); + simple-finalizer = ( + build-asdf-system { + pname = "simple-finalizer"; + version = "20101006-git"; + asds = [ "simple-finalizer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-finalizer/2010-10-06/simple-finalizer-20101006-git.tgz"; + sha256 = "1qdm48zjlkbygz9ip006xwpas59fhijrswv1k7pzvhdwl04vkq65"; + system = "simple-finalizer"; + asd = "simple-finalizer"; + } + ); + systems = [ "simple-finalizer" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-flow-dispatcher = ( + build-asdf-system { + pname = "simple-flow-dispatcher"; + version = "stable-git"; + asds = [ "simple-flow-dispatcher" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-flow-dispatcher/2020-10-16/simple-flow-dispatcher-stable-git.tgz"; + sha256 = "11k16svq4mgf0pagrs4drvf57hawffghv9g96b1n071nqyk2ald2"; + system = "simple-flow-dispatcher"; + asd = "simple-flow-dispatcher"; + } + ); + systems = [ "simple-flow-dispatcher" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bodge-queue" self) + (getAttr "cl-muth" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-guess = ( + build-asdf-system { + pname = "simple-guess"; + version = "1.0"; + asds = [ "simple-guess" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-guess/2020-09-25/simple-guess_1.0.tgz"; + sha256 = "11v3wxj3k036r0kazn69vi580qm593ir1yf7j5d737j4rb382682"; + system = "simple-guess"; + asd = "simple-guess"; + } + ); + systems = [ "simple-guess" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-guess__tests = ( + build-asdf-system { + pname = "simple-guess_tests"; + version = "1.0"; + asds = [ "simple-guess_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-guess/2020-09-25/simple-guess_1.0.tgz"; + sha256 = "11v3wxj3k036r0kazn69vi580qm593ir1yf7j5d737j4rb382682"; + system = "simple-guess_tests"; + asd = "simple-guess_tests"; + } + ); + systems = [ "simple-guess_tests" ]; + lispLibs = [ + (getAttr "fakenil" self) + (getAttr "parachute" self) + (getAttr "simple-guess" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-inferiors = ( + build-asdf-system { + pname = "simple-inferiors"; + version = "20231021-git"; + asds = [ "simple-inferiors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-inferiors/2023-10-21/simple-inferiors-20231021-git.tgz"; + sha256 = "1b7y44r2ncpfc5766pw56k07036qjvwqdbycizldfk9rjam2afa6"; + system = "simple-inferiors"; + asd = "simple-inferiors"; + } + ); + systems = [ "simple-inferiors" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "documentation-utils" self) + ]; + meta = { }; + } + ); + simple-neural-network = ( + build-asdf-system { + pname = "simple-neural-network"; + version = "20230214-git"; + asds = [ "simple-neural-network" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-neural-network/2023-02-14/simple-neural-network-20230214-git.tgz"; + sha256 = "14ix2f560bhvccfzi30ghmmg79785nmg8c3lpq5hg99djgigxyfw"; + system = "simple-neural-network"; + asd = "simple-neural-network"; + } + ); + systems = [ "simple-neural-network" ]; + lispLibs = [ + (getAttr "cl-store" self) + (getAttr "lparallel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-parallel-tasks = ( + build-asdf-system { + pname = "simple-parallel-tasks"; + version = "20201220-git"; + asds = [ "simple-parallel-tasks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-parallel-tasks/2020-12-20/simple-parallel-tasks-20201220-git.tgz"; + sha256 = "0gvbpyff4siifp3cp86cpr9ksmakn66fx21f3h0hpn647zl07nj7"; + system = "simple-parallel-tasks"; + asd = "simple-parallel-tasks"; + } + ); + systems = [ "simple-parallel-tasks" ]; + lispLibs = [ (getAttr "chanl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-parallel-tasks-tests = ( + build-asdf-system { + pname = "simple-parallel-tasks-tests"; + version = "20201220-git"; + asds = [ "simple-parallel-tasks-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-parallel-tasks/2020-12-20/simple-parallel-tasks-20201220-git.tgz"; + sha256 = "0gvbpyff4siifp3cp86cpr9ksmakn66fx21f3h0hpn647zl07nj7"; + system = "simple-parallel-tasks-tests"; + asd = "simple-parallel-tasks-tests"; + } + ); + systems = [ "simple-parallel-tasks-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "simple-parallel-tasks" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-rgb = ( + build-asdf-system { + pname = "simple-rgb"; + version = "20190521-git"; + asds = [ "simple-rgb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-rgb/2019-05-21/simple-rgb-20190521-git.tgz"; + sha256 = "0ggv0h2n4mvwnggjr1b40gw667gnyykzki2zadaczi38ydzyzlp1"; + system = "simple-rgb"; + asd = "simple-rgb"; + } + ); + systems = [ "simple-rgb" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-routes = ( + build-asdf-system { + pname = "simple-routes"; + version = "20180228-git"; + asds = [ "simple-routes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-routes/2018-02-28/simple-routes-20180228-git.tgz"; + sha256 = "0zkjl69zf1ynmqmvwccdbip3wxfyi7xplivv70qwxzd27mc0kh3k"; + system = "simple-routes"; + asd = "simple-routes"; + } + ); + systems = [ "simple-routes" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "hunchentoot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-scanf = ( + build-asdf-system { + pname = "simple-scanf"; + version = "20211209-git"; + asds = [ "simple-scanf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-string-match/2021-12-09/cl-string-match-20211209-git.tgz"; + sha256 = "0zndlkw3qy3vw4px4qv884z6232w8zfaliyc88irjwizdv35wcq9"; + system = "simple-scanf"; + asd = "simple-scanf"; + } + ); + systems = [ "simple-scanf" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "parse-float" self) + (getAttr "proc-parse" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simple-tasks = ( + build-asdf-system { + pname = "simple-tasks"; + version = "20231021-git"; + asds = [ "simple-tasks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-tasks/2023-10-21/simple-tasks-20231021-git.tgz"; + sha256 = "14j0sbi9zv22rrcp3wvjzmrgk6f75zydhs50cbmspr2r0c9s5c6n"; + system = "simple-tasks"; + asd = "simple-tasks"; + } + ); + systems = [ "simple-tasks" ]; + lispLibs = [ + (getAttr "array-utils" self) + (getAttr "bordeaux-threads" self) + (getAttr "dissect" self) + ]; + meta = { }; + } + ); + simpleroutes-demo = ( + build-asdf-system { + pname = "simpleroutes-demo"; + version = "20180228-git"; + asds = [ "simpleroutes-demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-routes/2018-02-28/simple-routes-20180228-git.tgz"; + sha256 = "0zkjl69zf1ynmqmvwccdbip3wxfyi7xplivv70qwxzd27mc0kh3k"; + system = "simpleroutes-demo"; + asd = "simple-routes"; + } + ); + systems = [ "simpleroutes-demo" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-who" self) + (getAttr "hunchentoot" self) + (getAttr "simple-routes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simpleroutes-test = ( + build-asdf-system { + pname = "simpleroutes-test"; + version = "20180228-git"; + asds = [ "simpleroutes-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simple-routes/2018-02-28/simple-routes-20180228-git.tgz"; + sha256 = "0zkjl69zf1ynmqmvwccdbip3wxfyi7xplivv70qwxzd27mc0kh3k"; + system = "simpleroutes-test"; + asd = "simple-routes"; + } + ); + systems = [ "simpleroutes-test" ]; + lispLibs = [ (getAttr "simple-routes" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simplet = ( + build-asdf-system { + pname = "simplet"; + version = "20191227-git"; + asds = [ "simplet" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simplet/2019-12-27/simplet-20191227-git.tgz"; + sha256 = "1scsalzbwxk6z48b61zq532c02l36yr3vl2jdy0xjm2diycq6jgs"; + system = "simplet"; + asd = "simplet"; + } + ); + systems = [ "simplet" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simplet-asdf = ( + build-asdf-system { + pname = "simplet-asdf"; + version = "20191227-git"; + asds = [ "simplet-asdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simplet/2019-12-27/simplet-20191227-git.tgz"; + sha256 = "1scsalzbwxk6z48b61zq532c02l36yr3vl2jdy0xjm2diycq6jgs"; + system = "simplet-asdf"; + asd = "simplet-asdf"; + } + ); + systems = [ "simplet-asdf" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simplified-types = ( + build-asdf-system { + pname = "simplified-types"; + version = "20190813-git"; + asds = [ "simplified-types" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simplified-types/2019-08-13/simplified-types-20190813-git.tgz"; + sha256 = "1hdwmn5lz717aj6qdqmfmr3cbjl8l3giwn0fb5ca9pj83cx7fg8y"; + system = "simplified-types"; + asd = "simplified-types"; + } + ); + systems = [ "simplified-types" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "introspect-environment" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simplified-types-test-suite = ( + build-asdf-system { + pname = "simplified-types-test-suite"; + version = "20190813-git"; + asds = [ "simplified-types-test-suite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simplified-types/2019-08-13/simplified-types-20190813-git.tgz"; + sha256 = "1hdwmn5lz717aj6qdqmfmr3cbjl8l3giwn0fb5ca9pj83cx7fg8y"; + system = "simplified-types-test-suite"; + asd = "simplified-types-test-suite"; + } + ); + systems = [ "simplified-types-test-suite" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "simplified-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + simpsamp = ( + build-asdf-system { + pname = "simpsamp"; + version = "0.1"; + asds = [ "simpsamp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/simpsamp/2010-10-06/simpsamp-0.1.tgz"; + sha256 = "0i85andjaz16lh4wwpdvd5kgg7lsfp206g7kniy16gs78xjy5jlc"; + system = "simpsamp"; + asd = "simpsamp"; + } + ); + systems = [ "simpsamp" ]; + lispLibs = [ (getAttr "jpl-util" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + single-threaded-ccl = ( + build-asdf-system { + pname = "single-threaded-ccl"; + version = "20150608-git"; + asds = [ "single-threaded-ccl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/single-threaded-ccl/2015-06-08/single-threaded-ccl-20150608-git.tgz"; + sha256 = "0d8cf8x77b3f7qh2cr3fnkc6i7dm7pwlnldmv9k4q033rmmhnfxb"; + system = "single-threaded-ccl"; + asd = "single-threaded-ccl"; + } + ); + systems = [ "single-threaded-ccl" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + singleton-classes = ( + build-asdf-system { + pname = "singleton-classes"; + version = "20190307-hg"; + asds = [ "singleton-classes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-abstract-classes/2019-03-07/cl-abstract-classes-20190307-hg.tgz"; + sha256 = "0q03j3ksgn56j9xvs3d3hhasplj3hvg488f4cx1z97nlyqxr5w1d"; + system = "singleton-classes"; + asd = "singleton-classes"; + } + ); + systems = [ "singleton-classes" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sip-hash = ( + build-asdf-system { + pname = "sip-hash"; + version = "20200610-git"; + asds = [ "sip-hash" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sip-hash/2020-06-10/sip-hash-20200610-git.tgz"; + sha256 = "0cd6g37lxd5i5fyg9my4jja27ki5agbpr9d635rcwpf32yhc4sh9"; + system = "sip-hash"; + asd = "sip-hash"; + } + ); + systems = [ "sip-hash" ]; + lispLibs = [ + (getAttr "com_dot_google_dot_base" self) + (getAttr "nibbles" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + skeleton-creator = ( + build-asdf-system { + pname = "skeleton-creator"; + version = "20191227-git"; + asds = [ "skeleton-creator" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/skeleton-creator/2019-12-27/skeleton-creator-20191227-git.tgz"; + sha256 = "1yj8w9lpb2jzyf02zg65ngmjfsakzc7k1kcw90w52gk14hv1lk6s"; + system = "skeleton-creator"; + asd = "skeleton-creator"; + } + ); + systems = [ "skeleton-creator" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "conf" self) + (getAttr "simplet-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sketch = ( + build-asdf-system { + pname = "sketch"; + version = "20241012-git"; + asds = [ "sketch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sketch/2024-10-12/sketch-20241012-git.tgz"; + sha256 = "1bq0ljb2awzkk4shsd0w4v2hc2abmkwfv7nz8d88hglrvar8qbnl"; + system = "sketch"; + asd = "sketch"; + } + ); + systems = [ "sketch" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-plus-c" self) + (getAttr "closer-mop" self) + (getAttr "glkit" self) + (getAttr "glu-tessellate" self) + (getAttr "mathkit" self) + (getAttr "md5" self) + (getAttr "sdl2" self) + (getAttr "sdl2-image" self) + (getAttr "sdl2-ttf" self) + (getAttr "sdl2kit" self) + (getAttr "split-sequence" self) + (getAttr "static-vectors" self) + (getAttr "trivial-garbage" self) + (getAttr "zpng" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sketch-examples = ( + build-asdf-system { + pname = "sketch-examples"; + version = "20241012-git"; + asds = [ "sketch-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sketch/2024-10-12/sketch-20241012-git.tgz"; + sha256 = "1bq0ljb2awzkk4shsd0w4v2hc2abmkwfv7nz8d88hglrvar8qbnl"; + system = "sketch-examples"; + asd = "sketch-examples"; + } + ); + systems = [ "sketch-examples" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "sketch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + skippy = ( + build-asdf-system { + pname = "skippy"; + version = "1.3.12"; + asds = [ "skippy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/skippy/2015-04-07/skippy-1.3.12.tgz"; + sha256 = "1n8925qz19w00qc67z3hc97fpmfhi0r54dd50fzqm24vhyb7qwc2"; + system = "skippy"; + asd = "skippy"; + } + ); + systems = [ "skippy" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + skippy-renderer = ( + build-asdf-system { + pname = "skippy-renderer"; + version = "20221106-git"; + asds = [ "skippy-renderer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/skippy-renderer/2022-11-06/skippy-renderer-20221106-git.tgz"; + sha256 = "0x9zv8zchxn48axl5rwfnywg9kb9m0pz3gwjk7gpg9m574jw8x0c"; + system = "skippy-renderer"; + asd = "skippy-renderer"; + } + ); + systems = [ "skippy-renderer" ]; + lispLibs = [ (getAttr "skippy" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + skitter = ( + build-asdf-system { + pname = "skitter"; + version = "release-quicklisp-620772ae-git"; + asds = [ "skitter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/skitter/2018-02-28/skitter-release-quicklisp-620772ae-git.tgz"; + sha256 = "1rixcav388fnal9v139kvagjfc60sbwd8ikbmd48lppq2nq5anwl"; + system = "skitter"; + asd = "skitter"; + } + ); + systems = [ "skitter" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "rtg-math" self) + (getAttr "structy-defclass" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + skitter_dot_glop = ( + build-asdf-system { + pname = "skitter.glop"; + version = "release-quicklisp-620772ae-git"; + asds = [ "skitter.glop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/skitter/2018-02-28/skitter-release-quicklisp-620772ae-git.tgz"; + sha256 = "1rixcav388fnal9v139kvagjfc60sbwd8ikbmd48lppq2nq5anwl"; + system = "skitter.glop"; + asd = "skitter.glop"; + } + ); + systems = [ "skitter.glop" ]; + lispLibs = [ + (getAttr "glop" self) + (getAttr "skitter" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + skitter_dot_sdl2 = ( + build-asdf-system { + pname = "skitter.sdl2"; + version = "release-quicklisp-620772ae-git"; + asds = [ "skitter.sdl2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/skitter/2018-02-28/skitter-release-quicklisp-620772ae-git.tgz"; + sha256 = "1rixcav388fnal9v139kvagjfc60sbwd8ikbmd48lppq2nq5anwl"; + system = "skitter.sdl2"; + asd = "skitter.sdl2"; + } + ); + systems = [ "skitter.sdl2" ]; + lispLibs = [ + (getAttr "sdl2" self) + (getAttr "skitter" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + slack-client = ( + build-asdf-system { + pname = "slack-client"; + version = "20160825-git"; + asds = [ "slack-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/slack-client/2016-08-25/slack-client-20160825-git.tgz"; + sha256 = "1yl2wqhx1h2kw3s5dkkq5c4hk1r7679yzq41j2j2bscbl3xk3jp9"; + system = "slack-client"; + asd = "slack-client"; + } + ); + systems = [ "slack-client" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "blackbird" self) + (getAttr "cl-async" self) + (getAttr "drakma-async" self) + (getAttr "event-glue" self) + (getAttr "jonathan" self) + (getAttr "safe-queue" self) + (getAttr "websocket-driver" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + slack-client-test = ( + build-asdf-system { + pname = "slack-client-test"; + version = "20160825-git"; + asds = [ "slack-client-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/slack-client/2016-08-25/slack-client-20160825-git.tgz"; + sha256 = "1yl2wqhx1h2kw3s5dkkq5c4hk1r7679yzq41j2j2bscbl3xk3jp9"; + system = "slack-client-test"; + asd = "slack-client-test"; + } + ); + systems = [ "slack-client-test" ]; + lispLibs = [ + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "slack-client" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + slim = ( + build-asdf-system { + pname = "slim"; + version = "20241012-git"; + asds = [ "slim" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mcclim/2024-10-12/mcclim-20241012-git.tgz"; + sha256 = "17chywrma5vhq254spmg1idpk1sq8isk1qj0lga9n8aiybqssxv9"; + system = "slim"; + asd = "slim"; + } + ); + systems = [ "slim" ]; + lispLibs = [ (getAttr "mcclim" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + slite = ( + build-asdf-system { + pname = "slite"; + version = "20241012-git"; + asds = [ "slite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/slite/2024-10-12/slite-20241012-git.tgz"; + sha256 = "1ij1qxp20p7zfxm453v42z27ff3z6lk7hly8knk5fj3awj9nvljd"; + system = "slite"; + asd = "slite"; + } + ); + systems = [ "slite" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + slot-extra-options = ( + build-asdf-system { + pname = "slot-extra-options"; + version = "20210411-git"; + asds = [ "slot-extra-options" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/slot-extra-options/2021-04-11/slot-extra-options-20210411-git.tgz"; + sha256 = "1b2swhjjs0w1034cy045q8l3ndmci7rjawka39q23vncy6d90497"; + system = "slot-extra-options"; + asd = "slot-extra-options"; + } + ); + systems = [ "slot-extra-options" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + slot-extra-options-tests = ( + build-asdf-system { + pname = "slot-extra-options-tests"; + version = "20210411-git"; + asds = [ "slot-extra-options-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/slot-extra-options/2021-04-11/slot-extra-options-20210411-git.tgz"; + sha256 = "1b2swhjjs0w1034cy045q8l3ndmci7rjawka39q23vncy6d90497"; + system = "slot-extra-options-tests"; + asd = "slot-extra-options-tests"; + } + ); + systems = [ "slot-extra-options-tests" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + (getAttr "parachute" self) + (getAttr "serapeum" self) + (getAttr "slot-extra-options" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + slot-map = ( + build-asdf-system { + pname = "slot-map"; + version = "20220707-git"; + asds = [ "slot-map" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/slot-map/2022-07-07/slot-map-20220707-git.tgz"; + sha256 = "1z9qprjqj3pwqf469bxj0fvvjni1ncap6g7w5q9gmv5hnf2a4yjb"; + system = "slot-map"; + asd = "slot-map"; + } + ); + systems = [ "slot-map" ]; + lispLibs = [ + (getAttr "dynamic-array" self) + (getAttr "mfiano-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + slynk = ( + build-asdf-system { + pname = "slynk"; + version = "20241012-git"; + asds = [ "slynk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sly/2024-10-12/sly-20241012-git.tgz"; + sha256 = "1mxkcgh7g76mqn148zm2mhsh09whwh89wldlyfhq0d9h96zch451"; + system = "slynk"; + asd = "slynk"; + } + ); + systems = [ "slynk" ]; + lispLibs = [ ]; + meta = { }; + } + ); + slynk-macrostep = ( + build-asdf-system { + pname = "slynk-macrostep"; + version = "20230618-git"; + asds = [ "slynk-macrostep" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sly-macrostep/2023-06-18/sly-macrostep-20230618-git.tgz"; + sha256 = "1nxf28gn4f3n0wnv7nb5sgl36fz175y470zs9hig4kq8cp0yal0r"; + system = "slynk-macrostep"; + asd = "slynk-macrostep"; + } + ); + systems = [ "slynk-macrostep" ]; + lispLibs = [ (getAttr "slynk" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + slynk-named-readtables = ( + build-asdf-system { + pname = "slynk-named-readtables"; + version = "20230618-git"; + asds = [ "slynk-named-readtables" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sly-named-readtables/2023-06-18/sly-named-readtables-20230618-git.tgz"; + sha256 = "16asd119rzqrlclps2q6yrkis8jy5an5xgzzqvb7jdyq39zxg54q"; + system = "slynk-named-readtables"; + asd = "slynk-named-readtables"; + } + ); + systems = [ "slynk-named-readtables" ]; + lispLibs = [ (getAttr "slynk" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + smackjack = ( + build-asdf-system { + pname = "smackjack"; + version = "20180228-git"; + asds = [ "smackjack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/smackjack/2018-02-28/smackjack-20180228-git.tgz"; + sha256 = "1n2x7qij2ci70axd2xn295qqgqrvbfbpvv2438lhwd8qa92dhk8b"; + system = "smackjack"; + asd = "smackjack"; + } + ); + systems = [ "smackjack" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-containers" self) + (getAttr "cl-json" self) + (getAttr "hunchentoot" self) + (getAttr "parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + smackjack-demo = ( + build-asdf-system { + pname = "smackjack-demo"; + version = "20180228-git"; + asds = [ "smackjack-demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/smackjack/2018-02-28/smackjack-20180228-git.tgz"; + sha256 = "1n2x7qij2ci70axd2xn295qqgqrvbfbpvv2438lhwd8qa92dhk8b"; + system = "smackjack-demo"; + asd = "smackjack-demo"; + } + ); + systems = [ "smackjack-demo" ]; + lispLibs = [ + (getAttr "cl-containers" self) + (getAttr "cl-who" self) + (getAttr "local-time" self) + (getAttr "smackjack" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + small-coalton-programs = ( + build-asdf-system { + pname = "small-coalton-programs"; + version = "20241012-git"; + asds = [ "small-coalton-programs" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; + sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; + system = "small-coalton-programs"; + asd = "small-coalton-programs"; + } + ); + systems = [ "small-coalton-programs" ]; + lispLibs = [ (getAttr "coalton" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + smart-buffer = ( + build-asdf-system { + pname = "smart-buffer"; + version = "20211020-git"; + asds = [ "smart-buffer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/smart-buffer/2021-10-20/smart-buffer-20211020-git.tgz"; + sha256 = "1r9y61a791m7aqgg2ixs86lc63y78w7n6dwipakcpjzscqmprppr"; + system = "smart-buffer"; + asd = "smart-buffer"; + } + ); + systems = [ "smart-buffer" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "xsubseq" self) + ]; + meta = { }; + } + ); + smart-buffer-test = ( + build-asdf-system { + pname = "smart-buffer-test"; + version = "20211020-git"; + asds = [ "smart-buffer-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/smart-buffer/2021-10-20/smart-buffer-20211020-git.tgz"; + sha256 = "1r9y61a791m7aqgg2ixs86lc63y78w7n6dwipakcpjzscqmprppr"; + system = "smart-buffer-test"; + asd = "smart-buffer-test"; + } + ); + systems = [ "smart-buffer-test" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "smart-buffer" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + smokebase = ( + build-asdf-system { + pname = "smokebase"; + version = "20210531-git"; + asds = [ "smokebase" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/qt-libs/2021-05-31/qt-libs-20210531-git.tgz"; + sha256 = "0why7cssadw20jg382k6mg2lgk5b3b3nwyyvjafaz90h0ljf0b9w"; + system = "smokebase"; + asd = "smokebase"; + } + ); + systems = [ "smokebase" ]; + lispLibs = [ + (getAttr "qt_plus_libs" self) + (getAttr "qt-libs" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + smoothers = ( + build-asdf-system { + pname = "smoothers"; + version = "20241012-git"; + asds = [ "smoothers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/smoothers/2024-10-12/smoothers-20241012-git.tgz"; + sha256 = "0byqn3xni83jkbzc0jllpyfsgjaiifsjr55aaf90pbi71as39xfd"; + system = "smoothers"; + asd = "smoothers"; + } + ); + systems = [ "smoothers" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "alexandria_plus" self) + (getAttr "array-operations" self) + (getAttr "lla" self) + (getAttr "num-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + smug = ( + build-asdf-system { + pname = "smug"; + version = "20211230-git"; + asds = [ "smug" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/smug/2021-12-30/smug-20211230-git.tgz"; + sha256 = "13gzkj9skya2ziwclk041v7sif392ydbvhvikhg2raa3qjcxb3rq"; + system = "smug"; + asd = "smug"; + } + ); + systems = [ "smug" ]; + lispLibs = [ (getAttr "asdf-package-system" self) ]; + meta = { }; + } + ); + snakes = ( + build-asdf-system { + pname = "snakes"; + version = "20221106-git"; + asds = [ "snakes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snakes/2022-11-06/snakes-20221106-git.tgz"; + sha256 = "17fqkw256c2iacy5g37sv9h0mbrmb3fg2s9sd83gj9clrg5r4wkl"; + system = "snakes"; + asd = "snakes"; + } + ); + systems = [ "snakes" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-cont" self) + (getAttr "cl-utilities" self) + (getAttr "closer-mop" self) + (getAttr "fiveam" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snappy = ( + build-asdf-system { + pname = "snappy"; + version = "20211209-git"; + asds = [ "snappy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snappy/2021-12-09/snappy-20211209-git.tgz"; + sha256 = "1g0d8icbqmahywqczb8pimr63970dil6mnlxkv3y9ng31dg0npy6"; + system = "snappy"; + asd = "snappy"; + } + ); + systems = [ "snappy" ]; + lispLibs = [ + (getAttr "com_dot_google_dot_base" self) + (getAttr "nibbles" self) + (getAttr "varint" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark = ( + build-asdf-system { + pname = "snark"; + version = "20160421-git"; + asds = [ "snark" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark"; + asd = "snark"; + } + ); + systems = [ "snark" ]; + lispLibs = [ (getAttr "snark-implementation" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-agenda = ( + build-asdf-system { + pname = "snark-agenda"; + version = "20160421-git"; + asds = [ "snark-agenda" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-agenda"; + asd = "snark-agenda"; + } + ); + systems = [ "snark-agenda" ]; + lispLibs = [ + (getAttr "snark-auxiliary-packages" self) + (getAttr "snark-deque" self) + (getAttr "snark-lisp" self) + (getAttr "snark-sparse-array" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-auxiliary-packages = ( + build-asdf-system { + pname = "snark-auxiliary-packages"; + version = "20160421-git"; + asds = [ "snark-auxiliary-packages" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-auxiliary-packages"; + asd = "snark-auxiliary-packages"; + } + ); + systems = [ "snark-auxiliary-packages" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-deque = ( + build-asdf-system { + pname = "snark-deque"; + version = "20160421-git"; + asds = [ "snark-deque" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-deque"; + asd = "snark-deque"; + } + ); + systems = [ "snark-deque" ]; + lispLibs = [ + (getAttr "snark-auxiliary-packages" self) + (getAttr "snark-lisp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-dpll = ( + build-asdf-system { + pname = "snark-dpll"; + version = "20160421-git"; + asds = [ "snark-dpll" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-dpll"; + asd = "snark-dpll"; + } + ); + systems = [ "snark-dpll" ]; + lispLibs = [ + (getAttr "snark-auxiliary-packages" self) + (getAttr "snark-lisp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-examples = ( + build-asdf-system { + pname = "snark-examples"; + version = "20160421-git"; + asds = [ "snark-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-examples"; + asd = "snark-examples"; + } + ); + systems = [ "snark-examples" ]; + lispLibs = [ (getAttr "snark" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-feature = ( + build-asdf-system { + pname = "snark-feature"; + version = "20160421-git"; + asds = [ "snark-feature" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-feature"; + asd = "snark-feature"; + } + ); + systems = [ "snark-feature" ]; + lispLibs = [ + (getAttr "snark-auxiliary-packages" self) + (getAttr "snark-lisp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-implementation = ( + build-asdf-system { + pname = "snark-implementation"; + version = "20160421-git"; + asds = [ "snark-implementation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-implementation"; + asd = "snark-implementation"; + } + ); + systems = [ "snark-implementation" ]; + lispLibs = [ + (getAttr "snark-agenda" self) + (getAttr "snark-auxiliary-packages" self) + (getAttr "snark-deque" self) + (getAttr "snark-dpll" self) + (getAttr "snark-feature" self) + (getAttr "snark-infix-reader" self) + (getAttr "snark-lisp" self) + (getAttr "snark-numbering" self) + (getAttr "snark-pkg" self) + (getAttr "snark-sparse-array" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-infix-reader = ( + build-asdf-system { + pname = "snark-infix-reader"; + version = "20160421-git"; + asds = [ "snark-infix-reader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-infix-reader"; + asd = "snark-infix-reader"; + } + ); + systems = [ "snark-infix-reader" ]; + lispLibs = [ + (getAttr "snark-auxiliary-packages" self) + (getAttr "snark-lisp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-lisp = ( + build-asdf-system { + pname = "snark-lisp"; + version = "20160421-git"; + asds = [ "snark-lisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-lisp"; + asd = "snark-lisp"; + } + ); + systems = [ "snark-lisp" ]; + lispLibs = [ (getAttr "snark-auxiliary-packages" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-loads = ( + build-asdf-system { + pname = "snark-loads"; + version = "20160421-git"; + asds = [ "snark-loads" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-loads"; + asd = "snark-loads"; + } + ); + systems = [ "snark-loads" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-numbering = ( + build-asdf-system { + pname = "snark-numbering"; + version = "20160421-git"; + asds = [ "snark-numbering" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-numbering"; + asd = "snark-numbering"; + } + ); + systems = [ "snark-numbering" ]; + lispLibs = [ + (getAttr "snark-auxiliary-packages" self) + (getAttr "snark-lisp" self) + (getAttr "snark-sparse-array" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-pkg = ( + build-asdf-system { + pname = "snark-pkg"; + version = "20160421-git"; + asds = [ "snark-pkg" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-pkg"; + asd = "snark-pkg"; + } + ); + systems = [ "snark-pkg" ]; + lispLibs = [ (getAttr "snark-dpll" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snark-sparse-array = ( + build-asdf-system { + pname = "snark-sparse-array"; + version = "20160421-git"; + asds = [ "snark-sparse-array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snark/2016-04-21/snark-20160421-git.tgz"; + sha256 = "0zsqaqkl9s626nk5h41z00kssjnzhbsra68zfflryp5j3gy9vgm5"; + system = "snark-sparse-array"; + asd = "snark-sparse-array"; + } + ); + systems = [ "snark-sparse-array" ]; + lispLibs = [ + (getAttr "snark-auxiliary-packages" self) + (getAttr "snark-lisp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sndfile-blob = ( + build-asdf-system { + pname = "sndfile-blob"; + version = "stable-git"; + asds = [ "sndfile-blob" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sndfile-blob/2020-10-16/sndfile-blob-stable-git.tgz"; + sha256 = "1csbm2cgj76smia59044vx8698w9dy223cmwv8l4i8kb95m1i3l0"; + system = "sndfile-blob"; + asd = "sndfile-blob"; + } + ); + systems = [ "sndfile-blob" ]; + lispLibs = [ + (getAttr "bodge-blobs-support" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snmp = ( + build-asdf-system { + pname = "snmp"; + version = "6.1"; + asds = [ "snmp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snmp/2016-10-31/snmp-6.1.tgz"; + sha256 = "0qpy6jfp0v9i80gli1gf98sj0h67x9g5a8bqxrsxnqyi3h59di5s"; + system = "snmp"; + asd = "snmp"; + } + ); + systems = [ "snmp" ]; + lispLibs = [ + (getAttr "ieee-floats" self) + (getAttr "ironclad" self) + (getAttr "portable-threads" self) + (getAttr "trivial-gray-streams" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snmp-server = ( + build-asdf-system { + pname = "snmp-server"; + version = "6.1"; + asds = [ "snmp-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snmp/2016-10-31/snmp-6.1.tgz"; + sha256 = "0qpy6jfp0v9i80gli1gf98sj0h67x9g5a8bqxrsxnqyi3h59di5s"; + system = "snmp-server"; + asd = "snmp-server"; + } + ); + systems = [ "snmp-server" ]; + lispLibs = [ + (getAttr "snmp" self) + (getAttr "usocket-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snmp-test = ( + build-asdf-system { + pname = "snmp-test"; + version = "6.1"; + asds = [ "snmp-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snmp/2016-10-31/snmp-6.1.tgz"; + sha256 = "0qpy6jfp0v9i80gli1gf98sj0h67x9g5a8bqxrsxnqyi3h59di5s"; + system = "snmp-test"; + asd = "snmp-test"; + } + ); + systems = [ "snmp-test" ]; + lispLibs = [ + (getAttr "snmp" self) + (getAttr "snmp-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snmp-ui = ( + build-asdf-system { + pname = "snmp-ui"; + version = "6.1"; + asds = [ "snmp-ui" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snmp/2016-10-31/snmp-6.1.tgz"; + sha256 = "0qpy6jfp0v9i80gli1gf98sj0h67x9g5a8bqxrsxnqyi3h59di5s"; + system = "snmp-ui"; + asd = "snmp-ui"; + } + ); + systems = [ "snmp-ui" ]; + lispLibs = [ (getAttr "snmp" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snooze = ( + build-asdf-system { + pname = "snooze"; + version = "20241012-git"; + asds = [ "snooze" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snooze/2024-10-12/snooze-20241012-git.tgz"; + sha256 = "0gm9vxi7lcir80snka3qkl6sw8z90jaqf31c72bgyk9j8qkf7xvc"; + system = "snooze"; + asd = "snooze"; + } + ); + systems = [ "snooze" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "parse-float" self) + (getAttr "quri" self) + (getAttr "rfc2388" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snooze-demo = ( + build-asdf-system { + pname = "snooze-demo"; + version = "20241012-git"; + asds = [ "snooze-demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snooze/2024-10-12/snooze-20241012-git.tgz"; + sha256 = "0gm9vxi7lcir80snka3qkl6sw8z90jaqf31c72bgyk9j8qkf7xvc"; + system = "snooze-demo"; + asd = "snooze"; + } + ); + systems = [ "snooze-demo" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-css" self) + (getAttr "cl-fad" self) + (getAttr "cl-json" self) + (getAttr "cl-who" self) + (getAttr "hunchentoot" self) + (getAttr "local-time" self) + (getAttr "local-time-duration" self) + (getAttr "snooze" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + snooze-tests = ( + build-asdf-system { + pname = "snooze-tests"; + version = "20241012-git"; + asds = [ "snooze-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/snooze/2024-10-12/snooze-20241012-git.tgz"; + sha256 = "0gm9vxi7lcir80snka3qkl6sw8z90jaqf31c72bgyk9j8qkf7xvc"; + system = "snooze-tests"; + asd = "snooze"; + } + ); + systems = [ "snooze-tests" ]; + lispLibs = [ + (getAttr "fiasco" self) + (getAttr "snooze" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + softdrink = ( + build-asdf-system { + pname = "softdrink"; + version = "20231021-git"; + asds = [ "softdrink" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/softdrink/2023-10-21/softdrink-20231021-git.tgz"; + sha256 = "1454mqpwb2s7m1myhibj2mrlm64wng1jgbv94mhs6hpzj2r2mgdi"; + system = "softdrink"; + asd = "softdrink"; + } + ); + systems = [ "softdrink" ]; + lispLibs = [ + (getAttr "lass" self) + (getAttr "lquery" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + software-evolution-library = ( + build-asdf-system { + pname = "software-evolution-library"; + version = "20241012-git"; + asds = [ "software-evolution-library" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sel/2024-10-12/sel-20241012-git.tgz"; + sha256 = "1j1disr1wcql30hdj3f49ss41843wlmqx486nkna6qbnnsfay66w"; + system = "software-evolution-library"; + asd = "software-evolution-library"; + } + ); + systems = [ "software-evolution-library" ]; + lispLibs = [ + (getAttr "asdf-package-system" self) + (getAttr "atomics" self) + (getAttr "cffi-grovel" self) + (getAttr "deploy" self) + (getAttr "gt" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + solid-engine = ( + build-asdf-system { + pname = "solid-engine"; + version = "20190521-git"; + asds = [ "solid-engine" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/solid-engine/2019-05-21/solid-engine-20190521-git.tgz"; + sha256 = "1pxrgxfqz8br258jy35qyimsrz544fg9k7lw2jshkj4jr2pswsv0"; + system = "solid-engine"; + asd = "solid-engine"; + } + ); + systems = [ "solid-engine" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + soundex = ( + build-asdf-system { + pname = "soundex"; + version = "1.0"; + asds = [ "soundex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/soundex/2010-10-06/soundex-1.0.tgz"; + sha256 = "00ar2x7ja35337v6gwa4h2b8w7gf7dwx5mdfz91dqay43kx1pjsi"; + system = "soundex"; + asd = "soundex"; + } + ); + systems = [ "soundex" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + source-error = ( + build-asdf-system { + pname = "source-error"; + version = "20241012-git"; + asds = [ "source-error" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; + sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; + system = "source-error"; + asd = "source-error"; + } + ); + systems = [ "source-error" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + south = ( + build-asdf-system { + pname = "south"; + version = "20231021-git"; + asds = [ "south" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/south/2023-10-21/south-20231021-git.tgz"; + sha256 = "0acvi3nwddwphxm92i8bbv1nbb9zzx7gbcza5cr68rs8wydsr8h3"; + system = "south"; + asd = "south"; + } + ); + systems = [ "south" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "ironclad" self) + (getAttr "uuid" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sparse-set = ( + build-asdf-system { + pname = "sparse-set"; + version = "20220707-git"; + asds = [ "sparse-set" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sparse-set/2022-07-07/sparse-set-20220707-git.tgz"; + sha256 = "0czms03lrvg20hw3sz7wzzkl1z0vm0ndb3dmbvwsjd7m89fag793"; + system = "sparse-set"; + asd = "sparse-set"; + } + ); + systems = [ "sparse-set" ]; + lispLibs = [ (getAttr "mfiano-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + spatial-trees = ( + build-asdf-system { + pname = "spatial-trees"; + version = "20140826-git"; + asds = [ "spatial-trees" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/spatial-trees/2014-08-26/spatial-trees-20140826-git.tgz"; + sha256 = "11rhc6h501dwcik2igkszz7b9n515cr99m5pjh4r2qfwgiri6ysa"; + system = "spatial-trees"; + asd = "spatial-trees"; + } + ); + systems = [ "spatial-trees" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + spatial-trees_dot_nns = ( + build-asdf-system { + pname = "spatial-trees.nns"; + version = "20140826-git"; + asds = [ "spatial-trees.nns" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/spatial-trees/2014-08-26/spatial-trees-20140826-git.tgz"; + sha256 = "11rhc6h501dwcik2igkszz7b9n515cr99m5pjh4r2qfwgiri6ysa"; + system = "spatial-trees.nns"; + asd = "spatial-trees.nns"; + } + ); + systems = [ "spatial-trees.nns" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "optima" self) + (getAttr "spatial-trees" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + spatial-trees_dot_nns_dot_test = ( + build-asdf-system { + pname = "spatial-trees.nns.test"; + version = "20140826-git"; + asds = [ "spatial-trees.nns.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/spatial-trees/2014-08-26/spatial-trees-20140826-git.tgz"; + sha256 = "11rhc6h501dwcik2igkszz7b9n515cr99m5pjh4r2qfwgiri6ysa"; + system = "spatial-trees.nns.test"; + asd = "spatial-trees.nns.test"; + } + ); + systems = [ "spatial-trees.nns.test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "fiveam" self) + (getAttr "iterate" self) + (getAttr "optima" self) + (getAttr "spatial-trees" self) + (getAttr "spatial-trees_dot_nns" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + spatial-trees_dot_test = ( + build-asdf-system { + pname = "spatial-trees.test"; + version = "20140826-git"; + asds = [ "spatial-trees.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/spatial-trees/2014-08-26/spatial-trees-20140826-git.tgz"; + sha256 = "11rhc6h501dwcik2igkszz7b9n515cr99m5pjh4r2qfwgiri6ysa"; + system = "spatial-trees.test"; + asd = "spatial-trees.test"; + } + ); + systems = [ "spatial-trees.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "spatial-trees" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + special-functions = ( + build-asdf-system { + pname = "special-functions"; + version = "20221106-git"; + asds = [ "special-functions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/special-functions/2022-11-06/special-functions-20221106-git.tgz"; + sha256 = "092szffy7zfxgrvfck11wnj8l0mgcym13yiafj01ad02lbj1fnnv"; + system = "special-functions"; + asd = "special-functions"; + } + ); + systems = [ "special-functions" ]; + lispLibs = [ + (getAttr "alexandria_plus" self) + (getAttr "float-features" self) + (getAttr "let-plus" self) + (getAttr "num-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + specialization-store = ( + build-asdf-system { + pname = "specialization-store"; + version = "v0.0.5"; + asds = [ "specialization-store" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/specialization-store/2020-06-10/specialization-store-v0.0.5.tgz"; + sha256 = "03q0szyz8ygqmg10q4j97dy7gfr9icxay9s8bgs883yncbk42y6c"; + system = "specialization-store"; + asd = "specialization-store"; + } + ); + systems = [ "specialization-store" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "introspect-environment" self) + (getAttr "specialization-store-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + specialization-store-features = ( + build-asdf-system { + pname = "specialization-store-features"; + version = "v0.0.5"; + asds = [ "specialization-store-features" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/specialization-store/2020-06-10/specialization-store-v0.0.5.tgz"; + sha256 = "03q0szyz8ygqmg10q4j97dy7gfr9icxay9s8bgs883yncbk42y6c"; + system = "specialization-store-features"; + asd = "specialization-store-features"; + } + ); + systems = [ "specialization-store-features" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "introspect-environment" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + specialization-store-tests = ( + build-asdf-system { + pname = "specialization-store-tests"; + version = "v0.0.5"; + asds = [ "specialization-store-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/specialization-store/2020-06-10/specialization-store-v0.0.5.tgz"; + sha256 = "03q0szyz8ygqmg10q4j97dy7gfr9icxay9s8bgs883yncbk42y6c"; + system = "specialization-store-tests"; + asd = "specialization-store-tests"; + } + ); + systems = [ "specialization-store-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "specialization-store" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + specialized-function = ( + build-asdf-system { + pname = "specialized-function"; + version = "20210531-git"; + asds = [ "specialized-function" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/specialized-function/2021-05-31/specialized-function-20210531-git.tgz"; + sha256 = "19hfgc83b7as630r1w9r8yl0v6xq3dn01vcrl0bd4pza5hgjn4la"; + system = "specialized-function"; + asd = "specialized-function"; + } + ); + systems = [ "specialized-function" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "lisp-namespace" self) + (getAttr "trivia" self) + (getAttr "trivial-cltl2" self) + (getAttr "type-r" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + specialized-function_dot_test = ( + build-asdf-system { + pname = "specialized-function.test"; + version = "20210531-git"; + asds = [ "specialized-function.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/specialized-function/2021-05-31/specialized-function-20210531-git.tgz"; + sha256 = "19hfgc83b7as630r1w9r8yl0v6xq3dn01vcrl0bd4pza5hgjn4la"; + system = "specialized-function.test"; + asd = "specialized-function.test"; + } + ); + systems = [ "specialized-function.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "specialized-function" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + speechless = ( + build-asdf-system { + pname = "speechless"; + version = "20231021-git"; + asds = [ "speechless" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/speechless/2023-10-21/speechless-20231021-git.tgz"; + sha256 = "0x1v3gf0f0xpyxs8392r4xaqz214zmd1j89l61x9bg2h30k8ls37"; + system = "speechless"; + asd = "speechless"; + } + ); + systems = [ "speechless" ]; + lispLibs = [ + (getAttr "cl-markless" self) + (getAttr "documentation-utils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + spell = ( + build-asdf-system { + pname = "spell"; + version = "20190307-git"; + asds = [ "spell" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/spell/2019-03-07/spell-20190307-git.tgz"; + sha256 = "1ifhx5q0iz80i9zwgcpv3w7xpp92ar9grz25008wnqzaayhfl020"; + system = "spell"; + asd = "spell"; + } + ); + systems = [ "spell" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + spellcheck = ( + build-asdf-system { + pname = "spellcheck"; + version = "20131003-git"; + asds = [ "spellcheck" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/spellcheck/2013-10-03/spellcheck-20131003-git.tgz"; + sha256 = "0a0r1dgh7y06s7j9mzxrryri8fhajzjsrrsh3i6vv65vq5zzxlka"; + system = "spellcheck"; + asd = "spellcheck"; + } + ); + systems = [ "spellcheck" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sphinx = ( + build-asdf-system { + pname = "sphinx"; + version = "20110619-git"; + asds = [ "sphinx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sphinx/2011-06-19/cl-sphinx-20110619-git.tgz"; + sha256 = "0z1ksxz1gh12ly6lbc77l0d5f380s81vx44qakm2dl1398lgb7x1"; + system = "sphinx"; + asd = "sphinx"; + } + ); + systems = [ "sphinx" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "closure-template" self) + (getAttr "colorize" self) + (getAttr "docutils" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + spinneret = ( + build-asdf-system { + pname = "spinneret"; + version = "20241012-git"; + asds = [ "spinneret" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/spinneret/2024-10-12/spinneret-20241012-git.tgz"; + sha256 = "09ak35p487bwlwbv0vcdg9h869n8m7i3j1qj4f53lh1bm5s1zi5n"; + system = "spinneret"; + asd = "spinneret"; + } + ); + systems = [ "spinneret" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "global-vars" self) + (getAttr "in-nomine" self) + (getAttr "parenscript" self) + (getAttr "serapeum" self) + (getAttr "trivia" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + split-sequence = ( + build-asdf-system { + pname = "split-sequence"; + version = "v2.0.1"; + asds = [ "split-sequence" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/split-sequence/2021-05-31/split-sequence-v2.0.1.tgz"; + sha256 = "172k7iv775kwism6304p6z7mqpjvipl57nq1bgvmbk445943fmhq"; + system = "split-sequence"; + asd = "split-sequence"; + } + ); + systems = [ "split-sequence" ]; + lispLibs = [ ]; + meta = { }; + } + ); + sqlite = ( + build-asdf-system { + pname = "sqlite"; + version = "20190813-git"; + asds = [ "sqlite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sqlite/2019-08-13/cl-sqlite-20190813-git.tgz"; + sha256 = "08iv7b4m0hh7qx2cvq4f510nrgdld0vicnvmqsh9w0fgrcgmyg4k"; + system = "sqlite"; + asd = "sqlite"; + } + ); + systems = [ "sqlite" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "iterate" self) + ]; + meta = { }; + } + ); + srfi-1 = ( + build-asdf-system { + pname = "srfi-1"; + version = "20200218-git"; + asds = [ "srfi-1" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/srfi-1/2020-02-18/srfi-1-20200218-git.tgz"; + sha256 = "00r2ikf1ck1zz3mx3jgk3plf3ibfhhrr8sc8hzr6ix34sbfvdadg"; + system = "srfi-1"; + asd = "srfi-1"; + } + ); + systems = [ "srfi-1" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + srfi-1_dot_test = ( + build-asdf-system { + pname = "srfi-1.test"; + version = "20200218-git"; + asds = [ "srfi-1.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/srfi-1/2020-02-18/srfi-1-20200218-git.tgz"; + sha256 = "00r2ikf1ck1zz3mx3jgk3plf3ibfhhrr8sc8hzr6ix34sbfvdadg"; + system = "srfi-1.test"; + asd = "srfi-1"; + } + ); + systems = [ "srfi-1.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "srfi-1" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + srfi-23 = ( + build-asdf-system { + pname = "srfi-23"; + version = "20200218-git"; + asds = [ "srfi-23" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/srfi-23/2020-02-18/srfi-23-20200218-git.tgz"; + sha256 = "0hgq2bdpdjp550kk9xlrxh82n45ldb42j2zzhkndmffh4rp9hd13"; + system = "srfi-23"; + asd = "srfi-23"; + } + ); + systems = [ "srfi-23" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + srfi-6 = ( + build-asdf-system { + pname = "srfi-6"; + version = "20200218-git"; + asds = [ "srfi-6" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/srfi-6/2020-02-18/srfi-6-20200218-git.tgz"; + sha256 = "1m9316r75haig84fhcrfm69gq0zfh5xqwqw8wsccc6z6vpz7pfwm"; + system = "srfi-6"; + asd = "srfi-6"; + } + ); + systems = [ "srfi-6" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + srfi-98 = ( + build-asdf-system { + pname = "srfi-98"; + version = "20200218-git"; + asds = [ "srfi-98" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/srfi-98/2020-02-18/srfi-98-20200218-git.tgz"; + sha256 = "0qqa7c6nas85n8mdpmk996jh12xm0nf63nhj1chi9qkwgm924fj3"; + system = "srfi-98"; + asd = "srfi-98"; + } + ); + systems = [ "srfi-98" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + srfi-98_dot_test = ( + build-asdf-system { + pname = "srfi-98.test"; + version = "20200218-git"; + asds = [ "srfi-98.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/srfi-98/2020-02-18/srfi-98-20200218-git.tgz"; + sha256 = "0qqa7c6nas85n8mdpmk996jh12xm0nf63nhj1chi9qkwgm924fj3"; + system = "srfi-98.test"; + asd = "srfi-98"; + } + ); + systems = [ "srfi-98.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "srfi-98" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sse-client = ( + build-asdf-system { + pname = "sse-client"; + version = "20210807-git"; + asds = [ "sse-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sse/2021-08-07/cl-sse-20210807-git.tgz"; + sha256 = "1by7xx397fyplxrydhfjm7nkxb6gmqh0h5f0rp4kh5dx45gk59gl"; + system = "sse-client"; + asd = "sse-client"; + } + ); + systems = [ "sse-client" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sse-client-test = ( + build-asdf-system { + pname = "sse-client-test"; + version = "20210807-git"; + asds = [ "sse-client-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sse/2021-08-07/cl-sse-20210807-git.tgz"; + sha256 = "1by7xx397fyplxrydhfjm7nkxb6gmqh0h5f0rp4kh5dx45gk59gl"; + system = "sse-client-test"; + asd = "sse-client-test"; + } + ); + systems = [ "sse-client-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "sse-client" self) + (getAttr "trivial-escapes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sse-demo = ( + build-asdf-system { + pname = "sse-demo"; + version = "20210807-git"; + asds = [ "sse-demo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sse/2021-08-07/cl-sse-20210807-git.tgz"; + sha256 = "1by7xx397fyplxrydhfjm7nkxb6gmqh0h5f0rp4kh5dx45gk59gl"; + system = "sse-demo"; + asd = "sse-demo"; + } + ); + systems = [ "sse-demo" ]; + lispLibs = [ + (getAttr "easy-routes" self) + (getAttr "flexi-streams" self) + (getAttr "hunchentoot" self) + (getAttr "sse-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sse-server = ( + build-asdf-system { + pname = "sse-server"; + version = "20210807-git"; + asds = [ "sse-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sse/2021-08-07/cl-sse-20210807-git.tgz"; + sha256 = "1by7xx397fyplxrydhfjm7nkxb6gmqh0h5f0rp4kh5dx45gk59gl"; + system = "sse-server"; + asd = "sse-server"; + } + ); + systems = [ "sse-server" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "trivial-escapes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sse-server-test = ( + build-asdf-system { + pname = "sse-server-test"; + version = "20210807-git"; + asds = [ "sse-server-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sse/2021-08-07/cl-sse-20210807-git.tgz"; + sha256 = "1by7xx397fyplxrydhfjm7nkxb6gmqh0h5f0rp4kh5dx45gk59gl"; + system = "sse-server-test"; + asd = "sse-server-test"; + } + ); + systems = [ "sse-server-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "sse-server" self) + (getAttr "trivial-escapes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + st-json = ( + build-asdf-system { + pname = "st-json"; + version = "20210630-git"; + asds = [ "st-json" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/st-json/2021-06-30/st-json-20210630-git.tgz"; + sha256 = "06qrhr5iw73k96lai2x9w52l6gnmlxy7fsr0r35gz6nz1f71x7gx"; + system = "st-json"; + asd = "st-json"; + } + ); + systems = [ "st-json" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + standard-cl = ( + build-asdf-system { + pname = "standard-cl"; + version = "20121125-git"; + asds = [ "standard-cl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-match/2012-11-25/cl-match-20121125-git.tgz"; + sha256 = "1qc8gzp7f4phgyi5whkxacrqzdqs0y1hvkf71m8n7l303jly9wjf"; + system = "standard-cl"; + asd = "standard-cl"; + } + ); + systems = [ "standard-cl" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + staple = ( + build-asdf-system { + pname = "staple"; + version = "20241012-git"; + asds = [ "staple" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; + sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; + system = "staple"; + asd = "staple"; + } + ); + systems = [ "staple" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + (getAttr "clip" self) + (getAttr "definitions" self) + (getAttr "documentation-utils" self) + (getAttr "language-codes" self) + (getAttr "pathname-utils" self) + (getAttr "staple-code-parser" self) + (getAttr "staple-package-recording" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + staple-code-parser = ( + build-asdf-system { + pname = "staple-code-parser"; + version = "20241012-git"; + asds = [ "staple-code-parser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; + sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; + system = "staple-code-parser"; + asd = "staple-code-parser"; + } + ); + systems = [ "staple-code-parser" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "concrete-syntax-tree" self) + (getAttr "concrete-syntax-tree-destructuring" self) + (getAttr "concrete-syntax-tree-lambda-list" self) + (getAttr "definitions" self) + (getAttr "documentation-utils" self) + (getAttr "eclector" self) + (getAttr "eclector-concrete-syntax-tree" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + staple-markdown = ( + build-asdf-system { + pname = "staple-markdown"; + version = "20241012-git"; + asds = [ "staple-markdown" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; + sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; + system = "staple-markdown"; + asd = "staple-markdown"; + } + ); + systems = [ "staple-markdown" ]; + lispLibs = [ + (getAttr "_3bmd" self) + (getAttr "_3bmd-ext-code-blocks" self) + (getAttr "staple" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + staple-markless = ( + build-asdf-system { + pname = "staple-markless"; + version = "20241012-git"; + asds = [ "staple-markless" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; + sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; + system = "staple-markless"; + asd = "staple-markless"; + } + ); + systems = [ "staple-markless" ]; + lispLibs = [ + (getAttr "cl-markless-plump" self) + (getAttr "staple" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + staple-package-recording = ( + build-asdf-system { + pname = "staple-package-recording"; + version = "20241012-git"; + asds = [ "staple-package-recording" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; + sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; + system = "staple-package-recording"; + asd = "staple-package-recording"; + } + ); + systems = [ "staple-package-recording" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + staple-restructured-text = ( + build-asdf-system { + pname = "staple-restructured-text"; + version = "20241012-git"; + asds = [ "staple-restructured-text" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; + sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; + system = "staple-restructured-text"; + asd = "staple-restructured-text"; + } + ); + systems = [ "staple-restructured-text" ]; + lispLibs = [ + (getAttr "docutils" self) + (getAttr "staple" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + staple-server = ( + build-asdf-system { + pname = "staple-server"; + version = "20241012-git"; + asds = [ "staple-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/staple/2024-10-12/staple-20241012-git.tgz"; + sha256 = "147511d57xkv9d9crnqygj8lqkdpmbyq3g8b9cns130d8m46f2vi"; + system = "staple-server"; + asd = "staple-server"; + } + ); + systems = [ "staple-server" ]; + lispLibs = [ + (getAttr "dissect" self) + (getAttr "documentation-utils" self) + (getAttr "hunchentoot" self) + (getAttr "staple-markdown" self) + (getAttr "staple-markless" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stars = ( + build-asdf-system { + pname = "stars"; + version = "20180831-git"; + asds = [ "stars" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sprint-stars/2018-08-31/sprint-stars-20180831-git.tgz"; + sha256 = "1pm6wvywfgy0vlb0b2lbybpvhw9xzyn1nlpy0wpcglxxig6mnrgi"; + system = "stars"; + asd = "stars"; + } + ); + systems = [ "stars" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "drakma" self) + (getAttr "xmls" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + static-dispatch = ( + build-asdf-system { + pname = "static-dispatch"; + version = "20211209-git"; + asds = [ "static-dispatch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/static-dispatch/2021-12-09/static-dispatch-20211209-git.tgz"; + sha256 = "1cishp7nckda5hav6c907axdfn1zpmzxpsy6hk7kkb69qn81yn2i"; + system = "static-dispatch"; + asd = "static-dispatch"; + } + ); + systems = [ "static-dispatch" ]; + lispLibs = [ + (getAttr "agutil" self) + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "arrows" self) + (getAttr "cl-environments" self) + (getAttr "cl-form-types" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + (getAttr "optima" self) + ]; + meta = { }; + } + ); + static-vectors = ( + build-asdf-system { + pname = "static-vectors"; + version = "v1.9.3"; + asds = [ "static-vectors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/static-vectors/2024-10-12/static-vectors-v1.9.3.tgz"; + sha256 = "1sn37hyf6x56irn2qqc51ncqswa3n94j6cxwcj2ixgxmszcyzx5h"; + system = "static-vectors"; + asd = "static-vectors"; + } + ); + systems = [ "static-vectors" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + ]; + meta = { }; + } + ); + statistics = ( + build-asdf-system { + pname = "statistics"; + version = "20241012-git"; + asds = [ "statistics" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/statistics/2024-10-12/statistics-20241012-git.tgz"; + sha256 = "00dir3sif9jqc0b48vsk8r41h4zmf95jj4nqrc45mbnr80pmdrsl"; + system = "statistics"; + asd = "statistics"; + } + ); + systems = [ "statistics" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "distributions" self) + (getAttr "let-plus" self) + (getAttr "num-utils" self) + (getAttr "org_dot_tfeb_dot_conduit-packages" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + statusor = ( + build-asdf-system { + pname = "statusor"; + version = "20230618-git"; + asds = [ "statusor" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/statusor/2023-06-18/statusor-20230618-git.tgz"; + sha256 = "1mxj4q7grvma6q05vj6sw4h4f2s121mnd77271lwnp74kjwh17cq"; + system = "statusor"; + asd = "statusor"; + } + ); + systems = [ "statusor" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stdutils = ( + build-asdf-system { + pname = "stdutils"; + version = "20111001-git"; + asds = [ "stdutils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-stdutils/2011-10-01/cl-stdutils-20111001-git.tgz"; + sha256 = "16vxxphqdq8264x0aanm36x9r6d3ci1gjf4vf46mwl59gcff4wcj"; + system = "stdutils"; + asd = "stdutils"; + } + ); + systems = [ "stdutils" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stealth-mixin = ( + build-asdf-system { + pname = "stealth-mixin"; + version = "20211020-git"; + asds = [ "stealth-mixin" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stealth-mixin/2021-10-20/stealth-mixin-20211020-git.tgz"; + sha256 = "0ar9cdmbmdnqz1ywpw34n47hlh0vqmb6pl76f5vbfgip3c81xwyi"; + system = "stealth-mixin"; + asd = "stealth-mixin"; + } + ); + systems = [ "stealth-mixin" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stefil = ( + build-asdf-system { + pname = "stefil"; + version = "20181210-git"; + asds = [ "stefil" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stefil/2018-12-10/stefil-20181210-git.tgz"; + sha256 = "0bqz64q2szzhf91zyqyssmvrz7da6442rs01808pf3wrdq28bclh"; + system = "stefil"; + asd = "stefil"; + } + ); + systems = [ "stefil" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "metabang-bind" self) + (getAttr "swank" self) + ]; + meta = { }; + } + ); + stefil_plus = ( + build-asdf-system { + pname = "stefil+"; + version = "20211209-git"; + asds = [ "stefil+" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stefil-/2021-12-09/stefil--20211209-git.tgz"; + sha256 = "039jjhcb3ka6vag39hz5v1bi81x444rqj6rb3np5qbm07dh1aij0"; + system = "stefil+"; + asd = "stefil+"; + } + ); + systems = [ "stefil+" ]; + lispLibs = [ + (getAttr "asdf-package-system" self) + (getAttr "gt" self) + (getAttr "metabang-bind" self) + (getAttr "stefil" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stefil-test = ( + build-asdf-system { + pname = "stefil-test"; + version = "20181210-git"; + asds = [ "stefil-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stefil/2018-12-10/stefil-20181210-git.tgz"; + sha256 = "0bqz64q2szzhf91zyqyssmvrz7da6442rs01808pf3wrdq28bclh"; + system = "stefil-test"; + asd = "stefil"; + } + ); + systems = [ "stefil-test" ]; + lispLibs = [ (getAttr "stefil" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stem = ( + build-asdf-system { + pname = "stem"; + version = "20150608-git"; + asds = [ "stem" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stem/2015-06-08/stem-20150608-git.tgz"; + sha256 = "0a2kr09c3qcwg16n8rm15qgy5p9l6z4m72jray0846hqbnji77mp"; + system = "stem"; + asd = "stem"; + } + ); + systems = [ "stem" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stepster = ( + build-asdf-system { + pname = "stepster"; + version = "20241012-git"; + asds = [ "stepster" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stepster/2024-10-12/stepster-20241012-git.tgz"; + sha256 = "027psal692mvpaj8bzp8fkkrsy5pgyrg8sr21xgc4m8ypp0shvw3"; + system = "stepster"; + asd = "stepster"; + } + ); + systems = [ "stepster" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-reexport" self) + (getAttr "clss" self) + (getAttr "dexador" self) + (getAttr "jonathan" self) + (getAttr "plump" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stl = ( + build-asdf-system { + pname = "stl"; + version = "20171019-git"; + asds = [ "stl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stl/2017-10-19/stl-20171019-git.tgz"; + sha256 = "12v11bsarlnx5k930gx116wbgv41kwm45ysdikq3am4x3lqsjz2n"; + system = "stl"; + asd = "stl"; + } + ); + systems = [ "stl" ]; + lispLibs = [ (getAttr "_3d-vectors" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stmx = ( + build-asdf-system { + pname = "stmx"; + version = "stable-95f7dea8-git"; + asds = [ "stmx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stmx/2024-10-12/stmx-stable-95f7dea8-git.tgz"; + sha256 = "1qq25y79casaa56a76gj9hk2f3hjcc5z3f4na4vy3sw99km54hn9"; + system = "stmx"; + asd = "stmx"; + } + ); + systems = [ "stmx" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "closer-mop" self) + (getAttr "log4cl" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stmx_dot_test = ( + build-asdf-system { + pname = "stmx.test"; + version = "stable-95f7dea8-git"; + asds = [ "stmx.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stmx/2024-10-12/stmx-stable-95f7dea8-git.tgz"; + sha256 = "1qq25y79casaa56a76gj9hk2f3hjcc5z3f4na4vy3sw99km54hn9"; + system = "stmx.test"; + asd = "stmx.test"; + } + ); + systems = [ "stmx.test" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "fiveam" self) + (getAttr "log4cl" self) + (getAttr "stmx" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stopclock = ( + build-asdf-system { + pname = "stopclock"; + version = "v1.0.2"; + asds = [ "stopclock" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stopclock/2023-10-21/stopclock-v1.0.2.tgz"; + sha256 = "1p5lygznfasad1sw8whd2bg9bwi3z7nbncr3samd55nsi5yr3hfd"; + system = "stopclock"; + asd = "stopclock"; + } + ); + systems = [ "stopclock" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + str = ( + build-asdf-system { + pname = "str"; + version = "20241012-git"; + asds = [ "str" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-str/2024-10-12/cl-str-20241012-git.tgz"; + sha256 = "1c9vcrm4gy3ljwnzjimsxswszfs2im1a4iqalpn1mhv8ddwavb2j"; + system = "str"; + asd = "str"; + } + ); + systems = [ "str" ]; + lispLibs = [ + (getAttr "cl-change-case" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-ppcre-unicode" self) + ]; + meta = { }; + } + ); + str_dot_test = ( + build-asdf-system { + pname = "str.test"; + version = "20241012-git"; + asds = [ "str.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-str/2024-10-12/cl-str-20241012-git.tgz"; + sha256 = "1c9vcrm4gy3ljwnzjimsxswszfs2im1a4iqalpn1mhv8ddwavb2j"; + system = "str.test"; + asd = "str.test"; + } + ); + systems = [ "str.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + strict-function = ( + build-asdf-system { + pname = "strict-function"; + version = "20211020-git"; + asds = [ "strict-function" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/strict-function/2021-10-20/strict-function-20211020-git.tgz"; + sha256 = "176l5024qa72my7wiag0w6mmwys1q4yk6b4n944378qbqr2zpq2a"; + system = "strict-function"; + asd = "strict-function"; + } + ); + systems = [ "strict-function" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + string-case = ( + build-asdf-system { + pname = "string-case"; + version = "20180711-git"; + asds = [ "string-case" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/string-case/2018-07-11/string-case-20180711-git.tgz"; + sha256 = "1n5i3yh0h5s636rcnwn7jwqy3rjflikra04lymimhpcshhjsk0md"; + system = "string-case"; + asd = "string-case"; + } + ); + systems = [ "string-case" ]; + lispLibs = [ ]; + meta = { }; + } + ); + string-escape = ( + build-asdf-system { + pname = "string-escape"; + version = "20150407-http"; + asds = [ "string-escape" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/string-escape/2015-04-07/string-escape-20150407-http.tgz"; + sha256 = "0r7b699332hy3qj17jax9jdhq4jx6rbw5xf0j43bwg79wddk0rq3"; + system = "string-escape"; + asd = "string-escape"; + } + ); + systems = [ "string-escape" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stripe = ( + build-asdf-system { + pname = "stripe"; + version = "20241012-git"; + asds = [ "stripe" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stripe/2024-10-12/stripe-20241012-git.tgz"; + sha256 = "1ng1381pg0mj1ba0ndxvhaqmm0w64v0gq0qsxbfm9kr6hq46gsf9"; + system = "stripe"; + asd = "stripe"; + } + ); + systems = [ "stripe" ]; + lispLibs = [ + (getAttr "dexador" self) + (getAttr "golden-utils" self) + (getAttr "local-time" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stripe-against-the-modern-world = ( + build-asdf-system { + pname = "stripe-against-the-modern-world"; + version = "20221106-git"; + asds = [ "stripe-against-the-modern-world" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stripe-against-the-modern-world/2022-11-06/stripe-against-the-modern-world-20221106-git.tgz"; + sha256 = "1qp714y7b7vfdafirlphk02gixa4jffs0xgcy96fncxs6r2zq3q9"; + system = "stripe-against-the-modern-world"; + asd = "stripe-against-the-modern-world"; + } + ); + systems = [ "stripe-against-the-modern-world" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "dexador" self) + (getAttr "do-urlencode" self) + (getAttr "ironclad" self) + (getAttr "jonathan" self) + (getAttr "local-time" self) + (getAttr "ningle" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + structure-ext = ( + build-asdf-system { + pname = "structure-ext"; + version = "20211209-git"; + asds = [ "structure-ext" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; + sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; + system = "structure-ext"; + asd = "structure-ext"; + } + ); + systems = [ "structure-ext" ]; + lispLibs = [ + (getAttr "structure-ext_dot_as-class" self) + (getAttr "structure-ext_dot_left-arrow-accessors" self) + (getAttr "structure-ext_dot_make-instance" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + structure-ext_dot_as-class = ( + build-asdf-system { + pname = "structure-ext.as-class"; + version = "20211209-git"; + asds = [ "structure-ext.as-class" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; + sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; + system = "structure-ext.as-class"; + asd = "structure-ext.as-class"; + } + ); + systems = [ "structure-ext.as-class" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "jingoh_dot_documentizer" self) + (getAttr "lambda-fiddle" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + structure-ext_dot_as-class_dot_test = ( + build-asdf-system { + pname = "structure-ext.as-class.test"; + version = "20211209-git"; + asds = [ "structure-ext.as-class.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; + sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; + system = "structure-ext.as-class.test"; + asd = "structure-ext.as-class.test"; + } + ); + systems = [ "structure-ext.as-class.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "structure-ext_dot_as-class" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + structure-ext_dot_left-arrow-accessors = ( + build-asdf-system { + pname = "structure-ext.left-arrow-accessors"; + version = "20211209-git"; + asds = [ "structure-ext.left-arrow-accessors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; + sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; + system = "structure-ext.left-arrow-accessors"; + asd = "structure-ext.left-arrow-accessors"; + } + ); + systems = [ "structure-ext.left-arrow-accessors" ]; + lispLibs = [ (getAttr "jingoh_dot_documentizer" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + structure-ext_dot_left-arrow-accessors_dot_test = ( + build-asdf-system { + pname = "structure-ext.left-arrow-accessors.test"; + version = "20211209-git"; + asds = [ "structure-ext.left-arrow-accessors.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; + sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; + system = "structure-ext.left-arrow-accessors.test"; + asd = "structure-ext.left-arrow-accessors.test"; + } + ); + systems = [ "structure-ext.left-arrow-accessors.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "structure-ext_dot_left-arrow-accessors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + structure-ext_dot_make-instance = ( + build-asdf-system { + pname = "structure-ext.make-instance"; + version = "20211209-git"; + asds = [ "structure-ext.make-instance" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; + sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; + system = "structure-ext.make-instance"; + asd = "structure-ext.make-instance"; + } + ); + systems = [ "structure-ext.make-instance" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "jingoh_dot_documentizer" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + structure-ext_dot_make-instance_dot_test = ( + build-asdf-system { + pname = "structure-ext.make-instance.test"; + version = "20211209-git"; + asds = [ "structure-ext.make-instance.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/structure-ext/2021-12-09/structure-ext-20211209-git.tgz"; + sha256 = "1qhny1m0r2s9bkhr9z7psczykknmb62c32bwav4hgqm96rna1pkq"; + system = "structure-ext.make-instance.test"; + asd = "structure-ext.make-instance.test"; + } + ); + systems = [ "structure-ext.make-instance.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "structure-ext_dot_make-instance" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + structy-defclass = ( + build-asdf-system { + pname = "structy-defclass"; + version = "20170630-git"; + asds = [ "structy-defclass" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/structy-defclass/2017-06-30/structy-defclass-20170630-git.tgz"; + sha256 = "0fdlj45xzyghmg65dvs7ww7dxji84iid2y6rh9j77aip7v0l5q63"; + system = "structy-defclass"; + asd = "structy-defclass"; + } + ); + systems = [ "structy-defclass" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + studio-client = ( + build-asdf-system { + pname = "studio-client"; + version = "20231021-git"; + asds = [ "studio-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/studio-client/2023-10-21/studio-client-20231021-git.tgz"; + sha256 = "0wxakd5jd0y6h2ii4690qav7zna6iyamdyksw5zjyz4xmsg4by2l"; + system = "studio-client"; + asd = "studio-client"; + } + ); + systems = [ "studio-client" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "com_dot_inuoe_dot_jzon" self) + (getAttr "documentation-utils" self) + (getAttr "north-core" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + stumpwm = ( + build-asdf-system { + pname = "stumpwm"; + version = "20231021-git"; + asds = [ "stumpwm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stumpwm/2023-10-21/stumpwm-20231021-git.tgz"; + sha256 = "114kicsziqvm15x15yhc39j8qzv6gxz4wxc40xp968pprzr4a4d1"; + system = "stumpwm"; + asd = "stumpwm"; + } + ); + systems = [ "stumpwm" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "clx" self) + (getAttr "dynamic-mixins-swm" self) + ]; + meta = { }; + } + ); + stumpwm-tests = ( + build-asdf-system { + pname = "stumpwm-tests"; + version = "20231021-git"; + asds = [ "stumpwm-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/stumpwm/2023-10-21/stumpwm-20231021-git.tgz"; + sha256 = "114kicsziqvm15x15yhc39j8qzv6gxz4wxc40xp968pprzr4a4d1"; + system = "stumpwm-tests"; + asd = "stumpwm-tests"; + } + ); + systems = [ "stumpwm-tests" ]; + lispLibs = [ + (getAttr "fiasco" self) + (getAttr "stumpwm" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sucle = ( + build-asdf-system { + pname = "sucle"; + version = "20200427-git"; + asds = [ "sucle" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "sucle"; + asd = "sucle"; + } + ); + systems = [ "sucle" ]; + lispLibs = [ + (getAttr "aabbcc" self) + (getAttr "alexandria" self) + (getAttr "application" self) + (getAttr "black-tie" self) + (getAttr "camera-matrix" self) + (getAttr "cl-opengl" self) + (getAttr "control" self) + (getAttr "crud" self) + (getAttr "fps-independent-timestep" self) + (getAttr "glhelp" self) + (getAttr "image-utility" self) + (getAttr "livesupport" self) + (getAttr "ncurses-clone-for-lem" self) + (getAttr "nsb-cga" self) + (getAttr "quads" self) + (getAttr "scratch-buffer" self) + (getAttr "sucle-multiprocessing" self) + (getAttr "sucle-temp" self) + (getAttr "text-subsystem" self) + (getAttr "uncommon-lisp" self) + (getAttr "utility" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sucle-multiprocessing = ( + build-asdf-system { + pname = "sucle-multiprocessing"; + version = "20200427-git"; + asds = [ "sucle-multiprocessing" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "sucle-multiprocessing"; + asd = "sucle-multiprocessing"; + } + ); + systems = [ "sucle-multiprocessing" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-cpus" self) + (getAttr "lparallel" self) + (getAttr "uncommon-lisp" self) + (getAttr "utility" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sucle-serialize = ( + build-asdf-system { + pname = "sucle-serialize"; + version = "20200427-git"; + asds = [ "sucle-serialize" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "sucle-serialize"; + asd = "sucle-serialize"; + } + ); + systems = [ "sucle-serialize" ]; + lispLibs = [ + (getAttr "chipz" self) + (getAttr "cl-conspack" self) + (getAttr "salza2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sucle-temp = ( + build-asdf-system { + pname = "sucle-temp"; + version = "20200427-git"; + asds = [ "sucle-temp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "sucle-temp"; + asd = "sucle-temp"; + } + ); + systems = [ "sucle-temp" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sucle-test = ( + build-asdf-system { + pname = "sucle-test"; + version = "20200427-git"; + asds = [ "sucle-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "sucle-test"; + asd = "sucle-test"; + } + ); + systems = [ "sucle-test" ]; + lispLibs = [ + (getAttr "aabbcc" self) + (getAttr "alexandria" self) + (getAttr "application" self) + (getAttr "camera-matrix" self) + (getAttr "character-modifier-bits" self) + (getAttr "cl-opengl" self) + (getAttr "control" self) + (getAttr "deflazy" self) + (getAttr "fps-independent-timestep" self) + (getAttr "image-utility" self) + (getAttr "ncurses-clone-for-lem" self) + (getAttr "nsb-cga" self) + (getAttr "quads" self) + (getAttr "scratch-buffer" self) + (getAttr "sucle" self) + (getAttr "sucle-multiprocessing" self) + (getAttr "sucle-serialize" self) + (getAttr "text-subsystem" self) + (getAttr "uncommon-lisp" self) + (getAttr "window" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + surf = ( + build-asdf-system { + pname = "surf"; + version = "master-fe503896-git"; + asds = [ "surf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "surf"; + asd = "surf"; + } + ); + systems = [ "surf" ]; + lispLibs = [ (getAttr "geom-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + swank = ( + build-asdf-system { + pname = "swank"; + version = "v2.30"; + asds = [ "swank" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/slime/2024-10-12/slime-v2.30.tgz"; + sha256 = "0qb7m65gq0mbxfrdppkh3k4jn13i14i07ziga4r8b3rmrxhrmlv0"; + system = "swank"; + asd = "swank"; + } + ); + systems = [ "swank" ]; + lispLibs = [ ]; + meta = { }; + } + ); + swank-client = ( + build-asdf-system { + pname = "swank-client"; + version = "20230618-git"; + asds = [ "swank-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/swank-client/2023-06-18/swank-client-20230618-git.tgz"; + sha256 = "0sd0xblaxj8zi03acmfq4pwv84jcl04fvyp1jqlb7d6iq0mbxvan"; + system = "swank-client"; + asd = "swank-client"; + } + ); + systems = [ "swank-client" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "com_dot_google_dot_base" self) + (getAttr "swank" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + swank-crew = ( + build-asdf-system { + pname = "swank-crew"; + version = "20241012-git"; + asds = [ "swank-crew" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/swank-crew/2024-10-12/swank-crew-20241012-git.tgz"; + sha256 = "0v0gg9d74x28xw3n12nrvkdnnvz0m972l4rymfansfaawiqm7ssz"; + system = "swank-crew"; + asd = "swank-crew"; + } + ); + systems = [ "swank-crew" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "com_dot_google_dot_base" self) + (getAttr "swank-client" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + swank-protocol = ( + build-asdf-system { + pname = "swank-protocol"; + version = "20241012-git"; + asds = [ "swank-protocol" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/swank-protocol/2024-10-12/swank-protocol-20241012-git.tgz"; + sha256 = "0vqcdxp228fk3snay90ml33r1y03l5k05snq633f95his8ffxknl"; + system = "swank-protocol"; + asd = "swank-protocol"; + } + ); + systems = [ "swank-protocol" ]; + lispLibs = [ + (getAttr "swank" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + swank_dot_live = ( + build-asdf-system { + pname = "swank.live"; + version = "20160208-git"; + asds = [ "swank.live" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/swank.live/2016-02-08/swank.live-20160208-git.tgz"; + sha256 = "0p7jyf07symfan6lmbhd3r42kf5vrsbmmh9li0n1kky8rd6fhgls"; + system = "swank.live"; + asd = "swank.live"; + } + ); + systems = [ "swank.live" ]; + lispLibs = [ (getAttr "swank" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + swap-bytes = ( + build-asdf-system { + pname = "swap-bytes"; + version = "v1.2"; + asds = [ "swap-bytes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/swap-bytes/2019-11-30/swap-bytes-v1.2.tgz"; + sha256 = "1hw1v1lw26rifyznpnj1csphha9jgzwpiic16ni3pvs6hcsni9rz"; + system = "swap-bytes"; + asd = "swap-bytes"; + } + ); + systems = [ "swap-bytes" ]; + lispLibs = [ (getAttr "trivial-features" self) ]; + meta = { }; + } + ); + sxql = ( + build-asdf-system { + pname = "sxql"; + version = "20241012-git"; + asds = [ "sxql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sxql/2024-10-12/sxql-20241012-git.tgz"; + sha256 = "11x4qgdwbddbk0a8avrirp1ksmphfxlimirfwvmiwi0jc4zd5csa"; + system = "sxql"; + asd = "sxql"; + } + ); + systems = [ "sxql" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-annot" self) + (getAttr "cl-package-locks" self) + (getAttr "iterate" self) + (getAttr "named-readtables" self) + (getAttr "split-sequence" self) + (getAttr "trivia" self) + (getAttr "trivial-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sxql-composer = ( + build-asdf-system { + pname = "sxql-composer"; + version = "20200325-git"; + asds = [ "sxql-composer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sxql-composer/2020-03-25/sxql-composer-20200325-git.tgz"; + sha256 = "1agkrj3ymskzc3c7pxbrj123d1kygjqcls145m0ap3i07q96hh1r"; + system = "sxql-composer"; + asd = "sxql-composer"; + } + ); + systems = [ "sxql-composer" ]; + lispLibs = [ (getAttr "sxql" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sxql-test = ( + build-asdf-system { + pname = "sxql-test"; + version = "20241012-git"; + asds = [ "sxql-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sxql/2024-10-12/sxql-20241012-git.tgz"; + sha256 = "11x4qgdwbddbk0a8avrirp1ksmphfxlimirfwvmiwi0jc4zd5csa"; + system = "sxql-test"; + asd = "sxql-test"; + } + ); + systems = [ "sxql-test" ]; + lispLibs = [ + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "sxql" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sycamore = ( + build-asdf-system { + pname = "sycamore"; + version = "20211020-git"; + asds = [ "sycamore" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sycamore/2021-10-20/sycamore-20211020-git.tgz"; + sha256 = "0icw7fba1ch51w24f4sinvy4xg3zc7zif0aqcjfrzxj14x108hai"; + system = "sycamore"; + asd = "sycamore"; + } + ); + systems = [ "sycamore" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-fuzz" self) + (getAttr "cl-ppcre" self) + (getAttr "lisp-unit" self) + ]; + meta = { }; + } + ); + symath = ( + build-asdf-system { + pname = "symath"; + version = "20241012-git"; + asds = [ "symath" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/symath/2024-10-12/symath-20241012-git.tgz"; + sha256 = "1bxggf9kn4bhx877hyj4kpr76p47d8cd35lgv224hri5211fqyaz"; + system = "symath"; + asd = "symath"; + } + ); + systems = [ "symath" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + symbol-munger = ( + build-asdf-system { + pname = "symbol-munger"; + version = "20220220-git"; + asds = [ "symbol-munger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/symbol-munger/2022-02-20/symbol-munger-20220220-git.tgz"; + sha256 = "16fshnxp9212503z1vjlmx5pafv14bzpihn486x1ljakqjigfnfz"; + system = "symbol-munger"; + asd = "symbol-munger"; + } + ); + systems = [ "symbol-munger" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + ]; + meta = { }; + } + ); + symbol-namespaces = ( + build-asdf-system { + pname = "symbol-namespaces"; + version = "1.0"; + asds = [ "symbol-namespaces" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/symbol-namespaces/2013-01-28/symbol-namespaces-1.0.tgz"; + sha256 = "0rw4ndhg669rkpjmv5n0zh69bzar60zn3bb4vs5ijgvxyl5f7xp1"; + system = "symbol-namespaces"; + asd = "symbol-namespaces"; + } + ); + systems = [ "symbol-namespaces" ]; + lispLibs = [ (getAttr "map-bind" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + synonyms = ( + build-asdf-system { + pname = "synonyms"; + version = "20230618-git"; + asds = [ "synonyms" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/synonyms/2023-06-18/synonyms-20230618-git.tgz"; + sha256 = "1373m0h765r60lif0jz3frqbq7phrm2jhc30b5dh51spd7732v3x"; + system = "synonyms"; + asd = "synonyms"; + } + ); + systems = [ "synonyms" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + sysexits = ( + build-asdf-system { + pname = "sysexits"; + version = "20220707-git"; + asds = [ "sysexits" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-sysexits/2022-07-07/cl-sysexits-20220707-git.tgz"; + sha256 = "1khkj0qqvmgylnvl32sks8v3iabasbcr9sj9zl89xh3rajc67z73"; + system = "sysexits"; + asd = "sysexits"; + } + ); + systems = [ "sysexits" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + system-locale = ( + build-asdf-system { + pname = "system-locale"; + version = "20241012-git"; + asds = [ "system-locale" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/system-locale/2024-10-12/system-locale-20241012-git.tgz"; + sha256 = "1q91vyvsh787fz3j49lmyw2lx85288cmamb11h99wdmbmf61rdgr"; + system = "system-locale"; + asd = "system-locale"; + } + ); + systems = [ "system-locale" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + t-clack-handler-hunchentoot = ( + build-asdf-system { + pname = "t-clack-handler-hunchentoot"; + version = "20241012-git"; + asds = [ "t-clack-handler-hunchentoot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; + sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; + system = "t-clack-handler-hunchentoot"; + asd = "t-clack-handler-hunchentoot"; + } + ); + systems = [ "t-clack-handler-hunchentoot" ]; + lispLibs = [ + (getAttr "clack-handler-hunchentoot" self) + (getAttr "clack-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + t-clack-handler-toot = ( + build-asdf-system { + pname = "t-clack-handler-toot"; + version = "20241012-git"; + asds = [ "t-clack-handler-toot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; + sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; + system = "t-clack-handler-toot"; + asd = "t-clack-handler-toot"; + } + ); + systems = [ "t-clack-handler-toot" ]; + lispLibs = [ + (getAttr "clack-handler-toot" self) + (getAttr "clack-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + t-clack-handler-wookie = ( + build-asdf-system { + pname = "t-clack-handler-wookie"; + version = "20241012-git"; + asds = [ "t-clack-handler-wookie" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clack/2024-10-12/clack-20241012-git.tgz"; + sha256 = "0dljkfxdypn50d6jlssl79ag072r7lcdhfy771hna0ihxii8vsm3"; + system = "t-clack-handler-wookie"; + asd = "t-clack-handler-wookie"; + } + ); + systems = [ "t-clack-handler-wookie" ]; + lispLibs = [ (getAttr "clack-test" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ta2 = ( + build-asdf-system { + pname = "ta2"; + version = "master-fe503896-git"; + asds = [ "ta2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "ta2"; + asd = "ta2"; + } + ); + systems = [ "ta2" ]; + lispLibs = [ (getAttr "gwl-graphics" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tagger = ( + build-asdf-system { + pname = "tagger"; + version = "20200715-git"; + asds = [ "tagger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tagger/2020-07-15/tagger-20200715-git.tgz"; + sha256 = "1mxkr5hx8p4rxc7vajgrpl49zh018wyspvww5fg50164if0n7j2q"; + system = "tagger"; + asd = "tagger"; + } + ); + systems = [ "tagger" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + taglib = ( + build-asdf-system { + pname = "taglib"; + version = "20241012-git"; + asds = [ "taglib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/taglib/2024-10-12/taglib-20241012-git.tgz"; + sha256 = "1jhi38g2ngmbsv71chxyavgf4fzb64nr7z648ia01qxii0435csb"; + system = "taglib"; + asd = "taglib"; + } + ); + systems = [ "taglib" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "flexi-streams" self) + (getAttr "optima" self) + (getAttr "optima_dot_ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + taglib-tests = ( + build-asdf-system { + pname = "taglib-tests"; + version = "20241012-git"; + asds = [ "taglib-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/taglib/2024-10-12/taglib-20241012-git.tgz"; + sha256 = "1jhi38g2ngmbsv71chxyavgf4fzb64nr7z648ia01qxii0435csb"; + system = "taglib-tests"; + asd = "taglib-tests"; + } + ); + systems = [ "taglib-tests" ]; + lispLibs = [ + (getAttr "chanl" self) + (getAttr "cl-fad" self) + (getAttr "taglib" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tailrec = ( + build-asdf-system { + pname = "tailrec"; + version = "20210807-git"; + asds = [ "tailrec" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tailrec/2021-08-07/tailrec-20210807-git.tgz"; + sha256 = "1h8m2npdzd2cpnl75pvv4yvvfwxa7kl6qvalc9s0y4yws0kaih3i"; + system = "tailrec"; + asd = "tailrec"; + } + ); + systems = [ "tailrec" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-macroexpand-all" self) + (getAttr "trivial-with-current-source-form" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + talcl = ( + build-asdf-system { + pname = "talcl"; + version = "20180228-git"; + asds = [ "talcl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/talcl/2018-02-28/talcl-20180228-git.tgz"; + sha256 = "18pm3vz82dwcckhp4lkwjv8431hkdj3ghxb4v5qdjsyw2jm56v1p"; + system = "talcl"; + asd = "talcl"; + } + ); + systems = [ "talcl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "buildnode" self) + (getAttr "cl-ppcre" self) + (getAttr "cxml" self) + (getAttr "iterate" self) + (getAttr "symbol-munger" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + talcl-examples = ( + build-asdf-system { + pname = "talcl-examples"; + version = "20180228-git"; + asds = [ "talcl-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/talcl/2018-02-28/talcl-20180228-git.tgz"; + sha256 = "18pm3vz82dwcckhp4lkwjv8431hkdj3ghxb4v5qdjsyw2jm56v1p"; + system = "talcl-examples"; + asd = "talcl"; + } + ); + systems = [ "talcl-examples" ]; + lispLibs = [ + (getAttr "buildnode-xhtml" self) + (getAttr "talcl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + talcl-speed-tests = ( + build-asdf-system { + pname = "talcl-speed-tests"; + version = "20180228-git"; + asds = [ "talcl-speed-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/talcl/2018-02-28/talcl-20180228-git.tgz"; + sha256 = "18pm3vz82dwcckhp4lkwjv8431hkdj3ghxb4v5qdjsyw2jm56v1p"; + system = "talcl-speed-tests"; + asd = "talcl"; + } + ); + systems = [ "talcl-speed-tests" ]; + lispLibs = [ + (getAttr "buildnode-xhtml" self) + (getAttr "lisp-unit2" self) + (getAttr "talcl" self) + (getAttr "talcl-examples" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + talcl-test = ( + build-asdf-system { + pname = "talcl-test"; + version = "20180228-git"; + asds = [ "talcl-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/talcl/2018-02-28/talcl-20180228-git.tgz"; + sha256 = "18pm3vz82dwcckhp4lkwjv8431hkdj3ghxb4v5qdjsyw2jm56v1p"; + system = "talcl-test"; + asd = "talcl"; + } + ); + systems = [ "talcl-test" ]; + lispLibs = [ + (getAttr "buildnode-xhtml" self) + (getAttr "lisp-unit2" self) + (getAttr "talcl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tap-unit-test = ( + build-asdf-system { + pname = "tap-unit-test"; + version = "20171227-git"; + asds = [ "tap-unit-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tap-unit-test/2017-12-27/tap-unit-test-20171227-git.tgz"; + sha256 = "1fzsnpng7y4sghasl29sjicbs4v6m5mgfj8wf2izhhcn1hbhr694"; + system = "tap-unit-test"; + asd = "tap-unit-test"; + } + ); + systems = [ "tap-unit-test" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tar = ( + build-asdf-system { + pname = "tar"; + version = "20230618-git"; + asds = [ "tar" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tar/2023-06-18/cl-tar-20230618-git.tgz"; + sha256 = "0wp23cs3i6a89dibifiz6559la5nk58d1n17xvbxq4nrl8cqsllf"; + system = "tar"; + asd = "tar"; + } + ); + systems = [ "tar" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "local-time" self) + (getAttr "split-sequence" self) + (getAttr "tar-file" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tar-file = ( + build-asdf-system { + pname = "tar-file"; + version = "20220220-git"; + asds = [ "tar-file" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tar-file/2022-02-20/cl-tar-file-20220220-git.tgz"; + sha256 = "0i8j05fkgdqy4c4pqj0c68sh4s3klpx9kc5wp73qwzrl3xqd2svy"; + system = "tar-file"; + asd = "tar-file"; + } + ); + systems = [ "tar-file" ]; + lispLibs = [ + (getAttr "_40ants-doc" self) + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "chipz" self) + (getAttr "flexi-streams" self) + (getAttr "salza2" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + targa = ( + build-asdf-system { + pname = "targa"; + version = "20181018-git"; + asds = [ "targa" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/targa/2018-10-18/targa-20181018-git.tgz"; + sha256 = "0fslb2alp4pfmp8md2q89xh8n43r8awwf343wfvkywwqdnls2zws"; + system = "targa"; + asd = "targa"; + } + ); + systems = [ "targa" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tasty = ( + build-asdf-system { + pname = "tasty"; + version = "master-fe503896-git"; + asds = [ "tasty" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "tasty"; + asd = "tasty"; + } + ); + systems = [ "tasty" ]; + lispLibs = [ + (getAttr "gwl-graphics" self) + (getAttr "tree" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tclcs-code = ( + build-asdf-system { + pname = "tclcs-code"; + version = "20210124-git"; + asds = [ "tclcs-code" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tclcs-code/2021-01-24/tclcs-code-20210124-git.tgz"; + sha256 = "0p0g8shy284sj9ncq27zn8yj7xsrdcg2aiy2q783l6sl2ip6nfxa"; + system = "tclcs-code"; + asd = "tclcs-code"; + } + ); + systems = [ "tclcs-code" ]; + lispLibs = [ (getAttr "trivial-custom-debugger" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tcod = ( + build-asdf-system { + pname = "tcod"; + version = "20231021-git"; + asds = [ "tcod" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-tcod/2023-10-21/cl-tcod-20231021-git.tgz"; + sha256 = "1r4ip16dlzr56p94b0grw6nmkykbmgb04jsqdvgl1ypcmbpfr3i1"; + system = "tcod"; + asd = "tcod"; + } + ); + systems = [ "tcod" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-libffi" self) + (getAttr "defstar" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + teddy = ( + build-asdf-system { + pname = "teddy"; + version = "20241012-git"; + asds = [ "teddy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/teddy/2024-10-12/teddy-20241012-git.tgz"; + sha256 = "0qg83khyny5pw9lk3ysid32wl1wds43ja35qx72mxpli3nhj7nhq"; + system = "teddy"; + asd = "teddy"; + } + ); + systems = [ "teddy" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "asdf-finalizers" self) + (getAttr "cl-ascii-table" self) + (getAttr "eazy-gnuplot" self) + (getAttr "hu_dot_dwim_dot_def" self) + (getAttr "lhstats" self) + (getAttr "list-of" self) + (getAttr "rutils" self) + (getAttr "simplified-types" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + teepeedee2 = ( + build-asdf-system { + pname = "teepeedee2"; + version = "20230214-git"; + asds = [ "teepeedee2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/teepeedee2/2023-02-14/teepeedee2-20230214-git.tgz"; + sha256 = "16mfc1hcjdjcj1iiihdn9a725xry8hpvxijf5ic6yi4ydcv84pni"; + system = "teepeedee2"; + asd = "teepeedee2"; + } + ); + systems = [ "teepeedee2" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-cont" self) + (getAttr "cl-fad" self) + (getAttr "cl-irregsexp" self) + (getAttr "iterate" self) + (getAttr "parenscript" self) + (getAttr "trivial-backtrace" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + teepeedee2-test = ( + build-asdf-system { + pname = "teepeedee2-test"; + version = "20230214-git"; + asds = [ "teepeedee2-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/teepeedee2/2023-02-14/teepeedee2-20230214-git.tgz"; + sha256 = "16mfc1hcjdjcj1iiihdn9a725xry8hpvxijf5ic6yi4ydcv84pni"; + system = "teepeedee2-test"; + asd = "teepeedee2-test"; + } + ); + systems = [ "teepeedee2-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "teepeedee2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + telnetlib = ( + build-asdf-system { + pname = "telnetlib"; + version = "20141217-git"; + asds = [ "telnetlib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/telnetlib/2014-12-17/telnetlib-20141217-git.tgz"; + sha256 = "1gdf6i352qkmp27nqbv6qfi7sqn5wjzdaffh6ls1y5jznqh3nb0h"; + system = "telnetlib"; + asd = "telnetlib"; + } + ); + systems = [ "telnetlib" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + template = ( + build-asdf-system { + pname = "template"; + version = "20230618-git"; + asds = [ "template" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/template/2023-06-18/template-20230618-git.tgz"; + sha256 = "1ccnjawxwjqk8gavqga7waqrxv0pmncbycyfwylyly7a1c7zjadr"; + system = "template"; + asd = "template"; + } + ); + systems = [ "template" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "parameterized-function" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + template-function = ( + build-asdf-system { + pname = "template-function"; + version = "v0.0.1-git"; + asds = [ "template-function" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/template-function/2017-11-30/template-function-v0.0.1-git.tgz"; + sha256 = "1nq782cdi9vr3hgqqyzvvng2sbyc09biggwq4zp7k1vmqnm6qdaf"; + system = "template-function"; + asd = "template-function"; + } + ); + systems = [ "template-function" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "introspect-environment" self) + (getAttr "specialization-store" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + template-function-tests = ( + build-asdf-system { + pname = "template-function-tests"; + version = "v0.0.1-git"; + asds = [ "template-function-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/template-function/2017-11-30/template-function-v0.0.1-git.tgz"; + sha256 = "1nq782cdi9vr3hgqqyzvvng2sbyc09biggwq4zp7k1vmqnm6qdaf"; + system = "template-function-tests"; + asd = "template-function-tests"; + } + ); + systems = [ "template-function-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "template-function" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + temporal-functions = ( + build-asdf-system { + pname = "temporal-functions"; + version = "20171019-git"; + asds = [ "temporal-functions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/temporal-functions/2017-10-19/temporal-functions-20171019-git.tgz"; + sha256 = "03cbgw949g68n72nqp0nmjq9nx0kfz5zs6kpk0pwchy3i8bwf22j"; + system = "temporal-functions"; + asd = "temporal-functions"; + } + ); + systems = [ "temporal-functions" ]; + lispLibs = [ (getAttr "fn" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + temporary-file = ( + build-asdf-system { + pname = "temporary-file"; + version = "20150608-git"; + asds = [ "temporary-file" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/temporary-file/2015-06-08/temporary-file-20150608-git.tgz"; + sha256 = "0m38lncj6bmj7gwq8vp7l0gwzmk7pfasl4samzgl2fah8hzb064a"; + system = "temporary-file"; + asd = "temporary-file"; + } + ); + systems = [ "temporary-file" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "unit-test" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ten = ( + build-asdf-system { + pname = "ten"; + version = "20241012-git"; + asds = [ "ten" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ten/2024-10-12/ten-20241012-git.tgz"; + sha256 = "0zrbgyvc21gq8r507jm664zd4r9q206g2ah1yybwi32lgzify6nk"; + system = "ten"; + asd = "ten"; + } + ); + systems = [ "ten" ]; + lispLibs = [ + (getAttr "access" self) + (getAttr "cl-who" self) + (getAttr "esrap" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ten_dot_examples = ( + build-asdf-system { + pname = "ten.examples"; + version = "20241012-git"; + asds = [ "ten.examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ten/2024-10-12/ten-20241012-git.tgz"; + sha256 = "0zrbgyvc21gq8r507jm664zd4r9q206g2ah1yybwi32lgzify6nk"; + system = "ten.examples"; + asd = "ten.examples"; + } + ); + systems = [ "ten.examples" ]; + lispLibs = [ (getAttr "ten" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ten_dot_i18n_dot_cl-locale = ( + build-asdf-system { + pname = "ten.i18n.cl-locale"; + version = "20241012-git"; + asds = [ "ten.i18n.cl-locale" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ten/2024-10-12/ten-20241012-git.tgz"; + sha256 = "0zrbgyvc21gq8r507jm664zd4r9q206g2ah1yybwi32lgzify6nk"; + system = "ten.i18n.cl-locale"; + asd = "ten.i18n.cl-locale"; + } + ); + systems = [ "ten.i18n.cl-locale" ]; + lispLibs = [ + (getAttr "cl-locale" self) + (getAttr "ten" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ten_dot_i18n_dot_gettext = ( + build-asdf-system { + pname = "ten.i18n.gettext"; + version = "20241012-git"; + asds = [ "ten.i18n.gettext" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ten/2024-10-12/ten-20241012-git.tgz"; + sha256 = "0zrbgyvc21gq8r507jm664zd4r9q206g2ah1yybwi32lgzify6nk"; + system = "ten.i18n.gettext"; + asd = "ten.i18n.gettext"; + } + ); + systems = [ "ten.i18n.gettext" ]; + lispLibs = [ + (getAttr "gettext" self) + (getAttr "ten" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ten_dot_tests = ( + build-asdf-system { + pname = "ten.tests"; + version = "20241012-git"; + asds = [ "ten.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ten/2024-10-12/ten-20241012-git.tgz"; + sha256 = "0zrbgyvc21gq8r507jm664zd4r9q206g2ah1yybwi32lgzify6nk"; + system = "ten.tests"; + asd = "ten.tests"; + } + ); + systems = [ "ten.tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "ten" self) + (getAttr "ten_dot_examples" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + terminfo = ( + build-asdf-system { + pname = "terminfo"; + version = "20210124-git"; + asds = [ "terminfo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/terminfo/2021-01-24/terminfo-20210124-git.tgz"; + sha256 = "1nmin9rr6f75xdhxysba66xa1dh62fh27w9ad1cvmj0062armf6b"; + system = "terminfo"; + asd = "terminfo"; + } + ); + systems = [ "terminfo" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + terrable = ( + build-asdf-system { + pname = "terrable"; + version = "20231021-git"; + asds = [ "terrable" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/terrable/2023-10-21/terrable-20231021-git.tgz"; + sha256 = "03fjfdffr5lf12llqbf3d07dd87ykfyw525dxnwm6gpyvg49wlgl"; + system = "terrable"; + asd = "terrable"; + } + ); + systems = [ "terrable" ]; + lispLibs = [ + (getAttr "documentation-utils" self) + (getAttr "fast-io" self) + (getAttr "ieee-floats" self) + (getAttr "static-vectors" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tesseract-capi = ( + build-asdf-system { + pname = "tesseract-capi"; + version = "20201220-git"; + asds = [ "tesseract-capi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tesseract-capi/2020-12-20/tesseract-capi-20201220-git.tgz"; + sha256 = "1g8afgzbvfk80gi05nbwp9cmmrsqm5knhqi04v1cx556vrbp6ks1"; + system = "tesseract-capi"; + asd = "tesseract-capi"; + } + ); + systems = [ "tesseract-capi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + test-40ants-system = ( + build-asdf-system { + pname = "test-40ants-system"; + version = "20241012-git"; + asds = [ "test-40ants-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/40ants-asdf-system/2024-10-12/40ants-asdf-system-20241012-git.tgz"; + sha256 = "0wi575m0s0a9fvp1wy5ga760f71la16z1633qk6s2f87rwcjs8kw"; + system = "test-40ants-system"; + asd = "test-40ants-system"; + } + ); + systems = [ "test-40ants-system" ]; + lispLibs = [ (getAttr "_40ants-asdf-system" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + test-gadgets = ( + build-asdf-system { + pname = "test-gadgets"; + version = "20241012-git"; + asds = [ "test-gadgets" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gadgets/2024-10-12/gadgets-20241012-git.tgz"; + sha256 = "1ba4gj8lh3ihbb66xiz7hc8cdg3gvi3q20w32nmsqdch956is34k"; + system = "test-gadgets"; + asd = "test-gadgets"; + } + ); + systems = [ "test-gadgets" ]; + lispLibs = [ + (getAttr "gadgets" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + test-paren6 = ( + build-asdf-system { + pname = "test-paren6"; + version = "20220331-git"; + asds = [ "test-paren6" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/paren6/2022-03-31/paren6-20220331-git.tgz"; + sha256 = "0m7z7zkc1vrwmp68f3yx0mdsb0j45dmw3iddnbvf94dpv8aywwpx"; + system = "test-paren6"; + asd = "test-paren6"; + } + ); + systems = [ "test-paren6" ]; + lispLibs = [ + (getAttr "external-program" self) + (getAttr "paren6" self) + (getAttr "parenscript" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + test-serial-system = ( + build-asdf-system { + pname = "test-serial-system"; + version = "20170403-git"; + asds = [ "test-serial-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/asdf-dependency-grovel/2017-04-03/asdf-dependency-grovel-20170403-git.tgz"; + sha256 = "1y4kdqsda4ira4r9dws6kxzzv6mg45q3lkmb2c9mg9q7ksc5glif"; + system = "test-serial-system"; + asd = "test-serial-system"; + } + ); + systems = [ "test-serial-system" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + test-utils = ( + build-asdf-system { + pname = "test-utils"; + version = "20200610-git"; + asds = [ "test-utils" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/test-utils/2020-06-10/test-utils-20200610-git.tgz"; + sha256 = "036a8wvs37lnsf9dy3c810qk54963v7hnxx0zas25b50ikcmiqm5"; + system = "test-utils"; + asd = "test-utils"; + } + ); + systems = [ "test-utils" ]; + lispLibs = [ + (getAttr "agnostic-lizard" self) + (getAttr "alexandria" self) + (getAttr "cl-quickcheck" self) + (getAttr "prove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + test_dot_eager-future2 = ( + build-asdf-system { + pname = "test.eager-future2"; + version = "20191130-git"; + asds = [ "test.eager-future2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/eager-future2/2019-11-30/eager-future2-20191130-git.tgz"; + sha256 = "1qs1bv3m0ki8l5czhsflxcryh22r9d9g9a3a3b0cr0pl954q5rld"; + system = "test.eager-future2"; + asd = "test.eager-future2"; + } + ); + systems = [ "test.eager-future2" ]; + lispLibs = [ + (getAttr "eager-future2" self) + (getAttr "eos" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + test_dot_vas-string-metrics = ( + build-asdf-system { + pname = "test.vas-string-metrics"; + version = "20211209-git"; + asds = [ "test.vas-string-metrics" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vas-string-metrics/2021-12-09/vas-string-metrics-20211209-git.tgz"; + sha256 = "1yvkwc939dckv070nlgqfj5ys9ii2rm32m5wfx7qxdjrb4n19sx9"; + system = "test.vas-string-metrics"; + asd = "test.vas-string-metrics"; + } + ); + systems = [ "test.vas-string-metrics" ]; + lispLibs = [ (getAttr "vas-string-metrics" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + testbild = ( + build-asdf-system { + pname = "testbild"; + version = "20101207-git"; + asds = [ "testbild" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/testbild/2010-12-07/testbild-20101207-git.tgz"; + sha256 = "024b6rlgljcjazwg302zkdmkpxs2hirjg7g39ypppz81ns2v65sw"; + system = "testbild"; + asd = "testbild"; + } + ); + systems = [ "testbild" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "graylex" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + testbild-test = ( + build-asdf-system { + pname = "testbild-test"; + version = "20101207-git"; + asds = [ "testbild-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/testbild/2010-12-07/testbild-20101207-git.tgz"; + sha256 = "024b6rlgljcjazwg302zkdmkpxs2hirjg7g39ypppz81ns2v65sw"; + system = "testbild-test"; + asd = "testbild-test"; + } + ); + systems = [ "testbild-test" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-heredoc" self) + (getAttr "testbild" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + testiere = ( + build-asdf-system { + pname = "testiere"; + version = "20241012-git"; + asds = [ "testiere" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/testiere/2024-10-12/testiere-20241012-git.tgz"; + sha256 = "0sfsk7i5kxk8s1273i9vwz49hak0qdrr9asq70kdiwq0lfd56kgg"; + system = "testiere"; + asd = "testiere"; + } + ); + systems = [ "testiere" ]; + lispLibs = [ (getAttr "trivia" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + texp = ( + build-asdf-system { + pname = "texp"; + version = "20151218-git"; + asds = [ "texp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/texp/2015-12-18/texp-20151218-git.tgz"; + sha256 = "1sbll7jwmzd86hg0zva8r7db2565nnliasv2x6rkrm9xl97q0kg5"; + system = "texp"; + asd = "texp"; + } + ); + systems = [ "texp" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + text-query = ( + build-asdf-system { + pname = "text-query"; + version = "1.1"; + asds = [ "text-query" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/text-query/2011-11-05/text-query-1.1.tgz"; + sha256 = "082xqpfchmg2752m1lw78q6c0z3walzsmqk8gl6qnj6bdwbhf4dm"; + system = "text-query"; + asd = "text-query"; + } + ); + systems = [ "text-query" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + text-subsystem = ( + build-asdf-system { + pname = "text-subsystem"; + version = "20200427-git"; + asds = [ "text-subsystem" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "text-subsystem"; + asd = "text-subsystem"; + } + ); + systems = [ "text-subsystem" ]; + lispLibs = [ + (getAttr "application" self) + (getAttr "deflazy" self) + (getAttr "image-utility" self) + (getAttr "nsb-cga" self) + (getAttr "quads" self) + (getAttr "sucle-temp" self) + (getAttr "utility" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + text-subsystem-generate-font = ( + build-asdf-system { + pname = "text-subsystem-generate-font"; + version = "20200427-git"; + asds = [ "text-subsystem-generate-font" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "text-subsystem-generate-font"; + asd = "text-subsystem-generate-font"; + } + ); + systems = [ "text-subsystem-generate-font" ]; + lispLibs = [ + (getAttr "cl-freetype2" self) + (getAttr "opticl" self) + (getAttr "utility" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + textery = ( + build-asdf-system { + pname = "textery"; + version = "20201220-git"; + asds = [ "textery" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/textery/2020-12-20/textery-20201220-git.tgz"; + sha256 = "0v8zk1s18fi462qwvjbci8nikgs5wqjpl97ckfk0spvhybrdgwcc"; + system = "textery"; + asd = "textery"; + } + ); + systems = [ "textery" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "str" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + the-cost-of-nothing = ( + build-asdf-system { + pname = "the-cost-of-nothing"; + version = "20191130-git"; + asds = [ "the-cost-of-nothing" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/the-cost-of-nothing/2019-11-30/the-cost-of-nothing-20191130-git.tgz"; + sha256 = "1ccrglyr1wnnfp218w1qj7yfl4yzlxkki3hqaifi5axgbi5dmmh8"; + system = "the-cost-of-nothing"; + asd = "the-cost-of-nothing"; + } + ); + systems = [ "the-cost-of-nothing" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "local-time" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + thih-coalton = ( + build-asdf-system { + pname = "thih-coalton"; + version = "20241012-git"; + asds = [ "thih-coalton" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/coalton/2024-10-12/coalton-20241012-git.tgz"; + sha256 = "19flzjxf3y6pxm09bmr8bmiqbgh4f7d5jjbgx2cb3dckmgvvg1d7"; + system = "thih-coalton"; + asd = "thih-coalton"; + } + ); + systems = [ "thih-coalton" ]; + lispLibs = [ (getAttr "coalton" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + thnappy = ( + build-asdf-system { + pname = "thnappy"; + version = "20180831-git"; + asds = [ "thnappy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/thnappy/2018-08-31/thnappy-20180831-git.tgz"; + sha256 = "0p03w2mcc655gm9x3rpgixhap9l56imjyblkwv05rk6mjx7wfnrp"; + system = "thnappy"; + asd = "thnappy"; + } + ); + systems = [ "thnappy" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + thorn = ( + build-asdf-system { + pname = "thorn"; + version = "20150608-git"; + asds = [ "thorn" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/thorn/2015-06-08/thorn-20150608-git.tgz"; + sha256 = "1d4w5358yxgccna91pxz9526w932j5ig17gp19zysjxvca57hqy7"; + system = "thorn"; + asd = "thorn"; + } + ); + systems = [ "thorn" ]; + lispLibs = [ (getAttr "common-doc" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + thorn-doc = ( + build-asdf-system { + pname = "thorn-doc"; + version = "20150608-git"; + asds = [ "thorn-doc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/thorn/2015-06-08/thorn-20150608-git.tgz"; + sha256 = "1d4w5358yxgccna91pxz9526w932j5ig17gp19zysjxvca57hqy7"; + system = "thorn-doc"; + asd = "thorn-doc"; + } + ); + systems = [ "thorn-doc" ]; + lispLibs = [ (getAttr "thorn" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + thorn-test = ( + build-asdf-system { + pname = "thorn-test"; + version = "20150608-git"; + asds = [ "thorn-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/thorn/2015-06-08/thorn-20150608-git.tgz"; + sha256 = "1d4w5358yxgccna91pxz9526w932j5ig17gp19zysjxvca57hqy7"; + system = "thorn-test"; + asd = "thorn-test"; + } + ); + systems = [ "thorn-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "thorn" self) + (getAttr "thorn-doc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + thread-pool = ( + build-asdf-system { + pname = "thread-pool"; + version = "20120107-git"; + asds = [ "thread-pool" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/thread-pool/2012-01-07/thread-pool-20120107-git.tgz"; + sha256 = "0wi9l0m660332w9pnc3w08m5hlsry9s0cgc3rznb5kyap68iv847"; + system = "thread-pool"; + asd = "thread-pool"; + } + ); + systems = [ "thread-pool" ]; + lispLibs = [ + (getAttr "arnesi" self) + (getAttr "bordeaux-threads" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + thread_dot_comm_dot_rendezvous = ( + build-asdf-system { + pname = "thread.comm.rendezvous"; + version = "20121013-git"; + asds = [ "thread.comm.rendezvous" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/thread.comm.rendezvous/2012-10-13/thread.comm.rendezvous-20121013-git.tgz"; + sha256 = "16crdy09zm20iclgln1vj0psd8ifz4rqb6g9255p0d2rkjk2rgfx"; + system = "thread.comm.rendezvous"; + asd = "thread.comm.rendezvous"; + } + ); + systems = [ "thread.comm.rendezvous" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-annot" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + thread_dot_comm_dot_rendezvous_dot_test = ( + build-asdf-system { + pname = "thread.comm.rendezvous.test"; + version = "20121013-git"; + asds = [ "thread.comm.rendezvous.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/thread.comm.rendezvous/2012-10-13/thread.comm.rendezvous-20121013-git.tgz"; + sha256 = "16crdy09zm20iclgln1vj0psd8ifz4rqb6g9255p0d2rkjk2rgfx"; + system = "thread.comm.rendezvous.test"; + asd = "thread.comm.rendezvous.test"; + } + ); + systems = [ "thread.comm.rendezvous.test" ]; + lispLibs = [ + (getAttr "cl-test-more" self) + (getAttr "thread_dot_comm_dot_rendezvous" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tile-grid = ( + build-asdf-system { + pname = "tile-grid"; + version = "20220707-git"; + asds = [ "tile-grid" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tile-grid/2022-07-07/tile-grid-20220707-git.tgz"; + sha256 = "10sqiqspiljnk4i1v4w0dkr640cgf9nvkgmkaww3smmhyjsd9270"; + system = "tile-grid"; + asd = "tile-grid"; + } + ); + systems = [ "tile-grid" ]; + lispLibs = [ (getAttr "mfiano-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + time-interval = ( + build-asdf-system { + pname = "time-interval"; + version = "20190202-git"; + asds = [ "time-interval" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/time-interval/2019-02-02/time-interval-20190202-git.tgz"; + sha256 = "0dydlg42bwcd7sr57v8hhrd86n80d5cb5r6r2id0zyqbrijabdw5"; + system = "time-interval"; + asd = "time-interval"; + } + ); + systems = [ "time-interval" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + timer-wheel = ( + build-asdf-system { + pname = "timer-wheel"; + version = "20180228-git"; + asds = [ "timer-wheel" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/timer-wheel/2018-02-28/timer-wheel-20180228-git.tgz"; + sha256 = "12pc1dpnkwj43n1sdqhg8n8h0mb16zcx4wxly85b7bqf00s962bc"; + system = "timer-wheel"; + asd = "timer-wheel"; + } + ); + systems = [ "timer-wheel" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + timer-wheel_dot_examples = ( + build-asdf-system { + pname = "timer-wheel.examples"; + version = "20180228-git"; + asds = [ "timer-wheel.examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/timer-wheel/2018-02-28/timer-wheel-20180228-git.tgz"; + sha256 = "12pc1dpnkwj43n1sdqhg8n8h0mb16zcx4wxly85b7bqf00s962bc"; + system = "timer-wheel.examples"; + asd = "timer-wheel.examples"; + } + ); + systems = [ "timer-wheel.examples" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "timer-wheel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tinaa = ( + build-asdf-system { + pname = "tinaa"; + version = "20171227-git"; + asds = [ "tinaa" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tinaa/2017-12-27/tinaa-20171227-git.tgz"; + sha256 = "10r1ypxphs5h7xxkl7v7r9pi2wdz1ik948mp63006hn44j7s1sa1"; + system = "tinaa"; + asd = "tinaa"; + } + ); + systems = [ "tinaa" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "asdf-system-connections" self) + (getAttr "cl-containers" self) + (getAttr "cl-graph" self) + (getAttr "defsystem-compatibility" self) + (getAttr "dynamic-classes" self) + (getAttr "lml2" self) + (getAttr "metatilities" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tinaa-test = ( + build-asdf-system { + pname = "tinaa-test"; + version = "20171227-git"; + asds = [ "tinaa-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tinaa/2017-12-27/tinaa-20171227-git.tgz"; + sha256 = "10r1ypxphs5h7xxkl7v7r9pi2wdz1ik948mp63006hn44j7s1sa1"; + system = "tinaa-test"; + asd = "tinaa-test"; + } + ); + systems = [ "tinaa-test" ]; + lispLibs = [ + (getAttr "lift" self) + (getAttr "tinaa" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tiny-routes = ( + build-asdf-system { + pname = "tiny-routes"; + version = "20241012-git"; + asds = [ "tiny-routes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tiny-routes/2024-10-12/tiny-routes-20241012-git.tgz"; + sha256 = "1wswzz7d26ic9izls7pnkybm8ryf5j0ksv55gr6k5nji9x8r5jqx"; + system = "tiny-routes"; + asd = "tiny-routes"; + } + ); + systems = [ "tiny-routes" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tiny-routes-middleware-cookie = ( + build-asdf-system { + pname = "tiny-routes-middleware-cookie"; + version = "20241012-git"; + asds = [ "tiny-routes-middleware-cookie" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tiny-routes/2024-10-12/tiny-routes-20241012-git.tgz"; + sha256 = "1wswzz7d26ic9izls7pnkybm8ryf5j0ksv55gr6k5nji9x8r5jqx"; + system = "tiny-routes-middleware-cookie"; + asd = "tiny-routes-middleware-cookie"; + } + ); + systems = [ "tiny-routes-middleware-cookie" ]; + lispLibs = [ + (getAttr "cl-cookie" self) + (getAttr "tiny-routes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tm = ( + build-asdf-system { + pname = "tm"; + version = "v0.8"; + asds = [ "tm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tm/2018-02-28/tm-v0.8.tgz"; + sha256 = "0lhqg5jpkzni1vzni0nnw7jb8ick1pbp04gfij2iczbi82qsw8x1"; + system = "tm"; + asd = "tm"; + } + ); + systems = [ "tm" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tmpdir = ( + build-asdf-system { + pname = "tmpdir"; + version = "20200218-git"; + asds = [ "tmpdir" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tmpdir/2020-02-18/tmpdir-20200218-git.tgz"; + sha256 = "11yshmg2wyd75ywwfybklm131d5rdw246pg35a6ksndiq3w5n4k8"; + system = "tmpdir"; + asd = "tmpdir"; + } + ); + systems = [ "tmpdir" ]; + lispLibs = [ (getAttr "cl-fad" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tmpdir_dot_tests = ( + build-asdf-system { + pname = "tmpdir.tests"; + version = "20200218-git"; + asds = [ "tmpdir.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tmpdir/2020-02-18/tmpdir-20200218-git.tgz"; + sha256 = "11yshmg2wyd75ywwfybklm131d5rdw246pg35a6ksndiq3w5n4k8"; + system = "tmpdir.tests"; + asd = "tmpdir.tests"; + } + ); + systems = [ "tmpdir.tests" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "fiveam" self) + (getAttr "osicat" self) + (getAttr "tmpdir" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + toadstool = ( + build-asdf-system { + pname = "toadstool"; + version = "20130615-git"; + asds = [ "toadstool" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/toadstool/2013-06-15/toadstool-20130615-git.tgz"; + sha256 = "0njb1mdzk0247h87db90zv7bk40mw54pq8sj35l1dwa30d5yhi6r"; + system = "toadstool"; + asd = "toadstool"; + } + ); + systems = [ "toadstool" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + toadstool-tests = ( + build-asdf-system { + pname = "toadstool-tests"; + version = "20130615-git"; + asds = [ "toadstool-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/toadstool/2013-06-15/toadstool-20130615-git.tgz"; + sha256 = "0njb1mdzk0247h87db90zv7bk40mw54pq8sj35l1dwa30d5yhi6r"; + system = "toadstool-tests"; + asd = "toadstool-tests"; + } + ); + systems = [ "toadstool-tests" ]; + lispLibs = [ + (getAttr "stefil" self) + (getAttr "toadstool" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + toms419 = ( + build-asdf-system { + pname = "toms419"; + version = "20231021-git"; + asds = [ "toms419" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "toms419"; + asd = "toms419"; + } + ); + systems = [ "toms419" ]; + lispLibs = [ (getAttr "f2cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + toms715 = ( + build-asdf-system { + pname = "toms715"; + version = "20231021-git"; + asds = [ "toms715" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "toms715"; + asd = "toms715"; + } + ); + systems = [ "toms715" ]; + lispLibs = [ (getAttr "f2cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + toms717 = ( + build-asdf-system { + pname = "toms717"; + version = "20231021-git"; + asds = [ "toms717" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/f2cl/2023-10-21/f2cl-20231021-git.tgz"; + sha256 = "0ifwsal8kxsbi4xrn90z2smvbz393babl3j25n33fadjpfan2f1z"; + system = "toms717"; + asd = "toms717"; + } + ); + systems = [ "toms717" ]; + lispLibs = [ (getAttr "f2cl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + toot = ( + build-asdf-system { + pname = "toot"; + version = "20121125-git"; + asds = [ "toot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/toot/2012-11-25/toot-20121125-git.tgz"; + sha256 = "1235qhkjrg1mmy6kx1vhsqvgjjgc7hk2sjssapv7xr43m71n6ivx"; + system = "toot"; + asd = "toot"; + } + ); + systems = [ "toot" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "chunga" self) + (getAttr "cl_plus_ssl" self) + (getAttr "cl-base64" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "md5" self) + (getAttr "puri" self) + (getAttr "trivial-backtrace" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tooter = ( + build-asdf-system { + pname = "tooter"; + version = "20241012-git"; + asds = [ "tooter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tooter/2024-10-12/tooter-20241012-git.tgz"; + sha256 = "03ymavph34248lh18jycsky55dg83kjr6k5a9bib5wh2idswrfxp"; + system = "tooter"; + asd = "tooter"; + } + ); + systems = [ "tooter" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "documentation-utils" self) + (getAttr "drakma" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + torrents = ( + build-asdf-system { + pname = "torrents"; + version = "20241012-git"; + asds = [ "torrents" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-torrents/2024-10-12/cl-torrents-20241012-git.tgz"; + sha256 = "1xigzskksgn8pg18v2dncfapdn94zv0djr4yi8nmkqbv8ljx93l4"; + system = "torrents"; + asd = "torrents"; + } + ); + systems = [ "torrents" ]; + lispLibs = [ + (getAttr "access" self) + (getAttr "cl-ansi-text" self) + (getAttr "cl-readline" self) + (getAttr "cl-transmission" self) + (getAttr "clache" self) + (getAttr "dexador" self) + (getAttr "jonathan" self) + (getAttr "log4cl" self) + (getAttr "lparallel" self) + (getAttr "lquery" self) + (getAttr "mockingbird" self) + (getAttr "parse-float" self) + (getAttr "plump" self) + (getAttr "py-configparser" self) + (getAttr "replic" self) + (getAttr "str" self) + (getAttr "unix-opts" self) + (getAttr "x_dot_let-star" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + torrents-test = ( + build-asdf-system { + pname = "torrents-test"; + version = "20241012-git"; + asds = [ "torrents-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-torrents/2024-10-12/cl-torrents-20241012-git.tgz"; + sha256 = "1xigzskksgn8pg18v2dncfapdn94zv0djr4yi8nmkqbv8ljx93l4"; + system = "torrents-test"; + asd = "torrents-test"; + } + ); + systems = [ "torrents-test" ]; + lispLibs = [ + (getAttr "mockingbird" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "torrents" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + towers = ( + build-asdf-system { + pname = "towers"; + version = "20141217-git"; + asds = [ "towers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/towers/2014-12-17/towers-20141217-git.tgz"; + sha256 = "0r89z1hfb7kmj0a4qm7ih599hlin8rhxk6pb7nnvsdjgn436dkga"; + system = "towers"; + asd = "towers"; + } + ); + systems = [ "towers" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-glu" self) + (getAttr "cl-glut" self) + (getAttr "cl-opengl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trace-db = ( + build-asdf-system { + pname = "trace-db"; + version = "20230618-git"; + asds = [ "trace-db" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trace-db/2023-06-18/trace-db-20230618-git.tgz"; + sha256 = "1n2mj8nzd0c3clz5xjllajfad50i6yhir27i9q41r4sc5z1k0x63"; + system = "trace-db"; + asd = "trace-db"; + } + ); + systems = [ "trace-db" ]; + lispLibs = [ (getAttr "asdf-package-system" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + track-best = ( + build-asdf-system { + pname = "track-best"; + version = "20220220-git"; + asds = [ "track-best" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/track-best/2022-02-20/track-best-20220220-git.tgz"; + sha256 = "1f59bn57y1mdq18l1ji5q8yazv73g85y1mns2xzwbmx8sgxsa6pq"; + system = "track-best"; + asd = "track-best"; + } + ); + systems = [ "track-best" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trainable-object = ( + build-asdf-system { + pname = "trainable-object"; + version = "20191227-git"; + asds = [ "trainable-object" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trainable-object/2019-12-27/trainable-object-20191227-git.tgz"; + sha256 = "06hfv039xx5vwm3qpm4kwlzlxc4zxlfcpxnbbq8x12a32ngqykwm"; + system = "trainable-object"; + asd = "trainable-object"; + } + ); + systems = [ "trainable-object" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "serializable-object" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trainable-object_dot_test = ( + build-asdf-system { + pname = "trainable-object.test"; + version = "20191227-git"; + asds = [ "trainable-object.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trainable-object/2019-12-27/trainable-object-20191227-git.tgz"; + sha256 = "06hfv039xx5vwm3qpm4kwlzlxc4zxlfcpxnbbq8x12a32ngqykwm"; + system = "trainable-object.test"; + asd = "trainable-object.test"; + } + ); + systems = [ "trainable-object.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "trainable-object" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + transducers = ( + build-asdf-system { + pname = "transducers"; + version = "20241012-git"; + asds = [ "transducers" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-transducers/2024-10-12/cl-transducers-20241012-git.tgz"; + sha256 = "1n7g2fr5bxyq1axp3a1pw01c5v167njhd7i0gbpq35s1fxvqw6ik"; + system = "transducers"; + asd = "transducers"; + } + ); + systems = [ "transducers" ]; + lispLibs = [ (getAttr "sycamore" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + transducers-jzon = ( + build-asdf-system { + pname = "transducers-jzon"; + version = "20241012-git"; + asds = [ "transducers-jzon" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-transducers/2024-10-12/cl-transducers-20241012-git.tgz"; + sha256 = "1n7g2fr5bxyq1axp3a1pw01c5v167njhd7i0gbpq35s1fxvqw6ik"; + system = "transducers-jzon"; + asd = "transducers"; + } + ); + systems = [ "transducers-jzon" ]; + lispLibs = [ + (getAttr "com_dot_inuoe_dot_jzon" self) + (getAttr "transducers" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + transit = ( + build-asdf-system { + pname = "transit"; + version = "20241012-git"; + asds = [ "transit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-transit/2024-10-12/cl-transit-20241012-git.tgz"; + sha256 = "09rlajmcljl43n5866ackbdjkdz19sd12wzdzxnk2l7bjx3khqm4"; + system = "transit"; + asd = "transit"; + } + ); + systems = [ "transit" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bit-smasher" self) + (getAttr "cl-messagepack" self) + (getAttr "com_dot_inuoe_dot_jzon" self) + (getAttr "flexi-streams" self) + (getAttr "frugal-uuid" self) + (getAttr "fset" self) + (getAttr "local-time" self) + (getAttr "parse-float" self) + (getAttr "quri" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + transit-tests = ( + build-asdf-system { + pname = "transit-tests"; + version = "20241012-git"; + asds = [ "transit-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-transit/2024-10-12/cl-transit-20241012-git.tgz"; + sha256 = "09rlajmcljl43n5866ackbdjkdz19sd12wzdzxnk2l7bjx3khqm4"; + system = "transit-tests"; + asd = "transit-tests"; + } + ); + systems = [ "transit-tests" ]; + lispLibs = [ + (getAttr "dexador" self) + (getAttr "fiveam" self) + (getAttr "marshal" self) + (getAttr "transit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + translate = ( + build-asdf-system { + pname = "translate"; + version = "20180228-git"; + asds = [ "translate" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/translate/2018-02-28/translate-20180228-git.tgz"; + sha256 = "07bvdmj8x77k8pw24yhfp1xv9h40n5w717vgj3wmq703159kyjia"; + system = "translate"; + asd = "translate"; + } + ); + systems = [ "translate" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + translate-client = ( + build-asdf-system { + pname = "translate-client"; + version = "20180228-git"; + asds = [ "translate-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/translate-client/2018-02-28/translate-client-20180228-git.tgz"; + sha256 = "0mjzzahy5wrycik37dirwnvcd5bj5xm20cnw6cmzh0ncvb442mdx"; + system = "translate-client"; + asd = "translate-client"; + } + ); + systems = [ "translate-client" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "assoc-utils" self) + (getAttr "dexador" self) + (getAttr "quri" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + translators = ( + build-asdf-system { + pname = "translators"; + version = "master-fe503896-git"; + asds = [ "translators" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "translators"; + asd = "translators"; + } + ); + systems = [ "translators" ]; + lispLibs = [ (getAttr "gwl" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + transparent-wrap = ( + build-asdf-system { + pname = "transparent-wrap"; + version = "20200925-git"; + asds = [ "transparent-wrap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/transparent-wrap/2020-09-25/transparent-wrap-20200925-git.tgz"; + sha256 = "0ghva34ksdvczfwpjdaf97bkjxrp35fjqkxamyqf7fbadh4wmfqj"; + system = "transparent-wrap"; + asd = "transparent-wrap"; + } + ); + systems = [ "transparent-wrap" ]; + lispLibs = [ + (getAttr "fare-quasiquote-extras" self) + (getAttr "named-readtables" self) + (getAttr "optima" self) + (getAttr "trivial-arguments" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tree = ( + build-asdf-system { + pname = "tree"; + version = "master-fe503896-git"; + asds = [ "tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "tree"; + asd = "tree"; + } + ); + systems = [ "tree" ]; + lispLibs = [ (getAttr "gwl-graphics" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tree-search = ( + build-asdf-system { + pname = "tree-search"; + version = "0.0.1"; + asds = [ "tree-search" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tree-search/2020-12-20/tree-search-0.0.1.tgz"; + sha256 = "10qgd5yj3n2w4j6wsq1xly0hnpdi1bhhzpia4s1gpkywhglw84zq"; + system = "tree-search"; + asd = "tree-search"; + } + ); + systems = [ "tree-search" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + treedb = ( + build-asdf-system { + pname = "treedb"; + version = "20160825-git"; + asds = [ "treedb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/treedb/2016-08-25/treedb-20160825-git.tgz"; + sha256 = "02xsm4han0m0vj1j2ly2a6ncjcv7z8p3lcpkyj27xygag2vlchbq"; + system = "treedb"; + asd = "treedb"; + } + ); + systems = [ "treedb" ]; + lispLibs = [ (getAttr "cl-json" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + treedb_dot_doc = ( + build-asdf-system { + pname = "treedb.doc"; + version = "20160825-git"; + asds = [ "treedb.doc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/treedb/2016-08-25/treedb-20160825-git.tgz"; + sha256 = "02xsm4han0m0vj1j2ly2a6ncjcv7z8p3lcpkyj27xygag2vlchbq"; + system = "treedb.doc"; + asd = "treedb.doc"; + } + ); + systems = [ "treedb.doc" ]; + lispLibs = [ + (getAttr "cl-gendoc" self) + (getAttr "treedb" self) + (getAttr "treedb_dot_tests" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + treedb_dot_tests = ( + build-asdf-system { + pname = "treedb.tests"; + version = "20160825-git"; + asds = [ "treedb.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/treedb/2016-08-25/treedb-20160825-git.tgz"; + sha256 = "02xsm4han0m0vj1j2ly2a6ncjcv7z8p3lcpkyj27xygag2vlchbq"; + system = "treedb.tests"; + asd = "treedb.tests"; + } + ); + systems = [ "treedb.tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "treedb" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trees = ( + build-asdf-system { + pname = "trees"; + version = "20180131-git"; + asds = [ "trees" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trees/2018-01-31/trees-20180131-git.tgz"; + sha256 = "1xvydf3qc17rd7ia8sffxcpclgm3l0iyhx8k72ddk59v3pg5is4k"; + system = "trees"; + asd = "trees"; + } + ); + systems = [ "trees" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trees-tests = ( + build-asdf-system { + pname = "trees-tests"; + version = "20180131-git"; + asds = [ "trees-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trees/2018-01-31/trees-20180131-git.tgz"; + sha256 = "1xvydf3qc17rd7ia8sffxcpclgm3l0iyhx8k72ddk59v3pg5is4k"; + system = "trees-tests"; + asd = "trees"; + } + ); + systems = [ "trees-tests" ]; + lispLibs = [ (getAttr "trees" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trestrul = ( + build-asdf-system { + pname = "trestrul"; + version = "20211020-git"; + asds = [ "trestrul" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trestrul/2021-10-20/trestrul-20211020-git.tgz"; + sha256 = "12bghcfnfxq8l4a1jzh6vx4yna9da1xvp0b7kfdcfylnyga9ivy6"; + system = "trestrul"; + asd = "trestrul"; + } + ); + systems = [ "trestrul" ]; + lispLibs = [ (getAttr "jingoh_dot_documentizer" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trestrul_dot_test = ( + build-asdf-system { + pname = "trestrul.test"; + version = "20211020-git"; + asds = [ "trestrul.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trestrul/2021-10-20/trestrul-20211020-git.tgz"; + sha256 = "12bghcfnfxq8l4a1jzh6vx4yna9da1xvp0b7kfdcfylnyga9ivy6"; + system = "trestrul.test"; + asd = "trestrul.test"; + } + ); + systems = [ "trestrul.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "trestrul" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivia = ( + build-asdf-system { + pname = "trivia"; + version = "20241012-git"; + asds = [ "trivia" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; + sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; + system = "trivia"; + asd = "trivia"; + } + ); + systems = [ "trivia" ]; + lispLibs = [ (getAttr "trivia_dot_balland2006" self) ]; + meta = { }; + } + ); + trivia_dot_balland2006 = ( + build-asdf-system { + pname = "trivia.balland2006"; + version = "20241012-git"; + asds = [ "trivia.balland2006" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; + sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; + system = "trivia.balland2006"; + asd = "trivia.balland2006"; + } + ); + systems = [ "trivia.balland2006" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + (getAttr "trivia_dot_trivial" self) + (getAttr "type-i" self) + ]; + meta = { }; + } + ); + trivia_dot_benchmark = ( + build-asdf-system { + pname = "trivia.benchmark"; + version = "20241012-git"; + asds = [ "trivia.benchmark" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; + sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; + system = "trivia.benchmark"; + asd = "trivia.benchmark"; + } + ); + systems = [ "trivia.benchmark" ]; + lispLibs = [ + (getAttr "iterate" self) + (getAttr "optima" self) + (getAttr "trivia" self) + (getAttr "trivia_dot_balland2006" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivia_dot_cffi = ( + build-asdf-system { + pname = "trivia.cffi"; + version = "20241012-git"; + asds = [ "trivia.cffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; + sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; + system = "trivia.cffi"; + asd = "trivia.cffi"; + } + ); + systems = [ "trivia.cffi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "trivia_dot_trivial" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivia_dot_fset = ( + build-asdf-system { + pname = "trivia.fset"; + version = "20241012-git"; + asds = [ "trivia.fset" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; + sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; + system = "trivia.fset"; + asd = "trivia.fset"; + } + ); + systems = [ "trivia.fset" ]; + lispLibs = [ + (getAttr "fset" self) + (getAttr "trivia_dot_trivial" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivia_dot_level0 = ( + build-asdf-system { + pname = "trivia.level0"; + version = "20241012-git"; + asds = [ "trivia.level0" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; + sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; + system = "trivia.level0"; + asd = "trivia.level0"; + } + ); + systems = [ "trivia.level0" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { }; + } + ); + trivia_dot_level1 = ( + build-asdf-system { + pname = "trivia.level1"; + version = "20241012-git"; + asds = [ "trivia.level1" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; + sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; + system = "trivia.level1"; + asd = "trivia.level1"; + } + ); + systems = [ "trivia.level1" ]; + lispLibs = [ (getAttr "trivia_dot_level0" self) ]; + meta = { }; + } + ); + trivia_dot_level2 = ( + build-asdf-system { + pname = "trivia.level2"; + version = "20241012-git"; + asds = [ "trivia.level2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; + sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; + system = "trivia.level2"; + asd = "trivia.level2"; + } + ); + systems = [ "trivia.level2" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "lisp-namespace" self) + (getAttr "trivia_dot_level1" self) + (getAttr "trivial-cltl2" self) + ]; + meta = { }; + } + ); + trivia_dot_ppcre = ( + build-asdf-system { + pname = "trivia.ppcre"; + version = "20241012-git"; + asds = [ "trivia.ppcre" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; + sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; + system = "trivia.ppcre"; + asd = "trivia.ppcre"; + } + ); + systems = [ "trivia.ppcre" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "trivia_dot_trivial" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivia_dot_quasiquote = ( + build-asdf-system { + pname = "trivia.quasiquote"; + version = "20241012-git"; + asds = [ "trivia.quasiquote" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; + sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; + system = "trivia.quasiquote"; + asd = "trivia.quasiquote"; + } + ); + systems = [ "trivia.quasiquote" ]; + lispLibs = [ + (getAttr "fare-quasiquote-readtable" self) + (getAttr "trivia_dot_trivial" self) + ]; + meta = { }; + } + ); + trivia_dot_test = ( + build-asdf-system { + pname = "trivia.test"; + version = "20241012-git"; + asds = [ "trivia.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; + sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; + system = "trivia.test"; + asd = "trivia.test"; + } + ); + systems = [ "trivia.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "optima" self) + (getAttr "trivia" self) + (getAttr "trivia_dot_cffi" self) + (getAttr "trivia_dot_fset" self) + (getAttr "trivia_dot_ppcre" self) + (getAttr "trivia_dot_quasiquote" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivia_dot_trivial = ( + build-asdf-system { + pname = "trivia.trivial"; + version = "20241012-git"; + asds = [ "trivia.trivial" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivia/2024-10-12/trivia-20241012-git.tgz"; + sha256 = "1kysjmgi0hg4f4vwn64494aylsywxs66ksz3bnissf9p5nzgz61b"; + system = "trivia.trivial"; + asd = "trivia.trivial"; + } + ); + systems = [ "trivia.trivial" ]; + lispLibs = [ (getAttr "trivia_dot_level2" self) ]; + meta = { }; + } + ); + trivial-adjust-simple-array = ( + build-asdf-system { + pname = "trivial-adjust-simple-array"; + version = "20241012-git"; + asds = [ "trivial-adjust-simple-array" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-adjust-simple-array/2024-10-12/trivial-adjust-simple-array-20241012-git.tgz"; + sha256 = "05yifs4b44whqz4bgv4wys6kvza8y7z5w52kh55ch7krpv61ncy6"; + system = "trivial-adjust-simple-array"; + asd = "trivial-adjust-simple-array"; + } + ); + systems = [ "trivial-adjust-simple-array" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-arguments = ( + build-asdf-system { + pname = "trivial-arguments"; + version = "20241012-git"; + asds = [ "trivial-arguments" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-arguments/2024-10-12/trivial-arguments-20241012-git.tgz"; + sha256 = "1x1jifrw4ryyqgbln07znrc1drl4gxvzhbhv5gl1kgp2xm0rvr7j"; + system = "trivial-arguments"; + asd = "trivial-arguments"; + } + ); + systems = [ "trivial-arguments" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-backtrace = ( + build-asdf-system { + pname = "trivial-backtrace"; + version = "20230214-git"; + asds = [ "trivial-backtrace" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-backtrace/2023-02-14/trivial-backtrace-20230214-git.tgz"; + sha256 = "11j0p3vgmnn5q84xw7sacr5p3cvff2hfhsh2is8xpm2iwxc723kn"; + system = "trivial-backtrace"; + asd = "trivial-backtrace"; + } + ); + systems = [ "trivial-backtrace" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-backtrace-test = ( + build-asdf-system { + pname = "trivial-backtrace-test"; + version = "20230214-git"; + asds = [ "trivial-backtrace-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-backtrace/2023-02-14/trivial-backtrace-20230214-git.tgz"; + sha256 = "11j0p3vgmnn5q84xw7sacr5p3cvff2hfhsh2is8xpm2iwxc723kn"; + system = "trivial-backtrace-test"; + asd = "trivial-backtrace-test"; + } + ); + systems = [ "trivial-backtrace-test" ]; + lispLibs = [ + (getAttr "lift" self) + (getAttr "trivial-backtrace" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-battery = ( + build-asdf-system { + pname = "trivial-battery"; + version = "20211020-git"; + asds = [ "trivial-battery" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-battery/2021-10-20/trivial-battery-20211020-git.tgz"; + sha256 = "12ni2502v9gjszhjsh0aai08cm64gl8g815xghdjhcf7y34ffl2b"; + system = "trivial-battery"; + asd = "trivial-battery"; + } + ); + systems = [ "trivial-battery" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-benchmark = ( + build-asdf-system { + pname = "trivial-benchmark"; + version = "20231021-git"; + asds = [ "trivial-benchmark" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-benchmark/2023-10-21/trivial-benchmark-20231021-git.tgz"; + sha256 = "1p48wgpady0n8frdcgp7sbg93b0fbvpx1qk5valmanhwr9j3xh88"; + system = "trivial-benchmark"; + asd = "trivial-benchmark"; + } + ); + systems = [ "trivial-benchmark" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-bit-streams = ( + build-asdf-system { + pname = "trivial-bit-streams"; + version = "20190710-git"; + asds = [ "trivial-bit-streams" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-bit-streams/2019-07-10/trivial-bit-streams-20190710-git.tgz"; + sha256 = "01xcs069934pzm8gi1xkwgd4lw37ams30i6rcgrlw8gnx4zc4zc9"; + system = "trivial-bit-streams"; + asd = "trivial-bit-streams"; + } + ); + systems = [ "trivial-bit-streams" ]; + lispLibs = [ (getAttr "trivial-gray-streams" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-bit-streams-tests = ( + build-asdf-system { + pname = "trivial-bit-streams-tests"; + version = "20190710-git"; + asds = [ "trivial-bit-streams-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-bit-streams/2019-07-10/trivial-bit-streams-20190710-git.tgz"; + sha256 = "01xcs069934pzm8gi1xkwgd4lw37ams30i6rcgrlw8gnx4zc4zc9"; + system = "trivial-bit-streams-tests"; + asd = "trivial-bit-streams-tests"; + } + ); + systems = [ "trivial-bit-streams-tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "flexi-streams" self) + (getAttr "trivial-bit-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-build = ( + build-asdf-system { + pname = "trivial-build"; + version = "20151218-git"; + asds = [ "trivial-build" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-build/2015-12-18/trivial-build-20151218-git.tgz"; + sha256 = "10h1igvryaqz6f72i57ppifysnw8swnss9395sijnk595icja7q0"; + system = "trivial-build"; + asd = "trivial-build"; + } + ); + systems = [ "trivial-build" ]; + lispLibs = [ + (getAttr "lisp-invocation" self) + (getAttr "trivial-exe" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-build-test = ( + build-asdf-system { + pname = "trivial-build-test"; + version = "20151218-git"; + asds = [ "trivial-build-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-build/2015-12-18/trivial-build-20151218-git.tgz"; + sha256 = "10h1igvryaqz6f72i57ppifysnw8swnss9395sijnk595icja7q0"; + system = "trivial-build-test"; + asd = "trivial-build-test"; + } + ); + systems = [ "trivial-build-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "trivial-build" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-channels = ( + build-asdf-system { + pname = "trivial-channels"; + version = "20160421-git"; + asds = [ "trivial-channels" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-channels/2016-04-21/trivial-channels-20160421-git.tgz"; + sha256 = "04wnxcgk40x8p0gxnz9arv1a5wasdqrdxa8c4p5v7r2mycfps6jj"; + system = "trivial-channels"; + asd = "trivial-channels"; + } + ); + systems = [ "trivial-channels" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "trivial-timeout" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-clipboard = ( + build-asdf-system { + pname = "trivial-clipboard"; + version = "20241012-git"; + asds = [ "trivial-clipboard" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-clipboard/2024-10-12/trivial-clipboard-20241012-git.tgz"; + sha256 = "1agj4nvw4qq7k4vp64y15gq5h5g22zasys48c2bvzqjr0n9d4lj1"; + system = "trivial-clipboard"; + asd = "trivial-clipboard"; + } + ); + systems = [ "trivial-clipboard" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-clipboard-test = ( + build-asdf-system { + pname = "trivial-clipboard-test"; + version = "20241012-git"; + asds = [ "trivial-clipboard-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-clipboard/2024-10-12/trivial-clipboard-20241012-git.tgz"; + sha256 = "1agj4nvw4qq7k4vp64y15gq5h5g22zasys48c2bvzqjr0n9d4lj1"; + system = "trivial-clipboard-test"; + asd = "trivial-clipboard-test"; + } + ); + systems = [ "trivial-clipboard-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "trivial-clipboard" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-clock = ( + build-asdf-system { + pname = "trivial-clock"; + version = "20241012-git"; + asds = [ "trivial-clock" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-trivial-clock/2024-10-12/cl-trivial-clock-20241012-git.tgz"; + sha256 = "1m1351j3xvrf6631gmf99xaxb3dhh4ak657p1hac3b9f9a5h85nd"; + system = "trivial-clock"; + asd = "trivial-clock"; + } + ); + systems = [ "trivial-clock" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-cltl2 = ( + build-asdf-system { + pname = "trivial-cltl2"; + version = "20211230-git"; + asds = [ "trivial-cltl2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-cltl2/2021-12-30/trivial-cltl2-20211230-git.tgz"; + sha256 = "0xx5vr0dp623m111zbfdk6x7l4jgd4wwyp6iarbj6ijq514wi3a3"; + system = "trivial-cltl2"; + asd = "trivial-cltl2"; + } + ); + systems = [ "trivial-cltl2" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-compress = ( + build-asdf-system { + pname = "trivial-compress"; + version = "20201220-git"; + asds = [ "trivial-compress" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-compress/2020-12-20/trivial-compress-20201220-git.tgz"; + sha256 = "1pbaz0phvzi27dgnfknscak1h27bsi16gys23kchg8y8zbm0z0g7"; + system = "trivial-compress"; + asd = "trivial-compress"; + } + ); + systems = [ "trivial-compress" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "archive" self) + (getAttr "which" self) + (getAttr "zip" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-compress-test = ( + build-asdf-system { + pname = "trivial-compress-test"; + version = "20201220-git"; + asds = [ "trivial-compress-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-compress/2020-12-20/trivial-compress-20201220-git.tgz"; + sha256 = "1pbaz0phvzi27dgnfknscak1h27bsi16gys23kchg8y8zbm0z0g7"; + system = "trivial-compress-test"; + asd = "trivial-compress-test"; + } + ); + systems = [ "trivial-compress-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "trivial-compress" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-continuation = ( + build-asdf-system { + pname = "trivial-continuation"; + version = "20191007-git"; + asds = [ "trivial-continuation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-continuation/2019-10-07/trivial-continuation-20191007-git.tgz"; + sha256 = "1j8d8q86r60qr9pi5p3q7rqn16xpzbzygs0i9b8sn3qyxnnz5037"; + system = "trivial-continuation"; + asd = "trivial-continuation"; + } + ); + systems = [ "trivial-continuation" ]; + lispLibs = [ + (getAttr "log4cl" self) + (getAttr "trivial-utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-coverage = ( + build-asdf-system { + pname = "trivial-coverage"; + version = "20200218-git"; + asds = [ "trivial-coverage" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-coverage/2020-02-18/trivial-coverage-20200218-git.tgz"; + sha256 = "1ak4mjcvzdjsjjh7j89zlnwgaamfrspxmjh2i9kg67kqn36prbsp"; + system = "trivial-coverage"; + asd = "trivial-coverage"; + } + ); + systems = [ "trivial-coverage" ]; + lispLibs = [ (getAttr "lquery" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-custom-debugger = ( + build-asdf-system { + pname = "trivial-custom-debugger"; + version = "20231021-git"; + asds = [ "trivial-custom-debugger" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-custom-debugger/2023-10-21/trivial-custom-debugger-20231021-git.tgz"; + sha256 = "11x0wpnfllazaqlrgv9xx1mb5q62dx6ny08hpwgkq3jpvqbhxs3b"; + system = "trivial-custom-debugger"; + asd = "trivial-custom-debugger"; + } + ); + systems = [ "trivial-custom-debugger" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-debug-console = ( + build-asdf-system { + pname = "trivial-debug-console"; + version = "20150407-git"; + asds = [ "trivial-debug-console" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-debug-console/2015-04-07/trivial-debug-console-20150407-git.tgz"; + sha256 = "07r42k57vldg01hfwjhkic2hsy84c2s5zj7pl60xjl960i0lqnam"; + system = "trivial-debug-console"; + asd = "trivial-debug-console"; + } + ); + systems = [ "trivial-debug-console" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-do = ( + build-asdf-system { + pname = "trivial-do"; + version = "20220331-git"; + asds = [ "trivial-do" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-do/2022-03-31/trivial-do-20220331-git.tgz"; + sha256 = "0vql7am4zyg6zav3l6n6q3qgdxlnchdxpgdxp8lr9sm7jra7sdsf"; + system = "trivial-do"; + asd = "trivial-do"; + } + ); + systems = [ "trivial-do" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-documentation = ( + build-asdf-system { + pname = "trivial-documentation"; + version = "20161204-git"; + asds = [ "trivial-documentation" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-documentation/2016-12-04/trivial-documentation-20161204-git.tgz"; + sha256 = "0y90zi6kaw7226xc089dl47677fz594a5ck1ld8yggk9ww7cdaav"; + system = "trivial-documentation"; + asd = "trivial-documentation"; + } + ); + systems = [ "trivial-documentation" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-documentation-test = ( + build-asdf-system { + pname = "trivial-documentation-test"; + version = "20161204-git"; + asds = [ "trivial-documentation-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-documentation/2016-12-04/trivial-documentation-20161204-git.tgz"; + sha256 = "0y90zi6kaw7226xc089dl47677fz594a5ck1ld8yggk9ww7cdaav"; + system = "trivial-documentation-test"; + asd = "trivial-documentation-test"; + } + ); + systems = [ "trivial-documentation-test" ]; + lispLibs = [ (getAttr "trivial-documentation" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-download = ( + build-asdf-system { + pname = "trivial-download"; + version = "20230214-git"; + asds = [ "trivial-download" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-download/2023-02-14/trivial-download-20230214-git.tgz"; + sha256 = "17kag2zi1r766n2mg4knz4ix268bll2acl0150cksibfa4dbq1k7"; + system = "trivial-download"; + asd = "trivial-download"; + } + ); + systems = [ "trivial-download" ]; + lispLibs = [ (getAttr "drakma" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-dump-core = ( + build-asdf-system { + pname = "trivial-dump-core"; + version = "20170227-git"; + asds = [ "trivial-dump-core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-dump-core/2017-02-27/trivial-dump-core-20170227-git.tgz"; + sha256 = "08lnp84gbf3yd3gpnbjbl8jm9p42j3m4hf2f355l7lylb8kabxn8"; + system = "trivial-dump-core"; + asd = "trivial-dump-core"; + } + ); + systems = [ "trivial-dump-core" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-ed-functions = ( + build-asdf-system { + pname = "trivial-ed-functions"; + version = "20210807-git"; + asds = [ "trivial-ed-functions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-ed-functions/2021-08-07/trivial-ed-functions-20210807-git.tgz"; + sha256 = "05r8n4jjcg2lci5qrjwqz913wivckgk01ivjg1barpnm0nr29qn1"; + system = "trivial-ed-functions"; + asd = "trivial-ed-functions"; + } + ); + systems = [ "trivial-ed-functions" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-escapes = ( + build-asdf-system { + pname = "trivial-escapes"; + version = "20180228-git"; + asds = [ "trivial-escapes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-escapes/2018-02-28/trivial-escapes-20180228-git.tgz"; + sha256 = "0v6h8lk17iqv1qkxgqjyzn8gi6v0hvq2vmfbb01md3zjvjqxn6lr"; + system = "trivial-escapes"; + asd = "trivial-escapes"; + } + ); + systems = [ "trivial-escapes" ]; + lispLibs = [ (getAttr "named-readtables" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-escapes-test = ( + build-asdf-system { + pname = "trivial-escapes-test"; + version = "20180228-git"; + asds = [ "trivial-escapes-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-escapes/2018-02-28/trivial-escapes-20180228-git.tgz"; + sha256 = "0v6h8lk17iqv1qkxgqjyzn8gi6v0hvq2vmfbb01md3zjvjqxn6lr"; + system = "trivial-escapes-test"; + asd = "trivial-escapes-test"; + } + ); + systems = [ "trivial-escapes-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "trivial-escapes" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-exe = ( + build-asdf-system { + pname = "trivial-exe"; + version = "20151218-git"; + asds = [ "trivial-exe" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-exe/2015-12-18/trivial-exe-20151218-git.tgz"; + sha256 = "1ryn7gh3n057czj3hwq6lx7h25ipfjxsvddywpm2ngfdwywaqzvc"; + system = "trivial-exe"; + asd = "trivial-exe"; + } + ); + systems = [ "trivial-exe" ]; + lispLibs = [ (getAttr "osicat" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-exe-test = ( + build-asdf-system { + pname = "trivial-exe-test"; + version = "20151218-git"; + asds = [ "trivial-exe-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-exe/2015-12-18/trivial-exe-20151218-git.tgz"; + sha256 = "1ryn7gh3n057czj3hwq6lx7h25ipfjxsvddywpm2ngfdwywaqzvc"; + system = "trivial-exe-test"; + asd = "trivial-exe-test"; + } + ); + systems = [ "trivial-exe-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "trivial-exe" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-extensible-sequences = ( + build-asdf-system { + pname = "trivial-extensible-sequences"; + version = "20231021-git"; + asds = [ "trivial-extensible-sequences" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-extensible-sequences/2023-10-21/trivial-extensible-sequences-20231021-git.tgz"; + sha256 = "1mgfvyvy3dkn8wyjqc49czl990rbbfkz7sfrhz9641dilasmw9s6"; + system = "trivial-extensible-sequences"; + asd = "trivial-extensible-sequences"; + } + ); + systems = [ "trivial-extensible-sequences" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-extract = ( + build-asdf-system { + pname = "trivial-extract"; + version = "20160421-git"; + asds = [ "trivial-extract" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-extract/2016-04-21/trivial-extract-20160421-git.tgz"; + sha256 = "0083x71f4x6b64wd8ywgaiqi0ygmdhl5rv101jcv44l3l61839sx"; + system = "trivial-extract"; + asd = "trivial-extract"; + } + ); + systems = [ "trivial-extract" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "archive" self) + (getAttr "cl-fad" self) + (getAttr "deflate" self) + (getAttr "which" self) + (getAttr "zip" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-extract-test = ( + build-asdf-system { + pname = "trivial-extract-test"; + version = "20160421-git"; + asds = [ "trivial-extract-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-extract/2016-04-21/trivial-extract-20160421-git.tgz"; + sha256 = "0083x71f4x6b64wd8ywgaiqi0ygmdhl5rv101jcv44l3l61839sx"; + system = "trivial-extract-test"; + asd = "trivial-extract-test"; + } + ); + systems = [ "trivial-extract-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "trivial-extract" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-features = ( + build-asdf-system { + pname = "trivial-features"; + version = "20230618-git"; + asds = [ "trivial-features" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-features/2023-06-18/trivial-features-20230618-git.tgz"; + sha256 = "0r33ycg1wsmglbsychglzkd6fachnnqfzd0w9mhpwi6cz94hx7c3"; + system = "trivial-features"; + asd = "trivial-features"; + } + ); + systems = [ "trivial-features" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-features-tests = ( + build-asdf-system { + pname = "trivial-features-tests"; + version = "20230618-git"; + asds = [ "trivial-features-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-features/2023-06-18/trivial-features-20230618-git.tgz"; + sha256 = "0r33ycg1wsmglbsychglzkd6fachnnqfzd0w9mhpwi6cz94hx7c3"; + system = "trivial-features-tests"; + asd = "trivial-features-tests"; + } + ); + systems = [ "trivial-features-tests" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "rt" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-file-size = ( + build-asdf-system { + pname = "trivial-file-size"; + version = "20241012-git"; + asds = [ "trivial-file-size" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-file-size/2024-10-12/trivial-file-size-20241012-git.tgz"; + sha256 = "08dbyrrgvvl459lk3pcq0j7qryb20hdh946y42h4jsp5crhbi71z"; + system = "trivial-file-size"; + asd = "trivial-file-size"; + } + ); + systems = [ "trivial-file-size" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-garbage = ( + build-asdf-system { + pname = "trivial-garbage"; + version = "20231021-git"; + asds = [ "trivial-garbage" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-garbage/2023-10-21/trivial-garbage-20231021-git.tgz"; + sha256 = "0rfwxvwg0kpcaa0hsi035yrkfdfks4bq8d9azmrww2f0rmv9g6sd"; + system = "trivial-garbage"; + asd = "trivial-garbage"; + } + ); + systems = [ "trivial-garbage" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-gray-streams = ( + build-asdf-system { + pname = "trivial-gray-streams"; + version = "20241012-git"; + asds = [ "trivial-gray-streams" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-gray-streams/2024-10-12/trivial-gray-streams-20241012-git.tgz"; + sha256 = "0iw6q5hx7x8sc5s7ikvsjccsksbm0rd13d54mkrg62sc56hjywrm"; + system = "trivial-gray-streams"; + asd = "trivial-gray-streams"; + } + ); + systems = [ "trivial-gray-streams" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-gray-streams-test = ( + build-asdf-system { + pname = "trivial-gray-streams-test"; + version = "20241012-git"; + asds = [ "trivial-gray-streams-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-gray-streams/2024-10-12/trivial-gray-streams-20241012-git.tgz"; + sha256 = "0iw6q5hx7x8sc5s7ikvsjccsksbm0rd13d54mkrg62sc56hjywrm"; + system = "trivial-gray-streams-test"; + asd = "trivial-gray-streams-test"; + } + ); + systems = [ "trivial-gray-streams-test" ]; + lispLibs = [ (getAttr "trivial-gray-streams" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-hashtable-serialize = ( + build-asdf-system { + pname = "trivial-hashtable-serialize"; + version = "20191007-git"; + asds = [ "trivial-hashtable-serialize" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-hashtable-serialize/2019-10-07/trivial-hashtable-serialize-20191007-git.tgz"; + sha256 = "06xdci47h6rpfkmrf7p9kd217jbkmkmf90ygqcmkkgf3sv5623bh"; + system = "trivial-hashtable-serialize"; + asd = "trivial-hashtable-serialize"; + } + ); + systems = [ "trivial-hashtable-serialize" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-http = ( + build-asdf-system { + pname = "trivial-http"; + version = "20110219-http"; + asds = [ "trivial-http" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-http/2011-02-19/trivial-http-20110219-http.tgz"; + sha256 = "06mrh2bjzhfdzi48dnq0bhl2cac4v41aqck53rfm4rnsygcjsn78"; + system = "trivial-http"; + asd = "trivial-http"; + } + ); + systems = [ "trivial-http" ]; + lispLibs = [ (getAttr "usocket" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-http-test = ( + build-asdf-system { + pname = "trivial-http-test"; + version = "20110219-http"; + asds = [ "trivial-http-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-http/2011-02-19/trivial-http-20110219-http.tgz"; + sha256 = "06mrh2bjzhfdzi48dnq0bhl2cac4v41aqck53rfm4rnsygcjsn78"; + system = "trivial-http-test"; + asd = "trivial-http-test"; + } + ); + systems = [ "trivial-http-test" ]; + lispLibs = [ + (getAttr "lift" self) + (getAttr "trivial-http" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-indent = ( + build-asdf-system { + pname = "trivial-indent"; + version = "20231021-git"; + asds = [ "trivial-indent" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-indent/2023-10-21/trivial-indent-20231021-git.tgz"; + sha256 = "08qgx34zbpafzws96nq68bgpynddf22ibliqni2jnvhwv74lcpiw"; + system = "trivial-indent"; + asd = "trivial-indent"; + } + ); + systems = [ "trivial-indent" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-inspector-hook = ( + build-asdf-system { + pname = "trivial-inspector-hook"; + version = "20210807-git"; + asds = [ "trivial-inspector-hook" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-inspector-hook/2021-08-07/trivial-inspector-hook-20210807-git.tgz"; + sha256 = "0h9m1ps5sqgrr171czj6rq84wpy2xvggfzspvy667xsldv4xi0c2"; + system = "trivial-inspector-hook"; + asd = "trivial-inspector-hook"; + } + ); + systems = [ "trivial-inspector-hook" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-irc = ( + build-asdf-system { + pname = "trivial-irc"; + version = "20171019-git"; + asds = [ "trivial-irc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-irc/2017-10-19/trivial-irc-20171019-git.tgz"; + sha256 = "0jjgx6ld2gcr0w0g5k62dr0rl6202ydih6ylmypv6m5jmrarcbza"; + system = "trivial-irc"; + asd = "trivial-irc"; + } + ); + systems = [ "trivial-irc" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "split-sequence" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-irc-echobot = ( + build-asdf-system { + pname = "trivial-irc-echobot"; + version = "20171019-git"; + asds = [ "trivial-irc-echobot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-irc/2017-10-19/trivial-irc-20171019-git.tgz"; + sha256 = "0jjgx6ld2gcr0w0g5k62dr0rl6202ydih6ylmypv6m5jmrarcbza"; + system = "trivial-irc-echobot"; + asd = "trivial-irc-echobot"; + } + ); + systems = [ "trivial-irc-echobot" ]; + lispLibs = [ (getAttr "trivial-irc" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-json-codec = ( + build-asdf-system { + pname = "trivial-json-codec"; + version = "20220707-git"; + asds = [ "trivial-json-codec" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-json-codec/2022-07-07/trivial-json-codec-20220707-git.tgz"; + sha256 = "1k0nnsn3nsb83gzmkrf81zqz6ydn21gzfq96r2d5690v5zkrg1kg"; + system = "trivial-json-codec"; + asd = "trivial-json-codec"; + } + ); + systems = [ "trivial-json-codec" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "iterate" self) + (getAttr "log4cl" self) + (getAttr "parse-number" self) + (getAttr "trivial-utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-jumptables = ( + build-asdf-system { + pname = "trivial-jumptables"; + version = "1.1"; + asds = [ "trivial-jumptables" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-jumptables/2019-11-30/trivial-jumptables_1.1.tgz"; + sha256 = "10ih84hkscj0l4ki3s196d9b85iil8f56ps5r8ng222i0lln1ni9"; + system = "trivial-jumptables"; + asd = "trivial-jumptables"; + } + ); + systems = [ "trivial-jumptables" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-jumptables__tests = ( + build-asdf-system { + pname = "trivial-jumptables_tests"; + version = "1.1"; + asds = [ "trivial-jumptables_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-jumptables/2019-11-30/trivial-jumptables_1.1.tgz"; + sha256 = "10ih84hkscj0l4ki3s196d9b85iil8f56ps5r8ng222i0lln1ni9"; + system = "trivial-jumptables_tests"; + asd = "trivial-jumptables_tests"; + } + ); + systems = [ "trivial-jumptables_tests" ]; + lispLibs = [ + (getAttr "bubble-operator-upwards" self) + (getAttr "parachute" self) + (getAttr "trivial-jumptables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-lazy = ( + build-asdf-system { + pname = "trivial-lazy"; + version = "20150709-git"; + asds = [ "trivial-lazy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-lazy/2015-07-09/trivial-lazy-20150709-git.tgz"; + sha256 = "0fnsz2kdb0v5cz4xl5a2c1szcif7jmnkxhbzvk6lrhzjccgyhjc7"; + system = "trivial-lazy"; + asd = "trivial-lazy"; + } + ); + systems = [ "trivial-lazy" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-ldap = ( + build-asdf-system { + pname = "trivial-ldap"; + version = "20180711-git"; + asds = [ "trivial-ldap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-ldap/2018-07-11/trivial-ldap-20180711-git.tgz"; + sha256 = "1zaa4wnk5y5ff211pkg6dl27j4pjwh56hq0246slxsdxv6kvp1z9"; + system = "trivial-ldap"; + asd = "trivial-ldap"; + } + ); + systems = [ "trivial-ldap" ]; + lispLibs = [ + (getAttr "cl_plus_ssl" self) + (getAttr "usocket" self) + (getAttr "yacc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-left-pad = ( + build-asdf-system { + pname = "trivial-left-pad"; + version = "20190813-git"; + asds = [ "trivial-left-pad" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-left-pad/2019-08-13/trivial-left-pad-20190813-git.tgz"; + sha256 = "0q68j0x0x3z8rl577jsl3y0s3x5xiqv54sla6kds43q7821qfnwk"; + system = "trivial-left-pad"; + asd = "trivial-left-pad"; + } + ); + systems = [ "trivial-left-pad" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "prove-asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-left-pad-test = ( + build-asdf-system { + pname = "trivial-left-pad-test"; + version = "20190813-git"; + asds = [ "trivial-left-pad-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-left-pad/2019-08-13/trivial-left-pad-20190813-git.tgz"; + sha256 = "0q68j0x0x3z8rl577jsl3y0s3x5xiqv54sla6kds43q7821qfnwk"; + system = "trivial-left-pad-test"; + asd = "trivial-left-pad"; + } + ); + systems = [ "trivial-left-pad-test" ]; + lispLibs = [ + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "trivial-left-pad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-macroexpand-all = ( + build-asdf-system { + pname = "trivial-macroexpand-all"; + version = "20171023-git"; + asds = [ "trivial-macroexpand-all" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-macroexpand-all/2017-10-23/trivial-macroexpand-all-20171023-git.tgz"; + sha256 = "191hnn4b5j4i3crydmlzbm231kj0h7l8zj6mzj69r1npbzkas4bd"; + system = "trivial-macroexpand-all"; + asd = "trivial-macroexpand-all"; + } + ); + systems = [ "trivial-macroexpand-all" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-main-thread = ( + build-asdf-system { + pname = "trivial-main-thread"; + version = "20241012-git"; + asds = [ "trivial-main-thread" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-main-thread/2024-10-12/trivial-main-thread-20241012-git.tgz"; + sha256 = "0vxr82ald41355hvlg0ngrpzkz9y3nyl24h58306kmg982xk4hnk"; + system = "trivial-main-thread"; + asd = "trivial-main-thread"; + } + ); + systems = [ "trivial-main-thread" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "documentation-utils" self) + (getAttr "trivial-features" self) + ]; + meta = { }; + } + ); + trivial-method-combinations = ( + build-asdf-system { + pname = "trivial-method-combinations"; + version = "20191130-git"; + asds = [ "trivial-method-combinations" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-method-combinations/2019-11-30/trivial-method-combinations-20191130-git.tgz"; + sha256 = "0w9w8bj835sfp797rdm7b5crpnz0xrz2q5vgbzm2p9n9jskxnxnv"; + system = "trivial-method-combinations"; + asd = "trivial-method-combinations"; + } + ); + systems = [ "trivial-method-combinations" ]; + lispLibs = [ (getAttr "closer-mop" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-mimes = ( + build-asdf-system { + pname = "trivial-mimes"; + version = "20231021-git"; + asds = [ "trivial-mimes" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-mimes/2023-10-21/trivial-mimes-20231021-git.tgz"; + sha256 = "05cqbg9bh4r9av675vrzgw4p3s1dxb74r2ygvbfkych79kdik871"; + system = "trivial-mimes"; + asd = "trivial-mimes"; + } + ); + systems = [ "trivial-mimes" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-mmap = ( + build-asdf-system { + pname = "trivial-mmap"; + version = "20210124-git"; + asds = [ "trivial-mmap" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-mmap/2021-01-24/trivial-mmap-20210124-git.tgz"; + sha256 = "1ckhd7b0ll9xcmwdh42g0v38grk2acs3kv66k1gwh539f99kzcps"; + system = "trivial-mmap"; + asd = "trivial-mmap"; + } + ); + systems = [ "trivial-mmap" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "osicat" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-monitored-thread = ( + build-asdf-system { + pname = "trivial-monitored-thread"; + version = "20220707-git"; + asds = [ "trivial-monitored-thread" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-monitored-thread/2022-07-07/trivial-monitored-thread-20220707-git.tgz"; + sha256 = "1vmhc5id0qk5yh8az4j1znqc73r18pygmrnfxmwwndh1a9yf98z4"; + system = "trivial-monitored-thread"; + asd = "trivial-monitored-thread"; + } + ); + systems = [ "trivial-monitored-thread" ]; + lispLibs = [ + (getAttr "iterate" self) + (getAttr "log4cl" self) + (getAttr "trivial-utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-msi = ( + build-asdf-system { + pname = "trivial-msi"; + version = "20160208-git"; + asds = [ "trivial-msi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-msi/2016-02-08/trivial-msi-20160208-git.tgz"; + sha256 = "1mbpwnsvv30gf7z8m96kv8933s6csg4q0frx03vazp4ckplwff8w"; + system = "trivial-msi"; + asd = "trivial-msi"; + } + ); + systems = [ "trivial-msi" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-msi-test = ( + build-asdf-system { + pname = "trivial-msi-test"; + version = "20160208-git"; + asds = [ "trivial-msi-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-msi/2016-02-08/trivial-msi-20160208-git.tgz"; + sha256 = "1mbpwnsvv30gf7z8m96kv8933s6csg4q0frx03vazp4ckplwff8w"; + system = "trivial-msi-test"; + asd = "trivial-msi-test"; + } + ); + systems = [ "trivial-msi-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "trivial-msi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-nntp = ( + build-asdf-system { + pname = "trivial-nntp"; + version = "20161204-git"; + asds = [ "trivial-nntp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-nntp/2016-12-04/trivial-nntp-20161204-git.tgz"; + sha256 = "0ywwrjx4vaz117zaxqhk2b4xrb75cw1ac5xir9zhvgzkyl6wf867"; + system = "trivial-nntp"; + asd = "trivial-nntp"; + } + ); + systems = [ "trivial-nntp" ]; + lispLibs = [ + (getAttr "cl_plus_ssl" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-object-lock = ( + build-asdf-system { + pname = "trivial-object-lock"; + version = "20220707-git"; + asds = [ "trivial-object-lock" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-object-lock/2022-07-07/trivial-object-lock-20220707-git.tgz"; + sha256 = "18xwwgvshib4l2bs6m16mk0kzdp40482yf7v72nzk13v0bgnw91s"; + system = "trivial-object-lock"; + asd = "trivial-object-lock"; + } + ); + systems = [ "trivial-object-lock" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "iterate" self) + (getAttr "log4cl" self) + (getAttr "trivial-utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-octet-streams = ( + build-asdf-system { + pname = "trivial-octet-streams"; + version = "20241012-git"; + asds = [ "trivial-octet-streams" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-octet-streams/2024-10-12/trivial-octet-streams-20241012-git.tgz"; + sha256 = "0zj7aijn10hflr87774hwi5k1jzq6j5bgh2hm70ixxhcmaq7lqk5"; + system = "trivial-octet-streams"; + asd = "trivial-octet-streams"; + } + ); + systems = [ "trivial-octet-streams" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-open-browser = ( + build-asdf-system { + pname = "trivial-open-browser"; + version = "20160825-git"; + asds = [ "trivial-open-browser" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-open-browser/2016-08-25/trivial-open-browser-20160825-git.tgz"; + sha256 = "0ixay1piq420i6adx642qhw45l6ik7rvgk52lyz27dvx5f8yqsdb"; + system = "trivial-open-browser"; + asd = "trivial-open-browser"; + } + ); + systems = [ "trivial-open-browser" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-openstack = ( + build-asdf-system { + pname = "trivial-openstack"; + version = "20160628-git"; + asds = [ "trivial-openstack" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-openstack/2016-06-28/trivial-openstack-20160628-git.tgz"; + sha256 = "0sdc6rhjqv1i7wknn44jg5xxnz70087bhfslh0izggny9d9s015i"; + system = "trivial-openstack"; + asd = "trivial-openstack"; + } + ); + systems = [ "trivial-openstack" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "drakma" self) + (getAttr "local-time" self) + (getAttr "st-json" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-openstack-test = ( + build-asdf-system { + pname = "trivial-openstack-test"; + version = "20160628-git"; + asds = [ "trivial-openstack-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-openstack/2016-06-28/trivial-openstack-20160628-git.tgz"; + sha256 = "0sdc6rhjqv1i7wknn44jg5xxnz70087bhfslh0izggny9d9s015i"; + system = "trivial-openstack-test"; + asd = "trivial-openstack-test"; + } + ); + systems = [ "trivial-openstack-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "hunchentoot" self) + (getAttr "local-time" self) + (getAttr "st-json" self) + (getAttr "trivial-openstack" self) + (getAttr "uri-template" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-package-local-nicknames = ( + build-asdf-system { + pname = "trivial-package-local-nicknames"; + version = "20220220-git"; + asds = [ "trivial-package-local-nicknames" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-package-local-nicknames/2022-02-20/trivial-package-local-nicknames-20220220-git.tgz"; + sha256 = "0p80s474czfqh7phd4qq5yjcy8q2160vxmn8pi6qlkqgdd7ix37r"; + system = "trivial-package-local-nicknames"; + asd = "trivial-package-local-nicknames"; + } + ); + systems = [ "trivial-package-local-nicknames" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-package-locks = ( + build-asdf-system { + pname = "trivial-package-locks"; + version = "20241012-git"; + asds = [ "trivial-package-locks" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-package-locks/2024-10-12/trivial-package-locks-20241012-git.tgz"; + sha256 = "09zhirygjmwr4xvwp1zx9b17mkxml7f7rni1xiwxg5vfgn0y1bi3"; + system = "trivial-package-locks"; + asd = "trivial-package-locks"; + } + ); + systems = [ "trivial-package-locks" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-package-manager = ( + build-asdf-system { + pname = "trivial-package-manager"; + version = "20241012-git"; + asds = [ "trivial-package-manager" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-package-manager/2024-10-12/trivial-package-manager-20241012-git.tgz"; + sha256 = "1q71r9h5xra0bg5c5v2gzjjswfv626gfg9sxn59w645g30xn1sph"; + system = "trivial-package-manager"; + asd = "trivial-package-manager"; + } + ); + systems = [ "trivial-package-manager" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-features" self) + (getAttr "trivial-open-browser" self) + ]; + meta = { }; + } + ); + trivial-package-manager_dot_test = ( + build-asdf-system { + pname = "trivial-package-manager.test"; + version = "20241012-git"; + asds = [ "trivial-package-manager.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-package-manager/2024-10-12/trivial-package-manager-20241012-git.tgz"; + sha256 = "1q71r9h5xra0bg5c5v2gzjjswfv626gfg9sxn59w645g30xn1sph"; + system = "trivial-package-manager.test"; + asd = "trivial-package-manager.test"; + } + ); + systems = [ "trivial-package-manager.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "trivial-package-manager" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-pooled-database = ( + build-asdf-system { + pname = "trivial-pooled-database"; + version = "20201220-git"; + asds = [ "trivial-pooled-database" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-pooled-database/2020-12-20/trivial-pooled-database-20201220-git.tgz"; + sha256 = "0a7c8bjl13k37b83lksklcw9sch570wgqv58cgs0dw9jcmsihqmx"; + system = "trivial-pooled-database"; + asd = "trivial-pooled-database"; + } + ); + systems = [ "trivial-pooled-database" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-dbi" self) + (getAttr "iterate" self) + (getAttr "log4cl" self) + (getAttr "parse-number" self) + (getAttr "trivial-object-lock" self) + (getAttr "trivial-utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-project = ( + build-asdf-system { + pname = "trivial-project"; + version = "quicklisp-9e3fe231-git"; + asds = [ "trivial-project" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-project/2017-08-30/trivial-project-quicklisp-9e3fe231-git.tgz"; + sha256 = "1s5h0fgs0rq00j492xln716w9i52v90rnfcr0idjzyimicx7hk22"; + system = "trivial-project"; + asd = "trivial-project"; + } + ); + systems = [ "trivial-project" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-raw-io = ( + build-asdf-system { + pname = "trivial-raw-io"; + version = "20141217-git"; + asds = [ "trivial-raw-io" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-raw-io/2014-12-17/trivial-raw-io-20141217-git.tgz"; + sha256 = "19290zw2b64k78wr62gv30pp7cmqg07q85vfwjknaffjdd73xwi1"; + system = "trivial-raw-io"; + asd = "trivial-raw-io"; + } + ); + systems = [ "trivial-raw-io" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-renamer = ( + build-asdf-system { + pname = "trivial-renamer"; + version = "quicklisp-1282597d-git"; + asds = [ "trivial-renamer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-renamer/2017-08-30/trivial-renamer-quicklisp-1282597d-git.tgz"; + sha256 = "1nlgsayx4iw6gskg0d5vc823p0lmh414k9jiccvcsk1r17684mp8"; + system = "trivial-renamer"; + asd = "trivial-renamer"; + } + ); + systems = [ "trivial-renamer" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-rfc-1123 = ( + build-asdf-system { + pname = "trivial-rfc-1123"; + version = "20220707-git"; + asds = [ "trivial-rfc-1123" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-rfc-1123/2022-07-07/trivial-rfc-1123-20220707-git.tgz"; + sha256 = "1w4ywpj10fnp7cya62dzlxlg8nyk4lppn2pnmfixsndwr4ib1h6x"; + system = "trivial-rfc-1123"; + asd = "trivial-rfc-1123"; + } + ); + systems = [ "trivial-rfc-1123" ]; + lispLibs = [ (getAttr "cl-ppcre" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-sanitize = ( + build-asdf-system { + pname = "trivial-sanitize"; + version = "20241012-git"; + asds = [ "trivial-sanitize" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-sanitize/2024-10-12/trivial-sanitize-20241012-git.tgz"; + sha256 = "18pc1diq0mfmr3ql79islv2mfm4y791vg9xwz3dwp8wa912dd93h"; + system = "trivial-sanitize"; + asd = "trivial-sanitize"; + } + ); + systems = [ "trivial-sanitize" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-html5-parser" self) + (getAttr "cl-ppcre-unicode" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-sanitize-tests = ( + build-asdf-system { + pname = "trivial-sanitize-tests"; + version = "20241012-git"; + asds = [ "trivial-sanitize-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-sanitize/2024-10-12/trivial-sanitize-20241012-git.tgz"; + sha256 = "18pc1diq0mfmr3ql79islv2mfm4y791vg9xwz3dwp8wa912dd93h"; + system = "trivial-sanitize-tests"; + asd = "trivial-sanitize-tests"; + } + ); + systems = [ "trivial-sanitize-tests" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "clunit2" self) + (getAttr "trivial-sanitize" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-shell = ( + build-asdf-system { + pname = "trivial-shell"; + version = "20241012-git"; + asds = [ "trivial-shell" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-shell/2024-10-12/trivial-shell-20241012-git.tgz"; + sha256 = "0cqfipcywi1ndl43walw7d54rd7layjq3wv2wpz5rlprv7dhpb2p"; + system = "trivial-shell"; + asd = "trivial-shell"; + } + ); + systems = [ "trivial-shell" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-shell-test = ( + build-asdf-system { + pname = "trivial-shell-test"; + version = "20241012-git"; + asds = [ "trivial-shell-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-shell/2024-10-12/trivial-shell-20241012-git.tgz"; + sha256 = "0cqfipcywi1ndl43walw7d54rd7layjq3wv2wpz5rlprv7dhpb2p"; + system = "trivial-shell-test"; + asd = "trivial-shell-test"; + } + ); + systems = [ "trivial-shell-test" ]; + lispLibs = [ + (getAttr "lift" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-signal = ( + build-asdf-system { + pname = "trivial-signal"; + version = "20190710-git"; + asds = [ "trivial-signal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-signal/2019-07-10/trivial-signal-20190710-git.tgz"; + sha256 = "13rh1jwh786xg235rkgqbdqga4b9jwn99zlxm0wr73rs2a5ga8ad"; + system = "trivial-signal"; + asd = "trivial-signal"; + } + ); + systems = [ "trivial-signal" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-sockets = ( + build-asdf-system { + pname = "trivial-sockets"; + version = "20190107-git"; + asds = [ "trivial-sockets" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-sockets/2019-01-07/trivial-sockets-20190107-git.tgz"; + sha256 = "0xj9x5z3psxqap9c29qz1xswx5fiqxyzd35kmbw2g6z08cgb7nd0"; + system = "trivial-sockets"; + asd = "trivial-sockets"; + } + ); + systems = [ "trivial-sockets" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-ssh = ( + build-asdf-system { + pname = "trivial-ssh"; + version = "20191130-git"; + asds = [ "trivial-ssh" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-ssh/2019-11-30/trivial-ssh-20191130-git.tgz"; + sha256 = "1hjd8bhbymq4s2jglid5i9m2b19cnf6c793gvkh6mawcjd37vjmb"; + system = "trivial-ssh"; + asd = "trivial-ssh"; + } + ); + systems = [ "trivial-ssh" ]; + lispLibs = [ (getAttr "trivial-ssh-libssh2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-ssh-libssh2 = ( + build-asdf-system { + pname = "trivial-ssh-libssh2"; + version = "20191130-git"; + asds = [ "trivial-ssh-libssh2" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-ssh/2019-11-30/trivial-ssh-20191130-git.tgz"; + sha256 = "1hjd8bhbymq4s2jglid5i9m2b19cnf6c793gvkh6mawcjd37vjmb"; + system = "trivial-ssh-libssh2"; + asd = "trivial-ssh-libssh2"; + } + ); + systems = [ "trivial-ssh-libssh2" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-fad" self) + (getAttr "split-sequence" self) + (getAttr "trivial-gray-streams" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-ssh-test = ( + build-asdf-system { + pname = "trivial-ssh-test"; + version = "20191130-git"; + asds = [ "trivial-ssh-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-ssh/2019-11-30/trivial-ssh-20191130-git.tgz"; + sha256 = "1hjd8bhbymq4s2jglid5i9m2b19cnf6c793gvkh6mawcjd37vjmb"; + system = "trivial-ssh-test"; + asd = "trivial-ssh-test"; + } + ); + systems = [ "trivial-ssh-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "trivial-ssh" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-system-loader = ( + build-asdf-system { + pname = "trivial-system-loader"; + version = "20241012-git"; + asds = [ "trivial-system-loader" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-system-loader/2024-10-12/trivial-system-loader-20241012-git.tgz"; + sha256 = "094j50asfgyhqcm86p47azviivap0hni2gjp3khdxcn4f9i9d2b0"; + system = "trivial-system-loader"; + asd = "trivial-system-loader"; + } + ); + systems = [ "trivial-system-loader" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-tco = ( + build-asdf-system { + pname = "trivial-tco"; + version = "20131003-git"; + asds = [ "trivial-tco" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-tco/2013-10-03/trivial-tco-20131003-git.tgz"; + sha256 = "0j6mkchrk6bzkpdkrahagip9lxxr8rx3qj4547wg8bdqr7mm2nmi"; + system = "trivial-tco"; + asd = "trivial-tco"; + } + ); + systems = [ "trivial-tco" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-tco-test = ( + build-asdf-system { + pname = "trivial-tco-test"; + version = "20131003-git"; + asds = [ "trivial-tco-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-tco/2013-10-03/trivial-tco-20131003-git.tgz"; + sha256 = "0j6mkchrk6bzkpdkrahagip9lxxr8rx3qj4547wg8bdqr7mm2nmi"; + system = "trivial-tco-test"; + asd = "trivial-tco-test"; + } + ); + systems = [ "trivial-tco-test" ]; + lispLibs = [ + (getAttr "clunit" self) + (getAttr "trivial-tco" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-thumbnail = ( + build-asdf-system { + pname = "trivial-thumbnail"; + version = "20231021-git"; + asds = [ "trivial-thumbnail" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-thumbnail/2023-10-21/trivial-thumbnail-20231021-git.tgz"; + sha256 = "1asa8vg8cyfr0kl86xrpywk0cpqym9lzhkhxb829lqr49vr8zfa7"; + system = "trivial-thumbnail"; + asd = "trivial-thumbnail"; + } + ); + systems = [ "trivial-thumbnail" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-timeout = ( + build-asdf-system { + pname = "trivial-timeout"; + version = "20231021-git"; + asds = [ "trivial-timeout" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-timeout/2023-10-21/trivial-timeout-20231021-git.tgz"; + sha256 = "0s8z9aj6b3kv21yiyk13cjylzf5zlnw9v86vcff477m1gk9yddjs"; + system = "trivial-timeout"; + asd = "trivial-timeout"; + } + ); + systems = [ "trivial-timeout" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-timer = ( + build-asdf-system { + pname = "trivial-timer"; + version = "20210531-git"; + asds = [ "trivial-timer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-timer/2021-05-31/trivial-timer-20210531-git.tgz"; + sha256 = "1b8pnw613h1dngzmv3qglmfrl1jdjbxrsbqnh7rfdj0lnv43h1il"; + system = "trivial-timer"; + asd = "trivial-timer"; + } + ); + systems = [ "trivial-timer" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "chanl" self) + (getAttr "iterate" self) + (getAttr "log4cl" self) + (getAttr "trivial-utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-toplevel-commands = ( + build-asdf-system { + pname = "trivial-toplevel-commands"; + version = "20241012-git"; + asds = [ "trivial-toplevel-commands" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-toplevel-commands/2024-10-12/trivial-toplevel-commands-20241012-git.tgz"; + sha256 = "03n0dpzgdgghc7cxj1s19w2wlx6r8f1s983f5a6cix5rigx9r834"; + system = "trivial-toplevel-commands"; + asd = "trivial-toplevel-commands"; + } + ); + systems = [ "trivial-toplevel-commands" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-toplevel-prompt = ( + build-asdf-system { + pname = "trivial-toplevel-prompt"; + version = "20241012-git"; + asds = [ "trivial-toplevel-prompt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-toplevel-prompt/2024-10-12/trivial-toplevel-prompt-20241012-git.tgz"; + sha256 = "07gvazwqiw37sic9zz8qnl3gz0b8n4qzrwbmg4wy3rlkps98i4s2"; + system = "trivial-toplevel-prompt"; + asd = "trivial-toplevel-prompt"; + } + ); + systems = [ "trivial-toplevel-prompt" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-types = ( + build-asdf-system { + pname = "trivial-types"; + version = "20120407-git"; + asds = [ "trivial-types" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-types/2012-04-07/trivial-types-20120407-git.tgz"; + sha256 = "1s4cp9bdlbn8447q7w7f1wkgwrbvfzp20mgs307l5pxvdslin341"; + system = "trivial-types"; + asd = "trivial-types"; + } + ); + systems = [ "trivial-types" ]; + lispLibs = [ ]; + meta = { }; + } + ); + trivial-update = ( + build-asdf-system { + pname = "trivial-update"; + version = "20180131-git"; + asds = [ "trivial-update" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-update/2018-01-31/trivial-update-20180131-git.tgz"; + sha256 = "0dpijh9alljk0jmnkp37hfliylscs7xwvlmjkfshizmyh0qjjxir"; + system = "trivial-update"; + asd = "trivial-update"; + } + ); + systems = [ "trivial-update" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-utf-8 = ( + build-asdf-system { + pname = "trivial-utf-8"; + version = "20231021-git"; + asds = [ "trivial-utf-8" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-utf-8/2023-10-21/trivial-utf-8-20231021-git.tgz"; + sha256 = "0paf7ldw6ffl5xilyri3rfygz1v1npagf186i1z8hyxxjkri4q9s"; + system = "trivial-utf-8"; + asd = "trivial-utf-8"; + } + ); + systems = [ "trivial-utf-8" ]; + lispLibs = [ (getAttr "mgl-pax-bootstrap" self) ]; + meta = { }; + } + ); + trivial-utilities = ( + build-asdf-system { + pname = "trivial-utilities"; + version = "20220707-git"; + asds = [ "trivial-utilities" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-utilities/2022-07-07/trivial-utilities-20220707-git.tgz"; + sha256 = "0k1xmn5f5dik7scadw0vyy67mik4ypnfqbhlv2vsg9afxzbpx2dz"; + system = "trivial-utilities"; + asd = "trivial-utilities"; + } + ); + systems = [ "trivial-utilities" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-variable-bindings = ( + build-asdf-system { + pname = "trivial-variable-bindings"; + version = "20191007-git"; + asds = [ "trivial-variable-bindings" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-variable-bindings/2019-10-07/trivial-variable-bindings-20191007-git.tgz"; + sha256 = "08lx5m1bspxsnv572zma1hxk3yfyk9fkmi5cvcr5riannyimdqgy"; + system = "trivial-variable-bindings"; + asd = "trivial-variable-bindings"; + } + ); + systems = [ "trivial-variable-bindings" ]; + lispLibs = [ + (getAttr "iterate" self) + (getAttr "trivial-utilities" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-wish = ( + build-asdf-system { + pname = "trivial-wish"; + version = "quicklisp-910afeea-git"; + asds = [ "trivial-wish" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-wish/2017-06-30/trivial-wish-quicklisp-910afeea-git.tgz"; + sha256 = "1ydb9vsanrv6slbddhxc38pq5s88k0rzgqnwabw5cgc8cp5gqvyp"; + system = "trivial-wish"; + asd = "trivial-wish"; + } + ); + systems = [ "trivial-wish" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-with = ( + build-asdf-system { + pname = "trivial-with"; + version = "quicklisp-2fd8ca54-git"; + asds = [ "trivial-with" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-with/2017-08-30/trivial-with-quicklisp-2fd8ca54-git.tgz"; + sha256 = "1h880j9k7piq6y5a6sywn1r43h439dd6vfymqvhgnbx458wy69sq"; + system = "trivial-with"; + asd = "trivial-with"; + } + ); + systems = [ "trivial-with" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-with-current-source-form = ( + build-asdf-system { + pname = "trivial-with-current-source-form"; + version = "20230618-git"; + asds = [ "trivial-with-current-source-form" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-with-current-source-form/2023-06-18/trivial-with-current-source-form-20230618-git.tgz"; + sha256 = "1856m234mcg8l0p63h0j76isx8n2iji569b4r4zf7qs135xbw930"; + system = "trivial-with-current-source-form"; + asd = "trivial-with-current-source-form"; + } + ); + systems = [ "trivial-with-current-source-form" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { }; + } + ); + trivial-ws = ( + build-asdf-system { + pname = "trivial-ws"; + version = "20180131-git"; + asds = [ "trivial-ws" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-ws/2018-01-31/trivial-ws-20180131-git.tgz"; + sha256 = "0qmsf0dhmyhjgqjzdgj2yb1nkrijwp4p1j411613i45xjc2zd6m7"; + system = "trivial-ws"; + asd = "trivial-ws"; + } + ); + systems = [ "trivial-ws" ]; + lispLibs = [ (getAttr "hunchensocket" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-ws-client = ( + build-asdf-system { + pname = "trivial-ws-client"; + version = "20180131-git"; + asds = [ "trivial-ws-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-ws/2018-01-31/trivial-ws-20180131-git.tgz"; + sha256 = "0qmsf0dhmyhjgqjzdgj2yb1nkrijwp4p1j411613i45xjc2zd6m7"; + system = "trivial-ws-client"; + asd = "trivial-ws-client"; + } + ); + systems = [ "trivial-ws-client" ]; + lispLibs = [ + (getAttr "cl-async" self) + (getAttr "websocket-driver" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-ws-test = ( + build-asdf-system { + pname = "trivial-ws-test"; + version = "20180131-git"; + asds = [ "trivial-ws-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-ws/2018-01-31/trivial-ws-20180131-git.tgz"; + sha256 = "0qmsf0dhmyhjgqjzdgj2yb1nkrijwp4p1j411613i45xjc2zd6m7"; + system = "trivial-ws-test"; + asd = "trivial-ws-test"; + } + ); + systems = [ "trivial-ws-test" ]; + lispLibs = [ + (getAttr "find-port" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "trivial-ws" self) + (getAttr "trivial-ws-client" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivial-yenc = ( + build-asdf-system { + pname = "trivial-yenc"; + version = "20161204-git"; + asds = [ "trivial-yenc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivial-yenc/2016-12-04/trivial-yenc-20161204-git.tgz"; + sha256 = "0jsqwixgikdinc1rq22c4dh9kgg6z0kvw9rh9sbssbmxv99sb5bf"; + system = "trivial-yenc"; + asd = "trivial-yenc"; + } + ); + systems = [ "trivial-yenc" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivialib_dot_bdd = ( + build-asdf-system { + pname = "trivialib.bdd"; + version = "20211209-git"; + asds = [ "trivialib.bdd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivialib.bdd/2021-12-09/trivialib.bdd-20211209-git.tgz"; + sha256 = "1iqpcihpm6glr0afi35z6qifj0ppl7s4h1k94fn6lqpv2js6lzbr"; + system = "trivialib.bdd"; + asd = "trivialib.bdd"; + } + ); + systems = [ "trivialib.bdd" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "immutable-struct" self) + (getAttr "trivia" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivialib_dot_bdd_dot_test = ( + build-asdf-system { + pname = "trivialib.bdd.test"; + version = "20211209-git"; + asds = [ "trivialib.bdd.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivialib.bdd/2021-12-09/trivialib.bdd-20211209-git.tgz"; + sha256 = "1iqpcihpm6glr0afi35z6qifj0ppl7s4h1k94fn6lqpv2js6lzbr"; + system = "trivialib.bdd.test"; + asd = "trivialib.bdd.test"; + } + ); + systems = [ "trivialib.bdd.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "trivialib_dot_bdd" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivialib_dot_type-unify = ( + build-asdf-system { + pname = "trivialib.type-unify"; + version = "20200325-git"; + asds = [ "trivialib.type-unify" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivialib.type-unify/2020-03-25/trivialib.type-unify-20200325-git.tgz"; + sha256 = "0b5ck9ldn1w3imgpxyh164bypy28kvjzkwlcyyfsc0h1njnm5jmy"; + system = "trivialib.type-unify"; + asd = "trivialib.type-unify"; + } + ); + systems = [ "trivialib.type-unify" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "introspect-environment" self) + (getAttr "trivia" self) + (getAttr "type-r" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trivialib_dot_type-unify_dot_test = ( + build-asdf-system { + pname = "trivialib.type-unify.test"; + version = "20200325-git"; + asds = [ "trivialib.type-unify.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trivialib.type-unify/2020-03-25/trivialib.type-unify-20200325-git.tgz"; + sha256 = "0b5ck9ldn1w3imgpxyh164bypy28kvjzkwlcyyfsc0h1njnm5jmy"; + system = "trivialib.type-unify.test"; + asd = "trivialib.type-unify.test"; + } + ); + systems = [ "trivialib.type-unify.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "trivialib_dot_type-unify" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trucler = ( + build-asdf-system { + pname = "trucler"; + version = "20231021-git"; + asds = [ "trucler" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trucler/2023-10-21/trucler-20231021-git.tgz"; + sha256 = "16cxx9pgpn3bkrmazc4lqhmaf20c0rhp1vaj78ms8ldwfqqrgznr"; + system = "trucler"; + asd = "trucler"; + } + ); + systems = [ "trucler" ]; + lispLibs = [ + (getAttr "trucler-base" self) + (getAttr "trucler-native" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trucler-base = ( + build-asdf-system { + pname = "trucler-base"; + version = "20231021-git"; + asds = [ "trucler-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trucler/2023-10-21/trucler-20231021-git.tgz"; + sha256 = "16cxx9pgpn3bkrmazc4lqhmaf20c0rhp1vaj78ms8ldwfqqrgznr"; + system = "trucler-base"; + asd = "trucler-base"; + } + ); + systems = [ "trucler-base" ]; + lispLibs = [ (getAttr "acclimation" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trucler-native = ( + build-asdf-system { + pname = "trucler-native"; + version = "20231021-git"; + asds = [ "trucler-native" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trucler/2023-10-21/trucler-20231021-git.tgz"; + sha256 = "16cxx9pgpn3bkrmazc4lqhmaf20c0rhp1vaj78ms8ldwfqqrgznr"; + system = "trucler-native"; + asd = "trucler-native"; + } + ); + systems = [ "trucler-native" ]; + lispLibs = [ (getAttr "trucler-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trucler-native-test = ( + build-asdf-system { + pname = "trucler-native-test"; + version = "20231021-git"; + asds = [ "trucler-native-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trucler/2023-10-21/trucler-20231021-git.tgz"; + sha256 = "16cxx9pgpn3bkrmazc4lqhmaf20c0rhp1vaj78ms8ldwfqqrgznr"; + system = "trucler-native-test"; + asd = "trucler-native-test"; + } + ); + systems = [ "trucler-native-test" ]; + lispLibs = [ + (getAttr "trucler-base" self) + (getAttr "trucler-native" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + trucler-reference = ( + build-asdf-system { + pname = "trucler-reference"; + version = "20231021-git"; + asds = [ "trucler-reference" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/trucler/2023-10-21/trucler-20231021-git.tgz"; + sha256 = "16cxx9pgpn3bkrmazc4lqhmaf20c0rhp1vaj78ms8ldwfqqrgznr"; + system = "trucler-reference"; + asd = "trucler-reference"; + } + ); + systems = [ "trucler-reference" ]; + lispLibs = [ (getAttr "trucler-base" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + truetype-clx = ( + build-asdf-system { + pname = "truetype-clx"; + version = "20200218-git"; + asds = [ "truetype-clx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/truetype-clx/2020-02-18/truetype-clx-20200218-git.tgz"; + sha256 = "1k46xa0nclj0mpd7khnlpam6q5hgnp23jixryhvv96gx47swhddr"; + system = "truetype-clx"; + asd = "truetype-clx"; + } + ); + systems = [ "truetype-clx" ]; + lispLibs = [ + (getAttr "cl-aa" self) + (getAttr "cl-paths-ttf" self) + (getAttr "cl-vectors" self) + (getAttr "zpb-ttf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + try = ( + build-asdf-system { + pname = "try"; + version = "20231021-git"; + asds = [ "try" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/try/2023-10-21/try-20231021-git.tgz"; + sha256 = "166i3fqwxfv9skz6yf95c95nx0jjqy1ak1131bd0sqmd582gi9mg"; + system = "try"; + asd = "try"; + } + ); + systems = [ "try" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "ieee-floats" self) + (getAttr "mgl-pax" self) + (getAttr "trivial-gray-streams" self) + (getAttr "try_dot_asdf" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + try_dot_asdf = ( + build-asdf-system { + pname = "try.asdf"; + version = "20231021-git"; + asds = [ "try.asdf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/try/2023-10-21/try-20231021-git.tgz"; + sha256 = "166i3fqwxfv9skz6yf95c95nx0jjqy1ak1131bd0sqmd582gi9mg"; + system = "try.asdf"; + asd = "try.asdf"; + } + ); + systems = [ "try.asdf" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + tsqueue = ( + build-asdf-system { + pname = "tsqueue"; + version = "20221106-git"; + asds = [ "tsqueue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/tsqueue/2022-11-06/tsqueue-20221106-git.tgz"; + sha256 = "1ifq53b95a1sdpgx1hlz31pjbh0z6izh3wrgsiqvzgkbiyxq513q"; + system = "tsqueue"; + asd = "tsqueue"; + } + ); + systems = [ "tsqueue" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ttt = ( + build-asdf-system { + pname = "ttt"; + version = "20220707-git"; + asds = [ "ttt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ttt/2022-07-07/ttt-20220707-git.tgz"; + sha256 = "0g6p8gpl8hl427mfrrf8824zq6wmkj11v1xq7pyv7v0b5cwp5ccv"; + system = "ttt"; + asd = "ttt"; + } + ); + systems = [ "ttt" ]; + lispLibs = [ (getAttr "bordeaux-threads" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + twfy = ( + build-asdf-system { + pname = "twfy"; + version = "20130420-git"; + asds = [ "twfy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/twfy/2013-04-20/twfy-20130420-git.tgz"; + sha256 = "1srns5ayg7q8dzviizgm7j767dxbbyzh2ca8a5wdz3bc0qmwrsbs"; + system = "twfy"; + asd = "twfy"; + } + ); + systems = [ "twfy" ]; + lispLibs = [ + (getAttr "cl-json" self) + (getAttr "drakma" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + twitter-mongodb-driver = ( + build-asdf-system { + pname = "twitter-mongodb-driver"; + version = "20180228-git"; + asds = [ "twitter-mongodb-driver" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-twitter/2018-02-28/cl-twitter-20180228-git.tgz"; + sha256 = "07l86c63ssahpz3s9f7d99mbzmh60askkpdrhjrdbzd1vxlwkhcr"; + system = "twitter-mongodb-driver"; + asd = "twitter-mongodb-driver"; + } + ); + systems = [ "twitter-mongodb-driver" ]; + lispLibs = [ + (getAttr "cl-mongo" self) + (getAttr "cl-twitter" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + type-i = ( + build-asdf-system { + pname = "type-i"; + version = "20230214-git"; + asds = [ "type-i" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/type-i/2023-02-14/type-i-20230214-git.tgz"; + sha256 = "1y9dh1iziv3gwpf5yls0amwjhdqjidfibcla04mz6dqdv3zrg3hs"; + system = "type-i"; + asd = "type-i"; + } + ); + systems = [ "type-i" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "introspect-environment" self) + (getAttr "lisp-namespace" self) + (getAttr "trivia_dot_trivial" self) + ]; + meta = { }; + } + ); + type-i_dot_test = ( + build-asdf-system { + pname = "type-i.test"; + version = "20230214-git"; + asds = [ "type-i.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/type-i/2023-02-14/type-i-20230214-git.tgz"; + sha256 = "1y9dh1iziv3gwpf5yls0amwjhdqjidfibcla04mz6dqdv3zrg3hs"; + system = "type-i.test"; + asd = "type-i.test"; + } + ); + systems = [ "type-i.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "type-i" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + type-r = ( + build-asdf-system { + pname = "type-r"; + version = "20191227-git"; + asds = [ "type-r" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/type-r/2019-12-27/type-r-20191227-git.tgz"; + sha256 = "1arsxc2539rg8vbrdirz4xxj1b06mc6g6rqndz7a02g127qvk2sm"; + system = "type-r"; + asd = "type-r"; + } + ); + systems = [ "type-r" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + type-r_dot_test = ( + build-asdf-system { + pname = "type-r.test"; + version = "20191227-git"; + asds = [ "type-r.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/type-r/2019-12-27/type-r-20191227-git.tgz"; + sha256 = "1arsxc2539rg8vbrdirz4xxj1b06mc6g6rqndz7a02g127qvk2sm"; + system = "type-r.test"; + asd = "type-r.test"; + } + ); + systems = [ "type-r.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "type-r" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + type-templates = ( + build-asdf-system { + pname = "type-templates"; + version = "20241012-git"; + asds = [ "type-templates" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/type-templates/2024-10-12/type-templates-20241012-git.tgz"; + sha256 = "1zmz3bmwg8ncqbnjwimn8n7q9ik9arnhd5ijd22ap1nwhbnmk1rj"; + system = "type-templates"; + asd = "type-templates"; + } + ); + systems = [ "type-templates" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "documentation-utils" self) + (getAttr "form-fiddle" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + typo = ( + build-asdf-system { + pname = "typo"; + version = "20241012-git"; + asds = [ "typo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/typo/2024-10-12/typo-20241012-git.tgz"; + sha256 = "1xgrfj1yxay04zf1ppf56b4j5p1wn67zfhiwpfd30dvk53mcrlik"; + system = "typo"; + asd = "typo"; + } + ); + systems = [ "typo" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "introspect-environment" self) + (getAttr "trivia" self) + (getAttr "trivial-arguments" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + typo_dot_test-suite = ( + build-asdf-system { + pname = "typo.test-suite"; + version = "20241012-git"; + asds = [ "typo.test-suite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/typo/2024-10-12/typo-20241012-git.tgz"; + sha256 = "1xgrfj1yxay04zf1ppf56b4j5p1wn67zfhiwpfd30dvk53mcrlik"; + system = "typo.test-suite"; + asd = "typo.test-suite"; + } + ); + systems = [ "typo.test-suite" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "typo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + uax-14 = ( + build-asdf-system { + pname = "uax-14"; + version = "20231021-git"; + asds = [ "uax-14" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uax-14/2023-10-21/uax-14-20231021-git.tgz"; + sha256 = "1k9cqs9lb5i2y9b3zgrr1kq2w8bcr3h362105ykz0if5yz8m59fq"; + system = "uax-14"; + asd = "uax-14"; + } + ); + systems = [ "uax-14" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + uax-14-test = ( + build-asdf-system { + pname = "uax-14-test"; + version = "20231021-git"; + asds = [ "uax-14-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uax-14/2023-10-21/uax-14-20231021-git.tgz"; + sha256 = "1k9cqs9lb5i2y9b3zgrr1kq2w8bcr3h362105ykz0if5yz8m59fq"; + system = "uax-14-test"; + asd = "uax-14-test"; + } + ); + systems = [ "uax-14-test" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "parachute" self) + (getAttr "uax-14" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + uax-15 = ( + build-asdf-system { + pname = "uax-15"; + version = "20241012-git"; + asds = [ "uax-15" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uax-15/2024-10-12/uax-15-20241012-git.tgz"; + sha256 = "12qkq4r6qv5cn535bwpkq7zfahajlrv8v7661x4wzf4pp0avx7n6"; + system = "uax-15"; + asd = "uax-15"; + } + ); + systems = [ "uax-15" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "split-sequence" self) + ]; + meta = { }; + } + ); + uax-9 = ( + build-asdf-system { + pname = "uax-9"; + version = "20231021-git"; + asds = [ "uax-9" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uax-9/2023-10-21/uax-9-20231021-git.tgz"; + sha256 = "1kbq8v45pxhmwqn6is5lfsp51h80kns4s1cqbh9z0xdmxzw63ip1"; + system = "uax-9"; + asd = "uax-9"; + } + ); + systems = [ "uax-9" ]; + lispLibs = [ (getAttr "documentation-utils" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + uax-9-test = ( + build-asdf-system { + pname = "uax-9-test"; + version = "20231021-git"; + asds = [ "uax-9-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uax-9/2023-10-21/uax-9-20231021-git.tgz"; + sha256 = "1kbq8v45pxhmwqn6is5lfsp51h80kns4s1cqbh9z0xdmxzw63ip1"; + system = "uax-9-test"; + asd = "uax-9-test"; + } + ); + systems = [ "uax-9-test" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "parachute" self) + (getAttr "uax-9" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ubiquitous = ( + build-asdf-system { + pname = "ubiquitous"; + version = "20231021-git"; + asds = [ "ubiquitous" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ubiquitous/2023-10-21/ubiquitous-20231021-git.tgz"; + sha256 = "02q6yz9j374q23avi06lddy6gkzza0xn3855n7dqgy34fv1shw1i"; + system = "ubiquitous"; + asd = "ubiquitous"; + } + ); + systems = [ "ubiquitous" ]; + lispLibs = [ ]; + meta = { + broken = true; + hydraPlatforms = [ ]; + }; + } + ); + ubiquitous-concurrent = ( + build-asdf-system { + pname = "ubiquitous-concurrent"; + version = "20231021-git"; + asds = [ "ubiquitous-concurrent" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ubiquitous/2023-10-21/ubiquitous-20231021-git.tgz"; + sha256 = "02q6yz9j374q23avi06lddy6gkzza0xn3855n7dqgy34fv1shw1i"; + system = "ubiquitous-concurrent"; + asd = "ubiquitous-concurrent"; + } + ); + systems = [ "ubiquitous-concurrent" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "ubiquitous" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ucons = ( + build-asdf-system { + pname = "ucons"; + version = "20230618-git"; + asds = [ "ucons" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ucons/2023-06-18/ucons-20230618-git.tgz"; + sha256 = "0pisf8sswh1wainabpnczla8c98kr0lv0qvh0zapwkf1lq1drzp1"; + system = "ucons"; + asd = "ucons"; + } + ); + systems = [ "ucons" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "atomics" self) + (getAttr "bordeaux-threads" self) + (getAttr "named-readtables" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ucw = ( + build-asdf-system { + pname = "ucw"; + version = "20160208-darcs"; + asds = [ "ucw" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ucw/2016-02-08/ucw-20160208-darcs.tgz"; + sha256 = "0wd7816zr53bw9z9a48cx1khj15d1jii5wzgqns1c5x70brgy89z"; + system = "ucw"; + asd = "ucw"; + } + ); + systems = [ "ucw" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "ucw-core" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ucw-core = ( + build-asdf-system { + pname = "ucw-core"; + version = "20160208-darcs"; + asds = [ "ucw-core" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ucw/2016-02-08/ucw-20160208-darcs.tgz"; + sha256 = "0wd7816zr53bw9z9a48cx1khj15d1jii5wzgqns1c5x70brgy89z"; + system = "ucw-core"; + asd = "ucw-core"; + } + ); + systems = [ "ucw-core" ]; + lispLibs = [ + (getAttr "arnesi" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-fad" self) + (getAttr "closer-mop" self) + (getAttr "iterate" self) + (getAttr "local-time" self) + (getAttr "net-telent-date" self) + (getAttr "rfc2109" self) + (getAttr "swank" self) + (getAttr "trivial-garbage" self) + (getAttr "usocket" self) + (getAttr "yaclml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ucw-core_dot_test = ( + build-asdf-system { + pname = "ucw-core.test"; + version = "20160208-darcs"; + asds = [ "ucw-core.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ucw/2016-02-08/ucw-20160208-darcs.tgz"; + sha256 = "0wd7816zr53bw9z9a48cx1khj15d1jii5wzgqns1c5x70brgy89z"; + system = "ucw-core.test"; + asd = "ucw-core"; + } + ); + systems = [ "ucw-core.test" ]; + lispLibs = [ + (getAttr "arnesi" self) + (getAttr "cxml" self) + (getAttr "drakma" self) + (getAttr "iterate" self) + (getAttr "stefil" self) + (getAttr "ucw-core" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ucw_dot_examples = ( + build-asdf-system { + pname = "ucw.examples"; + version = "20160208-darcs"; + asds = [ "ucw.examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ucw/2016-02-08/ucw-20160208-darcs.tgz"; + sha256 = "0wd7816zr53bw9z9a48cx1khj15d1jii5wzgqns1c5x70brgy89z"; + system = "ucw.examples"; + asd = "ucw"; + } + ); + systems = [ "ucw.examples" ]; + lispLibs = [ (getAttr "ucw" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ucw_dot_httpd = ( + build-asdf-system { + pname = "ucw.httpd"; + version = "20160208-darcs"; + asds = [ "ucw.httpd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ucw/2016-02-08/ucw-20160208-darcs.tgz"; + sha256 = "0wd7816zr53bw9z9a48cx1khj15d1jii5wzgqns1c5x70brgy89z"; + system = "ucw.httpd"; + asd = "ucw-core"; + } + ); + systems = [ "ucw.httpd" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "puri" self) + (getAttr "rfc2388-binary" self) + (getAttr "ucw-core" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ucw_dot_manual-examples = ( + build-asdf-system { + pname = "ucw.manual-examples"; + version = "20160208-darcs"; + asds = [ "ucw.manual-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ucw/2016-02-08/ucw-20160208-darcs.tgz"; + sha256 = "0wd7816zr53bw9z9a48cx1khj15d1jii5wzgqns1c5x70brgy89z"; + system = "ucw.manual-examples"; + asd = "ucw"; + } + ); + systems = [ "ucw.manual-examples" ]; + lispLibs = [ (getAttr "ucw" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + uffi = ( + build-asdf-system { + pname = "uffi"; + version = "20180228-git"; + asds = [ "uffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uffi/2018-02-28/uffi-20180228-git.tgz"; + sha256 = "0ywly04k8vir39ld7ids80yjn34y3y3mlpky1pr1fh9p8q412a85"; + system = "uffi"; + asd = "uffi"; + } + ); + systems = [ "uffi" ]; + lispLibs = [ ]; + meta = { }; + } + ); + uffi-tests = ( + build-asdf-system { + pname = "uffi-tests"; + version = "20180228-git"; + asds = [ "uffi-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uffi/2018-02-28/uffi-20180228-git.tgz"; + sha256 = "0ywly04k8vir39ld7ids80yjn34y3y3mlpky1pr1fh9p8q412a85"; + system = "uffi-tests"; + asd = "uffi-tests"; + } + ); + systems = [ "uffi-tests" ]; + lispLibs = [ (getAttr "uffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ufo = ( + build-asdf-system { + pname = "ufo"; + version = "20210807-git"; + asds = [ "ufo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ufo/2021-08-07/ufo-20210807-git.tgz"; + sha256 = "0bbq4pjnbmf1zpmh11jlriv0qnvrhw1xxnjj2y35gk75rr8rvizy"; + system = "ufo"; + asd = "ufo"; + } + ); + systems = [ "ufo" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ufo-test = ( + build-asdf-system { + pname = "ufo-test"; + version = "20210807-git"; + asds = [ "ufo-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ufo/2021-08-07/ufo-20210807-git.tgz"; + sha256 = "0bbq4pjnbmf1zpmh11jlriv0qnvrhw1xxnjj2y35gk75rr8rvizy"; + system = "ufo-test"; + asd = "ufo-test"; + } + ); + systems = [ "ufo-test" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "ufo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ugly-tiny-infix-macro = ( + build-asdf-system { + pname = "ugly-tiny-infix-macro"; + version = "20160825-git"; + asds = [ "ugly-tiny-infix-macro" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ugly-tiny-infix-macro/2016-08-25/ugly-tiny-infix-macro-20160825-git.tgz"; + sha256 = "15bbnr3kzy3p35skm6bkyyl5ck4d264am0zyjsix5k58d9fli3ii"; + system = "ugly-tiny-infix-macro"; + asd = "ugly-tiny-infix-macro"; + } + ); + systems = [ "ugly-tiny-infix-macro" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + umbra = ( + build-asdf-system { + pname = "umbra"; + version = "20220707-git"; + asds = [ "umbra" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/umbra/2022-07-07/umbra-20220707-git.tgz"; + sha256 = "125bsf69gzdy0r6jh6fz8000rqww1rji354x0yrgmkz9x3mvz4k4"; + system = "umbra"; + asd = "umbra"; + } + ); + systems = [ "umbra" ]; + lispLibs = [ + (getAttr "mfiano-utils" self) + (getAttr "shadow" self) + (getAttr "varjo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + umlisp = ( + build-asdf-system { + pname = "umlisp"; + version = "20210411-git"; + asds = [ "umlisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/umlisp/2021-04-11/umlisp-20210411-git.tgz"; + sha256 = "1yyyn1qka4iw3hwii7i8k939dbwvhn543m8qclk2ajggkdky4mqb"; + system = "umlisp"; + asd = "umlisp"; + } + ); + systems = [ "umlisp" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "clsql-mysql" self) + (getAttr "hyperobject" self) + (getAttr "kmrcl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + umlisp-orf = ( + build-asdf-system { + pname = "umlisp-orf"; + version = "20150923-git"; + asds = [ "umlisp-orf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/umlisp-orf/2015-09-23/umlisp-orf-20150923-git.tgz"; + sha256 = "187i9rcj3rymi8hmlvglvig7yqandzzx57x0rzr4yfv8sgnb82qx"; + system = "umlisp-orf"; + asd = "umlisp-orf"; + } + ); + systems = [ "umlisp-orf" ]; + lispLibs = [ + (getAttr "clsql" self) + (getAttr "clsql-postgresql-socket" self) + (getAttr "hyperobject" self) + (getAttr "kmrcl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + umlisp-tests = ( + build-asdf-system { + pname = "umlisp-tests"; + version = "20210411-git"; + asds = [ "umlisp-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/umlisp/2021-04-11/umlisp-20210411-git.tgz"; + sha256 = "1yyyn1qka4iw3hwii7i8k939dbwvhn543m8qclk2ajggkdky4mqb"; + system = "umlisp-tests"; + asd = "umlisp-tests"; + } + ); + systems = [ "umlisp-tests" ]; + lispLibs = [ + (getAttr "rt" self) + (getAttr "umlisp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + unboxables = ( + build-asdf-system { + pname = "unboxables"; + version = "20231021-git"; + asds = [ "unboxables" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/unboxables/2023-10-21/unboxables-20231021-git.tgz"; + sha256 = "099qcsc9q9q5cz2qlvkylc2g8g80fqzrxyq4lc072bmw96wy27fs"; + system = "unboxables"; + asd = "unboxables"; + } + ); + systems = [ "unboxables" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + uncommon-lisp = ( + build-asdf-system { + pname = "uncommon-lisp"; + version = "20200427-git"; + asds = [ "uncommon-lisp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "uncommon-lisp"; + asd = "uncommon-lisp"; + } + ); + systems = [ "uncommon-lisp" ]; + lispLibs = [ (getAttr "structy-defclass" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + uncursed = ( + build-asdf-system { + pname = "uncursed"; + version = "20220220-git"; + asds = [ "uncursed" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uncursed/2022-02-20/uncursed-20220220-git.tgz"; + sha256 = "1hydiwh12851rrm12y0a6pb2jml2cjdk8wxvz4c00d2xwraqc6mr"; + system = "uncursed"; + asd = "uncursed"; + } + ); + systems = [ "uncursed" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl-setlocale" self) + (getAttr "terminfo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + uncursed-examples = ( + build-asdf-system { + pname = "uncursed-examples"; + version = "20220220-git"; + asds = [ "uncursed-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uncursed/2022-02-20/uncursed-20220220-git.tgz"; + sha256 = "1hydiwh12851rrm12y0a6pb2jml2cjdk8wxvz4c00d2xwraqc6mr"; + system = "uncursed-examples"; + asd = "uncursed-examples"; + } + ); + systems = [ "uncursed-examples" ]; + lispLibs = [ + (getAttr "cffi-grovel" self) + (getAttr "uncursed" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + unifgram = ( + build-asdf-system { + pname = "unifgram"; + version = "20180228-git"; + asds = [ "unifgram" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/paiprolog/2018-02-28/paiprolog-20180228-git.tgz"; + sha256 = "1nxz01i6f8s920gm69r2kwjdpq9pli8b2ayqwijhzgjwi0r4jj9r"; + system = "unifgram"; + asd = "unifgram"; + } + ); + systems = [ "unifgram" ]; + lispLibs = [ (getAttr "paiprolog" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + unit-formulas = ( + build-asdf-system { + pname = "unit-formulas"; + version = "20180711-git"; + asds = [ "unit-formulas" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/unit-formula/2018-07-11/unit-formula-20180711-git.tgz"; + sha256 = "1j9zcnyj2ik7f2130pkfwr2bhh5ldlgc83n1024w0dy95ksl1f20"; + system = "unit-formulas"; + asd = "unit-formulas"; + } + ); + systems = [ "unit-formulas" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + unit-test = ( + build-asdf-system { + pname = "unit-test"; + version = "20120520-git"; + asds = [ "unit-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/unit-test/2012-05-20/unit-test-20120520-git.tgz"; + sha256 = "11hpksz56iqkv7jw25p2a8r3n9dj922fyarn16d98589g6hdskj9"; + system = "unit-test"; + asd = "unit-test"; + } + ); + systems = [ "unit-test" ]; + lispLibs = [ ]; + meta = { }; + } + ); + universal-config = ( + build-asdf-system { + pname = "universal-config"; + version = "20180430-git"; + asds = [ "universal-config" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/universal-config/2018-04-30/universal-config-20180430-git.tgz"; + sha256 = "17sjd37jwsi47yhsj9qsnfyhyrlhlxdrxa4szklwjh489hf01hd0"; + system = "universal-config"; + asd = "universal-config"; + } + ); + systems = [ "universal-config" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "parse-float" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + unix-options = ( + build-asdf-system { + pname = "unix-options"; + version = "20151031-git"; + asds = [ "unix-options" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/unix-options/2015-10-31/unix-options-20151031-git.tgz"; + sha256 = "17q7irrbmaja7gj86h01ali9n9p782jxisgkb1r2q5ajf4lr1rsv"; + system = "unix-options"; + asd = "unix-options"; + } + ); + systems = [ "unix-options" ]; + lispLibs = [ ]; + meta = { }; + } + ); + unix-opts = ( + build-asdf-system { + pname = "unix-opts"; + version = "20210124-git"; + asds = [ "unix-opts" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/unix-opts/2021-01-24/unix-opts-20210124-git.tgz"; + sha256 = "16mcqpzwrz808p9n3wwl99ckg3hg7yihw08y1i4l7c92aldbkasq"; + system = "unix-opts"; + asd = "unix-opts"; + } + ); + systems = [ "unix-opts" ]; + lispLibs = [ ]; + meta = { }; + } + ); + unix-sockets = ( + build-asdf-system { + pname = "unix-sockets"; + version = "20241012-git"; + asds = [ "unix-sockets" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-unix-sockets/2024-10-12/cl-unix-sockets-20241012-git.tgz"; + sha256 = "09l3032p3gavyin1hn45yqv6b3vrg74vzcz85ppqg4nzpmp44845"; + system = "unix-sockets"; + asd = "unix-sockets"; + } + ); + systems = [ "unix-sockets" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "flexi-streams" self) + (getAttr "log4cl" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-gray-streams" self) + (getAttr "uffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + unix-sockets_dot_tests = ( + build-asdf-system { + pname = "unix-sockets.tests"; + version = "20241012-git"; + asds = [ "unix-sockets.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-unix-sockets/2024-10-12/cl-unix-sockets-20241012-git.tgz"; + sha256 = "09l3032p3gavyin1hn45yqv6b3vrg74vzcz85ppqg4nzpmp44845"; + system = "unix-sockets.tests"; + asd = "unix-sockets.tests"; + } + ); + systems = [ "unix-sockets.tests" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "fiveam" self) + (getAttr "tmpdir" self) + (getAttr "trivial-timeout" self) + (getAttr "unix-sockets" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + uri-template = ( + build-asdf-system { + pname = "uri-template"; + version = "1.3.1"; + asds = [ "uri-template" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uri-template/2019-08-13/uri-template-1.3.1.tgz"; + sha256 = "06n5kmjax64kv57ng5g2030a67z131i4wm53npg9zq2xlj9sprd8"; + system = "uri-template"; + asd = "uri-template"; + } + ); + systems = [ "uri-template" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "named-readtables" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + uri-template_dot_test = ( + build-asdf-system { + pname = "uri-template.test"; + version = "1.3.1"; + asds = [ "uri-template.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uri-template/2019-08-13/uri-template-1.3.1.tgz"; + sha256 = "06n5kmjax64kv57ng5g2030a67z131i4wm53npg9zq2xlj9sprd8"; + system = "uri-template.test"; + asd = "uri-template.test"; + } + ); + systems = [ "uri-template.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "uri-template" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + url-rewrite = ( + build-asdf-system { + pname = "url-rewrite"; + version = "20171227-git"; + asds = [ "url-rewrite" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/url-rewrite/2017-12-27/url-rewrite-20171227-git.tgz"; + sha256 = "0d3awcb938ajiylyfnbqsc7nndy6csx0qz1bcyr4f0p862w3xbqf"; + system = "url-rewrite"; + asd = "url-rewrite"; + } + ); + systems = [ "url-rewrite" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + userial = ( + build-asdf-system { + pname = "userial"; + version = "0.8.2011.06.02"; + asds = [ "userial" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/userial/2011-06-19/userial_0.8.2011.06.02.tgz"; + sha256 = "08f8hc1f81gyn4br9p732p8r2gl6cvccd4yzc9ydz4i0ijclpp2m"; + system = "userial"; + asd = "userial"; + } + ); + systems = [ "userial" ]; + lispLibs = [ + (getAttr "contextl" self) + (getAttr "ieee-floats" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + userial-tests = ( + build-asdf-system { + pname = "userial-tests"; + version = "0.8.2011.06.02"; + asds = [ "userial-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/userial/2011-06-19/userial_0.8.2011.06.02.tgz"; + sha256 = "08f8hc1f81gyn4br9p732p8r2gl6cvccd4yzc9ydz4i0ijclpp2m"; + system = "userial-tests"; + asd = "userial-tests"; + } + ); + systems = [ "userial-tests" ]; + lispLibs = [ + (getAttr "nst" self) + (getAttr "userial" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + usocket = ( + build-asdf-system { + pname = "usocket"; + version = "0.8.8"; + asds = [ "usocket" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/usocket/2024-10-12/usocket-0.8.8.tgz"; + sha256 = "13j2hyl7j06vl8hh3930wd3bi2p0pcg4dcd243al31fgw4m0bvag"; + system = "usocket"; + asd = "usocket"; + } + ); + systems = [ "usocket" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { }; + } + ); + usocket-server = ( + build-asdf-system { + pname = "usocket-server"; + version = "0.8.8"; + asds = [ "usocket-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/usocket/2024-10-12/usocket-0.8.8.tgz"; + sha256 = "13j2hyl7j06vl8hh3930wd3bi2p0pcg4dcd243al31fgw4m0bvag"; + system = "usocket-server"; + asd = "usocket-server"; + } + ); + systems = [ "usocket-server" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "usocket" self) + ]; + meta = { }; + } + ); + usocket-test = ( + build-asdf-system { + pname = "usocket-test"; + version = "0.8.8"; + asds = [ "usocket-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/usocket/2024-10-12/usocket-0.8.8.tgz"; + sha256 = "13j2hyl7j06vl8hh3930wd3bi2p0pcg4dcd243al31fgw4m0bvag"; + system = "usocket-test"; + asd = "usocket-test"; + } + ); + systems = [ "usocket-test" ]; + lispLibs = [ + (getAttr "rt" self) + (getAttr "usocket-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + utf8-input-stream = ( + build-asdf-system { + pname = "utf8-input-stream"; + version = "20241012-git"; + asds = [ "utf8-input-stream" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/utf8-input-stream/2024-10-12/utf8-input-stream-20241012-git.tgz"; + sha256 = "06fk8fsz9nngdfjymg93h1l5m4yhfg4w8as68zlaj698xf9ry3i5"; + system = "utf8-input-stream"; + asd = "utf8-input-stream"; + } + ); + systems = [ "utf8-input-stream" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + utf8-input-stream_dot_tests = ( + build-asdf-system { + pname = "utf8-input-stream.tests"; + version = "20241012-git"; + asds = [ "utf8-input-stream.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/utf8-input-stream/2024-10-12/utf8-input-stream-20241012-git.tgz"; + sha256 = "06fk8fsz9nngdfjymg93h1l5m4yhfg4w8as68zlaj698xf9ry3i5"; + system = "utf8-input-stream.tests"; + asd = "utf8-input-stream.tests"; + } + ); + systems = [ "utf8-input-stream.tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "flexi-streams" self) + (getAttr "utf8-input-stream" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + utilities_dot_binary-dump = ( + build-asdf-system { + pname = "utilities.binary-dump"; + version = "20181210-git"; + asds = [ "utilities.binary-dump" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/utilities.binary-dump/2018-12-10/utilities.binary-dump-20181210-git.tgz"; + sha256 = "1l20r1782bskyy50ca6vsyxrvbxlgfq4nm33wl8as761dcjpj4d4"; + system = "utilities.binary-dump"; + asd = "utilities.binary-dump"; + } + ); + systems = [ "utilities.binary-dump" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "let-plus" self) + (getAttr "nibbles" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + utilities_dot_print-items = ( + build-asdf-system { + pname = "utilities.print-items"; + version = "20221106-git"; + asds = [ "utilities.print-items" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/utilities.print-items/2022-11-06/utilities.print-items-20221106-git.tgz"; + sha256 = "0qn0w7cyl76c3ssipqsx4ngb1641ajfkaihnb31w374zrzbns8wi"; + system = "utilities.print-items"; + asd = "utilities.print-items"; + } + ); + systems = [ "utilities.print-items" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { }; + } + ); + utilities_dot_print-tree = ( + build-asdf-system { + pname = "utilities.print-tree"; + version = "20221106-git"; + asds = [ "utilities.print-tree" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/utilities.print-tree/2022-11-06/utilities.print-tree-20221106-git.tgz"; + sha256 = "0i7371qvlnwjcybh3c2ac88xz39vjdynhgxwz4acjbcnsw0jqsls"; + system = "utilities.print-tree"; + asd = "utilities.print-tree"; + } + ); + systems = [ "utilities.print-tree" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { }; + } + ); + utility = ( + build-asdf-system { + pname = "utility"; + version = "20190202-git"; + asds = [ "utility" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/utility/2019-02-02/utility-20190202-git.tgz"; + sha256 = "0nc83kxp2c0wy5ai7dm6w4anx5266j99pxzr0c7fxgllc7d0g1qd"; + system = "utility"; + asd = "utility"; + } + ); + systems = [ "utility" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + utility-arguments = ( + build-asdf-system { + pname = "utility-arguments"; + version = "20161204-git"; + asds = [ "utility-arguments" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/utility-arguments/2016-12-04/utility-arguments-20161204-git.tgz"; + sha256 = "0dzbzzrla9709zl5dqdfw02mxa3rvcpca466qrcprgs3hnxdvgwb"; + system = "utility-arguments"; + asd = "utility-arguments"; + } + ); + systems = [ "utility-arguments" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + utils-kt = ( + build-asdf-system { + pname = "utils-kt"; + version = "20200218-git"; + asds = [ "utils-kt" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/utils-kt/2020-02-18/utils-kt-20200218-git.tgz"; + sha256 = "016x3w034brz02z9mrsrkhk2djizg3yqsvhl9k62xqcnpy3b87dn"; + system = "utils-kt"; + asd = "utils-kt"; + } + ); + systems = [ "utils-kt" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + utm = ( + build-asdf-system { + pname = "utm"; + version = "20200218-git"; + asds = [ "utm" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/utm/2020-02-18/utm-20200218-git.tgz"; + sha256 = "1a5dp5fls26ppc6fnvd941nfvk2qs72grl0a3pycq7vzw6580v01"; + system = "utm"; + asd = "utm"; + } + ); + systems = [ "utm" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + utm-ups = ( + build-asdf-system { + pname = "utm-ups"; + version = "20230618-git"; + asds = [ "utm-ups" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/utm-ups/2023-06-18/utm-ups-20230618-git.tgz"; + sha256 = "19nnnqagfg1c1vzwlqpp8mq2d0hrk8r6r07a46nvdyzmwbnmbwyr"; + system = "utm-ups"; + asd = "utm-ups"; + } + ); + systems = [ "utm-ups" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + utm_dot_test = ( + build-asdf-system { + pname = "utm.test"; + version = "20200218-git"; + asds = [ "utm.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/utm/2020-02-18/utm-20200218-git.tgz"; + sha256 = "1a5dp5fls26ppc6fnvd941nfvk2qs72grl0a3pycq7vzw6580v01"; + system = "utm.test"; + asd = "utm.test"; + } + ); + systems = [ "utm.test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "utm" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + uuid = ( + build-asdf-system { + pname = "uuid"; + version = "20200715-git"; + asds = [ "uuid" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uuid/2020-07-15/uuid-20200715-git.tgz"; + sha256 = "1ncwhyw0zggwpkzjsw7d4pkrlldi34xvb69c0bzxmyz2krg8rpx0"; + system = "uuid"; + asd = "uuid"; + } + ); + systems = [ "uuid" ]; + lispLibs = [ + (getAttr "ironclad" self) + (getAttr "trivial-utf-8" self) + ]; + meta = { }; + } + ); + uuidv7 = ( + build-asdf-system { + pname = "uuidv7"; + version = "20241012-git"; + asds = [ "uuidv7" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/uuidv7.lisp/2024-10-12/uuidv7.lisp-20241012-git.tgz"; + sha256 = "1lirb92a1b3hpf66gndas4yix0smfckg9arzk69lpcvxsidzc66l"; + system = "uuidv7"; + asd = "uuidv7"; + } + ); + systems = [ "uuidv7" ]; + lispLibs = [ (getAttr "local-time" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + validate-list = ( + build-asdf-system { + pname = "validate-list"; + version = "20210411-git"; + asds = [ "validate-list" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/validate-list/2021-04-11/validate-list-20210411-git.tgz"; + sha256 = "1rb7glqvlaz84cfd2wjk49si9jh4ffysmva5007gjhqfhr9z23lj"; + system = "validate-list"; + asd = "validate-list"; + } + ); + systems = [ "validate-list" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "arithmetic-operators-as-words" self) + (getAttr "lisp-unit" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + varint = ( + build-asdf-system { + pname = "varint"; + version = "20230618-git"; + asds = [ "varint" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/protobuf/2023-06-18/protobuf-20230618-git.tgz"; + sha256 = "0pp8i2i72p6cng11sxj83klw45jqv05l5024h7c2rl0pvsg8f6bc"; + system = "varint"; + asd = "varint"; + } + ); + systems = [ "varint" ]; + lispLibs = [ + (getAttr "com_dot_google_dot_base" self) + (getAttr "nibbles" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + varjo = ( + build-asdf-system { + pname = "varjo"; + version = "release-quicklisp-92f9c75b-git"; + asds = [ "varjo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/varjo/2021-01-24/varjo-release-quicklisp-92f9c75b-git.tgz"; + sha256 = "0gga4wq74qxql4zxh8zq1ab2xnsz8ygdaf8wxy7w15vv4czgamr9"; + system = "varjo"; + asd = "varjo"; + } + ); + systems = [ "varjo" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "documentation-utils" self) + (getAttr "fn" self) + (getAttr "glsl-docs" self) + (getAttr "glsl-spec" self) + (getAttr "glsl-symbols" self) + (getAttr "named-readtables" self) + (getAttr "parse-float" self) + (getAttr "vas-string-metrics" self) + ]; + meta = { }; + } + ); + varjo_dot_import = ( + build-asdf-system { + pname = "varjo.import"; + version = "release-quicklisp-92f9c75b-git"; + asds = [ "varjo.import" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/varjo/2021-01-24/varjo-release-quicklisp-92f9c75b-git.tgz"; + sha256 = "0gga4wq74qxql4zxh8zq1ab2xnsz8ygdaf8wxy7w15vv4czgamr9"; + system = "varjo.import"; + asd = "varjo.import"; + } + ); + systems = [ "varjo.import" ]; + lispLibs = [ + (getAttr "fare-quasiquote-extras" self) + (getAttr "glsl-toolkit" self) + (getAttr "rtg-math_dot_vari" self) + (getAttr "split-sequence" self) + (getAttr "varjo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + varjo_dot_tests = ( + build-asdf-system { + pname = "varjo.tests"; + version = "release-quicklisp-92f9c75b-git"; + asds = [ "varjo.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/varjo/2021-01-24/varjo-release-quicklisp-92f9c75b-git.tgz"; + sha256 = "0gga4wq74qxql4zxh8zq1ab2xnsz8ygdaf8wxy7w15vv4czgamr9"; + system = "varjo.tests"; + asd = "varjo.tests"; + } + ); + systems = [ "varjo.tests" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "rtg-math_dot_vari" self) + (getAttr "varjo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + varray = ( + build-asdf-system { + pname = "varray"; + version = "20241012-git"; + asds = [ "varray" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "varray"; + asd = "varray"; + } + ); + systems = [ "varray" ]; + lispLibs = [ + (getAttr "aplesque" self) + (getAttr "lparallel" self) + (getAttr "random-state" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vas-string-metrics = ( + build-asdf-system { + pname = "vas-string-metrics"; + version = "20211209-git"; + asds = [ "vas-string-metrics" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vas-string-metrics/2021-12-09/vas-string-metrics-20211209-git.tgz"; + sha256 = "1yvkwc939dckv070nlgqfj5ys9ii2rm32m5wfx7qxdjrb4n19sx9"; + system = "vas-string-metrics"; + asd = "vas-string-metrics"; + } + ); + systems = [ "vas-string-metrics" ]; + lispLibs = [ ]; + meta = { }; + } + ); + vecto = ( + build-asdf-system { + pname = "vecto"; + version = "1.6"; + asds = [ "vecto" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vecto/2021-12-30/vecto-1.6.tgz"; + sha256 = "1s3ii9absili7yiv89byjikxcxlbagsvcxdwkxgsm1rahgggyk5x"; + system = "vecto"; + asd = "vecto"; + } + ); + systems = [ "vecto" ]; + lispLibs = [ + (getAttr "cl-vectors" self) + (getAttr "zpb-ttf" self) + (getAttr "zpng" self) + ]; + meta = { }; + } + ); + vectometry = ( + build-asdf-system { + pname = "vectometry"; + version = "1.6"; + asds = [ "vectometry" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vecto/2021-12-30/vecto-1.6.tgz"; + sha256 = "1s3ii9absili7yiv89byjikxcxlbagsvcxdwkxgsm1rahgggyk5x"; + system = "vectometry"; + asd = "vectometry"; + } + ); + systems = [ "vectometry" ]; + lispLibs = [ (getAttr "vecto" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vectors = ( + build-asdf-system { + pname = "vectors"; + version = "20171227-git"; + asds = [ "vectors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vectors/2017-12-27/vectors-20171227-git.tgz"; + sha256 = "1sflb1wz6fcszdbqrcfh52bp5ch6wbizzp7jx97ni8lrqq2r6cqy"; + system = "vectors"; + asd = "vectors"; + } + ); + systems = [ "vectors" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vellum = ( + build-asdf-system { + pname = "vellum"; + version = "20241012-git"; + asds = [ "vellum" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vellum/2024-10-12/vellum-20241012-git.tgz"; + sha256 = "0qy5hsyy3qf5245n5lfnhsfdjmsdjmwa2d3jp8gr6zg71npfx926"; + system = "vellum"; + asd = "vellum"; + } + ); + systems = [ "vellum" ]; + lispLibs = [ + (getAttr "agnostic-lizard" self) + (getAttr "alexandria" self) + (getAttr "cl-data-structures" self) + (getAttr "closer-mop" self) + (getAttr "documentation-utils-extensions" self) + (getAttr "iterate" self) + (getAttr "lparallel" self) + (getAttr "metabang-bind" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vellum-binary = ( + build-asdf-system { + pname = "vellum-binary"; + version = "20241012-git"; + asds = [ "vellum-binary" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vellum-binary/2024-10-12/vellum-binary-20241012-git.tgz"; + sha256 = "15kv5vzzrf6c3nvibz3p3d9arxmvwska37p5s13g9d2z1k3wyag1"; + system = "vellum-binary"; + asd = "vellum-binary"; + } + ); + systems = [ "vellum-binary" ]; + lispLibs = [ + (getAttr "chipz" self) + (getAttr "cl-conspack" self) + (getAttr "ieee-floats" self) + (getAttr "nibbles" self) + (getAttr "salza2" self) + (getAttr "trivial-utf-8" self) + (getAttr "vellum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vellum-clim = ( + build-asdf-system { + pname = "vellum-clim"; + version = "20210531-git"; + asds = [ "vellum-clim" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vellum-clim/2021-05-31/vellum-clim-20210531-git.tgz"; + sha256 = "06g1pw0r60yd13hzbjrbpa1p0pnlwkqfn06ipk1gs0kc76gf2im5"; + system = "vellum-clim"; + asd = "vellum-clim"; + } + ); + systems = [ "vellum-clim" ]; + lispLibs = [ + (getAttr "iterate" self) + (getAttr "mcclim" self) + (getAttr "vellum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vellum-csv = ( + build-asdf-system { + pname = "vellum-csv"; + version = "20241012-git"; + asds = [ "vellum-csv" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vellum-csv/2024-10-12/vellum-csv-20241012-git.tgz"; + sha256 = "0xk4n6w3hsnn8cl34x8vigzmqnkdn04j6831095yyqk7373hvfql"; + system = "vellum-csv"; + asd = "vellum-csv"; + } + ); + systems = [ "vellum-csv" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "documentation-utils-extensions" self) + (getAttr "iterate" self) + (getAttr "parse-float" self) + (getAttr "serapeum" self) + (getAttr "vellum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vellum-csv-tests = ( + build-asdf-system { + pname = "vellum-csv-tests"; + version = "20241012-git"; + asds = [ "vellum-csv-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vellum-csv/2024-10-12/vellum-csv-20241012-git.tgz"; + sha256 = "0xk4n6w3hsnn8cl34x8vigzmqnkdn04j6831095yyqk7373hvfql"; + system = "vellum-csv-tests"; + asd = "vellum-csv-tests"; + } + ); + systems = [ "vellum-csv-tests" ]; + lispLibs = [ + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "vellum-csv" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vellum-postmodern = ( + build-asdf-system { + pname = "vellum-postmodern"; + version = "20241012-git"; + asds = [ "vellum-postmodern" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vellum-postmodern/2024-10-12/vellum-postmodern-20241012-git.tgz"; + sha256 = "1q7s57vfcs01nl03kjkyjk9ya68cnl9p6mf1z864imfd04ssy9gr"; + system = "vellum-postmodern"; + asd = "vellum-postmodern"; + } + ); + systems = [ "vellum-postmodern" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-postgres" self) + (getAttr "documentation-utils-extensions" self) + (getAttr "iterate" self) + (getAttr "postmodern" self) + (getAttr "s-sql" self) + (getAttr "serapeum" self) + (getAttr "vellum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vellum-tests = ( + build-asdf-system { + pname = "vellum-tests"; + version = "20241012-git"; + asds = [ "vellum-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vellum/2024-10-12/vellum-20241012-git.tgz"; + sha256 = "0qy5hsyy3qf5245n5lfnhsfdjmsdjmwa2d3jp8gr6zg71npfx926"; + system = "vellum-tests"; + asd = "vellum-tests"; + } + ); + systems = [ "vellum-tests" ]; + lispLibs = [ + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "vellum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + veq = ( + build-asdf-system { + pname = "veq"; + version = "v4.5.5"; + asds = [ "veq" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-veq/2023-10-21/cl-veq-v4.5.5.tgz"; + sha256 = "0sk6rvqck47ym7ryy0smya1vwgpksxzal1xcwmwl106nxi9l7m34"; + system = "veq"; + asd = "veq"; + } + ); + systems = [ "veq" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + verbose = ( + build-asdf-system { + pname = "verbose"; + version = "20241012-git"; + asds = [ "verbose" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/verbose/2024-10-12/verbose-20241012-git.tgz"; + sha256 = "1q0knjk1nlnvlg9kydyxzd4sd2v8vm9dx10zqz2bpihd5nyhz3nv"; + system = "verbose"; + asd = "verbose"; + } + ); + systems = [ "verbose" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "dissect" self) + (getAttr "documentation-utils" self) + (getAttr "local-time" self) + (getAttr "piping" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + verlet = ( + build-asdf-system { + pname = "verlet"; + version = "20211209-git"; + asds = [ "verlet" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/verlet/2021-12-09/verlet-20211209-git.tgz"; + sha256 = "0n6wgjwwbrr13ldwa4y59n2ixn47rr0ad7n3jbb58635z6ahfvd4"; + system = "verlet"; + asd = "verlet"; + } + ); + systems = [ "verlet" ]; + lispLibs = [ + (getAttr "chain" self) + (getAttr "fset" self) + (getAttr "metabang-bind" self) + (getAttr "mgl-pax" self) + (getAttr "rtg-math" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vernacular = ( + build-asdf-system { + pname = "vernacular"; + version = "20241012-git"; + asds = [ "vernacular" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vernacular/2024-10-12/vernacular-20241012-git.tgz"; + sha256 = "09jz68lms82vxq672pars6hqapvdl4z8z2v1s9kmzvgxm2khw8pw"; + system = "vernacular"; + asd = "vernacular"; + } + ); + systems = [ "vernacular" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "local-time" self) + (getAttr "named-readtables" self) + (getAttr "overlord" self) + (getAttr "serapeum" self) + (getAttr "trivia" self) + (getAttr "trivial-garbage" self) + (getAttr "trivial-macroexpand-all" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + verrazano = ( + build-asdf-system { + pname = "verrazano"; + version = "20120909-darcs"; + asds = [ "verrazano" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/verrazano/2012-09-09/verrazano-20120909-darcs.tgz"; + sha256 = "0d7qv5jwv5p1r64g4rfqb844b5fh71p82b5983gjz0a5p391p270"; + system = "verrazano"; + asd = "verrazano"; + } + ); + systems = [ "verrazano" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "cl-ppcre" self) + (getAttr "closer-mop" self) + (getAttr "cxml" self) + (getAttr "iterate" self) + (getAttr "metabang-bind" self) + (getAttr "parse-number" self) + (getAttr "trivial-shell" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + verrazano-runtime = ( + build-asdf-system { + pname = "verrazano-runtime"; + version = "20120909-darcs"; + asds = [ "verrazano-runtime" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/verrazano/2012-09-09/verrazano-20120909-darcs.tgz"; + sha256 = "0d7qv5jwv5p1r64g4rfqb844b5fh71p82b5983gjz0a5p391p270"; + system = "verrazano-runtime"; + asd = "verrazano-runtime"; + } + ); + systems = [ "verrazano-runtime" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vertex = ( + build-asdf-system { + pname = "vertex"; + version = "20150608-git"; + asds = [ "vertex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vertex/2015-06-08/vertex-20150608-git.tgz"; + sha256 = "0g3ck1kvp6x9874ffizjz3fsd35a3m4hcr2x5gq9fdql680ic4k2"; + system = "vertex"; + asd = "vertex"; + } + ); + systems = [ "vertex" ]; + lispLibs = [ + (getAttr "common-doc" self) + (getAttr "common-doc-plump" self) + (getAttr "plump-tex" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vertex-test = ( + build-asdf-system { + pname = "vertex-test"; + version = "20150608-git"; + asds = [ "vertex-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vertex/2015-06-08/vertex-20150608-git.tgz"; + sha256 = "0g3ck1kvp6x9874ffizjz3fsd35a3m4hcr2x5gq9fdql680ic4k2"; + system = "vertex-test"; + asd = "vertex-test"; + } + ); + systems = [ "vertex-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "vertex" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vex = ( + build-asdf-system { + pname = "vex"; + version = "20241012-git"; + asds = [ "vex" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/april/2024-10-12/april-20241012-git.tgz"; + sha256 = "1jb7c9hs8fvx7zm0p0pvsn8r5qsfnf9hr53xnnvcgparfjvxhfxn"; + system = "vex"; + asd = "vex"; + } + ); + systems = [ "vex" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "array-operations" self) + (getAttr "cl-ppcre" self) + (getAttr "maxpc-apache" self) + (getAttr "prove" self) + (getAttr "symbol-munger" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vgplot = ( + build-asdf-system { + pname = "vgplot"; + version = "20220707-git"; + asds = [ "vgplot" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vgplot/2022-07-07/vgplot-20220707-git.tgz"; + sha256 = "1vc5fd787xa8831wjbmwrpg17f9isi5k8dmb85fsysz47plbvi1y"; + system = "vgplot"; + asd = "vgplot"; + } + ); + systems = [ "vgplot" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "ltk" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-colors = ( + build-asdf-system { + pname = "vivid-colors"; + version = "20220707-git"; + asds = [ "vivid-colors" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; + sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; + system = "vivid-colors"; + asd = "vivid-colors"; + } + ); + systems = [ "vivid-colors" ]; + lispLibs = [ + (getAttr "cl-colors2" self) + (getAttr "closer-mop" self) + (getAttr "jingoh_dot_documentizer" self) + (getAttr "lambda-fiddle" self) + (getAttr "millet" self) + (getAttr "vivid-colors_dot_content" self) + (getAttr "vivid-colors_dot_dispatch" self) + (getAttr "vivid-colors_dot_stream" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-colors_dot_content = ( + build-asdf-system { + pname = "vivid-colors.content"; + version = "20220707-git"; + asds = [ "vivid-colors.content" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; + sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; + system = "vivid-colors.content"; + asd = "vivid-colors.content"; + } + ); + systems = [ "vivid-colors.content" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ansi-text" self) + (getAttr "jingoh_dot_documentizer" self) + (getAttr "mcase" self) + (getAttr "vivid-colors_dot_queue" self) + (getAttr "vivid-colors_dot_shared" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-colors_dot_content_dot_test = ( + build-asdf-system { + pname = "vivid-colors.content.test"; + version = "20220707-git"; + asds = [ "vivid-colors.content.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; + sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; + system = "vivid-colors.content.test"; + asd = "vivid-colors.content.test"; + } + ); + systems = [ "vivid-colors.content.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "vivid-colors_dot_content" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-colors_dot_dispatch = ( + build-asdf-system { + pname = "vivid-colors.dispatch"; + version = "20220707-git"; + asds = [ "vivid-colors.dispatch" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; + sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; + system = "vivid-colors.dispatch"; + asd = "vivid-colors.dispatch"; + } + ); + systems = [ "vivid-colors.dispatch" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "jingoh_dot_documentizer" self) + (getAttr "millet" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-colors_dot_dispatch_dot_test = ( + build-asdf-system { + pname = "vivid-colors.dispatch.test"; + version = "20220707-git"; + asds = [ "vivid-colors.dispatch.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; + sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; + system = "vivid-colors.dispatch.test"; + asd = "vivid-colors.dispatch.test"; + } + ); + systems = [ "vivid-colors.dispatch.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "vivid-colors_dot_dispatch" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-colors_dot_queue = ( + build-asdf-system { + pname = "vivid-colors.queue"; + version = "20220707-git"; + asds = [ "vivid-colors.queue" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; + sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; + system = "vivid-colors.queue"; + asd = "vivid-colors.queue"; + } + ); + systems = [ "vivid-colors.queue" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "jingoh_dot_documentizer" self) + (getAttr "millet" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-colors_dot_queue_dot_test = ( + build-asdf-system { + pname = "vivid-colors.queue.test"; + version = "20220707-git"; + asds = [ "vivid-colors.queue.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; + sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; + system = "vivid-colors.queue.test"; + asd = "vivid-colors.queue.test"; + } + ); + systems = [ "vivid-colors.queue.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "vivid-colors_dot_queue" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-colors_dot_shared = ( + build-asdf-system { + pname = "vivid-colors.shared"; + version = "20220707-git"; + asds = [ "vivid-colors.shared" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; + sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; + system = "vivid-colors.shared"; + asd = "vivid-colors.shared"; + } + ); + systems = [ "vivid-colors.shared" ]; + lispLibs = [ (getAttr "jingoh_dot_documentizer" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-colors_dot_shared_dot_test = ( + build-asdf-system { + pname = "vivid-colors.shared.test"; + version = "20220707-git"; + asds = [ "vivid-colors.shared.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; + sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; + system = "vivid-colors.shared.test"; + asd = "vivid-colors.shared.test"; + } + ); + systems = [ "vivid-colors.shared.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "vivid-colors_dot_shared" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-colors_dot_stream = ( + build-asdf-system { + pname = "vivid-colors.stream"; + version = "20220707-git"; + asds = [ "vivid-colors.stream" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; + sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; + system = "vivid-colors.stream"; + asd = "vivid-colors.stream"; + } + ); + systems = [ "vivid-colors.stream" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ansi-text" self) + (getAttr "jingoh_dot_documentizer" self) + (getAttr "trivial-gray-streams" self) + (getAttr "vivid-colors_dot_content" self) + (getAttr "vivid-colors_dot_dispatch" self) + (getAttr "vivid-colors_dot_shared" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-colors_dot_stream_dot_test = ( + build-asdf-system { + pname = "vivid-colors.stream.test"; + version = "20220707-git"; + asds = [ "vivid-colors.stream.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; + sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; + system = "vivid-colors.stream.test"; + asd = "vivid-colors.stream.test"; + } + ); + systems = [ "vivid-colors.stream.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "vivid-colors_dot_stream" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-colors_dot_test = ( + build-asdf-system { + pname = "vivid-colors.test"; + version = "20220707-git"; + asds = [ "vivid-colors.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-colors/2022-07-07/vivid-colors-20220707-git.tgz"; + sha256 = "0a1q1dgfgd7kqdziw80z1hhyp7l0mrd768lq68jva7vdv1r049ww"; + system = "vivid-colors.test"; + asd = "vivid-colors.test"; + } + ); + systems = [ "vivid-colors.test" ]; + lispLibs = [ + (getAttr "jingoh" self) + (getAttr "vivid-colors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-diff = ( + build-asdf-system { + pname = "vivid-diff"; + version = "20220707-git"; + asds = [ "vivid-diff" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-diff/2022-07-07/vivid-diff-20220707-git.tgz"; + sha256 = "195hqx304x4na56qpiblz30ahp1qj55kan50mkr0xyjhcx75nsdk"; + system = "vivid-diff"; + asd = "vivid-diff"; + } + ); + systems = [ "vivid-diff" ]; + lispLibs = [ + (getAttr "cl-colors2" self) + (getAttr "closer-mop" self) + (getAttr "jingoh_dot_documentizer" self) + (getAttr "matrix-case" self) + (getAttr "vivid-colors" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vivid-diff_dot_test = ( + build-asdf-system { + pname = "vivid-diff.test"; + version = "20220707-git"; + asds = [ "vivid-diff.test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vivid-diff/2022-07-07/vivid-diff-20220707-git.tgz"; + sha256 = "195hqx304x4na56qpiblz30ahp1qj55kan50mkr0xyjhcx75nsdk"; + system = "vivid-diff.test"; + asd = "vivid-diff.test"; + } + ); + systems = [ "vivid-diff.test" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "jingoh" self) + (getAttr "vivid-diff" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vk = ( + build-asdf-system { + pname = "vk"; + version = "20230214-git"; + asds = [ "vk" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vk/2023-02-14/vk-20230214-git.tgz"; + sha256 = "14986kss2rggdjiql3rr34qnfjwb8w73j0ggn6c3w4y9dny3l31j"; + system = "vk"; + asd = "vk"; + } + ); + systems = [ "vk" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cffi" self) + (getAttr "rove" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + voipms = ( + build-asdf-system { + pname = "voipms"; + version = "20231021-git"; + asds = [ "voipms" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-voipms/2023-10-21/cl-voipms-20231021-git.tgz"; + sha256 = "05jrpd9vc95hqxq3nbwv0qpsfj3winwx2n5a5933919gfanxrslk"; + system = "voipms"; + asd = "voipms"; + } + ); + systems = [ "voipms" ]; + lispLibs = [ + (getAttr "cl-date-time-parser" self) + (getAttr "erjoalgo-webutil" self) + (getAttr "local-time" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vom = ( + build-asdf-system { + pname = "vom"; + version = "20241012-git"; + asds = [ "vom" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vom/2024-10-12/vom-20241012-git.tgz"; + sha256 = "1rnrr69h3j8phm6z3cfagv2bjh71wbzx9acnas9fn33j3q94gr95"; + system = "vom"; + asd = "vom"; + } + ); + systems = [ "vom" ]; + lispLibs = [ ]; + meta = { }; + } + ); + vom-json = ( + build-asdf-system { + pname = "vom-json"; + version = "20200610-git"; + asds = [ "vom-json" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vom-json/2020-06-10/vom-json-20200610-git.tgz"; + sha256 = "14b39kqbjpibh545gh9mb6w5g0kz7fhd5zxfmlf9a0fpdbwhw41c"; + system = "vom-json"; + asd = "vom-json"; + } + ); + systems = [ "vom-json" ]; + lispLibs = [ + (getAttr "jonathan" self) + (getAttr "local-time" self) + (getAttr "vom" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vorbisfile-ffi = ( + build-asdf-system { + pname = "vorbisfile-ffi"; + version = "20151218-git"; + asds = [ "vorbisfile-ffi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/mixalot/2015-12-18/mixalot-20151218-git.tgz"; + sha256 = "0kqx933k8kly4yhzvspizzki556s1lfd4zafap42jcsqqhr4i5q9"; + system = "vorbisfile-ffi"; + asd = "vorbisfile-ffi"; + } + ); + systems = [ "vorbisfile-ffi" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + vp-trees = ( + build-asdf-system { + pname = "vp-trees"; + version = "20230214-git"; + asds = [ "vp-trees" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/vp-trees/2023-02-14/vp-trees-20230214-git.tgz"; + sha256 = "0fk41c97p5ck5g9nsvq6h9hzxz7yssyqz3v4f4qiavdnw6a9va1m"; + system = "vp-trees"; + asd = "vp-trees"; + } + ); + systems = [ "vp-trees" ]; + lispLibs = [ + (getAttr "float-features" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + wallstreetflets = ( + build-asdf-system { + pname = "wallstreetflets"; + version = "20211209-git"; + asds = [ "wallstreetflets" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/wallstreetflets/2021-12-09/wallstreetflets-20211209-git.tgz"; + sha256 = "0d9anws4gk16an1kl4kads6lhm8a4mpiwxg74i3235d5874gbdj5"; + system = "wallstreetflets"; + asd = "wallstreetflets"; + } + ); + systems = [ "wallstreetflets" ]; + lispLibs = [ + (getAttr "dexador" self) + (getAttr "lquery" self) + (getAttr "parse-number" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + wasm-encoder = ( + build-asdf-system { + pname = "wasm-encoder"; + version = "20210630-git"; + asds = [ "wasm-encoder" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/wasm-encoder/2021-06-30/wasm-encoder-20210630-git.tgz"; + sha256 = "1h094d8www9ydg96fjj17pi0lb63ikgyp5237cl6n3rmg4jpy9w6"; + system = "wasm-encoder"; + asd = "wasm-encoder"; + } + ); + systems = [ "wasm-encoder" ]; + lispLibs = [ + (getAttr "agutil" self) + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "flexi-streams" self) + (getAttr "generic-cl" self) + (getAttr "ieee-floats" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + water = ( + build-asdf-system { + pname = "water"; + version = "20190107-git"; + asds = [ "water" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/water/2019-01-07/water-20190107-git.tgz"; + sha256 = "0w9b6mh10rfv7rg1zq28pivad6435i9h839km6nlbhq9xmx0g27s"; + system = "water"; + asd = "water"; + } + ); + systems = [ "water" ]; + lispLibs = [ (getAttr "parenscript" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + wayflan = ( + build-asdf-system { + pname = "wayflan"; + version = "20230214-git"; + asds = [ "wayflan" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/wayflan/2023-02-14/wayflan-20230214-git.tgz"; + sha256 = "0y6hzskp1vgaigzj5b3i695sc6dn5mk7nlxs21nh5ybzmf4chhyy"; + system = "wayflan"; + asd = "wayflan"; + } + ); + systems = [ "wayflan" ]; + lispLibs = [ + (getAttr "cffi-grovel" self) + (getAttr "wayflan-client" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + wayflan-client = ( + build-asdf-system { + pname = "wayflan-client"; + version = "20230214-git"; + asds = [ "wayflan-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/wayflan/2023-02-14/wayflan-20230214-git.tgz"; + sha256 = "0y6hzskp1vgaigzj5b3i695sc6dn5mk7nlxs21nh5ybzmf4chhyy"; + system = "wayflan-client"; + asd = "wayflan-client"; + } + ); + systems = [ "wayflan-client" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "closer-mop" self) + (getAttr "plump" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + webactions = ( + build-asdf-system { + pname = "webactions"; + version = "20190813-git"; + asds = [ "webactions" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/portableaserve/2019-08-13/portableaserve-20190813-git.tgz"; + sha256 = "0ak6mqp84sjr0a7h5svr16vra4bf4fcx6wpir0n88dc1vjwy5xqa"; + system = "webactions"; + asd = "webactions"; + } + ); + systems = [ "webactions" ]; + lispLibs = [ + (getAttr "acl-compat" self) + (getAttr "aserve" self) + (getAttr "htmlgen" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + webapi = ( + build-asdf-system { + pname = "webapi"; + version = "20230618-git"; + asds = [ "webapi" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/webapi/2023-06-18/webapi-20230618-git.tgz"; + sha256 = "1irp18a0rq61xfr3944ahy2spj0095l15xf7j0245jd0qw7gmg03"; + system = "webapi"; + asd = "webapi"; + } + ); + systems = [ "webapi" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "dexador" self) + (getAttr "kebab" self) + (getAttr "quri" self) + (getAttr "st-json" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + weblocks-clsql = ( + build-asdf-system { + pname = "weblocks-clsql"; + version = "20211020-git"; + asds = [ "weblocks-clsql" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/weblocks-stores/2021-10-20/weblocks-stores-20211020-git.tgz"; + sha256 = "1k44dad18fkp80xjm04fiy6bciirs71ljvm8a2rb33xndrbxiiya"; + system = "weblocks-clsql"; + asd = "weblocks-clsql"; + } + ); + systems = [ "weblocks-clsql" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "clsql" self) + (getAttr "clsql-fluid" self) + (getAttr "metatilities" self) + (getAttr "weblocks-stores" self) + (getAttr "weblocks-util" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + weblocks-memory = ( + build-asdf-system { + pname = "weblocks-memory"; + version = "20211020-git"; + asds = [ "weblocks-memory" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/weblocks-stores/2021-10-20/weblocks-stores-20211020-git.tgz"; + sha256 = "1k44dad18fkp80xjm04fiy6bciirs71ljvm8a2rb33xndrbxiiya"; + system = "weblocks-memory"; + asd = "weblocks-memory"; + } + ); + systems = [ "weblocks-memory" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "metatilities" self) + (getAttr "weblocks-stores" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + weblocks-montezuma = ( + build-asdf-system { + pname = "weblocks-montezuma"; + version = "20211020-git"; + asds = [ "weblocks-montezuma" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/weblocks-stores/2021-10-20/weblocks-stores-20211020-git.tgz"; + sha256 = "1k44dad18fkp80xjm04fiy6bciirs71ljvm8a2rb33xndrbxiiya"; + system = "weblocks-montezuma"; + asd = "weblocks-montezuma"; + } + ); + systems = [ "weblocks-montezuma" ]; + lispLibs = [ + (getAttr "montezuma" self) + (getAttr "weblocks-stores" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + weblocks-perec = ( + build-asdf-system { + pname = "weblocks-perec"; + version = "20211020-git"; + asds = [ "weblocks-perec" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/weblocks-stores/2021-10-20/weblocks-stores-20211020-git.tgz"; + sha256 = "1k44dad18fkp80xjm04fiy6bciirs71ljvm8a2rb33xndrbxiiya"; + system = "weblocks-perec"; + asd = "weblocks-perec"; + } + ); + systems = [ "weblocks-perec" ]; + lispLibs = [ + (getAttr "hu_dot_dwim_dot_perec" self) + (getAttr "weblocks-stores" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + weblocks-prevalence = ( + build-asdf-system { + pname = "weblocks-prevalence"; + version = "20211020-git"; + asds = [ "weblocks-prevalence" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/weblocks-stores/2021-10-20/weblocks-stores-20211020-git.tgz"; + sha256 = "1k44dad18fkp80xjm04fiy6bciirs71ljvm8a2rb33xndrbxiiya"; + system = "weblocks-prevalence"; + asd = "weblocks-prevalence"; + } + ); + systems = [ "weblocks-prevalence" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-prevalence" self) + (getAttr "metatilities" self) + (getAttr "weblocks-memory" self) + (getAttr "weblocks-stores" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + weblocks-scripts = ( + build-asdf-system { + pname = "weblocks-scripts"; + version = "20211020-git"; + asds = [ "weblocks-scripts" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/weblocks/2021-10-20/weblocks-20211020-git.tgz"; + sha256 = "1hilpzm1p3hrp2hxghjr9y8sy5a9bgk96n8kc8bphvn7dvlbm78j"; + system = "weblocks-scripts"; + asd = "weblocks-scripts"; + } + ); + systems = [ "weblocks-scripts" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + weblocks-stores = ( + build-asdf-system { + pname = "weblocks-stores"; + version = "20211020-git"; + asds = [ "weblocks-stores" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/weblocks-stores/2021-10-20/weblocks-stores-20211020-git.tgz"; + sha256 = "1k44dad18fkp80xjm04fiy6bciirs71ljvm8a2rb33xndrbxiiya"; + system = "weblocks-stores"; + asd = "weblocks-stores"; + } + ); + systems = [ "weblocks-stores" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "metatilities" self) + (getAttr "weblocks-util" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + weblocks-util = ( + build-asdf-system { + pname = "weblocks-util"; + version = "20211020-git"; + asds = [ "weblocks-util" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/weblocks/2021-10-20/weblocks-20211020-git.tgz"; + sha256 = "1hilpzm1p3hrp2hxghjr9y8sy5a9bgk96n8kc8bphvn7dvlbm78j"; + system = "weblocks-util"; + asd = "weblocks-util"; + } + ); + systems = [ "weblocks-util" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-cont" self) + (getAttr "cl-fad" self) + (getAttr "cl-json" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-who" self) + (getAttr "closer-mop" self) + (getAttr "f-underscore" self) + (getAttr "html-template" self) + (getAttr "hunchentoot" self) + (getAttr "ironclad" self) + (getAttr "metatilities" self) + (getAttr "optima" self) + (getAttr "parenscript" self) + (getAttr "parse-number" self) + (getAttr "pretty-function" self) + (getAttr "puri" self) + (getAttr "salza2" self) + (getAttr "trivial-backtrace" self) + (getAttr "trivial-timeout" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + websocket-driver = ( + build-asdf-system { + pname = "websocket-driver"; + version = "20241012-git"; + asds = [ "websocket-driver" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/websocket-driver/2024-10-12/websocket-driver-20241012-git.tgz"; + sha256 = "1lj6xarr62199ladkml7qpgi86w94j4djrp54v9ch0zakni3rhj2"; + system = "websocket-driver"; + asd = "websocket-driver"; + } + ); + systems = [ "websocket-driver" ]; + lispLibs = [ + (getAttr "websocket-driver-client" self) + (getAttr "websocket-driver-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + websocket-driver-base = ( + build-asdf-system { + pname = "websocket-driver-base"; + version = "20241012-git"; + asds = [ "websocket-driver-base" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/websocket-driver/2024-10-12/websocket-driver-20241012-git.tgz"; + sha256 = "1lj6xarr62199ladkml7qpgi86w94j4djrp54v9ch0zakni3rhj2"; + system = "websocket-driver-base"; + asd = "websocket-driver-base"; + } + ); + systems = [ "websocket-driver-base" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-base64" self) + (getAttr "event-emitter" self) + (getAttr "fast-io" self) + (getAttr "fast-websocket" self) + (getAttr "sha1" self) + (getAttr "split-sequence" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + websocket-driver-client = ( + build-asdf-system { + pname = "websocket-driver-client"; + version = "20241012-git"; + asds = [ "websocket-driver-client" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/websocket-driver/2024-10-12/websocket-driver-20241012-git.tgz"; + sha256 = "1lj6xarr62199ladkml7qpgi86w94j4djrp54v9ch0zakni3rhj2"; + system = "websocket-driver-client"; + asd = "websocket-driver-client"; + } + ); + systems = [ "websocket-driver-client" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl_plus_ssl" self) + (getAttr "cl-base64" self) + (getAttr "fast-http" self) + (getAttr "fast-io" self) + (getAttr "fast-websocket" self) + (getAttr "quri" self) + (getAttr "usocket" self) + (getAttr "websocket-driver-base" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + websocket-driver-server = ( + build-asdf-system { + pname = "websocket-driver-server"; + version = "20241012-git"; + asds = [ "websocket-driver-server" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/websocket-driver/2024-10-12/websocket-driver-20241012-git.tgz"; + sha256 = "1lj6xarr62199ladkml7qpgi86w94j4djrp54v9ch0zakni3rhj2"; + system = "websocket-driver-server"; + asd = "websocket-driver-server"; + } + ); + systems = [ "websocket-driver-server" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "clack-socket" self) + (getAttr "fast-io" self) + (getAttr "fast-websocket" self) + (getAttr "websocket-driver-base" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + weft = ( + build-asdf-system { + pname = "weft"; + version = "20180228-git"; + asds = [ "weft" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/weft/2018-02-28/weft-20180228-git.tgz"; + sha256 = "1ia38xcpp9g4v6sij99lyl9b8p59ysg2cj9k92nb683f8pzv9pl3"; + system = "weft"; + asd = "weft"; + } + ); + systems = [ "weft" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "log4cl" self) + (getAttr "trivial-timeout" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + westbrook = ( + build-asdf-system { + pname = "westbrook"; + version = "20180131-git"; + asds = [ "westbrook" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/westbrook/2018-01-31/westbrook-20180131-git.tgz"; + sha256 = "08qs5lpg34d1mn6warrrq1wimyqqrjb8jih62g1pbysgni4ihm2v"; + system = "westbrook"; + asd = "westbrook"; + } + ); + systems = [ "westbrook" ]; + lispLibs = [ (getAttr "cxml" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + westbrook-tests = ( + build-asdf-system { + pname = "westbrook-tests"; + version = "20180131-git"; + asds = [ "westbrook-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/westbrook/2018-01-31/westbrook-20180131-git.tgz"; + sha256 = "08qs5lpg34d1mn6warrrq1wimyqqrjb8jih62g1pbysgni4ihm2v"; + system = "westbrook-tests"; + asd = "westbrook-tests"; + } + ); + systems = [ "westbrook-tests" ]; + lispLibs = [ + (getAttr "fiasco" self) + (getAttr "westbrook" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + what3words = ( + build-asdf-system { + pname = "what3words"; + version = "20161204-git"; + asds = [ "what3words" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/what3words/2016-12-04/what3words-20161204-git.tgz"; + sha256 = "0nlrpi8phrf2mpgbw9bj9w4vksqb0baj542bhnq39sjalc8bj73r"; + system = "what3words"; + asd = "what3words"; + } + ); + systems = [ "what3words" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "drakma" self) + (getAttr "jsown" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + whereiseveryone_dot_command-line-args = ( + build-asdf-system { + pname = "whereiseveryone.command-line-args"; + version = "20241012-git"; + asds = [ "whereiseveryone.command-line-args" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/whereiseveryone.command-line-args/2024-10-12/whereiseveryone.command-line-args-20241012-git.tgz"; + sha256 = "140xnz2v0v3hfg3dp2fhidw8ns6lxd3a5knm07wqdp48ksg119wy"; + system = "whereiseveryone.command-line-args"; + asd = "whereiseveryone.command-line-args"; + } + ); + systems = [ "whereiseveryone.command-line-args" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "charje_dot_documentation" self) + (getAttr "serapeum" self) + (getAttr "str" self) + (getAttr "trivia" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + which = ( + build-asdf-system { + pname = "which"; + version = "20160421-git"; + asds = [ "which" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/which/2016-04-21/which-20160421-git.tgz"; + sha256 = "127pm9h4rm4w9aadw5yvamnfzhk2rr69kchx10rf9k7sk7izqqfk"; + system = "which"; + asd = "which"; + } + ); + systems = [ "which" ]; + lispLibs = [ + (getAttr "cl-fad" self) + (getAttr "path-parse" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + which-test = ( + build-asdf-system { + pname = "which-test"; + version = "20160421-git"; + asds = [ "which-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/which/2016-04-21/which-20160421-git.tgz"; + sha256 = "127pm9h4rm4w9aadw5yvamnfzhk2rr69kchx10rf9k7sk7izqqfk"; + system = "which-test"; + asd = "which-test"; + } + ); + systems = [ "which-test" ]; + lispLibs = [ + (getAttr "fiveam" self) + (getAttr "which" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + whirlog = ( + build-asdf-system { + pname = "whirlog"; + version = "20211020-git"; + asds = [ "whirlog" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/whirlog/2021-10-20/whirlog-20211020-git.tgz"; + sha256 = "0sf1kc8ln1gszzrz3qh3bx11k42lpccrv6kp2ihlrg3d6lsa6i26"; + system = "whirlog"; + asd = "whirlog"; + } + ); + systems = [ "whirlog" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + whofields = ( + build-asdf-system { + pname = "whofields"; + version = "20211020-git"; + asds = [ "whofields" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/whofields/2021-10-20/whofields-20211020-git.tgz"; + sha256 = "1scpzzfdw5g7qsayhznjyzns8lxx4fvv2jxd0vr9vnxad3vm977x"; + system = "whofields"; + asd = "whofields"; + } + ); + systems = [ "whofields" ]; + lispLibs = [ + (getAttr "asdf-package-system" self) + (getAttr "cl-who" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + wilbur = ( + build-asdf-system { + pname = "wilbur"; + version = "20181210-git"; + asds = [ "wilbur" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/de.setf.wilbur/2018-12-10/de.setf.wilbur-20181210-git.tgz"; + sha256 = "0w4qssyarim4v64vv7jmspmyba7xghx9bkalyyhvccf6zrf7b2v7"; + system = "wilbur"; + asd = "wilbur"; + } + ); + systems = [ "wilbur" ]; + lispLibs = [ (getAttr "usocket" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + wild-package-inferred-system = ( + build-asdf-system { + pname = "wild-package-inferred-system"; + version = "20210531-git"; + asds = [ "wild-package-inferred-system" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/wild-package-inferred-system/2021-05-31/wild-package-inferred-system-20210531-git.tgz"; + sha256 = "0sp3j3i83aqyq9bl3djs490nilryi9sh1wjbcqd9z94d9wfbfz80"; + system = "wild-package-inferred-system"; + asd = "wild-package-inferred-system"; + } + ); + systems = [ "wild-package-inferred-system" ]; + lispLibs = [ ]; + meta = { }; + } + ); + window = ( + build-asdf-system { + pname = "window"; + version = "20200427-git"; + asds = [ "window" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/sucle/2020-04-27/sucle-20200427-git.tgz"; + sha256 = "033akkn9zxc6qdgycgxgybx3v23638245xrx29x2cbwnvg3i1q34"; + system = "window"; + asd = "window"; + } + ); + systems = [ "window" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bodge-glfw" self) + (getAttr "cffi" self) + (getAttr "trivial-features" self) + (getAttr "utility" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + winhttp = ( + build-asdf-system { + pname = "winhttp"; + version = "20241012-git"; + asds = [ "winhttp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/winhttp/2024-10-12/winhttp-20241012-git.tgz"; + sha256 = "1g4prr0x2cyc58wcpa3kfiwcs9f536bzfmsnlwnh3yn9aqndg67c"; + system = "winhttp"; + asd = "winhttp"; + } + ); + systems = [ "winhttp" ]; + lispLibs = [ (getAttr "cffi" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + winlock = ( + build-asdf-system { + pname = "winlock"; + version = "20191130-git"; + asds = [ "winlock" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/winlock/2019-11-30/winlock-20191130-git.tgz"; + sha256 = "0sgjq1cjbmshnh2zwyqws7rkr93zkjl0rrzyf04542gb1grj0vd8"; + system = "winlock"; + asd = "winlock"; + } + ); + systems = [ "winlock" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "named-readtables" self) + (getAttr "serapeum" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + wire-world = ( + build-asdf-system { + pname = "wire-world"; + version = "master-fe503896-git"; + asds = [ "wire-world" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "wire-world"; + asd = "wire-world"; + } + ); + systems = [ "wire-world" ]; + lispLibs = [ (getAttr "gwl-graphics" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + with-branching = ( + build-asdf-system { + pname = "with-branching"; + version = "20241012-git"; + asds = [ "with-branching" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/with-branching/2024-10-12/with-branching-20241012-git.tgz"; + sha256 = "0rhmlg1nbbhaa5jflhnydsqs7aqwg8d7ijxxcqa8lkcq49wvm647"; + system = "with-branching"; + asd = "with-branching"; + } + ); + systems = [ "with-branching" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-indent" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + with-c-syntax = ( + build-asdf-system { + pname = "with-c-syntax"; + version = "20221106-git"; + asds = [ "with-c-syntax" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/with-c-syntax/2022-11-06/with-c-syntax-20221106-git.tgz"; + sha256 = "12gdwdyxyl9xm8n04qvmvyc1s06dkckb87i6hdysal5lsf1gwc41"; + system = "with-c-syntax"; + asd = "with-c-syntax"; + } + ); + systems = [ "with-c-syntax" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-ppcre" self) + (getAttr "float-features" self) + (getAttr "floating-point-contractions" self) + (getAttr "named-readtables" self) + (getAttr "split-sequence" self) + (getAttr "trivial-gray-streams" self) + (getAttr "yacc" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + with-c-syntax-test = ( + build-asdf-system { + pname = "with-c-syntax-test"; + version = "20221106-git"; + asds = [ "with-c-syntax-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/with-c-syntax/2022-11-06/with-c-syntax-20221106-git.tgz"; + sha256 = "12gdwdyxyl9xm8n04qvmvyc1s06dkckb87i6hdysal5lsf1gwc41"; + system = "with-c-syntax-test"; + asd = "with-c-syntax-test"; + } + ); + systems = [ "with-c-syntax-test" ]; + lispLibs = [ + (getAttr "_1am" self) + (getAttr "floating-point" self) + (getAttr "trivial-cltl2" self) + (getAttr "with-c-syntax" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + with-cached-reader-conditionals = ( + build-asdf-system { + pname = "with-cached-reader-conditionals"; + version = "20170630-git"; + asds = [ "with-cached-reader-conditionals" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/with-cached-reader-conditionals/2017-06-30/with-cached-reader-conditionals-20170630-git.tgz"; + sha256 = "0n7a089d0wb13l1nsdh3xlgwxwlqynkbjl8fg2x56h52a5i9gkv4"; + system = "with-cached-reader-conditionals"; + asd = "with-cached-reader-conditionals"; + } + ); + systems = [ "with-cached-reader-conditionals" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + with-contexts = ( + build-asdf-system { + pname = "with-contexts"; + version = "20241012-git"; + asds = [ "with-contexts" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/with-contexts/2024-10-12/with-contexts-20241012-git.tgz"; + sha256 = "1biz33wxg312zsmpyjqfcmq4vnixxz3g4hp9krc61977d5n4fxwj"; + system = "with-contexts"; + asd = "with-contexts"; + } + ); + systems = [ "with-contexts" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + with-output-to-stream = ( + build-asdf-system { + pname = "with-output-to-stream"; + version = "1.0"; + asds = [ "with-output-to-stream" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/with-output-to-stream/2019-10-07/with-output-to-stream_1.0.tgz"; + sha256 = "0pv9kccjbxkgcv7wbcfpnzas9pq0n2rs2aq9kdnqkx55k12366sm"; + system = "with-output-to-stream"; + asd = "with-output-to-stream"; + } + ); + systems = [ "with-output-to-stream" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + with-output-to-stream__tests = ( + build-asdf-system { + pname = "with-output-to-stream_tests"; + version = "1.0"; + asds = [ "with-output-to-stream_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/with-output-to-stream/2019-10-07/with-output-to-stream_1.0.tgz"; + sha256 = "0pv9kccjbxkgcv7wbcfpnzas9pq0n2rs2aq9kdnqkx55k12366sm"; + system = "with-output-to-stream_tests"; + asd = "with-output-to-stream_tests"; + } + ); + systems = [ "with-output-to-stream_tests" ]; + lispLibs = [ + (getAttr "parachute" self) + (getAttr "with-output-to-stream" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + with-setf = ( + build-asdf-system { + pname = "with-setf"; + version = "release-quicklisp-df3eed9d-git"; + asds = [ "with-setf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/with-setf/2018-02-28/with-setf-release-quicklisp-df3eed9d-git.tgz"; + sha256 = "090v39kdxk4py3axjrjjac2pn1p0109q14hvl818pik479xr4inz"; + system = "with-setf"; + asd = "with-setf"; + } + ); + systems = [ "with-setf" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + with-shadowed-bindings = ( + build-asdf-system { + pname = "with-shadowed-bindings"; + version = "1.0"; + asds = [ "with-shadowed-bindings" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/with-shadowed-bindings/2019-01-07/with-shadowed-bindings-1.0.tgz"; + sha256 = "0kxy86a21v4fm4xwd44c6kpdadgkcj8iv6a68xavhirhjhngcwy5"; + system = "with-shadowed-bindings"; + asd = "with-shadowed-bindings"; + } + ); + systems = [ "with-shadowed-bindings" ]; + lispLibs = [ (getAttr "map-bind" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + with-shadowed-bindings__tests = ( + build-asdf-system { + pname = "with-shadowed-bindings_tests"; + version = "1.0"; + asds = [ "with-shadowed-bindings_tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/with-shadowed-bindings/2019-01-07/with-shadowed-bindings-1.0.tgz"; + sha256 = "0kxy86a21v4fm4xwd44c6kpdadgkcj8iv6a68xavhirhjhngcwy5"; + system = "with-shadowed-bindings_tests"; + asd = "with-shadowed-bindings_tests"; + } + ); + systems = [ "with-shadowed-bindings_tests" ]; + lispLibs = [ + (getAttr "parachute" self) + (getAttr "with-shadowed-bindings" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + with-user-abort = ( + build-asdf-system { + pname = "with-user-abort"; + version = "20230214-git"; + asds = [ "with-user-abort" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/with-user-abort/2023-02-14/with-user-abort-20230214-git.tgz"; + sha256 = "0yidlm92dk8kvz137zlm2f0d198kmgqpdswkinr2x4snbgkhd98j"; + system = "with-user-abort"; + asd = "with-user-abort"; + } + ); + systems = [ "with-user-abort" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + woo = ( + build-asdf-system { + pname = "woo"; + version = "20241012-git"; + asds = [ "woo" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/woo/2024-10-12/woo-20241012-git.tgz"; + sha256 = "0nhxlb1qhkl20vknm44gx0cq5cks33rcljczfhgbnmpkzrdpdrrl"; + system = "woo"; + asd = "woo"; + } + ); + systems = [ "woo" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "cl_plus_ssl" self) + (getAttr "clack-socket" self) + (getAttr "fast-http" self) + (getAttr "fast-io" self) + (getAttr "lev" self) + (getAttr "quri" self) + (getAttr "smart-buffer" self) + (getAttr "static-vectors" self) + (getAttr "swap-bytes" self) + (getAttr "trivial-mimes" self) + (getAttr "trivial-utf-8" self) + (getAttr "vom" self) + ]; + meta = { }; + } + ); + woo-test = ( + build-asdf-system { + pname = "woo-test"; + version = "20241012-git"; + asds = [ "woo-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/woo/2024-10-12/woo-20241012-git.tgz"; + sha256 = "0nhxlb1qhkl20vknm44gx0cq5cks33rcljczfhgbnmpkzrdpdrrl"; + system = "woo-test"; + asd = "woo-test"; + } + ); + systems = [ "woo-test" ]; + lispLibs = [ + (getAttr "clack-test" self) + (getAttr "rove" self) + (getAttr "woo" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + wookie = ( + build-asdf-system { + pname = "wookie"; + version = "20230214-git"; + asds = [ "wookie" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/wookie/2023-02-14/wookie-20230214-git.tgz"; + sha256 = "1i5l9isahww9zwizj6dmdcplck8wr8gxm31i43i8hf3rfxmvfjwn"; + system = "wookie"; + asd = "wookie"; + } + ); + systems = [ "wookie" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "blackbird" self) + (getAttr "chunga" self) + (getAttr "cl-async" self) + (getAttr "cl-async-ssl" self) + (getAttr "cl-fad" self) + (getAttr "cl-ppcre" self) + (getAttr "do-urlencode" self) + (getAttr "fast-http" self) + (getAttr "fast-io" self) + (getAttr "quri" self) + (getAttr "vom" self) + ]; + meta = { }; + } + ); + wordnet = ( + build-asdf-system { + pname = "wordnet"; + version = "20220220-git"; + asds = [ "wordnet" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/wordnet/2022-02-20/wordnet-20220220-git.tgz"; + sha256 = "07p60k295fsfcp0gmkqhrxd68hb38aqva8f4k8xk8bqqxxf42vkq"; + system = "wordnet"; + asd = "wordnet"; + } + ); + systems = [ "wordnet" ]; + lispLibs = [ (getAttr "split-sequence" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + workout-timer = ( + build-asdf-system { + pname = "workout-timer"; + version = "20230214-git"; + asds = [ "workout-timer" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/workout-timer/2023-02-14/workout-timer-20230214-git.tgz"; + sha256 = "1f8qj6la93k95xqkliv59r6dkyhyhzqp2zgk0s893a3mrar0gfrx"; + system = "workout-timer"; + asd = "workout-timer"; + } + ); + systems = [ "workout-timer" ]; + lispLibs = [ + (getAttr "cffi-toolchain" self) + (getAttr "command-line-arguments" self) + (getAttr "local-time" self) + (getAttr "mixalot" self) + (getAttr "mixalot-vorbis" self) + (getAttr "vorbisfile-ffi" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + wu-decimal = ( + build-asdf-system { + pname = "wu-decimal"; + version = "20130128-git"; + asds = [ "wu-decimal" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/wu-decimal/2013-01-28/wu-decimal-20130128-git.tgz"; + sha256 = "1p7na4hic7297amwm4idfwkyx664ny8cdssncyra37pmv4wzp8dm"; + system = "wu-decimal"; + asd = "wu-decimal"; + } + ); + systems = [ "wu-decimal" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + wu-sugar = ( + build-asdf-system { + pname = "wu-sugar"; + version = "20160825-git"; + asds = [ "wu-sugar" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/wu-sugar/2016-08-25/wu-sugar-20160825-git.tgz"; + sha256 = "0ypn5195krfd1rva5myla8j7n2ilfs5gxh81flx7v0mr4r70fayl"; + system = "wu-sugar"; + asd = "wu-sugar"; + } + ); + systems = [ "wu-sugar" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + wuwei = ( + build-asdf-system { + pname = "wuwei"; + version = "20221106-git"; + asds = [ "wuwei" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/wuwei/2022-11-06/wuwei-20221106-git.tgz"; + sha256 = "1k5yhxdqcx250kd56qgbch5z0hvjpjwch38c3949nf790pmrhl8f"; + system = "wuwei"; + asd = "wuwei"; + } + ); + systems = [ "wuwei" ]; + lispLibs = [ + (getAttr "aserve" self) + (getAttr "cl-json" self) + (getAttr "drakma" self) + (getAttr "ironclad" self) + (getAttr "mtlisp" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + wuwei-examples = ( + build-asdf-system { + pname = "wuwei-examples"; + version = "20221106-git"; + asds = [ "wuwei-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/wuwei/2022-11-06/wuwei-20221106-git.tgz"; + sha256 = "1k5yhxdqcx250kd56qgbch5z0hvjpjwch38c3949nf790pmrhl8f"; + system = "wuwei-examples"; + asd = "wuwei"; + } + ); + systems = [ "wuwei-examples" ]; + lispLibs = [ + (getAttr "drakma" self) + (getAttr "wuwei" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + x_dot_let-star = ( + build-asdf-system { + pname = "x.let-star"; + version = "20200325-git"; + asds = [ "x.let-star" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/x.let-star/2020-03-25/x.let-star-20200325-git.tgz"; + sha256 = "0qk0rpqzb7vaivggsqch06nmdjzp6b31a88w40y3864clajpcrnr"; + system = "x.let-star"; + asd = "x.let-star"; + } + ); + systems = [ "x.let-star" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xarray = ( + build-asdf-system { + pname = "xarray"; + version = "20140113-git"; + asds = [ "xarray" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xarray/2014-01-13/xarray-20140113-git.tgz"; + sha256 = "031h1bvy9s6qas2160dgf7gc0y6inrhpzp8j3wrb6fjxkb0524yl"; + system = "xarray"; + asd = "xarray"; + } + ); + systems = [ "xarray" ]; + lispLibs = [ + (getAttr "anaphora" self) + (getAttr "cl-utilities" self) + (getAttr "iterate" self) + (getAttr "metabang-bind" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xarray-test = ( + build-asdf-system { + pname = "xarray-test"; + version = "20140113-git"; + asds = [ "xarray-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xarray/2014-01-13/xarray-20140113-git.tgz"; + sha256 = "031h1bvy9s6qas2160dgf7gc0y6inrhpzp8j3wrb6fjxkb0524yl"; + system = "xarray-test"; + asd = "xarray-test"; + } + ); + systems = [ "xarray-test" ]; + lispLibs = [ + (getAttr "lift" self) + (getAttr "xarray" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xcat = ( + build-asdf-system { + pname = "xcat"; + version = "20200925-git"; + asds = [ "xcat" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xcat/2020-09-25/xcat-20200925-git.tgz"; + sha256 = "1v8mcz8bidcbfl587b5lm07l91xan6z1y3zikjkyzagiigd4byvi"; + system = "xcat"; + asd = "xcat"; + } + ); + systems = [ "xcat" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "flexi-streams" self) + (getAttr "log4cl" self) + (getAttr "trivial-features" self) + (getAttr "trivial-garbage" self) + (getAttr "usocket-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xecto = ( + build-asdf-system { + pname = "xecto"; + version = "20151218-git"; + asds = [ "xecto" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xecto/2015-12-18/xecto-20151218-git.tgz"; + sha256 = "1m81cl02k28v9sgscl8qhig735x5qybhw69szs6bkkqml7hbl12q"; + system = "xecto"; + asd = "xecto"; + } + ); + systems = [ "xecto" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xembed = ( + build-asdf-system { + pname = "xembed"; + version = "20191130-git"; + asds = [ "xembed" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clx-xembed/2019-11-30/clx-xembed-20191130-git.tgz"; + sha256 = "1abx4v36ycmfjdwpjk4hh8058ya8whwia7ds9vd96q2qsrs57f12"; + system = "xembed"; + asd = "xembed"; + } + ); + systems = [ "xembed" ]; + lispLibs = [ (getAttr "clx" self) ]; + meta = { }; + } + ); + xfactory = ( + build-asdf-system { + pname = "xfactory"; + version = "20130615-git"; + asds = [ "xfactory" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libxml2/2013-06-15/cl-libxml2-20130615-git.tgz"; + sha256 = "09049c13cfp5sc6x9lrw762jd7a9qkfq5jgngqgrzn4kn9qscarw"; + system = "xfactory"; + asd = "xfactory"; + } + ); + systems = [ "xfactory" ]; + lispLibs = [ (getAttr "cl-libxml2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xfactory-test = ( + build-asdf-system { + pname = "xfactory-test"; + version = "20130615-git"; + asds = [ "xfactory-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libxml2/2013-06-15/cl-libxml2-20130615-git.tgz"; + sha256 = "09049c13cfp5sc6x9lrw762jd7a9qkfq5jgngqgrzn4kn9qscarw"; + system = "xfactory-test"; + asd = "xfactory"; + } + ); + systems = [ "xfactory-test" ]; + lispLibs = [ + (getAttr "lift" self) + (getAttr "xfactory" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xhtmlambda = ( + build-asdf-system { + pname = "xhtmlambda"; + version = "20241012-git"; + asds = [ "xhtmlambda" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xhtmlambda/2024-10-12/xhtmlambda-20241012-git.tgz"; + sha256 = "1xqwps5lr66lhqiczvccxrpy8kff15fx6qr9nh1i65wi4p68i1bb"; + system = "xhtmlambda"; + asd = "xhtmlambda"; + } + ); + systems = [ "xhtmlambda" ]; + lispLibs = [ (getAttr "cl-unicode" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xhtmlgen = ( + build-asdf-system { + pname = "xhtmlgen"; + version = "20170124-git"; + asds = [ "xhtmlgen" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xhtmlgen/2017-01-24/xhtmlgen-20170124-git.tgz"; + sha256 = "0br4pqhl7y7rd95l9xx2p96gds3dh4pgk9v038wbshl2dnhjv82k"; + system = "xhtmlgen"; + asd = "xhtmlgen"; + } + ); + systems = [ "xhtmlgen" ]; + lispLibs = [ (getAttr "cxml" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xhtmlgen-test = ( + build-asdf-system { + pname = "xhtmlgen-test"; + version = "20170124-git"; + asds = [ "xhtmlgen-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xhtmlgen/2017-01-24/xhtmlgen-20170124-git.tgz"; + sha256 = "0br4pqhl7y7rd95l9xx2p96gds3dh4pgk9v038wbshl2dnhjv82k"; + system = "xhtmlgen-test"; + asd = "xhtmlgen"; + } + ); + systems = [ "xhtmlgen-test" ]; + lispLibs = [ + (getAttr "rt" self) + (getAttr "xhtmlgen" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xkeyboard = ( + build-asdf-system { + pname = "xkeyboard"; + version = "20120811-git"; + asds = [ "xkeyboard" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clx-xkeyboard/2012-08-11/clx-xkeyboard-20120811-git.tgz"; + sha256 = "1nxky9wsmm7nmwz372jgb4iy0ywlm22jw0vl8yi0k9slsfklvcqi"; + system = "xkeyboard"; + asd = "xkeyboard"; + } + ); + systems = [ "xkeyboard" ]; + lispLibs = [ (getAttr "clx" self) ]; + meta = { }; + } + ); + xkeyboard-test = ( + build-asdf-system { + pname = "xkeyboard-test"; + version = "20120811-git"; + asds = [ "xkeyboard-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/clx-xkeyboard/2012-08-11/clx-xkeyboard-20120811-git.tgz"; + sha256 = "1nxky9wsmm7nmwz372jgb4iy0ywlm22jw0vl8yi0k9slsfklvcqi"; + system = "xkeyboard-test"; + asd = "xkeyboard"; + } + ); + systems = [ "xkeyboard-test" ]; + lispLibs = [ (getAttr "xkeyboard" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xlsx = ( + build-asdf-system { + pname = "xlsx"; + version = "20180711-git"; + asds = [ "xlsx" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xlsx/2018-07-11/xlsx-20180711-git.tgz"; + sha256 = "15vw5zl13jg9b1rla7w2wv6ss93mijrnn9fzsh0fakgvfikqq1n6"; + system = "xlsx"; + asd = "xlsx"; + } + ); + systems = [ "xlsx" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "xmls" self) + (getAttr "zip" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xlunit = ( + build-asdf-system { + pname = "xlunit"; + version = "20150923-git"; + asds = [ "xlunit" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xlunit/2015-09-23/xlunit-20150923-git.tgz"; + sha256 = "0argfmp9nghs4sihyj3f8ch9qfib2b7ll07v5m9ziajgzsfl5xw3"; + system = "xlunit"; + asd = "xlunit"; + } + ); + systems = [ "xlunit" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xlunit-tests = ( + build-asdf-system { + pname = "xlunit-tests"; + version = "20150923-git"; + asds = [ "xlunit-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xlunit/2015-09-23/xlunit-20150923-git.tgz"; + sha256 = "0argfmp9nghs4sihyj3f8ch9qfib2b7ll07v5m9ziajgzsfl5xw3"; + system = "xlunit-tests"; + asd = "xlunit"; + } + ); + systems = [ "xlunit-tests" ]; + lispLibs = [ (getAttr "xlunit" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xml-emitter = ( + build-asdf-system { + pname = "xml-emitter"; + version = "20241012-git"; + asds = [ "xml-emitter" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xml-emitter/2024-10-12/xml-emitter-20241012-git.tgz"; + sha256 = "1q7iygd1v857a3c72kv4zxm9nhx94kkam4p8z5v10q2r2cwfps1w"; + system = "xml-emitter"; + asd = "xml-emitter"; + } + ); + systems = [ "xml-emitter" ]; + lispLibs = [ (getAttr "cl-utilities" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xml-mop = ( + build-asdf-system { + pname = "xml-mop"; + version = "20110418-git"; + asds = [ "xml-mop" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xml-mop/2011-04-18/xml-mop-20110418-git.tgz"; + sha256 = "1vfa3h5dghnpc7qbqqm80mm1ri6x7x5r528kvkwzngghrbxyhgjr"; + system = "xml-mop"; + asd = "xml-mop"; + } + ); + systems = [ "xml-mop" ]; + lispLibs = [ + (getAttr "closer-mop" self) + (getAttr "s-xml" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xml-render = ( + build-asdf-system { + pname = "xml-render"; + version = "20210531-git"; + asds = [ "xml-render" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-typesetting/2021-05-31/cl-typesetting-20210531-git.tgz"; + sha256 = "0fcs5mq0gxfczbrg7ay8r4bf5r4g6blvpdbjkhcl8dapcikyn35h"; + system = "xml-render"; + asd = "xml-render"; + } + ); + systems = [ "xml-render" ]; + lispLibs = [ + (getAttr "cl-typesetting" self) + (getAttr "xmls" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xml_dot_location = ( + build-asdf-system { + pname = "xml.location"; + version = "20200325-git"; + asds = [ "xml.location" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xml.location/2020-03-25/xml.location-20200325-git.tgz"; + sha256 = "0ajl03k7krns6b0z3ykmngq3i77yd2j85z3h76drlc9whxvm2kii"; + system = "xml.location"; + asd = "xml.location"; + } + ); + systems = [ "xml.location" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "closer-mop" self) + (getAttr "cxml-stp" self) + (getAttr "iterate" self) + (getAttr "let-plus" self) + (getAttr "more-conditions" self) + (getAttr "split-sequence" self) + (getAttr "xpath" self) + ]; + meta = { }; + } + ); + xml_dot_location-and-local-time = ( + build-asdf-system { + pname = "xml.location-and-local-time"; + version = "20200325-git"; + asds = [ "xml.location-and-local-time" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xml.location/2020-03-25/xml.location-20200325-git.tgz"; + sha256 = "0ajl03k7krns6b0z3ykmngq3i77yd2j85z3h76drlc9whxvm2kii"; + system = "xml.location-and-local-time"; + asd = "xml.location-and-local-time"; + } + ); + systems = [ "xml.location-and-local-time" ]; + lispLibs = [ + (getAttr "local-time" self) + (getAttr "xml_dot_location" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xmls = ( + build-asdf-system { + pname = "xmls"; + version = "release-310ba849-git"; + asds = [ "xmls" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xmls/2023-10-21/xmls-release-310ba849-git.tgz"; + sha256 = "0s1acd2r77v6x9f2kmd15njkmvvx3ivivlk509ndgmdhnn2jd776"; + system = "xmls"; + asd = "xmls"; + } + ); + systems = [ "xmls" ]; + lispLibs = [ ]; + meta = { }; + } + ); + xoverlay = ( + build-asdf-system { + pname = "xoverlay"; + version = "20130615-git"; + asds = [ "xoverlay" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-libxml2/2013-06-15/cl-libxml2-20130615-git.tgz"; + sha256 = "09049c13cfp5sc6x9lrw762jd7a9qkfq5jgngqgrzn4kn9qscarw"; + system = "xoverlay"; + asd = "xoverlay"; + } + ); + systems = [ "xoverlay" ]; + lispLibs = [ (getAttr "cl-libxml2" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xpath = ( + build-asdf-system { + pname = "xpath"; + version = "20190521-git"; + asds = [ "xpath" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/plexippus-xpath/2019-05-21/plexippus-xpath-20190521-git.tgz"; + sha256 = "1fb03fgnzrvh22lw1jdg04pmyja5fib5n42rzwp5mhr829yvxkvp"; + system = "xpath"; + asd = "xpath"; + } + ); + systems = [ "xpath" ]; + lispLibs = [ + (getAttr "cl-ppcre" self) + (getAttr "cxml" self) + (getAttr "parse-number" self) + (getAttr "yacc" self) + ]; + meta = { }; + } + ); + xptest = ( + build-asdf-system { + pname = "xptest"; + version = "20150923-git"; + asds = [ "xptest" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xptest/2015-09-23/xptest-20150923-git.tgz"; + sha256 = "02jwncq5d60l77gf87ahabzg6k6c878gfc4x1mf6ld97rj5lzp3b"; + system = "xptest"; + asd = "xptest"; + } + ); + systems = [ "xptest" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xsubseq = ( + build-asdf-system { + pname = "xsubseq"; + version = "20170830-git"; + asds = [ "xsubseq" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xsubseq/2017-08-30/xsubseq-20170830-git.tgz"; + sha256 = "1xz79q0p2mclf3sqjiwf6izdpb6xrsr350bv4mlmdlm6rg5r99px"; + system = "xsubseq"; + asd = "xsubseq"; + } + ); + systems = [ "xsubseq" ]; + lispLibs = [ ]; + meta = { }; + } + ); + xsubseq-test = ( + build-asdf-system { + pname = "xsubseq-test"; + version = "20170830-git"; + asds = [ "xsubseq-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xsubseq/2017-08-30/xsubseq-20170830-git.tgz"; + sha256 = "1xz79q0p2mclf3sqjiwf6izdpb6xrsr350bv4mlmdlm6rg5r99px"; + system = "xsubseq-test"; + asd = "xsubseq-test"; + } + ); + systems = [ "xsubseq-test" ]; + lispLibs = [ + (getAttr "prove" self) + (getAttr "prove-asdf" self) + (getAttr "xsubseq" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + xuriella = ( + build-asdf-system { + pname = "xuriella"; + version = "20120305-git"; + asds = [ "xuriella" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/xuriella/2012-03-05/xuriella-20120305-git.tgz"; + sha256 = "0wz98bfvr7h7g0r7dy815brq5sz3x40281hp0qk801q17aa4qhqh"; + system = "xuriella"; + asd = "xuriella"; + } + ); + systems = [ "xuriella" ]; + lispLibs = [ + (getAttr "closure-html" self) + (getAttr "cxml" self) + (getAttr "cxml-stp" self) + (getAttr "split-sequence" self) + (getAttr "xpath" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + yacc = ( + build-asdf-system { + pname = "yacc"; + version = "20230214-git"; + asds = [ "yacc" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-yacc/2023-02-14/cl-yacc-20230214-git.tgz"; + sha256 = "1f974ysi7mlrksnqg63iwwxgbypkng4n240q29imkrz6m5pwdig7"; + system = "yacc"; + asd = "yacc"; + } + ); + systems = [ "yacc" ]; + lispLibs = [ ]; + meta = { }; + } + ); + yaclml = ( + build-asdf-system { + pname = "yaclml"; + version = "20180131-git"; + asds = [ "yaclml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/yaclml/2018-01-31/yaclml-20180131-git.tgz"; + sha256 = "0wq6clk4qwbdaf0hcfjz4vg27nyf6ng0rrip1ay4rlkb03hdnssq"; + system = "yaclml"; + asd = "yaclml"; + } + ); + systems = [ "yaclml" ]; + lispLibs = [ + (getAttr "arnesi" self) + (getAttr "iterate" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + yadd = ( + build-asdf-system { + pname = "yadd"; + version = "master-fe503896-git"; + asds = [ "yadd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/gendl/2023-10-21/gendl-master-fe503896-git.tgz"; + sha256 = "0raymbbp71zfyiq6z2qvdh2h8jab3ilc0slxi2m8i7cz0kj1zw10"; + system = "yadd"; + asd = "yadd"; + } + ); + systems = [ "yadd" ]; + lispLibs = [ + (getAttr "cl-html-parse" self) + (getAttr "gwl-graphics" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + yah = ( + build-asdf-system { + pname = "yah"; + version = "20231021-git"; + asds = [ "yah" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/yah/2023-10-21/yah-20231021-git.tgz"; + sha256 = "1sklx9ak2rh9h19805i9wbym889pwd1qh3d4c4fsk9cbj2i9yxx5"; + system = "yah"; + asd = "yah"; + } + ); + systems = [ "yah" ]; + lispLibs = [ (getAttr "mgl-pax" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + yason = ( + build-asdf-system { + pname = "yason"; + version = "20241012-git"; + asds = [ "yason" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/yason/2024-10-12/yason-20241012-git.tgz"; + sha256 = "00hqii9n6ay5cq1ahbqpnw3l3v0mmz5s1f9kn6l35g8zxj1nlpa7"; + system = "yason"; + asd = "yason"; + } + ); + systems = [ "yason" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { }; + } + ); + yason-tests = ( + build-asdf-system { + pname = "yason-tests"; + version = "20241012-git"; + asds = [ "yason-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/yason/2024-10-12/yason-20241012-git.tgz"; + sha256 = "00hqii9n6ay5cq1ahbqpnw3l3v0mmz5s1f9kn6l35g8zxj1nlpa7"; + system = "yason-tests"; + asd = "yason-tests"; + } + ); + systems = [ "yason-tests" ]; + lispLibs = [ + (getAttr "unit-test" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + youtube = ( + build-asdf-system { + pname = "youtube"; + version = "20191227-git"; + asds = [ "youtube" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/youtube/2019-12-27/youtube-20191227-git.tgz"; + sha256 = "0rqbyxgb9v3m8rwx2agaz7cq83w9k8gy5wl5wbw0rfg7r88ah5z0"; + system = "youtube"; + asd = "youtube"; + } + ); + systems = [ "youtube" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl-ppcre" self) + (getAttr "yason" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + yxorp = ( + build-asdf-system { + pname = "yxorp"; + version = "20231021-git"; + asds = [ "yxorp" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-yxorp/2023-10-21/cl-yxorp-20231021-git.tgz"; + sha256 = "0l84icr1d3z2k6rs92lgkghwqm6w3i87d1sz4c8mpfcyfb5shgzn"; + system = "yxorp"; + asd = "yxorp"; + } + ); + systems = [ "yxorp" ]; + lispLibs = [ + (getAttr "binding-arrows" self) + (getAttr "chipz" self) + (getAttr "chunga" self) + (getAttr "cl_plus_ssl" self) + (getAttr "flexi-streams" self) + (getAttr "rutils" self) + (getAttr "salza2" self) + (getAttr "smart-buffer" self) + (getAttr "str" self) + (getAttr "trivial-garbage" self) + (getAttr "usocket" self) + (getAttr "usocket-server" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zacl = ( + build-asdf-system { + pname = "zacl"; + version = "20230618-git"; + asds = [ "zacl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zacl/2023-06-18/zacl-20230618-git.tgz"; + sha256 = "1s31d47zx8hczim78zrqzg4bvj4bshj31gmrff065q6racx3q1dk"; + system = "zacl"; + asd = "zacl"; + } + ); + systems = [ "zacl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "atomics" self) + (getAttr "babel-streams" self) + (getAttr "bordeaux-threads" self) + (getAttr "cl_plus_ssl" self) + (getAttr "cl-base64" self) + (getAttr "cl-ppcre" self) + (getAttr "cl-store" self) + (getAttr "local-time" self) + (getAttr "md5" self) + (getAttr "queues_dot_simple-queue" self) + (getAttr "quri" self) + (getAttr "setup-cl_plus_ssl" self) + (getAttr "split-sequence" self) + (getAttr "trivial-backtrace" self) + (getAttr "trivial-garbage" self) + (getAttr "usocket" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zaserve = ( + build-asdf-system { + pname = "zaserve"; + version = "20230618-git"; + asds = [ "zaserve" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/aserve/2023-06-18/aserve-20230618-git.tgz"; + sha256 = "1i88264yghlb4brdh58hn9cps695gh63b6w6i8dmsd9rqwhlsibi"; + system = "zaserve"; + asd = "zaserve"; + } + ); + systems = [ "zaserve" ]; + lispLibs = [ + (getAttr "setup-cl_plus_ssl" self) + (getAttr "zacl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zaws = ( + build-asdf-system { + pname = "zaws"; + version = "20150407-git"; + asds = [ "zaws" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zaws/2015-04-07/zaws-20150407-git.tgz"; + sha256 = "1iwjyqzm4b44in7i53z5lp8n4gzsi27ch02ql6y2vxbmq3sqffaw"; + system = "zaws"; + asd = "zaws"; + } + ); + systems = [ "zaws" ]; + lispLibs = [ + (getAttr "cl-base64" self) + (getAttr "drakma" self) + (getAttr "flexi-streams" self) + (getAttr "ironclad" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zaws-xml = ( + build-asdf-system { + pname = "zaws-xml"; + version = "20150407-git"; + asds = [ "zaws-xml" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zaws/2015-04-07/zaws-20150407-git.tgz"; + sha256 = "1iwjyqzm4b44in7i53z5lp8n4gzsi27ch02ql6y2vxbmq3sqffaw"; + system = "zaws-xml"; + asd = "zaws-xml"; + } + ); + systems = [ "zaws-xml" ]; + lispLibs = [ (getAttr "cxml" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zbucium = ( + build-asdf-system { + pname = "zbucium"; + version = "20190710-git"; + asds = [ "zbucium" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zbucium/2019-07-10/zbucium-20190710-git.tgz"; + sha256 = "112qx8lwcsaipnnypv2jr57lwhlgzb5n53wgck3r66b8vjjb91gy"; + system = "zbucium"; + asd = "zbucium"; + } + ); + systems = [ "zbucium" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "bordeaux-threads" self) + (getAttr "drakma" self) + (getAttr "fare-memoization" self) + (getAttr "generators" self) + (getAttr "lastfm" self) + (getAttr "local-time" self) + (getAttr "lquery" self) + (getAttr "lyrics" self) + (getAttr "plump" self) + (getAttr "yason" self) + (getAttr "youtube" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zcdb = ( + build-asdf-system { + pname = "zcdb"; + version = "1.0.4"; + asds = [ "zcdb" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zcdb/2015-04-07/zcdb-1.0.4.tgz"; + sha256 = "1g83hqivh40xrpifm9v1vx92h13g5kzn12fjrlk57fyl1qwjqdi7"; + system = "zcdb"; + asd = "zcdb"; + } + ); + systems = [ "zcdb" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zenekindarl = ( + build-asdf-system { + pname = "zenekindarl"; + version = "20171130-git"; + asds = [ "zenekindarl" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zenekindarl/2017-11-30/zenekindarl-20171130-git.tgz"; + sha256 = "104y98j8fjj4wry55mhgv3g6358h5n1qcbhpn19b27b8cs8gqwib"; + system = "zenekindarl"; + asd = "zenekindarl"; + } + ); + systems = [ "zenekindarl" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "anaphora" self) + (getAttr "babel" self) + (getAttr "cl-annot" self) + (getAttr "cl-ppcre" self) + (getAttr "fast-io" self) + (getAttr "html-encode" self) + (getAttr "maxpc" self) + (getAttr "optima" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zenekindarl-test = ( + build-asdf-system { + pname = "zenekindarl-test"; + version = "20171130-git"; + asds = [ "zenekindarl-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zenekindarl/2017-11-30/zenekindarl-20171130-git.tgz"; + sha256 = "104y98j8fjj4wry55mhgv3g6358h5n1qcbhpn19b27b8cs8gqwib"; + system = "zenekindarl-test"; + asd = "zenekindarl-test"; + } + ); + systems = [ "zenekindarl-test" ]; + lispLibs = [ + (getAttr "flexi-streams" self) + (getAttr "prove" self) + (getAttr "zenekindarl" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zeromq = ( + build-asdf-system { + pname = "zeromq"; + version = "20160318-git"; + asds = [ "zeromq" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-zmq/2016-03-18/cl-zmq-20160318-git.tgz"; + sha256 = "0g19ych3n57qdd42m0bcdcrq8c1p0fqzz07xrxl0s0g8bms3a3ga"; + system = "zeromq"; + asd = "zeromq"; + } + ); + systems = [ "zeromq" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zeromq_dot_tests = ( + build-asdf-system { + pname = "zeromq.tests"; + version = "20160318-git"; + asds = [ "zeromq.tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-zmq/2016-03-18/cl-zmq-20160318-git.tgz"; + sha256 = "0g19ych3n57qdd42m0bcdcrq8c1p0fqzz07xrxl0s0g8bms3a3ga"; + system = "zeromq.tests"; + asd = "zeromq"; + } + ); + systems = [ "zeromq.tests" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "fiveam" self) + (getAttr "zeromq" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zip = ( + build-asdf-system { + pname = "zip"; + version = "20150608-git"; + asds = [ "zip" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zip/2015-06-08/zip-20150608-git.tgz"; + sha256 = "0s08a6fq182fzsbfyvihqbdllq6gxcwkvphxnrd9wwz65dhg5y66"; + system = "zip"; + asd = "zip"; + } + ); + systems = [ "zip" ]; + lispLibs = [ + (getAttr "babel" self) + (getAttr "cl-fad" self) + (getAttr "salza2" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zippy = ( + build-asdf-system { + pname = "zippy"; + version = "20241012-git"; + asds = [ "zippy" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zippy/2024-10-12/zippy-20241012-git.tgz"; + sha256 = "06znhzi4zjg2p2858cwnlslqvx28zlmqr9jqij0rkvnn7ysa7qcg"; + system = "zippy"; + asd = "zippy"; + } + ); + systems = [ "zippy" ]; + lispLibs = [ + (getAttr "_3bz" self) + (getAttr "alexandria" self) + (getAttr "babel" self) + (getAttr "documentation-utils" self) + (getAttr "file-attributes" self) + (getAttr "filesystem-utils" self) + (getAttr "nibbles" self) + (getAttr "pathname-utils" self) + (getAttr "salza2" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zippy-dwim = ( + build-asdf-system { + pname = "zippy-dwim"; + version = "20241012-git"; + asds = [ "zippy-dwim" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zippy/2024-10-12/zippy-20241012-git.tgz"; + sha256 = "06znhzi4zjg2p2858cwnlslqvx28zlmqr9jqij0rkvnn7ysa7qcg"; + system = "zippy-dwim"; + asd = "zippy-dwim"; + } + ); + systems = [ "zippy-dwim" ]; + lispLibs = [ + (getAttr "deploy" self) + (getAttr "zippy" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + ziz = ( + build-asdf-system { + pname = "ziz"; + version = "20191007-git"; + asds = [ "ziz" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/ziz/2019-10-07/ziz-20191007-git.tgz"; + sha256 = "1rh6ixkyyj7y9jkw046m4ilmr8a12ylzm0a7sm8mjybdpkh6bk30"; + system = "ziz"; + asd = "ziz"; + } + ); + systems = [ "ziz" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "hunchentoot" self) + (getAttr "ironclad" self) + (getAttr "trivial-file-size" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zlib = ( + build-asdf-system { + pname = "zlib"; + version = "20170403-git"; + asds = [ "zlib" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zlib/2017-04-03/zlib-20170403-git.tgz"; + sha256 = "1gz771h2q3xhw1yxpwki5zr9mqysa818vn21501w6fsi8wlmlffa"; + system = "zlib"; + asd = "zlib"; + } + ); + systems = [ "zlib" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zmq = ( + build-asdf-system { + pname = "zmq"; + version = "20200218-git"; + asds = [ "zmq" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-zmq/2020-02-18/lisp-zmq-20200218-git.tgz"; + sha256 = "01aavmnn2lbsaq957p1qll21hmhvhkrqhq3kazmz88sc40x1n0ld"; + system = "zmq"; + asd = "zmq"; + } + ); + systems = [ "zmq" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "trivial-features" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zmq-examples = ( + build-asdf-system { + pname = "zmq-examples"; + version = "20200218-git"; + asds = [ "zmq-examples" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-zmq/2020-02-18/lisp-zmq-20200218-git.tgz"; + sha256 = "01aavmnn2lbsaq957p1qll21hmhvhkrqhq3kazmz88sc40x1n0ld"; + system = "zmq-examples"; + asd = "zmq-examples"; + } + ); + systems = [ "zmq-examples" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "zmq" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zmq-test = ( + build-asdf-system { + pname = "zmq-test"; + version = "20200218-git"; + asds = [ "zmq-test" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/lisp-zmq/2020-02-18/lisp-zmq-20200218-git.tgz"; + sha256 = "01aavmnn2lbsaq957p1qll21hmhvhkrqhq3kazmz88sc40x1n0ld"; + system = "zmq-test"; + asd = "zmq-test"; + } + ); + systems = [ "zmq-test" ]; + lispLibs = [ + (getAttr "bordeaux-threads" self) + (getAttr "fiveam" self) + (getAttr "zmq" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zpb-exif = ( + build-asdf-system { + pname = "zpb-exif"; + version = "release-1.2.5"; + asds = [ "zpb-exif" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zpb-exif/2021-01-24/zpb-exif-release-1.2.5.tgz"; + sha256 = "0h1n36lfl8xn8rfyl5jxz9m8zlg0if2avmryas79f684yczrvdnd"; + system = "zpb-exif"; + asd = "zpb-exif"; + } + ); + systems = [ "zpb-exif" ]; + lispLibs = [ ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zpb-ttf = ( + build-asdf-system { + pname = "zpb-ttf"; + version = "release-1.0.7"; + asds = [ "zpb-ttf" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zpb-ttf/2024-10-12/zpb-ttf-release-1.0.7.tgz"; + sha256 = "04lph7i153zlswvpgg76fxazyswj8j0idqm4ysn8qmflb7xcvd78"; + system = "zpb-ttf"; + asd = "zpb-ttf"; + } + ); + systems = [ "zpb-ttf" ]; + lispLibs = [ ]; + meta = { }; + } + ); + zpng = ( + build-asdf-system { + pname = "zpng"; + version = "1.2.2"; + asds = [ "zpng" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zpng/2015-04-07/zpng-1.2.2.tgz"; + sha256 = "0b3ag3jhl3z7kdls3ahdsdxsfhhw5qrizk769984f4wkxhb69rcm"; + system = "zpng"; + asd = "zpng"; + } + ); + systems = [ "zpng" ]; + lispLibs = [ (getAttr "salza2" self) ]; + meta = { }; + } + ); + zs3 = ( + build-asdf-system { + pname = "zs3"; + version = "1.3.3"; + asds = [ "zs3" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zs3/2019-10-07/zs3-1.3.3.tgz"; + sha256 = "186v95wgsj2hkxdw2jl9x1w4fddjclp7arp0rrd9vf5ly8h8sbf3"; + system = "zs3"; + asd = "zs3"; + } + ); + systems = [ "zs3" ]; + lispLibs = [ + (getAttr "alexandria" self) + (getAttr "cl-base64" self) + (getAttr "cxml" self) + (getAttr "drakma" self) + (getAttr "ironclad" self) + (getAttr "puri" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zsort = ( + build-asdf-system { + pname = "zsort"; + version = "20120520-git"; + asds = [ "zsort" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/zsort/2012-05-20/zsort-20120520-git.tgz"; + sha256 = "1vyklyh99712zsll4qi0m4mm8yb1nz04403vl8i57bjv5p5max49"; + system = "zsort"; + asd = "zsort"; + } + ); + systems = [ "zsort" ]; + lispLibs = [ (getAttr "alexandria" self) ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zstd = ( + build-asdf-system { + pname = "zstd"; + version = "20230618-git"; + asds = [ "zstd" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-zstd/2023-06-18/cl-zstd-20230618-git.tgz"; + sha256 = "037igr1v849smcs6svjb5s850k5s5yfg74d4gb3ir4b4v9g4k97i"; + system = "zstd"; + asd = "zstd"; + } + ); + systems = [ "zstd" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cl-octet-streams" self) + (getAttr "trivial-gray-streams" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zstd-tests = ( + build-asdf-system { + pname = "zstd-tests"; + version = "20230618-git"; + asds = [ "zstd-tests" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-zstd/2023-06-18/cl-zstd-20230618-git.tgz"; + sha256 = "037igr1v849smcs6svjb5s850k5s5yfg74d4gb3ir4b4v9g4k97i"; + system = "zstd-tests"; + asd = "zstd-tests"; + } + ); + systems = [ "zstd-tests" ]; + lispLibs = [ + (getAttr "cl-octet-streams" self) + (getAttr "fiveam" self) + (getAttr "zstd" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); + zyre = ( + build-asdf-system { + pname = "zyre"; + version = "20200925-git"; + asds = [ "zyre" ]; + src = ( + createAsd { + url = "http://beta.quicklisp.org/archive/cl-zyre/2020-09-25/cl-zyre-20200925-git.tgz"; + sha256 = "1pfb176k655hxksyrans5j43ridvpkl8q8h6d37zgi2z4iiz15wv"; + system = "zyre"; + asd = "zyre"; + } + ); + systems = [ "zyre" ]; + lispLibs = [ + (getAttr "cffi" self) + (getAttr "cffi-grovel" self) + (getAttr "trivia" self) + (getAttr "trivial-garbage" self) + ]; + meta = { + hydraPlatforms = [ ]; + }; + } + ); }) diff --git a/pkgs/development/lisp-modules/nix-cl.nix b/pkgs/development/lisp-modules/nix-cl.nix index a1441d2e57fffe..773372d25afa3c 100644 --- a/pkgs/development/lisp-modules/nix-cl.nix +++ b/pkgs/development/lisp-modules/nix-cl.nix @@ -10,10 +10,12 @@ # - figure out a less awkward way to patch sources # (have to build from src directly for SLIME to work, so can't just patch sources in place) -{ pkgs -, lib -, stdenv -, ... }: +{ + pkgs, + lib, + stdenv, + ... +}: let @@ -46,35 +48,52 @@ let makeLibraryPath makeSearchPath recurseIntoAttrs - ; + ; inherit (builtins) head tail elem split - storeDir; + storeDir + ; inherit (pkgs) - substituteAll; + substituteAll + ; # Stolen from python-packages.nix # Actually no idea how this works - makeOverridableLispPackage = f: origArgs: + makeOverridableLispPackage = + f: origArgs: let ff = f origArgs; - overrideWith = newArgs: origArgs // (if pkgs.lib.isFunction newArgs then newArgs origArgs else newArgs); + overrideWith = + newArgs: origArgs // (if pkgs.lib.isFunction newArgs then newArgs origArgs else newArgs); in - if builtins.isAttrs ff then (ff // { - overrideLispAttrs = newArgs: makeOverridableLispPackage f (overrideWith newArgs); - }) - else if builtins.isFunction ff then { + if builtins.isAttrs ff then + ( + ff + // { + overrideLispAttrs = newArgs: makeOverridableLispPackage f (overrideWith newArgs); + } + ) + else if builtins.isFunction ff then + { overrideLispAttrs = newArgs: makeOverridableLispPackage f (overrideWith newArgs); __functor = self: ff; } - else ff; + else + ff; - buildAsdf = { asdf, pkg, program, flags, faslExt }: + buildAsdf = + { + asdf, + pkg, + program, + flags, + faslExt, + }: stdenv.mkDerivation { inherit (asdf) pname version; dontUnpack = true; @@ -88,26 +107,26 @@ let ''; }; - # # Wrapper around stdenv.mkDerivation for building ASDF systems. # build-asdf-system = makeOverridableLispPackage ( - { pname, + { + pname, version, src ? null, - patches ? [], + patches ? [ ], # Native libraries, will be appended to the library path - nativeLibs ? [], + nativeLibs ? [ ], # Java libraries for ABCL, will be appended to the class path - javaLibs ? [], + javaLibs ? [ ], # Lisp dependencies # these should be packages built with `build-asdf-system` # TODO(kasper): use propagatedBuildInputs - lispLibs ? [], + lispLibs ? [ ], # Derivation containing the CL implementation package pkg, @@ -116,7 +135,7 @@ let program ? pkg.meta.mainProgram or pkg.pname, # General flags to the Lisp executable - flags ? [], + flags ? [ ], # Extension for implementation-dependent FASL files faslExt, @@ -143,117 +162,147 @@ let # Other args to mkDerivation ... - } @ args: - - (stdenv.mkDerivation (rec { - inherit - version nativeLibs javaLibs lispLibs systems asds - pkg program flags faslExt - ; - - # When src is null, we are building a lispWithPackages and only - # want to make use of the dependency environment variables - # generated by build-asdf-system - dontUnpack = src == null; - - # Portable script to build the systems. - # - # `lisp` must evaluate this file then exit immediately. For - # example, SBCL's --script flag does just that. - # - # NOTE: - # Every other library worked fine with asdf:compile-system in - # buildScript. - # - # cl-syslog, for some reason, signals that CL-SYSLOG::VALID-SD-ID-P - # is undefined with compile-system, but works perfectly with - # load-system. Strange. - - # TODO(kasper) portable quit - asdfFasl = buildAsdf { inherit asdf pkg program flags faslExt; }; - - buildScript = substituteAll { - src = ./builder.lisp; - asdf = "${asdfFasl}/asdf.${faslExt}"; - }; - - configurePhase = '' - runHook preConfigure - - source ${./setup-hook.sh} - buildAsdfPath - - runHook postConfigure - ''; - - buildPhase = optionalString (src != null) '' - runHook preBuild - - export CL_SOURCE_REGISTRY=$CL_SOURCE_REGISTRY:$src// - export ASDF_OUTPUT_TRANSLATIONS="$src:$(pwd):${storeDir}:${storeDir}" - ${pkg}/bin/${program} ${toString flags} < $buildScript - - runHook postBuild - ''; - - # Copy compiled files to store - # - # Make sure to include '$' in regex to prevent skipping - # stuff like 'iolib.asdf.asd' for system 'iolib.asd' - # - # Same with '/': `local-time.asd` for system `cl-postgres+local-time.asd` - installPhase = - let - mkSystemsRegex = systems: - concatMapStringsSep "\\|" (replaceStrings ["." "+"] ["[.]" "[+]"]) systems; - in - '' - runHook preInstall - - mkdir -pv $out - cp -r * $out - - # Remove all .asd files except for those in `systems`. - find $out -name "*.asd" \ - | grep -v "/\(${mkSystemsRegex systems}\)\.asd$" \ - | xargs rm -fv || true - - runHook postInstall - ''; - - dontPatchShebangs = true; - - # Not sure if it's needed, but caused problems with SBCL - # save-lisp-and-die binaries in the past - dontStrip = true; - - } // (args // (let - isJVM = args.pkg.pname == "abcl"; - javaLibs = lib.optionals isJVM args.javaLibs or []; - in { - pname = "${args.pkg.pname}-${args.pname}"; - src = if args?patches || args?postPatch - then pkgs.applyPatches { - inherit (args) src; - patches = args.patches or []; - postPatch = args.postPatch or ""; + }@args: + + ( + stdenv.mkDerivation ( + rec { + inherit + version + nativeLibs + javaLibs + lispLibs + systems + asds + pkg + program + flags + faslExt + ; + + # When src is null, we are building a lispWithPackages and only + # want to make use of the dependency environment variables + # generated by build-asdf-system + dontUnpack = src == null; + + # Portable script to build the systems. + # + # `lisp` must evaluate this file then exit immediately. For + # example, SBCL's --script flag does just that. + # + # NOTE: + # Every other library worked fine with asdf:compile-system in + # buildScript. + # + # cl-syslog, for some reason, signals that CL-SYSLOG::VALID-SD-ID-P + # is undefined with compile-system, but works perfectly with + # load-system. Strange. + + # TODO(kasper) portable quit + asdfFasl = buildAsdf { + inherit + asdf + pkg + program + flags + faslExt + ; + }; + + buildScript = substituteAll { + src = ./builder.lisp; + asdf = "${asdfFasl}/asdf.${faslExt}"; + }; + + configurePhase = '' + runHook preConfigure + + source ${./setup-hook.sh} + buildAsdfPath + + runHook postConfigure + ''; + + buildPhase = optionalString (src != null) '' + runHook preBuild + + export CL_SOURCE_REGISTRY=$CL_SOURCE_REGISTRY:$src// + export ASDF_OUTPUT_TRANSLATIONS="$src:$(pwd):${storeDir}:${storeDir}" + ${pkg}/bin/${program} ${toString flags} < $buildScript + + runHook postBuild + ''; + + # Copy compiled files to store + # + # Make sure to include '$' in regex to prevent skipping + # stuff like 'iolib.asdf.asd' for system 'iolib.asd' + # + # Same with '/': `local-time.asd` for system `cl-postgres+local-time.asd` + installPhase = + let + mkSystemsRegex = + systems: concatMapStringsSep "\\|" (replaceStrings [ "." "+" ] [ "[.]" "[+]" ]) systems; + in + '' + runHook preInstall + + mkdir -pv $out + cp -r * $out + + # Remove all .asd files except for those in `systems`. + find $out -name "*.asd" \ + | grep -v "/\(${mkSystemsRegex systems}\)\.asd$" \ + | xargs rm -fv || true + + runHook postInstall + ''; + + dontPatchShebangs = true; + + # Not sure if it's needed, but caused problems with SBCL + # save-lisp-and-die binaries in the past + dontStrip = true; + + } + // ( + args + // ( + let + isJVM = args.pkg.pname == "abcl"; + javaLibs = lib.optionals isJVM args.javaLibs or [ ]; + in + { + pname = "${args.pkg.pname}-${args.pname}"; + src = + if args ? patches || args ? postPatch then + pkgs.applyPatches { + inherit (args) src; + patches = args.patches or [ ]; + postPatch = args.postPatch or ""; + } + else + args.src; + patches = [ ]; + inherit javaLibs; + propagatedBuildInputs = args.propagatedBuildInputs or [ ] ++ lispLibs ++ javaLibs ++ nativeLibs; + meta = (args.meta or { }) // { + maintainers = args.meta.maintainers or lib.teams.lisp.members; + }; } - else args.src; - patches = []; - inherit javaLibs; - propagatedBuildInputs = args.propagatedBuildInputs or [] - ++ lispLibs ++ javaLibs ++ nativeLibs; - meta = (args.meta or {}) // { - maintainers = args.meta.maintainers or lib.teams.lisp.members; - }; - }))) // { - # Useful for overriding - # Overriding code would prefer to use pname from the attribute set - # However, pname is extended with the implementation name - # Moreover, it is used in the default list of systems to load - # So we pass the original pname - pname = args.pname; - })); + ) + ) + ) + // { + # Useful for overriding + # Overriding code would prefer to use pname from the attribute set + # However, pname is extended with the implementation name + # Moreover, it is used in the default list of systems to load + # So we pass the original pname + pname = args.pname; + } + ) + ); # Build the set of lisp packages using `lisp` # These packages are defined manually for one reason or another: @@ -266,19 +315,23 @@ let # # E.g if a QL package depends on cl-unicode it won't build out of # the box. - commonLispPackagesFor = spec: + commonLispPackagesFor = + spec: let build-asdf-system' = body: build-asdf-system (body // spec); - in pkgs.callPackage ./packages.nix { + in + pkgs.callPackage ./packages.nix { inherit spec quicklispPackagesFor; build-asdf-system = build-asdf-system'; }; # Build the set of packages imported from quicklisp using `lisp` - quicklispPackagesFor = spec: + quicklispPackagesFor = + spec: let build-asdf-system' = body: build-asdf-system (body // spec); - in pkgs.callPackage ./ql.nix { + in + pkgs.callPackage ./ql.nix { build-asdf-system = build-asdf-system'; }; @@ -288,55 +341,89 @@ let # packages - as argument and returns the list of packages to be # installed # TODO(kasper): assert each package has the same lisp and asdf? - lispWithPackages = clpkgs: packages: - let first = head (lib.attrValues clpkgs); in + lispWithPackages = + clpkgs: packages: + let + first = head (lib.attrValues clpkgs); + in (build-asdf-system { - inherit (first) pkg program flags faslExt asdf; + inherit (first) + pkg + program + flags + faslExt + asdf + ; # See dontUnpack in build-asdf-system src = null; pname = "with"; version = "packages"; lispLibs = packages clpkgs; - systems = []; - }).overrideAttrs(o: { - nativeBuildInputs = [ pkgs.makeBinaryWrapper ]; - installPhase = '' - mkdir -pv $out/bin - makeWrapper \ - ${o.pkg}/bin/${o.program} \ - $out/bin/${o.program} \ - --add-flags "${toString o.flags}" \ - --set ASDF "${o.asdfFasl}/asdf.${o.faslExt}" \ - --prefix CL_SOURCE_REGISTRY : "$CL_SOURCE_REGISTRY''${CL_SOURCE_REGISTRY:+:}" \ - --prefix ASDF_OUTPUT_TRANSLATIONS : "$(echo $CL_SOURCE_REGISTRY | sed s,//:,::,g):" \ - --prefix LD_LIBRARY_PATH : "$LD_LIBRARY_PATH" \ - --prefix DYLD_LIBRARY_PATH : "$DYLD_LIBRARY_PATH" \ - --prefix CLASSPATH : "$CLASSPATH" \ - --prefix GI_TYPELIB_PATH : "$GI_TYPELIB_PATH" \ - --prefix PATH : "${makeBinPath (o.propagatedBuildInputs or [])}" - ''; - }); - - wrapLisp = { - pkg - , faslExt - , program ? pkg.meta.mainProgram or pkg.pname - , flags ? [] - , asdf ? pkgs.asdf_3_3 - , packageOverrides ? (self: super: {}) - }: + systems = [ ]; + }).overrideAttrs + (o: { + nativeBuildInputs = [ pkgs.makeBinaryWrapper ]; + installPhase = '' + mkdir -pv $out/bin + makeWrapper \ + ${o.pkg}/bin/${o.program} \ + $out/bin/${o.program} \ + --add-flags "${toString o.flags}" \ + --set ASDF "${o.asdfFasl}/asdf.${o.faslExt}" \ + --prefix CL_SOURCE_REGISTRY : "$CL_SOURCE_REGISTRY''${CL_SOURCE_REGISTRY:+:}" \ + --prefix ASDF_OUTPUT_TRANSLATIONS : "$(echo $CL_SOURCE_REGISTRY | sed s,//:,::,g):" \ + --prefix LD_LIBRARY_PATH : "$LD_LIBRARY_PATH" \ + --prefix DYLD_LIBRARY_PATH : "$DYLD_LIBRARY_PATH" \ + --prefix CLASSPATH : "$CLASSPATH" \ + --prefix GI_TYPELIB_PATH : "$GI_TYPELIB_PATH" \ + --prefix PATH : "${makeBinPath (o.propagatedBuildInputs or [ ])}" + ''; + }); + + wrapLisp = + { + pkg, + faslExt, + program ? pkg.meta.mainProgram or pkg.pname, + flags ? [ ], + asdf ? pkgs.asdf_3_3, + packageOverrides ? (self: super: { }), + }: let - spec = { inherit pkg faslExt program flags asdf; }; + spec = { + inherit + pkg + faslExt + program + flags + asdf + ; + }; pkgs = (commonLispPackagesFor spec).overrideScope packageOverrides; withPackages = lispWithPackages pkgs; - withOverrides = packageOverrides: + withOverrides = + packageOverrides: wrapLisp { - inherit pkg faslExt program flags asdf; + inherit + pkg + faslExt + program + flags + asdf + ; inherit packageOverrides; }; buildASDFSystem = args: build-asdf-system (args // spec); - in pkg // { - inherit pkgs withPackages withOverrides buildASDFSystem; + in + pkg + // { + inherit + pkgs + withPackages + withOverrides + buildASDFSystem + ; }; -in wrapLisp +in +wrapLisp diff --git a/pkgs/development/lisp-modules/shell.nix b/pkgs/development/lisp-modules/shell.nix index d59cec77fd1adf..85b79bcbff6fc7 100644 --- a/pkgs/development/lisp-modules/shell.nix +++ b/pkgs/development/lisp-modules/shell.nix @@ -1,9 +1,10 @@ let - pkgs = import ../../../. {}; -in pkgs.mkShell { + pkgs = import ../../../. { }; +in +pkgs.mkShell { nativeBuildInputs = [ - (pkgs.sbcl.withPackages - (ps: with ps; [ + (pkgs.sbcl.withPackages ( + ps: with ps; [ alexandria str dexador @@ -11,6 +12,7 @@ in pkgs.mkShell { sqlite arrow-macros jzon - ])) + ] + )) ]; } diff --git a/pkgs/development/lua-modules/aliases.nix b/pkgs/development/lua-modules/aliases.nix index efa9a1e423cd79..4d463437086758 100644 --- a/pkgs/development/lua-modules/aliases.nix +++ b/pkgs/development/lua-modules/aliases.nix @@ -1,4 +1,3 @@ - lib: self: super: ### Deprecated aliases - for backward compatibility @@ -8,34 +7,33 @@ lib: self: super: ### from the `luaPackages` set without regenerating the entire file. let - inherit (lib) dontDistribute hasAttr isDerivation mapAttrs; + inherit (lib) + dontDistribute + hasAttr + isDerivation + mapAttrs + ; # Removing recurseForDerivation prevents derivations of aliased attribute # set to appear while listing all the packages available. - removeRecurseForDerivations = alias: - if alias.recurseForDerivations or false - then removeAttrs alias ["recurseForDerivations"] - else alias; + removeRecurseForDerivations = + alias: + if alias.recurseForDerivations or false then + removeAttrs alias [ "recurseForDerivations" ] + else + alias; # Disabling distribution prevents top-level aliases for non-recursed package # sets from building on Hydra. - removeDistribute = alias: - if isDerivation alias then - dontDistribute alias - else alias; + removeDistribute = alias: if isDerivation alias then dontDistribute alias else alias; # Make sure that we are not shadowing something from node-packages.nix. - checkInPkgs = n: alias: - if hasAttr n super - then throw "Alias ${n} is still in generated.nix" - else alias; + checkInPkgs = + n: alias: if hasAttr n super then throw "Alias ${n} is still in generated.nix" else alias; - mapAliases = aliases: - mapAttrs (n: alias: - removeDistribute - (removeRecurseForDerivations - (checkInPkgs n alias))) - aliases; + mapAliases = + aliases: + mapAttrs (n: alias: removeDistribute (removeRecurseForDerivations (checkInPkgs n alias))) aliases; in mapAliases { diff --git a/pkgs/development/lua-modules/generic/default.nix b/pkgs/development/lua-modules/generic/default.nix index 7f07c6602dacd3..565852bb081211 100644 --- a/pkgs/development/lua-modules/generic/default.nix +++ b/pkgs/development/lua-modules/generic/default.nix @@ -1,27 +1,35 @@ -{ lua, writeText, toLuaModule }: +{ + lua, + writeText, + toLuaModule, +}: -{ disabled ? false -, propagatedBuildInputs ? [ ] -, makeFlags ? [ ] -, ... -} @ attrs: +{ + disabled ? false, + propagatedBuildInputs ? [ ], + makeFlags ? [ ], + ... +}@attrs: if disabled then throw "${attrs.name} not supported by interpreter lua-${lua.luaversion}" else - toLuaModule (lua.stdenv.mkDerivation ( - attrs // { - name = "lua${lua.luaversion}-" + attrs.pname + "-" + attrs.version; + toLuaModule ( + lua.stdenv.mkDerivation ( + attrs + // { + name = "lua${lua.luaversion}-" + attrs.pname + "-" + attrs.version; - makeFlags = [ - "PREFIX=$(out)" - "LUA_INC=-I${lua}/include" - "LUA_LIBDIR=$(out)/lib/lua/${lua.luaversion}" - "LUA_VERSION=${lua.luaversion}" - ] ++ makeFlags; + makeFlags = [ + "PREFIX=$(out)" + "LUA_INC=-I${lua}/include" + "LUA_LIBDIR=$(out)/lib/lua/${lua.luaversion}" + "LUA_VERSION=${lua.luaversion}" + ] ++ makeFlags; - propagatedBuildInputs = propagatedBuildInputs ++ [ - lua # propagate it for its setup-hook - ]; - } - )) + propagatedBuildInputs = propagatedBuildInputs ++ [ + lua # propagate it for its setup-hook + ]; + } + ) + ) diff --git a/pkgs/development/lua-modules/lib.nix b/pkgs/development/lua-modules/lib.nix index df5dbc5d302432..d1482153ffead1 100644 --- a/pkgs/development/lua-modules/lib.nix +++ b/pkgs/development/lua-modules/lib.nix @@ -1,21 +1,32 @@ -{ pkgs, lib, lua }: +{ + pkgs, + lib, + lua, +}: let inherit (lib.generators) toLua; - requiredLuaModules = drvs: let - modules = lib.filter hasLuaModule drvs; - in lib.unique ([lua] ++ modules ++ lib.concatLists (lib.catAttrs "requiredLuaModules" modules)); + requiredLuaModules = + drvs: + let + modules = lib.filter hasLuaModule drvs; + in + lib.unique ([ lua ] ++ modules ++ lib.concatLists (lib.catAttrs "requiredLuaModules" modules)); # Check whether a derivation provides a lua module. hasLuaModule = drv: drv ? luaModule; - - /* - Use this to override the arguments passed to buildLuarocksPackage - */ - overrideLuarocks = drv: f: (drv.override (args: args // { - buildLuarocksPackage = drv: (args.buildLuarocksPackage drv).override f; - })) // { - overrideScope = scope: overrideLuarocks (drv.overrideScope scope) f; - }; + # Use this to override the arguments passed to buildLuarocksPackage + overrideLuarocks = + drv: f: + (drv.override ( + args: + args + // { + buildLuarocksPackage = drv: (args.buildLuarocksPackage drv).override f; + } + )) + // { + overrideScope = scope: overrideLuarocks (drv.overrideScope scope) f; + }; in rec { @@ -30,18 +41,15 @@ rec { "lib/lua/${lua.luaversion}/?.so" ]; - /* generate paths without a prefix - */ + # generate paths without a prefix luaPathRelStr = lib.concatStringsSep ";" luaPathList; luaCPathRelStr = lib.concatStringsSep ";" luaCPathList; - /* generate LUA_(C)PATH value for a specific derivation, i.e., with absolute paths - */ + # generate LUA_(C)PATH value for a specific derivation, i.e., with absolute paths genLuaPathAbsStr = drv: lib.concatMapStringsSep ";" (x: "${drv}/${x}") luaPathList; genLuaCPathAbsStr = drv: lib.concatMapStringsSep ";" (x: "${drv}/${x}") luaCPathList; - /* Generate a LUA_PATH with absolute paths - */ + # Generate a LUA_PATH with absolute paths # genLuaPathAbs = drv: # lib.concatStringsSep ";" (map (x: "${drv}/x") luaPathList); @@ -52,30 +60,32 @@ rec { isLua53 = lua.luaversion == "5.3"; isLuaJIT = lib.getName lua == "luajit"; - /* generates the relative path towards the folder where - seems stable even when using lua_modules_path = "" + /* + generates the relative path towards the folder where + seems stable even when using lua_modules_path = "" - Example: - getDataFolder luaPackages.stdlib - => stdlib-41.2.2-1-rocks/stdlib/41.2.2-1/doc + Example: + getDataFolder luaPackages.stdlib + => stdlib-41.2.2-1-rocks/stdlib/41.2.2-1/doc */ - getDataFolder = drv: - "${drv.pname}-${drv.version}-rocks/${drv.pname}/${drv.version}"; + getDataFolder = drv: "${drv.pname}-${drv.version}-rocks/${drv.pname}/${drv.version}"; - /* Convert derivation to a lua module. + /* + Convert derivation to a lua module. so that luaRequireModules can be run later */ - toLuaModule = drv: - drv.overrideAttrs(oldAttrs: { + toLuaModule = + drv: + drv.overrideAttrs (oldAttrs: { # Use passthru in order to prevent rebuilds when possible. - passthru = (oldAttrs.passthru or {}) // { + passthru = (oldAttrs.passthru or { }) // { luaModule = lua; requiredLuaModules = requiredLuaModules drv.propagatedBuildInputs; }; }); - - /* generate a luarocks config conforming to: + /* + generate a luarocks config conforming to: https://github.com/luarocks/luarocks/wiki/Config-file-format The config lists folders where to find lua dependencies @@ -89,65 +99,81 @@ rec { Type: generateLuarocksConfig :: AttrSet -> String */ - generateLuarocksConfig = { - externalDeps ? [] - # a list of lua derivations - , requiredLuaRocks ? [] - , ... - }@args: let - rocksTrees = lib.imap0 - (i: dep: { - name = "dep-${toString i}"; - root = "${dep}"; - # packages built by buildLuaPackage or luarocks doesn't contain rocksSubdir - # hence a default here - rocks_dir = if dep ? rocksSubdir then "${dep}/${dep.rocksSubdir}" else "${dep.pname}-${dep.version}-rocks"; - }) - requiredLuaRocks; + generateLuarocksConfig = + { + externalDeps ? [ ], + # a list of lua derivations + requiredLuaRocks ? [ ], + ... + }@args: + let + rocksTrees = lib.imap0 (i: dep: { + name = "dep-${toString i}"; + root = "${dep}"; + # packages built by buildLuaPackage or luarocks doesn't contain rocksSubdir + # hence a default here + rocks_dir = + if dep ? rocksSubdir then "${dep}/${dep.rocksSubdir}" else "${dep.pname}-${dep.version}-rocks"; + }) requiredLuaRocks; # Explicitly point luarocks to the relevant locations for multiple-output # derivations that are external dependencies, to work around an issue it has # (https://github.com/luarocks/luarocks/issues/766) - depVariables = zipAttrsWithLast (lib.lists.map ({name, dep}: { - "${name}_INCDIR" = "${lib.getDev dep}/include"; - "${name}_LIBDIR" = "${lib.getLib dep}/lib"; - "${name}_BINDIR" = "${lib.getBin dep}/bin"; - }) externalDeps'); + depVariables = zipAttrsWithLast ( + lib.lists.map ( + { name, dep }: + { + "${name}_INCDIR" = "${lib.getDev dep}/include"; + "${name}_LIBDIR" = "${lib.getLib dep}/lib"; + "${name}_BINDIR" = "${lib.getBin dep}/bin"; + } + ) externalDeps' + ); zipAttrsWithLast = lib.attrsets.zipAttrsWith (name: lib.lists.last); # example externalDeps': [ { name = "CRYPTO"; dep = pkgs.openssl; } ] externalDeps' = lib.filter (dep: !lib.isDerivation dep) externalDeps; - externalDepsDirs = map - (x: builtins.toString x) - (lib.filter (lib.isDerivation) externalDeps); - - generatedConfig = ({ - - - # first tree is the default target where new rocks are installed, - # any other trees in the list are treated as additional sources of installed rocks for matching dependencies. - rocks_trees = ( - [{name = "current"; root = "${placeholder "out"}"; rocks_dir = "current"; }] ++ - rocksTrees - ); - } // lib.optionalAttrs lua.pkgs.isLuaJIT { - # Luajit provides some additional functionality built-in; this exposes - # that to luarock's dependency system - rocks_provided = { - jit = "${lua.luaversion}-1"; - ffi = "${lua.luaversion}-1"; - luaffi = "${lua.luaversion}-1"; - bit = "${lua.luaversion}-1"; - }; - } // { - # For single-output external dependencies - external_deps_dirs = externalDepsDirs; - # Some needed machinery to handle multiple-output external dependencies, - # as per https://github.com/luarocks/luarocks/issues/766 - variables = depVariables; - } - // removeAttrs args [ "requiredLuaRocks" "externalDeps" ] + externalDepsDirs = map (x: builtins.toString x) (lib.filter (lib.isDerivation) externalDeps); + + generatedConfig = ( + { + + # first tree is the default target where new rocks are installed, + # any other trees in the list are treated as additional sources of installed rocks for matching dependencies. + rocks_trees = ( + [ + { + name = "current"; + root = "${placeholder "out"}"; + rocks_dir = "current"; + } + ] + ++ rocksTrees + ); + } + // lib.optionalAttrs lua.pkgs.isLuaJIT { + # Luajit provides some additional functionality built-in; this exposes + # that to luarock's dependency system + rocks_provided = { + jit = "${lua.luaversion}-1"; + ffi = "${lua.luaversion}-1"; + luaffi = "${lua.luaversion}-1"; + bit = "${lua.luaversion}-1"; + }; + } + // { + # For single-output external dependencies + external_deps_dirs = externalDepsDirs; + # Some needed machinery to handle multiple-output external dependencies, + # as per https://github.com/luarocks/luarocks/issues/766 + variables = depVariables; + } + // removeAttrs args [ + "requiredLuaRocks" + "externalDeps" + ] ); - in generatedConfig; + in + generatedConfig; } diff --git a/pkgs/development/lua-modules/nfd/default.nix b/pkgs/development/lua-modules/nfd/default.nix index 66624c6f095562..1b34c1bd180313 100644 --- a/pkgs/development/lua-modules/nfd/default.nix +++ b/pkgs/development/lua-modules/nfd/default.nix @@ -1,4 +1,14 @@ -{ stdenv, fetchFromGitHub, buildLuarocksPackage, lua, pkg-config, lib, substituteAll, zenity, AppKit}: +{ + stdenv, + fetchFromGitHub, + buildLuarocksPackage, + lua, + pkg-config, + lib, + substituteAll, + zenity, + AppKit, +}: buildLuarocksPackage { pname = "nfd"; @@ -32,14 +42,12 @@ buildLuarocksPackage { doInstallCheck = true; installCheckInputs = [ lua.pkgs.busted ]; - installCheckPhase= '' + installCheckPhase = '' busted lua/spec/ - ''; - + ''; meta = { - description = - "A tiny, neat lua library that portably invokes native file open and save dialogs."; + description = "A tiny, neat lua library that portably invokes native file open and save dialogs."; homepage = "https://github.com/Alloyed/nativefiledialog/tree/master/lua"; license = lib.licenses.zlib; maintainers = [ lib.maintainers.scoder12 ]; diff --git a/pkgs/development/misc/avr/libc/default.nix b/pkgs/development/misc/avr/libc/default.nix index 10bc020a34a43d..a0e928ab2918c3 100644 --- a/pkgs/development/misc/avr/libc/default.nix +++ b/pkgs/development/misc/avr/libc/default.nix @@ -1,16 +1,25 @@ -{ lib, stdenv, fetchurl, automake, autoconf }: +{ + lib, + stdenv, + fetchurl, + automake, + autoconf, +}: stdenv.mkDerivation (finalAttrs: { pname = "avr-libc"; version = "2.2.1"; - tag_version = builtins.replaceStrings ["."] ["_"] finalAttrs.version; + tag_version = builtins.replaceStrings [ "." ] [ "_" ] finalAttrs.version; src = fetchurl { url = "https://github.com/avrdudes/avr-libc/releases/download/avr-libc-${finalAttrs.tag_version}-release/avr-libc-${finalAttrs.version}.tar.bz2"; hash = "sha256-AGpjBsu8k4w721g6xU+T/n18jPl/nN6R+RxvsCc6tGU="; }; - nativeBuildInputs = [ automake autoconf ]; + nativeBuildInputs = [ + automake + autoconf + ]; # Make sure we don't strip the libraries in lib/gcc/avr. stripDebugList = [ "bin" ]; @@ -28,6 +37,9 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://github.com/avrdudes/avr-libc/blob/avr-libc-${finalAttrs.tag_version}-release/NEWS"; license = licenses.bsd3; platforms = [ "avr-none" ]; - maintainers = with maintainers; [ mguentner emilytrau ]; + maintainers = with maintainers; [ + mguentner + emilytrau + ]; }; }) diff --git a/pkgs/development/misc/h3/default.nix b/pkgs/development/misc/h3/default.nix index d30bdbc3e637f6..4f3b2041d6661f 100644 --- a/pkgs/development/misc/h3/default.nix +++ b/pkgs/development/misc/h3/default.nix @@ -1,12 +1,14 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, withFilters ? false +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + withFilters ? false, }: let - generic = { version, hash }: + generic = + { version, hash }: stdenv.mkDerivation rec { inherit version; pname = "h3"; @@ -18,7 +20,10 @@ let inherit hash; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/development/misc/haskell/changelog-d/default.nix b/pkgs/development/misc/haskell/changelog-d/default.nix index 90903e0aae20ce..fa788feac4196a 100644 --- a/pkgs/development/misc/haskell/changelog-d/default.nix +++ b/pkgs/development/misc/haskell/changelog-d/default.nix @@ -1,7 +1,21 @@ -{ mkDerivation, base, bytestring, cabal-install-parsers -, Cabal-syntax, containers, directory, fetchFromGitea, filepath -, generic-lens-lite, lib, mtl, optparse-applicative, parsec, pretty -, regex-applicative, frontmatter +{ + mkDerivation, + base, + bytestring, + cabal-install-parsers, + Cabal-syntax, + containers, + directory, + fetchFromGitea, + filepath, + generic-lens-lite, + lib, + mtl, + optparse-applicative, + parsec, + pretty, + regex-applicative, + frontmatter, }: mkDerivation rec { pname = "changelog-d"; @@ -16,12 +30,26 @@ mkDerivation rec { isLibrary = false; isExecutable = true; libraryHaskellDepends = [ - base bytestring cabal-install-parsers Cabal-syntax containers - directory filepath generic-lens-lite mtl parsec pretty - regex-applicative frontmatter + base + bytestring + cabal-install-parsers + Cabal-syntax + containers + directory + filepath + generic-lens-lite + mtl + parsec + pretty + regex-applicative + frontmatter ]; executableHaskellDepends = [ - base bytestring Cabal-syntax directory filepath + base + bytestring + Cabal-syntax + directory + filepath optparse-applicative ]; doHaddock = false; diff --git a/pkgs/development/misc/haskell/hasura/ci-info.nix b/pkgs/development/misc/haskell/hasura/ci-info.nix index 21b78ca76b34a2..1f01a0bc9fc1c6 100644 --- a/pkgs/development/misc/haskell/hasura/ci-info.nix +++ b/pkgs/development/misc/haskell/hasura/ci-info.nix @@ -1,8 +1,18 @@ # This has been automatically generated by the script # ./update.sh. This should not be changed by hand. -{ mkDerivation, aeson, aeson-casing, base, fetchgit, hashable -, hpack, lib, template-haskell, text, th-lift-instances -, unordered-containers +{ + mkDerivation, + aeson, + aeson-casing, + base, + fetchgit, + hashable, + hpack, + lib, + template-haskell, + text, + th-lift-instances, + unordered-containers, }: mkDerivation { pname = "ci-info"; @@ -14,8 +24,14 @@ mkDerivation { fetchSubmodules = true; }; libraryHaskellDepends = [ - aeson aeson-casing base hashable template-haskell text - th-lift-instances unordered-containers + aeson + aeson-casing + base + hashable + template-haskell + text + th-lift-instances + unordered-containers ]; libraryToolDepends = [ hpack ]; prePatch = "hpack"; diff --git a/pkgs/development/misc/haskell/hasura/ekg-core.nix b/pkgs/development/misc/haskell/hasura/ekg-core.nix index 7298eb75076b42..cbdad1adf512e1 100644 --- a/pkgs/development/misc/haskell/hasura/ekg-core.nix +++ b/pkgs/development/misc/haskell/hasura/ekg-core.nix @@ -1,9 +1,26 @@ # This has been automatically generated by the script # ./update.sh. This should not be changed by hand. -{ mkDerivation, async, atomic-primops, base, containers, criterion -, fetchgit, ghc-prim, hashable, hspec, hspec-smallcheck, HUnit -, inspection-testing, lib, markdown-unlit, primitive, QuickCheck -, smallcheck, text, unordered-containers +{ + mkDerivation, + async, + atomic-primops, + base, + containers, + criterion, + fetchgit, + ghc-prim, + hashable, + hspec, + hspec-smallcheck, + HUnit, + inspection-testing, + lib, + markdown-unlit, + primitive, + QuickCheck, + smallcheck, + text, + unordered-containers, }: mkDerivation { pname = "ekg-core"; @@ -15,16 +32,39 @@ mkDerivation { fetchSubmodules = true; }; libraryHaskellDepends = [ - atomic-primops base containers ghc-prim hashable inspection-testing - primitive text unordered-containers + atomic-primops + base + containers + ghc-prim + hashable + inspection-testing + primitive + text + unordered-containers ]; testHaskellDepends = [ - async atomic-primops base containers ghc-prim hashable hspec - hspec-smallcheck HUnit inspection-testing markdown-unlit primitive - QuickCheck smallcheck text unordered-containers + async + atomic-primops + base + containers + ghc-prim + hashable + hspec + hspec-smallcheck + HUnit + inspection-testing + markdown-unlit + primitive + QuickCheck + smallcheck + text + unordered-containers ]; testToolDepends = [ markdown-unlit ]; - benchmarkHaskellDepends = [ base criterion ]; + benchmarkHaskellDepends = [ + base + criterion + ]; doHaddock = false; homepage = "https://github.com/tibbe/ekg-core"; description = "Tracking of system metrics"; diff --git a/pkgs/development/misc/haskell/hasura/ekg-json.nix b/pkgs/development/misc/haskell/hasura/ekg-json.nix index db5c7ffb0346fe..821cba0644247a 100644 --- a/pkgs/development/misc/haskell/hasura/ekg-json.nix +++ b/pkgs/development/misc/haskell/hasura/ekg-json.nix @@ -1,7 +1,16 @@ # This has been automatically generated by the script # ./update.sh. This should not be changed by hand. -{ mkDerivation, aeson, base, ekg-core, fetchgit, hspec, lib, text -, unordered-containers, vector +{ + mkDerivation, + aeson, + base, + ekg-core, + fetchgit, + hspec, + lib, + text, + unordered-containers, + vector, }: mkDerivation { pname = "ekg-json"; @@ -13,10 +22,20 @@ mkDerivation { fetchSubmodules = true; }; libraryHaskellDepends = [ - aeson base ekg-core text unordered-containers vector + aeson + base + ekg-core + text + unordered-containers + vector ]; testHaskellDepends = [ - aeson base ekg-core hspec text unordered-containers + aeson + base + ekg-core + hspec + text + unordered-containers ]; homepage = "https://github.com/tibbe/ekg-json"; description = "JSON encoding of ekg metrics"; diff --git a/pkgs/development/misc/haskell/hasura/graphql-engine.nix b/pkgs/development/misc/haskell/hasura/graphql-engine.nix index 7e44cffe8939cd..cc47535ba3bf20 100644 --- a/pkgs/development/misc/haskell/hasura/graphql-engine.nix +++ b/pkgs/development/misc/haskell/hasura/graphql-engine.nix @@ -1,36 +1,160 @@ # This has been automatically generated by the script # ./update.sh. This should not be changed by hand. -{ mkDerivation, aeson, aeson-casing, aeson-qq, ansi-wl-pprint -, asn1-encoding, asn1-types, async, attoparsec, attoparsec-iso8601 -, auto-update, base, base16-bytestring, base64-bytestring, binary -, byteorder, bytestring, case-insensitive, ci-info, conduit -, connection, containers, cron, cryptonite, data-default-class -, data-has, deepseq, dependent-map, dependent-sum, directory -, either, ekg-core, ekg-json, exceptions, fast-logger, fetchgit -, file-embed, filepath, ghc-heap-view, graphql-parser, hashable -, hashable-time, haskell-src-meta, hedgehog, hspec, hspec-core -, hspec-discover, hspec-expectations, hspec-expectations-lifted -, hspec-hedgehog, hspec-wai, hspec-wai-json, http-api-data -, http-client, http-client-tls, http-conduit, http-media -, http-types, immortal, insert-ordered-containers, jose -, kan-extensions, kriti-lang, lens, lens-aeson, lib, libyaml -, lifted-async, lifted-base, list-t, memory, mime-types, mmorph -, monad-control, monad-logger, monad-loops, monad-validate, mtl -, mustache, mysql, mysql-simple, natural-transformation, network -, network-uri, odbc, openapi3, optparse-applicative -, optparse-generic, parsec, pem, pg-client, postgresql-binary -, postgresql-libpq, postgresql-simple, pretty-simple, process -, profunctors, psqueues, QuickCheck, quickcheck-instances, random -, regex-tdfa, resource-pool, resourcet, retry, safe -, safe-exceptions, scientific, semialign, semigroups, semver -, shakespeare, some, split, Spock-core, stm, stm-containers, tagged -, template-haskell, text, text-builder, text-conversions, th-lift -, th-lift-instances, these, time, tls, tmp-postgres, transformers -, transformers-base, typed-process, unix, unliftio-core -, unordered-containers, uri-bytestring, uri-encode, url -, utf8-string, uuid, validation, vector, vector-instances, wai -, wai-extra, warp, websockets, witch, wreq, x509, x509-store -, x509-system, x509-validation, yaml, zlib +{ + mkDerivation, + aeson, + aeson-casing, + aeson-qq, + ansi-wl-pprint, + asn1-encoding, + asn1-types, + async, + attoparsec, + attoparsec-iso8601, + auto-update, + base, + base16-bytestring, + base64-bytestring, + binary, + byteorder, + bytestring, + case-insensitive, + ci-info, + conduit, + connection, + containers, + cron, + cryptonite, + data-default-class, + data-has, + deepseq, + dependent-map, + dependent-sum, + directory, + either, + ekg-core, + ekg-json, + exceptions, + fast-logger, + fetchgit, + file-embed, + filepath, + ghc-heap-view, + graphql-parser, + hashable, + hashable-time, + haskell-src-meta, + hedgehog, + hspec, + hspec-core, + hspec-discover, + hspec-expectations, + hspec-expectations-lifted, + hspec-hedgehog, + hspec-wai, + hspec-wai-json, + http-api-data, + http-client, + http-client-tls, + http-conduit, + http-media, + http-types, + immortal, + insert-ordered-containers, + jose, + kan-extensions, + kriti-lang, + lens, + lens-aeson, + lib, + libyaml, + lifted-async, + lifted-base, + list-t, + memory, + mime-types, + mmorph, + monad-control, + monad-logger, + monad-loops, + monad-validate, + mtl, + mustache, + mysql, + mysql-simple, + natural-transformation, + network, + network-uri, + odbc, + openapi3, + optparse-applicative, + optparse-generic, + parsec, + pem, + pg-client, + postgresql-binary, + postgresql-libpq, + postgresql-simple, + pretty-simple, + process, + profunctors, + psqueues, + QuickCheck, + quickcheck-instances, + random, + regex-tdfa, + resource-pool, + resourcet, + retry, + safe, + safe-exceptions, + scientific, + semialign, + semigroups, + semver, + shakespeare, + some, + split, + Spock-core, + stm, + stm-containers, + tagged, + template-haskell, + text, + text-builder, + text-conversions, + th-lift, + th-lift-instances, + these, + time, + tls, + tmp-postgres, + transformers, + transformers-base, + typed-process, + unix, + unliftio-core, + unordered-containers, + uri-bytestring, + uri-encode, + url, + utf8-string, + uuid, + validation, + vector, + vector-instances, + wai, + wai-extra, + warp, + websockets, + witch, + wreq, + x509, + x509-store, + x509-system, + x509-validation, + yaml, + zlib, }: mkDerivation { pname = "graphql-engine"; @@ -45,50 +169,228 @@ mkDerivation { isLibrary = true; isExecutable = true; libraryHaskellDepends = [ - aeson aeson-casing ansi-wl-pprint asn1-encoding asn1-types async - attoparsec attoparsec-iso8601 auto-update base base16-bytestring - base64-bytestring binary byteorder bytestring case-insensitive - ci-info connection containers cron cryptonite data-default-class - data-has deepseq dependent-map dependent-sum directory either - ekg-core ekg-json exceptions fast-logger file-embed filepath - ghc-heap-view graphql-parser hashable hashable-time http-api-data - http-client http-client-tls http-conduit http-media http-types - immortal insert-ordered-containers jose kan-extensions kriti-lang - lens lens-aeson lifted-async lifted-base list-t memory mime-types - mmorph monad-control monad-loops monad-validate mtl mustache mysql - mysql-simple network network-uri odbc openapi3 optparse-applicative - optparse-generic parsec pem pg-client postgresql-binary - postgresql-libpq pretty-simple process profunctors psqueues - QuickCheck quickcheck-instances random regex-tdfa resource-pool - retry safe-exceptions scientific semialign semigroups semver - shakespeare some split Spock-core stm stm-containers tagged - template-haskell text text-builder text-conversions these time tls - transformers transformers-base unix unordered-containers - uri-bytestring uri-encode url utf8-string uuid validation vector - vector-instances wai warp websockets witch wreq x509 x509-store - x509-system x509-validation yaml zlib + aeson + aeson-casing + ansi-wl-pprint + asn1-encoding + asn1-types + async + attoparsec + attoparsec-iso8601 + auto-update + base + base16-bytestring + base64-bytestring + binary + byteorder + bytestring + case-insensitive + ci-info + connection + containers + cron + cryptonite + data-default-class + data-has + deepseq + dependent-map + dependent-sum + directory + either + ekg-core + ekg-json + exceptions + fast-logger + file-embed + filepath + ghc-heap-view + graphql-parser + hashable + hashable-time + http-api-data + http-client + http-client-tls + http-conduit + http-media + http-types + immortal + insert-ordered-containers + jose + kan-extensions + kriti-lang + lens + lens-aeson + lifted-async + lifted-base + list-t + memory + mime-types + mmorph + monad-control + monad-loops + monad-validate + mtl + mustache + mysql + mysql-simple + network + network-uri + odbc + openapi3 + optparse-applicative + optparse-generic + parsec + pem + pg-client + postgresql-binary + postgresql-libpq + pretty-simple + process + profunctors + psqueues + QuickCheck + quickcheck-instances + random + regex-tdfa + resource-pool + retry + safe-exceptions + scientific + semialign + semigroups + semver + shakespeare + some + split + Spock-core + stm + stm-containers + tagged + template-haskell + text + text-builder + text-conversions + these + time + tls + transformers + transformers-base + unix + unordered-containers + uri-bytestring + uri-encode + url + utf8-string + uuid + validation + vector + vector-instances + wai + warp + websockets + witch + wreq + x509 + x509-store + x509-system + x509-validation + yaml + zlib ]; executableHaskellDepends = [ - base bytestring ekg-core kan-extensions pg-client text - text-conversions time unix + base + bytestring + ekg-core + kan-extensions + pg-client + text + text-conversions + time + unix ]; testHaskellDepends = [ - aeson aeson-casing aeson-qq async base bytestring case-insensitive - conduit containers cron dependent-map dependent-sum ekg-core - exceptions graphql-parser haskell-src-meta hedgehog hspec - hspec-core hspec-discover hspec-expectations - hspec-expectations-lifted hspec-hedgehog hspec-wai hspec-wai-json - http-client http-client-tls http-conduit http-types - insert-ordered-containers jose kan-extensions lens lens-aeson - libyaml lifted-base mmorph monad-control monad-logger mtl mysql - mysql-simple natural-transformation network network-uri odbc - optparse-applicative parsec pg-client postgresql-libpq - postgresql-simple process QuickCheck resource-pool resourcet safe - safe-exceptions scientific shakespeare split Spock-core stm - template-haskell text text-conversions th-lift th-lift-instances - time tmp-postgres transformers transformers-base typed-process unix - unliftio-core unordered-containers utf8-string vector wai wai-extra - warp websockets yaml + aeson + aeson-casing + aeson-qq + async + base + bytestring + case-insensitive + conduit + containers + cron + dependent-map + dependent-sum + ekg-core + exceptions + graphql-parser + haskell-src-meta + hedgehog + hspec + hspec-core + hspec-discover + hspec-expectations + hspec-expectations-lifted + hspec-hedgehog + hspec-wai + hspec-wai-json + http-client + http-client-tls + http-conduit + http-types + insert-ordered-containers + jose + kan-extensions + lens + lens-aeson + libyaml + lifted-base + mmorph + monad-control + monad-logger + mtl + mysql + mysql-simple + natural-transformation + network + network-uri + odbc + optparse-applicative + parsec + pg-client + postgresql-libpq + postgresql-simple + process + QuickCheck + resource-pool + resourcet + safe + safe-exceptions + scientific + shakespeare + split + Spock-core + stm + template-haskell + text + text-conversions + th-lift + th-lift-instances + time + tmp-postgres + transformers + transformers-base + typed-process + unix + unliftio-core + unordered-containers + utf8-string + vector + wai + wai-extra + warp + websockets + yaml ]; testToolDepends = [ hspec-discover ]; doCheck = false; diff --git a/pkgs/development/misc/haskell/hasura/graphql-parser.nix b/pkgs/development/misc/haskell/hasura/graphql-parser.nix index 1a1fb27bf2ec2d..9b3d75267378ac 100644 --- a/pkgs/development/misc/haskell/hasura/graphql-parser.nix +++ b/pkgs/development/misc/haskell/hasura/graphql-parser.nix @@ -1,9 +1,24 @@ # This has been automatically generated by the script # ./update.sh. This should not be changed by hand. -{ mkDerivation, aeson, attoparsec, base, bytestring, deepseq -, fetchgit, hashable, hedgehog, lib, prettyprinter, scientific -, tasty-bench, template-haskell, text, text-builder -, th-lift-instances, unordered-containers +{ + mkDerivation, + aeson, + attoparsec, + base, + bytestring, + deepseq, + fetchgit, + hashable, + hedgehog, + lib, + prettyprinter, + scientific, + tasty-bench, + template-haskell, + text, + text-builder, + th-lift-instances, + unordered-containers, }: mkDerivation { pname = "graphql-parser"; @@ -15,15 +30,37 @@ mkDerivation { fetchSubmodules = true; }; libraryHaskellDepends = [ - aeson attoparsec base bytestring deepseq hashable hedgehog - prettyprinter scientific template-haskell text text-builder - th-lift-instances unordered-containers + aeson + attoparsec + base + bytestring + deepseq + hashable + hedgehog + prettyprinter + scientific + template-haskell + text + text-builder + th-lift-instances + unordered-containers ]; testHaskellDepends = [ - attoparsec base bytestring hedgehog prettyprinter text text-builder + attoparsec + base + bytestring + hedgehog + prettyprinter + text + text-builder ]; benchmarkHaskellDepends = [ - base bytestring prettyprinter tasty-bench text text-builder + base + bytestring + prettyprinter + tasty-bench + text + text-builder ]; homepage = "https://github.com/hasura/graphql-parser-hs"; description = "Native Haskell GraphQL parser"; diff --git a/pkgs/development/misc/haskell/hasura/kriti-lang.nix b/pkgs/development/misc/haskell/hasura/kriti-lang.nix index 17362f05dd0d78..f2f993723c645c 100644 --- a/pkgs/development/misc/haskell/hasura/kriti-lang.nix +++ b/pkgs/development/misc/haskell/hasura/kriti-lang.nix @@ -1,12 +1,41 @@ # This has been automatically generated by the script # ./update.sh. This should not be changed by hand. -{ mkDerivation, aeson, aeson-pretty, alex, array, base, bytestring -, containers, directory, fetchgit, filepath, generic-arbitrary -, happy, hspec, hspec-core, hspec-golden, lens, lens-aeson, lib -, megaparsec, mtl, network-uri, optparse-applicative, parsec -, parser-combinators, pretty-simple, prettyprinter, QuickCheck -, raw-strings-qq, safe-exceptions, scientific, text -, unordered-containers, utf8-string, vector +{ + mkDerivation, + aeson, + aeson-pretty, + alex, + array, + base, + bytestring, + containers, + directory, + fetchgit, + filepath, + generic-arbitrary, + happy, + hspec, + hspec-core, + hspec-golden, + lens, + lens-aeson, + lib, + megaparsec, + mtl, + network-uri, + optparse-applicative, + parsec, + parser-combinators, + pretty-simple, + prettyprinter, + QuickCheck, + raw-strings-qq, + safe-exceptions, + scientific, + text, + unordered-containers, + utf8-string, + vector, }: mkDerivation { pname = "kriti-lang"; @@ -20,21 +49,66 @@ mkDerivation { isLibrary = true; isExecutable = true; libraryHaskellDepends = [ - aeson array base bytestring containers lens megaparsec mtl - network-uri optparse-applicative parser-combinators prettyprinter - scientific text unordered-containers utf8-string vector + aeson + array + base + bytestring + containers + lens + megaparsec + mtl + network-uri + optparse-applicative + parser-combinators + prettyprinter + scientific + text + unordered-containers + utf8-string + vector + ]; + libraryToolDepends = [ + alex + happy ]; - libraryToolDepends = [ alex happy ]; executableHaskellDepends = [ - aeson base bytestring containers mtl optparse-applicative - prettyprinter text utf8-string + aeson + base + bytestring + containers + mtl + optparse-applicative + prettyprinter + text + utf8-string ]; testHaskellDepends = [ - aeson aeson-pretty base bytestring containers directory filepath - generic-arbitrary hspec hspec-core hspec-golden lens lens-aeson mtl - optparse-applicative parsec pretty-simple prettyprinter QuickCheck - raw-strings-qq safe-exceptions scientific text unordered-containers - utf8-string vector + aeson + aeson-pretty + base + bytestring + containers + directory + filepath + generic-arbitrary + hspec + hspec-core + hspec-golden + lens + lens-aeson + mtl + optparse-applicative + parsec + pretty-simple + prettyprinter + QuickCheck + raw-strings-qq + safe-exceptions + scientific + text + unordered-containers + utf8-string + vector ]; license = lib.licenses.asl20; maintainers = with lib.maintainers; [ lassulus ]; diff --git a/pkgs/development/misc/haskell/hasura/pg-client.nix b/pkgs/development/misc/haskell/hasura/pg-client.nix index 1c79a70271daa7..d906de3bdbb285 100644 --- a/pkgs/development/misc/haskell/hasura/pg-client.nix +++ b/pkgs/development/misc/haskell/hasura/pg-client.nix @@ -1,12 +1,40 @@ # This has been automatically generated by the script # ./update.sh. This should not be changed by hand. -{ mkDerivation, aeson, aeson-casing, async, attoparsec, base -, bytestring, ekg-core, fetchgit, file-embed, hashable, hashtables -, hasql, hasql-pool, hasql-transaction, hspec, lib, mmorph -, monad-control, mtl, postgresql-binary, postgresql-libpq -, resource-pool, retry, safe-exceptions, scientific, tasty-bench -, template-haskell, text, text-builder, time, transformers-base -, uuid, vector +{ + mkDerivation, + aeson, + aeson-casing, + async, + attoparsec, + base, + bytestring, + ekg-core, + fetchgit, + file-embed, + hashable, + hashtables, + hasql, + hasql-pool, + hasql-transaction, + hspec, + lib, + mmorph, + monad-control, + mtl, + postgresql-binary, + postgresql-libpq, + resource-pool, + retry, + safe-exceptions, + scientific, + tasty-bench, + template-haskell, + text, + text-builder, + time, + transformers-base, + uuid, + vector, }: mkDerivation { pname = "pg-client"; @@ -18,18 +46,51 @@ mkDerivation { fetchSubmodules = true; }; libraryHaskellDepends = [ - aeson aeson-casing async attoparsec base bytestring ekg-core - hashable hashtables mmorph monad-control mtl postgresql-binary - postgresql-libpq resource-pool retry safe-exceptions scientific - template-haskell text text-builder time transformers-base uuid + aeson + aeson-casing + async + attoparsec + base + bytestring + ekg-core + hashable + hashtables + mmorph + monad-control + mtl + postgresql-binary + postgresql-libpq + resource-pool + retry + safe-exceptions + scientific + template-haskell + text + text-builder + time + transformers-base + uuid vector ]; testHaskellDepends = [ - async base bytestring hspec mtl safe-exceptions time + async + base + bytestring + hspec + mtl + safe-exceptions + time ]; benchmarkHaskellDepends = [ - base bytestring file-embed hasql hasql-pool hasql-transaction mtl - tasty-bench text + base + bytestring + file-embed + hasql + hasql-pool + hasql-transaction + mtl + tasty-bench + text ]; homepage = "https://github.com/hasura/platform"; license = lib.licenses.asl20; diff --git a/pkgs/development/misc/haskell/hasura/pool.nix b/pkgs/development/misc/haskell/hasura/pool.nix index e2780e2cadec4a..8064ace3ab1763 100644 --- a/pkgs/development/misc/haskell/hasura/pool.nix +++ b/pkgs/development/misc/haskell/hasura/pool.nix @@ -1,7 +1,18 @@ # This has been automatically generated by the script # ./update.sh. This should not be changed by hand. -{ mkDerivation, base, fetchgit, hashable, hspec, lib, monad-control -, stm, time, transformers, transformers-base, vector +{ + mkDerivation, + base, + fetchgit, + hashable, + hspec, + lib, + monad-control, + stm, + time, + transformers, + transformers-base, + vector, }: mkDerivation { pname = "resource-pool"; @@ -13,10 +24,19 @@ mkDerivation { fetchSubmodules = true; }; libraryHaskellDepends = [ - base hashable monad-control stm time transformers transformers-base + base + hashable + monad-control + stm + time + transformers + transformers-base vector ]; - testHaskellDepends = [ base hspec ]; + testHaskellDepends = [ + base + hspec + ]; homepage = "https://github.com/bos/pool"; description = "High-performance striped resource pooling implementation"; license = lib.licenses.bsd3; diff --git a/pkgs/development/misc/haskell/hercules-ci-optparse-applicative.nix b/pkgs/development/misc/haskell/hercules-ci-optparse-applicative.nix index 7b7e64f7650bb4..83fab0673a2412 100644 --- a/pkgs/development/misc/haskell/hercules-ci-optparse-applicative.nix +++ b/pkgs/development/misc/haskell/hercules-ci-optparse-applicative.nix @@ -1,6 +1,15 @@ -{ mkDerivation, base, fetchFromGitHub, lib, prettyprinter -, prettyprinter-ansi-terminal, process, QuickCheck, text -, transformers, transformers-compat +{ + mkDerivation, + base, + fetchFromGitHub, + lib, + prettyprinter, + prettyprinter-ansi-terminal, + process, + QuickCheck, + text, + transformers, + transformers-compat, }: mkDerivation { pname = "hercules-ci-optparse-applicative"; @@ -12,10 +21,18 @@ mkDerivation { rev = "a123939663ba1cd0f1750343f1c6b9864ac21207"; }; libraryHaskellDepends = [ - base prettyprinter prettyprinter-ansi-terminal process text - transformers transformers-compat + base + prettyprinter + prettyprinter-ansi-terminal + process + text + transformers + transformers-compat + ]; + testHaskellDepends = [ + base + QuickCheck ]; - testHaskellDepends = [ base QuickCheck ]; homepage = "https://github.com/hercules-ci/optparse-applicative"; description = "Utilities and combinators for parsing command line options (fork)"; license = lib.licenses.bsd3; diff --git a/pkgs/development/misc/msp430/gcc-support.nix b/pkgs/development/misc/msp430/gcc-support.nix index fa143173c70c01..1d682d2f8c0567 100644 --- a/pkgs/development/misc/msp430/gcc-support.nix +++ b/pkgs/development/misc/msp430/gcc-support.nix @@ -1,8 +1,13 @@ -{ lib, stdenvNoCC, fetchzip }: +{ + lib, + stdenvNoCC, + fetchzip, +}: let mspgccVersion = "6_1_1_0"; -in stdenvNoCC.mkDerivation rec { +in +stdenvNoCC.mkDerivation rec { pname = "msp430-gcc-support-files"; version = "1.207"; src = fetchzip { diff --git a/pkgs/development/misc/msp430/mspdebug.nix b/pkgs/development/misc/msp430/mspdebug.nix index c24ca3b0c2622e..94df290fec087e 100644 --- a/pkgs/development/misc/msp430/mspdebug.nix +++ b/pkgs/development/misc/msp430/mspdebug.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, autoPatchelfHook -, libusb-compat-0_1 -, readline ? null -, enableReadline ? true -, hidapi ? null -, pkg-config ? null -, mspds ? null -, enableMspds ? false +{ + lib, + stdenv, + fetchFromGitHub, + autoPatchelfHook, + libusb-compat-0_1, + readline ? null, + enableReadline ? true, + hidapi ? null, + pkg-config ? null, + mspds ? null, + enableMspds ? false, }: assert stdenv.hostPlatform.isDarwin -> hidapi != null && pkg-config != null; @@ -25,11 +27,13 @@ stdenv.mkDerivation rec { }; enableParallelBuilding = true; - nativeBuildInputs = lib.optional stdenv.hostPlatform.isDarwin pkg-config - ++ lib.optional (enableMspds && stdenv.hostPlatform.isLinux) autoPatchelfHook; - buildInputs = [ libusb-compat-0_1 ] - ++ lib.optional stdenv.hostPlatform.isDarwin hidapi - ++ lib.optional enableReadline readline; + nativeBuildInputs = + lib.optional stdenv.hostPlatform.isDarwin pkg-config + ++ lib.optional (enableMspds && stdenv.hostPlatform.isLinux) autoPatchelfHook; + buildInputs = + [ libusb-compat-0_1 ] + ++ lib.optional stdenv.hostPlatform.isDarwin hidapi + ++ lib.optional enableReadline readline; postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' # TODO: remove once a new 0.26+ release is made @@ -48,9 +52,11 @@ stdenv.mkDerivation rec { done ''; - installFlags = [ "PREFIX=$(out)" "INSTALL=install" ]; - makeFlags = [ "UNAME_S=$(unameS)" ] ++ - lib.optional (!enableReadline) "WITHOUT_READLINE=1"; + installFlags = [ + "PREFIX=$(out)" + "INSTALL=install" + ]; + makeFlags = [ "UNAME_S=$(unameS)" ] ++ lib.optional (!enableReadline) "WITHOUT_READLINE=1"; unameS = lib.optionalString stdenv.hostPlatform.isDarwin "Darwin"; meta = with lib; { diff --git a/pkgs/development/misc/msp430/mspds/binary.nix b/pkgs/development/misc/msp430/mspds/binary.nix index 4dc3ec869bda7e..a25f3fb301603f 100644 --- a/pkgs/development/misc/msp430/mspds/binary.nix +++ b/pkgs/development/misc/msp430/mspds/binary.nix @@ -1,8 +1,17 @@ -{ stdenv, lib, fetchurl, unzip, autoPatchelfHook }: +{ + stdenv, + lib, + fetchurl, + unzip, + autoPatchelfHook, +}: let - archPostfix = lib.optionalString (stdenv.hostPlatform.is64bit && !stdenv.hostPlatform.isDarwin) "_64"; -in stdenv.mkDerivation rec { + archPostfix = lib.optionalString ( + stdenv.hostPlatform.is64bit && !stdenv.hostPlatform.isDarwin + ) "_64"; +in +stdenv.mkDerivation rec { pname = "msp-debug-stack-bin"; version = "3.15.1.1"; src = fetchurl { @@ -12,11 +21,12 @@ in stdenv.mkDerivation rec { sourceRoot = "."; libname = - if stdenv.hostPlatform.isWindows then "MSP430${archPostfix}.dll" - else "libmsp430${archPostfix}${stdenv.hostPlatform.extensions.sharedLibrary}"; + if stdenv.hostPlatform.isWindows then + "MSP430${archPostfix}.dll" + else + "libmsp430${archPostfix}${stdenv.hostPlatform.extensions.sharedLibrary}"; - nativeBuildInputs = [ unzip ] - ++ lib.optional stdenv.hostPlatform.isLinux autoPatchelfHook; + nativeBuildInputs = [ unzip ] ++ lib.optional stdenv.hostPlatform.isLinux autoPatchelfHook; buildInputs = [ stdenv.cc.cc ]; installPhase = '' diff --git a/pkgs/development/misc/msp430/mspds/default.nix b/pkgs/development/misc/msp430/mspds/default.nix index 17ee5cd76c50ac..d1fb0339ce33c2 100644 --- a/pkgs/development/misc/msp430/mspds/default.nix +++ b/pkgs/development/misc/msp430/mspds/default.nix @@ -1,9 +1,12 @@ -{ stdenv -, lib -, fetchurl, unzip -, boost, pugixml -, hidapi -, libusb1 ? null +{ + stdenv, + lib, + fetchurl, + unzip, + boost, + pugixml, + hidapi, + libusb1 ? null, }: assert stdenv.hostPlatform.isLinux -> libusb1 != null; @@ -11,7 +14,8 @@ assert stdenv.hostPlatform.isLinux -> libusb1 != null; let hidapiDriver = lib.optionalString stdenv.hostPlatform.isLinux "-libusb"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "msp-debug-stack"; version = "3.15.1.1"; @@ -23,18 +27,26 @@ in stdenv.mkDerivation { enableParallelBuilding = true; libName = "libmsp430${stdenv.hostPlatform.extensions.sharedLibrary}"; - makeFlags = [ "OUTPUT=$(libName)" "HIDOBJ=" ]; - NIX_LDFLAGS = [ "-lpugixml" "-lhidapi${hidapiDriver}" ]; + makeFlags = [ + "OUTPUT=$(libName)" + "HIDOBJ=" + ]; + NIX_LDFLAGS = [ + "-lpugixml" + "-lhidapi${hidapiDriver}" + ]; env.NIX_CFLAGS_COMPILE = toString [ "-I${hidapi}/include/hidapi" ]; patches = [ ./bsl430.patch ]; - preBuild = '' - rm ThirdParty/src/pugixml.cpp - rm ThirdParty/include/pugi{config,xml}.hpp - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - makeFlagsArray+=(OUTNAME="-install_name ") - ''; + preBuild = + '' + rm ThirdParty/src/pugixml.cpp + rm ThirdParty/include/pugi{config,xml}.hpp + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + makeFlagsArray+=(OUTNAME="-install_name ") + ''; installPhase = '' install -Dm0755 -t $out/lib $libName @@ -42,8 +54,11 @@ in stdenv.mkDerivation { ''; nativeBuildInputs = [ unzip ]; - buildInputs = [ boost hidapi pugixml ] - ++ lib.optional stdenv.hostPlatform.isLinux libusb1; + buildInputs = [ + boost + hidapi + pugixml + ] ++ lib.optional stdenv.hostPlatform.isLinux libusb1; meta = with lib; { description = "TI MSP430 FET debug driver"; diff --git a/pkgs/development/misc/msp430/newlib.nix b/pkgs/development/misc/msp430/newlib.nix index 005d8f8cbd9f82..323c26c8d3a73a 100644 --- a/pkgs/development/misc/msp430/newlib.nix +++ b/pkgs/development/misc/msp430/newlib.nix @@ -1,4 +1,9 @@ -{ stdenvNoCC, xorg, newlib, msp430GccSupport }: +{ + stdenvNoCC, + xorg, + newlib, + msp430GccSupport, +}: stdenvNoCC.mkDerivation { name = "msp430-${newlib.name}"; diff --git a/pkgs/development/misc/newlib/default.nix b/pkgs/development/misc/newlib/default.nix index 644017a886da59..ee34f56ebb5cae 100644 --- a/pkgs/development/misc/newlib/default.nix +++ b/pkgs/development/misc/newlib/default.nix @@ -1,8 +1,14 @@ -{ stdenv, fetchurl, buildPackages, lib, fetchpatch, texinfo -, # "newlib-nano" is what the official ARM embedded toolchain calls this build +{ + stdenv, + fetchurl, + buildPackages, + lib, + fetchpatch, + texinfo, + # "newlib-nano" is what the official ARM embedded toolchain calls this build # configuration that prioritizes low space usage. We include it as a preset # for embedded projects striving for a similar configuration. - nanoizeNewlib ? false + nanoizeNewlib ? false, }: stdenv.mkDerivation (finalAttrs: { @@ -29,81 +35,94 @@ stdenv.mkDerivation (finalAttrs: { ]; # newlib expects CC to build for build platform, not host platform - preConfigure = '' - export CC=cc - '' + - # newlib tries to disable itself when building for Linux *except* - # when native-compiling. Unfortunately the check for "is cross - # compiling" was written when newlib was part of GCC and newlib - # was built along with GCC (therefore newlib was built to execute - # on the targetPlatform, not the hostPlatform). Unfortunately - # when newlib was extracted from GCC, this "is cross compiling" - # logic was not fixed. So we must disable it. - '' - substituteInPlace configure --replace 'noconfigdirs target-newlib target-libgloss' 'noconfigdirs' - substituteInPlace configure --replace 'cross_only="target-libgloss target-newlib' 'cross_only="' - ''; + preConfigure = + '' + export CC=cc + '' + + + # newlib tries to disable itself when building for Linux *except* + # when native-compiling. Unfortunately the check for "is cross + # compiling" was written when newlib was part of GCC and newlib + # was built along with GCC (therefore newlib was built to execute + # on the targetPlatform, not the hostPlatform). Unfortunately + # when newlib was extracted from GCC, this "is cross compiling" + # logic was not fixed. So we must disable it. + '' + substituteInPlace configure --replace 'noconfigdirs target-newlib target-libgloss' 'noconfigdirs' + substituteInPlace configure --replace 'cross_only="target-libgloss target-newlib' 'cross_only="' + ''; - - configurePlatforms = [ "build" "target" ]; + configurePlatforms = [ + "build" + "target" + ]; # flags copied from https://community.arm.com/support-forums/f/compilers-and-libraries-forum/53310/gcc-arm-none-eabi-what-were-the-newlib-compilation-options # sort alphabetically - configureFlags = [ - "--with-newlib" + configureFlags = + [ + "--with-newlib" - # The newlib configury uses `host` to refer to the platform - # which is being used to compile newlib. Ugh. It does this - # because of its history: newlib used to be distributed with and - # built as part of gcc. - # - # To prevent nixpkgs from going insane, this package presents the - # "normal" view to the outside world: the binaries in $out will - # execute on `stdenv.hostPlatform`. We then fool newlib's build - # process into doing the right thing. - "--host=${stdenv.targetPlatform.config}" + # The newlib configury uses `host` to refer to the platform + # which is being used to compile newlib. Ugh. It does this + # because of its history: newlib used to be distributed with and + # built as part of gcc. + # + # To prevent nixpkgs from going insane, this package presents the + # "normal" view to the outside world: the binaries in $out will + # execute on `stdenv.hostPlatform`. We then fool newlib's build + # process into doing the right thing. + "--host=${stdenv.targetPlatform.config}" - ] ++ (if !nanoizeNewlib then [ - "--disable-newlib-supplied-syscalls" - "--disable-nls" - "--enable-newlib-io-c99-formats" - "--enable-newlib-io-long-long" - "--enable-newlib-reent-check-verify" - "--enable-newlib-register-fini" - "--enable-newlib-retargetable-locking" - ] else [ - "--disable-newlib-fseek-optimization" - "--disable-newlib-fvwrite-in-streamio" - "--disable-newlib-supplied-syscalls" - "--disable-newlib-unbuf-stream-opt" - "--disable-newlib-wide-orient" - "--disable-nls" - "--enable-lite-exit" - "--enable-newlib-global-atexit" - "--enable-newlib-nano-formatted-io" - "--enable-newlib-nano-malloc" - "--enable-newlib-reent-check-verify" - "--enable-newlib-reent-small" - "--enable-newlib-retargetable-locking" - ]); + ] + ++ ( + if !nanoizeNewlib then + [ + "--disable-newlib-supplied-syscalls" + "--disable-nls" + "--enable-newlib-io-c99-formats" + "--enable-newlib-io-long-long" + "--enable-newlib-reent-check-verify" + "--enable-newlib-register-fini" + "--enable-newlib-retargetable-locking" + ] + else + [ + "--disable-newlib-fseek-optimization" + "--disable-newlib-fvwrite-in-streamio" + "--disable-newlib-supplied-syscalls" + "--disable-newlib-unbuf-stream-opt" + "--disable-newlib-wide-orient" + "--disable-nls" + "--enable-lite-exit" + "--enable-newlib-global-atexit" + "--enable-newlib-nano-formatted-io" + "--enable-newlib-nano-malloc" + "--enable-newlib-reent-check-verify" + "--enable-newlib-reent-small" + "--enable-newlib-retargetable-locking" + ] + ); enableParallelBuilding = true; dontDisableStatic = true; # apply necessary nano changes from https://developer.arm.com/-/media/Files/downloads/gnu/12.2.rel1/manifest/copy_nano_libraries.sh?rev=4c50be6ccb9c4205a5262a3925317073&hash=1375A7B0A1CD0DB9B9EB0D2B574ADF66 - postInstall = lib.optionalString nanoizeNewlib '' - mkdir -p $out${finalAttrs.passthru.incdir}/newlib-nano - cp $out${finalAttrs.passthru.incdir}/newlib.h $out${finalAttrs.passthru.incdir}/newlib-nano/ + postInstall = + lib.optionalString nanoizeNewlib '' + mkdir -p $out${finalAttrs.passthru.incdir}/newlib-nano + cp $out${finalAttrs.passthru.incdir}/newlib.h $out${finalAttrs.passthru.incdir}/newlib-nano/ - ( - cd $out${finalAttrs.passthru.libdir} + ( + cd $out${finalAttrs.passthru.libdir} - for f in librdimon.a libc.a libg.a; do - # Some libraries are only available for specific architectures. - # For example, librdimon.a is only available on ARM. - [ -f "$f" ] && cp "$f" "''${f%%\.a}_nano.a" - done - ) - '' + ''[ "$(find $out -type f | wc -l)" -gt 0 ] || (echo '$out is empty' 1>&2 && exit 1)''; + for f in librdimon.a libc.a libg.a; do + # Some libraries are only available for specific architectures. + # For example, librdimon.a is only available on ARM. + [ -f "$f" ] && cp "$f" "''${f%%\.a}_nano.a" + done + ) + '' + + ''[ "$(find $out -type f | wc -l)" -gt 0 ] || (echo '$out is empty' 1>&2 && exit 1)''; passthru = { incdir = "/${stdenv.targetPlatform.config}/include"; diff --git a/pkgs/development/misc/or1k/newlib.nix b/pkgs/development/misc/or1k/newlib.nix index 7c0f0af4a21a62..fb265b726f40d2 100644 --- a/pkgs/development/misc/or1k/newlib.nix +++ b/pkgs/development/misc/or1k/newlib.nix @@ -1,4 +1,9 @@ -{ stdenv, fetchFromGitHub, stdenvNoLibc, buildPackages }: +{ + stdenv, + fetchFromGitHub, + stdenvNoLibc, + buildPackages, +}: stdenvNoLibc.mkDerivation { name = "newlib"; @@ -16,7 +21,10 @@ stdenvNoLibc.mkDerivation { export CC=cc ''; - configurePlatforms = [ "build" "target" ]; + configurePlatforms = [ + "build" + "target" + ]; configureFlags = [ "--host=${stdenv.buildPlatform.config}" diff --git a/pkgs/development/misc/resholve/default.nix b/pkgs/development/misc/resholve/default.nix index 5b68631e344de4..b995561a9c8761 100644 --- a/pkgs/development/misc/resholve/default.nix +++ b/pkgs/development/misc/resholve/default.nix @@ -1,17 +1,24 @@ -{ lib -, pkgsBuildHost -, ... +{ + lib, + pkgsBuildHost, + ... }: let - removeKnownVulnerabilities = pkg: pkg.overrideAttrs (old: { - meta = (old.meta or { }) // { knownVulnerabilities = [ ]; }; - }); + removeKnownVulnerabilities = + pkg: + pkg.overrideAttrs (old: { + meta = (old.meta or { }) // { + knownVulnerabilities = [ ]; + }; + }); # We are removing `meta.knownVulnerabilities` from `python27`, # and setting it in `resholve` itself. python27' = (removeKnownVulnerabilities pkgsBuildHost.python27).override { self = python27'; - pkgsBuildHost = pkgsBuildHost // { python27 = python27'; }; + pkgsBuildHost = pkgsBuildHost // { + python27 = python27'; + }; # strip down that python version as much as possible openssl = null; bzip2 = null; @@ -35,14 +42,16 @@ rec { # not exposed in all-packages resholveBuildTimeOnly = removeKnownVulnerabilities resholve; # resholve itself - resholve = (callPackage ./resholve.nix { - inherit (source) rSrc version; - inherit (deps.oil) oildev; - inherit (deps) configargparse; - inherit resholve-utils; - # used only in tests - resholve = resholveBuildTimeOnly; - }); + resholve = ( + callPackage ./resholve.nix { + inherit (source) rSrc version; + inherit (deps.oil) oildev; + inherit (deps) configargparse; + inherit resholve-utils; + # used only in tests + resholve = resholveBuildTimeOnly; + } + ); # funcs to validate and phrase invocations of resholve # and use those invocations to build packages resholve-utils = callPackage ./resholve-utils.nix { diff --git a/pkgs/development/misc/resholve/deps.nix b/pkgs/development/misc/resholve/deps.nix index 5b4133465fa74d..577a6ed1bb90f6 100644 --- a/pkgs/development/misc/resholve/deps.nix +++ b/pkgs/development/misc/resholve/deps.nix @@ -1,9 +1,10 @@ -{ lib -, callPackage -, fetchFromGitHub -, python27 -, fetchPypi -, ... +{ + lib, + callPackage, + fetchFromGitHub, + python27, + fetchPypi, + ... }: /* diff --git a/pkgs/development/misc/resholve/oildev.nix b/pkgs/development/misc/resholve/oildev.nix index c770fb894a3b0e..ff8385fbcd5440 100644 --- a/pkgs/development/misc/resholve/oildev.nix +++ b/pkgs/development/misc/resholve/oildev.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, python27 -, callPackage -, fetchFromGitHub -, makeWrapper -, re2c -, # oil deps - glibcLocales -, file -, six -, typing +{ + lib, + stdenv, + python27, + callPackage, + fetchFromGitHub, + makeWrapper, + re2c, + # oil deps + glibcLocales, + file, + six, + typing, }: rec { @@ -67,9 +68,16 @@ rec { "--without-readline" ]; - nativeBuildInputs = [ re2c file makeWrapper ]; + nativeBuildInputs = [ + re2c + file + makeWrapper + ]; - propagatedBuildInputs = [ six typing ]; + propagatedBuildInputs = [ + six + typing + ]; doCheck = true; @@ -85,7 +93,9 @@ rec { ''; # See earlier note on glibcLocales TODO: verify needed? - LOCALE_ARCHIVE = lib.optionalString (stdenv.buildPlatform.libc == "glibc") "${glibcLocales}/lib/locale/locale-archive"; + LOCALE_ARCHIVE = lib.optionalString ( + stdenv.buildPlatform.libc == "glibc" + ) "${glibcLocales}/lib/locale/locale-archive"; # not exhaustive; sample what resholve uses as a sanity check pythonImportsCheck = [ diff --git a/pkgs/development/misc/resholve/resholve-utils.nix b/pkgs/development/misc/resholve/resholve-utils.nix index a903b674eb3399..f024d04e0c2c7c 100644 --- a/pkgs/development/misc/resholve/resholve-utils.nix +++ b/pkgs/development/misc/resholve/resholve-utils.nix @@ -1,7 +1,14 @@ -{ lib, stdenv, resholve, binlore, writeTextFile }: +{ + lib, + stdenv, + resholve, + binlore, + writeTextFile, +}: rec { - /* These functions break up the work of partially validating the + /* + These functions break up the work of partially validating the 'solutions' attrset and massaging it into env/cli args. Note: some of the left-most args do not *have* to be passed as @@ -13,84 +20,128 @@ rec { colons = l: builtins.concatStringsSep ":" l; semicolons = l: builtins.concatStringsSep ";" l; - /* Throw a fit with dotted attr path context */ - nope = path: msg: - throw "${builtins.concatStringsSep "." path}: ${msg}"; - - /* Special-case directive value representations by type */ - phraseDirective = solution: env: name: val: - if builtins.isInt val then builtins.toString val - else if builtins.isString val then name - else if true == val then name - else if false == val then "" # omit! - else if null == val then "" # omit! - else if builtins.isList val then "${name}:${semicolons (map lib.escapeShellArg val)}" - else nope [ solution env name ] "unexpected type: ${builtins.typeOf val}"; - - /* Build fake/fix/keep directives from Nix types */ - phraseDirectives = solution: env: val: + # Throw a fit with dotted attr path context + nope = path: msg: throw "${builtins.concatStringsSep "." path}: ${msg}"; + + # Special-case directive value representations by type + phraseDirective = + solution: env: name: val: + if builtins.isInt val then + builtins.toString val + else if builtins.isString val then + name + else if true == val then + name + else if false == val then + "" # omit! + else if null == val then + "" # omit! + else if builtins.isList val then + "${name}:${semicolons (map lib.escapeShellArg val)}" + else + nope [ solution env name ] "unexpected type: ${builtins.typeOf val}"; + + # Build fake/fix/keep directives from Nix types + phraseDirectives = + solution: env: val: lib.mapAttrsToList (phraseDirective solution env) val; - /* Custom ~search-path routine to handle relative path strings */ - relSafeBinPath = input: - if lib.isDerivation input then ((lib.getOutput "bin" input) + "/bin") - else if builtins.isString input then input - else throw "unexpected type for input: ${builtins.typeOf input}"; - - /* Special-case value representation by type/name */ - phraseEnvVal = solution: env: val: - if env == "inputs" then (colons (map relSafeBinPath val)) - else if builtins.isString val then val - else if builtins.isList val then spaces val - else if builtins.isAttrs val then spaces (phraseDirectives solution env val) - else nope [ solution env ] "unexpected type: ${builtins.typeOf val}"; - - /* Shell-format each env value */ - shellEnv = solution: env: value: + # Custom ~search-path routine to handle relative path strings + relSafeBinPath = + input: + if lib.isDerivation input then + ((lib.getOutput "bin" input) + "/bin") + else if builtins.isString input then + input + else + throw "unexpected type for input: ${builtins.typeOf input}"; + + # Special-case value representation by type/name + phraseEnvVal = + solution: env: val: + if env == "inputs" then + (colons (map relSafeBinPath val)) + else if builtins.isString val then + val + else if builtins.isList val then + spaces val + else if builtins.isAttrs val then + spaces (phraseDirectives solution env val) + else + nope [ solution env ] "unexpected type: ${builtins.typeOf val}"; + + # Shell-format each env value + shellEnv = + solution: env: value: lib.escapeShellArg (phraseEnvVal solution env value); - /* Build a single ENV=val pair */ - phraseEnv = solution: env: value: + # Build a single ENV=val pair + phraseEnv = + solution: env: value: "RESHOLVE_${lib.toUpper env}=${shellEnv solution env value}"; - /* Discard attrs: - - claimed by phraseArgs - - only needed for binlore.collect + /* + Discard attrs: + - claimed by phraseArgs + - only needed for binlore.collect */ - removeUnneededArgs = value: - removeAttrs value [ "scripts" "flags" "unresholved" ]; + removeUnneededArgs = + value: + removeAttrs value [ + "scripts" + "flags" + "unresholved" + ]; - /* Verify required arguments are present */ - validateSolution = { scripts, inputs, interpreter, ... }: true; + # Verify required arguments are present + validateSolution = + { + scripts, + inputs, + interpreter, + ... + }: + true; - /* Pull out specific solution keys to build ENV=val pairs */ - phraseEnvs = solution: value: - spaces (lib.mapAttrsToList (phraseEnv solution) (removeUnneededArgs value)); + # Pull out specific solution keys to build ENV=val pairs + phraseEnvs = + solution: value: spaces (lib.mapAttrsToList (phraseEnv solution) (removeUnneededArgs value)); - /* Pull out specific solution keys to build CLI argstring */ - phraseArgs = { flags ? [ ], scripts, ... }: + # Pull out specific solution keys to build CLI argstring + phraseArgs = + { + flags ? [ ], + scripts, + ... + }: spaces (flags ++ scripts); - phraseBinloreArgs = value: + phraseBinloreArgs = + value: let hasUnresholved = builtins.hasAttr "unresholved" value; - in { - drvs = value.inputs ++ - lib.optionals hasUnresholved [ value.unresholved ]; + in + { + drvs = value.inputs ++ lib.optionals hasUnresholved [ value.unresholved ]; strip = if hasUnresholved then [ value.unresholved ] else [ ]; }; - /* Build a single resholve invocation */ - phraseInvocation = solution: value: + # Build a single resholve invocation + phraseInvocation = + solution: value: if validateSolution value then - # we pass resholve a directory - "RESHOLVE_LORE=${binlore.collect (phraseBinloreArgs value) } ${phraseEnvs solution value} ${resholve}/bin/resholve --overwrite ${phraseArgs value}" - else throw "invalid solution"; # shouldn't trigger for now + # we pass resholve a directory + "RESHOLVE_LORE=${binlore.collect (phraseBinloreArgs value)} ${phraseEnvs solution value} ${resholve}/bin/resholve --overwrite ${phraseArgs value}" + else + throw "invalid solution"; # shouldn't trigger for now - injectUnresholved = solutions: unresholved: (builtins.mapAttrs (name: value: value // { inherit unresholved; } ) solutions); + injectUnresholved = + solutions: unresholved: + (builtins.mapAttrs (name: value: value // { inherit unresholved; }) solutions); - /* Build resholve invocation for each solution. */ - phraseCommands = solutions: unresholved: + # Build resholve invocation for each solution. + phraseCommands = + solutions: unresholved: builtins.concatStringsSep "\n" ( lib.mapAttrsToList phraseInvocation (injectUnresholved solutions unresholved) ); @@ -100,112 +151,138 @@ rec { and invocation. Extra context makes it clearer what the Nix API is doing, makes nix-shell debugging easier, etc. */ - phraseContext = { invokable, prep ? ''cd "$out"'' }: '' - ( - ${prep} - PS4=$'\x1f'"\033[33m[resholve context]\033[0m " - set -x - : invoking resholve with PWD=$PWD - ${invokable} - ) - ''; - phraseContextForPWD = invokable: phraseContext { inherit invokable; prep = ""; }; + phraseContext = + { + invokable, + prep ? ''cd "$out"'', + }: + '' + ( + ${prep} + PS4=$'\x1f'"\033[33m[resholve context]\033[0m " + set -x + : invoking resholve with PWD=$PWD + ${invokable} + ) + ''; + phraseContextForPWD = + invokable: + phraseContext { + inherit invokable; + prep = ""; + }; phraseContextForOut = invokable: phraseContext { inherit invokable; }; phraseSolution = name: solution: (phraseContextForOut (phraseInvocation name solution)); - phraseSolutions = solutions: unresholved: - phraseContextForOut (phraseCommands solutions unresholved); + phraseSolutions = + solutions: unresholved: phraseContextForOut (phraseCommands solutions unresholved); - writeScript = name: partialSolution: text: + writeScript = + name: partialSolution: text: writeTextFile { inherit name text; executable = true; - checkPhase = '' - ${(phraseContextForPWD ( - phraseInvocation name ( - partialSolution // { - scripts = [ "${placeholder "out"}" ]; - } - ) - ) - )} - '' + lib.optionalString (partialSolution.interpreter != "none") '' - ${partialSolution.interpreter} -n $out - ''; + checkPhase = + '' + ${ + (phraseContextForPWD ( + phraseInvocation name ( + partialSolution + // { + scripts = [ "${placeholder "out"}" ]; + } + ) + )) + } + '' + + lib.optionalString (partialSolution.interpreter != "none") '' + ${partialSolution.interpreter} -n $out + ''; }; - writeScriptBin = name: partialSolution: text: + writeScriptBin = + name: partialSolution: text: writeTextFile rec { inherit name text; executable = true; destination = "/bin/${name}"; - checkPhase = '' - ${phraseContextForOut ( + checkPhase = + '' + ${phraseContextForOut ( phraseInvocation name ( - partialSolution // { + partialSolution + // { scripts = [ "bin/${name}" ]; } ) - ) - } - '' + lib.optionalString (partialSolution.interpreter != "none") '' - ${partialSolution.interpreter} -n $out/bin/${name} - ''; + )} + '' + + lib.optionalString (partialSolution.interpreter != "none") '' + ${partialSolution.interpreter} -n $out/bin/${name} + ''; }; - mkDerivation = { pname - , src - , version - , passthru ? { } - , solutions - , ... + mkDerivation = + { + pname, + src, + version, + passthru ? { }, + solutions, + ... }@attrs: let inherit stdenv; /* - Knock out our special solutions arg, but otherwise - just build what the caller is giving us. We'll - actually resholve it separately below (after we - generate binlore for it). + Knock out our special solutions arg, but otherwise + just build what the caller is giving us. We'll + actually resholve it separately below (after we + generate binlore for it). */ - unresholved = (stdenv.mkDerivation ((removeAttrs attrs [ "solutions" ]) - // { - inherit version src; - pname = "${pname}-unresholved"; - })); + unresholved = ( + stdenv.mkDerivation ( + (removeAttrs attrs [ "solutions" ]) + // { + inherit version src; + pname = "${pname}-unresholved"; + } + ) + ); in /* - resholve in a separate derivation; some concerns: - - we aren't keeping many of the user's args, so they - can't readily set LOGLEVEL and such... - - not sure how this affects multiple outputs + resholve in a separate derivation; some concerns: + - we aren't keeping many of the user's args, so they + can't readily set LOGLEVEL and such... + - not sure how this affects multiple outputs */ - lib.extendDerivation true passthru (stdenv.mkDerivation { - src = unresholved; - inherit version pname; - buildInputs = [ resholve ]; - disallowedReferences = [ resholve ]; - - # retain a reference to the base - passthru = unresholved.passthru // { - unresholved = unresholved; - # fallback attr for update bot to query our src - originalSrc = unresholved.src; - }; - - # do these imply that we should use NoCC or something? - dontConfigure = true; - dontBuild = true; - - installPhase = '' - cp -R $src $out - ''; - - # enable below for verbose debug info if needed - # supports default python.logging levels - # LOGLEVEL="INFO"; - preFixup = phraseSolutions solutions unresholved; - - # don't break the metadata... - meta = unresholved.meta; - }); + lib.extendDerivation true passthru ( + stdenv.mkDerivation { + src = unresholved; + inherit version pname; + buildInputs = [ resholve ]; + disallowedReferences = [ resholve ]; + + # retain a reference to the base + passthru = unresholved.passthru // { + unresholved = unresholved; + # fallback attr for update bot to query our src + originalSrc = unresholved.src; + }; + + # do these imply that we should use NoCC or something? + dontConfigure = true; + dontBuild = true; + + installPhase = '' + cp -R $src $out + ''; + + # enable below for verbose debug info if needed + # supports default python.logging levels + # LOGLEVEL="INFO"; + preFixup = phraseSolutions solutions unresholved; + + # don't break the metadata... + meta = unresholved.meta; + } + ); } diff --git a/pkgs/development/misc/resholve/resholve.nix b/pkgs/development/misc/resholve/resholve.nix index 9fb98de3a248e3..1539580446ed51 100644 --- a/pkgs/development/misc/resholve/resholve.nix +++ b/pkgs/development/misc/resholve/resholve.nix @@ -1,16 +1,17 @@ -{ lib -, callPackage -, python27 -, fetchFromGitHub -, installShellFiles -, rSrc -, version -, oildev -, configargparse -, gawk -, binlore -, resholve -, resholve-utils +{ + lib, + callPackage, + python27, + fetchFromGitHub, + installShellFiles, + rSrc, + version, + oildev, + configargparse, + gawk, + binlore, + resholve, + resholve-utils, }: let @@ -25,7 +26,8 @@ let }; }; -in python27.pkgs.buildPythonApplication { +in +python27.pkgs.buildPythonApplication { pname = "resholve"; inherit version; src = rSrc; @@ -59,8 +61,20 @@ in python27.pkgs.buildPythonApplication { ''; passthru = { - inherit (resholve-utils) mkDerivation phraseSolution writeScript writeScriptBin; - tests = callPackage ./test.nix { inherit rSrc binlore python27 resholve; }; + inherit (resholve-utils) + mkDerivation + phraseSolution + writeScript + writeScriptBin + ; + tests = callPackage ./test.nix { + inherit + rSrc + binlore + python27 + resholve + ; + }; }; meta = with lib; { @@ -70,10 +84,12 @@ in python27.pkgs.buildPythonApplication { license = with licenses; [ mit ]; maintainers = with maintainers; [ abathur ]; platforms = platforms.all; - knownVulnerabilities = [ '' - resholve depends on python27 (EOL). While it's safe to - run on trusted input in the build sandbox, you should - avoid running it on untrusted input. - '' ]; + knownVulnerabilities = [ + '' + resholve depends on python27 (EOL). While it's safe to + run on trusted input in the build sandbox, you should + avoid running it on untrusted input. + '' + ]; }; } diff --git a/pkgs/development/misc/resholve/source.nix b/pkgs/development/misc/resholve/source.nix index 7d843d61b16309..670010c835624e 100644 --- a/pkgs/development/misc/resholve/source.nix +++ b/pkgs/development/misc/resholve/source.nix @@ -1,5 +1,6 @@ -{ fetchFromGitHub -, ... +{ + fetchFromGitHub, + ... }: rec { diff --git a/pkgs/development/misc/resholve/test.nix b/pkgs/development/misc/resholve/test.nix index 654f8a4577f5bd..a3a7d3a812440e 100644 --- a/pkgs/development/misc/resholve/test.nix +++ b/pkgs/development/misc/resholve/test.nix @@ -1,67 +1,83 @@ -{ lib -, stdenv -, callPackage -, resholve -, shunit2 -, coreutils -, gnused -, gnugrep -, findutils -, jq -, bash -, bats -, libressl -, openssl -, python27 -, file -, gettext -, rSrc -, runDemo ? false -, binlore -, sqlite -, unixtools -, gawk -, rlwrap -, gnutar -, bc -# override testing -, esh -, getconf -, libarchive -, locale -, mount -, ncurses -, nixos-install-tools -, nixos-rebuild -, procps -, ps -# known consumers -, aaxtomp3 -, arch-install-scripts -, bashup-events32 -, dgoss -, git-ftp -, ix -, lesspipe -, locate-dominating-file -, mons -, msmtp -, nix-direnv -, pdf2odt -, pdfmm -, rancid -, s0ix-selftest-tool -, unix-privesc-check -, wgnord -, wsl-vpnkit -, xdg-utils -, yadm -, zxfer +{ + lib, + stdenv, + callPackage, + resholve, + shunit2, + coreutils, + gnused, + gnugrep, + findutils, + jq, + bash, + bats, + libressl, + openssl, + python27, + file, + gettext, + rSrc, + runDemo ? false, + binlore, + sqlite, + unixtools, + gawk, + rlwrap, + gnutar, + bc, + # override testing + esh, + getconf, + libarchive, + locale, + mount, + ncurses, + nixos-install-tools, + nixos-rebuild, + procps, + ps, + # known consumers + aaxtomp3, + arch-install-scripts, + bashup-events32, + dgoss, + git-ftp, + ix, + lesspipe, + locate-dominating-file, + mons, + msmtp, + nix-direnv, + pdf2odt, + pdfmm, + rancid, + s0ix-selftest-tool, + unix-privesc-check, + wgnord, + wsl-vpnkit, + xdg-utils, + yadm, + zxfer, }: let - default_packages = [ bash file findutils gettext ]; - parsed_packages = [ coreutils sqlite unixtools.script gnused gawk findutils rlwrap gnutar bc ]; + default_packages = [ + bash + file + findutils + gettext + ]; + parsed_packages = [ + coreutils + sqlite + unixtools.script + gnused + gawk + findutils + rlwrap + gnutar + bc + ]; in rec { module1 = resholve.mkDerivation { @@ -80,9 +96,16 @@ rec { solutions = { libressl = { # submodule to demonstrate - scripts = [ "bin/libressl.sh" "submodule/helper.sh" ]; + scripts = [ + "bin/libressl.sh" + "submodule/helper.sh" + ]; interpreter = "none"; - inputs = [ jq module2 libressl.bin ]; + inputs = [ + jq + module2 + libressl.bin + ]; }; }; @@ -107,9 +130,17 @@ rec { fix = { aliases = true; }; - scripts = [ "bin/openssl.sh" "libexec/invokeme" ]; + scripts = [ + "bin/openssl.sh" + "libexec/invokeme" + ]; interpreter = "none"; - inputs = [ shunit2 openssl.bin "libexec" "libexec/invokeme" ]; + inputs = [ + shunit2 + openssl.bin + "libexec" + "libexec/invokeme" + ]; execer = [ /* This is the same verdict binlore will @@ -144,7 +175,10 @@ rec { interpreter = "${bash}/bin/bash"; inputs = [ module1 ]; fake = { - external = [ "jq" "openssl" ]; + external = [ + "jq" + "openssl" + ]; }; }} ''; @@ -163,7 +197,10 @@ rec { doCheck = true; buildInputs = [ resholve ]; - nativeCheckInputs = [ coreutils bats ]; + nativeCheckInputs = [ + coreutils + bats + ]; # LOGLEVEL="DEBUG"; # default path @@ -173,95 +210,116 @@ rec { PKG_FINDUTILS = "${lib.makeBinPath [ findutils ]}"; PKG_GETTEXT = "${lib.makeBinPath [ gettext ]}"; PKG_COREUTILS = "${lib.makeBinPath [ coreutils ]}"; - RESHOLVE_LORE = "${binlore.collect { drvs = default_packages ++ [ coreutils ] ++ parsed_packages; } }"; + RESHOLVE_LORE = "${binlore.collect { + drvs = default_packages ++ [ coreutils ] ++ parsed_packages; + }}"; PKG_PARSED = "${lib.makeBinPath parsed_packages}"; # explicit interpreter for demo suite; maybe some better way... INTERP = "${bash}/bin/bash"; - checkPhase = '' - patchShebangs . - mkdir empty_lore - touch empty_lore/{execers,wrappers} - export EMPTY_LORE=$PWD/empty_lore - printf "\033[33m============================= resholve test suite ===================================\033[0m\n" > test.ansi - if ./test.sh &>> test.ansi; then - cat test.ansi - else - cat test.ansi && exit 1 - fi - '' + lib.optionalString runDemo '' - printf "\033[33m============================= resholve demo ===================================\033[0m\n" > demo.ansi - if ./demo &>> demo.ansi; then - cat demo.ansi - else - cat demo.ansi && exit 1 - fi - ''; + checkPhase = + '' + patchShebangs . + mkdir empty_lore + touch empty_lore/{execers,wrappers} + export EMPTY_LORE=$PWD/empty_lore + printf "\033[33m============================= resholve test suite ===================================\033[0m\n" > test.ansi + if ./test.sh &>> test.ansi; then + cat test.ansi + else + cat test.ansi && exit 1 + fi + '' + + lib.optionalString runDemo '' + printf "\033[33m============================= resholve demo ===================================\033[0m\n" > demo.ansi + if ./demo &>> demo.ansi; then + cat demo.ansi + else + cat demo.ansi && exit 1 + fi + ''; }; # Caution: ci.nix asserts the equality of both of these w/ diff - resholvedScript = resholve.writeScript "resholved-script" { - inputs = [ file ]; - interpreter = "${bash}/bin/bash"; - } '' - echo "Hello" - file . - ''; - resholvedScriptBin = resholve.writeScriptBin "resholved-script-bin" { - inputs = [ file ]; - interpreter = "${bash}/bin/bash"; - } '' - echo "Hello" - file . - ''; - resholvedScriptBinNone = resholve.writeScriptBin "resholved-script-bin" { - inputs = [ file ]; - interpreter = "none"; - } '' - echo "Hello" - file . - ''; + resholvedScript = + resholve.writeScript "resholved-script" + { + inputs = [ file ]; + interpreter = "${bash}/bin/bash"; + } + '' + echo "Hello" + file . + ''; + resholvedScriptBin = + resholve.writeScriptBin "resholved-script-bin" + { + inputs = [ file ]; + interpreter = "${bash}/bin/bash"; + } + '' + echo "Hello" + file . + ''; + resholvedScriptBinNone = + resholve.writeScriptBin "resholved-script-bin" + { + inputs = [ file ]; + interpreter = "none"; + } + '' + echo "Hello" + file . + ''; # spot-check lore overrides - loreOverrides = resholve.writeScriptBin "verify-overrides" { - inputs = [ - coreutils - esh - getconf - libarchive - locale - mount - ncurses - procps - ps - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - nixos-install-tools - nixos-rebuild - ]; - interpreter = "none"; - execer = [ - "cannot:${esh}/bin/esh" - ]; - fix = { - mount = true; - }; - } ('' - env b2sum fake args - b2sum fake args - esh fake args - getconf fake args - bsdtar fake args - locale fake args - mount fake args - reset fake args - tput fake args - tset fake args - ps fake args - top fake args - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - nixos-generate-config fake args - nixos-rebuild fake args - ''); + loreOverrides = + resholve.writeScriptBin "verify-overrides" + { + inputs = + [ + coreutils + esh + getconf + libarchive + locale + mount + ncurses + procps + ps + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + nixos-install-tools + nixos-rebuild + ]; + interpreter = "none"; + execer = [ + "cannot:${esh}/bin/esh" + ]; + fix = { + mount = true; + }; + } + ( + '' + env b2sum fake args + b2sum fake args + esh fake args + getconf fake args + bsdtar fake args + locale fake args + mount fake args + reset fake args + tput fake args + tset fake args + ps fake args + top fake args + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + nixos-generate-config fake args + nixos-rebuild fake args + '' + ); # ensure known consumers in nixpkgs keep working inherit aaxtomp3; @@ -279,7 +337,8 @@ rec { inherit shunit2; inherit xdg-utils; inherit yadm; -} // lib.optionalAttrs stdenv.hostPlatform.isLinux { +} +// lib.optionalAttrs stdenv.hostPlatform.isLinux { inherit arch-install-scripts; inherit dgoss; inherit rancid; @@ -287,6 +346,10 @@ rec { inherit wgnord; inherit wsl-vpnkit; inherit zxfer; -} // lib.optionalAttrs (stdenv.hostPlatform.isLinux && (stdenv.hostPlatform.isi686 || stdenv.hostPlatform.isx86_64)) { - inherit s0ix-selftest-tool; } +// + lib.optionalAttrs + (stdenv.hostPlatform.isLinux && (stdenv.hostPlatform.isi686 || stdenv.hostPlatform.isx86_64)) + { + inherit s0ix-selftest-tool; + } diff --git a/pkgs/development/misc/vc4/newlib.nix b/pkgs/development/misc/vc4/newlib.nix index 48efd317d4c26f..f1012186b1c3fd 100644 --- a/pkgs/development/misc/vc4/newlib.nix +++ b/pkgs/development/misc/vc4/newlib.nix @@ -1,4 +1,12 @@ -{ stdenv, texinfo, flex, bison, fetchFromGitHub, stdenvNoLibc, buildPackages }: +{ + stdenv, + texinfo, + flex, + bison, + fetchFromGitHub, + stdenvNoLibc, + buildPackages, +}: stdenvNoLibc.mkDerivation { name = "newlib"; @@ -12,7 +20,11 @@ stdenvNoLibc.mkDerivation { configurePlatforms = [ "target" ]; enableParallelBuilding = true; - nativeBuildInputs = [ texinfo flex bison ]; + nativeBuildInputs = [ + texinfo + flex + bison + ]; depsBuildBuild = [ buildPackages.stdenv.cc ]; # newlib expects CC to build for build platform, not host platform preConfigure = '' diff --git a/pkgs/development/mobile/adb-sync/default.nix b/pkgs/development/mobile/adb-sync/default.nix index 8233bd99984907..d254c7e2a5e1b3 100644 --- a/pkgs/development/mobile/adb-sync/default.nix +++ b/pkgs/development/mobile/adb-sync/default.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, python3, platform-tools, makeWrapper -, socat, go-mtpfs, adbfs-rootless +{ + lib, + stdenv, + fetchFromGitHub, + python3, + platform-tools, + makeWrapper, + socat, + go-mtpfs, + adbfs-rootless, }: stdenv.mkDerivation { @@ -18,26 +26,33 @@ stdenv.mkDerivation { dontBuild = true; - installPhase = let - dependencies = lib.makeBinPath [ platform-tools socat go-mtpfs adbfs-rootless ]; - in '' - runHook preInstall + installPhase = + let + dependencies = lib.makeBinPath [ + platform-tools + socat + go-mtpfs + adbfs-rootless + ]; + in + '' + runHook preInstall - mkdir -p $out/bin - cp adb-{sync,channel} $out/bin + mkdir -p $out/bin + cp adb-{sync,channel} $out/bin - wrapProgram $out/bin/adb-sync --suffix PATH : "${dependencies}" - wrapProgram $out/bin/adb-channel --suffix PATH : "${dependencies}" + wrapProgram $out/bin/adb-sync --suffix PATH : "${dependencies}" + wrapProgram $out/bin/adb-channel --suffix PATH : "${dependencies}" - runHook postInstall - ''; + runHook postInstall + ''; meta = with lib; { description = "Tool to synchronise files between a PC and an Android devices using ADB (Android Debug Bridge)"; homepage = "https://github.com/google/adb-sync"; license = licenses.asl20; platforms = platforms.unix; - hydraPlatforms = []; + hydraPlatforms = [ ]; maintainers = with maintainers; [ scolobb ]; }; } diff --git a/pkgs/development/mobile/androidenv/build-app.nix b/pkgs/development/mobile/androidenv/build-app.nix index 18e59f0bd0d60c..2be0ac56782149 100644 --- a/pkgs/development/mobile/androidenv/build-app.nix +++ b/pkgs/development/mobile/androidenv/build-app.nix @@ -1,12 +1,27 @@ -{ composeAndroidPackages, stdenv, lib, ant, jdk, gnumake, gawk }: +{ + composeAndroidPackages, + stdenv, + lib, + ant, + jdk, + gnumake, + gawk, +}: -{ name -, release ? false, keyStore ? null, keyAlias ? null, keyStorePassword ? null, keyAliasPassword ? null -, antFlags ? "" -, ... +{ + name, + release ? false, + keyStore ? null, + keyAlias ? null, + keyStorePassword ? null, + keyAliasPassword ? null, + antFlags ? "", + ... }@args: -assert release -> keyStore != null && keyAlias != null && keyStorePassword != null && keyAliasPassword != null; +assert + release + -> keyStore != null && keyAlias != null && keyStorePassword != null && keyAliasPassword != null; let androidSdkFormalArgs = lib.functionArgs composeAndroidPackages; @@ -15,34 +30,40 @@ let extraArgs = removeAttrs args ([ "name" ] ++ builtins.attrNames androidSdkFormalArgs); in -stdenv.mkDerivation ({ - name = lib.replaceStrings [" "] [""] name; # Android APKs may contain white spaces in their names, but Nix store paths cannot - ANDROID_HOME = "${androidsdk}/libexec/android-sdk"; - buildInputs = [ jdk ant ]; - buildPhase = '' - ${lib.optionalString release '' - # Provide key singing attributes - ( echo "key.store=${keyStore}" - echo "key.alias=${keyAlias}" - echo "key.store.password=${keyStorePassword}" - echo "key.alias.password=${keyAliasPassword}" - ) >> ant.properties - ''} +stdenv.mkDerivation ( + { + name = lib.replaceStrings [ " " ] [ "" ] name; # Android APKs may contain white spaces in their names, but Nix store paths cannot + ANDROID_HOME = "${androidsdk}/libexec/android-sdk"; + buildInputs = [ + jdk + ant + ]; + buildPhase = '' + ${lib.optionalString release '' + # Provide key singing attributes + ( echo "key.store=${keyStore}" + echo "key.alias=${keyAlias}" + echo "key.store.password=${keyStorePassword}" + echo "key.alias.password=${keyAliasPassword}" + ) >> ant.properties + ''} - export ANDROID_SDK_HOME=`pwd` # Key files cannot be stored in the user's home directory. This overrides it. + export ANDROID_SDK_HOME=`pwd` # Key files cannot be stored in the user's home directory. This overrides it. - ${lib.optionalString (args ? includeNDK && args.includeNDK) '' - export GNUMAKE=${gnumake}/bin/make - export NDK_HOST_AWK=${gawk}/bin/gawk - ${androidsdk}/libexec/android-sdk/ndk-bundle/ndk-build - ''} - ant ${antFlags} ${if release then "release" else "debug"} - ''; - installPhase = '' - mkdir -p $out - mv bin/*-${if release then "release" else "debug"}.apk $out + ${lib.optionalString (args ? includeNDK && args.includeNDK) '' + export GNUMAKE=${gnumake}/bin/make + export NDK_HOST_AWK=${gawk}/bin/gawk + ${androidsdk}/libexec/android-sdk/ndk-bundle/ndk-build + ''} + ant ${antFlags} ${if release then "release" else "debug"} + ''; + installPhase = '' + mkdir -p $out + mv bin/*-${if release then "release" else "debug"}.apk $out - mkdir -p $out/nix-support - echo "file binary-dist \"$(echo $out/*.apk)\"" > $out/nix-support/hydra-build-products - ''; -} // extraArgs) + mkdir -p $out/nix-support + echo "file binary-dist \"$(echo $out/*.apk)\"" > $out/nix-support/hydra-build-products + ''; + } + // extraArgs +) diff --git a/pkgs/development/mobile/androidenv/cmdline-tools.nix b/pkgs/development/mobile/androidenv/cmdline-tools.nix index b2d89ed741b5c5..d3935d547b04fe 100644 --- a/pkgs/development/mobile/androidenv/cmdline-tools.nix +++ b/pkgs/development/mobile/androidenv/cmdline-tools.nix @@ -1,10 +1,21 @@ -{deployAndroidPackage, lib, package, autoPatchelfHook, makeWrapper, os, pkgs, stdenv, postInstall}: +{ + deployAndroidPackage, + lib, + package, + autoPatchelfHook, + makeWrapper, + os, + pkgs, + stdenv, + postInstall, +}: deployAndroidPackage { name = "androidsdk"; inherit package os; - nativeBuildInputs = [ makeWrapper ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ autoPatchelfHook ]; + nativeBuildInputs = [ + makeWrapper + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ autoPatchelfHook ]; patchInstructions = '' ${lib.optionalString (os == "linux") '' diff --git a/pkgs/development/mobile/androidenv/default.nix b/pkgs/development/mobile/androidenv/default.nix index fbababf9af2c0f..2f4efd5b4e1fb3 100644 --- a/pkgs/development/mobile/androidenv/default.nix +++ b/pkgs/development/mobile/androidenv/default.nix @@ -1,5 +1,8 @@ -{ config, pkgs ? import {} -, licenseAccepted ? config.android_sdk.accept_license or (builtins.getEnv "NIXPKGS_ACCEPT_ANDROID_SDK_LICENSE" == "1") +{ + config, + pkgs ? import { }, + licenseAccepted ? + config.android_sdk.accept_license or (builtins.getEnv "NIXPKGS_ACCEPT_ANDROID_SDK_LICENSE" == "1"), }: rec { @@ -16,17 +19,29 @@ rec { }; androidPkgs = composeAndroidPackages { - platformVersions = [ "28" "29" "30" "31" "32" "33" "34" "35" ]; + platformVersions = [ + "28" + "29" + "30" + "31" + "32" + "33" + "34" + "35" + ]; includeEmulator = true; includeSystemImages = true; includeNDK = true; }; - test-suite = pkgs.callPackage ./test-suite.nix {}; + test-suite = pkgs.callPackage ./test-suite.nix { }; meta = with pkgs.lib; { description = "Android SDK & sdkmanager"; homepage = "https://developer.android.com/tools/sdkmanager"; - maintainers = with maintainers; [ numinit hadilq ]; + maintainers = with maintainers; [ + numinit + hadilq + ]; }; } diff --git a/pkgs/development/mobile/androidenv/emulate-app.nix b/pkgs/development/mobile/androidenv/emulate-app.nix index 94bf0084ed27b0..9d568a765d3a80 100644 --- a/pkgs/development/mobile/androidenv/emulate-app.nix +++ b/pkgs/development/mobile/androidenv/emulate-app.nix @@ -1,40 +1,49 @@ -{ composeAndroidPackages, stdenv, lib, runtimeShell }: -{ name -, app ? null -, platformVersion ? "35" -, abiVersion ? "x86" -, systemImageType ? "default" -, enableGPU ? false # Enable GPU acceleration. It's deprecated, instead use `configOptions` below. -, configOptions ? ( +{ + composeAndroidPackages, + stdenv, + lib, + runtimeShell, +}: +{ + name, + app ? null, + platformVersion ? "35", + abiVersion ? "x86", + systemImageType ? "default", + enableGPU ? false, # Enable GPU acceleration. It's deprecated, instead use `configOptions` below. + configOptions ? ( # List of options to add in config.ini - lib.optionalAttrs enableGPU - (lib.warn - "enableGPU argument is deprecated and will be removed; use configOptions instead" - { "hw.gpu.enabled" = "yes"; } - ) - ) -, extraAVDFiles ? [ ] -, package ? null -, activity ? null -, androidUserHome ? null -, avdHomeDir ? null # Support old variable with non-standard naming! -, androidAvdHome ? avdHomeDir -, deviceName ? "device" -, sdkExtraArgs ? { } -, androidAvdFlags ? null -, androidEmulatorFlags ? null + lib.optionalAttrs enableGPU ( + lib.warn "enableGPU argument is deprecated and will be removed; use configOptions instead" { + "hw.gpu.enabled" = "yes"; + } + ) + ), + extraAVDFiles ? [ ], + package ? null, + activity ? null, + androidUserHome ? null, + avdHomeDir ? null, # Support old variable with non-standard naming! + androidAvdHome ? avdHomeDir, + deviceName ? "device", + sdkExtraArgs ? { }, + androidAvdFlags ? null, + androidEmulatorFlags ? null, }: let - sdkArgs = { - includeEmulator = true; - includeSystemImages = true; - } // sdkExtraArgs // { - cmdLineToolsVersion = "8.0"; - platformVersions = [ platformVersion ]; - systemImageTypes = [ systemImageType ]; - abiVersions = [ abiVersion ]; - }; + sdkArgs = + { + includeEmulator = true; + includeSystemImages = true; + } + // sdkExtraArgs + // { + cmdLineToolsVersion = "8.0"; + platformVersions = [ platformVersion ]; + systemImageTypes = [ systemImageType ]; + abiVersions = [ abiVersion ]; + }; sdk = (composeAndroidPackages sdkArgs).androidsdk; in @@ -53,20 +62,30 @@ stdenv.mkDerivation { export TMPDIR=/tmp fi - ${if androidUserHome == null then '' - # Store the virtual devices somewhere else, instead of polluting a user's HOME directory - export ANDROID_USER_HOME=$(mktemp -d $TMPDIR/nix-android-user-home-XXXX) - '' else '' - mkdir -p "${androidUserHome}" - export ANDROID_USER_HOME="${androidUserHome}" - ''} - - ${if androidAvdHome == null then '' - export ANDROID_AVD_HOME=$ANDROID_USER_HOME/avd - '' else '' - mkdir -p "${androidAvdHome}" - export ANDROID_AVD_HOME="${androidAvdHome}" - ''} + ${ + if androidUserHome == null then + '' + # Store the virtual devices somewhere else, instead of polluting a user's HOME directory + export ANDROID_USER_HOME=$(mktemp -d $TMPDIR/nix-android-user-home-XXXX) + '' + else + '' + mkdir -p "${androidUserHome}" + export ANDROID_USER_HOME="${androidUserHome}" + '' + } + + ${ + if androidAvdHome == null then + '' + export ANDROID_AVD_HOME=$ANDROID_USER_HOME/avd + '' + else + '' + mkdir -p "${androidAvdHome}" + export ANDROID_AVD_HOME="${androidAvdHome}" + '' + } # We need to specify the location of the Android SDK root folder export ANDROID_SDK_ROOT=${sdk}/libexec/android-sdk @@ -169,7 +188,7 @@ stdenv.mkDerivation { # Start the application ${lib.optionalString (package != null && activity != null) '' - ${sdk}/libexec/android-sdk/platform-tools/adb -s emulator-$port shell am start -a android.intent.action.MAIN -n ${package}/${activity} + ${sdk}/libexec/android-sdk/platform-tools/adb -s emulator-$port shell am start -a android.intent.action.MAIN -n ${package}/${activity} ''} ''} EOF diff --git a/pkgs/development/mobile/androidenv/examples/shell-with-emulator.nix b/pkgs/development/mobile/androidenv/examples/shell-with-emulator.nix index 0a710e45843cde..2ebd0a72e42c66 100644 --- a/pkgs/development/mobile/androidenv/examples/shell-with-emulator.nix +++ b/pkgs/development/mobile/androidenv/examples/shell-with-emulator.nix @@ -3,14 +3,15 @@ # If you copy this example out of nixpkgs, use these lines instead of the next. # This example pins nixpkgs: https://nix.dev/tutorials/first-steps/towards-reproducibility-pinning-nixpkgs.html - /*nixpkgsSource ? (builtins.fetchTarball { - name = "nixpkgs-20.09"; - url = "https://github.com/NixOS/nixpkgs/archive/20.09.tar.gz"; - sha256 = "1wg61h4gndm3vcprdcg7rc4s1v3jkm5xd7lw8r2f67w502y94gcy"; - }), - pkgs ? import nixpkgsSource { - config.allowUnfree = true; - }, + /* + nixpkgsSource ? (builtins.fetchTarball { + name = "nixpkgs-20.09"; + url = "https://github.com/NixOS/nixpkgs/archive/20.09.tar.gz"; + sha256 = "1wg61h4gndm3vcprdcg7rc4s1v3jkm5xd7lw8r2f67w502y94gcy"; + }), + pkgs ? import nixpkgsSource { + config.allowUnfree = true; + }, */ # If you want to use the in-tree version of nixpkgs: @@ -18,7 +19,7 @@ config.allowUnfree = true; }, - config ? pkgs.config + config ? pkgs.config, }: # Copy this file to your Android project. @@ -32,16 +33,18 @@ let }; # If you copy this example out of nixpkgs, something like this will work: - /*androidEnvNixpkgs = fetchTarball { - name = "androidenv"; - url = "https://github.com/NixOS/nixpkgs/archive/.tar.gz"; - sha256 = ""; - }; - - androidEnv = pkgs.callPackage "${androidEnvNixpkgs}/pkgs/development/mobile/androidenv" { - inherit config pkgs; - licenseAccepted = true; - };*/ + /* + androidEnvNixpkgs = fetchTarball { + name = "androidenv"; + url = "https://github.com/NixOS/nixpkgs/archive/.tar.gz"; + sha256 = ""; + }; + + androidEnv = pkgs.callPackage "${androidEnvNixpkgs}/pkgs/development/mobile/androidenv" { + inherit config pkgs; + licenseAccepted = true; + }; + */ # Otherwise, just use the in-tree androidenv: androidEnv = pkgs.callPackage ./.. { @@ -78,7 +81,9 @@ let androidComposition = androidEnv.composeAndroidPackages sdkArgs; androidEmulator = androidEnv.emulateApp { name = "android-sdk-emulator-demo"; - configOptions = { "hw.keyboard" = "yes"; }; + configOptions = { + "hw.keyboard" = "yes"; + }; sdkExtraArgs = sdkArgs; }; androidSdk = androidComposition.androidsdk; @@ -87,7 +92,13 @@ let in pkgs.mkShell rec { name = "androidenv-demo"; - packages = [ androidSdk platformTools androidEmulator jdk pkgs.android-studio ]; + packages = [ + androidSdk + platformTools + androidEmulator + jdk + pkgs.android-studio + ]; LANG = "C.UTF-8"; LC_ALL = "C.UTF-8"; @@ -108,77 +119,94 @@ pkgs.mkShell rec { passthru.tests = { - shell-with-emulator-sdkmanager-packages-test = pkgs.runCommand "shell-with-emulator-sdkmanager-packages-test" { - nativeBuildInputs = [ androidSdk jdk ]; - } '' - output="$(sdkmanager --list)" - installed_packages_section=$(echo "''${output%%Available Packages*}" | awk 'NR>4 {print $1}') - echo "installed_packages_section: ''${installed_packages_section}" - - packages=( - "build-tools;35.0.0" "cmdline-tools;13.0" \ - "emulator" "patcher;v4" "platform-tools" "platforms;android-35" \ - "system-images;android-35;google_apis;x86_64" - ) - - for package in "''${packages[@]}"; do - if [[ ! $installed_packages_section =~ "$package" ]]; then - echo "$package package was not installed." - exit 1 - fi - done - - touch "$out" - ''; - - shell-with-emulator-sdkmanager-excluded-packages-test = pkgs.runCommand "shell-with-emulator-sdkmanager-excluded-packages-test" - { - nativeBuildInputs = [ androidSdk jdk ]; - } '' - output="$(sdkmanager --list)" - installed_packages_section=$(echo "''${output%%Available Packages*}" | awk 'NR>4 {print $1}') - - excluded_packages=( - "platforms;android-23" "platforms;android-24" "platforms;android-25" "platforms;android-26" \ - "platforms;android-27" "platforms;android-28" "platforms;android-29" "platforms;android-30" \ - "platforms;android-31" "platforms;android-32" "platforms;android-33" "platforms;android-34" \ - "sources;android-23" "sources;android-24" "sources;android-25" "sources;android-26" \ - "sources;android-27" "sources;android-28" "sources;android-29" "sources;android-30" \ - "sources;android-31" "sources;android-32" "sources;android-33" "sources;android-34" \ - "system-images;android-28" \ - "system-images;android-29" \ - "system-images;android-30" \ - "system-images;android-31" \ - "system-images;android-32" \ - "system-images;android-33" \ - "ndk" - ) - - for package in "''${excluded_packages[@]}"; do - if [[ $installed_packages_section =~ "$package" ]]; then - echo "$package package was installed, while it was excluded!" - exit 1 - fi - done - - touch "$out" - ''; - - shell-with-emulator-avdmanager-create-avd-test = pkgs.runCommand "shell-with-emulator-avdmanager-create-avd-test" { - nativeBuildInputs = [ androidSdk androidEmulator jdk ]; - } '' - avdmanager delete avd -n testAVD || true - echo "" | avdmanager create avd --force --name testAVD --package 'system-images;android-35;google_apis;x86_64' - result=$(avdmanager list avd) - - if [[ ! $result =~ "Name: testAVD" ]]; then - echo "avdmanager couldn't create the avd! The output is :''${result}" - exit 1 - fi - - avdmanager delete avd -n testAVD || true - touch "$out" - ''; + shell-with-emulator-sdkmanager-packages-test = + pkgs.runCommand "shell-with-emulator-sdkmanager-packages-test" + { + nativeBuildInputs = [ + androidSdk + jdk + ]; + } + '' + output="$(sdkmanager --list)" + installed_packages_section=$(echo "''${output%%Available Packages*}" | awk 'NR>4 {print $1}') + echo "installed_packages_section: ''${installed_packages_section}" + + packages=( + "build-tools;35.0.0" "cmdline-tools;13.0" \ + "emulator" "patcher;v4" "platform-tools" "platforms;android-35" \ + "system-images;android-35;google_apis;x86_64" + ) + + for package in "''${packages[@]}"; do + if [[ ! $installed_packages_section =~ "$package" ]]; then + echo "$package package was not installed." + exit 1 + fi + done + + touch "$out" + ''; + + shell-with-emulator-sdkmanager-excluded-packages-test = + pkgs.runCommand "shell-with-emulator-sdkmanager-excluded-packages-test" + { + nativeBuildInputs = [ + androidSdk + jdk + ]; + } + '' + output="$(sdkmanager --list)" + installed_packages_section=$(echo "''${output%%Available Packages*}" | awk 'NR>4 {print $1}') + + excluded_packages=( + "platforms;android-23" "platforms;android-24" "platforms;android-25" "platforms;android-26" \ + "platforms;android-27" "platforms;android-28" "platforms;android-29" "platforms;android-30" \ + "platforms;android-31" "platforms;android-32" "platforms;android-33" "platforms;android-34" \ + "sources;android-23" "sources;android-24" "sources;android-25" "sources;android-26" \ + "sources;android-27" "sources;android-28" "sources;android-29" "sources;android-30" \ + "sources;android-31" "sources;android-32" "sources;android-33" "sources;android-34" \ + "system-images;android-28" \ + "system-images;android-29" \ + "system-images;android-30" \ + "system-images;android-31" \ + "system-images;android-32" \ + "system-images;android-33" \ + "ndk" + ) + + for package in "''${excluded_packages[@]}"; do + if [[ $installed_packages_section =~ "$package" ]]; then + echo "$package package was installed, while it was excluded!" + exit 1 + fi + done + + touch "$out" + ''; + + shell-with-emulator-avdmanager-create-avd-test = + pkgs.runCommand "shell-with-emulator-avdmanager-create-avd-test" + { + nativeBuildInputs = [ + androidSdk + androidEmulator + jdk + ]; + } + '' + avdmanager delete avd -n testAVD || true + echo "" | avdmanager create avd --force --name testAVD --package 'system-images;android-35;google_apis;x86_64' + result=$(avdmanager list avd) + + if [[ ! $result =~ "Name: testAVD" ]]; then + echo "avdmanager couldn't create the avd! The output is :''${result}" + exit 1 + fi + + avdmanager delete avd -n testAVD || true + touch "$out" + ''; }; } - diff --git a/pkgs/development/mobile/androidenv/examples/shell-without-emulator.nix b/pkgs/development/mobile/androidenv/examples/shell-without-emulator.nix index 25b90e6d21a094..d43592c1b7e25a 100644 --- a/pkgs/development/mobile/androidenv/examples/shell-without-emulator.nix +++ b/pkgs/development/mobile/androidenv/examples/shell-without-emulator.nix @@ -3,7 +3,8 @@ # If you copy this example out of nixpkgs, use these lines instead of the next. # This example pins nixpkgs: https://nix.dev/tutorials/first-steps/towards-reproducibility-pinning-nixpkgs.html - /*nixpkgsSource ? (builtins.fetchTarball { + /* + nixpkgsSource ? (builtins.fetchTarball { name = "nixpkgs-20.09"; url = "https://github.com/NixOS/nixpkgs/archive/20.09.tar.gz"; sha256 = "1wg61h4gndm3vcprdcg7rc4s1v3jkm5xd7lw8r2f67w502y94gcy"; @@ -16,8 +17,8 @@ # If you want to use the in-tree version of nixpkgs: pkgs ? import ../../../../.. { config.allowUnfree = true; - } -, config ? pkgs.config + }, + config ? pkgs.config, }: # Copy this file to your Android project. @@ -34,7 +35,8 @@ let }; # If you copy this example out of nixpkgs, something like this will work: - /*androidEnvNixpkgs = fetchTarball { + /* + androidEnvNixpkgs = fetchTarball { name = "androidenv"; url = "https://github.com/NixOS/nixpkgs/archive/.tar.gz"; sha256 = ""; @@ -43,7 +45,8 @@ let androidEnv = pkgs.callPackage "${androidEnvNixpkgs}/pkgs/development/mobile/androidenv" { inherit config pkgs; licenseAccepted = true; - };*/ + }; + */ # Otherwise, just use the in-tree androidenv: androidEnv = pkgs.callPackage ./.. { @@ -85,7 +88,12 @@ let in pkgs.mkShell rec { name = "androidenv-example-without-emulator-demo"; - packages = [ androidSdk platformTools jdk pkgs.android-studio ]; + packages = [ + androidSdk + platformTools + jdk + pkgs.android-studio + ]; LANG = "C.UTF-8"; LC_ALL = "C.UTF-8"; @@ -104,49 +112,58 @@ pkgs.mkShell rec { passthru.tests = { - shell-without-emulator-sdkmanager-packages-test = pkgs.runCommand "shell-without-emulator-sdkmanager-packages-test" - { - nativeBuildInputs = [ androidSdk jdk ]; - } '' - output="$(sdkmanager --list)" - installed_packages_section=$(echo "''${output%%Available Packages*}" | awk 'NR>4 {print $1}') - echo "installed_packages_section: ''${installed_packages_section}" - - packages=( - "build-tools;35.0.0" "cmdline-tools;13.0" \ - "patcher;v4" "platform-tools" "platforms;android-35" - ) - - for package in "''${packages[@]}"; do - if [[ ! $installed_packages_section =~ "$package" ]]; then - echo "$package package was not installed." - exit 1 - fi - done - - touch "$out" - ''; - - shell-without-emulator-sdkmanager-excluded-packages-test = pkgs.runCommand "shell-without-emulator-sdkmanager-excluded-packages-test" - { - nativeBuildInputs = [ androidSdk jdk ]; - } '' - output="$(sdkmanager --list)" - installed_packages_section=$(echo "''${output%%Available Packages*}" | awk 'NR>4 {print $1}') - - excluded_packages=( - "emulator" "ndk" - ) - - for package in "''${excluded_packages[@]}"; do - if [[ $installed_packages_section =~ "$package" ]]; then - echo "$package package was installed, while it was excluded!" - exit 1 - fi - done - - touch "$out" - ''; + shell-without-emulator-sdkmanager-packages-test = + pkgs.runCommand "shell-without-emulator-sdkmanager-packages-test" + { + nativeBuildInputs = [ + androidSdk + jdk + ]; + } + '' + output="$(sdkmanager --list)" + installed_packages_section=$(echo "''${output%%Available Packages*}" | awk 'NR>4 {print $1}') + echo "installed_packages_section: ''${installed_packages_section}" + + packages=( + "build-tools;35.0.0" "cmdline-tools;13.0" \ + "patcher;v4" "platform-tools" "platforms;android-35" + ) + + for package in "''${packages[@]}"; do + if [[ ! $installed_packages_section =~ "$package" ]]; then + echo "$package package was not installed." + exit 1 + fi + done + + touch "$out" + ''; + + shell-without-emulator-sdkmanager-excluded-packages-test = + pkgs.runCommand "shell-without-emulator-sdkmanager-excluded-packages-test" + { + nativeBuildInputs = [ + androidSdk + jdk + ]; + } + '' + output="$(sdkmanager --list)" + installed_packages_section=$(echo "''${output%%Available Packages*}" | awk 'NR>4 {print $1}') + + excluded_packages=( + "emulator" "ndk" + ) + + for package in "''${excluded_packages[@]}"; do + if [[ $installed_packages_section =~ "$package" ]]; then + echo "$package package was installed, while it was excluded!" + exit 1 + fi + done + + touch "$out" + ''; }; } - diff --git a/pkgs/development/mobile/androidenv/patcher.nix b/pkgs/development/mobile/androidenv/patcher.nix index f525033d236a70..e52013f9c32342 100644 --- a/pkgs/development/mobile/androidenv/patcher.nix +++ b/pkgs/development/mobile/androidenv/patcher.nix @@ -1,4 +1,11 @@ -{deployAndroidPackage, lib, package, os, autoPatchelfHook, stdenv}: +{ + deployAndroidPackage, + lib, + package, + os, + autoPatchelfHook, + stdenv, +}: deployAndroidPackage { inherit package os; diff --git a/pkgs/development/mobile/androidenv/test-suite.nix b/pkgs/development/mobile/androidenv/test-suite.nix index c3a8cc64f0f4b7..0b6984366191f3 100644 --- a/pkgs/development/mobile/androidenv/test-suite.nix +++ b/pkgs/development/mobile/androidenv/test-suite.nix @@ -1,11 +1,15 @@ -{ callPackage, lib, stdenv }: +{ + callPackage, + lib, + stdenv, +}: let examples-shell = callPackage ./examples/shell.nix { }; examples-shell-with-emulator = callPackage ./examples/shell-with-emulator.nix { }; examples-shell-without-emulator = callPackage ./examples/shell-without-emulator.nix { }; - all-tests = examples-shell.passthru.tests // - (examples-shell-with-emulator.passthru.tests // - examples-shell-without-emulator.passthru.tests); + all-tests = + examples-shell.passthru.tests + // (examples-shell-with-emulator.passthru.tests // examples-shell-without-emulator.passthru.tests); in stdenv.mkDerivation { name = "androidenv-test-suite"; diff --git a/pkgs/development/mobile/fdroidcl/default.nix b/pkgs/development/mobile/fdroidcl/default.nix index 9b23443a3a2ad6..60bccaef812ae5 100644 --- a/pkgs/development/mobile/fdroidcl/default.nix +++ b/pkgs/development/mobile/fdroidcl/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, android-tools +{ + lib, + buildGoModule, + fetchFromGitHub, + android-tools, }: buildGoModule rec { diff --git a/pkgs/development/mobile/webos/cmake-modules.nix b/pkgs/development/mobile/webos/cmake-modules.nix index 81ea134dd29c10..be7818a9cab514 100644 --- a/pkgs/development/mobile/webos/cmake-modules.nix +++ b/pkgs/development/mobile/webos/cmake-modules.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "cmake-modules-webos"; diff --git a/pkgs/development/mobile/webos/novacom.nix b/pkgs/development/mobile/webos/novacom.nix index e62808ee9b7e62..9cd3fb152e31a4 100644 --- a/pkgs/development/mobile/webos/novacom.nix +++ b/pkgs/development/mobile/webos/novacom.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, webos, cmake, pkg-config }: +{ + lib, + stdenv, + fetchFromGitHub, + webos, + cmake, + pkg-config, +}: stdenv.mkDerivation rec { pname = "novacom"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "12s6g7l20kakyjlhqpli496miv2kfsdp17lcwhdrzdxvxl6hnf4n"; }; - nativeBuildInputs = [ cmake pkg-config webos.cmake-modules ]; + nativeBuildInputs = [ + cmake + pkg-config + webos.cmake-modules + ]; postInstall = '' install -Dm755 -t $out/bin ../scripts/novaterm diff --git a/pkgs/development/mobile/webos/novacomd.nix b/pkgs/development/mobile/webos/novacomd.nix index 7095dbaf9dfaaf..617ec9c836518e 100644 --- a/pkgs/development/mobile/webos/novacomd.nix +++ b/pkgs/development/mobile/webos/novacomd.nix @@ -1,8 +1,14 @@ -{ lib, stdenv, -fetchFromGitHub, fetchpatch, -webos, cmake, pkg-config, -nixosTests, -libusb-compat-0_1 }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + webos, + cmake, + pkg-config, + nixosTests, + libusb-compat-0_1, +}: stdenv.mkDerivation rec { pname = "novacomd"; @@ -26,7 +32,11 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ cmake pkg-config webos.cmake-modules ]; + nativeBuildInputs = [ + cmake + pkg-config + webos.cmake-modules + ]; buildInputs = [ libusb-compat-0_1 ]; diff --git a/pkgs/development/mobile/xcodeenv/build-app.nix b/pkgs/development/mobile/xcodeenv/build-app.nix index 2d9a295b86abf0..d77c8c85eac1fe 100644 --- a/pkgs/development/mobile/xcodeenv/build-app.nix +++ b/pkgs/development/mobile/xcodeenv/build-app.nix @@ -1,28 +1,40 @@ -{stdenv, lib, composeXcodeWrapper}: -{ name -, src -, sdkVersion ? "13.1" -, target ? null -, configuration ? null -, scheme ? null -, sdk ? null -, xcodeFlags ? "" -, release ? false -, certificateFile ? null -, certificatePassword ? null -, provisioningProfile ? null -, codeSignIdentity ? null -, signMethod ? null -, generateIPA ? false -, generateXCArchive ? false -, enableWirelessDistribution ? false -, installURL ? null -, bundleId ? null -, appVersion ? null -, ... +{ + stdenv, + lib, + composeXcodeWrapper, +}: +{ + name, + src, + sdkVersion ? "13.1", + target ? null, + configuration ? null, + scheme ? null, + sdk ? null, + xcodeFlags ? "", + release ? false, + certificateFile ? null, + certificatePassword ? null, + provisioningProfile ? null, + codeSignIdentity ? null, + signMethod ? null, + generateIPA ? false, + generateXCArchive ? false, + enableWirelessDistribution ? false, + installURL ? null, + bundleId ? null, + appVersion ? null, + ... }@args: -assert release -> certificateFile != null && certificatePassword != null && provisioningProfile != null && signMethod != null && codeSignIdentity != null; +assert + release + -> + certificateFile != null + && certificatePassword != null + && provisioningProfile != null + && signMethod != null + && codeSignIdentity != null; assert enableWirelessDistribution -> installURL != null && bundleId != null && appVersion != null; let @@ -30,15 +42,14 @@ let _target = if target == null then name else target; - _configuration = if configuration == null - then - if release then "Release" else "Debug" - else configuration; + _configuration = + if configuration == null then if release then "Release" else "Debug" else configuration; - _sdk = if sdk == null - then + _sdk = + if sdk == null then if release then "iphoneos" + sdkVersion else "iphonesimulator" + sdkVersion - else sdk; + else + sdk; # The following is to prevent repetition deleteKeychain = '' @@ -50,101 +61,126 @@ let xcodewrapperArgs = builtins.intersectAttrs xcodewrapperFormalArgs args; xcodewrapper = composeXcodeWrapper xcodewrapperArgs; - extraArgs = removeAttrs args ([ "name" "scheme" "xcodeFlags" "release" "certificateFile" "certificatePassword" "provisioningProfile" "signMethod" "generateIPA" "generateXCArchive" "enableWirelessDistribution" "installURL" "bundleId" "version" ] ++ builtins.attrNames xcodewrapperFormalArgs); + extraArgs = removeAttrs args ( + [ + "name" + "scheme" + "xcodeFlags" + "release" + "certificateFile" + "certificatePassword" + "provisioningProfile" + "signMethod" + "generateIPA" + "generateXCArchive" + "enableWirelessDistribution" + "installURL" + "bundleId" + "version" + ] + ++ builtins.attrNames xcodewrapperFormalArgs + ); in -stdenv.mkDerivation ({ - name = lib.replaceStrings [" "] [""] name; # iOS app names can contain spaces, but in the Nix store this is not allowed - buildPhase = '' - # Be sure that the Xcode wrapper has priority over everything else. - # When using buildInputs this does not seem to be the case. - export PATH=${xcodewrapper}/bin:$PATH - - ${lib.optionalString release '' - export HOME=/Users/$(whoami) - keychainName="$(basename $out)" - - # Create a keychain - security create-keychain -p "" $keychainName - security default-keychain -s $keychainName - security unlock-keychain -p "" $keychainName - - # Import the certificate into the keychain - security import ${certificateFile} -k $keychainName -P "${certificatePassword}" -A - - # Grant the codesign utility permissions to read from the keychain - security set-key-partition-list -S apple-tool:,apple: -s -k "" $keychainName - - # Determine provisioning ID - PROVISIONING_PROFILE=$(grep UUID -A1 -a ${provisioningProfile} | grep -o "[-A-Za-z0-9]\{36\}") - - if [ ! -f "$HOME/Library/MobileDevice/Provisioning Profiles/$PROVISIONING_PROFILE.mobileprovision" ] - then - # Copy provisioning profile into the home directory - mkdir -p "$HOME/Library/MobileDevice/Provisioning Profiles" - cp ${provisioningProfile} "$HOME/Library/MobileDevice/Provisioning Profiles/$PROVISIONING_PROFILE.mobileprovision" - fi - - # Check whether the identity can be found - security find-identity -p codesigning $keychainName - ''} - - # Do the building - export LD=/usr/bin/clang # To avoid problem with -isysroot parameter that is unrecognized by the stock ld. Comparison with an impure build shows that it uses clang instead. Ugly, but it works - - xcodebuild -target ${_target} -configuration ${_configuration} ${lib.optionalString (scheme != null) "-scheme ${scheme}"} -sdk ${_sdk} TARGETED_DEVICE_FAMILY="1, 2" ONLY_ACTIVE_ARCH=NO CONFIGURATION_TEMP_DIR=$TMPDIR CONFIGURATION_BUILD_DIR=$out ${lib.optionalString (generateIPA || generateXCArchive) "-archivePath \"${name}.xcarchive\" archive"} ${lib.optionalString release ''PROVISIONING_PROFILE=$PROVISIONING_PROFILE OTHER_CODE_SIGN_FLAGS="--keychain $HOME/Library/Keychains/$keychainName-db"''} ${xcodeFlags} - - ${lib.optionalString release '' - ${lib.optionalString generateIPA '' - # Create export plist file - cat > "${name}.plist" < - - - - signingCertificate - ${codeSignIdentity} - provisioningProfiles - - ${bundleId} - $PROVISIONING_PROFILE - - signingStyle - manual - method - ${signMethod} - ${lib.optionalString (signMethod == "enterprise" || signMethod == "ad-hoc") '' - compileBitcode - - ''} - - - EOF - - # Produce an IPA file - xcodebuild -exportArchive -archivePath "${name}.xcarchive" -exportOptionsPlist "${name}.plist" -exportPath $out - - # Add IPA to Hydra build products - mkdir -p $out/nix-support - echo "file binary-dist \"$(echo $out/*.ipa)\"" > $out/nix-support/hydra-build-products - - ${lib.optionalString enableWirelessDistribution '' - # Add another hacky build product that enables wireless adhoc installations - appname="$(basename "$(echo $out/*.ipa)" .ipa)" - sed -e "s|@INSTALL_URL@|${installURL}?bundleId=${bundleId}\&version=${appVersion}\&title=$appname|" ${./install.html.template} > $out/''${appname}.html - echo "doc install \"$out/''${appname}.html\"" >> $out/nix-support/hydra-build-products - ''} - ''} - ${lib.optionalString generateXCArchive '' - mkdir -p $out - mv "${name}.xcarchive" $out +stdenv.mkDerivation ( + { + name = lib.replaceStrings [ " " ] [ "" ] name; # iOS app names can contain spaces, but in the Nix store this is not allowed + buildPhase = '' + # Be sure that the Xcode wrapper has priority over everything else. + # When using buildInputs this does not seem to be the case. + export PATH=${xcodewrapper}/bin:$PATH + + ${lib.optionalString release '' + export HOME=/Users/$(whoami) + keychainName="$(basename $out)" + + # Create a keychain + security create-keychain -p "" $keychainName + security default-keychain -s $keychainName + security unlock-keychain -p "" $keychainName + + # Import the certificate into the keychain + security import ${certificateFile} -k $keychainName -P "${certificatePassword}" -A + + # Grant the codesign utility permissions to read from the keychain + security set-key-partition-list -S apple-tool:,apple: -s -k "" $keychainName + + # Determine provisioning ID + PROVISIONING_PROFILE=$(grep UUID -A1 -a ${provisioningProfile} | grep -o "[-A-Za-z0-9]\{36\}") + + if [ ! -f "$HOME/Library/MobileDevice/Provisioning Profiles/$PROVISIONING_PROFILE.mobileprovision" ] + then + # Copy provisioning profile into the home directory + mkdir -p "$HOME/Library/MobileDevice/Provisioning Profiles" + cp ${provisioningProfile} "$HOME/Library/MobileDevice/Provisioning Profiles/$PROVISIONING_PROFILE.mobileprovision" + fi + + # Check whether the identity can be found + security find-identity -p codesigning $keychainName ''} - # Delete our temp keychain - ${deleteKeychain} - ''} - ''; + # Do the building + export LD=/usr/bin/clang # To avoid problem with -isysroot parameter that is unrecognized by the stock ld. Comparison with an impure build shows that it uses clang instead. Ugly, but it works + + xcodebuild -target ${_target} -configuration ${_configuration} ${ + lib.optionalString (scheme != null) "-scheme ${scheme}" + } -sdk ${_sdk} TARGETED_DEVICE_FAMILY="1, 2" ONLY_ACTIVE_ARCH=NO CONFIGURATION_TEMP_DIR=$TMPDIR CONFIGURATION_BUILD_DIR=$out ${ + lib.optionalString (generateIPA || generateXCArchive) "-archivePath \"${name}.xcarchive\" archive" + } ${lib.optionalString release ''PROVISIONING_PROFILE=$PROVISIONING_PROFILE OTHER_CODE_SIGN_FLAGS="--keychain $HOME/Library/Keychains/$keychainName-db"''} ${xcodeFlags} + + ${lib.optionalString release '' + ${lib.optionalString generateIPA '' + # Create export plist file + cat > "${name}.plist" < + + + + signingCertificate + ${codeSignIdentity} + provisioningProfiles + + ${bundleId} + $PROVISIONING_PROFILE + + signingStyle + manual + method + ${signMethod} + ${lib.optionalString (signMethod == "enterprise" || signMethod == "ad-hoc") '' + compileBitcode + + ''} + + + EOF + + # Produce an IPA file + xcodebuild -exportArchive -archivePath "${name}.xcarchive" -exportOptionsPlist "${name}.plist" -exportPath $out + + # Add IPA to Hydra build products + mkdir -p $out/nix-support + echo "file binary-dist \"$(echo $out/*.ipa)\"" > $out/nix-support/hydra-build-products + + ${lib.optionalString enableWirelessDistribution '' + # Add another hacky build product that enables wireless adhoc installations + appname="$(basename "$(echo $out/*.ipa)" .ipa)" + sed -e "s|@INSTALL_URL@|${installURL}?bundleId=${bundleId}\&version=${appVersion}\&title=$appname|" ${./install.html.template} > $out/''${appname}.html + echo "doc install \"$out/''${appname}.html\"" >> $out/nix-support/hydra-build-products + ''} + ''} + ${lib.optionalString generateXCArchive '' + mkdir -p $out + mv "${name}.xcarchive" $out + ''} + + # Delete our temp keychain + ${deleteKeychain} + ''} + ''; - failureHook = lib.optionalString release deleteKeychain; + failureHook = lib.optionalString release deleteKeychain; - installPhase = "true"; -} // extraArgs) + installPhase = "true"; + } + // extraArgs +) diff --git a/pkgs/development/mobile/xcodeenv/compose-xcodewrapper.nix b/pkgs/development/mobile/xcodeenv/compose-xcodewrapper.nix index 13c8e6e8182791..c84d9bbefe0567 100644 --- a/pkgs/development/mobile/xcodeenv/compose-xcodewrapper.nix +++ b/pkgs/development/mobile/xcodeenv/compose-xcodewrapper.nix @@ -1,7 +1,12 @@ -{ lib, +{ + lib, stdenv, - writeShellScriptBin }: -{ versions ? [ ] , xcodeBaseDir ? "/Applications/Xcode.app" }: + writeShellScriptBin, +}: +{ + versions ? [ ], + xcodeBaseDir ? "/Applications/Xcode.app", +}: assert stdenv.hostPlatform.isDarwin; let @@ -31,11 +36,16 @@ stdenv.mkDerivation { buildCommand = '' mkdir -p $out/bin cd $out/bin - ${if versions == [ ] then '' - ln -s "${xcodebuildPath}" - '' else '' - ln -s "${xcodebuildWrapper}/bin/xcode-select" - ''} + ${ + if versions == [ ] then + '' + ln -s "${xcodebuildPath}" + '' + else + '' + ln -s "${xcodebuildWrapper}/bin/xcode-select" + '' + } ln -s /usr/bin/security ln -s /usr/bin/codesign ln -s /usr/bin/xcrun diff --git a/pkgs/development/mobile/xcodeenv/simulate-app.nix b/pkgs/development/mobile/xcodeenv/simulate-app.nix index ca6806d43b9981..d90bad38dfaad8 100644 --- a/pkgs/development/mobile/xcodeenv/simulate-app.nix +++ b/pkgs/development/mobile/xcodeenv/simulate-app.nix @@ -1,5 +1,14 @@ -{stdenv, lib, composeXcodeWrapper}: -{name, app ? null, bundleId ? null, ...}@args: +{ + stdenv, + lib, + composeXcodeWrapper, +}: +{ + name, + app ? null, + bundleId ? null, + ... +}@args: assert app != null -> bundleId != null; @@ -9,7 +18,7 @@ let xcodewrapper = composeXcodeWrapper xcodewrapperArgs; in stdenv.mkDerivation { - name = lib.replaceStrings [" "] [""] name; + name = lib.replaceStrings [ " " ] [ "" ] name; buildCommand = '' mkdir -p $out/bin cat > $out/bin/run-test-simulator << "EOF" diff --git a/pkgs/development/node-packages/composition.nix b/pkgs/development/node-packages/composition.nix index 4bd736ddc723cd..48d7c07ad193e2 100644 --- a/pkgs/development/node-packages/composition.nix +++ b/pkgs/development/node-packages/composition.nix @@ -1,17 +1,34 @@ # This file has been generated by node2nix 1.11.1. Do not edit! -{pkgs ? import { +{ + pkgs ? import { inherit system; - }, system ? builtins.currentSystem, nodejs ? pkgs."nodejs_18"}: + }, + system ? builtins.currentSystem, + nodejs ? pkgs."nodejs_18", +}: let nodeEnv = import ./node-env.nix { - inherit (pkgs) stdenv lib python2 runCommand writeTextFile writeShellScript; + inherit (pkgs) + stdenv + lib + python2 + runCommand + writeTextFile + writeShellScript + ; inherit pkgs nodejs; libtool = if pkgs.stdenv.hostPlatform.isDarwin then pkgs.cctools or pkgs.darwin.cctools else null; }; in import ./node-packages.nix { - inherit (pkgs) fetchurl nix-gitignore stdenv lib fetchgit; + inherit (pkgs) + fetchurl + nix-gitignore + stdenv + lib + fetchgit + ; inherit nodeEnv; } diff --git a/pkgs/development/node-packages/default.nix b/pkgs/development/node-packages/default.nix index 506dc8a525caa7..4257770dc02d2d 100644 --- a/pkgs/development/node-packages/default.nix +++ b/pkgs/development/node-packages/default.nix @@ -1,23 +1,39 @@ -{ config, pkgs, lib, nodejs, stdenv }: +{ + config, + pkgs, + lib, + nodejs, + stdenv, +}: let - inherit (lib) composeManyExtensions extends makeExtensible mapAttrs; + inherit (lib) + composeManyExtensions + extends + makeExtensible + mapAttrs + ; - nodePackages = final: import ./composition.nix { - inherit pkgs nodejs; - inherit (stdenv.hostPlatform) system; - }; + nodePackages = + final: + import ./composition.nix { + inherit pkgs nodejs; + inherit (stdenv.hostPlatform) system; + }; - mainProgramOverrides = final: prev: - mapAttrs (pkgName: mainProgram: + mainProgramOverrides = + final: prev: + mapAttrs ( + pkgName: mainProgram: prev.${pkgName}.override (oldAttrs: { - meta = oldAttrs.meta // { inherit mainProgram; }; + meta = oldAttrs.meta // { + inherit mainProgram; + }; }) ) (import ./main-programs.nix); - aliases = final: prev: - lib.optionalAttrs config.allowAliases - (import ./aliases.nix pkgs lib final prev); + aliases = + final: prev: lib.optionalAttrs config.allowAliases (import ./aliases.nix pkgs lib final prev); extensions = composeManyExtensions [ aliases @@ -25,4 +41,4 @@ let (import ./overrides.nix { inherit pkgs nodejs; }) ]; in - makeExtensible (extends extensions nodePackages) +makeExtensible (extends extensions nodePackages) diff --git a/pkgs/development/node-packages/package-tests/postcss-cli.nix b/pkgs/development/node-packages/package-tests/postcss-cli.nix index 521509e7f43b74..6c5847ed135290 100644 --- a/pkgs/development/node-packages/package-tests/postcss-cli.nix +++ b/pkgs/development/node-packages/package-tests/postcss-cli.nix @@ -4,42 +4,41 @@ let inherit (postcss-cli) packageName version; in -runCommand "${packageName}-tests" { meta.timeout = 60; } - '' - # get version of installed program and compare with package version - claimed_version="$(${postcss-cli}/bin/postcss --version)" - if [[ "$claimed_version" != "${version}" ]]; then - echo "Error: program version does not match package version ($claimed_version != ${version})" - exit 1 - fi +runCommand "${packageName}-tests" { meta.timeout = 60; } '' + # get version of installed program and compare with package version + claimed_version="$(${postcss-cli}/bin/postcss --version)" + if [[ "$claimed_version" != "${version}" ]]; then + echo "Error: program version does not match package version ($claimed_version != ${version})" + exit 1 + fi - # run basic help command - ${postcss-cli}/bin/postcss --help > /dev/null + # run basic help command + ${postcss-cli}/bin/postcss --help > /dev/null - # basic autoprefixer test - config_dir="$(mktemp -d)" - clean_up() { - rm -rf "$config_dir" + # basic autoprefixer test + config_dir="$(mktemp -d)" + clean_up() { + rm -rf "$config_dir" + } + trap clean_up EXIT + echo " + module.exports = { + plugins: { + 'autoprefixer': { overrideBrowserslist: 'chrome 40' }, + }, } - trap clean_up EXIT - echo " - module.exports = { - plugins: { - 'autoprefixer': { overrideBrowserslist: 'chrome 40' }, - }, - } - " > "$config_dir/postcss.config.js" - input='a{ user-select: none; }' - expected_output='a{ -webkit-user-select: none; user-select: none; }' - actual_output="$(echo $input | ${postcss-cli}/bin/postcss --no-map --config $config_dir)" - if [[ "$actual_output" != "$expected_output" ]]; then - echo "Error: autoprefixer did not output the correct CSS:" - echo "$actual_output" - echo "!=" - echo "$expected_output" - exit 1 - fi + " > "$config_dir/postcss.config.js" + input='a{ user-select: none; }' + expected_output='a{ -webkit-user-select: none; user-select: none; }' + actual_output="$(echo $input | ${postcss-cli}/bin/postcss --no-map --config $config_dir)" + if [[ "$actual_output" != "$expected_output" ]]; then + echo "Error: autoprefixer did not output the correct CSS:" + echo "$actual_output" + echo "!=" + echo "$expected_output" + exit 1 + fi - # needed for Nix to register the command as successful - touch $out - '' + # needed for Nix to register the command as successful + touch $out +'' diff --git a/pkgs/development/node-packages/package-tests/tailwindcss.nix b/pkgs/development/node-packages/package-tests/tailwindcss.nix index 1f986d8bb09664..53930735af4bbc 100644 --- a/pkgs/development/node-packages/package-tests/tailwindcss.nix +++ b/pkgs/development/node-packages/package-tests/tailwindcss.nix @@ -1,4 +1,8 @@ -{ runCommand, tailwindcss, nodePackages }: +{ + runCommand, + tailwindcss, + nodePackages, +}: let @@ -27,21 +31,20 @@ let in -runCommand "${packageName}-tests" { meta.timeout = 60; } - '' - mkdir $out +runCommand "${packageName}-tests" { meta.timeout = 60; } '' + mkdir $out - # Ensure CLI runs - ${tailwindcss}/bin/tailwind --help > /dev/null - ${tailwindcss}/bin/tailwindcss --help > /dev/null + # Ensure CLI runs + ${tailwindcss}/bin/tailwind --help > /dev/null + ${tailwindcss}/bin/tailwindcss --help > /dev/null - # Ensure CLI with plugins runs - echo '"ml-4 prose"' > ./with-typography.input - ${tailwindcssWithPlugins}/bin/tailwind \ - --config ${tailwindcssWithPluginsConfig} \ - --input ${tailwindcssInput} \ - --output $out/with-typography.css + # Ensure CLI with plugins runs + echo '"ml-4 prose"' > ./with-typography.input + ${tailwindcssWithPlugins}/bin/tailwind \ + --config ${tailwindcssWithPluginsConfig} \ + --input ${tailwindcssInput} \ + --output $out/with-typography.css - grep -q ml-4 $out/with-typography.css - grep -q prose $out/with-typography.css - '' + grep -q ml-4 $out/with-typography.css + grep -q prose $out/with-typography.css +'' diff --git a/pkgs/development/node-packages/package-tests/vega-lite.nix b/pkgs/development/node-packages/package-tests/vega-lite.nix index 5be356f0683fba..6326053ef0a983 100644 --- a/pkgs/development/node-packages/package-tests/vega-lite.nix +++ b/pkgs/development/node-packages/package-tests/vega-lite.nix @@ -4,21 +4,20 @@ let inherit (vega-lite) packageName version; in -runCommand "${packageName}-tests" { meta.timeout = 60; } - '' - # get version of installed program and compare with package version - claimed_version="$(${vega-lite}/bin/vl2vg --version)" - if [[ "$claimed_version" != "${version}" ]]; then - echo "Error: program version does not match package version ($claimed_version != ${version})" - exit 1 - fi +runCommand "${packageName}-tests" { meta.timeout = 60; } '' + # get version of installed program and compare with package version + claimed_version="$(${vega-lite}/bin/vl2vg --version)" + if [[ "$claimed_version" != "${version}" ]]; then + echo "Error: program version does not match package version ($claimed_version != ${version})" + exit 1 + fi - # run dummy commands - ${vega-lite}/bin/vl2vg --help > /dev/null - ${vega-lite}/bin/vl2svg --help > /dev/null - ${vega-lite}/bin/vl2png --help > /dev/null - ${vega-lite}/bin/vl2pdf --help > /dev/null + # run dummy commands + ${vega-lite}/bin/vl2vg --help > /dev/null + ${vega-lite}/bin/vl2svg --help > /dev/null + ${vega-lite}/bin/vl2png --help > /dev/null + ${vega-lite}/bin/vl2pdf --help > /dev/null - # needed for Nix to register the command as successful - touch $out - '' + # needed for Nix to register the command as successful + touch $out +'' diff --git a/pkgs/development/ocaml-modules/aches/default.nix b/pkgs/development/ocaml-modules/aches/default.nix index c590ecc04bdc87..63f814baf6c2dd 100644 --- a/pkgs/development/ocaml-modules/aches/default.nix +++ b/pkgs/development/ocaml-modules/aches/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, ringo }: +{ + lib, + buildDunePackage, + ringo, +}: buildDunePackage { pname = "aches"; diff --git a/pkgs/development/ocaml-modules/aches/lwt.nix b/pkgs/development/ocaml-modules/aches/lwt.nix index bfb57a5a91aa9d..e0bc45820ba6e9 100644 --- a/pkgs/development/ocaml-modules/aches/lwt.nix +++ b/pkgs/development/ocaml-modules/aches/lwt.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, ringo, aches, lwt }: +{ + lib, + buildDunePackage, + ringo, + aches, + lwt, +}: buildDunePackage { pname = "aches-lwt"; diff --git a/pkgs/development/ocaml-modules/afl-persistent/default.nix b/pkgs/development/ocaml-modules/afl-persistent/default.nix index 04d31c881561c3..e1b1c375b332cd 100644 --- a/pkgs/development/ocaml-modules/afl-persistent/default.nix +++ b/pkgs/development/ocaml-modules/afl-persistent/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, findlib, opaline }: +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, + opaline, +}: stdenv.mkDerivation rec { pname = "afl-persistent"; @@ -6,15 +13,18 @@ stdenv.mkDerivation rec { name = "ocaml${ocaml.version}-${pname}-${version}"; src = fetchFromGitHub { - owner = "stedolan"; - repo = "ocaml-${pname}"; - rev = "v${version}"; + owner = "stedolan"; + repo = "ocaml-${pname}"; + rev = "v${version}"; sha256 = "06yyds2vcwlfr2nd3gvyrazlijjcrd1abnvkfpkaadgwdw3qam1i"; }; strictDeps = true; - nativeBuildInputs = [ ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; # don't run tests in buildPhase # don't overwrite test binary diff --git a/pkgs/development/ocaml-modules/alcotest/default.nix b/pkgs/development/ocaml-modules/alcotest/default.nix index c921509907b94d..dddf79fa741ed2 100644 --- a/pkgs/development/ocaml-modules/alcotest/default.nix +++ b/pkgs/development/ocaml-modules/alcotest/default.nix @@ -1,5 +1,14 @@ -{ lib, buildDunePackage, fetchurl -, astring, cmdliner, fmt, re, stdlib-shims, uutf, ocaml-syntax-shims +{ + lib, + buildDunePackage, + fetchurl, + astring, + cmdliner, + fmt, + re, + stdlib-shims, + uutf, + ocaml-syntax-shims, }: buildDunePackage rec { @@ -13,7 +22,14 @@ buildDunePackage rec { nativeBuildInputs = [ ocaml-syntax-shims ]; - propagatedBuildInputs = [ astring cmdliner fmt re stdlib-shims uutf ]; + propagatedBuildInputs = [ + astring + cmdliner + fmt + re + stdlib-shims + uutf + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/alcotest/lwt.nix b/pkgs/development/ocaml-modules/alcotest/lwt.nix index 44fb987c477937..692d7e36c499f0 100644 --- a/pkgs/development/ocaml-modules/alcotest/lwt.nix +++ b/pkgs/development/ocaml-modules/alcotest/lwt.nix @@ -1,5 +1,11 @@ -{ buildDunePackage, alcotest, logs, lwt, fmt -, re, cmdliner +{ + buildDunePackage, + alcotest, + logs, + lwt, + fmt, + re, + cmdliner, }: buildDunePackage { @@ -9,10 +15,18 @@ buildDunePackage { duneVersion = "3"; - propagatedBuildInputs = [ alcotest logs lwt fmt ]; + propagatedBuildInputs = [ + alcotest + logs + lwt + fmt + ]; doCheck = true; - checkInputs = [ re cmdliner ]; + checkInputs = [ + re + cmdliner + ]; meta = alcotest.meta // { description = "Lwt-based helpers for Alcotest"; diff --git a/pkgs/development/ocaml-modules/alcotest/mirage.nix b/pkgs/development/ocaml-modules/alcotest/mirage.nix index e27889b40462ae..76e202d20c4fab 100644 --- a/pkgs/development/ocaml-modules/alcotest/mirage.nix +++ b/pkgs/development/ocaml-modules/alcotest/mirage.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, alcotest, lwt, logs, mirage-clock, duration }: +{ + lib, + buildDunePackage, + alcotest, + lwt, + logs, + mirage-clock, + duration, +}: buildDunePackage { pname = "alcotest-mirage"; @@ -7,12 +15,21 @@ buildDunePackage { duneVersion = "3"; - propagatedBuildInputs = [ alcotest lwt logs mirage-clock duration ]; + propagatedBuildInputs = [ + alcotest + lwt + logs + mirage-clock + duration + ]; doCheck = true; meta = alcotest.meta // { description = "Mirage implementation for Alcotest"; - maintainers = with lib.maintainers; [ ulrikstrid anmonteiro ]; + maintainers = with lib.maintainers; [ + ulrikstrid + anmonteiro + ]; }; } diff --git a/pkgs/development/ocaml-modules/algaeff/default.nix b/pkgs/development/ocaml-modules/algaeff/default.nix index b8c6a5f0cfd4b1..0e867f8a0838d2 100644 --- a/pkgs/development/ocaml-modules/algaeff/default.nix +++ b/pkgs/development/ocaml-modules/algaeff/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildDunePackage -, fetchFromGitHub -, alcotest -, qcheck-core +{ + lib, + buildDunePackage, + fetchFromGitHub, + alcotest, + qcheck-core, }: buildDunePackage rec { @@ -19,7 +20,10 @@ buildDunePackage rec { }; doCheck = true; - checkInputs = [ alcotest qcheck-core ]; + checkInputs = [ + alcotest + qcheck-core + ]; meta = { description = "Reusable Effects-Based Components"; diff --git a/pkgs/development/ocaml-modules/alsa/default.nix b/pkgs/development/ocaml-modules/alsa/default.nix index 988ca8280dccae..15b60d2882218f 100644 --- a/pkgs/development/ocaml-modules/alsa/default.nix +++ b/pkgs/development/ocaml-modules/alsa/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, alsa-lib }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + alsa-lib, +}: buildDunePackage rec { pname = "alsa"; diff --git a/pkgs/development/ocaml-modules/angstrom-async/default.nix b/pkgs/development/ocaml-modules/angstrom-async/default.nix index 92dd90ff22cbe7..3b1a8663148b20 100644 --- a/pkgs/development/ocaml-modules/angstrom-async/default.nix +++ b/pkgs/development/ocaml-modules/angstrom-async/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, angstrom, async }: +{ + lib, + buildDunePackage, + angstrom, + async, +}: buildDunePackage rec { pname = "angstrom-async"; @@ -7,7 +12,10 @@ buildDunePackage rec { minimalOCamlVersion = "4.04.1"; - propagatedBuildInputs = [ angstrom async ]; + propagatedBuildInputs = [ + angstrom + async + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/angstrom-lwt-unix/default.nix b/pkgs/development/ocaml-modules/angstrom-lwt-unix/default.nix index 2867e4b1a813fe..be3a83cca34ebc 100644 --- a/pkgs/development/ocaml-modules/angstrom-lwt-unix/default.nix +++ b/pkgs/development/ocaml-modules/angstrom-lwt-unix/default.nix @@ -1,11 +1,19 @@ -{ lib, buildDunePackage, angstrom, lwt }: +{ + lib, + buildDunePackage, + angstrom, + lwt, +}: buildDunePackage rec { pname = "angstrom-lwt-unix"; inherit (angstrom) version src; - propagatedBuildInputs = [ angstrom lwt ]; + propagatedBuildInputs = [ + angstrom + lwt + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/angstrom-unix/default.nix b/pkgs/development/ocaml-modules/angstrom-unix/default.nix index be341454631713..6f6664765f92a9 100644 --- a/pkgs/development/ocaml-modules/angstrom-unix/default.nix +++ b/pkgs/development/ocaml-modules/angstrom-unix/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, angstrom }: +{ + lib, + buildDunePackage, + angstrom, +}: buildDunePackage rec { pname = "angstrom-unix"; diff --git a/pkgs/development/ocaml-modules/angstrom/default.nix b/pkgs/development/ocaml-modules/angstrom/default.nix index 4c6ed4064ef649..423267fb2b1bdb 100644 --- a/pkgs/development/ocaml-modules/angstrom/default.nix +++ b/pkgs/development/ocaml-modules/angstrom/default.nix @@ -1,4 +1,14 @@ -{ lib, fetchFromGitHub, buildDunePackage, ocaml, ocaml-syntax-shims, alcotest, bigstringaf, ppx_let, gitUpdater }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + ocaml, + ocaml-syntax-shims, + alcotest, + bigstringaf, + ppx_let, + gitUpdater, +}: buildDunePackage rec { pname = "angstrom"; @@ -7,13 +17,16 @@ buildDunePackage rec { minimalOCamlVersion = "4.04"; src = fetchFromGitHub { - owner = "inhabitedtype"; - repo = pname; - rev = version; + owner = "inhabitedtype"; + repo = pname; + rev = version; hash = "sha256-EPqDK+7RU2vHEHvuoTXb8V2FkdXQ6tGu0ghbNPS3gZ4="; }; - checkInputs = [ alcotest ppx_let ]; + checkInputs = [ + alcotest + ppx_let + ]; buildInputs = [ ocaml-syntax-shims ]; propagatedBuildInputs = [ bigstringaf ]; doCheck = lib.versionAtLeast ocaml.version "4.08"; diff --git a/pkgs/development/ocaml-modules/ansiterminal/default.nix b/pkgs/development/ocaml-modules/ansiterminal/default.nix index 7530e45ac853e4..d8ad58b6c45dcc 100644 --- a/pkgs/development/ocaml-modules/ansiterminal/default.nix +++ b/pkgs/development/ocaml-modules/ansiterminal/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "ANSITerminal"; diff --git a/pkgs/development/ocaml-modules/ao/default.nix b/pkgs/development/ocaml-modules/ao/default.nix index 6abc7f98f63974..06d96fddeb8208 100644 --- a/pkgs/development/ocaml-modules/ao/default.nix +++ b/pkgs/development/ocaml-modules/ao/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, libao }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + libao, +}: buildDunePackage rec { pname = "ao"; diff --git a/pkgs/development/ocaml-modules/apron/default.nix b/pkgs/development/ocaml-modules/apron/default.nix index 7b993168e16791..f1206bab6ffbd2 100644 --- a/pkgs/development/ocaml-modules/apron/default.nix +++ b/pkgs/development/ocaml-modules/apron/default.nix @@ -1,5 +1,17 @@ -{ stdenv, lib, fetchFromGitHub, perl, gmp, mpfr, ppl, ocaml, findlib, camlidl, mlgmpidl -, flint, pplite +{ + stdenv, + lib, + fetchFromGitHub, + perl, + gmp, + mpfr, + ppl, + ocaml, + findlib, + camlidl, + mlgmpidl, + flint, + pplite, }: stdenv.mkDerivation rec { @@ -12,11 +24,25 @@ stdenv.mkDerivation rec { hash = "sha256-gHLCurydxX1pS66DTAWUJGl9Yqu9RWRjkZh6lXzM7YY="; }; - nativeBuildInputs = [ ocaml findlib perl ]; - buildInputs = [ gmp mpfr ppl camlidl flint pplite ]; + nativeBuildInputs = [ + ocaml + findlib + perl + ]; + buildInputs = [ + gmp + mpfr + ppl + camlidl + flint + pplite + ]; propagatedBuildInputs = [ mlgmpidl ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; configurePhase = '' runHook preConfigure diff --git a/pkgs/development/ocaml-modules/arp/default.nix b/pkgs/development/ocaml-modules/arp/default.nix index b8cc579e5661c2..af1f2380a28b3f 100644 --- a/pkgs/development/ocaml-modules/arp/default.nix +++ b/pkgs/development/ocaml-modules/arp/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, buildDunePackage -, fetchurl -, cstruct -, duration -, ethernet -, ipaddr -, logs -, lwt -, macaddr -, mirage-time -, alcotest -, mirage-clock-unix -, mirage-flow -, mirage-random -, mirage-random-test -, mirage-time-unix -, mirage-vnetif -, bisect_ppx +{ + lib, + stdenv, + buildDunePackage, + fetchurl, + cstruct, + duration, + ethernet, + ipaddr, + logs, + lwt, + macaddr, + mirage-time, + alcotest, + mirage-clock-unix, + mirage-flow, + mirage-random, + mirage-random-test, + mirage-time-unix, + mirage-vnetif, + bisect_ppx, }: buildDunePackage rec { @@ -47,7 +48,7 @@ buildDunePackage rec { ]; ## NOTE: As of 18 april 2023 and ARP version 3.0.0, tests fail on Darwin. - doCheck = ! stdenv.hostPlatform.isDarwin; + doCheck = !stdenv.hostPlatform.isDarwin; checkInputs = [ alcotest mirage-clock-unix diff --git a/pkgs/development/ocaml-modules/asai/default.nix b/pkgs/development/ocaml-modules/asai/default.nix index 5555194048ceb0..2f58276684ab82 100644 --- a/pkgs/development/ocaml-modules/asai/default.nix +++ b/pkgs/development/ocaml-modules/asai/default.nix @@ -1,6 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage -, algaeff -, bwd +{ + lib, + fetchFromGitHub, + buildDunePackage, + algaeff, + bwd, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/asetmap/default.nix b/pkgs/development/ocaml-modules/asetmap/default.nix index 40152ef5cbf423..11cecd66cc9dec 100644 --- a/pkgs/development/ocaml-modules/asetmap/default.nix +++ b/pkgs/development/ocaml-modules/asetmap/default.nix @@ -1,9 +1,10 @@ -{ fetchurl -, buildDunePackage -, topkg -, findlib -, ocamlbuild -, ocaml +{ + fetchurl, + buildDunePackage, + topkg, + findlib, + ocamlbuild, + ocaml, }: buildDunePackage rec { @@ -16,7 +17,12 @@ buildDunePackage rec { strictDeps = true; - nativeBuildInputs = [ topkg findlib ocamlbuild ocaml ]; + nativeBuildInputs = [ + topkg + findlib + ocamlbuild + ocaml + ]; buildInputs = [ topkg ]; inherit (topkg) buildPhase installPhase; diff --git a/pkgs/development/ocaml-modules/asn1-combinators/default.nix b/pkgs/development/ocaml-modules/asn1-combinators/default.nix index 822c4056e2597b..2530312bfeac80 100644 --- a/pkgs/development/ocaml-modules/asn1-combinators/default.nix +++ b/pkgs/development/ocaml-modules/asn1-combinators/default.nix @@ -1,6 +1,9 @@ -{ lib, buildDunePackage, fetchurl -, ptime -, alcotest +{ + lib, + buildDunePackage, + fetchurl, + ptime, + alcotest, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/astring/default.nix b/pkgs/development/ocaml-modules/astring/default.nix index f7478f93b91c01..3f4b19123337ef 100644 --- a/pkgs/development/ocaml-modules/astring/default.nix +++ b/pkgs/development/ocaml-modules/astring/default.nix @@ -1,16 +1,26 @@ -{ stdenv, lib, fetchurl, ocaml, findlib, ocamlbuild, topkg }: +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, +}: let # Use astring 0.8.3 for OCaml < 4.05 param = - if lib.versionAtLeast ocaml.version "4.05" - then { - version = "0.8.5"; - sha256 = "1ykhg9gd3iy7zsgyiy2p9b1wkpqg9irw5pvcqs3sphq71iir4ml6"; - } else { - version = "0.8.3"; - sha256 = "0ixjwc3plrljvj24za3l9gy0w30lsbggp8yh02lwrzw61ls4cri0"; - }; + if lib.versionAtLeast ocaml.version "4.05" then + { + version = "0.8.5"; + sha256 = "1ykhg9gd3iy7zsgyiy2p9b1wkpqg9irw5pvcqs3sphq71iir4ml6"; + } + else + { + version = "0.8.3"; + sha256 = "0ixjwc3plrljvj24za3l9gy0w30lsbggp8yh02lwrzw61ls4cri0"; + }; in stdenv.mkDerivation { @@ -22,7 +32,12 @@ stdenv.mkDerivation { inherit (param) sha256; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; buildInputs = [ topkg ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/atd/default.nix b/pkgs/development/ocaml-modules/atd/default.nix index 16944c7b38bc20..c956c430fc2e7c 100644 --- a/pkgs/development/ocaml-modules/atd/default.nix +++ b/pkgs/development/ocaml-modules/atd/default.nix @@ -1,4 +1,14 @@ -{ lib, atdgen-codec-runtime, cmdliner, menhir, easy-format, buildDunePackage, re, yojson, nixosTests }: +{ + lib, + atdgen-codec-runtime, + cmdliner, + menhir, + easy-format, + buildDunePackage, + re, + yojson, + nixosTests, +}: buildDunePackage rec { pname = "atd"; @@ -8,7 +18,11 @@ buildDunePackage rec { nativeBuildInputs = [ menhir ]; buildInputs = [ cmdliner ]; - propagatedBuildInputs = [ easy-format re yojson ]; + propagatedBuildInputs = [ + easy-format + re + yojson + ]; passthru.tests = { smoke-test = nixosTests.atd; diff --git a/pkgs/development/ocaml-modules/atdgen/codec-runtime.nix b/pkgs/development/ocaml-modules/atdgen/codec-runtime.nix index d2a875080eab4a..494b8bcb35175b 100644 --- a/pkgs/development/ocaml-modules/atdgen/codec-runtime.nix +++ b/pkgs/development/ocaml-modules/atdgen/codec-runtime.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "atdgen-codec-runtime"; diff --git a/pkgs/development/ocaml-modules/atdgen/default.nix b/pkgs/development/ocaml-modules/atdgen/default.nix index 6df0e4822634ba..d36b364c2cd7b1 100644 --- a/pkgs/development/ocaml-modules/atdgen/default.nix +++ b/pkgs/development/ocaml-modules/atdgen/default.nix @@ -1,5 +1,11 @@ -{ buildDunePackage, alcotest, atd, atdgen-codec-runtime, atdgen-runtime, re -, python3 +{ + buildDunePackage, + alcotest, + atd, + atdgen-codec-runtime, + atdgen-runtime, + re, + python3, }: buildDunePackage { @@ -8,13 +14,22 @@ buildDunePackage { duneVersion = "3"; - buildInputs = [ atd re ]; + buildInputs = [ + atd + re + ]; propagatedBuildInputs = [ atdgen-runtime ]; doCheck = true; - nativeCheckInputs = [ atd (python3.withPackages (ps: [ ps.jsonschema ]))]; - checkInputs = [ alcotest atdgen-codec-runtime ]; + nativeCheckInputs = [ + atd + (python3.withPackages (ps: [ ps.jsonschema ])) + ]; + checkInputs = [ + alcotest + atdgen-codec-runtime + ]; meta = (builtins.removeAttrs atd.meta [ "mainProgram" ]) // { description = "Generates efficient JSON serializers, deserializers and validators"; diff --git a/pkgs/development/ocaml-modules/atdgen/runtime.nix b/pkgs/development/ocaml-modules/atdgen/runtime.nix index c70d3752cdef84..f0442d46a30f99 100644 --- a/pkgs/development/ocaml-modules/atdgen/runtime.nix +++ b/pkgs/development/ocaml-modules/atdgen/runtime.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, atdgen-codec-runtime, biniou, yojson }: +{ + buildDunePackage, + atdgen-codec-runtime, + biniou, + yojson, +}: buildDunePackage rec { pname = "atdgen-runtime"; @@ -7,7 +12,10 @@ buildDunePackage rec { minimalOCamlVersion = "4.08"; duneVersion = "3"; - propagatedBuildInputs = [ biniou yojson ]; + propagatedBuildInputs = [ + biniou + yojson + ]; meta = atdgen-codec-runtime.meta // { description = "Runtime library for code generated by atdgen"; diff --git a/pkgs/development/ocaml-modules/awa/default.nix b/pkgs/development/ocaml-modules/awa/default.nix index 02e789de5672e0..41e17d575c57f8 100644 --- a/pkgs/development/ocaml-modules/awa/default.nix +++ b/pkgs/development/ocaml-modules/awa/default.nix @@ -1,8 +1,21 @@ -{ lib, buildDunePackage, fetchurl -, mirage-crypto, mirage-crypto-ec, mirage-crypto-rng, mirage-crypto-pk -, x509, cstruct, cstruct-unix, eqaf -, mtime, logs, fmt, cmdliner, base64 -, zarith +{ + lib, + buildDunePackage, + fetchurl, + mirage-crypto, + mirage-crypto-ec, + mirage-crypto-rng, + mirage-crypto-pk, + x509, + cstruct, + cstruct-unix, + eqaf, + mtime, + logs, + fmt, + cmdliner, + base64, + zarith, }: buildDunePackage rec { @@ -17,14 +30,25 @@ buildDunePackage rec { }; propagatedBuildInputs = [ - mirage-crypto mirage-crypto-ec mirage-crypto-rng mirage-crypto-pk x509 - cstruct mtime - logs base64 zarith + mirage-crypto + mirage-crypto-ec + mirage-crypto-rng + mirage-crypto-pk + x509 + cstruct + mtime + logs + base64 + zarith eqaf ]; doCheck = true; - checkInputs = [ cstruct-unix cmdliner fmt ]; + checkInputs = [ + cstruct-unix + cmdliner + fmt + ]; meta = with lib; { description = "SSH implementation in OCaml"; diff --git a/pkgs/development/ocaml-modules/awa/mirage.nix b/pkgs/development/ocaml-modules/awa/mirage.nix index 8513e574104807..795f421e1c172b 100644 --- a/pkgs/development/ocaml-modules/awa/mirage.nix +++ b/pkgs/development/ocaml-modules/awa/mirage.nix @@ -1,6 +1,14 @@ -{ buildDunePackage, awa -, cstruct, mtime, lwt, mirage-flow, mirage-clock, logs -, duration, mirage-time +{ + buildDunePackage, + awa, + cstruct, + mtime, + lwt, + mirage-flow, + mirage-clock, + logs, + duration, + mirage-time, }: buildDunePackage { @@ -9,8 +17,15 @@ buildDunePackage { inherit (awa) version src; propagatedBuildInputs = [ - awa cstruct mtime lwt mirage-flow mirage-clock logs - duration mirage-time + awa + cstruct + mtime + lwt + mirage-flow + mirage-clock + logs + duration + mirage-time ]; inherit (awa) meta; diff --git a/pkgs/development/ocaml-modules/b0/default.nix b/pkgs/development/ocaml-modules/b0/default.nix index e3c21c31e68961..a6c0bb4327d843 100644 --- a/pkgs/development/ocaml-modules/b0/default.nix +++ b/pkgs/development/ocaml-modules/b0/default.nix @@ -1,46 +1,65 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, topkg, ocamlbuild, cmdliner }: +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + topkg, + ocamlbuild, + cmdliner, +}: let -in lib.throwIfNot (lib.versionAtLeast ocaml.version "4.08") -"b0 is not available for OCaml ${ocaml.version}" - -stdenv.mkDerivation rec { - - pname = "ocaml${ocaml.version}-b0"; - version = "0.0.5"; - - src = fetchurl { - url = "${meta.homepage}/releases/b0-${version}.tbz"; - sha256 = "sha256-ty04JQcP4RCme/VQw0ko2IBebWWX5cBU6nRTTeV1I/I="; - }; - - strictDeps = true; - - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg cmdliner ]; - - inherit (topkg) buildPhase installPhase; - - meta = with lib; { - description = "Software construction and deployment kit"; - longDescription = '' - WARNING this package is unstable and work in progress, do not depend on - it. - B0 describes software construction and deployments using modular and - customizable definitions written in OCaml. B0 describes: - * Build environments. - * Software configuration, build and testing. - * Source and binary deployments. - * Software life-cycle procedures. - B0 also provides the B00 build library which provides abitrary build - abstraction with reliable and efficient incremental rebuilds. The B00 - library can be – and has been – used on its own to devise domain specific - build systems. - ''; - homepage = "https://erratique.ch/software/b0"; - inherit (ocaml.meta) platforms; - license = licenses.isc; - maintainers = [ maintainers.Julow ]; - }; -} +in +lib.throwIfNot (lib.versionAtLeast ocaml.version "4.08") + "b0 is not available for OCaml ${ocaml.version}" + + stdenv.mkDerivation + rec { + + pname = "ocaml${ocaml.version}-b0"; + version = "0.0.5"; + + src = fetchurl { + url = "${meta.homepage}/releases/b0-${version}.tbz"; + sha256 = "sha256-ty04JQcP4RCme/VQw0ko2IBebWWX5cBU6nRTTeV1I/I="; + }; + + strictDeps = true; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ + topkg + cmdliner + ]; + + inherit (topkg) buildPhase installPhase; + + meta = with lib; { + description = "Software construction and deployment kit"; + longDescription = '' + WARNING this package is unstable and work in progress, do not depend on + it. + B0 describes software construction and deployments using modular and + customizable definitions written in OCaml. B0 describes: + * Build environments. + * Software configuration, build and testing. + * Source and binary deployments. + * Software life-cycle procedures. + B0 also provides the B00 build library which provides abitrary build + abstraction with reliable and efficient incremental rebuilds. The B00 + library can be – and has been – used on its own to devise domain specific + build systems. + ''; + homepage = "https://erratique.ch/software/b0"; + inherit (ocaml.meta) platforms; + license = licenses.isc; + maintainers = [ maintainers.Julow ]; + }; + } diff --git a/pkgs/development/ocaml-modules/backoff/default.nix b/pkgs/development/ocaml-modules/backoff/default.nix index 75ee51ede5c7b5..a623ece4d2309e 100644 --- a/pkgs/development/ocaml-modules/backoff/default.nix +++ b/pkgs/development/ocaml-modules/backoff/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchurl, alcotest}: +{ + lib, + buildDunePackage, + fetchurl, + alcotest, +}: buildDunePackage rec { pname = "backoff"; diff --git a/pkgs/development/ocaml-modules/bap/default.nix b/pkgs/development/ocaml-modules/bap/default.nix index bdbf9b65c3c012..067e2bc16adbe3 100644 --- a/pkgs/development/ocaml-modules/bap/default.nix +++ b/pkgs/development/ocaml-modules/bap/default.nix @@ -1,85 +1,150 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl -, ocaml, findlib, ocamlbuild, ocaml_oasis -, bitstring, camlzip, cmdliner, core_kernel, ezjsonm, fileutils, mmap, lwt, ocamlgraph, ocurl, re, uri, zarith, piqi, piqi-ocaml, uuidm, llvm, frontc, ounit, ppx_jane, parsexp -, utop, libxml2, ncurses -, linenoise -, ppx_bap -, ppx_bitstring -, yojson -, which, makeWrapper, writeText -, z3 +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + ocaml, + findlib, + ocamlbuild, + ocaml_oasis, + bitstring, + camlzip, + cmdliner, + core_kernel, + ezjsonm, + fileutils, + mmap, + lwt, + ocamlgraph, + ocurl, + re, + uri, + zarith, + piqi, + piqi-ocaml, + uuidm, + llvm, + frontc, + ounit, + ppx_jane, + parsexp, + utop, + libxml2, + ncurses, + linenoise, + ppx_bap, + ppx_bitstring, + yojson, + which, + makeWrapper, + writeText, + z3, }: -if lib.versionOlder ocaml.version "4.08" -then throw "BAP is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.08" then + throw "BAP is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-bap"; - version = "2.5.0"; - src = fetchFromGitHub { - owner = "BinaryAnalysisPlatform"; - repo = "bap"; - rev = "v${version}"; - sha256 = "1c30zxn0zyi0wypvjmik3fd6n6a8xjcb102qfnccn1af052bvsrd"; - }; + stdenv.mkDerivation rec { + pname = "ocaml${ocaml.version}-bap"; + version = "2.5.0"; + src = fetchFromGitHub { + owner = "BinaryAnalysisPlatform"; + repo = "bap"; + rev = "v${version}"; + sha256 = "1c30zxn0zyi0wypvjmik3fd6n6a8xjcb102qfnccn1af052bvsrd"; + }; - sigs = fetchurl { - url = "https://github.com/BinaryAnalysisPlatform/bap/releases/download/v${version}/sigs.zip"; - sha256 = "0d69jd28z4g64mglq94kj5imhmk5f6sgcsh9q2nij3b0arpcliwk"; - }; + sigs = fetchurl { + url = "https://github.com/BinaryAnalysisPlatform/bap/releases/download/v${version}/sigs.zip"; + sha256 = "0d69jd28z4g64mglq94kj5imhmk5f6sgcsh9q2nij3b0arpcliwk"; + }; - createFindlibDestdir = true; + createFindlibDestdir = true; - setupHook = writeText "setupHook.sh" '' - export CAML_LD_LIBRARY_PATH="''${CAML_LD_LIBRARY_PATH-}''${CAML_LD_LIBRARY_PATH:+:}''$1/lib/ocaml/${ocaml.version}/site-lib/ocaml${ocaml.version}-bap-${version}/" - export CAML_LD_LIBRARY_PATH="''${CAML_LD_LIBRARY_PATH-}''${CAML_LD_LIBRARY_PATH:+:}''$1/lib/ocaml/${ocaml.version}/site-lib/ocaml${ocaml.version}-bap-${version}-llvm-plugins/" - ''; + setupHook = writeText "setupHook.sh" '' + export CAML_LD_LIBRARY_PATH="''${CAML_LD_LIBRARY_PATH-}''${CAML_LD_LIBRARY_PATH:+:}''$1/lib/ocaml/${ocaml.version}/site-lib/ocaml${ocaml.version}-bap-${version}/" + export CAML_LD_LIBRARY_PATH="''${CAML_LD_LIBRARY_PATH-}''${CAML_LD_LIBRARY_PATH:+:}''$1/lib/ocaml/${ocaml.version}/site-lib/ocaml${ocaml.version}-bap-${version}-llvm-plugins/" + ''; - nativeBuildInputs = [ which makeWrapper ocaml findlib ocamlbuild ocaml_oasis ]; + nativeBuildInputs = [ + which + makeWrapper + ocaml + findlib + ocamlbuild + ocaml_oasis + ]; - buildInputs = [ ocamlbuild - linenoise - ounit - ppx_bitstring - z3 - utop libxml2 ncurses ]; + buildInputs = [ + ocamlbuild + linenoise + ounit + ppx_bitstring + z3 + utop + libxml2 + ncurses + ]; - propagatedBuildInputs = [ bitstring camlzip cmdliner ppx_bap core_kernel ezjsonm fileutils mmap lwt ocamlgraph ocurl re uri zarith piqi parsexp - piqi-ocaml uuidm frontc yojson ]; + propagatedBuildInputs = [ + bitstring + camlzip + cmdliner + ppx_bap + core_kernel + ezjsonm + fileutils + mmap + lwt + ocamlgraph + ocurl + re + uri + zarith + piqi + parsexp + piqi-ocaml + uuidm + frontc + yojson + ]; - installPhase = '' - runHook preInstall - export OCAMLPATH=$OCAMLPATH:$OCAMLFIND_DESTDIR; - export PATH=$PATH:$out/bin - export CAML_LD_LIBRARY_PATH=''${CAML_LD_LIBRARY_PATH-}''${CAML_LD_LIBRARY_PATH:+:}$OCAMLFIND_DESTDIR/bap-plugin-llvm/:$OCAMLFIND_DESTDIR/bap/ - mkdir -p $out/lib/bap - make install - rm $out/bin/baptop - makeWrapper ${utop}/bin/utop $out/bin/baptop --prefix OCAMLPATH : $OCAMLPATH --prefix PATH : $PATH --add-flags "-ppx ppx-bap -short-paths -require \"bap.top\"" - wrapProgram $out/bin/bapbuild --prefix OCAMLPATH : $OCAMLPATH --prefix PATH : $PATH - ln -s $sigs $out/share/bap/sigs.zip - runHook postInstall - ''; + installPhase = '' + runHook preInstall + export OCAMLPATH=$OCAMLPATH:$OCAMLFIND_DESTDIR; + export PATH=$PATH:$out/bin + export CAML_LD_LIBRARY_PATH=''${CAML_LD_LIBRARY_PATH-}''${CAML_LD_LIBRARY_PATH:+:}$OCAMLFIND_DESTDIR/bap-plugin-llvm/:$OCAMLFIND_DESTDIR/bap/ + mkdir -p $out/lib/bap + make install + rm $out/bin/baptop + makeWrapper ${utop}/bin/utop $out/bin/baptop --prefix OCAMLPATH : $OCAMLPATH --prefix PATH : $PATH --add-flags "-ppx ppx-bap -short-paths -require \"bap.top\"" + wrapProgram $out/bin/bapbuild --prefix OCAMLPATH : $OCAMLPATH --prefix PATH : $PATH + ln -s $sigs $out/share/bap/sigs.zip + runHook postInstall + ''; - disableIda = "--disable-ida"; - disableGhidra = "--disable-ghidra"; + disableIda = "--disable-ida"; + disableGhidra = "--disable-ghidra"; - patches = [ - ./curses_is_ncurses.patch - ]; + patches = [ + ./curses_is_ncurses.patch + ]; - preConfigure = '' - substituteInPlace oasis/elf-loader --replace bitstring.ppx ppx_bitstring - ''; + preConfigure = '' + substituteInPlace oasis/elf-loader --replace bitstring.ppx ppx_bitstring + ''; - configureFlags = [ "--enable-everything ${disableIda} ${disableGhidra}" "--with-llvm-config=${llvm.dev}/bin/llvm-config" ]; + configureFlags = [ + "--enable-everything ${disableIda} ${disableGhidra}" + "--with-llvm-config=${llvm.dev}/bin/llvm-config" + ]; - meta = with lib; { - description = "Platform for binary analysis. It is written in OCaml, but can be used from other languages"; - homepage = "https://github.com/BinaryAnalysisPlatform/bap/"; - license = licenses.mit; - maintainers = [ maintainers.maurer ]; - mainProgram = "bap"; - }; -} + meta = with lib; { + description = "Platform for binary analysis. It is written in OCaml, but can be used from other languages"; + homepage = "https://github.com/BinaryAnalysisPlatform/bap/"; + license = licenses.mit; + maintainers = [ maintainers.maurer ]; + mainProgram = "bap"; + }; + } diff --git a/pkgs/development/ocaml-modules/base64/default.nix b/pkgs/development/ocaml-modules/base64/default.nix index be8dabf7f60eca..64fcbf8f93a8b8 100644 --- a/pkgs/development/ocaml-modules/base64/default.nix +++ b/pkgs/development/ocaml-modules/base64/default.nix @@ -1,4 +1,13 @@ -{ lib, fetchurl, buildDunePackage, ocaml, findlib, alcotest, bos, rresult }: +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + findlib, + alcotest, + bos, + rresult, +}: buildDunePackage rec { pname = "base64"; @@ -16,7 +25,11 @@ buildDunePackage rec { # otherwise fmt breaks evaluation doCheck = lib.versionAtLeast ocaml.version "4.08"; - checkInputs = [ alcotest bos rresult ]; + checkInputs = [ + alcotest + bos + rresult + ]; meta = { homepage = "https://github.com/mirage/ocaml-base64"; diff --git a/pkgs/development/ocaml-modules/batteries/default.nix b/pkgs/development/ocaml-modules/batteries/default.nix index 610973b5769c59..d68466731613a2 100644 --- a/pkgs/development/ocaml-modules/batteries/default.nix +++ b/pkgs/development/ocaml-modules/batteries/default.nix @@ -1,5 +1,13 @@ -{ lib, fetchFromGitHub, buildDunePackage, ocaml, qtest, qcheck, num, camlp-streams -, doCheck ? lib.versionAtLeast ocaml.version "4.08" +{ + lib, + fetchFromGitHub, + buildDunePackage, + ocaml, + qtest, + qcheck, + num, + camlp-streams, + doCheck ? lib.versionAtLeast ocaml.version "4.08", }: buildDunePackage rec { @@ -17,7 +25,10 @@ buildDunePackage rec { nativeCheckInputs = [ qtest ]; checkInputs = [ qcheck ]; - propagatedBuildInputs = [ camlp-streams num ]; + propagatedBuildInputs = [ + camlp-streams + num + ]; inherit doCheck; checkTarget = "test"; diff --git a/pkgs/development/ocaml-modules/bdd/default.nix b/pkgs/development/ocaml-modules/bdd/default.nix index 358d92d3505dce..cc9306bb455267 100644 --- a/pkgs/development/ocaml-modules/bdd/default.nix +++ b/pkgs/development/ocaml-modules/bdd/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildDunePackage -, fetchFromGitHub -, stdlib-shims +{ + lib, + buildDunePackage, + fetchFromGitHub, + stdlib-shims, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/benchmark/default.nix b/pkgs/development/ocaml-modules/benchmark/default.nix index b0e17054eb532d..c7a590773b3914 100644 --- a/pkgs/development/ocaml-modules/benchmark/default.nix +++ b/pkgs/development/ocaml-modules/benchmark/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, buildDunePackage }: +{ + lib, + fetchurl, + buildDunePackage, +}: buildDunePackage rec { pname = "benchmark"; diff --git a/pkgs/development/ocaml-modules/bheap/default.nix b/pkgs/development/ocaml-modules/bheap/default.nix index 49e5c336d90bcf..255aa62b7a5e3b 100644 --- a/pkgs/development/ocaml-modules/bheap/default.nix +++ b/pkgs/development/ocaml-modules/bheap/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchurl, stdlib-shims }: +{ + lib, + buildDunePackage, + fetchurl, + stdlib-shims, +}: buildDunePackage rec { pname = "bheap"; diff --git a/pkgs/development/ocaml-modules/bigarray-compat/default.nix b/pkgs/development/ocaml-modules/bigarray-compat/default.nix index be343c444171ae..476e9a3b33b04d 100644 --- a/pkgs/development/ocaml-modules/bigarray-compat/default.nix +++ b/pkgs/development/ocaml-modules/bigarray-compat/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchFromGitHub }: +{ + lib, + buildDunePackage, + fetchFromGitHub, +}: buildDunePackage rec { pname = "bigarray-compat"; diff --git a/pkgs/development/ocaml-modules/bigarray-overlap/default.nix b/pkgs/development/ocaml-modules/bigarray-overlap/default.nix index a913b507eab4b1..531bbfc0cdb3f8 100644 --- a/pkgs/development/ocaml-modules/bigarray-overlap/default.nix +++ b/pkgs/development/ocaml-modules/bigarray-overlap/default.nix @@ -1,5 +1,9 @@ -{ lib, buildDunePackage, fetchurl -, alcotest, pkg-config +{ + lib, + buildDunePackage, + fetchurl, + alcotest, + pkg-config, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/bigstring/default.nix b/pkgs/development/ocaml-modules/bigstring/default.nix index 650522363d318d..4023d5db5c4fc5 100644 --- a/pkgs/development/ocaml-modules/bigstring/default.nix +++ b/pkgs/development/ocaml-modules/bigstring/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, ocaml }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + ocaml, +}: buildDunePackage rec { pname = "bigstring"; diff --git a/pkgs/development/ocaml-modules/bigstringaf/default.nix b/pkgs/development/ocaml-modules/bigstringaf/default.nix index ac7c6e5a515855..f32bee87255d3b 100644 --- a/pkgs/development/ocaml-modules/bigstringaf/default.nix +++ b/pkgs/development/ocaml-modules/bigstringaf/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildDunePackage, alcotest, pkg-config }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + alcotest, + pkg-config, +}: buildDunePackage rec { pname = "bigstringaf"; diff --git a/pkgs/development/ocaml-modules/bindlib/default.nix b/pkgs/development/ocaml-modules/bindlib/default.nix index c0d8dd54a37bd1..49121cb39746d2 100644 --- a/pkgs/development/ocaml-modules/bindlib/default.nix +++ b/pkgs/development/ocaml-modules/bindlib/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, earley -, timed +{ + lib, + fetchFromGitHub, + buildDunePackage, + earley, + timed, }: buildDunePackage rec { @@ -18,7 +19,10 @@ buildDunePackage rec { hash = "sha256-058yMbz9ExvgNG/kY9tPk70XSeVRSSKVg4n4F4fmPu4="; }; - checkInputs = [ earley timed ]; + checkInputs = [ + earley + timed + ]; doCheck = true; meta = with lib; { diff --git a/pkgs/development/ocaml-modules/biniou/default.nix b/pkgs/development/ocaml-modules/biniou/default.nix index 2c58a4081401b2..4dfc9496fb8ae8 100644 --- a/pkgs/development/ocaml-modules/biniou/default.nix +++ b/pkgs/development/ocaml-modules/biniou/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, buildDunePackage, camlp-streams, easy-format }: +{ + lib, + fetchurl, + buildDunePackage, + camlp-streams, + easy-format, +}: buildDunePackage rec { pname = "biniou"; @@ -9,7 +15,10 @@ buildDunePackage rec { hash = "sha256-i/P/F80Oyy1rbR2UywjvCJ1Eyu+W6brmvmg51Cj6MY8="; }; - propagatedBuildInputs = [ camlp-streams easy-format ]; + propagatedBuildInputs = [ + camlp-streams + easy-format + ]; meta = { description = "Binary data format designed for speed, safety, ease of use and backward compatibility as protocols evolve"; diff --git a/pkgs/development/ocaml-modules/binning/default.nix b/pkgs/development/ocaml-modules/binning/default.nix index bf448970ef616a..e97db4daddaee5 100644 --- a/pkgs/development/ocaml-modules/binning/default.nix +++ b/pkgs/development/ocaml-modules/binning/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildDunePackage -, fetchurl +{ + lib, + buildDunePackage, + fetchurl, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/biocaml/default.nix b/pkgs/development/ocaml-modules/biocaml/default.nix index 5fa482acc6d400..0f5cc4f4c94214 100644 --- a/pkgs/development/ocaml-modules/biocaml/default.nix +++ b/pkgs/development/ocaml-modules/biocaml/default.nix @@ -1,6 +1,19 @@ -{ lib, buildDunePackage, fetchFromGitHub, fetchpatch -, ounit, async, base64, camlzip, cfstream -, core, ppx_jane, ppx_sexp_conv, rresult, uri, xmlm +{ + lib, + buildDunePackage, + fetchFromGitHub, + fetchpatch, + ounit, + async, + base64, + camlzip, + cfstream, + core, + ppx_jane, + ppx_sexp_conv, + rresult, + uri, + xmlm, }: buildDunePackage rec { @@ -22,9 +35,21 @@ buildDunePackage rec { sha256 = "0rcvf8gwq7sz15mghl9ing722rl2zpnqif9dfxrnpdxiv0rl0731"; }; - buildInputs = [ ppx_jane ppx_sexp_conv ]; + buildInputs = [ + ppx_jane + ppx_sexp_conv + ]; checkInputs = [ ounit ]; - propagatedBuildInputs = [ async base64 camlzip cfstream core rresult uri xmlm ]; + propagatedBuildInputs = [ + async + base64 + camlzip + cfstream + core + rresult + uri + xmlm + ]; meta = with lib; { description = "Bioinformatics library for Ocaml"; diff --git a/pkgs/development/ocaml-modules/biotk/default.nix b/pkgs/development/ocaml-modules/biotk/default.nix index b120e8008819c0..da97a0df3554ba 100644 --- a/pkgs/development/ocaml-modules/biotk/default.nix +++ b/pkgs/development/ocaml-modules/biotk/default.nix @@ -1,21 +1,22 @@ -{ lib -, buildDunePackage -, fetchurl -, angstrom-unix -, binning -, ocaml-crunch -, camlzip -, core_kernel -, core_unix ? null -, csvfields ? null -, fmt -, gsl -, ppx_csv_conv ? null -, ppx_deriving -, rresult -, tyxml -, uri -, vg +{ + lib, + buildDunePackage, + fetchurl, + angstrom-unix, + binning, + ocaml-crunch, + camlzip, + core_kernel, + core_unix ? null, + csvfields ? null, + fmt, + gsl, + ppx_csv_conv ? null, + ppx_deriving, + rresult, + tyxml, + uri, + vg, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/bisect_ppx/default.nix b/pkgs/development/ocaml-modules/bisect_ppx/default.nix index 98da1f31f3128f..a2ecd17f418e71 100644 --- a/pkgs/development/ocaml-modules/bisect_ppx/default.nix +++ b/pkgs/development/ocaml-modules/bisect_ppx/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildDunePackage, cmdliner, ppxlib }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + cmdliner, + ppxlib, +}: buildDunePackage rec { pname = "bisect_ppx"; diff --git a/pkgs/development/ocaml-modules/bistro/default.nix b/pkgs/development/ocaml-modules/bistro/default.nix index 5444c74cb14bac..29e2a681993bb9 100644 --- a/pkgs/development/ocaml-modules/bistro/default.nix +++ b/pkgs/development/ocaml-modules/bistro/default.nix @@ -1,17 +1,18 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, base64 -, bos -, core -, core_kernel -, core_unix ? null -, lwt_react -, ocamlgraph -, ppx_sexp_conv -, rresult -, sexplib -, tyxml +{ + lib, + fetchFromGitHub, + buildDunePackage, + base64, + bos, + core, + core_kernel, + core_unix ? null, + lwt_react, + ocamlgraph, + ppx_sexp_conv, + rresult, + sexplib, + tyxml, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/bitstring/default.nix b/pkgs/development/ocaml-modules/bitstring/default.nix index 4644d4cca86117..12f1232b71a5ac 100644 --- a/pkgs/development/ocaml-modules/bitstring/default.nix +++ b/pkgs/development/ocaml-modules/bitstring/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, stdlib-shims }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + stdlib-shims, +}: buildDunePackage rec { pname = "bitstring"; diff --git a/pkgs/development/ocaml-modules/bitstring/ppx.nix b/pkgs/development/ocaml-modules/bitstring/ppx.nix index 87370ef64b2096..aef82b128133f6 100644 --- a/pkgs/development/ocaml-modules/bitstring/ppx.nix +++ b/pkgs/development/ocaml-modules/bitstring/ppx.nix @@ -1,24 +1,31 @@ -{ lib, buildDunePackage, ocaml -, bitstring, ppxlib -, ounit +{ + lib, + buildDunePackage, + ocaml, + bitstring, + ppxlib, + ounit, }: -if lib.versionOlder ppxlib.version "0.18.0" -then throw "ppx_bitstring is not available with ppxlib-${ppxlib.version}" +if lib.versionOlder ppxlib.version "0.18.0" then + throw "ppx_bitstring is not available with ppxlib-${ppxlib.version}" else -buildDunePackage rec { - pname = "ppx_bitstring"; - inherit (bitstring) version src; + buildDunePackage rec { + pname = "ppx_bitstring"; + inherit (bitstring) version src; - duneVersion = "3"; + duneVersion = "3"; - buildInputs = [ bitstring ppxlib ]; + buildInputs = [ + bitstring + ppxlib + ]; - doCheck = lib.versionAtLeast ocaml.version "4.08"; - checkInputs = [ ounit ]; + doCheck = lib.versionAtLeast ocaml.version "4.08"; + checkInputs = [ ounit ]; - meta = bitstring.meta // { - description = "Bitstrings and bitstring matching for OCaml - PPX extension"; - }; -} + meta = bitstring.meta // { + description = "Bitstrings and bitstring matching for OCaml - PPX extension"; + }; + } diff --git a/pkgs/development/ocaml-modules/bitv/default.nix b/pkgs/development/ocaml-modules/bitv/default.nix index 1369ed078d6ec4..6b9325dc0c520e 100644 --- a/pkgs/development/ocaml-modules/bitv/default.nix +++ b/pkgs/development/ocaml-modules/bitv/default.nix @@ -1,29 +1,42 @@ -{ stdenv, lib, fetchFromGitHub, autoreconfHook, which, ocaml, findlib }: +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + which, + ocaml, + findlib, +}: -if lib.versionOlder ocaml.version "4.02" -then throw "bitv is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.02" then + throw "bitv is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-bitv"; - version = "1.3"; + stdenv.mkDerivation rec { + pname = "ocaml${ocaml.version}-bitv"; + version = "1.3"; - src = fetchFromGitHub { - owner = "backtracking"; - repo = "bitv"; - rev = version; - sha256 = "sha256-sZwq6c10hBBS9tGvKlWD9GE3JBrZPByfDrXE6xIPcG4="; - }; + src = fetchFromGitHub { + owner = "backtracking"; + repo = "bitv"; + rev = version; + sha256 = "sha256-sZwq6c10hBBS9tGvKlWD9GE3JBrZPByfDrXE6xIPcG4="; + }; - nativeBuildInputs = [ autoreconfHook which ocaml findlib ]; + nativeBuildInputs = [ + autoreconfHook + which + ocaml + findlib + ]; - createFindlibDestdir = true; + createFindlibDestdir = true; - meta = { - description = "Bit vector library for OCaml"; - license = lib.licenses.lgpl21; - homepage = "https://github.com/backtracking/bitv"; - maintainers = [ lib.maintainers.vbgl ]; - inherit (ocaml.meta) platforms; - }; -} + meta = { + description = "Bit vector library for OCaml"; + license = lib.licenses.lgpl21; + homepage = "https://github.com/backtracking/bitv"; + maintainers = [ lib.maintainers.vbgl ]; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/bjack/default.nix b/pkgs/development/ocaml-modules/bjack/default.nix index 21052759233a9d..1ee6783162b76a 100644 --- a/pkgs/development/ocaml-modules/bjack/default.nix +++ b/pkgs/development/ocaml-modules/bjack/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, buildDunePackage, fetchFromGitHub, Accelerate, CoreAudio, dune-configurator, libsamplerate, libjack2 }: +{ + lib, + stdenv, + buildDunePackage, + fetchFromGitHub, + Accelerate, + CoreAudio, + dune-configurator, + libsamplerate, + libjack2, +}: buildDunePackage rec { pname = "bjack"; @@ -11,8 +21,16 @@ buildDunePackage rec { hash = "sha256-jIxxqBVWphWYyLh+24rTxk4WWfPPdGCvNdevFJEKw70="; }; - buildInputs = [ dune-configurator ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Accelerate CoreAudio ]; - propagatedBuildInputs = [ libsamplerate libjack2 ]; + buildInputs = + [ dune-configurator ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Accelerate + CoreAudio + ]; + propagatedBuildInputs = [ + libsamplerate + libjack2 + ]; meta = with lib; { homepage = "https://github.com/savonet/ocaml-bjack"; diff --git a/pkgs/development/ocaml-modules/bls12-381-signature/default.nix b/pkgs/development/ocaml-modules/bls12-381-signature/default.nix index e7ca964750e06f..cfb03c5e6d0ba6 100644 --- a/pkgs/development/ocaml-modules/bls12-381-signature/default.nix +++ b/pkgs/development/ocaml-modules/bls12-381-signature/default.nix @@ -1,11 +1,11 @@ -{ lib -, fetchzip -, buildDunePackage -, bls12-381 -, alcotest -, bisect_ppx -, integers_stubs_js -, +{ + lib, + fetchzip, + buildDunePackage, + bls12-381, + alcotest, + bisect_ppx, + integers_stubs_js, }: buildDunePackage rec { @@ -22,7 +22,11 @@ buildDunePackage rec { propagatedBuildInputs = [ bls12-381 ]; - checkInputs = [ alcotest bisect_ppx integers_stubs_js ]; + checkInputs = [ + alcotest + bisect_ppx + integers_stubs_js + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/bls12-381/default.nix b/pkgs/development/ocaml-modules/bls12-381/default.nix index f5e7bbbb6f6d27..9d23c94e4b6fd5 100644 --- a/pkgs/development/ocaml-modules/bls12-381/default.nix +++ b/pkgs/development/ocaml-modules/bls12-381/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildDunePackage -, fetchFromGitLab -, zarith -, zarith_stubs_js ? null -, integers_stubs_js -, integers -, hex -, alcotest +{ + lib, + buildDunePackage, + fetchFromGitLab, + zarith, + zarith_stubs_js ? null, + integers_stubs_js, + integers, + hex, + alcotest, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/bls12-381/gen.nix b/pkgs/development/ocaml-modules/bls12-381/gen.nix index 2eaf616a77b1ce..36bc1c1e2e6d00 100644 --- a/pkgs/development/ocaml-modules/bls12-381/gen.nix +++ b/pkgs/development/ocaml-modules/bls12-381/gen.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitLab, buildDunePackage, ff-sig, zarith }: +{ + lib, + fetchFromGitLab, + buildDunePackage, + ff-sig, + zarith, +}: buildDunePackage rec { pname = "bls12-381-gen"; diff --git a/pkgs/development/ocaml-modules/bos/default.nix b/pkgs/development/ocaml-modules/bos/default.nix index 9f7ce539e18aaf..810e4d35f89c7b 100644 --- a/pkgs/development/ocaml-modules/bos/default.nix +++ b/pkgs/development/ocaml-modules/bos/default.nix @@ -1,5 +1,16 @@ -{ stdenv, lib, fetchurl, ocaml, findlib, ocamlbuild, topkg -, astring, fmt, fpath, logs, rresult +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + astring, + fmt, + fpath, + logs, + rresult, }: stdenv.mkDerivation rec { @@ -11,9 +22,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-2NYueGsQ1pfgRXIFqO7eqifrzJDxhV8Y3xkMrC49jzc="; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; buildInputs = [ topkg ]; - propagatedBuildInputs = [ astring fmt fpath logs rresult ]; + propagatedBuildInputs = [ + astring + fmt + fpath + logs + rresult + ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/brisk-reconciler/default.nix b/pkgs/development/ocaml-modules/brisk-reconciler/default.nix index addaedd5acae84..20fc2b0f97cbd7 100644 --- a/pkgs/development/ocaml-modules/brisk-reconciler/default.nix +++ b/pkgs/development/ocaml-modules/brisk-reconciler/default.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, fetchFromGitHub, lib, reason, ppxlib }: +{ + buildDunePackage, + fetchFromGitHub, + lib, + reason, + ppxlib, +}: buildDunePackage rec { pname = "brisk-reconciler"; diff --git a/pkgs/development/ocaml-modules/brr/default.nix b/pkgs/development/ocaml-modules/brr/default.nix index 7dd46af26cb4d3..79dc048be4f488 100644 --- a/pkgs/development/ocaml-modules/brr/default.nix +++ b/pkgs/development/ocaml-modules/brr/default.nix @@ -1,7 +1,13 @@ -{ stdenv, lib, fetchurl -, ocaml, findlib, ocamlbuild, topkg -, js_of_ocaml-compiler -, js_of_ocaml-toplevel +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + js_of_ocaml-compiler, + js_of_ocaml-toplevel, }: stdenv.mkDerivation rec { @@ -11,8 +17,16 @@ stdenv.mkDerivation rec { url = "https://erratique.ch/software/brr/releases/brr-${version}.tbz"; hash = "sha256-rcWuW6avI/RJZNAlxKOsPSEtDQZ1hb51oKpSk3iG7oY="; }; - buildInputs = [ ocaml findlib ocamlbuild topkg ]; - propagatedBuildInputs = [ js_of_ocaml-compiler js_of_ocaml-toplevel ]; + buildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + propagatedBuildInputs = [ + js_of_ocaml-compiler + js_of_ocaml-toplevel + ]; inherit (topkg) buildPhase installPhase; meta = { diff --git a/pkgs/development/ocaml-modules/bwd/default.nix b/pkgs/development/ocaml-modules/bwd/default.nix index af606763e22b30..c6179b4f31e3e9 100644 --- a/pkgs/development/ocaml-modules/bwd/default.nix +++ b/pkgs/development/ocaml-modules/bwd/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, qcheck-core }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + qcheck-core, +}: buildDunePackage rec { pname = "bwd"; diff --git a/pkgs/development/ocaml-modules/bytestring/default.nix b/pkgs/development/ocaml-modules/bytestring/default.nix index 8ed2a3ec47a0c1..ddf130ac8e28a5 100644 --- a/pkgs/development/ocaml-modules/bytestring/default.nix +++ b/pkgs/development/ocaml-modules/bytestring/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildDunePackage -, fetchurl -, ppxlib -, rio -, sedlex -, spices -, uutf -, qcheck +{ + lib, + buildDunePackage, + fetchurl, + ppxlib, + rio, + sedlex, + spices, + uutf, + qcheck, }: buildDunePackage rec { @@ -42,4 +43,3 @@ buildDunePackage rec { maintainers = [ ]; }; } - diff --git a/pkgs/development/ocaml-modules/bz2/default.nix b/pkgs/development/ocaml-modules/bz2/default.nix index dbe915468d9f9f..4fabc341888581 100644 --- a/pkgs/development/ocaml-modules/bz2/default.nix +++ b/pkgs/development/ocaml-modules/bz2/default.nix @@ -1,41 +1,51 @@ -{ lib, stdenv, fetchFromGitLab, ocaml, findlib, bzip2, autoreconfHook }: - -if lib.versionOlder ocaml.version "4.02" -|| lib.versionAtLeast ocaml.version "5.0" -then throw "bz2 is not available for OCaml ${ocaml.version}" +{ + lib, + stdenv, + fetchFromGitLab, + ocaml, + findlib, + bzip2, + autoreconfHook, +}: + +if lib.versionOlder ocaml.version "4.02" || lib.versionAtLeast ocaml.version "5.0" then + throw "bz2 is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-bz2"; - version = "0.7.0"; - - src = fetchFromGitLab { - owner = "irill"; - repo = "camlbz2"; - rev = version; - sha256 = "sha256-jBFEkLN2fbC3LxTu7C0iuhvNg64duuckBHWZoBxrV/U="; - }; - - autoreconfFlags = [ "-I" "." ]; - - nativeBuildInputs = [ - autoreconfHook - ocaml - findlib - ]; - - propagatedBuildInputs = [ - bzip2 - ]; - - strictDeps = true; - - preInstall = "mkdir -p $OCAMLFIND_DESTDIR/stublibs"; - - meta = with lib; { - description = "OCaml bindings for the libbz2 (AKA, bzip2) (de)compression library"; - downloadPage = "https://gitlab.com/irill/camlbz2"; - license = licenses.lgpl21; - maintainers = [ ]; - }; -} + stdenv.mkDerivation rec { + pname = "ocaml${ocaml.version}-bz2"; + version = "0.7.0"; + + src = fetchFromGitLab { + owner = "irill"; + repo = "camlbz2"; + rev = version; + sha256 = "sha256-jBFEkLN2fbC3LxTu7C0iuhvNg64duuckBHWZoBxrV/U="; + }; + + autoreconfFlags = [ + "-I" + "." + ]; + + nativeBuildInputs = [ + autoreconfHook + ocaml + findlib + ]; + + propagatedBuildInputs = [ + bzip2 + ]; + + strictDeps = true; + + preInstall = "mkdir -p $OCAMLFIND_DESTDIR/stublibs"; + + meta = with lib; { + description = "OCaml bindings for the libbz2 (AKA, bzip2) (de)compression library"; + downloadPage = "https://gitlab.com/irill/camlbz2"; + license = licenses.lgpl21; + maintainers = [ ]; + }; + } diff --git a/pkgs/development/ocaml-modules/ca-certs-nss/default.nix b/pkgs/development/ocaml-modules/ca-certs-nss/default.nix index f8e17420c44cd9..c6d3cfe1e0390f 100644 --- a/pkgs/development/ocaml-modules/ca-certs-nss/default.nix +++ b/pkgs/development/ocaml-modules/ca-certs-nss/default.nix @@ -1,14 +1,15 @@ -{ lib -, buildDunePackage -, fetchurl -, digestif -, mirage-clock -, x509 -, logs -, fmt -, bos -, cmdliner -, alcotest +{ + lib, + buildDunePackage, + fetchurl, + digestif, + mirage-clock, + x509, + logs, + fmt, + bos, + cmdliner, + alcotest, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ca-certs/default.nix b/pkgs/development/ocaml-modules/ca-certs/default.nix index 85539cdc3dd68a..23a76af4138742 100644 --- a/pkgs/development/ocaml-modules/ca-certs/default.nix +++ b/pkgs/development/ocaml-modules/ca-certs/default.nix @@ -1,6 +1,17 @@ -{ lib, buildDunePackage, fetchurl -, bos, fpath, ptime, mirage-crypto, x509, astring, logs -, cacert, alcotest, fmt +{ + lib, + buildDunePackage, + fetchurl, + bos, + fpath, + ptime, + mirage-crypto, + x509, + astring, + logs, + cacert, + alcotest, + fmt, }: buildDunePackage rec { @@ -14,11 +25,19 @@ buildDunePackage rec { hash = "sha256-hpDyMSNGckeZ8tihtoTsFrYnsCfUFkgDoOK34kYsCnI="; }; - propagatedBuildInputs = [ bos fpath ptime mirage-crypto x509 astring logs ]; + propagatedBuildInputs = [ + bos + fpath + ptime + mirage-crypto + x509 + astring + logs + ]; doCheck = true; checkInputs = [ - cacert # for /etc/ssl/certs/ca-bundle.crt + cacert # for /etc/ssl/certs/ca-bundle.crt alcotest fmt ]; diff --git a/pkgs/development/ocaml-modules/cairo2/default.nix b/pkgs/development/ocaml-modules/cairo2/default.nix index 38a6f2324ff7ac..baed712e9ac6a4 100644 --- a/pkgs/development/ocaml-modules/cairo2/default.nix +++ b/pkgs/development/ocaml-modules/cairo2/default.nix @@ -1,5 +1,14 @@ -{ stdenv, lib, fetchurl, buildDunePackage, ocaml, dune-configurator, pkg-config, cairo -, ApplicationServices }: +{ + stdenv, + lib, + fetchurl, + buildDunePackage, + ocaml, + dune-configurator, + pkg-config, + cairo, + ApplicationServices, +}: buildDunePackage rec { pname = "cairo2"; @@ -14,11 +23,17 @@ buildDunePackage rec { useDune2 = true; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ cairo dune-configurator ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ ApplicationServices ]; + buildInputs = [ + cairo + dune-configurator + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ ApplicationServices ]; - doCheck = !(stdenv.hostPlatform.isDarwin - # https://github.com/Chris00/ocaml-cairo/issues/19 - || lib.versionAtLeast ocaml.version "4.10"); + doCheck = + !( + stdenv.hostPlatform.isDarwin + # https://github.com/Chris00/ocaml-cairo/issues/19 + || lib.versionAtLeast ocaml.version "4.10" + ); meta = with lib; { homepage = "https://github.com/Chris00/ocaml-cairo"; @@ -30,6 +45,9 @@ buildDunePackage rec { and SVG file output. ''; license = licenses.lgpl3; - maintainers = with maintainers; [ jirkamarsik vbgl ]; + maintainers = with maintainers; [ + jirkamarsik + vbgl + ]; }; } diff --git a/pkgs/development/ocaml-modules/calendar/default.nix b/pkgs/development/ocaml-modules/calendar/default.nix index fcd8058d64c4fb..769386333fba35 100644 --- a/pkgs/development/ocaml-modules/calendar/default.nix +++ b/pkgs/development/ocaml-modules/calendar/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitHub, re }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + re, +}: buildDunePackage rec { pname = "calendar"; diff --git a/pkgs/development/ocaml-modules/callipyge/default.nix b/pkgs/development/ocaml-modules/callipyge/default.nix index 68ba880a7987da..40a3caaa61cee1 100644 --- a/pkgs/development/ocaml-modules/callipyge/default.nix +++ b/pkgs/development/ocaml-modules/callipyge/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildDunePackage -, fetchurl -, alcotest -, eqaf -, fmt +{ + lib, + buildDunePackage, + fetchurl, + alcotest, + eqaf, + fmt, }: buildDunePackage rec { @@ -19,7 +20,10 @@ buildDunePackage rec { minimalOCamlVersion = "4.08"; - propagatedBuildInputs = [ fmt eqaf ]; + propagatedBuildInputs = [ + fmt + eqaf + ]; doCheck = true; checkInputs = [ alcotest ]; diff --git a/pkgs/development/ocaml-modules/camlimages/default.nix b/pkgs/development/ocaml-modules/camlimages/default.nix index c9f523d098d701..e4fff7be0fefb1 100644 --- a/pkgs/development/ocaml-modules/camlimages/default.nix +++ b/pkgs/development/ocaml-modules/camlimages/default.nix @@ -1,5 +1,13 @@ -{ lib, fetchFromGitLab, buildDunePackage, findlib, dune-configurator, cppo -, graphics, lablgtk, stdio +{ + lib, + fetchFromGitLab, + buildDunePackage, + findlib, + dune-configurator, + cppo, + graphics, + lablgtk, + stdio, }: buildDunePackage rec { @@ -19,13 +27,22 @@ buildDunePackage rec { patches = [ ./camlimages.patch ]; nativeBuildInputs = [ cppo ]; - buildInputs = [ dune-configurator findlib graphics lablgtk stdio ]; + buildInputs = [ + dune-configurator + findlib + graphics + lablgtk + stdio + ]; meta = with lib; { branch = "5.0"; inherit (src.meta) homepage; description = "OCaml image processing library"; license = licenses.lgpl2; - maintainers = [ maintainers.vbgl maintainers.mt-caret ]; + maintainers = [ + maintainers.vbgl + maintainers.mt-caret + ]; }; } diff --git a/pkgs/development/ocaml-modules/camlp-streams/default.nix b/pkgs/development/ocaml-modules/camlp-streams/default.nix index 1e2a71cc0b9d5f..cabccf89e7fc4f 100644 --- a/pkgs/development/ocaml-modules/camlp-streams/default.nix +++ b/pkgs/development/ocaml-modules/camlp-streams/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchFromGitHub }: +{ + lib, + buildDunePackage, + fetchFromGitHub, +}: buildDunePackage rec { pname = "camlp-streams"; diff --git a/pkgs/development/ocaml-modules/camlzip/default.nix b/pkgs/development/ocaml-modules/camlzip/default.nix index 3b038f4dfec3ab..e36453d216fe21 100644 --- a/pkgs/development/ocaml-modules/camlzip/default.nix +++ b/pkgs/development/ocaml-modules/camlzip/default.nix @@ -1,34 +1,46 @@ -{lib, stdenv, fetchurl, zlib, ocaml, findlib}: +{ + lib, + stdenv, + fetchurl, + zlib, + ocaml, + findlib, +}: let common = { - patches = []; - postPatchInit = '' - cp META-zip META-camlzip - echo 'directory="../zip"' >> META-camlzip - ''; + patches = [ ]; + postPatchInit = '' + cp META-zip META-camlzip + echo 'directory="../zip"' >> META-camlzip + ''; }; param = - if lib.versionAtLeast ocaml.version "4.07" - then common // { - version = "1.11"; - url = "https://github.com/xavierleroy/camlzip/archive/rel111.tar.gz"; - sha256 = "sha256-/7vF3j4cE9wOWScjdtIy0u3pGzJ1UQY9R/3bdPHV7Tc="; - } else if lib.versionAtLeast ocaml.version "4.02" - then common // { - version = "1.10"; - url = "https://github.com/xavierleroy/camlzip/archive/rel110.tar.gz"; - sha256 = "X0YcczaQ3lFeJEiTIgjSSZ1zi32KFMtmZsP0FFpyfbI="; - } else { - version = "1.05"; - download_id = "1037"; - url = "http://forge.ocamlcore.org/frs/download.php/${param.download_id}/camlzip-${param.version}.tar.gz"; - sha256 = "930b70c736ab5a7ed1b05220102310a0a2241564786657abe418e834a538d06b"; - patches = [./makefile_1_05.patch]; - postPatchInit = '' - substitute ${./META} META --subst-var-by VERSION "${param.version}" - ''; - }; + if lib.versionAtLeast ocaml.version "4.07" then + common + // { + version = "1.11"; + url = "https://github.com/xavierleroy/camlzip/archive/rel111.tar.gz"; + sha256 = "sha256-/7vF3j4cE9wOWScjdtIy0u3pGzJ1UQY9R/3bdPHV7Tc="; + } + else if lib.versionAtLeast ocaml.version "4.02" then + common + // { + version = "1.10"; + url = "https://github.com/xavierleroy/camlzip/archive/rel110.tar.gz"; + sha256 = "X0YcczaQ3lFeJEiTIgjSSZ1zi32KFMtmZsP0FFpyfbI="; + } + else + { + version = "1.05"; + download_id = "1037"; + url = "http://forge.ocamlcore.org/frs/download.php/${param.download_id}/camlzip-${param.version}.tar.gz"; + sha256 = "930b70c736ab5a7ed1b05220102310a0a2241564786657abe418e834a538d06b"; + patches = [ ./makefile_1_05.patch ]; + postPatchInit = '' + substitute ${./META} META --subst-var-by VERSION "${param.version}" + ''; + }; in stdenv.mkDerivation { @@ -40,9 +52,12 @@ stdenv.mkDerivation { inherit (param) sha256; }; - nativeBuildInputs = [ ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; - propagatedBuildInputs = [zlib]; + propagatedBuildInputs = [ zlib ]; strictDeps = true; @@ -50,13 +65,18 @@ stdenv.mkDerivation { createFindlibDestdir = true; - postPatch = param.postPatchInit + '' - substituteInPlace Makefile \ - --subst-var-by ZLIB_LIBDIR "${zlib.out}/lib" \ - --subst-var-by ZLIB_INCLUDE "${zlib.dev}/include" - ''; + postPatch = + param.postPatchInit + + '' + substituteInPlace Makefile \ + --subst-var-by ZLIB_LIBDIR "${zlib.out}/lib" \ + --subst-var-by ZLIB_INCLUDE "${zlib.dev}/include" + ''; - buildFlags = [ "all" "allopt" ]; + buildFlags = [ + "all" + "allopt" + ]; postInstall = '' ln -s $out/lib/ocaml/${ocaml.version}/site-lib/{,caml}zip diff --git a/pkgs/development/ocaml-modules/camomile/0.8.5.nix b/pkgs/development/ocaml-modules/camomile/0.8.5.nix index 658daf61c81af3..430991dcad0765 100644 --- a/pkgs/development/ocaml-modules/camomile/0.8.5.nix +++ b/pkgs/development/ocaml-modules/camomile/0.8.5.nix @@ -1,4 +1,12 @@ -{stdenv, lib, fetchurl, fetchpatch, ocaml, findlib, camlp4}: +{ + stdenv, + lib, + fetchurl, + fetchpatch, + ocaml, + findlib, + camlp4, +}: stdenv.mkDerivation { pname = "camomile"; @@ -9,12 +17,18 @@ stdenv.mkDerivation { sha256 = "003ikpvpaliy5hblhckfmln34zqz0mk3y2m1fqvbjngh3h2np045"; }; - patches = [ (fetchpatch { - url = "https://raw.githubusercontent.com/ocaml/opam-repository/master/packages/camomile/camomile.0.8.5/files/4.05-typing-fix.patch"; - sha256 = "167279lia6qx62mdcyc5rjsi4gf4yi52wn9mhgd9y1v3754z7fwb"; - })]; + patches = [ + (fetchpatch { + url = "https://raw.githubusercontent.com/ocaml/opam-repository/master/packages/camomile/camomile.0.8.5/files/4.05-typing-fix.patch"; + sha256 = "167279lia6qx62mdcyc5rjsi4gf4yi52wn9mhgd9y1v3754z7fwb"; + }) + ]; - nativeBuildInputs = [ocaml findlib camlp4 ]; + nativeBuildInputs = [ + ocaml + findlib + camlp4 + ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/camomile/default.nix b/pkgs/development/ocaml-modules/camomile/default.nix index 94e858ff9fb4b2..3bb9677e7442ea 100644 --- a/pkgs/development/ocaml-modules/camomile/default.nix +++ b/pkgs/development/ocaml-modules/camomile/default.nix @@ -1,32 +1,42 @@ -{ stdenv, lib, darwin, fetchFromGitHub, buildDunePackage, ocaml, cppo -, camlp-streams, dune-site -, version ? if lib.versionAtLeast ocaml.version "4.08" then "2.0.0" else "1.0.2" +{ + stdenv, + lib, + darwin, + fetchFromGitHub, + buildDunePackage, + ocaml, + cppo, + camlp-streams, + dune-site, + version ? if lib.versionAtLeast ocaml.version "4.08" then "2.0.0" else "1.0.2", }: -let params = - { - "1.0.2" = lib.throwIf (lib.versionAtLeast ocaml.version "5.0") - "camomile 1 is not available for OCaml ${ocaml.version}" { - src = fetchFromGitHub { - owner = "yoriyuki"; - repo = "camomile"; - rev = version; - sha256 = "00i910qjv6bpk0nkafp5fg97isqas0bwjf7m6rz11rsxilpalzad"; - }; +let + params = { + "1.0.2" = + lib.throwIf (lib.versionAtLeast ocaml.version "5.0") + "camomile 1 is not available for OCaml ${ocaml.version}" + { + src = fetchFromGitHub { + owner = "yoriyuki"; + repo = "camomile"; + rev = version; + sha256 = "00i910qjv6bpk0nkafp5fg97isqas0bwjf7m6rz11rsxilpalzad"; + }; - nativeBuildInputs = [ cppo ]; + nativeBuildInputs = [ cppo ]; - configurePhase = '' - runHook preConfigure - ocaml configure.ml --share $out/share/camomile - runHook postConfigure - ''; + configurePhase = '' + runHook preConfigure + ocaml configure.ml --share $out/share/camomile + runHook postConfigure + ''; - postInstall = '' - echo "version = \"${version}\"" >> $out/lib/ocaml/${ocaml.version}/site-lib/camomile/META - ''; + postInstall = '' + echo "version = \"${version}\"" >> $out/lib/ocaml/${ocaml.version}/site-lib/camomile/META + ''; - }; + }; "2.0.0" = { src = fetchFromGitHub { @@ -38,20 +48,25 @@ let params = nativeBuildInputs = lib.optional stdenv.hostPlatform.isDarwin darwin.sigtool; - propagatedBuildInputs = [ camlp-streams dune-site ]; + propagatedBuildInputs = [ + camlp-streams + dune-site + ]; }; - } -; in - + }; +in -buildDunePackage (params."${version}" // { - pname = "camomile"; - inherit version; +buildDunePackage ( + params."${version}" + // { + pname = "camomile"; + inherit version; - meta = { - homepage = "https://github.com/ocaml-community/Camomile"; - maintainers = [ lib.maintainers.vbgl ]; - license = lib.licenses.lgpl21; - description = "Unicode library for OCaml"; - }; -}) + meta = { + homepage = "https://github.com/ocaml-community/Camomile"; + maintainers = [ lib.maintainers.vbgl ]; + license = lib.licenses.lgpl21; + description = "Unicode library for OCaml"; + }; + } +) diff --git a/pkgs/development/ocaml-modules/capnp/default.nix b/pkgs/development/ocaml-modules/capnp/default.nix index 2d405dceaab146..e81c1252edc39f 100644 --- a/pkgs/development/ocaml-modules/capnp/default.nix +++ b/pkgs/development/ocaml-modules/capnp/default.nix @@ -1,14 +1,15 @@ -{ lib -, buildDunePackage -, fetchFromGitHub -, base_quickcheck ? null -, capnproto -, ocplib-endian -, ounit2 -, res -, result -, stdint -, stdio +{ + lib, + buildDunePackage, + fetchFromGitHub, + base_quickcheck ? null, + capnproto, + ocplib-endian, + ounit2, + res, + result, + stdint, + stdio, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/caqti/async.nix b/pkgs/development/ocaml-modules/caqti/async.nix index a0f3fb035646b6..5db8fda9d77b6b 100644 --- a/pkgs/development/ocaml-modules/caqti/async.nix +++ b/pkgs/development/ocaml-modules/caqti/async.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, async_kernel, async_unix, caqti, core_kernel }: +{ + buildDunePackage, + async_kernel, + async_unix, + caqti, + core_kernel, +}: buildDunePackage { pname = "caqti-async"; @@ -6,7 +12,14 @@ buildDunePackage { minimalOCamlVersion = "4.14"; - propagatedBuildInputs = [ async_kernel async_unix caqti core_kernel ]; + propagatedBuildInputs = [ + async_kernel + async_unix + caqti + core_kernel + ]; - meta = caqti.meta // { description = "Async support for Caqti"; }; + meta = caqti.meta // { + description = "Async support for Caqti"; + }; } diff --git a/pkgs/development/ocaml-modules/caqti/default.nix b/pkgs/development/ocaml-modules/caqti/default.nix index 218f4cf3c120c7..5e04b4258bbee0 100644 --- a/pkgs/development/ocaml-modules/caqti/default.nix +++ b/pkgs/development/ocaml-modules/caqti/default.nix @@ -1,16 +1,17 @@ -{ lib -, fetchurl -, buildDunePackage -, angstrom -, bigstringaf -, domain-name -, dune-site -, ipaddr -, logs -, lwt-dllist -, mtime -, ptime -, uri +{ + lib, + fetchurl, + buildDunePackage, + angstrom, + bigstringaf, + domain-name, + dune-site, + ipaddr, + logs, + lwt-dllist, + mtime, + ptime, + uri, }: buildDunePackage rec { @@ -25,14 +26,27 @@ buildDunePackage rec { }; buildInputs = [ dune-site ]; - propagatedBuildInputs = [ angstrom bigstringaf domain-name ipaddr logs lwt-dllist mtime ptime uri ]; + propagatedBuildInputs = [ + angstrom + bigstringaf + domain-name + ipaddr + logs + lwt-dllist + mtime + ptime + uri + ]; # Checks depend on caqti-driver-sqlite3 (circural dependency) doCheck = false; meta = { description = "Unified interface to relational database libraries"; - license = with lib.licenses; [ lgpl3Plus ocamlLgplLinkingException ]; + license = with lib.licenses; [ + lgpl3Plus + ocamlLgplLinkingException + ]; maintainers = with lib.maintainers; [ bcc32 ]; homepage = "https://github.com/paurkedal/ocaml-caqti"; }; diff --git a/pkgs/development/ocaml-modules/caqti/driver-mariadb.nix b/pkgs/development/ocaml-modules/caqti/driver-mariadb.nix index 5a6199de3ccc33..4ea0b47dabbf01 100644 --- a/pkgs/development/ocaml-modules/caqti/driver-mariadb.nix +++ b/pkgs/development/ocaml-modules/caqti/driver-mariadb.nix @@ -1,10 +1,17 @@ -{ buildDunePackage, caqti, mariadb }: +{ + buildDunePackage, + caqti, + mariadb, +}: buildDunePackage { pname = "caqti-driver-mariadb"; inherit (caqti) version src; - propagatedBuildInputs = [ caqti mariadb ]; + propagatedBuildInputs = [ + caqti + mariadb + ]; meta = caqti.meta // { description = "MariaDB driver for Caqti using C bindings"; diff --git a/pkgs/development/ocaml-modules/caqti/driver-postgresql.nix b/pkgs/development/ocaml-modules/caqti/driver-postgresql.nix index fc440d2a1384db..5b7ffd3d37f889 100644 --- a/pkgs/development/ocaml-modules/caqti/driver-postgresql.nix +++ b/pkgs/development/ocaml-modules/caqti/driver-postgresql.nix @@ -1,10 +1,17 @@ -{ buildDunePackage, caqti, postgresql }: +{ + buildDunePackage, + caqti, + postgresql, +}: buildDunePackage { pname = "caqti-driver-postgresql"; inherit (caqti) version src; - propagatedBuildInputs = [ caqti postgresql ]; + propagatedBuildInputs = [ + caqti + postgresql + ]; meta = caqti.meta // { description = "PostgreSQL driver for Caqti based on C bindings"; diff --git a/pkgs/development/ocaml-modules/caqti/driver-sqlite3.nix b/pkgs/development/ocaml-modules/caqti/driver-sqlite3.nix index 362707025ee7f6..1387b0ff1a924d 100644 --- a/pkgs/development/ocaml-modules/caqti/driver-sqlite3.nix +++ b/pkgs/development/ocaml-modules/caqti/driver-sqlite3.nix @@ -1,10 +1,18 @@ -{ buildDunePackage, caqti, ocaml_sqlite3, alcotest }: +{ + buildDunePackage, + caqti, + ocaml_sqlite3, + alcotest, +}: buildDunePackage { pname = "caqti-driver-sqlite3"; inherit (caqti) version src; - propagatedBuildInputs = [ caqti ocaml_sqlite3 ]; + propagatedBuildInputs = [ + caqti + ocaml_sqlite3 + ]; checkInputs = [ alcotest ]; diff --git a/pkgs/development/ocaml-modules/caqti/dynload.nix b/pkgs/development/ocaml-modules/caqti/dynload.nix index 3450a6311efd28..6cbb4638a013cf 100644 --- a/pkgs/development/ocaml-modules/caqti/dynload.nix +++ b/pkgs/development/ocaml-modules/caqti/dynload.nix @@ -1,10 +1,17 @@ -{ buildDunePackage, caqti, findlib }: +{ + buildDunePackage, + caqti, + findlib, +}: buildDunePackage { pname = "caqti-dynload"; inherit (caqti) version src; - propagatedBuildInputs = [ caqti findlib ]; + propagatedBuildInputs = [ + caqti + findlib + ]; meta = caqti.meta // { description = "Dynamic linking of Caqti drivers using findlib.dynload"; diff --git a/pkgs/development/ocaml-modules/caqti/lwt.nix b/pkgs/development/ocaml-modules/caqti/lwt.nix index 35aebaebae5ae4..d3e0747d4dcf95 100644 --- a/pkgs/development/ocaml-modules/caqti/lwt.nix +++ b/pkgs/development/ocaml-modules/caqti/lwt.nix @@ -1,10 +1,21 @@ -{ buildDunePackage, caqti, logs, lwt }: +{ + buildDunePackage, + caqti, + logs, + lwt, +}: buildDunePackage { pname = "caqti-lwt"; inherit (caqti) version src; - propagatedBuildInputs = [ caqti logs lwt ]; + propagatedBuildInputs = [ + caqti + logs + lwt + ]; - meta = caqti.meta // { description = "Lwt support for Caqti"; }; + meta = caqti.meta // { + description = "Lwt support for Caqti"; + }; } diff --git a/pkgs/development/ocaml-modules/caqti/type-calendar.nix b/pkgs/development/ocaml-modules/caqti/type-calendar.nix index 9f71bd1d164c04..15efe5215e00ff 100644 --- a/pkgs/development/ocaml-modules/caqti/type-calendar.nix +++ b/pkgs/development/ocaml-modules/caqti/type-calendar.nix @@ -1,10 +1,17 @@ -{ buildDunePackage, calendar, caqti }: +{ + buildDunePackage, + calendar, + caqti, +}: buildDunePackage { pname = "caqti-type-calendar"; inherit (caqti) src version; - propagatedBuildInputs = [ calendar caqti ]; + propagatedBuildInputs = [ + calendar + caqti + ]; meta = caqti.meta // { description = "Date and time field types using the calendar library"; diff --git a/pkgs/development/ocaml-modules/carton/default.nix b/pkgs/development/ocaml-modules/carton/default.nix index 7ba02d68ff5f4a..b1f35bea8fa550 100644 --- a/pkgs/development/ocaml-modules/carton/default.nix +++ b/pkgs/development/ocaml-modules/carton/default.nix @@ -1,9 +1,33 @@ -{ lib, buildDunePackage, fetchurl -, ke, duff, decompress, cstruct, optint, bigstringaf -, checkseum, logs, psq, fmt -, result, rresult, fpath, base64, bos, digestif, alcotest -, crowbar, alcotest-lwt, lwt, findlib, mirage-flow, cmdliner, hxd -, getconf, substituteAll +{ + lib, + buildDunePackage, + fetchurl, + ke, + duff, + decompress, + cstruct, + optint, + bigstringaf, + checkseum, + logs, + psq, + fmt, + result, + rresult, + fpath, + base64, + bos, + digestif, + alcotest, + crowbar, + alcotest-lwt, + lwt, + findlib, + mirage-flow, + cmdliner, + hxd, + getconf, + substituteAll, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/carton/git.nix b/pkgs/development/ocaml-modules/carton/git.nix index 97055067bc4a23..331f66bb31f4f0 100644 --- a/pkgs/development/ocaml-modules/carton/git.nix +++ b/pkgs/development/ocaml-modules/carton/git.nix @@ -1,6 +1,14 @@ -{ buildDunePackage, carton, carton-lwt -, bigstringaf, lwt, fpath, result -, fmt, decompress, astring +{ + buildDunePackage, + carton, + carton-lwt, + bigstringaf, + lwt, + fpath, + result, + fmt, + decompress, + astring, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/carton/lwt.nix b/pkgs/development/ocaml-modules/carton/lwt.nix index cf07eca552bae1..eacc9e19505049 100644 --- a/pkgs/development/ocaml-modules/carton/lwt.nix +++ b/pkgs/development/ocaml-modules/carton/lwt.nix @@ -1,10 +1,26 @@ -{ buildDunePackage, carton -, lwt, decompress, optint, bigstringaf -, alcotest, alcotest-lwt, cstruct, fmt, logs -, mirage-flow, result, rresult -, ke, base64, bos, checkseum, digestif, fpath -, stdlib-shims -, git-binary # pkgs.git +{ + buildDunePackage, + carton, + lwt, + decompress, + optint, + bigstringaf, + alcotest, + alcotest-lwt, + cstruct, + fmt, + logs, + mirage-flow, + result, + rresult, + ke, + base64, + bos, + checkseum, + digestif, + fpath, + stdlib-shims, + git-binary, # pkgs.git }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/cfstream/default.nix b/pkgs/development/ocaml-modules/cfstream/default.nix index e5de1b64853489..07a16e32fbb36a 100644 --- a/pkgs/development/ocaml-modules/cfstream/default.nix +++ b/pkgs/development/ocaml-modules/cfstream/default.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, fetchFromGitHub, m4, camlp-streams, core_kernel, ounit }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + m4, + camlp-streams, + core_kernel, + ounit, +}: buildDunePackage rec { pname = "cfstream"; @@ -8,16 +16,22 @@ buildDunePackage rec { src = fetchFromGitHub { owner = "biocaml"; - repo = pname; - rev = version; + repo = pname; + rev = version; hash = "sha256-iSg0QsTcU0MT/Cletl+hW6bKyH0jkp7Jixqu8H59UmQ="; }; - patches = [ ./git_commit.patch ./janestreet-0.17.patch ]; + patches = [ + ./git_commit.patch + ./janestreet-0.17.patch + ]; nativeBuildInputs = [ m4 ]; checkInputs = [ ounit ]; - propagatedBuildInputs = [ camlp-streams core_kernel ]; + propagatedBuildInputs = [ + camlp-streams + core_kernel + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/chacha/default.nix b/pkgs/development/ocaml-modules/chacha/default.nix index c72ab59e3f7bcc..f5d6c4c1008b27 100644 --- a/pkgs/development/ocaml-modules/chacha/default.nix +++ b/pkgs/development/ocaml-modules/chacha/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildDunePackage -, fetchFromGitHub -, fetchpatch -, ocaml +{ + lib, + buildDunePackage, + fetchFromGitHub, + fetchpatch, + ocaml, -, alcotest -, cstruct -, mirage-crypto + alcotest, + cstruct, + mirage-crypto, }: buildDunePackage rec { @@ -21,12 +22,17 @@ buildDunePackage rec { }; # Ensure compatibility with cstruct ≥ 6.1.0 - patches = [ (fetchpatch { - url = "https://github.com/abeaumont/ocaml-chacha/commit/fbe4a0a808226229728a68f278adf370251196fd.patch"; - sha256 = "sha256-y7X9toFDrgdv3qmFmUs7K7QS+Gy45rRLulKy48m7uqc="; - })]; + patches = [ + (fetchpatch { + url = "https://github.com/abeaumont/ocaml-chacha/commit/fbe4a0a808226229728a68f278adf370251196fd.patch"; + sha256 = "sha256-y7X9toFDrgdv3qmFmUs7K7QS+Gy45rRLulKy48m7uqc="; + }) + ]; - propagatedBuildInputs = [ cstruct mirage-crypto ]; + propagatedBuildInputs = [ + cstruct + mirage-crypto + ]; # alcotest isn't available for OCaml < 4.05 due to fmt doCheck = lib.versionAtLeast ocaml.version "4.05"; diff --git a/pkgs/development/ocaml-modules/checkseum/default.nix b/pkgs/development/ocaml-modules/checkseum/default.nix index 7e3a17ac56007f..e72edc46e4f743 100644 --- a/pkgs/development/ocaml-modules/checkseum/default.nix +++ b/pkgs/development/ocaml-modules/checkseum/default.nix @@ -1,6 +1,16 @@ -{ lib, fetchurl, buildDunePackage, ocaml, dune-configurator -, optint -, fmt, rresult, bos, fpath, astring, alcotest +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + dune-configurator, + optint, + fmt, + rresult, + bos, + fpath, + astring, + alcotest, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/chrome-trace/default.nix b/pkgs/development/ocaml-modules/chrome-trace/default.nix index 9c427d343758ef..e07f1c796eed65 100644 --- a/pkgs/development/ocaml-modules/chrome-trace/default.nix +++ b/pkgs/development/ocaml-modules/chrome-trace/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, dune_3 }: +{ + lib, + buildDunePackage, + dune_3, +}: buildDunePackage rec { pname = "chrome-trace"; diff --git a/pkgs/development/ocaml-modules/cil/default.nix b/pkgs/development/ocaml-modules/cil/default.nix index 4cedb1291e1dee..73e37f9281bcd4 100644 --- a/pkgs/development/ocaml-modules/cil/default.nix +++ b/pkgs/development/ocaml-modules/cil/default.nix @@ -1,35 +1,48 @@ -{ lib, stdenv, fetchurl, perl, ocaml, findlib, ocamlbuild }: - -if lib.versionAtLeast ocaml.version "4.06" -then throw "cil is not available for OCaml ${ocaml.version}" +{ + lib, + stdenv, + fetchurl, + perl, + ocaml, + findlib, + ocamlbuild, +}: + +if lib.versionAtLeast ocaml.version "4.06" then + throw "cil is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "ocaml-cil"; - version = "1.7.3"; - - src = fetchurl { - url = "mirror://sourceforge/cil/cil-${version}.tar.gz"; - sha256 = "05739da0b0msx6kmdavr3y2bwi92jbh3szc35d7d8pdisa8g5dv9"; - }; - - nativeBuildInputs = [ perl ocaml findlib ocamlbuild ]; - - strictDeps = true; - - createFindlibDestdir = true; - - preConfigure = '' - substituteInPlace Makefile.in --replace 'MACHDEPCC=gcc' 'MACHDEPCC=$(CC)' - export FORCE_PERL_PREFIX=1 - ''; - prefixKey = "-prefix="; - - meta = with lib; { - homepage = "http://kerneis.github.io/cil/"; - description = "Front-end for the C programming language that facilitates program analysis and transformation"; - license = licenses.bsd3; - maintainers = [ maintainers.vbgl ]; - platforms = ocaml.meta.platforms or [ ]; - }; -} + stdenv.mkDerivation rec { + pname = "ocaml-cil"; + version = "1.7.3"; + + src = fetchurl { + url = "mirror://sourceforge/cil/cil-${version}.tar.gz"; + sha256 = "05739da0b0msx6kmdavr3y2bwi92jbh3szc35d7d8pdisa8g5dv9"; + }; + + nativeBuildInputs = [ + perl + ocaml + findlib + ocamlbuild + ]; + + strictDeps = true; + + createFindlibDestdir = true; + + preConfigure = '' + substituteInPlace Makefile.in --replace 'MACHDEPCC=gcc' 'MACHDEPCC=$(CC)' + export FORCE_PERL_PREFIX=1 + ''; + prefixKey = "-prefix="; + + meta = with lib; { + homepage = "http://kerneis.github.io/cil/"; + description = "Front-end for the C programming language that facilitates program analysis and transformation"; + license = licenses.bsd3; + maintainers = [ maintainers.vbgl ]; + platforms = ocaml.meta.platforms or [ ]; + }; + } diff --git a/pkgs/development/ocaml-modules/clap/default.nix b/pkgs/development/ocaml-modules/clap/default.nix index 83d420c80f3358..8ea75a2c7c7088 100644 --- a/pkgs/development/ocaml-modules/clap/default.nix +++ b/pkgs/development/ocaml-modules/clap/default.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildDunePackage +{ + lib, + fetchFromGitHub, + buildDunePackage, }: buildDunePackage rec { @@ -21,4 +22,3 @@ buildDunePackage rec { license = lib.licenses.mit; }; } - diff --git a/pkgs/development/ocaml-modules/class_group_vdf/default.nix b/pkgs/development/ocaml-modules/class_group_vdf/default.nix index 61acb189242d6a..e36c3463491997 100644 --- a/pkgs/development/ocaml-modules/class_group_vdf/default.nix +++ b/pkgs/development/ocaml-modules/class_group_vdf/default.nix @@ -1,55 +1,72 @@ -{ stdenv, lib, fetchFromGitLab, buildDunePackage -, gmp, pkg-config, dune-configurator -, zarith, integers -, alcotest, bisect_ppx +{ + stdenv, + lib, + fetchFromGitLab, + buildDunePackage, + gmp, + pkg-config, + dune-configurator, + zarith, + integers, + alcotest, + bisect_ppx, }: -buildDunePackage (rec { - pname = "class_group_vdf"; - version = "0.0.4"; - duneVersion = "3"; - - src = fetchFromGitLab { - owner = "nomadic-labs/cryptography"; - repo = "ocaml-chia-vdf"; - rev = "v${version}"; - hash = "sha256-KvpnX2DTUyfKARNWHC2lLBGH2Ou2GfRKjw05lu4jbBs="; - }; - - minimalOCamlVersion = "4.08"; - - nativeBuildInputs = [ - gmp - pkg-config - dune-configurator - ]; - - buildInputs = [ - dune-configurator - ]; - - propagatedBuildInputs = [ - zarith - integers - ]; - - checkInputs = [ - alcotest - bisect_ppx - ]; - - doCheck = true; - - meta = { - description = "Verifiable Delay Functions bindings to Chia's VDF"; - homepage = "https://gitlab.com/nomadic-labs/tezos"; - license = lib.licenses.mit; - maintainers = [ lib.maintainers.ulrikstrid ]; - }; -} -# Darwin sdk on intel target 10.12 (2016) at the time of writing. It is likely that host will be at least 10.14 (2018). This fix allow it to build and run on 10.14 and build on 10.12 (but don't run). -// lib.optionalAttrs (lib.versionOlder stdenv.hostPlatform.darwinMinVersion "10.14" && stdenv.hostPlatform.isMacOS && stdenv.hostPlatform.isx86_64) { - preHook = '' - export MACOSX_DEPLOYMENT_TARGET=10.14 - ''; -}) +buildDunePackage ( + rec { + pname = "class_group_vdf"; + version = "0.0.4"; + duneVersion = "3"; + + src = fetchFromGitLab { + owner = "nomadic-labs/cryptography"; + repo = "ocaml-chia-vdf"; + rev = "v${version}"; + hash = "sha256-KvpnX2DTUyfKARNWHC2lLBGH2Ou2GfRKjw05lu4jbBs="; + }; + + minimalOCamlVersion = "4.08"; + + nativeBuildInputs = [ + gmp + pkg-config + dune-configurator + ]; + + buildInputs = [ + dune-configurator + ]; + + propagatedBuildInputs = [ + zarith + integers + ]; + + checkInputs = [ + alcotest + bisect_ppx + ]; + + doCheck = true; + + meta = { + description = "Verifiable Delay Functions bindings to Chia's VDF"; + homepage = "https://gitlab.com/nomadic-labs/tezos"; + license = lib.licenses.mit; + maintainers = [ lib.maintainers.ulrikstrid ]; + }; + } + # Darwin sdk on intel target 10.12 (2016) at the time of writing. It is likely that host will be at least 10.14 (2018). This fix allow it to build and run on 10.14 and build on 10.12 (but don't run). + // + lib.optionalAttrs + ( + lib.versionOlder stdenv.hostPlatform.darwinMinVersion "10.14" + && stdenv.hostPlatform.isMacOS + && stdenv.hostPlatform.isx86_64 + ) + { + preHook = '' + export MACOSX_DEPLOYMENT_TARGET=10.14 + ''; + } +) diff --git a/pkgs/development/ocaml-modules/cmarkit/default.nix b/pkgs/development/ocaml-modules/cmarkit/default.nix index e2b6d054db10f9..7589b9dd9a7f36 100644 --- a/pkgs/development/ocaml-modules/cmarkit/default.nix +++ b/pkgs/development/ocaml-modules/cmarkit/default.nix @@ -1,48 +1,49 @@ -{ lib -, stdenv -, cmdliner -, fetchurl -, findlib -, ocaml -, ocamlbuild -, topkg +{ + lib, + stdenv, + cmdliner, + fetchurl, + findlib, + ocaml, + ocamlbuild, + topkg, }: -if lib.versionOlder ocaml.version "4.14.0" -then throw "cmarkit is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.14.0" then + throw "cmarkit is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "cmarkit"; - version = "0.3.0"; - - src = fetchurl { - url = "https://erratique.ch/software/cmarkit/releases/cmarkit-${version}.tbz"; - hash = "sha256-RouM5iU7VeTT0+4yhBgdEmxROeP/X31iqDjd1VI7z5c="; - }; - - nativeBuildInputs = [ - ocaml - findlib - ocamlbuild - topkg - ]; - - buildInputs = [ - topkg - cmdliner - ]; - - strictDeps = true; - - inherit (topkg) buildPhase installPhase; - - meta = with lib; { - description = "CommonMark parser and renderer for OCaml"; - homepage = "https://erratique.ch/software/cmarkit"; - changelog = "https://github.com/dbuenzli/cmarkit/blob/v${version}/CHANGES.md"; - license = licenses.isc; - maintainers = [ ]; - inherit (ocaml.meta) platforms; - }; -} + stdenv.mkDerivation rec { + pname = "cmarkit"; + version = "0.3.0"; + + src = fetchurl { + url = "https://erratique.ch/software/cmarkit/releases/cmarkit-${version}.tbz"; + hash = "sha256-RouM5iU7VeTT0+4yhBgdEmxROeP/X31iqDjd1VI7z5c="; + }; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + + buildInputs = [ + topkg + cmdliner + ]; + + strictDeps = true; + + inherit (topkg) buildPhase installPhase; + + meta = with lib; { + description = "CommonMark parser and renderer for OCaml"; + homepage = "https://erratique.ch/software/cmarkit"; + changelog = "https://github.com/dbuenzli/cmarkit/blob/v${version}/CHANGES.md"; + license = licenses.isc; + maintainers = [ ]; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/cmdliner/1_0.nix b/pkgs/development/ocaml-modules/cmdliner/1_0.nix index 62efd4a11eee16..ee57846783f9c0 100644 --- a/pkgs/development/ocaml-modules/cmdliner/1_0.nix +++ b/pkgs/development/ocaml-modules/cmdliner/1_0.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ocaml }: +{ + lib, + stdenv, + fetchurl, + ocaml, +}: assert (lib.versionAtLeast ocaml.version "4.03"); diff --git a/pkgs/development/ocaml-modules/cmdliner/1_1.nix b/pkgs/development/ocaml-modules/cmdliner/1_1.nix index b9639438c414f3..31ec0e69ef2fe8 100644 --- a/pkgs/development/ocaml-modules/cmdliner/1_1.nix +++ b/pkgs/development/ocaml-modules/cmdliner/1_1.nix @@ -1,34 +1,40 @@ -{ lib, stdenv, fetchurl, ocaml }: +{ + lib, + stdenv, + fetchurl, + ocaml, +}: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.08") "cmdliner 1.1 is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "cmdliner"; - version = "1.3.0"; + stdenv.mkDerivation + rec { + pname = "cmdliner"; + version = "1.3.0"; - src = fetchurl { - url = "https://erratique.ch/software/${pname}/releases/${pname}-${version}.tbz"; - sha256 = "sha256-joGA9XO0QPanqMII2rLK5KgjhP7HMtInhNG7bmQWjLs="; - }; + src = fetchurl { + url = "https://erratique.ch/software/${pname}/releases/${pname}-${version}.tbz"; + sha256 = "sha256-joGA9XO0QPanqMII2rLK5KgjhP7HMtInhNG7bmQWjLs="; + }; - nativeBuildInputs = [ ocaml ]; + nativeBuildInputs = [ ocaml ]; - makeFlags = [ "PREFIX=$(out)" ]; - installTargets = "install install-doc"; - installFlags = [ - "LIBDIR=$(out)/lib/ocaml/${ocaml.version}/site-lib/${pname}" - "DOCDIR=$(out)/share/doc/${pname}" - ]; - postInstall = '' - mv $out/lib/ocaml/${ocaml.version}/site-lib/${pname}/{opam,${pname}.opam} - ''; + makeFlags = [ "PREFIX=$(out)" ]; + installTargets = "install install-doc"; + installFlags = [ + "LIBDIR=$(out)/lib/ocaml/${ocaml.version}/site-lib/${pname}" + "DOCDIR=$(out)/share/doc/${pname}" + ]; + postInstall = '' + mv $out/lib/ocaml/${ocaml.version}/site-lib/${pname}/{opam,${pname}.opam} + ''; - meta = with lib; { - homepage = "https://erratique.ch/software/cmdliner"; - description = "OCaml module for the declarative definition of command line interfaces"; - license = licenses.isc; - inherit (ocaml.meta) platforms; - maintainers = [ maintainers.vbgl ]; - }; -} + meta = with lib; { + homepage = "https://erratique.ch/software/cmdliner"; + description = "OCaml module for the declarative definition of command line interfaces"; + license = licenses.isc; + inherit (ocaml.meta) platforms; + maintainers = [ maintainers.vbgl ]; + }; + } diff --git a/pkgs/development/ocaml-modules/cohttp/async.nix b/pkgs/development/ocaml-modules/cohttp/async.nix index 78367fcaba99a6..93a040b6ec7462 100644 --- a/pkgs/development/ocaml-modules/cohttp/async.nix +++ b/pkgs/development/ocaml-modules/cohttp/async.nix @@ -1,22 +1,23 @@ -{ buildDunePackage -, ppx_sexp_conv -, base -, async -, async_kernel -, async_unix -, cohttp -, conduit-async -, core_unix ? null -, uri -, uri-sexp -, logs -, fmt -, sexplib0 -, ipaddr -, magic-mime -, ounit -, mirage-crypto -, core +{ + buildDunePackage, + ppx_sexp_conv, + base, + async, + async_kernel, + async_unix, + cohttp, + conduit-async, + core_unix ? null, + uri, + uri-sexp, + logs, + fmt, + sexplib0, + ipaddr, + magic-mime, + ounit, + mirage-crypto, + core, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/cohttp/default.nix b/pkgs/development/ocaml-modules/cohttp/default.nix index 6f89c670c6b96f..8a3d0bd88f2336 100644 --- a/pkgs/development/ocaml-modules/cohttp/default.nix +++ b/pkgs/development/ocaml-modules/cohttp/default.nix @@ -1,7 +1,16 @@ -{ lib, fetchurl, buildDunePackage -, ppx_sexp_conv, base64, jsonm, re, stringext, uri-sexp -, fmt, alcotest -, crowbar +{ + lib, + fetchurl, + buildDunePackage, + ppx_sexp_conv, + base64, + jsonm, + re, + stringext, + uri-sexp, + fmt, + alcotest, + crowbar, }: buildDunePackage rec { @@ -19,12 +28,24 @@ buildDunePackage rec { substituteInPlace cohttp/src/dune --replace 'bytes base64' 'base64' ''; - buildInputs = [ jsonm ppx_sexp_conv ]; + buildInputs = [ + jsonm + ppx_sexp_conv + ]; - propagatedBuildInputs = [ base64 re stringext uri-sexp ]; + propagatedBuildInputs = [ + base64 + re + stringext + uri-sexp + ]; doCheck = true; - checkInputs = [ fmt alcotest crowbar ]; + checkInputs = [ + fmt + alcotest + crowbar + ]; meta = { description = "HTTP(S) library for Lwt, Async and Mirage"; diff --git a/pkgs/development/ocaml-modules/cohttp/lwt-jsoo.nix b/pkgs/development/ocaml-modules/cohttp/lwt-jsoo.nix index a1d349b647d50a..789466fa941053 100644 --- a/pkgs/development/ocaml-modules/cohttp/lwt-jsoo.nix +++ b/pkgs/development/ocaml-modules/cohttp/lwt-jsoo.nix @@ -1,6 +1,14 @@ -{ buildDunePackage -, cohttp, cohttp-lwt, logs, lwt, js_of_ocaml, js_of_ocaml-ppx, js_of_ocaml-lwt -, nodejs, lwt_ppx +{ + buildDunePackage, + cohttp, + cohttp-lwt, + logs, + lwt, + js_of_ocaml, + js_of_ocaml-ppx, + js_of_ocaml-lwt, + nodejs, + lwt_ppx, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/cohttp/lwt-unix.nix b/pkgs/development/ocaml-modules/cohttp/lwt-unix.nix index e7fecbefb91a0d..c8a77b57536f56 100644 --- a/pkgs/development/ocaml-modules/cohttp/lwt-unix.nix +++ b/pkgs/development/ocaml-modules/cohttp/lwt-unix.nix @@ -1,8 +1,15 @@ -{ buildDunePackage, cohttp-lwt -, conduit-lwt-unix, conduit-lwt, ppx_sexp_conv -, cmdliner, fmt, logs, magic-mime -, ounit -, cacert +{ + buildDunePackage, + cohttp-lwt, + conduit-lwt-unix, + conduit-lwt, + ppx_sexp_conv, + cmdliner, + fmt, + logs, + magic-mime, + ounit, + cacert, }: buildDunePackage { @@ -11,7 +18,10 @@ buildDunePackage { duneVersion = "3"; - buildInputs = [ cmdliner ppx_sexp_conv ]; + buildInputs = [ + cmdliner + ppx_sexp_conv + ]; propagatedBuildInputs = [ cohttp-lwt @@ -25,7 +35,10 @@ buildDunePackage { # TODO(@sternenseemann): fail for unknown reason # https://github.com/mirage/ocaml-cohttp/issues/675#issuecomment-830692742 doCheck = false; - checkInputs = [ ounit cacert ]; + checkInputs = [ + ounit + cacert + ]; meta = cohttp-lwt.meta // { description = "CoHTTP implementation for Unix and Windows using Lwt"; diff --git a/pkgs/development/ocaml-modules/cohttp/lwt.nix b/pkgs/development/ocaml-modules/cohttp/lwt.nix index 7d0678d8251d3d..4471ae205b1a82 100644 --- a/pkgs/development/ocaml-modules/cohttp/lwt.nix +++ b/pkgs/development/ocaml-modules/cohttp/lwt.nix @@ -1,4 +1,12 @@ -{ buildDunePackage, cohttp, lwt, uri, ppx_sexp_conv, logs, sexplib0 }: +{ + buildDunePackage, + cohttp, + lwt, + uri, + ppx_sexp_conv, + logs, + sexplib0, +}: buildDunePackage { pname = "cohttp-lwt"; @@ -12,7 +20,11 @@ buildDunePackage { buildInputs = [ ppx_sexp_conv ]; propagatedBuildInputs = [ - cohttp lwt logs sexplib0 uri + cohttp + lwt + logs + sexplib0 + uri ]; meta = cohttp.meta // { diff --git a/pkgs/development/ocaml-modules/coin/default.nix b/pkgs/development/ocaml-modules/coin/default.nix index b79a69e4321360..487c9f6c8c15d3 100644 --- a/pkgs/development/ocaml-modules/coin/default.nix +++ b/pkgs/development/ocaml-modules/coin/default.nix @@ -1,9 +1,10 @@ -{ buildDunePackage -, fetchurl -, findlib -, lib -, ocaml -, re +{ + buildDunePackage, + fetchurl, + findlib, + lib, + ocaml, + re, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/color/default.nix b/pkgs/development/ocaml-modules/color/default.nix index 84d2f11d8629dd..53a1c5273f8ca1 100644 --- a/pkgs/development/ocaml-modules/color/default.nix +++ b/pkgs/development/ocaml-modules/color/default.nix @@ -1,7 +1,8 @@ -{ lib -, fetchurl -, buildDunePackage -, gg +{ + lib, + fetchurl, + buildDunePackage, + gg, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/colors/default.nix b/pkgs/development/ocaml-modules/colors/default.nix index 2b7f5fbee3f47e..ad9f3532a49ff1 100644 --- a/pkgs/development/ocaml-modules/colors/default.nix +++ b/pkgs/development/ocaml-modules/colors/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildDunePackage -, fetchurl -, mdx +{ + lib, + buildDunePackage, + fetchurl, + mdx, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/conduit/async.nix b/pkgs/development/ocaml-modules/conduit/async.nix index 5d9475dbe0c5bf..c883cf181c8eab 100644 --- a/pkgs/development/ocaml-modules/conduit/async.nix +++ b/pkgs/development/ocaml-modules/conduit/async.nix @@ -1,5 +1,14 @@ -{ buildDunePackage, async, ppx_sexp_conv, ppx_here, uri, conduit -, core, ipaddr, ipaddr-sexp, sexplib0 +{ + buildDunePackage, + async, + ppx_sexp_conv, + ppx_here, + uri, + conduit, + core, + ipaddr, + ipaddr-sexp, + sexplib0, }: buildDunePackage { @@ -9,7 +18,10 @@ buildDunePackage { src ; - buildInputs = [ ppx_sexp_conv ppx_here ]; + buildInputs = [ + ppx_sexp_conv + ppx_here + ]; propagatedBuildInputs = [ async diff --git a/pkgs/development/ocaml-modules/conduit/default.nix b/pkgs/development/ocaml-modules/conduit/default.nix index 602e3919cb1fe1..de1159964fd170 100644 --- a/pkgs/development/ocaml-modules/conduit/default.nix +++ b/pkgs/development/ocaml-modules/conduit/default.nix @@ -1,6 +1,13 @@ -{ lib, fetchurl, buildDunePackage -, ppx_sexp_conv, sexplib0, astring, uri -, ipaddr, ipaddr-sexp +{ + lib, + fetchurl, + buildDunePackage, + ppx_sexp_conv, + sexplib0, + astring, + uri, + ipaddr, + ipaddr-sexp, }: buildDunePackage rec { @@ -14,12 +21,22 @@ buildDunePackage rec { hash = "sha256-Pg7ChIlqldF42NE1eS56Rssk+csK8OqWTQXO4avLEhg="; }; - propagatedBuildInputs = [ astring ipaddr ipaddr-sexp sexplib0 uri ppx_sexp_conv ]; + propagatedBuildInputs = [ + astring + ipaddr + ipaddr-sexp + sexplib0 + uri + ppx_sexp_conv + ]; meta = { description = "Network connection establishment library"; license = lib.licenses.isc; - maintainers = with lib.maintainers; [ alexfmpe vbgl ]; + maintainers = with lib.maintainers; [ + alexfmpe + vbgl + ]; homepage = "https://github.com/mirage/ocaml-conduit"; }; } diff --git a/pkgs/development/ocaml-modules/conduit/lwt-unix.nix b/pkgs/development/ocaml-modules/conduit/lwt-unix.nix index 4e614bfd40cb42..deba1080bb198e 100644 --- a/pkgs/development/ocaml-modules/conduit/lwt-unix.nix +++ b/pkgs/development/ocaml-modules/conduit/lwt-unix.nix @@ -1,6 +1,16 @@ -{ buildDunePackage -, conduit-lwt, ppx_sexp_conv, lwt, uri, ipaddr, ipaddr-sexp, ca-certs, logs -, lwt_ssl, lwt_log, ssl +{ + buildDunePackage, + conduit-lwt, + ppx_sexp_conv, + lwt, + uri, + ipaddr, + ipaddr-sexp, + ca-certs, + logs, + lwt_ssl, + lwt_log, + ssl, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/conduit/lwt.nix b/pkgs/development/ocaml-modules/conduit/lwt.nix index a81114ec4f7738..2b29b687a73160 100644 --- a/pkgs/development/ocaml-modules/conduit/lwt.nix +++ b/pkgs/development/ocaml-modules/conduit/lwt.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, ppx_sexp_conv, conduit, lwt, sexplib0 }: +{ + buildDunePackage, + ppx_sexp_conv, + conduit, + lwt, + sexplib0, +}: buildDunePackage { pname = "conduit-lwt"; @@ -6,7 +12,11 @@ buildDunePackage { buildInputs = [ ppx_sexp_conv ]; - propagatedBuildInputs = [ conduit lwt sexplib0 ]; + propagatedBuildInputs = [ + conduit + lwt + sexplib0 + ]; meta = conduit.meta // { description = "Network connection establishment library for Lwt"; diff --git a/pkgs/development/ocaml-modules/conduit/mirage.nix b/pkgs/development/ocaml-modules/conduit/mirage.nix index 02bb1e6649f449..41da2c2d8c271a 100644 --- a/pkgs/development/ocaml-modules/conduit/mirage.nix +++ b/pkgs/development/ocaml-modules/conduit/mirage.nix @@ -1,8 +1,24 @@ -{ buildDunePackage, conduit-lwt -, ppx_sexp_conv, sexplib0, uri, cstruct, mirage-flow -, mirage-flow-combinators, mirage-crypto-rng-mirage, mirage-time, mirage-clock -, dns-client-mirage, vchan, xenstore, tls, tls-mirage, ipaddr, ipaddr-sexp -, tcpip, ca-certs-nss +{ + buildDunePackage, + conduit-lwt, + ppx_sexp_conv, + sexplib0, + uri, + cstruct, + mirage-flow, + mirage-flow-combinators, + mirage-crypto-rng-mirage, + mirage-time, + mirage-clock, + dns-client-mirage, + vchan, + xenstore, + tls, + tls-mirage, + ipaddr, + ipaddr-sexp, + tcpip, + ca-certs-nss, }: buildDunePackage { @@ -13,10 +29,24 @@ buildDunePackage { nativeBuildInputs = [ ppx_sexp_conv ]; propagatedBuildInputs = [ - sexplib0 uri cstruct mirage-clock mirage-flow - mirage-flow-combinators mirage-crypto-rng-mirage mirage-time - dns-client-mirage conduit-lwt vchan xenstore tls tls-mirage - ipaddr ipaddr-sexp tcpip ca-certs-nss + sexplib0 + uri + cstruct + mirage-clock + mirage-flow + mirage-flow-combinators + mirage-crypto-rng-mirage + mirage-time + dns-client-mirage + conduit-lwt + vchan + xenstore + tls + tls-mirage + ipaddr + ipaddr-sexp + tcpip + ca-certs-nss ]; meta = conduit-lwt.meta // { diff --git a/pkgs/development/ocaml-modules/config-file/default.nix b/pkgs/development/ocaml-modules/config-file/default.nix index 46d513f62ddecc..f20a7d9b113f67 100644 --- a/pkgs/development/ocaml-modules/config-file/default.nix +++ b/pkgs/development/ocaml-modules/config-file/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchurl, ocaml, findlib, camlp4 }: +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + camlp4, +}: stdenv.mkDerivation rec { pname = "ocaml-config-file"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "1b02yxcnsjhr05ssh2br2ka4hxsjpdw34ldl3nk33wfnkwk7g67q"; }; - nativeBuildInputs = [ ocaml findlib camlp4 ]; + nativeBuildInputs = [ + ocaml + findlib + camlp4 + ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/config/default.nix b/pkgs/development/ocaml-modules/config/default.nix index 43ad500602ee7b..bd09b86be904b0 100644 --- a/pkgs/development/ocaml-modules/config/default.nix +++ b/pkgs/development/ocaml-modules/config/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildDunePackage -, fetchurl -, ppxlib -, spices +{ + lib, + buildDunePackage, + fetchurl, + ppxlib, + spices, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/containers/data.nix b/pkgs/development/ocaml-modules/containers/data.nix index 5d095049452204..243a60a7a2c6d0 100644 --- a/pkgs/development/ocaml-modules/containers/data.nix +++ b/pkgs/development/ocaml-modules/containers/data.nix @@ -1,8 +1,12 @@ -{ buildDunePackage, containers -, ocaml -, dune-configurator -, gen, iter, qcheck-core -, mdx +{ + buildDunePackage, + containers, + ocaml, + dune-configurator, + gen, + iter, + qcheck-core, + mdx, }: buildDunePackage { @@ -14,7 +18,11 @@ buildDunePackage { buildInputs = [ dune-configurator ]; nativeCheckInputs = [ mdx.bin ]; - checkInputs = [ gen iter qcheck-core ]; + checkInputs = [ + gen + iter + qcheck-core + ]; propagatedBuildInputs = [ containers ]; diff --git a/pkgs/development/ocaml-modules/containers/default.nix b/pkgs/development/ocaml-modules/containers/default.nix index fc56ad70bc7987..804cea216a4bb3 100644 --- a/pkgs/development/ocaml-modules/containers/default.nix +++ b/pkgs/development/ocaml-modules/containers/default.nix @@ -1,7 +1,16 @@ -{ lib, fetchFromGitHub, buildDunePackage, ocaml -, dune-configurator -, either, seq -, gen, iter, qcheck-core, uutf, yojson +{ + lib, + fetchFromGitHub, + buildDunePackage, + ocaml, + dune-configurator, + either, + seq, + gen, + iter, + qcheck-core, + uutf, + yojson, }: buildDunePackage rec { @@ -18,9 +27,18 @@ buildDunePackage rec { }; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ either seq ]; - - checkInputs = [ gen iter qcheck-core uutf yojson ]; + propagatedBuildInputs = [ + either + seq + ]; + + checkInputs = [ + gen + iter + qcheck-core + uutf + yojson + ]; doCheck = lib.versionAtLeast ocaml.version "4.08"; diff --git a/pkgs/development/ocaml-modules/cooltt/default.nix b/pkgs/development/ocaml-modules/cooltt/default.nix index cf322e74760d2a..b4f9e338c2bd94 100644 --- a/pkgs/development/ocaml-modules/cooltt/default.nix +++ b/pkgs/development/ocaml-modules/cooltt/default.nix @@ -1,22 +1,23 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, bos -, bwd -, cmdliner -, containers -, ezjsonm -, findlib -, menhir -, menhirLib -, ppx_deriving -, ppxlib -, uuseg -, uutf -, yuujinchou -, ounit2 -, qcheck -, qcheck-core +{ + lib, + fetchFromGitHub, + buildDunePackage, + bos, + bwd, + cmdliner, + containers, + ezjsonm, + findlib, + menhir, + menhirLib, + ppx_deriving, + ppxlib, + uuseg, + uutf, + yuujinchou, + ounit2, + qcheck, + qcheck-core, }: let @@ -30,7 +31,11 @@ let hash = "sha256-s6lUTs3VRl6YhLAn3PO4aniANhFp8ytoTsFAgcOlee4="; }; - propagatedBuildInputs = [ bos ezjsonm findlib ]; + propagatedBuildInputs = [ + bos + ezjsonm + findlib + ]; meta = { description = "Extensible Library Management and Path Resolution"; diff --git a/pkgs/development/ocaml-modules/cow/default.nix b/pkgs/development/ocaml-modules/cow/default.nix index eade22efc6e11f..7e9d1d1c662a72 100644 --- a/pkgs/development/ocaml-modules/cow/default.nix +++ b/pkgs/development/ocaml-modules/cow/default.nix @@ -1,5 +1,12 @@ -{ lib, fetchurl, buildDunePackage, alcotest -, uri, xmlm, omd, ezjsonm +{ + lib, + fetchurl, + buildDunePackage, + alcotest, + uri, + xmlm, + omd, + ezjsonm, }: buildDunePackage rec { @@ -14,7 +21,12 @@ buildDunePackage rec { sha256 = "1x77lwpskda4zyikwxh500xjn90pgdwz6jm7ca7f36pyav4vl6zx"; }; - propagatedBuildInputs = [ xmlm uri ezjsonm omd ]; + propagatedBuildInputs = [ + xmlm + uri + ezjsonm + omd + ]; checkInputs = [ alcotest ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/cpdf/default.nix b/pkgs/development/ocaml-modules/cpdf/default.nix index 0172efcc66a3dc..7e917482379d89 100644 --- a/pkgs/development/ocaml-modules/cpdf/default.nix +++ b/pkgs/development/ocaml-modules/cpdf/default.nix @@ -1,41 +1,52 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, findlib, camlpdf, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, + camlpdf, + ncurses, +}: -if lib.versionOlder ocaml.version "4.10" -then throw "cpdf is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.10" then + throw "cpdf is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-cpdf"; - version = "2.7.1"; + stdenv.mkDerivation rec { + pname = "ocaml${ocaml.version}-cpdf"; + version = "2.7.1"; - src = fetchFromGitHub { - owner = "johnwhitington"; - repo = "cpdf-source"; - rev = "v${version}"; - hash = "sha256-lFI7f1t70Pw0LJjDrhaB7yQKR1N5906xNYB+fnrz55M="; - }; + src = fetchFromGitHub { + owner = "johnwhitington"; + repo = "cpdf-source"; + rev = "v${version}"; + hash = "sha256-lFI7f1t70Pw0LJjDrhaB7yQKR1N5906xNYB+fnrz55M="; + }; - nativeBuildInputs = [ ocaml findlib ]; - buildInputs = [ ncurses ]; - propagatedBuildInputs = [ camlpdf ]; + nativeBuildInputs = [ + ocaml + findlib + ]; + buildInputs = [ ncurses ]; + propagatedBuildInputs = [ camlpdf ]; - strictDeps = true; + strictDeps = true; - preInstall = '' - mkdir -p $OCAMLFIND_DESTDIR - mkdir -p $out/bin - cp cpdf $out/bin - mkdir -p $out/share/ - cp -r doc $out/share - cp cpdfmanual.pdf $out/share/doc/cpdf/ - ''; + preInstall = '' + mkdir -p $OCAMLFIND_DESTDIR + mkdir -p $out/bin + cp cpdf $out/bin + mkdir -p $out/share/ + cp -r doc $out/share + cp cpdfmanual.pdf $out/share/doc/cpdf/ + ''; - meta = with lib; { - description = "PDF Command Line Tools"; - homepage = "https://www.coherentpdf.com/"; - license = licenses.agpl3Only; - maintainers = [ maintainers.vbgl ]; - mainProgram = "cpdf"; - inherit (ocaml.meta) platforms; - }; -} + meta = with lib; { + description = "PDF Command Line Tools"; + homepage = "https://www.coherentpdf.com/"; + license = licenses.agpl3Only; + maintainers = [ maintainers.vbgl ]; + mainProgram = "cpdf"; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/cpu/default.nix b/pkgs/development/ocaml-modules/cpu/default.nix index ee16765c1bcfb4..a93826b3449624 100644 --- a/pkgs/development/ocaml-modules/cpu/default.nix +++ b/pkgs/development/ocaml-modules/cpu/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, buildDunePackage, fetchFromGitHub, autoconf }: +{ + lib, + stdenv, + buildDunePackage, + fetchFromGitHub, + autoconf, +}: buildDunePackage rec { pname = "cpu"; @@ -8,8 +14,8 @@ buildDunePackage rec { src = fetchFromGitHub { owner = "UnixJunkie"; - repo = pname; - rev = "v${version}"; + repo = pname; + rev = "v${version}"; sha256 = "1vir6gh1bhvxgj2fcn69c38yhw3jgk7dyikmw789m5ld2csnyjiv"; }; diff --git a/pkgs/development/ocaml-modules/cpuid/default.nix b/pkgs/development/ocaml-modules/cpuid/default.nix index 7afbd843239904..eccb5aa9f026e4 100644 --- a/pkgs/development/ocaml-modules/cpuid/default.nix +++ b/pkgs/development/ocaml-modules/cpuid/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, buildDunePackage }: +{ + lib, + fetchurl, + buildDunePackage, +}: buildDunePackage rec { pname = "cpuid"; diff --git a/pkgs/development/ocaml-modules/crowbar/default.nix b/pkgs/development/ocaml-modules/crowbar/default.nix index 24ef96f57331b2..045df90d775df1 100644 --- a/pkgs/development/ocaml-modules/crowbar/default.nix +++ b/pkgs/development/ocaml-modules/crowbar/default.nix @@ -1,14 +1,27 @@ -{ lib, stdenv, buildDunePackage, fetchFromGitHub, ocplib-endian, cmdliner, afl-persistent -, calendar, fpath, pprint, uutf, uunf, uucp }: +{ + lib, + stdenv, + buildDunePackage, + fetchFromGitHub, + ocplib-endian, + cmdliner, + afl-persistent, + calendar, + fpath, + pprint, + uutf, + uunf, + uucp, +}: buildDunePackage rec { pname = "crowbar"; version = "0.2.1"; src = fetchFromGitHub { - owner = "stedolan"; - repo = pname; - rev = "v${version}"; + owner = "stedolan"; + repo = pname; + rev = "v${version}"; sha256 = "sha256-0jjwiOZ9Ut+dv5Iw4xNvf396WTehT1VClxY9VHicw4U="; }; @@ -17,8 +30,19 @@ buildDunePackage rec { # disable xmldiff tests, so we don't need to package unmaintained and legacy pkgs postPatch = "rm -rf examples/xmldiff"; - propagatedBuildInputs = [ ocplib-endian cmdliner afl-persistent ]; - checkInputs = [ calendar fpath pprint uutf uunf uucp ]; + propagatedBuildInputs = [ + ocplib-endian + cmdliner + afl-persistent + ]; + checkInputs = [ + calendar + fpath + pprint + uutf + uunf + uucp + ]; # uunf is broken on aarch64 doCheck = !stdenv.hostPlatform.isAarch64; @@ -29,4 +53,3 @@ buildDunePackage rec { maintainers = [ maintainers.sternenseemann ]; }; } - diff --git a/pkgs/development/ocaml-modules/cry/default.nix b/pkgs/development/ocaml-modules/cry/default.nix index 83a1d269060e3e..dfa64d096ceac1 100644 --- a/pkgs/development/ocaml-modules/cry/default.nix +++ b/pkgs/development/ocaml-modules/cry/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchFromGitHub }: +{ + lib, + buildDunePackage, + fetchFromGitHub, +}: buildDunePackage rec { pname = "cry"; diff --git a/pkgs/development/ocaml-modules/cryptgps/default.nix b/pkgs/development/ocaml-modules/cryptgps/default.nix index 60f64c3405431b..b69342f19add74 100644 --- a/pkgs/development/ocaml-modules/cryptgps/default.nix +++ b/pkgs/development/ocaml-modules/cryptgps/default.nix @@ -1,39 +1,48 @@ -{stdenv, lib, fetchurl, ocaml, findlib}: - -if lib.versionAtLeast ocaml.version "4.06" -then throw "cryptgps is not available for OCaml ${ocaml.version}" +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, +}: + +if lib.versionAtLeast ocaml.version "4.06" then + throw "cryptgps is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation { - pname = "ocaml-cryptgps"; - version = "0.2.1"; - - src = fetchurl { - url = "http://download.camlcity.org/download/cryptgps-0.2.1.tar.gz"; - sha256 = "1mp7i42cm9w9grmcsa69m3h1ycpn6a48p43y4xj8rsc12x9nav3s"; - }; - - nativeBuildInputs = [ ocaml findlib ]; + stdenv.mkDerivation { + pname = "ocaml-cryptgps"; + version = "0.2.1"; - strictDeps = true; + src = fetchurl { + url = "http://download.camlcity.org/download/cryptgps-0.2.1.tar.gz"; + sha256 = "1mp7i42cm9w9grmcsa69m3h1ycpn6a48p43y4xj8rsc12x9nav3s"; + }; - dontConfigure = true; # Skip configure phase - - createFindlibDestdir = true; - - meta = { - homepage = "http://projects.camlcity.org/projects/cryptgps.html"; - description = "Cryptographic functions for OCaml"; - longDescription = '' - This library implements the symmetric cryptographic algorithms - Blowfish, DES, and 3DES. The algorithms are written in O'Caml, - i.e. this is not a binding to some C library, but the implementation - itself. - ''; - license = lib.licenses.mit; - inherit (ocaml.meta) platforms; - maintainers = [ - lib.maintainers.maggesi + nativeBuildInputs = [ + ocaml + findlib ]; - }; -} + + strictDeps = true; + + dontConfigure = true; # Skip configure phase + + createFindlibDestdir = true; + + meta = { + homepage = "http://projects.camlcity.org/projects/cryptgps.html"; + description = "Cryptographic functions for OCaml"; + longDescription = '' + This library implements the symmetric cryptographic algorithms + Blowfish, DES, and 3DES. The algorithms are written in O'Caml, + i.e. this is not a binding to some C library, but the implementation + itself. + ''; + license = lib.licenses.mit; + inherit (ocaml.meta) platforms; + maintainers = [ + lib.maintainers.maggesi + ]; + }; + } diff --git a/pkgs/development/ocaml-modules/cryptokit/default.nix b/pkgs/development/ocaml-modules/cryptokit/default.nix index 157c2b4202905d..1de4fd6c0fd9e7 100644 --- a/pkgs/development/ocaml-modules/cryptokit/default.nix +++ b/pkgs/development/ocaml-modules/cryptokit/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub, zlib, dune-configurator, zarith }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + zlib, + dune-configurator, + zarith, +}: buildDunePackage rec { pname = "cryptokit"; @@ -9,7 +16,7 @@ buildDunePackage rec { src = fetchFromGitHub { owner = "xavierleroy"; repo = "cryptokit"; - rev = "release${lib.replaceStrings ["."] [""] version}"; + rev = "release${lib.replaceStrings [ "." ] [ "" ] version}"; hash = "sha256-VFY10jGctQfIUVv7dK06KP8zLZHLXTxvLyTCObS+W+E="; }; @@ -20,7 +27,10 @@ buildDunePackage rec { ''; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ zarith zlib ]; + propagatedBuildInputs = [ + zarith + zlib + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/csexp/default.nix b/pkgs/development/ocaml-modules/csexp/default.nix index f13e239a795ca0..5e47a4fcab6785 100644 --- a/pkgs/development/ocaml-modules/csexp/default.nix +++ b/pkgs/development/ocaml-modules/csexp/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, buildDunePackage, liquidsoap }: +{ + lib, + fetchurl, + buildDunePackage, + liquidsoap, +}: buildDunePackage rec { pname = "csexp"; diff --git a/pkgs/development/ocaml-modules/cstruct/async.nix b/pkgs/development/ocaml-modules/cstruct/async.nix index 53762abcc860b7..44ac3beb998539 100644 --- a/pkgs/development/ocaml-modules/cstruct/async.nix +++ b/pkgs/development/ocaml-modules/cstruct/async.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, cstruct, async_unix, async, core }: +{ + buildDunePackage, + cstruct, + async_unix, + async, + core, +}: buildDunePackage rec { pname = "cstruct-async"; diff --git a/pkgs/development/ocaml-modules/cstruct/default.nix b/pkgs/development/ocaml-modules/cstruct/default.nix index 9877adbcf81a58..8fac97fde6c9c3 100644 --- a/pkgs/development/ocaml-modules/cstruct/default.nix +++ b/pkgs/development/ocaml-modules/cstruct/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, buildDunePackage, fmt, alcotest, crowbar }: +{ + lib, + fetchurl, + buildDunePackage, + fmt, + alcotest, + crowbar, +}: buildDunePackage rec { pname = "cstruct"; @@ -15,7 +22,10 @@ buildDunePackage rec { buildInputs = [ fmt ]; doCheck = true; - checkInputs = [ alcotest crowbar ]; + checkInputs = [ + alcotest + crowbar + ]; meta = { description = "Access C-like structures directly from OCaml"; diff --git a/pkgs/development/ocaml-modules/cstruct/lwt.nix b/pkgs/development/ocaml-modules/cstruct/lwt.nix index 3aa70e5c9986d5..e040288583df5b 100644 --- a/pkgs/development/ocaml-modules/cstruct/lwt.nix +++ b/pkgs/development/ocaml-modules/cstruct/lwt.nix @@ -1,7 +1,12 @@ -{ lib, buildDunePackage, cstruct, lwt }: +{ + lib, + buildDunePackage, + cstruct, + lwt, +}: -if lib.versionOlder (cstruct.version or "1") "3" -then cstruct +if lib.versionOlder (cstruct.version or "1") "3" then + cstruct else buildDunePackage { @@ -11,5 +16,8 @@ else minimalOCamlVersion = "4.08"; duneVersion = "3"; - propagatedBuildInputs = [ cstruct lwt ]; + propagatedBuildInputs = [ + cstruct + lwt + ]; } diff --git a/pkgs/development/ocaml-modules/cstruct/ppx.nix b/pkgs/development/ocaml-modules/cstruct/ppx.nix index 1cae0cc3dea480..074b41df955530 100644 --- a/pkgs/development/ocaml-modules/cstruct/ppx.nix +++ b/pkgs/development/ocaml-modules/cstruct/ppx.nix @@ -1,10 +1,20 @@ -{ lib, buildDunePackage, ocaml, cstruct, sexplib, ppxlib -, ocaml-migrate-parsetree-2 -, ounit, cppo, ppx_sexp_conv, cstruct-unix, cstruct-sexp +{ + lib, + buildDunePackage, + ocaml, + cstruct, + sexplib, + ppxlib, + ocaml-migrate-parsetree-2, + ounit, + cppo, + ppx_sexp_conv, + cstruct-unix, + cstruct-sexp, }: -if lib.versionOlder (cstruct.version or "1") "3" -then cstruct +if lib.versionOlder (cstruct.version or "1") "3" then + cstruct else buildDunePackage { @@ -13,9 +23,19 @@ else minimalOCamlVersion = "4.08"; - propagatedBuildInputs = [ cstruct ppxlib sexplib ]; + propagatedBuildInputs = [ + cstruct + ppxlib + sexplib + ]; doCheck = !lib.versionAtLeast ocaml.version "5.1"; nativeCheckInputs = [ cppo ]; - checkInputs = [ ounit ppx_sexp_conv cstruct-sexp cstruct-unix ocaml-migrate-parsetree-2 ]; + checkInputs = [ + ounit + ppx_sexp_conv + cstruct-sexp + cstruct-unix + ocaml-migrate-parsetree-2 + ]; } diff --git a/pkgs/development/ocaml-modules/cstruct/sexp.nix b/pkgs/development/ocaml-modules/cstruct/sexp.nix index 3b28cda15afc1f..0b4b1e42f0e224 100644 --- a/pkgs/development/ocaml-modules/cstruct/sexp.nix +++ b/pkgs/development/ocaml-modules/cstruct/sexp.nix @@ -1,18 +1,28 @@ -{ lib, buildDunePackage, ocaml, alcotest, cstruct, sexplib }: +{ + lib, + buildDunePackage, + ocaml, + alcotest, + cstruct, + sexplib, +}: -if lib.versionOlder (cstruct.version or "1") "3" -then cstruct +if lib.versionOlder (cstruct.version or "1") "3" then + cstruct else -buildDunePackage rec { - pname = "cstruct-sexp"; - inherit (cstruct) version src meta; + buildDunePackage rec { + pname = "cstruct-sexp"; + inherit (cstruct) version src meta; - minimalOCamlVersion = "4.08"; - duneVersion = "3"; + minimalOCamlVersion = "4.08"; + duneVersion = "3"; - doCheck = true; - checkInputs = [ alcotest ]; + doCheck = true; + checkInputs = [ alcotest ]; - propagatedBuildInputs = [ cstruct sexplib ]; -} + propagatedBuildInputs = [ + cstruct + sexplib + ]; + } diff --git a/pkgs/development/ocaml-modules/cstruct/unix.nix b/pkgs/development/ocaml-modules/cstruct/unix.nix index 40467a77a57fe0..8f3e139563d90a 100644 --- a/pkgs/development/ocaml-modules/cstruct/unix.nix +++ b/pkgs/development/ocaml-modules/cstruct/unix.nix @@ -1,7 +1,11 @@ -{ lib, buildDunePackage, cstruct }: +{ + lib, + buildDunePackage, + cstruct, +}: -if lib.versionOlder (cstruct.version or "1") "3" -then cstruct +if lib.versionOlder (cstruct.version or "1") "3" then + cstruct else buildDunePackage { diff --git a/pkgs/development/ocaml-modules/csv/csvtool.nix b/pkgs/development/ocaml-modules/csv/csvtool.nix index d1705e9fd5cf9c..9c7eb763f64abc 100644 --- a/pkgs/development/ocaml-modules/csv/csvtool.nix +++ b/pkgs/development/ocaml-modules/csv/csvtool.nix @@ -1,6 +1,8 @@ { ocamlPackages }: -let inherit (ocamlPackages) buildDunePackage csv uutf; in +let + inherit (ocamlPackages) buildDunePackage csv uutf; +in buildDunePackage { pname = "csvtool"; @@ -8,7 +10,10 @@ buildDunePackage { duneVersion = "3"; - buildInputs = [ csv uutf ]; + buildInputs = [ + csv + uutf + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/csv/default.nix b/pkgs/development/ocaml-modules/csv/default.nix index 0846a35798557f..f3aa531ddefe23 100644 --- a/pkgs/development/ocaml-modules/csv/default.nix +++ b/pkgs/development/ocaml-modules/csv/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, buildDunePackage }: +{ + lib, + fetchurl, + buildDunePackage, +}: buildDunePackage rec { pname = "csv"; diff --git a/pkgs/development/ocaml-modules/csv/lwt.nix b/pkgs/development/ocaml-modules/csv/lwt.nix index 7dfe01d137e576..29d91a38554b31 100644 --- a/pkgs/development/ocaml-modules/csv/lwt.nix +++ b/pkgs/development/ocaml-modules/csv/lwt.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, csv, lwt }: +{ + buildDunePackage, + csv, + lwt, +}: buildDunePackage { pname = "csv-lwt"; @@ -10,7 +14,10 @@ buildDunePackage { duneVersion = "3"; - propagatedBuildInputs = [ csv lwt ]; + propagatedBuildInputs = [ + csv + lwt + ]; doCheck = true; } diff --git a/pkgs/development/ocaml-modules/ctypes/default.nix b/pkgs/development/ocaml-modules/ctypes/default.nix index cb6414a7a4cf82..2db0438c76592d 100644 --- a/pkgs/development/ocaml-modules/ctypes/default.nix +++ b/pkgs/development/ocaml-modules/ctypes/default.nix @@ -1,11 +1,12 @@ -{ lib -, ocaml -, fetchFromGitHub -, buildDunePackage -, dune-configurator -, integers -, bigarray-compat -, ounit2 +{ + lib, + ocaml, + fetchFromGitHub, + buildDunePackage, + dune-configurator, + integers, + bigarray-compat, + ounit2, }: buildDunePackage rec { @@ -21,7 +22,10 @@ buildDunePackage rec { buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ integers bigarray-compat ]; + propagatedBuildInputs = [ + integers + bigarray-compat + ]; doCheck = lib.versionAtLeast ocaml.version "4.08"; checkInputs = [ ounit2 ]; diff --git a/pkgs/development/ocaml-modules/ctypes/foreign.nix b/pkgs/development/ocaml-modules/ctypes/foreign.nix index 5c9efad790f245..1e082bff94dcd1 100644 --- a/pkgs/development/ocaml-modules/ctypes/foreign.nix +++ b/pkgs/development/ocaml-modules/ctypes/foreign.nix @@ -1,9 +1,10 @@ -{ buildDunePackage -, ctypes -, dune-configurator -, libffi -, ounit2 -, lwt +{ + buildDunePackage, + ctypes, + dune-configurator, + libffi, + ounit2, + lwt, }: buildDunePackage rec { @@ -13,9 +14,15 @@ buildDunePackage rec { buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ ctypes libffi ]; + propagatedBuildInputs = [ + ctypes + libffi + ]; - checkInputs = [ ounit2 lwt ]; + checkInputs = [ + ounit2 + lwt + ]; meta = ctypes.meta // { description = "Dynamic access to foreign C libraries using Ctypes"; diff --git a/pkgs/development/ocaml-modules/ctypes_stubs_js/default.nix b/pkgs/development/ocaml-modules/ctypes_stubs_js/default.nix index 171b084829408d..2b4ce1472e94fb 100644 --- a/pkgs/development/ocaml-modules/ctypes_stubs_js/default.nix +++ b/pkgs/development/ocaml-modules/ctypes_stubs_js/default.nix @@ -1,8 +1,13 @@ { - lib, fetchFromGitLab, buildDunePackage -, integers_stubs_js, ctypes, ppx_expect -, js_of_ocaml-compiler -, nodejs, stdenv + lib, + fetchFromGitLab, + buildDunePackage, + integers_stubs_js, + ctypes, + ppx_expect, + js_of_ocaml-compiler, + nodejs, + stdenv, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/cudf/default.nix b/pkgs/development/ocaml-modules/cudf/default.nix index dae074b05fac5e..40cb979e50adbd 100644 --- a/pkgs/development/ocaml-modules/cudf/default.nix +++ b/pkgs/development/ocaml-modules/cudf/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, ocaml, fetchFromGitLab, extlib, ounit2 }: +{ + lib, + buildDunePackage, + ocaml, + fetchFromGitLab, + extlib, + ounit2, +}: buildDunePackage rec { pname = "cudf"; diff --git a/pkgs/development/ocaml-modules/curly/default.nix b/pkgs/development/ocaml-modules/curly/default.nix index 229ad666cb24a9..0ab7922e674722 100644 --- a/pkgs/development/ocaml-modules/curly/default.nix +++ b/pkgs/development/ocaml-modules/curly/default.nix @@ -1,5 +1,14 @@ -{ stdenv, lib, buildDunePackage, fetchurl, ocaml -, result, alcotest, cohttp-lwt-unix, curl, cacert +{ + stdenv, + lib, + buildDunePackage, + fetchurl, + ocaml, + result, + alcotest, + cohttp-lwt-unix, + curl, + cacert, }: buildDunePackage rec { @@ -17,10 +26,14 @@ buildDunePackage rec { propagatedBuildInputs = [ result ]; nativeCheckInputs = [ cacert ]; - checkInputs = [ alcotest cohttp-lwt-unix ]; + checkInputs = [ + alcotest + cohttp-lwt-unix + ]; # test dependencies are only available for >= 4.08 # https://github.com/mirage/ca-certs/issues/16 - doCheck = lib.versionAtLeast ocaml.version "4.08" + doCheck = + lib.versionAtLeast ocaml.version "4.08" # Some test fails in macOS sandbox # > Fatal error: exception Unix.Unix_error(Unix.EPERM, "bind", "") && !stdenv.hostPlatform.isDarwin; @@ -28,7 +41,7 @@ buildDunePackage rec { postPatch = '' substituteInPlace src/curly.ml \ --replace "exe=\"curl\"" "exe=\"${curl}/bin/curl\"" - ''; + ''; meta = with lib; { description = "Curly is a brain dead wrapper around the curl command line utility"; @@ -37,4 +50,3 @@ buildDunePackage rec { maintainers = [ maintainers.sternenseemann ]; }; } - diff --git a/pkgs/development/ocaml-modules/curses/default.nix b/pkgs/development/ocaml-modules/curses/default.nix index 23c098aedcb5d7..7825a51b92b119 100644 --- a/pkgs/development/ocaml-modules/curses/default.nix +++ b/pkgs/development/ocaml-modules/curses/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, findlib, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, + ncurses, +}: stdenv.mkDerivation rec { pname = "ocaml-curses"; @@ -15,7 +22,10 @@ stdenv.mkDerivation rec { propagatedBuildInputs = [ ncurses ]; - nativeBuildInputs = [ ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; # Fix build for recent ncurses versions env.NIX_CFLAGS_COMPILE = "-DNCURSES_INTERNALS=1"; diff --git a/pkgs/development/ocaml-modules/dap/default.nix b/pkgs/development/ocaml-modules/dap/default.nix index 054020ba64e080..c10229c62d3f24 100644 --- a/pkgs/development/ocaml-modules/dap/default.nix +++ b/pkgs/development/ocaml-modules/dap/default.nix @@ -1,5 +1,15 @@ -{ lib, buildDunePackage, fetchurl -, angstrom-lwt-unix, lwt, logs, lwt_ppx, ppx_deriving_yojson, ppx_expect, ppx_here, react +{ + lib, + buildDunePackage, + fetchurl, + angstrom-lwt-unix, + lwt, + logs, + lwt_ppx, + ppx_deriving_yojson, + ppx_expect, + ppx_here, + react, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/data-encoding/default.nix b/pkgs/development/ocaml-modules/data-encoding/default.nix index 75490c9648db8b..0a893686fe91d6 100644 --- a/pkgs/development/ocaml-modules/data-encoding/default.nix +++ b/pkgs/development/ocaml-modules/data-encoding/default.nix @@ -1,15 +1,16 @@ -{ lib -, buildDunePackage -, ppx_hash -, bigstringaf -, either -, ezjsonm -, zarith -, zarith_stubs_js ? null -, hex -, json-data-encoding -, json-data-encoding-bson -, ppx_expect +{ + lib, + buildDunePackage, + ppx_hash, + bigstringaf, + either, + ezjsonm, + zarith, + zarith_stubs_js ? null, + hex, + json-data-encoding, + json-data-encoding-bson, + ppx_expect, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/dates_calc/default.nix b/pkgs/development/ocaml-modules/dates_calc/default.nix index e1def37250e799..4cfeeb34956ff4 100644 --- a/pkgs/development/ocaml-modules/dates_calc/default.nix +++ b/pkgs/development/ocaml-modules/dates_calc/default.nix @@ -1,5 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage -, alcotest, qcheck +{ + lib, + fetchFromGitHub, + buildDunePackage, + alcotest, + qcheck, }: buildDunePackage rec { @@ -16,7 +20,7 @@ buildDunePackage rec { sha256 = "sha256-B4li8vIK6AnPXJ1QSJ8rtr+JOcy4+h5sc1SH97U+Vgw="; }; - propagatedBuildInputs = []; + propagatedBuildInputs = [ ]; doCheck = true; checkInputs = [ diff --git a/pkgs/development/ocaml-modules/dbf/default.nix b/pkgs/development/ocaml-modules/dbf/default.nix index 91981fd735cb45..e02b13291ecd97 100644 --- a/pkgs/development/ocaml-modules/dbf/default.nix +++ b/pkgs/development/ocaml-modules/dbf/default.nix @@ -1,5 +1,12 @@ -{ lib, buildDunePackage, fetchFromGitHub, ppx_cstruct, rresult, cstruct-unix -, core_kernel }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + ppx_cstruct, + rresult, + cstruct-unix, + core_kernel, +}: buildDunePackage rec { pname = "dbf"; @@ -17,7 +24,11 @@ buildDunePackage rec { }; buildInputs = [ ppx_cstruct ]; - propagatedBuildInputs = [ rresult cstruct-unix core_kernel ]; + propagatedBuildInputs = [ + rresult + cstruct-unix + core_kernel + ]; meta = with lib; { description = "DBF format parsing"; diff --git a/pkgs/development/ocaml-modules/decompress/default.nix b/pkgs/development/ocaml-modules/decompress/default.nix index b20ef17d08b97c..470d357997b56c 100644 --- a/pkgs/development/ocaml-modules/decompress/default.nix +++ b/pkgs/development/ocaml-modules/decompress/default.nix @@ -1,7 +1,20 @@ -{ lib, fetchurl, buildDunePackage -, checkseum, optint, cmdliner -, bigstringaf, alcotest, camlzip, base64, ctypes, fmt, crowbar, rresult -, astring, bos +{ + lib, + fetchurl, + buildDunePackage, + checkseum, + optint, + cmdliner, + bigstringaf, + alcotest, + camlzip, + base64, + ctypes, + fmt, + crowbar, + rresult, + astring, + bos, }: buildDunePackage rec { @@ -16,8 +29,22 @@ buildDunePackage rec { }; buildInputs = [ cmdliner ]; - propagatedBuildInputs = [ optint checkseum ]; - checkInputs = [ alcotest astring bigstringaf bos ctypes fmt camlzip base64 crowbar rresult ]; + propagatedBuildInputs = [ + optint + checkseum + ]; + checkInputs = [ + alcotest + astring + bigstringaf + bos + ctypes + fmt + camlzip + base64 + crowbar + rresult + ]; doCheck = true; meta = { diff --git a/pkgs/development/ocaml-modules/dedukti/default.nix b/pkgs/development/ocaml-modules/dedukti/default.nix index 8f6305824f4ffc..9c5ef6de01dedb 100644 --- a/pkgs/development/ocaml-modules/dedukti/default.nix +++ b/pkgs/development/ocaml-modules/dedukti/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, cmdliner -, menhir +{ + lib, + fetchFromGitHub, + buildDunePackage, + cmdliner, + menhir, }: buildDunePackage rec { @@ -21,7 +22,7 @@ buildDunePackage rec { nativeBuildInputs = [ menhir ]; buildInputs = [ cmdliner ]; - doCheck = false; # requires `tezt` + doCheck = false; # requires `tezt` meta = with lib; { homepage = "https://deducteam.github.io"; diff --git a/pkgs/development/ocaml-modules/diet/default.nix b/pkgs/development/ocaml-modules/diet/default.nix index 5be9cde836617b..5e78e03f568337 100644 --- a/pkgs/development/ocaml-modules/diet/default.nix +++ b/pkgs/development/ocaml-modules/diet/default.nix @@ -1,12 +1,18 @@ -{ lib, buildDunePackage, fetchurl, ocaml, stdlib-shims, ounit }: +{ + lib, + buildDunePackage, + fetchurl, + ocaml, + stdlib-shims, + ounit, +}: buildDunePackage rec { pname = "diet"; version = "0.4"; src = fetchurl { - url = - "https://github.com/mirage/ocaml-diet/releases/download/v${version}/diet-v${version}.tbz"; + url = "https://github.com/mirage/ocaml-diet/releases/download/v${version}/diet-v${version}.tbz"; sha256 = "96acac2e4fdedb5f47dd8ad2562e723d85ab59cd1bd85554df21ec907b071741"; }; diff --git a/pkgs/development/ocaml-modules/digestif/default.nix b/pkgs/development/ocaml-modules/digestif/default.nix index 9f859b182831a6..2512e2a7364df8 100644 --- a/pkgs/development/ocaml-modules/digestif/default.nix +++ b/pkgs/development/ocaml-modules/digestif/default.nix @@ -1,6 +1,15 @@ -{ lib, ocaml, fetchurl, buildDunePackage -, eqaf -, alcotest, astring, bos, crowbar, findlib, fpath +{ + lib, + ocaml, + fetchurl, + buildDunePackage, + eqaf, + alcotest, + astring, + bos, + crowbar, + findlib, + fpath, }: buildDunePackage rec { @@ -16,7 +25,13 @@ buildDunePackage rec { propagatedBuildInputs = [ eqaf ]; - checkInputs = [ alcotest astring bos crowbar fpath ]; + checkInputs = [ + alcotest + astring + bos + crowbar + fpath + ]; doCheck = true; postCheck = '' diff --git a/pkgs/development/ocaml-modules/directories/default.nix b/pkgs/development/ocaml-modules/directories/default.nix index 5f86db245470d3..e90a1ce19222f9 100644 --- a/pkgs/development/ocaml-modules/directories/default.nix +++ b/pkgs/development/ocaml-modules/directories/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage }: +{ + lib, + fetchFromGitHub, + buildDunePackage, +}: buildDunePackage rec { pname = "directories"; diff --git a/pkgs/development/ocaml-modules/dispatch/default.nix b/pkgs/development/ocaml-modules/dispatch/default.nix index 958574f3d973a9..b5546a406c3db1 100644 --- a/pkgs/development/ocaml-modules/dispatch/default.nix +++ b/pkgs/development/ocaml-modules/dispatch/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub, ocaml, alcotest, result }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + ocaml, + alcotest, + result, +}: buildDunePackage rec { pname = "dispatch"; diff --git a/pkgs/development/ocaml-modules/dns/certify.nix b/pkgs/development/ocaml-modules/dns/certify.nix index fff97dafed3266..d289f8bc57b1bd 100644 --- a/pkgs/development/ocaml-modules/dns/certify.nix +++ b/pkgs/development/ocaml-modules/dns/certify.nix @@ -1,7 +1,18 @@ -{ buildDunePackage, dns, dns-tsig, dns-mirage, randomconv, x509 -, mirage-time, mirage-clock -, logs, mirage-crypto-pk, mirage-crypto-rng-mirage, mirage-crypto-ec, lwt -, tcpip +{ + buildDunePackage, + dns, + dns-tsig, + dns-mirage, + randomconv, + x509, + mirage-time, + mirage-clock, + logs, + mirage-crypto-pk, + mirage-crypto-rng-mirage, + mirage-crypto-ec, + lwt, + tcpip, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/dns/cli.nix b/pkgs/development/ocaml-modules/dns/cli.nix index e08a29756a2fee..fad820b460f28f 100644 --- a/pkgs/development/ocaml-modules/dns/cli.nix +++ b/pkgs/development/ocaml-modules/dns/cli.nix @@ -1,7 +1,27 @@ -{ buildDunePackage, dns, dns-tsig, dns-client-lwt, dns-server, dns-certify, dnssec -, bos, cmdliner, fpath, x509, mirage-crypto, mirage-crypto-pk -, mirage-crypto-rng, ohex, ptime, mtime, logs, fmt, ipaddr, lwt -, randomconv, alcotest +{ + buildDunePackage, + dns, + dns-tsig, + dns-client-lwt, + dns-server, + dns-certify, + dnssec, + bos, + cmdliner, + fpath, + x509, + mirage-crypto, + mirage-crypto-pk, + mirage-crypto-rng, + ohex, + ptime, + mtime, + logs, + fmt, + ipaddr, + lwt, + randomconv, + alcotest, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/dns/client-lwt.nix b/pkgs/development/ocaml-modules/dns/client-lwt.nix index 3c9c126e1d1b8d..0daa7a6299d792 100644 --- a/pkgs/development/ocaml-modules/dns/client-lwt.nix +++ b/pkgs/development/ocaml-modules/dns/client-lwt.nix @@ -1,10 +1,16 @@ -{ buildDunePackage, dns, dns-client, lwt -, mirage-crypto-rng-lwt, mtime -, ipaddr, alcotest -, ca-certs -, happy-eyeballs -, happy-eyeballs-lwt -, tls-lwt +{ + buildDunePackage, + dns, + dns-client, + lwt, + mirage-crypto-rng-lwt, + mtime, + ipaddr, + alcotest, + ca-certs, + happy-eyeballs, + happy-eyeballs-lwt, + tls-lwt, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/dns/client-mirage.nix b/pkgs/development/ocaml-modules/dns/client-mirage.nix index f9159df2f940d4..77e999e5e71398 100644 --- a/pkgs/development/ocaml-modules/dns/client-mirage.nix +++ b/pkgs/development/ocaml-modules/dns/client-mirage.nix @@ -1,11 +1,19 @@ -{ buildDunePackage, dns, dns-client, lwt, mirage-clock, mirage-time -, mirage-crypto-rng-mirage -, domain-name, ipaddr -, ca-certs-nss -, happy-eyeballs -, happy-eyeballs-mirage -, tcpip -, tls, tls-mirage +{ + buildDunePackage, + dns, + dns-client, + lwt, + mirage-clock, + mirage-time, + mirage-crypto-rng-mirage, + domain-name, + ipaddr, + ca-certs-nss, + happy-eyeballs, + happy-eyeballs-mirage, + tcpip, + tls, + tls-mirage, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/dns/client.nix b/pkgs/development/ocaml-modules/dns/client.nix index 10d79ef93ad7c2..956866037629ae 100644 --- a/pkgs/development/ocaml-modules/dns/client.nix +++ b/pkgs/development/ocaml-modules/dns/client.nix @@ -1,6 +1,11 @@ -{ buildDunePackage, dns -, mirage-crypto-rng, mtime, randomconv -, domain-name, alcotest +{ + buildDunePackage, + dns, + mirage-crypto-rng, + mtime, + randomconv, + domain-name, + alcotest, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/dns/default.nix b/pkgs/development/ocaml-modules/dns/default.nix index bcc67a6f6ebf96..3d6fb07fb35be2 100644 --- a/pkgs/development/ocaml-modules/dns/default.nix +++ b/pkgs/development/ocaml-modules/dns/default.nix @@ -1,18 +1,19 @@ -{ lib -, buildDunePackage -, fetchurl -, alcotest -, domain-name -, duration -, gmap -, ipaddr -, logs -, lru -, metrics -, ptime -, fmt -, base64 -, ohex +{ + lib, + buildDunePackage, + fetchurl, + alcotest, + domain-name, + duration, + gmap, + ipaddr, + logs, + lru, + metrics, + ptime, + fmt, + base64, + ohex, }: buildDunePackage rec { @@ -26,7 +27,19 @@ buildDunePackage rec { hash = "sha256-jz7JWs8U9XQhm1RAponq4azCpJyx2KBm+bI6esaPRPA="; }; - propagatedBuildInputs = [ fmt logs ptime domain-name gmap ipaddr lru duration metrics base64 ohex ]; + propagatedBuildInputs = [ + fmt + logs + ptime + domain-name + gmap + ipaddr + lru + duration + metrics + base64 + ohex + ]; doCheck = true; checkInputs = [ alcotest ]; diff --git a/pkgs/development/ocaml-modules/dns/dnssec.nix b/pkgs/development/ocaml-modules/dns/dnssec.nix index 16a5f34490418a..c83b89a5f93794 100644 --- a/pkgs/development/ocaml-modules/dns/dnssec.nix +++ b/pkgs/development/ocaml-modules/dns/dnssec.nix @@ -1,12 +1,13 @@ -{ buildDunePackage -, dns -, mirage-crypto -, mirage-crypto-pk -, mirage-crypto-ec -, domain-name -, logs -, alcotest -, base64 +{ + buildDunePackage, + dns, + mirage-crypto, + mirage-crypto-pk, + mirage-crypto-ec, + domain-name, + logs, + alcotest, + base64, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/dns/mirage.nix b/pkgs/development/ocaml-modules/dns/mirage.nix index 2040a56a67665c..fddf48ad739905 100644 --- a/pkgs/development/ocaml-modules/dns/mirage.nix +++ b/pkgs/development/ocaml-modules/dns/mirage.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, dns, ipaddr, lwt, tcpip }: +{ + buildDunePackage, + dns, + ipaddr, + lwt, + tcpip, +}: buildDunePackage { pname = "dns-mirage"; diff --git a/pkgs/development/ocaml-modules/dns/resolver.nix b/pkgs/development/ocaml-modules/dns/resolver.nix index 04611a738d74e2..3fb9446f7ac3f0 100644 --- a/pkgs/development/ocaml-modules/dns/resolver.nix +++ b/pkgs/development/ocaml-modules/dns/resolver.nix @@ -1,19 +1,20 @@ -{ buildDunePackage -, dns -, dns-server -, dns-mirage -, lru -, duration -, randomconv -, lwt -, mirage-time -, mirage-clock -, mirage-random -, tcpip -, tls -, tls-mirage -, dnssec -, alcotest +{ + buildDunePackage, + dns, + dns-server, + dns-mirage, + lru, + duration, + randomconv, + lwt, + mirage-time, + mirage-clock, + mirage-random, + tcpip, + tls, + tls-mirage, + dnssec, + alcotest, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/dns/server.nix b/pkgs/development/ocaml-modules/dns/server.nix index 09019bf655aa62..3fcbda761bd426 100644 --- a/pkgs/development/ocaml-modules/dns/server.nix +++ b/pkgs/development/ocaml-modules/dns/server.nix @@ -1,16 +1,17 @@ -{ buildDunePackage -, dns -, dns-mirage -, randomconv -, duration -, lwt -, mirage-time -, mirage-clock -, metrics -, alcotest -, mirage-crypto-rng -, dns-tsig -, base64 +{ + buildDunePackage, + dns, + dns-mirage, + randomconv, + duration, + lwt, + mirage-time, + mirage-clock, + metrics, + alcotest, + mirage-crypto-rng, + dns-tsig, + base64, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/dns/stub.nix b/pkgs/development/ocaml-modules/dns/stub.nix index 23ad5539c58692..f98b79a11bc211 100644 --- a/pkgs/development/ocaml-modules/dns/stub.nix +++ b/pkgs/development/ocaml-modules/dns/stub.nix @@ -1,6 +1,19 @@ -{ buildDunePackage, dns, dns-client-mirage, dns-mirage, dns-resolver, dns-tsig -, dns-server, duration, randomconv, lwt, mirage-time, mirage-clock -, mirage-crypto-rng-mirage, tcpip, metrics +{ + buildDunePackage, + dns, + dns-client-mirage, + dns-mirage, + dns-resolver, + dns-tsig, + dns-server, + duration, + randomconv, + lwt, + mirage-time, + mirage-clock, + mirage-crypto-rng-mirage, + tcpip, + metrics, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/dns/tsig.nix b/pkgs/development/ocaml-modules/dns/tsig.nix index 2d967301d25a79..84481564bfb46a 100644 --- a/pkgs/development/ocaml-modules/dns/tsig.nix +++ b/pkgs/development/ocaml-modules/dns/tsig.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, dns, digestif, base64, alcotest }: +{ + buildDunePackage, + dns, + digestif, + base64, + alcotest, +}: buildDunePackage { pname = "dns-tsig"; diff --git a/pkgs/development/ocaml-modules/dolmen/default.nix b/pkgs/development/ocaml-modules/dolmen/default.nix index ccecc8a33f764d..5bb495f8335a7b 100644 --- a/pkgs/development/ocaml-modules/dolmen/default.nix +++ b/pkgs/development/ocaml-modules/dolmen/default.nix @@ -1,8 +1,12 @@ -{ lib, fetchurl, buildDunePackage -, menhir, menhirLib -, fmt -, hmap -, qcheck +{ + lib, + fetchurl, + buildDunePackage, + menhir, + menhirLib, + fmt, + hmap, + qcheck, }: buildDunePackage rec { @@ -17,7 +21,11 @@ buildDunePackage rec { }; nativeBuildInputs = [ menhir ]; - propagatedBuildInputs = [ menhirLib fmt hmap ]; + propagatedBuildInputs = [ + menhirLib + fmt + hmap + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/dolmen/loop.nix b/pkgs/development/ocaml-modules/dolmen/loop.nix index 572c161edc49e8..0b3ca565d81f38 100644 --- a/pkgs/development/ocaml-modules/dolmen/loop.nix +++ b/pkgs/development/ocaml-modules/dolmen/loop.nix @@ -1,14 +1,22 @@ -{ buildDunePackage, dolmen, dolmen_type -, gen -, pp_loc -, mdx +{ + buildDunePackage, + dolmen, + dolmen_type, + gen, + pp_loc, + mdx, }: buildDunePackage { pname = "dolmen_loop"; inherit (dolmen) src version; - propagatedBuildInputs = [ dolmen dolmen_type gen pp_loc ]; + propagatedBuildInputs = [ + dolmen + dolmen_type + gen + pp_loc + ]; doCheck = true; nativeCheckInputs = [ mdx.bin ]; diff --git a/pkgs/development/ocaml-modules/dolmen/type.nix b/pkgs/development/ocaml-modules/dolmen/type.nix index 79b84fd1f0f065..3be6cdf3805a2f 100644 --- a/pkgs/development/ocaml-modules/dolmen/type.nix +++ b/pkgs/development/ocaml-modules/dolmen/type.nix @@ -1,13 +1,19 @@ -{ buildDunePackage, dolmen -, spelll -, uutf +{ + buildDunePackage, + dolmen, + spelll, + uutf, }: buildDunePackage { pname = "dolmen_type"; inherit (dolmen) src version; - propagatedBuildInputs = [ dolmen spelll uutf ]; + propagatedBuildInputs = [ + dolmen + spelll + uutf + ]; meta = dolmen.meta // { description = "Typechecker for automated deduction languages"; diff --git a/pkgs/development/ocaml-modules/dolog/default.nix b/pkgs/development/ocaml-modules/dolog/default.nix index cd3b0bffd29066..c5c9323de4e076 100644 --- a/pkgs/development/ocaml-modules/dolog/default.nix +++ b/pkgs/development/ocaml-modules/dolog/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchFromGitHub }: +{ + lib, + buildDunePackage, + fetchFromGitHub, +}: buildDunePackage rec { pname = "dolog"; diff --git a/pkgs/development/ocaml-modules/domain-local-await/default.nix b/pkgs/development/ocaml-modules/domain-local-await/default.nix index a9b5f76839aec0..854acc25f5e6be 100644 --- a/pkgs/development/ocaml-modules/domain-local-await/default.nix +++ b/pkgs/development/ocaml-modules/domain-local-await/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildDunePackage -, fetchurl -, alcotest -, domain_shims -, mdx -, thread-table +{ + lib, + buildDunePackage, + fetchurl, + alcotest, + domain_shims, + mdx, + thread-table, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/domain-local-timeout/default.nix b/pkgs/development/ocaml-modules/domain-local-timeout/default.nix index a8ba771399b7ee..50d33a063d8185 100644 --- a/pkgs/development/ocaml-modules/domain-local-timeout/default.nix +++ b/pkgs/development/ocaml-modules/domain-local-timeout/default.nix @@ -1,7 +1,14 @@ -{ lib, buildDunePackage, ocaml, fetchurl -, mtime, psq, thread-table -, alcotest, mdx -, domain-local-await +{ + lib, + buildDunePackage, + ocaml, + fetchurl, + mtime, + psq, + thread-table, + alcotest, + mdx, + domain-local-await, }: buildDunePackage rec { @@ -15,11 +22,19 @@ buildDunePackage rec { hash = "sha256-6sCqUkOjN8E+7OLUwVQntkv0vrQDkGDV8KNqDhVm0d8="; }; - propagatedBuildInputs = [ mtime psq thread-table ]; + propagatedBuildInputs = [ + mtime + psq + thread-table + ]; doCheck = lib.versionAtLeast ocaml.version "5.0"; nativeCheckInputs = [ mdx.bin ]; - checkInputs = [ alcotest domain-local-await mdx ]; + checkInputs = [ + alcotest + domain-local-await + mdx + ]; meta = { homepage = "https://github.com/ocaml-multicore/domain-local-timeout"; diff --git a/pkgs/development/ocaml-modules/domain-name/default.nix b/pkgs/development/ocaml-modules/domain-name/default.nix index d518f18571c5c4..745550691c4a2d 100644 --- a/pkgs/development/ocaml-modules/domain-name/default.nix +++ b/pkgs/development/ocaml-modules/domain-name/default.nix @@ -1,5 +1,9 @@ -{ lib, buildDunePackage, ocaml, fetchurl -, alcotest +{ + lib, + buildDunePackage, + ocaml, + fetchurl, + alcotest, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/domain_shims/default.nix b/pkgs/development/ocaml-modules/domain_shims/default.nix index 4ccc6bbe90bdcd..32373e0fb4071c 100644 --- a/pkgs/development/ocaml-modules/domain_shims/default.nix +++ b/pkgs/development/ocaml-modules/domain_shims/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitLab, buildDunePackage }: +{ + lib, + fetchFromGitLab, + buildDunePackage, +}: buildDunePackage rec { pname = "domain_shims"; diff --git a/pkgs/development/ocaml-modules/domainslib/default.nix b/pkgs/development/ocaml-modules/domainslib/default.nix index e912cfeb57afaa..aa3cd5e5be1dae 100644 --- a/pkgs/development/ocaml-modules/domainslib/default.nix +++ b/pkgs/development/ocaml-modules/domainslib/default.nix @@ -1,11 +1,12 @@ -{ lib -, fetchurl -, buildDunePackage -, saturn -, domain-local-await -, kcas -, mirage-clock-unix -, qcheck-stm +{ + lib, + fetchurl, + buildDunePackage, + saturn, + domain-local-await, + kcas, + mirage-clock-unix, + qcheck-stm, }: buildDunePackage rec { @@ -19,10 +20,17 @@ buildDunePackage rec { hash = "sha256-KMJd+6XZmUSXNsXW/KXgvnFtgY9vODeW3vhL77mDXQE="; }; - propagatedBuildInputs = [ domain-local-await saturn ]; + propagatedBuildInputs = [ + domain-local-await + saturn + ]; doCheck = true; - checkInputs = [ kcas mirage-clock-unix qcheck-stm ]; + checkInputs = [ + kcas + mirage-clock-unix + qcheck-stm + ]; meta = { homepage = "https://github.com/ocaml-multicore/domainslib"; diff --git a/pkgs/development/ocaml-modules/dose3/default.nix b/pkgs/development/ocaml-modules/dose3/default.nix index 3baf5ab62ff68d..70994c47cca7e4 100644 --- a/pkgs/development/ocaml-modules/dose3/default.nix +++ b/pkgs/development/ocaml-modules/dose3/default.nix @@ -1,7 +1,16 @@ -{ lib, buildDunePackage, fetchFromGitLab -, ocamlgraph, parmap, re, stdlib-shims -, base64, extlib, cudf -, ocaml, ounit +{ + lib, + buildDunePackage, + fetchFromGitLab, + ocamlgraph, + parmap, + re, + stdlib-shims, + base64, + extlib, + cudf, + ocaml, + ounit, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/dscheck/default.nix b/pkgs/development/ocaml-modules/dscheck/default.nix index 2b781a8631f873..e5ef2ea3549e5c 100644 --- a/pkgs/development/ocaml-modules/dscheck/default.nix +++ b/pkgs/development/ocaml-modules/dscheck/default.nix @@ -1,7 +1,10 @@ -{ lib, fetchurl, buildDunePackage -, containers -, oseq -, alcotest +{ + lib, + fetchurl, + buildDunePackage, + containers, + oseq, + alcotest, }: buildDunePackage rec { @@ -15,7 +18,10 @@ buildDunePackage rec { hash = "sha256-9Rm2DmdvVeCkgAWCvkYdQTj94wmU7JkY8UI3fReIaG0="; }; - propagatedBuildInputs = [ containers oseq ]; + propagatedBuildInputs = [ + containers + oseq + ]; doCheck = true; checkInputs = [ alcotest ]; diff --git a/pkgs/development/ocaml-modules/dssi/default.nix b/pkgs/development/ocaml-modules/dssi/default.nix index b8235cef96905f..58427339a480c0 100644 --- a/pkgs/development/ocaml-modules/dssi/default.nix +++ b/pkgs/development/ocaml-modules/dssi/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, ladspa, alsa-lib }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + ladspa, + alsa-lib, +}: buildDunePackage rec { pname = "dssi"; @@ -14,7 +21,10 @@ buildDunePackage rec { }; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ ladspa alsa-lib ]; + propagatedBuildInputs = [ + ladspa + alsa-lib + ]; meta = with lib; { homepage = "https://github.com/savonet/ocaml-dssi"; diff --git a/pkgs/development/ocaml-modules/dtoa/default.nix b/pkgs/development/ocaml-modules/dtoa/default.nix index c3297b9a525bd4..62b9f124eb0ee7 100644 --- a/pkgs/development/ocaml-modules/dtoa/default.nix +++ b/pkgs/development/ocaml-modules/dtoa/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchurl, buildDunePackage, ocaml, ounit2 }: +{ + stdenv, + lib, + fetchurl, + buildDunePackage, + ocaml, + ounit2, +}: buildDunePackage rec { pname = "dtoa"; diff --git a/pkgs/development/ocaml-modules/dtools/default.nix b/pkgs/development/ocaml-modules/dtools/default.nix index c534bdaad92a99..6867f32289b57a 100644 --- a/pkgs/development/ocaml-modules/dtools/default.nix +++ b/pkgs/development/ocaml-modules/dtools/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchFromGitHub }: +{ + lib, + buildDunePackage, + fetchFromGitHub, +}: buildDunePackage rec { pname = "dtools"; diff --git a/pkgs/development/ocaml-modules/duff/default.nix b/pkgs/development/ocaml-modules/duff/default.nix index 21e916b55e23f9..2713991617575d 100644 --- a/pkgs/development/ocaml-modules/duff/default.nix +++ b/pkgs/development/ocaml-modules/duff/default.nix @@ -1,11 +1,12 @@ -{ lib -, fetchurl -, buildDunePackage -, fmt -, alcotest -, hxd -, crowbar -, bigstringaf +{ + lib, + fetchurl, + buildDunePackage, + fmt, + alcotest, + hxd, + crowbar, + bigstringaf, }: buildDunePackage rec { @@ -30,7 +31,6 @@ buildDunePackage rec { bigstringaf ]; - meta = { description = "Pure OCaml implementation of libXdiff (Rabin’s fingerprint)"; homepage = "https://github.com/mirage/duff"; diff --git a/pkgs/development/ocaml-modules/dum/default.nix b/pkgs/development/ocaml-modules/dum/default.nix index 43584461af1828..fa41fe11f7c723 100644 --- a/pkgs/development/ocaml-modules/dum/default.nix +++ b/pkgs/development/ocaml-modules/dum/default.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, findlib -, easy-format +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, + easy-format, }: stdenv.mkDerivation rec { @@ -14,12 +19,15 @@ stdenv.mkDerivation rec { }; postPatch = '' - substituteInPlace "dum.ml" \ - --replace "Lazy.lazy_is_val" "Lazy.is_val" \ - --replace "Obj.final_tag" "Obj.custom_tag" + substituteInPlace "dum.ml" \ + --replace "Lazy.lazy_is_val" "Lazy.is_val" \ + --replace "Obj.final_tag" "Obj.custom_tag" ''; - nativeBuildInputs = [ ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; propagatedBuildInputs = [ easy-format ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/dune-action-plugin/default.nix b/pkgs/development/ocaml-modules/dune-action-plugin/default.nix index 18095bee8fc38e..1c40f29295d1c9 100644 --- a/pkgs/development/ocaml-modules/dune-action-plugin/default.nix +++ b/pkgs/development/ocaml-modules/dune-action-plugin/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, dune_3, dune-glob, dune-private-libs, dune-rpc }: +{ + lib, + buildDunePackage, + dune_3, + dune-glob, + dune-private-libs, + dune-rpc, +}: buildDunePackage rec { pname = "dune-action-plugin"; @@ -8,7 +15,11 @@ buildDunePackage rec { dontAddPrefix = true; - propagatedBuildInputs = [ dune-glob dune-private-libs dune-rpc ]; + propagatedBuildInputs = [ + dune-glob + dune-private-libs + dune-rpc + ]; preBuild = '' rm -r vendor/csexp diff --git a/pkgs/development/ocaml-modules/dune-build-info/default.nix b/pkgs/development/ocaml-modules/dune-build-info/default.nix index ac9b127cac38a9..81f876a8d78c3e 100644 --- a/pkgs/development/ocaml-modules/dune-build-info/default.nix +++ b/pkgs/development/ocaml-modules/dune-build-info/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, dune-action-plugin }: +{ + lib, + buildDunePackage, + dune-action-plugin, +}: buildDunePackage rec { pname = "dune-build-info"; diff --git a/pkgs/development/ocaml-modules/dune-configurator/default.nix b/pkgs/development/ocaml-modules/dune-configurator/default.nix index 324be141866f49..df4a8578df893c 100644 --- a/pkgs/development/ocaml-modules/dune-configurator/default.nix +++ b/pkgs/development/ocaml-modules/dune-configurator/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, dune_3, csexp }: +{ + lib, + buildDunePackage, + dune_3, + csexp, +}: buildDunePackage rec { pname = "dune-configurator"; diff --git a/pkgs/development/ocaml-modules/dune-glob/default.nix b/pkgs/development/ocaml-modules/dune-glob/default.nix index 474fd4a52c633e..08523a8974c213 100644 --- a/pkgs/development/ocaml-modules/dune-glob/default.nix +++ b/pkgs/development/ocaml-modules/dune-glob/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, dune_3, dune-private-libs }: +{ + lib, + buildDunePackage, + dune_3, + dune-private-libs, +}: buildDunePackage rec { pname = "dune-glob"; diff --git a/pkgs/development/ocaml-modules/dune-private-libs/default.nix b/pkgs/development/ocaml-modules/dune-private-libs/default.nix index 4c6092122a2949..ad60aa1c75ecd0 100644 --- a/pkgs/development/ocaml-modules/dune-private-libs/default.nix +++ b/pkgs/development/ocaml-modules/dune-private-libs/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, dune_3, stdune }: +{ + lib, + buildDunePackage, + dune_3, + stdune, +}: buildDunePackage rec { pname = "dune-private-libs"; diff --git a/pkgs/development/ocaml-modules/dune-rpc/default.nix b/pkgs/development/ocaml-modules/dune-rpc/default.nix index 3e83d04d5d7e44..07b8c584023ba8 100644 --- a/pkgs/development/ocaml-modules/dune-rpc/default.nix +++ b/pkgs/development/ocaml-modules/dune-rpc/default.nix @@ -1,4 +1,14 @@ -{ lib, buildDunePackage, dune_3, csexp, stdune, ordering, pp, xdg, dyn }: +{ + lib, + buildDunePackage, + dune_3, + csexp, + stdune, + ordering, + pp, + xdg, + dyn, +}: buildDunePackage rec { pname = "dune-rpc"; @@ -8,7 +18,14 @@ buildDunePackage rec { dontAddPrefix = true; - propagatedBuildInputs = [ csexp stdune ordering pp xdg dyn ]; + propagatedBuildInputs = [ + csexp + stdune + ordering + pp + xdg + dyn + ]; preBuild = '' rm -r vendor/csexp diff --git a/pkgs/development/ocaml-modules/dune-site/default.nix b/pkgs/development/ocaml-modules/dune-site/default.nix index fc99f4213e1504..dde8e616bd9405 100644 --- a/pkgs/development/ocaml-modules/dune-site/default.nix +++ b/pkgs/development/ocaml-modules/dune-site/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, dune_3, dune-private-libs }: +{ + lib, + buildDunePackage, + dune_3, + dune-private-libs, +}: buildDunePackage rec { pname = "dune-site"; diff --git a/pkgs/development/ocaml-modules/duppy/default.nix b/pkgs/development/ocaml-modules/duppy/default.nix index bae9f62d26f110..8a8188fa6730ac 100644 --- a/pkgs/development/ocaml-modules/duppy/default.nix +++ b/pkgs/development/ocaml-modules/duppy/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitHub, re }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + re, +}: buildDunePackage rec { pname = "duppy"; diff --git a/pkgs/development/ocaml-modules/duration/default.nix b/pkgs/development/ocaml-modules/duration/default.nix index 34326c8a114346..137edf6f8d2ae7 100644 --- a/pkgs/development/ocaml-modules/duration/default.nix +++ b/pkgs/development/ocaml-modules/duration/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, ocaml, fetchurl, alcotest }: +{ + lib, + buildDunePackage, + ocaml, + fetchurl, + alcotest, +}: buildDunePackage rec { pname = "duration"; diff --git a/pkgs/development/ocaml-modules/dyn/default.nix b/pkgs/development/ocaml-modules/dyn/default.nix index ae1218b844ce66..870a10e0a9660f 100644 --- a/pkgs/development/ocaml-modules/dyn/default.nix +++ b/pkgs/development/ocaml-modules/dyn/default.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, dune_3, ordering }: +{ + buildDunePackage, + dune_3, + ordering, +}: buildDunePackage { pname = "dyn"; @@ -13,4 +17,3 @@ buildDunePackage { description = "Dynamic type"; }; } - diff --git a/pkgs/development/ocaml-modules/dypgen/default.nix b/pkgs/development/ocaml-modules/dypgen/default.nix index d47b7830776952..2be5bdf3e5967d 100644 --- a/pkgs/development/ocaml-modules/dypgen/default.nix +++ b/pkgs/development/ocaml-modules/dypgen/default.nix @@ -1,28 +1,44 @@ -{ stdenv, lib, fetchFromGitHub, fetchurl, ocaml, findlib }: - -let params = - if lib.versionAtLeast ocaml.version "4.07" then rec { - version = "0.2"; - src = fetchFromGitHub { - owner = "grain-lang"; - repo = "dypgen"; - rev = version; - hash = "sha256-fKuO/e5YbA2B7XcghWl9pXxwvKw9YlhnmZDZcuKe3cs="; - }; - } else if lib.versionOlder ocaml.version "4.06" then { - version = "20120619-1"; - src = fetchurl { - url = "http://dypgen.free.fr/dypgen-20120619-1.tar.bz2"; - sha256 = "ecb53d6e469e9ec4d57ee6323ff498d45b78883ae13618492488e7c5151fdd97"; - }; - } else throw "dypgen is not available for OCaml ${ocaml.version}" -; in +{ + stdenv, + lib, + fetchFromGitHub, + fetchurl, + ocaml, + findlib, +}: + +let + params = + if lib.versionAtLeast ocaml.version "4.07" then + rec { + version = "0.2"; + src = fetchFromGitHub { + owner = "grain-lang"; + repo = "dypgen"; + rev = version; + hash = "sha256-fKuO/e5YbA2B7XcghWl9pXxwvKw9YlhnmZDZcuKe3cs="; + }; + } + else if lib.versionOlder ocaml.version "4.06" then + { + version = "20120619-1"; + src = fetchurl { + url = "http://dypgen.free.fr/dypgen-20120619-1.tar.bz2"; + sha256 = "ecb53d6e469e9ec4d57ee6323ff498d45b78883ae13618492488e7c5151fdd97"; + }; + } + else + throw "dypgen is not available for OCaml ${ocaml.version}"; +in stdenv.mkDerivation rec { pname = "ocaml${ocaml.version}-dypgen"; inherit (params) src version; - nativeBuildInputs = [ ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; strictDeps = true; @@ -32,7 +48,11 @@ stdenv.mkDerivation rec { make ''; - makeFlags = [ "BINDIR=$(out)/bin" "MANDIR=$(out)/usr/share/man/man1" "DYPGENLIBDIR=$(out)/lib/ocaml/${ocaml.version}/site-lib" ]; + makeFlags = [ + "BINDIR=$(out)/bin" + "MANDIR=$(out)/usr/share/man/man1" + "DYPGENLIBDIR=$(out)/lib/ocaml/${ocaml.version}/site-lib" + ]; meta = { homepage = "http://dypgen.free.fr"; diff --git a/pkgs/development/ocaml-modules/earley/default.nix b/pkgs/development/ocaml-modules/earley/default.nix index 5d292607e24a1f..7154c055405500 100644 --- a/pkgs/development/ocaml-modules/earley/default.nix +++ b/pkgs/development/ocaml-modules/earley/default.nix @@ -1,5 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage -, stdlib-shims +{ + lib, + fetchFromGitHub, + buildDunePackage, + stdlib-shims, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/earlybird/default.nix b/pkgs/development/ocaml-modules/earlybird/default.nix index 49d5895f6596e6..4d07d9a35d9133 100644 --- a/pkgs/development/ocaml-modules/earlybird/default.nix +++ b/pkgs/development/ocaml-modules/earlybird/default.nix @@ -1,7 +1,21 @@ -{ lib, fetchFromGitHub, buildDunePackage -, cmdliner, dap, fmt, iter, logs, lru, lwt_ppx, lwt_react, menhir, menhirLib, path_glob, ppx_deriving_yojson -, ppx_optcomp -, gitUpdater +{ + lib, + fetchFromGitHub, + buildDunePackage, + cmdliner, + dap, + fmt, + iter, + logs, + lru, + lwt_ppx, + lwt_react, + menhir, + menhirLib, + path_glob, + ppx_deriving_yojson, + ppx_optcomp, + gitUpdater, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/easy-format/default.nix b/pkgs/development/ocaml-modules/easy-format/default.nix index 7d178b75806293..df1b30dd647ac0 100644 --- a/pkgs/development/ocaml-modules/easy-format/default.nix +++ b/pkgs/development/ocaml-modules/easy-format/default.nix @@ -1,13 +1,22 @@ -{ lib, fetchurl, ocaml, buildDunePackage }: +{ + lib, + fetchurl, + ocaml, + buildDunePackage, +}: -let params = - if lib.versionAtLeast ocaml.version "4.08" then { - version = "1.3.3"; - sha256 = "sha256:05n4mm1yz33h9gw811ivjw7x4m26lpmf7kns9lza4v6227lwmz7a"; - } else { - version = "1.3.2"; - sha256 = "sha256:09hrikx310pac2sb6jzaa7k6fmiznnmhdsqij1gawdymhawc4h1l"; - }; +let + params = + if lib.versionAtLeast ocaml.version "4.08" then + { + version = "1.3.3"; + sha256 = "sha256:05n4mm1yz33h9gw811ivjw7x4m26lpmf7kns9lza4v6227lwmz7a"; + } + else + { + version = "1.3.2"; + sha256 = "sha256:09hrikx310pac2sb6jzaa7k6fmiznnmhdsqij1gawdymhawc4h1l"; + }; in buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/eigen/default.nix b/pkgs/development/ocaml-modules/eigen/default.nix index 0b02539d64cbc9..3dbe6315d5cd03 100644 --- a/pkgs/development/ocaml-modules/eigen/default.nix +++ b/pkgs/development/ocaml-modules/eigen/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, buildDunePackage, fetchFromGitHub, ctypes, libcxx }: +{ + lib, + stdenv, + buildDunePackage, + fetchFromGitHub, + ctypes, + libcxx, +}: buildDunePackage rec { pname = "eigen"; @@ -8,8 +15,8 @@ buildDunePackage rec { src = fetchFromGitHub { owner = "owlbarn"; - repo = pname; - rev = version; + repo = pname; + rev = version; sha256 = "1zaw03as14hyvfpyj6bjrfbcxp2ljdbqcqqgm53kms244mig425f"; }; diff --git a/pkgs/development/ocaml-modules/eio-ssl/default.nix b/pkgs/development/ocaml-modules/eio-ssl/default.nix index 087a667d4e2dfc..01834cfb612caf 100644 --- a/pkgs/development/ocaml-modules/eio-ssl/default.nix +++ b/pkgs/development/ocaml-modules/eio-ssl/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildDunePackage -, fetchurl -, eio -, ssl +{ + lib, + buildDunePackage, + fetchurl, + eio, + ssl, }: buildDunePackage rec { @@ -14,7 +15,10 @@ buildDunePackage rec { hash = "sha256-m4CiUQtXVSMfLthbDsAftpiOsr24I5IGiU1vv7Rz8go="; }; - propagatedBuildInputs = [ eio ssl ]; + propagatedBuildInputs = [ + eio + ssl + ]; meta = { homepage = "https://github.com/anmonteiro/eio-ssl"; diff --git a/pkgs/development/ocaml-modules/eio/default.nix b/pkgs/development/ocaml-modules/eio/default.nix index 422f3449f1e687..224e6051eb041f 100644 --- a/pkgs/development/ocaml-modules/eio/default.nix +++ b/pkgs/development/ocaml-modules/eio/default.nix @@ -1,33 +1,36 @@ -{ lib -, ocaml -, version ? if lib.versionAtLeast ocaml.version "5.1" then "1.2" else "0.12" -, buildDunePackage -, bigstringaf -, cstruct -, domain-local-await -, fetchurl -, fmt -, hmap -, lwt-dllist -, mtime -, optint -, psq -, alcotest -, crowbar -, mdx +{ + lib, + ocaml, + version ? if lib.versionAtLeast ocaml.version "5.1" then "1.2" else "0.12", + buildDunePackage, + bigstringaf, + cstruct, + domain-local-await, + fetchurl, + fmt, + hmap, + lwt-dllist, + mtime, + optint, + psq, + alcotest, + crowbar, + mdx, }: let - param = { - "0.12" = { - minimalOCamlVersion = "5.0"; - hash = "sha256-2EhHzoX/t4ZBSWrSS+PGq1zCxohc7a1q4lfsrFnZJqA="; - }; - "1.2" = { - minimalOCamlVersion = "5.1"; - hash = "sha256-N5LpEr2NSUuy449zCBgl5NISsZcM8sHxspZsqp/WvEA="; - }; - }."${version}"; + param = + { + "0.12" = { + minimalOCamlVersion = "5.0"; + hash = "sha256-2EhHzoX/t4ZBSWrSS+PGq1zCxohc7a1q4lfsrFnZJqA="; + }; + "1.2" = { + minimalOCamlVersion = "5.1"; + hash = "sha256-N5LpEr2NSUuy449zCBgl5NISsZcM8sHxspZsqp/WvEA="; + }; + } + ."${version}"; in buildDunePackage rec { pname = "eio"; diff --git a/pkgs/development/ocaml-modules/eio/linux.nix b/pkgs/development/ocaml-modules/eio/linux.nix index f6ed30d4e80d15..09e840ffecf5bf 100644 --- a/pkgs/development/ocaml-modules/eio/linux.nix +++ b/pkgs/development/ocaml-modules/eio/linux.nix @@ -1,13 +1,19 @@ -{ buildDunePackage -, eio -, fmt -, logs -, uring +{ + buildDunePackage, + eio, + fmt, + logs, + uring, }: buildDunePackage { pname = "eio_linux"; - inherit (eio) meta src patches version; + inherit (eio) + meta + src + patches + version + ; minimalOCamlVersion = "5.0"; diff --git a/pkgs/development/ocaml-modules/eio/main.nix b/pkgs/development/ocaml-modules/eio/main.nix index 48c15e99ae0c3a..a0affd2ea5e9bc 100644 --- a/pkgs/development/ocaml-modules/eio/main.nix +++ b/pkgs/development/ocaml-modules/eio/main.nix @@ -1,22 +1,30 @@ -{ lib -, stdenv -, buildDunePackage -, eio -, eio_posix -, eio_linux +{ + lib, + stdenv, + buildDunePackage, + eio, + eio_posix, + eio_linux, }: buildDunePackage { pname = "eio_main"; - inherit (eio) meta src patches version; + inherit (eio) + meta + src + patches + version + ; minimalOCamlVersion = "5.0"; dontStrip = true; - propagatedBuildInputs = [ - eio_posix - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - eio_linux - ]; + propagatedBuildInputs = + [ + eio_posix + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + eio_linux + ]; } diff --git a/pkgs/development/ocaml-modules/eio/posix.nix b/pkgs/development/ocaml-modules/eio/posix.nix index fa63c1ea713bf7..31ba1f8459c864 100644 --- a/pkgs/development/ocaml-modules/eio/posix.nix +++ b/pkgs/development/ocaml-modules/eio/posix.nix @@ -1,16 +1,22 @@ -{ buildDunePackage -, lib -, stdenv -, dune-configurator -, eio -, fmt -, logs -, iomux +{ + buildDunePackage, + lib, + stdenv, + dune-configurator, + eio, + fmt, + logs, + iomux, }: buildDunePackage { pname = "eio_posix"; - inherit (eio) meta src patches version; + inherit (eio) + meta + src + patches + version + ; minimalOCamlVersion = "5.0"; diff --git a/pkgs/development/ocaml-modules/either/default.nix b/pkgs/development/ocaml-modules/either/default.nix index 71d16c9674c9d4..5967168061e840 100644 --- a/pkgs/development/ocaml-modules/either/default.nix +++ b/pkgs/development/ocaml-modules/either/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "either"; diff --git a/pkgs/development/ocaml-modules/elina/default.nix b/pkgs/development/ocaml-modules/elina/default.nix index de3f1094143d33..65f13a4857c2eb 100644 --- a/pkgs/development/ocaml-modules/elina/default.nix +++ b/pkgs/development/ocaml-modules/elina/default.nix @@ -1,4 +1,16 @@ -{ stdenv, lib, fetchurl, gnumake42, perl, gmp, mpfr, ocaml, findlib, camlidl, apron }: +{ + stdenv, + lib, + fetchurl, + gnumake42, + perl, + gmp, + mpfr, + ocaml, + findlib, + camlidl, + apron, +}: stdenv.mkDerivation rec { version = "1.1"; @@ -9,9 +21,19 @@ stdenv.mkDerivation rec { }; # fails with make 4.4 - nativeBuildInputs = [ gnumake42 perl ocaml findlib camlidl ]; + nativeBuildInputs = [ + gnumake42 + perl + ocaml + findlib + camlidl + ]; - propagatedBuildInputs = [ apron gmp mpfr ]; + propagatedBuildInputs = [ + apron + gmp + mpfr + ]; strictDeps = true; @@ -19,10 +41,9 @@ stdenv.mkDerivation rec { configureFlags = [ "--use-apron" "--use-opam" - "--apron-prefix" apron - ] - ++ lib.optional stdenv.hostPlatform.isDarwin "--absolute-dylibs" - ; + "--apron-prefix" + apron + ] ++ lib.optional stdenv.hostPlatform.isDarwin "--absolute-dylibs"; createFindlibDestdir = true; diff --git a/pkgs/development/ocaml-modules/emile/default.nix b/pkgs/development/ocaml-modules/emile/default.nix index 0a70be2c4fee02..07786a974202fc 100644 --- a/pkgs/development/ocaml-modules/emile/default.nix +++ b/pkgs/development/ocaml-modules/emile/default.nix @@ -1,13 +1,14 @@ -{ lib -, buildDunePackage -, fetchurl -, angstrom -, ipaddr -, base64 -, pecu -, uutf -, alcotest -, cmdliner +{ + lib, + buildDunePackage, + fetchurl, + angstrom, + ipaddr, + base64, + pecu, + uutf, + alcotest, + cmdliner, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/encore/default.nix b/pkgs/development/ocaml-modules/encore/default.nix index fc54eb1a478108..e360b0004a6a22 100644 --- a/pkgs/development/ocaml-modules/encore/default.nix +++ b/pkgs/development/ocaml-modules/encore/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildDunePackage -, fetchurl -, fmt -, bigstringaf -, angstrom -, alcotest +{ + lib, + buildDunePackage, + fetchurl, + fmt, + bigstringaf, + angstrom, + alcotest, }: buildDunePackage rec { @@ -20,7 +21,11 @@ buildDunePackage rec { duneVersion = "3"; - propagatedBuildInputs = [ angstrom fmt bigstringaf ]; + propagatedBuildInputs = [ + angstrom + fmt + bigstringaf + ]; checkInputs = [ alcotest ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/eqaf/cstruct.nix b/pkgs/development/ocaml-modules/eqaf/cstruct.nix index b5f2f6e6668313..c6402542400294 100644 --- a/pkgs/development/ocaml-modules/eqaf/cstruct.nix +++ b/pkgs/development/ocaml-modules/eqaf/cstruct.nix @@ -1,9 +1,16 @@ -{ buildDunePackage, eqaf, cstruct }: +{ + buildDunePackage, + eqaf, + cstruct, +}: buildDunePackage { pname = "eqaf-cstruct"; inherit (eqaf) src version meta; - propagatedBuildInputs = [ cstruct eqaf ]; + propagatedBuildInputs = [ + cstruct + eqaf + ]; } diff --git a/pkgs/development/ocaml-modules/eqaf/default.nix b/pkgs/development/ocaml-modules/eqaf/default.nix index 9b5dadb7b710b4..1833f44518a2af 100644 --- a/pkgs/development/ocaml-modules/eqaf/default.nix +++ b/pkgs/development/ocaml-modules/eqaf/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, buildDunePackage }: +{ + lib, + fetchurl, + buildDunePackage, +}: buildDunePackage rec { minimalOCamlVersion = "4.07"; diff --git a/pkgs/development/ocaml-modules/erm_xml/default.nix b/pkgs/development/ocaml-modules/erm_xml/default.nix index 082f47313bd4ea..a5676c358741a9 100644 --- a/pkgs/development/ocaml-modules/erm_xml/default.nix +++ b/pkgs/development/ocaml-modules/erm_xml/default.nix @@ -1,32 +1,42 @@ -{ stdenv, lib, fetchFromGitHub, ocaml, findlib, ocamlbuild }: +{ + stdenv, + lib, + fetchFromGitHub, + ocaml, + findlib, + ocamlbuild, +}: -if lib.versionOlder ocaml.version "4.02" -|| lib.versionAtLeast ocaml.version "5.0" -then throw "erm_xml is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.02" || lib.versionAtLeast ocaml.version "5.0" then + throw "erm_xml is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-erm_xml"; - version = "0.3+20180112"; + stdenv.mkDerivation rec { + pname = "ocaml${ocaml.version}-erm_xml"; + version = "0.3+20180112"; - src = fetchFromGitHub { - owner = "hannesm"; - repo = "xml"; - rev = "bbabdade807d8281fc48806da054b70dfe482479"; - sha256 = "sha256-OQdLTq9tJZc6XlcuPv2gxzYiQAUGd6AiBzfSi169XL0="; - }; + src = fetchFromGitHub { + owner = "hannesm"; + repo = "xml"; + rev = "bbabdade807d8281fc48806da054b70dfe482479"; + sha256 = "sha256-OQdLTq9tJZc6XlcuPv2gxzYiQAUGd6AiBzfSi169XL0="; + }; - nativeBuildInputs = [ ocaml findlib ocamlbuild ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ]; - strictDeps = true; + strictDeps = true; - createFindlibDestdir = true; + createFindlibDestdir = true; - meta = { - homepage = "https://github.com/hannesm/xml"; - description = "XML Parser for discrete data"; - platforms = ocaml.meta.platforms or [ ]; - license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [ vbgl ]; - }; -} + meta = { + homepage = "https://github.com/hannesm/xml"; + description = "XML Parser for discrete data"; + platforms = ocaml.meta.platforms or [ ]; + license = lib.licenses.bsd3; + maintainers = with lib.maintainers; [ vbgl ]; + }; + } diff --git a/pkgs/development/ocaml-modules/erm_xmpp/default.nix b/pkgs/development/ocaml-modules/erm_xmpp/default.nix index d60c4684b3d96f..2d69ca7c285aef 100644 --- a/pkgs/development/ocaml-modules/erm_xmpp/default.nix +++ b/pkgs/development/ocaml-modules/erm_xmpp/default.nix @@ -1,5 +1,16 @@ -{ stdenv, lib, fetchFromGitHub, ocaml, findlib, camlp4, ocamlbuild -, erm_xml, mirage-crypto, mirage-crypto-rng, base64, digestif +{ + stdenv, + lib, + fetchFromGitHub, + ocaml, + findlib, + camlp4, + ocamlbuild, + erm_xml, + mirage-crypto, + mirage-crypto-rng, + base64, + digestif, }: stdenv.mkDerivation rec { @@ -7,15 +18,26 @@ stdenv.mkDerivation rec { pname = "ocaml${ocaml.version}-erm_xmpp"; src = fetchFromGitHub { - owner = "hannesm"; - repo = "xmpp"; - rev = "54418f77abf47b175e9c1b68a4f745a12b640d6a"; + owner = "hannesm"; + repo = "xmpp"; + rev = "54418f77abf47b175e9c1b68a4f745a12b640d6a"; sha256 = "sha256-AbzZjNkW1VH/FOnzNruvelZeo3IYg/Usr3enQEknTQs="; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild camlp4 ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + camlp4 + ]; buildInputs = [ camlp4 ]; - propagatedBuildInputs = [ erm_xml mirage-crypto mirage-crypto-rng base64 digestif ]; + propagatedBuildInputs = [ + erm_xml + mirage-crypto + mirage-crypto-rng + base64 + digestif + ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/ethernet/default.nix b/pkgs/development/ocaml-modules/ethernet/default.nix index c16534744d06c8..e1969a24e574de 100644 --- a/pkgs/development/ocaml-modules/ethernet/default.nix +++ b/pkgs/development/ocaml-modules/ethernet/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildDunePackage -, fetchurl -, cstruct -, logs -, lwt -, macaddr -, mirage-net +{ + lib, + buildDunePackage, + fetchurl, + cstruct, + logs, + lwt, + macaddr, + mirage-net, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/expat/default.nix b/pkgs/development/ocaml-modules/expat/default.nix index 2449308567e4e0..17bc6e628c5d2d 100644 --- a/pkgs/development/ocaml-modules/expat/default.nix +++ b/pkgs/development/ocaml-modules/expat/default.nix @@ -1,39 +1,51 @@ -{ stdenv, lib, fetchFromGitHub, expat, ocaml, findlib, ounit }: +{ + stdenv, + lib, + fetchFromGitHub, + expat, + ocaml, + findlib, + ounit, +}: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.02") "ocaml_expat is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-expat"; - version = "1.3.0"; - - src = fetchFromGitHub { - owner = "whitequark"; - repo = "ocaml-expat"; - rev = "v${version}"; - hash = "sha256-eDA6MUcztaI+fpunWBdanNnPo9Y5gvbj/ViVcxYYEBg="; - }; - - prePatch = '' - substituteInPlace Makefile --replace "gcc" "\$(CC)" - ''; - - nativeBuildInputs = [ ocaml findlib ]; - buildInputs = [ expat ]; - - strictDeps = true; - - doCheck = lib.versionAtLeast ocaml.version "4.08"; - checkTarget = "testall"; - checkInputs = [ ounit ]; - - createFindlibDestdir = true; - - meta = { - description = "OCaml wrapper for the Expat XML parsing library"; - license = lib.licenses.mit; - maintainers = [ lib.maintainers.vbgl ]; - inherit (src.meta) homepage; - inherit (ocaml.meta) platforms; - }; -} + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-expat"; + version = "1.3.0"; + + src = fetchFromGitHub { + owner = "whitequark"; + repo = "ocaml-expat"; + rev = "v${version}"; + hash = "sha256-eDA6MUcztaI+fpunWBdanNnPo9Y5gvbj/ViVcxYYEBg="; + }; + + prePatch = '' + substituteInPlace Makefile --replace "gcc" "\$(CC)" + ''; + + nativeBuildInputs = [ + ocaml + findlib + ]; + buildInputs = [ expat ]; + + strictDeps = true; + + doCheck = lib.versionAtLeast ocaml.version "4.08"; + checkTarget = "testall"; + checkInputs = [ ounit ]; + + createFindlibDestdir = true; + + meta = { + description = "OCaml wrapper for the Expat XML parsing library"; + license = lib.licenses.mit; + maintainers = [ lib.maintainers.vbgl ]; + inherit (src.meta) homepage; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/extlib/default.nix b/pkgs/development/ocaml-modules/extlib/default.nix index cd9f6d9b86ce03..9be2ca711fd7db 100644 --- a/pkgs/development/ocaml-modules/extlib/default.nix +++ b/pkgs/development/ocaml-modules/extlib/default.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, lib, fetchurl, cppo }: +{ + buildDunePackage, + lib, + fetchurl, + cppo, +}: buildDunePackage rec { pname = "extlib"; diff --git a/pkgs/development/ocaml-modules/ezjsonm-encoding/default.nix b/pkgs/development/ocaml-modules/ezjsonm-encoding/default.nix index 3a5b047903ad3c..26423ea1999560 100644 --- a/pkgs/development/ocaml-modules/ezjsonm-encoding/default.nix +++ b/pkgs/development/ocaml-modules/ezjsonm-encoding/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, buildDunePackage, ezjsonm }: +{ + lib, + fetchurl, + buildDunePackage, + ezjsonm, +}: buildDunePackage rec { pname = "ezjsonm-encoding"; diff --git a/pkgs/development/ocaml-modules/ezjsonm/default.nix b/pkgs/development/ocaml-modules/ezjsonm/default.nix index cde69a13e8babd..1f468bb2a3bcef 100644 --- a/pkgs/development/ocaml-modules/ezjsonm/default.nix +++ b/pkgs/development/ocaml-modules/ezjsonm/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, buildDunePackage, jsonm, hex, sexplib0 }: +{ + lib, + fetchurl, + buildDunePackage, + jsonm, + hex, + sexplib0, +}: buildDunePackage rec { pname = "ezjsonm"; @@ -11,7 +18,11 @@ buildDunePackage rec { hash = "sha256-CGM+Dw52eoroGTXKfnTxaTuFp5xFAtVo7t/1Fw8M13s="; }; - propagatedBuildInputs = [ jsonm hex sexplib0 ]; + propagatedBuildInputs = [ + jsonm + hex + sexplib0 + ]; meta = { description = "Easy interface on top of the Jsonm library"; diff --git a/pkgs/development/ocaml-modules/ezxmlm/default.nix b/pkgs/development/ocaml-modules/ezxmlm/default.nix index b146b2349cd50c..d0ac55f6787ec8 100644 --- a/pkgs/development/ocaml-modules/ezxmlm/default.nix +++ b/pkgs/development/ocaml-modules/ezxmlm/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, buildDunePackage, xmlm }: +{ + lib, + fetchurl, + buildDunePackage, + xmlm, +}: buildDunePackage rec { pname = "ezxmlm"; diff --git a/pkgs/development/ocaml-modules/faad/default.nix b/pkgs/development/ocaml-modules/faad/default.nix index a2705a27d929e0..1a45794059ee7f 100644 --- a/pkgs/development/ocaml-modules/faad/default.nix +++ b/pkgs/development/ocaml-modules/faad/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, faad2, pkg-config }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + faad2, + pkg-config, +}: buildDunePackage rec { pname = "faad"; diff --git a/pkgs/development/ocaml-modules/facile/default.nix b/pkgs/development/ocaml-modules/facile/default.nix index ee8b7cb5319d75..d2ebf8b8805f56 100644 --- a/pkgs/development/ocaml-modules/facile/default.nix +++ b/pkgs/development/ocaml-modules/facile/default.nix @@ -1,25 +1,30 @@ -{ lib, fetchurl, buildDunePackage, ocaml }: +{ + lib, + fetchurl, + buildDunePackage, + ocaml, +}: -lib.throwIf (lib.versionAtLeast ocaml.version "5.0") - "facile is not available for OCaml ≥ 5.0" +lib.throwIf (lib.versionAtLeast ocaml.version "5.0") "facile is not available for OCaml ≥ 5.0" -buildDunePackage rec { - pname = "facile"; - version = "1.1.4"; + buildDunePackage + rec { + pname = "facile"; + version = "1.1.4"; - src = fetchurl { - url = "https://github.com/Emmanuel-PLF/facile/releases/download/${version}/facile-${version}.tbz"; - sha256 = "0jqrwmn6fr2vj2rrbllwxq4cmxykv7zh0y4vnngx29f5084a04jp"; - }; + src = fetchurl { + url = "https://github.com/Emmanuel-PLF/facile/releases/download/${version}/facile-${version}.tbz"; + sha256 = "0jqrwmn6fr2vj2rrbllwxq4cmxykv7zh0y4vnngx29f5084a04jp"; + }; - doCheck = true; + doCheck = true; - duneVersion = if lib.versionAtLeast ocaml.version "4.12" then "2" else "1"; - postPatch = lib.optionalString (duneVersion != "1") "dune upgrade"; + duneVersion = if lib.versionAtLeast ocaml.version "4.12" then "2" else "1"; + postPatch = lib.optionalString (duneVersion != "1") "dune upgrade"; - meta = { - homepage = "http://opti.recherche.enac.fr/facile/"; - license = lib.licenses.lgpl21Plus; - description = "Functional Constraint Library"; - }; -} + meta = { + homepage = "http://opti.recherche.enac.fr/facile/"; + license = lib.licenses.lgpl21Plus; + description = "Functional Constraint Library"; + }; + } diff --git a/pkgs/development/ocaml-modules/faraday/async.nix b/pkgs/development/ocaml-modules/faraday/async.nix index d6ee91cacabb0b..adb80e01db3b76 100644 --- a/pkgs/development/ocaml-modules/faraday/async.nix +++ b/pkgs/development/ocaml-modules/faraday/async.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, faraday, core_unix ? null, async }: +{ + buildDunePackage, + faraday, + core_unix ? null, + async, +}: buildDunePackage rec { pname = "faraday-async"; @@ -7,7 +12,11 @@ buildDunePackage rec { minimalOCamlVersion = "4.08"; duneVersion = "3"; - propagatedBuildInputs = [ faraday core_unix async ]; + propagatedBuildInputs = [ + faraday + core_unix + async + ]; meta = faraday.meta // { description = "Async support for Faraday"; diff --git a/pkgs/development/ocaml-modules/faraday/default.nix b/pkgs/development/ocaml-modules/faraday/default.nix index da2647ef2392ac..c7507ee38f7c1a 100644 --- a/pkgs/development/ocaml-modules/faraday/default.nix +++ b/pkgs/development/ocaml-modules/faraday/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildDunePackage, alcotest, bigstringaf }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + alcotest, + bigstringaf, +}: buildDunePackage rec { pname = "faraday"; diff --git a/pkgs/development/ocaml-modules/faraday/lwt-unix.nix b/pkgs/development/ocaml-modules/faraday/lwt-unix.nix index 1919de47169d63..f194b6b56e9249 100644 --- a/pkgs/development/ocaml-modules/faraday/lwt-unix.nix +++ b/pkgs/development/ocaml-modules/faraday/lwt-unix.nix @@ -1,11 +1,19 @@ -{ buildDunePackage, faraday, faraday-lwt, lwt }: +{ + buildDunePackage, + faraday, + faraday-lwt, + lwt, +}: buildDunePackage rec { pname = "faraday-lwt-unix"; inherit (faraday) version src; duneVersion = "3"; - propagatedBuildInputs = [ lwt faraday-lwt ]; + propagatedBuildInputs = [ + lwt + faraday-lwt + ]; meta = faraday.meta // { description = "Lwt + Unix support for Faraday"; diff --git a/pkgs/development/ocaml-modules/faraday/lwt.nix b/pkgs/development/ocaml-modules/faraday/lwt.nix index 011074f2fba1fc..b7d0b35e6c347b 100644 --- a/pkgs/development/ocaml-modules/faraday/lwt.nix +++ b/pkgs/development/ocaml-modules/faraday/lwt.nix @@ -1,10 +1,17 @@ -{ buildDunePackage, faraday, lwt }: +{ + buildDunePackage, + faraday, + lwt, +}: buildDunePackage rec { pname = "faraday-lwt"; inherit (faraday) version src; - propagatedBuildInputs = [ faraday lwt ]; + propagatedBuildInputs = [ + faraday + lwt + ]; duneVersion = "3"; meta = faraday.meta // { diff --git a/pkgs/development/ocaml-modules/farfadet/default.nix b/pkgs/development/ocaml-modules/farfadet/default.nix index aa200f880e4508..ddc73697d8ef00 100644 --- a/pkgs/development/ocaml-modules/farfadet/default.nix +++ b/pkgs/development/ocaml-modules/farfadet/default.nix @@ -1,34 +1,46 @@ -{ stdenv, lib, fetchurl, ocaml, findlib, ocamlbuild, topkg -, faraday +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + faraday, }: -if lib.versionOlder ocaml.version "4.3" -then throw "farfadet is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.3" then + throw "farfadet is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-farfadet"; - version = "0.3"; - - src = fetchurl { - url = "https://github.com/oklm-wsh/Farfadet/releases/download/v${version}/farfadet-${version}.tbz"; - sha256 = "0nlafnp0pwx0n4aszpsk6nvcvqi9im306p4jhx70si7k3xprlr2j"; - }; - - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg ]; - - propagatedBuildInputs = [ faraday ]; - - strictDeps = true; - - inherit (topkg) buildPhase installPhase; - - meta = { - description = "Printf-like for Faraday library"; - homepage = "https://github.com/oklm-wsh/Farfadet"; - license = lib.licenses.mit; - maintainers = [ lib.maintainers.vbgl ]; - inherit (ocaml.meta) platforms; - }; -} + stdenv.mkDerivation rec { + pname = "ocaml${ocaml.version}-farfadet"; + version = "0.3"; + + src = fetchurl { + url = "https://github.com/oklm-wsh/Farfadet/releases/download/v${version}/farfadet-${version}.tbz"; + sha256 = "0nlafnp0pwx0n4aszpsk6nvcvqi9im306p4jhx70si7k3xprlr2j"; + }; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ topkg ]; + + propagatedBuildInputs = [ faraday ]; + + strictDeps = true; + + inherit (topkg) buildPhase installPhase; + + meta = { + description = "Printf-like for Faraday library"; + homepage = "https://github.com/oklm-wsh/Farfadet"; + license = lib.licenses.mit; + maintainers = [ lib.maintainers.vbgl ]; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/fdkaac/default.nix b/pkgs/development/ocaml-modules/fdkaac/default.nix index f31a94e2c7d658..ccabbfcc2a5d38 100644 --- a/pkgs/development/ocaml-modules/fdkaac/default.nix +++ b/pkgs/development/ocaml-modules/fdkaac/default.nix @@ -1,5 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, dune-configurator -, fdk_aac +{ + lib, + fetchFromGitHub, + buildDunePackage, + dune-configurator, + fdk_aac, }: buildDunePackage rec { @@ -19,7 +23,10 @@ buildDunePackage rec { description = "OCaml binding for the fdk-aac library"; inherit (src.meta) homepage; license = lib.licenses.gpl2Only; - maintainers = [ lib.maintainers.vbgl lib.maintainers.dandellion ]; + maintainers = [ + lib.maintainers.vbgl + lib.maintainers.dandellion + ]; }; } diff --git a/pkgs/development/ocaml-modules/ff/default.nix b/pkgs/development/ocaml-modules/ff/default.nix index 9eb8a8e23db157..a4268e0ec063e4 100644 --- a/pkgs/development/ocaml-modules/ff/default.nix +++ b/pkgs/development/ocaml-modules/ff/default.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, ff-pbt, ff-sig, zarith, alcotest }: +{ + buildDunePackage, + ff-pbt, + ff-sig, + zarith, + alcotest, +}: buildDunePackage rec { pname = "ff"; diff --git a/pkgs/development/ocaml-modules/ff/pbt.nix b/pkgs/development/ocaml-modules/ff/pbt.nix index 3d0c8e7a8081fc..dccad2b6c609eb 100644 --- a/pkgs/development/ocaml-modules/ff/pbt.nix +++ b/pkgs/development/ocaml-modules/ff/pbt.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, zarith, ff-sig, alcotest }: +{ + buildDunePackage, + zarith, + ff-sig, + alcotest, +}: buildDunePackage { pname = "ff-pbt"; diff --git a/pkgs/development/ocaml-modules/ff/sig.nix b/pkgs/development/ocaml-modules/ff/sig.nix index 41d95cf993227e..9aab1f066078a8 100644 --- a/pkgs/development/ocaml-modules/ff/sig.nix +++ b/pkgs/development/ocaml-modules/ff/sig.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitLab, buildDunePackage, zarith }: +{ + lib, + fetchFromGitLab, + buildDunePackage, + zarith, +}: buildDunePackage rec { pname = "ff-sig"; diff --git a/pkgs/development/ocaml-modules/ffmpeg/default.nix b/pkgs/development/ocaml-modules/ffmpeg/default.nix index 91da782b232b9b..54c460bb3afc79 100644 --- a/pkgs/development/ocaml-modules/ffmpeg/default.nix +++ b/pkgs/development/ocaml-modules/ffmpeg/default.nix @@ -1,12 +1,14 @@ -{ buildDunePackage, callPackage -, ffmpeg-base ? callPackage ./base.nix { } -, ffmpeg-avutil -, ffmpeg-avcodec -, ffmpeg-avfilter -, ffmpeg-swscale -, ffmpeg-swresample -, ffmpeg-av -, ffmpeg-avdevice +{ + buildDunePackage, + callPackage, + ffmpeg-base ? callPackage ./base.nix { }, + ffmpeg-avutil, + ffmpeg-avcodec, + ffmpeg-avfilter, + ffmpeg-swscale, + ffmpeg-swresample, + ffmpeg-av, + ffmpeg-avdevice, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-av.nix b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-av.nix index 4d855561317773..70c981ad11cbb8 100644 --- a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-av.nix +++ b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-av.nix @@ -1,9 +1,16 @@ -{ lib, buildDunePackage, dune-configurator, pkg-config, callPackage -, AudioToolbox -, ffmpeg-base ? callPackage ./base.nix { } -, ffmpeg-avutil, ffmpeg-avcodec, ffmpeg -, stdenv -, VideoToolbox +{ + lib, + buildDunePackage, + dune-configurator, + pkg-config, + callPackage, + AudioToolbox, + ffmpeg-base ? callPackage ./base.nix { }, + ffmpeg-avutil, + ffmpeg-avcodec, + ffmpeg, + stdenv, + VideoToolbox, }: buildDunePackage { @@ -14,8 +21,17 @@ buildDunePackage { inherit (ffmpeg-base) version src; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dune-configurator ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ AudioToolbox VideoToolbox ]; - propagatedBuildInputs = [ ffmpeg-avutil ffmpeg-avcodec ffmpeg.dev ]; + buildInputs = + [ dune-configurator ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AudioToolbox + VideoToolbox + ]; + propagatedBuildInputs = [ + ffmpeg-avutil + ffmpeg-avcodec + ffmpeg.dev + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avcodec.nix b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avcodec.nix index 85f03825cdbd00..76eaea775669cc 100644 --- a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avcodec.nix +++ b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avcodec.nix @@ -1,9 +1,15 @@ -{ lib, buildDunePackage, dune-configurator, pkg-config, callPackage -, AudioToolbox -, ffmpeg-base ? callPackage ./base.nix { } -, ffmpeg-avutil, ffmpeg -, stdenv -, VideoToolbox +{ + lib, + buildDunePackage, + dune-configurator, + pkg-config, + callPackage, + AudioToolbox, + ffmpeg-base ? callPackage ./base.nix { }, + ffmpeg-avutil, + ffmpeg, + stdenv, + VideoToolbox, }: buildDunePackage { @@ -14,9 +20,16 @@ buildDunePackage { inherit (ffmpeg-base) version src; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dune-configurator ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ AudioToolbox VideoToolbox ]; - propagatedBuildInputs = [ ffmpeg-avutil ffmpeg.dev ]; + buildInputs = + [ dune-configurator ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AudioToolbox + VideoToolbox + ]; + propagatedBuildInputs = [ + ffmpeg-avutil + ffmpeg.dev + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avdevice.nix b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avdevice.nix index f966706cc737a1..97bab8f5d38f1e 100644 --- a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avdevice.nix +++ b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avdevice.nix @@ -1,15 +1,21 @@ -{ lib, buildDunePackage, dune-configurator, pkg-config, callPackage -, AppKit -, AudioToolbox -, AVFoundation -, Cocoa -, CoreImage -, ForceFeedback -, ffmpeg-base ? callPackage ./base.nix { } -, ffmpeg-av, ffmpeg -, OpenGL -, stdenv -, VideoToolbox +{ + lib, + buildDunePackage, + dune-configurator, + pkg-config, + callPackage, + AppKit, + AudioToolbox, + AVFoundation, + Cocoa, + CoreImage, + ForceFeedback, + ffmpeg-base ? callPackage ./base.nix { }, + ffmpeg-av, + ffmpeg, + OpenGL, + stdenv, + VideoToolbox, }: buildDunePackage { @@ -20,20 +26,24 @@ buildDunePackage { inherit (ffmpeg-base) version src; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dune-configurator ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - AudioToolbox - AVFoundation - Cocoa - CoreImage - ForceFeedback - OpenGL - VideoToolbox + buildInputs = + [ dune-configurator ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + AudioToolbox + AVFoundation + Cocoa + CoreImage + ForceFeedback + OpenGL + VideoToolbox + ]; + + propagatedBuildInputs = [ + ffmpeg-av + ffmpeg.dev ]; - propagatedBuildInputs = [ ffmpeg-av ffmpeg.dev ]; - doCheck = true; meta = ffmpeg-base.meta // { diff --git a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avfilter.nix b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avfilter.nix index 1f9ded9bd0241a..0af5d888d02553 100644 --- a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avfilter.nix +++ b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avfilter.nix @@ -1,11 +1,17 @@ -{ lib, buildDunePackage, dune-configurator, pkg-config, callPackage -, AppKit -, CoreImage -, ffmpeg-base ? callPackage ./base.nix { } -, ffmpeg-avutil, ffmpeg -, OpenGL -, stdenv -, VideoToolbox +{ + lib, + buildDunePackage, + dune-configurator, + pkg-config, + callPackage, + AppKit, + CoreImage, + ffmpeg-base ? callPackage ./base.nix { }, + ffmpeg-avutil, + ffmpeg, + OpenGL, + stdenv, + VideoToolbox, }: buildDunePackage { @@ -16,9 +22,18 @@ buildDunePackage { inherit (ffmpeg-base) version src; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dune-configurator ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ AppKit CoreImage OpenGL VideoToolbox ]; - propagatedBuildInputs = [ ffmpeg-avutil ffmpeg.dev ]; + buildInputs = + [ dune-configurator ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + CoreImage + OpenGL + VideoToolbox + ]; + propagatedBuildInputs = [ + ffmpeg-avutil + ffmpeg.dev + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avutil.nix b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avutil.nix index 8374304fe4888a..213920a6a110b1 100644 --- a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avutil.nix +++ b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-avutil.nix @@ -1,7 +1,14 @@ -{ lib, stdenv, buildDunePackage, dune-configurator, pkg-config, callPackage -, AudioToolbox, VideoToolbox -, ffmpeg-base ? callPackage ./base.nix { } -, ffmpeg +{ + lib, + stdenv, + buildDunePackage, + dune-configurator, + pkg-config, + callPackage, + AudioToolbox, + VideoToolbox, + ffmpeg-base ? callPackage ./base.nix { }, + ffmpeg, }: buildDunePackage { @@ -12,7 +19,12 @@ buildDunePackage { inherit (ffmpeg-base) version src; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dune-configurator ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ AudioToolbox VideoToolbox ]; + buildInputs = + [ dune-configurator ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AudioToolbox + VideoToolbox + ]; propagatedBuildInputs = [ ffmpeg.dev ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-swresample.nix b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-swresample.nix index 5fda062454f074..bc4eb69009761a 100644 --- a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-swresample.nix +++ b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-swresample.nix @@ -1,8 +1,15 @@ -{ lib, buildDunePackage, dune-configurator, pkg-config, callPackage -, ffmpeg-base ? callPackage ./base.nix { } -, ffmpeg-avutil, ffmpeg-avcodec, ffmpeg -, stdenv -, VideoToolbox +{ + lib, + buildDunePackage, + dune-configurator, + pkg-config, + callPackage, + ffmpeg-base ? callPackage ./base.nix { }, + ffmpeg-avutil, + ffmpeg-avcodec, + ffmpeg, + stdenv, + VideoToolbox, }: buildDunePackage { @@ -14,7 +21,11 @@ buildDunePackage { nativeBuildInputs = [ pkg-config ]; buildInputs = [ dune-configurator ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ VideoToolbox ]; - propagatedBuildInputs = [ ffmpeg-avutil ffmpeg-avcodec ffmpeg.dev ]; + propagatedBuildInputs = [ + ffmpeg-avutil + ffmpeg-avcodec + ffmpeg.dev + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-swscale.nix b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-swscale.nix index 518f18b1509bd9..a5f07a13d967a8 100644 --- a/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-swscale.nix +++ b/pkgs/development/ocaml-modules/ffmpeg/ffmpeg-swscale.nix @@ -1,8 +1,14 @@ -{ lib, buildDunePackage, dune-configurator, pkg-config, callPackage -, ffmpeg-base ? callPackage ./base.nix { } -, ffmpeg-avutil, ffmpeg -, stdenv -, VideoToolbox +{ + lib, + buildDunePackage, + dune-configurator, + pkg-config, + callPackage, + ffmpeg-base ? callPackage ./base.nix { }, + ffmpeg-avutil, + ffmpeg, + stdenv, + VideoToolbox, }: buildDunePackage { @@ -14,7 +20,10 @@ buildDunePackage { nativeBuildInputs = [ pkg-config ]; buildInputs = [ dune-configurator ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ VideoToolbox ]; - propagatedBuildInputs = [ ffmpeg-avutil ffmpeg.dev ]; + propagatedBuildInputs = [ + ffmpeg-avutil + ffmpeg.dev + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/fiber/default.nix b/pkgs/development/ocaml-modules/fiber/default.nix index a99f10899e583c..cd2c62d66a49c1 100644 --- a/pkgs/development/ocaml-modules/fiber/default.nix +++ b/pkgs/development/ocaml-modules/fiber/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildDunePackage -, dyn -, fetchurl -, ppx_expect -, stdune +{ + lib, + buildDunePackage, + dyn, + fetchurl, + ppx_expect, + stdune, }: buildDunePackage rec { @@ -15,7 +16,10 @@ buildDunePackage rec { hash = "sha256-hkihWuk/5pQpmc42iHQpo5E7YoKcRxTlIMwOehw7loI="; }; - buildInputs = [ stdune dyn ]; + buildInputs = [ + stdune + dyn + ]; checkInputs = [ ppx_expect ]; diff --git a/pkgs/development/ocaml-modules/fileutils/default.nix b/pkgs/development/ocaml-modules/fileutils/default.nix index 832da7d3dc1567..9305760710b49a 100644 --- a/pkgs/development/ocaml-modules/fileutils/default.nix +++ b/pkgs/development/ocaml-modules/fileutils/default.nix @@ -1,4 +1,12 @@ -{ lib, fetchurl, ocaml, buildDunePackage, seq, stdlib-shims, ounit2 }: +{ + lib, + fetchurl, + ocaml, + buildDunePackage, + seq, + stdlib-shims, + ounit2, +}: buildDunePackage rec { pname = "fileutils"; diff --git a/pkgs/development/ocaml-modules/fix/default.nix b/pkgs/development/ocaml-modules/fix/default.nix index 844059849bfc30..a16a93debab559 100644 --- a/pkgs/development/ocaml-modules/fix/default.nix +++ b/pkgs/development/ocaml-modules/fix/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitLab, buildDunePackage }: +{ + lib, + fetchFromGitLab, + buildDunePackage, +}: buildDunePackage rec { pname = "fix"; diff --git a/pkgs/development/ocaml-modules/flac/default.nix b/pkgs/development/ocaml-modules/flac/default.nix index c30236e0e2c1e8..833da22738ea77 100644 --- a/pkgs/development/ocaml-modules/flac/default.nix +++ b/pkgs/development/ocaml-modules/flac/default.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, pkg-config, ogg, flac }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + pkg-config, + ogg, + flac, +}: buildDunePackage rec { pname = "flac"; @@ -13,7 +21,10 @@ buildDunePackage rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ ogg flac.dev ]; + propagatedBuildInputs = [ + ogg + flac.dev + ]; meta = with lib; { homepage = "https://github.com/savonet/ocaml-flac"; diff --git a/pkgs/development/ocaml-modules/flex/default.nix b/pkgs/development/ocaml-modules/flex/default.nix index 99af6da9268090..d638e057ea1ece 100644 --- a/pkgs/development/ocaml-modules/flex/default.nix +++ b/pkgs/development/ocaml-modules/flex/default.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, fetchFromGitHub, lib, reason }: +{ + buildDunePackage, + fetchFromGitHub, + lib, + reason, +}: buildDunePackage rec { pname = "flex"; diff --git a/pkgs/development/ocaml-modules/fmt/default.nix b/pkgs/development/ocaml-modules/fmt/default.nix index b82df99d2df0ee..bd86aa8f68b99b 100644 --- a/pkgs/development/ocaml-modules/fmt/default.nix +++ b/pkgs/development/ocaml-modules/fmt/default.nix @@ -1,30 +1,47 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, ocamlbuild, topkg, cmdliner }: +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + cmdliner, +}: -if lib.versionOlder ocaml.version "4.08" -then throw "fmt is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.08" then + throw "fmt is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - version = "0.9.0"; - pname = "ocaml${ocaml.version}-fmt"; + stdenv.mkDerivation rec { + version = "0.9.0"; + pname = "ocaml${ocaml.version}-fmt"; - src = fetchurl { - url = "https://erratique.ch/software/fmt/releases/fmt-${version}.tbz"; - sha256 = "sha256-8fsggFoi3XWhN9cnBKNw53ic9r32OUjmgX0cImwUEmE="; - }; + src = fetchurl { + url = "https://erratique.ch/software/fmt/releases/fmt-${version}.tbz"; + sha256 = "sha256-8fsggFoi3XWhN9cnBKNw53ic9r32OUjmgX0cImwUEmE="; + }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ cmdliner topkg ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ + cmdliner + topkg + ]; - strictDeps = true; + strictDeps = true; - inherit (topkg) buildPhase installPhase; + inherit (topkg) buildPhase installPhase; - meta = with lib; { - homepage = "https://erratique.ch/software/fmt"; - license = licenses.isc; - description = "OCaml Format pretty-printer combinators"; - inherit (ocaml.meta) platforms; - maintainers = [ maintainers.vbgl ]; - }; -} + meta = with lib; { + homepage = "https://erratique.ch/software/fmt"; + license = licenses.isc; + description = "OCaml Format pretty-printer combinators"; + inherit (ocaml.meta) platforms; + maintainers = [ maintainers.vbgl ]; + }; + } diff --git a/pkgs/development/ocaml-modules/fontconfig/default.nix b/pkgs/development/ocaml-modules/fontconfig/default.nix index 5d7e5f59b8bd57..4668d6e316e45b 100644 --- a/pkgs/development/ocaml-modules/fontconfig/default.nix +++ b/pkgs/development/ocaml-modules/fontconfig/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, pkg-config, fontconfig, ocaml }: +{ + stdenv, + lib, + fetchFromGitHub, + pkg-config, + fontconfig, + ocaml, +}: stdenv.mkDerivation { pname = "ocaml${ocaml.version}-fontconfig"; @@ -17,7 +24,10 @@ stdenv.mkDerivation { --replace String.capitalize String.capitalize_ascii ''; - nativeBuildInputs = [ pkg-config ocaml ]; + nativeBuildInputs = [ + pkg-config + ocaml + ]; buildInputs = [ fontconfig ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/fpath/default.nix b/pkgs/development/ocaml-modules/fpath/default.nix index db742f92902940..861b91901e559e 100644 --- a/pkgs/development/ocaml-modules/fpath/default.nix +++ b/pkgs/development/ocaml-modules/fpath/default.nix @@ -1,32 +1,46 @@ -{ stdenv, lib, fetchurl, ocaml, findlib, ocamlbuild, topkg, astring }: - -if lib.versionOlder ocaml.version "4.03" -then throw "fpath is not available for OCaml ${ocaml.version}" +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + astring, +}: + +if lib.versionOlder ocaml.version "4.03" then + throw "fpath is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-fpath"; - version = "0.7.3"; - - src = fetchurl { - url = "https://erratique.ch/software/fpath/releases/fpath-${version}.tbz"; - sha256 = "03z7mj0sqdz465rc4drj1gr88l9q3nfs374yssvdjdyhjbqqzc0j"; - }; - - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg ]; - - propagatedBuildInputs = [ astring ]; - - strictDeps = true; - - inherit (topkg) buildPhase installPhase; - - meta = { - description = "OCaml module for handling file system paths with POSIX and Windows conventions"; - homepage = "https://erratique.ch/software/fpath"; - license = lib.licenses.isc; - maintainers = [ lib.maintainers.vbgl ]; - inherit (ocaml.meta) platforms; - }; -} + stdenv.mkDerivation rec { + pname = "ocaml${ocaml.version}-fpath"; + version = "0.7.3"; + + src = fetchurl { + url = "https://erratique.ch/software/fpath/releases/fpath-${version}.tbz"; + sha256 = "03z7mj0sqdz465rc4drj1gr88l9q3nfs374yssvdjdyhjbqqzc0j"; + }; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ topkg ]; + + propagatedBuildInputs = [ astring ]; + + strictDeps = true; + + inherit (topkg) buildPhase installPhase; + + meta = { + description = "OCaml module for handling file system paths with POSIX and Windows conventions"; + homepage = "https://erratique.ch/software/fpath"; + license = lib.licenses.isc; + maintainers = [ lib.maintainers.vbgl ]; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/frei0r/default.nix b/pkgs/development/ocaml-modules/frei0r/default.nix index 4f4a64d220a454..e4aba92bf4c6fe 100644 --- a/pkgs/development/ocaml-modules/frei0r/default.nix +++ b/pkgs/development/ocaml-modules/frei0r/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, pkg-config, frei0r }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + pkg-config, + frei0r, +}: buildDunePackage rec { pname = "frei0r"; diff --git a/pkgs/development/ocaml-modules/frontc/default.nix b/pkgs/development/ocaml-modules/frontc/default.nix index c4ec0908fb0db4..857555a5363f5d 100644 --- a/pkgs/development/ocaml-modules/frontc/default.nix +++ b/pkgs/development/ocaml-modules/frontc/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, ocaml, menhir }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + ocaml, + menhir, +}: buildDunePackage rec { pname = "FrontC"; diff --git a/pkgs/development/ocaml-modules/functoria/default.nix b/pkgs/development/ocaml-modules/functoria/default.nix index 96fd6d0749ffcd..79cf437d87fe30 100644 --- a/pkgs/development/ocaml-modules/functoria/default.nix +++ b/pkgs/development/ocaml-modules/functoria/default.nix @@ -1,25 +1,48 @@ -{ lib, buildDunePackage, cmdliner -, functoria-runtime -, rresult, astring, fmt, logs, bos, fpath, emile, uri -, alcotest +{ + lib, + buildDunePackage, + cmdliner, + functoria-runtime, + rresult, + astring, + fmt, + logs, + bos, + fpath, + emile, + uri, + alcotest, }: buildDunePackage { - pname = "functoria"; + pname = "functoria"; inherit (functoria-runtime) version src; minimalOCamlVersion = "4.08"; - propagatedBuildInputs = [ cmdliner rresult astring fmt logs bos fpath emile uri ]; + propagatedBuildInputs = [ + cmdliner + rresult + astring + fmt + logs + bos + fpath + emile + uri + ]; # Tests are not compatible with cmdliner 1.3 doCheck = false; - checkInputs = [ alcotest functoria-runtime ]; + checkInputs = [ + alcotest + functoria-runtime + ]; meta = with lib; { description = "DSL to organize functor applications"; - homepage = "https://github.com/mirage/functoria"; - license = licenses.isc; + homepage = "https://github.com/mirage/functoria"; + license = licenses.isc; maintainers = [ maintainers.vbgl ]; }; } diff --git a/pkgs/development/ocaml-modules/functoria/runtime.nix b/pkgs/development/ocaml-modules/functoria/runtime.nix index 3ede6096e50800..45af2438f55b4c 100644 --- a/pkgs/development/ocaml-modules/functoria/runtime.nix +++ b/pkgs/development/ocaml-modules/functoria/runtime.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchurl, cmdliner }: +{ + lib, + buildDunePackage, + fetchurl, + cmdliner, +}: buildDunePackage rec { pname = "functoria-runtime"; @@ -14,8 +19,8 @@ buildDunePackage rec { propagatedBuildInputs = [ cmdliner ]; meta = with lib; { - homepage = "https://github.com/mirage/functoria"; - license = licenses.isc; + homepage = "https://github.com/mirage/functoria"; + license = licenses.isc; description = "Runtime support library for functoria-generated code"; maintainers = [ maintainers.sternenseemann ]; }; diff --git a/pkgs/development/ocaml-modules/functory/default.nix b/pkgs/development/ocaml-modules/functory/default.nix index 0901de7c53b5d9..84b16d678de899 100644 --- a/pkgs/development/ocaml-modules/functory/default.nix +++ b/pkgs/development/ocaml-modules/functory/default.nix @@ -1,40 +1,54 @@ -{ lib, stdenv, fetchurl, ocaml, findlib }: - -let param = - if lib.versionAtLeast ocaml.version "4.02" then { - version = "0.6"; - sha256 = "18wpyxblz9jh5bfp0hpffnd0q8cq1b0dqp0f36vhqydfknlnpx8y"; - } else { - version = "0.5"; - sha256 = "1j17rhifdjv1z262dma148ywg34x0zjn8vczdrnkwajsm4qg1hw3"; - }; +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, +}: + +let + param = + if lib.versionAtLeast ocaml.version "4.02" then + { + version = "0.6"; + sha256 = "18wpyxblz9jh5bfp0hpffnd0q8cq1b0dqp0f36vhqydfknlnpx8y"; + } + else + { + version = "0.5"; + sha256 = "1j17rhifdjv1z262dma148ywg34x0zjn8vczdrnkwajsm4qg1hw3"; + }; in lib.throwIf (lib.versionAtLeast ocaml.version "5.0") "functory is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation { - pname = "ocaml${ocaml.version}-functory"; - inherit (param) version; + stdenv.mkDerivation + { + pname = "ocaml${ocaml.version}-functory"; + inherit (param) version; - src = fetchurl { - url = "https://www.lri.fr/~filliatr/functory/download/functory-${param.version}.tar.gz"; - inherit (param) sha256; - }; + src = fetchurl { + url = "https://www.lri.fr/~filliatr/functory/download/functory-${param.version}.tar.gz"; + inherit (param) sha256; + }; - nativeBuildInputs = [ ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; - strictDeps = true; + strictDeps = true; - installTargets = [ "ocamlfind-install" ]; + installTargets = [ "ocamlfind-install" ]; - createFindlibDestdir = true; + createFindlibDestdir = true; - meta = with lib; { - homepage = "https://www.lri.fr/~filliatr/functory/"; - description = "Distributed computing library for Objective Caml which facilitates distributed execution of parallelizable computations in a seamless fashion"; - license = licenses.lgpl21; - maintainers = [ maintainers.vbgl ]; - inherit (ocaml.meta) platforms; - }; -} + meta = with lib; { + homepage = "https://www.lri.fr/~filliatr/functory/"; + description = "Distributed computing library for Objective Caml which facilitates distributed execution of parallelizable computations in a seamless fashion"; + license = licenses.lgpl21; + maintainers = [ maintainers.vbgl ]; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/gapi-ocaml/default.nix b/pkgs/development/ocaml-modules/gapi-ocaml/default.nix index f8d6c02e543346..3cce4f30823c70 100644 --- a/pkgs/development/ocaml-modules/gapi-ocaml/default.nix +++ b/pkgs/development/ocaml-modules/gapi-ocaml/default.nix @@ -1,6 +1,13 @@ -{ lib, fetchFromGitHub, buildDunePackage -, camlp-streams, cppo, cryptokit, ocurl, yojson -, ounit2 +{ + lib, + fetchFromGitHub, + buildDunePackage, + camlp-streams, + cppo, + cryptokit, + ocurl, + yojson, + ounit2, }: buildDunePackage rec { @@ -18,7 +25,12 @@ buildDunePackage rec { nativeBuildInputs = [ cppo ]; - propagatedBuildInputs = [ camlp-streams cryptokit ocurl yojson ]; + propagatedBuildInputs = [ + camlp-streams + cryptokit + ocurl + yojson + ]; doCheck = true; checkInputs = [ ounit2 ]; diff --git a/pkgs/development/ocaml-modules/gd/default.nix b/pkgs/development/ocaml-modules/gd/default.nix index 86817f05abb756..28c12345086403 100644 --- a/pkgs/development/ocaml-modules/gd/default.nix +++ b/pkgs/development/ocaml-modules/gd/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, gd }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + gd, +}: buildDunePackage rec { pname = "gd"; diff --git a/pkgs/development/ocaml-modules/gen/default.nix b/pkgs/development/ocaml-modules/gen/default.nix index 86dbc61f6faf8b..c46efbbf766b87 100644 --- a/pkgs/development/ocaml-modules/gen/default.nix +++ b/pkgs/development/ocaml-modules/gen/default.nix @@ -1,6 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub, ocaml -, seq -, qcheck, ounit2 +{ + lib, + buildDunePackage, + fetchFromGitHub, + ocaml, + seq, + qcheck, + ounit2, }: buildDunePackage rec { @@ -17,7 +22,10 @@ buildDunePackage rec { }; propagatedBuildInputs = [ seq ]; - checkInputs = [ qcheck ounit2 ]; + checkInputs = [ + qcheck + ounit2 + ]; doCheck = lib.versionAtLeast ocaml.version "4.08"; diff --git a/pkgs/development/ocaml-modules/gen_js_api/default.nix b/pkgs/development/ocaml-modules/gen_js_api/default.nix index 1c0cd9c5bdbfaa..f75d2295400acd 100644 --- a/pkgs/development/ocaml-modules/gen_js_api/default.nix +++ b/pkgs/development/ocaml-modules/gen_js_api/default.nix @@ -1,11 +1,12 @@ -{ buildDunePackage -, ocaml -, lib -, ppxlib -, fetchFromGitHub -, ojs -, js_of_ocaml-compiler -, nodejs +{ + buildDunePackage, + ocaml, + lib, + ppxlib, + fetchFromGitHub, + ojs, + js_of_ocaml-compiler, + nodejs, }: buildDunePackage rec { @@ -21,8 +22,14 @@ buildDunePackage rec { minimalOCamlVersion = "4.11"; - propagatedBuildInputs = [ ojs ppxlib ]; - nativeCheckInputs = [ js_of_ocaml-compiler nodejs ]; + propagatedBuildInputs = [ + ojs + ppxlib + ]; + nativeCheckInputs = [ + js_of_ocaml-compiler + nodejs + ]; doCheck = lib.versionAtLeast ocaml.version "4.13"; meta = { diff --git a/pkgs/development/ocaml-modules/gen_js_api/ojs.nix b/pkgs/development/ocaml-modules/gen_js_api/ojs.nix index 0cfe8f4bbfc1a9..7a77574be7e7cc 100644 --- a/pkgs/development/ocaml-modules/gen_js_api/ojs.nix +++ b/pkgs/development/ocaml-modules/gen_js_api/ojs.nix @@ -1,6 +1,7 @@ -{ buildDunePackage -, gen_js_api -, js_of_ocaml-compiler +{ + buildDunePackage, + gen_js_api, + js_of_ocaml-compiler, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/genspio/default.nix b/pkgs/development/ocaml-modules/genspio/default.nix index 338e1dd770c440..ca967338827f13 100644 --- a/pkgs/development/ocaml-modules/genspio/default.nix +++ b/pkgs/development/ocaml-modules/genspio/default.nix @@ -1,5 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage -, base, fmt +{ + lib, + fetchFromGitHub, + buildDunePackage, + base, + fmt, }: buildDunePackage rec { @@ -15,7 +19,10 @@ buildDunePackage rec { sha256 = "sha256:1788cnn10idp5i1hggg4pys7k0w8m3h2p4xa42jipfg4cpj7shaf"; }; - propagatedBuildInputs = [ base fmt ]; + propagatedBuildInputs = [ + base + fmt + ]; # base v0.17 compatibility patches = [ ./genspio.patch ]; diff --git a/pkgs/development/ocaml-modules/get-activity/default.nix b/pkgs/development/ocaml-modules/get-activity/default.nix index dbd585f57800e3..3976c9c24af9fd 100644 --- a/pkgs/development/ocaml-modules/get-activity/default.nix +++ b/pkgs/development/ocaml-modules/get-activity/default.nix @@ -7,7 +7,7 @@ dune-build-info, fmt, logs, - alcotest + alcotest, }: buildDunePackage rec { @@ -24,7 +24,10 @@ buildDunePackage rec { logs ]; - checkInputs = [ ppx_expect alcotest ]; + checkInputs = [ + ppx_expect + alcotest + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/get-activity/lib.nix b/pkgs/development/ocaml-modules/get-activity/lib.nix index 7f3fe161a6d2b3..352b75d27f4fd2 100644 --- a/pkgs/development/ocaml-modules/get-activity/lib.nix +++ b/pkgs/development/ocaml-modules/get-activity/lib.nix @@ -10,7 +10,7 @@ ppx_yojson_conv, ppx_yojson_conv_lib, yojson, - alcotest + alcotest, }: buildDunePackage rec { @@ -37,7 +37,10 @@ buildDunePackage rec { yojson ]; - checkInputs = [ ppx_expect alcotest ]; + checkInputs = [ + ppx_expect + alcotest + ]; doCheck = true; @@ -49,4 +52,3 @@ buildDunePackage rec { maintainers = with lib.maintainers; [ zazedd ]; }; } - diff --git a/pkgs/development/ocaml-modules/getopt/default.nix b/pkgs/development/ocaml-modules/getopt/default.nix index db03f7b079399e..9de42e3d8bae4d 100644 --- a/pkgs/development/ocaml-modules/getopt/default.nix +++ b/pkgs/development/ocaml-modules/getopt/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage }: +{ + lib, + fetchFromGitHub, + buildDunePackage, +}: buildDunePackage rec { pname = "getopt"; diff --git a/pkgs/development/ocaml-modules/gg/default.nix b/pkgs/development/ocaml-modules/gg/default.nix index c3bf3a2ec938af..7b015cf6840cef 100644 --- a/pkgs/development/ocaml-modules/gg/default.nix +++ b/pkgs/development/ocaml-modules/gg/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, topkg, ocamlbuild }: +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + topkg, + ocamlbuild, +}: let homepage = "https://erratique.ch/software/gg"; @@ -8,34 +16,40 @@ in lib.throwIfNot (lib.versionAtLeast ocaml.version "4.08") "gg is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation { - - pname = "ocaml${ocaml.version}-gg"; - inherit version; - - src = fetchurl { - url = "${homepage}/releases/gg-${version}.tbz"; - sha256 = "sha256:0j7bpj8k17csnz6v6frkz9aycywsb7xmznnb31g8rbfk3626f3ci"; - }; - - strictDeps = true; - - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg ]; - - inherit (topkg) buildPhase installPhase; - - meta = with lib; { - description = "Basic types for computer graphics in OCaml"; - longDescription = '' - Gg is an OCaml module providing basic types for computer graphics. It - defines types and functions for floats, vectors, points, sizes, - matrices, quaternions, axis aligned boxes, colors, color spaces, and - raster data. - ''; - inherit homepage; - inherit (ocaml.meta) platforms; - license = licenses.bsd3; - maintainers = [ maintainers.jirkamarsik ]; - }; -} + stdenv.mkDerivation + { + + pname = "ocaml${ocaml.version}-gg"; + inherit version; + + src = fetchurl { + url = "${homepage}/releases/gg-${version}.tbz"; + sha256 = "sha256:0j7bpj8k17csnz6v6frkz9aycywsb7xmznnb31g8rbfk3626f3ci"; + }; + + strictDeps = true; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ topkg ]; + + inherit (topkg) buildPhase installPhase; + + meta = with lib; { + description = "Basic types for computer graphics in OCaml"; + longDescription = '' + Gg is an OCaml module providing basic types for computer graphics. It + defines types and functions for floats, vectors, points, sizes, + matrices, quaternions, axis aligned boxes, colors, color spaces, and + raster data. + ''; + inherit homepage; + inherit (ocaml.meta) platforms; + license = licenses.bsd3; + maintainers = [ maintainers.jirkamarsik ]; + }; + } diff --git a/pkgs/development/ocaml-modules/git/default.nix b/pkgs/development/ocaml-modules/git/default.nix index 40be36100b65e4..71fc943fadec3e 100644 --- a/pkgs/development/ocaml-modules/git/default.nix +++ b/pkgs/development/ocaml-modules/git/default.nix @@ -1,9 +1,41 @@ -{ stdenv, lib, fetchurl, buildDunePackage -, alcotest, mirage-crypto-rng, git-binary -, angstrom, astring, cstruct, decompress, digestif, encore, fmt, checkseum -, ke, logs, lwt, ocamlgraph, uri, rresult, base64, hxd -, bigstringaf, optint, mirage-flow, domain-name, emile -, mimic, carton, carton-lwt, carton-git, ipaddr, psq, crowbar, alcotest-lwt, cmdliner +{ + stdenv, + lib, + fetchurl, + buildDunePackage, + alcotest, + mirage-crypto-rng, + git-binary, + angstrom, + astring, + cstruct, + decompress, + digestif, + encore, + fmt, + checkseum, + ke, + logs, + lwt, + ocamlgraph, + uri, + rresult, + base64, + hxd, + bigstringaf, + optint, + mirage-flow, + domain-name, + emile, + mimic, + carton, + carton-lwt, + carton-git, + ipaddr, + psq, + crowbar, + alcotest-lwt, + cmdliner, }: buildDunePackage rec { @@ -21,22 +53,52 @@ buildDunePackage rec { base64 ]; propagatedBuildInputs = [ - angstrom astring checkseum cstruct decompress digestif encore fmt - ke logs lwt ocamlgraph uri rresult bigstringaf optint mirage-flow - domain-name emile mimic carton carton-lwt carton-git ipaddr psq hxd + angstrom + astring + checkseum + cstruct + decompress + digestif + encore + fmt + ke + logs + lwt + ocamlgraph + uri + rresult + bigstringaf + optint + mirage-flow + domain-name + emile + mimic + carton + carton-lwt + carton-git + ipaddr + psq + hxd ]; nativeCheckInputs = [ git-binary ]; checkInputs = [ - alcotest alcotest-lwt mirage-crypto-rng crowbar cmdliner + alcotest + alcotest-lwt + mirage-crypto-rng + crowbar + cmdliner ]; doCheck = !stdenv.hostPlatform.isAarch64; meta = { description = "Git format and protocol in pure OCaml"; license = lib.licenses.isc; - maintainers = with lib.maintainers; [ sternenseemann vbgl ]; + maintainers = with lib.maintainers; [ + sternenseemann + vbgl + ]; homepage = "https://github.com/mirage/ocaml-git"; }; } diff --git a/pkgs/development/ocaml-modules/git/mirage.nix b/pkgs/development/ocaml-modules/git/mirage.nix index 09158c1ba90bb6..82225157ccdf42 100644 --- a/pkgs/development/ocaml-modules/git/mirage.nix +++ b/pkgs/development/ocaml-modules/git/mirage.nix @@ -1,36 +1,37 @@ -{ buildDunePackage -, git -, mimic -, mimic-happy-eyeballs -, base64 -, git-paf -, awa -, awa-mirage -, dns -, dns-client -, tls -, tls-mirage -, uri -, happy-eyeballs-mirage -, happy-eyeballs -, ca-certs-nss -, mirage-crypto -, ptime -, x509 -, cstruct -, tcpip -, domain-name -, fmt -, ipaddr -, lwt -, mirage-clock -, mirage-flow -, mirage-time -, alcotest -, alcotest-lwt -, bigstringaf -, logs -, ke +{ + buildDunePackage, + git, + mimic, + mimic-happy-eyeballs, + base64, + git-paf, + awa, + awa-mirage, + dns, + dns-client, + tls, + tls-mirage, + uri, + happy-eyeballs-mirage, + happy-eyeballs, + ca-certs-nss, + mirage-crypto, + ptime, + x509, + cstruct, + tcpip, + domain-name, + fmt, + ipaddr, + lwt, + mirage-clock, + mirage-flow, + mirage-time, + alcotest, + alcotest-lwt, + bigstringaf, + logs, + ke, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/git/paf.nix b/pkgs/development/ocaml-modules/git/paf.nix index b4b3c499bd26ba..9b4fdac9ea0bef 100644 --- a/pkgs/development/ocaml-modules/git/paf.nix +++ b/pkgs/development/ocaml-modules/git/paf.nix @@ -1,22 +1,23 @@ -{ buildDunePackage -, git -, mimic -, paf -, ca-certs-nss -, fmt -, ipaddr -, logs -, lwt -, mirage-clock -, mirage-time -, rresult -, tls -, uri -, bigstringaf -, domain-name -, httpaf -, mirage-flow -, tls-mirage +{ + buildDunePackage, + git, + mimic, + paf, + ca-certs-nss, + fmt, + ipaddr, + logs, + lwt, + mirage-clock, + mirage-time, + rresult, + tls, + uri, + bigstringaf, + domain-name, + httpaf, + mirage-flow, + tls-mirage, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/git/unix.nix b/pkgs/development/ocaml-modules/git/unix.nix index 9423f23b510167..ca4f784490c351 100644 --- a/pkgs/development/ocaml-modules/git/unix.nix +++ b/pkgs/development/ocaml-modules/git/unix.nix @@ -1,13 +1,38 @@ -{ buildDunePackage, git -, rresult, bigstringaf -, fmt, bos, fpath, uri, digestif, logs, lwt -, mirage-clock, mirage-clock-unix, astring, cmdliner -, decompress, domain-name, ipaddr, mtime -, tcpip, mirage-flow, mirage-unix -, alcotest, alcotest-lwt, base64, cstruct -, ke, mirage-crypto-rng, git-binary -, mimic, tls -, cacert, happy-eyeballs-lwt, git-mirage +{ + buildDunePackage, + git, + rresult, + bigstringaf, + fmt, + bos, + fpath, + uri, + digestif, + logs, + lwt, + mirage-clock, + mirage-clock-unix, + astring, + cmdliner, + decompress, + domain-name, + ipaddr, + mtime, + tcpip, + mirage-flow, + mirage-unix, + alcotest, + alcotest-lwt, + base64, + cstruct, + ke, + mirage-crypto-rng, + git-binary, + mimic, + tls, + cacert, + happy-eyeballs-lwt, + git-mirage, }: buildDunePackage { @@ -22,18 +47,36 @@ buildDunePackage { tcpip ]; propagatedBuildInputs = [ - rresult bigstringaf - fmt bos fpath digestif logs lwt - astring decompress - domain-name ipaddr mirage-flow mirage-unix - cstruct mimic - tls git happy-eyeballs-lwt - git-mirage mirage-clock-unix + rresult + bigstringaf + fmt + bos + fpath + digestif + logs + lwt + astring + decompress + domain-name + ipaddr + mirage-flow + mirage-unix + cstruct + mimic + tls + git + happy-eyeballs-lwt + git-mirage + mirage-clock-unix ]; checkInputs = [ - alcotest alcotest-lwt base64 ke + alcotest + alcotest-lwt + base64 + ke mirage-crypto-rng - uri mtime + uri + mtime cacert # sets up NIX_SSL_CERT_FILE ]; nativeCheckInputs = [ git-binary ]; diff --git a/pkgs/development/ocaml-modules/github/data.nix b/pkgs/development/ocaml-modules/github/data.nix index 9b8c207e91accb..9d7544d34bdebb 100644 --- a/pkgs/development/ocaml-modules/github/data.nix +++ b/pkgs/development/ocaml-modules/github/data.nix @@ -1,5 +1,8 @@ -{ buildDunePackage, github -, yojson, atdgen +{ + buildDunePackage, + github, + yojson, + atdgen, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/github/default.nix b/pkgs/development/ocaml-modules/github/default.nix index ec1816f8e5ad34..e104f98b743ddb 100644 --- a/pkgs/development/ocaml-modules/github/default.nix +++ b/pkgs/development/ocaml-modules/github/default.nix @@ -1,5 +1,14 @@ -{ lib, buildDunePackage, fetchFromGitHub -, uri, cohttp, lwt, cohttp-lwt, github-data, yojson, stringext +{ + lib, + buildDunePackage, + fetchFromGitHub, + uri, + cohttp, + lwt, + cohttp-lwt, + github-data, + yojson, + stringext, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/github/jsoo.nix b/pkgs/development/ocaml-modules/github/jsoo.nix index e5860fd1d72e28..02ea888d2d6c04 100644 --- a/pkgs/development/ocaml-modules/github/jsoo.nix +++ b/pkgs/development/ocaml-modules/github/jsoo.nix @@ -1,5 +1,9 @@ -{ buildDunePackage, github -, cohttp, cohttp-lwt-jsoo, js_of_ocaml-lwt +{ + buildDunePackage, + github, + cohttp, + cohttp-lwt-jsoo, + js_of_ocaml-lwt, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/github/unix.nix b/pkgs/development/ocaml-modules/github/unix.nix index 4d3205452094ac..4dd70fea7febf2 100644 --- a/pkgs/development/ocaml-modules/github/unix.nix +++ b/pkgs/development/ocaml-modules/github/unix.nix @@ -1,5 +1,11 @@ -{ buildDunePackage, github -, cohttp, cohttp-lwt-unix, stringext, cmdliner, lwt +{ + buildDunePackage, + github, + cohttp, + cohttp-lwt-unix, + stringext, + cmdliner, + lwt, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/gluon/default.nix b/pkgs/development/ocaml-modules/gluon/default.nix index cb926cbb07094d..38feb97ba89615 100644 --- a/pkgs/development/ocaml-modules/gluon/default.nix +++ b/pkgs/development/ocaml-modules/gluon/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildDunePackage -, fetchurl -, bytestring -, config -, libc -, rio -, uri +{ + lib, + buildDunePackage, + fetchurl, + bytestring, + config, + libc, + rio, + uri, }: buildDunePackage rec { @@ -38,5 +39,3 @@ buildDunePackage rec { maintainers = [ ]; }; } - - diff --git a/pkgs/development/ocaml-modules/gluten/default.nix b/pkgs/development/ocaml-modules/gluten/default.nix index 255f92378febc2..689c7a05f6596f 100644 --- a/pkgs/development/ocaml-modules/gluten/default.nix +++ b/pkgs/development/ocaml-modules/gluten/default.nix @@ -1,8 +1,9 @@ -{ buildDunePackage -, bigstringaf -, faraday -, fetchurl -, lib +{ + buildDunePackage, + bigstringaf, + faraday, + fetchurl, + lib, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/gluten/eio.nix b/pkgs/development/ocaml-modules/gluten/eio.nix index ceeb8f7294279b..d2c9cafb29e5a2 100644 --- a/pkgs/development/ocaml-modules/gluten/eio.nix +++ b/pkgs/development/ocaml-modules/gluten/eio.nix @@ -1,10 +1,17 @@ -{ buildDunePackage, gluten, eio }: +{ + buildDunePackage, + gluten, + eio, +}: buildDunePackage { pname = "gluten-eio"; inherit (gluten) src version; - propagatedBuildInputs = [ gluten eio ]; + propagatedBuildInputs = [ + gluten + eio + ]; meta = gluten.meta // { description = "EIO runtime for gluten"; diff --git a/pkgs/development/ocaml-modules/gluten/lwt-unix.nix b/pkgs/development/ocaml-modules/gluten/lwt-unix.nix index c3a360322a14a5..28f043d50c802f 100644 --- a/pkgs/development/ocaml-modules/gluten/lwt-unix.nix +++ b/pkgs/development/ocaml-modules/gluten/lwt-unix.nix @@ -1,13 +1,19 @@ -{ buildDunePackage -, faraday-lwt-unix -, gluten -, gluten-lwt -, lwt_ssl +{ + buildDunePackage, + faraday-lwt-unix, + gluten, + gluten-lwt, + lwt_ssl, }: buildDunePackage rec { pname = "gluten-lwt-unix"; - inherit (gluten) doCheck meta src version; + inherit (gluten) + doCheck + meta + src + version + ; propagatedBuildInputs = [ faraday-lwt-unix diff --git a/pkgs/development/ocaml-modules/gluten/lwt.nix b/pkgs/development/ocaml-modules/gluten/lwt.nix index e4cfb0d8db02ae..2da3d0f7d011ef 100644 --- a/pkgs/development/ocaml-modules/gluten/lwt.nix +++ b/pkgs/development/ocaml-modules/gluten/lwt.nix @@ -1,11 +1,17 @@ -{ buildDunePackage -, gluten -, lwt +{ + buildDunePackage, + gluten, + lwt, }: buildDunePackage rec { pname = "gluten-lwt"; - inherit (gluten) doCheck meta src version; + inherit (gluten) + doCheck + meta + src + version + ; propagatedBuildInputs = [ gluten diff --git a/pkgs/development/ocaml-modules/gmap/default.nix b/pkgs/development/ocaml-modules/gmap/default.nix index 59dbebe58e27bb..5b5fc7ecafff43 100644 --- a/pkgs/development/ocaml-modules/gmap/default.nix +++ b/pkgs/development/ocaml-modules/gmap/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, ocaml, fetchurl, alcotest, fmt }: +{ + lib, + buildDunePackage, + ocaml, + fetchurl, + alcotest, + fmt, +}: buildDunePackage rec { pname = "gmap"; @@ -13,7 +20,10 @@ buildDunePackage rec { minimalOCamlVersion = "4.03"; - checkInputs = [ alcotest fmt ]; + checkInputs = [ + alcotest + fmt + ]; doCheck = lib.versionAtLeast ocaml.version "4.08"; diff --git a/pkgs/development/ocaml-modules/gnuplot/default.nix b/pkgs/development/ocaml-modules/gnuplot/default.nix index 6b30ac5848c4d2..181366c2262675 100644 --- a/pkgs/development/ocaml-modules/gnuplot/default.nix +++ b/pkgs/development/ocaml-modules/gnuplot/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, gnuplot, iso8601 }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + gnuplot, + iso8601, +}: buildDunePackage rec { pname = "gnuplot"; @@ -9,13 +15,16 @@ buildDunePackage rec { minimalOCamlVersion = "4.03"; src = fetchFromGitHub { - owner = "c-cube"; - repo = "ocaml-${pname}"; - rev = "v${version}"; + owner = "c-cube"; + repo = "ocaml-${pname}"; + rev = "v${version}"; sha256 = "02pzi3lb57ysrdsba743s3vmnapjbxgq8ynlzpxbbs6cn1jj6ch9"; }; - propagatedBuildInputs = [ gnuplot iso8601 ]; + propagatedBuildInputs = [ + gnuplot + iso8601 + ]; meta = with lib; { inherit (src.meta) homepage; diff --git a/pkgs/development/ocaml-modules/graphics/default.nix b/pkgs/development/ocaml-modules/graphics/default.nix index 02edaded7c03d4..eab2c1b12ee6d5 100644 --- a/pkgs/development/ocaml-modules/graphics/default.nix +++ b/pkgs/development/ocaml-modules/graphics/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, buildDunePackage, dune-configurator, libX11 }: +{ + lib, + fetchurl, + buildDunePackage, + dune-configurator, + libX11, +}: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/graphql/cohttp.nix b/pkgs/development/ocaml-modules/graphql/cohttp.nix index b202d46abd533a..52d2aa6d5e5f47 100644 --- a/pkgs/development/ocaml-modules/graphql/cohttp.nix +++ b/pkgs/development/ocaml-modules/graphql/cohttp.nix @@ -1,14 +1,15 @@ -{ lib -, buildDunePackage -, ocaml-crunch -, astring -, cohttp -, digestif -, graphql -, ocplib-endian -, alcotest -, cohttp-lwt-unix -, graphql-lwt +{ + lib, + buildDunePackage, + ocaml-crunch, + astring, + cohttp, + digestif, + graphql, + ocplib-endian, + alcotest, + cohttp-lwt-unix, + graphql-lwt, }: buildDunePackage rec { @@ -19,9 +20,19 @@ buildDunePackage rec { duneVersion = "3"; nativeBuildInputs = [ ocaml-crunch ]; - propagatedBuildInputs = [ astring cohttp digestif graphql ocplib-endian ]; - - checkInputs = lib.optionals doCheck [ alcotest cohttp-lwt-unix graphql-lwt ]; + propagatedBuildInputs = [ + astring + cohttp + digestif + graphql + ocplib-endian + ]; + + checkInputs = lib.optionals doCheck [ + alcotest + cohttp-lwt-unix + graphql-lwt + ]; doCheck = true; @@ -30,5 +41,3 @@ buildDunePackage rec { }; } - - diff --git a/pkgs/development/ocaml-modules/graphql/default.nix b/pkgs/development/ocaml-modules/graphql/default.nix index 679d89f44b10d3..b095180b6dc779 100644 --- a/pkgs/development/ocaml-modules/graphql/default.nix +++ b/pkgs/development/ocaml-modules/graphql/default.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, alcotest, graphql_parser, rresult, yojson }: +{ + buildDunePackage, + alcotest, + graphql_parser, + rresult, + yojson, +}: buildDunePackage rec { pname = "graphql"; @@ -7,7 +13,11 @@ buildDunePackage rec { duneVersion = "3"; - propagatedBuildInputs = [ graphql_parser rresult yojson ]; + propagatedBuildInputs = [ + graphql_parser + rresult + yojson + ]; checkInputs = [ alcotest ]; diff --git a/pkgs/development/ocaml-modules/graphql/lwt.nix b/pkgs/development/ocaml-modules/graphql/lwt.nix index cbdcba64abb483..fbd2df35a23339 100644 --- a/pkgs/development/ocaml-modules/graphql/lwt.nix +++ b/pkgs/development/ocaml-modules/graphql/lwt.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, alcotest, graphql, ocaml_lwt }: +{ + buildDunePackage, + alcotest, + graphql, + ocaml_lwt, +}: buildDunePackage rec { pname = "graphql-lwt"; @@ -7,7 +12,10 @@ buildDunePackage rec { duneVersion = "3"; - propagatedBuildInputs = [ graphql ocaml_lwt ]; + propagatedBuildInputs = [ + graphql + ocaml_lwt + ]; checkInputs = [ alcotest ]; @@ -18,4 +26,3 @@ buildDunePackage rec { }; } - diff --git a/pkgs/development/ocaml-modules/graphql/parser.nix b/pkgs/development/ocaml-modules/graphql/parser.nix index 4042e65772bc8d..23fbd366f955ff 100644 --- a/pkgs/development/ocaml-modules/graphql/parser.nix +++ b/pkgs/development/ocaml-modules/graphql/parser.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, fetchurl, alcotest, fmt, menhir, re }: +{ + lib, + buildDunePackage, + fetchurl, + alcotest, + fmt, + menhir, + re, +}: buildDunePackage rec { pname = "graphql_parser"; @@ -13,7 +21,10 @@ buildDunePackage rec { }; nativeBuildInputs = [ menhir ]; - propagatedBuildInputs = [ fmt re ]; + propagatedBuildInputs = [ + fmt + re + ]; checkInputs = [ alcotest ]; diff --git a/pkgs/development/ocaml-modules/graphql_ppx/default.nix b/pkgs/development/ocaml-modules/graphql_ppx/default.nix index 9314c1033d4c64..08ae3343d06254 100644 --- a/pkgs/development/ocaml-modules/graphql_ppx/default.nix +++ b/pkgs/development/ocaml-modules/graphql_ppx/default.nix @@ -1,7 +1,13 @@ -{ lib, buildDunePackage, fetchFromGitHub, alcotest, reason -, result -, ppxlib -, yojson }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + alcotest, + reason, + result, + ppxlib, + yojson, +}: buildDunePackage rec { pname = "graphql_ppx"; @@ -20,7 +26,10 @@ buildDunePackage rec { nativeBuildInputs = [ reason ]; - buildInputs = [ ppxlib reason ]; + buildInputs = [ + ppxlib + reason + ]; propagatedBuildInputs = [ reason @@ -36,6 +45,9 @@ buildDunePackage rec { homepage = "https://github.com/reasonml-community/graphql_ppx"; description = "GraphQL PPX rewriter for Bucklescript/ReasonML"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ Zimmi48 jtcoolen ]; + maintainers = with lib.maintainers; [ + Zimmi48 + jtcoolen + ]; }; } diff --git a/pkgs/development/ocaml-modules/gsl/default.nix b/pkgs/development/ocaml-modules/gsl/default.nix index 726714617f25b4..5ab096a5a99c16 100644 --- a/pkgs/development/ocaml-modules/gsl/default.nix +++ b/pkgs/development/ocaml-modules/gsl/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, buildDunePackage, pkg-config, gsl, darwin, dune-configurator }: +{ + lib, + stdenv, + fetchFromGitHub, + buildDunePackage, + pkg-config, + gsl, + darwin, + dune-configurator, +}: buildDunePackage rec { pname = "gsl"; @@ -14,8 +23,13 @@ buildDunePackage rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dune-configurator gsl ]; - propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Accelerate ]; + buildInputs = [ + dune-configurator + gsl + ]; + propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Accelerate + ]; meta = with lib; { homepage = "https://mmottl.github.io/gsl-ocaml/"; diff --git a/pkgs/development/ocaml-modules/gstreamer/default.nix b/pkgs/development/ocaml-modules/gstreamer/default.nix index 689603c8e19c41..cbe55294443da5 100644 --- a/pkgs/development/ocaml-modules/gstreamer/default.nix +++ b/pkgs/development/ocaml-modules/gstreamer/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, buildDunePackage, fetchFromGitHub, dune-configurator, AppKit, Foundation, pkg-config, glib, gst_all_1 }: +{ + lib, + stdenv, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + AppKit, + Foundation, + pkg-config, + glib, + gst_all_1, +}: buildDunePackage rec { pname = "gstreamer"; @@ -12,8 +23,17 @@ buildDunePackage rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dune-configurator ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ AppKit Foundation ]; - propagatedBuildInputs = [ glib.dev gst_all_1.gstreamer.dev gst_all_1.gst-plugins-base ]; + buildInputs = + [ dune-configurator ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + Foundation + ]; + propagatedBuildInputs = [ + glib.dev + gst_all_1.gstreamer.dev + gst_all_1.gst-plugins-base + ]; CFLAGS_COMPILE = [ "-I${glib.dev}/include/glib-2.0" diff --git a/pkgs/development/ocaml-modules/h2/default.nix b/pkgs/development/ocaml-modules/h2/default.nix index 12aebd57774d99..325f6dc1f1c8d0 100644 --- a/pkgs/development/ocaml-modules/h2/default.nix +++ b/pkgs/development/ocaml-modules/h2/default.nix @@ -1,14 +1,15 @@ -{ buildDunePackage -, fetchFromGitHub -, hpack -, angstrom -, faraday -, base64 -, psq -, httpun-types -, alcotest -, yojson -, hex +{ + buildDunePackage, + fetchFromGitHub, + hpack, + angstrom, + faraday, + base64, + psq, + httpun-types, + alcotest, + yojson, + hex, }: let diff --git a/pkgs/development/ocaml-modules/h2/eio.nix b/pkgs/development/ocaml-modules/h2/eio.nix index 0beb6f3e086efe..2c75fd269ec484 100644 --- a/pkgs/development/ocaml-modules/h2/eio.nix +++ b/pkgs/development/ocaml-modules/h2/eio.nix @@ -1,7 +1,8 @@ -{ buildDunePackage -, h2 -, eio -, gluten-eio +{ + buildDunePackage, + h2, + eio, + gluten-eio, }: buildDunePackage { @@ -9,10 +10,13 @@ buildDunePackage { inherit (h2) src version; - propagatedBuildInputs = [ eio gluten-eio h2 ]; + propagatedBuildInputs = [ + eio + gluten-eio + h2 + ]; meta = h2.meta // { description = "EIO support for h2"; }; } - diff --git a/pkgs/development/ocaml-modules/hack_parallel/default.nix b/pkgs/development/ocaml-modules/hack_parallel/default.nix index 8ed2011b31c880..f7fb5ace45bc63 100644 --- a/pkgs/development/ocaml-modules/hack_parallel/default.nix +++ b/pkgs/development/ocaml-modules/hack_parallel/default.nix @@ -1,5 +1,12 @@ -{ lib, fetchFromGitHub, buildDunePackage, core, core_unix ? null, pkg-config -, sqlite }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + core, + core_unix ? null, + pkg-config, + sqlite, +}: buildDunePackage rec { pname = "hack_parallel"; version = "1.0.1"; @@ -33,11 +40,14 @@ buildDunePackage rec { nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ core core_unix sqlite ]; + propagatedBuildInputs = [ + core + core_unix + sqlite + ]; meta = { - description = - "Core parallel and shared memory library used by Hack, Flow, and Pyre"; + description = "Core parallel and shared memory library used by Hack, Flow, and Pyre"; license = lib.licenses.mit; homepage = "https://github.com/rvantonder/hack_parallel"; }; diff --git a/pkgs/development/ocaml-modules/hacl-star/default.nix b/pkgs/development/ocaml-modules/hacl-star/default.nix index 558146c3dd4b5c..62a34753b320a9 100644 --- a/pkgs/development/ocaml-modules/hacl-star/default.nix +++ b/pkgs/development/ocaml-modules/hacl-star/default.nix @@ -1,10 +1,23 @@ -{ buildDunePackage, hacl-star-raw, zarith, cppo, alcotest, secp256k1-internal, qcheck-core, cstruct }: - +{ + buildDunePackage, + hacl-star-raw, + zarith, + cppo, + alcotest, + secp256k1-internal, + qcheck-core, + cstruct, +}: buildDunePackage { pname = "hacl-star"; - inherit (hacl-star-raw) version src meta doCheck; + inherit (hacl-star-raw) + version + src + meta + doCheck + ; minimalOCamlVersion = "4.08"; diff --git a/pkgs/development/ocaml-modules/hacl-star/raw.nix b/pkgs/development/ocaml-modules/hacl-star/raw.nix index e481fea3866b24..535da5b1a1ee9a 100644 --- a/pkgs/development/ocaml-modules/hacl-star/raw.nix +++ b/pkgs/development/ocaml-modules/hacl-star/raw.nix @@ -1,12 +1,13 @@ -{ lib -, which -, stdenv -, fetchzip -, cmake -, ocaml -, findlib -, ctypes -, cppo +{ + lib, + which, + stdenv, + fetchzip, + cmake, + ocaml, + findlib, + ctypes, + cppo, }: stdenv.mkDerivation rec { pname = "ocaml${ocaml.version}-hacl-star-raw"; diff --git a/pkgs/development/ocaml-modules/happy-eyeballs/default.nix b/pkgs/development/ocaml-modules/happy-eyeballs/default.nix index 4e1eb163e37428..ea092ac66afde8 100644 --- a/pkgs/development/ocaml-modules/happy-eyeballs/default.nix +++ b/pkgs/development/ocaml-modules/happy-eyeballs/default.nix @@ -1,5 +1,12 @@ -{ lib, buildDunePackage, fetchurl -, domain-name, duration, fmt, ipaddr, logs +{ + lib, + buildDunePackage, + fetchurl, + domain-name, + duration, + fmt, + ipaddr, + logs, }: buildDunePackage rec { @@ -25,6 +32,9 @@ buildDunePackage rec { description = "Connecting to a remote host via IP version 4 or 6"; homepage = "https://github.com/roburio/happy-eyeballs"; license = lib.licenses.isc; - maintainers = with lib.maintainers; [ vbgl ulrikstrid ]; + maintainers = with lib.maintainers; [ + vbgl + ulrikstrid + ]; }; } diff --git a/pkgs/development/ocaml-modules/happy-eyeballs/lwt.nix b/pkgs/development/ocaml-modules/happy-eyeballs/lwt.nix index e7dc5b8705ef41..e5b6cf3660e15b 100644 --- a/pkgs/development/ocaml-modules/happy-eyeballs/lwt.nix +++ b/pkgs/development/ocaml-modules/happy-eyeballs/lwt.nix @@ -1,14 +1,15 @@ -{ buildDunePackage -, happy-eyeballs -, cmdliner -, dns -, duration -, domain-name -, ipaddr -, fmt -, logs -, lwt -, mtime +{ + buildDunePackage, + happy-eyeballs, + cmdliner, + dns, + duration, + domain-name, + ipaddr, + fmt, + logs, + lwt, + mtime, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/happy-eyeballs/mirage.nix b/pkgs/development/ocaml-modules/happy-eyeballs/mirage.nix index 1ff66a37104413..e0154c21ebcb8e 100644 --- a/pkgs/development/ocaml-modules/happy-eyeballs/mirage.nix +++ b/pkgs/development/ocaml-modules/happy-eyeballs/mirage.nix @@ -1,15 +1,16 @@ -{ buildDunePackage -, happy-eyeballs -, duration -, domain-name -, ipaddr -, fmt -, logs -, lwt -, mirage-clock -, mirage-random -, mirage-time -, tcpip +{ + buildDunePackage, + happy-eyeballs, + duration, + domain-name, + ipaddr, + fmt, + logs, + lwt, + mirage-clock, + mirage-random, + mirage-time, + tcpip, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/hashcons/default.nix b/pkgs/development/ocaml-modules/hashcons/default.nix index 2bfaced11551a9..72f81ca051dede 100644 --- a/pkgs/development/ocaml-modules/hashcons/default.nix +++ b/pkgs/development/ocaml-modules/hashcons/default.nix @@ -1,13 +1,17 @@ -{ lib, fetchFromGitHub, buildDunePackage }: +{ + lib, + fetchFromGitHub, + buildDunePackage, +}: buildDunePackage rec { pname = "hashcons"; version = "1.4"; src = fetchFromGitHub { - owner = "backtracking"; - repo = "ocaml-${pname}"; - rev = "d733325eeb55878bed285120c2c088daf78f0e2b"; + owner = "backtracking"; + repo = "ocaml-${pname}"; + rev = "d733325eeb55878bed285120c2c088daf78f0e2b"; sha256 = "0h4pvwj34pndaw3pajkhl710ywwinhc9pqimgllfmkl37wz2d8zq"; }; diff --git a/pkgs/development/ocaml-modules/hex/default.nix b/pkgs/development/ocaml-modules/hex/default.nix index 42c1b5d5c13b2f..1d7850b96b0304 100644 --- a/pkgs/development/ocaml-modules/hex/default.nix +++ b/pkgs/development/ocaml-modules/hex/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, buildDunePackage, cstruct }: +{ + lib, + fetchurl, + buildDunePackage, + cstruct, +}: buildDunePackage rec { pname = "hex"; diff --git a/pkgs/development/ocaml-modules/hidapi/default.nix b/pkgs/development/ocaml-modules/hidapi/default.nix index 49f92b87e015e2..d65243e2cb71ad 100644 --- a/pkgs/development/ocaml-modules/hidapi/default.nix +++ b/pkgs/development/ocaml-modules/hidapi/default.nix @@ -1,5 +1,11 @@ -{ pkgs, lib, fetchFromGitHub, buildDunePackage, pkg-config, dune-configurator -, bigstring, +{ + pkgs, + lib, + fetchFromGitHub, + buildDunePackage, + pkg-config, + dune-configurator, + bigstring, }: buildDunePackage rec { @@ -18,7 +24,10 @@ buildDunePackage rec { minimalOCamlVersion = "4.03"; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ pkgs.hidapi dune-configurator ]; + buildInputs = [ + pkgs.hidapi + dune-configurator + ]; propagatedBuildInputs = [ bigstring ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/higlo/default.nix b/pkgs/development/ocaml-modules/higlo/default.nix index fba8e35fb5be6f..2f5d5df61e3d39 100644 --- a/pkgs/development/ocaml-modules/higlo/default.nix +++ b/pkgs/development/ocaml-modules/higlo/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitLab, sedlex, xtmpl }: +{ + lib, + buildDunePackage, + fetchFromGitLab, + sedlex, + xtmpl, +}: buildDunePackage rec { pname = "higlo"; @@ -12,7 +18,10 @@ buildDunePackage rec { hash = "sha256-SaFFzp4FCjVLdMLH6mNIv3HzJbkXJ5Ojbku258LCfLI="; }; - propagatedBuildInputs = [ sedlex xtmpl ]; + propagatedBuildInputs = [ + sedlex + xtmpl + ]; meta = with lib; { description = "OCaml library for syntax highlighting"; @@ -21,5 +30,3 @@ buildDunePackage rec { maintainers = with maintainers; [ regnat ]; }; } - - diff --git a/pkgs/development/ocaml-modules/hkdf/default.nix b/pkgs/development/ocaml-modules/hkdf/default.nix index 9faa6d02b89721..b882215ae80208 100644 --- a/pkgs/development/ocaml-modules/hkdf/default.nix +++ b/pkgs/development/ocaml-modules/hkdf/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchurl, digestif, alcotest, ohex }: +{ + lib, + buildDunePackage, + fetchurl, + digestif, + alcotest, + ohex, +}: buildDunePackage rec { pname = "hkdf"; @@ -12,7 +19,10 @@ buildDunePackage rec { }; propagatedBuildInputs = [ digestif ]; - checkInputs = [ alcotest ohex ]; + checkInputs = [ + alcotest + ohex + ]; doCheck = true; meta = with lib; { diff --git a/pkgs/development/ocaml-modules/hmap/default.nix b/pkgs/development/ocaml-modules/hmap/default.nix index d0ae47031b23ab..61892116d6e936 100644 --- a/pkgs/development/ocaml-modules/hmap/default.nix +++ b/pkgs/development/ocaml-modules/hmap/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, fetchurl -, findlib -, ocaml -, ocamlbuild -, topkg +{ + stdenv, + lib, + fetchurl, + findlib, + ocaml, + ocamlbuild, + topkg, }: let @@ -22,7 +23,12 @@ stdenv.mkDerivation rec { sha256 = "10xyjy4ab87z7jnghy0wnla9wrmazgyhdwhr4hdmxxdn28dxn03a"; }; - nativeBuildInputs = [ ocaml ocamlbuild findlib topkg ]; + nativeBuildInputs = [ + ocaml + ocamlbuild + findlib + topkg + ]; buildInputs = [ topkg ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/hpack/default.nix b/pkgs/development/ocaml-modules/hpack/default.nix index c6c52a38dffd14..8a865415e3381f 100644 --- a/pkgs/development/ocaml-modules/hpack/default.nix +++ b/pkgs/development/ocaml-modules/hpack/default.nix @@ -1,8 +1,9 @@ -{ buildDunePackage -, lib -, fetchurl -, angstrom -, faraday +{ + buildDunePackage, + lib, + fetchurl, + angstrom, + faraday, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/http-mirage-client/default.nix b/pkgs/development/ocaml-modules/http-mirage-client/default.nix index d5c1cb39cfc504..86450b2311a099 100644 --- a/pkgs/development/ocaml-modules/http-mirage-client/default.nix +++ b/pkgs/development/ocaml-modules/http-mirage-client/default.nix @@ -1,17 +1,18 @@ -{ lib -, fetchurl -, buildDunePackage -, h2 -, httpaf -, mimic-happy-eyeballs -, mirage-clock -, paf -, tcpip -, x509 -, alcotest-lwt -, mirage-clock-unix -, mirage-crypto-rng -, mirage-time-unix +{ + lib, + fetchurl, + buildDunePackage, + h2, + httpaf, + mimic-happy-eyeballs, + mirage-clock, + paf, + tcpip, + x509, + alcotest-lwt, + mirage-clock-unix, + mirage-crypto-rng, + mirage-time-unix, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/httpaf/default.nix b/pkgs/development/ocaml-modules/httpaf/default.nix index c4a3dd8e317234..ec39fd6629957a 100644 --- a/pkgs/development/ocaml-modules/httpaf/default.nix +++ b/pkgs/development/ocaml-modules/httpaf/default.nix @@ -1,5 +1,11 @@ -{ lib, fetchFromGitHub, buildDunePackage -, angstrom, faraday, result, alcotest +{ + lib, + fetchFromGitHub, + buildDunePackage, + angstrom, + faraday, + result, + alcotest, }: buildDunePackage rec { @@ -16,7 +22,11 @@ buildDunePackage rec { }; checkInputs = [ alcotest ]; - propagatedBuildInputs = [ angstrom faraday result ]; + propagatedBuildInputs = [ + angstrom + faraday + result + ]; doCheck = true; meta = { diff --git a/pkgs/development/ocaml-modules/httpaf/lwt-unix.nix b/pkgs/development/ocaml-modules/httpaf/lwt-unix.nix index 46490def6f8e0d..1f915fff09ca19 100644 --- a/pkgs/development/ocaml-modules/httpaf/lwt-unix.nix +++ b/pkgs/development/ocaml-modules/httpaf/lwt-unix.nix @@ -1,7 +1,8 @@ -{ buildDunePackage -, httpaf -, faraday-lwt-unix -, lwt +{ + buildDunePackage, + httpaf, + faraday-lwt-unix, + lwt, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/httpun-ws/default.nix b/pkgs/development/ocaml-modules/httpun-ws/default.nix index 89ac696301b308..0e199d7168e7f6 100644 --- a/pkgs/development/ocaml-modules/httpun-ws/default.nix +++ b/pkgs/development/ocaml-modules/httpun-ws/default.nix @@ -1,13 +1,14 @@ -{ lib -, fetchurl -, buildDunePackage -, angstrom -, base64 -, bigstringaf -, faraday -, gluten -, httpun -, alcotest +{ + lib, + fetchurl, + buildDunePackage, + angstrom, + base64, + bigstringaf, + faraday, + gluten, + httpun, + alcotest, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/httpun/default.nix b/pkgs/development/ocaml-modules/httpun/default.nix index f45ffe5eca2e7d..51f0befde2d3cd 100644 --- a/pkgs/development/ocaml-modules/httpun/default.nix +++ b/pkgs/development/ocaml-modules/httpun/default.nix @@ -1,9 +1,10 @@ -{ buildDunePackage -, httpun-types -, angstrom -, bigstringaf -, faraday -, alcotest +{ + buildDunePackage, + httpun-types, + angstrom, + bigstringaf, + faraday, + alcotest, }: buildDunePackage { @@ -11,7 +12,12 @@ buildDunePackage { inherit (httpun-types) src version; - propagatedBuildInputs = [ angstrom bigstringaf faraday httpun-types ]; + propagatedBuildInputs = [ + angstrom + bigstringaf + faraday + httpun-types + ]; doCheck = true; checkInputs = [ alcotest ]; diff --git a/pkgs/development/ocaml-modules/httpun/eio.nix b/pkgs/development/ocaml-modules/httpun/eio.nix index 1b3160d699f1c0..b62cce32161545 100644 --- a/pkgs/development/ocaml-modules/httpun/eio.nix +++ b/pkgs/development/ocaml-modules/httpun/eio.nix @@ -1,6 +1,7 @@ -{ buildDunePackage -, httpun -, gluten-eio +{ + buildDunePackage, + httpun, + gluten-eio, }: buildDunePackage { @@ -8,7 +9,10 @@ buildDunePackage { inherit (httpun) src version; - propagatedBuildInputs = [ gluten-eio httpun ]; + propagatedBuildInputs = [ + gluten-eio + httpun + ]; meta = httpun.meta // { description = "EIO support for httpun"; diff --git a/pkgs/development/ocaml-modules/httpun/types.nix b/pkgs/development/ocaml-modules/httpun/types.nix index f69535129a31c7..260903504967fa 100644 --- a/pkgs/development/ocaml-modules/httpun/types.nix +++ b/pkgs/development/ocaml-modules/httpun/types.nix @@ -1,7 +1,8 @@ -{ lib -, buildDunePackage -, fetchurl -, faraday +{ + lib, + buildDunePackage, + fetchurl, + faraday, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/imagelib/default.nix b/pkgs/development/ocaml-modules/imagelib/default.nix index 3533a7880e3e06..d63ea0cd4dc57d 100644 --- a/pkgs/development/ocaml-modules/imagelib/default.nix +++ b/pkgs/development/ocaml-modules/imagelib/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchurl -, buildDunePackage -, decompress -, stdlib-shims -, alcotest +{ + lib, + fetchurl, + buildDunePackage, + decompress, + stdlib-shims, + alcotest, }: buildDunePackage rec { @@ -18,7 +19,10 @@ buildDunePackage rec { hash = "sha256-BQ2TVxGlpc6temteK84TKXpx0MtHZSykL/TjKN9xGP0="; }; - propagatedBuildInputs = [ decompress stdlib-shims ]; + propagatedBuildInputs = [ + decompress + stdlib-shims + ]; doCheck = true; checkInputs = [ alcotest ]; diff --git a/pkgs/development/ocaml-modules/index/default.nix b/pkgs/development/ocaml-modules/index/default.nix index edcb4161940931..598c2dd7af9a21 100644 --- a/pkgs/development/ocaml-modules/index/default.nix +++ b/pkgs/development/ocaml-modules/index/default.nix @@ -1,7 +1,21 @@ -{ lib, fetchurl, buildDunePackage -, repr, ppx_repr, fmt, logs, mtime, stdlib-shims -, cmdliner, progress, semaphore-compat, optint -, alcotest, crowbar, re, lru +{ + lib, + fetchurl, + buildDunePackage, + repr, + ppx_repr, + fmt, + logs, + mtime, + stdlib-shims, + cmdliner, + progress, + semaphore-compat, + optint, + alcotest, + crowbar, + re, + lru, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/inifiles/default.nix b/pkgs/development/ocaml-modules/inifiles/default.nix index a78e314b76656c..e4ac784b42b00f 100644 --- a/pkgs/development/ocaml-modules/inifiles/default.nix +++ b/pkgs/development/ocaml-modules/inifiles/default.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchurl, fetchpatch, ocaml, findlib, ocaml_pcre }: +{ + stdenv, + lib, + fetchurl, + fetchpatch, + ocaml, + findlib, + ocaml_pcre, +}: stdenv.mkDerivation rec { pname = "ocaml${ocaml.version}-inifiles"; @@ -20,12 +28,18 @@ stdenv.mkDerivation rec { substituteInPlace inifiles.ml --replace 'String.lowercase ' 'String.lowercase_ascii ' ''; - nativeBuildInputs = [ ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; propagatedBuildInputs = [ ocaml_pcre ]; strictDeps = true; - buildFlags = [ "all" "opt" ]; + buildFlags = [ + "all" + "opt" + ]; createFindlibDestdir = true; diff --git a/pkgs/development/ocaml-modules/inotify/default.nix b/pkgs/development/ocaml-modules/inotify/default.nix index 2a4f1ccd01ffbb..900f60e7c77495 100644 --- a/pkgs/development/ocaml-modules/inotify/default.nix +++ b/pkgs/development/ocaml-modules/inotify/default.nix @@ -1,6 +1,10 @@ -{ lib, fetchFromGitHub, buildDunePackage -, lwt # optional lwt support -, ounit2, fileutils # only for tests +{ + lib, + fetchFromGitHub, + buildDunePackage, + lwt, # optional lwt support + ounit2, + fileutils, # only for tests }: buildDunePackage rec { @@ -16,7 +20,10 @@ buildDunePackage rec { buildInputs = [ lwt ]; - checkInputs = [ ounit2 fileutils ]; + checkInputs = [ + ounit2 + fileutils + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/integers/default.nix b/pkgs/development/ocaml-modules/integers/default.nix index 343aeb216ba867..104438eeab50d6 100644 --- a/pkgs/development/ocaml-modules/integers/default.nix +++ b/pkgs/development/ocaml-modules/integers/default.nix @@ -1,5 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage -, stdlib-shims +{ + lib, + fetchFromGitHub, + buildDunePackage, + stdlib-shims, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/integers_stubs_js/default.nix b/pkgs/development/ocaml-modules/integers_stubs_js/default.nix index 236c44bcaa7519..1ab3dbb254073e 100644 --- a/pkgs/development/ocaml-modules/integers_stubs_js/default.nix +++ b/pkgs/development/ocaml-modules/integers_stubs_js/default.nix @@ -1,6 +1,8 @@ { - lib, fetchFromGitHub, buildDunePackage -, zarith_stubs_js ? null + lib, + fetchFromGitHub, + buildDunePackage, + zarith_stubs_js ? null, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/io-page/default.nix b/pkgs/development/ocaml-modules/io-page/default.nix index 79142f0e8d4d24..7860ecd681540a 100644 --- a/pkgs/development/ocaml-modules/io-page/default.nix +++ b/pkgs/development/ocaml-modules/io-page/default.nix @@ -1,4 +1,12 @@ -{ lib, fetchurl, buildDunePackage, pkg-config, cstruct, bigarray-compat, ounit }: +{ + lib, + fetchurl, + buildDunePackage, + pkg-config, + cstruct, + bigarray-compat, + ounit, +}: buildDunePackage rec { pname = "io-page"; @@ -13,7 +21,10 @@ buildDunePackage rec { }; nativeBuildInputs = [ pkg-config ]; - propagatedBuildInputs = [ cstruct bigarray-compat ]; + propagatedBuildInputs = [ + cstruct + bigarray-compat + ]; checkInputs = [ ounit ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/iomux/default.nix b/pkgs/development/ocaml-modules/iomux/default.nix index f1dc827a32d092..c4260b151eff1d 100644 --- a/pkgs/development/ocaml-modules/iomux/default.nix +++ b/pkgs/development/ocaml-modules/iomux/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchurl -, buildDunePackage -, dune-configurator -, alcotest +{ + lib, + fetchurl, + buildDunePackage, + dune-configurator, + alcotest, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ipaddr/cstruct.nix b/pkgs/development/ocaml-modules/ipaddr/cstruct.nix index 8471d9c4e8dc1c..5091612d940445 100644 --- a/pkgs/development/ocaml-modules/ipaddr/cstruct.nix +++ b/pkgs/development/ocaml-modules/ipaddr/cstruct.nix @@ -1,5 +1,7 @@ -{ buildDunePackage -, ipaddr, cstruct +{ + buildDunePackage, + ipaddr, + cstruct, }: buildDunePackage rec { @@ -9,7 +11,10 @@ buildDunePackage rec { duneVersion = "3"; - propagatedBuildInputs = [ ipaddr cstruct ]; + propagatedBuildInputs = [ + ipaddr + cstruct + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/ipaddr/default.nix b/pkgs/development/ocaml-modules/ipaddr/default.nix index b30da4c5aaa09f..8ed4d492149d4a 100644 --- a/pkgs/development/ocaml-modules/ipaddr/default.nix +++ b/pkgs/development/ocaml-modules/ipaddr/default.nix @@ -1,6 +1,11 @@ -{ lib, buildDunePackage -, macaddr, domain-name, stdlib-shims -, ounit2, ppx_sexp_conv +{ + lib, + buildDunePackage, + macaddr, + domain-name, + stdlib-shims, + ounit2, + ppx_sexp_conv, }: buildDunePackage rec { @@ -11,13 +16,23 @@ buildDunePackage rec { minimalOCamlVersion = "4.08"; duneVersion = "3"; - propagatedBuildInputs = [ macaddr domain-name stdlib-shims ]; + propagatedBuildInputs = [ + macaddr + domain-name + stdlib-shims + ]; - checkInputs = [ ppx_sexp_conv ounit2 ]; + checkInputs = [ + ppx_sexp_conv + ounit2 + ]; doCheck = true; meta = macaddr.meta // { description = "Library for manipulation of IP (and MAC) address representations"; - maintainers = with lib.maintainers; [ alexfmpe ericbmerritt ]; + maintainers = with lib.maintainers; [ + alexfmpe + ericbmerritt + ]; }; } diff --git a/pkgs/development/ocaml-modules/ipaddr/sexp.nix b/pkgs/development/ocaml-modules/ipaddr/sexp.nix index 0a05c7fbadd668..15de03d0c30993 100644 --- a/pkgs/development/ocaml-modules/ipaddr/sexp.nix +++ b/pkgs/development/ocaml-modules/ipaddr/sexp.nix @@ -1,5 +1,9 @@ -{ buildDunePackage -, ipaddr, ipaddr-cstruct, ounit2, ppx_sexp_conv +{ + buildDunePackage, + ipaddr, + ipaddr-cstruct, + ounit2, + ppx_sexp_conv, }: buildDunePackage rec { @@ -11,7 +15,11 @@ buildDunePackage rec { propagatedBuildInputs = [ ipaddr ]; - checkInputs = [ ipaddr-cstruct ounit2 ppx_sexp_conv ]; + checkInputs = [ + ipaddr-cstruct + ounit2 + ppx_sexp_conv + ]; doCheck = true; meta = ipaddr.meta // { diff --git a/pkgs/development/ocaml-modules/iri/default.nix b/pkgs/development/ocaml-modules/iri/default.nix index 54db34bc9740e0..a8f0bf5d77693f 100644 --- a/pkgs/development/ocaml-modules/iri/default.nix +++ b/pkgs/development/ocaml-modules/iri/default.nix @@ -1,5 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitLab -, sedlex, uunf, uutf +{ + lib, + buildDunePackage, + fetchFromGitLab, + sedlex, + uunf, + uutf, }: buildDunePackage rec { @@ -16,7 +21,11 @@ buildDunePackage rec { hash = "sha256-6Q7qPezmdcO6JSevWl55XAxFuIROZNDrMkYw8VRR7qg="; }; - propagatedBuildInputs = [ sedlex uunf uutf ]; + propagatedBuildInputs = [ + sedlex + uunf + uutf + ]; meta = { description = "IRI (RFC3987) native OCaml implementation"; diff --git a/pkgs/development/ocaml-modules/irmin-watcher/default.nix b/pkgs/development/ocaml-modules/irmin-watcher/default.nix index 7304528b7dc577..62c266750b799d 100644 --- a/pkgs/development/ocaml-modules/irmin-watcher/default.nix +++ b/pkgs/development/ocaml-modules/irmin-watcher/default.nix @@ -1,5 +1,11 @@ -{ lib, fetchurl, buildDunePackage -, astring, fmt, logs, ocaml_lwt +{ + lib, + fetchurl, + buildDunePackage, + astring, + fmt, + logs, + ocaml_lwt, }: buildDunePackage rec { @@ -13,7 +19,12 @@ buildDunePackage rec { sha256 = "sha256-vq4kwaz4QUG9x0fGEbQMAuDGjlT3/6lm8xiXTUqJmZM="; }; - propagatedBuildInputs = [ astring fmt logs ocaml_lwt ]; + propagatedBuildInputs = [ + astring + fmt + logs + ocaml_lwt + ]; meta = { homepage = "https://github.com/mirage/irmin-watcher"; diff --git a/pkgs/development/ocaml-modules/irmin/chunk.nix b/pkgs/development/ocaml-modules/irmin/chunk.nix index ce955265a2f886..7def846cff25ad 100644 --- a/pkgs/development/ocaml-modules/irmin/chunk.nix +++ b/pkgs/development/ocaml-modules/irmin/chunk.nix @@ -1,18 +1,33 @@ -{ buildDunePackage, irmin, irmin-test, fmt, logs, lwt, alcotest }: +{ + buildDunePackage, + irmin, + irmin-test, + fmt, + logs, + lwt, + alcotest, +}: buildDunePackage rec { pname = "irmin-chunk"; inherit (irmin) version src; - propagatedBuildInputs = [ irmin fmt logs lwt ]; + propagatedBuildInputs = [ + irmin + fmt + logs + lwt + ]; doCheck = true; - checkInputs = [ alcotest irmin-test ]; + checkInputs = [ + alcotest + irmin-test + ]; meta = irmin.meta // { description = "Irmin backend which allow to store values into chunks"; }; } - diff --git a/pkgs/development/ocaml-modules/irmin/containers.nix b/pkgs/development/ocaml-modules/irmin/containers.nix index 32677d9604c2f7..3d2b70d0eec4c0 100644 --- a/pkgs/development/ocaml-modules/irmin/containers.nix +++ b/pkgs/development/ocaml-modules/irmin/containers.nix @@ -1,6 +1,13 @@ -{ buildDunePackage -, irmin, irmin-fs, ppx_irmin, lwt, mtime -, alcotest, alcotest-lwt, cacert +{ + buildDunePackage, + irmin, + irmin-fs, + ppx_irmin, + lwt, + mtime, + alcotest, + alcotest-lwt, + cacert, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/irmin/default.nix b/pkgs/development/ocaml-modules/irmin/default.nix index da8531a9dec28f..2abcfc7d21e53b 100644 --- a/pkgs/development/ocaml-modules/irmin/default.nix +++ b/pkgs/development/ocaml-modules/irmin/default.nix @@ -1,7 +1,23 @@ -{ buildDunePackage -, astring, digestif, fmt, jsonm, logs, ocamlgraph, uri -, repr, ppx_irmin, bheap, uutf, mtime, lwt, optint -, vector, hex, alcotest, qcheck-alcotest +{ + buildDunePackage, + astring, + digestif, + fmt, + jsonm, + logs, + ocamlgraph, + uri, + repr, + ppx_irmin, + bheap, + uutf, + mtime, + lwt, + optint, + vector, + hex, + alcotest, + qcheck-alcotest, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/irmin/fs.nix b/pkgs/development/ocaml-modules/irmin/fs.nix index 093a68fe78ef0c..4d395a36fffb7e 100644 --- a/pkgs/development/ocaml-modules/irmin/fs.nix +++ b/pkgs/development/ocaml-modules/irmin/fs.nix @@ -1,5 +1,12 @@ -{ buildDunePackage, irmin, astring, logs, lwt -, alcotest, irmin-test, irmin-watcher +{ + buildDunePackage, + irmin, + astring, + logs, + lwt, + alcotest, + irmin-test, + irmin-watcher, }: buildDunePackage rec { @@ -8,9 +15,18 @@ buildDunePackage rec { inherit (irmin) version src; - propagatedBuildInputs = [ irmin astring logs lwt ]; - - checkInputs = [ alcotest irmin-test irmin-watcher ]; + propagatedBuildInputs = [ + irmin + astring + logs + lwt + ]; + + checkInputs = [ + alcotest + irmin-test + irmin-watcher + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/irmin/git.nix b/pkgs/development/ocaml-modules/irmin/git.nix index 1fde734d9c264d..22c1351288ed2e 100644 --- a/pkgs/development/ocaml-modules/irmin/git.nix +++ b/pkgs/development/ocaml-modules/irmin/git.nix @@ -1,8 +1,24 @@ -{ buildDunePackage -, git, irmin, ppx_irmin, git-unix, irmin-watcher -, digestif, cstruct, fmt, astring, fpath, logs, lwt, uri -, cohttp-lwt-unix, mimic -, irmin-test, mtime, alcotest, cacert +{ + buildDunePackage, + git, + irmin, + ppx_irmin, + git-unix, + irmin-watcher, + digestif, + cstruct, + fmt, + astring, + fpath, + logs, + lwt, + uri, + cohttp-lwt-unix, + mimic, + irmin-test, + mtime, + alcotest, + cacert, }: buildDunePackage { @@ -29,7 +45,12 @@ buildDunePackage { cohttp-lwt-unix ]; - checkInputs = [ mtime alcotest irmin-test cacert ]; + checkInputs = [ + mtime + alcotest + irmin-test + cacert + ]; doCheck = true; @@ -38,4 +59,3 @@ buildDunePackage { }; } - diff --git a/pkgs/development/ocaml-modules/irmin/graphql.nix b/pkgs/development/ocaml-modules/irmin/graphql.nix index 93b5c939e8fa1d..945e9d728c3790 100644 --- a/pkgs/development/ocaml-modules/irmin/graphql.nix +++ b/pkgs/development/ocaml-modules/irmin/graphql.nix @@ -1,5 +1,16 @@ -{ buildDunePackage, cohttp-lwt, cohttp-lwt-unix, graphql-cohttp, graphql-lwt, irmin, git-unix -, alcotest, alcotest-lwt, logs, yojson, cacert +{ + buildDunePackage, + cohttp-lwt, + cohttp-lwt-unix, + graphql-cohttp, + graphql-lwt, + irmin, + git-unix, + alcotest, + alcotest-lwt, + logs, + yojson, + cacert, }: buildDunePackage rec { @@ -8,7 +19,14 @@ buildDunePackage rec { inherit (irmin) version src; - propagatedBuildInputs = [ cohttp-lwt cohttp-lwt-unix graphql-cohttp graphql-lwt irmin git-unix ]; + propagatedBuildInputs = [ + cohttp-lwt + cohttp-lwt-unix + graphql-cohttp + graphql-lwt + irmin + git-unix + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/irmin/mirage-git.nix b/pkgs/development/ocaml-modules/irmin/mirage-git.nix index 7528e469913f7b..810821b6ecc1da 100644 --- a/pkgs/development/ocaml-modules/irmin/mirage-git.nix +++ b/pkgs/development/ocaml-modules/irmin/mirage-git.nix @@ -1,6 +1,17 @@ -{ buildDunePackage, irmin-mirage, irmin-git -, mirage-kv, cohttp, conduit-lwt, conduit-mirage -, git-paf, fmt, git, lwt, mirage-clock, uri +{ + buildDunePackage, + irmin-mirage, + irmin-git, + mirage-kv, + cohttp, + conduit-lwt, + conduit-mirage, + git-paf, + fmt, + git, + lwt, + mirage-clock, + uri, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/irmin/mirage-graphql.nix b/pkgs/development/ocaml-modules/irmin/mirage-graphql.nix index 1973cde8c3b6df..a79a7a4286fc84 100644 --- a/pkgs/development/ocaml-modules/irmin/mirage-graphql.nix +++ b/pkgs/development/ocaml-modules/irmin/mirage-graphql.nix @@ -1,5 +1,12 @@ -{ buildDunePackage, irmin-mirage, irmin-graphql -, mirage-clock, cohttp-lwt, lwt, uri, git +{ + buildDunePackage, + irmin-mirage, + irmin-graphql, + mirage-clock, + cohttp-lwt, + lwt, + uri, + git, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/irmin/mirage.nix b/pkgs/development/ocaml-modules/irmin/mirage.nix index eabb1e5874e876..1dfcc3d89fe498 100644 --- a/pkgs/development/ocaml-modules/irmin/mirage.nix +++ b/pkgs/development/ocaml-modules/irmin/mirage.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, irmin, fmt, ptime, mirage-clock }: +{ + buildDunePackage, + irmin, + fmt, + ptime, + mirage-clock, +}: buildDunePackage { pname = "irmin-mirage"; @@ -6,7 +12,10 @@ buildDunePackage { inherit (irmin) version src; propagatedBuildInputs = [ - irmin fmt ptime mirage-clock + irmin + fmt + ptime + mirage-clock ]; meta = irmin.meta // { diff --git a/pkgs/development/ocaml-modules/irmin/pack.nix b/pkgs/development/ocaml-modules/irmin/pack.nix index bb1a65354fb712..ecdb968f3c9cf8 100644 --- a/pkgs/development/ocaml-modules/irmin/pack.nix +++ b/pkgs/development/ocaml-modules/irmin/pack.nix @@ -1,6 +1,20 @@ -{ buildDunePackage -, index, ppx_irmin, irmin, optint, fmt, logs, lwt, mtime, cmdliner, checkseum, rusage -, alcotest, alcotest-lwt, astring, irmin-test +{ + buildDunePackage, + index, + ppx_irmin, + irmin, + optint, + fmt, + logs, + lwt, + mtime, + cmdliner, + checkseum, + rusage, + alcotest, + alcotest-lwt, + astring, + irmin-test, }: buildDunePackage rec { @@ -12,9 +26,25 @@ buildDunePackage rec { nativeBuildInputs = [ ppx_irmin ]; - propagatedBuildInputs = [ index irmin optint fmt logs lwt mtime cmdliner checkseum rusage ]; - - checkInputs = [ astring alcotest alcotest-lwt irmin-test ]; + propagatedBuildInputs = [ + index + irmin + optint + fmt + logs + lwt + mtime + cmdliner + checkseum + rusage + ]; + + checkInputs = [ + astring + alcotest + alcotest-lwt + irmin-test + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/irmin/ppx.nix b/pkgs/development/ocaml-modules/irmin/ppx.nix index 23165099443ebe..4d22f4a833c0d2 100644 --- a/pkgs/development/ocaml-modules/irmin/ppx.nix +++ b/pkgs/development/ocaml-modules/irmin/ppx.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, buildDunePackage, ppxlib, ppx_repr, logs }: +{ + lib, + fetchurl, + buildDunePackage, + ppxlib, + ppx_repr, + logs, +}: buildDunePackage rec { pname = "ppx_irmin"; @@ -21,6 +28,9 @@ buildDunePackage rec { homepage = "https://irmin.org/"; description = "PPX deriver for Irmin generics"; license = lib.licenses.isc; - maintainers = with lib.maintainers; [ vbgl sternenseemann ]; + maintainers = with lib.maintainers; [ + vbgl + sternenseemann + ]; }; } diff --git a/pkgs/development/ocaml-modules/irmin/test.nix b/pkgs/development/ocaml-modules/irmin/test.nix index a0e206cade7209..a29337effc85b9 100644 --- a/pkgs/development/ocaml-modules/irmin/test.nix +++ b/pkgs/development/ocaml-modules/irmin/test.nix @@ -1,6 +1,21 @@ -{ buildDunePackage, irmin, ppx_irmin, mtime, astring, fmt, jsonm, logs, lwt -, metrics-unix, ocaml-syntax-shims, cmdliner, metrics, alcotest-lwt -, hex, vector, qcheck-alcotest +{ + buildDunePackage, + irmin, + ppx_irmin, + mtime, + astring, + fmt, + jsonm, + logs, + lwt, + metrics-unix, + ocaml-syntax-shims, + cmdliner, + metrics, + alcotest-lwt, + hex, + vector, + qcheck-alcotest, }: buildDunePackage { @@ -28,7 +43,11 @@ buildDunePackage { ]; doCheck = true; - checkInputs = [ hex qcheck-alcotest vector ]; + checkInputs = [ + hex + qcheck-alcotest + vector + ]; meta = irmin.meta // { description = "Irmin test suite"; diff --git a/pkgs/development/ocaml-modules/irmin/tezos.nix b/pkgs/development/ocaml-modules/irmin/tezos.nix index ec005921c938bb..08d84929aea424 100644 --- a/pkgs/development/ocaml-modules/irmin/tezos.nix +++ b/pkgs/development/ocaml-modules/irmin/tezos.nix @@ -1,6 +1,18 @@ -{ lib, buildDunePackage -, irmin, irmin-pack, ppx_irmin, digestif, cmdliner, fmt, yojson, tezos-base58 -, alcotest, hex, irmin-test, fpath +{ + lib, + buildDunePackage, + irmin, + irmin-pack, + ppx_irmin, + digestif, + cmdliner, + fmt, + yojson, + tezos-base58, + alcotest, + hex, + irmin-test, + fpath, }: buildDunePackage rec { @@ -22,7 +34,12 @@ buildDunePackage rec { yojson ]; - checkInputs = [ alcotest hex irmin-test fpath ]; + checkInputs = [ + alcotest + hex + irmin-test + fpath + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/iso8601/default.nix b/pkgs/development/ocaml-modules/iso8601/default.nix index 5c6d4104b6a332..39dbd8e07fd63b 100644 --- a/pkgs/development/ocaml-modules/iso8601/default.nix +++ b/pkgs/development/ocaml-modules/iso8601/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, ocaml, findlib, ocamlbuild }: +{ + stdenv, + lib, + fetchFromGitHub, + ocaml, + findlib, + ocamlbuild, +}: stdenv.mkDerivation rec { pname = "ocaml-iso8601"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-QWjZ+2AjvXnnRVenbyCG/hSjfW53bHiftQUtWpK/7I8="; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/iter/default.nix b/pkgs/development/ocaml-modules/iter/default.nix index 109e51ee6f9194..df5316286b8b30 100644 --- a/pkgs/development/ocaml-modules/iter/default.nix +++ b/pkgs/development/ocaml-modules/iter/default.nix @@ -1,5 +1,10 @@ -{ lib, fetchurl, buildDunePackage -, mdx, ounit2, qcheck-core +{ + lib, + fetchurl, + buildDunePackage, + mdx, + ounit2, + qcheck-core, }: buildDunePackage rec { @@ -15,7 +20,10 @@ buildDunePackage rec { doCheck = true; nativeCheckInputs = [ mdx.bin ]; - checkInputs = [ ounit2 qcheck-core ]; + checkInputs = [ + ounit2 + qcheck-core + ]; meta = { homepage = "https://github.com/c-cube/sequence"; diff --git a/pkgs/development/ocaml-modules/janestreet/0.12.nix b/pkgs/development/ocaml-modules/janestreet/0.12.nix index a3b2ac581555ab..3fa02d9797758b 100644 --- a/pkgs/development/ocaml-modules/janestreet/0.12.nix +++ b/pkgs/development/ocaml-modules/janestreet/0.12.nix @@ -1,5 +1,6 @@ -{ self -, openssl +{ + self, + openssl, }: with self; @@ -59,7 +60,11 @@ with self; pname = "ppx_assert"; hash = "0as6mzr6ki2a9d4k6132p9dskn0qssla1s7j5rkzp75bfikd0ip8"; meta.description = "Assert-like extension nodes that raise useful errors on failure"; - propagatedBuildInputs = [ ppx_compare ppx_here ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_compare + ppx_here + ppx_sexp_conv + ]; }; ppx_inline_test = janePackage { @@ -88,7 +93,10 @@ with self; pname = "ppx_fields_conv"; hash = "0flrdyxdfcqcmdrbipxdjq0s3djdgs7z5pvjdycsvs6czbixz70v"; meta.description = "Generation of accessor and iteration functions for ocaml records"; - propagatedBuildInputs = [ fieldslib ppxlib ]; + propagatedBuildInputs = [ + fieldslib + ppxlib + ]; }; variantslib = janePackage { @@ -102,14 +110,24 @@ with self; pname = "ppx_variants_conv"; hash = "05j9bgra8xq6fcp12ch3z9vjrk139p2wrcjjcs4h52n5hhc8vzbz"; meta.description = "Generation of accessor and iteration functions for ocaml variant types"; - propagatedBuildInputs = [ variantslib ppxlib ]; + propagatedBuildInputs = [ + variantslib + ppxlib + ]; }; ppx_expect = janePackage { pname = "ppx_expect"; hash = "1wawsbjfkri4sw52n8xqrzihxc3xfpdicv3ahz83a1rsn4lb8j5q"; meta.description = "Cram like framework for OCaml"; - propagatedBuildInputs = [ ppx_assert ppx_custom_printf ppx_fields_conv ppx_inline_test ppx_variants_conv re ]; + propagatedBuildInputs = [ + ppx_assert + ppx_custom_printf + ppx_fields_conv + ppx_inline_test + ppx_variants_conv + re + ]; }; ppx_enumerate = janePackage { @@ -123,21 +141,31 @@ with self; pname = "ppx_hash"; hash = "1dfsfvhiyp1mnf24mr93svpdn432kla0y7x631lssacxxp2sadbg"; meta.description = "A ppx rewriter that generates hash functions from type expressions and definitions"; - propagatedBuildInputs = [ ppx_compare ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_compare + ppx_sexp_conv + ]; }; ppx_js_style = janePackage { pname = "ppx_js_style"; hash = "1lz931m3qdv3yzqy6dnb8fq1d99r61w0n7cwf3b9fl9rhk0pggwh"; meta.description = "Code style checker for Jane Street Packages"; - propagatedBuildInputs = [ octavius ppxlib ]; + propagatedBuildInputs = [ + octavius + ppxlib + ]; }; ppx_base = janePackage { pname = "ppx_base"; hash = "0vd96rp2l084iamkwmvizzhl9625cagjb6gzzbir06czii5mlq2p"; meta.description = "Base set of ppx rewriters"; - propagatedBuildInputs = [ ppx_enumerate ppx_hash ppx_js_style ]; + propagatedBuildInputs = [ + ppx_enumerate + ppx_hash + ppx_js_style + ]; }; ppx_bench = janePackage { @@ -151,14 +179,22 @@ with self; pname = "ppx_sexp_message"; hash = "0yskd6v48jc6wa0nhg685kylh1n9qb6b7d1wglr9wnhl9sw990mc"; meta.description = "A ppx rewriter for easy construction of s-expressions"; - propagatedBuildInputs = [ ppx_here ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_here + ppx_sexp_conv + ]; }; splittable_random = janePackage { pname = "splittable_random"; hash = "1wpyz7807cgj8b50gdx4rw6f1zsznp4ni5lzjbnqdwa66na6ynr4"; meta.description = "PRNG that can be split into independent streams"; - propagatedBuildInputs = [ base ppx_assert ppx_bench ppx_sexp_message ]; + propagatedBuildInputs = [ + base + ppx_assert + ppx_bench + ppx_sexp_message + ]; }; ppx_let = janePackage { @@ -173,7 +209,12 @@ with self; pname = "base_quickcheck"; hash = "sha256-ABfUtOzdtGrYR6EgtVYkmxRvsH48jJwSVVOwf4Od12Y="; meta.description = "Randomized testing framework, designed for compatibility with Base"; - propagatedBuildInputs = [ ppx_base ppx_fields_conv ppx_let splittable_random ]; + propagatedBuildInputs = [ + ppx_base + ppx_fields_conv + ppx_let + splittable_random + ]; }; ppx_stable = janePackage { @@ -187,7 +228,12 @@ with self; pname = "bin_prot"; hash = "0hh6s7g9s004z35hsr8z6nw5phlcvcd6g2q3bj4f0s1s0anlsswm"; meta.description = "A binary protocol generator"; - propagatedBuildInputs = [ ppx_compare ppx_custom_printf ppx_fields_conv ppx_variants_conv ]; + propagatedBuildInputs = [ + ppx_compare + ppx_custom_printf + ppx_fields_conv + ppx_variants_conv + ]; }; ppx_bin_prot = janePackage { @@ -195,7 +241,10 @@ with self; version = "0.12.1"; hash = "1j0kjgmv58dmg3x5dj5zrfbm920rwq21lvkkaqq493y76cd0x8xg"; meta.description = "Generation of bin_prot readers and writers from types"; - propagatedBuildInputs = [ bin_prot ppx_here ]; + propagatedBuildInputs = [ + bin_prot + ppx_here + ]; }; ppx_fail = janePackage { @@ -209,7 +258,10 @@ with self; pname = "jst-config"; hash = "0yxcz13vda1mdh9ah7qqxwfxpcqang5sgdssd8721rszbwqqaw93"; meta.description = "Compile-time configuration for Jane Street libraries"; - buildInputs = [ dune-configurator ppx_assert ]; + buildInputs = [ + dune-configurator + ppx_assert + ]; }; ppx_optcomp = janePackage { @@ -229,8 +281,15 @@ with self; pname = "time_now"; hash = "169mgsb3rja4j1j9nj5xa7bbkd21p9kfpskqz0wjf9x2fpxqsniq"; meta.description = "Reports the current time"; - buildInputs = [ jst-config ppx_optcomp ]; - propagatedBuildInputs = [ jane-street-headers base ppx_base ]; + buildInputs = [ + jst-config + ppx_optcomp + ]; + propagatedBuildInputs = [ + jane-street-headers + base + ppx_base + ]; }; ppx_module_timer = janePackage { @@ -258,7 +317,10 @@ with self; pname = "ppx_sexp_value"; hash = "1mg81834a6dx1x7x9zb9wc58438cabjjw08yhkx6i386hxfy891p"; meta.description = "A ppx rewriter that simplifies building s-expressions from ocaml values"; - propagatedBuildInputs = [ ppx_here ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_here + ppx_sexp_conv + ]; }; typerep = janePackage { @@ -272,14 +334,30 @@ with self; pname = "ppx_typerep_conv"; hash = "09vik6qma1id44k8nz87y48l9wbjhqhap1ar1hpfdfkjai1hrzzq"; meta.description = "Generation of runtime types from type declarations"; - propagatedBuildInputs = [ ppxlib typerep ]; + propagatedBuildInputs = [ + ppxlib + typerep + ]; }; ppx_jane = janePackage { pname = "ppx_jane"; hash = "1a2602isqzsh640q20qbmarx0sc316mlsqc3i25ysv2kdyhh0kyw"; meta.description = "Standard Jane Street ppx rewriters"; - propagatedBuildInputs = [ base_quickcheck ppx_bench ppx_bin_prot ppx_expect ppx_fail ppx_module_timer ppx_optcomp ppx_optional ppx_pipebang ppx_sexp_value ppx_stable ppx_typerep_conv ]; + propagatedBuildInputs = [ + base_quickcheck + ppx_bench + ppx_bin_prot + ppx_expect + ppx_fail + ppx_module_timer + ppx_optcomp + ppx_optional + ppx_pipebang + ppx_sexp_value + ppx_stable + ppx_typerep_conv + ]; }; base_bigstring = janePackage { @@ -293,14 +371,20 @@ with self; pname = "parsexp"; hash = "1974i9s2c2n03iffxrm6ncwbd2gg6j6avz5jsxfd35scc2zxcd4l"; meta.description = "S-expression parsing library"; - propagatedBuildInputs = [ base sexplib0 ]; + propagatedBuildInputs = [ + base + sexplib0 + ]; }; sexplib = janePackage { pname = "sexplib"; hash = "0780klc5nnv0ij6aklzra517cfnfkjdlp8ylwjrqwr8dl9rvxza2"; meta.description = "Library for serializing OCaml values to and from S-expressions"; - propagatedBuildInputs = [ num parsexp ]; + propagatedBuildInputs = [ + num + parsexp + ]; }; core_kernel = janePackage { @@ -309,7 +393,10 @@ with self; hash = "sha256-bDgxuOILAs4FYB8o92ysPHDdEzflZMsU/jk5hB9xfuc="; meta.description = "System-independent part of Core"; buildInputs = [ jst-config ]; - propagatedBuildInputs = [ base_bigstring sexplib ]; + propagatedBuildInputs = [ + base_bigstring + sexplib + ]; }; spawn = janePackage { @@ -326,7 +413,10 @@ with self; hash = "1vmjqiafkg45hqfvahx6jnlaww1q4a4215k8znbgprf0qn3zymnj"; meta.description = "System-independent part of Core"; buildInputs = [ jst-config ]; - propagatedBuildInputs = [ core_kernel spawn ]; + propagatedBuildInputs = [ + core_kernel + spawn + ]; }; async_kernel = janePackage { @@ -347,21 +437,30 @@ with self; pname = "async_rpc_kernel"; hash = "1znhqbzx4fp58i7dbcgyv5rx7difbhb5d8cbqzv96yqvbn67lsjk"; meta.description = "Platform-independent core of Async RPC library"; - propagatedBuildInputs = [ async_kernel protocol_version_header ]; + propagatedBuildInputs = [ + async_kernel + protocol_version_header + ]; }; async_unix = janePackage { pname = "async_unix"; hash = "09h10rdyykbm88n6r9nb5a22mlb6vcxa04q6hvrcr0kys6qhhqmb"; meta.description = "Monadic concurrency library"; - propagatedBuildInputs = [ async_kernel core ]; + propagatedBuildInputs = [ + async_kernel + core + ]; }; async_extra = janePackage { pname = "async_extra"; hash = "10j4mwlyqvf67yrp5dwd857llqjinpnnykmlzw2gpmks9azxk6mh"; meta.description = "Monadic concurrency library"; - propagatedBuildInputs = [ async_rpc_kernel async_unix ]; + propagatedBuildInputs = [ + async_rpc_kernel + async_unix + ]; }; textutils = janePackage { @@ -375,7 +474,10 @@ with self; pname = "async"; hash = "0pk7z3h2gi21nfchvmjz2wx516bynf9vgwf84zf5qhvlvqqsmyrx"; meta.description = "Monadic concurrency library"; - propagatedBuildInputs = [ async_extra textutils ]; + propagatedBuildInputs = [ + async_extra + textutils + ]; }; async_find = janePackage { @@ -402,14 +504,20 @@ with self; hash = "158857rdr6qgglc5iksg0l54jgf51b5lmsw7nlazpxwdwc9fcn5n"; meta.description = "Yet another implementation of fork&exec and related functionality"; buildInputs = [ jst-config ]; - propagatedBuildInputs = [ re2 textutils ]; + propagatedBuildInputs = [ + re2 + textutils + ]; }; async_shell = janePackage { pname = "async_shell"; hash = "0cxln9hkc3cy522la9yi9p23qjwl69kqmadsq4lnjh5bxdad06sv"; meta.description = "Shell helpers for Async"; - propagatedBuildInputs = [ async shell ]; + propagatedBuildInputs = [ + async + shell + ]; }; core_bench = janePackage { @@ -430,7 +538,11 @@ with self; pname = "sexp_pretty"; hash = "06hdsaszc5cd7fphiblbn4r1sh36xgjwf2igzr2rvlzqs7jiv2v4"; meta.description = "S-expression pretty-printer"; - propagatedBuildInputs = [ ppx_base re sexplib ]; + propagatedBuildInputs = [ + ppx_base + re + sexplib + ]; }; expect_test_helpers_kernel = janePackage { @@ -438,14 +550,20 @@ with self; hash = "18ya187y2i2hfxr771sd9vy5jdsa30vhs56yjdhwk06v01b2fzbq"; meta.description = "Helpers for writing expectation tests"; buildInputs = [ ppx_jane ]; - propagatedBuildInputs = [ core_kernel sexp_pretty ]; + propagatedBuildInputs = [ + core_kernel + sexp_pretty + ]; }; expect_test_helpers = janePackage { pname = "expect_test_helpers"; hash = "0ixqck2lnsmz107yw0q2sr8va80skjpldx7lz4ymjiq2vsghk0rb"; meta.description = "Async helpers for writing expectation tests"; - propagatedBuildInputs = [ async expect_test_helpers_kernel ]; + propagatedBuildInputs = [ + async + expect_test_helpers_kernel + ]; }; patience_diff = janePackage { @@ -459,7 +577,10 @@ with self; pname = "ecaml"; hash = "0n9xi6agc3lgyj2nsi10cbif0xwn57xyaranad9r285rmbxrgjh7"; meta.description = "Library for writing Emacs plugin in OCaml"; - propagatedBuildInputs = [ async expect_test_helpers_kernel ]; + propagatedBuildInputs = [ + async + expect_test_helpers_kernel + ]; }; } diff --git a/pkgs/development/ocaml-modules/janestreet/0.14.nix b/pkgs/development/ocaml-modules/janestreet/0.14.nix index 7d8bdc4dfb7d6d..c6210a966312a1 100644 --- a/pkgs/development/ocaml-modules/janestreet/0.14.nix +++ b/pkgs/development/ocaml-modules/janestreet/0.14.nix @@ -1,8 +1,9 @@ -{ self -, fetchpatch -, lib -, openssl -, zstd +{ + self, + fetchpatch, + lib, + openssl, + zstd, }: with self; @@ -24,7 +25,10 @@ with self; minimalOCamlVersion = "4.09"; hash = "1193hzvlzm7vcl9p67fs8al2pvkw9n2wz009m2l3lp35mrx8aq1w"; meta.description = "Accessors for Async types, for use with the Accessor library"; - propagatedBuildInputs = [ accessor_core async_kernel ]; + propagatedBuildInputs = [ + accessor_core + async_kernel + ]; }; accessor_base = janePackage { @@ -43,14 +47,21 @@ with self; hash = "1cdkv34m6czhacivpbb2sasj83fgcid6gnqk30ig9i84z8nh2gw2"; meta.description = "Accessors for Core types, for use with the Accessor library"; meta.broken = true; # Not compatible with ppxlib ≥ 0.23 - propagatedBuildInputs = [ accessor_base core_kernel ]; + propagatedBuildInputs = [ + accessor_base + core_kernel + ]; }; async = janePackage { pname = "async"; hash = "086v93div4h9l02n7wzv3xx3i6xvddazydm9qlfa72ad55x3vzy0"; meta.description = "Monadic concurrency library"; - propagatedBuildInputs = [ async_rpc_kernel async_unix textutils ]; + propagatedBuildInputs = [ + async_rpc_kernel + async_unix + textutils + ]; doCheck = false; # we don't have netkit_sockets }; @@ -72,7 +83,10 @@ with self; pname = "async_inotify"; hash = "0i0hf7nsir316ijixdj43qf0p3b6yapvcm2jzp7bhpf4r2kxislv"; meta.description = "Async wrapper for inotify"; - propagatedBuildInputs = [ async_find inotify ]; + propagatedBuildInputs = [ + async_find + inotify + ]; }; async_interactive = janePackage { @@ -87,7 +101,11 @@ with self; hash = "0rld8792lfwbinn9rhrgacivz49vppgy29smpqnvpga89wchjv0v"; meta.description = "A small library that provide Async support for JavaScript platforms"; buildInputs = [ js_of_ocaml-ppx ]; - propagatedBuildInputs = [ async_rpc_kernel js_of_ocaml uri-sexp ]; + propagatedBuildInputs = [ + async_rpc_kernel + js_of_ocaml + uri-sexp + ]; }; async_kernel = janePackage { @@ -101,7 +119,10 @@ with self; pname = "async_rpc_kernel"; hash = "1bwq3gkq057dd1fhrqz9kqq8a956nn87zaxvr0qcpiczzjv3zmvm"; meta.description = "Platform-independent core of Async RPC library"; - propagatedBuildInputs = [ async_kernel protocol_version_header ]; + propagatedBuildInputs = [ + async_kernel + protocol_version_header + ]; }; async_sendfile = janePackage { @@ -115,14 +136,27 @@ with self; pname = "async_shell"; hash = "1r00z620nqv2jxz2xrp2gsyc30h8dd2w9qsnys2fkqbgpxlbgdc7"; meta.description = "Shell helpers for Async"; - propagatedBuildInputs = [ async shell ]; + propagatedBuildInputs = [ + async + shell + ]; }; async_smtp = janePackage { pname = "async_smtp"; hash = "1xf3illn7vikdxldpnc29n4z8sv9f0wsdgdvl4iv93qlvjk8gzck"; meta.description = "SMTP client and server"; - propagatedBuildInputs = [ async_extra async_inotify async_sendfile async_shell async_ssl email_message resource_cache re2_stable sexp_macro ]; + propagatedBuildInputs = [ + async_extra + async_inotify + async_sendfile + async_shell + async_ssl + email_message + resource_cache + re2_stable + sexp_macro + ]; }; async_ssl = janePackage { @@ -130,7 +164,12 @@ with self; hash = "0ykys3ckpsx5crfgj26v2q3gy6wf684aq0bfb4q8p92ivwznvlzy"; meta.description = "Async wrappers for SSL"; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ async ctypes ctypes-foreign openssl ]; + propagatedBuildInputs = [ + async + ctypes + ctypes-foreign + openssl + ]; # in ctypes.foreign 0.18.0 threaded and unthreaded have been merged postPatch = '' substituteInPlace bindings/dune \ @@ -142,7 +181,10 @@ with self; pname = "async_unix"; hash = "1wgnr0vdsknqrfnf6irmwnvyngndsnvvl1sfnj3v6fhwk4nswnrs"; meta.description = "Monadic concurrency library"; - propagatedBuildInputs = [ async_kernel core ]; + propagatedBuildInputs = [ + async_kernel + core + ]; }; base = janePackage { @@ -170,13 +212,23 @@ with self; hash = "0apq3d9xb0zdaqsl4cjk5skyig57ff1plndb2mh0nn3czvfhifxs"; minimalOCamlVersion = "4.04.2"; meta.description = "Randomized testing framework, designed for compatibility with Base"; - propagatedBuildInputs = [ ppx_base ppx_fields_conv ppx_let ppx_sexp_value splittable_random ]; + propagatedBuildInputs = [ + ppx_base + ppx_fields_conv + ppx_let + ppx_sexp_value + splittable_random + ]; }; bignum = janePackage { pname = "bignum"; hash = "009ygr64q810p9iq4mykzz4ci00i5mzgpmq35jiyaiqm27bjam21"; - propagatedBuildInputs = [ core_kernel zarith zarith_stubs_js ]; + propagatedBuildInputs = [ + core_kernel + zarith + zarith_stubs_js + ]; meta.description = "Core-flavoured wrapper around zarith's arbitrary-precision rationals"; }; @@ -185,7 +237,13 @@ with self; hash = "1qyqbfp4zdc2jb87370cdgancisqffhf9x60zgh2m31kqik8annr"; minimalOCamlVersion = "4.04.2"; meta.description = "A binary protocol generator"; - propagatedBuildInputs = [ ppx_compare ppx_custom_printf ppx_fields_conv ppx_optcomp ppx_variants_conv ]; + propagatedBuildInputs = [ + ppx_compare + ppx_custom_printf + ppx_fields_conv + ppx_optcomp + ppx_variants_conv + ]; }; bonsai = janePackage { @@ -211,7 +269,11 @@ with self; hash = "1isrcl07nkmdm6akqsqs9z8s6zvva2lvg47kaagy7gsbyszrqb82"; meta.description = "System-independent part of Core"; buildInputs = [ jst-config ]; - propagatedBuildInputs = [ core_kernel spawn timezone ]; + propagatedBuildInputs = [ + core_kernel + spawn + timezone + ]; doCheck = false; # we don't have quickcheck_deprecated }; @@ -235,7 +297,10 @@ with self; hash = "0pikg4ln6177gbs0jfix7xj50zlcm7058h64lxnd7wspnj7mq8sd"; meta.description = "System-independent part of Core"; buildInputs = [ jst-config ]; - propagatedBuildInputs = [ base_bigstring sexplib ]; + propagatedBuildInputs = [ + base_bigstring + sexplib + ]; doCheck = false; # we don't have quickcheck_deprecated }; @@ -249,14 +314,20 @@ with self; csvfields = janePackage { pname = "csvfields"; hash = "09jmz6y6nwd96dcx6g8ydicxssi72v1ks276phbc9n19wwg9hkaz"; - propagatedBuildInputs = [ core num ]; + propagatedBuildInputs = [ + core + num + ]; meta.description = "Runtime support for ppx_xml_conv and ppx_csv_conv"; }; delimited_parsing = janePackage { pname = "delimited_parsing"; hash = "1dnr5wqacryx1kj38i9iifc3457pchr887xphzz2nhlbizq3d7qa"; - propagatedBuildInputs = [ async core_extended ]; + propagatedBuildInputs = [ + async + core_extended + ]; meta.description = "Parsing of character (e.g., comma) separated and fixed-width values"; }; @@ -264,28 +335,44 @@ with self; pname = "ecaml"; hash = "052qglpwzrx3c4gy3zr6dmsmfbi5gj4fs2jhx9yrsqb9hj8g36mj"; meta.description = "Library for writing Emacs plugin in OCaml"; - propagatedBuildInputs = [ async expect_test_helpers_core ]; + propagatedBuildInputs = [ + async + expect_test_helpers_core + ]; }; email_message = janePackage { pname = "email_message"; hash = "0k8hjkq91ikl7wjxs04k523jbkhl6q4abj6v0lzlbjiybmrpp69n"; meta.description = "E-mail message parser"; - propagatedBuildInputs = [ angstrom async base64 cryptokit magic-mime re2 ]; + propagatedBuildInputs = [ + angstrom + async + base64 + cryptokit + magic-mime + re2 + ]; }; expect_test_helpers_async = janePackage { pname = "expect_test_helpers_async"; hash = "175sjkx3b10d8vacp369rv53nxbiaxw1xhwy832g7ffk1by8l2m1"; meta.description = "Async helpers for writing expectation tests"; - propagatedBuildInputs = [ async expect_test_helpers_core ]; + propagatedBuildInputs = [ + async + expect_test_helpers_core + ]; }; expect_test_helpers_core = janePackage { pname = "expect_test_helpers_core"; hash = "1drl15akp4jz4wf26dr2y2nblvnhz14xsnb3ai8dg45y711svs2i"; meta.description = "Helpers for writing expectation tests"; - propagatedBuildInputs = [ core_kernel sexp_pretty ]; + propagatedBuildInputs = [ + core_kernel + sexp_pretty + ]; }; fieldslib = janePackage { @@ -302,7 +389,10 @@ with self; minimalOCamlVersion = "4.09"; hash = "05jvxgqsx3j2v8rqpd91ah76dgc1q2dz38kjklmx0vms4r4gvlsx"; meta.description = "A library with an encoding of higher kinded types in OCaml"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; }; incr_dom = janePackage { @@ -310,7 +400,12 @@ with self; hash = "0mi98cwi4npdh5vvcz0pb4sbb9j9dydl52s51rswwc3kn8mipxfx"; meta.description = "A library for building dynamic webapps, using Js_of_ocaml"; buildInputs = [ js_of_ocaml-ppx ]; - propagatedBuildInputs = [ async_js incr_map incr_select virtual_dom ]; + propagatedBuildInputs = [ + async_js + incr_map + incr_select + virtual_dom + ]; patches = [ ./incr_dom_jsoo_4_0.patch ]; }; @@ -347,7 +442,11 @@ with self; pname = "jst-config"; hash = "0hzw0crgj0kjxsvr10wng7gqy948v98hnijh30lgq3v62jdsjra8"; meta.description = "Compile-time configuration for Jane Street libraries"; - buildInputs = [ dune-configurator ppx_assert stdio ]; + buildInputs = [ + dune-configurator + ppx_assert + stdio + ]; }; ocaml-compiler-libs = janePackage { @@ -364,7 +463,10 @@ with self; hash = "1nr0ncb8l2mkk8pqzknr7fsqw5kpz8y102kyv5bc0x7c36v0d4zy"; minimalOCamlVersion = "4.04.2"; meta.description = "S-expression parsing library"; - propagatedBuildInputs = [ base sexplib0 ]; + propagatedBuildInputs = [ + base + sexplib0 + ]; }; patience_diff = janePackage { @@ -378,7 +480,10 @@ with self; pname = "posixat"; hash = "0aana1lzq4514kna7hr301b5iv6gcg6zhgrx8s8vaad1q38yfp6c"; minimalOCamlVersion = "4.07"; - propagatedBuildInputs = [ ppx_optcomp ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_optcomp + ppx_sexp_conv + ]; meta.description = "Binding to the posix *at functions"; }; @@ -396,7 +501,12 @@ with self; hash = "03mzgm4smrczp5dg3mpr6zc2v6a54n0r01k4ww820yrr25hcf8ip"; minimalOCamlVersion = "4.04.2"; meta.description = "Assert-like extension nodes that raise useful errors on failure"; - propagatedBuildInputs = [ ppx_cold ppx_compare ppx_here ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_cold + ppx_compare + ppx_here + ppx_sexp_conv + ]; }; ppx_base = janePackage { @@ -407,7 +517,12 @@ with self; description = "Base set of ppx rewriters"; mainProgram = "ppx-base"; }; - propagatedBuildInputs = [ ppx_cold ppx_enumerate ppx_hash ppx_js_style ]; + propagatedBuildInputs = [ + ppx_cold + ppx_enumerate + ppx_hash + ppx_js_style + ]; }; ppx_bench = janePackage { @@ -424,7 +539,10 @@ with self; hash = "1qryjxhyz3kn5jz5wm62j59lhjhd1mp7nbsj0np9qnbpapnnr1zg"; minimalOCamlVersion = "4.04.2"; meta.description = "Generation of bin_prot readers and writers from types"; - propagatedBuildInputs = [ bin_prot ppx_here ]; + propagatedBuildInputs = [ + bin_prot + ppx_here + ]; doCheck = false; # circular dependency with ppx_jane }; @@ -441,7 +559,10 @@ with self; hash = "11pj76dimx2f7l8m85myzp6yzx9xcg0bqi97s7ayssvkckm57390"; minimalOCamlVersion = "4.04.2"; meta.description = "Generation of comparison functions from types"; - propagatedBuildInputs = [ ppxlib base ]; + propagatedBuildInputs = [ + ppxlib + base + ]; doCheck = false; # test build rule broken }; @@ -468,7 +589,11 @@ with self; hash = "0vbbnjrzpyk5p0js21lafr6fcp2wqka89p1876rdf472cmg0l7fv"; minimalOCamlVersion = "4.04.2"; meta.description = "Cram like framework for OCaml"; - propagatedBuildInputs = [ ppx_here ppx_inline_test re ]; + propagatedBuildInputs = [ + ppx_here + ppx_inline_test + re + ]; doCheck = false; # circular dependency with ppx_jane }; @@ -478,7 +603,10 @@ with self; hash = "1zwirwqry24b48bg7d4yc845hvcirxyymzbw95aaxdcck84d30n8"; minimalOCamlVersion = "4.04.2"; meta.description = "Generation of accessor and iteration functions for ocaml records"; - propagatedBuildInputs = [ fieldslib ppxlib ]; + propagatedBuildInputs = [ + fieldslib + ppxlib + ]; }; ppx_fixed_literal = janePackage { @@ -494,7 +622,10 @@ with self; hash = "1zf03xdrg4jig7pdcrdpbabyjkdpifb31z2z1bf9wfdawybdhwkq"; minimalOCamlVersion = "4.04.2"; meta.description = "A ppx rewriter that generates hash functions from type expressions and definitions"; - propagatedBuildInputs = [ ppx_compare ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_compare + ppx_sexp_conv + ]; }; ppx_here = janePackage { @@ -512,7 +643,10 @@ with self; hash = "1ajdna1m9l1l3nfigyy33zkfa3yarfr6s086jdw2pcfwlq1fhhl4"; minimalOCamlVersion = "4.04.2"; meta.description = "Syntax extension for writing in-line tests in ocaml code"; - propagatedBuildInputs = [ ppxlib time_now ]; + propagatedBuildInputs = [ + ppxlib + time_now + ]; doCheck = false; # test build rules broken }; @@ -524,7 +658,20 @@ with self; description = "Standard Jane Street ppx rewriters"; mainProgram = "ppx-jane"; }; - propagatedBuildInputs = [ base_quickcheck ppx_bin_prot ppx_expect ppx_fixed_literal ppx_module_timer ppx_optcomp ppx_optional ppx_pipebang ppx_stable ppx_string ppx_typerep_conv ppx_variants_conv ]; + propagatedBuildInputs = [ + base_quickcheck + ppx_bin_prot + ppx_expect + ppx_fixed_literal + ppx_module_timer + ppx_optcomp + ppx_optional + ppx_pipebang + ppx_stable + ppx_string + ppx_typerep_conv + ppx_variants_conv + ]; }; ppx_js_style = janePackage { @@ -533,7 +680,10 @@ with self; hash = "16ax6ww9h36xyn9acbm8zxv0ajs344sm37lgj2zd2bvgsqv24kxj"; minimalOCamlVersion = "4.04.2"; meta.description = "Code style checker for Jane Street Packages"; - propagatedBuildInputs = [ octavius ppxlib ]; + propagatedBuildInputs = [ + octavius + ppxlib + ]; }; ppx_let = janePackage { @@ -549,7 +699,11 @@ with self; hash = "10hnr5lpww3fw0bnidzngalbgy0j1wvz1g5ki9c9h558pnpvsazr"; minimalOCamlVersion = "4.08.0"; meta.description = "Ppx_sexp_message-like extension nodes for lazily rendering log messages"; - propagatedBuildInputs = [ async_unix ppx_jane sexplib ]; + propagatedBuildInputs = [ + async_unix + ppx_jane + sexplib + ]; }; ppx_module_timer = janePackage { @@ -602,7 +756,11 @@ with self; url = "https://github.com/janestreet/ppx_python/commit/b2fe0040cc39fa6164de868f8a20edb38d81170e.patch"; sha256 = "sha256:1mrdwp0zw3dqavzx3ffrmzq5cdlninyf67ksavfzxb8gb16w6zpz"; }; - propagatedBuildInputs = [ ppx_base ppxlib pyml ]; + propagatedBuildInputs = [ + ppx_base + ppxlib + pyml + ]; }; ppx_sexp_conv = janePackage { @@ -611,7 +769,11 @@ with self; minimalOCamlVersion = "4.04.2"; hash = "0dbri9d00ydi0dw1cavswnqdmhjaaz80vap29ns2lr6mhhlvyjmj"; meta.description = "[@@deriving] plugin to generate S-expression conversion functions"; - propagatedBuildInputs = [ (ppxlib.override { version = "0.24.0"; }) sexplib0 base ]; + propagatedBuildInputs = [ + (ppxlib.override { version = "0.24.0"; }) + sexplib0 + base + ]; }; ppx_sexp_message = janePackage { @@ -620,7 +782,10 @@ with self; hash = "1lvsr0d68kakih1ll33hy6dxbjkly6lmky4q6z0h0hrcbd6z48k4"; minimalOCamlVersion = "4.04.2"; meta.description = "A ppx rewriter for easy construction of s-expressions"; - propagatedBuildInputs = [ ppx_here ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_here + ppx_sexp_conv + ]; }; ppx_sexp_value = janePackage { @@ -628,7 +793,10 @@ with self; hash = "1d1c92pyypqkd9473d59j0sfppxvcxggbc62w8bkqnbxrdmvirn9"; minimalOCamlVersion = "4.04.2"; meta.description = "A ppx rewriter that simplifies building s-expressions from ocaml values"; - propagatedBuildInputs = [ ppx_here ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_here + ppx_sexp_conv + ]; }; ppx_stable = janePackage { @@ -646,7 +814,11 @@ with self; minimalOCamlVersion = "4.04.2"; hash = "0a8khmg0y32kyn3q6idwgh0d6d1s6ms1w75gj3dzng0v7y4h6jx4"; meta.description = "Ppx extension for string interpolation"; - propagatedBuildInputs = [ ppx_base ppxlib stdio ]; + propagatedBuildInputs = [ + ppx_base + ppxlib + stdio + ]; }; ppx_typerep_conv = janePackage { @@ -655,7 +827,10 @@ with self; minimalOCamlVersion = "4.04.2"; hash = "0yk9vkpnwr8labgfncqdi4rfkj88d8mb3cr8m4gdqpi3f2r27hf0"; meta.description = "Generation of runtime types from type declarations"; - propagatedBuildInputs = [ ppxlib typerep ]; + propagatedBuildInputs = [ + ppxlib + typerep + ]; }; ppx_variants_conv = janePackage { @@ -664,7 +839,10 @@ with self; minimalOCamlVersion = "4.04.2"; hash = "1p11fiz4m160hs0xzg4g9rxchp053sz3s3d1lyciqixad1xi47a4"; meta.description = "Generation of accessor and iteration functions for ocaml variant types"; - propagatedBuildInputs = [ variantslib ppxlib ]; + propagatedBuildInputs = [ + variantslib + ppxlib + ]; }; protocol_version_header = janePackage { @@ -679,7 +857,13 @@ with self; hash = "0qr0mh9jiv1ham5zlz9i4im23a1vh6x1yp6dp2db2s4icmfph639"; meta.description = "A library to help writing wrappers around ocaml code for python"; meta.broken = lib.versionAtLeast ocaml.version "4.13"; - propagatedBuildInputs = [ ppx_expect ppx_let ppx_python stdio typerep ]; + propagatedBuildInputs = [ + ppx_expect + ppx_let + ppx_python + stdio + typerep + ]; }; re2 = janePackage { @@ -697,7 +881,10 @@ with self; pname = "re2_stable"; hash = "0kjc0ff6b3509s3b9n4q8ilb06d5fngdh3z58cm95vg7zkcas9w3"; meta.description = "Re2_stable adds an incomplete but stable serialization of Re2"; - propagatedBuildInputs = [ core re2 ]; + propagatedBuildInputs = [ + core + re2 + ]; }; resource_cache = janePackage { @@ -734,7 +921,10 @@ with self; sexp_macro = janePackage { pname = "sexp_macro"; hash = "1ih1g7vpb1j8vhzm9a5mjrrzgqrhjqdhf6vjrg8kxfqg5i5b8nyx"; - propagatedBuildInputs = [ async sexplib ]; + propagatedBuildInputs = [ + async + sexplib + ]; meta.description = "Sexp macros"; }; @@ -743,14 +933,21 @@ with self; hash = "0dax0wm511zgvr7p6kcd5gygi58118by7hsv7hymy8ldfcky5cwd"; minimalOCamlVersion = "4.07"; meta.description = "S-expression pretty-printer"; - propagatedBuildInputs = [ ppx_base re sexplib ]; + propagatedBuildInputs = [ + ppx_base + re + sexplib + ]; }; sexp_select = janePackage { pname = "sexp_select"; hash = "1lchhfqw4afw38fnarwylqc2qp7k6xwx3j7m9gy8ygjgd0vgd729"; minimalOCamlVersion = "4.07"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; meta.description = "A library to use CSS-style selectors to traverse sexp trees"; }; @@ -766,7 +963,10 @@ with self; hash = "03c3j1ihx4pjbb0x3arrcif3wvp3iva2ivnywhiak4mbbslgsnzr"; minimalOCamlVersion = "4.04.2"; meta.description = "Library for serializing OCaml values to and from S-expressions"; - propagatedBuildInputs = [ num parsexp ]; + propagatedBuildInputs = [ + num + parsexp + ]; }; shell = janePackage { @@ -782,7 +982,10 @@ with self; pname = "shexp"; hash = "1h6hsnbg6bk32f8iv6kd6im4mv2pjsjpd1mjsfx80p1n9273xack"; minimalOCamlVersion = "4.07"; - propagatedBuildInputs = [ posixat spawn ]; + propagatedBuildInputs = [ + posixat + spawn + ]; meta.description = "Process library and s-expression based shell"; }; @@ -807,7 +1010,12 @@ with self; pname = "splittable_random"; hash = "0ax988b1wc7km8khg4s6iphbz16y1rssh7baigxfyw3ldp0agk14"; meta.description = "PRNG that can be split into independent streams"; - propagatedBuildInputs = [ base ppx_assert ppx_bench ppx_sexp_message ]; + propagatedBuildInputs = [ + base + ppx_assert + ppx_bench + ppx_sexp_message + ]; }; stdio = janePackage { @@ -830,8 +1038,15 @@ with self; hash = "1lyq8zdz93hvpi4hpxh88kds30k5ljil8js9clcqyxrldp5n9mw0"; minimalOCamlVersion = "4.04.2"; meta.description = "Reports the current time"; - buildInputs = [ jst-config ppx_optcomp ]; - propagatedBuildInputs = [ jane-street-headers base ppx_base ]; + buildInputs = [ + jst-config + ppx_optcomp + ]; + propagatedBuildInputs = [ + jane-street-headers + base + ppx_base + ]; }; timezone = janePackage { @@ -845,7 +1060,10 @@ with self; pname = "topological_sort"; hash = "17iz7956zln31p0xnm3jlhj863zi84bcx41jylzf7gk23qsm95m8"; meta.description = "Topological sort algorithm"; - propagatedBuildInputs = [ ppx_jane stdio ]; + propagatedBuildInputs = [ + ppx_jane + stdio + ]; }; typerep = janePackage { @@ -868,7 +1086,11 @@ with self; pname = "vcaml"; hash = "0ykwrn8bvwx26ad4wb36jw9xnlwsdpnnx88396laxvcfimrp13qs"; meta.description = "OCaml bindings for the Neovim API"; - propagatedBuildInputs = [ angstrom-async async_extra faraday ]; + propagatedBuildInputs = [ + angstrom-async + async_extra + faraday + ]; }; virtual_dom = janePackage { @@ -876,7 +1098,12 @@ with self; hash = "0vcydxx0jhbd5hbriahgp947mc7n3xymyrsfny1c4adk6aaq3c5w"; meta.description = "OCaml bindings for the virtual-dom library"; buildInputs = [ js_of_ocaml-ppx ]; - propagatedBuildInputs = [ core_kernel js_of_ocaml lambdasoup tyxml ]; + propagatedBuildInputs = [ + core_kernel + js_of_ocaml + lambdasoup + tyxml + ]; }; zarith_stubs_js = janePackage { @@ -892,7 +1119,11 @@ with self; hash = "1vf76v5m9wsh5f77w9z4i8sxm05wr5digyi95x4wvzdi7q3qg6m8"; meta.description = "OCaml bindings to Zstandard"; buildInputs = [ ppx_jane ]; - propagatedBuildInputs = [ core ctypes zstd ]; + propagatedBuildInputs = [ + core + ctypes + zstd + ]; }; } diff --git a/pkgs/development/ocaml-modules/janestreet/0.15.nix b/pkgs/development/ocaml-modules/janestreet/0.15.nix index 6a0e4fb58fd397..ddb4c3a1f8dc69 100644 --- a/pkgs/development/ocaml-modules/janestreet/0.15.nix +++ b/pkgs/development/ocaml-modules/janestreet/0.15.nix @@ -1,11 +1,12 @@ -{ self -, bash -, fetchpatch -, fzf -, lib -, ocaml -, openssl -, zstd +{ + self, + bash, + fetchpatch, + fzf, + lib, + ocaml, + openssl, + zstd, }: with self; @@ -17,7 +18,10 @@ with self; minimalOCamlVersion = "4.08"; hash = "12imf6ibm7qb8r1fpqnrl20x2z14zl3ri1vzg0z8qby9l8bv2fbd"; meta.description = "A small library describing abstract algebra concepts"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; }; accessor = janePackage { @@ -33,7 +37,10 @@ with self; minimalOCamlVersion = "4.09"; hash = "17r6af55ms0i496jsfx0xpdm336c2vhyf49b3s8s1gpz521wrgmc"; meta.description = "Accessors for Async types, for use with the Accessor library"; - propagatedBuildInputs = [ accessor_core async_kernel ]; + propagatedBuildInputs = [ + accessor_core + async_kernel + ]; }; accessor_base = janePackage { @@ -49,14 +56,21 @@ with self; pname = "accessor_core"; hash = "0zrs5zbyrhfbah73g22l19bw1mmljhyb3l2mrwcxgbjq9pqp0k9v"; meta.description = "Accessors for Core types, for use with the Accessor library"; - propagatedBuildInputs = [ accessor_base core_kernel ]; + propagatedBuildInputs = [ + accessor_base + core_kernel + ]; }; async = janePackage { pname = "async"; hash = "0pykmnsil754jsnr8gss91ykyjvivngx4ii0ih3nsg1x2jl9xmy2"; meta.description = "Monadic concurrency library"; - propagatedBuildInputs = [ async_rpc_kernel async_unix textutils ]; + propagatedBuildInputs = [ + async_rpc_kernel + async_unix + textutils + ]; doCheck = false; # we don't have netkit_sockets }; @@ -78,7 +92,10 @@ with self; pname = "async_inotify"; hash = "1nxz6bijp7liy18ljrxg92v2m8v8fqcs1pmzg9kbcf0d4vij8j2p"; meta.description = "Async wrapper for inotify"; - propagatedBuildInputs = [ async_find inotify ]; + propagatedBuildInputs = [ + async_find + inotify + ]; }; async_interactive = janePackage { @@ -93,7 +110,11 @@ with self; hash = "184j077bz686k5lrqswircnrdqldb316ngpzq7xri1pcsl39sy3q"; meta.description = "A small library that provide Async support for JavaScript platforms"; buildInputs = [ js_of_ocaml-ppx ]; - propagatedBuildInputs = [ async_rpc_kernel js_of_ocaml uri-sexp ]; + propagatedBuildInputs = [ + async_rpc_kernel + js_of_ocaml + uri-sexp + ]; }; async_kernel = janePackage { @@ -107,14 +128,21 @@ with self; pname = "async_rpc_kernel"; hash = "1b5rp5yam03ir4f1sixpzjg1zdqmkb7lvnaa82kac4fzk80gfrfr"; meta.description = "Platform-independent core of Async RPC library"; - propagatedBuildInputs = [ async_kernel protocol_version_header ]; + propagatedBuildInputs = [ + async_kernel + protocol_version_header + ]; }; async_rpc_websocket = janePackage { pname = "async_rpc_websocket"; hash = "1n93jhkz5r76xcc40c4i4sxcyfz1dbppz8sjfxpwcwjyi6lyhp1p"; meta.description = "Library to serve and dispatch Async RPCs over websockets"; - propagatedBuildInputs = [ async_rpc_kernel async_websocket cohttp_async_websocket ]; + propagatedBuildInputs = [ + async_rpc_kernel + async_websocket + cohttp_async_websocket + ]; }; async_sendfile = janePackage { @@ -128,7 +156,10 @@ with self; pname = "async_shell"; hash = "07iwlyrc4smk6hsnz89cz2ihp670mllq0y9wbdafvagm1y1p62vx"; meta.description = "Shell helpers for Async"; - propagatedBuildInputs = [ async shell ]; + propagatedBuildInputs = [ + async + shell + ]; }; async_smtp = janePackage { @@ -136,7 +167,17 @@ with self; hash = "1m00j7wcb0blipnc1m6by70gd96a1k621b4dgvgffp8as04a461r"; minimalOCamlVersion = "4.12"; meta.description = "SMTP client and server"; - propagatedBuildInputs = [ async_extra async_inotify async_sendfile async_shell async_ssl email_message resource_cache re2_stable sexp_macro ]; + propagatedBuildInputs = [ + async_extra + async_inotify + async_sendfile + async_shell + async_ssl + email_message + resource_cache + re2_stable + sexp_macro + ]; }; async_ssl = janePackage { @@ -144,7 +185,12 @@ with self; hash = "1b7f7p3xj4jr2n2dxy2lp7a9k7944w6x2nrg6524clvcsd1ax4hn"; meta.description = "Async wrappers for SSL"; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ async ctypes ctypes-foreign openssl ]; + propagatedBuildInputs = [ + async + ctypes + ctypes-foreign + openssl + ]; # in ctypes.foreign 0.18.0 threaded and unthreaded have been merged postPatch = '' substituteInPlace bindings/dune \ @@ -156,14 +202,20 @@ with self; pname = "async_unix"; hash = "0z4fgpn93iw0abd7l9kac28qgzgc5qr2x0s1n2zh49lsdn02n6ys"; meta.description = "Monadic concurrency library"; - propagatedBuildInputs = [ async_kernel core_unix ]; + propagatedBuildInputs = [ + async_kernel + core_unix + ]; }; async_websocket = janePackage { pname = "async_websocket"; hash = "16ixqfnx9jp77bvx11dlzsq0pzfpyiif60hl2q06zncyswky9xgb"; meta.description = "A library that implements the websocket protocol on top of Async"; - propagatedBuildInputs = [ async cryptokit ]; + propagatedBuildInputs = [ + async + cryptokit + ]; }; base = janePackage { @@ -182,7 +234,10 @@ with self; hash = "1hv3hw2fwqmkrxms1g6rw3c18mmla1z5bva3anx45mnff903iv4q"; minimalOCamlVersion = "4.08"; meta.description = "String type based on [Bigarray], for use in I/O and C-bindings"; - propagatedBuildInputs = [ int_repr ppx_jane ]; + propagatedBuildInputs = [ + int_repr + ppx_jane + ]; }; base_quickcheck = janePackage { @@ -190,13 +245,23 @@ with self; hash = "0q73kfr67cz5wp4qn4rq3lpa922hqmvwdiinnans0js65fvlgqsi"; minimalOCamlVersion = "4.04.2"; meta.description = "Randomized testing framework, designed for compatibility with Base"; - propagatedBuildInputs = [ ppx_base ppx_fields_conv ppx_let ppx_sexp_value splittable_random ]; + propagatedBuildInputs = [ + ppx_base + ppx_fields_conv + ppx_let + ppx_sexp_value + splittable_random + ]; }; bignum = janePackage { pname = "bignum"; hash = "12q3xcv78b4s9srnc17jbyn53d5drmwmyvgp62p7nk3fs4f7cr4f"; - propagatedBuildInputs = [ core_kernel zarith zarith_stubs_js ]; + propagatedBuildInputs = [ + core_kernel + zarith + zarith_stubs_js + ]; meta.description = "Core-flavoured wrapper around zarith's arbitrary-precision rationals"; }; @@ -205,7 +270,13 @@ with self; hash = "1qfqglscc25wwnjx7byqmjcnjww1msnr8940gyg8h93wdq43fjnh"; minimalOCamlVersion = "4.04.2"; meta.description = "A binary protocol generator"; - propagatedBuildInputs = [ ppx_compare ppx_custom_printf ppx_fields_conv ppx_optcomp ppx_variants_conv ]; + propagatedBuildInputs = [ + ppx_compare + ppx_custom_printf + ppx_fields_conv + ppx_optcomp + ppx_variants_conv + ]; }; bonsai = janePackage { @@ -213,7 +284,10 @@ with self; hash = "150zx2g1dmhyrxwqq8j7f2m3hjpmk5bk182ihx2gdbarhw1ainpm"; meta.description = "A library for building dynamic webapps, using Js_of_ocaml"; buildInputs = [ ppx_pattern_bind ]; - nativeBuildInputs = [ js_of_ocaml-compiler ocaml-embed-file ]; + nativeBuildInputs = [ + js_of_ocaml-compiler + ocaml-embed-file + ]; propagatedBuildInputs = [ async async_extra @@ -246,7 +320,13 @@ with self; pname = "cohttp_async_websocket"; hash = "0d0smavnxpnwrmhlcf3b5a3cm3n9kz1y8fh6l28xv6zrn4sc7ik8"; meta.description = "Websocket library for use with cohttp and async"; - propagatedBuildInputs = [ async_ssl async_websocket cohttp-async ppx_jane uri-sexp ]; + propagatedBuildInputs = [ + async_ssl + async_websocket + cohttp-async + ppx_jane + uri-sexp + ]; }; cohttp_static_handler = janePackage { @@ -263,7 +343,13 @@ with self; hash = "sha256-SHjnNFl+JAjdgVoRgmnz0wqrrc3zoh0ZyG2UhUsUbJ8="; meta.description = "Industrial strength alternative to OCaml's standard library"; buildInputs = [ jst-config ]; - propagatedBuildInputs = [ base base_bigstring base_quickcheck ppx_jane time_now ]; + propagatedBuildInputs = [ + base + base_bigstring + base_quickcheck + ppx_jane + time_now + ]; doCheck = false; # circular dependency with core_kernel meta.broken = lib.versionAtLeast ocaml.version "5.1"; }; @@ -279,7 +365,10 @@ with self; pname = "core_extended"; hash = "0sx79hc1y1daczib2p4nbyw4aqnznmdd83knrhs5q153j7lnlalx"; meta.description = "Extra components that are not as closely vetted or as stable as Core"; - propagatedBuildInputs = [ core_unix record_builder ]; + propagatedBuildInputs = [ + core_unix + record_builder + ]; }; core_kernel = janePackage { @@ -287,7 +376,12 @@ with self; hash = "05mb4vbf293iq1xx4acyrmi9cgcw6capwrsa54ils62alby6w6yq"; meta.description = "System-independent part of Core"; buildInputs = [ jst-config ]; - propagatedBuildInputs = [ base_bigstring core int_repr sexplib ]; + propagatedBuildInputs = [ + base_bigstring + core + int_repr + sexplib + ]; doCheck = false; # we don't have quickcheck_deprecated }; @@ -297,7 +391,14 @@ with self; hash = "sha256-9f2PiLo+4Bjnfvh3scvIiPHj0wPZozmMMiCTe7vC1EA="; meta.description = "Unix-specific portions of Core"; buildInputs = [ jst-config ]; - propagatedBuildInputs = [ core_kernel expect_test_helpers_core ocaml_intrinsics ppx_jane timezone spawn ]; + propagatedBuildInputs = [ + core_kernel + expect_test_helpers_core + ocaml_intrinsics + ppx_jane + timezone + spawn + ]; postPatch = '' patchShebangs unix_pseudo_terminal/src/discover.sh ''; @@ -307,14 +408,20 @@ with self; pname = "csvfields"; version = "0.15.1"; hash = "sha256-bBupsarwjte2NCncNDFSkrrmMR3EYPn+D7xI9zQOhFA="; - propagatedBuildInputs = [ core num ]; + propagatedBuildInputs = [ + core + num + ]; meta.description = "Runtime support for ppx_xml_conv and ppx_csv_conv"; }; delimited_parsing = janePackage { pname = "delimited_parsing"; hash = "0d050v58zzi8c4qiwxbfcyrdw6zvncnnl3qj79qi0yq4xkg7820r"; - propagatedBuildInputs = [ async core_extended ]; + propagatedBuildInputs = [ + async + core_extended + ]; meta.description = "Parsing of character (e.g., comma) separated and fixed-width values"; }; @@ -322,28 +429,44 @@ with self; pname = "ecaml"; hash = "08g2bl06vkn3bkqzkmvk2646aqb6jj4a7n3wgzpcx1c2gl3iw5i6"; meta.description = "Library for writing Emacs plugin in OCaml"; - propagatedBuildInputs = [ async expect_test_helpers_core ]; + propagatedBuildInputs = [ + async + expect_test_helpers_core + ]; }; email_message = janePackage { pname = "email_message"; hash = "00h66l2g5rjaay0hbyqy4v9i866g779miriwv20h9k4mliqdq7in"; meta.description = "E-mail message parser"; - propagatedBuildInputs = [ angstrom async base64 cryptokit magic-mime re2 ]; + propagatedBuildInputs = [ + angstrom + async + base64 + cryptokit + magic-mime + re2 + ]; }; expect_test_helpers_async = janePackage { pname = "expect_test_helpers_async"; hash = "14v4966p5dmqgjb9sgrvnsixv0w0bagicn8v44g9mf9d88z8pfym"; meta.description = "Async helpers for writing expectation tests"; - propagatedBuildInputs = [ async expect_test_helpers_core ]; + propagatedBuildInputs = [ + async + expect_test_helpers_core + ]; }; expect_test_helpers_core = janePackage { pname = "expect_test_helpers_core"; hash = "0bxs3g0zzym8agfcbpg5lmrh6hcb86z861bq40xhhfwqf4pzdbfa"; meta.description = "Helpers for writing expectation tests"; - propagatedBuildInputs = [ core_kernel sexp_pretty ]; + propagatedBuildInputs = [ + core_kernel + sexp_pretty + ]; }; fieldslib = janePackage { @@ -358,8 +481,7 @@ with self; pname = "file_path"; minimalOCamlVersion = "4.11"; hash = "0vjvxviryywwwfdazcijwhpajp2d4mavlki7lj4qaafjrw62x14k"; - meta.description = - "A library for typed manipulation of UNIX-style file paths"; + meta.description = "A library for typed manipulation of UNIX-style file paths"; propagatedBuildInputs = [ async core @@ -375,7 +497,10 @@ with self; pname = "fuzzy_match"; hash = "0s5w81698b07l5m11nwx8xbjcpmp54dnf5fcrnlva22jrlsf14h4"; meta.description = "A library for fuzzy string matching"; - propagatedBuildInputs = [ core ppx_jane ]; + propagatedBuildInputs = [ + core + ppx_jane + ]; }; fzf = janePackage { @@ -383,7 +508,11 @@ with self; minimalOCamlVersion = "4.08"; hash = "1ha0i6dx5bgwzbdi4rn98wjwi2imv5p2i7qs7hy0c6cmg88xbdry"; meta.description = "A library for running the fzf command line tool"; - propagatedBuildInputs = [ async core_kernel ppx_jane ]; + propagatedBuildInputs = [ + async + core_kernel + ppx_jane + ]; postPatch = '' substituteInPlace src/fzf.ml --replace /usr/bin/fzf ${fzf}/bin/fzf ''; @@ -394,7 +523,10 @@ with self; minimalOCamlVersion = "4.09"; hash = "0rafxxajqswi070h8sinhjna0swh1hc6d7i3q7y099yj3wlr2y1l"; meta.description = "A library with an encoding of higher kinded types in OCaml"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; }; incr_dom = janePackage { @@ -402,7 +534,12 @@ with self; hash = "1sija9w2im8vdp61h387w0mww9hh7jgkgsjcccps4lbv936ac7c1"; meta.description = "A library for building dynamic webapps, using Js_of_ocaml"; buildInputs = [ js_of_ocaml-ppx ]; - propagatedBuildInputs = [ async_js incr_map incr_select virtual_dom ]; + propagatedBuildInputs = [ + async_js + incr_map + incr_select + virtual_dom + ]; patches = [ ./incr_dom_jsoo_4_0.patch ]; }; @@ -411,7 +548,10 @@ with self; hash = "0aq8wfylvq68him92vzh1fqmr7r0lfwc5cdiqr10r5x032vzpnii"; meta.description = "Helpers for incremental operations on map like data structures"; buildInputs = [ ppx_pattern_bind ]; - propagatedBuildInputs = [ abstract_algebra incremental ]; + propagatedBuildInputs = [ + abstract_algebra + incremental + ]; }; incr_select = janePackage { @@ -432,7 +572,10 @@ with self; pname = "int_repr"; hash = "0ph88ym3s9dk30n17si2xam40sp8wv1xffw5cl3bskc2vfya1nvl"; meta.description = "Integers of various widths"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; }; jane-street-headers = janePackage { @@ -446,14 +589,23 @@ with self; pname = "jsonaf"; hash = "1j9rn8vsvfpgmdpmdqb5qhvss5171j8n3ii1bcgnavqinchbvqa6"; meta.description = "A library for parsing, manipulating, and serializing data structured as JSON"; - propagatedBuildInputs = [ base ppx_jane angstrom faraday ]; + propagatedBuildInputs = [ + base + ppx_jane + angstrom + faraday + ]; }; jst-config = janePackage { pname = "jst-config"; hash = "1lxqsj5k3v8p7g802vj1xc6bs5wrfpszh3q61xvpcd42pf3ahma9"; meta.description = "Compile-time configuration for Jane Street libraries"; - buildInputs = [ dune-configurator ppx_assert stdio ]; + buildInputs = [ + dune-configurator + ppx_assert + stdio + ]; patches = [ # remove on next release (fetchpatch { @@ -474,7 +626,10 @@ with self; ocaml-embed-file = janePackage { pname = "ocaml-embed-file"; hash = "1nzgc0q05f0j3q1kwfpyhhhpgwrfjvmkqqifrkrm4y7d1i44bfnw"; - propagatedBuildInputs = [ async ppx_jane ]; + propagatedBuildInputs = [ + async + ppx_jane + ]; meta.description = "Files contents as module constants"; }; @@ -493,7 +648,10 @@ with self; hash = "1grzpxi39318vcqhwf723hqh11k68irh59zb3dyg9lw8wjn7752a"; minimalOCamlVersion = "4.04.2"; meta.description = "S-expression parsing library"; - propagatedBuildInputs = [ base sexplib0 ]; + propagatedBuildInputs = [ + base + sexplib0 + ]; }; patdiff = janePackage { @@ -503,7 +661,11 @@ with self; # Used by patdiff-git-wrapper. Providing it here also causes the shebang # line to be automatically patched. buildInputs = [ bash ]; - propagatedBuildInputs = [ core_unix patience_diff ocaml_pcre ]; + propagatedBuildInputs = [ + core_unix + patience_diff + ocaml_pcre + ]; meta = { description = "File Diff using the Patience Diff algorithm"; }; @@ -520,7 +682,10 @@ with self; pname = "posixat"; hash = "1xgycwa0janrfn9psb7xrm0820blr82mqf1lvjy9ipqalj7v9w1f"; minimalOCamlVersion = "4.07"; - propagatedBuildInputs = [ ppx_optcomp ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_optcomp + ppx_sexp_conv + ]; meta.description = "Binding to the posix *at functions"; }; @@ -537,7 +702,12 @@ with self; hash = "0dic250q3flrjs3i70a2qqqnhqqj75ddlixpy7hdfghjw32azw90"; minimalOCamlVersion = "4.04.2"; meta.description = "Assert-like extension nodes that raise useful errors on failure"; - propagatedBuildInputs = [ ppx_cold ppx_compare ppx_here ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_cold + ppx_compare + ppx_here + ppx_sexp_conv + ]; }; ppx_base = janePackage { @@ -545,7 +715,11 @@ with self; hash = "13rfmy2fxvwi7z5l1mai474ri5anqjm8q4hs7dblplsjjd9m5ld1"; minimalOCamlVersion = "4.04.2"; meta.description = "Base set of ppx rewriters"; - propagatedBuildInputs = [ ppx_cold ppx_enumerate ppx_hash ]; + propagatedBuildInputs = [ + ppx_cold + ppx_enumerate + ppx_hash + ]; }; ppx_bench = janePackage { @@ -562,7 +736,10 @@ with self; hash = "1280wsls061fmvmdysjqn3lv4mnkyg400jnjf4jyfr14s33h1ad5"; minimalOCamlVersion = "4.04.2"; meta.description = "Generation of bin_prot readers and writers from types"; - propagatedBuildInputs = [ bin_prot ppx_here ]; + propagatedBuildInputs = [ + bin_prot + ppx_here + ]; doCheck = false; # circular dependency with ppx_jane }; @@ -579,14 +756,20 @@ with self; hash = "1wjwqkr71p61vjidbr80l93y4kkad7xsfyp04w8qfqrj7h5nm625"; minimalOCamlVersion = "4.04.2"; meta.description = "Generation of comparison functions from types"; - propagatedBuildInputs = [ ppxlib base ]; + propagatedBuildInputs = [ + ppxlib + base + ]; }; ppx_conv_func = janePackage { pname = "ppx_conv_func"; hash = "sha256-61jX8yHZYOnMx1Jlqaq9zSOz25HLOa0Wv/iG6Hu82zI="; meta.description = "Part of the Jane Street's PPX rewriters collection"; - propagatedBuildInputs = [ ppxlib base ]; + propagatedBuildInputs = [ + ppxlib + base + ]; }; ppx_custom_printf = janePackage { @@ -601,14 +784,23 @@ with self; pname = "ppx_css"; hash = "09dpmj3f3m3z1ji9hq775iqr3cfmv5gh7q9zlblizj4wx4y0ibyi"; meta.description = "A ppx that takes in css strings and produces a module for accessing the unique names defined within"; - propagatedBuildInputs = [ core_kernel ppxlib js_of_ocaml js_of_ocaml-ppx sedlex ]; + propagatedBuildInputs = [ + core_kernel + ppxlib + js_of_ocaml + js_of_ocaml-ppx + sedlex + ]; }; ppx_csv_conv = janePackage { pname = "ppx_csv_conv"; hash = "sha256-ctwgUs1buBZiNqac4760LhWd2/PMZRuxx8SE5T7yZ+g="; meta.description = "Generate functions to read/write records in csv format"; - propagatedBuildInputs = [ csvfields ppx_conv_func ]; + propagatedBuildInputs = [ + csvfields + ppx_conv_func + ]; }; ppx_disable_unused_warnings = janePackage { @@ -633,7 +825,11 @@ with self; hash = "sha256-qlOipzTTdN9yQ35sItKmWpCv74kbuJLDg4IHNVTKvow="; minimalOCamlVersion = "4.04.2"; meta.description = "Cram like framework for OCaml"; - propagatedBuildInputs = [ ppx_here ppx_inline_test re ]; + propagatedBuildInputs = [ + ppx_here + ppx_inline_test + re + ]; doCheck = false; # test build rules broken }; @@ -642,7 +838,10 @@ with self; hash = "094wsnw7fcwgl9xg6vkjb0wbgpn9scsp847yhdd184sz9v1amz14"; minimalOCamlVersion = "4.04.2"; meta.description = "Generation of accessor and iteration functions for ocaml records"; - propagatedBuildInputs = [ fieldslib ppxlib ]; + propagatedBuildInputs = [ + fieldslib + ppxlib + ]; }; ppx_fixed_literal = janePackage { @@ -658,7 +857,10 @@ with self; hash = "15agkwavadllzxdv4syjna02083nfnap8qs4yqf5s0adjw73fzyg"; minimalOCamlVersion = "4.04.2"; meta.description = "A ppx rewriter that generates hash functions from type expressions and definitions"; - propagatedBuildInputs = [ ppx_compare ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_compare + ppx_sexp_conv + ]; }; ppx_here = janePackage { @@ -684,7 +886,10 @@ with self; hash = "sha256-9Up4/VK4gayuwbPc3r6gVRj78ILO2G3opL5UDOTKOgk="; minimalOCamlVersion = "4.04.2"; meta.description = "Syntax extension for writing in-line tests in ocaml code"; - propagatedBuildInputs = [ ppxlib time_now ]; + propagatedBuildInputs = [ + ppxlib + time_now + ]; doCheck = false; # test build rules broken }; @@ -693,7 +898,23 @@ with self; hash = "1p6847gdfnnj6qpa4yh57s6wwpsl7rfgy0q7993chz24h9mhz5lk"; minimalOCamlVersion = "4.04.2"; meta.description = "Standard Jane Street ppx rewriters"; - propagatedBuildInputs = [ base_quickcheck ppx_bin_prot ppx_disable_unused_warnings ppx_expect ppx_fixed_literal ppx_ignore_instrumentation ppx_log ppx_module_timer ppx_optcomp ppx_optional ppx_pipebang ppx_stable ppx_string ppx_typerep_conv ppx_variants_conv ]; + propagatedBuildInputs = [ + base_quickcheck + ppx_bin_prot + ppx_disable_unused_warnings + ppx_expect + ppx_fixed_literal + ppx_ignore_instrumentation + ppx_log + ppx_module_timer + ppx_optcomp + ppx_optional + ppx_pipebang + ppx_stable + ppx_string + ppx_typerep_conv + ppx_variants_conv + ]; }; ppx_jsonaf_conv = janePackage { @@ -701,9 +922,13 @@ with self; version = "0.15.1"; hash = "0wprs7qmscklyskj4famhaqqisi6jypy414aqba14qdyi43w0cv3"; minimalOCamlVersion = "4.08"; - meta.description = - "[@@deriving] plugin to generate Jsonaf conversion functions"; - propagatedBuildInputs = [ base jsonaf ppx_jane ppxlib ]; + meta.description = "[@@deriving] plugin to generate Jsonaf conversion functions"; + propagatedBuildInputs = [ + base + jsonaf + ppx_jane + ppxlib + ]; }; ppx_js_style = janePackage { @@ -711,7 +936,10 @@ with self; hash = "0q2p9pvmlncgv0hprph95xiv7s6q44ynvp4yl4dckf1qx68rb3ba"; minimalOCamlVersion = "4.04.2"; meta.description = "Code style checker for Jane Street Packages"; - propagatedBuildInputs = [ octavius ppxlib ]; + propagatedBuildInputs = [ + octavius + ppxlib + ]; }; ppx_let = janePackage { @@ -719,7 +947,10 @@ with self; hash = "04v3fq0vnvvavxbc7hfsrg8732pwxbyw8pjl3xfplqdqci6fj15n"; minimalOCamlVersion = "4.04.2"; meta.description = "Monadic let-bindings"; - propagatedBuildInputs = [ ppxlib ppx_here ]; + propagatedBuildInputs = [ + ppxlib + ppx_here + ]; }; ppx_log = janePackage { @@ -727,7 +958,13 @@ with self; hash = "08i9gz3f4w3bmlrfdw7ja9awsfkhhldz03bnnc4hijfmn8sawzi0"; minimalOCamlVersion = "4.08.0"; meta.description = "Ppx_sexp_message-like extension nodes for lazily rendering log messages"; - propagatedBuildInputs = [ base ppx_here ppx_sexp_conv ppx_sexp_message sexplib ]; + propagatedBuildInputs = [ + base + ppx_here + ppx_sexp_conv + ppx_sexp_message + sexplib + ]; }; ppx_module_timer = janePackage { @@ -774,7 +1011,11 @@ with self; pname = "ppx_python"; hash = "1d2wf0rkvxg07q6xq2zmxh6hmvnwlsmny3mm92jsg1s7bdl39gap"; meta.description = "A [@@deriving] plugin to generate Python conversion functions "; - propagatedBuildInputs = [ ppx_base ppxlib pyml ]; + propagatedBuildInputs = [ + ppx_base + ppxlib + pyml + ]; }; ppx_sexp_conv = janePackage { @@ -783,7 +1024,11 @@ with self; minimalOCamlVersion = "4.08.0"; hash = "sha256-NYknZHyDklr71hihM2pPFQ7uAKkuKO2DJkjtsF+xc5g="; meta.description = "[@@deriving] plugin to generate S-expression conversion functions"; - propagatedBuildInputs = [ ppxlib sexplib0 base ]; + propagatedBuildInputs = [ + ppxlib + sexplib0 + base + ]; }; ppx_sexp_message = janePackage { @@ -791,7 +1036,10 @@ with self; hash = "0a7hx50bkkc5n5msc3zzc4ixnp7674x3mallknb9j31jnd8l90nj"; minimalOCamlVersion = "4.04.2"; meta.description = "A ppx rewriter for easy construction of s-expressions"; - propagatedBuildInputs = [ ppx_here ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_here + ppx_sexp_conv + ]; }; ppx_sexp_value = janePackage { @@ -799,7 +1047,10 @@ with self; hash = "0kz83j9v6yz3v8c6vr9ilhkcci4hhjd6i6r6afnx72jh6i7d3hnv"; minimalOCamlVersion = "4.04.2"; meta.description = "A ppx rewriter that simplifies building s-expressions from ocaml values"; - propagatedBuildInputs = [ ppx_here ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_here + ppx_sexp_conv + ]; }; ppx_stable = janePackage { @@ -815,14 +1066,22 @@ with self; minimalOCamlVersion = "4.04.2"; hash = "1dp5frk6cig5m3m5rrh2alw63snyf845x7zlkkaljip02pqcbw1s"; meta.description = "Ppx extension for string interpolation"; - propagatedBuildInputs = [ ppx_base ppxlib stdio ]; + propagatedBuildInputs = [ + ppx_base + ppxlib + stdio + ]; }; ppx_typed_fields = janePackage { pname = "ppx_typed_fields"; hash = "0hxililjgy4jh66b4xmphrfhv6qpp7dz7xbz3islp357hf18niqy"; meta.description = "GADT-based field accessors and utilities"; - propagatedBuildInputs = [ core ppx_jane ppxlib ]; + propagatedBuildInputs = [ + core + ppx_jane + ppxlib + ]; }; ppx_typerep_conv = janePackage { @@ -830,7 +1089,10 @@ with self; minimalOCamlVersion = "4.04.2"; hash = "1q1lzykpm83ra4l5jh4rfddhd3c96kx4s4rvx0w4b51z1qk56zam"; meta.description = "Generation of runtime types from type declarations"; - propagatedBuildInputs = [ ppxlib typerep ]; + propagatedBuildInputs = [ + ppxlib + typerep + ]; }; ppx_variants_conv = janePackage { @@ -838,14 +1100,21 @@ with self; minimalOCamlVersion = "4.04.2"; hash = "1dh0bw9dn246k00pymf59yjkl6x6bxd76lkk9b5xpq2692wwlc3s"; meta.description = "Generation of accessor and iteration functions for ocaml variant types"; - propagatedBuildInputs = [ variantslib ppxlib ]; + propagatedBuildInputs = [ + variantslib + ppxlib + ]; }; profunctor = janePackage { pname = "profunctor"; hash = "151vk0cagjwn0isnnwryn6gmvnpds4dyj1in9jvv5is8yij203gg"; meta.description = "A library providing a signature for simple profunctors and traversal of a record"; - propagatedBuildInputs = [ base ppx_jane record_builder ]; + propagatedBuildInputs = [ + base + ppx_jane + record_builder + ]; }; protocol_version_header = janePackage { @@ -861,7 +1130,13 @@ with self; hash = "sha256-j8WXVTEiBmHtoTjkbnIh31vC4IghfAMaEL19nDLx3mc="; meta.description = "A library to help writing wrappers around ocaml code for python"; buildInputs = [ ppx_optcomp ]; - propagatedBuildInputs = [ ppx_expect ppx_let ppx_python stdio typerep ]; + propagatedBuildInputs = [ + ppx_expect + ppx_let + ppx_python + stdio + typerep + ]; }; re2 = janePackage { @@ -880,21 +1155,33 @@ with self; version = "0.14.0"; hash = "0kjc0ff6b3509s3b9n4q8ilb06d5fngdh3z58cm95vg7zkcas9w3"; meta.description = "Re2_stable adds an incomplete but stable serialization of Re2"; - propagatedBuildInputs = [ core re2 ]; + propagatedBuildInputs = [ + core + re2 + ]; }; record_builder = janePackage { pname = "record_builder"; hash = "004nqcmwll0vy47mb3d3jlk21cc6adcjy62dkv2k966n9jkh472h"; meta.description = "A library which provides traversal of records with an applicative"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; }; redis-async = janePackage { pname = "redis-async"; hash = "0pccf4gkm880yyk8x4kgy5rwblkbscxav2sbis13abpms9vr7jfn"; meta.description = "Redis client for Async applications"; - propagatedBuildInputs = [ async bignum core core_kernel ppx_jane ]; + propagatedBuildInputs = [ + async + bignum + core + core_kernel + ppx_jane + ]; }; resource_cache = janePackage { @@ -931,7 +1218,10 @@ with self; sexp_macro = janePackage { pname = "sexp_macro"; hash = "1l5dsv9gawmf5dg3rf8sxphp9qs3n4n038nlmf9rxzypzyn112k8"; - propagatedBuildInputs = [ async sexplib ]; + propagatedBuildInputs = [ + async + sexplib + ]; meta.description = "Sexp macros"; }; @@ -941,14 +1231,21 @@ with self; hash = "sha256-UJEO2P4C7ZaD110MEfkG4FXfGDVAAW2TAK489faV6SM="; minimalOCamlVersion = "4.07"; meta.description = "S-expression pretty-printer"; - propagatedBuildInputs = [ ppx_base re sexplib ]; + propagatedBuildInputs = [ + ppx_base + re + sexplib + ]; }; sexp_select = janePackage { pname = "sexp_select"; hash = "0mmvga9w3gbb2gd1h4l8f1c3l2lrpn1zld2a8xgqyfqfff3vg31p"; minimalOCamlVersion = "4.07"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; meta.description = "A library to use CSS-style selectors to traverse sexp trees"; }; @@ -966,7 +1263,10 @@ with self; hash = "sha256-LkGNnp717LMHeWe1Ka6qUZcpw8fKSsd5MusaLgFjm70="; minimalOCamlVersion = "4.04.2"; meta.description = "Library for serializing OCaml values to and from S-expressions"; - propagatedBuildInputs = [ num parsexp ]; + propagatedBuildInputs = [ + num + parsexp + ]; }; shell = janePackage { @@ -982,7 +1282,10 @@ with self; pname = "shexp"; hash = "05iswnhi92f4yvrh76j3254bvls6fbrdb56mv6vc6mi5f8z4l79i"; minimalOCamlVersion = "4.07"; - propagatedBuildInputs = [ posixat spawn ]; + propagatedBuildInputs = [ + posixat + spawn + ]; meta.description = "Process library and s-expression based shell"; }; @@ -1005,7 +1308,12 @@ with self; pname = "splittable_random"; hash = "0ap5z4z1aagz4z02q9642cbl25jzws9lbc2x5xkpyjlc0qcm9v3m"; meta.description = "PRNG that can be split into independent streams"; - propagatedBuildInputs = [ base ppx_assert ppx_bench ppx_sexp_message ]; + propagatedBuildInputs = [ + base + ppx_assert + ppx_bench + ppx_sexp_message + ]; }; stdio = janePackage { @@ -1020,14 +1328,21 @@ with self; pname = "textutils"; hash = "1wass49h645wql9b7nck2iqlkf4648dkxvlvxixr7z80zcnb5rxr"; meta.description = "Text output utilities"; - propagatedBuildInputs = [ core_unix textutils_kernel ]; + propagatedBuildInputs = [ + core_unix + textutils_kernel + ]; }; textutils_kernel = janePackage { pname = "textutils_kernel"; hash = "068g11d98wsb5a6ds0p5xybdmx5nx9bxa0k11dmh3l57kn4c169x"; meta.description = "Text output utilities"; - propagatedBuildInputs = [ core ppx_jane uutf ]; + propagatedBuildInputs = [ + core + ppx_jane + uutf + ]; }; time_now = janePackage { @@ -1035,8 +1350,15 @@ with self; hash = "1pa0hyh470j9jylii4983qagb6hq2dz6s0q2fnrcph9qbw83bc0c"; minimalOCamlVersion = "4.04.2"; meta.description = "Reports the current time"; - buildInputs = [ jst-config ppx_optcomp ]; - propagatedBuildInputs = [ jane-street-headers base ppx_base ]; + buildInputs = [ + jst-config + ppx_optcomp + ]; + propagatedBuildInputs = [ + jane-street-headers + base + ppx_base + ]; }; timezone = janePackage { @@ -1050,7 +1372,10 @@ with self; pname = "topological_sort"; hash = "0iqhp8n6g5n1ng80brjpav54229lykm2c1fc104s58lk3rqfvj9v"; meta.description = "Topological sort algorithm"; - propagatedBuildInputs = [ ppx_jane stdio ]; + propagatedBuildInputs = [ + ppx_jane + stdio + ]; }; typerep = janePackage { @@ -1073,7 +1398,12 @@ with self; pname = "vcaml"; hash = "12fd29x9dgf4f14xrx7z4y1bm1wbfynrs3jismjbiqnckfpbqrib"; meta.description = "OCaml bindings for the Neovim API"; - propagatedBuildInputs = [ angstrom-async async_extra expect_test_helpers_async faraday ]; + propagatedBuildInputs = [ + angstrom-async + async_extra + expect_test_helpers_async + faraday + ]; }; virtual_dom = janePackage { @@ -1082,7 +1412,13 @@ with self; hash = "sha256-Uv6ZDxz2/H0nHjiycUKNQwy/zZyHHmwDEHknFHwDuDs="; meta.description = "OCaml bindings for the virtual-dom library"; buildInputs = [ js_of_ocaml-ppx ]; - propagatedBuildInputs = [ core_kernel gen_js_api js_of_ocaml lambdasoup tyxml ]; + propagatedBuildInputs = [ + core_kernel + gen_js_api + js_of_ocaml + lambdasoup + tyxml + ]; }; zarith_stubs_js = janePackage { @@ -1097,7 +1433,11 @@ with self; hash = "1blkv35g5q1drkc6zmc4m027gjz6vfdadra1kw1xkp1wlc2l4v3k"; meta.description = "OCaml bindings to Zstandard"; buildInputs = [ ppx_jane ]; - propagatedBuildInputs = [ core_kernel ctypes zstd ]; + propagatedBuildInputs = [ + core_kernel + ctypes + zstd + ]; }; } diff --git a/pkgs/development/ocaml-modules/janestreet/0.16.nix b/pkgs/development/ocaml-modules/janestreet/0.16.nix index 325e182b48b193..30aa920fff2430 100644 --- a/pkgs/development/ocaml-modules/janestreet/0.16.nix +++ b/pkgs/development/ocaml-modules/janestreet/0.16.nix @@ -1,11 +1,12 @@ -{ self -, bash -, fetchpatch -, fzf -, lib -, openssl -, zstd -, krb5 +{ + self, + bash, + fetchpatch, + fzf, + lib, + openssl, + zstd, + krb5, }: with self; @@ -16,7 +17,10 @@ with self; pname = "abstract_algebra"; hash = "sha256-hAZzc2ypbGE/8mxxk4GZqr17JlIYv71gZJMQ4plsK38="; meta.description = "A small library describing abstract algebra concepts"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; }; accessor = janePackage { @@ -30,7 +34,10 @@ with self; pname = "accessor_async"; hash = "sha256-kGT7aFNOgU8/2ez9L/lefb2LN7I87+WthZHnb+dY9PE="; meta.description = "Accessors for Async types, for use with the Accessor library"; - propagatedBuildInputs = [ accessor_core async_kernel ]; + propagatedBuildInputs = [ + accessor_core + async_kernel + ]; }; accessor_base = janePackage { @@ -44,14 +51,21 @@ with self; pname = "accessor_core"; hash = "sha256-f4s/I+xDi/aca1WgaE+P3CD4e80jenS0WHg4T1Stcbg="; meta.description = "Accessors for Core types, for use with the Accessor library"; - propagatedBuildInputs = [ accessor_base core_kernel ]; + propagatedBuildInputs = [ + accessor_base + core_kernel + ]; }; async = janePackage { pname = "async"; hash = "sha256-TpsC9sn8noiNI0aYbMalUUv3xlC2LMERsv6Gr928Vzc="; meta.description = "Monadic concurrency library"; - propagatedBuildInputs = [ async_rpc_kernel async_unix textutils ]; + propagatedBuildInputs = [ + async_rpc_kernel + async_unix + textutils + ]; doCheck = false; # we don't have netkit_sockets }; @@ -59,7 +73,13 @@ with self; pname = "async_durable"; hash = "sha256-PImYpM9xNFUWeWRld4jFwWBRowUP1iXzdxkK/fP/rHE="; meta.description = "Durable connections for use with async"; - propagatedBuildInputs = [ async_kernel async_rpc_kernel core core_kernel ppx_jane ]; + propagatedBuildInputs = [ + async_kernel + async_rpc_kernel + core + core_kernel + ppx_jane + ]; }; async_extra = janePackage { @@ -80,7 +100,10 @@ with self; pname = "async_inotify"; hash = "sha256-seFbs06w3T+B49sw3nOjpXpoJbJ+IJ3qN5LnufrsE48="; meta.description = "Async wrapper for inotify"; - propagatedBuildInputs = [ async_find inotify ]; + propagatedBuildInputs = [ + async_find + inotify + ]; }; async_interactive = janePackage { @@ -95,7 +118,11 @@ with self; hash = "sha256-JyF1busOv9JWxp55oaxBozIQyCKlmAY3csBA4/98qy0="; meta.description = "A small library that provide Async support for JavaScript platforms"; buildInputs = [ js_of_ocaml-ppx ]; - propagatedBuildInputs = [ async_rpc_kernel js_of_ocaml uri-sexp ]; + propagatedBuildInputs = [ + async_rpc_kernel + js_of_ocaml + uri-sexp + ]; }; async_kernel = janePackage { @@ -109,14 +136,21 @@ with self; pname = "async_rpc_kernel"; hash = "sha256-OccFMfhTRSQwx1LJcN8OkDpA62KabsyWn2hox84jqow="; meta.description = "Platform-independent core of Async RPC library"; - propagatedBuildInputs = [ async_kernel protocol_version_header ]; + propagatedBuildInputs = [ + async_kernel + protocol_version_header + ]; }; async_rpc_websocket = janePackage { pname = "async_rpc_websocket"; hash = "sha256-S3xIw/mew9YhtenWfp8ZD82WtOQSzJHtreT1+kRivus="; meta.description = "Library to serve and dispatch Async RPCs over websockets"; - propagatedBuildInputs = [ async_rpc_kernel async_websocket cohttp_async_websocket ]; + propagatedBuildInputs = [ + async_rpc_kernel + async_websocket + cohttp_async_websocket + ]; }; async_sendfile = janePackage { @@ -130,14 +164,27 @@ with self; pname = "async_shell"; hash = "sha256-DjIbadCjPymnkDsnonmxKumCWf5P9XO3ZaAwOaYRnbk="; meta.description = "Shell helpers for Async"; - propagatedBuildInputs = [ async shell ]; + propagatedBuildInputs = [ + async + shell + ]; }; async_smtp = janePackage { pname = "async_smtp"; hash = "sha256-X0eegZMMU9EnC9Oi+6DjtwNmyzQYr3EKi1duNzEAfkk="; meta.description = "SMTP client and server"; - propagatedBuildInputs = [ async_extra async_inotify async_sendfile async_shell async_ssl email_message resource_cache re2_stable sexp_macro ]; + propagatedBuildInputs = [ + async_extra + async_inotify + async_sendfile + async_shell + async_ssl + email_message + resource_cache + re2_stable + sexp_macro + ]; }; async_ssl = janePackage { @@ -146,28 +193,45 @@ with self; hash = "sha256-83YKxvVb/JwBnQG4R/R1Ztik9T/hO4cbiNTfFnErpG4="; meta.description = "Async wrappers for SSL"; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ async ctypes ctypes-foreign openssl ]; + propagatedBuildInputs = [ + async + ctypes + ctypes-foreign + openssl + ]; }; async_unix = janePackage { pname = "async_unix"; hash = "sha256-dT+yJC73sxS4NPR/GC/FyVLbWtYpM9DqKykVk8PEEWU="; meta.description = "Monadic concurrency library"; - propagatedBuildInputs = [ async_kernel core_unix ]; + propagatedBuildInputs = [ + async_kernel + core_unix + ]; }; async_websocket = janePackage { pname = "async_websocket"; hash = "sha256-Qy+A8ee6u5Vr05FNeaH/6Sdp9bcq3cnaDYO9OU06VW0="; meta.description = "A library that implements the websocket protocol on top of Async"; - propagatedBuildInputs = [ async cryptokit ]; + propagatedBuildInputs = [ + async + cryptokit + ]; }; babel = janePackage { pname = "babel"; hash = "sha256-nnMliU0d6vtHTYEy9uMi8nMaHvAsEXKN6uNByqZ28+c="; meta.description = "A library for defining Rpcs that can evolve over time without breaking backward compatibility"; - propagatedBuildInputs = [ async_rpc_kernel core ppx_jane streamable tilde_f ]; + propagatedBuildInputs = [ + async_rpc_kernel + core + ppx_jane + streamable + tilde_f + ]; }; base = janePackage { @@ -184,21 +248,35 @@ with self; pname = "base_bigstring"; hash = "sha256-gQbzdr05DEowzd0k9JBTF0gGMwlaVwTVJuoKZ0u9voU="; meta.description = "String type based on [Bigarray], for use in I/O and C-bindings"; - propagatedBuildInputs = [ int_repr ppx_jane ]; + propagatedBuildInputs = [ + int_repr + ppx_jane + ]; }; base_trie = janePackage { pname = "base_trie"; hash = "sha256-KV/k3B0h/4rE+MY6f4qDnlaObMmewUS+NAN2M7sb+yw="; meta.description = "Trie data structure library"; - propagatedBuildInputs = [ base core expect_test_helpers_core ppx_jane ]; + propagatedBuildInputs = [ + base + core + expect_test_helpers_core + ppx_jane + ]; }; base_quickcheck = janePackage { pname = "base_quickcheck"; hash = "sha256-9Flg8vAoT6f+3lw9wETQhsaA1fSsQiqKeEhzo0qtDu4="; meta.description = "Randomized testing framework, designed for compatibility with Base"; - propagatedBuildInputs = [ ppx_base ppx_fields_conv ppx_let ppx_sexp_value splittable_random ]; + propagatedBuildInputs = [ + ppx_base + ppx_fields_conv + ppx_let + ppx_sexp_value + splittable_random + ]; }; bidirectional_map = janePackage { @@ -210,7 +288,11 @@ with self; bignum = janePackage { pname = "bignum"; hash = "sha256-PmvqGImF1Nrr6swx5q3+9mCfSbieC3RvWuz8oCTkSgg="; - propagatedBuildInputs = [ core_kernel zarith zarith_stubs_js ]; + propagatedBuildInputs = [ + core_kernel + zarith + zarith_stubs_js + ]; meta.description = "Core-flavoured wrapper around zarith's arbitrary-precision rationals"; }; @@ -218,7 +300,14 @@ with self; pname = "bin_prot"; hash = "sha256-qFkM6TrTLnnFKmzQHktBb68HpBTMYhiURvnRKEoAevk="; meta.description = "A binary protocol generator"; - propagatedBuildInputs = [ ppx_compare ppx_custom_printf ppx_fields_conv ppx_optcomp ppx_stable_witness ppx_variants_conv ]; + propagatedBuildInputs = [ + ppx_compare + ppx_custom_printf + ppx_fields_conv + ppx_optcomp + ppx_stable_witness + ppx_variants_conv + ]; }; bonsai = janePackage { @@ -226,7 +315,11 @@ with self; hash = "sha256-YJ+qkVG5PLBmioa1gP7y6jwn82smyyYDIwHwhDqNeWM="; meta.description = "A library for building dynamic webapps, using Js_of_ocaml"; buildInputs = [ ppx_pattern_bind ]; - nativeBuildInputs = [ ppx_css js_of_ocaml-compiler ocaml-embed-file ]; + nativeBuildInputs = [ + ppx_css + js_of_ocaml-compiler + ocaml-embed-file + ]; propagatedBuildInputs = [ async async_durable @@ -264,7 +357,13 @@ with self; pname = "cohttp_async_websocket"; hash = "sha256-OBtyKMyvfz0KNG4SWmvoTMVPnVTpO12N38q+kEbegJE="; meta.description = "Websocket library for use with cohttp and async"; - propagatedBuildInputs = [ async_ssl async_websocket cohttp-async ppx_jane uri-sexp ]; + propagatedBuildInputs = [ + async_ssl + async_websocket + cohttp-async + ppx_jane + uri-sexp + ]; }; cohttp_static_handler = janePackage { @@ -278,7 +377,10 @@ with self; pname = "content_security_policy"; hash = "sha256-q/J+ZzeC6txyuRQzR8Hmu7cYJCQbxaMlVEmK8fj0hus="; meta.description = "A library for building content-security policies"; - propagatedBuildInputs = [ core ppx_jane ]; + propagatedBuildInputs = [ + core + ppx_jane + ]; }; core = janePackage { @@ -287,7 +389,13 @@ with self; hash = "sha256-cyOU++XJJkU2YMHfn8saFOxLoQSFhF7kARJi/9unbFQ="; meta.description = "Industrial strength alternative to OCaml's standard library"; buildInputs = [ jst-config ]; - propagatedBuildInputs = [ base base_bigstring base_quickcheck ppx_jane time_now ]; + propagatedBuildInputs = [ + base + base_bigstring + base_quickcheck + ppx_jane + time_now + ]; doCheck = false; # circular dependency with core_kernel }; @@ -302,7 +410,10 @@ with self; pname = "core_extended"; hash = "sha256-hcjmFDdVKCHK8u6D4Qn2a/HYTEZOvkXHcB6BTpbjF/s="; meta.description = "Extra components that are not as closely vetted or as stable as Core"; - propagatedBuildInputs = [ core_unix record_builder ]; + propagatedBuildInputs = [ + core_unix + record_builder + ]; }; core_kernel = janePackage { @@ -310,7 +421,12 @@ with self; hash = "sha256-YB3WMNLePrOKu+mmVedNo0pWN9x5fIaBxJsby56TFJU="; meta.description = "System-independent part of Core"; buildInputs = [ jst-config ]; - propagatedBuildInputs = [ base_bigstring core int_repr sexplib ]; + propagatedBuildInputs = [ + base_bigstring + core + int_repr + sexplib + ]; doCheck = false; # we don't have quickcheck_deprecated }; @@ -319,7 +435,14 @@ with self; hash = "sha256-mePpxjbUumMemHDKhRgACilchgS6QHZEV1ghYtT3flg="; meta.description = "Unix-specific portions of Core"; buildInputs = [ jst-config ]; - propagatedBuildInputs = [ core_kernel expect_test_helpers_core ocaml_intrinsics ppx_jane timezone spawn ]; + propagatedBuildInputs = [ + core_kernel + expect_test_helpers_core + ocaml_intrinsics + ppx_jane + timezone + spawn + ]; postPatch = '' patchShebangs unix_pseudo_terminal/src/discover.sh ''; @@ -328,28 +451,43 @@ with self; csvfields = janePackage { pname = "csvfields"; hash = "sha256-FEkjRmLeqNvauBlrY2xtLZfxVfnFWU8w8noEArPUieo="; - propagatedBuildInputs = [ core num ]; + propagatedBuildInputs = [ + core + num + ]; meta.description = "Runtime support for ppx_xml_conv and ppx_csv_conv"; }; dedent = janePackage { pname = "dedent"; hash = "sha256-fzytLr3tVr2vPmykUBzNFMxnyMcIeeo8S9BydsTKnQw="; - propagatedBuildInputs = [ base ppx_jane stdio ]; + propagatedBuildInputs = [ + base + ppx_jane + stdio + ]; meta.description = "A library for improving redability of multi-line string constants in code"; }; delimited_parsing = janePackage { pname = "delimited_parsing"; hash = "sha256-XyO3hzPz48i1cnMTJvZfarM6HC7qdHqdftp9SnCjPEU="; - propagatedBuildInputs = [ async core_extended ]; + propagatedBuildInputs = [ + async + core_extended + ]; meta.description = "Parsing of character (e.g., comma) separated and fixed-width values"; }; diffable = janePackage { pname = "diffable"; hash = "sha256-ascQUbxzvRR8XrroaupyFZ2YNQMvlXn4PemumYTwRF4="; - propagatedBuildInputs = [ core ppx_jane stored_reversed streamable ]; + propagatedBuildInputs = [ + core + ppx_jane + stored_reversed + streamable + ]; meta.description = "An interface for diffs"; }; @@ -357,35 +495,56 @@ with self; pname = "ecaml"; hash = "sha256-VS7eTTD85ci3mJIXd2pG1Y/ygT9dCIvfzU2HtOufW6U="; meta.description = "Library for writing Emacs plugin in OCaml"; - propagatedBuildInputs = [ async expect_test_helpers_core ]; + propagatedBuildInputs = [ + async + expect_test_helpers_core + ]; }; email_message = janePackage { pname = "email_message"; hash = "sha256-eso68owbAspjaVgj/wGFQ7VQYlAwyYV3oNitLQWiRPA="; meta.description = "E-mail message parser"; - propagatedBuildInputs = [ angstrom async base64 cryptokit magic-mime re2 ]; + propagatedBuildInputs = [ + angstrom + async + base64 + cryptokit + magic-mime + re2 + ]; }; env_config = janePackage { pname = "env_config"; hash = "sha256-CvvpKI7F40DVC7iByrzCqW1ilPiIhdDPYaJrDoUZVSs="; meta.description = "Helper library for retrieving configuration from an environment variable"; - propagatedBuildInputs = [ async core core_unix ppx_jane ]; + propagatedBuildInputs = [ + async + core + core_unix + ppx_jane + ]; }; expect_test_helpers_async = janePackage { pname = "expect_test_helpers_async"; hash = "sha256-dEvOMb1aCEt05XtkKIC9jWoIQ/2zM0Gj+K/ZN3bFjeI="; meta.description = "Async helpers for writing expectation tests"; - propagatedBuildInputs = [ async expect_test_helpers_core ]; + propagatedBuildInputs = [ + async + expect_test_helpers_core + ]; }; expect_test_helpers_core = janePackage { pname = "expect_test_helpers_core"; hash = "sha256-8DsMwk9WhQQ7iMNYSFBglfbcgvE5dySt4J4qjzJ3dJk="; meta.description = "Helpers for writing expectation tests"; - propagatedBuildInputs = [ core_kernel sexp_pretty ]; + propagatedBuildInputs = [ + core_kernel + sexp_pretty + ]; }; fieldslib = janePackage { @@ -398,8 +557,7 @@ with self; file_path = janePackage { pname = "file_path"; hash = "sha256-EEpDZNgUgyeqivRhZgQWWlerl+7OOcvAbjjQ3e1NYOQ="; - meta.description = - "A library for typed manipulation of UNIX-style file paths"; + meta.description = "A library for typed manipulation of UNIX-style file paths"; propagatedBuildInputs = [ async core @@ -415,14 +573,21 @@ with self; pname = "fuzzy_match"; hash = "sha256-M3yOqP0/OZFbqZZpgDdhJ/FZU3MhKwIXbWjwuMlxe2Q="; meta.description = "A library for fuzzy string matching"; - propagatedBuildInputs = [ core ppx_jane ]; + propagatedBuildInputs = [ + core + ppx_jane + ]; }; fzf = janePackage { pname = "fzf"; hash = "sha256-IQ2wze34LlOutecDOrPhj3U7MFVJTSjQW+If3QyHoes="; meta.description = "A library for running the fzf command line tool"; - propagatedBuildInputs = [ async core_kernel ppx_jane ]; + propagatedBuildInputs = [ + async + core_kernel + ppx_jane + ]; postPatch = '' substituteInPlace src/fzf.ml --replace /usr/bin/fzf ${fzf}/bin/fzf ''; @@ -432,14 +597,21 @@ with self; pname = "hex_encode"; hash = "sha256-jnsf5T1D1++AUdrato/NO3gTVXu14klXozHFIG9HH/o="; meta.description = "Hexadecimal encoding library"; - propagatedBuildInputs = [ core ppx_jane ounit ]; + propagatedBuildInputs = [ + core + ppx_jane + ounit + ]; }; higher_kinded = janePackage { pname = "higher_kinded"; hash = "sha256-aCpYc7f4mrPsGp038YabEyw72cA6GbCKsok+5Hej5P0="; meta.description = "A library with an encoding of higher kinded types in OCaml"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; }; incr_dom = janePackage { @@ -447,7 +619,12 @@ with self; hash = "sha256-fnD/YnaGK6MIy/fL6bDwcoGDJhHo2+1l8dCXxwN28kg="; meta.description = "A library for building dynamic webapps, using Js_of_ocaml"; buildInputs = [ js_of_ocaml-ppx ]; - propagatedBuildInputs = [ async_js incr_map incr_select virtual_dom ]; + propagatedBuildInputs = [ + async_js + incr_map + incr_select + virtual_dom + ]; }; incr_map = janePackage { @@ -455,7 +632,13 @@ with self; hash = "sha256-D3ZD0C4YfZOfXw+3CtqL8DKcz+b06UL8AF7Rf9x+hps="; meta.description = "Helpers for incremental operations on map like data structures"; buildInputs = [ ppx_pattern_bind ]; - propagatedBuildInputs = [ abstract_algebra bignum diffable incremental streamable ]; + propagatedBuildInputs = [ + abstract_algebra + bignum + diffable + incremental + streamable + ]; }; incr_select = janePackage { @@ -469,34 +652,61 @@ with self; pname = "incremental"; hash = "sha256-PXGY0M2xeVWDLeS3SrqXy1dqsyeKgndGT6NpuiyNQQQ="; meta.description = "Library for incremental computations"; - propagatedBuildInputs = [ core_kernel lru_cache ]; + propagatedBuildInputs = [ + core_kernel + lru_cache + ]; }; indentation_buffer = janePackage { pname = "indentation_buffer"; hash = "sha256-5ayWs7yUnuxh5S3Dp0GbYTkGXttDMomfZak4MHePFbk="; meta.description = "A library for building strings with indentation"; - propagatedBuildInputs = [ core ppx_jane ]; + propagatedBuildInputs = [ + core + ppx_jane + ]; }; int_repr = janePackage { pname = "int_repr"; hash = "sha256-lghu2U1JwZaR4dkd9PcJEW3pZSPoaFhUluIDwFAYFK0="; meta.description = "Integers of various widths"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; }; janestreet_cpuid = janePackage { pname = "janestreet_cpuid"; hash = "sha256-lN8+8uhcVn3AoApWzqeCe/It1G6f0VgZzFcwFEckejk="; meta.description = "A library for parsing CPU capabilities out of the `cpuid` instruction"; - propagatedBuildInputs = [ core core_kernel ppx_jane ]; + propagatedBuildInputs = [ + core + core_kernel + ppx_jane + ]; }; janestreet_csv = janePackage { pname = "janestreet_csv"; hash = "sha256-XLyHxVlgBvMIBrG2wzOudbKqy+N12Boheb3K+6o9y1o="; - propagatedBuildInputs = [ async bignum core_kernel core_unix csvfields delimited_parsing fieldslib numeric_string ppx_jane re2 textutils tyxml ocaml_pcre ]; + propagatedBuildInputs = [ + async + bignum + core_kernel + core_unix + csvfields + delimited_parsing + fieldslib + numeric_string + ppx_jane + re2 + textutils + tyxml + ocaml_pcre + ]; meta.description = "Tools for working with CSVs on the command line"; }; @@ -504,7 +714,10 @@ with self; pname = "jane_rope"; hash = "sha256-MpjbwV+VS3qRuW8kxhjGzsITEdrPeWyr0V+LiKR6U8U="; meta.description = "String representation with cheap concatenation"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; }; jane-street-headers = janePackage { @@ -517,74 +730,129 @@ with self; pname = "js_of_ocaml_patches"; hash = "sha256-Uj+X/0XUP5Za8NKfHGo9OZnqzKCiuurYJyluD6b0wOQ="; meta.description = "Additions to js_of_ocaml's standard library that are required by Jane Street libraries"; - propagatedBuildInputs = [ js_of_ocaml js_of_ocaml-ppx ]; + propagatedBuildInputs = [ + js_of_ocaml + js_of_ocaml-ppx + ]; }; jsonaf = janePackage { pname = "jsonaf"; hash = "sha256-Gn54NUg4YOyrXY5kXCZhHFz24CfUT9c55cJ2sOsNVw8="; meta.description = "A library for parsing, manipulating, and serializing data structured as JSON"; - propagatedBuildInputs = [ base ppx_jane angstrom faraday ]; + propagatedBuildInputs = [ + base + ppx_jane + angstrom + faraday + ]; }; jst-config = janePackage { pname = "jst-config"; hash = "sha256-GviY+zYza7UNYOlAnfAz0aH4LH2B5xA+7iELLuZLgQQ="; meta.description = "Compile-time configuration for Jane Street libraries"; - buildInputs = [ dune-configurator ppx_assert stdio ]; + buildInputs = [ + dune-configurator + ppx_assert + stdio + ]; }; krb = janePackage { pname = "krb"; hash = "sha256-+XwYKwpl668fZ23YEbL1wW9PlaIIjbP/hHwNanf3dAY="; meta.description = "A library for using Kerberos for both Rpc and Tcp communication"; - propagatedBuildInputs = [ async base core env_config hex_encode ppx_jane protocol_version_header username_kernel dune-configurator krb5 ]; + propagatedBuildInputs = [ + async + base + core + env_config + hex_encode + ppx_jane + protocol_version_header + username_kernel + dune-configurator + krb5 + ]; }; lru_cache = janePackage { pname = "lru_cache"; hash = "sha256-FqOBC4kBL9IuFIL4JrVU7iF1AUu+1R/CchR52eyEsa8="; meta.description = "An LRU Cache implementation"; - propagatedBuildInputs = [ core_kernel ppx_jane ]; + propagatedBuildInputs = [ + core_kernel + ppx_jane + ]; }; man_in_the_middle_debugger = janePackage { pname = "man_in_the_middle_debugger"; hash = "sha256-b2A/ITf9gx3thSdEY2n7jxKrMOVDpzx4JkSMB3aTyE4="; meta.description = "Man-in-the-middle debugging library"; - propagatedBuildInputs = [ async core ppx_jane angstrom angstrom-async ]; + propagatedBuildInputs = [ + async + core + ppx_jane + angstrom + angstrom-async + ]; }; n_ary = janePackage { pname = "n_ary"; hash = "sha256-ofstQs5R25NTP4EtBIzDE/Mzg9ZzAJKfAF838uu0zuE="; meta.description = "A library for N-ary datatypes and operations"; - propagatedBuildInputs = [ base expect_test_helpers_core ppx_compare ppx_enumerate ppx_hash ppx_jane ppx_sexp_conv ppx_sexp_message ]; + propagatedBuildInputs = [ + base + expect_test_helpers_core + ppx_compare + ppx_enumerate + ppx_hash + ppx_jane + ppx_sexp_conv + ppx_sexp_message + ]; }; numeric_string = janePackage { pname = "numeric_string"; hash = "sha256-MzRPXMR4Pi07mfJQgOV6R1Z22y2tvQTCq22+00aY1ik="; meta.description = "A comparison function for strings that sorts numeric fragments of strings according to their numeric value"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; }; - ocaml-compiler-libs = janePackage ({ - pname = "ocaml-compiler-libs"; - minimalOCamlVersion = "4.04.1"; - meta.description = "OCaml compiler libraries repackaged"; - } // (if lib.versionAtLeast ocaml.version "5.2" then { - version = "0.17.0"; - hash = "sha256-QaC6BWrpFblra6X1+TrlK+J3vZxLvLJZ2b0427DiQzM="; - } else { - version = "0.12.4"; - hash = "00if2f7j9d8igdkj4rck3p74y17j6b233l91mq02drzrxj199qjv"; - })); + ocaml-compiler-libs = janePackage ( + { + pname = "ocaml-compiler-libs"; + minimalOCamlVersion = "4.04.1"; + meta.description = "OCaml compiler libraries repackaged"; + } + // ( + if lib.versionAtLeast ocaml.version "5.2" then + { + version = "0.17.0"; + hash = "sha256-QaC6BWrpFblra6X1+TrlK+J3vZxLvLJZ2b0427DiQzM="; + } + else + { + version = "0.12.4"; + hash = "00if2f7j9d8igdkj4rck3p74y17j6b233l91mq02drzrxj199qjv"; + } + ) + ); ocaml-embed-file = janePackage { pname = "ocaml-embed-file"; hash = "sha256-rs+68VATumUgZQ9QrG+By5yNc8cy7avL0BDeqwix0co="; - propagatedBuildInputs = [ async ppx_jane ]; + propagatedBuildInputs = [ + async + ppx_jane + ]; meta.description = "Files contents as module constants"; }; @@ -600,21 +868,32 @@ with self; pname = "of_json"; hash = "sha256-qh9mX03Fk9Jb8yox7mZ/CGbWecszK15oaygKbJVDqa0="; meta.description = "A friendly applicative interface for Jsonaf"; - buildInputs = [ core core_extended jsonaf ppx_jane ]; + buildInputs = [ + core + core_extended + jsonaf + ppx_jane + ]; }; ordinal_abbreviation = janePackage { pname = "ordinal_abbreviation"; hash = "sha256-bGlzFcM6Yw8fcuovrv11WNtAB4mVYv4BjuMlkhsHomQ="; meta.description = "A minimal library for generating ordinal names of integers"; - buildInputs = [ base ppx_jane ]; + buildInputs = [ + base + ppx_jane + ]; }; parsexp = janePackage { pname = "parsexp"; hash = "sha256-oc2ASDtUyRBB68tjAoblryAcXF+u3XP1mkQPO5hNbKo="; meta.description = "S-expression parsing library"; - propagatedBuildInputs = [ base sexplib0 ]; + propagatedBuildInputs = [ + base + sexplib0 + ]; }; patdiff = janePackage { @@ -624,7 +903,11 @@ with self; # Used by patdiff-git-wrapper. Providing it here also causes the shebang # line to be automatically patched. buildInputs = [ bash ]; - propagatedBuildInputs = [ core_unix patience_diff ocaml_pcre ]; + propagatedBuildInputs = [ + core_unix + patience_diff + ocaml_pcre + ]; meta = { description = "File Diff using the Patience Diff algorithm"; }; @@ -641,13 +924,23 @@ with self; pname = "polling_state_rpc"; hash = "sha256-l7SMFI+U2rde2OSUNOXPb9NBsvjPrBcxStNooxMgVB8="; meta.description = "An RPC which tracks state on the client and server so it only needs to send diffs across the wire"; - propagatedBuildInputs = [ async_kernel async_rpc_kernel core core_kernel diffable ppx_jane ]; + propagatedBuildInputs = [ + async_kernel + async_rpc_kernel + core + core_kernel + diffable + ppx_jane + ]; }; posixat = janePackage { pname = "posixat"; hash = "sha256-Nhp5jiK/TTwQXY5Bm4TTeH+xDTdXtvkSq5CS/Sr1UgA="; - propagatedBuildInputs = [ ppx_optcomp ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_optcomp + ppx_sexp_conv + ]; meta.description = "Binding to the posix *at functions"; }; @@ -663,14 +956,24 @@ with self; pname = "ppx_assert"; hash = "sha256-LrpKE0BlFC3QseSXf5WhI71blshUzhH8yo2nXjAtiB8="; meta.description = "Assert-like extension nodes that raise useful errors on failure"; - propagatedBuildInputs = [ ppx_cold ppx_compare ppx_here ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_cold + ppx_compare + ppx_here + ppx_sexp_conv + ]; }; ppx_base = janePackage { pname = "ppx_base"; hash = "sha256-Ak+7+33qEGYwZWbES032SdkFOsae0+tWtR/DV+xrB10="; meta.description = "Base set of ppx rewriters"; - propagatedBuildInputs = [ ppx_cold ppx_enumerate ppx_globalize ppx_hash ]; + propagatedBuildInputs = [ + ppx_cold + ppx_enumerate + ppx_globalize + ppx_hash + ]; }; ppx_bench = janePackage { @@ -684,7 +987,10 @@ with self; pname = "ppx_bin_prot"; hash = "sha256-ktfa4umCnLd9oY2WWX/5R7vPB/g7DJX8x3nF9fYLNCQ="; meta.description = "Generation of bin_prot readers and writers from types"; - propagatedBuildInputs = [ bin_prot ppx_here ]; + propagatedBuildInputs = [ + bin_prot + ppx_here + ]; doCheck = false; # circular dependency with ppx_jane }; @@ -699,14 +1005,20 @@ with self; pname = "ppx_compare"; hash = "sha256-4bZdhyfnzTjH4E303O6GO2jW968ftuXwoE4/x854JOo="; meta.description = "Generation of comparison functions from types"; - propagatedBuildInputs = [ ppxlib base ]; + propagatedBuildInputs = [ + ppxlib + base + ]; }; ppx_conv_func = janePackage { pname = "ppx_conv_func"; hash = "sha256-HPHSZHdR9ll+7EbWc36shTdRPFYB0lkApidk+XL3clI="; meta.description = "Part of the Jane Street's PPX rewriters collection"; - propagatedBuildInputs = [ ppxlib base ]; + propagatedBuildInputs = [ + ppxlib + base + ]; }; ppx_custom_printf = janePackage { @@ -720,28 +1032,51 @@ with self; pname = "ppx_css"; hash = "sha256-spT/dJW8YJtG4pOku9r6VVlBAMwGakTrr1euiABeqsU="; meta.description = "A ppx that takes in css strings and produces a module for accessing the unique names defined within"; - propagatedBuildInputs = [ async async_unix core_kernel core_unix ppxlib js_of_ocaml js_of_ocaml-ppx sedlex virtual_dom ]; + propagatedBuildInputs = [ + async + async_unix + core_kernel + core_unix + ppxlib + js_of_ocaml + js_of_ocaml-ppx + sedlex + virtual_dom + ]; }; ppx_csv_conv = janePackage { pname = "ppx_csv_conv"; hash = "sha256-RdPcDPLzoSf45Zeon3f4HcEvlwB6Q6sAINX3LHmjmj8="; meta.description = "Generate functions to read/write records in csv format"; - propagatedBuildInputs = [ csvfields ppx_conv_func ]; + propagatedBuildInputs = [ + csvfields + ppx_conv_func + ]; }; ppx_demo = janePackage { pname = "ppx_demo"; hash = "sha256-t/jz94YpwmorhWlcuflIZe0l85cESE62L9I7NMASVWM="; meta.description = "PPX that exposes the source code string of an expression/module structure"; - propagatedBuildInputs = [ core dedent ppx_jane ppxlib ]; + propagatedBuildInputs = [ + core + dedent + ppx_jane + ppxlib + ]; }; ppx_derive_at_runtime = janePackage { pname = "ppx_derive_at_runtime"; hash = "sha256-UESWOkyWTHJlsE6KZkty9P+iHI3oY1rLve3raRAqMbk="; meta.description = "Define a new ppx deriver by naming a runtime module"; - propagatedBuildInputs = [ base expect_test_helpers_core ppx_jane ppxlib ]; + propagatedBuildInputs = [ + base + expect_test_helpers_core + ppx_jane + ppxlib + ]; }; ppx_disable_unused_warnings = janePackage { @@ -762,7 +1097,11 @@ with self; pname = "ppx_expect"; hash = "sha256-H5ybRHufycdyCxKu370+QZAMUPQsHVD+6nD93tzvLn8="; meta.description = "Cram like framework for OCaml"; - propagatedBuildInputs = [ ppx_here ppx_inline_test re ]; + propagatedBuildInputs = [ + ppx_here + ppx_inline_test + re + ]; doCheck = false; # test build rules broken }; @@ -770,7 +1109,10 @@ with self; pname = "ppx_fields_conv"; hash = "sha256-kl0JZocMWo2KNciCWkT4nIbJZbh56ijZmlZWbxV8Qj0="; meta.description = "Generation of accessor and iteration functions for ocaml records"; - propagatedBuildInputs = [ fieldslib ppxlib ]; + propagatedBuildInputs = [ + fieldslib + ppxlib + ]; }; ppx_fixed_literal = janePackage { @@ -784,14 +1126,20 @@ with self; pname = "ppx_globalize"; hash = "sha256-SG7710YPwWmhRVl7wN3ZQz3ZMTw3cpoywVSeVQAI3Zc="; meta.description = "A ppx rewriter that generates functions to copy local values to the global heap"; - propagatedBuildInputs = [ base ppxlib ]; + propagatedBuildInputs = [ + base + ppxlib + ]; }; ppx_hash = janePackage { pname = "ppx_hash"; hash = "sha256-ZmdW+q7fak8iG42jRQgZ6chmjHHwrDSy9wg7pq/6zwk="; meta.description = "A ppx rewriter that generates hash functions from type expressions and definitions"; - propagatedBuildInputs = [ ppx_compare ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_compare + ppx_sexp_conv + ]; }; ppx_here = janePackage { @@ -813,7 +1161,10 @@ with self; pname = "ppx_inline_test"; hash = "sha256-Ql0/80KitKvW3xffeCapYREmZvlg+QWCb2JM2T4Rjlc="; meta.description = "Syntax extension for writing in-line tests in ocaml code"; - propagatedBuildInputs = [ ppxlib time_now ]; + propagatedBuildInputs = [ + ppxlib + time_now + ]; doCheck = false; # test build rules broken }; @@ -821,36 +1172,69 @@ with self; pname = "ppx_jane"; hash = "sha256-v+/wdEGaXdMWDBa0eJO0uR18G/pDwHjsjaskoEuLusA="; meta.description = "Standard Jane Street ppx rewriters"; - propagatedBuildInputs = [ base_quickcheck ppx_bin_prot ppx_disable_unused_warnings ppx_expect ppx_fixed_literal ppx_ignore_instrumentation ppx_log ppx_module_timer ppx_optcomp ppx_optional ppx_pipebang ppx_stable ppx_string ppx_tydi ppx_typerep_conv ppx_variants_conv ]; + propagatedBuildInputs = [ + base_quickcheck + ppx_bin_prot + ppx_disable_unused_warnings + ppx_expect + ppx_fixed_literal + ppx_ignore_instrumentation + ppx_log + ppx_module_timer + ppx_optcomp + ppx_optional + ppx_pipebang + ppx_stable + ppx_string + ppx_tydi + ppx_typerep_conv + ppx_variants_conv + ]; }; ppx_jsonaf_conv = janePackage { pname = "ppx_jsonaf_conv"; hash = "sha256-GWDhSLtr2+VG3XFIbHgWUcLJFniC7/z90ndiE919CBo="; - meta.description = - "[@@deriving] plugin to generate Jsonaf conversion functions"; - propagatedBuildInputs = [ base jsonaf ppx_jane ppxlib ]; + meta.description = "[@@deriving] plugin to generate Jsonaf conversion functions"; + propagatedBuildInputs = [ + base + jsonaf + ppx_jane + ppxlib + ]; }; ppx_js_style = janePackage { pname = "ppx_js_style"; hash = "sha256-q5CLyeu+5qjegLrJkQVMnId3HMvZ8j3c0PqEa2vTBtU="; meta.description = "Code style checker for Jane Street Packages"; - propagatedBuildInputs = [ octavius ppxlib ]; + propagatedBuildInputs = [ + octavius + ppxlib + ]; }; ppx_let = janePackage { pname = "ppx_let"; hash = "sha256-/kEkYXFZ5OyTM4i/WWViaxKvigpoKKoiWtUWuEMkgBE="; meta.description = "Monadic let-bindings"; - propagatedBuildInputs = [ ppxlib ppx_here ]; + propagatedBuildInputs = [ + ppxlib + ppx_here + ]; }; ppx_log = janePackage { pname = "ppx_log"; hash = "sha256-/HwoxBWKuVqTDYe4u0cYNGqg2Lj0h49U2VrFa4cpE2g="; meta.description = "Ppx_sexp_message-like extension nodes for lazily rendering log messages"; - propagatedBuildInputs = [ base ppx_here ppx_sexp_conv ppx_sexp_message sexplib ]; + propagatedBuildInputs = [ + base + ppx_here + ppx_sexp_conv + ppx_sexp_message + sexplib + ]; }; ppx_module_timer = janePackage { @@ -892,28 +1276,42 @@ with self; pname = "ppx_python"; hash = "sha256-lpc6F+Scc5ECdOXPWowKSWRnFSzKbmE8oHs7zCjq3j8="; meta.description = "A [@@deriving] plugin to generate Python conversion functions "; - propagatedBuildInputs = [ ppx_base ppxlib pyml ]; + propagatedBuildInputs = [ + ppx_base + ppxlib + pyml + ]; }; ppx_sexp_conv = janePackage { pname = "ppx_sexp_conv"; hash = "sha256-eCQfYAxZZmfNTbPrFW0sqrj63kIdIQ1MAlImCaMop68="; meta.description = "[@@deriving] plugin to generate S-expression conversion functions"; - propagatedBuildInputs = [ ppxlib sexplib0 base ]; + propagatedBuildInputs = [ + ppxlib + sexplib0 + base + ]; }; ppx_sexp_message = janePackage { pname = "ppx_sexp_message"; hash = "sha256-4g3Fjrjqhw+XNkCyxrXkgZDEa3e+ytPsEtQA2xSv+jA="; meta.description = "A ppx rewriter for easy construction of s-expressions"; - propagatedBuildInputs = [ ppx_here ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_here + ppx_sexp_conv + ]; }; ppx_sexp_value = janePackage { pname = "ppx_sexp_value"; hash = "sha256-LsP+deeFYxB38xXw7LLB3gOMGZiUOFRYklGVY7DMmvE="; meta.description = "A ppx rewriter that simplifies building s-expressions from ocaml values"; - propagatedBuildInputs = [ ppx_here ppx_sexp_conv ]; + propagatedBuildInputs = [ + ppx_here + ppx_sexp_conv + ]; }; ppx_stable = janePackage { @@ -927,42 +1325,62 @@ with self; pname = "ppx_stable_witness"; hash = "sha256-W1CN4xspM8NJiXfi7OsngfzWnLEUmBs+IRLwHfxX9d4="; meta.description = "Ppx extension for deriving a witness that a type is intended to be stable"; - propagatedBuildInputs = [ base ppxlib ]; + propagatedBuildInputs = [ + base + ppxlib + ]; }; ppx_string = janePackage { pname = "ppx_string"; hash = "sha256-GQlgiaES8wc6Y7rTgmPrf9UfMfu125VoNGEbdc7kFsk="; meta.description = "Ppx extension for string interpolation"; - propagatedBuildInputs = [ ppx_base ppxlib stdio ]; + propagatedBuildInputs = [ + ppx_base + ppxlib + stdio + ]; }; ppx_tydi = janePackage { pname = "ppx_tydi"; hash = "sha256-neu2Z7TgQdBzf8UtYDRhnGp3Iggfd90Fr+gQuwVTMOo="; meta.description = "Let expressions, inferring pattern type from expression"; - propagatedBuildInputs = [ base ppxlib ]; + propagatedBuildInputs = [ + base + ppxlib + ]; }; ppx_typed_fields = janePackage { pname = "ppx_typed_fields"; hash = "sha256-l4lCQ4n5FLPS82sb3FgW+HF2OEY/kY10sNfr+aQF8x8="; meta.description = "GADT-based field accessors and utilities"; - propagatedBuildInputs = [ core ppx_jane ppxlib ]; + propagatedBuildInputs = [ + core + ppx_jane + ppxlib + ]; }; ppx_typerep_conv = janePackage { pname = "ppx_typerep_conv"; hash = "sha256-DxjgwZee0jOea7qyPfEhRrdcKWQb2jtjrowiJszS+Fs="; meta.description = "Generation of runtime types from type declarations"; - propagatedBuildInputs = [ ppxlib typerep ]; + propagatedBuildInputs = [ + ppxlib + typerep + ]; }; ppx_variants_conv = janePackage { pname = "ppx_variants_conv"; hash = "sha256-Q/CCcMrD+XN5YRMzKvXuiQHfcwXwI773s8x150/eMzs="; meta.description = "Generation of accessor and iteration functions for ocaml variant types"; - propagatedBuildInputs = [ variantslib ppxlib ]; + propagatedBuildInputs = [ + variantslib + ppxlib + ]; }; pythonlib = janePackage { @@ -970,7 +1388,20 @@ with self; version = "0.16"; hash = "sha256-HrsdtwPSDSaMB9CDIR9P5iaAmLihUrReuNAPIYa+s3Y="; meta.description = "A library to help writing wrappers around ocaml code for python"; - propagatedBuildInputs = [ base core expect_test_helpers_core ppx_compare ppx_expect ppx_here ppx_let ppx_python ppx_string stdio typerep pyml ]; + propagatedBuildInputs = [ + base + core + expect_test_helpers_core + ppx_compare + ppx_expect + ppx_here + ppx_let + ppx_python + ppx_string + stdio + typerep + pyml + ]; meta.broken = lib.versionAtLeast ocaml.version "4.14"; }; @@ -978,7 +1409,11 @@ with self; pname = "profunctor"; hash = "sha256-CFHMtCuBnrlr+B2cdJm2Tamt0A/e+f3SnjEavvE31xQ="; meta.description = "A library providing a signature for simple profunctors and traversal of a record"; - propagatedBuildInputs = [ base ppx_jane record_builder ]; + propagatedBuildInputs = [ + base + ppx_jane + record_builder + ]; }; protocol_version_header = janePackage { @@ -992,7 +1427,11 @@ with self; pname = "re2"; hash = "sha256-ZRJ7ooXtatEEh0sPL8M9OZ+6s7xNdTuw0Ot6txiG16I="; meta.description = "OCaml bindings for RE2, Google's regular expression library"; - propagatedBuildInputs = [ core_kernel jane_rope regex_parser_intf ]; + propagatedBuildInputs = [ + core_kernel + jane_rope + regex_parser_intf + ]; prePatch = '' substituteInPlace src/re2_c/dune --replace 'CXX=g++' 'CXX=c++' substituteInPlace src/dune --replace '(cxx_flags (:standard \ -pedantic) (-I re2_c/libre2))' '(cxx_flags (:standard \ -pedantic) (-I re2_c/libre2) (-x c++))' @@ -1004,21 +1443,33 @@ with self; version = "0.14.0"; hash = "sha256-gyet2Pzn7ZIqQ+UP2J51pRmwaESY2LSGTqCMZZwDTE4="; meta.description = "Re2_stable adds an incomplete but stable serialization of Re2"; - propagatedBuildInputs = [ core re2 ]; + propagatedBuildInputs = [ + core + re2 + ]; }; record_builder = janePackage { pname = "record_builder"; hash = "sha256-46zGgN9RlDjoSbi8RimuQVrMhy65Gpic0YPZpHOeoo0="; meta.description = "A library which provides traversal of records with an applicative"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; }; redis-async = janePackage { pname = "redis-async"; hash = "sha256-5msIS2m8nkaprR8NEBfKFWZBWaDJiUtjHbfPelg9/os="; meta.description = "Redis client for Async applications"; - propagatedBuildInputs = [ async bignum core core_kernel ppx_jane ]; + propagatedBuildInputs = [ + async + bignum + core + core_kernel + ppx_jane + ]; }; regex_parser_intf = janePackage { @@ -1039,7 +1490,11 @@ with self; pname = "semantic_version"; hash = "sha256-KJanaDUW56ndvnTlnPeQgh0C7zsRqXJ328gcEiVDrmc="; meta.description = "Semantic versioning"; - propagatedBuildInputs = [ core ppx_jane re ]; + propagatedBuildInputs = [ + core + ppx_jane + re + ]; }; sexp = janePackage { @@ -1063,7 +1518,16 @@ with self; sexp_grammar = janePackage { pname = "sexp_grammar"; hash = "sha256-Y/abRingL4+3qvaKgW9jH46E9uq7jYE2+kgr8ERKqfI="; - propagatedBuildInputs = [ core ppx_bin_prot ppx_compare ppx_hash ppx_let ppx_sexp_conv ppx_sexp_message zarith ]; + propagatedBuildInputs = [ + core + ppx_bin_prot + ppx_compare + ppx_hash + ppx_let + ppx_sexp_conv + ppx_sexp_message + zarith + ]; meta.description = "Helpers for manipulating [Sexplib.Sexp_grammar] values"; }; @@ -1077,7 +1541,10 @@ with self; sexp_macro = janePackage { pname = "sexp_macro"; hash = "sha256-x9WsFFrV7wUqgPUw8KkfyzOxLrS5h5++OSK8QljeQqg="; - propagatedBuildInputs = [ async sexplib ]; + propagatedBuildInputs = [ + async + sexplib + ]; meta.description = "Sexp macros"; }; @@ -1085,13 +1552,20 @@ with self; pname = "sexp_pretty"; hash = "sha256-tcWdYZ717LkGowRSRoEcUNY7VCMX64uhCaY3bXhWxKM="; meta.description = "S-expression pretty-printer"; - propagatedBuildInputs = [ ppx_base re sexplib ]; + propagatedBuildInputs = [ + ppx_base + re + sexplib + ]; }; sexp_select = janePackage { pname = "sexp_select"; hash = "sha256-HEzZowojeK9yDOoTY/l01fYLUdolzQGlMO9u3phV8so="; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; meta.description = "A library to use CSS-style selectors to traverse sexp trees"; }; @@ -1106,7 +1580,10 @@ with self; pname = "sexplib"; hash = "sha256-6MwggpjHo4FmKF88fP56LN9OHi2uIJc13TvKx4T7gEI="; meta.description = "Library for serializing OCaml values to and from S-expressions"; - propagatedBuildInputs = [ num parsexp ]; + propagatedBuildInputs = [ + num + parsexp + ]; }; shell = janePackage { @@ -1121,7 +1598,10 @@ with self; shexp = janePackage { pname = "shexp"; hash = "sha256-npIcrxMOcIgsecdUEx5XHYp0KVrXiMzMLi8jskAp4vo="; - propagatedBuildInputs = [ posixat spawn ]; + propagatedBuildInputs = [ + posixat + spawn + ]; meta.description = "Process library and s-expression based shell"; }; @@ -1145,7 +1625,12 @@ with self; pname = "splittable_random"; hash = "sha256-wMmLuzhKmnS2iTYVTPUx5Rv2LhL/ygmWmb9t2pUjz+E="; meta.description = "PRNG that can be split into independent streams"; - propagatedBuildInputs = [ base ppx_assert ppx_bench ppx_sexp_message ]; + propagatedBuildInputs = [ + base + ppx_assert + ppx_bench + ppx_sexp_message + ]; }; stdio = janePackage { @@ -1159,7 +1644,10 @@ with self; pname = "stored_reversed"; hash = "sha256-ef11f0qifEvxKChM49Hnfk6J6hL+b0tMlm0iDLd5Y0Q="; meta.description = "A library for representing a list temporarily stored in reverse order"; - propagatedBuildInputs = [ core ppx_jane ]; + propagatedBuildInputs = [ + core + ppx_jane + ]; }; streamable = janePackage { @@ -1167,36 +1655,61 @@ with self; pname = "streamable"; hash = "sha256-3djrUW2tPKaEmoOIpdjN6ok7U9i07yreqbi1kP+6pnY="; meta.description = "A collection of types suitable for incremental serialization"; - propagatedBuildInputs = [ async_kernel async_rpc_kernel base core core_kernel ppx_jane ppxlib ]; + propagatedBuildInputs = [ + async_kernel + async_rpc_kernel + base + core + core_kernel + ppx_jane + ppxlib + ]; }; textutils = janePackage { pname = "textutils"; hash = "sha256-2qy99MUMpkuNCvCYlk36k4kN6cPjrEILbwEUv4DyNYw="; meta.description = "Text output utilities"; - propagatedBuildInputs = [ core_unix textutils_kernel ]; + propagatedBuildInputs = [ + core_unix + textutils_kernel + ]; }; textutils_kernel = janePackage { pname = "textutils_kernel"; hash = "sha256-DiXemANj5ONmvMzp+tly3AJud5u9i7HdaHmn8aVQS48="; meta.description = "Text output utilities"; - propagatedBuildInputs = [ core ppx_jane uutf ]; + propagatedBuildInputs = [ + core + ppx_jane + uutf + ]; }; tilde_f = janePackage { pname = "tilde_f"; hash = "sha256-qLjM9liJfMIh2fqRPBdnmtUf4xhzk2MY8dFNdON3Aew="; meta.description = "Provides a let-syntax for continuation-passing style"; - propagatedBuildInputs = [ base ppx_jane ]; + propagatedBuildInputs = [ + base + ppx_jane + ]; }; time_now = janePackage { pname = "time_now"; hash = "sha256-DjSrx/HgwCYS0Xzm2gFvWUVLD7a1KuFVIyVrJjBi8Tc="; meta.description = "Reports the current time"; - buildInputs = [ jst-config ppx_optcomp ]; - propagatedBuildInputs = [ jane-street-headers base ppx_base ]; + buildInputs = [ + jst-config + ppx_optcomp + ]; + propagatedBuildInputs = [ + jane-street-headers + base + ppx_base + ]; }; timezone = janePackage { @@ -1210,7 +1723,10 @@ with self; pname = "topological_sort"; hash = "sha256-um5++60mR++iHAruKqoQfd4EbQ1kb3L+cPOWhs9sIHI="; meta.description = "Topological sort algorithm"; - propagatedBuildInputs = [ ppx_jane stdio ]; + propagatedBuildInputs = [ + ppx_jane + stdio + ]; }; typerep = janePackage { @@ -1224,7 +1740,10 @@ with self; pname = "username_kernel"; hash = "sha256-UvFL/M9OsD+SOs9MYMKiKzZilLJHzriop6SPA4bOhZQ="; meta.description = "An identifier for a user"; - propagatedBuildInputs = [ core ppx_jane ]; + propagatedBuildInputs = [ + core + ppx_jane + ]; }; variantslib = janePackage { @@ -1238,7 +1757,15 @@ with self; pname = "vcaml"; hash = "sha256-pmEKi24+22T76SzI3RpBmQF7ZrQwlngrpFYLoBdLwe0="; meta.description = "OCaml bindings for the Neovim API"; - propagatedBuildInputs = [ angstrom-async async_extra expect_test_helpers_async faraday jsonaf man_in_the_middle_debugger semantic_version ]; + propagatedBuildInputs = [ + angstrom-async + async_extra + expect_test_helpers_async + faraday + jsonaf + man_in_the_middle_debugger + semantic_version + ]; patches = [ ./vcaml.patch ]; }; @@ -1247,7 +1774,16 @@ with self; hash = "sha256-nXW9cDHQVugriR0+GkayuV4S3HKothQAoNJef02iALM="; meta.description = "OCaml bindings for the virtual-dom library"; buildInputs = [ js_of_ocaml-ppx ]; - propagatedBuildInputs = [ base64 core_kernel gen_js_api js_of_ocaml js_of_ocaml_patches lambdasoup tyxml uri ]; + propagatedBuildInputs = [ + base64 + core_kernel + gen_js_api + js_of_ocaml + js_of_ocaml_patches + lambdasoup + tyxml + uri + ]; }; zarith_stubs_js = janePackage { @@ -1261,7 +1797,11 @@ with self; hash = "sha256-QcYqlOpCAr0owmO6sLDJhki8lUnNvtkaxldKb5I5AF0="; meta.description = "OCaml bindings to Zstandard"; buildInputs = [ ppx_jane ]; - propagatedBuildInputs = [ core_kernel ctypes zstd ]; + propagatedBuildInputs = [ + core_kernel + ctypes + zstd + ]; }; } diff --git a/pkgs/development/ocaml-modules/janestreet/janePackage_0_12.nix b/pkgs/development/ocaml-modules/janestreet/janePackage_0_12.nix index bbfd492cb64f87..67435557a36d76 100644 --- a/pkgs/development/ocaml-modules/janestreet/janePackage_0_12.nix +++ b/pkgs/development/ocaml-modules/janestreet/janePackage_0_12.nix @@ -1,21 +1,35 @@ -{ lib, fetchFromGitHub, buildDunePackage, defaultVersion ? "0.12.0" }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + defaultVersion ? "0.12.0", +}: -{ pname, version ? defaultVersion, duneVersion ? "3", hash, ...}@args: +{ + pname, + version ? defaultVersion, + duneVersion ? "3", + hash, + ... +}@args: -buildDunePackage (args // { - inherit version duneVersion; +buildDunePackage ( + args + // { + inherit version duneVersion; - minimalOCamlVersion = "4.07"; + minimalOCamlVersion = "4.07"; - src = fetchFromGitHub { - owner = "janestreet"; - repo = pname; - rev = "v${version}"; - sha256 = hash; - }; + src = fetchFromGitHub { + owner = "janestreet"; + repo = pname; + rev = "v${version}"; + sha256 = hash; + }; - meta = { - license = lib.licenses.mit; - homepage = "https://github.com/janestreet/${pname}"; - } // args.meta; -}) + meta = { + license = lib.licenses.mit; + homepage = "https://github.com/janestreet/${pname}"; + } // args.meta; + } +) diff --git a/pkgs/development/ocaml-modules/janestreet/janePackage_0_14.nix b/pkgs/development/ocaml-modules/janestreet/janePackage_0_14.nix index 59fd0e3e981890..1a7e8c8f6f6087 100644 --- a/pkgs/development/ocaml-modules/janestreet/janePackage_0_14.nix +++ b/pkgs/development/ocaml-modules/janestreet/janePackage_0_14.nix @@ -1,30 +1,40 @@ -{ lib, fetchFromGitHub, buildDunePackage, defaultVersion ? "0.14.0" }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + defaultVersion ? "0.14.0", +}: -{ pname -, version ? defaultVersion -, hash -, minimalOCamlVersion ? "4.08" -, doCheck ? true -, buildInputs ? [] -, ...}@args: +{ + pname, + version ? defaultVersion, + hash, + minimalOCamlVersion ? "4.08", + doCheck ? true, + buildInputs ? [ ], + ... +}@args: -buildDunePackage (args // { - duneVersion = "3"; - inherit version buildInputs; +buildDunePackage ( + args + // { + duneVersion = "3"; + inherit version buildInputs; - inherit minimalOCamlVersion; + inherit minimalOCamlVersion; - src = fetchFromGitHub { - owner = "janestreet"; - repo = pname; - rev = "v${version}"; - sha256 = hash; - }; + src = fetchFromGitHub { + owner = "janestreet"; + repo = pname; + rev = "v${version}"; + sha256 = hash; + }; - inherit doCheck; + inherit doCheck; - meta = { - license = lib.licenses.mit; - homepage = "https://github.com/janestreet/${pname}"; - } // args.meta; -}) + meta = { + license = lib.licenses.mit; + homepage = "https://github.com/janestreet/${pname}"; + } // args.meta; + } +) diff --git a/pkgs/development/ocaml-modules/janestreet/janePackage_0_15.nix b/pkgs/development/ocaml-modules/janestreet/janePackage_0_15.nix index ca590e2f1a7293..73812e186bd8f4 100644 --- a/pkgs/development/ocaml-modules/janestreet/janePackage_0_15.nix +++ b/pkgs/development/ocaml-modules/janestreet/janePackage_0_15.nix @@ -1,30 +1,40 @@ -{ lib, fetchFromGitHub, buildDunePackage, defaultVersion ? "0.15.0" }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + defaultVersion ? "0.15.0", +}: -{ pname -, version ? defaultVersion -, hash -, minimalOCamlVersion ? "4.11" -, doCheck ? true -, buildInputs ? [] -, ...}@args: +{ + pname, + version ? defaultVersion, + hash, + minimalOCamlVersion ? "4.11", + doCheck ? true, + buildInputs ? [ ], + ... +}@args: -buildDunePackage (args // { - duneVersion = "3"; - inherit version buildInputs; +buildDunePackage ( + args + // { + duneVersion = "3"; + inherit version buildInputs; - inherit minimalOCamlVersion; + inherit minimalOCamlVersion; - src = fetchFromGitHub { - owner = "janestreet"; - repo = pname; - rev = "v${version}"; - sha256 = hash; - }; + src = fetchFromGitHub { + owner = "janestreet"; + repo = pname; + rev = "v${version}"; + sha256 = hash; + }; - inherit doCheck; + inherit doCheck; - meta = { - license = lib.licenses.mit; - homepage = "https://github.com/janestreet/${pname}"; - } // args.meta; -}) + meta = { + license = lib.licenses.mit; + homepage = "https://github.com/janestreet/${pname}"; + } // args.meta; + } +) diff --git a/pkgs/development/ocaml-modules/janestreet/janePackage_0_16.nix b/pkgs/development/ocaml-modules/janestreet/janePackage_0_16.nix index c1b2ed2a913945..a08ff1e3b9b67e 100644 --- a/pkgs/development/ocaml-modules/janestreet/janePackage_0_16.nix +++ b/pkgs/development/ocaml-modules/janestreet/janePackage_0_16.nix @@ -1,30 +1,40 @@ -{ lib, fetchFromGitHub, buildDunePackage, defaultVersion ? "0.16.0" }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + defaultVersion ? "0.16.0", +}: -{ pname -, version ? defaultVersion -, hash -, minimalOCamlVersion ? "4.14" -, doCheck ? true -, buildInputs ? [] -, ...}@args: +{ + pname, + version ? defaultVersion, + hash, + minimalOCamlVersion ? "4.14", + doCheck ? true, + buildInputs ? [ ], + ... +}@args: -buildDunePackage (args // { - duneVersion = "3"; - inherit version buildInputs; +buildDunePackage ( + args + // { + duneVersion = "3"; + inherit version buildInputs; - inherit minimalOCamlVersion; + inherit minimalOCamlVersion; - src = fetchFromGitHub { - owner = "janestreet"; - repo = pname; - rev = "v${version}"; - sha256 = hash; - }; + src = fetchFromGitHub { + owner = "janestreet"; + repo = pname; + rev = "v${version}"; + sha256 = hash; + }; - inherit doCheck; + inherit doCheck; - meta = { - license = lib.licenses.mit; - homepage = "https://github.com/janestreet/${pname}"; - } // args.meta; -}) + meta = { + license = lib.licenses.mit; + homepage = "https://github.com/janestreet/${pname}"; + } // args.meta; + } +) diff --git a/pkgs/development/ocaml-modules/javalib/default.nix b/pkgs/development/ocaml-modules/javalib/default.nix index e6685ec0b5589e..43a6424f7c0458 100644 --- a/pkgs/development/ocaml-modules/javalib/default.nix +++ b/pkgs/development/ocaml-modules/javalib/default.nix @@ -1,47 +1,59 @@ -{ lib -, stdenv -, fetchFromGitHub -, which -, ocaml -, findlib -, camlzip -, extlib +{ + lib, + stdenv, + fetchFromGitHub, + which, + ocaml, + findlib, + camlzip, + extlib, }: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.08") "javalib is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-javalib"; - version = "3.2.2"; - - src = fetchFromGitHub { - owner = "javalib-team"; - repo = "javalib"; - rev = version; - hash = "sha256-XaI7GTU/O5UEWuYX4yqaIRmEoH7FuvCg/+gtKbE/P1s="; - }; - - nativeBuildInputs = [ which ocaml findlib ]; - - strictDeps = true; - - patches = [ ./configure.sh.patch ./Makefile.config.example.patch ]; - - createFindlibDestdir = true; - - configureScript = "./configure.sh"; - dontAddPrefix = "true"; - dontAddStaticConfigureFlags = true; - configurePlatforms = [ ]; - - propagatedBuildInputs = [ camlzip extlib ]; - - meta = with lib; { - description = "Library that parses Java .class files into OCaml data structures"; - homepage = "https://javalib-team.github.io/javalib/"; - license = licenses.lgpl3; - maintainers = [ maintainers.vbgl ]; - inherit (ocaml.meta) platforms; - }; -} + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-javalib"; + version = "3.2.2"; + + src = fetchFromGitHub { + owner = "javalib-team"; + repo = "javalib"; + rev = version; + hash = "sha256-XaI7GTU/O5UEWuYX4yqaIRmEoH7FuvCg/+gtKbE/P1s="; + }; + + nativeBuildInputs = [ + which + ocaml + findlib + ]; + + strictDeps = true; + + patches = [ + ./configure.sh.patch + ./Makefile.config.example.patch + ]; + + createFindlibDestdir = true; + + configureScript = "./configure.sh"; + dontAddPrefix = "true"; + dontAddStaticConfigureFlags = true; + configurePlatforms = [ ]; + + propagatedBuildInputs = [ + camlzip + extlib + ]; + + meta = with lib; { + description = "Library that parses Java .class files into OCaml data structures"; + homepage = "https://javalib-team.github.io/javalib/"; + license = licenses.lgpl3; + maintainers = [ maintainers.vbgl ]; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/jingoo/default.nix b/pkgs/development/ocaml-modules/jingoo/default.nix index 595a5cbb18a766..41c6e667bea483 100644 --- a/pkgs/development/ocaml-modules/jingoo/default.nix +++ b/pkgs/development/ocaml-modules/jingoo/default.nix @@ -1,5 +1,15 @@ -{ lib, buildDunePackage, fetchFromGitHub, ocaml -, menhir, ppxlib, ppx_deriving, re, uutf, uucp, ounit2 +{ + lib, + buildDunePackage, + fetchFromGitHub, + ocaml, + menhir, + ppxlib, + ppx_deriving, + re, + uutf, + uucp, + ounit2, }: buildDunePackage rec { @@ -16,11 +26,16 @@ buildDunePackage rec { }; nativeBuildInputs = [ menhir ]; - propagatedBuildInputs = [ ppxlib ppx_deriving re uutf uucp ]; + propagatedBuildInputs = [ + ppxlib + ppx_deriving + re + uutf + uucp + ]; checkInputs = [ ounit2 ]; doCheck = lib.versionAtLeast ocaml.version "4.08"; - meta = with lib; { homepage = "https://github.com/tategakibunko/jingoo"; description = "OCaml template engine almost compatible with jinja2"; diff --git a/pkgs/development/ocaml-modules/json-data-encoding/bson.nix b/pkgs/development/ocaml-modules/json-data-encoding/bson.nix index 4430746a7adda4..28a6ddb9ae91ea 100644 --- a/pkgs/development/ocaml-modules/json-data-encoding/bson.nix +++ b/pkgs/development/ocaml-modules/json-data-encoding/bson.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, json-data-encoding, ocplib-endian, crowbar, alcotest }: +{ + buildDunePackage, + json-data-encoding, + ocplib-endian, + crowbar, + alcotest, +}: buildDunePackage { pname = "json-data-encoding-bson"; diff --git a/pkgs/development/ocaml-modules/json-data-encoding/default.nix b/pkgs/development/ocaml-modules/json-data-encoding/default.nix index 5bb3f7701bba61..3c21d451d81b7a 100644 --- a/pkgs/development/ocaml-modules/json-data-encoding/default.nix +++ b/pkgs/development/ocaml-modules/json-data-encoding/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitLab, buildDunePackage, hex, uri }: +{ + lib, + fetchFromGitLab, + buildDunePackage, + hex, + uri, +}: buildDunePackage rec { pname = "json-data-encoding"; diff --git a/pkgs/development/ocaml-modules/jsonm/default.nix b/pkgs/development/ocaml-modules/jsonm/default.nix index ada427aef8668c..dc84d57ea402a8 100644 --- a/pkgs/development/ocaml-modules/jsonm/default.nix +++ b/pkgs/development/ocaml-modules/jsonm/default.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchurl, ocaml, findlib, ocamlbuild, topkg, uutf }: +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + uutf, +}: stdenv.mkDerivation rec { pname = "ocaml${ocaml.version}-jsonm"; @@ -9,7 +18,12 @@ stdenv.mkDerivation rec { hash = "sha256-6ikjn+tAUyAd8+Hm0nws4SOIKsRljhyL6plYvhGKe9Y="; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; buildInputs = [ topkg ]; propagatedBuildInputs = [ uutf ]; diff --git a/pkgs/development/ocaml-modules/junit/alcotest.nix b/pkgs/development/ocaml-modules/junit/alcotest.nix index 6bcdbab3349808..edec978cbe8e32 100644 --- a/pkgs/development/ocaml-modules/junit/alcotest.nix +++ b/pkgs/development/ocaml-modules/junit/alcotest.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, junit, alcotest }: +{ + buildDunePackage, + junit, + alcotest, +}: buildDunePackage ({ pname = "junit_alcotest"; diff --git a/pkgs/development/ocaml-modules/junit/default.nix b/pkgs/development/ocaml-modules/junit/default.nix index b9ab63ac84c5fc..e615c40d9a58ba 100644 --- a/pkgs/development/ocaml-modules/junit/default.nix +++ b/pkgs/development/ocaml-modules/junit/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, buildDunePackage, ptime, tyxml }: +{ + lib, + fetchurl, + buildDunePackage, + ptime, + tyxml, +}: buildDunePackage (rec { pname = "junit"; diff --git a/pkgs/development/ocaml-modules/junit/ounit.nix b/pkgs/development/ocaml-modules/junit/ounit.nix index c7d53ecc4f5085..2a0c47d01a5175 100644 --- a/pkgs/development/ocaml-modules/junit/ounit.nix +++ b/pkgs/development/ocaml-modules/junit/ounit.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, junit, ounit }: +{ + buildDunePackage, + junit, + ounit, +}: buildDunePackage ({ pname = "junit_ounit"; diff --git a/pkgs/development/ocaml-modules/jwto/default.nix b/pkgs/development/ocaml-modules/jwto/default.nix index 745f86dff52b06..6c73b06213ac83 100644 --- a/pkgs/development/ocaml-modules/jwto/default.nix +++ b/pkgs/development/ocaml-modules/jwto/default.nix @@ -1,6 +1,16 @@ -{ lib, buildDunePackage, fetchFromGitHub, alcotest, digestif, fmt, yojson -, ppxlib -, base64, re, ppx_deriving }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + alcotest, + digestif, + fmt, + yojson, + ppxlib, + base64, + re, + ppx_deriving, +}: buildDunePackage rec { pname = "jwto"; @@ -19,8 +29,14 @@ buildDunePackage rec { buildInputs = [ ppxlib ]; - propagatedBuildInputs = - [ digestif fmt yojson base64 re ppx_deriving ]; + propagatedBuildInputs = [ + digestif + fmt + yojson + base64 + re + ppx_deriving + ]; checkInputs = [ alcotest ]; @@ -30,6 +46,9 @@ buildDunePackage rec { homepage = "https://github.com/sporto/jwto"; description = "JSON Web Tokens (JWT) for OCaml"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ Zimmi48 jtcoolen ]; + maintainers = with lib.maintainers; [ + Zimmi48 + jtcoolen + ]; }; } diff --git a/pkgs/development/ocaml-modules/kafka/default.nix b/pkgs/development/ocaml-modules/kafka/default.nix index 28c380a4616d7b..383e4db25dae20 100644 --- a/pkgs/development/ocaml-modules/kafka/default.nix +++ b/pkgs/development/ocaml-modules/kafka/default.nix @@ -1,5 +1,10 @@ -{ lib, fetchurl, buildDunePackage -, rdkafka, zlib }: +{ + lib, + fetchurl, + buildDunePackage, + rdkafka, + zlib, +}: buildDunePackage rec { pname = "kafka"; @@ -10,13 +15,15 @@ buildDunePackage rec { sha256 = "0m9212yap0a00hd0f61i4y4fna3141p77qj3mm7jl1h4q60jdhvy"; }; - propagatedBuildInputs = [ rdkafka zlib ]; + propagatedBuildInputs = [ + rdkafka + zlib + ]; meta = with lib; { homepage = "https://github.com/didier-wenzek/ocaml-kafka"; description = "OCaml bindings for Kafka"; - license = licenses.mit; + license = licenses.mit; maintainers = [ maintainers.vbgl ]; }; } - diff --git a/pkgs/development/ocaml-modules/kafka/lwt.nix b/pkgs/development/ocaml-modules/kafka/lwt.nix index da931d6e8bffd8..b389de60b34c08 100644 --- a/pkgs/development/ocaml-modules/kafka/lwt.nix +++ b/pkgs/development/ocaml-modules/kafka/lwt.nix @@ -1,24 +1,29 @@ -{ buildDunePackage -, ocaml -, lib -, kafka -, lwt -, cmdliner +{ + buildDunePackage, + ocaml, + lib, + kafka, + lwt, + cmdliner, }: lib.throwIf (lib.versionAtLeast ocaml.version "5.0") "kafka_lwt is not available for OCaml ${ocaml.version}" -buildDunePackage rec { - pname = "kafka_lwt"; + buildDunePackage + rec { + pname = "kafka_lwt"; - inherit (kafka) version src; + inherit (kafka) version src; - buildInputs = [ cmdliner ]; + buildInputs = [ cmdliner ]; - propagatedBuildInputs = [ kafka lwt ]; + propagatedBuildInputs = [ + kafka + lwt + ]; - meta = kafka.meta // { - description = "OCaml bindings for Kafka, Lwt bindings"; - }; -} + meta = kafka.meta // { + description = "OCaml bindings for Kafka, Lwt bindings"; + }; + } diff --git a/pkgs/development/ocaml-modules/kcas/default.nix b/pkgs/development/ocaml-modules/kcas/default.nix index 2d840b9a750bbc..7f7a12258bafcf 100644 --- a/pkgs/development/ocaml-modules/kcas/default.nix +++ b/pkgs/development/ocaml-modules/kcas/default.nix @@ -1,6 +1,10 @@ -{ lib, buildDunePackage, fetchurl -, domain-local-await, domain-local-timeout -, alcotest +{ + lib, + buildDunePackage, + fetchurl, + domain-local-await, + domain-local-timeout, + alcotest, }: buildDunePackage rec { @@ -12,7 +16,10 @@ buildDunePackage rec { hash = "sha256-u3Z8uAvITRUhOcB2EUYjWtpxIFJMvm2O/kyNr/AELWI="; }; - propagatedBuildInputs = [ domain-local-await domain-local-timeout ]; + propagatedBuildInputs = [ + domain-local-await + domain-local-timeout + ]; doCheck = true; checkInputs = [ alcotest ]; diff --git a/pkgs/development/ocaml-modules/kdf/default.nix b/pkgs/development/ocaml-modules/kdf/default.nix index 8bd7f3bf306f78..cb5c091e3d77d3 100644 --- a/pkgs/development/ocaml-modules/kdf/default.nix +++ b/pkgs/development/ocaml-modules/kdf/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildDunePackage -, fetchurl -, digestif -, mirage-crypto -, alcotest -, ohex +{ + lib, + buildDunePackage, + fetchurl, + digestif, + mirage-crypto, + alcotest, + ohex, }: buildDunePackage rec { @@ -16,9 +17,15 @@ buildDunePackage rec { hash = "sha256-0WFYKw7+ZtlY3WuMnCEGjp9kVM4hg3fWz4eCPexi4M4="; }; - propagatedBuildInputs = [ digestif mirage-crypto ]; + propagatedBuildInputs = [ + digestif + mirage-crypto + ]; - checkInputs = [ alcotest ohex ]; + checkInputs = [ + alcotest + ohex + ]; doCheck = true; meta = { diff --git a/pkgs/development/ocaml-modules/ke/default.nix b/pkgs/development/ocaml-modules/ke/default.nix index db5bcd5e80a365..14b984f4b811d6 100644 --- a/pkgs/development/ocaml-modules/ke/default.nix +++ b/pkgs/development/ocaml-modules/ke/default.nix @@ -1,5 +1,10 @@ -{ lib, buildDunePackage, fetchurl, fmt -, alcotest, bigstringaf +{ + lib, + buildDunePackage, + fetchurl, + fmt, + alcotest, + bigstringaf, }: buildDunePackage rec { @@ -13,7 +18,10 @@ buildDunePackage rec { propagatedBuildInputs = [ fmt ]; - checkInputs = [ alcotest bigstringaf ]; + checkInputs = [ + alcotest + bigstringaf + ]; doCheck = true; minimalOCamlVersion = "4.08"; diff --git a/pkgs/development/ocaml-modules/kicadsch/default.nix b/pkgs/development/ocaml-modules/kicadsch/default.nix index 69b4aae3eafb78..dde07551e50cba 100644 --- a/pkgs/development/ocaml-modules/kicadsch/default.nix +++ b/pkgs/development/ocaml-modules/kicadsch/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildDunePackage -, fetchurl +{ + lib, + buildDunePackage, + fetchurl, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/kqueue/default.nix b/pkgs/development/ocaml-modules/kqueue/default.nix index 2ea64493f948e0..07d4921b704caf 100644 --- a/pkgs/development/ocaml-modules/kqueue/default.nix +++ b/pkgs/development/ocaml-modules/kqueue/default.nix @@ -1,9 +1,10 @@ -{ buildDunePackage -, dune-configurator -, lib -, fetchurl -, ppx_expect -, ppx_optcomp +{ + buildDunePackage, + dune-configurator, + lib, + fetchurl, + ppx_expect, + ppx_optcomp, }: buildDunePackage rec { @@ -36,4 +37,3 @@ buildDunePackage rec { maintainers = with lib.maintainers; [ sixstring982 ]; }; } - diff --git a/pkgs/development/ocaml-modules/lablgl/default.nix b/pkgs/development/ocaml-modules/lablgl/default.nix index 64ace7c4496373..3736fc84a8d4db 100644 --- a/pkgs/development/ocaml-modules/lablgl/default.nix +++ b/pkgs/development/ocaml-modules/lablgl/default.nix @@ -1,58 +1,81 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, findlib, libGLU, libglut, camlp-streams } : +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, + libGLU, + libglut, + camlp-streams, +}: -if lib.versionOlder ocaml.version "4.06" -then throw "lablgl is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.06" then + throw "lablgl is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-lablgl"; - version = "1.07"; - - src = fetchFromGitHub { - owner = "garrigue"; - repo = "lablgl"; - rev = "v${version}"; - hash = "sha256-GiQKHMn5zHyvDrA2ve12X5YTm3/RZp8tukIqifgVaW4="; - }; - - strictDeps = true; - - nativeBuildInputs = [ ocaml findlib ]; - buildInputs = [ libglut camlp-streams ]; - propagatedBuildInputs = [ - libGLU - ]; - - patches = [ ./META.patch ]; - - preConfigure = '' - mkdir -p $out/bin - mkdir -p $out/lib/ocaml/${ocaml.version}/site-lib/stublibs - cp \ - Makefile.config.${if stdenv.hostPlatform.isDarwin then "osx" else "ex"} \ - Makefile.config - ''; - - makeFlags = [ - "BINDIR=${placeholder "out"}/bin/" - "INSTALLDIR=${placeholder "out"}/lib/ocaml/${ocaml.version}/site-lib/lablgl/" - "DLLDIR=${placeholder "out"}/lib/ocaml/${ocaml.version}/site-lib/stublibs/" - "XINCLUDES=" - "TKINCLUDES=" - "TKLIBS=" - ]; - - buildFlags = [ "lib" "libopt" "glut" "glutopt" ]; - - postInstall = '' - cp ./META $out/lib/ocaml/${ocaml.version}/site-lib/lablgl - ''; - - meta = with lib; { - description = "OpenGL bindings for ocaml"; - homepage = "http://wwwfun.kurims.kyoto-u.ac.jp/soft/lsl/lablgl.html"; - license = licenses.gpl2; - maintainers = with maintainers; [ pSub vbgl ]; - mainProgram = "lablglut"; - }; -} + stdenv.mkDerivation rec { + pname = "ocaml${ocaml.version}-lablgl"; + version = "1.07"; + + src = fetchFromGitHub { + owner = "garrigue"; + repo = "lablgl"; + rev = "v${version}"; + hash = "sha256-GiQKHMn5zHyvDrA2ve12X5YTm3/RZp8tukIqifgVaW4="; + }; + + strictDeps = true; + + nativeBuildInputs = [ + ocaml + findlib + ]; + buildInputs = [ + libglut + camlp-streams + ]; + propagatedBuildInputs = [ + libGLU + ]; + + patches = [ ./META.patch ]; + + preConfigure = '' + mkdir -p $out/bin + mkdir -p $out/lib/ocaml/${ocaml.version}/site-lib/stublibs + cp \ + Makefile.config.${if stdenv.hostPlatform.isDarwin then "osx" else "ex"} \ + Makefile.config + ''; + + makeFlags = [ + "BINDIR=${placeholder "out"}/bin/" + "INSTALLDIR=${placeholder "out"}/lib/ocaml/${ocaml.version}/site-lib/lablgl/" + "DLLDIR=${placeholder "out"}/lib/ocaml/${ocaml.version}/site-lib/stublibs/" + "XINCLUDES=" + "TKINCLUDES=" + "TKLIBS=" + ]; + + buildFlags = [ + "lib" + "libopt" + "glut" + "glutopt" + ]; + + postInstall = '' + cp ./META $out/lib/ocaml/${ocaml.version}/site-lib/lablgl + ''; + + meta = with lib; { + description = "OpenGL bindings for ocaml"; + homepage = "http://wwwfun.kurims.kyoto-u.ac.jp/soft/lsl/lablgl.html"; + license = licenses.gpl2; + maintainers = with maintainers; [ + pSub + vbgl + ]; + mainProgram = "lablglut"; + }; + } diff --git a/pkgs/development/ocaml-modules/lablgtk-extras/1.4.nix b/pkgs/development/ocaml-modules/lablgtk-extras/1.4.nix index 6b8ee76985c796..9fa04045bbcd11 100644 --- a/pkgs/development/ocaml-modules/lablgtk-extras/1.4.nix +++ b/pkgs/development/ocaml-modules/lablgtk-extras/1.4.nix @@ -1,4 +1,14 @@ -{ stdenv, lib, fetchurl, ocaml, findlib, camlp4, config-file, lablgtk, xmlm }: +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + camlp4, + config-file, + lablgtk, + xmlm, +}: stdenv.mkDerivation rec { pname = "ocaml-lablgtk-extras"; @@ -11,8 +21,16 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ ocaml findlib camlp4 ]; - propagatedBuildInputs = [ config-file lablgtk xmlm ]; + nativeBuildInputs = [ + ocaml + findlib + camlp4 + ]; + propagatedBuildInputs = [ + config-file + lablgtk + xmlm + ]; createFindlibDestdir = true; diff --git a/pkgs/development/ocaml-modules/lablgtk-extras/default.nix b/pkgs/development/ocaml-modules/lablgtk-extras/default.nix index bca24a9240abf2..469c3750cafc52 100644 --- a/pkgs/development/ocaml-modules/lablgtk-extras/default.nix +++ b/pkgs/development/ocaml-modules/lablgtk-extras/default.nix @@ -1,33 +1,50 @@ -{ stdenv, lib, fetchFromGitLab, ocaml, findlib, camlp4, config-file, lablgtk, xmlm }: +{ + stdenv, + lib, + fetchFromGitLab, + ocaml, + findlib, + camlp4, + config-file, + lablgtk, + xmlm, +}: -if lib.versionOlder ocaml.version "4.02" -|| lib.versionAtLeast ocaml.version "4.13" -then throw "lablgtk-extras is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.02" || lib.versionAtLeast ocaml.version "4.13" then + throw "lablgtk-extras is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - version = "1.6"; - pname = "ocaml${ocaml.version}-lablgtk-extras"; - src = fetchFromGitLab { - domain = "framagit.org"; - owner = "zoggy"; - repo = "lablgtk-extras"; - rev = "release-${version}"; - sha256 = "1bbdp5j18s582mmyd7qiaq1p08g2ag4gl7x65pmzahbhg719hjda"; - }; + stdenv.mkDerivation rec { + version = "1.6"; + pname = "ocaml${ocaml.version}-lablgtk-extras"; + src = fetchFromGitLab { + domain = "framagit.org"; + owner = "zoggy"; + repo = "lablgtk-extras"; + rev = "release-${version}"; + sha256 = "1bbdp5j18s582mmyd7qiaq1p08g2ag4gl7x65pmzahbhg719hjda"; + }; - strictDeps = true; + strictDeps = true; - nativeBuildInputs = [ ocaml findlib camlp4 ]; - propagatedBuildInputs = [ config-file lablgtk xmlm ]; + nativeBuildInputs = [ + ocaml + findlib + camlp4 + ]; + propagatedBuildInputs = [ + config-file + lablgtk + xmlm + ]; - createFindlibDestdir = true; + createFindlibDestdir = true; - meta = { - inherit (ocaml.meta) platforms; - maintainers = with lib.maintainers; [ vbgl ]; - homepage = "https://framagit.org/zoggy/lablgtk-extras/"; - description = "Collection of libraries and modules useful when developing OCaml/LablGtk2 applications"; - license = lib.licenses.lgpl2Plus; - }; -} + meta = { + inherit (ocaml.meta) platforms; + maintainers = with lib.maintainers; [ vbgl ]; + homepage = "https://framagit.org/zoggy/lablgtk-extras/"; + description = "Collection of libraries and modules useful when developing OCaml/LablGtk2 applications"; + license = lib.licenses.lgpl2Plus; + }; + } diff --git a/pkgs/development/ocaml-modules/lablgtk/default.nix b/pkgs/development/ocaml-modules/lablgtk/default.nix index fc3aebd33d23c4..7d2a3601b4a53f 100644 --- a/pkgs/development/ocaml-modules/lablgtk/default.nix +++ b/pkgs/development/ocaml-modules/lablgtk/default.nix @@ -1,31 +1,50 @@ -{ lib, stdenv, fetchurl, fetchFromGitHub, ocaml, findlib, pkg-config, gtk2, libgnomecanvas, gtksourceview -, camlp-streams, gnumake42 +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + ocaml, + findlib, + pkg-config, + gtk2, + libgnomecanvas, + gtksourceview, + camlp-streams, + gnumake42, }: -let param = - let check = lib.versionAtLeast ocaml.version; in - if check "4.06" then rec { - version = "2.18.13"; - src = fetchFromGitHub { - owner = "garrigue"; - repo = "lablgtk"; - rev = version; - sha256 = "sha256-69Svno0qLaUifMscnVuPUJlCo9d8Lee+1qiYx34G3Po="; - }; - env = { }; - buildInputs = [ camlp-streams ]; - } else if check "3.12" then { - version = "2.18.5"; - src = fetchurl { - url = "https://forge.ocamlcore.org/frs/download.php/1627/lablgtk-2.18.5.tar.gz"; - sha256 = "0cyj6sfdvzx8hw7553lhgwc0krlgvlza0ph3dk9gsxy047dm3wib"; - }; - # Workaround build failure on -fno-common toolchains like upstream - # gcc-10. Otherwise build fails as: - # ld: ml_gtktree.o:(.bss+0x0): multiple definition of - # `ml_table_extension_events'; ml_gdkpixbuf.o:(.bss+0x0): first defined here - env.NIX_CFLAGS_COMPILE = "-fcommon"; - } else throw "lablgtk is not available for OCaml ${ocaml.version}"; +let + param = + let + check = lib.versionAtLeast ocaml.version; + in + if check "4.06" then + rec { + version = "2.18.13"; + src = fetchFromGitHub { + owner = "garrigue"; + repo = "lablgtk"; + rev = version; + sha256 = "sha256-69Svno0qLaUifMscnVuPUJlCo9d8Lee+1qiYx34G3Po="; + }; + env = { }; + buildInputs = [ camlp-streams ]; + } + else if check "3.12" then + { + version = "2.18.5"; + src = fetchurl { + url = "https://forge.ocamlcore.org/frs/download.php/1627/lablgtk-2.18.5.tar.gz"; + sha256 = "0cyj6sfdvzx8hw7553lhgwc0krlgvlza0ph3dk9gsxy047dm3wib"; + }; + # Workaround build failure on -fno-common toolchains like upstream + # gcc-10. Otherwise build fails as: + # ld: ml_gtktree.o:(.bss+0x0): multiple definition of + # `ml_table_extension_events'; ml_gdkpixbuf.o:(.bss+0x0): first defined here + env.NIX_CFLAGS_COMPILE = "-fcommon"; + } + else + throw "lablgtk is not available for OCaml ${ocaml.version}"; in stdenv.mkDerivation { @@ -33,9 +52,17 @@ stdenv.mkDerivation { inherit (param) version src env; # gnumake42: https://github.com/garrigue/lablgtk/issues/162 - nativeBuildInputs = [ pkg-config ocaml findlib gnumake42 ]; - buildInputs = [ gtk2 libgnomecanvas gtksourceview ] - ++ param.buildInputs or []; + nativeBuildInputs = [ + pkg-config + ocaml + findlib + gnumake42 + ]; + buildInputs = [ + gtk2 + libgnomecanvas + gtksourceview + ] ++ param.buildInputs or [ ]; configureFlags = [ "--with-libdir=$(out)/lib/ocaml/${ocaml.version}/site-lib" ]; buildFlags = [ "world" ]; @@ -51,7 +78,11 @@ stdenv.mkDerivation { description = "OCaml interface to GTK"; homepage = "http://lablgtk.forge.ocamlcore.org/"; license = licenses.lgpl21Plus; - maintainers = with maintainers; [ maggesi roconnor vbgl ]; + maintainers = with maintainers; [ + maggesi + roconnor + vbgl + ]; mainProgram = "lablgtk2"; inherit (ocaml.meta) platforms; }; diff --git a/pkgs/development/ocaml-modules/lablgtk3/default.nix b/pkgs/development/ocaml-modules/lablgtk3/default.nix index 3a2a2cb90ffb7e..56eff5d0e164f5 100644 --- a/pkgs/development/ocaml-modules/lablgtk3/default.nix +++ b/pkgs/development/ocaml-modules/lablgtk3/default.nix @@ -1,6 +1,12 @@ -{ lib, fetchurl, pkg-config, buildDunePackage, dune-configurator -, gtk3, cairo2 -, camlp-streams +{ + lib, + fetchurl, + pkg-config, + buildDunePackage, + dune-configurator, + gtk3, + cairo2, + camlp-streams, }: buildDunePackage rec { @@ -15,8 +21,14 @@ buildDunePackage rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dune-configurator camlp-streams ]; - propagatedBuildInputs = [ gtk3 cairo2 ]; + buildInputs = [ + dune-configurator + camlp-streams + ]; + propagatedBuildInputs = [ + gtk3 + cairo2 + ]; meta = { description = "OCaml interface to GTK 3"; diff --git a/pkgs/development/ocaml-modules/lablgtk3/gtkspell3.nix b/pkgs/development/ocaml-modules/lablgtk3/gtkspell3.nix index be57c7e7146f8b..9dbf1b7ddef1b6 100644 --- a/pkgs/development/ocaml-modules/lablgtk3/gtkspell3.nix +++ b/pkgs/development/ocaml-modules/lablgtk3/gtkspell3.nix @@ -1,8 +1,17 @@ -{ buildDunePackage, gtkspell3, lablgtk3 }: +{ + buildDunePackage, + gtkspell3, + lablgtk3, +}: buildDunePackage { pname = "lablgtk3-gtkspell3"; buildInputs = [ gtkspell3 ] ++ lablgtk3.buildInputs; propagatedBuildInputs = [ lablgtk3 ]; - inherit (lablgtk3) src version meta nativeBuildInputs; + inherit (lablgtk3) + src + version + meta + nativeBuildInputs + ; } diff --git a/pkgs/development/ocaml-modules/lablgtk3/rsvg2.nix b/pkgs/development/ocaml-modules/lablgtk3/rsvg2.nix index 463f50f18e6249..f38d3a524ad1f7 100644 --- a/pkgs/development/ocaml-modules/lablgtk3/rsvg2.nix +++ b/pkgs/development/ocaml-modules/lablgtk3/rsvg2.nix @@ -1,8 +1,9 @@ -{ buildDunePackage -, dune-configurator -, lablgtk3 -, librsvg -, pkg-config +{ + buildDunePackage, + dune-configurator, + lablgtk3, + librsvg, + pkg-config, }: buildDunePackage rec { @@ -12,7 +13,10 @@ buildDunePackage rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ lablgtk3 librsvg ]; + propagatedBuildInputs = [ + lablgtk3 + librsvg + ]; meta = lablgtk3.meta // { description = "OCaml interface to Gnome rsvg2 library"; diff --git a/pkgs/development/ocaml-modules/lablgtk3/sourceview3.nix b/pkgs/development/ocaml-modules/lablgtk3/sourceview3.nix index 0e8ba3ef3ffe83..0fa1039c62cb66 100644 --- a/pkgs/development/ocaml-modules/lablgtk3/sourceview3.nix +++ b/pkgs/development/ocaml-modules/lablgtk3/sourceview3.nix @@ -1,8 +1,17 @@ -{ buildDunePackage, gtksourceview, lablgtk3 }: +{ + buildDunePackage, + gtksourceview, + lablgtk3, +}: buildDunePackage { pname = "lablgtk3-sourceview3"; buildInputs = lablgtk3.buildInputs ++ [ gtksourceview ]; propagatedBuildInputs = [ lablgtk3 ]; - inherit (lablgtk3) src version meta nativeBuildInputs; + inherit (lablgtk3) + src + version + meta + nativeBuildInputs + ; } diff --git a/pkgs/development/ocaml-modules/labltk/default.nix b/pkgs/development/ocaml-modules/labltk/default.nix index 780213ad079257..2bd7444fb8aeed 100644 --- a/pkgs/development/ocaml-modules/labltk/default.nix +++ b/pkgs/development/ocaml-modules/labltk/default.nix @@ -1,62 +1,81 @@ -{ stdenv, lib, makeWrapper, fetchzip, Cocoa, ocaml, findlib, tcl, tk }: +{ + stdenv, + lib, + makeWrapper, + fetchzip, + Cocoa, + ocaml, + findlib, + tcl, + tk, +}: let - params = - let mkNewParam = { version, sha256, rev ? version }: { - inherit version; - src = fetchzip { - url = "https://github.com/garrigue/labltk/archive/${rev}.tar.gz"; - inherit sha256; + params = + let + mkNewParam = + { + version, + sha256, + rev ? version, + }: + { + inherit version; + src = fetchzip { + url = "https://github.com/garrigue/labltk/archive/${rev}.tar.gz"; + inherit sha256; + }; + }; + in + rec { + "4.06" = mkNewParam { + version = "8.06.4"; + rev = "labltk-8.06.4"; + sha256 = "03xwnnnahb2rf4siymzqyqy8zgrx3h26qxjgbp5dh1wdl7n02c7g"; + }; + "4.07" = mkNewParam { + version = "8.06.5"; + rev = "1b71e2c6f3ae6847d3d5e79bf099deb7330fb419"; + sha256 = "02vchmrm3izrk7daldd22harhgrjhmbw6i1pqw6hmfmrmrypypg2"; + }; + _8_06_7 = mkNewParam { + version = "8.06.7"; + sha256 = "1cqnxjv2dvw9csiz4iqqyx6rck04jgylpglk8f69kgybf7k7xk2h"; + }; + "4.08" = _8_06_7; + "4.09" = _8_06_7; + "4.10" = mkNewParam { + version = "8.06.8"; + sha256 = "0lfjc7lscq81ibqb3fcybdzs2r1i2xl7rsgi7linq46a0pcpkinw"; + }; + "4.11" = mkNewParam { + version = "8.06.9"; + sha256 = "1k42k3bjkf22gk39lwwzqzfhgjyhxnclslldrzpg5qy1829pbnc0"; + }; + "4.12" = mkNewParam { + version = "8.06.10"; + sha256 = "06cck7wijq4zdshzhxm6jyl8k3j0zglj2axsyfk6q1sq754zyf4a"; + }; + "4.13" = mkNewParam { + version = "8.06.11"; + sha256 = "1zjpg9jvs6i9jvbgn6zgispwqiv8rxvaszxcx9ha9fax3wzhv9qy"; + }; + "4.14" = mkNewParam { + version = "8.06.12"; + sha256 = "sha256:17fmb13l18isgwr38hg9r5a0nayf2hhw6acj5153cy1sygsdg3b5"; + }; + "5.0" = mkNewParam { + version = "8.06.13"; + sha256 = "sha256-Vpf13g3DEWlUI5aypiowGp2fkQPK0cOGv2XiRUY/Ip4="; + }; + "5.2" = mkNewParam { + version = "8.06.14"; + sha256 = "sha256-eVSQetk+i3KObjHfsvnD615cIsq3aZ7IxycX42cuPIU="; + }; }; - }; in - rec { - "4.06" = mkNewParam { - version = "8.06.4"; - rev = "labltk-8.06.4"; - sha256 = "03xwnnnahb2rf4siymzqyqy8zgrx3h26qxjgbp5dh1wdl7n02c7g"; - }; - "4.07" = mkNewParam { - version = "8.06.5"; - rev = "1b71e2c6f3ae6847d3d5e79bf099deb7330fb419"; - sha256 = "02vchmrm3izrk7daldd22harhgrjhmbw6i1pqw6hmfmrmrypypg2"; - }; - _8_06_7 = mkNewParam { - version = "8.06.7"; - sha256 = "1cqnxjv2dvw9csiz4iqqyx6rck04jgylpglk8f69kgybf7k7xk2h"; - }; - "4.08" = _8_06_7; - "4.09" = _8_06_7; - "4.10" = mkNewParam { - version = "8.06.8"; - sha256 = "0lfjc7lscq81ibqb3fcybdzs2r1i2xl7rsgi7linq46a0pcpkinw"; - }; - "4.11" = mkNewParam { - version = "8.06.9"; - sha256 = "1k42k3bjkf22gk39lwwzqzfhgjyhxnclslldrzpg5qy1829pbnc0"; - }; - "4.12" = mkNewParam { - version = "8.06.10"; - sha256 = "06cck7wijq4zdshzhxm6jyl8k3j0zglj2axsyfk6q1sq754zyf4a"; - }; - "4.13" = mkNewParam { - version = "8.06.11"; - sha256 = "1zjpg9jvs6i9jvbgn6zgispwqiv8rxvaszxcx9ha9fax3wzhv9qy"; - }; - "4.14" = mkNewParam { - version = "8.06.12"; - sha256 = "sha256:17fmb13l18isgwr38hg9r5a0nayf2hhw6acj5153cy1sygsdg3b5"; - }; - "5.0" = mkNewParam { - version = "8.06.13"; - sha256 = "sha256-Vpf13g3DEWlUI5aypiowGp2fkQPK0cOGv2XiRUY/Ip4="; - }; - "5.2" = mkNewParam { - version = "8.06.14"; - sha256 = "sha256-eVSQetk+i3KObjHfsvnD615cIsq3aZ7IxycX42cuPIU="; - }; - }; - param = params . ${lib.versions.majorMinor ocaml.version} - or (throw "labltk is not available for OCaml ${ocaml.version}"); + param = + params.${lib.versions.majorMinor ocaml.version} + or (throw "labltk is not available for OCaml ${ocaml.version}"); in stdenv.mkDerivation rec { @@ -65,15 +84,29 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ ocaml findlib makeWrapper ]; - buildInputs = [ tcl tk ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; + nativeBuildInputs = [ + ocaml + findlib + makeWrapper + ]; + buildInputs = [ + tcl + tk + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; - configureFlags = [ "--use-findlib" "--installbindir" "$(out)/bin" ]; + configureFlags = [ + "--use-findlib" + "--installbindir" + "$(out)/bin" + ]; dontAddPrefix = true; dontAddStaticConfigureFlags = true; - configurePlatforms = []; + configurePlatforms = [ ]; - buildFlags = [ "all" "opt" ]; + buildFlags = [ + "all" + "opt" + ]; createFindlibDestdir = true; diff --git a/pkgs/development/ocaml-modules/ladspa/default.nix b/pkgs/development/ocaml-modules/ladspa/default.nix index b037a61a0fb4f2..7ff7a0311356b9 100644 --- a/pkgs/development/ocaml-modules/ladspa/default.nix +++ b/pkgs/development/ocaml-modules/ladspa/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, ladspaH }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + ladspaH, +}: buildDunePackage rec { pname = "ladspa"; diff --git a/pkgs/development/ocaml-modules/lambda-term/default.nix b/pkgs/development/ocaml-modules/lambda-term/default.nix index 2846ff12845160..10a916a5f17fcc 100644 --- a/pkgs/development/ocaml-modules/lambda-term/default.nix +++ b/pkgs/development/ocaml-modules/lambda-term/default.nix @@ -1,14 +1,29 @@ -{ lib, fetchFromGitHub, buildDunePackage, ocaml, zed, lwt_log, lwt_react, mew_vi, uucp, logs }: - -let params = - if lib.versionAtLeast ocaml.version "4.08" then { - version = "3.3.2"; - sha256 = "sha256-T2DDpHqLar1sgmju0PLvhAZef5VzOpPWcFVhuZlPQmM="; - } else { - version = "3.1.0"; - sha256 = "1k0ykiz0vhpyyj9fkss29ajas4fh1xh449j702xkvayqipzj1mkg"; - } -; in +{ + lib, + fetchFromGitHub, + buildDunePackage, + ocaml, + zed, + lwt_log, + lwt_react, + mew_vi, + uucp, + logs, +}: + +let + params = + if lib.versionAtLeast ocaml.version "4.08" then + { + version = "3.3.2"; + sha256 = "sha256-T2DDpHqLar1sgmju0PLvhAZef5VzOpPWcFVhuZlPQmM="; + } + else + { + version = "3.1.0"; + sha256 = "1k0ykiz0vhpyyj9fkss29ajas4fh1xh449j702xkvayqipzj1mkg"; + }; +in buildDunePackage rec { pname = "lambda-term"; @@ -23,24 +38,33 @@ buildDunePackage rec { inherit (params) sha256; }; - propagatedBuildInputs = [ zed lwt_log lwt_react mew_vi ] - ++ lib.optionals (lib.versionAtLeast version "3.3.1") [ uucp logs ] ; + propagatedBuildInputs = + [ + zed + lwt_log + lwt_react + mew_vi + ] + ++ lib.optionals (lib.versionAtLeast version "3.3.1") [ + uucp + logs + ]; meta = { description = "Terminal manipulation library for OCaml"; longDescription = '' - Lambda-term is a cross-platform library for - manipulating the terminal. It provides an abstraction for keys, - mouse events, colors, as well as a set of widgets to write - curses-like applications. - - The main objective of lambda-term is to provide a higher level - functional interface to terminal manipulation than, for example, - ncurses, by providing a native OCaml interface instead of bindings to - a C library. - - Lambda-term integrates with zed to provide text edition facilities in - console applications. + Lambda-term is a cross-platform library for + manipulating the terminal. It provides an abstraction for keys, + mouse events, colors, as well as a set of widgets to write + curses-like applications. + + The main objective of lambda-term is to provide a higher level + functional interface to terminal manipulation than, for example, + ncurses, by providing a native OCaml interface instead of bindings to + a C library. + + Lambda-term integrates with zed to provide text edition facilities in + console applications. ''; inherit (src.meta) homepage; diff --git a/pkgs/development/ocaml-modules/lambdapi/default.nix b/pkgs/development/ocaml-modules/lambdapi/default.nix index f4d1cdb717b7af..fc4a0728b046a1 100644 --- a/pkgs/development/ocaml-modules/lambdapi/default.nix +++ b/pkgs/development/ocaml-modules/lambdapi/default.nix @@ -1,18 +1,19 @@ -{ lib -, fetchurl -, buildDunePackage -, alcotest -, dedukti -, bindlib -, camlp-streams -, cmdliner -, menhir -, pratter -, sedlex -, stdlib-shims -, timed -, why3 -, yojson +{ + lib, + fetchurl, + buildDunePackage, + alcotest, + dedukti, + bindlib, + camlp-streams, + cmdliner, + menhir, + pratter, + sedlex, + stdlib-shims, + timed, + why3, + yojson, }: buildDunePackage rec { @@ -28,10 +29,21 @@ buildDunePackage rec { nativeBuildInputs = [ menhir ]; propagatedBuildInputs = [ - bindlib camlp-streams cmdliner pratter sedlex stdlib-shims timed why3 yojson + bindlib + camlp-streams + cmdliner + pratter + sedlex + stdlib-shims + timed + why3 + yojson ]; - checkInputs = [ alcotest dedukti ]; + checkInputs = [ + alcotest + dedukti + ]; doCheck = false; # anomaly: Sys_error("/homeless-shelter/.why3.conf: No such file or directory") meta = with lib; { diff --git a/pkgs/development/ocaml-modules/lambdasoup/default.nix b/pkgs/development/ocaml-modules/lambdasoup/default.nix index c8c6c545cbaaf6..ea4b3512c16d76 100644 --- a/pkgs/development/ocaml-modules/lambdasoup/default.nix +++ b/pkgs/development/ocaml-modules/lambdasoup/default.nix @@ -1,4 +1,12 @@ -{ lib, fetchFromGitHub, buildDunePackage, ocaml, camlp-streams, markup, ounit2 }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + ocaml, + camlp-streams, + markup, + ounit2, +}: buildDunePackage rec { pname = "lambdasoup"; @@ -13,7 +21,10 @@ buildDunePackage rec { hash = "sha256-+d1JPU7OyQgt8pDTlwZraqPHH+OBQD1ycsELKpHT95Y="; }; - propagatedBuildInputs = [ camlp-streams markup ]; + propagatedBuildInputs = [ + camlp-streams + markup + ]; doCheck = lib.versionAtLeast ocaml.version "4.08"; checkInputs = [ ounit2 ]; diff --git a/pkgs/development/ocaml-modules/lame/default.nix b/pkgs/development/ocaml-modules/lame/default.nix index 2e23a3715dac60..338d6a4bb913cf 100644 --- a/pkgs/development/ocaml-modules/lame/default.nix +++ b/pkgs/development/ocaml-modules/lame/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub, pkg-config, dune-configurator, lame }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + pkg-config, + dune-configurator, + lame, +}: buildDunePackage rec { pname = "lame"; diff --git a/pkgs/development/ocaml-modules/landmarks-ppx/default.nix b/pkgs/development/ocaml-modules/landmarks-ppx/default.nix index f15c86b9e1f311..8025fb90303ce5 100644 --- a/pkgs/development/ocaml-modules/landmarks-ppx/default.nix +++ b/pkgs/development/ocaml-modules/landmarks-ppx/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, ocaml, landmarks, ppxlib }: +{ + lib, + buildDunePackage, + ocaml, + landmarks, + ppxlib, +}: buildDunePackage { pname = "landmarks-ppx"; @@ -9,8 +15,7 @@ buildDunePackage { buildInputs = [ ppxlib ]; propagatedBuildInputs = [ landmarks ]; - doCheck = lib.versionAtLeast ocaml.version "4.08" - && lib.versionOlder ocaml.version "5.0"; + doCheck = lib.versionAtLeast ocaml.version "4.08" && lib.versionOlder ocaml.version "5.0"; meta = landmarks.meta // { description = "Preprocessor instrumenting code using the landmarks library"; diff --git a/pkgs/development/ocaml-modules/landmarks/default.nix b/pkgs/development/ocaml-modules/landmarks/default.nix index e25bf1ae79047d..3a39592a9ecf8d 100644 --- a/pkgs/development/ocaml-modules/landmarks/default.nix +++ b/pkgs/development/ocaml-modules/landmarks/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, ocaml }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + ocaml, +}: buildDunePackage { pname = "landmarks"; @@ -12,8 +17,7 @@ buildDunePackage { hash = "sha256-Wpr76JURUFrj7v39rdM/2Lr7boa7nL/bnPEz1vMrmQo"; }; - doCheck = lib.versionAtLeast ocaml.version "4.08" - && lib.versionOlder ocaml.version "5.0"; + doCheck = lib.versionAtLeast ocaml.version "4.08" && lib.versionOlder ocaml.version "5.0"; meta = with lib; { description = "Simple Profiling Library for OCaml"; diff --git a/pkgs/development/ocaml-modules/lastfm/default.nix b/pkgs/development/ocaml-modules/lastfm/default.nix index da4bb54d2bf5da..12b2777b79faa1 100644 --- a/pkgs/development/ocaml-modules/lastfm/default.nix +++ b/pkgs/development/ocaml-modules/lastfm/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildDunePackage -, fetchFromGitHub -, re -, xmlplaylist +{ + lib, + buildDunePackage, + fetchFromGitHub, + re, + xmlplaylist, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/lem/default.nix b/pkgs/development/ocaml-modules/lem/default.nix index a020d2ab692fc8..6c1ff08f44dd35 100644 --- a/pkgs/development/ocaml-modules/lem/default.nix +++ b/pkgs/development/ocaml-modules/lem/default.nix @@ -1,45 +1,58 @@ -{ stdenv -, fetchFromGitHub -, lib -, makeWrapper -, ocamlbuild -, findlib -, ocaml -, num -, zarith +{ + stdenv, + fetchFromGitHub, + lib, + makeWrapper, + ocamlbuild, + findlib, + ocaml, + num, + zarith, }: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.07") "lem is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-lem"; - version = "2022-12-10"; - - src = fetchFromGitHub { - owner = "rems-project"; - repo = "lem"; - rev = version; - hash = "sha256-ZQgcuIVRkJS0KtpzjbO4OPHGg6B0TadWA6XpRir30y8="; - }; - - nativeBuildInputs = [ makeWrapper ocamlbuild findlib ocaml ]; - propagatedBuildInputs = [ zarith num ]; - - installFlags = [ "INSTALL_DIR=$(out)" ]; - - createFindlibDestdir = true; - - postInstall = '' - wrapProgram $out/bin/lem --set LEMLIB $out/share/lem/library - ''; - - meta = with lib; { - homepage = "https://github.com/rems-project/lem"; - description = "Tool for lightweight executable mathematics"; - mainProgram = "lem"; - maintainers = with maintainers; [ genericnerdyusername ]; - license = with licenses; [ bsd3 gpl2 ]; - platforms = ocaml.meta.platforms; - }; -} + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-lem"; + version = "2022-12-10"; + + src = fetchFromGitHub { + owner = "rems-project"; + repo = "lem"; + rev = version; + hash = "sha256-ZQgcuIVRkJS0KtpzjbO4OPHGg6B0TadWA6XpRir30y8="; + }; + + nativeBuildInputs = [ + makeWrapper + ocamlbuild + findlib + ocaml + ]; + propagatedBuildInputs = [ + zarith + num + ]; + + installFlags = [ "INSTALL_DIR=$(out)" ]; + + createFindlibDestdir = true; + + postInstall = '' + wrapProgram $out/bin/lem --set LEMLIB $out/share/lem/library + ''; + + meta = with lib; { + homepage = "https://github.com/rems-project/lem"; + description = "Tool for lightweight executable mathematics"; + mainProgram = "lem"; + maintainers = with maintainers; [ genericnerdyusername ]; + license = with licenses; [ + bsd3 + gpl2 + ]; + platforms = ocaml.meta.platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/lens/default.nix b/pkgs/development/ocaml-modules/lens/default.nix index 0de5773a597529..0499e640e24028 100644 --- a/pkgs/development/ocaml-modules/lens/default.nix +++ b/pkgs/development/ocaml-modules/lens/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, ppx_deriving, ppxlib, buildDunePackage, ounit }: +{ + lib, + fetchFromGitHub, + ppx_deriving, + ppxlib, + buildDunePackage, + ounit, +}: buildDunePackage rec { pname = "lens"; @@ -14,7 +21,10 @@ buildDunePackage rec { }; minimalOCamlVersion = "4.10"; - buildInputs = [ ppx_deriving ppxlib ]; + buildInputs = [ + ppx_deriving + ppxlib + ]; doCheck = true; checkInputs = [ ounit ]; diff --git a/pkgs/development/ocaml-modules/letsencrypt/app.nix b/pkgs/development/ocaml-modules/letsencrypt/app.nix index 2f43c8c5b78899..f24cafffed7630 100644 --- a/pkgs/development/ocaml-modules/letsencrypt/app.nix +++ b/pkgs/development/ocaml-modules/letsencrypt/app.nix @@ -1,16 +1,17 @@ -{ buildDunePackage -, letsencrypt -, letsencrypt-dns -, cmdliner -, cohttp-lwt-unix -, logs -, fmt -, lwt -, mirage-crypto-rng -, ptime -, bos -, fpath -, randomconv +{ + buildDunePackage, + letsencrypt, + letsencrypt-dns, + cmdliner, + cohttp-lwt-unix, + logs, + fmt, + lwt, + mirage-crypto-rng, + ptime, + bos, + fpath, + randomconv, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/letsencrypt/default.nix b/pkgs/development/ocaml-modules/letsencrypt/default.nix index fc4ccaaf00bdf4..033ffde04a3aef 100644 --- a/pkgs/development/ocaml-modules/letsencrypt/default.nix +++ b/pkgs/development/ocaml-modules/letsencrypt/default.nix @@ -1,20 +1,21 @@ -{ buildDunePackage -, lib -, fetchurl -, uri -, base64 -, digestif -, logs -, fmt -, lwt -, mirage-crypto -, mirage-crypto-ec -, mirage-crypto-pk -, x509 -, yojson -, ounit2 -, ptime -, domain-name +{ + buildDunePackage, + lib, + fetchurl, + uri, + base64, + digestif, + logs, + fmt, + lwt, + mirage-crypto, + mirage-crypto-ec, + mirage-crypto-pk, + x509, + yojson, + ounit2, + ptime, + domain-name, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/letsencrypt/dns.nix b/pkgs/development/ocaml-modules/letsencrypt/dns.nix index c263b6c1280656..55772136d7d57c 100644 --- a/pkgs/development/ocaml-modules/letsencrypt/dns.nix +++ b/pkgs/development/ocaml-modules/letsencrypt/dns.nix @@ -1,11 +1,12 @@ -{ buildDunePackage -, letsencrypt -, logs -, fmt -, lwt -, dns -, dns-tsig -, domain-name +{ + buildDunePackage, + letsencrypt, + logs, + fmt, + lwt, + dns, + dns-tsig, + domain-name, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/letsencrypt/mirage.nix b/pkgs/development/ocaml-modules/letsencrypt/mirage.nix index 038e75932da0f0..f6a4d25f9c1d0b 100644 --- a/pkgs/development/ocaml-modules/letsencrypt/mirage.nix +++ b/pkgs/development/ocaml-modules/letsencrypt/mirage.nix @@ -1,8 +1,9 @@ -{ buildDunePackage -, letsencrypt -, emile -, http-mirage-client -, paf +{ + buildDunePackage, + letsencrypt, + emile, + http-mirage-client, + paf, }: buildDunePackage { @@ -10,7 +11,12 @@ buildDunePackage { inherit (letsencrypt) version src; - propagatedBuildInputs = [ emile http-mirage-client letsencrypt paf ]; + propagatedBuildInputs = [ + emile + http-mirage-client + letsencrypt + paf + ]; meta = letsencrypt.meta // { description = "ACME implementation in OCaml for MirageOS"; diff --git a/pkgs/development/ocaml-modules/libc/default.nix b/pkgs/development/ocaml-modules/libc/default.nix index 13e0f04ddfc78f..cd2501325ab977 100644 --- a/pkgs/development/ocaml-modules/libc/default.nix +++ b/pkgs/development/ocaml-modules/libc/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildDunePackage -, fetchurl -, config +{ + lib, + buildDunePackage, + fetchurl, + config, }: buildDunePackage rec { @@ -23,4 +24,3 @@ buildDunePackage rec { license = lib.licenses.mit; }; } - diff --git a/pkgs/development/ocaml-modules/lilv/default.nix b/pkgs/development/ocaml-modules/lilv/default.nix index a5def260eb291e..3ff0782ca288c6 100644 --- a/pkgs/development/ocaml-modules/lilv/default.nix +++ b/pkgs/development/ocaml-modules/lilv/default.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, ctypes, ctypes-foreign, lilv }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + ctypes, + ctypes-foreign, + lilv, +}: buildDunePackage rec { pname = "lilv"; @@ -14,7 +22,11 @@ buildDunePackage rec { minimalOCamlVersion = "4.03.0"; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ ctypes ctypes-foreign lilv ]; + propagatedBuildInputs = [ + ctypes + ctypes-foreign + lilv + ]; meta = with lib; { homepage = "https://github.com/savonet/ocaml-lilv"; diff --git a/pkgs/development/ocaml-modules/linenoise/default.nix b/pkgs/development/ocaml-modules/linenoise/default.nix index 96d00c28fce66d..62516a7274860b 100644 --- a/pkgs/development/ocaml-modules/linenoise/default.nix +++ b/pkgs/development/ocaml-modules/linenoise/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, result }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + result, +}: buildDunePackage rec { pname = "linenoise"; diff --git a/pkgs/development/ocaml-modules/linksem/default.nix b/pkgs/development/ocaml-modules/linksem/default.nix index 2e88c7f0d45f8c..ccefd91c06cf80 100644 --- a/pkgs/development/ocaml-modules/linksem/default.nix +++ b/pkgs/development/ocaml-modules/linksem/default.nix @@ -1,36 +1,41 @@ -{ lib -, fetchFromGitHub -, stdenv -, findlib -, ocaml -, lem +{ + lib, + fetchFromGitHub, + stdenv, + findlib, + ocaml, + lem, }: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.07") "linksem is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-linksem"; - version = "0.8"; + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-linksem"; + version = "0.8"; - src = fetchFromGitHub { - owner = "rems-project"; - repo = "linksem"; - rev = version; - hash = "sha256-7/YfDK3TruKCckMzAPLRrwBkHRJcX1S+AzXHWRxkZPA="; - }; + src = fetchFromGitHub { + owner = "rems-project"; + repo = "linksem"; + rev = version; + hash = "sha256-7/YfDK3TruKCckMzAPLRrwBkHRJcX1S+AzXHWRxkZPA="; + }; - nativeBuildInputs = [ findlib ocaml ]; + nativeBuildInputs = [ + findlib + ocaml + ]; - propagatedBuildInputs = [ lem ]; + propagatedBuildInputs = [ lem ]; - createFindlibDestdir = true; + createFindlibDestdir = true; - meta = with lib; { - homepage = "https://github.com/rems-project/linksem"; - description = "Formalisation of substantial parts of ELF linking and DWARF debug information"; - maintainers = with maintainers; [ genericnerdyusername ]; - license = licenses.bsd2; - platforms = ocaml.meta.platforms; - }; -} + meta = with lib; { + homepage = "https://github.com/rems-project/linksem"; + description = "Formalisation of substantial parts of ELF linking and DWARF debug information"; + maintainers = with maintainers; [ genericnerdyusername ]; + license = licenses.bsd2; + platforms = ocaml.meta.platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/linol/default.nix b/pkgs/development/ocaml-modules/linol/default.nix index 97630cc3db93e3..3d0f513cad5b4c 100644 --- a/pkgs/development/ocaml-modules/linol/default.nix +++ b/pkgs/development/ocaml-modules/linol/default.nix @@ -1,7 +1,15 @@ -{ lib, fetchurl, buildDunePackage, yojson, logs, lsp, ppx_yojson_conv_lib, trace }: +{ + lib, + fetchurl, + buildDunePackage, + yojson, + logs, + lsp, + ppx_yojson_conv_lib, + trace, +}: -buildDunePackage -rec { +buildDunePackage rec { pname = "linol"; version = "0.6"; diff --git a/pkgs/development/ocaml-modules/linol/lwt.nix b/pkgs/development/ocaml-modules/linol/lwt.nix index b8d16b023041f8..a8c211be0ba644 100644 --- a/pkgs/development/ocaml-modules/linol/lwt.nix +++ b/pkgs/development/ocaml-modules/linol/lwt.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, linol, jsonrpc, lwt, yojson }: +{ + buildDunePackage, + linol, + jsonrpc, + lwt, + yojson, +}: buildDunePackage { pname = "linol-lwt"; diff --git a/pkgs/development/ocaml-modules/llvm/default.nix b/pkgs/development/ocaml-modules/llvm/default.nix index 948d326d659456..ced262a7824c57 100644 --- a/pkgs/development/ocaml-modules/llvm/default.nix +++ b/pkgs/development/ocaml-modules/llvm/default.nix @@ -1,6 +1,17 @@ -{ stdenv, lib, python3, cmake, libllvm, ocaml, findlib, ctypes }: +{ + stdenv, + lib, + python3, + cmake, + libllvm, + ocaml, + findlib, + ctypes, +}: -let version = lib.getVersion libllvm; in +let + version = lib.getVersion libllvm; +in stdenv.mkDerivation { pname = "ocaml-llvm"; @@ -8,7 +19,12 @@ stdenv.mkDerivation { inherit (libllvm) src; - nativeBuildInputs = [ cmake python3 ocaml findlib ]; + nativeBuildInputs = [ + cmake + python3 + ocaml + findlib + ]; buildInputs = [ ctypes ]; propagatedBuildInputs = [ libllvm ]; @@ -27,7 +43,10 @@ stdenv.mkDerivation { buildFlags = [ "ocaml_all" ]; - installFlags = [ "-C" "bindings/ocaml" ]; + installFlags = [ + "-C" + "bindings/ocaml" + ]; postInstall = '' mkdir -p $OCAMLFIND_DESTDIR/ diff --git a/pkgs/development/ocaml-modules/lo/default.nix b/pkgs/development/ocaml-modules/lo/default.nix index 6da5854f9de234..083de69b36cc7b 100644 --- a/pkgs/development/ocaml-modules/lo/default.nix +++ b/pkgs/development/ocaml-modules/lo/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, liblo }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + liblo, +}: buildDunePackage rec { pname = "lo"; diff --git a/pkgs/development/ocaml-modules/logs/default.nix b/pkgs/development/ocaml-modules/logs/default.nix index bd7326883829de..1eb99037686ba2 100644 --- a/pkgs/development/ocaml-modules/logs/default.nix +++ b/pkgs/development/ocaml-modules/logs/default.nix @@ -1,55 +1,87 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, ocamlbuild -, topkg, result, lwt, cmdliner, fmt -, fmtSupport ? lib.versionAtLeast ocaml.version "4.08" -, js_of_ocaml -, jsooSupport ? true -, lwtSupport ? true -, cmdlinerSupport ? true +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + result, + lwt, + cmdliner, + fmt, + fmtSupport ? lib.versionAtLeast ocaml.version "4.08", + js_of_ocaml, + jsooSupport ? true, + lwtSupport ? true, + cmdlinerSupport ? true, }: let pname = "logs"; webpage = "https://erratique.ch/software/${pname}"; optional_deps = [ - { pkg = js_of_ocaml; enable_flag = "--with-js_of_ocaml"; enabled = jsooSupport; } - { pkg = fmt; enable_flag = "--with-fmt"; enabled = fmtSupport; } - { pkg = lwt; enable_flag = "--with-lwt"; enabled = lwtSupport; } - { pkg = cmdliner; enable_flag = "--with-cmdliner"; enabled = cmdlinerSupport; } + { + pkg = js_of_ocaml; + enable_flag = "--with-js_of_ocaml"; + enabled = jsooSupport; + } + { + pkg = fmt; + enable_flag = "--with-fmt"; + enabled = fmtSupport; + } + { + pkg = lwt; + enable_flag = "--with-lwt"; + enabled = lwtSupport; + } + { + pkg = cmdliner; + enable_flag = "--with-cmdliner"; + enabled = cmdlinerSupport; + } ]; - enable_flags = - lib.concatMap (d: [ d.enable_flag (lib.boolToString d.enabled)]) optional_deps; - optional_buildInputs = - map (d: d.pkg) (lib.filter (d: d.enabled) optional_deps); + enable_flags = lib.concatMap (d: [ + d.enable_flag + (lib.boolToString d.enabled) + ]) optional_deps; + optional_buildInputs = map (d: d.pkg) (lib.filter (d: d.enabled) optional_deps); in -if lib.versionOlder ocaml.version "4.03" -then throw "logs is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.03" then + throw "logs is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - name = "ocaml${ocaml.version}-${pname}-${version}"; - version = "0.7.0"; + stdenv.mkDerivation rec { + name = "ocaml${ocaml.version}-${pname}-${version}"; + version = "0.7.0"; - src = fetchurl { - url = "${webpage}/releases/${pname}-${version}.tbz"; - sha256 = "1jnmd675wmsmdwyb5mx5b0ac66g4c6gpv5s4mrx2j6pb0wla1x46"; - }; + src = fetchurl { + url = "${webpage}/releases/${pname}-${version}.tbz"; + sha256 = "1jnmd675wmsmdwyb5mx5b0ac66g4c6gpv5s4mrx2j6pb0wla1x46"; + }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg ] ++ optional_buildInputs; - propagatedBuildInputs = [ result ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ topkg ] ++ optional_buildInputs; + propagatedBuildInputs = [ result ]; - strictDeps = true; + strictDeps = true; - buildPhase = "${topkg.run} build ${lib.escapeShellArgs enable_flags}"; + buildPhase = "${topkg.run} build ${lib.escapeShellArgs enable_flags}"; - inherit (topkg) installPhase; + inherit (topkg) installPhase; - meta = with lib; { - description = "Logging infrastructure for OCaml"; - homepage = webpage; - inherit (ocaml.meta) platforms; - maintainers = [ maintainers.sternenseemann ]; - license = licenses.isc; - }; -} + meta = with lib; { + description = "Logging infrastructure for OCaml"; + homepage = webpage; + inherit (ocaml.meta) platforms; + maintainers = [ maintainers.sternenseemann ]; + license = licenses.isc; + }; + } diff --git a/pkgs/development/ocaml-modules/lru/default.nix b/pkgs/development/ocaml-modules/lru/default.nix index 2c8a3e99df5757..74bb6c07f524b3 100644 --- a/pkgs/development/ocaml-modules/lru/default.nix +++ b/pkgs/development/ocaml-modules/lru/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, buildDunePackage, ocaml, psq, qcheck-alcotest }: +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + psq, + qcheck-alcotest, +}: buildDunePackage rec { pname = "lru"; diff --git a/pkgs/development/ocaml-modules/lua-ml/default.nix b/pkgs/development/ocaml-modules/lua-ml/default.nix index bec9b9a998dc47..1ea40e57d002c4 100644 --- a/pkgs/development/ocaml-modules/lua-ml/default.nix +++ b/pkgs/development/ocaml-modules/lua-ml/default.nix @@ -1,36 +1,49 @@ -{ stdenv, lib, fetchFromGitHub, ocaml, findlib, ocamlbuild, opaline }: - -if lib.versionOlder ocaml.version "4.07" -then throw "lua-ml is not available for OCaml ${ocaml.version}" +{ + stdenv, + lib, + fetchFromGitHub, + ocaml, + findlib, + ocamlbuild, + opaline, +}: + +if lib.versionOlder ocaml.version "4.07" then + throw "lua-ml is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "lua-ml"; - name = "ocaml${ocaml.version}-${pname}-${version}"; - version = "0.9.2"; - - src = fetchFromGitHub { - owner = "lindig"; - repo = pname; - rev = version; - sha256 = "sha256-xkjsjKD89W7Y5XK8kfL/ZErYKS14z0u0QCARN0DbTC8="; - }; - - nativeBuildInputs = [ opaline ocaml findlib ocamlbuild ]; - - strictDeps = true; - - buildFlags = [ "lib" ]; - - installPhase = '' - opaline -prefix $out -libdir $OCAMLFIND_DESTDIR - ''; - - meta = { - description = "Embeddable Lua 2.5 interpreter implemented in OCaml"; - inherit (src.meta) homepage; - inherit (ocaml.meta) platforms; - license = lib.licenses.bsd2; - maintainers = [ lib.maintainers.vbgl ]; - }; -} + stdenv.mkDerivation rec { + pname = "lua-ml"; + name = "ocaml${ocaml.version}-${pname}-${version}"; + version = "0.9.2"; + + src = fetchFromGitHub { + owner = "lindig"; + repo = pname; + rev = version; + sha256 = "sha256-xkjsjKD89W7Y5XK8kfL/ZErYKS14z0u0QCARN0DbTC8="; + }; + + nativeBuildInputs = [ + opaline + ocaml + findlib + ocamlbuild + ]; + + strictDeps = true; + + buildFlags = [ "lib" ]; + + installPhase = '' + opaline -prefix $out -libdir $OCAMLFIND_DESTDIR + ''; + + meta = { + description = "Embeddable Lua 2.5 interpreter implemented in OCaml"; + inherit (src.meta) homepage; + inherit (ocaml.meta) platforms; + license = lib.licenses.bsd2; + maintainers = [ lib.maintainers.vbgl ]; + }; + } diff --git a/pkgs/development/ocaml-modules/lun/default.nix b/pkgs/development/ocaml-modules/lun/default.nix index 17dcaead3c22cb..5e1e32178f5e45 100644 --- a/pkgs/development/ocaml-modules/lun/default.nix +++ b/pkgs/development/ocaml-modules/lun/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "lun"; diff --git a/pkgs/development/ocaml-modules/lun/ppx.nix b/pkgs/development/ocaml-modules/lun/ppx.nix index d4212a3d959562..8c701e7042b922 100644 --- a/pkgs/development/ocaml-modules/lun/ppx.nix +++ b/pkgs/development/ocaml-modules/lun/ppx.nix @@ -1,10 +1,19 @@ -{ lib, buildDunePackage, fmt, lun, ppxlib }: +{ + lib, + buildDunePackage, + fmt, + lun, + ppxlib, +}: buildDunePackage { pname = "ppx_lun"; inherit (lun) version src; - propagatedBuildInputs = [ lun ppxlib ]; + propagatedBuildInputs = [ + lun + ppxlib + ]; checkInputs = [ fmt ]; diff --git a/pkgs/development/ocaml-modules/lustre-v6/default.nix b/pkgs/development/ocaml-modules/lustre-v6/default.nix index d4ecdc7e28812d..ae43b9b5044cc2 100644 --- a/pkgs/development/ocaml-modules/lustre-v6/default.nix +++ b/pkgs/development/ocaml-modules/lustre-v6/default.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, fetchurl, extlib, lutils, rdbg, yaml }: +{ + lib, + buildDunePackage, + fetchurl, + extlib, + lutils, + rdbg, + yaml, +}: buildDunePackage rec { pname = "lustre-v6"; @@ -22,7 +30,10 @@ buildDunePackage rec { description = "Lustre V6 compiler"; homepage = "https://www-verimag.imag.fr/lustre-v6.html"; license = licenses.cecill21; - maintainers = with maintainers; [ delta wegank ]; + maintainers = with maintainers; [ + delta + wegank + ]; mainProgram = "lv6"; }; } diff --git a/pkgs/development/ocaml-modules/lutils/default.nix b/pkgs/development/ocaml-modules/lutils/default.nix index 38bd10077ce090..2130900625f538 100644 --- a/pkgs/development/ocaml-modules/lutils/default.nix +++ b/pkgs/development/ocaml-modules/lutils/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchurl, camlp-streams, num }: +{ + lib, + buildDunePackage, + fetchurl, + camlp-streams, + num, +}: buildDunePackage rec { pname = "lutils"; @@ -12,7 +18,8 @@ buildDunePackage rec { }; propagatedBuildInputs = [ - camlp-streams num + camlp-streams + num ]; meta = with lib; { diff --git a/pkgs/development/ocaml-modules/luv/default.nix b/pkgs/development/ocaml-modules/luv/default.nix index 86b799e72fd6db..687d1a0fdc4671 100644 --- a/pkgs/development/ocaml-modules/luv/default.nix +++ b/pkgs/development/ocaml-modules/luv/default.nix @@ -1,7 +1,12 @@ -{ lib, buildDunePackage, ocaml, fetchurl -, ctypes, result -, alcotest -, file +{ + lib, + buildDunePackage, + ocaml, + fetchurl, + ctypes, + result, + alcotest, + file, }: buildDunePackage rec { @@ -28,7 +33,10 @@ buildDunePackage rec { ''; nativeBuildInputs = [ file ]; - propagatedBuildInputs = [ ctypes result ]; + propagatedBuildInputs = [ + ctypes + result + ]; checkInputs = [ alcotest ]; # Alcotest depends on fmt that needs 4.08 or newer doCheck = lib.versionAtLeast ocaml.version "4.08"; @@ -37,7 +45,15 @@ buildDunePackage rec { homepage = "https://github.com/aantron/luv"; description = "Binding to libuv: cross-platform asynchronous I/O"; # MIT-licensed, extra licenses apply partially to libuv vendor - license = with licenses; [ mit bsd2 bsd3 cc-by-sa-40 ]; - maintainers = with maintainers; [ locallycompact sternenseemann ]; + license = with licenses; [ + mit + bsd2 + bsd3 + cc-by-sa-40 + ]; + maintainers = with maintainers; [ + locallycompact + sternenseemann + ]; }; } diff --git a/pkgs/development/ocaml-modules/lwd/default.nix b/pkgs/development/ocaml-modules/lwd/default.nix index 43e13bbcc89313..b83541271dd7a6 100644 --- a/pkgs/development/ocaml-modules/lwd/default.nix +++ b/pkgs/development/ocaml-modules/lwd/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, buildDunePackage, seq }: +{ + lib, + fetchurl, + buildDunePackage, + seq, +}: buildDunePackage rec { pname = "lwd"; @@ -8,8 +13,7 @@ buildDunePackage rec { duneVersion = "3"; src = fetchurl { - url = - "https://github.com/let-def/lwd/releases/download/v${version}/lwd-${version}.tbz"; + url = "https://github.com/let-def/lwd/releases/download/v${version}/lwd-${version}.tbz"; sha256 = "sha256-H/vyW2tn2OBuWwcmPs8NcINXgFe93MSxRd8dzeoXARI="; }; diff --git a/pkgs/development/ocaml-modules/lwd/nottui-lwt.nix b/pkgs/development/ocaml-modules/lwd/nottui-lwt.nix index 09a4a8ba228ebd..36b0f042ba4491 100644 --- a/pkgs/development/ocaml-modules/lwd/nottui-lwt.nix +++ b/pkgs/development/ocaml-modules/lwd/nottui-lwt.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, lwd, lwt, nottui }: +{ + lib, + buildDunePackage, + lwd, + lwt, + nottui, +}: buildDunePackage { pname = "nottui-lwt"; @@ -8,7 +14,10 @@ buildDunePackage { minimalOCamlVersion = "4.08"; duneVersion = "3"; - propagatedBuildInputs = [ lwt nottui ]; + propagatedBuildInputs = [ + lwt + nottui + ]; meta = with lib; { description = "Run Nottui UIs in Lwt"; diff --git a/pkgs/development/ocaml-modules/lwd/nottui-pretty.nix b/pkgs/development/ocaml-modules/lwd/nottui-pretty.nix index ac9b18ff3b4f90..9328677af22d22 100644 --- a/pkgs/development/ocaml-modules/lwd/nottui-pretty.nix +++ b/pkgs/development/ocaml-modules/lwd/nottui-pretty.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, lwd, nottui }: +{ + lib, + buildDunePackage, + lwd, + nottui, +}: buildDunePackage { pname = "nottui-pretty"; diff --git a/pkgs/development/ocaml-modules/lwd/nottui.nix b/pkgs/development/ocaml-modules/lwd/nottui.nix index bffab13a5e1d0c..0b01deb1555da6 100644 --- a/pkgs/development/ocaml-modules/lwd/nottui.nix +++ b/pkgs/development/ocaml-modules/lwd/nottui.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, lwd, notty }: +{ + lib, + buildDunePackage, + lwd, + notty, +}: buildDunePackage { pname = "nottui"; @@ -8,7 +13,10 @@ buildDunePackage { minimalOCamlVersion = "4.08"; duneVersion = "3"; - propagatedBuildInputs = [ lwd notty ]; + propagatedBuildInputs = [ + lwd + notty + ]; meta = with lib; { description = "UI toolkit for the terminal built on top of Notty and Lwd"; diff --git a/pkgs/development/ocaml-modules/lwd/tyxml-lwd.nix b/pkgs/development/ocaml-modules/lwd/tyxml-lwd.nix index f391eba7d62261..9e7df7f3a2c893 100644 --- a/pkgs/development/ocaml-modules/lwd/tyxml-lwd.nix +++ b/pkgs/development/ocaml-modules/lwd/tyxml-lwd.nix @@ -1,4 +1,12 @@ -{ lib, fetchpatch, buildDunePackage, js_of_ocaml, js_of_ocaml-ppx, lwd, tyxml }: +{ + lib, + fetchpatch, + buildDunePackage, + js_of_ocaml, + js_of_ocaml-ppx, + lwd, + tyxml, +}: buildDunePackage { pname = "tyxml-lwd"; @@ -14,7 +22,11 @@ buildDunePackage { minimalOCamlVersion = "4.08"; buildInputs = [ js_of_ocaml-ppx ]; - propagatedBuildInputs = [ js_of_ocaml lwd tyxml ]; + propagatedBuildInputs = [ + js_of_ocaml + lwd + tyxml + ]; meta = with lib; { description = "Make reactive webpages in Js_of_ocaml using Tyxml and Lwd"; diff --git a/pkgs/development/ocaml-modules/lwt-canceler/default.nix b/pkgs/development/ocaml-modules/lwt-canceler/default.nix index 97b27157265e9d..e49e5de90d014f 100644 --- a/pkgs/development/ocaml-modules/lwt-canceler/default.nix +++ b/pkgs/development/ocaml-modules/lwt-canceler/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitLab, buildDunePackage, lwt }: +{ + lib, + fetchFromGitLab, + buildDunePackage, + lwt, +}: buildDunePackage rec { pname = "lwt-canceler"; diff --git a/pkgs/development/ocaml-modules/lwt-dllist/default.nix b/pkgs/development/ocaml-modules/lwt-dllist/default.nix index 88ad74b3e652f4..be344e94e333f9 100644 --- a/pkgs/development/ocaml-modules/lwt-dllist/default.nix +++ b/pkgs/development/ocaml-modules/lwt-dllist/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchurl, lwt, ocaml }: +{ + lib, + buildDunePackage, + fetchurl, + lwt, + ocaml, +}: buildDunePackage rec { pname = "lwt-dllist"; diff --git a/pkgs/development/ocaml-modules/lwt-exit/default.nix b/pkgs/development/ocaml-modules/lwt-exit/default.nix index 52bcc0ab2de3af..44365f9d6b3569 100644 --- a/pkgs/development/ocaml-modules/lwt-exit/default.nix +++ b/pkgs/development/ocaml-modules/lwt-exit/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitLab -, buildDunePackage -, lwt -, ptime +{ + lib, + fetchFromGitLab, + buildDunePackage, + lwt, + ptime, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/lwt-watcher/default.nix b/pkgs/development/ocaml-modules/lwt-watcher/default.nix index 624b59b811b782..02bfc43abc5b20 100644 --- a/pkgs/development/ocaml-modules/lwt-watcher/default.nix +++ b/pkgs/development/ocaml-modules/lwt-watcher/default.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitLab -, buildDunePackage -, lwt +{ + lib, + fetchFromGitLab, + buildDunePackage, + lwt, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/lwt/camlp4.nix b/pkgs/development/ocaml-modules/lwt/camlp4.nix index de8252c55549b1..8466e20e9f4871 100644 --- a/pkgs/development/ocaml-modules/lwt/camlp4.nix +++ b/pkgs/development/ocaml-modules/lwt/camlp4.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, camlp4 }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + camlp4, +}: buildDunePackage rec { pname = "lwt_camlp4"; @@ -27,4 +32,3 @@ buildDunePackage rec { maintainers = [ lib.maintainers.vbgl ]; }; } - diff --git a/pkgs/development/ocaml-modules/lwt/ppx.nix b/pkgs/development/ocaml-modules/lwt/ppx.nix index 2881560c6f8d97..be2e32220c8b33 100644 --- a/pkgs/development/ocaml-modules/lwt/ppx.nix +++ b/pkgs/development/ocaml-modules/lwt/ppx.nix @@ -1,4 +1,9 @@ -{ fetchFromGitHub, buildDunePackage, lwt, ppxlib }: +{ + fetchFromGitHub, + buildDunePackage, + lwt, + ppxlib, +}: buildDunePackage { pname = "lwt_ppx"; @@ -21,7 +26,10 @@ buildDunePackage { hash = "sha256-DLQupCkZ14kOuSQatbb7j07I+jvvDCKpdlaR3rijT4s="; }; - propagatedBuildInputs = [ lwt ppxlib ]; + propagatedBuildInputs = [ + lwt + ppxlib + ]; meta = { description = "Ppx syntax extension for Lwt"; diff --git a/pkgs/development/ocaml-modules/lwt_log/default.nix b/pkgs/development/ocaml-modules/lwt_log/default.nix index 5a57c31969e9d5..4bcd3524e84925 100644 --- a/pkgs/development/ocaml-modules/lwt_log/default.nix +++ b/pkgs/development/ocaml-modules/lwt_log/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, lwt }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + lwt, +}: buildDunePackage rec { pname = "lwt_log"; diff --git a/pkgs/development/ocaml-modules/lwt_react/default.nix b/pkgs/development/ocaml-modules/lwt_react/default.nix index 492bad64708596..c9d7bed9f6aeba 100644 --- a/pkgs/development/ocaml-modules/lwt_react/default.nix +++ b/pkgs/development/ocaml-modules/lwt_react/default.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, fetchFromGitHub, cppo, lwt, react }: +{ + buildDunePackage, + fetchFromGitHub, + cppo, + lwt, + react, +}: buildDunePackage { pname = "lwt_react"; @@ -15,7 +21,10 @@ buildDunePackage { nativeBuildInputs = [ cppo ]; - propagatedBuildInputs = [ lwt react ]; + propagatedBuildInputs = [ + lwt + react + ]; meta = { description = "Helpers for using React with Lwt"; diff --git a/pkgs/development/ocaml-modules/lwt_ssl/default.nix b/pkgs/development/ocaml-modules/lwt_ssl/default.nix index 7b74d92c2e50f4..ec4ea72c53b527 100644 --- a/pkgs/development/ocaml-modules/lwt_ssl/default.nix +++ b/pkgs/development/ocaml-modules/lwt_ssl/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, buildDunePackage, ssl, lwt }: +{ + lib, + fetchurl, + buildDunePackage, + ssl, + lwt, +}: buildDunePackage rec { pname = "lwt_ssl"; @@ -11,7 +17,10 @@ buildDunePackage rec { hash = "sha256-swIK0nrs83fhw/J0Cgizbcu6mR+EMGZRE1dBBUiImnc="; }; - propagatedBuildInputs = [ ssl lwt ]; + propagatedBuildInputs = [ + ssl + lwt + ]; meta = { homepage = "https://github.com/aantron/lwt_ssl"; diff --git a/pkgs/development/ocaml-modules/macaddr/cstruct.nix b/pkgs/development/ocaml-modules/macaddr/cstruct.nix index db77c9fb2c5685..e5cc1fff5d9ed3 100644 --- a/pkgs/development/ocaml-modules/macaddr/cstruct.nix +++ b/pkgs/development/ocaml-modules/macaddr/cstruct.nix @@ -1,5 +1,7 @@ -{ buildDunePackage -, macaddr, cstruct +{ + buildDunePackage, + macaddr, + cstruct, }: buildDunePackage { @@ -9,7 +11,10 @@ buildDunePackage { duneVersion = "3"; - propagatedBuildInputs = [ macaddr cstruct ]; + propagatedBuildInputs = [ + macaddr + cstruct + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/macaddr/default.nix b/pkgs/development/ocaml-modules/macaddr/default.nix index 905426bf53b232..b413e7570d74fa 100644 --- a/pkgs/development/ocaml-modules/macaddr/default.nix +++ b/pkgs/development/ocaml-modules/macaddr/default.nix @@ -1,5 +1,10 @@ -{ lib, fetchurl, buildDunePackage, ocaml -, ppx_sexp_conv, ounit2 +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + ppx_sexp_conv, + ounit2, }: buildDunePackage rec { @@ -13,7 +18,10 @@ buildDunePackage rec { hash = "sha256-njBDP9tMpDemqo/7RHuspeunYV+4jnsM2KS0FsMggTM="; }; - checkInputs = [ ppx_sexp_conv ounit2 ]; + checkInputs = [ + ppx_sexp_conv + ounit2 + ]; doCheck = lib.versionAtLeast ocaml.version "4.08"; meta = with lib; { diff --git a/pkgs/development/ocaml-modules/macaddr/sexp.nix b/pkgs/development/ocaml-modules/macaddr/sexp.nix index 63a93efab2ed0f..86d79dc215d6f2 100644 --- a/pkgs/development/ocaml-modules/macaddr/sexp.nix +++ b/pkgs/development/ocaml-modules/macaddr/sexp.nix @@ -1,5 +1,9 @@ -{ buildDunePackage -, macaddr, ppx_sexp_conv, macaddr-cstruct, ounit2 +{ + buildDunePackage, + macaddr, + ppx_sexp_conv, + macaddr-cstruct, + ounit2, }: buildDunePackage { @@ -11,7 +15,10 @@ buildDunePackage { propagatedBuildInputs = [ ppx_sexp_conv ]; - checkInputs = [ macaddr-cstruct ounit2 ]; + checkInputs = [ + macaddr-cstruct + ounit2 + ]; doCheck = true; meta = macaddr.meta // { diff --git a/pkgs/development/ocaml-modules/mad/default.nix b/pkgs/development/ocaml-modules/mad/default.nix index 096987f737f844..401e75f7ea890b 100644 --- a/pkgs/development/ocaml-modules/mad/default.nix +++ b/pkgs/development/ocaml-modules/mad/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, libmad }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + libmad, +}: buildDunePackage rec { pname = "mad"; diff --git a/pkgs/development/ocaml-modules/magic-mime/default.nix b/pkgs/development/ocaml-modules/magic-mime/default.nix index a400e073f215b3..6460a1fb849628 100644 --- a/pkgs/development/ocaml-modules/magic-mime/default.nix +++ b/pkgs/development/ocaml-modules/magic-mime/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, buildDunePackage }: +{ + lib, + fetchurl, + buildDunePackage, +}: buildDunePackage rec { pname = "magic-mime"; diff --git a/pkgs/development/ocaml-modules/magic-trace/default.nix b/pkgs/development/ocaml-modules/magic-trace/default.nix index b4e1c557e81244..1cca903398f623 100644 --- a/pkgs/development/ocaml-modules/magic-trace/default.nix +++ b/pkgs/development/ocaml-modules/magic-trace/default.nix @@ -1,18 +1,19 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, ocaml-crunch -, angstrom -, async -, cohttp -, cohttp_static_handler ? null -, core -, core_unix ? null -, fzf -, owee -, ppx_jane -, re -, shell ? null +{ + lib, + fetchFromGitHub, + buildDunePackage, + ocaml-crunch, + angstrom, + async, + cohttp, + cohttp_static_handler ? null, + core, + core_unix ? null, + fzf, + owee, + ppx_jane, + re, + shell ? null, }: buildDunePackage rec { @@ -46,8 +47,7 @@ buildDunePackage rec { ]; meta = with lib; { - description = - "Collects and displays high-resolution traces of what a process is doing"; + description = "Collects and displays high-resolution traces of what a process is doing"; license = licenses.mit; maintainers = [ maintainers.alizter ]; homepage = "https://github.com/janestreet/magic-trace"; diff --git a/pkgs/development/ocaml-modules/magic/default.nix b/pkgs/development/ocaml-modules/magic/default.nix index 29ff7e67832c98..a6bd0eb2a03330 100644 --- a/pkgs/development/ocaml-modules/magic/default.nix +++ b/pkgs/development/ocaml-modules/magic/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, findlib, which, file }: +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, + which, + file, +}: stdenv.mkDerivation rec { pname = "magic"; @@ -14,7 +22,10 @@ stdenv.mkDerivation rec { createFindlibDestdir = true; nativeBuildInputs = [ which ]; - buildInputs = [ ocaml findlib ]; + buildInputs = [ + ocaml + findlib + ]; propagatedBuildInputs = [ file ]; meta = with lib; { diff --git a/pkgs/development/ocaml-modules/mariadb/default.nix b/pkgs/development/ocaml-modules/mariadb/default.nix index 3ac6027b22fd0d..4fbc81bfc313b5 100644 --- a/pkgs/development/ocaml-modules/mariadb/default.nix +++ b/pkgs/development/ocaml-modules/mariadb/default.nix @@ -1,49 +1,77 @@ -{ lib, fetchurl, stdenv -, fetchpatch -, ocaml, findlib, ocamlbuild, camlp-streams -, ctypes, mariadb, libmysqlclient }: +{ + lib, + fetchurl, + stdenv, + fetchpatch, + ocaml, + findlib, + ocamlbuild, + camlp-streams, + ctypes, + mariadb, + libmysqlclient, +}: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.07") "mariadb is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-mariadb"; - version = "1.1.6"; - - src = fetchurl { - url = "https://github.com/andrenth/ocaml-mariadb/releases/download/${version}/ocaml-mariadb-${version}.tar.gz"; - sha256 = "sha256-3/C1Gz6luUzS7oaudLlDHMT6JB2v5OdbLVzJhtayHGM="; - }; - - patches = lib.lists.map (x: - fetchpatch { - url = "https://github.com/andrenth/ocaml-mariadb/commit/${x.path}.patch"; - inherit (x) hash; - }) - [ { path = "9db2e4d8dec7c584213d0e0f03d079a36a35d9d5"; - hash = "sha256-heROtU02cYBJ5edIHMdYP1xNXcLv8h79GYGBuudJhgE="; } - { path = "40cd3102bc7cce4ed826ed609464daeb1bbb4581"; - hash = "sha256-YVsAMJiOgWRk9xPaRz2sDihBYLlXv+rhWtQIMOVLtSg="; } - ]; - - postPatch = '' - substituteInPlace setup.ml --replace '#use "topfind"' \ - '#directory "${findlib}/lib/ocaml/${ocaml.version}/site-lib/";; #use "topfind"' - ''; - - nativeBuildInputs = [ ocaml findlib ocamlbuild ]; - buildInputs = [ mariadb libmysqlclient camlp-streams ocamlbuild ]; - propagatedBuildInputs = [ ctypes ]; - - strictDeps = true; - - preInstall = "mkdir -p $OCAMLFIND_DESTDIR/stublibs"; - - meta = { - description = "OCaml bindings for MariaDB"; - license = lib.licenses.mit; - maintainers = with lib.maintainers; [ bcc32 ]; - homepage = "https://github.com/andrenth/ocaml-mariadb"; - inherit (ocaml.meta) platforms; - }; -} + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-mariadb"; + version = "1.1.6"; + + src = fetchurl { + url = "https://github.com/andrenth/ocaml-mariadb/releases/download/${version}/ocaml-mariadb-${version}.tar.gz"; + sha256 = "sha256-3/C1Gz6luUzS7oaudLlDHMT6JB2v5OdbLVzJhtayHGM="; + }; + + patches = + lib.lists.map + ( + x: + fetchpatch { + url = "https://github.com/andrenth/ocaml-mariadb/commit/${x.path}.patch"; + inherit (x) hash; + } + ) + [ + { + path = "9db2e4d8dec7c584213d0e0f03d079a36a35d9d5"; + hash = "sha256-heROtU02cYBJ5edIHMdYP1xNXcLv8h79GYGBuudJhgE="; + } + { + path = "40cd3102bc7cce4ed826ed609464daeb1bbb4581"; + hash = "sha256-YVsAMJiOgWRk9xPaRz2sDihBYLlXv+rhWtQIMOVLtSg="; + } + ]; + + postPatch = '' + substituteInPlace setup.ml --replace '#use "topfind"' \ + '#directory "${findlib}/lib/ocaml/${ocaml.version}/site-lib/";; #use "topfind"' + ''; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ]; + buildInputs = [ + mariadb + libmysqlclient + camlp-streams + ocamlbuild + ]; + propagatedBuildInputs = [ ctypes ]; + + strictDeps = true; + + preInstall = "mkdir -p $OCAMLFIND_DESTDIR/stublibs"; + + meta = { + description = "OCaml bindings for MariaDB"; + license = lib.licenses.mit; + maintainers = with lib.maintainers; [ bcc32 ]; + homepage = "https://github.com/andrenth/ocaml-mariadb"; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/markup/default.nix b/pkgs/development/ocaml-modules/markup/default.nix index 2de510919edf11..85a9afd80a2228 100644 --- a/pkgs/development/ocaml-modules/markup/default.nix +++ b/pkgs/development/ocaml-modules/markup/default.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, fetchFromGitHub, ocaml, uchar, uutf, ounit2 }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + ocaml, + uchar, + uutf, + ounit2, +}: buildDunePackage rec { pname = "markup"; @@ -13,7 +21,10 @@ buildDunePackage rec { sha256 = "sha256-tsXz39qFSyL6vPYKG7P73zSEiraaFuOySL1n0uFij6k="; }; - propagatedBuildInputs = [ uchar uutf ]; + propagatedBuildInputs = [ + uchar + uutf + ]; checkInputs = [ ounit2 ]; doCheck = lib.versionAtLeast ocaml.version "4.08"; diff --git a/pkgs/development/ocaml-modules/mccs/default.nix b/pkgs/development/ocaml-modules/mccs/default.nix index cb77d21479ca6c..d939538fa6601b 100644 --- a/pkgs/development/ocaml-modules/mccs/default.nix +++ b/pkgs/development/ocaml-modules/mccs/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, cudf }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + cudf, +}: buildDunePackage rec { pname = "mccs"; @@ -21,7 +26,10 @@ buildDunePackage rec { description = "Library providing a multi criteria CUDF solver, part of MANCOOSI project"; downloadPage = "https://github.com/AltGr/ocaml-mccs"; homepage = "https://www.i3s.unice.fr/~cpjm/misc/"; - license = with licenses; [ lgpl21 gpl3 ]; + license = with licenses; [ + lgpl21 + gpl3 + ]; maintainers = [ ]; }; } diff --git a/pkgs/development/ocaml-modules/mec/default.nix b/pkgs/development/ocaml-modules/mec/default.nix index de57b3d44d326a..29ed1fc0e86208 100644 --- a/pkgs/development/ocaml-modules/mec/default.nix +++ b/pkgs/development/ocaml-modules/mec/default.nix @@ -1,6 +1,15 @@ -{ lib, fetchzip, buildDunePackage -, zarith, eqaf, bigarray-compat, hex, ff-sig, ff -, alcotest, bisect_ppx +{ + lib, + fetchzip, + buildDunePackage, + zarith, + eqaf, + bigarray-compat, + hex, + ff-sig, + ff, + alcotest, + bisect_ppx, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/memprof-limits/default.nix b/pkgs/development/ocaml-modules/memprof-limits/default.nix index 768c0448728208..5548dce3a3d574 100644 --- a/pkgs/development/ocaml-modules/memprof-limits/default.nix +++ b/pkgs/development/ocaml-modules/memprof-limits/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitLab, ocaml }: +{ + lib, + buildDunePackage, + fetchFromGitLab, + ocaml, +}: if !(lib.versionOlder ocaml.version "5.0.0") then throw "memprof-limits is not available for OCaml ${ocaml.version}" @@ -18,8 +23,7 @@ else meta = with lib; { homepage = "https://ocaml.org/p/memprof-limits/latest"; - description = - "Memory limits, allocation limits, and thread cancellation for OCaml"; + description = "Memory limits, allocation limits, and thread cancellation for OCaml"; license = licenses.lgpl3; maintainers = with maintainers; [ alizter ]; }; diff --git a/pkgs/development/ocaml-modules/memtrace/default.nix b/pkgs/development/ocaml-modules/memtrace/default.nix index 03ed32af92139b..47520e2e61b71f 100644 --- a/pkgs/development/ocaml-modules/memtrace/default.nix +++ b/pkgs/development/ocaml-modules/memtrace/default.nix @@ -1,4 +1,7 @@ -{ lib, buildDunePackage, fetchFromGitHub +{ + lib, + buildDunePackage, + fetchFromGitHub, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/menhir/default.nix b/pkgs/development/ocaml-modules/menhir/default.nix index 04e80d69ebd0da..ae0f15843b30a7 100644 --- a/pkgs/development/ocaml-modules/menhir/default.nix +++ b/pkgs/development/ocaml-modules/menhir/default.nix @@ -1,5 +1,9 @@ -{ buildDunePackage, substituteAll, ocaml -, menhirLib, menhirSdk +{ + buildDunePackage, + substituteAll, + ocaml, + menhirLib, + menhirSdk, }: buildDunePackage rec { @@ -9,7 +13,10 @@ buildDunePackage rec { inherit (menhirLib) version src; - buildInputs = [ menhirLib menhirSdk ]; + buildInputs = [ + menhirLib + menhirSdk + ]; patches = [ (substituteAll { diff --git a/pkgs/development/ocaml-modules/menhir/lib.nix b/pkgs/development/ocaml-modules/menhir/lib.nix index 27af2c1b5200ee..f421b9de86c5c9 100644 --- a/pkgs/development/ocaml-modules/menhir/lib.nix +++ b/pkgs/development/ocaml-modules/menhir/lib.nix @@ -1,15 +1,21 @@ -{ lib -, buildDunePackage -, ocaml -, coqPackages -, version ? if lib.versionAtLeast ocaml.version "4.08" then "20240715" else "20231231" +{ + lib, + buildDunePackage, + ocaml, + coqPackages, + version ? if lib.versionAtLeast ocaml.version "4.08" then "20240715" else "20231231", }: -let fetched = coqPackages.metaFetch ({ +let + fetched = coqPackages.metaFetch ({ release."20231231".sha256 = "sha256-veB0ORHp6jdRwCyDDAfc7a7ov8sOeHUmiELdOFf/QYk="; release."20240715".sha256 = "sha256-9CSxAIm0aEXkwF+aj8u/bqLG30y5eDNz65EnohJPjzI="; releaseRev = v: "${v}"; - location = { domain = "gitlab.inria.fr"; owner = "fpottier"; repo = "menhir"; }; + location = { + domain = "gitlab.inria.fr"; + owner = "fpottier"; + repo = "menhir"; + }; }) version; in buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/menhir/sdk.nix b/pkgs/development/ocaml-modules/menhir/sdk.nix index ad406c8a31dd2b..9369be3a49f481 100644 --- a/pkgs/development/ocaml-modules/menhir/sdk.nix +++ b/pkgs/development/ocaml-modules/menhir/sdk.nix @@ -1,5 +1,7 @@ -{ lib, buildDunePackage -, menhirLib +{ + lib, + buildDunePackage, + menhirLib, }: buildDunePackage rec { @@ -12,4 +14,3 @@ buildDunePackage rec { license = with lib.licenses; [ gpl2Only ]; }; } - diff --git a/pkgs/development/ocaml-modules/merlin-extend/default.nix b/pkgs/development/ocaml-modules/merlin-extend/default.nix index 17013a11caad0b..8d578539ba86c4 100644 --- a/pkgs/development/ocaml-modules/merlin-extend/default.nix +++ b/pkgs/development/ocaml-modules/merlin-extend/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchurl, cppo }: +{ + lib, + buildDunePackage, + fetchurl, + cppo, +}: buildDunePackage rec { pname = "merlin-extend"; diff --git a/pkgs/development/ocaml-modules/metadata/default.nix b/pkgs/development/ocaml-modules/metadata/default.nix index 4fc86d1194700b..bbfb4e1e8f7e23 100644 --- a/pkgs/development/ocaml-modules/metadata/default.nix +++ b/pkgs/development/ocaml-modules/metadata/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchFromGitHub }: +{ + lib, + buildDunePackage, + fetchFromGitHub, +}: buildDunePackage rec { pname = "metadata"; diff --git a/pkgs/development/ocaml-modules/metrics/default.nix b/pkgs/development/ocaml-modules/metrics/default.nix index 9a0de6212f20dd..b1c921ac548c16 100644 --- a/pkgs/development/ocaml-modules/metrics/default.nix +++ b/pkgs/development/ocaml-modules/metrics/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, buildDunePackage, alcotest, fmt }: +{ + lib, + fetchurl, + buildDunePackage, + alcotest, + fmt, +}: buildDunePackage rec { pname = "metrics"; diff --git a/pkgs/development/ocaml-modules/metrics/influx.nix b/pkgs/development/ocaml-modules/metrics/influx.nix index f004c1042aa730..d4b94bc231e704 100644 --- a/pkgs/development/ocaml-modules/metrics/influx.nix +++ b/pkgs/development/ocaml-modules/metrics/influx.nix @@ -1,5 +1,9 @@ -{ buildDunePackage, metrics -, duration, fmt, lwt +{ + buildDunePackage, + metrics, + duration, + fmt, + lwt, }: buildDunePackage rec { @@ -8,7 +12,12 @@ buildDunePackage rec { duneVersion = "3"; - propagatedBuildInputs = [ duration fmt lwt metrics ]; + propagatedBuildInputs = [ + duration + fmt + lwt + metrics + ]; meta = metrics.meta // { description = "Influx reporter for the Metrics library"; diff --git a/pkgs/development/ocaml-modules/metrics/lwt.nix b/pkgs/development/ocaml-modules/metrics/lwt.nix index 465f4adc5c5ddb..782c05d9ca74c4 100644 --- a/pkgs/development/ocaml-modules/metrics/lwt.nix +++ b/pkgs/development/ocaml-modules/metrics/lwt.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, logs, lwt, metrics }: +{ + buildDunePackage, + logs, + lwt, + metrics, +}: buildDunePackage { pname = "metrics-lwt"; @@ -7,7 +12,11 @@ buildDunePackage { duneVersion = "3"; - propagatedBuildInputs = [ logs lwt metrics ]; + propagatedBuildInputs = [ + logs + lwt + metrics + ]; meta = metrics.meta // { description = "Lwt backend for the Metrics library"; diff --git a/pkgs/development/ocaml-modules/metrics/rusage.nix b/pkgs/development/ocaml-modules/metrics/rusage.nix index fcc188f7db4b24..bd7d952723ce59 100644 --- a/pkgs/development/ocaml-modules/metrics/rusage.nix +++ b/pkgs/development/ocaml-modules/metrics/rusage.nix @@ -1,5 +1,8 @@ -{ buildDunePackage, metrics -, fmt, logs +{ + buildDunePackage, + metrics, + fmt, + logs, }: buildDunePackage { @@ -9,7 +12,11 @@ buildDunePackage { minimalOCamlVersion = "4.08"; duneVersion = "3"; - propagatedBuildInputs = [ fmt logs metrics ]; + propagatedBuildInputs = [ + fmt + logs + metrics + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/metrics/unix.nix b/pkgs/development/ocaml-modules/metrics/unix.nix index 0c3a1465c2b161..91cb89c15f00bd 100644 --- a/pkgs/development/ocaml-modules/metrics/unix.nix +++ b/pkgs/development/ocaml-modules/metrics/unix.nix @@ -1,4 +1,12 @@ -{ buildDunePackage, gnuplot, lwt, metrics, metrics-lwt, mtime, uuidm }: +{ + buildDunePackage, + gnuplot, + lwt, + metrics, + metrics-lwt, + mtime, + uuidm, +}: buildDunePackage rec { @@ -6,7 +14,13 @@ buildDunePackage rec { inherit (metrics) version src; - propagatedBuildInputs = [ gnuplot lwt metrics mtime uuidm ]; + propagatedBuildInputs = [ + gnuplot + lwt + metrics + mtime + uuidm + ]; nativeCheckInputs = [ gnuplot ]; checkInputs = [ metrics-lwt ]; diff --git a/pkgs/development/ocaml-modules/mew/default.nix b/pkgs/development/ocaml-modules/mew/default.nix index 819bb020050c8c..479aae5283f0f1 100644 --- a/pkgs/development/ocaml-modules/mew/default.nix +++ b/pkgs/development/ocaml-modules/mew/default.nix @@ -1,5 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitHub -, result, trie +{ + lib, + buildDunePackage, + fetchFromGitHub, + result, + trie, }: buildDunePackage rec { @@ -15,7 +19,10 @@ buildDunePackage rec { sha256 = "0417xsghj92v3xa5q4dk4nzf2r4mylrx2fd18i7cg3nzja65nia2"; }; - propagatedBuildInputs = [ result trie ]; + propagatedBuildInputs = [ + result + trie + ]; meta = { inherit (src.meta) homepage; diff --git a/pkgs/development/ocaml-modules/mew_vi/default.nix b/pkgs/development/ocaml-modules/mew_vi/default.nix index 39228585fe3cd8..f5ae24e1c5dfd5 100644 --- a/pkgs/development/ocaml-modules/mew_vi/default.nix +++ b/pkgs/development/ocaml-modules/mew_vi/default.nix @@ -1,5 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitHub -, mew, react +{ + lib, + buildDunePackage, + fetchFromGitHub, + mew, + react, }: buildDunePackage rec { @@ -15,7 +19,10 @@ buildDunePackage rec { sha256 = "0lihbf822k5zasl60w5mhwmdkljlq49c9saayrws7g4qc1j353r8"; }; - propagatedBuildInputs = [ mew react ]; + propagatedBuildInputs = [ + mew + react + ]; meta = { inherit (src.meta) homepage; diff --git a/pkgs/development/ocaml-modules/middleware/default.nix b/pkgs/development/ocaml-modules/middleware/default.nix index 2cdef2e5a3c4e3..13371ab50e3050 100644 --- a/pkgs/development/ocaml-modules/middleware/default.nix +++ b/pkgs/development/ocaml-modules/middleware/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildDunePackage -, fetchurl -, alcotest +{ + lib, + buildDunePackage, + fetchurl, + alcotest, }: buildDunePackage rec { @@ -29,4 +30,3 @@ buildDunePackage rec { maintainers = with lib.maintainers; [ sixstring982 ]; }; } - diff --git a/pkgs/development/ocaml-modules/mimic/default.nix b/pkgs/development/ocaml-modules/mimic/default.nix index 706286fe26e657..80758efc0ed1b4 100644 --- a/pkgs/development/ocaml-modules/mimic/default.nix +++ b/pkgs/development/ocaml-modules/mimic/default.nix @@ -1,6 +1,15 @@ -{ lib, buildDunePackage, fetchurl -, mirage-flow, cstruct, logs, ke, lwt -, alcotest, alcotest-lwt, bigstringaf +{ + lib, + buildDunePackage, + fetchurl, + mirage-flow, + cstruct, + logs, + ke, + lwt, + alcotest, + alcotest-lwt, + bigstringaf, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/mimic/happy-eyeballs.nix b/pkgs/development/ocaml-modules/mimic/happy-eyeballs.nix index ede649c6951635..1dfdaeb47413d0 100644 --- a/pkgs/development/ocaml-modules/mimic/happy-eyeballs.nix +++ b/pkgs/development/ocaml-modules/mimic/happy-eyeballs.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, dns-client-mirage, mimic, happy-eyeballs-mirage }: +{ + lib, + buildDunePackage, + dns-client-mirage, + mimic, + happy-eyeballs-mirage, +}: buildDunePackage { pname = "mimic-happy-eyeballs"; diff --git a/pkgs/development/ocaml-modules/minisat/default.nix b/pkgs/development/ocaml-modules/minisat/default.nix index 3a7c222c957286..0148f37c1fca77 100644 --- a/pkgs/development/ocaml-modules/minisat/default.nix +++ b/pkgs/development/ocaml-modules/minisat/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchFromGitHub }: +{ + lib, + buildDunePackage, + fetchFromGitHub, +}: buildDunePackage rec { pname = "minisat"; @@ -7,10 +11,10 @@ buildDunePackage rec { minimalOCamlVersion = "4.05"; src = fetchFromGitHub { - owner = "c-cube"; - repo = "ocaml-minisat"; - rev = "v${version}"; - hash = "sha256-dH0Ndlyo/DTZ6Ao1S478aBuxoZFSkRBi5HblkTWCPas="; + owner = "c-cube"; + repo = "ocaml-minisat"; + rev = "v${version}"; + hash = "sha256-dH0Ndlyo/DTZ6Ao1S478aBuxoZFSkRBi5HblkTWCPas="; }; meta = { diff --git a/pkgs/development/ocaml-modules/minttea/default.nix b/pkgs/development/ocaml-modules/minttea/default.nix index 07084c12c87694..3685f2d459b421 100644 --- a/pkgs/development/ocaml-modules/minttea/default.nix +++ b/pkgs/development/ocaml-modules/minttea/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildDunePackage -, fetchurl -, riot -, tty +{ + lib, + buildDunePackage, + fetchurl, + riot, + tty, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/miou/default.nix b/pkgs/development/ocaml-modules/miou/default.nix index 1b4e1c318fb302..57c40e831c4243 100644 --- a/pkgs/development/ocaml-modules/miou/default.nix +++ b/pkgs/development/ocaml-modules/miou/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "miou"; diff --git a/pkgs/development/ocaml-modules/mirage-block-ramdisk/default.nix b/pkgs/development/ocaml-modules/mirage-block-ramdisk/default.nix index a6978d3d5811ea..09eb4b0a46824f 100644 --- a/pkgs/development/ocaml-modules/mirage-block-ramdisk/default.nix +++ b/pkgs/development/ocaml-modules/mirage-block-ramdisk/default.nix @@ -1,12 +1,17 @@ -{ lib, fetchurl, buildDunePackage, io-page, mirage-block }: +{ + lib, + fetchurl, + buildDunePackage, + io-page, + mirage-block, +}: buildDunePackage rec { pname = "mirage-block-ramdisk"; version = "0.5"; src = fetchurl { - url = - "https://github.com/mirage/mirage-block-ramdisk/releases/download/${version}/mirage-block-ramdisk-${version}.tbz"; + url = "https://github.com/mirage/mirage-block-ramdisk/releases/download/${version}/mirage-block-ramdisk-${version}.tbz"; sha256 = "cc0e814fd54efe7a5b7a8c5eb1c04e2dece751b7d8dee2d95908a0768896e8af"; }; @@ -18,7 +23,10 @@ buildDunePackage rec { minimalOCamlVersion = "4.06"; duneVersion = "3"; - propagatedBuildInputs = [ io-page mirage-block ]; + propagatedBuildInputs = [ + io-page + mirage-block + ]; doCheck = false; diff --git a/pkgs/development/ocaml-modules/mirage-block-unix/default.nix b/pkgs/development/ocaml-modules/mirage-block-unix/default.nix index e32523c85eb644..8efbe3a4bc9db7 100644 --- a/pkgs/development/ocaml-modules/mirage-block-unix/default.nix +++ b/pkgs/development/ocaml-modules/mirage-block-unix/default.nix @@ -1,5 +1,14 @@ -{ lib, fetchurl, buildDunePackage, cstruct-lwt, diet, logs -, mirage-block, ounit2, rresult, uri +{ + lib, + fetchurl, + buildDunePackage, + cstruct-lwt, + diet, + logs, + mirage-block, + ounit2, + rresult, + uri, }: buildDunePackage rec { @@ -7,18 +16,26 @@ buildDunePackage rec { version = "2.14.2"; src = fetchurl { - url = - "https://github.com/mirage/mirage-block-unix/releases/download/v${version}/mirage-block-unix-${version}.tbz"; + url = "https://github.com/mirage/mirage-block-unix/releases/download/v${version}/mirage-block-unix-${version}.tbz"; sha256 = "sha256-6ReAzd+pCd5ccmXOh6GlSxHo4GuEgptxLha62n+dBsE="; }; minimalOCamlVersion = "4.08"; duneVersion = "3"; - propagatedBuildInputs = [ cstruct-lwt logs mirage-block rresult uri ]; + propagatedBuildInputs = [ + cstruct-lwt + logs + mirage-block + rresult + uri + ]; doCheck = true; - checkInputs = [ diet ounit2 ]; + checkInputs = [ + diet + ounit2 + ]; meta = with lib; { description = "MirageOS disk block driver for Unix"; diff --git a/pkgs/development/ocaml-modules/mirage-block/combinators.nix b/pkgs/development/ocaml-modules/mirage-block/combinators.nix index fc50002da1e627..939cbacbbbb810 100644 --- a/pkgs/development/ocaml-modules/mirage-block/combinators.nix +++ b/pkgs/development/ocaml-modules/mirage-block/combinators.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, mirage-block, logs }: +{ + buildDunePackage, + mirage-block, + logs, +}: buildDunePackage rec { pname = "mirage-block-combinators"; @@ -6,7 +10,10 @@ buildDunePackage rec { duneVersion = "3"; - propagatedBuildInputs = [ mirage-block logs ]; + propagatedBuildInputs = [ + mirage-block + logs + ]; meta = mirage-block.meta // { description = "Block signatures and implementations for MirageOS using Lwt"; diff --git a/pkgs/development/ocaml-modules/mirage-block/default.nix b/pkgs/development/ocaml-modules/mirage-block/default.nix index 0cd1f1717ea668..365eb6a2228778 100644 --- a/pkgs/development/ocaml-modules/mirage-block/default.nix +++ b/pkgs/development/ocaml-modules/mirage-block/default.nix @@ -1,5 +1,10 @@ -{ lib, fetchurl, buildDunePackage -, cstruct, lwt, fmt +{ + lib, + fetchurl, + buildDunePackage, + cstruct, + lwt, + fmt, }: buildDunePackage rec { @@ -13,7 +18,11 @@ buildDunePackage rec { hash = "sha256-UALUfeL0G1mfSsLgAb/HpQ6OV12YtY+GUOYG6yhUwAI="; }; - propagatedBuildInputs = [ cstruct lwt fmt ]; + propagatedBuildInputs = [ + cstruct + lwt + fmt + ]; meta = with lib; { description = "Block signatures and implementations for MirageOS"; diff --git a/pkgs/development/ocaml-modules/mirage-bootvar-unix/default.nix b/pkgs/development/ocaml-modules/mirage-bootvar-unix/default.nix index d34513afef9f11..3adb2349092e1b 100644 --- a/pkgs/development/ocaml-modules/mirage-bootvar-unix/default.nix +++ b/pkgs/development/ocaml-modules/mirage-bootvar-unix/default.nix @@ -1,5 +1,9 @@ -{ lib, fetchurl, buildDunePackage -, lwt, parse-argv +{ + lib, + fetchurl, + buildDunePackage, + lwt, + parse-argv, }: buildDunePackage rec { @@ -13,7 +17,10 @@ buildDunePackage rec { sha256 = "0r92s6y7nxg0ci330a7p0hii4if51iq0sixn20cnm5j4a2clprbf"; }; - propagatedBuildInputs = [ lwt parse-argv ]; + propagatedBuildInputs = [ + lwt + parse-argv + ]; meta = { description = "Unix implementation of MirageOS Bootvar interface"; diff --git a/pkgs/development/ocaml-modules/mirage-bootvar-xen/default.nix b/pkgs/development/ocaml-modules/mirage-bootvar-xen/default.nix index 1bf622714788dd..b2969d3db6821d 100644 --- a/pkgs/development/ocaml-modules/mirage-bootvar-xen/default.nix +++ b/pkgs/development/ocaml-modules/mirage-bootvar-xen/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildDunePackage -, fetchurl -, mirage-xen -, parse-argv -, lwt +{ + lib, + buildDunePackage, + fetchurl, + mirage-xen, + parse-argv, + lwt, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/mirage-clock/default.nix b/pkgs/development/ocaml-modules/mirage-clock/default.nix index a436f0b59c0780..2cf12cec92ec2b 100644 --- a/pkgs/development/ocaml-modules/mirage-clock/default.nix +++ b/pkgs/development/ocaml-modules/mirage-clock/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "mirage-clock"; @@ -18,5 +22,3 @@ buildDunePackage rec { maintainers = [ lib.maintainers.vbgl ]; }; } - - diff --git a/pkgs/development/ocaml-modules/mirage-clock/solo5.nix b/pkgs/development/ocaml-modules/mirage-clock/solo5.nix index e13fc60e97bdf6..9ea8f53335199c 100644 --- a/pkgs/development/ocaml-modules/mirage-clock/solo5.nix +++ b/pkgs/development/ocaml-modules/mirage-clock/solo5.nix @@ -1,5 +1,6 @@ -{ buildDunePackage -, mirage-clock +{ + buildDunePackage, + mirage-clock, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/mirage-clock/unix.nix b/pkgs/development/ocaml-modules/mirage-clock/unix.nix index 6489a4d2566b6b..b51f4c40732045 100644 --- a/pkgs/development/ocaml-modules/mirage-clock/unix.nix +++ b/pkgs/development/ocaml-modules/mirage-clock/unix.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, mirage-clock, dune-configurator }: +{ + buildDunePackage, + mirage-clock, + dune-configurator, +}: buildDunePackage { pname = "mirage-clock-unix"; diff --git a/pkgs/development/ocaml-modules/mirage-console/default.nix b/pkgs/development/ocaml-modules/mirage-console/default.nix index b0746c54162afb..c22bf4d287f27c 100644 --- a/pkgs/development/ocaml-modules/mirage-console/default.nix +++ b/pkgs/development/ocaml-modules/mirage-console/default.nix @@ -1,5 +1,9 @@ -{ lib, fetchurl, buildDunePackage -, lwt, mirage-flow +{ + lib, + fetchurl, + buildDunePackage, + lwt, + mirage-flow, }: buildDunePackage rec { @@ -14,7 +18,10 @@ buildDunePackage rec { hash = "sha256-mjYRisbNOJbYoSuWaGoPueXakmqAwmWh0ATvLLsvpNM="; }; - propagatedBuildInputs = [ lwt mirage-flow ]; + propagatedBuildInputs = [ + lwt + mirage-flow + ]; meta = { description = "Implementations of Mirage console devices"; diff --git a/pkgs/development/ocaml-modules/mirage-crypto/default.nix b/pkgs/development/ocaml-modules/mirage-crypto/default.nix index 154c740bf00167..3f5f763581870f 100644 --- a/pkgs/development/ocaml-modules/mirage-crypto/default.nix +++ b/pkgs/development/ocaml-modules/mirage-crypto/default.nix @@ -1,6 +1,13 @@ -{ lib, fetchurl, buildDunePackage, ohex, ounit2, dune-configurator, eqaf-cstruct -, withFreestanding ? false -, ocaml-freestanding +{ + lib, + fetchurl, + buildDunePackage, + ohex, + ounit2, + dune-configurator, + eqaf-cstruct, + withFreestanding ? false, + ocaml-freestanding, }: buildDunePackage rec { @@ -15,22 +22,27 @@ buildDunePackage rec { }; doCheck = true; - checkInputs = [ ohex ounit2 ]; - - buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ - eqaf-cstruct - ] ++ lib.optionals withFreestanding [ - ocaml-freestanding + checkInputs = [ + ohex + ounit2 ]; + buildInputs = [ dune-configurator ]; + propagatedBuildInputs = + [ + eqaf-cstruct + ] + ++ lib.optionals withFreestanding [ + ocaml-freestanding + ]; + meta = with lib; { homepage = "https://github.com/mirage/mirage-crypto"; description = "Simple symmetric cryptography for the modern age"; license = [ - licenses.isc # default license + licenses.isc # default license licenses.bsd2 # mirage-crypto-rng-mirage - licenses.mit # mirage-crypto-ec + licenses.mit # mirage-crypto-ec ]; maintainers = with maintainers; [ sternenseemann ]; }; diff --git a/pkgs/development/ocaml-modules/mirage-crypto/ec.nix b/pkgs/development/ocaml-modules/mirage-crypto/ec.nix index 4fa3d2389f7b3f..c7bc636ff68c0c 100644 --- a/pkgs/development/ocaml-modules/mirage-crypto/ec.nix +++ b/pkgs/development/ocaml-modules/mirage-crypto/ec.nix @@ -1,19 +1,20 @@ -{ lib -, buildDunePackage -, mirage-crypto -, dune-configurator -, pkg-config -, mirage-crypto-rng -, mirage-crypto-pk -, alcotest -, asn1-combinators -, ohex -, ounit2 -, ppx_deriving_yojson -, ppx_deriving -, yojson -, withFreestanding ? false -, ocaml-freestanding +{ + lib, + buildDunePackage, + mirage-crypto, + dune-configurator, + pkg-config, + mirage-crypto-rng, + mirage-crypto-pk, + alcotest, + asn1-combinators, + ohex, + ounit2, + ppx_deriving_yojson, + ppx_deriving, + yojson, + withFreestanding ? false, + ocaml-freestanding, }: buildDunePackage rec { @@ -21,18 +22,21 @@ buildDunePackage rec { inherit (mirage-crypto) src - version; + version + ; nativeBuildInputs = [ pkg-config ]; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ - mirage-crypto - mirage-crypto-rng - ] ++ lib.optionals withFreestanding [ - ocaml-freestanding - ]; + propagatedBuildInputs = + [ + mirage-crypto + mirage-crypto-rng + ] + ++ lib.optionals withFreestanding [ + ocaml-freestanding + ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/mirage-crypto/pk.nix b/pkgs/development/ocaml-modules/mirage-crypto/pk.nix index 3b647e90b37bfe..6d637e0259056a 100644 --- a/pkgs/development/ocaml-modules/mirage-crypto/pk.nix +++ b/pkgs/development/ocaml-modules/mirage-crypto/pk.nix @@ -1,5 +1,14 @@ -{ buildDunePackage, ohex, ounit2, randomconv, mirage-crypto, mirage-crypto-rng -, sexplib0, zarith, gmp }: +{ + buildDunePackage, + ohex, + ounit2, + randomconv, + mirage-crypto, + mirage-crypto-rng, + sexplib0, + zarith, + gmp, +}: buildDunePackage rec { pname = "mirage-crypto-pk"; @@ -7,11 +16,19 @@ buildDunePackage rec { inherit (mirage-crypto) version src; buildInputs = [ gmp ]; - propagatedBuildInputs = [ mirage-crypto mirage-crypto-rng - zarith sexplib0 ]; + propagatedBuildInputs = [ + mirage-crypto + mirage-crypto-rng + zarith + sexplib0 + ]; doCheck = true; - checkInputs = [ ohex ounit2 randomconv ]; + checkInputs = [ + ohex + ounit2 + randomconv + ]; meta = mirage-crypto.meta // { description = "Simple public-key cryptography for the modern age"; diff --git a/pkgs/development/ocaml-modules/mirage-crypto/rng-async.nix b/pkgs/development/ocaml-modules/mirage-crypto/rng-async.nix index bc94e333131645..fef5f1231a36d2 100644 --- a/pkgs/development/ocaml-modules/mirage-crypto/rng-async.nix +++ b/pkgs/development/ocaml-modules/mirage-crypto/rng-async.nix @@ -1,6 +1,10 @@ -{ buildDunePackage -, mirage-crypto, mirage-crypto-rng -, dune-configurator, async, logs +{ + buildDunePackage, + mirage-crypto, + mirage-crypto-rng, + dune-configurator, + async, + logs, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/mirage-crypto/rng-lwt.nix b/pkgs/development/ocaml-modules/mirage-crypto/rng-lwt.nix index bcaac601c95c23..94759076251bb6 100644 --- a/pkgs/development/ocaml-modules/mirage-crypto/rng-lwt.nix +++ b/pkgs/development/ocaml-modules/mirage-crypto/rng-lwt.nix @@ -1,5 +1,13 @@ -{ buildDunePackage, mirage-crypto, mirage-crypto-rng, dune-configurator -, duration, logs, mtime, lwt }: +{ + buildDunePackage, + mirage-crypto, + mirage-crypto-rng, + dune-configurator, + duration, + logs, + mtime, + lwt, +}: buildDunePackage rec { pname = "mirage-crypto-rng-lwt"; @@ -11,7 +19,14 @@ buildDunePackage rec { doCheck = true; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ mirage-crypto mirage-crypto-rng duration logs mtime lwt ]; + propagatedBuildInputs = [ + mirage-crypto + mirage-crypto-rng + duration + logs + mtime + lwt + ]; meta = mirage-crypto-rng.meta; } diff --git a/pkgs/development/ocaml-modules/mirage-crypto/rng-mirage.nix b/pkgs/development/ocaml-modules/mirage-crypto/rng-mirage.nix index 78c64d98129732..60da0b042b4a4d 100644 --- a/pkgs/development/ocaml-modules/mirage-crypto/rng-mirage.nix +++ b/pkgs/development/ocaml-modules/mirage-crypto/rng-mirage.nix @@ -1,7 +1,16 @@ -{ buildDunePackage, mirage-crypto-rng, duration, mirage-runtime -, mirage-time, mirage-clock, mirage-unix, mirage-time-unix, mirage-clock-unix -, logs, lwt -, ohex +{ + buildDunePackage, + mirage-crypto-rng, + duration, + mirage-runtime, + mirage-time, + mirage-clock, + mirage-unix, + mirage-time-unix, + mirage-clock-unix, + logs, + lwt, + ohex, }: buildDunePackage rec { @@ -10,10 +19,22 @@ buildDunePackage rec { inherit (mirage-crypto-rng) version src; doCheck = true; - checkInputs = [ mirage-unix mirage-clock-unix mirage-time-unix ohex ]; + checkInputs = [ + mirage-unix + mirage-clock-unix + mirage-time-unix + ohex + ]; - propagatedBuildInputs = [ duration mirage-crypto-rng mirage-runtime - mirage-time mirage-clock logs lwt ]; + propagatedBuildInputs = [ + duration + mirage-crypto-rng + mirage-runtime + mirage-time + mirage-clock + logs + lwt + ]; meta = mirage-crypto-rng.meta // { description = "Entropy collection for a cryptographically secure PRNG"; diff --git a/pkgs/development/ocaml-modules/mirage-crypto/rng.nix b/pkgs/development/ocaml-modules/mirage-crypto/rng.nix index b1c4be4a623447..c91c80a893c406 100644 --- a/pkgs/development/ocaml-modules/mirage-crypto/rng.nix +++ b/pkgs/development/ocaml-modules/mirage-crypto/rng.nix @@ -1,5 +1,14 @@ -{ buildDunePackage, mirage-crypto, ohex, ounit2, randomconv, dune-configurator -, digestif, duration, logs }: +{ + buildDunePackage, + mirage-crypto, + ohex, + ounit2, + randomconv, + dune-configurator, + digestif, + duration, + logs, +}: buildDunePackage rec { pname = "mirage-crypto-rng"; @@ -7,10 +16,19 @@ buildDunePackage rec { inherit (mirage-crypto) version src; doCheck = true; - checkInputs = [ ohex ounit2 randomconv ]; + checkInputs = [ + ohex + ounit2 + randomconv + ]; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ digestif mirage-crypto duration logs ]; + propagatedBuildInputs = [ + digestif + mirage-crypto + duration + logs + ]; meta = mirage-crypto.meta // { description = "Cryptographically secure PRNG"; diff --git a/pkgs/development/ocaml-modules/mirage-device/default.nix b/pkgs/development/ocaml-modules/mirage-device/default.nix index d233277b7a7949..dd036c033c223e 100644 --- a/pkgs/development/ocaml-modules/mirage-device/default.nix +++ b/pkgs/development/ocaml-modules/mirage-device/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchurl, fmt, ocaml_lwt }: +{ + lib, + buildDunePackage, + fetchurl, + fmt, + ocaml_lwt, +}: buildDunePackage rec { pname = "mirage-device"; @@ -11,7 +17,10 @@ buildDunePackage rec { sha256 = "18alxyi6wlxqvb4lajjlbdfkgcajsmklxi9xqmpcz07j51knqa04"; }; - propagatedBuildInputs = [ fmt ocaml_lwt ]; + propagatedBuildInputs = [ + fmt + ocaml_lwt + ]; meta = { description = "Abstract devices for MirageOS"; @@ -20,5 +29,3 @@ buildDunePackage rec { maintainers = [ lib.maintainers.vbgl ]; }; } - - diff --git a/pkgs/development/ocaml-modules/mirage-flow/combinators.nix b/pkgs/development/ocaml-modules/mirage-flow/combinators.nix index 290787bf639fdb..9370117bcc10a0 100644 --- a/pkgs/development/ocaml-modules/mirage-flow/combinators.nix +++ b/pkgs/development/ocaml-modules/mirage-flow/combinators.nix @@ -1,4 +1,11 @@ -{ buildDunePackage, mirage-flow, lwt, logs, cstruct, mirage-clock }: +{ + buildDunePackage, + mirage-flow, + lwt, + logs, + cstruct, + mirage-clock, +}: buildDunePackage { pname = "mirage-flow-combinators"; @@ -7,7 +14,13 @@ buildDunePackage { duneVersion = "3"; - propagatedBuildInputs = [ lwt logs cstruct mirage-clock mirage-flow ]; + propagatedBuildInputs = [ + lwt + logs + cstruct + mirage-clock + mirage-flow + ]; meta = mirage-flow.meta // { description = "Flow implementations and combinators for MirageOS specialized to lwt"; diff --git a/pkgs/development/ocaml-modules/mirage-flow/default.nix b/pkgs/development/ocaml-modules/mirage-flow/default.nix index d95104c3c6b6e0..c1239ce00f259c 100644 --- a/pkgs/development/ocaml-modules/mirage-flow/default.nix +++ b/pkgs/development/ocaml-modules/mirage-flow/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchurl, cstruct, fmt, lwt }: +{ + lib, + buildDunePackage, + fetchurl, + cstruct, + fmt, + lwt, +}: buildDunePackage rec { pname = "mirage-flow"; @@ -11,7 +18,11 @@ buildDunePackage rec { hash = "sha256-SGXj3S4b53O9JENUFuMl3I+QoiZ0QSrYu7zTet7q+1o="; }; - propagatedBuildInputs = [ cstruct fmt lwt ]; + propagatedBuildInputs = [ + cstruct + fmt + lwt + ]; meta = { description = "Flow implementations and combinators for MirageOS"; @@ -20,5 +31,3 @@ buildDunePackage rec { maintainers = [ lib.maintainers.vbgl ]; }; } - - diff --git a/pkgs/development/ocaml-modules/mirage-flow/unix.nix b/pkgs/development/ocaml-modules/mirage-flow/unix.nix index 12681911a3de11..3571676f395d5b 100644 --- a/pkgs/development/ocaml-modules/mirage-flow/unix.nix +++ b/pkgs/development/ocaml-modules/mirage-flow/unix.nix @@ -1,5 +1,12 @@ -{ buildDunePackage, fmt, logs, mirage-flow, ocaml_lwt, cstruct -, alcotest, mirage-flow-combinators +{ + buildDunePackage, + fmt, + logs, + mirage-flow, + ocaml_lwt, + cstruct, + alcotest, + mirage-flow-combinators, }: buildDunePackage { @@ -14,10 +21,19 @@ buildDunePackage { substituteInPlace test/test.ml --replace 'Fmt.kstrf Alcotest.fail' 'Fmt.kstrf (fun s -> Alcotest.fail s)' ''; - propagatedBuildInputs = [ fmt logs mirage-flow ocaml_lwt cstruct ]; + propagatedBuildInputs = [ + fmt + logs + mirage-flow + ocaml_lwt + cstruct + ]; doCheck = true; - checkInputs = [ alcotest mirage-flow-combinators ]; + checkInputs = [ + alcotest + mirage-flow-combinators + ]; meta = mirage-flow.meta // { description = "Flow implementations and combinators for MirageOS on Unix"; diff --git a/pkgs/development/ocaml-modules/mirage-kv/default.nix b/pkgs/development/ocaml-modules/mirage-kv/default.nix index 97eb3128e15b81..cdcde9fee32256 100644 --- a/pkgs/development/ocaml-modules/mirage-kv/default.nix +++ b/pkgs/development/ocaml-modules/mirage-kv/default.nix @@ -1,9 +1,12 @@ -{ lib, fetchurl, buildDunePackage -, fmt -, lwt -, optint -, ptime -, alcotest +{ + lib, + fetchurl, + buildDunePackage, + fmt, + lwt, + optint, + ptime, + alcotest, }: buildDunePackage rec { @@ -17,7 +20,12 @@ buildDunePackage rec { hash = "sha256-fNXNlaDpb5zUA2rTwi5h1j4v4LQmovxG+Am6u+1guPQ="; }; - propagatedBuildInputs = [ fmt lwt optint ptime ]; + propagatedBuildInputs = [ + fmt + lwt + optint + ptime + ]; doCheck = true; checkInputs = [ alcotest ]; diff --git a/pkgs/development/ocaml-modules/mirage-logs/default.nix b/pkgs/development/ocaml-modules/mirage-logs/default.nix index ef842ec7318f23..c5200e186a7e90 100644 --- a/pkgs/development/ocaml-modules/mirage-logs/default.nix +++ b/pkgs/development/ocaml-modules/mirage-logs/default.nix @@ -1,6 +1,14 @@ -{ lib, fetchurl, buildDunePackage -, logs, fmt, ptime, mirage-clock, cmdliner -, lwt, alcotest +{ + lib, + fetchurl, + buildDunePackage, + logs, + fmt, + ptime, + mirage-clock, + cmdliner, + lwt, + alcotest, }: buildDunePackage rec { @@ -14,10 +22,19 @@ buildDunePackage rec { hash = "sha256-rorCsgw7QCQmjotr465KShQGWdoUM88djpwgqwBGnLs="; }; - propagatedBuildInputs = [ logs fmt ptime mirage-clock cmdliner ]; + propagatedBuildInputs = [ + logs + fmt + ptime + mirage-clock + cmdliner + ]; doCheck = true; - checkInputs = [ lwt alcotest ]; + checkInputs = [ + lwt + alcotest + ]; meta = { description = "Reporter for the Logs library that writes log messages to stderr, using a Mirage `CLOCK` to add timestamps"; diff --git a/pkgs/development/ocaml-modules/mirage-nat/default.nix b/pkgs/development/ocaml-modules/mirage-nat/default.nix index f0a89f37f418d8..4515507c5cfaa6 100644 --- a/pkgs/development/ocaml-modules/mirage-nat/default.nix +++ b/pkgs/development/ocaml-modules/mirage-nat/default.nix @@ -1,7 +1,15 @@ -{ lib, buildDunePackage, fetchurl -, ipaddr, cstruct, logs, lru -, tcpip, ethernet -, alcotest, mirage-clock-unix +{ + lib, + buildDunePackage, + fetchurl, + ipaddr, + cstruct, + logs, + lru, + tcpip, + ethernet, + alcotest, + mirage-clock-unix, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/mirage-net-xen/default.nix b/pkgs/development/ocaml-modules/mirage-net-xen/default.nix index 766db21c90abb6..7ed0187355227d 100644 --- a/pkgs/development/ocaml-modules/mirage-net-xen/default.nix +++ b/pkgs/development/ocaml-modules/mirage-net-xen/default.nix @@ -1,13 +1,14 @@ -{ buildDunePackage -, netchannel -, ppx_sexp_conv -, lwt -, cstruct -, mirage-net -, mirage-xen -, io-page -, lwt-dllist -, logs +{ + buildDunePackage, + netchannel, + ppx_sexp_conv, + lwt, + cstruct, + mirage-net, + mirage-xen, + io-page, + lwt-dllist, + logs, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/mirage-net/default.nix b/pkgs/development/ocaml-modules/mirage-net/default.nix index bf4992df76f438..ef8aefa2db5315 100644 --- a/pkgs/development/ocaml-modules/mirage-net/default.nix +++ b/pkgs/development/ocaml-modules/mirage-net/default.nix @@ -1,5 +1,12 @@ -{ lib, fetchurl, buildDunePackage -, cstruct, fmt, lwt, macaddr, mirage-device +{ + lib, + fetchurl, + buildDunePackage, + cstruct, + fmt, + lwt, + macaddr, + mirage-device, }: buildDunePackage rec { @@ -13,7 +20,13 @@ buildDunePackage rec { hash = "sha256-Zo7/0Ye4GgqzJFCHDBXbuJ/5ETl/8ziolRgH4lDhlM4="; }; - propagatedBuildInputs = [ cstruct fmt lwt macaddr mirage-device ]; + propagatedBuildInputs = [ + cstruct + fmt + lwt + macaddr + mirage-device + ]; meta = { description = "Network signatures for MirageOS"; diff --git a/pkgs/development/ocaml-modules/mirage-profile/default.nix b/pkgs/development/ocaml-modules/mirage-profile/default.nix index 2aba97944e17e3..f363df5136ed35 100644 --- a/pkgs/development/ocaml-modules/mirage-profile/default.nix +++ b/pkgs/development/ocaml-modules/mirage-profile/default.nix @@ -1,6 +1,11 @@ -{ lib, fetchurl, buildDunePackage -, ppx_cstruct, stdlib-shims -, cstruct, lwt +{ + lib, + fetchurl, + buildDunePackage, + ppx_cstruct, + stdlib-shims, + cstruct, + lwt, }: buildDunePackage rec { @@ -15,7 +20,11 @@ buildDunePackage rec { }; buildInputs = [ ppx_cstruct ]; - propagatedBuildInputs = [ cstruct lwt stdlib-shims ]; + propagatedBuildInputs = [ + cstruct + lwt + stdlib-shims + ]; meta = with lib; { description = "Collect runtime profiling information in CTF format"; diff --git a/pkgs/development/ocaml-modules/mirage-protocols/default.nix b/pkgs/development/ocaml-modules/mirage-protocols/default.nix index 2c80507051e5f1..c0d375a3c627b8 100644 --- a/pkgs/development/ocaml-modules/mirage-protocols/default.nix +++ b/pkgs/development/ocaml-modules/mirage-protocols/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildDunePackage -, fetchurl -, arp -, ethernet -, ipaddr -, tcpip +{ + lib, + buildDunePackage, + fetchurl, + arp, + ethernet, + ipaddr, + tcpip, }: buildDunePackage rec { @@ -18,7 +19,12 @@ buildDunePackage rec { hash = "sha256-UDCR4Jq3tw9P/Ilw7T4+3+yi9Q7VFqnHhXeSCvg9dyw="; }; - propagatedBuildInputs = [ arp ethernet ipaddr tcpip ]; + propagatedBuildInputs = [ + arp + ethernet + ipaddr + tcpip + ]; meta = { description = "MirageOS signatures for network protocols"; @@ -27,5 +33,3 @@ buildDunePackage rec { maintainers = [ lib.maintainers.vbgl ]; }; } - - diff --git a/pkgs/development/ocaml-modules/mirage-random-test/default.nix b/pkgs/development/ocaml-modules/mirage-random-test/default.nix index 24339b49568cca..545f4f1d2e9a34 100644 --- a/pkgs/development/ocaml-modules/mirage-random-test/default.nix +++ b/pkgs/development/ocaml-modules/mirage-random-test/default.nix @@ -1,5 +1,9 @@ -{ lib, buildDunePackage, fetchurl -, cstruct, mirage-random +{ + lib, + buildDunePackage, + fetchurl, + cstruct, + mirage-random, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/mirage-random/default.nix b/pkgs/development/ocaml-modules/mirage-random/default.nix index ba70665c6edefe..e016f47cd0d549 100644 --- a/pkgs/development/ocaml-modules/mirage-random/default.nix +++ b/pkgs/development/ocaml-modules/mirage-random/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchurl, cstruct }: +{ + lib, + buildDunePackage, + fetchurl, + cstruct, +}: buildDunePackage rec { pname = "mirage-random"; diff --git a/pkgs/development/ocaml-modules/mirage-time/default.nix b/pkgs/development/ocaml-modules/mirage-time/default.nix index 6b4b5f9ac7212d..5daedf448f3351 100644 --- a/pkgs/development/ocaml-modules/mirage-time/default.nix +++ b/pkgs/development/ocaml-modules/mirage-time/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchurl, lwt }: +{ + lib, + buildDunePackage, + fetchurl, + lwt, +}: buildDunePackage rec { minimalOCamlVersion = "4.08"; diff --git a/pkgs/development/ocaml-modules/mirage-time/unix.nix b/pkgs/development/ocaml-modules/mirage-time/unix.nix index 5771a3e2deeac3..4502f6f1c03c72 100644 --- a/pkgs/development/ocaml-modules/mirage-time/unix.nix +++ b/pkgs/development/ocaml-modules/mirage-time/unix.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, mirage-time, lwt, duration }: +{ + buildDunePackage, + mirage-time, + lwt, + duration, +}: buildDunePackage { pname = "mirage-time-unix"; @@ -6,7 +11,11 @@ buildDunePackage { inherit (mirage-time) src version; duneVersion = "3"; - propagatedBuildInputs = [ mirage-time lwt duration ]; + propagatedBuildInputs = [ + mirage-time + lwt + duration + ]; meta = mirage-time.meta // { description = "Time operations for MirageOS on Unix"; diff --git a/pkgs/development/ocaml-modules/mirage-unix/default.nix b/pkgs/development/ocaml-modules/mirage-unix/default.nix index c0ce9fec102c77..16df20d6f3f193 100644 --- a/pkgs/development/ocaml-modules/mirage-unix/default.nix +++ b/pkgs/development/ocaml-modules/mirage-unix/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchurl, lwt, duration, mirage-runtime }: +{ + lib, + buildDunePackage, + fetchurl, + lwt, + duration, + mirage-runtime, +}: buildDunePackage rec { pname = "mirage-unix"; @@ -11,7 +18,11 @@ buildDunePackage rec { hash = "sha256-U1oLznUDBcJLcVygfSiyl5qRLDM27cm/WrjT0vSGhPg="; }; - propagatedBuildInputs = [ lwt duration mirage-runtime ]; + propagatedBuildInputs = [ + lwt + duration + mirage-runtime + ]; doCheck = true; meta = with lib; { diff --git a/pkgs/development/ocaml-modules/mirage-vnetif/default.nix b/pkgs/development/ocaml-modules/mirage-vnetif/default.nix index 95a1e585754e3e..42378cd72a5b40 100644 --- a/pkgs/development/ocaml-modules/mirage-vnetif/default.nix +++ b/pkgs/development/ocaml-modules/mirage-vnetif/default.nix @@ -1,7 +1,14 @@ -{ lib, buildDunePackage, fetchurl -, lwt, mirage-net -, cstruct, ipaddr, macaddr -, duration, logs +{ + lib, + buildDunePackage, + fetchurl, + lwt, + mirage-net, + cstruct, + ipaddr, + macaddr, + duration, + logs, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/mirage-xen/default.nix b/pkgs/development/ocaml-modules/mirage-xen/default.nix index 8f174f01ccb94e..184abc551f731f 100644 --- a/pkgs/development/ocaml-modules/mirage-xen/default.nix +++ b/pkgs/development/ocaml-modules/mirage-xen/default.nix @@ -1,18 +1,19 @@ -{ lib -, buildDunePackage -, fetchurl -, cstruct -, lwt -, shared-memory-ring-lwt -, xenstore -, lwt-dllist -, mirage-profile -, mirage-runtime -, logs -, fmt -, bheap -, duration -, io-page +{ + lib, + buildDunePackage, + fetchurl, + cstruct, + lwt, + shared-memory-ring-lwt, + xenstore, + lwt-dllist, + mirage-profile, + mirage-runtime, + logs, + fmt, + bheap, + duration, + io-page, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/mirage/default.nix b/pkgs/development/ocaml-modules/mirage/default.nix index 3317a51cf3a491..018f818d6350f1 100644 --- a/pkgs/development/ocaml-modules/mirage/default.nix +++ b/pkgs/development/ocaml-modules/mirage/default.nix @@ -1,6 +1,14 @@ -{ buildDunePackage, ocaml, alcotest -, functoria, mirage-runtime, bos -, ipaddr, astring, logs, stdlib-shims +{ + buildDunePackage, + ocaml, + alcotest, + functoria, + mirage-runtime, + bos, + ipaddr, + astring, + logs, + stdlib-shims, }: buildDunePackage rec { @@ -9,7 +17,10 @@ buildDunePackage rec { minimalOCamlVersion = "4.08"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; propagatedBuildInputs = [ ipaddr diff --git a/pkgs/development/ocaml-modules/mirage/runtime.nix b/pkgs/development/ocaml-modules/mirage/runtime.nix index d3b847d6da477c..399a68b2630d6f 100644 --- a/pkgs/development/ocaml-modules/mirage/runtime.nix +++ b/pkgs/development/ocaml-modules/mirage/runtime.nix @@ -1,6 +1,11 @@ -{ lib, buildDunePackage, ipaddr, functoria-runtime -, logs, lwt -, alcotest +{ + lib, + buildDunePackage, + ipaddr, + functoria-runtime, + logs, + lwt, + alcotest, }: buildDunePackage rec { @@ -9,7 +14,12 @@ buildDunePackage rec { minimalOCamlVersion = "4.08"; - propagatedBuildInputs = [ ipaddr functoria-runtime logs lwt ]; + propagatedBuildInputs = [ + ipaddr + functoria-runtime + logs + lwt + ]; checkInputs = [ alcotest ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/mldoc/default.nix b/pkgs/development/ocaml-modules/mldoc/default.nix index b66617f7d28603..20398177d13532 100644 --- a/pkgs/development/ocaml-modules/mldoc/default.nix +++ b/pkgs/development/ocaml-modules/mldoc/default.nix @@ -1,19 +1,20 @@ -{ lib -, buildDunePackage -, fetchFromGitHub -, fetchpatch -, angstrom -, cmdliner -, core -, core_bench -, core_unix ? null -, js_of_ocaml -, js_of_ocaml-ppx -, ppx_deriving_yojson -, uri -, yojson -, lwt -, xmlm +{ + lib, + buildDunePackage, + fetchFromGitHub, + fetchpatch, + angstrom, + cmdliner, + core, + core_bench, + core_unix ? null, + js_of_ocaml, + js_of_ocaml-ppx, + ppx_deriving_yojson, + uri, + yojson, + lwt, + xmlm, }: let angstrom' = angstrom.overrideAttrs (attrs: { diff --git a/pkgs/development/ocaml-modules/mlgmpidl/default.nix b/pkgs/development/ocaml-modules/mlgmpidl/default.nix index c28a6fba99029e..ee578464641f7d 100644 --- a/pkgs/development/ocaml-modules/mlgmpidl/default.nix +++ b/pkgs/development/ocaml-modules/mlgmpidl/default.nix @@ -1,4 +1,15 @@ -{ stdenv, lib, fetchFromGitHub, perl, ocaml, findlib, camlidl, gmp, mpfr, bigarray-compat }: +{ + stdenv, + lib, + fetchFromGitHub, + perl, + ocaml, + findlib, + camlidl, + gmp, + mpfr, + bigarray-compat, +}: stdenv.mkDerivation rec { pname = "ocaml${ocaml.version}-mlgmpidl"; @@ -10,8 +21,16 @@ stdenv.mkDerivation rec { hash = "sha256-ZmSDKZiHko8MCeIuZL53HjupfwO6PAm8QOCc9O3xJOk="; }; - nativeBuildInputs = [ perl ocaml findlib camlidl ]; - buildInputs = [ gmp mpfr ]; + nativeBuildInputs = [ + perl + ocaml + findlib + camlidl + ]; + buildInputs = [ + gmp + mpfr + ]; propagatedBuildInputs = [ bigarray-compat ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/mm/default.nix b/pkgs/development/ocaml-modules/mm/default.nix index b0896d2fd6a756..f7e3eb32337120 100644 --- a/pkgs/development/ocaml-modules/mm/default.nix +++ b/pkgs/development/ocaml-modules/mm/default.nix @@ -1,5 +1,13 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator -, alsa, ao, mad, pulseaudio, theora +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + alsa, + ao, + mad, + pulseaudio, + theora, }: buildDunePackage rec { @@ -18,7 +26,13 @@ buildDunePackage rec { }; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ alsa ao mad pulseaudio theora ]; # ocamlsdl is blocked in nixpkgs from building for ocaml >= 4.06 + propagatedBuildInputs = [ + alsa + ao + mad + pulseaudio + theora + ]; # ocamlsdl is blocked in nixpkgs from building for ocaml >= 4.06 meta = with lib; { homepage = "https://github.com/savonet/ocaml-mm"; diff --git a/pkgs/development/ocaml-modules/mmap/default.nix b/pkgs/development/ocaml-modules/mmap/default.nix index b13639150b0d9b..ea9740494ad76a 100644 --- a/pkgs/development/ocaml-modules/mmap/default.nix +++ b/pkgs/development/ocaml-modules/mmap/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "mmap"; diff --git a/pkgs/development/ocaml-modules/morbig/default.nix b/pkgs/development/ocaml-modules/morbig/default.nix index 6b8adcf7429c1b..76150f19cf180a 100644 --- a/pkgs/development/ocaml-modules/morbig/default.nix +++ b/pkgs/development/ocaml-modules/morbig/default.nix @@ -1,5 +1,12 @@ -{ lib, buildDunePackage, fetchFromGitHub -, menhir, menhirLib, ppx_deriving_yojson, visitors, yojson +{ + lib, + buildDunePackage, + fetchFromGitHub, + menhir, + menhirLib, + ppx_deriving_yojson, + visitors, + yojson, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/mparser/default.nix b/pkgs/development/ocaml-modules/mparser/default.nix index 602545382bc412..d9fa6326e93f88 100644 --- a/pkgs/development/ocaml-modules/mparser/default.nix +++ b/pkgs/development/ocaml-modules/mparser/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage }: +{ + lib, + fetchFromGitHub, + buildDunePackage, +}: buildDunePackage rec { pname = "mparser"; diff --git a/pkgs/development/ocaml-modules/mparser/pcre.nix b/pkgs/development/ocaml-modules/mparser/pcre.nix index 6656deef147106..86ddc6c8c3c22b 100644 --- a/pkgs/development/ocaml-modules/mparser/pcre.nix +++ b/pkgs/development/ocaml-modules/mparser/pcre.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, ocaml_pcre, mparser }: +{ + buildDunePackage, + ocaml_pcre, + mparser, +}: buildDunePackage rec { pname = "mparser-pcre"; @@ -6,7 +10,12 @@ buildDunePackage rec { inherit (mparser) src version; - propagatedBuildInputs = [ ocaml_pcre mparser ]; + propagatedBuildInputs = [ + ocaml_pcre + mparser + ]; - meta = mparser.meta // { description = "PCRE-based regular expressions"; }; + meta = mparser.meta // { + description = "PCRE-based regular expressions"; + }; } diff --git a/pkgs/development/ocaml-modules/mrmime/default.nix b/pkgs/development/ocaml-modules/mrmime/default.nix index 758d27e45f1cea..b9a72244300c60 100644 --- a/pkgs/development/ocaml-modules/mrmime/default.nix +++ b/pkgs/development/ocaml-modules/mrmime/default.nix @@ -1,26 +1,27 @@ -{ afl-persistent -, alcotest -, angstrom -, base64 -, bigarray-overlap -, bigstringaf -, buildDunePackage -, cmdliner -, emile -, fetchurl -, fpath -, hxd -, ipaddr -, jsonm -, ke -, lib -, mirage-crypto-rng -, pecu -, prettym -, ptime -, rosetta -, unstrctrd -, uutf +{ + afl-persistent, + alcotest, + angstrom, + base64, + bigarray-overlap, + bigstringaf, + buildDunePackage, + cmdliner, + emile, + fetchurl, + fpath, + hxd, + ipaddr, + jsonm, + ke, + lib, + mirage-crypto-rng, + pecu, + prettym, + ptime, + rosetta, + unstrctrd, + uutf, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/msat/default.nix b/pkgs/development/ocaml-modules/msat/default.nix index 7cb512a942d11c..43d9d0e776940e 100644 --- a/pkgs/development/ocaml-modules/msat/default.nix +++ b/pkgs/development/ocaml-modules/msat/default.nix @@ -1,7 +1,10 @@ -{ lib, fetchFromGitHub, buildDunePackage -, iter -, containers -, mdx +{ + lib, + fetchFromGitHub, + buildDunePackage, + iter, + containers, + mdx, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/msgpck/default.nix b/pkgs/development/ocaml-modules/msgpck/default.nix index a766f249136673..bfee304681bb64 100644 --- a/pkgs/development/ocaml-modules/msgpck/default.nix +++ b/pkgs/development/ocaml-modules/msgpck/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, ocplib-endian -, alcotest +{ + lib, + fetchFromGitHub, + buildDunePackage, + ocplib-endian, + alcotest, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/mtime/default.nix b/pkgs/development/ocaml-modules/mtime/default.nix index 902a1dbeefc753..4c6677114b0916 100644 --- a/pkgs/development/ocaml-modules/mtime/default.nix +++ b/pkgs/development/ocaml-modules/mtime/default.nix @@ -1,29 +1,43 @@ -{ stdenv, lib, fetchurl, ocaml, findlib, ocamlbuild, topkg }: +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, +}: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.08") "mtime is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-mtime"; - version = "2.1.0"; + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-mtime"; + version = "2.1.0"; - src = fetchurl { - url = "https://erratique.ch/software/mtime/releases/mtime-${version}.tbz"; - sha256 = "sha256-CXyygC43AerZVy4bSD1aKMbi8KOUSfqvm0StiomDTYg="; - }; + src = fetchurl { + url = "https://erratique.ch/software/mtime/releases/mtime-${version}.tbz"; + sha256 = "sha256-CXyygC43AerZVy4bSD1aKMbi8KOUSfqvm0StiomDTYg="; + }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ topkg ]; - strictDeps = true; + strictDeps = true; - inherit (topkg) buildPhase installPhase; + inherit (topkg) buildPhase installPhase; - meta = with lib; { - description = "Monotonic wall-clock time for OCaml"; - homepage = "https://erratique.ch/software/mtime"; - inherit (ocaml.meta) platforms; - maintainers = [ maintainers.vbgl ]; - license = licenses.bsd3; - }; -} + meta = with lib; { + description = "Monotonic wall-clock time for OCaml"; + homepage = "https://erratique.ch/software/mtime"; + inherit (ocaml.meta) platforms; + maintainers = [ maintainers.vbgl ]; + license = licenses.bsd3; + }; + } diff --git a/pkgs/development/ocaml-modules/multicore-bench/default.nix b/pkgs/development/ocaml-modules/multicore-bench/default.nix index 5e1d2275e5b601..7f367f983eeaca 100644 --- a/pkgs/development/ocaml-modules/multicore-bench/default.nix +++ b/pkgs/development/ocaml-modules/multicore-bench/default.nix @@ -1,5 +1,11 @@ -{ lib, buildDunePackage, fetchurl -, domain-local-await, mtime, multicore-magic, yojson +{ + lib, + buildDunePackage, + fetchurl, + domain-local-await, + mtime, + multicore-magic, + yojson, }: buildDunePackage rec { @@ -11,7 +17,12 @@ buildDunePackage rec { hash = "sha256-iCx5QvhYo/e53cW23Sza2as4aez4HeESVvLPF1DW85A="; }; - propagatedBuildInputs = [ domain-local-await mtime multicore-magic yojson ]; + propagatedBuildInputs = [ + domain-local-await + mtime + multicore-magic + yojson + ]; meta = { description = "Framework for writing multicore benchmark executables to run on current-bench"; diff --git a/pkgs/development/ocaml-modules/multicore-magic/default.nix b/pkgs/development/ocaml-modules/multicore-magic/default.nix index 3082eece19cf12..534d47dfaa56c1 100644 --- a/pkgs/development/ocaml-modules/multicore-magic/default.nix +++ b/pkgs/development/ocaml-modules/multicore-magic/default.nix @@ -1,5 +1,9 @@ -{ lib, buildDunePackage, fetchurl -, alcotest, domain_shims +{ + lib, + buildDunePackage, + fetchurl, + alcotest, + domain_shims, }: buildDunePackage rec { @@ -13,7 +17,10 @@ buildDunePackage rec { doCheck = true; - checkInputs = [ alcotest domain_shims ]; + checkInputs = [ + alcotest + domain_shims + ]; meta = { description = "Low-level multicore utilities for OCaml"; diff --git a/pkgs/development/ocaml-modules/multipart-form-data/default.nix b/pkgs/development/ocaml-modules/multipart-form-data/default.nix index 4d44f3b977635f..fc5e9a0bbf6d34 100644 --- a/pkgs/development/ocaml-modules/multipart-form-data/default.nix +++ b/pkgs/development/ocaml-modules/multipart-form-data/default.nix @@ -1,6 +1,12 @@ -{ lib, fetchFromGitHub, buildDunePackage -, lwt, lwt_ppx, stringext -, alcotest }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + lwt, + lwt_ppx, + stringext, + alcotest, +}: buildDunePackage rec { pname = "multipart-form-data"; @@ -14,7 +20,10 @@ buildDunePackage rec { }; buildInputs = [ lwt_ppx ]; - propagatedBuildInputs = [ lwt stringext ]; + propagatedBuildInputs = [ + lwt + stringext + ]; duneVersion = "3"; diff --git a/pkgs/development/ocaml-modules/mustache/default.nix b/pkgs/development/ocaml-modules/mustache/default.nix index ce2201c37873fd..cefb4d3c1b77b4 100644 --- a/pkgs/development/ocaml-modules/mustache/default.nix +++ b/pkgs/development/ocaml-modules/mustache/default.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, fetchFromGitHub, ezjsonm, menhir, menhirLib, ounit }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + ezjsonm, + menhir, + menhirLib, + ounit, +}: buildDunePackage rec { pname = "mustache"; diff --git a/pkgs/development/ocaml-modules/mysql/default.nix b/pkgs/development/ocaml-modules/mysql/default.nix index c980984a26c8cc..0bd9a412a31649 100644 --- a/pkgs/development/ocaml-modules/mysql/default.nix +++ b/pkgs/development/ocaml-modules/mysql/default.nix @@ -1,4 +1,12 @@ -{ stdenv, lib, fetchurl, fetchpatch, ocaml, findlib, libmysqlclient }: +{ + stdenv, + lib, + fetchurl, + fetchpatch, + ocaml, + findlib, + libmysqlclient, +}: # TODO: la versione stabile da' un errore di compilazione dovuto a # qualche cambiamento negli header .h @@ -18,11 +26,14 @@ stdenv.mkDerivation rec { }; configureFlags = [ - "--prefix=$out" - "--libdir=$out/lib/ocaml/${ocaml.version}/site-lib/mysql" + "--prefix=$out" + "--libdir=$out/lib/ocaml/${ocaml.version}/site-lib/mysql" ]; - nativeBuildInputs = [ ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; createFindlibDestdir = true; diff --git a/pkgs/development/ocaml-modules/netchannel/default.nix b/pkgs/development/ocaml-modules/netchannel/default.nix index 8b0dbec39276ab..9e4f8015b557a0 100644 --- a/pkgs/development/ocaml-modules/netchannel/default.nix +++ b/pkgs/development/ocaml-modules/netchannel/default.nix @@ -1,20 +1,21 @@ -{ lib -, buildDunePackage -, fetchurl -, ppx_sexp_conv -, ppx_cstruct -, lwt -, mirage-net -, io-page -, mirage-xen -, ipaddr -, mirage-profile -, shared-memory-ring -, sexplib -, logs -, macaddr -, lwt-dllist -, result +{ + lib, + buildDunePackage, + fetchurl, + ppx_sexp_conv, + ppx_cstruct, + lwt, + mirage-net, + io-page, + mirage-xen, + ipaddr, + mirage-profile, + shared-memory-ring, + sexplib, + logs, + macaddr, + lwt-dllist, + result, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ninja_utils/default.nix b/pkgs/development/ocaml-modules/ninja_utils/default.nix index 2510cc93abbcd2..6d92745caacb40 100644 --- a/pkgs/development/ocaml-modules/ninja_utils/default.nix +++ b/pkgs/development/ocaml-modules/ninja_utils/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchzip, buildDunePackage, re }: +{ + lib, + fetchzip, + buildDunePackage, + re, +}: buildDunePackage rec { pname = "ninja_utils"; diff --git a/pkgs/development/ocaml-modules/nonstd/default.nix b/pkgs/development/ocaml-modules/nonstd/default.nix index 748196bf28e266..7d547d3818f947 100644 --- a/pkgs/development/ocaml-modules/nonstd/default.nix +++ b/pkgs/development/ocaml-modules/nonstd/default.nix @@ -1,27 +1,32 @@ -{ lib, fetchzip, buildDunePackage, ocaml }: +{ + lib, + fetchzip, + buildDunePackage, + ocaml, +}: -lib.throwIf (lib.versionAtLeast ocaml.version "5.0") - "nonstd is not available for OCaml ≥ 5.0" +lib.throwIf (lib.versionAtLeast ocaml.version "5.0") "nonstd is not available for OCaml ≥ 5.0" -buildDunePackage rec { - pname = "nonstd"; - version = "0.0.3"; + buildDunePackage + rec { + pname = "nonstd"; + version = "0.0.3"; - minimalOCamlVersion = "4.02"; + minimalOCamlVersion = "4.02"; - src = fetchzip { - url = "https://bitbucket.org/smondet/${pname}/get/${pname}.${version}.tar.gz"; - sha256 = "0ccjwcriwm8fv29ij1cnbc9win054kb6pfga3ygzdbjpjb778j46"; - }; + src = fetchzip { + url = "https://bitbucket.org/smondet/${pname}/get/${pname}.${version}.tar.gz"; + sha256 = "0ccjwcriwm8fv29ij1cnbc9win054kb6pfga3ygzdbjpjb778j46"; + }; - duneVersion = if lib.versionAtLeast ocaml.version "4.12" then "2" else "1"; - postPatch = lib.optionalString (duneVersion != "1") "dune upgrade"; - doCheck = true; + duneVersion = if lib.versionAtLeast ocaml.version "4.12" then "2" else "1"; + postPatch = lib.optionalString (duneVersion != "1") "dune upgrade"; + doCheck = true; - meta = with lib; { - homepage = "https://bitbucket.org/smondet/nonstd"; - description = "Non-standard mini-library"; - license = licenses.isc; - maintainers = [ maintainers.alexfmpe ]; - }; -} + meta = with lib; { + homepage = "https://bitbucket.org/smondet/nonstd"; + description = "Non-standard mini-library"; + license = licenses.isc; + maintainers = [ maintainers.alexfmpe ]; + }; + } diff --git a/pkgs/development/ocaml-modules/note/default.nix b/pkgs/development/ocaml-modules/note/default.nix index 11ab46a2af0dc6..c5e801456a473c 100644 --- a/pkgs/development/ocaml-modules/note/default.nix +++ b/pkgs/development/ocaml-modules/note/default.nix @@ -1,25 +1,40 @@ -{ stdenv, lib, fetchurl, ocaml, findlib, ocamlbuild, topkg, brr }: +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + brr, +}: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.08") "note is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-note"; - version = "0.0.3"; - src = fetchurl { - url = "https://erratique.ch/software/note/releases/note-${version}.tbz"; - hash = "sha256-ZZOvCnyz7UWzFtGFI1uC0ZApzyylgZYM/HYIXGVXY2k="; - }; - buildInputs = [ ocaml findlib ocamlbuild topkg ]; - inherit (topkg) buildPhase installPhase; + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-note"; + version = "0.0.3"; + src = fetchurl { + url = "https://erratique.ch/software/note/releases/note-${version}.tbz"; + hash = "sha256-ZZOvCnyz7UWzFtGFI1uC0ZApzyylgZYM/HYIXGVXY2k="; + }; + buildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + inherit (topkg) buildPhase installPhase; - propagatedBuildInputs = [ brr ]; + propagatedBuildInputs = [ brr ]; - meta = { - homepage = "https://erratique.ch/software/note"; - description = "OCaml module for functional reactive programming"; - license = lib.licenses.isc; - maintainers = [ lib.maintainers.vbgl ]; - inherit (ocaml.meta) platforms; - }; -} + meta = { + homepage = "https://erratique.ch/software/note"; + description = "OCaml module for functional reactive programming"; + license = lib.licenses.isc; + maintainers = [ lib.maintainers.vbgl ]; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/notty/default.nix b/pkgs/development/ocaml-modules/notty/default.nix index 9bab0482668e7e..26ed24c5f322b2 100644 --- a/pkgs/development/ocaml-modules/notty/default.nix +++ b/pkgs/development/ocaml-modules/notty/default.nix @@ -1,6 +1,10 @@ -{ lib, buildDunePackage, fetchurl, cppo -, uutf -, lwt +{ + lib, + buildDunePackage, + fetchurl, + cppo, + uutf, + lwt, }: buildDunePackage rec { @@ -16,7 +20,10 @@ buildDunePackage rec { nativeBuildInputs = [ cppo ]; - propagatedBuildInputs = [ lwt uutf ]; + propagatedBuildInputs = [ + lwt + uutf + ]; meta = with lib; { homepage = "https://github.com/pqwy/notty"; diff --git a/pkgs/development/ocaml-modules/npy/default.nix b/pkgs/development/ocaml-modules/npy/default.nix index f604780f4769c3..624a97507495d8 100644 --- a/pkgs/development/ocaml-modules/npy/default.nix +++ b/pkgs/development/ocaml-modules/npy/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, numpy, camlzip }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + numpy, + camlzip, +}: buildDunePackage rec { pname = "npy"; @@ -10,8 +16,8 @@ buildDunePackage rec { src = fetchFromGitHub { owner = "LaurentMazare"; - repo = "${pname}-ocaml"; - rev = version; + repo = "${pname}-ocaml"; + rev = version; hash = "sha256:1fryglkm20h6kdqjl55b7065b34bdg3g3p6j0jv33zvd1m5888m1"; }; diff --git a/pkgs/development/ocaml-modules/num/default.nix b/pkgs/development/ocaml-modules/num/default.nix index d41d0f851fa577..98dae8b475bac3 100644 --- a/pkgs/development/ocaml-modules/num/default.nix +++ b/pkgs/development/ocaml-modules/num/default.nix @@ -1,34 +1,48 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, ocaml, findlib, withStatic ? false }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + ocaml, + findlib, + withStatic ? false, +}: -stdenv.mkDerivation (rec { - version = "1.1"; - pname = "ocaml${ocaml.version}-num"; - src = fetchFromGitHub { - owner = "ocaml"; - repo = "num"; - rev = "v${version}"; - sha256 = "0a4mhxgs5hi81d227aygjx35696314swas0vzy3ig809jb7zq4h0"; - }; +stdenv.mkDerivation ( + rec { + version = "1.1"; + pname = "ocaml${ocaml.version}-num"; + src = fetchFromGitHub { + owner = "ocaml"; + repo = "num"; + rev = "v${version}"; + sha256 = "0a4mhxgs5hi81d227aygjx35696314swas0vzy3ig809jb7zq4h0"; + }; - patches = [ (fetchpatch { - url = "https://github.com/ocaml/num/commit/6d4c6d476c061298e6385e8a0864f083194b9307.patch"; - sha256 = "18zlvb5n327q8y3c52js5dvyy29ssld1l53jqng8m9w1k24ypi0b"; - }) - ] ++ lib.optional withStatic ./enable-static.patch; + patches = [ + (fetchpatch { + url = "https://github.com/ocaml/num/commit/6d4c6d476c061298e6385e8a0864f083194b9307.patch"; + sha256 = "18zlvb5n327q8y3c52js5dvyy29ssld1l53jqng8m9w1k24ypi0b"; + }) + ] ++ lib.optional withStatic ./enable-static.patch; - nativeBuildInputs = [ ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; - strictDeps = true; + strictDeps = true; - createFindlibDestdir = true; + createFindlibDestdir = true; - meta = { - description = "Legacy Num library for arbitrary-precision integer and rational arithmetic"; - license = lib.licenses.lgpl21; - inherit (ocaml.meta) platforms; - inherit (src.meta) homepage; - }; -} // (lib.optionalAttrs (lib.versions.majorMinor ocaml.version == "4.06") { + meta = { + description = "Legacy Num library for arbitrary-precision integer and rational arithmetic"; + license = lib.licenses.lgpl21; + inherit (ocaml.meta) platforms; + inherit (src.meta) homepage; + }; + } + // (lib.optionalAttrs (lib.versions.majorMinor ocaml.version == "4.06") { env.NIX_CFLAGS_COMPILE = "-fcommon"; }) ) diff --git a/pkgs/development/ocaml-modules/ocaml-cairo/default.nix b/pkgs/development/ocaml-modules/ocaml-cairo/default.nix index 2c2ffecf3dbae6..6ba132b327291a 100644 --- a/pkgs/development/ocaml-modules/ocaml-cairo/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-cairo/default.nix @@ -1,50 +1,82 @@ -{stdenv, lib, fetchurl, automake, ocaml, autoconf, gnum4, pkg-config, freetype, lablgtk, unzip, cairo, findlib, gdk-pixbuf, gtk2, pango }: +{ + stdenv, + lib, + fetchurl, + automake, + ocaml, + autoconf, + gnum4, + pkg-config, + freetype, + lablgtk, + unzip, + cairo, + findlib, + gdk-pixbuf, + gtk2, + pango, +}: let pname = "ocaml-cairo"; in -if lib.versionAtLeast ocaml.version "4.06" -then throw "${pname} is not available for OCaml ${ocaml.version}" +if lib.versionAtLeast ocaml.version "4.06" then + throw "${pname} is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - name = "${pname}-${version}"; - version = "1.2.0"; + stdenv.mkDerivation rec { + name = "${pname}-${version}"; + version = "1.2.0"; - src = fetchurl { - url = "http://cgit.freedesktop.org/cairo-ocaml/snapshot/cairo-ocaml-${version}.zip"; - sha256 = "0l4p9bp6kclr570mxma8wafibr1g5fsjj8h10yr4b507g0hmlh0l"; - }; + src = fetchurl { + url = "http://cgit.freedesktop.org/cairo-ocaml/snapshot/cairo-ocaml-${version}.zip"; + sha256 = "0l4p9bp6kclr570mxma8wafibr1g5fsjj8h10yr4b507g0hmlh0l"; + }; - patches = [ ./META.patch ]; + patches = [ ./META.patch ]; - strictDeps = true; + strictDeps = true; - nativeBuildInputs = [ pkg-config unzip ocaml automake gnum4 autoconf findlib ]; - buildInputs = [ freetype lablgtk cairo gdk-pixbuf gtk2 pango ]; + nativeBuildInputs = [ + pkg-config + unzip + ocaml + automake + gnum4 + autoconf + findlib + ]; + buildInputs = [ + freetype + lablgtk + cairo + gdk-pixbuf + gtk2 + pango + ]; - createFindlibDestdir = true; + createFindlibDestdir = true; - preConfigure = '' - aclocal -I support - autoconf - export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE `pkg-config --cflags cairo gdk-pixbuf glib gtk+ pango`" - export LABLGTKDIR=${lablgtk}/lib/ocaml/${ocaml.version}/site-lib/lablgtk2 - cp ${lablgtk}/lib/ocaml/${ocaml.version}/site-lib/lablgtk2/pango.ml ./src - cp ${lablgtk}/lib/ocaml/${ocaml.version}/site-lib/lablgtk2/gaux.ml ./src - ''; + preConfigure = '' + aclocal -I support + autoconf + export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE `pkg-config --cflags cairo gdk-pixbuf glib gtk+ pango`" + export LABLGTKDIR=${lablgtk}/lib/ocaml/${ocaml.version}/site-lib/lablgtk2 + cp ${lablgtk}/lib/ocaml/${ocaml.version}/site-lib/lablgtk2/pango.ml ./src + cp ${lablgtk}/lib/ocaml/${ocaml.version}/site-lib/lablgtk2/gaux.ml ./src + ''; - postInstall = '' - cp META $out/lib/ocaml/${ocaml.version}/site-lib/cairo/ - ''; + postInstall = '' + cp META $out/lib/ocaml/${ocaml.version}/site-lib/cairo/ + ''; - makeFlags = [ "INSTALLDIR=$(out)/lib/ocaml/${ocaml.version}/site-lib/cairo" ]; + makeFlags = [ "INSTALLDIR=$(out)/lib/ocaml/${ocaml.version}/site-lib/cairo" ]; - meta = { - homepage = "http://cairographics.org/cairo-ocaml"; - description = "ocaml bindings for cairo library"; - license = lib.licenses.gpl2; - inherit (ocaml.meta) platforms; - }; -} + meta = { + homepage = "http://cairographics.org/cairo-ocaml"; + description = "ocaml bindings for cairo library"; + license = lib.licenses.gpl2; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/ocaml-freestanding/default.nix b/pkgs/development/ocaml-modules/ocaml-freestanding/default.nix index e3627431d95932..1c69c85ab4e268 100644 --- a/pkgs/development/ocaml-modules/ocaml-freestanding/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-freestanding/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, ocaml -, pkg-config -, solo5 -, target ? "xen" +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + pkg-config, + solo5, + target ? "xen", }: # note: this is not technically an ocaml-module, @@ -15,67 +16,78 @@ let pname = "ocaml-freestanding"; in -if lib.versionOlder ocaml.version "4.08" -then builtins.throw "${pname} is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.08" then + builtins.throw "${pname} is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - name = "ocaml${ocaml.version}-${pname}-${version}"; - inherit pname; - version = "0.6.5"; + stdenv.mkDerivation rec { + name = "ocaml${ocaml.version}-${pname}-${version}"; + inherit pname; + version = "0.6.5"; - src = fetchFromGitHub { - owner = "mirage"; - repo = pname; - rev = "v${version}"; - sha256 = "sha256:1mbyjzwcs64n7i3xkkyaxgl3r46drbl0gkqf3fqgm2kh3q03638l"; - }; + src = fetchFromGitHub { + owner = "mirage"; + repo = pname; + rev = "v${version}"; + sha256 = "sha256:1mbyjzwcs64n7i3xkkyaxgl3r46drbl0gkqf3fqgm2kh3q03638l"; + }; - postUnpack = '' - # get ocaml-src from the ocaml drv instead of via ocamlfind - mkdir -p "${src.name}/ocaml" - tar --strip-components=1 -xf ${ocaml.src} -C "${src.name}/ocaml" - ''; + postUnpack = '' + # get ocaml-src from the ocaml drv instead of via ocamlfind + mkdir -p "${src.name}/ocaml" + tar --strip-components=1 -xf ${ocaml.src} -C "${src.name}/ocaml" + ''; - patches = [ - ./no-opam.patch - ./configurable-binding.patch - ]; + patches = [ + ./no-opam.patch + ./configurable-binding.patch + ]; - strictDeps = true; + strictDeps = true; - nativeBuildInputs = [ - ocaml - pkg-config - ]; + nativeBuildInputs = [ + ocaml + pkg-config + ]; - propagatedBuildInputs = [ solo5 ]; + propagatedBuildInputs = [ solo5 ]; - configurePhase = '' - runHook preConfigure - env PKG_CONFIG_DEPS=solo5-bindings-${target} sh configure.sh - runHook postConfigure - ''; + configurePhase = '' + runHook preConfigure + env PKG_CONFIG_DEPS=solo5-bindings-${target} sh configure.sh + runHook postConfigure + ''; - installPhase = '' - runHook preInstall - ./install.sh "$out" - runHook postInstall - ''; + installPhase = '' + runHook preInstall + ./install.sh "$out" + runHook postInstall + ''; - meta = with lib; { - broken = true; # Not compatible with solo5 ≥ 0.7 - description = "Freestanding OCaml runtime"; - license = licenses.mit; - maintainers = [ maintainers.sternenseemann ]; - homepage = "https://github.com/mirage/ocaml-freestanding"; - platforms = builtins.map ({ arch, os }: "${arch}-${os}") - (cartesianProduct { - arch = [ "aarch64" "x86_64" ]; + meta = with lib; { + broken = true; # Not compatible with solo5 ≥ 0.7 + description = "Freestanding OCaml runtime"; + license = licenses.mit; + maintainers = [ maintainers.sternenseemann ]; + homepage = "https://github.com/mirage/ocaml-freestanding"; + platforms = builtins.map ({ arch, os }: "${arch}-${os}") ( + cartesianProduct { + arch = [ + "aarch64" + "x86_64" + ]; os = [ "linux" ]; - } ++ [ - { arch = "x86_64"; os = "freebsd"; } - { arch = "x86_64"; os = "openbsd"; } - ]); - }; -} + } + ++ [ + { + arch = "x86_64"; + os = "freebsd"; + } + { + arch = "x86_64"; + os = "openbsd"; + } + ] + ); + }; + } diff --git a/pkgs/development/ocaml-modules/ocaml-gettext/camomile.nix b/pkgs/development/ocaml-modules/ocaml-gettext/camomile.nix index 3fde1d463cc7b5..14e3aedf49d33d 100644 --- a/pkgs/development/ocaml-modules/ocaml-gettext/camomile.nix +++ b/pkgs/development/ocaml-modules/ocaml-gettext/camomile.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, ocaml, ocaml_gettext, camomile, ounit, fileutils }: +{ + lib, + buildDunePackage, + ocaml, + ocaml_gettext, + camomile, + ounit, + fileutils, +}: buildDunePackage { pname = "gettext-camomile"; @@ -10,7 +18,10 @@ buildDunePackage { ]; doCheck = lib.versionAtLeast ocaml.version "4.08"; - checkInputs = [ ounit fileutils ]; + checkInputs = [ + ounit + fileutils + ]; meta = (builtins.removeAttrs ocaml_gettext.meta [ "mainProgram" ]) // { description = "Internationalization library using camomile (i18n)"; diff --git a/pkgs/development/ocaml-modules/ocaml-gettext/default.nix b/pkgs/development/ocaml-modules/ocaml-gettext/default.nix index c65f5064697464..79330a0999e5a1 100644 --- a/pkgs/development/ocaml-modules/ocaml-gettext/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-gettext/default.nix @@ -1,4 +1,12 @@ -{ lib, fetchurl, buildDunePackage, cppo, gettext, fileutils, ounit }: +{ + lib, + fetchurl, + buildDunePackage, + cppo, + gettext, + fileutils, + ounit, +}: buildDunePackage rec { pname = "gettext"; @@ -13,7 +21,10 @@ buildDunePackage rec { nativeBuildInputs = [ cppo ]; - propagatedBuildInputs = [ gettext fileutils ]; + propagatedBuildInputs = [ + gettext + fileutils + ]; # Tests for version 0.4.2 are not compatible with OUnit 2.2.6 doCheck = false; diff --git a/pkgs/development/ocaml-modules/ocaml-gettext/stub.nix b/pkgs/development/ocaml-modules/ocaml-gettext/stub.nix index 7c197f9e87b0f7..f5e287e87b82ff 100644 --- a/pkgs/development/ocaml-modules/ocaml-gettext/stub.nix +++ b/pkgs/development/ocaml-modules/ocaml-gettext/stub.nix @@ -1,23 +1,31 @@ -{ lib, buildDunePackage, ocaml, ocaml_gettext, dune-configurator, ounit }: +{ + lib, + buildDunePackage, + ocaml, + ocaml_gettext, + dune-configurator, + ounit, +}: lib.throwIf (lib.versionAtLeast ocaml.version "5.0") "gettext-stub is not available for OCaml ${ocaml.version}" -buildDunePackage { + buildDunePackage + { - pname = "gettext-stub"; + pname = "gettext-stub"; - inherit (ocaml_gettext) src version; + inherit (ocaml_gettext) src version; - minimalOCamlVersion = "4.06"; + minimalOCamlVersion = "4.06"; - buildInputs = [ dune-configurator ]; + buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ ocaml_gettext ]; + propagatedBuildInputs = [ ocaml_gettext ]; - doCheck = lib.versionAtLeast ocaml.version "4.08"; + doCheck = lib.versionAtLeast ocaml.version "4.08"; - checkInputs = [ ounit ]; + checkInputs = [ ounit ]; - meta = builtins.removeAttrs ocaml_gettext.meta [ "mainProgram" ]; -} + meta = builtins.removeAttrs ocaml_gettext.meta [ "mainProgram" ]; + } diff --git a/pkgs/development/ocaml-modules/ocaml-libvirt/default.nix b/pkgs/development/ocaml-modules/ocaml-libvirt/default.nix index e27fbca0a4a082..20737655bd21d6 100644 --- a/pkgs/development/ocaml-modules/ocaml-libvirt/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-libvirt/default.nix @@ -1,42 +1,65 @@ -{ lib, stdenv, fetchFromGitLab, libvirt, AppKit, Foundation, autoreconfHook, pkg-config, ocaml, findlib, perl }: +{ + lib, + stdenv, + fetchFromGitLab, + libvirt, + AppKit, + Foundation, + autoreconfHook, + pkg-config, + ocaml, + findlib, + perl, +}: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.02") "libvirt is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml-libvirt"; - version = "0.6.1.5"; - - src = fetchFromGitLab { - owner = "libvirt"; - repo = "libvirt-ocaml"; - rev = "v${version}"; - sha256 = "0xpkdmknk74yqxgw8z2w8b7ss8hpx92xnab5fsqg2byyj55gzf2k"; - }; - - propagatedBuildInputs = [ libvirt ]; - - nativeBuildInputs = [ autoreconfHook pkg-config findlib perl ocaml ]; - - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - Foundation - AppKit - ]; - - strictDeps = true; - - buildFlags = [ "all" "opt" "CPPFLAGS=-Wno-error" ]; - installTargets = "install-opt"; - preInstall = '' - # Fix 'dllmllibvirt.so' install failure into non-existent directory. - mkdir -p $OCAMLFIND_DESTDIR/stublibs - ''; - - meta = with lib; { - description = "OCaml bindings for libvirt"; - homepage = "https://libvirt.org/ocaml/"; - license = licenses.gpl2; - maintainers = [ ]; - inherit (ocaml.meta) platforms; - }; -} + stdenv.mkDerivation + rec { + pname = "ocaml-libvirt"; + version = "0.6.1.5"; + + src = fetchFromGitLab { + owner = "libvirt"; + repo = "libvirt-ocaml"; + rev = "v${version}"; + sha256 = "0xpkdmknk74yqxgw8z2w8b7ss8hpx92xnab5fsqg2byyj55gzf2k"; + }; + + propagatedBuildInputs = [ libvirt ]; + + nativeBuildInputs = [ + autoreconfHook + pkg-config + findlib + perl + ocaml + ]; + + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + Foundation + AppKit + ]; + + strictDeps = true; + + buildFlags = [ + "all" + "opt" + "CPPFLAGS=-Wno-error" + ]; + installTargets = "install-opt"; + preInstall = '' + # Fix 'dllmllibvirt.so' install failure into non-existent directory. + mkdir -p $OCAMLFIND_DESTDIR/stublibs + ''; + + meta = with lib; { + description = "OCaml bindings for libvirt"; + homepage = "https://libvirt.org/ocaml/"; + license = licenses.gpl2; + maintainers = [ ]; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/ocaml-lsp/default.nix b/pkgs/development/ocaml-modules/ocaml-lsp/default.nix index d9a21225cbb1e7..fe4d5e5fa1aad5 100644 --- a/pkgs/development/ocaml-modules/ocaml-lsp/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-lsp/default.nix @@ -1,58 +1,80 @@ -{ lib -, ocaml -, buildDunePackage -, lsp -, xdg -, re -, fiber -, makeWrapper -, dot-merlin-reader -, spawn -, ocamlc-loc -, merlin -, merlin-lib -, astring -, camlp-streams -, base +{ + lib, + ocaml, + buildDunePackage, + lsp, + xdg, + re, + fiber, + makeWrapper, + dot-merlin-reader, + spawn, + ocamlc-loc, + merlin, + merlin-lib, + astring, + camlp-streams, + base, }: # Freeze ocaml-lsp-version at 1.17.0 for OCaml 5.0 # for which merlin 4.16 is not available -let lsp_v = - if lib.versions.majorMinor ocaml.version == "5.0" - then lsp.override { version = "1.17.0"; } - else lsp -; in +let + lsp_v = + if lib.versions.majorMinor ocaml.version == "5.0" then + lsp.override { version = "1.17.0"; } + else + lsp; +in -let lsp = lsp_v; in +let + lsp = lsp_v; +in # Use merlin < 4.17 for OCaml < 5.2 -let merlin-lib_v = - if lib.versions.majorMinor ocaml.version == "4.14" - then merlin-lib.override { - merlin = merlin.override { - version = "4.16-414"; - }; - } else if lib.versions.majorMinor ocaml.version == "5.1" - then merlin-lib.override { - merlin = merlin.override { - version = "4.16-501"; - }; - } else merlin-lib -; in -let merlin-lib = merlin-lib_v; in +let + merlin-lib_v = + if lib.versions.majorMinor ocaml.version == "4.14" then + merlin-lib.override { + merlin = merlin.override { + version = "4.16-414"; + }; + } + else if lib.versions.majorMinor ocaml.version == "5.1" then + merlin-lib.override { + merlin = merlin.override { + version = "4.16-501"; + }; + } + else + merlin-lib; +in +let + merlin-lib = merlin-lib_v; +in buildDunePackage rec { pname = "ocaml-lsp-server"; inherit (lsp) version src preBuild; - buildInputs = lsp.buildInputs ++ [ lsp re ] - ++ lib.optional (lib.versionAtLeast version "1.9") spawn - ++ lib.optionals (lib.versionAtLeast version "1.10") [ fiber xdg ] - ++ lib.optional (lib.versionAtLeast version "1.14.2") ocamlc-loc - ++ lib.optionals (lib.versionAtLeast version "1.17.0") [ astring camlp-streams merlin-lib ] - ++ lib.optional (lib.versionAtLeast version "1.18.0") base - ; + buildInputs = + lsp.buildInputs + ++ [ + lsp + re + ] + ++ lib.optional (lib.versionAtLeast version "1.9") spawn + ++ lib.optionals (lib.versionAtLeast version "1.10") [ + fiber + xdg + ] + ++ lib.optional (lib.versionAtLeast version "1.14.2") ocamlc-loc + ++ lib.optionals (lib.versionAtLeast version "1.17.0") [ + astring + camlp-streams + merlin-lib + ] + ++ lib.optional (lib.versionAtLeast version "1.18.0") base; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/development/ocaml-modules/ocaml-lsp/jsonrpc.nix b/pkgs/development/ocaml-modules/ocaml-lsp/jsonrpc.nix index 1a2a97d21f2bd2..8b473e650e1f64 100644 --- a/pkgs/development/ocaml-modules/ocaml-lsp/jsonrpc.nix +++ b/pkgs/development/ocaml-modules/ocaml-lsp/jsonrpc.nix @@ -1,13 +1,14 @@ -{ buildDunePackage -, stdlib-shims -, ppx_yojson_conv_lib -, ocaml-syntax-shims -, yojson -, result -, fetchurl -, lib -, ocaml -, version ? +{ + buildDunePackage, + stdlib-shims, + ppx_yojson_conv_lib, + ocaml-syntax-shims, + yojson, + result, + fetchurl, + lib, + ocaml, + version ? if lib.versionAtLeast ocaml.version "5.02" then "1.19.0" else if lib.versionAtLeast ocaml.version "4.14" then @@ -17,46 +18,50 @@ else if lib.versionAtLeast ocaml.version "4.12" then "1.9.0" else - "1.4.1" + "1.4.1", }: -let params = { - "1.19.0" = { - name = "lsp"; - minimalOCamlVersion = "5.02"; - sha256 = "sha256-54PZ8af4nOG/TJFIqjSiKDaL0Um7zKQ96AtFkiHe5ew="; - }; - "1.18.0" = { - name = "lsp"; - minimalOCamlVersion = "4.14"; - sha256 = "sha256-tZ2kPM/S/9J3yeX2laDjnHLA144b8svy9iwae32nXwM="; - }; - "1.17.0" = { - name = "lsp"; - minimalOCamlVersion = "4.14"; - sha256 = "sha256-j7i71xfu/SYItNg0WBBbZg4N46ETTcj8IWrmWdTRlgA="; - }; - "1.14.2" = { - name = "lsp"; - minimalOCamlVersion = "4.14"; - sha256 = "sha256-1R+HYaGbPLGDs5DMN3jmnrZFMhMmPUHgF+s+yNzIVJQ="; - }; - "1.10.5" = { - name = "jsonrpc"; - minimalOCamlVersion = "4.13"; - sha256 = "sha256-TeJS6t1ruWhWPvWNatrnSUWI6T17XKiosHLYizBDDcw="; - }; - "1.9.0" = { - name = "jsonrpc"; - minimalOCamlVersion = "4.12"; - sha256 = "sha256:1ac44n6g3rf84gvhcca545avgf9vpkwkkkm0s8ipshfhp4g4jikh"; - }; - "1.4.1" = { - name = "jsonrpc"; - minimalOCamlVersion = "4.06"; - sha256 = "1ssyazc0yrdng98cypwa9m3nzfisdzpp7hqnx684rqj8f0g3gs6f"; - }; -}."${version}"; in +let + params = + { + "1.19.0" = { + name = "lsp"; + minimalOCamlVersion = "5.02"; + sha256 = "sha256-54PZ8af4nOG/TJFIqjSiKDaL0Um7zKQ96AtFkiHe5ew="; + }; + "1.18.0" = { + name = "lsp"; + minimalOCamlVersion = "4.14"; + sha256 = "sha256-tZ2kPM/S/9J3yeX2laDjnHLA144b8svy9iwae32nXwM="; + }; + "1.17.0" = { + name = "lsp"; + minimalOCamlVersion = "4.14"; + sha256 = "sha256-j7i71xfu/SYItNg0WBBbZg4N46ETTcj8IWrmWdTRlgA="; + }; + "1.14.2" = { + name = "lsp"; + minimalOCamlVersion = "4.14"; + sha256 = "sha256-1R+HYaGbPLGDs5DMN3jmnrZFMhMmPUHgF+s+yNzIVJQ="; + }; + "1.10.5" = { + name = "jsonrpc"; + minimalOCamlVersion = "4.13"; + sha256 = "sha256-TeJS6t1ruWhWPvWNatrnSUWI6T17XKiosHLYizBDDcw="; + }; + "1.9.0" = { + name = "jsonrpc"; + minimalOCamlVersion = "4.12"; + sha256 = "sha256:1ac44n6g3rf84gvhcca545avgf9vpkwkkkm0s8ipshfhp4g4jikh"; + }; + "1.4.1" = { + name = "jsonrpc"; + minimalOCamlVersion = "4.06"; + sha256 = "1ssyazc0yrdng98cypwa9m3nzfisdzpp7hqnx684rqj8f0g3gs6f"; + }; + } + ."${version}"; +in buildDunePackage rec { pname = "jsonrpc"; @@ -72,13 +77,20 @@ buildDunePackage rec { if lib.versionAtLeast version "1.7.0" then [ ] else - [ yojson stdlib-shims ocaml-syntax-shims ]; + [ + yojson + stdlib-shims + ocaml-syntax-shims + ]; propagatedBuildInputs = if lib.versionAtLeast version "1.7.0" then [ ] else - [ ppx_yojson_conv_lib result ]; + [ + ppx_yojson_conv_lib + result + ]; meta = with lib; { description = "Jsonrpc protocol implementation in OCaml"; diff --git a/pkgs/development/ocaml-modules/ocaml-lsp/lsp.nix b/pkgs/development/ocaml-modules/ocaml-lsp/lsp.nix index 9787c67bbd7cc0..4c3aaa15c29af4 100644 --- a/pkgs/development/ocaml-modules/ocaml-lsp/lsp.nix +++ b/pkgs/development/ocaml-modules/ocaml-lsp/lsp.nix @@ -1,27 +1,28 @@ -{ buildDunePackage -, lib -, cppo -, stdlib-shims -, ppx_yojson_conv_lib -, ocaml-syntax-shims -, jsonrpc -, omd -, octavius -, dune-build-info -, dune-rpc -, uutf -, dyn -, re -, stdune -, chrome-trace -, csexp -, result -, pp -, cmdliner -, ordering -, ocamlformat-rpc-lib -, ocaml -, version ? +{ + buildDunePackage, + lib, + cppo, + stdlib-shims, + ppx_yojson_conv_lib, + ocaml-syntax-shims, + jsonrpc, + omd, + octavius, + dune-build-info, + dune-rpc, + uutf, + dyn, + re, + stdune, + chrome-trace, + csexp, + result, + pp, + cmdliner, + ordering, + ocamlformat-rpc-lib, + ocaml, + version ? if lib.versionAtLeast ocaml.version "5.02" then "1.19.0" else if lib.versionAtLeast ocaml.version "4.14" then @@ -31,20 +32,18 @@ else if lib.versionAtLeast ocaml.version "4.12" then "1.9.0" else - "1.4.1" + "1.4.1", }: -let jsonrpc_v = jsonrpc.override { - inherit version; -}; in +let + jsonrpc_v = jsonrpc.override { + inherit version; + }; +in buildDunePackage rec { pname = "lsp"; inherit (jsonrpc_v) version src; - minimalOCamlVersion = - if lib.versionAtLeast version "1.7.0" then - "4.12" - else - "4.06"; + minimalOCamlVersion = if lib.versionAtLeast version "1.7.0" then "4.12" else "4.06"; # unvendor some (not all) dependencies. # They are vendored by upstream only because it is then easier to install @@ -85,7 +84,14 @@ buildDunePackage rec { stdune ] else if lib.versionAtLeast version "1.7.0" then - [ re octavius dune-build-info omd cmdliner ocamlformat-rpc-lib ] + [ + re + octavius + dune-build-info + omd + cmdliner + ocamlformat-rpc-lib + ] else [ ppx_yojson_conv_lib @@ -99,31 +105,38 @@ buildDunePackage rec { nativeBuildInputs = lib.optional (lib.versionOlder version "1.7.0") cppo; propagatedBuildInputs = - if lib.versionAtLeast version "1.14.0" then [ - jsonrpc - ppx_yojson_conv_lib - uutf - ] else if lib.versionAtLeast version "1.10.0" then [ - dyn - jsonrpc - ordering - ppx_yojson_conv_lib - stdune - uutf - ] else if lib.versionAtLeast version "1.7.0" then [ - csexp - jsonrpc - (pp.override { version = "1.2.0"; }) - ppx_yojson_conv_lib - result - uutf - ] else [ - csexp - jsonrpc - ppx_yojson_conv_lib - stdlib-shims - uutf - ]; + if lib.versionAtLeast version "1.14.0" then + [ + jsonrpc + ppx_yojson_conv_lib + uutf + ] + else if lib.versionAtLeast version "1.10.0" then + [ + dyn + jsonrpc + ordering + ppx_yojson_conv_lib + stdune + uutf + ] + else if lib.versionAtLeast version "1.7.0" then + [ + csexp + jsonrpc + (pp.override { version = "1.2.0"; }) + ppx_yojson_conv_lib + result + uutf + ] + else + [ + csexp + jsonrpc + ppx_yojson_conv_lib + stdlib-shims + uutf + ]; meta = jsonrpc.meta // { description = "LSP protocol implementation in OCaml"; diff --git a/pkgs/development/ocaml-modules/ocaml-lua/default.nix b/pkgs/development/ocaml-modules/ocaml-lua/default.nix index 8a09b1d9387ed0..57a131763ad99d 100644 --- a/pkgs/development/ocaml-modules/ocaml-lua/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-lua/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildDunePackage, lua5_1, pkg-config }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + lua5_1, + pkg-config, +}: buildDunePackage { pname = "ocaml-lua"; diff --git a/pkgs/development/ocaml-modules/ocaml-migrate-parsetree/1.8.x.nix b/pkgs/development/ocaml-modules/ocaml-migrate-parsetree/1.8.x.nix index 9802d07d4a4f33..6e16fd2f255602 100644 --- a/pkgs/development/ocaml-modules/ocaml-migrate-parsetree/1.8.x.nix +++ b/pkgs/development/ocaml-modules/ocaml-migrate-parsetree/1.8.x.nix @@ -1,26 +1,36 @@ -{ lib, fetchFromGitHub, buildDunePackage, ocaml, result, ppx_derivers }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + ocaml, + result, + ppx_derivers, +}: -if lib.versionOlder "4.13" ocaml.version -then throw "ocaml-migrate-parsetree-1.8 is not available for OCaml ${ocaml.version}" +if lib.versionOlder "4.13" ocaml.version then + throw "ocaml-migrate-parsetree-1.8 is not available for OCaml ${ocaml.version}" else -buildDunePackage rec { - pname = "ocaml-migrate-parsetree"; - version = "1.8.0"; + buildDunePackage rec { + pname = "ocaml-migrate-parsetree"; + version = "1.8.0"; - src = fetchFromGitHub { - owner = "ocaml-ppx"; - repo = pname; - rev = "v${version}"; - sha256 = "16x8sxc4ygxrr1868qpzfqyrvjf3hfxvjzmxmf6ibgglq7ixa2nq"; - }; + src = fetchFromGitHub { + owner = "ocaml-ppx"; + repo = pname; + rev = "v${version}"; + sha256 = "16x8sxc4ygxrr1868qpzfqyrvjf3hfxvjzmxmf6ibgglq7ixa2nq"; + }; - propagatedBuildInputs = [ ppx_derivers result ]; + propagatedBuildInputs = [ + ppx_derivers + result + ]; - meta = { - description = "Convert OCaml parsetrees between different major versions"; - license = lib.licenses.lgpl21; - maintainers = [ lib.maintainers.vbgl ]; - inherit (src.meta) homepage; - }; -} + meta = { + description = "Convert OCaml parsetrees between different major versions"; + license = lib.licenses.lgpl21; + maintainers = [ lib.maintainers.vbgl ]; + inherit (src.meta) homepage; + }; + } diff --git a/pkgs/development/ocaml-modules/ocaml-migrate-parsetree/2.x.nix b/pkgs/development/ocaml-modules/ocaml-migrate-parsetree/2.x.nix index 1ba2976bcc54f0..2c66caae99f998 100644 --- a/pkgs/development/ocaml-modules/ocaml-migrate-parsetree/2.x.nix +++ b/pkgs/development/ocaml-modules/ocaml-migrate-parsetree/2.x.nix @@ -1,23 +1,32 @@ -{ lib, fetchurl, buildDunePackage, ocaml }: +{ + lib, + fetchurl, + buildDunePackage, + ocaml, +}: lib.throwIf (lib.versionAtLeast ocaml.version "5.1") "ocaml-migrate-parsetree is not available for OCaml ${ocaml.version}" -buildDunePackage rec { - pname = "ocaml-migrate-parsetree"; - version = "2.4.0"; + buildDunePackage + rec { + pname = "ocaml-migrate-parsetree"; + version = "2.4.0"; - minimalOCamlVersion = "4.02"; + minimalOCamlVersion = "4.02"; - src = fetchurl { - url = "https://github.com/ocaml-ppx/${pname}/releases/download/${version}/${pname}-${version}.tbz"; - sha256 = "sha256-7EnEUtwzemIFVqtoK/AZi/UBglULUC2PsjClkSYKpqQ="; - }; + src = fetchurl { + url = "https://github.com/ocaml-ppx/${pname}/releases/download/${version}/${pname}-${version}.tbz"; + sha256 = "sha256-7EnEUtwzemIFVqtoK/AZi/UBglULUC2PsjClkSYKpqQ="; + }; - meta = { - description = "Convert OCaml parsetrees between different major versions"; - license = lib.licenses.lgpl21; - maintainers = with lib.maintainers; [ vbgl sternenseemann ]; - homepage = "https://github.com/ocaml-ppx/ocaml-migrate-parsetree"; - }; -} + meta = { + description = "Convert OCaml parsetrees between different major versions"; + license = lib.licenses.lgpl21; + maintainers = with lib.maintainers; [ + vbgl + sternenseemann + ]; + homepage = "https://github.com/ocaml-ppx/ocaml-migrate-parsetree"; + }; + } diff --git a/pkgs/development/ocaml-modules/ocaml-monadic/default.nix b/pkgs/development/ocaml-modules/ocaml-monadic/default.nix index 50a04bbefab226..fa28353f10828c 100644 --- a/pkgs/development/ocaml-modules/ocaml-monadic/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-monadic/default.nix @@ -1,5 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage -, ppxlib +{ + lib, + fetchFromGitHub, + buildDunePackage, + ppxlib, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ocaml-print-intf/default.nix b/pkgs/development/ocaml-modules/ocaml-print-intf/default.nix index 21add50c60617a..a48d73b341af6f 100644 --- a/pkgs/development/ocaml-modules/ocaml-print-intf/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-print-intf/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, dune-build-info -, bos +{ + lib, + fetchFromGitHub, + buildDunePackage, + dune-build-info, + bos, }: let author = "avsm"; @@ -20,7 +21,10 @@ buildDunePackage rec { sha256 = "0hw4gl7irarcywibdjqxmrga8f7yj52wgy7sc7n0wyy74jzxb8np"; }; - buildInputs = [ dune-build-info bos ]; + buildInputs = [ + dune-build-info + bos + ]; meta = with lib; { description = "Pretty print an OCaml cmi/cmt/cmti file in human-readable OCaml signature form"; diff --git a/pkgs/development/ocaml-modules/ocaml-protoc-plugin/default.nix b/pkgs/development/ocaml-modules/ocaml-protoc-plugin/default.nix index c89d9d7219ac75..0de49d843861e5 100644 --- a/pkgs/development/ocaml-modules/ocaml-protoc-plugin/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-protoc-plugin/default.nix @@ -1,14 +1,15 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, pkg-config -, protobuf -, zarith -, ppx_deriving -, ppx_deriving_yojson -, re -, dune-site -, ppx_expect +{ + lib, + fetchFromGitHub, + buildDunePackage, + pkg-config, + protobuf, + zarith, + ppx_deriving, + ppx_deriving_yojson, + re, + dune-site, + ppx_expect, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ocaml-protoc/default.nix b/pkgs/development/ocaml-modules/ocaml-protoc/default.nix index 717f5755ebac62..1342aa079a1188 100644 --- a/pkgs/development/ocaml-modules/ocaml-protoc/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-protoc/default.nix @@ -1,6 +1,7 @@ -{ buildDunePackage -, pbrt -, stdlib-shims +{ + buildDunePackage, + pbrt, + stdlib-shims, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ocaml-r/default.nix b/pkgs/development/ocaml-modules/ocaml-r/default.nix index 8de5abf7e4814f..3a399d4d0dba98 100644 --- a/pkgs/development/ocaml-modules/ocaml-r/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-r/default.nix @@ -1,5 +1,13 @@ -{ lib, fetchFromGitHub, fetchpatch, buildDunePackage, pkg-config, dune-configurator, stdio, R -, alcotest +{ + lib, + fetchFromGitHub, + fetchpatch, + buildDunePackage, + pkg-config, + dune-configurator, + stdio, + R, + alcotest, }: buildDunePackage rec { @@ -25,8 +33,15 @@ buildDunePackage rec { }) ]; - nativeBuildInputs = [ pkg-config R ]; - buildInputs = [ dune-configurator stdio R ]; + nativeBuildInputs = [ + pkg-config + R + ]; + buildInputs = [ + dune-configurator + stdio + R + ]; doCheck = true; checkInputs = [ alcotest ]; diff --git a/pkgs/development/ocaml-modules/ocaml-result/default.nix b/pkgs/development/ocaml-modules/ocaml-result/default.nix index 2814c6c5280646..710f1ede3e78bb 100644 --- a/pkgs/development/ocaml-modules/ocaml-result/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-result/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "result"; diff --git a/pkgs/development/ocaml-modules/ocaml-sat-solvers/default.nix b/pkgs/development/ocaml-modules/ocaml-sat-solvers/default.nix index c7779b098e73dc..b24ef9e2868213 100644 --- a/pkgs/development/ocaml-modules/ocaml-sat-solvers/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-sat-solvers/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildOasisPackage, minisat }: +{ + lib, + fetchFromGitHub, + buildOasisPackage, + minisat, +}: buildOasisPackage rec { pname = "ocaml-sat-solvers"; @@ -7,9 +12,9 @@ buildOasisPackage rec { minimumOCamlVersion = "4.03.0"; src = fetchFromGitHub { - owner = "tcsprojects"; - repo = "ocaml-sat-solvers"; - rev = "v${version}"; + owner = "tcsprojects"; + repo = "ocaml-sat-solvers"; + rev = "v${version}"; sha256 = "1hxr16cyl1p1k1cik848mqrysq95wxmlykpm93a99pn55mp28938"; }; diff --git a/pkgs/development/ocaml-modules/ocaml-syntax-shims/default.nix b/pkgs/development/ocaml-modules/ocaml-syntax-shims/default.nix index 49f8cb63b98b6a..e3539194e1111b 100644 --- a/pkgs/development/ocaml-modules/ocaml-syntax-shims/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-syntax-shims/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { minimumOCamlVersion = "4.02.3"; diff --git a/pkgs/development/ocaml-modules/ocaml-vdom/default.nix b/pkgs/development/ocaml-modules/ocaml-vdom/default.nix index 72c1cb148c20b1..e34feb49f0d3fe 100644 --- a/pkgs/development/ocaml-modules/ocaml-vdom/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-vdom/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, buildDunePackage, js_of_ocaml-compiler , gen_js_api, ojs }: +{ + lib, + fetchurl, + buildDunePackage, + js_of_ocaml-compiler, + gen_js_api, + ojs, +}: buildDunePackage rec { pname = "ocaml-vdom"; @@ -31,5 +38,3 @@ buildDunePackage rec { maintainers = with lib.maintainers; [ jayesh-bhoot ]; }; } - - diff --git a/pkgs/development/ocaml-modules/ocaml-version/default.nix b/pkgs/development/ocaml-modules/ocaml-version/default.nix index a8a998299a95f9..e1839ad42e8c25 100644 --- a/pkgs/development/ocaml-modules/ocaml-version/default.nix +++ b/pkgs/development/ocaml-modules/ocaml-version/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, buildDunePackage, alcotest }: +{ + lib, + fetchurl, + buildDunePackage, + alcotest, +}: buildDunePackage rec { pname = "ocaml-version"; diff --git a/pkgs/development/ocaml-modules/ocamlc-loc/default.nix b/pkgs/development/ocaml-modules/ocamlc-loc/default.nix index 3f2d9c013c45c0..47b1c6ffe75c0d 100644 --- a/pkgs/development/ocaml-modules/ocamlc-loc/default.nix +++ b/pkgs/development/ocaml-modules/ocamlc-loc/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, dune_3, dyn }: +{ + lib, + buildDunePackage, + dune_3, + dyn, +}: buildDunePackage { pname = "ocamlc-loc"; diff --git a/pkgs/development/ocaml-modules/ocamlformat/generic.nix b/pkgs/development/ocaml-modules/ocamlformat/generic.nix index 6e6f39630239d7..9c1bfa77cf26b4 100644 --- a/pkgs/development/ocaml-modules/ocamlformat/generic.nix +++ b/pkgs/development/ocaml-modules/ocamlformat/generic.nix @@ -1,7 +1,29 @@ -{ lib, fetchurl, version ? "0.27.0", astring, base, camlp-streams, cmdliner_1_0 -, cmdliner_1_1, csexp, dune-build-info, either, fix, fpath, menhirLib, menhirSdk -, ocaml-version, ocp-indent, odoc-parser, result, stdio, uuseg, uutf -, janeStreet_0_15, ... }: +{ + lib, + fetchurl, + version ? "0.27.0", + astring, + base, + camlp-streams, + cmdliner_1_0, + cmdliner_1_1, + csexp, + dune-build-info, + either, + fix, + fpath, + menhirLib, + menhirSdk, + ocaml-version, + ocp-indent, + odoc-parser, + result, + stdio, + uuseg, + uutf, + janeStreet_0_15, + ... +}: # The ocamlformat package have been split into two in version 0.25.1: # one for the library and one for the executable. @@ -11,64 +33,71 @@ rec { tarballName = "ocamlformat-${version}.tbz"; src = fetchurl { - url = - "https://github.com/ocaml-ppx/ocamlformat/releases/download/${version}/${tarballName}"; - sha256 = { - "0.19.0" = "0ihgwl7d489g938m1jvgx8azdgq9f5np5mzqwwya797hx2m4dz32"; - "0.20.0" = "sha256-JtmNCgwjbCyUE4bWqdH5Nc2YSit+rekwS43DcviIfgk="; - "0.20.1" = "sha256-fTpRZFQW+ngoc0T6A69reEUAZ6GmHkeQvxspd5zRAjU="; - "0.21.0" = "sha256-KhgX9rxYH/DM6fCqloe4l7AnJuKrdXSe6Y1XY3BXMy0="; - "0.22.4" = "sha256-61TeK4GsfMLmjYGn3ICzkagbc3/Po++Wnqkb2tbJwGA="; - "0.23.0" = "sha256-m9Pjz7DaGy917M1GjyfqG5Lm5ne7YSlJF2SVcDHe3+0="; - "0.24.0" = "sha256-Zil0wceeXmq2xy0OVLxa/Ujl4Dtsmc4COyv6Jo7rVaM="; - "0.24.1" = "sha256-AjQl6YGPgOpQU3sjcaSnZsFJqZV9BYB+iKAE0tX0Qc4="; - "0.25.1" = "sha256-3I8qMwyjkws2yssmI7s2Dti99uSorNKT29niJBpv0z0="; - "0.26.0" = "sha256-AxSUq3cM7xCo9qocvrVmDkbDqmwM1FexEP7IWadeh30="; - "0.26.1" = "sha256-2gBuQn8VuexhL7gI1EZZm9m3w+4lq+s9VVdHpw10xtc="; - "0.26.2" = "sha256-Lk9Za/eqNnqET+g7oPawvxSyplF53cCCNj/peT0DdcU="; - "0.27.0" = "sha256-3b9ITAdtCPmUAO6Et5DsIx9cj8vV0zJKZADVOI6EbRU="; - }."${version}"; + url = "https://github.com/ocaml-ppx/ocamlformat/releases/download/${version}/${tarballName}"; + sha256 = + { + "0.19.0" = "0ihgwl7d489g938m1jvgx8azdgq9f5np5mzqwwya797hx2m4dz32"; + "0.20.0" = "sha256-JtmNCgwjbCyUE4bWqdH5Nc2YSit+rekwS43DcviIfgk="; + "0.20.1" = "sha256-fTpRZFQW+ngoc0T6A69reEUAZ6GmHkeQvxspd5zRAjU="; + "0.21.0" = "sha256-KhgX9rxYH/DM6fCqloe4l7AnJuKrdXSe6Y1XY3BXMy0="; + "0.22.4" = "sha256-61TeK4GsfMLmjYGn3ICzkagbc3/Po++Wnqkb2tbJwGA="; + "0.23.0" = "sha256-m9Pjz7DaGy917M1GjyfqG5Lm5ne7YSlJF2SVcDHe3+0="; + "0.24.0" = "sha256-Zil0wceeXmq2xy0OVLxa/Ujl4Dtsmc4COyv6Jo7rVaM="; + "0.24.1" = "sha256-AjQl6YGPgOpQU3sjcaSnZsFJqZV9BYB+iKAE0tX0Qc4="; + "0.25.1" = "sha256-3I8qMwyjkws2yssmI7s2Dti99uSorNKT29niJBpv0z0="; + "0.26.0" = "sha256-AxSUq3cM7xCo9qocvrVmDkbDqmwM1FexEP7IWadeh30="; + "0.26.1" = "sha256-2gBuQn8VuexhL7gI1EZZm9m3w+4lq+s9VVdHpw10xtc="; + "0.26.2" = "sha256-Lk9Za/eqNnqET+g7oPawvxSyplF53cCCNj/peT0DdcU="; + "0.27.0" = "sha256-3b9ITAdtCPmUAO6Et5DsIx9cj8vV0zJKZADVOI6EbRU="; + } + ."${version}"; }; inherit version; odoc-parser_v = odoc-parser.override { - version = if lib.versionAtLeast version "0.24.0" then - "2.0.0" - else if lib.versionAtLeast version "0.20.1" then - "1.0.1" - else - "0.9.0"; + version = + if lib.versionAtLeast version "0.24.0" then + "2.0.0" + else if lib.versionAtLeast version "0.20.1" then + "1.0.1" + else + "0.9.0"; }; - cmdliner_v = - if lib.versionAtLeast version "0.21.0" then cmdliner_1_1 else cmdliner_1_0; + cmdliner_v = if lib.versionAtLeast version "0.21.0" then cmdliner_1_1 else cmdliner_1_0; base_v = if lib.versionAtLeast version "0.25.1" then base else janeStreet_0_15.base; - stdio_v =if lib.versionAtLeast version "0.25.1" then stdio else janeStreet_0_15.stdio; + stdio_v = if lib.versionAtLeast version "0.25.1" then stdio else janeStreet_0_15.stdio; - library_deps= [ - base_v - cmdliner_v - dune-build-info - fix - fpath - menhirLib - menhirSdk - ocp-indent - stdio_v - uuseg - uutf - ] ++ lib.optionals (lib.versionAtLeast version "0.20.0") [ - either - ocaml-version - ] ++ lib.optionals (lib.versionAtLeast version "0.22.4") [ csexp ] - ++ (if lib.versionOlder version "0.25.1" then - [ odoc-parser_v ] - else [ - camlp-streams - result - astring - ]); + library_deps = + [ + base_v + cmdliner_v + dune-build-info + fix + fpath + menhirLib + menhirSdk + ocp-indent + stdio_v + uuseg + uutf + ] + ++ lib.optionals (lib.versionAtLeast version "0.20.0") [ + either + ocaml-version + ] + ++ lib.optionals (lib.versionAtLeast version "0.22.4") [ csexp ] + ++ ( + if lib.versionOlder version "0.25.1" then + [ odoc-parser_v ] + else + [ + camlp-streams + result + astring + ] + ); } diff --git a/pkgs/development/ocaml-modules/ocamlformat/ocamlformat-lib.nix b/pkgs/development/ocaml-modules/ocamlformat/ocamlformat-lib.nix index a6607ba83ccd36..6e3a23f1996db6 100644 --- a/pkgs/development/ocaml-modules/ocamlformat/ocamlformat-lib.nix +++ b/pkgs/development/ocaml-modules/ocamlformat/ocamlformat-lib.nix @@ -1,9 +1,17 @@ # Version can be selected with the 'version' argument, see generic.nix. -{ lib, callPackage, buildDunePackage, menhir, ... }@args: +{ + lib, + callPackage, + buildDunePackage, + menhir, + ... +}@args: -let inherit (callPackage ./generic.nix args) src version library_deps; +let + inherit (callPackage ./generic.nix args) src version library_deps; -in assert (lib.versionAtLeast version "0.25.1"); +in +assert (lib.versionAtLeast version "0.25.1"); buildDunePackage { pname = "ocamlformat-lib"; @@ -19,7 +27,10 @@ buildDunePackage { meta = { homepage = "https://github.com/ocaml-ppx/ocamlformat"; description = "Auto-formatter for OCaml code (library)"; - maintainers = with lib.maintainers; [ Zimmi48 Julow ]; + maintainers = with lib.maintainers; [ + Zimmi48 + Julow + ]; license = lib.licenses.mit; }; } diff --git a/pkgs/development/ocaml-modules/ocamlformat/ocamlformat-rpc-lib.nix b/pkgs/development/ocaml-modules/ocamlformat/ocamlformat-rpc-lib.nix index d8dc1d54ffc0cb..1a714241fa07ab 100644 --- a/pkgs/development/ocaml-modules/ocamlformat/ocamlformat-rpc-lib.nix +++ b/pkgs/development/ocaml-modules/ocamlformat/ocamlformat-rpc-lib.nix @@ -1,26 +1,40 @@ # Version can be selected with the 'version' argument, see generic.nix. -{ lib, buildDunePackage, ocaml, csexp, sexplib0, callPackage, ... }@args: +{ + lib, + buildDunePackage, + ocaml, + csexp, + sexplib0, + callPackage, + ... +}@args: let # for compat with ocaml-lsp - version_arg = - if lib.versionAtLeast ocaml.version "4.13" then {} else { version = "0.20.0"; }; + version_arg = if lib.versionAtLeast ocaml.version "4.13" then { } else { version = "0.20.0"; }; inherit (callPackage ./generic.nix (args // version_arg)) src version; -in buildDunePackage rec { +in +buildDunePackage rec { pname = "ocamlformat-rpc-lib"; inherit src version; minimalOCamlVersion = "4.08"; duneVersion = "3"; - propagatedBuildInputs = [ csexp sexplib0 ]; + propagatedBuildInputs = [ + csexp + sexplib0 + ]; meta = with lib; { homepage = "https://github.com/ocaml-ppx/ocamlformat"; description = "Auto-formatter for OCaml code (RPC mode)"; license = licenses.mit; - maintainers = with maintainers; [ Zimmi48 Julow ]; + maintainers = with maintainers; [ + Zimmi48 + Julow + ]; }; } diff --git a/pkgs/development/ocaml-modules/ocamlformat/ocamlformat.nix b/pkgs/development/ocaml-modules/ocamlformat/ocamlformat.nix index e56b8640968540..f41abb136091c5 100644 --- a/pkgs/development/ocaml-modules/ocamlformat/ocamlformat.nix +++ b/pkgs/development/ocaml-modules/ocamlformat/ocamlformat.nix @@ -1,39 +1,50 @@ # Version can be selected with the 'version' argument, see generic.nix. -{ lib -, callPackage -, buildDunePackage -, ocaml -, re -, ocamlformat-lib -, menhir -, ... +{ + lib, + callPackage, + buildDunePackage, + ocaml, + re, + ocamlformat-lib, + menhir, + ... }@args: -let inherit (callPackage ./generic.nix args) src version library_deps; +let + inherit (callPackage ./generic.nix args) src version library_deps; in -lib.throwIf (lib.versionAtLeast ocaml.version "5.0" && !lib.versionAtLeast version "0.23" - || lib.versionAtLeast ocaml.version "5.2" && !lib.versionAtLeast version "0.26.2") +lib.throwIf + ( + lib.versionAtLeast ocaml.version "5.0" && !lib.versionAtLeast version "0.23" + || lib.versionAtLeast ocaml.version "5.2" && !lib.versionAtLeast version "0.26.2" + ) "ocamlformat ${version} is not available for OCaml ${ocaml.version}" -buildDunePackage { - pname = "ocamlformat"; - inherit src version; + buildDunePackage + { + pname = "ocamlformat"; + inherit src version; - minimalOCamlVersion = "4.08"; + minimalOCamlVersion = "4.08"; - nativeBuildInputs = - if lib.versionAtLeast version "0.25.1" then [ ] else [ menhir ]; + nativeBuildInputs = if lib.versionAtLeast version "0.25.1" then [ ] else [ menhir ]; - buildInputs = [ re ] ++ library_deps - ++ lib.optionals (lib.versionAtLeast version "0.25.1") - [ (ocamlformat-lib.override { inherit version; }) ]; + buildInputs = + [ re ] + ++ library_deps + ++ lib.optionals (lib.versionAtLeast version "0.25.1") [ + (ocamlformat-lib.override { inherit version; }) + ]; - meta = { - homepage = "https://github.com/ocaml-ppx/ocamlformat"; - description = "Auto-formatter for OCaml code"; - maintainers = with lib.maintainers; [ Zimmi48 Julow ]; - license = lib.licenses.mit; - mainProgram = "ocamlformat"; - }; -} + meta = { + homepage = "https://github.com/ocaml-ppx/ocamlformat"; + description = "Auto-formatter for OCaml code"; + maintainers = with lib.maintainers; [ + Zimmi48 + Julow + ]; + license = lib.licenses.mit; + mainProgram = "ocamlformat"; + }; + } diff --git a/pkgs/development/ocaml-modules/ocamlfuse/default.nix b/pkgs/development/ocaml-modules/ocamlfuse/default.nix index c34fb91f5e73bb..599591cc76c068 100644 --- a/pkgs/development/ocaml-modules/ocamlfuse/default.nix +++ b/pkgs/development/ocaml-modules/ocamlfuse/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub, camlidl, fuse, dune-configurator }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + camlidl, + fuse, + dune-configurator, +}: buildDunePackage rec { pname = "ocamlfuse"; @@ -18,7 +25,10 @@ buildDunePackage rec { nativeBuildInputs = [ camlidl ]; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ camlidl fuse ]; + propagatedBuildInputs = [ + camlidl + fuse + ]; meta = { homepage = "https://sourceforge.net/projects/ocamlfuse"; diff --git a/pkgs/development/ocaml-modules/ocamlgraph/default.nix b/pkgs/development/ocaml-modules/ocamlgraph/default.nix index 92b625a4ab47bd..a6c54e876c9544 100644 --- a/pkgs/development/ocaml-modules/ocamlgraph/default.nix +++ b/pkgs/development/ocaml-modules/ocamlgraph/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, buildDunePackage, stdlib-shims }: +{ + lib, + fetchurl, + buildDunePackage, + stdlib-shims, +}: buildDunePackage rec { pname = "ocamlgraph"; @@ -16,9 +21,9 @@ buildDunePackage rec { ]; meta = with lib; { - homepage = "https://github.com/backtracking/ocamlgraph"; - description = "Graph library for OCaml"; - license = licenses.gpl2Oss; - maintainers = [ ]; + homepage = "https://github.com/backtracking/ocamlgraph"; + description = "Graph library for OCaml"; + license = licenses.gpl2Oss; + maintainers = [ ]; }; } diff --git a/pkgs/development/ocaml-modules/ocamlgraph/gtk.nix b/pkgs/development/ocaml-modules/ocamlgraph/gtk.nix index e8167356f9399e..e5529f1507ba4d 100644 --- a/pkgs/development/ocaml-modules/ocamlgraph/gtk.nix +++ b/pkgs/development/ocaml-modules/ocamlgraph/gtk.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, lablgtk, ocamlgraph, stdlib-shims, ... }: +{ + buildDunePackage, + lablgtk, + ocamlgraph, + stdlib-shims, + ... +}: buildDunePackage rec { pname = "ocamlgraph_gtk"; diff --git a/pkgs/development/ocaml-modules/ocamline/default.nix b/pkgs/development/ocaml-modules/ocamline/default.nix index 694988df7dc757..eb77721bf0a6ff 100644 --- a/pkgs/development/ocaml-modules/ocamline/default.nix +++ b/pkgs/development/ocaml-modules/ocamline/default.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, linenoise, fetchFromGitHub, lib }: +{ + buildDunePackage, + linenoise, + fetchFromGitHub, + lib, +}: buildDunePackage rec { pname = "ocamline"; diff --git a/pkgs/development/ocaml-modules/ocamlnat/default.nix b/pkgs/development/ocaml-modules/ocamlnat/default.nix index 850c29c4dc024d..8729a4cc71fb02 100644 --- a/pkgs/development/ocaml-modules/ocamlnat/default.nix +++ b/pkgs/development/ocaml-modules/ocamlnat/default.nix @@ -1,4 +1,11 @@ -{stdenv, lib, fetchurl, ocaml, findlib, ounit}: +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ounit, +}: # https://github.com/bmeurer/ocamlnat/issues/3 assert lib.versionOlder ocaml.version "4"; @@ -12,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "0dyvy0j6f47laxhnadvm71z1py9hz9zd49hamf6bij99cggb2ij1"; }; - nativeBuildInputs = [ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; checkInputs = [ ounit ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/ocamlnet/default.nix b/pkgs/development/ocaml-modules/ocamlnet/default.nix index 7fb262a91ac44a..72ecf9ada9cbbb 100644 --- a/pkgs/development/ocaml-modules/ocamlnet/default.nix +++ b/pkgs/development/ocaml-modules/ocamlnet/default.nix @@ -1,54 +1,77 @@ -{ stdenv, lib, fetchurl, pkg-config, which, ncurses, ocaml, findlib, ocaml_pcre, camlzip -, gnutls, nettle +{ + stdenv, + lib, + fetchurl, + pkg-config, + which, + ncurses, + ocaml, + findlib, + ocaml_pcre, + camlzip, + gnutls, + nettle, }: lib.throwIf (lib.versionOlder ocaml.version "4.02" || lib.versionAtLeast ocaml.version "5.0") "ocamlnet is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-ocamlnet"; - version = "4.1.9"; - - src = fetchurl { - url = "http://download.camlcity.org/download/ocamlnet-${version}.tar.gz"; - sha256 = "1vlwxjxr946gdl61a1d7yk859cijq45f60dhn54ik3w4g6cx33pr"; - }; - - nativeBuildInputs = [ pkg-config which ocaml findlib ]; - buildInputs = [ ncurses ocaml_pcre camlzip gnutls nettle ]; - - strictDeps = true; - - createFindlibDestdir = true; - - dontAddPrefix = true; - dontAddStaticConfigureFlags = true; - configurePlatforms = []; - - preConfigure = '' - configureFlagsArray=( - -bindir $out/bin - -enable-gnutls - -enable-zip - -enable-pcre - -disable-gtk2 - -with-nethttpd - -datadir $out/lib/ocaml/${ocaml.version}/ocamlnet - ) - ''; - - buildPhase = '' - make all - make opt - ''; - - meta = { - homepage = "http://projects.camlcity.org/projects/ocamlnet.html"; - description = "Library implementing Internet protocols (http, cgi, email, etc.) for OCaml"; - license = "Most Ocamlnet modules are released under the zlib/png license. The HTTP server module Nethttpd is, however, under the GPL."; - inherit (ocaml.meta) platforms; - maintainers = [ - lib.maintainers.maggesi + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-ocamlnet"; + version = "4.1.9"; + + src = fetchurl { + url = "http://download.camlcity.org/download/ocamlnet-${version}.tar.gz"; + sha256 = "1vlwxjxr946gdl61a1d7yk859cijq45f60dhn54ik3w4g6cx33pr"; + }; + + nativeBuildInputs = [ + pkg-config + which + ocaml + findlib + ]; + buildInputs = [ + ncurses + ocaml_pcre + camlzip + gnutls + nettle ]; - }; -} + + strictDeps = true; + + createFindlibDestdir = true; + + dontAddPrefix = true; + dontAddStaticConfigureFlags = true; + configurePlatforms = [ ]; + + preConfigure = '' + configureFlagsArray=( + -bindir $out/bin + -enable-gnutls + -enable-zip + -enable-pcre + -disable-gtk2 + -with-nethttpd + -datadir $out/lib/ocaml/${ocaml.version}/ocamlnet + ) + ''; + + buildPhase = '' + make all + make opt + ''; + + meta = { + homepage = "http://projects.camlcity.org/projects/ocamlnet.html"; + description = "Library implementing Internet protocols (http, cgi, email, etc.) for OCaml"; + license = "Most Ocamlnet modules are released under the zlib/png license. The HTTP server module Nethttpd is, however, under the GPL."; + inherit (ocaml.meta) platforms; + maintainers = [ + lib.maintainers.maggesi + ]; + }; + } diff --git a/pkgs/development/ocaml-modules/ocb-stubblr/default.nix b/pkgs/development/ocaml-modules/ocb-stubblr/default.nix index fcd63ced7a8090..b7b93ebd5e5ae5 100644 --- a/pkgs/development/ocaml-modules/ocb-stubblr/default.nix +++ b/pkgs/development/ocaml-modules/ocb-stubblr/default.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchzip, ocaml, findlib, ocamlbuild, topkg, astring }: +{ + stdenv, + lib, + fetchzip, + ocaml, + findlib, + ocamlbuild, + topkg, + astring, +}: stdenv.mkDerivation rec { pname = "ocaml${ocaml.version}-ocb-stubblr"; @@ -12,8 +21,16 @@ stdenv.mkDerivation rec { patches = [ ./pkg-config.patch ]; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg ocamlbuild ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ + topkg + ocamlbuild + ]; propagatedBuildInputs = [ astring ]; diff --git a/pkgs/development/ocaml-modules/ocf/default.nix b/pkgs/development/ocaml-modules/ocf/default.nix index 137589308e2bcf..f1e5e2d48a4232 100644 --- a/pkgs/development/ocaml-modules/ocf/default.nix +++ b/pkgs/development/ocaml-modules/ocf/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitLab, yojson }: +{ + lib, + buildDunePackage, + fetchFromGitLab, + yojson, +}: buildDunePackage rec { pname = "ocf"; diff --git a/pkgs/development/ocaml-modules/ocf/ppx.nix b/pkgs/development/ocaml-modules/ocf/ppx.nix index 7538bdeca167f9..a01c36942ea9a0 100644 --- a/pkgs/development/ocaml-modules/ocf/ppx.nix +++ b/pkgs/development/ocaml-modules/ocf/ppx.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, ocf, ppxlib }: +{ + buildDunePackage, + ocf, + ppxlib, +}: buildDunePackage { pname = "ocf_ppx"; @@ -8,7 +12,10 @@ buildDunePackage { duneVersion = "3"; - buildInputs = [ ppxlib ocf ]; + buildInputs = [ + ppxlib + ocf + ]; meta = ocf.meta // { description = "Preprocessor for Ocf library"; diff --git a/pkgs/development/ocaml-modules/ocolor/default.nix b/pkgs/development/ocaml-modules/ocolor/default.nix index 16663a8db64c29..ebd34a84e684e1 100644 --- a/pkgs/development/ocaml-modules/ocolor/default.nix +++ b/pkgs/development/ocaml-modules/ocolor/default.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, cppo +{ + lib, + fetchFromGitHub, + buildDunePackage, + cppo, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ocp-ocamlres/default.nix b/pkgs/development/ocaml-modules/ocp-ocamlres/default.nix index e8b705ebdd4d83..263caad5486320 100644 --- a/pkgs/development/ocaml-modules/ocp-ocamlres/default.nix +++ b/pkgs/development/ocaml-modules/ocp-ocamlres/default.nix @@ -1,35 +1,49 @@ -{ stdenv, lib, fetchFromGitHub, ocaml, findlib, astring, pprint }: +{ + stdenv, + lib, + fetchFromGitHub, + ocaml, + findlib, + astring, + pprint, +}: -if lib.versionOlder ocaml.version "4.02" -then throw "ocp-ocamlres is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.02" then + throw "ocp-ocamlres is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-ocp-ocamlres"; - version = "0.4"; - src = fetchFromGitHub { - owner = "OCamlPro"; - repo = "ocp-ocamlres"; - rev = "v${version}"; - sha256 = "0smfwrj8qhzknhzawygxi0vgl2af4vyi652fkma59rzjpvscqrnn"; - }; + stdenv.mkDerivation rec { + pname = "ocaml${ocaml.version}-ocp-ocamlres"; + version = "0.4"; + src = fetchFromGitHub { + owner = "OCamlPro"; + repo = "ocp-ocamlres"; + rev = "v${version}"; + sha256 = "0smfwrj8qhzknhzawygxi0vgl2af4vyi652fkma59rzjpvscqrnn"; + }; - nativeBuildInputs = [ ocaml findlib ]; - buildInputs = [ astring pprint ]; + nativeBuildInputs = [ + ocaml + findlib + ]; + buildInputs = [ + astring + pprint + ]; - strictDeps = true; + strictDeps = true; - createFindlibDestdir = true; + createFindlibDestdir = true; - installFlags = [ "BINDIR=$(out)/bin" ]; - preInstall = "mkdir -p $out/bin"; + installFlags = [ "BINDIR=$(out)/bin" ]; + preInstall = "mkdir -p $out/bin"; - meta = { - description = "Simple tool and library to embed files and directories inside OCaml executables"; - homepage = "https://www.typerex.org/ocp-ocamlres.html"; - license = lib.licenses.lgpl3Plus; - maintainers = [ lib.maintainers.vbgl ]; - mainProgram = "ocp-ocamlres"; - inherit (ocaml.meta) platforms; - }; -} + meta = { + description = "Simple tool and library to embed files and directories inside OCaml executables"; + homepage = "https://www.typerex.org/ocp-ocamlres.html"; + license = lib.licenses.lgpl3Plus; + maintainers = [ lib.maintainers.vbgl ]; + mainProgram = "ocp-ocamlres"; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/ocplib-endian/default.nix b/pkgs/development/ocaml-modules/ocplib-endian/default.nix index c7fa14a291d711..2d7ea6e26359cf 100644 --- a/pkgs/development/ocaml-modules/ocplib-endian/default.nix +++ b/pkgs/development/ocaml-modules/ocplib-endian/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, ocaml, cppo }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + ocaml, + cppo, +}: buildDunePackage rec { version = "1.2"; diff --git a/pkgs/development/ocaml-modules/ocsigen-ppx-rpc/default.nix b/pkgs/development/ocaml-modules/ocsigen-ppx-rpc/default.nix index fdd6b91f19f17f..ae41c05490298c 100644 --- a/pkgs/development/ocaml-modules/ocsigen-ppx-rpc/default.nix +++ b/pkgs/development/ocaml-modules/ocsigen-ppx-rpc/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitHub, ppxlib }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + ppxlib, +}: buildDunePackage rec { pname = "ocsigen-ppx-rpc"; diff --git a/pkgs/development/ocaml-modules/ocsigen-server/default.nix b/pkgs/development/ocaml-modules/ocsigen-server/default.nix index 0984416020e93c..4e4a09e22d878b 100644 --- a/pkgs/development/ocaml-modules/ocsigen-server/default.nix +++ b/pkgs/development/ocaml-modules/ocsigen-server/default.nix @@ -1,20 +1,55 @@ -{ lib, buildDunePackage, fetchFromGitHub, which, ocaml, lwt_react, ssl, lwt_ssl, findlib -, bigstringaf, lwt, cstruct, mirage-crypto, zarith, mirage-crypto-ec, ptime, mirage-crypto-rng, mtime, ca-certs -, cohttp, cohttp-lwt-unix -, lwt_log, re, cryptokit, xml-light, ipaddr -, camlzip -, makeWrapper +{ + lib, + buildDunePackage, + fetchFromGitHub, + which, + ocaml, + lwt_react, + ssl, + lwt_ssl, + findlib, + bigstringaf, + lwt, + cstruct, + mirage-crypto, + zarith, + mirage-crypto-ec, + ptime, + mirage-crypto-rng, + mtime, + ca-certs, + cohttp, + cohttp-lwt-unix, + lwt_log, + re, + cryptokit, + xml-light, + ipaddr, + camlzip, + makeWrapper, }: -let mkpath = p: - "${p}/lib/ocaml/${ocaml.version}/site-lib/stublibs"; +let + mkpath = p: "${p}/lib/ocaml/${ocaml.version}/site-lib/stublibs"; in -let caml_ld_library_path = - lib.concatMapStringsSep ":" mkpath [ - bigstringaf lwt ssl cstruct mirage-crypto zarith mirage-crypto-ec ptime mirage-crypto-rng mtime ca-certs cryptokit re - ] -; in +let + caml_ld_library_path = lib.concatMapStringsSep ":" mkpath [ + bigstringaf + lwt + ssl + cstruct + mirage-crypto + zarith + mirage-crypto-ec + ptime + mirage-crypto-rng + mtime + ca-certs + cryptokit + re + ]; +in buildDunePackage rec { version = "6.0.0"; @@ -29,18 +64,36 @@ buildDunePackage rec { hash = "sha256-T3bgPZpDO6plgebLJDBtBuR2eR/bN3o24UAUv1VwgtI="; }; - nativeBuildInputs = [ makeWrapper which ]; - buildInputs = [ lwt_react camlzip findlib ]; + nativeBuildInputs = [ + makeWrapper + which + ]; + buildInputs = [ + lwt_react + camlzip + findlib + ]; - propagatedBuildInputs = [ cohttp cohttp-lwt-unix cryptokit ipaddr lwt_log lwt_ssl - re xml-light + propagatedBuildInputs = [ + cohttp + cohttp-lwt-unix + cryptokit + ipaddr + lwt_log + lwt_ssl + re + xml-light ]; - configureFlags = [ "--root $(out)" "--prefix /" "--temproot ''" ]; + configureFlags = [ + "--root $(out)" + "--prefix /" + "--temproot ''" + ]; dontAddPrefix = true; dontAddStaticConfigureFlags = true; - configurePlatforms = []; + configurePlatforms = [ ]; postConfigure = '' make -C src confs @@ -50,11 +103,10 @@ buildDunePackage rec { make install.files ''; - postFixup = - '' - rm -rf $out/var/run - wrapProgram $out/bin/ocsigenserver \ - --suffix CAML_LD_LIBRARY_PATH : "${caml_ld_library_path}" + postFixup = '' + rm -rf $out/var/run + wrapProgram $out/bin/ocsigenserver \ + --suffix CAML_LD_LIBRARY_PATH : "${caml_ld_library_path}" ''; dontPatchShebangs = true; @@ -62,9 +114,9 @@ buildDunePackage rec { meta = { homepage = "http://ocsigen.org/ocsigenserver/"; description = "Full featured Web server"; - longDescription ='' + longDescription = '' A full featured Web server. It implements most features of the HTTP protocol, and has a very powerful extension mechanism that make very easy to plug your own OCaml modules for generating pages. - ''; + ''; license = lib.licenses.lgpl21Only; inherit (ocaml.meta) platforms; maintainers = [ lib.maintainers.gal_bolle ]; diff --git a/pkgs/development/ocaml-modules/ocsigen-start/default.nix b/pkgs/development/ocaml-modules/ocsigen-start/default.nix index e9af3a27a756d2..37a63948a355e9 100644 --- a/pkgs/development/ocaml-modules/ocsigen-start/default.nix +++ b/pkgs/development/ocaml-modules/ocsigen-start/default.nix @@ -1,24 +1,47 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, ocaml, findlib, ocsigen-toolkit, pgocaml_ppx, safepass, yojson -, cohttp-lwt-unix, eliom -, resource-pooling -, ocsigen-ppx-rpc +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + ocaml, + findlib, + ocsigen-toolkit, + pgocaml_ppx, + safepass, + yojson, + cohttp-lwt-unix, + eliom, + resource-pooling, + ocsigen-ppx-rpc, }: stdenv.mkDerivation rec { pname = "ocaml${ocaml.version}-ocsigen-start"; version = "6.2.0"; - nativeBuildInputs = [ ocaml findlib eliom ]; + nativeBuildInputs = [ + ocaml + findlib + eliom + ]; buildInputs = [ ocsigen-ppx-rpc ]; - propagatedBuildInputs = [ pgocaml_ppx safepass ocsigen-toolkit yojson resource-pooling cohttp-lwt-unix ]; + propagatedBuildInputs = [ + pgocaml_ppx + safepass + ocsigen-toolkit + yojson + resource-pooling + cohttp-lwt-unix + ]; strictDeps = true; - patches = [ ./templates-dir.patch + patches = [ + ./templates-dir.patch # Compatibility with tyxml 4.6.x (fetchpatch { - url = "https://github.com/ocsigen/ocsigen-start/commit/0b70506f94fcb2e06cb65ce0d6a28b9b84c695f3.patch"; - hash = "sha256-p/VvIu9reI8lc9lxWiTrjZvn46vuF00QInYuWPtRVyk="; + url = "https://github.com/ocsigen/ocsigen-start/commit/0b70506f94fcb2e06cb65ce0d6a28b9b84c695f3.patch"; + hash = "sha256-p/VvIu9reI8lc9lxWiTrjZvn46vuF00QInYuWPtRVyk="; }) ]; @@ -36,9 +59,9 @@ stdenv.mkDerivation rec { meta = { homepage = "http://ocsigen.org/ocsigen-start"; description = "Eliom application skeleton"; - longDescription ='' - An Eliom application skeleton, ready to use to build your own application with users, (pre)registration, notifications, etc. - ''; + longDescription = '' + An Eliom application skeleton, ready to use to build your own application with users, (pre)registration, notifications, etc. + ''; license = lib.licenses.lgpl21Only; inherit (ocaml.meta) platforms; maintainers = [ lib.maintainers.gal_bolle ]; diff --git a/pkgs/development/ocaml-modules/ocsipersist/pgsql.nix b/pkgs/development/ocaml-modules/ocsipersist/pgsql.nix index e2d95e7434ef1a..6543eef3016289 100644 --- a/pkgs/development/ocaml-modules/ocsipersist/pgsql.nix +++ b/pkgs/development/ocaml-modules/ocsipersist/pgsql.nix @@ -1,8 +1,10 @@ -{ buildDunePackage, ocsipersist-lib -, lwt_log -, ocsigen_server -, pgocaml -, xml-light +{ + buildDunePackage, + ocsipersist-lib, + lwt_log, + ocsigen_server, + pgocaml, + xml-light, }: buildDunePackage { @@ -22,4 +24,3 @@ buildDunePackage { description = "Persistent key/value storage (for Ocsigen) using PostgreSQL"; }; } - diff --git a/pkgs/development/ocaml-modules/octavius/default.nix b/pkgs/development/ocaml-modules/octavius/default.nix index 1a973da5e84d84..fadb54519abf97 100644 --- a/pkgs/development/ocaml-modules/octavius/default.nix +++ b/pkgs/development/ocaml-modules/octavius/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage }: +{ + lib, + fetchFromGitHub, + buildDunePackage, +}: buildDunePackage rec { pname = "octavius"; diff --git a/pkgs/development/ocaml-modules/ocurl/default.nix b/pkgs/development/ocaml-modules/ocurl/default.nix index cb3c70198dc61f..8f30944d359081 100644 --- a/pkgs/development/ocaml-modules/ocurl/default.nix +++ b/pkgs/development/ocaml-modules/ocurl/default.nix @@ -1,27 +1,48 @@ -{ lib, stdenv, fetchurl, pkg-config, ocaml, findlib, curl, lwt, lwt_ppx }: -if lib.versionOlder ocaml.version "4.04" -then throw "ocurl is not available for OCaml ${ocaml.version}" +{ + lib, + stdenv, + fetchurl, + pkg-config, + ocaml, + findlib, + curl, + lwt, + lwt_ppx, +}: +if lib.versionOlder ocaml.version "4.04" then + throw "ocurl is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "ocurl"; - version = "0.9.2"; + stdenv.mkDerivation rec { + pname = "ocurl"; + version = "0.9.2"; - src = fetchurl { - url = "https://github.com/ygrek/ocurl/releases/download/${version}/ocurl-${version}.tar.gz"; - sha256 = "sha256-4DWXGMh02s1VwLWW5d7h0jtMOUubWmBPGm1hghfWd2M="; - }; + src = fetchurl { + url = "https://github.com/ygrek/ocurl/releases/download/${version}/ocurl-${version}.tar.gz"; + sha256 = "sha256-4DWXGMh02s1VwLWW5d7h0jtMOUubWmBPGm1hghfWd2M="; + }; - nativeBuildInputs = [ pkg-config ocaml findlib ]; - propagatedBuildInputs = [ curl lwt lwt_ppx ]; + nativeBuildInputs = [ + pkg-config + ocaml + findlib + ]; + propagatedBuildInputs = [ + curl + lwt + lwt_ppx + ]; - strictDeps = true; + strictDeps = true; - createFindlibDestdir = true; - meta = { - description = "OCaml bindings to libcurl"; - license = lib.licenses.mit; - homepage = "http://ygrek.org.ua/p/ocurl/"; - maintainers = with lib.maintainers; [ dandellion bennofs ]; - platforms = ocaml.meta.platforms or [ ]; - }; -} + createFindlibDestdir = true; + meta = { + description = "OCaml bindings to libcurl"; + license = lib.licenses.mit; + homepage = "http://ygrek.org.ua/p/ocurl/"; + maintainers = with lib.maintainers; [ + dandellion + bennofs + ]; + platforms = ocaml.meta.platforms or [ ]; + }; + } diff --git a/pkgs/development/ocaml-modules/odate/default.nix b/pkgs/development/ocaml-modules/odate/default.nix index 89c47781a8fb8b..c952882e7d0e13 100644 --- a/pkgs/development/ocaml-modules/odate/default.nix +++ b/pkgs/development/ocaml-modules/odate/default.nix @@ -1,5 +1,8 @@ -{ lib, buildDunePackage, fetchFromGitHub -, menhir +{ + lib, + buildDunePackage, + fetchFromGitHub, + menhir, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/odig/default.nix b/pkgs/development/ocaml-modules/odig/default.nix index 3fe26e5b90ddb1..6dca841771483d 100644 --- a/pkgs/development/ocaml-modules/odig/default.nix +++ b/pkgs/development/ocaml-modules/odig/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, buildTopkgPackage, cmdliner, odoc, b0 }: +{ + lib, + fetchurl, + buildTopkgPackage, + cmdliner, + odoc, + b0, +}: buildTopkgPackage rec { pname = "odig"; @@ -9,7 +16,11 @@ buildTopkgPackage rec { sha256 = "sha256-sYKvGYkxeF5FmrNQdOyMAtlsJqhlmUESi9SkPn/cjM4="; }; - buildInputs = [ cmdliner odoc b0 ]; + buildInputs = [ + cmdliner + odoc + b0 + ]; meta = with lib; { description = "Lookup documentation of installed OCaml packages"; diff --git a/pkgs/development/ocaml-modules/odoc-parser/default.nix b/pkgs/development/ocaml-modules/odoc-parser/default.nix index 5d22d2d7123847..83f58189652257 100644 --- a/pkgs/development/ocaml-modules/odoc-parser/default.nix +++ b/pkgs/development/ocaml-modules/odoc-parser/default.nix @@ -1,49 +1,67 @@ -{ lib, fetchurl, buildDunePackage, ocaml, astring, result, camlp-streams, version ? "2.4.2" }: +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + astring, + result, + camlp-streams, + version ? "2.4.2", +}: -let param = { - "2.4.2" = { - sha256 = "sha256-Vjz9uybsijDnN6nPKFoG4LuulT9I4lu7D2n3qZwrpAs="; - }; - "2.0.0" = { - sha256 = "sha256-QHkZ+7DrlXYdb8bsZ3dijZSqGQc0O9ymeLGIC6+zOSI="; - }; - "1.0.1" = { - sha256 = "sha256-orvo5CAbYOmAurAeluQfK6CwW6P1C0T3WDfoovuQfSw="; - }; - "1.0.0" = { - sha256 = "sha256-tqoI6nGp662bK+vE2h7aDXE882dObVfRBFnZNChueqE="; - max_version = "5.0"; - }; - "0.9.0" = { - sha256 = "sha256-3w2tG605v03mvmZsS2O5c71y66O3W+n3JjFxIbXwvXk="; - max_version = "5.0"; - }; -}."${version}"; in +let + param = + { + "2.4.2" = { + sha256 = "sha256-Vjz9uybsijDnN6nPKFoG4LuulT9I4lu7D2n3qZwrpAs="; + }; + "2.0.0" = { + sha256 = "sha256-QHkZ+7DrlXYdb8bsZ3dijZSqGQc0O9ymeLGIC6+zOSI="; + }; + "1.0.1" = { + sha256 = "sha256-orvo5CAbYOmAurAeluQfK6CwW6P1C0T3WDfoovuQfSw="; + }; + "1.0.0" = { + sha256 = "sha256-tqoI6nGp662bK+vE2h7aDXE882dObVfRBFnZNChueqE="; + max_version = "5.0"; + }; + "0.9.0" = { + sha256 = "sha256-3w2tG605v03mvmZsS2O5c71y66O3W+n3JjFxIbXwvXk="; + max_version = "5.0"; + }; + } + ."${version}"; +in lib.throwIf (param ? max_version && lib.versionAtLeast ocaml.version param.max_version) "odoc-parser ${version} is not available for OCaml ${ocaml.version}" -buildDunePackage rec { - pname = "odoc-parser"; - inherit version; + buildDunePackage + rec { + pname = "odoc-parser"; + inherit version; - minimalOCamlVersion = "4.02"; + minimalOCamlVersion = "4.02"; - src = fetchurl { - url = if lib.versionAtLeast version "2.4" - then "https://github.com/ocaml/odoc/releases/download/${version}/odoc-${version}.tbz" - else "https://github.com/ocaml-doc/odoc-parser/releases/download/${version}/odoc-parser-${version}.tbz"; - inherit (param) sha256; - }; + src = fetchurl { + url = + if lib.versionAtLeast version "2.4" then + "https://github.com/ocaml/odoc/releases/download/${version}/odoc-${version}.tbz" + else + "https://github.com/ocaml-doc/odoc-parser/releases/download/${version}/odoc-parser-${version}.tbz"; + inherit (param) sha256; + }; - propagatedBuildInputs = [ astring result ] ++ - lib.optional (lib.versionAtLeast version "1.0.1") camlp-streams; + propagatedBuildInputs = [ + astring + result + ] ++ lib.optional (lib.versionAtLeast version "1.0.1") camlp-streams; - meta = { - description = "Parser for Ocaml documentation comments"; - license = lib.licenses.isc; - maintainers = [ ]; - homepage = "https://github.com/ocaml-doc/odoc-parser"; - changelog = "https://github.com/ocaml-doc/odoc-parser/raw/${version}/CHANGES.md"; - }; -} + meta = { + description = "Parser for Ocaml documentation comments"; + license = lib.licenses.isc; + maintainers = [ ]; + homepage = "https://github.com/ocaml-doc/odoc-parser"; + changelog = "https://github.com/ocaml-doc/odoc-parser/raw/${version}/CHANGES.md"; + }; + } diff --git a/pkgs/development/ocaml-modules/odoc/default.nix b/pkgs/development/ocaml-modules/odoc/default.nix index 58a52a04c19618..d49547dafab4b0 100644 --- a/pkgs/development/ocaml-modules/odoc/default.nix +++ b/pkgs/development/ocaml-modules/odoc/default.nix @@ -1,21 +1,54 @@ -{ lib, buildDunePackage, ocaml -, ocaml-crunch -, astring, cmdliner, cppo, fpath, result, tyxml -, markup, yojson, sexplib0, jq -, odoc-parser, ppx_expect, bash, fmt +{ + lib, + buildDunePackage, + ocaml, + ocaml-crunch, + astring, + cmdliner, + cppo, + fpath, + result, + tyxml, + markup, + yojson, + sexplib0, + jq, + odoc-parser, + ppx_expect, + bash, + fmt, }: buildDunePackage rec { pname = "odoc"; inherit (odoc-parser) version src; - nativeBuildInputs = [ cppo ocaml-crunch ]; - buildInputs = [ astring cmdliner fpath result tyxml odoc-parser fmt ]; + nativeBuildInputs = [ + cppo + ocaml-crunch + ]; + buildInputs = [ + astring + cmdliner + fpath + result + tyxml + odoc-parser + fmt + ]; - nativeCheckInputs = [ bash jq ]; - checkInputs = [ markup yojson sexplib0 jq ppx_expect ]; - doCheck = lib.versionAtLeast ocaml.version "4.08" - && lib.versionOlder yojson.version "2.0"; + nativeCheckInputs = [ + bash + jq + ]; + checkInputs = [ + markup + yojson + sexplib0 + jq + ppx_expect + ]; + doCheck = lib.versionAtLeast ocaml.version "4.08" && lib.versionOlder yojson.version "2.0"; preCheck = '' # some run.t files check the content of patchShebangs-ed scripts, so patch diff --git a/pkgs/development/ocaml-modules/ogg/default.nix b/pkgs/development/ocaml-modules/ogg/default.nix index 6c125130e81c2e..b815923bb91182 100644 --- a/pkgs/development/ocaml-modules/ogg/default.nix +++ b/pkgs/development/ocaml-modules/ogg/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, libogg }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + libogg, +}: buildDunePackage rec { pname = "ogg"; diff --git a/pkgs/development/ocaml-modules/omd/default.nix b/pkgs/development/ocaml-modules/omd/default.nix index 2ccf939ea614d9..cb0697188eb4c5 100644 --- a/pkgs/development/ocaml-modules/omd/default.nix +++ b/pkgs/development/ocaml-modules/omd/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "omd"; diff --git a/pkgs/development/ocaml-modules/opam-core/default.nix b/pkgs/development/ocaml-modules/opam-core/default.nix index 0aa5f10f0674a4..0cb568cd2dfcef 100644 --- a/pkgs/development/ocaml-modules/opam-core/default.nix +++ b/pkgs/development/ocaml-modules/opam-core/default.nix @@ -1,5 +1,13 @@ -{ lib, buildDunePackage, opam -, jsonm, ocamlgraph, re, sha, swhid_core, uutf +{ + lib, + buildDunePackage, + opam, + jsonm, + ocamlgraph, + re, + sha, + swhid_core, + uutf, }: buildDunePackage { @@ -7,7 +15,14 @@ buildDunePackage { inherit (opam) src version; - propagatedBuildInputs = [ jsonm ocamlgraph uutf re sha swhid_core ]; + propagatedBuildInputs = [ + jsonm + ocamlgraph + uutf + re + sha + swhid_core + ]; # get rid of check for curl at configure time # opam-core does not call curl at run time diff --git a/pkgs/development/ocaml-modules/opam-file-format/default.nix b/pkgs/development/ocaml-modules/opam-file-format/default.nix index f91609aa27cfa6..eaf87e5684f848 100644 --- a/pkgs/development/ocaml-modules/opam-file-format/default.nix +++ b/pkgs/development/ocaml-modules/opam-file-format/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage }: +{ + lib, + fetchFromGitHub, + buildDunePackage, +}: buildDunePackage rec { pname = "opam-file-format"; diff --git a/pkgs/development/ocaml-modules/opam-format/default.nix b/pkgs/development/ocaml-modules/opam-format/default.nix index 27b90a8556b472..63c83949e9f240 100644 --- a/pkgs/development/ocaml-modules/opam-format/default.nix +++ b/pkgs/development/ocaml-modules/opam-format/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, opam-core, opam-file-format }: +{ + lib, + buildDunePackage, + opam-core, + opam-file-format, +}: buildDunePackage { pname = "opam-format"; @@ -9,7 +14,10 @@ buildDunePackage { # opam-format does not call curl at run time configureFlags = [ "--disable-checks" ]; - propagatedBuildInputs = [ opam-core opam-file-format ]; + propagatedBuildInputs = [ + opam-core + opam-file-format + ]; meta = opam-core.meta // { description = "Definition of opam datastructures and its file interface"; diff --git a/pkgs/development/ocaml-modules/opam-repository/default.nix b/pkgs/development/ocaml-modules/opam-repository/default.nix index 472bcc78f211db..61b9bc4133c129 100644 --- a/pkgs/development/ocaml-modules/opam-repository/default.nix +++ b/pkgs/development/ocaml-modules/opam-repository/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, opam-format, curl }: +{ + lib, + buildDunePackage, + opam-format, + curl, +}: buildDunePackage { pname = "opam-repository"; diff --git a/pkgs/development/ocaml-modules/opam-state/default.nix b/pkgs/development/ocaml-modules/opam-state/default.nix index 7481f04f3202e4..a2ff0249b652e5 100644 --- a/pkgs/development/ocaml-modules/opam-state/default.nix +++ b/pkgs/development/ocaml-modules/opam-state/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, opam, opam-repository, spdx_licenses }: +{ + lib, + buildDunePackage, + opam, + opam-repository, + spdx_licenses, +}: buildDunePackage { pname = "opam-state"; @@ -9,7 +15,10 @@ buildDunePackage { # opam-state does not call curl at run time configureFlags = [ "--disable-checks" ]; - propagatedBuildInputs = [ opam-repository spdx_licenses ]; + propagatedBuildInputs = [ + opam-repository + spdx_licenses + ]; meta = opam.meta // { description = "OPAM development library handling the ~/.opam hierarchy, repository and switch states"; diff --git a/pkgs/development/ocaml-modules/opium/default.nix b/pkgs/development/ocaml-modules/opium/default.nix index ceae3c4867cfad..719f0fcbfe9f0a 100644 --- a/pkgs/development/ocaml-modules/opium/default.nix +++ b/pkgs/development/ocaml-modules/opium/default.nix @@ -1,23 +1,24 @@ -{ buildDunePackage -, lib -, astring -, base64 -, cmdliner -, fmt -, httpaf -, httpaf-lwt-unix -, logs -, magic-mime -, mirage-crypto -, mtime -, multipart-form-data -, ptime -, re -, rock -, tyxml -, uri -, yojson -, alcotest-lwt +{ + buildDunePackage, + lib, + astring, + base64, + cmdliner, + fmt, + httpaf, + httpaf-lwt-unix, + logs, + magic-mime, + mirage-crypto, + mtime, + multipart-form-data, + ptime, + re, + rock, + tyxml, + uri, + yojson, + alcotest-lwt, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/opti/default.nix b/pkgs/development/ocaml-modules/opti/default.nix index 1d854a1fda5028..c0eec8aa06c709 100644 --- a/pkgs/development/ocaml-modules/opti/default.nix +++ b/pkgs/development/ocaml-modules/opti/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, buildDunePackage }: +{ + lib, + fetchurl, + buildDunePackage, +}: buildDunePackage rec { pname = "opti"; diff --git a/pkgs/development/ocaml-modules/optint/default.nix b/pkgs/development/ocaml-modules/optint/default.nix index d98f6cf5ee2f27..2726e0aae88977 100644 --- a/pkgs/development/ocaml-modules/optint/default.nix +++ b/pkgs/development/ocaml-modules/optint/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { minimalOCamlVersion = "4.07"; diff --git a/pkgs/development/ocaml-modules/opus/default.nix b/pkgs/development/ocaml-modules/opus/default.nix index 104846b87f6e4c..693426fb235661 100644 --- a/pkgs/development/ocaml-modules/opus/default.nix +++ b/pkgs/development/ocaml-modules/opus/default.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, pkg-config, ogg, libopus }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + pkg-config, + ogg, + libopus, +}: buildDunePackage rec { pname = "opus"; @@ -15,7 +23,10 @@ buildDunePackage rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ ogg libopus.dev ]; + propagatedBuildInputs = [ + ogg + libopus.dev + ]; meta = with lib; { homepage = "https://github.com/savonet/ocaml-opus"; diff --git a/pkgs/development/ocaml-modules/oseq/default.nix b/pkgs/development/ocaml-modules/oseq/default.nix index 02b34027573261..7d462b10c6a24e 100644 --- a/pkgs/development/ocaml-modules/oseq/default.nix +++ b/pkgs/development/ocaml-modules/oseq/default.nix @@ -1,5 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage -, containers, qcheck +{ + lib, + fetchFromGitHub, + buildDunePackage, + containers, + qcheck, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/otfed/default.nix b/pkgs/development/ocaml-modules/otfed/default.nix index d9d3c5bcb54f0f..b33036380e1726 100644 --- a/pkgs/development/ocaml-modules/otfed/default.nix +++ b/pkgs/development/ocaml-modules/otfed/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildDunePackage -, fetchFromGitHub -, base -, ppx_deriving -, ppx_inline_test -, uutf -, alcotest +{ + lib, + buildDunePackage, + fetchFromGitHub, + base, + ppx_deriving, + ppx_inline_test, + uutf, + alcotest, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/otfm/default.nix b/pkgs/development/ocaml-modules/otfm/default.nix index c7b9d930bd6f07..6d4e4a5ffbc3d3 100644 --- a/pkgs/development/ocaml-modules/otfm/default.nix +++ b/pkgs/development/ocaml-modules/otfm/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, ocamlbuild, topkg, uutf }: +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + uutf, +}: let pname = "otfm"; @@ -16,7 +25,12 @@ stdenv.mkDerivation { hash = "sha256-02U23mYTy0ZJgSObDoyygPTGEMC4/Zge5bux4wshaEE="; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; buildInputs = [ topkg ]; propagatedBuildInputs = [ uutf ]; diff --git a/pkgs/development/ocaml-modules/otoml/default.nix b/pkgs/development/ocaml-modules/otoml/default.nix index 10b8a03a1b1879..8990a3611ecaab 100644 --- a/pkgs/development/ocaml-modules/otoml/default.nix +++ b/pkgs/development/ocaml-modules/otoml/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, menhir -, menhirLib -, uutf +{ + lib, + fetchFromGitHub, + buildDunePackage, + menhir, + menhirLib, + uutf, }: buildDunePackage rec { @@ -21,7 +22,10 @@ buildDunePackage rec { nativeBuildInputs = [ menhir ]; - propagatedBuildInputs = [ menhirLib uutf ]; + propagatedBuildInputs = [ + menhirLib + uutf + ]; meta = { description = "TOML parsing and manipulation library for OCaml"; diff --git a/pkgs/development/ocaml-modules/otr/default.nix b/pkgs/development/ocaml-modules/otr/default.nix index ef4743be9ac933..12c45fda978d09 100644 --- a/pkgs/development/ocaml-modules/otr/default.nix +++ b/pkgs/development/ocaml-modules/otr/default.nix @@ -1,5 +1,13 @@ -{ lib, fetchurl, buildDunePackage -, digestif, sexplib0, mirage-crypto, mirage-crypto-pk, astring, base64 +{ + lib, + fetchurl, + buildDunePackage, + digestif, + sexplib0, + mirage-crypto, + mirage-crypto-pk, + astring, + base64, }: buildDunePackage rec { @@ -13,8 +21,14 @@ buildDunePackage rec { hash = "sha256-/CcVqLbdylB+LqpKNETkpvQ8SEAIcEFCO1MZqvdmJWU="; }; - propagatedBuildInputs = [ digestif sexplib0 mirage-crypto mirage-crypto-pk - astring base64 ]; + propagatedBuildInputs = [ + digestif + sexplib0 + mirage-crypto + mirage-crypto-pk + astring + base64 + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/ounit/default.nix b/pkgs/development/ocaml-modules/ounit/default.nix index a40111cd3b3785..6f355769c6d0eb 100644 --- a/pkgs/development/ocaml-modules/ounit/default.nix +++ b/pkgs/development/ocaml-modules/ounit/default.nix @@ -1,4 +1,9 @@ -{ stdenv, ocaml, findlib, ounit2 }: +{ + stdenv, + ocaml, + findlib, + ounit2, +}: stdenv.mkDerivation { pname = "ocaml${ocaml.version}-ounit"; diff --git a/pkgs/development/ocaml-modules/ounit2/default.nix b/pkgs/development/ocaml-modules/ounit2/default.nix index 1d629daef87516..7708bc1849afe8 100644 --- a/pkgs/development/ocaml-modules/ounit2/default.nix +++ b/pkgs/development/ocaml-modules/ounit2/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchurl, seq, stdlib-shims }: +{ + lib, + buildDunePackage, + fetchurl, + seq, + stdlib-shims, +}: buildDunePackage rec { minimalOCamlVersion = "4.08"; @@ -11,7 +17,10 @@ buildDunePackage rec { hash = "sha256-kPbmO9EkClHYubL3IgWb15zgC1J2vdYji49cYTwOc4g="; }; - propagatedBuildInputs = [ seq stdlib-shims ]; + propagatedBuildInputs = [ + seq + stdlib-shims + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/owee/default.nix b/pkgs/development/ocaml-modules/owee/default.nix index 67cdb3828f818c..9f61ee89d32239 100644 --- a/pkgs/development/ocaml-modules/owee/default.nix +++ b/pkgs/development/ocaml-modules/owee/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { minimalOCamlVersion = "4.06"; @@ -6,8 +10,7 @@ buildDunePackage rec { version = "0.7"; src = fetchurl { - url = - "https://github.com/let-def/owee/releases/download/v${version}/owee-${version}.tbz"; + url = "https://github.com/let-def/owee/releases/download/v${version}/owee-${version}.tbz"; hash = "sha256-9FXcmddHg5mk5UWgYd4kTPOLOY/p6A/OBuvfas4elUA="; }; @@ -15,6 +18,9 @@ buildDunePackage rec { description = "Experimental OCaml library to work with DWARF format"; homepage = "https://github.com/let-def/owee/"; license = licenses.mit; - maintainers = with maintainers; [ vbgl alizter ]; + maintainers = with maintainers; [ + vbgl + alizter + ]; }; } diff --git a/pkgs/development/ocaml-modules/owl-base/default.nix b/pkgs/development/ocaml-modules/owl-base/default.nix index 2f27d5d3e17b5e..2c9eb60a189314 100644 --- a/pkgs/development/ocaml-modules/owl-base/default.nix +++ b/pkgs/development/ocaml-modules/owl-base/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "owl-base"; diff --git a/pkgs/development/ocaml-modules/owl/default.nix b/pkgs/development/ocaml-modules/owl/default.nix index 178a4f6349b3dd..5826a1ba39b843 100644 --- a/pkgs/development/ocaml-modules/owl/default.nix +++ b/pkgs/development/ocaml-modules/owl/default.nix @@ -1,21 +1,24 @@ -{ buildDunePackage -, dune-configurator -, alcotest -, ctypes -, stdio -, openblasCompat -, owl-base -, npy +{ + buildDunePackage, + dune-configurator, + alcotest, + ctypes, + stdio, + openblasCompat, + owl-base, + npy, }: - buildDunePackage rec { pname = "owl"; inherit (owl-base) version src meta; checkInputs = [ alcotest ]; - buildInputs = [ dune-configurator stdio ]; + buildInputs = [ + dune-configurator + stdio + ]; propagatedBuildInputs = [ ctypes openblasCompat diff --git a/pkgs/development/ocaml-modules/paf/cohttp.nix b/pkgs/development/ocaml-modules/paf/cohttp.nix index a19f3797e71a84..253b271e0e97d1 100644 --- a/pkgs/development/ocaml-modules/paf/cohttp.nix +++ b/pkgs/development/ocaml-modules/paf/cohttp.nix @@ -1,18 +1,19 @@ -{ buildDunePackage -, paf -, cohttp-lwt -, domain-name -, httpaf -, ipaddr -, alcotest-lwt -, fmt -, logs -, mirage-crypto-rng -, mirage-time-unix -, tcpip -, uri -, lwt -, astring +{ + buildDunePackage, + paf, + cohttp-lwt, + domain-name, + httpaf, + ipaddr, + alcotest-lwt, + fmt, + logs, + mirage-crypto-rng, + mirage-time-unix, + tcpip, + uri, + lwt, + astring, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/paf/default.nix b/pkgs/development/ocaml-modules/paf/default.nix index 7ac80079933aaf..404597974164ee 100644 --- a/pkgs/development/ocaml-modules/paf/default.nix +++ b/pkgs/development/ocaml-modules/paf/default.nix @@ -1,25 +1,26 @@ -{ buildDunePackage -, lib -, fetchurl -, mirage-time -, h2 -, tls-mirage -, mimic -, ke -, bigstringaf -, faraday -, tls -, lwt -, logs -, fmt -, mirage-crypto-rng -, tcpip -, mirage-time-unix -, ptime -, uri -, alcotest-lwt -, cstruct -, httpaf +{ + buildDunePackage, + lib, + fetchurl, + mirage-time, + h2, + tls-mirage, + mimic, + ke, + bigstringaf, + faraday, + tls, + lwt, + logs, + fmt, + mirage-crypto-rng, + tcpip, + mirage-time-unix, + ptime, + uri, + alcotest-lwt, + cstruct, + httpaf, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/parany/default.nix b/pkgs/development/ocaml-modules/parany/default.nix index 3824730765825d..1b0605a6269da2 100644 --- a/pkgs/development/ocaml-modules/parany/default.nix +++ b/pkgs/development/ocaml-modules/parany/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitHub, cpu }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + cpu, +}: buildDunePackage rec { pname = "parany"; diff --git a/pkgs/development/ocaml-modules/parmap/default.nix b/pkgs/development/ocaml-modules/parmap/default.nix index a8885aa27f2741..7babaab8b725a3 100644 --- a/pkgs/development/ocaml-modules/parmap/default.nix +++ b/pkgs/development/ocaml-modules/parmap/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, dune-configurator }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + dune-configurator, +}: buildDunePackage rec { pname = "parmap"; diff --git a/pkgs/development/ocaml-modules/parse-argv/default.nix b/pkgs/development/ocaml-modules/parse-argv/default.nix index 88df0bc281d131..b59feac4fb4004 100644 --- a/pkgs/development/ocaml-modules/parse-argv/default.nix +++ b/pkgs/development/ocaml-modules/parse-argv/default.nix @@ -1,6 +1,10 @@ -{ lib, fetchurl, buildDunePackage, ocaml -, astring -, ounit +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + astring, + ounit, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/path_glob/default.nix b/pkgs/development/ocaml-modules/path_glob/default.nix index ed6363bad26138..e0f56e6a63776a 100644 --- a/pkgs/development/ocaml-modules/path_glob/default.nix +++ b/pkgs/development/ocaml-modules/path_glob/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "path_glob"; diff --git a/pkgs/development/ocaml-modules/pbkdf/default.nix b/pkgs/development/ocaml-modules/pbkdf/default.nix index 27b269b369e8ea..b09fcdf56fade9 100644 --- a/pkgs/development/ocaml-modules/pbkdf/default.nix +++ b/pkgs/development/ocaml-modules/pbkdf/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildDunePackage -, fetchzip -, digestif -, mirage-crypto -, alcotest -, ohex +{ + lib, + buildDunePackage, + fetchzip, + digestif, + mirage-crypto, + alcotest, + ohex, }: buildDunePackage rec { @@ -17,8 +18,14 @@ buildDunePackage rec { }; minimalOCamlVersion = "4.08"; - propagatedBuildInputs = [ digestif mirage-crypto ]; - checkInputs = [ alcotest ohex ]; + propagatedBuildInputs = [ + digestif + mirage-crypto + ]; + checkInputs = [ + alcotest + ohex + ]; doCheck = true; meta = { @@ -28,4 +35,3 @@ buildDunePackage rec { homepage = "https://github.com/abeaumont/ocaml-pbkdf"; }; } - diff --git a/pkgs/development/ocaml-modules/pbrt/default.nix b/pkgs/development/ocaml-modules/pbrt/default.nix index ec5e5df7ab49d4..c025ee5d5bffb3 100644 --- a/pkgs/development/ocaml-modules/pbrt/default.nix +++ b/pkgs/development/ocaml-modules/pbrt/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage }: +{ + lib, + fetchFromGitHub, + buildDunePackage, +}: buildDunePackage rec { pname = "pbrt"; @@ -20,4 +24,3 @@ buildDunePackage rec { maintainers = [ maintainers.vyorkin ]; }; } - diff --git a/pkgs/development/ocaml-modules/pcap-format/default.nix b/pkgs/development/ocaml-modules/pcap-format/default.nix index e73492830893c1..b8b93b7af56be2 100644 --- a/pkgs/development/ocaml-modules/pcap-format/default.nix +++ b/pkgs/development/ocaml-modules/pcap-format/default.nix @@ -1,7 +1,10 @@ -{ lib, buildDunePackage, fetchurl -, ppx_cstruct -, cstruct -, ounit +{ + lib, + buildDunePackage, + fetchurl, + ppx_cstruct, + cstruct, + ounit, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/pecu/default.nix b/pkgs/development/ocaml-modules/pecu/default.nix index 66d9e56c6dc365..6f05ea5196a4c4 100644 --- a/pkgs/development/ocaml-modules/pecu/default.nix +++ b/pkgs/development/ocaml-modules/pecu/default.nix @@ -1,4 +1,13 @@ -{ lib, buildDunePackage, ocaml, fetchurl, fmt, alcotest, crowbar, astring }: +{ + lib, + buildDunePackage, + ocaml, + fetchurl, + fmt, + alcotest, + crowbar, + astring, +}: buildDunePackage rec { pname = "pecu"; @@ -13,7 +22,12 @@ buildDunePackage rec { # crowbar availability doCheck = lib.versionAtLeast ocaml.version "4.08"; - checkInputs = [ fmt alcotest crowbar astring ]; + checkInputs = [ + fmt + alcotest + crowbar + astring + ]; meta = with lib; { description = "Encoder/Decoder of Quoted-Printable (RFC2045 & RFC2047)"; diff --git a/pkgs/development/ocaml-modules/pgocaml/default.nix b/pkgs/development/ocaml-modules/pgocaml/default.nix index ba9a97fcaa0d18..454939a9d11473 100644 --- a/pkgs/development/ocaml-modules/pgocaml/default.nix +++ b/pkgs/development/ocaml-modules/pgocaml/default.nix @@ -1,5 +1,16 @@ -{ lib, fetchFromGitHub, buildDunePackage -, calendar, camlp-streams, csv, hex, ppx_deriving, ppx_sexp_conv, re, rresult, sexplib +{ + lib, + fetchFromGitHub, + buildDunePackage, + calendar, + camlp-streams, + csv, + hex, + ppx_deriving, + ppx_sexp_conv, + re, + rresult, + sexplib, }: buildDunePackage rec { @@ -14,8 +25,16 @@ buildDunePackage rec { minimalOCamlVersion = "4.08"; - propagatedBuildInputs = [ calendar csv hex ppx_deriving ppx_sexp_conv re - rresult sexplib camlp-streams + propagatedBuildInputs = [ + calendar + csv + hex + ppx_deriving + ppx_sexp_conv + re + rresult + sexplib + camlp-streams ]; meta = with lib; { diff --git a/pkgs/development/ocaml-modules/pgocaml/ppx.nix b/pkgs/development/ocaml-modules/pgocaml/ppx.nix index 1b76f9a577e7e0..4c1f1204825f98 100644 --- a/pkgs/development/ocaml-modules/pgocaml/ppx.nix +++ b/pkgs/development/ocaml-modules/pgocaml/ppx.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, pgocaml, ppx_optcomp }: +{ + buildDunePackage, + pgocaml, + ppx_optcomp, +}: buildDunePackage { pname = "pgocaml_ppx"; diff --git a/pkgs/development/ocaml-modules/pgsolver/default.nix b/pkgs/development/ocaml-modules/pgsolver/default.nix index 4bf765bc9cfc4c..ddfde095c7d973 100644 --- a/pkgs/development/ocaml-modules/pgsolver/default.nix +++ b/pkgs/development/ocaml-modules/pgsolver/default.nix @@ -1,18 +1,28 @@ -{ lib, fetchFromGitHub, buildOasisPackage, ounit, tcslib, ocaml-sat-solvers }: +{ + lib, + fetchFromGitHub, + buildOasisPackage, + ounit, + tcslib, + ocaml-sat-solvers, +}: buildOasisPackage rec { pname = "pgsolver"; version = "4.1"; src = fetchFromGitHub { - owner = "tcsprojects"; - repo = "pgsolver"; - rev = "v${version}"; + owner = "tcsprojects"; + repo = "pgsolver"; + rev = "v${version}"; sha256 = "16skrn8qql9djpray25xv66rjgfl20js5wqnxyq1763nmyizyj8a"; }; buildInputs = [ ounit ]; - propagatedBuildInputs = [ tcslib ocaml-sat-solvers ]; + propagatedBuildInputs = [ + tcslib + ocaml-sat-solvers + ]; meta = { description = "Collection of tools for generating, manipulating and - most of all - solving parity games"; diff --git a/pkgs/development/ocaml-modules/phylogenetics/default.nix b/pkgs/development/ocaml-modules/phylogenetics/default.nix index dd99947db1f58b..122ca3e0416b04 100644 --- a/pkgs/development/ocaml-modules/phylogenetics/default.nix +++ b/pkgs/development/ocaml-modules/phylogenetics/default.nix @@ -1,16 +1,17 @@ -{ lib -, buildDunePackage -, fetchurl -, bppsuite -, alcotest -, angstrom-unix -, biotk -, core -, gsl -, lacaml -, menhir -, menhirLib -, printbox-text +{ + lib, + buildDunePackage, + fetchurl, + bppsuite, + alcotest, + angstrom-unix, + biotk, + core, + gsl, + lacaml, + menhir, + menhirLib, + printbox-text, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/piaf/default.nix b/pkgs/development/ocaml-modules/piaf/default.nix index 9c2e481b76e4d9..dae4a95291d0bc 100644 --- a/pkgs/development/ocaml-modules/piaf/default.nix +++ b/pkgs/development/ocaml-modules/piaf/default.nix @@ -1,23 +1,24 @@ -{ alcotest -, buildDunePackage -, fetchurl -, eio-ssl -, faraday -, h2-eio -, httpun-eio -, httpun-ws -, ipaddr -, ke -, lib -, logs -, magic-mime -, pecu -, prettym -, unstrctrd -, uri -, uutf -, dune-site -, eio_main +{ + alcotest, + buildDunePackage, + fetchurl, + eio-ssl, + faraday, + h2-eio, + httpun-eio, + httpun-ws, + ipaddr, + ke, + lib, + logs, + magic-mime, + pecu, + prettym, + unstrctrd, + uri, + uutf, + dune-site, + eio_main, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/piqi-ocaml/default.nix b/pkgs/development/ocaml-modules/piqi-ocaml/default.nix index ae1efafb22516d..74f01c35ce9440 100644 --- a/pkgs/development/ocaml-modules/piqi-ocaml/default.nix +++ b/pkgs/development/ocaml-modules/piqi-ocaml/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, findlib, piqi, stdlib-shims, num }: +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, + piqi, + stdlib-shims, + num, +}: stdenv.mkDerivation rec { version = "0.7.8"; @@ -12,8 +21,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-6Luq49sbo+AqLSq57mc6fLhrRx0K6G5LCUIzkGPfqYo="; }; - nativeBuildInputs = [ ocaml findlib ]; - buildInputs = [ piqi stdlib-shims ]; + nativeBuildInputs = [ + ocaml + findlib + ]; + buildInputs = [ + piqi + stdlib-shims + ]; checkInputs = [ num ]; diff --git a/pkgs/development/ocaml-modules/piqi/default.nix b/pkgs/development/ocaml-modules/piqi/default.nix index fb5f0192c45997..1c45d67324d60b 100644 --- a/pkgs/development/ocaml-modules/piqi/default.nix +++ b/pkgs/development/ocaml-modules/piqi/default.nix @@ -1,37 +1,64 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, findlib, which, sedlex, easy-format, xmlm, base64 }: +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, + which, + sedlex, + easy-format, + xmlm, + base64, +}: lib.throwIf (lib.versionAtLeast ocaml.version "5.0") "piqi is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - version = "0.6.16"; - pname = "piqi"; - name = "ocaml${ocaml.version}-${pname}-${version}"; + stdenv.mkDerivation + rec { + version = "0.6.16"; + pname = "piqi"; + name = "ocaml${ocaml.version}-${pname}-${version}"; - src = fetchFromGitHub { - owner = "alavrik"; - repo = pname; - rev = "v${version}"; - sha256 = "sha256-qE+yybTn+kzbY0h8udhZYO+GwQPI/J/6p3LMmF12cFU="; - }; + src = fetchFromGitHub { + owner = "alavrik"; + repo = pname; + rev = "v${version}"; + sha256 = "sha256-qE+yybTn+kzbY0h8udhZYO+GwQPI/J/6p3LMmF12cFU="; + }; - nativeBuildInputs = [ ocaml findlib which ]; - propagatedBuildInputs = [ sedlex xmlm easy-format base64 ]; + nativeBuildInputs = [ + ocaml + findlib + which + ]; + propagatedBuildInputs = [ + sedlex + xmlm + easy-format + base64 + ]; - strictDeps = true; + strictDeps = true; - patches = [ ./no-stream.patch ./no-ocamlpath-override.patch ]; + patches = [ + ./no-stream.patch + ./no-ocamlpath-override.patch + ]; - createFindlibDestdir = true; + createFindlibDestdir = true; - postBuild = "make -C piqilib piqilib.cma"; + postBuild = "make -C piqilib piqilib.cma"; - installTargets = [ "install" "ocaml-install" ]; + installTargets = [ + "install" + "ocaml-install" + ]; - meta = with lib; { - homepage = "https://piqi.org"; - description = "Universal schema language and a collection of tools built around it"; - license = licenses.asl20; - maintainers = [ maintainers.maurer ]; - }; -} + meta = with lib; { + homepage = "https://piqi.org"; + description = "Universal schema language and a collection of tools built around it"; + license = licenses.asl20; + maintainers = [ maintainers.maurer ]; + }; + } diff --git a/pkgs/development/ocaml-modules/plotkicadsch/default.nix b/pkgs/development/ocaml-modules/plotkicadsch/default.nix index 09593f835aef66..69f67ae580a6d6 100644 --- a/pkgs/development/ocaml-modules/plotkicadsch/default.nix +++ b/pkgs/development/ocaml-modules/plotkicadsch/default.nix @@ -1,17 +1,18 @@ -{ lib -, buildDunePackage -, substituteAll -, base64 -, cmdliner -, digestif -, git-unix -, kicadsch -, lwt -, lwt_ppx -, sha -, tyxml -, coreutils -, imagemagick +{ + lib, + buildDunePackage, + substituteAll, + base64, + cmdliner, + digestif, + git-unix, + kicadsch, + lwt, + lwt_ppx, + sha, + tyxml, + coreutils, + imagemagick, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/poll/default.nix b/pkgs/development/ocaml-modules/poll/default.nix index ea1e2e1c13d799..0f0e616da1bafb 100644 --- a/pkgs/development/ocaml-modules/poll/default.nix +++ b/pkgs/development/ocaml-modules/poll/default.nix @@ -1,10 +1,11 @@ -{ buildDunePackage -, dune-configurator -, fetchurl -, kqueue -, lib -, ppx_expect -, ppx_optcomp +{ + buildDunePackage, + dune-configurator, + fetchurl, + kqueue, + lib, + ppx_expect, + ppx_optcomp, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/polynomial/default.nix b/pkgs/development/ocaml-modules/polynomial/default.nix index 791aa7b7fabde9..e2f77205e70d30 100644 --- a/pkgs/development/ocaml-modules/polynomial/default.nix +++ b/pkgs/development/ocaml-modules/polynomial/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitLab -, buildDunePackage -, zarith -, ff-sig +{ + lib, + fetchFromGitLab, + buildDunePackage, + zarith, + ff-sig, }: buildDunePackage rec { @@ -17,7 +18,10 @@ buildDunePackage rec { hash = "sha256-is/PrYLCwStHiQsNq5OVRCwHdXjO2K2Z7FrXgytRfAU="; }; - propagatedBuildInputs = [ zarith ff-sig ]; + propagatedBuildInputs = [ + zarith + ff-sig + ]; doCheck = false; # circular dependencies diff --git a/pkgs/development/ocaml-modules/portaudio/default.nix b/pkgs/development/ocaml-modules/portaudio/default.nix index 9a6b450b5c4ed4..20879672792594 100644 --- a/pkgs/development/ocaml-modules/portaudio/default.nix +++ b/pkgs/development/ocaml-modules/portaudio/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, portaudio }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + portaudio, +}: buildDunePackage rec { pname = "portaudio"; diff --git a/pkgs/development/ocaml-modules/posix/base.nix b/pkgs/development/ocaml-modules/posix/base.nix index ab78d3737f9f33..449eb5736da247 100644 --- a/pkgs/development/ocaml-modules/posix/base.nix +++ b/pkgs/development/ocaml-modules/posix/base.nix @@ -1,5 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitHub -, ctypes, integers +{ + lib, + buildDunePackage, + fetchFromGitHub, + ctypes, + integers, }: buildDunePackage rec { @@ -16,7 +20,10 @@ buildDunePackage rec { duneVersion = "3"; minimalOCamlVersion = "4.08"; - propagatedBuildInputs = [ ctypes integers ]; + propagatedBuildInputs = [ + ctypes + integers + ]; meta = { homepage = "https://www.liquidsoap.info/ocaml-posix/"; diff --git a/pkgs/development/ocaml-modules/posix/time2.nix b/pkgs/development/ocaml-modules/posix/time2.nix index c82da776b8fccb..a2fc562496b1ef 100644 --- a/pkgs/development/ocaml-modules/posix/time2.nix +++ b/pkgs/development/ocaml-modules/posix/time2.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, posix-base, posix-types, unix-errno }: +{ + lib, + buildDunePackage, + posix-base, + posix-types, + unix-errno, +}: buildDunePackage { pname = "posix-time2"; @@ -7,7 +13,11 @@ buildDunePackage { duneVersion = "3"; - propagatedBuildInputs = [ posix-base posix-types unix-errno ]; + propagatedBuildInputs = [ + posix-base + posix-types + unix-errno + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/pp/default.nix b/pkgs/development/ocaml-modules/pp/default.nix index 5851c758cf31b8..2a23896b54d07c 100644 --- a/pkgs/development/ocaml-modules/pp/default.nix +++ b/pkgs/development/ocaml-modules/pp/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildDunePackage -, fetchurl -, ppx_expect -, version ? "2.0.0" +{ + lib, + buildDunePackage, + fetchurl, + ppx_expect, + version ? "2.0.0", }: buildDunePackage rec { @@ -10,12 +11,13 @@ buildDunePackage rec { inherit version; src = fetchurl { - url = - "https://github.com/ocaml-dune/pp/releases/download/${version}/pp-${version}.tbz"; - hash = { - "2.0.0" = "sha256-hlE1FRiwkrSi3vTggXHCdhUvkvtqhKixm2uSnM20RBk="; - "1.2.0" = "sha256-pegiVzxVr7Qtsp7FbqzR8qzY9lzy3yh44pHeN0zmkJw="; - }."${version}"; + url = "https://github.com/ocaml-dune/pp/releases/download/${version}/pp-${version}.tbz"; + hash = + { + "2.0.0" = "sha256-hlE1FRiwkrSi3vTggXHCdhUvkvtqhKixm2uSnM20RBk="; + "1.2.0" = "sha256-pegiVzxVr7Qtsp7FbqzR8qzY9lzy3yh44pHeN0zmkJw="; + } + ."${version}"; }; minimalOCamlVersion = "4.08"; @@ -24,8 +26,7 @@ buildDunePackage rec { doCheck = true; meta = with lib; { - description = - "A an alternative pretty printing library to the Format module of the OCaml standard library"; + description = "A an alternative pretty printing library to the Format module of the OCaml standard library"; license = licenses.mit; platforms = platforms.unix; maintainers = [ ]; diff --git a/pkgs/development/ocaml-modules/pp_loc/default.nix b/pkgs/development/ocaml-modules/pp_loc/default.nix index 147dd49f5d84a1..e6cd85d7cf89f5 100644 --- a/pkgs/development/ocaml-modules/pp_loc/default.nix +++ b/pkgs/development/ocaml-modules/pp_loc/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, buildDunePackage }: +{ + lib, + fetchurl, + buildDunePackage, +}: buildDunePackage rec { pname = "pp_loc"; diff --git a/pkgs/development/ocaml-modules/pprint/default.nix b/pkgs/development/ocaml-modules/pprint/default.nix index 2fcb4dbf1fe7a3..a542bf2e2ec1ba 100644 --- a/pkgs/development/ocaml-modules/pprint/default.nix +++ b/pkgs/development/ocaml-modules/pprint/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage }: +{ + lib, + fetchFromGitHub, + buildDunePackage, +}: buildDunePackage rec { pname = "pprint"; diff --git a/pkgs/development/ocaml-modules/ppx_bap/default.nix b/pkgs/development/ocaml-modules/ppx_bap/default.nix index 13f9d3471fef2a..7414253eef2e3f 100644 --- a/pkgs/development/ocaml-modules/ppx_bap/default.nix +++ b/pkgs/development/ocaml-modules/ppx_bap/default.nix @@ -1,15 +1,17 @@ -{ lib, buildDunePackage -, fetchFromGitHub -, ppx_assert -, ppx_bench -, ppx_bin_prot -, ppx_compare -, ppx_enumerate -, ppx_hash -, ppx_here -, ppx_optcomp -, ppx_sexp_conv -, ppx_sexp_value +{ + lib, + buildDunePackage, + fetchFromGitHub, + ppx_assert, + ppx_bench, + ppx_bin_prot, + ppx_compare, + ppx_enumerate, + ppx_hash, + ppx_here, + ppx_optcomp, + ppx_sexp_conv, + ppx_sexp_value, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ppx_blob/default.nix b/pkgs/development/ocaml-modules/ppx_blob/default.nix index 62ac0769d6eb7a..ec417f79e5aee6 100644 --- a/pkgs/development/ocaml-modules/ppx_blob/default.nix +++ b/pkgs/development/ocaml-modules/ppx_blob/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, buildDunePackage, ocaml, alcotest, ppxlib }: +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + alcotest, + ppxlib, +}: buildDunePackage rec { pname = "ppx_blob"; diff --git a/pkgs/development/ocaml-modules/ppx_cstubs/default.nix b/pkgs/development/ocaml-modules/ppx_cstubs/default.nix index 189efc3a675dd3..75bdee5783a8e3 100644 --- a/pkgs/development/ocaml-modules/ppx_cstubs/default.nix +++ b/pkgs/development/ocaml-modules/ppx_cstubs/default.nix @@ -1,57 +1,59 @@ -{ lib -, ocaml -, fetchFromGitHub -, buildDunePackage -, bigarray-compat -, containers -, cppo -, ctypes -, integers -, num -, ppxlib -, re -, findlib +{ + lib, + ocaml, + fetchFromGitHub, + buildDunePackage, + bigarray-compat, + containers, + cppo, + ctypes, + integers, + num, + ppxlib, + re, + findlib, }: lib.throwIf (lib.versionAtLeast ocaml.version "5.2") "ppx_cstubs is not available for OCaml ${ocaml.version}" -buildDunePackage rec { - pname = "ppx_cstubs"; - version = "0.7.0"; - - minimalOCamlVersion = "4.08"; - - src = fetchFromGitHub { - owner = "fdopen"; - repo = "ppx_cstubs"; - rev = version; - hash = "sha256-qMmwRWCIfNyhCQYPKLiufnb57sTR3P+WInOqtPDywFs="; - }; - - patches = [ ./ppxlib.patch ]; - - nativeBuildInputs = [ cppo ]; - - buildInputs = [ - bigarray-compat - containers - findlib - integers - num - ppxlib - re - ]; - - propagatedBuildInputs = [ - ctypes - ]; - - meta = with lib; { - homepage = "https://github.com/fdopen/ppx_cstubs"; - changelog = "https://github.com/fdopen/ppx_cstubs/raw/${version}/CHANGES.md"; - description = "Preprocessor for easier stub generation with ocaml-ctypes"; - license = licenses.lgpl21Plus; - maintainers = [ maintainers.osener ]; - }; -} + buildDunePackage + rec { + pname = "ppx_cstubs"; + version = "0.7.0"; + + minimalOCamlVersion = "4.08"; + + src = fetchFromGitHub { + owner = "fdopen"; + repo = "ppx_cstubs"; + rev = version; + hash = "sha256-qMmwRWCIfNyhCQYPKLiufnb57sTR3P+WInOqtPDywFs="; + }; + + patches = [ ./ppxlib.patch ]; + + nativeBuildInputs = [ cppo ]; + + buildInputs = [ + bigarray-compat + containers + findlib + integers + num + ppxlib + re + ]; + + propagatedBuildInputs = [ + ctypes + ]; + + meta = with lib; { + homepage = "https://github.com/fdopen/ppx_cstubs"; + changelog = "https://github.com/fdopen/ppx_cstubs/raw/${version}/CHANGES.md"; + description = "Preprocessor for easier stub generation with ocaml-ctypes"; + license = licenses.lgpl21Plus; + maintainers = [ maintainers.osener ]; + }; + } diff --git a/pkgs/development/ocaml-modules/ppx_derivers/default.nix b/pkgs/development/ocaml-modules/ppx_derivers/default.nix index ebf19c70ff30ee..e1208fe330e348 100644 --- a/pkgs/development/ocaml-modules/ppx_derivers/default.nix +++ b/pkgs/development/ocaml-modules/ppx_derivers/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage }: +{ + lib, + fetchFromGitHub, + buildDunePackage, +}: buildDunePackage rec { pname = "ppx_derivers"; diff --git a/pkgs/development/ocaml-modules/ppx_deriving/default.nix b/pkgs/development/ocaml-modules/ppx_deriving/default.nix index c38f79a071f72f..f1b1828afa9813 100644 --- a/pkgs/development/ocaml-modules/ppx_deriving/default.nix +++ b/pkgs/development/ocaml-modules/ppx_deriving/default.nix @@ -1,28 +1,37 @@ -{ lib -, fetchurl -, buildDunePackage -, ocaml -, findlib -, cppo -, ppxlib -, ppx_derivers -, result -, ounit -, ounit2 -, ocaml-migrate-parsetree -, version ? - if lib.versionAtLeast ppxlib.version "0.32" then "6.0.3" - else if lib.versionAtLeast ppxlib.version "0.20" then "5.2.1" - else if lib.versionAtLeast ppxlib.version "0.15" then "5.1" - else "5.0" +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + findlib, + cppo, + ppxlib, + ppx_derivers, + result, + ounit, + ounit2, + ocaml-migrate-parsetree, + version ? + if lib.versionAtLeast ppxlib.version "0.32" then + "6.0.3" + else if lib.versionAtLeast ppxlib.version "0.20" then + "5.2.1" + else if lib.versionAtLeast ppxlib.version "0.15" then + "5.1" + else + "5.0", }: -let hash = { - "6.0.3" = "sha256-N0qpezLF4BwJqXgQpIv6IYwhO1tknkRSEBRVrBnJSm0="; - "5.2.1" = "sha256:11h75dsbv3rs03pl67hdd3lbim7wjzh257ij9c75fcknbfr5ysz9"; - "5.1" = "sha256:1i64fd7qrfzbam5hfbl01r0sx4iihsahcwqj13smmrjlnwi3nkxh"; - "5.0" = "sha256:0fkzrn4pdyvf1kl0nwvhqidq01pnq3ql8zk1jd56hb0cxaw851w3"; -}."${version}"; in +let + hash = + { + "6.0.3" = "sha256-N0qpezLF4BwJqXgQpIv6IYwhO1tknkRSEBRVrBnJSm0="; + "5.2.1" = "sha256:11h75dsbv3rs03pl67hdd3lbim7wjzh257ij9c75fcknbfr5ysz9"; + "5.1" = "sha256:1i64fd7qrfzbam5hfbl01r0sx4iihsahcwqj13smmrjlnwi3nkxh"; + "5.0" = "sha256:0fkzrn4pdyvf1kl0nwvhqidq01pnq3ql8zk1jd56hb0cxaw851w3"; + } + ."${version}"; +in buildDunePackage rec { pname = "ppx_deriving"; @@ -36,12 +45,16 @@ buildDunePackage rec { strictDeps = true; nativeBuildInputs = [ cppo ]; - buildInputs = [ findlib ppxlib ]; + buildInputs = [ + findlib + ppxlib + ]; propagatedBuildInputs = - lib.optional (lib.versionOlder version "5.2") ocaml-migrate-parsetree ++ [ - ppx_derivers - ] ++ lib.optional (lib.versionOlder version "6.0") result - ; + lib.optional (lib.versionOlder version "5.2") ocaml-migrate-parsetree + ++ [ + ppx_derivers + ] + ++ lib.optional (lib.versionOlder version "6.0") result; doCheck = lib.versionAtLeast ocaml.version "4.08"; checkInputs = [ diff --git a/pkgs/development/ocaml-modules/ppx_deriving_cmdliner/default.nix b/pkgs/development/ocaml-modules/ppx_deriving_cmdliner/default.nix index d956856327f01e..d289734a9a1c0e 100644 --- a/pkgs/development/ocaml-modules/ppx_deriving_cmdliner/default.nix +++ b/pkgs/development/ocaml-modules/ppx_deriving_cmdliner/default.nix @@ -1,13 +1,14 @@ -{ lib -, buildDunePackage -, fetchFromGitHub -, fetchpatch -, alcotest -, cmdliner -, ppx_deriving -, ppxlib -, result -, gitUpdater +{ + lib, + buildDunePackage, + fetchFromGitHub, + fetchpatch, + alcotest, + cmdliner, + ppx_deriving, + ppxlib, + result, + gitUpdater, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ppx_deriving_protobuf/default.nix b/pkgs/development/ocaml-modules/ppx_deriving_protobuf/default.nix index 00f2ee0f8317df..22c859f364b1c7 100644 --- a/pkgs/development/ocaml-modules/ppx_deriving_protobuf/default.nix +++ b/pkgs/development/ocaml-modules/ppx_deriving_protobuf/default.nix @@ -1,5 +1,11 @@ -{ lib, fetchurl, buildDunePackage, cppo, ppx_deriving -, ppxlib, dune-configurator +{ + lib, + fetchurl, + buildDunePackage, + cppo, + ppx_deriving, + ppxlib, + dune-configurator, }: buildDunePackage rec { @@ -14,7 +20,10 @@ buildDunePackage rec { }; nativeBuildInputs = [ cppo ]; - buildInputs = [ ppxlib dune-configurator ]; + buildInputs = [ + ppxlib + dune-configurator + ]; propagatedBuildInputs = [ ppx_deriving ]; meta = with lib; { diff --git a/pkgs/development/ocaml-modules/ppx_deriving_rpc/default.nix b/pkgs/development/ocaml-modules/ppx_deriving_rpc/default.nix index acc36f2b01acaa..26d2cc66e37a11 100644 --- a/pkgs/development/ocaml-modules/ppx_deriving_rpc/default.nix +++ b/pkgs/development/ocaml-modules/ppx_deriving_rpc/default.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, rpclib, alcotest, ppxlib, ppx_deriving, yojson }: +{ + lib, + buildDunePackage, + rpclib, + alcotest, + ppxlib, + ppx_deriving, + yojson, +}: buildDunePackage rec { pname = "ppx_deriving_rpc"; @@ -8,9 +16,16 @@ buildDunePackage rec { minimalOCamlVersion = "4.08"; duneVersion = "3"; - propagatedBuildInputs = [ ppxlib rpclib ppx_deriving ]; + propagatedBuildInputs = [ + ppxlib + rpclib + ppx_deriving + ]; - checkInputs = [ alcotest yojson ]; + checkInputs = [ + alcotest + yojson + ]; doCheck = true; meta = with lib; { diff --git a/pkgs/development/ocaml-modules/ppx_deriving_yaml/default.nix b/pkgs/development/ocaml-modules/ppx_deriving_yaml/default.nix index 18308734b164a9..c33ad55e9b19e6 100644 --- a/pkgs/development/ocaml-modules/ppx_deriving_yaml/default.nix +++ b/pkgs/development/ocaml-modules/ppx_deriving_yaml/default.nix @@ -1,5 +1,12 @@ -{ lib, buildDunePackage, fetchurl, ppxlib, alcotest, mdx -, ppx_deriving, yaml +{ + lib, + buildDunePackage, + fetchurl, + ppxlib, + alcotest, + mdx, + ppx_deriving, + yaml, }: buildDunePackage rec { @@ -13,7 +20,11 @@ buildDunePackage rec { hash = "sha256-HLY0ozmy6zY0KjXkwP3drTdz857PvLS/buN1nB+xf1s="; }; - propagatedBuildInputs = [ ppxlib ppx_deriving yaml ]; + propagatedBuildInputs = [ + ppxlib + ppx_deriving + yaml + ]; doCheck = true; checkInputs = [ alcotest ]; diff --git a/pkgs/development/ocaml-modules/ppx_deriving_yojson/default.nix b/pkgs/development/ocaml-modules/ppx_deriving_yojson/default.nix index edccd29a0ab115..a509985cdec25f 100644 --- a/pkgs/development/ocaml-modules/ppx_deriving_yojson/default.nix +++ b/pkgs/development/ocaml-modules/ppx_deriving_yojson/default.nix @@ -1,19 +1,32 @@ -{ lib, buildDunePackage, fetchFromGitHub, ocaml, ppxlib, ounit, ounit2 -, ppx_deriving, result, yojson +{ + lib, + buildDunePackage, + fetchFromGitHub, + ocaml, + ppxlib, + ounit, + ounit2, + ppx_deriving, + result, + yojson, }: -let param = - if lib.versionAtLeast ppxlib.version "0.30" then { - version = "3.9.0"; - sha256 = "sha256-0d6YcBkeFoHXffCYjLIIvruw8B9ZB6NbUijhTv9uyN8="; - checkInputs = [ ounit2 ]; - } else { - version = "3.6.1"; - sha256 = "1icz5h6p3pfj7my5gi7wxpflrb8c902dqa17f9w424njilnpyrbk"; - checkInputs = [ ounit ]; - propagatedBuildInputs = [ result ]; - } -; in +let + param = + if lib.versionAtLeast ppxlib.version "0.30" then + { + version = "3.9.0"; + sha256 = "sha256-0d6YcBkeFoHXffCYjLIIvruw8B9ZB6NbUijhTv9uyN8="; + checkInputs = [ ounit2 ]; + } + else + { + version = "3.6.1"; + sha256 = "1icz5h6p3pfj7my5gi7wxpflrb8c902dqa17f9w424njilnpyrbk"; + checkInputs = [ ounit ]; + propagatedBuildInputs = [ result ]; + }; +in buildDunePackage rec { pname = "ppx_deriving_yojson"; @@ -28,8 +41,11 @@ buildDunePackage rec { inherit (param) sha256; }; - propagatedBuildInputs = [ ppxlib ppx_deriving yojson ] - ++ param.propagatedBuildInputs or []; + propagatedBuildInputs = [ + ppxlib + ppx_deriving + yojson + ] ++ param.propagatedBuildInputs or [ ]; doCheck = lib.versionAtLeast ocaml.version "4.08"; inherit (param) checkInputs; diff --git a/pkgs/development/ocaml-modules/ppx_gen_rec/default.nix b/pkgs/development/ocaml-modules/ppx_gen_rec/default.nix index ea2ea5be9db5f4..8f92df791b449b 100644 --- a/pkgs/development/ocaml-modules/ppx_gen_rec/default.nix +++ b/pkgs/development/ocaml-modules/ppx_gen_rec/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, buildDunePackage, ppxlib }: +{ + lib, + fetchurl, + buildDunePackage, + ppxlib, +}: buildDunePackage rec { pname = "ppx_gen_rec"; diff --git a/pkgs/development/ocaml-modules/ppx_import/default.nix b/pkgs/development/ocaml-modules/ppx_import/default.nix index 7b74fb8a49a5a6..349bb527b3da54 100644 --- a/pkgs/development/ocaml-modules/ppx_import/default.nix +++ b/pkgs/development/ocaml-modules/ppx_import/default.nix @@ -1,48 +1,55 @@ -{ lib -, fetchurl -, buildDunePackage -, ocaml -, ounit -, ppx_deriving -, ppx_sexp_conv -, ppxlib -, version ? if lib.versionAtLeast ocaml.version "4.11" then "1.11.0" else "1.9.1" +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + ounit, + ppx_deriving, + ppx_sexp_conv, + ppxlib, + version ? if lib.versionAtLeast ocaml.version "4.11" then "1.11.0" else "1.9.1", }: lib.throwIfNot (lib.versionAtLeast ppxlib.version "0.24.0") "ppx_import is not available with ppxlib-${ppxlib.version}" -buildDunePackage rec { - pname = "ppx_import"; - inherit version; - - minimalOCamlVersion = "4.05"; - - src = fetchurl { - url = let dir = if lib.versionAtLeast version "1.11" then "v${version}" else "${version}"; in - "https://github.com/ocaml-ppx/ppx_import/releases/download/${dir}/ppx_import-${version}.tbz"; - - hash = { - "1.9.1" = "sha256-0bSY4u44Ds84XPIbcT5Vt4AG/4PkzFKMl9CDGFZyIdI="; - "1.11.0" = "sha256-Jmfv1IkQoaTkyxoxp9FI0ChNESqCaoDsA7D4ZUbOrBo="; - }."${version}"; - }; - - propagatedBuildInputs = [ - ppxlib - ]; - - checkInputs = [ - ounit - ppx_deriving - ppx_sexp_conv - ]; - - doCheck = true; - - meta = { - description = "Syntax extension for importing declarations from interface files"; - license = lib.licenses.mit; - homepage = "https://github.com/ocaml-ppx/ppx_import"; - }; -} + buildDunePackage + rec { + pname = "ppx_import"; + inherit version; + + minimalOCamlVersion = "4.05"; + + src = fetchurl { + url = + let + dir = if lib.versionAtLeast version "1.11" then "v${version}" else "${version}"; + in + "https://github.com/ocaml-ppx/ppx_import/releases/download/${dir}/ppx_import-${version}.tbz"; + + hash = + { + "1.9.1" = "sha256-0bSY4u44Ds84XPIbcT5Vt4AG/4PkzFKMl9CDGFZyIdI="; + "1.11.0" = "sha256-Jmfv1IkQoaTkyxoxp9FI0ChNESqCaoDsA7D4ZUbOrBo="; + } + ."${version}"; + }; + + propagatedBuildInputs = [ + ppxlib + ]; + + checkInputs = [ + ounit + ppx_deriving + ppx_sexp_conv + ]; + + doCheck = true; + + meta = { + description = "Syntax extension for importing declarations from interface files"; + license = lib.licenses.mit; + homepage = "https://github.com/ocaml-ppx/ppx_import"; + }; + } diff --git a/pkgs/development/ocaml-modules/ppx_monad/default.nix b/pkgs/development/ocaml-modules/ppx_monad/default.nix index d17de7a1033c91..cb45f523379094 100644 --- a/pkgs/development/ocaml-modules/ppx_monad/default.nix +++ b/pkgs/development/ocaml-modules/ppx_monad/default.nix @@ -1,5 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage -, ppxlib +{ + lib, + fetchFromGitHub, + buildDunePackage, + ppxlib, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ppx_show/default.nix b/pkgs/development/ocaml-modules/ppx_show/default.nix index 6d33e0f0c163ce..8874f2f4253a55 100644 --- a/pkgs/development/ocaml-modules/ppx_show/default.nix +++ b/pkgs/development/ocaml-modules/ppx_show/default.nix @@ -1,5 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitHub -, stdcompat, ppxlib +{ + lib, + buildDunePackage, + fetchFromGitHub, + stdcompat, + ppxlib, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ppx_tools/default.nix b/pkgs/development/ocaml-modules/ppx_tools/default.nix index 41db9313fe7fe5..21d6f116b9e70d 100644 --- a/pkgs/development/ocaml-modules/ppx_tools/default.nix +++ b/pkgs/development/ocaml-modules/ppx_tools/default.nix @@ -1,49 +1,68 @@ -{ lib, stdenv, fetchFromGitHub, buildDunePackage, ocaml, findlib, cppo }: +{ + lib, + stdenv, + fetchFromGitHub, + buildDunePackage, + ocaml, + findlib, + cppo, +}: -if lib.versionAtLeast ocaml.version "5.2" -then throw "ppx_tools is not available for OCaml ${ocaml.version}" +if lib.versionAtLeast ocaml.version "5.2" then + throw "ppx_tools is not available for OCaml ${ocaml.version}" else -let param = - let v6_6 = { - version = "6.6"; - sha256 = "sha256-QhuaQ9346a3neoRM4GrOVzjR8fg9ysMZR1VzNgyIQtc="; - nativeBuildInputs = [cppo]; - buildInputs = [cppo]; - }; in -{ - "4.02" = { - version = "5.0+4.02.0"; - sha256 = "16drjk0qafjls8blng69qiv35a84wlafpk16grrg2i3x19p8dlj8"; }; - "4.03" = { - version = "5.0+4.03.0"; - sha256 = "061v1fl5z7z3ywi4ppryrlcywnvnqbsw83ppq72qmkc7ma4603jg"; }; - "4.04" = { - version = "unstable-20161114"; - rev = "49c08e2e4ea8fef88692cd1dcc1b38a9133f17ac"; - sha256 = "0ywzfkf5brj33nwh49k9if8x8v433ral25f3nbklfc9vqr06zrfl"; }; - "4.05" = { - version = "5.0+4.05.0"; - sha256 = "1jvvhk6wnkvm7b9zph309ihsc0hyxfpahmxxrq19vx8c674jsdm4"; }; - "4.06" = { - version = "5.1+4.06.0"; - sha256 = "1ww4cspdpgjjsgiv71s0im5yjkr3544x96wsq1vpdacq7dr7zwiw"; }; - "4.07" = { - version = "5.1+4.06.0"; - sha256 = "1ww4cspdpgjjsgiv71s0im5yjkr3544x96wsq1vpdacq7dr7zwiw"; }; - "4.08" = v6_6; - "4.09" = v6_6; - "4.10" = v6_6; - "4.11" = v6_6; - "4.12" = v6_6; - "4.13" = v6_6; - "4.14" = v6_6; - "5.0" = v6_6; - "5.1" = v6_6; -}.${ocaml.meta.branch}; -in + let + param = + let + v6_6 = { + version = "6.6"; + sha256 = "sha256-QhuaQ9346a3neoRM4GrOVzjR8fg9ysMZR1VzNgyIQtc="; + nativeBuildInputs = [ cppo ]; + buildInputs = [ cppo ]; + }; + in + { + "4.02" = { + version = "5.0+4.02.0"; + sha256 = "16drjk0qafjls8blng69qiv35a84wlafpk16grrg2i3x19p8dlj8"; + }; + "4.03" = { + version = "5.0+4.03.0"; + sha256 = "061v1fl5z7z3ywi4ppryrlcywnvnqbsw83ppq72qmkc7ma4603jg"; + }; + "4.04" = { + version = "unstable-20161114"; + rev = "49c08e2e4ea8fef88692cd1dcc1b38a9133f17ac"; + sha256 = "0ywzfkf5brj33nwh49k9if8x8v433ral25f3nbklfc9vqr06zrfl"; + }; + "4.05" = { + version = "5.0+4.05.0"; + sha256 = "1jvvhk6wnkvm7b9zph309ihsc0hyxfpahmxxrq19vx8c674jsdm4"; + }; + "4.06" = { + version = "5.1+4.06.0"; + sha256 = "1ww4cspdpgjjsgiv71s0im5yjkr3544x96wsq1vpdacq7dr7zwiw"; + }; + "4.07" = { + version = "5.1+4.06.0"; + sha256 = "1ww4cspdpgjjsgiv71s0im5yjkr3544x96wsq1vpdacq7dr7zwiw"; + }; + "4.08" = v6_6; + "4.09" = v6_6; + "4.10" = v6_6; + "4.11" = v6_6; + "4.12" = v6_6; + "4.13" = v6_6; + "4.14" = v6_6; + "5.0" = v6_6; + "5.1" = v6_6; + } + .${ocaml.meta.branch}; + in -let src = fetchFromGitHub { + let + src = fetchFromGitHub { owner = "alainfrisch"; repo = pname; rev = param.rev or param.version; @@ -56,26 +75,30 @@ let src = fetchFromGitHub { license = licenses.mit; maintainers = with maintainers; [ vbgl ]; }; -in -if lib.versionAtLeast param.version "6.0" -then - buildDunePackage { - inherit pname src meta; - inherit (param) version buildInputs nativeBuildInputs; - } -else - stdenv.mkDerivation { - name = "ocaml${ocaml.version}-${pname}-${param.version}"; + in + if lib.versionAtLeast param.version "6.0" then + buildDunePackage { + inherit pname src meta; + inherit (param) version buildInputs nativeBuildInputs; + } + else + stdenv.mkDerivation { + name = "ocaml${ocaml.version}-${pname}-${param.version}"; - inherit src; + inherit src; - nativeBuildInputs = [ ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; - strictDeps = true; + strictDeps = true; - createFindlibDestdir = true; + createFindlibDestdir = true; - dontStrip = true; + dontStrip = true; - meta = meta // { inherit (ocaml.meta) platforms; }; - } + meta = meta // { + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/ppx_tools_versioned/default.nix b/pkgs/development/ocaml-modules/ppx_tools_versioned/default.nix index 78915135a0c719..3a887bdd5aebde 100644 --- a/pkgs/development/ocaml-modules/ppx_tools_versioned/default.nix +++ b/pkgs/development/ocaml-modules/ppx_tools_versioned/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, ocaml-migrate-parsetree }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + ocaml-migrate-parsetree, +}: buildDunePackage rec { pname = "ppx_tools_versioned"; diff --git a/pkgs/development/ocaml-modules/ppx_yojson_conv_lib/default.nix b/pkgs/development/ocaml-modules/ppx_yojson_conv_lib/default.nix index 49d02693843c05..22fe2ef279f2eb 100644 --- a/pkgs/development/ocaml-modules/ppx_yojson_conv_lib/default.nix +++ b/pkgs/development/ocaml-modules/ppx_yojson_conv_lib/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitHub, yojson }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + yojson, +}: buildDunePackage rec { pname = "ppx_yojson_conv_lib"; diff --git a/pkgs/development/ocaml-modules/ppxlib/default.nix b/pkgs/development/ocaml-modules/ppxlib/default.nix index b64a5301fc32e9..3f8ebe6da9489c 100644 --- a/pkgs/development/ocaml-modules/ppxlib/default.nix +++ b/pkgs/development/ocaml-modules/ppxlib/default.nix @@ -1,104 +1,124 @@ -{ lib, fetchurl, buildDunePackage, ocaml -, version ? - if lib.versionAtLeast ocaml.version "4.07" - then if lib.versionAtLeast ocaml.version "4.08" - then if lib.versionAtLeast ocaml.version "4.11" - then "0.33.0" else "0.24.0" else "0.15.0" else "0.13.0" -, ocaml-compiler-libs, ocaml-migrate-parsetree, ppx_derivers, stdio -, stdlib-shims, ocaml-migrate-parsetree-2 +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + version ? + if lib.versionAtLeast ocaml.version "4.07" then + if lib.versionAtLeast ocaml.version "4.08" then + if lib.versionAtLeast ocaml.version "4.11" then "0.33.0" else "0.24.0" + else + "0.15.0" + else + "0.13.0", + ocaml-compiler-libs, + ocaml-migrate-parsetree, + ppx_derivers, + stdio, + stdlib-shims, + ocaml-migrate-parsetree-2, }: -let param = { - "0.8.1" = { - sha256 = "sha256-pct57oO7qAMEtlvEfymFOCvviWaLG0b5/7NzTC8vdSE="; - max_version = "4.10"; - OMP = [ ocaml-migrate-parsetree ]; - }; - "0.13.0" = { - sha256 = "sha256-geHz0whQDg5/YQjVsN2iuHlkClwh7z3Eqb2QOBzuOdk="; - min_version = "4.07"; - max_version = "4.11"; - OMP = [ ocaml-migrate-parsetree ]; - }; - "0.15.0" = { - sha256 = "sha256-C2MNf410qJmlXMJxiLXOA+c1qT8H6gwt5WUy2P2TszA="; - min_version = "4.07"; - max_version = "4.12"; - OMP = [ ocaml-migrate-parsetree ]; - }; - "0.18.0" = { - sha256 = "sha256-nUg8NkZ64GHHDfcWbtFGXq3MNEKu+nYPtcVDm/gEfcM="; - min_version = "4.07"; - max_version = "4.12"; - OMP = [ ocaml-migrate-parsetree-2 ]; - }; - "0.22.0" = { - sha256 = "sha256-PuuR4DlmZiKEoyIuYS3uf0+it2N8U9lXLSp0E0u5bXo="; - min_version = "4.07"; - max_version = "4.13"; - OMP = [ ocaml-migrate-parsetree-2 ]; - }; - "0.22.2" = { - sha256 = "sha256-0Oih69xiILFXTXqSbwCEYMURjM73m/mgzgJC80z/Ilo="; - min_version = "4.07"; - max_version = "4.14"; - OMP = [ ocaml-migrate-parsetree-2 ]; - }; - "0.23.0" = { - sha256 = "sha256-G1g2wYa51aFqz0falPOWj08ItRm3cpzYao/TmXH+EuU="; - min_version = "4.07"; - max_version = "4.14"; - }; - "0.24.0" = { - sha256 = "sha256-d2YCfC7ND1s7Rg6SEqcHCcZ0QngRPrkfMXxWxB56kMg="; - min_version = "4.07"; - max_version = "5.1"; - }; - "0.28.0" = { - sha256 = "sha256-2Hrl+aCBIGMIypZICbUKZq646D0lSAHouWdUSLYM83c="; - min_version = "4.07"; - max_version = "5.1"; - }; - "0.30.0" = { - sha256 = "sha256-3UpjvenSm0mBDgTXZTk3yTLxd6lByg4ZgratU6xEIRA="; - min_version = "4.07"; - }; - "0.32.1" = { - sha256 = "sha256-nbrYvLHItPPfP1i8pgpe0j2GUx8No0tBlshr1YXAnX8="; - min_version = "4.07"; - }; - "0.33.0" = { - sha256 = "sha256-/6RO9VHyO3XiHb1pijAxBDE4Gq8UC5/kuBwucKLSxjo="; - min_version = "4.07"; - }; -}."${version}"; in +let + param = + { + "0.8.1" = { + sha256 = "sha256-pct57oO7qAMEtlvEfymFOCvviWaLG0b5/7NzTC8vdSE="; + max_version = "4.10"; + OMP = [ ocaml-migrate-parsetree ]; + }; + "0.13.0" = { + sha256 = "sha256-geHz0whQDg5/YQjVsN2iuHlkClwh7z3Eqb2QOBzuOdk="; + min_version = "4.07"; + max_version = "4.11"; + OMP = [ ocaml-migrate-parsetree ]; + }; + "0.15.0" = { + sha256 = "sha256-C2MNf410qJmlXMJxiLXOA+c1qT8H6gwt5WUy2P2TszA="; + min_version = "4.07"; + max_version = "4.12"; + OMP = [ ocaml-migrate-parsetree ]; + }; + "0.18.0" = { + sha256 = "sha256-nUg8NkZ64GHHDfcWbtFGXq3MNEKu+nYPtcVDm/gEfcM="; + min_version = "4.07"; + max_version = "4.12"; + OMP = [ ocaml-migrate-parsetree-2 ]; + }; + "0.22.0" = { + sha256 = "sha256-PuuR4DlmZiKEoyIuYS3uf0+it2N8U9lXLSp0E0u5bXo="; + min_version = "4.07"; + max_version = "4.13"; + OMP = [ ocaml-migrate-parsetree-2 ]; + }; + "0.22.2" = { + sha256 = "sha256-0Oih69xiILFXTXqSbwCEYMURjM73m/mgzgJC80z/Ilo="; + min_version = "4.07"; + max_version = "4.14"; + OMP = [ ocaml-migrate-parsetree-2 ]; + }; + "0.23.0" = { + sha256 = "sha256-G1g2wYa51aFqz0falPOWj08ItRm3cpzYao/TmXH+EuU="; + min_version = "4.07"; + max_version = "4.14"; + }; + "0.24.0" = { + sha256 = "sha256-d2YCfC7ND1s7Rg6SEqcHCcZ0QngRPrkfMXxWxB56kMg="; + min_version = "4.07"; + max_version = "5.1"; + }; + "0.28.0" = { + sha256 = "sha256-2Hrl+aCBIGMIypZICbUKZq646D0lSAHouWdUSLYM83c="; + min_version = "4.07"; + max_version = "5.1"; + }; + "0.30.0" = { + sha256 = "sha256-3UpjvenSm0mBDgTXZTk3yTLxd6lByg4ZgratU6xEIRA="; + min_version = "4.07"; + }; + "0.32.1" = { + sha256 = "sha256-nbrYvLHItPPfP1i8pgpe0j2GUx8No0tBlshr1YXAnX8="; + min_version = "4.07"; + }; + "0.33.0" = { + sha256 = "sha256-/6RO9VHyO3XiHb1pijAxBDE4Gq8UC5/kuBwucKLSxjo="; + min_version = "4.07"; + }; + } + ."${version}"; +in -if param ? max_version && lib.versionAtLeast ocaml.version param.max_version -|| param ? min_version && lib.versionOlder ocaml.version param.min_version -then throw "ppxlib-${version} is not available for OCaml ${ocaml.version}" +if + param ? max_version && lib.versionAtLeast ocaml.version param.max_version + || param ? min_version && lib.versionOlder ocaml.version param.min_version +then + throw "ppxlib-${version} is not available for OCaml ${ocaml.version}" else -buildDunePackage rec { - pname = "ppxlib"; - inherit version; + buildDunePackage rec { + pname = "ppxlib"; + inherit version; - src = fetchurl { - url = "https://github.com/ocaml-ppx/ppxlib/releases/download/${version}/ppxlib-${version}.tbz"; - inherit (param) sha256; - }; + src = fetchurl { + url = "https://github.com/ocaml-ppx/ppxlib/releases/download/${version}/ppxlib-${version}.tbz"; + inherit (param) sha256; + }; - propagatedBuildInputs = [ - ocaml-compiler-libs - ] ++ (param.OMP or []) ++ [ - ppx_derivers - stdio - stdlib-shims - ]; + propagatedBuildInputs = + [ + ocaml-compiler-libs + ] + ++ (param.OMP or [ ]) + ++ [ + ppx_derivers + stdio + stdlib-shims + ]; - meta = { - description = "Comprehensive ppx tool set"; - license = lib.licenses.mit; - maintainers = [ lib.maintainers.vbgl ]; - homepage = "https://github.com/ocaml-ppx/ppxlib"; - }; -} + meta = { + description = "Comprehensive ppx tool set"; + license = lib.licenses.mit; + maintainers = [ lib.maintainers.vbgl ]; + homepage = "https://github.com/ocaml-ppx/ppxlib"; + }; + } diff --git a/pkgs/development/ocaml-modules/pratter/default.nix b/pkgs/development/ocaml-modules/pratter/default.nix index efd2fc6639c282..dcaead619d9816 100644 --- a/pkgs/development/ocaml-modules/pratter/default.nix +++ b/pkgs/development/ocaml-modules/pratter/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, camlp-streams -, alcotest -, qcheck -, qcheck-alcotest +{ + lib, + fetchFromGitHub, + buildDunePackage, + camlp-streams, + alcotest, + qcheck, + qcheck-alcotest, }: buildDunePackage rec { @@ -23,7 +24,11 @@ buildDunePackage rec { propagatedBuildInputs = [ camlp-streams ]; - checkInputs = [ alcotest qcheck qcheck-alcotest ]; + checkInputs = [ + alcotest + qcheck + qcheck-alcotest + ]; doCheck = true; meta = with lib; { diff --git a/pkgs/development/ocaml-modules/prettym/default.nix b/pkgs/development/ocaml-modules/prettym/default.nix index 8d6a855fe74fc1..a5e93870ff98df 100644 --- a/pkgs/development/ocaml-modules/prettym/default.nix +++ b/pkgs/development/ocaml-modules/prettym/default.nix @@ -1,14 +1,15 @@ -{ alcotest -, base64 -, bigarray-overlap -, bigstringaf -, buildDunePackage -, fetchurl -, fmt -, jsonm -, ke -, lib -, ptime +{ + alcotest, + base64, + bigarray-overlap, + bigstringaf, + buildDunePackage, + fetchurl, + fmt, + jsonm, + ke, + lib, + ptime, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/printbox/default.nix b/pkgs/development/ocaml-modules/printbox/default.nix index ea99dfcd81def9..d3e7673a5c27d2 100644 --- a/pkgs/development/ocaml-modules/printbox/default.nix +++ b/pkgs/development/ocaml-modules/printbox/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, buildDunePackage, ocaml, mdx, gitUpdater }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + ocaml, + mdx, + gitUpdater, +}: buildDunePackage rec { pname = "printbox"; diff --git a/pkgs/development/ocaml-modules/printbox/text.nix b/pkgs/development/ocaml-modules/printbox/text.nix index dd823b2264c8d1..a3f1596905a426 100644 --- a/pkgs/development/ocaml-modules/printbox/text.nix +++ b/pkgs/development/ocaml-modules/printbox/text.nix @@ -1,10 +1,22 @@ -{ buildDunePackage, lib, ocaml, printbox, uucp, uutf, mdx }: +{ + buildDunePackage, + lib, + ocaml, + printbox, + uucp, + uutf, + mdx, +}: buildDunePackage { pname = "printbox-text"; inherit (printbox) src version; - propagatedBuildInputs = [ printbox uucp uutf ]; + propagatedBuildInputs = [ + printbox + uucp + uutf + ]; doCheck = printbox.doCheck && lib.versionOlder ocaml.version "5.0"; nativeCheckInputs = [ mdx.bin ]; diff --git a/pkgs/development/ocaml-modules/process/default.nix b/pkgs/development/ocaml-modules/process/default.nix index 89faf40c3be570..ad1c2d96b6c08f 100644 --- a/pkgs/development/ocaml-modules/process/default.nix +++ b/pkgs/development/ocaml-modules/process/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, ocaml, findlib, ocamlbuild }: +{ + stdenv, + lib, + fetchFromGitHub, + ocaml, + findlib, + ocamlbuild, +}: stdenv.mkDerivation rec { pname = "ocaml${ocaml.version}-process"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "0m1ldah5r9gcq09d9jh8lhvr77910dygx5m309k1jm60ah9mdcab"; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ]; strictDeps = true; createFindlibDestdir = true; diff --git a/pkgs/development/ocaml-modules/progress/default.nix b/pkgs/development/ocaml-modules/progress/default.nix index 7ca95a0882434d..d5ca6eee3860c2 100644 --- a/pkgs/development/ocaml-modules/progress/default.nix +++ b/pkgs/development/ocaml-modules/progress/default.nix @@ -1,6 +1,14 @@ -{ lib, buildDunePackage -, fmt, logs, mtime, optint, terminal, vector -, alcotest, astring +{ + lib, + buildDunePackage, + fmt, + logs, + mtime, + optint, + terminal, + vector, + alcotest, + astring, }: buildDunePackage rec { @@ -10,10 +18,20 @@ buildDunePackage rec { inherit (terminal) version src; - propagatedBuildInputs = [ fmt logs mtime optint terminal vector ]; + propagatedBuildInputs = [ + fmt + logs + mtime + optint + terminal + vector + ]; doCheck = true; - checkInputs = [ alcotest astring ]; + checkInputs = [ + alcotest + astring + ]; meta = with lib; { description = "Progress bar library for OCaml"; diff --git a/pkgs/development/ocaml-modules/prometheus/default.nix b/pkgs/development/ocaml-modules/prometheus/default.nix index 2715c50b3eddd6..8590436398580f 100644 --- a/pkgs/development/ocaml-modules/prometheus/default.nix +++ b/pkgs/development/ocaml-modules/prometheus/default.nix @@ -1,4 +1,14 @@ -{ lib, fetchurl, buildDunePackage, astring, asetmap, fmt, re, lwt, alcotest }: +{ + lib, + fetchurl, + buildDunePackage, + astring, + asetmap, + fmt, + re, + lwt, + alcotest, +}: buildDunePackage rec { pname = "prometheus"; diff --git a/pkgs/development/ocaml-modules/promise_jsoo/default.nix b/pkgs/development/ocaml-modules/promise_jsoo/default.nix index 061f965e0e52ce..d380fa1adb9a2f 100644 --- a/pkgs/development/ocaml-modules/promise_jsoo/default.nix +++ b/pkgs/development/ocaml-modules/promise_jsoo/default.nix @@ -1,4 +1,13 @@ -{ lib, fetchurl, buildDunePackage, js_of_ocaml, ppxlib, js_of_ocaml-ppx, gen_js_api, ojs }: +{ + lib, + fetchurl, + buildDunePackage, + js_of_ocaml, + ppxlib, + js_of_ocaml-ppx, + gen_js_api, + ojs, +}: buildDunePackage rec { pname = "promise_jsoo"; diff --git a/pkgs/development/ocaml-modules/psmt2-frontend/default.nix b/pkgs/development/ocaml-modules/psmt2-frontend/default.nix index 6981726f6df729..74798bc3d6fe08 100644 --- a/pkgs/development/ocaml-modules/psmt2-frontend/default.nix +++ b/pkgs/development/ocaml-modules/psmt2-frontend/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, menhir }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + menhir, +}: buildDunePackage rec { version = "0.4.0"; diff --git a/pkgs/development/ocaml-modules/psq/default.nix b/pkgs/development/ocaml-modules/psq/default.nix index f1c8ab92af440c..e2349aed828a5b 100644 --- a/pkgs/development/ocaml-modules/psq/default.nix +++ b/pkgs/development/ocaml-modules/psq/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, ocaml, fetchurl, seq, qcheck-alcotest }: +{ + lib, + buildDunePackage, + ocaml, + fetchurl, + seq, + qcheck-alcotest, +}: buildDunePackage rec { minimalOCamlVersion = "4.03"; diff --git a/pkgs/development/ocaml-modules/ptime/default.nix b/pkgs/development/ocaml-modules/ptime/default.nix index 7110a66c8f609d..4624e22600a169 100644 --- a/pkgs/development/ocaml-modules/ptime/default.nix +++ b/pkgs/development/ocaml-modules/ptime/default.nix @@ -1,55 +1,57 @@ -{ stdenv -, lib -, fetchurl -, ocaml -, findlib -, ocamlbuild -, topkg +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, }: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.08") "ptime is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation (finalAttrs: { - version = "1.2.0"; - pname = "ocaml${ocaml.version}-ptime"; - - src = fetchurl { - url = "https://erratique.ch/software/ptime/releases/ptime-${finalAttrs.version}.tbz"; - hash = "sha256-lhZ0f99JDsNugCTKsn7gHjoK9XfYojImY4+kA03nOrA="; - }; - - nativeBuildInputs = [ - findlib - ocaml - ocamlbuild - topkg - ]; - - buildInputs = [ - topkg - ]; - - strictDeps = true; - - inherit (topkg) buildPhase installPhase; - - meta = { - description = "POSIX time for OCaml"; - homepage = "https://erratique.ch/software/ptime"; - license = lib.licenses.isc; - longDescription = '' - Ptime has platform independent POSIX time support in pure OCaml. - It provides a type to represent a well-defined range of POSIX timestamps - with picosecond precision, conversion with date-time values, conversion - with RFC 3339 timestamps and pretty printing to a human-readable, - locale-independent representation. - - The additional Ptime_clock library provides access to a system POSIX clock - and to the system's current time zone offset. - - Ptime is not a calendar library. - ''; - maintainers = with lib.maintainers; [ sternenseemann ]; - }; -}) + stdenv.mkDerivation + (finalAttrs: { + version = "1.2.0"; + pname = "ocaml${ocaml.version}-ptime"; + + src = fetchurl { + url = "https://erratique.ch/software/ptime/releases/ptime-${finalAttrs.version}.tbz"; + hash = "sha256-lhZ0f99JDsNugCTKsn7gHjoK9XfYojImY4+kA03nOrA="; + }; + + nativeBuildInputs = [ + findlib + ocaml + ocamlbuild + topkg + ]; + + buildInputs = [ + topkg + ]; + + strictDeps = true; + + inherit (topkg) buildPhase installPhase; + + meta = { + description = "POSIX time for OCaml"; + homepage = "https://erratique.ch/software/ptime"; + license = lib.licenses.isc; + longDescription = '' + Ptime has platform independent POSIX time support in pure OCaml. + It provides a type to represent a well-defined range of POSIX timestamps + with picosecond precision, conversion with date-time values, conversion + with RFC 3339 timestamps and pretty printing to a human-readable, + locale-independent representation. + + The additional Ptime_clock library provides access to a system POSIX clock + and to the system's current time zone offset. + + Ptime is not a calendar library. + ''; + maintainers = with lib.maintainers; [ sternenseemann ]; + }; + }) diff --git a/pkgs/development/ocaml-modules/ptmap/default.nix b/pkgs/development/ocaml-modules/ptmap/default.nix index 6fd6a7d8b9c24f..da24c5757f3628 100644 --- a/pkgs/development/ocaml-modules/ptmap/default.nix +++ b/pkgs/development/ocaml-modules/ptmap/default.nix @@ -1,6 +1,9 @@ -{ lib, buildDunePackage, fetchurl -, seq -, stdlib-shims +{ + lib, + buildDunePackage, + fetchurl, + seq, + stdlib-shims, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ptset/default.nix b/pkgs/development/ocaml-modules/ptset/default.nix index b9c534e763d0f8..bdf39ad27e3ec9 100644 --- a/pkgs/development/ocaml-modules/ptset/default.nix +++ b/pkgs/development/ocaml-modules/ptset/default.nix @@ -1,5 +1,8 @@ -{ lib, fetchurl, buildDunePackage -, stdlib-shims +{ + lib, + fetchurl, + buildDunePackage, + stdlib-shims, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/pulseaudio/default.nix b/pkgs/development/ocaml-modules/pulseaudio/default.nix index 75f5e0f414fb02..3afa4d4fee7f79 100644 --- a/pkgs/development/ocaml-modules/pulseaudio/default.nix +++ b/pkgs/development/ocaml-modules/pulseaudio/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, pkg-config, pulseaudio }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + pkg-config, + pulseaudio, +}: buildDunePackage rec { pname = "pulseaudio"; diff --git a/pkgs/development/ocaml-modules/pure-splitmix/default.nix b/pkgs/development/ocaml-modules/pure-splitmix/default.nix index 228f8ad8c488b1..8b929da7331c0d 100644 --- a/pkgs/development/ocaml-modules/pure-splitmix/default.nix +++ b/pkgs/development/ocaml-modules/pure-splitmix/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage }: +{ + lib, + fetchFromGitHub, + buildDunePackage, +}: buildDunePackage rec { pname = "pure-splitmix"; diff --git a/pkgs/development/ocaml-modules/pyml/default.nix b/pkgs/development/ocaml-modules/pyml/default.nix index d5840c8af53ddb..2d63152d9f6b35 100644 --- a/pkgs/development/ocaml-modules/pyml/default.nix +++ b/pkgs/development/ocaml-modules/pyml/default.nix @@ -1,9 +1,10 @@ -{ buildDunePackage -, lib -, fetchFromGitHub -, utop -, python3 -, stdcompat +{ + buildDunePackage, + lib, + fetchFromGitHub, + utop, + python3, + stdcompat, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/qcheck/alcotest.nix b/pkgs/development/ocaml-modules/qcheck/alcotest.nix index 113b61eea18056..9ddcdcc1d5e541 100644 --- a/pkgs/development/ocaml-modules/qcheck/alcotest.nix +++ b/pkgs/development/ocaml-modules/qcheck/alcotest.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, qcheck-core, alcotest }: +{ + buildDunePackage, + qcheck-core, + alcotest, +}: buildDunePackage { pname = "qcheck-alcotest"; @@ -7,7 +11,10 @@ buildDunePackage { duneVersion = "3"; - propagatedBuildInputs = [ qcheck-core alcotest ]; + propagatedBuildInputs = [ + qcheck-core + alcotest + ]; meta = qcheck-core.meta // { description = "Alcotest backend for qcheck"; diff --git a/pkgs/development/ocaml-modules/qcheck/core.nix b/pkgs/development/ocaml-modules/qcheck/core.nix index 9817bedafff18b..a2e5d8910dc1aa 100644 --- a/pkgs/development/ocaml-modules/qcheck/core.nix +++ b/pkgs/development/ocaml-modules/qcheck/core.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchFromGitHub }: +{ + lib, + buildDunePackage, + fetchFromGitHub, +}: buildDunePackage rec { pname = "qcheck-core"; diff --git a/pkgs/development/ocaml-modules/qcheck/lin.nix b/pkgs/development/ocaml-modules/qcheck/lin.nix index 460d15b288da94..42398920e2dcef 100644 --- a/pkgs/development/ocaml-modules/qcheck/lin.nix +++ b/pkgs/development/ocaml-modules/qcheck/lin.nix @@ -1,5 +1,6 @@ -{ buildDunePackage -, qcheck-multicoretests-util +{ + buildDunePackage, + qcheck-multicoretests-util, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/qcheck/multicoretests-util.nix b/pkgs/development/ocaml-modules/qcheck/multicoretests-util.nix index 7f51f8235d4877..38af73b0e6d730 100644 --- a/pkgs/development/ocaml-modules/qcheck/multicoretests-util.nix +++ b/pkgs/development/ocaml-modules/qcheck/multicoretests-util.nix @@ -1,5 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage -, qcheck-core +{ + lib, + fetchFromGitHub, + buildDunePackage, + qcheck-core, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/qcheck/ounit.nix b/pkgs/development/ocaml-modules/qcheck/ounit.nix index aef47005a27a17..6a09f20dfdf0ae 100644 --- a/pkgs/development/ocaml-modules/qcheck/ounit.nix +++ b/pkgs/development/ocaml-modules/qcheck/ounit.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, qcheck-core, ounit }: +{ + buildDunePackage, + qcheck-core, + ounit, +}: buildDunePackage { pname = "qcheck-ounit"; @@ -7,7 +11,10 @@ buildDunePackage { duneVersion = "3"; - propagatedBuildInputs = [ qcheck-core ounit ]; + propagatedBuildInputs = [ + qcheck-core + ounit + ]; meta = qcheck-core.meta // { description = "OUnit backend for qcheck"; diff --git a/pkgs/development/ocaml-modules/qcheck/ppx_deriving_qcheck.nix b/pkgs/development/ocaml-modules/qcheck/ppx_deriving_qcheck.nix index 82dc5399f28224..70bf69ecacf70e 100644 --- a/pkgs/development/ocaml-modules/qcheck/ppx_deriving_qcheck.nix +++ b/pkgs/development/ocaml-modules/qcheck/ppx_deriving_qcheck.nix @@ -1,5 +1,10 @@ -{ buildDunePackage, qcheck-core -, qcheck, ppxlib, ppx_deriving }: +{ + buildDunePackage, + qcheck-core, + qcheck, + ppxlib, + ppx_deriving, +}: buildDunePackage { pname = "ppx_deriving_qcheck"; diff --git a/pkgs/development/ocaml-modules/qcheck/stm.nix b/pkgs/development/ocaml-modules/qcheck/stm.nix index a4cd762ea5e44a..62b221e625aa5c 100644 --- a/pkgs/development/ocaml-modules/qcheck/stm.nix +++ b/pkgs/development/ocaml-modules/qcheck/stm.nix @@ -1,5 +1,6 @@ -{ buildDunePackage -, qcheck-multicoretests-util +{ + buildDunePackage, + qcheck-multicoretests-util, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/qtest/default.nix b/pkgs/development/ocaml-modules/qtest/default.nix index 640ecf45b7cf26..de1bbca4ef086b 100644 --- a/pkgs/development/ocaml-modules/qtest/default.nix +++ b/pkgs/development/ocaml-modules/qtest/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitHub, qcheck }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + qcheck, +}: buildDunePackage rec { pname = "qtest"; diff --git a/pkgs/development/ocaml-modules/randomconv/default.nix b/pkgs/development/ocaml-modules/randomconv/default.nix index e3e7f8ceb99d16..898318a00b21aa 100644 --- a/pkgs/development/ocaml-modules/randomconv/default.nix +++ b/pkgs/development/ocaml-modules/randomconv/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "randomconv"; diff --git a/pkgs/development/ocaml-modules/rdbg/default.nix b/pkgs/development/ocaml-modules/rdbg/default.nix index 47504e4aa88880..11aca2dd4e4e35 100644 --- a/pkgs/development/ocaml-modules/rdbg/default.nix +++ b/pkgs/development/ocaml-modules/rdbg/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchurl, num, lutils, ounit}: +{ + lib, + buildDunePackage, + fetchurl, + num, + lutils, + ounit, +}: buildDunePackage rec { pname = "rdbg"; diff --git a/pkgs/development/ocaml-modules/re/default.nix b/pkgs/development/ocaml-modules/re/default.nix index eaab20f7f2e789..badee9a3c91d09 100644 --- a/pkgs/development/ocaml-modules/re/default.nix +++ b/pkgs/development/ocaml-modules/re/default.nix @@ -1,16 +1,24 @@ -{ lib, fetchurl, buildDunePackage, ocaml, ounit, seq }: +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + ounit, + seq, +}: -let version_sha = if lib.versionAtLeast ocaml.version "4.08" - then - { - version = "1.11.0"; - sha256 = "sha256-AfwkR4DA9r5yrnlrH7dQ82feGGJP110H7nl4LtbfjU8="; - } - else - { - version = "1.9.0"; - sha256 = "1gas4ky49zgxph3870nffzkr6y41kkpqp4nj38pz1gh49zcf12aj"; - }; +let + version_sha = + if lib.versionAtLeast ocaml.version "4.08" then + { + version = "1.11.0"; + sha256 = "sha256-AfwkR4DA9r5yrnlrH7dQ82feGGJP110H7nl4LtbfjU8="; + } + else + { + version = "1.9.0"; + sha256 = "1gas4ky49zgxph3870nffzkr6y41kkpqp4nj38pz1gh49zcf12aj"; + }; in buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/react/default.nix b/pkgs/development/ocaml-modules/react/default.nix index 753a3e82c0de4a..a5cd1cb10f04c0 100644 --- a/pkgs/development/ocaml-modules/react/default.nix +++ b/pkgs/development/ocaml-modules/react/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, topkg, ocamlbuild }: +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + topkg, + ocamlbuild, +}: stdenv.mkDerivation rec { pname = "ocaml-react"; @@ -9,7 +17,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-xK3TFdbx8VPRFe58qN1gwSZf9NQIwmYSX8tRJP0ij5k="; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ]; buildInputs = [ topkg ]; strictDeps = true; @@ -21,6 +33,10 @@ stdenv.mkDerivation rec { description = "Applicative events and signals for OCaml"; license = licenses.bsd3; inherit (ocaml.meta) platforms; - maintainers = with maintainers; [ maggesi vbmithr gal_bolle ]; + maintainers = with maintainers; [ + maggesi + vbmithr + gal_bolle + ]; }; } diff --git a/pkgs/development/ocaml-modules/reactivedata/default.nix b/pkgs/development/ocaml-modules/reactivedata/default.nix index 243e0daf163189..1e5042d1ee5dab 100644 --- a/pkgs/development/ocaml-modules/reactivedata/default.nix +++ b/pkgs/development/ocaml-modules/reactivedata/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, react }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + react, +}: buildDunePackage rec { pname = "reactiveData"; diff --git a/pkgs/development/ocaml-modules/readline/default.nix b/pkgs/development/ocaml-modules/readline/default.nix index 43763a3116c6f5..4efafe2f4e3201 100644 --- a/pkgs/development/ocaml-modules/readline/default.nix +++ b/pkgs/development/ocaml-modules/readline/default.nix @@ -1,5 +1,8 @@ -{ lib, buildDunePackage, fetchFromGitLab -, readline +{ + lib, + buildDunePackage, + fetchFromGitLab, + readline, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/reason-native/cli.nix b/pkgs/development/ocaml-modules/reason-native/cli.nix index ebce5ad277f276..d07ad0475b8f3a 100644 --- a/pkgs/development/ocaml-modules/reason-native/cli.nix +++ b/pkgs/development/ocaml-modules/reason-native/cli.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, re, reason, pastel, src }: +{ + lib, + buildDunePackage, + re, + reason, + pastel, + src, +}: buildDunePackage { inherit src; @@ -15,7 +22,7 @@ buildDunePackage { pastel ]; - meta = { + meta = { downloadPage = "https://github.com/reasonml/reason-native"; homepage = "https://reason-native.com/"; license = lib.licenses.mit; diff --git a/pkgs/development/ocaml-modules/reason-native/console.nix b/pkgs/development/ocaml-modules/reason-native/console.nix index 6bede4e59e50a6..2530adf39f0da7 100644 --- a/pkgs/development/ocaml-modules/reason-native/console.nix +++ b/pkgs/development/ocaml-modules/reason-native/console.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, callPackage, reason, console, src }: +{ + lib, + buildDunePackage, + callPackage, + reason, + console, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/default.nix b/pkgs/development/ocaml-modules/reason-native/default.nix index b44e63080e5c5b..aa0c6860f73a02 100644 --- a/pkgs/development/ocaml-modules/reason-native/default.nix +++ b/pkgs/development/ocaml-modules/reason-native/default.nix @@ -12,7 +12,13 @@ }: lib.makeScope newScope (self: { - inherit lib buildDunePackage re reason ppxlib; + inherit + lib + buildDunePackage + re + reason + ppxlib + ; # Upstream doesn't use tags, releases, or branches. src = fetchFromGitHub { diff --git a/pkgs/development/ocaml-modules/reason-native/dir.nix b/pkgs/development/ocaml-modules/reason-native/dir.nix index 9b166beb40cb39..3f0cb5c4d141b2 100644 --- a/pkgs/development/ocaml-modules/reason-native/dir.nix +++ b/pkgs/development/ocaml-modules/reason-native/dir.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, reason, fp, src }: +{ + lib, + buildDunePackage, + reason, + fp, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/file-context-printer.nix b/pkgs/development/ocaml-modules/reason-native/file-context-printer.nix index 8cfd60d144bf3c..1bdad5de2d35d6 100644 --- a/pkgs/development/ocaml-modules/reason-native/file-context-printer.nix +++ b/pkgs/development/ocaml-modules/reason-native/file-context-printer.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, reason, re, pastel, src }: +{ + lib, + buildDunePackage, + reason, + re, + pastel, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/fp.nix b/pkgs/development/ocaml-modules/reason-native/fp.nix index 5cf7c3d417dea8..dc630aa12aba75 100644 --- a/pkgs/development/ocaml-modules/reason-native/fp.nix +++ b/pkgs/development/ocaml-modules/reason-native/fp.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, reason, src }: +{ + lib, + buildDunePackage, + reason, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/frame.nix b/pkgs/development/ocaml-modules/reason-native/frame.nix index 78ccdd2a879323..998ab567a14d29 100644 --- a/pkgs/development/ocaml-modules/reason-native/frame.nix +++ b/pkgs/development/ocaml-modules/reason-native/frame.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, reason, re, pastel, src }: +{ + lib, + buildDunePackage, + reason, + re, + pastel, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/fs.nix b/pkgs/development/ocaml-modules/reason-native/fs.nix index fc65551a2481ee..331607990544a7 100644 --- a/pkgs/development/ocaml-modules/reason-native/fs.nix +++ b/pkgs/development/ocaml-modules/reason-native/fs.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fp, reason, src }: +{ + lib, + buildDunePackage, + fp, + reason, + src, +}: buildDunePackage { inherit src; @@ -21,4 +27,3 @@ buildDunePackage { maintainers = [ ]; }; } - diff --git a/pkgs/development/ocaml-modules/reason-native/pastel-console.nix b/pkgs/development/ocaml-modules/reason-native/pastel-console.nix index 82a3ff55057f07..43df6e38116269 100644 --- a/pkgs/development/ocaml-modules/reason-native/pastel-console.nix +++ b/pkgs/development/ocaml-modules/reason-native/pastel-console.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, reason, console, pastel, src }: +{ + lib, + buildDunePackage, + reason, + console, + pastel, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/pastel.nix b/pkgs/development/ocaml-modules/reason-native/pastel.nix index 473c6a09e5faa4..fd22e7c56fb14f 100644 --- a/pkgs/development/ocaml-modules/reason-native/pastel.nix +++ b/pkgs/development/ocaml-modules/reason-native/pastel.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, reason, re, src }: +{ + lib, + buildDunePackage, + reason, + re, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/qcheck-rely.nix b/pkgs/development/ocaml-modules/reason-native/qcheck-rely.nix index c58782260385da..df376cf7b3cec7 100644 --- a/pkgs/development/ocaml-modules/reason-native/qcheck-rely.nix +++ b/pkgs/development/ocaml-modules/reason-native/qcheck-rely.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, qcheck-core, reason, console, rely, src }: +{ + lib, + buildDunePackage, + qcheck-core, + reason, + console, + rely, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/refmterr.nix b/pkgs/development/ocaml-modules/reason-native/refmterr.nix index b24fd7c527f3f5..35b127a9d218e9 100644 --- a/pkgs/development/ocaml-modules/reason-native/refmterr.nix +++ b/pkgs/development/ocaml-modules/reason-native/refmterr.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, atdgen, re, reason, pastel, src }: +{ + lib, + buildDunePackage, + atdgen, + re, + reason, + pastel, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/rely-junit-reporter.nix b/pkgs/development/ocaml-modules/reason-native/rely-junit-reporter.nix index 92743f4c2ecbac..43febed9c932cc 100644 --- a/pkgs/development/ocaml-modules/reason-native/rely-junit-reporter.nix +++ b/pkgs/development/ocaml-modules/reason-native/rely-junit-reporter.nix @@ -1,4 +1,14 @@ -{ lib, buildDunePackage, atdgen, junit, re, reason, pastel, rely, src }: +{ + lib, + buildDunePackage, + atdgen, + junit, + re, + reason, + pastel, + rely, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/rely.nix b/pkgs/development/ocaml-modules/reason-native/rely.nix index e9870f92b33c05..b53d32b2b0a7c8 100644 --- a/pkgs/development/ocaml-modules/reason-native/rely.nix +++ b/pkgs/development/ocaml-modules/reason-native/rely.nix @@ -1,4 +1,13 @@ -{ lib, buildDunePackage, re, reason, cli, file-context-printer, pastel, src }: +{ + lib, + buildDunePackage, + re, + reason, + cli, + file-context-printer, + pastel, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/tests/console/default.nix b/pkgs/development/ocaml-modules/reason-native/tests/console/default.nix index b2bc31565f04a2..c80bee6b4380ca 100644 --- a/pkgs/development/ocaml-modules/reason-native/tests/console/default.nix +++ b/pkgs/development/ocaml-modules/reason-native/tests/console/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, reason, console, ppxlib }: +{ + lib, + buildDunePackage, + reason, + console, + ppxlib, +}: buildDunePackage { pname = "console_test"; diff --git a/pkgs/development/ocaml-modules/reason-native/unicode-config.nix b/pkgs/development/ocaml-modules/reason-native/unicode-config.nix index bb2bbef3c4a168..b0393918b188e5 100644 --- a/pkgs/development/ocaml-modules/reason-native/unicode-config.nix +++ b/pkgs/development/ocaml-modules/reason-native/unicode-config.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, reason, src }: +{ + lib, + buildDunePackage, + reason, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/unicode.nix b/pkgs/development/ocaml-modules/reason-native/unicode.nix index 7ce536a6e21387..f8376ec6756135 100644 --- a/pkgs/development/ocaml-modules/reason-native/unicode.nix +++ b/pkgs/development/ocaml-modules/reason-native/unicode.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, reason, src }: +{ + lib, + buildDunePackage, + reason, + src, +}: buildDunePackage { inherit src; diff --git a/pkgs/development/ocaml-modules/reason-native/utf8.nix b/pkgs/development/ocaml-modules/reason-native/utf8.nix index 0a18e68a154198..5e2c6eef79eac7 100644 --- a/pkgs/development/ocaml-modules/reason-native/utf8.nix +++ b/pkgs/development/ocaml-modules/reason-native/utf8.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, reason, src }: +{ + lib, + buildDunePackage, + reason, + src, +}: buildDunePackage { inherit src; @@ -17,4 +22,3 @@ buildDunePackage { maintainers = [ ]; }; } - diff --git a/pkgs/development/ocaml-modules/rebez/default.nix b/pkgs/development/ocaml-modules/rebez/default.nix index ce2e9d3aad707a..026c67445706e7 100644 --- a/pkgs/development/ocaml-modules/rebez/default.nix +++ b/pkgs/development/ocaml-modules/rebez/default.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, fetchFromGitHub, lib, reason }: +{ + buildDunePackage, + fetchFromGitHub, + lib, + reason, +}: buildDunePackage rec { pname = "rebez"; diff --git a/pkgs/development/ocaml-modules/reperf/default.nix b/pkgs/development/ocaml-modules/reperf/default.nix index ce3164fa19a23b..829c1653840e5f 100644 --- a/pkgs/development/ocaml-modules/reperf/default.nix +++ b/pkgs/development/ocaml-modules/reperf/default.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, fetchFromGitHub, lib, printbox-text, reason }: +{ + buildDunePackage, + fetchFromGitHub, + lib, + printbox-text, + reason, +}: buildDunePackage rec { pname = "reperf"; diff --git a/pkgs/development/ocaml-modules/repr/default.nix b/pkgs/development/ocaml-modules/repr/default.nix index d3d23a5d9fc65b..ba9a0fc8572920 100644 --- a/pkgs/development/ocaml-modules/repr/default.nix +++ b/pkgs/development/ocaml-modules/repr/default.nix @@ -1,4 +1,14 @@ -{ lib, buildDunePackage, fetchFromGitHub, base64, either, fmt, jsonm, uutf, optint }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + base64, + either, + fmt, + jsonm, + uutf, + optint, +}: buildDunePackage rec { pname = "repr"; diff --git a/pkgs/development/ocaml-modules/repr/ppx.nix b/pkgs/development/ocaml-modules/repr/ppx.nix index 71fab69b08d114..82d3d85611f41b 100644 --- a/pkgs/development/ocaml-modules/repr/ppx.nix +++ b/pkgs/development/ocaml-modules/repr/ppx.nix @@ -1,4 +1,11 @@ -{ buildDunePackage, ppx_deriving, ppxlib, repr, alcotest, hex }: +{ + buildDunePackage, + ppx_deriving, + ppxlib, + repr, + alcotest, + hex, +}: buildDunePackage { pname = "ppx_repr"; diff --git a/pkgs/development/ocaml-modules/res/default.nix b/pkgs/development/ocaml-modules/res/default.nix index b7a4edd69f8edc..5ae73c967c4b91 100644 --- a/pkgs/development/ocaml-modules/res/default.nix +++ b/pkgs/development/ocaml-modules/res/default.nix @@ -1,4 +1,8 @@ -{ lib , fetchurl , buildDunePackage }: +{ + lib, + fetchurl, + buildDunePackage, +}: buildDunePackage rec { pname = "res"; @@ -21,4 +25,3 @@ buildDunePackage rec { maintainers = with lib.maintainers; [ sixstring982 ]; }; } - diff --git a/pkgs/development/ocaml-modules/resource-pooling/default.nix b/pkgs/development/ocaml-modules/resource-pooling/default.nix index 79d5c6175a7b57..d98e8e8c47e9ee 100644 --- a/pkgs/development/ocaml-modules/resource-pooling/default.nix +++ b/pkgs/development/ocaml-modules/resource-pooling/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage, lwt_log }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + lwt_log, +}: buildDunePackage rec { version = "1.2"; diff --git a/pkgs/development/ocaml-modules/resto/acl.nix b/pkgs/development/ocaml-modules/resto/acl.nix index e96f9471b1b237..c247cac6f73ace 100644 --- a/pkgs/development/ocaml-modules/resto/acl.nix +++ b/pkgs/development/ocaml-modules/resto/acl.nix @@ -1,8 +1,17 @@ -{ buildDunePackage, resto, uri }: +{ + buildDunePackage, + resto, + uri, +}: buildDunePackage { pname = "resto-acl"; - inherit (resto) src version meta doCheck; + inherit (resto) + src + version + meta + doCheck + ; minimalOCamlVersion = "4.10"; duneVersion = "3"; diff --git a/pkgs/development/ocaml-modules/resto/cohttp-client.nix b/pkgs/development/ocaml-modules/resto/cohttp-client.nix index fe6dd6b506e133..df11a7b585aee3 100644 --- a/pkgs/development/ocaml-modules/resto/cohttp-client.nix +++ b/pkgs/development/ocaml-modules/resto/cohttp-client.nix @@ -1,14 +1,20 @@ -{ buildDunePackage -, resto -, resto-directory -, resto-cohttp -, uri -, lwt +{ + buildDunePackage, + resto, + resto-directory, + resto-cohttp, + uri, + lwt, }: buildDunePackage { pname = "resto-cohttp-client"; - inherit (resto) src version meta doCheck; + inherit (resto) + src + version + meta + doCheck + ; duneVersion = "3"; propagatedBuildInputs = [ diff --git a/pkgs/development/ocaml-modules/resto/cohttp-self-serving-client.nix b/pkgs/development/ocaml-modules/resto/cohttp-self-serving-client.nix index ccce7af29d9c1e..b632c348e31c6b 100644 --- a/pkgs/development/ocaml-modules/resto/cohttp-self-serving-client.nix +++ b/pkgs/development/ocaml-modules/resto/cohttp-self-serving-client.nix @@ -1,17 +1,23 @@ -{ buildDunePackage -, resto -, resto-directory -, resto-acl -, resto-cohttp -, resto-cohttp-client -, resto-cohttp-server -, uri -, lwt +{ + buildDunePackage, + resto, + resto-directory, + resto-acl, + resto-cohttp, + resto-cohttp-client, + resto-cohttp-server, + uri, + lwt, }: buildDunePackage { pname = "resto-cohttp-self-serving-client"; - inherit (resto) src version meta doCheck; + inherit (resto) + src + version + meta + doCheck + ; duneVersion = "3"; propagatedBuildInputs = [ diff --git a/pkgs/development/ocaml-modules/resto/cohttp-server.nix b/pkgs/development/ocaml-modules/resto/cohttp-server.nix index 8a528b561a9553..0a1bb0945f3ab0 100644 --- a/pkgs/development/ocaml-modules/resto/cohttp-server.nix +++ b/pkgs/development/ocaml-modules/resto/cohttp-server.nix @@ -1,16 +1,22 @@ -{ buildDunePackage -, resto -, resto-directory -, resto-acl -, resto-cohttp -, cohttp-lwt-unix -, conduit-lwt-unix -, lwt +{ + buildDunePackage, + resto, + resto-directory, + resto-acl, + resto-cohttp, + cohttp-lwt-unix, + conduit-lwt-unix, + lwt, }: buildDunePackage { pname = "resto-cohttp-server"; - inherit (resto) src version meta doCheck; + inherit (resto) + src + version + meta + doCheck + ; duneVersion = "3"; propagatedBuildInputs = [ diff --git a/pkgs/development/ocaml-modules/resto/cohttp.nix b/pkgs/development/ocaml-modules/resto/cohttp.nix index f495cadbf48fa8..87b82ecee1adb6 100644 --- a/pkgs/development/ocaml-modules/resto/cohttp.nix +++ b/pkgs/development/ocaml-modules/resto/cohttp.nix @@ -1,8 +1,18 @@ -{ buildDunePackage, resto, resto-directory, cohttp-lwt }: +{ + buildDunePackage, + resto, + resto-directory, + cohttp-lwt, +}: buildDunePackage { pname = "resto-cohttp"; - inherit (resto) src version meta doCheck; + inherit (resto) + src + version + meta + doCheck + ; duneVersion = "3"; propagatedBuildInputs = [ diff --git a/pkgs/development/ocaml-modules/resto/default.nix b/pkgs/development/ocaml-modules/resto/default.nix index 8e887d263657ba..5018a282e59ec0 100644 --- a/pkgs/development/ocaml-modules/resto/default.nix +++ b/pkgs/development/ocaml-modules/resto/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitLab, buildDunePackage, uri }: +{ + lib, + fetchFromGitLab, + buildDunePackage, + uri, +}: buildDunePackage rec { pname = "resto"; diff --git a/pkgs/development/ocaml-modules/resto/directory.nix b/pkgs/development/ocaml-modules/resto/directory.nix index d23b6457892416..187248fcc2d894 100644 --- a/pkgs/development/ocaml-modules/resto/directory.nix +++ b/pkgs/development/ocaml-modules/resto/directory.nix @@ -1,8 +1,17 @@ -{ buildDunePackage, resto, lwt }: +{ + buildDunePackage, + resto, + lwt, +}: buildDunePackage { pname = "resto-directory"; - inherit (resto) src version meta doCheck; + inherit (resto) + src + version + meta + doCheck + ; duneVersion = "3"; propagatedBuildInputs = [ diff --git a/pkgs/development/ocaml-modules/resto/json.nix b/pkgs/development/ocaml-modules/resto/json.nix index f1ca0c49bb99e3..313acf87046291 100644 --- a/pkgs/development/ocaml-modules/resto/json.nix +++ b/pkgs/development/ocaml-modules/resto/json.nix @@ -1,8 +1,18 @@ -{ buildDunePackage, resto, json-data-encoding, json-data-encoding-bson }: +{ + buildDunePackage, + resto, + json-data-encoding, + json-data-encoding-bson, +}: buildDunePackage { pname = "resto-json"; - inherit (resto) src version meta doCheck; + inherit (resto) + src + version + meta + doCheck + ; duneVersion = "3"; propagatedBuildInputs = [ diff --git a/pkgs/development/ocaml-modules/rfc7748/default.nix b/pkgs/development/ocaml-modules/rfc7748/default.nix index 0cc59fa3e7c567..8adf46c3b384bb 100644 --- a/pkgs/development/ocaml-modules/rfc7748/default.nix +++ b/pkgs/development/ocaml-modules/rfc7748/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildDunePackage -, fetchFromGitHub -, fetchpatch -, ocaml - -, ounit -, zarith +{ + lib, + buildDunePackage, + fetchFromGitHub, + fetchpatch, + ocaml, + + ounit, + zarith, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/ringo/default.nix b/pkgs/development/ocaml-modules/ringo/default.nix index bdc9e07c0411c2..4120d82cb29534 100644 --- a/pkgs/development/ocaml-modules/ringo/default.nix +++ b/pkgs/development/ocaml-modules/ringo/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitLab, buildDunePackage }: +{ + lib, + fetchFromGitLab, + buildDunePackage, +}: buildDunePackage rec { pname = "ringo"; diff --git a/pkgs/development/ocaml-modules/rio/default.nix b/pkgs/development/ocaml-modules/rio/default.nix index 853670be35288b..ed82f82fd30eee 100644 --- a/pkgs/development/ocaml-modules/rio/default.nix +++ b/pkgs/development/ocaml-modules/rio/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildDunePackage -, fetchurl -, cstruct +{ + lib, + buildDunePackage, + fetchurl, + cstruct, }: buildDunePackage rec { @@ -27,4 +28,3 @@ buildDunePackage rec { maintainers = [ ]; }; } - diff --git a/pkgs/development/ocaml-modules/riot/default.nix b/pkgs/development/ocaml-modules/riot/default.nix index 7b5008d9b1b011..d85f0738e4bad9 100644 --- a/pkgs/development/ocaml-modules/riot/default.nix +++ b/pkgs/development/ocaml-modules/riot/default.nix @@ -1,14 +1,15 @@ -{ lib -, buildDunePackage -, fetchurl -, fetchpatch -, mirage-crypto-rng -, mtime -, gluon -, randomconv -, rio -, telemetry -, tls +{ + lib, + buildDunePackage, + fetchurl, + fetchpatch, + mirage-crypto-rng, + mtime, + gluon, + randomconv, + rio, + telemetry, + tls, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/rock/default.nix b/pkgs/development/ocaml-modules/rock/default.nix index ae484e937b83c9..4ac05b0150b267 100644 --- a/pkgs/development/ocaml-modules/rock/default.nix +++ b/pkgs/development/ocaml-modules/rock/default.nix @@ -1,9 +1,12 @@ -{ lib, fetchurl, buildDunePackage -, bigstringaf -, hmap -, httpaf -, lwt -, sexplib0 +{ + lib, + fetchurl, + buildDunePackage, + bigstringaf, + hmap, + httpaf, + lwt, + sexplib0, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/rope/default.nix b/pkgs/development/ocaml-modules/rope/default.nix index 975595808ad09e..16a8d4951fb283 100644 --- a/pkgs/development/ocaml-modules/rope/default.nix +++ b/pkgs/development/ocaml-modules/rope/default.nix @@ -1,9 +1,13 @@ -{ lib, fetchurl, fetchpatch, ocaml, buildDunePackage -, version ? if lib.versionAtLeast ocaml.version "5.0" then "0.6.3" else "0.6.2" -, benchmark +{ + lib, + fetchurl, + fetchpatch, + ocaml, + buildDunePackage, + version ? if lib.versionAtLeast ocaml.version "5.0" then "0.6.3" else "0.6.2", + benchmark, }: - buildDunePackage { pname = "rope"; inherit version; @@ -11,13 +15,15 @@ buildDunePackage { src = fetchurl { url = "https://github.com/Chris00/ocaml-rope/releases/download/${version}/rope-${version}.tbz"; - hash = { - "0.6.2" = "sha256:15cvfa0s1vjx7gjd07d3fkznilishqf4z4h2q5f20wm9ysjh2h2i"; - "0.6.3" = "sha256-M14fiP9BDiz3WEoMqAJqZaXk4PoZ8Z1YjOk+F97z05Y="; - }."${version}"; + hash = + { + "0.6.2" = "sha256:15cvfa0s1vjx7gjd07d3fkznilishqf4z4h2q5f20wm9ysjh2h2i"; + "0.6.3" = "sha256-M14fiP9BDiz3WEoMqAJqZaXk4PoZ8Z1YjOk+F97z05Y="; + } + ."${version}"; }; - buildInputs = [ benchmark ] ; + buildInputs = [ benchmark ]; patches = lib.optional (version == "0.6.3") (fetchpatch { url = "https://github.com/Chris00/ocaml-rope/commit/be53daa18dd3d1450a92881b33c997eafb1dc958.patch"; diff --git a/pkgs/development/ocaml-modules/rosetta/default.nix b/pkgs/development/ocaml-modules/rosetta/default.nix index 8e366bda1d6574..f86715ff507c57 100644 --- a/pkgs/development/ocaml-modules/rosetta/default.nix +++ b/pkgs/development/ocaml-modules/rosetta/default.nix @@ -1,9 +1,10 @@ -{ buildDunePackage -, coin -, fetchzip -, lib -, yuscii -, uuuu +{ + buildDunePackage, + coin, + fetchzip, + lib, + yuscii, + uuuu, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/routes/default.nix b/pkgs/development/ocaml-modules/routes/default.nix index 584e287bbabf9f..122c002643a02e 100644 --- a/pkgs/development/ocaml-modules/routes/default.nix +++ b/pkgs/development/ocaml-modules/routes/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, buildDunePackage }: +{ + lib, + fetchurl, + buildDunePackage, +}: buildDunePackage rec { pname = "routes"; @@ -16,6 +20,9 @@ buildDunePackage rec { description = "Typed routing for OCaml applications"; license = licenses.bsd3; homepage = "https://anuragsoni.github.io/routes"; - maintainers = with maintainers; [ ulrikstrid anmonteiro ]; + maintainers = with maintainers; [ + ulrikstrid + anmonteiro + ]; }; } diff --git a/pkgs/development/ocaml-modules/rpclib/default.nix b/pkgs/development/ocaml-modules/rpclib/default.nix index 9dd895ea4b0e0a..e6f25b2c30f820 100644 --- a/pkgs/development/ocaml-modules/rpclib/default.nix +++ b/pkgs/development/ocaml-modules/rpclib/default.nix @@ -1,6 +1,13 @@ -{ lib, fetchurl, buildDunePackage -, alcotest -, base64, cmdliner, rresult, xmlm, yojson +{ + lib, + fetchurl, + buildDunePackage, + alcotest, + base64, + cmdliner, + rresult, + xmlm, + yojson, }: buildDunePackage rec { @@ -15,8 +22,15 @@ buildDunePackage rec { hash = "sha256-ziPrdWwCjZN0vRmCMpa923wjfT8FVFLTDRz30VIW6WM="; }; - buildInputs = [ cmdliner yojson ]; - propagatedBuildInputs = [ base64 rresult xmlm ]; + buildInputs = [ + cmdliner + yojson + ]; + propagatedBuildInputs = [ + base64 + rresult + xmlm + ]; checkInputs = [ alcotest ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/rpclib/lwt.nix b/pkgs/development/ocaml-modules/rpclib/lwt.nix index ce02d4b1e66b34..5133e2f83eace7 100644 --- a/pkgs/development/ocaml-modules/rpclib/lwt.nix +++ b/pkgs/development/ocaml-modules/rpclib/lwt.nix @@ -1,9 +1,10 @@ -{ buildDunePackage -, rpclib -, lwt -, alcotest-lwt -, ppx_deriving_rpc -, yojson +{ + buildDunePackage, + rpclib, + lwt, + alcotest-lwt, + ppx_deriving_rpc, + yojson, }: buildDunePackage { @@ -11,9 +12,16 @@ buildDunePackage { inherit (rpclib) version src; duneVersion = "3"; - propagatedBuildInputs = [ lwt rpclib ]; + propagatedBuildInputs = [ + lwt + rpclib + ]; - checkInputs = [ alcotest-lwt ppx_deriving_rpc yojson ]; + checkInputs = [ + alcotest-lwt + ppx_deriving_rpc + yojson + ]; doCheck = true; meta = rpclib.meta // { diff --git a/pkgs/development/ocaml-modules/rresult/default.nix b/pkgs/development/ocaml-modules/rresult/default.nix index 0c1081159ede6e..cc559c1c1740b2 100644 --- a/pkgs/development/ocaml-modules/rresult/default.nix +++ b/pkgs/development/ocaml-modules/rresult/default.nix @@ -1,30 +1,45 @@ -{ stdenv, lib, fetchurl, ocaml, findlib, ocamlbuild, topkg, result }: +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + result, +}: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.07") "rresult is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-rresult"; - version = "0.7.0"; - src = fetchurl { - url = "https://erratique.ch/software/rresult/releases/rresult-${version}.tbz"; - sha256 = "sha256-Eap/W4NGDmBDHjFU4+MsBx1G4VHqV2DPJDd4Bb+XVUA="; - }; + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-rresult"; + version = "0.7.0"; + src = fetchurl { + url = "https://erratique.ch/software/rresult/releases/rresult-${version}.tbz"; + sha256 = "sha256-Eap/W4NGDmBDHjFU4+MsBx1G4VHqV2DPJDd4Bb+XVUA="; + }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ topkg ]; - propagatedBuildInputs = [ result ]; + propagatedBuildInputs = [ result ]; - strictDeps = true; + strictDeps = true; - inherit (topkg) buildPhase installPhase; + inherit (topkg) buildPhase installPhase; - meta = { - license = lib.licenses.isc; - homepage = "https://erratique.ch/software/rresult"; - description = "Result value combinators for OCaml"; - maintainers = [ lib.maintainers.vbgl ]; - inherit (ocaml.meta) platforms; - }; -} + meta = { + license = lib.licenses.isc; + homepage = "https://erratique.ch/software/rresult"; + description = "Result value combinators for OCaml"; + maintainers = [ lib.maintainers.vbgl ]; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/rusage/default.nix b/pkgs/development/ocaml-modules/rusage/default.nix index 891784ba6def0c..8992d60368ca42 100644 --- a/pkgs/development/ocaml-modules/rusage/default.nix +++ b/pkgs/development/ocaml-modules/rusage/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, buildDunePackage }: +{ + lib, + fetchurl, + buildDunePackage, +}: buildDunePackage rec { pname = "rusage"; diff --git a/pkgs/development/ocaml-modules/safepass/default.nix b/pkgs/development/ocaml-modules/safepass/default.nix index d60cfcdb127625..363c8edf71ee20 100644 --- a/pkgs/development/ocaml-modules/safepass/default.nix +++ b/pkgs/development/ocaml-modules/safepass/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage }: +{ + lib, + fetchFromGitHub, + buildDunePackage, +}: buildDunePackage rec { pname = "safepass"; diff --git a/pkgs/development/ocaml-modules/sail/default.nix b/pkgs/development/ocaml-modules/sail/default.nix index 56a7ef2ece2fbc..fd7947b862f776 100644 --- a/pkgs/development/ocaml-modules/sail/default.nix +++ b/pkgs/development/ocaml-modules/sail/default.nix @@ -1,17 +1,18 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, base64 -, omd -, menhir -, ott -, linenoise -, dune-site -, pprint -, makeWrapper -, lem -, linksem -, yojson +{ + lib, + fetchFromGitHub, + buildDunePackage, + base64, + omd, + menhir, + ott, + linenoise, + dune-site, + pprint, + makeWrapper, + lem, + linksem, + yojson, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/samplerate/default.nix b/pkgs/development/ocaml-modules/samplerate/default.nix index c101cfc0c2798a..51f80d727f1afc 100644 --- a/pkgs/development/ocaml-modules/samplerate/default.nix +++ b/pkgs/development/ocaml-modules/samplerate/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, libsamplerate }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + libsamplerate, +}: buildDunePackage rec { pname = "samplerate"; diff --git a/pkgs/development/ocaml-modules/saturn/default.nix b/pkgs/development/ocaml-modules/saturn/default.nix index d5b8d0478f2a3d..caa735dd17a6a5 100644 --- a/pkgs/development/ocaml-modules/saturn/default.nix +++ b/pkgs/development/ocaml-modules/saturn/default.nix @@ -1,9 +1,14 @@ -{ lib, buildDunePackage, ocaml -, saturn_lockfree -, domain_shims -, dscheck -, multicore-bench -, qcheck, qcheck-alcotest, qcheck-stm +{ + lib, + buildDunePackage, + ocaml, + saturn_lockfree, + domain_shims, + dscheck, + multicore-bench, + qcheck, + qcheck-alcotest, + qcheck-stm, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/saturn/lockfree.nix b/pkgs/development/ocaml-modules/saturn/lockfree.nix index 07b8dc785cff57..538dfda5e8385d 100644 --- a/pkgs/development/ocaml-modules/saturn/lockfree.nix +++ b/pkgs/development/ocaml-modules/saturn/lockfree.nix @@ -1,5 +1,9 @@ -{ lib, fetchurl, buildDunePackage -, backoff, multicore-magic +{ + lib, + fetchurl, + buildDunePackage, + backoff, + multicore-magic, }: buildDunePackage rec { @@ -13,7 +17,10 @@ buildDunePackage rec { hash = "sha256-ZmmxwIe5PiPYTTdvOHbOjRbv2b/bb9y0IekByfREPjk="; }; - propagatedBuildInputs = [ backoff multicore-magic ]; + propagatedBuildInputs = [ + backoff + multicore-magic + ]; meta = { description = "Lock-free data structures for multicore OCaml"; diff --git a/pkgs/development/ocaml-modules/sawja/default.nix b/pkgs/development/ocaml-modules/sawja/default.nix index 465c568a1d1f9a..57cf08744cb3a9 100644 --- a/pkgs/development/ocaml-modules/sawja/default.nix +++ b/pkgs/development/ocaml-modules/sawja/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, which, ocaml, findlib, javalib }: +{ + lib, + stdenv, + fetchFromGitHub, + which, + ocaml, + findlib, + javalib, +}: let pname = "sawja"; @@ -8,39 +16,47 @@ in lib.throwIfNot (lib.versionAtLeast ocaml.version "4.08") "${pname} is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation { + stdenv.mkDerivation + { - pname = "ocaml${ocaml.version}-${pname}"; + pname = "ocaml${ocaml.version}-${pname}"; - inherit version; + inherit version; - src = fetchFromGitHub { - owner = "javalib-team"; - repo = pname; - rev = version; - hash = "sha256-G1W8/G0TEcldnFnH/NAb9a6ZSGGP2fWTM47lI8bBHnw="; - }; + src = fetchFromGitHub { + owner = "javalib-team"; + repo = pname; + rev = version; + hash = "sha256-G1W8/G0TEcldnFnH/NAb9a6ZSGGP2fWTM47lI8bBHnw="; + }; - nativeBuildInputs = [ which ocaml findlib ]; + nativeBuildInputs = [ + which + ocaml + findlib + ]; - strictDeps = true; + strictDeps = true; - patches = [ ./configure.sh.patch ./Makefile.config.example.patch ]; + patches = [ + ./configure.sh.patch + ./Makefile.config.example.patch + ]; - createFindlibDestdir = true; + createFindlibDestdir = true; - configureScript = "./configure.sh"; - dontAddPrefix = "true"; - dontAddStaticConfigureFlags = true; - configurePlatforms = []; + configureScript = "./configure.sh"; + dontAddPrefix = "true"; + dontAddStaticConfigureFlags = true; + configurePlatforms = [ ]; - propagatedBuildInputs = [ javalib ]; + propagatedBuildInputs = [ javalib ]; - meta = with lib; { - description = "Library written in OCaml, relying on Javalib to provide a high level representation of Java bytecode programs"; - homepage = "http://sawja.inria.fr/"; - license = licenses.gpl3Plus; - maintainers = [ maintainers.vbgl ]; - inherit (ocaml.meta) platforms; - }; -} + meta = with lib; { + description = "Library written in OCaml, relying on Javalib to provide a high level representation of Java bytecode programs"; + homepage = "http://sawja.inria.fr/"; + license = licenses.gpl3Plus; + maintainers = [ maintainers.vbgl ]; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/secp256k1-internal/default.nix b/pkgs/development/ocaml-modules/secp256k1-internal/default.nix index b403b997027b62..5a57a79889e1c4 100644 --- a/pkgs/development/ocaml-modules/secp256k1-internal/default.nix +++ b/pkgs/development/ocaml-modules/secp256k1-internal/default.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitLab -, buildDunePackage -, gmp -, dune-configurator -, cstruct -, bigstring -, alcotest -, hex +{ + lib, + fetchFromGitLab, + buildDunePackage, + gmp, + dune-configurator, + cstruct, + bigstring, + alcotest, + hex, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/secp256k1/default.nix b/pkgs/development/ocaml-modules/secp256k1/default.nix index 6dd4d7ad64a48f..5a97578db5dd3a 100644 --- a/pkgs/development/ocaml-modules/secp256k1/default.nix +++ b/pkgs/development/ocaml-modules/secp256k1/default.nix @@ -1,4 +1,12 @@ -{ lib, fetchFromGitHub, buildDunePackage, base, stdio, dune-configurator, secp256k1 }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + base, + stdio, + dune-configurator, + secp256k1, +}: buildDunePackage rec { pname = "secp256k1"; @@ -13,7 +21,12 @@ buildDunePackage rec { hash = "sha256-22+dZb3MC1W5Qvsz3+IHV1/XiGCRmJHTH+6IW2QX2hU="; }; - buildInputs = [ base stdio dune-configurator secp256k1 ]; + buildInputs = [ + base + stdio + dune-configurator + secp256k1 + ]; meta = with lib; { homepage = "https://github.com/dakk/secp256k1-ml"; diff --git a/pkgs/development/ocaml-modules/sedlex/default.nix b/pkgs/development/ocaml-modules/sedlex/default.nix index 480083d6253a49..66038de71668f2 100644 --- a/pkgs/development/ocaml-modules/sedlex/default.nix +++ b/pkgs/development/ocaml-modules/sedlex/default.nix @@ -1,24 +1,27 @@ -{ lib -, fetchFromGitHub -, fetchurl -, buildDunePackage -, gen -, ppxlib -, uchar -, ppx_expect +{ + lib, + fetchFromGitHub, + fetchurl, + buildDunePackage, + gen, + ppxlib, + uchar, + ppx_expect, }: -let param = - if lib.versionAtLeast ppxlib.version "0.26.0" then - { - version = "3.3"; - sha256 = "sha256-33eJKVdoR4mlWdPZUdjQ26w+kuQWoUN68+bxy2o+Pjs="; - } - else { - version = "2.5"; - sha256 = "sha256:062a5dvrzvb81l3a9phljrhxfw9nlb61q341q0a6xn65hll3z2wy"; - } -; in +let + param = + if lib.versionAtLeast ppxlib.version "0.26.0" then + { + version = "3.3"; + sha256 = "sha256-33eJKVdoR4mlWdPZUdjQ26w+kuQWoUN68+bxy2o+Pjs="; + } + else + { + version = "2.5"; + sha256 = "sha256:062a5dvrzvb81l3a9phljrhxfw9nlb61q341q0a6xn65hll3z2wy"; + }; +in let unicodeVersion = "16.0.0"; @@ -51,12 +54,14 @@ buildDunePackage rec { inherit (param) sha256; }; - propagatedBuildInputs = [ - gen - ppxlib - ] ++ lib.optionals (!atLeast31) [ - uchar - ]; + propagatedBuildInputs = + [ + gen + ppxlib + ] + ++ lib.optionals (!atLeast31) [ + uchar + ]; preBuild = '' rm src/generator/data/dune diff --git a/pkgs/development/ocaml-modules/sel/default.nix b/pkgs/development/ocaml-modules/sel/default.nix index e5fdccbc7a3f44..89abcc5aef336e 100644 --- a/pkgs/development/ocaml-modules/sel/default.nix +++ b/pkgs/development/ocaml-modules/sel/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, ppxlib, ppx_deriving, buildDunePackage }: +{ + lib, + fetchurl, + ppxlib, + ppx_deriving, + buildDunePackage, +}: buildDunePackage rec { pname = "sel"; diff --git a/pkgs/development/ocaml-modules/semaphore-compat/default.nix b/pkgs/development/ocaml-modules/semaphore-compat/default.nix index adbff78d59453a..10d91afe8d27f5 100644 --- a/pkgs/development/ocaml-modules/semaphore-compat/default.nix +++ b/pkgs/development/ocaml-modules/semaphore-compat/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "semaphore-compat"; @@ -14,7 +18,10 @@ buildDunePackage rec { meta = with lib; { description = "Compatibility Semaphore module"; homepage = "https://github.com/mirage/semaphore-compat"; - license = with licenses; [ lgpl21Plus ocamlLgplLinkingException ]; + license = with licenses; [ + lgpl21Plus + ocamlLgplLinkingException + ]; maintainers = [ maintainers.sternenseemann ]; }; } diff --git a/pkgs/development/ocaml-modules/semver/default.nix b/pkgs/development/ocaml-modules/semver/default.nix index 5f4880c0cf2efa..3529f481c33f9b 100644 --- a/pkgs/development/ocaml-modules/semver/default.nix +++ b/pkgs/development/ocaml-modules/semver/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, buildDunePackage, ocaml, alcotest }: +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + alcotest, +}: buildDunePackage rec { pname = "semver"; diff --git a/pkgs/development/ocaml-modules/seq/default.nix b/pkgs/development/ocaml-modules/seq/default.nix index 6131585e34b150..3ca46ad5d2ac3d 100644 --- a/pkgs/development/ocaml-modules/seq/default.nix +++ b/pkgs/development/ocaml-modules/seq/default.nix @@ -1,43 +1,62 @@ -{ stdenv, lib, fetchFromGitHub, ocaml, findlib, ocamlbuild }: - -stdenv.mkDerivation ({ - version = "0.1"; - pname = "ocaml${ocaml.version}-seq"; - - meta = { - license = lib.licenses.lgpl21; - maintainers = [ lib.maintainers.vbgl ]; - homepage = "https://github.com/c-cube/seq"; - inherit (ocaml.meta) platforms; - }; - -} // (if lib.versionOlder ocaml.version "4.07" then { - - src = fetchFromGitHub { - owner = "c-cube"; - repo = "seq"; - rev = "0.1"; - sha256 = "1cjpsc7q76yfgq9iyvswxgic4kfq2vcqdlmxjdjgd4lx87zvcwrv"; - }; - - nativeBuildInputs = [ ocaml findlib ocamlbuild ]; - strictDeps = true; - - createFindlibDestdir = true; - - meta.description = "Compatibility package for OCaml’s standard iterator type starting from 4.07"; - -} else { - - src = ./src-base; - - dontBuild = true; - - installPhase = '' - mkdir -p $out/lib/ocaml/${ocaml.version}/site-lib/seq - cp META $out/lib/ocaml/${ocaml.version}/site-lib/seq - ''; - - meta.description = "dummy backward-compatibility package for iterators"; - -})) +{ + stdenv, + lib, + fetchFromGitHub, + ocaml, + findlib, + ocamlbuild, +}: + +stdenv.mkDerivation ( + { + version = "0.1"; + pname = "ocaml${ocaml.version}-seq"; + + meta = { + license = lib.licenses.lgpl21; + maintainers = [ lib.maintainers.vbgl ]; + homepage = "https://github.com/c-cube/seq"; + inherit (ocaml.meta) platforms; + }; + + } + // ( + if lib.versionOlder ocaml.version "4.07" then + { + + src = fetchFromGitHub { + owner = "c-cube"; + repo = "seq"; + rev = "0.1"; + sha256 = "1cjpsc7q76yfgq9iyvswxgic4kfq2vcqdlmxjdjgd4lx87zvcwrv"; + }; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ]; + strictDeps = true; + + createFindlibDestdir = true; + + meta.description = "Compatibility package for OCaml’s standard iterator type starting from 4.07"; + + } + else + { + + src = ./src-base; + + dontBuild = true; + + installPhase = '' + mkdir -p $out/lib/ocaml/${ocaml.version}/site-lib/seq + cp META $out/lib/ocaml/${ocaml.version}/site-lib/seq + ''; + + meta.description = "dummy backward-compatibility package for iterators"; + + } + ) +) diff --git a/pkgs/development/ocaml-modules/seqes/default.nix b/pkgs/development/ocaml-modules/seqes/default.nix index 242895f95c5c41..00d68ffdbb164f 100644 --- a/pkgs/development/ocaml-modules/seqes/default.nix +++ b/pkgs/development/ocaml-modules/seqes/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, buildDunePackage, qcheck, qcheck-alcotest, alcotest }: +{ + lib, + fetchurl, + buildDunePackage, + qcheck, + qcheck-alcotest, + alcotest, +}: buildDunePackage rec { pname = "seqes"; @@ -11,7 +18,11 @@ buildDunePackage rec { minimalOCamlVersion = "4.14"; doCheck = true; - checkInputs = [ qcheck qcheck-alcotest alcotest ]; + checkInputs = [ + qcheck + qcheck-alcotest + alcotest + ]; meta = with lib; { description = "Variations of the Seq module with monads folded into the type"; diff --git a/pkgs/development/ocaml-modules/sha/default.nix b/pkgs/development/ocaml-modules/sha/default.nix index c54c143d5b48cc..c7f646d469081b 100644 --- a/pkgs/development/ocaml-modules/sha/default.nix +++ b/pkgs/development/ocaml-modules/sha/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, buildDunePackage, ocaml, stdlib-shims, ounit2 }: +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + stdlib-shims, + ounit2, +}: buildDunePackage rec { pname = "sha"; diff --git a/pkgs/development/ocaml-modules/shared-memory-ring/default.nix b/pkgs/development/ocaml-modules/shared-memory-ring/default.nix index 331eff1c1027a1..ea64b87f062f48 100644 --- a/pkgs/development/ocaml-modules/shared-memory-ring/default.nix +++ b/pkgs/development/ocaml-modules/shared-memory-ring/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildDunePackage -, fetchurl -, ppx_cstruct -, cstruct -, lwt -, ounit +{ + lib, + buildDunePackage, + fetchurl, + ppx_cstruct, + cstruct, + lwt, + ounit, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/shared-memory-ring/lwt.nix b/pkgs/development/ocaml-modules/shared-memory-ring/lwt.nix index 0dd8d819611da4..81a8b7ca30d9cb 100644 --- a/pkgs/development/ocaml-modules/shared-memory-ring/lwt.nix +++ b/pkgs/development/ocaml-modules/shared-memory-ring/lwt.nix @@ -1,11 +1,12 @@ -{ buildDunePackage -, shared-memory-ring -, ppx_cstruct -, cstruct -, lwt -, lwt-dllist -, mirage-profile -, ounit +{ + buildDunePackage, + shared-memory-ring, + ppx_cstruct, + cstruct, + lwt, + lwt-dllist, + mirage-profile, + ounit, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/shine/default.nix b/pkgs/development/ocaml-modules/shine/default.nix index 13d41e72254b76..cea921d9132330 100644 --- a/pkgs/development/ocaml-modules/shine/default.nix +++ b/pkgs/development/ocaml-modules/shine/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, shine }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + shine, +}: buildDunePackage rec { pname = "shine"; diff --git a/pkgs/development/ocaml-modules/simple-diff/default.nix b/pkgs/development/ocaml-modules/simple-diff/default.nix index a87026fb4a0b70..0a578f28b2b1e5 100644 --- a/pkgs/development/ocaml-modules/simple-diff/default.nix +++ b/pkgs/development/ocaml-modules/simple-diff/default.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchFromGitHub, ocaml, findlib, topkg, ocamlbuild, re }: +{ + stdenv, + lib, + fetchFromGitHub, + ocaml, + findlib, + topkg, + ocamlbuild, + re, +}: stdenv.mkDerivation rec { pname = "ocaml${ocaml.version}-simple-diff"; @@ -11,7 +20,12 @@ stdenv.mkDerivation rec { sha256 = "sha256-OaKECUBCCt9KfdRJf3HcXTUJVxKKdYtnzOHpMPOllrk="; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; buildInputs = [ topkg ]; propagatedBuildInputs = [ re ]; diff --git a/pkgs/development/ocaml-modules/slug/default.nix b/pkgs/development/ocaml-modules/slug/default.nix index 2ae81209b54963..55657d32c454f7 100644 --- a/pkgs/development/ocaml-modules/slug/default.nix +++ b/pkgs/development/ocaml-modules/slug/default.nix @@ -1,6 +1,11 @@ -{ lib, fetchFromGitHub, buildDunePackage -, re, uunf, uuseg -, alcotest +{ + lib, + fetchFromGitHub, + buildDunePackage, + re, + uunf, + uuseg, + alcotest, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/sodium/default.nix b/pkgs/development/ocaml-modules/sodium/default.nix index a3777f7d8aec84..7ca2e65935adb5 100644 --- a/pkgs/development/ocaml-modules/sodium/default.nix +++ b/pkgs/development/ocaml-modules/sodium/default.nix @@ -1,37 +1,54 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, findlib, ocamlbuild, ctypes, libsodium }: +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, + ocamlbuild, + ctypes, + libsodium, +}: lib.throwIf (lib.versionAtLeast ocaml.version "5.0") "sodium is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-sodium"; - version = "0.6.0"; - - src = fetchFromGitHub { - owner = "dsheets"; - repo = "ocaml-sodium"; - rev = version; - sha256 = "124gpi1jhac46x05gp5viykyrafnlp03v1cmkl13c6pgcs8w04pv"; - }; - - patches = [ - # ctypes.stubs no longer pulls in bigarray automatically - ./lib-gen-link-bigarray.patch - ]; - - nativeBuildInputs = [ ocaml findlib ocamlbuild ]; - propagatedBuildInputs = [ ctypes libsodium ]; - - strictDeps = true; - - createFindlibDestdir = true; - - hardeningDisable = lib.optional stdenv.hostPlatform.isDarwin "strictoverflow"; - - meta = with lib; { - homepage = "https://github.com/dsheets/ocaml-sodium"; - description = "Binding to libsodium 1.0.9+"; - inherit (ocaml.meta) platforms; - maintainers = [ maintainers.rixed ]; - }; -} + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-sodium"; + version = "0.6.0"; + + src = fetchFromGitHub { + owner = "dsheets"; + repo = "ocaml-sodium"; + rev = version; + sha256 = "124gpi1jhac46x05gp5viykyrafnlp03v1cmkl13c6pgcs8w04pv"; + }; + + patches = [ + # ctypes.stubs no longer pulls in bigarray automatically + ./lib-gen-link-bigarray.patch + ]; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ]; + propagatedBuildInputs = [ + ctypes + libsodium + ]; + + strictDeps = true; + + createFindlibDestdir = true; + + hardeningDisable = lib.optional stdenv.hostPlatform.isDarwin "strictoverflow"; + + meta = with lib; { + homepage = "https://github.com/dsheets/ocaml-sodium"; + description = "Binding to libsodium 1.0.9+"; + inherit (ocaml.meta) platforms; + maintainers = [ maintainers.rixed ]; + }; + } diff --git a/pkgs/development/ocaml-modules/sosa/default.nix b/pkgs/development/ocaml-modules/sosa/default.nix index 1ef11e363ff817..ded25d88f58e35 100644 --- a/pkgs/development/ocaml-modules/sosa/default.nix +++ b/pkgs/development/ocaml-modules/sosa/default.nix @@ -1,42 +1,52 @@ -{ lib, fetchFromGitHub, stdenv -, findlib, ocaml, ocamlbuild +{ + lib, + fetchFromGitHub, + stdenv, + findlib, + ocaml, + ocamlbuild, }: lib.throwIf (lib.versionOlder ocaml.version "4.02") "sosa is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-sosa"; - version = "0.3.0"; - - src = fetchFromGitHub { - owner = "hammerlab"; - repo = "sosa"; - rev = "sosa.${version}"; - sha256 = "053hdv6ww0q4mivajj4iyp7krfvgq8zajq9d8x4mia4lid7j0dyk"; - }; - - postPatch = lib.optionalString (lib.versionAtLeast ocaml.version "4.07") '' - for p in functors list_of of_mutable - do - substituteInPlace src/lib/$p.ml --replace Pervasives. Stdlib. - done - ''; - - nativeBuildInputs = [ ocaml ocamlbuild findlib ]; - - strictDeps = true; - - buildPhase = "make build"; - - createFindlibDestdir = true; - - doCheck = true; - - meta = with lib; { - homepage = "http://www.hammerlab.org/docs/sosa/master/index.html"; - description = "Sane OCaml String API"; - license = licenses.isc; - maintainers = [ maintainers.alexfmpe ]; - }; -} + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-sosa"; + version = "0.3.0"; + + src = fetchFromGitHub { + owner = "hammerlab"; + repo = "sosa"; + rev = "sosa.${version}"; + sha256 = "053hdv6ww0q4mivajj4iyp7krfvgq8zajq9d8x4mia4lid7j0dyk"; + }; + + postPatch = lib.optionalString (lib.versionAtLeast ocaml.version "4.07") '' + for p in functors list_of of_mutable + do + substituteInPlace src/lib/$p.ml --replace Pervasives. Stdlib. + done + ''; + + nativeBuildInputs = [ + ocaml + ocamlbuild + findlib + ]; + + strictDeps = true; + + buildPhase = "make build"; + + createFindlibDestdir = true; + + doCheck = true; + + meta = with lib; { + homepage = "http://www.hammerlab.org/docs/sosa/master/index.html"; + description = "Sane OCaml String API"; + license = licenses.isc; + maintainers = [ maintainers.alexfmpe ]; + }; + } diff --git a/pkgs/development/ocaml-modules/soundtouch/default.nix b/pkgs/development/ocaml-modules/soundtouch/default.nix index fc79664d06bbe4..db7cb1de1060a0 100644 --- a/pkgs/development/ocaml-modules/soundtouch/default.nix +++ b/pkgs/development/ocaml-modules/soundtouch/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, soundtouch }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + soundtouch, +}: buildDunePackage rec { pname = "soundtouch"; diff --git a/pkgs/development/ocaml-modules/speex/default.nix b/pkgs/development/ocaml-modules/speex/default.nix index 1bf5f308ecf226..e0e8da318dd9bc 100644 --- a/pkgs/development/ocaml-modules/speex/default.nix +++ b/pkgs/development/ocaml-modules/speex/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, ogg, speex }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + ogg, + speex, +}: buildDunePackage rec { pname = "speex"; @@ -14,7 +21,10 @@ buildDunePackage rec { }; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ ogg speex.dev ]; + propagatedBuildInputs = [ + ogg + speex.dev + ]; meta = with lib; { homepage = "https://github.com/savonet/ocaml-speex"; diff --git a/pkgs/development/ocaml-modules/spelll/default.nix b/pkgs/development/ocaml-modules/spelll/default.nix index 076cc5cc3a4557..ec59977d333ef6 100644 --- a/pkgs/development/ocaml-modules/spelll/default.nix +++ b/pkgs/development/ocaml-modules/spelll/default.nix @@ -1,6 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage -, seq -, stdlib-shims +{ + lib, + fetchFromGitHub, + buildDunePackage, + seq, + stdlib-shims, }: buildDunePackage rec { @@ -16,7 +19,10 @@ buildDunePackage rec { hash = "sha256-nI8fdArYynR70PUJIgyogGBCe4gFhfVzuRdZzFGKqOc="; }; - propagatedBuildInputs = [ seq stdlib-shims ]; + propagatedBuildInputs = [ + seq + stdlib-shims + ]; meta = { inherit (src.meta) homepage; diff --git a/pkgs/development/ocaml-modules/spices/default.nix b/pkgs/development/ocaml-modules/spices/default.nix index 263d1441e35b90..488e802497765b 100644 --- a/pkgs/development/ocaml-modules/spices/default.nix +++ b/pkgs/development/ocaml-modules/spices/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildDunePackage -, fetchurl -, colors -, tty +{ + lib, + buildDunePackage, + fetchurl, + colors, + tty, }: buildDunePackage rec { @@ -31,4 +32,3 @@ buildDunePackage rec { maintainers = [ ]; }; } - diff --git a/pkgs/development/ocaml-modules/sqlite3/default.nix b/pkgs/development/ocaml-modules/sqlite3/default.nix index e45961f403e125..240cab8d4e4606 100644 --- a/pkgs/development/ocaml-modules/sqlite3/default.nix +++ b/pkgs/development/ocaml-modules/sqlite3/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, sqlite, pkg-config, buildDunePackage, dune-configurator }: +{ + lib, + fetchurl, + sqlite, + pkg-config, + buildDunePackage, + dune-configurator, +}: buildDunePackage rec { pname = "sqlite3"; @@ -12,14 +19,18 @@ buildDunePackage rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ dune-configurator sqlite ]; + buildInputs = [ + dune-configurator + sqlite + ]; meta = with lib; { homepage = "http://mmottl.github.io/sqlite3-ocaml/"; description = "OCaml bindings to the SQLite 3 database access library"; license = licenses.mit; maintainers = with maintainers; [ - maggesi vbgl + maggesi + vbgl ]; }; } diff --git a/pkgs/development/ocaml-modules/srt/default.nix b/pkgs/development/ocaml-modules/srt/default.nix index e0184643e14fa7..5854e55142853a 100644 --- a/pkgs/development/ocaml-modules/srt/default.nix +++ b/pkgs/development/ocaml-modules/srt/default.nix @@ -1,8 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub -, dune-configurator -, posix-socket -, srt -, ctypes-foreign +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + posix-socket, + srt, + ctypes-foreign, }: buildDunePackage rec { @@ -19,12 +22,19 @@ buildDunePackage rec { }; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ ctypes-foreign posix-socket srt ]; + propagatedBuildInputs = [ + ctypes-foreign + posix-socket + srt + ]; meta = { description = "OCaml bindings for the libsrt library"; license = lib.licenses.gpl2Plus; inherit (src.meta) homepage; - maintainers = with lib.maintainers; [ vbgl dandellion ]; + maintainers = with lib.maintainers; [ + vbgl + dandellion + ]; }; } diff --git a/pkgs/development/ocaml-modules/ssl/default.nix b/pkgs/development/ocaml-modules/ssl/default.nix index c3b66f29a24c26..fea4be04f8a3c4 100644 --- a/pkgs/development/ocaml-modules/ssl/default.nix +++ b/pkgs/development/ocaml-modules/ssl/default.nix @@ -1,11 +1,12 @@ -{ alcotest -, buildDunePackage -, dune-configurator -, fetchFromGitHub -, lib -, ocaml -, openssl -, pkg-config +{ + alcotest, + buildDunePackage, + dune-configurator, + fetchFromGitHub, + lib, + ocaml, + openssl, + pkg-config, }: buildDunePackage rec { @@ -37,6 +38,10 @@ buildDunePackage rec { homepage = "http://savonet.rastageeks.org/"; description = "OCaml bindings for libssl"; license = "LGPL+link exception"; - maintainers = with lib.maintainers; [ anmonteiro dandellion maggesi ]; + maintainers = with lib.maintainers; [ + anmonteiro + dandellion + maggesi + ]; }; } diff --git a/pkgs/development/ocaml-modules/stdcompat/default.nix b/pkgs/development/ocaml-modules/stdcompat/default.nix index 23eeca421f5ea2..b2d5e3e89eec70 100644 --- a/pkgs/development/ocaml-modules/stdcompat/default.nix +++ b/pkgs/development/ocaml-modules/stdcompat/default.nix @@ -1,27 +1,29 @@ -{ buildDunePackage -, ocaml -, lib -, fetchurl +{ + buildDunePackage, + ocaml, + lib, + fetchurl, }: lib.throwIf (lib.versionAtLeast ocaml.version "5.2") "stdcompat is not available for OCaml ${ocaml.version}" -buildDunePackage rec { - pname = "stdcompat"; - version = "19"; + buildDunePackage + rec { + pname = "stdcompat"; + version = "19"; - src = fetchurl { - url = "https://github.com/thierry-martinez/stdcompat/releases/download/v${version}/stdcompat-${version}.tar.gz"; - sha256 = "sha256-DKQGd4nnIN6SPls6hcA/2Jvc7ivYNpeMU6rYsVc1ClU="; - }; + src = fetchurl { + url = "https://github.com/thierry-martinez/stdcompat/releases/download/v${version}/stdcompat-${version}.tar.gz"; + sha256 = "sha256-DKQGd4nnIN6SPls6hcA/2Jvc7ivYNpeMU6rYsVc1ClU="; + }; - # Otherwise ./configure script will run and create files conflicting with dune. - dontConfigure = true; + # Otherwise ./configure script will run and create files conflicting with dune. + dontConfigure = true; - meta = { - homepage = "https://github.com/thierry-martinez/stdcompat"; - license = lib.licenses.bsd2; - maintainers = [ lib.maintainers.vbgl ]; - }; -} + meta = { + homepage = "https://github.com/thierry-martinez/stdcompat"; + license = lib.licenses.bsd2; + maintainers = [ lib.maintainers.vbgl ]; + }; + } diff --git a/pkgs/development/ocaml-modules/stdint/default.nix b/pkgs/development/ocaml-modules/stdint/default.nix index cec0ec81830027..f4696204409289 100644 --- a/pkgs/development/ocaml-modules/stdint/default.nix +++ b/pkgs/development/ocaml-modules/stdint/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, buildDunePackage, ocaml, qcheck }: +{ + lib, + fetchurl, + buildDunePackage, + ocaml, + qcheck, +}: buildDunePackage rec { pname = "stdint"; diff --git a/pkgs/development/ocaml-modules/stdlib-shims/default.nix b/pkgs/development/ocaml-modules/stdlib-shims/default.nix index 45c8bb2e4a1a2b..3c3625c8c35113 100644 --- a/pkgs/development/ocaml-modules/stdlib-shims/default.nix +++ b/pkgs/development/ocaml-modules/stdlib-shims/default.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, lib, fetchurl, ocaml }: +{ + buildDunePackage, + lib, + fetchurl, + ocaml, +}: buildDunePackage rec { pname = "stdlib-shims"; diff --git a/pkgs/development/ocaml-modules/stdune/default.nix b/pkgs/development/ocaml-modules/stdune/default.nix index ffb73941f0bdc4..bc880cf2125f55 100644 --- a/pkgs/development/ocaml-modules/stdune/default.nix +++ b/pkgs/development/ocaml-modules/stdune/default.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, dune_3, dyn, ordering, csexp }: +{ + buildDunePackage, + dune_3, + dyn, + ordering, + csexp, +}: buildDunePackage { pname = "stdune"; @@ -7,7 +13,11 @@ buildDunePackage { dontAddPrefix = true; - propagatedBuildInputs = [ dyn ordering csexp ]; + propagatedBuildInputs = [ + dyn + ordering + csexp + ]; preBuild = '' rm -r vendor/csexp @@ -17,4 +27,3 @@ buildDunePackage { description = "Dune's unstable standard library"; }; } - diff --git a/pkgs/development/ocaml-modules/streaming/default.nix b/pkgs/development/ocaml-modules/streaming/default.nix index f2a8c883f72406..77912934d4b5d2 100644 --- a/pkgs/development/ocaml-modules/streaming/default.nix +++ b/pkgs/development/ocaml-modules/streaming/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildDunePackage -, fetchurl -, stdlib-shims +{ + lib, + buildDunePackage, + fetchurl, + stdlib-shims, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/stringext/default.nix b/pkgs/development/ocaml-modules/stringext/default.nix index 32d801f971fb4a..830185e89054c3 100644 --- a/pkgs/development/ocaml-modules/stringext/default.nix +++ b/pkgs/development/ocaml-modules/stringext/default.nix @@ -1,9 +1,17 @@ -{ lib, fetchurl, ocaml, buildDunePackage, ounit, qtest -# Optionally enable tests; test script use OCaml-4.01+ features -, doCheck ? lib.versionAtLeast ocaml.version "4.08" +{ + lib, + fetchurl, + ocaml, + buildDunePackage, + ounit, + qtest, + # Optionally enable tests; test script use OCaml-4.01+ features + doCheck ? lib.versionAtLeast ocaml.version "4.08", }: -let version = "1.6.0"; in +let + version = "1.6.0"; +in buildDunePackage { pname = "stringext"; @@ -14,7 +22,10 @@ buildDunePackage { sha256 = "1sh6nafi3i9773j5mlwwz3kxfzdjzsfqj2qibxhigawy5vazahfv"; }; - checkInputs = [ ounit qtest ]; + checkInputs = [ + ounit + qtest + ]; inherit doCheck; meta = { diff --git a/pkgs/development/ocaml-modules/syslog-message/default.nix b/pkgs/development/ocaml-modules/syslog-message/default.nix index 5d1000c3182e07..33c71b455f8a1b 100644 --- a/pkgs/development/ocaml-modules/syslog-message/default.nix +++ b/pkgs/development/ocaml-modules/syslog-message/default.nix @@ -1,5 +1,9 @@ -{ lib, buildDunePackage, fetchurl -, ptime, qcheck +{ + lib, + buildDunePackage, + fetchurl, + ptime, + qcheck, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/syslog/default.nix b/pkgs/development/ocaml-modules/syslog/default.nix index ad9204847e1016..293e508c283fd4 100644 --- a/pkgs/development/ocaml-modules/syslog/default.nix +++ b/pkgs/development/ocaml-modules/syslog/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, buildDunePackage }: +{ + lib, + fetchFromGitHub, + buildDunePackage, +}: buildDunePackage rec { pname = "syslog"; diff --git a/pkgs/development/ocaml-modules/taglib/default.nix b/pkgs/development/ocaml-modules/taglib/default.nix index 95b5ae04578ff5..58bfb599272a71 100644 --- a/pkgs/development/ocaml-modules/taglib/default.nix +++ b/pkgs/development/ocaml-modules/taglib/default.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, pkg-config, taglib, zlib }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + pkg-config, + taglib, + zlib, +}: buildDunePackage rec { pname = "taglib"; @@ -15,12 +23,18 @@ buildDunePackage rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ taglib zlib ]; + propagatedBuildInputs = [ + taglib + zlib + ]; meta = with lib; { homepage = "https://github.com/savonet/ocaml-taglib"; description = "Bindings for the taglib library which provides functions for reading tags in headers of audio files"; - license = with licenses; [ lgpl21Plus "link-exception" ]; # GNU Library Public License 2 Linking Exception + license = with licenses; [ + lgpl21Plus + "link-exception" + ]; # GNU Library Public License 2 Linking Exception maintainers = with maintainers; [ dandellion ]; }; } diff --git a/pkgs/development/ocaml-modules/tar/default.nix b/pkgs/development/ocaml-modules/tar/default.nix index f0d8876fd41e2a..0a5bda3881c40c 100644 --- a/pkgs/development/ocaml-modules/tar/default.nix +++ b/pkgs/development/ocaml-modules/tar/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchurl -, buildDunePackage -, camlp-streams -, cstruct -, decompress +{ + lib, + fetchurl, + buildDunePackage, + camlp-streams, + cstruct, + decompress, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/tar/unix.nix b/pkgs/development/ocaml-modules/tar/unix.nix index ed12dd57536a07..701e2a4458bf25 100644 --- a/pkgs/development/ocaml-modules/tar/unix.nix +++ b/pkgs/development/ocaml-modules/tar/unix.nix @@ -1,8 +1,9 @@ -{ buildDunePackage -, tar -, cstruct-lwt -, lwt -, git +{ + buildDunePackage, + tar, + cstruct-lwt, + lwt, + git, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/tcpip/default.nix b/pkgs/development/ocaml-modules/tcpip/default.nix index 9920f8f8576b9c..d72332b832482e 100644 --- a/pkgs/development/ocaml-modules/tcpip/default.nix +++ b/pkgs/development/ocaml-modules/tcpip/default.nix @@ -1,14 +1,35 @@ -{ lib, buildDunePackage, fetchurl -, pkg-config -, cstruct, cstruct-lwt, mirage-net, mirage-clock -, mirage-crypto-rng-mirage, mirage-time -, macaddr, macaddr-cstruct, fmt -, lwt, lwt-dllist, logs, duration, randomconv, ethernet -, alcotest, mirage-flow, mirage-vnetif, pcap-format -, mirage-clock-unix, arp, ipaddr-cstruct, mirage-crypto-rng -, lru, metrics -, withFreestanding ? false -, ocaml-freestanding +{ + lib, + buildDunePackage, + fetchurl, + pkg-config, + cstruct, + cstruct-lwt, + mirage-net, + mirage-clock, + mirage-crypto-rng-mirage, + mirage-time, + macaddr, + macaddr-cstruct, + fmt, + lwt, + lwt-dllist, + logs, + duration, + randomconv, + ethernet, + alcotest, + mirage-flow, + mirage-vnetif, + pcap-format, + mirage-clock-unix, + arp, + ipaddr-cstruct, + mirage-crypto-rng, + lru, + metrics, + withFreestanding ? false, + ocaml-freestanding, }: buildDunePackage rec { @@ -24,30 +45,32 @@ buildDunePackage rec { pkg-config ]; - propagatedBuildInputs = [ - cstruct - cstruct-lwt - mirage-net - mirage-clock - mirage-crypto-rng-mirage - mirage-time - ipaddr-cstruct - macaddr - macaddr-cstruct - fmt - lwt - lwt-dllist - logs - duration - randomconv - ethernet - lru - metrics - arp - mirage-flow - ] ++ lib.optionals withFreestanding [ - ocaml-freestanding - ]; + propagatedBuildInputs = + [ + cstruct + cstruct-lwt + mirage-net + mirage-clock + mirage-crypto-rng-mirage + mirage-time + ipaddr-cstruct + macaddr + macaddr-cstruct + fmt + lwt + lwt-dllist + logs + duration + randomconv + ethernet + lru + metrics + arp + mirage-flow + ] + ++ lib.optionals withFreestanding [ + ocaml-freestanding + ]; doCheck = true; checkInputs = [ diff --git a/pkgs/development/ocaml-modules/tcslib/default.nix b/pkgs/development/ocaml-modules/tcslib/default.nix index 2cec5ccc5e5eaf..58c19e399cc40c 100644 --- a/pkgs/development/ocaml-modules/tcslib/default.nix +++ b/pkgs/development/ocaml-modules/tcslib/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildOasisPackage, extlib, num }: +{ + lib, + fetchFromGitHub, + buildOasisPackage, + extlib, + num, +}: buildOasisPackage rec { pname = "tcslib"; @@ -7,13 +13,16 @@ buildOasisPackage rec { minimumOCamlVersion = "4.03.0"; src = fetchFromGitHub { - owner = "tcsprojects"; - repo = "tcslib"; - rev = "v${version}"; + owner = "tcsprojects"; + repo = "tcslib"; + rev = "v${version}"; sha256 = "05g6m82blsccq8wx8knxv6a5fzww7hi624jx91f9h87nk2fsplhi"; }; - propagatedBuildInputs = [ extlib num ]; + propagatedBuildInputs = [ + extlib + num + ]; meta = { homepage = "https://github.com/tcsprojects/tcslib"; diff --git a/pkgs/development/ocaml-modules/tdigest/default.nix b/pkgs/development/ocaml-modules/tdigest/default.nix index b8d8f7b5201728..5ea7ed0f7ee03d 100644 --- a/pkgs/development/ocaml-modules/tdigest/default.nix +++ b/pkgs/development/ocaml-modules/tdigest/default.nix @@ -1,7 +1,10 @@ -{ lib, fetchFromGitHub, nix-update-script -, buildDunePackage -, base -, ppx_sexp_conv +{ + lib, + fetchFromGitHub, + nix-update-script, + buildDunePackage, + base, + ppx_sexp_conv, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/telegraml/default.nix b/pkgs/development/ocaml-modules/telegraml/default.nix index 31eccdcaa6e546..23ce695840bc0d 100644 --- a/pkgs/development/ocaml-modules/telegraml/default.nix +++ b/pkgs/development/ocaml-modules/telegraml/default.nix @@ -1,10 +1,11 @@ -{ batteries -, buildDunePackage -, cohttp-lwt-unix -, fetchFromGitHub -, lib -, logs -, yojson +{ + batteries, + buildDunePackage, + cohttp-lwt-unix, + fetchFromGitHub, + lib, + logs, + yojson, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/telemetry/default.nix b/pkgs/development/ocaml-modules/telemetry/default.nix index d1a57745cefb7f..bf25a422bb2dad 100644 --- a/pkgs/development/ocaml-modules/telemetry/default.nix +++ b/pkgs/development/ocaml-modules/telemetry/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "telemetry"; diff --git a/pkgs/development/ocaml-modules/terminal/default.nix b/pkgs/development/ocaml-modules/terminal/default.nix index 1e43b2f8ee2a22..0222690e2d5a26 100644 --- a/pkgs/development/ocaml-modules/terminal/default.nix +++ b/pkgs/development/ocaml-modules/terminal/default.nix @@ -1,6 +1,13 @@ -{ lib, buildDunePackage, fetchurl, ocaml -, stdlib-shims, uutf, uucp -, alcotest, fmt +{ + lib, + buildDunePackage, + fetchurl, + ocaml, + stdlib-shims, + uutf, + uucp, + alcotest, + fmt, }: buildDunePackage rec { @@ -14,10 +21,17 @@ buildDunePackage rec { hash = "sha256-i+RJVTN5uy3F6LeYBcgER2kKA9yj6a7pWf7PRtgnj7c="; }; - propagatedBuildInputs = [ stdlib-shims uutf uucp ]; + propagatedBuildInputs = [ + stdlib-shims + uutf + uucp + ]; doCheck = lib.versionAtLeast ocaml.version "4.08"; - checkInputs = [ alcotest fmt ]; + checkInputs = [ + alcotest + fmt + ]; meta = with lib; { description = "Basic utilities for interacting with terminals"; @@ -26,4 +40,3 @@ buildDunePackage rec { maintainers = [ maintainers.vbgl ]; }; } - diff --git a/pkgs/development/ocaml-modules/terminal_size/default.nix b/pkgs/development/ocaml-modules/terminal_size/default.nix index 228a6f222efc9f..305d9743fa4cb7 100644 --- a/pkgs/development/ocaml-modules/terminal_size/default.nix +++ b/pkgs/development/ocaml-modules/terminal_size/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, ocaml, fetchurl, alcotest }: +{ + lib, + buildDunePackage, + ocaml, + fetchurl, + alcotest, +}: buildDunePackage rec { pname = "terminal_size"; diff --git a/pkgs/development/ocaml-modules/tezos-base58/default.nix b/pkgs/development/ocaml-modules/tezos-base58/default.nix index 1ed04a082d5b86..ff639092642338 100644 --- a/pkgs/development/ocaml-modules/tezos-base58/default.nix +++ b/pkgs/development/ocaml-modules/tezos-base58/default.nix @@ -1,5 +1,10 @@ -{ buildDunePackage, fetchurl, lib -, zarith, digestif, fmt +{ + buildDunePackage, + fetchurl, + lib, + zarith, + digestif, + fmt, }: buildDunePackage rec { @@ -15,7 +20,9 @@ buildDunePackage rec { duneVersion = "3"; propagatedBuildInputs = [ - zarith digestif fmt + zarith + digestif + fmt ]; meta = with lib; { diff --git a/pkgs/development/ocaml-modules/tezt/default.nix b/pkgs/development/ocaml-modules/tezt/default.nix index 0dc05750896a2d..66a4cde7cbee3d 100644 --- a/pkgs/development/ocaml-modules/tezt/default.nix +++ b/pkgs/development/ocaml-modules/tezt/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitLab -, buildDunePackage -, clap -, ezjsonm -, lwt -, re +{ + lib, + fetchFromGitLab, + buildDunePackage, + clap, + ezjsonm, + lwt, + re, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/theora/default.nix b/pkgs/development/ocaml-modules/theora/default.nix index 0fc9048a09cec8..e0aa39107f8b17 100644 --- a/pkgs/development/ocaml-modules/theora/default.nix +++ b/pkgs/development/ocaml-modules/theora/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, ogg, libtheora }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + ogg, + libtheora, +}: buildDunePackage rec { pname = "theora"; @@ -14,7 +21,10 @@ buildDunePackage rec { }; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ ogg libtheora ]; + propagatedBuildInputs = [ + ogg + libtheora + ]; meta = with lib; { homepage = "https://github.com/savonet/ocaml-theora"; diff --git a/pkgs/development/ocaml-modules/thread-table/default.nix b/pkgs/development/ocaml-modules/thread-table/default.nix index 155bca397ee691..5caa45f287ca1e 100644 --- a/pkgs/development/ocaml-modules/thread-table/default.nix +++ b/pkgs/development/ocaml-modules/thread-table/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchurl -, buildDunePackage -, alcotest -, mdx +{ + lib, + fetchurl, + buildDunePackage, + alcotest, + mdx, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/timed/default.nix b/pkgs/development/ocaml-modules/timed/default.nix index f3e925f4eefaac..d68f85ca9fb1d3 100644 --- a/pkgs/development/ocaml-modules/timed/default.nix +++ b/pkgs/development/ocaml-modules/timed/default.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildDunePackage +{ + lib, + fetchFromGitHub, + buildDunePackage, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/timedesc/default.nix b/pkgs/development/ocaml-modules/timedesc/default.nix index 9acd69305bee83..5d46988949d0a2 100644 --- a/pkgs/development/ocaml-modules/timedesc/default.nix +++ b/pkgs/development/ocaml-modules/timedesc/default.nix @@ -1,11 +1,12 @@ -{ lib -, fetchurl -, buildDunePackage -, angstrom -, ptime -, seq -, timedesc-tzdb -, timedesc-tzlocal +{ + lib, + fetchurl, + buildDunePackage, + angstrom, + ptime, + seq, + timedesc-tzdb, + timedesc-tzlocal, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/timedesc/tzdb.nix b/pkgs/development/ocaml-modules/timedesc/tzdb.nix index d335ee4c315de3..343327a728d65c 100644 --- a/pkgs/development/ocaml-modules/timedesc/tzdb.nix +++ b/pkgs/development/ocaml-modules/timedesc/tzdb.nix @@ -1,5 +1,6 @@ -{ buildDunePackage -, timedesc +{ + buildDunePackage, + timedesc, }: buildDunePackage { @@ -11,4 +12,3 @@ buildDunePackage { description = "Virtual library for Timedesc time zone database backends"; }; } - diff --git a/pkgs/development/ocaml-modules/timedesc/tzlocal.nix b/pkgs/development/ocaml-modules/timedesc/tzlocal.nix index 780ba7f8bda2da..5d4cabd3b4936c 100644 --- a/pkgs/development/ocaml-modules/timedesc/tzlocal.nix +++ b/pkgs/development/ocaml-modules/timedesc/tzlocal.nix @@ -1,5 +1,6 @@ -{ buildDunePackage -, timedesc +{ + buildDunePackage, + timedesc, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/tiny_httpd/default.nix b/pkgs/development/ocaml-modules/tiny_httpd/default.nix index 2e8e537cba806f..4ea3551aae83a4 100644 --- a/pkgs/development/ocaml-modules/tiny_httpd/default.nix +++ b/pkgs/development/ocaml-modules/tiny_httpd/default.nix @@ -1,6 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitHub -, result -, seq +{ + lib, + buildDunePackage, + fetchFromGitHub, + result, + seq, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/tls/async.nix b/pkgs/development/ocaml-modules/tls/async.nix index ef4f72ec15a9b0..906ec0b83b1428 100644 --- a/pkgs/development/ocaml-modules/tls/async.nix +++ b/pkgs/development/ocaml-modules/tls/async.nix @@ -1,4 +1,11 @@ -{ buildDunePackage, tls, async, cstruct-async, core, mirage-crypto-rng-async }: +{ + buildDunePackage, + tls, + async, + cstruct-async, + core, + mirage-crypto-rng-async, +}: buildDunePackage rec { pname = "tls-async"; diff --git a/pkgs/development/ocaml-modules/tls/default.nix b/pkgs/development/ocaml-modules/tls/default.nix index d4668411989d93..a576d1327925c8 100644 --- a/pkgs/development/ocaml-modules/tls/default.nix +++ b/pkgs/development/ocaml-modules/tls/default.nix @@ -1,7 +1,19 @@ -{ lib, fetchurl, buildDunePackage -, domain-name, fmt, logs, kdf, mirage-crypto, mirage-crypto-ec, mirage-crypto-pk, mirage-crypto-rng, x509 -, ipaddr -, alcotest, ounit2 +{ + lib, + fetchurl, + buildDunePackage, + domain-name, + fmt, + logs, + kdf, + mirage-crypto, + mirage-crypto-ec, + mirage-crypto-pk, + mirage-crypto-rng, + x509, + ipaddr, + alcotest, + ounit2, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/tls/lwt.nix b/pkgs/development/ocaml-modules/tls/lwt.nix index 113a705381caa6..bc201900742d0d 100644 --- a/pkgs/development/ocaml-modules/tls/lwt.nix +++ b/pkgs/development/ocaml-modules/tls/lwt.nix @@ -1,4 +1,9 @@ -{ buildDunePackage, tls, lwt, mirage-crypto-rng-lwt }: +{ + buildDunePackage, + tls, + lwt, + mirage-crypto-rng-lwt, +}: buildDunePackage rec { pname = "tls-lwt"; diff --git a/pkgs/development/ocaml-modules/tls/mirage.nix b/pkgs/development/ocaml-modules/tls/mirage.nix index b302a90aecfd3c..d15ef5ef84f68a 100644 --- a/pkgs/development/ocaml-modules/tls/mirage.nix +++ b/pkgs/development/ocaml-modules/tls/mirage.nix @@ -1,5 +1,14 @@ -{ buildDunePackage, tls -, fmt, lwt, mirage-clock, mirage-crypto, mirage-crypto-pk, mirage-flow, mirage-kv, ptime +{ + buildDunePackage, + tls, + fmt, + lwt, + mirage-clock, + mirage-crypto, + mirage-crypto-pk, + mirage-flow, + mirage-kv, + ptime, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/toml/default.nix b/pkgs/development/ocaml-modules/toml/default.nix index baab042b1bf419..2f7f9b547e0627 100644 --- a/pkgs/development/ocaml-modules/toml/default.nix +++ b/pkgs/development/ocaml-modules/toml/default.nix @@ -1,5 +1,9 @@ -{ lib, fetchFromGitHub, buildDunePackage -, iso8601, menhir +{ + lib, + fetchFromGitHub, + buildDunePackage, + iso8601, + menhir, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/topkg/default.nix b/pkgs/development/ocaml-modules/topkg/default.nix index e0dbc77eafd99d..63ef3447cfe89d 100644 --- a/pkgs/development/ocaml-modules/topkg/default.nix +++ b/pkgs/development/ocaml-modules/topkg/default.nix @@ -1,31 +1,47 @@ -/* Topkg is a packager for distributing OCaml software. This derivation -provides facilities to describe derivations for OCaml libraries -using topkg. -The `buildPhase` and `installPhase` attributes can be reused directly -in many cases. When more fine-grained control on how to run the “topkg” -build system is required, the attribute `run` can be used. +/* + Topkg is a packager for distributing OCaml software. This derivation + provides facilities to describe derivations for OCaml libraries + using topkg. + The `buildPhase` and `installPhase` attributes can be reused directly + in many cases. When more fine-grained control on how to run the “topkg” + build system is required, the attribute `run` can be used. */ -{ stdenv, lib, fetchurl, ocaml, findlib, ocamlbuild, result, opaline }: +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + result, + opaline, +}: let param = - if lib.versionAtLeast ocaml.version "4.05" then { - version = "1.0.7"; - sha256 = "sha256-X8Iq0/OtbRJ8sSRdGFgIgUeNotbeULIxXm3UWGxSvhk="; - } else if lib.versionAtLeast ocaml.version "4.03" then { - version = "1.0.3"; - sha256 = "0b77gsz9bqby8v77kfi4lans47x9p2lmzanzwins5r29maphb8y6"; - } else { - version = "1.0.0"; - sha256 = "1df61vw6v5bg2mys045682ggv058yqkqb67w7r2gz85crs04d5fw"; - propagatedBuildInputs = [ result ]; - }; + if lib.versionAtLeast ocaml.version "4.05" then + { + version = "1.0.7"; + sha256 = "sha256-X8Iq0/OtbRJ8sSRdGFgIgUeNotbeULIxXm3UWGxSvhk="; + } + else if lib.versionAtLeast ocaml.version "4.03" then + { + version = "1.0.3"; + sha256 = "0b77gsz9bqby8v77kfi4lans47x9p2lmzanzwins5r29maphb8y6"; + } + else + { + version = "1.0.0"; + sha256 = "1df61vw6v5bg2mys045682ggv058yqkqb67w7r2gz85crs04d5fw"; + propagatedBuildInputs = [ result ]; + }; -/* This command allows to run the “topkg” build system. - * It is usually called with `build` or `test` as argument. - * Packages that use `topkg` may call this command as part of - * their `buildPhase` or `checkPhase`. -*/ + /* + This command allows to run the “topkg” build system. + It is usually called with `build` or `test` as argument. + Packages that use `topkg` may call this command as part of + their `buildPhase` or `checkPhase`. + */ run = "ocaml -I ${findlib}/lib/ocaml/${ocaml.version}/site-lib/ pkg/pkg.ml"; in @@ -38,8 +54,12 @@ stdenv.mkDerivation rec { inherit (param) sha256; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild ]; - propagatedBuildInputs = param.propagatedBuildInputs or []; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ]; + propagatedBuildInputs = param.propagatedBuildInputs or [ ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/torch/default.nix b/pkgs/development/ocaml-modules/torch/default.nix index 83446cdf0e173c..6ac2867ac1a79d 100644 --- a/pkgs/development/ocaml-modules/torch/default.nix +++ b/pkgs/development/ocaml-modules/torch/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, buildDunePackage -, fetchFromGitHub -, fetchpatch -, cmdliner -, ctypes -, ctypes-foreign -, dune-configurator -, npy -, ocaml-compiler-libs -, ppx_custom_printf -, ppx_expect -, ppx_sexp_conv -, sexplib -, stdio -, torch +{ + lib, + stdenv, + buildDunePackage, + fetchFromGitHub, + fetchpatch, + cmdliner, + ctypes, + ctypes-foreign, + dune-configurator, + npy, + ocaml-compiler-libs, + ppx_custom_printf, + ppx_expect, + ppx_sexp_conv, + sexplib, + stdio, + torch, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/trace/default.nix b/pkgs/development/ocaml-modules/trace/default.nix index 2c7356669860c0..dbc492efee403b 100644 --- a/pkgs/development/ocaml-modules/trace/default.nix +++ b/pkgs/development/ocaml-modules/trace/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, buildDunePackage }: +{ + lib, + fetchurl, + buildDunePackage, +}: buildDunePackage rec { pname = "trace"; diff --git a/pkgs/development/ocaml-modules/trace/tef.nix b/pkgs/development/ocaml-modules/trace/tef.nix index 618009d11fa776..05a8280c2ac12c 100644 --- a/pkgs/development/ocaml-modules/trace/tef.nix +++ b/pkgs/development/ocaml-modules/trace/tef.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, trace, mtime }: +{ + buildDunePackage, + trace, + mtime, +}: buildDunePackage { pname = "trace-tef"; @@ -13,7 +17,10 @@ buildDunePackage { minimalOCamlVersion = "4.12"; - propagatedBuildInputs = [ mtime trace ]; + propagatedBuildInputs = [ + mtime + trace + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/trie/default.nix b/pkgs/development/ocaml-modules/trie/default.nix index 935f71a5e22459..f0101bb7313977 100644 --- a/pkgs/development/ocaml-modules/trie/default.nix +++ b/pkgs/development/ocaml-modules/trie/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchFromGitHub }: +{ + lib, + buildDunePackage, + fetchFromGitHub, +}: buildDunePackage rec { pname = "trie"; diff --git a/pkgs/development/ocaml-modules/tsdl-image/default.nix b/pkgs/development/ocaml-modules/tsdl-image/default.nix index cc9404ed193e20..8ee97c9aa4ddd1 100644 --- a/pkgs/development/ocaml-modules/tsdl-image/default.nix +++ b/pkgs/development/ocaml-modules/tsdl-image/default.nix @@ -1,10 +1,11 @@ -{ buildDunePackage -, dune-configurator -, fetchFromGitHub -, lib -, SDL2 -, SDL2_image -, tsdl +{ + buildDunePackage, + dune-configurator, + fetchFromGitHub, + lib, + SDL2, + SDL2_image, + tsdl, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/tsdl-mixer/default.nix b/pkgs/development/ocaml-modules/tsdl-mixer/default.nix index 4e5aa3650b161a..fbe0f16ff0c933 100644 --- a/pkgs/development/ocaml-modules/tsdl-mixer/default.nix +++ b/pkgs/development/ocaml-modules/tsdl-mixer/default.nix @@ -1,10 +1,11 @@ -{ buildDunePackage -, dune-configurator -, fetchFromGitHub -, lib -, SDL2 -, SDL2_mixer -, tsdl +{ + buildDunePackage, + dune-configurator, + fetchFromGitHub, + lib, + SDL2, + SDL2_mixer, + tsdl, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/tsdl-ttf/default.nix b/pkgs/development/ocaml-modules/tsdl-ttf/default.nix index 33f5f834e01aa0..17b5e2006b0c62 100644 --- a/pkgs/development/ocaml-modules/tsdl-ttf/default.nix +++ b/pkgs/development/ocaml-modules/tsdl-ttf/default.nix @@ -1,10 +1,11 @@ -{ buildDunePackage -, dune-configurator -, fetchFromGitHub -, lib -, SDL2 -, SDL2_ttf -, tsdl +{ + buildDunePackage, + dune-configurator, + fetchFromGitHub, + lib, + SDL2, + SDL2_ttf, + tsdl, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/tsdl/default.nix b/pkgs/development/ocaml-modules/tsdl/default.nix index 0e4b1cf83e2c21..e57ebcb844793f 100644 --- a/pkgs/development/ocaml-modules/tsdl/default.nix +++ b/pkgs/development/ocaml-modules/tsdl/default.nix @@ -1,47 +1,81 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, ocamlbuild, topkg, ctypes, ctypes-foreign, result, SDL2, pkg-config -, AudioToolbox, Cocoa, CoreAudio, CoreVideo, ForceFeedback }: +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + ctypes, + ctypes-foreign, + result, + SDL2, + pkg-config, + AudioToolbox, + Cocoa, + CoreAudio, + CoreVideo, + ForceFeedback, +}: -if lib.versionOlder ocaml.version "4.03" -then throw "tsdl is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.03" then + throw "tsdl is not available for OCaml ${ocaml.version}" else -let - pname = "tsdl"; - version = "1.1.0"; - webpage = "https://erratique.ch/software/${pname}"; -in - -stdenv.mkDerivation { - pname = "ocaml${ocaml.version}-${pname}"; - inherit version; - - src = fetchurl { - url = "${webpage}/releases/${pname}-${version}.tbz"; - hash = "sha256-ZN4+trqesU1IREKcwm1Ro37jszKG8XcVigoE4BdGhzs="; - }; - - strictDeps = true; - - nativeBuildInputs = [ pkg-config ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg ]; - propagatedBuildInputs = [ SDL2 ctypes ctypes-foreign ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ AudioToolbox Cocoa CoreAudio CoreVideo ForceFeedback ]; - - preConfigure = '' - # The following is done to avoid an additional dependency (ncurses) - # due to linking in the custom bytecode runtime. Instead, just - # compile directly into a native binary, even if it's just a - # temporary build product. - substituteInPlace myocamlbuild.ml \ - --replace ".byte" ".native" - ''; - - inherit (topkg) buildPhase installPhase; - - meta = with lib; { - homepage = webpage; - description = "Thin bindings to the cross-platform SDL library"; - license = licenses.isc; - inherit (ocaml.meta) platforms; - }; -} + let + pname = "tsdl"; + version = "1.1.0"; + webpage = "https://erratique.ch/software/${pname}"; + in + + stdenv.mkDerivation { + pname = "ocaml${ocaml.version}-${pname}"; + inherit version; + + src = fetchurl { + url = "${webpage}/releases/${pname}-${version}.tbz"; + hash = "sha256-ZN4+trqesU1IREKcwm1Ro37jszKG8XcVigoE4BdGhzs="; + }; + + strictDeps = true; + + nativeBuildInputs = [ + pkg-config + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ topkg ]; + propagatedBuildInputs = + [ + SDL2 + ctypes + ctypes-foreign + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AudioToolbox + Cocoa + CoreAudio + CoreVideo + ForceFeedback + ]; + + preConfigure = '' + # The following is done to avoid an additional dependency (ncurses) + # due to linking in the custom bytecode runtime. Instead, just + # compile directly into a native binary, even if it's just a + # temporary build product. + substituteInPlace myocamlbuild.ml \ + --replace ".byte" ".native" + ''; + + inherit (topkg) buildPhase installPhase; + + meta = with lib; { + homepage = webpage; + description = "Thin bindings to the cross-platform SDL library"; + license = licenses.isc; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/tsort/default.nix b/pkgs/development/ocaml-modules/tsort/default.nix index 1e40488080a830..e026ecb27ffc85 100644 --- a/pkgs/development/ocaml-modules/tsort/default.nix +++ b/pkgs/development/ocaml-modules/tsort/default.nix @@ -1,4 +1,9 @@ -{ lib, buildDunePackage, fetchFromGitHub, containers }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + containers, +}: buildDunePackage rec { pname = "tsort"; diff --git a/pkgs/development/ocaml-modules/tty/default.nix b/pkgs/development/ocaml-modules/tty/default.nix index 649973df578be7..be90526c91908a 100644 --- a/pkgs/development/ocaml-modules/tty/default.nix +++ b/pkgs/development/ocaml-modules/tty/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildDunePackage -, fetchurl -, uutf +{ + lib, + buildDunePackage, + fetchurl, + uutf, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/tuntap/default.nix b/pkgs/development/ocaml-modules/tuntap/default.nix index e5db86d7fee4f3..d1d2579e39df4c 100644 --- a/pkgs/development/ocaml-modules/tuntap/default.nix +++ b/pkgs/development/ocaml-modules/tuntap/default.nix @@ -1,5 +1,10 @@ -{ lib, buildDunePackage, fetchurl -, ipaddr, macaddr, cmdliner +{ + lib, + buildDunePackage, + fetchurl, + ipaddr, + macaddr, + cmdliner, }: buildDunePackage rec { @@ -15,7 +20,11 @@ buildDunePackage rec { sha256 = "12wmls28h3jzikwyfw08d5f7ycsc9njwzbhd3qk2l8jnf5rakfsa"; }; - propagatedBuildInputs = [ ipaddr macaddr cmdliner ]; + propagatedBuildInputs = [ + ipaddr + macaddr + cmdliner + ]; # tests manipulate network devices and use network # also depend on LWT 5 diff --git a/pkgs/development/ocaml-modules/twt/default.nix b/pkgs/development/ocaml-modules/twt/default.nix index 069cacb34079ad..ef5fae48b37c78 100644 --- a/pkgs/development/ocaml-modules/twt/default.nix +++ b/pkgs/development/ocaml-modules/twt/default.nix @@ -1,40 +1,50 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, findlib }: +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, +}: lib.throwIf (lib.versionAtLeast ocaml.version "5.0") "twt is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-twt"; - version = "0.94.0"; - - src = fetchFromGitHub { - owner = "mlin"; - repo = "twt"; - rev = "v${version}"; - sha256 = "sha256-xbjLPd7P1KyuC3i6WHLBcdLwd14atcBsd5ER+l97KAk="; - }; - - nativeBuildInputs = [ ocaml findlib ]; - - strictDeps = true; - - preInstall = '' - mkdir -p $out/bin - mkdir -p $OCAMLFIND_DESTDIR - ''; - - dontBuild = true; - - installFlags = [ "PREFIX=$(out)" ]; - - dontStrip = true; - - meta = with lib; { - description = "“The Whitespace Thing” for OCaml"; - homepage = "http://people.csail.mit.edu/mikelin/ocaml+twt/"; - license = licenses.mit; - maintainers = [ maintainers.vbgl ]; - mainProgram = "ocaml+twt"; - inherit (ocaml.meta) platforms; - }; -} + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-twt"; + version = "0.94.0"; + + src = fetchFromGitHub { + owner = "mlin"; + repo = "twt"; + rev = "v${version}"; + sha256 = "sha256-xbjLPd7P1KyuC3i6WHLBcdLwd14atcBsd5ER+l97KAk="; + }; + + nativeBuildInputs = [ + ocaml + findlib + ]; + + strictDeps = true; + + preInstall = '' + mkdir -p $out/bin + mkdir -p $OCAMLFIND_DESTDIR + ''; + + dontBuild = true; + + installFlags = [ "PREFIX=$(out)" ]; + + dontStrip = true; + + meta = with lib; { + description = "“The Whitespace Thing” for OCaml"; + homepage = "http://people.csail.mit.edu/mikelin/ocaml+twt/"; + license = licenses.mit; + maintainers = [ maintainers.vbgl ]; + mainProgram = "ocaml+twt"; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/type_eq/default.nix b/pkgs/development/ocaml-modules/type_eq/default.nix index a1426789e3db5a..bdec535d07945e 100644 --- a/pkgs/development/ocaml-modules/type_eq/default.nix +++ b/pkgs/development/ocaml-modules/type_eq/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildDunePackage -, fetchurl -, alcotest +{ + lib, + buildDunePackage, + fetchurl, + alcotest, }: buildDunePackage rec { @@ -29,4 +30,3 @@ buildDunePackage rec { maintainers = with lib.maintainers; [ sixstring982 ]; }; } - diff --git a/pkgs/development/ocaml-modules/type_id/default.nix b/pkgs/development/ocaml-modules/type_id/default.nix index 6ecca71927aa74..baca40db32b039 100644 --- a/pkgs/development/ocaml-modules/type_id/default.nix +++ b/pkgs/development/ocaml-modules/type_id/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildDunePackage -, fetchurl -, alcotest -, type_eq +{ + lib, + buildDunePackage, + fetchurl, + alcotest, + type_eq, }: buildDunePackage rec { @@ -20,7 +21,6 @@ buildDunePackage rec { type_eq ]; - checkInputs = [ alcotest ]; @@ -35,4 +35,3 @@ buildDunePackage rec { maintainers = with lib.maintainers; [ sixstring982 ]; }; } - diff --git a/pkgs/development/ocaml-modules/tyxml/default.nix b/pkgs/development/ocaml-modules/tyxml/default.nix index d58cee2cad3c0f..5d1b6423e7cfec 100644 --- a/pkgs/development/ocaml-modules/tyxml/default.nix +++ b/pkgs/development/ocaml-modules/tyxml/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchurl, re, uutf }: +{ + lib, + buildDunePackage, + fetchurl, + re, + uutf, +}: buildDunePackage rec { pname = "tyxml"; @@ -9,14 +15,18 @@ buildDunePackage rec { hash = "sha256-v+tnPGtOEgpOykxIRIrdR9w/jQLCtA9j/9zMTpHJAt0="; }; - propagatedBuildInputs = [ uutf re ]; + propagatedBuildInputs = [ + uutf + re + ]; meta = with lib; { homepage = "http://ocsigen.org/tyxml/"; description = "Library that makes it almost impossible for your OCaml programs to generate wrong XML output, using static typing"; license = licenses.lgpl21; maintainers = with maintainers; [ - gal_bolle vbgl + gal_bolle + vbgl ]; }; diff --git a/pkgs/development/ocaml-modules/uchar/default.nix b/pkgs/development/ocaml-modules/uchar/default.nix index 09004e8a94388a..20162813c3cc29 100644 --- a/pkgs/development/ocaml-modules/uchar/default.nix +++ b/pkgs/development/ocaml-modules/uchar/default.nix @@ -1,4 +1,13 @@ -{ stdenv, fetchurl, ocaml, findlib, ocamlbuild, opaline, withShared ? true, lib }: +{ + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + opaline, + withShared ? true, + lib, +}: stdenv.mkDerivation rec { pname = "ocaml${ocaml.version}-uchar"; @@ -9,7 +18,11 @@ stdenv.mkDerivation rec { sha256 = "1w2saw7zanf9m9ffvz2lvcxvlm118pws2x1wym526xmydhqpyfa7"; }; - nativeBuildInputs = [ ocaml ocamlbuild findlib ]; + nativeBuildInputs = [ + ocaml + ocamlbuild + findlib + ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/uecc/default.nix b/pkgs/development/ocaml-modules/uecc/default.nix index 1185977132dd5f..e9bdc340647ae3 100644 --- a/pkgs/development/ocaml-modules/uecc/default.nix +++ b/pkgs/development/ocaml-modules/uecc/default.nix @@ -1,4 +1,13 @@ -{ lib, fetchFromGitLab, buildDunePackage, ocaml, bigstring, alcotest, cstruct, hex }: +{ + lib, + fetchFromGitLab, + buildDunePackage, + ocaml, + bigstring, + alcotest, + cstruct, + hex, +}: buildDunePackage rec { pname = "uecc"; diff --git a/pkgs/development/ocaml-modules/ulex/default.nix b/pkgs/development/ocaml-modules/ulex/default.nix index 910d75dcdc2bbe..bbc26d8650f8f9 100644 --- a/pkgs/development/ocaml-modules/ulex/default.nix +++ b/pkgs/development/ocaml-modules/ulex/default.nix @@ -1,15 +1,26 @@ -{ stdenv, lib, fetchFromGitHub, ocaml, findlib, ocamlbuild, camlp4 }: +{ + stdenv, + lib, + fetchFromGitHub, + ocaml, + findlib, + ocamlbuild, + camlp4, +}: let pname = "ulex"; param = - if lib.versionAtLeast ocaml.version "4.02" then { - version = "1.2"; - sha256 = "08yf2x9a52l2y4savjqfjd2xy4pjd1rpla2ylrr9qrz1drpfw4ic"; - } else { - version = "1.1"; - sha256 = "0cmscxcmcxhlshh4jd0lzw5ffzns12x3bj7h27smbc8waxkwffhl"; - }; + if lib.versionAtLeast ocaml.version "4.02" then + { + version = "1.2"; + sha256 = "08yf2x9a52l2y4savjqfjd2xy4pjd1rpla2ylrr9qrz1drpfw4ic"; + } + else + { + version = "1.1"; + sha256 = "0cmscxcmcxhlshh4jd0lzw5ffzns12x3bj7h27smbc8waxkwffhl"; + }; in stdenv.mkDerivation rec { @@ -25,12 +36,20 @@ stdenv.mkDerivation rec { createFindlibDestdir = true; - nativeBuildInputs = [ ocaml findlib ocamlbuild camlp4 ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + camlp4 + ]; propagatedBuildInputs = [ camlp4 ]; strictDeps = true; - buildFlags = [ "all" "all.opt" ]; + buildFlags = [ + "all" + "all.opt" + ]; meta = { inherit (src.meta) homepage; diff --git a/pkgs/development/ocaml-modules/unionFind/default.nix b/pkgs/development/ocaml-modules/unionFind/default.nix index aa1d5e82362bc6..3e374acfe6c228 100644 --- a/pkgs/development/ocaml-modules/unionFind/default.nix +++ b/pkgs/development/ocaml-modules/unionFind/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitLab, buildDunePackage }: +{ + lib, + fetchFromGitLab, + buildDunePackage, +}: buildDunePackage rec { pname = "unionFind"; diff --git a/pkgs/development/ocaml-modules/unisim_archisec/default.nix b/pkgs/development/ocaml-modules/unisim_archisec/default.nix index f29ea64f4f101f..1c587c7f4f2f48 100644 --- a/pkgs/development/ocaml-modules/unisim_archisec/default.nix +++ b/pkgs/development/ocaml-modules/unisim_archisec/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "unisim_archisec"; diff --git a/pkgs/development/ocaml-modules/unix-errno/default.nix b/pkgs/development/ocaml-modules/unix-errno/default.nix index d869748ecb5008..5a6ce57cc62a8a 100644 --- a/pkgs/development/ocaml-modules/unix-errno/default.nix +++ b/pkgs/development/ocaml-modules/unix-errno/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchurl, ctypes, integers, result }: +{ + lib, + buildDunePackage, + fetchurl, + ctypes, + integers, + result, +}: buildDunePackage rec { pname = "unix-errno"; @@ -11,12 +18,19 @@ buildDunePackage rec { sha256 = "sha256-LWqbyGcxs6f/FcOPo3JYR3U+AL0JHeWCiGjuYhxxrWU="; }; - propagatedBuildInputs = [ ctypes integers result ]; + propagatedBuildInputs = [ + ctypes + integers + result + ]; meta = with lib; { homepage = "https://github.com/xapi-project/ocaml-unix-errno"; # This is the repo used in the opam package description = "Unix errno types, maps, and support for OCaml"; - license = with licenses; [ isc lgpl21Only ]; # All the files indicate ISC, but there's an LGPL LICENSE file + license = with licenses; [ + isc + lgpl21Only + ]; # All the files indicate ISC, but there's an LGPL LICENSE file maintainers = with maintainers; [ dandellion ]; }; } diff --git a/pkgs/development/ocaml-modules/unstrctrd/default.nix b/pkgs/development/ocaml-modules/unstrctrd/default.nix index e5959f803c8f9a..1426a68f14d353 100644 --- a/pkgs/development/ocaml-modules/unstrctrd/default.nix +++ b/pkgs/development/ocaml-modules/unstrctrd/default.nix @@ -1,15 +1,16 @@ -{ alcotest -, angstrom -, bigstringaf -, buildDunePackage -, crowbar -, fetchzip -, fmt -, hxd -, ke -, lib -, rresult -, uutf +{ + alcotest, + angstrom, + bigstringaf, + buildDunePackage, + crowbar, + fetchzip, + fmt, + hxd, + ke, + lib, + rresult, + uutf, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/uri/default.nix b/pkgs/development/ocaml-modules/uri/default.nix index f8e8efdaae6780..86185efcab6aac 100644 --- a/pkgs/development/ocaml-modules/uri/default.nix +++ b/pkgs/development/ocaml-modules/uri/default.nix @@ -1,5 +1,10 @@ -{ lib, fetchurl, buildDunePackage, ounit -, angstrom, stringext +{ + lib, + fetchurl, + buildDunePackage, + ounit, + angstrom, + stringext, }: buildDunePackage rec { @@ -15,7 +20,10 @@ buildDunePackage rec { }; checkInputs = [ ounit ]; - propagatedBuildInputs = [ angstrom stringext ]; + propagatedBuildInputs = [ + angstrom + stringext + ]; doCheck = true; meta = { diff --git a/pkgs/development/ocaml-modules/uri/sexp.nix b/pkgs/development/ocaml-modules/uri/sexp.nix index 61aa01fad8ba55..df54c7636c7390 100644 --- a/pkgs/development/ocaml-modules/uri/sexp.nix +++ b/pkgs/development/ocaml-modules/uri/sexp.nix @@ -1,16 +1,28 @@ -{ lib, ocaml, buildDunePackage, uri, ounit, ppx_sexp_conv, sexplib0 }: +{ + lib, + ocaml, + buildDunePackage, + uri, + ounit, + ppx_sexp_conv, + sexplib0, +}: -if lib.versionOlder ocaml.version "4.04" -then throw "uri-sexp is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.04" then + throw "uri-sexp is not available for OCaml ${ocaml.version}" else -buildDunePackage { - pname = "uri-sexp"; - inherit (uri) version src meta; + buildDunePackage { + pname = "uri-sexp"; + inherit (uri) version src meta; - duneVersion = "3"; + duneVersion = "3"; - checkInputs = [ ounit ]; - propagatedBuildInputs = [ ppx_sexp_conv sexplib0 uri ]; - doCheck = lib.versionAtLeast ocaml.version "4.08"; -} + checkInputs = [ ounit ]; + propagatedBuildInputs = [ + ppx_sexp_conv + sexplib0 + uri + ]; + doCheck = lib.versionAtLeast ocaml.version "4.08"; + } diff --git a/pkgs/development/ocaml-modules/uring/default.nix b/pkgs/development/ocaml-modules/uring/default.nix index 46867bf954d9f7..7ab261c06e1291 100644 --- a/pkgs/development/ocaml-modules/uring/default.nix +++ b/pkgs/development/ocaml-modules/uring/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildDunePackage -, cstruct -, dune-configurator -, fetchurl -, fmt -, optint -, mdx +{ + lib, + buildDunePackage, + cstruct, + dune-configurator, + fetchurl, + fmt, + optint, + mdx, }: buildDunePackage rec { @@ -47,7 +48,10 @@ buildDunePackage rec { homepage = "https://github.com/ocaml-multicore/ocaml-${pname}"; changelog = "https://github.com/ocaml-multicore/ocaml-${pname}/raw/v${version}/CHANGES.md"; description = "Bindings to io_uring for OCaml"; - license = with lib.licenses; [ isc mit ]; + license = with lib.licenses; [ + isc + mit + ]; platforms = lib.platforms.linux; maintainers = with lib.maintainers; [ toastal ]; }; diff --git a/pkgs/development/ocaml-modules/uucd/default.nix b/pkgs/development/ocaml-modules/uucd/default.nix index d350071304c0da..405afe47c6cdf8 100644 --- a/pkgs/development/ocaml-modules/uucd/default.nix +++ b/pkgs/development/ocaml-modules/uucd/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, ocamlbuild, xmlm, topkg }: +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + xmlm, + topkg, +}: let pname = "uucd"; @@ -13,7 +22,12 @@ stdenv.mkDerivation rec { hash = "sha256-VVGPG6ZjchUqo8xMCJRahqCCF5WheDBpK1stuts+orM="; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; buildInputs = [ topkg ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/uucp/default.nix b/pkgs/development/ocaml-modules/uucp/default.nix index 10b4cc4ff4e6d6..c1aeeeff5262ba 100644 --- a/pkgs/development/ocaml-modules/uucp/default.nix +++ b/pkgs/development/ocaml-modules/uucp/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, ocamlbuild, topkg, uchar, uutf, uunf, uucd }: +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + uchar, + uutf, + uunf, + uucd, +}: let pname = "uucp"; @@ -8,47 +20,57 @@ let doCheck = true; in -if lib.versionOlder ocaml.version minimalOCamlVersion -then builtins.throw "${pname} needs at least OCaml ${minimalOCamlVersion}" +if lib.versionOlder ocaml.version minimalOCamlVersion then + builtins.throw "${pname} needs at least OCaml ${minimalOCamlVersion}" else -stdenv.mkDerivation { + stdenv.mkDerivation { - name = "ocaml${ocaml.version}-${pname}-${version}"; + name = "ocaml${ocaml.version}-${pname}-${version}"; - src = fetchurl { - url = "${webpage}/releases/${pname}-${version}.tbz"; - hash = "sha256-5//UGI4u3OROYdxtwz9K2vCTzYiN16mOyEFhUQWtgEQ="; - }; + src = fetchurl { + url = "${webpage}/releases/${pname}-${version}.tbz"; + hash = "sha256-5//UGI4u3OROYdxtwz9K2vCTzYiN16mOyEFhUQWtgEQ="; + }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg uutf uunf uucd ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ + topkg + uutf + uunf + uucd + ]; - propagatedBuildInputs = [ uchar ]; + propagatedBuildInputs = [ uchar ]; - strictDeps = true; + strictDeps = true; - buildPhase = '' - runHook preBuild - ${topkg.buildPhase} --with-cmdliner false --tests ${lib.boolToString doCheck} - runHook postBuild - ''; + buildPhase = '' + runHook preBuild + ${topkg.buildPhase} --with-cmdliner false --tests ${lib.boolToString doCheck} + runHook postBuild + ''; - inherit (topkg) installPhase; + inherit (topkg) installPhase; - inherit doCheck; - checkPhase = '' - runHook preCheck - ${topkg.run} test - runHook postCheck - ''; - checkInputs = [ uucd ]; + inherit doCheck; + checkPhase = '' + runHook preCheck + ${topkg.run} test + runHook postCheck + ''; + checkInputs = [ uucd ]; - meta = with lib; { - description = "OCaml library providing efficient access to a selection of character properties of the Unicode character database"; - homepage = webpage; - inherit (ocaml.meta) platforms; - license = licenses.bsd3; - maintainers = [ maintainers.vbgl ]; - }; -} + meta = with lib; { + description = "OCaml library providing efficient access to a selection of character properties of the Unicode character database"; + homepage = webpage; + inherit (ocaml.meta) platforms; + license = licenses.bsd3; + maintainers = [ maintainers.vbgl ]; + }; + } diff --git a/pkgs/development/ocaml-modules/uuidm/default.nix b/pkgs/development/ocaml-modules/uuidm/default.nix index cf354c5e898d48..7c389f87f651e7 100644 --- a/pkgs/development/ocaml-modules/uuidm/default.nix +++ b/pkgs/development/ocaml-modules/uuidm/default.nix @@ -1,35 +1,54 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, ocamlbuild, topkg, cmdliner -, version ? if lib.versionAtLeast ocaml.version "4.14" then "0.9.9" else "0.9.8" +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + cmdliner, + version ? if lib.versionAtLeast ocaml.version "4.14" then "0.9.9" else "0.9.8", }: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.08") "uuidm is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation { - inherit version; - pname = "uuidm"; - src = fetchurl { - url = "https://erratique.ch/software/uuidm/releases/uuidm-${version}.tbz"; - hash = { - "0.9.9" = "sha256-jOgNF05dpoU/XQEefSZhn3zSlQ1BA1b/U4Ib9j2mvFo="; - "0.9.8" = "sha256-/GZbkJVDQu1UY8SliK282kUWAVMfOnpQadUlRT/tJrM="; - }."${version}"; - }; + stdenv.mkDerivation + { + inherit version; + pname = "uuidm"; + src = fetchurl { + url = "https://erratique.ch/software/uuidm/releases/uuidm-${version}.tbz"; + hash = + { + "0.9.9" = "sha256-jOgNF05dpoU/XQEefSZhn3zSlQ1BA1b/U4Ib9j2mvFo="; + "0.9.8" = "sha256-/GZbkJVDQu1UY8SliK282kUWAVMfOnpQadUlRT/tJrM="; + } + ."${version}"; + }; - strictDeps = true; + strictDeps = true; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - configurePlatforms = []; - buildInputs = [ topkg cmdliner ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + configurePlatforms = [ ]; + buildInputs = [ + topkg + cmdliner + ]; - inherit (topkg) buildPhase installPhase; + inherit (topkg) buildPhase installPhase; - meta = with lib; { - description = "OCaml module implementing 128 bits universally unique identifiers version 3, 5 (name based with MD5, SHA-1 hashing) and 4 (random based) according to RFC 4122"; - homepage = "https://erratique.ch/software/uuidm"; - license = licenses.bsd3; - maintainers = [ maintainers.maurer ]; - mainProgram = "uuidtrip"; - inherit (ocaml.meta) platforms; - }; -} + meta = with lib; { + description = "OCaml module implementing 128 bits universally unique identifiers version 3, 5 (name based with MD5, SHA-1 hashing) and 4 (random based) according to RFC 4122"; + homepage = "https://erratique.ch/software/uuidm"; + license = licenses.bsd3; + maintainers = [ maintainers.maurer ]; + mainProgram = "uuidtrip"; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/uunf/default.nix b/pkgs/development/ocaml-modules/uunf/default.nix index ae2d8d6c2987e7..f51dc88eeb7b8f 100644 --- a/pkgs/development/ocaml-modules/uunf/default.nix +++ b/pkgs/development/ocaml-modules/uunf/default.nix @@ -1,54 +1,72 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, ocamlbuild, topkg, uutf, cmdliner -, cmdlinerSupport ? lib.versionAtLeast cmdliner.version "1.1" -, version ? if lib.versionAtLeast ocaml.version "4.14" then "16.0.0" else "15.0.0" +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + uutf, + cmdliner, + cmdlinerSupport ? lib.versionAtLeast cmdliner.version "1.1", + version ? if lib.versionAtLeast ocaml.version "4.14" then "16.0.0" else "15.0.0", }: let pname = "uunf"; webpage = "https://erratique.ch/software/${pname}"; - hash = { - "15.0.0" = "sha256-B/prPAwfqS8ZPS3fyDDIzXWRbKofwOCyCfwvh9veuug="; - "16.0.0" = "sha256-iQNkT1av6ONJXn3yWbNbEVV8lKGYOKh/nPU0tkUdX64="; - }."${version}"; + hash = + { + "15.0.0" = "sha256-B/prPAwfqS8ZPS3fyDDIzXWRbKofwOCyCfwvh9veuug="; + "16.0.0" = "sha256-iQNkT1av6ONJXn3yWbNbEVV8lKGYOKh/nPU0tkUdX64="; + } + ."${version}"; in -if lib.versionOlder ocaml.version "4.03" -then throw "${pname} is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.03" then + throw "${pname} is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation { - name = "ocaml${ocaml.version}-${pname}-${version}"; - inherit version; - - src = fetchurl { - url = "${webpage}/releases/${pname}-${version}.tbz"; - inherit hash; - }; - - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg uutf ] - ++ lib.optional cmdlinerSupport cmdliner; - - strictDeps = true; - - prePatch = lib.optionalString stdenv.hostPlatform.isAarch64 "ulimit -s 16384"; - - buildPhase = '' - runHook preBuild - ${topkg.run} build \ - --with-uutf true \ - --with-cmdliner ${lib.boolToString cmdlinerSupport} - runHook postBuild - ''; - - inherit (topkg) installPhase; - - meta = with lib; { - description = "OCaml module for normalizing Unicode text"; - homepage = webpage; - license = licenses.bsd3; - maintainers = [ maintainers.vbgl ]; - mainProgram = "unftrip"; - inherit (ocaml.meta) platforms; - }; -} + stdenv.mkDerivation { + name = "ocaml${ocaml.version}-${pname}-${version}"; + inherit version; + + src = fetchurl { + url = "${webpage}/releases/${pname}-${version}.tbz"; + inherit hash; + }; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ + topkg + uutf + ] ++ lib.optional cmdlinerSupport cmdliner; + + strictDeps = true; + + prePatch = lib.optionalString stdenv.hostPlatform.isAarch64 "ulimit -s 16384"; + + buildPhase = '' + runHook preBuild + ${topkg.run} build \ + --with-uutf true \ + --with-cmdliner ${lib.boolToString cmdlinerSupport} + runHook postBuild + ''; + + inherit (topkg) installPhase; + + meta = with lib; { + description = "OCaml module for normalizing Unicode text"; + homepage = webpage; + license = licenses.bsd3; + maintainers = [ maintainers.vbgl ]; + mainProgram = "unftrip"; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/uuseg/default.nix b/pkgs/development/ocaml-modules/uuseg/default.nix index 44a58ab49a59c7..85442fc47eac8b 100644 --- a/pkgs/development/ocaml-modules/uuseg/default.nix +++ b/pkgs/development/ocaml-modules/uuseg/default.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, ocamlbuild, topkg, uucp, uutf, cmdliner -, version ? if lib.versionAtLeast ocaml.version "4.14" then "16.0.0" else "15.0.0" -, cmdlinerSupport ? lib.versionAtLeast cmdliner.version "1.1" +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + uucp, + uutf, + cmdliner, + version ? if lib.versionAtLeast ocaml.version "4.14" then "16.0.0" else "15.0.0", + cmdlinerSupport ? lib.versionAtLeast cmdliner.version "1.1", }: let @@ -15,15 +25,24 @@ stdenv.mkDerivation rec { src = fetchurl { url = "${webpage}/releases/${pname}-${version}.tbz"; - hash = { - "16.0.0" = "sha256-WAP9uyofhtw6ag6/U4GQAanIFoKWvyA4NgeVweTs/iQ="; - "15.0.0" = "sha256-q8x3bia1QaKpzrWFxUmLWIraKqby7TuPNGvbSjkY4eM="; - }."${version}"; + hash = + { + "16.0.0" = "sha256-WAP9uyofhtw6ag6/U4GQAanIFoKWvyA4NgeVweTs/iQ="; + "15.0.0" = "sha256-q8x3bia1QaKpzrWFxUmLWIraKqby7TuPNGvbSjkY4eM="; + } + ."${version}"; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg uutf ] - ++ lib.optional cmdlinerSupport cmdliner; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ + topkg + uutf + ] ++ lib.optional cmdlinerSupport cmdliner; propagatedBuildInputs = [ uucp ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/uutf/default.nix b/pkgs/development/ocaml-modules/uutf/default.nix index 62ac1fc7c1c004..0908650560b8f0 100644 --- a/pkgs/development/ocaml-modules/uutf/default.nix +++ b/pkgs/development/ocaml-modules/uutf/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, ocamlbuild, cmdliner , topkg, uchar }: +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + cmdliner, + topkg, + uchar, +}: let pname = "uutf"; in @@ -6,29 +16,38 @@ in lib.throwIfNot (lib.versionAtLeast ocaml.version "4.03") "${pname} is not available with OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - name = "ocaml${ocaml.version}-${pname}-${version}"; - version = "1.0.3"; + stdenv.mkDerivation + rec { + name = "ocaml${ocaml.version}-${pname}-${version}"; + version = "1.0.3"; - src = fetchurl { - url = "https://erratique.ch/software/${pname}/releases/${pname}-${version}.tbz"; - sha256 = "sha256-h3KlYT0ecCmM4U3zMkGjaF8h5O9r20zwP+mF+x7KBWg="; - }; + src = fetchurl { + url = "https://erratique.ch/software/${pname}/releases/${pname}-${version}.tbz"; + sha256 = "sha256-h3KlYT0ecCmM4U3zMkGjaF8h5O9r20zwP+mF+x7KBWg="; + }; - nativeBuildInputs = [ ocaml ocamlbuild findlib topkg ]; - buildInputs = [ topkg cmdliner ]; - propagatedBuildInputs = [ uchar ]; + nativeBuildInputs = [ + ocaml + ocamlbuild + findlib + topkg + ]; + buildInputs = [ + topkg + cmdliner + ]; + propagatedBuildInputs = [ uchar ]; - strictDeps = true; + strictDeps = true; - inherit (topkg) buildPhase installPhase; + inherit (topkg) buildPhase installPhase; - meta = with lib; { - description = "Non-blocking streaming Unicode codec for OCaml"; - homepage = "https://erratique.ch/software/uutf"; - license = licenses.bsd3; - maintainers = [ maintainers.vbgl ]; - mainProgram = "utftrip"; - inherit (ocaml.meta) platforms; - }; -} + meta = with lib; { + description = "Non-blocking streaming Unicode codec for OCaml"; + homepage = "https://erratique.ch/software/uutf"; + license = licenses.bsd3; + maintainers = [ maintainers.vbgl ]; + mainProgram = "utftrip"; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/uuuu/default.nix b/pkgs/development/ocaml-modules/uuuu/default.nix index 6f0312cfb61a66..8965114543e7b9 100644 --- a/pkgs/development/ocaml-modules/uuuu/default.nix +++ b/pkgs/development/ocaml-modules/uuuu/default.nix @@ -1,10 +1,11 @@ -{ angstrom -, buildDunePackage -, fetchurl -, findlib -, lib -, ocaml -, re +{ + angstrom, + buildDunePackage, + fetchurl, + findlib, + lib, + ocaml, + re, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/vchan/default.nix b/pkgs/development/ocaml-modules/vchan/default.nix index 51aae9b59b345a..fa47958ab4d22a 100644 --- a/pkgs/development/ocaml-modules/vchan/default.nix +++ b/pkgs/development/ocaml-modules/vchan/default.nix @@ -1,6 +1,14 @@ -{ lib, buildDunePackage, fetchurl -, ounit2 -, lwt, cstruct, io-page, mirage-flow, xenstore, xenstore_transport +{ + lib, + buildDunePackage, + fetchurl, + ounit2, + lwt, + cstruct, + io-page, + mirage-flow, + xenstore, + xenstore_transport, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/vector/default.nix b/pkgs/development/ocaml-modules/vector/default.nix index c5f4336bb833aa..e2c3240697bf22 100644 --- a/pkgs/development/ocaml-modules/vector/default.nix +++ b/pkgs/development/ocaml-modules/vector/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, fetchurl }: +{ + lib, + buildDunePackage, + fetchurl, +}: buildDunePackage rec { pname = "vector"; diff --git a/pkgs/development/ocaml-modules/vg/default.nix b/pkgs/development/ocaml-modules/vg/default.nix index 410e356be797d1..2fb3c2857816b3 100644 --- a/pkgs/development/ocaml-modules/vg/default.nix +++ b/pkgs/development/ocaml-modules/vg/default.nix @@ -1,8 +1,20 @@ -{ stdenv, lib, fetchurl, ocaml, findlib, ocamlbuild, topkg -, uchar, result, gg, uutf, otfm -, js_of_ocaml, js_of_ocaml-ppx, +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + uchar, + result, + gg, + uutf, + otfm, + js_of_ocaml, + js_of_ocaml-ppx, pdfBackend ? true, # depends on uutf and otfm - htmlcBackend ? true # depends on js_of_ocaml + htmlcBackend ? true, # depends on js_of_ocaml }: let @@ -13,51 +25,67 @@ let webpage = "https://erratique.ch/software/${pname}"; in -if versionOlder ocaml.version "4.03" -then throw "vg is not available for OCaml ${ocaml.version}" +if versionOlder ocaml.version "4.03" then + throw "vg is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation { - - name = "ocaml${ocaml.version}-${pname}-${version}"; - - src = fetchurl { - url = "${webpage}/releases/${pname}-${version}.tbz"; - sha256 = "181sz6l5xrj5jvwg4m2yqsjzwp2s5h8v0mwhjcwbam90kdfx2nak"; - }; - - nativeBuildInputs = [ ocaml findlib ocamlbuild ]; - buildInputs = [ topkg ]; - - propagatedBuildInputs = [ uchar result gg ] - ++ optionals pdfBackend [ uutf otfm ] - ++ optionals htmlcBackend [ js_of_ocaml js_of_ocaml-ppx ]; - - strictDeps = true; - - buildPhase = topkg.buildPhase - + " --with-uutf ${lib.boolToString pdfBackend}" - + " --with-otfm ${lib.boolToString pdfBackend}" - + " --with-js_of_ocaml ${lib.boolToString htmlcBackend}" - + " --with-cairo2 false"; - - inherit (topkg) installPhase; - - meta = with lib; { - description = "Declarative 2D vector graphics for OCaml"; - longDescription = '' - Vg is an OCaml module for declarative 2D vector graphics. In Vg, images - are values that denote functions mapping points of the cartesian plane - to colors. The module provides combinators to define and compose these - values. - - Renderers for PDF, SVG and the HTML canvas are distributed with the - module. An API allows to implement new renderers. - ''; - homepage = webpage; - license = licenses.isc; - maintainers = [ maintainers.jirkamarsik ]; - mainProgram = "vecho"; - inherit (ocaml.meta) platforms; - }; -} + stdenv.mkDerivation { + + name = "ocaml${ocaml.version}-${pname}-${version}"; + + src = fetchurl { + url = "${webpage}/releases/${pname}-${version}.tbz"; + sha256 = "181sz6l5xrj5jvwg4m2yqsjzwp2s5h8v0mwhjcwbam90kdfx2nak"; + }; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ]; + buildInputs = [ topkg ]; + + propagatedBuildInputs = + [ + uchar + result + gg + ] + ++ optionals pdfBackend [ + uutf + otfm + ] + ++ optionals htmlcBackend [ + js_of_ocaml + js_of_ocaml-ppx + ]; + + strictDeps = true; + + buildPhase = + topkg.buildPhase + + " --with-uutf ${lib.boolToString pdfBackend}" + + " --with-otfm ${lib.boolToString pdfBackend}" + + " --with-js_of_ocaml ${lib.boolToString htmlcBackend}" + + " --with-cairo2 false"; + + inherit (topkg) installPhase; + + meta = with lib; { + description = "Declarative 2D vector graphics for OCaml"; + longDescription = '' + Vg is an OCaml module for declarative 2D vector graphics. In Vg, images + are values that denote functions mapping points of the cartesian plane + to colors. The module provides combinators to define and compose these + values. + + Renderers for PDF, SVG and the HTML canvas are distributed with the + module. An API allows to implement new renderers. + ''; + homepage = webpage; + license = licenses.isc; + maintainers = [ maintainers.jirkamarsik ]; + mainProgram = "vecho"; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/visitors/default.nix b/pkgs/development/ocaml-modules/visitors/default.nix index 22762db02aa3f0..f2115d16ee4b99 100644 --- a/pkgs/development/ocaml-modules/visitors/default.nix +++ b/pkgs/development/ocaml-modules/visitors/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitLab, ppxlib, ppx_deriving, result }: +{ + lib, + buildDunePackage, + fetchFromGitLab, + ppxlib, + ppx_deriving, + result, +}: buildDunePackage rec { pname = "visitors"; @@ -16,7 +23,11 @@ buildDunePackage rec { sha256 = "1p75x5yqwbwv8yb2gz15rfl3znipy59r45d1f4vcjdghhjws6q2a"; }; - propagatedBuildInputs = [ ppxlib ppx_deriving result ]; + propagatedBuildInputs = [ + ppxlib + ppx_deriving + result + ]; meta = with lib; { homepage = "https://gitlab.inria.fr/fpottier/visitors"; diff --git a/pkgs/development/ocaml-modules/vlq/default.nix b/pkgs/development/ocaml-modules/vlq/default.nix index a6ba09ebc6799a..e23bf4cb7513c6 100644 --- a/pkgs/development/ocaml-modules/vlq/default.nix +++ b/pkgs/development/ocaml-modules/vlq/default.nix @@ -1,26 +1,31 @@ -{ lib, buildDunePackage, fetchurl, ocaml -, dune-configurator +{ + lib, + buildDunePackage, + fetchurl, + ocaml, + dune-configurator, }: lib.throwIf (lib.versionAtLeast ocaml.version "5.0") "vlq is not available for OCaml ${ocaml.version}" -buildDunePackage rec { - pname = "vlq"; - version = "0.2.1"; + buildDunePackage + rec { + pname = "vlq"; + version = "0.2.1"; - src = fetchurl { - url = "https://github.com/flowtype/ocaml-vlq/releases/download/v${version}/vlq-v${version}.tbz"; - sha256 = "02wr9ph4q0nxmqgbc67ydf165hmrdv9b655krm2glc3ahb6larxi"; - }; + src = fetchurl { + url = "https://github.com/flowtype/ocaml-vlq/releases/download/v${version}/vlq-v${version}.tbz"; + sha256 = "02wr9ph4q0nxmqgbc67ydf165hmrdv9b655krm2glc3ahb6larxi"; + }; - buildInputs = [ dune-configurator ]; + buildInputs = [ dune-configurator ]; - meta = { - description = "encoding variable-length quantities, in particular base64"; - license = lib.licenses.mit; - homepage = "https://github.com/flowtype/ocaml-vlq"; - maintainers = [ lib.maintainers.nomeata ]; - }; + meta = { + description = "encoding variable-length quantities, in particular base64"; + license = lib.licenses.mit; + homepage = "https://github.com/flowtype/ocaml-vlq"; + maintainers = [ lib.maintainers.nomeata ]; + }; -} + } diff --git a/pkgs/development/ocaml-modules/vorbis/default.nix b/pkgs/development/ocaml-modules/vorbis/default.nix index 5bfb230e6c7c28..968c51f5e3736b 100644 --- a/pkgs/development/ocaml-modules/vorbis/default.nix +++ b/pkgs/development/ocaml-modules/vorbis/default.nix @@ -1,4 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, ogg, libvorbis }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + ogg, + libvorbis, +}: buildDunePackage rec { pname = "vorbis"; @@ -14,7 +21,10 @@ buildDunePackage rec { }; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ ogg libvorbis ]; + propagatedBuildInputs = [ + ogg + libvorbis + ]; meta = with lib; { homepage = "https://github.com/savonet/ocaml-vorbis"; diff --git a/pkgs/development/ocaml-modules/vpl-core/default.nix b/pkgs/development/ocaml-modules/vpl-core/default.nix index 08f8eccacc6b03..bdc78d94192541 100644 --- a/pkgs/development/ocaml-modules/vpl-core/default.nix +++ b/pkgs/development/ocaml-modules/vpl-core/default.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, zarith +{ + lib, + fetchFromGitHub, + buildDunePackage, + zarith, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/wasm/default.nix b/pkgs/development/ocaml-modules/wasm/default.nix index 95ba92c8bca30a..1abe1f060bbd74 100644 --- a/pkgs/development/ocaml-modules/wasm/default.nix +++ b/pkgs/development/ocaml-modules/wasm/default.nix @@ -1,41 +1,55 @@ -{ stdenv, lib, fetchFromGitHub, ocaml, findlib, ocamlbuild }: - -if lib.versionOlder ocaml.version "4.08" -then throw "wasm is not available for OCaml ${ocaml.version}" +{ + stdenv, + lib, + fetchFromGitHub, + ocaml, + findlib, + ocamlbuild, +}: + +if lib.versionOlder ocaml.version "4.08" then + throw "wasm is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-wasm"; - version = "2.0.1"; - - src = fetchFromGitHub { - owner = "WebAssembly"; - repo = "spec"; - rev = "opam-${version}"; - hash = "sha256-5eo8MIui2GxRS5X9az0NlLGZfxi5KGsTI/EaP6m/zts="; - }; - - nativeBuildInputs = [ ocaml findlib ocamlbuild ]; - strictDeps = true; - - # x86_64-unknown-linux-musl-ld: -r and -pie may not be used together - hardeningDisable = lib.optional stdenv.hostPlatform.isStatic "pie"; - - makeFlags = [ "-C" "interpreter" ]; - - createFindlibDestdir = true; - - postInstall = '' - mkdir $out/bin - cp -L interpreter/wasm $out/bin - ''; - - meta = { - description = "Executable and OCaml library to run, read and write Web Assembly (wasm) files and manipulate their AST"; - mainProgram = "wasm"; - license = lib.licenses.asl20; - maintainers = [ lib.maintainers.vbgl ]; - homepage = "https://github.com/WebAssembly/spec/tree/master/interpreter"; - inherit (ocaml.meta) platforms; - }; -} + stdenv.mkDerivation rec { + pname = "ocaml${ocaml.version}-wasm"; + version = "2.0.1"; + + src = fetchFromGitHub { + owner = "WebAssembly"; + repo = "spec"; + rev = "opam-${version}"; + hash = "sha256-5eo8MIui2GxRS5X9az0NlLGZfxi5KGsTI/EaP6m/zts="; + }; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ]; + strictDeps = true; + + # x86_64-unknown-linux-musl-ld: -r and -pie may not be used together + hardeningDisable = lib.optional stdenv.hostPlatform.isStatic "pie"; + + makeFlags = [ + "-C" + "interpreter" + ]; + + createFindlibDestdir = true; + + postInstall = '' + mkdir $out/bin + cp -L interpreter/wasm $out/bin + ''; + + meta = { + description = "Executable and OCaml library to run, read and write Web Assembly (wasm) files and manipulate their AST"; + mainProgram = "wasm"; + license = lib.licenses.asl20; + maintainers = [ lib.maintainers.vbgl ]; + homepage = "https://github.com/WebAssembly/spec/tree/master/interpreter"; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/wayland/default.nix b/pkgs/development/ocaml-modules/wayland/default.nix index c839546a2ba692..062774ad50781e 100644 --- a/pkgs/development/ocaml-modules/wayland/default.nix +++ b/pkgs/development/ocaml-modules/wayland/default.nix @@ -1,14 +1,15 @@ -{ lib -, buildDunePackage -, fetchurl -, xmlm -, eio -, logs -, fmt -, cstruct -, cmdliner -, alcotest -, eio_main +{ + lib, + buildDunePackage, + fetchurl, + xmlm, + eio, + logs, + fmt, + cstruct, + cmdliner, + alcotest, + eio_main, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/webbrowser/default.nix b/pkgs/development/ocaml-modules/webbrowser/default.nix index 7ace251e5533e3..2c5e51dbd4516d 100644 --- a/pkgs/development/ocaml-modules/webbrowser/default.nix +++ b/pkgs/development/ocaml-modules/webbrowser/default.nix @@ -1,5 +1,15 @@ -{ stdenv, lib, fetchurl, ocaml, findlib, ocamlbuild, topkg -, astring, bos, cmdliner, rresult +{ + stdenv, + lib, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + astring, + bos, + cmdliner, + rresult, }: stdenv.mkDerivation rec { @@ -10,9 +20,19 @@ stdenv.mkDerivation rec { sha256 = "137a948bx7b71zfv4za3hhznrn5lzbbrgzjy0das83zms508isx3"; }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; buildInputs = [ topkg ]; - propagatedBuildInputs = [ astring bos cmdliner rresult ]; + propagatedBuildInputs = [ + astring + bos + cmdliner + rresult + ]; strictDeps = true; diff --git a/pkgs/development/ocaml-modules/webmachine/default.nix b/pkgs/development/ocaml-modules/webmachine/default.nix index 33436cd2c8c231..3cd3fb98e481f4 100644 --- a/pkgs/development/ocaml-modules/webmachine/default.nix +++ b/pkgs/development/ocaml-modules/webmachine/default.nix @@ -1,6 +1,11 @@ -{ lib, buildDunePackage, fetchFromGitHub -, cohttp, dispatch, ptime -, ounit +{ + lib, + buildDunePackage, + fetchFromGitHub, + cohttp, + dispatch, + ptime, + ounit, }: buildDunePackage rec { @@ -17,7 +22,11 @@ buildDunePackage rec { sha256 = "03ynb1l2jjqba88m9r8m5hwlm8izpfp617r4vcab5kmdim1l2ffx"; }; - propagatedBuildInputs = [ cohttp dispatch ptime ]; + propagatedBuildInputs = [ + cohttp + dispatch + ptime + ]; checkInputs = [ ounit ]; diff --git a/pkgs/development/ocaml-modules/wtf8/default.nix b/pkgs/development/ocaml-modules/wtf8/default.nix index 456fe129c8b198..faeb7730f6876a 100644 --- a/pkgs/development/ocaml-modules/wtf8/default.nix +++ b/pkgs/development/ocaml-modules/wtf8/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, buildDunePackage }: +{ + lib, + fetchurl, + buildDunePackage, +}: buildDunePackage rec { pname = "wtf8"; diff --git a/pkgs/development/ocaml-modules/x509/default.nix b/pkgs/development/ocaml-modules/x509/default.nix index 3d82633cf7bda5..d7b3c6e7a1cdbb 100644 --- a/pkgs/development/ocaml-modules/x509/default.nix +++ b/pkgs/development/ocaml-modules/x509/default.nix @@ -1,7 +1,20 @@ -{ lib, fetchurl, buildDunePackage -, alcotest -, asn1-combinators, domain-name, fmt, gmap, kdf, mirage-crypto, mirage-crypto-ec, mirage-crypto-pk, ipaddr -, logs, base64, ohex +{ + lib, + fetchurl, + buildDunePackage, + alcotest, + asn1-combinators, + domain-name, + fmt, + gmap, + kdf, + mirage-crypto, + mirage-crypto-ec, + mirage-crypto-pk, + ipaddr, + logs, + base64, + ohex, }: buildDunePackage rec { @@ -16,7 +29,20 @@ buildDunePackage rec { }; checkInputs = [ alcotest ]; - propagatedBuildInputs = [ asn1-combinators domain-name fmt gmap mirage-crypto mirage-crypto-pk mirage-crypto-ec kdf logs base64 ipaddr ohex ]; + propagatedBuildInputs = [ + asn1-combinators + domain-name + fmt + gmap + mirage-crypto + mirage-crypto-pk + mirage-crypto-ec + kdf + logs + base64 + ipaddr + ohex + ]; doCheck = true; diff --git a/pkgs/development/ocaml-modules/xdg/default.nix b/pkgs/development/ocaml-modules/xdg/default.nix index b6260451965d78..ca18fb0bd4dacd 100644 --- a/pkgs/development/ocaml-modules/xdg/default.nix +++ b/pkgs/development/ocaml-modules/xdg/default.nix @@ -1,4 +1,8 @@ -{ lib, buildDunePackage, dune_3 }: +{ + lib, + buildDunePackage, + dune_3, +}: buildDunePackage rec { pname = "xdg"; diff --git a/pkgs/development/ocaml-modules/xenstore-tool/default.nix b/pkgs/development/ocaml-modules/xenstore-tool/default.nix index e75a2036642fb2..df61ab0eb491ec 100644 --- a/pkgs/development/ocaml-modules/xenstore-tool/default.nix +++ b/pkgs/development/ocaml-modules/xenstore-tool/default.nix @@ -1,4 +1,10 @@ -{ buildDunePackage, camlp-streams, xenstore_transport, xenstore, lwt }: +{ + buildDunePackage, + camlp-streams, + xenstore_transport, + xenstore, + lwt, +}: buildDunePackage { pname = "xenstore-tool"; @@ -9,7 +15,12 @@ buildDunePackage { substituteInPlace cli/dune --replace 'libraries ' 'libraries camlp-streams ' ''; - buildInputs = [ camlp-streams xenstore_transport xenstore lwt ]; + buildInputs = [ + camlp-streams + xenstore_transport + xenstore + lwt + ]; meta = xenstore_transport.meta // { description = "Command line tool for interfacing with xenstore"; diff --git a/pkgs/development/ocaml-modules/xenstore_transport/default.nix b/pkgs/development/ocaml-modules/xenstore_transport/default.nix index 5ef03349e68a81..735495979cc56e 100644 --- a/pkgs/development/ocaml-modules/xenstore_transport/default.nix +++ b/pkgs/development/ocaml-modules/xenstore_transport/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, xenstore, lwt }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + xenstore, + lwt, +}: buildDunePackage rec { pname = "xenstore_transport"; @@ -14,7 +20,10 @@ buildDunePackage rec { sha256 = "1kxxd9i4qiq98r7sgvl59iq2ni7y6drnv48qj580q5cyiyyc85q3"; }; - propagatedBuildInputs = [ xenstore lwt ]; + propagatedBuildInputs = [ + xenstore + lwt + ]; # requires a mounted xenfs and xen server doCheck = false; diff --git a/pkgs/development/ocaml-modules/xml-light/default.nix b/pkgs/development/ocaml-modules/xml-light/default.nix index 5ebaadf214fb62..8d0bf0dd9be217 100644 --- a/pkgs/development/ocaml-modules/xml-light/default.nix +++ b/pkgs/development/ocaml-modules/xml-light/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildDunePackage -, fetchurl +{ + lib, + buildDunePackage, + fetchurl, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/xmlm/default.nix b/pkgs/development/ocaml-modules/xmlm/default.nix index 35459d14024b0d..21d0b28a09b736 100644 --- a/pkgs/development/ocaml-modules/xmlm/default.nix +++ b/pkgs/development/ocaml-modules/xmlm/default.nix @@ -1,35 +1,48 @@ -{ lib, stdenv, fetchurl, ocaml, findlib, ocamlbuild, topkg }: +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, +}: let pname = "xmlm"; webpage = "https://erratique.ch/software/${pname}"; in -if lib.versionOlder ocaml.version "4.05" -then throw "xmlm is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.05" then + throw "xmlm is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation rec { - name = "ocaml${ocaml.version}-${pname}-${version}"; - version = "1.4.0"; + stdenv.mkDerivation rec { + name = "ocaml${ocaml.version}-${pname}-${version}"; + version = "1.4.0"; - src = fetchurl { - url = "${webpage}/releases/${pname}-${version}.tbz"; - sha256 = "sha256-CRJSJY490WMgw85N2yG81X79nIwuv7eZ7mpUPtSS2fo="; - }; + src = fetchurl { + url = "${webpage}/releases/${pname}-${version}.tbz"; + sha256 = "sha256-CRJSJY490WMgw85N2yG81X79nIwuv7eZ7mpUPtSS2fo="; + }; - nativeBuildInputs = [ ocaml findlib ocamlbuild topkg ]; - buildInputs = [ topkg ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + topkg + ]; + buildInputs = [ topkg ]; - strictDeps = true; + strictDeps = true; - inherit (topkg) buildPhase installPhase; + inherit (topkg) buildPhase installPhase; - meta = with lib; { - description = "OCaml streaming codec to decode and encode the XML data format"; - homepage = webpage; - license = licenses.isc; - maintainers = [ maintainers.vbgl ]; - mainProgram = "xmltrip"; - inherit (ocaml.meta) platforms; - }; -} + meta = with lib; { + description = "OCaml streaming codec to decode and encode the XML data format"; + homepage = webpage; + license = licenses.isc; + maintainers = [ maintainers.vbgl ]; + mainProgram = "xmltrip"; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/ocaml-modules/xmlplaylist/default.nix b/pkgs/development/ocaml-modules/xmlplaylist/default.nix index a30172573506e6..a9294cf162dfac 100644 --- a/pkgs/development/ocaml-modules/xmlplaylist/default.nix +++ b/pkgs/development/ocaml-modules/xmlplaylist/default.nix @@ -1,4 +1,10 @@ -{ lib, buildDunePackage, fetchFromGitHub, dune-configurator, xmlm }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + dune-configurator, + xmlm, +}: buildDunePackage rec { pname = "xmlplaylist"; diff --git a/pkgs/development/ocaml-modules/xtmpl/default.nix b/pkgs/development/ocaml-modules/xtmpl/default.nix index 47e153e53c2d20..7350e31df8c653 100644 --- a/pkgs/development/ocaml-modules/xtmpl/default.nix +++ b/pkgs/development/ocaml-modules/xtmpl/default.nix @@ -1,4 +1,12 @@ -{ lib, buildDunePackage, fetchFromGitLab, iri, re, sedlex, uutf }: +{ + lib, + buildDunePackage, + fetchFromGitLab, + iri, + re, + sedlex, + uutf, +}: buildDunePackage rec { pname = "xtmpl"; @@ -12,7 +20,12 @@ buildDunePackage rec { sha256 = "sha256:0vwj0aayg60wm98d91fg3hmj90730liljy4cn8771dpxvz8m07bw"; }; - propagatedBuildInputs = [ iri re sedlex uutf ]; + propagatedBuildInputs = [ + iri + re + sedlex + uutf + ]; meta = with lib; { description = "XML templating library for OCaml"; diff --git a/pkgs/development/ocaml-modules/xtmpl/ppx.nix b/pkgs/development/ocaml-modules/xtmpl/ppx.nix index 0e23cdc48f7079..39200face2cd22 100644 --- a/pkgs/development/ocaml-modules/xtmpl/ppx.nix +++ b/pkgs/development/ocaml-modules/xtmpl/ppx.nix @@ -1,4 +1,8 @@ -{ buildDunePackage, xtmpl, ppxlib }: +{ + buildDunePackage, + xtmpl, + ppxlib, +}: buildDunePackage { pname = "xtmpl_ppx"; @@ -7,7 +11,10 @@ buildDunePackage { inherit (xtmpl) src version; - buildInputs = [ ppxlib xtmpl ]; + buildInputs = [ + ppxlib + xtmpl + ]; meta = xtmpl.meta // { description = "Xml templating library, ppx extension"; diff --git a/pkgs/development/ocaml-modules/xxhash/default.nix b/pkgs/development/ocaml-modules/xxhash/default.nix index d8ef8f3d60effe..0b16c4d8c03ac9 100644 --- a/pkgs/development/ocaml-modules/xxhash/default.nix +++ b/pkgs/development/ocaml-modules/xxhash/default.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, buildDunePackage -, xxHash -, ctypes -, ctypes-foreign -, dune-configurator -, ppx_expect +{ + lib, + fetchFromGitHub, + buildDunePackage, + xxHash, + ctypes, + ctypes-foreign, + dune-configurator, + ppx_expect, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/yaml/default.nix b/pkgs/development/ocaml-modules/yaml/default.nix index 99b6fb245a2649..003a0ea1b3748a 100644 --- a/pkgs/development/ocaml-modules/yaml/default.nix +++ b/pkgs/development/ocaml-modules/yaml/default.nix @@ -1,7 +1,17 @@ -{ lib, fetchurl, buildDunePackage -, dune-configurator -, bos, ctypes, fmt, logs -, mdx, alcotest, crowbar, junit_alcotest, ezjsonm +{ + lib, + fetchurl, + buildDunePackage, + dune-configurator, + bos, + ctypes, + fmt, + logs, + mdx, + alcotest, + crowbar, + junit_alcotest, + ezjsonm, }: buildDunePackage rec { @@ -16,11 +26,21 @@ buildDunePackage rec { minimalOCamlVersion = "4.13"; buildInputs = [ dune-configurator ]; - propagatedBuildInputs = [ bos ctypes ]; + propagatedBuildInputs = [ + bos + ctypes + ]; doCheck = true; nativeCheckInputs = [ mdx.bin ]; - checkInputs = [ fmt logs alcotest crowbar junit_alcotest ezjsonm ]; + checkInputs = [ + fmt + logs + alcotest + crowbar + junit_alcotest + ezjsonm + ]; meta = { description = "Parse and generate YAML 1.1 files"; diff --git a/pkgs/development/ocaml-modules/yaml/yaml-sexp.nix b/pkgs/development/ocaml-modules/yaml/yaml-sexp.nix index 44e111715db568..ae3d3f30257591 100644 --- a/pkgs/development/ocaml-modules/yaml/yaml-sexp.nix +++ b/pkgs/development/ocaml-modules/yaml/yaml-sexp.nix @@ -1,5 +1,9 @@ -{ buildDunePackage, yaml, ppx_sexp_conv, sexplib -, junit_alcotest +{ + buildDunePackage, + yaml, + ppx_sexp_conv, + sexplib, + junit_alcotest, }: buildDunePackage rec { @@ -7,7 +11,11 @@ buildDunePackage rec { inherit (yaml) version src; - propagatedBuildInputs = [ yaml ppx_sexp_conv sexplib ]; + propagatedBuildInputs = [ + yaml + ppx_sexp_conv + sexplib + ]; doCheck = true; checkInputs = [ junit_alcotest ]; diff --git a/pkgs/development/ocaml-modules/yojson/default.nix b/pkgs/development/ocaml-modules/yojson/default.nix index 6c75916c69f59d..3074e9553c46a6 100644 --- a/pkgs/development/ocaml-modules/yojson/default.nix +++ b/pkgs/development/ocaml-modules/yojson/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, buildDunePackage, seq }: +{ + lib, + fetchurl, + buildDunePackage, + seq, +}: buildDunePackage rec { pname = "yojson"; diff --git a/pkgs/development/ocaml-modules/yuscii/default.nix b/pkgs/development/ocaml-modules/yuscii/default.nix index a8b8d7640f7bde..9995dbce4aa8c8 100644 --- a/pkgs/development/ocaml-modules/yuscii/default.nix +++ b/pkgs/development/ocaml-modules/yuscii/default.nix @@ -1,11 +1,12 @@ -{ alcotest -, buildDunePackage -, ocaml -, fetchzip -, gcc -, fmt -, lib -, uutf +{ + alcotest, + buildDunePackage, + ocaml, + fetchzip, + gcc, + fmt, + lib, + uutf, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/yuujinchou/default.nix b/pkgs/development/ocaml-modules/yuujinchou/default.nix index 7b9b290662a667..3a0f6b08ea46a7 100644 --- a/pkgs/development/ocaml-modules/yuujinchou/default.nix +++ b/pkgs/development/ocaml-modules/yuujinchou/default.nix @@ -1,17 +1,30 @@ -{ lib, ocaml, fetchFromGitHub, buildDunePackage -, algaeff, bwd -, qcheck-alcotest +{ + lib, + ocaml, + fetchFromGitHub, + buildDunePackage, + algaeff, + bwd, + qcheck-alcotest, }: -let params = if lib.versionAtLeast ocaml.version "5.0" then { - version = "5.2.0"; - hash = "sha256-DJzXjV5Tjf69FKUiRioeHghks72pOOHYd73vqhmecS8="; - propagatedBuildInputs = [ algaeff bwd ]; - } else { - version = "2.0.0"; - hash = "sha256:1nhz44cyipy922anzml856532m73nn0g7iwkg79yzhq6yb87109w"; - } -; in +let + params = + if lib.versionAtLeast ocaml.version "5.0" then + { + version = "5.2.0"; + hash = "sha256-DJzXjV5Tjf69FKUiRioeHghks72pOOHYd73vqhmecS8="; + propagatedBuildInputs = [ + algaeff + bwd + ]; + } + else + { + version = "2.0.0"; + hash = "sha256:1nhz44cyipy922anzml856532m73nn0g7iwkg79yzhq6yb87109w"; + }; +in buildDunePackage rec { pname = "yuujinchou"; @@ -26,8 +39,7 @@ buildDunePackage rec { inherit (params) hash; }; - propagatedBuildInputs = params.propagatedBuildInputs or []; - + propagatedBuildInputs = params.propagatedBuildInputs or [ ]; doCheck = true; checkInputs = [ qcheck-alcotest ]; @@ -39,4 +51,3 @@ buildDunePackage rec { maintainers = [ lib.maintainers.vbgl ]; }; } - diff --git a/pkgs/development/ocaml-modules/z3/default.nix b/pkgs/development/ocaml-modules/z3/default.nix index f2ece5550d785b..39f893d418769d 100644 --- a/pkgs/development/ocaml-modules/z3/default.nix +++ b/pkgs/development/ocaml-modules/z3/default.nix @@ -1,35 +1,46 @@ -{ stdenv, lib, ocaml, findlib, zarith, z3 }: - -if lib.versionOlder ocaml.version "4.07" -then throw "z3 is not available for OCaml ${ocaml.version}" +{ + stdenv, + lib, + ocaml, + findlib, + zarith, + z3, +}: + +if lib.versionOlder ocaml.version "4.07" then + throw "z3 is not available for OCaml ${ocaml.version}" else -let z3-with-ocaml = (z3.override { - ocamlBindings = true; - inherit ocaml findlib zarith; -}); in + let + z3-with-ocaml = ( + z3.override { + ocamlBindings = true; + inherit ocaml findlib zarith; + } + ); + in -stdenv.mkDerivation { + stdenv.mkDerivation { - pname = "ocaml${ocaml.version}-z3"; - inherit (z3-with-ocaml) version; + pname = "ocaml${ocaml.version}-z3"; + inherit (z3-with-ocaml) version; - dontUnpack = true; + dontUnpack = true; - installPhase = '' - runHook preInstall - mkdir -p $OCAMLFIND_DESTDIR - cp -r ${z3-with-ocaml.ocaml}/lib/ocaml/${ocaml.version}/site-lib/stublibs $OCAMLFIND_DESTDIR - cp -r ${z3-with-ocaml.ocaml}/lib/ocaml/${ocaml.version}/site-lib/Z3 $OCAMLFIND_DESTDIR/z3 - runHook postInstall - ''; + installPhase = '' + runHook preInstall + mkdir -p $OCAMLFIND_DESTDIR + cp -r ${z3-with-ocaml.ocaml}/lib/ocaml/${ocaml.version}/site-lib/stublibs $OCAMLFIND_DESTDIR + cp -r ${z3-with-ocaml.ocaml}/lib/ocaml/${ocaml.version}/site-lib/Z3 $OCAMLFIND_DESTDIR/z3 + runHook postInstall + ''; - nativeBuildInputs = [ findlib ]; - propagatedBuildInputs = [ zarith ]; + nativeBuildInputs = [ findlib ]; + propagatedBuildInputs = [ zarith ]; - strictDeps = true; + strictDeps = true; - meta = z3.meta // { - description = "Z3 Theorem Prover (OCaml API)"; - }; -} + meta = z3.meta // { + description = "Z3 Theorem Prover (OCaml API)"; + }; + } diff --git a/pkgs/development/ocaml-modules/zarith/default.nix b/pkgs/development/ocaml-modules/zarith/default.nix index c09b5a828f925a..09ef6ced260090 100644 --- a/pkgs/development/ocaml-modules/zarith/default.nix +++ b/pkgs/development/ocaml-modules/zarith/default.nix @@ -1,43 +1,57 @@ -{ lib, stdenv, fetchFromGitHub -, ocaml, findlib, pkg-config -, gmp -, version ? if lib.versionAtLeast ocaml.version "4.08" then "1.14" else "1.13" +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, + pkg-config, + gmp, + version ? if lib.versionAtLeast ocaml.version "4.08" then "1.14" else "1.13", }: -if lib.versionOlder ocaml.version "4.04" -then throw "zarith is not available for OCaml ${ocaml.version}" +if lib.versionOlder ocaml.version "4.04" then + throw "zarith is not available for OCaml ${ocaml.version}" else -stdenv.mkDerivation (finalAttrs: { - pname = "ocaml${ocaml.version}-zarith"; - inherit version; - src = fetchFromGitHub { - owner = "ocaml"; - repo = "Zarith"; - rev = "release-${version}"; - hash = { - "1.13" = "sha256-CNVKoJeO3fsmWaV/dwnUA8lgI4ZlxR/LKCXpCXUrpSg="; - "1.14" = "sha256-xUrBDr+M8uW2KOy7DZieO/vDgsSOnyBnpOzQDlXJ0oE="; - }."${finalAttrs.version}"; - }; + stdenv.mkDerivation (finalAttrs: { + pname = "ocaml${ocaml.version}-zarith"; + inherit version; + src = fetchFromGitHub { + owner = "ocaml"; + repo = "Zarith"; + rev = "release-${version}"; + hash = + { + "1.13" = "sha256-CNVKoJeO3fsmWaV/dwnUA8lgI4ZlxR/LKCXpCXUrpSg="; + "1.14" = "sha256-xUrBDr+M8uW2KOy7DZieO/vDgsSOnyBnpOzQDlXJ0oE="; + } + ."${finalAttrs.version}"; + }; - nativeBuildInputs = [ pkg-config ocaml findlib ]; - propagatedBuildInputs = [ gmp ]; - strictDeps = true; + nativeBuildInputs = [ + pkg-config + ocaml + findlib + ]; + propagatedBuildInputs = [ gmp ]; + strictDeps = true; - dontAddPrefix = true; - dontAddStaticConfigureFlags = true; - configurePlatforms = []; - configureFlags = [ "-installdir ${placeholder "out"}/lib/ocaml/${ocaml.version}/site-lib" ]; + dontAddPrefix = true; + dontAddStaticConfigureFlags = true; + configurePlatforms = [ ]; + configureFlags = [ "-installdir ${placeholder "out"}/lib/ocaml/${ocaml.version}/site-lib" ]; - preInstall = "mkdir -p $out/lib/ocaml/${ocaml.version}/site-lib/stublibs"; + preInstall = "mkdir -p $out/lib/ocaml/${ocaml.version}/site-lib/stublibs"; - meta = with lib; { - description = "Fast, arbitrary precision OCaml integers"; - homepage = "https://github.com/ocaml/Zarith"; - changelog = "https://github.com/ocaml/Zarith/raw/${finalAttrs.src.rev}/Changes"; - license = licenses.lgpl2; - inherit (ocaml.meta) platforms; - maintainers = with maintainers; [ thoughtpolice vbgl ]; - }; -}) + meta = with lib; { + description = "Fast, arbitrary precision OCaml integers"; + homepage = "https://github.com/ocaml/Zarith"; + changelog = "https://github.com/ocaml/Zarith/raw/${finalAttrs.src.rev}/Changes"; + license = licenses.lgpl2; + inherit (ocaml.meta) platforms; + maintainers = with maintainers; [ + thoughtpolice + vbgl + ]; + }; + }) diff --git a/pkgs/development/ocaml-modules/zed/default.nix b/pkgs/development/ocaml-modules/zed/default.nix index 4b05b21c69d10a..1e2dea1420b6ba 100644 --- a/pkgs/development/ocaml-modules/zed/default.nix +++ b/pkgs/development/ocaml-modules/zed/default.nix @@ -1,10 +1,27 @@ -{ lib, buildDunePackage, fetchFromGitHub, react, result, uchar, uutf, uucp, uuseg }: +{ + lib, + buildDunePackage, + fetchFromGitHub, + react, + result, + uchar, + uutf, + uucp, + uuseg, +}: buildDunePackage rec { pname = "zed"; version = "3.2.3"; - propagatedBuildInputs = [ react result uchar uutf uucp uuseg ]; + propagatedBuildInputs = [ + react + result + uchar + uutf + uucp + uuseg + ]; src = fetchFromGitHub { owner = "ocaml-community"; @@ -16,11 +33,11 @@ buildDunePackage rec { meta = { description = "Abstract engine for text edition in OCaml"; longDescription = '' - Zed is an abstract engine for text edition. It can be used to write text editors, edition widgets, readlines, ... + Zed is an abstract engine for text edition. It can be used to write text editors, edition widgets, readlines, ... - Zed uses Camomile to fully support the Unicode specification, and implements an UTF-8 encoded string type with validation, and a rope datastructure to achieve efficient operations on large Unicode buffers. Zed also features a regular expression search on ropes. + Zed uses Camomile to fully support the Unicode specification, and implements an UTF-8 encoded string type with validation, and a rope datastructure to achieve efficient operations on large Unicode buffers. Zed also features a regular expression search on ropes. - To support efficient text edition capabilities, Zed provides macro recording and cursor management facilities. + To support efficient text edition capabilities, Zed provides macro recording and cursor management facilities. ''; homepage = "https://github.com/ocaml-community/zed"; changelog = "https://github.com/ocaml-community/zed/blob/${version}/CHANGES.md"; diff --git a/pkgs/development/ocaml-modules/zelus-gtk/default.nix b/pkgs/development/ocaml-modules/zelus-gtk/default.nix index 759a625d26a2a7..c5ebeaddc85686 100644 --- a/pkgs/development/ocaml-modules/zelus-gtk/default.nix +++ b/pkgs/development/ocaml-modules/zelus-gtk/default.nix @@ -1,6 +1,7 @@ -{ buildDunePackage -, zelus -, lablgtk +{ + buildDunePackage, + zelus, + lablgtk, }: buildDunePackage { diff --git a/pkgs/development/ocaml-modules/zelus/default.nix b/pkgs/development/ocaml-modules/zelus/default.nix index 4d52640d53bc56..5425038111fbf9 100644 --- a/pkgs/development/ocaml-modules/zelus/default.nix +++ b/pkgs/development/ocaml-modules/zelus/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, buildDunePackage -, fetchFromGitHub -, menhir -, menhirLib +{ + lib, + stdenv, + buildDunePackage, + fetchFromGitHub, + menhir, + menhirLib, }: buildDunePackage rec { diff --git a/pkgs/development/ocaml-modules/zipc/default.nix b/pkgs/development/ocaml-modules/zipc/default.nix index a31d2644e668b5..74717ec794713f 100644 --- a/pkgs/development/ocaml-modules/zipc/default.nix +++ b/pkgs/development/ocaml-modules/zipc/default.nix @@ -1,33 +1,46 @@ -{ lib, stdenv, fetchurl -, ocaml, findlib, ocamlbuild, topkg, cmdliner +{ + lib, + stdenv, + fetchurl, + ocaml, + findlib, + ocamlbuild, + topkg, + cmdliner, }: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.14") "zipc is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-zipc"; - version = "0.2.0"; - - src = fetchurl { - url = "https://erratique.ch/software/zipc/releases/zipc-${version}.tbz"; - hash = "sha256-YQqkCURwrJgFH0+zgfket25zJQ4w+Tcc1mTSrDuWRt0="; - }; - - strictDeps = true; - - nativeBuildInputs = [ - ocaml findlib ocamlbuild - ]; - - buildInputs = [ cmdliner topkg ]; - - inherit (topkg) buildPhase installPhase; - - meta = { - description = "ZIP archive and deflate codec for OCaml"; - homepage = "https://erratique.ch/software/zipc"; - license = lib.licenses.isc; - maintainers = [ lib.maintainers.vbgl ]; - }; -} + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-zipc"; + version = "0.2.0"; + + src = fetchurl { + url = "https://erratique.ch/software/zipc/releases/zipc-${version}.tbz"; + hash = "sha256-YQqkCURwrJgFH0+zgfket25zJQ4w+Tcc1mTSrDuWRt0="; + }; + + strictDeps = true; + + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ]; + + buildInputs = [ + cmdliner + topkg + ]; + + inherit (topkg) buildPhase installPhase; + + meta = { + description = "ZIP archive and deflate codec for OCaml"; + homepage = "https://erratique.ch/software/zipc"; + license = lib.licenses.isc; + maintainers = [ lib.maintainers.vbgl ]; + }; + } diff --git a/pkgs/development/ocaml-modules/zmq/default.nix b/pkgs/development/ocaml-modules/zmq/default.nix index 41d91b8cf5dbed..003181044329c8 100644 --- a/pkgs/development/ocaml-modules/zmq/default.nix +++ b/pkgs/development/ocaml-modules/zmq/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, buildDunePackage, dune-configurator, czmq }: +{ + lib, + fetchurl, + buildDunePackage, + dune-configurator, + czmq, +}: buildDunePackage rec { pname = "zmq"; @@ -9,11 +15,14 @@ buildDunePackage rec { hash = "sha256-tetCmVg27/WHZ+HMwKZVHCrHTzWAlKwkAjNDibB1+6g="; }; - buildInputs = [ czmq dune-configurator ]; + buildInputs = [ + czmq + dune-configurator + ]; meta = { description = "ZeroMQ bindings for OCaml"; - license = lib.licenses.mit; + license = lib.licenses.mit; maintainers = with lib.maintainers; [ akavel ]; homepage = "https://engineering.issuu.com/ocaml-zmq/"; }; diff --git a/pkgs/development/ocaml-modules/zmq/lwt.nix b/pkgs/development/ocaml-modules/zmq/lwt.nix index 1bbc1b7ad63ec0..17b19fed23d936 100644 --- a/pkgs/development/ocaml-modules/zmq/lwt.nix +++ b/pkgs/development/ocaml-modules/zmq/lwt.nix @@ -1,8 +1,15 @@ -{ buildDunePackage, zmq, lwt }: +{ + buildDunePackage, + zmq, + lwt, +}: buildDunePackage { pname = "zmq-lwt"; inherit (zmq) version src meta; - propagatedBuildInputs = [ zmq lwt ]; + propagatedBuildInputs = [ + zmq + lwt + ]; } diff --git a/pkgs/development/octave-modules/arduino/default.nix b/pkgs/development/octave-modules/arduino/default.nix index 3cd5838590f82a..0b758f191084a9 100644 --- a/pkgs/development/octave-modules/arduino/default.nix +++ b/pkgs/development/octave-modules/arduino/default.nix @@ -1,8 +1,9 @@ -{ buildOctavePackage -, lib -, fetchurl -, instrument-control -, arduino-core-unwrapped +{ + buildOctavePackage, + lib, + fetchurl, + instrument-control, + arduino-core-unwrapped, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/audio/default.nix b/pkgs/development/octave-modules/audio/default.nix index 6e00dd05fdd449..377cb36597c219 100644 --- a/pkgs/development/octave-modules/audio/default.nix +++ b/pkgs/development/octave-modules/audio/default.nix @@ -1,10 +1,11 @@ -{ buildOctavePackage -, lib -, fetchurl -, jack2 -, alsa-lib -, rtmidi -, pkg-config +{ + buildOctavePackage, + lib, + fetchurl, + jack2, + alsa-lib, + rtmidi, + pkg-config, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/bim/default.nix b/pkgs/development/octave-modules/bim/default.nix index dc018ae6143eaa..afffe81ef8e94d 100644 --- a/pkgs/development/octave-modules/bim/default.nix +++ b/pkgs/development/octave-modules/bim/default.nix @@ -1,8 +1,9 @@ -{ buildOctavePackage -, lib -, fetchFromGitHub -, fpl -, msh +{ + buildOctavePackage, + lib, + fetchFromGitHub, + fpl, + msh, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/bsltl/default.nix b/pkgs/development/octave-modules/bsltl/default.nix index aefe543b097d26..dfd225c9b52d0b 100644 --- a/pkgs/development/octave-modules/bsltl/default.nix +++ b/pkgs/development/octave-modules/bsltl/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/cgi/default.nix b/pkgs/development/octave-modules/cgi/default.nix index 4686881251afa3..d486c4e0fb1d57 100644 --- a/pkgs/development/octave-modules/cgi/default.nix +++ b/pkgs/development/octave-modules/cgi/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/communications/default.nix b/pkgs/development/octave-modules/communications/default.nix index 74acc26bb0325e..2cfea0e235923f 100644 --- a/pkgs/development/octave-modules/communications/default.nix +++ b/pkgs/development/octave-modules/communications/default.nix @@ -1,8 +1,9 @@ -{ buildOctavePackage -, lib -, fetchurl -, signal -, hdf5 +{ + buildOctavePackage, + lib, + fetchurl, + signal, + hdf5, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/control/default.nix b/pkgs/development/octave-modules/control/default.nix index 8b17493bb36ce8..64d8aaca2026e7 100644 --- a/pkgs/development/octave-modules/control/default.nix +++ b/pkgs/development/octave-modules/control/default.nix @@ -1,9 +1,11 @@ -{ buildOctavePackage -, lib -, fetchFromGitHub -, gfortran -, lapack, blas -, autoreconfHook +{ + buildOctavePackage, + lib, + fetchFromGitHub, + gfortran, + lapack, + blas, + autoreconfHook, }: buildOctavePackage rec { @@ -35,7 +37,8 @@ buildOctavePackage rec { ]; buildInputs = [ - lapack blas + lapack + blas ]; meta = with lib; { diff --git a/pkgs/development/octave-modules/data-smoothing/default.nix b/pkgs/development/octave-modules/data-smoothing/default.nix index 551582a77703e7..4e3924ccabb9f0 100644 --- a/pkgs/development/octave-modules/data-smoothing/default.nix +++ b/pkgs/development/octave-modules/data-smoothing/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, lib -, fetchurl -, optim +{ + buildOctavePackage, + lib, + fetchurl, + optim, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/database/default.nix b/pkgs/development/octave-modules/database/default.nix index 811278af5027e8..0449c767e6d410 100644 --- a/pkgs/development/octave-modules/database/default.nix +++ b/pkgs/development/octave-modules/database/default.nix @@ -1,8 +1,9 @@ -{ buildOctavePackage -, lib -, fetchurl -, struct -, postgresql +{ + buildOctavePackage, + lib, + fetchurl, + struct, + postgresql, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/dataframe/default.nix b/pkgs/development/octave-modules/dataframe/default.nix index 8f145f0d510c2f..476ae4cabf1811 100644 --- a/pkgs/development/octave-modules/dataframe/default.nix +++ b/pkgs/development/octave-modules/dataframe/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/dicom/default.nix b/pkgs/development/octave-modules/dicom/default.nix index 118537215f9fec..2f37f7210e63c7 100644 --- a/pkgs/development/octave-modules/dicom/default.nix +++ b/pkgs/development/octave-modules/dicom/default.nix @@ -1,8 +1,9 @@ -{ buildOctavePackage -, lib -, fetchurl -, gdcm -, cmake +{ + buildOctavePackage, + lib, + fetchurl, + gdcm, + cmake, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/divand/default.nix b/pkgs/development/octave-modules/divand/default.nix index ac8de9060680a4..541805f7aefd67 100644 --- a/pkgs/development/octave-modules/divand/default.nix +++ b/pkgs/development/octave-modules/divand/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/doctest/default.nix b/pkgs/development/octave-modules/doctest/default.nix index 456b9810df90fd..0e8edfc701efde 100644 --- a/pkgs/development/octave-modules/doctest/default.nix +++ b/pkgs/development/octave-modules/doctest/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/econometrics/default.nix b/pkgs/development/octave-modules/econometrics/default.nix index 0aa795959ab6bf..92d8b4613837b6 100644 --- a/pkgs/development/octave-modules/econometrics/default.nix +++ b/pkgs/development/octave-modules/econometrics/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, lib -, fetchurl -, optim +{ + buildOctavePackage, + lib, + fetchurl, + optim, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/fem-fenics/default.nix b/pkgs/development/octave-modules/fem-fenics/default.nix index 300dfd758774e6..472a3094ec6fd7 100644 --- a/pkgs/development/octave-modules/fem-fenics/default.nix +++ b/pkgs/development/octave-modules/fem-fenics/default.nix @@ -1,9 +1,10 @@ -{ buildOctavePackage -, lib -, fetchurl -, dolfin -, ffc -, pkg-config +{ + buildOctavePackage, + lib, + fetchurl, + dolfin, + ffc, + pkg-config, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/financial/default.nix b/pkgs/development/octave-modules/financial/default.nix index d034718ab5b8d0..15b0a2e7f04f90 100644 --- a/pkgs/development/octave-modules/financial/default.nix +++ b/pkgs/development/octave-modules/financial/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/fits/default.nix b/pkgs/development/octave-modules/fits/default.nix index 9d236cb9f1fa50..5c1cc3c69dd696 100644 --- a/pkgs/development/octave-modules/fits/default.nix +++ b/pkgs/development/octave-modules/fits/default.nix @@ -1,9 +1,10 @@ -{ buildOctavePackage -, lib -, fetchurl -, cfitsio -, hdf5 -, pkg-config +{ + buildOctavePackage, + lib, + fetchurl, + cfitsio, + hdf5, + pkg-config, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/fpl/default.nix b/pkgs/development/octave-modules/fpl/default.nix index e5b276c0c20de9..75c7386deaf512 100644 --- a/pkgs/development/octave-modules/fpl/default.nix +++ b/pkgs/development/octave-modules/fpl/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/fuzzy-logic-toolkit/default.nix b/pkgs/development/octave-modules/fuzzy-logic-toolkit/default.nix index 5d6a188bd77da7..11f6551375e90d 100644 --- a/pkgs/development/octave-modules/fuzzy-logic-toolkit/default.nix +++ b/pkgs/development/octave-modules/fuzzy-logic-toolkit/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchFromGitHub +{ + buildOctavePackage, + lib, + fetchFromGitHub, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/ga/default.nix b/pkgs/development/octave-modules/ga/default.nix index 6c7f8e09460200..3f6367d4f667fc 100644 --- a/pkgs/development/octave-modules/ga/default.nix +++ b/pkgs/development/octave-modules/ga/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/general/default.nix b/pkgs/development/octave-modules/general/default.nix index 33caeb1ea554c0..e424e11c97dd3a 100644 --- a/pkgs/development/octave-modules/general/default.nix +++ b/pkgs/development/octave-modules/general/default.nix @@ -1,8 +1,9 @@ -{ buildOctavePackage -, lib -, fetchurl -, pkg-config -, nettle +{ + buildOctavePackage, + lib, + fetchurl, + pkg-config, + nettle, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/generate_html/default.nix b/pkgs/development/octave-modules/generate_html/default.nix index 2082aa7f8207bb..405f80fcc0d941 100644 --- a/pkgs/development/octave-modules/generate_html/default.nix +++ b/pkgs/development/octave-modules/generate_html/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/geometry/default.nix b/pkgs/development/octave-modules/geometry/default.nix index 86ef985fd1b0d6..27f0c320d4dcba 100644 --- a/pkgs/development/octave-modules/geometry/default.nix +++ b/pkgs/development/octave-modules/geometry/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, lib -, fetchhg -, matgeom +{ + buildOctavePackage, + lib, + fetchhg, + matgeom, }: buildOctavePackage rec { @@ -20,7 +21,10 @@ buildOctavePackage rec { meta = with lib; { homepage = "https://octave.sourceforge.io/geometry/index.html"; - license = with licenses; [ gpl3Plus boost ]; + license = with licenses; [ + gpl3Plus + boost + ]; maintainers = with maintainers; [ KarlJoad ]; description = "Library for extending MatGeom functionality"; }; diff --git a/pkgs/development/octave-modules/gsl/default.nix b/pkgs/development/octave-modules/gsl/default.nix index 2ce92f43d61816..e7379d22cc7b27 100644 --- a/pkgs/development/octave-modules/gsl/default.nix +++ b/pkgs/development/octave-modules/gsl/default.nix @@ -1,8 +1,9 @@ -{ buildOctavePackage -, stdenv -, lib -, fetchurl -, gsl +{ + buildOctavePackage, + stdenv, + lib, + fetchurl, + gsl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/image-acquisition/default.nix b/pkgs/development/octave-modules/image-acquisition/default.nix index 69f7c1a60a5463..d04928cbd60339 100644 --- a/pkgs/development/octave-modules/image-acquisition/default.nix +++ b/pkgs/development/octave-modules/image-acquisition/default.nix @@ -1,8 +1,9 @@ -{ buildOctavePackage -, lib -, fetchurl -, libv4l -, fltk +{ + buildOctavePackage, + lib, + fetchurl, + libv4l, + fltk, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/image/default.nix b/pkgs/development/octave-modules/image/default.nix index 78fcedfbd36098..e8748558f9eff2 100644 --- a/pkgs/development/octave-modules/image/default.nix +++ b/pkgs/development/octave-modules/image/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { @@ -18,10 +19,10 @@ buildOctavePackage rec { maintainers = with maintainers; [ KarlJoad ]; description = "Functions for processing images"; longDescription = '' - The Octave-forge Image package provides functions for processing - images. The package also provides functions for feature extraction, - image statistics, spatial and geometric transformations, morphological - operations, linear filtering, and much more. + The Octave-forge Image package provides functions for processing + images. The package also provides functions for feature extraction, + image statistics, spatial and geometric transformations, morphological + operations, linear filtering, and much more. ''; }; } diff --git a/pkgs/development/octave-modules/instrument-control/default.nix b/pkgs/development/octave-modules/instrument-control/default.nix index c975d49278ae95..433bfcf24f6ba8 100644 --- a/pkgs/development/octave-modules/instrument-control/default.nix +++ b/pkgs/development/octave-modules/instrument-control/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/interval/default.nix b/pkgs/development/octave-modules/interval/default.nix index 8cf9d555678c0c..3c46b154bda2f1 100644 --- a/pkgs/development/octave-modules/interval/default.nix +++ b/pkgs/development/octave-modules/interval/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, lib -, fetchurl -, mpfr +{ + buildOctavePackage, + lib, + fetchurl, + mpfr, }: buildOctavePackage rec { @@ -23,17 +24,17 @@ buildOctavePackage rec { maintainers = with maintainers; [ KarlJoad ]; description = "Interval arithmetic to evaluate functions over subsets of their domain"; longDescription = '' - The interval package for real-valued interval arithmetic allows one to - evaluate functions over subsets of their domain. All results are verified, - because interval computations automatically keep track of any errors. + The interval package for real-valued interval arithmetic allows one to + evaluate functions over subsets of their domain. All results are verified, + because interval computations automatically keep track of any errors. - These concepts can be used to handle uncertainties, estimate arithmetic - errors and produce reliable results. Also it can be applied to - computer-assisted proofs, constraint programming, and verified computing. + These concepts can be used to handle uncertainties, estimate arithmetic + errors and produce reliable results. Also it can be applied to + computer-assisted proofs, constraint programming, and verified computing. - The implementation is based on interval boundaries represented by - binary64 numbers and is conforming to IEEE Std 1788-2015, IEEE standard - for interval arithmetic. + The implementation is based on interval boundaries represented by + binary64 numbers and is conforming to IEEE Std 1788-2015, IEEE standard + for interval arithmetic. ''; }; } diff --git a/pkgs/development/octave-modules/io/default.nix b/pkgs/development/octave-modules/io/default.nix index 42effce5a045ea..ac825fd4f91943 100644 --- a/pkgs/development/octave-modules/io/default.nix +++ b/pkgs/development/octave-modules/io/default.nix @@ -1,9 +1,10 @@ -{ buildOctavePackage -, lib -, fetchurl -, enableJava -, jdk -, unzip +{ + buildOctavePackage, + lib, + fetchurl, + enableJava, + jdk, + unzip, }: buildOctavePackage rec { @@ -25,7 +26,10 @@ buildOctavePackage rec { meta = with lib; { homepage = "https://octave.sourceforge.io/io/index.html"; - license = with licenses; [ gpl3Plus bsd2 ]; + license = with licenses; [ + gpl3Plus + bsd2 + ]; maintainers = with maintainers; [ KarlJoad ]; description = "Input/Output in external formats"; }; diff --git a/pkgs/development/octave-modules/level-set/default.nix b/pkgs/development/octave-modules/level-set/default.nix index 325ce0390ada58..c7b4729d2be0ad 100644 --- a/pkgs/development/octave-modules/level-set/default.nix +++ b/pkgs/development/octave-modules/level-set/default.nix @@ -1,10 +1,11 @@ -{ buildOctavePackage -, lib -, fetchgit -, automake -, autoconf -, autoconf-archive -, parallel +{ + buildOctavePackage, + lib, + fetchgit, + automake, + autoconf, + autoconf-archive, + parallel, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/linear-algebra/default.nix b/pkgs/development/octave-modules/linear-algebra/default.nix index 18818c1db60647..f7205dede500ad 100644 --- a/pkgs/development/octave-modules/linear-algebra/default.nix +++ b/pkgs/development/octave-modules/linear-algebra/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { @@ -14,7 +15,10 @@ buildOctavePackage rec { meta = with lib; { homepage = "https://octave.sourceforge.io/linear-algebra/index.html"; - license = with licenses; [ gpl3Plus lgpl3Plus ]; + license = with licenses; [ + gpl3Plus + lgpl3Plus + ]; # They claim to have a FreeBSD license, but none of their code seems to have it. maintainers = with maintainers; [ KarlJoad ]; description = "Additional linear algebra code, including matrix functions"; diff --git a/pkgs/development/octave-modules/lssa/default.nix b/pkgs/development/octave-modules/lssa/default.nix index f737c104f3021d..2635c57e4be26f 100644 --- a/pkgs/development/octave-modules/lssa/default.nix +++ b/pkgs/development/octave-modules/lssa/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { @@ -18,10 +19,10 @@ buildOctavePackage rec { maintainers = with maintainers; [ KarlJoad ]; description = "Tools to compute spectral decompositions of irregularly-spaced time series"; longDescription = '' - A package implementing tools to compute spectral decompositions of - irregularly-spaced time series. Currently includes functions based off - the Lomb-Scargle periodogram and Adolf Mathias' implementation for R - and C. + A package implementing tools to compute spectral decompositions of + irregularly-spaced time series. Currently includes functions based off + the Lomb-Scargle periodogram and Adolf Mathias' implementation for R + and C. ''; }; } diff --git a/pkgs/development/octave-modules/ltfat/default.nix b/pkgs/development/octave-modules/ltfat/default.nix index b48472d3c28aca..43fe020b322ad4 100644 --- a/pkgs/development/octave-modules/ltfat/default.nix +++ b/pkgs/development/octave-modules/ltfat/default.nix @@ -1,14 +1,15 @@ -{ buildOctavePackage -, lib -, fetchurl -, fftw -, fftwSinglePrec -, fftwFloat -, fftwLongDouble -, lapack -, blas -, portaudio -, jdk +{ + buildOctavePackage, + lib, + fetchurl, + fftw, + fftwSinglePrec, + fftwFloat, + fftwLongDouble, + lapack, + blas, + portaudio, + jdk, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/mapping/default.nix b/pkgs/development/octave-modules/mapping/default.nix index 13d7fd5dd526a8..39a3023c520304 100644 --- a/pkgs/development/octave-modules/mapping/default.nix +++ b/pkgs/development/octave-modules/mapping/default.nix @@ -1,9 +1,10 @@ -{ buildOctavePackage -, lib -, fetchurl -, io # >= 2.2.7 -, geometry # >= 4.0.0 -, gdal +{ + buildOctavePackage, + lib, + fetchurl, + io, # >= 2.2.7 + geometry, # >= 4.0.0 + gdal, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/matgeom/default.nix b/pkgs/development/octave-modules/matgeom/default.nix index c74b8b00cfbeff..243c9b67e4ec84 100644 --- a/pkgs/development/octave-modules/matgeom/default.nix +++ b/pkgs/development/octave-modules/matgeom/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { @@ -14,7 +15,10 @@ buildOctavePackage rec { meta = with lib; { homepage = "https://octave.sourceforge.io/matgeom/index.html"; - license = with licenses; [ bsd2 gpl3Plus ]; + license = with licenses; [ + bsd2 + gpl3Plus + ]; maintainers = with maintainers; [ KarlJoad ]; description = "Geometry toolbox for 2D/3D geometric computing"; }; diff --git a/pkgs/development/octave-modules/miscellaneous/default.nix b/pkgs/development/octave-modules/miscellaneous/default.nix index 64edb8e9a41889..e39ad4bd293113 100644 --- a/pkgs/development/octave-modules/miscellaneous/default.nix +++ b/pkgs/development/octave-modules/miscellaneous/default.nix @@ -1,9 +1,10 @@ -{ buildOctavePackage -, lib -, fetchurl -# Build-time dependencies -, ncurses # >= 5 -, units +{ + buildOctavePackage, + lib, + fetchurl, + # Build-time dependencies + ncurses, # >= 5 + units, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/msh/default.nix b/pkgs/development/octave-modules/msh/default.nix index e147b9a9c2a2e5..181b0c2ac58fc8 100644 --- a/pkgs/development/octave-modules/msh/default.nix +++ b/pkgs/development/octave-modules/msh/default.nix @@ -1,14 +1,16 @@ -{ buildOctavePackage -, lib -, fetchFromGitHub -# Octave Dependencies -, splines -# Other Dependencies -, gmsh -, gawk -, pkg-config -, dolfin -, autoconf, automake +{ + buildOctavePackage, + lib, + fetchFromGitHub, + # Octave Dependencies + splines, + # Other Dependencies + gmsh, + gawk, + pkg-config, + dolfin, + autoconf, + automake, }: buildOctavePackage rec { @@ -24,7 +26,8 @@ buildOctavePackage rec { nativeBuildInputs = [ pkg-config - autoconf automake + autoconf + automake dolfin ]; diff --git a/pkgs/development/octave-modules/mvn/default.nix b/pkgs/development/octave-modules/mvn/default.nix index 06fd1905604dd8..65568d305dd3a9 100644 --- a/pkgs/development/octave-modules/mvn/default.nix +++ b/pkgs/development/octave-modules/mvn/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/nan/default.nix b/pkgs/development/octave-modules/nan/default.nix index 59d71d8769e0bf..5146d4c189836c 100644 --- a/pkgs/development/octave-modules/nan/default.nix +++ b/pkgs/development/octave-modules/nan/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, lib -, fetchurl -, blas +{ + buildOctavePackage, + lib, + fetchurl, + blas, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/ncarray/default.nix b/pkgs/development/octave-modules/ncarray/default.nix index 0c5546ffd121df..57940c3411a3bc 100644 --- a/pkgs/development/octave-modules/ncarray/default.nix +++ b/pkgs/development/octave-modules/ncarray/default.nix @@ -1,8 +1,9 @@ -{ buildOctavePackage -, lib -, fetchurl -, netcdf -, statistics +{ + buildOctavePackage, + lib, + fetchurl, + netcdf, + statistics, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/nurbs/default.nix b/pkgs/development/octave-modules/nurbs/default.nix index fbd67a0a46a94a..dfe3105d860b5c 100644 --- a/pkgs/development/octave-modules/nurbs/default.nix +++ b/pkgs/development/octave-modules/nurbs/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/ocl/default.nix b/pkgs/development/octave-modules/ocl/default.nix index 72242d165543e1..015441db1acc23 100644 --- a/pkgs/development/octave-modules/ocl/default.nix +++ b/pkgs/development/octave-modules/ocl/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, stdenv -, lib -, fetchurl +{ + buildOctavePackage, + stdenv, + lib, + fetchurl, }: buildOctavePackage rec { @@ -19,9 +20,9 @@ buildOctavePackage rec { maintainers = with maintainers; [ KarlJoad ]; description = "Use OpenCL for parallelization"; longDescription = '' - Package using OpenCL for parallelization, mostly suitable to - Single-Instruction-Multiple-Data (SIMD) computations, selectively - using available OpenCL hardware and drivers. + Package using OpenCL for parallelization, mostly suitable to + Single-Instruction-Multiple-Data (SIMD) computations, selectively + using available OpenCL hardware and drivers. ''; # error: structure has no member 'dir' broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/development/octave-modules/octclip/default.nix b/pkgs/development/octave-modules/octclip/default.nix index c70a5ffc137acf..cefd09e7a25b5e 100644 --- a/pkgs/development/octave-modules/octclip/default.nix +++ b/pkgs/development/octave-modules/octclip/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchFromBitbucket +{ + buildOctavePackage, + lib, + fetchFromBitbucket, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/octproj/default.nix b/pkgs/development/octave-modules/octproj/default.nix index bc0dd4ea2132ef..d8da27eceb835f 100644 --- a/pkgs/development/octave-modules/octproj/default.nix +++ b/pkgs/development/octave-modules/octproj/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, lib -, fetchFromBitbucket -, proj # >= 6.3.0 +{ + buildOctavePackage, + lib, + fetchFromBitbucket, + proj, # >= 6.3.0 }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/optics/default.nix b/pkgs/development/octave-modules/optics/default.nix index 1324c6cd4ba332..c72df5c360a433 100644 --- a/pkgs/development/octave-modules/optics/default.nix +++ b/pkgs/development/octave-modules/optics/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/optim/default.nix b/pkgs/development/octave-modules/optim/default.nix index 5a99fc3f9a68fc..fd6282ccee660d 100644 --- a/pkgs/development/octave-modules/optim/default.nix +++ b/pkgs/development/octave-modules/optim/default.nix @@ -1,10 +1,11 @@ -{ buildOctavePackage -, lib -, fetchurl -, struct -, statistics -, lapack -, blas +{ + buildOctavePackage, + lib, + fetchurl, + struct, + statistics, + lapack, + blas, }: buildOctavePackage rec { @@ -28,7 +29,10 @@ buildOctavePackage rec { meta = with lib; { homepage = "https://octave.sourceforge.io/optim/index.html"; - license = with licenses; [ gpl3Plus publicDomain ]; + license = with licenses; [ + gpl3Plus + publicDomain + ]; # Modified BSD code seems removed maintainers = with maintainers; [ KarlJoad ]; description = "Non-linear optimization toolkit"; diff --git a/pkgs/development/octave-modules/optiminterp/default.nix b/pkgs/development/octave-modules/optiminterp/default.nix index b1c676b149769e..439d8b687dd64b 100644 --- a/pkgs/development/octave-modules/optiminterp/default.nix +++ b/pkgs/development/octave-modules/optiminterp/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, lib -, fetchurl -, gfortran +{ + buildOctavePackage, + lib, + fetchurl, + gfortran, }: buildOctavePackage rec { @@ -23,9 +24,9 @@ buildOctavePackage rec { maintainers = with maintainers; [ KarlJoad ]; description = "Optimal interpolation toolbox for octave"; longDescription = '' - An optimal interpolation toolbox for octave. This package provides - functions to perform a n-dimensional optimal interpolations of - arbitrarily distributed data points. + An optimal interpolation toolbox for octave. This package provides + functions to perform a n-dimensional optimal interpolations of + arbitrarily distributed data points. ''; }; } diff --git a/pkgs/development/octave-modules/parallel/default.nix b/pkgs/development/octave-modules/parallel/default.nix index 45c57d72f20fb5..342ac6a53cdbfb 100644 --- a/pkgs/development/octave-modules/parallel/default.nix +++ b/pkgs/development/octave-modules/parallel/default.nix @@ -1,9 +1,10 @@ -{ buildOctavePackage -, lib -, fetchurl -, struct -, gnutls -, pkg-config +{ + buildOctavePackage, + lib, + fetchurl, + struct, + gnutls, + pkg-config, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/quaternion/default.nix b/pkgs/development/octave-modules/quaternion/default.nix index 4681b699684c46..b87771c7d52da9 100644 --- a/pkgs/development/octave-modules/quaternion/default.nix +++ b/pkgs/development/octave-modules/quaternion/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/queueing/default.nix b/pkgs/development/octave-modules/queueing/default.nix index 75b3e67e353691..db0a635b9a092a 100644 --- a/pkgs/development/octave-modules/queueing/default.nix +++ b/pkgs/development/octave-modules/queueing/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/signal/default.nix b/pkgs/development/octave-modules/signal/default.nix index 1693d8360628dc..b19e8d16a0aee3 100644 --- a/pkgs/development/octave-modules/signal/default.nix +++ b/pkgs/development/octave-modules/signal/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, lib -, fetchurl -, control +{ + buildOctavePackage, + lib, + fetchurl, + control, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/sockets/default.nix b/pkgs/development/octave-modules/sockets/default.nix index 80f2f6dc15eb87..3c114f7e05c961 100644 --- a/pkgs/development/octave-modules/sockets/default.nix +++ b/pkgs/development/octave-modules/sockets/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/sparsersb/default.nix b/pkgs/development/octave-modules/sparsersb/default.nix index 41ee75cb1a800d..d7c1beea493b94 100644 --- a/pkgs/development/octave-modules/sparsersb/default.nix +++ b/pkgs/development/octave-modules/sparsersb/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, lib -, fetchurl -, librsb +{ + buildOctavePackage, + lib, + fetchurl, + librsb, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/splines/default.nix b/pkgs/development/octave-modules/splines/default.nix index 1e05ef98c0ce81..90330d2b74417f 100644 --- a/pkgs/development/octave-modules/splines/default.nix +++ b/pkgs/development/octave-modules/splines/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { @@ -14,7 +15,10 @@ buildOctavePackage rec { meta = with lib; { homepage = "https://octave.sourceforge.io/splines/index.html"; - license = with licenses; [ gpl3Plus publicDomain ]; + license = with licenses; [ + gpl3Plus + publicDomain + ]; maintainers = with maintainers; [ KarlJoad ]; description = "Additional spline functions"; }; diff --git a/pkgs/development/octave-modules/statistics/default.nix b/pkgs/development/octave-modules/statistics/default.nix index 48fbb9a67c322f..c914bb75be3b0e 100644 --- a/pkgs/development/octave-modules/statistics/default.nix +++ b/pkgs/development/octave-modules/statistics/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, lib -, fetchFromGitHub -, io +{ + buildOctavePackage, + lib, + fetchFromGitHub, + io, }: buildOctavePackage rec { @@ -21,7 +22,10 @@ buildOctavePackage rec { meta = with lib; { homepage = "https://packages.octave.org/statistics"; - license = with licenses; [ gpl3Plus publicDomain ]; + license = with licenses; [ + gpl3Plus + publicDomain + ]; maintainers = with maintainers; [ KarlJoad ]; description = "Statistics package for GNU Octave"; }; diff --git a/pkgs/development/octave-modules/stk/default.nix b/pkgs/development/octave-modules/stk/default.nix index 7afebb9ad942dd..13bea3633e2baa 100644 --- a/pkgs/development/octave-modules/stk/default.nix +++ b/pkgs/development/octave-modules/stk/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/strings/default.nix b/pkgs/development/octave-modules/strings/default.nix index fbf7aec786afcd..800cc0b0b7ece6 100644 --- a/pkgs/development/octave-modules/strings/default.nix +++ b/pkgs/development/octave-modules/strings/default.nix @@ -1,9 +1,10 @@ -{ buildOctavePackage -, stdenv -, lib -, fetchurl -, pkg-config -, pcre2 +{ + buildOctavePackage, + stdenv, + lib, + fetchurl, + pkg-config, + pcre2, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/struct/default.nix b/pkgs/development/octave-modules/struct/default.nix index 91597d94f03ee3..2a89fa86940b65 100644 --- a/pkgs/development/octave-modules/struct/default.nix +++ b/pkgs/development/octave-modules/struct/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/symbolic/default.nix b/pkgs/development/octave-modules/symbolic/default.nix index 06920cfb6d5019..38bd1753ce2c5d 100644 --- a/pkgs/development/octave-modules/symbolic/default.nix +++ b/pkgs/development/octave-modules/symbolic/default.nix @@ -1,8 +1,9 @@ -{ buildOctavePackage -, lib -, fetchFromGitHub +{ + buildOctavePackage, + lib, + fetchFromGitHub, # Octave's Python (Python 3) -, python + python, }: let diff --git a/pkgs/development/octave-modules/tisean/default.nix b/pkgs/development/octave-modules/tisean/default.nix index 71d05dc7a1f004..a20810058af12d 100644 --- a/pkgs/development/octave-modules/tisean/default.nix +++ b/pkgs/development/octave-modules/tisean/default.nix @@ -1,10 +1,11 @@ -{ buildOctavePackage -, lib -, fetchurl -# Octave dependencies -, signal # >= 1.3.0 -# Build dependencies -, gfortran +{ + buildOctavePackage, + lib, + fetchurl, + # Octave dependencies + signal, # >= 1.3.0 + # Build dependencies + gfortran, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/tsa/default.nix b/pkgs/development/octave-modules/tsa/default.nix index 985612fa8c7af0..52d61b070e0a58 100644 --- a/pkgs/development/octave-modules/tsa/default.nix +++ b/pkgs/development/octave-modules/tsa/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, lib -, fetchurl -, nan # > 3.0.0 +{ + buildOctavePackage, + lib, + fetchurl, + nan, # > 3.0.0 }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/vibes/default.nix b/pkgs/development/octave-modules/vibes/default.nix index 4d05a2c6893f7e..53c49f43553fcc 100644 --- a/pkgs/development/octave-modules/vibes/default.nix +++ b/pkgs/development/octave-modules/vibes/default.nix @@ -1,7 +1,8 @@ -{ buildOctavePackage -, lib -, fetchurl -, vibes +{ + buildOctavePackage, + lib, + fetchurl, + vibes, }: buildOctavePackage rec { @@ -19,7 +20,10 @@ buildOctavePackage rec { meta = with lib; { homepage = "https://octave.sourceforge.io/vibes/index.html"; - license = with licenses; [ gpl3Plus mit ]; + license = with licenses; [ + gpl3Plus + mit + ]; maintainers = with maintainers; [ KarlJoad ]; description = "Easily display results (boxes, pavings) from interval methods"; longDescription = '' diff --git a/pkgs/development/octave-modules/video/default.nix b/pkgs/development/octave-modules/video/default.nix index 798607fb34be91..903d68589d2f88 100644 --- a/pkgs/development/octave-modules/video/default.nix +++ b/pkgs/development/octave-modules/video/default.nix @@ -1,9 +1,10 @@ -{ buildOctavePackage -, stdenv -, lib -, fetchFromGitHub -, pkg-config -, ffmpeg +{ + buildOctavePackage, + stdenv, + lib, + fetchFromGitHub, + pkg-config, + ffmpeg, }: buildOctavePackage rec { @@ -27,7 +28,10 @@ buildOctavePackage rec { meta = with lib; { homepage = "https://octave.sourceforge.io/video/index.html"; - license = with licenses; [ gpl3Plus bsd3 ]; + license = with licenses; [ + gpl3Plus + bsd3 + ]; maintainers = with maintainers; [ KarlJoad ]; description = "Wrapper for OpenCV's CvCapture_FFMPEG and CvVideoWriter_FFMPEG"; }; diff --git a/pkgs/development/octave-modules/vrml/default.nix b/pkgs/development/octave-modules/vrml/default.nix index e46e621b80d9ab..a36326ea989ac2 100644 --- a/pkgs/development/octave-modules/vrml/default.nix +++ b/pkgs/development/octave-modules/vrml/default.nix @@ -1,13 +1,14 @@ -{ buildOctavePackage -, lib -, fetchurl -# Octave dependencies -, linear-algebra -, miscellaneous -, struct -, statistics -# Runtime dependencies -, freewrl +{ + buildOctavePackage, + lib, + fetchurl, + # Octave dependencies + linear-algebra, + miscellaneous, + struct, + statistics, + # Runtime dependencies + freewrl, }: buildOctavePackage rec { @@ -32,7 +33,10 @@ buildOctavePackage rec { meta = with lib; { homepage = "https://octave.sourceforge.io/vrml/index.html"; - license = with licenses; [ gpl3Plus fdl12Plus ]; + license = with licenses; [ + gpl3Plus + fdl12Plus + ]; maintainers = with maintainers; [ KarlJoad ]; description = "3D graphics using VRML"; # Marked this way until KarlJoad gets freewrl as a runtime dependency. diff --git a/pkgs/development/octave-modules/windows/default.nix b/pkgs/development/octave-modules/windows/default.nix index 1ecbce2f529628..6ffec8edcb47f7 100644 --- a/pkgs/development/octave-modules/windows/default.nix +++ b/pkgs/development/octave-modules/windows/default.nix @@ -1,6 +1,7 @@ -{ buildOctavePackage -, lib -, fetchurl +{ + buildOctavePackage, + lib, + fetchurl, }: buildOctavePackage rec { diff --git a/pkgs/development/octave-modules/zeromq/default.nix b/pkgs/development/octave-modules/zeromq/default.nix index 33c0d70464af50..f5a31142263080 100644 --- a/pkgs/development/octave-modules/zeromq/default.nix +++ b/pkgs/development/octave-modules/zeromq/default.nix @@ -1,9 +1,10 @@ -{ buildOctavePackage -, lib -, fetchurl -, zeromq -, pkg-config -, autoreconfHook +{ + buildOctavePackage, + lib, + fetchurl, + zeromq, + pkg-config, + autoreconfHook, }: buildOctavePackage rec { diff --git a/pkgs/development/perl-modules/Bio-BigFile/default.nix b/pkgs/development/perl-modules/Bio-BigFile/default.nix index 3c360c2396a8db..fe4c85490ba45f 100644 --- a/pkgs/development/perl-modules/Bio-BigFile/default.nix +++ b/pkgs/development/perl-modules/Bio-BigFile/default.nix @@ -1,14 +1,14 @@ { - BioPerl, - IOString, - buildPerlModule, - fetchFromGitHub, - fetchurl, - kent, - lib, - libmysqlclient, - libpng, - openssl, + BioPerl, + IOString, + buildPerlModule, + fetchFromGitHub, + fetchurl, + kent, + lib, + libmysqlclient, + libpng, + openssl, }: buildPerlModule rec { @@ -43,7 +43,6 @@ buildPerlModule rec { ]; }); - buildInputs = [ BioPerl IOString diff --git a/pkgs/development/perl-modules/Bio-Ext-Align/default.nix b/pkgs/development/perl-modules/Bio-Ext-Align/default.nix index 237a4be03614ff..dde83f2b0f2330 100644 --- a/pkgs/development/perl-modules/Bio-Ext-Align/default.nix +++ b/pkgs/development/perl-modules/Bio-Ext-Align/default.nix @@ -1,15 +1,22 @@ -{ lib, buildPerlPackage, fetchFromGitHub }: +{ + lib, + buildPerlPackage, + fetchFromGitHub, +}: buildPerlPackage rec { pname = "BioExtAlign"; version = "1.5.1"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; src = fetchFromGitHub { owner = "bioperl"; repo = "bioperl-ext"; - rev = "bioperl-ext-release-${lib.replaceStrings ["."] ["-"] version}"; + rev = "bioperl-ext-release-${lib.replaceStrings [ "." ] [ "-" ] version}"; sha256 = "sha256-+0tZ6q3PFem8DWa2vq+njOLmjDvMB0JhD0FGk00lVMA="; }; diff --git a/pkgs/development/perl-modules/ImageExifTool/default.nix b/pkgs/development/perl-modules/ImageExifTool/default.nix index 7a282e4acf7e13..23ec4187531902 100644 --- a/pkgs/development/perl-modules/ImageExifTool/default.nix +++ b/pkgs/development/perl-modules/ImageExifTool/default.nix @@ -52,8 +52,14 @@ buildPerlPackage rec { ''; homepage = "https://exiftool.org/"; changelog = "https://exiftool.org/history.html"; - license = with lib.licenses; [ gpl1Plus /* or */ artistic2 ]; - maintainers = with lib.maintainers; [ kiloreux anthonyroussel ]; + license = with lib.licenses; [ + gpl1Plus # or + artistic2 + ]; + maintainers = with lib.maintainers; [ + kiloreux + anthonyroussel + ]; mainProgram = "exiftool"; }; } diff --git a/pkgs/development/perl-modules/MNI/default.nix b/pkgs/development/perl-modules/MNI/default.nix index 067a08f5e5a10e..b1e66804f8dede 100644 --- a/pkgs/development/perl-modules/MNI/default.nix +++ b/pkgs/development/perl-modules/MNI/default.nix @@ -1,24 +1,31 @@ -{ fetchFromGitHub, buildPerlPackage, lib }: +{ + fetchFromGitHub, + buildPerlPackage, + lib, +}: buildPerlPackage { pname = "MNI-Perllib"; version = "2012-04-13"; src = fetchFromGitHub { - owner = "BIC-MNI"; - repo = "mni-perllib"; - rev = "b908472b4390180ea5d19a121ac5edad6ed88d83"; + owner = "BIC-MNI"; + repo = "mni-perllib"; + rev = "b908472b4390180ea5d19a121ac5edad6ed88d83"; sha256 = "0vk99pwgbard62k63386r7dpnm3h435jdqywr4xqfq7p04dz6kyb"; }; patches = [ ./no-stdin.patch ]; - doCheck = false; # TODO: almost all tests fail ... is this a real problem? + doCheck = false; # TODO: almost all tests fail ... is this a real problem? meta = { description = "MNI MINC perllib (not used much anymore)"; homepage = "https://github.com/BIC-MNI/mni-perllib"; - license = with lib.licenses; [ artistic1 gpl1Plus ]; + license = with lib.licenses; [ + artistic1 + gpl1Plus + ]; maintainers = with lib.maintainers; [ bcdarwin ]; }; } diff --git a/pkgs/development/perl-modules/Mozilla-LDAP/default.nix b/pkgs/development/perl-modules/Mozilla-LDAP/default.nix index 6c3d01a3462954..39d7011d4cf57d 100644 --- a/pkgs/development/perl-modules/Mozilla-LDAP/default.nix +++ b/pkgs/development/perl-modules/Mozilla-LDAP/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, openldap, buildPerlPackage }: +{ + lib, + fetchurl, + openldap, + buildPerlPackage, +}: buildPerlPackage rec { pname = "Mozilla-Ldap"; @@ -13,6 +18,10 @@ buildPerlPackage rec { meta = { description = "Mozilla's ldap client library"; homepage = "https://metacpan.org/release/perldap"; - license = with lib.licenses; [ mpl20 lgpl21Plus gpl2Plus ]; + license = with lib.licenses; [ + mpl20 + lgpl21Plus + gpl2Plus + ]; }; } diff --git a/pkgs/development/perl-modules/Tirex/default.nix b/pkgs/development/perl-modules/Tirex/default.nix index 48e63bb5932c49..91138974222e35 100644 --- a/pkgs/development/perl-modules/Tirex/default.nix +++ b/pkgs/development/perl-modules/Tirex/default.nix @@ -1,14 +1,15 @@ -{ lib -, buildPerlPackage -, fetchFromGitHub -, fetchpatch -, GD -, IPCShareLite -, JSON -, LWP -, mapnik -, boost -, nix-update-script +{ + lib, + buildPerlPackage, + fetchFromGitHub, + fetchpatch, + GD, + IPCShareLite, + JSON, + LWP, + mapnik, + boost, + nix-update-script, }: buildPerlPackage rec { diff --git a/pkgs/development/perl-modules/generic/default.nix b/pkgs/development/perl-modules/generic/default.nix index 73c09f4dbe9f5b..583a8c862cebe0 100644 --- a/pkgs/development/perl-modules/generic/default.nix +++ b/pkgs/development/perl-modules/generic/default.nix @@ -1,57 +1,81 @@ -{ lib, stdenv, perl, toPerlModule }: - -{ buildInputs ? [] -, nativeBuildInputs ? [] -, outputs ? [ "out" "devdoc" ] -, src ? null - -# enabling or disabling does nothing for perl packages so set it explicitly -# to false to not change hashes when enableParallelBuildingByDefault is enabled -, enableParallelBuilding ? false - -, doCheck ? true -, checkTarget ? "test" - -# Prevent CPAN downloads. -, PERL_AUTOINSTALL ? "--skipdeps" - -# From http://wiki.cpantesters.org/wiki/CPANAuthorNotes: "allows -# authors to skip certain tests (or include certain tests) when -# the results are not being monitored by a human being." -, AUTOMATED_TESTING ? true - -# current directory (".") is removed from @INC in Perl 5.26 but many old libs rely on it -# https://metacpan.org/pod/release/XSAWYERX/perl-5.26.0/pod/perldelta.pod#Removal-of-the-current-directory-%28%22.%22%29-from-@INC -, PERL_USE_UNSAFE_INC ? "1" - -, env ? {} - -, ... +{ + lib, + stdenv, + perl, + toPerlModule, +}: + +{ + buildInputs ? [ ], + nativeBuildInputs ? [ ], + outputs ? [ + "out" + "devdoc" + ], + src ? null, + + # enabling or disabling does nothing for perl packages so set it explicitly + # to false to not change hashes when enableParallelBuildingByDefault is enabled + enableParallelBuilding ? false, + + doCheck ? true, + checkTarget ? "test", + + # Prevent CPAN downloads. + PERL_AUTOINSTALL ? "--skipdeps", + + # From http://wiki.cpantesters.org/wiki/CPANAuthorNotes: "allows + # authors to skip certain tests (or include certain tests) when + # the results are not being monitored by a human being." + AUTOMATED_TESTING ? true, + + # current directory (".") is removed from @INC in Perl 5.26 but many old libs rely on it + # https://metacpan.org/pod/release/XSAWYERX/perl-5.26.0/pod/perldelta.pod#Removal-of-the-current-directory-%28%22.%22%29-from-@INC + PERL_USE_UNSAFE_INC ? "1", + + env ? { }, + + ... }@attrs: -lib.throwIf (attrs ? name) "buildPerlPackage: `name` (\"${attrs.name}\") is deprecated, use `pname` and `version` instead" - -(let - defaultMeta = { - homepage = "https://metacpan.org/dist/${attrs.pname}"; - inherit (perl.meta) platforms; - }; - - package = stdenv.mkDerivation (attrs // { - name = "perl${perl.version}-${attrs.pname}-${attrs.version}"; - - builder = ./builder.sh; - - buildInputs = buildInputs ++ [ perl ]; - nativeBuildInputs = nativeBuildInputs ++ (if !(stdenv.buildPlatform.canExecute stdenv.hostPlatform) then [ perl.mini ] else [ perl ]); - - inherit outputs src doCheck checkTarget enableParallelBuilding; - env = { - inherit PERL_AUTOINSTALL AUTOMATED_TESTING PERL_USE_UNSAFE_INC; - fullperl = perl.__spliced.buildHost or perl; - } // env; - - meta = defaultMeta // (attrs.meta or { }); - }); - -in toPerlModule package) +lib.throwIf (attrs ? name) + "buildPerlPackage: `name` (\"${attrs.name}\") is deprecated, use `pname` and `version` instead" + + ( + let + defaultMeta = { + homepage = "https://metacpan.org/dist/${attrs.pname}"; + inherit (perl.meta) platforms; + }; + + package = stdenv.mkDerivation ( + attrs + // { + name = "perl${perl.version}-${attrs.pname}-${attrs.version}"; + + builder = ./builder.sh; + + buildInputs = buildInputs ++ [ perl ]; + nativeBuildInputs = + nativeBuildInputs + ++ (if !(stdenv.buildPlatform.canExecute stdenv.hostPlatform) then [ perl.mini ] else [ perl ]); + + inherit + outputs + src + doCheck + checkTarget + enableParallelBuilding + ; + env = { + inherit PERL_AUTOINSTALL AUTOMATED_TESTING PERL_USE_UNSAFE_INC; + fullperl = perl.__spliced.buildHost or perl; + } // env; + + meta = defaultMeta // (attrs.meta or { }); + } + ); + + in + toPerlModule package + ) diff --git a/pkgs/development/perl-modules/ham/default.nix b/pkgs/development/perl-modules/ham/default.nix index b25adff4c800dc..65d9701d614dd3 100644 --- a/pkgs/development/perl-modules/ham/default.nix +++ b/pkgs/development/perl-modules/ham/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildPerlPackage -, fetchFromGitHub -, makeWrapper -, openssh -, GitRepository -, URI -, XMLParser +{ + lib, + buildPerlPackage, + fetchFromGitHub, + makeWrapper, + openssh, + GitRepository, + URI, + XMLParser, }: buildPerlPackage { @@ -22,7 +23,12 @@ buildPerlPackage { outputs = [ "out" ]; nativeBuildInputs = [ makeWrapper ]; - propagatedBuildInputs = [ openssh GitRepository URI XMLParser ]; + propagatedBuildInputs = [ + openssh + GitRepository + URI + XMLParser + ]; preConfigure = '' patchShebangs . diff --git a/pkgs/development/perl-modules/maatkit/default.nix b/pkgs/development/perl-modules/maatkit/default.nix index d6945083f63434..7a0ad7bae4b7da 100644 --- a/pkgs/development/perl-modules/maatkit/default.nix +++ b/pkgs/development/perl-modules/maatkit/default.nix @@ -1,4 +1,9 @@ -{buildPerlPackage, lib, fetchurl, DBDmysql}: +{ + buildPerlPackage, + lib, + fetchurl, + DBDmysql, +}: buildPerlPackage { pname = "maatkit"; @@ -11,7 +16,7 @@ buildPerlPackage { outputs = [ "out" ]; - buildInputs = [ DBDmysql ] ; + buildInputs = [ DBDmysql ]; preConfigure = '' find . | while read fn; do @@ -25,7 +30,7 @@ buildPerlPackage { fi fi done - '' ; + ''; meta = with lib; { description = "Database toolkit"; diff --git a/pkgs/development/perl-modules/strip-nondeterminism/default.nix b/pkgs/development/perl-modules/strip-nondeterminism/default.nix index fe6328ea39462c..29fa3f1dc900a0 100644 --- a/pkgs/development/perl-modules/strip-nondeterminism/default.nix +++ b/pkgs/development/perl-modules/strip-nondeterminism/default.nix @@ -1,19 +1,23 @@ -{ lib -, stdenv -, file -, fetchFromGitLab -, buildPerlPackage -, ArchiveZip -, ArchiveCpio -, SubOverride -, shortenPerlShebang +{ + lib, + stdenv, + file, + fetchFromGitLab, + buildPerlPackage, + ArchiveZip, + ArchiveCpio, + SubOverride, + shortenPerlShebang, }: buildPerlPackage rec { pname = "strip-nondeterminism"; version = "1.13.1"; - outputs = [ "out" "dev" ]; # no "devdoc" + outputs = [ + "out" + "dev" + ]; # no "devdoc" src = fetchFromGitLab { owner = "reproducible-builds"; @@ -36,18 +40,19 @@ buildPerlPackage rec { --replace "exec('file'" "exec('${lib.getExe file}'" ''; - postBuild = '' patchShebangs ./bin ''; - postInstall = '' - # we don’t need the debhelper script - rm $out/bin/dh_strip_nondeterminism - rm $out/share/man/man1/dh_strip_nondeterminism.1 - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - shortenPerlShebang $out/bin/strip-nondeterminism - ''; + postInstall = + '' + # we don’t need the debhelper script + rm $out/bin/dh_strip_nondeterminism + rm $out/share/man/man1/dh_strip_nondeterminism.1 + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + shortenPerlShebang $out/bin/strip-nondeterminism + ''; installCheckPhase = '' runHook preInstallCheck @@ -64,6 +69,9 @@ buildPerlPackage rec { mainProgram = "strip-nondeterminism"; homepage = "https://reproducible-builds.org/"; license = licenses.gpl3Only; - maintainers = with maintainers; [ pSub artturin ]; + maintainers = with maintainers; [ + pSub + artturin + ]; }; } diff --git a/pkgs/development/python-modules/aiobiketrax/default.nix b/pkgs/development/python-modules/aiobiketrax/default.nix index e75f12130994a6..6b92ffd909efe8 100644 --- a/pkgs/development/python-modules/aiobiketrax/default.nix +++ b/pkgs/development/python-modules/aiobiketrax/default.nix @@ -35,7 +35,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ aiohttp auth0-python diff --git a/pkgs/development/python-modules/aiomisc-pytest/default.nix b/pkgs/development/python-modules/aiomisc-pytest/default.nix index ebbc22e37a22e3..0e0add78bf19fc 100644 --- a/pkgs/development/python-modules/aiomisc-pytest/default.nix +++ b/pkgs/development/python-modules/aiomisc-pytest/default.nix @@ -23,7 +23,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - pythonRelaxDeps = [ "pytest" ]; buildInputs = [ pytest ]; diff --git a/pkgs/development/python-modules/aioopenexchangerates/default.nix b/pkgs/development/python-modules/aioopenexchangerates/default.nix index 42d9511e216e3b..4452d1d75920dc 100644 --- a/pkgs/development/python-modules/aioopenexchangerates/default.nix +++ b/pkgs/development/python-modules/aioopenexchangerates/default.nix @@ -30,7 +30,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ aiohttp mashumaro diff --git a/pkgs/development/python-modules/aiooss2/default.nix b/pkgs/development/python-modules/aiooss2/default.nix index 7d1e235949e702..6f646429f35a82 100644 --- a/pkgs/development/python-modules/aiooss2/default.nix +++ b/pkgs/development/python-modules/aiooss2/default.nix @@ -37,7 +37,6 @@ buildPythonPackage rec { setuptools-scm ]; - dependencies = [ aiohttp oss2 diff --git a/pkgs/development/python-modules/aioxmpp/default.nix b/pkgs/development/python-modules/aioxmpp/default.nix index e753cb6c63dcff..ce69f3037422fa 100644 --- a/pkgs/development/python-modules/aioxmpp/default.nix +++ b/pkgs/development/python-modules/aioxmpp/default.nix @@ -40,7 +40,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ aiosasl aioopenssl @@ -68,21 +67,23 @@ buildPythonPackage rec { disabledTestPaths = [ "benchmarks" ]; - disabledTests = [ - # AttributeError: 'zoneinfo.ZoneInfo' object has no attribute 'normalize' - "test_convert_field_datetime_default_locale" - ] ++ lib.optionals (pythonAtLeast "3.12") [ - # asyncio issues - "test_is_abstract" - "Testbackground" - "TestCapturingXSO" - "Testcheck_x509" - "TestClient" - "TestIntegerType" - "TestStanzaStream" - "TestStanzaToken" - "TestXMLStream" - ]; + disabledTests = + [ + # AttributeError: 'zoneinfo.ZoneInfo' object has no attribute 'normalize' + "test_convert_field_datetime_default_locale" + ] + ++ lib.optionals (pythonAtLeast "3.12") [ + # asyncio issues + "test_is_abstract" + "Testbackground" + "TestCapturingXSO" + "Testcheck_x509" + "TestClient" + "TestIntegerType" + "TestStanzaStream" + "TestStanzaToken" + "TestXMLStream" + ]; meta = { description = "Pure-python XMPP library for asyncio"; diff --git a/pkgs/development/python-modules/aliyun-python-sdk-core/default.nix b/pkgs/development/python-modules/aliyun-python-sdk-core/default.nix index 9fdbb0c65f22b7..65a5778310f6df 100644 --- a/pkgs/development/python-modules/aliyun-python-sdk-core/default.nix +++ b/pkgs/development/python-modules/aliyun-python-sdk-core/default.nix @@ -24,7 +24,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ cryptography jmespath diff --git a/pkgs/development/python-modules/altgraph/default.nix b/pkgs/development/python-modules/altgraph/default.nix index 932896f1beea1e..7c8d02bdf61583 100644 --- a/pkgs/development/python-modules/altgraph/default.nix +++ b/pkgs/development/python-modules/altgraph/default.nix @@ -2,7 +2,7 @@ lib, buildPythonPackage, fetchPypi, - setuptools + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/androidtv/default.nix b/pkgs/development/python-modules/androidtv/default.nix index d07c2530a4506b..f094205e739afa 100644 --- a/pkgs/development/python-modules/androidtv/default.nix +++ b/pkgs/development/python-modules/androidtv/default.nix @@ -39,10 +39,13 @@ buildPythonPackage rec { inherit (adb-shell.optional-dependencies) usb; }; - nativeCheckInputs = [ - mock - pytestCheckHook - ] ++ optional-dependencies.async ++ optional-dependencies.usb; + nativeCheckInputs = + [ + mock + pytestCheckHook + ] + ++ optional-dependencies.async + ++ optional-dependencies.usb; disabledTests = [ # Requires git but fails anyway diff --git a/pkgs/development/python-modules/appthreat-vulnerability-db/default.nix b/pkgs/development/python-modules/appthreat-vulnerability-db/default.nix index acb87d74c27569..3a2916887bafb1 100644 --- a/pkgs/development/python-modules/appthreat-vulnerability-db/default.nix +++ b/pkgs/development/python-modules/appthreat-vulnerability-db/default.nix @@ -40,7 +40,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ appdirs apsw diff --git a/pkgs/development/python-modules/arsenic/default.nix b/pkgs/development/python-modules/arsenic/default.nix index 8d7ab341c9d2bc..cd5488578c626c 100644 --- a/pkgs/development/python-modules/arsenic/default.nix +++ b/pkgs/development/python-modules/arsenic/default.nix @@ -42,7 +42,6 @@ buildPythonPackage rec { pythonRelaxDeps = [ "structlog" ]; - build-system = [ poetry-core ]; dependencies = [ diff --git a/pkgs/development/python-modules/ase/default.nix b/pkgs/development/python-modules/ase/default.nix index dbdcbce0675395..59caf790cad378 100644 --- a/pkgs/development/python-modules/ase/default.nix +++ b/pkgs/development/python-modules/ase/default.nix @@ -32,16 +32,18 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ - numpy - scipy - matplotlib - flask - pillow - psycopg2 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - tkinter - ]; + dependencies = + [ + numpy + scipy + matplotlib + flask + pillow + psycopg2 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + tkinter + ]; nativeCheckInputs = [ pytestCheckHook diff --git a/pkgs/development/python-modules/asyncua/default.nix b/pkgs/development/python-modules/asyncua/default.nix index 59c42fd028383e..6a9b6d278049fd 100644 --- a/pkgs/development/python-modules/asyncua/default.nix +++ b/pkgs/development/python-modules/asyncua/default.nix @@ -61,17 +61,19 @@ buildPythonPackage rec { pythonImportsCheck = [ "asyncua" ]; - disabledTests = [ - # Failed: DID NOT RAISE - "test_publish" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # OSError: [Errno 48] error while attempting to bind on address ('127.0.0.1',... - "test_anonymous_rejection" - "test_certificate_handling_success" - "test_encrypted_private_key_handling_success" - "test_encrypted_private_key_handling_success_with_cert_props" - "test_encrypted_private_key_handling_failure" - ]; + disabledTests = + [ + # Failed: DID NOT RAISE + "test_publish" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # OSError: [Errno 48] error while attempting to bind on address ('127.0.0.1',... + "test_anonymous_rejection" + "test_certificate_handling_success" + "test_encrypted_private_key_handling_success" + "test_encrypted_private_key_handling_success_with_cert_props" + "test_encrypted_private_key_handling_failure" + ]; meta = with lib; { description = "OPC UA / IEC 62541 Client and Server for Python"; diff --git a/pkgs/development/python-modules/audio-metadata/default.nix b/pkgs/development/python-modules/audio-metadata/default.nix index 40b47f61016aa0..92f1dc76988c45 100644 --- a/pkgs/development/python-modules/audio-metadata/default.nix +++ b/pkgs/development/python-modules/audio-metadata/default.nix @@ -43,7 +43,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ attrs bidict diff --git a/pkgs/development/python-modules/autobahn/default.nix b/pkgs/development/python-modules/autobahn/default.nix index fe6ee9f8f9ba24..be2e8f77d8bcab 100644 --- a/pkgs/development/python-modules/autobahn/default.nix +++ b/pkgs/development/python-modules/autobahn/default.nix @@ -52,11 +52,14 @@ buildPythonPackage rec { txaio ]; - nativeCheckInputs = [ - mock - pytest-asyncio - pytestCheckHook - ] ++ optional-dependencies.scram ++ optional-dependencies.serialization; + nativeCheckInputs = + [ + mock + pytest-asyncio + pytestCheckHook + ] + ++ optional-dependencies.scram + ++ optional-dependencies.serialization; preCheck = '' # Run asyncio tests (requires twisted) diff --git a/pkgs/development/python-modules/autofaiss/default.nix b/pkgs/development/python-modules/autofaiss/default.nix index 02dd9c071d7f23..4b38bfa7310f08 100644 --- a/pkgs/development/python-modules/autofaiss/default.nix +++ b/pkgs/development/python-modules/autofaiss/default.nix @@ -26,7 +26,6 @@ buildPythonPackage rec { hash = "sha256-pey3wrW7CDLMiPPKnmYrcSJqGuy6ecA2SE9m3Jtt6DU="; }; - pythonRemoveDeps = [ # The `dataclasses` packages is a python2-only backport, unnecessary in # python3. diff --git a/pkgs/development/python-modules/backports-tarfile/default.nix b/pkgs/development/python-modules/backports-tarfile/default.nix index 49c5c7458c8840..450db5506756a5 100644 --- a/pkgs/development/python-modules/backports-tarfile/default.nix +++ b/pkgs/development/python-modules/backports-tarfile/default.nix @@ -9,57 +9,59 @@ pytestCheckHook, }: -let self = buildPythonPackage rec { - pname = "backports-tarfile"; - version = "1.2.0"; - pyproject = true; +let + self = buildPythonPackage rec { + pname = "backports-tarfile"; + version = "1.2.0"; + pyproject = true; - src = fetchFromGitHub { - owner = "jaraco"; - repo = "backports.tarfile"; - rev = "v${version}"; - hash = "sha256-X3rkL35aDG+DnIOq0fI7CFoWGNtgLkLjtT9y6+23oto="; - }; + src = fetchFromGitHub { + owner = "jaraco"; + repo = "backports.tarfile"; + rev = "v${version}"; + hash = "sha256-X3rkL35aDG+DnIOq0fI7CFoWGNtgLkLjtT9y6+23oto="; + }; - build-system = [ - setuptools - setuptools-scm - wheel - ]; + build-system = [ + setuptools + setuptools-scm + wheel + ]; - doCheck = false; + doCheck = false; - nativeCheckInputs = [ - jaraco-test - pytestCheckHook - ]; + nativeCheckInputs = [ + jaraco-test + pytestCheckHook + ]; - disabledTests = [ - # calls python -m backports.tarfile and doesn't find module documentation - "test_bad_use" - "test_create_command" - "test_create_command_compressed" - "test_create_command_dot_started_filename" - "test_create_command_dotless_filename" - "test_extract_command" - "test_extract_command_different_directory" - "test_extract_command_invalid_file" - "test_list_command_invalid_file" - "test_test_command" - "test_test_command_invalid_file" - # chmod: permission denied - "test_modes" - ]; + disabledTests = [ + # calls python -m backports.tarfile and doesn't find module documentation + "test_bad_use" + "test_create_command" + "test_create_command_compressed" + "test_create_command_dot_started_filename" + "test_create_command_dotless_filename" + "test_extract_command" + "test_extract_command_different_directory" + "test_extract_command_invalid_file" + "test_list_command_invalid_file" + "test_test_command" + "test_test_command_invalid_file" + # chmod: permission denied + "test_modes" + ]; - pythonImportsCheck = [ "backports.tarfile" ]; + pythonImportsCheck = [ "backports.tarfile" ]; - passthru.tests.pytest = self.overridePythonAttrs { doCheck = true; }; + passthru.tests.pytest = self.overridePythonAttrs { doCheck = true; }; - meta = with lib; { - description = "Backport of CPython tarfile module"; - homepage = "https://github.com/jaraco/backports.tarfile"; - license = licenses.mit; - maintainers = [ ]; + meta = with lib; { + description = "Backport of CPython tarfile module"; + homepage = "https://github.com/jaraco/backports.tarfile"; + license = licenses.mit; + maintainers = [ ]; + }; }; -}; -in self +in +self diff --git a/pkgs/development/python-modules/bcg/default.nix b/pkgs/development/python-modules/bcg/default.nix index f0bf00086818dd..4065c235861c3c 100644 --- a/pkgs/development/python-modules/bcg/default.nix +++ b/pkgs/development/python-modules/bcg/default.nix @@ -26,7 +26,8 @@ buildPythonPackage rec { }; patches = [ - (fetchpatch { # https://github.com/hardwario/bch-gateway/pull/19 + (fetchpatch { + # https://github.com/hardwario/bch-gateway/pull/19 name = "bcg-fix-import-with-Python-3.12.patch"; url = "https://github.com/hardwario/bch-gateway/pull/19/commits/1314c892992d8914802b6c42602c39f6a1418fca.patch"; hash = "sha256-dNiBppXjPSMUe2yiiSc9gGbAc8l4mI41wWq+g7PkD/Y="; diff --git a/pkgs/development/python-modules/beancount/default.nix b/pkgs/development/python-modules/beancount/default.nix index 81cf300fe559f0..e530a39933c14b 100644 --- a/pkgs/development/python-modules/beancount/default.nix +++ b/pkgs/development/python-modules/beancount/default.nix @@ -58,6 +58,9 @@ buildPythonPackage rec { generate a variety of reports from them, and provides a web interface. ''; license = licenses.gpl2Only; - maintainers = with maintainers; [ sharzy polarmutex ]; + maintainers = with maintainers; [ + sharzy + polarmutex + ]; }; } diff --git a/pkgs/development/python-modules/bork/default.nix b/pkgs/development/python-modules/bork/default.nix index 9da54dc1ec6911..77d7b3906ea1a1 100644 --- a/pkgs/development/python-modules/bork/default.nix +++ b/pkgs/development/python-modules/bork/default.nix @@ -37,15 +37,16 @@ buildPythonPackage rec { "packaging" ]; - dependencies = [ - build - coloredlogs - packaging - pip - urllib3 - ] ++ lib.optionals (pythonOlder "3.11") [ toml ] - ++ lib.optionals (pythonOlder "3.10") [ importlib-metadata ] - ; + dependencies = + [ + build + coloredlogs + packaging + pip + urllib3 + ] + ++ lib.optionals (pythonOlder "3.11") [ toml ] + ++ lib.optionals (pythonOlder "3.10") [ importlib-metadata ]; pythonImportsCheck = [ "bork" diff --git a/pkgs/development/python-modules/brother/default.nix b/pkgs/development/python-modules/brother/default.nix index 84ad97686b48ee..7bb9fbc9a17c0e 100644 --- a/pkgs/development/python-modules/brother/default.nix +++ b/pkgs/development/python-modules/brother/default.nix @@ -10,7 +10,7 @@ pytestCheckHook, pythonOlder, setuptools, - syrupy + syrupy, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/certbot/default.nix b/pkgs/development/python-modules/certbot/default.nix index f04d2b2a793b01..c639113e48a260 100644 --- a/pkgs/development/python-modules/certbot/default.nix +++ b/pkgs/development/python-modules/certbot/default.nix @@ -43,7 +43,7 @@ buildPythonPackage rec { }) ]; - postPatch = "cd ${pname}"; # using sourceRoot would interfere with patches + postPatch = "cd ${pname}"; # using sourceRoot would interfere with patches build-system = [ setuptools ]; diff --git a/pkgs/development/python-modules/changefinder/default.nix b/pkgs/development/python-modules/changefinder/default.nix index 4405fa8a8525b4..a02cf6979f8b8a 100644 --- a/pkgs/development/python-modules/changefinder/default.nix +++ b/pkgs/development/python-modules/changefinder/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, setuptools -, pytestCheckHook -, numpy -, scipy -, statsmodels +{ + lib, + buildPythonPackage, + fetchFromGitHub, + setuptools, + pytestCheckHook, + numpy, + scipy, + statsmodels, }: buildPythonPackage { diff --git a/pkgs/development/python-modules/cli-ui/default.nix b/pkgs/development/python-modules/cli-ui/default.nix index 3b93c3eb7be8b9..81da90802abffc 100644 --- a/pkgs/development/python-modules/cli-ui/default.nix +++ b/pkgs/development/python-modules/cli-ui/default.nix @@ -23,7 +23,6 @@ buildPythonPackage rec { pythonRelaxDeps = [ "tabulate" ]; - build-system = [ poetry-core ]; dependencies = [ diff --git a/pkgs/development/python-modules/clickhouse-connect/default.nix b/pkgs/development/python-modules/clickhouse-connect/default.nix index f338744bbae9d0..9b4b213be8fdd8 100644 --- a/pkgs/development/python-modules/clickhouse-connect/default.nix +++ b/pkgs/development/python-modules/clickhouse-connect/default.nix @@ -50,10 +50,13 @@ buildPythonPackage rec { lz4 ]; - nativeCheckInputs = [ - pytestCheckHook - pytest-dotenv - ] ++ optional-dependencies.sqlalchemy ++ optional-dependencies.numpy; + nativeCheckInputs = + [ + pytestCheckHook + pytest-dotenv + ] + ++ optional-dependencies.sqlalchemy + ++ optional-dependencies.numpy; # these tests require a running clickhouse instance disabledTestPaths = [ diff --git a/pkgs/development/python-modules/conda/default.nix b/pkgs/development/python-modules/conda/default.nix index 523110cf03ab8b..1339c7fa1a1d60 100644 --- a/pkgs/development/python-modules/conda/default.nix +++ b/pkgs/development/python-modules/conda/default.nix @@ -38,7 +38,6 @@ buildPythonPackage rec { hash = "sha256-e+C+tSUdSGyotuZzkOuV0e0hOj+MZRuq1fHzsu3LERQ="; }; - build-system = [ hatchling hatch-vcs diff --git a/pkgs/development/python-modules/crc32c/default.nix b/pkgs/development/python-modules/crc32c/default.nix index f5f44c351c15f2..96b55009bb76e6 100644 --- a/pkgs/development/python-modules/crc32c/default.nix +++ b/pkgs/development/python-modules/crc32c/default.nix @@ -4,7 +4,7 @@ fetchFromGitHub, pythonOlder, pytestCheckHook, - setuptools + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/crossandra/default.nix b/pkgs/development/python-modules/crossandra/default.nix index c7400b62f53ac6..20bcb21ff6b71e 100644 --- a/pkgs/development/python-modules/crossandra/default.nix +++ b/pkgs/development/python-modules/crossandra/default.nix @@ -4,7 +4,7 @@ fetchFromGitHub, setuptools, result, - mypy + mypy, }: buildPythonPackage rec { @@ -19,7 +19,10 @@ buildPythonPackage rec { hash = "sha256-/JhrjXRH7Rs2bUil9HRneBC9wlVYEyfwivjzb+eyRv8="; }; - build-system = [ setuptools mypy ]; + build-system = [ + setuptools + mypy + ]; dependencies = [ result ]; pythonImportsCheck = [ "crossandra" ]; diff --git a/pkgs/development/python-modules/csv2md/default.nix b/pkgs/development/python-modules/csv2md/default.nix index a8d62dd33fcfa1..f3c6faf3f19516 100644 --- a/pkgs/development/python-modules/csv2md/default.nix +++ b/pkgs/development/python-modules/csv2md/default.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildPythonPackage +{ + lib, + fetchFromGitHub, + buildPythonPackage, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/cython/0.nix b/pkgs/development/python-modules/cython/0.nix index a484892c004001..fa02399bbb6fdb 100644 --- a/pkgs/development/python-modules/cython/0.nix +++ b/pkgs/development/python-modules/cython/0.nix @@ -77,11 +77,9 @@ buildPythonPackage rec { export HOME="$NIX_BUILD_TOP" ${python.interpreter} runtests.py -j$NIX_BUILD_CORES \ --no-code-style \ - ${ - lib.optionalString ( - builtins.length excludedTests != 0 - ) ''--exclude="(${builtins.concatStringsSep "|" excludedTests})"'' - } + ${lib.optionalString ( + builtins.length excludedTests != 0 + ) ''--exclude="(${builtins.concatStringsSep "|" excludedTests})"''} ''; # https://github.com/cython/cython/issues/2785 diff --git a/pkgs/development/python-modules/dask-ml/default.nix b/pkgs/development/python-modules/dask-ml/default.nix index 913480c060d375..af0270af385f93 100644 --- a/pkgs/development/python-modules/dask-ml/default.nix +++ b/pkgs/development/python-modules/dask-ml/default.nix @@ -45,18 +45,21 @@ buildPythonPackage rec { setuptools-scm ]; - dependencies = [ - dask-expr - dask-glm - distributed - multipledispatch - numba - numpy - packaging - pandas - scikit-learn - scipy - ] ++ dask.optional-dependencies.array ++ dask.optional-dependencies.dataframe; + dependencies = + [ + dask-expr + dask-glm + distributed + multipledispatch + numba + numpy + packaging + pandas + scikit-learn + scipy + ] + ++ dask.optional-dependencies.array + ++ dask.optional-dependencies.dataframe; pythonImportsCheck = [ "dask_ml" diff --git a/pkgs/development/python-modules/dataclass-wizard/default.nix b/pkgs/development/python-modules/dataclass-wizard/default.nix index 2a063482fe17b2..21a5ddcee0fa7c 100644 --- a/pkgs/development/python-modules/dataclass-wizard/default.nix +++ b/pkgs/development/python-modules/dataclass-wizard/default.nix @@ -30,10 +30,13 @@ buildPythonPackage rec { yaml = [ pyyaml ]; }; - nativeCheckInputs = [ - pytestCheckHook - pytest-mock - ] ++ optional-dependencies.timedelta ++ optional-dependencies.yaml; + nativeCheckInputs = + [ + pytestCheckHook + pytest-mock + ] + ++ optional-dependencies.timedelta + ++ optional-dependencies.yaml; disabledTests = [ ] diff --git a/pkgs/development/python-modules/dbt-redshift/default.nix b/pkgs/development/python-modules/dbt-redshift/default.nix index deffc3b313d130..6bd42b7fadba71 100644 --- a/pkgs/development/python-modules/dbt-redshift/default.nix +++ b/pkgs/development/python-modules/dbt-redshift/default.nix @@ -31,7 +31,6 @@ buildPythonPackage rec { "redshift-connector" ]; - build-system = [ setuptools ]; dependencies = [ diff --git a/pkgs/development/python-modules/defcon/default.nix b/pkgs/development/python-modules/defcon/default.nix index 4e2c4d9b75e20e..19f4f28463d110 100644 --- a/pkgs/development/python-modules/defcon/default.nix +++ b/pkgs/development/python-modules/defcon/default.nix @@ -24,9 +24,12 @@ buildPythonPackage rec { nativeBuildInputs = [ setuptools-scm ]; - propagatedBuildInputs = [ - fonttools - ] ++ fonttools.optional-dependencies.ufo ++ fonttools.optional-dependencies.unicode; + propagatedBuildInputs = + [ + fonttools + ] + ++ fonttools.optional-dependencies.ufo + ++ fonttools.optional-dependencies.unicode; nativeCheckInputs = [ pytestCheckHook ]; diff --git a/pkgs/development/python-modules/deform/default.nix b/pkgs/development/python-modules/deform/default.nix index 082c0a8ff44751..27dbd22ea70366 100644 --- a/pkgs/development/python-modules/deform/default.nix +++ b/pkgs/development/python-modules/deform/default.nix @@ -49,7 +49,10 @@ buildPythonPackage rec { description = "Form library with advanced features like nested forms"; homepage = "https://docs.pylonsproject.org/projects/deform/en/latest/"; # https://github.com/Pylons/deform/blob/fdc43d59de7d11b0e3ba1b92835b780cfe181719/LICENSE.txt - license = [ lib.licenses.bsd3 lib.licenses.cc-by-30 ]; + license = [ + lib.licenses.bsd3 + lib.licenses.cc-by-30 + ]; maintainers = with lib.maintainers; [ domenkozar ]; }; } diff --git a/pkgs/development/python-modules/defusedxml/default.nix b/pkgs/development/python-modules/defusedxml/default.nix index ce997d1fcb820c..95b34a00dbdcc0 100644 --- a/pkgs/development/python-modules/defusedxml/default.nix +++ b/pkgs/development/python-modules/defusedxml/default.nix @@ -19,7 +19,7 @@ buildPythonPackage rec { hash = "sha256-X88A5V9uXP3wJQ+olK6pZJT66LP2uCXLK8goa5bPARA="; }; - build-system = [ setuptools ] ; + build-system = [ setuptools ]; nativeCheckInputs = [ lxml ]; diff --git a/pkgs/development/python-modules/deltachat2/default.nix b/pkgs/development/python-modules/deltachat2/default.nix index cbd9fd791e6fb1..8025dc4ac228f0 100644 --- a/pkgs/development/python-modules/deltachat2/default.nix +++ b/pkgs/development/python-modules/deltachat2/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, buildPythonPackage -, deltachat-rpc-server -, setuptools-scm -, substituteAll +{ + lib, + fetchFromGitHub, + buildPythonPackage, + deltachat-rpc-server, + setuptools-scm, + substituteAll, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/deltalake/default.nix b/pkgs/development/python-modules/deltalake/default.nix index c61c1cd3b41d95..74622f890144af 100644 --- a/pkgs/development/python-modules/deltalake/default.nix +++ b/pkgs/development/python-modules/deltalake/default.nix @@ -1,20 +1,21 @@ -{ lib -, buildPythonPackage -, fetchPypi -, rustPlatform -, pyarrow -, pyarrow-hotfix -, openssl -, stdenv -, darwin -, libiconv -, pkg-config -, pytestCheckHook -, pytest-benchmark -, pytest-cov -, pytest-mock -, pandas -, azure-storage-blob +{ + lib, + buildPythonPackage, + fetchPypi, + rustPlatform, + pyarrow, + pyarrow-hotfix, + openssl, + stdenv, + darwin, + libiconv, + pkg-config, + pytestCheckHook, + pytest-benchmark, + pytest-cov, + pytest-mock, + pandas, + azure-storage-blob, }: buildPythonPackage rec { @@ -39,20 +40,24 @@ buildPythonPackage rec { pyarrow-hotfix ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.SystemConfiguration - libiconv - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + libiconv + ]; - nativeBuildInputs = [ - pkg-config # openssl-sys needs this - ] ++ (with rustPlatform; [ - cargoSetupHook - maturinBuildHook - ]); + nativeBuildInputs = + [ + pkg-config # openssl-sys needs this + ] + ++ (with rustPlatform; [ + cargoSetupHook + maturinBuildHook + ]); pythonImportsCheck = [ "deltalake" ]; @@ -81,6 +86,11 @@ buildPythonPackage rec { homepage = "https://github.com/delta-io/delta-rs"; changelog = "https://github.com/delta-io/delta-rs/blob/python-v${version}/CHANGELOG.md"; license = licenses.asl20; - maintainers = with maintainers; [ kfollesdal mslingsby harvidsen andershus ]; + maintainers = with maintainers; [ + kfollesdal + mslingsby + harvidsen + andershus + ]; }; } diff --git a/pkgs/development/python-modules/django-extensions/default.nix b/pkgs/development/python-modules/django-extensions/default.nix index 8e10c4c1f567ed..bb7ea8e2a155fb 100644 --- a/pkgs/development/python-modules/django-extensions/default.nix +++ b/pkgs/development/python-modules/django-extensions/default.nix @@ -29,7 +29,7 @@ buildPythonPackage rec { version = "3.2.3"; pyproject = true; - src = fetchFromGitHub { + src = fetchFromGitHub { owner = pname; repo = pname; rev = "refs/tags/${version}"; diff --git a/pkgs/development/python-modules/django-graphiql-debug-toolbar/default.nix b/pkgs/development/python-modules/django-graphiql-debug-toolbar/default.nix index cbd1e348c74d45..0f8ab4fed5ecf3 100644 --- a/pkgs/development/python-modules/django-graphiql-debug-toolbar/default.nix +++ b/pkgs/development/python-modules/django-graphiql-debug-toolbar/default.nix @@ -15,7 +15,7 @@ # tests pytest-django, - pytestCheckHook + pytestCheckHook, }: buildPythonPackage rec { @@ -37,7 +37,7 @@ buildPythonPackage rec { (fetchpatch { url = "https://github.com/flavors/django-graphiql-debug-toolbar/commit/2b42fdb1bc40109d9bb0ae1fb4d2163d13904724.patch"; hash = "sha256-ywTLqXlAxA2DCacrJOqmB7jSzfpeuGTX2ETu0fKmhq4="; - }) + }) ]; build-system = [ poetry-core ]; diff --git a/pkgs/development/python-modules/django-ipware/default.nix b/pkgs/development/python-modules/django-ipware/default.nix index b778e0a93d7d09..d6c195a9ec4384 100644 --- a/pkgs/development/python-modules/django-ipware/default.nix +++ b/pkgs/development/python-modules/django-ipware/default.nix @@ -19,7 +19,10 @@ buildPythonPackage rec { hash = "sha256-2exD0r983yFv7Y1JSghN61dhpUhgpTsudDRqTzhM/0c="; }; - propagatedBuildInputs = [ django python-ipware ]; + propagatedBuildInputs = [ + django + python-ipware + ]; # django.core.exceptions.ImproperlyConfigured: Requested setting IPWARE_TRUSTED_PROXY_LIST, but settings are not configured. You must either define the environment variable DJANGO_SETTINGS_MODULE or call settings.configure() before accessing settings. doCheck = false; diff --git a/pkgs/development/python-modules/django-ratelimit/default.nix b/pkgs/development/python-modules/django-ratelimit/default.nix index ca0216a9de5c3d..fd74e1e68fc7b8 100644 --- a/pkgs/development/python-modules/django-ratelimit/default.nix +++ b/pkgs/development/python-modules/django-ratelimit/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildPythonPackage -, django -, django-redis -, fetchFromGitHub -, pymemcache -, pythonOlder -, setuptools +{ + lib, + buildPythonPackage, + django, + django-redis, + fetchFromGitHub, + pymemcache, + pythonOlder, + setuptools, }: buildPythonPackage rec { @@ -45,7 +46,6 @@ buildPythonPackage rec { runHook postCheck ''; - meta = with lib; { description = "Cache-based rate-limiting for Django"; homepage = "https://github.com/jsocol/django-ratelimit"; diff --git a/pkgs/development/python-modules/dohq-artifactory/default.nix b/pkgs/development/python-modules/dohq-artifactory/default.nix index 2e44d4464791e2..12f1b068e2e9bf 100644 --- a/pkgs/development/python-modules/dohq-artifactory/default.nix +++ b/pkgs/development/python-modules/dohq-artifactory/default.nix @@ -1,15 +1,15 @@ { - lib -, buildPythonPackage -, fetchFromGitHub -, pythonAtLeast -, setuptools -, requests -, python-dateutil -, pyjwt -, pytestCheckHook -, responses -, nix-update-script + lib, + buildPythonPackage, + fetchFromGitHub, + pythonAtLeast, + setuptools, + requests, + python-dateutil, + pyjwt, + pytestCheckHook, + responses, + nix-update-script, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/dscribe/default.nix b/pkgs/development/python-modules/dscribe/default.nix index f2cacd6045247e..33229ab0307512 100644 --- a/pkgs/development/python-modules/dscribe/default.nix +++ b/pkgs/development/python-modules/dscribe/default.nix @@ -1,13 +1,14 @@ -{ buildPythonPackage -, lib -, fetchFromGitHub -, numpy -, scipy -, ase -, joblib -, sparse -, pybind11 -, scikit-learn +{ + buildPythonPackage, + lib, + fetchFromGitHub, + numpy, + scipy, + ase, + joblib, + sparse, + pybind11, + scikit-learn, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/dulwich/default.nix b/pkgs/development/python-modules/dulwich/default.nix index 752a09be221e5f..0145773a6e0fe3 100644 --- a/pkgs/development/python-modules/dulwich/default.nix +++ b/pkgs/development/python-modules/dulwich/default.nix @@ -52,15 +52,13 @@ buildPythonPackage rec { paramiko = [ paramiko ]; }; - nativeCheckInputs = - [ - gevent - geventhttpclient - git - glibcLocales - unittestCheckHook - ] - ++ lib.flatten (lib.attrValues optional-dependencies); + nativeCheckInputs = [ + gevent + geventhttpclient + git + glibcLocales + unittestCheckHook + ] ++ lib.flatten (lib.attrValues optional-dependencies); preCheck = '' # requires swift config file diff --git a/pkgs/development/python-modules/dvc-render/default.nix b/pkgs/development/python-modules/dvc-render/default.nix index 749abe71e0bc84..63b83d0c1d5046 100644 --- a/pkgs/development/python-modules/dvc-render/default.nix +++ b/pkgs/development/python-modules/dvc-render/default.nix @@ -41,12 +41,15 @@ buildPythonPackage rec { ]; }; - nativeCheckInputs = [ - funcy - pytestCheckHook - pytest-mock - pytest-test-utils - ] ++ optional-dependencies.table ++ optional-dependencies.markdown; + nativeCheckInputs = + [ + funcy + pytestCheckHook + pytest-mock + pytest-test-utils + ] + ++ optional-dependencies.table + ++ optional-dependencies.markdown; disabledTestPaths = lib.optionals stdenv.hostPlatform.isDarwin [ "tests/test_vega.py" ]; diff --git a/pkgs/development/python-modules/dvc-s3/default.nix b/pkgs/development/python-modules/dvc-s3/default.nix index eaed1006a500b8..faa0cec34d0280 100644 --- a/pkgs/development/python-modules/dvc-s3/default.nix +++ b/pkgs/development/python-modules/dvc-s3/default.nix @@ -30,7 +30,7 @@ buildPythonPackage rec { --replace-fail "aiobotocore[boto3]" "aiobotocore" ''; - build-system = [ setuptools-scm ]; + build-system = [ setuptools-scm ]; dependencies = [ aiobotocore diff --git a/pkgs/development/python-modules/dvc/default.nix b/pkgs/development/python-modules/dvc/default.nix index 089cf52f10a675..190f8faf276111 100644 --- a/pkgs/development/python-modules/dvc/default.nix +++ b/pkgs/development/python-modules/dvc/default.nix @@ -83,7 +83,6 @@ buildPythonPackage rec { build-system = [ setuptools-scm ]; - dependencies = [ appdirs diff --git a/pkgs/development/python-modules/elastic-apm/default.nix b/pkgs/development/python-modules/elastic-apm/default.nix index fb27b98608dd2a..af1505d27e6fbe 100644 --- a/pkgs/development/python-modules/elastic-apm/default.nix +++ b/pkgs/development/python-modules/elastic-apm/default.nix @@ -48,7 +48,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ aiohttp blinker diff --git a/pkgs/development/python-modules/embedding-reader/default.nix b/pkgs/development/python-modules/embedding-reader/default.nix index 0f4d3c54a34b95..a65d0a07e49c84 100644 --- a/pkgs/development/python-modules/embedding-reader/default.nix +++ b/pkgs/development/python-modules/embedding-reader/default.nix @@ -21,7 +21,6 @@ buildPythonPackage rec { hash = "sha256-paN6rAyH3L7qCfWPr5kXo9Xl57gRMhdcDnoyLJ7II2w="; }; - pythonRelaxDeps = [ "pyarrow" ]; propagatedBuildInputs = [ diff --git a/pkgs/development/python-modules/ete3/default.nix b/pkgs/development/python-modules/ete3/default.nix index ee5881128336b1..282a0546431f3d 100644 --- a/pkgs/development/python-modules/ete3/default.nix +++ b/pkgs/development/python-modules/ete3/default.nix @@ -23,10 +23,13 @@ buildPythonPackage rec { doCheck = false; # Tests are (i) not 3.x compatible, (ii) broken under 2.7 pythonImportsCheck = [ "ete3" ]; - propagatedBuildInputs = [ - six - numpy - ] ++ lib.optional withTreeVisualization pyqt5 ++ lib.optional withXmlSupport lxml; + propagatedBuildInputs = + [ + six + numpy + ] + ++ lib.optional withTreeVisualization pyqt5 + ++ lib.optional withXmlSupport lxml; meta = with lib; { description = "Python framework for the analysis and visualization of trees"; diff --git a/pkgs/development/python-modules/eth-utils/default.nix b/pkgs/development/python-modules/eth-utils/default.nix index a9e5790fcf4fef..feb07cbac013ac 100644 --- a/pkgs/development/python-modules/eth-utils/default.nix +++ b/pkgs/development/python-modules/eth-utils/default.nix @@ -29,10 +29,13 @@ buildPythonPackage rec { nativeBuildInputs = [ setuptools ]; - propagatedBuildInputs = [ - eth-hash - eth-typing - ] ++ lib.optional (!isPyPy) cytoolz ++ lib.optional isPyPy toolz; + propagatedBuildInputs = + [ + eth-hash + eth-typing + ] + ++ lib.optional (!isPyPy) cytoolz + ++ lib.optional isPyPy toolz; nativeCheckInputs = [ hypothesis diff --git a/pkgs/development/python-modules/fastapi-cli/default.nix b/pkgs/development/python-modules/fastapi-cli/default.nix index 071b1cd0c9cf28..6b4598ad05a417 100644 --- a/pkgs/development/python-modules/fastapi-cli/default.nix +++ b/pkgs/development/python-modules/fastapi-cli/default.nix @@ -1,66 +1,69 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, pdm-backend -, typer -, fastapi -, uvicorn +{ + lib, + buildPythonPackage, + fetchFromGitHub, + pdm-backend, + typer, + fastapi, + uvicorn, -# checks -, pytestCheckHook -, rich + # checks + pytestCheckHook, + rich, }: -let self = buildPythonPackage rec { - pname = "fastapi-cli"; - version = "0.0.5"; - pyproject = true; +let + self = buildPythonPackage rec { + pname = "fastapi-cli"; + version = "0.0.5"; + pyproject = true; - src = fetchFromGitHub { - owner = "tiangolo"; - repo = "fastapi-cli"; - rev = "refs/tags/${version}"; - hash = "sha256-hUS9zkDJJB51X+e31RvyxcGAP8j4oulAPFAvEMPiIn8="; - }; - - build-system = [ pdm-backend ]; + src = fetchFromGitHub { + owner = "tiangolo"; + repo = "fastapi-cli"; + rev = "refs/tags/${version}"; + hash = "sha256-hUS9zkDJJB51X+e31RvyxcGAP8j4oulAPFAvEMPiIn8="; + }; - dependencies = [ - typer - uvicorn - ] ++ uvicorn.optional-dependencies.standard; + build-system = [ pdm-backend ]; - optional-dependencies = { - standard = [ + dependencies = [ + typer uvicorn ] ++ uvicorn.optional-dependencies.standard; - }; - doCheck = false; + optional-dependencies = { + standard = [ + uvicorn + ] ++ uvicorn.optional-dependencies.standard; + }; + + doCheck = false; - passthru.tests.pytest = self.overridePythonAttrs { doCheck = true; }; + passthru.tests.pytest = self.overridePythonAttrs { doCheck = true; }; - nativeCheckInputs = [ - pytestCheckHook - rich - ] ++ optional-dependencies.standard; + nativeCheckInputs = [ + pytestCheckHook + rich + ] ++ optional-dependencies.standard; - # coverage - disabledTests = [ "test_script" ]; + # coverage + disabledTests = [ "test_script" ]; - pythonImportsCheck = [ "fastapi_cli" ]; + pythonImportsCheck = [ "fastapi_cli" ]; - meta = with lib; { - description = "Run and manage FastAPI apps from the command line with FastAPI CLI"; - homepage = "https://github.com/tiangolo/fastapi-cli"; - changelog = "https://github.com/tiangolo/fastapi-cli/releases/tag/${version}"; - mainProgram = "fastapi"; - license = licenses.mit; - maintainers = [ ]; - # This package provides a `fastapi`-executable that is in conflict with the one from - # python3Packages.fastapi. Because this package is primarily used for the purpose of - # implementing the CLI for python3Packages.fastapi, we reduce the executable's priority - priority = 10; + meta = with lib; { + description = "Run and manage FastAPI apps from the command line with FastAPI CLI"; + homepage = "https://github.com/tiangolo/fastapi-cli"; + changelog = "https://github.com/tiangolo/fastapi-cli/releases/tag/${version}"; + mainProgram = "fastapi"; + license = licenses.mit; + maintainers = [ ]; + # This package provides a `fastapi`-executable that is in conflict with the one from + # python3Packages.fastapi. Because this package is primarily used for the purpose of + # implementing the CLI for python3Packages.fastapi, we reduce the executable's priority + priority = 10; + }; }; -}; -in self +in +self diff --git a/pkgs/development/python-modules/flask-compress/default.nix b/pkgs/development/python-modules/flask-compress/default.nix index c0239f2a6c86dd..7a79bf47ba6e68 100644 --- a/pkgs/development/python-modules/flask-compress/default.nix +++ b/pkgs/development/python-modules/flask-compress/default.nix @@ -30,10 +30,13 @@ buildPythonPackage rec { setuptools-scm ]; - dependencies = [ - flask - zstandard - ] ++ lib.optionals (!isPyPy) [ brotli ] ++ lib.optionals isPyPy [ brotlicffi ]; + dependencies = + [ + flask + zstandard + ] + ++ lib.optionals (!isPyPy) [ brotli ] + ++ lib.optionals isPyPy [ brotlicffi ]; nativeCheckInputs = [ pytestCheckHook diff --git a/pkgs/development/python-modules/flask-sqlalchemy-lite/default.nix b/pkgs/development/python-modules/flask-sqlalchemy-lite/default.nix index a6afc09f4edf24..c17f7229ad7bcb 100644 --- a/pkgs/development/python-modules/flask-sqlalchemy-lite/default.nix +++ b/pkgs/development/python-modules/flask-sqlalchemy-lite/default.nix @@ -23,10 +23,13 @@ buildPythonPackage rec { build-system = [ flit-core ]; - dependencies = [ - flask - sqlalchemy - ] ++ flask.optional-dependencies.async ++ sqlalchemy.optional-dependencies.asyncio; + dependencies = + [ + flask + sqlalchemy + ] + ++ flask.optional-dependencies.async + ++ sqlalchemy.optional-dependencies.asyncio; pythonImportsCheck = [ "flask_sqlalchemy_lite" ]; diff --git a/pkgs/development/python-modules/flet/default.nix b/pkgs/development/python-modules/flet/default.nix index d35a99194358e6..ea052649f4b196 100644 --- a/pkgs/development/python-modules/flet/default.nix +++ b/pkgs/development/python-modules/flet/default.nix @@ -35,7 +35,10 @@ buildPythonPackage rec { ]; makeWrapperArgs = [ - "--prefix" "PYTHONPATH" ":" "$PYTHONPATH" + "--prefix" + "PYTHONPATH" + ":" + "$PYTHONPATH" ]; pythonRelaxDeps = [ diff --git a/pkgs/development/python-modules/freertos-gdb/default.nix b/pkgs/development/python-modules/freertos-gdb/default.nix index f932925762134a..5b6bc91aaf5427 100644 --- a/pkgs/development/python-modules/freertos-gdb/default.nix +++ b/pkgs/development/python-modules/freertos-gdb/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchPypi, buildPythonPackage }: +{ + lib, + fetchPypi, + buildPythonPackage, +}: buildPythonPackage rec { pname = "freertos-gdb"; diff --git a/pkgs/development/python-modules/furo/default.nix b/pkgs/development/python-modules/furo/default.nix index 36e2f47663ed20..71bc32d7a51680 100644 --- a/pkgs/development/python-modules/furo/default.nix +++ b/pkgs/development/python-modules/furo/default.nix @@ -22,7 +22,6 @@ buildPythonPackage rec { hash = "sha256-bNl8WLR4E9NhnmPpCBFpiA++Mx8MqIPIcf8fPxGBT1w="; }; - pythonRelaxDeps = [ "sphinx" ]; propagatedBuildInputs = [ diff --git a/pkgs/development/python-modules/gftools/default.nix b/pkgs/development/python-modules/gftools/default.nix index 9ad7021e8ff012..2ea13f65fb0bdc 100644 --- a/pkgs/development/python-modules/gftools/default.nix +++ b/pkgs/development/python-modules/gftools/default.nix @@ -126,47 +126,50 @@ buildPythonPackage rec { setuptools-scm ]; - dependencies = [ - absl-py - afdko - axisregistry - babelfont - beautifulsoup4 - brotli - bumpfontversion - font-v - fontfeatures - fontmake - fonttools - gflanguages - gfsubsets - glyphsets - glyphslib - jinja2 - nanoemoji - networkx - ninja - ots-python - packaging - pillow - protobuf - pygit2 - pygithub - pyyaml - requests - rich - ruamel-yaml - setuptools - skia-pathops - statmake - strictyaml - tabulate - ttfautohint-py - ufomerge - unidecode - vharfbuzz - vttlib - ] ++ fonttools.optional-dependencies.ufo ++ fontmake.optional-dependencies.json; + dependencies = + [ + absl-py + afdko + axisregistry + babelfont + beautifulsoup4 + brotli + bumpfontversion + font-v + fontfeatures + fontmake + fonttools + gflanguages + gfsubsets + glyphsets + glyphslib + jinja2 + nanoemoji + networkx + ninja + ots-python + packaging + pillow + protobuf + pygit2 + pygithub + pyyaml + requests + rich + ruamel-yaml + setuptools + skia-pathops + statmake + strictyaml + tabulate + ttfautohint-py + ufomerge + unidecode + vharfbuzz + vttlib + ] + ++ fonttools.optional-dependencies.ufo + ++ fontmake.optional-dependencies.json; optional-dependencies = { qa = [ diff --git a/pkgs/development/python-modules/google-cloud-bigquery/default.nix b/pkgs/development/python-modules/google-cloud-bigquery/default.nix index 3d29e7ee164639..a48fae473b5c2b 100644 --- a/pkgs/development/python-modules/google-cloud-bigquery/default.nix +++ b/pkgs/development/python-modules/google-cloud-bigquery/default.nix @@ -70,16 +70,19 @@ buildPythonPackage rec { ipython = [ ipython ]; }; - nativeCheckInputs = [ - freezegun - google-cloud-testutils - mock - psutil - google-cloud-datacatalog - google-cloud-storage - pytestCheckHook - pytest-xdist - ] ++ optional-dependencies.pandas ++ optional-dependencies.ipython; + nativeCheckInputs = + [ + freezegun + google-cloud-testutils + mock + psutil + google-cloud-datacatalog + google-cloud-storage + pytestCheckHook + pytest-xdist + ] + ++ optional-dependencies.pandas + ++ optional-dependencies.ipython; # prevent google directory from shadowing google imports preCheck = '' diff --git a/pkgs/development/python-modules/google-generativeai/default.nix b/pkgs/development/python-modules/google-generativeai/default.nix index ae82378dfa06c2..ce76f9794b0383 100644 --- a/pkgs/development/python-modules/google-generativeai/default.nix +++ b/pkgs/development/python-modules/google-generativeai/default.nix @@ -32,7 +32,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ google-ai-generativelanguage google-api-core diff --git a/pkgs/development/python-modules/gophish/default.nix b/pkgs/development/python-modules/gophish/default.nix index 48b4e880e5fcf9..316244a5fa384b 100644 --- a/pkgs/development/python-modules/gophish/default.nix +++ b/pkgs/development/python-modules/gophish/default.nix @@ -34,7 +34,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ appdirs certifi diff --git a/pkgs/development/python-modules/gotenberg-client/default.nix b/pkgs/development/python-modules/gotenberg-client/default.nix index bb18da52f95157..10d29ac87177be 100644 --- a/pkgs/development/python-modules/gotenberg-client/default.nix +++ b/pkgs/development/python-modules/gotenberg-client/default.nix @@ -23,9 +23,12 @@ buildPythonPackage rec { nativeBuildInputs = [ hatchling ]; - propagatedBuildInputs = [ - httpx - ] ++ lib.optionals (pythonOlder "3.11") [ typing-extensions ] ++ httpx.optional-dependencies.http2; + propagatedBuildInputs = + [ + httpx + ] + ++ lib.optionals (pythonOlder "3.11") [ typing-extensions ] + ++ httpx.optional-dependencies.http2; pythonImportsCheck = [ "gotenberg_client" ]; diff --git a/pkgs/development/python-modules/great-expectations/default.nix b/pkgs/development/python-modules/great-expectations/default.nix index 04a180c15eb388..c25ce9206f1805 100644 --- a/pkgs/development/python-modules/great-expectations/default.nix +++ b/pkgs/development/python-modules/great-expectations/default.nix @@ -83,21 +83,24 @@ buildPythonPackage rec { "posthog" ]; - nativeCheckInputs = [ - pytestCheckHook - pytest-mock - pytest-order - pytest-random-order - click - flaky - freezegun - invoke - moto - psycopg2 - requirements-parser - responses - sqlalchemy - ] ++ moto.optional-dependencies.s3 ++ moto.optional-dependencies.sns; + nativeCheckInputs = + [ + pytestCheckHook + pytest-mock + pytest-order + pytest-random-order + click + flaky + freezegun + invoke + moto + psycopg2 + requirements-parser + responses + sqlalchemy + ] + ++ moto.optional-dependencies.s3 + ++ moto.optional-dependencies.sns; disabledTestPaths = [ # try to access external URLs: diff --git a/pkgs/development/python-modules/ha-mqtt-discoverable/default.nix b/pkgs/development/python-modules/ha-mqtt-discoverable/default.nix index deff078edf859a..9d9f5985c2ca97 100644 --- a/pkgs/development/python-modules/ha-mqtt-discoverable/default.nix +++ b/pkgs/development/python-modules/ha-mqtt-discoverable/default.nix @@ -29,7 +29,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ gitlike-commands paho-mqtt diff --git a/pkgs/development/python-modules/handy-archives/default.nix b/pkgs/development/python-modules/handy-archives/default.nix index 6bafb066cb57cc..4609d4ffb399e8 100644 --- a/pkgs/development/python-modules/handy-archives/default.nix +++ b/pkgs/development/python-modules/handy-archives/default.nix @@ -17,9 +17,8 @@ buildPythonPackage rec { build-system = [ flit-core ]; - dependencies = - [ - ]; + dependencies = [ + ]; meta = { description = "Some handy archive helpers for Python."; diff --git a/pkgs/development/python-modules/hatch-odoo/default.nix b/pkgs/development/python-modules/hatch-odoo/default.nix index e3c0c26dbebf85..eebb52bee81b30 100644 --- a/pkgs/development/python-modules/hatch-odoo/default.nix +++ b/pkgs/development/python-modules/hatch-odoo/default.nix @@ -20,7 +20,7 @@ buildPythonPackage rec { sha256 = "sha256-I3jaiG0Xu8B34q30p7zTs+FeBXUQiPKTAJLSVxE9gYE="; }; - buildInputs = [hatch-vcs]; + buildInputs = [ hatch-vcs ]; propagatedBuildInputs = [ @@ -35,6 +35,6 @@ buildPythonPackage rec { description = "A hatch plugin to develop and package Odoo projects"; homepage = "https://github.com/acsone/hatch-odoo"; license = licenses.mit; - maintainers = with maintainers; [yajo]; + maintainers = with maintainers; [ yajo ]; }; } diff --git a/pkgs/development/python-modules/hatch-vcs/default.nix b/pkgs/development/python-modules/hatch-vcs/default.nix index ec89847abc248b..f7fe24743c7b39 100644 --- a/pkgs/development/python-modules/hatch-vcs/default.nix +++ b/pkgs/development/python-modules/hatch-vcs/default.nix @@ -34,16 +34,18 @@ buildPythonPackage rec { pytestCheckHook ]; - disabledTests = [ - # incompatible with setuptools-scm>=7 - # https://github.com/ofek/hatch-vcs/issues/8 - "test_write" - ] ++ lib.optionals (pythonOlder "3.11") [ - # https://github.com/pypa/setuptools_scm/issues/1038, fixed in setuptools_scm@8.1.0 - "test_basic" - "test_root" - "test_metadata" - ]; + disabledTests = + [ + # incompatible with setuptools-scm>=7 + # https://github.com/ofek/hatch-vcs/issues/8 + "test_write" + ] + ++ lib.optionals (pythonOlder "3.11") [ + # https://github.com/pypa/setuptools_scm/issues/1038, fixed in setuptools_scm@8.1.0 + "test_basic" + "test_root" + "test_metadata" + ]; pythonImportsCheck = [ "hatch_vcs" ]; diff --git a/pkgs/development/python-modules/hikari-crescent/default.nix b/pkgs/development/python-modules/hikari-crescent/default.nix index 3d450a68de13dd..7b8b39994cc9c3 100644 --- a/pkgs/development/python-modules/hikari-crescent/default.nix +++ b/pkgs/development/python-modules/hikari-crescent/default.nix @@ -9,7 +9,7 @@ python-dotenv, pytest-asyncio, croniter, - pynacl + pynacl, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/htmltools/default.nix b/pkgs/development/python-modules/htmltools/default.nix index 3bb83d269109f7..a5bcf561cab000 100644 --- a/pkgs/development/python-modules/htmltools/default.nix +++ b/pkgs/development/python-modules/htmltools/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonPackage -, pythonOlder -, fetchFromGitHub -, setuptools -, packaging -, typing-extensions -, pytestCheckHook -, syrupy +{ + lib, + buildPythonPackage, + pythonOlder, + fetchFromGitHub, + setuptools, + packaging, + typing-extensions, + pytestCheckHook, + syrupy, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/jschon/default.nix b/pkgs/development/python-modules/jschon/default.nix index 82a125e4460be4..a2308db968c44c 100644 --- a/pkgs/development/python-modules/jschon/default.nix +++ b/pkgs/development/python-modules/jschon/default.nix @@ -1,14 +1,15 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, setuptools -, wheel -, rfc3986 -, pytestCheckHook -, hypothesis -, requests -, pytest-httpserver -, pytest-xdist +{ + lib, + buildPythonPackage, + fetchFromGitHub, + setuptools, + wheel, + rfc3986, + pytestCheckHook, + hypothesis, + requests, + pytest-httpserver, + pytest-xdist, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/kafka-python-ng/default.nix b/pkgs/development/python-modules/kafka-python-ng/default.nix index 6252e1a5044a60..88fa6541680074 100644 --- a/pkgs/development/python-modules/kafka-python-ng/default.nix +++ b/pkgs/development/python-modules/kafka-python-ng/default.nix @@ -31,7 +31,7 @@ buildPythonPackage rec { build-system = [ setuptools-scm ]; optional-dependencies = { - crc32c = [ crc32c ]; + crc32c = [ crc32c ]; lz4 = [ lz4 ]; snappy = [ python-snappy ]; zstd = [ zstandard ]; diff --git a/pkgs/development/python-modules/karton-dashboard/default.nix b/pkgs/development/python-modules/karton-dashboard/default.nix index efbff71a3795c5..90d02be4f461ce 100644 --- a/pkgs/development/python-modules/karton-dashboard/default.nix +++ b/pkgs/development/python-modules/karton-dashboard/default.nix @@ -31,7 +31,6 @@ buildPythonPackage rec { "prometheus-client" ]; - propagatedBuildInputs = [ flask karton-core diff --git a/pkgs/development/python-modules/laundrify-aio/default.nix b/pkgs/development/python-modules/laundrify-aio/default.nix index 21625e58464566..e6ccf3531af220 100644 --- a/pkgs/development/python-modules/laundrify-aio/default.nix +++ b/pkgs/development/python-modules/laundrify-aio/default.nix @@ -13,7 +13,6 @@ buildPythonPackage rec { version = "1.2.2"; pyproject = true; - disabled = pythonOlder "3.7"; src = fetchFromGitHub { diff --git a/pkgs/development/python-modules/llama-index-embeddings-gemini/default.nix b/pkgs/development/python-modules/llama-index-embeddings-gemini/default.nix index 2d1a6281b7cc4e..e27f02e0fc3d5a 100644 --- a/pkgs/development/python-modules/llama-index-embeddings-gemini/default.nix +++ b/pkgs/development/python-modules/llama-index-embeddings-gemini/default.nix @@ -25,7 +25,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ google-generativeai llama-index-core diff --git a/pkgs/development/python-modules/llama-index-embeddings-google/default.nix b/pkgs/development/python-modules/llama-index-embeddings-google/default.nix index b8925cf0d1a5c6..da627edc9f5e06 100644 --- a/pkgs/development/python-modules/llama-index-embeddings-google/default.nix +++ b/pkgs/development/python-modules/llama-index-embeddings-google/default.nix @@ -25,7 +25,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ google-generativeai llama-index-core diff --git a/pkgs/development/python-modules/llama-index-program-openai/default.nix b/pkgs/development/python-modules/llama-index-program-openai/default.nix index c2f57b35edab75..6f8fea48c09391 100644 --- a/pkgs/development/python-modules/llama-index-program-openai/default.nix +++ b/pkgs/development/python-modules/llama-index-program-openai/default.nix @@ -26,7 +26,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ llama-index-agent-openai llama-index-core diff --git a/pkgs/development/python-modules/llama-index-readers-file/default.nix b/pkgs/development/python-modules/llama-index-readers-file/default.nix index a8d452f6e20743..e62d137220967f 100644 --- a/pkgs/development/python-modules/llama-index-readers-file/default.nix +++ b/pkgs/development/python-modules/llama-index-readers-file/default.nix @@ -31,7 +31,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ beautifulsoup4 llama-index-core diff --git a/pkgs/development/python-modules/loguru/default.nix b/pkgs/development/python-modules/loguru/default.nix index 216a20663381ef..d3776308759cd5 100644 --- a/pkgs/development/python-modules/loguru/default.nix +++ b/pkgs/development/python-modules/loguru/default.nix @@ -7,7 +7,7 @@ freezegun, pytestCheckHook, pythonOlder, - pytest-xdist + pytest-xdist, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/lsassy/default.nix b/pkgs/development/python-modules/lsassy/default.nix index f85a1f134eba46..5bd9ec7c0df707 100644 --- a/pkgs/development/python-modules/lsassy/default.nix +++ b/pkgs/development/python-modules/lsassy/default.nix @@ -30,7 +30,6 @@ buildPythonPackage rec { "rich" ]; - build-system = [ poetry-core ]; dependencies = [ diff --git a/pkgs/development/python-modules/magic-wormhole-mailbox-server/default.nix b/pkgs/development/python-modules/magic-wormhole-mailbox-server/default.nix index 8ee9ab16ef3d76..0459564e2a6319 100644 --- a/pkgs/development/python-modules/magic-wormhole-mailbox-server/default.nix +++ b/pkgs/development/python-modules/magic-wormhole-mailbox-server/default.nix @@ -24,12 +24,15 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ - attrs - autobahn - setuptools # pkg_resources is referenced at runtime - twisted - ] ++ autobahn.optional-dependencies.twisted ++ twisted.optional-dependencies.tls; + dependencies = + [ + attrs + autobahn + setuptools # pkg_resources is referenced at runtime + twisted + ] + ++ autobahn.optional-dependencies.twisted + ++ twisted.optional-dependencies.tls; pythonImportsCheck = [ "wormhole_mailbox_server" ]; diff --git a/pkgs/development/python-modules/magic-wormhole/default.nix b/pkgs/development/python-modules/magic-wormhole/default.nix index f85cfd2959548a..d48fce2d2d9736 100644 --- a/pkgs/development/python-modules/magic-wormhole/default.nix +++ b/pkgs/development/python-modules/magic-wormhole/default.nix @@ -59,21 +59,24 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ - attrs - autobahn - automat - click - humanize - iterable-io - pynacl - six - spake2 - tqdm - twisted - txtorcon - zipstream-ng - ] ++ autobahn.optional-dependencies.twisted ++ twisted.optional-dependencies.tls; + dependencies = + [ + attrs + autobahn + automat + click + humanize + iterable-io + pynacl + six + spake2 + tqdm + twisted + txtorcon + zipstream-ng + ] + ++ autobahn.optional-dependencies.twisted + ++ twisted.optional-dependencies.tls; optional-dependencies = { dilation = [ noiseprotocol ]; diff --git a/pkgs/development/python-modules/manifestoo/default.nix b/pkgs/development/python-modules/manifestoo/default.nix index 45c59f1c230940..14f81fdf2cdfb2 100644 --- a/pkgs/development/python-modules/manifestoo/default.nix +++ b/pkgs/development/python-modules/manifestoo/default.nix @@ -24,12 +24,11 @@ buildPythonPackage rec { nativeCheckInputs = [ pytestCheckHook ]; - propagatedBuildInputs = - [ - manifestoo-core - textual - typer - ]; + propagatedBuildInputs = [ + manifestoo-core + textual + typer + ]; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/development/python-modules/marko/default.nix b/pkgs/development/python-modules/marko/default.nix index d5aaf83d76c086..d8471107f92850 100644 --- a/pkgs/development/python-modules/marko/default.nix +++ b/pkgs/development/python-modules/marko/default.nix @@ -41,9 +41,12 @@ buildPythonPackage rec { "marko" ]; - nativeCheckInputs = [ - pytestCheckHook - ] ++ optional-dependencies.toc ++ optional-dependencies.codehilite; + nativeCheckInputs = + [ + pytestCheckHook + ] + ++ optional-dependencies.toc + ++ optional-dependencies.codehilite; meta = { changelog = "https://github.com/frostming/marko/blob/${src.rev}/CHANGELOG.md"; diff --git a/pkgs/development/python-modules/mathutils/default.nix b/pkgs/development/python-modules/mathutils/default.nix index 97442eba2b8551..13604f3d4cf78c 100644 --- a/pkgs/development/python-modules/mathutils/default.nix +++ b/pkgs/development/python-modules/mathutils/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonPackage -, fetchFromGitLab +{ + lib, + buildPythonPackage, + fetchFromGitLab, -# build-system -, setuptools + # build-system + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/memory-tempfile/default.nix b/pkgs/development/python-modules/memory-tempfile/default.nix index 7255e35f18ef38..a50a7c50de60c8 100644 --- a/pkgs/development/python-modules/memory-tempfile/default.nix +++ b/pkgs/development/python-modules/memory-tempfile/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, fetchpatch2 -, poetry-core +{ + lib, + buildPythonPackage, + fetchFromGitHub, + fetchpatch2, + poetry-core, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/minichain/default.nix b/pkgs/development/python-modules/minichain/default.nix index 5109a0136bde83..4c87c4c9e2c9ec 100644 --- a/pkgs/development/python-modules/minichain/default.nix +++ b/pkgs/development/python-modules/minichain/default.nix @@ -31,7 +31,6 @@ buildPythonPackage rec { substituteInPlace ./minichain/__init__.py --replace "from .gradio import GradioConf, show" "" ''; - pythonRemoveDeps = [ # Only used in the examples: "datasets" diff --git a/pkgs/development/python-modules/mitmproxy-rs/default.nix b/pkgs/development/python-modules/mitmproxy-rs/default.nix index fecb4d9794b4ee..ec433ca357f364 100644 --- a/pkgs/development/python-modules/mitmproxy-rs/default.nix +++ b/pkgs/development/python-modules/mitmproxy-rs/default.nix @@ -49,7 +49,9 @@ buildPythonPackage rec { meta = with lib; { description = "Rust bits in mitmproxy"; homepage = "https://github.com/mitmproxy/mitmproxy_rs"; - changelog = "https://github.com/mitmproxy/mitmproxy_rs/blob/${src.rev}/CHANGELOG.md#${lib.replaceStrings ["."] [""] version}"; + changelog = "https://github.com/mitmproxy/mitmproxy_rs/blob/${src.rev}/CHANGELOG.md#${ + lib.replaceStrings [ "." ] [ "" ] version + }"; license = licenses.mit; inherit (mitmproxy.meta) maintainers; }; diff --git a/pkgs/development/python-modules/mkdocs-awesome-pages-plugin/default.nix b/pkgs/development/python-modules/mkdocs-awesome-pages-plugin/default.nix index 8799dfcd380a8d..d2d5ccb84b7bd3 100644 --- a/pkgs/development/python-modules/mkdocs-awesome-pages-plugin/default.nix +++ b/pkgs/development/python-modules/mkdocs-awesome-pages-plugin/default.nix @@ -32,7 +32,7 @@ buildPythonPackage rec { natsort ]; - nativeBuildInputs = [poetry-core]; + nativeBuildInputs = [ poetry-core ]; nativeCheckInputs = [ pytestCheckHook @@ -46,6 +46,6 @@ buildPythonPackage rec { homepage = "https://github.com/lukasgeiter/mkdocs-awesome-pages-plugin"; changelog = "https://github.com/lukasgeiter/mkdocs-awesome-pages-plugin/blob/v${version}/CHANGELOG"; license = licenses.mit; - maintainers = with maintainers; [phaer]; + maintainers = with maintainers; [ phaer ]; }; } diff --git a/pkgs/development/python-modules/mkdocs-get-deps/default.nix b/pkgs/development/python-modules/mkdocs-get-deps/default.nix index 3b36dfb7fea223..60faf85431f3f1 100644 --- a/pkgs/development/python-modules/mkdocs-get-deps/default.nix +++ b/pkgs/development/python-modules/mkdocs-get-deps/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, hatchling -, importlib-metadata -, mergedeep -, platformdirs -, pyyaml -, pytestCheckHook +{ + lib, + buildPythonPackage, + fetchFromGitHub, + hatchling, + importlib-metadata, + mergedeep, + platformdirs, + pyyaml, + pytestCheckHook, }: buildPythonPackage rec { @@ -30,7 +31,7 @@ buildPythonPackage rec { pyyaml ]; - nativeCheckInputs = [ pytestCheckHook ]; + nativeCheckInputs = [ pytestCheckHook ]; pythonImportsCheck = [ "mkdocs_get_deps" ]; diff --git a/pkgs/development/python-modules/moddb/default.nix b/pkgs/development/python-modules/moddb/default.nix index 17af65e37a2068..9da9cb837c51a2 100644 --- a/pkgs/development/python-modules/moddb/default.nix +++ b/pkgs/development/python-modules/moddb/default.nix @@ -20,7 +20,6 @@ buildPythonPackage rec { hash = "sha256-2t5QQAmSLOrdNCl0XdsFPdP2UF10/qq69DovqeQ1Vt8="; }; - propagatedBuildInputs = [ beautifulsoup4 pyrate-limiter diff --git a/pkgs/development/python-modules/model-checker/default.nix b/pkgs/development/python-modules/model-checker/default.nix index 3de3be17c54642..0a27a55ad02c68 100644 --- a/pkgs/development/python-modules/model-checker/default.nix +++ b/pkgs/development/python-modules/model-checker/default.nix @@ -26,7 +26,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ tqdm z3-solver diff --git a/pkgs/development/python-modules/molbar/default.nix b/pkgs/development/python-modules/molbar/default.nix index d2f608a8049cb9..8096a9a2212d2c 100644 --- a/pkgs/development/python-modules/molbar/default.nix +++ b/pkgs/development/python-modules/molbar/default.nix @@ -1,21 +1,22 @@ -{ buildPythonPackage -, lib -, gfortran -, fetchgit -, cmake -, ninja -, networkx -, numpy -, pandas -, scipy -, tqdm -, joblib -, numba -, ase -, scikit-build -, dscribe -, pyyaml -, pytestCheckHook +{ + buildPythonPackage, + lib, + gfortran, + fetchgit, + cmake, + ninja, + networkx, + numpy, + pandas, + scipy, + tqdm, + joblib, + numba, + ase, + scikit-build, + dscribe, + pyyaml, + pytestCheckHook, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/mozilla-django-oidc/default.nix b/pkgs/development/python-modules/mozilla-django-oidc/default.nix index 78c24b8b0b785f..cd44808efc57ed 100644 --- a/pkgs/development/python-modules/mozilla-django-oidc/default.nix +++ b/pkgs/development/python-modules/mozilla-django-oidc/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, setuptools -, djangorestframework -, django -, josepy -, requests -, cryptography +{ + lib, + buildPythonPackage, + fetchFromGitHub, + setuptools, + djangorestframework, + django, + josepy, + requests, + cryptography, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/mwcli/default.nix b/pkgs/development/python-modules/mwcli/default.nix index adcc5ab1e34cca..9c644cf9c41b01 100644 --- a/pkgs/development/python-modules/mwcli/default.nix +++ b/pkgs/development/python-modules/mwcli/default.nix @@ -19,7 +19,6 @@ buildPythonPackage rec { # Prevent circular dependency pythonRemoveDeps = [ "mwxml" ]; - propagatedBuildInputs = [ docopt para diff --git a/pkgs/development/python-modules/mypy-protobuf/default.nix b/pkgs/development/python-modules/mypy-protobuf/default.nix index 0dca10652ac615..7c6bdb19db41a6 100644 --- a/pkgs/development/python-modules/mypy-protobuf/default.nix +++ b/pkgs/development/python-modules/mypy-protobuf/default.nix @@ -24,7 +24,6 @@ buildPythonPackage rec { hash = "sha256-AvJC6zQJ9miJ8rGjqlg1bsTZCc3Q+TEVYi6ecDZuyjw="; }; - pythonRelaxDeps = [ "protobuf" ]; build-system = [ setuptools ]; diff --git a/pkgs/development/python-modules/natural/default.nix b/pkgs/development/python-modules/natural/default.nix index fc6bde5f8dc057..8e8b32fc84098a 100644 --- a/pkgs/development/python-modules/natural/default.nix +++ b/pkgs/development/python-modules/natural/default.nix @@ -1,9 +1,10 @@ -{ buildPythonPackage -, fetchFromGitHub -, lib -, setuptools -, six -, django +{ + buildPythonPackage, + fetchFromGitHub, + lib, + setuptools, + six, + django, }: buildPythonPackage rec { pname = "natural"; @@ -27,6 +28,9 @@ buildPythonPackage rec { description = "Convert data to their natural (human-readable) format"; homepage = "https://github.com/tehmaze/natural"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ sailord vinetos ]; + maintainers = with lib.maintainers; [ + sailord + vinetos + ]; }; } diff --git a/pkgs/development/python-modules/nbdev/default.nix b/pkgs/development/python-modules/nbdev/default.nix index b25da1d8b1133f..fb3df9b93a6b40 100644 --- a/pkgs/development/python-modules/nbdev/default.nix +++ b/pkgs/development/python-modules/nbdev/default.nix @@ -25,7 +25,6 @@ buildPythonPackage rec { hash = "sha256-oHZjN+Qu4I9HyR1ReATgCdheTfvphJUcvs7od1OOTvc="; }; - pythonRelaxDeps = [ "ipywidgets" ]; build-system = [ setuptools ]; diff --git a/pkgs/development/python-modules/nengo/default.nix b/pkgs/development/python-modules/nengo/default.nix index 915663c0b13fcf..6ada695cbc0d66 100644 --- a/pkgs/development/python-modules/nengo/default.nix +++ b/pkgs/development/python-modules/nengo/default.nix @@ -24,9 +24,12 @@ buildPythonPackage rec { nativeBuildInputs = [ setuptools ]; - propagatedBuildInputs = [ - numpy - ] ++ lib.optionals scipySupport [ scipy ] ++ lib.optionals scikitSupport [ scikit-learn ]; + propagatedBuildInputs = + [ + numpy + ] + ++ lib.optionals scipySupport [ scipy ] + ++ lib.optionals scikitSupport [ scikit-learn ]; # checks req missing: # pytest-allclose diff --git a/pkgs/development/python-modules/netdata-pandas/default.nix b/pkgs/development/python-modules/netdata-pandas/default.nix index 01fb2d65c65c27..ff8bc2c4622ed9 100644 --- a/pkgs/development/python-modules/netdata-pandas/default.nix +++ b/pkgs/development/python-modules/netdata-pandas/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, setuptools -, pandas -, requests -, trio -, asks +{ + lib, + buildPythonPackage, + fetchFromGitHub, + setuptools, + pandas, + requests, + trio, + asks, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/niapy/default.nix b/pkgs/development/python-modules/niapy/default.nix index 575ee5043044f0..ca443b5526bead 100644 --- a/pkgs/development/python-modules/niapy/default.nix +++ b/pkgs/development/python-modules/niapy/default.nix @@ -35,7 +35,10 @@ buildPythonPackage rec { pandas ]; - nativeCheckInputs = [ pytest7CheckHook pytest-xdist ]; + nativeCheckInputs = [ + pytest7CheckHook + pytest-xdist + ]; pythonImportsCheck = [ "niapy" ]; diff --git a/pkgs/development/python-modules/nodriver/default.nix b/pkgs/development/python-modules/nodriver/default.nix index 9a19815af991e5..86572a31b2e985 100644 --- a/pkgs/development/python-modules/nodriver/default.nix +++ b/pkgs/development/python-modules/nodriver/default.nix @@ -48,4 +48,3 @@ buildPythonPackage rec { ]; }; } - diff --git a/pkgs/development/python-modules/notus-scanner/default.nix b/pkgs/development/python-modules/notus-scanner/default.nix index d665a7d9baf45a..83b710fdbb11b3 100644 --- a/pkgs/development/python-modules/notus-scanner/default.nix +++ b/pkgs/development/python-modules/notus-scanner/default.nix @@ -34,7 +34,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - propagatedBuildInputs = [ paho-mqtt psutil diff --git a/pkgs/development/python-modules/objexplore/default.nix b/pkgs/development/python-modules/objexplore/default.nix index 02d4ceeb214283..a23561876a1ef4 100644 --- a/pkgs/development/python-modules/objexplore/default.nix +++ b/pkgs/development/python-modules/objexplore/default.nix @@ -7,7 +7,7 @@ blessed, rich, pytestCheckHook, - pandas + pandas, }: buildPythonPackage { @@ -26,7 +26,10 @@ buildPythonPackage { hash = "sha256-BgeuRRuvbB4p99mwCjNxm3hYEZuGua8x2GdoVssQ7eI="; }; - pythonRelaxDeps = [ "blessed" "rich" ]; + pythonRelaxDeps = [ + "blessed" + "rich" + ]; build-system = [ setuptools ]; @@ -56,6 +59,9 @@ buildPythonPackage { description = "Terminal UI to interactively inspect and explore Python objects"; homepage = "https://github.com/kylepollina/objexplore"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ pbsds sigmanificient ]; + maintainers = with lib.maintainers; [ + pbsds + sigmanificient + ]; }; } diff --git a/pkgs/development/python-modules/ollama/default.nix b/pkgs/development/python-modules/ollama/default.nix index 4f5266494e5cb5..c0b556a9408240 100644 --- a/pkgs/development/python-modules/ollama/default.nix +++ b/pkgs/development/python-modules/ollama/default.nix @@ -34,7 +34,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ httpx ]; nativeCheckInputs = [ diff --git a/pkgs/development/python-modules/openrazer/daemon.nix b/pkgs/development/python-modules/openrazer/daemon.nix index f1af8a82faf719..0bcfd6b516540c 100644 --- a/pkgs/development/python-modules/openrazer/daemon.nix +++ b/pkgs/development/python-modules/openrazer/daemon.nix @@ -12,58 +12,65 @@ setuptools, wrapGAppsNoGuiHook, notify2, - glib + glib, }: let common = import ./common.nix { inherit lib fetchFromGitHub; }; in -buildPythonPackage (common // { - pname = "openrazer-daemon"; +buildPythonPackage ( + common + // { + pname = "openrazer-daemon"; - outputs = [ - "out" - "man" - ]; + outputs = [ + "out" + "man" + ]; - sourceRoot = "${common.src.name}/daemon"; + sourceRoot = "${common.src.name}/daemon"; - postPatch = '' - substituteInPlace openrazer_daemon/daemon.py \ - --replace-fail "plugdev" "openrazer" - ''; + postPatch = '' + substituteInPlace openrazer_daemon/daemon.py \ + --replace-fail "plugdev" "openrazer" + ''; - nativeBuildInputs = [ setuptools wrapGAppsNoGuiHook gobject-introspection ]; + nativeBuildInputs = [ + setuptools + wrapGAppsNoGuiHook + gobject-introspection + ]; - buildInputs = [ - glib - gtk3 - ]; + buildInputs = [ + glib + gtk3 + ]; - propagatedBuildInputs = [ - daemonize - dbus-python - pygobject3 - pyudev - setproctitle - notify2 - ]; + propagatedBuildInputs = [ + daemonize + dbus-python + pygobject3 + pyudev + setproctitle + notify2 + ]; - postInstall = '' - DESTDIR="$out" PREFIX="" make manpages install-resources install-systemd - ''; + postInstall = '' + DESTDIR="$out" PREFIX="" make manpages install-resources install-systemd + ''; - # no tests run - doCheck = false; + # no tests run + doCheck = false; - dontWrapGApps = true; + dontWrapGApps = true; - preFixup = '' - makeWrapperArgs+=("''${gappsWrapperArgs[@]}") - ''; + preFixup = '' + makeWrapperArgs+=("''${gappsWrapperArgs[@]}") + ''; - meta = common.meta // { - description = "Entirely open source user-space daemon that allows you to manage your Razer peripherals on GNU/Linux"; - mainProgram = "openrazer-daemon"; - }; -}) + meta = common.meta // { + description = "Entirely open source user-space daemon that allows you to manage your Razer peripherals on GNU/Linux"; + mainProgram = "openrazer-daemon"; + }; + } +) diff --git a/pkgs/development/python-modules/opentelemetry-api/default.nix b/pkgs/development/python-modules/opentelemetry-api/default.nix index 08d5458968c8e3..85e4520ec61d12 100644 --- a/pkgs/development/python-modules/opentelemetry-api/default.nix +++ b/pkgs/development/python-modules/opentelemetry-api/default.nix @@ -29,7 +29,6 @@ let sourceRoot = "${src.name}/opentelemetry-api"; - build-system = [ hatchling ]; dependencies = [ diff --git a/pkgs/development/python-modules/optuna/default.nix b/pkgs/development/python-modules/optuna/default.nix index 85f3062a8b9b41..9df86d3458d843 100644 --- a/pkgs/development/python-modules/optuna/default.nix +++ b/pkgs/development/python-modules/optuna/default.nix @@ -105,13 +105,16 @@ buildPythonPackage rec { export PATH=$out/bin:$PATH ''; - nativeCheckInputs = [ - fakeredis - moto - pytest-xdist - pytestCheckHook - scipy - ] ++ fakeredis.optional-dependencies.lua ++ optional-dependencies.optional; + nativeCheckInputs = + [ + fakeredis + moto + pytest-xdist + pytestCheckHook + scipy + ] + ++ fakeredis.optional-dependencies.lua + ++ optional-dependencies.optional; pytestFlagsArray = [ "-m 'not integration'" ]; diff --git a/pkgs/development/python-modules/oss2/default.nix b/pkgs/development/python-modules/oss2/default.nix index 374f526b57f544..c44c7c276e6bec 100644 --- a/pkgs/development/python-modules/oss2/default.nix +++ b/pkgs/development/python-modules/oss2/default.nix @@ -28,7 +28,6 @@ buildPythonPackage rec { hash = "sha256-jDSXPVyy8XvPgsGZXsdfavFPptq28pCwr9C63OZvNrY="; }; - propagatedBuildInputs = [ requests crcmod diff --git a/pkgs/development/python-modules/outspin/default.nix b/pkgs/development/python-modules/outspin/default.nix index 4555e9cbca3c78..3d0d8e34ad81f9 100644 --- a/pkgs/development/python-modules/outspin/default.nix +++ b/pkgs/development/python-modules/outspin/default.nix @@ -3,7 +3,7 @@ buildPythonPackage, fetchFromGitHub, poetry-core, - pytestCheckHook + pytestCheckHook, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/paho-mqtt/default.nix b/pkgs/development/python-modules/paho-mqtt/default.nix index 890cf28a7462bb..10afacd1c1973d 100644 --- a/pkgs/development/python-modules/paho-mqtt/default.nix +++ b/pkgs/development/python-modules/paho-mqtt/default.nix @@ -15,7 +15,8 @@ let rev = "a4dc694010217b291ee78ee13a6d1db812f9babd"; hash = "sha256-SQoNdkWMjnasPjpXQF2yV97MUra8gb27pc3rNoA8Rjw="; }; -in buildPythonPackage rec { +in +buildPythonPackage rec { pname = "paho-mqtt"; version = "2.1.0"; pyproject = true; diff --git a/pkgs/development/python-modules/papermill/default.nix b/pkgs/development/python-modules/papermill/default.nix index bf81409491cec8..6291f013941463 100644 --- a/pkgs/development/python-modules/papermill/default.nix +++ b/pkgs/development/python-modules/papermill/default.nix @@ -69,12 +69,16 @@ buildPythonPackage rec { s3 = [ boto3 ]; }; - nativeCheckInputs = [ - ipykernel - moto - pytest-mock - pytestCheckHook - ] ++ optional-dependencies.azure ++ optional-dependencies.s3 ++ optional-dependencies.gcs; + nativeCheckInputs = + [ + ipykernel + moto + pytest-mock + pytestCheckHook + ] + ++ optional-dependencies.azure + ++ optional-dependencies.s3 + ++ optional-dependencies.gcs; preCheck = '' export HOME=$(mktemp -d) diff --git a/pkgs/development/python-modules/passlib/default.nix b/pkgs/development/python-modules/passlib/default.nix index 98be7873032aee..396afc45dfbef3 100644 --- a/pkgs/development/python-modules/passlib/default.nix +++ b/pkgs/development/python-modules/passlib/default.nix @@ -43,10 +43,14 @@ buildPythonPackage rec { "version = getattr(getattr(_bcrypt, '__about__', _bcrypt), '__version__', '')" ''; - nativeCheckInputs = [ - pytestCheckHook - pytest-xdist - ] ++ optional-dependencies.argon2 ++ optional-dependencies.bcrypt ++ optional-dependencies.totp; + nativeCheckInputs = + [ + pytestCheckHook + pytest-xdist + ] + ++ optional-dependencies.argon2 + ++ optional-dependencies.bcrypt + ++ optional-dependencies.totp; pythonImportsCheck = [ "passlib" ]; diff --git a/pkgs/development/python-modules/pathy/default.nix b/pkgs/development/python-modules/pathy/default.nix index 3e384c62a98a34..fa7286d4687933 100644 --- a/pkgs/development/python-modules/pathy/default.nix +++ b/pkgs/development/python-modules/pathy/default.nix @@ -23,7 +23,6 @@ buildPythonPackage rec { hash = "sha256-uz0OawuL92709jxxkeluCvLtZcj9tfoXSI+ch55jcG0="; }; - pythonRelaxDeps = [ "smart-open" ]; build-system = [ setuptools ]; diff --git a/pkgs/development/python-modules/pdb2pqr/default.nix b/pkgs/development/python-modules/pdb2pqr/default.nix index e082eab102bae6..073c52f5f6e4ef 100644 --- a/pkgs/development/python-modules/pdb2pqr/default.nix +++ b/pkgs/development/python-modules/pdb2pqr/default.nix @@ -25,7 +25,6 @@ buildPythonPackage rec { hash = "sha256-He301TJ1bzWub0DZ6Ro/Xc+JMtJBbyygVpWjPY6RMbA="; }; - pythonRelaxDeps = [ "docutils" ]; propagatedBuildInputs = [ diff --git a/pkgs/development/python-modules/persistent/default.nix b/pkgs/development/python-modules/persistent/default.nix index 18fc8b244fbb48..97553db305af8e 100644 --- a/pkgs/development/python-modules/persistent/default.nix +++ b/pkgs/development/python-modules/persistent/default.nix @@ -36,8 +36,7 @@ buildPythonPackage rec { dependencies = [ zope-interface zope-deferredimport - ] - ++ lib.optionals (!isPyPy) [ cffi ]; + ] ++ lib.optionals (!isPyPy) [ cffi ]; pythonImportsCheck = [ "persistent" ]; diff --git a/pkgs/development/python-modules/piccolo-theme/default.nix b/pkgs/development/python-modules/piccolo-theme/default.nix index 5c8bf351b52594..6f736f142961aa 100644 --- a/pkgs/development/python-modules/piccolo-theme/default.nix +++ b/pkgs/development/python-modules/piccolo-theme/default.nix @@ -13,7 +13,7 @@ buildPythonPackage rec { disabled = pythonOlder "3.9"; - src = fetchPypi { + src = fetchPypi { pname = "piccolo_theme"; inherit version; hash = "sha256-Cc9w9Lttuk680UlmVQwpIznBHZMclTMiHNPb/+sdG9k="; diff --git a/pkgs/development/python-modules/pinecone-client/default.nix b/pkgs/development/python-modules/pinecone-client/default.nix index a22aa39aa82e8d..9ade9dc4d2ce0c 100644 --- a/pkgs/development/python-modules/pinecone-client/default.nix +++ b/pkgs/development/python-modules/pinecone-client/default.nix @@ -31,7 +31,6 @@ buildPythonPackage rec { pythonRelaxDeps = [ "urllib3" ]; - build-system = [ setuptools poetry-core diff --git a/pkgs/development/python-modules/pip/default.nix b/pkgs/development/python-modules/pip/default.nix index 058970320f90d7..97043d7ca8d327 100644 --- a/pkgs/development/python-modules/pip/default.nix +++ b/pkgs/development/python-modules/pip/default.nix @@ -27,94 +27,96 @@ pip-tools, }: -let self = buildPythonPackage rec { - pname = "pip"; - version = "24.0"; - format = "pyproject"; - - src = fetchFromGitHub { - owner = "pypa"; - repo = pname; - rev = "refs/tags/${version}"; - hash = "sha256-yojk2T5wuPkS1OKusilj253AT+xyKwXCWKBNUEH2Mgo="; +let + self = buildPythonPackage rec { + pname = "pip"; + version = "24.0"; + format = "pyproject"; + + src = fetchFromGitHub { + owner = "pypa"; + repo = pname; + rev = "refs/tags/${version}"; + hash = "sha256-yojk2T5wuPkS1OKusilj253AT+xyKwXCWKBNUEH2Mgo="; + }; + + postPatch = '' + # Remove vendored Windows PE binaries + # Note: These are unused but make the package unreproducible. + find -type f -name '*.exe' -delete + ''; + + nativeBuildInputs = [ + installShellFiles + setuptools + wheel + + # docs + sphinx + ]; + + outputs = [ + "out" + "man" + ]; + + # pip uses a custom sphinx extension and unusual conf.py location, mimic the internal build rather than attempting + # to fit sphinxHook see https://github.com/pypa/pip/blob/0778c1c153da7da457b56df55fb77cbba08dfb0c/noxfile.py#L129-L148 + postBuild = '' + cd docs + + # remove references to sphinx extentions only required for html doc generation + # sphinx.ext.intersphinx requires network connection or packaged object.inv files for python and pypug + # sphinxcontrib.towncrier is not currently packaged + for ext in sphinx.ext.intersphinx sphinx_copybutton sphinx_inline_tabs sphinxcontrib.towncrier myst_parser; do + substituteInPlace html/conf.py --replace '"'$ext'",' "" + done + + PYTHONPATH=$src/src:$PYTHONPATH sphinx-build -v \ + -d build/doctrees/man \ + -c html \ + -d build/doctrees/man \ + -b man \ + man \ + build/man + cd .. + ''; + + doCheck = false; + + nativeCheckInputs = [ + freezegun + git + mock + scripttest + virtualenv + pretend + pytestCheckHook + proxy-py + tomli-w + werkzeug + ]; + + postInstall = '' + installManPage docs/build/man/* + + installShellCompletion --cmd pip \ + --bash <($out/bin/pip completion --bash --no-cache-dir) \ + --fish <($out/bin/pip completion --fish --no-cache-dir) \ + --zsh <($out/bin/pip completion --zsh --no-cache-dir) + ''; + + passthru.tests = { + inherit pip-tools; + pytest = self.overridePythonAttrs { doCheck = true; }; + }; + + meta = { + description = "PyPA recommended tool for installing Python packages"; + license = with lib.licenses; [ mit ]; + homepage = "https://pip.pypa.io/"; + changelog = "https://pip.pypa.io/en/stable/news/#v${lib.replaceStrings [ "." ] [ "-" ] version}"; + }; }; - - postPatch = '' - # Remove vendored Windows PE binaries - # Note: These are unused but make the package unreproducible. - find -type f -name '*.exe' -delete - ''; - - nativeBuildInputs = [ - installShellFiles - setuptools - wheel - - # docs - sphinx - ]; - - outputs = [ - "out" - "man" - ]; - - # pip uses a custom sphinx extension and unusual conf.py location, mimic the internal build rather than attempting - # to fit sphinxHook see https://github.com/pypa/pip/blob/0778c1c153da7da457b56df55fb77cbba08dfb0c/noxfile.py#L129-L148 - postBuild = '' - cd docs - - # remove references to sphinx extentions only required for html doc generation - # sphinx.ext.intersphinx requires network connection or packaged object.inv files for python and pypug - # sphinxcontrib.towncrier is not currently packaged - for ext in sphinx.ext.intersphinx sphinx_copybutton sphinx_inline_tabs sphinxcontrib.towncrier myst_parser; do - substituteInPlace html/conf.py --replace '"'$ext'",' "" - done - - PYTHONPATH=$src/src:$PYTHONPATH sphinx-build -v \ - -d build/doctrees/man \ - -c html \ - -d build/doctrees/man \ - -b man \ - man \ - build/man - cd .. - ''; - - doCheck = false; - - nativeCheckInputs = [ - freezegun - git - mock - scripttest - virtualenv - pretend - pytestCheckHook - proxy-py - tomli-w - werkzeug - ]; - - postInstall = '' - installManPage docs/build/man/* - - installShellCompletion --cmd pip \ - --bash <($out/bin/pip completion --bash --no-cache-dir) \ - --fish <($out/bin/pip completion --fish --no-cache-dir) \ - --zsh <($out/bin/pip completion --zsh --no-cache-dir) - ''; - - passthru.tests = { - inherit pip-tools; - pytest = self.overridePythonAttrs { doCheck = true; }; - }; - - meta = { - description = "PyPA recommended tool for installing Python packages"; - license = with lib.licenses; [ mit ]; - homepage = "https://pip.pypa.io/"; - changelog = "https://pip.pypa.io/en/stable/news/#v${lib.replaceStrings [ "." ] [ "-" ] version}"; - }; -}; -in self +in +self diff --git a/pkgs/development/python-modules/playwrightcapture/default.nix b/pkgs/development/python-modules/playwrightcapture/default.nix index 75c4970abb117a..764f75c5647120 100644 --- a/pkgs/development/python-modules/playwrightcapture/default.nix +++ b/pkgs/development/python-modules/playwrightcapture/default.nix @@ -45,7 +45,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ aiohttp aiohttp-socks diff --git a/pkgs/development/python-modules/plugp100/default.nix b/pkgs/development/python-modules/plugp100/default.nix index 6a79e5b30068ba..0cc356e3d15b55 100644 --- a/pkgs/development/python-modules/plugp100/default.nix +++ b/pkgs/development/python-modules/plugp100/default.nix @@ -14,7 +14,7 @@ pyyaml, pytest-asyncio, async-timeout, - }: +}: buildPythonPackage rec { pname = "plugp100"; @@ -27,10 +27,22 @@ buildPythonPackage rec { sha256 = "sha256-V+9cVBMN8H4oFU51T9BDrLF46xgQHqIsMj8nuPedUGA="; }; - propagatedBuildInputs = - [ certifi jsons requests aiohttp semantic-version scapy urllib3 pyyaml ]; + propagatedBuildInputs = [ + certifi + jsons + requests + aiohttp + semantic-version + scapy + urllib3 + pyyaml + ]; - nativeCheckInputs = [ pytestCheckHook pytest-asyncio async-timeout ]; + nativeCheckInputs = [ + pytestCheckHook + pytest-asyncio + async-timeout + ]; disabledTestPaths = [ "tests/integration/" diff --git a/pkgs/development/python-modules/prometheus-async/default.nix b/pkgs/development/python-modules/prometheus-async/default.nix index 22627f161fa22a..9f35acd96b1a9f 100644 --- a/pkgs/development/python-modules/prometheus-async/default.nix +++ b/pkgs/development/python-modules/prometheus-async/default.nix @@ -1,17 +1,18 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub +{ + lib, + buildPythonPackage, + fetchFromGitHub, -, flit-core + flit-core, -, prometheus-client -, typing-extensions -, wrapt -, aiohttp -, twisted + prometheus-client, + typing-extensions, + wrapt, + aiohttp, + twisted, -, pytestCheckHook -, pytest-asyncio + pytestCheckHook, + pytest-asyncio, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/prometheus-fastapi-instrumentator/default.nix b/pkgs/development/python-modules/prometheus-fastapi-instrumentator/default.nix index 9ec29ff80bca18..62168d3d745c7d 100644 --- a/pkgs/development/python-modules/prometheus-fastapi-instrumentator/default.nix +++ b/pkgs/development/python-modules/prometheus-fastapi-instrumentator/default.nix @@ -1,15 +1,16 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, pythonOlder -, pytestCheckHook -, devtools -, fastapi -, httpx -, poetry-core -, prometheus-client -, requests -, starlette +{ + lib, + buildPythonPackage, + fetchFromGitHub, + pythonOlder, + pytestCheckHook, + devtools, + fastapi, + httpx, + poetry-core, + prometheus-client, + requests, + starlette, }: buildPythonPackage rec { @@ -49,8 +50,11 @@ buildPythonPackage rec { description = "Instrument FastAPI with Prometheus metrics"; homepage = "https://github.com/trallnag/prometheus-fastapi-instrumentator"; changelog = "https://github.com/trallnag/prometheus-fastapi-instrumentator/blob/${src.rev}/CHANGELOG.md"; - license = with lib.licenses; [ isc bsd3 ]; + license = with lib.licenses; [ + isc + bsd3 + ]; maintainers = with lib.maintainers; [ bcdarwin ]; - platforms = lib.platforms.linux; # numerous test failures on Darwin + platforms = lib.platforms.linux; # numerous test failures on Darwin }; } diff --git a/pkgs/development/python-modules/prometrix/default.nix b/pkgs/development/python-modules/prometrix/default.nix index 52e0621136c7e1..4c362e26ef2778 100644 --- a/pkgs/development/python-modules/prometrix/default.nix +++ b/pkgs/development/python-modules/prometrix/default.nix @@ -34,7 +34,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ boto3 botocore diff --git a/pkgs/development/python-modules/py-opensonic/default.nix b/pkgs/development/python-modules/py-opensonic/default.nix index 3a7bb3244536b5..00d06bf5576f51 100644 --- a/pkgs/development/python-modules/py-opensonic/default.nix +++ b/pkgs/development/python-modules/py-opensonic/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, setuptools -, requests +{ + lib, + buildPythonPackage, + fetchFromGitHub, + setuptools, + requests, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/py-slvs/default.nix b/pkgs/development/python-modules/py-slvs/default.nix index 1f434fe66970f3..5f68487a879a0a 100644 --- a/pkgs/development/python-modules/py-slvs/default.nix +++ b/pkgs/development/python-modules/py-slvs/default.nix @@ -47,4 +47,3 @@ buildPythonPackage rec { ]; }; } - diff --git a/pkgs/development/python-modules/pyTelegramBotAPI/default.nix b/pkgs/development/python-modules/pyTelegramBotAPI/default.nix index 1e225cd5fa6439..66eade834fbe4b 100644 --- a/pkgs/development/python-modules/pyTelegramBotAPI/default.nix +++ b/pkgs/development/python-modules/pyTelegramBotAPI/default.nix @@ -47,10 +47,13 @@ buildPythonPackage rec { watchdog = [ watchdog ]; }; - checkInputs = [ - pytestCheckHook - requests - ] ++ optional-dependencies.watchdog ++ optional-dependencies.aiohttp; + checkInputs = + [ + pytestCheckHook + requests + ] + ++ optional-dependencies.watchdog + ++ optional-dependencies.aiohttp; pythonImportsCheck = [ "telebot" ]; diff --git a/pkgs/development/python-modules/pycddl/default.nix b/pkgs/development/python-modules/pycddl/default.nix index e55a0dc4bf1a9b..660006c9c12a59 100644 --- a/pkgs/development/python-modules/pycddl/default.nix +++ b/pkgs/development/python-modules/pycddl/default.nix @@ -52,7 +52,7 @@ buildPythonPackage rec { cbor2 ]; - disabledTests =[ + disabledTests = [ # flaky "test_memory_usage" ]; diff --git a/pkgs/development/python-modules/pycfmodel/default.nix b/pkgs/development/python-modules/pycfmodel/default.nix index e16ec8a669ab67..0390fedf176078 100644 --- a/pkgs/development/python-modules/pycfmodel/default.nix +++ b/pkgs/development/python-modules/pycfmodel/default.nix @@ -27,7 +27,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ pydantic ]; nativeCheckInputs = [ diff --git a/pkgs/development/python-modules/pycookiecheat/default.nix b/pkgs/development/python-modules/pycookiecheat/default.nix index e40731c554f082..bc51c78bf551b3 100644 --- a/pkgs/development/python-modules/pycookiecheat/default.nix +++ b/pkgs/development/python-modules/pycookiecheat/default.nix @@ -36,7 +36,6 @@ buildPythonPackage rec { setuptools-scm ]; - dependencies = [ cryptography keyring diff --git a/pkgs/development/python-modules/pygame-ce/default.nix b/pkgs/development/python-modules/pygame-ce/default.nix index 80c0d153b72d54..0c7ef2cebbb9e8 100644 --- a/pkgs/development/python-modules/pygame-ce/default.nix +++ b/pkgs/development/python-modules/pygame-ce/default.nix @@ -110,7 +110,6 @@ buildPythonPackage rec { numpy ]; - preConfigure = '' ${python.pythonOnBuildForHost.interpreter} -m buildconfig.config ''; diff --git a/pkgs/development/python-modules/pygame-gui/default.nix b/pkgs/development/python-modules/pygame-gui/default.nix index 6c8261a06b3a79..5808904d063480 100644 --- a/pkgs/development/python-modules/pygame-gui/default.nix +++ b/pkgs/development/python-modules/pygame-gui/default.nix @@ -43,28 +43,32 @@ buildPythonPackage rec { export SDL_VIDEODRIVER=dummy ''; - disabledTests = [ - # Clipboard doesn't exist in test environment - "test_process_event_text_ctrl_c" - "test_process_event_text_ctrl_v" - "test_process_event_text_ctrl_v_nothing" - "test_process_event_ctrl_v_over_limit" - "test_process_event_ctrl_v_at_limit" - "test_process_event_ctrl_v_over_limit_select_range" - "test_process_event_text_ctrl_v_select_range" - "test_process_event_text_ctrl_a" - "test_process_event_text_ctrl_x" - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # fails to determine "/" as an existing path - # https://github.com/MyreMylar/pygame_gui/issues/644 - "test_process_event" - ]; + disabledTests = + [ + # Clipboard doesn't exist in test environment + "test_process_event_text_ctrl_c" + "test_process_event_text_ctrl_v" + "test_process_event_text_ctrl_v_nothing" + "test_process_event_ctrl_v_over_limit" + "test_process_event_ctrl_v_at_limit" + "test_process_event_ctrl_v_over_limit_select_range" + "test_process_event_text_ctrl_v_select_range" + "test_process_event_text_ctrl_a" + "test_process_event_text_ctrl_x" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # fails to determine "/" as an existing path + # https://github.com/MyreMylar/pygame_gui/issues/644 + "test_process_event" + ]; disabledTestPaths = [ "tests/test_performance/test_text_performance.py" ]; passthru.updateScript = nix-update-script { - extraArgs = [ "--version-regex" "v_(.*)" ]; + extraArgs = [ + "--version-regex" + "v_(.*)" + ]; }; meta = with lib; { diff --git a/pkgs/development/python-modules/pygments/default.nix b/pkgs/development/python-modules/pygments/default.nix index 007e36f172331e..dfec7d51976b1a 100644 --- a/pkgs/development/python-modules/pygments/default.nix +++ b/pkgs/development/python-modules/pygments/default.nix @@ -9,7 +9,7 @@ # tests pytestCheckHook, wcag-contrast-ratio, - pythonOlder + pythonOlder, }: let diff --git a/pkgs/development/python-modules/pyinstaller-hooks-contrib/default.nix b/pkgs/development/python-modules/pyinstaller-hooks-contrib/default.nix index 9d1e9bdbb972a0..5ca881319e38a0 100644 --- a/pkgs/development/python-modules/pyinstaller-hooks-contrib/default.nix +++ b/pkgs/development/python-modules/pyinstaller-hooks-contrib/default.nix @@ -1,8 +1,8 @@ { - lib -, buildPythonPackage -, fetchPypi -, setuptools + lib, + buildPythonPackage, + fetchPypi, + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/pyloadapi/default.nix b/pkgs/development/python-modules/pyloadapi/default.nix index cb2e77d5d22384..bf5876cb121110 100644 --- a/pkgs/development/python-modules/pyloadapi/default.nix +++ b/pkgs/development/python-modules/pyloadapi/default.nix @@ -60,4 +60,3 @@ buildPythonPackage rec { maintainers = with maintainers; [ fab ]; }; } - diff --git a/pkgs/development/python-modules/pylsp-rope/default.nix b/pkgs/development/python-modules/pylsp-rope/default.nix index f1d011d2ef025a..43d53049ddde41 100644 --- a/pkgs/development/python-modules/pylsp-rope/default.nix +++ b/pkgs/development/python-modules/pylsp-rope/default.nix @@ -26,7 +26,7 @@ buildPythonPackage rec { hash = "sha256-gEmSZQZ2rtSljN8USsUiqsP2cr54k6kwvsz8cjam9dU="; }; - build-system = [ + build-system = [ setuptools ]; diff --git a/pkgs/development/python-modules/pymsteams/default.nix b/pkgs/development/python-modules/pymsteams/default.nix index 6708d5bed7071d..11f818c2b5e6ab 100644 --- a/pkgs/development/python-modules/pymsteams/default.nix +++ b/pkgs/development/python-modules/pymsteams/default.nix @@ -16,7 +16,7 @@ buildPythonPackage rec { src = fetchFromGitHub { owner = "rveachkc"; - repo ="pymsteams"; + repo = "pymsteams"; rev = "refs/tags/${version}"; hash = "sha256-suPCAzjQp46+kKFiCtm65lxBbsn78Owq4dVmWCdhIpA="; }; diff --git a/pkgs/development/python-modules/pynvim/default.nix b/pkgs/development/python-modules/pynvim/default.nix index 3897b971e32c52..9b110f8f2e83ad 100644 --- a/pkgs/development/python-modules/pynvim/default.nix +++ b/pkgs/development/python-modules/pynvim/default.nix @@ -26,7 +26,8 @@ buildPythonPackage rec { dependencies = [ msgpack ] - ++ lib.optionals (!isPyPy) [ greenlet ] ++ lib.optionals (pythonOlder "3.12") [ typing-extensions ]; + ++ lib.optionals (!isPyPy) [ greenlet ] + ++ lib.optionals (pythonOlder "3.12") [ typing-extensions ]; # Tests require pkgs.neovim which we cannot add because of circular dependency doCheck = false; diff --git a/pkgs/development/python-modules/pyowm/default.nix b/pkgs/development/python-modules/pyowm/default.nix index 78d8e05301e4fb..afc3fc3ba0b283 100644 --- a/pkgs/development/python-modules/pyowm/default.nix +++ b/pkgs/development/python-modules/pyowm/default.nix @@ -28,7 +28,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ geojson pysocks diff --git a/pkgs/development/python-modules/pyqtgraph/default.nix b/pkgs/development/python-modules/pyqtgraph/default.nix index 629f96d76df4ea..45cbada84b375c 100644 --- a/pkgs/development/python-modules/pyqtgraph/default.nix +++ b/pkgs/development/python-modules/pyqtgraph/default.nix @@ -75,6 +75,9 @@ buildPythonPackage rec { changelog = "https://github.com/pyqtgraph/pyqtgraph/blob/master/CHANGELOG"; license = lib.licenses.mit; platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ koral doronbehar ]; + maintainers = with lib.maintainers; [ + koral + doronbehar + ]; }; } diff --git a/pkgs/development/python-modules/pyquil/default.nix b/pkgs/development/python-modules/pyquil/default.nix index 84e97f2bf050d6..efc9368907dfc7 100644 --- a/pkgs/development/python-modules/pyquil/default.nix +++ b/pkgs/development/python-modules/pyquil/default.nix @@ -47,7 +47,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ deprecated matplotlib-inline diff --git a/pkgs/development/python-modules/pyre-extensions/default.nix b/pkgs/development/python-modules/pyre-extensions/default.nix index aa5f70da4a91fa..6a97b84bc2c041 100644 --- a/pkgs/development/python-modules/pyre-extensions/default.nix +++ b/pkgs/development/python-modules/pyre-extensions/default.nix @@ -19,7 +19,7 @@ buildPythonPackage { src = fetchPypi { inherit version; - pname = "pyre_extensions"; # changed pname on 0.0.31? + pname = "pyre_extensions"; # changed pname on 0.0.31? hash = "sha256-lFgG3TMCeFbPbkHJxK2s/6srVpk/h2L/TqeCb5XbBIE="; }; diff --git a/pkgs/development/python-modules/pysigma-backend-opensearch/default.nix b/pkgs/development/python-modules/pysigma-backend-opensearch/default.nix index 5c689f81c0d6af..ea7ea74498976c 100644 --- a/pkgs/development/python-modules/pysigma-backend-opensearch/default.nix +++ b/pkgs/development/python-modules/pysigma-backend-opensearch/default.nix @@ -33,7 +33,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ pysigma pysigma-backend-elasticsearch diff --git a/pkgs/development/python-modules/pysigma/default.nix b/pkgs/development/python-modules/pysigma/default.nix index c711ef880b8032..77c6ad1daedbef 100644 --- a/pkgs/development/python-modules/pysigma/default.nix +++ b/pkgs/development/python-modules/pysigma/default.nix @@ -33,7 +33,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ jinja2 packaging diff --git a/pkgs/development/python-modules/pysolcast/default.nix b/pkgs/development/python-modules/pysolcast/default.nix index db2df1ad97cbd2..7b13e0cb81e3af 100644 --- a/pkgs/development/python-modules/pysolcast/default.nix +++ b/pkgs/development/python-modules/pysolcast/default.nix @@ -34,7 +34,6 @@ buildPythonPackage rec { poetry-dynamic-versioning ]; - dependencies = [ anyconfig isodate diff --git a/pkgs/development/python-modules/pytest-lazy-fixtures/default.nix b/pkgs/development/python-modules/pytest-lazy-fixtures/default.nix index 66a267be113e35..96f167d8f165ef 100644 --- a/pkgs/development/python-modules/pytest-lazy-fixtures/default.nix +++ b/pkgs/development/python-modules/pytest-lazy-fixtures/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, poetry-core -, pytestCheckHook +{ + lib, + buildPythonPackage, + fetchFromGitHub, + poetry-core, + pytestCheckHook, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/pytest-mpi/default.nix b/pkgs/development/python-modules/pytest-mpi/default.nix index 7c375aa1087d24..7a474fd084b060 100644 --- a/pkgs/development/python-modules/pytest-mpi/default.nix +++ b/pkgs/development/python-modules/pytest-mpi/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, setuptools -, sybil -, pytest -, pytestCheckHook -, mpi -, mpi4py +{ + lib, + buildPythonPackage, + fetchFromGitHub, + setuptools, + sybil, + pytest, + pytestCheckHook, + mpi, + mpi4py, }: buildPythonPackage rec { @@ -42,7 +43,8 @@ buildPythonPackage rec { doCheck = false; pytestFlagsArray = [ # https://github.com/aragilar/pytest-mpi/issues/4#issuecomment-634614337 - "-p" "pytester" + "-p" + "pytester" ]; pythonImportsCheck = [ "pytest_mpi" ]; diff --git a/pkgs/development/python-modules/python-mapnik/default.nix b/pkgs/development/python-modules/python-mapnik/default.nix index 72f26cde2d953d..4f467a84484e38 100644 --- a/pkgs/development/python-modules/python-mapnik/default.nix +++ b/pkgs/development/python-modules/python-mapnik/default.nix @@ -53,7 +53,8 @@ buildPythonPackage rec { ./python-mapnik_std_optional.patch ]; - stdenv = if python.stdenv.hostPlatform.isDarwin then darwin.apple_sdk_11_0.stdenv else python.stdenv; + stdenv = + if python.stdenv.hostPlatform.isDarwin then darwin.apple_sdk_11_0.stdenv else python.stdenv; build-system = [ setuptools ]; @@ -109,21 +110,23 @@ buildPythonPackage rec { ''; # https://github.com/mapnik/python-mapnik/issues/255 - disabledTests = [ - "test_geometry_type" - "test_passing_pycairo_context_pdf" - "test_pdf_printing" - "test_render_with_scale_factor" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "test_passing_pycairo_context_png" - "test_passing_pycairo_context_svg" - "test_pycairo_pdf_surface1" - "test_pycairo_pdf_surface2" - "test_pycairo_pdf_surface3" - "test_pycairo_svg_surface1" - "test_pycairo_svg_surface2" - "test_pycairo_svg_surface3" - ]; + disabledTests = + [ + "test_geometry_type" + "test_passing_pycairo_context_pdf" + "test_pdf_printing" + "test_render_with_scale_factor" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "test_passing_pycairo_context_png" + "test_passing_pycairo_context_svg" + "test_pycairo_pdf_surface1" + "test_pycairo_pdf_surface2" + "test_pycairo_pdf_surface3" + "test_pycairo_svg_surface1" + "test_pycairo_svg_surface2" + "test_pycairo_svg_surface3" + ]; pythonImportsCheck = [ "mapnik" ]; diff --git a/pkgs/development/python-modules/python-roborock/default.nix b/pkgs/development/python-modules/python-roborock/default.nix index 9cfebbbbaa90c2..f1776e25bd764f 100644 --- a/pkgs/development/python-modules/python-roborock/default.nix +++ b/pkgs/development/python-modules/python-roborock/default.nix @@ -40,7 +40,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - propagatedBuildInputs = [ aiohttp async-timeout diff --git a/pkgs/development/python-modules/pytorch-metric-learning/default.nix b/pkgs/development/python-modules/pytorch-metric-learning/default.nix index 6c110d8fb35e4f..dd6ce14adf108c 100644 --- a/pkgs/development/python-modules/pytorch-metric-learning/default.nix +++ b/pkgs/development/python-modules/pytorch-metric-learning/default.nix @@ -22,7 +22,7 @@ # tests cudaSupport ? config.cudaSupport, pytestCheckHook, - torchvision + torchvision, }: buildPythonPackage rec { @@ -75,31 +75,34 @@ buildPythonPackage rec { torchvision ] ++ lib.flatten (lib.attrValues optional-dependencies); - disabledTests = [ - # network access - "test_tuplestoweights_sampler" - "test_metric_loss_only" - "test_add_to_indexer" - "test_get_nearest_neighbors" - "test_list_of_text" - "test_untrained_indexer" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # AttributeError: module 'torch.distributed' has no attribute 'init_process_group' - "test_single_proc" - ] ++ lib.optionals cudaSupport [ - # crashes with SIGBART - "test_accuracy_calculator_and_faiss_with_torch_and_numpy" - "test_accuracy_calculator_large_k" - "test_custom_knn" - "test_global_embedding_space_tester" - "test_global_two_stream_embedding_space_tester" - "test_index_type" - "test_k_warning" - "test_many_tied_distances" - "test_query_within_reference" - "test_tied_distances" - "test_with_same_parent_label_tester" - ]; + disabledTests = + [ + # network access + "test_tuplestoweights_sampler" + "test_metric_loss_only" + "test_add_to_indexer" + "test_get_nearest_neighbors" + "test_list_of_text" + "test_untrained_indexer" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # AttributeError: module 'torch.distributed' has no attribute 'init_process_group' + "test_single_proc" + ] + ++ lib.optionals cudaSupport [ + # crashes with SIGBART + "test_accuracy_calculator_and_faiss_with_torch_and_numpy" + "test_accuracy_calculator_large_k" + "test_custom_knn" + "test_global_embedding_space_tester" + "test_global_two_stream_embedding_space_tester" + "test_index_type" + "test_k_warning" + "test_many_tied_distances" + "test_query_within_reference" + "test_tied_distances" + "test_with_same_parent_label_tester" + ]; meta = { description = "Metric learning library for PyTorch"; diff --git a/pkgs/development/python-modules/pyunbound/default.nix b/pkgs/development/python-modules/pyunbound/default.nix index 13357faec5931e..a8378b5ad22bfb 100644 --- a/pkgs/development/python-modules/pyunbound/default.nix +++ b/pkgs/development/python-modules/pyunbound/default.nix @@ -1,4 +1,14 @@ -{ lib, buildPythonPackage, unbound, openssl, expat, libevent, swig, python, stdenv }: +{ + lib, + buildPythonPackage, + unbound, + openssl, + expat, + libevent, + swig, + python, + stdenv, +}: buildPythonPackage rec { pname = "pyunbound"; @@ -9,7 +19,12 @@ buildPythonPackage rec { nativeBuildInputs = [ swig ]; - buildInputs = [ openssl expat libevent python ]; + buildInputs = [ + openssl + expat + libevent + python + ]; postPatch = '' substituteInPlace Makefile.in \ @@ -47,18 +62,19 @@ buildPythonPackage rec { ]; # All we want is the Unbound Python module - postInstall = '' - # Generate the built in root anchor and root key and store these in a logical place - # to be used by tools depending only on the Python module - $out/bin/unbound-anchor -l | head -1 > $out/etc/${pname}/root.anchor - $out/bin/unbound-anchor -l | tail --lines=+2 - > $out/etc/${pname}/root.key - # We don't need anything else - rm -r $out/bin $out/share $out/include $out/etc/unbound - '' - # patchelf is only available on Linux and no patching is needed on darwin - + lib.optionalString stdenv.hostPlatform.isLinux '' - patchelf --replace-needed libunbound.so.8 $out/${python.sitePackages}/libunbound.so.8 $out/${python.sitePackages}/_unbound.so - ''; + postInstall = + '' + # Generate the built in root anchor and root key and store these in a logical place + # to be used by tools depending only on the Python module + $out/bin/unbound-anchor -l | head -1 > $out/etc/${pname}/root.anchor + $out/bin/unbound-anchor -l | tail --lines=+2 - > $out/etc/${pname}/root.key + # We don't need anything else + rm -r $out/bin $out/share $out/include $out/etc/unbound + '' + # patchelf is only available on Linux and no patching is needed on darwin + + lib.optionalString stdenv.hostPlatform.isLinux '' + patchelf --replace-needed libunbound.so.8 $out/${python.sitePackages}/libunbound.so.8 $out/${python.sitePackages}/_unbound.so + ''; meta = with lib; { description = "Python library for Unbound, the validating, recursive, and caching DNS resolver"; diff --git a/pkgs/development/python-modules/qcs-api-client/default.nix b/pkgs/development/python-modules/qcs-api-client/default.nix index 9d903f4fe064b5..e4e658dd280060 100644 --- a/pkgs/development/python-modules/qcs-api-client/default.nix +++ b/pkgs/development/python-modules/qcs-api-client/default.nix @@ -55,7 +55,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ attrs httpx diff --git a/pkgs/development/python-modules/rdflib/default.nix b/pkgs/development/python-modules/rdflib/default.nix index 6b52f646a78cae..88c63343203ab0 100644 --- a/pkgs/development/python-modules/rdflib/default.nix +++ b/pkgs/development/python-modules/rdflib/default.nix @@ -52,12 +52,15 @@ buildPythonPackage rec { __darwinAllowLocalNetworking = true; - nativeCheckInputs = [ - pip - pytest-cov-stub - pytestCheckHook - setuptools - ] ++ optional-dependencies.networkx ++ optional-dependencies.html; + nativeCheckInputs = + [ + pip + pytest-cov-stub + pytestCheckHook + setuptools + ] + ++ optional-dependencies.networkx + ++ optional-dependencies.html; pytestFlagsArray = [ # requires network access diff --git a/pkgs/development/python-modules/reikna/default.nix b/pkgs/development/python-modules/reikna/default.nix index f1877c11e12e4a..6dee74d2b7128f 100644 --- a/pkgs/development/python-modules/reikna/default.nix +++ b/pkgs/development/python-modules/reikna/default.nix @@ -30,11 +30,14 @@ buildPythonPackage rec { pytest ]; - propagatedBuildInputs = [ - mako - numpy - funcsigs - ] ++ lib.optional withCuda pycuda ++ lib.optional withOpenCL pyopencl; + propagatedBuildInputs = + [ + mako + numpy + funcsigs + ] + ++ lib.optional withCuda pycuda + ++ lib.optional withOpenCL pyopencl; checkPhase = '' py.test diff --git a/pkgs/development/python-modules/reptor/default.nix b/pkgs/development/python-modules/reptor/default.nix index c8326128fac86c..033445a3790cf4 100644 --- a/pkgs/development/python-modules/reptor/default.nix +++ b/pkgs/development/python-modules/reptor/default.nix @@ -46,7 +46,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ asgiref certifi diff --git a/pkgs/development/python-modules/requests-cache/default.nix b/pkgs/development/python-modules/requests-cache/default.nix index aa8b918ca8c1ec..c1e5f1fd6c1b92 100644 --- a/pkgs/development/python-modules/requests-cache/default.nix +++ b/pkgs/development/python-modules/requests-cache/default.nix @@ -68,18 +68,21 @@ buildPythonPackage rec { yaml = [ pyyaml ]; }; - nativeCheckInputs = [ - psutil - pytestCheckHook - pytest-rerunfailures - pytest-xdist - requests-mock - responses - rich - tenacity - time-machine - timeout-decorator - ] ++ optional-dependencies.json ++ optional-dependencies.security; + nativeCheckInputs = + [ + psutil + pytestCheckHook + pytest-rerunfailures + pytest-xdist + requests-mock + responses + rich + tenacity + time-machine + timeout-decorator + ] + ++ optional-dependencies.json + ++ optional-dependencies.security; preCheck = '' export HOME=$(mktemp -d); diff --git a/pkgs/development/python-modules/rfc8785/default.nix b/pkgs/development/python-modules/rfc8785/default.nix index e4eb48964d0843..7d3195ee38010a 100644 --- a/pkgs/development/python-modules/rfc8785/default.nix +++ b/pkgs/development/python-modules/rfc8785/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, flit-core -, pytestCheckHook -, pythonOlder +{ + lib, + buildPythonPackage, + fetchFromGitHub, + flit-core, + pytestCheckHook, + pythonOlder, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/riscv-config/default.nix b/pkgs/development/python-modules/riscv-config/default.nix index c03e97c6232e43..a159476538bbf7 100644 --- a/pkgs/development/python-modules/riscv-config/default.nix +++ b/pkgs/development/python-modules/riscv-config/default.nix @@ -27,7 +27,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ cerberus pyyaml diff --git a/pkgs/development/python-modules/rnginline/default.nix b/pkgs/development/python-modules/rnginline/default.nix index 966dec934aa2fc..9c64e23fd0a911 100644 --- a/pkgs/development/python-modules/rnginline/default.nix +++ b/pkgs/development/python-modules/rnginline/default.nix @@ -30,7 +30,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ docopt-ng lxml diff --git a/pkgs/development/python-modules/rowan/default.nix b/pkgs/development/python-modules/rowan/default.nix index d8fe055a993870..84b872d871a7e9 100644 --- a/pkgs/development/python-modules/rowan/default.nix +++ b/pkgs/development/python-modules/rowan/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, setuptools -, pytestCheckHook -, scipy -, numpy +{ + lib, + buildPythonPackage, + fetchFromGitHub, + setuptools, + pytestCheckHook, + scipy, + numpy, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/samarium/default.nix b/pkgs/development/python-modules/samarium/default.nix index 9e32e1c5b5dfe4..fc91e1480bda3b 100644 --- a/pkgs/development/python-modules/samarium/default.nix +++ b/pkgs/development/python-modules/samarium/default.nix @@ -20,7 +20,10 @@ buildPythonPackage rec { }; build-system = [ poetry-core ]; - dependencies = [ crossandra dahlia ]; + dependencies = [ + crossandra + dahlia + ]; meta = with lib; { changelog = "https://github.com/samarium-lang/samarium/blob/${src.rev}/CHANGELOG.md"; diff --git a/pkgs/development/python-modules/samsungtvws/default.nix b/pkgs/development/python-modules/samsungtvws/default.nix index bab6de96b59b4b..ee6bdbf1ef50a3 100644 --- a/pkgs/development/python-modules/samsungtvws/default.nix +++ b/pkgs/development/python-modules/samsungtvws/default.nix @@ -51,11 +51,14 @@ buildPythonPackage rec { ]; }; - nativeCheckInputs = [ - aioresponses - pytest-asyncio - pytestCheckHook - ] ++ optional-dependencies.async ++ optional-dependencies.encrypted; + nativeCheckInputs = + [ + aioresponses + pytest-asyncio + pytestCheckHook + ] + ++ optional-dependencies.async + ++ optional-dependencies.encrypted; pythonImportsCheck = [ "samsungtvws" ]; diff --git a/pkgs/development/python-modules/schema/default.nix b/pkgs/development/python-modules/schema/default.nix index 9ffeb56f887d87..37a608515e7c71 100644 --- a/pkgs/development/python-modules/schema/default.nix +++ b/pkgs/development/python-modules/schema/default.nix @@ -19,7 +19,6 @@ buildPythonPackage rec { hash = "sha256-faVTq9KVihncJUfDiM3lM5izkZYXWpvlnqHK9asKGAc="; }; - pythonRemoveDeps = [ "contextlib2" ]; nativeCheckInputs = [ diff --git a/pkgs/development/python-modules/scikit-learn/default.nix b/pkgs/development/python-modules/scikit-learn/default.nix index 2502006fbae442..146f67f53448f8 100644 --- a/pkgs/development/python-modules/scikit-learn/default.nix +++ b/pkgs/development/python-modules/scikit-learn/default.nix @@ -78,14 +78,16 @@ buildPythonPackage rec { # PermissionError: [Errno 1] Operation not permitted: '/nix/nix-installer' doCheck = !stdenv.hostPlatform.isDarwin; - disabledTests = [ - # Skip test_feature_importance_regression - does web fetch - "test_feature_importance_regression" - ] ++ lib.optionals stdenv.hostPlatform.isAarch64 [ - # doesn't seem to produce correct results? - # possibly relevant: https://github.com/scikit-learn/scikit-learn/issues/25838#issuecomment-2308650816 - "test_sparse_input" - ]; + disabledTests = + [ + # Skip test_feature_importance_regression - does web fetch + "test_feature_importance_regression" + ] + ++ lib.optionals stdenv.hostPlatform.isAarch64 [ + # doesn't seem to produce correct results? + # possibly relevant: https://github.com/scikit-learn/scikit-learn/issues/25838#issuecomment-2308650816 + "test_sparse_input" + ]; pytestFlagsArray = [ # verbose build outputs needed to debug hard-to-reproduce hydra failures diff --git a/pkgs/development/python-modules/sdkmanager/default.nix b/pkgs/development/python-modules/sdkmanager/default.nix index 225600d174661c..ebe1b685ff23af 100644 --- a/pkgs/development/python-modules/sdkmanager/default.nix +++ b/pkgs/development/python-modules/sdkmanager/default.nix @@ -29,10 +29,13 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ - argcomplete - requests - ] ++ requests.optional-dependencies.socks ++ lib.optionals (pythonAtLeast "3.12") [ looseversion ]; + dependencies = + [ + argcomplete + requests + ] + ++ requests.optional-dependencies.socks + ++ lib.optionals (pythonAtLeast "3.12") [ looseversion ]; postInstall = '' wrapProgram $out/bin/sdkmanager \ diff --git a/pkgs/development/python-modules/semgrep/semgrep-core.nix b/pkgs/development/python-modules/semgrep/semgrep-core.nix index 8986cba7d880fd..fd5f1b37a44533 100644 --- a/pkgs/development/python-modules/semgrep/semgrep-core.nix +++ b/pkgs/development/python-modules/semgrep/semgrep-core.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchPypi, unzip }: +{ + lib, + stdenvNoCC, + fetchPypi, + unzip, +}: let common = import ./common.nix { inherit lib; }; diff --git a/pkgs/development/python-modules/sentry-sdk/default.nix b/pkgs/development/python-modules/sentry-sdk/default.nix index e3d542906a717f..ed57437d22be87 100644 --- a/pkgs/development/python-modules/sentry-sdk/default.nix +++ b/pkgs/development/python-modules/sentry-sdk/default.nix @@ -1,64 +1,65 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub +{ + lib, + buildPythonPackage, + fetchFromGitHub, -# build-system -, setuptools + # build-system + setuptools, -# dependencies -, certifi -, urllib3 + # dependencies + certifi, + urllib3, -# optional-dependencies -, aiohttp -, anthropic -, asyncpg -, apache-beam -, bottle -, celery -, celery-redbeat -, chalice -, clickhouse-driver -, django -, falcon -, fastapi -, flask -, blinker -, markupsafe -, grpcio -, protobuf -, httpx -, huey -, huggingface-hub -, langchain -, loguru -, openai -, tiktoken -, pure-eval -, executing -, asttokens -, pymongo -, pyspark -, quart -, rq -, sanic -, sqlalchemy -, starlette -, tornado + # optional-dependencies + aiohttp, + anthropic, + asyncpg, + apache-beam, + bottle, + celery, + celery-redbeat, + chalice, + clickhouse-driver, + django, + falcon, + fastapi, + flask, + blinker, + markupsafe, + grpcio, + protobuf, + httpx, + huey, + huggingface-hub, + langchain, + loguru, + openai, + tiktoken, + pure-eval, + executing, + asttokens, + pymongo, + pyspark, + quart, + rq, + sanic, + sqlalchemy, + starlette, + tornado, -# checks -, ipdb -, jsonschema -, pip -, pyrsistent -, pysocks -, pytest-asyncio -, pytestCheckHook -, pytest-forked -, pytest-localserver -, pytest-xdist -, pytest-watch -, responses + # checks + ipdb, + jsonschema, + pip, + pyrsistent, + pysocks, + pytest-asyncio, + pytestCheckHook, + pytest-forked, + pytest-localserver, + pytest-xdist, + pytest-watch, + responses, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/signalslot/default.nix b/pkgs/development/python-modules/signalslot/default.nix index 7bf0f0ef5b7ecb..d6f122f2a56a6f 100644 --- a/pkgs/development/python-modules/signalslot/default.nix +++ b/pkgs/development/python-modules/signalslot/default.nix @@ -26,7 +26,6 @@ buildPythonPackage rec { --replace "--cov-report html" "" ''; - propagatedBuildInputs = [ contexter six diff --git a/pkgs/development/python-modules/sigparse/default.nix b/pkgs/development/python-modules/sigparse/default.nix index d06a2a91e49dc4..3335b0e7755d57 100644 --- a/pkgs/development/python-modules/sigparse/default.nix +++ b/pkgs/development/python-modules/sigparse/default.nix @@ -4,7 +4,7 @@ fetchFromGitHub, poetry-core, pytestCheckHook, - fetchpatch + fetchpatch, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/skl2onnx/default.nix b/pkgs/development/python-modules/skl2onnx/default.nix index 8d258c18883ccb..d02b350dc7cdff 100644 --- a/pkgs/development/python-modules/skl2onnx/default.nix +++ b/pkgs/development/python-modules/skl2onnx/default.nix @@ -32,7 +32,6 @@ buildPythonPackage rec { onnxconverter-common ]; - pythonRelaxDeps = [ "scikit-learn" ]; nativeCheckInputs = [ diff --git a/pkgs/development/python-modules/snscrape/default.nix b/pkgs/development/python-modules/snscrape/default.nix index b2b4622c383823..f9e12d45e0c28c 100644 --- a/pkgs/development/python-modules/snscrape/default.nix +++ b/pkgs/development/python-modules/snscrape/default.nix @@ -37,12 +37,15 @@ buildPythonPackage rec { build-system = [ setuptools-scm ]; - dependencies = [ - beautifulsoup4 - filelock - lxml - requests - ] ++ requests.optional-dependencies.socks ++ lib.optionals (pythonOlder "3.9") [ pytz ]; + dependencies = + [ + beautifulsoup4 + filelock + lxml + requests + ] + ++ requests.optional-dependencies.socks + ++ lib.optionals (pythonOlder "3.9") [ pytz ]; # There are no tests; make sure the executable works. checkPhase = '' diff --git a/pkgs/development/python-modules/solidpython2/default.nix b/pkgs/development/python-modules/solidpython2/default.nix index 54dd8e2c2004a4..124945750e7da9 100644 --- a/pkgs/development/python-modules/solidpython2/default.nix +++ b/pkgs/development/python-modules/solidpython2/default.nix @@ -1,11 +1,12 @@ -{ buildPythonPackage -, fetchFromGitHub -, lib -, ply -, setuptools -, poetry-core -, withOpenSCAD ? false -, openscad +{ + buildPythonPackage, + fetchFromGitHub, + lib, + ply, + setuptools, + poetry-core, + withOpenSCAD ? false, + openscad, }: buildPythonPackage rec { pname = "solidpython2"; @@ -24,7 +25,7 @@ buildPythonPackage rec { # - drop the openscad image geneneration tests, these don't work on the nix sandbox due to the need for xserver patches = [ ./difftool_tests.patch ]; - propagatedBuildInputs = lib.optionals withOpenSCAD [openscad]; + propagatedBuildInputs = lib.optionals withOpenSCAD [ openscad ]; build-system = [ poetry-core diff --git a/pkgs/development/python-modules/spacy-transformers/default.nix b/pkgs/development/python-modules/spacy-transformers/default.nix index ddc71b75eac5ba..7a35b89573d96f 100644 --- a/pkgs/development/python-modules/spacy-transformers/default.nix +++ b/pkgs/development/python-modules/spacy-transformers/default.nix @@ -34,7 +34,6 @@ buildPythonPackage rec { cython ]; - dependencies = [ spacy numpy diff --git a/pkgs/development/python-modules/spacy/annotation-test/default.nix b/pkgs/development/python-modules/spacy/annotation-test/default.nix index 5f5f8f3ca0a718..419271ab7e9c8a 100644 --- a/pkgs/development/python-modules/spacy/annotation-test/default.nix +++ b/pkgs/development/python-modules/spacy/annotation-test/default.nix @@ -9,7 +9,7 @@ stdenv.mkDerivation { name = "spacy-annotation-test"; src = lib.fileset.toSource { - root = ./.; + root = ./.; fileset = lib.fileset.unions [ ./annotate.py ]; diff --git a/pkgs/development/python-modules/sphinx-multiversion/default.nix b/pkgs/development/python-modules/sphinx-multiversion/default.nix index 6febaecc3f5d40..cbf77abe98769a 100644 --- a/pkgs/development/python-modules/sphinx-multiversion/default.nix +++ b/pkgs/development/python-modules/sphinx-multiversion/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildPythonPackage -, pythonOlder -, fetchPypi -, sphinx -, setuptools -, unittestCheckHook +{ + lib, + buildPythonPackage, + pythonOlder, + fetchPypi, + sphinx, + setuptools, + unittestCheckHook, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/sphinx-rtd-theme/default.nix b/pkgs/development/python-modules/sphinx-rtd-theme/default.nix index b53a9849ac0669..80dd79d124e258 100644 --- a/pkgs/development/python-modules/sphinx-rtd-theme/default.nix +++ b/pkgs/development/python-modules/sphinx-rtd-theme/default.nix @@ -31,7 +31,6 @@ buildPythonPackage rec { sphinxcontrib-jquery ]; - nativeCheckInputs = [ pytestCheckHook readthedocs-sphinx-ext diff --git a/pkgs/development/python-modules/sphinxcontrib-katex/default.nix b/pkgs/development/python-modules/sphinxcontrib-katex/default.nix index 6716a3ba7902a3..44f1e74e62b08e 100644 --- a/pkgs/development/python-modules/sphinxcontrib-katex/default.nix +++ b/pkgs/development/python-modules/sphinxcontrib-katex/default.nix @@ -5,7 +5,7 @@ pythonOlder, setuptools, sphinx, - pytestCheckHook + pytestCheckHook, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/sqlmodel/default.nix b/pkgs/development/python-modules/sqlmodel/default.nix index 89f19b1e65057f..e7b5212281479d 100644 --- a/pkgs/development/python-modules/sqlmodel/default.nix +++ b/pkgs/development/python-modules/sqlmodel/default.nix @@ -30,7 +30,8 @@ buildPythonPackage rec { }; patches = [ - (fetchpatch { # https://github.com/tiangolo/sqlmodel/pull/969 + (fetchpatch { + # https://github.com/tiangolo/sqlmodel/pull/969 name = "passthru-environ-variables.patch"; url = "https://github.com/tiangolo/sqlmodel/pull/969/commits/42d33049e9e4182b78914ad41d1e3d30125126ba.patch"; hash = "sha256-dPuFCFUnmTpduxn45tE8XUP0Jlwjwmwe+zFaKSganOg="; diff --git a/pkgs/development/python-modules/stamina/default.nix b/pkgs/development/python-modules/stamina/default.nix index 9597bc54964399..281b8e03c3ab0e 100644 --- a/pkgs/development/python-modules/stamina/default.nix +++ b/pkgs/development/python-modules/stamina/default.nix @@ -1,16 +1,17 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub +{ + lib, + buildPythonPackage, + fetchFromGitHub, -, hatch-fancy-pypi-readme -, hatch-vcs -, hatchling + hatch-fancy-pypi-readme, + hatch-vcs, + hatchling, -, tenacity -, typing-extensions + tenacity, + typing-extensions, -, anyio -, pytestCheckHook + anyio, + pytestCheckHook, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/svg2tikz/default.nix b/pkgs/development/python-modules/svg2tikz/default.nix index e295f2bdc6eab8..d079222d53ad44 100644 --- a/pkgs/development/python-modules/svg2tikz/default.nix +++ b/pkgs/development/python-modules/svg2tikz/default.nix @@ -37,7 +37,6 @@ buildPythonPackage rec { "lxml" ]; - nativeCheckInputs = [ pytestCheckHook ]; pythonImportsCheck = [ "svg2tikz" ]; diff --git a/pkgs/development/python-modules/tabcmd/default.nix b/pkgs/development/python-modules/tabcmd/default.nix index 1c2906333437f9..b9ec593c9b53f6 100644 --- a/pkgs/development/python-modules/tabcmd/default.nix +++ b/pkgs/development/python-modules/tabcmd/default.nix @@ -46,7 +46,6 @@ buildPythonPackage rec { "urllib3" ]; - build-system = [ setuptools ]; dependencies = [ diff --git a/pkgs/development/python-modules/tago/default.nix b/pkgs/development/python-modules/tago/default.nix index eb42efff568969..d2899ec1a2149c 100644 --- a/pkgs/development/python-modules/tago/default.nix +++ b/pkgs/development/python-modules/tago/default.nix @@ -26,7 +26,6 @@ buildPythonPackage rec { pythonRelaxDeps = true; - propagatedBuildInputs = [ aiohttp promise diff --git a/pkgs/development/python-modules/taskw-ng/default.nix b/pkgs/development/python-modules/taskw-ng/default.nix index 35bda3dfb96212..dee865bd833ade 100644 --- a/pkgs/development/python-modules/taskw-ng/default.nix +++ b/pkgs/development/python-modules/taskw-ng/default.nix @@ -36,7 +36,6 @@ buildPythonPackage rec { poetry-dynamic-versioning ]; - propagatedBuildInputs = [ kitchen packaging diff --git a/pkgs/development/python-modules/tbm-utils/default.nix b/pkgs/development/python-modules/tbm-utils/default.nix index 9daa9648fe1ec8..a11a8dfef6b20c 100644 --- a/pkgs/development/python-modules/tbm-utils/default.nix +++ b/pkgs/development/python-modules/tbm-utils/default.nix @@ -51,7 +51,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - propagatedBuildInputs = [ attrs pendulum diff --git a/pkgs/development/python-modules/tensorboard/default.nix b/pkgs/development/python-modules/tensorboard/default.nix index 918df0bb1c91ba..d6801aa6d6294c 100644 --- a/pkgs/development/python-modules/tensorboard/default.nix +++ b/pkgs/development/python-modules/tensorboard/default.nix @@ -34,7 +34,6 @@ buildPythonPackage rec { hash = "sha256-EHykghdF9z4q76AsUP9wqbaU8595CxHm9oL30yZ0Xqs="; }; - pythonRelaxDeps = [ "google-auth-oauthlib" "protobuf" diff --git a/pkgs/development/python-modules/terminaltexteffects/default.nix b/pkgs/development/python-modules/terminaltexteffects/default.nix index 27b07d56158881..2879d7e9dd2708 100644 --- a/pkgs/development/python-modules/terminaltexteffects/default.nix +++ b/pkgs/development/python-modules/terminaltexteffects/default.nix @@ -13,7 +13,7 @@ buildPythonPackage rec { disabled = pythonOlder "3.8"; - # no tests on pypi, no tags on github + # no tests on pypi, no tags on github src = fetchPypi { inherit pname version; hash = "sha256-FDDLc7oAOgSpaxmuS6Wzej+vEOuSx3WT2ntpfoET3LI="; diff --git a/pkgs/development/python-modules/textual/default.nix b/pkgs/development/python-modules/textual/default.nix index 82652024251376..ad3ae1d1b8defc 100644 --- a/pkgs/development/python-modules/textual/default.nix +++ b/pkgs/development/python-modules/textual/default.nix @@ -34,12 +34,15 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ - platformdirs - markdown-it-py - rich - typing-extensions - ] ++ markdown-it-py.optional-dependencies.plugins ++ markdown-it-py.optional-dependencies.linkify; + dependencies = + [ + platformdirs + markdown-it-py + rich + typing-extensions + ] + ++ markdown-it-py.optional-dependencies.plugins + ++ markdown-it-py.optional-dependencies.linkify; optional-dependencies = { syntax = [ diff --git a/pkgs/development/python-modules/timy/default.nix b/pkgs/development/python-modules/timy/default.nix index 3fb4096bb51968..678623fabd0e12 100644 --- a/pkgs/development/python-modules/timy/default.nix +++ b/pkgs/development/python-modules/timy/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, pytestCheckHook +{ + lib, + buildPythonPackage, + fetchFromGitHub, + pytestCheckHook, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/tree-sitter-html/default.nix b/pkgs/development/python-modules/tree-sitter-html/default.nix index 4c5060294231c4..28c8707bb73634 100644 --- a/pkgs/development/python-modules/tree-sitter-html/default.nix +++ b/pkgs/development/python-modules/tree-sitter-html/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, setuptools -, tree-sitter +{ + lib, + buildPythonPackage, + fetchFromGitHub, + setuptools, + tree-sitter, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/tree-sitter-javascript/default.nix b/pkgs/development/python-modules/tree-sitter-javascript/default.nix index 39766ce588f79c..8987a233ae375a 100644 --- a/pkgs/development/python-modules/tree-sitter-javascript/default.nix +++ b/pkgs/development/python-modules/tree-sitter-javascript/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, setuptools -, tree-sitter +{ + lib, + buildPythonPackage, + fetchFromGitHub, + setuptools, + tree-sitter, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/tree-sitter-json/default.nix b/pkgs/development/python-modules/tree-sitter-json/default.nix index 0e6cd37f8b87aa..1716cd9e715eba 100644 --- a/pkgs/development/python-modules/tree-sitter-json/default.nix +++ b/pkgs/development/python-modules/tree-sitter-json/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, setuptools -, tree-sitter +{ + lib, + buildPythonPackage, + fetchFromGitHub, + setuptools, + tree-sitter, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/tree-sitter-python/default.nix b/pkgs/development/python-modules/tree-sitter-python/default.nix index ece3a6900804ed..372b595c87509f 100644 --- a/pkgs/development/python-modules/tree-sitter-python/default.nix +++ b/pkgs/development/python-modules/tree-sitter-python/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, setuptools -, tree-sitter +{ + lib, + buildPythonPackage, + fetchFromGitHub, + setuptools, + tree-sitter, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/tree-sitter-rust/default.nix b/pkgs/development/python-modules/tree-sitter-rust/default.nix index 526d1907a0a650..3e65b035b39fb8 100644 --- a/pkgs/development/python-modules/tree-sitter-rust/default.nix +++ b/pkgs/development/python-modules/tree-sitter-rust/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, setuptools -, tree-sitter +{ + lib, + buildPythonPackage, + fetchFromGitHub, + setuptools, + tree-sitter, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/tuf/default.nix b/pkgs/development/python-modules/tuf/default.nix index f2fb03758fbd8d..320e9e240be2f8 100644 --- a/pkgs/development/python-modules/tuf/default.nix +++ b/pkgs/development/python-modules/tuf/default.nix @@ -26,10 +26,13 @@ buildPythonPackage rec { build-system = [ hatchling ]; - dependencies = [ - requests - securesystemslib - ] ++ securesystemslib.optional-dependencies.pynacl ++ securesystemslib.optional-dependencies.crypto; + dependencies = + [ + requests + securesystemslib + ] + ++ securesystemslib.optional-dependencies.pynacl + ++ securesystemslib.optional-dependencies.crypto; nativeCheckInputs = [ ed25519 diff --git a/pkgs/development/python-modules/twill/default.nix b/pkgs/development/python-modules/twill/default.nix index 8b5144e74eccd5..f9013e4d8a1d21 100644 --- a/pkgs/development/python-modules/twill/default.nix +++ b/pkgs/development/python-modules/twill/default.nix @@ -27,7 +27,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ httpx lxml diff --git a/pkgs/development/python-modules/typer-shell/default.nix b/pkgs/development/python-modules/typer-shell/default.nix index eed96f61780ade..79c5468ebdf88a 100644 --- a/pkgs/development/python-modules/typer-shell/default.nix +++ b/pkgs/development/python-modules/typer-shell/default.nix @@ -33,7 +33,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ click click-shell diff --git a/pkgs/development/python-modules/typer/default.nix b/pkgs/development/python-modules/typer/default.nix index 3c92fb408ecf01..dae031fe710e34 100644 --- a/pkgs/development/python-modules/typer/default.nix +++ b/pkgs/development/python-modules/typer/default.nix @@ -33,8 +33,8 @@ buildPythonPackage rec { propagatedBuildInputs = [ click typing-extensions - # Build includes the standard optional by default - # https://github.com/tiangolo/typer/blob/0.12.3/pyproject.toml#L71-L72 + # Build includes the standard optional by default + # https://github.com/tiangolo/typer/blob/0.12.3/pyproject.toml#L71-L72 ] ++ optional-dependencies.standard; optional-dependencies = { @@ -44,26 +44,32 @@ buildPythonPackage rec { ]; }; - nativeCheckInputs = [ - coverage # execs coverage in tests - pytest-sugar - pytest-xdist - pytestCheckHook - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - procps - ]; + nativeCheckInputs = + [ + coverage # execs coverage in tests + pytest-sugar + pytest-xdist + pytestCheckHook + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + procps + ]; preCheck = '' export HOME=$(mktemp -d); ''; - disabledTests = [ - "test_scripts" - # Likely related to https://github.com/sarugaku/shellingham/issues/35 - # fails also on Linux - "test_show_completion" - "test_install_completion" - ] ++ lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) [ "test_install_completion" ]; + disabledTests = + [ + "test_scripts" + # Likely related to https://github.com/sarugaku/shellingham/issues/35 + # fails also on Linux + "test_show_completion" + "test_install_completion" + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) [ + "test_install_completion" + ]; pythonImportsCheck = [ "typer" ]; diff --git a/pkgs/development/python-modules/typical/default.nix b/pkgs/development/python-modules/typical/default.nix index d222c05650dd69..2d8928d2455ffa 100644 --- a/pkgs/development/python-modules/typical/default.nix +++ b/pkgs/development/python-modules/typical/default.nix @@ -34,7 +34,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - dependencies = [ fastjsonschema future-typing diff --git a/pkgs/development/python-modules/ufo2ft/default.nix b/pkgs/development/python-modules/ufo2ft/default.nix index 22ea350cf303d3..06a0307ba731af 100644 --- a/pkgs/development/python-modules/ufo2ft/default.nix +++ b/pkgs/development/python-modules/ufo2ft/default.nix @@ -44,17 +44,20 @@ buildPythonPackage rec { pythonRelaxDeps = [ "cffsubr" ]; - dependencies = [ - cu2qu - fontmath - fonttools - defcon - compreffor - booleanoperations - cffsubr - ufolib2 - skia-pathops - ] ++ fonttools.optional-dependencies.lxml ++ fonttools.optional-dependencies.ufo; + dependencies = + [ + cu2qu + fontmath + fonttools + defcon + compreffor + booleanoperations + cffsubr + ufolib2 + skia-pathops + ] + ++ fonttools.optional-dependencies.lxml + ++ fonttools.optional-dependencies.ufo; nativeCheckInputs = [ pytestCheckHook diff --git a/pkgs/development/python-modules/uncertainties/default.nix b/pkgs/development/python-modules/uncertainties/default.nix index 9d8cb99be6852d..37998350b26966 100644 --- a/pkgs/development/python-modules/uncertainties/default.nix +++ b/pkgs/development/python-modules/uncertainties/default.nix @@ -35,8 +35,7 @@ buildPythonPackage rec { nativeCheckInputs = [ pytestCheckHook - ] - ++ optional-dependencies.arrays; + ] ++ optional-dependencies.arrays; pythonImportsCheck = [ "uncertainties" ]; diff --git a/pkgs/development/python-modules/universal-silabs-flasher/default.nix b/pkgs/development/python-modules/universal-silabs-flasher/default.nix index 025eec125099ca..97aeed521d3e07 100644 --- a/pkgs/development/python-modules/universal-silabs-flasher/default.nix +++ b/pkgs/development/python-modules/universal-silabs-flasher/default.nix @@ -43,7 +43,6 @@ buildPythonPackage rec { --replace-fail 'dynamic = ["version"]' 'version = "${version}"' ''; - build-system = [ setuptools ]; pythonRelaxDeps = [ diff --git a/pkgs/development/python-modules/unstructured-inference/default.nix b/pkgs/development/python-modules/unstructured-inference/default.nix index cf51d6bdf9732b..49c6eefd605fba 100644 --- a/pkgs/development/python-modules/unstructured-inference/default.nix +++ b/pkgs/development/python-modules/unstructured-inference/default.nix @@ -45,7 +45,8 @@ buildPythonPackage rec { paddleocr # yolox ] - ++ layoutparser.optional-dependencies.layoutmodels ++ layoutparser.optional-dependencies.tesseract; + ++ layoutparser.optional-dependencies.layoutmodels + ++ layoutparser.optional-dependencies.tesseract; nativeCheckInputs = [ pytestCheckHook diff --git a/pkgs/development/python-modules/uvcclient/default.nix b/pkgs/development/python-modules/uvcclient/default.nix index 4f37152ef71f50..8bcf22c0806c32 100644 --- a/pkgs/development/python-modules/uvcclient/default.nix +++ b/pkgs/development/python-modules/uvcclient/default.nix @@ -6,7 +6,7 @@ mock, pytest-cov-stub, pytest-xdist, - pytestCheckHook + pytestCheckHook, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/visions/default.nix b/pkgs/development/python-modules/visions/default.nix index f79a34ce58c9bf..58b325b3877f15 100644 --- a/pkgs/development/python-modules/visions/default.nix +++ b/pkgs/development/python-modules/visions/default.nix @@ -1,20 +1,21 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, pythonOlder -, pytestCheckHook -, setuptools -, attrs -, imagehash -, matplotlib -, multimethod -, networkx -, numpy -, pandas -, pillow -, pydot -, pygraphviz -, shapely +{ + lib, + buildPythonPackage, + fetchFromGitHub, + pythonOlder, + pytestCheckHook, + setuptools, + attrs, + imagehash, + matplotlib, + multimethod, + networkx, + numpy, + pandas, + pillow, + pydot, + pygraphviz, + shapely, }: buildPythonPackage rec { @@ -27,7 +28,7 @@ buildPythonPackage rec { src = fetchFromGitHub { owner = "dylan-profiler"; repo = "visions"; - rev = "5fe9dd0c2a5ada0162a005c880bac5296686a5aa"; # no 0.7.6 tag in github + rev = "5fe9dd0c2a5ada0162a005c880bac5296686a5aa"; # no 0.7.6 tag in github hash = "sha256-SZzDXm+faAvrfSOT0fwwAf9IH7upNybwKxbjw1CrHj8="; }; @@ -44,8 +45,15 @@ buildPythonPackage rec { optional-dependencies = { type-geometry = [ shapely ]; - type-image-path = [ imagehash pillow ]; - plotting = [ matplotlib pydot pygraphviz ]; + type-image-path = [ + imagehash + pillow + ]; + plotting = [ + matplotlib + pydot + pygraphviz + ]; }; nativeCheckInputs = [ diff --git a/pkgs/development/python-modules/vnoise/default.nix b/pkgs/development/python-modules/vnoise/default.nix index 02f917bc17aca3..169f5b3fd61b2a 100644 --- a/pkgs/development/python-modules/vnoise/default.nix +++ b/pkgs/development/python-modules/vnoise/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, numpy -, pytestCheckHook -, setuptools +{ + lib, + buildPythonPackage, + fetchFromGitHub, + numpy, + pytestCheckHook, + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/vt-py/default.nix b/pkgs/development/python-modules/vt-py/default.nix index f81ce1d07dfc52..6a340fbeeb1298 100644 --- a/pkgs/development/python-modules/vt-py/default.nix +++ b/pkgs/development/python-modules/vt-py/default.nix @@ -35,7 +35,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ aiofiles aiohttp diff --git a/pkgs/development/python-modules/w3lib/default.nix b/pkgs/development/python-modules/w3lib/default.nix index 620f30f2508f5a..96314e37ca7cbd 100644 --- a/pkgs/development/python-modules/w3lib/default.nix +++ b/pkgs/development/python-modules/w3lib/default.nix @@ -4,7 +4,7 @@ fetchPypi, pytestCheckHook, pythonOlder, - setuptools + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/development/python-modules/weconnect-mqtt/default.nix b/pkgs/development/python-modules/weconnect-mqtt/default.nix index 7253e9d5c3401b..b7bbebd84189a1 100644 --- a/pkgs/development/python-modules/weconnect-mqtt/default.nix +++ b/pkgs/development/python-modules/weconnect-mqtt/default.nix @@ -38,7 +38,6 @@ buildPythonPackage rec { build-system = [ setuptools ]; - dependencies = [ paho-mqtt_2 python-dateutil diff --git a/pkgs/development/python-modules/xiaomi-ble/default.nix b/pkgs/development/python-modules/xiaomi-ble/default.nix index 1be46ecf56566e..4209ceb2e28373 100644 --- a/pkgs/development/python-modules/xiaomi-ble/default.nix +++ b/pkgs/development/python-modules/xiaomi-ble/default.nix @@ -37,7 +37,6 @@ buildPythonPackage rec { build-system = [ poetry-core ]; - pythonRelaxDeps = [ "pycryptodomex" ]; dependencies = [ diff --git a/pkgs/development/python-modules/xsdata/default.nix b/pkgs/development/python-modules/xsdata/default.nix index e83779c85a803b..9524fc6b2200bb 100644 --- a/pkgs/development/python-modules/xsdata/default.nix +++ b/pkgs/development/python-modules/xsdata/default.nix @@ -59,9 +59,13 @@ buildPythonPackage rec { soap = [ requests ]; }; - nativeCheckInputs = [ - pytestCheckHook - ] ++ optional-dependencies.cli ++ optional-dependencies.lxml ++ optional-dependencies.soap; + nativeCheckInputs = + [ + pytestCheckHook + ] + ++ optional-dependencies.cli + ++ optional-dependencies.lxml + ++ optional-dependencies.soap; disabledTestPaths = [ "tests/integration/benchmarks" ]; diff --git a/pkgs/development/python2-modules/attrs/default.nix b/pkgs/development/python2-modules/attrs/default.nix index 30eb0ab17e2599..d4b2630bd4cd66 100644 --- a/pkgs/development/python2-modules/attrs/default.nix +++ b/pkgs/development/python2-modules/attrs/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildPythonPackage -, fetchPypi +{ + lib, + buildPythonPackage, + fetchPypi, }: buildPythonPackage rec { diff --git a/pkgs/development/python2-modules/backports-functools-lru-cache/default.nix b/pkgs/development/python2-modules/backports-functools-lru-cache/default.nix index 859bb6b8d91ab5..6b0f0a6047c404 100644 --- a/pkgs/development/python2-modules/backports-functools-lru-cache/default.nix +++ b/pkgs/development/python2-modules/backports-functools-lru-cache/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchPypi -, setuptools -, setuptools-scm +{ + lib, + buildPythonPackage, + fetchPypi, + setuptools, + setuptools-scm, }: buildPythonPackage rec { @@ -35,4 +36,3 @@ buildPythonPackage rec { license = lib.licenses.mit; }; } - diff --git a/pkgs/development/python2-modules/bootstrapped-pip/default.nix b/pkgs/development/python2-modules/bootstrapped-pip/default.nix index 846c76b677b3b3..112ec66578bb3b 100644 --- a/pkgs/development/python2-modules/bootstrapped-pip/default.nix +++ b/pkgs/development/python2-modules/bootstrapped-pip/default.nix @@ -1,7 +1,14 @@ -{ lib, stdenv, python, makeWrapper, unzip -, pipInstallHook -, setuptoolsBuildHook -, wheel, pip, setuptools +{ + lib, + stdenv, + python, + makeWrapper, + unzip, + pipInstallHook, + setuptoolsBuildHook, + wheel, + pip, + setuptools, }: stdenv.mkDerivation rec { @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { inherit (pip) version; name = "${python.libPrefix}-bootstrapped-${pname}-${version}"; - srcs = [ wheel.src pip.src setuptools.src ]; + srcs = [ + wheel.src + pip.src + setuptools.src + ]; sourceRoot = "."; dontUseSetuptoolsBuild = true; @@ -18,46 +29,54 @@ stdenv.mkDerivation rec { # Should be propagatedNativeBuildInputs propagatedBuildInputs = [ # Override to remove dependencies to prevent infinite recursion. - (pipInstallHook.override{pip=null;}) - (setuptoolsBuildHook.override{setuptools=null; wheel=null;}) + (pipInstallHook.override { pip = null; }) + (setuptoolsBuildHook.override { + setuptools = null; + wheel = null; + }) ]; postPatch = '' mkdir -p $out/bin ''; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; buildInputs = [ python ]; dontBuild = true; - installPhase = lib.optionalString (!stdenv.hostPlatform.isWindows) '' - export SETUPTOOLS_INSTALL_WINDOWS_SPECIFIC_FILES=0 - '' + '' - # Give folders a known name - mv pip* pip - mv setuptools* setuptools - mv wheel* wheel - # Set up PYTHONPATH: - # - pip and setuptools need to be in PYTHONPATH to install setuptools, wheel, and pip. - # - $out is where we are installing to and takes precedence, and is where wheel will end so we can install pip. - export PYTHONPATH="$out/${python.sitePackages}:$(pwd)/pip/src:$(pwd)/setuptools:$(pwd)/setuptools/pkg_resources:$PYTHONPATH" + installPhase = + lib.optionalString (!stdenv.hostPlatform.isWindows) '' + export SETUPTOOLS_INSTALL_WINDOWS_SPECIFIC_FILES=0 + '' + + '' + # Give folders a known name + mv pip* pip + mv setuptools* setuptools + mv wheel* wheel + # Set up PYTHONPATH: + # - pip and setuptools need to be in PYTHONPATH to install setuptools, wheel, and pip. + # - $out is where we are installing to and takes precedence, and is where wheel will end so we can install pip. + export PYTHONPATH="$out/${python.sitePackages}:$(pwd)/pip/src:$(pwd)/setuptools:$(pwd)/setuptools/pkg_resources:$PYTHONPATH" - echo "Building setuptools wheel..." - pushd setuptools - ${python.pythonOnBuildForHost.interpreter} -m pip install --no-build-isolation --no-index --prefix=$out --ignore-installed --no-dependencies --no-cache . - popd + echo "Building setuptools wheel..." + pushd setuptools + ${python.pythonOnBuildForHost.interpreter} -m pip install --no-build-isolation --no-index --prefix=$out --ignore-installed --no-dependencies --no-cache . + popd - echo "Building wheel wheel..." - pushd wheel - ${python.pythonOnBuildForHost.interpreter} -m pip install --no-build-isolation --no-index --prefix=$out --ignore-installed --no-dependencies --no-cache . - popd + echo "Building wheel wheel..." + pushd wheel + ${python.pythonOnBuildForHost.interpreter} -m pip install --no-build-isolation --no-index --prefix=$out --ignore-installed --no-dependencies --no-cache . + popd - echo "Building pip wheel..." - pushd pip - ${python.pythonOnBuildForHost.interpreter} -m pip install --no-build-isolation --no-index --prefix=$out --ignore-installed --no-dependencies --no-cache . - popd - ''; + echo "Building pip wheel..." + pushd pip + ${python.pythonOnBuildForHost.interpreter} -m pip install --no-build-isolation --no-index --prefix=$out --ignore-installed --no-dependencies --no-cache . + popd + ''; meta = { description = "Version of pip used for bootstrapping"; diff --git a/pkgs/development/python2-modules/cffi/default.nix b/pkgs/development/python2-modules/cffi/default.nix index aa6f49f95e3ce7..52ed21c84918f2 100644 --- a/pkgs/development/python2-modules/cffi/default.nix +++ b/pkgs/development/python2-modules/cffi/default.nix @@ -1,45 +1,52 @@ -{ lib, stdenv, cffi }: +{ + lib, + stdenv, + cffi, +}: -if cffi == null then null else cffi.overridePythonAttrs { - disabledTests = lib.optionals stdenv.hostPlatform.isDarwin [ - # cannot load library 'c' - "test_FILE" - "test_FILE_object" - "test_FILE_only_for_FILE_arg" - "test_load_and_call_function" - "test_load_library" +if cffi == null then + null +else + cffi.overridePythonAttrs { + disabledTests = lib.optionals stdenv.hostPlatform.isDarwin [ + # cannot load library 'c' + "test_FILE" + "test_FILE_object" + "test_FILE_only_for_FILE_arg" + "test_load_and_call_function" + "test_load_library" - # cannot load library 'dl' - "test_dlopen_handle" + # cannot load library 'dl' + "test_dlopen_handle" - # cannot load library 'm' - "test_dir_on_dlopen_lib" - "test_dlclose" - "test_dlopen" - "test_dlopen_constant" - "test_dlopen_flags" - "test_function_typedef" - "test_line_continuation_in_defines" - "test_missing_function" - "test_remove_comments" - "test_remove_line_continuation_comments" - "test_simple" - "test_sin" - "test_sinf" - "test_stdcall_only_on_windows" - "test_wraps_from_stdlib" + # cannot load library 'm' + "test_dir_on_dlopen_lib" + "test_dlclose" + "test_dlopen" + "test_dlopen_constant" + "test_dlopen_flags" + "test_function_typedef" + "test_line_continuation_in_defines" + "test_missing_function" + "test_remove_comments" + "test_remove_line_continuation_comments" + "test_simple" + "test_sin" + "test_sinf" + "test_stdcall_only_on_windows" + "test_wraps_from_stdlib" - # MemoryError - "test_callback_as_function_argument" - "test_callback_crash" - "test_callback_decorator" - "test_callback_large_struct" - "test_callback_returning_void" - "test_cast_functionptr_and_int" - "test_function_pointer" - "test_functionptr_intptr_return" - "test_functionptr_simple" - "test_functionptr_void_return" - "test_functionptr_voidptr_return" - ]; -} + # MemoryError + "test_callback_as_function_argument" + "test_callback_crash" + "test_callback_decorator" + "test_callback_large_struct" + "test_callback_returning_void" + "test_cast_functionptr_and_int" + "test_function_pointer" + "test_functionptr_intptr_return" + "test_functionptr_simple" + "test_functionptr_void_return" + "test_functionptr_voidptr_return" + ]; + } diff --git a/pkgs/development/python2-modules/configparser/default.nix b/pkgs/development/python2-modules/configparser/default.nix index 956c12f44c5dcc..bff2f2723340b3 100644 --- a/pkgs/development/python2-modules/configparser/default.nix +++ b/pkgs/development/python2-modules/configparser/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, buildPythonPackage, fetchPypi, setuptools-scm }: +{ + lib, + stdenv, + buildPythonPackage, + fetchPypi, + setuptools-scm, +}: buildPythonPackage rec { pname = "configparser"; diff --git a/pkgs/development/python2-modules/contextlib2/default.nix b/pkgs/development/python2-modules/contextlib2/default.nix index 063039448feaba..6da00c18b62741 100644 --- a/pkgs/development/python2-modules/contextlib2/default.nix +++ b/pkgs/development/python2-modules/contextlib2/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildPythonPackage -, fetchPypi +{ + lib, + buildPythonPackage, + fetchPypi, }: buildPythonPackage rec { diff --git a/pkgs/development/python2-modules/coverage/default.nix b/pkgs/development/python2-modules/coverage/default.nix index 94da2f4c7b43d5..49766e98858f96 100644 --- a/pkgs/development/python2-modules/coverage/default.nix +++ b/pkgs/development/python2-modules/coverage/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildPythonPackage -, fetchPypi -, mock +{ + lib, + buildPythonPackage, + fetchPypi, + mock, }: buildPythonPackage rec { diff --git a/pkgs/development/python2-modules/enum/default.nix b/pkgs/development/python2-modules/enum/default.nix index db827601d5de56..b2cf685df1438a 100644 --- a/pkgs/development/python2-modules/enum/default.nix +++ b/pkgs/development/python2-modules/enum/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchPypi -, isPy3k -, isPyPy +{ + lib, + buildPythonPackage, + fetchPypi, + isPy3k, + isPyPy, }: buildPythonPackage rec { diff --git a/pkgs/development/python2-modules/filelock/default.nix b/pkgs/development/python2-modules/filelock/default.nix index fc787fab1b3e24..15ba0afec8b685 100644 --- a/pkgs/development/python2-modules/filelock/default.nix +++ b/pkgs/development/python2-modules/filelock/default.nix @@ -1,4 +1,9 @@ -{ lib, buildPythonPackage, fetchPypi, setuptools-scm }: +{ + lib, + buildPythonPackage, + fetchPypi, + setuptools-scm, +}: buildPythonPackage rec { pname = "filelock"; diff --git a/pkgs/development/python2-modules/futures/default.nix b/pkgs/development/python2-modules/futures/default.nix index 5cad6c13029d94..035962759c4cad 100644 --- a/pkgs/development/python2-modules/futures/default.nix +++ b/pkgs/development/python2-modules/futures/default.nix @@ -1,4 +1,11 @@ -{ lib, buildPythonPackage, fetchPypi, isPy3k, python, stdenv }: +{ + lib, + buildPythonPackage, + fetchPypi, + isPy3k, + python, + stdenv, +}: buildPythonPackage rec { pname = "futures"; diff --git a/pkgs/development/python2-modules/hypothesis/default.nix b/pkgs/development/python2-modules/hypothesis/default.nix index 06dd5930aae308..ed9e049bc95594 100644 --- a/pkgs/development/python2-modules/hypothesis/default.nix +++ b/pkgs/development/python2-modules/hypothesis/default.nix @@ -1,7 +1,18 @@ -{ lib, buildPythonPackage, fetchFromGitHub -, isPy3k, attrs, coverage, enum34, pexpect -, doCheck ? true, pytest, pytest-xdist, flaky, mock -, sortedcontainers +{ + lib, + buildPythonPackage, + fetchFromGitHub, + isPy3k, + attrs, + coverage, + enum34, + pexpect, + doCheck ? true, + pytest, + pytest-xdist, + flaky, + mock, + sortedcontainers, }: buildPythonPackage rec { # https://hypothesis.readthedocs.org/en/latest/packaging.html @@ -29,7 +40,13 @@ buildPythonPackage rec { sortedcontainers ] ++ lib.optional (!isPy3k) enum34; - nativeCheckInputs = [ pytest pytest-xdist flaky mock pexpect ]; + nativeCheckInputs = [ + pytest + pytest-xdist + flaky + mock + pexpect + ]; inherit doCheck; checkPhase = '' diff --git a/pkgs/development/python2-modules/importlib-metadata/default.nix b/pkgs/development/python2-modules/importlib-metadata/default.nix index f50b2c07c1dab2..72b37433c5122a 100644 --- a/pkgs/development/python2-modules/importlib-metadata/default.nix +++ b/pkgs/development/python2-modules/importlib-metadata/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonPackage -, fetchPypi -, setuptools-scm -, zipp -, pathlib2 -, contextlib2 -, configparser -, isPy3k +{ + lib, + buildPythonPackage, + fetchPypi, + setuptools-scm, + zipp, + pathlib2, + contextlib2, + configparser, + isPy3k, }: buildPythonPackage rec { @@ -21,8 +22,13 @@ buildPythonPackage rec { nativeBuildInputs = [ setuptools-scm ]; - propagatedBuildInputs = [ zipp ] - ++ lib.optionals (!isPy3k) [ pathlib2 contextlib2 configparser ]; + propagatedBuildInputs = + [ zipp ] + ++ lib.optionals (!isPy3k) [ + pathlib2 + contextlib2 + configparser + ]; # Cyclic dependencies doCheck = false; diff --git a/pkgs/development/python2-modules/jinja2/default.nix b/pkgs/development/python2-modules/jinja2/default.nix index 1b6948a66aadef..53f9bb60379d64 100644 --- a/pkgs/development/python2-modules/jinja2/default.nix +++ b/pkgs/development/python2-modules/jinja2/default.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, buildPythonPackage -, isPy3k -, fetchPypi -, pytest -, markupsafe -, setuptools +{ + lib, + stdenv, + buildPythonPackage, + isPy3k, + fetchPypi, + pytest, + markupsafe, + setuptools, }: buildPythonPackage rec { @@ -17,7 +19,10 @@ buildPythonPackage rec { }; nativeCheckInputs = [ pytest ]; - propagatedBuildInputs = [ markupsafe setuptools ]; + propagatedBuildInputs = [ + markupsafe + setuptools + ]; # Multiple tests run out of stack space on 32bit systems with python2. # See https://github.com/pallets/jinja/issues/1158 diff --git a/pkgs/development/python2-modules/markupsafe/default.nix b/pkgs/development/python2-modules/markupsafe/default.nix index ae0878c7a97230..7bff587591e132 100644 --- a/pkgs/development/python2-modules/markupsafe/default.nix +++ b/pkgs/development/python2-modules/markupsafe/default.nix @@ -1,13 +1,14 @@ -{ lib -, buildPythonPackage -, fetchPypi +{ + lib, + buildPythonPackage, + fetchPypi, }: buildPythonPackage rec { pname = "MarkupSafe"; version = "1.1.1"; - src = fetchPypi { + src = fetchPypi { inherit pname version; sha256 = "29872e92839765e546828bb7754a68c418d927cd064fd4708fab9fe9c8bb116b"; }; diff --git a/pkgs/development/python2-modules/mock/default.nix b/pkgs/development/python2-modules/mock/default.nix index a343acfffaa193..63298dfc38dfe6 100644 --- a/pkgs/development/python2-modules/mock/default.nix +++ b/pkgs/development/python2-modules/mock/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonPackage -, fetchPypi -, isPy27 -, funcsigs -, six -, pbr -, unittestCheckHook -, pytest +{ + lib, + buildPythonPackage, + fetchPypi, + isPy27, + funcsigs, + six, + pbr, + unittestCheckHook, + pytest, }: buildPythonPackage rec { @@ -18,7 +19,10 @@ buildPythonPackage rec { sha256 = "83657d894c90d5681d62155c82bda9c1187827525880eda8ff5df4ec813437c3"; }; - propagatedBuildInputs = [ six pbr ] ++ lib.optionals isPy27 [ funcsigs ]; + propagatedBuildInputs = [ + six + pbr + ] ++ lib.optionals isPy27 [ funcsigs ]; # On PyPy for Python 2.7 in particular, Mock's tests have a known failure. # Mock upstream has a decoration to disable the failing test and make diff --git a/pkgs/development/python2-modules/more-itertools/default.nix b/pkgs/development/python2-modules/more-itertools/default.nix index 7a09dda8e9cd75..ae2d5f7235642a 100644 --- a/pkgs/development/python2-modules/more-itertools/default.nix +++ b/pkgs/development/python2-modules/more-itertools/default.nix @@ -1,12 +1,12 @@ -{ lib -, buildPythonPackage -, fetchPypi -, unittestCheckHook -, six -, stdenv +{ + lib, + buildPythonPackage, + fetchPypi, + unittestCheckHook, + six, + stdenv, }: - buildPythonPackage rec { pname = "more-itertools"; version = "5.0.0"; diff --git a/pkgs/development/python2-modules/packaging/default.nix b/pkgs/development/python2-modules/packaging/default.nix index 61f0ed3a73035f..71d4d674717688 100644 --- a/pkgs/development/python2-modules/packaging/default.nix +++ b/pkgs/development/python2-modules/packaging/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildPythonPackage -, fetchPypi -, pyparsing -, six -, pytestCheckHook -, pretend +{ + lib, + buildPythonPackage, + fetchPypi, + pyparsing, + six, + pytestCheckHook, + pretend, }: # We keep 20.4 because it uses setuptools instead of flit-core @@ -20,7 +21,10 @@ buildPythonPackage rec { sha256 = "4357f74f47b9c12db93624a82154e9b120fa8293699949152b22065d556079f8"; }; - propagatedBuildInputs = [ pyparsing six ]; + propagatedBuildInputs = [ + pyparsing + six + ]; nativeCheckInputs = [ pytestCheckHook @@ -33,7 +37,10 @@ buildPythonPackage rec { meta = with lib; { description = "Core utilities for Python packages"; homepage = "https://github.com/pypa/packaging"; - license = [ licenses.bsd2 licenses.asl20 ]; + license = [ + licenses.bsd2 + licenses.asl20 + ]; maintainers = with maintainers; [ bennofs ]; }; } diff --git a/pkgs/development/python2-modules/pip/default.nix b/pkgs/development/python2-modules/pip/default.nix index 0e5229c5884450..229f34fa1a7ad5 100644 --- a/pkgs/development/python2-modules/pip/default.nix +++ b/pkgs/development/python2-modules/pip/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonPackage -, bootstrapped-pip -, fetchFromGitHub -, mock -, scripttest -, virtualenv -, pretend -, pytest +{ + lib, + buildPythonPackage, + bootstrapped-pip, + fetchFromGitHub, + mock, + scripttest, + virtualenv, + pretend, + pytest, }: buildPythonPackage rec { @@ -28,7 +29,13 @@ buildPythonPackage rec { # to force it a little. pipInstallFlags = [ "--ignore-installed" ]; - nativeCheckInputs = [ mock scripttest virtualenv pretend pytest ]; + nativeCheckInputs = [ + mock + scripttest + virtualenv + pretend + pytest + ]; # Pip wants pytest, but tests are not distributed doCheck = false; diff --git a/pkgs/development/python2-modules/pluggy/default.nix b/pkgs/development/python2-modules/pluggy/default.nix index ea362bdb5812ff..6765530948a29d 100644 --- a/pkgs/development/python2-modules/pluggy/default.nix +++ b/pkgs/development/python2-modules/pluggy/default.nix @@ -1,8 +1,9 @@ -{ buildPythonPackage -, lib -, fetchPypi -, setuptools-scm -, importlib-metadata +{ + buildPythonPackage, + lib, + fetchPypi, + setuptools-scm, + importlib-metadata, }: buildPythonPackage rec { diff --git a/pkgs/development/python2-modules/pycairo/default.nix b/pkgs/development/python2-modules/pycairo/default.nix index 97fe85a9990759..85430cae6ac27b 100644 --- a/pkgs/development/python2-modules/pycairo/default.nix +++ b/pkgs/development/python2-modules/pycairo/default.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, meson -, ninja -, buildPythonPackage -, pytest -, pkg-config -, cairo -, python +{ + lib, + fetchFromGitHub, + fetchpatch, + meson, + ninja, + buildPythonPackage, + pytest, + pkg-config, + cairo, + python, }: buildPythonPackage rec { @@ -56,7 +57,10 @@ buildPythonPackage rec { meta = with lib; { description = "Python 2 bindings for cairo"; homepage = "https://pycairo.readthedocs.io/"; - license = with licenses; [ lgpl21Only mpl11 ]; + license = with licenses; [ + lgpl21Only + mpl11 + ]; platforms = lib.platforms.linux ++ lib.platforms.darwin; }; } diff --git a/pkgs/development/python2-modules/pygobject/default.nix b/pkgs/development/python2-modules/pygobject/default.nix index 3202c6e6af76d2..01920854cb043f 100644 --- a/pkgs/development/python2-modules/pygobject/default.nix +++ b/pkgs/development/python2-modules/pygobject/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, fetchpatch, python, buildPythonPackage, pkg-config, glib, isPy3k, pythonAtLeast }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + python, + buildPythonPackage, + pkg-config, + glib, + isPy3k, + pythonAtLeast, +}: buildPythonPackage rec { pname = "pygobject"; @@ -11,7 +22,10 @@ buildPythonPackage rec { sha256 = "0nkam61rsn7y3wik3vw46wk5q2cjfh2iph57hl9m39rc8jijb7dv"; }; - outputs = [ "out" "devdoc" ]; + outputs = [ + "out" + "devdoc" + ]; patches = lib.optionals stdenv.hostPlatform.isDarwin [ ./pygobject-2.0-fix-darwin.patch diff --git a/pkgs/development/python2-modules/pygtk/default.nix b/pkgs/development/python2-modules/pygtk/default.nix index 68a7dba4c8e363..9ba5ce952e17e6 100644 --- a/pkgs/development/python2-modules/pygtk/default.nix +++ b/pkgs/development/python2-modules/pygtk/default.nix @@ -1,9 +1,24 @@ -{ lib, stdenv, fetchurl, fetchpatch, python, pkg-config, gtk2, pygobject2, pycairo, pango -, buildPythonPackage, isPy3k }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + python, + pkg-config, + gtk2, + pygobject2, + pycairo, + pango, + buildPythonPackage, + isPy3k, +}: buildPythonPackage rec { pname = "pygtk"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; version = "2.24.0"; format = "other"; @@ -31,13 +46,18 @@ buildPythonPackage rec { pango ]; - propagatedBuildInputs = [ gtk2 pygobject2 pycairo ]; + propagatedBuildInputs = [ + gtk2 + pygobject2 + pycairo + ]; configurePhase = "configurePhase"; buildPhase = "buildPhase"; - env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isDarwin "-ObjC" + env.NIX_CFLAGS_COMPILE = + lib.optionalString stdenv.hostPlatform.isDarwin "-ObjC" + lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) " -lpython2.7"; installPhase = "installPhase"; @@ -50,7 +70,8 @@ buildPythonPackage rec { -e "s/.*testGlade.*//" \ -e "s/.*(glade.*//" \ tests/test_api.py - '' + '' + '' + + '' sed -i -e "s/sys.path.insert(0, os.path.join(buildDir, 'gtk'))//" \ -e "s/sys.path.insert(0, buildDir)//" \ tests/common.py diff --git a/pkgs/development/python2-modules/pyparsing/default.nix b/pkgs/development/python2-modules/pyparsing/default.nix index 8a04747075450a..52566d07ce5e97 100644 --- a/pkgs/development/python2-modules/pyparsing/default.nix +++ b/pkgs/development/python2-modules/pyparsing/default.nix @@ -1,11 +1,12 @@ -{ buildPythonPackage -, fetchFromGitHub -, lib +{ + buildPythonPackage, + fetchFromGitHub, + lib, -# since this is a dependency of pytest, we need to avoid -# circular dependencies -, jinja2 -, railroad-diagrams + # since this is a dependency of pytest, we need to avoid + # circular dependencies + jinja2, + railroad-diagrams, }: let @@ -32,7 +33,9 @@ let ''; passthru.tests = { - check = pyparsing.overridePythonAttrs (_: { doCheck = true; }); + check = pyparsing.overridePythonAttrs (_: { + doCheck = true; + }); }; meta = with lib; { @@ -42,4 +45,4 @@ let }; }; in - pyparsing +pyparsing diff --git a/pkgs/development/python2-modules/pytest-xdist/default.nix b/pkgs/development/python2-modules/pytest-xdist/default.nix index 5da424a0c30263..73b845f7530794 100644 --- a/pkgs/development/python2-modules/pytest-xdist/default.nix +++ b/pkgs/development/python2-modules/pytest-xdist/default.nix @@ -1,5 +1,16 @@ -{ lib, fetchPypi, buildPythonPackage, execnet, pytest -, setuptools-scm, pytest-forked, filelock, psutil, six, isPy3k }: +{ + lib, + fetchPypi, + buildPythonPackage, + execnet, + pytest, + setuptools-scm, + pytest-forked, + filelock, + psutil, + six, + isPy3k, +}: buildPythonPackage rec { pname = "pytest-xdist"; @@ -10,9 +21,20 @@ buildPythonPackage rec { sha256 = "1vh4ps32lp5ignch5adbl3pgchvigdfmrl6qpmhxih54wa1qw3il"; }; - nativeBuildInputs = [ setuptools-scm pytest ]; - nativeCheckInputs = [ pytest filelock ]; - propagatedBuildInputs = [ execnet pytest-forked psutil six ]; + nativeBuildInputs = [ + setuptools-scm + pytest + ]; + nativeCheckInputs = [ + pytest + filelock + ]; + propagatedBuildInputs = [ + execnet + pytest-forked + psutil + six + ]; # Encountered a memory leak # https://github.com/pytest-dev/pytest-xdist/issues/462 diff --git a/pkgs/development/python2-modules/pytest/default.nix b/pkgs/development/python2-modules/pytest/default.nix index fa086eb46c7c89..a6abb8075316ba 100644 --- a/pkgs/development/python2-modules/pytest/default.nix +++ b/pkgs/development/python2-modules/pytest/default.nix @@ -1,6 +1,25 @@ -{ lib, buildPythonPackage, pythonOlder, fetchPypi, attrs, hypothesis, py -, setuptools-scm, setuptools, six, pluggy, funcsigs, isPy3k, more-itertools -, atomicwrites, mock, writeText, pathlib2, wcwidth, packaging, isPyPy +{ + lib, + buildPythonPackage, + pythonOlder, + fetchPypi, + attrs, + hypothesis, + py, + setuptools-scm, + setuptools, + six, + pluggy, + funcsigs, + isPy3k, + more-itertools, + atomicwrites, + mock, + writeText, + pathlib2, + wcwidth, + packaging, + isPyPy, }: buildPythonPackage rec { version = "4.6.11"; @@ -16,9 +35,23 @@ buildPythonPackage rec { --replace "pluggy>=0.12,<1.0" "pluggy>=0.12,<2.0" ''; - nativeCheckInputs = [ hypothesis mock ]; + nativeCheckInputs = [ + hypothesis + mock + ]; buildInputs = [ setuptools-scm ]; - propagatedBuildInputs = [ attrs py setuptools six pluggy more-itertools atomicwrites wcwidth packaging ] + propagatedBuildInputs = + [ + attrs + py + setuptools + six + pluggy + more-itertools + atomicwrites + wcwidth + packaging + ] ++ lib.optionals (!isPy3k) [ funcsigs ] ++ lib.optionals (pythonOlder "3.6") [ pathlib2 ]; @@ -61,7 +94,12 @@ buildPythonPackage rec { meta = with lib; { homepage = "https://docs.pytest.org"; description = "Framework for writing tests"; - maintainers = with maintainers; [ domenkozar lovek323 madjar lsix ]; + maintainers = with maintainers; [ + domenkozar + lovek323 + madjar + lsix + ]; license = licenses.mit; platforms = platforms.unix; }; diff --git a/pkgs/development/python2-modules/scandir/default.nix b/pkgs/development/python2-modules/scandir/default.nix index 9c8396a191d1c2..650dee1ddf83c6 100644 --- a/pkgs/development/python2-modules/scandir/default.nix +++ b/pkgs/development/python2-modules/scandir/default.nix @@ -1,4 +1,9 @@ -{ lib, python, buildPythonPackage, fetchPypi }: +{ + lib, + python, + buildPythonPackage, + fetchPypi, +}: buildPythonPackage rec { pname = "scandir"; diff --git a/pkgs/development/python2-modules/setuptools-scm/default.nix b/pkgs/development/python2-modules/setuptools-scm/default.nix index 48b6d3b8134735..ef0e4de6b2be12 100644 --- a/pkgs/development/python2-modules/setuptools-scm/default.nix +++ b/pkgs/development/python2-modules/setuptools-scm/default.nix @@ -1,4 +1,9 @@ -{ lib, buildPythonPackage, fetchPypi, toml }: +{ + lib, + buildPythonPackage, + fetchPypi, + toml, +}: buildPythonPackage rec { pname = "setuptools_scm"; diff --git a/pkgs/development/python2-modules/setuptools/default.nix b/pkgs/development/python2-modules/setuptools/default.nix index faddafc9f9d372..1e7c78532e5922 100644 --- a/pkgs/development/python2-modules/setuptools/default.nix +++ b/pkgs/development/python2-modules/setuptools/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, buildPythonPackage -, fetchFromGitHub -, python -, bootstrapped-pip -, lib -, pipInstallHook -, setuptoolsBuildHook +{ + stdenv, + buildPythonPackage, + fetchFromGitHub, + python, + bootstrapped-pip, + lib, + pipInstallHook, + setuptoolsBuildHook, }: let @@ -43,7 +44,8 @@ let mv dist/${name} $out ''; }; -in buildPythonPackage rec { +in +buildPythonPackage rec { inherit pname version; # Because of bootstrapping we don't use the setuptoolsBuildHook that comes with format="setuptools" directly. # Instead, we override it to remove setuptools to avoid a circular dependency. @@ -54,8 +56,11 @@ in buildPythonPackage rec { nativeBuildInputs = [ bootstrapped-pip - (pipInstallHook.override{pip=null;}) - (setuptoolsBuildHook.override{setuptools=null; wheel=null;}) + (pipInstallHook.override { pip = null; }) + (setuptoolsBuildHook.override { + setuptools = null; + wheel = null; + }) ]; preBuild = lib.optionalString (!stdenv.hostPlatform.isWindows) '' @@ -73,7 +78,10 @@ in buildPythonPackage rec { meta = with lib; { description = "Utilities to facilitate the installation of Python packages"; homepage = "https://pypi.python.org/pypi/setuptools"; - license = with licenses; [ psfl zpl20 ]; + license = with licenses; [ + psfl + zpl20 + ]; platforms = python.meta.platforms; priority = 10; }; diff --git a/pkgs/development/python2-modules/typing/default.nix b/pkgs/development/python2-modules/typing/default.nix index b8c143cbd53790..1d6f07eb878092 100644 --- a/pkgs/development/python2-modules/typing/default.nix +++ b/pkgs/development/python2-modules/typing/default.nix @@ -1,10 +1,19 @@ -{ lib, buildPythonPackage, fetchPypi, pythonOlder, isPy3k, isPyPy, unittestCheckHook -, pythonAtLeast }: +{ + lib, + buildPythonPackage, + fetchPypi, + pythonOlder, + isPy3k, + isPyPy, + unittestCheckHook, + pythonAtLeast, +}: let testDir = if isPy3k then "src" else "python2"; -in buildPythonPackage rec { +in +buildPythonPackage rec { pname = "typing"; version = "3.10.0.0"; @@ -22,7 +31,10 @@ in buildPythonPackage rec { nativeCheckInputs = [ unittestCheckHook ]; - unittestFlagsArray = [ "-s" testDir ]; + unittestFlagsArray = [ + "-s" + testDir + ]; meta = with lib; { description = "Backport of typing module to Python versions older than 3.5"; diff --git a/pkgs/development/python2-modules/wcwidth/default.nix b/pkgs/development/python2-modules/wcwidth/default.nix index eccaadf66c54f2..f16622f7a7b0e1 100644 --- a/pkgs/development/python2-modules/wcwidth/default.nix +++ b/pkgs/development/python2-modules/wcwidth/default.nix @@ -1,10 +1,11 @@ -{ backports-functools-lru-cache -, wcwidth -, lib +{ + backports-functools-lru-cache, + wcwidth, + lib, }: -wcwidth.overridePythonAttrs(oldAttrs: { - propagatedBuildInputs = oldAttrs.propagatedBuildInputs or [] ++ [ +wcwidth.overridePythonAttrs (oldAttrs: { + propagatedBuildInputs = oldAttrs.propagatedBuildInputs or [ ] ++ [ backports-functools-lru-cache ]; @@ -17,8 +18,10 @@ wcwidth.overridePythonAttrs(oldAttrs: { disabled = false; meta = oldAttrs.meta // { - /** maintainers overridden here for python2; this makes sure that python3 - maintainers are not blamed for the breakage here. */ + /** + maintainers overridden here for python2; this makes sure that python3 + maintainers are not blamed for the breakage here. + */ maintainers = with lib.maintainers; [ bryango ]; }; }) diff --git a/pkgs/development/python2-modules/wheel/default.nix b/pkgs/development/python2-modules/wheel/default.nix index 5831e234fe1e52..95841e413c6300 100644 --- a/pkgs/development/python2-modules/wheel/default.nix +++ b/pkgs/development/python2-modules/wheel/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, bootstrapped-pip -, setuptools +{ + lib, + buildPythonPackage, + fetchFromGitHub, + bootstrapped-pip, + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/development/python2-modules/zipp/default.nix b/pkgs/development/python2-modules/zipp/default.nix index c256ed4f7ada87..b4aed672ffa940 100644 --- a/pkgs/development/python2-modules/zipp/default.nix +++ b/pkgs/development/python2-modules/zipp/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildPythonPackage -, fetchPypi -, setuptools-scm -, pytest -, pytest-flake8 -, more-itertools +{ + lib, + buildPythonPackage, + fetchPypi, + setuptools-scm, + pytest, + pytest-flake8, + more-itertools, }: buildPythonPackage rec { @@ -20,7 +21,10 @@ buildPythonPackage rec { propagatedBuildInputs = [ more-itertools ]; - nativeCheckInputs = [ pytest pytest-flake8 ]; + nativeCheckInputs = [ + pytest + pytest-flake8 + ]; checkPhase = '' pytest diff --git a/pkgs/development/r-modules/generate-shell.nix b/pkgs/development/r-modules/generate-shell.nix index 1588aa9b76d7b6..66b51380277949 100644 --- a/pkgs/development/r-modules/generate-shell.nix +++ b/pkgs/development/r-modules/generate-shell.nix @@ -1,4 +1,4 @@ -with import ../../.. {}; +with import ../../.. { }; stdenv.mkDerivation { name = "generate-r-packages-shell"; diff --git a/pkgs/development/r-modules/test-evaluation.nix b/pkgs/development/r-modules/test-evaluation.nix index 2ca0d42c6db4f5..b7898fd478a8dd 100644 --- a/pkgs/development/r-modules/test-evaluation.nix +++ b/pkgs/development/r-modules/test-evaluation.nix @@ -18,4 +18,4 @@ let }; in - rWrapper +rWrapper diff --git a/pkgs/development/r-modules/wrapper-radian.nix b/pkgs/development/r-modules/wrapper-radian.nix index 44099206b5b558..be829ccde8d125 100644 --- a/pkgs/development/r-modules/wrapper-radian.nix +++ b/pkgs/development/r-modules/wrapper-radian.nix @@ -1,36 +1,48 @@ -{ lib -, runCommand -, R -, radian -, makeWrapper -, recommendedPackages -, packages -, wrapR ? false +{ + lib, + runCommand, + R, + radian, + makeWrapper, + recommendedPackages, + packages, + wrapR ? false, }: -runCommand (radian.name + "-wrapper") { - preferLocalBuild = true; - allowSubstitutes = false; +runCommand (radian.name + "-wrapper") + { + preferLocalBuild = true; + allowSubstitutes = false; - buildInputs = [ R radian ] ++ recommendedPackages ++ packages; + buildInputs = + [ + R + radian + ] + ++ recommendedPackages + ++ packages; - nativeBuildInputs = [ makeWrapper ]; + nativeBuildInputs = [ makeWrapper ]; - passthru = { inherit recommendedPackages; }; + passthru = { inherit recommendedPackages; }; - meta = radian.meta // { - # To prevent builds on hydra - hydraPlatforms = [ ]; - # prefer wrapper over the package - priority = (radian.meta.priority or lib.meta.defaultPriority) - 1; - }; -} ('' - makeWrapper "${radian}/bin/radian" "$out/bin/radian" \ - --prefix "R_LIBS_SITE" ":" "$R_LIBS_SITE" -'' + lib.optionalString wrapR '' - cd ${R}/bin - for exe in *; do - makeWrapper "${R}/bin/$exe" "$out/bin/$exe" \ - --prefix "R_LIBS_SITE" ":" "$R_LIBS_SITE" - done -'') + meta = radian.meta // { + # To prevent builds on hydra + hydraPlatforms = [ ]; + # prefer wrapper over the package + priority = (radian.meta.priority or lib.meta.defaultPriority) - 1; + }; + } + ( + '' + makeWrapper "${radian}/bin/radian" "$out/bin/radian" \ + --prefix "R_LIBS_SITE" ":" "$R_LIBS_SITE" + '' + + lib.optionalString wrapR '' + cd ${R}/bin + for exe in *; do + makeWrapper "${R}/bin/$exe" "$out/bin/$exe" \ + --prefix "R_LIBS_SITE" ":" "$R_LIBS_SITE" + done + '' + ) diff --git a/pkgs/development/r-modules/wrapper-rstudio.nix b/pkgs/development/r-modules/wrapper-rstudio.nix index 2b65bb3d82da21..8088098484f877 100644 --- a/pkgs/development/r-modules/wrapper-rstudio.nix +++ b/pkgs/development/r-modules/wrapper-rstudio.nix @@ -1,33 +1,40 @@ -{ runCommand -, R -, rstudio -, makeWrapper -, wrapQtAppsHook -, recommendedPackages -, packages -, fontconfig +{ + runCommand, + R, + rstudio, + makeWrapper, + wrapQtAppsHook, + recommendedPackages, + packages, + fontconfig, }: runCommand (rstudio.name + "-wrapper") -{ - preferLocalBuild = true; - allowSubstitutes = false; + { + preferLocalBuild = true; + allowSubstitutes = false; - nativeBuildInputs = [ (if rstudio.server then makeWrapper else wrapQtAppsHook) ]; - dontWrapQtApps = true; + nativeBuildInputs = [ (if rstudio.server then makeWrapper else wrapQtAppsHook) ]; + dontWrapQtApps = true; - buildInputs = [ R rstudio ] ++ recommendedPackages ++ packages; + buildInputs = + [ + R + rstudio + ] + ++ recommendedPackages + ++ packages; - # rWrapper points R to a specific set of packages by using a wrapper - # (as in https://nixos.org/nixpkgs/manual/#r-packages) which sets - # R_LIBS_SITE. Ordinarily, it would be possible to make RStudio use - # this same set of packages by simply overriding its version of R - # with the wrapped one, however, RStudio internally overrides - # R_LIBS_SITE. The below works around this by turning R_LIBS_SITE - # into an R file (fixLibsR) which achieves the same effect, then - # uses R_PROFILE_USER to load this code at startup in RStudio. - fixLibsR = "fix_libs.R"; -} + # rWrapper points R to a specific set of packages by using a wrapper + # (as in https://nixos.org/nixpkgs/manual/#r-packages) which sets + # R_LIBS_SITE. Ordinarily, it would be possible to make RStudio use + # this same set of packages by simply overriding its version of R + # with the wrapped one, however, RStudio internally overrides + # R_LIBS_SITE. The below works around this by turning R_LIBS_SITE + # into an R file (fixLibsR) which achieves the same effect, then + # uses R_PROFILE_USER to load this code at startup in RStudio. + fixLibsR = "fix_libs.R"; + } ( '' mkdir -p $out/bin @@ -37,18 +44,20 @@ runCommand (rstudio.name + "-wrapper") echo -n $R_LIBS_SITE | sed -e 's/:/", "/g' >> $out/$fixLibsR echo -n "\"))" >> $out/$fixLibsR echo >> $out/$fixLibsR - '' + - (if - rstudio.server then '' - makeWrapper ${rstudio}/bin/rsession $out/bin/rsession \ - --set R_PROFILE_USER $out/$fixLibsR --set FONTCONFIG_FILE ${fontconfig.out}/etc/fonts/fonts.conf - - makeWrapper ${rstudio}/bin/rserver $out/bin/rserver \ - --add-flags --rsession-path=$out/bin/rsession '' - else - '' - makeQtWrapper ${rstudio}/bin/rstudio $out/bin/rstudio \ - --set R_PROFILE_USER $out/$fixLibsR - '') + + ( + if rstudio.server then + '' + makeWrapper ${rstudio}/bin/rsession $out/bin/rsession \ + --set R_PROFILE_USER $out/$fixLibsR --set FONTCONFIG_FILE ${fontconfig.out}/etc/fonts/fonts.conf + + makeWrapper ${rstudio}/bin/rserver $out/bin/rserver \ + --add-flags --rsession-path=$out/bin/rsession + '' + else + '' + makeQtWrapper ${rstudio}/bin/rstudio $out/bin/rstudio \ + --set R_PROFILE_USER $out/$fixLibsR + '' + ) ) diff --git a/pkgs/development/r-modules/wrapper.nix b/pkgs/development/r-modules/wrapper.nix index 9dffbd83187b77..8d7445a50e970c 100644 --- a/pkgs/development/r-modules/wrapper.nix +++ b/pkgs/development/r-modules/wrapper.nix @@ -1,13 +1,20 @@ -{ lib, symlinkJoin, R, makeWrapper, recommendedPackages, packages }: +{ + lib, + symlinkJoin, + R, + makeWrapper, + recommendedPackages, + packages, +}: symlinkJoin { name = R.name + "-wrapper"; preferLocalBuild = true; allowSubstitutes = false; - buildInputs = [R] ++ recommendedPackages ++ packages; + buildInputs = [ R ] ++ recommendedPackages ++ packages; paths = [ R ]; - nativeBuildInputs = [makeWrapper]; + nativeBuildInputs = [ makeWrapper ]; postBuild = '' cd ${R}/bin @@ -22,10 +29,10 @@ symlinkJoin { # Make the list of recommended R packages accessible to other packages such as rpy2 passthru = { inherit recommendedPackages; }; - meta = R.meta // { - # To prevent builds on hydra - hydraPlatforms = []; - # prefer wrapper over the package - priority = (R.meta.priority or lib.meta.defaultPriority) - 1; - }; + meta = R.meta // { + # To prevent builds on hydra + hydraPlatforms = [ ]; + # prefer wrapper over the package + priority = (R.meta.priority or lib.meta.defaultPriority) - 1; + }; } diff --git a/pkgs/development/rocm-modules/5/clang-ocl/default.nix b/pkgs/development/rocm-modules/5/clang-ocl/default.nix index 65c2ea80b2a575..07ff08fa2e142e 100644 --- a/pkgs/development/rocm-modules/5/clang-ocl/default.nix +++ b/pkgs/development/rocm-modules/5/clang-ocl/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-device-libs +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-device-libs, }: stdenv.mkDerivation (finalAttrs: { @@ -38,6 +39,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/clr/default.nix b/pkgs/development/rocm-modules/5/clr/default.nix index 49857e9d26f5ac..2add6e58c9b059 100644 --- a/pkgs/development/rocm-modules/5/clr/default.nix +++ b/pkgs/development/rocm-modules/5/clr/default.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, callPackage -, fetchFromGitHub -, fetchurl -, rocmUpdateScript -, makeWrapper -, cmake -, perl -, clang -, hip-common -, hipcc -, rocm-device-libs -, rocm-comgr -, rocm-runtime -, roctracer -, rocminfo -, rocm-smi -, numactl -, libGL -, libxml2 -, libX11 -, python3Packages +{ + lib, + stdenv, + callPackage, + fetchFromGitHub, + fetchurl, + rocmUpdateScript, + makeWrapper, + cmake, + perl, + clang, + hip-common, + hipcc, + rocm-device-libs, + rocm-comgr, + rocm-runtime, + roctracer, + rocminfo, + rocm-smi, + numactl, + libGL, + libxml2, + libX11, + python3Packages, }: let @@ -37,14 +38,15 @@ let # https://github.com/NixOS/nixpkgs/issues/305641 # Not needed when 3.29.2 is in unstable - cmake' = cmake.overrideAttrs(old: rec { + cmake' = cmake.overrideAttrs (old: rec { version = "3.29.2"; src = fetchurl { url = "https://cmake.org/files/v${lib.versions.majorMinor version}/cmake-${version}.tar.gz"; hash = "sha256-NttLaSaqt0G6bksuotmckZMiITIwi03IJNQSPLcwNS4="; }; }); -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "clr"; version = "5.7.1"; @@ -185,6 +187,8 @@ in stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/clr/test-opencl-example.nix b/pkgs/development/rocm-modules/5/clr/test-opencl-example.nix index 0b612cde3f80db..2b3959d6e3ec51 100644 --- a/pkgs/development/rocm-modules/5/clr/test-opencl-example.nix +++ b/pkgs/development/rocm-modules/5/clr/test-opencl-example.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, makeImpureTest -, fetchFromGitHub -, clr -, cmake -, pkg-config -, glew -, libglut -, opencl-headers -, ocl-icd +{ + lib, + stdenv, + makeImpureTest, + fetchFromGitHub, + clr, + cmake, + pkg-config, + glew, + libglut, + opencl-headers, + ocl-icd, }: let @@ -24,9 +25,17 @@ let hash = "sha256-qARQpUiYsamHbko/I1gPZE9pUGJ+3396Vk2n7ERSftA="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ glew libglut opencl-headers ocl-icd ]; + buildInputs = [ + glew + libglut + opencl-headers + ocl-icd + ]; installPhase = '' runHook preInstall @@ -42,9 +51,9 @@ let meta = with lib; { description = "Samples from the AMD APP SDK (with OpenCRun support)"; - homepage = "https://github.com/OpenCL/AMD_APP_samples"; - license = licenses.bsd2; - platforms = platforms.linux; + homepage = "https://github.com/OpenCL/AMD_APP_samples"; + license = licenses.bsd2; + platforms = platforms.linux; maintainers = lib.teams.rocm.members; }; }; @@ -54,7 +63,11 @@ makeImpureTest { name = "opencl-example"; testedPackage = "rocmPackages_5.clr"; - sandboxPaths = [ "/sys" "/dev/dri" "/dev/kfd" ]; + sandboxPaths = [ + "/sys" + "/dev/dri" + "/dev/kfd" + ]; nativeBuildInputs = [ examples ]; diff --git a/pkgs/development/rocm-modules/5/clr/test-rocm-smi.nix b/pkgs/development/rocm-modules/5/clr/test-rocm-smi.nix index 25c0a7e0c32c6b..16bf1287001a5e 100644 --- a/pkgs/development/rocm-modules/5/clr/test-rocm-smi.nix +++ b/pkgs/development/rocm-modules/5/clr/test-rocm-smi.nix @@ -1,14 +1,18 @@ -{ lib -, makeImpureTest -, clinfo -, clr -, rocm-smi +{ + lib, + makeImpureTest, + clinfo, + clr, + rocm-smi, }: makeImpureTest { name = "rocm-smi"; testedPackage = "rocmPackages_5.clr"; - nativeBuildInputs = [ clinfo rocm-smi ]; + nativeBuildInputs = [ + clinfo + rocm-smi + ]; OCL_ICD_VENDORS = "${clr.icd}/etc/OpenCL/vendors"; testScript = '' diff --git a/pkgs/development/rocm-modules/5/composable_kernel/default.nix b/pkgs/development/rocm-modules/5/composable_kernel/default.nix index 7e7de3cf736833..1792acccab6855 100644 --- a/pkgs/development/rocm-modules/5/composable_kernel/default.nix +++ b/pkgs/development/rocm-modules/5/composable_kernel/default.nix @@ -1,29 +1,33 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, openmp -, clang-tools-extra -, gtest -, buildTests ? false -, buildExamples ? false -, gpuTargets ? [ ] # gpuTargets = [ "gfx803" "gfx900" "gfx1030" ... ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + openmp, + clang-tools-extra, + gtest, + buildTests ? false, + buildExamples ? false, + gpuTargets ? [ ], # gpuTargets = [ "gfx803" "gfx900" "gfx1030" ... ] }: stdenv.mkDerivation (finalAttrs: { pname = "composable_kernel"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildExamples [ - "example" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildExamples [ + "example" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -41,32 +45,39 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ openmp ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DGOOGLETEST_DIR=${gtest.src}" # Custom linker names - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DGOOGLETEST_DIR=${gtest.src}" # Custom linker names + ]; # No flags to build selectively it seems... - postPatch = lib.optionalString (!buildTests) '' - substituteInPlace CMakeLists.txt \ - --replace "add_subdirectory(test)" "" - '' + lib.optionalString (!buildExamples) '' - substituteInPlace CMakeLists.txt \ - --replace "add_subdirectory(example)" "" - ''; + postPatch = + lib.optionalString (!buildTests) '' + substituteInPlace CMakeLists.txt \ + --replace "add_subdirectory(test)" "" + '' + + lib.optionalString (!buildExamples) '' + substituteInPlace CMakeLists.txt \ + --replace "add_subdirectory(example)" "" + ''; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/test_* $test/bin - '' + lib.optionalString buildExamples '' - mkdir -p $example/bin - mv $out/bin/example_* $example/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/test_* $test/bin + '' + + lib.optionalString buildExamples '' + mkdir -p $example/bin + mv $out/bin/example_* $example/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -84,6 +95,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/half/default.nix b/pkgs/development/rocm-modules/5/half/default.nix index 400ab50885986f..168613cf912d7f 100644 --- a/pkgs/development/rocm-modules/5/half/default.nix +++ b/pkgs/development/rocm-modules/5/half/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -34,6 +35,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.unix; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/hip-common/default.nix b/pkgs/development/rocm-modules/5/hip-common/default.nix index 2687b587dbde06..4e7e23943cd174 100644 --- a/pkgs/development/rocm-modules/5/hip-common/default.nix +++ b/pkgs/development/rocm-modules/5/hip-common/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, }: stdenv.mkDerivation (finalAttrs: { @@ -39,6 +40,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/hipblas/default.nix b/pkgs/development/rocm-modules/5/hipblas/default.nix index a59543d653a4c0..59d93a4cd2b059 100644 --- a/pkgs/development/rocm-modules/5/hipblas/default.nix +++ b/pkgs/development/rocm-modules/5/hipblas/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, gfortran -, rocblas -, rocsolver -, gtest -, lapack-reference -, buildTests ? false -, buildBenchmarks ? false -, buildSamples ? false +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + gfortran, + rocblas, + rocsolver, + gtest, + lapack-reference, + buildTests ? false, + buildBenchmarks ? false, + buildSamples ? false, }: # Can also use cuBLAS @@ -20,15 +21,19 @@ stdenv.mkDerivation (finalAttrs: { pname = "hipblas"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ] ++ lib.optionals buildSamples [ - "sample" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ] + ++ lib.optionals buildSamples [ + "sample" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -44,43 +49,54 @@ stdenv.mkDerivation (finalAttrs: { gfortran ]; - buildInputs = [ - rocblas - rocsolver - ] ++ lib.optionals buildTests [ - gtest - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - lapack-reference - ]; + buildInputs = + [ + rocblas + rocsolver + ] + ++ lib.optionals buildTests [ + gtest + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + lapack-reference + ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_BENCHMARKS=ON" - ] ++ lib.optionals buildSamples [ - "-DBUILD_CLIENTS_SAMPLES=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_BENCHMARKS=ON" + ] + ++ lib.optionals buildSamples [ + "-DBUILD_CLIENTS_SAMPLES=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/hipblas-test $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/hipblas-bench $benchmark/bin - '' + lib.optionalString buildSamples '' - mkdir -p $sample/bin - mv $out/bin/example-* $sample/bin - '' + lib.optionalString (buildTests || buildBenchmarks || buildSamples) '' - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/hipblas-test $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/hipblas-bench $benchmark/bin + '' + + lib.optionalString buildSamples '' + mkdir -p $sample/bin + mv $out/bin/example-* $sample/bin + '' + + lib.optionalString (buildTests || buildBenchmarks || buildSamples) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -94,6 +110,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/hipcc/default.nix b/pkgs/development/rocm-modules/5/hipcc/default.nix index 63e6e4fb577de6..f89227bb50581e 100644 --- a/pkgs/development/rocm-modules/5/hipcc/default.nix +++ b/pkgs/development/rocm-modules/5/hipcc/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, lsb-release +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + lsb-release, }: stdenv.mkDerivation (finalAttrs: { @@ -41,6 +42,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/hipcub/default.nix b/pkgs/development/rocm-modules/5/hipcub/default.nix index ede46ccfbd57aa..cda80a0ed795fe 100644 --- a/pkgs/development/rocm-modules/5/hipcub/default.nix +++ b/pkgs/development/rocm-modules/5/hipcub/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocprim -, clr -, gtest -, gbenchmark -, buildTests ? false -, buildBenchmarks ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocprim, + clr, + gtest, + gbenchmark, + buildTests ? false, + buildBenchmarks ? false, + gpuTargets ? [ ], }: # CUB can also be used as a backend instead of rocPRIM. @@ -18,13 +19,16 @@ stdenv.mkDerivation (finalAttrs: { pname = "hipcub"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -39,39 +43,49 @@ stdenv.mkDerivation (finalAttrs: { clr ]; - buildInputs = [ - rocprim - ] ++ lib.optionals buildTests [ - gtest - ] ++ lib.optionals buildBenchmarks [ - gbenchmark - ]; + buildInputs = + [ + rocprim + ] + ++ lib.optionals buildTests [ + gtest + ] + ++ lib.optionals buildBenchmarks [ + gbenchmark + ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - "-DHIP_ROOT_DIR=${clr}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_TEST=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_BENCHMARK=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + "-DHIP_ROOT_DIR=${clr}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_TEST=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_BENCHMARK=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/test_* $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/benchmark_* $benchmark/bin - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/test_* $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/benchmark_* $benchmark/bin + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -85,6 +99,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ bsd3 ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/hipfft/default.nix b/pkgs/development/rocm-modules/5/hipfft/default.nix index 44d1475f687725..93eb03370b7d29 100644 --- a/pkgs/development/rocm-modules/5/hipfft/default.nix +++ b/pkgs/development/rocm-modules/5/hipfft/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, git -, rocfft -, gtest -, boost -, fftw -, fftwFloat -, openmp -, buildTests ? false -, buildBenchmarks ? false -, buildSamples ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + git, + rocfft, + gtest, + boost, + fftw, + fftwFloat, + openmp, + buildTests ? false, + buildBenchmarks ? false, + buildSamples ? false, + gpuTargets ? [ ], }: # Can also use cuFFT @@ -23,15 +24,19 @@ stdenv.mkDerivation (finalAttrs: { pname = "hipfft"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ] ++ lib.optionals buildSamples [ - "sample" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ] + ++ lib.optionals buildSamples [ + "sample" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -48,50 +53,61 @@ stdenv.mkDerivation (finalAttrs: { rocm-cmake ]; - buildInputs = [ - rocfft - ] ++ lib.optionals (buildTests || buildBenchmarks || buildSamples) [ - gtest - boost - fftw - fftwFloat - openmp - ]; + buildInputs = + [ + rocfft + ] + ++ lib.optionals (buildTests || buildBenchmarks || buildSamples) [ + gtest + boost + fftw + fftwFloat + openmp + ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-DCMAKE_MODULE_PATH=${clr}/lib/cmake/hip" - "-DHIP_ROOT_DIR=${clr}" - "-DHIP_PATH=${clr}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_RIDER=ON" - ] ++ lib.optionals buildSamples [ - "-DBUILD_CLIENTS_SAMPLES=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-DCMAKE_MODULE_PATH=${clr}/lib/cmake/hip" + "-DHIP_ROOT_DIR=${clr}" + "-DHIP_PATH=${clr}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_RIDER=ON" + ] + ++ lib.optionals buildSamples [ + "-DBUILD_CLIENTS_SAMPLES=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/hipfft-test $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/hipfft-rider $benchmark/bin - '' + lib.optionalString buildSamples '' - mkdir -p $sample/bin - mv clients/staging/hipfft_* $sample/bin - patchelf $sample/bin/hipfft_* --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/hipfft-test $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/hipfft-rider $benchmark/bin + '' + + lib.optionalString buildSamples '' + mkdir -p $sample/bin + mv clients/staging/hipfft_* $sample/bin + patchelf $sample/bin/hipfft_* --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -105,6 +121,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/hipfort/default.nix b/pkgs/development/rocm-modules/5/hipfort/default.nix index 13e02d439c01df..e9a2f82ed03191 100644 --- a/pkgs/development/rocm-modules/5/hipfort/default.nix +++ b/pkgs/development/rocm-modules/5/hipfort/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, gfortran +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + gfortran, }: stdenv.mkDerivation (finalAttrs: { @@ -62,6 +63,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; # mitx11 maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/hipify/default.nix b/pkgs/development/rocm-modules/5/hipify/default.nix index 281ad02d5dfcf5..8c885610756d2c 100644 --- a/pkgs/development/rocm-modules/5/hipify/default.nix +++ b/pkgs/development/rocm-modules/5/hipify/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, clang -, libxml2 +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + clang, + libxml2, }: stdenv.mkDerivation (finalAttrs: { @@ -45,6 +46,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/hipsolver/default.nix b/pkgs/development/rocm-modules/5/hipsolver/default.nix index ab4b60ef2c355b..a7b20ad6d72729 100644 --- a/pkgs/development/rocm-modules/5/hipsolver/default.nix +++ b/pkgs/development/rocm-modules/5/hipsolver/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, gfortran -, rocblas -, rocsolver -, gtest -, lapack-reference -, buildTests ? false -, buildBenchmarks ? false -, buildSamples ? false +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + gfortran, + rocblas, + rocsolver, + gtest, + lapack-reference, + buildTests ? false, + buildBenchmarks ? false, + buildSamples ? false, }: # Can also use cuSOLVER @@ -20,15 +21,19 @@ stdenv.mkDerivation (finalAttrs: { pname = "hipsolver"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ] ++ lib.optionals buildSamples [ - "sample" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ] + ++ lib.optionals buildSamples [ + "sample" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -44,44 +49,55 @@ stdenv.mkDerivation (finalAttrs: { gfortran ]; - buildInputs = [ - rocblas - rocsolver - ] ++ lib.optionals buildTests [ - gtest - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - lapack-reference - ]; + buildInputs = + [ + rocblas + rocsolver + ] + ++ lib.optionals buildTests [ + gtest + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + lapack-reference + ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_BENCHMARKS=ON" - ] ++ lib.optionals buildSamples [ - "-DBUILD_CLIENTS_SAMPLES=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_BENCHMARKS=ON" + ] + ++ lib.optionals buildSamples [ + "-DBUILD_CLIENTS_SAMPLES=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/hipsolver-test $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/hipsolver-bench $benchmark/bin - '' + lib.optionalString buildSamples '' - mkdir -p $sample/bin - mv clients/staging/example-* $sample/bin - patchelf $sample/bin/example-* --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/hipsolver-test $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/hipsolver-bench $benchmark/bin + '' + + lib.optionalString buildSamples '' + mkdir -p $sample/bin + mv clients/staging/example-* $sample/bin + patchelf $sample/bin/example-* --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -95,6 +111,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/hipsparse/default.nix b/pkgs/development/rocm-modules/5/hipsparse/default.nix index 9e3046223173d5..1891a60c1d0edf 100644 --- a/pkgs/development/rocm-modules/5/hipsparse/default.nix +++ b/pkgs/development/rocm-modules/5/hipsparse/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocsparse -, clr -, gfortran -, git -, gtest -, openmp -, buildTests ? false -, buildSamples ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocsparse, + clr, + gfortran, + git, + gtest, + openmp, + buildTests ? false, + buildSamples ? false, + gpuTargets ? [ ], }: # This can also use cuSPARSE as a backend instead of rocSPARSE @@ -20,13 +21,16 @@ stdenv.mkDerivation (finalAttrs: { pname = "hipsparse"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildSamples [ - "sample" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildSamples [ + "sample" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -42,29 +46,35 @@ stdenv.mkDerivation (finalAttrs: { gfortran ]; - buildInputs = [ - rocsparse - git - ] ++ lib.optionals buildTests [ - gtest - ] ++ lib.optionals (buildTests || buildSamples) [ - openmp - ]; + buildInputs = + [ + rocsparse + git + ] + ++ lib.optionals buildTests [ + gtest + ] + ++ lib.optionals (buildTests || buildSamples) [ + openmp + ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-DBUILD_CLIENTS_SAMPLES=${if buildSamples then "ON" else "OFF"}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-DBUILD_CLIENTS_SAMPLES=${if buildSamples then "ON" else "OFF"}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ]; # We have to manually generate the matrices # CMAKE_MATRICES_DIR seems to be reset in clients/tests/CMakeLists.txt @@ -107,17 +117,26 @@ stdenv.mkDerivation (finalAttrs: { --replace "\''${PROJECT_BINARY_DIR}/matrices" "/build/source/matrices" ''; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/hipsparse-test $test/bin - mv /build/source/matrices $test - rmdir $out/bin - '' + lib.optionalString buildSamples '' - mkdir -p $sample/bin - mv clients/staging/example_* $sample/bin - patchelf --set-rpath $out/lib:${lib.makeLibraryPath ( - finalAttrs.buildInputs ++ [ clr gfortran.cc ])} $sample/bin/example_* - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/hipsparse-test $test/bin + mv /build/source/matrices $test + rmdir $out/bin + '' + + lib.optionalString buildSamples '' + mkdir -p $sample/bin + mv clients/staging/example_* $sample/bin + patchelf --set-rpath $out/lib:${ + lib.makeLibraryPath ( + finalAttrs.buildInputs + ++ [ + clr + gfortran.cc + ] + ) + } $sample/bin/example_* + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -131,6 +150,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/hsa-amd-aqlprofile-bin/default.nix b/pkgs/development/rocm-modules/5/hsa-amd-aqlprofile-bin/default.nix index c007f2c62260a8..84e603c71f784f 100644 --- a/pkgs/development/rocm-modules/5/hsa-amd-aqlprofile-bin/default.nix +++ b/pkgs/development/rocm-modules/5/hsa-amd-aqlprofile-bin/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, callPackage -, dpkg +{ + lib, + stdenv, + fetchurl, + callPackage, + dpkg, }: stdenv.mkDerivation (finalAttrs: { @@ -38,6 +39,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ unfree ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/hsa-amd-aqlprofile-bin/update.nix b/pkgs/development/rocm-modules/5/hsa-amd-aqlprofile-bin/update.nix index bbde07ae9a98be..03f60b738b5567 100644 --- a/pkgs/development/rocm-modules/5/hsa-amd-aqlprofile-bin/update.nix +++ b/pkgs/development/rocm-modules/5/hsa-amd-aqlprofile-bin/update.nix @@ -1,12 +1,15 @@ -{ lib -, writeScript +{ + lib, + writeScript, }: { version }: let prefix = "hsa-amd-aqlprofile"; - extVersion = lib.strings.concatStrings (lib.strings.intersperse "0" (lib.versions.splitVersion version)); + extVersion = lib.strings.concatStrings ( + lib.strings.intersperse "0" (lib.versions.splitVersion version) + ); major = lib.versions.major version; minor = lib.versions.minor version; patch = lib.versions.patch version; @@ -54,4 +57,5 @@ let update-source-version rocmPackages_5.${prefix}-bin "$version" "" "$apt/$repoVersion/$pool$deb" --ignore-same-hash fi ''; -in [ updateScript ] +in +[ updateScript ] diff --git a/pkgs/development/rocm-modules/5/llvm/base.nix b/pkgs/development/rocm-modules/5/llvm/base.nix index a8147d862e320b..1330d9d84b37fe 100644 --- a/pkgs/development/rocm-modules/5/llvm/base.nix +++ b/pkgs/development/rocm-modules/5/llvm/base.nix @@ -1,76 +1,84 @@ -{ lib -, stdenv -, gcc12Stdenv -, fetchFromGitHub -, rocmUpdateScript -, pkg-config -, cmake -, ninja -, git -, doxygen -, sphinx -, lit -, libxml2 -, libxcrypt -, libedit -, libffi -, mpfr -, zlib -, ncurses -, python3Packages -, buildDocs ? true -, buildMan ? true -, buildTests ? true -, targetName ? "llvm" -, targetDir ? "llvm" -, targetProjects ? [ ] -, targetRuntimes ? [ ] -, llvmTargetsToBuild ? [ "NATIVE" ] # "NATIVE" resolves into x86 or aarch64 depending on stdenv -, extraPatches ? [ ] -, extraNativeBuildInputs ? [ ] -, extraBuildInputs ? [ ] -, extraCMakeFlags ? [ ] -, extraPostPatch ? "" -, checkTargets ? [( - lib.optionalString buildTests ( - if targetDir == "runtimes" - then "check-runtimes" - else "check-all" - ) -)] -, extraPostInstall ? "" -, hardeningDisable ? [ ] -, requiredSystemFeatures ? [ ] -, extraLicenses ? [ ] -, isBroken ? false +{ + lib, + stdenv, + gcc12Stdenv, + fetchFromGitHub, + rocmUpdateScript, + pkg-config, + cmake, + ninja, + git, + doxygen, + sphinx, + lit, + libxml2, + libxcrypt, + libedit, + libffi, + mpfr, + zlib, + ncurses, + python3Packages, + buildDocs ? true, + buildMan ? true, + buildTests ? true, + targetName ? "llvm", + targetDir ? "llvm", + targetProjects ? [ ], + targetRuntimes ? [ ], + llvmTargetsToBuild ? [ "NATIVE" ], # "NATIVE" resolves into x86 or aarch64 depending on stdenv + extraPatches ? [ ], + extraNativeBuildInputs ? [ ], + extraBuildInputs ? [ ], + extraCMakeFlags ? [ ], + extraPostPatch ? "", + checkTargets ? [ + (lib.optionalString buildTests (if targetDir == "runtimes" then "check-runtimes" else "check-all")) + ], + extraPostInstall ? "", + hardeningDisable ? [ ], + requiredSystemFeatures ? [ ], + extraLicenses ? [ ], + isBroken ? false, }: -let stdenv' = stdenv; in -let stdenv = - if stdenv'.cc.cc.isGNU or false && lib.versionAtLeast stdenv'.cc.cc.version "13.0" - then gcc12Stdenv - else stdenv'; +let + stdenv' = stdenv; +in +let + stdenv = + if stdenv'.cc.cc.isGNU or false && lib.versionAtLeast stdenv'.cc.cc.version "13.0" then + gcc12Stdenv + else + stdenv'; in let llvmNativeTarget = - if stdenv.hostPlatform.isx86_64 then "X86" - else if stdenv.hostPlatform.isAarch64 then "AArch64" - else throw "Unsupported ROCm LLVM platform"; + if stdenv.hostPlatform.isx86_64 then + "X86" + else if stdenv.hostPlatform.isAarch64 then + "AArch64" + else + throw "Unsupported ROCm LLVM platform"; inferNativeTarget = t: if t == "NATIVE" then llvmNativeTarget else t; llvmTargetsToBuild' = [ "AMDGPU" ] ++ builtins.map inferNativeTarget llvmTargetsToBuild; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "rocm-llvm-${targetName}"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ] ++ lib.optionals buildMan [ - "man" - "info" # Avoid `attribute 'info' missing` when using with wrapCC - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ] + ++ lib.optionals buildMan [ + "man" + "info" # Avoid `attribute 'info' missing` when using with wrapCC + ]; patches = extraPatches; @@ -81,19 +89,23 @@ in stdenv.mkDerivation (finalAttrs: { hash = "sha256-0+lJnDiMntxCYbZBCSWvHOcKXexFfEzRfb49QbfOmK8="; }; - nativeBuildInputs = [ - pkg-config - cmake - ninja - git - (python3Packages.python.withPackages (p: [ p.setuptools ])) - ] ++ lib.optionals (buildDocs || buildMan) [ - doxygen - sphinx - python3Packages.recommonmark - ] ++ lib.optionals (buildTests && !finalAttrs.passthru.isLLVM) [ - lit - ] ++ extraNativeBuildInputs; + nativeBuildInputs = + [ + pkg-config + cmake + ninja + git + (python3Packages.python.withPackages (p: [ p.setuptools ])) + ] + ++ lib.optionals (buildDocs || buildMan) [ + doxygen + sphinx + python3Packages.recommonmark + ] + ++ lib.optionals (buildTests && !finalAttrs.passthru.isLLVM) [ + lit + ] + ++ extraNativeBuildInputs; buildInputs = [ libxml2 @@ -110,46 +122,60 @@ in stdenv.mkDerivation (finalAttrs: { sourceRoot = "${finalAttrs.src.name}/${targetDir}"; - cmakeFlags = [ - "-DLLVM_TARGETS_TO_BUILD=${builtins.concatStringsSep ";" llvmTargetsToBuild'}" - ] ++ lib.optionals (finalAttrs.passthru.isLLVM && targetProjects != [ ]) [ - "-DLLVM_ENABLE_PROJECTS=${lib.concatStringsSep ";" targetProjects}" - ] ++ lib.optionals ((finalAttrs.passthru.isLLVM || targetDir == "runtimes") && targetRuntimes != [ ]) [ - "-DLLVM_ENABLE_RUNTIMES=${lib.concatStringsSep ";" targetRuntimes}" - ] ++ lib.optionals finalAttrs.passthru.isLLVM [ - "-DLLVM_INSTALL_UTILS=ON" - "-DLLVM_INSTALL_GTEST=ON" - ] ++ lib.optionals (buildDocs || buildMan) [ - "-DLLVM_INCLUDE_DOCS=ON" - "-DLLVM_BUILD_DOCS=ON" - # "-DLLVM_ENABLE_DOXYGEN=ON" Way too slow, only uses one core - "-DLLVM_ENABLE_SPHINX=ON" - "-DSPHINX_OUTPUT_HTML=ON" - "-DSPHINX_OUTPUT_MAN=ON" - "-DSPHINX_WARNINGS_AS_ERRORS=OFF" - ] ++ lib.optionals buildTests [ - "-DLLVM_INCLUDE_TESTS=ON" - "-DLLVM_BUILD_TESTS=ON" - "-DLLVM_EXTERNAL_LIT=${lit}/bin/.lit-wrapped" - ] ++ extraCMakeFlags; - - postPatch = lib.optionalString finalAttrs.passthru.isLLVM '' - patchShebangs lib/OffloadArch/make_generated_offload_arch_h.sh - '' + lib.optionalString (buildTests && finalAttrs.passthru.isLLVM) '' - # FileSystem permissions tests fail with various special bits - rm test/tools/llvm-objcopy/ELF/mirror-permissions-unix.test - rm unittests/Support/Path.cpp - - substituteInPlace unittests/Support/CMakeLists.txt \ - --replace "Path.cpp" "" - '' + extraPostPatch; + cmakeFlags = + [ + "-DLLVM_TARGETS_TO_BUILD=${builtins.concatStringsSep ";" llvmTargetsToBuild'}" + ] + ++ lib.optionals (finalAttrs.passthru.isLLVM && targetProjects != [ ]) [ + "-DLLVM_ENABLE_PROJECTS=${lib.concatStringsSep ";" targetProjects}" + ] + ++ + lib.optionals ((finalAttrs.passthru.isLLVM || targetDir == "runtimes") && targetRuntimes != [ ]) + [ + "-DLLVM_ENABLE_RUNTIMES=${lib.concatStringsSep ";" targetRuntimes}" + ] + ++ lib.optionals finalAttrs.passthru.isLLVM [ + "-DLLVM_INSTALL_UTILS=ON" + "-DLLVM_INSTALL_GTEST=ON" + ] + ++ lib.optionals (buildDocs || buildMan) [ + "-DLLVM_INCLUDE_DOCS=ON" + "-DLLVM_BUILD_DOCS=ON" + # "-DLLVM_ENABLE_DOXYGEN=ON" Way too slow, only uses one core + "-DLLVM_ENABLE_SPHINX=ON" + "-DSPHINX_OUTPUT_HTML=ON" + "-DSPHINX_OUTPUT_MAN=ON" + "-DSPHINX_WARNINGS_AS_ERRORS=OFF" + ] + ++ lib.optionals buildTests [ + "-DLLVM_INCLUDE_TESTS=ON" + "-DLLVM_BUILD_TESTS=ON" + "-DLLVM_EXTERNAL_LIT=${lit}/bin/.lit-wrapped" + ] + ++ extraCMakeFlags; + + postPatch = + lib.optionalString finalAttrs.passthru.isLLVM '' + patchShebangs lib/OffloadArch/make_generated_offload_arch_h.sh + '' + + lib.optionalString (buildTests && finalAttrs.passthru.isLLVM) '' + # FileSystem permissions tests fail with various special bits + rm test/tools/llvm-objcopy/ELF/mirror-permissions-unix.test + rm unittests/Support/Path.cpp + + substituteInPlace unittests/Support/CMakeLists.txt \ + --replace "Path.cpp" "" + '' + + extraPostPatch; doCheck = buildTests; checkTarget = lib.concatStringsSep " " checkTargets; - postInstall = lib.optionalString buildMan '' - mkdir -p $info - '' + extraPostInstall; + postInstall = + lib.optionalString buildMan '' + mkdir -p $info + '' + + extraPostInstall; passthru = { isLLVM = targetDir == "llvm"; @@ -168,7 +194,13 @@ in stdenv.mkDerivation (finalAttrs: { description = "ROCm fork of the LLVM compiler infrastructure"; homepage = "https://github.com/ROCm/llvm-project"; license = with licenses; [ ncsa ] ++ extraLicenses; - maintainers = with maintainers; [ acowley lovesegfault ] ++ teams.rocm.members; + maintainers = + with maintainers; + [ + acowley + lovesegfault + ] + ++ teams.rocm.members; platforms = platforms.linux; broken = isBroken || versionAtLeast finalAttrs.version "6.0.0"; }; diff --git a/pkgs/development/rocm-modules/5/llvm/default.nix b/pkgs/development/rocm-modules/5/llvm/default.nix index 9c8919165a516f..f68d29e37a19c4 100644 --- a/pkgs/development/rocm-modules/5/llvm/default.nix +++ b/pkgs/development/rocm-modules/5/llvm/default.nix @@ -1,58 +1,142 @@ -{ # stdenv FIXME: Try changing back to this with a new ROCm release https://github.com/NixOS/nixpkgs/issues/271943 - gcc12Stdenv -, callPackage -, rocmUpdateScript -, wrapBintoolsWith -, overrideCC -, rocm-device-libs -, rocm-runtime -, rocm-thunk -, clr +{ + # stdenv FIXME: Try changing back to this with a new ROCm release https://github.com/NixOS/nixpkgs/issues/271943 + gcc12Stdenv, + callPackage, + rocmUpdateScript, + wrapBintoolsWith, + overrideCC, + rocm-device-libs, + rocm-runtime, + rocm-thunk, + clr, }: let ## Stage 1 ## # Projects - llvm = callPackage ./stage-1/llvm.nix { inherit rocmUpdateScript; stdenv = gcc12Stdenv; }; - clang-unwrapped = callPackage ./stage-1/clang-unwrapped.nix { inherit rocmUpdateScript llvm; stdenv = gcc12Stdenv; }; - lld = callPackage ./stage-1/lld.nix { inherit rocmUpdateScript llvm; stdenv = gcc12Stdenv; }; + llvm = callPackage ./stage-1/llvm.nix { + inherit rocmUpdateScript; + stdenv = gcc12Stdenv; + }; + clang-unwrapped = callPackage ./stage-1/clang-unwrapped.nix { + inherit rocmUpdateScript llvm; + stdenv = gcc12Stdenv; + }; + lld = callPackage ./stage-1/lld.nix { + inherit rocmUpdateScript llvm; + stdenv = gcc12Stdenv; + }; # Runtimes - runtimes = callPackage ./stage-1/runtimes.nix { inherit rocmUpdateScript llvm; stdenv = gcc12Stdenv; }; + runtimes = callPackage ./stage-1/runtimes.nix { + inherit rocmUpdateScript llvm; + stdenv = gcc12Stdenv; + }; ## Stage 2 ## # Helpers bintools-unwrapped = callPackage ./stage-2/bintools-unwrapped.nix { inherit llvm lld; }; bintools = wrapBintoolsWith { bintools = bintools-unwrapped; }; - rStdenv = callPackage ./stage-2/rstdenv.nix { inherit llvm clang-unwrapped lld runtimes bintools; stdenv = gcc12Stdenv; }; -in rec { + rStdenv = callPackage ./stage-2/rstdenv.nix { + inherit + llvm + clang-unwrapped + lld + runtimes + bintools + ; + stdenv = gcc12Stdenv; + }; +in +rec { inherit - llvm - clang-unwrapped - lld - bintools; + llvm + clang-unwrapped + lld + bintools + ; # Runtimes - libc = callPackage ./stage-2/libc.nix { inherit rocmUpdateScript; stdenv = rStdenv; }; - libunwind = callPackage ./stage-2/libunwind.nix { inherit rocmUpdateScript; stdenv = rStdenv; }; - libcxxabi = callPackage ./stage-2/libcxxabi.nix { inherit rocmUpdateScript; stdenv = rStdenv; }; - libcxx = callPackage ./stage-2/libcxx.nix { inherit rocmUpdateScript; stdenv = rStdenv; }; - compiler-rt = callPackage ./stage-2/compiler-rt.nix { inherit rocmUpdateScript llvm; stdenv = rStdenv; }; + libc = callPackage ./stage-2/libc.nix { + inherit rocmUpdateScript; + stdenv = rStdenv; + }; + libunwind = callPackage ./stage-2/libunwind.nix { + inherit rocmUpdateScript; + stdenv = rStdenv; + }; + libcxxabi = callPackage ./stage-2/libcxxabi.nix { + inherit rocmUpdateScript; + stdenv = rStdenv; + }; + libcxx = callPackage ./stage-2/libcxx.nix { + inherit rocmUpdateScript; + stdenv = rStdenv; + }; + compiler-rt = callPackage ./stage-2/compiler-rt.nix { + inherit rocmUpdateScript llvm; + stdenv = rStdenv; + }; ## Stage 3 ## # Helpers - clang = callPackage ./stage-3/clang.nix { inherit llvm lld clang-unwrapped bintools libc libunwind libcxxabi libcxx compiler-rt; stdenv = gcc12Stdenv; }; + clang = callPackage ./stage-3/clang.nix { + inherit + llvm + lld + clang-unwrapped + bintools + libc + libunwind + libcxxabi + libcxx + compiler-rt + ; + stdenv = gcc12Stdenv; + }; rocmClangStdenv = overrideCC gcc12Stdenv clang; # Projects - clang-tools-extra = callPackage ./stage-3/clang-tools-extra.nix { inherit rocmUpdateScript llvm clang-unwrapped; stdenv = rocmClangStdenv; }; - libclc = callPackage ./stage-3/libclc.nix { inherit rocmUpdateScript llvm clang; stdenv = rocmClangStdenv; }; - lldb = callPackage ./stage-3/lldb.nix { inherit rocmUpdateScript clang; stdenv = rocmClangStdenv; }; - mlir = callPackage ./stage-3/mlir.nix { inherit rocmUpdateScript clr; stdenv = rocmClangStdenv; }; - polly = callPackage ./stage-3/polly.nix { inherit rocmUpdateScript; stdenv = rocmClangStdenv; }; - flang = callPackage ./stage-3/flang.nix { inherit rocmUpdateScript clang-unwrapped mlir; stdenv = rocmClangStdenv; }; - openmp = callPackage ./stage-3/openmp.nix { inherit rocmUpdateScript llvm clang-unwrapped clang rocm-device-libs rocm-runtime rocm-thunk; stdenv = rocmClangStdenv; }; + clang-tools-extra = callPackage ./stage-3/clang-tools-extra.nix { + inherit rocmUpdateScript llvm clang-unwrapped; + stdenv = rocmClangStdenv; + }; + libclc = callPackage ./stage-3/libclc.nix { + inherit rocmUpdateScript llvm clang; + stdenv = rocmClangStdenv; + }; + lldb = callPackage ./stage-3/lldb.nix { + inherit rocmUpdateScript clang; + stdenv = rocmClangStdenv; + }; + mlir = callPackage ./stage-3/mlir.nix { + inherit rocmUpdateScript clr; + stdenv = rocmClangStdenv; + }; + polly = callPackage ./stage-3/polly.nix { + inherit rocmUpdateScript; + stdenv = rocmClangStdenv; + }; + flang = callPackage ./stage-3/flang.nix { + inherit rocmUpdateScript clang-unwrapped mlir; + stdenv = rocmClangStdenv; + }; + openmp = callPackage ./stage-3/openmp.nix { + inherit + rocmUpdateScript + llvm + clang-unwrapped + clang + rocm-device-libs + rocm-runtime + rocm-thunk + ; + stdenv = rocmClangStdenv; + }; # Runtimes - pstl = callPackage ./stage-3/pstl.nix { inherit rocmUpdateScript; stdenv = rocmClangStdenv; }; + pstl = callPackage ./stage-3/pstl.nix { + inherit rocmUpdateScript; + stdenv = rocmClangStdenv; + }; } diff --git a/pkgs/development/rocm-modules/5/llvm/stage-1/clang-unwrapped.nix b/pkgs/development/rocm-modules/5/llvm/stage-1/clang-unwrapped.nix index 5a61732ffd2d40..4363521d880292 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-1/clang-unwrapped.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-1/clang-unwrapped.nix @@ -1,7 +1,8 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, llvm +{ + stdenv, + callPackage, + rocmUpdateScript, + llvm, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-1/lld.nix b/pkgs/development/rocm-modules/5/llvm/stage-1/lld.nix index 5ca8bca25a3385..6a6226a221e08b 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-1/lld.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-1/lld.nix @@ -1,7 +1,8 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, llvm +{ + stdenv, + callPackage, + rocmUpdateScript, + llvm, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-1/llvm.nix b/pkgs/development/rocm-modules/5/llvm/stage-1/llvm.nix index ad4981aa435be9..a9464da16697a2 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-1/llvm.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-1/llvm.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-1/runtimes.nix b/pkgs/development/rocm-modules/5/llvm/stage-1/runtimes.nix index 0364a02e6e59b4..268ad973b9134f 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-1/runtimes.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-1/runtimes.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, callPackage -, rocmUpdateScript -, llvm +{ + lib, + stdenv, + callPackage, + rocmUpdateScript, + llvm, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-2/bintools-unwrapped.nix b/pkgs/development/rocm-modules/5/llvm/stage-2/bintools-unwrapped.nix index ef40dd4d38246b..e17a913d4bb77d 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-2/bintools-unwrapped.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-2/bintools-unwrapped.nix @@ -1,6 +1,7 @@ -{ runCommand -, llvm -, lld +{ + runCommand, + llvm, + lld, }: runCommand "rocm-llvm-binutils-${llvm.version}" { preferLocalBuild = true; } '' diff --git a/pkgs/development/rocm-modules/5/llvm/stage-2/compiler-rt.nix b/pkgs/development/rocm-modules/5/llvm/stage-2/compiler-rt.nix index 3b8e41705e1a7b..f3b8648e11045b 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-2/compiler-rt.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-2/compiler-rt.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, callPackage -, rocmUpdateScript -, llvm -, glibc +{ + lib, + stdenv, + callPackage, + rocmUpdateScript, + llvm, + glibc, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-2/libc.nix b/pkgs/development/rocm-modules/5/llvm/stage-2/libc.nix index 7e7cf9c2a60886..e52e39276f15f5 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-2/libc.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-2/libc.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-2/libcxx.nix b/pkgs/development/rocm-modules/5/llvm/stage-2/libcxx.nix index 473227242765be..b9ed102d5408ad 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-2/libcxx.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-2/libcxx.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-2/libcxxabi.nix b/pkgs/development/rocm-modules/5/llvm/stage-2/libcxxabi.nix index e15ec777ff61a7..bc54e17be45fb0 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-2/libcxxabi.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-2/libcxxabi.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-2/libunwind.nix b/pkgs/development/rocm-modules/5/llvm/stage-2/libunwind.nix index 3d599e0d4b3250..fb5e7cb3b68ca8 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-2/libunwind.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-2/libunwind.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-2/rstdenv.nix b/pkgs/development/rocm-modules/5/llvm/stage-2/rstdenv.nix index 3820d45a2b814d..f83abe36cc2e28 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-2/rstdenv.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-2/rstdenv.nix @@ -1,11 +1,12 @@ -{ stdenv -, overrideCC -, wrapCCWith -, llvm -, clang-unwrapped -, lld -, runtimes -, bintools +{ + stdenv, + overrideCC, + wrapCCWith, + llvm, + clang-unwrapped, + lld, + runtimes, + bintools, }: overrideCC stdenv (wrapCCWith rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-3/clang-tools-extra.nix b/pkgs/development/rocm-modules/5/llvm/stage-3/clang-tools-extra.nix index d18673ecb3db4b..4351c4bc6629de 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-3/clang-tools-extra.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-3/clang-tools-extra.nix @@ -1,9 +1,10 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, llvm -, clang-unwrapped -, gtest +{ + stdenv, + callPackage, + rocmUpdateScript, + llvm, + clang-unwrapped, + gtest, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-3/clang.nix b/pkgs/development/rocm-modules/5/llvm/stage-3/clang.nix index 91f34265f85fa6..a0e4e79e4337aa 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-3/clang.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-3/clang.nix @@ -1,14 +1,15 @@ -{ stdenv -, wrapCCWith -, llvm -, lld -, clang-unwrapped -, bintools -, libc -, libunwind -, libcxxabi -, libcxx -, compiler-rt +{ + stdenv, + wrapCCWith, + llvm, + lld, + clang-unwrapped, + bintools, + libc, + libunwind, + libcxxabi, + libcxx, + compiler-rt, }: wrapCCWith rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-3/flang.nix b/pkgs/development/rocm-modules/5/llvm/stage-3/flang.nix index 421663dcb1b769..c6e72d56ce566e 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-3/flang.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-3/flang.nix @@ -1,10 +1,11 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, clang-unwrapped -, mlir -, graphviz -, python3Packages +{ + stdenv, + callPackage, + rocmUpdateScript, + clang-unwrapped, + mlir, + graphviz, + python3Packages, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-3/libclc.nix b/pkgs/development/rocm-modules/5/llvm/stage-3/libclc.nix index 1fd72ee67188f8..a00dbc29271750 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-3/libclc.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-3/libclc.nix @@ -1,14 +1,16 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, llvm -, clang -, spirv-llvm-translator +{ + stdenv, + callPackage, + rocmUpdateScript, + llvm, + clang, + spirv-llvm-translator, }: let spirv = (spirv-llvm-translator.override { inherit llvm; }); -in callPackage ../base.nix rec { +in +callPackage ../base.nix rec { inherit stdenv rocmUpdateScript; buildDocs = false; # No documentation to build buildMan = false; # No man pages to build diff --git a/pkgs/development/rocm-modules/5/llvm/stage-3/lldb.nix b/pkgs/development/rocm-modules/5/llvm/stage-3/lldb.nix index 9b7d25e06d9d68..31694ce50113f7 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-3/lldb.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-3/lldb.nix @@ -1,13 +1,14 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, clang -, xz -, swig -, lua5_3 -, graphviz -, gtest -, python3Packages +{ + stdenv, + callPackage, + rocmUpdateScript, + clang, + xz, + swig, + lua5_3, + graphviz, + gtest, + python3Packages, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-3/mlir.nix b/pkgs/development/rocm-modules/5/llvm/stage-3/mlir.nix index 11b9ae9ab5de69..e826d2a7a2b394 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-3/mlir.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-3/mlir.nix @@ -1,11 +1,12 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, clr -, vulkan-headers -, vulkan-loader -, glslang -, shaderc +{ + stdenv, + callPackage, + rocmUpdateScript, + clr, + vulkan-headers, + vulkan-loader, + glslang, + shaderc, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-3/openmp.nix b/pkgs/development/rocm-modules/5/llvm/stage-3/openmp.nix index 5fd7b6fd9aa3d0..25816610578092 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-3/openmp.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-3/openmp.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, callPackage -, rocmUpdateScript -, llvm -, clang -, clang-unwrapped -, rocm-device-libs -, rocm-runtime -, rocm-thunk -, perl -, elfutils -, libdrm -, numactl -, lit +{ + lib, + stdenv, + callPackage, + rocmUpdateScript, + llvm, + clang, + clang-unwrapped, + rocm-device-libs, + rocm-runtime, + rocm-thunk, + perl, + elfutils, + libdrm, + numactl, + lit, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-3/polly.nix b/pkgs/development/rocm-modules/5/llvm/stage-3/polly.nix index e001f33dfd4332..6347cfffbe2af3 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-3/polly.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-3/polly.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/llvm/stage-3/pstl.nix b/pkgs/development/rocm-modules/5/llvm/stage-3/pstl.nix index dc7d7cd6ccbfa1..63fba911677cc4 100644 --- a/pkgs/development/rocm-modules/5/llvm/stage-3/pstl.nix +++ b/pkgs/development/rocm-modules/5/llvm/stage-3/pstl.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/5/migraphx/default.nix b/pkgs/development/rocm-modules/5/migraphx/default.nix index 006a5ca9990b0e..1f060a1a8fd55d 100644 --- a/pkgs/development/rocm-modules/5/migraphx/default.nix +++ b/pkgs/development/rocm-modules/5/migraphx/default.nix @@ -1,62 +1,71 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, pkg-config -, cmake -, rocm-cmake -, clr -, clang-tools-extra -, openmp -, rocblas -, rocmlir -, composable_kernel -, miopengemm -, miopen -, protobuf -, half -, nlohmann_json -, msgpack -, sqlite -, oneDNN_2 -, blaze -, cppcheck -, rocm-device-libs -, texliveSmall -, doxygen -, sphinx -, docutils -, ghostscript -, python3Packages -, buildDocs ? false -, buildTests ? false +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + pkg-config, + cmake, + rocm-cmake, + clr, + clang-tools-extra, + openmp, + rocblas, + rocmlir, + composable_kernel, + miopengemm, + miopen, + protobuf, + half, + nlohmann_json, + msgpack, + sqlite, + oneDNN_2, + blaze, + cppcheck, + rocm-device-libs, + texliveSmall, + doxygen, + sphinx, + docutils, + ghostscript, + python3Packages, + buildDocs ? false, + buildTests ? false, }: let - latex = lib.optionalAttrs buildDocs (texliveSmall.withPackages (ps: with ps; [ - latexmk - tex-gyre - fncychap - wrapfig - capt-of - framed - needspace - tabulary - varwidth - titlesec - epstopdf - ])); -in stdenv.mkDerivation (finalAttrs: { + latex = lib.optionalAttrs buildDocs ( + texliveSmall.withPackages ( + ps: with ps; [ + latexmk + tex-gyre + fncychap + wrapfig + capt-of + framed + needspace + tabulary + varwidth + titlesec + epstopdf + ] + ) + ); +in +stdenv.mkDerivation (finalAttrs: { pname = "migraphx"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ] ++ lib.optionals buildTests [ - "test" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ] + ++ lib.optionals buildTests [ + "test" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -65,22 +74,24 @@ in stdenv.mkDerivation (finalAttrs: { hash = "sha256-lg3pxHBpwqxBvdOQgE44YKLuumhkVF6b3Xx4+cw7jNQ="; }; - nativeBuildInputs = [ - pkg-config - cmake - rocm-cmake - clr - clang-tools-extra - python3Packages.python - ] ++ lib.optionals buildDocs [ - latex - doxygen - sphinx - docutils - ghostscript - python3Packages.sphinx-rtd-theme - python3Packages.breathe - ]; + nativeBuildInputs = + [ + pkg-config + cmake + rocm-cmake + clr + clang-tools-extra + python3Packages.python + ] + ++ lib.optionals buildDocs [ + latex + doxygen + sphinx + docutils + ghostscript + python3Packages.sphinx-rtd-theme + python3Packages.breathe + ]; buildInputs = [ openmp @@ -113,28 +124,31 @@ in stdenv.mkDerivation (finalAttrs: { "-DCMAKE_INSTALL_INCLUDEDIR=include" ]; - postPatch = '' - # We need to not use hipcc and define the CXXFLAGS manually due to `undefined hidden symbol: tensorflow:: ...` - export CXXFLAGS+="--rocm-path=${clr} --rocm-device-lib-path=${rocm-device-libs}/amdgcn/bitcode" - patchShebangs tools + postPatch = + '' + # We need to not use hipcc and define the CXXFLAGS manually due to `undefined hidden symbol: tensorflow:: ...` + export CXXFLAGS+="--rocm-path=${clr} --rocm-device-lib-path=${rocm-device-libs}/amdgcn/bitcode" + patchShebangs tools - # `error: '__clang_hip_runtime_wrapper.h' file not found [clang-diagnostic-error]` - substituteInPlace CMakeLists.txt \ - --replace "set(MIGRAPHX_TIDY_ERRORS ALL)" "" + # `error: '__clang_hip_runtime_wrapper.h' file not found [clang-diagnostic-error]` + substituteInPlace CMakeLists.txt \ + --replace "set(MIGRAPHX_TIDY_ERRORS ALL)" "" - # JIT library was removed from composable_kernel... - # https://github.com/ROCm/composable_kernel/issues/782 - substituteInPlace src/targets/gpu/CMakeLists.txt \ - --replace " COMPONENTS jit_library" "" \ - --replace " composable_kernel::jit_library" "" \ - --replace "if(WIN32)" "if(TRUE)" - '' + lib.optionalString (!buildDocs) '' - substituteInPlace CMakeLists.txt \ - --replace "add_subdirectory(doc)" "" - '' + lib.optionalString (!buildTests) '' - substituteInPlace CMakeLists.txt \ - --replace "add_subdirectory(test)" "" - ''; + # JIT library was removed from composable_kernel... + # https://github.com/ROCm/composable_kernel/issues/782 + substituteInPlace src/targets/gpu/CMakeLists.txt \ + --replace " COMPONENTS jit_library" "" \ + --replace " composable_kernel::jit_library" "" \ + --replace "if(WIN32)" "if(TRUE)" + '' + + lib.optionalString (!buildDocs) '' + substituteInPlace CMakeLists.txt \ + --replace "add_subdirectory(doc)" "" + '' + + lib.optionalString (!buildTests) '' + substituteInPlace CMakeLists.txt \ + --replace "add_subdirectory(test)" "" + ''; # Unfortunately, it seems like we have to call make on this manually preInstall = lib.optionalString buildDocs '' @@ -145,14 +159,16 @@ in stdenv.mkDerivation (finalAttrs: { cd - ''; - postInstall = lib.optionalString buildDocs '' - mv ../doc/html $out/share/doc/migraphx - mv ../doc/pdf/MIGraphX.pdf $out/share/doc/migraphx - '' + lib.optionalString buildTests '' - mkdir -p $test/bin - mv bin/test_* $test/bin - patchelf $test/bin/test_* --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" - ''; + postInstall = + lib.optionalString buildDocs '' + mv ../doc/html $out/share/doc/migraphx + mv ../doc/pdf/MIGraphX.pdf $out/share/doc/migraphx + '' + + lib.optionalString buildTests '' + mkdir -p $test/bin + mv bin/test_* $test/bin + patchelf $test/bin/test_* --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -166,6 +182,8 @@ in stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/miopen/default.nix b/pkgs/development/rocm-modules/5/miopen/default.nix index 1c072ef1a304d3..b42450529ed210 100644 --- a/pkgs/development/rocm-modules/5/miopen/default.nix +++ b/pkgs/development/rocm-modules/5/miopen/default.nix @@ -1,37 +1,38 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, rocmUpdateScript -, runCommand -, pkg-config -, cmake -, rocm-cmake -, rocblas -, rocmlir -, clr -, clang-tools-extra -, clang-ocl -, miopengemm -, composable_kernel -, frugally-deep -, rocm-docs-core -, half -, boost -, sqlite -, bzip2 -, lbzip2 -, nlohmann_json -, texliveSmall -, doxygen -, sphinx -, zlib -, gtest -, rocm-comgr -, python3Packages -, buildDocs ? false # Needs internet because of rocm-docs-core -, buildTests ? false -, useOpenCL ? false +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + rocmUpdateScript, + runCommand, + pkg-config, + cmake, + rocm-cmake, + rocblas, + rocmlir, + clr, + clang-tools-extra, + clang-ocl, + miopengemm, + composable_kernel, + frugally-deep, + rocm-docs-core, + half, + boost, + sqlite, + bzip2, + lbzip2, + nlohmann_json, + texliveSmall, + doxygen, + sphinx, + zlib, + gtest, + rocm-comgr, + python3Packages, + buildDocs ? false, # Needs internet because of rocm-docs-core + buildTests ? false, + useOpenCL ? false, }: let @@ -71,18 +72,22 @@ let ''; }; - latex = lib.optionalAttrs buildDocs (texliveSmall.withPackages (ps: with ps; [ - latexmk - tex-gyre - fncychap - wrapfig - capt-of - framed - needspace - tabulary - varwidth - titlesec - ])); + latex = lib.optionalAttrs buildDocs ( + texliveSmall.withPackages ( + ps: with ps; [ + latexmk + tex-gyre + fncychap + wrapfig + capt-of + framed + needspace + tabulary + varwidth + titlesec + ] + ) + ); gfx900 = runCommand "miopen-gfx900.kdb" { preferLocalBuild = true; } '' ${lbzip2}/bin/lbzip2 -ckd ${src}/src/kernels/gfx900.kdb.bz2 > $out @@ -103,7 +108,8 @@ let gfx1030 = runCommand "miopen-gfx1030.kdb" { preferLocalBuild = true; } '' ${lbzip2}/bin/lbzip2 -ckd ${src}/src/kernels/gfx1030.kdb.bz2 > $out ''; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { inherit version src; pname = "miopen"; @@ -119,13 +125,16 @@ in stdenv.mkDerivation (finalAttrs: { }) ]; - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ] ++ lib.optionals buildTests [ - "test" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ] + ++ lib.optionals buildTests [ + "test" + ]; nativeBuildInputs = [ pkg-config @@ -135,50 +144,57 @@ in stdenv.mkDerivation (finalAttrs: { clang-tools-extra ]; - buildInputs = [ - rocblas - rocmlir - clang-ocl - miopengemm - composable_kernel - half - boost - sqlite - bzip2 - nlohmann_json - frugally-deep - ] ++ lib.optionals buildDocs [ - latex - doxygen - sphinx - rocm-docs-core - python3Packages.sphinx-rtd-theme - python3Packages.breathe - python3Packages.myst-parser - ] ++ lib.optionals buildTests [ - gtest - zlib - ]; + buildInputs = + [ + rocblas + rocmlir + clang-ocl + miopengemm + composable_kernel + half + boost + sqlite + bzip2 + nlohmann_json + frugally-deep + ] + ++ lib.optionals buildDocs [ + latex + doxygen + sphinx + rocm-docs-core + python3Packages.sphinx-rtd-theme + python3Packages.breathe + python3Packages.myst-parser + ] + ++ lib.optionals buildTests [ + gtest + zlib + ]; - cmakeFlags = [ - "-DCMAKE_CXX_FLAGS=-Wno-#warnings" # -> - "-DMIOPEN_USE_MIOPENGEMM=ON" - "-DUNZIPPER=${bzip2}/bin/bunzip2" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (!useOpenCL) [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-DMIOPEN_BACKEND=HIP" - ] ++ lib.optionals useOpenCL [ - "-DMIOPEN_BACKEND=OpenCL" - ] ++ lib.optionals buildTests [ - "-DBUILD_TESTS=ON" - "-DMIOPEN_TEST_ALL=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_FLAGS=-Wno-#warnings" # -> + "-DMIOPEN_USE_MIOPENGEMM=ON" + "-DUNZIPPER=${bzip2}/bin/bunzip2" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (!useOpenCL) [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-DMIOPEN_BACKEND=HIP" + ] + ++ lib.optionals useOpenCL [ + "-DMIOPEN_BACKEND=OpenCL" + ] + ++ lib.optionals buildTests [ + "-DBUILD_TESTS=ON" + "-DMIOPEN_TEST_ALL=ON" + ]; postPatch = '' patchShebangs test src/composable_kernel fin utils install_deps.cmake @@ -202,27 +218,39 @@ in stdenv.mkDerivation (finalAttrs: { ''; # Unfortunately, it seems like we have to call make on these manually - postBuild = lib.optionalString buildDocs '' - python -m sphinx -T -E -b html -d _build/doctrees -D language=en ../docs _build/html - '' + lib.optionalString buildTests '' - make -j$NIX_BUILD_CORES check - ''; + postBuild = + lib.optionalString buildDocs '' + python -m sphinx -T -E -b html -d _build/doctrees -D language=en ../docs _build/html + '' + + lib.optionalString buildTests '' + make -j$NIX_BUILD_CORES check + ''; - postInstall = '' - rm $out/bin/install_precompiled_kernels.sh - ln -sf ${gfx900} $out/share/miopen/db/gfx900.kdb - ln -sf ${gfx906} $out/share/miopen/db/gfx906.kdb - ln -sf ${gfx908} $out/share/miopen/db/gfx908.kdb - ln -sf ${gfx90a} $out/share/miopen/db/gfx90a.kdb - ln -sf ${gfx1030} $out/share/miopen/db/gfx1030.kdb - '' + lib.optionalString buildDocs '' - mv ../doc/html $out/share/doc/miopen-${if useOpenCL then "opencl" else "hip"} - '' + lib.optionalString buildTests '' - mkdir -p $test/bin - mv bin/test_* $test/bin - patchelf --set-rpath $out/lib:${lib.makeLibraryPath (finalAttrs.buildInputs ++ - [ clr rocm-comgr ])} $test/bin/* - ''; + postInstall = + '' + rm $out/bin/install_precompiled_kernels.sh + ln -sf ${gfx900} $out/share/miopen/db/gfx900.kdb + ln -sf ${gfx906} $out/share/miopen/db/gfx906.kdb + ln -sf ${gfx908} $out/share/miopen/db/gfx908.kdb + ln -sf ${gfx90a} $out/share/miopen/db/gfx90a.kdb + ln -sf ${gfx1030} $out/share/miopen/db/gfx1030.kdb + '' + + lib.optionalString buildDocs '' + mv ../doc/html $out/share/doc/miopen-${if useOpenCL then "opencl" else "hip"} + '' + + lib.optionalString buildTests '' + mkdir -p $test/bin + mv bin/test_* $test/bin + patchelf --set-rpath $out/lib:${ + lib.makeLibraryPath ( + finalAttrs.buildInputs + ++ [ + clr + rocm-comgr + ] + ) + } $test/bin/* + ''; requiredSystemFeatures = [ "big-parallel" ]; @@ -238,6 +266,8 @@ in stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/miopengemm/default.nix b/pkgs/development/rocm-modules/5/miopengemm/default.nix index c86a4f5b1edaff..24a7056b5a0b1e 100644 --- a/pkgs/development/rocm-modules/5/miopengemm/default.nix +++ b/pkgs/development/rocm-modules/5/miopengemm/default.nix @@ -1,47 +1,57 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, clblast -, texliveSmall -, doxygen -, sphinx -, openblas -, python3Packages -, buildDocs ? true -, buildTests ? false -, buildBenchmarks ? false +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + clblast, + texliveSmall, + doxygen, + sphinx, + openblas, + python3Packages, + buildDocs ? true, + buildTests ? false, + buildBenchmarks ? false, }: let - latex = lib.optionalAttrs buildDocs (texliveSmall.withPackages (ps: with ps; [ - latexmk - tex-gyre - fncychap - wrapfig - capt-of - framed - needspace - tabulary - varwidth - titlesec - ])); -in stdenv.mkDerivation (finalAttrs: { + latex = lib.optionalAttrs buildDocs ( + texliveSmall.withPackages ( + ps: with ps; [ + latexmk + tex-gyre + fncychap + wrapfig + capt-of + framed + needspace + tabulary + varwidth + titlesec + ] + ) + ); +in +stdenv.mkDerivation (finalAttrs: { pname = "miopengemm"; version = "5.5.0"; - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ]; # Deprecated? https://github.com/ROCmSoftwarePlatform/MIOpenGEMM/issues/62 src = fetchFromGitHub { @@ -57,55 +67,67 @@ in stdenv.mkDerivation (finalAttrs: { clr ]; - buildInputs = lib.optionals buildDocs [ - latex - doxygen - sphinx - python3Packages.sphinx-rtd-theme - python3Packages.breathe - ] ++ lib.optionals buildTests [ - openblas - ] ++ lib.optionals buildBenchmarks [ - clblast - python3Packages.triton - ]; + buildInputs = + lib.optionals buildDocs [ + latex + doxygen + sphinx + python3Packages.sphinx-rtd-theme + python3Packages.breathe + ] + ++ lib.optionals buildTests [ + openblas + ] + ++ lib.optionals buildBenchmarks [ + clblast + python3Packages.triton + ]; - cmakeFlags = [ - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals buildTests [ - "-DOPENBLAS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DAPI_BENCH_MIOGEMM=ON" - "-DAPI_BENCH_CLBLAST=ON" - "-DAPI_BENCH_ISAAC=ON" - ]; + cmakeFlags = + [ + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals buildTests [ + "-DOPENBLAS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DAPI_BENCH_MIOGEMM=ON" + "-DAPI_BENCH_CLBLAST=ON" + "-DAPI_BENCH_ISAAC=ON" + ]; # Unfortunately, it seems like we have to call make on these manually - postBuild = lib.optionalString buildDocs '' - export HOME=$(mktemp -d) - make doc - '' + lib.optionalString buildTests '' - make check - '' + lib.optionalString buildBenchmarks '' - make examples - ''; + postBuild = + lib.optionalString buildDocs '' + export HOME=$(mktemp -d) + make doc + '' + + lib.optionalString buildTests '' + make check + '' + + lib.optionalString buildBenchmarks '' + make examples + ''; - postInstall = lib.optionalString buildDocs '' - mv ../doc/html $out/share/doc/miopengemm - mv ../doc/pdf/miopengemm.pdf $out/share/doc/miopengemm - '' + lib.optionalString buildTests '' - mkdir -p $test/bin - find tests -executable -type f -exec mv {} $test/bin \; - patchelf --set-rpath ${lib.makeLibraryPath finalAttrs.buildInputs}:$out/lib $test/bin/* - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - find examples -executable -type f -exec mv {} $benchmark/bin \; - patchelf --set-rpath ${lib.makeLibraryPath finalAttrs.buildInputs}:$out/lib $benchmark/bin/* - ''; + postInstall = + lib.optionalString buildDocs '' + mv ../doc/html $out/share/doc/miopengemm + mv ../doc/pdf/miopengemm.pdf $out/share/doc/miopengemm + '' + + lib.optionalString buildTests '' + mkdir -p $test/bin + find tests -executable -type f -exec mv {} $test/bin \; + patchelf --set-rpath ${lib.makeLibraryPath finalAttrs.buildInputs}:$out/lib $test/bin/* + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + find examples -executable -type f -exec mv {} $benchmark/bin \; + patchelf --set-rpath ${lib.makeLibraryPath finalAttrs.buildInputs}:$out/lib $benchmark/bin/* + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -121,6 +143,8 @@ in stdenv.mkDerivation (finalAttrs: { platforms = platforms.linux; # They are not making tags or releases, this may break other derivations in the future # Use version major instead of minor, 6.0 will HOPEFULLY have a release or tag - broken = versions.major finalAttrs.version != versions.major stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.major finalAttrs.version != versions.major stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/mivisionx/default.nix b/pkgs/development/rocm-modules/5/mivisionx/default.nix index b7d9762869793a..9d8e57ae70022f 100644 --- a/pkgs/development/rocm-modules/5/mivisionx/default.nix +++ b/pkgs/development/rocm-modules/5/mivisionx/default.nix @@ -1,42 +1,48 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-device-libs -, clr -, pkg-config -, rpp -, rocblas -, miopengemm -, miopen -, migraphx -, clang -, openmp -, protobuf -, qtcreator -, opencv -, ffmpeg -, boost -, libjpeg_turbo -, half -, lmdb -, rapidjson -, rocm-docs-core -, python3Packages -, useOpenCL ? false -, useCPU ? false -, buildDocs ? false # Needs internet -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-device-libs, + clr, + pkg-config, + rpp, + rocblas, + miopengemm, + miopen, + migraphx, + clang, + openmp, + protobuf, + qtcreator, + opencv, + ffmpeg, + boost, + libjpeg_turbo, + half, + lmdb, + rapidjson, + rocm-docs-core, + python3Packages, + useOpenCL ? false, + useCPU ? false, + buildDocs ? false, # Needs internet + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { - pname = "mivisionx-" + ( - if (!useOpenCL && !useCPU) then "hip" - else if (!useOpenCL && !useCPU) then "opencl" - else "cpu" - ); + pname = + "mivisionx-" + + ( + if (!useOpenCL && !useCPU) then + "hip" + else if (!useOpenCL && !useCPU) then + "opencl" + else + "cpu" + ); version = "5.7.1"; @@ -51,15 +57,17 @@ stdenv.mkDerivation (finalAttrs: { ../../6/mivisionx/0001-set-__STDC_CONSTANT_MACROS-to-make-rocAL-compile.patch ]; - nativeBuildInputs = [ - cmake - rocm-cmake - clr - pkg-config - ] ++ lib.optionals buildDocs [ - rocm-docs-core - python3Packages.python - ]; + nativeBuildInputs = + [ + cmake + rocm-cmake + clr + pkg-config + ] + ++ lib.optionals buildDocs [ + rocm-docs-core + python3Packages.python + ]; buildInputs = [ miopengemm @@ -82,25 +90,30 @@ stdenv.mkDerivation (finalAttrs: { python3Packages.torchWithRocm ]; - cmakeFlags = [ - "-DROCM_PATH=${clr}" - "-DAMDRPP_PATH=${rpp}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - "-DCMAKE_INSTALL_PREFIX_PYTHON=lib" - # "-DAMD_FP16_SUPPORT=ON" `error: typedef redefinition with different types ('__half' vs 'half_float::half')` - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals (!useOpenCL && !useCPU) [ - "-DBACKEND=HIP" - ] ++ lib.optionals (useOpenCL && !useCPU) [ - "-DBACKEND=OCL" - ] ++ lib.optionals useCPU [ - "-DBACKEND=CPU" - ]; + cmakeFlags = + [ + "-DROCM_PATH=${clr}" + "-DAMDRPP_PATH=${rpp}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + "-DCMAKE_INSTALL_PREFIX_PYTHON=lib" + # "-DAMD_FP16_SUPPORT=ON" `error: typedef redefinition with different types ('__half' vs 'half_float::half')` + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals (!useOpenCL && !useCPU) [ + "-DBACKEND=HIP" + ] + ++ lib.optionals (useOpenCL && !useCPU) [ + "-DBACKEND=OCL" + ] + ++ lib.optionals useCPU [ + "-DBACKEND=CPU" + ]; postPatch = '' # We need to not use hipcc and define the CXXFLAGS manually due to `undefined hidden symbol: tensorflow:: ...` @@ -144,6 +157,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rccl/default.nix b/pkgs/development/rocm-modules/5/rccl/default.nix index b80b96ac403a76..ecb9ed461c2b42 100644 --- a/pkgs/development/rocm-modules/5/rccl/default.nix +++ b/pkgs/development/rocm-modules/5/rccl/default.nix @@ -1,28 +1,31 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-smi -, clr -, perl -, hipify -, gtest -, chrpath -, buildTests ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-smi, + clr, + perl, + hipify, + gtest, + chrpath, + buildTests ? false, + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { pname = "rccl"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -39,26 +42,31 @@ stdenv.mkDerivation (finalAttrs: { hipify ]; - buildInputs = [ - rocm-smi - gtest - ] ++ lib.optionals buildTests [ - chrpath - ]; + buildInputs = + [ + rocm-smi + gtest + ] + ++ lib.optionals buildTests [ + chrpath + ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - "-DBUILD_BFD=OFF" # Can't get it to detect bfd.h - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_TESTS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + "-DBUILD_BFD=OFF" # Can't get it to detect bfd.h + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_TESTS=ON" + ]; postPatch = '' patchShebangs src tools @@ -83,9 +91,14 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "ROCm communication collectives library"; homepage = "https://github.com/ROCm/rccl"; - license = with licenses; [ bsd2 bsd3 ]; + license = with licenses; [ + bsd2 + bsd3 + ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rdc/default.nix b/pkgs/development/rocm-modules/5/rdc/default.nix index 3ef5a200ea1a52..7c8b26f16cf793 100644 --- a/pkgs/development/rocm-modules/5/rdc/default.nix +++ b/pkgs/development/rocm-modules/5/rdc/default.nix @@ -1,54 +1,63 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-smi -, rocm-runtime -, libcap -, grpc -, protobuf -, openssl -, doxygen -, graphviz -, texliveSmall -, gtest -, buildDocs ? true -, buildTests ? false +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-smi, + rocm-runtime, + libcap, + grpc, + protobuf, + openssl, + doxygen, + graphviz, + texliveSmall, + gtest, + buildDocs ? true, + buildTests ? false, }: let - latex = lib.optionalAttrs buildDocs (texliveSmall.withPackages (ps: with ps; [ - changepage - latexmk - varwidth - multirow - hanging - adjustbox - collectbox - stackengine - enumitem - alphalph - wasysym - sectsty - tocloft - newunicodechar - etoc - helvetic - wasy - courier - ])); -in stdenv.mkDerivation (finalAttrs: { + latex = lib.optionalAttrs buildDocs ( + texliveSmall.withPackages ( + ps: with ps; [ + changepage + latexmk + varwidth + multirow + hanging + adjustbox + collectbox + stackengine + enumitem + alphalph + wasysym + sectsty + tocloft + newunicodechar + etoc + helvetic + wasy + courier + ] + ) + ); +in +stdenv.mkDerivation (finalAttrs: { pname = "rdc"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ] ++ lib.optionals buildTests [ - "test" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ] + ++ lib.optionals buildTests [ + "test" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -57,55 +66,63 @@ in stdenv.mkDerivation (finalAttrs: { hash = "sha256-xZD/WI/LfNtKK9j6ZjuU0OTTFZz3G4atyD5mVcSsQ8A="; }; - nativeBuildInputs = [ - cmake - protobuf - ] ++ lib.optionals buildDocs [ - doxygen - graphviz - latex - ]; + nativeBuildInputs = + [ + cmake + protobuf + ] + ++ lib.optionals buildDocs [ + doxygen + graphviz + latex + ]; - buildInputs = [ - rocm-smi - rocm-runtime - libcap - grpc - openssl - ] ++ lib.optionals buildTests [ - gtest - ]; + buildInputs = + [ + rocm-smi + rocm-runtime + libcap + grpc + openssl + ] + ++ lib.optionals buildTests [ + gtest + ]; - cmakeFlags = [ - "-DCMAKE_VERBOSE_MAKEFILE=OFF" - "-DRDC_INSTALL_PREFIX=${placeholder "out"}" - "-DBUILD_ROCRTEST=ON" - "-DRSMI_INC_DIR=${rocm-smi}/include" - "-DRSMI_LIB_DIR=${rocm-smi}/lib" - "-DGRPC_ROOT=${grpc}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - "-DCMAKE_INSTALL_LIBEXECDIR=libexec" - "-DCMAKE_INSTALL_DOCDIR=doc" - ] ++ lib.optionals buildTests [ - "-DBUILD_TESTS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_VERBOSE_MAKEFILE=OFF" + "-DRDC_INSTALL_PREFIX=${placeholder "out"}" + "-DBUILD_ROCRTEST=ON" + "-DRSMI_INC_DIR=${rocm-smi}/include" + "-DRSMI_LIB_DIR=${rocm-smi}/lib" + "-DGRPC_ROOT=${grpc}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + "-DCMAKE_INSTALL_LIBEXECDIR=libexec" + "-DCMAKE_INSTALL_DOCDIR=doc" + ] + ++ lib.optionals buildTests [ + "-DBUILD_TESTS=ON" + ]; postPatch = '' substituteInPlace CMakeLists.txt \ --replace "file(STRINGS /etc/os-release LINUX_DISTRO LIMIT_COUNT 1 REGEX \"NAME=\")" "set(LINUX_DISTRO \"NixOS\")" ''; - postInstall = '' - find $out/bin -executable -type f -exec \ - patchelf {} --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" \; - '' + lib.optionalString buildTests '' - mkdir -p $test - mv $out/bin/rdctst_tests $test/bin - ''; + postInstall = + '' + find $out/bin -executable -type f -exec \ + patchelf {} --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" \; + '' + + lib.optionalString buildTests '' + mkdir -p $test + mv $out/bin/rdctst_tests $test/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; diff --git a/pkgs/development/rocm-modules/5/rocalution/default.nix b/pkgs/development/rocm-modules/5/rocalution/default.nix index 11f52ea1318c58..e4d1cf7f59b869 100644 --- a/pkgs/development/rocm-modules/5/rocalution/default.nix +++ b/pkgs/development/rocm-modules/5/rocalution/default.nix @@ -1,37 +1,42 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocblas -, rocsparse -, rocprim -, rocrand -, clr -, git -, openmp -, openmpi -, gtest -, buildTests ? false -, buildBenchmarks ? false -, buildSamples ? false -, gpuTargets ? [ ] # gpuTargets = [ "gfx803" "gfx900:xnack-" "gfx906:xnack-" ... ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocblas, + rocsparse, + rocprim, + rocrand, + clr, + git, + openmp, + openmpi, + gtest, + buildTests ? false, + buildBenchmarks ? false, + buildSamples ? false, + gpuTargets ? [ ], # gpuTargets = [ "gfx803" "gfx900:xnack-" "gfx906:xnack-" ... ] }: stdenv.mkDerivation (finalAttrs: { pname = "rocalution"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ] ++ lib.optionals buildSamples [ - "sample" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ] + ++ lib.optionals buildSamples [ + "sample" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -47,56 +52,66 @@ stdenv.mkDerivation (finalAttrs: { git ]; - buildInputs = [ - rocblas - rocsparse - rocprim - rocrand - openmp - openmpi - ] ++ lib.optionals buildTests [ - gtest - ]; + buildInputs = + [ + rocblas + rocsparse + rocprim + rocrand + openmp + openmpi + ] + ++ lib.optionals buildTests [ + gtest + ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - "-DROCM_PATH=${clr}" - "-DHIP_ROOT_DIR=${clr}" - "-DSUPPORT_HIP=ON" - "-DSUPPORT_OMP=ON" - "-DSUPPORT_MPI=ON" - "-DBUILD_CLIENTS_SAMPLES=${if buildSamples then "ON" else "OFF"}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.strings.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_BENCHMARKS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + "-DROCM_PATH=${clr}" + "-DHIP_ROOT_DIR=${clr}" + "-DSUPPORT_HIP=ON" + "-DSUPPORT_OMP=ON" + "-DSUPPORT_MPI=ON" + "-DBUILD_CLIENTS_SAMPLES=${if buildSamples then "ON" else "OFF"}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.strings.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_BENCHMARKS=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/rocalution-test $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/rocalution-bench $benchmark/bin - '' + lib.optionalString buildSamples '' - mkdir -p $sample/bin - mv clients/staging/* $sample/bin - rm $sample/bin/rocalution-test || true - rm $sample/bin/rocalution-bench || true + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/rocalution-test $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/rocalution-bench $benchmark/bin + '' + + lib.optionalString buildSamples '' + mkdir -p $sample/bin + mv clients/staging/* $sample/bin + rm $sample/bin/rocalution-test || true + rm $sample/bin/rocalution-bench || true - patchelf --set-rpath \ - $out/lib:${lib.makeLibraryPath (finalAttrs.buildInputs ++ [ clr ])} \ - $sample/bin/* - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rmdir $out/bin - ''; + patchelf --set-rpath \ + $out/lib:${lib.makeLibraryPath (finalAttrs.buildInputs ++ [ clr ])} \ + $sample/bin/* + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -110,6 +125,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocblas/default.nix b/pkgs/development/rocm-modules/5/rocblas/default.nix index 187775e25a6518..baedf04b14511a 100644 --- a/pkgs/development/rocm-modules/5/rocblas/default.nix +++ b/pkgs/development/rocm-modules/5/rocblas/default.nix @@ -1,86 +1,101 @@ -{ rocblas -, lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, python3 -, tensile -, msgpack -, libxml2 -, gtest -, gfortran -, openmp -, amd-blis -, python3Packages -, buildTensile ? true -, buildTests ? false -, buildBenchmarks ? false -, tensileLogic ? "asm_full" -, tensileCOVersion ? "default" -, tensileSepArch ? true -, tensileLazyLib ? true -, tensileLibFormat ? "msgpack" -, gpuTargets ? [ "all" ] +{ + rocblas, + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + python3, + tensile, + msgpack, + libxml2, + gtest, + gfortran, + openmp, + amd-blis, + python3Packages, + buildTensile ? true, + buildTests ? false, + buildBenchmarks ? false, + tensileLogic ? "asm_full", + tensileCOVersion ? "default", + tensileSepArch ? true, + tensileLazyLib ? true, + tensileLibFormat ? "msgpack", + gpuTargets ? [ "all" ], }: let # NOTE: Update the default GPU targets on every update - gfx80 = (rocblas.override { - gpuTargets = [ - "gfx803" - ]; - }).overrideAttrs { pname = "rocblas-tensile-gfx80"; }; - - gfx90 = (rocblas.override { - gpuTargets = [ - "gfx900" - "gfx906:xnack-" - "gfx908:xnack-" - "gfx90a:xnack+" - "gfx90a:xnack-" - ]; - }).overrideAttrs { pname = "rocblas-tensile-gfx90"; }; - - gfx94 = (rocblas.override { - gpuTargets = [ - "gfx940" - "gfx941" - "gfx942" - ]; - }).overrideAttrs { pname = "rocblas-tensile-gfx94"; }; - - gfx10 = (rocblas.override { - gpuTargets = [ - "gfx1010" - "gfx1012" - "gfx1030" - ]; - }).overrideAttrs { pname = "rocblas-tensile-gfx10"; }; - - gfx11 = (rocblas.override { - gpuTargets = [ - "gfx1100" - "gfx1101" - "gfx1102" - ]; - }).overrideAttrs { pname = "rocblas-tensile-gfx11"; }; + gfx80 = + (rocblas.override { + gpuTargets = [ + "gfx803" + ]; + }).overrideAttrs + { pname = "rocblas-tensile-gfx80"; }; + + gfx90 = + (rocblas.override { + gpuTargets = [ + "gfx900" + "gfx906:xnack-" + "gfx908:xnack-" + "gfx90a:xnack+" + "gfx90a:xnack-" + ]; + }).overrideAttrs + { pname = "rocblas-tensile-gfx90"; }; + + gfx94 = + (rocblas.override { + gpuTargets = [ + "gfx940" + "gfx941" + "gfx942" + ]; + }).overrideAttrs + { pname = "rocblas-tensile-gfx94"; }; + + gfx10 = + (rocblas.override { + gpuTargets = [ + "gfx1010" + "gfx1012" + "gfx1030" + ]; + }).overrideAttrs + { pname = "rocblas-tensile-gfx10"; }; + + gfx11 = + (rocblas.override { + gpuTargets = [ + "gfx1100" + "gfx1101" + "gfx1102" + ]; + }).overrideAttrs + { pname = "rocblas-tensile-gfx11"; }; # Unfortunately, we have to do two full builds, otherwise we get overlapping _fallback.dat files fallbacks = rocblas.overrideAttrs { pname = "rocblas-tensile-fallbacks"; }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "rocblas"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -95,99 +110,122 @@ in stdenv.mkDerivation (finalAttrs: { clr ]; - buildInputs = [ - python3 - ] ++ lib.optionals buildTensile [ - msgpack - libxml2 - python3Packages.msgpack - python3Packages.joblib - ] ++ lib.optionals buildTests [ - gtest - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - gfortran - openmp - amd-blis - ] ++ lib.optionals (buildTensile || buildTests || buildBenchmarks) [ - python3Packages.pyyaml - ]; + buildInputs = + [ + python3 + ] + ++ lib.optionals buildTensile [ + msgpack + libxml2 + python3Packages.msgpack + python3Packages.joblib + ] + ++ lib.optionals buildTests [ + gtest + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + gfortran + openmp + amd-blis + ] + ++ lib.optionals (buildTensile || buildTests || buildBenchmarks) [ + python3Packages.pyyaml + ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-Dpython=python3" - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - "-DBUILD_WITH_TENSILE=${if buildTensile then "ON" else "OFF"}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals buildTensile [ - "-DVIRTUALENV_HOME_DIR=/build/source/tensile" - "-DTensile_TEST_LOCAL_PATH=/build/source/tensile" - "-DTensile_ROOT=/build/source/tensile/${python3.sitePackages}/Tensile" - "-DTensile_LOGIC=${tensileLogic}" - "-DTensile_CODE_OBJECT_VERSION=${tensileCOVersion}" - "-DTensile_SEPARATE_ARCHITECTURES=${if tensileSepArch then "ON" else "OFF"}" - "-DTensile_LAZY_LIBRARY_LOADING=${if tensileLazyLib then "ON" else "OFF"}" - "-DTensile_LIBRARY_FORMAT=${tensileLibFormat}" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_BENCHMARKS=ON" - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - "-DCMAKE_CXX_FLAGS=-I${amd-blis}/include/blis" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-Dpython=python3" + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + "-DBUILD_WITH_TENSILE=${if buildTensile then "ON" else "OFF"}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals buildTensile [ + "-DVIRTUALENV_HOME_DIR=/build/source/tensile" + "-DTensile_TEST_LOCAL_PATH=/build/source/tensile" + "-DTensile_ROOT=/build/source/tensile/${python3.sitePackages}/Tensile" + "-DTensile_LOGIC=${tensileLogic}" + "-DTensile_CODE_OBJECT_VERSION=${tensileCOVersion}" + "-DTensile_SEPARATE_ARCHITECTURES=${if tensileSepArch then "ON" else "OFF"}" + "-DTensile_LAZY_LIBRARY_LOADING=${if tensileLazyLib then "ON" else "OFF"}" + "-DTensile_LIBRARY_FORMAT=${tensileLibFormat}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_BENCHMARKS=ON" + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + "-DCMAKE_CXX_FLAGS=-I${amd-blis}/include/blis" + ]; - postPatch = lib.optionalString (finalAttrs.pname != "rocblas") '' - # Return early and install tensile files manually - substituteInPlace library/src/CMakeLists.txt \ - --replace "set_target_properties( TensileHost PROPERTIES OUTPUT_NAME" "return()''\nset_target_properties( TensileHost PROPERTIES OUTPUT_NAME" - '' + lib.optionalString (buildTensile && finalAttrs.pname == "rocblas") '' - # Link the prebuilt Tensile files - mkdir -p build/Tensile/library - - for path in ${gfx80} ${gfx90} ${gfx94} ${gfx10} ${gfx11} ${fallbacks}; do - ln -s $path/lib/rocblas/library/* build/Tensile/library - done - - unlink build/Tensile/library/TensileManifest.txt - '' + lib.optionalString buildTensile '' - # Tensile REALLY wants to write to the nix directory if we include it normally - cp -a ${tensile} tensile - chmod +w -R tensile - - # Rewrap Tensile - substituteInPlace tensile/bin/{.t*,.T*,*} \ - --replace "${tensile}" "/build/source/tensile" - - substituteInPlace CMakeLists.txt \ - --replace "include(virtualenv)" "" \ - --replace "virtualenv_install(\''${Tensile_TEST_LOCAL_PATH})" "" - ''; - - postInstall = lib.optionalString (finalAttrs.pname == "rocblas") '' - ln -sf ${fallbacks}/lib/rocblas/library/TensileManifest.txt $out/lib/rocblas/library - '' + lib.optionalString (finalAttrs.pname != "rocblas") '' - mkdir -p $out/lib/rocblas/library - rm -rf $out/share - '' + lib.optionalString (finalAttrs.pname != "rocblas" && finalAttrs.pname != "rocblas-tensile-fallbacks") '' - rm Tensile/library/{TensileManifest.txt,*_fallback.dat} - mv Tensile/library/* $out/lib/rocblas/library - '' + lib.optionalString (finalAttrs.pname == "rocblas-tensile-fallbacks") '' - mv Tensile/library/{TensileManifest.txt,*_fallback.dat} $out/lib/rocblas/library - '' + lib.optionalString buildTests '' - mkdir -p $test/bin - cp -a $out/bin/* $test/bin - rm $test/bin/*-bench || true - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - cp -a $out/bin/* $benchmark/bin - rm $benchmark/bin/*-test || true - '' + lib.optionalString (buildTests || buildBenchmarks ) '' - rm -rf $out/bin - ''; + postPatch = + lib.optionalString (finalAttrs.pname != "rocblas") '' + # Return early and install tensile files manually + substituteInPlace library/src/CMakeLists.txt \ + --replace "set_target_properties( TensileHost PROPERTIES OUTPUT_NAME" "return()''\nset_target_properties( TensileHost PROPERTIES OUTPUT_NAME" + '' + + lib.optionalString (buildTensile && finalAttrs.pname == "rocblas") '' + # Link the prebuilt Tensile files + mkdir -p build/Tensile/library + + for path in ${gfx80} ${gfx90} ${gfx94} ${gfx10} ${gfx11} ${fallbacks}; do + ln -s $path/lib/rocblas/library/* build/Tensile/library + done + + unlink build/Tensile/library/TensileManifest.txt + '' + + lib.optionalString buildTensile '' + # Tensile REALLY wants to write to the nix directory if we include it normally + cp -a ${tensile} tensile + chmod +w -R tensile + + # Rewrap Tensile + substituteInPlace tensile/bin/{.t*,.T*,*} \ + --replace "${tensile}" "/build/source/tensile" + + substituteInPlace CMakeLists.txt \ + --replace "include(virtualenv)" "" \ + --replace "virtualenv_install(\''${Tensile_TEST_LOCAL_PATH})" "" + ''; + + postInstall = + lib.optionalString (finalAttrs.pname == "rocblas") '' + ln -sf ${fallbacks}/lib/rocblas/library/TensileManifest.txt $out/lib/rocblas/library + '' + + lib.optionalString (finalAttrs.pname != "rocblas") '' + mkdir -p $out/lib/rocblas/library + rm -rf $out/share + '' + + + lib.optionalString + (finalAttrs.pname != "rocblas" && finalAttrs.pname != "rocblas-tensile-fallbacks") + '' + rm Tensile/library/{TensileManifest.txt,*_fallback.dat} + mv Tensile/library/* $out/lib/rocblas/library + '' + + lib.optionalString (finalAttrs.pname == "rocblas-tensile-fallbacks") '' + mv Tensile/library/{TensileManifest.txt,*_fallback.dat} $out/lib/rocblas/library + '' + + lib.optionalString buildTests '' + mkdir -p $test/bin + cp -a $out/bin/* $test/bin + rm $test/bin/*-bench || true + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + cp -a $out/bin/* $benchmark/bin + rm $benchmark/bin/*-test || true + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rm -rf $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -203,6 +241,8 @@ in stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocdbgapi/default.nix b/pkgs/development/rocm-modules/5/rocdbgapi/default.nix index fd6797d0d43b40..dddab5997bafc3 100644 --- a/pkgs/development/rocm-modules/5/rocdbgapi/default.nix +++ b/pkgs/development/rocm-modules/5/rocdbgapi/default.nix @@ -1,49 +1,57 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, git -, rocm-comgr -, rocm-runtime -, hwdata -, texliveSmall -, doxygen -, graphviz -, buildDocs ? true +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + git, + rocm-comgr, + rocm-runtime, + hwdata, + texliveSmall, + doxygen, + graphviz, + buildDocs ? true, }: let - latex = lib.optionalAttrs buildDocs (texliveSmall.withPackages (ps: with ps; [ - changepage - latexmk - varwidth - multirow - hanging - adjustbox - collectbox - stackengine - enumitem - alphalph - wasysym - sectsty - tocloft - newunicodechar - etoc - helvetic - wasy - courier - ])); -in stdenv.mkDerivation (finalAttrs: { + latex = lib.optionalAttrs buildDocs ( + texliveSmall.withPackages ( + ps: with ps; [ + changepage + latexmk + varwidth + multirow + hanging + adjustbox + collectbox + stackengine + enumitem + alphalph + wasysym + sectsty + tocloft + newunicodechar + etoc + helvetic + wasy + courier + ] + ) + ); +in +stdenv.mkDerivation (finalAttrs: { pname = "rocdbgapi"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -52,15 +60,17 @@ in stdenv.mkDerivation (finalAttrs: { hash = "sha256-qMXvgcS61lgcylz62ErYq8fhpYIR31skQEeKUryuP1w="; }; - nativeBuildInputs = [ - cmake - rocm-cmake - git - ] ++ lib.optionals buildDocs [ - latex - doxygen - graphviz - ]; + nativeBuildInputs = + [ + cmake + rocm-cmake + git + ] + ++ lib.optionals buildDocs [ + latex + doxygen + graphviz + ]; buildInputs = [ rocm-comgr @@ -83,16 +93,18 @@ in stdenv.mkDerivation (finalAttrs: { make -j$NIX_BUILD_CORES doc ''; - postInstall = '' - substituteInPlace $out/lib/cmake/amd-dbgapi/amd-dbgapi-config.cmake \ - --replace "/build/source/build/" "" + postInstall = + '' + substituteInPlace $out/lib/cmake/amd-dbgapi/amd-dbgapi-config.cmake \ + --replace "/build/source/build/" "" - substituteInPlace $out/lib/cmake/amd-dbgapi/amd-dbgapi-targets.cmake \ - --replace "/build/source/build" "$out" - '' + lib.optionalString buildDocs '' - mv $out/share/html/amd-dbgapi $doc/share/doc/amd-dbgapi/html - rmdir $out/share/html - ''; + substituteInPlace $out/lib/cmake/amd-dbgapi/amd-dbgapi-targets.cmake \ + --replace "/build/source/build" "$out" + '' + + lib.optionalString buildDocs '' + mv $out/share/html/amd-dbgapi $doc/share/doc/amd-dbgapi/html + rmdir $out/share/html + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -106,6 +118,8 @@ in stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocfft/default.nix b/pkgs/development/rocm-modules/5/rocfft/default.nix index 48f3264d157f3b..d7a0d0e81ba87a 100644 --- a/pkgs/development/rocm-modules/5/rocfft/default.nix +++ b/pkgs/development/rocm-modules/5/rocfft/default.nix @@ -1,20 +1,21 @@ -{ rocfft -, lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, clr -, python3 -, rocm-cmake -, sqlite -, boost -, fftw -, fftwFloat -, gtest -, openmp -, rocrand -, gpuTargets ? [ ] +{ + rocfft, + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + clr, + python3, + rocm-cmake, + sqlite, + boost, + fftw, + fftwFloat, + gtest, + openmp, + rocrand, + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { @@ -37,18 +38,20 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ sqlite ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-DSQLITE_USE_SYSTEM_PACKAGE=ON" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-DSQLITE_USE_SYSTEM_PACKAGE=ON" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ]; passthru = { test = stdenv.mkDerivation { @@ -100,10 +103,12 @@ stdenv.mkDerivation (finalAttrs: { boost finalAttrs.finalPackage openmp - (python3.withPackages (ps: with ps; [ - pandas - scipy - ])) + (python3.withPackages ( + ps: with ps; [ + pandas + scipy + ] + )) rocrand ]; @@ -164,6 +169,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = with maintainers; [ kira-bruneau ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocgdb/default.nix b/pkgs/development/rocm-modules/5/rocgdb/default.nix index a02ad3f9e8f2d9..7a289dbae38e53 100644 --- a/pkgs/development/rocm-modules/5/rocgdb/default.nix +++ b/pkgs/development/rocm-modules/5/rocgdb/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, pkg-config -, texinfo -, bison -, flex -, zlib -, elfutils -, gmp -, ncurses -, expat +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + pkg-config, + texinfo, + bison, + flex, + zlib, + elfutils, + gmp, + ncurses, + expat, }: stdenv.mkDerivation (finalAttrs: { @@ -51,7 +52,11 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "ROCm source-level debugger for Linux, based on GDB"; homepage = "https://github.com/ROCm/ROCgdb"; - license = with licenses; [ gpl2 gpl3 bsd3 ]; + license = with licenses; [ + gpl2 + gpl3 + bsd3 + ]; maintainers = teams.rocm.members; platforms = platforms.linux; broken = versionAtLeast finalAttrs.version "6.0.0"; diff --git a/pkgs/development/rocm-modules/5/rocm-cmake/default.nix b/pkgs/development/rocm-modules/5/rocm-cmake/default.nix index c0d7e48ff59f34..009dcf6f0d6c1e 100644 --- a/pkgs/development/rocm-modules/5/rocm-cmake/default.nix +++ b/pkgs/development/rocm-modules/5/rocm-cmake/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -30,6 +31,8 @@ stdenv.mkDerivation (finalAttrs: { license = licenses.mit; maintainers = teams.rocm.members; platforms = platforms.unix; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocm-comgr/default.nix b/pkgs/development/rocm-modules/5/rocm-comgr/default.nix index ab43edf8a4b998..d54b8488850242 100644 --- a/pkgs/development/rocm-modules/5/rocm-comgr/default.nix +++ b/pkgs/development/rocm-modules/5/rocm-comgr/default.nix @@ -1,19 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-device-libs -, libxml2 +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-device-libs, + libxml2, }: let llvmNativeTarget = - if stdenv.hostPlatform.isx86_64 then "X86" - else if stdenv.hostPlatform.isAarch64 then "AArch64" - else throw "Unsupported ROCm LLVM platform"; -in stdenv.mkDerivation (finalAttrs: { + if stdenv.hostPlatform.isx86_64 then + "X86" + else if stdenv.hostPlatform.isAarch64 then + "AArch64" + else + throw "Unsupported ROCm LLVM platform"; +in +stdenv.mkDerivation (finalAttrs: { pname = "rocm-comgr"; version = "5.7.1"; @@ -50,6 +55,8 @@ in stdenv.mkDerivation (finalAttrs: { license = licenses.ncsa; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocm-core/default.nix b/pkgs/development/rocm-modules/5/rocm-core/default.nix index c96bfeb0d2952e..bd11a416bc9154 100644 --- a/pkgs/development/rocm-modules/5/rocm-core/default.nix +++ b/pkgs/development/rocm-modules/5/rocm-core/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -33,6 +34,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocm-device-libs/default.nix b/pkgs/development/rocm-modules/5/rocm-device-libs/default.nix index 3e769421548b74..52342c23121ed1 100644 --- a/pkgs/development/rocm-modules/5/rocm-device-libs/default.nix +++ b/pkgs/development/rocm-modules/5/rocm-device-libs/default.nix @@ -1,18 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, libxml2 +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + libxml2, }: let llvmNativeTarget = - if stdenv.hostPlatform.isx86_64 then "X86" - else if stdenv.hostPlatform.isAarch64 then "AArch64" - else throw "Unsupported ROCm LLVM platform"; -in stdenv.mkDerivation (finalAttrs: { + if stdenv.hostPlatform.isx86_64 then + "X86" + else if stdenv.hostPlatform.isAarch64 then + "AArch64" + else + throw "Unsupported ROCm LLVM platform"; +in +stdenv.mkDerivation (finalAttrs: { pname = "rocm-device-libs"; version = "5.7.1"; @@ -45,6 +50,8 @@ in stdenv.mkDerivation (finalAttrs: { license = licenses.ncsa; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocm-docs-core/default.nix b/pkgs/development/rocm-modules/5/rocm-docs-core/default.nix index d234628f092912..2e32240ca31351 100644 --- a/pkgs/development/rocm-modules/5/rocm-docs-core/default.nix +++ b/pkgs/development/rocm-modules/5/rocm-docs-core/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, gitUpdater -, buildPythonPackage -, setuptools -, beautifulsoup4 -, gitpython -, pydata-sphinx-theme -, pygithub -, sphinx -, breathe -, myst-parser -, sphinx-book-theme -, sphinx-copybutton -, sphinx-design -, sphinx-external-toc -, sphinx-notfound-page -, pyyaml -, fastjsonschema +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + buildPythonPackage, + setuptools, + beautifulsoup4, + gitpython, + pydata-sphinx-theme, + pygithub, + sphinx, + breathe, + myst-parser, + sphinx-book-theme, + sphinx-copybutton, + sphinx-design, + sphinx-external-toc, + sphinx-notfound-page, + pyyaml, + fastjsonschema, }: # FIXME: Move to rocmPackages_common @@ -59,7 +60,10 @@ buildPythonPackage rec { meta = with lib; { description = "ROCm Documentation Python package for ReadTheDocs build standardization"; homepage = "https://github.com/RadeonOpenCompute/rocm-docs-core"; - license = with licenses; [ mit cc-by-40 ]; + license = with licenses; [ + mit + cc-by-40 + ]; maintainers = teams.rocm.members; platforms = platforms.linux; }; diff --git a/pkgs/development/rocm-modules/5/rocm-runtime/default.nix b/pkgs/development/rocm-modules/5/rocm-runtime/default.nix index 58730f40817fee..a8a71ce3df6b68 100644 --- a/pkgs/development/rocm-modules/5/rocm-runtime/default.nix +++ b/pkgs/development/rocm-modules/5/rocm-runtime/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, pkg-config -, cmake -, xxd -, rocm-device-libs -, rocm-thunk -, elfutils -, libdrm -, numactl -, valgrind -, libxml2 +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + pkg-config, + cmake, + xxd, + rocm-device-libs, + rocm-thunk, + elfutils, + libdrm, + numactl, + valgrind, + libxml2, }: stdenv.mkDerivation (finalAttrs: { @@ -73,6 +74,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ ncsa ]; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocm-smi/default.nix b/pkgs/development/rocm-modules/5/rocm-smi/default.nix index 3598f70b7709ca..2d19e2575cf8ee 100644 --- a/pkgs/development/rocm-modules/5/rocm-smi/default.nix +++ b/pkgs/development/rocm-modules/5/rocm-smi/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, wrapPython +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + wrapPython, }: stdenv.mkDerivation (finalAttrs: { @@ -50,6 +51,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = [ "x86_64-linux" ]; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocm-thunk/default.nix b/pkgs/development/rocm-modules/5/rocm-thunk/default.nix index f610f8a0d53a85..b013a3c26f5813 100644 --- a/pkgs/development/rocm-modules/5/rocm-thunk/default.nix +++ b/pkgs/development/rocm-modules/5/rocm-thunk/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, pkg-config -, cmake -, libdrm -, numactl +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + pkg-config, + cmake, + libdrm, + numactl, }: stdenv.mkDerivation (finalAttrs: { @@ -46,9 +47,14 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Radeon open compute thunk interface"; homepage = "https://github.com/ROCm/ROCT-Thunk-Interface"; - license = with licenses; [ bsd2 mit ]; + license = with licenses; [ + bsd2 + mit + ]; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocminfo/default.nix b/pkgs/development/rocm-modules/5/rocminfo/default.nix index fbeb2f7d7f2cbd..2c1ad76a61e74e 100644 --- a/pkgs/development/rocm-modules/5/rocminfo/default.nix +++ b/pkgs/development/rocm-modules/5/rocminfo/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-runtime -, busybox -, python3 -, gnugrep +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-runtime, + busybox, + python3, + gnugrep, # rocminfo requires that the calling user have a password and be in # the video group. If we let rocm_agent_enumerator rely upon # rocminfo's output, then it, too, has those requirements. Instead, # we can specify the GPU targets for this system (e.g. "gfx803" for # Polaris) such that no system call is needed for downstream # compilers to determine the desired target. -, defaultTargets ? [] + defaultTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { @@ -58,6 +59,9 @@ stdenv.mkDerivation (finalAttrs: { license = licenses.ncsa; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = stdenv.hostPlatform.isAarch64 || versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + stdenv.hostPlatform.isAarch64 + || versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocmlir/default.nix b/pkgs/development/rocm-modules/5/rocmlir/default.nix index 33d0ddb55604d5..85c0c0bc17d47c 100644 --- a/pkgs/development/rocm-modules/5/rocmlir/default.nix +++ b/pkgs/development/rocm-modules/5/rocmlir/default.nix @@ -1,44 +1,48 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, ninja -, clr -, git -, libxml2 -, libedit -, zstd -, zlib -, ncurses -, python3Packages -, buildRockCompiler ? false -, buildTests ? false # `argument of type 'NoneType' is not iterable` +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + ninja, + clr, + git, + libxml2, + libedit, + zstd, + zlib, + ncurses, + python3Packages, + buildRockCompiler ? false, + buildTests ? false, # `argument of type 'NoneType' is not iterable` }: # Theoretically, we could have our MLIR have an output # with the source and built objects so that we can just # use it as the external LLVM repo for this let - suffix = - if buildRockCompiler - then "-rock" - else ""; + suffix = if buildRockCompiler then "-rock" else ""; llvmNativeTarget = - if stdenv.hostPlatform.isx86_64 then "X86" - else if stdenv.hostPlatform.isAarch64 then "AArch64" - else throw "Unsupported ROCm LLVM platform"; -in stdenv.mkDerivation (finalAttrs: { + if stdenv.hostPlatform.isx86_64 then + "X86" + else if stdenv.hostPlatform.isAarch64 then + "AArch64" + else + throw "Unsupported ROCm LLVM platform"; +in +stdenv.mkDerivation (finalAttrs: { pname = "rocmlir${suffix}"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals (!buildRockCompiler) [ - "external" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals (!buildRockCompiler) [ + "external" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -68,22 +72,25 @@ in stdenv.mkDerivation (finalAttrs: { ncurses ]; - cmakeFlags = [ - "-DLLVM_TARGETS_TO_BUILD=AMDGPU;${llvmNativeTarget}" - "-DLLVM_ENABLE_ZSTD=ON" - "-DLLVM_ENABLE_ZLIB=ON" - "-DLLVM_ENABLE_TERMINFO=ON" - "-DROCM_PATH=${clr}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals buildRockCompiler [ - "-DBUILD_FAT_LIBROCKCOMPILER=ON" - ] ++ lib.optionals (!buildRockCompiler) [ - "-DROCM_TEST_CHIPSET=gfx000" - ]; + cmakeFlags = + [ + "-DLLVM_TARGETS_TO_BUILD=AMDGPU;${llvmNativeTarget}" + "-DLLVM_ENABLE_ZSTD=ON" + "-DLLVM_ENABLE_ZLIB=ON" + "-DLLVM_ENABLE_TERMINFO=ON" + "-DROCM_PATH=${clr}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals buildRockCompiler [ + "-DBUILD_FAT_LIBROCKCOMPILER=ON" + ] + ++ lib.optionals (!buildRockCompiler) [ + "-DROCM_TEST_CHIPSET=gfx000" + ]; postPatch = '' patchShebangs mlir @@ -96,20 +103,30 @@ in stdenv.mkDerivation (finalAttrs: { doCheck = true; # Certain libs aren't being generated, try enabling tests next update - checkTarget = if buildRockCompiler - then "librockCompiler" - else if buildTests - then "check-rocmlir" - else "check-rocmlir-build-only"; + checkTarget = + if buildRockCompiler then + "librockCompiler" + else if buildTests then + "check-rocmlir" + else + "check-rocmlir-build-only"; - postInstall = let - libPath = lib.makeLibraryPath [ zstd zlib ncurses clr stdenv.cc.cc ]; - in lib.optionals (!buildRockCompiler) '' - mkdir -p $external/lib - cp -a external/llvm-project/llvm/lib/{*.a*,*.so*} $external/lib - patchelf --set-rpath $external/lib:$out/lib:${libPath} $external/lib/*.so* - patchelf --set-rpath $out/lib:$external/lib:${libPath} $out/{bin/*,lib/*.so*} - ''; + postInstall = + let + libPath = lib.makeLibraryPath [ + zstd + zlib + ncurses + clr + stdenv.cc.cc + ]; + in + lib.optionals (!buildRockCompiler) '' + mkdir -p $external/lib + cp -a external/llvm-project/llvm/lib/{*.a*,*.so*} $external/lib + patchelf --set-rpath $external/lib:$out/lib:${libPath} $external/lib/*.so* + patchelf --set-rpath $out/lib:$external/lib:${libPath} $out/{bin/*,lib/*.so*} + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -125,6 +142,8 @@ in stdenv.mkDerivation (finalAttrs: { license = with licenses; [ asl20 ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocprim/default.nix b/pkgs/development/rocm-modules/5/rocprim/default.nix index 398d1d5509cfee..97f7418d3d25a6 100644 --- a/pkgs/development/rocm-modules/5/rocprim/default.nix +++ b/pkgs/development/rocm-modules/5/rocprim/default.nix @@ -1,28 +1,32 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, gtest -, gbenchmark -, buildTests ? false -, buildBenchmarks ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + gtest, + gbenchmark, + buildTests ? false, + buildBenchmarks ? false, + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { pname = "rocprim"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -37,37 +41,46 @@ stdenv.mkDerivation (finalAttrs: { clr ]; - buildInputs = lib.optionals buildTests [ - gtest - ] ++ lib.optionals buildBenchmarks [ - gbenchmark - ]; + buildInputs = + lib.optionals buildTests [ + gtest + ] + ++ lib.optionals buildBenchmarks [ + gbenchmark + ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_TEST=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_BENCHMARK=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_TEST=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_BENCHMARK=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/test_* $test/bin - mv $out/bin/rocprim $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/benchmark_* $benchmark/bin - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/test_* $test/bin + mv $out/bin/rocprim $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/benchmark_* $benchmark/bin + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -81,6 +94,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocprofiler/default.nix b/pkgs/development/rocm-modules/5/rocprofiler/default.nix index c544b3f226bba5..10397e8b9e7a26 100644 --- a/pkgs/development/rocm-modules/5/rocprofiler/default.nix +++ b/pkgs/development/rocm-modules/5/rocprofiler/default.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, symlinkJoin -, substituteAll -, cmake -, clang -, clr -, rocm-core -, rocm-thunk -, rocm-device-libs -, roctracer -, rocdbgapi -, rocm-smi -, hsa-amd-aqlprofile-bin -, numactl -, libpciaccess -, libxml2 -, elfutils -, mpi -, systemd -, gtest -, python3Packages -, gpuTargets ? clr.gpuTargets +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + symlinkJoin, + substituteAll, + cmake, + clang, + clr, + rocm-core, + rocm-thunk, + rocm-device-libs, + roctracer, + rocdbgapi, + rocm-smi, + hsa-amd-aqlprofile-bin, + numactl, + libpciaccess, + libxml2, + elfutils, + mpi, + systemd, + gtest, + python3Packages, + gpuTargets ? clr.gpuTargets, }: let @@ -44,7 +45,8 @@ let rm -rf $out/nix-support ''; }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "rocprofiler"; version = "5.7.1"; @@ -131,6 +133,8 @@ in stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; # mitx11 maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor clr.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor clr.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocr-debug-agent/default.nix b/pkgs/development/rocm-modules/5/rocr-debug-agent/default.nix index 67da17304b3d00..3b94b41169c099 100644 --- a/pkgs/development/rocm-modules/5/rocr-debug-agent/default.nix +++ b/pkgs/development/rocm-modules/5/rocr-debug-agent/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, clr -, git -, rocdbgapi -, elfutils +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + clr, + git, + rocdbgapi, + elfutils, }: stdenv.mkDerivation (finalAttrs: { @@ -54,6 +55,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ ncsa ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocrand/default.nix b/pkgs/development/rocm-modules/5/rocrand/default.nix index 5abdb3fafecb2a..d62d348ca5d2ff 100644 --- a/pkgs/development/rocm-modules/5/rocrand/default.nix +++ b/pkgs/development/rocm-modules/5/rocrand/default.nix @@ -1,28 +1,32 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, gtest -, gbenchmark -, buildTests ? false -, buildBenchmarks ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + gtest, + gbenchmark, + buildTests ? false, + buildBenchmarks ? false, + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { pname = "rocrand"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -38,38 +42,47 @@ stdenv.mkDerivation (finalAttrs: { clr ]; - buildInputs = lib.optionals buildTests [ - gtest - ] ++ lib.optionals buildBenchmarks [ - gbenchmark - ]; + buildInputs = + lib.optionals buildTests [ + gtest + ] + ++ lib.optionals buildBenchmarks [ + gbenchmark + ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-DHIP_ROOT_DIR=${clr}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_TEST=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_BENCHMARK=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-DHIP_ROOT_DIR=${clr}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_TEST=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_BENCHMARK=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/test_* $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/benchmark_* $benchmark/bin - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/test_* $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/benchmark_* $benchmark/bin + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -83,6 +96,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocsolver/default.nix b/pkgs/development/rocm-modules/5/rocsolver/default.nix index 518aa798d49b42..a1b24af681b8b2 100644 --- a/pkgs/development/rocm-modules/5/rocsolver/default.nix +++ b/pkgs/development/rocm-modules/5/rocsolver/default.nix @@ -1,32 +1,36 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocblas -, rocsparse -, clr -, fmt -, gtest -, gfortran -, lapack-reference -, buildTests ? false -, buildBenchmarks ? false -, gpuTargets ? [ ] # gpuTargets = [ "gfx803" "gfx900" "gfx906:xnack-" ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocblas, + rocsparse, + clr, + fmt, + gtest, + gfortran, + lapack-reference, + buildTests ? false, + buildBenchmarks ? false, + gpuTargets ? [ ], # gpuTargets = [ "gfx803" "gfx900" "gfx906:xnack-" ] }: stdenv.mkDerivation (finalAttrs: { pname = "rocsolver"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -35,49 +39,61 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-qxmjm4tgpCnfJ2SqUXndk6y0MsPJUKHvjv/3Uc0smr4="; }; - nativeBuildInputs = [ - cmake - rocm-cmake - clr - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - gfortran - ]; + nativeBuildInputs = + [ + cmake + rocm-cmake + clr + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + gfortran + ]; - buildInputs = [ - rocblas - rocsparse - fmt - ] ++ lib.optionals buildTests [ - gtest - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - lapack-reference - ]; + buildInputs = + [ + rocblas + rocsparse + fmt + ] + ++ lib.optionals buildTests [ + gtest + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + lapack-reference + ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - "-DCMAKE_CXX_FLAGS=-Wno-switch" # Way too many warnings - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_BENCHMARKS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + "-DCMAKE_CXX_FLAGS=-Wno-switch" # Way too many warnings + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_BENCHMARKS=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/rocsolver-test $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/rocsolver-bench $benchmark/bin - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/rocsolver-test $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/rocsolver-bench $benchmark/bin + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -95,6 +111,8 @@ stdenv.mkDerivation (finalAttrs: { platforms = platforms.linux; timeout = 14400; # 4 hours maxSilent = 14400; # 4 hours - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocsparse/default.nix b/pkgs/development/rocm-modules/5/rocsparse/default.nix index 07e2018b0287c5..58890373403d1d 100644 --- a/pkgs/development/rocm-modules/5/rocsparse/default.nix +++ b/pkgs/development/rocm-modules/5/rocsparse/default.nix @@ -1,33 +1,37 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchzip -, rocmUpdateScript -, cmake -, rocm-cmake -, rocprim -, clr -, gfortran -, git -, gtest -, boost -, python3Packages -, buildTests ? false -, buildBenchmarks ? false # Seems to depend on tests -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + fetchzip, + rocmUpdateScript, + cmake, + rocm-cmake, + rocprim, + clr, + gfortran, + git, + gtest, + boost, + python3Packages, + buildTests ? false, + buildBenchmarks ? false, # Seems to depend on tests + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { pname = "rocsparse"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -43,32 +47,38 @@ stdenv.mkDerivation (finalAttrs: { gfortran ]; - buildInputs = [ - rocprim - git - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - gtest - boost - python3Packages.python - python3Packages.pyyaml - ]; + buildInputs = + [ + rocprim + git + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + gtest + boost + python3Packages.python + python3Packages.pyyaml + ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - "-DBUILD_CLIENTS_TESTS=ON" - "-DCMAKE_MATRICES_DIR=/build/source/matrices" - "-Dpython=python3" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_BENCHMARKS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + "-DBUILD_CLIENTS_TESTS=ON" + "-DCMAKE_MATRICES_DIR=/build/source/matrices" + "-Dpython=python3" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_BENCHMARKS=ON" + ]; # We have to manually generate the matrices postPatch = lib.optionalString (buildTests || buildBenchmarks) '' @@ -112,17 +122,19 @@ stdenv.mkDerivation (finalAttrs: { done ''; - postInstall = lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - cp -a $out/bin/* $benchmark/bin - rm $benchmark/bin/rocsparse-test - '' + lib.optionalString (buildTests || buildBenchmarks) '' - mkdir -p $test/bin - mv $out/bin/* $test/bin - rm $test/bin/rocsparse-bench || true - mv /build/source/matrices $test - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + cp -a $out/bin/* $benchmark/bin + rm $benchmark/bin/rocsparse-test + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + mkdir -p $test/bin + mv $out/bin/* $test/bin + rm $test/bin/rocsparse-bench || true + mv /build/source/matrices $test + rmdir $out/bin + ''; passthru = { matrices = import ./deps.nix { @@ -144,6 +156,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocsparse/deps.nix b/pkgs/development/rocm-modules/5/rocsparse/deps.nix index cef880ab3232d2..e39b6de39673cc 100644 --- a/pkgs/development/rocm-modules/5/rocsparse/deps.nix +++ b/pkgs/development/rocm-modules/5/rocsparse/deps.nix @@ -1,6 +1,7 @@ -{ fetchzip -, mirror1 -, mirror2 +{ + fetchzip, + mirror1, + mirror2, }: { diff --git a/pkgs/development/rocm-modules/5/rocthrust/default.nix b/pkgs/development/rocm-modules/5/rocthrust/default.nix index bd03cc11d7807e..cbf9d77f149d6e 100644 --- a/pkgs/development/rocm-modules/5/rocthrust/default.nix +++ b/pkgs/development/rocm-modules/5/rocthrust/default.nix @@ -1,28 +1,32 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocprim -, clr -, gtest -, buildTests ? false -, buildBenchmarks ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocprim, + clr, + gtest, + buildTests ? false, + buildBenchmarks ? false, + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { pname = "rocthrust"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -42,33 +46,41 @@ stdenv.mkDerivation (finalAttrs: { gtest ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - "-DHIP_ROOT_DIR=${clr}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_TEST=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_BENCHMARKS=ON" - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - "-DCMAKE_CXX_FLAGS=-Wno-deprecated-builtins" # Too much spam - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + "-DHIP_ROOT_DIR=${clr}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_TEST=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_BENCHMARKS=ON" + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + "-DCMAKE_CXX_FLAGS=-Wno-deprecated-builtins" # Too much spam + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/{test_*,*.hip} $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/benchmark_* $benchmark/bin - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rm -rf $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/{test_*,*.hip} $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/benchmark_* $benchmark/bin + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rm -rf $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -82,6 +94,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ asl20 ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/roctracer/default.nix b/pkgs/development/rocm-modules/5/roctracer/default.nix index 9270a273dcae90..44736676a2dd33 100644 --- a/pkgs/development/rocm-modules/5/roctracer/default.nix +++ b/pkgs/development/rocm-modules/5/roctracer/default.nix @@ -1,32 +1,36 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, clr -, rocm-device-libs -, libxml2 -, doxygen -, graphviz -, gcc-unwrapped -, libbacktrace -, rocm-runtime -, python3Packages -, buildDocs ? false # Nothing seems to be generated, so not making the output -, buildTests ? false +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + clr, + rocm-device-libs, + libxml2, + doxygen, + graphviz, + gcc-unwrapped, + libbacktrace, + rocm-runtime, + python3Packages, + buildDocs ? false, # Nothing seems to be generated, so not making the output + buildTests ? false, }: stdenv.mkDerivation (finalAttrs: { pname = "roctracer"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ] ++ lib.optionals buildTests [ - "test" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ] + ++ lib.optionals buildTests [ + "test" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -35,13 +39,15 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-P6QYyAjMRwFFWKF8AhbrYGe+mYVJXdbBW1or6vcobYU="; }; - nativeBuildInputs = [ - cmake - clr - ] ++ lib.optionals buildDocs [ - doxygen - graphviz - ]; + nativeBuildInputs = + [ + cmake + clr + ] + ++ lib.optionals buildDocs [ + doxygen + graphviz + ]; buildInputs = [ libxml2 @@ -64,27 +70,39 @@ stdenv.mkDerivation (finalAttrs: { "-Wno-error=array-bounds" ]; - postPatch = '' - export HIP_DEVICE_LIB_PATH=${rocm-device-libs}/amdgcn/bitcode - '' + lib.optionalString (!buildTests) '' - substituteInPlace CMakeLists.txt \ - --replace "add_subdirectory(test)" "" - ''; + postPatch = + '' + export HIP_DEVICE_LIB_PATH=${rocm-device-libs}/amdgcn/bitcode + '' + + lib.optionalString (!buildTests) '' + substituteInPlace CMakeLists.txt \ + --replace "add_subdirectory(test)" "" + ''; # Tests always fail, probably need GPU # doCheck = buildTests; - postInstall = lib.optionalString buildDocs '' - mkdir -p $doc - '' + lib.optionalString buildTests '' - mkdir -p $test/bin - # Not sure why this is an install target - find $out/test -executable -type f -exec mv {} $test/bin \; - rm $test/bin/{*.sh,*.py} - patchelf --set-rpath $out/lib:${lib.makeLibraryPath ( - finalAttrs.buildInputs ++ [ clr gcc-unwrapped.lib rocm-runtime ])} $test/bin/* - rm -rf $out/test - ''; + postInstall = + lib.optionalString buildDocs '' + mkdir -p $doc + '' + + lib.optionalString buildTests '' + mkdir -p $test/bin + # Not sure why this is an install target + find $out/test -executable -type f -exec mv {} $test/bin \; + rm $test/bin/{*.sh,*.py} + patchelf --set-rpath $out/lib:${ + lib.makeLibraryPath ( + finalAttrs.buildInputs + ++ [ + clr + gcc-unwrapped.lib + rocm-runtime + ] + ) + } $test/bin/* + rm -rf $out/test + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -98,6 +116,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; # mitx11 maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor clr.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor clr.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rocwmma/default.nix b/pkgs/development/rocm-modules/5/rocwmma/default.nix index f02859995bcc18..7fdd88e2277b47 100644 --- a/pkgs/development/rocm-modules/5/rocwmma/default.nix +++ b/pkgs/development/rocm-modules/5/rocwmma/default.nix @@ -1,34 +1,39 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-smi -, clr -, openmp -, gtest -, rocblas -, buildTests ? false # Will likely fail building because wavefront shifts are not supported for certain archs -, buildExtendedTests ? false -, buildBenchmarks ? false -, buildSamples ? false -, gpuTargets ? [ ] # gpuTargets = [ "gfx908:xnack-" "gfx90a:xnack-" "gfx90a:xnack+" ... ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-smi, + clr, + openmp, + gtest, + rocblas, + buildTests ? false, # Will likely fail building because wavefront shifts are not supported for certain archs + buildExtendedTests ? false, + buildBenchmarks ? false, + buildSamples ? false, + gpuTargets ? [ ], # gpuTargets = [ "gfx908:xnack-" "gfx90a:xnack-" "gfx90a:xnack+" ... ] }: stdenv.mkDerivation (finalAttrs: { pname = "rocwmma"; version = "5.7.1"; - outputs = [ - "out" - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ] ++ lib.optionals buildSamples [ - "sample" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ] + ++ lib.optionals buildSamples [ + "sample" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -47,46 +52,56 @@ stdenv.mkDerivation (finalAttrs: { clr ]; - buildInputs = [ - openmp - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - rocm-smi - gtest - rocblas - ]; + buildInputs = + [ + openmp + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + rocm-smi + gtest + rocblas + ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - "-DROCWMMA_BUILD_TESTS=${if buildTests || buildBenchmarks then "ON" else "OFF"}" - "-DROCWMMA_BUILD_SAMPLES=${if buildSamples then "ON" else "OFF"}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildExtendedTests [ - "-DROCWMMA_BUILD_EXTENDED_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DROCWMMA_BUILD_BENCHMARK_TESTS=ON" - "-DROCWMMA_BENCHMARK_WITH_ROCBLAS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + "-DROCWMMA_BUILD_TESTS=${if buildTests || buildBenchmarks then "ON" else "OFF"}" + "-DROCWMMA_BUILD_SAMPLES=${if buildSamples then "ON" else "OFF"}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildExtendedTests [ + "-DROCWMMA_BUILD_EXTENDED_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DROCWMMA_BUILD_BENCHMARK_TESTS=ON" + "-DROCWMMA_BENCHMARK_WITH_ROCBLAS=ON" + ]; - postInstall = lib.optionalString (buildTests || buildBenchmarks) '' - mkdir -p $test/bin - mv $out/bin/{*_test,*-validate} $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/*-bench $benchmark/bin - '' + lib.optionalString buildSamples '' - mkdir -p $sample/bin - mv $out/bin/sgemmv $sample/bin - mv $out/bin/simple_gemm $sample/bin - mv $out/bin/simple_dlrm $sample/bin - '' + lib.optionalString (buildTests || buildBenchmarks || buildSamples) '' - rm -rf $out/bin - ''; + postInstall = + lib.optionalString (buildTests || buildBenchmarks) '' + mkdir -p $test/bin + mv $out/bin/{*_test,*-validate} $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/*-bench $benchmark/bin + '' + + lib.optionalString buildSamples '' + mkdir -p $sample/bin + mv $out/bin/sgemmv $sample/bin + mv $out/bin/simple_gemm $sample/bin + mv $out/bin/simple_dlrm $sample/bin + '' + + lib.optionalString (buildTests || buildBenchmarks || buildSamples) '' + rm -rf $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -100,6 +115,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/rpp/default.nix b/pkgs/development/rocm-modules/5/rpp/default.nix index 45079c6d62cc98..59f633f4bfa112 100644 --- a/pkgs/development/rocm-modules/5/rpp/default.nix +++ b/pkgs/development/rocm-modules/5/rpp/default.nix @@ -1,27 +1,33 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-docs-core -, half -, clr -, openmp -, boost -, python3Packages -, buildDocs ? false # Needs internet -, useOpenCL ? false -, useCPU ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-docs-core, + half, + clr, + openmp, + boost, + python3Packages, + buildDocs ? false, # Needs internet + useOpenCL ? false, + useCPU ? false, + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { - pname = "rpp-" + ( - if (!useOpenCL && !useCPU) then "hip" - else if (!useOpenCL && !useCPU) then "opencl" - else "cpu" - ); + pname = + "rpp-" + + ( + if (!useOpenCL && !useCPU) then + "hip" + else if (!useOpenCL && !useCPU) then + "opencl" + else + "cpu" + ); version = "5.7.1"; @@ -32,14 +38,16 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-s6ODmxPBLpR5f8VALaW6F0p0rZSxSd2LH2+60SEfLCk="; }; - nativeBuildInputs = [ - cmake - rocm-cmake - clr - ] ++ lib.optionals buildDocs [ - rocm-docs-core - python3Packages.python - ]; + nativeBuildInputs = + [ + cmake + rocm-cmake + clr + ] + ++ lib.optionals buildDocs [ + rocm-docs-core + python3Packages.python + ]; buildInputs = [ half @@ -47,19 +55,24 @@ stdenv.mkDerivation (finalAttrs: { boost ]; - cmakeFlags = [ - "-DROCM_PATH=${clr}" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals (!useOpenCL && !useCPU) [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-DBACKEND=HIP" - ] ++ lib.optionals (useOpenCL && !useCPU) [ - "-DBACKEND=OCL" - ] ++ lib.optionals useCPU [ - "-DBACKEND=CPU" - ]; + cmakeFlags = + [ + "-DROCM_PATH=${clr}" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals (!useOpenCL && !useCPU) [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-DBACKEND=HIP" + ] + ++ lib.optionals (useOpenCL && !useCPU) [ + "-DBACKEND=OCL" + ] + ++ lib.optionals useCPU [ + "-DBACKEND=CPU" + ]; postPatch = lib.optionalString (!useOpenCL && !useCPU) '' # Bad path @@ -83,6 +96,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "6.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "6.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/5/tensile/default.nix b/pkgs/development/rocm-modules/5/tensile/default.nix index 7f1e64422668f6..bb8db155c42a32 100644 --- a/pkgs/development/rocm-modules/5/tensile/default.nix +++ b/pkgs/development/rocm-modules/5/tensile/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, buildPythonPackage -, pytestCheckHook -, setuptools -, pyyaml -, msgpack -, pandas -, joblib -, filelock -, rocminfo +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + buildPythonPackage, + pytestCheckHook, + setuptools, + pyyaml, + msgpack, + pandas, + joblib, + filelock, + rocminfo, }: buildPythonPackage rec { @@ -60,6 +61,7 @@ buildPythonPackage rec { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor version != versions.minor stdenv.cc.version || versionAtLeast version "6.0.0"; + broken = + versions.minor version != versions.minor stdenv.cc.version || versionAtLeast version "6.0.0"; }; } diff --git a/pkgs/development/rocm-modules/5/update.nix b/pkgs/development/rocm-modules/5/update.nix index ebf21b8f15a731..e9ff2d93d98fab 100644 --- a/pkgs/development/rocm-modules/5/update.nix +++ b/pkgs/development/rocm-modules/5/update.nix @@ -1,19 +1,19 @@ -{ lib -, writeScript +{ + lib, + writeScript, }: -{ name ? "" -, owner ? "" -, repo ? "" -, page ? "releases/latest" -, filter ? ".tag_name | split(\"-\") | .[1]" +{ + name ? "", + owner ? "", + repo ? "", + page ? "releases/latest", + filter ? ".tag_name | split(\"-\") | .[1]", }: let pname = - if lib.hasPrefix "rocm-llvm-" name - then "llvm.${lib.removePrefix "rocm-llvm-" name}" - else name; + if lib.hasPrefix "rocm-llvm-" name then "llvm.${lib.removePrefix "rocm-llvm-" name}" else name; updateScript = writeScript "update.sh" '' #!/usr/bin/env nix-shell @@ -34,4 +34,5 @@ let update-source-version rocmPackages_5.${pname} "$version" --ignore-same-hash ''; -in [ updateScript ] +in +[ updateScript ] diff --git a/pkgs/development/rocm-modules/6/clang-ocl/default.nix b/pkgs/development/rocm-modules/6/clang-ocl/default.nix index 7d366e53ae5658..0ef8a04a744b2c 100644 --- a/pkgs/development/rocm-modules/6/clang-ocl/default.nix +++ b/pkgs/development/rocm-modules/6/clang-ocl/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-device-libs +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-device-libs, }: stdenv.mkDerivation (finalAttrs: { @@ -37,6 +38,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/clr/default.nix b/pkgs/development/rocm-modules/6/clr/default.nix index 7d80242ccbda01..a3dc49695c50d4 100644 --- a/pkgs/development/rocm-modules/6/clr/default.nix +++ b/pkgs/development/rocm-modules/6/clr/default.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, callPackage -, fetchFromGitHub -, fetchpatch -, fetchurl -, rocmUpdateScript -, makeWrapper -, cmake -, perl -, clang -, hip-common -, hipcc -, rocm-device-libs -, rocm-comgr -, rocm-runtime -, roctracer -, rocminfo -, rocm-smi -, numactl -, libGL -, libxml2 -, libX11 -, python3Packages +{ + lib, + stdenv, + callPackage, + fetchFromGitHub, + fetchpatch, + fetchurl, + rocmUpdateScript, + makeWrapper, + cmake, + perl, + clang, + hip-common, + hipcc, + rocm-device-libs, + rocm-comgr, + rocm-runtime, + roctracer, + rocminfo, + rocm-smi, + numactl, + libGL, + libxml2, + libX11, + python3Packages, }: let @@ -38,14 +39,15 @@ let # https://github.com/NixOS/nixpkgs/issues/305641 # Not needed when 3.29.2 is in unstable - cmake' = cmake.overrideAttrs(old: rec { + cmake' = cmake.overrideAttrs (old: rec { version = "3.29.2"; src = fetchurl { url = "https://cmake.org/files/v${lib.versions.majorMinor version}/cmake-${version}.tar.gz"; hash = "sha256-NttLaSaqt0G6bksuotmckZMiITIwi03IJNQSPLcwNS4="; }; }); -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "clr"; version = "6.0.2"; @@ -213,6 +215,8 @@ in stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/clr/test-opencl-example.nix b/pkgs/development/rocm-modules/6/clr/test-opencl-example.nix index d2797d1a501690..3ed1143d66c616 100644 --- a/pkgs/development/rocm-modules/6/clr/test-opencl-example.nix +++ b/pkgs/development/rocm-modules/6/clr/test-opencl-example.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, makeImpureTest -, fetchFromGitHub -, clr -, cmake -, pkg-config -, glew -, libglut -, opencl-headers -, ocl-icd +{ + lib, + stdenv, + makeImpureTest, + fetchFromGitHub, + clr, + cmake, + pkg-config, + glew, + libglut, + opencl-headers, + ocl-icd, }: let @@ -24,9 +25,17 @@ let hash = "sha256-qARQpUiYsamHbko/I1gPZE9pUGJ+3396Vk2n7ERSftA="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ glew libglut opencl-headers ocl-icd ]; + buildInputs = [ + glew + libglut + opencl-headers + ocl-icd + ]; installPhase = '' runHook preInstall @@ -42,9 +51,9 @@ let meta = with lib; { description = "Samples from the AMD APP SDK (with OpenCRun support)"; - homepage = "https://github.com/OpenCL/AMD_APP_samples"; - license = licenses.bsd2; - platforms = platforms.linux; + homepage = "https://github.com/OpenCL/AMD_APP_samples"; + license = licenses.bsd2; + platforms = platforms.linux; maintainers = lib.teams.rocm.members; }; }; @@ -54,7 +63,11 @@ makeImpureTest { name = "opencl-example"; testedPackage = "rocmPackages_6.clr"; - sandboxPaths = [ "/sys" "/dev/dri" "/dev/kfd" ]; + sandboxPaths = [ + "/sys" + "/dev/dri" + "/dev/kfd" + ]; nativeBuildInputs = [ examples ]; diff --git a/pkgs/development/rocm-modules/6/clr/test-rocm-smi.nix b/pkgs/development/rocm-modules/6/clr/test-rocm-smi.nix index 6f2d3c7882890a..dfbb67343e3f40 100644 --- a/pkgs/development/rocm-modules/6/clr/test-rocm-smi.nix +++ b/pkgs/development/rocm-modules/6/clr/test-rocm-smi.nix @@ -1,14 +1,18 @@ -{ lib -, makeImpureTest -, clinfo -, clr -, rocm-smi +{ + lib, + makeImpureTest, + clinfo, + clr, + rocm-smi, }: makeImpureTest { name = "rocm-smi"; testedPackage = "rocmPackages_6.clr"; - nativeBuildInputs = [ clinfo rocm-smi ]; + nativeBuildInputs = [ + clinfo + rocm-smi + ]; OCL_ICD_VENDORS = "${clr.icd}/etc/OpenCL/vendors"; testScript = '' diff --git a/pkgs/development/rocm-modules/6/composable_kernel/default.nix b/pkgs/development/rocm-modules/6/composable_kernel/default.nix index e0f8daf8263830..16f3f05f750982 100644 --- a/pkgs/development/rocm-modules/6/composable_kernel/default.nix +++ b/pkgs/development/rocm-modules/6/composable_kernel/default.nix @@ -1,31 +1,35 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, openmp -, clang-tools-extra -, git -, gtest -, zstd -, buildTests ? false -, buildExamples ? false -, gpuTargets ? [ ] # gpuTargets = [ "gfx803" "gfx900" "gfx1030" ... ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + openmp, + clang-tools-extra, + git, + gtest, + zstd, + buildTests ? false, + buildExamples ? false, + gpuTargets ? [ ], # gpuTargets = [ "gfx803" "gfx900" "gfx1030" ... ] }: stdenv.mkDerivation (finalAttrs: { pname = "composable_kernel"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildExamples [ - "example" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildExamples [ + "example" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -45,38 +49,46 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ openmp ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DGOOGLETEST_DIR=${gtest.src}" # Custom linker names - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DGOOGLETEST_DIR=${gtest.src}" # Custom linker names + ]; # No flags to build selectively it seems... - postPatch = lib.optionalString (!buildTests) '' - substituteInPlace CMakeLists.txt \ - --replace "add_subdirectory(test)" "" - '' + lib.optionalString (!buildExamples) '' - substituteInPlace CMakeLists.txt \ - --replace "add_subdirectory(example)" "" - '' + '' - substituteInPlace CMakeLists.txt \ - --replace "add_subdirectory(profiler)" "" - '' - ; + postPatch = + lib.optionalString (!buildTests) '' + substituteInPlace CMakeLists.txt \ + --replace "add_subdirectory(test)" "" + '' + + lib.optionalString (!buildExamples) '' + substituteInPlace CMakeLists.txt \ + --replace "add_subdirectory(example)" "" + '' + + '' + substituteInPlace CMakeLists.txt \ + --replace "add_subdirectory(profiler)" "" + ''; - postInstall = '' - zstd --rm $out/lib/libdevice_operations.a - '' + lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/test_* $test/bin - '' + lib.optionalString buildExamples '' - mkdir -p $example/bin - mv $out/bin/example_* $example/bin - ''; + postInstall = + '' + zstd --rm $out/lib/libdevice_operations.a + '' + + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/test_* $test/bin + '' + + lib.optionalString buildExamples '' + mkdir -p $example/bin + mv $out/bin/example_* $example/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -93,6 +105,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/composable_kernel/unpack.nix b/pkgs/development/rocm-modules/6/composable_kernel/unpack.nix index 2572884388fa35..ff98df6eff3b0c 100644 --- a/pkgs/development/rocm-modules/6/composable_kernel/unpack.nix +++ b/pkgs/development/rocm-modules/6/composable_kernel/unpack.nix @@ -1,13 +1,17 @@ -{ runCommandLocal, +{ + runCommandLocal, composable_kernel_build, - zstd + zstd, }: let ck = composable_kernel_build; -in runCommandLocal "unpack-${ck.name}" { +in +runCommandLocal "unpack-${ck.name}" + { nativeBuildInputs = [ zstd ]; meta = ck.meta; - } '' + } + '' mkdir -p $out cp -r --no-preserve=mode ${ck}/* $out zstd -dv --rm $out/lib/libdevice_operations.a.zst -o $out/lib/libdevice_operations.a diff --git a/pkgs/development/rocm-modules/6/hipblas/default.nix b/pkgs/development/rocm-modules/6/hipblas/default.nix index 5989aff90a7d70..3e4436b7d3f729 100644 --- a/pkgs/development/rocm-modules/6/hipblas/default.nix +++ b/pkgs/development/rocm-modules/6/hipblas/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, gfortran -, rocblas -, rocsolver -, gtest -, lapack-reference -, buildTests ? false -, buildBenchmarks ? false -, buildSamples ? false +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + gfortran, + rocblas, + rocsolver, + gtest, + lapack-reference, + buildTests ? false, + buildBenchmarks ? false, + buildSamples ? false, }: # Can also use cuBLAS @@ -20,15 +21,19 @@ stdenv.mkDerivation (finalAttrs: { pname = "hipblas"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ] ++ lib.optionals buildSamples [ - "sample" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ] + ++ lib.optionals buildSamples [ + "sample" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -44,43 +49,54 @@ stdenv.mkDerivation (finalAttrs: { gfortran ]; - buildInputs = [ - rocblas - rocsolver - ] ++ lib.optionals buildTests [ - gtest - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - lapack-reference - ]; + buildInputs = + [ + rocblas + rocsolver + ] + ++ lib.optionals buildTests [ + gtest + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + lapack-reference + ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_BENCHMARKS=ON" - ] ++ lib.optionals buildSamples [ - "-DBUILD_CLIENTS_SAMPLES=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_BENCHMARKS=ON" + ] + ++ lib.optionals buildSamples [ + "-DBUILD_CLIENTS_SAMPLES=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/hipblas-test $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/hipblas-bench $benchmark/bin - '' + lib.optionalString buildSamples '' - mkdir -p $sample/bin - mv $out/bin/example-* $sample/bin - '' + lib.optionalString (buildTests || buildBenchmarks || buildSamples) '' - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/hipblas-test $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/hipblas-bench $benchmark/bin + '' + + lib.optionalString buildSamples '' + mkdir -p $sample/bin + mv $out/bin/example-* $sample/bin + '' + + lib.optionalString (buildTests || buildBenchmarks || buildSamples) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -94,6 +110,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/hipcc/default.nix b/pkgs/development/rocm-modules/6/hipcc/default.nix index 96bc914e3a67f6..5f2ac080cb50df 100644 --- a/pkgs/development/rocm-modules/6/hipcc/default.nix +++ b/pkgs/development/rocm-modules/6/hipcc/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, lsb-release +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + lsb-release, }: stdenv.mkDerivation (finalAttrs: { @@ -41,6 +42,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/hipfft/default.nix b/pkgs/development/rocm-modules/6/hipfft/default.nix index dca6337e6de8e8..bc9e26bd9f1136 100644 --- a/pkgs/development/rocm-modules/6/hipfft/default.nix +++ b/pkgs/development/rocm-modules/6/hipfft/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, git -, rocfft -, gtest -, boost -, fftw -, fftwFloat -, openmp -, buildTests ? false -, buildBenchmarks ? false -, buildSamples ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + git, + rocfft, + gtest, + boost, + fftw, + fftwFloat, + openmp, + buildTests ? false, + buildBenchmarks ? false, + buildSamples ? false, + gpuTargets ? [ ], }: # Can also use cuFFT @@ -23,15 +24,19 @@ stdenv.mkDerivation (finalAttrs: { pname = "hipfft"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ] ++ lib.optionals buildSamples [ - "sample" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ] + ++ lib.optionals buildSamples [ + "sample" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -48,50 +53,61 @@ stdenv.mkDerivation (finalAttrs: { rocm-cmake ]; - buildInputs = [ - rocfft - ] ++ lib.optionals (buildTests || buildBenchmarks || buildSamples) [ - gtest - boost - fftw - fftwFloat - openmp - ]; + buildInputs = + [ + rocfft + ] + ++ lib.optionals (buildTests || buildBenchmarks || buildSamples) [ + gtest + boost + fftw + fftwFloat + openmp + ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-DCMAKE_MODULE_PATH=${clr}/lib/cmake/hip" - "-DHIP_ROOT_DIR=${clr}" - "-DHIP_PATH=${clr}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_RIDER=ON" - ] ++ lib.optionals buildSamples [ - "-DBUILD_CLIENTS_SAMPLES=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-DCMAKE_MODULE_PATH=${clr}/lib/cmake/hip" + "-DHIP_ROOT_DIR=${clr}" + "-DHIP_PATH=${clr}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_RIDER=ON" + ] + ++ lib.optionals buildSamples [ + "-DBUILD_CLIENTS_SAMPLES=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/hipfft-test $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/hipfft-rider $benchmark/bin - '' + lib.optionalString buildSamples '' - mkdir -p $sample/bin - mv clients/staging/hipfft_* $sample/bin - patchelf $sample/bin/hipfft_* --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/hipfft-test $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/hipfft-rider $benchmark/bin + '' + + lib.optionalString buildSamples '' + mkdir -p $sample/bin + mv clients/staging/hipfft_* $sample/bin + patchelf $sample/bin/hipfft_* --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -105,6 +121,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/hiprand/default.nix b/pkgs/development/rocm-modules/6/hiprand/default.nix index 1541ff3ef95f93..796e73c4e9e228 100644 --- a/pkgs/development/rocm-modules/6/hiprand/default.nix +++ b/pkgs/development/rocm-modules/6/hiprand/default.nix @@ -1,25 +1,28 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, rocrand -, gtest -, buildTests ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + rocrand, + gtest, + buildTests ? false, + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { pname = "hiprand"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -36,20 +39,23 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ rocrand ] ++ (lib.optionals buildTests [ gtest ]); - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-DHIP_ROOT_DIR=${clr}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_TEST=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-DHIP_ROOT_DIR=${clr}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_TEST=ON" + ]; postInstall = lib.optionalString buildTests '' mkdir -p $test/bin @@ -71,6 +77,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/hipsolver/default.nix b/pkgs/development/rocm-modules/6/hipsolver/default.nix index 43971dc23ebfa9..de2e3a049b6523 100644 --- a/pkgs/development/rocm-modules/6/hipsolver/default.nix +++ b/pkgs/development/rocm-modules/6/hipsolver/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, gfortran -, rocblas -, rocsolver -, gtest -, lapack-reference -, buildTests ? false -, buildBenchmarks ? false -, buildSamples ? false +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + gfortran, + rocblas, + rocsolver, + gtest, + lapack-reference, + buildTests ? false, + buildBenchmarks ? false, + buildSamples ? false, }: # Can also use cuSOLVER @@ -20,15 +21,19 @@ stdenv.mkDerivation (finalAttrs: { pname = "hipsolver"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ] ++ lib.optionals buildSamples [ - "sample" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ] + ++ lib.optionals buildSamples [ + "sample" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -44,44 +49,55 @@ stdenv.mkDerivation (finalAttrs: { gfortran ]; - buildInputs = [ - rocblas - rocsolver - ] ++ lib.optionals buildTests [ - gtest - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - lapack-reference - ]; + buildInputs = + [ + rocblas + rocsolver + ] + ++ lib.optionals buildTests [ + gtest + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + lapack-reference + ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_BENCHMARKS=ON" - ] ++ lib.optionals buildSamples [ - "-DBUILD_CLIENTS_SAMPLES=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_BENCHMARKS=ON" + ] + ++ lib.optionals buildSamples [ + "-DBUILD_CLIENTS_SAMPLES=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/hipsolver-test $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/hipsolver-bench $benchmark/bin - '' + lib.optionalString buildSamples '' - mkdir -p $sample/bin - mv clients/staging/example-* $sample/bin - patchelf $sample/bin/example-* --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/hipsolver-test $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/hipsolver-bench $benchmark/bin + '' + + lib.optionalString buildSamples '' + mkdir -p $sample/bin + mv clients/staging/example-* $sample/bin + patchelf $sample/bin/example-* --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -95,6 +111,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/hipsparse/default.nix b/pkgs/development/rocm-modules/6/hipsparse/default.nix index ba5854e01f3996..20257d629a00b3 100644 --- a/pkgs/development/rocm-modules/6/hipsparse/default.nix +++ b/pkgs/development/rocm-modules/6/hipsparse/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocsparse -, clr -, gfortran -, git -, gtest -, openmp -, buildTests ? false -, buildSamples ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocsparse, + clr, + gfortran, + git, + gtest, + openmp, + buildTests ? false, + buildSamples ? false, + gpuTargets ? [ ], }: # This can also use cuSPARSE as a backend instead of rocSPARSE @@ -20,13 +21,16 @@ stdenv.mkDerivation (finalAttrs: { pname = "hipsparse"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildSamples [ - "sample" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildSamples [ + "sample" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -42,29 +46,35 @@ stdenv.mkDerivation (finalAttrs: { gfortran ]; - buildInputs = [ - rocsparse - git - ] ++ lib.optionals buildTests [ - gtest - ] ++ lib.optionals (buildTests || buildSamples) [ - openmp - ]; + buildInputs = + [ + rocsparse + git + ] + ++ lib.optionals buildTests [ + gtest + ] + ++ lib.optionals (buildTests || buildSamples) [ + openmp + ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-DBUILD_CLIENTS_SAMPLES=${if buildSamples then "ON" else "OFF"}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-DBUILD_CLIENTS_SAMPLES=${if buildSamples then "ON" else "OFF"}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ]; # We have to manually generate the matrices # CMAKE_MATRICES_DIR seems to be reset in clients/tests/CMakeLists.txt @@ -107,17 +117,26 @@ stdenv.mkDerivation (finalAttrs: { --replace "\''${PROJECT_BINARY_DIR}/matrices" "/build/source/matrices" ''; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/hipsparse-test $test/bin - mv /build/source/matrices $test - rmdir $out/bin - '' + lib.optionalString buildSamples '' - mkdir -p $sample/bin - mv clients/staging/example_* $sample/bin - patchelf --set-rpath $out/lib:${lib.makeLibraryPath ( - finalAttrs.buildInputs ++ [ clr gfortran.cc ])} $sample/bin/example_* - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/hipsparse-test $test/bin + mv /build/source/matrices $test + rmdir $out/bin + '' + + lib.optionalString buildSamples '' + mkdir -p $sample/bin + mv clients/staging/example_* $sample/bin + patchelf --set-rpath $out/lib:${ + lib.makeLibraryPath ( + finalAttrs.buildInputs + ++ [ + clr + gfortran.cc + ] + ) + } $sample/bin/example_* + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -131,6 +150,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/hsa-amd-aqlprofile-bin/default.nix b/pkgs/development/rocm-modules/6/hsa-amd-aqlprofile-bin/default.nix index b88485b5fa3703..fb2f2c84379b52 100644 --- a/pkgs/development/rocm-modules/6/hsa-amd-aqlprofile-bin/default.nix +++ b/pkgs/development/rocm-modules/6/hsa-amd-aqlprofile-bin/default.nix @@ -1,23 +1,26 @@ -{ lib -, stdenv -, fetchurl -, callPackage -, dpkg +{ + lib, + stdenv, + fetchurl, + callPackage, + dpkg, }: stdenv.mkDerivation (finalAttrs: { pname = "hsa-amd-aqlprofile-bin"; version = "6.0.2"; - src = let - version = finalAttrs.version; - dotless = builtins.replaceStrings ["."] ["0"] version; - incremental = "115"; - osRelease = "22.04"; - in fetchurl { - url = "https://repo.radeon.com/rocm/apt/${version}/pool/main/h/hsa-amd-aqlprofile/hsa-amd-aqlprofile_1.0.0.${dotless}.${dotless}-${incremental}~${osRelease}_amd64.deb"; - hash = "sha256-0XeKUKaof5pSMS/UgLwumBDBYgyH/pCex9jViUKENXY="; - }; + src = + let + version = finalAttrs.version; + dotless = builtins.replaceStrings [ "." ] [ "0" ] version; + incremental = "115"; + osRelease = "22.04"; + in + fetchurl { + url = "https://repo.radeon.com/rocm/apt/${version}/pool/main/h/hsa-amd-aqlprofile/hsa-amd-aqlprofile_1.0.0.${dotless}.${dotless}-${incremental}~${osRelease}_amd64.deb"; + hash = "sha256-0XeKUKaof5pSMS/UgLwumBDBYgyH/pCex9jViUKENXY="; + }; nativeBuildInputs = [ dpkg ]; dontPatch = true; @@ -43,6 +46,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ unfree ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/hsa-amd-aqlprofile-bin/update.nix b/pkgs/development/rocm-modules/6/hsa-amd-aqlprofile-bin/update.nix index 7fdcfad859247e..ed834c84a67807 100644 --- a/pkgs/development/rocm-modules/6/hsa-amd-aqlprofile-bin/update.nix +++ b/pkgs/development/rocm-modules/6/hsa-amd-aqlprofile-bin/update.nix @@ -1,12 +1,15 @@ -{ lib -, writeScript +{ + lib, + writeScript, }: { version }: let prefix = "hsa-amd-aqlprofile"; - extVersion = lib.strings.concatStrings (lib.strings.intersperse "0" (lib.versions.splitVersion version)); + extVersion = lib.strings.concatStrings ( + lib.strings.intersperse "0" (lib.versions.splitVersion version) + ); major = lib.versions.major version; minor = lib.versions.minor version; patch = lib.versions.patch version; @@ -54,4 +57,5 @@ let update-source-version rocmPackages_6.${prefix}-bin "$version" "" "$apt/$repoVersion/$pool$deb" --ignore-same-hash fi ''; -in [ updateScript ] +in +[ updateScript ] diff --git a/pkgs/development/rocm-modules/6/llvm/base.nix b/pkgs/development/rocm-modules/6/llvm/base.nix index b7a919c792ba01..bbe964547a9cb0 100644 --- a/pkgs/development/rocm-modules/6/llvm/base.nix +++ b/pkgs/development/rocm-modules/6/llvm/base.nix @@ -1,76 +1,84 @@ -{ lib -, stdenv -, gcc12Stdenv -, fetchFromGitHub -, rocmUpdateScript -, pkg-config -, cmake -, ninja -, git -, doxygen -, sphinx -, lit -, libxml2 -, libxcrypt -, libedit -, libffi -, mpfr -, zlib -, ncurses -, python3Packages -, buildDocs ? true -, buildMan ? true -, buildTests ? true -, targetName ? "llvm" -, targetDir ? "llvm" -, targetProjects ? [ ] -, targetRuntimes ? [ ] -, llvmTargetsToBuild ? [ "NATIVE" ] # "NATIVE" resolves into x86 or aarch64 depending on stdenv -, extraPatches ? [ ] -, extraNativeBuildInputs ? [ ] -, extraBuildInputs ? [ ] -, extraCMakeFlags ? [ ] -, extraPostPatch ? "" -, checkTargets ? [( - lib.optionalString buildTests ( - if targetDir == "runtimes" - then "check-runtimes" - else "check-all" - ) -)] -, extraPostInstall ? "" -, hardeningDisable ? [ ] -, requiredSystemFeatures ? [ ] -, extraLicenses ? [ ] -, isBroken ? false +{ + lib, + stdenv, + gcc12Stdenv, + fetchFromGitHub, + rocmUpdateScript, + pkg-config, + cmake, + ninja, + git, + doxygen, + sphinx, + lit, + libxml2, + libxcrypt, + libedit, + libffi, + mpfr, + zlib, + ncurses, + python3Packages, + buildDocs ? true, + buildMan ? true, + buildTests ? true, + targetName ? "llvm", + targetDir ? "llvm", + targetProjects ? [ ], + targetRuntimes ? [ ], + llvmTargetsToBuild ? [ "NATIVE" ], # "NATIVE" resolves into x86 or aarch64 depending on stdenv + extraPatches ? [ ], + extraNativeBuildInputs ? [ ], + extraBuildInputs ? [ ], + extraCMakeFlags ? [ ], + extraPostPatch ? "", + checkTargets ? [ + (lib.optionalString buildTests (if targetDir == "runtimes" then "check-runtimes" else "check-all")) + ], + extraPostInstall ? "", + hardeningDisable ? [ ], + requiredSystemFeatures ? [ ], + extraLicenses ? [ ], + isBroken ? false, }: -let stdenv' = stdenv; in -let stdenv = - if stdenv'.cc.cc.isGNU or false && lib.versionAtLeast stdenv'.cc.cc.version "13.0" - then gcc12Stdenv - else stdenv'; +let + stdenv' = stdenv; +in +let + stdenv = + if stdenv'.cc.cc.isGNU or false && lib.versionAtLeast stdenv'.cc.cc.version "13.0" then + gcc12Stdenv + else + stdenv'; in let llvmNativeTarget = - if stdenv.hostPlatform.isx86_64 then "X86" - else if stdenv.hostPlatform.isAarch64 then "AArch64" - else throw "Unsupported ROCm LLVM platform"; + if stdenv.hostPlatform.isx86_64 then + "X86" + else if stdenv.hostPlatform.isAarch64 then + "AArch64" + else + throw "Unsupported ROCm LLVM platform"; inferNativeTarget = t: if t == "NATIVE" then llvmNativeTarget else t; llvmTargetsToBuild' = [ "AMDGPU" ] ++ builtins.map inferNativeTarget llvmTargetsToBuild; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "rocm-llvm-${targetName}"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ] ++ lib.optionals buildMan [ - "man" - "info" # Avoid `attribute 'info' missing` when using with wrapCC - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ] + ++ lib.optionals buildMan [ + "man" + "info" # Avoid `attribute 'info' missing` when using with wrapCC + ]; patches = extraPatches; @@ -81,19 +89,23 @@ in stdenv.mkDerivation (finalAttrs: { hash = "sha256-uGxalrwMNCOSqSFVrYUBi3ijkMEFFTrzFImmvZKQf6I="; }; - nativeBuildInputs = [ - pkg-config - cmake - ninja - git - (python3Packages.python.withPackages (p: [ p.setuptools ])) - ] ++ lib.optionals (buildDocs || buildMan) [ - doxygen - sphinx - python3Packages.recommonmark - ] ++ lib.optionals (buildTests && !finalAttrs.passthru.isLLVM) [ - lit - ] ++ extraNativeBuildInputs; + nativeBuildInputs = + [ + pkg-config + cmake + ninja + git + (python3Packages.python.withPackages (p: [ p.setuptools ])) + ] + ++ lib.optionals (buildDocs || buildMan) [ + doxygen + sphinx + python3Packages.recommonmark + ] + ++ lib.optionals (buildTests && !finalAttrs.passthru.isLLVM) [ + lit + ] + ++ extraNativeBuildInputs; buildInputs = [ libxml2 @@ -110,53 +122,68 @@ in stdenv.mkDerivation (finalAttrs: { sourceRoot = "${finalAttrs.src.name}/${targetDir}"; - cmakeFlags = [ - "-DLLVM_TARGETS_TO_BUILD=${builtins.concatStringsSep ";" llvmTargetsToBuild'}" - ] ++ lib.optionals (finalAttrs.passthru.isLLVM && targetProjects != [ ]) [ - "-DLLVM_ENABLE_PROJECTS=${lib.concatStringsSep ";" targetProjects}" - ] ++ lib.optionals ((finalAttrs.passthru.isLLVM || targetDir == "runtimes") && targetRuntimes != [ ]) [ - "-DLLVM_ENABLE_RUNTIMES=${lib.concatStringsSep ";" targetRuntimes}" - ] ++ lib.optionals finalAttrs.passthru.isLLVM [ - "-DLLVM_INSTALL_UTILS=ON" - "-DLLVM_INSTALL_GTEST=ON" - ] ++ lib.optionals (buildDocs || buildMan) [ - "-DLLVM_INCLUDE_DOCS=ON" - "-DLLVM_BUILD_DOCS=ON" - # "-DLLVM_ENABLE_DOXYGEN=ON" Way too slow, only uses one core - "-DLLVM_ENABLE_SPHINX=ON" - "-DSPHINX_OUTPUT_HTML=ON" - "-DSPHINX_OUTPUT_MAN=ON" - "-DSPHINX_WARNINGS_AS_ERRORS=OFF" - ] ++ lib.optionals buildTests [ - "-DLLVM_INCLUDE_TESTS=ON" - "-DLLVM_BUILD_TESTS=ON" - "-DLLVM_EXTERNAL_LIT=${lit}/bin/.lit-wrapped" - ] ++ extraCMakeFlags; + cmakeFlags = + [ + "-DLLVM_TARGETS_TO_BUILD=${builtins.concatStringsSep ";" llvmTargetsToBuild'}" + ] + ++ lib.optionals (finalAttrs.passthru.isLLVM && targetProjects != [ ]) [ + "-DLLVM_ENABLE_PROJECTS=${lib.concatStringsSep ";" targetProjects}" + ] + ++ + lib.optionals ((finalAttrs.passthru.isLLVM || targetDir == "runtimes") && targetRuntimes != [ ]) + [ + "-DLLVM_ENABLE_RUNTIMES=${lib.concatStringsSep ";" targetRuntimes}" + ] + ++ lib.optionals finalAttrs.passthru.isLLVM [ + "-DLLVM_INSTALL_UTILS=ON" + "-DLLVM_INSTALL_GTEST=ON" + ] + ++ lib.optionals (buildDocs || buildMan) [ + "-DLLVM_INCLUDE_DOCS=ON" + "-DLLVM_BUILD_DOCS=ON" + # "-DLLVM_ENABLE_DOXYGEN=ON" Way too slow, only uses one core + "-DLLVM_ENABLE_SPHINX=ON" + "-DSPHINX_OUTPUT_HTML=ON" + "-DSPHINX_OUTPUT_MAN=ON" + "-DSPHINX_WARNINGS_AS_ERRORS=OFF" + ] + ++ lib.optionals buildTests [ + "-DLLVM_INCLUDE_TESTS=ON" + "-DLLVM_BUILD_TESTS=ON" + "-DLLVM_EXTERNAL_LIT=${lit}/bin/.lit-wrapped" + ] + ++ extraCMakeFlags; prePatch = '' cd ../ chmod -R u+w . ''; - postPatch = '' - cd ${targetDir} - '' + lib.optionalString finalAttrs.passthru.isLLVM '' - patchShebangs lib/OffloadArch/make_generated_offload_arch_h.sh - '' + lib.optionalString (buildTests && finalAttrs.passthru.isLLVM) '' - # FileSystem permissions tests fail with various special bits - rm test/tools/llvm-objcopy/ELF/mirror-permissions-unix.test - rm unittests/Support/Path.cpp - - substituteInPlace unittests/Support/CMakeLists.txt \ - --replace-fail "Path.cpp" "" - '' + extraPostPatch; + postPatch = + '' + cd ${targetDir} + '' + + lib.optionalString finalAttrs.passthru.isLLVM '' + patchShebangs lib/OffloadArch/make_generated_offload_arch_h.sh + '' + + lib.optionalString (buildTests && finalAttrs.passthru.isLLVM) '' + # FileSystem permissions tests fail with various special bits + rm test/tools/llvm-objcopy/ELF/mirror-permissions-unix.test + rm unittests/Support/Path.cpp + + substituteInPlace unittests/Support/CMakeLists.txt \ + --replace-fail "Path.cpp" "" + '' + + extraPostPatch; doCheck = buildTests; checkTarget = lib.concatStringsSep " " checkTargets; - postInstall = lib.optionalString buildMan '' - mkdir -p $info - '' + extraPostInstall; + postInstall = + lib.optionalString buildMan '' + mkdir -p $info + '' + + extraPostInstall; passthru = { isLLVM = targetDir == "llvm"; @@ -175,7 +202,13 @@ in stdenv.mkDerivation (finalAttrs: { description = "ROCm fork of the LLVM compiler infrastructure"; homepage = "https://github.com/ROCm/llvm-project"; license = with licenses; [ ncsa ] ++ extraLicenses; - maintainers = with maintainers; [ acowley lovesegfault ] ++ teams.rocm.members; + maintainers = + with maintainers; + [ + acowley + lovesegfault + ] + ++ teams.rocm.members; platforms = platforms.linux; broken = isBroken || versionAtLeast finalAttrs.version "7.0.0"; }; diff --git a/pkgs/development/rocm-modules/6/llvm/default.nix b/pkgs/development/rocm-modules/6/llvm/default.nix index 9c8919165a516f..f68d29e37a19c4 100644 --- a/pkgs/development/rocm-modules/6/llvm/default.nix +++ b/pkgs/development/rocm-modules/6/llvm/default.nix @@ -1,58 +1,142 @@ -{ # stdenv FIXME: Try changing back to this with a new ROCm release https://github.com/NixOS/nixpkgs/issues/271943 - gcc12Stdenv -, callPackage -, rocmUpdateScript -, wrapBintoolsWith -, overrideCC -, rocm-device-libs -, rocm-runtime -, rocm-thunk -, clr +{ + # stdenv FIXME: Try changing back to this with a new ROCm release https://github.com/NixOS/nixpkgs/issues/271943 + gcc12Stdenv, + callPackage, + rocmUpdateScript, + wrapBintoolsWith, + overrideCC, + rocm-device-libs, + rocm-runtime, + rocm-thunk, + clr, }: let ## Stage 1 ## # Projects - llvm = callPackage ./stage-1/llvm.nix { inherit rocmUpdateScript; stdenv = gcc12Stdenv; }; - clang-unwrapped = callPackage ./stage-1/clang-unwrapped.nix { inherit rocmUpdateScript llvm; stdenv = gcc12Stdenv; }; - lld = callPackage ./stage-1/lld.nix { inherit rocmUpdateScript llvm; stdenv = gcc12Stdenv; }; + llvm = callPackage ./stage-1/llvm.nix { + inherit rocmUpdateScript; + stdenv = gcc12Stdenv; + }; + clang-unwrapped = callPackage ./stage-1/clang-unwrapped.nix { + inherit rocmUpdateScript llvm; + stdenv = gcc12Stdenv; + }; + lld = callPackage ./stage-1/lld.nix { + inherit rocmUpdateScript llvm; + stdenv = gcc12Stdenv; + }; # Runtimes - runtimes = callPackage ./stage-1/runtimes.nix { inherit rocmUpdateScript llvm; stdenv = gcc12Stdenv; }; + runtimes = callPackage ./stage-1/runtimes.nix { + inherit rocmUpdateScript llvm; + stdenv = gcc12Stdenv; + }; ## Stage 2 ## # Helpers bintools-unwrapped = callPackage ./stage-2/bintools-unwrapped.nix { inherit llvm lld; }; bintools = wrapBintoolsWith { bintools = bintools-unwrapped; }; - rStdenv = callPackage ./stage-2/rstdenv.nix { inherit llvm clang-unwrapped lld runtimes bintools; stdenv = gcc12Stdenv; }; -in rec { + rStdenv = callPackage ./stage-2/rstdenv.nix { + inherit + llvm + clang-unwrapped + lld + runtimes + bintools + ; + stdenv = gcc12Stdenv; + }; +in +rec { inherit - llvm - clang-unwrapped - lld - bintools; + llvm + clang-unwrapped + lld + bintools + ; # Runtimes - libc = callPackage ./stage-2/libc.nix { inherit rocmUpdateScript; stdenv = rStdenv; }; - libunwind = callPackage ./stage-2/libunwind.nix { inherit rocmUpdateScript; stdenv = rStdenv; }; - libcxxabi = callPackage ./stage-2/libcxxabi.nix { inherit rocmUpdateScript; stdenv = rStdenv; }; - libcxx = callPackage ./stage-2/libcxx.nix { inherit rocmUpdateScript; stdenv = rStdenv; }; - compiler-rt = callPackage ./stage-2/compiler-rt.nix { inherit rocmUpdateScript llvm; stdenv = rStdenv; }; + libc = callPackage ./stage-2/libc.nix { + inherit rocmUpdateScript; + stdenv = rStdenv; + }; + libunwind = callPackage ./stage-2/libunwind.nix { + inherit rocmUpdateScript; + stdenv = rStdenv; + }; + libcxxabi = callPackage ./stage-2/libcxxabi.nix { + inherit rocmUpdateScript; + stdenv = rStdenv; + }; + libcxx = callPackage ./stage-2/libcxx.nix { + inherit rocmUpdateScript; + stdenv = rStdenv; + }; + compiler-rt = callPackage ./stage-2/compiler-rt.nix { + inherit rocmUpdateScript llvm; + stdenv = rStdenv; + }; ## Stage 3 ## # Helpers - clang = callPackage ./stage-3/clang.nix { inherit llvm lld clang-unwrapped bintools libc libunwind libcxxabi libcxx compiler-rt; stdenv = gcc12Stdenv; }; + clang = callPackage ./stage-3/clang.nix { + inherit + llvm + lld + clang-unwrapped + bintools + libc + libunwind + libcxxabi + libcxx + compiler-rt + ; + stdenv = gcc12Stdenv; + }; rocmClangStdenv = overrideCC gcc12Stdenv clang; # Projects - clang-tools-extra = callPackage ./stage-3/clang-tools-extra.nix { inherit rocmUpdateScript llvm clang-unwrapped; stdenv = rocmClangStdenv; }; - libclc = callPackage ./stage-3/libclc.nix { inherit rocmUpdateScript llvm clang; stdenv = rocmClangStdenv; }; - lldb = callPackage ./stage-3/lldb.nix { inherit rocmUpdateScript clang; stdenv = rocmClangStdenv; }; - mlir = callPackage ./stage-3/mlir.nix { inherit rocmUpdateScript clr; stdenv = rocmClangStdenv; }; - polly = callPackage ./stage-3/polly.nix { inherit rocmUpdateScript; stdenv = rocmClangStdenv; }; - flang = callPackage ./stage-3/flang.nix { inherit rocmUpdateScript clang-unwrapped mlir; stdenv = rocmClangStdenv; }; - openmp = callPackage ./stage-3/openmp.nix { inherit rocmUpdateScript llvm clang-unwrapped clang rocm-device-libs rocm-runtime rocm-thunk; stdenv = rocmClangStdenv; }; + clang-tools-extra = callPackage ./stage-3/clang-tools-extra.nix { + inherit rocmUpdateScript llvm clang-unwrapped; + stdenv = rocmClangStdenv; + }; + libclc = callPackage ./stage-3/libclc.nix { + inherit rocmUpdateScript llvm clang; + stdenv = rocmClangStdenv; + }; + lldb = callPackage ./stage-3/lldb.nix { + inherit rocmUpdateScript clang; + stdenv = rocmClangStdenv; + }; + mlir = callPackage ./stage-3/mlir.nix { + inherit rocmUpdateScript clr; + stdenv = rocmClangStdenv; + }; + polly = callPackage ./stage-3/polly.nix { + inherit rocmUpdateScript; + stdenv = rocmClangStdenv; + }; + flang = callPackage ./stage-3/flang.nix { + inherit rocmUpdateScript clang-unwrapped mlir; + stdenv = rocmClangStdenv; + }; + openmp = callPackage ./stage-3/openmp.nix { + inherit + rocmUpdateScript + llvm + clang-unwrapped + clang + rocm-device-libs + rocm-runtime + rocm-thunk + ; + stdenv = rocmClangStdenv; + }; # Runtimes - pstl = callPackage ./stage-3/pstl.nix { inherit rocmUpdateScript; stdenv = rocmClangStdenv; }; + pstl = callPackage ./stage-3/pstl.nix { + inherit rocmUpdateScript; + stdenv = rocmClangStdenv; + }; } diff --git a/pkgs/development/rocm-modules/6/llvm/stage-1/clang-unwrapped.nix b/pkgs/development/rocm-modules/6/llvm/stage-1/clang-unwrapped.nix index 1cf60223def6f3..dc9af79816c31c 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-1/clang-unwrapped.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-1/clang-unwrapped.nix @@ -1,7 +1,8 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, llvm +{ + stdenv, + callPackage, + rocmUpdateScript, + llvm, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-1/lld.nix b/pkgs/development/rocm-modules/6/llvm/stage-1/lld.nix index 5ca8bca25a3385..6a6226a221e08b 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-1/lld.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-1/lld.nix @@ -1,7 +1,8 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, llvm +{ + stdenv, + callPackage, + rocmUpdateScript, + llvm, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-1/llvm.nix b/pkgs/development/rocm-modules/6/llvm/stage-1/llvm.nix index ad4981aa435be9..a9464da16697a2 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-1/llvm.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-1/llvm.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-1/runtimes.nix b/pkgs/development/rocm-modules/6/llvm/stage-1/runtimes.nix index 0364a02e6e59b4..268ad973b9134f 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-1/runtimes.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-1/runtimes.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, callPackage -, rocmUpdateScript -, llvm +{ + lib, + stdenv, + callPackage, + rocmUpdateScript, + llvm, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-2/bintools-unwrapped.nix b/pkgs/development/rocm-modules/6/llvm/stage-2/bintools-unwrapped.nix index ef40dd4d38246b..e17a913d4bb77d 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-2/bintools-unwrapped.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-2/bintools-unwrapped.nix @@ -1,6 +1,7 @@ -{ runCommand -, llvm -, lld +{ + runCommand, + llvm, + lld, }: runCommand "rocm-llvm-binutils-${llvm.version}" { preferLocalBuild = true; } '' diff --git a/pkgs/development/rocm-modules/6/llvm/stage-2/compiler-rt.nix b/pkgs/development/rocm-modules/6/llvm/stage-2/compiler-rt.nix index 3b8e41705e1a7b..f3b8648e11045b 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-2/compiler-rt.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-2/compiler-rt.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, callPackage -, rocmUpdateScript -, llvm -, glibc +{ + lib, + stdenv, + callPackage, + rocmUpdateScript, + llvm, + glibc, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-2/libc.nix b/pkgs/development/rocm-modules/6/llvm/stage-2/libc.nix index 2446723ef5feab..26d33460d4338c 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-2/libc.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-2/libc.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-2/libcxx.nix b/pkgs/development/rocm-modules/6/llvm/stage-2/libcxx.nix index 473227242765be..b9ed102d5408ad 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-2/libcxx.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-2/libcxx.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-2/libcxxabi.nix b/pkgs/development/rocm-modules/6/llvm/stage-2/libcxxabi.nix index e15ec777ff61a7..bc54e17be45fb0 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-2/libcxxabi.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-2/libcxxabi.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-2/libunwind.nix b/pkgs/development/rocm-modules/6/llvm/stage-2/libunwind.nix index 3d599e0d4b3250..fb5e7cb3b68ca8 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-2/libunwind.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-2/libunwind.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-2/rstdenv.nix b/pkgs/development/rocm-modules/6/llvm/stage-2/rstdenv.nix index 3820d45a2b814d..f83abe36cc2e28 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-2/rstdenv.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-2/rstdenv.nix @@ -1,11 +1,12 @@ -{ stdenv -, overrideCC -, wrapCCWith -, llvm -, clang-unwrapped -, lld -, runtimes -, bintools +{ + stdenv, + overrideCC, + wrapCCWith, + llvm, + clang-unwrapped, + lld, + runtimes, + bintools, }: overrideCC stdenv (wrapCCWith rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-3/clang-tools-extra.nix b/pkgs/development/rocm-modules/6/llvm/stage-3/clang-tools-extra.nix index d18673ecb3db4b..4351c4bc6629de 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-3/clang-tools-extra.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-3/clang-tools-extra.nix @@ -1,9 +1,10 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, llvm -, clang-unwrapped -, gtest +{ + stdenv, + callPackage, + rocmUpdateScript, + llvm, + clang-unwrapped, + gtest, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-3/clang.nix b/pkgs/development/rocm-modules/6/llvm/stage-3/clang.nix index a0e1935d3c5fea..894ffed8b8b610 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-3/clang.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-3/clang.nix @@ -1,14 +1,15 @@ -{ stdenv -, wrapCCWith -, llvm -, lld -, clang-unwrapped -, bintools -, libc -, libunwind -, libcxxabi -, libcxx -, compiler-rt +{ + stdenv, + wrapCCWith, + llvm, + lld, + clang-unwrapped, + bintools, + libc, + libunwind, + libcxxabi, + libcxx, + compiler-rt, }: wrapCCWith rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-3/flang.nix b/pkgs/development/rocm-modules/6/llvm/stage-3/flang.nix index 421663dcb1b769..c6e72d56ce566e 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-3/flang.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-3/flang.nix @@ -1,10 +1,11 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, clang-unwrapped -, mlir -, graphviz -, python3Packages +{ + stdenv, + callPackage, + rocmUpdateScript, + clang-unwrapped, + mlir, + graphviz, + python3Packages, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-3/libclc.nix b/pkgs/development/rocm-modules/6/llvm/stage-3/libclc.nix index c395dd792db018..c8a6b98d913010 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-3/libclc.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-3/libclc.nix @@ -1,14 +1,16 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, llvm -, clang -, spirv-llvm-translator +{ + stdenv, + callPackage, + rocmUpdateScript, + llvm, + clang, + spirv-llvm-translator, }: let spirv = (spirv-llvm-translator.override { inherit llvm; }); -in callPackage ../base.nix rec { +in +callPackage ../base.nix rec { inherit stdenv rocmUpdateScript; buildDocs = false; # No documentation to build buildMan = false; # No man pages to build diff --git a/pkgs/development/rocm-modules/6/llvm/stage-3/lldb.nix b/pkgs/development/rocm-modules/6/llvm/stage-3/lldb.nix index 9b7d25e06d9d68..31694ce50113f7 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-3/lldb.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-3/lldb.nix @@ -1,13 +1,14 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, clang -, xz -, swig -, lua5_3 -, graphviz -, gtest -, python3Packages +{ + stdenv, + callPackage, + rocmUpdateScript, + clang, + xz, + swig, + lua5_3, + graphviz, + gtest, + python3Packages, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-3/mlir.nix b/pkgs/development/rocm-modules/6/llvm/stage-3/mlir.nix index 7611a30165a72d..9b87769e3e8fea 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-3/mlir.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-3/mlir.nix @@ -1,12 +1,13 @@ -{ stdenv -, callPackage -, rocmUpdateScript -, clr -, vulkan-headers -, vulkan-loader -, glslang -, shaderc -, fetchpatch +{ + stdenv, + callPackage, + rocmUpdateScript, + clr, + vulkan-headers, + vulkan-loader, + glslang, + shaderc, + fetchpatch, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-3/openmp.nix b/pkgs/development/rocm-modules/6/llvm/stage-3/openmp.nix index 5fd7b6fd9aa3d0..25816610578092 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-3/openmp.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-3/openmp.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, callPackage -, rocmUpdateScript -, llvm -, clang -, clang-unwrapped -, rocm-device-libs -, rocm-runtime -, rocm-thunk -, perl -, elfutils -, libdrm -, numactl -, lit +{ + lib, + stdenv, + callPackage, + rocmUpdateScript, + llvm, + clang, + clang-unwrapped, + rocm-device-libs, + rocm-runtime, + rocm-thunk, + perl, + elfutils, + libdrm, + numactl, + lit, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-3/polly.nix b/pkgs/development/rocm-modules/6/llvm/stage-3/polly.nix index da5c2e16f5d3b3..d70a353d3a8cf6 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-3/polly.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-3/polly.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/llvm/stage-3/pstl.nix b/pkgs/development/rocm-modules/6/llvm/stage-3/pstl.nix index dc7d7cd6ccbfa1..63fba911677cc4 100644 --- a/pkgs/development/rocm-modules/6/llvm/stage-3/pstl.nix +++ b/pkgs/development/rocm-modules/6/llvm/stage-3/pstl.nix @@ -1,6 +1,7 @@ -{ stdenv -, callPackage -, rocmUpdateScript +{ + stdenv, + callPackage, + rocmUpdateScript, }: callPackage ../base.nix rec { diff --git a/pkgs/development/rocm-modules/6/migraphx/default.nix b/pkgs/development/rocm-modules/6/migraphx/default.nix index 4cc2e4bd24b35c..137f3a23470877 100644 --- a/pkgs/development/rocm-modules/6/migraphx/default.nix +++ b/pkgs/development/rocm-modules/6/migraphx/default.nix @@ -1,62 +1,71 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, pkg-config -, cmake -, rocm-cmake -, clr -, clang-tools-extra -, openmp -, rocblas -, rocmlir -, composable_kernel -, miopen -, protobuf -, half -, nlohmann_json -, msgpack -, sqlite -, oneDNN_2 -, blaze -, cppcheck -, rocm-device-libs -, texliveSmall -, doxygen -, sphinx -, docutils -, ghostscript -, python3Packages -, buildDocs ? false -, buildTests ? false -, gpuTargets ? clr.gpuTargets +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + pkg-config, + cmake, + rocm-cmake, + clr, + clang-tools-extra, + openmp, + rocblas, + rocmlir, + composable_kernel, + miopen, + protobuf, + half, + nlohmann_json, + msgpack, + sqlite, + oneDNN_2, + blaze, + cppcheck, + rocm-device-libs, + texliveSmall, + doxygen, + sphinx, + docutils, + ghostscript, + python3Packages, + buildDocs ? false, + buildTests ? false, + gpuTargets ? clr.gpuTargets, }: let - latex = lib.optionalAttrs buildDocs (texliveSmall.withPackages (ps: with ps; [ - latexmk - tex-gyre - fncychap - wrapfig - capt-of - framed - needspace - tabulary - varwidth - titlesec - epstopdf - ])); -in stdenv.mkDerivation (finalAttrs: { + latex = lib.optionalAttrs buildDocs ( + texliveSmall.withPackages ( + ps: with ps; [ + latexmk + tex-gyre + fncychap + wrapfig + capt-of + framed + needspace + tabulary + varwidth + titlesec + epstopdf + ] + ) + ); +in +stdenv.mkDerivation (finalAttrs: { pname = "migraphx"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ] ++ lib.optionals buildTests [ - "test" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ] + ++ lib.optionals buildTests [ + "test" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -65,22 +74,24 @@ in stdenv.mkDerivation (finalAttrs: { hash = "sha256-VDYUSpWYAdJ63SKVCO26DVAC3RtZM7otqN0sYUA6DBQ="; }; - nativeBuildInputs = [ - pkg-config - cmake - rocm-cmake - clr - clang-tools-extra - python3Packages.python - ] ++ lib.optionals buildDocs [ - latex - doxygen - sphinx - docutils - ghostscript - python3Packages.sphinx-rtd-theme - python3Packages.breathe - ]; + nativeBuildInputs = + [ + pkg-config + cmake + rocm-cmake + clr + clang-tools-extra + python3Packages.python + ] + ++ lib.optionals buildDocs [ + latex + doxygen + sphinx + docutils + ghostscript + python3Packages.sphinx-rtd-theme + python3Packages.breathe + ]; buildInputs = [ openmp @@ -113,28 +124,31 @@ in stdenv.mkDerivation (finalAttrs: { "-DGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" ]; - postPatch = '' - # We need to not use hipcc and define the CXXFLAGS manually due to `undefined hidden symbol: tensorflow:: ...` - export CXXFLAGS+="--rocm-path=${clr} --rocm-device-lib-path=${rocm-device-libs}/amdgcn/bitcode" - patchShebangs tools + postPatch = + '' + # We need to not use hipcc and define the CXXFLAGS manually due to `undefined hidden symbol: tensorflow:: ...` + export CXXFLAGS+="--rocm-path=${clr} --rocm-device-lib-path=${rocm-device-libs}/amdgcn/bitcode" + patchShebangs tools - # `error: '__clang_hip_runtime_wrapper.h' file not found [clang-diagnostic-error]` - substituteInPlace CMakeLists.txt \ - --replace "set(MIGRAPHX_TIDY_ERRORS ALL)" "" + # `error: '__clang_hip_runtime_wrapper.h' file not found [clang-diagnostic-error]` + substituteInPlace CMakeLists.txt \ + --replace "set(MIGRAPHX_TIDY_ERRORS ALL)" "" - # JIT library was removed from composable_kernel... - # https://github.com/ROCm/composable_kernel/issues/782 - substituteInPlace src/targets/gpu/CMakeLists.txt \ - --replace " COMPONENTS jit_library" "" \ - --replace " composable_kernel::jit_library" "" \ - --replace "if(WIN32)" "if(TRUE)" - '' + lib.optionalString (!buildDocs) '' - substituteInPlace CMakeLists.txt \ - --replace "add_subdirectory(doc)" "" - '' + lib.optionalString (!buildTests) '' - substituteInPlace CMakeLists.txt \ - --replace "add_subdirectory(test)" "" - ''; + # JIT library was removed from composable_kernel... + # https://github.com/ROCm/composable_kernel/issues/782 + substituteInPlace src/targets/gpu/CMakeLists.txt \ + --replace " COMPONENTS jit_library" "" \ + --replace " composable_kernel::jit_library" "" \ + --replace "if(WIN32)" "if(TRUE)" + '' + + lib.optionalString (!buildDocs) '' + substituteInPlace CMakeLists.txt \ + --replace "add_subdirectory(doc)" "" + '' + + lib.optionalString (!buildTests) '' + substituteInPlace CMakeLists.txt \ + --replace "add_subdirectory(test)" "" + ''; # Unfortunately, it seems like we have to call make on this manually preInstall = lib.optionalString buildDocs '' @@ -145,14 +159,16 @@ in stdenv.mkDerivation (finalAttrs: { cd - ''; - postInstall = lib.optionalString buildDocs '' - mv ../doc/html $out/share/doc/migraphx - mv ../doc/pdf/MIGraphX.pdf $out/share/doc/migraphx - '' + lib.optionalString buildTests '' - mkdir -p $test/bin - mv bin/test_* $test/bin - patchelf $test/bin/test_* --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" - ''; + postInstall = + lib.optionalString buildDocs '' + mv ../doc/html $out/share/doc/migraphx + mv ../doc/pdf/MIGraphX.pdf $out/share/doc/migraphx + '' + + lib.optionalString buildTests '' + mkdir -p $test/bin + mv bin/test_* $test/bin + patchelf $test/bin/test_* --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; diff --git a/pkgs/development/rocm-modules/6/miopen/default.nix b/pkgs/development/rocm-modules/6/miopen/default.nix index 0b57cf6592cbf5..e815ca00b7f073 100644 --- a/pkgs/development/rocm-modules/6/miopen/default.nix +++ b/pkgs/development/rocm-modules/6/miopen/default.nix @@ -1,36 +1,37 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, rocmUpdateScript -, runCommand -, pkg-config -, cmake -, rocm-cmake -, rocblas -, rocmlir -, clr -, clang-tools-extra -, clang-ocl -, composable_kernel -, frugally-deep -, rocm-docs-core -, half -, boost -, sqlite -, bzip2 -, lbzip2 -, nlohmann_json -, texliveSmall -, doxygen -, sphinx -, zlib -, gtest -, rocm-comgr -, roctracer -, python3Packages -, buildDocs ? false # Needs internet because of rocm-docs-core -, buildTests ? false +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + rocmUpdateScript, + runCommand, + pkg-config, + cmake, + rocm-cmake, + rocblas, + rocmlir, + clr, + clang-tools-extra, + clang-ocl, + composable_kernel, + frugally-deep, + rocm-docs-core, + half, + boost, + sqlite, + bzip2, + lbzip2, + nlohmann_json, + texliveSmall, + doxygen, + sphinx, + zlib, + gtest, + rocm-comgr, + roctracer, + python3Packages, + buildDocs ? false, # Needs internet because of rocm-docs-core + buildTests ? false, }: let @@ -70,18 +71,22 @@ let ''; }; - latex = lib.optionalAttrs buildDocs (texliveSmall.withPackages (ps: with ps; [ - latexmk - tex-gyre - fncychap - wrapfig - capt-of - framed - needspace - tabulary - varwidth - titlesec - ])); + latex = lib.optionalAttrs buildDocs ( + texliveSmall.withPackages ( + ps: with ps; [ + latexmk + tex-gyre + fncychap + wrapfig + capt-of + framed + needspace + tabulary + varwidth + titlesec + ] + ) + ); gfx900 = runCommand "miopen-gfx900.kdb" { preferLocalBuild = true; } '' ${lbzip2}/bin/lbzip2 -ckd ${src}/src/kernels/gfx900.kdb.bz2 > $out @@ -102,7 +107,8 @@ let gfx1030 = runCommand "miopen-gfx1030.kdb" { preferLocalBuild = true; } '' ${lbzip2}/bin/lbzip2 -ckd ${src}/src/kernels/gfx1030.kdb.bz2 > $out ''; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { inherit version src; pname = "miopen"; @@ -123,13 +129,16 @@ in stdenv.mkDerivation (finalAttrs: { }) ]; - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ] ++ lib.optionals buildTests [ - "test" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ] + ++ lib.optionals buildTests [ + "test" + ]; nativeBuildInputs = [ pkg-config @@ -139,46 +148,51 @@ in stdenv.mkDerivation (finalAttrs: { clang-tools-extra ]; - buildInputs = [ - rocblas - rocmlir - clang-ocl - composable_kernel - half - boost - sqlite - bzip2 - nlohmann_json - frugally-deep - roctracer - ] ++ lib.optionals buildDocs [ - latex - doxygen - sphinx - rocm-docs-core - python3Packages.sphinx-rtd-theme - python3Packages.breathe - python3Packages.myst-parser - ] ++ lib.optionals buildTests [ - gtest - zlib - ]; + buildInputs = + [ + rocblas + rocmlir + clang-ocl + composable_kernel + half + boost + sqlite + bzip2 + nlohmann_json + frugally-deep + roctracer + ] + ++ lib.optionals buildDocs [ + latex + doxygen + sphinx + rocm-docs-core + python3Packages.sphinx-rtd-theme + python3Packages.breathe + python3Packages.myst-parser + ] + ++ lib.optionals buildTests [ + gtest + zlib + ]; - cmakeFlags = [ - "-DCMAKE_CXX_FLAGS=-Wno-#warnings" # -> - "-DUNZIPPER=${bzip2}/bin/bunzip2" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-DMIOPEN_BACKEND=HIP" - ] ++ lib.optionals buildTests [ - "-DBUILD_TESTS=ON" - "-DMIOPEN_TEST_ALL=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_FLAGS=-Wno-#warnings" # -> + "-DUNZIPPER=${bzip2}/bin/bunzip2" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-DMIOPEN_BACKEND=HIP" + ] + ++ lib.optionals buildTests [ + "-DBUILD_TESTS=ON" + "-DMIOPEN_TEST_ALL=ON" + ]; postPatch = '' patchShebangs test src/composable_kernel fin utils install_deps.cmake @@ -202,27 +216,39 @@ in stdenv.mkDerivation (finalAttrs: { ''; # Unfortunately, it seems like we have to call make on these manually - postBuild = lib.optionalString buildDocs '' - python -m sphinx -T -E -b html -d _build/doctrees -D language=en ../docs _build/html - '' + lib.optionalString buildTests '' - make -j$NIX_BUILD_CORES check - ''; + postBuild = + lib.optionalString buildDocs '' + python -m sphinx -T -E -b html -d _build/doctrees -D language=en ../docs _build/html + '' + + lib.optionalString buildTests '' + make -j$NIX_BUILD_CORES check + ''; - postInstall = '' - rm $out/bin/install_precompiled_kernels.sh - ln -sf ${gfx900} $out/share/miopen/db/gfx900.kdb - ln -sf ${gfx906} $out/share/miopen/db/gfx906.kdb - ln -sf ${gfx908} $out/share/miopen/db/gfx908.kdb - ln -sf ${gfx90a} $out/share/miopen/db/gfx90a.kdb - ln -sf ${gfx1030} $out/share/miopen/db/gfx1030.kdb - '' + lib.optionalString buildDocs '' - mv ../doc/html $out/share/doc/miopen-hip - '' + lib.optionalString buildTests '' - mkdir -p $test/bin - mv bin/test_* $test/bin - patchelf --set-rpath $out/lib:${lib.makeLibraryPath (finalAttrs.buildInputs ++ - [ clr rocm-comgr ])} $test/bin/* - ''; + postInstall = + '' + rm $out/bin/install_precompiled_kernels.sh + ln -sf ${gfx900} $out/share/miopen/db/gfx900.kdb + ln -sf ${gfx906} $out/share/miopen/db/gfx906.kdb + ln -sf ${gfx908} $out/share/miopen/db/gfx908.kdb + ln -sf ${gfx90a} $out/share/miopen/db/gfx90a.kdb + ln -sf ${gfx1030} $out/share/miopen/db/gfx1030.kdb + '' + + lib.optionalString buildDocs '' + mv ../doc/html $out/share/doc/miopen-hip + '' + + lib.optionalString buildTests '' + mkdir -p $test/bin + mv bin/test_* $test/bin + patchelf --set-rpath $out/lib:${ + lib.makeLibraryPath ( + finalAttrs.buildInputs + ++ [ + clr + rocm-comgr + ] + ) + } $test/bin/* + ''; requiredSystemFeatures = [ "big-parallel" ]; @@ -238,6 +264,8 @@ in stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/mivisionx/default.nix b/pkgs/development/rocm-modules/6/mivisionx/default.nix index 8459dff1c89221..1b117ad3fc4d85 100644 --- a/pkgs/development/rocm-modules/6/mivisionx/default.nix +++ b/pkgs/development/rocm-modules/6/mivisionx/default.nix @@ -1,41 +1,47 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-device-libs -, clr -, pkg-config -, rpp -, rocblas -, miopen -, migraphx -, clang -, openmp -, protobuf -, qtcreator -, opencv -, ffmpeg -, boost -, libjpeg_turbo -, half -, lmdb -, rapidjson -, rocm-docs-core -, python3Packages -, useOpenCL ? false -, useCPU ? false -, buildDocs ? false # Needs internet -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-device-libs, + clr, + pkg-config, + rpp, + rocblas, + miopen, + migraphx, + clang, + openmp, + protobuf, + qtcreator, + opencv, + ffmpeg, + boost, + libjpeg_turbo, + half, + lmdb, + rapidjson, + rocm-docs-core, + python3Packages, + useOpenCL ? false, + useCPU ? false, + buildDocs ? false, # Needs internet + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { - pname = "mivisionx-" + ( - if (!useOpenCL && !useCPU) then "hip" - else if (!useOpenCL && !useCPU) then "opencl" - else "cpu" - ); + pname = + "mivisionx-" + + ( + if (!useOpenCL && !useCPU) then + "hip" + else if (!useOpenCL && !useCPU) then + "opencl" + else + "cpu" + ); version = "6.0.2"; @@ -50,15 +56,17 @@ stdenv.mkDerivation (finalAttrs: { ./0001-set-__STDC_CONSTANT_MACROS-to-make-rocAL-compile.patch ]; - nativeBuildInputs = [ - cmake - rocm-cmake - clr - pkg-config - ] ++ lib.optionals buildDocs [ - rocm-docs-core - python3Packages.python - ]; + nativeBuildInputs = + [ + cmake + rocm-cmake + clr + pkg-config + ] + ++ lib.optionals buildDocs [ + rocm-docs-core + python3Packages.python + ]; buildInputs = [ miopen @@ -80,25 +88,30 @@ stdenv.mkDerivation (finalAttrs: { python3Packages.torchWithRocm ]; - cmakeFlags = [ - "-DROCM_PATH=${clr}" - "-DAMDRPP_PATH=${rpp}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - "-DCMAKE_INSTALL_PREFIX_PYTHON=lib" - # "-DAMD_FP16_SUPPORT=ON" `error: typedef redefinition with different types ('__half' vs 'half_float::half')` - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals (!useOpenCL && !useCPU) [ - "-DBACKEND=HIP" - ] ++ lib.optionals (useOpenCL && !useCPU) [ - "-DBACKEND=OCL" - ] ++ lib.optionals useCPU [ - "-DBACKEND=CPU" - ]; + cmakeFlags = + [ + "-DROCM_PATH=${clr}" + "-DAMDRPP_PATH=${rpp}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + "-DCMAKE_INSTALL_PREFIX_PYTHON=lib" + # "-DAMD_FP16_SUPPORT=ON" `error: typedef redefinition with different types ('__half' vs 'half_float::half')` + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals (!useOpenCL && !useCPU) [ + "-DBACKEND=HIP" + ] + ++ lib.optionals (useOpenCL && !useCPU) [ + "-DBACKEND=OCL" + ] + ++ lib.optionals useCPU [ + "-DBACKEND=CPU" + ]; postPatch = '' # We need to not use hipcc and define the CXXFLAGS manually due to `undefined hidden symbol: tensorflow:: ...` @@ -141,6 +154,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rccl/default.nix b/pkgs/development/rocm-modules/6/rccl/default.nix index a830883b4f82ef..dc5fd0534b0611 100644 --- a/pkgs/development/rocm-modules/6/rccl/default.nix +++ b/pkgs/development/rocm-modules/6/rccl/default.nix @@ -1,28 +1,31 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-smi -, clr -, perl -, hipify -, gtest -, chrpath -, buildTests ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-smi, + clr, + perl, + hipify, + gtest, + chrpath, + buildTests ? false, + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { pname = "rccl"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -39,26 +42,31 @@ stdenv.mkDerivation (finalAttrs: { hipify ]; - buildInputs = [ - rocm-smi - gtest - ] ++ lib.optionals buildTests [ - chrpath - ]; + buildInputs = + [ + rocm-smi + gtest + ] + ++ lib.optionals buildTests [ + chrpath + ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - "-DBUILD_BFD=OFF" # Can't get it to detect bfd.h - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_TESTS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + "-DBUILD_BFD=OFF" # Can't get it to detect bfd.h + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_TESTS=ON" + ]; postPatch = '' patchShebangs src tools @@ -85,9 +93,14 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "ROCm communication collectives library"; homepage = "https://github.com/ROCm/rccl"; - license = with licenses; [ bsd2 bsd3 ]; + license = with licenses; [ + bsd2 + bsd3 + ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rdc/default.nix b/pkgs/development/rocm-modules/6/rdc/default.nix index 6591e55a0cc792..2422ef71579c77 100644 --- a/pkgs/development/rocm-modules/6/rdc/default.nix +++ b/pkgs/development/rocm-modules/6/rdc/default.nix @@ -1,54 +1,63 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-smi -, rocm-runtime -, libcap -, grpc -, protobuf -, openssl -, doxygen -, graphviz -, texliveSmall -, gtest -, buildDocs ? true -, buildTests ? false +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-smi, + rocm-runtime, + libcap, + grpc, + protobuf, + openssl, + doxygen, + graphviz, + texliveSmall, + gtest, + buildDocs ? true, + buildTests ? false, }: let - latex = lib.optionalAttrs buildDocs (texliveSmall.withPackages (ps: with ps; [ - changepage - latexmk - varwidth - multirow - hanging - adjustbox - collectbox - stackengine - enumitem - alphalph - wasysym - sectsty - tocloft - newunicodechar - etoc - helvetic - wasy - courier - ])); -in stdenv.mkDerivation (finalAttrs: { + latex = lib.optionalAttrs buildDocs ( + texliveSmall.withPackages ( + ps: with ps; [ + changepage + latexmk + varwidth + multirow + hanging + adjustbox + collectbox + stackengine + enumitem + alphalph + wasysym + sectsty + tocloft + newunicodechar + etoc + helvetic + wasy + courier + ] + ) + ); +in +stdenv.mkDerivation (finalAttrs: { pname = "rdc"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ] ++ lib.optionals buildTests [ - "test" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ] + ++ lib.optionals buildTests [ + "test" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -57,55 +66,63 @@ in stdenv.mkDerivation (finalAttrs: { hash = "sha256-QugcajxILmDeQiWG5uAUO41Wut45irg2Ynufgn1bmps="; }; - nativeBuildInputs = [ - cmake - protobuf - ] ++ lib.optionals buildDocs [ - doxygen - graphviz - latex - ]; + nativeBuildInputs = + [ + cmake + protobuf + ] + ++ lib.optionals buildDocs [ + doxygen + graphviz + latex + ]; - buildInputs = [ - rocm-smi - rocm-runtime - libcap - grpc - openssl - ] ++ lib.optionals buildTests [ - gtest - ]; + buildInputs = + [ + rocm-smi + rocm-runtime + libcap + grpc + openssl + ] + ++ lib.optionals buildTests [ + gtest + ]; - cmakeFlags = [ - "-DCMAKE_VERBOSE_MAKEFILE=OFF" - "-DRDC_INSTALL_PREFIX=${placeholder "out"}" - "-DBUILD_ROCRTEST=ON" - "-DRSMI_INC_DIR=${rocm-smi}/include" - "-DRSMI_LIB_DIR=${rocm-smi}/lib" - "-DGRPC_ROOT=${grpc}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - "-DCMAKE_INSTALL_LIBEXECDIR=libexec" - "-DCMAKE_INSTALL_DOCDIR=doc" - ] ++ lib.optionals buildTests [ - "-DBUILD_TESTS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_VERBOSE_MAKEFILE=OFF" + "-DRDC_INSTALL_PREFIX=${placeholder "out"}" + "-DBUILD_ROCRTEST=ON" + "-DRSMI_INC_DIR=${rocm-smi}/include" + "-DRSMI_LIB_DIR=${rocm-smi}/lib" + "-DGRPC_ROOT=${grpc}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + "-DCMAKE_INSTALL_LIBEXECDIR=libexec" + "-DCMAKE_INSTALL_DOCDIR=doc" + ] + ++ lib.optionals buildTests [ + "-DBUILD_TESTS=ON" + ]; postPatch = '' substituteInPlace CMakeLists.txt \ --replace "file(STRINGS /etc/os-release LINUX_DISTRO LIMIT_COUNT 1 REGEX \"NAME=\")" "set(LINUX_DISTRO \"NixOS\")" ''; - postInstall = '' - find $out/bin -executable -type f -exec \ - patchelf {} --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" \; - '' + lib.optionalString buildTests '' - mkdir -p $test - mv $out/bin/rdctst_tests $test/bin - ''; + postInstall = + '' + find $out/bin -executable -type f -exec \ + patchelf {} --shrink-rpath --allowed-rpath-prefixes "$NIX_STORE" \; + '' + + lib.optionalString buildTests '' + mkdir -p $test + mv $out/bin/rdctst_tests $test/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; diff --git a/pkgs/development/rocm-modules/6/rocalution/default.nix b/pkgs/development/rocm-modules/6/rocalution/default.nix index 056cbb9b358c5b..48cc9ab3f8ccb2 100644 --- a/pkgs/development/rocm-modules/6/rocalution/default.nix +++ b/pkgs/development/rocm-modules/6/rocalution/default.nix @@ -1,37 +1,42 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocblas -, rocsparse -, rocprim -, rocrand -, clr -, git -, openmp -, openmpi -, gtest -, buildTests ? false -, buildBenchmarks ? false -, buildSamples ? false -, gpuTargets ? [ ] # gpuTargets = [ "gfx803" "gfx900:xnack-" "gfx906:xnack-" ... ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocblas, + rocsparse, + rocprim, + rocrand, + clr, + git, + openmp, + openmpi, + gtest, + buildTests ? false, + buildBenchmarks ? false, + buildSamples ? false, + gpuTargets ? [ ], # gpuTargets = [ "gfx803" "gfx900:xnack-" "gfx906:xnack-" ... ] }: stdenv.mkDerivation (finalAttrs: { pname = "rocalution"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ] ++ lib.optionals buildSamples [ - "sample" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ] + ++ lib.optionals buildSamples [ + "sample" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -47,56 +52,66 @@ stdenv.mkDerivation (finalAttrs: { git ]; - buildInputs = [ - rocblas - rocsparse - rocprim - rocrand - openmp - openmpi - ] ++ lib.optionals buildTests [ - gtest - ]; + buildInputs = + [ + rocblas + rocsparse + rocprim + rocrand + openmp + openmpi + ] + ++ lib.optionals buildTests [ + gtest + ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - "-DROCM_PATH=${clr}" - "-DHIP_ROOT_DIR=${clr}" - "-DSUPPORT_HIP=ON" - "-DSUPPORT_OMP=ON" - "-DSUPPORT_MPI=ON" - "-DBUILD_CLIENTS_SAMPLES=${if buildSamples then "ON" else "OFF"}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.strings.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_BENCHMARKS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + "-DROCM_PATH=${clr}" + "-DHIP_ROOT_DIR=${clr}" + "-DSUPPORT_HIP=ON" + "-DSUPPORT_OMP=ON" + "-DSUPPORT_MPI=ON" + "-DBUILD_CLIENTS_SAMPLES=${if buildSamples then "ON" else "OFF"}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.strings.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_BENCHMARKS=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/rocalution-test $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/rocalution-bench $benchmark/bin - '' + lib.optionalString buildSamples '' - mkdir -p $sample/bin - mv clients/staging/* $sample/bin - rm $sample/bin/rocalution-test || true - rm $sample/bin/rocalution-bench || true + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/rocalution-test $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/rocalution-bench $benchmark/bin + '' + + lib.optionalString buildSamples '' + mkdir -p $sample/bin + mv clients/staging/* $sample/bin + rm $sample/bin/rocalution-test || true + rm $sample/bin/rocalution-bench || true - patchelf --set-rpath \ - $out/lib:${lib.makeLibraryPath (finalAttrs.buildInputs ++ [ clr ])} \ - $sample/bin/* - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rmdir $out/bin - ''; + patchelf --set-rpath \ + $out/lib:${lib.makeLibraryPath (finalAttrs.buildInputs ++ [ clr ])} \ + $sample/bin/* + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -110,6 +125,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocblas/default.nix b/pkgs/development/rocm-modules/6/rocblas/default.nix index 4233aa640690f8..7c5fbe801b1932 100644 --- a/pkgs/development/rocm-modules/6/rocblas/default.nix +++ b/pkgs/development/rocm-modules/6/rocblas/default.nix @@ -1,55 +1,61 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, rocmUpdateScript -, cmake -, rocm-cmake -, clr -, python3 -, tensile -, msgpack -, libxml2 -, gtest -, gfortran -, openmp -, amd-blis -, python3Packages -, buildTensile ? true -, buildTests ? false -, buildBenchmarks ? false -, tensileLogic ? "asm_full" -, tensileCOVersion ? "default" -# https://github.com/ROCm/Tensile/issues/1757 -# Allows gfx101* users to use rocBLAS normally. -# Turn the below two values to `true` after the fix has been cherry-picked -# into a release. Just backporting that single fix is not enough because it -# depends on some previous commits. -, tensileSepArch ? false -, tensileLazyLib ? false -, tensileLibFormat ? "msgpack" -# `gfx940`, `gfx941` are not present in this list because they are early -# engineering samples, and all final MI300 hardware are `gfx942`: -# https://github.com/NixOS/nixpkgs/pull/298388#issuecomment-2032791130 -# -# `gfx1012` is not present in this list because the ISA compatibility patches -# would force all `gfx101*` GPUs to run as `gfx1010`, so `gfx101*` GPUs will -# always try to use `gfx1010` code objects, hence building for `gfx1012` is -# useless: https://github.com/NixOS/nixpkgs/pull/298388#issuecomment-2076327152 -, gpuTargets ? [ "gfx900;gfx906:xnack-;gfx908:xnack-;gfx90a:xnack+;gfx90a:xnack-;gfx942;gfx1010;gfx1030;gfx1100;gfx1101;gfx1102" ] +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + rocmUpdateScript, + cmake, + rocm-cmake, + clr, + python3, + tensile, + msgpack, + libxml2, + gtest, + gfortran, + openmp, + amd-blis, + python3Packages, + buildTensile ? true, + buildTests ? false, + buildBenchmarks ? false, + tensileLogic ? "asm_full", + tensileCOVersion ? "default", + # https://github.com/ROCm/Tensile/issues/1757 + # Allows gfx101* users to use rocBLAS normally. + # Turn the below two values to `true` after the fix has been cherry-picked + # into a release. Just backporting that single fix is not enough because it + # depends on some previous commits. + tensileSepArch ? false, + tensileLazyLib ? false, + tensileLibFormat ? "msgpack", + # `gfx940`, `gfx941` are not present in this list because they are early + # engineering samples, and all final MI300 hardware are `gfx942`: + # https://github.com/NixOS/nixpkgs/pull/298388#issuecomment-2032791130 + # + # `gfx1012` is not present in this list because the ISA compatibility patches + # would force all `gfx101*` GPUs to run as `gfx1010`, so `gfx101*` GPUs will + # always try to use `gfx1010` code objects, hence building for `gfx1012` is + # useless: https://github.com/NixOS/nixpkgs/pull/298388#issuecomment-2076327152 + gpuTargets ? [ + "gfx900;gfx906:xnack-;gfx908:xnack-;gfx90a:xnack+;gfx90a:xnack-;gfx942;gfx1010;gfx1030;gfx1100;gfx1101;gfx1102" + ], }: stdenv.mkDerivation (finalAttrs: { pname = "rocblas"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -58,54 +64,64 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-G68d/gvBbTdNx8xR3xY+OkBm5Yxq1NFjxby9BbpOcUk="; }; - nativeBuildInputs = [ - cmake - rocm-cmake - clr - ] ++ lib.optionals buildTensile [ - tensile - ]; + nativeBuildInputs = + [ + cmake + rocm-cmake + clr + ] + ++ lib.optionals buildTensile [ + tensile + ]; - buildInputs = [ - python3 - ] ++ lib.optionals buildTensile [ - msgpack - libxml2 - python3Packages.msgpack - python3Packages.joblib - ] ++ lib.optionals buildTests [ - gtest - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - gfortran - openmp - amd-blis - ] ++ lib.optionals (buildTensile || buildTests || buildBenchmarks) [ - python3Packages.pyyaml - ]; + buildInputs = + [ + python3 + ] + ++ lib.optionals buildTensile [ + msgpack + libxml2 + python3Packages.msgpack + python3Packages.joblib + ] + ++ lib.optionals buildTests [ + gtest + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + gfortran + openmp + amd-blis + ] + ++ lib.optionals (buildTensile || buildTests || buildBenchmarks) [ + python3Packages.pyyaml + ]; - cmakeFlags = [ - (lib.cmakeFeature "CMAKE_C_COMPILER" "hipcc") - (lib.cmakeFeature "CMAKE_CXX_COMPILER" "hipcc") - (lib.cmakeFeature "python" "python3") - (lib.cmakeFeature "AMDGPU_TARGETS" (lib.concatStringsSep ";" gpuTargets)) - (lib.cmakeBool "BUILD_WITH_TENSILE" buildTensile) - (lib.cmakeBool "ROCM_SYMLINK_LIBS" false) - (lib.cmakeFeature "ROCBLAS_TENSILE_LIBRARY_DIR" "lib/rocblas") - (lib.cmakeBool "BUILD_CLIENTS_TESTS" buildTests) - (lib.cmakeBool "BUILD_CLIENTS_BENCHMARKS" buildBenchmarks) - # rocblas header files are not installed unless we set this - (lib.cmakeFeature "CMAKE_INSTALL_INCLUDEDIR" "include") - ] ++ lib.optionals buildTensile [ - (lib.cmakeBool "BUILD_WITH_PIP" false) - (lib.cmakeFeature "Tensile_LOGIC" tensileLogic) - (lib.cmakeFeature "Tensile_CODE_OBJECT_VERSION" tensileCOVersion) - (lib.cmakeBool "Tensile_SEPARATE_ARCHITECTURES" tensileSepArch) - (lib.cmakeBool "Tensile_LAZY_LIBRARY_LOADING" tensileLazyLib) - (lib.cmakeFeature "Tensile_LIBRARY_FORMAT" tensileLibFormat) - (lib.cmakeBool "Tensile_PRINT_DEBUG" true) - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - (lib.cmakeFeature "CMAKE_CXX_FLAGS" "-I${amd-blis}/include/blis") - ]; + cmakeFlags = + [ + (lib.cmakeFeature "CMAKE_C_COMPILER" "hipcc") + (lib.cmakeFeature "CMAKE_CXX_COMPILER" "hipcc") + (lib.cmakeFeature "python" "python3") + (lib.cmakeFeature "AMDGPU_TARGETS" (lib.concatStringsSep ";" gpuTargets)) + (lib.cmakeBool "BUILD_WITH_TENSILE" buildTensile) + (lib.cmakeBool "ROCM_SYMLINK_LIBS" false) + (lib.cmakeFeature "ROCBLAS_TENSILE_LIBRARY_DIR" "lib/rocblas") + (lib.cmakeBool "BUILD_CLIENTS_TESTS" buildTests) + (lib.cmakeBool "BUILD_CLIENTS_BENCHMARKS" buildBenchmarks) + # rocblas header files are not installed unless we set this + (lib.cmakeFeature "CMAKE_INSTALL_INCLUDEDIR" "include") + ] + ++ lib.optionals buildTensile [ + (lib.cmakeBool "BUILD_WITH_PIP" false) + (lib.cmakeFeature "Tensile_LOGIC" tensileLogic) + (lib.cmakeFeature "Tensile_CODE_OBJECT_VERSION" tensileCOVersion) + (lib.cmakeBool "Tensile_SEPARATE_ARCHITECTURES" tensileSepArch) + (lib.cmakeBool "Tensile_LAZY_LIBRARY_LOADING" tensileLazyLib) + (lib.cmakeFeature "Tensile_LIBRARY_FORMAT" tensileLibFormat) + (lib.cmakeBool "Tensile_PRINT_DEBUG" true) + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + (lib.cmakeFeature "CMAKE_CXX_FLAGS" "-I${amd-blis}/include/blis") + ]; patches = [ (fetchpatch { @@ -135,6 +151,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocfft/default.nix b/pkgs/development/rocm-modules/6/rocfft/default.nix index 9fd1f02398b397..92f51a161a48d1 100644 --- a/pkgs/development/rocm-modules/6/rocfft/default.nix +++ b/pkgs/development/rocm-modules/6/rocfft/default.nix @@ -1,20 +1,21 @@ -{ rocfft -, lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, clr -, python3 -, rocm-cmake -, sqlite -, boost -, fftw -, fftwFloat -, gtest -, openmp -, rocrand -, gpuTargets ? [ ] +{ + rocfft, + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + clr, + python3, + rocm-cmake, + sqlite, + boost, + fftw, + fftwFloat, + gtest, + openmp, + rocrand, + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { @@ -37,18 +38,20 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ sqlite ]; - cmakeFlags = [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-DSQLITE_USE_SYSTEM_PACKAGE=ON" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ]; + cmakeFlags = + [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-DSQLITE_USE_SYSTEM_PACKAGE=ON" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ]; passthru = { test = stdenv.mkDerivation { @@ -100,10 +103,12 @@ stdenv.mkDerivation (finalAttrs: { boost finalAttrs.finalPackage openmp - (python3.withPackages (ps: with ps; [ - pandas - scipy - ])) + (python3.withPackages ( + ps: with ps; [ + pandas + scipy + ] + )) rocrand ]; @@ -164,6 +169,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = with maintainers; [ kira-bruneau ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocgdb/default.nix b/pkgs/development/rocm-modules/6/rocgdb/default.nix index 2112c6cf021056..cf51f05f9ee48f 100644 --- a/pkgs/development/rocm-modules/6/rocgdb/default.nix +++ b/pkgs/development/rocm-modules/6/rocgdb/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, pkg-config -, texinfo -, bison -, flex -, glibc -, zlib -, gmp -, mpfr -, ncurses -, expat -, rocdbgapi -, python3 -, babeltrace -, sourceHighlight +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + pkg-config, + texinfo, + bison, + flex, + glibc, + zlib, + gmp, + mpfr, + ncurses, + expat, + rocdbgapi, + python3, + babeltrace, + sourceHighlight, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/rocm-modules/6/rocm-comgr/default.nix b/pkgs/development/rocm-modules/6/rocm-comgr/default.nix index 033de08af11b86..fb85e6dd2a1b92 100644 --- a/pkgs/development/rocm-modules/6/rocm-comgr/default.nix +++ b/pkgs/development/rocm-modules/6/rocm-comgr/default.nix @@ -1,19 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-device-libs -, libxml2 +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-device-libs, + libxml2, }: let llvmNativeTarget = - if stdenv.hostPlatform.isx86_64 then "X86" - else if stdenv.hostPlatform.isAarch64 then "AArch64" - else throw "Unsupported ROCm LLVM platform"; -in stdenv.mkDerivation (finalAttrs: { + if stdenv.hostPlatform.isx86_64 then + "X86" + else if stdenv.hostPlatform.isAarch64 then + "AArch64" + else + throw "Unsupported ROCm LLVM platform"; +in +stdenv.mkDerivation (finalAttrs: { pname = "rocm-comgr"; version = "6.0.2"; @@ -50,6 +55,8 @@ in stdenv.mkDerivation (finalAttrs: { license = licenses.ncsa; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocm-core/default.nix b/pkgs/development/rocm-modules/6/rocm-core/default.nix index 2601918d916573..31f47fb26b976b 100644 --- a/pkgs/development/rocm-modules/6/rocm-core/default.nix +++ b/pkgs/development/rocm-modules/6/rocm-core/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, }: stdenv.mkDerivation (finalAttrs: { @@ -33,6 +34,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocm-device-libs/default.nix b/pkgs/development/rocm-modules/6/rocm-device-libs/default.nix index c55ba960fc6180..a16eee74c3f178 100644 --- a/pkgs/development/rocm-modules/6/rocm-device-libs/default.nix +++ b/pkgs/development/rocm-modules/6/rocm-device-libs/default.nix @@ -1,18 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, libxml2 +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + libxml2, }: let llvmNativeTarget = - if stdenv.hostPlatform.isx86_64 then "X86" - else if stdenv.hostPlatform.isAarch64 then "AArch64" - else throw "Unsupported ROCm LLVM platform"; -in stdenv.mkDerivation (finalAttrs: { + if stdenv.hostPlatform.isx86_64 then + "X86" + else if stdenv.hostPlatform.isAarch64 then + "AArch64" + else + throw "Unsupported ROCm LLVM platform"; +in +stdenv.mkDerivation (finalAttrs: { pname = "rocm-device-libs"; version = "6.0.2"; @@ -45,6 +50,8 @@ in stdenv.mkDerivation (finalAttrs: { license = licenses.ncsa; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocm-runtime/default.nix b/pkgs/development/rocm-modules/6/rocm-runtime/default.nix index 1e728fb73cf793..a24c751a44ef05 100644 --- a/pkgs/development/rocm-modules/6/rocm-runtime/default.nix +++ b/pkgs/development/rocm-modules/6/rocm-runtime/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, rocmUpdateScript -, pkg-config -, cmake -, xxd -, rocm-device-libs -, rocm-thunk -, elfutils -, libdrm -, numactl -, valgrind -, libxml2 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + rocmUpdateScript, + pkg-config, + cmake, + xxd, + rocm-device-libs, + rocm-thunk, + elfutils, + libdrm, + numactl, + valgrind, + libxml2, }: stdenv.mkDerivation (finalAttrs: { @@ -79,6 +80,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ ncsa ]; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocminfo/default.nix b/pkgs/development/rocm-modules/6/rocminfo/default.nix index f53dcf19b96bee..9c88274d722f29 100644 --- a/pkgs/development/rocm-modules/6/rocminfo/default.nix +++ b/pkgs/development/rocm-modules/6/rocminfo/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-runtime -, busybox -, python3 -, gnugrep +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-runtime, + busybox, + python3, + gnugrep, # rocminfo requires that the calling user have a password and be in # the video group. If we let rocm_agent_enumerator rely upon # rocminfo's output, then it, too, has those requirements. Instead, # we can specify the GPU targets for this system (e.g. "gfx803" for # Polaris) such that no system call is needed for downstream # compilers to determine the desired target. -, defaultTargets ? [] + defaultTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { @@ -58,6 +59,9 @@ stdenv.mkDerivation (finalAttrs: { license = licenses.ncsa; maintainers = with maintainers; [ lovesegfault ] ++ teams.rocm.members; platforms = platforms.linux; - broken = stdenv.hostPlatform.isAarch64 || versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + stdenv.hostPlatform.isAarch64 + || versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocmlir/default.nix b/pkgs/development/rocm-modules/6/rocmlir/default.nix index efc33fd8468ad3..b0063bf9f74461 100644 --- a/pkgs/development/rocm-modules/6/rocmlir/default.nix +++ b/pkgs/development/rocm-modules/6/rocmlir/default.nix @@ -1,45 +1,49 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocminfo -, ninja -, clr -, git -, libxml2 -, libedit -, zstd -, zlib -, ncurses -, python3Packages -, buildRockCompiler ? false -, buildTests ? false # `argument of type 'NoneType' is not iterable` +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocminfo, + ninja, + clr, + git, + libxml2, + libedit, + zstd, + zlib, + ncurses, + python3Packages, + buildRockCompiler ? false, + buildTests ? false, # `argument of type 'NoneType' is not iterable` }: # Theoretically, we could have our MLIR have an output # with the source and built objects so that we can just # use it as the external LLVM repo for this let - suffix = - if buildRockCompiler - then "-rock" - else ""; + suffix = if buildRockCompiler then "-rock" else ""; llvmNativeTarget = - if stdenv.hostPlatform.isx86_64 then "X86" - else if stdenv.hostPlatform.isAarch64 then "AArch64" - else throw "Unsupported ROCm LLVM platform"; -in stdenv.mkDerivation (finalAttrs: { + if stdenv.hostPlatform.isx86_64 then + "X86" + else if stdenv.hostPlatform.isAarch64 then + "AArch64" + else + throw "Unsupported ROCm LLVM platform"; +in +stdenv.mkDerivation (finalAttrs: { pname = "rocmlir${suffix}"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals (!buildRockCompiler) [ - "external" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals (!buildRockCompiler) [ + "external" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -69,22 +73,25 @@ in stdenv.mkDerivation (finalAttrs: { ncurses ]; - cmakeFlags = [ - "-DLLVM_TARGETS_TO_BUILD=AMDGPU;${llvmNativeTarget}" - "-DLLVM_ENABLE_ZSTD=ON" - "-DLLVM_ENABLE_ZLIB=ON" - "-DLLVM_ENABLE_TERMINFO=ON" - "-DROCM_PATH=${clr}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals buildRockCompiler [ - "-DBUILD_FAT_LIBROCKCOMPILER=ON" - ] ++ lib.optionals (!buildRockCompiler) [ - "-DROCM_TEST_CHIPSET=gfx000" - ]; + cmakeFlags = + [ + "-DLLVM_TARGETS_TO_BUILD=AMDGPU;${llvmNativeTarget}" + "-DLLVM_ENABLE_ZSTD=ON" + "-DLLVM_ENABLE_ZLIB=ON" + "-DLLVM_ENABLE_TERMINFO=ON" + "-DROCM_PATH=${clr}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals buildRockCompiler [ + "-DBUILD_FAT_LIBROCKCOMPILER=ON" + ] + ++ lib.optionals (!buildRockCompiler) [ + "-DROCM_TEST_CHIPSET=gfx000" + ]; postPatch = '' patchShebangs mlir @@ -102,20 +109,30 @@ in stdenv.mkDerivation (finalAttrs: { doCheck = true; # Certain libs aren't being generated, try enabling tests next update - checkTarget = if buildRockCompiler - then "librockCompiler" - else if buildTests - then "check-rocmlir" - else "check-rocmlir-build-only"; - - postInstall = let - libPath = lib.makeLibraryPath [ zstd zlib ncurses clr stdenv.cc.cc ]; - in lib.optionals (!buildRockCompiler) '' - mkdir -p $external/lib - cp -a external/llvm-project/llvm/lib/{*.a*,*.so*} $external/lib - patchelf --set-rpath $external/lib:$out/lib:${libPath} $external/lib/*.so* - patchelf --set-rpath $out/lib:$external/lib:${libPath} $out/{bin/*,lib/*.so*} - ''; + checkTarget = + if buildRockCompiler then + "librockCompiler" + else if buildTests then + "check-rocmlir" + else + "check-rocmlir-build-only"; + + postInstall = + let + libPath = lib.makeLibraryPath [ + zstd + zlib + ncurses + clr + stdenv.cc.cc + ]; + in + lib.optionals (!buildRockCompiler) '' + mkdir -p $external/lib + cp -a external/llvm-project/llvm/lib/{*.a*,*.so*} $external/lib + patchelf --set-rpath $external/lib:$out/lib:${libPath} $external/lib/*.so* + patchelf --set-rpath $out/lib:$external/lib:${libPath} $out/{bin/*,lib/*.so*} + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -131,6 +148,8 @@ in stdenv.mkDerivation (finalAttrs: { license = with licenses; [ asl20 ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocprofiler/default.nix b/pkgs/development/rocm-modules/6/rocprofiler/default.nix index ca6291992d85ab..c3a0bf7112a62f 100644 --- a/pkgs/development/rocm-modules/6/rocprofiler/default.nix +++ b/pkgs/development/rocm-modules/6/rocprofiler/default.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, symlinkJoin -, substituteAll -, cmake -, clang -, clr -, rocm-core -, rocm-thunk -, rocm-device-libs -, roctracer -, rocdbgapi -, rocm-smi -, hsa-amd-aqlprofile-bin -, numactl -, libpciaccess -, libxml2 -, elfutils -, mpi -, systemd -, gtest -, python3Packages -, gpuTargets ? clr.gpuTargets +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + symlinkJoin, + substituteAll, + cmake, + clang, + clr, + rocm-core, + rocm-thunk, + rocm-device-libs, + roctracer, + rocdbgapi, + rocm-smi, + hsa-amd-aqlprofile-bin, + numactl, + libpciaccess, + libxml2, + elfutils, + mpi, + systemd, + gtest, + python3Packages, + gpuTargets ? clr.gpuTargets, }: let @@ -44,7 +45,8 @@ let rm -rf $out/nix-support ''; }; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "rocprofiler"; version = "6.0.2"; @@ -135,6 +137,8 @@ in stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; # mitx11 maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor clr.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor clr.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocr-debug-agent/default.nix b/pkgs/development/rocm-modules/6/rocr-debug-agent/default.nix index 625a8ef5a364fd..6d9a91be00ef1c 100644 --- a/pkgs/development/rocm-modules/6/rocr-debug-agent/default.nix +++ b/pkgs/development/rocm-modules/6/rocr-debug-agent/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, clr -, git -, rocdbgapi -, elfutils +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + clr, + git, + rocdbgapi, + elfutils, }: stdenv.mkDerivation (finalAttrs: { @@ -54,6 +55,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ ncsa ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocsolver/default.nix b/pkgs/development/rocm-modules/6/rocsolver/default.nix index 42334d396b04a0..577ef73d25343f 100644 --- a/pkgs/development/rocm-modules/6/rocsolver/default.nix +++ b/pkgs/development/rocm-modules/6/rocsolver/default.nix @@ -1,32 +1,36 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocblas -, rocsparse -, clr -, fmt -, gtest -, gfortran -, lapack-reference -, buildTests ? false -, buildBenchmarks ? false -, gpuTargets ? [ ] # gpuTargets = [ "gfx803" "gfx900" "gfx906:xnack-" ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocblas, + rocsparse, + clr, + fmt, + gtest, + gfortran, + lapack-reference, + buildTests ? false, + buildBenchmarks ? false, + gpuTargets ? [ ], # gpuTargets = [ "gfx803" "gfx900" "gfx906:xnack-" ] }: stdenv.mkDerivation (finalAttrs: { pname = "rocsolver"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -35,49 +39,61 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-tglQpwCSFABRuEDiJrzQVFIdx9p85E2MiUYN0aoTAXo="; }; - nativeBuildInputs = [ - cmake - rocm-cmake - clr - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - gfortran - ]; + nativeBuildInputs = + [ + cmake + rocm-cmake + clr + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + gfortran + ]; - buildInputs = [ - rocblas - rocsparse - fmt - ] ++ lib.optionals buildTests [ - gtest - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - lapack-reference - ]; + buildInputs = + [ + rocblas + rocsparse + fmt + ] + ++ lib.optionals buildTests [ + gtest + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + lapack-reference + ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - "-DCMAKE_CXX_FLAGS=-Wno-switch" # Way too many warnings - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_CLIENTS_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_BENCHMARKS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + "-DCMAKE_CXX_FLAGS=-Wno-switch" # Way too many warnings + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_CLIENTS_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_BENCHMARKS=ON" + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/rocsolver-test $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/rocsolver-bench $benchmark/bin - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/rocsolver-test $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/rocsolver-bench $benchmark/bin + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rmdir $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -95,6 +111,8 @@ stdenv.mkDerivation (finalAttrs: { platforms = platforms.linux; timeout = 14400; # 4 hours maxSilent = 14400; # 4 hours - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocsparse/default.nix b/pkgs/development/rocm-modules/6/rocsparse/default.nix index 2a1043b33c0596..a4c29bc980c920 100644 --- a/pkgs/development/rocm-modules/6/rocsparse/default.nix +++ b/pkgs/development/rocm-modules/6/rocsparse/default.nix @@ -1,33 +1,37 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchzip -, rocmUpdateScript -, cmake -, rocm-cmake -, rocprim -, clr -, gfortran -, git -, gtest -, boost -, python3Packages -, buildTests ? false -, buildBenchmarks ? false # Seems to depend on tests -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + fetchzip, + rocmUpdateScript, + cmake, + rocm-cmake, + rocprim, + clr, + gfortran, + git, + gtest, + boost, + python3Packages, + buildTests ? false, + buildBenchmarks ? false, # Seems to depend on tests + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { pname = "rocsparse"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -43,32 +47,38 @@ stdenv.mkDerivation (finalAttrs: { gfortran ]; - buildInputs = [ - rocprim - git - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - gtest - boost - python3Packages.python - python3Packages.pyyaml - ]; + buildInputs = + [ + rocprim + git + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + gtest + boost + python3Packages.python + python3Packages.pyyaml + ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - "-DBUILD_CLIENTS_TESTS=ON" - "-DCMAKE_MATRICES_DIR=/build/source/matrices" - "-Dpython=python3" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_CLIENTS_BENCHMARKS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + "-DBUILD_CLIENTS_TESTS=ON" + "-DCMAKE_MATRICES_DIR=/build/source/matrices" + "-Dpython=python3" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_CLIENTS_BENCHMARKS=ON" + ]; # We have to manually generate the matrices postPatch = lib.optionalString (buildTests || buildBenchmarks) '' @@ -112,17 +122,19 @@ stdenv.mkDerivation (finalAttrs: { done ''; - postInstall = lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - cp -a $out/bin/* $benchmark/bin - rm $benchmark/bin/rocsparse-test - '' + lib.optionalString (buildTests || buildBenchmarks) '' - mkdir -p $test/bin - mv $out/bin/* $test/bin - rm $test/bin/rocsparse-bench || true - mv /build/source/matrices $test - rmdir $out/bin - ''; + postInstall = + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + cp -a $out/bin/* $benchmark/bin + rm $benchmark/bin/rocsparse-test + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + mkdir -p $test/bin + mv $out/bin/* $test/bin + rm $test/bin/rocsparse-bench || true + mv /build/source/matrices $test + rmdir $out/bin + ''; passthru = { matrices = import ./deps.nix { @@ -144,6 +156,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocsparse/deps.nix b/pkgs/development/rocm-modules/6/rocsparse/deps.nix index cef880ab3232d2..e39b6de39673cc 100644 --- a/pkgs/development/rocm-modules/6/rocsparse/deps.nix +++ b/pkgs/development/rocm-modules/6/rocsparse/deps.nix @@ -1,6 +1,7 @@ -{ fetchzip -, mirror1 -, mirror2 +{ + fetchzip, + mirror1, + mirror2, }: { diff --git a/pkgs/development/rocm-modules/6/rocthrust/default.nix b/pkgs/development/rocm-modules/6/rocthrust/default.nix index e34e3ada6b991c..2044968441ff8d 100644 --- a/pkgs/development/rocm-modules/6/rocthrust/default.nix +++ b/pkgs/development/rocm-modules/6/rocthrust/default.nix @@ -1,28 +1,32 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocprim -, clr -, gtest -, buildTests ? false -, buildBenchmarks ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocprim, + clr, + gtest, + buildTests ? false, + buildBenchmarks ? false, + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { pname = "rocthrust"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildTests [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildTests [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -42,33 +46,41 @@ stdenv.mkDerivation (finalAttrs: { gtest ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - "-DHIP_ROOT_DIR=${clr}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildTests [ - "-DBUILD_TEST=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DBUILD_BENCHMARKS=ON" - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - "-DCMAKE_CXX_FLAGS=-Wno-deprecated-builtins" # Too much spam - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + "-DHIP_ROOT_DIR=${clr}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildTests [ + "-DBUILD_TEST=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DBUILD_BENCHMARKS=ON" + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + "-DCMAKE_CXX_FLAGS=-Wno-deprecated-builtins" # Too much spam + ]; - postInstall = lib.optionalString buildTests '' - mkdir -p $test/bin - mv $out/bin/{test_*,*.hip} $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/benchmark_* $benchmark/bin - '' + lib.optionalString (buildTests || buildBenchmarks) '' - rm -rf $out/bin - ''; + postInstall = + lib.optionalString buildTests '' + mkdir -p $test/bin + mv $out/bin/{test_*,*.hip} $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/benchmark_* $benchmark/bin + '' + + lib.optionalString (buildTests || buildBenchmarks) '' + rm -rf $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -82,6 +94,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ asl20 ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/roctracer/default.nix b/pkgs/development/rocm-modules/6/roctracer/default.nix index 2523a9ab5330ad..b5e411dd059d68 100644 --- a/pkgs/development/rocm-modules/6/roctracer/default.nix +++ b/pkgs/development/rocm-modules/6/roctracer/default.nix @@ -1,32 +1,36 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, clr -, rocm-device-libs -, libxml2 -, doxygen -, graphviz -, gcc-unwrapped -, libbacktrace -, rocm-runtime -, python3Packages -, buildDocs ? false # Nothing seems to be generated, so not making the output -, buildTests ? false +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + clr, + rocm-device-libs, + libxml2, + doxygen, + graphviz, + gcc-unwrapped, + libbacktrace, + rocm-runtime, + python3Packages, + buildDocs ? false, # Nothing seems to be generated, so not making the output + buildTests ? false, }: stdenv.mkDerivation (finalAttrs: { pname = "roctracer"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals buildDocs [ - "doc" - ] ++ lib.optionals buildTests [ - "test" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals buildDocs [ + "doc" + ] + ++ lib.optionals buildTests [ + "test" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -35,13 +39,15 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-a6/N6W3JXVI0VZRGxlS3cVENC3VTP1w9UFnd0+EWAuo="; }; - nativeBuildInputs = [ - cmake - clr - ] ++ lib.optionals buildDocs [ - doxygen - graphviz - ]; + nativeBuildInputs = + [ + cmake + clr + ] + ++ lib.optionals buildDocs [ + doxygen + graphviz + ]; buildInputs = [ libxml2 @@ -64,27 +70,39 @@ stdenv.mkDerivation (finalAttrs: { "-Wno-error=array-bounds" ]; - postPatch = '' - export HIP_DEVICE_LIB_PATH=${rocm-device-libs}/amdgcn/bitcode - '' + lib.optionalString (!buildTests) '' - substituteInPlace CMakeLists.txt \ - --replace "add_subdirectory(test)" "" - ''; + postPatch = + '' + export HIP_DEVICE_LIB_PATH=${rocm-device-libs}/amdgcn/bitcode + '' + + lib.optionalString (!buildTests) '' + substituteInPlace CMakeLists.txt \ + --replace "add_subdirectory(test)" "" + ''; # Tests always fail, probably need GPU # doCheck = buildTests; - postInstall = lib.optionalString buildDocs '' - mkdir -p $doc - '' + lib.optionalString buildTests '' - mkdir -p $test/bin - # Not sure why this is an install target - find $out/test -executable -type f -exec mv {} $test/bin \; - rm $test/bin/{*.sh,*.py} - patchelf --set-rpath $out/lib:${lib.makeLibraryPath ( - finalAttrs.buildInputs ++ [ clr gcc-unwrapped.lib rocm-runtime ])} $test/bin/* - rm -rf $out/test - ''; + postInstall = + lib.optionalString buildDocs '' + mkdir -p $doc + '' + + lib.optionalString buildTests '' + mkdir -p $test/bin + # Not sure why this is an install target + find $out/test -executable -type f -exec mv {} $test/bin \; + rm $test/bin/{*.sh,*.py} + patchelf --set-rpath $out/lib:${ + lib.makeLibraryPath ( + finalAttrs.buildInputs + ++ [ + clr + gcc-unwrapped.lib + rocm-runtime + ] + ) + } $test/bin/* + rm -rf $out/test + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -98,6 +116,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; # mitx11 maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor clr.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor clr.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rocwmma/default.nix b/pkgs/development/rocm-modules/6/rocwmma/default.nix index da7791f51a3a7d..7f6669312fd136 100644 --- a/pkgs/development/rocm-modules/6/rocwmma/default.nix +++ b/pkgs/development/rocm-modules/6/rocwmma/default.nix @@ -1,34 +1,39 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-smi -, clr -, openmp -, gtest -, rocblas -, buildTests ? false # Will likely fail building because wavefront shifts are not supported for certain archs -, buildExtendedTests ? false -, buildBenchmarks ? false -, buildSamples ? false -, gpuTargets ? [ ] # gpuTargets = [ "gfx908:xnack-" "gfx90a:xnack-" "gfx90a:xnack+" ... ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-smi, + clr, + openmp, + gtest, + rocblas, + buildTests ? false, # Will likely fail building because wavefront shifts are not supported for certain archs + buildExtendedTests ? false, + buildBenchmarks ? false, + buildSamples ? false, + gpuTargets ? [ ], # gpuTargets = [ "gfx908:xnack-" "gfx90a:xnack-" "gfx90a:xnack+" ... ] }: stdenv.mkDerivation (finalAttrs: { pname = "rocwmma"; version = "6.0.2"; - outputs = [ - "out" - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - "test" - ] ++ lib.optionals buildBenchmarks [ - "benchmark" - ] ++ lib.optionals buildSamples [ - "sample" - ]; + outputs = + [ + "out" + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + "test" + ] + ++ lib.optionals buildBenchmarks [ + "benchmark" + ] + ++ lib.optionals buildSamples [ + "sample" + ]; src = fetchFromGitHub { owner = "ROCm"; @@ -47,46 +52,56 @@ stdenv.mkDerivation (finalAttrs: { clr ]; - buildInputs = [ - openmp - ] ++ lib.optionals (buildTests || buildBenchmarks) [ - rocm-smi - gtest - rocblas - ]; + buildInputs = + [ + openmp + ] + ++ lib.optionals (buildTests || buildBenchmarks) [ + rocm-smi + gtest + rocblas + ]; - cmakeFlags = [ - "-DCMAKE_CXX_COMPILER=hipcc" - "-DROCWMMA_BUILD_TESTS=${if buildTests || buildBenchmarks then "ON" else "OFF"}" - "-DROCWMMA_BUILD_SAMPLES=${if buildSamples then "ON" else "OFF"}" - # Manually define CMAKE_INSTALL_ - # See: https://github.com/NixOS/nixpkgs/pull/197838 - "-DCMAKE_INSTALL_BINDIR=bin" - "-DCMAKE_INSTALL_LIBDIR=lib" - "-DCMAKE_INSTALL_INCLUDEDIR=include" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals buildExtendedTests [ - "-DROCWMMA_BUILD_EXTENDED_TESTS=ON" - ] ++ lib.optionals buildBenchmarks [ - "-DROCWMMA_BUILD_BENCHMARK_TESTS=ON" - "-DROCWMMA_BENCHMARK_WITH_ROCBLAS=ON" - ]; + cmakeFlags = + [ + "-DCMAKE_CXX_COMPILER=hipcc" + "-DROCWMMA_BUILD_TESTS=${if buildTests || buildBenchmarks then "ON" else "OFF"}" + "-DROCWMMA_BUILD_SAMPLES=${if buildSamples then "ON" else "OFF"}" + # Manually define CMAKE_INSTALL_ + # See: https://github.com/NixOS/nixpkgs/pull/197838 + "-DCMAKE_INSTALL_BINDIR=bin" + "-DCMAKE_INSTALL_LIBDIR=lib" + "-DCMAKE_INSTALL_INCLUDEDIR=include" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals buildExtendedTests [ + "-DROCWMMA_BUILD_EXTENDED_TESTS=ON" + ] + ++ lib.optionals buildBenchmarks [ + "-DROCWMMA_BUILD_BENCHMARK_TESTS=ON" + "-DROCWMMA_BENCHMARK_WITH_ROCBLAS=ON" + ]; - postInstall = lib.optionalString (buildTests || buildBenchmarks) '' - mkdir -p $test/bin - mv $out/bin/{*_test,*-validate} $test/bin - '' + lib.optionalString buildBenchmarks '' - mkdir -p $benchmark/bin - mv $out/bin/*-bench $benchmark/bin - '' + lib.optionalString buildSamples '' - mkdir -p $sample/bin - mv $out/bin/sgemmv $sample/bin - mv $out/bin/simple_gemm $sample/bin - mv $out/bin/simple_dlrm $sample/bin - '' + lib.optionalString (buildTests || buildBenchmarks || buildSamples) '' - rm -rf $out/bin - ''; + postInstall = + lib.optionalString (buildTests || buildBenchmarks) '' + mkdir -p $test/bin + mv $out/bin/{*_test,*-validate} $test/bin + '' + + lib.optionalString buildBenchmarks '' + mkdir -p $benchmark/bin + mv $out/bin/*-bench $benchmark/bin + '' + + lib.optionalString buildSamples '' + mkdir -p $sample/bin + mv $out/bin/sgemmv $sample/bin + mv $out/bin/simple_gemm $sample/bin + mv $out/bin/simple_dlrm $sample/bin + '' + + lib.optionalString (buildTests || buildBenchmarks || buildSamples) '' + rm -rf $out/bin + ''; passthru.updateScript = rocmUpdateScript { name = finalAttrs.pname; @@ -100,6 +115,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/rpp/default.nix b/pkgs/development/rocm-modules/6/rpp/default.nix index 239c99017d026c..31b67cc860576d 100644 --- a/pkgs/development/rocm-modules/6/rpp/default.nix +++ b/pkgs/development/rocm-modules/6/rpp/default.nix @@ -1,27 +1,33 @@ -{ lib -, stdenv -, fetchFromGitHub -, rocmUpdateScript -, cmake -, rocm-cmake -, rocm-docs-core -, half -, clr -, openmp -, boost -, python3Packages -, buildDocs ? false # Needs internet -, useOpenCL ? false -, useCPU ? false -, gpuTargets ? [ ] +{ + lib, + stdenv, + fetchFromGitHub, + rocmUpdateScript, + cmake, + rocm-cmake, + rocm-docs-core, + half, + clr, + openmp, + boost, + python3Packages, + buildDocs ? false, # Needs internet + useOpenCL ? false, + useCPU ? false, + gpuTargets ? [ ], }: stdenv.mkDerivation (finalAttrs: { - pname = "rpp-" + ( - if (!useOpenCL && !useCPU) then "hip" - else if (!useOpenCL && !useCPU) then "opencl" - else "cpu" - ); + pname = + "rpp-" + + ( + if (!useOpenCL && !useCPU) then + "hip" + else if (!useOpenCL && !useCPU) then + "opencl" + else + "cpu" + ); version = "6.0.2"; @@ -32,14 +38,16 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-AquAVoEqlsBVxd41hG2sVo9UoSS+255eCQzIfGkC/Tk="; }; - nativeBuildInputs = [ - cmake - rocm-cmake - clr - ] ++ lib.optionals buildDocs [ - rocm-docs-core - python3Packages.python - ]; + nativeBuildInputs = + [ + cmake + rocm-cmake + clr + ] + ++ lib.optionals buildDocs [ + rocm-docs-core + python3Packages.python + ]; buildInputs = [ half @@ -47,19 +55,24 @@ stdenv.mkDerivation (finalAttrs: { boost ]; - cmakeFlags = [ - "-DROCM_PATH=${clr}" - ] ++ lib.optionals (gpuTargets != [ ]) [ - "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" - ] ++ lib.optionals (!useOpenCL && !useCPU) [ - "-DCMAKE_C_COMPILER=hipcc" - "-DCMAKE_CXX_COMPILER=hipcc" - "-DBACKEND=HIP" - ] ++ lib.optionals (useOpenCL && !useCPU) [ - "-DBACKEND=OCL" - ] ++ lib.optionals useCPU [ - "-DBACKEND=CPU" - ]; + cmakeFlags = + [ + "-DROCM_PATH=${clr}" + ] + ++ lib.optionals (gpuTargets != [ ]) [ + "-DAMDGPU_TARGETS=${lib.concatStringsSep ";" gpuTargets}" + ] + ++ lib.optionals (!useOpenCL && !useCPU) [ + "-DCMAKE_C_COMPILER=hipcc" + "-DCMAKE_CXX_COMPILER=hipcc" + "-DBACKEND=HIP" + ] + ++ lib.optionals (useOpenCL && !useCPU) [ + "-DBACKEND=OCL" + ] + ++ lib.optionals useCPU [ + "-DBACKEND=CPU" + ]; postPatch = lib.optionalString (!useOpenCL && !useCPU) '' # Bad path @@ -83,6 +96,8 @@ stdenv.mkDerivation (finalAttrs: { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor finalAttrs.version != versions.minor stdenv.cc.version || versionAtLeast finalAttrs.version "7.0.0"; + broken = + versions.minor finalAttrs.version != versions.minor stdenv.cc.version + || versionAtLeast finalAttrs.version "7.0.0"; }; }) diff --git a/pkgs/development/rocm-modules/6/tensile/default.nix b/pkgs/development/rocm-modules/6/tensile/default.nix index 6df403249e9aac..0a1f4d60ea5eab 100644 --- a/pkgs/development/rocm-modules/6/tensile/default.nix +++ b/pkgs/development/rocm-modules/6/tensile/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, rocmUpdateScript -, buildPythonPackage -, pytestCheckHook -, setuptools -, pyyaml -, msgpack -, pandas -, joblib -, filelock -, rocminfo +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + rocmUpdateScript, + buildPythonPackage, + pytestCheckHook, + setuptools, + pyyaml, + msgpack, + pandas, + joblib, + filelock, + rocminfo, }: buildPythonPackage rec { @@ -74,6 +75,7 @@ buildPythonPackage rec { license = with licenses; [ mit ]; maintainers = teams.rocm.members; platforms = platforms.linux; - broken = versions.minor version != versions.minor stdenv.cc.version || versionAtLeast version "7.0.0"; + broken = + versions.minor version != versions.minor stdenv.cc.version || versionAtLeast version "7.0.0"; }; } diff --git a/pkgs/development/rocm-modules/6/update.nix b/pkgs/development/rocm-modules/6/update.nix index 4d531e6bb17655..ee638dc58c2f40 100644 --- a/pkgs/development/rocm-modules/6/update.nix +++ b/pkgs/development/rocm-modules/6/update.nix @@ -1,19 +1,19 @@ -{ lib -, writeScript +{ + lib, + writeScript, }: -{ name ? "" -, owner ? "" -, repo ? "" -, page ? "releases/latest" -, filter ? ".tag_name | split(\"-\") | .[1]" +{ + name ? "", + owner ? "", + repo ? "", + page ? "releases/latest", + filter ? ".tag_name | split(\"-\") | .[1]", }: let pname = - if lib.hasPrefix "rocm-llvm-" name - then "llvm.${lib.removePrefix "rocm-llvm-" name}" - else name; + if lib.hasPrefix "rocm-llvm-" name then "llvm.${lib.removePrefix "rocm-llvm-" name}" else name; updateScript = writeScript "update.sh" '' #!/usr/bin/env nix-shell @@ -30,4 +30,5 @@ let update-source-version rocmPackages_6.${pname} "$version" --ignore-same-hash ''; -in [ updateScript ] +in +[ updateScript ] diff --git a/pkgs/development/ruby-modules/bundled-common/default.nix b/pkgs/development/ruby-modules/bundled-common/default.nix index 1cb6574839366a..f60c7f3762958e 100644 --- a/pkgs/development/ruby-modules/bundled-common/default.nix +++ b/pkgs/development/ruby-modules/bundled-common/default.nix @@ -1,34 +1,37 @@ -{ stdenv -, lib -, buildPackages -, runCommand -, ruby -, defaultGemConfig, buildRubyGem, buildEnv -, makeBinaryWrapper -, bundler +{ + stdenv, + lib, + buildPackages, + runCommand, + ruby, + defaultGemConfig, + buildRubyGem, + buildEnv, + makeBinaryWrapper, + bundler, }@defs: { - name ? null -, pname ? null -, mainGemName ? null -, gemdir ? null -, gemfile ? null -, lockfile ? null -, gemset ? null -, ruby ? defs.ruby -, copyGemFiles ? false # Copy gem files instead of symlinking -, gemConfig ? defaultGemConfig -, postBuild ? null -, document ? [] -, meta ? {} -, groups ? null -, ignoreCollisions ? false -, nativeBuildInputs ? [] -, buildInputs ? [] -, extraConfigPaths ? [] -, passthru ? {} -, ... + name ? null, + pname ? null, + mainGemName ? null, + gemdir ? null, + gemfile ? null, + lockfile ? null, + gemset ? null, + ruby ? defs.ruby, + copyGemFiles ? false, # Copy gem files instead of symlinking + gemConfig ? defaultGemConfig, + postBuild ? null, + document ? [ ], + meta ? { }, + groups ? null, + ignoreCollisions ? false, + nativeBuildInputs ? [ ], + buildInputs ? [ ], + extraConfigPaths ? [ ], + passthru ? { }, + ... }@args: assert name == null -> pname != null; @@ -47,54 +50,70 @@ let gemFiles = bundlerFiles args; - importedGemset = if builtins.typeOf gemFiles.gemset != "set" - then import gemFiles.gemset - else gemFiles.gemset; + importedGemset = + if builtins.typeOf gemFiles.gemset != "set" then import gemFiles.gemset else gemFiles.gemset; filteredGemset = filterGemset { inherit ruby groups; } importedGemset; - configuredGemset = lib.flip lib.mapAttrs filteredGemset (name: attrs: - applyGemConfigs (attrs // { inherit ruby document; gemName = name; }) + configuredGemset = lib.flip lib.mapAttrs filteredGemset ( + name: attrs: + applyGemConfigs ( + attrs + // { + inherit ruby document; + gemName = name; + } + ) ); hasBundler = builtins.hasAttr "bundler" filteredGemset; bundler = - if hasBundler then gems.bundler - else defs.bundler.override (attrs: { inherit ruby; }); + if hasBundler then + gems.bundler + else + defs.bundler.override (attrs: { + inherit ruby; + }); gems = lib.flip lib.mapAttrs configuredGemset (name: attrs: buildGem name attrs); - name' = if name != null then - name - else - let - gem = gems.${pname}; - suffix = gem.suffix; - in + name' = + if name != null then + name + else + let + gem = gems.${pname}; + suffix = gem.suffix; + in "${pname}-${suffix}"; - pname' = if pname != null then - pname - else - name; - - copyIfBundledByPath = { bundledByPath ? false, ...}: - (lib.optionalString bundledByPath ( - assert gemFiles.gemdir != null; "cp -a ${gemFiles.gemdir}/* $out/") #*/ - ); - - maybeCopyAll = pkgname: lib.optionalString (pkgname != null) ( - let - mainGem = gems.${pkgname} or (throw "bundlerEnv: gem ${pkgname} not found"); - in + pname' = if pname != null then pname else name; + + copyIfBundledByPath = + { + bundledByPath ? false, + ... + }: + (lib.optionalString bundledByPath ( + assert gemFiles.gemdir != null; + "cp -a ${gemFiles.gemdir}/* $out/" + ) # */ + ); + + maybeCopyAll = + pkgname: + lib.optionalString (pkgname != null) ( + let + mainGem = gems.${pkgname} or (throw "bundlerEnv: gem ${pkgname} not found"); + in copyIfBundledByPath mainGem - ); + ); # We have to normalize the Gemfile.lock, otherwise bundler tries to be # helpful by doing so at run time, causing executables to immediately bail # out. Yes, I'm serious. - confFiles = runCommand "gemfile-and-lockfile" {} '' + confFiles = runCommand "gemfile-and-lockfile" { } '' mkdir -p $out ${maybeCopyAll mainGemName} cp ${gemFiles.gemfile} $out/Gemfile || ls -l $out/Gemfile @@ -103,19 +122,20 @@ let ${lib.concatMapStringsSep "\n" (path: "cp -r ${path} $out/") extraConfigPaths} ''; - buildGem = name: attrs: ( - let - gemAttrs = composeGemAttrs ruby gems name attrs; - in - if gemAttrs.type == "path" then - pathDerivation (gemAttrs.source // gemAttrs) - else - buildRubyGem gemAttrs - ); + buildGem = + name: attrs: + ( + let + gemAttrs = composeGemAttrs ruby gems name attrs; + in + if gemAttrs.type == "path" then + pathDerivation (gemAttrs.source // gemAttrs) + else + buildRubyGem gemAttrs + ); envPaths = lib.attrValues gems ++ lib.optional (!hasBundler) bundler; - basicEnvArgs = { inherit nativeBuildInputs buildInputs ignoreCollisions; @@ -124,70 +144,93 @@ let paths = envPaths; pathsToLink = [ "/lib" ]; - postBuild = genStubsScript (defs // args // { - inherit confFiles bundler groups; - binPaths = envPaths; - }) + lib.optionalString (postBuild != null) postBuild; - - meta = { platforms = ruby.meta.platforms; } // meta; - - passthru = (lib.optionalAttrs (pname != null) { - inherit (gems.${pname}) gemType; - } // rec { - inherit ruby bundler gems confFiles envPaths; - - wrappedRuby = stdenv.mkDerivation { - name = "wrapped-ruby-${pname'}"; - - nativeBuildInputs = [ makeBinaryWrapper ]; - - dontUnpack = true; - - buildPhase = '' - mkdir -p $out/bin - for i in ${ruby}/bin/*; do - makeWrapper "$i" $out/bin/$(basename "$i") \ - --set BUNDLE_GEMFILE ${confFiles}/Gemfile \ - --unset BUNDLE_PATH \ - --set BUNDLE_FROZEN 1 \ - --set GEM_HOME ${basicEnv}/${ruby.gemPath} \ - --set GEM_PATH ${basicEnv}/${ruby.gemPath} - done - ''; - - dontInstall = true; - - doCheck = true; - checkPhase = '' - $out/bin/ruby --help > /dev/null - ''; - - inherit (ruby) meta; - }; - - env = let - irbrc = builtins.toFile "irbrc" '' - if !(ENV["OLD_IRBRC"].nil? || ENV["OLD_IRBRC"].empty?) - require ENV["OLD_IRBRC"] - end - require 'rubygems' - require 'bundler/setup' - ''; - in stdenv.mkDerivation { - name = "${pname'}-interactive-environment"; - nativeBuildInputs = [ wrappedRuby basicEnv ]; - shellHook = '' - export OLD_IRBRC=$IRBRC - export IRBRC=${irbrc} + postBuild = + genStubsScript ( + defs + // args + // { + inherit confFiles bundler groups; + binPaths = envPaths; + } + ) + + lib.optionalString (postBuild != null) postBuild; + + meta = { + platforms = ruby.meta.platforms; + } // meta; + + passthru = ( + lib.optionalAttrs (pname != null) { + inherit (gems.${pname}) gemType; + } + // rec { + inherit + ruby + bundler + gems + confFiles + envPaths + ; + + wrappedRuby = stdenv.mkDerivation { + name = "wrapped-ruby-${pname'}"; + + nativeBuildInputs = [ makeBinaryWrapper ]; + + dontUnpack = true; + + buildPhase = '' + mkdir -p $out/bin + for i in ${ruby}/bin/*; do + makeWrapper "$i" $out/bin/$(basename "$i") \ + --set BUNDLE_GEMFILE ${confFiles}/Gemfile \ + --unset BUNDLE_PATH \ + --set BUNDLE_FROZEN 1 \ + --set GEM_HOME ${basicEnv}/${ruby.gemPath} \ + --set GEM_PATH ${basicEnv}/${ruby.gemPath} + done ''; - buildCommand = '' - echo >&2 "" - echo >&2 "*** Ruby 'env' attributes are intended for interactive nix-shell sessions, not for building! ***" - echo >&2 "" - exit 1 + + dontInstall = true; + + doCheck = true; + checkPhase = '' + $out/bin/ruby --help > /dev/null ''; + + inherit (ruby) meta; }; - } // passthru); + + env = + let + irbrc = builtins.toFile "irbrc" '' + if !(ENV["OLD_IRBRC"].nil? || ENV["OLD_IRBRC"].empty?) + require ENV["OLD_IRBRC"] + end + require 'rubygems' + require 'bundler/setup' + ''; + in + stdenv.mkDerivation { + name = "${pname'}-interactive-environment"; + nativeBuildInputs = [ + wrappedRuby + basicEnv + ]; + shellHook = '' + export OLD_IRBRC=$IRBRC + export IRBRC=${irbrc} + ''; + buildCommand = '' + echo >&2 "" + echo >&2 "*** Ruby 'env' attributes are intended for interactive nix-shell sessions, not for building! ***" + echo >&2 "" + exit 1 + ''; + }; + } + // passthru + ); }; basicEnv = @@ -202,4 +245,4 @@ let else buildEnv basicEnvArgs; in - basicEnv +basicEnv diff --git a/pkgs/development/ruby-modules/bundled-common/functions.nix b/pkgs/development/ruby-modules/bundled-common/functions.nix index 3f9e49fc53be82..8b0d38d5388eb7 100644 --- a/pkgs/development/ruby-modules/bundled-common/functions.nix +++ b/pkgs/development/ruby-modules/bundled-common/functions.nix @@ -1,76 +1,111 @@ { lib, gemConfig, ... }: let - inherit (lib) attrValues concatMap converge filterAttrs getAttrs - intersectLists; + inherit (lib) + attrValues + concatMap + converge + filterAttrs + getAttrs + intersectLists + ; -in rec { - bundlerFiles = { - gemfile ? null - , lockfile ? null - , gemset ? null - , gemdir ? null - , ... - }: { - inherit gemdir; +in +rec { + bundlerFiles = + { + gemfile ? null, + lockfile ? null, + gemset ? null, + gemdir ? null, + ... + }: + { + inherit gemdir; - gemfile = - if gemfile == null then assert gemdir != null; gemdir + "/Gemfile" - else gemfile; + gemfile = + if gemfile == null then + assert gemdir != null; + gemdir + "/Gemfile" + else + gemfile; - lockfile = - if lockfile == null then assert gemdir != null; gemdir + "/Gemfile.lock" - else lockfile; + lockfile = + if lockfile == null then + assert gemdir != null; + gemdir + "/Gemfile.lock" + else + lockfile; - gemset = - if gemset == null then assert gemdir != null; gemdir + "/gemset.nix" - else gemset; - }; + gemset = + if gemset == null then + assert gemdir != null; + gemdir + "/gemset.nix" + else + gemset; + }; - filterGemset = { ruby, groups, ... }: gemset: + filterGemset = + { ruby, groups, ... }: + gemset: let platformGems = filterAttrs (_: platformMatches ruby) gemset; directlyMatchingGems = filterAttrs (_: groupMatches groups) platformGems; - expandDependencies = gems: + expandDependencies = + gems: let - depNames = concatMap (gem: gem.dependencies or []) (attrValues gems); + depNames = concatMap (gem: gem.dependencies or [ ]) (attrValues gems); deps = getAttrs depNames platformGems; in - gems // deps; + gems // deps; in - converge expandDependencies directlyMatchingGems; + converge expandDependencies directlyMatchingGems; - platformMatches = {rubyEngine, version, ...}: attrs: ( - !(attrs ? platforms) || - builtins.length attrs.platforms == 0 || - builtins.any (platform: - platform.engine == rubyEngine && - (!(platform ? version) || platform.version == version.majMin) - ) attrs.platforms - ); + platformMatches = + { rubyEngine, version, ... }: + attrs: + ( + !(attrs ? platforms) + || builtins.length attrs.platforms == 0 + || builtins.any ( + platform: + platform.engine == rubyEngine && (!(platform ? version) || platform.version == version.majMin) + ) attrs.platforms + ); - groupMatches = groups: attrs: - groups == null || !(attrs ? groups) || - (intersectLists (groups ++ [ "default" ]) attrs.groups) != []; + groupMatches = + groups: attrs: + groups == null + || !(attrs ? groups) + || (intersectLists (groups ++ [ "default" ]) attrs.groups) != [ ]; - applyGemConfigs = attrs: - (if gemConfig ? ${attrs.gemName} - then attrs // gemConfig.${attrs.gemName} attrs - else attrs); + applyGemConfigs = + attrs: (if gemConfig ? ${attrs.gemName} then attrs // gemConfig.${attrs.gemName} attrs else attrs); - genStubsScript = { lib, runCommand, ruby, confFiles, bundler, groups, binPaths, ... }: + genStubsScript = + { + lib, + runCommand, + ruby, + confFiles, + bundler, + groups, + binPaths, + ... + }: let - genStubsScript = runCommand "gen-bin-stubs" - { - strictDeps = true; - nativeBuildInputs = [ ruby ]; - } - '' - cp ${./gen-bin-stubs.rb} $out - chmod +x $out - patchShebangs --build $out - ''; + genStubsScript = + runCommand "gen-bin-stubs" + { + strictDeps = true; + nativeBuildInputs = [ ruby ]; + } + '' + cp ${./gen-bin-stubs.rb} $out + chmod +x $out + patchShebangs --build $out + ''; in '' ${genStubsScript} \ @@ -82,27 +117,39 @@ in rec { ${lib.escapeShellArg groups} ''; - pathDerivation = { gemName, version, path, ... }: + pathDerivation = + { + gemName, + version, + path, + ... + }: let res = { - type = "derivation"; - bundledByPath = true; - name = gemName; - version = version; - outPath = "${path}"; - outputs = [ "out" ]; - out = res; - outputName = "out"; - suffix = version; - gemType = "path"; - }; - in res; + type = "derivation"; + bundledByPath = true; + name = gemName; + version = version; + outPath = "${path}"; + outputs = [ "out" ]; + out = res; + outputName = "out"; + suffix = version; + gemType = "path"; + }; + in + res; - composeGemAttrs = ruby: gems: name: attrs: ((removeAttrs attrs ["platforms"]) // { - inherit ruby; - inherit (attrs.source) type; - source = removeAttrs attrs.source ["type"]; - gemName = name; - gemPath = map (gemName: gems.${gemName}) (attrs.dependencies or []); - }); + composeGemAttrs = + ruby: gems: name: attrs: + ( + (removeAttrs attrs [ "platforms" ]) + // { + inherit ruby; + inherit (attrs.source) type; + source = removeAttrs attrs.source [ "type" ]; + gemName = name; + gemPath = map (gemName: gems.${gemName}) (attrs.dependencies or [ ]); + } + ); } diff --git a/pkgs/development/ruby-modules/bundled-common/test.nix b/pkgs/development/ruby-modules/bundled-common/test.nix index ab03f48445b389..61fcb30ef7826c 100644 --- a/pkgs/development/ruby-modules/bundled-common/test.nix +++ b/pkgs/development/ruby-modules/bundled-common/test.nix @@ -1,50 +1,140 @@ -{ lib, ruby, defaultGemConfig, test, should }: +{ + lib, + ruby, + defaultGemConfig, + test, + should, +}: let testConfigs = { inherit lib; - gemConfig = defaultGemConfig; + gemConfig = defaultGemConfig; }; functions = (import ./functions.nix testConfigs); in - builtins.concatLists [ - ( test.run "All set, no gemdir" (functions.bundlerFiles { - gemfile = test/Gemfile; +builtins.concatLists [ + (test.run "All set, no gemdir" + (functions.bundlerFiles { + gemfile = test/Gemfile; lockfile = test/Gemfile.lock; - gemset = test/gemset.nix; - }) { - gemfile = should.equal test/Gemfile; - lockfile = should.equal test/Gemfile.lock; - gemset = should.equal test/gemset.nix; + gemset = test/gemset.nix; }) + { + gemfile = should.equal test/Gemfile; + lockfile = should.equal test/Gemfile.lock; + gemset = should.equal test/gemset.nix; + } + ) - ( test.run "Just gemdir" (functions.bundlerFiles { + (test.run "Just gemdir" + (functions.bundlerFiles { gemdir = test/.; - }) { - gemfile = should.equal test/Gemfile; - lockfile = should.equal test/Gemfile.lock; - gemset = should.equal test/gemset.nix; }) + { + gemfile = should.equal test/Gemfile; + lockfile = should.equal test/Gemfile.lock; + gemset = should.equal test/gemset.nix; + } + ) - ( test.run "Gemset and dir" (functions.bundlerFiles { + (test.run "Gemset and dir" + (functions.bundlerFiles { gemdir = test/.; gemset = test/extraGemset.nix; - }) { - gemfile = should.equal test/Gemfile; - lockfile = should.equal test/Gemfile.lock; - gemset = should.equal test/extraGemset.nix; }) + { + gemfile = should.equal test/Gemfile; + lockfile = should.equal test/Gemfile.lock; + gemset = should.equal test/extraGemset.nix; + } + ) - ( test.run "Filter empty gemset" {} (set: functions.filterGemset {inherit ruby; groups = ["default"]; } set == {})) - ( let gemSet = { test = { groups = ["x" "y"]; }; }; - in - test.run "Filter matches a group" gemSet (set: functions.filterGemset {inherit ruby; groups = ["y" "z"];} set == gemSet)) - ( let gemSet = { test = { platforms = []; }; }; - in - test.run "Filter matches empty platforms list" gemSet (set: functions.filterGemset {inherit ruby; groups = [];} set == gemSet)) - ( let gemSet = { test = { platforms = [{engine = ruby.rubyEngine; version = ruby.version.majMin;}]; }; }; - in - test.run "Filter matches on platform" gemSet (set: functions.filterGemset {inherit ruby; groups = [];} set == gemSet)) - ( let gemSet = { test = { groups = ["x" "y"]; }; }; - in - test.run "Filter excludes based on groups" gemSet (set: functions.filterGemset {inherit ruby; groups = ["a" "b"];} set == {})) - ] + (test.run "Filter empty gemset" { } ( + set: + functions.filterGemset { + inherit ruby; + groups = [ "default" ]; + } set == { } + )) + ( + let + gemSet = { + test = { + groups = [ + "x" + "y" + ]; + }; + }; + in + test.run "Filter matches a group" gemSet ( + set: + functions.filterGemset { + inherit ruby; + groups = [ + "y" + "z" + ]; + } set == gemSet + ) + ) + ( + let + gemSet = { + test = { + platforms = [ ]; + }; + }; + in + test.run "Filter matches empty platforms list" gemSet ( + set: + functions.filterGemset { + inherit ruby; + groups = [ ]; + } set == gemSet + ) + ) + ( + let + gemSet = { + test = { + platforms = [ + { + engine = ruby.rubyEngine; + version = ruby.version.majMin; + } + ]; + }; + }; + in + test.run "Filter matches on platform" gemSet ( + set: + functions.filterGemset { + inherit ruby; + groups = [ ]; + } set == gemSet + ) + ) + ( + let + gemSet = { + test = { + groups = [ + "x" + "y" + ]; + }; + }; + in + test.run "Filter excludes based on groups" gemSet ( + set: + functions.filterGemset { + inherit ruby; + groups = [ + "a" + "b" + ]; + } set == { } + ) + ) +] diff --git a/pkgs/development/ruby-modules/bundler-app/default.nix b/pkgs/development/ruby-modules/bundler-app/default.nix index 01e90ba53f1ff7..b6c4dd2f8452f8 100644 --- a/pkgs/development/ruby-modules/bundler-app/default.nix +++ b/pkgs/development/ruby-modules/bundler-app/default.nix @@ -1,4 +1,10 @@ -{ lib, callPackage, runCommand, makeWrapper, ruby }@defs: +{ + lib, + callPackage, + runCommand, + makeWrapper, + ruby, +}@defs: # Use for simple installation of Ruby tools shipped in a Gem. # Start with a Gemfile that includes `gem ` @@ -11,67 +17,88 @@ # The 'exes' parameter ensures that a copy of e.g. rake doesn't polute the system. { # use the name of the name in question; its version will be picked up from the gemset - pname + pname, # Gemdir is the location of the Gemfile{,.lock} and gemset.nix; usually ./. # This is required unless gemfile, lockfile, and gemset are all provided -, gemdir ? null + gemdir ? null, # Exes is the list of executables provided by the gems in the Gemfile -, exes ? [] + exes ? [ ], # Scripts are ruby programs depend on gems in the Gemfile (e.g. scripts/rails) -, scripts ? [] -, ruby ? defs.ruby -, gemfile ? null -, lockfile ? null -, gemset ? null -, preferLocalBuild ? false -, allowSubstitutes ? false -, installManpages ? true -, meta ? {} -, nativeBuildInputs ? [] -, buildInputs ? [] -, postBuild ? "" -, gemConfig ? null -, passthru ? {} + scripts ? [ ], + ruby ? defs.ruby, + gemfile ? null, + lockfile ? null, + gemset ? null, + preferLocalBuild ? false, + allowSubstitutes ? false, + installManpages ? true, + meta ? { }, + nativeBuildInputs ? [ ], + buildInputs ? [ ], + postBuild ? "", + gemConfig ? null, + passthru ? { }, }@args: let - basicEnv = (callPackage ../bundled-common { - inherit ruby; - }) args; + basicEnv = + (callPackage ../bundled-common { + inherit ruby; + }) + args; - cmdArgs = removeAttrs args [ "pname" "postBuild" "gemConfig" "passthru" "gemset" "gemdir" ] // { - inherit preferLocalBuild allowSubstitutes; # pass the defaults + cmdArgs = + removeAttrs args [ + "pname" + "postBuild" + "gemConfig" + "passthru" + "gemset" + "gemdir" + ] + // { + inherit preferLocalBuild allowSubstitutes; # pass the defaults - nativeBuildInputs = nativeBuildInputs ++ lib.optionals (scripts != []) [ makeWrapper ]; + nativeBuildInputs = nativeBuildInputs ++ lib.optionals (scripts != [ ]) [ makeWrapper ]; - meta = { - mainProgram = pname; - inherit (ruby.meta) platforms; - } // meta; - passthru = basicEnv.passthru // { - inherit basicEnv; - inherit (basicEnv) env; - } // passthru; - }; + meta = { + mainProgram = pname; + inherit (ruby.meta) platforms; + } // meta; + passthru = + basicEnv.passthru + // { + inherit basicEnv; + inherit (basicEnv) env; + } + // passthru; + }; in - runCommand basicEnv.name cmdArgs '' - mkdir -p $out/bin - ${(lib.concatMapStrings (x: "ln -s '${basicEnv}/bin/${x}' $out/bin/${x};\n") exes)} - ${(lib.concatMapStrings (s: "makeWrapper $out/bin/$(basename ${s}) $srcdir/${s} " + - "--set BUNDLE_GEMFILE ${basicEnv.confFiles}/Gemfile "+ - "--unset BUNDLE_PATH "+ - "--set BUNDLE_FROZEN 1 "+ - "--set GEM_HOME ${basicEnv}/${ruby.gemPath} "+ - "--set GEM_PATH ${basicEnv}/${ruby.gemPath} "+ - "--chdir \"$srcdir\";\n") scripts)} +runCommand basicEnv.name cmdArgs '' + mkdir -p $out/bin + ${(lib.concatMapStrings (x: "ln -s '${basicEnv}/bin/${x}' $out/bin/${x};\n") exes)} + ${ + (lib.concatMapStrings ( + s: + "makeWrapper $out/bin/$(basename ${s}) $srcdir/${s} " + + "--set BUNDLE_GEMFILE ${basicEnv.confFiles}/Gemfile " + + "--unset BUNDLE_PATH " + + "--set BUNDLE_FROZEN 1 " + + "--set GEM_HOME ${basicEnv}/${ruby.gemPath} " + + "--set GEM_PATH ${basicEnv}/${ruby.gemPath} " + + "--chdir \"$srcdir\";\n" + ) scripts) + } - ${lib.optionalString installManpages '' + ${lib.optionalString installManpages '' for section in {1..9}; do mandir="$out/share/man/man$section" # See: https://github.com/NixOS/nixpkgs/blob/master/pkgs/development/ruby-modules/gem/default.nix#L184-L200 # See: https://github.com/rubygems/rubygems/blob/7a7b234721c375874b7e22b1c5b14925b943f04e/bundler/lib/bundler.rb#L285-L291 - find -L ${basicEnv}/${ruby.gemPath}/${lib.optionalString (basicEnv.gemType == "git" || basicEnv.gemType == "url") "bundler/"}gems/${basicEnv.name} \( -wholename "*/man/*.$section" -o -wholename "*/man/man$section/*.$section" \) -print -execdir mkdir -p $mandir \; -execdir cp '{}' $mandir \; + find -L ${basicEnv}/${ruby.gemPath}/${ + lib.optionalString (basicEnv.gemType == "git" || basicEnv.gemType == "url") "bundler/" + }gems/${basicEnv.name} \( -wholename "*/man/*.$section" -o -wholename "*/man/man$section/*.$section" \) -print -execdir mkdir -p $mandir \; -execdir cp '{}' $mandir \; done - ''} - '' + ''} +'' diff --git a/pkgs/development/ruby-modules/bundler-env/default.nix b/pkgs/development/ruby-modules/bundler-env/default.nix index 35fecb70c00521..df43ce4c6a36fa 100644 --- a/pkgs/development/ruby-modules/bundler-env/default.nix +++ b/pkgs/development/ruby-modules/bundler-env/default.nix @@ -1,30 +1,53 @@ -{ ruby, lib, callPackage, defaultGemConfig, buildEnv, runCommand -, buildPackages -, bundler +{ + ruby, + lib, + callPackage, + defaultGemConfig, + buildEnv, + runCommand, + buildPackages, + bundler, }@defs: -{ name ? null -, pname ? null -, gemdir ? null -, gemfile ? null -, lockfile ? null -, gemset ? null -, groups ? ["default"] -, ruby ? defs.ruby -, copyGemFiles ? false # Copy gem files instead of symlinking -, gemConfig ? defaultGemConfig -, postBuild ? null -, document ? [] -, meta ? {} -, ignoreCollisions ? false -, passthru ? {} -, ... +{ + name ? null, + pname ? null, + gemdir ? null, + gemfile ? null, + lockfile ? null, + gemset ? null, + groups ? [ "default" ], + ruby ? defs.ruby, + copyGemFiles ? false, # Copy gem files instead of symlinking + gemConfig ? defaultGemConfig, + postBuild ? null, + document ? [ ], + meta ? { }, + ignoreCollisions ? false, + passthru ? { }, + ... }@args: let - inherit (import ../bundled-common/functions.nix { inherit lib ruby gemConfig groups; }) genStubsScript; + inherit + (import ../bundled-common/functions.nix { + inherit + lib + ruby + gemConfig + groups + ; + }) + genStubsScript + ; - basicEnv = (callPackage ../bundled-common { inherit bundler; }) (args // { inherit pname name; mainGemName = pname; }); + basicEnv = (callPackage ../bundled-common { inherit bundler; }) ( + args + // { + inherit pname name; + mainGemName = pname; + } + ); inherit (basicEnv) envPaths; # Idea here is a mkDerivation that gen-bin-stubs new stubs "as specified" - @@ -37,40 +60,53 @@ let # Different use cases should use different variations on this file, rather # than the expression trying to deduce a use case. - # The basicEnv should be put into passthru so that e.g. nix-shell can use it. in - if pname == null then - basicEnv // { inherit name basicEnv; } - else - let - bundlerEnvArgs = { - inherit ignoreCollisions; +# The basicEnv should be put into passthru so that e.g. nix-shell can use it. +if pname == null then + basicEnv // { inherit name basicEnv; } +else + let + bundlerEnvArgs = { + inherit ignoreCollisions; - name = basicEnv.name; + name = basicEnv.name; - paths = envPaths; - pathsToLink = [ "/lib" ]; + paths = envPaths; + pathsToLink = [ "/lib" ]; - postBuild = genStubsScript { - inherit lib runCommand ruby bundler groups; + postBuild = + genStubsScript { + inherit + lib + runCommand + ruby + bundler + groups + ; confFiles = basicEnv.confFiles; binPaths = [ basicEnv.gems.${pname} ]; - } + lib.optionalString (postBuild != null) postBuild; + } + + lib.optionalString (postBuild != null) postBuild; - meta = { platforms = ruby.meta.platforms; } // meta; - passthru = basicEnv.passthru // { + meta = { + platforms = ruby.meta.platforms; + } // meta; + passthru = + basicEnv.passthru + // { inherit basicEnv; inherit (basicEnv) env; - } // passthru; - }; - in - if copyGemFiles then - runCommand basicEnv.name bundlerEnvArgs '' - mkdir -p $out - for i in $paths; do - ${buildPackages.rsync}/bin/rsync -a $i/lib $out/ - done - eval "$postBuild" - '' - else - buildEnv bundlerEnvArgs + } + // passthru; + }; + in + if copyGemFiles then + runCommand basicEnv.name bundlerEnvArgs '' + mkdir -p $out + for i in $paths; do + ${buildPackages.rsync}/bin/rsync -a $i/lib $out/ + done + eval "$postBuild" + '' + else + buildEnv bundlerEnvArgs diff --git a/pkgs/development/ruby-modules/bundler-env/test.nix b/pkgs/development/ruby-modules/bundler-env/test.nix index 8fdbafbba42513..da6ac290671519 100644 --- a/pkgs/development/ruby-modules/bundler-env/test.nix +++ b/pkgs/development/ruby-modules/bundler-env/test.nix @@ -1,4 +1,9 @@ -{ callPackage, test, stubs, should}: +{ + callPackage, + test, + stubs, + should, +}: let bundlerEnv = callPackage ./default.nix stubs // { basicEnv = callPackage ../bundled-common stubs; @@ -17,17 +22,20 @@ let lockfile = ./test/Gemfile.lock; }; in - builtins.concatLists [ - (test.run "bundlerEnv { name }" justName { - name = should.equal "test-0.1.2"; - }) - (test.run "bundlerEnv { pname }" pnamed - [ - (should.haveKeys [ "name" "env" "postBuild" ]) - { - name = should.equal "test-0.1.2"; - env = should.beASet; - postBuild = should.havePrefix "/nix/store"; - } +builtins.concatLists [ + (test.run "bundlerEnv { name }" justName { + name = should.equal "test-0.1.2"; + }) + (test.run "bundlerEnv { pname }" pnamed [ + (should.haveKeys [ + "name" + "env" + "postBuild" ]) - ] + { + name = should.equal "test-0.1.2"; + env = should.beASet; + postBuild = should.havePrefix "/nix/store"; + } + ]) +] diff --git a/pkgs/development/ruby-modules/bundler-env/test/gemset.nix b/pkgs/development/ruby-modules/bundler-env/test/gemset.nix index 53f15f96bc6db4..aa4fa980c58061 100644 --- a/pkgs/development/ruby-modules/bundler-env/test/gemset.nix +++ b/pkgs/development/ruby-modules/bundler-env/test/gemset.nix @@ -1,7 +1,7 @@ { test = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j5r0anj8m4qlf2psnldip4b8ha2bsscv11lpdgnfh4nnchzjnxw"; type = "gem"; }; diff --git a/pkgs/development/ruby-modules/bundler-update-script/default.nix b/pkgs/development/ruby-modules/bundler-update-script/default.nix index d0da591b4f5168..037aeef4a0e734 100644 --- a/pkgs/development/ruby-modules/bundler-update-script/default.nix +++ b/pkgs/development/ruby-modules/bundler-update-script/default.nix @@ -1,11 +1,28 @@ -{ runtimeShell, lib, writeScript, bundix, bundler, coreutils, git, nix }: +{ + runtimeShell, + lib, + writeScript, + bundix, + bundler, + coreutils, + git, + nix, +}: attrPath: let updateScript = writeScript "bundler-update-script" '' #!${runtimeShell} - PATH=${lib.makeBinPath [ bundler bundix coreutils git nix ]} + PATH=${ + lib.makeBinPath [ + bundler + bundix + coreutils + git + nix + ] + } set -o errexit set -o nounset set -o pipefail @@ -23,4 +40,8 @@ let bundler lock --update bundix ''; -in [ updateScript attrPath ] +in +[ + updateScript + attrPath +] diff --git a/pkgs/development/ruby-modules/gem/default.nix b/pkgs/development/ruby-modules/gem/default.nix index 5ed890f8ec489a..5d7379cf56c758 100644 --- a/pkgs/development/ruby-modules/gem/default.nix +++ b/pkgs/development/ruby-modules/gem/default.nix @@ -18,259 +18,290 @@ # Normal gem packages can be used outside of bundler; a binstub is created in # $out/bin. -{ lib, fetchurl, fetchgit, makeWrapper, gitMinimal, libobjc -, ruby, bundler -} @ defs: +{ + lib, + fetchurl, + fetchgit, + makeWrapper, + gitMinimal, + libobjc, + ruby, + bundler, +}@defs: lib.makeOverridable ( -{ name ? null -, gemName -, version ? null -, type ? "gem" -, document ? [] # e.g. [ "ri" "rdoc" ] -, platform ? "ruby" -, ruby ? defs.ruby -, stdenv ? ruby.stdenv -, namePrefix ? (let - rubyName = builtins.parseDrvName ruby.name; - in "${rubyName.name}${lib.versions.majorMinor rubyName.version}-") -, nativeBuildInputs ? [] -, buildInputs ? [] -, meta ? {} -, patches ? [] -, gemPath ? [] -, dontStrip ? false -# Assume we don't have to build unless strictly necessary (e.g. the source is a -# git checkout). -# If you need to apply patches, make sure to set `dontBuild = false`; -, dontBuild ? true -, dontInstallManpages ? false -, propagatedBuildInputs ? [] -, propagatedUserEnvPkgs ? [] -, buildFlags ? [] -, passthru ? {} -# bundler expects gems to be stored in the cache directory for certain actions -# such as `bundler install --redownload`. -# At the cost of increasing the store size, you can keep the gems to have closer -# alignment with what Bundler expects. -, keepGemCache ? false -, ...} @ attrs: - -let - src = attrs.src or ( - if type == "gem" then - fetchurl { - urls = map ( - remote: "${remote}/gems/${gemName}-${suffix}.gem" - ) (attrs.source.remotes or [ "https://rubygems.org" ]); - inherit (attrs.source) sha256; - } - else if type == "git" then - fetchgit { - inherit (attrs.source) url rev sha256 fetchSubmodules; - } - else if type == "url" then - fetchurl attrs.source - else - throw "buildRubyGem: don't know how to build a gem of type \"${type}\"" - ); - - # See: https://github.com/rubygems/rubygems/blob/7a7b234721c375874b7e22b1c5b14925b943f04e/bundler/lib/bundler/source/git.rb#L103 - suffix = - if type == "git" then - builtins.substring 0 12 attrs.source.rev - else if platform != "ruby" then - "${version}-${platform}" - else - version; - - documentFlag = - if document == [] - then "-N" - else "--document ${lib.concatStringsSep "," document}"; - -in - -stdenv.mkDerivation ((builtins.removeAttrs attrs ["source"]) // { - inherit ruby; - inherit dontBuild; - inherit dontStrip; - inherit suffix; - gemType = type; - - nativeBuildInputs = [ - ruby makeWrapper - ] ++ lib.optionals (type == "git") [ gitMinimal ] - ++ lib.optionals (type != "gem") [ bundler ] - ++ nativeBuildInputs; - - buildInputs = [ - ruby - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libobjc ] - ++ buildInputs; - - #name = builtins.trace (attrs.name or "no attr.name" ) "${namePrefix}${gemName}-${version}"; - name = attrs.name or "${namePrefix}${gemName}-${suffix}"; - - inherit src; - - - unpackPhase = attrs.unpackPhase or '' - runHook preUnpack - - if [[ -f $src && $src == *.gem ]]; then - if [[ -z "''${dontBuild-}" ]]; then - # we won't know the name of the directory that RubyGems creates, - # so we'll just use a glob to find it and move it over. - gempkg="$src" - sourceRoot=source - gem unpack $gempkg --target=container - cp -r container/* $sourceRoot - rm -r container - - # copy out the original gemspec, for convenience during patching / - # overrides. - gem specification $gempkg --ruby > original.gemspec - gemspec=$(readlink -f .)/original.gemspec + { + name ? null, + gemName, + version ? null, + type ? "gem", + document ? [ ], # e.g. [ "ri" "rdoc" ] + platform ? "ruby", + ruby ? defs.ruby, + stdenv ? ruby.stdenv, + namePrefix ? ( + let + rubyName = builtins.parseDrvName ruby.name; + in + "${rubyName.name}${lib.versions.majorMinor rubyName.version}-" + ), + nativeBuildInputs ? [ ], + buildInputs ? [ ], + meta ? { }, + patches ? [ ], + gemPath ? [ ], + dontStrip ? false, + # Assume we don't have to build unless strictly necessary (e.g. the source is a + # git checkout). + # If you need to apply patches, make sure to set `dontBuild = false`; + dontBuild ? true, + dontInstallManpages ? false, + propagatedBuildInputs ? [ ], + propagatedUserEnvPkgs ? [ ], + buildFlags ? [ ], + passthru ? { }, + # bundler expects gems to be stored in the cache directory for certain actions + # such as `bundler install --redownload`. + # At the cost of increasing the store size, you can keep the gems to have closer + # alignment with what Bundler expects. + keepGemCache ? false, + ... + }@attrs: + + let + src = + attrs.src or ( + if type == "gem" then + fetchurl { + urls = map (remote: "${remote}/gems/${gemName}-${suffix}.gem") ( + attrs.source.remotes or [ "https://rubygems.org" ] + ); + inherit (attrs.source) sha256; + } + else if type == "git" then + fetchgit { + inherit (attrs.source) + url + rev + sha256 + fetchSubmodules + ; + } + else if type == "url" then + fetchurl attrs.source + else + throw "buildRubyGem: don't know how to build a gem of type \"${type}\"" + ); + + # See: https://github.com/rubygems/rubygems/blob/7a7b234721c375874b7e22b1c5b14925b943f04e/bundler/lib/bundler/source/git.rb#L103 + suffix = + if type == "git" then + builtins.substring 0 12 attrs.source.rev + else if platform != "ruby" then + "${version}-${platform}" else - gempkg="$src" - fi - else - # Fall back to the original thing for everything else. - dontBuild="" - preUnpack="" postUnpack="" unpackPhase - fi - - runHook postUnpack - ''; - - # As of ruby 3.0, ruby headers require -fdeclspec when building with clang - # Introduced in https://github.com/ruby/ruby/commit/0958e19ffb047781fe1506760c7cbd8d7fe74e57 - env.NIX_CFLAGS_COMPILE = toString (lib.optionals (ruby.rubyEngine == "ruby" && stdenv.cc.isClang && lib.versionAtLeast ruby.version.major "3") [ - "-fdeclspec" - ]); - - buildPhase = attrs.buildPhase or '' - runHook preBuild - - if [[ "$gemType" == "gem" ]]; then - if [[ -z "$gemspec" ]]; then - gemspec="$(find . -name '*.gemspec')" - echo "found the following gemspecs:" - echo "$gemspec" - gemspec="$(echo "$gemspec" | head -n1)" - fi - - exec 3>&1 - output="$(gem build $gemspec | tee >(cat - >&3))" - exec 3>&- - - gempkg=$(echo "$output" | grep -oP 'File: \K(.*)') - - echo "gem package built: $gempkg" - elif [[ "$gemType" == "git" ]]; then - git init - # remove variations to improve the likelihood of a bit-reproducible output - rm -rf .git/logs/ .git/hooks/ .git/index .git/FETCH_HEAD .git/ORIG_HEAD .git/refs/remotes/origin/HEAD .git/config - # support `git ls-files` - git add . - fi - - runHook postBuild - ''; - - # Note: - # We really do need to keep the $out/${ruby.gemPath}/cache. - # This is very important in order for many parts of RubyGems/Bundler to not blow up. - # See https://github.com/bundler/bundler/issues/3327 - installPhase = attrs.installPhase or '' - runHook preInstall - - export GEM_HOME=$out/${ruby.gemPath} - mkdir -p $GEM_HOME - - echo "buildFlags: $buildFlags" - - ${lib.optionalString (type == "url") '' - ruby ${./nix-bundle-install.rb} \ - "path" \ - '${gemName}' \ - '${version}' \ - '${lib.escapeShellArgs buildFlags}' - ''} - ${lib.optionalString (type == "git") '' - ruby ${./nix-bundle-install.rb} \ - "git" \ - '${gemName}' \ - '${version}' \ - '${lib.escapeShellArgs buildFlags}' \ - '${attrs.source.url}' \ - '.' \ - '${attrs.source.rev}' - ''} - - ${lib.optionalString (type == "gem") '' - if [[ -z "$gempkg" ]]; then - echo "failure: \$gempkg path unspecified" 1>&2 - exit 1 - elif [[ ! -f "$gempkg" ]]; then - echo "failure: \$gempkg path invalid" 1>&2 - exit 1 - fi - - gem install \ - --local \ - --force \ - --http-proxy 'http://nodtd.invalid' \ - --ignore-dependencies \ - --install-dir "$GEM_HOME" \ - --build-root '/' \ - --backtrace \ - --no-env-shebang \ - ${documentFlag} \ - $gempkg $gemFlags -- $buildFlags - - # looks like useless files which break build repeatability and consume space - pushd $out/${ruby.gemPath} - find doc/ -iname created.rid -delete -print - find gems/*/ext/ extensions/ \( -iname Makefile -o -iname mkmf.log -o -iname gem_make.out \) -delete -print - ${lib.optionalString (!keepGemCache) "rm -fvr cache"} - popd - - # write out metadata and binstubs - spec=$(echo $out/${ruby.gemPath}/specifications/*.gemspec) - ruby ${./gem-post-build.rb} "$spec" - ''} - - ${lib.optionalString (!dontInstallManpages) '' - for section in {1..9}; do - mandir="$out/share/man/man$section" - find $out/lib \( -wholename "*/man/*.$section" -o -wholename "*/man/man$section/*.$section" \) \ - -execdir mkdir -p $mandir \; -execdir cp '{}' $mandir \; - done - ''} - - # For Ruby-generated binstubs, shebang paths are already in Nix store but for - # ruby used to build the package. Update them to match the host system. Note - # that patchShebangsAuto ignores scripts where shebang line is already in Nix - # store. - if [[ -d $GEM_HOME/bin ]]; then - patchShebangs --update --host -- "$GEM_HOME"/bin - fi - - runHook postInstall - ''; - - propagatedBuildInputs = gemPath ++ propagatedBuildInputs; - propagatedUserEnvPkgs = gemPath ++ propagatedUserEnvPkgs; - - passthru = passthru // { isRubyGem = true; }; - meta = { - # default to Ruby's platforms - platforms = ruby.meta.platforms; - mainProgram = gemName; - } // meta; -}) + version; + + documentFlag = if document == [ ] then "-N" else "--document ${lib.concatStringsSep "," document}"; + + in + + stdenv.mkDerivation ( + (builtins.removeAttrs attrs [ "source" ]) + // { + inherit ruby; + inherit dontBuild; + inherit dontStrip; + inherit suffix; + gemType = type; + + nativeBuildInputs = + [ + ruby + makeWrapper + ] + ++ lib.optionals (type == "git") [ gitMinimal ] + ++ lib.optionals (type != "gem") [ bundler ] + ++ nativeBuildInputs; + + buildInputs = + [ + ruby + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ libobjc ] + ++ buildInputs; + + #name = builtins.trace (attrs.name or "no attr.name" ) "${namePrefix}${gemName}-${version}"; + name = attrs.name or "${namePrefix}${gemName}-${suffix}"; + + inherit src; + + unpackPhase = + attrs.unpackPhase or '' + runHook preUnpack + + if [[ -f $src && $src == *.gem ]]; then + if [[ -z "''${dontBuild-}" ]]; then + # we won't know the name of the directory that RubyGems creates, + # so we'll just use a glob to find it and move it over. + gempkg="$src" + sourceRoot=source + gem unpack $gempkg --target=container + cp -r container/* $sourceRoot + rm -r container + + # copy out the original gemspec, for convenience during patching / + # overrides. + gem specification $gempkg --ruby > original.gemspec + gemspec=$(readlink -f .)/original.gemspec + else + gempkg="$src" + fi + else + # Fall back to the original thing for everything else. + dontBuild="" + preUnpack="" postUnpack="" unpackPhase + fi + + runHook postUnpack + ''; + + # As of ruby 3.0, ruby headers require -fdeclspec when building with clang + # Introduced in https://github.com/ruby/ruby/commit/0958e19ffb047781fe1506760c7cbd8d7fe74e57 + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals + (ruby.rubyEngine == "ruby" && stdenv.cc.isClang && lib.versionAtLeast ruby.version.major "3") + [ + "-fdeclspec" + ] + ); + + buildPhase = + attrs.buildPhase or '' + runHook preBuild + + if [[ "$gemType" == "gem" ]]; then + if [[ -z "$gemspec" ]]; then + gemspec="$(find . -name '*.gemspec')" + echo "found the following gemspecs:" + echo "$gemspec" + gemspec="$(echo "$gemspec" | head -n1)" + fi + + exec 3>&1 + output="$(gem build $gemspec | tee >(cat - >&3))" + exec 3>&- + + gempkg=$(echo "$output" | grep -oP 'File: \K(.*)') + + echo "gem package built: $gempkg" + elif [[ "$gemType" == "git" ]]; then + git init + # remove variations to improve the likelihood of a bit-reproducible output + rm -rf .git/logs/ .git/hooks/ .git/index .git/FETCH_HEAD .git/ORIG_HEAD .git/refs/remotes/origin/HEAD .git/config + # support `git ls-files` + git add . + fi + + runHook postBuild + ''; + + # Note: + # We really do need to keep the $out/${ruby.gemPath}/cache. + # This is very important in order for many parts of RubyGems/Bundler to not blow up. + # See https://github.com/bundler/bundler/issues/3327 + installPhase = + attrs.installPhase or '' + runHook preInstall + + export GEM_HOME=$out/${ruby.gemPath} + mkdir -p $GEM_HOME + + echo "buildFlags: $buildFlags" + + ${lib.optionalString (type == "url") '' + ruby ${./nix-bundle-install.rb} \ + "path" \ + '${gemName}' \ + '${version}' \ + '${lib.escapeShellArgs buildFlags}' + ''} + ${lib.optionalString (type == "git") '' + ruby ${./nix-bundle-install.rb} \ + "git" \ + '${gemName}' \ + '${version}' \ + '${lib.escapeShellArgs buildFlags}' \ + '${attrs.source.url}' \ + '.' \ + '${attrs.source.rev}' + ''} + + ${lib.optionalString (type == "gem") '' + if [[ -z "$gempkg" ]]; then + echo "failure: \$gempkg path unspecified" 1>&2 + exit 1 + elif [[ ! -f "$gempkg" ]]; then + echo "failure: \$gempkg path invalid" 1>&2 + exit 1 + fi + + gem install \ + --local \ + --force \ + --http-proxy 'http://nodtd.invalid' \ + --ignore-dependencies \ + --install-dir "$GEM_HOME" \ + --build-root '/' \ + --backtrace \ + --no-env-shebang \ + ${documentFlag} \ + $gempkg $gemFlags -- $buildFlags + + # looks like useless files which break build repeatability and consume space + pushd $out/${ruby.gemPath} + find doc/ -iname created.rid -delete -print + find gems/*/ext/ extensions/ \( -iname Makefile -o -iname mkmf.log -o -iname gem_make.out \) -delete -print + ${lib.optionalString (!keepGemCache) "rm -fvr cache"} + popd + + # write out metadata and binstubs + spec=$(echo $out/${ruby.gemPath}/specifications/*.gemspec) + ruby ${./gem-post-build.rb} "$spec" + ''} + + ${lib.optionalString (!dontInstallManpages) '' + for section in {1..9}; do + mandir="$out/share/man/man$section" + find $out/lib \( -wholename "*/man/*.$section" -o -wholename "*/man/man$section/*.$section" \) \ + -execdir mkdir -p $mandir \; -execdir cp '{}' $mandir \; + done + ''} + + # For Ruby-generated binstubs, shebang paths are already in Nix store but for + # ruby used to build the package. Update them to match the host system. Note + # that patchShebangsAuto ignores scripts where shebang line is already in Nix + # store. + if [[ -d $GEM_HOME/bin ]]; then + patchShebangs --update --host -- "$GEM_HOME"/bin + fi + + runHook postInstall + ''; + + propagatedBuildInputs = gemPath ++ propagatedBuildInputs; + propagatedUserEnvPkgs = gemPath ++ propagatedUserEnvPkgs; + + passthru = passthru // { + isRubyGem = true; + }; + meta = { + # default to Ruby's platforms + platforms = ruby.meta.platforms; + mainProgram = gemName; + } // meta; + } + ) ) diff --git a/pkgs/development/ruby-modules/testing/assertions.nix b/pkgs/development/ruby-modules/testing/assertions.nix index f28cfcd508d47f..c8e7f9a05e94ed 100644 --- a/pkgs/development/ruby-modules/testing/assertions.nix +++ b/pkgs/development/ruby-modules/testing/assertions.nix @@ -1,28 +1,34 @@ -{ test, lib, ...}: +{ test, lib, ... }: { - equal = expected: actual: + equal = + expected: actual: if actual == expected then - (test.passed "= ${toString expected}") else + (test.passed "= ${toString expected}") + else (test.failed ( - "expected '${toString expected}'(${builtins.typeOf expected})" - + " != "+ - "actual '${toString actual}'(${builtins.typeOf actual})" + "expected '${toString expected}'(${builtins.typeOf expected})" + + " != " + + "actual '${toString actual}'(${builtins.typeOf actual})" )); - beASet = actual: + beASet = + actual: if builtins.isAttrs actual then - (test.passed "is a set") else + (test.passed "is a set") + else (test.failed "is not a set, was ${builtins.typeOf actual}: ${toString actual}"); - haveKeys = expected: actual: - if builtins.all - (ex: builtins.any (ac: ex == ac) (builtins.attrNames actual)) - expected then - (test.passed "has expected keys") else + haveKeys = + expected: actual: + if builtins.all (ex: builtins.any (ac: ex == ac) (builtins.attrNames actual)) expected then + (test.passed "has expected keys") + else (test.failed "keys differ: expected: [${lib.concatStringsSep ";" expected}] actual: [${lib.concatStringsSep ";" (builtins.attrNames actual)}]"); - havePrefix = expected: actual: + havePrefix = + expected: actual: if lib.hasPrefix expected actual then - (test.passed "has prefix '${expected}'") else + (test.passed "has prefix '${expected}'") + else (test.failed "prefix '${expected}' not found in '${actual}'"); } diff --git a/pkgs/development/ruby-modules/testing/driver.nix b/pkgs/development/ruby-modules/testing/driver.nix index 23a9a1cec543de..6ca12ee4b64ff5 100644 --- a/pkgs/development/ruby-modules/testing/driver.nix +++ b/pkgs/development/ruby-modules/testing/driver.nix @@ -1,11 +1,17 @@ /* -Run with: -nix-build -E 'with import { }; callPackage ./test.nix {}' --show-trace; and cat result + Run with: + nix-build -E 'with import { }; callPackage ./test.nix {}' --show-trace; and cat result -Confusingly, the ideal result ends with something like: -error: build of ‘/nix/store/3245f3dcl2wxjs4rci7n069zjlz8qg85-test-results.tap.drv’ failed + Confusingly, the ideal result ends with something like: + error: build of ‘/nix/store/3245f3dcl2wxjs4rci7n069zjlz8qg85-test-results.tap.drv’ failed */ -{ writeText, lib, callPackage, testFiles, ruby }@defs: +{ + writeText, + lib, + callPackage, + testFiles, + ruby, +}@defs: let testTools = rec { test = import ./testing.nix; @@ -17,4 +23,4 @@ let results = builtins.concatLists (map (file: callPackage file testTools) testFiles); in - writeText "test-results.tap" (tap.output results) +writeText "test-results.tap" (tap.output results) diff --git a/pkgs/development/ruby-modules/testing/stubs.nix b/pkgs/development/ruby-modules/testing/stubs.nix index aaab2f6896023e..b0258988888fbe 100644 --- a/pkgs/development/ruby-modules/testing/stubs.nix +++ b/pkgs/development/ruby-modules/testing/stubs.nix @@ -1,15 +1,41 @@ -{ stdenv, lib, ruby, callPackage, ... }: +{ + stdenv, + lib, + ruby, + callPackage, + ... +}: let - mkDerivation = {name, ...}@argSet: - derivation { - inherit name; - text = (builtins.toJSON (lib.filterAttrs ( n: v: builtins.any (x: x == n) ["name" "system"]) argSet)); - builder = stdenv.shell; - args = [ "-c" "echo $(<$textPath) > $out"]; - system = stdenv.hostPlatform.system; - passAsFile = ["text"]; - }; - fetchurl = {url?"", urls ? [],...}: "fetchurl:${if urls == [] then url else builtins.head urls}"; + mkDerivation = + { name, ... }@argSet: + derivation { + inherit name; + text = ( + builtins.toJSON ( + lib.filterAttrs ( + n: v: + builtins.any (x: x == n) [ + "name" + "system" + ] + ) argSet + ) + ); + builder = stdenv.shell; + args = [ + "-c" + "echo $(<$textPath) > $out" + ]; + system = stdenv.hostPlatform.system; + passAsFile = [ "text" ]; + }; + fetchurl = + { + url ? "", + urls ? [ ], + ... + }: + "fetchurl:${if urls == [ ] then url else builtins.head urls}"; stdenv' = stdenv // { inherit mkDerivation; @@ -20,11 +46,11 @@ let stubbed = true; }; in - { +{ + ruby = ruby'; + buildRubyGem = callPackage ../gem { + inherit fetchurl; ruby = ruby'; - buildRubyGem = callPackage ../gem { - inherit fetchurl; - ruby = ruby'; - }; - stdenv = stdenv'; - } + }; + stdenv = stdenv'; +} diff --git a/pkgs/development/ruby-modules/testing/tap-support.nix b/pkgs/development/ruby-modules/testing/tap-support.nix index 74fcceebaa0420..000b8a4a53cbf0 100644 --- a/pkgs/development/ruby-modules/testing/tap-support.nix +++ b/pkgs/development/ruby-modules/testing/tap-support.nix @@ -1,21 +1,29 @@ with builtins; let - withIndexes = list: genList (idx: (elemAt list idx) // {index = idx;}) (length list); + withIndexes = list: genList (idx: (elemAt list idx) // { index = idx; }) (length list); - testLine = report: "${okStr report} ${toString (report.index + 1)} ${report.description}" + testDirective report + testYaml report; + testLine = + report: + "${okStr report} ${toString (report.index + 1)} ${report.description}" + + testDirective report + + testYaml report; # These are part of the TAP spec, not yet implemented. #c.f. https://github.com/NixOS/nixpkgs/issues/27071 testDirective = report: ""; testYaml = report: ""; - okStr = { result, ...}: if result == "pass" then "ok" else "not ok"; + okStr = { result, ... }: if result == "pass" then "ok" else "not ok"; in - { - output = reports: '' +{ + output = + reports: + '' TAP version 13 - 1..${toString (length reports)}'' + (foldl' (l: r: l + "\n" + r) "" (map testLine (withIndexes reports))) + '' + 1..${toString (length reports)}'' + + (foldl' (l: r: l + "\n" + r) "" (map testLine (withIndexes reports))) + + '' # Finished at ${toString currentTime} - ''; - } + ''; +} diff --git a/pkgs/development/ruby-modules/testing/testing.nix b/pkgs/development/ruby-modules/testing/testing.nix index 43d10fca044499..ef19506e7c3c3a 100644 --- a/pkgs/development/ruby-modules/testing/testing.nix +++ b/pkgs/development/ruby-modules/testing/testing.nix @@ -1,27 +1,27 @@ with builtins; let /* - underTest = { - x = { - a = 1; - b = "2"; + underTest = { + x = { + a = 1; + b = "2"; + }; }; - }; - tests = [ - (root: false) - { - x = [ - (set: true) - { - a = (a: a > 1); - b = (b: b == "3"); - } - ]; - } - ]; + tests = [ + (root: false) + { + x = [ + (set: true) + { + a = (a: a > 1); + b = (b: b == "3"); + } + ]; + } + ]; - results = run "Examples" underTest tests; + results = run "Examples" underTest tests; */ passed = desc: { @@ -39,24 +39,35 @@ let description = "${name}: ${res.description}"; }; - run = name: under: tests: if isList tests then - (concatLists (map (run name under) tests)) - else if isAttrs tests then - (concatLists (map ( - subName: run (name + "." + subName) (if hasAttr subName under then getAttr subName under else "") (getAttr subName tests) - ) (attrNames tests))) - else if isFunction tests then - let - res = tests under; - in + run = + name: under: tests: + if isList tests then + (concatLists (map (run name under) tests)) + else if isAttrs tests then + (concatLists ( + map ( + subName: + run (name + "." + subName) (if hasAttr subName under then getAttr subName under else "") ( + getAttr subName tests + ) + ) (attrNames tests) + )) + else if isFunction tests then + let + res = tests under; + in if isBool res then [ (prefixName name (if tests under then passed "passed" else failed "failed")) ] else [ (prefixName name res) ] - else [ - failed (name ": not a function, list or set") - ]; + else + [ + failed + (name ": not a function, list or set") + ]; in - { inherit run passed failed; } +{ + inherit run passed failed; +} diff --git a/pkgs/development/ruby-modules/with-packages/default.nix b/pkgs/development/ruby-modules/with-packages/default.nix index 31573bce499fcb..96bb7018cc2911 100644 --- a/pkgs/development/ruby-modules/with-packages/default.nix +++ b/pkgs/development/ruby-modules/with-packages/default.nix @@ -1,44 +1,64 @@ -{ stdenv, lib, buildEnv, buildRubyGem, ruby, gemConfig, makeBinaryWrapper }: +{ + stdenv, + lib, + buildEnv, + buildRubyGem, + ruby, + gemConfig, + makeBinaryWrapper, +}: /* -Example usage: -nix-shell -E "(import {}).ruby.withPackages (pkgs: with pkgs; [ pry nokogiri ])" + Example usage: + nix-shell -E "(import {}).ruby.withPackages (pkgs: with pkgs; [ pry nokogiri ])" -You can also use this for writing ruby scripts that run anywhere that has nix -using a nix-shell shebang: - #!/usr/bin/env nix-shell - #!nix-shell -i ruby -p "ruby.withPackages (pkgs: with pkgs; [ pry nokogiri ])" + You can also use this for writing ruby scripts that run anywhere that has nix + using a nix-shell shebang: + #!/usr/bin/env nix-shell + #!nix-shell -i ruby -p "ruby.withPackages (pkgs: with pkgs; [ pry nokogiri ])" - -Run the following in the nixpkgs root directory to update the ruby-packages.nix: -./maintainers/scripts/update-ruby-packages + Run the following in the nixpkgs root directory to update the ruby-packages.nix: + ./maintainers/scripts/update-ruby-packages */ let functions = import ../bundled-common/functions.nix { inherit lib gemConfig; }; - buildGems = gemset: + buildGems = + gemset: let realGemset = if builtins.isAttrs gemset then gemset else import gemset; - builtGems = - lib.mapAttrs (name: initialAttrs: - let - attrs = functions.applyGemConfigs ({ inherit ruby; gemName = name; } // initialAttrs); - in - buildRubyGem (functions.composeGemAttrs ruby builtGems name attrs) - ) realGemset; - in builtGems; + builtGems = lib.mapAttrs ( + name: initialAttrs: + let + attrs = functions.applyGemConfigs ( + { + inherit ruby; + gemName = name; + } + // initialAttrs + ); + in + buildRubyGem (functions.composeGemAttrs ruby builtGems name attrs) + ) realGemset; + in + builtGems; gems = buildGems (import ../../../top-level/ruby-packages.nix); - withPackages = selector: + withPackages = + selector: let selected = selector gems; gemEnv = buildEnv { name = "ruby-gems"; paths = selected; - pathsToLink = [ "/lib" "/bin" "/nix-support" ]; + pathsToLink = [ + "/lib" + "/bin" + "/nix-support" + ]; }; wrappedRuby = stdenv.mkDerivation { @@ -52,10 +72,14 @@ let ''; }; - in stdenv.mkDerivation { + in + stdenv.mkDerivation { name = "${ruby.name}-with-packages"; nativeBuildInputs = [ makeBinaryWrapper ]; - buildInputs = [ selected ruby ]; + buildInputs = [ + selected + ruby + ]; dontUnpack = true; @@ -74,4 +98,7 @@ let }; }; -in { inherit withPackages gems buildGems; } +in +{ + inherit withPackages gems buildGems; +} diff --git a/pkgs/development/ruby-modules/with-packages/require_exceptions.nix b/pkgs/development/ruby-modules/with-packages/require_exceptions.nix index e6ae3b5013fe81..f59ad38cf01e5f 100644 --- a/pkgs/development/ruby-modules/with-packages/require_exceptions.nix +++ b/pkgs/development/ruby-modules/with-packages/require_exceptions.nix @@ -3,7 +3,8 @@ let require "cocoapods" require "#{Gem::Specification.find_by_name(%(${name})).gem_dir}/lib/cocoapods_plugin" ''; -in { +in +{ actioncable = [ "action_cable" ]; actionmailer = [ "action_mailer" ]; actionpack = [ "action_pack" ]; @@ -15,9 +16,15 @@ in { activesupport = [ "active_support" ]; atk = [ "atk" ]; CFPropertyList = [ "cfpropertylist" ]; - cocoapods-acknowledgements = [ "cocoapods" "cocoapods_acknowledgements" ]; + cocoapods-acknowledgements = [ + "cocoapods" + "cocoapods_acknowledgements" + ]; cocoapods-art = [ "cocoapods_art" ]; - cocoapods-browser = [ "cocoapods" "cocoapods_plugin" ]; + cocoapods-browser = [ + "cocoapods" + "cocoapods_plugin" + ]; cocoapods-bugsnag = cocoapod-plugin "cocoapods-bugsnag"; cocoapods-clean = [ "cocoapods_clean" ]; cocoapods-coverage = [ "cocoapods_coverage" ]; @@ -26,8 +33,11 @@ in { cocoapods-deploy = cocoapod-plugin "cocoapods-deploy"; cocoapods-generate = cocoapod-plugin "cocoapods-generate"; cocoapods-git_url_rewriter = cocoapod-plugin "cocoapods-git_url_rewriter"; - cocoapods-keys = []; # osx only cocoapod-plugin "cocoapods-keys"; - cocoapods-open = [ "cocoapods" "cocoapods_plugin" ]; + cocoapods-keys = [ ]; # osx only cocoapod-plugin "cocoapods-keys"; + cocoapods-open = [ + "cocoapods" + "cocoapods_plugin" + ]; cocoapods-packager = [ "cocoapods_packager" ]; cocoapods-packager-pro = [ ]; # requires osx cocoapods-plugins = [ "cocoapods_plugins" ]; @@ -50,7 +60,7 @@ in { gobject-introspection = [ "gobject-introspection" ]; gtk2 = [ ]; # requires display idn-ruby = [ "idn" ]; - jekyll-sass-converter = []; # tested through jekyll + jekyll-sass-converter = [ ]; # tested through jekyll libxml-ruby = [ "libxml" ]; multipart-post = [ "multipart_post" ]; unicode-display_width = [ "unicode/display_width" ]; @@ -73,7 +83,12 @@ in { ruby-macho = [ "macho" ]; ruby-terminfo = [ "terminfo" ]; rubyzip = [ "zip" ]; - sequel_pg = [ "pg" "sequel" "sequel/adapters/postgresql" "sequel_pg" ]; + sequel_pg = [ + "pg" + "sequel" + "sequel/adapters/postgresql" + "sequel_pg" + ]; simplecov-html = [ ]; # tested through simplecov sinatra = [ "sinatra/base" ]; sprockets-rails = [ "sprockets/rails" ]; diff --git a/pkgs/development/ruby-modules/with-packages/test.nix b/pkgs/development/ruby-modules/with-packages/test.nix index 50947a44a2434c..b22e2931cf1207 100644 --- a/pkgs/development/ruby-modules/with-packages/test.nix +++ b/pkgs/development/ruby-modules/with-packages/test.nix @@ -1,7 +1,7 @@ # a generic test suite for all gems for all ruby versions. # use via nix-build. let - pkgs = import ../../../.. {}; + pkgs = import ../../../.. { }; lib = pkgs.lib; stdenv = pkgs.stdenv; @@ -9,41 +9,43 @@ let ruby_3_2 ]; - gemTests = - (lib.mapAttrs - (name: gem: [ name ]) - pkgs.ruby.gems) // - (import ./require_exceptions.nix); + gemTests = (lib.mapAttrs (name: gem: [ name ]) pkgs.ruby.gems) // (import ./require_exceptions.nix); - testWrapper = ruby: stdenv.mkDerivation { - name = "test-wrappedRuby-${ruby.name}"; - buildInputs = [ ((ruby.withPackages (ps: [ ])).wrappedRuby) ]; - buildCommand = '' - cat <<'EOF' > test-ruby - #!/usr/bin/env ruby - puts RUBY_VERSION - EOF + testWrapper = + ruby: + stdenv.mkDerivation { + name = "test-wrappedRuby-${ruby.name}"; + buildInputs = [ ((ruby.withPackages (ps: [ ])).wrappedRuby) ]; + buildCommand = '' + cat <<'EOF' > test-ruby + #!/usr/bin/env ruby + puts RUBY_VERSION + EOF - chmod +x test-ruby - patchShebangs test-ruby - [[ $(./test-ruby) = $(${ruby}/bin/ruby test-ruby) ]] - touch $out - ''; - }; + chmod +x test-ruby + patchShebangs test-ruby + [[ $(./test-ruby) = $(${ruby}/bin/ruby test-ruby) ]] + touch $out + ''; + }; - tests = ruby: - lib.mapAttrs (name: gem: + tests = + ruby: + lib.mapAttrs ( + name: gem: let test = - if builtins.isList gemTests.${name} - then pkgs.writeText "${name}.rb" '' - puts "${name} GEM_HOME: #{ENV['GEM_HOME']}" - ${lib.concatStringsSep "\n" (map (n: "require '${n}'") gemTests.${name})} - '' - else pkgs.writeText "${name}.rb" gemTests.${name}; + if builtins.isList gemTests.${name} then + pkgs.writeText "${name}.rb" '' + puts "${name} GEM_HOME: #{ENV['GEM_HOME']}" + ${lib.concatStringsSep "\n" (map (n: "require '${n}'") gemTests.${name})} + '' + else + pkgs.writeText "${name}.rb" gemTests.${name}; deps = ruby.withPackages (g: [ g.${name} ]); - in stdenv.mkDerivation { + in + stdenv.mkDerivation { name = "test-gem-${ruby.name}-${name}"; buildInputs = [ deps ]; buildCommand = '' @@ -53,10 +55,12 @@ let } ) ruby.gems; in - stdenv.mkDerivation { - name = "test-all-ruby-gems"; - buildInputs = builtins.foldl' (sum: ruby: sum ++ [ (testWrapper ruby) ] ++ ( builtins.attrValues (tests ruby) )) [] rubyVersions; - buildCommand = '' - touch $out - ''; - } +stdenv.mkDerivation { + name = "test-all-ruby-gems"; + buildInputs = builtins.foldl' ( + sum: ruby: sum ++ [ (testWrapper ruby) ] ++ (builtins.attrValues (tests ruby)) + ) [ ] rubyVersions; + buildCommand = '' + touch $out + ''; +} diff --git a/pkgs/development/skaware-packages/build-skaware-man-pages.nix b/pkgs/development/skaware-packages/build-skaware-man-pages.nix index 3e317d608c03fa..5f5471d8caaa18 100644 --- a/pkgs/development/skaware-packages/build-skaware-man-pages.nix +++ b/pkgs/development/skaware-packages/build-skaware-man-pages.nix @@ -1,22 +1,26 @@ -{ lib, stdenv, fetchFromSourcehut }: +{ + lib, + stdenv, + fetchFromSourcehut, +}: { # : string - pname + pname, # : string -, version + version, # : string -, sha256 + sha256, # : string -, description + description, # : list Maintainer -, maintainers + maintainers, # : license -, license ? lib.licenses.isc + license ? lib.licenses.isc, # : string -, owner ? "~flexibeast" + owner ? "~flexibeast", # : string -, rev ? "v${version}" + rev ? "v${version}", }: let diff --git a/pkgs/development/skaware-packages/build-skaware-package.nix b/pkgs/development/skaware-packages/build-skaware-package.nix index abad5441456675..2bb9340e6579dd 100644 --- a/pkgs/development/skaware-packages/build-skaware-package.nix +++ b/pkgs/development/skaware-packages/build-skaware-package.nix @@ -1,33 +1,44 @@ -{ lib, stdenv, cleanPackaging, fetchurl }: +{ + lib, + stdenv, + cleanPackaging, + fetchurl, +}: { # : string - pname + pname, # : string -, version + version, # : string -, sha256 ? lib.fakeSha256 + sha256 ? lib.fakeSha256, # : drv | null -, manpages ? null + manpages ? null, # : string -, description + description, # : list Platform -, platforms ? lib.platforms.all + platforms ? lib.platforms.all, # : list string -, outputs ? [ "bin" "lib" "dev" "doc" "out" ] + outputs ? [ + "bin" + "lib" + "dev" + "doc" + "out" + ], # TODO(Profpatsch): automatically infer most of these # : list string -, configureFlags + configureFlags, # : string -, postConfigure ? null + postConfigure ? null, # mostly for moving and deleting files from the build directory # : lines -, postInstall + postInstall, # : list Maintainer -, maintainers ? [ ] + maintainers ? [ ], # : passthru arguments (e.g. tests) -, passthru ? { } + passthru ? { }, # : attributes to be merged into meta -, broken ? false + broken ? false, }: let @@ -67,53 +78,68 @@ stdenv.mkDerivation { }; outputs = - if manpages == null - then outputs + if manpages == null then + outputs else - assert (lib.assertMsg (!lib.elem "man" outputs) "If you pass `manpages` to `skawarePackages.buildPackage`, you cannot have a `man` output already!"); - # insert as early as posible, but keep the first element - if lib.length outputs > 0 - then [(lib.head outputs) "man"] ++ lib.tail outputs - else ["man"]; + assert ( + lib.assertMsg (!lib.elem "man" outputs) + "If you pass `manpages` to `skawarePackages.buildPackage`, you cannot have a `man` output already!" + ); + # insert as early as posible, but keep the first element + if lib.length outputs > 0 then + [ + (lib.head outputs) + "man" + ] + ++ lib.tail outputs + else + [ "man" ]; dontDisableStatic = true; enableParallelBuilding = true; - configureFlags = configureFlags ++ [ - "--enable-absolute-paths" - # We assume every nix-based cross target has urandom. - # This might not hold for e.g. BSD. - "--with-sysdep-devurandom=yes" - (if stdenv.hostPlatform.isDarwin - then "--disable-shared" - else "--enable-shared") - ] + configureFlags = + configureFlags + ++ [ + "--enable-absolute-paths" + # We assume every nix-based cross target has urandom. + # This might not hold for e.g. BSD. + "--with-sysdep-devurandom=yes" + (if stdenv.hostPlatform.isDarwin then "--disable-shared" else "--enable-shared") + ] # On darwin, the target triplet from -dumpmachine includes version number, # but skarnet.org software uses the triplet to test binary compatibility. # Explicitly setting target ensures code can be compiled against a skalibs # binary built on a different version of darwin. # http://www.skarnet.org/cgi-bin/archive.cgi?1:mss:623:heiodchokfjdkonfhdph - ++ (lib.optional stdenv.hostPlatform.isDarwin - "--build=${stdenv.hostPlatform.system}"); + ++ (lib.optional stdenv.hostPlatform.isDarwin "--build=${stdenv.hostPlatform.system}"); inherit postConfigure; - makeFlags = lib.optionals stdenv.cc.isClang [ "AR=${stdenv.cc.targetPrefix}ar" "RANLIB=${stdenv.cc.targetPrefix}ranlib" ]; + makeFlags = lib.optionals stdenv.cc.isClang [ + "AR=${stdenv.cc.targetPrefix}ar" + "RANLIB=${stdenv.cc.targetPrefix}ranlib" + ]; # TODO(Profpatsch): ensure that there is always a $doc output! postInstall = '' echo "Cleaning & moving common files" - ${cleanPackaging.commonFileActions { - noiseFiles = commonNoiseFiles; - docFiles = commonMetaFiles; - }} $doc/share/doc/${pname} - - ${if manpages == null - then ''echo "no manpages for this package"'' - else '' - echo "copying manpages" - cp -vr ${manpages} $man - ''} + ${ + cleanPackaging.commonFileActions { + noiseFiles = commonNoiseFiles; + docFiles = commonMetaFiles; + } + } $doc/share/doc/${pname} + + ${ + if manpages == null then + ''echo "no manpages for this package"'' + else + '' + echo "copying manpages" + cp -vr ${manpages} $man + '' + } ${postInstall} ''; @@ -122,14 +148,20 @@ stdenv.mkDerivation { ${cleanPackaging.checkForRemainingFiles} ''; - passthru = passthru // (if manpages == null then {} else { inherit manpages; }); + passthru = passthru // (if manpages == null then { } else { inherit manpages; }); meta = { homepage = "https://skarnet.org/software/${pname}/"; inherit broken description platforms; license = lib.licenses.isc; - maintainers = with lib.maintainers; - [ pmahoney Profpatsch qyliss ] ++ maintainers; + maintainers = + with lib.maintainers; + [ + pmahoney + Profpatsch + qyliss + ] + ++ maintainers; }; } diff --git a/pkgs/development/skaware-packages/clean-packaging.nix b/pkgs/development/skaware-packages/clean-packaging.nix index d51cbec8aeb267..6437bb370f9829 100644 --- a/pkgs/development/skaware-packages/clean-packaging.nix +++ b/pkgs/development/skaware-packages/clean-packaging.nix @@ -3,26 +3,30 @@ # files were either discarded or moved to outputs. # This ensures nothing is forgotten and new files # are correctly handled on update. -{ lib, stdenv, file, writeScript }: +{ + lib, + stdenv, + file, + writeScript, +}: let globWith = lib.concatMapStringsSep "\n"; - rmNoise = noiseGlobs: globWith (f: - "rm -rf ${f}") noiseGlobs; - mvDoc = docGlobs: globWith - (f: ''mv ${f} "$DOCDIR" 2>/dev/null || true'') - docGlobs; + rmNoise = noiseGlobs: globWith (f: "rm -rf ${f}") noiseGlobs; + mvDoc = docGlobs: globWith (f: ''mv ${f} "$DOCDIR" 2>/dev/null || true'') docGlobs; # Shell script that implements common move & remove actions # $1 is the doc directory (will be created). # Best used in conjunction with checkForRemainingFiles commonFileActions = - { # list of fileglobs that are removed from the source dir - noiseFiles + { + # list of fileglobs that are removed from the source dir + noiseFiles, # files that are moved to the doc directory ($1) # TODO(Profpatsch): allow to set target dir with # { glob = …; to = "html" } (relative to docdir) - , docFiles }: + docFiles, + }: writeScript "common-file-actions.sh" '' #!${stdenv.shell} set -e @@ -48,6 +52,7 @@ let fi ''; -in { +in +{ inherit commonFileActions checkForRemainingFiles; } diff --git a/pkgs/development/skaware-packages/default.nix b/pkgs/development/skaware-packages/default.nix index 4800b6e6a854c7..b0877ada8c36aa 100644 --- a/pkgs/development/skaware-packages/default.nix +++ b/pkgs/development/skaware-packages/default.nix @@ -1,40 +1,43 @@ { lib, pkgs }: -lib.makeScope pkgs.newScope (self: +lib.makeScope pkgs.newScope ( + self: let inherit (self) callPackage; - in { - buildManPages = callPackage ./build-skaware-man-pages.nix { }; - buildPackage = callPackage ./build-skaware-package.nix { }; - cleanPackaging = callPackage ./clean-packaging.nix { }; + in + { + buildManPages = callPackage ./build-skaware-man-pages.nix { }; + buildPackage = callPackage ./build-skaware-package.nix { }; + cleanPackaging = callPackage ./clean-packaging.nix { }; - # execline - execline = callPackage ./execline { }; + # execline + execline = callPackage ./execline { }; - # servers & tools - mdevd = callPackage ./mdevd { }; - nsss = callPackage ./nsss { }; - tipidee = callPackage ./tipidee { }; - utmps = callPackage ./utmps { }; + # servers & tools + mdevd = callPackage ./mdevd { }; + nsss = callPackage ./nsss { }; + tipidee = callPackage ./tipidee { }; + utmps = callPackage ./utmps { }; - # libs - skalibs = callPackage ./skalibs { }; - skalibs_2_10 = callPackage ./skalibs/2_10.nix { }; - sdnotify-wrapper = callPackage ./sdnotify-wrapper { }; + # libs + skalibs = callPackage ./skalibs { }; + skalibs_2_10 = callPackage ./skalibs/2_10.nix { }; + sdnotify-wrapper = callPackage ./sdnotify-wrapper { }; - # s6 tooling - s6 = callPackage ./s6 { }; - s6-dns = callPackage ./s6-dns { }; - s6-linux-init = callPackage ./s6-linux-init { }; - s6-linux-utils = callPackage ./s6-linux-utils { }; - s6-networking = callPackage ./s6-networking { }; - s6-portable-utils = callPackage ./s6-portable-utils { }; - s6-rc = callPackage ./s6-rc { }; + # s6 tooling + s6 = callPackage ./s6 { }; + s6-dns = callPackage ./s6-dns { }; + s6-linux-init = callPackage ./s6-linux-init { }; + s6-linux-utils = callPackage ./s6-linux-utils { }; + s6-networking = callPackage ./s6-networking { }; + s6-portable-utils = callPackage ./s6-portable-utils { }; + s6-rc = callPackage ./s6-rc { }; - # manpages (DEPRECATED, they are added directly to the packages now) - execline-man-pages = self.execline.passthru.manpages; - s6-man-pages = self.s6.passthru.manpages; - s6-networking-man-pages = self.s6-networking.passthru.manpages; - s6-portable-utils-man-pages = self.s6-portable-utils.passthru.manpages; - s6-rc-man-pages = self.s6-rc.passthru.manpages; -}) + # manpages (DEPRECATED, they are added directly to the packages now) + execline-man-pages = self.execline.passthru.manpages; + s6-man-pages = self.s6.passthru.manpages; + s6-networking-man-pages = self.s6-networking.passthru.manpages; + s6-portable-utils-man-pages = self.s6-portable-utils.passthru.manpages; + s6-rc-man-pages = self.s6-rc.passthru.manpages; + } +) diff --git a/pkgs/development/skaware-packages/execline/default.nix b/pkgs/development/skaware-packages/execline/default.nix index eb552cd23957d8..500d39b773c06d 100644 --- a/pkgs/development/skaware-packages/execline/default.nix +++ b/pkgs/development/skaware-packages/execline/default.nix @@ -1,9 +1,14 @@ -{ lib, skawarePackages, skalibs }: +{ + lib, + skawarePackages, + skalibs, +}: let version = "2.9.6.1"; -in skawarePackages.buildPackage { +in +skawarePackages.buildPackage { inherit version; pname = "execline"; @@ -24,7 +29,13 @@ in skawarePackages.buildPackage { description = "Small scripting language, to be used in place of a shell in non-interactive scripts"; - outputs = [ "bin" "lib" "dev" "doc" "out" ]; + outputs = [ + "bin" + "lib" + "dev" + "doc" + "out" + ]; # TODO: nsss support configureFlags = [ diff --git a/pkgs/development/skaware-packages/mdevd/default.nix b/pkgs/development/skaware-packages/mdevd/default.nix index dcc78ad4f60b96..0fd5107e179dd3 100644 --- a/pkgs/development/skaware-packages/mdevd/default.nix +++ b/pkgs/development/skaware-packages/mdevd/default.nix @@ -1,4 +1,8 @@ -{ lib, skawarePackages, skalibs }: +{ + lib, + skawarePackages, + skalibs, +}: skawarePackages.buildPackage { pname = "mdevd"; @@ -8,7 +12,12 @@ skawarePackages.buildPackage { description = "mdev-compatible Linux hotplug manager daemon"; platforms = lib.platforms.linux; - outputs = [ "bin" "out" "dev" "doc" ]; + outputs = [ + "bin" + "out" + "dev" + "doc" + ]; configureFlags = [ "--with-sysdeps=${skalibs.lib}/lib/skalibs/sysdeps" diff --git a/pkgs/development/skaware-packages/s6-dns/default.nix b/pkgs/development/skaware-packages/s6-dns/default.nix index e51beccd74d2ad..e5ed1be433e043 100644 --- a/pkgs/development/skaware-packages/s6-dns/default.nix +++ b/pkgs/development/skaware-packages/s6-dns/default.nix @@ -7,7 +7,13 @@ skawarePackages.buildPackage { description = "Suite of DNS client programs and libraries for Unix systems"; - outputs = [ "bin" "lib" "dev" "doc" "out" ]; + outputs = [ + "bin" + "lib" + "dev" + "doc" + "out" + ]; configureFlags = [ "--libdir=\${lib}/lib" diff --git a/pkgs/development/skaware-packages/s6-linux-init/default.nix b/pkgs/development/skaware-packages/s6-linux-init/default.nix index d7d44aeac42ac9..7b35ce8cf0415c 100644 --- a/pkgs/development/skaware-packages/s6-linux-init/default.nix +++ b/pkgs/development/skaware-packages/s6-linux-init/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, skawarePackages -, skalibs -, execline -, s6 -, targetPackages +{ + lib, + stdenv, + skawarePackages, + skalibs, + execline, + s6, + targetPackages, }: skawarePackages.buildPackage { @@ -15,7 +16,12 @@ skawarePackages.buildPackage { description = "Set of minimalistic tools used to create a s6-based init system, including a /sbin/init binary, on a Linux kernel"; platforms = lib.platforms.linux; - outputs = [ "bin" "dev" "doc" "out" ]; + outputs = [ + "bin" + "dev" + "doc" + "out" + ]; configureFlags = [ "--bindir=\${bin}/bin" diff --git a/pkgs/development/skaware-packages/s6-linux-utils/default.nix b/pkgs/development/skaware-packages/s6-linux-utils/default.nix index 23d0d2be69fe4a..338aa8291cff4d 100644 --- a/pkgs/development/skaware-packages/s6-linux-utils/default.nix +++ b/pkgs/development/skaware-packages/s6-linux-utils/default.nix @@ -1,4 +1,8 @@ -{ lib, skawarePackages, skalibs }: +{ + lib, + skawarePackages, + skalibs, +}: skawarePackages.buildPackage { pname = "s6-linux-utils"; @@ -8,7 +12,12 @@ skawarePackages.buildPackage { description = "Set of minimalistic Linux-specific system utilities"; platforms = lib.platforms.linux; - outputs = [ "bin" "dev" "doc" "out" ]; + outputs = [ + "bin" + "dev" + "doc" + "out" + ]; # TODO: nsss support configureFlags = [ diff --git a/pkgs/development/skaware-packages/s6-networking/default.nix b/pkgs/development/skaware-packages/s6-networking/default.nix index b8c2c56a69e9e2..a30c7f8c0c458c 100644 --- a/pkgs/development/skaware-packages/s6-networking/default.nix +++ b/pkgs/development/skaware-packages/s6-networking/default.nix @@ -1,8 +1,16 @@ -{ lib, skawarePackages, skalibs, execline, s6, s6-dns +{ + lib, + skawarePackages, + skalibs, + execline, + s6, + s6-dns, -# Whether to build the TLS/SSL tools and what library to use -# acceptable values: "bearssl", "libressl", false -, sslSupport ? "bearssl" , libressl, bearssl + # Whether to build the TLS/SSL tools and what library to use + # acceptable values: "bearssl", "libressl", false + sslSupport ? "bearssl", + libressl, + bearssl, }: let @@ -15,7 +23,6 @@ let in assert sslSupportEnabled -> sslLibs ? ${sslSupport}; - skawarePackages.buildPackage { pname = "s6-networking"; version = "2.7.0.3"; @@ -31,35 +38,42 @@ skawarePackages.buildPackage { description = "Suite of small networking utilities for Unix systems"; - outputs = [ "bin" "lib" "dev" "doc" "out" ]; + outputs = [ + "bin" + "lib" + "dev" + "doc" + "out" + ]; # TODO: nsss support - configureFlags = [ - "--libdir=\${lib}/lib" - "--libexecdir=\${lib}/libexec" - "--dynlibdir=\${lib}/lib" - "--bindir=\${bin}/bin" - "--includedir=\${dev}/include" - "--with-sysdeps=${skalibs.lib}/lib/skalibs/sysdeps" - "--with-include=${skalibs.dev}/include" - "--with-include=${execline.dev}/include" - "--with-include=${s6.dev}/include" - "--with-include=${s6-dns.dev}/include" - "--with-lib=${skalibs.lib}/lib" - "--with-lib=${execline.lib}/lib" - "--with-lib=${s6.out}/lib" - "--with-lib=${s6-dns.lib}/lib" - "--with-dynlib=${skalibs.lib}/lib" - "--with-dynlib=${execline.lib}/lib" - "--with-dynlib=${s6.out}/lib" - "--with-dynlib=${s6-dns.lib}/lib" - ] - ++ (lib.optionals sslSupportEnabled [ - "--enable-ssl=${sslSupport}" - "--with-include=${lib.getDev sslLibs.${sslSupport}}/include" - "--with-lib=${lib.getLib sslLibs.${sslSupport}}/lib" - "--with-dynlib=${lib.getLib sslLibs.${sslSupport}}/lib" - ]); + configureFlags = + [ + "--libdir=\${lib}/lib" + "--libexecdir=\${lib}/libexec" + "--dynlibdir=\${lib}/lib" + "--bindir=\${bin}/bin" + "--includedir=\${dev}/include" + "--with-sysdeps=${skalibs.lib}/lib/skalibs/sysdeps" + "--with-include=${skalibs.dev}/include" + "--with-include=${execline.dev}/include" + "--with-include=${s6.dev}/include" + "--with-include=${s6-dns.dev}/include" + "--with-lib=${skalibs.lib}/lib" + "--with-lib=${execline.lib}/lib" + "--with-lib=${s6.out}/lib" + "--with-lib=${s6-dns.lib}/lib" + "--with-dynlib=${skalibs.lib}/lib" + "--with-dynlib=${execline.lib}/lib" + "--with-dynlib=${s6.out}/lib" + "--with-dynlib=${s6-dns.lib}/lib" + ] + ++ (lib.optionals sslSupportEnabled [ + "--enable-ssl=${sslSupport}" + "--with-include=${lib.getDev sslLibs.${sslSupport}}/include" + "--with-lib=${lib.getLib sslLibs.${sslSupport}}/lib" + "--with-dynlib=${lib.getLib sslLibs.${sslSupport}}/lib" + ]); postInstall = '' # remove all s6 executables from build directory diff --git a/pkgs/development/skaware-packages/s6-portable-utils/default.nix b/pkgs/development/skaware-packages/s6-portable-utils/default.nix index 51fb31b574bf76..ce363381ec24df 100644 --- a/pkgs/development/skaware-packages/s6-portable-utils/default.nix +++ b/pkgs/development/skaware-packages/s6-portable-utils/default.nix @@ -1,4 +1,8 @@ -{ lib, skawarePackages, skalibs }: +{ + lib, + skawarePackages, + skalibs, +}: skawarePackages.buildPackage { pname = "s6-portable-utils"; @@ -15,7 +19,12 @@ skawarePackages.buildPackage { description = "Set of tiny general Unix utilities optimized for simplicity and small size"; - outputs = [ "bin" "dev" "doc" "out" ]; + outputs = [ + "bin" + "dev" + "doc" + "out" + ]; configureFlags = [ "--bindir=\${bin}/bin" @@ -34,5 +43,4 @@ skawarePackages.buildPackage { mv doc $doc/share/doc/s6-portable-utils/html ''; - } diff --git a/pkgs/development/skaware-packages/s6-rc/default.nix b/pkgs/development/skaware-packages/s6-rc/default.nix index dee9e4ed7209a8..110b869d855333 100644 --- a/pkgs/development/skaware-packages/s6-rc/default.nix +++ b/pkgs/development/skaware-packages/s6-rc/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, skawarePackages, targetPackages, skalibs, execline, s6 }: +{ + lib, + stdenv, + skawarePackages, + targetPackages, + skalibs, + execline, + s6, +}: skawarePackages.buildPackage { pname = "s6-rc"; @@ -16,7 +24,13 @@ skawarePackages.buildPackage { description = "Service manager for s6-based systems"; platforms = lib.platforms.unix; - outputs = [ "bin" "lib" "dev" "doc" "out" ]; + outputs = [ + "bin" + "lib" + "dev" + "doc" + "out" + ]; configureFlags = [ "--libdir=\${lib}/lib" diff --git a/pkgs/development/skaware-packages/s6/default.nix b/pkgs/development/skaware-packages/s6/default.nix index 188e33696c8fcc..69d6e48d88ee57 100644 --- a/pkgs/development/skaware-packages/s6/default.nix +++ b/pkgs/development/skaware-packages/s6/default.nix @@ -1,4 +1,9 @@ -{ lib, skawarePackages, skalibs, execline }: +{ + lib, + skawarePackages, + skalibs, + execline, +}: skawarePackages.buildPackage { pname = "s6"; @@ -18,7 +23,12 @@ skawarePackages.buildPackage { # NOTE lib: cannot split lib from bin at the moment, # since some parts of lib depend on executables in bin. # (the `*_startf` functions in `libs6`) - outputs = [ /*"bin" "lib"*/ "out" "dev" "doc" ]; + outputs = [ + # "bin" "lib" + "out" + "dev" + "doc" + ]; # TODO: nsss support configureFlags = [ diff --git a/pkgs/development/skaware-packages/sdnotify-wrapper/default.nix b/pkgs/development/skaware-packages/sdnotify-wrapper/default.nix index 25d5bc9651932a..d9fa940a3294eb 100644 --- a/pkgs/development/skaware-packages/sdnotify-wrapper/default.nix +++ b/pkgs/development/skaware-packages/sdnotify-wrapper/default.nix @@ -1,36 +1,47 @@ -{ lib, runCommandCC, skalibs }: +{ + lib, + runCommandCC, + skalibs, +}: let # From https://skarnet.org/software/misc/sdnotify-wrapper.c, # which is unversioned. src = ./sdnotify-wrapper.c; -in runCommandCC "sdnotify-wrapper" { +in +runCommandCC "sdnotify-wrapper" + { - outputs = [ "bin" "doc" "out" ]; + outputs = [ + "bin" + "doc" + "out" + ]; - meta = { - homepage = "https://skarnet.org/software/misc/sdnotify-wrapper.c"; - description = "Use systemd sd_notify without having to link against libsystemd"; - mainProgram = "sdnotify-wrapper"; - platforms = lib.platforms.linux; - license = lib.licenses.isc; - maintainers = with lib.maintainers; [ Profpatsch ]; - }; + meta = { + homepage = "https://skarnet.org/software/misc/sdnotify-wrapper.c"; + description = "Use systemd sd_notify without having to link against libsystemd"; + mainProgram = "sdnotify-wrapper"; + platforms = lib.platforms.linux; + license = lib.licenses.isc; + maintainers = with lib.maintainers; [ Profpatsch ]; + }; -} '' - mkdir -p $bin/bin - mkdir $out + } + '' + mkdir -p $bin/bin + mkdir $out - # the -lskarnet has to come at the end to support static builds - $CC \ - -o $bin/bin/sdnotify-wrapper \ - -I${skalibs.dev}/include \ - -L${skalibs.lib}/lib \ - ${src} \ - -lskarnet + # the -lskarnet has to come at the end to support static builds + $CC \ + -o $bin/bin/sdnotify-wrapper \ + -I${skalibs.dev}/include \ + -L${skalibs.lib}/lib \ + ${src} \ + -lskarnet - mkdir -p $doc/share/doc/sdnotify-wrapper - # copy the documentation comment - sed -ne '/Usage:/,/*\//p' ${src} > $doc/share/doc/sdnotify-wrapper/README -'' + mkdir -p $doc/share/doc/sdnotify-wrapper + # copy the documentation comment + sed -ne '/Usage:/,/*\//p' ${src} > $doc/share/doc/sdnotify-wrapper/README + '' diff --git a/pkgs/development/skaware-packages/skalibs/2_10.nix b/pkgs/development/skaware-packages/skalibs/2_10.nix index c9a38b2c022469..478939661954e0 100644 --- a/pkgs/development/skaware-packages/skalibs/2_10.nix +++ b/pkgs/development/skaware-packages/skalibs/2_10.nix @@ -7,7 +7,12 @@ skawarePackages.buildPackage { description = "Set of general-purpose C programming libraries"; - outputs = [ "lib" "dev" "doc" "out" ]; + outputs = [ + "lib" + "dev" + "doc" + "out" + ]; configureFlags = [ # assume /dev/random works diff --git a/pkgs/development/skaware-packages/skalibs/default.nix b/pkgs/development/skaware-packages/skalibs/default.nix index f473135c70c5cc..0f8bfe664c3173 100644 --- a/pkgs/development/skaware-packages/skalibs/default.nix +++ b/pkgs/development/skaware-packages/skalibs/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, skawarePackages -, pkgs +{ + lib, + stdenv, + skawarePackages, + pkgs, }: skawarePackages.buildPackage { @@ -11,31 +12,38 @@ skawarePackages.buildPackage { description = "Set of general-purpose C programming libraries"; - outputs = [ "lib" "dev" "doc" "out" ]; - - configureFlags = [ - # assume /dev/random works - "--enable-force-devr" - "--libdir=\${lib}/lib" - "--dynlibdir=\${lib}/lib" - "--includedir=\${dev}/include" - "--sysdepdir=\${lib}/lib/skalibs/sysdeps" - # Empty the default path, which would be "/usr/bin:bin". - # It would be set when PATH is empty. This hurts hermeticity. - "--with-default-path=" - - ] ++ lib.optionals (stdenv.buildPlatform.config != stdenv.hostPlatform.config) [ - # ./configure: sysdep posixspawnearlyreturn cannot be autodetected - # when cross-compiling. Please manually provide a value with the - # --with-sysdep-posixspawnearlyreturn=yes|no|... option. - # - # posixspawnearlyreturn: `yes` if the target has a broken - # `posix_spawn()` implementation that can return before the - # child has successfully exec'ed. That happens with old glibcs - # and some virtual platforms. - "--with-sysdep-posixspawnearlyreturn=no" + outputs = [ + "lib" + "dev" + "doc" + "out" ]; + configureFlags = + [ + # assume /dev/random works + "--enable-force-devr" + "--libdir=\${lib}/lib" + "--dynlibdir=\${lib}/lib" + "--includedir=\${dev}/include" + "--sysdepdir=\${lib}/lib/skalibs/sysdeps" + # Empty the default path, which would be "/usr/bin:bin". + # It would be set when PATH is empty. This hurts hermeticity. + "--with-default-path=" + + ] + ++ lib.optionals (stdenv.buildPlatform.config != stdenv.hostPlatform.config) [ + # ./configure: sysdep posixspawnearlyreturn cannot be autodetected + # when cross-compiling. Please manually provide a value with the + # --with-sysdep-posixspawnearlyreturn=yes|no|... option. + # + # posixspawnearlyreturn: `yes` if the target has a broken + # `posix_spawn()` implementation that can return before the + # child has successfully exec'ed. That happens with old glibcs + # and some virtual platforms. + "--with-sysdep-posixspawnearlyreturn=no" + ]; + postInstall = '' rm -rf sysdeps.cfg rm libskarnet.* diff --git a/pkgs/development/skaware-packages/tipidee/default.nix b/pkgs/development/skaware-packages/tipidee/default.nix index de3557d58f7659..4ab5af54b194b4 100644 --- a/pkgs/development/skaware-packages/tipidee/default.nix +++ b/pkgs/development/skaware-packages/tipidee/default.nix @@ -1,4 +1,8 @@ -{ skawarePackages, stdenv, skalibs }: +{ + skawarePackages, + stdenv, + skalibs, +}: skawarePackages.buildPackage { pname = "tipidee"; @@ -7,7 +11,13 @@ skawarePackages.buildPackage { description = "HTTP 1.1 webserver, serving static files and CGI/NPH"; - outputs = [ "bin" "lib" "out" "dev" "doc" ]; + outputs = [ + "bin" + "lib" + "out" + "dev" + "doc" + ]; configureFlags = [ "--libdir=\${lib}/lib" diff --git a/pkgs/development/tcl-modules/by-name/bw/bwidget/package.nix b/pkgs/development/tcl-modules/by-name/bw/bwidget/package.nix index 161324f9e6e0e7..f1acf555e6ce8a 100644 --- a/pkgs/development/tcl-modules/by-name/bw/bwidget/package.nix +++ b/pkgs/development/tcl-modules/by-name/bw/bwidget/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, mkTclDerivation, tk }: +{ + lib, + fetchurl, + mkTclDerivation, + tk, +}: mkTclDerivation rec { pname = "bwidget"; diff --git a/pkgs/development/tcl-modules/by-name/ex/expect/package.nix b/pkgs/development/tcl-modules/by-name/ex/expect/package.nix index e1ddab04bfbef1..ae1c8ae21cc1bc 100644 --- a/pkgs/development/tcl-modules/by-name/ex/expect/package.nix +++ b/pkgs/development/tcl-modules/by-name/ex/expect/package.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, buildPackages, fetchurl, tcl, makeWrapper, autoreconfHook, fetchpatch, substituteAll }: +{ + lib, + stdenv, + buildPackages, + fetchurl, + tcl, + makeWrapper, + autoreconfHook, + fetchpatch, + substituteAll, +}: tcl.mkTclDerivation rec { pname = "expect"; @@ -35,7 +45,10 @@ tcl.mkTclDerivation rec { sed -i "s,/bin/stty,$(type -p stty),g" configure.in ''; - nativeBuildInputs = [ autoreconfHook makeWrapper ]; + nativeBuildInputs = [ + autoreconfHook + makeWrapper + ]; strictDeps = true; @@ -50,7 +63,10 @@ tcl.mkTclDerivation rec { ${lib.optionalString stdenv.hostPlatform.isDarwin "tclWrapperArgs+=(--prefix DYLD_LIBRARY_PATH : $out/lib/expect${version})"} ''; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; meta = with lib; { description = "Tool for automating interactive applications"; diff --git a/pkgs/development/tcl-modules/by-name/in/incrtcl/package.nix b/pkgs/development/tcl-modules/by-name/in/incrtcl/package.nix index 7b1397ac1bb8eb..2da1f8192428b2 100644 --- a/pkgs/development/tcl-modules/by-name/in/incrtcl/package.nix +++ b/pkgs/development/tcl-modules/by-name/in/incrtcl/package.nix @@ -1,11 +1,18 @@ -{ lib, stdenv, mkTclDerivation, fetchurl, writeText, tcl }: +{ + lib, + stdenv, + mkTclDerivation, + fetchurl, + writeText, + tcl, +}: mkTclDerivation rec { pname = "incrtcl"; version = "4.2.3"; src = fetchurl { - url = "mirror://sourceforge/incrtcl/%5BIncr%20Tcl_Tk%5D-source/3.4/itcl${version}.tar.gz"; + url = "mirror://sourceforge/incrtcl/%5BIncr%20Tcl_Tk%5D-source/3.4/itcl${version}.tar.gz"; sha256 = "sha256-idOs2GXP3ZY7ECtF+K9hg5REyK6sQ0qk+666gUQPjCY="; }; @@ -27,13 +34,17 @@ mkTclDerivation rec { export ITCL_LIBRARY=@out@/lib ''; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; meta = with lib; { - homepage = "https://incrtcl.sourceforge.net/"; + homepage = "https://incrtcl.sourceforge.net/"; description = "Object Oriented Enhancements for Tcl/Tk"; - license = licenses.tcltk; - platforms = platforms.unix; + license = licenses.tcltk; + platforms = platforms.unix; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/development/tcl-modules/by-name/it/itktcl/package.nix b/pkgs/development/tcl-modules/by-name/it/itktcl/package.nix index aefefa8c3cebd3..7d856b6b188336 100644 --- a/pkgs/development/tcl-modules/by-name/it/itktcl/package.nix +++ b/pkgs/development/tcl-modules/by-name/it/itktcl/package.nix @@ -1,15 +1,25 @@ -{ lib, stdenv, fetchurl, mkTclDerivation, tk, incrtcl }: +{ + lib, + stdenv, + fetchurl, + mkTclDerivation, + tk, + incrtcl, +}: mkTclDerivation rec { pname = "itk-tcl"; version = "4.1.0"; src = fetchurl { - url = "mirror://sourceforge/incrtcl/%5BIncr%20Tcl_Tk%5D-source/3.4/itk${version}.tar.gz"; + url = "mirror://sourceforge/incrtcl/%5BIncr%20Tcl_Tk%5D-source/3.4/itk${version}.tar.gz"; sha256 = "1iy964jfgsfnc1agk1w6bbm44x18ily8d4wmr7cc9z9f4acn2r6s"; }; - buildInputs = [ tk incrtcl ]; + buildInputs = [ + tk + incrtcl + ]; enableParallelBuilding = true; configureFlags = [ @@ -26,13 +36,17 @@ mkTclDerivation rec { rmdir $out/lib/itk${version} ''; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; meta = with lib; { - homepage = "https://incrtcl.sourceforge.net/"; + homepage = "https://incrtcl.sourceforge.net/"; description = "Mega-widget toolkit for incr Tk"; - license = licenses.tcltk; - platforms = platforms.unix; + license = licenses.tcltk; + platforms = platforms.unix; maintainers = with maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/development/tcl-modules/by-name/mu/mustache-tcl/package.nix b/pkgs/development/tcl-modules/by-name/mu/mustache-tcl/package.nix index 5281f40a78e8ef..ff61e9a8d94bfb 100644 --- a/pkgs/development/tcl-modules/by-name/mu/mustache-tcl/package.nix +++ b/pkgs/development/tcl-modules/by-name/mu/mustache-tcl/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, mkTclDerivation, tcllib }: +{ + lib, + fetchFromGitHub, + mkTclDerivation, + tcllib, +}: mkTclDerivation rec { pname = "mustache-tcl"; @@ -29,4 +34,3 @@ mkTclDerivation rec { maintainers = with maintainers; [ nat-418 ]; }; } - diff --git a/pkgs/development/tcl-modules/by-name/tc/tcl-fcgi/package.nix b/pkgs/development/tcl-modules/by-name/tc/tcl-fcgi/package.nix index 49d23ddd9a7245..6f281c82890820 100644 --- a/pkgs/development/tcl-modules/by-name/tc/tcl-fcgi/package.nix +++ b/pkgs/development/tcl-modules/by-name/tc/tcl-fcgi/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, mkTclDerivation, tclx }: +{ + lib, + fetchFromGitHub, + mkTclDerivation, + tclx, +}: mkTclDerivation rec { pname = "tcl-fcgi"; @@ -28,4 +33,3 @@ mkTclDerivation rec { maintainers = with maintainers; [ nat-418 ]; }; } - diff --git a/pkgs/development/tcl-modules/by-name/tc/tcllib/package.nix b/pkgs/development/tcl-modules/by-name/tc/tcllib/package.nix index bfccba88fa66ad..33ca7b53001b92 100644 --- a/pkgs/development/tcl-modules/by-name/tc/tcllib/package.nix +++ b/pkgs/development/tcl-modules/by-name/tc/tcllib/package.nix @@ -1,8 +1,9 @@ -{ lib -, fetchzip -, mkTclDerivation -, critcl -, withCritcl ? true +{ + lib, + fetchzip, + mkTclDerivation, + critcl, + withCritcl ? true, }: mkTclDerivation rec { diff --git a/pkgs/development/tcl-modules/by-name/tc/tclreadline/package.nix b/pkgs/development/tcl-modules/by-name/tc/tclreadline/package.nix index 62880ee5323a62..90c8fa7f3e6cbe 100644 --- a/pkgs/development/tcl-modules/by-name/tc/tclreadline/package.nix +++ b/pkgs/development/tcl-modules/by-name/tc/tclreadline/package.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, automake -, autoconf -, libtool -, readline -, mkTclDerivation -, tk +{ + lib, + stdenv, + fetchFromGitHub, + automake, + autoconf, + libtool, + readline, + mkTclDerivation, + tk, }: mkTclDerivation rec { diff --git a/pkgs/development/tcl-modules/by-name/tc/tcltls/package.nix b/pkgs/development/tcl-modules/by-name/tc/tcltls/package.nix index cb32bf4a7ba8e5..f5f2d99b284d83 100644 --- a/pkgs/development/tcl-modules/by-name/tc/tcltls/package.nix +++ b/pkgs/development/tcl-modules/by-name/tc/tcltls/package.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, mkTclDerivation, openssl }: +{ + lib, + fetchurl, + mkTclDerivation, + openssl, +}: mkTclDerivation rec { pname = "tcltls"; diff --git a/pkgs/development/tcl-modules/by-name/tc/tclx/package.nix b/pkgs/development/tcl-modules/by-name/tc/tclx/package.nix index 8ed3bb6f5931c3..a82b75b56fafec 100644 --- a/pkgs/development/tcl-modules/by-name/tc/tclx/package.nix +++ b/pkgs/development/tcl-modules/by-name/tc/tclx/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, mkTclDerivation +{ + lib, + fetchFromGitHub, + mkTclDerivation, }: mkTclDerivation rec { @@ -15,16 +16,21 @@ mkTclDerivation rec { }; # required in order for tclx to properly detect tclx.tcl at runtime - postInstall = let - majorMinorVersion = lib.versions.majorMinor version; - in '' - ln -s $prefix/lib/tclx${majorMinorVersion} $prefix/lib/tclx${majorMinorVersion}/tclx${majorMinorVersion} - ''; + postInstall = + let + majorMinorVersion = lib.versions.majorMinor version; + in + '' + ln -s $prefix/lib/tclx${majorMinorVersion} $prefix/lib/tclx${majorMinorVersion}/tclx${majorMinorVersion} + ''; meta = { homepage = "https://github.com/flightaware/tclx"; description = "Tcl extensions"; license = lib.licenses.tcltk; - maintainers = with lib.maintainers; [ kovirobi fgaz ]; + maintainers = with lib.maintainers; [ + kovirobi + fgaz + ]; }; } diff --git a/pkgs/development/tcl-modules/by-name/ti/tix/package.nix b/pkgs/development/tcl-modules/by-name/ti/tix/package.nix index 67cee0140de043..9257d4a760aad7 100644 --- a/pkgs/development/tcl-modules/by-name/ti/tix/package.nix +++ b/pkgs/development/tcl-modules/by-name/ti/tix/package.nix @@ -1,35 +1,36 @@ -{ lib -, fetchurl -, fetchpatch -, tcl -, tk +{ + lib, + fetchurl, + fetchpatch, + tcl, + tk, }: tcl.mkTclDerivation { version = "8.4.3"; pname = "tix"; src = fetchurl { - url = "mirror://sourceforge/tix/tix/8.4.3/Tix8.4.3-src.tar.gz"; - sha256 = "1jq3dkyk9mqkj4cg7mdk5r0cclqsby9l2b7wrysi0zk5yw7h8bsn"; + url = "mirror://sourceforge/tix/tix/8.4.3/Tix8.4.3-src.tar.gz"; + sha256 = "1jq3dkyk9mqkj4cg7mdk5r0cclqsby9l2b7wrysi0zk5yw7h8bsn"; }; - patches = [ - (fetchpatch { - name = "tix-8.4.3-tcl8.5.patch"; - url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/dev-tcltk/tix/files/tix-8.4.3-tcl8.5.patch?id=56bd759df1d0c750a065b8c845e93d5dfa6b549d"; - sha256 = "0wzqmcxxq0rqpnjgxz10spw92yhfygnlwv0h8pcx2ycnqiljz6vj"; - }) - # Remove duplicated definition of XLowerWindow - ./duplicated-xlowerwindow.patch - # Fix incompatible function pointer conversions and implicit definition of `panic`. - # `panic` is just `Tcl_Panic`, but it is not defined on Darwin due to a conflict with `mach/mach.h`. - ./fix-clang16.patch - ] ++ lib.optional (tcl.release == "8.6") - (fetchpatch { - name = "tix-8.4.3-tcl8.6.patch"; - url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/dev-tcltk/tix/files/tix-8.4.3-tcl8.6.patch?id=56bd759df1d0c750a065b8c845e93d5dfa6b549d"; - sha256 = "1jaz0l22xj7x1k4rb9ia6i1psnbwk4pblgq4gfvya7gg7fbb7r36"; - }) - ; + patches = + [ + (fetchpatch { + name = "tix-8.4.3-tcl8.5.patch"; + url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/dev-tcltk/tix/files/tix-8.4.3-tcl8.5.patch?id=56bd759df1d0c750a065b8c845e93d5dfa6b549d"; + sha256 = "0wzqmcxxq0rqpnjgxz10spw92yhfygnlwv0h8pcx2ycnqiljz6vj"; + }) + # Remove duplicated definition of XLowerWindow + ./duplicated-xlowerwindow.patch + # Fix incompatible function pointer conversions and implicit definition of `panic`. + # `panic` is just `Tcl_Panic`, but it is not defined on Darwin due to a conflict with `mach/mach.h`. + ./fix-clang16.patch + ] + ++ lib.optional (tcl.release == "8.6") (fetchpatch { + name = "tix-8.4.3-tcl8.6.patch"; + url = "https://gitweb.gentoo.org/repo/gentoo.git/plain/dev-tcltk/tix/files/tix-8.4.3-tcl8.6.patch?id=56bd759df1d0c750a065b8c845e93d5dfa6b549d"; + sha256 = "1jaz0l22xj7x1k4rb9ia6i1psnbwk4pblgq4gfvya7gg7fbb7r36"; + }); buildInputs = [ tk ]; # the configure script expects to find the location of the sources of # tcl and tk in {tcl,tk}Config.sh @@ -43,7 +44,7 @@ tcl.mkTclDerivation { for i in ${tcl}/include/* ${tk.dev}/include/*; do ln -s $i private_headers/generic; done; - ''; + ''; addTclConfigureFlags = false; configureFlags = [ "--with-tclconfig=." @@ -54,9 +55,9 @@ tcl.mkTclDerivation { meta = with lib; { description = "Widget library for Tcl/Tk"; - homepage = "https://tix.sourceforge.net/"; - platforms = platforms.all; - license = with licenses; [ + homepage = "https://tix.sourceforge.net/"; + platforms = platforms.all; + license = with licenses; [ bsd2 # tix gpl2 # patches from portage ]; diff --git a/pkgs/development/tcl-modules/by-name/tk/tkimg/package.nix b/pkgs/development/tcl-modules/by-name/tk/tkimg/package.nix index f058585d3ad952..ad737f13a3551b 100644 --- a/pkgs/development/tcl-modules/by-name/tk/tkimg/package.nix +++ b/pkgs/development/tcl-modules/by-name/tk/tkimg/package.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchsvn, tcl, tcllib, tk, xorg, darwin }: +{ + stdenv, + lib, + fetchsvn, + tcl, + tcllib, + tk, + xorg, + darwin, +}: tcl.mkTclDerivation rec { pname = "tkimg"; @@ -16,9 +25,17 @@ tcl.mkTclDerivation rec { "--with-tkinclude=${tk.dev}/include" ]; - buildInputs = [ xorg.libX11 tcllib ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - Cocoa - ]); + buildInputs = + [ + xorg.libX11 + tcllib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + Cocoa + ] + ); meta = { homepage = "https://sourceforge.net/projects/tkimg/"; diff --git a/pkgs/development/tcl-modules/critcl/default.nix b/pkgs/development/tcl-modules/critcl/default.nix index a1d69dbe246ce2..045b9a28958c5f 100644 --- a/pkgs/development/tcl-modules/critcl/default.nix +++ b/pkgs/development/tcl-modules/critcl/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, mkTclDerivation -, tcl -, tcllib +{ + lib, + fetchFromGitHub, + mkTclDerivation, + tcl, + tcllib, }: mkTclDerivation rec { diff --git a/pkgs/development/tools/alloy/default.nix b/pkgs/development/tools/alloy/default.nix index 37b2fd6a76c876..806ce6f7faca6a 100644 --- a/pkgs/development/tools/alloy/default.nix +++ b/pkgs/development/tools/alloy/default.nix @@ -1,60 +1,74 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper, makeDesktopItem }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, + makeDesktopItem, +}: -let generic = { version, sha256 }: - stdenv.mkDerivation rec { - pname = "alloy${lib.versions.major version}"; - inherit version; +let + generic = + { version, sha256 }: + stdenv.mkDerivation rec { + pname = "alloy${lib.versions.major version}"; + inherit version; - src = fetchurl { - inherit sha256; - url = "https://github.com/AlloyTools/org.alloytools.alloy/releases/download/v${version}/org.alloytools.alloy.dist.jar"; - }; - - desktopItem = makeDesktopItem rec { - name = pname; - exec = name; - icon = name; - desktopName = "Alloy ${lib.versions.major version}"; - genericName = "Relational modelling tool"; - comment = meta.description; - categories = [ "Development" "IDE" "Education" ]; - }; + src = fetchurl { + inherit sha256; + url = "https://github.com/AlloyTools/org.alloytools.alloy/releases/download/v${version}/org.alloytools.alloy.dist.jar"; + }; - nativeBuildInputs = [ makeWrapper ]; + desktopItem = makeDesktopItem rec { + name = pname; + exec = name; + icon = name; + desktopName = "Alloy ${lib.versions.major version}"; + genericName = "Relational modelling tool"; + comment = meta.description; + categories = [ + "Development" + "IDE" + "Education" + ]; + }; - buildCommand = '' - jar=$out/share/alloy/${pname}.jar - install -Dm644 ${src} $jar + nativeBuildInputs = [ makeWrapper ]; - mkdir -p $out/bin - makeWrapper ${jre}/bin/java $out/bin/${pname} --add-flags \ - "-jar $jar" + buildCommand = '' + jar=$out/share/alloy/${pname}.jar + install -Dm644 ${src} $jar - install -Dm644 ${./icon.png} $out/share/pixmaps/${pname}.png - cp -r ${desktopItem}/share/applications $out/share - ''; + mkdir -p $out/bin + makeWrapper ${jre}/bin/java $out/bin/${pname} --add-flags \ + "-jar $jar" - meta = with lib; { - description = "Language & tool for relational models"; - longDescription = '' - Alloy is a language for describing structures and a tool for exploring - them. An Alloy model is a collection of constraints that describes a set - of structures, e.g. all the possible security configurations of a web - application, or all the possible topologies of a switching network. The - Alloy Analyzer is a solver that takes the constraints of a model and - finds structures that satisfy them. Structures are displayed graphically, - and their appearance can be customized for the domain at hand. + install -Dm644 ${./icon.png} $out/share/pixmaps/${pname}.png + cp -r ${desktopItem}/share/applications $out/share ''; - homepage = "http://alloytools.org/"; - downloadPage = "http://alloytools.org/download.html"; - sourceProvenance = with sourceTypes; [ binaryBytecode ]; - license = licenses.mit; - platforms = platforms.unix; - maintainers = with maintainers; [ notbandali ]; + + meta = with lib; { + description = "Language & tool for relational models"; + longDescription = '' + Alloy is a language for describing structures and a tool for exploring + them. An Alloy model is a collection of constraints that describes a set + of structures, e.g. all the possible security configurations of a web + application, or all the possible topologies of a switching network. The + Alloy Analyzer is a solver that takes the constraints of a model and + finds structures that satisfy them. Structures are displayed graphically, + and their appearance can be customized for the domain at hand. + ''; + homepage = "http://alloytools.org/"; + downloadPage = "http://alloytools.org/download.html"; + sourceProvenance = with sourceTypes; [ binaryBytecode ]; + license = licenses.mit; + platforms = platforms.unix; + maintainers = with maintainers; [ notbandali ]; + }; }; - }; -in rec { +in +rec { alloy5 = generic rec { version = "5.1.0"; sha256 = "02k9khs4k5nc86x9pp5k3vcb0kiwdgcin46mlap4fycnr673xd53"; diff --git a/pkgs/development/tools/amazon-qldb-shell/default.nix b/pkgs/development/tools/amazon-qldb-shell/default.nix index 308552b99e2bfd..6cd0c01ad20ac9 100644 --- a/pkgs/development/tools/amazon-qldb-shell/default.nix +++ b/pkgs/development/tools/amazon-qldb-shell/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, lib -, cmake -, fetchFromGitHub -, rustPlatform -, testers -, Security +{ + stdenv, + lib, + cmake, + fetchFromGitHub, + rustPlatform, + testers, + Security, }: let @@ -20,7 +21,10 @@ let sha256 = "sha256-aXScqJ1LijMSAy9YkS5QyXtTqxd19lLt3BbyVXlbw8o="; }; - nativeBuildInputs = [ cmake rustPlatform.bindgenHook ]; + nativeBuildInputs = [ + cmake + rustPlatform.bindgenHook + ]; buildInputs = lib.optional stdenv.hostPlatform.isDarwin Security; cargoLock = { diff --git a/pkgs/development/tools/ammonite/default.nix b/pkgs/development/tools/ammonite/default.nix index e0382a5e83d07f..d2fd413d43099d 100644 --- a/pkgs/development/tools/ammonite/default.nix +++ b/pkgs/development/tools/ammonite/default.nix @@ -1,29 +1,43 @@ -{ lib, stdenv, fetchurl, jre, writeScript, common-updater-scripts, git, nixfmt-classic -, nix, coreutils, gnused, disableRemoteLogging ? true }: +{ + lib, + stdenv, + fetchurl, + jre, + writeScript, + common-updater-scripts, + git, + nixfmt-classic, + nix, + coreutils, + gnused, + disableRemoteLogging ? true, +}: let repo = "git@github.com:lihaoyi/Ammonite.git"; - common = { scalaVersion, sha256 }: + common = + { scalaVersion, sha256 }: stdenv.mkDerivation rec { pname = "ammonite"; version = "3.0.0-M1"; src = fetchurl { - url = - "https://github.com/lihaoyi/Ammonite/releases/download/${version}/${scalaVersion}-${version}"; + url = "https://github.com/lihaoyi/Ammonite/releases/download/${version}/${scalaVersion}-${version}"; inherit sha256; }; dontUnpack = true; - installPhase = '' - install -Dm755 $src $out/bin/amm - sed -i '0,/java/{s|java|${jre}/bin/java|}' $out/bin/amm - '' + lib.optionalString (disableRemoteLogging) '' - sed -i "0,/ammonite.Main/{s|ammonite.Main'|ammonite.Main' --no-remote-logging|}" $out/bin/amm - sed -i '1i #!/bin/sh' $out/bin/amm - ''; + installPhase = + '' + install -Dm755 $src $out/bin/amm + sed -i '0,/java/{s|java|${jre}/bin/java|}' $out/bin/amm + '' + + lib.optionalString (disableRemoteLogging) '' + sed -i "0,/ammonite.Main/{s|ammonite.Main'|ammonite.Main' --no-remote-logging|}" $out/bin/amm + sed -i '1i #!/bin/sh' $out/bin/amm + ''; passthru = { @@ -79,7 +93,8 @@ let platforms = platforms.all; }; }; -in { +in +{ ammonite_2_12 = common { scalaVersion = "2.12"; sha256 = "sha256-SlweOVHudknbInM4rfEPJ9bLd3Z/EImLhVLzeKfjfMQ="; diff --git a/pkgs/development/tools/analysis/binlore/default.nix b/pkgs/development/tools/analysis/binlore/default.nix index 53a024766576be..5033a73c515eb7 100644 --- a/pkgs/development/tools/analysis/binlore/default.nix +++ b/pkgs/development/tools/analysis/binlore/default.nix @@ -1,29 +1,30 @@ -{ lib -, fetchFromGitHub -, runCommand -, yallback -, yara +{ + lib, + fetchFromGitHub, + runCommand, + yallback, + yara, }: -/* TODO/CAUTION: +/* + TODO/CAUTION: -I don't want to discourage use, but I'm not sure how stable -the API is. Have fun, but be prepared to track changes! :) + I don't want to discourage use, but I'm not sure how stable + the API is. Have fun, but be prepared to track changes! :) -For _now_, binlore is basically a thin wrapper around -` | ` with support -for running it on a derivation, saving the result in the -store, and aggregating results from a set of packages. + For _now_, binlore is basically a thin wrapper around + ` | ` with support + for running it on a derivation, saving the result in the + store, and aggregating results from a set of packages. -In the longer term, I suspect there are more uses for this -general pattern (i.e., run some analysis tool that produces -a deterministic output and cache the result per package...). - -I'm not sure how that'll look and if it'll be the case that -binlore automatically collects all of them, or if you'll be -configuring which "kind(s)" of lore it generates. Nailing -that down will almost certainly mean reworking the API. + In the longer term, I suspect there are more uses for this + general pattern (i.e., run some analysis tool that produces + a deterministic output and cache the result per package...). + I'm not sure how that'll look and if it'll be the case that + binlore automatically collects all of them, or if you'll be + configuring which "kind(s)" of lore it generates. Nailing + that down will almost certainly mean reworking the API. */ let @@ -34,20 +35,23 @@ let hash = "sha256-4Fs6HThfDhKRskuDJx2+hucl8crMRm10K6949JdIwPY="; }; /* - binlore has one one more yallbacks responsible for - routing the appropriate lore to a named file in the - appropriate format. At some point I might try to do - something fancy with this, but for now the answer to - *all* questions about the lore are: the bare minimum - to get resholve over the next feature hump in time to - hopefully slip this feature in before the branch-off. + binlore has one one more yallbacks responsible for + routing the appropriate lore to a named file in the + appropriate format. At some point I might try to do + something fancy with this, but for now the answer to + *all* questions about the lore are: the bare minimum + to get resholve over the next feature hump in time to + hopefully slip this feature in before the branch-off. */ # TODO: feeling really uninspired on the API loreDef = { # YARA rule file rules = (src + "/execers.yar"); # output filenames; "types" of lore - types = [ "execers" "wrappers" ]; + types = [ + "execers" + "wrappers" + ]; # shell rule callbacks; see github.com/abathur/yallback yallback = (src + "/execers.yall"); # TODO: @@ -70,7 +74,8 @@ let ''; }; -in rec { +in +rec { /* Output a directory containing lore for multiple drvs. @@ -83,13 +88,23 @@ in rec { uses a chain of two or more derivations where the output of one is the source for the next. See resholve for an example.) */ - collect = { lore ? loreDef, drvs, strip ? [ ] }: (runCommand "more-binlore" { } '' - mkdir $out - for lorefile in ${toString lore.types}; do - cat ${lib.concatMapStrings (x: x + "/$lorefile ") (map (make lore) (map lib.getBin (builtins.filter lib.isDerivation drvs)))} > $out/$lorefile - substituteInPlace $out/$lorefile ${lib.concatMapStrings (x: "--replace-quiet '${x}/' '' ") strip} - done - ''); + collect = + { + lore ? loreDef, + drvs, + strip ? [ ], + }: + (runCommand "more-binlore" { } '' + mkdir $out + for lorefile in ${toString lore.types}; do + cat ${ + lib.concatMapStrings (x: x + "/$lorefile ") ( + map (make lore) (map lib.getBin (builtins.filter lib.isDerivation drvs)) + ) + } > $out/$lorefile + substituteInPlace $out/$lorefile ${lib.concatMapStrings (x: "--replace-quiet '${x}/' '' ") strip} + done + ''); /* Output a directory containing lore for a single drv. @@ -105,29 +120,40 @@ in rec { Since the last entry wins, the effective priority is: drv.binlore. > $drv/nix-support > lore generated here by callback */ - make = lore: drv: runCommand "${drv.name}-binlore" { - drv = drv; - } ('' - mkdir $out - touch $out/{${builtins.concatStringsSep "," lore.types}} - - ${lore.callback lore drv} - '' + - # append lore from package's $out and drv.binlore.${drv.outputName} (last entry wins) - '' - for lore_type in ${builtins.toString lore.types}; do - if [[ -f "${drv}/nix-support/$lore_type" ]]; then - cat "${drv}/nix-support/$lore_type" >> "$out/$lore_type" - fi - '' + lib.optionalString (builtins.hasAttr "binlore" drv && builtins.hasAttr drv.outputName drv.binlore) '' - if [[ -f "${drv.binlore."${drv.outputName}"}/$lore_type" ]]; then - cat "${drv.binlore."${drv.outputName}"}/$lore_type" >> "$out/$lore_type" - fi - '' + '' - done - - echo binlore for $drv written to $out - ''); + make = + lore: drv: + runCommand "${drv.name}-binlore" + { + drv = drv; + } + ( + '' + mkdir $out + touch $out/{${builtins.concatStringsSep "," lore.types}} + + ${lore.callback lore drv} + '' + + + # append lore from package's $out and drv.binlore.${drv.outputName} (last entry wins) + '' + for lore_type in ${builtins.toString lore.types}; do + if [[ -f "${drv}/nix-support/$lore_type" ]]; then + cat "${drv}/nix-support/$lore_type" >> "$out/$lore_type" + fi + '' + + + lib.optionalString (builtins.hasAttr "binlore" drv && builtins.hasAttr drv.outputName drv.binlore) + '' + if [[ -f "${drv.binlore."${drv.outputName}"}/$lore_type" ]]; then + cat "${drv.binlore."${drv.outputName}"}/$lore_type" >> "$out/$lore_type" + fi + '' + + '' + done + + echo binlore for $drv written to $out + '' + ); /* Utility function for creating override lore for drv. @@ -179,46 +205,53 @@ in rec { glob can match new executables added in future package versions before anyone can audit them. */ - synthesize = drv: loreSynthesizingScript: runCommand "${drv.name}-lore-override" { - drv = drv; - } ('' - execer(){ - local verdict="$1" - - shift - - for path in "$@"; do - if [[ -f "$PWD/$path" ]]; then - echo "$verdict:$PWD/$path" - else - echo "error: Tried to synthesize execer lore for missing file: $PWD/$path" >&2 - exit 2 - fi - done - } >> $out/execers - - wrapper(){ - local wrapper="$1" - local original="$2" - - if [[ ! -f "$wrapper" ]]; then - echo "error: Tried to synthesize wrapper lore for missing wrapper: $PWD/$wrapper" >&2 - exit 2 - fi - - if [[ ! -f "$original" ]]; then - echo "error: Tried to synthesize wrapper lore for missing original: $PWD/$original" >&2 - exit 2 - fi - - echo "$PWD/$wrapper:$PWD/$original" - - } >> $out/wrappers - - mkdir $out - - # lore override commands are relative to the drv root - cd $drv - - '' + loreSynthesizingScript); + synthesize = + drv: loreSynthesizingScript: + runCommand "${drv.name}-lore-override" + { + drv = drv; + } + ( + '' + execer(){ + local verdict="$1" + + shift + + for path in "$@"; do + if [[ -f "$PWD/$path" ]]; then + echo "$verdict:$PWD/$path" + else + echo "error: Tried to synthesize execer lore for missing file: $PWD/$path" >&2 + exit 2 + fi + done + } >> $out/execers + + wrapper(){ + local wrapper="$1" + local original="$2" + + if [[ ! -f "$wrapper" ]]; then + echo "error: Tried to synthesize wrapper lore for missing wrapper: $PWD/$wrapper" >&2 + exit 2 + fi + + if [[ ! -f "$original" ]]; then + echo "error: Tried to synthesize wrapper lore for missing original: $PWD/$original" >&2 + exit 2 + fi + + echo "$PWD/$wrapper:$PWD/$original" + + } >> $out/wrappers + + mkdir $out + + # lore override commands are relative to the drv root + cd $drv + + '' + + loreSynthesizingScript + ); } diff --git a/pkgs/development/tools/analysis/brakeman/default.nix b/pkgs/development/tools/analysis/brakeman/default.nix index 0380524b240146..98e3c3a28faeba 100644 --- a/pkgs/development/tools/analysis/brakeman/default.nix +++ b/pkgs/development/tools/analysis/brakeman/default.nix @@ -1,4 +1,9 @@ -{ lib, ruby, bundlerApp, bundlerUpdateScript }: +{ + lib, + ruby, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp rec { pname = "brakeman"; diff --git a/pkgs/development/tools/analysis/brakeman/gemset.nix b/pkgs/development/tools/analysis/brakeman/gemset.nix index d7d2908f742705..b77d22a540271f 100644 --- a/pkgs/development/tools/analysis/brakeman/gemset.nix +++ b/pkgs/development/tools/analysis/brakeman/gemset.nix @@ -1,20 +1,20 @@ { brakeman = { - dependencies = ["racc"]; - groups = ["default"]; - platforms = []; + dependencies = [ "racc" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1lylig4vgnw9l1ybwgxdi9nw9q2bc5dcplklg8nsbi7j32f7c5kp"; type = "gem"; }; version = "6.1.2"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01b9662zd2x9bp4rdjfid07h09zxj7kvn7f5fghbqhzc625ap1dp"; type = "gem"; }; diff --git a/pkgs/development/tools/analysis/cargo-tarpaulin/default.nix b/pkgs/development/tools/analysis/cargo-tarpaulin/default.nix index a68328655e3517..3f971b8d59d0f3 100644 --- a/pkgs/development/tools/analysis/cargo-tarpaulin/default.nix +++ b/pkgs/development/tools/analysis/cargo-tarpaulin/default.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, curl -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + curl, + Security, }: rustPlatform.buildRustPackage rec { @@ -24,8 +25,12 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ curl Security ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + curl + Security + ]; doCheck = false; @@ -34,7 +39,13 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-tarpaulin"; homepage = "https://github.com/xd009642/tarpaulin"; changelog = "https://github.com/xd009642/tarpaulin/blob/${src.rev}/CHANGELOG.md"; - license = with licenses; [ mit /* or */ asl20 ]; - maintainers = with maintainers; [ figsoda hugoreeves ]; + license = with licenses; [ + mit # or + asl20 + ]; + maintainers = with maintainers; [ + figsoda + hugoreeves + ]; }; } diff --git a/pkgs/development/tools/analysis/clang-analyzer/default.nix b/pkgs/development/tools/analysis/clang-analyzer/default.nix index 67a38a526be2fd..84c948566debe9 100644 --- a/pkgs/development/tools/analysis/clang-analyzer/default.nix +++ b/pkgs/development/tools/analysis/clang-analyzer/default.nix @@ -1,11 +1,24 @@ -{ lib, stdenv, clang, llvmPackages, perl, makeWrapper, python3 }: +{ + lib, + stdenv, + clang, + llvmPackages, + perl, + makeWrapper, + python3, +}: stdenv.mkDerivation rec { pname = "clang-analyzer"; inherit (llvmPackages.clang-unwrapped) src version; patches = [ ./0001-Fix-scan-build-to-use-NIX_CFLAGS_COMPILE.patch ]; - buildInputs = [ clang llvmPackages.clang perl python3 ]; + buildInputs = [ + clang + llvmPackages.clang + perl + python3 + ]; nativeBuildInputs = [ makeWrapper ]; dontBuild = true; @@ -30,9 +43,9 @@ stdenv.mkDerivation rec { The Clang Static Analyzer is a source code analysis tool that finds bugs in C, C++, and Objective-C programs. ''; - homepage = "https://clang-analyzer.llvm.org/"; - license = lib.licenses.bsd3; - platforms = lib.platforms.unix; + homepage = "https://clang-analyzer.llvm.org/"; + license = lib.licenses.bsd3; + platforms = lib.platforms.unix; maintainers = [ lib.maintainers.thoughtpolice ]; }; } diff --git a/pkgs/development/tools/analysis/clazy/default.nix b/pkgs/development/tools/analysis/clazy/default.nix index 8f92ab15150b66..b1578dc3f860da 100644 --- a/pkgs/development/tools/analysis/clazy/default.nix +++ b/pkgs/development/tools/analysis/clazy/default.nix @@ -1,10 +1,10 @@ { - lib - , stdenv - , fetchFromGitHub - , llvmPackages - , cmake - , makeWrapper + lib, + stdenv, + fetchFromGitHub, + llvmPackages, + cmake, + makeWrapper, }: stdenv.mkDerivation rec { @@ -12,9 +12,9 @@ stdenv.mkDerivation rec { version = "1.12"; src = fetchFromGitHub { - owner = "KDE"; - repo = "clazy"; - rev = "v${version}"; + owner = "KDE"; + repo = "clazy"; + rev = "v${version}"; sha256 = "sha256-Fex0BAmCZUYcNJriHHt/QPi5IgSH/yhnpGCFFZMMD/g="; }; diff --git a/pkgs/development/tools/analysis/dotenv-linter/default.nix b/pkgs/development/tools/analysis/dotenv-linter/default.nix index c61f862f5178bb..aa6bf93b4e2b77 100644 --- a/pkgs/development/tools/analysis/dotenv-linter/default.nix +++ b/pkgs/development/tools/analysis/dotenv-linter/default.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, rustPlatform -, fetchFromGitHub -, Security +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + Security, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/development/tools/analysis/flow/default.nix b/pkgs/development/tools/analysis/flow/default.nix index 2bb80f22ecc4f6..50c839d12ba139 100644 --- a/pkgs/development/tools/analysis/flow/default.nix +++ b/pkgs/development/tools/analysis/flow/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, ocamlPackages, CoreServices }: +{ + lib, + stdenv, + fetchFromGitHub, + ocamlPackages, + CoreServices, +}: stdenv.mkDerivation rec { pname = "flow"; @@ -24,10 +30,33 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = with ocamlPackages; [ ocaml dune_3 findlib ocamlbuild ]; + nativeBuildInputs = with ocamlPackages; [ + ocaml + dune_3 + findlib + ocamlbuild + ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices ] - ++ (with ocamlPackages; [ core_kernel dtoa fileutils lwt_log lwt_ppx ocaml_lwt ppx_deriving ppx_gen_rec ppx_let sedlex visitors wtf8 ] ++ lib.optionals stdenv.hostPlatform.isLinux [ inotify ]); + buildInputs = + lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices ] + ++ ( + with ocamlPackages; + [ + core_kernel + dtoa + fileutils + lwt_log + lwt_ppx + ocaml_lwt + ppx_deriving + ppx_gen_rec + ppx_let + sedlex + visitors + wtf8 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ inotify ] + ); meta = with lib; { description = "Static type checker for JavaScript"; diff --git a/pkgs/development/tools/analysis/include-what-you-use/default.nix b/pkgs/development/tools/analysis/include-what-you-use/default.nix index 6e7f6d5eea1af6..dab9eb7504ab13 100644 --- a/pkgs/development/tools/analysis/include-what-you-use/default.nix +++ b/pkgs/development/tools/analysis/include-what-you-use/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, cmake, llvmPackages, python3 }: +{ + lib, + stdenv, + fetchurl, + cmake, + llvmPackages, + python3, +}: stdenv.mkDerivation rec { pname = "include-what-you-use"; @@ -14,8 +21,17 @@ stdenv.mkDerivation rec { patchShebangs . ''; - nativeBuildInputs = with llvmPackages; [ cmake llvm.dev llvm python3 ]; - buildInputs = with llvmPackages; [ libclang clang-unwrapped python3 ]; + nativeBuildInputs = with llvmPackages; [ + cmake + llvm.dev + llvm + python3 + ]; + buildInputs = with llvmPackages; [ + libclang + clang-unwrapped + python3 + ]; clang = llvmPackages.clang; diff --git a/pkgs/development/tools/analysis/jdepend/default.nix b/pkgs/development/tools/analysis/jdepend/default.nix index 1f2e9605b117e2..6ba10c6611c7f6 100644 --- a/pkgs/development/tools/analysis/jdepend/default.nix +++ b/pkgs/development/tools/analysis/jdepend/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, ant -, jdk -, makeWrapper -, stripJavaArchivesHook +{ + lib, + stdenv, + fetchFromGitHub, + ant, + jdk, + makeWrapper, + stripJavaArchivesHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/tools/analysis/massif-visualizer/default.nix b/pkgs/development/tools/analysis/massif-visualizer/default.nix index 4e969baf376391..d459bd320ac168 100644 --- a/pkgs/development/tools/analysis/massif-visualizer/default.nix +++ b/pkgs/development/tools/analysis/massif-visualizer/default.nix @@ -1,8 +1,19 @@ { - mkDerivation, lib, fetchurl, - extra-cmake-modules, shared-mime-info, - qtsvg, qtxmlpatterns, karchive, kconfig, kcoreaddons, kparts, kio, ki18n, - kdiagram, kgraphviewer + mkDerivation, + lib, + fetchurl, + extra-cmake-modules, + shared-mime-info, + qtsvg, + qtxmlpatterns, + karchive, + kconfig, + kcoreaddons, + kparts, + kio, + ki18n, + kdiagram, + kgraphviewer, }: mkDerivation rec { @@ -14,11 +25,22 @@ mkDerivation rec { sha256 = "0v8z6r9gngzckvqyxjm9kp7hilwfqibyk2f9vag9l98ar0iwr97q"; }; - nativeBuildInputs = [ extra-cmake-modules shared-mime-info ]; + nativeBuildInputs = [ + extra-cmake-modules + shared-mime-info + ]; buildInputs = [ - qtsvg qtxmlpatterns karchive kconfig kcoreaddons kparts kio ki18n - kdiagram kgraphviewer + qtsvg + qtxmlpatterns + karchive + kconfig + kcoreaddons + kparts + kio + ki18n + kdiagram + kgraphviewer ]; meta = with lib; { diff --git a/pkgs/development/tools/analysis/nix-linter/default.nix b/pkgs/development/tools/analysis/nix-linter/default.nix index 160c3b8eb83567..1dd6cfdf3de9c8 100644 --- a/pkgs/development/tools/analysis/nix-linter/default.nix +++ b/pkgs/development/tools/analysis/nix-linter/default.nix @@ -1,22 +1,23 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, fixplate -, tasty -, tasty-hunit -, tasty-th -, streamly -, mtl -, path -, pretty-terminal -, text -, base -, aeson -, path-io -, cmdargs -, containers -, hnix -, bytestring +{ + lib, + mkDerivation, + fetchFromGitHub, + fixplate, + tasty, + tasty-hunit, + tasty-th, + streamly, + mtl, + path, + pretty-terminal, + text, + base, + aeson, + path-io, + cmdargs, + containers, + hnix, + bytestring, }: mkDerivation rec { @@ -33,8 +34,25 @@ mkDerivation rec { isLibrary = false; isExecutable = true; libraryHaskellDepends = [ fixplate ]; - executableHaskellDepends = [ streamly mtl path pretty-terminal text base aeson cmdargs containers hnix bytestring path-io ]; - testHaskellDepends = [ tasty tasty-hunit tasty-th ]; + executableHaskellDepends = [ + streamly + mtl + path + pretty-terminal + text + base + aeson + cmdargs + containers + hnix + bytestring + path-io + ]; + testHaskellDepends = [ + tasty + tasty-hunit + tasty-th + ]; description = "Linter for Nix(pkgs), based on hnix"; homepage = "https://github.com/Synthetica9/nix-linter"; diff --git a/pkgs/development/tools/analysis/pmd/default.nix b/pkgs/development/tools/analysis/pmd/default.nix index d8a300fb08d83b..567699b6b3c604 100644 --- a/pkgs/development/tools/analysis/pmd/default.nix +++ b/pkgs/development/tools/analysis/pmd/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, unzip, makeWrapper, openjdk }: +{ + lib, + stdenv, + fetchurl, + unzip, + makeWrapper, + openjdk, +}: stdenv.mkDerivation rec { pname = "pmd"; @@ -9,7 +16,10 @@ stdenv.mkDerivation rec { hash = "sha256-Iaz5bUPLQNWRyszMHCCmb8eW6t32nqYYEllER7rHoR0="; }; - nativeBuildInputs = [ unzip makeWrapper ]; + nativeBuildInputs = [ + unzip + makeWrapper + ]; dontConfigure = true; dontBuild = true; @@ -36,6 +46,9 @@ stdenv.mkDerivation rec { homepage = "https://pmd.github.io/"; changelog = "https://pmd.github.io/pmd-${version}/pmd_release_notes.html"; platforms = platforms.unix; - license = with licenses; [ bsdOriginal asl20 ]; + license = with licenses; [ + bsdOriginal + asl20 + ]; }; } diff --git a/pkgs/development/tools/analysis/qcachegrind/default.nix b/pkgs/development/tools/analysis/qcachegrind/default.nix index 9c0be92e261898..352160006742a4 100644 --- a/pkgs/development/tools/analysis/qcachegrind/default.nix +++ b/pkgs/development/tools/analysis/qcachegrind/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, qmake, qtbase, perl, php, kcachegrind, wrapQtAppsHook }: +{ + lib, + stdenv, + qmake, + qtbase, + perl, + php, + kcachegrind, + wrapQtAppsHook, +}: stdenv.mkDerivation { pname = "qcachegrind"; @@ -6,29 +15,43 @@ stdenv.mkDerivation { src = kcachegrind.src; - buildInputs = [ qtbase perl php ]; + buildInputs = [ + qtbase + perl + php + ]; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; dontWrapQtApps = true; - postInstall = '' - mkdir -p $out/bin - cp -p converters/dprof2calltree $out/bin/dprof2calltree - cp -p converters/memprof2calltree $out/bin/memprof2calltree - cp -p converters/op2calltree $out/bin/op2calltree - cp -p converters/pprof2calltree $out/bin/pprof2calltree - chmod -R +x $out/bin/ - '' + (if stdenv.hostPlatform.isDarwin then '' - mkdir -p $out/Applications - cp cgview/cgview.app/Contents/MacOS/cgview $out/bin - cp -a qcachegrind/qcachegrind.app $out/Applications - '' else '' - install qcachegrind/qcachegrind cgview/cgview -t "$out/bin" - install -Dm644 qcachegrind/qcachegrind.desktop -t "$out/share/applications" - install -Dm644 kcachegrind/32-apps-kcachegrind.png "$out/share/icons/hicolor/32x32/apps/kcachegrind.png" - install -Dm644 kcachegrind/48-apps-kcachegrind.png "$out/share/icons/hicolor/48x48/apps/kcachegrind.png" - ''); + postInstall = + '' + mkdir -p $out/bin + cp -p converters/dprof2calltree $out/bin/dprof2calltree + cp -p converters/memprof2calltree $out/bin/memprof2calltree + cp -p converters/op2calltree $out/bin/op2calltree + cp -p converters/pprof2calltree $out/bin/pprof2calltree + chmod -R +x $out/bin/ + '' + + ( + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p $out/Applications + cp cgview/cgview.app/Contents/MacOS/cgview $out/bin + cp -a qcachegrind/qcachegrind.app $out/Applications + '' + else + '' + install qcachegrind/qcachegrind cgview/cgview -t "$out/bin" + install -Dm644 qcachegrind/qcachegrind.desktop -t "$out/share/applications" + install -Dm644 kcachegrind/32-apps-kcachegrind.png "$out/share/icons/hicolor/32x32/apps/kcachegrind.png" + install -Dm644 kcachegrind/48-apps-kcachegrind.png "$out/share/icons/hicolor/48x48/apps/kcachegrind.png" + '' + ); preFixup = '' wrapQtApp "$out/bin/qcachegrind" diff --git a/pkgs/development/tools/analysis/radare2/default.nix b/pkgs/development/tools/analysis/radare2/default.nix index 6bf80144a83922..65389f2845153a 100644 --- a/pkgs/development/tools/analysis/radare2/default.nix +++ b/pkgs/development/tools/analysis/radare2/default.nix @@ -1,31 +1,32 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildPackages -, pkg-config -, meson -, ninja -, libusb-compat-0_1 -, readline -, libewf -, perl -, zlib -, openssl -, libuv -, file -, libzip -, xxHash -, gtk2 -, vte -, gtkdialog -, python3 -, ruby -, lua -, lz4 -, capstone -, useX11 ? false -, rubyBindings ? false -, luaBindings ? false +{ + lib, + stdenv, + fetchFromGitHub, + buildPackages, + pkg-config, + meson, + ninja, + libusb-compat-0_1, + readline, + libewf, + perl, + zlib, + openssl, + libuv, + file, + libzip, + xxHash, + gtk2, + vte, + gtkdialog, + python3, + ruby, + lua, + lz4, + capstone, + useX11 ? false, + rubyBindings ? false, + luaBindings ? false, }: let @@ -70,13 +71,13 @@ stdenv.mkDerivation (finalAttrs: { ''; mesonFlags = [ - "-Dr2_gittap=${finalAttrs.version}" - "-Duse_sys_capstone=true" - "-Duse_sys_lz4=true" - "-Duse_sys_magic=true" - "-Duse_sys_openssl=true" - "-Duse_sys_xxhash=true" - "-Duse_sys_zip=true" + "-Dr2_gittap=${finalAttrs.version}" + "-Duse_sys_capstone=true" + "-Duse_sys_lz4=true" + "-Duse_sys_magic=true" + "-Duse_sys_openssl=true" + "-Duse_sys_xxhash=true" + "-Duse_sys_zip=true" ]; enableParallelBuilding = true; @@ -85,20 +86,31 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; - nativeBuildInputs = [ pkg-config meson ninja python3 ]; + nativeBuildInputs = [ + pkg-config + meson + ninja + python3 + ]; - buildInputs = [ - capstone - file - readline - libusb-compat-0_1 - libewf - perl - zlib - openssl - libuv - lz4 - ] ++ lib.optionals useX11 [ gtkdialog vte gtk2 ] + buildInputs = + [ + capstone + file + readline + libusb-compat-0_1 + libewf + perl + zlib + openssl + libuv + lz4 + ] + ++ lib.optionals useX11 [ + gtkdialog + vte + gtk2 + ] ++ lib.optionals rubyBindings [ ruby ] ++ lib.optionals luaBindings [ lua ]; @@ -128,8 +140,17 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://radare.org"; changelog = "https://github.com/radareorg/radare2/releases/tag/${finalAttrs.version}"; - license = with licenses; [ gpl3Only lgpl3Only ]; - maintainers = with maintainers; [ azahi raskin makefu mic92 arkivm ]; + license = with licenses; [ + gpl3Only + lgpl3Only + ]; + maintainers = with maintainers; [ + azahi + raskin + makefu + mic92 + arkivm + ]; mainProgram = "radare2"; platforms = platforms.unix; }; diff --git a/pkgs/development/tools/analysis/rizin/cutter.nix b/pkgs/development/tools/analysis/rizin/cutter.nix index 1fa12c6eef528c..213894fa62e36a 100644 --- a/pkgs/development/tools/analysis/rizin/cutter.nix +++ b/pkgs/development/tools/analysis/rizin/cutter.nix @@ -1,102 +1,113 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, stdenv -# for passthru.plugins -, pkgs -# nativeBuildInputs -, cmake -, pkg-config -, wrapQtAppsHook -# Qt -, qt5compat -, qtbase -, qtwayland -, qtsvg -, qttools -, qtwebengine -# buildInputs -, graphviz -, python3 -, rizin +{ + lib, + fetchFromGitHub, + fetchpatch, + stdenv, + # for passthru.plugins + pkgs, + # nativeBuildInputs + cmake, + pkg-config, + wrapQtAppsHook, + # Qt + qt5compat, + qtbase, + qtwayland, + qtsvg, + qttools, + qtwebengine, + # buildInputs + graphviz, + python3, + rizin, }: -let cutter = stdenv.mkDerivation rec { - pname = "cutter"; - version = "2.3.4"; +let + cutter = stdenv.mkDerivation rec { + pname = "cutter"; + version = "2.3.4"; - src = fetchFromGitHub { - owner = "rizinorg"; - repo = "cutter"; - rev = "v${version}"; - hash = "sha256-TSEi1mXVvvaGo4koo3EnN/veXPUHF747g+gifnl4IDQ="; - fetchSubmodules = true; - }; + src = fetchFromGitHub { + owner = "rizinorg"; + repo = "cutter"; + rev = "v${version}"; + hash = "sha256-TSEi1mXVvvaGo4koo3EnN/veXPUHF747g+gifnl4IDQ="; + fetchSubmodules = true; + }; - patches = [ - # https://github.com/rizinorg/cutter/issues/3384 - (fetchpatch { - url = "https://gitlab.archlinux.org/archlinux/packaging/packages/rz-cutter/-/raw/f736a5709c0b4711760f8242fa77eeaf178c0302/pyside-6.8.patch"; - hash = "sha256-k1Bn6tCNkbE9r5QLfJTBg1zZZU9R7fG1tyfPgSJyQgg="; - }) - ]; + patches = [ + # https://github.com/rizinorg/cutter/issues/3384 + (fetchpatch { + url = "https://gitlab.archlinux.org/archlinux/packaging/packages/rz-cutter/-/raw/f736a5709c0b4711760f8242fa77eeaf178c0302/pyside-6.8.patch"; + hash = "sha256-k1Bn6tCNkbE9r5QLfJTBg1zZZU9R7fG1tyfPgSJyQgg="; + }) + ]; - nativeBuildInputs = [ - cmake - pkg-config - python3 - wrapQtAppsHook - ]; + nativeBuildInputs = [ + cmake + pkg-config + python3 + wrapQtAppsHook + ]; - propagatedBuildInputs = [ - python3.pkgs.pyside6 - ]; + propagatedBuildInputs = [ + python3.pkgs.pyside6 + ]; - buildInputs = [ - graphviz - python3 - qt5compat - qtbase - qtsvg - qttools - qtwebengine - rizin - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qtwayland - ]; + buildInputs = + [ + graphviz + python3 + qt5compat + qtbase + qtsvg + qttools + qtwebengine + rizin + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qtwayland + ]; - cmakeFlags = [ - "-DCUTTER_USE_BUNDLED_RIZIN=OFF" - "-DCUTTER_ENABLE_PYTHON=ON" - "-DCUTTER_ENABLE_PYTHON_BINDINGS=ON" - "-DCUTTER_ENABLE_GRAPHVIZ=ON" - "-DCUTTER_QT6=ON" - ]; + cmakeFlags = [ + "-DCUTTER_USE_BUNDLED_RIZIN=OFF" + "-DCUTTER_ENABLE_PYTHON=ON" + "-DCUTTER_ENABLE_PYTHON_BINDINGS=ON" + "-DCUTTER_ENABLE_GRAPHVIZ=ON" + "-DCUTTER_QT6=ON" + ]; - preBuild = '' - qtWrapperArgs+=(--prefix PYTHONPATH : "$PYTHONPATH") - ''; + preBuild = '' + qtWrapperArgs+=(--prefix PYTHONPATH : "$PYTHONPATH") + ''; - passthru = rec { - plugins = rizin.plugins // { - rz-ghidra = rizin.plugins.rz-ghidra.override { - inherit cutter qtbase qtsvg; - enableCutterPlugin = true; + passthru = rec { + plugins = rizin.plugins // { + rz-ghidra = rizin.plugins.rz-ghidra.override { + inherit cutter qtbase qtsvg; + enableCutterPlugin = true; + }; }; + withPlugins = + filter: + pkgs.callPackage ./wrapper.nix { + inherit rizin cutter; + isCutter = true; + plugins = filter plugins; + }; }; - withPlugins = filter: pkgs.callPackage ./wrapper.nix { - inherit rizin cutter; - isCutter = true; - plugins = filter plugins; - }; - }; - meta = with lib; { - description = "Free and Open Source Reverse Engineering Platform powered by rizin"; - homepage = src.meta.homepage; - license = licenses.gpl3; - mainProgram = "cutter"; - maintainers = with maintainers; [ mic92 dtzWill ]; - inherit (rizin.meta) platforms; + meta = with lib; { + description = "Free and Open Source Reverse Engineering Platform powered by rizin"; + homepage = src.meta.homepage; + license = licenses.gpl3; + mainProgram = "cutter"; + maintainers = with maintainers; [ + mic92 + dtzWill + ]; + inherit (rizin.meta) platforms; + }; }; -}; in cutter +in +cutter diff --git a/pkgs/development/tools/analysis/rizin/default.nix b/pkgs/development/tools/analysis/rizin/default.nix index 893242aa4f5a42..32e140d83f9c56 100644 --- a/pkgs/development/tools/analysis/rizin/default.nix +++ b/pkgs/development/tools/analysis/rizin/default.nix @@ -1,147 +1,160 @@ -{ lib -, pkgs # for passthru.plugins -, stdenv -, fetchurl -, pkg-config -, libusb-compat-0_1 -, readline -, libewf -, perl -, pcre2 -, zlib -, openssl -, file -, libmspack -, libzip -, lz4 -, xxHash -, xz -, meson -, python3 -, cmake -, ninja -, capstone -, tree-sitter -, zstd +{ + lib, + pkgs, # for passthru.plugins + stdenv, + fetchurl, + pkg-config, + libusb-compat-0_1, + readline, + libewf, + perl, + pcre2, + zlib, + openssl, + file, + libmspack, + libzip, + lz4, + xxHash, + xz, + meson, + python3, + cmake, + ninja, + capstone, + tree-sitter, + zstd, }: -let rizin = stdenv.mkDerivation rec { - pname = "rizin"; - version = "0.7.3"; +let + rizin = stdenv.mkDerivation rec { + pname = "rizin"; + version = "0.7.3"; - src = fetchurl { - url = "https://github.com/rizinorg/rizin/releases/download/v${version}/rizin-src-v${version}.tar.xz"; - hash = "sha256-4O0lraa+QgmNONqczvS++9VJ5HfoD43/pcobj/n72nQ="; - }; - - mesonFlags = [ - "-Duse_sys_capstone=enabled" - "-Duse_sys_magic=enabled" - "-Duse_sys_libzip=enabled" - "-Duse_sys_zlib=enabled" - "-Duse_sys_lz4=enabled" - "-Duse_sys_libzstd=enabled" - "-Duse_sys_lzma=enabled" - "-Duse_sys_xxhash=enabled" - "-Duse_sys_openssl=enabled" - "-Duse_sys_libmspack=enabled" - "-Duse_sys_tree_sitter=enabled" - "-Duse_sys_pcre2=enabled" - # this is needed for wrapping (adding plugins) to work - "-Dportable=true" - ]; + src = fetchurl { + url = "https://github.com/rizinorg/rizin/releases/download/v${version}/rizin-src-v${version}.tar.xz"; + hash = "sha256-4O0lraa+QgmNONqczvS++9VJ5HfoD43/pcobj/n72nQ="; + }; - patches = [ - # Normally, Rizin only looks for files in the install prefix. With - # portable=true, it instead looks for files in relation to the parent - # of the directory of the binary file specified in /proc/self/exe, - # caching it. This patch replaces the entire logic to only look at - # the env var NIX_RZ_PREFIX - ./librz-wrapper-support.patch + mesonFlags = [ + "-Duse_sys_capstone=enabled" + "-Duse_sys_magic=enabled" + "-Duse_sys_libzip=enabled" + "-Duse_sys_zlib=enabled" + "-Duse_sys_lz4=enabled" + "-Duse_sys_libzstd=enabled" + "-Duse_sys_lzma=enabled" + "-Duse_sys_xxhash=enabled" + "-Duse_sys_openssl=enabled" + "-Duse_sys_libmspack=enabled" + "-Duse_sys_tree_sitter=enabled" + "-Duse_sys_pcre2=enabled" + # this is needed for wrapping (adding plugins) to work + "-Dportable=true" + ]; - ./0001-fix-compilation-with-clang.patch - # Can be dropped when upstream fixes this: https://github.com/NixOS/nixpkgs/issues/300056 - ./0002-disable-pcre2-jit.patch - ]; + patches = [ + # Normally, Rizin only looks for files in the install prefix. With + # portable=true, it instead looks for files in relation to the parent + # of the directory of the binary file specified in /proc/self/exe, + # caching it. This patch replaces the entire logic to only look at + # the env var NIX_RZ_PREFIX + ./librz-wrapper-support.patch + ./0001-fix-compilation-with-clang.patch + # Can be dropped when upstream fixes this: https://github.com/NixOS/nixpkgs/issues/300056 + ./0002-disable-pcre2-jit.patch + ]; - nativeBuildInputs = [ - pkg-config - meson - (python3.withPackages (pp: with pp; [ - pyyaml - ])) - ninja - cmake - ]; + nativeBuildInputs = [ + pkg-config + meson + (python3.withPackages ( + pp: with pp; [ + pyyaml + ] + )) + ninja + cmake + ]; - # meson's find_library seems to not use our compiler wrapper if static parameter - # is either true/false... We work around by also providing LIBRARY_PATH - preConfigure = '' - LIBRARY_PATH="" - for b in ${toString (map lib.getLib buildInputs)}; do - if [[ -d "$b/lib" ]]; then - LIBRARY_PATH="$b/lib''${LIBRARY_PATH:+:}$LIBRARY_PATH" - fi - done - export LIBRARY_PATH - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace binrz/rizin/macos_sign.sh \ - --replace 'codesign' '# codesign' - ''; + # meson's find_library seems to not use our compiler wrapper if static parameter + # is either true/false... We work around by also providing LIBRARY_PATH + preConfigure = + '' + LIBRARY_PATH="" + for b in ${toString (map lib.getLib buildInputs)}; do + if [[ -d "$b/lib" ]]; then + LIBRARY_PATH="$b/lib''${LIBRARY_PATH:+:}$LIBRARY_PATH" + fi + done + export LIBRARY_PATH + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace binrz/rizin/macos_sign.sh \ + --replace 'codesign' '# codesign' + ''; - buildInputs = [ - file - libzip - capstone - readline - libusb-compat-0_1 - libewf - pcre2 - perl - zlib - lz4 - openssl - libmspack - tree-sitter - xxHash - xz - zstd - ]; + buildInputs = [ + file + libzip + capstone + readline + libusb-compat-0_1 + libewf + pcre2 + perl + zlib + lz4 + openssl + libmspack + tree-sitter + xxHash + xz + zstd + ]; - postPatch = '' - # find_installation without arguments uses Meson’s Python interpreter, - # which does not have any extra modules. - # https://github.com/mesonbuild/meson/pull/9904 - substituteInPlace meson.build \ - --replace "import('python').find_installation()" "find_program('python3')" - ''; + postPatch = '' + # find_installation without arguments uses Meson’s Python interpreter, + # which does not have any extra modules. + # https://github.com/mesonbuild/meson/pull/9904 + substituteInPlace meson.build \ + --replace "import('python').find_installation()" "find_program('python3')" + ''; - passthru = rec { - plugins = { - jsdec = pkgs.callPackage ./jsdec.nix { - inherit rizin openssl; - }; - rz-ghidra = pkgs.qt6.callPackage ./rz-ghidra.nix { - inherit rizin openssl; - enableCutterPlugin = false; + passthru = rec { + plugins = { + jsdec = pkgs.callPackage ./jsdec.nix { + inherit rizin openssl; + }; + rz-ghidra = pkgs.qt6.callPackage ./rz-ghidra.nix { + inherit rizin openssl; + enableCutterPlugin = false; + }; + # sigdb isn't a real plugin, but it's separated from the main rizin + # derivation so that only those who need it will download it + sigdb = pkgs.callPackage ./sigdb.nix { }; }; - # sigdb isn't a real plugin, but it's separated from the main rizin - # derivation so that only those who need it will download it - sigdb = pkgs.callPackage ./sigdb.nix { }; + withPlugins = + filter: + pkgs.callPackage ./wrapper.nix { + inherit rizin; + plugins = filter plugins; + }; }; - withPlugins = filter: pkgs.callPackage ./wrapper.nix { - inherit rizin; - plugins = filter plugins; - }; - }; - meta = { - description = "UNIX-like reverse engineering framework and command-line toolset"; - homepage = "https://rizin.re/"; - license = lib.licenses.gpl3Plus; - mainProgram = "rizin"; - maintainers = with lib.maintainers; [ raskin makefu mic92 ]; - platforms = with lib.platforms; unix; + meta = { + description = "UNIX-like reverse engineering framework and command-line toolset"; + homepage = "https://rizin.re/"; + license = lib.licenses.gpl3Plus; + mainProgram = "rizin"; + maintainers = with lib.maintainers; [ + raskin + makefu + mic92 + ]; + platforms = with lib.platforms; unix; + }; }; -}; in rizin +in +rizin diff --git a/pkgs/development/tools/analysis/rizin/jsdec.nix b/pkgs/development/tools/analysis/rizin/jsdec.nix index a1c0bc7ed67fb4..ba63e8f0209e5a 100644 --- a/pkgs/development/tools/analysis/rizin/jsdec.nix +++ b/pkgs/development/tools/analysis/rizin/jsdec.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, pkg-config -, ninja -, rizin -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + meson, + pkg-config, + ninja, + rizin, + openssl, }: let @@ -35,14 +36,25 @@ stdenv.mkDerivation (finalAttrs: { cp subprojects/packagefiles/libquickjs/* subprojects/libquickjs ''; - nativeBuildInputs = [ meson ninja pkg-config ]; - buildInputs = [ openssl rizin ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + ]; + buildInputs = [ + openssl + rizin + ]; meta = with lib; { description = "Simple decompiler for Rizin"; homepage = finalAttrs.src.meta.homepage; changelog = "${finalAttrs.src.meta.homepage}/releases/tag/${finalAttrs.src.rev}"; - license = with licenses; [ asl20 bsd3 mit ]; + license = with licenses; [ + asl20 + bsd3 + mit + ]; maintainers = with maintainers; [ chayleaf ]; }; }) diff --git a/pkgs/development/tools/analysis/rizin/rz-ghidra.nix b/pkgs/development/tools/analysis/rizin/rz-ghidra.nix index d9ef68b8620e27..db0a053879b3a3 100644 --- a/pkgs/development/tools/analysis/rizin/rz-ghidra.nix +++ b/pkgs/development/tools/analysis/rizin/rz-ghidra.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -# buildInputs -, rizin -, openssl -, pugixml -# optional buildInputs -, enableCutterPlugin ? true -, cutter -, qt5compat -, qtbase -, qtsvg +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + # buildInputs + rizin, + openssl, + pugixml, + # optional buildInputs + enableCutterPlugin ? true, + cutter, + qt5compat, + qtbase, + qtsvg, }: stdenv.mkDerivation (finalAttrs: { @@ -27,25 +28,29 @@ stdenv.mkDerivation (finalAttrs: { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ - openssl - pugixml - rizin - ] ++ lib.optionals enableCutterPlugin [ - cutter - qt5compat - qtbase - qtsvg - ]; + buildInputs = + [ + openssl + pugixml + rizin + ] + ++ lib.optionals enableCutterPlugin [ + cutter + qt5compat + qtbase + qtsvg + ]; dontWrapQtApps = true; - cmakeFlags = [ - "-DUSE_SYSTEM_PUGIXML=ON" - ] ++ lib.optionals enableCutterPlugin [ - "-DBUILD_CUTTER_PLUGIN=ON" - "-DCUTTER_INSTALL_PLUGDIR=share/rizin/cutter/plugins/native" - ]; + cmakeFlags = + [ + "-DUSE_SYSTEM_PUGIXML=ON" + ] + ++ lib.optionals enableCutterPlugin [ + "-DBUILD_CUTTER_PLUGIN=ON" + "-DCUTTER_INSTALL_PLUGDIR=share/rizin/cutter/plugins/native" + ]; meta = with lib; { # errors out with undefined symbols from Cutter diff --git a/pkgs/development/tools/analysis/rizin/sigdb.nix b/pkgs/development/tools/analysis/rizin/sigdb.nix index 40d0fe62f259e4..3aa1c91f33a187 100644 --- a/pkgs/development/tools/analysis/rizin/sigdb.nix +++ b/pkgs/development/tools/analysis/rizin/sigdb.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, stdenvNoCC +{ + lib, + fetchFromGitHub, + stdenvNoCC, }: stdenvNoCC.mkDerivation rec { diff --git a/pkgs/development/tools/analysis/rizin/wrapper.nix b/pkgs/development/tools/analysis/rizin/wrapper.nix index 92fe042856cba8..17a910cb915256 100644 --- a/pkgs/development/tools/analysis/rizin/wrapper.nix +++ b/pkgs/development/tools/analysis/rizin/wrapper.nix @@ -1,10 +1,11 @@ -{ lib -, makeWrapper -, symlinkJoin -, plugins -, rizin -, isCutter ? false -, cutter +{ + lib, + makeWrapper, + symlinkJoin, + plugins, + rizin, + isCutter ? false, + cutter, }: let @@ -29,9 +30,7 @@ symlinkJoin { postBuild = '' rm $out/bin/* - wrapperArgs=(--set NIX_RZ_PREFIX $out${ - lib.optionalString isCutter " --prefix XDG_DATA_DIRS : $out/share" - }) + wrapperArgs=(--set NIX_RZ_PREFIX $out${lib.optionalString isCutter " --prefix XDG_DATA_DIRS : $out/share"}) for binary in $(ls ${unwrapped}/bin); do makeWrapper ${unwrapped}/bin/$binary $out/bin/$binary "''${wrapperArgs[@]}" done diff --git a/pkgs/development/tools/analysis/rr/zen_workaround.nix b/pkgs/development/tools/analysis/rr/zen_workaround.nix index 4410224e845471..e72b6dd98f659b 100644 --- a/pkgs/development/tools/analysis/rr/zen_workaround.nix +++ b/pkgs/development/tools/analysis/rr/zen_workaround.nix @@ -1,6 +1,12 @@ -{ stdenv, lib, kernel, rr }: +{ + stdenv, + lib, + kernel, + rr, +}: -/* The python script shouldn't be needed for users of this kernel module. +/* + The python script shouldn't be needed for users of this kernel module. https://github.com/rr-debugger/rr/blob/master/scripts/zen_workaround.py The module itself is called "zen_workaround" (a bit generic unfortunately). */ @@ -21,15 +27,17 @@ stdenv.mkDerivation { ''; buildFlags = [ "modules" ]; - installPhase = let - modDestDir = "$out/lib/modules/${kernel.modDirVersion}/kernel"; #TODO: longer path? - in '' - runHook preInstall - mkdir -p "${modDestDir}" - cp *.ko "${modDestDir}/" - find ${modDestDir} -name '*.ko' -exec xz -f '{}' \; - runHook postInstall - ''; + installPhase = + let + modDestDir = "$out/lib/modules/${kernel.modDirVersion}/kernel"; # TODO: longer path? + in + '' + runHook preInstall + mkdir -p "${modDestDir}" + cp *.ko "${modDestDir}/" + find ${modDestDir} -name '*.ko' -exec xz -f '{}' \; + runHook postInstall + ''; meta = with lib; { description = "Kernel module supporting the rr debugger on (some) AMD Zen-based CPUs"; diff --git a/pkgs/development/tools/analysis/snowman/default.nix b/pkgs/development/tools/analysis/snowman/default.nix index 706d3f6b8edb02..4cc3b44a37df3d 100644 --- a/pkgs/development/tools/analysis/snowman/default.nix +++ b/pkgs/development/tools/analysis/snowman/default.nix @@ -1,4 +1,11 @@ -{ lib, mkDerivation, fetchFromGitHub, cmake, boost, qtbase }: +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + boost, + qtbase, +}: mkDerivation rec { pname = "snowman"; @@ -13,7 +20,10 @@ mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ boost qtbase ]; + buildInputs = [ + boost + qtbase + ]; postUnpack = '' export sourceRoot=$sourceRoot/src diff --git a/pkgs/development/tools/analysis/sparse/default.nix b/pkgs/development/tools/analysis/sparse/default.nix index 497d571cf14c39..e81a6c8356f9a3 100644 --- a/pkgs/development/tools/analysis/sparse/default.nix +++ b/pkgs/development/tools/analysis/sparse/default.nix @@ -1,8 +1,20 @@ -{ callPackage, fetchurl, lib, stdenv, gtk3, pkg-config, libxml2, llvm, perl, sqlite }: +{ + callPackage, + fetchurl, + lib, + stdenv, + gtk3, + pkg-config, + libxml2, + llvm, + perl, + sqlite, +}: let GCC_BASE = "${stdenv.cc.cc}/lib/gcc/${stdenv.hostPlatform.uname.processor}-unknown-linux-gnu/${stdenv.cc.cc.version}"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "sparse"; version = "0.6.4"; @@ -18,7 +30,13 @@ in stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk3 libxml2 llvm perl sqlite ]; + buildInputs = [ + gtk3 + libxml2 + llvm + perl + sqlite + ]; doCheck = true; buildFlags = [ "GCC_BASE:=${GCC_BASE}" ]; @@ -36,9 +54,12 @@ in stdenv.mkDerivation rec { meta = with lib; { description = "Semantic parser for C"; - homepage = "https://git.kernel.org/pub/scm/devel/sparse/sparse.git/"; - license = licenses.mit; - platforms = platforms.linux; - maintainers = with maintainers; [ thoughtpolice jkarlson ]; + homepage = "https://git.kernel.org/pub/scm/devel/sparse/sparse.git/"; + license = licenses.mit; + platforms = platforms.linux; + maintainers = with maintainers; [ + thoughtpolice + jkarlson + ]; }; } diff --git a/pkgs/development/tools/analysis/sparse/tests.nix b/pkgs/development/tools/analysis/sparse/tests.nix index 5eba254e537a84..2c87ed7f4ac730 100644 --- a/pkgs/development/tools/analysis/sparse/tests.nix +++ b/pkgs/development/tools/analysis/sparse/tests.nix @@ -1,4 +1,9 @@ -{ runCommand, gcc, sparse, writeText }: +{ + runCommand, + gcc, + sparse, + writeText, +}: let src = writeText "CODE.c" '' #include @@ -10,15 +15,22 @@ let } ''; in - runCommand "${sparse.pname}-tests" { buildInputs = [ gcc sparse ]; meta.timeout = 3; } -'' - set -eu - ${sparse}/bin/cgcc ${src} > output 2>&1 || ret=$? - if [[ -z $( output 2>&1 || ret=$? + if [[ -z $(/i #include " src/main/cpp/blaze_util_darwin.cc + + # clang installed from Xcode has a compatibility wrapper that forwards + # invocations of gcc to clang, but vanilla clang doesn't + sed -i -e 's;_find_generic(repository_ctx, "gcc", "CC", overriden_tools);_find_generic(repository_ctx, "clang", "CC", overriden_tools);g' tools/cpp/unix_cc_configure.bzl + sed -i -e 's;env -i codesign --identifier $@ --force --sign;env -i CODESIGN_ALLOCATE=${cctools}/bin/${cctools.targetPrefix}codesign_allocate ${sigtool}/bin/codesign --identifier $@ --force -s;g' tools/osx/BUILD + sed -i -e 's;"/usr/bin/libtool";_find_generic(repository_ctx, "libtool", "LIBTOOL", overriden_tools);g' tools/cpp/unix_cc_configure.bzl + wrappers=( tools/cpp/osx_cc_wrapper.sh tools/cpp/osx_cc_wrapper.sh.tpl ) + for wrapper in "''${wrappers[@]}"; do + sed -i -e "s,/usr/bin/gcc,${stdenv.cc}/bin/clang,g" $wrapper + sed -i -e "s,/usr/bin/install_name_tool,${cctools}/bin/install_name_tool,g" $wrapper + done + ''; + + genericPatches = '' + # Substitute j2objc and objc wrapper's python shebang to plain python path. + substituteInPlace tools/j2objc/j2objc_header_map.py --replace "$!/usr/bin/python2.7" "#!${python3.interpreter}" + substituteInPlace tools/j2objc/j2objc_wrapper.py --replace "$!/usr/bin/python2.7" "#!${python3.interpreter}" + substituteInPlace tools/objc/j2objc_dead_code_pruner.py --replace "$!/usr/bin/python2.7" "#!${python3.interpreter}" + + # md5sum is part of coreutils + sed -i 's|/sbin/md5|md5sum|g' \ + src/BUILD third_party/ijar/test/testenv.sh tools/objc/libtool.sh + + # replace initial value of pythonShebang variable in BazelPythonSemantics.java + substituteInPlace src/main/java/com/google/devtools/build/lib/bazel/rules/python/BazelPythonSemantics.java \ + --replace '"#!/usr/bin/env " + pythonExecutableName' "\"#!${python3}/bin/python\"" + + substituteInPlace src/main/java/com/google/devtools/build/lib/starlarkbuildapi/python/PyRuntimeInfoApi.java \ + --replace '"#!/usr/bin/env python3"' "\"#!${python3}/bin/python\"" + + # substituteInPlace is rather slow, so prefilter the files with grep + grep -rlZ /bin/ src/main/java/com/google/devtools | while IFS="" read -r -d "" path; do + # If you add more replacements here, you must change the grep above! + # Only files containing /bin are taken into account. + substituteInPlace "$path" \ + --replace /bin/bash ${bash}/bin/bash \ + --replace "/usr/bin/env bash" ${bash}/bin/bash \ + --replace "/usr/bin/env python" ${python3}/bin/python \ + --replace /usr/bin/env ${coreutils}/bin/env \ + --replace /bin/true ${coreutils}/bin/true done - } - - # Disable Bazel's Xcode toolchain detection which would configure compilers - # and linkers from Xcode instead of from PATH - export BAZEL_USE_CPP_ONLY_TOOLCHAIN=1 - - # Explicitly configure gcov since we don't have it on Darwin, so autodetection fails - export GCOV=${coreutils}/bin/false - - # Framework search paths aren't added by bintools hook - # https://github.com/NixOS/nixpkgs/pull/41914 - export NIX_LDFLAGS+=" -F${CoreFoundation}/Library/Frameworks -F${CoreServices}/Library/Frameworks -F${Foundation}/Library/Frameworks" - - # libcxx includes aren't added by libcxx hook - # https://github.com/NixOS/nixpkgs/pull/41589 - export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -isystem ${lib.getDev libcxx}/include/c++/v1" - # for CLang 16 compatibility in external/{absl,upb} dependencies and in execlog - export NIX_CFLAGS_COMPILE+=" -Wno-deprecated-builtins -Wno-gnu-offsetof-extensions -Wno-implicit-function-declaration" - - # don't use system installed Xcode to run clang, use Nix clang instead - sed -i -E "s;/usr/bin/xcrun (--sdk macosx )?clang;${stdenv.cc}/bin/clang $NIX_CFLAGS_COMPILE $(bazelLinkFlags) -framework CoreFoundation;g" \ - scripts/bootstrap/compile.sh \ - tools/osx/BUILD - - substituteInPlace scripts/bootstrap/compile.sh --replace ' -mmacosx-version-min=10.9' "" - - # nixpkgs's libSystem cannot use pthread headers directly, must import GCD headers instead - sed -i -e "/#include /i #include " src/main/cpp/blaze_util_darwin.cc - - # clang installed from Xcode has a compatibility wrapper that forwards - # invocations of gcc to clang, but vanilla clang doesn't - sed -i -e 's;_find_generic(repository_ctx, "gcc", "CC", overriden_tools);_find_generic(repository_ctx, "clang", "CC", overriden_tools);g' tools/cpp/unix_cc_configure.bzl - sed -i -e 's;env -i codesign --identifier $@ --force --sign;env -i CODESIGN_ALLOCATE=${cctools}/bin/${cctools.targetPrefix}codesign_allocate ${sigtool}/bin/codesign --identifier $@ --force -s;g' tools/osx/BUILD - sed -i -e 's;"/usr/bin/libtool";_find_generic(repository_ctx, "libtool", "LIBTOOL", overriden_tools);g' tools/cpp/unix_cc_configure.bzl - wrappers=( tools/cpp/osx_cc_wrapper.sh tools/cpp/osx_cc_wrapper.sh.tpl ) - for wrapper in "''${wrappers[@]}"; do - sed -i -e "s,/usr/bin/gcc,${stdenv.cc}/bin/clang,g" $wrapper - sed -i -e "s,/usr/bin/install_name_tool,${cctools}/bin/install_name_tool,g" $wrapper - done - ''; - genericPatches = '' - # Substitute j2objc and objc wrapper's python shebang to plain python path. - substituteInPlace tools/j2objc/j2objc_header_map.py --replace "$!/usr/bin/python2.7" "#!${python3.interpreter}" - substituteInPlace tools/j2objc/j2objc_wrapper.py --replace "$!/usr/bin/python2.7" "#!${python3.interpreter}" - substituteInPlace tools/objc/j2objc_dead_code_pruner.py --replace "$!/usr/bin/python2.7" "#!${python3.interpreter}" - - # md5sum is part of coreutils - sed -i 's|/sbin/md5|md5sum|g' \ - src/BUILD third_party/ijar/test/testenv.sh tools/objc/libtool.sh - - # replace initial value of pythonShebang variable in BazelPythonSemantics.java - substituteInPlace src/main/java/com/google/devtools/build/lib/bazel/rules/python/BazelPythonSemantics.java \ - --replace '"#!/usr/bin/env " + pythonExecutableName' "\"#!${python3}/bin/python\"" - - substituteInPlace src/main/java/com/google/devtools/build/lib/starlarkbuildapi/python/PyRuntimeInfoApi.java \ - --replace '"#!/usr/bin/env python3"' "\"#!${python3}/bin/python\"" - - # substituteInPlace is rather slow, so prefilter the files with grep - grep -rlZ /bin/ src/main/java/com/google/devtools | while IFS="" read -r -d "" path; do - # If you add more replacements here, you must change the grep above! - # Only files containing /bin are taken into account. - substituteInPlace "$path" \ - --replace /bin/bash ${bash}/bin/bash \ - --replace "/usr/bin/env bash" ${bash}/bin/bash \ - --replace "/usr/bin/env python" ${python3}/bin/python \ - --replace /usr/bin/env ${coreutils}/bin/env \ - --replace /bin/true ${coreutils}/bin/true - done - - grep -rlZ /bin/ tools/python | while IFS="" read -r -d "" path; do - substituteInPlace "$path" \ - --replace "/usr/bin/env python2" ${python3.interpreter} \ - --replace "/usr/bin/env python3" ${python3}/bin/python \ - --replace /usr/bin/env ${coreutils}/bin/env - done - - # bazel test runner include references to /bin/bash - substituteInPlace tools/build_rules/test_rules.bzl \ - --replace /bin/bash ${bash}/bin/bash - - for i in $(find tools/cpp/ -type f) - do - substituteInPlace $i \ - --replace /bin/bash ${bash}/bin/bash - done + grep -rlZ /bin/ tools/python | while IFS="" read -r -d "" path; do + substituteInPlace "$path" \ + --replace "/usr/bin/env python2" ${python3.interpreter} \ + --replace "/usr/bin/env python3" ${python3}/bin/python \ + --replace /usr/bin/env ${coreutils}/bin/env + done - # Fixup scripts that generate scripts. Not fixed up by patchShebangs below. - substituteInPlace scripts/bootstrap/compile.sh \ + # bazel test runner include references to /bin/bash + substituteInPlace tools/build_rules/test_rules.bzl \ --replace /bin/bash ${bash}/bin/bash - # add nix environment vars to .bazelrc - cat >> .bazelrc <> tools/jdk/BUILD.tools <> third_party/grpc/bazel_1.41.0.patch <> runfiles.bash.tmp - cat tools/bash/runfiles/runfiles.bash >> runfiles.bash.tmp - mv runfiles.bash.tmp tools/bash/runfiles/runfiles.bash - - patchShebangs . - ''; - in lib.optionalString stdenv.hostPlatform.isDarwin darwinPatches - + genericPatches; + for i in $(find tools/cpp/ -type f) + do + substituteInPlace $i \ + --replace /bin/bash ${bash}/bin/bash + done - buildInputs = [buildJdk] ++ defaultShellUtils; + # Fixup scripts that generate scripts. Not fixed up by patchShebangs below. + substituteInPlace scripts/bootstrap/compile.sh \ + --replace /bin/bash ${bash}/bin/bash + + # add nix environment vars to .bazelrc + cat >> .bazelrc <> tools/jdk/BUILD.tools <> third_party/grpc/bazel_1.41.0.patch <> runfiles.bash.tmp + cat tools/bash/runfiles/runfiles.bash >> runfiles.bash.tmp + mv runfiles.bash.tmp tools/bash/runfiles/runfiles.bash + + patchShebangs . + ''; + in + lib.optionalString stdenv.hostPlatform.isDarwin darwinPatches + genericPatches; + + buildInputs = [ buildJdk ] ++ defaultShellUtils; # when a command can’t be found in a bazel build, you might also # need to add it to `defaultShellPath`. - nativeBuildInputs = [ - installShellFiles - makeWrapper - python3 - unzip - which - zip - python3.pkgs.absl-py # Needed to build fish completion - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ cctools libcxx CoreFoundation CoreServices Foundation ]; + nativeBuildInputs = + [ + installShellFiles + makeWrapper + python3 + unzip + which + zip + python3.pkgs.absl-py # Needed to build fish completion + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ + cctools + libcxx + CoreFoundation + CoreServices + Foundation + ]; # Bazel makes extensive use of symlinks in the WORKSPACE. # This causes problems with infinite symlinks if the build output is in the same location as the # Bazel WORKSPACE. This is why before executing the build, the source code is moved into a # subdirectory. # Failing to do this causes "infinite symlink expansion detected" - preBuildPhases = ["preBuildPhase"]; + preBuildPhases = [ "preBuildPhase" ]; preBuildPhase = '' mkdir bazel_src shopt -s dotglob extglob @@ -643,16 +757,18 @@ stdenv.mkDerivation rec { # Save paths to hardcoded dependencies so Nix can detect them. # This is needed because the templates get tar’d up into a .jar. - postFixup = '' - mkdir -p $out/nix-support - echo "${defaultShellPath}" >> $out/nix-support/depends - # The string literal specifying the path to the bazel-rc file is sometimes - # stored non-contiguously in the binary due to gcc optimisations, which leads - # Nix to miss the hash when scanning for dependencies - echo "${bazelRC}" >> $out/nix-support/depends - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - echo "${cctools}" >> $out/nix-support/depends - ''; + postFixup = + '' + mkdir -p $out/nix-support + echo "${defaultShellPath}" >> $out/nix-support/depends + # The string literal specifying the path to the bazel-rc file is sometimes + # stored non-contiguously in the binary due to gcc optimisations, which leads + # Nix to miss the hash when scanning for dependencies + echo "${bazelRC}" >> $out/nix-support/depends + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + echo "${cctools}" >> $out/nix-support/depends + ''; dontStrip = true; dontPatchELF = true; diff --git a/pkgs/development/tools/build-managers/bazel/cpp-test.nix b/pkgs/development/tools/build-managers/bazel/cpp-test.nix index cc3bc8d9a14187..e1748042d13716 100644 --- a/pkgs/development/tools/build-managers/bazel/cpp-test.nix +++ b/pkgs/development/tools/build-managers/bazel/cpp-test.nix @@ -1,18 +1,18 @@ { - bazel -, bazelTest -, bazel-examples -, stdenv -, cctools -, darwin -, extraBazelArgs ? "" -, lib -, runLocal -, runtimeShell -, writeScript -, writeText -, distDir -, Foundation ? null + bazel, + bazelTest, + bazel-examples, + stdenv, + cctools, + darwin, + extraBazelArgs ? "", + lib, + runLocal, + runtimeShell, + writeScript, + writeText, + distDir, + Foundation ? null, }: let @@ -32,32 +32,38 @@ let exec "$BAZEL_REAL" "$@" ''; - workspaceDir = runLocal "our_workspace" {} ('' - cp -r ${bazel-examples}/cpp-tutorial/stage3 $out - find $out -type d -exec chmod 755 {} \; - '' - + (lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir $out/tools - cp ${toolsBazel} $out/tools/bazel - '')); + workspaceDir = runLocal "our_workspace" { } ( + '' + cp -r ${bazel-examples}/cpp-tutorial/stage3 $out + find $out -type d -exec chmod 755 {} \; + '' + + (lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir $out/tools + cp ${toolsBazel} $out/tools/bazel + '') + ); testBazel = bazelTest { name = "${bazel.pname}-test-cpp"; inherit workspaceDir; bazelPkg = bazel; - bazelScript = '' - ${bazel}/bin/bazel build //... \ - --verbose_failures \ - --distdir=${distDir} \ - --curses=no \ - ${extraBazelArgs} \ - '' + lib.optionalString (stdenv.hostPlatform.isDarwin) '' + bazelScript = + '' + ${bazel}/bin/bazel build //... \ + --verbose_failures \ + --distdir=${distDir} \ + --curses=no \ + ${extraBazelArgs} \ + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin) '' --cxxopt=-x --cxxopt=c++ --host_cxxopt=-x --host_cxxopt=c++ \ --linkopt=-stdlib=libc++ --host_linkopt=-stdlib=libc++ \ - '' + lib.optionalString (stdenv.hostPlatform.isDarwin && Foundation != null) '' + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin && Foundation != null) '' --linkopt=-Wl,-F${Foundation}/Library/Frameworks \ --linkopt=-L${darwin.libobjc}/lib \ - ''; + ''; }; -in testBazel +in +testBazel diff --git a/pkgs/development/tools/build-managers/bazel/java-test.nix b/pkgs/development/tools/build-managers/bazel/java-test.nix index afdacaf6a8440f..c17e34cb60cdb5 100644 --- a/pkgs/development/tools/build-managers/bazel/java-test.nix +++ b/pkgs/development/tools/build-managers/bazel/java-test.nix @@ -1,17 +1,18 @@ -{ bazel -, bazelTest -, bazel-examples -, stdenv -, cctools -, extraBazelArgs ? "" -, lib -, openjdk8 -, jdk11_headless -, runLocal -, runtimeShell -, writeScript -, writeText -, distDir +{ + bazel, + bazelTest, + bazel-examples, + stdenv, + cctools, + extraBazelArgs ? "", + lib, + openjdk8, + jdk11_headless, + runLocal, + runtimeShell, + writeScript, + writeText, + distDir, }: let @@ -31,38 +32,43 @@ let exec "$BAZEL_REAL" "$@" ''; - workspaceDir = runLocal "our_workspace" {} ('' - cp -r ${bazel-examples}/java-tutorial $out - find $out -type d -exec chmod 755 {} \; - '' - + (lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir $out/tools - cp ${toolsBazel} $out/tools/bazel - '')); + workspaceDir = runLocal "our_workspace" { } ( + '' + cp -r ${bazel-examples}/java-tutorial $out + find $out -type d -exec chmod 755 {} \; + '' + + (lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir $out/tools + cp ${toolsBazel} $out/tools/bazel + '') + ); testBazel = bazelTest { name = "${bazel.pname}-test-java"; inherit workspaceDir; bazelPkg = bazel; - buildInputs = [ (if lib.strings.versionOlder bazel.version "5.0.0" then openjdk8 else jdk11_headless) ]; - bazelScript = '' - ${bazel}/bin/bazel \ - run \ - --announce_rc \ - ${lib.optionalString (lib.strings.versionOlder "5.0.0" bazel.version) - "--toolchain_resolution_debug='@bazel_tools//tools/jdk:(runtime_)?toolchain_type'" - } \ - --distdir=${distDir} \ - --verbose_failures \ - --curses=no \ - --strict_java_deps=off \ - //:ProjectRunner \ - '' + lib.optionalString (lib.strings.versionOlder bazel.version "5.0.0") '' + buildInputs = [ + (if lib.strings.versionOlder bazel.version "5.0.0" then openjdk8 else jdk11_headless) + ]; + bazelScript = + '' + ${bazel}/bin/bazel \ + run \ + --announce_rc \ + ${lib.optionalString (lib.strings.versionOlder "5.0.0" bazel.version) "--toolchain_resolution_debug='@bazel_tools//tools/jdk:(runtime_)?toolchain_type'"} \ + --distdir=${distDir} \ + --verbose_failures \ + --curses=no \ + --strict_java_deps=off \ + //:ProjectRunner \ + '' + + lib.optionalString (lib.strings.versionOlder bazel.version "5.0.0") '' --host_javabase='@local_jdk//:jdk' \ --java_toolchain='@bazel_tools//tools/jdk:toolchain_hostjdk8' \ --javabase='@local_jdk//:jdk' \ - '' + extraBazelArgs; + '' + + extraBazelArgs; }; -in testBazel - +in +testBazel diff --git a/pkgs/development/tools/build-managers/bazel/protobuf-test.nix b/pkgs/development/tools/build-managers/bazel/protobuf-test.nix index 5880c5dd95fe38..0522c9172ecabc 100644 --- a/pkgs/development/tools/build-managers/bazel/protobuf-test.nix +++ b/pkgs/development/tools/build-managers/bazel/protobuf-test.nix @@ -1,18 +1,18 @@ { - bazel -, bazelTest -, fetchFromGitHub -, fetchurl -, stdenv -, cctools -, lib -, openjdk8 -, jdk11_headless -, runLocal -, runtimeShell -, writeScript -, writeText -, distDir + bazel, + bazelTest, + fetchFromGitHub, + fetchurl, + stdenv, + cctools, + lib, + openjdk8, + jdk11_headless, + runLocal, + runtimeShell, + writeScript, + writeText, + distDir, }: let @@ -58,7 +58,7 @@ let protobuf_deps() load("@rules_proto//proto:repositories.bzl", "rules_proto_toolchains") rules_proto_toolchains() - ''; + ''; protoSupport = writeText "proto-support.bzl" '' """Load dependencies needed to compile the protobuf library as a 3rd-party consumer.""" @@ -145,43 +145,51 @@ let exec "$BAZEL_REAL" "$@" ''; - workspaceDir = runLocal "our_workspace" {} ('' - mkdir $out - cp ${WORKSPACE} $out/WORKSPACE - touch $out/BUILD.bazel - cp ${protoSupport} $out/proto-support.bzl - mkdir $out/person - cp ${personProto} $out/person/person.proto - cp ${personBUILD} $out/person/BUILD.bazel - '' - + (lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir $out/tools - cp ${toolsBazel} $out/tools/bazel - '')); + workspaceDir = runLocal "our_workspace" { } ( + '' + mkdir $out + cp ${WORKSPACE} $out/WORKSPACE + touch $out/BUILD.bazel + cp ${protoSupport} $out/proto-support.bzl + mkdir $out/person + cp ${personProto} $out/person/person.proto + cp ${personBUILD} $out/person/BUILD.bazel + '' + + (lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir $out/tools + cp ${toolsBazel} $out/tools/bazel + '') + ); testBazel = bazelTest { name = "${bazel.pname}-test-protocol-buffers"; inherit workspaceDir; bazelPkg = bazel; - buildInputs = [ (if lib.strings.versionOlder bazel.version "5.0.0" then openjdk8 else jdk11_headless) ]; - bazelScript = '' - ${bazel}/bin/bazel \ - build \ - --distdir=${distDir} \ - --verbose_failures \ - --curses=no \ - --subcommands \ - --strict_java_deps=off \ - --strict_proto_deps=off \ - //... \ - '' + lib.optionalString (lib.strings.versionOlder bazel.version "5.0.0") '' + buildInputs = [ + (if lib.strings.versionOlder bazel.version "5.0.0" then openjdk8 else jdk11_headless) + ]; + bazelScript = + '' + ${bazel}/bin/bazel \ + build \ + --distdir=${distDir} \ + --verbose_failures \ + --curses=no \ + --subcommands \ + --strict_java_deps=off \ + --strict_proto_deps=off \ + //... \ + '' + + lib.optionalString (lib.strings.versionOlder bazel.version "5.0.0") '' --host_javabase='@local_jdk//:jdk' \ --java_toolchain='@bazel_tools//tools/jdk:toolchain_hostjdk8' \ --javabase='@local_jdk//:jdk' \ - '' + lib.optionalString (stdenv.hostPlatform.isDarwin) '' + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin) '' --cxxopt=-x --cxxopt=c++ --host_cxxopt=-x --host_cxxopt=c++ \ --linkopt=-stdlib=libc++ --host_linkopt=-stdlib=libc++ \ - ''; + ''; }; -in testBazel +in +testBazel diff --git a/pkgs/development/tools/build-managers/bazel/python-bin-path-test.nix b/pkgs/development/tools/build-managers/bazel/python-bin-path-test.nix index 59f5d0c01fccfd..4af2940d80c29e 100644 --- a/pkgs/development/tools/build-managers/bazel/python-bin-path-test.nix +++ b/pkgs/development/tools/build-managers/bazel/python-bin-path-test.nix @@ -1,15 +1,15 @@ { - bazel -, bazelTest -, stdenv -, cctools -, extraBazelArgs ? "" -, lib -, runLocal -, runtimeShell -, writeScript -, writeText -, distDir + bazel, + bazelTest, + stdenv, + cctools, + extraBazelArgs ? "", + lib, + runLocal, + runtimeShell, + writeScript, + writeText, + distDir, }: let @@ -57,18 +57,20 @@ let ) ''; - workspaceDir = runLocal "our_workspace" {} ('' - mkdir $out - cp ${WORKSPACE} $out/WORKSPACE - mkdir $out/python - cp ${pythonLib} $out/python/lib.py - cp ${pythonBin} $out/python/bin.py - cp ${pythonBUILD} $out/python/BUILD.bazel - '' - + (lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir $out/tools - cp ${toolsBazel} $out/tools/bazel - '')); + workspaceDir = runLocal "our_workspace" { } ( + '' + mkdir $out + cp ${WORKSPACE} $out/WORKSPACE + mkdir $out/python + cp ${pythonLib} $out/python/lib.py + cp ${pythonBin} $out/python/bin.py + cp ${pythonBUILD} $out/python/BUILD.bazel + '' + + (lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir $out/tools + cp ${toolsBazel} $out/tools/bazel + '') + ); testBazel = bazelTest { name = "${bazel.pname}-test-builtin-rules"; @@ -83,4 +85,5 @@ let ''; }; -in testBazel +in +testBazel diff --git a/pkgs/development/tools/build-managers/bazel/shebang-test.nix b/pkgs/development/tools/build-managers/bazel/shebang-test.nix index d316b4650ddf97..fe12cf4de88120 100644 --- a/pkgs/development/tools/build-managers/bazel/shebang-test.nix +++ b/pkgs/development/tools/build-managers/bazel/shebang-test.nix @@ -1,11 +1,11 @@ { - bazel -, bazelTest -, extracted -, ripgrep -, runLocal -, unzip -, ... + bazel, + bazelTest, + extracted, + ripgrep, + runLocal, + unzip, + ... }: # Tests that all shebangs are patched appropriately. @@ -14,7 +14,7 @@ let - workspaceDir = runLocal "our_workspace" {} "mkdir $out"; + workspaceDir = runLocal "our_workspace" { } "mkdir $out"; testBazel = bazelTest { name = "bazel-test-shebangs"; @@ -52,7 +52,11 @@ let exit 1 fi ''; - buildInputs = [ unzip ripgrep ]; + buildInputs = [ + unzip + ripgrep + ]; }; -in testBazel +in +testBazel diff --git a/pkgs/development/tools/build-managers/buck/default.nix b/pkgs/development/tools/build-managers/buck/default.nix index 06246f6b081a18..c4066663a9d93a 100644 --- a/pkgs/development/tools/build-managers/buck/default.nix +++ b/pkgs/development/tools/build-managers/buck/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, jdk8, ant, python3, watchman, bash, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + jdk8, + ant, + python3, + watchman, + bash, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "buck"; @@ -17,7 +27,13 @@ stdenv.mkDerivation rec { grep -l -r '/bin/bash' --null | xargs -0 sed -i -e "s!/bin/bash!${bash}/bin/bash!g" ''; - nativeBuildInputs = [ makeWrapper python3 jdk8 ant watchman ]; + nativeBuildInputs = [ + makeWrapper + python3 + jdk8 + ant + watchman + ]; buildPhase = '' # Set correct version, see https://github.com/facebook/buck/issues/2607 @@ -31,7 +47,13 @@ stdenv.mkDerivation rec { installPhase = '' install -D -m755 buck-out/gen/*/programs/buck.pex $out/bin/buck wrapProgram $out/bin/buck \ - --prefix PATH : "${lib.makeBinPath [ jdk8 watchman python3 ]}" + --prefix PATH : "${ + lib.makeBinPath [ + jdk8 + watchman + python3 + ] + }" ''; meta = with lib; { diff --git a/pkgs/development/tools/build-managers/buck2/default.nix b/pkgs/development/tools/build-managers/buck2/default.nix index b40748d76278f4..1d603c53938f6a 100644 --- a/pkgs/development/tools/build-managers/buck2/default.nix +++ b/pkgs/development/tools/build-managers/buck2/default.nix @@ -50,19 +50,22 @@ let # zstd-compressed src = let - suffix = { - # map our platform name to the rust toolchain suffix - # NOTE (aseipp): must be synchronized with update.sh! - x86_64-darwin = "x86_64-apple-darwin"; - aarch64-darwin = "aarch64-apple-darwin"; - x86_64-linux = "x86_64-unknown-linux-musl"; - aarch64-linux = "aarch64-unknown-linux-musl"; - }."${stdenv.hostPlatform.system}" or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + suffix = + { + # map our platform name to the rust toolchain suffix + # NOTE (aseipp): must be synchronized with update.sh! + x86_64-darwin = "x86_64-apple-darwin"; + aarch64-darwin = "aarch64-apple-darwin"; + x86_64-linux = "x86_64-unknown-linux-musl"; + aarch64-linux = "aarch64-unknown-linux-musl"; + } + ."${stdenv.hostPlatform.system}" or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); name = "buck2-${version}-${suffix}.zst"; hash = buildHashes."${stdenv.hostPlatform.system}"; url = "https://github.com/facebook/buck2/releases/download/${version}/buck2-${suffix}.zst"; - in fetchurl { inherit name url hash; }; + in + fetchurl { inherit name url hash; }; # compatible version of buck2 prelude; this is exported via passthru.prelude # for downstream consumers to use when they need to automate any kind of @@ -73,9 +76,11 @@ let name = "buck2-prelude-${version}.tar.gz"; hash = buildHashes."_prelude"; url = "https://github.com/facebook/buck2-prelude/archive/${prelude-hash}.tar.gz"; - in fetchurl { inherit name url hash; }; + in + fetchurl { inherit name url hash; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "buck2"; version = "unstable-${version}"; # TODO (aseipp): kill 'unstable' once a non-prerelease is made inherit src; @@ -124,12 +129,17 @@ in stdenv.mkDerivation { description = "Fast, hermetic, multi-language build system"; homepage = "https://buck2.build"; changelog = "https://github.com/facebook/buck2/releases/tag/${version}"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; mainProgram = "buck2"; maintainers = with maintainers; [ thoughtpolice ]; platforms = [ - "x86_64-linux" "aarch64-linux" - "x86_64-darwin" "aarch64-darwin" + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" ]; }; } diff --git a/pkgs/development/tools/build-managers/build2/bdep.nix b/pkgs/development/tools/build-managers/build2/bdep.nix index a1a77db45e1b41..0e410058be4165 100644 --- a/pkgs/development/tools/build-managers/build2/bdep.nix +++ b/pkgs/development/tools/build-managers/build2/bdep.nix @@ -1,19 +1,25 @@ -{ lib, stdenv -, build2 -, fetchurl -, libbpkg -, libbutl -, libodb -, libodb-sqlite -, enableShared ? !stdenv.hostPlatform.isStatic -, enableStatic ? !enableShared +{ + lib, + stdenv, + build2, + fetchurl, + libbpkg, + libbutl, + libodb, + libodb-sqlite, + enableShared ? !stdenv.hostPlatform.isStatic, + enableStatic ? !enableShared, }: stdenv.mkDerivation rec { pname = "bdep"; version = "0.17.0"; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; src = fetchurl { url = "https://pkg.cppget.org/1/alpha/build2/bdep-${version}.tar.gz"; hash = "sha256-+2Hl5kanxWJmOpfePAvvSBSmG3kZLQv/kYIkT4J+kaQ="; diff --git a/pkgs/development/tools/build-managers/build2/bootstrap.nix b/pkgs/development/tools/build-managers/build2/bootstrap.nix index c06be28e462ac9..d853adc83ebf76 100644 --- a/pkgs/development/tools/build-managers/build2/bootstrap.nix +++ b/pkgs/development/tools/build-managers/build2/bootstrap.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchurl -, pkgs -, buildPackages -, fixDarwinDylibNames +{ + lib, + stdenv, + fetchurl, + pkgs, + buildPackages, + fixDarwinDylibNames, }: stdenv.mkDerivation rec { pname = "build2-bootstrap"; diff --git a/pkgs/development/tools/build-managers/build2/bpkg.nix b/pkgs/development/tools/build-managers/build2/bpkg.nix index bf9951e7ae1721..01a1b52dcf60c6 100644 --- a/pkgs/development/tools/build-managers/build2/bpkg.nix +++ b/pkgs/development/tools/build-managers/build2/bpkg.nix @@ -1,21 +1,27 @@ -{ lib, stdenv -, build2 -, fetchurl -, git -, libbpkg -, libbutl -, libodb -, libodb-sqlite -, openssl -, enableShared ? !stdenv.hostPlatform.isStatic -, enableStatic ? !enableShared +{ + lib, + stdenv, + build2, + fetchurl, + git, + libbpkg, + libbutl, + libodb, + libodb-sqlite, + openssl, + enableShared ? !stdenv.hostPlatform.isStatic, + enableStatic ? !enableShared, }: stdenv.mkDerivation rec { pname = "bpkg"; version = "0.17.0"; - outputs = [ "out" "doc" "man" ]; + outputs = [ + "out" + "doc" + "man" + ]; src = fetchurl { url = "https://pkg.cppget.org/1/alpha/build2/bpkg-${version}.tar.gz"; diff --git a/pkgs/development/tools/build-managers/build2/default.nix b/pkgs/development/tools/build-managers/build2/default.nix index c02334c98a51ea..5b66917f96f653 100644 --- a/pkgs/development/tools/build-managers/build2/default.nix +++ b/pkgs/development/tools/build-managers/build2/default.nix @@ -1,25 +1,37 @@ -{ stdenv, lib -, build2 -, fetchurl -, fixDarwinDylibNames -, libbutl -, libpkgconf -, buildPackages -, enableShared ? !stdenv.hostPlatform.isStatic -, enableStatic ? !enableShared +{ + stdenv, + lib, + build2, + fetchurl, + fixDarwinDylibNames, + libbutl, + libpkgconf, + buildPackages, + enableShared ? !stdenv.hostPlatform.isStatic, + enableStatic ? !enableShared, }: let - configSharedStatic = enableShared: enableStatic: - if enableShared && enableStatic then "both" - else if enableShared then "shared" - else if enableStatic then "static" - else throw "neither shared nor static libraries requested"; + configSharedStatic = + enableShared: enableStatic: + if enableShared && enableStatic then + "both" + else if enableShared then + "shared" + else if enableStatic then + "static" + else + throw "neither shared nor static libraries requested"; in stdenv.mkDerivation rec { pname = "build2"; version = "0.17.0"; - outputs = [ "out" "dev" "doc" "man" ]; + outputs = [ + "out" + "dev" + "doc" + "man" + ]; setupHook = ./setup-hook.sh; @@ -104,7 +116,10 @@ stdenv.mkDerivation rec { ''; changelog = "https://git.build2.org/cgit/build2/tree/NEWS"; platforms = platforms.all; - maintainers = with maintainers; [ hiro98 r-burns ]; + maintainers = with maintainers; [ + hiro98 + r-burns + ]; mainProgram = "b"; }; } diff --git a/pkgs/development/tools/build-managers/drake/default.nix b/pkgs/development/tools/build-managers/drake/default.nix index 139f8e0436a50f..3ccf765d354e29 100644 --- a/pkgs/development/tools/build-managers/drake/default.nix +++ b/pkgs/development/tools/build-managers/drake/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "drake"; @@ -10,7 +14,11 @@ bundlerApp { meta = with lib; { description = "Branch of Rake supporting automatic parallelizing of tasks"; homepage = "http://quix.github.io/rake/"; - maintainers = with maintainers; [ romildo manveru nicknovitski ]; + maintainers = with maintainers; [ + romildo + manveru + nicknovitski + ]; license = licenses.mit; platforms = platforms.unix; }; diff --git a/pkgs/development/tools/build-managers/drake/gemset.nix b/pkgs/development/tools/build-managers/drake/gemset.nix index 09b3bc7ec061c7..b31a295137bffd 100644 --- a/pkgs/development/tools/build-managers/drake/gemset.nix +++ b/pkgs/development/tools/build-managers/drake/gemset.nix @@ -1,20 +1,20 @@ { comp_tree = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dj9lkfxcczn67l1j12dcxswrfxxd1zgxa344zk6vqs2gwwhy9m9"; type = "gem"; }; version = "1.1.3"; }; drake = { - dependencies = ["comp_tree"]; - groups = ["default"]; - platforms = []; + dependencies = [ "comp_tree" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09gkmdshwdmdnkdxi03dv4rk1dip0wdv6dx14wscrmi0jyk86yag"; type = "gem"; }; diff --git a/pkgs/development/tools/build-managers/fac/default.nix b/pkgs/development/tools/build-managers/fac/default.nix index 63d53e123aad5e..ce8b4a52cf2b0d 100644 --- a/pkgs/development/tools/build-managers/fac/default.nix +++ b/pkgs/development/tools/build-managers/fac/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, rustPlatform, fetchCrate, git, CoreServices }: +{ + lib, + stdenv, + rustPlatform, + fetchCrate, + git, + CoreServices, +}: rustPlatform.buildRustPackage rec { pname = "fac-build"; @@ -10,7 +17,6 @@ rustPlatform.buildRustPackage rec { hash = "sha256-+JJVuKUdnjJoQJ4a2EE0O6jZdVoFxPwbPgfD2LfiDPI="; }; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices ]; cargoHash = "sha256-XT4FQVE+buORuZAFZK5Qnf/Fl3QSvw4SHUuCzWhxUdk="; diff --git a/pkgs/development/tools/build-managers/gnumake/default.nix b/pkgs/development/tools/build-managers/gnumake/default.nix index 5f215be7386a7b..e5fc56c2249b05 100644 --- a/pkgs/development/tools/build-managers/gnumake/default.nix +++ b/pkgs/development/tools/build-managers/gnumake/default.nix @@ -1,12 +1,14 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, guileSupport ? false, guile -# avoid guile depend on bootstrap to prevent dependency cycles -, inBootstrap ? false -, pkg-config -, gnumake +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + guileSupport ? false, + guile, + # avoid guile depend on bootstrap to prevent dependency cycles + inBootstrap ? false, + pkg-config, + gnumake, }: let @@ -35,10 +37,14 @@ stdenv.mkDerivation rec { # directory until derivation realization to avoid unnecessary Nix evaluations. patches = lib.filesystem.listFilesRecursive ./patches; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; buildInputs = lib.optionals guileEnabled [ guile ]; - configureFlags = lib.optional guileEnabled "--with-guile" + configureFlags = + lib.optional guileEnabled "--with-guile" # Make uses this test to decide whether it should keep track of # subseconds. Apple made this possible with APFS and macOS 10.13. @@ -49,7 +55,11 @@ stdenv.mkDerivation rec { # See https://github.com/NixOS/nixpkgs/issues/51221 for discussion. ++ lib.optional stdenv.hostPlatform.isDarwin "ac_cv_struct_st_mtim_nsec=no"; - outputs = [ "out" "man" "info" ]; + outputs = [ + "out" + "man" + "info" + ]; separateDebugInfo = true; passthru.tests = { diff --git a/pkgs/development/tools/build-managers/gradle/fetch-deps.nix b/pkgs/development/tools/build-managers/gradle/fetch-deps.nix index a0d3b10ba863d7..1474d003f70dc9 100644 --- a/pkgs/development/tools/build-managers/gradle/fetch-deps.nix +++ b/pkgs/development/tools/build-managers/gradle/fetch-deps.nix @@ -1,221 +1,277 @@ -{ mitm-cache -, lib -, pkgs -, stdenv -, callPackage +{ + mitm-cache, + lib, + pkgs, + stdenv, + callPackage, }: let - getPkg = attrPath: - lib.getAttrFromPath - (lib.splitString "." (toString attrPath)) - pkgs; + getPkg = attrPath: lib.getAttrFromPath (lib.splitString "." (toString attrPath)) pkgs; in # the derivation to fetch/update deps for -{ pkg ? getPkg attrPath -, pname ? null -, attrPath ? pname -# bwrap flags for the update script (this will be put in bash as-is) -# this is relevant for downstream users -, bwrapFlags ? "--ro-bind \"$PWD\" \"$PWD\"" -# deps path (relative to the package directory, or absolute) -, data -# redirect stdout to stderr to allow the update script to be used with update script combinators -, silent ? true -, useBwrap ? stdenv.hostPlatform.isLinux -} @ attrs: +{ + pkg ? getPkg attrPath, + pname ? null, + attrPath ? pname, + # bwrap flags for the update script (this will be put in bash as-is) + # this is relevant for downstream users + bwrapFlags ? "--ro-bind \"$PWD\" \"$PWD\"", + # deps path (relative to the package directory, or absolute) + data, + # redirect stdout to stderr to allow the update script to be used with update script combinators + silent ? true, + useBwrap ? stdenv.hostPlatform.isLinux, +}@attrs: let - data' = builtins.removeAttrs - (if builtins.isPath data then lib.importJSON data - else if builtins.isString data then lib.importJSON "${dirOf pkg.meta.position}/${data}" - else data) - [ "!comment" "!version" ]; - - parseArtifactUrl = url: let - extension = lib.last (lib.splitString "." url); - splitUrl = lib.splitString "/" url; - artifactId = builtins.elemAt splitUrl (builtins.length splitUrl - 3); - baseVer = builtins.elemAt splitUrl (builtins.length splitUrl - 2); - filename = builtins.elemAt splitUrl (builtins.length splitUrl - 1); - filenameNoExt = lib.removeSuffix ".${extension}" filename; - verCls = lib.removePrefix "${artifactId}-" filenameNoExt; - in rec { - inherit artifactId baseVer filename extension; - isSnapshot = lib.hasSuffix "-SNAPSHOT" baseVer; - version = - if isSnapshot && !lib.hasPrefix "SNAPSHOT" verCls - then builtins.concatStringsSep "-" (lib.take 3 (lib.splitString "-" verCls)) - else baseVer; - classifier = - if verCls == version then null - else lib.removePrefix "${version}-" verCls; - # for snapshots - timestamp = builtins.elemAt (lib.splitString "-" version) 1; - buildNum = builtins.elemAt (lib.splitString "-" version) 2; - }; + data' = + builtins.removeAttrs + ( + if builtins.isPath data then + lib.importJSON data + else if builtins.isString data then + lib.importJSON "${dirOf pkg.meta.position}/${data}" + else + data + ) + [ + "!comment" + "!version" + ]; - parseMetadataUrl = url: let - xmlBase = lib.removeSuffix "/maven-metadata.xml" url; - vMeta = lib.hasSuffix "-SNAPSHOT" xmlBase; - splitBase = lib.splitString "/" xmlBase; - in - if vMeta then { - vMeta = true; - baseVer = builtins.elemAt splitBase (builtins.length splitBase - 1); - artifactId = builtins.elemAt splitBase (builtins.length splitBase - 2); - } else { - vMeta = false; - baseVer = null; - artifactId = builtins.elemAt splitBase (builtins.length splitBase - 1); + parseArtifactUrl = + url: + let + extension = lib.last (lib.splitString "." url); + splitUrl = lib.splitString "/" url; + artifactId = builtins.elemAt splitUrl (builtins.length splitUrl - 3); + baseVer = builtins.elemAt splitUrl (builtins.length splitUrl - 2); + filename = builtins.elemAt splitUrl (builtins.length splitUrl - 1); + filenameNoExt = lib.removeSuffix ".${extension}" filename; + verCls = lib.removePrefix "${artifactId}-" filenameNoExt; + in + rec { + inherit + artifactId + baseVer + filename + extension + ; + isSnapshot = lib.hasSuffix "-SNAPSHOT" baseVer; + version = + if isSnapshot && !lib.hasPrefix "SNAPSHOT" verCls then + builtins.concatStringsSep "-" (lib.take 3 (lib.splitString "-" verCls)) + else + baseVer; + classifier = if verCls == version then null else lib.removePrefix "${version}-" verCls; + # for snapshots + timestamp = builtins.elemAt (lib.splitString "-" version) 1; + buildNum = builtins.elemAt (lib.splitString "-" version) 2; }; - extractHashArtifact = afterHash: let - nameVer = builtins.match "([^/]*)/([^/]*)(/SNAPSHOT)?(/.*)?" afterHash; - artifactId = builtins.elemAt nameVer 0; - version = builtins.elemAt nameVer 1; - isSnapshot = builtins.elemAt nameVer 2 != null; - cls = builtins.elemAt nameVer 3; - in rec { - inherit artifactId version isSnapshot; - baseVer = - if !isSnapshot then version - else builtins.head (builtins.match "(.*)-([^-]*)-([^-]*)" version) + "-SNAPSHOT"; - classifier = - if cls == null then null - else lib.removePrefix "/" cls; - clsSuf = - if classifier == null then "" - else "-${classifier}"; - }; + parseMetadataUrl = + url: + let + xmlBase = lib.removeSuffix "/maven-metadata.xml" url; + vMeta = lib.hasSuffix "-SNAPSHOT" xmlBase; + splitBase = lib.splitString "/" xmlBase; + in + if vMeta then + { + vMeta = true; + baseVer = builtins.elemAt splitBase (builtins.length splitBase - 1); + artifactId = builtins.elemAt splitBase (builtins.length splitBase - 2); + } + else + { + vMeta = false; + baseVer = null; + artifactId = builtins.elemAt splitBase (builtins.length splitBase - 1); + }; + + extractHashArtifact = + afterHash: + let + nameVer = builtins.match "([^/]*)/([^/]*)(/SNAPSHOT)?(/.*)?" afterHash; + artifactId = builtins.elemAt nameVer 0; + version = builtins.elemAt nameVer 1; + isSnapshot = builtins.elemAt nameVer 2 != null; + cls = builtins.elemAt nameVer 3; + in + rec { + inherit artifactId version isSnapshot; + baseVer = + if !isSnapshot then + version + else + builtins.head (builtins.match "(.*)-([^-]*)-([^-]*)" version) + "-SNAPSHOT"; + classifier = if cls == null then null else lib.removePrefix "/" cls; + clsSuf = if classifier == null then "" else "-${classifier}"; + }; # replace base#name/ver with base/name/ver/name-ver - decompressNameVer = prefix: let - splitHash = lib.splitString "#" (builtins.concatStringsSep "/" prefix); - inherit (extractHashArtifact (lib.last splitHash)) artifactId baseVer version clsSuf; - in - if builtins.length splitHash == 1 then builtins.head splitHash - else builtins.concatStringsSep "/${artifactId}/${baseVer}/" (lib.init splitHash ++ [ "${artifactId}-${version}${clsSuf}" ]); + decompressNameVer = + prefix: + let + splitHash = lib.splitString "#" (builtins.concatStringsSep "/" prefix); + inherit (extractHashArtifact (lib.last splitHash)) + artifactId + baseVer + version + clsSuf + ; + in + if builtins.length splitHash == 1 then + builtins.head splitHash + else + builtins.concatStringsSep "/${artifactId}/${baseVer}/" ( + lib.init splitHash ++ [ "${artifactId}-${version}${clsSuf}" ] + ); # `visit` all elements in attrs and merge into a set # attrs will be passed as parent1, parent1 will be passed as parent2 - visitAttrs = parent1: prefix: attrs: - builtins.foldl' - (a: b: a // b) - {} - (lib.mapAttrsToList (visit parent1 attrs prefix) attrs); + visitAttrs = + parent1: prefix: attrs: + builtins.foldl' (a: b: a // b) { } (lib.mapAttrsToList (visit parent1 attrs prefix) attrs); # convert a compressed deps.json into an uncompressed json used for mitm-cache.fetch - visit = parent2: parent1: prefix: k: v: + visit = + parent2: parent1: prefix: k: v: # groupId being present means this is a metadata xml "leaf" and we shouldn't descend further - if builtins.isAttrs v && !v?groupId - then visitAttrs parent1 (prefix ++ [k]) v - else let - url = "${decompressNameVer prefix}.${k}"; - in { - ${url} = - if builtins.isString v then { hash = v; } - else { - text = let - xmlBase = lib.removeSuffix "/maven-metadata.xml" url; - meta = parseMetadataUrl url // v; - inherit (meta) groupId vMeta artifactId baseVer; - - fileList = builtins.filter (x: lib.hasPrefix xmlBase x && x != url) (builtins.attrNames finalData); - jarPomList = map parseArtifactUrl fileList; - - sortByVersion = a: b: (builtins.compareVersions a.version b.version) < 0; - sortedJarPomList = lib.sort sortByVersion jarPomList; - - uniqueVersionFiles = - builtins.map ({ i, x }: x) - (builtins.filter ({ i, x }: i == 0 || (builtins.elemAt sortedJarPomList (i - 1)).version != x.version) - (lib.imap0 (i: x: { inherit i x; }) sortedJarPomList)); - uniqueVersions' = map (x: x.version) uniqueVersionFiles; - releaseVersions = map (x: x.version) (builtins.filter (x: !x.isSnapshot) uniqueVersionFiles); - latestVer = v.latest or v.release or (lib.last uniqueVersions'); - releaseVer = v.release or (lib.last releaseVersions); - - # The very latest version isn't necessarily used by Gradle, so it may not be present in the MITM data. - # In order to generate better metadata xml, if the latest version is known but wasn't fetched by Gradle, - # add it anyway. - uniqueVersions = - uniqueVersions' - ++ lib.optional (!builtins.elem releaseVer uniqueVersions') releaseVer - ++ lib.optional (!builtins.elem latestVer uniqueVersions' && releaseVer != latestVer) latestVer; - - lastUpdated = v.lastUpdated or - (if vMeta then builtins.replaceStrings ["."] [""] snapshotTs - else "20240101123456"); - - # the following are only used for snapshots - snapshotTsAndNum = lib.splitString "-" latestVer; - snapshotTs = builtins.elemAt snapshotTsAndNum 1; - snapshotNum = lib.last snapshotTsAndNum; - - indent = x: s: builtins.concatStringsSep "\n" (map (s: x + s) (lib.splitString "\n" s)); - containsSpecialXmlChars = s: builtins.match ''.*[<>"'&].*'' s != null; - in - # make sure all user-provided data is safe - assert lib.hasInfix "${builtins.replaceStrings ["."] ["/"] groupId}/${artifactId}" url; - assert !containsSpecialXmlChars groupId; - assert !containsSpecialXmlChars lastUpdated; - if vMeta then '' - - - ${groupId} - ${artifactId} - ${baseVer} - - - ${snapshotTs} - ${snapshotNum} - - ${lastUpdated} - - ${builtins.concatStringsSep "\n" (map (x: indent " " '' - ${ - lib.optionalString - (x.classifier != null) - "\n ${x.classifier}" - } - ${x.extension} - ${x.version} - ${builtins.replaceStrings ["."] [""] x.timestamp} - '') sortedJarPomList)} - - - - '' + if builtins.isAttrs v && !v ? groupId then + visitAttrs parent1 (prefix ++ [ k ]) v + else + let + url = "${decompressNameVer prefix}.${k}"; + in + { + ${url} = + if builtins.isString v then + { hash = v; } else - assert !containsSpecialXmlChars latestVer; - assert !containsSpecialXmlChars releaseVer; - '' - - - ${groupId} - ${artifactId} - - ${latestVer} - ${releaseVer} - - ${builtins.concatStringsSep "\n" (map (x: " ${x}") uniqueVersions)} - - ${lastUpdated} - - - ''; - }; - }; + { + text = + let + xmlBase = lib.removeSuffix "/maven-metadata.xml" url; + meta = parseMetadataUrl url // v; + inherit (meta) + groupId + vMeta + artifactId + baseVer + ; - finalData = visitAttrs {} [] data'; -in - mitm-cache.fetch { - name = "${pkg.pname or pkg.name}-deps"; - data = finalData // { "!version" = 1; }; - passthru = lib.optionalAttrs (!builtins.isAttrs data) { - updateScript = callPackage ./update-deps.nix { } { - inherit pkg pname attrPath bwrapFlags data silent useBwrap; + fileList = builtins.filter (x: lib.hasPrefix xmlBase x && x != url) (builtins.attrNames finalData); + jarPomList = map parseArtifactUrl fileList; + + sortByVersion = a: b: (builtins.compareVersions a.version b.version) < 0; + sortedJarPomList = lib.sort sortByVersion jarPomList; + + uniqueVersionFiles = builtins.map ({ i, x }: x) ( + builtins.filter ( + { i, x }: i == 0 || (builtins.elemAt sortedJarPomList (i - 1)).version != x.version + ) (lib.imap0 (i: x: { inherit i x; }) sortedJarPomList) + ); + uniqueVersions' = map (x: x.version) uniqueVersionFiles; + releaseVersions = map (x: x.version) (builtins.filter (x: !x.isSnapshot) uniqueVersionFiles); + latestVer = v.latest or v.release or (lib.last uniqueVersions'); + releaseVer = v.release or (lib.last releaseVersions); + + # The very latest version isn't necessarily used by Gradle, so it may not be present in the MITM data. + # In order to generate better metadata xml, if the latest version is known but wasn't fetched by Gradle, + # add it anyway. + uniqueVersions = + uniqueVersions' + ++ lib.optional (!builtins.elem releaseVer uniqueVersions') releaseVer + ++ lib.optional (!builtins.elem latestVer uniqueVersions' && releaseVer != latestVer) latestVer; + + lastUpdated = + v.lastUpdated + or (if vMeta then builtins.replaceStrings [ "." ] [ "" ] snapshotTs else "20240101123456"); + + # the following are only used for snapshots + snapshotTsAndNum = lib.splitString "-" latestVer; + snapshotTs = builtins.elemAt snapshotTsAndNum 1; + snapshotNum = lib.last snapshotTsAndNum; + + indent = x: s: builtins.concatStringsSep "\n" (map (s: x + s) (lib.splitString "\n" s)); + containsSpecialXmlChars = s: builtins.match ''.*[<>"'&].*'' s != null; + in + # make sure all user-provided data is safe + assert lib.hasInfix "${builtins.replaceStrings [ "." ] [ "/" ] groupId}/${artifactId}" url; + assert !containsSpecialXmlChars groupId; + assert !containsSpecialXmlChars lastUpdated; + if vMeta then + '' + + + ${groupId} + ${artifactId} + ${baseVer} + + + ${snapshotTs} + ${snapshotNum} + + ${lastUpdated} + + ${builtins.concatStringsSep "\n" ( + map ( + x: + indent " " '' + ${ + lib.optionalString (x.classifier != null) "\n ${x.classifier}" + } + ${x.extension} + ${x.version} + ${builtins.replaceStrings [ "." ] [ "" ] x.timestamp} + '' + ) sortedJarPomList + )} + + + + '' + else + assert !containsSpecialXmlChars latestVer; + assert !containsSpecialXmlChars releaseVer; + '' + + + ${groupId} + ${artifactId} + + ${latestVer} + ${releaseVer} + + ${builtins.concatStringsSep "\n" (map (x: " ${x}") uniqueVersions)} + + ${lastUpdated} + + + ''; + }; }; + + finalData = visitAttrs { } [ ] data'; +in +mitm-cache.fetch { + name = "${pkg.pname or pkg.name}-deps"; + data = finalData // { + "!version" = 1; + }; + passthru = lib.optionalAttrs (!builtins.isAttrs data) { + updateScript = callPackage ./update-deps.nix { } { + inherit + pkg + pname + attrPath + bwrapFlags + data + silent + useBwrap + ; }; - } + }; +} diff --git a/pkgs/development/tools/build-managers/gradle/update-deps.nix b/pkgs/development/tools/build-managers/gradle/update-deps.nix index 51959fa69f38fa..8dc36c3bd7b421 100644 --- a/pkgs/development/tools/build-managers/gradle/update-deps.nix +++ b/pkgs/development/tools/build-managers/gradle/update-deps.nix @@ -1,125 +1,156 @@ -{ lib -, runtimeShell -, srcOnly -, stdenvNoCC -, writeTextFile -, writeShellScript -, path -, bubblewrap -, coreutils -, curl -, jq -, mitm-cache -, nix -, openssl -, procps -, python3 +{ + lib, + runtimeShell, + srcOnly, + stdenvNoCC, + writeTextFile, + writeShellScript, + path, + bubblewrap, + coreutils, + curl, + jq, + mitm-cache, + nix, + openssl, + procps, + python3, }: -lib.makeOverridable -({ pkg, pname, attrPath, bwrapFlags, data, silent, useBwrap }: -let - keep = [ "MITM_CACHE_HOST" "MITM_CACHE_PORT" "MITM_CACHE_ADDRESS" "MITM_CACHE_CA" "MITM_CACHE_CERT_DIR" ]; - gradleScript = writeShellScript "gradle-commands.sh" '' - set -eo pipefail - export http_proxy="$MITM_CACHE_ADDRESS" - export https_proxy="$MITM_CACHE_ADDRESS" - export SSL_CERT_FILE="$MITM_CACHE_CA" - export NIX_SSL_CERT_FILE="$MITM_CACHE_CA" - export GRADLE_USER_HOME="$(${coreutils}/bin/mktemp -d)" - export IN_GRADLE_UPDATE_DEPS=1 - trap "${coreutils}/bin/rm -rf '$GRADLE_USER_HOME'" SIGINT SIGTERM ERR EXIT - cd "$(${coreutils}/bin/mktemp -d)" - ${coreutils}/bin/mkdir out - export out="$PWD/out" - trap "${coreutils}/bin/rm -rf '$PWD'" SIGINT SIGTERM ERR EXIT - source "$stdenv/setup" - phases="''${prePhases[*]:-} unpackPhase patchPhase ''${preConfigurePhases[*]:-} configurePhase gradleUpdateScript" genericBuild - ''; - source = srcOnly (pkg.overrideAttrs (old: { - mitmCache = ""; - gradleInitScript = ./init-deps.gradle; +lib.makeOverridable ( + { + pkg, + pname, + attrPath, + bwrapFlags, + data, + silent, + useBwrap, + }: + let + keep = [ + "MITM_CACHE_HOST" + "MITM_CACHE_PORT" + "MITM_CACHE_ADDRESS" + "MITM_CACHE_CA" + "MITM_CACHE_CERT_DIR" + ]; + gradleScript = writeShellScript "gradle-commands.sh" '' + set -eo pipefail + export http_proxy="$MITM_CACHE_ADDRESS" + export https_proxy="$MITM_CACHE_ADDRESS" + export SSL_CERT_FILE="$MITM_CACHE_CA" + export NIX_SSL_CERT_FILE="$MITM_CACHE_CA" + export GRADLE_USER_HOME="$(${coreutils}/bin/mktemp -d)" + export IN_GRADLE_UPDATE_DEPS=1 + trap "${coreutils}/bin/rm -rf '$GRADLE_USER_HOME'" SIGINT SIGTERM ERR EXIT + cd "$(${coreutils}/bin/mktemp -d)" + ${coreutils}/bin/mkdir out + export out="$PWD/out" + trap "${coreutils}/bin/rm -rf '$PWD'" SIGINT SIGTERM ERR EXIT + source "$stdenv/setup" + phases="''${prePhases[*]:-} unpackPhase patchPhase ''${preConfigurePhases[*]:-} configurePhase gradleUpdateScript" genericBuild + ''; + source = srcOnly ( + pkg.overrideAttrs (old: { + mitmCache = ""; + gradleInitScript = ./init-deps.gradle; - stdenv = old.stdenv or stdenvNoCC; - })); - sourceDrvPath = builtins.unsafeDiscardOutputDependency source.drvPath; - nixShellKeep = lib.concatMapStringsSep " " (x: "--keep ${x}") keep; -in -writeTextFile { - name = "fetch-deps.sh"; - executable = true; - # see pkgs/common-updater/combinators.nix - derivationArgs.passthru = - { supportedFeatures = lib.optional silent "silent"; } - // lib.optionalAttrs (attrPath != null) { inherit attrPath; }; - text = '' - #!${runtimeShell} - set -eo pipefail - export PATH="${lib.makeBinPath ([ - coreutils curl jq mitm-cache openssl - procps python3.pkgs.ephemeral-port-reserve - ] ++ lib.optional useBwrap bubblewrap)}:$PATH" - outPath="${ - # if this is an absolute path in nix store, use path relative to the store path - if lib.hasPrefix "${builtins.storeDir}/" (toString data) - then builtins.concatStringsSep "/" (lib.drop 1 (lib.splitString "/" (lib.removePrefix "${builtins.storeDir}/" (toString data)))) - # if this is an absolute path anywhere else, just use that path - else if lib.hasPrefix "/" (toString data) - then toString data - # otherwise, use a path relative to the package - else "${dirOf pkg.meta.position}/${data}" - }" + stdenv = old.stdenv or stdenvNoCC; + }) + ); + sourceDrvPath = builtins.unsafeDiscardOutputDependency source.drvPath; + nixShellKeep = lib.concatMapStringsSep " " (x: "--keep ${x}") keep; + in + writeTextFile { + name = "fetch-deps.sh"; + executable = true; + # see pkgs/common-updater/combinators.nix + derivationArgs.passthru = { + supportedFeatures = lib.optional silent "silent"; + } // lib.optionalAttrs (attrPath != null) { inherit attrPath; }; + text = '' + #!${runtimeShell} + set -eo pipefail + export PATH="${ + lib.makeBinPath ( + [ + coreutils + curl + jq + mitm-cache + openssl + procps + python3.pkgs.ephemeral-port-reserve + ] + ++ lib.optional useBwrap bubblewrap + ) + }:$PATH" + outPath="${ + # if this is an absolute path in nix store, use path relative to the store path + if lib.hasPrefix "${builtins.storeDir}/" (toString data) then + builtins.concatStringsSep "/" ( + lib.drop 1 (lib.splitString "/" (lib.removePrefix "${builtins.storeDir}/" (toString data))) + ) + # if this is an absolute path anywhere else, just use that path + else if lib.hasPrefix "/" (toString data) then + toString data + # otherwise, use a path relative to the package + else + "${dirOf pkg.meta.position}/${data}" + }" - pushd "$(mktemp -d)" >/dev/null - MITM_CACHE_DIR="$PWD" - trap "rm -rf '$MITM_CACHE_DIR'" SIGINT SIGTERM ERR EXIT - openssl genrsa -out ca.key 2048 - openssl req -x509 -new -nodes -key ca.key -sha256 -days 1 -out ca.cer -subj "/C=AL/ST=a/L=a/O=a/OU=a/CN=example.org" - export MITM_CACHE_HOST=127.0.0.1 - export MITM_CACHE_PORT="''${mitmCachePort:-$(ephemeral-port-reserve "$MITM_CACHE_HOST")}" - export MITM_CACHE_ADDRESS="$MITM_CACHE_HOST:$MITM_CACHE_PORT" - # forget all redirects - this makes the lockfiles predictable - # not only does this strip CDN URLs, but it also improves security - since the redirects aren't - # stored in the lockfile, a malicious actor can't change the redirect URL stored in the lockfile - mitm-cache \ - -l"$MITM_CACHE_ADDRESS" \ - record \ - --reject '\.(md5|sha(1|256|512:?):?)$' \ - --forget-redirects-from '.*' \ - --record-text '/maven-metadata\.xml$' >/dev/null 2>/dev/null & - MITM_CACHE_PID="$!" - # wait for mitm-cache to fully start - for i in {0..20}; do - ps -p "$MITM_CACHE_PID" >/dev/null || (echo "Failed to start mitm-cache" && exit 1) - curl -so/dev/null "$MITM_CACHE_ADDRESS" && break - [[ "$i" -eq 20 ]] && (echo "Failed to start mitm-cache" && exit 1) - sleep 0.5 - done - trap "kill '$MITM_CACHE_PID'" SIGINT SIGTERM ERR EXIT - export MITM_CACHE_CERT_DIR="$PWD" - export MITM_CACHE_CA="$MITM_CACHE_CERT_DIR/ca.cer" - popd >/dev/null - useBwrap="''${USE_BWRAP:-${toString useBwrap}}" - if [ -n "$useBwrap" ]; then - # bwrap isn't necessary, it's only used to prevent messy build scripts from touching ~ - bwrap \ - --unshare-all --share-net --clearenv --chdir / --setenv HOME /homeless-shelter \ - --tmpfs /home --bind /tmp /tmp --ro-bind /nix /nix --ro-bind /run /run --proc /proc --dev /dev \ - --ro-bind ${toString path} ${toString path} --bind "$MITM_CACHE_CERT_DIR" "$MITM_CACHE_CERT_DIR" \ - ${builtins.concatStringsSep " " (map (x: "--setenv ${x} \"\$${x}\"") keep)} \ - --setenv NIX_BUILD_SHELL ${runtimeShell} ${bwrapFlags} ''${BWRAP_FLAGS:-} \ - -- ${nix}/bin/nix-shell --pure --run ${gradleScript} ${nixShellKeep} ${sourceDrvPath} - else - NIX_BUILD_SHELL=${runtimeShell} nix-shell --pure --run ${gradleScript} ${nixShellKeep} ${sourceDrvPath} - fi${lib.optionalString silent " >&2"} - kill -s SIGINT "$MITM_CACHE_PID" - for i in {0..20}; do - # check for valid json - if jq -e 1 "$MITM_CACHE_DIR/out.json" >/dev/null 2>/dev/null; then - exec ${python3.interpreter} ${./compress-deps-json.py} "$MITM_CACHE_DIR/out.json" "$outPath" - fi - sleep 1 - done - exit 1 - ''; -}) + pushd "$(mktemp -d)" >/dev/null + MITM_CACHE_DIR="$PWD" + trap "rm -rf '$MITM_CACHE_DIR'" SIGINT SIGTERM ERR EXIT + openssl genrsa -out ca.key 2048 + openssl req -x509 -new -nodes -key ca.key -sha256 -days 1 -out ca.cer -subj "/C=AL/ST=a/L=a/O=a/OU=a/CN=example.org" + export MITM_CACHE_HOST=127.0.0.1 + export MITM_CACHE_PORT="''${mitmCachePort:-$(ephemeral-port-reserve "$MITM_CACHE_HOST")}" + export MITM_CACHE_ADDRESS="$MITM_CACHE_HOST:$MITM_CACHE_PORT" + # forget all redirects - this makes the lockfiles predictable + # not only does this strip CDN URLs, but it also improves security - since the redirects aren't + # stored in the lockfile, a malicious actor can't change the redirect URL stored in the lockfile + mitm-cache \ + -l"$MITM_CACHE_ADDRESS" \ + record \ + --reject '\.(md5|sha(1|256|512:?):?)$' \ + --forget-redirects-from '.*' \ + --record-text '/maven-metadata\.xml$' >/dev/null 2>/dev/null & + MITM_CACHE_PID="$!" + # wait for mitm-cache to fully start + for i in {0..20}; do + ps -p "$MITM_CACHE_PID" >/dev/null || (echo "Failed to start mitm-cache" && exit 1) + curl -so/dev/null "$MITM_CACHE_ADDRESS" && break + [[ "$i" -eq 20 ]] && (echo "Failed to start mitm-cache" && exit 1) + sleep 0.5 + done + trap "kill '$MITM_CACHE_PID'" SIGINT SIGTERM ERR EXIT + export MITM_CACHE_CERT_DIR="$PWD" + export MITM_CACHE_CA="$MITM_CACHE_CERT_DIR/ca.cer" + popd >/dev/null + useBwrap="''${USE_BWRAP:-${toString useBwrap}}" + if [ -n "$useBwrap" ]; then + # bwrap isn't necessary, it's only used to prevent messy build scripts from touching ~ + bwrap \ + --unshare-all --share-net --clearenv --chdir / --setenv HOME /homeless-shelter \ + --tmpfs /home --bind /tmp /tmp --ro-bind /nix /nix --ro-bind /run /run --proc /proc --dev /dev \ + --ro-bind ${toString path} ${toString path} --bind "$MITM_CACHE_CERT_DIR" "$MITM_CACHE_CERT_DIR" \ + ${builtins.concatStringsSep " " (map (x: "--setenv ${x} \"\$${x}\"") keep)} \ + --setenv NIX_BUILD_SHELL ${runtimeShell} ${bwrapFlags} ''${BWRAP_FLAGS:-} \ + -- ${nix}/bin/nix-shell --pure --run ${gradleScript} ${nixShellKeep} ${sourceDrvPath} + else + NIX_BUILD_SHELL=${runtimeShell} nix-shell --pure --run ${gradleScript} ${nixShellKeep} ${sourceDrvPath} + fi${lib.optionalString silent " >&2"} + kill -s SIGINT "$MITM_CACHE_PID" + for i in {0..20}; do + # check for valid json + if jq -e 1 "$MITM_CACHE_DIR/out.json" >/dev/null 2>/dev/null; then + exec ${python3.interpreter} ${./compress-deps-json.py} "$MITM_CACHE_DIR/out.json" "$outPath" + fi + sleep 1 + done + exit 1 + ''; + } +) diff --git a/pkgs/development/tools/build-managers/gup/default.nix b/pkgs/development/tools/build-managers/gup/default.nix index b500d7d9cc4066..ca8c6a6a59fefd 100644 --- a/pkgs/development/tools/build-managers/gup/default.nix +++ b/pkgs/development/tools/build-managers/gup/default.nix @@ -1,5 +1,13 @@ -{ stdenv, fetchFromGitHub, nix-update-source, lib, python3 -, which, runtimeShell, pylint }: +{ + stdenv, + fetchFromGitHub, + nix-update-source, + lib, + python3, + which, + runtimeShell, + pylint, +}: stdenv.mkDerivation rec { version = "0.9.2"; src = fetchFromGitHub { @@ -9,7 +17,11 @@ stdenv.mkDerivation rec { rev = "version-${version}"; }; pname = "gup"; - nativeBuildInputs = [ python3 which pylint ]; + nativeBuildInputs = [ + python3 + which + pylint + ]; buildInputs = [ python3 ]; strictDeps = true; buildPhase = "make python"; diff --git a/pkgs/development/tools/build-managers/moon/default.nix b/pkgs/development/tools/build-managers/moon/default.nix index b377ca2fc955df..a24cfa50091489 100644 --- a/pkgs/development/tools/build-managers/moon/default.nix +++ b/pkgs/development/tools/build-managers/moon/default.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, darwin -, stdenv -, openssl -, pkg-config +{ + lib, + rustPlatform, + fetchFromGitHub, + darwin, + stdenv, + openssl, + pkg-config, }: rustPlatform.buildRustPackage rec { @@ -25,11 +26,12 @@ rustPlatform.buildRustPackage rec { OPENSSL_NO_VENDOR = 1; }; - buildInputs = [ openssl ] ++ - lib.optionals stdenv.hostPlatform.isDarwin [ + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ darwin.apple_sdk.frameworks.Security darwin.apple_sdk.frameworks.SystemConfiguration - ]; + ]; nativeBuildInputs = [ pkg-config ]; # Some tests fail, because test using internet connection and install NodeJS by example diff --git a/pkgs/development/tools/build-managers/qbs/default.nix b/pkgs/development/tools/build-managers/qbs/default.nix index 9c642123ee4d19..fb2cb702e5b570 100644 --- a/pkgs/development/tools/build-managers/qbs/default.nix +++ b/pkgs/development/tools/build-managers/qbs/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, qmake, qtbase, qtscript }: +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + qtbase, + qtscript, +}: stdenv.mkDerivation rec { pname = "qbs"; @@ -16,15 +23,21 @@ stdenv.mkDerivation rec { dontWrapQtApps = true; - qmakeFlags = [ "QBS_INSTALL_PREFIX=$(out)" "qbs.pro" ]; + qmakeFlags = [ + "QBS_INSTALL_PREFIX=$(out)" + "qbs.pro" + ]; - buildInputs = [ qtbase qtscript ]; + buildInputs = [ + qtbase + qtscript + ]; meta = with lib; { description = "Tool that helps simplify the build process for developing projects across multiple platforms"; homepage = "https://wiki.qt.io/Qbs"; license = licenses.lgpl3; - maintainers = []; + maintainers = [ ]; platforms = platforms.linux; }; } diff --git a/pkgs/development/tools/build-managers/rake/default.nix b/pkgs/development/tools/build-managers/rake/default.nix index 0017a099be0de3..73dbe5bea416c3 100644 --- a/pkgs/development/tools/build-managers/rake/default.nix +++ b/pkgs/development/tools/build-managers/rake/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "rake"; @@ -10,8 +14,11 @@ bundlerApp { meta = with lib; { description = "Software task management and build automation tool"; homepage = "https://github.com/ruby/rake"; - license = with licenses; mit; - maintainers = with maintainers; [ manveru nicknovitski ]; + license = with licenses; mit; + maintainers = with maintainers; [ + manveru + nicknovitski + ]; platforms = platforms.unix; mainProgram = "rake"; }; diff --git a/pkgs/development/tools/build-managers/rake/gemset.nix b/pkgs/development/tools/build-managers/rake/gemset.nix index 365174a7e971ec..0cf78683c486af 100644 --- a/pkgs/development/tools/build-managers/rake/gemset.nix +++ b/pkgs/development/tools/build-managers/rake/gemset.nix @@ -1,9 +1,9 @@ { rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17850wcwkgi30p7yqh60960ypn7yibacjjha0av78zaxwvd3ijs6"; type = "gem"; }; diff --git a/pkgs/development/tools/build-managers/rebar/default.nix b/pkgs/development/tools/build-managers/rebar/default.nix index b73553466cbb82..b6fc00753c5c24 100644 --- a/pkgs/development/tools/build-managers/rebar/default.nix +++ b/pkgs/development/tools/build-managers/rebar/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, erlang }: +{ + lib, + stdenv, + fetchFromGitHub, + erlang, +}: stdenv.mkDerivation rec { pname = "rebar"; diff --git a/pkgs/development/tools/build-managers/rebar3/default.nix b/pkgs/development/tools/build-managers/rebar3/default.nix index 651bc16be06bca..9a70da3f09fdb0 100644 --- a/pkgs/development/tools/build-managers/rebar3/default.nix +++ b/pkgs/development/tools/build-managers/rebar3/default.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, fetchgit, - fetchHex, erlang, makeWrapper, - writeScript, common-updater-scripts, coreutils, git, gnused, nix, rebar3-nix }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchgit, + fetchHex, + erlang, + makeWrapper, + writeScript, + common-updater-scripts, + coreutils, + git, + gnused, + nix, + rebar3-nix, +}: let version = "3.24.0"; @@ -24,9 +37,11 @@ let postPatch = '' mkdir -p _checkouts _build/default/lib/ - ${toString (lib.mapAttrsToList (k: v: '' - cp -R --no-preserve=mode ${v} _checkouts/${k} - '') deps)} + ${toString ( + lib.mapAttrsToList (k: v: '' + cp -R --no-preserve=mode ${v} _checkouts/${k} + '') deps + )} # Bootstrap script expects the dependencies in _build/default/lib # TODO: Make it accept checkouts? @@ -62,7 +77,7 @@ let of build configuration work. rebar also provides dependency management, enabling application writers to easily re-use common libraries from a variety of locations (hex.pm, git, hg, and so on). - ''; + ''; platforms = lib.platforms.unix; maintainers = lib.teams.beam.members; @@ -79,7 +94,7 @@ let git gnused nix - (rebar3WithPlugins { globalPlugins = [rebar3-nix]; }) + (rebar3WithPlugins { globalPlugins = [ rebar3-nix ]; }) ] } latest=$(list-git-tags | sed -n '/[\d\.]\+/p' | sort -V | tail -1) @@ -99,27 +114,41 @@ let # Alias rebar3 so we can use it as default parameter below _rebar3 = rebar3; - rebar3WithPlugins = { plugins ? [ ], globalPlugins ? [ ], rebar3 ? _rebar3 }: + rebar3WithPlugins = + { + plugins ? [ ], + globalPlugins ? [ ], + rebar3 ? _rebar3, + }: let pluginLibDirs = map (p: "${p}/lib/erlang/lib") (lib.unique (plugins ++ globalPlugins)); globalPluginNames = lib.unique (map (p: p.packageName) globalPlugins); - rebar3Patched = (rebar3.overrideAttrs (old: { - - # skip-plugins.patch is necessary because otherwise rebar3 will always - # try to fetch plugins if they are not already present in _build. - # - # global-deps.patch makes it possible to use REBAR_GLOBAL_PLUGINS to - # instruct rebar3 to always load a certain plugin. It is necessary since - # REBAR_GLOBAL_CONFIG_DIR doesn't seem to work for this. - patches = [ ./skip-plugins.patch ./global-plugins.patch ]; - - # our patches cause the tests to fail - doCheck = false; - })); - in stdenv.mkDerivation { + rebar3Patched = ( + rebar3.overrideAttrs (old: { + + # skip-plugins.patch is necessary because otherwise rebar3 will always + # try to fetch plugins if they are not already present in _build. + # + # global-deps.patch makes it possible to use REBAR_GLOBAL_PLUGINS to + # instruct rebar3 to always load a certain plugin. It is necessary since + # REBAR_GLOBAL_CONFIG_DIR doesn't seem to work for this. + patches = [ + ./skip-plugins.patch + ./global-plugins.patch + ]; + + # our patches cause the tests to fail + doCheck = false; + }) + ); + in + stdenv.mkDerivation { pname = "rebar3-with-plugins"; inherit (rebar3) version; - nativeBuildInputs = [ erlang makeWrapper ]; + nativeBuildInputs = [ + erlang + makeWrapper + ]; unpackPhase = "true"; # Here we extract the rebar3 escript (like `rebar3_prv_local_install.erl`) and @@ -141,4 +170,7 @@ let --add-flags "+sbtu +A1 -noshell -boot start_clean -s rebar3 main -extra" ''; }; -in { inherit rebar3 rebar3WithPlugins; } +in +{ + inherit rebar3 rebar3WithPlugins; +} diff --git a/pkgs/development/tools/build-managers/rebar3/rebar-deps.nix b/pkgs/development/tools/build-managers/rebar3/rebar-deps.nix index 7f6be584098d7e..18fa145d429569 100644 --- a/pkgs/development/tools/build-managers/rebar3/rebar-deps.nix +++ b/pkgs/development/tools/build-managers/rebar3/rebar-deps.nix @@ -1,6 +1,14 @@ # Generated by rebar3_nix -let fetchOnly = { src, ... }: src; -in { builder ? fetchOnly, fetchHex, fetchgit, fetchFromGitHub, overrides ? (x: y: { }) }: +let + fetchOnly = { src, ... }: src; +in +{ + builder ? fetchOnly, + fetchHex, + fetchgit, + fetchFromGitHub, + overrides ? (x: y: { }), +}: let self = packages // (overrides self packages); packages = with self; { @@ -15,4 +23,5 @@ let beamDeps = [ ]; }; }; -in self +in +self diff --git a/pkgs/development/tools/build-managers/sbt/default.nix b/pkgs/development/tools/build-managers/sbt/default.nix index 57a8f2673c47dd..be62398d179c30 100644 --- a/pkgs/development/tools/build-managers/sbt/default.nix +++ b/pkgs/development/tools/build-managers/sbt/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, jre -, autoPatchelfHook -, zlib -, ncurses +{ + lib, + stdenv, + fetchurl, + jre, + autoPatchelfHook, + zlib, + ncurses, }: stdenv.mkDerivation (finalAttrs: { @@ -39,9 +40,12 @@ stdenv.mkDerivation (finalAttrs: { cp -ra . $out/share/sbt ln -sT ../share/sbt/bin/sbt $out/bin/sbt ln -sT ../share/sbt/bin/sbtn-${ - if (stdenv.hostPlatform.isDarwin) then "universal-apple-darwin" - else if (stdenv.hostPlatform.isAarch64) then "aarch64-pc-linux" - else "x86_64-pc-linux" + if (stdenv.hostPlatform.isDarwin) then + "universal-apple-darwin" + else if (stdenv.hostPlatform.isAarch64) then + "aarch64-pc-linux" + else + "x86_64-pc-linux" } $out/bin/sbtn runHook postInstall @@ -55,7 +59,10 @@ stdenv.mkDerivation (finalAttrs: { binaryNativeCode ]; description = "Build tool for Scala, Java and more"; - maintainers = with maintainers; [ nequissimus kashw2 ]; + maintainers = with maintainers; [ + nequissimus + kashw2 + ]; platforms = platforms.unix; }; }) diff --git a/pkgs/development/tools/build-managers/sbt/scala-native.nix b/pkgs/development/tools/build-managers/sbt/scala-native.nix index 5dc5cf7eb3e05c..86df0b13961241 100644 --- a/pkgs/development/tools/build-managers/sbt/scala-native.nix +++ b/pkgs/development/tools/build-managers/sbt/scala-native.nix @@ -1,14 +1,41 @@ -{ lib, sbt, makeWrapper, boehmgc, libunwind, re2, llvmPackages, zlib }: +{ + lib, + sbt, + makeWrapper, + boehmgc, + libunwind, + re2, + llvmPackages, + zlib, +}: -sbt.overrideAttrs(previousAttrs: { +sbt.overrideAttrs (previousAttrs: { nativeBuildInputs = (previousAttrs.nativeBuildInputs or [ ]) ++ [ makeWrapper ]; - postFixup = (previousAttrs.postFixup or "") + '' - wrapProgram $out/bin/sbt \ - --set CLANG_PATH "${llvmPackages.clang}/bin/clang" \ - --set CLANGPP_PATH "${llvmPackages.clang}/bin/clang" \ - --set CPATH "${lib.makeSearchPathOutput "dev" "include" [ re2 zlib boehmgc libunwind llvmPackages.libcxx ]}/c++/v1" \ - --set LIBRARY_PATH "${lib.makeLibraryPath [ re2 zlib boehmgc libunwind llvmPackages.libcxx ]}" \ - --set NIX_CFLAGS_LINK "-lc++" - ''; + postFixup = + (previousAttrs.postFixup or "") + + '' + wrapProgram $out/bin/sbt \ + --set CLANG_PATH "${llvmPackages.clang}/bin/clang" \ + --set CLANGPP_PATH "${llvmPackages.clang}/bin/clang" \ + --set CPATH "${ + lib.makeSearchPathOutput "dev" "include" [ + re2 + zlib + boehmgc + libunwind + llvmPackages.libcxx + ] + }/c++/v1" \ + --set LIBRARY_PATH "${ + lib.makeLibraryPath [ + re2 + zlib + boehmgc + libunwind + llvmPackages.libcxx + ] + }" \ + --set NIX_CFLAGS_LINK "-lc++" + ''; }) diff --git a/pkgs/development/tools/build-managers/scala-cli/default.nix b/pkgs/development/tools/build-managers/scala-cli/default.nix index 3a0eb79b243035..9a7c1b45cf9e89 100644 --- a/pkgs/development/tools/build-managers/scala-cli/default.nix +++ b/pkgs/development/tools/build-managers/scala-cli/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, coreutils -, lib -, installShellFiles -, zlib -, autoPatchelfHook -, fetchurl -, makeWrapper -, callPackage -, jre -, testers -, scala-cli +{ + stdenv, + coreutils, + lib, + installShellFiles, + zlib, + autoPatchelfHook, + fetchurl, + makeWrapper, + callPackage, + jre, + testers, + scala-cli, }: let @@ -21,16 +22,24 @@ let in stdenv.mkDerivation { inherit pname version; - nativeBuildInputs = [ installShellFiles makeWrapper ] - ++ lib.optional stdenv.hostPlatform.isLinux autoPatchelfHook; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ] ++ lib.optional stdenv.hostPlatform.isLinux autoPatchelfHook; buildInputs = assert lib.assertMsg (lib.versionAtLeast jre.version "17.0.0") '' scala-cli requires Java 17 or newer, but ${jre.name} is ${jre.version} ''; - [ coreutils zlib stdenv.cc.cc ]; + [ + coreutils + zlib + stdenv.cc.cc + ]; src = let - asset = assets."${stdenv.hostPlatform.system}" or (throw "Unsupported platform ${stdenv.hostPlatform.system}"); + asset = + assets."${stdenv.hostPlatform.system}" + or (throw "Unsupported platform ${stdenv.hostPlatform.system}"); in fetchurl { url = "https://github.com/Virtuslab/scala-cli/releases/download/v${version}/${asset.asset}"; @@ -54,19 +63,21 @@ stdenv.mkDerivation { # We need to call autopatchelf before generating completions dontAutoPatchelf = true; - postFixup = lib.optionalString stdenv.hostPlatform.isLinux '' - autoPatchelf $out - '' + '' - # hack to ensure the completion function looks right - # as $0 is used to generate the compdef directive - mkdir temp - cp $out/bin/.scala-cli-wrapped temp/scala-cli - PATH="./temp:$PATH" + postFixup = + lib.optionalString stdenv.hostPlatform.isLinux '' + autoPatchelf $out + '' + + '' + # hack to ensure the completion function looks right + # as $0 is used to generate the compdef directive + mkdir temp + cp $out/bin/.scala-cli-wrapped temp/scala-cli + PATH="./temp:$PATH" - installShellCompletion --cmd scala-cli \ - --bash <(scala-cli completions bash) \ - --zsh <(scala-cli completions zsh) - ''; + installShellCompletion --cmd scala-cli \ + --bash <(scala-cli completions bash) \ + --zsh <(scala-cli completions zsh) + ''; meta = with lib; { homepage = "https://scala-cli.virtuslab.org"; diff --git a/pkgs/development/tools/build-managers/scala-cli/update.nix b/pkgs/development/tools/build-managers/scala-cli/update.nix index fd79a1cf3a8b99..80b34a4d9d1d15 100644 --- a/pkgs/development/tools/build-managers/scala-cli/update.nix +++ b/pkgs/development/tools/build-managers/scala-cli/update.nix @@ -1,8 +1,31 @@ -{ lib, curl, writeShellScript, jq, gnused, git, nix, coreutils }: { platforms, pname, version }: +{ + lib, + curl, + writeShellScript, + jq, + gnused, + git, + nix, + coreutils, +}: +{ + platforms, + pname, + version, +}: writeShellScript "${pname}-update-script" '' set -o errexit - PATH=${lib.makeBinPath [ curl jq gnused git nix coreutils ]} + PATH=${ + lib.makeBinPath [ + curl + jq + gnused + git + nix + coreutils + ] + } latest_version=$(curl -s "https://api.github.com/repos/VirtusLab/scala-cli/releases?per_page=1" | jq ".[0].tag_name" --raw-output | sed 's/^v//') diff --git a/pkgs/development/tools/build-managers/shards/default.nix b/pkgs/development/tools/build-managers/shards/default.nix index 94e0bc9a278474..dd4a752025617b 100644 --- a/pkgs/development/tools/build-managers/shards/default.nix +++ b/pkgs/development/tools/build-managers/shards/default.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, crystal +{ + lib, + fetchFromGitHub, + crystal, }: let diff --git a/pkgs/development/tools/buildah/default.nix b/pkgs/development/tools/buildah/default.nix index d89a0e3c60f3f3..4b2ea26f69851d 100644 --- a/pkgs/development/tools/buildah/default.nix +++ b/pkgs/development/tools/buildah/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, go-md2man -, installShellFiles -, pkg-config -, gpgme -, lvm2 -, btrfs-progs -, libapparmor -, libselinux -, libseccomp -, testers -, buildah +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + go-md2man, + installShellFiles, + pkg-config, + gpgme, + lvm2, + btrfs-progs, + libapparmor, + libselinux, + libseccomp, + testers, + buildah, }: buildGoModule rec { @@ -26,24 +27,33 @@ buildGoModule rec { hash = "sha256-avQdK7+kMrPc8rp/2nTiUC/ZTW8nUem9v3u0xsE0oGM="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; vendorHash = null; doCheck = false; - nativeBuildInputs = [ go-md2man installShellFiles pkg-config ]; - - buildInputs = [ - gpgme - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - btrfs-progs - libapparmor - libseccomp - libselinux - lvm2 + nativeBuildInputs = [ + go-md2man + installShellFiles + pkg-config ]; + buildInputs = + [ + gpgme + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + btrfs-progs + libapparmor + libseccomp + libselinux + lvm2 + ]; + buildPhase = '' runHook preBuild patchShebangs . @@ -77,4 +87,3 @@ buildGoModule rec { maintainers = with maintainers; [ ] ++ teams.podman.members; }; } - diff --git a/pkgs/development/tools/buildah/wrapper.nix b/pkgs/development/tools/buildah/wrapper.nix index 1b27c4899715d8..9da8c022ac769e 100644 --- a/pkgs/development/tools/buildah/wrapper.nix +++ b/pkgs/development/tools/buildah/wrapper.nix @@ -1,69 +1,79 @@ -{ buildah-unwrapped -, runCommand -, makeWrapper -, symlinkJoin -, lib -, stdenv -, extraPackages ? [] -, runc # Default container runtime -, crun # Container runtime (default with cgroups v2 for podman/buildah) -, conmon # Container runtime monitor -, slirp4netns # User-mode networking for unprivileged namespaces -, fuse-overlayfs # CoW for images, much faster than default vfs -, util-linux # nsenter -, iptables -, aardvark-dns -, netavark -, passt +{ + buildah-unwrapped, + runCommand, + makeWrapper, + symlinkJoin, + lib, + stdenv, + extraPackages ? [ ], + runc, # Default container runtime + crun, # Container runtime (default with cgroups v2 for podman/buildah) + conmon, # Container runtime monitor + slirp4netns, # User-mode networking for unprivileged namespaces + fuse-overlayfs, # CoW for images, much faster than default vfs + util-linux, # nsenter + iptables, + aardvark-dns, + netavark, + passt, }: let - binPath = lib.makeBinPath ([ - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - runc - crun - conmon - slirp4netns - fuse-overlayfs - util-linux - iptables - ] ++ extraPackages); + binPath = lib.makeBinPath ( + [ + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + runc + crun + conmon + slirp4netns + fuse-overlayfs + util-linux + iptables + ] + ++ extraPackages + ); helpersBin = symlinkJoin { name = "${buildah-unwrapped.pname}-helper-binary-wrapper-${buildah-unwrapped.version}"; # this only works for some binaries, others may need to be added to `binPath` or in the modules - paths = [ - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - aardvark-dns - netavark - passt - ]; + paths = + [ + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + aardvark-dns + netavark + passt + ]; }; -in runCommand buildah-unwrapped.name { - name = "${buildah-unwrapped.pname}-wrapper-${buildah-unwrapped.version}"; - inherit (buildah-unwrapped) pname version passthru; +in +runCommand buildah-unwrapped.name + { + name = "${buildah-unwrapped.pname}-wrapper-${buildah-unwrapped.version}"; + inherit (buildah-unwrapped) pname version passthru; - preferLocalBuild = true; + preferLocalBuild = true; - meta = builtins.removeAttrs buildah-unwrapped.meta [ "outputsToInstall" ]; + meta = builtins.removeAttrs buildah-unwrapped.meta [ "outputsToInstall" ]; - outputs = [ - "out" - "man" - ]; + outputs = [ + "out" + "man" + ]; - nativeBuildInputs = [ - makeWrapper - ]; + nativeBuildInputs = [ + makeWrapper + ]; -} '' - ln -s ${buildah-unwrapped.man} $man + } + '' + ln -s ${buildah-unwrapped.man} $man - mkdir -p $out/bin - ln -s ${buildah-unwrapped}/share $out/share - makeWrapper ${buildah-unwrapped}/bin/buildah $out/bin/buildah \ - --set CONTAINERS_HELPER_BINARY_DIR ${helpersBin}/bin \ - --prefix PATH : ${binPath} -'' + mkdir -p $out/bin + ln -s ${buildah-unwrapped}/share $out/share + makeWrapper ${buildah-unwrapped}/bin/buildah $out/bin/buildah \ + --set CONTAINERS_HELPER_BINARY_DIR ${helpersBin}/bin \ + --prefix PATH : ${binPath} + '' diff --git a/pkgs/development/tools/cadre/default.nix b/pkgs/development/tools/cadre/default.nix index 17b505bf2a9d1b..1694f36647ee40 100644 --- a/pkgs/development/tools/cadre/default.nix +++ b/pkgs/development/tools/cadre/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "cadre"; @@ -9,9 +13,12 @@ bundlerApp { meta = with lib; { description = "Toolkit to add Ruby development - in-editor coverage, libnotify of test runs"; - homepage = "https://github.com/nyarly/cadre"; - license = licenses.mit; - maintainers = with maintainers; [ nyarly nicknovitski ]; - platforms = platforms.unix; + homepage = "https://github.com/nyarly/cadre"; + license = licenses.mit; + maintainers = with maintainers; [ + nyarly + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/cadre/gemset.nix b/pkgs/development/tools/cadre/gemset.nix index e98f5c5f3e693d..3219fa88c12cf3 100644 --- a/pkgs/development/tools/cadre/gemset.nix +++ b/pkgs/development/tools/cadre/gemset.nix @@ -1,8 +1,12 @@ { cadre = { - dependencies = ["thor" "tilt" "valise"]; + dependencies = [ + "thor" + "tilt" + "valise" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07q60s1bm2xar46g00ls5fjkn6dm2kfxhsz9ayblc31x5kr8d83a"; type = "gem"; }; @@ -10,7 +14,7 @@ }; thor = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yhrnp9x8qcy5vc7g438amd5j9sw83ih7c30dr6g6slgw9zj3g29"; type = "gem"; }; @@ -18,7 +22,7 @@ }; tilt = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ca4k0clwf0rkvy7726x4nxpjxkpv67w043i39saxgldxd97zmwz"; type = "gem"; }; @@ -26,7 +30,7 @@ }; valise = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1arsbmk2gifrhv244qrld7s3202xrnxy6vlc5gqklg70dpsinbn5"; type = "gem"; }; diff --git a/pkgs/development/tools/ceedling/default.nix b/pkgs/development/tools/ceedling/default.nix index 25c6dd5bb83643..798369fb72051b 100644 --- a/pkgs/development/tools/ceedling/default.nix +++ b/pkgs/development/tools/ceedling/default.nix @@ -1,5 +1,6 @@ -{ lib -, bundlerApp +{ + lib, + bundlerApp, }: bundlerApp { @@ -9,8 +10,8 @@ bundlerApp { meta = with lib; { description = "Build system for C projects that is something of an extension around Ruby's Rake"; - homepage = "http://www.throwtheswitch.org/ceedling"; - license = licenses.mit; - platforms = platforms.unix; + homepage = "http://www.throwtheswitch.org/ceedling"; + license = licenses.mit; + platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/ceedling/gemset.nix b/pkgs/development/tools/ceedling/gemset.nix index e094c7dd4d671e..953161915e61b2 100644 --- a/pkgs/development/tools/ceedling/gemset.nix +++ b/pkgs/development/tools/ceedling/gemset.nix @@ -1,50 +1,55 @@ { ceedling = { - dependencies = ["constructor" "deep_merge" "rake" "thor"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "constructor" + "deep_merge" + "rake" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jjvz14dg85v8c4raxvk618rq7f6kyna5148901xciz2zjpm3bri"; type = "gem"; }; version = "0.31.1"; }; constructor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02qmp08kcvi5dkz3lxm5yck9msfwfx1msvrrz9d6z4klc14q889y"; type = "gem"; }; version = "2.0.0"; }; deep_merge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fjn4civid68a3zxnbgyjj6krs3l30dy8b4djpg6fpzrsyix7kl3"; type = "gem"; }; version = "1.2.2"; }; rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15whn7p9nrkxangbs9hh75q585yfn66lv0v2mhj6q6dl6x8bzr2w"; type = "gem"; }; version = "13.0.6"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yhrnp9x8qcy5vc7g438amd5j9sw83ih7c30dr6g6slgw9zj3g29"; type = "gem"; }; diff --git a/pkgs/development/tools/click/default.nix b/pkgs/development/tools/click/default.nix index 3508b4cddbcef2..b703b2a4eb634f 100644 --- a/pkgs/development/tools/click/default.nix +++ b/pkgs/development/tools/click/default.nix @@ -1,19 +1,20 @@ -{ lib -, fetchFromGitLab -, buildPythonApplication -, autoreconfHook -, debian -, perl -, vala -, pkg-config -, libgee -, json-glib -, properties-cpp -, gobject-introspection -, getopt -, setuptools -, pygobject3 -, wrapGAppsHook3 +{ + lib, + fetchFromGitLab, + buildPythonApplication, + autoreconfHook, + debian, + perl, + vala, + pkg-config, + libgee, + json-glib, + properties-cpp, + gobject-introspection, + getopt, + setuptools, + pygobject3, + wrapGAppsHook3, }: buildPythonApplication { @@ -86,7 +87,10 @@ buildPythonApplication { description = "Tool to build click packages. Mainly used for Ubuntu Touch"; homepage = "https://gitlab.com/ubports/development/core/click"; license = lib.licenses.gpl3Only; - maintainers = with lib.maintainers; [ ilyakooo0 OPNA2608 ]; + maintainers = with lib.maintainers; [ + ilyakooo0 + OPNA2608 + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/development/tools/cmake-format/default.nix b/pkgs/development/tools/cmake-format/default.nix index 281f36dfe00702..37d7b3219701fd 100644 --- a/pkgs/development/tools/cmake-format/default.nix +++ b/pkgs/development/tools/cmake-format/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonApplication -, fetchPypi -, autopep8 -, flake8 -, jinja2 -, pylint -, pyyaml -, six +{ + lib, + buildPythonApplication, + fetchPypi, + autopep8, + flake8, + jinja2, + pylint, + pyyaml, + six, }: buildPythonApplication rec { @@ -22,7 +23,14 @@ buildPythonApplication rec { sha256 = "0kmggnfbv6bba75l3zfzqwk0swi90brjka307m2kcz2w35kr8jvn"; }; - propagatedBuildInputs = [ autopep8 flake8 jinja2 pylint pyyaml six ]; + propagatedBuildInputs = [ + autopep8 + flake8 + jinja2 + pylint + pyyaml + six + ]; doCheck = false; diff --git a/pkgs/development/tools/cocoapods/default.nix b/pkgs/development/tools/cocoapods/default.nix index 49f7cc3134afb4..ced83c48468e27 100644 --- a/pkgs/development/tools/cocoapods/default.nix +++ b/pkgs/development/tools/cocoapods/default.nix @@ -1,5 +1,9 @@ -{ lib, bundlerApp, ruby -, beta ? false }: +{ + lib, + bundlerApp, + ruby, + beta ? false, +}: bundlerApp { inherit ruby; @@ -13,11 +17,11 @@ bundlerApp { passthru.updateScript = toString ./update; meta = with lib; { - description = "Manages dependencies for your Xcode projects"; - homepage = "https://github.com/CocoaPods/CocoaPods"; - license = licenses.mit; - platforms = platforms.darwin; - maintainers = with maintainers; [ + description = "Manages dependencies for your Xcode projects"; + homepage = "https://github.com/CocoaPods/CocoaPods"; + license = licenses.mit; + platforms = platforms.darwin; + maintainers = with maintainers; [ peterromfeldhk ]; mainProgram = "pod"; diff --git a/pkgs/development/tools/cocoapods/gemset-beta.nix b/pkgs/development/tools/cocoapods/gemset-beta.nix index 381bf3a188f328..b37e23adc0b6b0 100644 --- a/pkgs/development/tools/cocoapods/gemset-beta.nix +++ b/pkgs/development/tools/cocoapods/gemset-beta.nix @@ -1,452 +1,509 @@ { activesupport = { - dependencies = ["base64" "benchmark" "bigdecimal" "concurrent-ruby" "connection_pool" "drb" "i18n" "logger" "minitest" "securerandom" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "benchmark" + "bigdecimal" + "concurrent-ruby" + "connection_pool" + "drb" + "i18n" + "logger" + "minitest" + "securerandom" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "12ijz1mmg70agw4d91hjdyzvma3dzs52mchasslxyn7p9j960qs3"; type = "gem"; }; version = "7.2.2"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; algoliasearch = { - dependencies = ["httpclient" "json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "httpclient" + "json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ly8zsgvih540xmxr098hsngv61cf119wf28q5hbvi1f7kgwvh96"; type = "gem"; }; version = "1.27.5"; }; atomos = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17vq6sjyswr5jfzwdccw748kgph6bdw30bakwnn6p8sl4hpv4hvx"; type = "gem"; }; version = "0.1.3"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; benchmark = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wghmhwjzv4r9mdcny4xfz2h2cm7ci24md79rvy2x65r4i99k9sc"; type = "gem"; }; version = "0.3.0"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; CFPropertyList = { - dependencies = ["base64" "nkf" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "nkf" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k1w5i4lb1z941m7ds858nly33f3iv12wvr1zav5x3fa99hj2my4"; type = "gem"; }; version = "3.0.7"; }; claide = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bpqhc0kqjp1bh9b7ffc395l9gfls0337rrhmab4v46ykl45qg3d"; type = "gem"; }; version = "1.1.0"; }; cocoapods = { - dependencies = ["addressable" "claide" "cocoapods-core" "cocoapods-deintegrate" "cocoapods-downloader" "cocoapods-plugins" "cocoapods-search" "cocoapods-trunk" "cocoapods-try" "colored2" "escape" "fourflusher" "gh_inspector" "molinillo" "nap" "ruby-macho" "xcodeproj"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "claide" + "cocoapods-core" + "cocoapods-deintegrate" + "cocoapods-downloader" + "cocoapods-plugins" + "cocoapods-search" + "cocoapods-trunk" + "cocoapods-try" + "colored2" + "escape" + "fourflusher" + "gh_inspector" + "molinillo" + "nap" + "ruby-macho" + "xcodeproj" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0phyvpx78jlrpvldbxjmzq92mfx6l66va2fz2s5xpwrdydhciw8g"; type = "gem"; }; version = "1.16.2"; }; cocoapods-core = { - dependencies = ["activesupport" "addressable" "algoliasearch" "concurrent-ruby" "fuzzy_match" "nap" "netrc" "public_suffix" "typhoeus"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "addressable" + "algoliasearch" + "concurrent-ruby" + "fuzzy_match" + "nap" + "netrc" + "public_suffix" + "typhoeus" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ay1dwjg79rfa6mbfyy96in0k364dgn7s8ps6v7n07k9432bbcab"; type = "gem"; }; version = "1.16.2"; }; cocoapods-deintegrate = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18pnng0lv5z6kpp8hnki0agdxx979iq6hxkfkglsyqzmir22lz2i"; type = "gem"; }; version = "1.0.5"; }; cocoapods-downloader = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ldnwwsx44i2xsdmsmyz9xrar19lfy5s5xslvral1p3674dvwvmv"; type = "gem"; }; version = "2.1"; }; cocoapods-plugins = { - dependencies = ["nap"]; - groups = ["default"]; - platforms = []; + dependencies = [ "nap" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16na82sfyc8801qs1n22nwq486s4j7yj6rj7fcp8cbxmj371fpbj"; type = "gem"; }; version = "1.0.0"; }; cocoapods-search = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12amy0nknv09bvzix8bkmcjn996c50c4ms20v2dl7v8rcw73n4qv"; type = "gem"; }; version = "1.0.1"; }; cocoapods-trunk = { - dependencies = ["nap" "netrc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "nap" + "netrc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cgdx7z9psxxrsa13fk7qc9i6jskrwcafhrdz94avzia2y6dlnsz"; type = "gem"; }; version = "1.6.0"; }; cocoapods-try = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znyp625rql37ivb5rk9fk9564cmax8icxfr041ysivpdrn98nql"; type = "gem"; }; version = "1.2.0"; }; colored2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jlbqa9q4mvrm73aw9mxh23ygzbjiqwisl32d8szfb5fxvbjng5i"; type = "gem"; }; version = "3.1.2"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; connection_pool = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; drb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h5kbj9hvg5hb3c7l425zpds0vb42phvln2knab8nmazg2zp5m79"; type = "gem"; }; version = "2.2.1"; }; escape = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sa1xkfc9jvkwyw1jbz3jhkq0ms1zrvswi6mmfiwcisg5fp497z4"; type = "gem"; }; version = "0.0.4"; }; ethon = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17ix0mijpsy3y0c6ywrk5ibarmvqzjsirjyprpsy3hwax8fdm85v"; type = "gem"; }; version = "0.16.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; fourflusher = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1afabh3g3gwj0ad53fs62waks815xcckf7pkci76l6vrghffcg8v"; type = "gem"; }; version = "2.3.1"; }; fuzzy_match = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19gw1ifsgfrv7xdi6n61658vffgm1867f4xdqfswb2b5h6alzpmm"; type = "gem"; }; version = "2.0.4"; }; gh_inspector = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f8r9byajj3bi2c7c5sqrc7m0zrv3nblfcd4782lw5l73cbsgk04"; type = "gem"; }; version = "1.1.3"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k31wcgnvcvd14snz0pfqj976zv6drfsnq6x8acz10fiyms9l8nw"; type = "gem"; }; version = "1.14.6"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03q7kbadhbyfnz21abv2b9dyqnjvxpd51ppqihg40rrimw1vm6id"; type = "gem"; }; version = "2.7.6"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n1akmc6bibkbxkzm1p1wmfb4n9vv397knkgz0ffykb3h1d7kdix"; type = "gem"; }; version = "5.25.1"; }; molinillo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p846facmh1j5xmbrpgzadflspvk7bzs3sykrh5s7qi4cdqz5gzg"; type = "gem"; }; version = "0.8.0"; }; nanaimo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08q73nchv8cpk28h1sdnf5z6a862fcf4mxy1d58z25xb3dankw7s"; type = "gem"; }; version = "0.4.0"; }; nap = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xm5xssxk5s03wjarpipfm39qmgxsalb46v1prsis14x1xk935ll"; type = "gem"; }; version = "1.1.0"; }; netrc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gzfmcywp1da8nzfqsql2zqi648mfnx6qwkig3cv36n9m0yy676y"; type = "gem"; }; version = "0.11.0"; }; nkf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09piyp2pd74klb9wcn0zw4mb5l0k9wzwppxggxi1yi95l2ym3hgv"; type = "gem"; }; version = "0.2.0"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1f3knlwfwm05sfbaihrxm4g772b79032q14c16q4b38z8bi63qcb"; type = "gem"; }; version = "4.0.7"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j9p66pmfgxnzp76ksssyfyqqrg7281dyi3xyknl3wwraaw7a66p"; type = "gem"; }; version = "3.3.9"; }; ruby-macho = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jgmhj4srl7cck1ipbjys6q4klcs473gq90bm59baw4j1wpfaxch"; type = "gem"; }; version = "2.5.1"; }; securerandom = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1phv6kh417vkanhssbjr960c0gfqvf8z7d3d9fd2yvd41q64bw4q"; type = "gem"; }; version = "0.3.1"; }; typhoeus = { - dependencies = ["ethon"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ethon" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0z7gamf6s83wy0yqms3bi4srirn3fc0lc7n65lqanidxcj1xn5qw"; type = "gem"; }; version = "1.4.1"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; xcodeproj = { - dependencies = ["CFPropertyList" "atomos" "claide" "colored2" "nanaimo" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "CFPropertyList" + "atomos" + "claide" + "colored2" + "nanaimo" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1lslz1kfb8jnd1ilgg02qx0p0y6yiq8wwk84mgg2ghh58lxsgiwc"; type = "gem"; }; diff --git a/pkgs/development/tools/cocoapods/gemset.nix b/pkgs/development/tools/cocoapods/gemset.nix index 092d4f15ae56d9..d65ed21c8e6cca 100644 --- a/pkgs/development/tools/cocoapods/gemset.nix +++ b/pkgs/development/tools/cocoapods/gemset.nix @@ -1,32 +1,47 @@ { activesupport = { - dependencies = ["base64" "benchmark" "bigdecimal" "concurrent-ruby" "connection_pool" "drb" "i18n" "logger" "minitest" "securerandom" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "benchmark" + "bigdecimal" + "concurrent-ruby" + "connection_pool" + "drb" + "i18n" + "logger" + "minitest" + "securerandom" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "12ijz1mmg70agw4d91hjdyzvma3dzs52mchasslxyn7p9j960qs3"; type = "gem"; }; version = "7.2.2"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; algoliasearch = { - dependencies = ["httpclient" "json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "httpclient" + "json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ly8zsgvih540xmxr098hsngv61cf119wf28q5hbvi1f7kgwvh96"; type = "gem"; }; @@ -34,140 +49,175 @@ }; atomos = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17vq6sjyswr5jfzwdccw748kgph6bdw30bakwnn6p8sl4hpv4hvx"; type = "gem"; }; version = "0.1.3"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; benchmark = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wghmhwjzv4r9mdcny4xfz2h2cm7ci24md79rvy2x65r4i99k9sc"; type = "gem"; }; version = "0.3.0"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; CFPropertyList = { - dependencies = ["base64" "nkf" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "nkf" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k1w5i4lb1z941m7ds858nly33f3iv12wvr1zav5x3fa99hj2my4"; type = "gem"; }; version = "3.0.7"; }; claide = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bpqhc0kqjp1bh9b7ffc395l9gfls0337rrhmab4v46ykl45qg3d"; type = "gem"; }; version = "1.1.0"; }; cocoapods = { - dependencies = ["addressable" "claide" "cocoapods-core" "cocoapods-deintegrate" "cocoapods-downloader" "cocoapods-plugins" "cocoapods-search" "cocoapods-trunk" "cocoapods-try" "colored2" "escape" "fourflusher" "gh_inspector" "molinillo" "nap" "ruby-macho" "xcodeproj"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "claide" + "cocoapods-core" + "cocoapods-deintegrate" + "cocoapods-downloader" + "cocoapods-plugins" + "cocoapods-search" + "cocoapods-trunk" + "cocoapods-try" + "colored2" + "escape" + "fourflusher" + "gh_inspector" + "molinillo" + "nap" + "ruby-macho" + "xcodeproj" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0phyvpx78jlrpvldbxjmzq92mfx6l66va2fz2s5xpwrdydhciw8g"; type = "gem"; }; version = "1.16.2"; }; cocoapods-core = { - dependencies = ["activesupport" "addressable" "algoliasearch" "concurrent-ruby" "fuzzy_match" "nap" "netrc" "public_suffix" "typhoeus"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "addressable" + "algoliasearch" + "concurrent-ruby" + "fuzzy_match" + "nap" + "netrc" + "public_suffix" + "typhoeus" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ay1dwjg79rfa6mbfyy96in0k364dgn7s8ps6v7n07k9432bbcab"; type = "gem"; }; version = "1.16.2"; }; cocoapods-deintegrate = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18pnng0lv5z6kpp8hnki0agdxx979iq6hxkfkglsyqzmir22lz2i"; type = "gem"; }; version = "1.0.5"; }; cocoapods-downloader = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ldnwwsx44i2xsdmsmyz9xrar19lfy5s5xslvral1p3674dvwvmv"; type = "gem"; }; version = "2.1"; }; cocoapods-plugins = { - dependencies = ["nap"]; + dependencies = [ "nap" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16na82sfyc8801qs1n22nwq486s4j7yj6rj7fcp8cbxmj371fpbj"; type = "gem"; }; version = "1.0.0"; }; cocoapods-search = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12amy0nknv09bvzix8bkmcjn996c50c4ms20v2dl7v8rcw73n4qv"; type = "gem"; }; version = "1.0.1"; }; cocoapods-trunk = { - dependencies = ["nap" "netrc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "nap" + "netrc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cgdx7z9psxxrsa13fk7qc9i6jskrwcafhrdz94avzia2y6dlnsz"; type = "gem"; }; version = "1.6.0"; }; cocoapods-try = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znyp625rql37ivb5rk9fk9564cmax8icxfr041ysivpdrn98nql"; type = "gem"; }; @@ -175,37 +225,37 @@ }; colored2 = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jlbqa9q4mvrm73aw9mxh23ygzbjiqwisl32d8szfb5fxvbjng5i"; type = "gem"; }; version = "3.1.2"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; connection_pool = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; drb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h5kbj9hvg5hb3c7l425zpds0vb42phvln2knab8nmazg2zp5m79"; type = "gem"; }; @@ -213,38 +263,38 @@ }; escape = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sa1xkfc9jvkwyw1jbz3jhkq0ms1zrvswi6mmfiwcisg5fp497z4"; type = "gem"; }; version = "0.0.4"; }; ethon = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17ix0mijpsy3y0c6ywrk5ibarmvqzjsirjyprpsy3hwax8fdm85v"; type = "gem"; }; version = "0.16.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; fourflusher = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1afabh3g3gwj0ad53fs62waks815xcckf7pkci76l6vrghffcg8v"; type = "gem"; }; @@ -252,7 +302,7 @@ }; fuzzy_match = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19gw1ifsgfrv7xdi6n61658vffgm1867f4xdqfswb2b5h6alzpmm"; type = "gem"; }; @@ -260,78 +310,78 @@ }; gh_inspector = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f8r9byajj3bi2c7c5sqrc7m0zrv3nblfcd4782lw5l73cbsgk04"; type = "gem"; }; version = "1.1.3"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k31wcgnvcvd14snz0pfqj976zv6drfsnq6x8acz10fiyms9l8nw"; type = "gem"; }; version = "1.14.6"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03q7kbadhbyfnz21abv2b9dyqnjvxpd51ppqihg40rrimw1vm6id"; type = "gem"; }; version = "2.7.6"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n1akmc6bibkbxkzm1p1wmfb4n9vv397knkgz0ffykb3h1d7kdix"; type = "gem"; }; version = "5.25.1"; }; molinillo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p846facmh1j5xmbrpgzadflspvk7bzs3sykrh5s7qi4cdqz5gzg"; type = "gem"; }; version = "0.8.0"; }; nanaimo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08q73nchv8cpk28h1sdnf5z6a862fcf4mxy1d58z25xb3dankw7s"; type = "gem"; }; @@ -339,7 +389,7 @@ }; nap = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xm5xssxk5s03wjarpipfm39qmgxsalb46v1prsis14x1xk935ll"; type = "gem"; }; @@ -347,90 +397,97 @@ }; netrc = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gzfmcywp1da8nzfqsql2zqi648mfnx6qwkig3cv36n9m0yy676y"; type = "gem"; }; version = "0.11.0"; }; nkf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09piyp2pd74klb9wcn0zw4mb5l0k9wzwppxggxi1yi95l2ym3hgv"; type = "gem"; }; version = "0.2.0"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1f3knlwfwm05sfbaihrxm4g772b79032q14c16q4b38z8bi63qcb"; type = "gem"; }; version = "4.0.7"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j9p66pmfgxnzp76ksssyfyqqrg7281dyi3xyknl3wwraaw7a66p"; type = "gem"; }; version = "3.3.9"; }; ruby-macho = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jgmhj4srl7cck1ipbjys6q4klcs473gq90bm59baw4j1wpfaxch"; type = "gem"; }; version = "2.5.1"; }; securerandom = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1phv6kh417vkanhssbjr960c0gfqvf8z7d3d9fd2yvd41q64bw4q"; type = "gem"; }; version = "0.3.1"; }; typhoeus = { - dependencies = ["ethon"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ethon" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0z7gamf6s83wy0yqms3bi4srirn3fc0lc7n65lqanidxcj1xn5qw"; type = "gem"; }; version = "1.4.1"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; xcodeproj = { - dependencies = ["CFPropertyList" "atomos" "claide" "colored2" "nanaimo" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "CFPropertyList" + "atomos" + "claide" + "colored2" + "nanaimo" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1lslz1kfb8jnd1ilgg02qx0p0y6yiq8wwk84mgg2ghh58lxsgiwc"; type = "gem"; }; diff --git a/pkgs/development/tools/cocogitto/default.nix b/pkgs/development/tools/cocogitto/default.nix index 6cf8f0baf956c7..4b0b7d5eb433c2 100644 --- a/pkgs/development/tools/cocogitto/default.nix +++ b/pkgs/development/tools/cocogitto/default.nix @@ -1,4 +1,11 @@ -{ lib, rustPlatform, fetchFromGitHub, installShellFiles, stdenv, libgit2 }: +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + libgit2, +}: rustPlatform.buildRustPackage rec { pname = "cocogitto"; diff --git a/pkgs/development/tools/comby/default.nix b/pkgs/development/tools/comby/default.nix index 49532070b2b4ee..ad072ca9ce3f68 100644 --- a/pkgs/development/tools/comby/default.nix +++ b/pkgs/development/tools/comby/default.nix @@ -1,17 +1,24 @@ -{ ocamlPackages -, fetchFromGitHub -, lib -, zlib -, pkg-config -, cacert -, gmp -, libev -, autoconf -, sqlite -, stdenv +{ + ocamlPackages, + fetchFromGitHub, + lib, + zlib, + pkg-config, + cacert, + gmp, + libev, + autoconf, + sqlite, + stdenv, }: let - mkCombyPackage = { pname, extraBuildInputs ? [ ], extraNativeInputs ? [ ], preBuild ? "" }: + mkCombyPackage = + { + pname, + extraBuildInputs ? [ ], + extraNativeInputs ? [ ], + preBuild ? "", + }: ocamlPackages.buildDunePackage rec { inherit pname preBuild; version = "1.8.1"; @@ -54,7 +61,10 @@ let }; combyKernel = mkCombyPackage { pname = "comby-kernel"; }; - combySemantic = mkCombyPackage { pname = "comby-semantic"; extraBuildInputs = [ ocamlPackages.cohttp-lwt-unix ]; }; + combySemantic = mkCombyPackage { + pname = "comby-semantic"; + extraBuildInputs = [ ocamlPackages.cohttp-lwt-unix ]; + }; in mkCombyPackage { pname = "comby"; @@ -69,32 +79,36 @@ mkCombyPackage { rm test/common/{test_cli_list,test_cli_helper,test_cli}.ml ''; - extraBuildInputs = [ - zlib - gmp - libev - sqlite - ocamlPackages.shell # This input must appear before `parany` or any other input that propagates `ocamlnet` - ocamlPackages.lwt - ocamlPackages.patience_diff - ocamlPackages.toml - ocamlPackages.cohttp-lwt-unix - ocamlPackages.textutils - ocamlPackages.jst-config - ocamlPackages.parany - ocamlPackages.conduit-lwt-unix - ocamlPackages.lwt_react - ocamlPackages.tar-unix - ocamlPackages.tls - ocamlPackages.ppx_jane - ocamlPackages.ppx_expect - ocamlPackages.dune-configurator - combyKernel - combySemantic - ] ++ (if !stdenv.hostPlatform.isAarch32 && !stdenv.hostPlatform.isAarch64 then - [ ocamlPackages.hack_parallel ] - else - [ ]); + extraBuildInputs = + [ + zlib + gmp + libev + sqlite + ocamlPackages.shell # This input must appear before `parany` or any other input that propagates `ocamlnet` + ocamlPackages.lwt + ocamlPackages.patience_diff + ocamlPackages.toml + ocamlPackages.cohttp-lwt-unix + ocamlPackages.textutils + ocamlPackages.jst-config + ocamlPackages.parany + ocamlPackages.conduit-lwt-unix + ocamlPackages.lwt_react + ocamlPackages.tar-unix + ocamlPackages.tls + ocamlPackages.ppx_jane + ocamlPackages.ppx_expect + ocamlPackages.dune-configurator + combyKernel + combySemantic + ] + ++ ( + if !stdenv.hostPlatform.isAarch32 && !stdenv.hostPlatform.isAarch64 then + [ ocamlPackages.hack_parallel ] + else + [ ] + ); extraNativeInputs = [ autoconf diff --git a/pkgs/development/tools/compass/default.nix b/pkgs/development/tools/compass/default.nix index 8b8752d1c0d8c2..c8e214c1cffa4b 100644 --- a/pkgs/development/tools/compass/default.nix +++ b/pkgs/development/tools/compass/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerEnv, bundlerUpdateScript, ruby }: +{ + lib, + bundlerEnv, + bundlerUpdateScript, + ruby, +}: bundlerEnv { pname = "compass"; @@ -11,10 +16,14 @@ bundlerEnv { meta = with lib; { description = "Stylesheet Authoring Environment that makes your website design simpler to implement and easier to maintain"; - homepage = "https://github.com/Compass/compass"; - license = with licenses; mit; - maintainers = with maintainers; [ offline manveru nicknovitski ]; + homepage = "https://github.com/Compass/compass"; + license = with licenses; mit; + maintainers = with maintainers; [ + offline + manveru + nicknovitski + ]; mainProgram = "compass"; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/compass/gemset.nix b/pkgs/development/tools/compass/gemset.nix index 2b1bd604254bf4..51a595f3a4221d 100644 --- a/pkgs/development/tools/compass/gemset.nix +++ b/pkgs/development/tools/compass/gemset.nix @@ -1,93 +1,103 @@ { chunky_png = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znw5x86hmm9vfhidwdsijz8m38pqgmv98l9ryilvky0aldv7mc9"; type = "gem"; }; version = "1.4.0"; }; compass = { - dependencies = ["chunky_png" "compass-core" "compass-import-once" "rb-fsevent" "rb-inotify" "sass"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "chunky_png" + "compass-core" + "compass-import-once" + "rb-fsevent" + "rb-inotify" + "sass" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lfi83w8z75czr0pf0rmj9hda22082h3cmvczl8r1ma9agf88y2c"; type = "gem"; }; version = "1.0.3"; }; compass-core = { - dependencies = ["multi_json" "sass"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "multi_json" + "sass" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yaspqwdmzwdcqviclbs3blq7an16pysrfzylz8q1gxmmd6bpj3a"; type = "gem"; }; version = "1.0.3"; }; compass-import-once = { - dependencies = ["sass"]; - groups = ["default"]; - platforms = []; + dependencies = [ "sass" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bn7gwbfz7jvvdd0qdfqlx67fcb83gyvxqc7dr9fhcnks3z8z5rq"; type = "gem"; }; version = "1.0.5"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ssxcywmb3flxsjdg13is6k01807zgzasdhj4j48dm7ac59cmksn"; type = "gem"; }; version = "1.15.4"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; rb-fsevent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qsx9c4jr11vr3a9s5j83avczx9qn9rjaf32gxpc2v451hvbc0is"; type = "gem"; }; version = "0.11.0"; }; rb-inotify = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jm76h8f8hji38z3ggf4bzi8vps6p7sagxn3ab57qc0xyga64005"; type = "gem"; }; version = "0.10.1"; }; sass = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kfpcwh8dgw4lc81qglkvjl73689jy3g7196zkxm4fpskg1p5lkw"; type = "gem"; }; diff --git a/pkgs/development/tools/continuous-integration/buildbot/default.nix b/pkgs/development/tools/continuous-integration/buildbot/default.nix index 07b18f6923130f..6a5da56092d836 100644 --- a/pkgs/development/tools/continuous-integration/buildbot/default.nix +++ b/pkgs/development/tools/continuous-integration/buildbot/default.nix @@ -1,7 +1,8 @@ -{ lib -, newScope -, python3 -, recurseIntoAttrs +{ + lib, + newScope, + python3, + recurseIntoAttrs, }: # Take packages from self first, then python.pkgs (and secondarily pkgs) lib.makeScope (self: newScope (self.python.pkgs // self)) (self: { @@ -17,7 +18,15 @@ lib.makeScope (self: newScope (self.python.pkgs // self)) (self: { buildbot-ui = self.buildbot.withPlugins (with self.buildbot-plugins; [ www ]); - buildbot-full = self.buildbot.withPlugins (with self.buildbot-plugins; [ - www console-view waterfall-view grid-view wsgi-dashboards badges - ]); + buildbot-full = self.buildbot.withPlugins ( + with self.buildbot-plugins; + [ + www + console-view + waterfall-view + grid-view + wsgi-dashboards + badges + ] + ); }) diff --git a/pkgs/development/tools/continuous-integration/buildbot/master.nix b/pkgs/development/tools/continuous-integration/buildbot/master.nix index 965bb2e936f267..6a8dc5b2379064 100644 --- a/pkgs/development/tools/continuous-integration/buildbot/master.nix +++ b/pkgs/development/tools/continuous-integration/buildbot/master.nix @@ -1,75 +1,78 @@ -{ lib -, stdenv -, buildPythonApplication -, fetchFromGitHub -, makeWrapper -# Tie withPlugins through the fixed point here, so it will receive an -# overridden version properly -, buildbot -, pythonOlder -, python -, twisted -, jinja2 -, msgpack -, zope-interface -, sqlalchemy -, alembic -, python-dateutil -, txaio -, autobahn -, pyjwt -, pyyaml -, treq -, txrequests -, pypugjs -, boto3 -, moto -, markdown -, lz4 -, brotli -, zstandard -, setuptools-trial -, buildbot-worker -, buildbot-plugins -, buildbot-pkg -, parameterized -, git -, openssh -, setuptools -, croniter -, importlib-resources -, packaging -, unidiff -, glibcLocales -, nixosTests +{ + lib, + stdenv, + buildPythonApplication, + fetchFromGitHub, + makeWrapper, + # Tie withPlugins through the fixed point here, so it will receive an + # overridden version properly + buildbot, + pythonOlder, + python, + twisted, + jinja2, + msgpack, + zope-interface, + sqlalchemy, + alembic, + python-dateutil, + txaio, + autobahn, + pyjwt, + pyyaml, + treq, + txrequests, + pypugjs, + boto3, + moto, + markdown, + lz4, + brotli, + zstandard, + setuptools-trial, + buildbot-worker, + buildbot-plugins, + buildbot-pkg, + parameterized, + git, + openssh, + setuptools, + croniter, + importlib-resources, + packaging, + unidiff, + glibcLocales, + nixosTests, }: let - withPlugins = plugins: buildPythonApplication { - pname = "${buildbot.pname}-with-plugins"; - inherit (buildbot) version; - format = "other"; - - dontUnpack = true; - dontBuild = true; - doCheck = false; - - nativeBuildInputs = [ - makeWrapper - ]; - - propagatedBuildInputs = plugins ++ buildbot.propagatedBuildInputs; - - installPhase = '' - makeWrapper ${buildbot}/bin/buildbot $out/bin/buildbot \ - --prefix PYTHONPATH : "${buildbot}/${python.sitePackages}:$PYTHONPATH" - ln -sfv ${buildbot}/lib $out/lib - ''; - - passthru = buildbot.passthru // { - withPlugins = morePlugins: withPlugins (morePlugins ++ plugins); + withPlugins = + plugins: + buildPythonApplication { + pname = "${buildbot.pname}-with-plugins"; + inherit (buildbot) version; + format = "other"; + + dontUnpack = true; + dontBuild = true; + doCheck = false; + + nativeBuildInputs = [ + makeWrapper + ]; + + propagatedBuildInputs = plugins ++ buildbot.propagatedBuildInputs; + + installPhase = '' + makeWrapper ${buildbot}/bin/buildbot $out/bin/buildbot \ + --prefix PYTHONPATH : "${buildbot}/${python.sitePackages}:$PYTHONPATH" + ln -sfv ${buildbot}/lib $out/lib + ''; + + passthru = buildbot.passthru // { + withPlugins = morePlugins: withPlugins (morePlugins ++ plugins); + }; }; - }; in buildPythonApplication rec { pname = "buildbot"; @@ -92,28 +95,29 @@ buildPythonApplication rec { "twisted" ]; - propagatedBuildInputs = [ - # core - twisted - jinja2 - msgpack - zope-interface - sqlalchemy - alembic - python-dateutil - txaio - autobahn - pyjwt - pyyaml - setuptools - croniter - importlib-resources - packaging - unidiff - treq - brotli - zstandard - ] + propagatedBuildInputs = + [ + # core + twisted + jinja2 + msgpack + zope-interface + sqlalchemy + alembic + python-dateutil + txaio + autobahn + pyjwt + pyyaml + setuptools + croniter + importlib-resources + packaging + unidiff + treq + brotli + zstandard + ] # tls ++ twisted.optional-dependencies.tls; @@ -155,14 +159,16 @@ buildPythonApplication rec { export PATH="$out/bin:$PATH" ''; - passthru = { - inherit withPlugins python; - updateScript = ./update.sh; - } // lib.optionalAttrs stdenv.hostPlatform.isLinux { - tests = { - inherit (nixosTests) buildbot; + passthru = + { + inherit withPlugins python; + updateScript = ./update.sh; + } + // lib.optionalAttrs stdenv.hostPlatform.isLinux { + tests = { + inherit (nixosTests) buildbot; + }; }; - }; meta = with lib; { description = "Open-source continuous integration framework for automating software build, test, and release processes"; diff --git a/pkgs/development/tools/continuous-integration/buildbot/pkg.nix b/pkgs/development/tools/continuous-integration/buildbot/pkg.nix index 3f982a2a36a4ca..44c4e9591116d5 100644 --- a/pkgs/development/tools/continuous-integration/buildbot/pkg.nix +++ b/pkgs/development/tools/continuous-integration/buildbot/pkg.nix @@ -1,4 +1,9 @@ -{ lib, buildPythonPackage, isPy3k, buildbot }: +{ + lib, + buildPythonPackage, + isPy3k, + buildbot, +}: buildPythonPackage { pname = "buildbot_pkg"; diff --git a/pkgs/development/tools/continuous-integration/buildbot/plugins.nix b/pkgs/development/tools/continuous-integration/buildbot/plugins.nix index 7da50409cbd706..1faf0e56eafed9 100644 --- a/pkgs/development/tools/continuous-integration/buildbot/plugins.nix +++ b/pkgs/development/tools/continuous-integration/buildbot/plugins.nix @@ -1,4 +1,14 @@ -{ lib, buildPythonPackage, fetchurl, callPackage, mock, cairosvg, klein, jinja2, buildbot-pkg }: +{ + lib, + buildPythonPackage, + fetchurl, + callPackage, + mock, + cairosvg, + klein, + jinja2, + buildbot-pkg, +}: { # this is exposed for potential plugins to use and for nix-update inherit buildbot-pkg; @@ -16,7 +26,10 @@ sed -i "s/'buildbot'//" setup.py ''; - buildInputs = [ buildbot-pkg mock ]; + buildInputs = [ + buildbot-pkg + mock + ]; # No tests doCheck = false; @@ -127,7 +140,11 @@ }; buildInputs = [ buildbot-pkg ]; - propagatedBuildInputs = [ cairosvg klein jinja2 ]; + propagatedBuildInputs = [ + cairosvg + klein + jinja2 + ]; # No tests doCheck = false; diff --git a/pkgs/development/tools/continuous-integration/buildbot/worker.nix b/pkgs/development/tools/continuous-integration/buildbot/worker.nix index 8bbe3a241b0ed9..0ecb0228e5d865 100644 --- a/pkgs/development/tools/continuous-integration/buildbot/worker.nix +++ b/pkgs/development/tools/continuous-integration/buildbot/worker.nix @@ -1,23 +1,24 @@ -{ lib -, buildPythonPackage -, buildbot -, stdenv - -# patch -, coreutils - -# propagates -, autobahn -, msgpack -, twisted - -# tests -, parameterized -, psutil -, setuptools-trial - -# passthru -, nixosTests +{ + lib, + buildPythonPackage, + buildbot, + stdenv, + + # patch + coreutils, + + # propagates + autobahn, + msgpack, + twisted, + + # tests + parameterized, + psutil, + setuptools-trial, + + # passthru + nixosTests, }: buildPythonPackage ({ diff --git a/pkgs/development/tools/continuous-integration/buildkite-test-collector-rust/default.nix b/pkgs/development/tools/continuous-integration/buildkite-test-collector-rust/default.nix index 84c62e55685830..5258908cdef4da 100644 --- a/pkgs/development/tools/continuous-integration/buildkite-test-collector-rust/default.nix +++ b/pkgs/development/tools/continuous-integration/buildkite-test-collector-rust/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, stdenv -, Security -, nix-update-script +{ + lib, + fetchFromGitHub, + rustPlatform, + stdenv, + Security, + nix-update-script, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/development/tools/continuous-integration/drone/default.nix b/pkgs/development/tools/continuous-integration/drone/default.nix index e2caa3c8097b22..e039a6ba910f7f 100644 --- a/pkgs/development/tools/continuous-integration/drone/default.nix +++ b/pkgs/development/tools/continuous-integration/drone/default.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildGoModule -, enableUnfree ? true +{ + lib, + fetchFromGitHub, + buildGoModule, + enableUnfree ? true, }: buildGoModule rec { @@ -17,7 +18,10 @@ buildGoModule rec { vendorHash = "sha256-9jzhoFN7aAUgPxENPuGYR41gXLzSv1VtnTPB38heVlI="; - tags = lib.optionals (!enableUnfree) [ "oss" "nolimit" ]; + tags = lib.optionals (!enableUnfree) [ + "oss" + "nolimit" + ]; doCheck = false; @@ -25,7 +29,10 @@ buildGoModule rec { description = "Continuous Integration platform built on container technology"; mainProgram = "drone-server"; homepage = "https://github.com/harness/drone"; - maintainers = with maintainers; [ vdemeester techknowlogick ]; + maintainers = with maintainers; [ + vdemeester + techknowlogick + ]; license = with licenses; if enableUnfree then unfreeRedistributable else asl20; }; } diff --git a/pkgs/development/tools/continuous-integration/hci/default.nix b/pkgs/development/tools/continuous-integration/hci/default.nix index 6da44a4786cd04..a1ce297d14f300 100644 --- a/pkgs/development/tools/continuous-integration/hci/default.nix +++ b/pkgs/development/tools/continuous-integration/hci/default.nix @@ -1,23 +1,33 @@ -{ crun, haskell, haskellPackages, lib, makeWrapper, stdenv, emptyDirectory }: +{ + crun, + haskell, + haskellPackages, + lib, + makeWrapper, + stdenv, + emptyDirectory, +}: let - inherit (haskell.lib.compose) overrideCabal addBuildTools justStaticExecutables appendConfigureFlags; + inherit (haskell.lib.compose) + overrideCabal + addBuildTools + justStaticExecutables + appendConfigureFlags + ; inherit (lib) makeBinPath; bundledBins = lib.optional stdenv.hostPlatform.isLinux crun; overrides = old: { - hercules-ci-agent = - overrideCabal - (o: { - isLibrary = true; - isExecutable = false; - postInstall = ""; # ignore completions - enableSharedExecutables = false; - buildTarget = "lib:hercules-ci-agent hercules-ci-agent-unit-tests"; - configureFlags = o.configureFlags or [ ] ++ [ - "--bindir=${emptyDirectory}/hercules-ci-built-without-binaries/no-bin" - ]; - }) - old.hercules-ci-agent; + hercules-ci-agent = overrideCabal (o: { + isLibrary = true; + isExecutable = false; + postInstall = ""; # ignore completions + enableSharedExecutables = false; + buildTarget = "lib:hercules-ci-agent hercules-ci-agent-unit-tests"; + configureFlags = o.configureFlags or [ ] ++ [ + "--bindir=${emptyDirectory}/hercules-ci-built-without-binaries/no-bin" + ]; + }) old.hercules-ci-agent; }; pkg = @@ -31,12 +41,23 @@ let makeWrapper $out/libexec/hci $out/bin/hci --prefix PATH : ${lib.escapeShellArg (makeBinPath bundledBins)} ''; }) - (addBuildTools [ makeWrapper ] - # TODO: Erroneous references to GHC on aarch64-darwin: https://github.com/NixOS/nixpkgs/issues/318013 - ((if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 then lib.id else haskell.lib.compose.justStaticExecutables) - (haskellPackages.hercules-ci-cli.override overrides))); -in pkg // { - meta = pkg.meta // { - position = toString ./default.nix + ":1"; - }; - } + ( + addBuildTools [ makeWrapper ] + # TODO: Erroneous references to GHC on aarch64-darwin: https://github.com/NixOS/nixpkgs/issues/318013 + ( + ( + if stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64 then + lib.id + else + haskell.lib.compose.justStaticExecutables + ) + (haskellPackages.hercules-ci-cli.override overrides) + ) + ); +in +pkg +// { + meta = pkg.meta // { + position = toString ./default.nix + ":1"; + }; +} diff --git a/pkgs/development/tools/continuous-integration/hercules-ci-agent/default.nix b/pkgs/development/tools/continuous-integration/hercules-ci-agent/default.nix index a01febb9113d3f..0fd5e62e414ecd 100644 --- a/pkgs/development/tools/continuous-integration/hercules-ci-agent/default.nix +++ b/pkgs/development/tools/continuous-integration/hercules-ci-agent/default.nix @@ -15,62 +15,78 @@ let inherit (haskell.lib.compose) overrideCabal addBuildTools justStaticExecutables; inherit (lib) makeBinPath; - bundledBins = [ gnutar gzip git openssh ] ++ lib.optional stdenv.hostPlatform.isLinux crun; + bundledBins = [ + gnutar + gzip + git + openssh + ] ++ lib.optional stdenv.hostPlatform.isLinux crun; pkg = # justStaticExecutables is needed due to https://github.com/NixOS/nix/issues/2990 - overrideCabal - (o: { - postInstall = '' - ${o.postInstall or ""} - ${lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' - remove-references-to -t ${haskellPackages.hercules-ci-cnix-expr} $out/bin/hercules-ci-agent - remove-references-to -t ${haskellPackages.hercules-ci-cnix-expr} $out/bin/hercules-ci-agent-worker - ''} - mkdir -p $out/libexec - mv $out/bin/hercules-ci-agent $out/libexec - makeWrapper $out/libexec/hercules-ci-agent $out/bin/hercules-ci-agent --prefix PATH : ${lib.escapeShellArg (makeBinPath bundledBins)} - ''; - }) - (addBuildTools [ makeBinaryWrapper ] (justStaticExecutables haskellPackages.hercules-ci-agent)); -in pkg.overrideAttrs (finalAttrs: o: { + overrideCabal (o: { + postInstall = '' + ${o.postInstall or ""} + ${lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' + remove-references-to -t ${haskellPackages.hercules-ci-cnix-expr} $out/bin/hercules-ci-agent + remove-references-to -t ${haskellPackages.hercules-ci-cnix-expr} $out/bin/hercules-ci-agent-worker + ''} + mkdir -p $out/libexec + mv $out/bin/hercules-ci-agent $out/libexec + makeWrapper $out/libexec/hercules-ci-agent $out/bin/hercules-ci-agent --prefix PATH : ${lib.escapeShellArg (makeBinPath bundledBins)} + ''; + }) (addBuildTools [ makeBinaryWrapper ] (justStaticExecutables haskellPackages.hercules-ci-agent)); +in +pkg.overrideAttrs ( + finalAttrs: o: { meta = o.meta // { position = toString ./default.nix + ":1"; }; passthru = o.passthru // { - tests = { - version = testers.testVersion { - package = finalAttrs.finalPackage; - command = "hercules-ci-agent --help"; - }; - } // lib.optionalAttrs (stdenv.hostPlatform.isLinux) { - # Does not test the package, but evaluation of the related NixOS module. - nixos-simple-config = (nixos { - boot.loader.grub.enable = false; - fileSystems."/".device = "bogus"; - services.hercules-ci-agent.enable = true; - # Dummy value for testing only. - system.stateVersion = lib.trivial.release; # TEST ONLY - }).config.system.build.toplevel; - - nixos-many-options-config = (nixos ({ pkgs, ... }: { - boot.loader.grub.enable = false; - fileSystems."/".device = "bogus"; - services.hercules-ci-agent = { - enable = true; - package = pkgs.hercules-ci-agent; - settings = { - workDirectory = "/var/tmp/hci"; - binaryCachesPath = "/var/keys/binary-caches.json"; - labels.foo.bar.baz = "qux"; - labels.qux = ["q" "u"]; - apiBaseUrl = "https://hci.dev.biz.example.com"; - concurrentTasks = 42; - }; + tests = + { + version = testers.testVersion { + package = finalAttrs.finalPackage; + command = "hercules-ci-agent --help"; }; - # Dummy value for testing only. - system.stateVersion = lib.trivial.release; # TEST ONLY - })).config.system.build.toplevel; - }; + } + // lib.optionalAttrs (stdenv.hostPlatform.isLinux) { + # Does not test the package, but evaluation of the related NixOS module. + nixos-simple-config = + (nixos { + boot.loader.grub.enable = false; + fileSystems."/".device = "bogus"; + services.hercules-ci-agent.enable = true; + # Dummy value for testing only. + system.stateVersion = lib.trivial.release; # TEST ONLY + }).config.system.build.toplevel; + + nixos-many-options-config = + (nixos ( + { pkgs, ... }: + { + boot.loader.grub.enable = false; + fileSystems."/".device = "bogus"; + services.hercules-ci-agent = { + enable = true; + package = pkgs.hercules-ci-agent; + settings = { + workDirectory = "/var/tmp/hci"; + binaryCachesPath = "/var/keys/binary-caches.json"; + labels.foo.bar.baz = "qux"; + labels.qux = [ + "q" + "u" + ]; + apiBaseUrl = "https://hci.dev.biz.example.com"; + concurrentTasks = 42; + }; + }; + # Dummy value for testing only. + system.stateVersion = lib.trivial.release; # TEST ONLY + } + )).config.system.build.toplevel; + }; }; - }) + } +) diff --git a/pkgs/development/tools/continuous-integration/woodpecker/agent.nix b/pkgs/development/tools/continuous-integration/woodpecker/agent.nix index 5bbc4cf99ceaa7..6b03083597bedf 100644 --- a/pkgs/development/tools/continuous-integration/woodpecker/agent.nix +++ b/pkgs/development/tools/continuous-integration/woodpecker/agent.nix @@ -4,7 +4,13 @@ let in buildGoModule { pname = "woodpecker-agent"; - inherit (common) version src ldflags postInstall vendorHash; + inherit (common) + version + src + ldflags + postInstall + vendorHash + ; subPackages = "cmd/agent"; diff --git a/pkgs/development/tools/continuous-integration/woodpecker/cli.nix b/pkgs/development/tools/continuous-integration/woodpecker/cli.nix index 2121258f3c048f..b6eb1cc68849a1 100644 --- a/pkgs/development/tools/continuous-integration/woodpecker/cli.nix +++ b/pkgs/development/tools/continuous-integration/woodpecker/cli.nix @@ -4,7 +4,13 @@ let in buildGoModule { pname = "woodpecker-cli"; - inherit (common) version src ldflags postInstall vendorHash; + inherit (common) + version + src + ldflags + postInstall + vendorHash + ; subPackages = "cmd/cli"; diff --git a/pkgs/development/tools/continuous-integration/woodpecker/common.nix b/pkgs/development/tools/continuous-integration/woodpecker/common.nix index 5c6db6f48020f5..72fa9025de1347 100644 --- a/pkgs/development/tools/continuous-integration/woodpecker/common.nix +++ b/pkgs/development/tools/continuous-integration/woodpecker/common.nix @@ -44,6 +44,10 @@ in homepage = "https://woodpecker-ci.org/"; changelog = "https://github.com/woodpecker-ci/woodpecker/blob/v${version}/CHANGELOG.md"; license = licenses.asl20; - maintainers = with maintainers; [ ambroisie techknowlogick adamcstephens ]; + maintainers = with maintainers; [ + ambroisie + techknowlogick + adamcstephens + ]; }; } diff --git a/pkgs/development/tools/continuous-integration/woodpecker/server.nix b/pkgs/development/tools/continuous-integration/woodpecker/server.nix index fb232a19ba2e59..2e4eb98bae8f98 100644 --- a/pkgs/development/tools/continuous-integration/woodpecker/server.nix +++ b/pkgs/development/tools/continuous-integration/woodpecker/server.nix @@ -4,7 +4,13 @@ let in buildGoModule { pname = "woodpecker-server"; - inherit (common) version src ldflags postInstall vendorHash; + inherit (common) + version + src + ldflags + postInstall + vendorHash + ; subPackages = "cmd/server"; diff --git a/pkgs/development/tools/corundum/default.nix b/pkgs/development/tools/corundum/default.nix index 62d00cbc3768be..8864f859a583d1 100644 --- a/pkgs/development/tools/corundum/default.nix +++ b/pkgs/development/tools/corundum/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "corundum"; @@ -9,9 +13,12 @@ bundlerApp { meta = with lib; { description = "Tool and libraries for maintaining Ruby gems"; - homepage = "https://github.com/nyarly/corundum"; - license = licenses.mit; - maintainers = with maintainers; [ nyarly nicknovitski ]; - platforms = platforms.unix; + homepage = "https://github.com/nyarly/corundum"; + license = licenses.mit; + maintainers = with maintainers; [ + nyarly + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/corundum/gemset.nix b/pkgs/development/tools/corundum/gemset.nix index a6ec2f2b9b9106..01a2e5c7551fa2 100644 --- a/pkgs/development/tools/corundum/gemset.nix +++ b/pkgs/development/tools/corundum/gemset.nix @@ -1,7 +1,7 @@ { calibrate = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17kmlss7db70pjwdbbhag7mnixh8wasdq6n1v8663x50z9c7n2ng"; type = "gem"; }; @@ -9,7 +9,7 @@ }; caliph = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08d07n4m4yh1h9icq6n9dkw4jwgdmgd638f15mxr2pvqp4wycsnr"; type = "gem"; }; @@ -17,7 +17,7 @@ }; corundum = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1y6shjrqaqyh14a1r4ic660g6jnq4abdrx9imglyalzyrlrwbsxq"; type = "gem"; }; @@ -25,7 +25,7 @@ }; diff-lcs = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18w22bjz424gzafv6nzv98h0aqkwz3d9xhm7cbr1wfbyas8zayza"; type = "gem"; }; @@ -33,7 +33,7 @@ }; docile = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0m8j31whq7bm5ljgmsrlfkiqvacrw6iz9wq10r3gwrv5785y8gjx"; type = "gem"; }; @@ -41,7 +41,7 @@ }; json = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01v6jjpvh3gnq6sgllpfqahlgxzj50ailwhj9b3cd20hi2dx0vxp"; type = "gem"; }; @@ -49,7 +49,7 @@ }; mattock = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02d6igwr4sfj4jnky8d5h0rm2cc665k1bqz7sj4khzvr18nk3ai6"; type = "gem"; }; @@ -57,7 +57,7 @@ }; paint = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fcn7cfrhbl4nl95fmcd67q33h7bl3iafsafs6w9yj4nqzagz1yc"; type = "gem"; }; @@ -65,7 +65,7 @@ }; rake = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jcabbgnjc788chx31sihc5pgbqnlc1c75wakmqlbjdm8jns2m9b"; type = "gem"; }; @@ -73,7 +73,7 @@ }; rspec = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nd50hycab2a2vdah9lxi585g8f63jxjvmzmxqyln51grxwx9hzb"; type = "gem"; }; @@ -81,7 +81,7 @@ }; rspec-core = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18np8wyw2g79waclpaacba6nd7x60ixg07ncya0j0qj1z9b37grd"; type = "gem"; }; @@ -89,7 +89,7 @@ }; rspec-expectations = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "028ifzf9mqp3kxx40q1nbwj40g72g9zk0wr78l146phblkv96w0a"; type = "gem"; }; @@ -97,7 +97,7 @@ }; rspec-mocks = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nv6jkxy24sag1i9w9wi3850k6skk2fm6yhcrgnmlz6vmwxvizp8"; type = "gem"; }; @@ -105,7 +105,7 @@ }; rspec-support = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "050paqqpsml8w88nf4a15zbbj3vvm471zpv73sjfdnz7w21wnypb"; type = "gem"; }; @@ -113,7 +113,7 @@ }; simplecov = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1r9fnsnsqj432cmrpafryn8nif3x0qg9mdnvrcf0wr01prkdlnww"; type = "gem"; }; @@ -121,7 +121,7 @@ }; simplecov-html = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f3psphismgp6jp1fxxz09zbswh7m2xxxr6gqlzdh7sgv415clvm"; type = "gem"; }; @@ -129,7 +129,7 @@ }; simplecov-json = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0x9hr08pkj5d14nfzsn5h8b7ayl6q0xir45dcx5rv2a7g10kzlpp"; type = "gem"; }; @@ -137,7 +137,7 @@ }; tilt = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1is1ayw5049z8pd7slsk870bddyy5g2imp4z78lnvl8qsl8l0s7b"; type = "gem"; }; @@ -145,7 +145,7 @@ }; valise = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1arsbmk2gifrhv244qrld7s3202xrnxy6vlc5gqklg70dpsinbn5"; type = "gem"; }; diff --git a/pkgs/development/tools/cotton/default.nix b/pkgs/development/tools/cotton/default.nix index bc54f31549494c..a8271a144fee87 100644 --- a/pkgs/development/tools/cotton/default.nix +++ b/pkgs/development/tools/cotton/default.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, CoreServices +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + CoreServices, }: rustPlatform.buildRustPackage rec { @@ -31,6 +32,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "cotton"; homepage = "https://github.com/danielhuang/cotton"; license = licenses.gpl3Only; - maintainers = with maintainers; [ dit7ya figsoda ]; + maintainers = with maintainers; [ + dit7ya + figsoda + ]; }; } diff --git a/pkgs/development/tools/database/cdb/default.nix b/pkgs/development/tools/database/cdb/default.nix index b9ebba55477450..3da8c8855bc358 100644 --- a/pkgs/development/tools/database/cdb/default.nix +++ b/pkgs/development/tools/database/cdb/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchurl, fetchFromGitHub }: +{ + stdenv, + lib, + fetchurl, + fetchFromGitHub, +}: let version = "0.75"; @@ -15,7 +20,8 @@ let sha256 = "1y0ivviy58i0pmavhvrpznc4yjigjknff298gnw9rkg5wxm0gbbq"; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "cdb"; inherit version; @@ -24,7 +30,11 @@ in stdenv.mkDerivation { inherit sha256; }; - outputs = [ "bin" "doc" "out" ]; + outputs = [ + "bin" + "doc" + "out" + ]; postPatch = '' # A little patch, borrowed from Archlinux AUR, borrowed from Gentoo Portage diff --git a/pkgs/development/tools/database/dynein/default.nix b/pkgs/development/tools/database/dynein/default.nix index d1a31880e54f47..d48d25f0402640 100644 --- a/pkgs/development/tools/database/dynein/default.nix +++ b/pkgs/development/tools/database/dynein/default.nix @@ -1,8 +1,9 @@ -{ fetchFromGitHub -, lib -, openssl -, pkg-config -, rustPlatform +{ + fetchFromGitHub, + lib, + openssl, + pkg-config, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/development/tools/database/indradb/default.nix b/pkgs/development/tools/database/indradb/default.nix index 29f665d1e12100..87ff3688641aee 100644 --- a/pkgs/development/tools/database/indradb/default.nix +++ b/pkgs/development/tools/database/indradb/default.nix @@ -1,9 +1,10 @@ -{ stdenv -, fetchFromGitHub -, lib -, rustPlatform -, rustfmt -, protobuf +{ + stdenv, + fetchFromGitHub, + lib, + rustPlatform, + rustfmt, + protobuf, }: let src = fetchFromGitHub { @@ -33,7 +34,10 @@ in PROTOC = "${protobuf}/bin/protoc"; - nativeBuildInputs = [ rustfmt rustPlatform.bindgenHook ]; + nativeBuildInputs = [ + rustfmt + rustPlatform.bindgenHook + ]; # test rely on libindradb and it can't be found # failure at https://github.com/indradb/indradb/blob/master/server/tests/plugins.rs#L63 @@ -49,7 +53,10 @@ in PROTOC = "${protobuf}/bin/protoc"; - nativeBuildInputs = [ rustfmt rustPlatform.bindgenHook ]; + nativeBuildInputs = [ + rustfmt + rustPlatform.bindgenHook + ]; buildAndTestSubdir = "client"; }; diff --git a/pkgs/development/tools/database/pgsync/default.nix b/pkgs/development/tools/database/pgsync/default.nix index 7e075784f122d8..d1ae5a11b34a7f 100644 --- a/pkgs/development/tools/database/pgsync/default.nix +++ b/pkgs/development/tools/database/pgsync/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp rec { gemdir = ./.; @@ -9,8 +13,8 @@ bundlerApp rec { meta = with lib; { description = "Sync data from one Postgres database to another (like `pg_dump`/`pg_restore`)"; - homepage = "https://github.com/ankane/pgsync"; - license = with licenses; mit; + homepage = "https://github.com/ankane/pgsync"; + license = with licenses; mit; maintainers = with maintainers; [ fabianhjr ]; }; } diff --git a/pkgs/development/tools/database/pgsync/gemset.nix b/pkgs/development/tools/database/pgsync/gemset.nix index a18ec0613f187e..49b7641f65fa1b 100644 --- a/pkgs/development/tools/database/pgsync/gemset.nix +++ b/pkgs/development/tools/database/pgsync/gemset.nix @@ -1,61 +1,66 @@ { parallel = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07vnk6bb54k4yc06xnwck7php50l09vvlw1ga8wdz0pia461zpzb"; type = "gem"; }; version = "1.22.1"; }; pg = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07m6lxljabw9kyww5k5lgsxsznsm1v5l14r1la09gqka9b5kv3yr"; type = "gem"; }; version = "1.4.6"; }; pgsync = { - dependencies = ["parallel" "pg" "slop" "tty-spinner"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "parallel" + "pg" + "slop" + "tty-spinner" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1f2lzsa7l88skp18f8w1ch9w8a42pymc48rdaqjrrdgg0126kvj3"; type = "gem"; }; version = "0.7.4"; }; slop = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1iyrjskgxyn8i1679qwkzns85p909aq77cgx2m4fs5ygzysj4hw4"; type = "gem"; }; version = "4.10.1"; }; tty-cursor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j5zw041jgkmn605ya1zc151bxgxl6v192v2i26qhxx7ws2l2lvr"; type = "gem"; }; version = "0.7.1"; }; tty-spinner = { - dependencies = ["tty-cursor"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-cursor" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hh5awmijnzw9flmh5ak610x1d00xiqagxa5mbr63ysggc26y0qf"; type = "gem"; }; diff --git a/pkgs/development/tools/database/prisma-engines/default.nix b/pkgs/development/tools/database/prisma-engines/default.nix index c61bde4f96c3dc..bc296c87e3a3f6 100644 --- a/pkgs/development/tools/database/prisma-engines/default.nix +++ b/pkgs/development/tools/database/prisma-engines/default.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, lib -, openssl -, pkg-config -, protobuf -, rustPlatform -, stdenv +{ + fetchFromGitHub, + lib, + openssl, + pkg-config, + protobuf, + rustPlatform, + stdenv, }: # Updating this package will force an update for prisma. The @@ -48,10 +49,14 @@ rustPlatform.buildRustPackage rec { ''; cargoBuildFlags = [ - "-p" "query-engine" - "-p" "query-engine-node-api" - "-p" "schema-engine-cli" - "-p" "prisma-fmt" + "-p" + "query-engine" + "-p" + "query-engine-node-api" + "-p" + "schema-engine-cli" + "-p" + "prisma-fmt" ]; postInstall = '' @@ -67,7 +72,11 @@ rustPlatform.buildRustPackage rec { license = licenses.asl20; platforms = platforms.unix; mainProgram = "prisma"; - maintainers = with maintainers; [ pimeys tomhoule aqrln ]; + maintainers = with maintainers; [ + pimeys + tomhoule + aqrln + ]; }; } diff --git a/pkgs/development/tools/database/replibyte/default.nix b/pkgs/development/tools/database/replibyte/default.nix index f04a00e881cae1..a71e141362394e 100644 --- a/pkgs/development/tools/database/replibyte/default.nix +++ b/pkgs/development/tools/database/replibyte/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, Security -, SystemConfiguration +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + Security, + SystemConfiguration, }: rustPlatform.buildRustPackage rec { @@ -32,7 +33,12 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security SystemConfiguration ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + ]; cargoBuildFlags = [ "--all-features" ]; diff --git a/pkgs/development/tools/database/sqlitebrowser/default.nix b/pkgs/development/tools/database/sqlitebrowser/default.nix index ec73d534007ad0..bbd3453ce1bada 100644 --- a/pkgs/development/tools/database/sqlitebrowser/default.nix +++ b/pkgs/development/tools/database/sqlitebrowser/default.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, qtbase, qttools, sqlcipher, wrapQtAppsHook, qtmacextras +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtbase, + qttools, + sqlcipher, + wrapQtAppsHook, + qtmacextras, }: stdenv.mkDerivation (finalAttrs: { @@ -19,9 +27,16 @@ stdenv.mkDerivation (finalAttrs: { # but qscintilla is currently in a bit of a mess as some consumers expect a # -qt4 or -qt5 prefix while others do not. # We *really* should get that cleaned up. - buildInputs = [ qtbase sqlcipher ] ++ lib.optional stdenv.hostPlatform.isDarwin qtmacextras; - - nativeBuildInputs = [ cmake qttools wrapQtAppsHook ]; + buildInputs = [ + qtbase + sqlcipher + ] ++ lib.optional stdenv.hostPlatform.isDarwin qtmacextras; + + nativeBuildInputs = [ + cmake + qttools + wrapQtAppsHook + ]; cmakeFlags = [ "-Dsqlcipher=1" diff --git a/pkgs/development/tools/database/squirrel-sql/default.nix b/pkgs/development/tools/database/squirrel-sql/default.nix index 31d538597e518f..24719eb8b08cef 100644 --- a/pkgs/development/tools/database/squirrel-sql/default.nix +++ b/pkgs/development/tools/database/squirrel-sql/default.nix @@ -1,8 +1,14 @@ # To enable specific database drivers, override this derivation and pass the # driver packages in the drivers argument (e.g. mysql_jdbc, postgresql_jdbc). -{ lib, stdenv, fetchurl, makeDesktopItem, makeWrapper, unzip -, jre -, drivers ? [] +{ + lib, + stdenv, + fetchurl, + makeDesktopItem, + makeWrapper, + unzip, + jre, + drivers ? [ ], }: stdenv.mkDerivation rec { pname = "squirrel-sql"; @@ -13,7 +19,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-uQuzh9CyGNJsbYvQiQAYmIyBgpIzXALg8dTFB1USkr0="; }; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; buildInputs = [ jre ]; unpackPhase = '' diff --git a/pkgs/development/tools/database/surrealdb-migrations/default.nix b/pkgs/development/tools/database/surrealdb-migrations/default.nix index e47174c93450e1..99fe949bd6e908 100644 --- a/pkgs/development/tools/database/surrealdb-migrations/default.nix +++ b/pkgs/development/tools/database/surrealdb-migrations/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, testers -, Security -, surrealdb-migrations -, nix-update-script +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + testers, + Security, + surrealdb-migrations, + nix-update-script, }: let @@ -24,28 +25,27 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-ELYBEQrh80LdNYNZwcGVh9GE+dSfjF+RuO8fd0PabIw="; - buildInputs = [ ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; + buildInputs = [ ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; - # Error: No such file or directory (os error 2) - # failures: - # cli::apply::apply_initial_migrations - # cli::apply::apply_initial_schema_changes - # cli::apply::apply_new_migrations - # cli::apply::apply_new_schema_changes - # cli::apply::apply_should_skip_events_if_no_events_folder - # cli::apply::apply_with_db_configuration - # cli::apply::apply_with_skipped_migrations - # cli::list::list_blog_migrations - # cli::list::list_empty_migrations - # library::list::list_blog_migrations - # library::list::list_empty_migrations - # library::up::apply_initial_migrations - # library::up::apply_initial_schema_changes - # library::up::apply_new_migrations - # library::up::apply_new_schema_changes - # library::up::apply_should_skip_events_if_no_events_folder - # library::up_to::apply_with_skipped_migrations + # Error: No such file or directory (os error 2) + # failures: + # cli::apply::apply_initial_migrations + # cli::apply::apply_initial_schema_changes + # cli::apply::apply_new_migrations + # cli::apply::apply_new_schema_changes + # cli::apply::apply_should_skip_events_if_no_events_folder + # cli::apply::apply_with_db_configuration + # cli::apply::apply_with_skipped_migrations + # cli::list::list_blog_migrations + # cli::list::list_empty_migrations + # library::list::list_blog_migrations + # library::list::list_empty_migrations + # library::up::apply_initial_migrations + # library::up::apply_initial_schema_changes + # library::up::apply_new_migrations + # library::up::apply_new_schema_changes + # library::up::apply_should_skip_events_if_no_events_folder + # library::up_to::apply_with_skipped_migrations doCheck = false; passthru = { diff --git a/pkgs/development/tools/dazel/default.nix b/pkgs/development/tools/dazel/default.nix index 119cbaca9c7063..1a898b19118d36 100644 --- a/pkgs/development/tools/dazel/default.nix +++ b/pkgs/development/tools/dazel/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildPythonApplication -, fetchPypi +{ + lib, + buildPythonApplication, + fetchPypi, }: buildPythonApplication rec { version = "0.0.42"; diff --git a/pkgs/development/tools/devbox/default.nix b/pkgs/development/tools/devbox/default.nix index fcf88c57464f3e..17e0daee151753 100644 --- a/pkgs/development/tools/devbox/default.nix +++ b/pkgs/development/tools/devbox/default.nix @@ -1,8 +1,9 @@ -{ buildGoModule -, fetchFromGitHub -, installShellFiles -, lib -, stdenv +{ + buildGoModule, + fetchFromGitHub, + installShellFiles, + lib, + stdenv, }: buildGoModule rec { pname = "devbox"; @@ -41,6 +42,9 @@ buildGoModule rec { description = "Instant, easy, predictable shells and containers"; homepage = "https://www.jetpack.io/devbox"; license = licenses.asl20; - maintainers = with maintainers; [ urandom lagoja ]; + maintainers = with maintainers; [ + urandom + lagoja + ]; }; } diff --git a/pkgs/development/tools/devpi-server/default.nix b/pkgs/development/tools/devpi-server/default.nix index e32f0702e2aaeb..4fcaf9aa09c3b2 100644 --- a/pkgs/development/tools/devpi-server/default.nix +++ b/pkgs/development/tools/devpi-server/default.nix @@ -1,33 +1,35 @@ -{ lib, fetchFromGitHub, buildPythonApplication -, gitUpdater -, pythonOlder -, aiohttp -, appdirs -, beautifulsoup4 -, defusedxml -, devpi-common -, execnet -, itsdangerous -, nginx -, packaging -, passlib -, platformdirs -, pluggy -, py -, httpx -, pyramid -, pytestCheckHook -, repoze-lru -, setuptools -, strictyaml -, waitress -, webtest -, testers -, devpi-server -, nixosTests +{ + lib, + fetchFromGitHub, + buildPythonApplication, + gitUpdater, + pythonOlder, + aiohttp, + appdirs, + beautifulsoup4, + defusedxml, + devpi-common, + execnet, + itsdangerous, + nginx, + packaging, + passlib, + platformdirs, + pluggy, + py, + httpx, + pyramid, + pytestCheckHook, + repoze-lru, + setuptools, + strictyaml, + waitress, + webtest, + testers, + devpi-server, + nixosTests, }: - buildPythonApplication rec { pname = "devpi-server"; version = "6.14.0"; @@ -122,7 +124,7 @@ buildPythonApplication rec { rev-prefix = "server-"; }; - meta = with lib;{ + meta = with lib; { homepage = "http://doc.devpi.net"; description = "Github-style pypi index server and packaging meta tool"; changelog = "https://github.com/devpi/devpi/blob/${src.rev}/server/CHANGELOG"; diff --git a/pkgs/development/tools/djhtml/default.nix b/pkgs/development/tools/djhtml/default.nix index 1859249eb0f3cd..892e78717eb0b5 100644 --- a/pkgs/development/tools/djhtml/default.nix +++ b/pkgs/development/tools/djhtml/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, setuptools +{ + lib, + buildPythonApplication, + fetchFromGitHub, + setuptools, }: buildPythonApplication rec { pname = "djhtml"; diff --git a/pkgs/development/tools/dump_syms/default.nix b/pkgs/development/tools/dump_syms/default.nix index 7f723096a8a72d..073730272dc3cf 100644 --- a/pkgs/development/tools/dump_syms/default.nix +++ b/pkgs/development/tools/dump_syms/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, -# darwin -, Security -, SystemConfiguration + # darwin + Security, + SystemConfiguration, -# tests -, firefox-esr-unwrapped -, firefox-unwrapped -, thunderbird-unwrapped + # tests + firefox-esr-unwrapped, + firefox-unwrapped, + thunderbird-unwrapped, }: let @@ -35,12 +36,14 @@ rustPlatform.buildRustPackage { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ - Security - SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ + Security + SystemConfiguration + ]; checkFlags = [ # Disable tests that require network access diff --git a/pkgs/development/tools/electron/binary/default.nix b/pkgs/development/tools/electron/binary/default.nix index 07637d13e9f25b..1e3233717bfd4e 100644 --- a/pkgs/development/tools/electron/binary/default.nix +++ b/pkgs/development/tools/electron/binary/default.nix @@ -7,8 +7,7 @@ in let mkElectron = callPackage ./generic.nix { }; in -lib.mapAttrs' (majorVersion: info: - lib.nameValuePair - "electron_${majorVersion}-bin" - (mkElectron info.version info.hashes) +lib.mapAttrs' ( + majorVersion: info: + lib.nameValuePair "electron_${majorVersion}-bin" (mkElectron info.version info.hashes) ) infoJson diff --git a/pkgs/development/tools/electron/binary/generic.nix b/pkgs/development/tools/electron/binary/generic.nix index 6835c8a6263e3e..b053700719c96a 100644 --- a/pkgs/development/tools/electron/binary/generic.nix +++ b/pkgs/development/tools/electron/binary/generic.nix @@ -1,31 +1,32 @@ -{ lib -, stdenv -, libXScrnSaver -, makeWrapper -, fetchurl -, wrapGAppsHook3 -, glib -, gtk3 -, unzip -, at-spi2-atk -, libdrm -, mesa -, libxkbcommon -, libxshmfence -, libGL -, vulkan-loader -, alsa-lib -, cairo -, cups -, dbus -, expat -, gdk-pixbuf -, nss -, nspr -, xorg -, pango -, systemd -, pciutils +{ + lib, + stdenv, + libXScrnSaver, + makeWrapper, + fetchurl, + wrapGAppsHook3, + glib, + gtk3, + unzip, + at-spi2-atk, + libdrm, + mesa, + libxkbcommon, + libxshmfence, + libGL, + vulkan-loader, + alsa-lib, + cairo, + cups, + dbus, + expat, + gdk-pixbuf, + nss, + nspr, + xorg, + pango, + systemd, + pciutils, }: version: hashes: @@ -37,8 +38,17 @@ let homepage = "https://github.com/electron/electron"; license = licenses.mit; mainProgram = "electron"; - maintainers = with maintainers; [ yayayayaka teutat3s ]; - platforms = [ "x86_64-darwin" "x86_64-linux" "armv7l-linux" "aarch64-linux" ] + maintainers = with maintainers; [ + yayayayaka + teutat3s + ]; + platforms = + [ + "x86_64-darwin" + "x86_64-linux" + "armv7l-linux" + "aarch64-linux" + ] ++ optionals (versionAtLeast version "11.0.0") [ "aarch64-darwin" ] ++ optionals (versionOlder version "19.0.0") [ "i686-linux" ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; @@ -46,26 +56,33 @@ let knownVulnerabilities = optional (versionOlder version "31.0.0") "Electron version ${version} is EOL"; }; - fetcher = vers: tag: hash: fetchurl { - url = "https://github.com/electron/electron/releases/download/v${vers}/electron-v${vers}-${tag}.zip"; - sha256 = hash; - }; - - headersFetcher = vers: hash: fetchurl { - url = "https://artifacts.electronjs.org/headers/dist/v${vers}/node-v${vers}-headers.tar.gz"; - sha256 = hash; - }; - - tags = { - x86_64-linux = "linux-x64"; - armv7l-linux = "linux-armv7l"; - aarch64-linux = "linux-arm64"; - x86_64-darwin = "darwin-x64"; - } // lib.optionalAttrs (lib.versionAtLeast version "11.0.0") { - aarch64-darwin = "darwin-arm64"; - } // lib.optionalAttrs (lib.versionOlder version "19.0.0") { - i686-linux = "linux-ia32"; - }; + fetcher = + vers: tag: hash: + fetchurl { + url = "https://github.com/electron/electron/releases/download/v${vers}/electron-v${vers}-${tag}.zip"; + sha256 = hash; + }; + + headersFetcher = + vers: hash: + fetchurl { + url = "https://artifacts.electronjs.org/headers/dist/v${vers}/node-v${vers}-headers.tar.gz"; + sha256 = hash; + }; + + tags = + { + x86_64-linux = "linux-x64"; + armv7l-linux = "linux-armv7l"; + aarch64-linux = "linux-arm64"; + x86_64-darwin = "darwin-x64"; + } + // lib.optionalAttrs (lib.versionAtLeast version "11.0.0") { + aarch64-darwin = "darwin-arm64"; + } + // lib.optionalAttrs (lib.versionOlder version "19.0.0") { + i686-linux = "linux-ia32"; + }; get = as: platform: as.${platform.system} or (throw "Unsupported system: ${platform.system}"); @@ -75,40 +92,50 @@ let passthru.headers = headersFetcher version hashes.headers; }; - electronLibPath = lib.makeLibraryPath ([ - alsa-lib - at-spi2-atk - cairo - cups - dbus - expat - gdk-pixbuf - glib - gtk3 - nss - nspr - xorg.libX11 - xorg.libxcb - xorg.libXcomposite - xorg.libXdamage - xorg.libXext - xorg.libXfixes - xorg.libXrandr - xorg.libxkbfile - pango - pciutils - stdenv.cc.cc - systemd - ] - ++ lib.optionals (lib.versionAtLeast version "9.0.0") [ libdrm mesa ] + electronLibPath = lib.makeLibraryPath ( + [ + alsa-lib + at-spi2-atk + cairo + cups + dbus + expat + gdk-pixbuf + glib + gtk3 + nss + nspr + xorg.libX11 + xorg.libxcb + xorg.libXcomposite + xorg.libXdamage + xorg.libXext + xorg.libXfixes + xorg.libXrandr + xorg.libxkbfile + pango + pciutils + stdenv.cc.cc + systemd + ] + ++ lib.optionals (lib.versionAtLeast version "9.0.0") [ + libdrm + mesa + ] ++ lib.optionals (lib.versionOlder version "10.0.0") [ libXScrnSaver ] ++ lib.optionals (lib.versionAtLeast version "11.0.0") [ libxkbcommon ] ++ lib.optionals (lib.versionAtLeast version "12.0.0") [ libxshmfence ] - ++ lib.optionals (lib.versionAtLeast version "17.0.0") [ libGL vulkan-loader ] + ++ lib.optionals (lib.versionAtLeast version "17.0.0") [ + libGL + vulkan-loader + ] ); linux = finalAttrs: { - buildInputs = [ glib gtk3 ]; + buildInputs = [ + glib + gtk3 + ]; nativeBuildInputs = [ unzip @@ -131,11 +158,17 @@ let --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ --set-rpath "${electronLibPath}:$out/libexec/electron" \ $out/libexec/electron/.electron-wrapped \ - ${lib.optionalString (lib.versionAtLeast version "15.0.0") "$out/libexec/electron/.chrome_crashpad_handler-wrapped" } + ${lib.optionalString (lib.versionAtLeast version "15.0.0") "$out/libexec/electron/.chrome_crashpad_handler-wrapped"} # patch libANGLE patchelf \ - --set-rpath "${lib.makeLibraryPath [ libGL pciutils vulkan-loader ]}" \ + --set-rpath "${ + lib.makeLibraryPath [ + libGL + pciutils + vulkan-loader + ] + }" \ $out/libexec/electron/lib*GL* # replace bundled vulkan-loader @@ -163,8 +196,9 @@ let passthru.dist = finalAttrs.finalPackage + "/Applications"; }; in - stdenv.mkDerivation (finalAttrs: - lib.recursiveUpdate - (common stdenv.hostPlatform) - ((if stdenv.hostPlatform.isDarwin then darwin else linux) finalAttrs) +stdenv.mkDerivation ( + finalAttrs: + lib.recursiveUpdate (common stdenv.hostPlatform) ( + (if stdenv.hostPlatform.isDarwin then darwin else linux) finalAttrs ) +) diff --git a/pkgs/development/tools/electron/chromedriver/default.nix b/pkgs/development/tools/electron/chromedriver/default.nix index 87c45f5d566a36..0185737df74ca1 100644 --- a/pkgs/development/tools/electron/chromedriver/default.nix +++ b/pkgs/development/tools/electron/chromedriver/default.nix @@ -7,8 +7,9 @@ in let mkElectronChromedriver = callPackage ./generic.nix { }; in -lib.mapAttrs' (majorVersion: info: - lib.nameValuePair - "electron-chromedriver_${majorVersion}" - (mkElectronChromedriver info.version info.hashes) +lib.mapAttrs' ( + majorVersion: info: + lib.nameValuePair "electron-chromedriver_${majorVersion}" ( + mkElectronChromedriver info.version info.hashes + ) ) infoJson diff --git a/pkgs/development/tools/electron/chromedriver/generic.nix b/pkgs/development/tools/electron/chromedriver/generic.nix index 6ee587b26ef9c9..cebc3fe9bb6857 100644 --- a/pkgs/development/tools/electron/chromedriver/generic.nix +++ b/pkgs/development/tools/electron/chromedriver/generic.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, glib -, xorg -, nspr -, nss -, autoPatchelfHook -, unzip +{ + lib, + stdenv, + fetchurl, + glib, + xorg, + nspr, + nss, + autoPatchelfHook, + unzip, }: version: hashes: @@ -26,15 +27,26 @@ let ''; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.mit; - maintainers = with maintainers; [ liammurphy14 yayayayaka ]; - platforms = ["x86_64-darwin" "x86_64-linux" "armv7l-linux" "aarch64-linux" "aarch64-darwin"]; + maintainers = with maintainers; [ + liammurphy14 + yayayayaka + ]; + platforms = [ + "x86_64-darwin" + "x86_64-linux" + "armv7l-linux" + "aarch64-linux" + "aarch64-darwin" + ]; mainProgram = "chromedriver"; }; - fetcher = vers: tag: hash: fetchurl { - url = "https://github.com/electron/electron/releases/download/v${vers}/chromedriver-v${vers}-${tag}.zip"; - sha256 = hash; - }; + fetcher = + vers: tag: hash: + fetchurl { + url = "https://github.com/electron/electron/releases/download/v${vers}/chromedriver-v${vers}-${tag}.zip"; + sha256 = hash; + }; tags = { x86_64-linux = "linux-x64"; @@ -60,7 +72,10 @@ let }; linux = { - nativeBuildInputs = [ autoPatchelfHook unzip ]; + nativeBuildInputs = [ + autoPatchelfHook + unzip + ]; dontUnpack = true; dontBuild = true; @@ -90,7 +105,6 @@ let ''; }; in - stdenv.mkDerivation ( - (common stdenv.hostPlatform) // - (if stdenv.hostPlatform.isDarwin then darwin else linux) - ) +stdenv.mkDerivation ( + (common stdenv.hostPlatform) // (if stdenv.hostPlatform.isDarwin then darwin else linux) +) diff --git a/pkgs/development/tools/electron/common.nix b/pkgs/development/tools/electron/common.nix index bd4843edbcca1d..07367857eccd18 100644 --- a/pkgs/development/tools/electron/common.nix +++ b/pkgs/development/tools/electron/common.nix @@ -1,38 +1,49 @@ -{ lib -, stdenv -, chromium -, nodejs -, python3 -, fetchYarnDeps -, fetchNpmDeps -, fixup-yarn-lock -, npmHooks -, yarn -, substituteAll -, libnotify -, unzip -, pkgs -, pkgsBuildHost -, pipewire -, libsecret -, libpulseaudio -, speechd-minimal -, info +{ + lib, + stdenv, + chromium, + nodejs, + python3, + fetchYarnDeps, + fetchNpmDeps, + fixup-yarn-lock, + npmHooks, + yarn, + substituteAll, + libnotify, + unzip, + pkgs, + pkgsBuildHost, + pipewire, + libsecret, + libpulseaudio, + speechd-minimal, + info, }: let - fetchdep = dep: let - opts = removeAttrs dep ["fetcher"]; - in pkgs.${dep.fetcher} opts; + fetchdep = + dep: + let + opts = removeAttrs dep [ "fetcher" ]; + in + pkgs.${dep.fetcher} opts; fetchedDeps = lib.mapAttrs (name: fetchdep) info.deps; -in ((chromium.override { upstream-info = info.chromium; }).mkDerivation (base: { +in +((chromium.override { upstream-info = info.chromium; }).mkDerivation (base: { packageName = "electron"; inherit (info) version; buildTargets = [ "electron:electron_dist_zip" ]; - nativeBuildInputs = base.nativeBuildInputs ++ [ nodejs yarn fixup-yarn-lock unzip npmHooks.npmConfigHook ]; + nativeBuildInputs = base.nativeBuildInputs ++ [ + nodejs + yarn + fixup-yarn-lock + unzip + npmHooks.npmConfigHook + ]; buildInputs = base.buildInputs ++ [ libnotify ]; electronOfflineCache = fetchYarnDeps { @@ -51,133 +62,151 @@ in ((chromium.override { upstream-info = info.chromium; }).mkDerivation (base: { patches = base.patches; - unpackPhase = '' - runHook preUnpack - '' + ( - lib.concatStrings (lib.mapAttrsToList (path: dep: '' - mkdir -p ${builtins.dirOf path} - cp -r ${dep}/. ${path} - chmod u+w -R ${path} - '') fetchedDeps) - ) + '' - sourceRoot=src - runHook postUnpack - ''; + unpackPhase = + '' + runHook preUnpack + '' + + (lib.concatStrings ( + lib.mapAttrsToList (path: dep: '' + mkdir -p ${builtins.dirOf path} + cp -r ${dep}/. ${path} + chmod u+w -R ${path} + '') fetchedDeps + )) + + '' + sourceRoot=src + runHook postUnpack + ''; npmRoot = "third_party/node"; - postPatch = '' - mkdir -p third_party/jdk/current/bin - - echo 'build_with_chromium = true' >> build/config/gclient_args.gni - echo 'checkout_google_benchmark = false' >> build/config/gclient_args.gni - echo 'checkout_android = false' >> build/config/gclient_args.gni - echo 'checkout_android_prebuilts_build_tools = false' >> build/config/gclient_args.gni - echo 'checkout_android_native_support = false' >> build/config/gclient_args.gni - echo 'checkout_ios_webkit = false' >> build/config/gclient_args.gni - echo 'checkout_nacl = false' >> build/config/gclient_args.gni - echo 'checkout_openxr = false' >> build/config/gclient_args.gni - echo 'checkout_rts_model = false' >> build/config/gclient_args.gni - echo 'checkout_src_internal = false' >> build/config/gclient_args.gni - echo 'cros_boards = ""' >> build/config/gclient_args.gni - echo 'cros_boards_with_qemu_images = ""' >> build/config/gclient_args.gni - echo 'generate_location_tags = true' >> build/config/gclient_args.gni - - echo 'LASTCHANGE=${info.deps."src".rev}-refs/heads/master@{#0}' > build/util/LASTCHANGE - echo "$SOURCE_DATE_EPOCH" > build/util/LASTCHANGE.committime - - cat << EOF > gpu/config/gpu_lists_version.h - /* Generated by lastchange.py, do not edit.*/ - #ifndef GPU_CONFIG_GPU_LISTS_VERSION_H_ - #define GPU_CONFIG_GPU_LISTS_VERSION_H_ - #define GPU_LISTS_VERSION "${info.deps."src".rev}" - #endif // GPU_CONFIG_GPU_LISTS_VERSION_H_ - EOF - - cat << EOF > skia/ext/skia_commit_hash.h - /* Generated by lastchange.py, do not edit.*/ - #ifndef SKIA_EXT_SKIA_COMMIT_HASH_H_ - #define SKIA_EXT_SKIA_COMMIT_HASH_H_ - #define SKIA_COMMIT_HASH "${info.deps."src/third_party/skia".rev}-" - #endif // SKIA_EXT_SKIA_COMMIT_HASH_H_ - EOF - - echo -n '${info.deps."src/third_party/dawn".rev}' > gpu/webgpu/DAWN_VERSION - - ( - cd electron - export HOME=$TMPDIR/fake_home - yarn config --offline set yarn-offline-mirror $electronOfflineCache - fixup-yarn-lock yarn.lock - yarn install --offline --frozen-lockfile --ignore-scripts --no-progress --non-interactive - ) - - ( - cd .. - PATH=$PATH:${lib.makeBinPath (with pkgsBuildHost; [ jq git ])} - config=src/electron/patches/config.json - for entry in $(cat $config | jq -c ".[]") - do - patch_dir=$(echo $entry | jq -r ".patch_dir") - repo=$(echo $entry | jq -r ".repo") - for patch in $(cat $patch_dir/.patches) + postPatch = + '' + mkdir -p third_party/jdk/current/bin + + echo 'build_with_chromium = true' >> build/config/gclient_args.gni + echo 'checkout_google_benchmark = false' >> build/config/gclient_args.gni + echo 'checkout_android = false' >> build/config/gclient_args.gni + echo 'checkout_android_prebuilts_build_tools = false' >> build/config/gclient_args.gni + echo 'checkout_android_native_support = false' >> build/config/gclient_args.gni + echo 'checkout_ios_webkit = false' >> build/config/gclient_args.gni + echo 'checkout_nacl = false' >> build/config/gclient_args.gni + echo 'checkout_openxr = false' >> build/config/gclient_args.gni + echo 'checkout_rts_model = false' >> build/config/gclient_args.gni + echo 'checkout_src_internal = false' >> build/config/gclient_args.gni + echo 'cros_boards = ""' >> build/config/gclient_args.gni + echo 'cros_boards_with_qemu_images = ""' >> build/config/gclient_args.gni + echo 'generate_location_tags = true' >> build/config/gclient_args.gni + + echo 'LASTCHANGE=${info.deps."src".rev}-refs/heads/master@{#0}' > build/util/LASTCHANGE + echo "$SOURCE_DATE_EPOCH" > build/util/LASTCHANGE.committime + + cat << EOF > gpu/config/gpu_lists_version.h + /* Generated by lastchange.py, do not edit.*/ + #ifndef GPU_CONFIG_GPU_LISTS_VERSION_H_ + #define GPU_CONFIG_GPU_LISTS_VERSION_H_ + #define GPU_LISTS_VERSION "${info.deps."src".rev}" + #endif // GPU_CONFIG_GPU_LISTS_VERSION_H_ + EOF + + cat << EOF > skia/ext/skia_commit_hash.h + /* Generated by lastchange.py, do not edit.*/ + #ifndef SKIA_EXT_SKIA_COMMIT_HASH_H_ + #define SKIA_EXT_SKIA_COMMIT_HASH_H_ + #define SKIA_COMMIT_HASH "${info.deps."src/third_party/skia".rev}-" + #endif // SKIA_EXT_SKIA_COMMIT_HASH_H_ + EOF + + echo -n '${info.deps."src/third_party/dawn".rev}' > gpu/webgpu/DAWN_VERSION + + ( + cd electron + export HOME=$TMPDIR/fake_home + yarn config --offline set yarn-offline-mirror $electronOfflineCache + fixup-yarn-lock yarn.lock + yarn install --offline --frozen-lockfile --ignore-scripts --no-progress --non-interactive + ) + + ( + cd .. + PATH=$PATH:${ + lib.makeBinPath ( + with pkgsBuildHost; + [ + jq + git + ] + ) + } + config=src/electron/patches/config.json + for entry in $(cat $config | jq -c ".[]") do - echo applying in $repo: $patch - git apply -p1 --directory=$repo --exclude='src/third_party/blink/web_tests/*' --exclude='src/content/test/data/*' $patch_dir/$patch + patch_dir=$(echo $entry | jq -r ".patch_dir") + repo=$(echo $entry | jq -r ".repo") + for patch in $(cat $patch_dir/.patches) + do + echo applying in $repo: $patch + git apply -p1 --directory=$repo --exclude='src/third_party/blink/web_tests/*' --exclude='src/content/test/data/*' $patch_dir/$patch + done done - done - ) - '' + base.postPatch; - - preConfigure = '' - ( - cd third_party/node - grep patch update_npm_deps | sh - ) - '' + (base.preConfigure or ""); - - gnFlags = rec { - # build/args/release.gn - is_component_build = false; - is_official_build = true; - rtc_use_h264 = proprietary_codecs; - is_component_ffmpeg = true; - - # build/args/all.gn - is_electron_build = true; - root_extra_deps = [ "//electron" ]; - node_module_version = info.modules; - v8_promise_internal_field_count = 1; - v8_embedder_string = "-electron.0"; - v8_enable_snapshot_native_code_counters = false; - v8_enable_javascript_promise_hooks = true; - enable_cdm_host_verification = false; - proprietary_codecs = true; - ffmpeg_branding = "Chrome"; - enable_printing = true; - angle_enable_vulkan_validation_layers = false; - dawn_enable_vulkan_validation_layers = false; - enable_pseudolocales = false; - allow_runtime_configurable_key_storage = true; - enable_cet_shadow_stack = false; - is_cfi = false; - use_qt = false; - v8_builtins_profiling_log_file = ""; - enable_dangling_raw_ptr_checks = false; - dawn_use_built_dxc = false; - v8_enable_private_mapping_fork_optimization = true; - v8_expose_public_symbols = true; - enable_dangling_raw_ptr_feature_flag = false; - clang_unsafe_buffers_paths = ""; - enterprise_cloud_content_analysis = false; - } // lib.optionalAttrs (lib.versionAtLeast info.version "33") { - content_enable_legacy_ipc = true; - } // { - - # other - enable_widevine = false; - override_electron_version = info.version; - }; + ) + '' + + base.postPatch; + + preConfigure = + '' + ( + cd third_party/node + grep patch update_npm_deps | sh + ) + '' + + (base.preConfigure or ""); + + gnFlags = + rec { + # build/args/release.gn + is_component_build = false; + is_official_build = true; + rtc_use_h264 = proprietary_codecs; + is_component_ffmpeg = true; + + # build/args/all.gn + is_electron_build = true; + root_extra_deps = [ "//electron" ]; + node_module_version = info.modules; + v8_promise_internal_field_count = 1; + v8_embedder_string = "-electron.0"; + v8_enable_snapshot_native_code_counters = false; + v8_enable_javascript_promise_hooks = true; + enable_cdm_host_verification = false; + proprietary_codecs = true; + ffmpeg_branding = "Chrome"; + enable_printing = true; + angle_enable_vulkan_validation_layers = false; + dawn_enable_vulkan_validation_layers = false; + enable_pseudolocales = false; + allow_runtime_configurable_key_storage = true; + enable_cet_shadow_stack = false; + is_cfi = false; + use_qt = false; + v8_builtins_profiling_log_file = ""; + enable_dangling_raw_ptr_checks = false; + dawn_use_built_dxc = false; + v8_enable_private_mapping_fork_optimization = true; + v8_expose_public_symbols = true; + enable_dangling_raw_ptr_feature_flag = false; + clang_unsafe_buffers_paths = ""; + enterprise_cloud_content_analysis = false; + } + // lib.optionalAttrs (lib.versionAtLeast info.version "33") { + content_enable_legacy_ipc = true; + } + // { + + # other + enable_widevine = false; + override_electron_version = info.version; + }; installPhase = '' runHook preInstall @@ -199,11 +228,12 @@ in ((chromium.override { upstream-info = info.chromium; }).mkDerivation (base: { speechd-minimal ]; in - base.postFixup + '' - patchelf \ - --add-rpath "${libPath}" \ - $out/libexec/electron/electron - ''; + base.postFixup + + '' + patchelf \ + --add-rpath "${libPath}" \ + $out/libexec/electron/electron + ''; requiredSystemFeatures = [ "big-parallel" ]; @@ -231,14 +261,25 @@ in ((chromium.override { upstream-info = info.chromium; }).mkDerivation (base: { homepage = "https://github.com/electron/electron"; platforms = lib.platforms.linux; license = licenses.mit; - maintainers = with maintainers; [ yayayayaka teutat3s ]; + maintainers = with maintainers; [ + yayayayaka + teutat3s + ]; mainProgram = "electron"; - hydraPlatforms = lib.optionals (!(hasInfix "alpha" info.version) && !(hasInfix "beta" info.version)) ["aarch64-linux" "x86_64-linux"]; + hydraPlatforms = + lib.optionals (!(hasInfix "alpha" info.version) && !(hasInfix "beta" info.version)) + [ + "aarch64-linux" + "x86_64-linux" + ]; timeout = 172800; # 48 hours (increased from the Hydra default of 10h) }; -})).overrideAttrs (finalAttrs: prevAttrs: { - # this was the only way I could get the package to properly reference itself - passthru = prevAttrs.passthru // { - dist = finalAttrs.finalPackage + "/libexec/electron"; - }; -}) +})).overrideAttrs + ( + finalAttrs: prevAttrs: { + # this was the only way I could get the package to properly reference itself + passthru = prevAttrs.passthru // { + dist = finalAttrs.finalPackage + "/libexec/electron"; + }; + } + ) diff --git a/pkgs/development/tools/electron/default.nix b/pkgs/development/tools/electron/default.nix index 8c97837160d1ca..b8d452c56d59cc 100644 --- a/pkgs/development/tools/electron/default.nix +++ b/pkgs/development/tools/electron/default.nix @@ -3,10 +3,12 @@ let versions = lib.importJSON ./info.json; in - lib.mapAttrs' (version: info: - lib.nameValuePair "electron_${version}" ( - let - electron-unwrapped = callPackage ./common.nix { inherit info; }; - in callPackage ./wrapper.nix { inherit electron-unwrapped; } - ) - ) versions +lib.mapAttrs' ( + version: info: + lib.nameValuePair "electron_${version}" ( + let + electron-unwrapped = callPackage ./common.nix { inherit info; }; + in + callPackage ./wrapper.nix { inherit electron-unwrapped; } + ) +) versions diff --git a/pkgs/development/tools/electron/wrapper.nix b/pkgs/development/tools/electron/wrapper.nix index 8c48e8f695fc2d..412596a0629b2e 100644 --- a/pkgs/development/tools/electron/wrapper.nix +++ b/pkgs/development/tools/electron/wrapper.nix @@ -1,21 +1,28 @@ -{ stdenv -, electron-unwrapped -, wrapGAppsHook3 -, makeWrapper -, gsettings-desktop-schemas -, glib -, gtk3 -, gtk4 +{ + stdenv, + electron-unwrapped, + wrapGAppsHook3, + makeWrapper, + gsettings-desktop-schemas, + glib, + gtk3, + gtk4, }: stdenv.mkDerivation { pname = "electron"; inherit (electron-unwrapped) version; - nativeBuildInputs = [ wrapGAppsHook3 makeWrapper ]; + nativeBuildInputs = [ + wrapGAppsHook3 + makeWrapper + ]; buildInputs = [ # needed for GSETTINGS_SCHEMAS_PATH - gsettings-desktop-schemas glib gtk3 gtk4 + gsettings-desktop-schemas + glib + gtk3 + gtk4 ]; dontWrapGApps = true; diff --git a/pkgs/development/tools/enochecker-test/default.nix b/pkgs/development/tools/enochecker-test/default.nix index ca6a49e3502fd7..08a7e3080512eb 100644 --- a/pkgs/development/tools/enochecker-test/default.nix +++ b/pkgs/development/tools/enochecker-test/default.nix @@ -1,22 +1,23 @@ -{ lib -, buildPythonApplication -, fetchPypi -, pythonOlder +{ + lib, + buildPythonApplication, + fetchPypi, + pythonOlder, -, certifi -, charset-normalizer -, enochecker-core -, exceptiongroup -, idna -, iniconfig -, jsons -, packaging -, pluggy -, pytest -, requests -, tomli -, typish -, urllib3 + certifi, + charset-normalizer, + enochecker-core, + exceptiongroup, + idna, + iniconfig, + jsons, + packaging, + pluggy, + pytest, + requests, + tomli, + typish, + urllib3, }: buildPythonApplication rec { diff --git a/pkgs/development/tools/esbuild/default.nix b/pkgs/development/tools/esbuild/default.nix index a7720470f4896d..c5921c694473b2 100644 --- a/pkgs/development/tools/esbuild/default.nix +++ b/pkgs/development/tools/esbuild/default.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "esbuild"; @@ -15,14 +19,21 @@ buildGoModule rec { subPackages = [ "cmd/esbuild" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Extremely fast JavaScript bundler"; homepage = "https://esbuild.github.io"; changelog = "https://github.com/evanw/esbuild/blob/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ lucus16 undefined-moe ivan ]; + maintainers = with maintainers; [ + lucus16 + undefined-moe + ivan + ]; mainProgram = "esbuild"; }; } diff --git a/pkgs/development/tools/esbuild/netlify.nix b/pkgs/development/tools/esbuild/netlify.nix index d94f78bc8b2661..5431b56ddbf7e5 100644 --- a/pkgs/development/tools/esbuild/netlify.nix +++ b/pkgs/development/tools/esbuild/netlify.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, netlify-cli +{ + lib, + buildGoModule, + fetchFromGitHub, + netlify-cli, }: buildGoModule rec { diff --git a/pkgs/development/tools/flatpak-builder/default.nix b/pkgs/development/tools/flatpak-builder/default.nix index ae3c3ce32192e4..7bbeee4a153636 100644 --- a/pkgs/development/tools/flatpak-builder/default.nix +++ b/pkgs/development/tools/flatpak-builder/default.nix @@ -1,51 +1,58 @@ -{ lib, stdenv -, fetchurl -, substituteAll -, nixosTests - -, docbook_xml_dtd_45 -, docbook_xsl -, gettext -, libxml2 -, libxslt -, pkg-config -, xmlto -, meson -, ninja - -, acl -, appstream -, breezy -, binutils -, bzip2 -, coreutils -, cpio -, curl -, debugedit -, elfutils -, flatpak -, gitMinimal -, glib -, glibcLocales -, gnumake -, gnupg -, gnutar -, json-glib -, libcap -, libsoup_2_4 -, libyaml -, ostree -, patch -, rpm -, unzip -, attr +{ + lib, + stdenv, + fetchurl, + substituteAll, + nixosTests, + + docbook_xml_dtd_45, + docbook_xsl, + gettext, + libxml2, + libxslt, + pkg-config, + xmlto, + meson, + ninja, + + acl, + appstream, + breezy, + binutils, + bzip2, + coreutils, + cpio, + curl, + debugedit, + elfutils, + flatpak, + gitMinimal, + glib, + glibcLocales, + gnumake, + gnupg, + gnutar, + json-glib, + libcap, + libsoup_2_4, + libyaml, + ostree, + patch, + rpm, + unzip, + attr, }: stdenv.mkDerivation (finalAttrs: { pname = "flatpak-builder"; version = "1.4.4"; - outputs = [ "out" "doc" "man" "installedTests" ]; + outputs = [ + "out" + "doc" + "man" + "installedTests" + ]; # fetchFromGitHub fetches an archive which does not contain the full source (https://github.com/flatpak/flatpak-builder/issues/558) src = fetchurl { @@ -121,13 +128,15 @@ stdenv.mkDerivation (finalAttrs: { enableParallelBuilding = true; # Installed tests - postFixup = let - installed_testdir = "${placeholder "installedTests"}/libexec/installed-tests/flatpak-builder"; - in '' - for file in ${installed_testdir}/{test-builder.sh,test-builder-python.sh,test-builder-deprecated.sh}; do - patchShebangs $file - done - ''; + postFixup = + let + installed_testdir = "${placeholder "installedTests"}/libexec/installed-tests/flatpak-builder"; + in + '' + for file in ${installed_testdir}/{test-builder.sh,test-builder-python.sh,test-builder-deprecated.sh}; do + patchShebangs $file + done + ''; passthru = { installedTestsDependencies = [ diff --git a/pkgs/development/tools/gammaray/default.nix b/pkgs/development/tools/gammaray/default.nix index a7c16674973acc..a00ddf3cb699d6 100644 --- a/pkgs/development/tools/gammaray/default.nix +++ b/pkgs/development/tools/gammaray/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, pkg-config -, qttools -, wrapQtAppsHook -, qtbase -, qtwayland -, qtsvg -, qt3d -, qtdeclarative -, qtconnectivity -, qtlocation -, qtscxml -, qtwebengine -, kdePackages -, wayland -, elfutils -, libbfd +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + qttools, + wrapQtAppsHook, + qtbase, + qtwayland, + qtsvg, + qt3d, + qtdeclarative, + qtconnectivity, + qtlocation, + qtscxml, + qtwebengine, + kdePackages, + wayland, + elfutils, + libbfd, }: stdenv.mkDerivation rec { @@ -68,4 +69,3 @@ stdenv.mkDerivation rec { mainProgram = "gammaray"; }; } - diff --git a/pkgs/development/tools/gauge/default.nix b/pkgs/development/tools/gauge/default.nix index 05538598dd6971..be2c4397fe75d6 100644 --- a/pkgs/development/tools/gauge/default.nix +++ b/pkgs/development/tools/gauge/default.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gauge"; @@ -19,13 +23,19 @@ buildGoModule rec { vendorHash = "sha256-2oEIBIr8oc1ku/k9mlLSg6Q6BbUleufvlmWOaV6wPfU="; - excludedPackages = [ "build" "man" ]; + excludedPackages = [ + "build" + "man" + ]; meta = with lib; { description = "Light weight cross-platform test automation"; mainProgram = "gauge"; homepage = "https://gauge.org"; license = licenses.asl20; - maintainers = with maintainers; [ vdemeester marie ]; + maintainers = with maintainers; [ + vdemeester + marie + ]; }; } diff --git a/pkgs/development/tools/gauge/plugins/default.nix b/pkgs/development/tools/gauge/plugins/default.nix index b68d48ba4767e5..73dfa06bd04bf2 100644 --- a/pkgs/development/tools/gauge/plugins/default.nix +++ b/pkgs/development/tools/gauge/plugins/default.nix @@ -1,15 +1,19 @@ { lib, pkgs }: -lib.makeScope pkgs.newScope (final: let - inherit (final) callPackage; -in { - makeGaugePlugin = callPackage ./make-gauge-plugin.nix { }; - testGaugePlugins = callPackage ./test-gauge-plugins.nix { }; - dotnet = callPackage ./dotnet { }; - html-report = callPackage ./html-report { }; - java = callPackage ./java { }; - js = callPackage ./js { }; - ruby = callPackage ./ruby { }; - go = callPackage ./go { }; - screenshot = callPackage ./screenshot { }; - xml-report = callPackage ./xml-report { }; -}) +lib.makeScope pkgs.newScope ( + final: + let + inherit (final) callPackage; + in + { + makeGaugePlugin = callPackage ./make-gauge-plugin.nix { }; + testGaugePlugins = callPackage ./test-gauge-plugins.nix { }; + dotnet = callPackage ./dotnet { }; + html-report = callPackage ./html-report { }; + java = callPackage ./java { }; + js = callPackage ./js { }; + ruby = callPackage ./ruby { }; + go = callPackage ./go { }; + screenshot = callPackage ./screenshot { }; + xml-report = callPackage ./xml-report { }; + } +) diff --git a/pkgs/development/tools/gauge/plugins/dotnet/default.nix b/pkgs/development/tools/gauge/plugins/dotnet/default.nix index dbac34acdac76a..26e2efe38f558d 100644 --- a/pkgs/development/tools/gauge/plugins/dotnet/default.nix +++ b/pkgs/development/tools/gauge/plugins/dotnet/default.nix @@ -1,7 +1,8 @@ -{ lib -, makeGaugePlugin -, gauge-unwrapped -, stdenv +{ + lib, + makeGaugePlugin, + gauge-unwrapped, + stdenv, }: makeGaugePlugin { diff --git a/pkgs/development/tools/gauge/plugins/go/default.nix b/pkgs/development/tools/gauge/plugins/go/default.nix index c21c517fb7d10b..14be396ef0867e 100644 --- a/pkgs/development/tools/gauge/plugins/go/default.nix +++ b/pkgs/development/tools/gauge/plugins/go/default.nix @@ -1,5 +1,6 @@ -{ lib -, makeGaugePlugin +{ + lib, + makeGaugePlugin, }: makeGaugePlugin { pname = "go"; @@ -14,6 +15,10 @@ makeGaugePlugin { license = lib.licenses.gpl3; maintainers = with lib.maintainers; [ marie ]; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; - platforms = [ "aarch64-darwin" "x86_64-darwin" "x86_64-linux" ]; + platforms = [ + "aarch64-darwin" + "x86_64-darwin" + "x86_64-linux" + ]; }; } diff --git a/pkgs/development/tools/gauge/plugins/html-report/default.nix b/pkgs/development/tools/gauge/plugins/html-report/default.nix index 33e0eb272275a7..8083b1cbd87754 100644 --- a/pkgs/development/tools/gauge/plugins/html-report/default.nix +++ b/pkgs/development/tools/gauge/plugins/html-report/default.nix @@ -1,5 +1,6 @@ -{ lib -, makeGaugePlugin +{ + lib, + makeGaugePlugin, }: makeGaugePlugin { pname = "html-report"; @@ -14,6 +15,11 @@ makeGaugePlugin { license = lib.licenses.asl20; maintainers = with lib.maintainers; [ marie ]; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; - platforms = [ "aarch64-darwin" "x86_64-darwin" "aarch64-linux" "x86_64-linux" ]; + platforms = [ + "aarch64-darwin" + "x86_64-darwin" + "aarch64-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/development/tools/gauge/plugins/java/default.nix b/pkgs/development/tools/gauge/plugins/java/default.nix index 1dafc4a04065e7..27a94cdf8aedb3 100644 --- a/pkgs/development/tools/gauge/plugins/java/default.nix +++ b/pkgs/development/tools/gauge/plugins/java/default.nix @@ -1,5 +1,6 @@ -{ lib -, makeGaugePlugin +{ + lib, + makeGaugePlugin, }: makeGaugePlugin { pname = "java"; @@ -19,6 +20,11 @@ makeGaugePlugin { # Jar files binaryBytecode ]; - platforms = [ "aarch64-darwin" "x86_64-darwin" "aarch64-linux" "x86_64-linux" ]; + platforms = [ + "aarch64-darwin" + "x86_64-darwin" + "aarch64-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/development/tools/gauge/plugins/js/default.nix b/pkgs/development/tools/gauge/plugins/js/default.nix index 20af0ab0f8f978..c3f2923cdb313a 100644 --- a/pkgs/development/tools/gauge/plugins/js/default.nix +++ b/pkgs/development/tools/gauge/plugins/js/default.nix @@ -1,9 +1,10 @@ -{ lib -, nodejs -, buildNpmPackage -, fetchFromGitHub -, unzip -, gauge-unwrapped +{ + lib, + nodejs, + buildNpmPackage, + fetchFromGitHub, + unzip, + gauge-unwrapped, }: buildNpmPackage rec { pname = "gauge-plugin-js"; diff --git a/pkgs/development/tools/gauge/plugins/make-gauge-plugin.nix b/pkgs/development/tools/gauge/plugins/make-gauge-plugin.nix index 71f88a2c40ae67..1bf16e984bea7f 100644 --- a/pkgs/development/tools/gauge/plugins/make-gauge-plugin.nix +++ b/pkgs/development/tools/gauge/plugins/make-gauge-plugin.nix @@ -1,23 +1,40 @@ -{ stdenvNoCC -, fetchzip -, lib -, writeScript -, autoPatchelfHook -, testGaugePlugins +{ + stdenvNoCC, + fetchzip, + lib, + writeScript, + autoPatchelfHook, + testGaugePlugins, }: -{ pname -, data -, repo -, releasePrefix -, isCrossArch ? false -, meta -, ... -} @ args: +{ + pname, + data, + repo, + releasePrefix, + isCrossArch ? false, + meta, + ... +}@args: let - otherArgs = lib.attrsets.removeAttrs args [ "pname" "data" "repo" "releasePrefix" "isMultiArch" ]; + otherArgs = lib.attrsets.removeAttrs args [ + "pname" + "data" + "repo" + "releasePrefix" + "isMultiArch" + ]; inherit (stdenvNoCC.hostPlatform) system; - inherit (if isCrossArch then data else data.${system} or (throw "gaugePlugins.${pname}: No source for system: ${system}")) url hash; + inherit + ( + if isCrossArch then + data + else + data.${system} or (throw "gaugePlugins.${pname}: No source for system: ${system}") + ) + url + hash + ; # Upstream uses a different naming scheme for platforms systemMap = { "x86_64-darwin" = "darwin.x86_64"; @@ -26,76 +43,84 @@ let "x86_64-linux" = "linux.x86_64"; }; in -stdenvNoCC.mkDerivation (finalAttrs: (lib.recursiveUpdate { - pname = "gauge-plugin-${pname}"; - inherit (data) version; - - src = fetchzip { - inherit url hash; - stripRoot = false; - }; - - nativeBuildInputs = lib.optional stdenvNoCC.hostPlatform.isLinux autoPatchelfHook; - - installPhase = '' - mkdir -p "$out/share/gauge-plugins/${pname}/${finalAttrs.version}" - cp -r . "$out/share/gauge-plugins/${pname}/${finalAttrs.version}" - ''; +stdenvNoCC.mkDerivation ( + finalAttrs: + (lib.recursiveUpdate { + pname = "gauge-plugin-${pname}"; + inherit (data) version; + + src = fetchzip { + inherit url hash; + stripRoot = false; + }; + + nativeBuildInputs = lib.optional stdenvNoCC.hostPlatform.isLinux autoPatchelfHook; + + installPhase = '' + mkdir -p "$out/share/gauge-plugins/${pname}/${finalAttrs.version}" + cp -r . "$out/share/gauge-plugins/${pname}/${finalAttrs.version}" + ''; - passthru = { - tests.loadPlugin = testGaugePlugins { plugins = [ finalAttrs.finalPackage ]; }; - updateScript = writeScript "update-${finalAttrs.pname}" '' - #!/usr/bin/env nix-shell - #!nix-shell -i bash -p curl nix-prefetch yq-go + passthru = { + tests.loadPlugin = testGaugePlugins { plugins = [ finalAttrs.finalPackage ]; }; + updateScript = writeScript "update-${finalAttrs.pname}" '' + #!/usr/bin/env nix-shell + #!nix-shell -i bash -p curl nix-prefetch yq-go - set -e + set -e - dirname="pkgs/development/tools/gauge/plugins/${pname}" + dirname="pkgs/development/tools/gauge/plugins/${pname}" - currentVersion=$(nix eval --raw -f default.nix gaugePlugins.${pname}.version) + currentVersion=$(nix eval --raw -f default.nix gaugePlugins.${pname}.version) - latestTag=$(curl -s ''${GITHUB_TOKEN:+-u ":$GITHUB_TOKEN"} https://api.github.com/repos/${repo}/releases/latest | yq ".tag_name") - latestVersion="$(expr $latestTag : 'v\(.*\)')" + latestTag=$(curl -s ''${GITHUB_TOKEN:+-u ":$GITHUB_TOKEN"} https://api.github.com/repos/${repo}/releases/latest | yq ".tag_name") + latestVersion="$(expr $latestTag : 'v\(.*\)')" - tempfile=$(mktemp) + tempfile=$(mktemp) - if [[ "$FORCE_UPDATE" != "true" && "$currentVersion" == "$latestVersion" ]]; then - echo "gauge-${pname} is up-to-date: ''${currentVersion}" - exit 0 - fi + if [[ "$FORCE_UPDATE" != "true" && "$currentVersion" == "$latestVersion" ]]; then + echo "gauge-${pname} is up-to-date: ''${currentVersion}" + exit 0 + fi - yq -iPoj "{ \"version\": \"$latestVersion\" }" "$tempfile" + yq -iPoj "{ \"version\": \"$latestVersion\" }" "$tempfile" - updateSystem() { - system=$1 - url=$2 + updateSystem() { + system=$1 + url=$2 - echo "Fetching hash for $system" - hash=$(nix-prefetch-url --type sha256 $url --unpack) - sriHash="$(nix hash to-sri --type sha256 $hash)" + echo "Fetching hash for $system" + hash=$(nix-prefetch-url --type sha256 $url --unpack) + sriHash="$(nix hash to-sri --type sha256 $hash)" - yq -iPoj ". + { \"$system\": { \"url\": \"$url\", \"hash\": \"$sriHash\" } }" "$tempfile" - } + yq -iPoj ". + { \"$system\": { \"url\": \"$url\", \"hash\": \"$sriHash\" } }" "$tempfile" + } - updateSingle() { - url=$1 + updateSingle() { + url=$1 - echo "Fetching hash" - hash=$(nix-prefetch-url --type sha256 $url --unpack) - sriHash="$(nix hash to-sri --type sha256 $hash)" + echo "Fetching hash" + hash=$(nix-prefetch-url --type sha256 $url --unpack) + sriHash="$(nix hash to-sri --type sha256 $hash)" - yq -iPoj ". + { \"url\": \"$url\", \"hash\": \"$sriHash\" }" "$tempfile" - } + yq -iPoj ". + { \"url\": \"$url\", \"hash\": \"$sriHash\" }" "$tempfile" + } - baseUrl="https://github.com/${repo}/releases/download/$latestTag/${releasePrefix}$latestVersion" + baseUrl="https://github.com/${repo}/releases/download/$latestTag/${releasePrefix}$latestVersion" - ${if isCrossArch then - "updateSingle \${baseUrl}.zip" - else - lib.concatStringsSep "\n" (map (platform: ''updateSystem "${platform}" "''${baseUrl}-${systemMap.${platform}}.zip"'') meta.platforms) - } + ${ + if isCrossArch then + "updateSingle \${baseUrl}.zip" + else + lib.concatStringsSep "\n" ( + map ( + platform: ''updateSystem "${platform}" "''${baseUrl}-${systemMap.${platform}}.zip"'' + ) meta.platforms + ) + } - mv "$tempfile" "$dirname/data.json" - ''; - }; -} otherArgs)) + mv "$tempfile" "$dirname/data.json" + ''; + }; + } otherArgs) +) diff --git a/pkgs/development/tools/gauge/plugins/ruby/default.nix b/pkgs/development/tools/gauge/plugins/ruby/default.nix index 9a5283b649a140..017dbf3b6b8c62 100644 --- a/pkgs/development/tools/gauge/plugins/ruby/default.nix +++ b/pkgs/development/tools/gauge/plugins/ruby/default.nix @@ -1,5 +1,6 @@ -{ lib -, makeGaugePlugin +{ + lib, + makeGaugePlugin, }: makeGaugePlugin { pname = "ruby"; @@ -14,6 +15,11 @@ makeGaugePlugin { license = lib.licenses.asl20; maintainers = with lib.maintainers; [ marie ]; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; - platforms = [ "aarch64-darwin" "x86_64-darwin" "aarch64-linux" "x86_64-linux" ]; + platforms = [ + "aarch64-darwin" + "x86_64-darwin" + "aarch64-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/development/tools/gauge/plugins/screenshot/default.nix b/pkgs/development/tools/gauge/plugins/screenshot/default.nix index a394338d7a641e..26ac349837765c 100644 --- a/pkgs/development/tools/gauge/plugins/screenshot/default.nix +++ b/pkgs/development/tools/gauge/plugins/screenshot/default.nix @@ -1,5 +1,6 @@ -{ lib -, makeGaugePlugin +{ + lib, + makeGaugePlugin, }: makeGaugePlugin { pname = "screenshot"; @@ -14,6 +15,11 @@ makeGaugePlugin { license = lib.licenses.gpl3; maintainers = with lib.maintainers; [ marie ]; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; - platforms = [ "x86_64-darwin" "aarch64-darwin" "aarch64-linux" "x86_64-linux" ]; + platforms = [ + "x86_64-darwin" + "aarch64-darwin" + "aarch64-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/development/tools/gauge/plugins/xml-report/default.nix b/pkgs/development/tools/gauge/plugins/xml-report/default.nix index 0337ceca0605a5..154c2f3de244d1 100644 --- a/pkgs/development/tools/gauge/plugins/xml-report/default.nix +++ b/pkgs/development/tools/gauge/plugins/xml-report/default.nix @@ -1,5 +1,6 @@ -{ lib -, makeGaugePlugin +{ + lib, + makeGaugePlugin, }: makeGaugePlugin { pname = "xml-report"; @@ -14,6 +15,11 @@ makeGaugePlugin { license = lib.licenses.asl20; maintainers = with lib.maintainers; [ marie ]; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; - platforms = [ "x86_64-darwin" "aarch64-darwin" "aarch64-linux" "x86_64-linux" ]; + platforms = [ + "x86_64-darwin" + "aarch64-darwin" + "aarch64-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/development/tools/gauge/wrapper.nix b/pkgs/development/tools/gauge/wrapper.nix index 8f4ceca25e9ebc..fcdfcaacb277c5 100644 --- a/pkgs/development/tools/gauge/wrapper.nix +++ b/pkgs/development/tools/gauge/wrapper.nix @@ -1,12 +1,13 @@ -{ gauge-unwrapped -, gauge -, makeWrapper -, stdenvNoCC -, lib -, xorg -, gaugePlugins -, plugins ? [] -, runCommand +{ + gauge-unwrapped, + gauge, + makeWrapper, + stdenvNoCC, + lib, + xorg, + gaugePlugins, + plugins ? [ ], + runCommand, }: stdenvNoCC.mkDerivation { @@ -44,18 +45,28 @@ stdenvNoCC.mkDerivation { --set GAUGE_HOME "$GAUGE_HOME" ''; - nativeBuildInputs = [ gauge-unwrapped makeWrapper xorg.lndir ]; + nativeBuildInputs = [ + gauge-unwrapped + makeWrapper + xorg.lndir + ]; passthru = { withPlugins = f: gauge.override { plugins = f gaugePlugins; }; - fromManifest = path: + fromManifest = + path: let manifest = lib.importJSON path; requiredPlugins = with manifest; [ Language ] ++ Plugins; - manifestPlugins = plugins: map (name: plugins.${name} or (throw "Gauge plugin ${name} is not available!")) requiredPlugins; - in gauge.withPlugins manifestPlugins; + manifestPlugins = + plugins: + map (name: plugins.${name} or (throw "Gauge plugin ${name} is not available!")) requiredPlugins; + in + gauge.withPlugins manifestPlugins; # Builds gauge with all plugins and checks for successful installation - tests.allPlugins = gaugePlugins.testGaugePlugins { plugins = lib.filter lib.isDerivation (lib.attrValues gaugePlugins); }; + tests.allPlugins = gaugePlugins.testGaugePlugins { + plugins = lib.filter lib.isDerivation (lib.attrValues gaugePlugins); + }; }; inherit (gauge-unwrapped) meta; diff --git a/pkgs/development/tools/geckodriver/default.nix b/pkgs/development/tools/geckodriver/default.nix index 7af8747ef8c4b2..7adc26e81ad59b 100644 --- a/pkgs/development/tools/geckodriver/default.nix +++ b/pkgs/development/tools/geckodriver/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, stdenv -, Security -, libiconv +{ + lib, + fetchFromGitHub, + rustPlatform, + stdenv, + Security, + libiconv, }: rustPlatform.buildRustPackage rec { @@ -19,7 +20,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-gopI5iOCSzD23mvOues76WIiBtpNf9A6X9NoOULm6Qo="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv Security ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Security + ]; meta = with lib; { description = "Proxy for using W3C WebDriver-compatible clients to interact with Gecko-based browsers"; diff --git a/pkgs/development/tools/gemstash/default.nix b/pkgs/development/tools/gemstash/default.nix index 8128c4db290af4..8256c82baa2844 100644 --- a/pkgs/development/tools/gemstash/default.nix +++ b/pkgs/development/tools/gemstash/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerApp, bundlerUpdateScript, nixosTests }: +{ + lib, + bundlerApp, + bundlerUpdateScript, + nixosTests, +}: bundlerApp rec { pname = "gemstash"; @@ -12,8 +17,8 @@ bundlerApp rec { meta = with lib; { description = "Cache for RubyGems.org and a private gem server"; - homepage = "https://github.com/rubygems/gemstash"; - license = licenses.mit; + homepage = "https://github.com/rubygems/gemstash"; + license = licenses.mit; maintainers = [ maintainers.viraptor ]; }; } diff --git a/pkgs/development/tools/gemstash/gemset.nix b/pkgs/development/tools/gemstash/gemset.nix index 8d626cd10367c4..40f7f09fe9e265 100644 --- a/pkgs/development/tools/gemstash/gemset.nix +++ b/pkgs/development/tools/gemstash/gemset.nix @@ -1,454 +1,499 @@ { activesupport = { - dependencies = ["base64" "bigdecimal" "concurrent-ruby" "connection_pool" "drb" "i18n" "logger" "minitest" "securerandom" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "bigdecimal" + "concurrent-ruby" + "connection_pool" + "drb" + "i18n" + "logger" + "minitest" + "securerandom" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1cacrvmn1561fb88fn99ig52wdz1k67s7vbssqwwwljf1kanlgvc"; type = "gem"; }; version = "7.2.1.2"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; connection_pool = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; dalli = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19daxf5n5gr3pr57k4wqg701c3zwsk2h4jjialkaw7yrhi85jqrf"; type = "gem"; }; version = "3.2.8"; }; drb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h5kbj9hvg5hb3c7l425zpds0vb42phvln2knab8nmazg2zp5m79"; type = "gem"; }; version = "2.2.1"; }; faraday = { - dependencies = ["faraday-em_http" "faraday-em_synchrony" "faraday-excon" "faraday-httpclient" "faraday-multipart" "faraday-net_http" "faraday-net_http_persistent" "faraday-patron" "faraday-rack" "faraday-retry" "ruby2_keywords"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-em_http" + "faraday-em_synchrony" + "faraday-excon" + "faraday-httpclient" + "faraday-multipart" + "faraday-net_http" + "faraday-net_http_persistent" + "faraday-patron" + "faraday-rack" + "faraday-retry" + "ruby2_keywords" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "069gmdh5j90v06rbwlqvlhzhq45lxhx74mahz25xd276rm0wb153"; type = "gem"; }; version = "1.10.4"; }; faraday-em_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12cnqpbak4vhikrh2cdn94assh3yxza8rq2p9w2j34bqg5q4qgbs"; type = "gem"; }; version = "1.0.0"; }; faraday-em_synchrony = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vgrbhkp83sngv6k4mii9f2s9v5lmp693hylfxp2ssfc60fas3a6"; type = "gem"; }; version = "1.0.0"; }; faraday-excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h09wkb0k0bhm6dqsd47ac601qiaah8qdzjh8gvxfd376x1chmdh"; type = "gem"; }; version = "1.1.0"; }; faraday-httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fyk0jd3ks7fdn8nv3spnwjpzx2lmxmg2gh4inz3by1zjzqg33sc"; type = "gem"; }; version = "1.0.1"; }; faraday-multipart = { - dependencies = ["multipart-post"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multipart-post" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09871c4hd7s5ws1wl4gs7js1k2wlby6v947m2bbzg43pnld044lh"; type = "gem"; }; version = "1.0.4"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10n6wikd442mfm15hd6gzm0qb527161w1wwch4h5m4iclkz2x6b3"; type = "gem"; }; version = "1.0.2"; }; faraday-net_http_persistent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dc36ih95qw3rlccffcb0vgxjhmipsvxhn6cw71l7ffs0f7vq30b"; type = "gem"; }; version = "1.2.0"; }; faraday-patron = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19wgsgfq0xkski1g7m96snv39la3zxz6x7nbdgiwhg5v82rxfb6w"; type = "gem"; }; version = "1.0.0"; }; faraday-rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h184g4vqql5jv9s9im6igy00jp6mrah2h14py6mpf9bkabfqq7g"; type = "gem"; }; version = "1.0.0"; }; faraday-retry = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "153i967yrwnswqgvnnajgwp981k9p50ys1h80yz3q94rygs59ldd"; type = "gem"; }; version = "1.0.3"; }; faraday_middleware = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1s990pnapb3vci9c00bklqc7jjix4i2zhxn2zf1lfk46xv47hnyl"; type = "gem"; }; version = "1.2.1"; }; gemstash = { - dependencies = ["activesupport" "dalli" "faraday" "faraday_middleware" "lru_redux" "psych" "puma" "sequel" "server_health_check-rack" "sinatra" "sqlite3" "terminal-table" "thor"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "dalli" + "faraday" + "faraday_middleware" + "lru_redux" + "psych" + "puma" + "sequel" + "server_health_check-rack" + "sinatra" + "sqlite3" + "terminal-table" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0sysgn3gxxdyqm08b9ldsbzmp3yhdwgala9dfv5yspw5nkksprpj"; type = "gem"; }; version = "2.7.1"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k31wcgnvcvd14snz0pfqj976zv6drfsnq6x8acz10fiyms9l8nw"; type = "gem"; }; version = "1.14.6"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; lru_redux = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yxghzg7476sivz8yyr9nkak2dlbls0b89vc2kg52k0nmg6d0wgf"; type = "gem"; }; version = "1.1.0"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n1akmc6bibkbxkzm1p1wmfb4n9vv397knkgz0ffykb3h1d7kdix"; type = "gem"; }; version = "5.25.1"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a5lrlvmg2kb2dhw3lxcsv6x276bwgsxpnka1752082miqxd0wlq"; type = "gem"; }; version = "2.4.1"; }; mustermann = { - dependencies = ["ruby2_keywords"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ruby2_keywords" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "123ycmq6pkivv29bqbv79jv2cs04xakzd0fz1lalgvfs5nxfky6i"; type = "gem"; }; version = "3.0.3"; }; nio4r = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "017nbw87dpr4wyk81cgj8kxkxqgsgblrkxnmmadc77cg9gflrfal"; type = "gem"; }; version = "2.7.3"; }; psych = { - dependencies = ["stringio"]; - groups = ["default"]; - platforms = []; + dependencies = [ "stringio" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0s5383m6004q76xm3lb732bp4sjzb6mxb6rbgn129gy2izsj4wrk"; type = "gem"; }; version = "5.1.2"; }; puma = { - dependencies = ["nio4r"]; - groups = ["default"]; - platforms = []; + dependencies = [ "nio4r" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gml1rixrfb0naciq3mrnqkpcvm9ahgps1c04hzxh4b801f69914"; type = "gem"; }; version = "6.4.3"; }; rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ax778fsfvlhj7c11n0d1wdcb8bxvkb190a9lha5d91biwzyx9g4"; type = "gem"; }; version = "2.2.10"; }; rack-protection = { - dependencies = ["base64" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zzvivmdb4dkscc58i3gmcyrnypynsjwp6xgc4ylarlhqmzvlx1w"; type = "gem"; }; version = "3.2.0"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; securerandom = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1phv6kh417vkanhssbjr960c0gfqvf8z7d3d9fd2yvd41q64bw4q"; type = "gem"; }; version = "0.3.1"; }; sequel = { - dependencies = ["bigdecimal"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bigdecimal" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04jjv63wvvi9qfkpfsrv6w74liiqk4cd1qnlk7ja7i2waci9hlzx"; type = "gem"; }; version = "5.85.0"; }; server_health_check = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06chz92parchhj1457lf5lbj3hrmvqpq6mfskxcnj5f4qa14n5wd"; type = "gem"; }; version = "1.0.2"; }; server_health_check-rack = { - dependencies = ["server_health_check"]; - groups = ["default"]; - platforms = []; + dependencies = [ "server_health_check" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cgqr94x18f60n27sk9lgg471c6vk6qy132z7i1ppp32kvmjfphs"; type = "gem"; }; version = "0.1.0"; }; sinatra = { - dependencies = ["mustermann" "rack" "rack-protection" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mustermann" + "rack" + "rack-protection" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "01wq20aqk5kfggq3wagx5xr1cz0x08lg6dxbk9yhd1sf0d6pywkf"; type = "gem"; }; version = "3.2.0"; }; sqlite3 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "sha256-+nf2PHCVSPRtTptrtFzaUqo4gaoSzIWZETJ1jolocBw="; type = "gem"; }; version = "1.7.3"; }; stringio = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07mfqb40b2wh53k33h91zva78f9zwcdnl85jiq74wnaw2wa6wiak"; type = "gem"; }; version = "3.1.1"; }; terminal-table = { - dependencies = ["unicode-display_width"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unicode-display_width" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14dfmfjppmng5hwj7c5ka6qdapawm3h6k9lhn8zj001ybypvclgr"; type = "gem"; }; version = "3.0.2"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nmymd86a0vb39pzj2cwv57avdrl6pl3lf5bsz58q594kqxjkw7f"; type = "gem"; }; version = "1.3.2"; }; tilt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kds7wkxmb038cwp6ravnwn8k65ixc68wpm8j5jx5bhx8ndg4x6z"; type = "gem"; }; version = "2.4.0"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; unicode-display_width = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nkz7fadlrdbkf37m0x7sw8bnz8r355q3vwcfb9f9md6pds9h9qj"; type = "gem"; }; diff --git a/pkgs/development/tools/git-ps-rs/default.nix b/pkgs/development/tools/git-ps-rs/default.nix index 089c03268931cb..10299c5d439b83 100644 --- a/pkgs/development/tools/git-ps-rs/default.nix +++ b/pkgs/development/tools/git-ps-rs/default.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, stdenv -, pkg-config -, dbus -, openssl -, Security +{ + lib, + fetchFromGitHub, + rustPlatform, + stdenv, + pkg-config, + dbus, + openssl, + Security, }: rustPlatform.buildRustPackage rec { @@ -23,7 +24,10 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl dbus ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; + buildInputs = [ + openssl + dbus + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; meta = with lib; { description = "Tool for working with a stack of patches"; diff --git a/pkgs/development/tools/github-changelog-generator/default.nix b/pkgs/development/tools/github-changelog-generator/default.nix index 0239259a0c81eb..4faae1cfe0e6cc 100644 --- a/pkgs/development/tools/github-changelog-generator/default.nix +++ b/pkgs/development/tools/github-changelog-generator/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "github_changelog_generator"; @@ -9,9 +13,12 @@ bundlerApp { meta = with lib; { description = "Fully automated changelog generation - This gem generates a changelog file based on tags, issues and merged pull requests"; - homepage = "https://github.com/github-changelog-generator/github-changelog-generator"; - license = licenses.mit; - maintainers = with maintainers; [ Scriptkiddi nicknovitski ]; - platforms = platforms.unix; + homepage = "https://github.com/github-changelog-generator/github-changelog-generator"; + license = licenses.mit; + maintainers = with maintainers; [ + Scriptkiddi + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/github-changelog-generator/gemset.nix b/pkgs/development/tools/github-changelog-generator/gemset.nix index 3a68811b0f7b4a..4499566e99d54d 100644 --- a/pkgs/development/tools/github-changelog-generator/gemset.nix +++ b/pkgs/development/tools/github-changelog-generator/gemset.nix @@ -1,417 +1,466 @@ { activesupport = { - dependencies = ["concurrent-ruby" "i18n" "minitest" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "i18n" + "minitest" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "02lys9pnb99hsczs551iqzjn008i8k7c728xxba7acfi9rdw9pa6"; type = "gem"; }; version = "7.0.1"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "022r3m9wdxljpbya69y2i3h9g3dhhfaqzidf95m6qjzms792jvgp"; type = "gem"; }; version = "2.8.0"; }; async = { - dependencies = ["console" "nio4r" "timers"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "console" + "nio4r" + "timers" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0mdv66xn5xjyaidyrp66mfnx7d4habkbfmx9y57k75h5q6fd2b65"; type = "gem"; }; version = "1.30.1"; }; async-http = { - dependencies = ["async" "async-io" "async-pool" "protocol-http" "protocol-http1" "protocol-http2"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "async" + "async-io" + "async-pool" + "protocol-http" + "protocol-http1" + "protocol-http2" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0v3451bnn7rhgvl6ng0ys0dgm7cmyi3m41kmf5wyrpb83dhds13l"; type = "gem"; }; version = "0.56.5"; }; async-http-faraday = { - dependencies = ["async-http" "faraday"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "async-http" + "faraday" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ndynkfknabv6m9wzcmdnj4r4bhlxqkg9c6rzsjc1pk8q057kslv"; type = "gem"; }; version = "0.11.0"; }; async-io = { - dependencies = ["async"]; - groups = ["default"]; - platforms = []; + dependencies = [ "async" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10l9m0x2ffvsaaxc4mfalrljjx13njkyir9w6yfif8wpszc291h8"; type = "gem"; }; version = "1.32.2"; }; async-pool = { - dependencies = ["async"]; - groups = ["default"]; - platforms = []; + dependencies = [ "async" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02r6cyvralcv2yn1jj0plxynwr7rvxym13vlxd2wxk1bymfq9fd9"; type = "gem"; }; version = "0.3.9"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nwad3211p7yv9sda31jmbyw6sdafzmdi2i2niaz6f0wk5nq9h0f"; type = "gem"; }; version = "1.1.9"; }; console = { - dependencies = ["fiber-local"]; - groups = ["default"]; - platforms = []; + dependencies = [ "fiber-local" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13ylq7x9zk79r79pssnjvby14shcyamwcbap842p9gvmkf7xblmr"; type = "gem"; }; version = "1.14.0"; }; faraday = { - dependencies = ["faraday-em_http" "faraday-em_synchrony" "faraday-excon" "faraday-httpclient" "faraday-multipart" "faraday-net_http" "faraday-net_http_persistent" "faraday-patron" "faraday-rack" "faraday-retry" "ruby2_keywords"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-em_http" + "faraday-em_synchrony" + "faraday-excon" + "faraday-httpclient" + "faraday-multipart" + "faraday-net_http" + "faraday-net_http_persistent" + "faraday-patron" + "faraday-rack" + "faraday-retry" + "ruby2_keywords" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0y32gj994ll3zlcqjmwp78r7s03iiwayij6fz2pjpkfywgvp71s6"; type = "gem"; }; version = "1.9.3"; }; faraday-em_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12cnqpbak4vhikrh2cdn94assh3yxza8rq2p9w2j34bqg5q4qgbs"; type = "gem"; }; version = "1.0.0"; }; faraday-em_synchrony = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vgrbhkp83sngv6k4mii9f2s9v5lmp693hylfxp2ssfc60fas3a6"; type = "gem"; }; version = "1.0.0"; }; faraday-excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h09wkb0k0bhm6dqsd47ac601qiaah8qdzjh8gvxfd376x1chmdh"; type = "gem"; }; version = "1.1.0"; }; faraday-http-cache = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lhfwlk4mhmw9pdlgdsl2bq4x45w7s51jkxjryf18wym8iiw36g7"; type = "gem"; }; version = "2.2.0"; }; faraday-httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fyk0jd3ks7fdn8nv3spnwjpzx2lmxmg2gh4inz3by1zjzqg33sc"; type = "gem"; }; version = "1.0.1"; }; faraday-multipart = { - dependencies = ["multipart-post"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multipart-post" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03qfi9020ynf7hkdiaq01sd2mllvw7fg4qiin3pk028b4wv23j3j"; type = "gem"; }; version = "1.0.3"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fi8sda5hc54v1w3mqfl5yz09nhx35kglyx72w7b8xxvdr0cwi9j"; type = "gem"; }; version = "1.0.1"; }; faraday-net_http_persistent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dc36ih95qw3rlccffcb0vgxjhmipsvxhn6cw71l7ffs0f7vq30b"; type = "gem"; }; version = "1.2.0"; }; faraday-patron = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19wgsgfq0xkski1g7m96snv39la3zxz6x7nbdgiwhg5v82rxfb6w"; type = "gem"; }; version = "1.0.0"; }; faraday-rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h184g4vqql5jv9s9im6igy00jp6mrah2h14py6mpf9bkabfqq7g"; type = "gem"; }; version = "1.0.0"; }; faraday-retry = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "153i967yrwnswqgvnnajgwp981k9p50ys1h80yz3q94rygs59ldd"; type = "gem"; }; version = "1.0.3"; }; fiber-local = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vrxxb09fc7aicb9zb0pmn5akggjy21dmxkdl3w949y4q05rldr9"; type = "gem"; }; version = "1.0.0"; }; github_changelog_generator = { - dependencies = ["activesupport" "async" "async-http-faraday" "faraday-http-cache" "multi_json" "octokit" "rainbow" "rake"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "async" + "async-http-faraday" + "faraday-http-cache" + "multi_json" + "octokit" + "rainbow" + "rake" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "04d6z2ysq3gzvpw91lq8mxmdlqcxkmvp8rw9zrzkmksh3pjdzli1"; type = "gem"; }; version = "1.16.4"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vdd1kii40qhbr9n8qx71k2gskq6rkl8ygy8hw5hfj8bb5a364xf"; type = "gem"; }; version = "1.8.11"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06xf558gid4w8lwx13jwfdafsch9maz8m0g85wnfymqj63x5nbbd"; type = "gem"; }; version = "5.15.0"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zgw9zlwh2a6i1yvhhc4a84ry1hv824d6g2iw2chs3k5aylpmpfj"; type = "gem"; }; version = "2.1.1"; }; nio4r = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xk64wghkscs6bv2n22853k2nh39d131c6rfpnlw12mbjnnv9v1v"; type = "gem"; }; version = "2.5.8"; }; octokit = { - dependencies = ["faraday" "sawyer"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "sawyer" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1nmdd7klyinvrrv2mggwwmc99ykaq7i379j00i37hvvaqx4giifj"; type = "gem"; }; version = "4.22.0"; }; protocol-hpack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sd85am1hj2w7z5hv19wy1nbisxfr1vqx3wlxjfz9xy7x7s6aczw"; type = "gem"; }; version = "1.4.2"; }; protocol-http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lhg47b3w1d6pdwdkyha8ijzfhjrh90snwydkhwfnl5r10dd9cg5"; type = "gem"; }; version = "0.22.5"; }; protocol-http1 = { - dependencies = ["protocol-http"]; - groups = ["default"]; - platforms = []; + dependencies = [ "protocol-http" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0z56p7zqbyvwlrsbs19knny4v9f7ycsgblhv50ar8wgyifvsddf6"; type = "gem"; }; version = "0.14.2"; }; protocol-http2 = { - dependencies = ["protocol-hpack" "protocol-http"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "protocol-hpack" + "protocol-http" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1a9klpfmi7w465zq5xz8y8h1qvj42hkm0qd0nlws9d2idd767q5j"; type = "gem"; }; version = "0.14.2"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xqcgkl7bwws1qrlnmxgh8g4g9m10vg60bhlw40fplninb3ng6d9"; type = "gem"; }; version = "4.0.6"; }; rainbow = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0smwg4mii0fm38pyb5fddbmrdpifwv22zv3d3px2xx497am93503"; type = "gem"; }; version = "3.1.1"; }; rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15whn7p9nrkxangbs9hh75q585yfn66lv0v2mhj6q6dl6x8bzr2w"; type = "gem"; }; version = "13.0.6"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; sawyer = { - dependencies = ["addressable" "faraday"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "faraday" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0yrdchs3psh583rjapkv33mljdivggqn99wkydkjdckcjn43j3cz"; type = "gem"; }; version = "0.8.2"; }; timers = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00xdi97gm01alfqhjgvv5sff9n1n2l6aym69s9jh8l9clg63b0jc"; type = "gem"; }; version = "4.3.3"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10qp5x7f9hvlc0psv9gsfbxg4a7s0485wsbq1kljkxq94in91l4z"; type = "gem"; }; diff --git a/pkgs/development/tools/github/cligh/default.nix b/pkgs/development/tools/github/cligh/default.nix index bb97fc2e8b3ee2..c6ccd1588cea4c 100644 --- a/pkgs/development/tools/github/cligh/default.nix +++ b/pkgs/development/tools/github/cligh/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildPythonApplication, pyxdg, pygithub }: +{ + lib, + fetchFromGitHub, + buildPythonApplication, + pyxdg, + pygithub, +}: buildPythonApplication rec { pname = "cligh"; @@ -13,18 +19,21 @@ buildPythonApplication rec { sha256 = "0d1fd78rzl2n75xpmy1gnxh1shvcs4qm0j4qqszqvfriwkg2flxn"; }; - propagatedBuildInputs = [ pyxdg pygithub ]; + propagatedBuildInputs = [ + pyxdg + pygithub + ]; meta = with lib; { homepage = "http://the-brannons.com/software/cligh.html"; description = "Simple command-line interface to the facilities of Github"; mainProgram = "cligh"; longDescription = '' - Cligh is a simple command-line interface to the facilities of GitHub. - It is written by Christopher Brannon chris@the-brannons.com. The - current version is 0.3, released July 23, 2016. This program is still - in the early stage of development. It is by no means feature-complete. - A friend and I consider it useful, but others may not. + Cligh is a simple command-line interface to the facilities of GitHub. + It is written by Christopher Brannon chris@the-brannons.com. The + current version is 0.3, released July 23, 2016. This program is still + in the early stage of development. It is by no means feature-complete. + A friend and I consider it useful, but others may not. ''; platforms = platforms.all; license = licenses.bsd3; diff --git a/pkgs/development/tools/glslviewer/default.nix b/pkgs/development/tools/glslviewer/default.nix index 0d950d24bf6068..dc2dc3f7c457ce 100644 --- a/pkgs/development/tools/glslviewer/default.nix +++ b/pkgs/development/tools/glslviewer/default.nix @@ -26,26 +26,28 @@ stdenv.mkDerivation rec { rev = version; hash = "sha256-Ve3wmX5+kABCu8IRe4ySrwsBJm47g1zvMqDbqrpQl88="; }; - nativeBuildInputs = [cmake ninja pkg-config]; - buildInputs = - [ - libX11 - libXrandr - libXinerama - libXcursor - libXi - libXext - libGLU - ncurses - ffmpeg - ] - ++ lib.optional stdenv.hostPlatform.isDarwin Cocoa; + nativeBuildInputs = [ + cmake + ninja + pkg-config + ]; + buildInputs = [ + libX11 + libXrandr + libXinerama + libXcursor + libXi + libXext + libGLU + ncurses + ffmpeg + ] ++ lib.optional stdenv.hostPlatform.isDarwin Cocoa; meta = with lib; { description = "Live GLSL coding renderer"; homepage = "https://patriciogonzalezvivo.com/2015/glslViewer/"; license = licenses.bsd3; - maintainers = [maintainers.hodapp]; + maintainers = [ maintainers.hodapp ]; platforms = platforms.unix; mainProgram = "glslViewer"; # never built on aarch64-darwin since first introduction in nixpkgs diff --git a/pkgs/development/tools/godot/3/debug-server.nix b/pkgs/development/tools/godot/3/debug-server.nix index 5e134d71e1e6c2..fd3c25f004de4f 100644 --- a/pkgs/development/tools/godot/3/debug-server.nix +++ b/pkgs/development/tools/godot/3/debug-server.nix @@ -1,7 +1,9 @@ { godot3-headless }: -godot3-headless.overrideAttrs (self: base: { - pname = "godot3-debug-server"; - godotBuildDescription = "debug server"; - shouldBuildTools = false; -}) +godot3-headless.overrideAttrs ( + self: base: { + pname = "godot3-debug-server"; + godotBuildDescription = "debug server"; + shouldBuildTools = false; + } +) diff --git a/pkgs/development/tools/godot/3/export-templates.nix b/pkgs/development/tools/godot/3/export-templates.nix index 714cd32869c01a..184920bfcde766 100644 --- a/pkgs/development/tools/godot/3/export-templates.nix +++ b/pkgs/development/tools/godot/3/export-templates.nix @@ -1,28 +1,30 @@ { godot3 }: -godot3.overrideAttrs (self: base: { - pname = "godot3-export-templates"; - godotBuildDescription = "nix export templates"; +godot3.overrideAttrs ( + self: base: { + pname = "godot3-export-templates"; + godotBuildDescription = "nix export templates"; - # As described in default.nix, adding the link flags to pulseaudio in detect.py was necessary to - # allow the dlopen calls to succeed in Nix builds of godot. However, it seems that this *breaks* - # the export templates, resulting in programs exported from godot using these export templates to - # be unable to load this library. - shouldAddLinkFlagsToPulse = false; + # As described in default.nix, adding the link flags to pulseaudio in detect.py was necessary to + # allow the dlopen calls to succeed in Nix builds of godot. However, it seems that this *breaks* + # the export templates, resulting in programs exported from godot using these export templates to + # be unable to load this library. + shouldAddLinkFlagsToPulse = false; - shouldBuildTools = false; - godotBuildTarget = "release"; - godotBinInstallPath = "share/godot/templates/${self.version}.stable"; - installedGodotBinName = "linux_${self.godotBuildPlatform}_64_${self.godotBuildTarget}"; + shouldBuildTools = false; + godotBuildTarget = "release"; + godotBinInstallPath = "share/godot/templates/${self.version}.stable"; + installedGodotBinName = "linux_${self.godotBuildPlatform}_64_${self.godotBuildTarget}"; - # https://docs.godotengine.org/en/stable/development/compiling/optimizing_for_size.html - # Stripping reduces the template size from around 500MB to 40MB for Linux. - # This also impacts the size of the exported games. - # This is added explicitly here because mkDerivation does not automatically - # strip binaries in the template directory. - stripAllList = (base.stripAllList or []) ++ [ "share/godot/templates" ]; + # https://docs.godotengine.org/en/stable/development/compiling/optimizing_for_size.html + # Stripping reduces the template size from around 500MB to 40MB for Linux. + # This also impacts the size of the exported games. + # This is added explicitly here because mkDerivation does not automatically + # strip binaries in the template directory. + stripAllList = (base.stripAllList or [ ]) ++ [ "share/godot/templates" ]; - meta = base.meta // { - homepage = "https://docs.godotengine.org/en/stable/development/compiling/compiling_for_x11.html#building-export-templates"; - }; -}) + meta = base.meta // { + homepage = "https://docs.godotengine.org/en/stable/development/compiling/compiling_for_x11.html#building-export-templates"; + }; + } +) diff --git a/pkgs/development/tools/godot/3/headless.nix b/pkgs/development/tools/godot/3/headless.nix index 85b998f3807c35..2e66516c012ba4 100644 --- a/pkgs/development/tools/godot/3/headless.nix +++ b/pkgs/development/tools/godot/3/headless.nix @@ -1,7 +1,9 @@ { godot3 }: -godot3.overrideAttrs (self: base: { - pname = "godot3-headless"; - godotBuildDescription = "headless"; - godotBuildPlatform = "server"; -}) +godot3.overrideAttrs ( + self: base: { + pname = "godot3-headless"; + godotBuildDescription = "headless"; + godotBuildPlatform = "server"; + } +) diff --git a/pkgs/development/tools/godot/3/mono/debug-server.nix b/pkgs/development/tools/godot/3/mono/debug-server.nix index 28c18dbdb2ba07..d0e88ca91cf9fb 100644 --- a/pkgs/development/tools/godot/3/mono/debug-server.nix +++ b/pkgs/development/tools/godot/3/mono/debug-server.nix @@ -1,7 +1,9 @@ { godot3-mono-headless }: -godot3-mono-headless.overrideAttrs (self: base: { - pname = "godot3-mono-debug-server"; - godotBuildDescription = "mono debug server"; - shouldBuildTools = false; -}) +godot3-mono-headless.overrideAttrs ( + self: base: { + pname = "godot3-mono-debug-server"; + godotBuildDescription = "mono debug server"; + shouldBuildTools = false; + } +) diff --git a/pkgs/development/tools/godot/3/mono/default.nix b/pkgs/development/tools/godot/3/mono/default.nix index eafe05691c1e01..340b04e094ef8b 100644 --- a/pkgs/development/tools/godot/3/mono/default.nix +++ b/pkgs/development/tools/godot/3/mono/default.nix @@ -1,47 +1,57 @@ -{ godot3 -, callPackage -, mkNugetDeps -, mono -, dotnet-sdk -, scons -, python311Packages +{ + godot3, + callPackage, + mkNugetDeps, + mono, + dotnet-sdk, + scons, + python311Packages, }: (godot3.override { scons = scons.override { python3Packages = python311Packages; }; -}).overrideAttrs (self: base: { - pname = "godot3-mono"; - - godotBuildDescription = "mono build"; - - nativeBuildInputs = base.nativeBuildInputs ++ [ mono dotnet-sdk ]; - - glue = callPackage ./glue.nix {}; - - buildInputs = base.buildInputs ++ [ - (mkNugetDeps { name = "deps"; nugetDeps = import ./deps.nix; }) - ]; - - sconsFlags = base.sconsFlags ++ [ - "module_mono_enabled=true" - "mono_prefix=${mono}" - ]; - - postConfigure = '' - echo "Setting up buildhome." - mkdir buildhome - export HOME="$PWD"/buildhome - - echo "Overlaying godot glue." - cp -R --no-preserve=mode "$glue"/. . - ''; - - installedGodotShortcutFileName = "org.godotengine.GodotMono3.desktop"; - installedGodotShortcutDisplayName = "Godot Engine (Mono) 3"; - - passthru = { - make-deps = callPackage ./make-deps.nix {}; - }; -}) +}).overrideAttrs + ( + self: base: { + pname = "godot3-mono"; + + godotBuildDescription = "mono build"; + + nativeBuildInputs = base.nativeBuildInputs ++ [ + mono + dotnet-sdk + ]; + + glue = callPackage ./glue.nix { }; + + buildInputs = base.buildInputs ++ [ + (mkNugetDeps { + name = "deps"; + nugetDeps = import ./deps.nix; + }) + ]; + + sconsFlags = base.sconsFlags ++ [ + "module_mono_enabled=true" + "mono_prefix=${mono}" + ]; + + postConfigure = '' + echo "Setting up buildhome." + mkdir buildhome + export HOME="$PWD"/buildhome + + echo "Overlaying godot glue." + cp -R --no-preserve=mode "$glue"/. . + ''; + + installedGodotShortcutFileName = "org.godotengine.GodotMono3.desktop"; + installedGodotShortcutDisplayName = "Godot Engine (Mono) 3"; + + passthru = { + make-deps = callPackage ./make-deps.nix { }; + }; + } + ) diff --git a/pkgs/development/tools/godot/3/mono/deps.nix b/pkgs/development/tools/godot/3/mono/deps.nix index ea909921b4313b..7e5c4469cb6f1b 100644 --- a/pkgs/development/tools/godot/3/mono/deps.nix +++ b/pkgs/development/tools/godot/3/mono/deps.nix @@ -1,34 +1,163 @@ -{ fetchNuGet }: [ - (fetchNuGet { pname = "EnvDTE"; version = "8.0.2"; sha256 = "1wdvjzdmqbqyqlaijpjc959vvdic12vqr3c5sffhbxi7m1si5k63"; }) - (fetchNuGet { pname = "GodotTools.IdeMessaging"; version = "1.1.1"; sha256 = "0v70acpw2yq9mx05jy2gmkqqdbpgj8rb29ny2f3bgvmw9g5qmq94"; }) - (fetchNuGet { pname = "JetBrains.Annotations"; version = "2019.1.3"; sha256 = "188b0qw6lih0k3ddnmimadzr3y1y6vh6ramgkjnyskqd43prjzc2"; }) - (fetchNuGet { pname = "Microsoft.Build"; version = "16.5.0"; sha256 = "0baihvnzanqhk125g0ass9hhsqgp55h770pjjmsxdvprv0aqq22i"; }) - (fetchNuGet { pname = "Microsoft.Build.Framework"; version = "16.5.0"; sha256 = "1xgr02r7s9i6s70n237hss4yi9zicssia3zd2ny6s8vyxb7jpdyb"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.0.1"; sha256 = "01al6cfxp68dscl15z7rxfw9zvhm64dncsw09a1vmdkacsa2v6lr"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.0.1"; sha256 = "0ppdkwy6s9p7x9jix3v4402wb171cdiibq7js7i13nxpdky7074p"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies"; version = "1.0.0"; sha256 = "0na724xhvqm63vq9y18fl9jw9q2v99bdwr353378s5fsi11qzxp9"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies.net472"; version = "1.0.0"; sha256 = "1bqinq2nxnpqxziypg1sqy3ly0nymxxjpn8fwkn3rl4vl6gdg3rc"; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Setup.Configuration.Interop"; version = "1.16.30"; sha256 = "14022lx03vdcqlvbbdmbsxg5pqfx1rfq2jywxlyaz9v68cvsb0g4"; }) - (fetchNuGet { pname = "Mono.Cecil"; version = "0.11.3"; sha256 = "0xcx7pk9y2n1hr15c0l1balzi69kw5gy8dk7sb8jwqyyvm35q4j3"; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; sha256 = "1fn9fxppfcg4jgypp2pmrpr6awl3qz1xmnri0cygpkwvyx27df1y"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.1"; sha256 = "0fijg0w6iwap8gvzyjnndds0q4b8anwxxvik7y8vgq97dram4srb"; }) - (fetchNuGet { pname = "Semver"; version = "2.0.6"; sha256 = "136sd6d3ys49dipvc1h3ivmp8ryd4p7fdmdrr28521cqpvkw5f1k"; }) - (fetchNuGet { pname = "stdole"; version = "7.0.3302"; sha256 = "1n8vbzlgyklazriwvb6kjyw5w0m9a1b3xsa0f0v29j03z23fx69p"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.4.0"; sha256 = "183f8063w8zqn99pv0ni0nnwh7fgx46qzxamwnans55hhs2l0g19"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "1.5.0"; sha256 = "1d5gjn5afnrf461jlxzawcvihz195gayqpcfbv6dd7pxa9ialn06"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.0.11"; sha256 = "070c5jbas2v7smm660zaf1gh0489xanjqymkvafcs4f8cdrs1d5d"; }) - (fetchNuGet { pname = "System.IO"; version = "4.1.0"; sha256 = "1g0yb8p11vfd0kbkyzlfsbsp5z44lwsvyc0h3dpw6vqnbi035ajp"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.3"; sha256 = "0naqahm3wljxb5a911d37mwjqjdxv9l0b49p5dmfyijvni2ppy8a"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.4.0"; sha256 = "0rdvma399070b0i46c4qq1h2yvjj3k013sqzkilz4bz5cwmx1rba"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.1.0"; sha256 = "1js89429pfw79mxvbzp8p3q93il6rdff332hddhzi5wqglc4gml9"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.0.1"; sha256 = "1bangaabhsl4k9fg8khn83wm6yial8ik1sza7401621jc6jrym28"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.0.1"; sha256 = "0b4i7mncaf8cnai85jv3wnw6hps140cxz8vylv2bik6wyzgvz7bi"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.1.0"; sha256 = "02hdkgk13rvsd6r9yafbwzss8kr55wnj8d5c7xjnp8gqrwc8sn0m"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.2"; sha256 = "1vz4275fjij8inf31np78hw50al8nqkngk04p3xv5n4fcmf1grgi"; }) - (fetchNuGet { pname = "System.Runtime.Serialization.Primitives"; version = "4.1.1"; sha256 = "042rfjixknlr6r10vx2pgf56yming8lkjikamg3g4v29ikk78h7k"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.0.11"; sha256 = "1dyqv0hijg265dwxg6l7aiv74102d6xjiwplh2ar1ly6xfaa4iiw"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.0.11"; sha256 = "0nr1r41rak82qfa5m0lhk9mp0k93bvfd7bbd9sdzwx9mb36g28p5"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Dataflow"; version = "4.9.0"; sha256 = "1g6s9pjg4z8iy98df60y9a01imdqy59zd767vz74rrng78jl2dk5"; }) - (fetchNuGet { pname = "System.Threading.Thread"; version = "4.0.0"; sha256 = "1gxxm5fl36pjjpnx1k688dcw8m9l7nmf802nxis6swdaw8k54jzc"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "EnvDTE"; + version = "8.0.2"; + sha256 = "1wdvjzdmqbqyqlaijpjc959vvdic12vqr3c5sffhbxi7m1si5k63"; + }) + (fetchNuGet { + pname = "GodotTools.IdeMessaging"; + version = "1.1.1"; + sha256 = "0v70acpw2yq9mx05jy2gmkqqdbpgj8rb29ny2f3bgvmw9g5qmq94"; + }) + (fetchNuGet { + pname = "JetBrains.Annotations"; + version = "2019.1.3"; + sha256 = "188b0qw6lih0k3ddnmimadzr3y1y6vh6ramgkjnyskqd43prjzc2"; + }) + (fetchNuGet { + pname = "Microsoft.Build"; + version = "16.5.0"; + sha256 = "0baihvnzanqhk125g0ass9hhsqgp55h770pjjmsxdvprv0aqq22i"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Framework"; + version = "16.5.0"; + sha256 = "1xgr02r7s9i6s70n237hss4yi9zicssia3zd2ny6s8vyxb7jpdyb"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.0.1"; + sha256 = "01al6cfxp68dscl15z7rxfw9zvhm64dncsw09a1vmdkacsa2v6lr"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.0.1"; + sha256 = "0ppdkwy6s9p7x9jix3v4402wb171cdiibq7js7i13nxpdky7074p"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies"; + version = "1.0.0"; + sha256 = "0na724xhvqm63vq9y18fl9jw9q2v99bdwr353378s5fsi11qzxp9"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies.net472"; + version = "1.0.0"; + sha256 = "1bqinq2nxnpqxziypg1sqy3ly0nymxxjpn8fwkn3rl4vl6gdg3rc"; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Setup.Configuration.Interop"; + version = "1.16.30"; + sha256 = "14022lx03vdcqlvbbdmbsxg5pqfx1rfq2jywxlyaz9v68cvsb0g4"; + }) + (fetchNuGet { + pname = "Mono.Cecil"; + version = "0.11.3"; + sha256 = "0xcx7pk9y2n1hr15c0l1balzi69kw5gy8dk7sb8jwqyyvm35q4j3"; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + sha256 = "1fn9fxppfcg4jgypp2pmrpr6awl3qz1xmnri0cygpkwvyx27df1y"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.1"; + sha256 = "0fijg0w6iwap8gvzyjnndds0q4b8anwxxvik7y8vgq97dram4srb"; + }) + (fetchNuGet { + pname = "Semver"; + version = "2.0.6"; + sha256 = "136sd6d3ys49dipvc1h3ivmp8ryd4p7fdmdrr28521cqpvkw5f1k"; + }) + (fetchNuGet { + pname = "stdole"; + version = "7.0.3302"; + sha256 = "1n8vbzlgyklazriwvb6kjyw5w0m9a1b3xsa0f0v29j03z23fx69p"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.4.0"; + sha256 = "183f8063w8zqn99pv0ni0nnwh7fgx46qzxamwnans55hhs2l0g19"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "1.5.0"; + sha256 = "1d5gjn5afnrf461jlxzawcvihz195gayqpcfbv6dd7pxa9ialn06"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.0.11"; + sha256 = "070c5jbas2v7smm660zaf1gh0489xanjqymkvafcs4f8cdrs1d5d"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.1.0"; + sha256 = "1g0yb8p11vfd0kbkyzlfsbsp5z44lwsvyc0h3dpw6vqnbi035ajp"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.3"; + sha256 = "0naqahm3wljxb5a911d37mwjqjdxv9l0b49p5dmfyijvni2ppy8a"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.4.0"; + sha256 = "0rdvma399070b0i46c4qq1h2yvjj3k013sqzkilz4bz5cwmx1rba"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.1.0"; + sha256 = "1js89429pfw79mxvbzp8p3q93il6rdff332hddhzi5wqglc4gml9"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.0.1"; + sha256 = "1bangaabhsl4k9fg8khn83wm6yial8ik1sza7401621jc6jrym28"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.0.1"; + sha256 = "0b4i7mncaf8cnai85jv3wnw6hps140cxz8vylv2bik6wyzgvz7bi"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.1.0"; + sha256 = "02hdkgk13rvsd6r9yafbwzss8kr55wnj8d5c7xjnp8gqrwc8sn0m"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.2"; + sha256 = "1vz4275fjij8inf31np78hw50al8nqkngk04p3xv5n4fcmf1grgi"; + }) + (fetchNuGet { + pname = "System.Runtime.Serialization.Primitives"; + version = "4.1.1"; + sha256 = "042rfjixknlr6r10vx2pgf56yming8lkjikamg3g4v29ikk78h7k"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.0.11"; + sha256 = "1dyqv0hijg265dwxg6l7aiv74102d6xjiwplh2ar1ly6xfaa4iiw"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.0.11"; + sha256 = "0nr1r41rak82qfa5m0lhk9mp0k93bvfd7bbd9sdzwx9mb36g28p5"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Dataflow"; + version = "4.9.0"; + sha256 = "1g6s9pjg4z8iy98df60y9a01imdqy59zd767vz74rrng78jl2dk5"; + }) + (fetchNuGet { + pname = "System.Threading.Thread"; + version = "4.0.0"; + sha256 = "1gxxm5fl36pjjpnx1k688dcw8m9l7nmf802nxis6swdaw8k54jzc"; + }) ] diff --git a/pkgs/development/tools/godot/3/mono/export-templates.nix b/pkgs/development/tools/godot/3/mono/export-templates.nix index da0d7cb2be3cab..e89ca1e2fcc200 100644 --- a/pkgs/development/tools/godot/3/mono/export-templates.nix +++ b/pkgs/development/tools/godot/3/mono/export-templates.nix @@ -1,28 +1,30 @@ { godot3-mono }: -godot3-mono.overrideAttrs (self: base: { - pname = "godot3-mono-export-templates"; - godotBuildDescription = "nix mono export templates"; +godot3-mono.overrideAttrs ( + self: base: { + pname = "godot3-mono-export-templates"; + godotBuildDescription = "nix mono export templates"; - # As described in default.nix, adding the link flags to pulseaudio in detect.py was necessary to - # allow the dlopen calls to succeed in Nix builds of godot. However, it seems that this *breaks* - # the export templates, resulting in programs exported from godot using these export templates to - # be unable to load this library. - shouldAddLinkFlagsToPulse = false; + # As described in default.nix, adding the link flags to pulseaudio in detect.py was necessary to + # allow the dlopen calls to succeed in Nix builds of godot. However, it seems that this *breaks* + # the export templates, resulting in programs exported from godot using these export templates to + # be unable to load this library. + shouldAddLinkFlagsToPulse = false; - shouldBuildTools = false; - godotBuildTarget = "release"; - godotBinInstallPath = "share/godot/templates/${self.version}.stable.mono"; - installedGodotBinName = "linux_${self.godotBuildPlatform}_64_${self.godotBuildTarget}"; + shouldBuildTools = false; + godotBuildTarget = "release"; + godotBinInstallPath = "share/godot/templates/${self.version}.stable.mono"; + installedGodotBinName = "linux_${self.godotBuildPlatform}_64_${self.godotBuildTarget}"; - # https://docs.godotengine.org/en/stable/development/compiling/optimizing_for_size.html - # Stripping reduces the template size from around 500MB to 40MB for Linux. - # This also impacts the size of the exported games. - # This is added explicitly here because mkDerivation does not automatically - # strip binaries in the template directory. - stripAllList = (base.stripAllList or []) ++ [ "share/godot/templates" ]; + # https://docs.godotengine.org/en/stable/development/compiling/optimizing_for_size.html + # Stripping reduces the template size from around 500MB to 40MB for Linux. + # This also impacts the size of the exported games. + # This is added explicitly here because mkDerivation does not automatically + # strip binaries in the template directory. + stripAllList = (base.stripAllList or [ ]) ++ [ "share/godot/templates" ]; - meta = base.meta // { - homepage = "https://docs.godotengine.org/en/stable/development/compiling/compiling_with_mono.html#export-templates"; - }; -}) + meta = base.meta // { + homepage = "https://docs.godotengine.org/en/stable/development/compiling/compiling_with_mono.html#export-templates"; + }; + } +) diff --git a/pkgs/development/tools/godot/3/mono/glue.nix b/pkgs/development/tools/godot/3/mono/glue.nix index 09659d0ab48d69..b8901d0e386ba8 100644 --- a/pkgs/development/tools/godot/3/mono/glue.nix +++ b/pkgs/development/tools/godot/3/mono/glue.nix @@ -1,70 +1,76 @@ -{ godot3, mono, scons, python311Packages }: +{ + godot3, + mono, + scons, + python311Packages, +}: (godot3.override { scons = scons.override { python3Packages = python311Packages; }; -}).overrideAttrs (self: base: { - pname = "godot3-mono-glue"; - godotBuildDescription = "mono glue"; - godotBuildPlatform = "server"; +}).overrideAttrs + ( + self: base: { + pname = "godot3-mono-glue"; + godotBuildDescription = "mono glue"; + godotBuildPlatform = "server"; - sconsFlags = base.sconsFlags ++ [ - "module_mono_enabled=true" - "mono_glue=false" # Indicates not to expect already existing glue. - "mono_prefix=${mono}" - ]; + sconsFlags = base.sconsFlags ++ [ + "module_mono_enabled=true" + "mono_glue=false" # Indicates not to expect already existing glue. + "mono_prefix=${mono}" + ]; - nativeBuildInputs = base.nativeBuildInputs ++ [ mono ]; + nativeBuildInputs = base.nativeBuildInputs ++ [ mono ]; - patches = - base.patches ++ - map (rp: ./patches + rp) ( - [ - # When building godot mono, a "glue version" gets baked into it, and into the mono glue code - # generated by it. Godot mono export templates are also get a glue version baked in. If you - # export a godot mono project using an export template for which the glue version doesn't - # match that of the godot mono tool itself, then the resulting game will fail with an error - # saying "The assembly 'GodotSharp' is out of sync." Thus, if we want our build of godot mono - # to be compatible with the official export templates, we need to ensure it is built with the - # same glue version as the official build. - # - # A python script in the godot source, i.e. modules/mono/build_scripts/gen_cs_glue_version.py, - # is used by the build process to generate the glue version number. The official version of it - # does so based on the latest modified time of all the C# files in the GodotSharp solution. This - # is problematic because it is difficult to reproduce the exact timestamps that the files had - # when the official build was created. This is further complicated by the fact that nix clears - # the timestamps on the source files when they're unpacked. Thus, we can't simply regenerate the - # official glue version by building from the official source. - # - # To address this, we are patching the python script with a hard-coded glue version number. This - # patch file needs to be updated for every new version of godot, so to enforce this, the godot - # version is baked in to the file name, causing the build to fail until the patch is updated. - # - # The correct glue version number for a given godot version is obtained by running the official - # build of that version of godot with the --generate-mono-glue flag. This generates the mono - # glue files. One of those files, mono_glue.gen.cpp, has a function called get_cs_glue_version() - # which contains a hard-coded number. This is the glue version to put in the patch file. - # - # For convenience, the accompanying update-glue-version.sh script automates this work. Run it by - # passing the godot version as an argument, e.g. "3.5.2". - "/gen_cs_glue_version.py/hardcodeGlueVersion_${self.version}.patch" - ] - ); + patches = + base.patches + ++ map (rp: ./patches + rp) ([ + # When building godot mono, a "glue version" gets baked into it, and into the mono glue code + # generated by it. Godot mono export templates are also get a glue version baked in. If you + # export a godot mono project using an export template for which the glue version doesn't + # match that of the godot mono tool itself, then the resulting game will fail with an error + # saying "The assembly 'GodotSharp' is out of sync." Thus, if we want our build of godot mono + # to be compatible with the official export templates, we need to ensure it is built with the + # same glue version as the official build. + # + # A python script in the godot source, i.e. modules/mono/build_scripts/gen_cs_glue_version.py, + # is used by the build process to generate the glue version number. The official version of it + # does so based on the latest modified time of all the C# files in the GodotSharp solution. This + # is problematic because it is difficult to reproduce the exact timestamps that the files had + # when the official build was created. This is further complicated by the fact that nix clears + # the timestamps on the source files when they're unpacked. Thus, we can't simply regenerate the + # official glue version by building from the official source. + # + # To address this, we are patching the python script with a hard-coded glue version number. This + # patch file needs to be updated for every new version of godot, so to enforce this, the godot + # version is baked in to the file name, causing the build to fail until the patch is updated. + # + # The correct glue version number for a given godot version is obtained by running the official + # build of that version of godot with the --generate-mono-glue flag. This generates the mono + # glue files. One of those files, mono_glue.gen.cpp, has a function called get_cs_glue_version() + # which contains a hard-coded number. This is the glue version to put in the patch file. + # + # For convenience, the accompanying update-glue-version.sh script automates this work. Run it by + # passing the godot version as an argument, e.g. "3.5.2". + "/gen_cs_glue_version.py/hardcodeGlueVersion_${self.version}.patch" + ]); - outputs = [ "out" ]; + outputs = [ "out" ]; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - glue="$out"/modules/mono/glue - mkdir -p "$glue" - bin/godot_server.x11.opt.tools.*.mono --generate-mono-glue "$glue" + glue="$out"/modules/mono/glue + mkdir -p "$glue" + bin/godot_server.x11.opt.tools.*.mono --generate-mono-glue "$glue" - runHook postInstall - ''; + runHook postInstall + ''; - meta = base.meta // { - homepage = "https://docs.godotengine.org/en/stable/development/compiling/compiling_with_mono.html#generate-the-glue"; - }; -}) + meta = base.meta // { + homepage = "https://docs.godotengine.org/en/stable/development/compiling/compiling_with_mono.html#generate-the-glue"; + }; + } + ) diff --git a/pkgs/development/tools/godot/3/mono/headless.nix b/pkgs/development/tools/godot/3/mono/headless.nix index fff5367e86132b..8d96948b8a111c 100644 --- a/pkgs/development/tools/godot/3/mono/headless.nix +++ b/pkgs/development/tools/godot/3/mono/headless.nix @@ -1,7 +1,9 @@ { godot3-mono }: -godot3-mono.overrideAttrs (self: base: { - pname = "godot3-mono-headless"; - godotBuildDescription = "mono headless"; - godotBuildPlatform = "server"; -}) +godot3-mono.overrideAttrs ( + self: base: { + pname = "godot3-mono-headless"; + godotBuildDescription = "mono headless"; + godotBuildPlatform = "server"; + } +) diff --git a/pkgs/development/tools/godot/3/mono/make-deps.nix b/pkgs/development/tools/godot/3/mono/make-deps.nix index b654576daced44..00914f824277b4 100644 --- a/pkgs/development/tools/godot/3/mono/make-deps.nix +++ b/pkgs/development/tools/godot/3/mono/make-deps.nix @@ -1,60 +1,69 @@ -{ godot3-mono, nuget-to-nix, nixfmt-rfc-style }: - -godot3-mono.overrideAttrs (self: base: { - pname = "godot3-mono-make-deps"; - - nativeBuildInputs = base.nativeBuildInputs ++ [ nuget-to-nix nixfmt-rfc-style ]; - - nugetDeps = null; - nugetSource = null; - nugetConfig = null; - - keepNugetConfig = true; - - outputs = [ "out" ]; - buildPhase = " "; - installPhase = ''echo "No output intended. Run make-deps.sh instead." > $out''; - - # This script is used to update the accompanying deps.nix file, a nix expression listing the - # nuget packages that the godot-mono code depends on, along with their sha256 hashes. This - # file is referenced by the godot-mono derivation and needs to be updated every time the - # godot version is updated. The way it works is: - # - # 1) Creates and navigates to a temporary directory and then explicitly runs the unpack, - # patch, and configure phases from the godot-mono derivation. - # 2) Instead of building at this point, a nuget restore is performed, downloading all the - # nuget dependencies of godot-mono into a local folder. - # 3) Once these have been downloaded, the nuget-to-nix tool is used to generate a nix - # expression listing the locally obtained nuget packages, along with their sha256 hashes. - # 4) This nix expression is saved as deps.nix in the PWD. - # - # This process is impure, because it entails downloading files with unknown hashes, so it - # is run manually by the maintainer within a nix-shell environment. Running the accompanying - # make-deps.sh instead simplifies this. - makeDeps = '' - set -e - outdir="$(pwd)" - wrkdir="$(mktemp -d)" - trap 'rm -rf -- "$wrkdir"' EXIT - pushd "$wrkdir" > /dev/null - unpackPhase - cd source - patchPhase - configurePhase - - # Without RestorePackagesPath set, it restores packages to a temp directory. Specifying - # a path ensures we have a place to run nuget-to-nix. - nugetRestore() { dotnet msbuild -t:Restore -p:RestorePackagesPath=nugetPackages $1; } - - nugetRestore modules/mono/glue/GodotSharp/GodotSharp.sln - nugetRestore modules/mono/editor/GodotTools/GodotTools.sln - - nuget-to-nix nugetPackages > "$outdir"/deps.nix - nixfmt "$outdir"/deps.nix - popd > /dev/null - ''; - - meta = base.meta // { - description = "Derivation with no output that exists to provide an environment for make-deps.sh"; - }; -}) +{ + godot3-mono, + nuget-to-nix, + nixfmt-rfc-style, +}: + +godot3-mono.overrideAttrs ( + self: base: { + pname = "godot3-mono-make-deps"; + + nativeBuildInputs = base.nativeBuildInputs ++ [ + nuget-to-nix + nixfmt-rfc-style + ]; + + nugetDeps = null; + nugetSource = null; + nugetConfig = null; + + keepNugetConfig = true; + + outputs = [ "out" ]; + buildPhase = " "; + installPhase = ''echo "No output intended. Run make-deps.sh instead." > $out''; + + # This script is used to update the accompanying deps.nix file, a nix expression listing the + # nuget packages that the godot-mono code depends on, along with their sha256 hashes. This + # file is referenced by the godot-mono derivation and needs to be updated every time the + # godot version is updated. The way it works is: + # + # 1) Creates and navigates to a temporary directory and then explicitly runs the unpack, + # patch, and configure phases from the godot-mono derivation. + # 2) Instead of building at this point, a nuget restore is performed, downloading all the + # nuget dependencies of godot-mono into a local folder. + # 3) Once these have been downloaded, the nuget-to-nix tool is used to generate a nix + # expression listing the locally obtained nuget packages, along with their sha256 hashes. + # 4) This nix expression is saved as deps.nix in the PWD. + # + # This process is impure, because it entails downloading files with unknown hashes, so it + # is run manually by the maintainer within a nix-shell environment. Running the accompanying + # make-deps.sh instead simplifies this. + makeDeps = '' + set -e + outdir="$(pwd)" + wrkdir="$(mktemp -d)" + trap 'rm -rf -- "$wrkdir"' EXIT + pushd "$wrkdir" > /dev/null + unpackPhase + cd source + patchPhase + configurePhase + + # Without RestorePackagesPath set, it restores packages to a temp directory. Specifying + # a path ensures we have a place to run nuget-to-nix. + nugetRestore() { dotnet msbuild -t:Restore -p:RestorePackagesPath=nugetPackages $1; } + + nugetRestore modules/mono/glue/GodotSharp/GodotSharp.sln + nugetRestore modules/mono/editor/GodotTools/GodotTools.sln + + nuget-to-nix nugetPackages > "$outdir"/deps.nix + nixfmt "$outdir"/deps.nix + popd > /dev/null + ''; + + meta = base.meta // { + description = "Derivation with no output that exists to provide an environment for make-deps.sh"; + }; + } +) diff --git a/pkgs/development/tools/godot/3/mono/server.nix b/pkgs/development/tools/godot/3/mono/server.nix index 28049f320a0fdb..9cf1d8774fe911 100644 --- a/pkgs/development/tools/godot/3/mono/server.nix +++ b/pkgs/development/tools/godot/3/mono/server.nix @@ -1,7 +1,9 @@ { godot3-mono-debug-server }: -godot3-mono-debug-server.overrideAttrs (self: base: { - pname = "godot3-mono-server"; - godotBuildDescription = "mono server"; - godotBuildTarget = "release"; -}) +godot3-mono-debug-server.overrideAttrs ( + self: base: { + pname = "godot3-mono-server"; + godotBuildDescription = "mono server"; + godotBuildTarget = "release"; + } +) diff --git a/pkgs/development/tools/godot/3/server.nix b/pkgs/development/tools/godot/3/server.nix index d2c4939167f184..8a41bf8698ff45 100644 --- a/pkgs/development/tools/godot/3/server.nix +++ b/pkgs/development/tools/godot/3/server.nix @@ -1,7 +1,9 @@ { godot3-debug-server }: -godot3-debug-server.overrideAttrs (self: base: { - pname = "godot3-server"; - godotBuildDescription = "server"; - godotBuildTarget = "release"; -}) +godot3-debug-server.overrideAttrs ( + self: base: { + pname = "godot3-server"; + godotBuildDescription = "server"; + godotBuildTarget = "release"; + } +) diff --git a/pkgs/development/tools/gptcommit/default.nix b/pkgs/development/tools/gptcommit/default.nix index 1a4036d7718907..6ef0590ffbf5a7 100644 --- a/pkgs/development/tools/gptcommit/default.nix +++ b/pkgs/development/tools/gptcommit/default.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, nix-update-script -, Security -, SystemConfiguration -, openssl +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + nix-update-script, + Security, + SystemConfiguration, + openssl, }: let @@ -30,7 +31,11 @@ rustPlatform.buildRustPackage { # 0.5.6 release has failing tests doCheck = false; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Security SystemConfiguration ] + buildInputs = + lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ openssl ]; passthru = { @@ -46,4 +51,3 @@ rustPlatform.buildRustPackage { platforms = with platforms; all; }; } - diff --git a/pkgs/development/tools/graphql-client/default.nix b/pkgs/development/tools/graphql-client/default.nix index 8fe6ff5bcf083a..8a9817bd430d40 100644 --- a/pkgs/development/tools/graphql-client/default.nix +++ b/pkgs/development/tools/graphql-client/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, rustPlatform, fetchCrate, pkg-config, openssl, Security }: +{ + lib, + stdenv, + rustPlatform, + fetchCrate, + pkg-config, + openssl, + Security, +}: rustPlatform.buildRustPackage rec { pname = "graphql-client"; @@ -23,7 +31,10 @@ rustPlatform.buildRustPackage rec { description = "GraphQL tool for Rust projects"; mainProgram = "graphql-client"; homepage = "https://github.com/graphql-rust/graphql-client"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ bbigras ]; }; } diff --git a/pkgs/development/tools/haskell/dconf2nix/dconf2nix.nix b/pkgs/development/tools/haskell/dconf2nix/dconf2nix.nix index eae92da1926730..0b3ff069c8122b 100644 --- a/pkgs/development/tools/haskell/dconf2nix/dconf2nix.nix +++ b/pkgs/development/tools/haskell/dconf2nix/dconf2nix.nix @@ -1,5 +1,15 @@ -{ mkDerivation, base, containers, emojis, fetchgit, hedgehog, lib -, optparse-applicative, parsec, template-haskell, text +{ + mkDerivation, + base, + containers, + emojis, + fetchgit, + hedgehog, + lib, + optparse-applicative, + parsec, + template-haskell, + text, }: mkDerivation { pname = "dconf2nix"; @@ -13,11 +23,21 @@ mkDerivation { isLibrary = true; isExecutable = true; libraryHaskellDepends = [ - base containers emojis optparse-applicative parsec text + base + containers + emojis + optparse-applicative + parsec + text ]; executableHaskellDepends = [ base ]; testHaskellDepends = [ - base containers hedgehog parsec template-haskell text + base + containers + hedgehog + parsec + template-haskell + text ]; description = "Convert dconf files to Nix, as expected by Home Manager"; license = lib.licenses.asl20; diff --git a/pkgs/development/tools/haskell/dconf2nix/default.nix b/pkgs/development/tools/haskell/dconf2nix/default.nix index 4cc137b54f75bd..dc07938f5d59e5 100644 --- a/pkgs/development/tools/haskell/dconf2nix/default.nix +++ b/pkgs/development/tools/haskell/dconf2nix/default.nix @@ -1,25 +1,29 @@ -{ haskell, haskellPackages, lib, runCommand }: +{ + haskell, + haskellPackages, + lib, + runCommand, +}: let - dconf2nix = - haskell.lib.compose.justStaticExecutables - (haskell.lib.compose.overrideCabal (oldAttrs: { - maintainers = (oldAttrs.maintainers or []) ++ [ - lib.maintainers.gvolpe - ]; - }) haskellPackages.dconf2nix); + dconf2nix = haskell.lib.compose.justStaticExecutables ( + haskell.lib.compose.overrideCabal (oldAttrs: { + maintainers = (oldAttrs.maintainers or [ ]) ++ [ + lib.maintainers.gvolpe + ]; + }) haskellPackages.dconf2nix + ); in dconf2nix.overrideAttrs (oldAttrs: { - passthru = (oldAttrs.passthru or {}) // { + passthru = (oldAttrs.passthru or { }) // { updateScript = ./update.sh; # These tests can be run with the following command. # # $ nix-build -A dconf2nix.passthru.tests tests = - runCommand - "dconf2nix-tests" + runCommand "dconf2nix-tests" { nativeBuildInputs = [ dconf2nix diff --git a/pkgs/development/tools/haskell/hadrian/ghc-platform.nix b/pkgs/development/tools/haskell/hadrian/ghc-platform.nix index 3b1b17fba2c7b6..cb8a193d7ff6dc 100644 --- a/pkgs/development/tools/haskell/hadrian/ghc-platform.nix +++ b/pkgs/development/tools/haskell/hadrian/ghc-platform.nix @@ -1,7 +1,10 @@ -{ mkDerivation, base, lib +{ + mkDerivation, + base, + lib, # GHC source tree to build ghc-toolchain from -, ghcSrc -, ghcVersion + ghcSrc, + ghcVersion, }: mkDerivation { pname = "ghc-platform"; diff --git a/pkgs/development/tools/haskell/hadrian/ghc-toolchain.nix b/pkgs/development/tools/haskell/hadrian/ghc-toolchain.nix index 035fee7aca8065..328367a5729e9f 100644 --- a/pkgs/development/tools/haskell/hadrian/ghc-toolchain.nix +++ b/pkgs/development/tools/haskell/hadrian/ghc-toolchain.nix @@ -1,8 +1,16 @@ -{ mkDerivation, base, directory, filepath, ghc-platform, lib -, process, text, transformers +{ + mkDerivation, + base, + directory, + filepath, + ghc-platform, + lib, + process, + text, + transformers, # GHC source tree to build ghc-toolchain from -, ghcVersion -, ghcSrc + ghcVersion, + ghcSrc, }: mkDerivation { pname = "ghc-toolchain"; @@ -12,7 +20,13 @@ mkDerivation { sourceRoot="$sourceRoot/utils/ghc-toolchain" ''; libraryHaskellDepends = [ - base directory filepath ghc-platform process text transformers + base + directory + filepath + ghc-platform + process + text + transformers ]; description = "Utility for managing GHC target toolchains"; license = lib.licenses.bsd3; diff --git a/pkgs/development/tools/haskell/hadrian/hadrian.nix b/pkgs/development/tools/haskell/hadrian/hadrian.nix index d1368427f0c9f0..e65481b79da2fb 100644 --- a/pkgs/development/tools/haskell/hadrian/hadrian.nix +++ b/pkgs/development/tools/haskell/hadrian/hadrian.nix @@ -1,16 +1,31 @@ # See also ./make-hadria.nix -{ mkDerivation, base, bytestring, Cabal, containers, directory -, extra, filepath, lib, mtl, parsec, shake, text, transformers -, unordered-containers, cryptohash-sha256, base16-bytestring -, writeText +{ + mkDerivation, + base, + bytestring, + Cabal, + containers, + directory, + extra, + filepath, + lib, + mtl, + parsec, + shake, + text, + transformers, + unordered-containers, + cryptohash-sha256, + base16-bytestring, + writeText, # Dependencies that are not on Hackage and only used in certain Hadrian versions -, ghc-platform ? null -, ghc-toolchain ? null + ghc-platform ? null, + ghc-toolchain ? null, # GHC source tree to build hadrian from -, ghcSrc -, ghcVersion + ghcSrc, + ghcVersion, # Customization -, userSettings ? null + userSettings ? null, }: mkDerivation { @@ -34,14 +49,30 @@ mkDerivation { ]; isLibrary = false; isExecutable = true; - executableHaskellDepends = [ - base bytestring Cabal containers directory extra filepath mtl - parsec shake text transformers unordered-containers - ] ++ lib.optionals (lib.versionAtLeast ghcVersion "9.7") [ - cryptohash-sha256 base16-bytestring - ] ++ lib.optionals (lib.versionAtLeast ghcVersion "9.9") [ - ghc-platform ghc-toolchain - ]; + executableHaskellDepends = + [ + base + bytestring + Cabal + containers + directory + extra + filepath + mtl + parsec + shake + text + transformers + unordered-containers + ] + ++ lib.optionals (lib.versionAtLeast ghcVersion "9.7") [ + cryptohash-sha256 + base16-bytestring + ] + ++ lib.optionals (lib.versionAtLeast ghcVersion "9.9") [ + ghc-platform + ghc-toolchain + ]; passthru = { # Expose »private« dependencies if any inherit ghc-platform ghc-toolchain; diff --git a/pkgs/development/tools/haskell/hadrian/make-hadrian.nix b/pkgs/development/tools/haskell/hadrian/make-hadrian.nix index 8db821a9794d8e..463d485e242e7e 100644 --- a/pkgs/development/tools/haskell/hadrian/make-hadrian.nix +++ b/pkgs/development/tools/haskell/hadrian/make-hadrian.nix @@ -21,23 +21,30 @@ # related packages that are managed in the GHC source tree. Its main job is to # expose all possible compile time customization in a common interface and # take care of all differences between Hadrian versions. -{ bootPkgs -, lib +{ + bootPkgs, + lib, }: -{ # GHC source tree and version to build hadrian & friends from. +{ + # GHC source tree and version to build hadrian & friends from. # These are passed on to the actual package expressions. - ghcSrc -, ghcVersion + ghcSrc, + ghcVersion, # Contents of a non-default UserSettings.hs to use when building hadrian, if any. # Should be a string or null. -, userSettings ? null + userSettings ? null, }: let - callPackage' = f: args: bootPkgs.callPackage f ({ - inherit ghcSrc ghcVersion; - } // args); + callPackage' = + f: args: + bootPkgs.callPackage f ( + { + inherit ghcSrc ghcVersion; + } + // args + ); ghc-platform = callPackage' ./ghc-platform.nix { }; ghc-toolchain = callPackage' ./ghc-toolchain.nix { @@ -45,14 +52,18 @@ let }; in -callPackage' ./hadrian.nix ({ - inherit userSettings; -} // lib.optionalAttrs (lib.versionAtLeast ghcVersion "9.9") { - # Starting with GHC 9.9 development, additional in tree packages are required - # to build hadrian. (Hackage-released conditional dependencies are handled - # in ./hadrian.nix without requiring intervention here.) - inherit ghc-platform ghc-toolchain; -} // lib.optionalAttrs (lib.versionAtLeast ghcVersion "9.11") { - # See https://gitlab.haskell.org/ghc/ghc/-/commit/145a6477854d4003a07573d5e7ffa0c9a64ae29c - Cabal = bootPkgs.Cabal_3_14_0_0; -}) +callPackage' ./hadrian.nix ( + { + inherit userSettings; + } + // lib.optionalAttrs (lib.versionAtLeast ghcVersion "9.9") { + # Starting with GHC 9.9 development, additional in tree packages are required + # to build hadrian. (Hackage-released conditional dependencies are handled + # in ./hadrian.nix without requiring intervention here.) + inherit ghc-platform ghc-toolchain; + } + // lib.optionalAttrs (lib.versionAtLeast ghcVersion "9.11") { + # See https://gitlab.haskell.org/ghc/ghc/-/commit/145a6477854d4003a07573d5e7ffa0c9a64ae29c + Cabal = bootPkgs.Cabal_3_14_0_0; + } +) diff --git a/pkgs/development/tools/haskell/haskell-language-server/withWrapper.nix b/pkgs/development/tools/haskell/haskell-language-server/withWrapper.nix index 14cc0760be222f..0d343e055cbebc 100644 --- a/pkgs/development/tools/haskell/haskell-language-server/withWrapper.nix +++ b/pkgs/development/tools/haskell/haskell-language-server/withWrapper.nix @@ -1,36 +1,40 @@ -{ lib -, stdenv -, haskellPackages -, haskell - -# Which GHC versions this hls can support. -# These are looked up in nixpkgs as `pkgs.haskell.packages."ghc${version}`. -# Run -# $ nix-instantiate --eval -E 'with import {}; builtins.attrNames pkgs.haskell.packages' -# to list for your nixpkgs version. -, supportedGhcVersions ? [ "96" ] - -# Whether to build hls with the dynamic run-time system. -# See https://haskell-language-server.readthedocs.io/en/latest/troubleshooting.html#static-binaries for more information. -, dynamic ? true - -# Which formatters are supported. Pass `[]` to remove all formatters. -# -# Maintainers: if a new formatter is added, add it here and down in knownFormatters -, supportedFormatters ? [ "ormolu" "fourmolu" "floskell" "stylish-haskell" ] +{ + lib, + stdenv, + haskellPackages, + haskell, + + # Which GHC versions this hls can support. + # These are looked up in nixpkgs as `pkgs.haskell.packages."ghc${version}`. + # Run + # $ nix-instantiate --eval -E 'with import {}; builtins.attrNames pkgs.haskell.packages' + # to list for your nixpkgs version. + supportedGhcVersions ? [ "96" ], + + # Whether to build hls with the dynamic run-time system. + # See https://haskell-language-server.readthedocs.io/en/latest/troubleshooting.html#static-binaries for more information. + dynamic ? true, + + # Which formatters are supported. Pass `[]` to remove all formatters. + # + # Maintainers: if a new formatter is added, add it here and down in knownFormatters + supportedFormatters ? [ + "ormolu" + "fourmolu" + "floskell" + "stylish-haskell" + ], }: # make sure the user only sets GHC versions that actually exist -assert supportedGhcVersions != []; -assert - lib.asserts.assertEachOneOf - "supportedGhcVersions" - supportedGhcVersions - (lib.pipe haskell.packages [ - lib.attrNames - (lib.filter (lib.hasPrefix "ghc")) - (map (lib.removePrefix "ghc")) - ]); +assert supportedGhcVersions != [ ]; +assert lib.asserts.assertEachOneOf "supportedGhcVersions" supportedGhcVersions ( + lib.pipe haskell.packages [ + lib.attrNames + (lib.filter (lib.hasPrefix "ghc")) + (map (lib.removePrefix "ghc")) + ] +); let # A mapping from formatter name to @@ -66,11 +70,9 @@ let in # make sure any formatter that is set is actually supported by us -assert - lib.asserts.assertEachOneOf - "supportedFormatters" - supportedFormatters - (lib.attrNames knownFormatters); +assert lib.asserts.assertEachOneOf "supportedFormatters" supportedFormatters ( + lib.attrNames knownFormatters +); # # The recommended way to override this package is @@ -95,7 +97,7 @@ let let # only formatters that were not requested unwanted = lib.pipe knownFormatters [ - (lib.filterAttrs (fmt: _: ! (lib.elem fmt supportedFormatters))) + (lib.filterAttrs (fmt: _: !(lib.elem fmt supportedFormatters))) lib.attrsToList ]; # all flags to disable @@ -108,45 +110,51 @@ let # remove all unwanted dependencies of formatters we don’t want stripDeps = overrideCabal (drv: { - libraryHaskellDepends = lib.pipe (drv.libraryHaskellDepends or []) [ + libraryHaskellDepends = lib.pipe (drv.libraryHaskellDepends or [ ]) [ # the existing list may contain nulls, so let’s strip them first stripNulls - (lib.filter (dep: ! (lib.elem dep.pname deps))) + (lib.filter (dep: !(lib.elem dep.pname deps))) ]; }); - in drv: lib.pipe drv ([stripDeps] ++ map disableCabalFlag flags); - - tunedHls = hsPkgs: - lib.pipe hsPkgs.haskell-language-server ([ - (haskell.lib.compose.overrideCabal (old: { - enableSharedExecutables = dynamic; - ${if !dynamic then "postInstall" else null} = '' - ${old.postInstall or ""} - - remove-references-to -t ${hsPkgs.ghc} $out/bin/haskell-language-server - ''; - })) - ((if dynamic then enableCabalFlag else disableCabalFlag) "dynamic") - removeUnnecessaryFormatters - ] - ++ lib.optionals (!dynamic) [ - justStaticExecutables - ]); - - targets = version: - let packages = getPackages version; - in [ "haskell-language-server-${packages.ghc.version}" ]; - - makeSymlinks = version: - lib.concatMapStringsSep "\n" - (x: - "ln -s ${ - tunedHls (getPackages version) - }/bin/haskell-language-server $out/bin/${x}") - (targets version); - -in stdenv.mkDerivation { + in + drv: lib.pipe drv ([ stripDeps ] ++ map disableCabalFlag flags); + + tunedHls = + hsPkgs: + lib.pipe hsPkgs.haskell-language-server ( + [ + (haskell.lib.compose.overrideCabal (old: { + enableSharedExecutables = dynamic; + ${if !dynamic then "postInstall" else null} = '' + ${old.postInstall or ""} + + remove-references-to -t ${hsPkgs.ghc} $out/bin/haskell-language-server + ''; + })) + ((if dynamic then enableCabalFlag else disableCabalFlag) "dynamic") + removeUnnecessaryFormatters + ] + ++ lib.optionals (!dynamic) [ + justStaticExecutables + ] + ); + + targets = + version: + let + packages = getPackages version; + in + [ "haskell-language-server-${packages.ghc.version}" ]; + + makeSymlinks = + version: + lib.concatMapStringsSep "\n" ( + x: "ln -s ${tunedHls (getPackages version)}/bin/haskell-language-server $out/bin/${x}" + ) (targets version); + +in +stdenv.mkDerivation { pname = "haskell-language-server"; version = haskellPackages.haskell-language-server.version; @@ -160,8 +168,7 @@ in stdenv.mkDerivation { maintainers = [ lib.maintainers.maralorn ]; longDescription = '' This package provides the executables ${ - lib.concatMapStringsSep ", " (x: lib.concatStringsSep ", " (targets x)) - supportedGhcVersions + lib.concatMapStringsSep ", " (x: lib.concatStringsSep ", " (targets x)) supportedGhcVersions } and haskell-language-server-wrapper. You can choose for which ghc versions to install hls with pkgs.haskell-language-server.override { supportedGhcVersions = [ "90" "92" ]; }. ''; diff --git a/pkgs/development/tools/haskell/ihaskell/wrapper.nix b/pkgs/development/tools/haskell/ihaskell/wrapper.nix index a2d73ae7c8165a..14c9ae409c2279 100644 --- a/pkgs/development/tools/haskell/ihaskell/wrapper.nix +++ b/pkgs/development/tools/haskell/ihaskell/wrapper.nix @@ -1,23 +1,44 @@ -{ lib, stdenv, writeScriptBin, makeWrapper, buildEnv, ghcWithPackages, jupyter, packages }: +{ + lib, + stdenv, + writeScriptBin, + makeWrapper, + buildEnv, + ghcWithPackages, + jupyter, + packages, +}: let - ihaskellEnv = ghcWithPackages (self: [ - self.ihaskell - self.ihaskell-blaze - # Doesn't work with latest ihaskell versions missing an unrelated change - # https://github.com/IHaskell/IHaskell/issues/1378 - # self.ihaskell-diagrams - ] ++ packages self); + ihaskellEnv = ghcWithPackages ( + self: + [ + self.ihaskell + self.ihaskell-blaze + # Doesn't work with latest ihaskell versions missing an unrelated change + # https://github.com/IHaskell/IHaskell/issues/1378 + # self.ihaskell-diagrams + ] + ++ packages self + ); ihaskellSh = writeScriptBin "ihaskell-notebook" '' #! ${stdenv.shell} export GHC_PACKAGE_PATH="$(echo ${ihaskellEnv}/lib/*/package.conf.d| tr ' ' ':'):$GHC_PACKAGE_PATH" - export PATH="${lib.makeBinPath ([ ihaskellEnv jupyter ])}''${PATH:+:}$PATH" + export PATH="${ + lib.makeBinPath ([ + ihaskellEnv + jupyter + ]) + }''${PATH:+:}$PATH" ${ihaskellEnv}/bin/ihaskell install -l $(${ihaskellEnv}/bin/ghc --print-libdir) && ${jupyter}/bin/jupyter notebook ''; in buildEnv { name = "ihaskell-with-packages"; nativeBuildInputs = [ makeWrapper ]; - paths = [ ihaskellEnv jupyter ]; + paths = [ + ihaskellEnv + jupyter + ]; postBuild = '' ln -s ${ihaskellSh}/bin/ihaskell-notebook $out/bin/ for prg in $out/bin"/"*;do diff --git a/pkgs/development/tools/haskell/lambdabot/default.nix b/pkgs/development/tools/haskell/lambdabot/default.nix index b563fa4b7a75e3..0109e1ea2934a4 100644 --- a/pkgs/development/tools/haskell/lambdabot/default.nix +++ b/pkgs/development/tools/haskell/lambdabot/default.nix @@ -1,41 +1,53 @@ -{ lib, haskellLib, makeWrapper, haskellPackages -, mueval -, withDjinn ? true -, aspell ? null -, packages ? (pkgs: []) -, modules ? "oldDefaultModules" -, configuration ? "[]" +{ + lib, + haskellLib, + makeWrapper, + haskellPackages, + mueval, + withDjinn ? true, + aspell ? null, + packages ? (pkgs: [ ]), + modules ? "oldDefaultModules", + configuration ? "[]", }: -let allPkgs = pkgs: mueval.defaultPkgs pkgs ++ [ pkgs.lambdabot-trusted ] ++ packages pkgs; - mueval' = mueval.override { - inherit haskellPackages; - packages = allPkgs; - }; - bins = lib.makeBinPath ([ mueval' - (haskellPackages.ghcWithHoogle allPkgs) - haskellPackages.unlambda - haskellPackages.brainfuck - ] - ++ lib.optional withDjinn haskellPackages.djinn - ++ lib.optional (aspell != null) aspell - ); - modulesStr = lib.replaceStrings ["\n"] [" "] modules; - configStr = lib.replaceStrings ["\n"] [" "] configuration; +let + allPkgs = pkgs: mueval.defaultPkgs pkgs ++ [ pkgs.lambdabot-trusted ] ++ packages pkgs; + mueval' = mueval.override { + inherit haskellPackages; + packages = allPkgs; + }; + bins = lib.makeBinPath ( + [ + mueval' + (haskellPackages.ghcWithHoogle allPkgs) + haskellPackages.unlambda + haskellPackages.brainfuck + ] + ++ lib.optional withDjinn haskellPackages.djinn + ++ lib.optional (aspell != null) aspell + ); + modulesStr = lib.replaceStrings [ "\n" ] [ " " ] modules; + configStr = lib.replaceStrings [ "\n" ] [ " " ] configuration; -in haskellLib.overrideCabal (self: { - patches = (self.patches or []) ++ [ ./custom-config.patch ]; - postPatch = (self.postPatch or "") + '' - substituteInPlace src/Main.hs \ - --replace '@config@' '${configStr}' - substituteInPlace src/Modules.hs \ - --replace '@modules@' '${modulesStr}' - ''; +in +haskellLib.overrideCabal (self: { + patches = (self.patches or [ ]) ++ [ ./custom-config.patch ]; + postPatch = + (self.postPatch or "") + + '' + substituteInPlace src/Main.hs \ + --replace '@config@' '${configStr}' + substituteInPlace src/Modules.hs \ + --replace '@modules@' '${modulesStr}' + ''; - buildTools = (self.buildTools or []) ++ [ makeWrapper ]; + buildTools = (self.buildTools or [ ]) ++ [ makeWrapper ]; - postInstall = (self.postInstall or "") + '' - wrapProgram $out/bin/lambdabot \ - --prefix PATH ":" '${bins}' - ''; + postInstall = + (self.postInstall or "") + + '' + wrapProgram $out/bin/lambdabot \ + --prefix PATH ":" '${bins}' + ''; }) haskellPackages.lambdabot diff --git a/pkgs/development/tools/haskell/vaultenv/default.nix b/pkgs/development/tools/haskell/vaultenv/default.nix index e3adef87524568..72114fbadbe787 100644 --- a/pkgs/development/tools/haskell/vaultenv/default.nix +++ b/pkgs/development/tools/haskell/vaultenv/default.nix @@ -1,31 +1,32 @@ -{ mkDerivation -, async -, base -, bytestring -, connection -, containers -, directory -, hpack -, hspec -, hspec-discover -, hspec-expectations -, http-client -, http-conduit -, lens -, lens-aeson -, megaparsec -, mtl -, optparse-applicative -, parser-combinators -, retry -, lib -, quickcheck-instances -, text -, unix -, unordered-containers -, utf8-string -, fetchFromGitHub -, dotenv +{ + mkDerivation, + async, + base, + bytestring, + connection, + containers, + directory, + hpack, + hspec, + hspec-discover, + hspec-expectations, + http-client, + http-conduit, + lens, + lens-aeson, + megaparsec, + mtl, + optparse-applicative, + parser-combinators, + retry, + lib, + quickcheck-instances, + text, + unix, + unordered-containers, + utf8-string, + fetchFromGitHub, + dotenv, }: mkDerivation rec { pname = "vaultenv"; @@ -97,5 +98,8 @@ mkDerivation rec { homepage = "https://github.com/channable/vaultenv#readme"; description = "Runs processes with secrets from HashiCorp Vault"; license = lib.licenses.bsd3; - maintainers = with lib.maintainers; [ lnl7 manveru ]; + maintainers = with lib.maintainers; [ + lnl7 + manveru + ]; } diff --git a/pkgs/development/tools/hors/default.nix b/pkgs/development/tools/hors/default.nix index 03f53f1eabafd4..b2217078394dd6 100644 --- a/pkgs/development/tools/hors/default.nix +++ b/pkgs/development/tools/hors/default.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, stdenv, Security }: +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + Security, +}: rustPlatform.buildRustPackage rec { pname = "hors"; diff --git a/pkgs/development/tools/hotdoc/default.nix b/pkgs/development/tools/hotdoc/default.nix index 9a1bfe9ded9e1c..a8c1b30f53f8ad 100644 --- a/pkgs/development/tools/hotdoc/default.nix +++ b/pkgs/development/tools/hotdoc/default.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, buildPythonApplication -, fetchpatch -, fetchPypi -, pytestCheckHook -, pkg-config -, cmake -, flex -, glib -, json-glib -, libxml2 -, appdirs -, dbus-deviation -, faust-cchardet -, feedgen -, lxml -, networkx -, pkgconfig -, pyyaml -, schema -, setuptools -, toposort -, wheezy-template -, llvmPackages -, gst_all_1 +{ + lib, + stdenv, + buildPythonApplication, + fetchpatch, + fetchPypi, + pytestCheckHook, + pkg-config, + cmake, + flex, + glib, + json-glib, + libxml2, + appdirs, + dbus-deviation, + faust-cchardet, + feedgen, + lxml, + networkx, + pkgconfig, + pyyaml, + schema, + setuptools, + toposort, + wheezy-template, + llvmPackages, + gst_all_1, }: buildPythonApplication rec { @@ -66,7 +67,7 @@ buildPythonApplication rec { pkgconfig pyyaml schema - setuptools # for pkg_resources + setuptools # for pkg_resources toposort wheezy-template ]; @@ -86,16 +87,21 @@ buildPythonApplication rec { ]; # Run the tests by package instead of current dir - pytestFlagsArray = [ "--pyargs" "hotdoc" ]; - - disabledTests = [ - # Test does not correctly handle path normalization for test comparison - "test_cli_overrides" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # Test does not correctly handle absolute /home paths on Darwin (even fake ones) - "test_index" + pytestFlagsArray = [ + "--pyargs" + "hotdoc" ]; + disabledTests = + [ + # Test does not correctly handle path normalization for test comparison + "test_cli_overrides" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # Test does not correctly handle absolute /home paths on Darwin (even fake ones) + "test_index" + ]; + # Hardcode libclang paths postPatch = '' substituteInPlace hotdoc/extensions/c/c_extension.py \ diff --git a/pkgs/development/tools/htmlq/default.nix b/pkgs/development/tools/htmlq/default.nix index e9767ca60029f4..120521c71b6cc6 100644 --- a/pkgs/development/tools/htmlq/default.nix +++ b/pkgs/development/tools/htmlq/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, +}: rustPlatform.buildRustPackage rec { pname = "htmlq"; @@ -21,7 +27,10 @@ rustPlatform.buildRustPackage rec { description = "Like jq, but for HTML"; homepage = "https://github.com/mgdm/htmlq"; license = licenses.mit; - maintainers = with maintainers; [ siraben nerdypepper ]; + maintainers = with maintainers; [ + siraben + nerdypepper + ]; mainProgram = "htmlq"; }; } diff --git a/pkgs/development/tools/iaca/2.1.nix b/pkgs/development/tools/iaca/2.1.nix index e368d608d59372..dea1cbd9d76e14 100644 --- a/pkgs/development/tools/iaca/2.1.nix +++ b/pkgs/development/tools/iaca/2.1.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, makeWrapper, requireFile, gcc, unzip }: +{ + lib, + stdenv, + makeWrapper, + requireFile, + gcc, + unzip, +}: # v2.1: last version with NHM/WSM arch support stdenv.mkDerivation rec { @@ -16,12 +23,19 @@ stdenv.mkDerivation rec { cp bin/iaca $out/bin/ cp lib/* $out/lib ''; - preFixup = let libPath = lib.makeLibraryPath [ stdenv.cc.cc gcc ]; in '' - patchelf \ - --set-interpreter ${stdenv.cc.libc}/lib/ld-linux-x86-64.so.2 \ - --set-rpath $out/lib:"${libPath}" \ - $out/bin/iaca - ''; + preFixup = + let + libPath = lib.makeLibraryPath [ + stdenv.cc.cc + gcc + ]; + in + '' + patchelf \ + --set-interpreter ${stdenv.cc.libc}/lib/ld-linux-x86-64.so.2 \ + --set-rpath $out/lib:"${libPath}" \ + $out/bin/iaca + ''; postFixup = "wrapProgram $out/bin/iaca --set LD_LIBRARY_PATH $out/lib"; meta = with lib; { description = "Intel Architecture Code Analyzer"; diff --git a/pkgs/development/tools/iaca/3.0.nix b/pkgs/development/tools/iaca/3.0.nix index 1c0a4f5460fd5a..742aadae3a2a8a 100644 --- a/pkgs/development/tools/iaca/3.0.nix +++ b/pkgs/development/tools/iaca/3.0.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, requireFile, unzip }: +{ + lib, + stdenv, + requireFile, + unzip, +}: stdenv.mkDerivation rec { pname = "iaca"; diff --git a/pkgs/development/tools/ilspycmd/deps.nix b/pkgs/development/tools/ilspycmd/deps.nix index f95ab0d6c4f0e4..a4a02ffbfd6c6e 100644 --- a/pkgs/development/tools/ilspycmd/deps.nix +++ b/pkgs/development/tools/ilspycmd/deps.nix @@ -1,78 +1,371 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "K4os.Compression.LZ4"; version = "1.3.5"; sha256 = "1nv9inhz0n25lhkw9xgp6g5xbqmcdccdhx6mwrli0pdp6hjmlh9k"; }) - (fetchNuGet { pname = "McMaster.Extensions.CommandLineUtils"; version = "3.1.0"; sha256 = "075n1mfsxwz514r94l8i3ax0wp43c3xb4f9w25a96h6xxnj0k2hd"; }) - (fetchNuGet { pname = "Microsoft.Build.Tasks.Git"; version = "1.1.1"; sha256 = "1bb5p4zlnfn88skkvymxfsn0jybqncl4356hwnic9jxdq2d4fz1w"; }) - (fetchNuGet { pname = "Microsoft.NETCore.App.Ref"; version = "6.0.0"; sha256 = "1skgkralqkg2srvgvrmbsmya67f37gzk40lg28j8nz5mg8k8g0ia"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; }) - (fetchNuGet { pname = "Microsoft.SourceLink.Common"; version = "1.1.1"; sha256 = "0xkdqs7az2cprar7jzjlgjpd64l6f8ixcmwmpkdm03fyb4s5m0bg"; }) - (fetchNuGet { pname = "Microsoft.SourceLink.GitHub"; version = "1.1.1"; sha256 = "099y35f2npvva3jk1zp8hn0vb9pwm2l0ivjasdly6y2idv53s5yy"; }) - (fetchNuGet { pname = "Mono.Cecil"; version = "0.11.4"; sha256 = "1yxa7mh432s7g7p9r7scqxvxjk5ypwc567qdbf0gmk8fbf0d3f8y"; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; sha256 = "1fn9fxppfcg4jgypp2pmrpr6awl3qz1xmnri0cygpkwvyx27df1y"; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "16rnxzpk5dpbbl1x354yrlsbvwylrq456xzpsha1n9y3glnhyx9d"; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0hkg03sgm2wyq8nqk6dbm9jh5vcq57ry42lkqdmfklrw89lsmr59"; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0c2p354hjx58xhhz7wv6div8xpi90sc6ibdm40qin21bvi7ymcaa"; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; }) - (fetchNuGet { pname = "runtime.native.System.IO.Compression"; version = "4.3.0"; sha256 = "1vvivbqsk6y4hzcid27pqpm5bsi6sc50hvqwbcx8aap5ifrxfs8d"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "18pzfdlwsg2nb1jjjjzyb5qlgy6xjxzmhnfaijq5s2jw3cm3ab97"; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0qyynf9nz5i7pc26cwhgi8j62ps27sqmf78ijcfgzab50z9g8ay3"; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "1klrs545awhayryma6l7g2pvnp9xy4z0r1i40r80zb45q3i9nbyf"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0zcxjv5pckplvkg0r6mw3asggm7aqzbdjimhvsasb0cgm59x09l3"; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0vhynn79ih7hw7cwjazn87rm9z9fj0rvxgzlab36jybgcpcgphsn"; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "160p68l2c7cqmyqjwxydcvgw7lvl1cr0znkw8fp24d1by9mqc8p3"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "15zrc8fgd8zx28hdghcj5f5i34wf3l6bq5177075m2bc2j34jrqy"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "1p4dgxax6p7rlgj4q73k73rslcnz4wdcv8q2flg1s8ygwcm58ld5"; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "6.0.0"; sha256 = "1js98kmjn47ivcvkjqdmyipzknb9xbndssczm8gq224pbaj1p88c"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "7.0.0"; sha256 = "1n9122cy6v3qhsisc9lzwa1m1j62b8pi2678nsmnlyvfpk0zdagm"; }) - (fetchNuGet { pname = "System.ComponentModel.Annotations"; version = "5.0.0"; sha256 = "021h7x98lblq9avm1bgpa4i31c2kgsa7zn4sqhxf39g087ar756j"; }) - (fetchNuGet { pname = "System.Composition"; version = "6.0.0"; sha256 = "1p7hysns39cc24af6dwd4m48bqjsrr3clvi4aws152mh2fgyg50z"; }) - (fetchNuGet { pname = "System.Composition.AttributedModel"; version = "6.0.0"; sha256 = "1mqrblb0l65hw39d0hnspqcv85didpn4wbiwhfgj4784wzqx2w6k"; }) - (fetchNuGet { pname = "System.Composition.Convention"; version = "6.0.0"; sha256 = "02km3yb94p1c4s7liyhkmda0g71zm1rc8ijsfmy4bnlkq15xjw3b"; }) - (fetchNuGet { pname = "System.Composition.Hosting"; version = "6.0.0"; sha256 = "0big5nk8c44rxp6cfykhk7rxvn2cgwa99w6c3v2a36adc3lj36ky"; }) - (fetchNuGet { pname = "System.Composition.Runtime"; version = "6.0.0"; sha256 = "0vq5ik63yii1784gsa2f2kx9w6xllmm8b8rk0arid1jqdj1nyrlw"; }) - (fetchNuGet { pname = "System.Composition.TypedParts"; version = "6.0.0"; sha256 = "0y9pq3y60nyrpfy51f576a0qjjdh61mcv8vnik32pm4bz56h9q72"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; }) - (fetchNuGet { pname = "System.IO.Compression"; version = "4.3.0"; sha256 = "084zc82yi6yllgda0zkgl2ys48sypiswbiwrv7irb3r0ai1fp4vz"; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.4.0"; sha256 = "0rdvma399070b0i46c4qq1h2yvjj3k013sqzkilz4bz5cwmx1rba"; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "6.0.0"; sha256 = "1x0b289r9yjzdqypi2x3dc8sa66s3b6bpc7l2f8hxrzl6czdg4al"; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "7.0.0"; sha256 = "1wilasn2qmj870h2bhw348lspamm7pbinpb4m89icg113510l00v"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; }) - (fetchNuGet { pname = "System.Runtime.Loader"; version = "4.3.0"; sha256 = "07fgipa93g1xxgf7193a6vw677mpzgr0z0cfswbvqqb364cva8dk"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; }) - (fetchNuGet { pname = "TunnelVisionLabs.ReferenceAssemblyAnnotator"; version = "1.0.0-alpha.160"; sha256 = "1wvfa3098a984kydjgjvx43gncnr89fw20if2gqvz8kqn9pxqjbq"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "K4os.Compression.LZ4"; + version = "1.3.5"; + sha256 = "1nv9inhz0n25lhkw9xgp6g5xbqmcdccdhx6mwrli0pdp6hjmlh9k"; + }) + (fetchNuGet { + pname = "McMaster.Extensions.CommandLineUtils"; + version = "3.1.0"; + sha256 = "075n1mfsxwz514r94l8i3ax0wp43c3xb4f9w25a96h6xxnj0k2hd"; + }) + (fetchNuGet { + pname = "Microsoft.Build.Tasks.Git"; + version = "1.1.1"; + sha256 = "1bb5p4zlnfn88skkvymxfsn0jybqncl4356hwnic9jxdq2d4fz1w"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.App.Ref"; + version = "6.0.0"; + sha256 = "1skgkralqkg2srvgvrmbsmya67f37gzk40lg28j8nz5mg8k8g0ia"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; + }) + (fetchNuGet { + pname = "Microsoft.SourceLink.Common"; + version = "1.1.1"; + sha256 = "0xkdqs7az2cprar7jzjlgjpd64l6f8ixcmwmpkdm03fyb4s5m0bg"; + }) + (fetchNuGet { + pname = "Microsoft.SourceLink.GitHub"; + version = "1.1.1"; + sha256 = "099y35f2npvva3jk1zp8hn0vb9pwm2l0ivjasdly6y2idv53s5yy"; + }) + (fetchNuGet { + pname = "Mono.Cecil"; + version = "0.11.4"; + sha256 = "1yxa7mh432s7g7p9r7scqxvxjk5ypwc567qdbf0gmk8fbf0d3f8y"; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + sha256 = "1fn9fxppfcg4jgypp2pmrpr6awl3qz1xmnri0cygpkwvyx27df1y"; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "16rnxzpk5dpbbl1x354yrlsbvwylrq456xzpsha1n9y3glnhyx9d"; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0hkg03sgm2wyq8nqk6dbm9jh5vcq57ry42lkqdmfklrw89lsmr59"; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0c2p354hjx58xhhz7wv6div8xpi90sc6ibdm40qin21bvi7ymcaa"; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; + }) + (fetchNuGet { + pname = "runtime.native.System.IO.Compression"; + version = "4.3.0"; + sha256 = "1vvivbqsk6y4hzcid27pqpm5bsi6sc50hvqwbcx8aap5ifrxfs8d"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "18pzfdlwsg2nb1jjjjzyb5qlgy6xjxzmhnfaijq5s2jw3cm3ab97"; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0qyynf9nz5i7pc26cwhgi8j62ps27sqmf78ijcfgzab50z9g8ay3"; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "1klrs545awhayryma6l7g2pvnp9xy4z0r1i40r80zb45q3i9nbyf"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0zcxjv5pckplvkg0r6mw3asggm7aqzbdjimhvsasb0cgm59x09l3"; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0vhynn79ih7hw7cwjazn87rm9z9fj0rvxgzlab36jybgcpcgphsn"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "160p68l2c7cqmyqjwxydcvgw7lvl1cr0znkw8fp24d1by9mqc8p3"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "15zrc8fgd8zx28hdghcj5f5i34wf3l6bq5177075m2bc2j34jrqy"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "1p4dgxax6p7rlgj4q73k73rslcnz4wdcv8q2flg1s8ygwcm58ld5"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "6.0.0"; + sha256 = "1js98kmjn47ivcvkjqdmyipzknb9xbndssczm8gq224pbaj1p88c"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "7.0.0"; + sha256 = "1n9122cy6v3qhsisc9lzwa1m1j62b8pi2678nsmnlyvfpk0zdagm"; + }) + (fetchNuGet { + pname = "System.ComponentModel.Annotations"; + version = "5.0.0"; + sha256 = "021h7x98lblq9avm1bgpa4i31c2kgsa7zn4sqhxf39g087ar756j"; + }) + (fetchNuGet { + pname = "System.Composition"; + version = "6.0.0"; + sha256 = "1p7hysns39cc24af6dwd4m48bqjsrr3clvi4aws152mh2fgyg50z"; + }) + (fetchNuGet { + pname = "System.Composition.AttributedModel"; + version = "6.0.0"; + sha256 = "1mqrblb0l65hw39d0hnspqcv85didpn4wbiwhfgj4784wzqx2w6k"; + }) + (fetchNuGet { + pname = "System.Composition.Convention"; + version = "6.0.0"; + sha256 = "02km3yb94p1c4s7liyhkmda0g71zm1rc8ijsfmy4bnlkq15xjw3b"; + }) + (fetchNuGet { + pname = "System.Composition.Hosting"; + version = "6.0.0"; + sha256 = "0big5nk8c44rxp6cfykhk7rxvn2cgwa99w6c3v2a36adc3lj36ky"; + }) + (fetchNuGet { + pname = "System.Composition.Runtime"; + version = "6.0.0"; + sha256 = "0vq5ik63yii1784gsa2f2kx9w6xllmm8b8rk0arid1jqdj1nyrlw"; + }) + (fetchNuGet { + pname = "System.Composition.TypedParts"; + version = "6.0.0"; + sha256 = "0y9pq3y60nyrpfy51f576a0qjjdh61mcv8vnik32pm4bz56h9q72"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; + }) + (fetchNuGet { + pname = "System.IO.Compression"; + version = "4.3.0"; + sha256 = "084zc82yi6yllgda0zkgl2ys48sypiswbiwrv7irb3r0ai1fp4vz"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.4.0"; + sha256 = "0rdvma399070b0i46c4qq1h2yvjj3k013sqzkilz4bz5cwmx1rba"; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "6.0.0"; + sha256 = "1x0b289r9yjzdqypi2x3dc8sa66s3b6bpc7l2f8hxrzl6czdg4al"; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "7.0.0"; + sha256 = "1wilasn2qmj870h2bhw348lspamm7pbinpb4m89icg113510l00v"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; + }) + (fetchNuGet { + pname = "System.Runtime.Loader"; + version = "4.3.0"; + sha256 = "07fgipa93g1xxgf7193a6vw677mpzgr0z0cfswbvqqb364cva8dk"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; + }) + (fetchNuGet { + pname = "TunnelVisionLabs.ReferenceAssemblyAnnotator"; + version = "1.0.0-alpha.160"; + sha256 = "1wvfa3098a984kydjgjvx43gncnr89fw20if2gqvz8kqn9pxqjbq"; + }) ] diff --git a/pkgs/development/tools/infisical/default.nix b/pkgs/development/tools/infisical/default.nix index d6335a4d6122e7..2df7f07b015cda 100644 --- a/pkgs/development/tools/infisical/default.nix +++ b/pkgs/development/tools/infisical/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, testers, installShellFiles }: +{ + stdenv, + lib, + fetchurl, + testers, + installShellFiles, +}: # this expression is mostly automated, and you are STRONGLY # RECOMMENDED to use to nix-update for updating this expression when new @@ -20,14 +26,16 @@ let # the platform-specific, statically linked binary src = let - suffix = { - # map the platform name to the golang toolchain suffix - # NOTE: must be synchronized with update.sh! - x86_64-linux = "linux_amd64"; - x86_64-darwin = "darwin_amd64"; - aarch64-linux = "linux_arm64"; - aarch64-darwin = "darwin_arm64"; - }."${stdenv.hostPlatform.system}" or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + suffix = + { + # map the platform name to the golang toolchain suffix + # NOTE: must be synchronized with update.sh! + x86_64-linux = "linux_amd64"; + x86_64-darwin = "darwin_amd64"; + aarch64-linux = "linux_arm64"; + aarch64-darwin = "darwin_arm64"; + } + ."${stdenv.hostPlatform.system}" or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); name = "infisical_${version}_${suffix}.tar.gz"; hash = buildHashes."${stdenv.hostPlatform.system}"; diff --git a/pkgs/development/tools/irony-server/default.nix b/pkgs/development/tools/irony-server/default.nix index 62b44214adcfa6..2a2b97222d19bc 100644 --- a/pkgs/development/tools/irony-server/default.nix +++ b/pkgs/development/tools/irony-server/default.nix @@ -1,10 +1,20 @@ -{ lib, stdenv, cmake, llvmPackages, llvm, irony }: +{ + lib, + stdenv, + cmake, + llvmPackages, + llvm, + irony, +}: stdenv.mkDerivation { pname = "irony-server"; inherit (irony) src version; - nativeBuildInputs = [ cmake llvm ]; + nativeBuildInputs = [ + cmake + llvm + ]; buildInputs = [ llvmPackages.libclang ]; dontUseCmakeBuildDir = true; diff --git a/pkgs/development/tools/jazzy/default.nix b/pkgs/development/tools/jazzy/default.nix index 23d9859eeb876f..ef04d10d5c4a5d 100644 --- a/pkgs/development/tools/jazzy/default.nix +++ b/pkgs/development/tools/jazzy/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "jazzy"; @@ -8,11 +12,11 @@ bundlerApp { passthru.updateScript = bundlerUpdateScript "jazzy"; meta = with lib; { - description = "Command-line utility that generates documentation for Swift or Objective-C"; - homepage = "https://github.com/realm/jazzy"; - license = licenses.mit; - platforms = platforms.darwin; - maintainers = with maintainers; [ + description = "Command-line utility that generates documentation for Swift or Objective-C"; + homepage = "https://github.com/realm/jazzy"; + license = licenses.mit; + platforms = platforms.darwin; + maintainers = with maintainers; [ peterromfeldhk nicknovitski ]; diff --git a/pkgs/development/tools/jazzy/gemset.nix b/pkgs/development/tools/jazzy/gemset.nix index 1514943d1eb745..e0c652b82e229e 100644 --- a/pkgs/development/tools/jazzy/gemset.nix +++ b/pkgs/development/tools/jazzy/gemset.nix @@ -1,155 +1,198 @@ { activesupport = { - dependencies = ["concurrent-ruby" "i18n" "minitest" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "i18n" + "minitest" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0r15sbhl4nrkh2g5ccbhmn3c2ngri71j0yfnarxkq90vdrhqqjgh"; type = "gem"; }; version = "5.2.8.1"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; algoliasearch = { - dependencies = ["httpclient" "json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "httpclient" + "json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ly8zsgvih540xmxr098hsngv61cf119wf28q5hbvi1f7kgwvh96"; type = "gem"; }; version = "1.27.5"; }; atomos = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17vq6sjyswr5jfzwdccw748kgph6bdw30bakwnn6p8sl4hpv4hvx"; type = "gem"; }; version = "0.1.3"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; CFPropertyList = { - dependencies = ["base64" "nkf" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "nkf" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k1w5i4lb1z941m7ds858nly33f3iv12wvr1zav5x3fa99hj2my4"; type = "gem"; }; version = "3.0.7"; }; claide = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bpqhc0kqjp1bh9b7ffc395l9gfls0337rrhmab4v46ykl45qg3d"; type = "gem"; }; version = "1.1.0"; }; cocoapods = { - dependencies = ["addressable" "claide" "cocoapods-core" "cocoapods-deintegrate" "cocoapods-downloader" "cocoapods-plugins" "cocoapods-search" "cocoapods-trunk" "cocoapods-try" "colored2" "escape" "fourflusher" "gh_inspector" "molinillo" "nap" "ruby-macho" "xcodeproj"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "claide" + "cocoapods-core" + "cocoapods-deintegrate" + "cocoapods-downloader" + "cocoapods-plugins" + "cocoapods-search" + "cocoapods-trunk" + "cocoapods-try" + "colored2" + "escape" + "fourflusher" + "gh_inspector" + "molinillo" + "nap" + "ruby-macho" + "xcodeproj" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0d0vlzjizqkw2m6am9gcnjkxy73zl74ill28v17v0s2v8fzd7nbg"; type = "gem"; }; version = "1.10.2"; }; cocoapods-core = { - dependencies = ["activesupport" "addressable" "algoliasearch" "concurrent-ruby" "fuzzy_match" "nap" "netrc" "public_suffix" "typhoeus"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "addressable" + "algoliasearch" + "concurrent-ruby" + "fuzzy_match" + "nap" + "netrc" + "public_suffix" + "typhoeus" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1j1sapw5l3xc5d8mli09az1bbmfdynlx7xv8lbghvm9i1md14dl5"; type = "gem"; }; version = "1.10.2"; }; cocoapods-deintegrate = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18pnng0lv5z6kpp8hnki0agdxx979iq6hxkfkglsyqzmir22lz2i"; type = "gem"; }; version = "1.0.5"; }; cocoapods-downloader = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jgipkiah3z6qb9ax6qac3b2m1idavd5adc319k5rjsfddpfgszh"; type = "gem"; }; version = "1.6.3"; }; cocoapods-plugins = { - dependencies = ["nap"]; + dependencies = [ "nap" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16na82sfyc8801qs1n22nwq486s4j7yj6rj7fcp8cbxmj371fpbj"; type = "gem"; }; version = "1.0.0"; }; cocoapods-search = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12amy0nknv09bvzix8bkmcjn996c50c4ms20v2dl7v8rcw73n4qv"; type = "gem"; }; version = "1.0.1"; }; cocoapods-trunk = { - dependencies = ["nap" "netrc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "nap" + "netrc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cgdx7z9psxxrsa13fk7qc9i6jskrwcafhrdz94avzia2y6dlnsz"; type = "gem"; }; version = "1.6.0"; }; cocoapods-try = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znyp625rql37ivb5rk9fk9564cmax8icxfr041ysivpdrn98nql"; type = "gem"; }; @@ -157,17 +200,17 @@ }; colored2 = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jlbqa9q4mvrm73aw9mxh23ygzbjiqwisl32d8szfb5fxvbjng5i"; type = "gem"; }; version = "3.1.2"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0skwdasxq7mnlcccn6aqabl7n9r3jd7k19ryzlzzip64cn4x572g"; type = "gem"; }; @@ -175,38 +218,38 @@ }; escape = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sa1xkfc9jvkwyw1jbz3jhkq0ms1zrvswi6mmfiwcisg5fp497z4"; type = "gem"; }; version = "0.0.4"; }; ethon = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17ix0mijpsy3y0c6ywrk5ibarmvqzjsirjyprpsy3hwax8fdm85v"; type = "gem"; }; version = "0.16.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; fourflusher = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1afabh3g3gwj0ad53fs62waks815xcckf7pkci76l6vrghffcg8v"; type = "gem"; }; @@ -214,59 +257,69 @@ }; fuzzy_match = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19gw1ifsgfrv7xdi6n61658vffgm1867f4xdqfswb2b5h6alzpmm"; type = "gem"; }; version = "2.0.4"; }; gh_inspector = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f8r9byajj3bi2c7c5sqrc7m0zrv3nblfcd4782lw5l73cbsgk04"; type = "gem"; }; version = "1.1.3"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ffix518y7976qih9k1lgnc17i3v6yrlh0a3mckpxdb4wc2vrp16"; type = "gem"; }; version = "1.14.5"; }; jazzy = { - dependencies = ["cocoapods" "mustache" "open4" "redcarpet" "rexml" "rouge" "sassc" "sqlite3" "xcinvoke"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "cocoapods" + "mustache" + "open4" + "redcarpet" + "rexml" + "rouge" + "sassc" + "sqlite3" + "xcinvoke" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "04gm9p7qlac46ml7fz5gd0b6f43hl3ib4w9vvxnq9k9fg9qqs88v"; type = "gem"; }; version = "0.15.1"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b4qsi8gay7ncmigr0pnbxyb17y3h8kavdyhsh7nrlqwr35vb60q"; type = "gem"; }; @@ -274,57 +327,57 @@ }; liferaft = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kasbbx84gzsxx8w8bgr6xjg43h9bvzzaqg7si8jirnja8yc27k3"; type = "gem"; }; version = "0.0.6"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q1f2sdw3y3y9mnym9dhjgsjr72sq975cfg5c4yx7gwv8nmzbvhk"; type = "gem"; }; version = "2.8.7"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jj629q3vw5yn90q4di4dyb87pil4a8qfm2srhgy5nc8j2n33v1i"; type = "gem"; }; version = "5.24.1"; }; molinillo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1hh40z1adl4lw16dj4hxgabx4rr28mgqycih1y1d91bwww0jjdg6"; type = "gem"; }; version = "0.6.6"; }; mustache = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l0p4wx15mi3wnamfv92ipkia4nsx8qi132c6g51jfdma3fiz2ch"; type = "gem"; }; version = "1.1.1"; }; nanaimo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xi36h3f7nm8bc2k0b6svpda1lyank2gf872lxjbhw3h95hdrbma"; type = "gem"; }; @@ -332,7 +385,7 @@ }; nap = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xm5xssxk5s03wjarpipfm39qmgxsalb46v1prsis14x1xk935ll"; type = "gem"; }; @@ -340,17 +393,17 @@ }; netrc = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gzfmcywp1da8nzfqsql2zqi648mfnx6qwkig3cv36n9m0yy676y"; type = "gem"; }; version = "0.11.0"; }; nkf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09piyp2pd74klb9wcn0zw4mb5l0k9wzwppxggxi1yi95l2ym3hgv"; type = "gem"; }; @@ -358,90 +411,90 @@ }; open4 = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cgls3f9dlrpil846q0w7h66vsc33jqn84nql4gcqkk221rh7px1"; type = "gem"; }; version = "1.3.4"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17m8q2dzm7a74amnab5rf3f3m466i300awihl3ygh4v80wpf3j6j"; type = "gem"; }; version = "6.0.0"; }; redcarpet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sg9sbf9pm91l7lac7fs4silabyn0vflxwaa2x3lrzsm0ff8ilca"; type = "gem"; }; version = "3.6.0"; }; rexml = { - dependencies = ["strscan"]; - groups = ["default"]; - platforms = []; + dependencies = [ "strscan" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zr5qpa8lampaqzhdcjcvyqnrqcjl7439mqjlkjz43wdhmpnh4s5"; type = "gem"; }; version = "3.3.2"; }; rouge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "072qvvrcqj0yfr3b0j932mlhvn41i38bq37z7z07i3ikagndkqwy"; type = "gem"; }; version = "4.3.0"; }; ruby-macho = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lhdjn91jkifsy2hzq2hgcm0pp8pbik87m58zmw1ifh6hkp9adjb"; type = "gem"; }; version = "1.4.0"; }; sassc = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gpqv48xhl8mb8qqhcifcp0pixn206a7imc07g48armklfqa4q2c"; type = "gem"; }; version = "2.4.0"; }; sqlite3 = { - dependencies = ["mini_portile2"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mini_portile2" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "073hd24qwx9j26cqbk0jma0kiajjv9fb8swv9rnz8j4mf0ygcxzs"; type = "gem"; }; version = "1.7.3"; }; strscan = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mamrl7pxacbc79ny5hzmakc9grbjysm3yy6119ppgsg44fsif01"; type = "gem"; }; @@ -449,49 +502,55 @@ }; thread_safe = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nmhcgq6cgz44srylra07bmaw99f5271l0dpsvl5f75m44l0gmwy"; type = "gem"; }; version = "0.3.6"; }; typhoeus = { - dependencies = ["ethon"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ethon" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0z7gamf6s83wy0yqms3bi4srirn3fc0lc7n65lqanidxcj1xn5qw"; type = "gem"; }; version = "1.4.1"; }; tzinfo = { - dependencies = ["thread_safe"]; - groups = ["default"]; - platforms = []; + dependencies = [ "thread_safe" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dk1cfnhgl14l580b650qyp8m5xpqb3zg0wb251h5jkm46hzc0b5"; type = "gem"; }; version = "1.2.11"; }; xcinvoke = { - dependencies = ["liferaft"]; + dependencies = [ "liferaft" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16pyq7wvx2c0fywrqxk3vg6psa3yjhbd7hw7hv2mjim6myjkdsb7"; type = "gem"; }; version = "0.3.0"; }; xcodeproj = { - dependencies = ["CFPropertyList" "atomos" "claide" "colored2" "nanaimo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "CFPropertyList" + "atomos" + "claide" + "colored2" + "nanaimo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1411j6sfnz0cx4fiw52f0yqx4bgcn8cmpgi3i5rwmmahayyjz2fn"; type = "gem"; }; diff --git a/pkgs/development/tools/jless/default.nix b/pkgs/development/tools/jless/default.nix index 0aba5e3f23f11e..bf7ecb5b25c7e2 100644 --- a/pkgs/development/tools/jless/default.nix +++ b/pkgs/development/tools/jless/default.nix @@ -1,4 +1,12 @@ -{ lib, fetchFromGitHub, rustPlatform, stdenv, python3, AppKit, libxcb }: +{ + lib, + fetchFromGitHub, + rustPlatform, + stdenv, + python3, + AppKit, + libxcb, +}: rustPlatform.buildRustPackage rec { pname = "jless"; @@ -15,7 +23,8 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ python3 ]; - buildInputs = [ ] + buildInputs = + [ ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ AppKit ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libxcb ]; @@ -25,6 +34,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://jless.io"; changelog = "https://github.com/PaulJuliusMartinez/jless/blob/${src.rev}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ figsoda jfchevrette ]; + maintainers = with maintainers; [ + figsoda + jfchevrette + ]; }; } diff --git a/pkgs/development/tools/kdash/default.nix b/pkgs/development/tools/kdash/default.nix index aceddd467b023c..fe6d7f868979b8 100644 --- a/pkgs/development/tools/kdash/default.nix +++ b/pkgs/development/tools/kdash/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, pkg-config -, perl -, python3 -, openssl -, xorg -, AppKit +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + perl, + python3, + openssl, + xorg, + AppKit, }: rustPlatform.buildRustPackage rec { @@ -21,10 +22,16 @@ rustPlatform.buildRustPackage rec { sha256 = "sha256-IpF5uXRxHBmfWkBBJjNvDsyQG5nzFjKbCmmGpG3howo="; }; - nativeBuildInputs = [ perl python3 pkg-config ]; + nativeBuildInputs = [ + perl + python3 + pkg-config + ]; - buildInputs = [ openssl xorg.xcbutil ] - ++ lib.optional stdenv.hostPlatform.isDarwin AppKit; + buildInputs = [ + openssl + xorg.xcbutil + ] ++ lib.optional stdenv.hostPlatform.isDarwin AppKit; cargoHash = "sha256-jm0UCKDy6TrogMPavB86lvk8yKZXubTGGbApk+oP2RQ="; diff --git a/pkgs/development/tools/kgt/default.nix b/pkgs/development/tools/kgt/default.nix index e0ef6bd6d15d56..684561d195f06b 100644 --- a/pkgs/development/tools/kgt/default.nix +++ b/pkgs/development/tools/kgt/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, bmake, cleanPackaging }: +{ + lib, + stdenv, + fetchFromGitHub, + bmake, + cleanPackaging, +}: stdenv.mkDerivation { pname = "kgt"; @@ -13,17 +19,25 @@ stdenv.mkDerivation { fetchSubmodules = true; }; - outputs = [ "bin" "doc" "out" ]; + outputs = [ + "bin" + "doc" + "out" + ]; nativeBuildInputs = [ bmake ]; enableParallelBuilding = true; - makeFlags = [ "-r" "PREFIX=$(bin)" ]; + makeFlags = [ + "-r" + "PREFIX=$(bin)" + ]; installPhase = '' runHook preInstall - ${cleanPackaging.commonFileActions { + ${ + cleanPackaging.commonFileActions { docFiles = [ "README.md" "LICENCE" @@ -52,7 +66,8 @@ stdenv.mkDerivation { ".gitattributes" ".github" ]; - }} $doc/share/doc/kgt + } + } $doc/share/doc/kgt install -Dm755 build/bin/kgt $bin/bin/kgt rm build/bin/kgt @@ -73,9 +88,9 @@ stdenv.mkDerivation { Input: Various BNF-like syntaxes Output: Various BNF-like syntaxes, AST dumps, and Railroad Syntax Diagrams ''; - homepage = "https://github.com/katef/kgt"; - license = licenses.bsd2; - platforms = platforms.unix; + homepage = "https://github.com/katef/kgt"; + license = licenses.bsd2; + platforms = platforms.unix; maintainers = with maintainers; [ Profpatsch ]; }; diff --git a/pkgs/development/tools/kubie/default.nix b/pkgs/development/tools/kubie/default.nix index 18b429e2d434df..332f0724079290 100644 --- a/pkgs/development/tools/kubie/default.nix +++ b/pkgs/development/tools/kubie/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, installShellFiles, Security }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + installShellFiles, + Security, +}: rustPlatform.buildRustPackage rec { pname = "kubie"; diff --git a/pkgs/development/tools/kustomize/3.nix b/pkgs/development/tools/kustomize/3.nix index 01cb1fd4861550..1d8382f01a5552 100644 --- a/pkgs/development/tools/kustomize/3.nix +++ b/pkgs/development/tools/kustomize/3.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "kustomize_3"; @@ -6,11 +10,15 @@ buildGoModule rec { # rev is the commit of the tag, mainly for kustomize version command output rev = "602ad8aa98e2e17f6c9119e027a09757e63c8bec"; - ldflags = let t = "sigs.k8s.io/kustomize/api/provenance"; in [ - "-s -w" - "-X ${t}.version=${version}" - "-X ${t}.gitCommit=${rev}" - ]; + ldflags = + let + t = "sigs.k8s.io/kustomize/api/provenance"; + in + [ + "-s -w" + "-X ${t}.version=${version}" + "-X ${t}.gitCommit=${rev}" + ]; src = fetchFromGitHub { owner = "kubernetes-sigs"; @@ -35,7 +43,13 @@ buildGoModule rec { ''; homepage = "https://github.com/kubernetes-sigs/kustomize"; license = licenses.asl20; - maintainers = with maintainers; [ carlosdagos vdemeester zaninime Chili-Man saschagrunert ]; + maintainers = with maintainers; [ + carlosdagos + vdemeester + zaninime + Chili-Man + saschagrunert + ]; mainProgram = "kustomize"; }; } diff --git a/pkgs/development/tools/kustomize/4.nix b/pkgs/development/tools/kustomize/4.nix index 9b3b73e0486840..e7f9c4e978fed3 100644 --- a/pkgs/development/tools/kustomize/4.nix +++ b/pkgs/development/tools/kustomize/4.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "kustomize_4"; @@ -13,7 +18,10 @@ buildGoModule rec { # rev is the commit of the tag, mainly for kustomize version command output rev = "56d82a8378dfc8dc3b3b1085e5a6e67b82966bd7"; - ldflags = let t = "sigs.k8s.io/kustomize/api/provenance"; in + ldflags = + let + t = "sigs.k8s.io/kustomize/api/provenance"; + in [ "-s" "-X ${t}.version=${version}" @@ -44,6 +52,13 @@ buildGoModule rec { ''; homepage = "https://github.com/kubernetes-sigs/kustomize"; license = licenses.asl20; - maintainers = with maintainers; [ carlosdagos vdemeester periklis zaninime Chili-Man saschagrunert ]; + maintainers = with maintainers; [ + carlosdagos + vdemeester + periklis + zaninime + Chili-Man + saschagrunert + ]; }; } diff --git a/pkgs/development/tools/kustomize/default.nix b/pkgs/development/tools/kustomize/default.nix index e7955979a7ae25..de256650c25f7d 100644 --- a/pkgs/development/tools/kustomize/default.nix +++ b/pkgs/development/tools/kustomize/default.nix @@ -1,10 +1,18 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: buildGoModule rec { pname = "kustomize"; version = "5.5.0"; - ldflags = let t = "sigs.k8s.io/kustomize/api/provenance"; in + ldflags = + let + t = "sigs.k8s.io/kustomize/api/provenance"; + in [ "-s" "-X ${t}.version=${version}" @@ -42,6 +50,13 @@ buildGoModule rec { ''; homepage = "https://github.com/kubernetes-sigs/kustomize"; license = licenses.asl20; - maintainers = with maintainers; [ carlosdagos vdemeester periklis zaninime Chili-Man saschagrunert ]; + maintainers = with maintainers; [ + carlosdagos + vdemeester + periklis + zaninime + Chili-Man + saschagrunert + ]; }; } diff --git a/pkgs/development/tools/kustomize/kustomize-sops.nix b/pkgs/development/tools/kustomize/kustomize-sops.nix index 2801930a22efc4..704754d945a205 100644 --- a/pkgs/development/tools/kustomize/kustomize-sops.nix +++ b/pkgs/development/tools/kustomize/kustomize-sops.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "kustomize-sops"; diff --git a/pkgs/development/tools/language-servers/ccls/default.nix b/pkgs/development/tools/language-servers/ccls/default.nix index 0cb1e788409756..5e40d5fc0f40ab 100644 --- a/pkgs/development/tools/language-servers/ccls/default.nix +++ b/pkgs/development/tools/language-servers/ccls/default.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, llvmPackages, rapidjson, runtimeShell }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + llvmPackages, + rapidjson, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "ccls"; @@ -12,8 +19,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-0hZ4VnscnKYBrXy58IjeoeDxja1oNq0mNaQGPmej5BA="; }; - nativeBuildInputs = [ cmake llvmPackages.llvm.dev ]; - buildInputs = with llvmPackages; [ libclang llvm rapidjson ]; + nativeBuildInputs = [ + cmake + llvmPackages.llvm.dev + ]; + buildInputs = with llvmPackages; [ + libclang + llvm + rapidjson + ]; cmakeFlags = [ "-DCCLS_VERSION=${version}" ]; @@ -34,9 +48,12 @@ stdenv.mkDerivation rec { meta = with lib; { description = "C/c++ language server powered by clang"; mainProgram = "ccls"; - homepage = "https://github.com/MaskRay/ccls"; - license = licenses.asl20; - platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ mic92 tobim ]; + homepage = "https://github.com/MaskRay/ccls"; + license = licenses.asl20; + platforms = platforms.linux ++ platforms.darwin; + maintainers = with maintainers; [ + mic92 + tobim + ]; }; } diff --git a/pkgs/development/tools/language-servers/crystalline/default.nix b/pkgs/development/tools/language-servers/crystalline/default.nix index 3f59e57bdb01ce..1555dc35e824a8 100644 --- a/pkgs/development/tools/language-servers/crystalline/default.nix +++ b/pkgs/development/tools/language-servers/crystalline/default.nix @@ -1,9 +1,10 @@ -{ lib -, crystal -, fetchFromGitHub -, llvmPackages -, openssl -, makeWrapper +{ + lib, + crystal, + fetchFromGitHub, + llvmPackages, + openssl, + makeWrapper, }: let @@ -23,20 +24,27 @@ crystal.buildCrystalPackage { format = "crystal"; shardsFile = ./shards.nix; - nativeBuildInputs = [ llvmPackages.llvm openssl makeWrapper ]; + nativeBuildInputs = [ + llvmPackages.llvm + openssl + makeWrapper + ]; doCheck = false; doInstallCheck = false; crystalBinaries.crystalline = { src = "src/crystalline.cr"; - options = [ "--release" "--no-debug" "--progress" "-Dpreview_mt" ]; + options = [ + "--release" + "--no-debug" + "--progress" + "-Dpreview_mt" + ]; }; postInstall = '' - wrapProgram "$out/bin/crystalline" --prefix PATH : '${ - lib.makeBinPath [llvmPackages.llvm.dev] - }' + wrapProgram "$out/bin/crystalline" --prefix PATH : '${lib.makeBinPath [ llvmPackages.llvm.dev ]}' ''; meta = with lib; { diff --git a/pkgs/development/tools/language-servers/fortls/default.nix b/pkgs/development/tools/language-servers/fortls/default.nix index 5faa408ecff2ec..273a0179863b78 100644 --- a/pkgs/development/tools/language-servers/fortls/default.nix +++ b/pkgs/development/tools/language-servers/fortls/default.nix @@ -1,9 +1,10 @@ -{ buildPythonApplication -, lib -, fetchFromGitHub -, setuptools-scm -, json5 -, packaging +{ + buildPythonApplication, + lib, + fetchFromGitHub, + setuptools-scm, + json5, + packaging, }: buildPythonApplication rec { @@ -19,7 +20,10 @@ buildPythonApplication rec { nativeBuildInputs = [ setuptools-scm ]; - propagatedBuildInputs = [ json5 packaging ]; + propagatedBuildInputs = [ + json5 + packaging + ]; doCheck = true; checkPhase = "$out/bin/fortls --help 1>/dev/null"; diff --git a/pkgs/development/tools/language-servers/fortran-language-server/default.nix b/pkgs/development/tools/language-servers/fortran-language-server/default.nix index 81ecf59c6d43b1..419f372c9be1b5 100644 --- a/pkgs/development/tools/language-servers/fortran-language-server/default.nix +++ b/pkgs/development/tools/language-servers/fortran-language-server/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchPypi, buildPythonApplication }: +{ + lib, + fetchPypi, + buildPythonApplication, +}: buildPythonApplication rec { pname = "fortran-language-server"; diff --git a/pkgs/development/tools/ldid/default.nix b/pkgs/development/tools/ldid/default.nix index c3a988885cec52..c0c2645ab09463 100644 --- a/pkgs/development/tools/ldid/default.nix +++ b/pkgs/development/tools/ldid/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchgit -, libplist -, libxml2 -, openssl -, CoreFoundation -, Security +{ + lib, + stdenv, + fetchgit, + libplist, + libxml2, + openssl, + CoreFoundation, + Security, }: stdenv.mkDerivation rec { @@ -20,23 +21,27 @@ stdenv.mkDerivation rec { strictDeps = true; - buildInputs = [ - libplist - libxml2 - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreFoundation - Security - ]; + buildInputs = + [ + libplist + libxml2 + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreFoundation + Security + ]; - NIX_LDFLAGS = [ - "-lcrypto" - "-lplist-2.0" - "-lxml2" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-framework CoreFoundation" - "-framework Security" - ]; + NIX_LDFLAGS = + [ + "-lcrypto" + "-lplist-2.0" + "-lxml2" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-framework CoreFoundation" + "-framework Security" + ]; buildPhase = '' runHook preBuild diff --git a/pkgs/development/tools/libsigrok/default.nix b/pkgs/development/tools/libsigrok/default.nix index c93c27722ec233..caf8199c93e121 100644 --- a/pkgs/development/tools/libsigrok/default.nix +++ b/pkgs/development/tools/libsigrok/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchgit -, autoreconfHook -, pkg-config -, libzip -, glib -, libusb1 -, libftdi1 -, check -, libserialport -, doxygen -, glibmm -, python -, hidapi -, libieee1284 -, bluez -, sigrok-firmware-fx2lafw +{ + lib, + stdenv, + fetchgit, + autoreconfHook, + pkg-config, + libzip, + glib, + libusb1, + libftdi1, + check, + libserialport, + doxygen, + glibmm, + python, + hidapi, + libieee1284, + bluez, + sigrok-firmware-fx2lafw, }: stdenv.mkDerivation rec { @@ -30,10 +31,27 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - nativeBuildInputs = [ autoreconfHook doxygen pkg-config python ]; - buildInputs = [ - libzip glib libusb1 libftdi1 check libserialport glibmm hidapi - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libieee1284 bluez ]; + nativeBuildInputs = [ + autoreconfHook + doxygen + pkg-config + python + ]; + buildInputs = + [ + libzip + glib + libusb1 + libftdi1 + check + libserialport + glibmm + hidapi + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libieee1284 + bluez + ]; strictDeps = true; @@ -58,6 +76,9 @@ stdenv.mkDerivation rec { homepage = "https://sigrok.org/"; license = licenses.gpl3Plus; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ bjornfor vifino ]; + maintainers = with maintainers; [ + bjornfor + vifino + ]; }; } diff --git a/pkgs/development/tools/license_finder/default.nix b/pkgs/development/tools/license_finder/default.nix index c5ac0885556589..c30860a9a4ba2b 100644 --- a/pkgs/development/tools/license_finder/default.nix +++ b/pkgs/development/tools/license_finder/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerEnv, bundlerUpdateScript, ruby }: +{ + lib, + bundlerEnv, + bundlerUpdateScript, + ruby, +}: bundlerEnv { pname = "license_finder"; diff --git a/pkgs/development/tools/license_finder/gemset.nix b/pkgs/development/tools/license_finder/gemset.nix index 89becfc04d3517..fad868d54e4ada 100644 --- a/pkgs/development/tools/license_finder/gemset.nix +++ b/pkgs/development/tools/license_finder/gemset.nix @@ -1,71 +1,77 @@ { license_finder = { - dependencies = ["rubyzip" "thor" "tomlrb" "with_env" "xml-simple"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "rubyzip" + "thor" + "tomlrb" + "with_env" + "xml-simple" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sig4ifxzvcz3fwjnz93dpv61v6sxpmlknj5f8n112ragrbcj8hb"; type = "gem"; }; version = "7.0.1"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08ximcyfjy94pm1rhcx04ny1vx2sk0x4y185gzn86yfsbzwkng53"; type = "gem"; }; version = "3.2.5"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0inl77jh4ia03jw3iqm5ipr76ghal3hyjrd6r8zqsswwvi9j2xdi"; type = "gem"; }; version = "1.2.1"; }; tomlrb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a83cb5xpyzlr651d46rk5xgq37s46hs9nfqy9baawzs31hm9k2g"; type = "gem"; }; version = "2.0.1"; }; with_env = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1r5ns064mbb99hf1dyxsk9183hznc5i7mn3bi86zka6dlvqf9csh"; type = "gem"; }; version = "1.1.0"; }; xml-simple = { - dependencies = ["rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rexml" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb9plyl71mdbjr4kllfy53qx6g68ryxblmnq9dilvy837jk24fj"; type = "gem"; }; diff --git a/pkgs/development/tools/loganalyzer/default.nix b/pkgs/development/tools/loganalyzer/default.nix index d992b539dafd20..76e782e8f8b996 100644 --- a/pkgs/development/tools/loganalyzer/default.nix +++ b/pkgs/development/tools/loganalyzer/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, qtbase -, qtsvg -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + qtbase, + qtsvg, + wrapQtAppsHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/tools/marksman/default.nix b/pkgs/development/tools/marksman/default.nix index bae8b5ad21dc66..6a771c63adfd0a 100644 --- a/pkgs/development/tools/marksman/default.nix +++ b/pkgs/development/tools/marksman/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, buildDotnetModule -, dotnetCorePackages -, marksman -, testers +{ + lib, + fetchFromGitHub, + buildDotnetModule, + dotnetCorePackages, + marksman, + testers, }: buildDotnetModule rec { @@ -54,7 +55,10 @@ buildDotnetModule rec { ''; homepage = "https://github.com/artempyanykh/marksman"; license = licenses.mit; - maintainers = with maintainers; [ stasjok plusgut ]; + maintainers = with maintainers; [ + stasjok + plusgut + ]; platforms = dotnet-sdk.meta.platforms; mainProgram = "marksman"; }; diff --git a/pkgs/development/tools/marksman/deps.nix b/pkgs/development/tools/marksman/deps.nix index 485b522734e570..3a369829b93ad6 100644 --- a/pkgs/development/tools/marksman/deps.nix +++ b/pkgs/development/tools/marksman/deps.nix @@ -1,89 +1,426 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "coverlet.collector"; version = "6.0.2"; hash = "sha256-LdSQUrOmjFug47LjtqgtN2MM6BcfG0HR5iL+prVHlDo="; }) - (fetchNuGet { pname = "fantomas"; version = "6.3.16"; hash = "sha256-4tRdYf+/Q1iedx+DDuIKVGlIWQdr6erM51VdKzZkhCs="; }) - (fetchNuGet { pname = "FSharp.SystemCommandLine"; version = "0.13.0-beta4"; hash = "sha256-QDT7vllfe978acAmSXltWXsnG/LZOEWTb1C85vBDBYI="; }) - (fetchNuGet { pname = "FSharpPlus"; version = "1.6.1"; hash = "sha256-MGwxfDTg6gJiS88yiqi1OGJk5WmaAFkVniniwF9Ilkc="; }) - (fetchNuGet { pname = "Glob"; version = "1.1.9"; hash = "sha256-o3igdoWYiatTNlvBA6UrhZVLweh6qcY7CcQtILCC4uA="; }) - (fetchNuGet { pname = "Markdig"; version = "0.38.0"; hash = "sha256-5DuDlj+TCDJWP8oJM2WU48ps3HFuUg5P28O/SPcjwGk="; }) - (fetchNuGet { pname = "MessagePack"; version = "2.5.108"; hash = "sha256-+vMXyEbfutY5WOFuFnNF24uLcKJTTdntVrVlSJH4yjI="; }) - (fetchNuGet { pname = "MessagePack.Annotations"; version = "2.5.108"; hash = "sha256-u3Qu8UftNIz3oIzQUMa7Z0G6VzmDLcAnAeNQ3lB3YVk="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "7.0.0"; hash = "sha256-1e031E26iraIqun84ad0fCIR4MJZ1hcQo4yFN+B7UfE="; }) - (fetchNuGet { pname = "Microsoft.CodeCoverage"; version = "17.11.1"; hash = "sha256-1dLlK3NGh88PuFYZiYpT+izA96etxhU3BSgixDgdtGA="; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.0.1"; hash = "sha256-0huoqR2CJ3Z9Q2peaKD09TV3E6saYSqDGZ290K8CrH8="; }) - (fetchNuGet { pname = "Microsoft.NET.StringTools"; version = "17.4.0"; hash = "sha256-+9uBaUDZ3roUJwyYJUL30Mz+3C6LE16FzfQKgS0Yveo="; }) - (fetchNuGet { pname = "Microsoft.NET.Test.Sdk"; version = "17.11.1"; hash = "sha256-0JUEucQ2lzaPgkrjm/NFLBTbqU1dfhvhN3Tl3moE6mI="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.0.1"; hash = "sha256-mZotlGZqtrqDSoBrZhsxFe6fuOv5/BIo0w2Z2x0zVAU="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "5.0.0"; hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.0.1"; hash = "sha256-lxxw/Gy32xHi0fLgFWNj4YTFBSBkjx5l6ucmbTyf7V4="; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.ObjectModel"; version = "17.11.1"; hash = "sha256-5vX+vCzFY3S7xfMVIv8OlMMFtdedW9UIJzc0WEc+vm4="; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.TestHost"; version = "17.11.1"; hash = "sha256-wSkY0H1fQAq0H3LcKT4u7Y5RzhAAPa6yueVN84g8HxU="; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Threading"; version = "17.6.40"; hash = "sha256-5HtsgSPV5RdaPREGDvJ7qMOFubb1wMyHwkfTnZs9Zsc="; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Threading.Analyzers"; version = "17.6.40"; hash = "sha256-WghLNITEsKTV5pCjogmhfsVD3iO7ghTk0KNrOXzKSS0="; }) - (fetchNuGet { pname = "Microsoft.VisualStudio.Validation"; version = "17.6.11"; hash = "sha256-Lkjp9Ove4+CFP06x/toYpJEiAinuTfn/o+oh0fW3pGM="; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "5.0.0"; hash = "sha256-9kylPGfKZc58yFqNKa77stomcoNnMeERXozWJzDcUIA="; }) - (fetchNuGet { pname = "Nerdbank.Streams"; version = "2.10.66"; hash = "sha256-35qyZOVDemtsBYjaZSkzuXGp0mIOSFnCeEHWsUXb5BI="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.1"; hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.3"; hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "9.0.1"; hash = "sha256-mYCBrgUhIJFzRuLLV9SIiIFHovzfR8Uuqfg6e08EnlU="; }) - (fetchNuGet { pname = "Serilog"; version = "2.11.0"; hash = "sha256-kI7I/NiH7GuR0MQTZsy+m+8+2qT0xMBrY7SXYCocbds="; }) - (fetchNuGet { pname = "Serilog.Sinks.Console"; version = "4.0.1"; hash = "sha256-n0LQOEsUg9M/T1aWryiG2690pyGBjHsk6TRZz2aCGyA="; }) - (fetchNuGet { pname = "Snapper"; version = "2.4.1"; hash = "sha256-mgYpGR3MWNQyueF07kDgl8ToyzcISqYTabVYn8Davpo="; }) - (fetchNuGet { pname = "StreamJsonRpc"; version = "2.16.36"; hash = "sha256-XLCQsY7xu67E8E7WJIvjHtk3iobREPCiljW8jNpfi68="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.0.11"; hash = "sha256-puoFMkx4Z55C1XPxNw3np8nzNGjH+G24j43yTIsDRL0="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "7.0.0"; hash = "sha256-9an2wbxue2qrtugYES9awshQg+KfJqajhnhs45kQIdk="; }) - (fetchNuGet { pname = "System.CommandLine"; version = "2.0.0-beta4.22272.1"; hash = "sha256-zSO+CYnMH8deBHDI9DHhCPj79Ce3GOzHCyH1/TiHxcc="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.0.11"; hash = "sha256-P+rSQJVoN6M56jQbs76kZ9G3mAWFdtF27P/RijN8sj4="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "7.0.2"; hash = "sha256-8Uawe7mWOQsDzMSAAP16nuGD1FRSajyS8q+cA++MJ8E="; }) - (fetchNuGet { pname = "System.Diagnostics.Tools"; version = "4.0.1"; hash = "sha256-vSBqTbmWXylvRa37aWyktym+gOpsvH43mwr6A962k6U="; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.0.11"; hash = "sha256-qWqFVxuXioesVftv2RVJZOnmojUvRjb7cS3Oh3oTit4="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.0.11"; hash = "sha256-rbSgc2PIEc2c2rN6LK3qCREAX3DqA2Nq1WcLrZYsDBw="; }) - (fetchNuGet { pname = "System.IO"; version = "4.1.0"; hash = "sha256-V6oyQFwWb8NvGxAwvzWnhPxy9dKOfj/XBM3tEC5aHrw="; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.0.1"; hash = "sha256-4VKXFgcGYCTWVXjAlniAVq0dO3o5s8KHylg2wg2/7k0="; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.0.1"; hash = "sha256-IpigKMomqb6pmYWkrlf0ZdpILtRluX2cX5sOKVW0Feg="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "7.0.0"; hash = "sha256-W2181khfJUTxLqhuAVRhCa52xZ3+ePGOLIPwEN8WisY="; }) - (fetchNuGet { pname = "System.Linq"; version = "4.1.0"; hash = "sha256-ZQpFtYw5N1F1aX0jUK3Tw+XvM5tnlnshkTCNtfVA794="; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.1.0"; hash = "sha256-7zqB+FXgkvhtlBzpcZyd81xczWP0D3uWssyAGw3t7b4="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.5"; hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.0.12"; hash = "sha256-MudZ/KYcvYsn2cST3EE049mLikrNkmE7QoUoYKKby+s="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.1.0"; hash = "sha256-idZHGH2Yl/hha1CM4VzLhsaR8Ljo/rV7TYe7mwRJSMs="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.0.1"; hash = "sha256-F1MvYoQWHCY89/O4JBwswogitqVvKuVfILFqA7dmuHk="; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.0.1"; hash = "sha256-YG+eJBG5P+5adsHiw/lhJwvREnvdHw6CJyS8ZV4Ujd0="; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.0.1"; hash = "sha256-uVvNOnL64CPqsgZP2OLqNmxdkZl6Q0fTmKmv9gcBi+g="; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.0.1"; hash = "sha256-NsfmzM9G/sN3H8X2cdnheTGRsh7zbRzvegnjDzDH/FQ="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "1.6.0"; hash = "sha256-JJfgaPav7UfEh4yRAQdGhLZF1brr0tUWPl6qmfNWq/E="; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.0.1"; hash = "sha256-SFSfpWEyCBMAOerrMCOiKnpT+UAWTvRcmoRquJR6Vq0="; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.1.0"; hash = "sha256-R0YZowmFda+xzKNR4kKg7neFoE30KfZwp/IwfRSKVK4="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.0.1"; hash = "sha256-cZ2/3/fczLjEpn6j3xkgQV9ouOVjy4Kisgw5xWw9kSw="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.1.0"; hash = "sha256-FViNGM/4oWtlP6w0JC0vJU+k9efLKZ+yaXrnEeabDQo="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.1.0"; hash = "sha256-X7DZ5CbPY7jHs20YZ7bmcXs9B5Mxptu/HnBUvUnNhGc="; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.0.1"; hash = "sha256-j2QgVO9ZOjv7D1het98CoFpjoYgxjupuIhuBUmLLH7w="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.1.0"; hash = "sha256-QceAYlJvkPRJc/+5jR+wQpNNI3aqGySWWSO30e/FfQY="; }) - (fetchNuGet { pname = "System.Runtime.Serialization.Primitives"; version = "4.1.1"; hash = "sha256-80B05oxJbPLGq2pGOSl6NlZvintX9A1CNpna2aN0WRA="; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "5.0.0"; hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.0.11"; hash = "sha256-PEailOvG05CVgPTyKLtpAgRydlSHmtd5K0Y8GSHY2Lc="; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.0.11"; hash = "sha256-+kf7J3dEhgCbnCM5vHYlsTm5/R/Ud0Jr6elpHm922iI="; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "7.0.0"; hash = "sha256-tF8qt9GZh/nPy0mEnj6nKLG4Lldpoi/D8xM5lv2CoYQ="; }) - (fetchNuGet { pname = "System.Text.Json"; version = "7.0.3"; hash = "sha256-aSJZ17MjqaZNQkprfxm/09LaCoFtpdWmqU9BTROzWX4="; }) - (fetchNuGet { pname = "System.Text.RegularExpressions"; version = "4.1.0"; hash = "sha256-x6OQN6MCN7S0fJ6EFTfv4rczdUWjwuWE9QQ0P6fbh9c="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.0.11"; hash = "sha256-mob1Zv3qLQhQ1/xOLXZmYqpniNUMCfn02n8ZkaAhqac="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.0.11"; hash = "sha256-5SLxzFg1df6bTm2t09xeI01wa5qQglqUwwJNlQPJIVs="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Dataflow"; version = "7.0.0"; hash = "sha256-KTeMhCWcyYEwG7EkA0VkVvHwo0B2FBs5FpjW3BFNVUE="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.0.0"; hash = "sha256-+YdcPkMhZhRbMZHnfsDwpNbUkr31X7pQFGxXYcAPZbE="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.0.11"; hash = "sha256-haZAFFQ9Sl2DhfvEbdx2YRqKEoxNMU5STaqpMmXw0zA="; }) - (fetchNuGet { pname = "System.Xml.XDocument"; version = "4.0.11"; hash = "sha256-KPz1kxe0RUBM+aoktJ/f9p51GudMERU8Pmwm//HdlFg="; }) - (fetchNuGet { pname = "Tomlyn"; version = "0.17.0"; hash = "sha256-pJHF7w8RJhV23wiI3qzm5el4qPlPlgYTmTKA8yGhzXY="; }) - (fetchNuGet { pname = "xunit"; version = "2.9.2"; hash = "sha256-h5+yTTfCmokCPy4lqdEw8RGzQlrlsQAW3Am0Jh0q7oo="; }) - (fetchNuGet { pname = "xunit.abstractions"; version = "2.0.3"; hash = "sha256-0D1y/C34iARI96gb3bAOG8tcGPMjx+fMabTPpydGlAM="; }) - (fetchNuGet { pname = "xunit.analyzers"; version = "1.16.0"; hash = "sha256-P5Bvl9hvHvF8KY1YWLg4tKiYxlfRnmHyL14jfSACDaU="; }) - (fetchNuGet { pname = "xunit.assert"; version = "2.9.2"; hash = "sha256-EE6r526Q4cHn0Ourf1ENpXZ37Lj/P2uNvonHgpdcnq4="; }) - (fetchNuGet { pname = "xunit.core"; version = "2.9.2"; hash = "sha256-zhjV1I5xh0RFckgTEK72tIkLxVl4CPmter2UB++oye8="; }) - (fetchNuGet { pname = "xunit.extensibility.core"; version = "2.9.2"; hash = "sha256-MQAC/4d67Nssu3R+pHPh6vHitBXQYxEEZkVVMGW720c="; }) - (fetchNuGet { pname = "xunit.extensibility.execution"; version = "2.9.2"; hash = "sha256-f+9UfoPyK3JIDhQSW0Yu9c4PGqUqZC96DMINCYi2i80="; }) - (fetchNuGet { pname = "xunit.runner.visualstudio"; version = "2.8.2"; hash = "sha256-UlfK348r8kJuraywfdCtpJJxHkv04wPNzpUaz4UM/60="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "coverlet.collector"; + version = "6.0.2"; + hash = "sha256-LdSQUrOmjFug47LjtqgtN2MM6BcfG0HR5iL+prVHlDo="; + }) + (fetchNuGet { + pname = "fantomas"; + version = "6.3.16"; + hash = "sha256-4tRdYf+/Q1iedx+DDuIKVGlIWQdr6erM51VdKzZkhCs="; + }) + (fetchNuGet { + pname = "FSharp.SystemCommandLine"; + version = "0.13.0-beta4"; + hash = "sha256-QDT7vllfe978acAmSXltWXsnG/LZOEWTb1C85vBDBYI="; + }) + (fetchNuGet { + pname = "FSharpPlus"; + version = "1.6.1"; + hash = "sha256-MGwxfDTg6gJiS88yiqi1OGJk5WmaAFkVniniwF9Ilkc="; + }) + (fetchNuGet { + pname = "Glob"; + version = "1.1.9"; + hash = "sha256-o3igdoWYiatTNlvBA6UrhZVLweh6qcY7CcQtILCC4uA="; + }) + (fetchNuGet { + pname = "Markdig"; + version = "0.38.0"; + hash = "sha256-5DuDlj+TCDJWP8oJM2WU48ps3HFuUg5P28O/SPcjwGk="; + }) + (fetchNuGet { + pname = "MessagePack"; + version = "2.5.108"; + hash = "sha256-+vMXyEbfutY5WOFuFnNF24uLcKJTTdntVrVlSJH4yjI="; + }) + (fetchNuGet { + pname = "MessagePack.Annotations"; + version = "2.5.108"; + hash = "sha256-u3Qu8UftNIz3oIzQUMa7Z0G6VzmDLcAnAeNQ3lB3YVk="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "7.0.0"; + hash = "sha256-1e031E26iraIqun84ad0fCIR4MJZ1hcQo4yFN+B7UfE="; + }) + (fetchNuGet { + pname = "Microsoft.CodeCoverage"; + version = "17.11.1"; + hash = "sha256-1dLlK3NGh88PuFYZiYpT+izA96etxhU3BSgixDgdtGA="; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.0.1"; + hash = "sha256-0huoqR2CJ3Z9Q2peaKD09TV3E6saYSqDGZ290K8CrH8="; + }) + (fetchNuGet { + pname = "Microsoft.NET.StringTools"; + version = "17.4.0"; + hash = "sha256-+9uBaUDZ3roUJwyYJUL30Mz+3C6LE16FzfQKgS0Yveo="; + }) + (fetchNuGet { + pname = "Microsoft.NET.Test.Sdk"; + version = "17.11.1"; + hash = "sha256-0JUEucQ2lzaPgkrjm/NFLBTbqU1dfhvhN3Tl3moE6mI="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.0.1"; + hash = "sha256-mZotlGZqtrqDSoBrZhsxFe6fuOv5/BIo0w2Z2x0zVAU="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "5.0.0"; + hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.0.1"; + hash = "sha256-lxxw/Gy32xHi0fLgFWNj4YTFBSBkjx5l6ucmbTyf7V4="; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.ObjectModel"; + version = "17.11.1"; + hash = "sha256-5vX+vCzFY3S7xfMVIv8OlMMFtdedW9UIJzc0WEc+vm4="; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.TestHost"; + version = "17.11.1"; + hash = "sha256-wSkY0H1fQAq0H3LcKT4u7Y5RzhAAPa6yueVN84g8HxU="; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Threading"; + version = "17.6.40"; + hash = "sha256-5HtsgSPV5RdaPREGDvJ7qMOFubb1wMyHwkfTnZs9Zsc="; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Threading.Analyzers"; + version = "17.6.40"; + hash = "sha256-WghLNITEsKTV5pCjogmhfsVD3iO7ghTk0KNrOXzKSS0="; + }) + (fetchNuGet { + pname = "Microsoft.VisualStudio.Validation"; + version = "17.6.11"; + hash = "sha256-Lkjp9Ove4+CFP06x/toYpJEiAinuTfn/o+oh0fW3pGM="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "5.0.0"; + hash = "sha256-9kylPGfKZc58yFqNKa77stomcoNnMeERXozWJzDcUIA="; + }) + (fetchNuGet { + pname = "Nerdbank.Streams"; + version = "2.10.66"; + hash = "sha256-35qyZOVDemtsBYjaZSkzuXGp0mIOSFnCeEHWsUXb5BI="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.1"; + hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.3"; + hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "9.0.1"; + hash = "sha256-mYCBrgUhIJFzRuLLV9SIiIFHovzfR8Uuqfg6e08EnlU="; + }) + (fetchNuGet { + pname = "Serilog"; + version = "2.11.0"; + hash = "sha256-kI7I/NiH7GuR0MQTZsy+m+8+2qT0xMBrY7SXYCocbds="; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Console"; + version = "4.0.1"; + hash = "sha256-n0LQOEsUg9M/T1aWryiG2690pyGBjHsk6TRZz2aCGyA="; + }) + (fetchNuGet { + pname = "Snapper"; + version = "2.4.1"; + hash = "sha256-mgYpGR3MWNQyueF07kDgl8ToyzcISqYTabVYn8Davpo="; + }) + (fetchNuGet { + pname = "StreamJsonRpc"; + version = "2.16.36"; + hash = "sha256-XLCQsY7xu67E8E7WJIvjHtk3iobREPCiljW8jNpfi68="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.0.11"; + hash = "sha256-puoFMkx4Z55C1XPxNw3np8nzNGjH+G24j43yTIsDRL0="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "7.0.0"; + hash = "sha256-9an2wbxue2qrtugYES9awshQg+KfJqajhnhs45kQIdk="; + }) + (fetchNuGet { + pname = "System.CommandLine"; + version = "2.0.0-beta4.22272.1"; + hash = "sha256-zSO+CYnMH8deBHDI9DHhCPj79Ce3GOzHCyH1/TiHxcc="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.0.11"; + hash = "sha256-P+rSQJVoN6M56jQbs76kZ9G3mAWFdtF27P/RijN8sj4="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "7.0.2"; + hash = "sha256-8Uawe7mWOQsDzMSAAP16nuGD1FRSajyS8q+cA++MJ8E="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tools"; + version = "4.0.1"; + hash = "sha256-vSBqTbmWXylvRa37aWyktym+gOpsvH43mwr6A962k6U="; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.0.11"; + hash = "sha256-qWqFVxuXioesVftv2RVJZOnmojUvRjb7cS3Oh3oTit4="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.0.11"; + hash = "sha256-rbSgc2PIEc2c2rN6LK3qCREAX3DqA2Nq1WcLrZYsDBw="; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.1.0"; + hash = "sha256-V6oyQFwWb8NvGxAwvzWnhPxy9dKOfj/XBM3tEC5aHrw="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.0.1"; + hash = "sha256-4VKXFgcGYCTWVXjAlniAVq0dO3o5s8KHylg2wg2/7k0="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.0.1"; + hash = "sha256-IpigKMomqb6pmYWkrlf0ZdpILtRluX2cX5sOKVW0Feg="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "7.0.0"; + hash = "sha256-W2181khfJUTxLqhuAVRhCa52xZ3+ePGOLIPwEN8WisY="; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.1.0"; + hash = "sha256-ZQpFtYw5N1F1aX0jUK3Tw+XvM5tnlnshkTCNtfVA794="; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.1.0"; + hash = "sha256-7zqB+FXgkvhtlBzpcZyd81xczWP0D3uWssyAGw3t7b4="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.5"; + hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.0.12"; + hash = "sha256-MudZ/KYcvYsn2cST3EE049mLikrNkmE7QoUoYKKby+s="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.1.0"; + hash = "sha256-idZHGH2Yl/hha1CM4VzLhsaR8Ljo/rV7TYe7mwRJSMs="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.0.1"; + hash = "sha256-F1MvYoQWHCY89/O4JBwswogitqVvKuVfILFqA7dmuHk="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.0.1"; + hash = "sha256-YG+eJBG5P+5adsHiw/lhJwvREnvdHw6CJyS8ZV4Ujd0="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.0.1"; + hash = "sha256-uVvNOnL64CPqsgZP2OLqNmxdkZl6Q0fTmKmv9gcBi+g="; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.0.1"; + hash = "sha256-NsfmzM9G/sN3H8X2cdnheTGRsh7zbRzvegnjDzDH/FQ="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "1.6.0"; + hash = "sha256-JJfgaPav7UfEh4yRAQdGhLZF1brr0tUWPl6qmfNWq/E="; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.0.1"; + hash = "sha256-SFSfpWEyCBMAOerrMCOiKnpT+UAWTvRcmoRquJR6Vq0="; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.1.0"; + hash = "sha256-R0YZowmFda+xzKNR4kKg7neFoE30KfZwp/IwfRSKVK4="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.0.1"; + hash = "sha256-cZ2/3/fczLjEpn6j3xkgQV9ouOVjy4Kisgw5xWw9kSw="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.1.0"; + hash = "sha256-FViNGM/4oWtlP6w0JC0vJU+k9efLKZ+yaXrnEeabDQo="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.1.0"; + hash = "sha256-X7DZ5CbPY7jHs20YZ7bmcXs9B5Mxptu/HnBUvUnNhGc="; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.0.1"; + hash = "sha256-j2QgVO9ZOjv7D1het98CoFpjoYgxjupuIhuBUmLLH7w="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.1.0"; + hash = "sha256-QceAYlJvkPRJc/+5jR+wQpNNI3aqGySWWSO30e/FfQY="; + }) + (fetchNuGet { + pname = "System.Runtime.Serialization.Primitives"; + version = "4.1.1"; + hash = "sha256-80B05oxJbPLGq2pGOSl6NlZvintX9A1CNpna2aN0WRA="; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "5.0.0"; + hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.0.11"; + hash = "sha256-PEailOvG05CVgPTyKLtpAgRydlSHmtd5K0Y8GSHY2Lc="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.0.11"; + hash = "sha256-+kf7J3dEhgCbnCM5vHYlsTm5/R/Ud0Jr6elpHm922iI="; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "7.0.0"; + hash = "sha256-tF8qt9GZh/nPy0mEnj6nKLG4Lldpoi/D8xM5lv2CoYQ="; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "7.0.3"; + hash = "sha256-aSJZ17MjqaZNQkprfxm/09LaCoFtpdWmqU9BTROzWX4="; + }) + (fetchNuGet { + pname = "System.Text.RegularExpressions"; + version = "4.1.0"; + hash = "sha256-x6OQN6MCN7S0fJ6EFTfv4rczdUWjwuWE9QQ0P6fbh9c="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.0.11"; + hash = "sha256-mob1Zv3qLQhQ1/xOLXZmYqpniNUMCfn02n8ZkaAhqac="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.0.11"; + hash = "sha256-5SLxzFg1df6bTm2t09xeI01wa5qQglqUwwJNlQPJIVs="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Dataflow"; + version = "7.0.0"; + hash = "sha256-KTeMhCWcyYEwG7EkA0VkVvHwo0B2FBs5FpjW3BFNVUE="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.0.0"; + hash = "sha256-+YdcPkMhZhRbMZHnfsDwpNbUkr31X7pQFGxXYcAPZbE="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.0.11"; + hash = "sha256-haZAFFQ9Sl2DhfvEbdx2YRqKEoxNMU5STaqpMmXw0zA="; + }) + (fetchNuGet { + pname = "System.Xml.XDocument"; + version = "4.0.11"; + hash = "sha256-KPz1kxe0RUBM+aoktJ/f9p51GudMERU8Pmwm//HdlFg="; + }) + (fetchNuGet { + pname = "Tomlyn"; + version = "0.17.0"; + hash = "sha256-pJHF7w8RJhV23wiI3qzm5el4qPlPlgYTmTKA8yGhzXY="; + }) + (fetchNuGet { + pname = "xunit"; + version = "2.9.2"; + hash = "sha256-h5+yTTfCmokCPy4lqdEw8RGzQlrlsQAW3Am0Jh0q7oo="; + }) + (fetchNuGet { + pname = "xunit.abstractions"; + version = "2.0.3"; + hash = "sha256-0D1y/C34iARI96gb3bAOG8tcGPMjx+fMabTPpydGlAM="; + }) + (fetchNuGet { + pname = "xunit.analyzers"; + version = "1.16.0"; + hash = "sha256-P5Bvl9hvHvF8KY1YWLg4tKiYxlfRnmHyL14jfSACDaU="; + }) + (fetchNuGet { + pname = "xunit.assert"; + version = "2.9.2"; + hash = "sha256-EE6r526Q4cHn0Ourf1ENpXZ37Lj/P2uNvonHgpdcnq4="; + }) + (fetchNuGet { + pname = "xunit.core"; + version = "2.9.2"; + hash = "sha256-zhjV1I5xh0RFckgTEK72tIkLxVl4CPmter2UB++oye8="; + }) + (fetchNuGet { + pname = "xunit.extensibility.core"; + version = "2.9.2"; + hash = "sha256-MQAC/4d67Nssu3R+pHPh6vHitBXQYxEEZkVVMGW720c="; + }) + (fetchNuGet { + pname = "xunit.extensibility.execution"; + version = "2.9.2"; + hash = "sha256-f+9UfoPyK3JIDhQSW0Yu9c4PGqUqZC96DMINCYi2i80="; + }) + (fetchNuGet { + pname = "xunit.runner.visualstudio"; + version = "2.8.2"; + hash = "sha256-UlfK348r8kJuraywfdCtpJJxHkv04wPNzpUaz4UM/60="; + }) ] diff --git a/pkgs/development/tools/minizinc/default.nix b/pkgs/development/tools/minizinc/default.nix index 183481d872dda2..346fdb18811dcb 100644 --- a/pkgs/development/tools/minizinc/default.nix +++ b/pkgs/development/tools/minizinc/default.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, callPackage, jq, cmake, flex, bison, gecode, mpfr, cbc, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + callPackage, + jq, + cmake, + flex, + bison, + gecode, + mpfr, + cbc, + zlib, +}: stdenv.mkDerivation (finalAttrs: { pname = "minizinc"; @@ -11,9 +24,19 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-2JCTOgnzGeh106YBkLPM46MgnB4XHZmdMXNn1P0OBqA="; }; - nativeBuildInputs = [ bison cmake flex jq ]; + nativeBuildInputs = [ + bison + cmake + flex + jq + ]; - buildInputs = [ gecode mpfr cbc zlib ]; + buildInputs = [ + gecode + mpfr + cbc + zlib + ]; postInstall = '' mkdir -p $out/share/minizinc/solvers/ diff --git a/pkgs/development/tools/minizinc/ide.nix b/pkgs/development/tools/minizinc/ide.nix index f6535569abf759..3c348570f6bb0c 100644 --- a/pkgs/development/tools/minizinc/ide.nix +++ b/pkgs/development/tools/minizinc/ide.nix @@ -1,7 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, qtbase, qmake, qtwebsockets, minizinc, makeWrapper, Cocoa }: +{ + lib, + stdenv, + fetchFromGitHub, + qtbase, + qmake, + qtwebsockets, + minizinc, + makeWrapper, + Cocoa, +}: let - executableLoc = if stdenv.hostPlatform.isDarwin then "$out/Applications/MiniZincIDE.app/Contents/MacOS/MiniZincIDE" else "$out/bin/MiniZincIDE"; + executableLoc = + if stdenv.hostPlatform.isDarwin then + "$out/Applications/MiniZincIDE.app/Contents/MacOS/MiniZincIDE" + else + "$out/bin/MiniZincIDE"; in stdenv.mkDerivation rec { pname = "minizinc-ide"; @@ -15,21 +29,29 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ qmake makeWrapper ]; - buildInputs = [ qtbase qtwebsockets ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; + nativeBuildInputs = [ + qmake + makeWrapper + ]; + buildInputs = [ + qtbase + qtwebsockets + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; sourceRoot = "${src.name}/MiniZincIDE"; dontWrapQtApps = true; - postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p $out/Applications - mv $out/bin/MiniZincIDE.app $out/Applications/ - '' + '' - wrapProgram ${executableLoc} \ - --prefix PATH ":" ${lib.makeBinPath [ minizinc ]} \ - --set QT_QPA_PLATFORM_PLUGIN_PATH "${qtbase}/lib/qt-6/plugins/platforms" - ''; + postInstall = + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p $out/Applications + mv $out/bin/MiniZincIDE.app $out/Applications/ + '' + + '' + wrapProgram ${executableLoc} \ + --prefix PATH ":" ${lib.makeBinPath [ minizinc ]} \ + --set QT_QPA_PLATFORM_PLUGIN_PATH "${qtbase}/lib/qt-6/plugins/platforms" + ''; meta = with lib; { homepage = "https://www.minizinc.org/"; diff --git a/pkgs/development/tools/misc/autoconf/2.13.nix b/pkgs/development/tools/misc/autoconf/2.13.nix index 8fba52aa1fd937..e829c1cd968480 100644 --- a/pkgs/development/tools/misc/autoconf/2.13.nix +++ b/pkgs/development/tools/misc/autoconf/2.13.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, m4, perl }: +{ + lib, + stdenv, + fetchurl, + m4, + perl, +}: stdenv.mkDerivation rec { pname = "autoconf"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "07krzl4czczdsgzrrw9fiqx35xcf32naf751khg821g5pqv12qgh"; }; - nativeBuildInputs = [ m4 perl ]; + nativeBuildInputs = [ + m4 + perl + ]; strictDeps = true; doCheck = true; diff --git a/pkgs/development/tools/misc/autoconf/2.64.nix b/pkgs/development/tools/misc/autoconf/2.64.nix index c505cc6948054f..e0c0f6810c67cf 100644 --- a/pkgs/development/tools/misc/autoconf/2.64.nix +++ b/pkgs/development/tools/misc/autoconf/2.64.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, m4, perl }: +{ + lib, + stdenv, + fetchurl, + m4, + perl, +}: stdenv.mkDerivation rec { pname = "autoconf"; @@ -10,7 +16,10 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ m4 perl ]; + nativeBuildInputs = [ + m4 + perl + ]; buildInputs = [ m4 ]; # Work around a known issue in Cygwin. See diff --git a/pkgs/development/tools/misc/autoconf/2.69.nix b/pkgs/development/tools/misc/autoconf/2.69.nix index bdd534055a5a09..046c885e9955c0 100644 --- a/pkgs/development/tools/misc/autoconf/2.69.nix +++ b/pkgs/development/tools/misc/autoconf/2.69.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, m4, perl }: +{ + lib, + stdenv, + fetchurl, + m4, + perl, +}: stdenv.mkDerivation rec { pname = "autoconf"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "113nlmidxy9kjr45kg9x3ngar4951mvag1js2a3j8nxcz34wxsv4"; }; - nativeBuildInputs = [ m4 perl ]; + nativeBuildInputs = [ + m4 + perl + ]; buildInputs = [ m4 ]; # Work around a known issue in Cygwin. See diff --git a/pkgs/development/tools/misc/autoconf/2.71.nix b/pkgs/development/tools/misc/autoconf/2.71.nix index bfc24892ecd92d..96b369d68e7f05 100644 --- a/pkgs/development/tools/misc/autoconf/2.71.nix +++ b/pkgs/development/tools/misc/autoconf/2.71.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, m4, perl, texinfo }: +{ + lib, + stdenv, + fetchurl, + m4, + perl, + texinfo, +}: # Note: this package is used for bootstrapping fetchurl, and thus # cannot use fetchpatch! All mutable patches (generated by GitHub or @@ -8,7 +15,10 @@ stdenv.mkDerivation rec { pname = "autoconf"; version = "2.71"; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; src = fetchurl { url = "mirror://gnu/autoconf/autoconf-${version}.tar.xz"; @@ -21,7 +31,11 @@ stdenv.mkDerivation rec { ]; strictDeps = true; - nativeBuildInputs = [ m4 perl texinfo ]; + nativeBuildInputs = [ + m4 + perl + texinfo + ]; buildInputs = [ m4 ]; postBuild = " make html @@ -44,7 +58,7 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; # Make the Autotest test suite run in parallel. - preCheck ='' + preCheck = '' export TESTSUITEFLAGS="-j$NIX_BUILD_CORES" ''; diff --git a/pkgs/development/tools/misc/autoconf/default.nix b/pkgs/development/tools/misc/autoconf/default.nix index 9f4ee80d1a767b..6eac0fd1839335 100644 --- a/pkgs/development/tools/misc/autoconf/default.nix +++ b/pkgs/development/tools/misc/autoconf/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, m4, perl, texinfo }: +{ + lib, + stdenv, + fetchurl, + m4, + perl, + texinfo, +}: # Note: this package is used for bootstrapping fetchurl, and thus # cannot use fetchpatch! All mutable patches (generated by GitHub or @@ -8,7 +15,10 @@ stdenv.mkDerivation rec { pname = "autoconf"; version = "2.72"; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; src = fetchurl { url = "mirror://gnu/autoconf/autoconf-${version}.tar.xz"; @@ -16,7 +26,11 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ m4 perl texinfo ]; + nativeBuildInputs = [ + m4 + perl + texinfo + ]; buildInputs = [ m4 ]; postBuild = " make html @@ -39,7 +53,7 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; # Make the Autotest test suite run in parallel. - preCheck ='' + preCheck = '' export TESTSUITEFLAGS="-j$NIX_BUILD_CORES" ''; diff --git a/pkgs/development/tools/misc/automake/automake-1.11.x.nix b/pkgs/development/tools/misc/automake/automake-1.11.x.nix index 161dca6f1805d1..20921a95de73f0 100644 --- a/pkgs/development/tools/misc/automake/automake-1.11.x.nix +++ b/pkgs/development/tools/misc/automake/automake-1.11.x.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, perl, autoconf }: +{ + lib, + stdenv, + fetchurl, + perl, + autoconf, +}: stdenv.mkDerivation rec { pname = "automake"; @@ -16,10 +22,16 @@ stdenv.mkDerivation rec { sha256 = "1ffbc6cc41f0ea6c864fbe9485b981679dc5e350f6c4bc6c3512f5a4226936b5"; }; - patches = [ ./fix-test-autoconf-2.69.patch ./fix-perl-5.26.patch ]; + patches = [ + ./fix-test-autoconf-2.69.patch + ./fix-perl-5.26.patch + ]; strictDeps = true; - nativeBuildInputs = [ perl autoconf ]; + nativeBuildInputs = [ + perl + autoconf + ]; buildInputs = [ autoconf ]; doCheck = false; # takes _a lot_ of time, fails 11 of 782 tests diff --git a/pkgs/development/tools/misc/automake/automake-1.15.x.nix b/pkgs/development/tools/misc/automake/automake-1.15.x.nix index f0df759ee2cf69..3defb1dd9148d5 100644 --- a/pkgs/development/tools/misc/automake/automake-1.15.x.nix +++ b/pkgs/development/tools/misc/automake/automake-1.15.x.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, perl, autoconf }: +{ + lib, + stdenv, + fetchurl, + perl, + autoconf, +}: stdenv.mkDerivation rec { pname = "automake"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1bzd9g32dfm4rsbw93ld9x7b5nc1y6i4m6zp032qf1i28a8s6sxg"; }; - nativeBuildInputs = [ autoconf perl ]; + nativeBuildInputs = [ + autoconf + perl + ]; buildInputs = [ autoconf ]; setupHook = ./setup-hook.sh; diff --git a/pkgs/development/tools/misc/automake/automake-1.16.x.nix b/pkgs/development/tools/misc/automake/automake-1.16.x.nix index 20fe31ef6cd7f6..4fa03389760d50 100644 --- a/pkgs/development/tools/misc/automake/automake-1.16.x.nix +++ b/pkgs/development/tools/misc/automake/automake-1.16.x.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, perl, autoconf, updateAutotoolsGnuConfigScriptsHook }: +{ + lib, + stdenv, + fetchurl, + perl, + autoconf, + updateAutotoolsGnuConfigScriptsHook, +}: stdenv.mkDerivation rec { pname = "automake"; @@ -10,7 +17,11 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook autoconf perl ]; + nativeBuildInputs = [ + updateAutotoolsGnuConfigScriptsHook + autoconf + perl + ]; buildInputs = [ autoconf ]; setupHook = ./setup-hook.sh; diff --git a/pkgs/development/tools/misc/automake/automake-1.17.x.nix b/pkgs/development/tools/misc/automake/automake-1.17.x.nix index 991049a4795052..91f8857c0a2294 100644 --- a/pkgs/development/tools/misc/automake/automake-1.17.x.nix +++ b/pkgs/development/tools/misc/automake/automake-1.17.x.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, perl, autoconf, updateAutotoolsGnuConfigScriptsHook }: +{ + lib, + stdenv, + fetchurl, + perl, + autoconf, + updateAutotoolsGnuConfigScriptsHook, +}: stdenv.mkDerivation rec { pname = "automake"; @@ -10,7 +17,11 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook autoconf perl ]; + nativeBuildInputs = [ + updateAutotoolsGnuConfigScriptsHook + autoconf + perl + ]; buildInputs = [ autoconf ]; setupHook = ./setup-hook.sh; diff --git a/pkgs/development/tools/misc/binutils/2.38/default.nix b/pkgs/development/tools/misc/binutils/2.38/default.nix index 474a565f351f9f..2fe833bc2841ff 100644 --- a/pkgs/development/tools/misc/binutils/2.38/default.nix +++ b/pkgs/development/tools/misc/binutils/2.38/default.nix @@ -1,30 +1,32 @@ -{ stdenv -, autoreconfHook -, autoconf269, automake, libtool -, bison -, buildPackages -, fetchFromGitHub -, fetchurl -, flex -, gettext -, lib -, noSysDirs -, perl -, substitute -, texinfo -, zlib - -, enableGold ? stdenv.targetPlatform.isElf -, enableShared ? !stdenv.hostPlatform.isStatic +{ + stdenv, + autoreconfHook, + autoconf269, + automake, + libtool, + bison, + buildPackages, + fetchFromGitHub, + fetchurl, + flex, + gettext, + lib, + noSysDirs, + perl, + substitute, + texinfo, + zlib, + + enableGold ? stdenv.targetPlatform.isElf, + enableShared ? !stdenv.hostPlatform.isStatic, # WARN: Enabling all targets increases output size to a multiple. -, withAllTargets ? false + withAllTargets ? false, }: # WARN: configure silently disables ld.gold if it's unsupported, so we need to # make sure that intent matches result ourselves. assert enableGold -> stdenv.targetPlatform.isElf; - let inherit (stdenv) buildPlatform hostPlatform targetPlatform; @@ -53,138 +55,181 @@ stdenv.mkDerivation { inherit version; # HACK: Ensure that we preserve source from bootstrap binutils to not rebuild LLVM - src = stdenv.__bootPackages.binutils-unwrapped_2_38.src - or srcs.${targetPlatform.system} - or srcs.normal; + src = + stdenv.__bootPackages.binutils-unwrapped_2_38.src or srcs.${targetPlatform.system} or srcs.normal; # WARN: this package is used for bootstrapping fetchurl, and thus cannot use # fetchpatch! All mutable patches (generated by GitHub or cgit) that are # needed here should be included directly in Nixpkgs as files. - patches = [ - # Make binutils output deterministic by default. - ./deterministic.patch - - - # Breaks nm BSD flag detection - ./0001-Revert-libtool.m4-fix-nm-BSD-flag-detection.patch - - # Required for newer macos versions - ./0001-libtool.m4-update-macos-version-detection-block.patch - - # For some reason bfd ld doesn't search DT_RPATH when cross-compiling. It's - # not clear why this behavior was decided upon but it has the unfortunate - # consequence that the linker will fail to find transitive dependencies of - # shared objects when cross-compiling. Consequently, we are forced to - # override this behavior, forcing ld to search DT_RPATH even when - # cross-compiling. - ./always-search-rpath.patch - - # Fixed in 2.39 - # https://sourceware.org/bugzilla/show_bug.cgi?id=28885 - # https://sourceware.org/git/?p=binutils-gdb.git;a=patch;h=99852365513266afdd793289813e8e565186c9e6 - # https://github.com/NixOS/nixpkgs/issues/170946 - ./deterministic-temp-prefixes.patch - ] - ++ lib.optional targetPlatform.isiOS ./support-ios.patch - ++ lib.optional stdenv.targetPlatform.isWindows ./windres-locate-gcc.patch - ++ lib.optional stdenv.targetPlatform.isMips64n64 - # this patch is from debian: - # https://sources.debian.org/data/main/b/binutils/2.38-3/debian/patches/mips64-default-n64.diff - (if stdenv.targetPlatform.isMusl - then substitute { src = ./mips64-default-n64.patch; substitutions = [ "--replace" "gnuabi64" "muslabi64" ]; } - else ./mips64-default-n64.patch) - # On PowerPC, when generating assembly code, GCC generates a `.machine` - # custom instruction which instructs the assembler to generate code for this - # machine. However, some GCC versions generate the wrong one, or make it - # too strict, which leads to some confusing "unrecognized opcode: wrtee" - # or "unrecognized opcode: eieio" errors. - # - # To remove when binutils 2.39 is released. - # - # Upstream commit: - # https://sourceware.org/git/?p=binutils-gdb.git;a=commit;h=cebc89b9328eab994f6b0314c263f94e7949a553 - ++ lib.optional stdenv.targetPlatform.isPower ./ppc-make-machine-less-strict.patch - ; - - outputs = [ "out" "info" "man" ]; + patches = + [ + # Make binutils output deterministic by default. + ./deterministic.patch + + # Breaks nm BSD flag detection + ./0001-Revert-libtool.m4-fix-nm-BSD-flag-detection.patch + + # Required for newer macos versions + ./0001-libtool.m4-update-macos-version-detection-block.patch + + # For some reason bfd ld doesn't search DT_RPATH when cross-compiling. It's + # not clear why this behavior was decided upon but it has the unfortunate + # consequence that the linker will fail to find transitive dependencies of + # shared objects when cross-compiling. Consequently, we are forced to + # override this behavior, forcing ld to search DT_RPATH even when + # cross-compiling. + ./always-search-rpath.patch + + # Fixed in 2.39 + # https://sourceware.org/bugzilla/show_bug.cgi?id=28885 + # https://sourceware.org/git/?p=binutils-gdb.git;a=patch;h=99852365513266afdd793289813e8e565186c9e6 + # https://github.com/NixOS/nixpkgs/issues/170946 + ./deterministic-temp-prefixes.patch + ] + ++ lib.optional targetPlatform.isiOS ./support-ios.patch + ++ lib.optional stdenv.targetPlatform.isWindows ./windres-locate-gcc.patch + ++ + lib.optional stdenv.targetPlatform.isMips64n64 + # this patch is from debian: + # https://sources.debian.org/data/main/b/binutils/2.38-3/debian/patches/mips64-default-n64.diff + ( + if stdenv.targetPlatform.isMusl then + substitute { + src = ./mips64-default-n64.patch; + substitutions = [ + "--replace" + "gnuabi64" + "muslabi64" + ]; + } + else + ./mips64-default-n64.patch + ) + # On PowerPC, when generating assembly code, GCC generates a `.machine` + # custom instruction which instructs the assembler to generate code for this + # machine. However, some GCC versions generate the wrong one, or make it + # too strict, which leads to some confusing "unrecognized opcode: wrtee" + # or "unrecognized opcode: eieio" errors. + # + # To remove when binutils 2.39 is released. + # + # Upstream commit: + # https://sourceware.org/git/?p=binutils-gdb.git;a=commit;h=cebc89b9328eab994f6b0314c263f94e7949a553 + ++ lib.optional stdenv.targetPlatform.isPower ./ppc-make-machine-less-strict.patch; + + outputs = [ + "out" + "info" + "man" + ]; strictDeps = true; depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ - bison - perl - texinfo - ] - ++ lib.optionals targetPlatform.isiOS [ autoreconfHook ] - ++ lib.optionals buildPlatform.isDarwin [ autoconf269 automake gettext libtool ] - ++ lib.optionals targetPlatform.isVc4 [ flex ] - ; - - buildInputs = [ zlib gettext ]; + nativeBuildInputs = + [ + bison + perl + texinfo + ] + ++ lib.optionals targetPlatform.isiOS [ autoreconfHook ] + ++ lib.optionals buildPlatform.isDarwin [ + autoconf269 + automake + gettext + libtool + ] + ++ lib.optionals targetPlatform.isVc4 [ flex ]; + + buildInputs = [ + zlib + gettext + ]; inherit noSysDirs; - preConfigure = (lib.optionalString buildPlatform.isDarwin '' - for i in */configure.ac; do - pushd "$(dirname "$i")" - echo "Running autoreconf in $PWD" - # autoreconf doesn't work, don't know why - # autoreconf ''${autoreconfFlags:---install --force --verbose} - autoconf - popd - done - '') + '' - # Clear the default library search path. - if test "$noSysDirs" = "1"; then - echo 'NATIVE_LIB_DIRS=' >> ld/configure.tgt - fi - - # Use symlinks instead of hard links to save space ("strip" in the - # fixup phase strips each hard link separately). - for i in binutils/Makefile.in gas/Makefile.in ld/Makefile.in gold/Makefile.in; do - sed -i "$i" -e 's|ln |ln -s |' - done - ''; + preConfigure = + (lib.optionalString buildPlatform.isDarwin '' + for i in */configure.ac; do + pushd "$(dirname "$i")" + echo "Running autoreconf in $PWD" + # autoreconf doesn't work, don't know why + # autoreconf ''${autoreconfFlags:---install --force --verbose} + autoconf + popd + done + '') + + '' + # Clear the default library search path. + if test "$noSysDirs" = "1"; then + echo 'NATIVE_LIB_DIRS=' >> ld/configure.tgt + fi + + # Use symlinks instead of hard links to save space ("strip" in the + # fixup phase strips each hard link separately). + for i in binutils/Makefile.in gas/Makefile.in ld/Makefile.in gold/Makefile.in; do + sed -i "$i" -e 's|ln |ln -s |' + done + ''; # As binutils takes part in the stdenv building, we don't want references # to the bootstrap-tools libgcc (as uses to happen on arm/mips) env.NIX_CFLAGS_COMPILE = - if hostPlatform.isDarwin - then "-Wno-string-plus-int -Wno-deprecated-declarations" - else "-static-libgcc"; - - hardeningDisable = [ "format" "pie" ]; - - configurePlatforms = [ "build" "host" "target" ]; - - configureFlags = [ - "--enable-64-bit-bfd" - "--with-system-zlib" - - "--enable-deterministic-archives" - "--disable-werror" - "--enable-fix-loongson2f-nop" - - # Turn on --enable-new-dtags by default to make the linker set - # RUNPATH instead of RPATH on binaries. This is important because - # RUNPATH can be overridden using LD_LIBRARY_PATH at runtime. - "--enable-new-dtags" - - # force target prefix. Some versions of binutils will make it empty if - # `--host` and `--target` are too close, even if Nixpkgs thinks the - # platforms are different (e.g. because not all the info makes the - # `config`). Other versions of binutils will always prefix if `--target` is - # passed, even if `--host` and `--target` are the same. The easiest thing - # for us to do is not leave it to chance, and force the program prefix to be - # what we want it to be. - "--program-prefix=${targetPrefix}" - ] - ++ lib.optionals withAllTargets [ "--enable-targets=all" ] - ++ lib.optionals enableGold [ "--enable-gold" "--enable-plugins" ] - ++ (if enableShared - then [ "--enable-shared" "--disable-static" ] - else [ "--disable-shared" "--enable-static" ]) - ; + if hostPlatform.isDarwin then + "-Wno-string-plus-int -Wno-deprecated-declarations" + else + "-static-libgcc"; + + hardeningDisable = [ + "format" + "pie" + ]; + + configurePlatforms = [ + "build" + "host" + "target" + ]; + + configureFlags = + [ + "--enable-64-bit-bfd" + "--with-system-zlib" + + "--enable-deterministic-archives" + "--disable-werror" + "--enable-fix-loongson2f-nop" + + # Turn on --enable-new-dtags by default to make the linker set + # RUNPATH instead of RPATH on binaries. This is important because + # RUNPATH can be overridden using LD_LIBRARY_PATH at runtime. + "--enable-new-dtags" + + # force target prefix. Some versions of binutils will make it empty if + # `--host` and `--target` are too close, even if Nixpkgs thinks the + # platforms are different (e.g. because not all the info makes the + # `config`). Other versions of binutils will always prefix if `--target` is + # passed, even if `--host` and `--target` are the same. The easiest thing + # for us to do is not leave it to chance, and force the program prefix to be + # what we want it to be. + "--program-prefix=${targetPrefix}" + ] + ++ lib.optionals withAllTargets [ "--enable-targets=all" ] + ++ lib.optionals enableGold [ + "--enable-gold" + "--enable-plugins" + ] + ++ ( + if enableShared then + [ + "--enable-shared" + "--disable-static" + ] + else + [ + "--disable-shared" + "--enable-static" + ] + ); # Fails doCheck = false; @@ -194,7 +239,11 @@ stdenv.mkDerivation { postFixup = ""; # Break dependency on pkgsBuildBuild.gcc when building a cross-binutils - stripDebugList = if stdenv.hostPlatform != stdenv.targetPlatform then "bin lib ${stdenv.hostPlatform.config}" else null; + stripDebugList = + if stdenv.hostPlatform != stdenv.targetPlatform then + "bin lib ${stdenv.hostPlatform.config}" + else + null; # INFO: Otherwise it fails with: # `./sanity.sh: line 36: $out/bin/size: not found` @@ -218,7 +267,10 @@ stdenv.mkDerivation { ''; homepage = "https://www.gnu.org/software/binutils/"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ ericson2314 lovesegfault ]; + maintainers = with maintainers; [ + ericson2314 + lovesegfault + ]; platforms = platforms.unix; # INFO: Give binutils a lower priority than gcc-wrapper to prevent a diff --git a/pkgs/development/tools/misc/binutils/2.38/libbfd.nix b/pkgs/development/tools/misc/binutils/2.38/libbfd.nix index 313b610560da82..c24d238261155a 100644 --- a/pkgs/development/tools/misc/binutils/2.38/libbfd.nix +++ b/pkgs/development/tools/misc/binutils/2.38/libbfd.nix @@ -1,13 +1,24 @@ -{ lib, stdenv -, fetchpatch, gnu-config, autoreconfHook, bison, binutils-unwrapped_2_38 -, libiberty, libintl, zlib +{ + lib, + stdenv, + fetchpatch, + gnu-config, + autoreconfHook, + bison, + binutils-unwrapped_2_38, + libiberty, + libintl, + zlib, }: stdenv.mkDerivation { pname = "libbfd"; inherit (binutils-unwrapped_2_38) version src; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; patches = binutils-unwrapped_2_38.patches ++ [ ./build-components-separately.patch @@ -31,12 +42,22 @@ stdenv.mkDerivation { dontUpdateAutotoolsGnuConfigScripts = true; strictDeps = true; - nativeBuildInputs = [ autoreconfHook bison ]; - buildInputs = [ libiberty zlib ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libintl ]; + nativeBuildInputs = [ + autoreconfHook + bison + ]; + buildInputs = [ + libiberty + zlib + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libintl ]; - configurePlatforms = [ "build" "host" ]; + configurePlatforms = [ + "build" + "host" + ]; configureFlags = [ - "--enable-targets=all" "--enable-64-bit-bfd" + "--enable-targets=all" + "--enable-64-bit-bfd" "--enable-install-libbfd" "--with-system-zlib" ] ++ lib.optional (!stdenv.hostPlatform.isStatic) "--enable-shared"; diff --git a/pkgs/development/tools/misc/binutils/2.38/libopcodes.nix b/pkgs/development/tools/misc/binutils/2.38/libopcodes.nix index 12a2ebc52fb25b..90377382eafb50 100644 --- a/pkgs/development/tools/misc/binutils/2.38/libopcodes.nix +++ b/pkgs/development/tools/misc/binutils/2.38/libopcodes.nix @@ -1,13 +1,22 @@ -{ lib, stdenv, buildPackages -, autoreconfHook, bison, binutils-unwrapped_2_38 -, libiberty, libbfd_2_38 +{ + lib, + stdenv, + buildPackages, + autoreconfHook, + bison, + binutils-unwrapped_2_38, + libiberty, + libbfd_2_38, }: stdenv.mkDerivation { pname = "libopcodes"; inherit (binutils-unwrapped_2_38) version src; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; patches = binutils-unwrapped_2_38.patches ++ [ ./build-components-separately.patch @@ -20,14 +29,21 @@ stdenv.mkDerivation { ''; depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ autoreconfHook bison ]; + nativeBuildInputs = [ + autoreconfHook + bison + ]; buildInputs = [ libiberty ]; # dis-asm.h includes bfd.h propagatedBuildInputs = [ libbfd_2_38 ]; - configurePlatforms = [ "build" "host" ]; + configurePlatforms = [ + "build" + "host" + ]; configureFlags = [ - "--enable-targets=all" "--enable-64-bit-bfd" + "--enable-targets=all" + "--enable-64-bit-bfd" "--enable-install-libbfd" "--enable-shared" ]; diff --git a/pkgs/development/tools/misc/binutils/default.nix b/pkgs/development/tools/misc/binutils/default.nix index 4d90fa66ea7da5..e9d864f993c3b8 100644 --- a/pkgs/development/tools/misc/binutils/default.nix +++ b/pkgs/development/tools/misc/binutils/default.nix @@ -2,24 +2,27 @@ let withGold = platform: platform.isElf && !platform.isRiscV && !platform.isLoongArch64; in -{ stdenv -, autoconf269, automake, libtool -, bison -, buildPackages -, fetchFromGitHub -, fetchurl -, gettext -, lib -, noSysDirs -, perl -, zlib -, CoreServices - -, enableGold ? withGold stdenv.targetPlatform -, enableGoldDefault ? false -, enableShared ? !stdenv.hostPlatform.isStatic +{ + stdenv, + autoconf269, + automake, + libtool, + bison, + buildPackages, + fetchFromGitHub, + fetchurl, + gettext, + lib, + noSysDirs, + perl, + zlib, + CoreServices, + + enableGold ? withGold stdenv.targetPlatform, + enableGoldDefault ? false, + enableShared ? !stdenv.hostPlatform.isStatic, # WARN: Enabling all targets increases output size to a multiple. -, withAllTargets ? false + withAllTargets ? false, }: # WARN: configure silently disables ld.gold if it's unsupported, so we need to @@ -27,7 +30,6 @@ in assert enableGold -> withGold stdenv.targetPlatform; assert enableGoldDefault -> enableGold; - let inherit (stdenv) buildPlatform hostPlatform targetPlatform; @@ -54,7 +56,6 @@ stdenv.mkDerivation (finalAttrs: { # Make binutils output deterministic by default. ./deterministic.patch - # Breaks nm BSD flag detection, heeds an upstream fix: # https://sourceware.org/PR29547 ./0001-Revert-libtool.m4-fix-the-NM-nm-over-here-B-option-w.patch @@ -85,57 +86,73 @@ stdenv.mkDerivation (finalAttrs: { ./windres-locate-gcc.patch ]; - outputs = [ "out" "info" "man" "dev" ] - # Ideally we would like to always install 'lib' into a separate - # target. Unfortunately cross-compiled binutils installs libraries - # across both `$lib/lib/` and `$out/$target/lib` with a reference - # from $out to $lib. Probably a binutils bug: all libraries should go - # to $lib as binutils does not build target libraries. Let's make our - # life slightly simpler by installing everything into $out for - # cross-binutils. - ++ lib.optionals (targetPlatform == hostPlatform) [ "lib" ]; + outputs = + [ + "out" + "info" + "man" + "dev" + ] + # Ideally we would like to always install 'lib' into a separate + # target. Unfortunately cross-compiled binutils installs libraries + # across both `$lib/lib/` and `$out/$target/lib` with a reference + # from $out to $lib. Probably a binutils bug: all libraries should go + # to $lib as binutils does not build target libraries. Let's make our + # life slightly simpler by installing everything into $out for + # cross-binutils. + ++ lib.optionals (targetPlatform == hostPlatform) [ "lib" ]; strictDeps = true; depsBuildBuild = [ buildPackages.stdenv.cc ]; # texinfo was removed here in https://github.com/NixOS/nixpkgs/pull/210132 # to reduce rebuilds during stdenv bootstrap. Please don't add it back without # checking the impact there first. - nativeBuildInputs = [ - bison - perl - ] - ++ lib.optionals buildPlatform.isDarwin [ autoconf269 automake gettext libtool ] - ; - - buildInputs = [ zlib gettext ] ++ lib.optionals hostPlatform.isDarwin [ CoreServices ]; + nativeBuildInputs = + [ + bison + perl + ] + ++ lib.optionals buildPlatform.isDarwin [ + autoconf269 + automake + gettext + libtool + ]; + + buildInputs = [ + zlib + gettext + ] ++ lib.optionals hostPlatform.isDarwin [ CoreServices ]; inherit noSysDirs; - preConfigure = (lib.optionalString buildPlatform.isDarwin '' - for i in */configure.ac; do - pushd "$(dirname "$i")" - echo "Running autoreconf in $PWD" - # autoreconf doesn't work, don't know why - # autoreconf ''${autoreconfFlags:---install --force --verbose} - autoconf - popd - done - '') + '' - # Clear the default library search path. - if test "$noSysDirs" = "1"; then - echo 'NATIVE_LIB_DIRS=' >> ld/configure.tgt - fi - - # Use symlinks instead of hard links to save space ("strip" in the - # fixup phase strips each hard link separately). - for i in binutils/Makefile.in gas/Makefile.in ld/Makefile.in gold/Makefile.in; do - sed -i "$i" -e 's|ln |ln -s |' - done - - # autoreconfHook is not included for all targets. - # Call it here explicitly as well. - ${finalAttrs.postAutoreconf} - ''; + preConfigure = + (lib.optionalString buildPlatform.isDarwin '' + for i in */configure.ac; do + pushd "$(dirname "$i")" + echo "Running autoreconf in $PWD" + # autoreconf doesn't work, don't know why + # autoreconf ''${autoreconfFlags:---install --force --verbose} + autoconf + popd + done + '') + + '' + # Clear the default library search path. + if test "$noSysDirs" = "1"; then + echo 'NATIVE_LIB_DIRS=' >> ld/configure.tgt + fi + + # Use symlinks instead of hard links to save space ("strip" in the + # fixup phase strips each hard link separately). + for i in binutils/Makefile.in gas/Makefile.in ld/Makefile.in gold/Makefile.in; do + sed -i "$i" -e 's|ln |ln -s |' + done + + # autoreconfHook is not included for all targets. + # Call it here explicitly as well. + ${finalAttrs.postAutoreconf} + ''; postAutoreconf = '' # As we regenerated configure build system tries hard to use @@ -155,67 +172,91 @@ stdenv.mkDerivation (finalAttrs: { # LONG_MIN. The configure test itself succeeds but the compiler issues a # warning about -static-libgcc being unused. env.NIX_CFLAGS_COMPILE = - if (hostPlatform.isDarwin || hostPlatform.isFreeBSD) - then "-Wno-string-plus-int -Wno-deprecated-declarations" - else "-static-libgcc"; - - hardeningDisable = [ "format" "pie" ]; - - configurePlatforms = [ "build" "host" "target" ]; - - configureFlags = [ - "--enable-64-bit-bfd" - "--with-system-zlib" - - "--enable-deterministic-archives" - "--disable-werror" - "--enable-fix-loongson2f-nop" - - # Turn on --enable-new-dtags by default to make the linker set - # RUNPATH instead of RPATH on binaries. This is important because - # RUNPATH can be overridden using LD_LIBRARY_PATH at runtime. - "--enable-new-dtags" - - # force target prefix. Some versions of binutils will make it empty if - # `--host` and `--target` are too close, even if Nixpkgs thinks the - # platforms are different (e.g. because not all the info makes the - # `config`). Other versions of binutils will always prefix if `--target` is - # passed, even if `--host` and `--target` are the same. The easiest thing - # for us to do is not leave it to chance, and force the program prefix to be - # what we want it to be. - "--program-prefix=${targetPrefix}" - - # Unconditionally disable: - # - musl target needs porting: https://sourceware.org/PR29477 - "--disable-gprofng" - - # By default binutils searches $libdir for libraries. This brings in - # libbfd and libopcodes into a default visibility. Drop default lib - # path to force users to declare their use of these libraries. - "--with-lib-path=:" - ] - ++ lib.optionals withAllTargets [ "--enable-targets=all" ] - ++ lib.optionals enableGold [ - "--enable-gold${lib.optionalString enableGoldDefault "=default"}" - "--enable-plugins" - ] ++ (if enableShared - then [ "--enable-shared" "--disable-static" ] - else [ "--disable-shared" "--enable-static" ]) - ++ (lib.optionals (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") [ - # lld17+ passes `--no-undefined-version` by default and makes this a hard - # error; libctf.ver version script references symbols that aren't present. - # - # This is fixed upstream and can be removed with the future release of 2.43. - # For now we allow this with `--undefined-version`: - "LDFLAGS=-Wl,--undefined-version" - ]) - ; + if (hostPlatform.isDarwin || hostPlatform.isFreeBSD) then + "-Wno-string-plus-int -Wno-deprecated-declarations" + else + "-static-libgcc"; + + hardeningDisable = [ + "format" + "pie" + ]; + + configurePlatforms = [ + "build" + "host" + "target" + ]; + + configureFlags = + [ + "--enable-64-bit-bfd" + "--with-system-zlib" + + "--enable-deterministic-archives" + "--disable-werror" + "--enable-fix-loongson2f-nop" + + # Turn on --enable-new-dtags by default to make the linker set + # RUNPATH instead of RPATH on binaries. This is important because + # RUNPATH can be overridden using LD_LIBRARY_PATH at runtime. + "--enable-new-dtags" + + # force target prefix. Some versions of binutils will make it empty if + # `--host` and `--target` are too close, even if Nixpkgs thinks the + # platforms are different (e.g. because not all the info makes the + # `config`). Other versions of binutils will always prefix if `--target` is + # passed, even if `--host` and `--target` are the same. The easiest thing + # for us to do is not leave it to chance, and force the program prefix to be + # what we want it to be. + "--program-prefix=${targetPrefix}" + + # Unconditionally disable: + # - musl target needs porting: https://sourceware.org/PR29477 + "--disable-gprofng" + + # By default binutils searches $libdir for libraries. This brings in + # libbfd and libopcodes into a default visibility. Drop default lib + # path to force users to declare their use of these libraries. + "--with-lib-path=:" + ] + ++ lib.optionals withAllTargets [ "--enable-targets=all" ] + ++ lib.optionals enableGold [ + "--enable-gold${lib.optionalString enableGoldDefault "=default"}" + "--enable-plugins" + ] + ++ ( + if enableShared then + [ + "--enable-shared" + "--disable-static" + ] + else + [ + "--disable-shared" + "--enable-static" + ] + ) + ++ (lib.optionals (stdenv.cc.bintools.isLLVM && lib.versionAtLeast stdenv.cc.bintools.version "17") + [ + # lld17+ passes `--no-undefined-version` by default and makes this a hard + # error; libctf.ver version script references symbols that aren't present. + # + # This is fixed upstream and can be removed with the future release of 2.43. + # For now we allow this with `--undefined-version`: + "LDFLAGS=-Wl,--undefined-version" + ] + ); # Fails doCheck = false; # Break dependency on pkgsBuildBuild.gcc when building a cross-binutils - stripDebugList = if stdenv.hostPlatform != stdenv.targetPlatform then "bin lib ${stdenv.hostPlatform.config}" else null; + stripDebugList = + if stdenv.hostPlatform != stdenv.targetPlatform then + "bin lib ${stdenv.hostPlatform.config}" + else + null; # INFO: Otherwise it fails with: # `./sanity.sh: line 36: $out/bin/size: not found` @@ -255,7 +296,10 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://www.gnu.org/software/binutils/"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ ericson2314 lovesegfault ]; + maintainers = with maintainers; [ + ericson2314 + lovesegfault + ]; platforms = platforms.unix; # INFO: Give binutils a lower priority than gcc-wrapper to prevent a diff --git a/pkgs/development/tools/misc/binutils/libbfd.nix b/pkgs/development/tools/misc/binutils/libbfd.nix index c6ab2a6431d062..983c4f0c3db362 100644 --- a/pkgs/development/tools/misc/binutils/libbfd.nix +++ b/pkgs/development/tools/misc/binutils/libbfd.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, binutils-unwrapped-all-targets +{ + lib, + stdenv, + binutils-unwrapped-all-targets, }: stdenv.mkDerivation { diff --git a/pkgs/development/tools/misc/binutils/libopcodes.nix b/pkgs/development/tools/misc/binutils/libopcodes.nix index c8d3b78b29eb7f..52f0f801cf6711 100644 --- a/pkgs/development/tools/misc/binutils/libopcodes.nix +++ b/pkgs/development/tools/misc/binutils/libopcodes.nix @@ -1,5 +1,7 @@ -{ lib, stdenv -, binutils-unwrapped-all-targets +{ + lib, + stdenv, + binutils-unwrapped-all-targets, }: stdenv.mkDerivation { diff --git a/pkgs/development/tools/misc/blackfire/default.nix b/pkgs/development/tools/misc/blackfire/default.nix index bf8d7c81866742..f68900c1fddf54 100644 --- a/pkgs/development/tools/misc/blackfire/default.nix +++ b/pkgs/development/tools/misc/blackfire/default.nix @@ -1,18 +1,21 @@ -{ stdenv -, lib -, fetchurl -, dpkg -, writeShellScript -, curl -, jq -, common-updater-scripts +{ + stdenv, + lib, + fetchurl, + dpkg, + writeShellScript, + curl, + jq, + common-updater-scripts, }: stdenv.mkDerivation rec { pname = "blackfire"; version = "2.28.20"; - src = passthru.sources.${stdenv.hostPlatform.system} or (throw "Unsupported platform for blackfire: ${stdenv.hostPlatform.system}"); + src = + passthru.sources.${stdenv.hostPlatform.system} + or (throw "Unsupported platform for blackfire: ${stdenv.hostPlatform.system}"); nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ dpkg @@ -23,7 +26,7 @@ stdenv.mkDerivation rec { installPhase = '' runHook preInstall - if ${ lib.boolToString stdenv.hostPlatform.isLinux } + if ${lib.boolToString stdenv.hostPlatform.isLinux} then dpkg-deb -x $src $out mv $out/usr/* $out @@ -79,7 +82,13 @@ stdenv.mkDerivation rec { updateScript = writeShellScript "update-blackfire" '' set -o errexit - export PATH="${lib.makeBinPath [ curl jq common-updater-scripts ]}" + export PATH="${ + lib.makeBinPath [ + curl + jq + common-updater-scripts + ] + }" NEW_VERSION=$(curl -s https://blackfire.io/api/v1/releases | jq .cli --raw-output) if [[ "${version}" = "$NEW_VERSION" ]]; then @@ -99,6 +108,12 @@ stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; maintainers = with maintainers; [ shyim ]; - platforms = [ "x86_64-linux" "aarch64-linux" "i686-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "i686-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; }; } diff --git a/pkgs/development/tools/misc/blackfire/php-probe.nix b/pkgs/development/tools/misc/blackfire/php-probe.nix index 4e280e5f3bdd39..87bc0d93efe695 100644 --- a/pkgs/development/tools/misc/blackfire/php-probe.nix +++ b/pkgs/development/tools/misc/blackfire/php-probe.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchurl -, autoPatchelfHook -, php -, writeShellScript -, curl -, jq -, common-updater-scripts +{ + stdenv, + lib, + fetchurl, + autoPatchelfHook, + php, + writeShellScript, + curl, + jq, + common-updater-scripts, }: assert lib.assertMsg (!php.ztsSupport) "blackfire only supports non zts versions of PHP"; @@ -60,17 +61,22 @@ let }; }; - makeSource = { system, phpMajor }: + makeSource = + { system, phpMajor }: let isLinux = builtins.match ".+-linux" system != null; in fetchurl { - url = "https://packages.blackfire.io/binaries/blackfire-php/${version}/blackfire-php-${if isLinux then "linux" else "darwin"}_${hashes.${system}.system}-php-${builtins.replaceStrings [ "." ] [ "" ] phpMajor}.so"; + url = "https://packages.blackfire.io/binaries/blackfire-php/${version}/blackfire-php-${ + if isLinux then "linux" else "darwin" + }_${hashes.${system}.system}-php-${builtins.replaceStrings [ "." ] [ "" ] phpMajor}.so"; hash = hashes.${system}.hash.${phpMajor}; }; in -assert lib.assertMsg (hashes ? ${system}.hash.${phpMajor}) "blackfire does not support PHP version ${phpMajor} on ${system}."; +assert lib.assertMsg ( + hashes ? ${system}.hash.${phpMajor} +) "blackfire does not support PHP version ${phpMajor} on ${system}."; stdenv.mkDerivation (finalAttrs: { pname = "php-blackfire"; @@ -100,7 +106,13 @@ stdenv.mkDerivation (finalAttrs: { passthru = { updateScript = writeShellScript "update-${finalAttrs.pname}" '' set -o errexit - export PATH="${lib.makeBinPath [ curl jq common-updater-scripts ]}" + export PATH="${ + lib.makeBinPath [ + curl + jq + common-updater-scripts + ] + }" NEW_VERSION=$(curl --silent https://blackfire.io/api/v1/releases | jq .probe.php --raw-output) if [[ "${version}" = "$NEW_VERSION" ]]; then @@ -116,15 +128,16 @@ stdenv.mkDerivation (finalAttrs: { # All sources for updating by the update script. updateables = let - createName = { phpMajor, system }: - "php${builtins.replaceStrings [ "." ] [ "" ] phpMajor}_${system}"; + createName = + { phpMajor, system }: "php${builtins.replaceStrings [ "." ] [ "" ] phpMajor}_${system}"; - createUpdateable = sourceParams: - lib.nameValuePair - (createName sourceParams) - (finalAttrs.finalPackage.overrideAttrs (attrs: { + createUpdateable = + sourceParams: + lib.nameValuePair (createName sourceParams) ( + finalAttrs.finalPackage.overrideAttrs (attrs: { src = makeSource sourceParams; - })); + }) + ); in lib.concatMapAttrs ( system: @@ -139,7 +152,13 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://blackfire.io/"; license = lib.licenses.unfree; maintainers = with lib.maintainers; [ shyim ]; - platforms = [ "x86_64-linux" "aarch64-linux" "i686-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "i686-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; }; }) diff --git a/pkgs/development/tools/misc/chruby/default.nix b/pkgs/development/tools/misc/chruby/default.nix index 10d6d2e7d020c0..279c1238f055a0 100644 --- a/pkgs/development/tools/misc/chruby/default.nix +++ b/pkgs/development/tools/misc/chruby/default.nix @@ -1,13 +1,19 @@ -{ stdenv, lib, fetchFromGitHub, runCommand, rubies ? null }: +{ + stdenv, + lib, + fetchFromGitHub, + runCommand, + rubies ? null, +}: let rubiesEnv = runCommand "chruby-env" { preferLocalBuild = true; } '' mkdir $out - ${lib.concatStrings - (lib.mapAttrsToList (name: path: "ln -s ${path} $out/${name}\n") rubies)} + ${lib.concatStrings (lib.mapAttrsToList (name: path: "ln -s ${path} $out/${name}\n") rubies)} ''; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "chruby"; version = "0.3.9"; diff --git a/pkgs/development/tools/misc/cmake-language-server/default.nix b/pkgs/development/tools/misc/cmake-language-server/default.nix index 5b8cc307cb0440..db14eb249dfc1c 100644 --- a/pkgs/development/tools/misc/cmake-language-server/default.nix +++ b/pkgs/development/tools/misc/cmake-language-server/default.nix @@ -1,13 +1,14 @@ -{ lib -, buildPythonApplication -, pythonOlder -, fetchFromGitHub -, pdm-backend -, cmake-format -, pygls -, cmake -, pytest-datadir -, pytestCheckHook +{ + lib, + buildPythonApplication, + pythonOlder, + fetchFromGitHub, + pdm-backend, + cmake-format, + pygls, + cmake, + pytest-datadir, + pytestCheckHook, }: buildPythonApplication rec { diff --git a/pkgs/development/tools/misc/coreboot-toolchain/default.nix b/pkgs/development/tools/misc/coreboot-toolchain/default.nix index a7a923a6d48429..523c261d1619ac 100644 --- a/pkgs/development/tools/misc/coreboot-toolchain/default.nix +++ b/pkgs/development/tools/misc/coreboot-toolchain/default.nix @@ -104,4 +104,3 @@ lib.listToAttrs ( "ppc64" ] ) - diff --git a/pkgs/development/tools/misc/creduce/default.nix b/pkgs/development/tools/misc/creduce/default.nix index a8b6acb1e3f93a..a893a0acb8a188 100644 --- a/pkgs/development/tools/misc/creduce/default.nix +++ b/pkgs/development/tools/misc/creduce/default.nix @@ -1,9 +1,16 @@ -{ lib, stdenv, fetchurl, fetchpatch, cmake, makeWrapper -, llvm, libclang -, flex -, zlib -, perlPackages -, util-linux +{ + lib, + stdenv, + fetchurl, + fetchpatch, + cmake, + makeWrapper, + llvm, + libclang, + flex, + zlib, + perlPackages, + util-linux, }: stdenv.mkDerivation rec { @@ -32,26 +39,42 @@ stdenv.mkDerivation rec { }) ]; - postPatch = '' - substituteInPlace CMakeLists.txt \ - --replace "-std=c++11" "-std=c++17" - '' - # On Linux, c-reduce's preferred way to reason about - # the cpu architecture/topology is to use 'lscpu', - # so let's make sure it knows where to find it: - + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace creduce/creduce_utils.pm --replace \ - lscpu ${util-linux}/bin/lscpu - ''; + postPatch = + '' + substituteInPlace CMakeLists.txt \ + --replace "-std=c++11" "-std=c++17" + '' + # On Linux, c-reduce's preferred way to reason about + # the cpu architecture/topology is to use 'lscpu', + # so let's make sure it knows where to find it: + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace creduce/creduce_utils.pm --replace \ + lscpu ${util-linux}/bin/lscpu + ''; - nativeBuildInputs = [ cmake makeWrapper llvm.dev ]; - buildInputs = [ - # Ensure stdenv's CC is on PATH before clang-unwrapped - stdenv.cc - # Actual deps: - llvm libclang - flex zlib - ] ++ (with perlPackages; [ perl ExporterLite FileWhich GetoptTabular RegexpCommon TermReadKey ]); + nativeBuildInputs = [ + cmake + makeWrapper + llvm.dev + ]; + buildInputs = + [ + # Ensure stdenv's CC is on PATH before clang-unwrapped + stdenv.cc + # Actual deps: + llvm + libclang + flex + zlib + ] + ++ (with perlPackages; [ + perl + ExporterLite + FileWhich + GetoptTabular + RegexpCommon + TermReadKey + ]); postInstall = '' wrapProgram $out/bin/creduce --prefix PERL5LIB : "$PERL5LIB" diff --git a/pkgs/development/tools/misc/ctags/default.nix b/pkgs/development/tools/misc/ctags/default.nix index fadc3b3830ce7f..5d3bd729129d18 100644 --- a/pkgs/development/tools/misc/ctags/default.nix +++ b/pkgs/development/tools/misc/ctags/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchsvn, autoreconfHook }: +{ + lib, + stdenv, + fetchsvn, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "ctags"; @@ -13,7 +18,7 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; # don't use $T(E)MP which is set to the build directory - configureFlags= [ "--enable-tmpdir=/tmp" ]; + configureFlags = [ "--enable-tmpdir=/tmp" ]; patches = [ # Library defines an `__unused__` which is a reserved name, and may diff --git a/pkgs/development/tools/misc/cvise/default.nix b/pkgs/development/tools/misc/cvise/default.nix index 26aacff8256d4c..7dc6d534eaaaef 100644 --- a/pkgs/development/tools/misc/cvise/default.nix +++ b/pkgs/development/tools/misc/cvise/default.nix @@ -1,17 +1,18 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, clang-tools -, cmake -, colordiff -, flex -, libclang -, llvm -, unifdef -, chardet -, pebble -, psutil -, pytestCheckHook +{ + lib, + buildPythonApplication, + fetchFromGitHub, + clang-tools, + cmake, + colordiff, + flex, + libclang, + llvm, + unifdef, + chardet, + pebble, + psutil, + pytestCheckHook, }: buildPythonApplication rec { diff --git a/pkgs/development/tools/misc/distcc/default.nix b/pkgs/development/tools/misc/distcc/default.nix index 954312b729b551..cc5a704dcef01f 100644 --- a/pkgs/development/tools/misc/distcc/default.nix +++ b/pkgs/development/tools/misc/distcc/default.nix @@ -1,8 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, popt, avahi, pkg-config, python3, gtk3, runCommand -, gcc, autoconf, automake, which, procps, libiberty_static -, runtimeShell -, sysconfDir ? "" # set this parameter to override the default value $out/etc -, static ? false +{ + lib, + stdenv, + fetchFromGitHub, + popt, + avahi, + pkg-config, + python3, + gtk3, + runCommand, + gcc, + autoconf, + automake, + which, + procps, + libiberty_static, + runtimeShell, + sysconfDir ? "", # set this parameter to override the default value $out/etc + static ? false, }: let @@ -18,12 +32,20 @@ let }; nativeBuildInputs = [ - pkg-config autoconf automake which + pkg-config + autoconf + automake + which (python3.withPackages (p: [ p.setuptools ])) ]; - buildInputs = [ popt avahi gtk3 procps libiberty_static ]; - preConfigure = - '' + buildInputs = [ + popt + avahi + gtk3 + procps + libiberty_static + ]; + preConfigure = '' export CPATH=$(ls -d ${gcc.cc}/lib/gcc/*/${gcc.cc.version}/plugin/include) configureFlagsArray=( CFLAGS="-O2 -fno-strict-aliasing" @@ -52,8 +74,9 @@ let # # extraConfig is meant to be sh lines exporting environment # variables like DISTCC_HOSTS, DISTCC_DIR, ... - links = extraConfig: (runCommand "distcc-links" { passthru.gcc = gcc.cc; } - '' + links = + extraConfig: + (runCommand "distcc-links" { passthru.gcc = gcc.cc; } '' mkdir -p $out/bin if [ -x "${gcc.cc}/bin/gcc" ]; then cat > $out/bin/gcc << EOF @@ -84,4 +107,4 @@ let }; }; in - distcc +distcc diff --git a/pkgs/development/tools/misc/distcc/masq.nix b/pkgs/development/tools/misc/distcc/masq.nix index 27840481a10912..78cbccb2c565fe 100644 --- a/pkgs/development/tools/misc/distcc/masq.nix +++ b/pkgs/development/tools/misc/distcc/masq.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, gccRaw, binutils }: +{ + lib, + stdenv, + gccRaw, + binutils, +}: stdenv.mkDerivation { name = "distcc-masq-${gccRaw.name}"; diff --git a/pkgs/development/tools/misc/dura/default.nix b/pkgs/development/tools/misc/dura/default.nix index 34b966607a745f..b6a76b78d6a163 100644 --- a/pkgs/development/tools/misc/dura/default.nix +++ b/pkgs/development/tools/misc/dura/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, openssl, pkg-config, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + openssl, + pkg-config, + Security, +}: rustPlatform.buildRustPackage rec { pname = "dura"; @@ -19,11 +27,13 @@ rustPlatform.buildRustPackage rec { doCheck = false; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + ]; nativeBuildInputs = [ pkg-config diff --git a/pkgs/development/tools/misc/edb/default.nix b/pkgs/development/tools/misc/edb/default.nix index a1f9120f314c10..f5103f9d0c2c64 100644 --- a/pkgs/development/tools/misc/edb/default.nix +++ b/pkgs/development/tools/misc/edb/default.nix @@ -1,5 +1,15 @@ -{ lib, mkDerivation, fetchFromGitHub, cmake, pkg-config, boost, capstone_4 -, double-conversion, graphviz, qtxmlpatterns }: +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + pkg-config, + boost, + capstone_4, + double-conversion, + graphviz, + qtxmlpatterns, +}: mkDerivation rec { pname = "edb"; @@ -13,9 +23,18 @@ mkDerivation rec { hash = "sha256-1Q0eZS05L4sxzcPvEFdEaobO7JYHRu98Yf+n3ZnBi+E="; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ boost.dev capstone_4 double-conversion graphviz qtxmlpatterns ]; + buildInputs = [ + boost.dev + capstone_4 + double-conversion + graphviz + qtxmlpatterns + ]; postPatch = '' # Remove CMAKE_INSTALL_PREFIX from DEFAULT_PLUGIN_PATH otherwise the nix store path will appear twice. @@ -37,7 +56,10 @@ mkDerivation rec { mainProgram = "edb"; homepage = "https://github.com/eteran/edb-debugger"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ lihop maxxk ]; + maintainers = with maintainers; [ + lihop + maxxk + ]; platforms = [ "x86_64-linux" ]; }; } diff --git a/pkgs/development/tools/misc/fswatch/default.nix b/pkgs/development/tools/misc/fswatch/default.nix index 05fbd759ffcaaf..bce63deb9f0391 100644 --- a/pkgs/development/tools/misc/fswatch/default.nix +++ b/pkgs/development/tools/misc/fswatch/default.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook - # for xargs -, gettext -, libtool -, makeWrapper -, texinfo -, CoreServices +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + # for xargs + gettext, + libtool, + makeWrapper, + texinfo, + CoreServices, }: stdenv.mkDerivation rec { @@ -20,8 +22,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-gVYDvda+6ZJkShJXUxUEVxq4enkRrhdvlTTxYWq4Aho="; }; - nativeBuildInputs = [ autoreconfHook makeWrapper ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices ]; - buildInputs = [ gettext libtool texinfo ]; + nativeBuildInputs = [ + autoreconfHook + makeWrapper + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices ]; + buildInputs = [ + gettext + libtool + texinfo + ]; enableParallelBuilding = true; diff --git a/pkgs/development/tools/misc/gdb/default.nix b/pkgs/development/tools/misc/gdb/default.nix index 19783b40756786..6dc6be7f442a30 100644 --- a/pkgs/development/tools/misc/gdb/default.nix +++ b/pkgs/development/tools/misc/gdb/default.nix @@ -1,29 +1,52 @@ -{ lib, stdenv, targetPackages - -# Build time -, fetchurl, pkg-config, perl, texinfo, setupDebugInfoDirs, buildPackages - -# Run time -, ncurses, readline, gmp, mpfr, expat, libipt, zlib, zstd, xz, dejagnu, sourceHighlight, libiconv - -, pythonSupport ? stdenv.hostPlatform == stdenv.buildPlatform && !stdenv.hostPlatform.isCygwin, python3 ? null -, enableDebuginfod ? lib.meta.availableOn stdenv.hostPlatform elfutils, elfutils -, guile ? null -, hostCpuOnly ? false -, enableSim ? false -, safePaths ? [ - # $debugdir:$datadir/auto-load are whitelisted by default by GDB - "$debugdir" "$datadir/auto-load" - # targetPackages so we get the right libc when cross-compiling and using buildPackages.gdb - (lib.getLib targetPackages.stdenv.cc.cc) - ] -, writeScript +{ + lib, + stdenv, + targetPackages, + + # Build time + fetchurl, + pkg-config, + perl, + texinfo, + setupDebugInfoDirs, + buildPackages, + + # Run time + ncurses, + readline, + gmp, + mpfr, + expat, + libipt, + zlib, + zstd, + xz, + dejagnu, + sourceHighlight, + libiconv, + + pythonSupport ? stdenv.hostPlatform == stdenv.buildPlatform && !stdenv.hostPlatform.isCygwin, + python3 ? null, + enableDebuginfod ? lib.meta.availableOn stdenv.hostPlatform elfutils, + elfutils, + guile ? null, + hostCpuOnly ? false, + enableSim ? false, + safePaths ? [ + # $debugdir:$datadir/auto-load are whitelisted by default by GDB + "$debugdir" + "$datadir/auto-load" + # targetPackages so we get the right libc when cross-compiling and using buildPackages.gdb + (lib.getLib targetPackages.stdenv.cc.cc) + ], + writeScript, }: let basename = "gdb"; - targetPrefix = lib.optionalString (stdenv.targetPlatform != stdenv.hostPlatform) - "${stdenv.targetPlatform.config}-"; + targetPrefix = lib.optionalString ( + stdenv.targetPlatform != stdenv.hostPlatform + ) "${stdenv.targetPlatform.config}-"; in assert pythonSupport -> python3 != null; @@ -37,25 +60,47 @@ stdenv.mkDerivation rec { hash = "sha256-gzUMzTW1taDLprM0xBKU6paBWMVzlAkE8AuS92NFMU0="; }; - postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace gdb/darwin-nat.c \ - --replace '#include "bfd/mach-o.h"' '#include "mach-o.h"' - '' + lib.optionalString stdenv.hostPlatform.isMusl '' - substituteInPlace sim/erc32/erc32.c --replace sys/fcntl.h fcntl.h - substituteInPlace sim/erc32/interf.c --replace sys/fcntl.h fcntl.h - substituteInPlace sim/erc32/sis.c --replace sys/fcntl.h fcntl.h - substituteInPlace sim/ppc/emul_unix.c --replace sys/termios.h termios.h - ''; + postPatch = + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace gdb/darwin-nat.c \ + --replace '#include "bfd/mach-o.h"' '#include "mach-o.h"' + '' + + lib.optionalString stdenv.hostPlatform.isMusl '' + substituteInPlace sim/erc32/erc32.c --replace sys/fcntl.h fcntl.h + substituteInPlace sim/erc32/interf.c --replace sys/fcntl.h fcntl.h + substituteInPlace sim/erc32/sis.c --replace sys/fcntl.h fcntl.h + substituteInPlace sim/ppc/emul_unix.c --replace sys/termios.h termios.h + ''; - patches = [ - ./debug-info-from-env.patch - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - ./darwin-target-match.patch + patches = + [ + ./debug-info-from-env.patch + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + ./darwin-target-match.patch + ]; + + nativeBuildInputs = [ + pkg-config + texinfo + perl + setupDebugInfoDirs ]; - nativeBuildInputs = [ pkg-config texinfo perl setupDebugInfoDirs ]; - - buildInputs = [ ncurses readline gmp mpfr expat libipt zlib zstd xz guile sourceHighlight ] + buildInputs = + [ + ncurses + readline + gmp + mpfr + expat + libipt + zlib + zstd + xz + guile + sourceHighlight + ] ++ lib.optional pythonSupport python3 ++ lib.optional doCheck dejagnu ++ lib.optional enableDebuginfod (elfutils.override { enableDebuginfod = true; }) @@ -72,7 +117,11 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = "-Wno-format-nonliteral"; - configurePlatforms = [ "build" "host" "target" ]; + configurePlatforms = [ + "build" + "host" + "target" + ]; preConfigure = '' # remove precompiled docs, required for man gdbinit to mention /etc/gdb/gdbinit @@ -88,30 +137,36 @@ stdenv.mkDerivation rec { ''; configureScript = "../configure"; - configureFlags = [ - # Set the program prefix to the current targetPrefix. - # This ensures that the prefix always conforms to - # nixpkgs' expectations instead of relying on the build - # system which only receives `config` which is merely a - # subset of the platform description. - "--program-prefix=${targetPrefix}" - - "--disable-werror" - ] ++ lib.optional (!hostCpuOnly) "--enable-targets=all" ++ [ - "--enable-64-bit-bfd" - "--disable-install-libbfd" - "--disable-shared" "--enable-static" - "--with-system-zlib" - "--with-system-readline" - - "--with-system-gdbinit=/etc/gdb/gdbinit" - "--with-system-gdbinit-dir=/etc/gdb/gdbinit.d" - - "--with-gmp=${gmp.dev}" - "--with-mpfr=${mpfr.dev}" - "--with-expat" "--with-libexpat-prefix=${expat.dev}" - "--with-auto-load-safe-path=${builtins.concatStringsSep ":" safePaths}" - ] ++ lib.optional (!pythonSupport) "--without-python" + configureFlags = + [ + # Set the program prefix to the current targetPrefix. + # This ensures that the prefix always conforms to + # nixpkgs' expectations instead of relying on the build + # system which only receives `config` which is merely a + # subset of the platform description. + "--program-prefix=${targetPrefix}" + + "--disable-werror" + ] + ++ lib.optional (!hostCpuOnly) "--enable-targets=all" + ++ [ + "--enable-64-bit-bfd" + "--disable-install-libbfd" + "--disable-shared" + "--enable-static" + "--with-system-zlib" + "--with-system-readline" + + "--with-system-gdbinit=/etc/gdb/gdbinit" + "--with-system-gdbinit-dir=/etc/gdb/gdbinit.d" + + "--with-gmp=${gmp.dev}" + "--with-mpfr=${mpfr.dev}" + "--with-expat" + "--with-libexpat-prefix=${expat.dev}" + "--with-auto-load-safe-path=${builtins.concatStringsSep ":" safePaths}" + ] + ++ lib.optional (!pythonSupport) "--without-python" ++ lib.optional stdenv.hostPlatform.isMusl "--disable-nls" ++ lib.optional stdenv.hostPlatform.isStatic "--disable-inprocess-agent" ++ lib.optional enableDebuginfod "--with-debuginfod=yes" @@ -158,6 +213,10 @@ stdenv.mkDerivation rec { # upstream does not support targeting aarch64-darwin; # see https://inbox.sourceware.org/gdb/3185c3b8-8a91-4beb-a5d5-9db6afb93713@Spark/ badPlatforms = lib.optionals (stdenv.targetPlatform.system == "aarch64-darwin") meta.platforms; - maintainers = with lib.maintainers; [ pierron globin lsix ]; + maintainers = with lib.maintainers; [ + pierron + globin + lsix + ]; }; } diff --git a/pkgs/development/tools/misc/gdbgui/default.nix b/pkgs/development/tools/misc/gdbgui/default.nix index 33d9da9f636e47..d58d874c7ccafb 100644 --- a/pkgs/development/tools/misc/gdbgui/default.nix +++ b/pkgs/development/tools/misc/gdbgui/default.nix @@ -1,13 +1,14 @@ -{ lib -, buildPythonApplication -, fetchPypi -, gdb -, eventlet -, flask-compress -, flask-socketio -, pygdbmi -, pygments -, }: +{ + lib, + buildPythonApplication, + fetchPypi, + gdb, + eventlet, + flask-compress, + flask-socketio, + pygdbmi, + pygments, +}: buildPythonApplication rec { pname = "gdbgui"; @@ -48,6 +49,9 @@ buildPythonApplication rec { homepage = "https://www.gdbgui.com/"; license = licenses.gpl3; platforms = platforms.unix; - maintainers = with maintainers; [ yrashk dump_stack ]; + maintainers = with maintainers; [ + yrashk + dump_stack + ]; }; } diff --git a/pkgs/development/tools/misc/gede/default.nix b/pkgs/development/tools/misc/gede/default.nix index 6ae512657666ca..1feff837877a08 100644 --- a/pkgs/development/tools/misc/gede/default.nix +++ b/pkgs/development/tools/misc/gede/default.nix @@ -1,4 +1,13 @@ -{ mkDerivation, lib, fetchurl, makeWrapper, python3, qmake, ctags, gdb }: +{ + mkDerivation, + lib, + fetchurl, + makeWrapper, + python3, + qmake, + ctags, + gdb, +}: mkDerivation rec { pname = "gede"; @@ -9,7 +18,11 @@ mkDerivation rec { sha256 = "sha256-RUl60iPa4XSlUilpYKaYQbRmLqthKHAvYonnhufjPsE="; }; - nativeBuildInputs = [ qmake makeWrapper python3 ]; + nativeBuildInputs = [ + qmake + makeWrapper + python3 + ]; buildInputs = [ ctags ]; @@ -22,7 +35,12 @@ mkDerivation rec { installPhase = '' python build.py install --verbose --prefix="$out" wrapProgram $out/bin/gede \ - --prefix PATH : ${lib.makeBinPath [ ctags gdb ]} + --prefix PATH : ${ + lib.makeBinPath [ + ctags + gdb + ] + } ''; meta = with lib; { diff --git a/pkgs/development/tools/misc/gperf/3.0.x.nix b/pkgs/development/tools/misc/gperf/3.0.x.nix index bceef7502a878b..9fb2caa7b8457b 100644 --- a/pkgs/development/tools/misc/gperf/3.0.x.nix +++ b/pkgs/development/tools/misc/gperf/3.0.x.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, autoreconfHook }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "gperf"; diff --git a/pkgs/development/tools/misc/gperf/default.nix b/pkgs/development/tools/misc/gperf/default.nix index bdc3b7a4a852dd..150a0cf0c6e996 100644 --- a/pkgs/development/tools/misc/gperf/default.nix +++ b/pkgs/development/tools/misc/gperf/default.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "gperf"; diff --git a/pkgs/development/tools/misc/kdbg/default.nix b/pkgs/development/tools/misc/kdbg/default.nix index cd32840239445c..f442bd5613414b 100644 --- a/pkgs/development/tools/misc/kdbg/default.nix +++ b/pkgs/development/tools/misc/kdbg/default.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, fetchurl, cmake, extra-cmake-modules, qt5, - ki18n, kconfig, kiconthemes, kxmlgui, kwindowsystem, - qtbase, makeWrapper, +{ + lib, + stdenv, + fetchurl, + cmake, + extra-cmake-modules, + qt5, + ki18n, + kconfig, + kiconthemes, + kxmlgui, + kwindowsystem, + qtbase, + makeWrapper, }: stdenv.mkDerivation rec { @@ -11,8 +22,19 @@ stdenv.mkDerivation rec { sha256 = "sha256-aLX/0GXof77NqQj7I7FUCZjyDtF1P8MJ4/NHJNm4Yr0="; }; - nativeBuildInputs = [ cmake extra-cmake-modules makeWrapper ]; - buildInputs = [ qt5.qtbase ki18n kconfig kiconthemes kxmlgui kwindowsystem ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + makeWrapper + ]; + buildInputs = [ + qt5.qtbase + ki18n + kconfig + kiconthemes + kxmlgui + kwindowsystem + ]; postInstall = '' wrapProgram $out/bin/kdbg --prefix QT_PLUGIN_PATH : ${qtbase}/${qtbase.qtPluginPrefix} diff --git a/pkgs/development/tools/misc/libtool/default.nix b/pkgs/development/tools/misc/libtool/default.nix index 6970d2a94ec9ab..2fcc7a03626d7d 100644 --- a/pkgs/development/tools/misc/libtool/default.nix +++ b/pkgs/development/tools/misc/libtool/default.nix @@ -1,4 +1,10 @@ -{lib, stdenv, fetchurl, m4, perl}: +{ + lib, + stdenv, + fetchurl, + m4, + perl, +}: stdenv.mkDerivation rec { pname = "libtool"; @@ -9,8 +15,8 @@ stdenv.mkDerivation rec { sha256 = "029ggq5kri1gjn6nfqmgw4w920gyfzscjjxbsxxidal5zqsawd8w"; }; - nativeBuildInputs = [m4]; - buildInputs = [perl]; + nativeBuildInputs = [ m4 ]; + buildInputs = [ perl ]; # Don't fixup "#! /bin/sh" in Libtool, otherwise it will use the # "fixed" path in generated files! diff --git a/pkgs/development/tools/misc/linuxkit/default.nix b/pkgs/development/tools/misc/linuxkit/default.nix index ec721340b34c81..bad149ffeed63e 100644 --- a/pkgs/development/tools/misc/linuxkit/default.nix +++ b/pkgs/development/tools/misc/linuxkit/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, git, Cocoa, Virtualization, sigtool, testers, linuxkit }: +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + git, + Cocoa, + Virtualization, + sigtool, + testers, + linuxkit, +}: buildGoModule rec { pname = "linuxkit"; @@ -25,7 +36,10 @@ buildGoModule rec { # - sigtool is allows us to validly sign such executables with a dummy # authority. nativeBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ sigtool ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa Virtualization ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + Virtualization + ]; ldflags = [ "-s" diff --git a/pkgs/development/tools/misc/lttng-ust/generic.nix b/pkgs/development/tools/misc/lttng-ust/generic.nix index 24d022e4d8512c..6125bfb7dbbe37 100644 --- a/pkgs/development/tools/misc/lttng-ust/generic.nix +++ b/pkgs/development/tools/misc/lttng-ust/generic.nix @@ -1,6 +1,14 @@ { version, sha256 }: -{ lib, stdenv, fetchurl, pkg-config, liburcu, numactl, python3 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + liburcu, + numactl, + python3, +}: # NOTE: # ./configure ... @@ -22,10 +30,18 @@ stdenv.mkDerivation rec { inherit sha256; }; - outputs = [ "bin" "out" "dev" "devdoc" ]; + outputs = [ + "bin" + "out" + "dev" + "devdoc" + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ numactl python3 ]; + buildInputs = [ + numactl + python3 + ]; preConfigure = '' patchShebangs . @@ -43,7 +59,11 @@ stdenv.mkDerivation rec { description = "LTTng Userspace Tracer libraries"; mainProgram = "lttng-gen-tp"; homepage = "https://lttng.org/"; - license = with licenses; [ lgpl21Only gpl2Only mit ]; + license = with licenses; [ + lgpl21Only + gpl2Only + mit + ]; platforms = lib.intersectLists platforms.linux liburcu.meta.platforms; maintainers = [ maintainers.bjornfor ]; }; diff --git a/pkgs/development/tools/misc/luarocks/default.nix b/pkgs/development/tools/misc/luarocks/default.nix index b15924b34f3c59..c0caa152c91ed8 100644 --- a/pkgs/development/tools/misc/luarocks/default.nix +++ b/pkgs/development/tools/misc/luarocks/default.nix @@ -1,26 +1,26 @@ /* -This is a minimal/manual luarocks derivation used by `buildLuarocksPackage` to install lua packages. - -As a nix user, you should use the generated lua.pkgs.luarocks that contains a luarocks manifest -which makes it recognizable to luarocks. -Generating the manifest for luarocks_bootstrap seemed too hackish, which is why we end up -with two "luarocks" derivations. + This is a minimal/manual luarocks derivation used by `buildLuarocksPackage` to install lua packages. + As a nix user, you should use the generated lua.pkgs.luarocks that contains a luarocks manifest + which makes it recognizable to luarocks. + Generating the manifest for luarocks_bootstrap seemed too hackish, which is why we end up + with two "luarocks" derivations. */ -{ lib -, stdenv -, fetchFromGitHub -, curl -, makeWrapper -, which -, unzip -, lua +{ + lib, + stdenv, + fetchFromGitHub, + curl, + makeWrapper, + which, + unzip, + lua, # for 'luarocks pack' -, zip -, nix-update-script + zip, + nix-update-script, # some packages need to be compiled with cmake -, cmake -, installShellFiles + cmake, + installShellFiles, }: stdenv.mkDerivation (finalAttrs: { @@ -59,40 +59,53 @@ stdenv.mkDerivation (finalAttrs: { fi ''; - nativeBuildInputs = [ makeWrapper installShellFiles lua unzip ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + lua + unzip + ]; - buildInputs = [ curl which ]; + buildInputs = [ + curl + which + ]; - postInstall = '' - sed -e "1s@.*@#! ${lua}/bin/lua$LUA_SUFFIX@" -i "$out"/bin/* - substituteInPlace $out/etc/luarocks/* \ - --replace-quiet '${lua.luaOnBuild}' '${lua}' - '' + postInstall = + '' + sed -e "1s@.*@#! ${lua}/bin/lua$LUA_SUFFIX@" -i "$out"/bin/* + substituteInPlace $out/etc/luarocks/* \ + --replace-quiet '${lua.luaOnBuild}' '${lua}' + '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - installShellCompletion --cmd luarocks \ - --bash <($out/bin/luarocks completion bash) \ - --fish <($out/bin/luarocks completion fish) \ - --zsh <($out/bin/luarocks completion zsh) - - installShellCompletion --cmd luarocks-admin \ - --bash <($out/bin/luarocks-admin completion bash) \ - --fish <($out/bin/luarocks-admin completion fish) \ - --zsh <($out/bin/luarocks-admin completion zsh) - '' - + '' - for i in "$out"/bin/*; do - test -L "$i" || { - wrapProgram "$i" \ - --suffix LUA_PATH ";" "$(echo "$out"/share/lua/*/)?.lua" \ - --suffix LUA_PATH ";" "$(echo "$out"/share/lua/*/)?/init.lua" \ - --suffix LUA_CPATH ";" "$(echo "$out"/lib/lua/*/)?.so" \ - --suffix LUA_CPATH ";" "$(echo "$out"/share/lua/*/)?/init.lua" \ - --suffix PATH : ${lib.makeBinPath finalAttrs.propagatedBuildInputs} - } - done - ''; - - propagatedBuildInputs = [ zip unzip cmake ]; + installShellCompletion --cmd luarocks \ + --bash <($out/bin/luarocks completion bash) \ + --fish <($out/bin/luarocks completion fish) \ + --zsh <($out/bin/luarocks completion zsh) + + installShellCompletion --cmd luarocks-admin \ + --bash <($out/bin/luarocks-admin completion bash) \ + --fish <($out/bin/luarocks-admin completion fish) \ + --zsh <($out/bin/luarocks-admin completion zsh) + '' + + '' + for i in "$out"/bin/*; do + test -L "$i" || { + wrapProgram "$i" \ + --suffix LUA_PATH ";" "$(echo "$out"/share/lua/*/)?.lua" \ + --suffix LUA_PATH ";" "$(echo "$out"/share/lua/*/)?/init.lua" \ + --suffix LUA_CPATH ";" "$(echo "$out"/lib/lua/*/)?.so" \ + --suffix LUA_CPATH ";" "$(echo "$out"/share/lua/*/)?/init.lua" \ + --suffix PATH : ${lib.makeBinPath finalAttrs.propagatedBuildInputs} + } + done + ''; + + propagatedBuildInputs = [ + zip + unzip + cmake + ]; # unpack hook for src.rock and rockspec files setupHook = ./setup-hook.sh; @@ -116,7 +129,10 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "Package manager for Lua"; license = licenses.mit; - maintainers = with maintainers; [ raskin teto ]; + maintainers = with maintainers; [ + raskin + teto + ]; mainProgram = "luarocks"; platforms = platforms.linux ++ platforms.darwin; downloadPage = "http://luarocks.org/releases/"; diff --git a/pkgs/development/tools/misc/luarocks/luarocks-nix.nix b/pkgs/development/tools/misc/luarocks/luarocks-nix.nix index 1a0466596fdc35..21bfcb3506eccb 100644 --- a/pkgs/development/tools/misc/luarocks/luarocks-nix.nix +++ b/pkgs/development/tools/misc/luarocks/luarocks-nix.nix @@ -1,8 +1,9 @@ -{ luarocks_bootstrap -, fetchFromGitHub -, unstableGitUpdater -, nurl -, file +{ + luarocks_bootstrap, + fetchFromGitHub, + unstableGitUpdater, + nurl, + file, }: luarocks_bootstrap.overrideAttrs (old: { @@ -32,7 +33,12 @@ luarocks_bootstrap.overrideAttrs (old: { # old.meta // { /* ... */ } doesn't update meta.position, which breaks the updateScript meta = { - inherit (old.meta) description license maintainers platforms; + inherit (old.meta) + description + license + maintainers + platforms + ; mainProgram = "luarocks"; }; }) diff --git a/pkgs/development/tools/misc/mdl/default.nix b/pkgs/development/tools/misc/mdl/default.nix index 105dbb6af29988..77720c8435d68b 100644 --- a/pkgs/development/tools/misc/mdl/default.nix +++ b/pkgs/development/tools/misc/mdl/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "mdl"; @@ -11,7 +15,12 @@ bundlerApp { description = "Tool to check markdown files and flag style issues"; homepage = "https://github.com/markdownlint/markdownlint"; license = licenses.mit; - maintainers = with maintainers; [ gerschtli manveru nicknovitski totoroot ]; + maintainers = with maintainers; [ + gerschtli + manveru + nicknovitski + totoroot + ]; platforms = platforms.all; }; } diff --git a/pkgs/development/tools/misc/mdl/gemset.nix b/pkgs/development/tools/misc/mdl/gemset.nix index 7c9f7b003789d6..91f6ba380735c4 100644 --- a/pkgs/development/tools/misc/mdl/gemset.nix +++ b/pkgs/development/tools/misc/mdl/gemset.nix @@ -1,105 +1,111 @@ { chef-utils = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ckbnra3cs71syrvfhgcrg1icqxh6pj21by2f9sy6r6kbr19g4w3"; type = "gem"; }; version = "18.1.0"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qnsflsbjj38im8xq35g0vihlz96h09wjn2dad5g543l3vvrkrx5"; type = "gem"; }; version = "1.2.0"; }; kramdown = { - dependencies = ["rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rexml" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ic14hdcqxn821dvzki99zhmcy130yhv5fqfffkcf87asv5mnbmn"; type = "gem"; }; version = "2.4.0"; }; kramdown-parser-gfm = { - dependencies = ["kramdown"]; - groups = ["default"]; - platforms = []; + dependencies = [ "kramdown" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a8pb3v951f4x7h968rqfsa19c8arz21zw1vaj42jza22rap8fgv"; type = "gem"; }; version = "1.1.0"; }; mdl = { - dependencies = ["kramdown" "kramdown-parser-gfm" "mixlib-cli" "mixlib-config" "mixlib-shellout"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "kramdown" + "kramdown-parser-gfm" + "mixlib-cli" + "mixlib-config" + "mixlib-shellout" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a463jx8v4a3lgmmfalq73c337d66hc21q4vnfar1qf4lhk5wyi0"; type = "gem"; }; version = "0.13.0"; }; mixlib-cli = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ydxlfgd7nnj3rp1y70k4yk96xz5cywldjii2zbnw3sq9pippwp6"; type = "gem"; }; version = "2.1.8"; }; mixlib-config = { - dependencies = ["tomlrb"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tomlrb" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j0122lv2qgccl61njqi0pj6sp6nb85y07gcmw16bwg4k0c8nx6p"; type = "gem"; }; version = "3.0.27"; }; mixlib-shellout = { - dependencies = ["chef-utils"]; - groups = ["default"]; - platforms = []; + dependencies = [ "chef-utils" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zkwg76y96nkh1mv0k92ybq46cr06v1wmic16129ls3yqzwx3xj6"; type = "gem"; }; version = "3.2.7"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08ximcyfjy94pm1rhcx04ny1vx2sk0x4y185gzn86yfsbzwkng53"; type = "gem"; }; version = "3.2.5"; }; tomlrb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xyl2nlfm39lklyaf0p7zj9psr60jvrlyfh26hrpk7wi4k7nlwy2"; type = "gem"; }; diff --git a/pkgs/development/tools/misc/nixbang/default.nix b/pkgs/development/tools/misc/nixbang/default.nix index d4541b76ba0609..0cb6f1c24b74ba 100644 --- a/pkgs/development/tools/misc/nixbang/default.nix +++ b/pkgs/development/tools/misc/nixbang/default.nix @@ -1,4 +1,8 @@ -{ lib, pythonPackages, fetchFromGitHub }: +{ + lib, + pythonPackages, + fetchFromGitHub, +}: pythonPackages.buildPythonApplication rec { pname = "nixbang"; diff --git a/pkgs/development/tools/misc/one_gadget/default.nix b/pkgs/development/tools/misc/one_gadget/default.nix index f1fbd4a0356a81..d03d231e3744b7 100644 --- a/pkgs/development/tools/misc/one_gadget/default.nix +++ b/pkgs/development/tools/misc/one_gadget/default.nix @@ -1,4 +1,10 @@ -{ lib, binutils, bundlerApp, bundlerUpdateScript, makeWrapper }: +{ + lib, + binutils, + bundlerApp, + bundlerUpdateScript, + makeWrapper, +}: bundlerApp { pname = "one_gadget"; @@ -15,10 +21,13 @@ bundlerApp { meta = with lib; { description = "Best tool for finding one gadget RCE in libc.so.6"; - homepage = "https://github.com/david942j/one_gadget"; - license = licenses.mit; - maintainers = with maintainers; [ artemist nicknovitski ]; + homepage = "https://github.com/david942j/one_gadget"; + license = licenses.mit; + maintainers = with maintainers; [ + artemist + nicknovitski + ]; mainProgram = "one_gadget"; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/misc/one_gadget/gemset.nix b/pkgs/development/tools/misc/one_gadget/gemset.nix index c1127a8b6c6a20..856aaa446ccada 100644 --- a/pkgs/development/tools/misc/one_gadget/gemset.nix +++ b/pkgs/development/tools/misc/one_gadget/gemset.nix @@ -1,31 +1,31 @@ { bindata = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08r67nglsqnxrbn803szf5bdnqhchhq8kf2by94f37fcl65wpp19"; type = "gem"; }; version = "2.5.0"; }; elftools = { - dependencies = ["bindata"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bindata" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p96wj4sz3sfv9yxyl8z530554bkbf82vj24w6x7yf91qa1p8z6i"; type = "gem"; }; version = "1.1.3"; }; one_gadget = { - dependencies = ["elftools"]; - groups = ["default"]; - platforms = []; + dependencies = [ "elftools" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j9478h929jm5hq2fs3v8y37a7y2hhpli90mbps7yvka4ykci7mw"; type = "gem"; }; diff --git a/pkgs/development/tools/misc/patchelf/default.nix b/pkgs/development/tools/misc/patchelf/default.nix index d079f08a294aee..7b65465a2b10e4 100644 --- a/pkgs/development/tools/misc/patchelf/default.nix +++ b/pkgs/development/tools/misc/patchelf/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: # Note: this package is used for bootstrapping fetchurl, and thus # cannot use fetchpatch! All mutable patches (generated by GitHub or @@ -21,7 +25,8 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; # fails 8 out of 24 tests, problems when loading libc.so.6 - doCheck = stdenv.name == "stdenv-linux" + doCheck = + stdenv.name == "stdenv-linux" # test scripts require unprefixed bintools binaries # https://github.com/NixOS/patchelf/issues/417 && stdenv.cc.targetPrefix == ""; diff --git a/pkgs/development/tools/misc/premake/3.nix b/pkgs/development/tools/misc/premake/3.nix index 9e9775dcf71eb4..7eabdae30648ea 100644 --- a/pkgs/development/tools/misc/premake/3.nix +++ b/pkgs/development/tools/misc/premake/3.nix @@ -1,8 +1,13 @@ -{lib, stdenv, fetchurl, unzip}: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "premake"; - version = "3.7"; + version = "3.7"; src = fetchurl { url = "mirror://sourceforge/sourceforge/premake/premake-src-${version}.zip"; diff --git a/pkgs/development/tools/misc/premake/5.nix b/pkgs/development/tools/misc/premake/5.nix index e84d2a57c94308..3821dc5f385a68 100644 --- a/pkgs/development/tools/misc/premake/5.nix +++ b/pkgs/development/tools/misc/premake/5.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, libuuid, cacert, Foundation, readline }: +{ + lib, + stdenv, + fetchFromGitHub, + libuuid, + cacert, + Foundation, + readline, +}: stdenv.mkDerivation rec { pname = "premake5"; @@ -11,34 +19,47 @@ stdenv.mkDerivation rec { sha256 = "sha256-2R5gq4jaQsp8Ny1oGuIYkef0kn2UG9jMf20vq0714oY="; }; - buildInputs = [ libuuid ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Foundation readline ]; + buildInputs = + [ libuuid ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Foundation + readline + ]; patches = [ ./no-curl-ca.patch ]; - postPatch = '' - substituteInPlace contrib/curl/premake5.lua \ - --replace "ca = nil" "ca = '${cacert}/etc/ssl/certs/ca-bundle.crt'" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace premake5.lua \ - --replace -mmacosx-version-min=10.4 -mmacosx-version-min=10.5 \ - --replace-fail '"-arch arm64"' '""' \ - --replace-fail '"-arch x86_64"' '""' - '' + lib.optionalString stdenv.hostPlatform.isStatic '' - substituteInPlace \ - binmodules/example/premake5.lua \ - binmodules/luasocket/premake5.lua \ - --replace SharedLib StaticLib - ''; + postPatch = + '' + substituteInPlace contrib/curl/premake5.lua \ + --replace "ca = nil" "ca = '${cacert}/etc/ssl/certs/ca-bundle.crt'" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace premake5.lua \ + --replace -mmacosx-version-min=10.4 -mmacosx-version-min=10.5 \ + --replace-fail '"-arch arm64"' '""' \ + --replace-fail '"-arch x86_64"' '""' + '' + + lib.optionalString stdenv.hostPlatform.isStatic '' + substituteInPlace \ + binmodules/example/premake5.lua \ + binmodules/luasocket/premake5.lua \ + --replace SharedLib StaticLib + ''; buildPhase = - if stdenv.hostPlatform.isDarwin then '' - make -f Bootstrap.mak osx - '' else '' - make -f Bootstrap.mak linux - ''; + if stdenv.hostPlatform.isDarwin then + '' + make -f Bootstrap.mak osx + '' + else + '' + make -f Bootstrap.mak linux + ''; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-error=implicit-function-declaration" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-error=implicit-function-declaration" + ] + ); installPhase = '' install -Dm755 bin/release/premake5 $out/bin/premake5 diff --git a/pkgs/development/tools/misc/premake/default.nix b/pkgs/development/tools/misc/premake/default.nix index 9987cb2d0b9b20..1435c2c4c5785b 100644 --- a/pkgs/development/tools/misc/premake/default.nix +++ b/pkgs/development/tools/misc/premake/default.nix @@ -1,8 +1,13 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "premake"; - version = "4.3"; + version = "4.3"; src = fetchurl { url = "mirror://sourceforge/premake/premake-${version}-src.zip"; diff --git a/pkgs/development/tools/misc/pwninit/default.nix b/pkgs/development/tools/misc/pwninit/default.nix index d67c7e64061177..7a616761311d45 100644 --- a/pkgs/development/tools/misc/pwninit/default.nix +++ b/pkgs/development/tools/misc/pwninit/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, openssl -, elfutils -, makeBinaryWrapper -, pkg-config -, xz -, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + openssl, + elfutils, + makeBinaryWrapper, + pkg-config, + xz, + Security, }: rustPlatform.buildRustPackage rec { @@ -21,8 +22,14 @@ rustPlatform.buildRustPackage rec { sha256 = "sha256-tbZS7PdRFvO2ifoHA/w3cSPfqqHrLeLHAg6V8oG9gVE="; }; - buildInputs = [ openssl xz ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; - nativeBuildInputs = [ pkg-config makeBinaryWrapper ]; + buildInputs = [ + openssl + xz + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; + nativeBuildInputs = [ + pkg-config + makeBinaryWrapper + ]; postInstall = '' wrapProgram $out/bin/pwninit \ --prefix PATH : "${lib.getBin elfutils}/bin" diff --git a/pkgs/development/tools/misc/qtspim/default.nix b/pkgs/development/tools/misc/qtspim/default.nix index 15fd8dd13b2c78..42c927e5b32d60 100644 --- a/pkgs/development/tools/misc/qtspim/default.nix +++ b/pkgs/development/tools/misc/qtspim/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchsvn, wrapQtAppsHook, qtbase, qttools, qmake, bison, flex, ... }: +{ + lib, + stdenv, + fetchsvn, + wrapQtAppsHook, + qtbase, + qttools, + qmake, + bison, + flex, + ... +}: stdenv.mkDerivation rec { pname = "qtspim"; version = "9.1.23"; @@ -21,7 +32,13 @@ stdenv.mkDerivation rec { --replace /usr/lib/qtspim/qtspim.png qtspim ''; - nativeBuildInputs = [ wrapQtAppsHook qttools qmake bison flex ]; + nativeBuildInputs = [ + wrapQtAppsHook + qttools + qmake + bison + flex + ]; buildInputs = [ qtbase ]; QT_PLUGIN_PATH = "${qtbase}/${qtbase.qtPluginPrefix}"; diff --git a/pkgs/development/tools/misc/seer/default.nix b/pkgs/development/tools/misc/seer/default.nix index 385aea2e73acfb..a36609835a07d6 100644 --- a/pkgs/development/tools/misc/seer/default.nix +++ b/pkgs/development/tools/misc/seer/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, cmake, gdb, kdePackages, wrapQtAppsHook }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gdb, + kdePackages, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "seer"; @@ -20,8 +28,15 @@ stdenv.mkDerivation rec { --replace-fail "/usr/bin/gdb" "${gdb}/bin/gdb" ''; - buildInputs = with kdePackages; [ qtbase qtcharts qtsvg ]; - nativeBuildInputs = [ cmake kdePackages.wrapQtAppsHook ]; + buildInputs = with kdePackages; [ + qtbase + qtcharts + qtsvg + ]; + nativeBuildInputs = [ + cmake + kdePackages.wrapQtAppsHook + ]; meta = with lib; { description = "Qt gui frontend for GDB"; diff --git a/pkgs/development/tools/misc/sqitch/default.nix b/pkgs/development/tools/misc/sqitch/default.nix index 458e3b51d30969..ee88ee76415e08 100644 --- a/pkgs/development/tools/misc/sqitch/default.nix +++ b/pkgs/development/tools/misc/sqitch/default.nix @@ -1,16 +1,19 @@ -{ stdenv -, lib -, perlPackages -, makeWrapper -, shortenPerlShebang -, mysqlSupport ? false -, postgresqlSupport ? false -, templateToolkitSupport ? false +{ + stdenv, + lib, + perlPackages, + makeWrapper, + shortenPerlShebang, + mysqlSupport ? false, + postgresqlSupport ? false, + templateToolkitSupport ? false, }: let sqitch = perlPackages.AppSqitch; - modules = with perlPackages; [ AlgorithmBackoff ] + modules = + with perlPackages; + [ AlgorithmBackoff ] ++ lib.optional mysqlSupport DBDmysql ++ lib.optional postgresqlSupport DBDPg ++ lib.optional templateToolkitSupport TemplateToolkit; @@ -25,25 +28,32 @@ stdenv.mkDerivation { src = sqitch; dontBuild = true; - installPhase = '' - mkdir -p $out/bin - for d in bin/sqitch etc lib share ; do - # make sure dest alreay exists before symlink - # this prevents installing a broken link into the path - if [ -e ${sqitch}/$d ]; then - ln -s ${sqitch}/$d $out/$d - fi - done - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - shortenPerlShebang $out/bin/sqitch - ''; + installPhase = + '' + mkdir -p $out/bin + for d in bin/sqitch etc lib share ; do + # make sure dest alreay exists before symlink + # this prevents installing a broken link into the path + if [ -e ${sqitch}/$d ]; then + ln -s ${sqitch}/$d $out/$d + fi + done + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + shortenPerlShebang $out/bin/sqitch + ''; dontStrip = true; postFixup = '' wrapProgram $out/bin/sqitch --prefix PERL5LIB : ${lib.escapeShellArg (perlPackages.makeFullPerlPath modules)} ''; meta = { - inherit (sqitch.meta) description homepage license platforms; + inherit (sqitch.meta) + description + homepage + license + platforms + ; mainProgram = "sqitch"; }; } diff --git a/pkgs/development/tools/misc/stlink/default.nix b/pkgs/development/tools/misc/stlink/default.nix index c5c54351ac6463..27e5437d9517fc 100644 --- a/pkgs/development/tools/misc/stlink/default.nix +++ b/pkgs/development/tools/misc/stlink/default.nix @@ -1,22 +1,25 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, libusb1 -, gtk3 -, pkg-config -, wrapGAppsHook3 -, withGUI ? false +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + libusb1, + gtk3, + pkg-config, + wrapGAppsHook3, + withGUI ? false, }: let # The Darwin build of stlink explicitly refers to static libusb. - libusb1' = if stdenv.hostPlatform.isDarwin then libusb1.override { withStatic = true; } else libusb1; + libusb1' = + if stdenv.hostPlatform.isDarwin then libusb1.override { withStatic = true; } else libusb1; -# IMPORTANT: You need permissions to access the stlink usb devices. -# Add services.udev.packages = [ pkgs.stlink ] to your configuration.nix + # IMPORTANT: You need permissions to access the stlink usb devices. + # Add services.udev.packages = [ pkgs.stlink ] to your configuration.nix -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "stlink"; version = "1.8.0"; @@ -27,17 +30,21 @@ in stdenv.mkDerivation rec { sha256 = "sha256-hlFI2xpZ4ldMcxZbg/T5/4JuFFdO9THLcU0DQKSFqrw="; }; - buildInputs = [ - libusb1' - ] ++ lib.optionals withGUI [ - gtk3 - ]; - nativeBuildInputs = [ - cmake - ] ++ lib.optionals withGUI [ - pkg-config - wrapGAppsHook3 - ]; + buildInputs = + [ + libusb1' + ] + ++ lib.optionals withGUI [ + gtk3 + ]; + nativeBuildInputs = + [ + cmake + ] + ++ lib.optionals withGUI [ + pkg-config + wrapGAppsHook3 + ]; cmakeFlags = [ "-DSTLINK_MODPROBED_DIR=${placeholder "out"}/etc/modprobe.d" @@ -49,6 +56,9 @@ in stdenv.mkDerivation rec { license = licenses.bsd3; platforms = platforms.unix; badPlatforms = platforms.darwin; - maintainers = [ maintainers.bjornfor maintainers.rongcuid ]; + maintainers = [ + maintainers.bjornfor + maintainers.rongcuid + ]; }; } diff --git a/pkgs/development/tools/misc/texlab/default.nix b/pkgs/development/tools/misc/texlab/default.nix index 051bc6d8529a44..a958648220b8ad 100644 --- a/pkgs/development/tools/misc/texlab/default.nix +++ b/pkgs/development/tools/misc/texlab/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, help2man -, installShellFiles -, libiconv -, Security -, CoreServices -, nix-update-script +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + help2man, + installShellFiles, + libiconv, + Security, + CoreServices, + nix-update-script, }: let @@ -28,8 +29,7 @@ rustPlatform.buildRustPackage rec { outputs = [ "out" ] ++ lib.optional (!isCross) "man"; - nativeBuildInputs = [ installShellFiles ] - ++ lib.optional (!isCross) help2man; + nativeBuildInputs = [ installShellFiles ] ++ lib.optional (!isCross) help2man; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv @@ -53,7 +53,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/latex-lsp/texlab"; changelog = "https://github.com/latex-lsp/texlab/blob/v${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ doronbehar kira-bruneau ]; + maintainers = with maintainers; [ + doronbehar + kira-bruneau + ]; platforms = platforms.all; mainProgram = "texlab"; }; diff --git a/pkgs/development/tools/misc/tokei/default.nix b/pkgs/development/tools/misc/tokei/default.nix index 6c6b232e9354bd..a577405c730c65 100644 --- a/pkgs/development/tools/misc/tokei/default.nix +++ b/pkgs/development/tools/misc/tokei/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, libiconv, Security, zlib }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + libiconv, + Security, + zlib, +}: rustPlatform.buildRustPackage rec { pname = "tokei"; @@ -14,7 +22,8 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-U7Bode8qwDsNf4FVppfEHA9uiOFz74CtKgXG6xyYlT8="; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv Security + libiconv + Security ]; checkInputs = lib.optionals stdenv.hostPlatform.isDarwin [ zlib ]; @@ -28,7 +37,10 @@ rustPlatform.buildRustPackage rec { Tokei is a program that displays statistics about your code. Tokei will show number of files, total lines within those files and code, comments, and blanks grouped by language. ''; homepage = "https://github.com/XAMPPRocky/tokei"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ gebner ]; mainProgram = "tokei"; }; diff --git a/pkgs/development/tools/misc/travis/default.nix b/pkgs/development/tools/misc/travis/default.nix index 494604e975f178..52ae177172d307 100644 --- a/pkgs/development/tools/misc/travis/default.nix +++ b/pkgs/development/tools/misc/travis/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerEnv, ruby, bundlerUpdateScript }: +{ + lib, + bundlerEnv, + ruby, + bundlerUpdateScript, +}: bundlerEnv { inherit ruby; @@ -10,8 +15,11 @@ bundlerEnv { meta = with lib; { description = "CLI and Ruby client library for Travis CI"; mainProgram = "travis"; - homepage = "https://github.com/travis-ci/travis.rb"; - license = licenses.mit; - maintainers = with maintainers; [ zimbatm nicknovitski ]; + homepage = "https://github.com/travis-ci/travis.rb"; + license = licenses.mit; + maintainers = with maintainers; [ + zimbatm + nicknovitski + ]; }; } diff --git a/pkgs/development/tools/misc/travis/gemset.nix b/pkgs/development/tools/misc/travis/gemset.nix index 02b39bfca9470c..f304f77cc785bc 100644 --- a/pkgs/development/tools/misc/travis/gemset.nix +++ b/pkgs/development/tools/misc/travis/gemset.nix @@ -1,163 +1,176 @@ { activesupport = { - dependencies = ["concurrent-ruby" "i18n" "minitest" "tzinfo"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "concurrent-ruby" + "i18n" + "minitest" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02fdawr3wyvpzpja3r7mvb8lmn2mm5jdw502bx3ncr2sy2nw1kx6"; type = "gem"; }; version = "5.2.4.3"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fvchp2rhp2rmigx7qglf69xvjqvzq7x0g49naliw29r2bz656sy"; type = "gem"; }; version = "2.7.0"; }; coderay = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jvxqxzply1lwp7ysn94zjhh57vc14mcshw1ygw14ib8lhc00lyw"; type = "gem"; }; version = "1.1.3"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "094387x4yasb797mv07cs3g6f08y56virc2rjcpb1k79rzaj3nhl"; type = "gem"; }; version = "1.1.6"; }; ethon = { - dependencies = ["ffi"]; + dependencies = [ "ffi" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gggrgkcq839mamx7a8jbnp2h7x2ykfn34ixwskwb0lzx2ak17g9"; type = "gem"; }; version = "0.12.0"; }; faraday = { - dependencies = ["multipart-post"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multipart-post" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wwks9652xwgjm7yszcq5xr960pjypc07ivwzbjzpvy9zh2fw6iq"; type = "gem"; }; version = "1.0.1"; }; faraday_middleware = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jik2kgfinwnfi6fpp512vlvs0mlggign3gkbpkg5fw1jr9his0r"; type = "gem"; }; version = "1.0.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12lpwaw82bb0rm9f52v1498bpba8aj2l2q359mkwbxsswhpga5af"; type = "gem"; }; version = "1.13.1"; }; gh = { - dependencies = ["activesupport" "addressable" "faraday" "faraday_middleware" "multi_json" "net-http-persistent" "net-http-pipeline"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "activesupport" + "addressable" + "faraday" + "faraday_middleware" + "multi_json" + "net-http-persistent" + "net-http-pipeline" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nj2dm2pahfa4d39y8csvjv5l3hpsm6yjq2y96vj2bqgg0qs26bj"; type = "gem"; }; version = "0.17.0"; }; highline = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yclf57n2j3cw8144ania99h1zinf8q3f5zrhqa754j6gl95rp9d"; type = "gem"; }; version = "2.0.3"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10nq1xjqvkhngiygji831qx9bryjwws95r4vrnlq9142bzkg670s"; type = "gem"; }; version = "1.8.3"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nrmw2r4nfxlfgprfgki3hjifgrcrs3l5zvm3ca3gb4743yr25mn"; type = "gem"; }; version = "2.3.0"; }; launchy = { - dependencies = ["addressable"]; + dependencies = [ "addressable" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "190lfbiy1vwxhbgn4nl4dcbzxvm049jwc158r2x7kq3g5khjrxa2"; type = "gem"; }; version = "2.4.3"; }; method_source = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pviwzvdqd90gn6y7illcdd9adapw8fczml933p5vl739dkvl3lq"; type = "gem"; }; version = "0.9.2"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09bz9nsznxgaf06cx3b5z71glgl0hdw469gqx3w7bqijgrb55p5g"; type = "gem"; }; version = "5.14.1"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xy54mjf7xg41l8qrg1bqri75agdqmxap9z466fjismc1rn2jwfr"; type = "gem"; }; @@ -165,7 +178,7 @@ }; multipart-post = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zgw9zlwh2a6i1yvhhc4a84ry1hv824d6g2iw2chs3k5aylpmpfj"; type = "gem"; }; @@ -173,7 +186,7 @@ }; net-http-persistent = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1y9fhaax0d9kkslyiqi1zys6cvpaqx9a0y0cywp24rpygwh4s9r4"; type = "gem"; }; @@ -181,78 +194,93 @@ }; net-http-pipeline = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bxjy33yhxwsbnld8xj3zv64ibgfjn9rjpiqkyd5ipmz50pww8v9"; type = "gem"; }; version = "1.0.1"; }; pry = { - dependencies = ["coderay" "method_source"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "coderay" + "method_source" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1mh312k3y94sj0pi160wpia0ps8f4kmzvm505i6bvwynfdh7v30g"; type = "gem"; }; version = "0.11.3"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vywld400fzi17cszwrchrzcqys4qm6sshbv73wy5mwcixmrgg7g"; type = "gem"; }; version = "4.0.5"; }; pusher-client = { - dependencies = ["json" "websocket"]; + dependencies = [ + "json" + "websocket" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18ymxz34gmg7jff3h0nyzp5vdg5i06dbdxlrdl2nq4hf14qwj1f4"; type = "gem"; }; version = "0.6.2"; }; thread_safe = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nmhcgq6cgz44srylra07bmaw99f5271l0dpsvl5f75m44l0gmwy"; type = "gem"; }; version = "0.3.6"; }; travis = { - dependencies = ["faraday" "faraday_middleware" "gh" "highline" "json" "launchy" "pusher-client" "typhoeus"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "faraday" + "faraday_middleware" + "gh" + "highline" + "json" + "launchy" + "pusher-client" + "typhoeus" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yizj5nqvyrfbyiv1kfwc33dylhsmk5l007z06djj152v04z63i3"; type = "gem"; }; version = "1.9.1"; }; typhoeus = { - dependencies = ["ethon"]; + dependencies = [ "ethon" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03x3fxjsnhgayl4s96h0a9975awlvx2v9nmx2ba0cnliglyczdr8"; type = "gem"; }; version = "0.8.0"; }; tzinfo = { - dependencies = ["thread_safe"]; - groups = ["default"]; - platforms = []; + dependencies = [ "thread_safe" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1i3jh086w1kbdj3k5l60lc3nwbanmzdf8yjj3mlrx9b2gjjxhi9r"; type = "gem"; }; @@ -260,7 +288,7 @@ }; websocket = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f11rcn4qgffb1rq4kjfwi7di79w8840x9l74pkyif5arp0mb08x"; type = "gem"; }; diff --git a/pkgs/development/tools/misc/usb-modeswitch/data.nix b/pkgs/development/tools/misc/usb-modeswitch/data.nix index 7bb9fc69c58a28..2317c825e5304b 100644 --- a/pkgs/development/tools/misc/usb-modeswitch/data.nix +++ b/pkgs/development/tools/misc/usb-modeswitch/data.nix @@ -1,11 +1,17 @@ -{ lib, stdenv, fetchurl, tcl, usb-modeswitch }: +{ + lib, + stdenv, + fetchurl, + tcl, + usb-modeswitch, +}: stdenv.mkDerivation rec { pname = "usb-modeswitch-data"; version = "20191128"; src = fetchurl { - url = "http://www.draisberghof.de/usb_modeswitch/${pname}-${version}.tar.bz2"; + url = "http://www.draisberghof.de/usb_modeswitch/${pname}-${version}.tar.bz2"; sha256 = "1ygahl3r26r38ai8yyblq9nhf3v5i6n6r6672p5wf88wg5h9n0rz"; }; diff --git a/pkgs/development/tools/misc/usb-modeswitch/default.nix b/pkgs/development/tools/misc/usb-modeswitch/default.nix index 474de710048698..64b80c03921662 100644 --- a/pkgs/development/tools/misc/usb-modeswitch/default.nix +++ b/pkgs/development/tools/misc/usb-modeswitch/default.nix @@ -1,12 +1,22 @@ -{ stdenv, lib, fetchurl, pkg-config, makeWrapper -, libusb1, tcl, util-linux, coreutils, bash }: +{ + stdenv, + lib, + fetchurl, + pkg-config, + makeWrapper, + libusb1, + tcl, + util-linux, + coreutils, + bash, +}: stdenv.mkDerivation rec { pname = "usb-modeswitch"; version = "2.6.0"; src = fetchurl { - url = "http://www.draisberghof.de/usb_modeswitch/${pname}-${version}.tar.bz2"; + url = "http://www.draisberghof.de/usb_modeswitch/${pname}-${version}.tar.bz2"; sha256 = "18wbbxc5cfsmikba0msdvd5qlaga27b32nhrzicyd9mdddp265f2"; }; @@ -34,16 +44,31 @@ stdenv.mkDerivation rec { postFixup = '' wrapProgram $out/bin/usb_modeswitch_dispatcher \ - --set PATH ${lib.makeBinPath [ util-linux coreutils bash ]} + --set PATH ${ + lib.makeBinPath [ + util-linux + coreutils + bash + ] + } ''; - buildInputs = [ libusb1 tcl ]; - nativeBuildInputs = [ pkg-config makeWrapper ]; + buildInputs = [ + libusb1 + tcl + ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; meta = with lib; { description = "Mode switching tool for controlling 'multi-mode' USB devices"; license = licenses.gpl2; - maintainers = with maintainers; [ marcweber peterhoeg ]; + maintainers = with maintainers; [ + marcweber + peterhoeg + ]; platforms = platforms.linux; mainProgram = "usb_modeswitch"; }; diff --git a/pkgs/development/tools/misc/watson-ruby/default.nix b/pkgs/development/tools/misc/watson-ruby/default.nix index b0faf75892ee15..bceddf51643f63 100644 --- a/pkgs/development/tools/misc/watson-ruby/default.nix +++ b/pkgs/development/tools/misc/watson-ruby/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, bundlerEnv, ruby, bundlerUpdateScript }: +{ + lib, + stdenv, + bundlerEnv, + ruby, + bundlerUpdateScript, +}: stdenv.mkDerivation rec { pname = "watson-ruby"; @@ -6,26 +12,31 @@ stdenv.mkDerivation rec { dontUnpack = true; - installPhase = let - env = bundlerEnv { - name = "watson-ruby-gems-${version}"; - inherit ruby; - # expects Gemfile, Gemfile.lock and gemset.nix in the same directory - gemdir = ./.; - }; - in '' - mkdir -p $out/bin - ln -s ${env}/bin/watson $out/bin/watson - ''; + installPhase = + let + env = bundlerEnv { + name = "watson-ruby-gems-${version}"; + inherit ruby; + # expects Gemfile, Gemfile.lock and gemset.nix in the same directory + gemdir = ./.; + }; + in + '' + mkdir -p $out/bin + ln -s ${env}/bin/watson $out/bin/watson + ''; passthru.updateScript = bundlerUpdateScript "watson-ruby"; meta = with lib; { description = "Inline issue manager"; - homepage = "https://goosecode.com/watson/"; - license = with licenses; mit; - maintainers = with maintainers; [ robertodr nicknovitski ]; + homepage = "https://goosecode.com/watson/"; + license = with licenses; mit; + maintainers = with maintainers; [ + robertodr + nicknovitski + ]; mainProgram = "watson"; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/misc/watson-ruby/gemset.nix b/pkgs/development/tools/misc/watson-ruby/gemset.nix index 2f865820f5aa32..ccd5709b23b7b5 100644 --- a/pkgs/development/tools/misc/watson-ruby/gemset.nix +++ b/pkgs/development/tools/misc/watson-ruby/gemset.nix @@ -1,7 +1,7 @@ { json = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01v6jjpvh3gnq6sgllpfqahlgxzj50ailwhj9b3cd20hi2dx0vxp"; type = "gem"; }; @@ -9,7 +9,7 @@ }; watson-ruby = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d5m29nr0i030q8ygmbapwri5ndcg2q6lf8a15bk79lfcp9xyj9w"; type = "gem"; }; diff --git a/pkgs/development/tools/misc/whatstyle/default.nix b/pkgs/development/tools/misc/whatstyle/default.nix index 030dcf400f7385..e7dd2ec40735ac 100644 --- a/pkgs/development/tools/misc/whatstyle/default.nix +++ b/pkgs/development/tools/misc/whatstyle/default.nix @@ -1,4 +1,9 @@ -{ lib, python3, fetchFromGitHub, clang-unwrapped }: +{ + lib, + python3, + fetchFromGitHub, + clang-unwrapped, +}: python3.pkgs.buildPythonApplication rec { pname = "whatstyle"; @@ -16,7 +21,9 @@ python3.pkgs.buildPythonApplication rec { substituteInPlace ${pname}.py --replace 0.1.6 ${version} ''; - nativeCheckInputs = [ clang-unwrapped /* clang-format */ ]; + nativeCheckInputs = [ + clang-unwrapped # clang-format + ]; doCheck = false; # 3 or 4 failures depending on version, haven't investigated. diff --git a/pkgs/development/tools/misc/xxdiff/default.nix b/pkgs/development/tools/misc/xxdiff/default.nix index 87097ef819e31b..1da47d6c51c57e 100644 --- a/pkgs/development/tools/misc/xxdiff/default.nix +++ b/pkgs/development/tools/misc/xxdiff/default.nix @@ -1,5 +1,12 @@ -{ lib, mkDerivation, fetchFromBitbucket, docutils, bison, flex, qmake -, qtbase +{ + lib, + mkDerivation, + fetchFromBitbucket, + docutils, + bison, + flex, + qmake, + qtbase, }: mkDerivation rec { @@ -13,7 +20,12 @@ mkDerivation rec { sha256 = "0gbvxrkwkbvag3298j89smszghpr8ilxxfb0cvsknfqdf15b296w"; }; - nativeBuildInputs = [ bison docutils flex qmake ]; + nativeBuildInputs = [ + bison + docutils + flex + qmake + ]; buildInputs = [ qtbase ]; @@ -46,7 +58,10 @@ mkDerivation rec { mainProgram = "xxdiff"; homepage = "http://furius.ca/xxdiff/"; license = licenses.gpl2; - maintainers = with maintainers; [ pSub raskin ]; + maintainers = with maintainers; [ + pSub + raskin + ]; platforms = platforms.linux; }; } diff --git a/pkgs/development/tools/ocaml/camlidl/default.nix b/pkgs/development/tools/ocaml/camlidl/default.nix index 82bfff61e9de50..0e707e4fdaee3f 100644 --- a/pkgs/development/tools/ocaml/camlidl/default.nix +++ b/pkgs/development/tools/ocaml/camlidl/default.nix @@ -1,56 +1,63 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, writeText }: +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + writeText, +}: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.03") "camlidl is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-camlidl"; - version = "1.12"; - - src = fetchFromGitHub { - owner = "xavierleroy"; - repo = "camlidl"; - rev = "camlidl112"; - hash = "sha256-ONPQMDFaU2OzFa5jgMVKx+ZRKk8ZgBZyk42vDvbM7E0="; - }; - - nativeBuildInputs = [ ocaml ]; - - # build fails otherwise - enableParallelBuilding = false; - - preBuild = '' - mv config/Makefile.unix config/Makefile - substituteInPlace config/Makefile --replace BINDIR=/usr/local/bin BINDIR=$out - substituteInPlace config/Makefile --replace 'OCAMLLIB=$(shell $(OCAMLC) -where)' OCAMLLIB=$out/lib/ocaml/${ocaml.version}/site-lib/camlidl - substituteInPlace config/Makefile --replace CPP=cpp CPP=${stdenv.cc}/bin/cpp - substituteInPlace lib/Makefile --replace '$(OCAMLLIB)/Makefile.config' "${ocaml}/lib/ocaml/Makefile.config" - mkdir -p $out/lib/ocaml/${ocaml.version}/site-lib/camlidl/caml - mkdir -p $out/lib/ocaml/${ocaml.version}/site-lib/camlidl/stublibs - ''; - - postInstall = '' - cat >$out/lib/ocaml/${ocaml.version}/site-lib/camlidl/META <$out/lib/ocaml/${ocaml.version}/site-lib/camlidl/META <= 4.08 doCheck = lib.versionAtLeast ocaml.version "4.08"; in -lib.throwIf (lib.versionAtLeast ocaml.version "5.0") - "ocamlmod is not available for OCaml ≥ 5.0" +lib.throwIf (lib.versionAtLeast ocaml.version "5.0") "ocamlmod is not available for OCaml ≥ 5.0" -stdenv.mkDerivation { - pname = "ocamlmod"; - version = "0.0.9"; + stdenv.mkDerivation + { + pname = "ocamlmod"; + version = "0.0.9"; - src = fetchurl { - url = "https://forge.ocamlcore.org/frs/download.php/1702/ocamlmod-0.0.9.tar.gz"; - sha256 = "0cgp9qqrq7ayyhddrmqmq1affvfqcn722qiakjq4dkywvp67h4aa"; - }; + src = fetchurl { + url = "https://forge.ocamlcore.org/frs/download.php/1702/ocamlmod-0.0.9.tar.gz"; + sha256 = "0cgp9qqrq7ayyhddrmqmq1affvfqcn722qiakjq4dkywvp67h4aa"; + }; - strictDeps = !doCheck; + strictDeps = !doCheck; - nativeBuildInputs = [ ocaml findlib ocamlbuild ]; + nativeBuildInputs = [ + ocaml + findlib + ocamlbuild + ]; - configurePhase = "ocaml setup.ml -configure --prefix $out" - + lib.optionalString doCheck " --enable-tests"; - buildPhase = "ocaml setup.ml -build"; - installPhase = "ocaml setup.ml -install"; + configurePhase = + "ocaml setup.ml -configure --prefix $out" + lib.optionalString doCheck " --enable-tests"; + buildPhase = "ocaml setup.ml -build"; + installPhase = "ocaml setup.ml -install"; - inherit doCheck; - nativeCheckInputs = [ ounit ]; + inherit doCheck; + nativeCheckInputs = [ ounit ]; - checkPhase = "ocaml setup.ml -test"; + checkPhase = "ocaml setup.ml -test"; - dontStrip = true; + dontStrip = true; - meta = { - homepage = "https://forge.ocamlcore.org/projects/ocamlmod/ocamlmod"; - description = "Generate OCaml modules from source files"; - platforms = ocaml.meta.platforms or []; - maintainers = with lib.maintainers; [ - maggesi - ]; - }; -} + meta = { + homepage = "https://forge.ocamlcore.org/projects/ocamlmod/ocamlmod"; + description = "Generate OCaml modules from source files"; + platforms = ocaml.meta.platforms or [ ]; + maintainers = with lib.maintainers; [ + maggesi + ]; + }; + } diff --git a/pkgs/development/tools/ocaml/ocamlscript/default.nix b/pkgs/development/tools/ocaml/ocamlscript/default.nix index 8277f4adb06dc7..fee5a45b3f5dcf 100644 --- a/pkgs/development/tools/ocaml/ocamlscript/default.nix +++ b/pkgs/development/tools/ocaml/ocamlscript/default.nix @@ -1,34 +1,44 @@ -{ lib, stdenv, fetchFromGitHub, ocaml, findlib }: +{ + lib, + stdenv, + fetchFromGitHub, + ocaml, + findlib, +}: lib.throwIfNot (lib.versionAtLeast ocaml.version "4.08") "ocamlscript is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-ocamlscript"; - version = "3.0.0"; - src = fetchFromGitHub { - owner = "mjambon"; - repo = "ocamlscript"; - rev = "v${version}"; - sha256 = "sha256:10xz8jknlmcgnf233nahd04q98ijnxpijhpvb8hl7sv94dgkvpql"; - }; + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-ocamlscript"; + version = "3.0.0"; + src = fetchFromGitHub { + owner = "mjambon"; + repo = "ocamlscript"; + rev = "v${version}"; + sha256 = "sha256:10xz8jknlmcgnf233nahd04q98ijnxpijhpvb8hl7sv94dgkvpql"; + }; - nativeBuildInputs = [ ocaml findlib ]; + nativeBuildInputs = [ + ocaml + findlib + ]; - patches = [ ./Makefile.patch ]; + patches = [ ./Makefile.patch ]; - buildFlags = [ "PREFIX=$(out)" ]; - installFlags = [ "PREFIX=$(out)" ]; + buildFlags = [ "PREFIX=$(out)" ]; + installFlags = [ "PREFIX=$(out)" ]; - preInstall = "mkdir -p $out/bin"; - createFindlibDestdir = true; + preInstall = "mkdir -p $out/bin"; + createFindlibDestdir = true; - meta = with lib; { - inherit (src.meta) homepage; - license = licenses.boost; - inherit (ocaml.meta) platforms; - description = "Natively-compiled OCaml scripts"; - maintainers = [ maintainers.vbgl ]; - mainProgram = "ocamlscript"; - }; -} + meta = with lib; { + inherit (src.meta) homepage; + license = licenses.boost; + inherit (ocaml.meta) platforms; + description = "Natively-compiled OCaml scripts"; + maintainers = [ maintainers.vbgl ]; + mainProgram = "ocamlscript"; + }; + } diff --git a/pkgs/development/tools/ocaml/ocp-build/default.nix b/pkgs/development/tools/ocaml/ocp-build/default.nix index b3426a721ff4f1..d7d780d1a6d59a 100644 --- a/pkgs/development/tools/ocaml/ocp-build/default.nix +++ b/pkgs/development/tools/ocaml/ocp-build/default.nix @@ -1,47 +1,64 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, ocaml, findlib, ncurses, cmdliner_1_0, re }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + ocaml, + findlib, + ncurses, + cmdliner_1_0, + re, +}: lib.throwIf (lib.versionAtLeast ocaml.version "5.0") "ocp-build is not available for OCaml ${ocaml.version}" -stdenv.mkDerivation rec { - pname = "ocaml${ocaml.version}-ocp-build"; - version = "1.99.21"; + stdenv.mkDerivation + rec { + pname = "ocaml${ocaml.version}-ocp-build"; + version = "1.99.21"; - src = fetchFromGitHub { - owner = "OCamlPro"; - repo = "ocp-build"; - rev = "v${version}"; - sha256 = "1641xzik98c7xnjwxpacijd6d9jzx340fmdn6i372z8h554jjlg9"; - }; + src = fetchFromGitHub { + owner = "OCamlPro"; + repo = "ocp-build"; + rev = "v${version}"; + sha256 = "1641xzik98c7xnjwxpacijd6d9jzx340fmdn6i372z8h554jjlg9"; + }; - patches = [ - # Fix compilation with OCaml 4.12 - (fetchpatch { - url = "https://github.com/OCamlPro/ocp-build/commit/104e4656ca6dba9edb03b62539c9f1e10abcaae8.patch"; - sha256 = "0sbyi4acig9q8x1ky4hckfg5pm2nad6zasi51ravaf1spgl148c2"; - }) - ]; + patches = [ + # Fix compilation with OCaml 4.12 + (fetchpatch { + url = "https://github.com/OCamlPro/ocp-build/commit/104e4656ca6dba9edb03b62539c9f1e10abcaae8.patch"; + sha256 = "0sbyi4acig9q8x1ky4hckfg5pm2nad6zasi51ravaf1spgl148c2"; + }) + ]; - strictDeps = true; + strictDeps = true; - nativeBuildInputs = [ ocaml findlib ]; - buildInputs = [ cmdliner_1_0 re ]; - propagatedBuildInputs = [ ncurses ]; - preInstall = "mkdir -p $out/bin"; + nativeBuildInputs = [ + ocaml + findlib + ]; + buildInputs = [ + cmdliner_1_0 + re + ]; + propagatedBuildInputs = [ ncurses ]; + preInstall = "mkdir -p $out/bin"; - meta = with lib; { - description = "Build tool for OCaml"; - longDescription = '' - ocp-build is a build system for OCaml application, based on simple - descriptions of packages. ocp-build combines the descriptions of - packages, and optimize the parallel compilation of files depending on - the number of cores and the automatically-inferred dependencies - between source files. - ''; - homepage = "https://www.typerex.org/ocp-build.html"; - license = licenses.gpl3; - maintainers = [ maintainers.jirkamarsik ]; - mainProgram = "ocp-build"; - inherit (ocaml.meta) platforms; - }; -} + meta = with lib; { + description = "Build tool for OCaml"; + longDescription = '' + ocp-build is a build system for OCaml application, based on simple + descriptions of packages. ocp-build combines the descriptions of + packages, and optimize the parallel compilation of files depending on + the number of cores and the automatically-inferred dependencies + between source files. + ''; + homepage = "https://www.typerex.org/ocp-build.html"; + license = licenses.gpl3; + maintainers = [ maintainers.jirkamarsik ]; + mainProgram = "ocp-build"; + inherit (ocaml.meta) platforms; + }; + } diff --git a/pkgs/development/tools/ocaml/ocp-indent/default.nix b/pkgs/development/tools/ocaml/ocp-indent/default.nix index 2599b560550b35..73c834c6624faa 100644 --- a/pkgs/development/tools/ocaml/ocp-indent/default.nix +++ b/pkgs/development/tools/ocaml/ocp-indent/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, buildDunePackage, cmdliner, findlib }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + cmdliner, + findlib, +}: buildDunePackage rec { version = "1.8.2"; diff --git a/pkgs/development/tools/ocaml/ocp-index/default.nix b/pkgs/development/tools/ocaml/ocp-index/default.nix index 84e4dfb2be903d..d1f7ec0f097cad 100644 --- a/pkgs/development/tools/ocaml/ocp-index/default.nix +++ b/pkgs/development/tools/ocaml/ocp-index/default.nix @@ -1,4 +1,12 @@ -{ lib, fetchFromGitHub, buildDunePackage, cppo, ocp-indent, cmdliner, re }: +{ + lib, + fetchFromGitHub, + buildDunePackage, + cppo, + ocp-indent, + cmdliner, + re, +}: buildDunePackage rec { pname = "ocp-index"; @@ -14,7 +22,10 @@ buildDunePackage rec { }; nativeBuildInputs = [ cppo ]; - buildInputs = [ cmdliner re ]; + buildInputs = [ + cmdliner + re + ]; propagatedBuildInputs = [ ocp-indent ]; diff --git a/pkgs/development/tools/ocaml/opam/installer.nix b/pkgs/development/tools/ocaml/opam/installer.nix index 3e3685b8e2fe12..5da0e140ad04a8 100644 --- a/pkgs/development/tools/ocaml/opam/installer.nix +++ b/pkgs/development/tools/ocaml/opam/installer.nix @@ -5,8 +5,14 @@ ocamlPackages.buildDunePackage { inherit (opam) version src; - configureFlags = [ "--disable-checks" "--prefix=$out" ]; - buildInputs = with ocamlPackages; [ opam-format cmdliner ]; + configureFlags = [ + "--disable-checks" + "--prefix=$out" + ]; + buildInputs = with ocamlPackages; [ + opam-format + cmdliner + ]; meta = opam.meta // { description = "Handle (un)installation from opam install files"; diff --git a/pkgs/development/tools/ofono-phonesim/default.nix b/pkgs/development/tools/ofono-phonesim/default.nix index b37043ca41cc4b..ab01fa1a32a81d 100644 --- a/pkgs/development/tools/ofono-phonesim/default.nix +++ b/pkgs/development/tools/ofono-phonesim/default.nix @@ -1,9 +1,10 @@ -{ lib -, mkDerivation -, fetchzip -, autoreconfHook -, pkg-config -, qtbase +{ + lib, + mkDerivation, + fetchzip, + autoreconfHook, + pkg-config, + qtbase, }: mkDerivation { diff --git a/pkgs/development/tools/pactorio/default.nix b/pkgs/development/tools/pactorio/default.nix index 06b55790ddf6fc..dc0b2e1dfbcb66 100644 --- a/pkgs/development/tools/pactorio/default.nix +++ b/pkgs/development/tools/pactorio/default.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, bzip2 -, stdenv -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + bzip2, + stdenv, + Security, }: rustPlatform.buildRustPackage rec { @@ -21,7 +22,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-sAFsG+EPSmvPDFR9R0fZ5f+y/PXVpTJlMzL61vwf4SY="; - nativeBuildInputs = [ installShellFiles pkg-config ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + ]; buildInputs = [ bzip2 ] ++ lib.optional stdenv.hostPlatform.isDarwin Security; diff --git a/pkgs/development/tools/parsing/antlr/2.7.7.nix b/pkgs/development/tools/parsing/antlr/2.7.7.nix index 991925cb4e7626..df89324aba6aeb 100644 --- a/pkgs/development/tools/parsing/antlr/2.7.7.nix +++ b/pkgs/development/tools/parsing/antlr/2.7.7.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, jdk }: +{ + lib, + stdenv, + fetchurl, + jdk, +}: stdenv.mkDerivation rec { pname = "antlr"; diff --git a/pkgs/development/tools/parsing/antlr/3.4.nix b/pkgs/development/tools/parsing/antlr/3.4.nix index 38493dedab10cd..16d1c7045cf44d 100644 --- a/pkgs/development/tools/parsing/antlr/3.4.nix +++ b/pkgs/development/tools/parsing/antlr/3.4.nix @@ -1,10 +1,15 @@ -{lib, stdenv, fetchurl, jre}: +{ + lib, + stdenv, + fetchurl, + jre, +}: stdenv.mkDerivation rec { pname = "antlr"; version = "3.4"; src = fetchurl { - url ="https://www.antlr3.org/download/antlr-${version}-complete.jar"; + url = "https://www.antlr3.org/download/antlr-${version}-complete.jar"; sha256 = "1xqbam8vf04q5fasb0m2n1pn5dbp2yw763sj492ncq04c5mqcglx"; }; diff --git a/pkgs/development/tools/parsing/antlr/3.5.nix b/pkgs/development/tools/parsing/antlr/3.5.nix index 132da31fee3513..ae466260d03945 100644 --- a/pkgs/development/tools/parsing/antlr/3.5.nix +++ b/pkgs/development/tools/parsing/antlr/3.5.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchpatch, fetchurl, fetchFromGitHub, jre}: +{ + lib, + stdenv, + fetchpatch, + fetchurl, + fetchFromGitHub, + jre, +}: stdenv.mkDerivation rec { pname = "antlr"; diff --git a/pkgs/development/tools/parsing/flex/2.5.35.nix b/pkgs/development/tools/parsing/flex/2.5.35.nix index a68f7e07429c38..e27af764014221 100644 --- a/pkgs/development/tools/parsing/flex/2.5.35.nix +++ b/pkgs/development/tools/parsing/flex/2.5.35.nix @@ -1,11 +1,23 @@ -{ lib, stdenv, fetchurl, autoreconfHook, flex, bison, texinfo, help2man, m4 }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + flex, + bison, + texinfo, + help2man, + m4, +}: stdenv.mkDerivation rec { pname = "flex"; version = "2.5.35"; src = fetchurl { - url = "https://github.com/westes/flex/archive/flex-${lib.replaceStrings ["."] ["-"] version}.tar.gz"; + url = "https://github.com/westes/flex/archive/flex-${ + lib.replaceStrings [ "." ] [ "-" ] version + }.tar.gz"; sha256 = "0wh06nix8bd4w1aq4k2fbbkdq5i30a9lxz3xczf3ff28yy0kfwzm"; }; @@ -13,7 +25,13 @@ stdenv.mkDerivation rec { patchShebangs tests ''; - nativeBuildInputs = [ flex bison texinfo help2man autoreconfHook ]; + nativeBuildInputs = [ + flex + bison + texinfo + help2man + autoreconfHook + ]; propagatedBuildInputs = [ m4 ]; diff --git a/pkgs/development/tools/parsing/flex/default.nix b/pkgs/development/tools/parsing/flex/default.nix index 84cb5f35d3c6d3..c6c62b2cc2dcd2 100644 --- a/pkgs/development/tools/parsing/flex/default.nix +++ b/pkgs/development/tools/parsing/flex/default.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, buildPackages, fetchurl, bison, m4 -, autoreconfHook, help2man +{ + lib, + stdenv, + buildPackages, + fetchurl, + bison, + m4, + autoreconfHook, + help2man, }: # Avoid 'fetchpatch' to allow 'flex' to be used as a possible 'gcc' @@ -17,22 +24,29 @@ stdenv.mkDerivation rec { # Also upstream, will be part of 2.6.5 # https://github.com/westes/flex/commit/24fd0551333e - patches = [(fetchurl { - name = "glibc-2.26.patch"; - url = "https://raw.githubusercontent.com/lede-project/source/0fb14a2b1ab2f82ce63f4437b062229d73d90516/tools/flex/patches/200-build-AC_USE_SYSTEM_EXTENSIONS-in-configure.ac.patch"; - sha256 = "0mpp41zdg17gx30kcpj83jl8hssks3adbks0qzbhcz882b9c083r"; - })]; - - postPatch = '' - patchShebangs tests - '' + lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' - substituteInPlace Makefile.in --replace "tests" " " - - substituteInPlace doc/Makefile.am --replace 'flex.1: $(top_srcdir)/configure.ac' 'flex.1: ' - ''; + patches = [ + (fetchurl { + name = "glibc-2.26.patch"; + url = "https://raw.githubusercontent.com/lede-project/source/0fb14a2b1ab2f82ce63f4437b062229d73d90516/tools/flex/patches/200-build-AC_USE_SYSTEM_EXTENSIONS-in-configure.ac.patch"; + sha256 = "0mpp41zdg17gx30kcpj83jl8hssks3adbks0qzbhcz882b9c083r"; + }) + ]; + + postPatch = + '' + patchShebangs tests + '' + + lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' + substituteInPlace Makefile.in --replace "tests" " " + + substituteInPlace doc/Makefile.am --replace 'flex.1: $(top_srcdir)/configure.ac' 'flex.1: ' + ''; depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ autoreconfHook help2man ]; + nativeBuildInputs = [ + autoreconfHook + help2man + ]; buildInputs = [ bison ]; propagatedBuildInputs = [ m4 ]; diff --git a/pkgs/development/tools/parsing/javacc/default.nix b/pkgs/development/tools/parsing/javacc/default.nix index ed016506782161..8845ae95f2f982 100644 --- a/pkgs/development/tools/parsing/javacc/default.nix +++ b/pkgs/development/tools/parsing/javacc/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, ant -, jdk -, jre -, makeWrapper -, stripJavaArchivesHook +{ + lib, + stdenv, + fetchFromGitHub, + ant, + jdk, + jre, + makeWrapper, + stripJavaArchivesHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/tools/parsing/ragel/default.nix b/pkgs/development/tools/parsing/ragel/default.nix index a6090f104fa24f..949c282ecd73ad 100644 --- a/pkgs/development/tools/parsing/ragel/default.nix +++ b/pkgs/development/tools/parsing/ragel/default.nix @@ -1,9 +1,22 @@ -{ lib, stdenv, fetchurl, fig2dev, texliveSmall, ghostscript, colm -, build-manual ? false +{ + lib, + stdenv, + fetchurl, + fig2dev, + texliveSmall, + ghostscript, + colm, + build-manual ? false, }: let - generic = { version, sha256, broken ? false, license }: + generic = + { + version, + sha256, + broken ? false, + license, + }: stdenv.mkDerivation rec { pname = "ragel"; inherit version; @@ -13,7 +26,11 @@ let inherit sha256; }; - buildInputs = lib.optionals build-manual [ fig2dev ghostscript texliveSmall ]; + buildInputs = lib.optionals build-manual [ + fig2dev + ghostscript + texliveSmall + ]; preConfigure = lib.optionalString build-manual '' sed -i "s/build_manual=no/build_manual=yes/g" DIST diff --git a/pkgs/development/tools/perseus-cli/default.nix b/pkgs/development/tools/perseus-cli/default.nix index 7ba885234445e5..ba37dc5e141786 100644 --- a/pkgs/development/tools/perseus-cli/default.nix +++ b/pkgs/development/tools/perseus-cli/default.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchCrate -, makeWrapper -, wasm-pack +{ + lib, + rustPlatform, + fetchCrate, + makeWrapper, + wasm-pack, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/development/tools/profiling/oprofile/default.nix b/pkgs/development/tools/profiling/oprofile/default.nix index 3bedc45c8d1000..b49f7a68420e8c 100644 --- a/pkgs/development/tools/profiling/oprofile/default.nix +++ b/pkgs/development/tools/profiling/oprofile/default.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, buildPackages -, fetchurl, pkg-config -, libbfd, popt, zlib, linuxHeaders, libiberty_static +{ + lib, + stdenv, + buildPackages, + fetchurl, + pkg-config, + libbfd, + popt, + zlib, + linuxHeaders, + libiberty_static, }: stdenv.mkDerivation rec { @@ -19,11 +27,17 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libbfd zlib popt linuxHeaders libiberty_static ]; + buildInputs = [ + libbfd + zlib + popt + linuxHeaders + libiberty_static + ]; configureFlags = [ "--with-kernel=${linuxHeaders}" - "--disable-shared" # needed because only the static libbfd is available + "--disable-shared" # needed because only the static libbfd is available ]; meta = { diff --git a/pkgs/development/tools/profiling/sysprof/capture.nix b/pkgs/development/tools/profiling/sysprof/capture.nix index ad04b731482084..00a7bdc6a01e50 100644 --- a/pkgs/development/tools/profiling/sysprof/capture.nix +++ b/pkgs/development/tools/profiling/sysprof/capture.nix @@ -1,8 +1,9 @@ -{ stdenv -, lib -, meson -, ninja -, sysprof +{ + stdenv, + lib, + meson, + ninja, + sysprof, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/tools/profiling/sysprof/default.nix b/pkgs/development/tools/profiling/sysprof/default.nix index b13883474363a7..01de2e761ea9f1 100644 --- a/pkgs/development/tools/profiling/sysprof/default.nix +++ b/pkgs/development/tools/profiling/sysprof/default.nix @@ -1,32 +1,37 @@ -{ stdenv -, lib -, desktop-file-utils -, fetchurl -, gettext -, glib -, gtk4 -, json-glib -, itstool -, libadwaita -, libdex -, libpanel -, libunwind -, libxml2 -, meson -, ninja -, pkg-config -, polkit -, shared-mime-info -, systemd -, wrapGAppsHook4 -, gnome +{ + stdenv, + lib, + desktop-file-utils, + fetchurl, + gettext, + glib, + gtk4, + json-glib, + itstool, + libadwaita, + libdex, + libpanel, + libunwind, + libxml2, + meson, + ninja, + pkg-config, + polkit, + shared-mime-info, + systemd, + wrapGAppsHook4, + gnome, }: stdenv.mkDerivation rec { pname = "sysprof"; version = "47.0"; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.major version}/${pname}-${version}.tar.xz"; diff --git a/pkgs/development/tools/profiling/systemtap/default.nix b/pkgs/development/tools/profiling/systemtap/default.nix index c6595db224efeb..955cec56124f3c 100644 --- a/pkgs/development/tools/profiling/systemtap/default.nix +++ b/pkgs/development/tools/profiling/systemtap/default.nix @@ -1,7 +1,17 @@ -{ lib, fetchgit, pkg-config, gettext, runCommand, makeWrapper -, cpio, elfutils, kernel, gnumake, python3 -, nixosTests -, withStap ? true # avoid cyclic dependency with glib +{ + lib, + fetchgit, + pkg-config, + gettext, + runCommand, + makeWrapper, + cpio, + elfutils, + kernel, + gnumake, + python3, + nixosTests, + withStap ? true, # avoid cyclic dependency with glib }: let @@ -18,8 +28,17 @@ let pname = "systemtap"; inherit version; src = fetchgit { inherit url rev sha256; }; - nativeBuildInputs = [ pkg-config cpio python3 python3.pkgs.setuptools ]; - buildInputs = [ elfutils gettext python3 ]; + nativeBuildInputs = [ + pkg-config + cpio + python3 + python3.pkgs.setuptools + ]; + buildInputs = [ + elfutils + gettext + python3 + ]; enableParallelBuilding = true; env.NIX_CFLAGS_COMPILE = toString [ "-Wno-error=deprecated-declarations" ]; # Needed with GCC 12 }; @@ -34,26 +53,39 @@ let pypkgs = with python3.pkgs; makePythonPath [ pyparsing ]; -in runCommand "systemtap-${version}" { - inherit stapBuild; - nativeBuildInputs = [ makeWrapper ]; - passthru.tests = { inherit (nixosTests.systemtap) linux_default linux_latest; }; - meta = { - homepage = "https://sourceware.org/systemtap/"; - description = "Provides a scripting language for instrumentation on a live kernel plus user-space"; - license = lib.licenses.gpl2; - platforms = lib.systems.inspect.patterns.isGnu; - }; -} ('' - mkdir -p $out/bin - for bin in $stapBuild/bin/*; do - ln -s $bin $out/bin - done - rm $out/bin/stap $out/bin/dtrace - makeWrapper $stapBuild/bin/dtrace $out/bin/dtrace \ - --prefix PYTHONPATH : ${pypkgs} -'' + lib.optionalString withStap '' - makeWrapper $stapBuild/bin/stap $out/bin/stap \ - --add-flags "--sysroot ${sysroot}" \ - --prefix PATH : ${lib.makeBinPath [ stdenv.cc.cc stdenv.cc.bintools elfutils gnumake ]} -'') +in +runCommand "systemtap-${version}" + { + inherit stapBuild; + nativeBuildInputs = [ makeWrapper ]; + passthru.tests = { inherit (nixosTests.systemtap) linux_default linux_latest; }; + meta = { + homepage = "https://sourceware.org/systemtap/"; + description = "Provides a scripting language for instrumentation on a live kernel plus user-space"; + license = lib.licenses.gpl2; + platforms = lib.systems.inspect.patterns.isGnu; + }; + } + ( + '' + mkdir -p $out/bin + for bin in $stapBuild/bin/*; do + ln -s $bin $out/bin + done + rm $out/bin/stap $out/bin/dtrace + makeWrapper $stapBuild/bin/dtrace $out/bin/dtrace \ + --prefix PYTHONPATH : ${pypkgs} + '' + + lib.optionalString withStap '' + makeWrapper $stapBuild/bin/stap $out/bin/stap \ + --add-flags "--sysroot ${sysroot}" \ + --prefix PATH : ${ + lib.makeBinPath [ + stdenv.cc.cc + stdenv.cc.bintools + elfutils + gnumake + ] + } + '' + ) diff --git a/pkgs/development/tools/prospector/default.nix b/pkgs/development/tools/prospector/default.nix index 58fab74c988415..dcfbcd52fa1ec5 100644 --- a/pkgs/development/tools/prospector/default.nix +++ b/pkgs/development/tools/prospector/default.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: let @@ -67,7 +68,6 @@ python3.pkgs.buildPythonApplication rec { "tests/tools/pyroma/test_pyroma_tool.py" ]; - meta = with lib; { description = "Tool to analyse Python code and output information about errors, potential problems, convention violations and complexity"; homepage = "https://github.com/PyCQA/prospector"; diff --git a/pkgs/development/tools/prospector/setoptconf.nix b/pkgs/development/tools/prospector/setoptconf.nix index 918c377cfa6421..dfd3824fdf13bc 100644 --- a/pkgs/development/tools/prospector/setoptconf.nix +++ b/pkgs/development/tools/prospector/setoptconf.nix @@ -1,6 +1,7 @@ -{ buildPythonPackage -, fetchPypi -, lib +{ + buildPythonPackage, + fetchPypi, + lib, }: buildPythonPackage rec { diff --git a/pkgs/development/tools/protoc-gen-dart/default.nix b/pkgs/development/tools/protoc-gen-dart/default.nix index 06a96e70cf3e7d..4b51e146940423 100644 --- a/pkgs/development/tools/protoc-gen-dart/default.nix +++ b/pkgs/development/tools/protoc-gen-dart/default.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildDartApplication +{ + lib, + fetchFromGitHub, + buildDartApplication, }: buildDartApplication rec { diff --git a/pkgs/development/tools/protoc-gen-grpc-web/default.nix b/pkgs/development/tools/protoc-gen-grpc-web/default.nix index 6c8d8c5417602c..61e9c252c12c2b 100644 --- a/pkgs/development/tools/protoc-gen-grpc-web/default.nix +++ b/pkgs/development/tools/protoc-gen-grpc-web/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, protobuf -, isStatic ? stdenv.hostPlatform.isStatic +{ + lib, + stdenv, + fetchFromGitHub, + protobuf, + isStatic ? stdenv.hostPlatform.isStatic, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/development/tools/pry/default.nix b/pkgs/development/tools/pry/default.nix index 209d61e23c5e86..678f58b8fe9aac 100644 --- a/pkgs/development/tools/pry/default.nix +++ b/pkgs/development/tools/pry/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "pry"; @@ -9,9 +13,9 @@ bundlerApp { meta = with lib; { description = "Ruby runtime developer console and IRB alternative"; - homepage = "https://pryrepl.org"; - license = licenses.mit; + homepage = "https://pryrepl.org"; + license = licenses.mit; maintainers = [ maintainers.tckmn ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/pry/gemset.nix b/pkgs/development/tools/pry/gemset.nix index c3f42889e1fffa..6c0d1085ede094 100644 --- a/pkgs/development/tools/pry/gemset.nix +++ b/pkgs/development/tools/pry/gemset.nix @@ -1,30 +1,33 @@ { coderay = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jvxqxzply1lwp7ysn94zjhh57vc14mcshw1ygw14ib8lhc00lyw"; type = "gem"; }; version = "1.1.3"; }; method_source = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pnyh44qycnf9mzi1j6fywd5fkskv3x7nmsqrrws0rjn5dd4ayfp"; type = "gem"; }; version = "1.0.0"; }; pry = { - dependencies = ["coderay" "method_source"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "coderay" + "method_source" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0iyw4q4an2wmk8v5rn2ghfy2jaz9vmw2nk8415nnpx2s866934qk"; type = "gem"; }; diff --git a/pkgs/development/tools/purescript/spago/default.nix b/pkgs/development/tools/purescript/spago/default.nix index b9d97c351b6d79..c06b588c56bafb 100644 --- a/pkgs/development/tools/purescript/spago/default.nix +++ b/pkgs/development/tools/purescript/spago/default.nix @@ -1,57 +1,55 @@ -{ haskell -, haskellPackages -, lib +{ + haskell, + haskellPackages, + lib, -# The following are only needed for the passthru.tests: -, spago -, cacert -, git -, nodejs -, purescript -, runCommand + # The following are only needed for the passthru.tests: + spago, + cacert, + git, + nodejs, + purescript, + runCommand, }: -lib.pipe - haskellPackages.spago - [ - haskell.lib.compose.justStaticExecutables +lib.pipe haskellPackages.spago [ + haskell.lib.compose.justStaticExecutables - (haskell.lib.compose.overrideCabal (oldAttrs: { - changelog = "https://github.com/purescript/spago/releases/tag/${oldAttrs.version}"; + (haskell.lib.compose.overrideCabal (oldAttrs: { + changelog = "https://github.com/purescript/spago/releases/tag/${oldAttrs.version}"; - passthru = (oldAttrs.passthru or {}) // { - updateScript = ./update.sh; + passthru = (oldAttrs.passthru or { }) // { + updateScript = ./update.sh; - # These tests can be run with the following command. The tests access the - # network, so they cannot be run in the nix sandbox. sudo is needed in - # order to change the sandbox option. - # - # $ sudo nix-build -A spago.passthru.tests --option sandbox relaxed - # - tests = - runCommand - "spago-tests" - { - __noChroot = true; - nativeBuildInputs = [ - cacert - git - nodejs - purescript - spago - ]; - } - '' - # spago expects HOME to be set because it creates a cache file under - # home. - HOME=$(pwd) + # These tests can be run with the following command. The tests access the + # network, so they cannot be run in the nix sandbox. sudo is needed in + # order to change the sandbox option. + # + # $ sudo nix-build -A spago.passthru.tests --option sandbox relaxed + # + tests = + runCommand "spago-tests" + { + __noChroot = true; + nativeBuildInputs = [ + cacert + git + nodejs + purescript + spago + ]; + } + '' + # spago expects HOME to be set because it creates a cache file under + # home. + HOME=$(pwd) - spago --verbose init - spago --verbose build - spago --verbose test + spago --verbose init + spago --verbose build + spago --verbose test - touch $out - ''; - }; - })) - ] + touch $out + ''; + }; + })) +] diff --git a/pkgs/development/tools/purescript/spago/spago.nix b/pkgs/development/tools/purescript/spago/spago.nix index d0455081111fa7..905d6b63720e8c 100644 --- a/pkgs/development/tools/purescript/spago/spago.nix +++ b/pkgs/development/tools/purescript/spago/spago.nix @@ -1,16 +1,65 @@ # This has been automatically generated by the script # ./update.sh. This should not be changed by hand. -{ mkDerivation, aeson, aeson-pretty, ansi-terminal, async-pool -, base, bower-json, bytestring, containers, cryptonite, dhall -, directory, either, extra, fetchgit, file-embed, filepath, foldl -, fsnotify, generic-lens, Glob, hspec, hspec-discover -, hspec-megaparsec, http-client, http-conduit, http-types -, lens-family-core, lib, megaparsec, mtl, network-uri, open-browser -, optparse-applicative, prettyprinter, process, QuickCheck, retry -, rio, rio-orphans, safe, semver-range, stm, stringsearch, tar -, template-haskell, temporary, text, time, transformers, turtle -, unliftio, unordered-containers, uri-encode, utf8-string, versions -, with-utf8, yaml, zlib +{ + mkDerivation, + aeson, + aeson-pretty, + ansi-terminal, + async-pool, + base, + bower-json, + bytestring, + containers, + cryptonite, + dhall, + directory, + either, + extra, + fetchgit, + file-embed, + filepath, + foldl, + fsnotify, + generic-lens, + Glob, + hspec, + hspec-discover, + hspec-megaparsec, + http-client, + http-conduit, + http-types, + lens-family-core, + lib, + megaparsec, + mtl, + network-uri, + open-browser, + optparse-applicative, + prettyprinter, + process, + QuickCheck, + retry, + rio, + rio-orphans, + safe, + semver-range, + stm, + stringsearch, + tar, + template-haskell, + temporary, + text, + time, + transformers, + turtle, + unliftio, + unordered-containers, + uri-encode, + utf8-string, + versions, + with-utf8, + yaml, + zlib, }: mkDerivation { pname = "spago"; @@ -24,21 +73,79 @@ mkDerivation { isLibrary = true; isExecutable = true; libraryHaskellDepends = [ - aeson aeson-pretty ansi-terminal async-pool base bower-json - bytestring containers cryptonite dhall directory either file-embed - filepath foldl fsnotify generic-lens Glob http-client http-conduit - http-types lens-family-core megaparsec mtl network-uri open-browser - optparse-applicative prettyprinter process retry rio rio-orphans - safe semver-range stm stringsearch tar template-haskell temporary - text time transformers turtle unliftio unordered-containers - uri-encode utf8-string versions with-utf8 yaml zlib + aeson + aeson-pretty + ansi-terminal + async-pool + base + bower-json + bytestring + containers + cryptonite + dhall + directory + either + file-embed + filepath + foldl + fsnotify + generic-lens + Glob + http-client + http-conduit + http-types + lens-family-core + megaparsec + mtl + network-uri + open-browser + optparse-applicative + prettyprinter + process + retry + rio + rio-orphans + safe + semver-range + stm + stringsearch + tar + template-haskell + temporary + text + time + transformers + turtle + unliftio + unordered-containers + uri-encode + utf8-string + versions + with-utf8 + yaml + zlib ]; executableHaskellDepends = [ - ansi-terminal base text turtle with-utf8 + ansi-terminal + base + text + turtle + with-utf8 ]; testHaskellDepends = [ - base containers directory extra hspec hspec-megaparsec megaparsec - process QuickCheck temporary text turtle versions + base + containers + directory + extra + hspec + hspec-megaparsec + megaparsec + process + QuickCheck + temporary + text + turtle + versions ]; testToolDepends = [ hspec-discover ]; homepage = "https://github.com/purescript/spago#readme"; diff --git a/pkgs/development/tools/qtcreator/default.nix b/pkgs/development/tools/qtcreator/default.nix index de759bc0c87f50..aed03b72322a93 100644 --- a/pkgs/development/tools/qtcreator/default.nix +++ b/pkgs/development/tools/qtcreator/default.nix @@ -1,31 +1,32 @@ -{ stdenv -, lib -, fetchurl -, cmake -, pkg-config -, ninja -, python3 -, qtbase -, qt5compat -, qtdeclarative -, qtdoc -, qtquick3d -, qtquicktimeline -, qtserialport -, qtsvg -, qttools -, qtwebengine -, qtwayland -, qtshadertools -, wrapQtAppsHook -, yaml-cpp -, litehtml -, libsecret -, gumbo -, llvmPackages -, rustc-demangle -, elfutils -, perf +{ + stdenv, + lib, + fetchurl, + cmake, + pkg-config, + ninja, + python3, + qtbase, + qt5compat, + qtdeclarative, + qtdoc, + qtquick3d, + qtquicktimeline, + qtserialport, + qtsvg, + qttools, + qtwebengine, + qtwayland, + qtshadertools, + wrapQtAppsHook, + yaml-cpp, + litehtml, + libsecret, + gumbo, + llvmPackages, + rustc-demangle, + elfutils, + perf, }: stdenv.mkDerivation rec { diff --git a/pkgs/development/tools/rbspy/default.nix b/pkgs/development/tools/rbspy/default.nix index 837468803842fc..a989d85fd6b778 100644 --- a/pkgs/development/tools/rbspy/default.nix +++ b/pkgs/development/tools/rbspy/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, ruby -, which -, nix-update-script +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + ruby, + which, + nix-update-script, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/development/tools/rdbtools/default.nix b/pkgs/development/tools/rdbtools/default.nix index 40cbce35ba3f24..5bad05ad3fc7dc 100644 --- a/pkgs/development/tools/rdbtools/default.nix +++ b/pkgs/development/tools/rdbtools/default.nix @@ -1,4 +1,8 @@ -{ lib, python, fetchPypi }: +{ + lib, + python, + fetchPypi, +}: with python.pkgs; @@ -11,7 +15,10 @@ buildPythonApplication rec { sha256 = "689e57e42f43bdc73ea4e893d9676819980d17968696826b69fbd951f59772de"; }; - propagatedBuildInputs = [ redis python-lzf ]; + propagatedBuildInputs = [ + redis + python-lzf + ]; # No tests in published package doCheck = false; diff --git a/pkgs/development/tools/rebazel/default.nix b/pkgs/development/tools/rebazel/default.nix index 4b9549b8a58afc..33592b76e8536e 100644 --- a/pkgs/development/tools/rebazel/default.nix +++ b/pkgs/development/tools/rebazel/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, CoreServices }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + CoreServices, +}: rustPlatform.buildRustPackage rec { pname = "rebazel"; diff --git a/pkgs/development/tools/redis-dump/default.nix b/pkgs/development/tools/redis-dump/default.nix index 2d4acd724d39b3..58ba7be5ae1e55 100644 --- a/pkgs/development/tools/redis-dump/default.nix +++ b/pkgs/development/tools/redis-dump/default.nix @@ -1,17 +1,28 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "redis-dump"; gemdir = ./.; - exes = [ "redis-dump" "redis-load" ]; + exes = [ + "redis-dump" + "redis-load" + ]; passthru.updateScript = bundlerUpdateScript "redis-dump"; meta = with lib; { description = "Backup and restore your Redis data to and from JSON"; - homepage = "http://delanotes.com/redis-dump/"; - license = licenses.mit; - maintainers = with maintainers; [ offline manveru nicknovitski ]; - platforms = platforms.unix; + homepage = "http://delanotes.com/redis-dump/"; + license = licenses.mit; + maintainers = with maintainers; [ + offline + manveru + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/redis-dump/gemset.nix b/pkgs/development/tools/redis-dump/gemset.nix index 74e6d4e1b32499..128fc3de21c5d9 100644 --- a/pkgs/development/tools/redis-dump/gemset.nix +++ b/pkgs/development/tools/redis-dump/gemset.nix @@ -1,50 +1,55 @@ { drydock = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grf3361mh93lczljmnwafl7gbcp9kk1bjpfwx4ykpd43fzdbfyj"; type = "gem"; }; version = "0.6.9"; }; redis = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rk6mmy3y2jd34llrf591ribl1p54ghkw7m96wrbamy8fwva5zqv"; type = "gem"; }; version = "4.1.0"; }; redis-dump = { - dependencies = ["drydock" "redis" "uri-redis" "yajl-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "drydock" + "redis" + "uri-redis" + "yajl-ruby" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gvip73kgm8xvyjmjkz4b986wni9blsmrnpvp5jrsxjz3g0sqzwg"; type = "gem"; }; version = "0.4.0"; }; uri-redis = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13n8ak41rikkbmml054pir4i1xbgjpmf3dbqihc2kcrgmz3dg81a"; type = "gem"; }; version = "0.4.2"; }; yajl-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16v0w5749qjp13xhjgr2gcsvjv6mf35br7iqwycix1n2h7kfcckf"; type = "gem"; }; diff --git a/pkgs/development/tools/remodel/default.nix b/pkgs/development/tools/remodel/default.nix index 83b32a7dd26f38..c0de834e678e6d 100644 --- a/pkgs/development/tools/remodel/default.nix +++ b/pkgs/development/tools/remodel/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, pkg-config -, openssl -, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + Security, }: rustPlatform.buildRustPackage rec { @@ -24,11 +25,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + ]; meta = with lib; { description = "Roblox file manipulation tool"; diff --git a/pkgs/development/tools/reno/default.nix b/pkgs/development/tools/reno/default.nix index c5d79f3badf681..04990e6d71e935 100644 --- a/pkgs/development/tools/reno/default.nix +++ b/pkgs/development/tools/reno/default.nix @@ -30,7 +30,7 @@ python3Packages.buildPythonApplication rec { dulwich pbr pyyaml - setuptools # required for finding pkg_resources at runtime + setuptools # required for finding pkg_resources at runtime ]; nativeCheckInputs = with python3Packages; [ @@ -79,6 +79,11 @@ python3Packages.buildPythonApplication rec { mainProgram = "reno"; homepage = "https://docs.openstack.org/reno/latest"; license = licenses.asl20; - maintainers = teams.openstack.members ++ (with maintainers; [ drewrisinger guillaumekoenig ]); + maintainers = + teams.openstack.members + ++ (with maintainers; [ + drewrisinger + guillaumekoenig + ]); }; } diff --git a/pkgs/development/tools/replay-io/default.nix b/pkgs/development/tools/replay-io/default.nix index 274ddd98efe157..e5ef210c5fbb22 100644 --- a/pkgs/development/tools/replay-io/default.nix +++ b/pkgs/development/tools/replay-io/default.nix @@ -1,14 +1,35 @@ -{ stdenv, lib, fetchurl, fetchFromGitHub, autoPatchelfHook, makeWrapper, libcxx -, libX11, libXt, libXdamage, glib, gtk3, dbus-glib, openssl, nodejs, zlib -, fetchzip }: -let metadata = lib.importJSON ./meta.json; -in rec { +{ + stdenv, + lib, + fetchurl, + fetchFromGitHub, + autoPatchelfHook, + makeWrapper, + libcxx, + libX11, + libXt, + libXdamage, + glib, + gtk3, + dbus-glib, + openssl, + nodejs, + zlib, + fetchzip, +}: +let + metadata = lib.importJSON ./meta.json; +in +rec { replay-recordreplay = stdenv.mkDerivation rec { pname = "replay-recordreplay"; - version = builtins.head (builtins.match ".*/linux-recordreplay-(.*).tgz" - metadata.recordreplay.url); + version = builtins.head (builtins.match ".*/linux-recordreplay-(.*).tgz" metadata.recordreplay.url); nativeBuildInputs = [ autoPatchelfHook ]; - buildInputs = [ (lib.getLib stdenv.cc.cc) openssl zlib ]; + buildInputs = [ + (lib.getLib stdenv.cc.cc) + openssl + zlib + ]; src = (fetchzip metadata.recordreplay); dontBuild = true; @@ -18,9 +39,7 @@ in rec { runHook postInstall ''; postFixup = '' - patchelf --set-rpath "$(patchelf --print-rpath $out):${ - lib.makeLibraryPath [ openssl ] - }" $out + patchelf --set-rpath "$(patchelf --print-rpath $out):${lib.makeLibraryPath [ openssl ]}" $out ''; meta = with lib; { description = "RecordReplay internal recording library"; @@ -33,11 +52,20 @@ in rec { replay-io = stdenv.mkDerivation rec { pname = "replay-io"; - version = builtins.head - (builtins.match ".*/linux-gecko-(.*).tar.bz2" metadata.replay.url); + version = builtins.head (builtins.match ".*/linux-gecko-(.*).tar.bz2" metadata.replay.url); srcs = fetchurl metadata.replay; - nativeBuildInputs = [ autoPatchelfHook makeWrapper ]; - buildInputs = [ dbus-glib glib gtk3 libX11 libXdamage libXt ]; + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + ]; + buildInputs = [ + dbus-glib + glib + gtk3 + libX11 + libXdamage + libXt + ]; installPhase = '' runHook preInstall mkdir -p $out/opt/replay-io @@ -70,9 +98,11 @@ in rec { replay-node = stdenv.mkDerivation rec { pname = "replay-node"; - version = builtins.head - (builtins.match ".*/linux-node-(.*)" metadata.replay-node.url); - nativeBuildInputs = [ autoPatchelfHook makeWrapper ]; + version = builtins.head (builtins.match ".*/linux-node-(.*)" metadata.replay-node.url); + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + ]; buildInputs = [ (lib.getLib stdenv.cc.cc) ]; src = (fetchurl metadata.replay-node); @@ -104,8 +134,7 @@ in rec { replay-node-cli = stdenv.mkDerivation { pname = "replay-node-cli"; - version = "0.1.7-" + builtins.head - (builtins.match ".*/linux-node-(.*)" metadata.replay-node.url); + version = "0.1.7-" + builtins.head (builtins.match ".*/linux-node-(.*)" metadata.replay-node.url); src = fetchFromGitHub { owner = "RecordReplay"; repo = "replay-node-cli"; @@ -114,7 +143,10 @@ in rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ (lib.getLib stdenv.cc.cc) nodejs ]; + buildInputs = [ + (lib.getLib stdenv.cc.cc) + nodejs + ]; dontBuild = true; installPhase = '' runHook preInstall diff --git a/pkgs/development/tools/rgp/default.nix b/pkgs/development/tools/rgp/default.nix index 85c04d53e80132..aaccbdba360f23 100644 --- a/pkgs/development/tools/rgp/default.nix +++ b/pkgs/development/tools/rgp/default.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, makeWrapper -, fetchurl -, autoPatchelfHook -, dbus -, fontconfig -, freetype -, glib -, libdrm -, libGLU -, libglvnd -, libICE -, libkrb5 -, libSM -, libX11 -, libxcb -, libXi -, libxkbcommon -, ncurses -, wayland -, zlib +{ + lib, + stdenv, + makeWrapper, + fetchurl, + autoPatchelfHook, + dbus, + fontconfig, + freetype, + glib, + libdrm, + libGLU, + libglvnd, + libICE, + libkrb5, + libSM, + libX11, + libxcb, + libXi, + libxkbcommon, + ncurses, + wayland, + zlib, }: let @@ -34,7 +35,10 @@ stdenv.mkDerivation { hash = "sha256-mgIFDStgat4E+67TaSLrcwgWTu7zLf7Nkn6zBlgeVcQ="; }; - nativeBuildInputs = [ makeWrapper autoPatchelfHook ]; + nativeBuildInputs = [ + makeWrapper + autoPatchelfHook + ]; buildInputs = [ dbus diff --git a/pkgs/development/tools/rover/default.nix b/pkgs/development/tools/rover/default.nix index 978935595fecfb..8b2e47d81605ba 100644 --- a/pkgs/development/tools/rover/default.nix +++ b/pkgs/development/tools/rover/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, pkg-config -, rustPlatform -, openssl -, darwin -, stdenv +{ + lib, + fetchFromGitHub, + pkg-config, + rustPlatform, + openssl, + darwin, + stdenv, }: rustPlatform.buildRustPackage rec { @@ -20,13 +21,15 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Rf4kRXYW+WAF1rM7o8PmXBLgp/YyA8y/TqbZL22VOqI="; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - darwin.apple_sdk.frameworks.CoreServices - darwin.apple_sdk.frameworks.SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.CoreServices + darwin.apple_sdk.frameworks.SystemConfiguration + ]; nativeBuildInputs = [ pkg-config @@ -57,6 +60,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "rover"; homepage = "https://www.apollographql.com/docs/rover"; license = licenses.mit; - maintainers = [ maintainers.ivanbrennan maintainers.aaronarinder ]; + maintainers = [ + maintainers.ivanbrennan + maintainers.aaronarinder + ]; }; } diff --git a/pkgs/development/tools/rtags/default.nix b/pkgs/development/tools/rtags/default.nix index b3f9e00a81a5ff..b0f2ea7303312f 100644 --- a/pkgs/development/tools/rtags/default.nix +++ b/pkgs/development/tools/rtags/default.nix @@ -1,12 +1,36 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, cmake, llvmPackages, openssl, apple_sdk, emacs, pkg-config }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, + llvmPackages, + openssl, + apple_sdk, + emacs, + pkg-config, +}: stdenv.mkDerivation rec { pname = "rtags"; version = "2.38"; - nativeBuildInputs = [ cmake pkg-config llvmPackages.llvm.dev ]; - buildInputs = [ llvmPackages.llvm llvmPackages.libclang openssl emacs ] + nativeBuildInputs = [ + cmake + pkg-config + llvmPackages.llvm.dev + ]; + buildInputs = + [ + llvmPackages.llvm + llvmPackages.libclang + openssl + emacs + ] ++ lib.optionals stdenv.cc.isGNU [ llvmPackages.clang-unwrapped ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ apple_sdk.libs.xpc apple_sdk.frameworks.CoreServices ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + apple_sdk.libs.xpc + apple_sdk.frameworks.CoreServices + ]; src = fetchFromGitHub { owner = "andersbakken"; @@ -23,11 +47,13 @@ stdenv.mkDerivation rec { # This should be fixed with the next verison bump # https://github.com/Andersbakken/rtags/issues/1411 - patches = [(fetchpatch { - name = "define-obsolete-function-alias.patch"; - url = "https://github.com/Andersbakken/rtags/commit/63f18acb21e664fd92fbc19465f0b5df085b5e93.patch"; - sha256 = "sha256-dmEPtnk8Pylmf5479ovHKItRZ+tJuOWuYOQbWB/si/Y="; - })]; + patches = [ + (fetchpatch { + name = "define-obsolete-function-alias.patch"; + url = "https://github.com/Andersbakken/rtags/commit/63f18acb21e664fd92fbc19465f0b5df085b5e93.patch"; + sha256 = "sha256-dmEPtnk8Pylmf5479ovHKItRZ+tJuOWuYOQbWB/si/Y="; + }) + ]; preConfigure = '' export LIBCLANG_CXXFLAGS="-isystem ${llvmPackages.clang.cc}/include $(llvm-config --cxxflags) -fexceptions" \ diff --git a/pkgs/development/tools/rubyfmt/default.nix b/pkgs/development/tools/rubyfmt/default.nix index 480826ab55d0bd..f58e56a35f03fe 100644 --- a/pkgs/development/tools/rubyfmt/default.nix +++ b/pkgs/development/tools/rubyfmt/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, autoconf -, automake -, bison -, ruby -, zlib -, readline -, libiconv -, libobjc -, libunwind -, libxcrypt -, libyaml -, rust-jemalloc-sys-unprefixed -, Foundation -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + autoconf, + automake, + bison, + ruby, + zlib, + readline, + libiconv, + libobjc, + libunwind, + libxcrypt, + libyaml, + rust-jemalloc-sys-unprefixed, + Foundation, + Security, }: rustPlatform.buildRustPackage rec { @@ -37,19 +38,21 @@ rustPlatform.buildRustPackage rec { ruby ]; - buildInputs = [ - zlib - libxcrypt - libyaml - rust-jemalloc-sys-unprefixed - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - readline - libiconv - libobjc - libunwind - Foundation - Security - ]; + buildInputs = + [ + zlib + libxcrypt + libyaml + rust-jemalloc-sys-unprefixed + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + readline + libiconv + libobjc + libunwind + Foundation + Security + ]; preConfigure = '' pushd librubyfmt/ruby_checkout diff --git a/pkgs/development/tools/rufo/default.nix b/pkgs/development/tools/rufo/default.nix index f198ce36d91b29..ebd32f78be7bb7 100644 --- a/pkgs/development/tools/rufo/default.nix +++ b/pkgs/development/tools/rufo/default.nix @@ -1,4 +1,8 @@ -{ bundlerApp, bundlerUpdateScript, lib }: +{ + bundlerApp, + bundlerUpdateScript, + lib, +}: bundlerApp { pname = "rufo"; diff --git a/pkgs/development/tools/rufo/gemset.nix b/pkgs/development/tools/rufo/gemset.nix index 36b2d87637a9d7..18b3414d4be9be 100644 --- a/pkgs/development/tools/rufo/gemset.nix +++ b/pkgs/development/tools/rufo/gemset.nix @@ -1,9 +1,9 @@ { rufo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rqq6mf7fvwvc9m3d5w5ysch3h7z4ml1vvdvy26064fb6lrnn5ai"; type = "gem"; }; diff --git a/pkgs/development/tools/rust/bindgen/default.nix b/pkgs/development/tools/rust/bindgen/default.nix index 1e2af744f9bceb..c6e6ec12f9d0a4 100644 --- a/pkgs/development/tools/rust/bindgen/default.nix +++ b/pkgs/development/tools/rust/bindgen/default.nix @@ -1,47 +1,57 @@ -{ lib, rust-bindgen-unwrapped, zlib, bash, runCommand, runCommandCC }: +{ + lib, + rust-bindgen-unwrapped, + zlib, + bash, + runCommand, + runCommandCC, +}: let clang = rust-bindgen-unwrapped.clang; - self = runCommand "rust-bindgen-${rust-bindgen-unwrapped.version}" - { - #for substituteAll - inherit bash; - unwrapped = rust-bindgen-unwrapped; - libclang = (lib.getLib clang.cc); - meta = rust-bindgen-unwrapped.meta // { - longDescription = rust-bindgen-unwrapped.meta.longDescription + '' - This version of bindgen is wrapped with the required compiler flags - required to find the c and c++ standard library, as well as the libraries - specified in the buildInputs of your derivation. - ''; - }; - passthru.tests = { - simple-c = runCommandCC "simple-c-bindgen-tests" { } '' - echo '#include ' > a.c - ${self}/bin/bindgen a.c --allowlist-function atoi | tee output - grep atoi output - touch $out - ''; - simple-cpp = runCommandCC "simple-cpp-bindgen-tests" { } '' - echo '#include ' > a.cpp - ${self}/bin/bindgen a.cpp --allowlist-function erf -- -xc++ | tee output - grep erf output - touch $out - ''; - with-lib = runCommandCC "zlib-bindgen-tests" { buildInputs = [ zlib ]; } '' - echo '#include ' > a.c - ${self}/bin/bindgen a.c --allowlist-function compress | tee output - grep compress output - touch $out - ''; - }; - } - # if you modify the logic to find the right clang flags, also modify rustPlatform.bindgenHook - '' - mkdir -p $out/bin - export cincludes="$(< ${clang}/nix-support/cc-cflags) $(< ${clang}/nix-support/libc-cflags)" - export cxxincludes="$(< ${clang}/nix-support/libcxx-cxxflags)" - substituteAll ${./wrapper.sh} $out/bin/bindgen - chmod +x $out/bin/bindgen - ''; + self = + runCommand "rust-bindgen-${rust-bindgen-unwrapped.version}" + { + #for substituteAll + inherit bash; + unwrapped = rust-bindgen-unwrapped; + libclang = (lib.getLib clang.cc); + meta = rust-bindgen-unwrapped.meta // { + longDescription = + rust-bindgen-unwrapped.meta.longDescription + + '' + This version of bindgen is wrapped with the required compiler flags + required to find the c and c++ standard library, as well as the libraries + specified in the buildInputs of your derivation. + ''; + }; + passthru.tests = { + simple-c = runCommandCC "simple-c-bindgen-tests" { } '' + echo '#include ' > a.c + ${self}/bin/bindgen a.c --allowlist-function atoi | tee output + grep atoi output + touch $out + ''; + simple-cpp = runCommandCC "simple-cpp-bindgen-tests" { } '' + echo '#include ' > a.cpp + ${self}/bin/bindgen a.cpp --allowlist-function erf -- -xc++ | tee output + grep erf output + touch $out + ''; + with-lib = runCommandCC "zlib-bindgen-tests" { buildInputs = [ zlib ]; } '' + echo '#include ' > a.c + ${self}/bin/bindgen a.c --allowlist-function compress | tee output + grep compress output + touch $out + ''; + }; + } + # if you modify the logic to find the right clang flags, also modify rustPlatform.bindgenHook + '' + mkdir -p $out/bin + export cincludes="$(< ${clang}/nix-support/cc-cflags) $(< ${clang}/nix-support/libc-cflags)" + export cxxincludes="$(< ${clang}/nix-support/libcxx-cxxflags)" + substituteAll ${./wrapper.sh} $out/bin/bindgen + chmod +x $out/bin/bindgen + ''; in self diff --git a/pkgs/development/tools/rust/cargo-asm/default.nix b/pkgs/development/tools/rust/cargo-asm/default.nix index 4e8cecb4a338c8..476eb57c4341bb 100644 --- a/pkgs/development/tools/rust/cargo-asm/default.nix +++ b/pkgs/development/tools/rust/cargo-asm/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, +}: rustPlatform.buildRustPackage rec { pname = "cargo-asm"; diff --git a/pkgs/development/tools/rust/cargo-bazel/default.nix b/pkgs/development/tools/rust/cargo-bazel/default.nix index 151f155f9ee140..35db4be2116bee 100644 --- a/pkgs/development/tools/rust/cargo-bazel/default.nix +++ b/pkgs/development/tools/rust/cargo-bazel/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchCrate -, rustPlatform -, Security +{ + lib, + stdenv, + fetchCrate, + rustPlatform, + Security, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/development/tools/rust/cargo-c/default.nix b/pkgs/development/tools/rust/cargo-c/default.nix index 3dd89aefe7acfd..e100e2a09998f9 100644 --- a/pkgs/development/tools/rust/cargo-c/default.nix +++ b/pkgs/development/tools/rust/cargo-c/default.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, curl -, openssl -, stdenv -, CoreFoundation -, libiconv -, Security -, rav1e +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + curl, + openssl, + stdenv, + CoreFoundation, + libiconv, + Security, + rav1e, }: rustPlatform.buildRustPackage rec { @@ -24,12 +25,20 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-UfhIz87s0CLUDbIpWMPzGQ7qVmh14GuiFoquauSbTOw="; - nativeBuildInputs = [ pkg-config (lib.getDev curl) ]; - buildInputs = [ openssl curl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreFoundation - libiconv - Security + nativeBuildInputs = [ + pkg-config + (lib.getDev curl) ]; + buildInputs = + [ + openssl + curl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreFoundation + libiconv + Security + ]; # Ensure that we are avoiding build of the curl vendored in curl-sys doInstallCheck = stdenv.hostPlatform.libc == "glibc"; diff --git a/pkgs/development/tools/rust/cargo-cache/default.nix b/pkgs/development/tools/rust/cargo-cache/default.nix index fc5da4b5b1cbe5..7b8b60ad4125ff 100644 --- a/pkgs/development/tools/rust/cargo-cache/default.nix +++ b/pkgs/development/tools/rust/cargo-cache/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, libiconv, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + libiconv, + Security, +}: rustPlatform.buildRustPackage rec { pname = "cargo-cache"; @@ -13,7 +20,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-275QREIcncgBk4ah/CivSz5N2m6s/XPCfp6JGChpr38="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv Security ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Security + ]; checkFlags = [ "offline_tests" ]; @@ -21,7 +31,13 @@ rustPlatform.buildRustPackage rec { description = "Manage cargo cache (\${CARGO_HOME}, ~/.cargo/), print sizes of dirs and remove dirs selectively"; mainProgram = "cargo-cache"; homepage = "https://github.com/matthiaskrgr/cargo-cache"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ Br1ght0ne matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + Br1ght0ne + matthiasbeyer + ]; }; } diff --git a/pkgs/development/tools/rust/cargo-clone/default.nix b/pkgs/development/tools/rust/cargo-clone/default.nix index ee119146feaf58..a14d9f4431b8e7 100644 --- a/pkgs/development/tools/rust/cargo-clone/default.nix +++ b/pkgs/development/tools/rust/cargo-clone/default.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, CoreServices -, Security -, SystemConfiguration +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + CoreServices, + Security, + SystemConfiguration, }: rustPlatform.buildRustPackage rec { @@ -24,11 +25,13 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreServices - Security - SystemConfiguration - ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + Security + SystemConfiguration + ]; # requires internet access doCheck = false; @@ -38,7 +41,14 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-clone"; homepage = "https://github.com/janlikar/cargo-clone"; changelog = "https://github.com/janlikar/cargo-clone/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 mit ]; - maintainers = with maintainers; [ figsoda matthiasbeyer janlikar ]; + license = with licenses; [ + asl20 + mit + ]; + maintainers = with maintainers; [ + figsoda + matthiasbeyer + janlikar + ]; }; } diff --git a/pkgs/development/tools/rust/cargo-codspeed/default.nix b/pkgs/development/tools/rust/cargo-codspeed/default.nix index ce20d409df2882..2d162dd2ef3543 100644 --- a/pkgs/development/tools/rust/cargo-codspeed/default.nix +++ b/pkgs/development/tools/rust/cargo-codspeed/default.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, curl -, pkg-config -, libgit2 -, openssl -, zlib -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + curl, + pkg-config, + libgit2, + openssl, + zlib, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -28,14 +29,16 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - curl - libgit2 - openssl - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.Security - ]; + buildInputs = + [ + curl + libgit2 + openssl + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.Security + ]; cargoBuildFlags = [ "-p=cargo-codspeed" ]; cargoTestFlags = cargoBuildFlags; @@ -48,7 +51,10 @@ rustPlatform.buildRustPackage rec { description = "Cargo extension to build & run your codspeed benchmarks"; homepage = "https://github.com/CodSpeedHQ/codspeed-rust"; changelog = "https://github.com/CodSpeedHQ/codspeed-rust/releases/tag/${src.rev}"; - license = with licenses; [ mit asl20 ]; + license = with licenses; [ + mit + asl20 + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "cargo-codspeed"; }; diff --git a/pkgs/development/tools/rust/cargo-cyclonedx/default.nix b/pkgs/development/tools/rust/cargo-cyclonedx/default.nix index f8fd99b30dffa5..59f21853a23b7b 100644 --- a/pkgs/development/tools/rust/cargo-cyclonedx/default.nix +++ b/pkgs/development/tools/rust/cargo-cyclonedx/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, Security -, SystemConfiguration -, CoreFoundation -, curl +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + Security, + SystemConfiguration, + CoreFoundation, + curl, }: rustPlatform.buildRustPackage rec { @@ -27,14 +28,16 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - SystemConfiguration - CoreFoundation - curl - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + CoreFoundation + curl + ]; meta = with lib; { description = "Creates CycloneDX Software Bill of Materials (SBOM) from Rust (Cargo) projects"; diff --git a/pkgs/development/tools/rust/cargo-edit/default.nix b/pkgs/development/tools/rust/cargo-edit/default.nix index f42607332d711d..f97543a88bc599 100644 --- a/pkgs/development/tools/rust/cargo-edit/default.nix +++ b/pkgs/development/tools/rust/cargo-edit/default.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, zlib -, stdenv -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + zlib, + stdenv, + Security, }: rustPlatform.buildRustPackage rec { @@ -23,9 +24,14 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl zlib ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - ]; + buildInputs = + [ + openssl + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + ]; doCheck = false; # integration tests depend on changing cargo config @@ -33,7 +39,16 @@ rustPlatform.buildRustPackage rec { description = "Utility for managing cargo dependencies from the command line"; homepage = "https://github.com/killercup/cargo-edit"; changelog = "https://github.com/killercup/cargo-edit/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ Br1ght0ne figsoda gerschtli jb55 killercup ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + Br1ght0ne + figsoda + gerschtli + jb55 + killercup + ]; }; } diff --git a/pkgs/development/tools/rust/cargo-flamegraph/default.nix b/pkgs/development/tools/rust/cargo-flamegraph/default.nix index aca8e713e6e3f8..e440b9074504ad 100644 --- a/pkgs/development/tools/rust/cargo-flamegraph/default.nix +++ b/pkgs/development/tools/rust/cargo-flamegraph/default.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, makeWrapper, perf, nix-update-script -, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + makeWrapper, + perf, + nix-update-script, + Security, }: rustPlatform.buildRustPackage rec { @@ -32,7 +39,13 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Easy flamegraphs for Rust projects and everything else, without Perl or pipes <3"; homepage = "https://github.com/flamegraph-rs/flamegraph"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ killercup matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + killercup + matthiasbeyer + ]; }; } diff --git a/pkgs/development/tools/rust/cargo-fund/default.nix b/pkgs/development/tools/rust/cargo-fund/default.nix index 23d13a8841ae75..50e3b7db2bf09c 100644 --- a/pkgs/development/tools/rust/cargo-fund/default.nix +++ b/pkgs/development/tools/rust/cargo-fund/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, rustPlatform, Security, curl, openssl, libiconv }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + rustPlatform, + Security, + curl, + openssl, + libiconv, +}: rustPlatform.buildRustPackage rec { pname = "cargo-fund"; @@ -18,13 +28,22 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security libiconv curl ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + libiconv + curl + ]; meta = with lib; { description = "Discover funding links for your project's dependencies"; mainProgram = "cargo-fund"; homepage = "https://github.com/acfoltzer/cargo-fund"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ johntitor ]; }; } diff --git a/pkgs/development/tools/rust/cargo-hf2/default.nix b/pkgs/development/tools/rust/cargo-hf2/default.nix index 8859fa605a4290..08544400fc46e7 100644 --- a/pkgs/development/tools/rust/cargo-hf2/default.nix +++ b/pkgs/development/tools/rust/cargo-hf2/default.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, libusb1 -, stdenv -, AppKit +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + libusb1, + stdenv, + AppKit, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/development/tools/rust/cargo-inspect/default.nix b/pkgs/development/tools/rust/cargo-inspect/default.nix index b1126b42f24800..47f236d0b525a7 100644 --- a/pkgs/development/tools/rust/cargo-inspect/default.nix +++ b/pkgs/development/tools/rust/cargo-inspect/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, rustPlatform, fetchFromGitHub, Security }: +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + Security, +}: rustPlatform.buildRustPackage rec { pname = "cargo-inspect"; @@ -19,7 +25,13 @@ rustPlatform.buildRustPackage rec { description = "See what Rust is doing behind the curtains"; mainProgram = "cargo-inspect"; homepage = "https://github.com/mre/cargo-inspect"; - license = with licenses; [ mit asl20 ]; - maintainers = with maintainers; [ minijackson matthiasbeyer ]; + license = with licenses; [ + mit + asl20 + ]; + maintainers = with maintainers; [ + minijackson + matthiasbeyer + ]; }; } diff --git a/pkgs/development/tools/rust/cargo-msrv/default.nix b/pkgs/development/tools/rust/cargo-msrv/default.nix index ec0f9331df7bfc..4a1ff0908d5949 100644 --- a/pkgs/development/tools/rust/cargo-msrv/default.nix +++ b/pkgs/development/tools/rust/cargo-msrv/default.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, rustup -, openssl -, stdenv -, libiconv -, Security -, makeWrapper -, gitUpdater +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + rustup, + openssl, + stdenv, + libiconv, + Security, + makeWrapper, + gitUpdater, }: rustPlatform.buildRustPackage rec { @@ -34,11 +35,19 @@ rustPlatform.buildRustPackage rec { # Integration tests fail doCheck = false; - buildInputs = if stdenv.hostPlatform.isDarwin - then [ libiconv Security ] - else [ openssl ]; + buildInputs = + if stdenv.hostPlatform.isDarwin then + [ + libiconv + Security + ] + else + [ openssl ]; - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; # Depends at run-time on having rustup in PATH postInstall = '' @@ -49,7 +58,13 @@ rustPlatform.buildRustPackage rec { description = "Cargo subcommand \"msrv\": assists with finding your minimum supported Rust version (MSRV)"; mainProgram = "cargo-msrv"; homepage = "https://github.com/foresterre/cargo-msrv"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ otavio matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + otavio + matthiasbeyer + ]; }; } diff --git a/pkgs/development/tools/rust/cargo-ndk/default.nix b/pkgs/development/tools/rust/cargo-ndk/default.nix index 8e38d601c75226..c0231216b4bad8 100644 --- a/pkgs/development/tools/rust/cargo-ndk/default.nix +++ b/pkgs/development/tools/rust/cargo-ndk/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, CoreGraphics -, Foundation +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + CoreGraphics, + Foundation, }: rustPlatform.buildRustPackage rec { @@ -28,8 +29,10 @@ rustPlatform.buildRustPackage rec { description = "Cargo extension for building Android NDK projects"; mainProgram = "cargo-ndk"; homepage = "https://github.com/bbqsrc/cargo-ndk"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ mglolenstine ]; }; } - diff --git a/pkgs/development/tools/rust/cargo-outdated/default.nix b/pkgs/development/tools/rust/cargo-outdated/default.nix index 41003605dab939..876f01215cbf4b 100644 --- a/pkgs/development/tools/rust/cargo-outdated/default.nix +++ b/pkgs/development/tools/rust/cargo-outdated/default.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchCrate -, pkg-config -, openssl -, stdenv -, curl -, CoreFoundation -, CoreServices -, Security -, SystemConfiguration +{ + lib, + rustPlatform, + fetchCrate, + pkg-config, + openssl, + stdenv, + curl, + CoreFoundation, + CoreServices, + Security, + SystemConfiguration, }: rustPlatform.buildRustPackage rec { @@ -24,20 +25,28 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - curl - CoreFoundation - CoreServices - Security - SystemConfiguration - ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + curl + CoreFoundation + CoreServices + Security + SystemConfiguration + ]; meta = with lib; { description = "Cargo subcommand for displaying when Rust dependencies are out of date"; mainProgram = "cargo-outdated"; homepage = "https://github.com/kbknapp/cargo-outdated"; changelog = "https://github.com/kbknapp/cargo-outdated/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ ivan matthiasbeyer ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + ivan + matthiasbeyer + ]; }; } diff --git a/pkgs/development/tools/rust/cargo-pgrx/buildPgrxExtension.nix b/pkgs/development/tools/rust/cargo-pgrx/buildPgrxExtension.nix index 785a500c3917ec..504ad1a0bbdff8 100644 --- a/pkgs/development/tools/rust/cargo-pgrx/buildPgrxExtension.nix +++ b/pkgs/development/tools/rust/cargo-pgrx/buildPgrxExtension.nix @@ -27,13 +27,14 @@ # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE # SOFTWARE. -{ lib -, cargo-pgrx -, pkg-config -, rustPlatform -, stdenv -, Security -, writeShellScriptBin +{ + lib, + cargo-pgrx, + pkg-config, + rustPlatform, + stdenv, + Security, + writeShellScriptBin, }: # The idea behind: Use it mostly like rustPlatform.buildRustPackage and so @@ -47,26 +48,31 @@ # unnecessary and heavy dependency. If you set this to true, you also # have to add `rustfmt` to `nativeBuildInputs`. -{ buildAndTestSubdir ? null -, buildType ? "release" -, buildFeatures ? [ ] -, cargoBuildFlags ? [ ] -, postgresql -# cargo-pgrx calls rustfmt on generated bindings, this is not strictly necessary, so we avoid the -# dependency here. Set to false and provide rustfmt in nativeBuildInputs, if you need it, e.g. -# if you include the generated code in the output via postInstall. -, useFakeRustfmt ? true -, usePgTestCheckFeature ? true -, ... -} @ args: +{ + buildAndTestSubdir ? null, + buildType ? "release", + buildFeatures ? [ ], + cargoBuildFlags ? [ ], + postgresql, + # cargo-pgrx calls rustfmt on generated bindings, this is not strictly necessary, so we avoid the + # dependency here. Set to false and provide rustfmt in nativeBuildInputs, if you need it, e.g. + # if you include the generated code in the output via postInstall. + useFakeRustfmt ? true, + usePgTestCheckFeature ? true, + ... +}@args: let - rustfmtInNativeBuildInputs = lib.lists.any (dep: lib.getName dep == "rustfmt") (args.nativeBuildInputs or []); + rustfmtInNativeBuildInputs = lib.lists.any (dep: lib.getName dep == "rustfmt") ( + args.nativeBuildInputs or [ ] + ); in -assert lib.asserts.assertMsg ((args.installPhase or "") == "") - "buildPgrxExtensions overwrites the installPhase, so providing one does nothing"; -assert lib.asserts.assertMsg ((args.buildPhase or "") == "") - "buildPgrxExtensions overwrites the buildPhase, so providing one does nothing"; +assert lib.asserts.assertMsg ( + (args.installPhase or "") == "" +) "buildPgrxExtensions overwrites the installPhase, so providing one does nothing"; +assert lib.asserts.assertMsg ( + (args.buildPhase or "") == "" +) "buildPgrxExtensions overwrites the buildPhase, so providing one does nothing"; assert lib.asserts.assertMsg (useFakeRustfmt -> !rustfmtInNativeBuildInputs) "The parameter useFakeRustfmt is set to true, but rustfmt is included in nativeBuildInputs. Either set useFakeRustfmt to false or remove rustfmt from nativeBuildInputs."; assert lib.asserts.assertMsg (!useFakeRustfmt -> rustfmtInNativeBuildInputs) @@ -75,7 +81,7 @@ assert lib.asserts.assertMsg (!useFakeRustfmt -> rustfmtInNativeBuildInputs) let fakeRustfmt = writeShellScriptBin "rustfmt" '' exit 0 - ''; + ''; maybeDebugFlag = lib.optionalString (buildType != "release") "--debug"; maybeEnterBuildAndTestSubdir = lib.optionalString (buildAndTestSubdir != null) '' export CARGO_TARGET_DIR="$(pwd)/target" @@ -103,19 +109,26 @@ let pg_ctl stop ''; - argsForBuildRustPackage = builtins.removeAttrs args [ "postgresql" "useFakeRustfmt" "usePgTestCheckFeature" ]; + argsForBuildRustPackage = builtins.removeAttrs args [ + "postgresql" + "useFakeRustfmt" + "usePgTestCheckFeature" + ]; # so we don't accidentally `(rustPlatform.buildRustPackage argsForBuildRustPackage) // { ... }` because # we forgot parentheses finalArgs = argsForBuildRustPackage // { buildInputs = (args.buildInputs or [ ]) ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; - nativeBuildInputs = (args.nativeBuildInputs or [ ]) ++ [ - cargo-pgrx - postgresql - pkg-config - rustPlatform.bindgenHook - ] ++ lib.optionals useFakeRustfmt [ fakeRustfmt ]; + nativeBuildInputs = + (args.nativeBuildInputs or [ ]) + ++ [ + cargo-pgrx + postgresql + pkg-config + rustPlatform.bindgenHook + ] + ++ lib.optionals useFakeRustfmt [ fakeRustfmt ]; buildPhase = '' runHook preBuild @@ -161,7 +174,10 @@ let RUST_BACKTRACE = "full"; checkNoDefaultFeatures = true; - checkFeatures = (args.checkFeatures or [ ]) ++ (lib.optionals usePgTestCheckFeature [ "pg_test" ]) ++ [ "pg${pgrxPostgresMajor}" ]; + checkFeatures = + (args.checkFeatures or [ ]) + ++ (lib.optionals usePgTestCheckFeature [ "pg_test" ]) + ++ [ "pg${pgrxPostgresMajor}" ]; }; in rustPlatform.buildRustPackage finalArgs diff --git a/pkgs/development/tools/rust/cargo-udeps/default.nix b/pkgs/development/tools/rust/cargo-udeps/default.nix index cb1321e451e57d..1ad27f4a9b99d9 100644 --- a/pkgs/development/tools/rust/cargo-udeps/default.nix +++ b/pkgs/development/tools/rust/cargo-udeps/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, pkg-config, openssl, CoreServices, Security, libiconv, SystemConfiguration }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + CoreServices, + Security, + libiconv, + SystemConfiguration, +}: rustPlatform.buildRustPackage rec { pname = "cargo-udeps"; @@ -16,8 +27,14 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; # TODO figure out how to use provided curl instead of compiling curl from curl-sys - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices Security libiconv SystemConfiguration ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + Security + libiconv + SystemConfiguration + ]; # Requires network access doCheck = false; @@ -26,7 +43,10 @@ rustPlatform.buildRustPackage rec { description = "Find unused dependencies in Cargo.toml"; homepage = "https://github.com/est31/cargo-udeps"; license = licenses.mit; - maintainers = with maintainers; [ b4dm4n matthiasbeyer ]; + maintainers = with maintainers; [ + b4dm4n + matthiasbeyer + ]; mainProgram = "cargo-udeps"; }; } diff --git a/pkgs/development/tools/rust/cargo-vet/default.nix b/pkgs/development/tools/rust/cargo-vet/default.nix index 69c5d69d2c69fb..7f88be5ddfbf08 100644 --- a/pkgs/development/tools/rust/cargo-vet/default.nix +++ b/pkgs/development/tools/rust/cargo-vet/default.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, stdenv, Security }: +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + Security, +}: rustPlatform.buildRustPackage rec { pname = "cargo-vet"; @@ -24,7 +30,13 @@ rustPlatform.buildRustPackage rec { description = "Tool to help projects ensure that third-party Rust dependencies have been audited by a trusted source"; mainProgram = "cargo-vet"; homepage = "https://mozilla.github.io/cargo-vet"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ figsoda jk ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + figsoda + jk + ]; }; } diff --git a/pkgs/development/tools/rust/cargo-watch/default.nix b/pkgs/development/tools/rust/cargo-watch/default.nix index 91e7fea0fa1076..0ba5fd8b450fe9 100644 --- a/pkgs/development/tools/rust/cargo-watch/default.nix +++ b/pkgs/development/tools/rust/cargo-watch/default.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, rustPlatform -, fetchFromGitHub -, Cocoa -, Foundation +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + Cocoa, + Foundation, }: rustPlatform.buildRustPackage rec { @@ -19,9 +20,15 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-oqGc5haN8Jyi0eQf8egrRXWxi0RGVdIFhpGKgmFB8DI="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Foundation Cocoa ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + Foundation + Cocoa + ]; - NIX_LDFLAGS = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ "-framework" "AppKit" ]; + NIX_LDFLAGS = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + "-framework" + "AppKit" + ]; # `test with_cargo` tries to call cargo-watch as a cargo subcommand # (calling cargo-watch with command `cargo watch`) @@ -34,6 +41,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "cargo-watch"; homepage = "https://github.com/watchexec/cargo-watch"; license = licenses.cc0; - maintainers = with maintainers; [ xrelkd ivan matthiasbeyer ]; + maintainers = with maintainers; [ + xrelkd + ivan + matthiasbeyer + ]; }; } diff --git a/pkgs/development/tools/rust/cargo-whatfeatures/default.nix b/pkgs/development/tools/rust/cargo-whatfeatures/default.nix index 42b3078f4e947b..ad29ce3774975e 100644 --- a/pkgs/development/tools/rust/cargo-whatfeatures/default.nix +++ b/pkgs/development/tools/rust/cargo-whatfeatures/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, pkg-config, openssl, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + Security, +}: rustPlatform.buildRustPackage rec { pname = "cargo-whatfeatures"; @@ -15,14 +23,19 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; + buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; meta = with lib; { description = "Simple cargo plugin to get a list of features for a specific crate"; mainProgram = "cargo-whatfeatures"; homepage = "https://github.com/museun/cargo-whatfeatures"; - license = with licenses; [ mit asl20 ]; - maintainers = with maintainers; [ ivan-babrou matthiasbeyer ]; + license = with licenses; [ + mit + asl20 + ]; + maintainers = with maintainers; [ + ivan-babrou + matthiasbeyer + ]; }; } diff --git a/pkgs/development/tools/rust/duckscript/default.nix b/pkgs/development/tools/rust/duckscript/default.nix index bfafef5c70c1a6..adebe70d878ab4 100644 --- a/pkgs/development/tools/rust/duckscript/default.nix +++ b/pkgs/development/tools/rust/duckscript/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchCrate -, rustPlatform -, Security -, openssl -, pkg-config -, SystemConfiguration -, libiconv +{ + lib, + stdenv, + fetchCrate, + rustPlatform, + Security, + openssl, + pkg-config, + SystemConfiguration, + libiconv, }: rustPlatform.buildRustPackage rec { @@ -20,8 +21,13 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security SystemConfiguration libiconv ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + libiconv + ]; cargoHash = "sha256-TX/Xi57fn85GjHc74icxhsQ6n7FwqzGIr3Qoc2o681E="; diff --git a/pkgs/development/tools/rust/humility/default.nix b/pkgs/development/tools/rust/humility/default.nix index 5486d0785233e6..b443575175651a 100644 --- a/pkgs/development/tools/rust/humility/default.nix +++ b/pkgs/development/tools/rust/humility/default.nix @@ -1,22 +1,31 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, libusb1 -, libftdi -, cargo-readme -, pkg-config -, AppKit +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + libusb1, + libftdi, + cargo-readme, + pkg-config, + AppKit, }: rustPlatform.buildRustPackage rec { pname = "humility"; version = "unstable-2023-11-08"; - nativeBuildInputs = [ pkg-config cargo-readme ]; - buildInputs = [ libusb1 libftdi ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit + nativeBuildInputs = [ + pkg-config + cargo-readme ]; + buildInputs = + [ + libusb1 + libftdi + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + ]; src = fetchFromGitHub { owner = "oxidecomputer"; diff --git a/pkgs/development/tools/rust/rustup-toolchain-install-master/default.nix b/pkgs/development/tools/rust/rustup-toolchain-install-master/default.nix index f5dacb999a685a..5f531bff222ee9 100644 --- a/pkgs/development/tools/rust/rustup-toolchain-install-master/default.nix +++ b/pkgs/development/tools/rust/rustup-toolchain-install-master/default.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, runCommand -, stdenv -, patchelf -, zlib -, pkg-config -, openssl -, xz -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + runCommand, + stdenv, + patchelf, + zlib, + pkg-config, + openssl, + xz, + Security, }: rustPlatform.buildRustPackage rec { @@ -28,28 +29,32 @@ rustPlatform.buildRustPackage rec { patches = let - patchelfPatch = runCommand "0001-dynamically-patchelf-binaries.patch" { - CC = stdenv.cc; - patchelf = patchelf; - libPath = "$ORIGIN/../lib:${lib.makeLibraryPath [ zlib ]}"; - } - '' - export dynamicLinker=$(cat $CC/nix-support/dynamic-linker) - substitute ${./0001-dynamically-patchelf-binaries.patch} $out \ - --subst-var patchelf \ - --subst-var dynamicLinker \ - --subst-var libPath - ''; + patchelfPatch = + runCommand "0001-dynamically-patchelf-binaries.patch" + { + CC = stdenv.cc; + patchelf = patchelf; + libPath = "$ORIGIN/../lib:${lib.makeLibraryPath [ zlib ]}"; + } + '' + export dynamicLinker=$(cat $CC/nix-support/dynamic-linker) + substitute ${./0001-dynamically-patchelf-binaries.patch} $out \ + --subst-var patchelf \ + --subst-var dynamicLinker \ + --subst-var libPath + ''; in lib.optionals stdenv.hostPlatform.isLinux [ patchelfPatch ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - openssl - xz - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - ]; + buildInputs = + [ + openssl + xz + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + ]; # update Cargo.lock to work with openssl 3 postPatch = '' diff --git a/pkgs/development/tools/rust/rustup/default.nix b/pkgs/development/tools/rust/rustup/default.nix index 4225b2a4d29ef7..e0de754928fc06 100644 --- a/pkgs/development/tools/rust/rustup/default.nix +++ b/pkgs/development/tools/rust/rustup/default.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, runCommand -, patchelf -, fetchFromGitHub -, rustPlatform -, makeBinaryWrapper -, pkg-config -, openssl -, curl -, zlib -, Security -, CoreServices -, libiconv -, xz +{ + stdenv, + lib, + runCommand, + patchelf, + fetchFromGitHub, + rustPlatform, + makeBinaryWrapper, + pkg-config, + openssl, + curl, + zlib, + Security, + CoreServices, + libiconv, + xz, }: let @@ -34,12 +35,22 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-iQoMPV97V9WJqT+qVtNpQtW5g+Jyl+U2uA+JEoRYTQA="; - nativeBuildInputs = [ makeBinaryWrapper pkg-config ]; + nativeBuildInputs = [ + makeBinaryWrapper + pkg-config + ]; - buildInputs = [ - (curl.override { inherit openssl; }) - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices Security libiconv xz ]; + buildInputs = + [ + (curl.override { inherit openssl; }) + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + Security + libiconv + xz + ]; buildFeatures = [ "no-self-update" ]; @@ -51,13 +62,15 @@ rustPlatform.buildRustPackage rec { CC = stdenv.cc; patchelf = patchelf; libPath = "${libPath}"; - } '' - export dynamicLinker=$(cat $CC/nix-support/dynamic-linker) - substitute ${./0001-dynamically-patchelf-binaries.patch} $out \ - --subst-var patchelf \ - --subst-var dynamicLinker \ - --subst-var libPath - '') + } + '' + export dynamicLinker=$(cat $CC/nix-support/dynamic-linker) + substitute ${./0001-dynamically-patchelf-binaries.patch} $out \ + --subst-var patchelf \ + --subst-var dynamicLinker \ + --subst-var libPath + '' + ) ]; # Random tests fail nondeterministically on macOS. @@ -115,14 +128,23 @@ rustPlatform.buildRustPackage rec { ''; env = lib.optionalAttrs (pname == "rustup") { - inherit (stdenv.cc.bintools) expandResponseParams shell suffixSalt wrapperName coreutils_bin; + inherit (stdenv.cc.bintools) + expandResponseParams + shell + suffixSalt + wrapperName + coreutils_bin + ; hardening_unsupported_flags = ""; }; meta = with lib; { description = "Rust toolchain installer"; homepage = "https://www.rustup.rs/"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = [ maintainers.mic92 ]; }; } diff --git a/pkgs/development/tools/rust/sqlx-cli/default.nix b/pkgs/development/tools/rust/sqlx-cli/default.nix index 71f6b2b9ddcd78..12891edf0b6866 100644 --- a/pkgs/development/tools/rust/sqlx-cli/default.nix +++ b/pkgs/development/tools/rust/sqlx-cli/default.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, openssl -, libiconv -, testers -, sqlx-cli -, CoreFoundation -, Security -, SystemConfiguration -, nix-update-script +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + openssl, + libiconv, + testers, + sqlx-cli, + CoreFoundation, + Security, + SystemConfiguration, + nix-update-script, }: rustPlatform.buildRustPackage rec { @@ -47,8 +48,8 @@ rustPlatform.buildRustPackage rec { buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ openssl - ] ++ - lib.optionals stdenv.hostPlatform.isDarwin [ + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreFoundation Security SystemConfiguration @@ -70,11 +71,14 @@ rustPlatform.buildRustPackage rec { passthru.updateScript = nix-update-script { }; meta = with lib; { - description = - "SQLx's associated command-line utility for managing databases, migrations, and enabling offline mode with sqlx::query!() and friends."; + description = "SQLx's associated command-line utility for managing databases, migrations, and enabling offline mode with sqlx::query!() and friends."; homepage = "https://github.com/launchbadge/sqlx"; license = licenses.asl20; - maintainers = with maintainers; [ greizgh xrelkd fd ]; + maintainers = with maintainers; [ + greizgh + xrelkd + fd + ]; mainProgram = "sqlx"; }; } diff --git a/pkgs/development/tools/sass/default.nix b/pkgs/development/tools/sass/default.nix index 8c76ac4e017b91..2c81f7fdf18132 100644 --- a/pkgs/development/tools/sass/default.nix +++ b/pkgs/development/tools/sass/default.nix @@ -1,17 +1,29 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "sass"; gemdir = ./.; - exes = [ "sass" "sass-convert" "scss" ]; + exes = [ + "sass" + "sass-convert" + "scss" + ]; passthru.updateScript = bundlerUpdateScript "sass"; meta = with lib; { description = "Tools and Ruby libraries for the CSS3 extension languages: Sass and SCSS"; - homepage = "https://sass-lang.com"; - license = licenses.mit; - maintainers = with maintainers; [ romildo manveru nicknovitski ]; - platforms = platforms.unix; + homepage = "https://sass-lang.com"; + license = licenses.mit; + maintainers = with maintainers; [ + romildo + manveru + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/sass/gemset.nix b/pkgs/development/tools/sass/gemset.nix index 5cadd7870b86d8..21540aa7fb2490 100644 --- a/pkgs/development/tools/sass/gemset.nix +++ b/pkgs/development/tools/sass/gemset.nix @@ -1,52 +1,55 @@ { ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yvii03hcgqj30maavddqamqy50h7y6xcn2wcyq72wn823zl4ckd"; type = "gem"; }; version = "1.16.3"; }; rb-fsevent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zmf31rnpm8553lqwibvv3kkx0v7majm1f341xbxc0bk5sbhp423"; type = "gem"; }; version = "0.11.2"; }; rb-inotify = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jm76h8f8hji38z3ggf4bzi8vps6p7sagxn3ab57qc0xyga64005"; type = "gem"; }; version = "0.10.1"; }; sass = { - dependencies = ["sass-listen"]; - groups = ["default"]; - platforms = []; + dependencies = [ "sass-listen" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p95lhs0jza5l7hqci1isflxakz83xkj97lkvxl919is0lwhv2w0"; type = "gem"; }; version = "3.7.4"; }; sass-listen = { - dependencies = ["rb-fsevent" "rb-inotify"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "rb-fsevent" + "rb-inotify" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xw3q46cmahkgyldid5hwyiwacp590zj2vmswlll68ryvmvcp7df"; type = "gem"; }; diff --git a/pkgs/development/tools/sauce-connect/default.nix b/pkgs/development/tools/sauce-connect/default.nix index 4a5972a4018eda..576275d8bf195a 100644 --- a/pkgs/development/tools/sauce-connect/default.nix +++ b/pkgs/development/tools/sauce-connect/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchurl, zlib, unzip }: +{ + stdenv, + lib, + fetchurl, + zlib, + unzip, +}: stdenv.mkDerivation rec { pname = "sauce-connect"; @@ -19,15 +25,16 @@ stdenv.mkDerivation rec { updateScript = ./update.sh; }; - src = passthru.sources.${stdenv.hostPlatform.system} - or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + src = + passthru.sources.${stdenv.hostPlatform.system} + or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); nativeBuildInputs = [ unzip ]; patchPhase = lib.optionalString stdenv.hostPlatform.isLinux '' patchelf \ --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - --set-rpath "$out/lib:${lib.makeLibraryPath [zlib]}" \ + --set-rpath "$out/lib:${lib.makeLibraryPath [ zlib ]}" \ bin/sc ''; diff --git a/pkgs/development/tools/scalafix/default.nix b/pkgs/development/tools/scalafix/default.nix index aa02fa8f405b14..94abffd9612018 100644 --- a/pkgs/development/tools/scalafix/default.nix +++ b/pkgs/development/tools/scalafix/default.nix @@ -8,50 +8,52 @@ setJavaClassPath, testers, }: -stdenv.mkDerivation ( - finalAttrs: { - pname = "scalafix"; - version = "0.12.0"; - deps = stdenv.mkDerivation { - name = "${finalAttrs.pname}-deps-${finalAttrs.version}"; - buildCommand = '' - export COURSIER_CACHE=$(pwd) - ${coursier}/bin/cs fetch ch.epfl.scala:scalafix-cli_2.13.13:${finalAttrs.version} > deps - mkdir -p $out/share/java - cp $(< deps) $out/share/java/ - ''; - outputHashMode = "recursive"; - outputHash = "sha256-HMTnr3awTIAgLSl4eF36U1kv162ajJxC5MreSk2TfUE="; - }; +stdenv.mkDerivation (finalAttrs: { + pname = "scalafix"; + version = "0.12.0"; + deps = stdenv.mkDerivation { + name = "${finalAttrs.pname}-deps-${finalAttrs.version}"; + buildCommand = '' + export COURSIER_CACHE=$(pwd) + ${coursier}/bin/cs fetch ch.epfl.scala:scalafix-cli_2.13.13:${finalAttrs.version} > deps + mkdir -p $out/share/java + cp $(< deps) $out/share/java/ + ''; + outputHashMode = "recursive"; + outputHash = "sha256-HMTnr3awTIAgLSl4eF36U1kv162ajJxC5MreSk2TfUE="; + }; - nativeBuildInputs = [makeWrapper installShellFiles setJavaClassPath]; - buildInputs = [finalAttrs.deps]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + setJavaClassPath + ]; + buildInputs = [ finalAttrs.deps ]; - dontUnpack = true; + dontUnpack = true; - installPhase = '' - makeWrapper ${jre}/bin/java $out/bin/${finalAttrs.pname} \ - --add-flags "-cp $CLASSPATH scalafix.cli.Cli" + installPhase = '' + makeWrapper ${jre}/bin/java $out/bin/${finalAttrs.pname} \ + --add-flags "-cp $CLASSPATH scalafix.cli.Cli" - installShellCompletion --cmd ${finalAttrs.pname} \ - --bash <($out/bin/${finalAttrs.pname} --bash) \ - --zsh <($out/bin/${finalAttrs.pname} --zsh) - ''; + installShellCompletion --cmd ${finalAttrs.pname} \ + --bash <($out/bin/${finalAttrs.pname} --bash) \ + --zsh <($out/bin/${finalAttrs.pname} --zsh) + ''; - passthru.tests = { - testVersion = testers.testVersion { - package = finalAttrs.finalPackage; - version = "${finalAttrs.version}"; - }; + passthru.tests = { + testVersion = testers.testVersion { + package = finalAttrs.finalPackage; + version = "${finalAttrs.version}"; }; + }; - meta = with lib; { - description = "Refactoring and linting tool for Scala"; - mainProgram = "scalafix"; - homepage = "https://scalacenter.github.io/scalafix/"; - license = licenses.bsd3; - maintainers = [maintainers.tomahna]; - sourceProvenance = with sourceTypes; [ binaryBytecode ]; - }; - } -) + meta = with lib; { + description = "Refactoring and linting tool for Scala"; + mainProgram = "scalafix"; + homepage = "https://scalacenter.github.io/scalafix/"; + license = licenses.bsd3; + maintainers = [ maintainers.tomahna ]; + sourceProvenance = with sourceTypes; [ binaryBytecode ]; + }; +}) diff --git a/pkgs/development/tools/scry/default.nix b/pkgs/development/tools/scry/default.nix index 28a6c09177b427..e1982a96df90a4 100644 --- a/pkgs/development/tools/scry/default.nix +++ b/pkgs/development/tools/scry/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, crystal, coreutils, makeWrapper, bash }: +{ + lib, + fetchFromGitHub, + crystal, + coreutils, + makeWrapper, + bash, +}: crystal.buildCrystalPackage rec { pname = "scry"; @@ -25,7 +32,12 @@ crystal.buildCrystalPackage rec { postFixup = '' wrapProgram $out/bin/scry \ - --prefix PATH : ${lib.makeBinPath [ crystal coreutils ]} + --prefix PATH : ${ + lib.makeBinPath [ + crystal + coreutils + ] + } ''; # the binary doesn't take any arguments, so this will hang @@ -35,6 +47,9 @@ crystal.buildCrystalPackage rec { description = "Code analysis server for the Crystal programming language"; homepage = "https://github.com/crystal-lang-tools/scry"; license = licenses.mit; - maintainers = with maintainers; [ peterhoeg Br1ght0ne ]; + maintainers = with maintainers; [ + peterhoeg + Br1ght0ne + ]; }; } diff --git a/pkgs/development/tools/scss-lint/default.nix b/pkgs/development/tools/scss-lint/default.nix index 2d26d2518d082a..4d5cbab9945f27 100644 --- a/pkgs/development/tools/scss-lint/default.nix +++ b/pkgs/development/tools/scss-lint/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "scss_lint"; @@ -9,9 +13,12 @@ bundlerApp { meta = with lib; { description = "Tool to help keep your SCSS files clean and readable"; - homepage = "https://github.com/brigade/scss-lint"; - license = licenses.mit; - maintainers = with maintainers; [ lovek323 nicknovitski ]; - platforms = platforms.unix; + homepage = "https://github.com/brigade/scss-lint"; + license = licenses.mit; + maintainers = with maintainers; [ + lovek323 + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/scss-lint/gemset.nix b/pkgs/development/tools/scss-lint/gemset.nix index 027522e58f8b6b..1262917c224a9c 100644 --- a/pkgs/development/tools/scss-lint/gemset.nix +++ b/pkgs/development/tools/scss-lint/gemset.nix @@ -1,7 +1,7 @@ { ffi = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jpm2dis1j7zvvy3lg7axz9jml316zrn7s0j59vyq3qr127z0m7q"; type = "gem"; }; @@ -9,7 +9,7 @@ }; rake = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1idi53jay34ba9j68c3mfr9wwkg3cd9qh0fn9cg42hv72c6q8dyg"; type = "gem"; }; @@ -17,43 +17,49 @@ }; rb-fsevent = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1lm1k7wpz69jx7jrc92w3ggczkjyjbfziq5mg62vjnxmzs383xx8"; type = "gem"; }; version = "0.10.3"; }; rb-inotify = { - dependencies = ["ffi"]; + dependencies = [ "ffi" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yfsgw5n7pkpyky6a9wkf1g9jafxb0ja7gz0qw0y14fd2jnzfh71"; type = "gem"; }; version = "0.9.10"; }; sass = { - dependencies = ["sass-listen"]; + dependencies = [ "sass-listen" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1phs6hnd8b95m7n5wbh5bsclmwaajd1sqlgw9fmj72bfqldbmcqa"; type = "gem"; }; version = "3.7.2"; }; sass-listen = { - dependencies = ["rb-fsevent" "rb-inotify"]; + dependencies = [ + "rb-fsevent" + "rb-inotify" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xw3q46cmahkgyldid5hwyiwacp590zj2vmswlll68ryvmvcp7df"; type = "gem"; }; version = "4.0.0"; }; scss_lint = { - dependencies = ["rake" "sass"]; + dependencies = [ + "rake" + "sass" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dv4ff1lqbgqdx99nwg059c983dhw67kvvjd21f6vf62cjx09lpn"; type = "gem"; }; diff --git a/pkgs/development/tools/selenium/chromedriver/default.nix b/pkgs/development/tools/selenium/chromedriver/default.nix index 4d62e7b8692d4c..b43d3aae181024 100644 --- a/pkgs/development/tools/selenium/chromedriver/default.nix +++ b/pkgs/development/tools/selenium/chromedriver/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, chromium, callPackage }: -if lib.meta.availableOn stdenv.hostPlatform chromium - then callPackage ./source.nix {} - else callPackage ./binary.nix {} +{ + lib, + stdenv, + chromium, + callPackage, +}: +if lib.meta.availableOn stdenv.hostPlatform chromium then + callPackage ./source.nix { } +else + callPackage ./binary.nix { } diff --git a/pkgs/development/tools/selenium/chromedriver/source.nix b/pkgs/development/tools/selenium/chromedriver/source.nix index fcb22c4066448e..a1bece1dea87da 100644 --- a/pkgs/development/tools/selenium/chromedriver/source.nix +++ b/pkgs/development/tools/selenium/chromedriver/source.nix @@ -1,4 +1,8 @@ -{ chromium, testers, chromedriver }: +{ + chromium, + testers, + chromedriver, +}: chromium.mkDerivation (_: { name = "chromedriver"; packageName = "chromedriver"; diff --git a/pkgs/development/tools/shellcheck/default.nix b/pkgs/development/tools/shellcheck/default.nix index 8d04c357ce5089..7931e90505b044 100644 --- a/pkgs/development/tools/shellcheck/default.nix +++ b/pkgs/development/tools/shellcheck/default.nix @@ -1,11 +1,18 @@ -{ stdenv, lib, ShellCheck, haskell, pandoc }: +{ + stdenv, + lib, + ShellCheck, + haskell, + pandoc, +}: # this wraps around the haskell package # and puts the documentation into place let # TODO: move to lib/ in separate PR - overrideMeta = drv: overrideFn: + overrideMeta = + drv: overrideFn: let drv' = if drv ? meta then drv else drv // { meta = { }; }; pos = (builtins.unsafeGetAttrPos "pname" drv'); @@ -26,7 +33,12 @@ let nativeBuildInputs = [ pandoc ]; - outputs = [ "bin" "man" "doc" "out" ]; + outputs = [ + "bin" + "man" + "doc" + "out" + ]; buildPhase = '' pandoc -s -f markdown-smart -t man shellcheck.1.md -o shellcheck.1 @@ -49,5 +61,9 @@ in overrideMeta shellcheck (old: { maintainers = with lib.maintainers; [ zowoq ]; mainProgram = "shellcheck"; - outputsToInstall = [ "bin" "man" "doc" ]; + outputsToInstall = [ + "bin" + "man" + "doc" + ]; }) diff --git a/pkgs/development/tools/simavr/default.nix b/pkgs/development/tools/simavr/default.nix index e50986dd650219..9a8dc3ef60e71c 100644 --- a/pkgs/development/tools/simavr/default.nix +++ b/pkgs/development/tools/simavr/default.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, makeSetupHook, fetchFromGitHub, libelf, which, pkg-config, libglut -, avrgcc, avrlibc -, libGLU, libGL -, GLUT }: +{ + lib, + stdenv, + makeSetupHook, + fetchFromGitHub, + libelf, + which, + pkg-config, + libglut, + avrgcc, + avrlibc, + libGLU, + libGL, + GLUT, +}: let setupHookDarwin = makeSetupHook { @@ -11,7 +22,8 @@ let avrSuffixSalt = avrgcc.suffixSalt; }; } ./setup-hook-darwin.sh; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "simavr"; version = "1.7"; @@ -30,10 +42,17 @@ in stdenv.mkDerivation rec { "AVR=avr-" ]; - nativeBuildInputs = [ which pkg-config avrgcc ] - ++ lib.optional stdenv.hostPlatform.isDarwin setupHookDarwin; - buildInputs = [ libelf libglut libGLU libGL ] - ++ lib.optional stdenv.hostPlatform.isDarwin GLUT; + nativeBuildInputs = [ + which + pkg-config + avrgcc + ] ++ lib.optional stdenv.hostPlatform.isDarwin setupHookDarwin; + buildInputs = [ + libelf + libglut + libGLU + libGL + ] ++ lib.optional stdenv.hostPlatform.isDarwin GLUT; # remove forbidden references to $TMPDIR preFixup = lib.optionalString stdenv.hostPlatform.isLinux '' @@ -46,9 +65,9 @@ in stdenv.mkDerivation rec { meta = with lib; { description = "Lean and mean Atmel AVR simulator"; mainProgram = "simavr"; - homepage = "https://github.com/buserror/simavr"; - license = licenses.gpl3; - platforms = platforms.unix; + homepage = "https://github.com/buserror/simavr"; + license = licenses.gpl3; + platforms = platforms.unix; maintainers = with maintainers; [ goodrone ]; }; diff --git a/pkgs/development/tools/solarus-quest-editor/default.nix b/pkgs/development/tools/solarus-quest-editor/default.nix index f0c6ba5bf0f1c8..873314138265d5 100644 --- a/pkgs/development/tools/solarus-quest-editor/default.nix +++ b/pkgs/development/tools/solarus-quest-editor/default.nix @@ -1,7 +1,22 @@ -{ lib, mkDerivation, fetchFromGitLab, cmake, luajit -, SDL2, SDL2_image, SDL2_ttf, physfs, fetchpatch -, openal, libmodplug, libvorbis, solarus -, qtbase, qttools, glm }: +{ + lib, + mkDerivation, + fetchFromGitLab, + cmake, + luajit, + SDL2, + SDL2_image, + SDL2_ttf, + physfs, + fetchpatch, + openal, + libmodplug, + libvorbis, + solarus, + qtbase, + qttools, + glm, +}: mkDerivation rec { pname = "solarus-quest-editor"; @@ -23,8 +38,20 @@ mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ luajit SDL2 SDL2_image SDL2_ttf physfs openal - libmodplug libvorbis solarus qtbase qttools glm ]; + buildInputs = [ + luajit + SDL2 + SDL2_image + SDL2_ttf + physfs + openal + libmodplug + libvorbis + solarus + qtbase + qttools + glm + ]; meta = with lib; { description = "Editor for the Zelda-like ARPG game engine, Solarus"; diff --git a/pkgs/development/tools/spr/default.nix b/pkgs/development/tools/spr/default.nix index d7a9b4530c6312..9d7467383a8dfa 100644 --- a/pkgs/development/tools/spr/default.nix +++ b/pkgs/development/tools/spr/default.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchCrate -, Security -, stdenv +{ + lib, + rustPlatform, + fetchCrate, + Security, + stdenv, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/development/tools/sqlint/default.nix b/pkgs/development/tools/sqlint/default.nix index 960792d648b3aa..a78c35ac1ecbae 100644 --- a/pkgs/development/tools/sqlint/default.nix +++ b/pkgs/development/tools/sqlint/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "sqlint"; @@ -10,9 +14,13 @@ bundlerApp { meta = with lib; { description = "Simple SQL linter"; - homepage = "https://github.com/purcell/sqlint"; - license = licenses.mit; - maintainers = with maintainers; [ ariutta nicknovitski purcell ]; - platforms = platforms.unix; + homepage = "https://github.com/purcell/sqlint"; + license = licenses.mit; + maintainers = with maintainers; [ + ariutta + nicknovitski + purcell + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/sqlint/gemset.nix b/pkgs/development/tools/sqlint/gemset.nix index 4ad8655564e913..dd8ce2f48e5c3b 100644 --- a/pkgs/development/tools/sqlint/gemset.nix +++ b/pkgs/development/tools/sqlint/gemset.nix @@ -1,31 +1,31 @@ { google-protobuf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fanhdf3vzghma51w1hqpp8s585mwzxgqkwvxj5is4q9j0pgwcs3"; type = "gem"; }; version = "3.25.5"; }; pg_query = { - dependencies = ["google-protobuf"]; - groups = ["default"]; - platforms = []; + dependencies = [ "google-protobuf" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15ynrzqsmmbmxib8ri8n9k6z3l6rwd91j7y1mghm33nfgdf9bj8w"; type = "gem"; }; version = "4.2.3"; }; sqlint = { - dependencies = ["pg_query"]; - groups = ["default"]; - platforms = []; + dependencies = [ "pg_query" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06gljzjhbfvxs85699jr1p7y2j8hhi629kfarad7yjqy7ssl541n"; type = "gem"; }; diff --git a/pkgs/development/tools/tabnine/default.nix b/pkgs/development/tools/tabnine/default.nix index 4426e2bbf81fcb..d93c951272f4af 100644 --- a/pkgs/development/tools/tabnine/default.nix +++ b/pkgs/development/tools/tabnine/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchurl, unzip }: +{ + stdenv, + lib, + fetchurl, + unzip, +}: let sources = lib.importJSON ./sources.json; platform = diff --git a/pkgs/development/tools/tailwindcss/default.nix b/pkgs/development/tools/tailwindcss/default.nix index b8de6ef462ed6d..92e5049fb4cb85 100644 --- a/pkgs/development/tools/tailwindcss/default.nix +++ b/pkgs/development/tools/tailwindcss/default.nix @@ -1,29 +1,33 @@ -{ lib -, fetchurl -, stdenv -, runCommand -, tailwindcss -, +{ + lib, + fetchurl, + stdenv, + runCommand, + tailwindcss, }: let inherit (stdenv.hostPlatform) system; throwSystem = throw "tailwindcss has not been packaged for ${system} yet."; - plat = { - aarch64-darwin = "macos-arm64"; - aarch64-linux = "linux-arm64"; - armv7l-linux = "linux-armv7"; - x86_64-darwin = "macos-x64"; - x86_64-linux = "linux-x64"; - }.${system} or throwSystem; + plat = + { + aarch64-darwin = "macos-arm64"; + aarch64-linux = "linux-arm64"; + armv7l-linux = "linux-armv7"; + x86_64-darwin = "macos-x64"; + x86_64-linux = "linux-x64"; + } + .${system} or throwSystem; - hash = { - aarch64-darwin = "sha256-AXUcYBnBtL94fS4LHyIb7xvMAQzvVTE/wGkfO2o7Z28="; - aarch64-linux = "sha256-HmdGu6bz0011UIiaGgCauQ7jeUpevOYO0QaIrRBoCoc="; - armv7l-linux = "sha256-OLWmAuwp1/W+DUx4N9pgedg2mELT+hFMYiUJu06g35U="; - x86_64-darwin = "sha256-IglipvNx/DFgX4lWmtZHMJy9g0cc2MKbg/I1pQHDnc4="; - x86_64-linux = "sha256-M/JUtUyHVPFu++K+HeOMolGSYw3DbxZFladw1Lv02JM="; - }.${system} or throwSystem; + hash = + { + aarch64-darwin = "sha256-AXUcYBnBtL94fS4LHyIb7xvMAQzvVTE/wGkfO2o7Z28="; + aarch64-linux = "sha256-HmdGu6bz0011UIiaGgCauQ7jeUpevOYO0QaIrRBoCoc="; + armv7l-linux = "sha256-OLWmAuwp1/W+DUx4N9pgedg2mELT+hFMYiUJu06g35U="; + x86_64-darwin = "sha256-IglipvNx/DFgX4lWmtZHMJy9g0cc2MKbg/I1pQHDnc4="; + x86_64-linux = "sha256-M/JUtUyHVPFu++K+HeOMolGSYw3DbxZFladw1Lv02JM="; + } + .${system} or throwSystem; in stdenv.mkDerivation rec { pname = "tailwindcss"; diff --git a/pkgs/development/tools/tarmac/default.nix b/pkgs/development/tools/tarmac/default.nix index a2b03fa93cbd33..5fd7d941a299e8 100644 --- a/pkgs/development/tools/tarmac/default.nix +++ b/pkgs/development/tools/tarmac/default.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + Security, }: rustPlatform.buildRustPackage rec { @@ -26,11 +27,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + ]; # update Cargo.lock to work with openssl 3 postPatch = '' diff --git a/pkgs/development/tools/thrust/default.nix b/pkgs/development/tools/thrust/default.nix index 889d3bc3af3650..22a3d67bef6d79 100644 --- a/pkgs/development/tools/thrust/default.nix +++ b/pkgs/development/tools/thrust/default.nix @@ -1,19 +1,64 @@ -{ lib, stdenv, fetchurl, buildEnv, makeWrapper, glib, alsa-lib , dbus, gtk2, atk -, pango, freetype, fontconfig, gdk-pixbuf , cairo, cups, expat, nspr, gconf, nss -, xorg, libcap, unzip +{ + lib, + stdenv, + fetchurl, + buildEnv, + makeWrapper, + glib, + alsa-lib, + dbus, + gtk2, + atk, + pango, + freetype, + fontconfig, + gdk-pixbuf, + cairo, + cups, + expat, + nspr, + gconf, + nss, + xorg, + libcap, + unzip, }: let thrustEnv = buildEnv { name = "env-thrust"; paths = [ - stdenv.cc.cc glib dbus gtk2 atk pango freetype fontconfig gdk-pixbuf - cairo cups expat alsa-lib nspr gconf nss xorg.libXrender xorg.libX11 - xorg.libXext xorg.libXdamage xorg.libXtst xorg.libXcomposite - xorg.libXi xorg.libXfixes xorg.libXrandr xorg.libXcursor libcap + stdenv.cc.cc + glib + dbus + gtk2 + atk + pango + freetype + fontconfig + gdk-pixbuf + cairo + cups + expat + alsa-lib + nspr + gconf + nss + xorg.libXrender + xorg.libX11 + xorg.libXext + xorg.libXdamage + xorg.libXtst + xorg.libXcomposite + xorg.libXi + xorg.libXfixes + xorg.libXrandr + xorg.libXcursor + libcap ]; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "thrust"; version = "0.7.6"; @@ -22,7 +67,10 @@ in stdenv.mkDerivation rec { sha256 = "07rrnlj0gk500pvar4b1wdqm05p4n9yjwn911x93bd2qwc8r5ymc"; }; - nativeBuildInputs = [ makeWrapper unzip ]; + nativeBuildInputs = [ + makeWrapper + unzip + ]; buildInputs = [ thrustEnv ]; installPhase = '' diff --git a/pkgs/development/tools/toluapp/default.nix b/pkgs/development/tools/toluapp/default.nix index 5d3d9a53854028..fbe1416808f744 100644 --- a/pkgs/development/tools/toluapp/default.nix +++ b/pkgs/development/tools/toluapp/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, lua }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + lua, +}: stdenv.mkDerivation rec { version = "1.0.93"; @@ -6,15 +12,18 @@ stdenv.mkDerivation rec { src = fetchFromGitHub { owner = "LuaDist"; - repo = "toluapp"; - rev = version; + repo = "toluapp"; + rev = version; sha256 = "0zd55bc8smmgk9j4cf0jpibb03lgsvl0knpwhplxbv93mcdnw7s0"; }; nativeBuildInputs = [ cmake ]; buildInputs = [ lua ]; - patches = [ ./environ-and-linux-is-kinda-posix.patch ./headers.patch ]; + patches = [ + ./environ-and-linux-is-kinda-posix.patch + ./headers.patch + ]; meta = with lib; { description = "Tool to integrate C/Cpp code with Lua"; diff --git a/pkgs/development/tools/tora/default.nix b/pkgs/development/tools/tora/default.nix index 512d5adc0a7ff5..fde6ca673de1f6 100644 --- a/pkgs/development/tools/tora/default.nix +++ b/pkgs/development/tools/tora/default.nix @@ -1,22 +1,50 @@ -{ mkDerivation, lib, fetchFromGitHub, cmake, extra-cmake-modules, makeWrapper -, boost, doxygen, openssl, libmysqlclient, postgresql, graphviz, loki -, qscintilla, qtbase, qttools }: +{ + mkDerivation, + lib, + fetchFromGitHub, + cmake, + extra-cmake-modules, + makeWrapper, + boost, + doxygen, + openssl, + libmysqlclient, + postgresql, + graphviz, + loki, + qscintilla, + qtbase, + qttools, +}: mkDerivation { pname = "tora"; version = "3.2.176"; src = fetchFromGitHub { - owner = "tora-tool"; - repo = "tora"; - rev = "39bf2837779bf458fc72a9f0e49271152e57829f"; + owner = "tora-tool"; + repo = "tora"; + rev = "39bf2837779bf458fc72a9f0e49271152e57829f"; sha256 = "0fr9b542i8r6shgnz33lc3cz333fnxgmac033yxfrdjfglzk0j2k"; }; - nativeBuildInputs = [ cmake extra-cmake-modules makeWrapper qttools ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + makeWrapper + qttools + ]; buildInputs = [ - boost doxygen graphviz loki libmysqlclient openssl postgresql qscintilla qtbase + boost + doxygen + graphviz + loki + libmysqlclient + openssl + postgresql + qscintilla + qtbase ]; preConfigure = '' diff --git a/pkgs/development/tools/unityhub/default.nix b/pkgs/development/tools/unityhub/default.nix index d875c176b91065..5a4d94f5022c20 100644 --- a/pkgs/development/tools/unityhub/default.nix +++ b/pkgs/development/tools/unityhub/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, dpkg -, makeWrapper -, buildFHSEnv -, extraPkgs ? pkgs: [ ] -, extraLibs ? pkgs: [ ] +{ + lib, + stdenv, + fetchurl, + dpkg, + makeWrapper, + buildFHSEnv, + extraPkgs ? pkgs: [ ], + extraLibs ? pkgs: [ ], }: stdenv.mkDerivation rec { @@ -27,81 +28,89 @@ stdenv.mkDerivation rec { inherit version; runScript = ""; - targetPkgs = pkgs: with pkgs; [ - # Unity Hub binary dependencies - xorg.libXrandr - xdg-utils - - # GTK filepicker - gsettings-desktop-schemas - hicolor-icon-theme - - # Bug Reporter dependencies - fontconfig - freetype - lsb-release - ] ++ extraPkgs pkgs; - - multiPkgs = pkgs: with pkgs; [ - # Unity Hub ldd dependencies - cups - gtk3 - expat - libxkbcommon - lttng-ust_2_12 - krb5 - alsa-lib - nss - libdrm - mesa - nspr - atk - dbus - at-spi2-core - pango - xorg.libXcomposite - xorg.libXext - xorg.libXdamage - xorg.libXfixes - xorg.libxcb - xorg.libxshmfence - xorg.libXScrnSaver - xorg.libXtst - - # Unity Hub additional dependencies - libva - openssl - cairo - libnotify - libuuid - libsecret - udev - libappindicator - wayland - cpio - icu - libpulseaudio - - # Unity Editor dependencies - libglvnd # provides ligbl - xorg.libX11 - xorg.libXcursor - glib - gdk-pixbuf - libxml2 - zlib - clang - git # for git-based packages in unity package manager - - # Unity Editor 2019 specific dependencies - xorg.libXi - xorg.libXrender - gnome2.GConf - libcap - - # Unity Editor 6000 specific dependencies - harfbuzz - ] ++ extraLibs pkgs; + targetPkgs = + pkgs: + with pkgs; + [ + # Unity Hub binary dependencies + xorg.libXrandr + xdg-utils + + # GTK filepicker + gsettings-desktop-schemas + hicolor-icon-theme + + # Bug Reporter dependencies + fontconfig + freetype + lsb-release + ] + ++ extraPkgs pkgs; + + multiPkgs = + pkgs: + with pkgs; + [ + # Unity Hub ldd dependencies + cups + gtk3 + expat + libxkbcommon + lttng-ust_2_12 + krb5 + alsa-lib + nss + libdrm + mesa + nspr + atk + dbus + at-spi2-core + pango + xorg.libXcomposite + xorg.libXext + xorg.libXdamage + xorg.libXfixes + xorg.libxcb + xorg.libxshmfence + xorg.libXScrnSaver + xorg.libXtst + + # Unity Hub additional dependencies + libva + openssl + cairo + libnotify + libuuid + libsecret + udev + libappindicator + wayland + cpio + icu + libpulseaudio + + # Unity Editor dependencies + libglvnd # provides ligbl + xorg.libX11 + xorg.libXcursor + glib + gdk-pixbuf + libxml2 + zlib + clang + git # for git-based packages in unity package manager + + # Unity Editor 2019 specific dependencies + xorg.libXi + xorg.libXrender + gnome2.GConf + libcap + + # Unity Editor 6000 specific dependencies + harfbuzz + ] + ++ extraLibs pkgs; }; unpackCmd = "dpkg -x $curSrc src"; @@ -140,7 +149,10 @@ stdenv.mkDerivation rec { downloadPage = "https://unity.com/unity-hub"; changelog = "https://unity.com/unity-hub/release-notes"; license = licenses.unfree; - maintainers = with maintainers; [ tesq0 huantian ]; + maintainers = with maintainers; [ + tesq0 + huantian + ]; platforms = [ "x86_64-linux" ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; }; diff --git a/pkgs/development/tools/viceroy/default.nix b/pkgs/development/tools/viceroy/default.nix index 9504fd9551867f..6220337c275cb9 100644 --- a/pkgs/development/tools/viceroy/default.nix +++ b/pkgs/development/tools/viceroy/default.nix @@ -1,4 +1,10 @@ -{ rustPlatform, fetchFromGitHub, lib, stdenv, Security }: +{ + rustPlatform, + fetchFromGitHub, + lib, + stdenv, + Security, +}: rustPlatform.buildRustPackage rec { pname = "viceroy"; @@ -24,7 +30,10 @@ rustPlatform.buildRustPackage rec { mainProgram = "viceroy"; homepage = "https://github.com/fastly/Viceroy"; license = licenses.asl20; - maintainers = with maintainers; [ ereslibre shyim ]; + maintainers = with maintainers; [ + ereslibre + shyim + ]; platforms = platforms.unix; }; } diff --git a/pkgs/development/tools/wails/default.nix b/pkgs/development/tools/wails/default.nix index b024d5fe710ca2..700cb90046a32b 100644 --- a/pkgs/development/tools/wails/default.nix +++ b/pkgs/development/tools/wails/default.nix @@ -1,27 +1,30 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, pkg-config -, makeWrapper -, go -, nodejs -, zlib +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + pkg-config, + makeWrapper, + go, + nodejs, + zlib, # Linux specific dependencies -, gtk3 -, webkitgtk_4_0 + gtk3, + webkitgtk_4_0, }: buildGoModule rec { pname = "wails"; version = "2.9.1"; - src = fetchFromGitHub { - owner = "wailsapp"; - repo = pname; - rev = "v${version}"; - hash = "sha256-dtfFeNK7ZfqriK4S0/+Wor1hUJv5kgnRWURVqt+RrNU="; - } + "/v2"; + src = + fetchFromGitHub { + owner = "wailsapp"; + repo = pname; + rev = "v${version}"; + hash = "sha256-dtfFeNK7ZfqriK4S0/+Wor1hUJv5kgnRWURVqt+RrNU="; + } + + "/v2"; vendorHash = "sha256-15Vo4AKmd9qOF0ea1klTlrXJOUs+IHvsNT2rw4R7ZiU="; @@ -41,15 +44,17 @@ buildGoModule rec { allowGoReference = true; # Following packages are required when wails used as a builder. - propagatedBuildInputs = [ - pkg-config - go - stdenv.cc - nodejs - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - gtk3 - webkitgtk_4_0 - ]; + propagatedBuildInputs = + [ + pkg-config + go + stdenv.cc + nodejs + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + gtk3 + webkitgtk_4_0 + ]; ldflags = [ "-s" @@ -59,8 +64,22 @@ buildGoModule rec { # As Wails calls a compiler, certain apps and libraries need to be made available. postFixup = '' wrapProgram $out/bin/wails \ - --prefix PATH : ${lib.makeBinPath [ pkg-config go stdenv.cc nodejs ]} \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath (lib.optionals stdenv.hostPlatform.isLinux [ gtk3 webkitgtk_4_0 ])}" \ + --prefix PATH : ${ + lib.makeBinPath [ + pkg-config + go + stdenv.cc + nodejs + ] + } \ + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath ( + lib.optionals stdenv.hostPlatform.isLinux [ + gtk3 + webkitgtk_4_0 + ] + ) + }" \ --set PKG_CONFIG_PATH "$PKG_CONFIG_PATH" \ --set CGO_LDFLAGS "-L${lib.makeLibraryPath [ zlib ]}" ''; diff --git a/pkgs/development/tools/wasmedge/default.nix b/pkgs/development/tools/wasmedge/default.nix index 4ca0844821d3ac..d21ac338f34f9d 100644 --- a/pkgs/development/tools/wasmedge/default.nix +++ b/pkgs/development/tools/wasmedge/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, llvmPackages -, boost -, cmake -, spdlog -, libxml2 -, libffi -, Foundation -, testers +{ + lib, + stdenv, + fetchFromGitHub, + llvmPackages, + boost, + cmake, + spdlog, + libxml2, + libffi, + Foundation, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -27,21 +28,25 @@ stdenv.mkDerivation (finalAttrs: { llvmPackages.lld ]; - buildInputs = [ - boost - spdlog - llvmPackages.llvm - libxml2 - libffi - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Foundation - ]; + buildInputs = + [ + boost + spdlog + llvmPackages.llvm + libxml2 + libffi + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Foundation + ]; - cmakeFlags = [ - "-DWASMEDGE_BUILD_TESTS=OFF" # Tests are downloaded using git - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DWASMEDGE_FORCE_DISABLE_LTO=ON" - ]; + cmakeFlags = + [ + "-DWASMEDGE_BUILD_TESTS=OFF" # Tests are downloaded using git + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DWASMEDGE_FORCE_DISABLE_LTO=ON" + ]; postPatch = '' echo -n $version > VERSION diff --git a/pkgs/development/tools/worker-build/default.nix b/pkgs/development/tools/worker-build/default.nix index cc48ae31d39baa..6e4a2d0320ac84 100644 --- a/pkgs/development/tools/worker-build/default.nix +++ b/pkgs/development/tools/worker-build/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, +}: rustPlatform.buildRustPackage rec { pname = "worker-build"; @@ -29,7 +35,10 @@ rustPlatform.buildRustPackage rec { description = "This is a tool to be used as a custom build command for a Cloudflare Workers `workers-rs` project"; mainProgram = "worker-build"; homepage = "https://github.com/cloudflare/workers-rs"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ happysalada ]; }; } diff --git a/pkgs/development/tools/wrangler_1/default.nix b/pkgs/development/tools/wrangler_1/default.nix index 570092b7ee4841..259139fc661b70 100644 --- a/pkgs/development/tools/wrangler_1/default.nix +++ b/pkgs/development/tools/wrangler_1/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, pkg-config, openssl, curl, Security, CoreServices, CoreFoundation, libiconv }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + curl, + Security, + CoreServices, + CoreFoundation, + libiconv, +}: rustPlatform.buildRustPackage rec { pname = "wrangler"; @@ -15,8 +27,15 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ curl CoreFoundation CoreServices Security libiconv ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + curl + CoreFoundation + CoreServices + Security + libiconv + ]; OPENSSL_NO_VENDOR = 1; @@ -27,7 +46,10 @@ rustPlatform.buildRustPackage rec { description = "CLI tool designed for folks who are interested in using Cloudflare Workers"; mainProgram = "wrangler"; homepage = "https://github.com/cloudflare/wrangler"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ Br1ght0ne ]; }; } diff --git a/pkgs/development/tools/xcode-install/default.nix b/pkgs/development/tools/xcode-install/default.nix index 677217b5c810a1..4b753b74d9f8a6 100644 --- a/pkgs/development/tools/xcode-install/default.nix +++ b/pkgs/development/tools/xcode-install/default.nix @@ -1,5 +1,6 @@ -{ lib -, bundlerApp +{ + lib, + bundlerApp, }: bundlerApp { diff --git a/pkgs/development/tools/xcode-install/gemset.nix b/pkgs/development/tools/xcode-install/gemset.nix index c6355de34a2f0f..351c162ca498a0 100644 --- a/pkgs/development/tools/xcode-install/gemset.nix +++ b/pkgs/development/tools/xcode-install/gemset.nix @@ -1,830 +1,942 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fvchp2rhp2rmigx7qglf69xvjqvzq7x0g49naliw29r2bz656sy"; type = "gem"; }; version = "2.7.0"; }; artifactory = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wify8rhjwr5bw5y6ary61vba290vk766cxw9a9mg05yswmaisls"; type = "gem"; }; version = "3.0.15"; }; atomos = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17vq6sjyswr5jfzwdccw748kgph6bdw30bakwnn6p8sl4hpv4hvx"; type = "gem"; }; version = "0.1.3"; }; aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0r0pn66yqrdkrfdin7qdim0yj2x75miyg4wp6mijckhzhrjb7cv5"; type = "gem"; }; version = "1.1.0"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz0djj8w3ns0sz5gvkla5jml8xzx6skbcfj255m81fyww1x6ws8"; type = "gem"; }; version = "1.419.0"; }; aws-sdk-core = { - dependencies = ["aws-eventstream" "aws-partitions" "aws-sigv4" "jmespath"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-eventstream" + "aws-partitions" + "aws-sigv4" + "jmespath" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0bfj1cnpp0ljr9jc44kljdwl5399cbqlvlqkz6fxq5i4r6ckggi4"; type = "gem"; }; version = "3.111.2"; }; aws-sdk-kms = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "02f70a4rr5h2na7navjhaf3n15ifq95zdl1avsryyxdvqzm5gzwm"; type = "gem"; }; version = "1.41.0"; }; aws-sdk-s3 = { - dependencies = ["aws-sdk-core" "aws-sdk-kms" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sdk-kms" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0capqhvm08ngq74n33ym0khixkdj342jpikssw57avdmd8g6kaq7"; type = "gem"; }; version = "1.87.0"; }; aws-sigv4 = { - dependencies = ["aws-eventstream"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-eventstream" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ll9382c1x2hp750cilh01h1cycgyhdr4cmmgx23k94hyyb8chv5"; type = "gem"; }; version = "1.2.2"; }; babosa = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16dwqn33kmxkqkv51cwiikdkbrdjfsymlnc0rgbjwilmym8a9phq"; type = "gem"; }; version = "1.0.4"; }; CFPropertyList = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ia09r8bj3bjhcfiyr3vlk9zx7vahfypbs2lyrxix9x1jx3lfzq4"; type = "gem"; }; version = "3.0.3"; }; claide = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kasxsms24fgcdsq680nz99d5lazl9rmz1qkil2y5gbbssx89g0z"; type = "gem"; }; version = "1.0.3"; }; colored = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b0x5jmsyi0z69bm6sij1k89z7h0laag3cb4mdn7zkl9qmxb90lx"; type = "gem"; }; version = "1.2"; }; colored2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jlbqa9q4mvrm73aw9mxh23ygzbjiqwisl32d8szfb5fxvbjng5i"; type = "gem"; }; version = "3.1.2"; }; commander-fastlane = { - dependencies = ["highline"]; - groups = ["default"]; - platforms = []; + dependencies = [ "highline" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0y8d3ac9qwm1cg6rnpf8rcdsy1yxacrd2g2kl809xsp2vi973g65"; type = "gem"; }; version = "4.4.6"; }; declarative = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yczgnqrbls7shrg63y88g7wand2yp9h6sf56c9bdcksn5nds8c0"; type = "gem"; }; version = "0.0.20"; }; declarative-option = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g4ibxq566f1frnhdymzi9hxxcm4g2gw4n21mpjk2mhwym4q6l0p"; type = "gem"; }; version = "0.1.0"; }; digest-crc = { - dependencies = ["rake"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rake" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "118d5p02kdw6a5pi8af12dxma7q3b77zz5q5xjjf5kgp8qh1930a"; type = "gem"; }; version = "0.6.3"; }; domain_name = { - dependencies = ["unf"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unf" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lcqjsmixjp52bnlgzh4lg9ppsk52x9hpwdjd53k8jnbah2602h0"; type = "gem"; }; version = "0.5.20190701"; }; dotenv = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0iym172c5337sm1x2ykc2i3f961vj3wdclbyg1x6sxs3irgfsl94"; type = "gem"; }; version = "2.7.6"; }; emoji_regex = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qbzlracxw4xwyvrgr0qcl1alk4ijk6pv53ni6f43csi649y3n3s"; type = "gem"; }; version = "3.2.1"; }; excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16ij8617v3js03yj1zd32mmrf7kpi9l96bid5mpqk30c4mzai55r"; type = "gem"; }; version = "0.78.1"; }; faraday = { - dependencies = ["faraday-net_http" "multipart-post" "ruby2_keywords"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-net_http" + "multipart-post" + "ruby2_keywords" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1hmssd8pj4n7yq4kz834ylkla8ryyvhaap6q9nzymp93m1xq21kz"; type = "gem"; }; version = "1.3.0"; }; faraday-cookie_jar = { - dependencies = ["faraday" "http-cookie"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "http-cookie" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00hligx26w9wdnpgsrf0qdnqld4rdccy8ym6027h5m735mpvxjzk"; type = "gem"; }; version = "0.0.7"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fi8sda5hc54v1w3mqfl5yz09nhx35kglyx72w7b8xxvdr0cwi9j"; type = "gem"; }; version = "1.0.1"; }; faraday_middleware = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jik2kgfinwnfi6fpp512vlvs0mlggign3gkbpkg5fw1jr9his0r"; type = "gem"; }; version = "1.0.0"; }; fastimage = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vqp53s9vgd28f4l17q0vs7xv32y64af0ny3wb1fgg4i534rzg6j"; type = "gem"; }; version = "2.2.1"; }; fastlane = { - dependencies = ["CFPropertyList" "addressable" "artifactory" "aws-sdk-s3" "babosa" "colored" "commander-fastlane" "dotenv" "emoji_regex" "excon" "faraday" "faraday-cookie_jar" "faraday_middleware" "fastimage" "gh_inspector" "google-api-client" "google-cloud-storage" "highline" "json" "jwt" "mini_magick" "multipart-post" "plist" "rubyzip" "security" "simctl" "slack-notifier" "terminal-notifier" "terminal-table" "tty-screen" "tty-spinner" "word_wrap" "xcodeproj" "xcpretty" "xcpretty-travis-formatter"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "CFPropertyList" + "addressable" + "artifactory" + "aws-sdk-s3" + "babosa" + "colored" + "commander-fastlane" + "dotenv" + "emoji_regex" + "excon" + "faraday" + "faraday-cookie_jar" + "faraday_middleware" + "fastimage" + "gh_inspector" + "google-api-client" + "google-cloud-storage" + "highline" + "json" + "jwt" + "mini_magick" + "multipart-post" + "plist" + "rubyzip" + "security" + "simctl" + "slack-notifier" + "terminal-notifier" + "terminal-table" + "tty-screen" + "tty-spinner" + "word_wrap" + "xcodeproj" + "xcpretty" + "xcpretty-travis-formatter" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0crr42qdgy9l409pffpfs7nq8ha18lp1nxngny2dc9hiq1xx4r5d"; type = "gem"; }; version = "2.172.0"; }; gh_inspector = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f8r9byajj3bi2c7c5sqrc7m0zrv3nblfcd4782lw5l73cbsgk04"; type = "gem"; }; version = "1.1.3"; }; google-api-client = { - dependencies = ["addressable" "googleauth" "httpclient" "mini_mime" "representable" "retriable" "signet"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "googleauth" + "httpclient" + "mini_mime" + "representable" + "retriable" + "signet" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1jybks8i00rxrxx9mkx90dbdk6pczh2w757wchlavmrkrk0dp9s1"; type = "gem"; }; version = "0.38.0"; }; google-apis-core = { - dependencies = ["addressable" "googleauth" "httpclient" "mini_mime" "representable" "retriable" "rexml" "signet" "webrick"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "googleauth" + "httpclient" + "mini_mime" + "representable" + "retriable" + "rexml" + "signet" + "webrick" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "184pqw7z7s8mc1r5gj8f76xvp8z650xq50vdfj5gjwsbmzd99z2f"; type = "gem"; }; version = "0.2.1"; }; google-apis-iamcredentials_v1 = { - dependencies = ["google-apis-core"]; - groups = ["default"]; - platforms = []; + dependencies = [ "google-apis-core" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xjlzq2fxpwvp9b6ajs8cpyjv8vs2d2npg9v23yj181hj2fnn82c"; type = "gem"; }; version = "0.1.0"; }; google-apis-storage_v1 = { - dependencies = ["google-apis-core"]; - groups = ["default"]; - platforms = []; + dependencies = [ "google-apis-core" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0axycds5q20fqm6vqxa5r922021p0f8jhwvlgw8r1vq600ljribi"; type = "gem"; }; version = "0.1.0"; }; google-cloud-core = { - dependencies = ["google-cloud-env" "google-cloud-errors"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "google-cloud-env" + "google-cloud-errors" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1qjn7vs8f85vxi1nkikbjfja6bv9snrj26vzscjii0cm8n4dy0i1"; type = "gem"; }; version = "1.5.0"; }; google-cloud-env = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bjgxyvagy6hjj8yg7fqq24rwdjxb6hx7fdd1bmn4mwd846lci2i"; type = "gem"; }; version = "1.4.0"; }; google-cloud-errors = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1hvs1x39g77hbdqjxmzcl6gq8160pv3kskvzbbch0ww1np6qwm67"; type = "gem"; }; version = "1.0.1"; }; google-cloud-storage = { - dependencies = ["addressable" "digest-crc" "google-apis-iamcredentials_v1" "google-apis-storage_v1" "google-cloud-core" "googleauth" "mini_mime"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "digest-crc" + "google-apis-iamcredentials_v1" + "google-apis-storage_v1" + "google-cloud-core" + "googleauth" + "mini_mime" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "17axi5gmy0g04801v11lww5mvqzffqdc3w6k1j7f95v90hy4yn6m"; type = "gem"; }; version = "1.30.0"; }; googleauth = { - dependencies = ["faraday" "jwt" "memoist" "multi_json" "os" "signet"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "jwt" + "memoist" + "multi_json" + "os" + "signet" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1pwm0mzb5zffhk6yw4v3n1yj8qr6jla6f78vsv4g0bxh9z0ikc2z"; type = "gem"; }; version = "0.15.0"; }; highline = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01ib7jp85xjc4gh4jg0wyzllm46hwv8p0w1m4c75pbgi41fps50y"; type = "gem"; }; version = "1.7.10"; }; http-cookie = { - dependencies = ["domain_name"]; - groups = ["default"]; - platforms = []; + dependencies = [ "domain_name" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "004cgs4xg5n6byjs7qld0xhsjq3n6ydfh897myr2mibvh6fjc49g"; type = "gem"; }; version = "1.0.3"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d4wac0dcd1jf6kc57891glih9w57552zgqswgy74d1xhgnk0ngf"; type = "gem"; }; version = "1.4.0"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lrirj0gw420kw71bjjlqkqhqbrplla61gbv1jzgsz6bv90qr3ci"; type = "gem"; }; version = "2.5.1"; }; jwt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14ynyq1q483spj20ffl4xayfqx1a8qr761mqjfxczf8lwlap392n"; type = "gem"; }; version = "2.2.2"; }; memoist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0i9wpzix3sjhf6d9zw60dm4371iq8kyz7ckh2qapan2vyaim6b55"; type = "gem"; }; version = "0.16.2"; }; mini_magick = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1aj604x11d9pksbljh0l38f70b558rhdgji1s9i763hiagvvx2hs"; type = "gem"; }; version = "4.11.0"; }; mini_mime = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1axm0rxyx3ss93wbmfkm78a6x03l8y4qy60rhkkiq0aza0vwq3ha"; type = "gem"; }; version = "1.0.2"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09k0b3cybqilk1gwrwwain95rdypixb2q9w65gd44gfzsd84xi1x"; type = "gem"; }; version = "2.0.0"; }; nanaimo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xi36h3f7nm8bc2k0b6svpda1lyank2gf872lxjbhw3h95hdrbma"; type = "gem"; }; version = "0.3.0"; }; naturally = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04x1nkx6gkqzlc4phdvq05v3vjds6mgqhjqzqpcs6vdh5xyqrf59"; type = "gem"; }; version = "2.2.1"; }; os = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12fli64wz5j9868gpzv5wqsingk1jk457qyqksv9ksmq9b0zpc9x"; type = "gem"; }; version = "1.1.1"; }; plist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1whhr897z6z6av85x2cipyjk46bwh6s4wx6nbrcd3iifnzvbqs7l"; type = "gem"; }; version = "3.6.0"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xqcgkl7bwws1qrlnmxgh8g4g9m10vg60bhlw40fplninb3ng6d9"; type = "gem"; }; version = "4.0.6"; }; rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1iik52mf9ky4cgs38fp2m8r6skdkq1yz23vh18lk95fhbcxb6a67"; type = "gem"; }; version = "13.0.3"; }; representable = { - dependencies = ["declarative" "declarative-option" "uber"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "declarative" + "declarative-option" + "uber" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0qm9rgi1j5a6nv726ka4mmixivlxfsg91h8rpp72wwd4vqbkkm07"; type = "gem"; }; version = "3.0.4"; }; retriable = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q48hqws2dy1vws9schc0kmina40gy7sn5qsndpsfqdslh65snha"; type = "gem"; }; version = "3.1.2"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1mkvkcw9fhpaizrhca0pdgjcrbns48rlz4g6lavl5gjjq3rk2sq3"; type = "gem"; }; version = "3.2.4"; }; rouge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sfikq1q8xyqqx690iiz7ybhzx87am4w50w8f2nq36l3asw4x89d"; type = "gem"; }; version = "2.0.7"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15wfcqxyfgka05v2a7kpg64x57gl1y4xzvnc9lh60bqx5sf1iqrs"; type = "gem"; }; version = "0.0.4"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0590m2pr9i209pp5z4mx0nb1961ishdiqb28995hw1nln1d1b5ji"; type = "gem"; }; version = "2.3.0"; }; security = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ryjxs0j66wrbky2c08yf0mllwalvpg12rpxzbdx2rdhj3cbrlxa"; type = "gem"; }; version = "0.1.3"; }; signet = { - dependencies = ["addressable" "faraday" "jwt" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "faraday" + "jwt" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "10g2667fvxnc50hcd1aywgsbf8j7nrckg3n7zjvywmyz82pwmpqp"; type = "gem"; }; version = "0.14.0"; }; simctl = { - dependencies = ["CFPropertyList" "naturally"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "CFPropertyList" + "naturally" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1v9rsdmg5c5kkf8ps47xnrfbvjnq11sbaifr186jwkh4npawz00x"; type = "gem"; }; version = "1.6.8"; }; slack-notifier = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pkfn99dhy5s526r6k8d87fwwb6j287ga9s7lxqmh60z28xqh3bv"; type = "gem"; }; version = "2.3.2"; }; terminal-notifier = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1slc0y8pjpw30hy21v8ypafi8r7z9jlj4bjbgz03b65b28i2n3bs"; type = "gem"; }; version = "2.0.0"; }; terminal-table = { - dependencies = ["unicode-display_width"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unicode-display_width" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1512cngw35hsmhvw4c05rscihc59mnj09m249sm9p3pik831ydqk"; type = "gem"; }; version = "1.8.0"; }; tty-cursor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j5zw041jgkmn605ya1zc151bxgxl6v192v2i26qhxx7ws2l2lvr"; type = "gem"; }; version = "0.7.1"; }; tty-screen = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18jr6s1cg8yb26wzkqa6874q0z93rq0y5aw092kdqazk71y6a235"; type = "gem"; }; version = "0.8.1"; }; tty-spinner = { - dependencies = ["tty-cursor"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-cursor" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hh5awmijnzw9flmh5ak610x1d00xiqagxa5mbr63ysggc26y0qf"; type = "gem"; }; version = "0.9.3"; }; uber = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1p1mm7mngg40x05z52md3mbamkng0zpajbzqjjwmsyw0zw3v9vjv"; type = "gem"; }; version = "0.1.0"; }; unf = { - dependencies = ["unf_ext"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unf_ext" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bh2cf73i2ffh4fcpdn9ir4mhq8zi50ik0zqa1braahzadx536a9"; type = "gem"; }; version = "0.1.4"; }; unf_ext = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wc47r23h063l8ysws8sy24gzh74mks81cak3lkzlrw4qkqb3sg4"; type = "gem"; }; version = "0.0.7.7"; }; unicode-display_width = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06i3id27s60141x6fdnjn5rar1cywdwy64ilc59cz937303q3mna"; type = "gem"; }; version = "1.7.0"; }; webrick = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d4cvgmxhfczxiq5fr534lmizkhigd15bsx5719r5ds7k7ivisc7"; type = "gem"; }; version = "1.7.0"; }; word_wrap = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1iyc5bc7dbgsd8j3yk1i99ral39f23l6wapi0083fbl19hid8mpm"; type = "gem"; }; version = "1.0.0"; }; xcode-install = { - dependencies = ["claide" "fastlane"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "claide" + "fastlane" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yhslanqw8r0mhls2hira05c8xjzzr7mnz1ab9p5qwg4z45ddjj8"; type = "gem"; }; version = "2.6.8"; }; xcodeproj = { - dependencies = ["CFPropertyList" "atomos" "claide" "colored2" "nanaimo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "CFPropertyList" + "atomos" + "claide" + "colored2" + "nanaimo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1411j6sfnz0cx4fiw52f0yqx4bgcn8cmpgi3i5rwmmahayyjz2fn"; type = "gem"; }; version = "1.19.0"; }; xcpretty = { - dependencies = ["rouge"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rouge" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xq47q2h5llj7b54rws4796904vnnjz7qqnacdv7wlp3gdbwrivm"; type = "gem"; }; version = "0.3.0"; }; xcpretty-travis-formatter = { - dependencies = ["xcpretty"]; - groups = ["default"]; - platforms = []; + dependencies = [ "xcpretty" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14rg4f70klrs910n7rsgfa4dn8s2qyny55194ax2qyyb2wpk7k5a"; type = "gem"; }; diff --git a/pkgs/development/tools/xcpretty/default.nix b/pkgs/development/tools/xcpretty/default.nix index 9c24b98100505c..322e3f4cae1790 100644 --- a/pkgs/development/tools/xcpretty/default.nix +++ b/pkgs/development/tools/xcpretty/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "xcpretty"; @@ -11,10 +15,10 @@ bundlerApp { }; meta = with lib; { - description = "Flexible and fast xcodebuild formatter"; - homepage = "https://github.com/supermarin/xcpretty"; - license = licenses.mit; - maintainers = with maintainers; [ + description = "Flexible and fast xcodebuild formatter"; + homepage = "https://github.com/supermarin/xcpretty"; + license = licenses.mit; + maintainers = with maintainers; [ nicknovitski ]; }; diff --git a/pkgs/development/tools/xcpretty/gemset.nix b/pkgs/development/tools/xcpretty/gemset.nix index ef5591c30cf3ec..97dffa3040fd7b 100644 --- a/pkgs/development/tools/xcpretty/gemset.nix +++ b/pkgs/development/tools/xcpretty/gemset.nix @@ -1,16 +1,16 @@ { rouge = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sfikq1q8xyqqx690iiz7ybhzx87am4w50w8f2nq36l3asw4x89d"; type = "gem"; }; version = "2.0.7"; }; xcpretty = { - dependencies = ["rouge"]; + dependencies = [ "rouge" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xq47q2h5llj7b54rws4796904vnnjz7qqnacdv7wlp3gdbwrivm"; type = "gem"; }; diff --git a/pkgs/development/tools/yarn-berry/default.nix b/pkgs/development/tools/yarn-berry/default.nix index d07f27de42e512..e0ec4b878f9c05 100644 --- a/pkgs/development/tools/yarn-berry/default.nix +++ b/pkgs/development/tools/yarn-berry/default.nix @@ -1,4 +1,11 @@ -{ fetchFromGitHub, lib, nodejs, stdenv, testers, yarn }: +{ + fetchFromGitHub, + lib, + nodejs, + stdenv, + testers, + yarn, +}: stdenv.mkDerivation (finalAttrs: { pname = "yarn-berry"; @@ -45,7 +52,11 @@ stdenv.mkDerivation (finalAttrs: { homepage = "https://yarnpkg.com/"; description = "Fast, reliable, and secure dependency management"; license = licenses.bsd2; - maintainers = with maintainers; [ ryota-ka pyrox0 DimitarNestorov ]; + maintainers = with maintainers; [ + ryota-ka + pyrox0 + DimitarNestorov + ]; platforms = platforms.unix; mainProgram = "yarn"; }; diff --git a/pkgs/development/tools/yarn2nix-moretea/yarn2nix/yarn.nix b/pkgs/development/tools/yarn2nix-moretea/yarn2nix/yarn.nix index a6d7f79a7bee1d..159c136f6658eb 100644 --- a/pkgs/development/tools/yarn2nix-moretea/yarn2nix/yarn.nix +++ b/pkgs/development/tools/yarn2nix-moretea/yarn2nix/yarn.nix @@ -1,11 +1,18 @@ -{ fetchurl, fetchgit, linkFarm, runCommand, gnutar }: rec { +{ + fetchurl, + fetchgit, + linkFarm, + runCommand, + gnutar, +}: +rec { offline_cache = linkFarm "offline" packages; packages = [ { name = "_babel_code_frame___code_frame_7.8.3.tgz"; path = fetchurl { name = "_babel_code_frame___code_frame_7.8.3.tgz"; - url = "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.8.3.tgz"; + url = "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.8.3.tgz"; sha512 = "a9gxpmdXtZEInkCSHUJDLHZVBgb1QS0jhss4cPP93EW7s+uC5bikET2twEF3KV+7rDblJcmNvTR7VJejqd2C2g=="; }; } @@ -13,7 +20,7 @@ name = "_babel_generator___generator_7.9.6.tgz"; path = fetchurl { name = "_babel_generator___generator_7.9.6.tgz"; - url = "https://registry.yarnpkg.com/@babel/generator/-/generator-7.9.6.tgz"; + url = "https://registry.yarnpkg.com/@babel/generator/-/generator-7.9.6.tgz"; sha512 = "+htwWKJbH2bL72HRluF8zumBxzuX0ZZUFl3JLNyoUjM/Ho8wnVpPXM6aUz8cfKDqQ/h7zHqKt4xzJteUosckqQ=="; }; } @@ -21,7 +28,7 @@ name = "_babel_helper_function_name___helper_function_name_7.9.5.tgz"; path = fetchurl { name = "_babel_helper_function_name___helper_function_name_7.9.5.tgz"; - url = "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.9.5.tgz"; + url = "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.9.5.tgz"; sha512 = "JVcQZeXM59Cd1qanDUxv9fgJpt3NeKUaqBqUEvfmQ+BCOKq2xUgaWZW2hr0dkbyJgezYuplEoh5knmrnS68efw=="; }; } @@ -29,7 +36,7 @@ name = "_babel_helper_get_function_arity___helper_get_function_arity_7.8.3.tgz"; path = fetchurl { name = "_babel_helper_get_function_arity___helper_get_function_arity_7.8.3.tgz"; - url = "https://registry.yarnpkg.com/@babel/helper-get-function-arity/-/helper-get-function-arity-7.8.3.tgz"; + url = "https://registry.yarnpkg.com/@babel/helper-get-function-arity/-/helper-get-function-arity-7.8.3.tgz"; sha512 = "FVDR+Gd9iLjUMY1fzE2SR0IuaJToR4RkCDARVfsBBPSP53GEqSFjD8gNyxg246VUyc/ALRxFaAK8rVG7UT7xRA=="; }; } @@ -37,7 +44,7 @@ name = "_babel_helper_split_export_declaration___helper_split_export_declaration_7.8.3.tgz"; path = fetchurl { name = "_babel_helper_split_export_declaration___helper_split_export_declaration_7.8.3.tgz"; - url = "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.8.3.tgz"; + url = "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.8.3.tgz"; sha512 = "3x3yOeyBhW851hroze7ElzdkeRXQYQbFIb7gLK1WQYsw2GWDay5gAJNw1sWJ0VFP6z5J1whqeXH/WCdCjZv6dA=="; }; } @@ -45,7 +52,7 @@ name = "_babel_helper_validator_identifier___helper_validator_identifier_7.9.5.tgz"; path = fetchurl { name = "_babel_helper_validator_identifier___helper_validator_identifier_7.9.5.tgz"; - url = "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.9.5.tgz"; + url = "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.9.5.tgz"; sha512 = "/8arLKUFq882w4tWGj9JYzRpAlZgiWUJ+dtteNTDqrRBz9Iguck9Rn3ykuBDoUwh2TO4tSAJlrxDUOXWklJe4g=="; }; } @@ -53,7 +60,7 @@ name = "_babel_highlight___highlight_7.9.0.tgz"; path = fetchurl { name = "_babel_highlight___highlight_7.9.0.tgz"; - url = "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.9.0.tgz"; + url = "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.9.0.tgz"; sha512 = "lJZPilxX7Op3Nv/2cvFdnlepPXDxi29wxteT57Q965oc5R9v86ztx0jfxVrTcBk8C2kcPkkDa2Z4T3ZsPPVWsQ=="; }; } @@ -61,7 +68,7 @@ name = "_babel_parser___parser_7.9.6.tgz"; path = fetchurl { name = "_babel_parser___parser_7.9.6.tgz"; - url = "https://registry.yarnpkg.com/@babel/parser/-/parser-7.9.6.tgz"; + url = "https://registry.yarnpkg.com/@babel/parser/-/parser-7.9.6.tgz"; sha512 = "AoeIEJn8vt+d/6+PXDRPaksYhnlbMIiejioBZvvMQsOjW/JYK6k/0dKnvvP3EhK5GfMBWDPtrxRtegWdAcdq9Q=="; }; } @@ -69,7 +76,7 @@ name = "_babel_runtime_corejs3___runtime_corejs3_7.9.6.tgz"; path = fetchurl { name = "_babel_runtime_corejs3___runtime_corejs3_7.9.6.tgz"; - url = "https://registry.yarnpkg.com/@babel/runtime-corejs3/-/runtime-corejs3-7.9.6.tgz"; + url = "https://registry.yarnpkg.com/@babel/runtime-corejs3/-/runtime-corejs3-7.9.6.tgz"; sha512 = "6toWAfaALQjt3KMZQc6fABqZwUDDuWzz+cAfPhqyEnzxvdWOAkjwPNxgF8xlmo7OWLsSjaKjsskpKHRLaMArOA=="; }; } @@ -77,7 +84,7 @@ name = "_babel_runtime___runtime_7.9.6.tgz"; path = fetchurl { name = "_babel_runtime___runtime_7.9.6.tgz"; - url = "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.9.6.tgz"; + url = "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.9.6.tgz"; sha512 = "64AF1xY3OAkFHqOb9s4jpgk1Mm5vDZ4L3acHvAml+53nO1XbXLuDodsVpO4OIUsmemlUHMxNdYMNJmsvOwLrvQ=="; }; } @@ -85,7 +92,7 @@ name = "_babel_template___template_7.8.6.tgz"; path = fetchurl { name = "_babel_template___template_7.8.6.tgz"; - url = "https://registry.yarnpkg.com/@babel/template/-/template-7.8.6.tgz"; + url = "https://registry.yarnpkg.com/@babel/template/-/template-7.8.6.tgz"; sha512 = "zbMsPMy/v0PWFZEhQJ66bqjhH+z0JgMoBWuikXybgG3Gkd/3t5oQ1Rw2WQhnSrsOmsKXnZOx15tkC4qON/+JPg=="; }; } @@ -93,7 +100,7 @@ name = "_babel_traverse___traverse_7.9.6.tgz"; path = fetchurl { name = "_babel_traverse___traverse_7.9.6.tgz"; - url = "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.9.6.tgz"; + url = "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.9.6.tgz"; sha512 = "b3rAHSjbxy6VEAvlxM8OV/0X4XrG72zoxme6q1MOoe2vd0bEc+TwayhuC1+Dfgqh1QEG+pj7atQqvUprHIccsg=="; }; } @@ -101,7 +108,7 @@ name = "_babel_types___types_7.9.6.tgz"; path = fetchurl { name = "_babel_types___types_7.9.6.tgz"; - url = "https://registry.yarnpkg.com/@babel/types/-/types-7.9.6.tgz"; + url = "https://registry.yarnpkg.com/@babel/types/-/types-7.9.6.tgz"; sha512 = "qxXzvBO//jO9ZnoasKF1uJzHd2+M6Q2ZPIVfnFps8JJvXy0ZBbwbNOmE6SGIY5XOY6d1Bo5lb9d9RJ8nv3WSeA=="; }; } @@ -109,7 +116,7 @@ name = "_samverschueren_stream_to_observable___stream_to_observable_0.3.0.tgz"; path = fetchurl { name = "_samverschueren_stream_to_observable___stream_to_observable_0.3.0.tgz"; - url = "https://registry.yarnpkg.com/@samverschueren/stream-to-observable/-/stream-to-observable-0.3.0.tgz"; + url = "https://registry.yarnpkg.com/@samverschueren/stream-to-observable/-/stream-to-observable-0.3.0.tgz"; sha512 = "MI4Xx6LHs4Webyvi6EbspgyAb4D2Q2VtnCQ1blOJcoLS6mVa8lNN2rkIy1CVxfTUpoyIbCTkXES1rLXztFD1lg=="; }; } @@ -117,7 +124,7 @@ name = "_yarnpkg_lockfile___lockfile_1.1.0.tgz"; path = fetchurl { name = "_yarnpkg_lockfile___lockfile_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz"; sha512 = "GpSwvyXOcOOlV70vbnzjj4fW5xW/FdUF6nQEt1ENy7m4ZCczi1+/buVUPAqmGfqznsORNFzUMjctTIp8a9tuCQ=="; }; } @@ -125,7 +132,7 @@ name = "abbrev___abbrev_1.1.1.tgz"; path = fetchurl { name = "abbrev___abbrev_1.1.1.tgz"; - url = "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz"; + url = "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz"; sha512 = "nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q=="; }; } @@ -133,7 +140,7 @@ name = "acorn_jsx___acorn_jsx_3.0.1.tgz"; path = fetchurl { name = "acorn_jsx___acorn_jsx_3.0.1.tgz"; - url = "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-3.0.1.tgz"; + url = "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-3.0.1.tgz"; sha1 = "r9+UiPsezvyDSPb7IvRk4ypYs2s="; }; } @@ -141,7 +148,7 @@ name = "acorn_jsx___acorn_jsx_5.2.0.tgz"; path = fetchurl { name = "acorn_jsx___acorn_jsx_5.2.0.tgz"; - url = "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.2.0.tgz"; + url = "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.2.0.tgz"; sha512 = "HiUX/+K2YpkpJ+SzBffkM/AQ2YE03S0U1kjTLVpoJdhZMOWy8qvXVN9JdLqv2QsaQ6MPYQIuNmwD8zOiYUofLQ=="; }; } @@ -149,7 +156,7 @@ name = "acorn___acorn_3.3.0.tgz"; path = fetchurl { name = "acorn___acorn_3.3.0.tgz"; - url = "https://registry.yarnpkg.com/acorn/-/acorn-3.3.0.tgz"; + url = "https://registry.yarnpkg.com/acorn/-/acorn-3.3.0.tgz"; sha1 = "ReN/s56No/JbruP/U2niu18iAXo="; }; } @@ -157,7 +164,7 @@ name = "acorn___acorn_5.7.4.tgz"; path = fetchurl { name = "acorn___acorn_5.7.4.tgz"; - url = "https://registry.yarnpkg.com/acorn/-/acorn-5.7.4.tgz"; + url = "https://registry.yarnpkg.com/acorn/-/acorn-5.7.4.tgz"; sha512 = "1D++VG7BhrtvQpNbBzovKNc1FLGGEE/oGe7b9xJm/RFHMBeUaUGpluV9RLjZa47YFdPcDAenEYuq9pQPcMdLJg=="; }; } @@ -165,7 +172,7 @@ name = "acorn___acorn_6.4.1.tgz"; path = fetchurl { name = "acorn___acorn_6.4.1.tgz"; - url = "https://registry.yarnpkg.com/acorn/-/acorn-6.4.1.tgz"; + url = "https://registry.yarnpkg.com/acorn/-/acorn-6.4.1.tgz"; sha512 = "ZVA9k326Nwrj3Cj9jlh3wGFutC2ZornPNARZwsNYqQYgN0EsV2d53w5RN/co65Ohn4sUAUtb1rSUAOD6XN9idA=="; }; } @@ -173,7 +180,7 @@ name = "ajv_keywords___ajv_keywords_2.1.1.tgz"; path = fetchurl { name = "ajv_keywords___ajv_keywords_2.1.1.tgz"; - url = "https://registry.yarnpkg.com/ajv-keywords/-/ajv-keywords-2.1.1.tgz"; + url = "https://registry.yarnpkg.com/ajv-keywords/-/ajv-keywords-2.1.1.tgz"; sha1 = "YXmX/F9gV2iUxDX5QNgZ4TW4B2I="; }; } @@ -181,7 +188,7 @@ name = "ajv___ajv_5.5.2.tgz"; path = fetchurl { name = "ajv___ajv_5.5.2.tgz"; - url = "https://registry.yarnpkg.com/ajv/-/ajv-5.5.2.tgz"; + url = "https://registry.yarnpkg.com/ajv/-/ajv-5.5.2.tgz"; sha1 = "c7Xuyj+rZT49P5Qis0GtQiBdyWU="; }; } @@ -189,7 +196,7 @@ name = "ajv___ajv_6.12.2.tgz"; path = fetchurl { name = "ajv___ajv_6.12.2.tgz"; - url = "https://registry.yarnpkg.com/ajv/-/ajv-6.12.2.tgz"; + url = "https://registry.yarnpkg.com/ajv/-/ajv-6.12.2.tgz"; sha512 = "k+V+hzjm5q/Mr8ef/1Y9goCmlsK4I6Sm74teeyGvFk1XrOsbsKLjEdrvny42CZ+a8sXbk8KWpY/bDwS+FLL2UQ=="; }; } @@ -197,7 +204,7 @@ name = "ansi_escapes___ansi_escapes_3.2.0.tgz"; path = fetchurl { name = "ansi_escapes___ansi_escapes_3.2.0.tgz"; - url = "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-3.2.0.tgz"; + url = "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-3.2.0.tgz"; sha512 = "cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ=="; }; } @@ -205,7 +212,7 @@ name = "ansi_regex___ansi_regex_2.1.1.tgz"; path = fetchurl { name = "ansi_regex___ansi_regex_2.1.1.tgz"; - url = "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz"; + url = "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz"; sha1 = "w7M6te42DYbg5ijwRorn7yfWVN8="; }; } @@ -213,7 +220,7 @@ name = "ansi_regex___ansi_regex_3.0.0.tgz"; path = fetchurl { name = "ansi_regex___ansi_regex_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.0.tgz"; sha1 = "7QMXwyIGT3lGbAKWa922Bas32Zg="; }; } @@ -221,7 +228,7 @@ name = "ansi_regex___ansi_regex_4.1.0.tgz"; path = fetchurl { name = "ansi_regex___ansi_regex_4.1.0.tgz"; - url = "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-4.1.0.tgz"; + url = "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-4.1.0.tgz"; sha512 = "1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg=="; }; } @@ -229,7 +236,7 @@ name = "ansi_styles___ansi_styles_2.2.1.tgz"; path = fetchurl { name = "ansi_styles___ansi_styles_2.2.1.tgz"; - url = "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-2.2.1.tgz"; + url = "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-2.2.1.tgz"; sha1 = "tDLdM1i2NM914eRmQ2gkBTPB3b4="; }; } @@ -237,7 +244,7 @@ name = "ansi_styles___ansi_styles_3.2.1.tgz"; path = fetchurl { name = "ansi_styles___ansi_styles_3.2.1.tgz"; - url = "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz"; + url = "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz"; sha512 = "VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA=="; }; } @@ -245,7 +252,7 @@ name = "any_observable___any_observable_0.3.0.tgz"; path = fetchurl { name = "any_observable___any_observable_0.3.0.tgz"; - url = "https://registry.yarnpkg.com/any-observable/-/any-observable-0.3.0.tgz"; + url = "https://registry.yarnpkg.com/any-observable/-/any-observable-0.3.0.tgz"; sha512 = "/FQM1EDkTsf63Ub2C6O7GuYFDsSXUwsaZDurV0np41ocwq0jthUAYCmhBX9f+KwlaCgIuWyr/4WlUQUBfKfZog=="; }; } @@ -253,7 +260,7 @@ name = "argparse___argparse_1.0.10.tgz"; path = fetchurl { name = "argparse___argparse_1.0.10.tgz"; - url = "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz"; + url = "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz"; sha512 = "o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg=="; }; } @@ -261,7 +268,7 @@ name = "aria_query___aria_query_3.0.0.tgz"; path = fetchurl { name = "aria_query___aria_query_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/aria-query/-/aria-query-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/aria-query/-/aria-query-3.0.0.tgz"; sha1 = "ZbP8wcoRVajJrmTW7uKX8V1RM8w="; }; } @@ -269,7 +276,7 @@ name = "arr_diff___arr_diff_4.0.0.tgz"; path = fetchurl { name = "arr_diff___arr_diff_4.0.0.tgz"; - url = "https://registry.yarnpkg.com/arr-diff/-/arr-diff-4.0.0.tgz"; + url = "https://registry.yarnpkg.com/arr-diff/-/arr-diff-4.0.0.tgz"; sha1 = "1kYQdP6/7HHn4VI1dhoyml3HxSA="; }; } @@ -277,7 +284,7 @@ name = "arr_flatten___arr_flatten_1.1.0.tgz"; path = fetchurl { name = "arr_flatten___arr_flatten_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/arr-flatten/-/arr-flatten-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/arr-flatten/-/arr-flatten-1.1.0.tgz"; sha512 = "L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg=="; }; } @@ -285,7 +292,7 @@ name = "arr_union___arr_union_3.1.0.tgz"; path = fetchurl { name = "arr_union___arr_union_3.1.0.tgz"; - url = "https://registry.yarnpkg.com/arr-union/-/arr-union-3.1.0.tgz"; + url = "https://registry.yarnpkg.com/arr-union/-/arr-union-3.1.0.tgz"; sha1 = "45sJrqne+Gao8gbiiK9jkZuuOcQ="; }; } @@ -293,7 +300,7 @@ name = "array_includes___array_includes_3.1.1.tgz"; path = fetchurl { name = "array_includes___array_includes_3.1.1.tgz"; - url = "https://registry.yarnpkg.com/array-includes/-/array-includes-3.1.1.tgz"; + url = "https://registry.yarnpkg.com/array-includes/-/array-includes-3.1.1.tgz"; sha512 = "c2VXaCHl7zPsvpkFsw4nxvFie4fh1ur9bpcgsVkIjqn0H/Xwdg+7fv3n2r/isyS8EBj5b06M9kHyZuIr4El6WQ=="; }; } @@ -301,7 +308,7 @@ name = "array_union___array_union_1.0.2.tgz"; path = fetchurl { name = "array_union___array_union_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/array-union/-/array-union-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/array-union/-/array-union-1.0.2.tgz"; sha1 = "mjRBDk9OPaI96jdb5b5w8kd47Dk="; }; } @@ -309,7 +316,7 @@ name = "array_uniq___array_uniq_1.0.3.tgz"; path = fetchurl { name = "array_uniq___array_uniq_1.0.3.tgz"; - url = "https://registry.yarnpkg.com/array-uniq/-/array-uniq-1.0.3.tgz"; + url = "https://registry.yarnpkg.com/array-uniq/-/array-uniq-1.0.3.tgz"; sha1 = "r2rId6Jcx/dOBYiUdThY39sk/bY="; }; } @@ -317,7 +324,7 @@ name = "array_unique___array_unique_0.3.2.tgz"; path = fetchurl { name = "array_unique___array_unique_0.3.2.tgz"; - url = "https://registry.yarnpkg.com/array-unique/-/array-unique-0.3.2.tgz"; + url = "https://registry.yarnpkg.com/array-unique/-/array-unique-0.3.2.tgz"; sha1 = "qJS3XUvE9s1nnvMkSp/Y9Gri1Cg="; }; } @@ -325,7 +332,7 @@ name = "array.prototype.flat___array.prototype.flat_1.2.3.tgz"; path = fetchurl { name = "array.prototype.flat___array.prototype.flat_1.2.3.tgz"; - url = "https://registry.yarnpkg.com/array.prototype.flat/-/array.prototype.flat-1.2.3.tgz"; + url = "https://registry.yarnpkg.com/array.prototype.flat/-/array.prototype.flat-1.2.3.tgz"; sha512 = "gBlRZV0VSmfPIeWfuuy56XZMvbVfbEUnOXUvt3F/eUUUSyzlgLxhEX4YAEpxNAogRGehPSnfXyPtYyKAhkzQhQ=="; }; } @@ -333,7 +340,7 @@ name = "arrify___arrify_1.0.1.tgz"; path = fetchurl { name = "arrify___arrify_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/arrify/-/arrify-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/arrify/-/arrify-1.0.1.tgz"; sha1 = "iYUI2iIm84DfkEcoRWhJwVAaSw0="; }; } @@ -341,7 +348,7 @@ name = "assign_symbols___assign_symbols_1.0.0.tgz"; path = fetchurl { name = "assign_symbols___assign_symbols_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/assign-symbols/-/assign-symbols-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/assign-symbols/-/assign-symbols-1.0.0.tgz"; sha1 = "WWZ/QfrdTyDMvCu5a41Pf3jsA2c="; }; } @@ -349,7 +356,7 @@ name = "ast_types_flow___ast_types_flow_0.0.7.tgz"; path = fetchurl { name = "ast_types_flow___ast_types_flow_0.0.7.tgz"; - url = "https://registry.yarnpkg.com/ast-types-flow/-/ast-types-flow-0.0.7.tgz"; + url = "https://registry.yarnpkg.com/ast-types-flow/-/ast-types-flow-0.0.7.tgz"; sha1 = "9wtzXGvKGlycItmCw+Oef+ujva0="; }; } @@ -357,7 +364,7 @@ name = "astral_regex___astral_regex_1.0.0.tgz"; path = fetchurl { name = "astral_regex___astral_regex_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/astral-regex/-/astral-regex-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/astral-regex/-/astral-regex-1.0.0.tgz"; sha512 = "+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg=="; }; } @@ -365,7 +372,7 @@ name = "atob___atob_2.1.2.tgz"; path = fetchurl { name = "atob___atob_2.1.2.tgz"; - url = "https://registry.yarnpkg.com/atob/-/atob-2.1.2.tgz"; + url = "https://registry.yarnpkg.com/atob/-/atob-2.1.2.tgz"; sha512 = "Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg=="; }; } @@ -373,7 +380,7 @@ name = "axobject_query___axobject_query_2.1.2.tgz"; path = fetchurl { name = "axobject_query___axobject_query_2.1.2.tgz"; - url = "https://registry.yarnpkg.com/axobject-query/-/axobject-query-2.1.2.tgz"; + url = "https://registry.yarnpkg.com/axobject-query/-/axobject-query-2.1.2.tgz"; sha512 = "ICt34ZmrVt8UQnvPl6TVyDTkmhXmAyAT4Jh5ugfGUX4MOrZ+U/ZY6/sdylRw3qGNr9Ub5AJsaHeDMzNLehRdOQ=="; }; } @@ -381,7 +388,7 @@ name = "babel_code_frame___babel_code_frame_6.26.0.tgz"; path = fetchurl { name = "babel_code_frame___babel_code_frame_6.26.0.tgz"; - url = "https://registry.yarnpkg.com/babel-code-frame/-/babel-code-frame-6.26.0.tgz"; + url = "https://registry.yarnpkg.com/babel-code-frame/-/babel-code-frame-6.26.0.tgz"; sha1 = "Y/1D99weO7fONZR9uP42mj9Yx0s="; }; } @@ -389,7 +396,7 @@ name = "babel_eslint___babel_eslint_10.1.0.tgz"; path = fetchurl { name = "babel_eslint___babel_eslint_10.1.0.tgz"; - url = "https://registry.yarnpkg.com/babel-eslint/-/babel-eslint-10.1.0.tgz"; + url = "https://registry.yarnpkg.com/babel-eslint/-/babel-eslint-10.1.0.tgz"; sha512 = "ifWaTHQ0ce+448CYop8AdrQiBsGrnC+bMgfyKFdi6EsPLTAWG+QfyDeM6OH+FmWnKvEq5NnBMLvlBUPKQZoDSg=="; }; } @@ -397,7 +404,7 @@ name = "babel_runtime___babel_runtime_6.26.0.tgz"; path = fetchurl { name = "babel_runtime___babel_runtime_6.26.0.tgz"; - url = "https://registry.yarnpkg.com/babel-runtime/-/babel-runtime-6.26.0.tgz"; + url = "https://registry.yarnpkg.com/babel-runtime/-/babel-runtime-6.26.0.tgz"; sha1 = "llxwWGaOgrVde/4E/yM3vItWR/4="; }; } @@ -405,7 +412,7 @@ name = "balanced_match___balanced_match_1.0.0.tgz"; path = fetchurl { name = "balanced_match___balanced_match_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz"; sha1 = "ibTRmasr7kneFk6gK4nORi1xt2c="; }; } @@ -413,7 +420,7 @@ name = "base___base_0.11.2.tgz"; path = fetchurl { name = "base___base_0.11.2.tgz"; - url = "https://registry.yarnpkg.com/base/-/base-0.11.2.tgz"; + url = "https://registry.yarnpkg.com/base/-/base-0.11.2.tgz"; sha512 = "5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg=="; }; } @@ -421,7 +428,7 @@ name = "boolify___boolify_1.0.1.tgz"; path = fetchurl { name = "boolify___boolify_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/boolify/-/boolify-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/boolify/-/boolify-1.0.1.tgz"; sha1 = "tcCeF8rNET0Rt7s+04TMASmU2Gs="; }; } @@ -429,7 +436,7 @@ name = "brace_expansion___brace_expansion_1.1.11.tgz"; path = fetchurl { name = "brace_expansion___brace_expansion_1.1.11.tgz"; - url = "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz"; + url = "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz"; sha512 = "iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA=="; }; } @@ -437,7 +444,7 @@ name = "braces___braces_2.3.2.tgz"; path = fetchurl { name = "braces___braces_2.3.2.tgz"; - url = "https://registry.yarnpkg.com/braces/-/braces-2.3.2.tgz"; + url = "https://registry.yarnpkg.com/braces/-/braces-2.3.2.tgz"; sha512 = "aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w=="; }; } @@ -445,7 +452,7 @@ name = "buffer_from___buffer_from_1.1.1.tgz"; path = fetchurl { name = "buffer_from___buffer_from_1.1.1.tgz"; - url = "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.1.tgz"; + url = "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.1.tgz"; sha512 = "MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A=="; }; } @@ -453,7 +460,7 @@ name = "cache_base___cache_base_1.0.1.tgz"; path = fetchurl { name = "cache_base___cache_base_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/cache-base/-/cache-base-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/cache-base/-/cache-base-1.0.1.tgz"; sha512 = "AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ=="; }; } @@ -461,7 +468,7 @@ name = "caller_callsite___caller_callsite_2.0.0.tgz"; path = fetchurl { name = "caller_callsite___caller_callsite_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/caller-callsite/-/caller-callsite-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/caller-callsite/-/caller-callsite-2.0.0.tgz"; sha1 = "hH4PzgoiN1CpoCfFSzNzGtMVQTQ="; }; } @@ -469,7 +476,7 @@ name = "caller_path___caller_path_0.1.0.tgz"; path = fetchurl { name = "caller_path___caller_path_0.1.0.tgz"; - url = "https://registry.yarnpkg.com/caller-path/-/caller-path-0.1.0.tgz"; + url = "https://registry.yarnpkg.com/caller-path/-/caller-path-0.1.0.tgz"; sha1 = "lAhe9jWB7NPaqSREqP6U6CV3dR8="; }; } @@ -477,7 +484,7 @@ name = "caller_path___caller_path_2.0.0.tgz"; path = fetchurl { name = "caller_path___caller_path_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/caller-path/-/caller-path-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/caller-path/-/caller-path-2.0.0.tgz"; sha1 = "Ro+DBE42mrIBD6xfBs7uFbsssfQ="; }; } @@ -485,7 +492,7 @@ name = "callsites___callsites_0.2.0.tgz"; path = fetchurl { name = "callsites___callsites_0.2.0.tgz"; - url = "https://registry.yarnpkg.com/callsites/-/callsites-0.2.0.tgz"; + url = "https://registry.yarnpkg.com/callsites/-/callsites-0.2.0.tgz"; sha1 = "r6uWJikQp/M8GaV3WCXGnzTjUMo="; }; } @@ -493,7 +500,7 @@ name = "callsites___callsites_2.0.0.tgz"; path = fetchurl { name = "callsites___callsites_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/callsites/-/callsites-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/callsites/-/callsites-2.0.0.tgz"; sha1 = "BuuE8A7qQT2oav/vrL/7Ngk7PFA="; }; } @@ -501,7 +508,7 @@ name = "callsites___callsites_3.1.0.tgz"; path = fetchurl { name = "callsites___callsites_3.1.0.tgz"; - url = "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz"; + url = "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz"; sha512 = "P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ=="; }; } @@ -509,7 +516,7 @@ name = "camelcase_keys___camelcase_keys_4.2.0.tgz"; path = fetchurl { name = "camelcase_keys___camelcase_keys_4.2.0.tgz"; - url = "https://registry.yarnpkg.com/camelcase-keys/-/camelcase-keys-4.2.0.tgz"; + url = "https://registry.yarnpkg.com/camelcase-keys/-/camelcase-keys-4.2.0.tgz"; sha1 = "oqpfsa9oh1glnDLBQUJteJI7m3c="; }; } @@ -517,7 +524,7 @@ name = "camelcase___camelcase_4.1.0.tgz"; path = fetchurl { name = "camelcase___camelcase_4.1.0.tgz"; - url = "https://registry.yarnpkg.com/camelcase/-/camelcase-4.1.0.tgz"; + url = "https://registry.yarnpkg.com/camelcase/-/camelcase-4.1.0.tgz"; sha1 = "1UVjW+HjPFQmScaRc+Xeas+uNN0="; }; } @@ -525,7 +532,7 @@ name = "chalk___chalk_2.3.0.tgz"; path = fetchurl { name = "chalk___chalk_2.3.0.tgz"; - url = "https://registry.yarnpkg.com/chalk/-/chalk-2.3.0.tgz"; + url = "https://registry.yarnpkg.com/chalk/-/chalk-2.3.0.tgz"; sha512 = "Az5zJR2CBujap2rqXGaJKaPHyJ0IrUimvYNX+ncCy8PJP4ltOGTrHUIo097ZaL2zMeKYpiCdqDvS6zdrTFok3Q=="; }; } @@ -533,7 +540,7 @@ name = "chalk___chalk_1.1.3.tgz"; path = fetchurl { name = "chalk___chalk_1.1.3.tgz"; - url = "https://registry.yarnpkg.com/chalk/-/chalk-1.1.3.tgz"; + url = "https://registry.yarnpkg.com/chalk/-/chalk-1.1.3.tgz"; sha1 = "qBFcVeSnAv5NFQq9OHKCKn4J/Jg="; }; } @@ -541,7 +548,7 @@ name = "chalk___chalk_2.4.2.tgz"; path = fetchurl { name = "chalk___chalk_2.4.2.tgz"; - url = "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz"; + url = "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz"; sha512 = "Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ=="; }; } @@ -549,7 +556,7 @@ name = "chardet___chardet_0.4.2.tgz"; path = fetchurl { name = "chardet___chardet_0.4.2.tgz"; - url = "https://registry.yarnpkg.com/chardet/-/chardet-0.4.2.tgz"; + url = "https://registry.yarnpkg.com/chardet/-/chardet-0.4.2.tgz"; sha1 = "tUc7M9yXxCTl2Y3IfVXU2KKci/I="; }; } @@ -557,7 +564,7 @@ name = "chardet___chardet_0.7.0.tgz"; path = fetchurl { name = "chardet___chardet_0.7.0.tgz"; - url = "https://registry.yarnpkg.com/chardet/-/chardet-0.7.0.tgz"; + url = "https://registry.yarnpkg.com/chardet/-/chardet-0.7.0.tgz"; sha512 = "mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA=="; }; } @@ -565,7 +572,7 @@ name = "ci_info___ci_info_2.0.0.tgz"; path = fetchurl { name = "ci_info___ci_info_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz"; sha512 = "5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ=="; }; } @@ -573,7 +580,7 @@ name = "circular_json___circular_json_0.3.3.tgz"; path = fetchurl { name = "circular_json___circular_json_0.3.3.tgz"; - url = "https://registry.yarnpkg.com/circular-json/-/circular-json-0.3.3.tgz"; + url = "https://registry.yarnpkg.com/circular-json/-/circular-json-0.3.3.tgz"; sha512 = "UZK3NBx2Mca+b5LsG7bY183pHWt5Y1xts4P3Pz7ENTwGVnJOUWbRb3ocjvX7hx9tq/yTAdclXm9sZ38gNuem4A=="; }; } @@ -581,7 +588,7 @@ name = "class_utils___class_utils_0.3.6.tgz"; path = fetchurl { name = "class_utils___class_utils_0.3.6.tgz"; - url = "https://registry.yarnpkg.com/class-utils/-/class-utils-0.3.6.tgz"; + url = "https://registry.yarnpkg.com/class-utils/-/class-utils-0.3.6.tgz"; sha512 = "qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg=="; }; } @@ -589,7 +596,7 @@ name = "cli_cursor___cli_cursor_2.1.0.tgz"; path = fetchurl { name = "cli_cursor___cli_cursor_2.1.0.tgz"; - url = "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-2.1.0.tgz"; + url = "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-2.1.0.tgz"; sha1 = "s12sN2R5+sw+lHR9QdDQ9SOP/LU="; }; } @@ -597,7 +604,7 @@ name = "cli_truncate___cli_truncate_0.2.1.tgz"; path = fetchurl { name = "cli_truncate___cli_truncate_0.2.1.tgz"; - url = "https://registry.yarnpkg.com/cli-truncate/-/cli-truncate-0.2.1.tgz"; + url = "https://registry.yarnpkg.com/cli-truncate/-/cli-truncate-0.2.1.tgz"; sha1 = "nxXPuwcFAFNpIWxiasfQWrkN1XQ="; }; } @@ -605,7 +612,7 @@ name = "cli_width___cli_width_2.2.1.tgz"; path = fetchurl { name = "cli_width___cli_width_2.2.1.tgz"; - url = "https://registry.yarnpkg.com/cli-width/-/cli-width-2.2.1.tgz"; + url = "https://registry.yarnpkg.com/cli-width/-/cli-width-2.2.1.tgz"; sha512 = "GRMWDxpOB6Dgk2E5Uo+3eEBvtOOlimMmpbFiKuLFnQzYDavtLFY3K5ona41jgN/WdRZtG7utuVSVTL4HbZHGkw=="; }; } @@ -613,7 +620,7 @@ name = "cliui___cliui_3.2.0.tgz"; path = fetchurl { name = "cliui___cliui_3.2.0.tgz"; - url = "https://registry.yarnpkg.com/cliui/-/cliui-3.2.0.tgz"; + url = "https://registry.yarnpkg.com/cliui/-/cliui-3.2.0.tgz"; sha1 = "EgYBU3qRbSmUD5NNo7SNWFo5IT0="; }; } @@ -621,7 +628,7 @@ name = "co___co_4.6.0.tgz"; path = fetchurl { name = "co___co_4.6.0.tgz"; - url = "https://registry.yarnpkg.com/co/-/co-4.6.0.tgz"; + url = "https://registry.yarnpkg.com/co/-/co-4.6.0.tgz"; sha1 = "bqa989hTrlTMuOR7+gvz+QMfsYQ="; }; } @@ -629,7 +636,7 @@ name = "code_point_at___code_point_at_1.1.0.tgz"; path = fetchurl { name = "code_point_at___code_point_at_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz"; sha1 = "DQcLTQQ6W+ozovGkDi7bPZpMz3c="; }; } @@ -637,7 +644,7 @@ name = "collection_visit___collection_visit_1.0.0.tgz"; path = fetchurl { name = "collection_visit___collection_visit_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/collection-visit/-/collection-visit-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/collection-visit/-/collection-visit-1.0.0.tgz"; sha1 = "S8A3PBZLwykbTTaMgpzxqApZ3KA="; }; } @@ -645,7 +652,7 @@ name = "color_convert___color_convert_1.9.3.tgz"; path = fetchurl { name = "color_convert___color_convert_1.9.3.tgz"; - url = "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz"; + url = "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz"; sha512 = "QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg=="; }; } @@ -653,7 +660,7 @@ name = "color_name___color_name_1.1.3.tgz"; path = fetchurl { name = "color_name___color_name_1.1.3.tgz"; - url = "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz"; + url = "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz"; sha1 = "p9BVi9icQveV3UIyj3QIMcpTvCU="; }; } @@ -661,7 +668,7 @@ name = "commander___commander_2.20.3.tgz"; path = fetchurl { name = "commander___commander_2.20.3.tgz"; - url = "https://registry.yarnpkg.com/commander/-/commander-2.20.3.tgz"; + url = "https://registry.yarnpkg.com/commander/-/commander-2.20.3.tgz"; sha512 = "GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ=="; }; } @@ -669,7 +676,7 @@ name = "common_tags___common_tags_1.8.0.tgz"; path = fetchurl { name = "common_tags___common_tags_1.8.0.tgz"; - url = "https://registry.yarnpkg.com/common-tags/-/common-tags-1.8.0.tgz"; + url = "https://registry.yarnpkg.com/common-tags/-/common-tags-1.8.0.tgz"; sha512 = "6P6g0uetGpW/sdyUy/iQQCbFF0kWVMSIVSyYz7Zgjcgh8mgw8PQzDNZeyZ5DQ2gM7LBoZPHmnjz8rUthkBG5tw=="; }; } @@ -677,7 +684,7 @@ name = "component_emitter___component_emitter_1.3.0.tgz"; path = fetchurl { name = "component_emitter___component_emitter_1.3.0.tgz"; - url = "https://registry.yarnpkg.com/component-emitter/-/component-emitter-1.3.0.tgz"; + url = "https://registry.yarnpkg.com/component-emitter/-/component-emitter-1.3.0.tgz"; sha512 = "Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg=="; }; } @@ -685,7 +692,7 @@ name = "concat_map___concat_map_0.0.1.tgz"; path = fetchurl { name = "concat_map___concat_map_0.0.1.tgz"; - url = "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz"; + url = "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz"; sha1 = "2Klr13/Wjfd5OnMDajug1UBdR3s="; }; } @@ -693,7 +700,7 @@ name = "concat_stream___concat_stream_1.6.2.tgz"; path = fetchurl { name = "concat_stream___concat_stream_1.6.2.tgz"; - url = "https://registry.yarnpkg.com/concat-stream/-/concat-stream-1.6.2.tgz"; + url = "https://registry.yarnpkg.com/concat-stream/-/concat-stream-1.6.2.tgz"; sha512 = "27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw=="; }; } @@ -701,7 +708,7 @@ name = "confusing_browser_globals___confusing_browser_globals_1.0.9.tgz"; path = fetchurl { name = "confusing_browser_globals___confusing_browser_globals_1.0.9.tgz"; - url = "https://registry.yarnpkg.com/confusing-browser-globals/-/confusing-browser-globals-1.0.9.tgz"; + url = "https://registry.yarnpkg.com/confusing-browser-globals/-/confusing-browser-globals-1.0.9.tgz"; sha512 = "KbS1Y0jMtyPgIxjO7ZzMAuUpAKMt1SzCL9fsrKsX6b0zJPTaT0SiSPmewwVZg9UAO83HVIlEhZF84LIjZ0lmAw=="; }; } @@ -709,7 +716,7 @@ name = "contains_path___contains_path_0.1.0.tgz"; path = fetchurl { name = "contains_path___contains_path_0.1.0.tgz"; - url = "https://registry.yarnpkg.com/contains-path/-/contains-path-0.1.0.tgz"; + url = "https://registry.yarnpkg.com/contains-path/-/contains-path-0.1.0.tgz"; sha1 = "/ozxhP9mcLa67wGp1IYaXL7EEgo="; }; } @@ -717,7 +724,7 @@ name = "copy_descriptor___copy_descriptor_0.1.1.tgz"; path = fetchurl { name = "copy_descriptor___copy_descriptor_0.1.1.tgz"; - url = "https://registry.yarnpkg.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz"; + url = "https://registry.yarnpkg.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz"; sha1 = "Z29us8OZl8LuGsOpJP1hJHSPV40="; }; } @@ -725,7 +732,7 @@ name = "core_js_pure___core_js_pure_3.6.5.tgz"; path = fetchurl { name = "core_js_pure___core_js_pure_3.6.5.tgz"; - url = "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.6.5.tgz"; + url = "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.6.5.tgz"; sha512 = "lacdXOimsiD0QyNf9BC/mxivNJ/ybBGJXQFKzRekp1WTHoVUWsUHEn+2T8GJAzzIhyOuXA+gOxCVN3l+5PLPUA=="; }; } @@ -733,7 +740,7 @@ name = "core_js___core_js_2.6.11.tgz"; path = fetchurl { name = "core_js___core_js_2.6.11.tgz"; - url = "https://registry.yarnpkg.com/core-js/-/core-js-2.6.11.tgz"; + url = "https://registry.yarnpkg.com/core-js/-/core-js-2.6.11.tgz"; sha512 = "5wjnpaT/3dV+XB4borEsnAYQchn00XSgTAWKDkEqv+K8KevjbzmofK6hfJ9TZIlpj2N0xQpazy7PiRQiWHqzWg=="; }; } @@ -741,7 +748,7 @@ name = "core_util_is___core_util_is_1.0.2.tgz"; path = fetchurl { name = "core_util_is___core_util_is_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz"; sha1 = "tf1UIgqivFq1eqtxQMlAdUUDwac="; }; } @@ -749,7 +756,7 @@ name = "cosmiconfig___cosmiconfig_5.2.1.tgz"; path = fetchurl { name = "cosmiconfig___cosmiconfig_5.2.1.tgz"; - url = "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-5.2.1.tgz"; + url = "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-5.2.1.tgz"; sha512 = "H65gsXo1SKjf8zmrJ67eJk8aIRKV5ff2D4uKZIBZShbhGSpEmsQOPW/SKMKYhSTrqR7ufy6RP69rPogdaPh/kA=="; }; } @@ -757,7 +764,7 @@ name = "cross_spawn___cross_spawn_5.1.0.tgz"; path = fetchurl { name = "cross_spawn___cross_spawn_5.1.0.tgz"; - url = "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-5.1.0.tgz"; + url = "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-5.1.0.tgz"; sha1 = "6L0O/uWPz/b4+UUQoKVUu/ojVEk="; }; } @@ -765,7 +772,7 @@ name = "cross_spawn___cross_spawn_6.0.5.tgz"; path = fetchurl { name = "cross_spawn___cross_spawn_6.0.5.tgz"; - url = "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-6.0.5.tgz"; + url = "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-6.0.5.tgz"; sha512 = "eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ=="; }; } @@ -773,7 +780,7 @@ name = "damerau_levenshtein___damerau_levenshtein_1.0.6.tgz"; path = fetchurl { name = "damerau_levenshtein___damerau_levenshtein_1.0.6.tgz"; - url = "https://registry.yarnpkg.com/damerau-levenshtein/-/damerau-levenshtein-1.0.6.tgz"; + url = "https://registry.yarnpkg.com/damerau-levenshtein/-/damerau-levenshtein-1.0.6.tgz"; sha512 = "JVrozIeElnj3QzfUIt8tB8YMluBJom4Vw9qTPpjGYQ9fYlB3D/rb6OordUxf3xeFB35LKWs0xqcO5U6ySvBtug=="; }; } @@ -781,7 +788,7 @@ name = "date_fns___date_fns_1.30.1.tgz"; path = fetchurl { name = "date_fns___date_fns_1.30.1.tgz"; - url = "https://registry.yarnpkg.com/date-fns/-/date-fns-1.30.1.tgz"; + url = "https://registry.yarnpkg.com/date-fns/-/date-fns-1.30.1.tgz"; sha512 = "hBSVCvSmWC+QypYObzwGOd9wqdDpOt+0wl0KbU+R+uuZBS1jN8VsD1ss3irQDknRj5NvxiTF6oj/nDRnN/UQNw=="; }; } @@ -789,7 +796,7 @@ name = "debug___debug_2.6.9.tgz"; path = fetchurl { name = "debug___debug_2.6.9.tgz"; - url = "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz"; + url = "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz"; sha512 = "bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA=="; }; } @@ -797,7 +804,7 @@ name = "debug___debug_3.2.6.tgz"; path = fetchurl { name = "debug___debug_3.2.6.tgz"; - url = "https://registry.yarnpkg.com/debug/-/debug-3.2.6.tgz"; + url = "https://registry.yarnpkg.com/debug/-/debug-3.2.6.tgz"; sha512 = "mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ=="; }; } @@ -805,7 +812,7 @@ name = "debug___debug_4.1.1.tgz"; path = fetchurl { name = "debug___debug_4.1.1.tgz"; - url = "https://registry.yarnpkg.com/debug/-/debug-4.1.1.tgz"; + url = "https://registry.yarnpkg.com/debug/-/debug-4.1.1.tgz"; sha512 = "pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw=="; }; } @@ -813,7 +820,7 @@ name = "decamelize___decamelize_1.2.0.tgz"; path = fetchurl { name = "decamelize___decamelize_1.2.0.tgz"; - url = "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz"; + url = "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz"; sha1 = "9lNNFRSCabIDUue+4m9QH5oZEpA="; }; } @@ -821,7 +828,7 @@ name = "decode_uri_component___decode_uri_component_0.2.0.tgz"; path = fetchurl { name = "decode_uri_component___decode_uri_component_0.2.0.tgz"; - url = "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz"; + url = "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz"; sha1 = "6zkTMzRYd1y4TNGh+uBiEGu4dUU="; }; } @@ -829,7 +836,7 @@ name = "dedent___dedent_0.7.0.tgz"; path = fetchurl { name = "dedent___dedent_0.7.0.tgz"; - url = "https://registry.yarnpkg.com/dedent/-/dedent-0.7.0.tgz"; + url = "https://registry.yarnpkg.com/dedent/-/dedent-0.7.0.tgz"; sha1 = "JJXduvbrh0q7Dhvp3yLS5aVEMmw="; }; } @@ -837,7 +844,7 @@ name = "deep_equal___deep_equal_1.1.1.tgz"; path = fetchurl { name = "deep_equal___deep_equal_1.1.1.tgz"; - url = "https://registry.yarnpkg.com/deep-equal/-/deep-equal-1.1.1.tgz"; + url = "https://registry.yarnpkg.com/deep-equal/-/deep-equal-1.1.1.tgz"; sha512 = "yd9c5AdiqVcR+JjcwUQb9DkhJc8ngNr0MahEBGvDiJw8puWab2yZlh+nkasOnZP+EGTAP6rRp2JzJhJZzvNF8g=="; }; } @@ -845,7 +852,7 @@ name = "deep_is___deep_is_0.1.3.tgz"; path = fetchurl { name = "deep_is___deep_is_0.1.3.tgz"; - url = "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.3.tgz"; + url = "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.3.tgz"; sha1 = "s2nW+128E+7PUk+RsHD+7cNXzzQ="; }; } @@ -853,7 +860,7 @@ name = "define_properties___define_properties_1.1.3.tgz"; path = fetchurl { name = "define_properties___define_properties_1.1.3.tgz"; - url = "https://registry.yarnpkg.com/define-properties/-/define-properties-1.1.3.tgz"; + url = "https://registry.yarnpkg.com/define-properties/-/define-properties-1.1.3.tgz"; sha512 = "3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ=="; }; } @@ -861,7 +868,7 @@ name = "define_property___define_property_0.2.5.tgz"; path = fetchurl { name = "define_property___define_property_0.2.5.tgz"; - url = "https://registry.yarnpkg.com/define-property/-/define-property-0.2.5.tgz"; + url = "https://registry.yarnpkg.com/define-property/-/define-property-0.2.5.tgz"; sha1 = "w1se+RjsPJkPmlvFe+BKrOxcgRY="; }; } @@ -869,7 +876,7 @@ name = "define_property___define_property_1.0.0.tgz"; path = fetchurl { name = "define_property___define_property_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/define-property/-/define-property-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/define-property/-/define-property-1.0.0.tgz"; sha1 = "dp66rz9KY6rTr56NMEybvnm/sOY="; }; } @@ -877,7 +884,7 @@ name = "define_property___define_property_2.0.2.tgz"; path = fetchurl { name = "define_property___define_property_2.0.2.tgz"; - url = "https://registry.yarnpkg.com/define-property/-/define-property-2.0.2.tgz"; + url = "https://registry.yarnpkg.com/define-property/-/define-property-2.0.2.tgz"; sha512 = "jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ=="; }; } @@ -885,7 +892,7 @@ name = "del___del_3.0.0.tgz"; path = fetchurl { name = "del___del_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/del/-/del-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/del/-/del-3.0.0.tgz"; sha1 = "U+z2mf/LyzljdpGrE7rxYIGXZuU="; }; } @@ -893,7 +900,7 @@ name = "dlv___dlv_1.1.3.tgz"; path = fetchurl { name = "dlv___dlv_1.1.3.tgz"; - url = "https://registry.yarnpkg.com/dlv/-/dlv-1.1.3.tgz"; + url = "https://registry.yarnpkg.com/dlv/-/dlv-1.1.3.tgz"; sha512 = "+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA=="; }; } @@ -901,7 +908,7 @@ name = "docopt___docopt_0.6.2.tgz"; path = fetchurl { name = "docopt___docopt_0.6.2.tgz"; - url = "https://registry.yarnpkg.com/docopt/-/docopt-0.6.2.tgz"; + url = "https://registry.yarnpkg.com/docopt/-/docopt-0.6.2.tgz"; sha1 = "so6eIiDaXsSffqW7JKR3h0Be6xE="; }; } @@ -909,7 +916,7 @@ name = "doctrine___doctrine_1.5.0.tgz"; path = fetchurl { name = "doctrine___doctrine_1.5.0.tgz"; - url = "https://registry.yarnpkg.com/doctrine/-/doctrine-1.5.0.tgz"; + url = "https://registry.yarnpkg.com/doctrine/-/doctrine-1.5.0.tgz"; sha1 = "N53Ocw9hZvds76TmcHoVmwLFpvo="; }; } @@ -917,7 +924,7 @@ name = "doctrine___doctrine_2.1.0.tgz"; path = fetchurl { name = "doctrine___doctrine_2.1.0.tgz"; - url = "https://registry.yarnpkg.com/doctrine/-/doctrine-2.1.0.tgz"; + url = "https://registry.yarnpkg.com/doctrine/-/doctrine-2.1.0.tgz"; sha512 = "35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw=="; }; } @@ -925,7 +932,7 @@ name = "doctrine___doctrine_3.0.0.tgz"; path = fetchurl { name = "doctrine___doctrine_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/doctrine/-/doctrine-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/doctrine/-/doctrine-3.0.0.tgz"; sha512 = "yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w=="; }; } @@ -933,7 +940,7 @@ name = "elegant_spinner___elegant_spinner_1.0.1.tgz"; path = fetchurl { name = "elegant_spinner___elegant_spinner_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/elegant-spinner/-/elegant-spinner-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/elegant-spinner/-/elegant-spinner-1.0.1.tgz"; sha1 = "2wQ1IcldfjA/2PNFvtwzSc+wcp4="; }; } @@ -941,7 +948,7 @@ name = "emoji_regex___emoji_regex_7.0.3.tgz"; path = fetchurl { name = "emoji_regex___emoji_regex_7.0.3.tgz"; - url = "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-7.0.3.tgz"; + url = "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-7.0.3.tgz"; sha512 = "CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA=="; }; } @@ -949,7 +956,7 @@ name = "end_of_stream___end_of_stream_1.4.4.tgz"; path = fetchurl { name = "end_of_stream___end_of_stream_1.4.4.tgz"; - url = "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz"; + url = "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz"; sha512 = "+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q=="; }; } @@ -957,7 +964,7 @@ name = "error_ex___error_ex_1.3.2.tgz"; path = fetchurl { name = "error_ex___error_ex_1.3.2.tgz"; - url = "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz"; + url = "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz"; sha512 = "7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g=="; }; } @@ -965,7 +972,7 @@ name = "es_abstract___es_abstract_1.17.5.tgz"; path = fetchurl { name = "es_abstract___es_abstract_1.17.5.tgz"; - url = "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.17.5.tgz"; + url = "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.17.5.tgz"; sha512 = "BR9auzDbySxOcfog0tLECW8l28eRGpDpU3Dm3Hp4q/N+VtLTmyj4EUN088XZWQDW/hzj6sYRDXeOFsaAODKvpg=="; }; } @@ -973,7 +980,7 @@ name = "es_to_primitive___es_to_primitive_1.2.1.tgz"; path = fetchurl { name = "es_to_primitive___es_to_primitive_1.2.1.tgz"; - url = "https://registry.yarnpkg.com/es-to-primitive/-/es-to-primitive-1.2.1.tgz"; + url = "https://registry.yarnpkg.com/es-to-primitive/-/es-to-primitive-1.2.1.tgz"; sha512 = "QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA=="; }; } @@ -981,7 +988,7 @@ name = "escape_string_regexp___escape_string_regexp_1.0.5.tgz"; path = fetchurl { name = "escape_string_regexp___escape_string_regexp_1.0.5.tgz"; - url = "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz"; + url = "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz"; sha1 = "G2HAViGQqN/2rjuyzwIAyhMLhtQ="; }; } @@ -989,7 +996,7 @@ name = "eslint_config_airbnb_base___eslint_config_airbnb_base_13.2.0.tgz"; path = fetchurl { name = "eslint_config_airbnb_base___eslint_config_airbnb_base_13.2.0.tgz"; - url = "https://registry.yarnpkg.com/eslint-config-airbnb-base/-/eslint-config-airbnb-base-13.2.0.tgz"; + url = "https://registry.yarnpkg.com/eslint-config-airbnb-base/-/eslint-config-airbnb-base-13.2.0.tgz"; sha512 = "1mg/7eoB4AUeB0X1c/ho4vb2gYkNH8Trr/EgCT/aGmKhhG+F6vF5s8+iRBlWAzFIAphxIdp3YfEKgEl0f9Xg+w=="; }; } @@ -997,7 +1004,7 @@ name = "eslint_config_airbnb___eslint_config_airbnb_17.1.1.tgz"; path = fetchurl { name = "eslint_config_airbnb___eslint_config_airbnb_17.1.1.tgz"; - url = "https://registry.yarnpkg.com/eslint-config-airbnb/-/eslint-config-airbnb-17.1.1.tgz"; + url = "https://registry.yarnpkg.com/eslint-config-airbnb/-/eslint-config-airbnb-17.1.1.tgz"; sha512 = "xCu//8a/aWqagKljt+1/qAM62BYZeNq04HmdevG5yUGWpja0I/xhqd6GdLRch5oetEGFiJAnvtGuTEAese53Qg=="; }; } @@ -1005,7 +1012,7 @@ name = "eslint_config_prettier___eslint_config_prettier_3.6.0.tgz"; path = fetchurl { name = "eslint_config_prettier___eslint_config_prettier_3.6.0.tgz"; - url = "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-3.6.0.tgz"; + url = "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-3.6.0.tgz"; sha512 = "ixJ4U3uTLXwJts4rmSVW/lMXjlGwCijhBJHk8iVqKKSifeI0qgFEfWl8L63isfc8Od7EiBALF6BX3jKLluf/jQ=="; }; } @@ -1013,7 +1020,7 @@ name = "eslint_config_standard___eslint_config_standard_12.0.0.tgz"; path = fetchurl { name = "eslint_config_standard___eslint_config_standard_12.0.0.tgz"; - url = "https://registry.yarnpkg.com/eslint-config-standard/-/eslint-config-standard-12.0.0.tgz"; + url = "https://registry.yarnpkg.com/eslint-config-standard/-/eslint-config-standard-12.0.0.tgz"; sha512 = "COUz8FnXhqFitYj4DTqHzidjIL/t4mumGZto5c7DrBpvWoie+Sn3P4sLEzUGeYhRElWuFEf8K1S1EfvD1vixCQ=="; }; } @@ -1021,7 +1028,7 @@ name = "eslint_import_resolver_node___eslint_import_resolver_node_0.3.3.tgz"; path = fetchurl { name = "eslint_import_resolver_node___eslint_import_resolver_node_0.3.3.tgz"; - url = "https://registry.yarnpkg.com/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.3.tgz"; + url = "https://registry.yarnpkg.com/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.3.tgz"; sha512 = "b8crLDo0M5RSe5YG8Pu2DYBj71tSB6OvXkfzwbJU2w7y8P4/yo0MyF8jU26IEuEuHF2K5/gcAJE3LhQGqBBbVg=="; }; } @@ -1029,7 +1036,7 @@ name = "eslint_module_utils___eslint_module_utils_2.6.0.tgz"; path = fetchurl { name = "eslint_module_utils___eslint_module_utils_2.6.0.tgz"; - url = "https://registry.yarnpkg.com/eslint-module-utils/-/eslint-module-utils-2.6.0.tgz"; + url = "https://registry.yarnpkg.com/eslint-module-utils/-/eslint-module-utils-2.6.0.tgz"; sha512 = "6j9xxegbqe8/kZY8cYpcp0xhbK0EgJlg3g9mib3/miLaExuuwc3n5UEfSnU6hWMbT0FAYVvDbL9RrRgpUeQIvA=="; }; } @@ -1037,7 +1044,7 @@ name = "eslint_plugin_es___eslint_plugin_es_1.4.1.tgz"; path = fetchurl { name = "eslint_plugin_es___eslint_plugin_es_1.4.1.tgz"; - url = "https://registry.yarnpkg.com/eslint-plugin-es/-/eslint-plugin-es-1.4.1.tgz"; + url = "https://registry.yarnpkg.com/eslint-plugin-es/-/eslint-plugin-es-1.4.1.tgz"; sha512 = "5fa/gR2yR3NxQf+UXkeLeP8FBBl6tSgdrAz1+cF84v1FMM4twGwQoqTnn+QxFLcPOrF4pdKEJKDB/q9GoyJrCA=="; }; } @@ -1045,7 +1052,7 @@ name = "eslint_plugin_import___eslint_plugin_import_2.20.2.tgz"; path = fetchurl { name = "eslint_plugin_import___eslint_plugin_import_2.20.2.tgz"; - url = "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.20.2.tgz"; + url = "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.20.2.tgz"; sha512 = "FObidqpXrR8OnCh4iNsxy+WACztJLXAHBO5hK79T1Hc77PgQZkyDGA5Ag9xAvRpglvLNxhH/zSmZ70/pZ31dHg=="; }; } @@ -1053,7 +1060,7 @@ name = "eslint_plugin_jsx_a11y___eslint_plugin_jsx_a11y_6.2.3.tgz"; path = fetchurl { name = "eslint_plugin_jsx_a11y___eslint_plugin_jsx_a11y_6.2.3.tgz"; - url = "https://registry.yarnpkg.com/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.2.3.tgz"; + url = "https://registry.yarnpkg.com/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.2.3.tgz"; sha512 = "CawzfGt9w83tyuVekn0GDPU9ytYtxyxyFZ3aSWROmnRRFQFT2BiPJd7jvRdzNDi6oLWaS2asMeYSNMjWTV4eNg=="; }; } @@ -1061,7 +1068,7 @@ name = "eslint_plugin_node___eslint_plugin_node_8.0.1.tgz"; path = fetchurl { name = "eslint_plugin_node___eslint_plugin_node_8.0.1.tgz"; - url = "https://registry.yarnpkg.com/eslint-plugin-node/-/eslint-plugin-node-8.0.1.tgz"; + url = "https://registry.yarnpkg.com/eslint-plugin-node/-/eslint-plugin-node-8.0.1.tgz"; sha512 = "ZjOjbjEi6jd82rIpFSgagv4CHWzG9xsQAVp1ZPlhRnnYxcTgENUVBvhYmkQ7GvT1QFijUSo69RaiOJKhMu6i8w=="; }; } @@ -1069,7 +1076,7 @@ name = "eslint_plugin_promise___eslint_plugin_promise_4.2.1.tgz"; path = fetchurl { name = "eslint_plugin_promise___eslint_plugin_promise_4.2.1.tgz"; - url = "https://registry.yarnpkg.com/eslint-plugin-promise/-/eslint-plugin-promise-4.2.1.tgz"; + url = "https://registry.yarnpkg.com/eslint-plugin-promise/-/eslint-plugin-promise-4.2.1.tgz"; sha512 = "VoM09vT7bfA7D+upt+FjeBO5eHIJQBUWki1aPvB+vbNiHS3+oGIJGIeyBtKQTME6UPXXy3vV07OL1tHd3ANuDw=="; }; } @@ -1077,7 +1084,7 @@ name = "eslint_plugin_react___eslint_plugin_react_7.20.0.tgz"; path = fetchurl { name = "eslint_plugin_react___eslint_plugin_react_7.20.0.tgz"; - url = "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.20.0.tgz"; + url = "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.20.0.tgz"; sha512 = "rqe1abd0vxMjmbPngo4NaYxTcR3Y4Hrmc/jg4T+sYz63yqlmJRknpEQfmWY+eDWPuMmix6iUIK+mv0zExjeLgA=="; }; } @@ -1085,7 +1092,7 @@ name = "eslint_plugin_standard___eslint_plugin_standard_4.0.1.tgz"; path = fetchurl { name = "eslint_plugin_standard___eslint_plugin_standard_4.0.1.tgz"; - url = "https://registry.yarnpkg.com/eslint-plugin-standard/-/eslint-plugin-standard-4.0.1.tgz"; + url = "https://registry.yarnpkg.com/eslint-plugin-standard/-/eslint-plugin-standard-4.0.1.tgz"; sha512 = "v/KBnfyaOMPmZc/dmc6ozOdWqekGp7bBGq4jLAecEfPGmfKiWS4sA8sC0LqiV9w5qmXAtXVn4M3p1jSyhY85SQ=="; }; } @@ -1093,7 +1100,7 @@ name = "eslint_scope___eslint_scope_3.7.3.tgz"; path = fetchurl { name = "eslint_scope___eslint_scope_3.7.3.tgz"; - url = "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-3.7.3.tgz"; + url = "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-3.7.3.tgz"; sha512 = "W+B0SvF4gamyCTmUc+uITPY0989iXVfKvhwtmJocTaYoc/3khEHmEmvfY/Gn9HA9VV75jrQECsHizkNw1b68FA=="; }; } @@ -1101,7 +1108,7 @@ name = "eslint_scope___eslint_scope_4.0.3.tgz"; path = fetchurl { name = "eslint_scope___eslint_scope_4.0.3.tgz"; - url = "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-4.0.3.tgz"; + url = "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-4.0.3.tgz"; sha512 = "p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg=="; }; } @@ -1109,7 +1116,7 @@ name = "eslint_utils___eslint_utils_1.4.3.tgz"; path = fetchurl { name = "eslint_utils___eslint_utils_1.4.3.tgz"; - url = "https://registry.yarnpkg.com/eslint-utils/-/eslint-utils-1.4.3.tgz"; + url = "https://registry.yarnpkg.com/eslint-utils/-/eslint-utils-1.4.3.tgz"; sha512 = "fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q=="; }; } @@ -1117,7 +1124,7 @@ name = "eslint_visitor_keys___eslint_visitor_keys_1.1.0.tgz"; path = fetchurl { name = "eslint_visitor_keys___eslint_visitor_keys_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz"; sha512 = "8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A=="; }; } @@ -1125,7 +1132,7 @@ name = "eslint___eslint_4.19.1.tgz"; path = fetchurl { name = "eslint___eslint_4.19.1.tgz"; - url = "https://registry.yarnpkg.com/eslint/-/eslint-4.19.1.tgz"; + url = "https://registry.yarnpkg.com/eslint/-/eslint-4.19.1.tgz"; sha512 = "bT3/1x1EbZB7phzYu7vCr1v3ONuzDtX8WjuM9c0iYxe+cq+pwcKEoQjl7zd3RpC6YOLgnSy3cTN58M2jcoPDIQ=="; }; } @@ -1133,7 +1140,7 @@ name = "eslint___eslint_5.16.0.tgz"; path = fetchurl { name = "eslint___eslint_5.16.0.tgz"; - url = "https://registry.yarnpkg.com/eslint/-/eslint-5.16.0.tgz"; + url = "https://registry.yarnpkg.com/eslint/-/eslint-5.16.0.tgz"; sha512 = "S3Rz11i7c8AA5JPv7xAH+dOyq/Cu/VXHiHXBPOU1k/JAM5dXqQPt3qcrhpHSorXmrpu2g0gkIBVXAqCpzfoZIg=="; }; } @@ -1141,7 +1148,7 @@ name = "espree___espree_3.5.4.tgz"; path = fetchurl { name = "espree___espree_3.5.4.tgz"; - url = "https://registry.yarnpkg.com/espree/-/espree-3.5.4.tgz"; + url = "https://registry.yarnpkg.com/espree/-/espree-3.5.4.tgz"; sha512 = "yAcIQxtmMiB/jL32dzEp2enBeidsB7xWPLNiw3IIkpVds1P+h7qF9YwJq1yUNzp2OKXgAprs4F61ih66UsoD1A=="; }; } @@ -1149,7 +1156,7 @@ name = "espree___espree_5.0.1.tgz"; path = fetchurl { name = "espree___espree_5.0.1.tgz"; - url = "https://registry.yarnpkg.com/espree/-/espree-5.0.1.tgz"; + url = "https://registry.yarnpkg.com/espree/-/espree-5.0.1.tgz"; sha512 = "qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A=="; }; } @@ -1157,7 +1164,7 @@ name = "esprima___esprima_4.0.1.tgz"; path = fetchurl { name = "esprima___esprima_4.0.1.tgz"; - url = "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz"; + url = "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz"; sha512 = "eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A=="; }; } @@ -1165,7 +1172,7 @@ name = "esquery___esquery_1.3.1.tgz"; path = fetchurl { name = "esquery___esquery_1.3.1.tgz"; - url = "https://registry.yarnpkg.com/esquery/-/esquery-1.3.1.tgz"; + url = "https://registry.yarnpkg.com/esquery/-/esquery-1.3.1.tgz"; sha512 = "olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ=="; }; } @@ -1173,7 +1180,7 @@ name = "esrecurse___esrecurse_4.2.1.tgz"; path = fetchurl { name = "esrecurse___esrecurse_4.2.1.tgz"; - url = "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.2.1.tgz"; + url = "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.2.1.tgz"; sha512 = "64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ=="; }; } @@ -1181,7 +1188,7 @@ name = "estraverse___estraverse_4.3.0.tgz"; path = fetchurl { name = "estraverse___estraverse_4.3.0.tgz"; - url = "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz"; + url = "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz"; sha512 = "39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw=="; }; } @@ -1189,7 +1196,7 @@ name = "estraverse___estraverse_5.1.0.tgz"; path = fetchurl { name = "estraverse___estraverse_5.1.0.tgz"; - url = "https://registry.yarnpkg.com/estraverse/-/estraverse-5.1.0.tgz"; + url = "https://registry.yarnpkg.com/estraverse/-/estraverse-5.1.0.tgz"; sha512 = "FyohXK+R0vE+y1nHLoBM7ZTyqRpqAlhdZHCWIWEviFLiGB8b04H6bQs8G+XTthacvT8VuwvteiP7RJSxMs8UEw=="; }; } @@ -1197,7 +1204,7 @@ name = "esutils___esutils_2.0.3.tgz"; path = fetchurl { name = "esutils___esutils_2.0.3.tgz"; - url = "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz"; + url = "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz"; sha512 = "kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g=="; }; } @@ -1205,7 +1212,7 @@ name = "execa___execa_0.7.0.tgz"; path = fetchurl { name = "execa___execa_0.7.0.tgz"; - url = "https://registry.yarnpkg.com/execa/-/execa-0.7.0.tgz"; + url = "https://registry.yarnpkg.com/execa/-/execa-0.7.0.tgz"; sha1 = "lEvs00zEHuMqY6n68nrVpl/Fl3c="; }; } @@ -1213,7 +1220,7 @@ name = "execa___execa_1.0.0.tgz"; path = fetchurl { name = "execa___execa_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/execa/-/execa-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/execa/-/execa-1.0.0.tgz"; sha512 = "adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA=="; }; } @@ -1221,7 +1228,7 @@ name = "expand_brackets___expand_brackets_2.1.4.tgz"; path = fetchurl { name = "expand_brackets___expand_brackets_2.1.4.tgz"; - url = "https://registry.yarnpkg.com/expand-brackets/-/expand-brackets-2.1.4.tgz"; + url = "https://registry.yarnpkg.com/expand-brackets/-/expand-brackets-2.1.4.tgz"; sha1 = "t3c14xXOMPa27/D4OwQVGiJEliI="; }; } @@ -1229,7 +1236,7 @@ name = "extend_shallow___extend_shallow_2.0.1.tgz"; path = fetchurl { name = "extend_shallow___extend_shallow_2.0.1.tgz"; - url = "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-2.0.1.tgz"; + url = "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-2.0.1.tgz"; sha1 = "Ua99YUrZqfYQ6huvu5idaxxWiQ8="; }; } @@ -1237,7 +1244,7 @@ name = "extend_shallow___extend_shallow_3.0.2.tgz"; path = fetchurl { name = "extend_shallow___extend_shallow_3.0.2.tgz"; - url = "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-3.0.2.tgz"; + url = "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-3.0.2.tgz"; sha1 = "Jqcarwc7OfshJxcnRhMcJwQCjbg="; }; } @@ -1245,7 +1252,7 @@ name = "external_editor___external_editor_2.2.0.tgz"; path = fetchurl { name = "external_editor___external_editor_2.2.0.tgz"; - url = "https://registry.yarnpkg.com/external-editor/-/external-editor-2.2.0.tgz"; + url = "https://registry.yarnpkg.com/external-editor/-/external-editor-2.2.0.tgz"; sha512 = "bSn6gvGxKt+b7+6TKEv1ZycHleA7aHhRHyAqJyp5pbUFuYYNIzpZnQDk7AsYckyWdEnTeAnay0aCy2aV6iTk9A=="; }; } @@ -1253,7 +1260,7 @@ name = "external_editor___external_editor_3.1.0.tgz"; path = fetchurl { name = "external_editor___external_editor_3.1.0.tgz"; - url = "https://registry.yarnpkg.com/external-editor/-/external-editor-3.1.0.tgz"; + url = "https://registry.yarnpkg.com/external-editor/-/external-editor-3.1.0.tgz"; sha512 = "hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew=="; }; } @@ -1261,7 +1268,7 @@ name = "extglob___extglob_2.0.4.tgz"; path = fetchurl { name = "extglob___extglob_2.0.4.tgz"; - url = "https://registry.yarnpkg.com/extglob/-/extglob-2.0.4.tgz"; + url = "https://registry.yarnpkg.com/extglob/-/extglob-2.0.4.tgz"; sha512 = "Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw=="; }; } @@ -1269,7 +1276,7 @@ name = "fast_deep_equal___fast_deep_equal_1.1.0.tgz"; path = fetchurl { name = "fast_deep_equal___fast_deep_equal_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz"; sha1 = "wFNHeBfIa1HaqFPIHgWbcz0CNhQ="; }; } @@ -1277,7 +1284,7 @@ name = "fast_deep_equal___fast_deep_equal_3.1.1.tgz"; path = fetchurl { name = "fast_deep_equal___fast_deep_equal_3.1.1.tgz"; - url = "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.1.tgz"; + url = "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.1.tgz"; sha512 = "8UEa58QDLauDNfpbrX55Q9jrGHThw2ZMdOky5Gl1CDtVeJDPVrG4Jxx1N8jw2gkWaff5UUuX1KJd+9zGe2B+ZA=="; }; } @@ -1285,7 +1292,7 @@ name = "fast_json_stable_stringify___fast_json_stable_stringify_2.1.0.tgz"; path = fetchurl { name = "fast_json_stable_stringify___fast_json_stable_stringify_2.1.0.tgz"; - url = "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz"; + url = "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz"; sha512 = "lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw=="; }; } @@ -1293,7 +1300,7 @@ name = "fast_levenshtein___fast_levenshtein_2.0.6.tgz"; path = fetchurl { name = "fast_levenshtein___fast_levenshtein_2.0.6.tgz"; - url = "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz"; + url = "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz"; sha1 = "PYpcZog6FqMMqGQ+hR8Zuqd5eRc="; }; } @@ -1301,7 +1308,7 @@ name = "figures___figures_1.7.0.tgz"; path = fetchurl { name = "figures___figures_1.7.0.tgz"; - url = "https://registry.yarnpkg.com/figures/-/figures-1.7.0.tgz"; + url = "https://registry.yarnpkg.com/figures/-/figures-1.7.0.tgz"; sha1 = "y+Hjr/zxzUS4DK3+0o3Hk6lwHS4="; }; } @@ -1309,7 +1316,7 @@ name = "figures___figures_2.0.0.tgz"; path = fetchurl { name = "figures___figures_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/figures/-/figures-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/figures/-/figures-2.0.0.tgz"; sha1 = "OrGi0qYsi/tDGgyUy3l6L84nyWI="; }; } @@ -1317,7 +1324,7 @@ name = "file_entry_cache___file_entry_cache_2.0.0.tgz"; path = fetchurl { name = "file_entry_cache___file_entry_cache_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-2.0.0.tgz"; sha1 = "w5KZDD5oR4PYOLjISkXYoEhFg2E="; }; } @@ -1325,7 +1332,7 @@ name = "file_entry_cache___file_entry_cache_5.0.1.tgz"; path = fetchurl { name = "file_entry_cache___file_entry_cache_5.0.1.tgz"; - url = "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-5.0.1.tgz"; + url = "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-5.0.1.tgz"; sha512 = "bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g=="; }; } @@ -1333,7 +1340,7 @@ name = "fill_range___fill_range_4.0.0.tgz"; path = fetchurl { name = "fill_range___fill_range_4.0.0.tgz"; - url = "https://registry.yarnpkg.com/fill-range/-/fill-range-4.0.0.tgz"; + url = "https://registry.yarnpkg.com/fill-range/-/fill-range-4.0.0.tgz"; sha1 = "1USBHUKPmOsGpj3EAtJAPDKMOPc="; }; } @@ -1341,7 +1348,7 @@ name = "find_up___find_up_2.1.0.tgz"; path = fetchurl { name = "find_up___find_up_2.1.0.tgz"; - url = "https://registry.yarnpkg.com/find-up/-/find-up-2.1.0.tgz"; + url = "https://registry.yarnpkg.com/find-up/-/find-up-2.1.0.tgz"; sha1 = "RdG35QbHF93UgndaK3eSCjwMV6c="; }; } @@ -1349,7 +1356,7 @@ name = "find_up___find_up_3.0.0.tgz"; path = fetchurl { name = "find_up___find_up_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/find-up/-/find-up-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/find-up/-/find-up-3.0.0.tgz"; sha512 = "1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg=="; }; } @@ -1357,7 +1364,7 @@ name = "flat_cache___flat_cache_1.3.4.tgz"; path = fetchurl { name = "flat_cache___flat_cache_1.3.4.tgz"; - url = "https://registry.yarnpkg.com/flat-cache/-/flat-cache-1.3.4.tgz"; + url = "https://registry.yarnpkg.com/flat-cache/-/flat-cache-1.3.4.tgz"; sha512 = "VwyB3Lkgacfik2vhqR4uv2rvebqmDvFu4jlN/C1RzWoJEo8I7z4Q404oiqYCkq41mni8EzQnm95emU9seckwtg=="; }; } @@ -1365,7 +1372,7 @@ name = "flat_cache___flat_cache_2.0.1.tgz"; path = fetchurl { name = "flat_cache___flat_cache_2.0.1.tgz"; - url = "https://registry.yarnpkg.com/flat-cache/-/flat-cache-2.0.1.tgz"; + url = "https://registry.yarnpkg.com/flat-cache/-/flat-cache-2.0.1.tgz"; sha512 = "LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA=="; }; } @@ -1373,7 +1380,7 @@ name = "flatted___flatted_2.0.2.tgz"; path = fetchurl { name = "flatted___flatted_2.0.2.tgz"; - url = "https://registry.yarnpkg.com/flatted/-/flatted-2.0.2.tgz"; + url = "https://registry.yarnpkg.com/flatted/-/flatted-2.0.2.tgz"; sha512 = "r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA=="; }; } @@ -1381,7 +1388,7 @@ name = "fn_name___fn_name_2.0.1.tgz"; path = fetchurl { name = "fn_name___fn_name_2.0.1.tgz"; - url = "https://registry.yarnpkg.com/fn-name/-/fn-name-2.0.1.tgz"; + url = "https://registry.yarnpkg.com/fn-name/-/fn-name-2.0.1.tgz"; sha1 = "UhTXU3pNBqSjAcDMJi/rhBiAAuc="; }; } @@ -1389,7 +1396,7 @@ name = "for_in___for_in_1.0.2.tgz"; path = fetchurl { name = "for_in___for_in_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/for-in/-/for-in-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/for-in/-/for-in-1.0.2.tgz"; sha1 = "gQaNKVqBQuwKxybG4iAMMPttXoA="; }; } @@ -1397,7 +1404,7 @@ name = "fragment_cache___fragment_cache_0.2.1.tgz"; path = fetchurl { name = "fragment_cache___fragment_cache_0.2.1.tgz"; - url = "https://registry.yarnpkg.com/fragment-cache/-/fragment-cache-0.2.1.tgz"; + url = "https://registry.yarnpkg.com/fragment-cache/-/fragment-cache-0.2.1.tgz"; sha1 = "QpD60n8T6Jvn8zeZxrxaCr//DRk="; }; } @@ -1405,7 +1412,7 @@ name = "fs.realpath___fs.realpath_1.0.0.tgz"; path = fetchurl { name = "fs.realpath___fs.realpath_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz"; sha1 = "FQStJSMVjKpA20onh8sBQRmU6k8="; }; } @@ -1413,7 +1420,7 @@ name = "function_bind___function_bind_1.1.1.tgz"; path = fetchurl { name = "function_bind___function_bind_1.1.1.tgz"; - url = "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz"; + url = "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz"; sha512 = "yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A=="; }; } @@ -1421,7 +1428,7 @@ name = "functional_red_black_tree___functional_red_black_tree_1.0.1.tgz"; path = fetchurl { name = "functional_red_black_tree___functional_red_black_tree_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz"; sha1 = "GwqzvVU7Kg1jmdKcDj6gslIHgyc="; }; } @@ -1429,7 +1436,7 @@ name = "g_status___g_status_2.0.2.tgz"; path = fetchurl { name = "g_status___g_status_2.0.2.tgz"; - url = "https://registry.yarnpkg.com/g-status/-/g-status-2.0.2.tgz"; + url = "https://registry.yarnpkg.com/g-status/-/g-status-2.0.2.tgz"; sha512 = "kQoE9qH+T1AHKgSSD0Hkv98bobE90ILQcXAF4wvGgsr7uFqNvwmh8j+Lq3l0RVt3E3HjSbv2B9biEGcEtpHLCA=="; }; } @@ -1437,7 +1444,7 @@ name = "get_caller_file___get_caller_file_1.0.3.tgz"; path = fetchurl { name = "get_caller_file___get_caller_file_1.0.3.tgz"; - url = "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-1.0.3.tgz"; + url = "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-1.0.3.tgz"; sha512 = "3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w=="; }; } @@ -1445,7 +1452,7 @@ name = "get_own_enumerable_property_symbols___get_own_enumerable_property_symbols_3.0.2.tgz"; path = fetchurl { name = "get_own_enumerable_property_symbols___get_own_enumerable_property_symbols_3.0.2.tgz"; - url = "https://registry.yarnpkg.com/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz"; + url = "https://registry.yarnpkg.com/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz"; sha512 = "I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g=="; }; } @@ -1453,7 +1460,7 @@ name = "get_stdin___get_stdin_5.0.1.tgz"; path = fetchurl { name = "get_stdin___get_stdin_5.0.1.tgz"; - url = "https://registry.yarnpkg.com/get-stdin/-/get-stdin-5.0.1.tgz"; + url = "https://registry.yarnpkg.com/get-stdin/-/get-stdin-5.0.1.tgz"; sha1 = "Ei4WFZHiH/TFJTAwVpPyDmOTo5g="; }; } @@ -1461,7 +1468,7 @@ name = "get_stdin___get_stdin_6.0.0.tgz"; path = fetchurl { name = "get_stdin___get_stdin_6.0.0.tgz"; - url = "https://registry.yarnpkg.com/get-stdin/-/get-stdin-6.0.0.tgz"; + url = "https://registry.yarnpkg.com/get-stdin/-/get-stdin-6.0.0.tgz"; sha512 = "jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g=="; }; } @@ -1469,7 +1476,7 @@ name = "get_stream___get_stream_3.0.0.tgz"; path = fetchurl { name = "get_stream___get_stream_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/get-stream/-/get-stream-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/get-stream/-/get-stream-3.0.0.tgz"; sha1 = "jpQ9E1jcN1VQVOy+LtsFqhdO3hQ="; }; } @@ -1477,7 +1484,7 @@ name = "get_stream___get_stream_4.1.0.tgz"; path = fetchurl { name = "get_stream___get_stream_4.1.0.tgz"; - url = "https://registry.yarnpkg.com/get-stream/-/get-stream-4.1.0.tgz"; + url = "https://registry.yarnpkg.com/get-stream/-/get-stream-4.1.0.tgz"; sha512 = "GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w=="; }; } @@ -1485,7 +1492,7 @@ name = "get_value___get_value_2.0.6.tgz"; path = fetchurl { name = "get_value___get_value_2.0.6.tgz"; - url = "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz"; + url = "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz"; sha1 = "3BXKHGcjh8p2vTesCjlbogQqLCg="; }; } @@ -1493,7 +1500,7 @@ name = "glob___glob_7.1.6.tgz"; path = fetchurl { name = "glob___glob_7.1.6.tgz"; - url = "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz"; + url = "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz"; sha512 = "LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA=="; }; } @@ -1501,7 +1508,7 @@ name = "glob___glob_7.0.6.tgz"; path = fetchurl { name = "glob___glob_7.0.6.tgz"; - url = "https://registry.yarnpkg.com/glob/-/glob-7.0.6.tgz"; + url = "https://registry.yarnpkg.com/glob/-/glob-7.0.6.tgz"; sha1 = "IRuvr0nlJbjNkyYNFKsTYVKz9Xo="; }; } @@ -1509,7 +1516,7 @@ name = "globals___globals_11.12.0.tgz"; path = fetchurl { name = "globals___globals_11.12.0.tgz"; - url = "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz"; + url = "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz"; sha512 = "WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA=="; }; } @@ -1517,7 +1524,7 @@ name = "globby___globby_6.1.0.tgz"; path = fetchurl { name = "globby___globby_6.1.0.tgz"; - url = "https://registry.yarnpkg.com/globby/-/globby-6.1.0.tgz"; + url = "https://registry.yarnpkg.com/globby/-/globby-6.1.0.tgz"; sha1 = "9abXDoOV4hyFj7BInWTfAkJNUGw="; }; } @@ -1525,7 +1532,7 @@ name = "graceful_fs___graceful_fs_4.2.4.tgz"; path = fetchurl { name = "graceful_fs___graceful_fs_4.2.4.tgz"; - url = "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.4.tgz"; + url = "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.4.tgz"; sha512 = "WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw=="; }; } @@ -1533,7 +1540,7 @@ name = "has_ansi___has_ansi_2.0.0.tgz"; path = fetchurl { name = "has_ansi___has_ansi_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/has-ansi/-/has-ansi-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/has-ansi/-/has-ansi-2.0.0.tgz"; sha1 = "NPUEnOHs3ysGSa8+8k5F7TVBbZE="; }; } @@ -1541,7 +1548,7 @@ name = "has_flag___has_flag_2.0.0.tgz"; path = fetchurl { name = "has_flag___has_flag_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/has-flag/-/has-flag-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/has-flag/-/has-flag-2.0.0.tgz"; sha1 = "6CB68cx7MNRGzHC3NLXovhj4jVE="; }; } @@ -1549,7 +1556,7 @@ name = "has_flag___has_flag_3.0.0.tgz"; path = fetchurl { name = "has_flag___has_flag_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz"; sha1 = "tdRU3CGZriJWmfNGfloH87lVuv0="; }; } @@ -1557,7 +1564,7 @@ name = "has_symbols___has_symbols_1.0.1.tgz"; path = fetchurl { name = "has_symbols___has_symbols_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.1.tgz"; sha512 = "PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg=="; }; } @@ -1565,7 +1572,7 @@ name = "has_value___has_value_0.3.1.tgz"; path = fetchurl { name = "has_value___has_value_0.3.1.tgz"; - url = "https://registry.yarnpkg.com/has-value/-/has-value-0.3.1.tgz"; + url = "https://registry.yarnpkg.com/has-value/-/has-value-0.3.1.tgz"; sha1 = "ex9YutpiyoJ+wKIHgCVlSEWZXh8="; }; } @@ -1573,7 +1580,7 @@ name = "has_value___has_value_1.0.0.tgz"; path = fetchurl { name = "has_value___has_value_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/has-value/-/has-value-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/has-value/-/has-value-1.0.0.tgz"; sha1 = "GLKB2lhbHFxR3vJMkw7SmgvmsXc="; }; } @@ -1581,7 +1588,7 @@ name = "has_values___has_values_0.1.4.tgz"; path = fetchurl { name = "has_values___has_values_0.1.4.tgz"; - url = "https://registry.yarnpkg.com/has-values/-/has-values-0.1.4.tgz"; + url = "https://registry.yarnpkg.com/has-values/-/has-values-0.1.4.tgz"; sha1 = "bWHeldkd/Km5oCCJrThL/49it3E="; }; } @@ -1589,7 +1596,7 @@ name = "has_values___has_values_1.0.0.tgz"; path = fetchurl { name = "has_values___has_values_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/has-values/-/has-values-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/has-values/-/has-values-1.0.0.tgz"; sha1 = "lbC2P+whRmGab+V/51Yo1aOe/k8="; }; } @@ -1597,7 +1604,7 @@ name = "has___has_1.0.3.tgz"; path = fetchurl { name = "has___has_1.0.3.tgz"; - url = "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz"; + url = "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz"; sha512 = "f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw=="; }; } @@ -1605,7 +1612,7 @@ name = "hosted_git_info___hosted_git_info_2.8.8.tgz"; path = fetchurl { name = "hosted_git_info___hosted_git_info_2.8.8.tgz"; - url = "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.8.8.tgz"; + url = "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.8.8.tgz"; sha512 = "f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg=="; }; } @@ -1613,7 +1620,7 @@ name = "husky___husky_1.3.1.tgz"; path = fetchurl { name = "husky___husky_1.3.1.tgz"; - url = "https://registry.yarnpkg.com/husky/-/husky-1.3.1.tgz"; + url = "https://registry.yarnpkg.com/husky/-/husky-1.3.1.tgz"; sha512 = "86U6sVVVf4b5NYSZ0yvv88dRgBSSXXmHaiq5pP4KDj5JVzdwKgBjEtUPOm8hcoytezFwbU+7gotXNhpHdystlg=="; }; } @@ -1621,7 +1628,7 @@ name = "iconv_lite___iconv_lite_0.4.24.tgz"; path = fetchurl { name = "iconv_lite___iconv_lite_0.4.24.tgz"; - url = "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz"; + url = "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz"; sha512 = "v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA=="; }; } @@ -1629,7 +1636,7 @@ name = "ignore___ignore_3.3.10.tgz"; path = fetchurl { name = "ignore___ignore_3.3.10.tgz"; - url = "https://registry.yarnpkg.com/ignore/-/ignore-3.3.10.tgz"; + url = "https://registry.yarnpkg.com/ignore/-/ignore-3.3.10.tgz"; sha512 = "Pgs951kaMm5GXP7MOvxERINe3gsaVjUWFm+UZPSq9xYriQAksyhg0csnS0KXSNRD5NmNdapXEpjxG49+AKh/ug=="; }; } @@ -1637,7 +1644,7 @@ name = "ignore___ignore_4.0.6.tgz"; path = fetchurl { name = "ignore___ignore_4.0.6.tgz"; - url = "https://registry.yarnpkg.com/ignore/-/ignore-4.0.6.tgz"; + url = "https://registry.yarnpkg.com/ignore/-/ignore-4.0.6.tgz"; sha512 = "cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg=="; }; } @@ -1645,7 +1652,7 @@ name = "ignore___ignore_5.1.4.tgz"; path = fetchurl { name = "ignore___ignore_5.1.4.tgz"; - url = "https://registry.yarnpkg.com/ignore/-/ignore-5.1.4.tgz"; + url = "https://registry.yarnpkg.com/ignore/-/ignore-5.1.4.tgz"; sha512 = "MzbUSahkTW1u7JpKKjY7LCARd1fU5W2rLdxlM4kdkayuCwZImjkpluF9CM1aLewYJguPDqewLam18Y6AU69A8A=="; }; } @@ -1653,7 +1660,7 @@ name = "import_fresh___import_fresh_2.0.0.tgz"; path = fetchurl { name = "import_fresh___import_fresh_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/import-fresh/-/import-fresh-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/import-fresh/-/import-fresh-2.0.0.tgz"; sha1 = "2BNVwVYS04bGH53dOSLUMEgipUY="; }; } @@ -1661,7 +1668,7 @@ name = "import_fresh___import_fresh_3.2.1.tgz"; path = fetchurl { name = "import_fresh___import_fresh_3.2.1.tgz"; - url = "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.2.1.tgz"; + url = "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.2.1.tgz"; sha512 = "6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ=="; }; } @@ -1669,7 +1676,7 @@ name = "imurmurhash___imurmurhash_0.1.4.tgz"; path = fetchurl { name = "imurmurhash___imurmurhash_0.1.4.tgz"; - url = "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz"; + url = "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz"; sha1 = "khi5srkoojixPcT7a21XbyMUU+o="; }; } @@ -1677,7 +1684,7 @@ name = "indent_string___indent_string_3.2.0.tgz"; path = fetchurl { name = "indent_string___indent_string_3.2.0.tgz"; - url = "https://registry.yarnpkg.com/indent-string/-/indent-string-3.2.0.tgz"; + url = "https://registry.yarnpkg.com/indent-string/-/indent-string-3.2.0.tgz"; sha1 = "Sl/W0nzDMvN+VBmlBNu4NxBckok="; }; } @@ -1685,7 +1692,7 @@ name = "inflight___inflight_1.0.6.tgz"; path = fetchurl { name = "inflight___inflight_1.0.6.tgz"; - url = "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz"; + url = "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz"; sha1 = "Sb1jMdfQLQwJvJEKEHW6gWW1bfk="; }; } @@ -1693,7 +1700,7 @@ name = "inherits___inherits_2.0.4.tgz"; path = fetchurl { name = "inherits___inherits_2.0.4.tgz"; - url = "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz"; + url = "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz"; sha512 = "k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="; }; } @@ -1701,7 +1708,7 @@ name = "inquirer___inquirer_3.3.0.tgz"; path = fetchurl { name = "inquirer___inquirer_3.3.0.tgz"; - url = "https://registry.yarnpkg.com/inquirer/-/inquirer-3.3.0.tgz"; + url = "https://registry.yarnpkg.com/inquirer/-/inquirer-3.3.0.tgz"; sha512 = "h+xtnyk4EwKvFWHrUYsWErEVR+igKtLdchu+o0Z1RL7VU/jVMFbYir2bp6bAj8efFNxWqHX0dIss6fJQ+/+qeQ=="; }; } @@ -1709,7 +1716,7 @@ name = "inquirer___inquirer_6.5.2.tgz"; path = fetchurl { name = "inquirer___inquirer_6.5.2.tgz"; - url = "https://registry.yarnpkg.com/inquirer/-/inquirer-6.5.2.tgz"; + url = "https://registry.yarnpkg.com/inquirer/-/inquirer-6.5.2.tgz"; sha512 = "cntlB5ghuB0iuO65Ovoi8ogLHiWGs/5yNrtUcKjFhSSiVeAIVpD7koaSU9RM8mpXw5YDi9RdYXGQMaOURB7ycQ=="; }; } @@ -1717,7 +1724,7 @@ name = "internal_slot___internal_slot_1.0.2.tgz"; path = fetchurl { name = "internal_slot___internal_slot_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.2.tgz"; sha512 = "2cQNfwhAfJIkU4KZPkDI+Gj5yNNnbqi40W9Gge6dfnk4TocEVm00B3bdiL+JINrbGJil2TeHvM4rETGzk/f/0g=="; }; } @@ -1725,7 +1732,7 @@ name = "invert_kv___invert_kv_1.0.0.tgz"; path = fetchurl { name = "invert_kv___invert_kv_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/invert-kv/-/invert-kv-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/invert-kv/-/invert-kv-1.0.0.tgz"; sha1 = "EEqOSqym09jNFXqO+L+rLXo//bY="; }; } @@ -1733,7 +1740,7 @@ name = "is_accessor_descriptor___is_accessor_descriptor_0.1.6.tgz"; path = fetchurl { name = "is_accessor_descriptor___is_accessor_descriptor_0.1.6.tgz"; - url = "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz"; + url = "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz"; sha1 = "qeEss66Nh2cn7u84Q/igiXtcmNY="; }; } @@ -1741,7 +1748,7 @@ name = "is_accessor_descriptor___is_accessor_descriptor_1.0.0.tgz"; path = fetchurl { name = "is_accessor_descriptor___is_accessor_descriptor_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz"; sha512 = "m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ=="; }; } @@ -1749,7 +1756,7 @@ name = "is_arguments___is_arguments_1.0.4.tgz"; path = fetchurl { name = "is_arguments___is_arguments_1.0.4.tgz"; - url = "https://registry.yarnpkg.com/is-arguments/-/is-arguments-1.0.4.tgz"; + url = "https://registry.yarnpkg.com/is-arguments/-/is-arguments-1.0.4.tgz"; sha512 = "xPh0Rmt8NE65sNzvyUmWgI1tz3mKq74lGA0mL8LYZcoIzKOzDh6HmrYm3d18k60nHerC8A9Km8kYu87zfSFnLA=="; }; } @@ -1757,7 +1764,7 @@ name = "is_arrayish___is_arrayish_0.2.1.tgz"; path = fetchurl { name = "is_arrayish___is_arrayish_0.2.1.tgz"; - url = "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz"; + url = "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz"; sha1 = "d8mYQFJ6qOyxqLppe4BkWnqSap0="; }; } @@ -1765,7 +1772,7 @@ name = "is_buffer___is_buffer_1.1.6.tgz"; path = fetchurl { name = "is_buffer___is_buffer_1.1.6.tgz"; - url = "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz"; + url = "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz"; sha512 = "NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w=="; }; } @@ -1773,7 +1780,7 @@ name = "is_callable___is_callable_1.1.5.tgz"; path = fetchurl { name = "is_callable___is_callable_1.1.5.tgz"; - url = "https://registry.yarnpkg.com/is-callable/-/is-callable-1.1.5.tgz"; + url = "https://registry.yarnpkg.com/is-callable/-/is-callable-1.1.5.tgz"; sha512 = "ESKv5sMCJB2jnHTWZ3O5itG+O128Hsus4K4Qh1h2/cgn2vbgnLSVqfV46AeJA9D5EeeLa9w81KUXMtn34zhX+Q=="; }; } @@ -1781,7 +1788,7 @@ name = "is_ci___is_ci_2.0.0.tgz"; path = fetchurl { name = "is_ci___is_ci_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/is-ci/-/is-ci-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/is-ci/-/is-ci-2.0.0.tgz"; sha512 = "YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w=="; }; } @@ -1789,7 +1796,7 @@ name = "is_data_descriptor___is_data_descriptor_0.1.4.tgz"; path = fetchurl { name = "is_data_descriptor___is_data_descriptor_0.1.4.tgz"; - url = "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz"; + url = "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz"; sha1 = "C17mSDiOLIYCgueT8YVv7D8wG1Y="; }; } @@ -1797,7 +1804,7 @@ name = "is_data_descriptor___is_data_descriptor_1.0.0.tgz"; path = fetchurl { name = "is_data_descriptor___is_data_descriptor_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz"; sha512 = "jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ=="; }; } @@ -1805,7 +1812,7 @@ name = "is_date_object___is_date_object_1.0.2.tgz"; path = fetchurl { name = "is_date_object___is_date_object_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/is-date-object/-/is-date-object-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/is-date-object/-/is-date-object-1.0.2.tgz"; sha512 = "USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g=="; }; } @@ -1813,7 +1820,7 @@ name = "is_descriptor___is_descriptor_0.1.6.tgz"; path = fetchurl { name = "is_descriptor___is_descriptor_0.1.6.tgz"; - url = "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-0.1.6.tgz"; + url = "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-0.1.6.tgz"; sha512 = "avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg=="; }; } @@ -1821,7 +1828,7 @@ name = "is_descriptor___is_descriptor_1.0.2.tgz"; path = fetchurl { name = "is_descriptor___is_descriptor_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-1.0.2.tgz"; sha512 = "2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg=="; }; } @@ -1829,7 +1836,7 @@ name = "is_directory___is_directory_0.3.1.tgz"; path = fetchurl { name = "is_directory___is_directory_0.3.1.tgz"; - url = "https://registry.yarnpkg.com/is-directory/-/is-directory-0.3.1.tgz"; + url = "https://registry.yarnpkg.com/is-directory/-/is-directory-0.3.1.tgz"; sha1 = "YTObbyR1/Hcv2cnYP1yFddwVSuE="; }; } @@ -1837,7 +1844,7 @@ name = "is_extendable___is_extendable_0.1.1.tgz"; path = fetchurl { name = "is_extendable___is_extendable_0.1.1.tgz"; - url = "https://registry.yarnpkg.com/is-extendable/-/is-extendable-0.1.1.tgz"; + url = "https://registry.yarnpkg.com/is-extendable/-/is-extendable-0.1.1.tgz"; sha1 = "YrEQ4omkcUGOPsNqYX1HLjAd/Ik="; }; } @@ -1845,7 +1852,7 @@ name = "is_extendable___is_extendable_1.0.1.tgz"; path = fetchurl { name = "is_extendable___is_extendable_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/is-extendable/-/is-extendable-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/is-extendable/-/is-extendable-1.0.1.tgz"; sha512 = "arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA=="; }; } @@ -1853,7 +1860,7 @@ name = "is_extglob___is_extglob_2.1.1.tgz"; path = fetchurl { name = "is_extglob___is_extglob_2.1.1.tgz"; - url = "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz"; + url = "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz"; sha1 = "qIwCU1eR8C7TfHahueqXc8gz+MI="; }; } @@ -1861,7 +1868,7 @@ name = "is_fullwidth_code_point___is_fullwidth_code_point_1.0.0.tgz"; path = fetchurl { name = "is_fullwidth_code_point___is_fullwidth_code_point_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz"; sha1 = "754xOG8DGn8NZDr4L95QxFfvAMs="; }; } @@ -1869,7 +1876,7 @@ name = "is_fullwidth_code_point___is_fullwidth_code_point_2.0.0.tgz"; path = fetchurl { name = "is_fullwidth_code_point___is_fullwidth_code_point_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz"; sha1 = "o7MKXE8ZkYMWeqq5O+764937ZU8="; }; } @@ -1877,7 +1884,7 @@ name = "is_glob___is_glob_4.0.1.tgz"; path = fetchurl { name = "is_glob___is_glob_4.0.1.tgz"; - url = "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.1.tgz"; + url = "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.1.tgz"; sha512 = "5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg=="; }; } @@ -1885,7 +1892,7 @@ name = "is_number___is_number_3.0.0.tgz"; path = fetchurl { name = "is_number___is_number_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/is-number/-/is-number-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/is-number/-/is-number-3.0.0.tgz"; sha1 = "JP1iAaR4LPUFYcgQJ2r8fRLXEZU="; }; } @@ -1893,7 +1900,7 @@ name = "is_obj___is_obj_1.0.1.tgz"; path = fetchurl { name = "is_obj___is_obj_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/is-obj/-/is-obj-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/is-obj/-/is-obj-1.0.1.tgz"; sha1 = "PkcprB9f3gJc19g6iW2rn09n2w8="; }; } @@ -1901,7 +1908,7 @@ name = "is_observable___is_observable_1.1.0.tgz"; path = fetchurl { name = "is_observable___is_observable_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/is-observable/-/is-observable-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/is-observable/-/is-observable-1.1.0.tgz"; sha512 = "NqCa4Sa2d+u7BWc6CukaObG3Fh+CU9bvixbpcXYhy2VvYS7vVGIdAgnIS5Ks3A/cqk4rebLJ9s8zBstT2aKnIA=="; }; } @@ -1909,7 +1916,7 @@ name = "is_path_cwd___is_path_cwd_1.0.0.tgz"; path = fetchurl { name = "is_path_cwd___is_path_cwd_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/is-path-cwd/-/is-path-cwd-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/is-path-cwd/-/is-path-cwd-1.0.0.tgz"; sha1 = "0iXsIxMuie3Tj9p2dHLmLmXxEG0="; }; } @@ -1917,7 +1924,7 @@ name = "is_path_in_cwd___is_path_in_cwd_1.0.1.tgz"; path = fetchurl { name = "is_path_in_cwd___is_path_in_cwd_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/is-path-in-cwd/-/is-path-in-cwd-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/is-path-in-cwd/-/is-path-in-cwd-1.0.1.tgz"; sha512 = "FjV1RTW48E7CWM7eE/J2NJvAEEVektecDBVBE5Hh3nM1Jd0kvhHtX68Pr3xsDf857xt3Y4AkwVULK1Vku62aaQ=="; }; } @@ -1925,7 +1932,7 @@ name = "is_path_inside___is_path_inside_1.0.1.tgz"; path = fetchurl { name = "is_path_inside___is_path_inside_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-1.0.1.tgz"; sha1 = "jvW33lBDej/cprToZe96pVy0gDY="; }; } @@ -1933,7 +1940,7 @@ name = "is_plain_object___is_plain_object_2.0.4.tgz"; path = fetchurl { name = "is_plain_object___is_plain_object_2.0.4.tgz"; - url = "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz"; + url = "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz"; sha512 = "h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og=="; }; } @@ -1941,7 +1948,7 @@ name = "is_promise___is_promise_2.2.2.tgz"; path = fetchurl { name = "is_promise___is_promise_2.2.2.tgz"; - url = "https://registry.yarnpkg.com/is-promise/-/is-promise-2.2.2.tgz"; + url = "https://registry.yarnpkg.com/is-promise/-/is-promise-2.2.2.tgz"; sha512 = "+lP4/6lKUBfQjZ2pdxThZvLUAafmZb8OAxFb8XXtiQmS35INgr85hdOGoEs124ez1FCnZJt6jau/T+alh58QFQ=="; }; } @@ -1949,7 +1956,7 @@ name = "is_regex___is_regex_1.0.5.tgz"; path = fetchurl { name = "is_regex___is_regex_1.0.5.tgz"; - url = "https://registry.yarnpkg.com/is-regex/-/is-regex-1.0.5.tgz"; + url = "https://registry.yarnpkg.com/is-regex/-/is-regex-1.0.5.tgz"; sha512 = "vlKW17SNq44owv5AQR3Cq0bQPEb8+kF3UKZ2fiZNOWtztYE5i0CzCZxFDwO58qAOWtxdBRVO/V5Qin1wjCqFYQ=="; }; } @@ -1957,7 +1964,7 @@ name = "is_regexp___is_regexp_1.0.0.tgz"; path = fetchurl { name = "is_regexp___is_regexp_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/is-regexp/-/is-regexp-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/is-regexp/-/is-regexp-1.0.0.tgz"; sha1 = "/S2INUXEa6xaYz57mgnof6LLUGk="; }; } @@ -1965,7 +1972,7 @@ name = "is_resolvable___is_resolvable_1.1.0.tgz"; path = fetchurl { name = "is_resolvable___is_resolvable_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/is-resolvable/-/is-resolvable-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/is-resolvable/-/is-resolvable-1.1.0.tgz"; sha512 = "qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg=="; }; } @@ -1973,7 +1980,7 @@ name = "is_stream___is_stream_1.1.0.tgz"; path = fetchurl { name = "is_stream___is_stream_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/is-stream/-/is-stream-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/is-stream/-/is-stream-1.1.0.tgz"; sha1 = "EtSj3U5o4Lec6428hBc66A2RykQ="; }; } @@ -1981,7 +1988,7 @@ name = "is_string___is_string_1.0.5.tgz"; path = fetchurl { name = "is_string___is_string_1.0.5.tgz"; - url = "https://registry.yarnpkg.com/is-string/-/is-string-1.0.5.tgz"; + url = "https://registry.yarnpkg.com/is-string/-/is-string-1.0.5.tgz"; sha512 = "buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ=="; }; } @@ -1989,7 +1996,7 @@ name = "is_symbol___is_symbol_1.0.3.tgz"; path = fetchurl { name = "is_symbol___is_symbol_1.0.3.tgz"; - url = "https://registry.yarnpkg.com/is-symbol/-/is-symbol-1.0.3.tgz"; + url = "https://registry.yarnpkg.com/is-symbol/-/is-symbol-1.0.3.tgz"; sha512 = "OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ=="; }; } @@ -1997,7 +2004,7 @@ name = "is_windows___is_windows_1.0.2.tgz"; path = fetchurl { name = "is_windows___is_windows_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/is-windows/-/is-windows-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/is-windows/-/is-windows-1.0.2.tgz"; sha512 = "eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA=="; }; } @@ -2005,7 +2012,7 @@ name = "isarray___isarray_1.0.0.tgz"; path = fetchurl { name = "isarray___isarray_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz"; sha1 = "u5NdSFgsuhaMBoNJV6VKPgcSTxE="; }; } @@ -2013,7 +2020,7 @@ name = "isexe___isexe_2.0.0.tgz"; path = fetchurl { name = "isexe___isexe_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz"; sha1 = "6PvzdNxVb/iUehDcsFctYz8s+hA="; }; } @@ -2021,7 +2028,7 @@ name = "isobject___isobject_2.1.0.tgz"; path = fetchurl { name = "isobject___isobject_2.1.0.tgz"; - url = "https://registry.yarnpkg.com/isobject/-/isobject-2.1.0.tgz"; + url = "https://registry.yarnpkg.com/isobject/-/isobject-2.1.0.tgz"; sha1 = "8GVWEJaj8dou9GJy+BXIQNh+DIk="; }; } @@ -2029,7 +2036,7 @@ name = "isobject___isobject_3.0.1.tgz"; path = fetchurl { name = "isobject___isobject_3.0.1.tgz"; - url = "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz"; + url = "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz"; sha1 = "TkMekrEalzFjaqH5yNHMvP2reN8="; }; } @@ -2037,7 +2044,7 @@ name = "js_tokens___js_tokens_4.0.0.tgz"; path = fetchurl { name = "js_tokens___js_tokens_4.0.0.tgz"; - url = "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz"; + url = "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz"; sha512 = "RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ=="; }; } @@ -2045,7 +2052,7 @@ name = "js_tokens___js_tokens_3.0.2.tgz"; path = fetchurl { name = "js_tokens___js_tokens_3.0.2.tgz"; - url = "https://registry.yarnpkg.com/js-tokens/-/js-tokens-3.0.2.tgz"; + url = "https://registry.yarnpkg.com/js-tokens/-/js-tokens-3.0.2.tgz"; sha1 = "mGbfOVECEw449/mWvOtlRDIJwls="; }; } @@ -2053,7 +2060,7 @@ name = "js_yaml___js_yaml_3.13.1.tgz"; path = fetchurl { name = "js_yaml___js_yaml_3.13.1.tgz"; - url = "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.13.1.tgz"; + url = "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.13.1.tgz"; sha512 = "YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw=="; }; } @@ -2061,7 +2068,7 @@ name = "jsesc___jsesc_2.5.2.tgz"; path = fetchurl { name = "jsesc___jsesc_2.5.2.tgz"; - url = "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz"; + url = "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz"; sha512 = "OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA=="; }; } @@ -2069,7 +2076,7 @@ name = "json_parse_better_errors___json_parse_better_errors_1.0.2.tgz"; path = fetchurl { name = "json_parse_better_errors___json_parse_better_errors_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz"; sha512 = "mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw=="; }; } @@ -2077,7 +2084,7 @@ name = "json_schema_traverse___json_schema_traverse_0.3.1.tgz"; path = fetchurl { name = "json_schema_traverse___json_schema_traverse_0.3.1.tgz"; - url = "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz"; + url = "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz"; sha1 = "NJptRMU6Ud6JtAgFxdXlm0F9M0A="; }; } @@ -2085,7 +2092,7 @@ name = "json_schema_traverse___json_schema_traverse_0.4.1.tgz"; path = fetchurl { name = "json_schema_traverse___json_schema_traverse_0.4.1.tgz"; - url = "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz"; + url = "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz"; sha512 = "xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg=="; }; } @@ -2093,7 +2100,7 @@ name = "json_stable_stringify_without_jsonify___json_stable_stringify_without_jsonify_1.0.1.tgz"; path = fetchurl { name = "json_stable_stringify_without_jsonify___json_stable_stringify_without_jsonify_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz"; sha1 = "nbe1lJatPzz+8wp1FC0tkwrXJlE="; }; } @@ -2101,7 +2108,7 @@ name = "jsx_ast_utils___jsx_ast_utils_2.2.3.tgz"; path = fetchurl { name = "jsx_ast_utils___jsx_ast_utils_2.2.3.tgz"; - url = "https://registry.yarnpkg.com/jsx-ast-utils/-/jsx-ast-utils-2.2.3.tgz"; + url = "https://registry.yarnpkg.com/jsx-ast-utils/-/jsx-ast-utils-2.2.3.tgz"; sha512 = "EdIHFMm+1BPynpKOpdPqiOsvnIrInRGJD7bzPZdPkjitQEqpdpUuFpq4T0npZFKTiB3RhWFdGN+oqOJIdhDhQA=="; }; } @@ -2109,7 +2116,7 @@ name = "kind_of___kind_of_3.2.2.tgz"; path = fetchurl { name = "kind_of___kind_of_3.2.2.tgz"; - url = "https://registry.yarnpkg.com/kind-of/-/kind-of-3.2.2.tgz"; + url = "https://registry.yarnpkg.com/kind-of/-/kind-of-3.2.2.tgz"; sha1 = "MeohpzS6ubuw8yRm2JOupR5KPGQ="; }; } @@ -2117,7 +2124,7 @@ name = "kind_of___kind_of_4.0.0.tgz"; path = fetchurl { name = "kind_of___kind_of_4.0.0.tgz"; - url = "https://registry.yarnpkg.com/kind-of/-/kind-of-4.0.0.tgz"; + url = "https://registry.yarnpkg.com/kind-of/-/kind-of-4.0.0.tgz"; sha1 = "IIE989cSkosgc3hpGkUGb65y3Vc="; }; } @@ -2125,7 +2132,7 @@ name = "kind_of___kind_of_5.1.0.tgz"; path = fetchurl { name = "kind_of___kind_of_5.1.0.tgz"; - url = "https://registry.yarnpkg.com/kind-of/-/kind-of-5.1.0.tgz"; + url = "https://registry.yarnpkg.com/kind-of/-/kind-of-5.1.0.tgz"; sha512 = "NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw=="; }; } @@ -2133,7 +2140,7 @@ name = "kind_of___kind_of_6.0.3.tgz"; path = fetchurl { name = "kind_of___kind_of_6.0.3.tgz"; - url = "https://registry.yarnpkg.com/kind-of/-/kind-of-6.0.3.tgz"; + url = "https://registry.yarnpkg.com/kind-of/-/kind-of-6.0.3.tgz"; sha512 = "dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw=="; }; } @@ -2141,7 +2148,7 @@ name = "lcid___lcid_1.0.0.tgz"; path = fetchurl { name = "lcid___lcid_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/lcid/-/lcid-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/lcid/-/lcid-1.0.0.tgz"; sha1 = "MIrMr6C8SDo4Z7S28rlQYlHRuDU="; }; } @@ -2149,7 +2156,7 @@ name = "levn___levn_0.3.0.tgz"; path = fetchurl { name = "levn___levn_0.3.0.tgz"; - url = "https://registry.yarnpkg.com/levn/-/levn-0.3.0.tgz"; + url = "https://registry.yarnpkg.com/levn/-/levn-0.3.0.tgz"; sha1 = "OwmSTt+fCDwEkP3UwLxEIeBHZO4="; }; } @@ -2157,7 +2164,7 @@ name = "lint_staged___lint_staged_8.2.1.tgz"; path = fetchurl { name = "lint_staged___lint_staged_8.2.1.tgz"; - url = "https://registry.yarnpkg.com/lint-staged/-/lint-staged-8.2.1.tgz"; + url = "https://registry.yarnpkg.com/lint-staged/-/lint-staged-8.2.1.tgz"; sha512 = "n0tDGR/rTCgQNwXnUf/eWIpPNddGWxC32ANTNYsj2k02iZb7Cz5ox2tytwBu+2r0zDXMEMKw7Y9OD/qsav561A=="; }; } @@ -2165,7 +2172,7 @@ name = "listr_silent_renderer___listr_silent_renderer_1.1.1.tgz"; path = fetchurl { name = "listr_silent_renderer___listr_silent_renderer_1.1.1.tgz"; - url = "https://registry.yarnpkg.com/listr-silent-renderer/-/listr-silent-renderer-1.1.1.tgz"; + url = "https://registry.yarnpkg.com/listr-silent-renderer/-/listr-silent-renderer-1.1.1.tgz"; sha1 = "kktaN1cVN3C/Go4/v3S4u/P5JC4="; }; } @@ -2173,7 +2180,7 @@ name = "listr_update_renderer___listr_update_renderer_0.5.0.tgz"; path = fetchurl { name = "listr_update_renderer___listr_update_renderer_0.5.0.tgz"; - url = "https://registry.yarnpkg.com/listr-update-renderer/-/listr-update-renderer-0.5.0.tgz"; + url = "https://registry.yarnpkg.com/listr-update-renderer/-/listr-update-renderer-0.5.0.tgz"; sha512 = "tKRsZpKz8GSGqoI/+caPmfrypiaq+OQCbd+CovEC24uk1h952lVj5sC7SqyFUm+OaJ5HN/a1YLt5cit2FMNsFA=="; }; } @@ -2181,7 +2188,7 @@ name = "listr_verbose_renderer___listr_verbose_renderer_0.5.0.tgz"; path = fetchurl { name = "listr_verbose_renderer___listr_verbose_renderer_0.5.0.tgz"; - url = "https://registry.yarnpkg.com/listr-verbose-renderer/-/listr-verbose-renderer-0.5.0.tgz"; + url = "https://registry.yarnpkg.com/listr-verbose-renderer/-/listr-verbose-renderer-0.5.0.tgz"; sha512 = "04PDPqSlsqIOaaaGZ+41vq5FejI9auqTInicFRndCBgE3bXG8D6W1I+mWhk+1nqbHmyhla/6BUrd5OSiHwKRXw=="; }; } @@ -2189,7 +2196,7 @@ name = "listr___listr_0.14.3.tgz"; path = fetchurl { name = "listr___listr_0.14.3.tgz"; - url = "https://registry.yarnpkg.com/listr/-/listr-0.14.3.tgz"; + url = "https://registry.yarnpkg.com/listr/-/listr-0.14.3.tgz"; sha512 = "RmAl7su35BFd/xoMamRjpIE4j3v+L28o8CT5YhAXQJm1fD+1l9ngXY8JAQRJ+tFK2i5njvi0iRUKV09vPwA0iA=="; }; } @@ -2197,7 +2204,7 @@ name = "load_json_file___load_json_file_2.0.0.tgz"; path = fetchurl { name = "load_json_file___load_json_file_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/load-json-file/-/load-json-file-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/load-json-file/-/load-json-file-2.0.0.tgz"; sha1 = "eUfkIUmvgNaWy/eXvKq8/h/inKg="; }; } @@ -2205,7 +2212,7 @@ name = "locate_path___locate_path_2.0.0.tgz"; path = fetchurl { name = "locate_path___locate_path_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/locate-path/-/locate-path-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/locate-path/-/locate-path-2.0.0.tgz"; sha1 = "K1aLJl7slExtnA3pw9u7ygNUzY4="; }; } @@ -2213,7 +2220,7 @@ name = "locate_path___locate_path_3.0.0.tgz"; path = fetchurl { name = "locate_path___locate_path_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/locate-path/-/locate-path-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/locate-path/-/locate-path-3.0.0.tgz"; sha512 = "7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A=="; }; } @@ -2221,7 +2228,7 @@ name = "lodash.memoize___lodash.memoize_4.1.2.tgz"; path = fetchurl { name = "lodash.memoize___lodash.memoize_4.1.2.tgz"; - url = "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-4.1.2.tgz"; + url = "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-4.1.2.tgz"; sha1 = "vMbEmkKihA7Zl/Mj6tpezRguC/4="; }; } @@ -2229,7 +2236,7 @@ name = "lodash.merge___lodash.merge_4.6.2.tgz"; path = fetchurl { name = "lodash.merge___lodash.merge_4.6.2.tgz"; - url = "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz"; + url = "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz"; sha512 = "0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ=="; }; } @@ -2237,7 +2244,7 @@ name = "lodash.unescape___lodash.unescape_4.0.1.tgz"; path = fetchurl { name = "lodash.unescape___lodash.unescape_4.0.1.tgz"; - url = "https://registry.yarnpkg.com/lodash.unescape/-/lodash.unescape-4.0.1.tgz"; + url = "https://registry.yarnpkg.com/lodash.unescape/-/lodash.unescape-4.0.1.tgz"; sha1 = "vyJJiGzlFM2hEvrpIYzcBlIR/Jw="; }; } @@ -2245,7 +2252,7 @@ name = "lodash___lodash_4.17.15.tgz"; path = fetchurl { name = "lodash___lodash_4.17.15.tgz"; - url = "https://registry.yarnpkg.com/lodash/-/lodash-4.17.15.tgz"; + url = "https://registry.yarnpkg.com/lodash/-/lodash-4.17.15.tgz"; sha512 = "8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A=="; }; } @@ -2253,7 +2260,7 @@ name = "log_symbols___log_symbols_1.0.2.tgz"; path = fetchurl { name = "log_symbols___log_symbols_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/log-symbols/-/log-symbols-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/log-symbols/-/log-symbols-1.0.2.tgz"; sha1 = "N2/3tY6jCGoPCfrMdGF+ylAeGhg="; }; } @@ -2261,7 +2268,7 @@ name = "log_symbols___log_symbols_2.2.0.tgz"; path = fetchurl { name = "log_symbols___log_symbols_2.2.0.tgz"; - url = "https://registry.yarnpkg.com/log-symbols/-/log-symbols-2.2.0.tgz"; + url = "https://registry.yarnpkg.com/log-symbols/-/log-symbols-2.2.0.tgz"; sha512 = "VeIAFslyIerEJLXHziedo2basKbMKtTw3vfn5IzG0XTjhAVEJyNHnL2p7vc+wBDSdQuUpNw3M2u6xb9QsAY5Eg=="; }; } @@ -2269,7 +2276,7 @@ name = "log_update___log_update_2.3.0.tgz"; path = fetchurl { name = "log_update___log_update_2.3.0.tgz"; - url = "https://registry.yarnpkg.com/log-update/-/log-update-2.3.0.tgz"; + url = "https://registry.yarnpkg.com/log-update/-/log-update-2.3.0.tgz"; sha1 = "iDKP19HOeTiykoN0bwsbwSayRwg="; }; } @@ -2277,7 +2284,7 @@ name = "loglevel_colored_level_prefix___loglevel_colored_level_prefix_1.0.0.tgz"; path = fetchurl { name = "loglevel_colored_level_prefix___loglevel_colored_level_prefix_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/loglevel-colored-level-prefix/-/loglevel-colored-level-prefix-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/loglevel-colored-level-prefix/-/loglevel-colored-level-prefix-1.0.0.tgz"; sha1 = "akAhj9x64V/HbD0PPmdsRlOIYD4="; }; } @@ -2285,7 +2292,7 @@ name = "loglevel___loglevel_1.6.8.tgz"; path = fetchurl { name = "loglevel___loglevel_1.6.8.tgz"; - url = "https://registry.yarnpkg.com/loglevel/-/loglevel-1.6.8.tgz"; + url = "https://registry.yarnpkg.com/loglevel/-/loglevel-1.6.8.tgz"; sha512 = "bsU7+gc9AJ2SqpzxwU3+1fedl8zAntbtC5XYlt3s2j1hJcn2PsXSmgN8TaLG/J1/2mod4+cE/3vNL70/c1RNCA=="; }; } @@ -2293,7 +2300,7 @@ name = "loose_envify___loose_envify_1.4.0.tgz"; path = fetchurl { name = "loose_envify___loose_envify_1.4.0.tgz"; - url = "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz"; + url = "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz"; sha512 = "lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q=="; }; } @@ -2301,7 +2308,7 @@ name = "lru_cache___lru_cache_4.1.5.tgz"; path = fetchurl { name = "lru_cache___lru_cache_4.1.5.tgz"; - url = "https://registry.yarnpkg.com/lru-cache/-/lru-cache-4.1.5.tgz"; + url = "https://registry.yarnpkg.com/lru-cache/-/lru-cache-4.1.5.tgz"; sha512 = "sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g=="; }; } @@ -2309,7 +2316,7 @@ name = "make_plural___make_plural_4.3.0.tgz"; path = fetchurl { name = "make_plural___make_plural_4.3.0.tgz"; - url = "https://registry.yarnpkg.com/make-plural/-/make-plural-4.3.0.tgz"; + url = "https://registry.yarnpkg.com/make-plural/-/make-plural-4.3.0.tgz"; sha512 = "xTYd4JVHpSCW+aqDof6w/MebaMVNTVYBZhbB/vi513xXdiPT92JMVCo0Jq8W2UZnzYRFeVbQiQ+I25l13JuKvA=="; }; } @@ -2317,7 +2324,7 @@ name = "map_cache___map_cache_0.2.2.tgz"; path = fetchurl { name = "map_cache___map_cache_0.2.2.tgz"; - url = "https://registry.yarnpkg.com/map-cache/-/map-cache-0.2.2.tgz"; + url = "https://registry.yarnpkg.com/map-cache/-/map-cache-0.2.2.tgz"; sha1 = "wyq9C9ZSXZsFFkW7TyasXcmKDb8="; }; } @@ -2325,7 +2332,7 @@ name = "map_obj___map_obj_2.0.0.tgz"; path = fetchurl { name = "map_obj___map_obj_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/map-obj/-/map-obj-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/map-obj/-/map-obj-2.0.0.tgz"; sha1 = "plzSkIepJZi4eRJXpSPgISIqwfk="; }; } @@ -2333,7 +2340,7 @@ name = "map_visit___map_visit_1.0.0.tgz"; path = fetchurl { name = "map_visit___map_visit_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/map-visit/-/map-visit-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/map-visit/-/map-visit-1.0.0.tgz"; sha1 = "7Nyo8TFE5mDxtb1B8S80edmN+48="; }; } @@ -2341,7 +2348,7 @@ name = "matcher___matcher_1.1.1.tgz"; path = fetchurl { name = "matcher___matcher_1.1.1.tgz"; - url = "https://registry.yarnpkg.com/matcher/-/matcher-1.1.1.tgz"; + url = "https://registry.yarnpkg.com/matcher/-/matcher-1.1.1.tgz"; sha512 = "+BmqxWIubKTRKNWx/ahnCkk3mG8m7OturVlqq6HiojGJTd5hVYbgZm6WzcYPCoB+KBT4Vd6R7WSRG2OADNaCjg=="; }; } @@ -2349,7 +2356,7 @@ name = "mem___mem_1.1.0.tgz"; path = fetchurl { name = "mem___mem_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/mem/-/mem-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/mem/-/mem-1.1.0.tgz"; sha1 = "Xt1StIXKHZAP5kiVUFOZoN+kX3Y="; }; } @@ -2357,7 +2364,7 @@ name = "messageformat_parser___messageformat_parser_1.1.0.tgz"; path = fetchurl { name = "messageformat_parser___messageformat_parser_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/messageformat-parser/-/messageformat-parser-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/messageformat-parser/-/messageformat-parser-1.1.0.tgz"; sha512 = "Hwem6G3MsKDLS1FtBRGIs8T50P1Q00r3srS6QJePCFbad9fq0nYxwf3rnU2BreApRGhmpKMV7oZI06Sy1c9TPA=="; }; } @@ -2365,7 +2372,7 @@ name = "messageformat___messageformat_1.1.1.tgz"; path = fetchurl { name = "messageformat___messageformat_1.1.1.tgz"; - url = "https://registry.yarnpkg.com/messageformat/-/messageformat-1.1.1.tgz"; + url = "https://registry.yarnpkg.com/messageformat/-/messageformat-1.1.1.tgz"; sha512 = "Q0uXcDtF5pEZsVSyhzDOGgZZK6ykN79VY9CwU3Nv0gsqx62BjdJW0MT+63UkHQ4exe3HE33ZlxR2/YwoJarRTg=="; }; } @@ -2373,7 +2380,7 @@ name = "micromatch___micromatch_3.1.10.tgz"; path = fetchurl { name = "micromatch___micromatch_3.1.10.tgz"; - url = "https://registry.yarnpkg.com/micromatch/-/micromatch-3.1.10.tgz"; + url = "https://registry.yarnpkg.com/micromatch/-/micromatch-3.1.10.tgz"; sha512 = "MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg=="; }; } @@ -2381,7 +2388,7 @@ name = "mimic_fn___mimic_fn_1.2.0.tgz"; path = fetchurl { name = "mimic_fn___mimic_fn_1.2.0.tgz"; - url = "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-1.2.0.tgz"; + url = "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-1.2.0.tgz"; sha512 = "jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ=="; }; } @@ -2389,7 +2396,7 @@ name = "minimatch___minimatch_3.0.4.tgz"; path = fetchurl { name = "minimatch___minimatch_3.0.4.tgz"; - url = "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz"; + url = "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz"; sha512 = "yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA=="; }; } @@ -2397,7 +2404,7 @@ name = "minimist___minimist_1.2.5.tgz"; path = fetchurl { name = "minimist___minimist_1.2.5.tgz"; - url = "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz"; + url = "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz"; sha512 = "FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw=="; }; } @@ -2405,7 +2412,7 @@ name = "minipass___minipass_3.3.4.tgz"; path = fetchurl { name = "minipass___minipass_3.3.4.tgz"; - url = "https://registry.yarnpkg.com/minipass/-/minipass-3.3.4.tgz"; + url = "https://registry.yarnpkg.com/minipass/-/minipass-3.3.4.tgz"; sha512 = "I9WPbWHCGu8W+6k1ZiGpPu0GkoKBeorkfKNuAFBNS1HNFJvke82sxvI5bzcCNpWPorkOO5QQ+zomzzwRxejXiw=="; }; } @@ -2413,7 +2420,7 @@ name = "mixin_deep___mixin_deep_1.3.2.tgz"; path = fetchurl { name = "mixin_deep___mixin_deep_1.3.2.tgz"; - url = "https://registry.yarnpkg.com/mixin-deep/-/mixin-deep-1.3.2.tgz"; + url = "https://registry.yarnpkg.com/mixin-deep/-/mixin-deep-1.3.2.tgz"; sha512 = "WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA=="; }; } @@ -2421,7 +2428,7 @@ name = "mkdirp___mkdirp_0.5.5.tgz"; path = fetchurl { name = "mkdirp___mkdirp_0.5.5.tgz"; - url = "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.5.tgz"; + url = "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.5.tgz"; sha512 = "NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ=="; }; } @@ -2429,7 +2436,7 @@ name = "ms___ms_2.0.0.tgz"; path = fetchurl { name = "ms___ms_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz"; sha1 = "VgiurfwAvmwpAd9fmGF4jeDVl8g="; }; } @@ -2437,7 +2444,7 @@ name = "ms___ms_2.1.2.tgz"; path = fetchurl { name = "ms___ms_2.1.2.tgz"; - url = "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz"; + url = "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz"; sha512 = "sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="; }; } @@ -2445,7 +2452,7 @@ name = "mute_stream___mute_stream_0.0.7.tgz"; path = fetchurl { name = "mute_stream___mute_stream_0.0.7.tgz"; - url = "https://registry.yarnpkg.com/mute-stream/-/mute-stream-0.0.7.tgz"; + url = "https://registry.yarnpkg.com/mute-stream/-/mute-stream-0.0.7.tgz"; sha1 = "MHXOk7whuPq0PhvE2n6BFe0ee6s="; }; } @@ -2453,7 +2460,7 @@ name = "nanomatch___nanomatch_1.2.13.tgz"; path = fetchurl { name = "nanomatch___nanomatch_1.2.13.tgz"; - url = "https://registry.yarnpkg.com/nanomatch/-/nanomatch-1.2.13.tgz"; + url = "https://registry.yarnpkg.com/nanomatch/-/nanomatch-1.2.13.tgz"; sha512 = "fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA=="; }; } @@ -2461,7 +2468,7 @@ name = "natural_compare___natural_compare_1.4.0.tgz"; path = fetchurl { name = "natural_compare___natural_compare_1.4.0.tgz"; - url = "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz"; + url = "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz"; sha1 = "Sr6/7tdUHywnrPspvbvRXI1bpPc="; }; } @@ -2469,7 +2476,7 @@ name = "nice_try___nice_try_1.0.5.tgz"; path = fetchurl { name = "nice_try___nice_try_1.0.5.tgz"; - url = "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz"; + url = "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz"; sha512 = "1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ=="; }; } @@ -2477,7 +2484,7 @@ name = "nopt___nopt_3.0.6.tgz"; path = fetchurl { name = "nopt___nopt_3.0.6.tgz"; - url = "https://registry.yarnpkg.com/nopt/-/nopt-3.0.6.tgz"; + url = "https://registry.yarnpkg.com/nopt/-/nopt-3.0.6.tgz"; sha1 = "xkZdvwirzU2zWTF/eaxopkayj/k="; }; } @@ -2485,7 +2492,7 @@ name = "normalize_package_data___normalize_package_data_2.5.0.tgz"; path = fetchurl { name = "normalize_package_data___normalize_package_data_2.5.0.tgz"; - url = "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz"; + url = "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz"; sha512 = "/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA=="; }; } @@ -2493,7 +2500,7 @@ name = "npm_path___npm_path_2.0.4.tgz"; path = fetchurl { name = "npm_path___npm_path_2.0.4.tgz"; - url = "https://registry.yarnpkg.com/npm-path/-/npm-path-2.0.4.tgz"; + url = "https://registry.yarnpkg.com/npm-path/-/npm-path-2.0.4.tgz"; sha512 = "IFsj0R9C7ZdR5cP+ET342q77uSRdtWOlWpih5eC+lu29tIDbNEgDbzgVJ5UFvYHWhxDZ5TFkJafFioO0pPQjCw=="; }; } @@ -2501,7 +2508,7 @@ name = "npm_run_path___npm_run_path_2.0.2.tgz"; path = fetchurl { name = "npm_run_path___npm_run_path_2.0.2.tgz"; - url = "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-2.0.2.tgz"; + url = "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-2.0.2.tgz"; sha1 = "NakjLfo11wZ7TLLd8jV7GHFTbF8="; }; } @@ -2509,7 +2516,7 @@ name = "npm_which___npm_which_3.0.1.tgz"; path = fetchurl { name = "npm_which___npm_which_3.0.1.tgz"; - url = "https://registry.yarnpkg.com/npm-which/-/npm-which-3.0.1.tgz"; + url = "https://registry.yarnpkg.com/npm-which/-/npm-which-3.0.1.tgz"; sha1 = "kiXybsOihcIJyuZ8OxGmtKtxQKo="; }; } @@ -2517,7 +2524,7 @@ name = "number_is_nan___number_is_nan_1.0.1.tgz"; path = fetchurl { name = "number_is_nan___number_is_nan_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz"; sha1 = "CXtgK1NCKlIsGvuHkDGDNpQaAR0="; }; } @@ -2525,7 +2532,7 @@ name = "object_assign___object_assign_4.1.1.tgz"; path = fetchurl { name = "object_assign___object_assign_4.1.1.tgz"; - url = "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz"; + url = "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz"; sha1 = "IQmtx5ZYh8/AXLvUQsrIv7s2CGM="; }; } @@ -2533,7 +2540,7 @@ name = "object_copy___object_copy_0.1.0.tgz"; path = fetchurl { name = "object_copy___object_copy_0.1.0.tgz"; - url = "https://registry.yarnpkg.com/object-copy/-/object-copy-0.1.0.tgz"; + url = "https://registry.yarnpkg.com/object-copy/-/object-copy-0.1.0.tgz"; sha1 = "fn2Fi3gb18mRpBupde04EnVOmYw="; }; } @@ -2541,7 +2548,7 @@ name = "object_inspect___object_inspect_1.7.0.tgz"; path = fetchurl { name = "object_inspect___object_inspect_1.7.0.tgz"; - url = "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.7.0.tgz"; + url = "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.7.0.tgz"; sha512 = "a7pEHdh1xKIAgTySUGgLMx/xwDZskN1Ud6egYYN3EdRW4ZMPNEDUTF+hwy2LUC+Bl+SyLXANnwz/jyh/qutKUw=="; }; } @@ -2549,7 +2556,7 @@ name = "object_is___object_is_1.1.2.tgz"; path = fetchurl { name = "object_is___object_is_1.1.2.tgz"; - url = "https://registry.yarnpkg.com/object-is/-/object-is-1.1.2.tgz"; + url = "https://registry.yarnpkg.com/object-is/-/object-is-1.1.2.tgz"; sha512 = "5lHCz+0uufF6wZ7CRFWJN3hp8Jqblpgve06U5CMQ3f//6iDjPr2PEo9MWCjEssDsa+UZEL4PkFpr+BMop6aKzQ=="; }; } @@ -2557,7 +2564,7 @@ name = "object_keys___object_keys_1.1.1.tgz"; path = fetchurl { name = "object_keys___object_keys_1.1.1.tgz"; - url = "https://registry.yarnpkg.com/object-keys/-/object-keys-1.1.1.tgz"; + url = "https://registry.yarnpkg.com/object-keys/-/object-keys-1.1.1.tgz"; sha512 = "NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA=="; }; } @@ -2565,7 +2572,7 @@ name = "object_visit___object_visit_1.0.1.tgz"; path = fetchurl { name = "object_visit___object_visit_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/object-visit/-/object-visit-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/object-visit/-/object-visit-1.0.1.tgz"; sha1 = "95xEk68MU3e1n+OdOV5BBC3QRbs="; }; } @@ -2573,7 +2580,7 @@ name = "object.assign___object.assign_4.1.0.tgz"; path = fetchurl { name = "object.assign___object.assign_4.1.0.tgz"; - url = "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.0.tgz"; + url = "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.0.tgz"; sha512 = "exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w=="; }; } @@ -2581,7 +2588,7 @@ name = "object.entries___object.entries_1.1.1.tgz"; path = fetchurl { name = "object.entries___object.entries_1.1.1.tgz"; - url = "https://registry.yarnpkg.com/object.entries/-/object.entries-1.1.1.tgz"; + url = "https://registry.yarnpkg.com/object.entries/-/object.entries-1.1.1.tgz"; sha512 = "ilqR7BgdyZetJutmDPfXCDffGa0/Yzl2ivVNpbx/g4UeWrCdRnFDUBrKJGLhGieRHDATnyZXWBeCb29k9CJysQ=="; }; } @@ -2589,7 +2596,7 @@ name = "object.fromentries___object.fromentries_2.0.2.tgz"; path = fetchurl { name = "object.fromentries___object.fromentries_2.0.2.tgz"; - url = "https://registry.yarnpkg.com/object.fromentries/-/object.fromentries-2.0.2.tgz"; + url = "https://registry.yarnpkg.com/object.fromentries/-/object.fromentries-2.0.2.tgz"; sha512 = "r3ZiBH7MQppDJVLx6fhD618GKNG40CZYH9wgwdhKxBDDbQgjeWGGd4AtkZad84d291YxvWe7bJGuE65Anh0dxQ=="; }; } @@ -2597,7 +2604,7 @@ name = "object.pick___object.pick_1.3.0.tgz"; path = fetchurl { name = "object.pick___object.pick_1.3.0.tgz"; - url = "https://registry.yarnpkg.com/object.pick/-/object.pick-1.3.0.tgz"; + url = "https://registry.yarnpkg.com/object.pick/-/object.pick-1.3.0.tgz"; sha1 = "h6EKxMFpS9Lhy/U1kaZhQftd10c="; }; } @@ -2605,7 +2612,7 @@ name = "object.values___object.values_1.1.1.tgz"; path = fetchurl { name = "object.values___object.values_1.1.1.tgz"; - url = "https://registry.yarnpkg.com/object.values/-/object.values-1.1.1.tgz"; + url = "https://registry.yarnpkg.com/object.values/-/object.values-1.1.1.tgz"; sha512 = "WTa54g2K8iu0kmS/us18jEmdv1a4Wi//BZ/DTVYEcH0XhLM5NYdpDHja3gt57VrZLcNAO2WGA+KpWsDBaHt6eA=="; }; } @@ -2613,7 +2620,7 @@ name = "once___once_1.4.0.tgz"; path = fetchurl { name = "once___once_1.4.0.tgz"; - url = "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz"; + url = "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz"; sha1 = "WDsap3WWHUsROsF9nFC6753Xa9E="; }; } @@ -2621,7 +2628,7 @@ name = "onetime___onetime_2.0.1.tgz"; path = fetchurl { name = "onetime___onetime_2.0.1.tgz"; - url = "https://registry.yarnpkg.com/onetime/-/onetime-2.0.1.tgz"; + url = "https://registry.yarnpkg.com/onetime/-/onetime-2.0.1.tgz"; sha1 = "BnQoIw/WdEOyeUsiu6UotoZ5YtQ="; }; } @@ -2629,7 +2636,7 @@ name = "optionator___optionator_0.8.3.tgz"; path = fetchurl { name = "optionator___optionator_0.8.3.tgz"; - url = "https://registry.yarnpkg.com/optionator/-/optionator-0.8.3.tgz"; + url = "https://registry.yarnpkg.com/optionator/-/optionator-0.8.3.tgz"; sha512 = "+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA=="; }; } @@ -2637,7 +2644,7 @@ name = "os_locale___os_locale_2.1.0.tgz"; path = fetchurl { name = "os_locale___os_locale_2.1.0.tgz"; - url = "https://registry.yarnpkg.com/os-locale/-/os-locale-2.1.0.tgz"; + url = "https://registry.yarnpkg.com/os-locale/-/os-locale-2.1.0.tgz"; sha512 = "3sslG3zJbEYcaC4YVAvDorjGxc7tv6KVATnLPZONiljsUncvihe9BQoVCEs0RZ1kmf4Hk9OBqlZfJZWI4GanKA=="; }; } @@ -2645,7 +2652,7 @@ name = "os_tmpdir___os_tmpdir_1.0.2.tgz"; path = fetchurl { name = "os_tmpdir___os_tmpdir_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz"; sha1 = "u+Z0BseaqFxc/sdm/lc0VV36EnQ="; }; } @@ -2653,7 +2660,7 @@ name = "p_finally___p_finally_1.0.0.tgz"; path = fetchurl { name = "p_finally___p_finally_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/p-finally/-/p-finally-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/p-finally/-/p-finally-1.0.0.tgz"; sha1 = "P7z7FbiZpEEjs0ttzBi3JDNqLK4="; }; } @@ -2661,7 +2668,7 @@ name = "p_limit___p_limit_1.3.0.tgz"; path = fetchurl { name = "p_limit___p_limit_1.3.0.tgz"; - url = "https://registry.yarnpkg.com/p-limit/-/p-limit-1.3.0.tgz"; + url = "https://registry.yarnpkg.com/p-limit/-/p-limit-1.3.0.tgz"; sha512 = "vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q=="; }; } @@ -2669,7 +2676,7 @@ name = "p_limit___p_limit_2.3.0.tgz"; path = fetchurl { name = "p_limit___p_limit_2.3.0.tgz"; - url = "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz"; + url = "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz"; sha512 = "//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w=="; }; } @@ -2677,7 +2684,7 @@ name = "p_locate___p_locate_2.0.0.tgz"; path = fetchurl { name = "p_locate___p_locate_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz"; sha1 = "IKAQOyIqcMj9OcwuWAaA893l7EM="; }; } @@ -2685,7 +2692,7 @@ name = "p_locate___p_locate_3.0.0.tgz"; path = fetchurl { name = "p_locate___p_locate_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/p-locate/-/p-locate-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/p-locate/-/p-locate-3.0.0.tgz"; sha512 = "x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ=="; }; } @@ -2693,7 +2700,7 @@ name = "p_map___p_map_1.2.0.tgz"; path = fetchurl { name = "p_map___p_map_1.2.0.tgz"; - url = "https://registry.yarnpkg.com/p-map/-/p-map-1.2.0.tgz"; + url = "https://registry.yarnpkg.com/p-map/-/p-map-1.2.0.tgz"; sha512 = "r6zKACMNhjPJMTl8KcFH4li//gkrXWfbD6feV8l6doRHlzljFWGJ2AP6iKaCJXyZmAUMOPtvbW7EXkbWO/pLEA=="; }; } @@ -2701,7 +2708,7 @@ name = "p_map___p_map_2.1.0.tgz"; path = fetchurl { name = "p_map___p_map_2.1.0.tgz"; - url = "https://registry.yarnpkg.com/p-map/-/p-map-2.1.0.tgz"; + url = "https://registry.yarnpkg.com/p-map/-/p-map-2.1.0.tgz"; sha512 = "y3b8Kpd8OAN444hxfBbFfj1FY/RjtTd8tzYwhUqNYXx0fXx2iX4maP4Qr6qhIKbQXI02wTLAda4fYUbDagTUFw=="; }; } @@ -2709,7 +2716,7 @@ name = "p_try___p_try_1.0.0.tgz"; path = fetchurl { name = "p_try___p_try_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/p-try/-/p-try-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/p-try/-/p-try-1.0.0.tgz"; sha1 = "y8ec26+P1CKOE/Yh8rGiN8GyB7M="; }; } @@ -2717,7 +2724,7 @@ name = "p_try___p_try_2.2.0.tgz"; path = fetchurl { name = "p_try___p_try_2.2.0.tgz"; - url = "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz"; + url = "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz"; sha512 = "R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ=="; }; } @@ -2725,7 +2732,7 @@ name = "parent_module___parent_module_1.0.1.tgz"; path = fetchurl { name = "parent_module___parent_module_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz"; sha512 = "GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g=="; }; } @@ -2733,7 +2740,7 @@ name = "parse_json___parse_json_2.2.0.tgz"; path = fetchurl { name = "parse_json___parse_json_2.2.0.tgz"; - url = "https://registry.yarnpkg.com/parse-json/-/parse-json-2.2.0.tgz"; + url = "https://registry.yarnpkg.com/parse-json/-/parse-json-2.2.0.tgz"; sha1 = "9ID0BDTvgHQfhGkJn43qGPVaTck="; }; } @@ -2741,7 +2748,7 @@ name = "parse_json___parse_json_4.0.0.tgz"; path = fetchurl { name = "parse_json___parse_json_4.0.0.tgz"; - url = "https://registry.yarnpkg.com/parse-json/-/parse-json-4.0.0.tgz"; + url = "https://registry.yarnpkg.com/parse-json/-/parse-json-4.0.0.tgz"; sha1 = "vjX1Qlvh9/bHRxhPmKeIy5lHfuA="; }; } @@ -2749,7 +2756,7 @@ name = "pascalcase___pascalcase_0.1.1.tgz"; path = fetchurl { name = "pascalcase___pascalcase_0.1.1.tgz"; - url = "https://registry.yarnpkg.com/pascalcase/-/pascalcase-0.1.1.tgz"; + url = "https://registry.yarnpkg.com/pascalcase/-/pascalcase-0.1.1.tgz"; sha1 = "s2PlXoAGym/iF4TS2yK9FdeRfxQ="; }; } @@ -2757,7 +2764,7 @@ name = "path_exists___path_exists_3.0.0.tgz"; path = fetchurl { name = "path_exists___path_exists_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz"; sha1 = "zg6+ql94yxiSXqfYENe1mwEP1RU="; }; } @@ -2765,7 +2772,7 @@ name = "path_is_absolute___path_is_absolute_1.0.1.tgz"; path = fetchurl { name = "path_is_absolute___path_is_absolute_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz"; sha1 = "F0uSaHNVNP+8es5r9TpanhtcX18="; }; } @@ -2773,7 +2780,7 @@ name = "path_is_inside___path_is_inside_1.0.2.tgz"; path = fetchurl { name = "path_is_inside___path_is_inside_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/path-is-inside/-/path-is-inside-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/path-is-inside/-/path-is-inside-1.0.2.tgz"; sha1 = "NlQX3t5EQw0cEa9hAn+s8HS9/FM="; }; } @@ -2781,7 +2788,7 @@ name = "path_key___path_key_2.0.1.tgz"; path = fetchurl { name = "path_key___path_key_2.0.1.tgz"; - url = "https://registry.yarnpkg.com/path-key/-/path-key-2.0.1.tgz"; + url = "https://registry.yarnpkg.com/path-key/-/path-key-2.0.1.tgz"; sha1 = "QRyttXTFoUDTpLGRDUDYDMn0C0A="; }; } @@ -2789,7 +2796,7 @@ name = "path_parse___path_parse_1.0.6.tgz"; path = fetchurl { name = "path_parse___path_parse_1.0.6.tgz"; - url = "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.6.tgz"; + url = "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.6.tgz"; sha512 = "GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw=="; }; } @@ -2797,7 +2804,7 @@ name = "path_type___path_type_2.0.0.tgz"; path = fetchurl { name = "path_type___path_type_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/path-type/-/path-type-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/path-type/-/path-type-2.0.0.tgz"; sha1 = "8BLMuEFbcJb8LaoQVMPXI4lZTHM="; }; } @@ -2805,7 +2812,7 @@ name = "pify___pify_2.3.0.tgz"; path = fetchurl { name = "pify___pify_2.3.0.tgz"; - url = "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz"; + url = "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz"; sha1 = "7RQaasBDqEnqWISY59yosVMw6Qw="; }; } @@ -2813,7 +2820,7 @@ name = "pify___pify_3.0.0.tgz"; path = fetchurl { name = "pify___pify_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/pify/-/pify-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/pify/-/pify-3.0.0.tgz"; sha1 = "5aSs0sEB/fPZpNB/DbxNtJ3SgXY="; }; } @@ -2821,7 +2828,7 @@ name = "pinkie_promise___pinkie_promise_2.0.1.tgz"; path = fetchurl { name = "pinkie_promise___pinkie_promise_2.0.1.tgz"; - url = "https://registry.yarnpkg.com/pinkie-promise/-/pinkie-promise-2.0.1.tgz"; + url = "https://registry.yarnpkg.com/pinkie-promise/-/pinkie-promise-2.0.1.tgz"; sha1 = "ITXW36ejWMBprJsXh3YogihFD/o="; }; } @@ -2829,7 +2836,7 @@ name = "pinkie___pinkie_2.0.4.tgz"; path = fetchurl { name = "pinkie___pinkie_2.0.4.tgz"; - url = "https://registry.yarnpkg.com/pinkie/-/pinkie-2.0.4.tgz"; + url = "https://registry.yarnpkg.com/pinkie/-/pinkie-2.0.4.tgz"; sha1 = "clVrgM+g1IqXToDnckjoDtT3+HA="; }; } @@ -2837,7 +2844,7 @@ name = "pkg_dir___pkg_dir_2.0.0.tgz"; path = fetchurl { name = "pkg_dir___pkg_dir_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-2.0.0.tgz"; sha1 = "9tXREJ4Z1j7fQo4L1X4Sd3YVM0s="; }; } @@ -2845,7 +2852,7 @@ name = "pkg_dir___pkg_dir_3.0.0.tgz"; path = fetchurl { name = "pkg_dir___pkg_dir_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-3.0.0.tgz"; sha512 = "/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw=="; }; } @@ -2853,7 +2860,7 @@ name = "please_upgrade_node___please_upgrade_node_3.2.0.tgz"; path = fetchurl { name = "please_upgrade_node___please_upgrade_node_3.2.0.tgz"; - url = "https://registry.yarnpkg.com/please-upgrade-node/-/please-upgrade-node-3.2.0.tgz"; + url = "https://registry.yarnpkg.com/please-upgrade-node/-/please-upgrade-node-3.2.0.tgz"; sha512 = "gQR3WpIgNIKwBMVLkpMUeR3e1/E1y42bqDQZfql+kDeXd8COYfM8PQA4X6y7a8u9Ua9FHmsrrmirW2vHs45hWg=="; }; } @@ -2861,7 +2868,7 @@ name = "pluralize___pluralize_7.0.0.tgz"; path = fetchurl { name = "pluralize___pluralize_7.0.0.tgz"; - url = "https://registry.yarnpkg.com/pluralize/-/pluralize-7.0.0.tgz"; + url = "https://registry.yarnpkg.com/pluralize/-/pluralize-7.0.0.tgz"; sha512 = "ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow=="; }; } @@ -2869,7 +2876,7 @@ name = "posix_character_classes___posix_character_classes_0.1.1.tgz"; path = fetchurl { name = "posix_character_classes___posix_character_classes_0.1.1.tgz"; - url = "https://registry.yarnpkg.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz"; + url = "https://registry.yarnpkg.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz"; sha1 = "AerA/jta9xoqbAL+q7jB/vfgDqs="; }; } @@ -2877,7 +2884,7 @@ name = "prelude_ls___prelude_ls_1.1.2.tgz"; path = fetchurl { name = "prelude_ls___prelude_ls_1.1.2.tgz"; - url = "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.1.2.tgz"; + url = "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.1.2.tgz"; sha1 = "IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ="; }; } @@ -2885,7 +2892,7 @@ name = "prettier_eslint_cli___prettier_eslint_cli_4.7.1.tgz"; path = fetchurl { name = "prettier_eslint_cli___prettier_eslint_cli_4.7.1.tgz"; - url = "https://registry.yarnpkg.com/prettier-eslint-cli/-/prettier-eslint-cli-4.7.1.tgz"; + url = "https://registry.yarnpkg.com/prettier-eslint-cli/-/prettier-eslint-cli-4.7.1.tgz"; sha512 = "hQbsGaEVz97oBBcKdsJ46khv0kOGkMyWrXzcFOXW6X8UuetZ/j0yDJkNJgUTVc6PVFbbzBXk+qgd5vos9qzXPQ=="; }; } @@ -2893,7 +2900,7 @@ name = "prettier_eslint___prettier_eslint_8.8.2.tgz"; path = fetchurl { name = "prettier_eslint___prettier_eslint_8.8.2.tgz"; - url = "https://registry.yarnpkg.com/prettier-eslint/-/prettier-eslint-8.8.2.tgz"; + url = "https://registry.yarnpkg.com/prettier-eslint/-/prettier-eslint-8.8.2.tgz"; sha512 = "2UzApPuxi2yRoyMlXMazgR6UcH9DKJhNgCviIwY3ixZ9THWSSrUww5vkiZ3C48WvpFl1M1y/oU63deSy1puWEA=="; }; } @@ -2901,7 +2908,7 @@ name = "prettier___prettier_1.19.1.tgz"; path = fetchurl { name = "prettier___prettier_1.19.1.tgz"; - url = "https://registry.yarnpkg.com/prettier/-/prettier-1.19.1.tgz"; + url = "https://registry.yarnpkg.com/prettier/-/prettier-1.19.1.tgz"; sha512 = "s7PoyDv/II1ObgQunCbB9PdLmUcBZcnWOcxDh7O0N/UwDEsHyqkW+Qh28jW+mVuCdx7gLB0BotYI1Y6uI9iyew=="; }; } @@ -2909,7 +2916,7 @@ name = "pretty_format___pretty_format_23.6.0.tgz"; path = fetchurl { name = "pretty_format___pretty_format_23.6.0.tgz"; - url = "https://registry.yarnpkg.com/pretty-format/-/pretty-format-23.6.0.tgz"; + url = "https://registry.yarnpkg.com/pretty-format/-/pretty-format-23.6.0.tgz"; sha512 = "zf9NV1NSlDLDjycnwm6hpFATCGl/K1lt0R/GdkAK2O5LN/rwJoB+Mh93gGJjut4YbmecbfgLWVGSTCr0Ewvvbw=="; }; } @@ -2917,7 +2924,7 @@ name = "process_nextick_args___process_nextick_args_2.0.1.tgz"; path = fetchurl { name = "process_nextick_args___process_nextick_args_2.0.1.tgz"; - url = "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz"; + url = "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz"; sha512 = "3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag=="; }; } @@ -2925,7 +2932,7 @@ name = "progress___progress_2.0.3.tgz"; path = fetchurl { name = "progress___progress_2.0.3.tgz"; - url = "https://registry.yarnpkg.com/progress/-/progress-2.0.3.tgz"; + url = "https://registry.yarnpkg.com/progress/-/progress-2.0.3.tgz"; sha512 = "7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA=="; }; } @@ -2933,7 +2940,7 @@ name = "prop_types___prop_types_15.7.2.tgz"; path = fetchurl { name = "prop_types___prop_types_15.7.2.tgz"; - url = "https://registry.yarnpkg.com/prop-types/-/prop-types-15.7.2.tgz"; + url = "https://registry.yarnpkg.com/prop-types/-/prop-types-15.7.2.tgz"; sha512 = "8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ=="; }; } @@ -2941,7 +2948,7 @@ name = "property_expr___property_expr_1.5.1.tgz"; path = fetchurl { name = "property_expr___property_expr_1.5.1.tgz"; - url = "https://registry.yarnpkg.com/property-expr/-/property-expr-1.5.1.tgz"; + url = "https://registry.yarnpkg.com/property-expr/-/property-expr-1.5.1.tgz"; sha512 = "CGuc0VUTGthpJXL36ydB6jnbyOf/rAHFvmVrJlH+Rg0DqqLFQGAP6hIaxD/G0OAmBJPhXDHuEJigrp0e0wFV6g=="; }; } @@ -2949,7 +2956,7 @@ name = "pseudomap___pseudomap_1.0.2.tgz"; path = fetchurl { name = "pseudomap___pseudomap_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/pseudomap/-/pseudomap-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/pseudomap/-/pseudomap-1.0.2.tgz"; sha1 = "8FKijacOYYkX7wqKw0wa5aaChrM="; }; } @@ -2957,7 +2964,7 @@ name = "pump___pump_3.0.0.tgz"; path = fetchurl { name = "pump___pump_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/pump/-/pump-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/pump/-/pump-3.0.0.tgz"; sha512 = "LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww=="; }; } @@ -2965,7 +2972,7 @@ name = "punycode___punycode_2.1.1.tgz"; path = fetchurl { name = "punycode___punycode_2.1.1.tgz"; - url = "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz"; + url = "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz"; sha512 = "XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A=="; }; } @@ -2973,7 +2980,7 @@ name = "quick_lru___quick_lru_1.1.0.tgz"; path = fetchurl { name = "quick_lru___quick_lru_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/quick-lru/-/quick-lru-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/quick-lru/-/quick-lru-1.1.0.tgz"; sha1 = "Q2CxfGETatOAeDl/8RQW4Ybc+7g="; }; } @@ -2981,7 +2988,7 @@ name = "ramda___ramda_0.26.1.tgz"; path = fetchurl { name = "ramda___ramda_0.26.1.tgz"; - url = "https://registry.yarnpkg.com/ramda/-/ramda-0.26.1.tgz"; + url = "https://registry.yarnpkg.com/ramda/-/ramda-0.26.1.tgz"; sha512 = "hLWjpy7EnsDBb0p+Z3B7rPi3GDeRG5ZtiI33kJhTt+ORCd38AbAIjB/9zRIUoeTbE/AVX5ZkU7m6bznsvrf8eQ=="; }; } @@ -2989,7 +2996,7 @@ name = "react_is___react_is_16.13.1.tgz"; path = fetchurl { name = "react_is___react_is_16.13.1.tgz"; - url = "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz"; + url = "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz"; sha512 = "24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ=="; }; } @@ -2997,7 +3004,7 @@ name = "read_pkg_up___read_pkg_up_2.0.0.tgz"; path = fetchurl { name = "read_pkg_up___read_pkg_up_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/read-pkg-up/-/read-pkg-up-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/read-pkg-up/-/read-pkg-up-2.0.0.tgz"; sha1 = "a3KoBImE4MQeeVEP1en6mbO1Sb4="; }; } @@ -3005,7 +3012,7 @@ name = "read_pkg___read_pkg_2.0.0.tgz"; path = fetchurl { name = "read_pkg___read_pkg_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/read-pkg/-/read-pkg-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/read-pkg/-/read-pkg-2.0.0.tgz"; sha1 = "jvHAYjxqbbDcZxPEv6xGMysjaPg="; }; } @@ -3013,7 +3020,7 @@ name = "read_pkg___read_pkg_4.0.1.tgz"; path = fetchurl { name = "read_pkg___read_pkg_4.0.1.tgz"; - url = "https://registry.yarnpkg.com/read-pkg/-/read-pkg-4.0.1.tgz"; + url = "https://registry.yarnpkg.com/read-pkg/-/read-pkg-4.0.1.tgz"; sha1 = "ljYlN48+HE1IyFhytabsfV0JMjc="; }; } @@ -3021,7 +3028,7 @@ name = "readable_stream___readable_stream_2.3.7.tgz"; path = fetchurl { name = "readable_stream___readable_stream_2.3.7.tgz"; - url = "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz"; + url = "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz"; sha512 = "Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw=="; }; } @@ -3029,7 +3036,7 @@ name = "regenerator_runtime___regenerator_runtime_0.11.1.tgz"; path = fetchurl { name = "regenerator_runtime___regenerator_runtime_0.11.1.tgz"; - url = "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz"; + url = "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz"; sha512 = "MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg=="; }; } @@ -3037,7 +3044,7 @@ name = "regenerator_runtime___regenerator_runtime_0.13.5.tgz"; path = fetchurl { name = "regenerator_runtime___regenerator_runtime_0.13.5.tgz"; - url = "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.5.tgz"; + url = "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.5.tgz"; sha512 = "ZS5w8CpKFinUzOwW3c83oPeVXoNsrLsaCoLtJvAClH135j/R77RuymhiSErhm2lKcwSCIpmvIWSbDkIfAqKQlA=="; }; } @@ -3045,7 +3052,7 @@ name = "regex_not___regex_not_1.0.2.tgz"; path = fetchurl { name = "regex_not___regex_not_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/regex-not/-/regex-not-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/regex-not/-/regex-not-1.0.2.tgz"; sha512 = "J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A=="; }; } @@ -3053,7 +3060,7 @@ name = "regexp.prototype.flags___regexp.prototype.flags_1.3.0.tgz"; path = fetchurl { name = "regexp.prototype.flags___regexp.prototype.flags_1.3.0.tgz"; - url = "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.3.0.tgz"; + url = "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.3.0.tgz"; sha512 = "2+Q0C5g951OlYlJz6yu5/M33IcsESLlLfsyIaLJaG4FA2r4yP8MvVMJUUP/fVBkSpbbbZlS5gynbEWLipiiXiQ=="; }; } @@ -3061,7 +3068,7 @@ name = "regexpp___regexpp_1.1.0.tgz"; path = fetchurl { name = "regexpp___regexpp_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/regexpp/-/regexpp-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/regexpp/-/regexpp-1.1.0.tgz"; sha512 = "LOPw8FpgdQF9etWMaAfG/WRthIdXJGYp4mJ2Jgn/2lpkbod9jPn0t9UqN7AxBOKNfzRbYyVfgc7Vk4t/MpnXgw=="; }; } @@ -3069,7 +3076,7 @@ name = "regexpp___regexpp_2.0.1.tgz"; path = fetchurl { name = "regexpp___regexpp_2.0.1.tgz"; - url = "https://registry.yarnpkg.com/regexpp/-/regexpp-2.0.1.tgz"; + url = "https://registry.yarnpkg.com/regexpp/-/regexpp-2.0.1.tgz"; sha512 = "lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw=="; }; } @@ -3077,7 +3084,7 @@ name = "repeat_element___repeat_element_1.1.3.tgz"; path = fetchurl { name = "repeat_element___repeat_element_1.1.3.tgz"; - url = "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.3.tgz"; + url = "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.3.tgz"; sha512 = "ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g=="; }; } @@ -3085,7 +3092,7 @@ name = "repeat_string___repeat_string_1.6.1.tgz"; path = fetchurl { name = "repeat_string___repeat_string_1.6.1.tgz"; - url = "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz"; + url = "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz"; sha1 = "jcrkcOHIirwtYA//Sndihtp15jc="; }; } @@ -3093,7 +3100,7 @@ name = "require_directory___require_directory_2.1.1.tgz"; path = fetchurl { name = "require_directory___require_directory_2.1.1.tgz"; - url = "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz"; + url = "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz"; sha1 = "jGStX9MNqxyXbiNE/+f3kqam30I="; }; } @@ -3101,7 +3108,7 @@ name = "require_main_filename___require_main_filename_1.0.1.tgz"; path = fetchurl { name = "require_main_filename___require_main_filename_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/require-main-filename/-/require-main-filename-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/require-main-filename/-/require-main-filename-1.0.1.tgz"; sha1 = "l/cXtp1IeE9fUmpsWqj/3aBVpNE="; }; } @@ -3109,7 +3116,7 @@ name = "require_relative___require_relative_0.8.7.tgz"; path = fetchurl { name = "require_relative___require_relative_0.8.7.tgz"; - url = "https://registry.yarnpkg.com/require-relative/-/require-relative-0.8.7.tgz"; + url = "https://registry.yarnpkg.com/require-relative/-/require-relative-0.8.7.tgz"; sha1 = "eZlTn8ngR6N5KPoZb44VY9q9Nt4="; }; } @@ -3117,7 +3124,7 @@ name = "require_uncached___require_uncached_1.0.3.tgz"; path = fetchurl { name = "require_uncached___require_uncached_1.0.3.tgz"; - url = "https://registry.yarnpkg.com/require-uncached/-/require-uncached-1.0.3.tgz"; + url = "https://registry.yarnpkg.com/require-uncached/-/require-uncached-1.0.3.tgz"; sha1 = "Tg1W1slmL9MeQwEcS5WqSZVUIdM="; }; } @@ -3125,7 +3132,7 @@ name = "reserved_words___reserved_words_0.1.2.tgz"; path = fetchurl { name = "reserved_words___reserved_words_0.1.2.tgz"; - url = "https://registry.yarnpkg.com/reserved-words/-/reserved-words-0.1.2.tgz"; + url = "https://registry.yarnpkg.com/reserved-words/-/reserved-words-0.1.2.tgz"; sha1 = "AKCUD5jNUBrqqsMWQR2a3FKzGrE="; }; } @@ -3133,7 +3140,7 @@ name = "resolve_from___resolve_from_1.0.1.tgz"; path = fetchurl { name = "resolve_from___resolve_from_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/resolve-from/-/resolve-from-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/resolve-from/-/resolve-from-1.0.1.tgz"; sha1 = "Jsv+k10a7uq7Kbw/5a6wHpPUQiY="; }; } @@ -3141,7 +3148,7 @@ name = "resolve_from___resolve_from_3.0.0.tgz"; path = fetchurl { name = "resolve_from___resolve_from_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/resolve-from/-/resolve-from-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/resolve-from/-/resolve-from-3.0.0.tgz"; sha1 = "six699nWiBvItuZTM17rywoYh0g="; }; } @@ -3149,7 +3156,7 @@ name = "resolve_from___resolve_from_4.0.0.tgz"; path = fetchurl { name = "resolve_from___resolve_from_4.0.0.tgz"; - url = "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz"; + url = "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz"; sha512 = "pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g=="; }; } @@ -3157,7 +3164,7 @@ name = "resolve_url___resolve_url_0.2.1.tgz"; path = fetchurl { name = "resolve_url___resolve_url_0.2.1.tgz"; - url = "https://registry.yarnpkg.com/resolve-url/-/resolve-url-0.2.1.tgz"; + url = "https://registry.yarnpkg.com/resolve-url/-/resolve-url-0.2.1.tgz"; sha1 = "LGN/53yJOv0qZj/iGqkIAGjiBSo="; }; } @@ -3165,7 +3172,7 @@ name = "resolve___resolve_1.17.0.tgz"; path = fetchurl { name = "resolve___resolve_1.17.0.tgz"; - url = "https://registry.yarnpkg.com/resolve/-/resolve-1.17.0.tgz"; + url = "https://registry.yarnpkg.com/resolve/-/resolve-1.17.0.tgz"; sha512 = "ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w=="; }; } @@ -3173,7 +3180,7 @@ name = "restore_cursor___restore_cursor_2.0.0.tgz"; path = fetchurl { name = "restore_cursor___restore_cursor_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-2.0.0.tgz"; sha1 = "n37ih/gv0ybU/RYpI9YhKe7g368="; }; } @@ -3181,7 +3188,7 @@ name = "ret___ret_0.1.15.tgz"; path = fetchurl { name = "ret___ret_0.1.15.tgz"; - url = "https://registry.yarnpkg.com/ret/-/ret-0.1.15.tgz"; + url = "https://registry.yarnpkg.com/ret/-/ret-0.1.15.tgz"; sha512 = "TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg=="; }; } @@ -3189,7 +3196,7 @@ name = "rimraf___rimraf_2.6.3.tgz"; path = fetchurl { name = "rimraf___rimraf_2.6.3.tgz"; - url = "https://registry.yarnpkg.com/rimraf/-/rimraf-2.6.3.tgz"; + url = "https://registry.yarnpkg.com/rimraf/-/rimraf-2.6.3.tgz"; sha512 = "mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA=="; }; } @@ -3197,7 +3204,7 @@ name = "rimraf___rimraf_2.7.1.tgz"; path = fetchurl { name = "rimraf___rimraf_2.7.1.tgz"; - url = "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz"; + url = "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz"; sha512 = "uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w=="; }; } @@ -3205,7 +3212,7 @@ name = "run_async___run_async_2.4.1.tgz"; path = fetchurl { name = "run_async___run_async_2.4.1.tgz"; - url = "https://registry.yarnpkg.com/run-async/-/run-async-2.4.1.tgz"; + url = "https://registry.yarnpkg.com/run-async/-/run-async-2.4.1.tgz"; sha512 = "tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ=="; }; } @@ -3213,7 +3220,7 @@ name = "run_node___run_node_1.0.0.tgz"; path = fetchurl { name = "run_node___run_node_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/run-node/-/run-node-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/run-node/-/run-node-1.0.0.tgz"; sha512 = "kc120TBlQ3mih1LSzdAJXo4xn/GWS2ec0l3S+syHDXP9uRr0JAT8Qd3mdMuyjqCzeZktgP3try92cEgf9Nks8A=="; }; } @@ -3221,7 +3228,7 @@ name = "rx_lite_aggregates___rx_lite_aggregates_4.0.8.tgz"; path = fetchurl { name = "rx_lite_aggregates___rx_lite_aggregates_4.0.8.tgz"; - url = "https://registry.yarnpkg.com/rx-lite-aggregates/-/rx-lite-aggregates-4.0.8.tgz"; + url = "https://registry.yarnpkg.com/rx-lite-aggregates/-/rx-lite-aggregates-4.0.8.tgz"; sha1 = "dTuHqJoRyVRnxKwWJsTvxOBcZ74="; }; } @@ -3229,7 +3236,7 @@ name = "rx_lite___rx_lite_4.0.8.tgz"; path = fetchurl { name = "rx_lite___rx_lite_4.0.8.tgz"; - url = "https://registry.yarnpkg.com/rx-lite/-/rx-lite-4.0.8.tgz"; + url = "https://registry.yarnpkg.com/rx-lite/-/rx-lite-4.0.8.tgz"; sha1 = "Cx4Rr4vESDbwSmQH6S2kJGe3lEQ="; }; } @@ -3237,7 +3244,7 @@ name = "rxjs___rxjs_5.5.12.tgz"; path = fetchurl { name = "rxjs___rxjs_5.5.12.tgz"; - url = "https://registry.yarnpkg.com/rxjs/-/rxjs-5.5.12.tgz"; + url = "https://registry.yarnpkg.com/rxjs/-/rxjs-5.5.12.tgz"; sha512 = "xx2itnL5sBbqeeiVgNPVuQQ1nC8Jp2WfNJhXWHmElW9YmrpS9UVnNzhP3EH3HFqexO5Tlp8GhYY+WEcqcVMvGw=="; }; } @@ -3245,7 +3252,7 @@ name = "rxjs___rxjs_6.5.5.tgz"; path = fetchurl { name = "rxjs___rxjs_6.5.5.tgz"; - url = "https://registry.yarnpkg.com/rxjs/-/rxjs-6.5.5.tgz"; + url = "https://registry.yarnpkg.com/rxjs/-/rxjs-6.5.5.tgz"; sha512 = "WfQI+1gohdf0Dai/Bbmk5L5ItH5tYqm3ki2c5GdWhKjalzjg93N3avFjVStyZZz+A2Em+ZxKH5bNghw9UeylGQ=="; }; } @@ -3253,7 +3260,7 @@ name = "safe_buffer___safe_buffer_5.1.2.tgz"; path = fetchurl { name = "safe_buffer___safe_buffer_5.1.2.tgz"; - url = "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz"; + url = "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz"; sha512 = "Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="; }; } @@ -3261,7 +3268,7 @@ name = "safe_regex___safe_regex_1.1.0.tgz"; path = fetchurl { name = "safe_regex___safe_regex_1.1.0.tgz"; - url = "https://registry.yarnpkg.com/safe-regex/-/safe-regex-1.1.0.tgz"; + url = "https://registry.yarnpkg.com/safe-regex/-/safe-regex-1.1.0.tgz"; sha1 = "QKNmnzsHfR6UPURinhV91IAjvy4="; }; } @@ -3269,7 +3276,7 @@ name = "safer_buffer___safer_buffer_2.1.2.tgz"; path = fetchurl { name = "safer_buffer___safer_buffer_2.1.2.tgz"; - url = "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz"; + url = "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz"; sha512 = "YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="; }; } @@ -3277,7 +3284,7 @@ name = "semver_compare___semver_compare_1.0.0.tgz"; path = fetchurl { name = "semver_compare___semver_compare_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/semver-compare/-/semver-compare-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/semver-compare/-/semver-compare-1.0.0.tgz"; sha1 = "De4hahyUGrN+nvsXiPavxf9VN/w="; }; } @@ -3285,7 +3292,7 @@ name = "semver___semver_5.7.1.tgz"; path = fetchurl { name = "semver___semver_5.7.1.tgz"; - url = "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz"; + url = "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz"; sha512 = "sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ=="; }; } @@ -3293,7 +3300,7 @@ name = "semver___semver_5.5.0.tgz"; path = fetchurl { name = "semver___semver_5.5.0.tgz"; - url = "https://registry.yarnpkg.com/semver/-/semver-5.5.0.tgz"; + url = "https://registry.yarnpkg.com/semver/-/semver-5.5.0.tgz"; sha512 = "4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA=="; }; } @@ -3301,7 +3308,7 @@ name = "set_blocking___set_blocking_2.0.0.tgz"; path = fetchurl { name = "set_blocking___set_blocking_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz"; sha1 = "BF+XgtARrppoA93TgrJDkrPYkPc="; }; } @@ -3309,7 +3316,7 @@ name = "set_value___set_value_2.0.1.tgz"; path = fetchurl { name = "set_value___set_value_2.0.1.tgz"; - url = "https://registry.yarnpkg.com/set-value/-/set-value-2.0.1.tgz"; + url = "https://registry.yarnpkg.com/set-value/-/set-value-2.0.1.tgz"; sha512 = "JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw=="; }; } @@ -3317,7 +3324,7 @@ name = "shebang_command___shebang_command_1.2.0.tgz"; path = fetchurl { name = "shebang_command___shebang_command_1.2.0.tgz"; - url = "https://registry.yarnpkg.com/shebang-command/-/shebang-command-1.2.0.tgz"; + url = "https://registry.yarnpkg.com/shebang-command/-/shebang-command-1.2.0.tgz"; sha1 = "RKrGW2lbAzmJaMOfNj/uXer98eo="; }; } @@ -3325,7 +3332,7 @@ name = "shebang_regex___shebang_regex_1.0.0.tgz"; path = fetchurl { name = "shebang_regex___shebang_regex_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-1.0.0.tgz"; sha1 = "2kL0l0DAtC2yypcoVxyxkMmO/qM="; }; } @@ -3333,7 +3340,7 @@ name = "side_channel___side_channel_1.0.2.tgz"; path = fetchurl { name = "side_channel___side_channel_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.2.tgz"; sha512 = "7rL9YlPHg7Ancea1S96Pa8/QWb4BtXL/TZvS6B8XFetGBeuhAsfmUspK6DokBeZ64+Kj9TCNRD/30pVz1BvQNA=="; }; } @@ -3341,7 +3348,7 @@ name = "signal_exit___signal_exit_3.0.3.tgz"; path = fetchurl { name = "signal_exit___signal_exit_3.0.3.tgz"; - url = "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.3.tgz"; + url = "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.3.tgz"; sha512 = "VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA=="; }; } @@ -3349,7 +3356,7 @@ name = "simple_git___simple_git_1.132.0.tgz"; path = fetchurl { name = "simple_git___simple_git_1.132.0.tgz"; - url = "https://registry.yarnpkg.com/simple-git/-/simple-git-1.132.0.tgz"; + url = "https://registry.yarnpkg.com/simple-git/-/simple-git-1.132.0.tgz"; sha512 = "xauHm1YqCTom1sC9eOjfq3/9RKiUA9iPnxBbrY2DdL8l4ADMu0jjM5l5lphQP5YWNqAL2aXC/OeuQ76vHtW5fg=="; }; } @@ -3357,7 +3364,7 @@ name = "slash___slash_2.0.0.tgz"; path = fetchurl { name = "slash___slash_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/slash/-/slash-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/slash/-/slash-2.0.0.tgz"; sha512 = "ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A=="; }; } @@ -3365,7 +3372,7 @@ name = "slice_ansi___slice_ansi_0.0.4.tgz"; path = fetchurl { name = "slice_ansi___slice_ansi_0.0.4.tgz"; - url = "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-0.0.4.tgz"; + url = "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-0.0.4.tgz"; sha1 = "7b+JA/ZvfOL46v1s7tZeJkyDGzU="; }; } @@ -3373,7 +3380,7 @@ name = "slice_ansi___slice_ansi_1.0.0.tgz"; path = fetchurl { name = "slice_ansi___slice_ansi_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-1.0.0.tgz"; sha512 = "POqxBK6Lb3q6s047D/XsDVNPnF9Dl8JSaqe9h9lURl0OdNqy/ujDrOiIHtsqXMGbWWTIomRzAMaTyawAU//Reg=="; }; } @@ -3381,7 +3388,7 @@ name = "slice_ansi___slice_ansi_2.1.0.tgz"; path = fetchurl { name = "slice_ansi___slice_ansi_2.1.0.tgz"; - url = "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-2.1.0.tgz"; + url = "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-2.1.0.tgz"; sha512 = "Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ=="; }; } @@ -3389,7 +3396,7 @@ name = "snapdragon_node___snapdragon_node_2.1.1.tgz"; path = fetchurl { name = "snapdragon_node___snapdragon_node_2.1.1.tgz"; - url = "https://registry.yarnpkg.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz"; + url = "https://registry.yarnpkg.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz"; sha512 = "O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw=="; }; } @@ -3397,7 +3404,7 @@ name = "snapdragon_util___snapdragon_util_3.0.1.tgz"; path = fetchurl { name = "snapdragon_util___snapdragon_util_3.0.1.tgz"; - url = "https://registry.yarnpkg.com/snapdragon-util/-/snapdragon-util-3.0.1.tgz"; + url = "https://registry.yarnpkg.com/snapdragon-util/-/snapdragon-util-3.0.1.tgz"; sha512 = "mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ=="; }; } @@ -3405,7 +3412,7 @@ name = "snapdragon___snapdragon_0.8.2.tgz"; path = fetchurl { name = "snapdragon___snapdragon_0.8.2.tgz"; - url = "https://registry.yarnpkg.com/snapdragon/-/snapdragon-0.8.2.tgz"; + url = "https://registry.yarnpkg.com/snapdragon/-/snapdragon-0.8.2.tgz"; sha512 = "FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg=="; }; } @@ -3413,7 +3420,7 @@ name = "source_map_resolve___source_map_resolve_0.5.3.tgz"; path = fetchurl { name = "source_map_resolve___source_map_resolve_0.5.3.tgz"; - url = "https://registry.yarnpkg.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz"; + url = "https://registry.yarnpkg.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz"; sha512 = "Htz+RnsXWk5+P2slx5Jh3Q66vhQj1Cllm0zvnaY98+NFx+Dv2CF/f5O/t8x+KaNdrdIAsruNzoh/KpialbqAnw=="; }; } @@ -3421,7 +3428,7 @@ name = "source_map_url___source_map_url_0.4.0.tgz"; path = fetchurl { name = "source_map_url___source_map_url_0.4.0.tgz"; - url = "https://registry.yarnpkg.com/source-map-url/-/source-map-url-0.4.0.tgz"; + url = "https://registry.yarnpkg.com/source-map-url/-/source-map-url-0.4.0.tgz"; sha1 = "PpNdfd1zYxuXZZlW1VEo6HtQhKM="; }; } @@ -3429,7 +3436,7 @@ name = "source_map___source_map_0.5.7.tgz"; path = fetchurl { name = "source_map___source_map_0.5.7.tgz"; - url = "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz"; + url = "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz"; sha1 = "igOdLRAh0i0eoUyA2OpGi6LvP8w="; }; } @@ -3437,7 +3444,7 @@ name = "spdx_correct___spdx_correct_3.1.0.tgz"; path = fetchurl { name = "spdx_correct___spdx_correct_3.1.0.tgz"; - url = "https://registry.yarnpkg.com/spdx-correct/-/spdx-correct-3.1.0.tgz"; + url = "https://registry.yarnpkg.com/spdx-correct/-/spdx-correct-3.1.0.tgz"; sha512 = "lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q=="; }; } @@ -3445,7 +3452,7 @@ name = "spdx_exceptions___spdx_exceptions_2.3.0.tgz"; path = fetchurl { name = "spdx_exceptions___spdx_exceptions_2.3.0.tgz"; - url = "https://registry.yarnpkg.com/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz"; + url = "https://registry.yarnpkg.com/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz"; sha512 = "/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A=="; }; } @@ -3453,7 +3460,7 @@ name = "spdx_expression_parse___spdx_expression_parse_3.0.1.tgz"; path = fetchurl { name = "spdx_expression_parse___spdx_expression_parse_3.0.1.tgz"; - url = "https://registry.yarnpkg.com/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz"; + url = "https://registry.yarnpkg.com/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz"; sha512 = "cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q=="; }; } @@ -3461,7 +3468,7 @@ name = "spdx_license_ids___spdx_license_ids_3.0.5.tgz"; path = fetchurl { name = "spdx_license_ids___spdx_license_ids_3.0.5.tgz"; - url = "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz"; + url = "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz"; sha512 = "J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q=="; }; } @@ -3469,7 +3476,7 @@ name = "split_string___split_string_3.1.0.tgz"; path = fetchurl { name = "split_string___split_string_3.1.0.tgz"; - url = "https://registry.yarnpkg.com/split-string/-/split-string-3.1.0.tgz"; + url = "https://registry.yarnpkg.com/split-string/-/split-string-3.1.0.tgz"; sha512 = "NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw=="; }; } @@ -3477,7 +3484,7 @@ name = "sprintf_js___sprintf_js_1.0.3.tgz"; path = fetchurl { name = "sprintf_js___sprintf_js_1.0.3.tgz"; - url = "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz"; + url = "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz"; sha1 = "BOaSb2YolTVPPdAVIDYzuFcpfiw="; }; } @@ -3485,7 +3492,7 @@ name = "ssri___ssri_10.0.0.tgz"; path = fetchurl { name = "ssri___ssri_10.0.0.tgz"; - url = "https://registry.yarnpkg.com/ssri/-/ssri-10.0.0.tgz"; + url = "https://registry.yarnpkg.com/ssri/-/ssri-10.0.0.tgz"; sha512 = "64ghGOpqW0k+jh7m5jndBGdVEoPikWwGQmBNN5ks6jyUSMymzHDTlnNHOvzp+6MmHOljr2MokUzvRksnTwG0Iw=="; }; } @@ -3493,7 +3500,7 @@ name = "staged_git_files___staged_git_files_1.1.2.tgz"; path = fetchurl { name = "staged_git_files___staged_git_files_1.1.2.tgz"; - url = "https://registry.yarnpkg.com/staged-git-files/-/staged-git-files-1.1.2.tgz"; + url = "https://registry.yarnpkg.com/staged-git-files/-/staged-git-files-1.1.2.tgz"; sha512 = "0Eyrk6uXW6tg9PYkhi/V/J4zHp33aNyi2hOCmhFLqLTIhbgqWn5jlSzI+IU0VqrZq6+DbHcabQl/WP6P3BG0QA=="; }; } @@ -3501,7 +3508,7 @@ name = "static_extend___static_extend_0.1.2.tgz"; path = fetchurl { name = "static_extend___static_extend_0.1.2.tgz"; - url = "https://registry.yarnpkg.com/static-extend/-/static-extend-0.1.2.tgz"; + url = "https://registry.yarnpkg.com/static-extend/-/static-extend-0.1.2.tgz"; sha1 = "YICcOcv/VTNyJv1eC1IPNB8ftcY="; }; } @@ -3509,7 +3516,7 @@ name = "string_argv___string_argv_0.0.2.tgz"; path = fetchurl { name = "string_argv___string_argv_0.0.2.tgz"; - url = "https://registry.yarnpkg.com/string-argv/-/string-argv-0.0.2.tgz"; + url = "https://registry.yarnpkg.com/string-argv/-/string-argv-0.0.2.tgz"; sha1 = "2sMECGkMIfPDYwo/86BYd73L1zY="; }; } @@ -3517,7 +3524,7 @@ name = "string_width___string_width_1.0.2.tgz"; path = fetchurl { name = "string_width___string_width_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz"; sha1 = "EYvfW4zcUaKn5w0hHgfisLmxB9M="; }; } @@ -3525,7 +3532,7 @@ name = "string_width___string_width_2.1.1.tgz"; path = fetchurl { name = "string_width___string_width_2.1.1.tgz"; - url = "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz"; + url = "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz"; sha512 = "nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw=="; }; } @@ -3533,7 +3540,7 @@ name = "string_width___string_width_3.1.0.tgz"; path = fetchurl { name = "string_width___string_width_3.1.0.tgz"; - url = "https://registry.yarnpkg.com/string-width/-/string-width-3.1.0.tgz"; + url = "https://registry.yarnpkg.com/string-width/-/string-width-3.1.0.tgz"; sha512 = "vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w=="; }; } @@ -3541,7 +3548,7 @@ name = "string.prototype.matchall___string.prototype.matchall_4.0.2.tgz"; path = fetchurl { name = "string.prototype.matchall___string.prototype.matchall_4.0.2.tgz"; - url = "https://registry.yarnpkg.com/string.prototype.matchall/-/string.prototype.matchall-4.0.2.tgz"; + url = "https://registry.yarnpkg.com/string.prototype.matchall/-/string.prototype.matchall-4.0.2.tgz"; sha512 = "N/jp6O5fMf9os0JU3E72Qhf590RSRZU/ungsL/qJUYVTNv7hTG0P/dbPjxINVN9jpscu3nzYwKESU3P3RY5tOg=="; }; } @@ -3549,7 +3556,7 @@ name = "string.prototype.trimend___string.prototype.trimend_1.0.1.tgz"; path = fetchurl { name = "string.prototype.trimend___string.prototype.trimend_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz"; sha512 = "LRPxFUaTtpqYsTeNKaFOw3R4bxIzWOnbQ837QfBylo8jIxtcbK/A/sMV7Q+OAV/vWo+7s25pOE10KYSjaSO06g=="; }; } @@ -3557,7 +3564,7 @@ name = "string.prototype.trimleft___string.prototype.trimleft_2.1.2.tgz"; path = fetchurl { name = "string.prototype.trimleft___string.prototype.trimleft_2.1.2.tgz"; - url = "https://registry.yarnpkg.com/string.prototype.trimleft/-/string.prototype.trimleft-2.1.2.tgz"; + url = "https://registry.yarnpkg.com/string.prototype.trimleft/-/string.prototype.trimleft-2.1.2.tgz"; sha512 = "gCA0tza1JBvqr3bfAIFJGqfdRTyPae82+KTnm3coDXkZN9wnuW3HjGgN386D7hfv5CHQYCI022/rJPVlqXyHSw=="; }; } @@ -3565,7 +3572,7 @@ name = "string.prototype.trimright___string.prototype.trimright_2.1.2.tgz"; path = fetchurl { name = "string.prototype.trimright___string.prototype.trimright_2.1.2.tgz"; - url = "https://registry.yarnpkg.com/string.prototype.trimright/-/string.prototype.trimright-2.1.2.tgz"; + url = "https://registry.yarnpkg.com/string.prototype.trimright/-/string.prototype.trimright-2.1.2.tgz"; sha512 = "ZNRQ7sY3KroTaYjRS6EbNiiHrOkjihL9aQE/8gfQ4DtAC/aEBRHFJa44OmoWxGGqXuJlfKkZW4WcXErGr+9ZFg=="; }; } @@ -3573,7 +3580,7 @@ name = "string.prototype.trimstart___string.prototype.trimstart_1.0.1.tgz"; path = fetchurl { name = "string.prototype.trimstart___string.prototype.trimstart_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz"; sha512 = "XxZn+QpvrBI1FOcg6dIpxUPgWCPuNXvMD72aaRaUQv1eD4e/Qy8i/hFTe0BUmD60p/QA6bh1avmuPTfNjqVWRw=="; }; } @@ -3581,7 +3588,7 @@ name = "string_decoder___string_decoder_1.1.1.tgz"; path = fetchurl { name = "string_decoder___string_decoder_1.1.1.tgz"; - url = "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz"; + url = "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz"; sha512 = "n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg=="; }; } @@ -3589,7 +3596,7 @@ name = "stringify_object___stringify_object_3.3.0.tgz"; path = fetchurl { name = "stringify_object___stringify_object_3.3.0.tgz"; - url = "https://registry.yarnpkg.com/stringify-object/-/stringify-object-3.3.0.tgz"; + url = "https://registry.yarnpkg.com/stringify-object/-/stringify-object-3.3.0.tgz"; sha512 = "rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw=="; }; } @@ -3597,7 +3604,7 @@ name = "strip_ansi___strip_ansi_3.0.1.tgz"; path = fetchurl { name = "strip_ansi___strip_ansi_3.0.1.tgz"; - url = "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz"; + url = "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz"; sha1 = "ajhfuIU9lS1f8F0Oiq+UJ43GPc8="; }; } @@ -3605,7 +3612,7 @@ name = "strip_ansi___strip_ansi_4.0.0.tgz"; path = fetchurl { name = "strip_ansi___strip_ansi_4.0.0.tgz"; - url = "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-4.0.0.tgz"; + url = "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-4.0.0.tgz"; sha1 = "qEeQIusaw2iocTibY1JixQXuNo8="; }; } @@ -3613,7 +3620,7 @@ name = "strip_ansi___strip_ansi_5.2.0.tgz"; path = fetchurl { name = "strip_ansi___strip_ansi_5.2.0.tgz"; - url = "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-5.2.0.tgz"; + url = "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-5.2.0.tgz"; sha512 = "DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA=="; }; } @@ -3621,7 +3628,7 @@ name = "strip_bom___strip_bom_3.0.0.tgz"; path = fetchurl { name = "strip_bom___strip_bom_3.0.0.tgz"; - url = "https://registry.yarnpkg.com/strip-bom/-/strip-bom-3.0.0.tgz"; + url = "https://registry.yarnpkg.com/strip-bom/-/strip-bom-3.0.0.tgz"; sha1 = "IzTBjpx1n3vdVv3vfprj1YjmjtM="; }; } @@ -3629,7 +3636,7 @@ name = "strip_eof___strip_eof_1.0.0.tgz"; path = fetchurl { name = "strip_eof___strip_eof_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/strip-eof/-/strip-eof-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/strip-eof/-/strip-eof-1.0.0.tgz"; sha1 = "u0P/VZim6wXYm1n80SnJgzE2Br8="; }; } @@ -3637,7 +3644,7 @@ name = "strip_json_comments___strip_json_comments_2.0.1.tgz"; path = fetchurl { name = "strip_json_comments___strip_json_comments_2.0.1.tgz"; - url = "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz"; + url = "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz"; sha1 = "PFMZQukIwml8DsNEhYwobHygpgo="; }; } @@ -3645,7 +3652,7 @@ name = "supports_color___supports_color_2.0.0.tgz"; path = fetchurl { name = "supports_color___supports_color_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/supports-color/-/supports-color-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/supports-color/-/supports-color-2.0.0.tgz"; sha1 = "U10EXOa2Nj+kARcIRimZXp3zJMc="; }; } @@ -3653,7 +3660,7 @@ name = "supports_color___supports_color_4.5.0.tgz"; path = fetchurl { name = "supports_color___supports_color_4.5.0.tgz"; - url = "https://registry.yarnpkg.com/supports-color/-/supports-color-4.5.0.tgz"; + url = "https://registry.yarnpkg.com/supports-color/-/supports-color-4.5.0.tgz"; sha1 = "vnoN5ITexcXN34s9WRJQRJEvY1s="; }; } @@ -3661,7 +3668,7 @@ name = "supports_color___supports_color_5.5.0.tgz"; path = fetchurl { name = "supports_color___supports_color_5.5.0.tgz"; - url = "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz"; + url = "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz"; sha512 = "QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow=="; }; } @@ -3669,7 +3676,7 @@ name = "symbol_observable___symbol_observable_1.0.1.tgz"; path = fetchurl { name = "symbol_observable___symbol_observable_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/symbol-observable/-/symbol-observable-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/symbol-observable/-/symbol-observable-1.0.1.tgz"; sha1 = "g0D8RwLDEi310iKI+IKD9RPT/dQ="; }; } @@ -3677,7 +3684,7 @@ name = "symbol_observable___symbol_observable_1.2.0.tgz"; path = fetchurl { name = "symbol_observable___symbol_observable_1.2.0.tgz"; - url = "https://registry.yarnpkg.com/symbol-observable/-/symbol-observable-1.2.0.tgz"; + url = "https://registry.yarnpkg.com/symbol-observable/-/symbol-observable-1.2.0.tgz"; sha512 = "e900nM8RRtGhlV36KGEU9k65K3mPb1WV70OdjfxlG2EAuM1noi/E/BaW/uMhL7bPEssK8QV57vN3esixjUvcXQ=="; }; } @@ -3685,7 +3692,7 @@ name = "synchronous_promise___synchronous_promise_2.0.12.tgz"; path = fetchurl { name = "synchronous_promise___synchronous_promise_2.0.12.tgz"; - url = "https://registry.yarnpkg.com/synchronous-promise/-/synchronous-promise-2.0.12.tgz"; + url = "https://registry.yarnpkg.com/synchronous-promise/-/synchronous-promise-2.0.12.tgz"; sha512 = "rIDJiHmIK02tXU+eW1v6a7rNIIiMLm5JUF5Uj2fT6oLSulg7WNDVoqvkYqkFoJzf4v2gmTLppvzegdo9R+7h1Q=="; }; } @@ -3693,7 +3700,7 @@ name = "table___table_4.0.2.tgz"; path = fetchurl { name = "table___table_4.0.2.tgz"; - url = "https://registry.yarnpkg.com/table/-/table-4.0.2.tgz"; + url = "https://registry.yarnpkg.com/table/-/table-4.0.2.tgz"; sha512 = "UUkEAPdSGxtRpiV9ozJ5cMTtYiqz7Ni1OGqLXRCynrvzdtR1p+cfOWe2RJLwvUG8hNanaSRjecIqwOjqeatDsA=="; }; } @@ -3701,7 +3708,7 @@ name = "table___table_5.4.6.tgz"; path = fetchurl { name = "table___table_5.4.6.tgz"; - url = "https://registry.yarnpkg.com/table/-/table-5.4.6.tgz"; + url = "https://registry.yarnpkg.com/table/-/table-5.4.6.tgz"; sha512 = "wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug=="; }; } @@ -3709,7 +3716,7 @@ name = "text_table___text_table_0.2.0.tgz"; path = fetchurl { name = "text_table___text_table_0.2.0.tgz"; - url = "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz"; + url = "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz"; sha1 = "f17oI66AUgfACvLfSoTsP8+lcLQ="; }; } @@ -3717,7 +3724,7 @@ name = "through___through_2.3.8.tgz"; path = fetchurl { name = "through___through_2.3.8.tgz"; - url = "https://registry.yarnpkg.com/through/-/through-2.3.8.tgz"; + url = "https://registry.yarnpkg.com/through/-/through-2.3.8.tgz"; sha1 = "DdTJ/6q8NXlgsbckEV1+Doai4fU="; }; } @@ -3725,7 +3732,7 @@ name = "tmp___tmp_0.0.33.tgz"; path = fetchurl { name = "tmp___tmp_0.0.33.tgz"; - url = "https://registry.yarnpkg.com/tmp/-/tmp-0.0.33.tgz"; + url = "https://registry.yarnpkg.com/tmp/-/tmp-0.0.33.tgz"; sha512 = "jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw=="; }; } @@ -3733,7 +3740,7 @@ name = "to_fast_properties___to_fast_properties_2.0.0.tgz"; path = fetchurl { name = "to_fast_properties___to_fast_properties_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz"; sha1 = "3F5pjL0HkmW8c+A3doGk5Og/YW4="; }; } @@ -3741,7 +3748,7 @@ name = "to_object_path___to_object_path_0.3.0.tgz"; path = fetchurl { name = "to_object_path___to_object_path_0.3.0.tgz"; - url = "https://registry.yarnpkg.com/to-object-path/-/to-object-path-0.3.0.tgz"; + url = "https://registry.yarnpkg.com/to-object-path/-/to-object-path-0.3.0.tgz"; sha1 = "KXWIt7Dn4KwI4E5nL4XB9JmeF68="; }; } @@ -3749,7 +3756,7 @@ name = "to_regex_range___to_regex_range_2.1.1.tgz"; path = fetchurl { name = "to_regex_range___to_regex_range_2.1.1.tgz"; - url = "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-2.1.1.tgz"; + url = "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-2.1.1.tgz"; sha1 = "fIDBe53+vlmeJzZ+DU3VWQFB2zg="; }; } @@ -3757,7 +3764,7 @@ name = "to_regex___to_regex_3.0.2.tgz"; path = fetchurl { name = "to_regex___to_regex_3.0.2.tgz"; - url = "https://registry.yarnpkg.com/to-regex/-/to-regex-3.0.2.tgz"; + url = "https://registry.yarnpkg.com/to-regex/-/to-regex-3.0.2.tgz"; sha512 = "FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw=="; }; } @@ -3765,7 +3772,7 @@ name = "toposort___toposort_2.0.2.tgz"; path = fetchurl { name = "toposort___toposort_2.0.2.tgz"; - url = "https://registry.yarnpkg.com/toposort/-/toposort-2.0.2.tgz"; + url = "https://registry.yarnpkg.com/toposort/-/toposort-2.0.2.tgz"; sha1 = "riF2gXXRVZ1IvvNUILL0li8JwzA="; }; } @@ -3773,7 +3780,7 @@ name = "tslib___tslib_1.13.0.tgz"; path = fetchurl { name = "tslib___tslib_1.13.0.tgz"; - url = "https://registry.yarnpkg.com/tslib/-/tslib-1.13.0.tgz"; + url = "https://registry.yarnpkg.com/tslib/-/tslib-1.13.0.tgz"; sha512 = "i/6DQjL8Xf3be4K/E6Wgpekn5Qasl1usyw++dAA35Ue5orEn65VIxOA+YvNNl9HV3qv70T7CNwjODHZrLwvd1Q=="; }; } @@ -3781,7 +3788,7 @@ name = "type_check___type_check_0.3.2.tgz"; path = fetchurl { name = "type_check___type_check_0.3.2.tgz"; - url = "https://registry.yarnpkg.com/type-check/-/type-check-0.3.2.tgz"; + url = "https://registry.yarnpkg.com/type-check/-/type-check-0.3.2.tgz"; sha1 = "WITKtRLPHTVeP7eE8wgEsrUg23I="; }; } @@ -3789,7 +3796,7 @@ name = "typedarray___typedarray_0.0.6.tgz"; path = fetchurl { name = "typedarray___typedarray_0.0.6.tgz"; - url = "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz"; + url = "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz"; sha1 = "hnrHTjhkGHsdPUfZlqeOxciDB3c="; }; } @@ -3797,7 +3804,7 @@ name = "typescript_eslint_parser___typescript_eslint_parser_16.0.1.tgz"; path = fetchurl { name = "typescript_eslint_parser___typescript_eslint_parser_16.0.1.tgz"; - url = "https://registry.yarnpkg.com/typescript-eslint-parser/-/typescript-eslint-parser-16.0.1.tgz"; + url = "https://registry.yarnpkg.com/typescript-eslint-parser/-/typescript-eslint-parser-16.0.1.tgz"; sha512 = "IKawLTu4A2xN3aN/cPLxvZ0bhxZHILGDKTZWvWNJ3sLNhJ3PjfMEDQmR2VMpdRPrmWOadgWXRwjLBzSA8AGsaQ=="; }; } @@ -3805,7 +3812,7 @@ name = "typescript___typescript_2.9.2.tgz"; path = fetchurl { name = "typescript___typescript_2.9.2.tgz"; - url = "https://registry.yarnpkg.com/typescript/-/typescript-2.9.2.tgz"; + url = "https://registry.yarnpkg.com/typescript/-/typescript-2.9.2.tgz"; sha512 = "Gr4p6nFNaoufRIY4NMdpQRNmgxVIGMs4Fcu/ujdYk3nAZqk7supzBE9idmvfZIlH/Cuj//dvi+019qEue9lV0w=="; }; } @@ -3813,7 +3820,7 @@ name = "union_value___union_value_1.0.1.tgz"; path = fetchurl { name = "union_value___union_value_1.0.1.tgz"; - url = "https://registry.yarnpkg.com/union-value/-/union-value-1.0.1.tgz"; + url = "https://registry.yarnpkg.com/union-value/-/union-value-1.0.1.tgz"; sha512 = "tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg=="; }; } @@ -3821,7 +3828,7 @@ name = "unset_value___unset_value_1.0.0.tgz"; path = fetchurl { name = "unset_value___unset_value_1.0.0.tgz"; - url = "https://registry.yarnpkg.com/unset-value/-/unset-value-1.0.0.tgz"; + url = "https://registry.yarnpkg.com/unset-value/-/unset-value-1.0.0.tgz"; sha1 = "g3aHP30jNRef+x5vw6jtDfyKtVk="; }; } @@ -3829,7 +3836,7 @@ name = "uri_js___uri_js_4.2.2.tgz"; path = fetchurl { name = "uri_js___uri_js_4.2.2.tgz"; - url = "https://registry.yarnpkg.com/uri-js/-/uri-js-4.2.2.tgz"; + url = "https://registry.yarnpkg.com/uri-js/-/uri-js-4.2.2.tgz"; sha512 = "KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ=="; }; } @@ -3837,7 +3844,7 @@ name = "urix___urix_0.1.0.tgz"; path = fetchurl { name = "urix___urix_0.1.0.tgz"; - url = "https://registry.yarnpkg.com/urix/-/urix-0.1.0.tgz"; + url = "https://registry.yarnpkg.com/urix/-/urix-0.1.0.tgz"; sha1 = "2pN/emLiH+wf0Y1Js1wpNQZ6bHI="; }; } @@ -3845,7 +3852,7 @@ name = "use___use_3.1.1.tgz"; path = fetchurl { name = "use___use_3.1.1.tgz"; - url = "https://registry.yarnpkg.com/use/-/use-3.1.1.tgz"; + url = "https://registry.yarnpkg.com/use/-/use-3.1.1.tgz"; sha512 = "cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ=="; }; } @@ -3853,7 +3860,7 @@ name = "util_deprecate___util_deprecate_1.0.2.tgz"; path = fetchurl { name = "util_deprecate___util_deprecate_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz"; sha1 = "RQ1Nyfpw3nMnYvvS1KKJgUGaDM8="; }; } @@ -3861,7 +3868,7 @@ name = "validate_npm_package_license___validate_npm_package_license_3.0.4.tgz"; path = fetchurl { name = "validate_npm_package_license___validate_npm_package_license_3.0.4.tgz"; - url = "https://registry.yarnpkg.com/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz"; + url = "https://registry.yarnpkg.com/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz"; sha512 = "DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew=="; }; } @@ -3869,7 +3876,7 @@ name = "vue_eslint_parser___vue_eslint_parser_2.0.3.tgz"; path = fetchurl { name = "vue_eslint_parser___vue_eslint_parser_2.0.3.tgz"; - url = "https://registry.yarnpkg.com/vue-eslint-parser/-/vue-eslint-parser-2.0.3.tgz"; + url = "https://registry.yarnpkg.com/vue-eslint-parser/-/vue-eslint-parser-2.0.3.tgz"; sha512 = "ZezcU71Owm84xVF6gfurBQUGg8WQ+WZGxgDEQu1IHFBZNx7BFZg3L1yHxrCBNNwbwFtE1GuvfJKMtb6Xuwc/Bw=="; }; } @@ -3877,7 +3884,7 @@ name = "which_module___which_module_2.0.0.tgz"; path = fetchurl { name = "which_module___which_module_2.0.0.tgz"; - url = "https://registry.yarnpkg.com/which-module/-/which-module-2.0.0.tgz"; + url = "https://registry.yarnpkg.com/which-module/-/which-module-2.0.0.tgz"; sha1 = "2e8H3Od7mQK4o6j6SzHD4/fm6Ho="; }; } @@ -3885,7 +3892,7 @@ name = "which___which_1.3.1.tgz"; path = fetchurl { name = "which___which_1.3.1.tgz"; - url = "https://registry.yarnpkg.com/which/-/which-1.3.1.tgz"; + url = "https://registry.yarnpkg.com/which/-/which-1.3.1.tgz"; sha512 = "HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ=="; }; } @@ -3893,7 +3900,7 @@ name = "word_wrap___word_wrap_1.2.3.tgz"; path = fetchurl { name = "word_wrap___word_wrap_1.2.3.tgz"; - url = "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz"; + url = "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz"; sha512 = "Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ=="; }; } @@ -3901,7 +3908,7 @@ name = "wrap_ansi___wrap_ansi_2.1.0.tgz"; path = fetchurl { name = "wrap_ansi___wrap_ansi_2.1.0.tgz"; - url = "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-2.1.0.tgz"; + url = "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-2.1.0.tgz"; sha1 = "2Pw9KE3QV5T+hJc8rs3Rz4JP3YU="; }; } @@ -3909,7 +3916,7 @@ name = "wrap_ansi___wrap_ansi_3.0.1.tgz"; path = fetchurl { name = "wrap_ansi___wrap_ansi_3.0.1.tgz"; - url = "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-3.0.1.tgz"; + url = "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-3.0.1.tgz"; sha1 = "KIoE2H7aXChuBg3+jxNc6NAH+Lo="; }; } @@ -3917,7 +3924,7 @@ name = "wrappy___wrappy_1.0.2.tgz"; path = fetchurl { name = "wrappy___wrappy_1.0.2.tgz"; - url = "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz"; + url = "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz"; sha1 = "tSQ9jz7BqjXxNkYFvA0QNuMKtp8="; }; } @@ -3925,7 +3932,7 @@ name = "write___write_1.0.3.tgz"; path = fetchurl { name = "write___write_1.0.3.tgz"; - url = "https://registry.yarnpkg.com/write/-/write-1.0.3.tgz"; + url = "https://registry.yarnpkg.com/write/-/write-1.0.3.tgz"; sha512 = "/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig=="; }; } @@ -3933,7 +3940,7 @@ name = "write___write_0.2.1.tgz"; path = fetchurl { name = "write___write_0.2.1.tgz"; - url = "https://registry.yarnpkg.com/write/-/write-0.2.1.tgz"; + url = "https://registry.yarnpkg.com/write/-/write-0.2.1.tgz"; sha1 = "X8A4KOJkzqP+kUVUdvejxWbLB1c="; }; } @@ -3941,7 +3948,7 @@ name = "xregexp___xregexp_4.3.0.tgz"; path = fetchurl { name = "xregexp___xregexp_4.3.0.tgz"; - url = "https://registry.yarnpkg.com/xregexp/-/xregexp-4.3.0.tgz"; + url = "https://registry.yarnpkg.com/xregexp/-/xregexp-4.3.0.tgz"; sha512 = "7jXDIFXh5yJ/orPn4SXjuVrWWoi4Cr8jfV1eHv9CixKSbU+jY4mxfrBwAuDvupPNKpMUY+FeIqsVw/JLT9+B8g=="; }; } @@ -3949,7 +3956,7 @@ name = "y18n___y18n_3.2.1.tgz"; path = fetchurl { name = "y18n___y18n_3.2.1.tgz"; - url = "https://registry.yarnpkg.com/y18n/-/y18n-3.2.1.tgz"; + url = "https://registry.yarnpkg.com/y18n/-/y18n-3.2.1.tgz"; sha1 = "bRX7qITAhnnA136I53WegR4H+kE="; }; } @@ -3957,7 +3964,7 @@ name = "yallist___yallist_2.1.2.tgz"; path = fetchurl { name = "yallist___yallist_2.1.2.tgz"; - url = "https://registry.yarnpkg.com/yallist/-/yallist-2.1.2.tgz"; + url = "https://registry.yarnpkg.com/yallist/-/yallist-2.1.2.tgz"; sha1 = "HBH5IY8HYImkfdUS+TxmmaaoHVI="; }; } @@ -3965,7 +3972,7 @@ name = "yallist___yallist_4.0.0.tgz"; path = fetchurl { name = "yallist___yallist_4.0.0.tgz"; - url = "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz"; + url = "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz"; sha512 = "3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A=="; }; } @@ -3973,7 +3980,7 @@ name = "yargs_parser___yargs_parser_8.1.0.tgz"; path = fetchurl { name = "yargs_parser___yargs_parser_8.1.0.tgz"; - url = "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-8.1.0.tgz"; + url = "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-8.1.0.tgz"; sha512 = "yP+6QqN8BmrgW2ggLtTbdrOyBNSI7zBa4IykmiV5R1wl1JWNxQvWhMfMdmzIYtKU7oP3OOInY/tl2ov3BDjnJQ=="; }; } @@ -3981,7 +3988,7 @@ name = "yargs___yargs_10.0.3.tgz"; path = fetchurl { name = "yargs___yargs_10.0.3.tgz"; - url = "https://registry.yarnpkg.com/yargs/-/yargs-10.0.3.tgz"; + url = "https://registry.yarnpkg.com/yargs/-/yargs-10.0.3.tgz"; sha512 = "DqBpQ8NAUX4GyPP/ijDGHsJya4tYqLQrjPr95HNsr1YwL3+daCfvBwg7+gIC6IdJhR2kATh3hb61vjzMWEtjdw=="; }; } @@ -3989,7 +3996,7 @@ name = "yup___yup_0.27.0.tgz"; path = fetchurl { name = "yup___yup_0.27.0.tgz"; - url = "https://registry.yarnpkg.com/yup/-/yup-0.27.0.tgz"; + url = "https://registry.yarnpkg.com/yup/-/yup-0.27.0.tgz"; sha512 = "v1yFnE4+u9za42gG/b/081E7uNW9mUj3qtkmelLbW5YPROZzSH/KUUyJu9Wt8vxFJcT9otL/eZopS0YK1L5yPQ=="; }; } diff --git a/pkgs/development/web/grails/default.nix b/pkgs/development/web/grails/default.nix index d4a324d340d68f..84f6260adc1ece 100644 --- a/pkgs/development/web/grails/default.nix +++ b/pkgs/development/web/grails/default.nix @@ -1,13 +1,27 @@ -{ lib, stdenv, fetchurl, unzip -# If jdk is null, require JAVA_HOME in runtime environment, else store -# JAVA_HOME=${jdk.home} into grails. -, jdk ? null -, coreutils, ncurses, gnused, gnugrep # for purity +{ + lib, + stdenv, + fetchurl, + unzip, + # If jdk is null, require JAVA_HOME in runtime environment, else store + # JAVA_HOME=${jdk.home} into grails. + jdk ? null, + coreutils, + ncurses, + gnused, + gnugrep, # for purity }: let - binpath = lib.makeBinPath - ([ coreutils ncurses gnused gnugrep ] ++ lib.optional (jdk != null) jdk); + binpath = lib.makeBinPath ( + [ + coreutils + ncurses + gnused + gnugrep + ] + ++ lib.optional (jdk != null) jdk + ); in stdenv.mkDerivation rec { pname = "grails"; @@ -22,17 +36,19 @@ stdenv.mkDerivation rec { dontBuild = true; - installPhase = '' - mkdir -p "$out" - cp -vr . "$out" - # Remove (for now) uneeded Windows .bat files - rm -f "$out"/bin/*.bat - # Improve purity - sed -i -e '2iPATH=${binpath}:\$PATH' "$out"/bin/grails - '' + lib.optionalString (jdk != null) '' - # Inject JDK path into grails - sed -i -e '2iJAVA_HOME=${jdk.home}' "$out"/bin/grails - ''; + installPhase = + '' + mkdir -p "$out" + cp -vr . "$out" + # Remove (for now) uneeded Windows .bat files + rm -f "$out"/bin/*.bat + # Improve purity + sed -i -e '2iPATH=${binpath}:\$PATH' "$out"/bin/grails + '' + + lib.optionalString (jdk != null) '' + # Inject JDK path into grails + sed -i -e '2iJAVA_HOME=${jdk.home}' "$out"/bin/grails + ''; preferLocalBuild = true; diff --git a/pkgs/development/web/mailcatcher/default.nix b/pkgs/development/web/mailcatcher/default.nix index a6188fec5dbd5a..b89f39a237cae4 100644 --- a/pkgs/development/web/mailcatcher/default.nix +++ b/pkgs/development/web/mailcatcher/default.nix @@ -1,9 +1,18 @@ -{ ruby_3_2, lib, bundlerApp, bundlerUpdateScript, nixosTests }: +{ + ruby_3_2, + lib, + bundlerApp, + bundlerUpdateScript, + nixosTests, +}: bundlerApp { pname = "mailcatcher"; gemdir = ./.; - exes = [ "mailcatcher" "catchmail" ]; + exes = [ + "mailcatcher" + "catchmail" + ]; ruby = ruby_3_2; passthru.updateScript = bundlerUpdateScript "mailcatcher"; @@ -11,9 +20,12 @@ bundlerApp { meta = with lib; { description = "SMTP server and web interface to locally test outbound emails"; - homepage = "https://mailcatcher.me/"; - license = licenses.mit; - maintainers = with maintainers; [ zarelit nicknovitski ]; - platforms = platforms.unix; + homepage = "https://mailcatcher.me/"; + license = licenses.mit; + maintainers = with maintainers; [ + zarelit + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/development/web/mailcatcher/gemset.nix b/pkgs/development/web/mailcatcher/gemset.nix index 7dd515a3743700..34021359d86500 100644 --- a/pkgs/development/web/mailcatcher/gemset.nix +++ b/pkgs/development/web/mailcatcher/gemset.nix @@ -1,664 +1,833 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "public_suffix" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15s8van7r2ad3dq6i03l3z4hqnvxcq75a3h72kxvf9an53sqma20"; type = "gem"; }; version = "2.8.4"; }; capybara = { - dependencies = ["addressable" "matrix" "mini_mime" "nokogiri" "rack" "rack-test" "regexp_parser" "xpath"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "matrix" + "mini_mime" + "nokogiri" + "rack" + "rack-test" + "regexp_parser" + "xpath" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "114qm5f5vhwaaw9rj1h2lcamh46zl13v1m18jiw68zl961gwmw6n"; type = "gem"; }; version = "3.39.2"; }; capybara-screenshot = { - dependencies = ["capybara" "launchy"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "capybara" + "launchy" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0xqc7hdiw1ql42mklpfvqd2pyfsxmy55cpx0h9y0jlkpl1q96sw1"; type = "gem"; }; version = "1.0.26"; }; chunky_png = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znw5x86hmm9vfhidwdsijz8m38pqgmv98l9ryilvky0aldv7mc9"; type = "gem"; }; version = "1.4.0"; }; coffee-script = { - dependencies = ["coffee-script-source" "execjs"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "coffee-script-source" + "execjs" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0rc7scyk7mnpfxqv5yy4y5q1hx3i7q3ahplcp4bq2g5r24g2izl2"; type = "gem"; }; version = "2.4.1"; }; coffee-script-source = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1907v9q1zcqmmyqzhzych5l7qifgls2rlbnbhy5vzyr7i7yicaz1"; type = "gem"; }; version = "1.12.2"; }; compass = { - dependencies = ["chunky_png" "compass-core" "compass-import-once" "rb-fsevent" "rb-inotify" "sass"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "chunky_png" + "compass-core" + "compass-import-once" + "rb-fsevent" + "rb-inotify" + "sass" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0lfi83w8z75czr0pf0rmj9hda22082h3cmvczl8r1ma9agf88y2c"; type = "gem"; }; version = "1.0.3"; }; compass-core = { - dependencies = ["multi_json" "sass"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "multi_json" + "sass" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0yaspqwdmzwdcqviclbs3blq7an16pysrfzylz8q1gxmmd6bpj3a"; type = "gem"; }; version = "1.0.3"; }; compass-import-once = { - dependencies = ["sass"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "sass" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0bn7gwbfz7jvvdd0qdfqlx67fcb83gyvxqc7dr9fhcnks3z8z5rq"; type = "gem"; }; version = "1.0.5"; }; concurrent-ruby = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0krcwb6mn0iklajwngwsg850nk8k9b35dhmc2qkbdqvmifdi2y9q"; type = "gem"; }; version = "1.2.2"; }; daemons = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07cszb0zl8mqmwhc8a2yfg36vi6lbgrp4pa5bvmryrpcz9v6viwg"; type = "gem"; }; version = "1.4.1"; }; date = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03skfikihpx37rc27vr3hwrb057gxnmdzxhmzd4bf4jpkl0r55w1"; type = "gem"; }; version = "3.3.3"; }; diff-lcs = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rwvjahnp7cpmracd8x732rjgnilqv2sx7d1gfrysslc3h039fa9"; type = "gem"; }; version = "1.5.0"; }; eventmachine = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wh9aqb0skz80fhfn66lbpr4f86ya2z5rx6gm5xlfhd05bj1ch4r"; type = "gem"; }; version = "1.2.7"; }; execjs = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "121h6af4i6wr3wxvv84y53jcyw2sk71j5wsncm6wq6yqrwcrk4vd"; type = "gem"; }; version = "2.8.1"; }; faye-websocket = { - dependencies = ["eventmachine" "websocket-driver"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "eventmachine" + "websocket-driver" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "01xkpv5b4fjc5n6n1fq6z1ris991av2fbadvs8r71i9r34b8g48h"; type = "gem"; }; version = "0.11.3"; }; ffi = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1862ydmclzy1a0cjbvm8dz7847d9rch495ib0zb64y84d3xd4bkg"; type = "gem"; }; version = "1.15.5"; }; launchy = { - dependencies = ["addressable"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "addressable" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "06r43899384das2bkbrpsdxsafyyqa94il7111053idfalb4984a"; type = "gem"; }; version = "2.5.2"; }; mail = { - dependencies = ["mini_mime" "net-imap" "net-pop" "net-smtp"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_mime" + "net-imap" + "net-pop" + "net-smtp" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1bf9pysw1jfgynv692hhaycfxa8ckay1gjw5hz3madrbrynryfzc"; type = "gem"; }; version = "2.8.1"; }; mailcatcher = { - dependencies = ["eventmachine" "faye-websocket" "mail" "net-smtp" "rack" "sinatra" "sqlite3" "thin"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "eventmachine" + "faye-websocket" + "mail" + "net-smtp" + "rack" + "sinatra" + "sqlite3" + "thin" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "003d2a6i97syw67jxrjq0p4xm19p9cfqnbmsg4b1c3mdb5c78rfz"; type = "gem"; }; version = "0.9.0"; }; matrix = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h2cgkpzkh3dd0flnnwfq6f3nl2b1zff9lvqz8xs853ssv5kq23i"; type = "gem"; }; version = "0.4.2"; }; mini_mime = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lbim375gw2dk6383qirz13hgdmxlan0vc5da2l072j3qw6fqjm5"; type = "gem"; }; version = "1.1.2"; }; mini_portile2 = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02mj8mpd6ck5gpcnsimx5brzggw5h5mmmpq2djdypfq16wcw82qq"; type = "gem"; }; version = "2.8.4"; }; multi_json = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; net-imap = { - dependencies = ["date" "net-protocol"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "date" + "net-protocol" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0lf7wqg7czhaj51qsnmn28j7jmcxhkh3m28rl1cjrqsgjxhwj7r3"; type = "gem"; }; version = "0.3.7"; }; net-pop = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wyz41jd4zpjn0v1xsf9j778qx1vfrl24yc20cpmph8k42c4x2w4"; type = "gem"; }; version = "0.1.2"; }; net-protocol = { - dependencies = ["timeout"]; - groups = ["default"]; - platforms = []; + dependencies = [ "timeout" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dxckrlw4q1lcn3qg4mimmjazmg9bma5gllv72f8js3p36fb3b91"; type = "gem"; }; version = "0.2.1"; }; net-smtp = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c6md06hm5bf6rv53sk54dl2vg038pg8kglwv3rayx0vk2mdql9x"; type = "gem"; }; version = "0.3.3"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1l8b0i24h4irivyhwy9xmkjbggw86cxkzkiqdqg0jpcp9qc8h4rl"; type = "gem"; }; version = "1.16.0"; }; psych = { - dependencies = ["stringio"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "stringio" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1msambb54r3d1sg6smyj4k2pj9h9lz8jq4jamip7ivcyv32a85vz"; type = "gem"; }; version = "5.1.0"; }; public_suffix = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0n9j7mczl15r3kwqrah09cxj8hxdfawiqxa60kga2bmxl9flfz9k"; type = "gem"; }; version = "5.0.3"; }; racc = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11v3l46mwnlzlc371wr3x6yylpgafgwdf0q7hc7c1lzx6r414r5g"; type = "gem"; }; version = "1.7.1"; }; rack = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wr1f3g9rc9i8svfxa9cijajl1661d817s56b2w7rd572zwn0zi0"; type = "gem"; }; version = "1.6.13"; }; rack-protection = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0my0wlw4a5l3hs79jkx2xzv7djhajgf8d28k8ai1ddlnxxb0v7ss"; type = "gem"; }; version = "1.5.5"; }; rack-test = { - dependencies = ["rack"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rack" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ysx29gk9k14a14zsp5a8czys140wacvp91fja8xcja0j1hzqq8c"; type = "gem"; }; version = "2.1.0"; }; rake = { - groups = ["development"]; - platforms = []; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15whn7p9nrkxangbs9hh75q585yfn66lv0v2mhj6q6dl6x8bzr2w"; type = "gem"; }; version = "13.0.6"; }; rb-fsevent = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zmf31rnpm8553lqwibvv3kkx0v7majm1f341xbxc0bk5sbhp423"; type = "gem"; }; version = "0.11.2"; }; rb-inotify = { - dependencies = ["ffi"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "ffi" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1jm76h8f8hji38z3ggf4bzi8vps6p7sagxn3ab57qc0xyga64005"; type = "gem"; }; version = "0.10.1"; }; rdoc = { - dependencies = ["psych"]; - groups = ["development"]; - platforms = []; + dependencies = [ "psych" ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05r2cxscapr9saqjw8dlp89as7jvc2mlz1h5kssrmkbz105qmfcm"; type = "gem"; }; version = "6.5.0"; }; regexp_parser = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "136br91alxdwh1s85z912dwz23qlhm212vy6i3wkinz3z8mkxxl3"; type = "gem"; }; version = "2.8.1"; }; rexml = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05i8518ay14kjbma550mv0jm8a6di8yp5phzrd8rj44z9qnrlrp0"; type = "gem"; }; version = "3.2.6"; }; rspec = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "171rc90vcgjl8p1bdrqa92ymrj8a87qf6w20x05xq29mljcigi6c"; type = "gem"; }; version = "3.12.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rspec-support" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0l95bnjxdabrn79hwdhn2q1n7mn26pj7y1w5660v5qi81x458nqm"; type = "gem"; }; version = "3.12.2"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05j44jfqlv7j2rpxb5vqzf9hfv7w8ba46wwgxwcwd8p0wzi1hg89"; type = "gem"; }; version = "3.12.3"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1gq7gviwpck7fhp4y5ibljljvxgjklza18j62qf6zkm2icaa8lfy"; type = "gem"; }; version = "3.12.6"; }; rspec-support = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ky86j3ksi26ng9ybd7j0qsdf1lpr8mzrmn98yy9gzv801fvhsgr"; type = "gem"; }; version = "3.12.1"; }; rubyzip = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; sass = { - groups = ["development"]; - platforms = []; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kfpcwh8dgw4lc81qglkvjl73689jy3g7196zkxm4fpskg1p5lkw"; type = "gem"; }; version = "3.4.25"; }; selenium-webdriver = { - dependencies = ["rexml" "rubyzip" "websocket"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rexml" + "rubyzip" + "websocket" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kxnv3ywssagv2q453hasrrrvsv68d5f3ccm33pyacdji88w8pqg"; type = "gem"; }; version = "4.9.0"; }; sinatra = { - dependencies = ["rack" "rack-protection" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rack" + "rack-protection" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0byxzl7rx3ki0xd7aiv1x8mbah7hzd8f81l65nq8857kmgzj1jqq"; type = "gem"; }; version = "1.4.8"; }; sprockets = { - dependencies = ["concurrent-ruby" "rack"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "rack" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "182jw5a0fbqah5w9jancvfmjbk88h8bxdbwnl4d3q809rpxdg8ay"; type = "gem"; }; version = "3.7.2"; }; sprockets-helpers = { - dependencies = ["sprockets"]; - groups = ["development"]; - platforms = []; + dependencies = [ "sprockets" ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0513ma356g05lsskhsb363263177h6ccmp475il0p69y18his2ij"; type = "gem"; }; version = "1.4.0"; }; sprockets-sass = { - dependencies = ["sprockets"]; - groups = ["development"]; - platforms = []; + dependencies = [ "sprockets" ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02g153dhzmrlik5dd9kyq0rvr2xjm3fwx8rm7apqfrykc47aizqr"; type = "gem"; }; version = "2.0.0.beta2"; }; sqlite3 = { - dependencies = ["mini_portile2"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mini_portile2" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h95kr5529qv786mfk8r2jjdsdi6v7v3k3dpz69mrcc9i0vpdd37"; type = "gem"; }; version = "1.6.3"; }; stringio = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0557v4z7996cgqw7i9197848mymv02krads93dn9lyqa5d7xd0dn"; type = "gem"; }; version = "3.0.7"; }; thin = { - dependencies = ["daemons" "eventmachine" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "daemons" + "eventmachine" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08g1yq6zzvgndj8fd98ah7pp8g2diw28p8bfjgv7rvjvp8d2am8w"; type = "gem"; }; version = "1.8.2"; }; tilt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bmjgbv8158klwp2r3klxjwaj93nh1sbl4xvj9wsha0ic478avz7"; type = "gem"; }; version = "2.2.0"; }; timeout = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d9cvm0f4zdpwa795v3zv4973y5zk59j7s1x3yn90jjrhcz1yvfd"; type = "gem"; }; version = "0.4.0"; }; uglifier = { - dependencies = ["execjs"]; - groups = ["development"]; - platforms = []; + dependencies = [ "execjs" ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wgh7bzy68vhv9v68061519dd8samcy8sazzz0w3k8kqpy3g4s5f"; type = "gem"; }; version = "4.2.0"; }; websocket = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dib6p55sl606qb4vpwrvj5wh881kk4aqn2zpfapf8ckx7g14jw8"; type = "gem"; }; version = "1.2.9"; }; websocket-driver = { - dependencies = ["websocket-extensions"]; - groups = ["default"]; - platforms = []; + dependencies = [ "websocket-extensions" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nyh873w4lvahcl8kzbjfca26656d5c6z3md4sbqg5y1gfz0157n"; type = "gem"; }; version = "0.7.6"; }; websocket-extensions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hc2g9qps8lmhibl5baa91b4qx8wqw872rgwagml78ydj8qacsqw"; type = "gem"; }; version = "0.1.5"; }; xpath = { - dependencies = ["nokogiri"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "nokogiri" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0bh8lk9hvlpn7vmi6h4hkcwjzvs2y0cmkk3yjjdr8fxvj6fsgzbd"; type = "gem"; }; diff --git a/pkgs/development/web/netlify-cli/test.nix b/pkgs/development/web/netlify-cli/test.nix index 5acd4f1046d56f..5c2608fb094c19 100644 --- a/pkgs/development/web/netlify-cli/test.nix +++ b/pkgs/development/web/netlify-cli/test.nix @@ -7,36 +7,40 @@ stdenv, }: -runCommand "netlify-cli-test" { - nativeBuildInputs = [ - netlify-cli - curl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.ps - ]; - meta.timeout = 600; -} '' - mkdir home - export HOME=$PWD/home +runCommand "netlify-cli-test" + { + nativeBuildInputs = + [ + netlify-cli + curl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.ps + ]; + meta.timeout = 600; + } + '' + mkdir home + export HOME=$PWD/home - # Create a simple site - echo '

hi

' >index.html - echo '/with-redirect /' >_redirects + # Create a simple site + echo '

hi

' >index.html + echo '/with-redirect /' >_redirects - # Start a local server and wait for it to respond - netlify dev --offline --port 8888 2>&1 | tee log & - sleep 0.1 || true - for (( i=0; i<300; i++ )); do - if grep --ignore-case 'Server now ready' &1 | tee log & + sleep 0.1 || true + for (( i=0; i<300; i++ )); do + if grep --ignore-case 'Server now ready' hi' + # Test the local server + curl -L http://localhost:8888/with-redirect | grep '

hi

' - # Success - touch $out -'' + # Success + touch $out + '' diff --git a/pkgs/development/web/nodejs/corepack.nix b/pkgs/development/web/nodejs/corepack.nix index c83d3f1645fccd..d96f3bad0e2150 100644 --- a/pkgs/development/web/nodejs/corepack.nix +++ b/pkgs/development/web/nodejs/corepack.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, nodejs }: +{ + lib, + stdenv, + nodejs, +}: stdenv.mkDerivation { pname = "corepack-nodejs"; diff --git a/pkgs/development/web/nodejs/update.nix b/pkgs/development/web/nodejs/update.nix index ebe6a74c269670..ae3914dac33b17 100644 --- a/pkgs/development/web/nodejs/update.nix +++ b/pkgs/development/web/nodejs/update.nix @@ -1,19 +1,30 @@ -{ lib -, writeScript -, coreutils -, curl -, gnugrep -, jq -, gnupg -, common-updater-scripts -, majorVersion -, nix -, runtimeShell +{ + lib, + writeScript, + coreutils, + curl, + gnugrep, + jq, + gnupg, + common-updater-scripts, + majorVersion, + nix, + runtimeShell, }: writeScript "update-nodejs" '' #!${runtimeShell} - PATH=${lib.makeBinPath [ common-updater-scripts coreutils curl gnugrep jq gnupg nix ]} + PATH=${ + lib.makeBinPath [ + common-updater-scripts + coreutils + curl + gnugrep + jq + gnupg + nix + ] + } HOME=`mktemp -d` cat ${./nodejs-release-keys.asc} | gpg --import diff --git a/pkgs/development/web/nodejs/v18.nix b/pkgs/development/web/nodejs/v18.nix index 6099d100675aab..f470f32aac7e43 100644 --- a/pkgs/development/web/nodejs/v18.nix +++ b/pkgs/development/web/nodejs/v18.nix @@ -1,19 +1,35 @@ -{ callPackage, lib, overrideCC, pkgs, buildPackages, openssl, python311, fetchpatch2, enableNpm ? true }: +{ + callPackage, + lib, + overrideCC, + pkgs, + buildPackages, + openssl, + python311, + fetchpatch2, + enableNpm ? true, +}: let # Clang 16+ cannot build Node v18 due to -Wenum-constexpr-conversion errors. # Use an older version of clang with the current libc++ for compatibility (e.g., with icu). - ensureCompatibleCC = packages: - if packages.stdenv.cc.isClang && lib.versionAtLeast (lib.getVersion packages.stdenv.cc.cc) "16" - then overrideCC packages.llvmPackages_15.stdenv (packages.llvmPackages_15.stdenv.cc.override { - inherit (packages.llvmPackages) libcxx; - }) - else packages.stdenv; + ensureCompatibleCC = + packages: + if packages.stdenv.cc.isClang && lib.versionAtLeast (lib.getVersion packages.stdenv.cc.cc) "16" then + overrideCC packages.llvmPackages_15.stdenv ( + packages.llvmPackages_15.stdenv.cc.override { + inherit (packages.llvmPackages) libcxx; + } + ) + else + packages.stdenv; buildNodejs = callPackage ./nodejs.nix { inherit openssl; stdenv = ensureCompatibleCC pkgs; - buildPackages = buildPackages // { stdenv = ensureCompatibleCC buildPackages; }; + buildPackages = buildPackages // { + stdenv = ensureCompatibleCC buildPackages; + }; python = python311; }; @@ -41,7 +57,7 @@ buildNodejs { (fetchpatch2 { url = "https://github.com/nodejs/node/commit/87598d4b63ef2c827a2bebdfa0f1540c35718519.patch"; hash = "sha256-JJi8z9aaWnu/y3nZGOSUfeNzNSCYzD9dzoHXaGkeaEA="; - includes = ["test/common/assertSnapshot.js"]; + includes = [ "test/common/assertSnapshot.js" ]; }) (fetchpatch2 { url = "https://github.com/nodejs/node/commit/d0a6b605fba6cd69a82e6f12ff0363eef8fe1ee9.patch"; diff --git a/pkgs/development/web/nodejs/v20.nix b/pkgs/development/web/nodejs/v20.nix index 7a8865afae94dc..6fa35c0ac44751 100644 --- a/pkgs/development/web/nodejs/v20.nix +++ b/pkgs/development/web/nodejs/v20.nix @@ -1,4 +1,10 @@ -{ callPackage, fetchpatch2, openssl, python3, enableNpm ? true }: +{ + callPackage, + fetchpatch2, + openssl, + python3, + enableNpm ? true, +}: let buildNodejs = callPackage ./nodejs.nix { diff --git a/pkgs/development/web/pnpm-lock-export/default.nix b/pkgs/development/web/pnpm-lock-export/default.nix index 093a1da2d0d455..2a019d5920f656 100644 --- a/pkgs/development/web/pnpm-lock-export/default.nix +++ b/pkgs/development/web/pnpm-lock-export/default.nix @@ -1,4 +1,8 @@ -{ lib, buildNpmPackage, fetchFromGitHub }: +{ + lib, + buildNpmPackage, + fetchFromGitHub, +}: buildNpmPackage rec { pname = "pnpm-lock-export"; version = "unstable-2023-07-31"; diff --git a/pkgs/games/0ad/data.nix b/pkgs/games/0ad/data.nix index 92ebf574864689..9165b107be4dd9 100644 --- a/pkgs/games/0ad/data.nix +++ b/pkgs/games/0ad/data.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, zeroad-unwrapped }: +{ + lib, + stdenv, + fetchurl, + zeroad-unwrapped, +}: stdenv.mkDerivation rec { pname = "0ad-data"; @@ -21,6 +26,6 @@ stdenv.mkDerivation rec { license = licenses.cc-by-sa-30; maintainers = with maintainers; [ chvp ]; platforms = platforms.linux; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/games/0ad/default.nix b/pkgs/games/0ad/default.nix index a97d9f4cda3a49..963b3c47121704 100644 --- a/pkgs/games/0ad/default.nix +++ b/pkgs/games/0ad/default.nix @@ -1,4 +1,9 @@ -{ fmt, wxGTK, stdenv, newScope }: +{ + fmt, + wxGTK, + stdenv, + newScope, +}: let callPackage = newScope self; diff --git a/pkgs/games/0ad/game.nix b/pkgs/games/0ad/game.nix index 676c14fd1fc91b..7f41d04321a8d4 100644 --- a/pkgs/games/0ad/game.nix +++ b/pkgs/games/0ad/game.nix @@ -1,9 +1,40 @@ -{ stdenv, lib, fetchpatch, fetchpatch2, perl, fetchurl, python3, fmt, libidn -, pkg-config, spidermonkey_78, boost, icu, libxml2, libpng, libsodium -, libjpeg, zlib, curl, libogg, libvorbis, enet, miniupnpc -, openal, libGLU, libGL, xorgproto, libX11, libXcursor, nspr, SDL2 -, gloox, nvidia-texture-tools, freetype -, withEditor ? true, wxGTK +{ + stdenv, + lib, + fetchpatch, + fetchpatch2, + perl, + fetchurl, + python3, + fmt, + libidn, + pkg-config, + spidermonkey_78, + boost, + icu, + libxml2, + libpng, + libsodium, + libjpeg, + zlib, + curl, + libogg, + libvorbis, + enet, + miniupnpc, + openal, + libGLU, + libGL, + xorgproto, + libX11, + libXcursor, + nspr, + SDL2, + gloox, + nvidia-texture-tools, + freetype, + withEditor ? true, + wxGTK, }: # You can find more instructions on how to build 0ad here: @@ -13,13 +44,13 @@ let # the game requires a special version 78.6.0 of spidermonkey, otherwise # we get compilation errors. We override the src attribute of spidermonkey_78 # in order to reuse that declartion, while giving it a different source input. - spidermonkey_78_6 = spidermonkey_78.overrideAttrs(old: rec { + spidermonkey_78_6 = spidermonkey_78.overrideAttrs (old: rec { version = "78.6.0"; src = fetchurl { url = "mirror://mozilla/firefox/releases/${version}esr/source/firefox-${version}esr.source.tar.xz"; sha256 = "0lyg65v380j8i2lrylwz8a5ya80822l8vcnlx3dfqpd3s6zzjsay"; }; - patches = (old.patches or []) ++ [ + patches = (old.patches or [ ]) ++ [ ./spidermonkey-cargo-toml.patch ]; }); @@ -33,13 +64,39 @@ stdenv.mkDerivation rec { sha256 = "Lhxt9+MxLnfF+CeIZkz/w6eNO/YGBsAAOSdeHRPA7ks="; }; - nativeBuildInputs = [ python3 perl pkg-config ]; + nativeBuildInputs = [ + python3 + perl + pkg-config + ]; buildInputs = [ - spidermonkey_78_6 boost icu libxml2 libpng libjpeg - zlib curl libogg libvorbis enet miniupnpc openal libidn - libGLU libGL xorgproto libX11 libXcursor nspr SDL2 gloox - nvidia-texture-tools libsodium fmt freetype + spidermonkey_78_6 + boost + icu + libxml2 + libpng + libjpeg + zlib + curl + libogg + libvorbis + enet + miniupnpc + openal + libidn + libGLU + libGL + xorgproto + libX11 + libXcursor + nspr + SDL2 + gloox + nvidia-texture-tools + libsodium + fmt + freetype ] ++ lib.optional withEditor wxGTK; env.NIX_CFLAGS_COMPILE = toString [ @@ -126,7 +183,10 @@ stdenv.mkDerivation rec { description = "Free, open-source game of ancient warfare"; homepage = "https://play0ad.com/"; license = with licenses; [ - gpl2Plus lgpl21 mit cc-by-sa-30 + gpl2Plus + lgpl21 + mit + cc-by-sa-30 licenses.zlib # otherwise masked by pkgs.zlib ]; maintainers = with maintainers; [ chvp ]; diff --git a/pkgs/games/0ad/wrapper.nix b/pkgs/games/0ad/wrapper.nix index 3511dc0bed4987..b07405b7ec7237 100644 --- a/pkgs/games/0ad/wrapper.nix +++ b/pkgs/games/0ad/wrapper.nix @@ -1,4 +1,9 @@ -{ buildEnv, makeWrapper, zeroad-unwrapped, zeroad-data }: +{ + buildEnv, + makeWrapper, + zeroad-unwrapped, + zeroad-data, +}: assert zeroad-unwrapped.version == zeroad-data.version; @@ -7,9 +12,15 @@ buildEnv { nativeBuildInputs = [ makeWrapper ]; - paths = [ zeroad-unwrapped zeroad-data ]; + paths = [ + zeroad-unwrapped + zeroad-data + ]; - pathsToLink = [ "/" "/bin" ]; + pathsToLink = [ + "/" + "/bin" + ]; postBuild = '' for i in $out/bin/*; do @@ -19,6 +30,6 @@ buildEnv { ''; meta = zeroad-unwrapped.meta // { - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/games/2048-cli/default.nix b/pkgs/games/2048-cli/default.nix index 450982df7446ca..c3c1da7c93e72a 100644 --- a/pkgs/games/2048-cli/default.nix +++ b/pkgs/games/2048-cli/default.nix @@ -1,13 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, gettext -, installShellFiles -, ncurses -, ui ? "terminal" +{ + lib, + stdenv, + fetchFromGitHub, + gettext, + installShellFiles, + ncurses, + ui ? "terminal", }: -assert lib.elem ui [ "terminal" "curses" ]; +assert lib.elem ui [ + "terminal" + "curses" +]; stdenv.mkDerivation (finalAttrs: { pname = "2048-cli"; version = "unstable-2019-12-10"; @@ -30,8 +34,7 @@ stdenv.mkDerivation (finalAttrs: { buildInputs = [ gettext - ] - ++ (lib.optional (ui == "curses") ncurses); + ] ++ (lib.optional (ui == "curses") ncurses); dontConfigure = true; diff --git a/pkgs/games/90secondportraits/default.nix b/pkgs/games/90secondportraits/default.nix index c8db41d791d6f1..3d0f95f304a8b1 100644 --- a/pkgs/games/90secondportraits/default.nix +++ b/pkgs/games/90secondportraits/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, love, makeWrapper, makeDesktopItem, copyDesktopItems }: +{ + lib, + stdenv, + fetchurl, + love, + makeWrapper, + makeDesktopItem, + copyDesktopItems, +}: let pname = "90secondportraits"; @@ -20,7 +28,8 @@ let }) ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { inherit pname desktopItems; version = "1.01b"; @@ -29,7 +38,10 @@ in stdenv.mkDerivation rec { sha256 = "0jj3k953r6vb02212gqcgqpb4ima87gnqgls43jmylxq2mcm33h5"; }; - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; dontUnpack = true; @@ -46,7 +58,13 @@ in stdenv.mkDerivation rec { mainProgram = "90secondportraits"; maintainers = with maintainers; [ leenaars ]; platforms = platforms.linux; - license = with licenses; [ zlib cc-by-sa-40 cc-by-sa-30 /* vendored */ x11 mit ]; + license = with licenses; [ + zlib + cc-by-sa-40 + cc-by-sa-30 # vendored + x11 + mit + ]; downloadPage = "http://tangramgames.dk/games/90secondportraits"; }; diff --git a/pkgs/games/amoeba/data.nix b/pkgs/games/amoeba/data.nix index 193c710b31a101..fcffe73b1d628e 100644 --- a/pkgs/games/amoeba/data.nix +++ b/pkgs/games/amoeba/data.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "amoeba-data"; diff --git a/pkgs/games/amoeba/default.nix b/pkgs/games/amoeba/default.nix index 63fa8a62365bfa..274e91ba33dcbf 100644 --- a/pkgs/games/amoeba/default.nix +++ b/pkgs/games/amoeba/default.nix @@ -1,4 +1,18 @@ -{ lib, stdenv, fetchurl, amoeba-data, alsa-lib, expat, freetype, gtk3, libvorbis, libGLU, xorg, pkg-config, installShellFiles }: +{ + lib, + stdenv, + fetchurl, + amoeba-data, + alsa-lib, + expat, + freetype, + gtk3, + libvorbis, + libGLU, + xorg, + pkg-config, + installShellFiles, +}: stdenv.mkDerivation rec { pname = "amoeba"; @@ -26,8 +40,19 @@ stdenv.mkDerivation rec { sed -i main/linux-config/linux-config.cpp -e 's|libgtk-x11-2.0.so.0|${gtk3}/lib/&|' ''; - nativeBuildInputs = [ pkg-config installShellFiles ]; - buildInputs = [ alsa-lib expat freetype gtk3 libvorbis libGLU xorg.libXxf86vm ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; + buildInputs = [ + alsa-lib + expat + freetype + gtk3 + libvorbis + libGLU + xorg.libXxf86vm + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/games/armagetronad/default.nix b/pkgs/games/armagetronad/default.nix index 1db364ce6fc824..5bab46e5b7c34e 100644 --- a/pkgs/games/armagetronad/default.nix +++ b/pkgs/games/armagetronad/default.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchFromGitLab -, autoconf -, automake -, gnum4 -, pkg-config -, bison -, python3 -, which -, boost -, ftgl -, freetype -, glew -, SDL -, SDL_image -, SDL_mixer -, SDL2 -, SDL2_image -, SDL2_mixer -, libpng -, libxml2 -, protobuf -, xvfb-run -, gnugrep -, nixosTests -, dedicatedServer ? false +{ + lib, + stdenv, + fetchFromGitLab, + autoconf, + automake, + gnum4, + pkg-config, + bison, + python3, + which, + boost, + ftgl, + freetype, + glew, + SDL, + SDL_image, + SDL_mixer, + SDL2, + SDL2_image, + SDL2_mixer, + libpng, + libxml2, + protobuf, + xvfb-run, + gnugrep, + nixosTests, + dedicatedServer ? false, }: let @@ -32,74 +33,102 @@ let unstableVersionMajor = "0.4"; srcs = - let - fetchArmagetron = rev: hash: - fetchFromGitLab { - owner = "armagetronad"; - repo = "armagetronad"; - inherit rev hash; - }; - in - { - # https://gitlab.com/armagetronad/armagetronad/-/tags - ${latestVersionMajor} = - let - version = "${latestVersionMajor}.2.3"; - rev = "v${version}"; - hash = "sha256-lfYJ3luGK9hB0aiiBiJIqq5ddANqGaVtKXckbo4fl2g="; - in dedicatedServer: { - inherit version; - src = fetchArmagetron rev hash; - extraBuildInputs = lib.optionals (!dedicatedServer) [ libpng SDL SDL_image SDL_mixer ]; - }; - - # https://gitlab.com/armagetronad/armagetronad/-/commits/trunk/?ref_type=heads - ${unstableVersionMajor} = - let - rev = "391a74625c1222dd180f069f1b61c3e069a3ba8c"; - hash = "sha256-fUY0dBj85k0QhnAoDzyBmmKmRh9oCYC6r6X4ukt7/L0="; - in dedicatedServer: { - version = "${unstableVersionMajor}-${builtins.substring 0 8 rev}"; - src = fetchArmagetron rev hash; - extraBuildInputs = [ protobuf boost ] - ++ lib.optionals (!dedicatedServer) [ glew ftgl freetype SDL2 SDL2_image SDL2_mixer ]; - extraNativeBuildInputs = [ bison ]; - }; - - # https://gitlab.com/armagetronad/armagetronad/-/commits/hack-0.2.8-sty+ct+ap/?ref_type=heads - "${latestVersionMajor}-sty+ct+ap" = - let - rev = "5a17cc9fb6e1e27a358711afbd745ae54d4a8c60"; - hash = "sha256-111C1j/hSaASGcvYy3//TyHs4Z+3fuiOvCmtcWLdFd4="; - in dedicatedServer: { - version = "${latestVersionMajor}-sty+ct+ap-${builtins.substring 0 8 rev}"; - src = fetchArmagetron rev hash; - extraBuildInputs = lib.optionals (!dedicatedServer) [ libpng SDL SDL_image SDL_mixer ]; - }; - }; + let + fetchArmagetron = + rev: hash: + fetchFromGitLab { + owner = "armagetronad"; + repo = "armagetronad"; + inherit rev hash; + }; + in + { + # https://gitlab.com/armagetronad/armagetronad/-/tags + ${latestVersionMajor} = + let + version = "${latestVersionMajor}.2.3"; + rev = "v${version}"; + hash = "sha256-lfYJ3luGK9hB0aiiBiJIqq5ddANqGaVtKXckbo4fl2g="; + in + dedicatedServer: { + inherit version; + src = fetchArmagetron rev hash; + extraBuildInputs = lib.optionals (!dedicatedServer) [ + libpng + SDL + SDL_image + SDL_mixer + ]; + }; + + # https://gitlab.com/armagetronad/armagetronad/-/commits/trunk/?ref_type=heads + ${unstableVersionMajor} = + let + rev = "391a74625c1222dd180f069f1b61c3e069a3ba8c"; + hash = "sha256-fUY0dBj85k0QhnAoDzyBmmKmRh9oCYC6r6X4ukt7/L0="; + in + dedicatedServer: { + version = "${unstableVersionMajor}-${builtins.substring 0 8 rev}"; + src = fetchArmagetron rev hash; + extraBuildInputs = + [ + protobuf + boost + ] + ++ lib.optionals (!dedicatedServer) [ + glew + ftgl + freetype + SDL2 + SDL2_image + SDL2_mixer + ]; + extraNativeBuildInputs = [ bison ]; + }; + + # https://gitlab.com/armagetronad/armagetronad/-/commits/hack-0.2.8-sty+ct+ap/?ref_type=heads + "${latestVersionMajor}-sty+ct+ap" = + let + rev = "5a17cc9fb6e1e27a358711afbd745ae54d4a8c60"; + hash = "sha256-111C1j/hSaASGcvYy3//TyHs4Z+3fuiOvCmtcWLdFd4="; + in + dedicatedServer: { + version = "${latestVersionMajor}-sty+ct+ap-${builtins.substring 0 8 rev}"; + src = fetchArmagetron rev hash; + extraBuildInputs = lib.optionals (!dedicatedServer) [ + libpng + SDL + SDL_image + SDL_mixer + ]; + }; + }; # Creates an Armagetron build. Takes a function returning build inputs for a particular value of dedicatedServer. - mkArmagetron = fn: dedicatedServer: - let - # Compute the build params. - resolvedParams = fn dedicatedServer; - - # Figure out the binary name depending on whether this is a dedicated server. - mainProgram = if dedicatedServer then "armagetronad-dedicated" else "armagetronad"; - - # Split the version into the major and minor parts - versionParts = lib.splitString "-" resolvedParams.version; - splitVersion = lib.splitVersion (builtins.elemAt versionParts 0); - majorVersion = builtins.concatStringsSep "." (lib.lists.take 2 splitVersion); - - minorVersionPart = parts: sep: expectedSize: - if builtins.length parts > expectedSize then - sep + (builtins.concatStringsSep sep (lib.lists.drop expectedSize parts)) - else - ""; - - minorVersion = (minorVersionPart splitVersion "." 2) + (minorVersionPart versionParts "-" 1) + "-nixpkgs"; - in + mkArmagetron = + fn: dedicatedServer: + let + # Compute the build params. + resolvedParams = fn dedicatedServer; + + # Figure out the binary name depending on whether this is a dedicated server. + mainProgram = if dedicatedServer then "armagetronad-dedicated" else "armagetronad"; + + # Split the version into the major and minor parts + versionParts = lib.splitString "-" resolvedParams.version; + splitVersion = lib.splitVersion (builtins.elemAt versionParts 0); + majorVersion = builtins.concatStringsSep "." (lib.lists.take 2 splitVersion); + + minorVersionPart = + parts: sep: expectedSize: + if builtins.length parts > expectedSize then + sep + (builtins.concatStringsSep sep (lib.lists.drop expectedSize parts)) + else + ""; + + minorVersion = + (minorVersionPart splitVersion "." 2) + (minorVersionPart versionParts "-" 1) + "-nixpkgs"; + in stdenv.mkDerivation { pname = mainProgram; inherit (resolvedParams) version src; @@ -119,27 +148,36 @@ let ./bootstrap.sh ''; - configureFlags = [ - "--enable-automakedefaults" - "--enable-authentication" - "--disable-memmanager" - "--disable-useradd" - "--disable-initscripts" - "--disable-etc" - "--disable-uninstall" - "--disable-sysinstall" - ] ++ lib.optional dedicatedServer "--enable-dedicated" + configureFlags = + [ + "--enable-automakedefaults" + "--enable-authentication" + "--disable-memmanager" + "--disable-useradd" + "--disable-initscripts" + "--disable-etc" + "--disable-uninstall" + "--disable-sysinstall" + ] + ++ lib.optional dedicatedServer "--enable-dedicated" ++ lib.optional (!dedicatedServer) "--enable-music"; - buildInputs = lib.singleton (libxml2.override { enableHttp = true; }) - ++ (resolvedParams.extraBuildInputs or []); + buildInputs = + lib.singleton (libxml2.override { enableHttp = true; }) ++ (resolvedParams.extraBuildInputs or [ ]); - nativeBuildInputs = [ autoconf automake gnum4 pkg-config which python3 ] - ++ (resolvedParams.extraNativeBuildInputs or []); + nativeBuildInputs = [ + autoconf + automake + gnum4 + pkg-config + which + python3 + ] ++ (resolvedParams.extraNativeBuildInputs or [ ]); - nativeInstallCheckInputs = [ gnugrep ] + nativeInstallCheckInputs = + [ gnugrep ] ++ lib.optional (!dedicatedServer) xvfb-run - ++ (resolvedParams.extraNativeInstallCheckInputs or []); + ++ (resolvedParams.extraNativeInstallCheckInputs or [ ]); postInstall = lib.optionalString (!dedicatedServer) '' mkdir -p $out/share/{applications,icons/hicolor} @@ -176,20 +214,23 @@ let ''; passthru = - if (dedicatedServer) then { - # No passthru, end of the line. - # https://www.youtube.com/watch?v=NOMa56y_Was - } - else if (resolvedParams.version != (srcs.${latestVersionMajor} dedicatedServer).version) then { - # Allow a "dedicated" passthru for versions other than the default. - dedicated = mkArmagetron fn true; - } - else - ( - lib.mapAttrs (name: value: mkArmagetron value dedicatedServer) - (lib.filterAttrs (name: value: (value dedicatedServer).version != (srcs.${latestVersionMajor} dedicatedServer).version) srcs) - ) // + if (dedicatedServer) then { + # No passthru, end of the line. + # https://www.youtube.com/watch?v=NOMa56y_Was + } + else if (resolvedParams.version != (srcs.${latestVersionMajor} dedicatedServer).version) then + { + # Allow a "dedicated" passthru for versions other than the default. + dedicated = mkArmagetron fn true; + } + else + (lib.mapAttrs (name: value: mkArmagetron value dedicatedServer) ( + lib.filterAttrs ( + name: value: (value dedicatedServer).version != (srcs.${latestVersionMajor} dedicatedServer).version + ) srcs + )) + // { # Allow both a "dedicated" passthru and a passthru for all the options other than the latest version, which this is. dedicated = mkArmagetron fn true; tests.armagetronad = nixosTests.armagetronad; diff --git a/pkgs/games/arx-libertatis/default.nix b/pkgs/games/arx-libertatis/default.nix index 9dbe2ce7a7dfc0..a55b58c7e83a88 100644 --- a/pkgs/games/arx-libertatis/default.nix +++ b/pkgs/games/arx-libertatis/default.nix @@ -1,11 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, cmake, zlib, boost -, openal, glm, freetype, libGLU, SDL2, libepoxy -, dejavu_fonts, inkscape, optipng, imagemagick -, withCrashReporter ? !stdenv.hostPlatform.isDarwin -, qtbase ? null -, wrapQtAppsHook ? null -, curl ? null -, gdb ? null +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, + boost, + openal, + glm, + freetype, + libGLU, + SDL2, + libepoxy, + dejavu_fonts, + inkscape, + optipng, + imagemagick, + withCrashReporter ? !stdenv.hostPlatform.isDarwin, + qtbase ? null, + wrapQtAppsHook ? null, + curl ? null, + gdb ? null, }: let @@ -30,14 +44,28 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - cmake inkscape imagemagick optipng + cmake + inkscape + imagemagick + optipng ] ++ optionals withCrashReporter [ wrapQtAppsHook ]; - buildInputs = [ - zlib boost openal glm - freetype libGLU SDL2 libepoxy - ] ++ optionals withCrashReporter [ qtbase curl ] - ++ optionals stdenv.hostPlatform.isLinux [ gdb ]; + buildInputs = + [ + zlib + boost + openal + glm + freetype + libGLU + SDL2 + libepoxy + ] + ++ optionals withCrashReporter [ + qtbase + curl + ] + ++ optionals stdenv.hostPlatform.isLinux [ gdb ]; cmakeFlags = [ "-DDATA_DIR_PREFIXES=$out/share" @@ -47,13 +75,15 @@ stdenv.mkDerivation rec { dontWrapQtApps = true; - postInstall = '' - ln -sf \ - ${dejavu_fonts}/share/fonts/truetype/DejaVuSansMono.ttf \ - $out/share/games/arx/misc/dejavusansmono.ttf - '' + optionalString withCrashReporter '' - wrapQtApp "$out/libexec/arxcrashreporter" - ''; + postInstall = + '' + ln -sf \ + ${dejavu_fonts}/share/fonts/truetype/DejaVuSansMono.ttf \ + $out/share/games/arx/misc/dejavusansmono.ttf + '' + + optionalString withCrashReporter '' + wrapQtApp "$out/libexec/arxcrashreporter" + ''; meta = { description = '' diff --git a/pkgs/games/asc/default.nix b/pkgs/games/asc/default.nix index 94a16f60140d3c..fb74dada582f79 100644 --- a/pkgs/games/asc/default.nix +++ b/pkgs/games/asc/default.nix @@ -1,30 +1,31 @@ -{ fetchFromGitHub -, lib -, stdenv -, SDL -, SDL_image -, SDL_mixer -, SDL_sound -, libsigcxx -, physfs -, boost -, expat -, freetype -, libjpeg -, wxGTK32 -, lua -, perl -, pkg-config -, zlib -, zip -, bzip2 -, libpng -, libtiff -, fluidsynth -, libmikmod -, libvorbis -, flac -, libogg +{ + fetchFromGitHub, + lib, + stdenv, + SDL, + SDL_image, + SDL_mixer, + SDL_sound, + libsigcxx, + physfs, + boost, + expat, + freetype, + libjpeg, + wxGTK32, + lua, + perl, + pkg-config, + zlib, + zip, + bzip2, + libpng, + libtiff, + fluidsynth, + libmikmod, + libvorbis, + flac, + libogg, }: stdenv.mkDerivation rec { diff --git a/pkgs/games/black-hole-solver/default.nix b/pkgs/games/black-hole-solver/default.nix index cab7b2ca6d6bdd..dc9e1c7e967201 100644 --- a/pkgs/games/black-hole-solver/default.nix +++ b/pkgs/games/black-hole-solver/default.nix @@ -1,7 +1,13 @@ { - stdenv, lib, fetchurl, - cmake, perl, pkg-config, python3, - rinutils, PathTiny, + stdenv, + lib, + fetchurl, + cmake, + perl, + pkg-config, + python3, + rinutils, + PathTiny, }: stdenv.mkDerivation rec { @@ -13,9 +19,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-0y8yU291cykliPQbsNha5C1WE3bCGNxKtrrf5JBKN6c="; }; - nativeBuildInputs = [ cmake perl pkg-config python3 ]; + nativeBuildInputs = [ + cmake + perl + pkg-config + python3 + ]; - buildInputs = [ rinutils PathTiny ]; + buildInputs = [ + rinutils + PathTiny + ]; prePatch = '' patchShebangs ./scripts diff --git a/pkgs/games/blightmud/default.nix b/pkgs/games/blightmud/default.nix index b5ebd8c279ee4b..c152ed040a4ec8 100644 --- a/pkgs/games/blightmud/default.nix +++ b/pkgs/games/blightmud/default.nix @@ -1,17 +1,22 @@ -{ stdenv -, lib -, fetchFromGitHub -, rustPlatform -, pkg-config -, alsa-lib -, openssl -, withTTS ? false -, speechd-minimal -, darwin +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + pkg-config, + alsa-lib, + openssl, + withTTS ? false, + speechd-minimal, + darwin, }: let inherit (darwin.apple_sdk.frameworks) - CoreAudio AudioUnit AVFoundation AppKit; + CoreAudio + AudioUnit + AVFoundation + AppKit + ; in rustPlatform.buildRustPackage rec { pname = "blightmud"; @@ -28,13 +33,23 @@ rustPlatform.buildRustPackage rec { buildFeatures = lib.optional withTTS "tts"; - nativeBuildInputs = [ pkg-config rustPlatform.bindgenHook ]; + nativeBuildInputs = [ + pkg-config + rustPlatform.bindgenHook + ]; - buildInputs = [ openssl ] + buildInputs = + [ openssl ] ++ lib.optionals (withTTS && stdenv.hostPlatform.isLinux) [ speechd-minimal ] ++ lib.optionals stdenv.hostPlatform.isLinux [ alsa-lib ] - ++ lib.optionals (withTTS && stdenv.hostPlatform.isDarwin) [ AVFoundation AppKit ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreAudio AudioUnit ]; + ++ lib.optionals (withTTS && stdenv.hostPlatform.isDarwin) [ + AVFoundation + AppKit + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreAudio + AudioUnit + ]; checkFlags = let diff --git a/pkgs/games/bugdom/default.nix b/pkgs/games/bugdom/default.nix index 586d92e9d417f2..76cf666873dff1 100644 --- a/pkgs/games/bugdom/default.nix +++ b/pkgs/games/bugdom/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, SDL2, IOKit, Foundation, OpenGL, cmake, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + IOKit, + Foundation, + OpenGL, + cmake, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "bugdom"; @@ -21,13 +31,15 @@ stdenv.mkDerivation rec { sed -i '/plutil/d' CMakeLists.txt ''; - buildInputs = [ - SDL2 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - IOKit - Foundation - OpenGL - ]; + buildInputs = + [ + SDL2 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + IOKit + Foundation + OpenGL + ]; nativeBuildInputs = [ cmake @@ -40,24 +52,32 @@ stdenv.mkDerivation rec { "-DSDL2_INCLUDE_DIRS=${SDL2.dev}/include/SDL2" ]; - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - '' + (if stdenv.hostPlatform.isDarwin then '' - mkdir -p $out/{bin,Applications} - mv {,$out/Applications/}Bugdom.app - makeWrapper $out/{Applications/Bugdom.app/Contents/MacOS,bin}/Bugdom - '' else '' - mkdir -p $out/share/bugdom - mv Data $out/share/bugdom - install -Dm755 {.,$out/bin}/Bugdom - wrapProgram $out/bin/Bugdom --run "cd $out/share/bugdom" - install -Dm644 $src/packaging/io.jor.bugdom.desktop $out/share/applications/io.jor.bugdom.desktop - install -Dm644 $src/packaging/io.jor.bugdom.png $out/share/pixmaps/io.jor.bugdom.png - '') + '' + '' + + ( + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p $out/{bin,Applications} + mv {,$out/Applications/}Bugdom.app + makeWrapper $out/{Applications/Bugdom.app/Contents/MacOS,bin}/Bugdom + '' + else + '' + mkdir -p $out/share/bugdom + mv Data $out/share/bugdom + install -Dm755 {.,$out/bin}/Bugdom + wrapProgram $out/bin/Bugdom --run "cd $out/share/bugdom" + install -Dm644 $src/packaging/io.jor.bugdom.desktop $out/share/applications/io.jor.bugdom.desktop + install -Dm644 $src/packaging/io.jor.bugdom.png $out/share/pixmaps/io.jor.bugdom.png + '' + ) + + '' - runHook postInstall - ''; + runHook postInstall + ''; meta = with lib; { description = "Port of Bugdom, a 1999 Macintosh game by Pangea Software, for modern operating systems"; diff --git a/pkgs/games/bzflag/default.nix b/pkgs/games/bzflag/default.nix index 9b20252feffa76..b2036bb6d0db0d 100644 --- a/pkgs/games/bzflag/default.nix +++ b/pkgs/games/bzflag/default.nix @@ -1,6 +1,18 @@ -{ stdenv, lib, fetchurl, pkg-config -, curl, SDL2, libGLU, libGL, glew, ncurses, c-ares -, Carbon, CoreServices }: +{ + stdenv, + lib, + fetchurl, + pkg-config, + curl, + SDL2, + libGLU, + libGL, + glew, + ncurses, + c-ares, + Carbon, + CoreServices, +}: stdenv.mkDerivation rec { pname = "bzflag"; @@ -12,8 +24,20 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ curl SDL2 libGLU libGL glew ncurses c-ares ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Carbon CoreServices ]; + buildInputs = + [ + curl + SDL2 + libGLU + libGL + glew + ncurses + c-ares + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + CoreServices + ]; meta = with lib; { description = "Multiplayer 3D Tank game"; diff --git a/pkgs/games/cataclysm-dda/builder.nix b/pkgs/games/cataclysm-dda/builder.nix index 24128875f3a183..96e9a5758bd67b 100644 --- a/pkgs/games/cataclysm-dda/builder.nix +++ b/pkgs/games/cataclysm-dda/builder.nix @@ -1,4 +1,8 @@ -{ stdenvNoCC, lib, type }: +{ + stdenvNoCC, + lib, + type, +}: assert lib.elem type [ "mod" @@ -6,44 +10,59 @@ assert lib.elem type [ "tileset" ]; -{ modName, version, src, ... } @ args: - -stdenvNoCC.mkDerivation (args // rec { - pname = args.pname or "cataclysm-dda-${type}-${modName}"; - - modRoot = args.modRoot or "."; - - configurePhase = args.configurePhase or '' - runHook preConfigure - runHook postConfigure - ''; - - buildPhase = args.buildPhase or '' - runHook preBuild - runHook postBuild - ''; - - checkPhase = args.checkPhase or '' - runHook preCheck - runHook postCheck - ''; - - installPhase = let - baseDir = { - mod = "mods"; - soundpack = "sound"; - tileset = "gfx"; - }.${type}; - in args.installPhase or '' - runHook preInstall - destdir="$out/share/cataclysm-dda/${baseDir}" - mkdir -p "$destdir" - cp -R "${modRoot}" "$destdir/${modName}" - runHook postInstall - ''; - - passthru = { - forTiles = true; - forCurses = type == "mod"; - }; -}) +{ + modName, + version, + src, + ... +}@args: + +stdenvNoCC.mkDerivation ( + args + // rec { + pname = args.pname or "cataclysm-dda-${type}-${modName}"; + + modRoot = args.modRoot or "."; + + configurePhase = + args.configurePhase or '' + runHook preConfigure + runHook postConfigure + ''; + + buildPhase = + args.buildPhase or '' + runHook preBuild + runHook postBuild + ''; + + checkPhase = + args.checkPhase or '' + runHook preCheck + runHook postCheck + ''; + + installPhase = + let + baseDir = + { + mod = "mods"; + soundpack = "sound"; + tileset = "gfx"; + } + .${type}; + in + args.installPhase or '' + runHook preInstall + destdir="$out/share/cataclysm-dda/${baseDir}" + mkdir -p "$destdir" + cp -R "${modRoot}" "$destdir/${modName}" + runHook postInstall + ''; + + passthru = { + forTiles = true; + forCurses = type == "mod"; + }; + } +) diff --git a/pkgs/games/cataclysm-dda/default.nix b/pkgs/games/cataclysm-dda/default.nix index 1649cd031a4b47..a42d4bf87f4ddf 100644 --- a/pkgs/games/cataclysm-dda/default.nix +++ b/pkgs/games/cataclysm-dda/default.nix @@ -19,22 +19,24 @@ let curses = tiles.override { tiles = false; }; }; - lib = callPackage ./lib.nix {}; + lib = callPackage ./lib.nix { }; - pkgs = callPackage ./pkgs {}; + pkgs = callPackage ./pkgs { }; self = { inherit - callPackage - stable - git; + callPackage + stable + git + ; inherit (lib) - buildMod - buildSoundPack - buildTileSet - wrapCDDA - attachPkgs; + buildMod + buildSoundPack + buildTileSet + wrapCDDA + attachPkgs + ; inherit pkgs; }; diff --git a/pkgs/games/cataclysm-dda/lib.nix b/pkgs/games/cataclysm-dda/lib.nix index f2b38a16aa534a..aed4a1efd38cf9 100644 --- a/pkgs/games/cataclysm-dda/lib.nix +++ b/pkgs/games/cataclysm-dda/lib.nix @@ -13,7 +13,7 @@ rec { type = "tileset"; }; - wrapCDDA = callPackage ./wrapper.nix {}; + wrapCDDA = callPackage ./wrapper.nix { }; # Required to fix `pkgs` and `withMods` attrs after applying `overrideAttrs`. # @@ -33,14 +33,15 @@ rec { # (attachPkgs pkgs myBuild).withMods (_: []); # in # goodExample.x # returns "hello" - attachPkgs = pkgs: super: - let - self = super.overrideAttrs (old: { - passthru = old.passthru // { - pkgs = pkgs.override { build = self; }; - withMods = wrapCDDA self; - }; - }); - in - self; + attachPkgs = + pkgs: super: + let + self = super.overrideAttrs (old: { + passthru = old.passthru // { + pkgs = pkgs.override { build = self; }; + withMods = wrapCDDA self; + }; + }); + in + self; } diff --git a/pkgs/games/cataclysm-dda/pkgs/default.nix b/pkgs/games/cataclysm-dda/pkgs/default.nix index 72b2c814389a8a..3d098d51ea5182 100644 --- a/pkgs/games/cataclysm-dda/pkgs/default.nix +++ b/pkgs/games/cataclysm-dda/pkgs/default.nix @@ -1,4 +1,8 @@ -{ lib, callPackage, build ? null }: +{ + lib, + callPackage, + build ? null, +}: let pkgs = { @@ -9,21 +13,22 @@ let }; tileset = { - UndeadPeople = callPackage ./tilesets/UndeadPeople {}; + UndeadPeople = callPackage ./tilesets/UndeadPeople { }; }; }; pkgs' = lib.mapAttrs (_: mods: lib.filterAttrs isAvailable mods) pkgs; - isAvailable = _: mod: - if (build == null) then - true - else if build.isTiles then - mod.forTiles or false - else if build.isCurses then - mod.forCurses or false - else - false; + isAvailable = + _: mod: + if (build == null) then + true + else if build.isTiles then + mod.forTiles or false + else if build.isCurses then + mod.forCurses or false + else + false; in lib.makeExtensible (_: pkgs') diff --git a/pkgs/games/cataclysm-dda/pkgs/tilesets/UndeadPeople/default.nix b/pkgs/games/cataclysm-dda/pkgs/tilesets/UndeadPeople/default.nix index 07465d137c3edc..30c2793f6a8fd0 100644 --- a/pkgs/games/cataclysm-dda/pkgs/tilesets/UndeadPeople/default.nix +++ b/pkgs/games/cataclysm-dda/pkgs/tilesets/UndeadPeople/default.nix @@ -1,4 +1,8 @@ -{ lib, buildTileSet, fetchFromGitHub }: +{ + lib, + buildTileSet, + fetchFromGitHub, +}: buildTileSet { modName = "UndeadPeople"; diff --git a/pkgs/games/cataclysm-dda/wrapper.nix b/pkgs/games/cataclysm-dda/wrapper.nix index 28189fa7375a9b..58d09b1326865c 100644 --- a/pkgs/games/cataclysm-dda/wrapper.nix +++ b/pkgs/games/cataclysm-dda/wrapper.nix @@ -1,47 +1,50 @@ -{ lib, symlinkJoin, makeWrapper }: +{ + lib, + symlinkJoin, + makeWrapper, +}: unwrapped: pkgsSpec: let - mods = if lib.isFunction pkgsSpec - then pkgsSpec unwrapped.pkgs - else pkgsSpec; + mods = if lib.isFunction pkgsSpec then pkgsSpec unwrapped.pkgs else pkgsSpec; in -if builtins.length mods == 0 -then unwrapped -else symlinkJoin { - name = unwrapped.name + "-with-mods"; - - paths = [ unwrapped ] ++ mods; - - nativeBuildInputs = [ makeWrapper ]; - - postBuild = '' - if [ -x $out/bin/cataclysm ]; then - wrapProgram $out/bin/cataclysm \ - --add-flags "--datadir $out/share/cataclysm-dda/" - fi - if [ -x $out/bin/cataclysm-tiles ]; then - wrapProgram $out/bin/cataclysm-tiles \ - --add-flags "--datadir $out/share/cataclysm-dda/" - fi - - # Launch the wrapped program - replaceProgram() { - cp "$1" "''${1}.bk" - unlink "$1" - mv "''${1}.bk" "$1" - sed -i "$1" -e "s,${builtins.storeDir}/.\+\(/bin/cataclysm-tiles\),$out\1," - } - for script in "$out/share/applications/cataclysm-dda.desktop" \ - "$out/Applications/Cataclysm.app/Contents/MacOS/Cataclysm.sh" - do - if [ -e "$script" ]; then - replaceProgram "$script" - fi - done - ''; -} +if builtins.length mods == 0 then + unwrapped +else + symlinkJoin { + name = unwrapped.name + "-with-mods"; + + paths = [ unwrapped ] ++ mods; + + nativeBuildInputs = [ makeWrapper ]; + + postBuild = '' + if [ -x $out/bin/cataclysm ]; then + wrapProgram $out/bin/cataclysm \ + --add-flags "--datadir $out/share/cataclysm-dda/" + fi + if [ -x $out/bin/cataclysm-tiles ]; then + wrapProgram $out/bin/cataclysm-tiles \ + --add-flags "--datadir $out/share/cataclysm-dda/" + fi + + # Launch the wrapped program + replaceProgram() { + cp "$1" "''${1}.bk" + unlink "$1" + mv "''${1}.bk" "$1" + sed -i "$1" -e "s,${builtins.storeDir}/.\+\(/bin/cataclysm-tiles\),$out\1," + } + for script in "$out/share/applications/cataclysm-dda.desktop" \ + "$out/Applications/Cataclysm.app/Contents/MacOS/Cataclysm.sh" + do + if [ -e "$script" ]; then + replaceProgram "$script" + fi + done + ''; + } diff --git a/pkgs/games/chessx/default.nix b/pkgs/games/chessx/default.nix index 527188019e73ef..e76cccc6853285 100644 --- a/pkgs/games/chessx/default.nix +++ b/pkgs/games/chessx/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, pkg-config -, zlib -, qtbase -, qtsvg -, qttools -, qtmultimedia -, qmake -, fetchpatch -, fetchurl -, wrapQtAppsHook +{ + stdenv, + lib, + pkg-config, + zlib, + qtbase, + qtsvg, + qttools, + qtmultimedia, + qmake, + fetchpatch, + fetchurl, + wrapQtAppsHook, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/games/chiaki-ng/default.nix b/pkgs/games/chiaki-ng/default.nix index f11a980d73cf8a..be04bf3ec080e6 100644 --- a/pkgs/games/chiaki-ng/default.nix +++ b/pkgs/games/chiaki-ng/default.nix @@ -1,36 +1,37 @@ -{ lib -, fetchFromGitHub -, stdenv -, cmake -, pkg-config -, protobuf -, python3 -, ffmpeg -, libopus -, wrapQtAppsHook -, qtbase -, qtmultimedia -, qtsvg -, qtwayland -, qtdeclarative -, qtwebengine -, SDL2 -, libevdev -, udev -, curlFull -, hidapi -, json_c -, fftw -, miniupnpc -, speexdsp -, libplacebo -, vulkan-loader -, vulkan-headers -, libunwind -, shaderc -, lcms2 -, libdovi -, xxHash +{ + lib, + fetchFromGitHub, + stdenv, + cmake, + pkg-config, + protobuf, + python3, + ffmpeg, + libopus, + wrapQtAppsHook, + qtbase, + qtmultimedia, + qtsvg, + qtwayland, + qtdeclarative, + qtwebengine, + SDL2, + libevdev, + udev, + curlFull, + hidapi, + json_c, + fftw, + miniupnpc, + speexdsp, + libplacebo, + vulkan-loader, + vulkan-headers, + libunwind, + shaderc, + lcms2, + libdovi, + xxHash, }: stdenv.mkDerivation rec { diff --git a/pkgs/games/chiaki/default.nix b/pkgs/games/chiaki/default.nix index 6ff93f4d47e5d7..2c9f319029e42a 100644 --- a/pkgs/games/chiaki/default.nix +++ b/pkgs/games/chiaki/default.nix @@ -1,19 +1,21 @@ -{ lib, stdenv -, fetchgit -, cmake -, pkg-config -, protobuf -, python3Packages -, ffmpeg -, libopus -, mkDerivation -, qtbase -, qtmultimedia -, qtsvg -, SDL2 -, libevdev -, udev -, qtmacextras +{ + lib, + stdenv, + fetchgit, + cmake, + pkg-config, + protobuf, + python3Packages, + ffmpeg, + libopus, + mkDerivation, + qtbase, + qtmultimedia, + qtsvg, + SDL2, + libevdev, + udev, + qtmacextras, }: mkDerivation rec { @@ -36,20 +38,23 @@ mkDerivation rec { python3Packages.setuptools ]; - buildInputs = [ - ffmpeg - libopus - qtbase - qtmultimedia - qtsvg - protobuf - SDL2 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libevdev - udev - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - qtmacextras - ]; + buildInputs = + [ + ffmpeg + libopus + qtbase + qtmultimedia + qtsvg + protobuf + SDL2 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libevdev + udev + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + qtmacextras + ]; doCheck = true; diff --git a/pkgs/games/cockatrice/default.nix b/pkgs/games/cockatrice/default.nix index 2f268409d89258..5f06dea0df0242 100644 --- a/pkgs/games/cockatrice/default.nix +++ b/pkgs/games/cockatrice/default.nix @@ -1,5 +1,14 @@ -{ lib, fetchFromGitHub, mkDerivation, cmake, protobuf -, qtbase, qtmultimedia, qttools, qtwebsockets, wrapQtAppsHook +{ + lib, + fetchFromGitHub, + mkDerivation, + cmake, + protobuf, + qtbase, + qtmultimedia, + qttools, + qtwebsockets, + wrapQtAppsHook, }: mkDerivation rec { @@ -14,10 +23,17 @@ mkDerivation rec { }; buildInputs = [ - qtbase qtmultimedia protobuf qttools qtwebsockets + qtbase + qtmultimedia + protobuf + qttools + qtwebsockets ]; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; meta = { homepage = "https://github.com/Cockatrice/Cockatrice"; diff --git a/pkgs/games/construo/default.nix b/pkgs/games/construo/default.nix index c4d4c50df39315..b4805a029bd582 100644 --- a/pkgs/games/construo/default.nix +++ b/pkgs/games/construo/default.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchurl -, libX11 -, zlib -, xorgproto -, libGL ? null -, libGLU ? null -, libglut ? null +{ + lib, + stdenv, + fetchurl, + libX11, + zlib, + xorgproto, + libGL ? null, + libGLU ? null, + libglut ? null, }: stdenv.mkDerivation rec { @@ -17,7 +19,12 @@ stdenv.mkDerivation rec { sha256 = "1wmj527hbj1qv44cdsj6ahfjrnrjwg2dp8gdick8nd07vm062qxa"; }; - buildInputs = [ libX11 zlib xorgproto ] + buildInputs = + [ + libX11 + zlib + xorgproto + ] ++ lib.optional (libGL != null) libGL ++ lib.optional (libGLU != null) libGLU ++ lib.optional (libglut != null) libglut; diff --git a/pkgs/games/crawl/default.nix b/pkgs/games/crawl/default.nix index c240e116047f09..81e8f826e509dc 100644 --- a/pkgs/games/crawl/default.nix +++ b/pkgs/games/crawl/default.nix @@ -1,29 +1,30 @@ -{ stdenv -, lib -, fetchFromGitHub -, which -, sqlite -, lua5_1 -, perl -, python3 -, zlib -, pkg-config -, ncurses -, dejavu_fonts -, libpng -, SDL2 -, SDL2_image -, SDL2_mixer -, libGLU -, libGL -, freetype -, pngcrush -, advancecomp -, tileMode ? false -, enableSound ? tileMode -, buildPackages +{ + stdenv, + lib, + fetchFromGitHub, + which, + sqlite, + lua5_1, + perl, + python3, + zlib, + pkg-config, + ncurses, + dejavu_fonts, + libpng, + SDL2, + SDL2_image, + SDL2_mixer, + libGLU, + libGL, + freetype, + pngcrush, + advancecomp, + tileMode ? false, + enableSound ? tileMode, + buildPackages, # MacOS / Darwin builds -, darwin + darwin, }: stdenv.mkDerivation rec { @@ -45,50 +46,72 @@ stdenv.mkDerivation rec { --replace 'SDL_image.h' 'SDL2/SDL_image.h' ''; - nativeBuildInputs = [ pkg-config which perl pngcrush advancecomp ]; + nativeBuildInputs = [ + pkg-config + which + perl + pngcrush + advancecomp + ]; # Still unstable with luajit - buildInputs = [ lua5_1 zlib sqlite ncurses ] + buildInputs = + [ + lua5_1 + zlib + sqlite + ncurses + ] ++ (with python3.pkgs; [ pyyaml ]) - ++ lib.optionals tileMode [ libpng SDL2 SDL2_image freetype libGLU libGL ] + ++ lib.optionals tileMode [ + libpng + SDL2 + SDL2_image + freetype + libGLU + libGL + ] ++ lib.optional enableSound SDL2_mixer ++ (lib.optionals stdenv.hostPlatform.isDarwin ( - with darwin.apple_sdk.frameworks; [ - AppKit - AudioUnit - CoreAudio - ForceFeedback - Carbon - IOKit - OpenGL - ] - )); + with darwin.apple_sdk.frameworks; + [ + AppKit + AudioUnit + CoreAudio + ForceFeedback + Carbon + IOKit + OpenGL + ] + )); - preBuild = '' - cd crawl-ref/source - echo "${version}" > util/release_ver - patchShebangs 'util' - patchShebangs util/gen-mi-enum - rm -rf contrib - mkdir -p $out/xdg-data - '' - + lib.optionalString tileMode "mv xdg-data/*_tiles.* $out/xdg-data" - + lib.optionalString (!tileMode) "mv xdg-data/*_console.* $out/xdg-data"; + preBuild = + '' + cd crawl-ref/source + echo "${version}" > util/release_ver + patchShebangs 'util' + patchShebangs util/gen-mi-enum + rm -rf contrib + mkdir -p $out/xdg-data + '' + + lib.optionalString tileMode "mv xdg-data/*_tiles.* $out/xdg-data" + + lib.optionalString (!tileMode) "mv xdg-data/*_console.* $out/xdg-data"; fontsPath = lib.optionalString tileMode dejavu_fonts; - makeFlags = [ - "prefix=${placeholder "out"}" - "FORCE_CC=${stdenv.cc.targetPrefix}cc" - "FORCE_CXX=${stdenv.cc.targetPrefix}c++" - "HOSTCXX=${buildPackages.stdenv.cc.targetPrefix}c++" - "FORCE_PKGCONFIG=y" - "SAVEDIR=~/.crawl" - "sqlite=${sqlite.dev}" - "DATADIR=${placeholder "out"}" - ] - ++ lib.optional tileMode "TILES=y" - ++ lib.optional enableSound "SOUND=y"; + makeFlags = + [ + "prefix=${placeholder "out"}" + "FORCE_CC=${stdenv.cc.targetPrefix}cc" + "FORCE_CXX=${stdenv.cc.targetPrefix}c++" + "HOSTCXX=${buildPackages.stdenv.cc.targetPrefix}c++" + "FORCE_PKGCONFIG=y" + "SAVEDIR=~/.crawl" + "sqlite=${sqlite.dev}" + "DATADIR=${placeholder "out"}" + ] + ++ lib.optional tileMode "TILES=y" + ++ lib.optional enableSound "SOUND=y"; postInstall = lib.optionalString tileMode '' @@ -98,15 +121,13 @@ stdenv.mkDerivation rec { install -Dm444 $out/xdg-data/org.develz.Crawl_tiles.desktop -t $out/share/applications install -Dm444 $out/xdg-data/org.develz.Crawl_tiles.appdata.xml -t $out/share/metainfo '' - + - lib.optionalString (!tileMode) '' + + lib.optionalString (!tileMode) '' echo "Exec=crawl" >> $out/xdg-data/org.develz.Crawl_console.desktop echo "Icon=crawl" >> $out/xdg-data/org.develz.Crawl_console.desktop install -Dm444 $out/xdg-data/org.develz.Crawl_console.desktop -t $out/share/applications install -Dm444 $out/xdg-data/org.develz.Crawl_console.appdata.xml -t $out/share/metainfo '' - + "install -Dm444 dat/tiles/stone_soup_icon-512x512.png $out/share/icons/hicolor/512x512/apps/crawl.png" - ; + + "install -Dm444 dat/tiles/stone_soup_icon-512x512.png $out/share/icons/hicolor/512x512/apps/crawl.png"; enableParallelBuilding = true; @@ -120,7 +141,14 @@ stdenv.mkDerivation rec { mystifyingly fabulous Orb of Zot. ''; platforms = platforms.linux ++ platforms.darwin; - license = with licenses; [ gpl2Plus bsd2 bsd3 mit licenses.zlib cc0 ]; + license = with licenses; [ + gpl2Plus + bsd2 + bsd3 + mit + licenses.zlib + cc0 + ]; maintainers = [ maintainers.abbradar ]; }; } diff --git a/pkgs/games/crossfire/crossfire-arch.nix b/pkgs/games/crossfire/crossfire-arch.nix index c09f474e70c79f..cb21856eab9f8b 100644 --- a/pkgs/games/crossfire/crossfire-arch.nix +++ b/pkgs/games/crossfire/crossfire-arch.nix @@ -1,5 +1,11 @@ -{ stdenv, lib, fetchsvn, - version, rev, sha256 }: +{ + stdenv, + lib, + fetchsvn, + version, + rev, + sha256, +}: stdenv.mkDerivation rec { pname = "crossfire-arch"; @@ -21,7 +27,7 @@ stdenv.mkDerivation rec { homepage = "http://crossfire.real-time.com/"; license = licenses.gpl2Plus; platforms = platforms.linux; - hydraPlatforms = []; + hydraPlatforms = [ ]; maintainers = with maintainers; [ ToxicFrog ]; }; } diff --git a/pkgs/games/crossfire/crossfire-client.nix b/pkgs/games/crossfire/crossfire-client.nix index bc3a6bbf8b0649..99c3ae355af6f5 100644 --- a/pkgs/games/crossfire/crossfire-client.nix +++ b/pkgs/games/crossfire/crossfire-client.nix @@ -1,8 +1,28 @@ -{ stdenv, lib, fetchsvn -, cmake, pkg-config, perl, vala -, gtk2, pcre, zlib, libpng, fribidi, harfbuzzFull, xorg, util-linux, curl -, SDL, SDL_image, SDL_mixer, libselinux, libsepol -, version, rev, sha256 +{ + stdenv, + lib, + fetchsvn, + cmake, + pkg-config, + perl, + vala, + gtk2, + pcre, + zlib, + libpng, + fribidi, + harfbuzzFull, + xorg, + util-linux, + curl, + SDL, + SDL_image, + SDL_mixer, + libselinux, + libsepol, + version, + rev, + sha256, }: stdenv.mkDerivation rec { @@ -15,10 +35,28 @@ stdenv.mkDerivation rec { rev = "r${rev}"; }; - nativeBuildInputs = [ cmake pkg-config perl vala ]; + nativeBuildInputs = [ + cmake + pkg-config + perl + vala + ]; buildInputs = [ - gtk2 pcre zlib libpng fribidi harfbuzzFull xorg.libpthreadstubs - xorg.libXdmcp curl SDL SDL_image SDL_mixer util-linux libselinux libsepol + gtk2 + pcre + zlib + libpng + fribidi + harfbuzzFull + xorg.libpthreadstubs + xorg.libXdmcp + curl + SDL + SDL_image + SDL_mixer + util-linux + libselinux + libsepol ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/games/crossfire/crossfire-maps.nix b/pkgs/games/crossfire/crossfire-maps.nix index cb514a90d16995..7740452d054d5c 100644 --- a/pkgs/games/crossfire/crossfire-maps.nix +++ b/pkgs/games/crossfire/crossfire-maps.nix @@ -1,5 +1,11 @@ -{ stdenv, lib, fetchsvn, - version, rev, sha256 }: +{ + stdenv, + lib, + fetchsvn, + version, + rev, + sha256, +}: stdenv.mkDerivation rec { pname = "crossfire-maps"; @@ -21,7 +27,7 @@ stdenv.mkDerivation rec { homepage = "http://crossfire.real-time.com/"; license = licenses.gpl2Plus; platforms = platforms.linux; - hydraPlatforms = []; + hydraPlatforms = [ ]; maintainers = with maintainers; [ ToxicFrog ]; }; } diff --git a/pkgs/games/crossfire/crossfire-server.nix b/pkgs/games/crossfire/crossfire-server.nix index aab4e2c2032b0a..a22eb9dc11936d 100644 --- a/pkgs/games/crossfire/crossfire-server.nix +++ b/pkgs/games/crossfire/crossfire-server.nix @@ -1,19 +1,20 @@ -{ stdenv -, lib -, fetchsvn -, autoconf -, automake -, libtool -, flex -, perl -, check -, pkg-config -, python39 # crossfire-server relies on a parser wich was removed in python >3.9 -, version -, rev -, sha256 -, maps -, arch +{ + stdenv, + lib, + fetchsvn, + autoconf, + automake, + libtool, + flex, + perl, + check, + pkg-config, + python39, # crossfire-server relies on a parser wich was removed in python >3.9 + version, + rev, + sha256, + maps, + arch, }: stdenv.mkDerivation rec { @@ -30,7 +31,16 @@ stdenv.mkDerivation rec { ./add-cstdint-include-to-crossfire-server.patch ]; - nativeBuildInputs = [ autoconf automake libtool flex perl check pkg-config python39 ]; + nativeBuildInputs = [ + autoconf + automake + libtool + flex + perl + check + pkg-config + python39 + ]; hardeningDisable = [ "format" ]; preConfigure = '' diff --git a/pkgs/games/crossfire/default.nix b/pkgs/games/crossfire/default.nix index 7d0716df3d9b9d..f494592d6f0ad9 100644 --- a/pkgs/games/crossfire/default.nix +++ b/pkgs/games/crossfire/default.nix @@ -11,7 +11,8 @@ rec { version = "latest"; rev = "22111"; sha256 = "04fjif6zv642n2zlw27cgzkak2kknwrxqzg42bvzl7q901bsr9l7"; - maps = crossfire-maps; arch = crossfire-arch; + maps = crossfire-maps; + arch = crossfire-arch; }; crossfire-arch = callPackage ./crossfire-arch.nix { diff --git a/pkgs/games/curseofwar/default.nix b/pkgs/games/curseofwar/default.nix index 448d8fb7ae2c4c..0a74065cec930d 100644 --- a/pkgs/games/curseofwar/default.nix +++ b/pkgs/games/curseofwar/default.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchFromGitHub -, ncurses -, SDL +{ + lib, + stdenv, + fetchFromGitHub, + ncurses, + SDL, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/games/cutechess/default.nix b/pkgs/games/cutechess/default.nix index 6c473857ba75b8..05a75351e9e296 100644 --- a/pkgs/games/cutechess/default.nix +++ b/pkgs/games/cutechess/default.nix @@ -1,10 +1,11 @@ -{ stdenv -, fetchFromGitHub -, cmake -, pkg-config -, wrapQtAppsHook -, qtbase -, lib +{ + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + wrapQtAppsHook, + qtbase, + lib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/games/cutemaze/default.nix b/pkgs/games/cutemaze/default.nix index 2a1f194f5c0ddb..f2f741934f25a4 100644 --- a/pkgs/games/cutemaze/default.nix +++ b/pkgs/games/cutemaze/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, cmake -, qttools -, wrapQtAppsHook -, qtbase -, qtwayland -, qtsvg +{ + lib, + stdenv, + fetchurl, + cmake, + qttools, + wrapQtAppsHook, + qtbase, + qtwayland, + qtsvg, }: stdenv.mkDerivation rec { @@ -24,22 +25,28 @@ stdenv.mkDerivation rec { wrapQtAppsHook ]; - buildInputs = [ - qtbase - qtsvg - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qtwayland - ]; - - installPhase = if stdenv.hostPlatform.isDarwin then '' - runHook preInstall - - mkdir -p $out/Applications - mv CuteMaze.app $out/Applications - makeWrapper $out/Applications/CuteMaze.app/Contents/MacOS/CuteMaze $out/bin/cutemaze - - runHook postInstall - '' else null; + buildInputs = + [ + qtbase + qtsvg + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qtwayland + ]; + + installPhase = + if stdenv.hostPlatform.isDarwin then + '' + runHook preInstall + + mkdir -p $out/Applications + mv CuteMaze.app $out/Applications + makeWrapper $out/Applications/CuteMaze.app/Contents/MacOS/CuteMaze $out/bin/cutemaze + + runHook postInstall + '' + else + null; meta = with lib; { changelog = "https://github.com/gottcode/cutemaze/blob/v${version}/ChangeLog"; diff --git a/pkgs/games/deliantra/arch.nix b/pkgs/games/deliantra/arch.nix index 2201ca2d1f5fb7..24fdaa82df487f 100644 --- a/pkgs/games/deliantra/arch.nix +++ b/pkgs/games/deliantra/arch.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchurl, deliantra-server }: +{ + stdenv, + lib, + fetchurl, + deliantra-server, +}: stdenv.mkDerivation rec { pname = "deliantra-arch"; @@ -18,7 +23,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Archetype data for the Deliantra free MMORPG"; homepage = "http://www.deliantra.net/"; - license = with licenses; [ gpl2Plus agpl3Plus ]; + license = with licenses; [ + gpl2Plus + agpl3Plus + ]; platforms = platforms.linux; maintainers = with maintainers; [ ToxicFrog ]; }; diff --git a/pkgs/games/deliantra/data.nix b/pkgs/games/deliantra/data.nix index ca1cec26683719..7d16f4a3d91511 100644 --- a/pkgs/games/deliantra/data.nix +++ b/pkgs/games/deliantra/data.nix @@ -1,4 +1,10 @@ -{ lib, deliantra-maps, deliantra-arch, deliantra-server, symlinkJoin }: +{ + lib, + deliantra-maps, + deliantra-arch, + deliantra-server, + symlinkJoin, +}: symlinkJoin rec { name = "deliantra-data-${version}"; @@ -13,9 +19,12 @@ symlinkJoin rec { meta = with lib; { description = "Combined game data (maps + archetypes) for the Deliantra free MMORPG"; homepage = "http://www.deliantra.net/"; - license = with licenses; [ gpl2Plus agpl3Plus ]; + license = with licenses; [ + gpl2Plus + agpl3Plus + ]; platforms = platforms.linux; maintainers = with maintainers; [ ToxicFrog ]; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/games/deliantra/maps.nix b/pkgs/games/deliantra/maps.nix index 1f87178102a0c3..f630a1e50d3a7e 100644 --- a/pkgs/games/deliantra/maps.nix +++ b/pkgs/games/deliantra/maps.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchurl, deliantra-server }: +{ + stdenv, + lib, + fetchurl, + deliantra-server, +}: stdenv.mkDerivation rec { pname = "deliantra-maps"; @@ -18,7 +23,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Map data for the Deliantra free MMORPG"; homepage = "http://www.deliantra.net/"; - license = with licenses; [ gpl2Plus agpl3Plus ]; + license = with licenses; [ + gpl2Plus + agpl3Plus + ]; platforms = platforms.linux; maintainers = with maintainers; [ ToxicFrog ]; }; diff --git a/pkgs/games/deliantra/server.nix b/pkgs/games/deliantra/server.nix index 08889dd2302d74..9f92d99aad1ba0 100644 --- a/pkgs/games/deliantra/server.nix +++ b/pkgs/games/deliantra/server.nix @@ -1,13 +1,39 @@ -{ stdenv, lib, fetchurl, perlPackages -, autoconf, perl, gperf, optipng, pngnq, rsync, imagemagick, blitz -, pkg-config, glib, boost, makeWrapper +{ + stdenv, + lib, + fetchurl, + perlPackages, + autoconf, + perl, + gperf, + optipng, + pngnq, + rsync, + imagemagick, + blitz, + pkg-config, + glib, + boost, + makeWrapper, }: let perl-deps = with perlPackages; [ - AnyEvent AnyEventAIO AnyEventBDB AnyEventIRC - CompressLZF commonsense Coro CoroEV - Deliantra DigestSHA1 EV PodPOM SafeHole URI YAMLLibYAML + AnyEvent + AnyEventAIO + AnyEventBDB + AnyEventIRC + CompressLZF + commonsense + Coro + CoroEV + Deliantra + DigestSHA1 + EV + PodPOM + SafeHole + URI + YAMLLibYAML ]; in stdenv.mkDerivation rec { @@ -20,14 +46,23 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - autoconf perl gperf optipng pngnq rsync imagemagick - pkg-config makeWrapper + autoconf + perl + gperf + optipng + pngnq + rsync + imagemagick + pkg-config + makeWrapper ]; propagatedBuildInputs = perl-deps; buildInputs = [ - blitz boost glib + blitz + boost + glib ]; hardeningDisable = [ "format" ]; @@ -48,7 +83,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Server for the Deliantra free MMORPG"; homepage = "http://www.deliantra.net/"; - license = with licenses; [ gpl2Plus agpl3Plus ]; + license = with licenses; [ + gpl2Plus + agpl3Plus + ]; platforms = platforms.linux; maintainers = with maintainers; [ ToxicFrog ]; }; diff --git a/pkgs/games/devilutionx/default.nix b/pkgs/games/devilutionx/default.nix index c8d2102728b22e..19c21d9284267e 100644 --- a/pkgs/games/devilutionx/default.nix +++ b/pkgs/games/devilutionx/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchurl -, bzip2 -, cmake -, pkg-config -, gettext -, libsodium -, SDL2 -, SDL2_image -, SDL_audiolib -, flac -, fmt -, libpng -, smpq +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + bzip2, + cmake, + pkg-config, + gettext, + libsodium, + SDL2, + SDL2_image, + SDL_audiolib, + flac, + fmt, + libpng, + smpq, }: let @@ -103,25 +104,33 @@ stdenv.mkDerivation rec { SDL_audiolib' ]; - installPhase = '' - runHook preInstall - - '' + (if stdenv.hostPlatform.isDarwin then '' - mkdir -p $out/Applications - mv devilutionx.app $out/Applications - '' else '' - install -Dm755 -t $out/bin devilutionx - install -Dm755 -t $out/bin devilutionx.mpq - install -Dm755 -t $out/share/diasurgical/devilutionx devilutionx.mpq - install -Dm755 -t $out/share/applications ../Packaging/nix/devilutionx-hellfire.desktop ../Packaging/nix/devilutionx.desktop - install -Dm755 ../Packaging/resources/icon.png $out/share/icons/hicolor/512x512/apps/devilutionx.png - install -Dm755 ../Packaging/resources/hellfire.png $out/share/icons/hicolor/512x512/apps/devilutionx-hellfire.png - install -Dm755 ../Packaging/resources/icon_32.png $out/share/icons/hicolor/32x32/apps/devilutionx.png - install -Dm755 ../Packaging/resources/hellfire_32.png $out/share/icons/hicolor/32x32/apps/devilutionx-hellfire.png - '') + '' - - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + + '' + + ( + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p $out/Applications + mv devilutionx.app $out/Applications + '' + else + '' + install -Dm755 -t $out/bin devilutionx + install -Dm755 -t $out/bin devilutionx.mpq + install -Dm755 -t $out/share/diasurgical/devilutionx devilutionx.mpq + install -Dm755 -t $out/share/applications ../Packaging/nix/devilutionx-hellfire.desktop ../Packaging/nix/devilutionx.desktop + install -Dm755 ../Packaging/resources/icon.png $out/share/icons/hicolor/512x512/apps/devilutionx.png + install -Dm755 ../Packaging/resources/hellfire.png $out/share/icons/hicolor/512x512/apps/devilutionx-hellfire.png + install -Dm755 ../Packaging/resources/icon_32.png $out/share/icons/hicolor/32x32/apps/devilutionx.png + install -Dm755 ../Packaging/resources/hellfire_32.png $out/share/icons/hicolor/32x32/apps/devilutionx-hellfire.png + '' + ) + + '' + + runHook postInstall + ''; meta = with lib; { homepage = "https://github.com/diasurgical/devilutionX"; @@ -129,7 +138,10 @@ stdenv.mkDerivation rec { mainProgram = "devilutionx"; longDescription = "In order to play this game a copy of diabdat.mpq is required. Place a copy of diabdat.mpq in ~/.local/share/diasurgical/devilution before executing the game."; license = licenses.unlicense; - maintainers = with maintainers; [ karolchmist aanderse ]; + maintainers = with maintainers; [ + karolchmist + aanderse + ]; platforms = platforms.linux ++ platforms.windows; }; } diff --git a/pkgs/games/doom-ports/doomrunner/default.nix b/pkgs/games/doom-ports/doomrunner/default.nix index a33f1273f6d087..c61055e190aba9 100644 --- a/pkgs/games/doom-ports/doomrunner/default.nix +++ b/pkgs/games/doom-ports/doomrunner/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, qtbase -, qmake -, makeDesktopItem -, wrapQtAppsHook -, imagemagick -, fetchFromGitHub +{ + lib, + stdenv, + qtbase, + qmake, + makeDesktopItem, + wrapQtAppsHook, + imagemagick, + fetchFromGitHub, }: stdenv.mkDerivation (finalAttrs: { @@ -20,7 +21,11 @@ stdenv.mkDerivation (finalAttrs: { }; buildInputs = [ qtbase ]; - nativeBuildInputs = [ qmake wrapQtAppsHook imagemagick ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + imagemagick + ]; makeFlags = [ "INSTALL_ROOT=${placeholder "out"}" diff --git a/pkgs/games/doom-ports/doomseeker/default.nix b/pkgs/games/doom-ports/doomseeker/default.nix index 25c536230a6c7c..eb1b4dedce92a6 100644 --- a/pkgs/games/doom-ports/doomseeker/default.nix +++ b/pkgs/games/doom-ports/doomseeker/default.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, cmake, fetchFromBitbucket, wrapQtAppsHook, pkg-config, qtbase, qttools, qtmultimedia, zlib, bzip2, xxd }: +{ + lib, + stdenv, + cmake, + fetchFromBitbucket, + wrapQtAppsHook, + pkg-config, + qtbase, + qttools, + qtmultimedia, + zlib, + bzip2, + xxd, +}: stdenv.mkDerivation { pname = "doomseeker"; @@ -11,10 +24,25 @@ stdenv.mkDerivation { hash = "sha256-J7gesOo8NUPuVaU0o4rCGzLrqr3IIMAchulWZG3HTqg="; }; - patches = [ ./dont_update_gitinfo.patch ./add_gitinfo.patch ./fix_paths.patch ]; + patches = [ + ./dont_update_gitinfo.patch + ./add_gitinfo.patch + ./fix_paths.patch + ]; - nativeBuildInputs = [ wrapQtAppsHook cmake qttools pkg-config xxd ]; - buildInputs = [ qtbase qtmultimedia zlib bzip2 ]; + nativeBuildInputs = [ + wrapQtAppsHook + cmake + qttools + pkg-config + xxd + ]; + buildInputs = [ + qtbase + qtmultimedia + zlib + bzip2 + ]; hardeningDisable = lib.optional stdenv.hostPlatform.isDarwin "format"; diff --git a/pkgs/games/doom-ports/enyo-launcher/default.nix b/pkgs/games/doom-ports/enyo-launcher/default.nix index 422a9033ee0f12..b8e38af270aa35 100644 --- a/pkgs/games/doom-ports/enyo-launcher/default.nix +++ b/pkgs/games/doom-ports/enyo-launcher/default.nix @@ -1,4 +1,10 @@ -{ mkDerivation, lib, fetchFromGitLab, cmake, qtbase }: +{ + mkDerivation, + lib, + fetchFromGitLab, + cmake, + qtbase, +}: mkDerivation rec { pname = "enyo-launcher"; diff --git a/pkgs/games/doom-ports/zandronum/alpha/default.nix b/pkgs/games/doom-ports/zandronum/alpha/default.nix index 665bef3bd4a19d..9f2bde55e8361b 100644 --- a/pkgs/games/doom-ports/zandronum/alpha/default.nix +++ b/pkgs/games/doom-ports/zandronum/alpha/default.nix @@ -1,24 +1,25 @@ -{ stdenv -, lib -, fetchhg -, cmake -, pkg-config -, makeWrapper -, callPackage -, soundfont-fluid -, SDL_compat -, libGL -, glew -, bzip2 -, zlib -, libjpeg -, fluidsynth -, fmodex -, openssl -, gtk2 -, python3 -, game-music-emu -, serverOnly ? false +{ + stdenv, + lib, + fetchhg, + cmake, + pkg-config, + makeWrapper, + callPackage, + soundfont-fluid, + SDL_compat, + libGL, + glew, + bzip2, + zlib, + libjpeg, + fluidsynth, + fmodex, + openssl, + gtk2, + python3, + game-music-emu, + serverOnly ? false, }: let @@ -43,31 +44,55 @@ stdenv.mkDerivation rec { # it also needs the current mercurial revision info embedded in gitinfo.h # otherwise, the client will fail to connect to servers because the # protocol version doesn't match. - patches = [ ./zan_configure_impurity.patch ./dont_update_gitinfo.patch ./add_gitinfo.patch ]; + patches = [ + ./zan_configure_impurity.patch + ./dont_update_gitinfo.patch + ./add_gitinfo.patch + ]; # I have no idea why would SDL and libjpeg be needed for the server part! # But they are. - buildInputs = [ openssl bzip2 zlib SDL_compat libjpeg sqlite game-music-emu ] - ++ lib.optionals (!serverOnly) [ libGL glew fmod fluidsynth gtk2 ]; + buildInputs = + [ + openssl + bzip2 + zlib + SDL_compat + libjpeg + sqlite + game-music-emu + ] + ++ lib.optionals (!serverOnly) [ + libGL + glew + fmod + fluidsynth + gtk2 + ]; - nativeBuildInputs = [ cmake pkg-config makeWrapper python3 ]; + nativeBuildInputs = [ + cmake + pkg-config + makeWrapper + python3 + ]; - preConfigure = '' - ln -s ${sqlite}/* sqlite/ - sed -ie 's| restrict| _restrict|g' dumb/include/dumb.h \ - dumb/src/it/*.c - '' + lib.optionalString (!serverOnly) '' - sed -i \ - -e "s@/usr/share/sounds/sf2/@${soundfont-fluid}/share/soundfonts/@g" \ - -e "s@FluidR3_GM.sf2@FluidR3_GM2-2.sf2@g" \ - src/sound/music_fluidsynth_mididevice.cpp - ''; + preConfigure = + '' + ln -s ${sqlite}/* sqlite/ + sed -ie 's| restrict| _restrict|g' dumb/include/dumb.h \ + dumb/src/it/*.c + '' + + lib.optionalString (!serverOnly) '' + sed -i \ + -e "s@/usr/share/sounds/sf2/@${soundfont-fluid}/share/soundfonts/@g" \ + -e "s@FluidR3_GM.sf2@FluidR3_GM2-2.sf2@g" \ + src/sound/music_fluidsynth_mididevice.cpp + ''; - cmakeFlags = - [ "-DFORCE_INTERNAL_GME=OFF" ] - ++ (if serverOnly - then [ "-DSERVERONLY=ON" ] - else [ "-DFMOD_LIBRARY=${fmod}/lib/libfmodex.so" ]); + cmakeFlags = [ + "-DFORCE_INTERNAL_GME=OFF" + ] ++ (if serverOnly then [ "-DSERVERONLY=ON" ] else [ "-DFMOD_LIBRARY=${fmod}/lib/libfmodex.so" ]); hardeningDisable = [ "format" ]; diff --git a/pkgs/games/doom-ports/zandronum/default.nix b/pkgs/games/doom-ports/zandronum/default.nix index 17c9b473870a63..5a36f375ac79c6 100644 --- a/pkgs/games/doom-ports/zandronum/default.nix +++ b/pkgs/games/doom-ports/zandronum/default.nix @@ -1,24 +1,25 @@ -{ stdenv -, lib -, fetchhg -, cmake -, pkg-config -, makeWrapper -, callPackage -, soundfont-fluid -, SDL_compat -, libGL -, glew -, bzip2 -, zlib -, libjpeg -, fluidsynth -, fmodex -, openssl -, gtk2 -, python3 -, game-music-emu -, serverOnly ? false +{ + stdenv, + lib, + fetchhg, + cmake, + pkg-config, + makeWrapper, + callPackage, + soundfont-fluid, + SDL_compat, + libGL, + glew, + bzip2, + zlib, + libjpeg, + fluidsynth, + fmodex, + openssl, + gtk2, + python3, + game-music-emu, + serverOnly ? false, }: let @@ -43,31 +44,55 @@ stdenv.mkDerivation rec { # it also needs the current mercurial revision info embedded in gitinfo.h # otherwise, the client will fail to connect to servers because the # protocol version doesn't match. - patches = [ ./zan_configure_impurity.patch ./dont_update_gitinfo.patch ./add_gitinfo.patch ]; + patches = [ + ./zan_configure_impurity.patch + ./dont_update_gitinfo.patch + ./add_gitinfo.patch + ]; # I have no idea why would SDL and libjpeg be needed for the server part! # But they are. - buildInputs = [ openssl bzip2 zlib SDL_compat libjpeg sqlite game-music-emu ] - ++ lib.optionals (!serverOnly) [ libGL glew fmod fluidsynth gtk2 ]; + buildInputs = + [ + openssl + bzip2 + zlib + SDL_compat + libjpeg + sqlite + game-music-emu + ] + ++ lib.optionals (!serverOnly) [ + libGL + glew + fmod + fluidsynth + gtk2 + ]; - nativeBuildInputs = [ cmake pkg-config makeWrapper python3 ]; + nativeBuildInputs = [ + cmake + pkg-config + makeWrapper + python3 + ]; - preConfigure = '' - ln -s ${sqlite}/* sqlite/ - sed -ie 's| restrict| _restrict|g' dumb/include/dumb.h \ - dumb/src/it/*.c - '' + lib.optionalString (!serverOnly) '' - sed -i \ - -e "s@/usr/share/sounds/sf2/@${soundfont-fluid}/share/soundfonts/@g" \ - -e "s@FluidR3_GM.sf2@FluidR3_GM2-2.sf2@g" \ - src/sound/music_fluidsynth_mididevice.cpp - ''; + preConfigure = + '' + ln -s ${sqlite}/* sqlite/ + sed -ie 's| restrict| _restrict|g' dumb/include/dumb.h \ + dumb/src/it/*.c + '' + + lib.optionalString (!serverOnly) '' + sed -i \ + -e "s@/usr/share/sounds/sf2/@${soundfont-fluid}/share/soundfonts/@g" \ + -e "s@FluidR3_GM.sf2@FluidR3_GM2-2.sf2@g" \ + src/sound/music_fluidsynth_mididevice.cpp + ''; - cmakeFlags = - [ "-DFORCE_INTERNAL_GME=OFF" ] - ++ (if serverOnly - then [ "-DSERVERONLY=ON" ] - else [ "-DFMOD_LIBRARY=${fmod}/lib/libfmodex.so" ]); + cmakeFlags = [ + "-DFORCE_INTERNAL_GME=OFF" + ] ++ (if serverOnly then [ "-DSERVERONLY=ON" ] else [ "-DFMOD_LIBRARY=${fmod}/lib/libfmodex.so" ]); hardeningDisable = [ "format" ]; diff --git a/pkgs/games/doom-ports/zandronum/fmod.nix b/pkgs/games/doom-ports/zandronum/fmod.nix index 0d965cb7172431..030f20e084e495 100644 --- a/pkgs/games/doom-ports/zandronum/fmod.nix +++ b/pkgs/games/doom-ports/zandronum/fmod.nix @@ -1,8 +1,19 @@ -{ stdenv, lib, fetchurl, alsa-lib, libpulseaudio, undmg }: +{ + stdenv, + lib, + fetchurl, + alsa-lib, + libpulseaudio, + undmg, +}: let bits = lib.optionalString (stdenv.hostPlatform.system == "x86_64-linux") "64"; - libPath = lib.makeLibraryPath [ stdenv.cc.cc alsa-lib libpulseaudio ]; + libPath = lib.makeLibraryPath [ + stdenv.cc.cc + alsa-lib + libpulseaudio + ]; in stdenv.mkDerivation rec { @@ -10,13 +21,18 @@ stdenv.mkDerivation rec { version = "4.44.64"; shortVersion = builtins.replaceStrings [ "." ] [ "" ] version; - src = fetchurl (if stdenv.hostPlatform.isLinux then { - url = "https://zdoom.org/files/fmod/fmodapi${shortVersion}linux.tar.gz"; - sha256 = "047hk92xapwwqj281f4zwl0ih821rrliya70gfj82sdfjh9lz8i1"; - } else { - url = "https://zdoom.org/files/fmod/fmodapi${shortVersion}mac-installer.dmg"; - sha256 = "1m1y4cpcwpkl8x31d3s68xzp107f343ma09w2437i2adn5y7m8ii"; - }); + src = fetchurl ( + if stdenv.hostPlatform.isLinux then + { + url = "https://zdoom.org/files/fmod/fmodapi${shortVersion}linux.tar.gz"; + sha256 = "047hk92xapwwqj281f4zwl0ih821rrliya70gfj82sdfjh9lz8i1"; + } + else + { + url = "https://zdoom.org/files/fmod/fmodapi${shortVersion}mac-installer.dmg"; + sha256 = "1m1y4cpcwpkl8x31d3s68xzp107f343ma09w2437i2adn5y7m8ii"; + } + ); nativeBuildInputs = [ undmg ]; @@ -24,22 +40,29 @@ stdenv.mkDerivation rec { dontPatchELF = true; dontBuild = true; - installPhase = lib.optionalString stdenv.hostPlatform.isLinux '' - install -Dm755 api/lib/libfmodex${bits}-${version}.so $out/lib/libfmodex-${version}.so - ln -s libfmodex-${version}.so $out/lib/libfmodex.so - patchelf --set-rpath ${libPath} $out/lib/libfmodex.so - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install -D api/lib/libfmodex.dylib $out/lib/libfmodex.dylib - install -D api/lib/libfmodexL.dylib $out/lib/libfmodexL.dylib - '' + '' - cp -r api/inc $out/include - ''; + installPhase = + lib.optionalString stdenv.hostPlatform.isLinux '' + install -Dm755 api/lib/libfmodex${bits}-${version}.so $out/lib/libfmodex-${version}.so + ln -s libfmodex-${version}.so $out/lib/libfmodex.so + patchelf --set-rpath ${libPath} $out/lib/libfmodex.so + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install -D api/lib/libfmodex.dylib $out/lib/libfmodex.dylib + install -D api/lib/libfmodexL.dylib $out/lib/libfmodexL.dylib + '' + + '' + cp -r api/inc $out/include + ''; meta = with lib; { description = "Programming library and toolkit for the creation and playback of interactive audio"; - homepage = "http://www.fmod.org/"; - license = licenses.unfreeRedistributable; - platforms = [ "x86_64-linux" "i686-linux" "x86_64-darwin" ]; + homepage = "http://www.fmod.org/"; + license = licenses.unfreeRedistributable; + platforms = [ + "x86_64-linux" + "i686-linux" + "x86_64-darwin" + ]; maintainers = [ maintainers.lassulus ]; }; } diff --git a/pkgs/games/doom-ports/zandronum/sqlite.nix b/pkgs/games/doom-ports/zandronum/sqlite.nix index e6c8585cb541a9..6565ff2f542a6b 100644 --- a/pkgs/games/doom-ports/zandronum/sqlite.nix +++ b/pkgs/games/doom-ports/zandronum/sqlite.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchurl +{ + lib, + stdenv, + fetchurl, }: stdenv.mkDerivation { diff --git a/pkgs/games/doom-ports/zdoom/bcc-git.nix b/pkgs/games/doom-ports/zdoom/bcc-git.nix index 5263ef9bac32d6..3c78b892970cc4 100644 --- a/pkgs/games/doom-ports/zdoom/bcc-git.nix +++ b/pkgs/games/doom-ports/zdoom/bcc-git.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "doom-bcc"; @@ -12,7 +16,7 @@ stdenv.mkDerivation { }; enableParallelBuilding = true; - makeFlags = ["CC=${stdenv.cc.targetPrefix}cc"]; + makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" ]; patches = [ ./bcc-warning-fix.patch ]; @@ -28,6 +32,6 @@ stdenv.mkDerivation { mainProgram = "bcc"; homepage = "https://github.com/wormt/bcc"; license = licenses.mit; - maintainers = with maintainers; [ertes]; + maintainers = with maintainers; [ ertes ]; }; } diff --git a/pkgs/games/doom-ports/zdoom/default.nix b/pkgs/games/doom-ports/zdoom/default.nix index 3a31f8fdfb5f6f..d34f4498c5d6d8 100644 --- a/pkgs/games/doom-ports/zdoom/default.nix +++ b/pkgs/games/doom-ports/zdoom/default.nix @@ -1,6 +1,20 @@ -{ lib, stdenv, fetchurl, p7zip, cmake -, SDL2, openal, fluidsynth, soundfont-fluid, bzip2, zlib, libjpeg, game-music-emu -, libsndfile, mpg123 }: +{ + lib, + stdenv, + fetchurl, + p7zip, + cmake, + SDL2, + openal, + fluidsynth, + soundfont-fluid, + bzip2, + zlib, + libjpeg, + game-music-emu, + libsndfile, + mpg123, +}: stdenv.mkDerivation rec { pname = "zdoom"; @@ -12,9 +26,20 @@ stdenv.mkDerivation rec { sha256 = "0453fqrh9l00xwphfxni5qkf9y134n3s1mr1dvi5cbkxcva7j8bq"; }; - nativeBuildInputs = [ p7zip cmake ]; + nativeBuildInputs = [ + p7zip + cmake + ]; buildInputs = [ - SDL2 openal fluidsynth bzip2 zlib libjpeg game-music-emu libsndfile mpg123 + SDL2 + openal + fluidsynth + bzip2 + zlib + libjpeg + game-music-emu + libsndfile + mpg123 ]; cmakeFlags = [ @@ -25,7 +50,10 @@ stdenv.mkDerivation rec { sourceRoot = "."; - NIX_CFLAGS_LINK = [ "-lopenal" "-lfluidsynth" ]; + NIX_CFLAGS_LINK = [ + "-lopenal" + "-lfluidsynth" + ]; preConfigure = '' sed -i \ @@ -52,4 +80,3 @@ stdenv.mkDerivation rec { maintainers = with maintainers; [ lassulus ]; }; } - diff --git a/pkgs/games/doom-ports/zdoom/zdbsp.nix b/pkgs/games/doom-ports/zdoom/zdbsp.nix index 8949febdefea38..bef477e1fc1524 100644 --- a/pkgs/games/doom-ports/zdoom/zdbsp.nix +++ b/pkgs/games/doom-ports/zdoom/zdbsp.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchzip -, cmake -, zlib +{ + lib, + stdenv, + fetchzip, + cmake, + zlib, }: stdenv.mkDerivation rec { @@ -32,7 +33,10 @@ stdenv.mkDerivation rec { description = "ZDoom's internal node builder for DOOM maps"; mainProgram = "zdbsp"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ lassulus siraben ]; + maintainers = with maintainers; [ + lassulus + siraben + ]; platforms = platforms.unix; }; } diff --git a/pkgs/games/duckmarines/default.nix b/pkgs/games/duckmarines/default.nix index a4e37081ab0ea9..36fdccc01c5ab1 100644 --- a/pkgs/games/duckmarines/default.nix +++ b/pkgs/games/duckmarines/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, love, lua, makeWrapper, makeDesktopItem }: +{ + lib, + stdenv, + fetchurl, + love, + lua, + makeWrapper, + makeDesktopItem, +}: stdenv.mkDerivation rec { pname = "duckmarines"; @@ -25,12 +33,14 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ lua love ]; + buildInputs = [ + lua + love + ]; dontUnpack = true; - installPhase = - '' + installPhase = '' mkdir -p $out/bin mkdir -p $out/share/games/lovegames @@ -47,7 +57,7 @@ stdenv.mkDerivation rec { description = "Duck-themed action puzzle video game"; maintainers = with maintainers; [ leenaars ]; platforms = platforms.linux; - hydraPlatforms = []; + hydraPlatforms = [ ]; license = licenses.free; downloadPage = "http://tangramgames.dk/games/duckmarines"; }; diff --git a/pkgs/games/dwarf-fortress/game.nix b/pkgs/games/dwarf-fortress/game.nix index 40a84886d8472e..927c501bb41365 100644 --- a/pkgs/games/dwarf-fortress/game.nix +++ b/pkgs/games/dwarf-fortress/game.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, fetchurl -, SDL -, SDL2 -, SDL2_image -, SDL2_mixer -, fmodex -, dwarf-fortress-unfuck -, autoPatchelfHook +{ + stdenv, + lib, + fetchurl, + SDL, + SDL2, + SDL2_image, + SDL2_mixer, + fmodex, + dwarf-fortress-unfuck, + autoPatchelfHook, # Our own "unfuck" libs for macOS -, ncurses -, gcc + ncurses, + gcc, -, dfVersion -, df-hashes + dfVersion, + df-hashes, }: let @@ -46,31 +47,40 @@ let }; dfVersionTuple = splitVersion dfVersion; - dfVersionBaseIndex = let - x = (builtins.length dfVersionTuple) - 2; - in if x >= 0 then x else 0; + dfVersionBaseIndex = + let + x = (builtins.length dfVersionTuple) - 2; + in + if x >= 0 then x else 0; baseVersion = toInt (elemAt dfVersionTuple dfVersionBaseIndex); patchVersion = elemAt dfVersionTuple (dfVersionBaseIndex + 1); isAtLeast50 = baseVersion >= 50; - enableUnfuck = !isAtLeast50 && dwarf-fortress-unfuck != null && (dwarf-fortress-unfuck.dfVersion or null) == dfVersion; + enableUnfuck = + !isAtLeast50 + && dwarf-fortress-unfuck != null + && (dwarf-fortress-unfuck.dfVersion or null) == dfVersion; game = - if hasAttr dfVersion df-hashes - then getAttr dfVersion df-hashes - else throw "Unknown Dwarf Fortress version: ${dfVersion}"; + if hasAttr dfVersion df-hashes then + getAttr dfVersion df-hashes + else + throw "Unknown Dwarf Fortress version: ${dfVersion}"; dfPlatform = - if hasAttr stdenv.hostPlatform.system platforms - then getAttr stdenv.hostPlatform.system platforms - else throw "Unsupported system: ${stdenv.hostPlatform.system}"; + if hasAttr stdenv.hostPlatform.system platforms then + getAttr stdenv.hostPlatform.system platforms + else + throw "Unsupported system: ${stdenv.hostPlatform.system}"; sha256 = - if hasAttr dfPlatform game - then getAttr dfPlatform game - else throw "Unsupported dfPlatform: ${dfPlatform}"; - exe = if stdenv.hostPlatform.isLinux then - if baseVersion >= 50 then "dwarfort" else "libs/Dwarf_Fortress" - else - "dwarfort.exe"; + if hasAttr dfPlatform game then + getAttr dfPlatform game + else + throw "Unsupported dfPlatform: ${dfPlatform}"; + exe = + if stdenv.hostPlatform.isLinux then + if baseVersion >= 50 then "dwarfort" else "libs/Dwarf_Fortress" + else + "dwarfort.exe"; in stdenv.mkDerivation { @@ -86,9 +96,12 @@ stdenv.mkDerivation { postUnpack = '' directory=${ - if stdenv.hostPlatform.isLinux then "df_linux" - else if stdenv.hostPlatform.isDarwin then "df_osx" - else throw "Unsupported system" + if stdenv.hostPlatform.isLinux then + "df_linux" + else if stdenv.hostPlatform.isDarwin then + "df_osx" + else + throw "Unsupported system" } if [ -d "$directory" ]; then mv "$directory/"* . @@ -96,54 +109,62 @@ stdenv.mkDerivation { ''; nativeBuildInputs = optional stdenv.hostPlatform.isLinux autoPatchelfHook; - buildInputs = optionals isAtLeast50 [ SDL2 SDL2_image SDL2_mixer ] + buildInputs = + optionals isAtLeast50 [ + SDL2 + SDL2_image + SDL2_mixer + ] ++ optional (!isAtLeast50) SDL ++ optional enableUnfuck dwarf-fortress-unfuck ++ [ (lib.getLib stdenv.cc.cc) ]; - installPhase = '' - runHook preInstall - - exe=$out/${exe} - mkdir -p $out - cp -r * $out - - # Clean up OS X detritus in the tarball. - find $out -type f -name '._*' -exec rm -rf {} \; - - # Lots of files are +x in the newer releases... - find $out -type d -exec chmod 0755 {} \; - find $out -type f -exec chmod 0644 {} \; - chmod +x $exe - [ -f $out/df ] && chmod +x $out/df - [ -f $out/run_df ] && chmod +x $out/run_df - - # We don't need any of these since they will just break autoPatchelf on $out/hash.md5.orig - echo "Original MD5: $(<$out/hash.md5.orig)" >&2 - '' + optionalString stdenv.hostPlatform.isDarwin '' - # My custom unfucked dwarfort.exe for macOS. Can't use - # absolute paths because original doesn't have enough - # header space. Someone plz break into Tarn's house & put - # -headerpad_max_install_names into his LDFLAGS. - - ln -s ${getLib ncurses}/lib/libncurses.dylib $out/libs - ln -s ${getLib gcc.cc}/lib/libstdc++.6.dylib $out/libs - ln -s ${getLib gcc.cc}/lib/libgcc_s.1.dylib $out/libs - ln -s ${getLib fmodex}/lib/libfmodex.dylib $out/libs - - install_name_tool \ - -change /usr/lib/libncurses.5.4.dylib \ - @executable_path/libs/libncurses.dylib \ - -change /usr/local/lib/x86_64/libstdc++.6.dylib \ - @executable_path/libs/libstdc++.6.dylib \ - $exe - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + + exe=$out/${exe} + mkdir -p $out + cp -r * $out + + # Clean up OS X detritus in the tarball. + find $out -type f -name '._*' -exec rm -rf {} \; + + # Lots of files are +x in the newer releases... + find $out -type d -exec chmod 0755 {} \; + find $out -type f -exec chmod 0644 {} \; + chmod +x $exe + [ -f $out/df ] && chmod +x $out/df + [ -f $out/run_df ] && chmod +x $out/run_df + + # We don't need any of these since they will just break autoPatchelf on $out/hash.md5.orig + echo "Original MD5: $(<$out/hash.md5.orig)" >&2 + '' + + optionalString stdenv.hostPlatform.isDarwin '' + # My custom unfucked dwarfort.exe for macOS. Can't use + # absolute paths because original doesn't have enough + # header space. Someone plz break into Tarn's house & put + # -headerpad_max_install_names into his LDFLAGS. + + ln -s ${getLib ncurses}/lib/libncurses.dylib $out/libs + ln -s ${getLib gcc.cc}/lib/libstdc++.6.dylib $out/libs + ln -s ${getLib gcc.cc}/lib/libgcc_s.1.dylib $out/libs + ln -s ${getLib fmodex}/lib/libfmodex.dylib $out/libs + + install_name_tool \ + -change /usr/lib/libncurses.5.4.dylib \ + @executable_path/libs/libncurses.dylib \ + -change /usr/local/lib/x86_64/libstdc++.6.dylib \ + @executable_path/libs/libstdc++.6.dylib \ + $exe + '' + + '' + runHook postInstall + ''; preFixup = '' recompute_hash() { @@ -158,7 +179,12 @@ stdenv.mkDerivation { ''; passthru = { - inherit baseVersion patchVersion dfVersion exe; + inherit + baseVersion + patchVersion + dfVersion + exe + ; updateScript = ./update.sh; }; @@ -167,7 +193,15 @@ stdenv.mkDerivation { homepage = "https://www.bay12games.com/dwarves/"; license = licenses.unfreeRedistributable; platforms = attrNames platforms; - maintainers = with maintainers; [ a1russell robbinch roconnor abbradar numinit shazow ncfavier ]; + maintainers = with maintainers; [ + a1russell + robbinch + roconnor + abbradar + numinit + shazow + ncfavier + ]; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; }; } diff --git a/pkgs/games/dwarf-fortress/lazy-pack.nix b/pkgs/games/dwarf-fortress/lazy-pack.nix index eef830965eb4e1..732c1019bf123c 100644 --- a/pkgs/games/dwarf-fortress/lazy-pack.nix +++ b/pkgs/games/dwarf-fortress/lazy-pack.nix @@ -1,28 +1,29 @@ -{ stdenvNoCC -, lib -, buildEnv -, df-games -, themes -, latestVersion -, versionToName -, dfVersion ? latestVersion +{ + stdenvNoCC, + lib, + buildEnv, + df-games, + themes, + latestVersion, + versionToName, + dfVersion ? latestVersion, # This package should, at any given time, provide an opinionated "optimal" # DF experience. It's the equivalent of the Lazy Newbie Pack, that is, and # should contain every utility available unless you disable them. -, enableDFHack ? stdenvNoCC.hostPlatform.isLinux -, enableTWBT ? enableDFHack -, enableSoundSense ? true -, enableStoneSense ? true -, enableDwarfTherapist ? true -, enableLegendsBrowser ? true -, legends-browser -, theme ? themes.phoebus + enableDFHack ? stdenvNoCC.hostPlatform.isLinux, + enableTWBT ? enableDFHack, + enableSoundSense ? true, + enableStoneSense ? true, + enableDwarfTherapist ? true, + enableLegendsBrowser ? true, + legends-browser, + theme ? themes.phoebus, # General config options: -, enableIntro ? true -, enableTruetype ? null # defaults to 24, see init.txt -, enableFPS ? false -, enableTextMode ? false -, enableSound ? true + enableIntro ? true, + enableTruetype ? null, # defaults to 24, see init.txt + enableFPS ? false, + enableTextMode ? false, + enableSound ? true, }: let @@ -37,28 +38,43 @@ let dfGame = versionToName dfVersion; dwarf-fortress = - if hasAttr dfGame df-games - then getAttr dfGame df-games - else throw "Unknown Dwarf Fortress version: ${dfVersion}"; + if hasAttr dfGame df-games then + getAttr dfGame df-games + else + throw "Unknown Dwarf Fortress version: ${dfVersion}"; dwarf-therapist = dwarf-fortress.dwarf-therapist; mainProgram = if enableDFHack then "dfhack" else "dwarf-fortress"; in buildEnv { name = "dwarf-fortress-full"; - paths = [ - (dwarf-fortress.override { - inherit enableDFHack enableTWBT enableSoundSense enableStoneSense theme - enableIntro enableTruetype enableFPS enableTextMode enableSound; - }) - ] - ++ optional enableDwarfTherapist dwarf-therapist - ++ optional enableLegendsBrowser legends-browser; + paths = + [ + (dwarf-fortress.override { + inherit + enableDFHack + enableTWBT + enableSoundSense + enableStoneSense + theme + enableIntro + enableTruetype + enableFPS + enableTextMode + enableSound + ; + }) + ] + ++ optional enableDwarfTherapist dwarf-therapist + ++ optional enableLegendsBrowser legends-browser; meta = { inherit mainProgram; description = "Opinionated wrapper for Dwarf Fortress"; - maintainers = with maintainers; [ Baughn numinit ]; + maintainers = with maintainers; [ + Baughn + numinit + ]; license = licenses.mit; platforms = platforms.all; homepage = "https://github.com/NixOS/nixpkgs/"; diff --git a/pkgs/games/dwarf-fortress/soundsense.nix b/pkgs/games/dwarf-fortress/soundsense.nix index 8ed1e7be1b2027..2ec8361a20f545 100644 --- a/pkgs/games/dwarf-fortress/soundsense.nix +++ b/pkgs/games/dwarf-fortress/soundsense.nix @@ -1,7 +1,8 @@ -{ stdenv -, fetchzip -, dos2unix -, soundPack ? stdenv.mkDerivation { +{ + stdenv, + fetchzip, + dos2unix, + soundPack ? stdenv.mkDerivation { name = "soundsense-soundpack"; src = fetchzip { url = "http://df.zweistein.cz/soundsense/soundpack.zip"; @@ -10,7 +11,7 @@ installPhase = '' cp -r . $out ''; - } + }, }: stdenv.mkDerivation rec { diff --git a/pkgs/games/dwarf-fortress/themes/default.nix b/pkgs/games/dwarf-fortress/themes/default.nix index 279c816211ee19..befcd224a060be 100644 --- a/pkgs/games/dwarf-fortress/themes/default.nix +++ b/pkgs/games/dwarf-fortress/themes/default.nix @@ -11,8 +11,8 @@ let ; in -listToAttrs (map - (v: { +listToAttrs ( + map (v: { inherit (v) name; value = fetchFromGitHub { name = "${v.name}-theme-${v.version}"; @@ -22,9 +22,12 @@ listToAttrs (map sha256 = v.sha256; meta = { platforms = platforms.all; - maintainers = [ maintainers.matthewbauer maintainers.shazow ]; + maintainers = [ + maintainers.matthewbauer + maintainers.shazow + ]; license = licenses.unfree; }; }; - }) - (importJSON ./themes.json)) + }) (importJSON ./themes.json) +) diff --git a/pkgs/games/dwarf-fortress/twbt/default.nix b/pkgs/games/dwarf-fortress/twbt/default.nix index 82b03dd1e0d726..7b56ab310e8b29 100644 --- a/pkgs/games/dwarf-fortress/twbt/default.nix +++ b/pkgs/games/dwarf-fortress/twbt/default.nix @@ -1,8 +1,9 @@ -{ stdenvNoCC -, lib -, fetchurl -, unzip -, dfVersion +{ + stdenvNoCC, + lib, + fetchurl, + unzip, + dfVersion, }: let @@ -50,9 +51,10 @@ let }; release = - if hasAttr dfVersion twbt-releases - then getAttr dfVersion twbt-releases - else throw "[TWBT] Unsupported Dwarf Fortress version: ${dfVersion}"; + if hasAttr dfVersion twbt-releases then + getAttr dfVersion twbt-releases + else + throw "[TWBT] Unsupported Dwarf Fortress version: ${dfVersion}"; in stdenvNoCC.mkDerivation rec { @@ -70,7 +72,11 @@ stdenvNoCC.mkDerivation rec { sourceRoot = "."; - outputs = [ "lib" "art" "out" ]; + outputs = [ + "lib" + "art" + "out" + ]; nativeBuildInputs = [ unzip ]; @@ -87,7 +93,10 @@ stdenvNoCC.mkDerivation rec { meta = { description = "Plugin for Dwarf Fortress / DFHack that improves various aspects of the game interface"; - maintainers = with maintainers; [ Baughn numinit ]; + maintainers = with maintainers; [ + Baughn + numinit + ]; license = licenses.mit; platforms = platforms.linux; homepage = "https://github.com/mifki/df-twbt"; diff --git a/pkgs/games/dwarf-fortress/unfuck.nix b/pkgs/games/dwarf-fortress/unfuck.nix index a1baa2d83f757b..b04c2132cec6ac 100644 --- a/pkgs/games/dwarf-fortress/unfuck.nix +++ b/pkgs/games/dwarf-fortress/unfuck.nix @@ -1,23 +1,24 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, cmake -, libGL -, libSM -, SDL -, SDL_image -, SDL_ttf -, glew -, openalSoft -, ncurses -, glib -, gtk2 -, gtk3 -, libsndfile -, zlib -, dfVersion -, pkg-config +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + cmake, + libGL, + libSM, + SDL, + SDL_image, + SDL_ttf, + glew, + openalSoft, + ncurses, + glib, + gtk2, + gtk3, + libsndfile, + zlib, + dfVersion, + pkg-config, }: let @@ -74,9 +75,10 @@ let }; release = - if hasAttr dfVersion unfuck-releases - then getAttr dfVersion unfuck-releases - else throw "[unfuck] Unknown Dwarf Fortress version: ${dfVersion}"; + if hasAttr dfVersion unfuck-releases then + getAttr dfVersion unfuck-releases + else + throw "[unfuck] Unknown Dwarf Fortress version: ${dfVersion}"; in stdenv.mkDerivation { @@ -90,13 +92,13 @@ stdenv.mkDerivation { inherit (release) hash; }; - patches = lib.optionals (versionOlder release.unfuckRelease "0.47.05") [( - fetchpatch { + patches = lib.optionals (versionOlder release.unfuckRelease "0.47.05") [ + (fetchpatch { name = "fix-noreturn-returning.patch"; url = "https://github.com/svenstaro/dwarf_fortress_unfuck/commit/6dcfe5ae869fddd51940c6c37a95f7bc639f4389.patch"; hash = "sha256-b9eI3iR7dmFqCrktPyn6QJ9U2A/7LvfYRS+vE3BOaqk="; - } - )]; + }) + ]; postPatch = '' # https://github.com/svenstaro/dwarf_fortress_unfuck/pull/27 @@ -108,25 +110,34 @@ stdenv.mkDerivation { "-DGTK2_GDKCONFIG_INCLUDE_DIR=${gtk2.out}/lib/gtk-2.0/include" ]; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ - libSM - SDL - SDL_image - SDL_ttf - glew - openalSoft - ncurses - libsndfile - zlib - libGL - ] - # switched to gtk3 in 0.47.05 - ++ (if versionOlder release.unfuckRelease "0.47.05" then [ - gtk2 - ] else [ - gtk3 - ]); + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = + [ + libSM + SDL + SDL_image + SDL_ttf + glew + openalSoft + ncurses + libsndfile + zlib + libGL + ] + # switched to gtk3 in 0.47.05 + ++ ( + if versionOlder release.unfuckRelease "0.47.05" then + [ + gtk2 + ] + else + [ + gtk3 + ] + ); # Don't strip unused symbols; dfhack hooks into some of them. dontStrip = true; @@ -145,6 +156,9 @@ stdenv.mkDerivation { homepage = "https://github.com/svenstaro/dwarf_fortress_unfuck"; license = licenses.free; platforms = platforms.linux; - maintainers = with maintainers; [ abbradar numinit ]; + maintainers = with maintainers; [ + abbradar + numinit + ]; }; } diff --git a/pkgs/games/dwarf-fortress/wrapper/default.nix b/pkgs/games/dwarf-fortress/wrapper/default.nix index 268a5c1f5da535..b1a6555f6cb430 100644 --- a/pkgs/games/dwarf-fortress/wrapper/default.nix +++ b/pkgs/games/dwarf-fortress/wrapper/default.nix @@ -1,36 +1,37 @@ -{ stdenv -, lib -, buildEnv -, substituteAll -, makeWrapper -, runCommand -, coreutils -, gawk -, dwarf-fortress -, dwarf-therapist -, enableDFHack ? false -, dfhack -, enableSoundSense ? false -, soundSense -, jdk -, expect -, xvfb-run -, writeText -, enableStoneSense ? false -, enableTWBT ? false -, twbt -, themes ? { } -, theme ? null -, extraPackages ? [ ] +{ + stdenv, + lib, + buildEnv, + substituteAll, + makeWrapper, + runCommand, + coreutils, + gawk, + dwarf-fortress, + dwarf-therapist, + enableDFHack ? false, + dfhack, + enableSoundSense ? false, + soundSense, + jdk, + expect, + xvfb-run, + writeText, + enableStoneSense ? false, + enableTWBT ? false, + twbt, + themes ? { }, + theme ? null, + extraPackages ? [ ], # General config options: -, enableIntro ? true -, enableTruetype ? null # defaults to 24, see init.txt -, enableFPS ? false -, enableTextMode ? false -, enableSound ? true -# An attribute set of settings to override in data/init/*.txt. -# For example, `init.FOO = true;` is translated to `[FOO:YES]` in init.txt -, settings ? { } + enableIntro ? true, + enableTruetype ? null, # defaults to 24, see init.txt + enableFPS ? false, + enableTextMode ? false, + enableSound ? true, + # An attribute set of settings to override in data/init/*.txt. + # For example, `init.FOO = true;` is translated to `[FOO:YES]` in init.txt + settings ? { }, # TODO world-gen.txt, interface.txt require special logic }: @@ -44,21 +45,22 @@ let # If TWBT is null or the dfVersion is wrong, it isn't supported (for example, on version 50). enableTWBT' = enableTWBT && twbt != null && (twbt.dfVersion or null) == dwarf-fortress.version; - ptheme = - if builtins.isString theme - then builtins.getAttr theme themes - else theme; + ptheme = if builtins.isString theme then builtins.getAttr theme themes else theme; baseEnv = buildEnv { name = "dwarf-fortress-base-env-${dwarf-fortress.dfVersion}"; # These are in inverse order for first packages to override the next ones. - paths = extraPackages - ++ lib.optional (theme != null) ptheme - ++ lib.optional enableDFHack dfhack' - ++ lib.optional enableSoundSense soundSense - ++ lib.optionals enableTWBT' [ twbt.lib twbt.art ] - ++ [ dwarf-fortress ]; + paths = + extraPackages + ++ lib.optional (theme != null) ptheme + ++ lib.optional enableDFHack dfhack' + ++ lib.optional enableSoundSense soundSense + ++ lib.optionals enableTWBT' [ + twbt.lib + twbt.art + ] + ++ [ dwarf-fortress ]; ignoreCollisions = true; }; @@ -66,10 +68,14 @@ let settings' = lib.recursiveUpdate { init = { PRINT_MODE = - if enableTextMode then "TEXT" - else if enableTWBT' then "TWBT" - else if stdenv.hostPlatform.isDarwin then "STANDARD" # https://www.bay12games.com/dwarves/mantisbt/view.php?id=11680 - else null; + if enableTextMode then + "TEXT" + else if enableTWBT' then + "TWBT" + else if stdenv.hostPlatform.isDarwin then + "STANDARD" # https://www.bay12games.com/dwarves/mantisbt/view.php?id=11680 + else + null; INTRO = enableIntro; TRUETYPE = enableTruetype; FPS = enableFPS; @@ -79,173 +85,234 @@ let forEach = attrs: f: lib.concatStrings (lib.mapAttrsToList f attrs); - toTxt = v: - if lib.isBool v then if v then "YES" else "NO" - else if lib.isInt v then toString v - else if lib.isString v then v - else throw "dwarf-fortress: unsupported configuration value ${toString v}"; - - config = runCommand "dwarf-fortress-config" { - nativeBuildInputs = [ gawk makeWrapper ]; - } ('' - mkdir -p $out/data/init - - edit_setting() { - v=''${v//'&'/'\&'} - if [ -f "$out/$file" ]; then - if ! gawk -i inplace -v RS='\r?\n' ' - { n += sub("\\[" ENVIRON["k"] ":[^]]*\\]", "[" ENVIRON["k"] ":" ENVIRON["v"] "]"); print } - END { exit(!n) } - ' "$out/$file"; then - echo "error: no setting named '$k' in $out/$file" >&2 - exit 1 - fi - else - echo "warning: no file $out/$file; cannot edit" >&2 - fi - } - '' + forEach settings' (file: kv: '' - file=data/init/${lib.escapeShellArg file}.txt - if [ -f "${baseEnv}/$file" ]; then - cp "${baseEnv}/$file" "$out/$file" + toTxt = + v: + if lib.isBool v then + if v then "YES" else "NO" + else if lib.isInt v then + toString v + else if lib.isString v then + v else - echo "warning: no file ${baseEnv}/$file; cannot copy" >&2 - fi - '' + forEach kv (k: v: lib.optionalString (v != null) '' - export k=${lib.escapeShellArg k} v=${lib.escapeShellArg (toTxt v)} - edit_setting - '')) + lib.optionalString enableDFHack '' - mkdir -p $out/hack - - # Patch the MD5 - orig_md5=$(< "${dwarf-fortress}/hash.md5.orig") - patched_md5=$(< "${dwarf-fortress}/hash.md5") - input_file="${dfhack'}/hack/symbols.xml" - output_file="$out/hack/symbols.xml" - - echo "[DFHack Wrapper] Fixing Dwarf Fortress MD5:" - echo " Input: $input_file" - echo " Search: $orig_md5" - echo " Output: $output_file" - echo " Replace: $patched_md5" - - substitute "$input_file" "$output_file" --replace-fail "$orig_md5" "$patched_md5" - ''); + throw "dwarf-fortress: unsupported configuration value ${toString v}"; + + config = + runCommand "dwarf-fortress-config" + { + nativeBuildInputs = [ + gawk + makeWrapper + ]; + } + ( + '' + mkdir -p $out/data/init + + edit_setting() { + v=''${v//'&'/'\&'} + if [ -f "$out/$file" ]; then + if ! gawk -i inplace -v RS='\r?\n' ' + { n += sub("\\[" ENVIRON["k"] ":[^]]*\\]", "[" ENVIRON["k"] ":" ENVIRON["v"] "]"); print } + END { exit(!n) } + ' "$out/$file"; then + echo "error: no setting named '$k' in $out/$file" >&2 + exit 1 + fi + else + echo "warning: no file $out/$file; cannot edit" >&2 + fi + } + '' + + forEach settings' ( + file: kv: + '' + file=data/init/${lib.escapeShellArg file}.txt + if [ -f "${baseEnv}/$file" ]; then + cp "${baseEnv}/$file" "$out/$file" + else + echo "warning: no file ${baseEnv}/$file; cannot copy" >&2 + fi + '' + + forEach kv ( + k: v: + lib.optionalString (v != null) '' + export k=${lib.escapeShellArg k} v=${lib.escapeShellArg (toTxt v)} + edit_setting + '' + ) + ) + + lib.optionalString enableDFHack '' + mkdir -p $out/hack + + # Patch the MD5 + orig_md5=$(< "${dwarf-fortress}/hash.md5.orig") + patched_md5=$(< "${dwarf-fortress}/hash.md5") + input_file="${dfhack'}/hack/symbols.xml" + output_file="$out/hack/symbols.xml" + + echo "[DFHack Wrapper] Fixing Dwarf Fortress MD5:" + echo " Input: $input_file" + echo " Search: $orig_md5" + echo " Output: $output_file" + echo " Replace: $patched_md5" + + substitute "$input_file" "$output_file" --replace-fail "$orig_md5" "$patched_md5" + '' + ); # This is a separate environment because the config files to modify may come # from any of the paths in baseEnv. env = buildEnv { name = "dwarf-fortress-env-${dwarf-fortress.dfVersion}"; - paths = [ config baseEnv ]; + paths = [ + config + baseEnv + ]; ignoreCollisions = true; }; in lib.throwIf (enableTWBT' && !enableDFHack) "dwarf-fortress: TWBT requires DFHack to be enabled" -lib.throwIf (enableStoneSense && !enableDFHack) "dwarf-fortress: StoneSense requires DFHack to be enabled" -lib.throwIf (enableTextMode && enableTWBT') "dwarf-fortress: text mode and TWBT are mutually exclusive" - -stdenv.mkDerivation rec { - pname = "dwarf-fortress"; - version = dwarf-fortress.dfVersion; - - dfInit = substituteAll { - name = "dwarf-fortress-init"; - src = ./dwarf-fortress-init.in; - inherit env; - inherit (dwarf-fortress) exe; - stdenv_shell = "${stdenv.shell}"; - cp = "${coreutils}/bin/cp"; - rm = "${coreutils}/bin/rm"; - ln = "${coreutils}/bin/ln"; - cat = "${coreutils}/bin/cat"; - mkdir = "${coreutils}/bin/mkdir"; - printf = "${coreutils}/bin/printf"; - uname = "${coreutils}/bin/uname"; - }; + lib.throwIf + (enableStoneSense && !enableDFHack) + "dwarf-fortress: StoneSense requires DFHack to be enabled" + lib.throwIf + (enableTextMode && enableTWBT') + "dwarf-fortress: text mode and TWBT are mutually exclusive" - runDF = ./dwarf-fortress.in; - runSoundSense = ./soundSense.in; + stdenv.mkDerivation + rec { + pname = "dwarf-fortress"; + version = dwarf-fortress.dfVersion; - passthru = { - inherit dwarf-fortress dwarf-therapist twbt env; - dfhack = dfhack'; - }; + dfInit = substituteAll { + name = "dwarf-fortress-init"; + src = ./dwarf-fortress-init.in; + inherit env; + inherit (dwarf-fortress) exe; + stdenv_shell = "${stdenv.shell}"; + cp = "${coreutils}/bin/cp"; + rm = "${coreutils}/bin/rm"; + ln = "${coreutils}/bin/ln"; + cat = "${coreutils}/bin/cat"; + mkdir = "${coreutils}/bin/mkdir"; + printf = "${coreutils}/bin/printf"; + uname = "${coreutils}/bin/uname"; + }; + + runDF = ./dwarf-fortress.in; + runSoundSense = ./soundSense.in; + + passthru = { + inherit + dwarf-fortress + dwarf-therapist + twbt + env + ; + dfhack = dfhack'; + }; + + dontUnpack = true; + dontBuild = true; + preferLocalBuild = true; + installPhase = + '' + mkdir -p $out/bin + + substitute $runDF $out/bin/dwarf-fortress \ + --subst-var-by stdenv_shell ${stdenv.shell} \ + --subst-var-by dfExe ${dwarf-fortress.exe} \ + --subst-var dfInit + chmod 755 $out/bin/dwarf-fortress + '' + + lib.optionalString enableDFHack '' + substitute $runDF $out/bin/dfhack \ + --subst-var-by stdenv_shell ${stdenv.shell} \ + --subst-var-by dfExe dfhack \ + --subst-var dfInit + chmod 755 $out/bin/dfhack + '' + + lib.optionalString enableSoundSense '' + substitute $runSoundSense $out/bin/soundsense \ + --subst-var-by stdenv_shell ${stdenv.shell} \ + --subst-var-by jre ${jdk.jre} \ + --subst-var dfInit + chmod 755 $out/bin/soundsense + ''; + + doInstallCheck = stdenv.hostPlatform.isLinux; + nativeInstallCheckInputs = lib.optionals stdenv.hostPlatform.isLinux [ + expect + xvfb-run + ]; + + installCheckPhase = + let + commonExpectStatements = + fmod: + lib.optionalString isAtLeast50 '' + expect "Loading audio..." + '' + + lib.optionalString (!fmod && isAtLeast50) '' + expect "Failed to load fmod, trying SDL_mixer" + '' + + lib.optionalString isAtLeast50 '' + expect "Audio loaded successfully!" + '' + + '' + expect "Loading bindings from data/init/interface.txt" + ''; + dfHackExpectScript = writeText "dfhack-test.exp" ( + '' + spawn env NIXPKGS_DF_OPTS=debug xvfb-run $env(out)/bin/dfhack + '' + + commonExpectStatements false + + '' + expect "DFHack is ready. Have a nice day!" + expect "DFHack version ${version}" + expect "\[DFHack\]#" + send -- "lua print(os.getenv('out'))\r" + expect "$env(out)" + # Don't send 'die' here; just exit. Some versions of dfhack crash on exit. + exit 0 + '' + ); + vanillaExpectScript = + fmod: + writeText "vanilla-test.exp" ( + '' + spawn env NIXPKGS_DF_OPTS=debug,${lib.optionalString fmod "fmod"} xvfb-run $env(out)/bin/dwarf-fortress + '' + + commonExpectStatements fmod + + '' + exit 0 + '' + ); + in + '' + export HOME="$(mktemp -dt dwarf-fortress.XXXXXX)" + '' + + lib.optionalString enableDFHack '' + expect ${dfHackExpectScript} + df_home="$(find ~ -name "df_*" | head -n1)" + test -f "$df_home/dfhack" + '' + + lib.optionalString isAtLeast50 '' + expect ${vanillaExpectScript true} + df_home="$(find ~ -name "df_*" | head -n1)" + test ! -f "$df_home/dfhack" + test -f "$df_home/libfmod_plugin.so" + '' + + '' + expect ${vanillaExpectScript false} + df_home="$(find ~ -name "df_*" | head -n1)" + test ! -f "$df_home/dfhack" + test ! -f "$df_home/libfmod_plugin.so" + '' + + '' + test -d "$df_home/data" + ''; - dontUnpack = true; - dontBuild = true; - preferLocalBuild = true; - installPhase = '' - mkdir -p $out/bin - - substitute $runDF $out/bin/dwarf-fortress \ - --subst-var-by stdenv_shell ${stdenv.shell} \ - --subst-var-by dfExe ${dwarf-fortress.exe} \ - --subst-var dfInit - chmod 755 $out/bin/dwarf-fortress - '' + lib.optionalString enableDFHack '' - substitute $runDF $out/bin/dfhack \ - --subst-var-by stdenv_shell ${stdenv.shell} \ - --subst-var-by dfExe dfhack \ - --subst-var dfInit - chmod 755 $out/bin/dfhack - '' + lib.optionalString enableSoundSense '' - substitute $runSoundSense $out/bin/soundsense \ - --subst-var-by stdenv_shell ${stdenv.shell} \ - --subst-var-by jre ${jdk.jre} \ - --subst-var dfInit - chmod 755 $out/bin/soundsense - ''; - - doInstallCheck = stdenv.hostPlatform.isLinux; - nativeInstallCheckInputs = lib.optionals stdenv.hostPlatform.isLinux [ expect xvfb-run ]; - - installCheckPhase = let - commonExpectStatements = fmod: lib.optionalString isAtLeast50 '' - expect "Loading audio..." - '' + lib.optionalString (!fmod && isAtLeast50) '' - expect "Failed to load fmod, trying SDL_mixer" - '' + lib.optionalString isAtLeast50 '' - expect "Audio loaded successfully!" - '' + '' - expect "Loading bindings from data/init/interface.txt" - ''; - dfHackExpectScript = writeText "dfhack-test.exp" ('' - spawn env NIXPKGS_DF_OPTS=debug xvfb-run $env(out)/bin/dfhack - '' + commonExpectStatements false + '' - expect "DFHack is ready. Have a nice day!" - expect "DFHack version ${version}" - expect "\[DFHack\]#" - send -- "lua print(os.getenv('out'))\r" - expect "$env(out)" - # Don't send 'die' here; just exit. Some versions of dfhack crash on exit. - exit 0 - ''); - vanillaExpectScript = fmod: writeText "vanilla-test.exp" ('' - spawn env NIXPKGS_DF_OPTS=debug,${lib.optionalString fmod "fmod"} xvfb-run $env(out)/bin/dwarf-fortress - '' + commonExpectStatements fmod + '' - exit 0 - ''); - in - '' - export HOME="$(mktemp -dt dwarf-fortress.XXXXXX)" - '' + lib.optionalString enableDFHack '' - expect ${dfHackExpectScript} - df_home="$(find ~ -name "df_*" | head -n1)" - test -f "$df_home/dfhack" - '' + lib.optionalString isAtLeast50 '' - expect ${vanillaExpectScript true} - df_home="$(find ~ -name "df_*" | head -n1)" - test ! -f "$df_home/dfhack" - test -f "$df_home/libfmod_plugin.so" - '' + '' - expect ${vanillaExpectScript false} - df_home="$(find ~ -name "df_*" | head -n1)" - test ! -f "$df_home/dfhack" - test ! -f "$df_home/libfmod_plugin.so" - '' + '' - test -d "$df_home/data" - ''; - - inherit (dwarf-fortress) meta; -} + inherit (dwarf-fortress) meta; + } diff --git a/pkgs/games/dxx-rebirth/assets.nix b/pkgs/games/dxx-rebirth/assets.nix index b214d49659b6ec..fb37b540068e6b 100644 --- a/pkgs/games/dxx-rebirth/assets.nix +++ b/pkgs/games/dxx-rebirth/assets.nix @@ -1,55 +1,64 @@ -{ lib, stdenv, requireFile, gogUnpackHook }: +{ + lib, + stdenv, + requireFile, + gogUnpackHook, +}: let - generic = ver: source: let - pname = "descent${toString ver}"; - in stdenv.mkDerivation rec { - name = "${pname}-assets-${version}"; - version = "2.0.0.7"; + generic = + ver: source: + let + pname = "descent${toString ver}"; + in + stdenv.mkDerivation rec { + name = "${pname}-assets-${version}"; + version = "2.0.0.7"; - src = requireFile rec { - name = "setup_descent12_${version}.exe"; - sha256 = "1r1drbfda6czg21f9qqiiwgnkpszxgmcn5bafp5ljddh34swkn3f"; - message = '' - While the Descent ${toString ver} game engine is free, the game assets are not. + src = requireFile rec { + name = "setup_descent12_${version}.exe"; + sha256 = "1r1drbfda6czg21f9qqiiwgnkpszxgmcn5bafp5ljddh34swkn3f"; + message = '' + While the Descent ${toString ver} game engine is free, the game assets are not. - Please purchase the game on gog.com and download the Windows installer. + Please purchase the game on gog.com and download the Windows installer. - Once you have downloaded the file, please use the following command and re-run the - installation: + Once you have downloaded the file, please use the following command and re-run the + installation: - nix-prefetch-url file://\$PWD/${name} - ''; - }; + nix-prefetch-url file://\$PWD/${name} + ''; + }; - nativeBuildInputs = [ gogUnpackHook ]; + nativeBuildInputs = [ gogUnpackHook ]; - dontBuild = true; - dontFixup = true; + dontBuild = true; + dontFixup = true; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $out/share/{games/${pname},doc/${pname}/examples} - pushd "app/${source}" - mv dosbox*.conf $out/share/doc/${pname}/examples - mv *.txt *.pdf $out/share/doc/${pname} - cp -r * $out/share/games/descent${toString ver} - popd + mkdir -p $out/share/{games/${pname},doc/${pname}/examples} + pushd "app/${source}" + mv dosbox*.conf $out/share/doc/${pname}/examples + mv *.txt *.pdf $out/share/doc/${pname} + cp -r * $out/share/games/descent${toString ver} + popd - runHook postInstall - ''; + runHook postInstall + ''; - meta = with lib; { - description = "Descent ${toString ver} assets from GOG"; - homepage = "https://www.dxx-rebirth.com/"; - license = licenses.unfree; - maintainers = with maintainers; [ peterhoeg ]; - hydraPlatforms = []; + meta = with lib; { + description = "Descent ${toString ver} assets from GOG"; + homepage = "https://www.dxx-rebirth.com/"; + license = licenses.unfree; + maintainers = with maintainers; [ peterhoeg ]; + hydraPlatforms = [ ]; + }; }; - }; -in { +in +{ descent1-assets = generic 1 "descent"; descent2-assets = generic 2 "descent 2"; } diff --git a/pkgs/games/dxx-rebirth/default.nix b/pkgs/games/dxx-rebirth/default.nix index 29da6adb5aca9d..dddde9c6cc2743 100644 --- a/pkgs/games/dxx-rebirth/default.nix +++ b/pkgs/games/dxx-rebirth/default.nix @@ -1,16 +1,18 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchurl -, scons -, pkg-config -, SDL2 -, SDL2_image -, SDL2_mixer -, libGLU -, libGL -, libpng -, physfs -, unstableGitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + scons, + pkg-config, + SDL2, + SDL2_image, + SDL2_mixer, + libGLU, + libGL, + libpng, + physfs, + unstableGitUpdater, }: let @@ -31,9 +33,20 @@ stdenv.mkDerivation rec { hash = "sha256-b6N/qkydI56bkCPhTJ5SwB8OdLqEFJhK9WPA4ELB1BI="; }; - nativeBuildInputs = [ pkg-config scons ]; + nativeBuildInputs = [ + pkg-config + scons + ]; - buildInputs = [ libGLU libGL libpng physfs SDL2 SDL2_image SDL2_mixer ]; + buildInputs = [ + libGLU + libGL + libpng + physfs + SDL2 + SDL2_image + SDL2_mixer + ]; enableParallelBuilding = true; @@ -49,7 +62,7 @@ stdenv.mkDerivation rec { install -Dm644 -t $out/share/doc/dxx-rebirth *.txt ''; - passthru.updateScript = unstableGitUpdater {}; + passthru.updateScript = unstableGitUpdater { }; meta = with lib; { description = "Source Port of the Descent 1 and 2 engines"; diff --git a/pkgs/games/dxx-rebirth/full.nix b/pkgs/games/dxx-rebirth/full.nix index f3349c114eed15..1bffa245449b2d 100644 --- a/pkgs/games/dxx-rebirth/full.nix +++ b/pkgs/games/dxx-rebirth/full.nix @@ -1,30 +1,42 @@ -{ lib, stdenv, makeWrapper -, dxx-rebirth, descent1-assets, descent2-assets }: +{ + lib, + stdenv, + makeWrapper, + dxx-rebirth, + descent1-assets, + descent2-assets, +}: let - generic = ver: assets: stdenv.mkDerivation { - name = "d${toString ver}x-rebirth-full-${assets.version}"; + generic = + ver: assets: + stdenv.mkDerivation { + name = "d${toString ver}x-rebirth-full-${assets.version}"; - nativeBuildInputs = [ makeWrapper ]; + nativeBuildInputs = [ makeWrapper ]; - buildCommand = '' - mkdir -p $out/bin + buildCommand = '' + mkdir -p $out/bin - makeWrapper ${dxx-rebirth}/bin/d${toString ver}x-rebirth $out/bin/descent${toString ver} \ - --add-flags "-hogdir ${assets}/share/games/descent${toString ver}" - ''; + makeWrapper ${dxx-rebirth}/bin/d${toString ver}x-rebirth $out/bin/descent${toString ver} \ + --add-flags "-hogdir ${assets}/share/games/descent${toString ver}" + ''; - meta = with lib; { - description = "Descent ${toString ver} using the DXX-Rebirth project engine and game assets from GOG"; - homepage = "https://www.dxx-rebirth.com/"; - license = with licenses; [ free unfree ]; - maintainers = with maintainers; [ peterhoeg ]; - platforms = with platforms; linux; - hydraPlatforms = []; + meta = with lib; { + description = "Descent ${toString ver} using the DXX-Rebirth project engine and game assets from GOG"; + homepage = "https://www.dxx-rebirth.com/"; + license = with licenses; [ + free + unfree + ]; + maintainers = with maintainers; [ peterhoeg ]; + platforms = with platforms; linux; + hydraPlatforms = [ ]; + }; }; - }; -in { +in +{ d1x-rebirth-full = generic 1 descent1-assets; d2x-rebirth-full = generic 2 descent2-assets; } diff --git a/pkgs/games/easyrpg-player/default.nix b/pkgs/games/easyrpg-player/default.nix index 558f3755d1cfd0..be92949cb91a6f 100644 --- a/pkgs/games/easyrpg-player/default.nix +++ b/pkgs/games/easyrpg-player/default.nix @@ -1,40 +1,41 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, cmake -, doxygen -, pkg-config -, freetype -, fmt -, glib -, harfbuzz -, liblcf -, libpng -, libsndfile -, libvorbis -, libxmp -, libXcursor -, libXext -, libXi -, libXinerama -, libXrandr -, libXScrnSaver -, libXxf86vm -, mpg123 -, opusfile -, pcre -, pixman -, SDL2 -, speexdsp -, wildmidi -, zlib -, libdecor -, alsa-lib -, asciidoctor -, Foundation -, AudioUnit -, AudioToolbox +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + doxygen, + pkg-config, + freetype, + fmt, + glib, + harfbuzz, + liblcf, + libpng, + libsndfile, + libvorbis, + libxmp, + libXcursor, + libXext, + libXi, + libXinerama, + libXrandr, + libXScrnSaver, + libXxf86vm, + mpg123, + opusfile, + pcre, + pixman, + SDL2, + speexdsp, + wildmidi, + zlib, + libdecor, + alsa-lib, + asciidoctor, + Foundation, + AudioUnit, + AudioToolbox, }: stdenv.mkDerivation rec { @@ -67,39 +68,42 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - fmt - freetype - glib - harfbuzz - liblcf - libpng - libsndfile - libvorbis - libxmp - mpg123 - opusfile - pcre - pixman - SDL2 - speexdsp - zlib - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - libXcursor - libXext - libXi - libXinerama - libXrandr - libXScrnSaver - libXxf86vm - libdecor - wildmidi # until packaged on Darwin - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Foundation - AudioUnit - AudioToolbox - ]; + buildInputs = + [ + fmt + freetype + glib + harfbuzz + liblcf + libpng + libsndfile + libvorbis + libxmp + mpg123 + opusfile + pcre + pixman + SDL2 + speexdsp + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + libXcursor + libXext + libXi + libXinerama + libXrandr + libXScrnSaver + libXxf86vm + libdecor + wildmidi # until packaged on Darwin + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Foundation + AudioUnit + AudioToolbox + ]; cmakeFlags = [ "-DPLAYER_ENABLE_TESTS=${lib.boolToString doCheck}" diff --git a/pkgs/games/exult/default.nix b/pkgs/games/exult/default.nix index cc32d13617dc19..4f26dbed108a51 100644 --- a/pkgs/games/exult/default.nix +++ b/pkgs/games/exult/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL2 -, autoconf -, autoconf-archive -, autoreconfHook -, automake -, libogg -, libtool -, libvorbis -, pkg-config -, zlib -, enableTools ? false -# Darwin-specific -, AudioUnit +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + autoconf, + autoconf-archive, + autoreconfHook, + automake, + libogg, + libtool, + libvorbis, + pkg-config, + zlib, + enableTools ? false, + # Darwin-specific + AudioUnit, }: stdenv.mkDerivation rec { @@ -42,14 +43,16 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - SDL2 - libogg - libvorbis - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AudioUnit - ]; + buildInputs = + [ + SDL2 + libogg + libvorbis + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AudioUnit + ]; enableParallelBuilding = true; diff --git a/pkgs/games/fallout-ce/build.nix b/pkgs/games/fallout-ce/build.nix index 5f0c0b404f36d5..91792a613d8d6a 100644 --- a/pkgs/games/fallout-ce/build.nix +++ b/pkgs/games/fallout-ce/build.nix @@ -1,16 +1,17 @@ -{ cmake -, fpattern -, lib -, SDL2 -, stdenv -, writeShellScript +{ + cmake, + fpattern, + lib, + SDL2, + stdenv, + writeShellScript, -, extraBuildInputs ? [ ] -, extraMeta -, patches -, pname -, version -, src + extraBuildInputs ? [ ], + extraMeta, + patches, + pname, + version, + src, }: let @@ -46,7 +47,12 @@ let ''; in stdenv.mkDerivation { - inherit pname version src patches; + inherit + pname + version + src + patches + ; nativeBuildInputs = [ cmake ]; buildInputs = [ SDL2 ] ++ extraBuildInputs; @@ -70,9 +76,12 @@ stdenv.mkDerivation { runHook postInstall ''; - meta = with lib; { - license = licenses.sustainableUse; - maintainers = with maintainers; [ hughobrien ]; - platforms = platforms.linux; - } // extraMeta; + meta = + with lib; + { + license = licenses.sustainableUse; + maintainers = with maintainers; [ hughobrien ]; + platforms = platforms.linux; + } + // extraMeta; } diff --git a/pkgs/games/fallout-ce/fallout-ce.nix b/pkgs/games/fallout-ce/fallout-ce.nix index 2c30d62bb77ff5..6754fad6a1b50f 100644 --- a/pkgs/games/fallout-ce/fallout-ce.nix +++ b/pkgs/games/fallout-ce/fallout-ce.nix @@ -1,6 +1,7 @@ -{ callPackage -, fetchFromGitHub -, fetchpatch2 +{ + callPackage, + fetchFromGitHub, + fetchpatch2, }: callPackage ./build.nix rec { diff --git a/pkgs/games/fallout-ce/fallout2-ce.nix b/pkgs/games/fallout-ce/fallout2-ce.nix index 09dbd93feb9df8..a1b4f28b1971da 100644 --- a/pkgs/games/fallout-ce/fallout2-ce.nix +++ b/pkgs/games/fallout-ce/fallout2-ce.nix @@ -1,7 +1,8 @@ -{ callPackage -, fetchFromGitHub -, fetchpatch2 -, zlib +{ + callPackage, + fetchFromGitHub, + fetchpatch2, + zlib, }: callPackage ./build.nix rec { diff --git a/pkgs/games/ferium/default.nix b/pkgs/games/ferium/default.nix index 08710c42214da9..1073764cbaeadb 100644 --- a/pkgs/games/ferium/default.nix +++ b/pkgs/games/ferium/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, Security -, SystemConfiguration -, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, + SystemConfiguration, + installShellFiles, }: rustPlatform.buildRustPackage rec { @@ -18,7 +19,10 @@ rustPlatform.buildRustPackage rec { hash = "sha256-eeQjezB6pRdnPADLgDLo8b+bUSP12gfBhFNt/uYCwHU="; }; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Security SystemConfiguration ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + ]; cargoHash = "sha256-yBi6zyljkYEIUvSH4nXMw8fjPnt4kjqiuZ/QLT5IbqQ="; @@ -42,6 +46,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "ferium"; homepage = "https://github.com/gorilla-devs/ferium"; license = licenses.mpl20; - maintainers = with maintainers; [ leo60228 soupglasses ]; + maintainers = with maintainers; [ + leo60228 + soupglasses + ]; }; } diff --git a/pkgs/games/flare/default.nix b/pkgs/games/flare/default.nix index 0e1b4571e5ce9a..8dd6c435c1b575 100644 --- a/pkgs/games/flare/default.nix +++ b/pkgs/games/flare/default.nix @@ -1,11 +1,17 @@ -{ lib, buildEnv, callPackage, makeWrapper, Cocoa }: +{ + lib, + buildEnv, + callPackage, + makeWrapper, + Cocoa, +}: buildEnv { name = "flare-1.14"; paths = [ (callPackage ./engine.nix { inherit Cocoa; }) - (callPackage ./game.nix {}) + (callPackage ./game.nix { }) ]; nativeBuildInputs = [ makeWrapper ]; @@ -18,8 +24,14 @@ buildEnv { description = "Fantasy action RPG using the FLARE engine"; mainProgram = "flare"; homepage = "https://flarerpg.org/"; - maintainers = with maintainers; [ aanderse McSinyx ]; - license = [ licenses.gpl3 licenses.cc-by-sa-30 ]; + maintainers = with maintainers; [ + aanderse + McSinyx + ]; + license = [ + licenses.gpl3 + licenses.cc-by-sa-30 + ]; platforms = platforms.unix; }; } diff --git a/pkgs/games/flare/engine.nix b/pkgs/games/flare/engine.nix index b404e8ecfcd033..8d4069874bd6d4 100644 --- a/pkgs/games/flare/engine.nix +++ b/pkgs/games/flare/engine.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, cmake, SDL2, SDL2_image, SDL2_mixer, SDL2_ttf, Cocoa }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + SDL2, + SDL2_image, + SDL2_mixer, + SDL2_ttf, + Cocoa, +}: stdenv.mkDerivation rec { pname = "flare-engine"; @@ -14,13 +24,20 @@ stdenv.mkDerivation rec { patches = [ ./desktop.patch ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ SDL2 SDL2_image SDL2_mixer SDL2_ttf ] - ++ lib.optional stdenv.hostPlatform.isDarwin Cocoa; + buildInputs = [ + SDL2 + SDL2_image + SDL2_mixer + SDL2_ttf + ] ++ lib.optional stdenv.hostPlatform.isDarwin Cocoa; meta = with lib; { description = "Free/Libre Action Roleplaying Engine"; homepage = "https://github.com/flareteam/flare-engine"; - maintainers = with maintainers; [ aanderse McSinyx ]; + maintainers = with maintainers; [ + aanderse + McSinyx + ]; license = [ licenses.gpl3 ]; platforms = platforms.unix; }; diff --git a/pkgs/games/flare/game.nix b/pkgs/games/flare/game.nix index 8cfe40dc22b5e1..74dbcaaaae318e 100644 --- a/pkgs/games/flare/game.nix +++ b/pkgs/games/flare/game.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, cmake }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, +}: stdenv.mkDerivation rec { pname = "flare-game"; @@ -16,7 +21,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Fantasy action RPG using the FLARE engine"; homepage = "https://github.com/flareteam/flare-game"; - maintainers = with maintainers; [ aanderse McSinyx ]; + maintainers = with maintainers; [ + aanderse + McSinyx + ]; license = [ licenses.cc-by-sa-30 ]; platforms = platforms.unix; }; diff --git a/pkgs/games/flightgear/default.nix b/pkgs/games/flightgear/default.nix index d81b2774b4ae5a..ec9b9358b1559b 100644 --- a/pkgs/games/flightgear/default.nix +++ b/pkgs/games/flightgear/default.nix @@ -1,8 +1,38 @@ -{ lib, stdenv, fetchurl, wrapQtAppsHook -, libglut, freealut, libGLU, libGL, libICE, libjpeg, openal, openscenegraph, plib -, libSM, libunwind, libX11, xorgproto, libXext, libXi -, libXmu, libXt, simgear, zlib, boost, cmake, libpng, udev, fltk13, apr -, makeDesktopItem, qtbase, qtdeclarative, glew, curl +{ + lib, + stdenv, + fetchurl, + wrapQtAppsHook, + libglut, + freealut, + libGLU, + libGL, + libICE, + libjpeg, + openal, + openscenegraph, + plib, + libSM, + libunwind, + libX11, + xorgproto, + libXext, + libXi, + libXmu, + libXt, + simgear, + zlib, + boost, + cmake, + libpng, + udev, + fltk13, + apr, + makeDesktopItem, + qtbase, + qtdeclarative, + glew, + curl, }: let @@ -35,12 +65,39 @@ stdenv.mkDerivation rec { sha256 = "sha256-Fn0I3pzA9yIYs3myPNflbH9u4Y19VZUS2lGjvWfzjm4="; }; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; buildInputs = [ - libglut freealut libGLU libGL libICE libjpeg openal openscenegraph plib - libSM libunwind libX11 xorgproto libXext libXi - libXmu libXt simgear zlib boost libpng udev fltk13 apr qtbase - glew qtdeclarative curl + libglut + freealut + libGLU + libGL + libICE + libjpeg + openal + openscenegraph + plib + libSM + libunwind + libX11 + xorgproto + libXext + libXi + libXmu + libXt + simgear + zlib + boost + libpng + udev + fltk13 + apr + qtbase + glew + qtdeclarative + curl ]; qtWrapperArgs = [ @@ -51,7 +108,7 @@ stdenv.mkDerivation rec { description = "Flight simulator"; maintainers = with maintainers; [ raskin ]; platforms = platforms.linux; - hydraPlatforms = []; # disabled from hydra because it's so big + hydraPlatforms = [ ]; # disabled from hydra because it's so big license = licenses.gpl2Plus; mainProgram = "fgfs"; }; diff --git a/pkgs/games/fltrator/default.nix b/pkgs/games/fltrator/default.nix index c3402eda408271..d1a39f76a13090 100644 --- a/pkgs/games/fltrator/default.nix +++ b/pkgs/games/fltrator/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, unzip, fltk, which, libjpeg }: +{ + lib, + stdenv, + fetchurl, + unzip, + fltk, + which, + libjpeg, +}: stdenv.mkDerivation rec { pname = "fltrator"; @@ -9,8 +17,14 @@ stdenv.mkDerivation rec { sha256 = "125aqq1sfrm0c9cm6gyylwdmc8xrb0rjf563xvw7q28sdbl6ayp7"; }; - buildInputs = [ fltk libjpeg ]; - nativeBuildInputs = [ unzip which ]; + buildInputs = [ + fltk + libjpeg + ]; + nativeBuildInputs = [ + unzip + which + ]; postPatch = '' substituteInPlace src/fltrator.cxx\ @@ -23,7 +37,10 @@ stdenv.mkDerivation rec { dontAddPrefix = true; - makeFlags = [ "HOME=$(out)" "RSC_PATH=$(out)/fltrator"]; + makeFlags = [ + "HOME=$(out)" + "RSC_PATH=$(out)/fltrator" + ]; postInstall = '' mkdir -p $out/share/applications diff --git a/pkgs/games/freeciv/default.nix b/pkgs/games/freeciv/default.nix index 3732f4f3a06e9a..110dd68ace55ff 100644 --- a/pkgs/games/freeciv/default.nix +++ b/pkgs/games/freeciv/default.nix @@ -1,11 +1,35 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, lua5_3, pkg-config, python3 -, zlib, bzip2, curl, xz, gettext, libiconv, icu -, SDL2, SDL2_mixer, SDL2_image, SDL2_ttf, SDL2_gfx, freetype, fluidsynth -, sdl2Client ? false -, gtkClient ? true, gtk3, wrapGAppsHook3 -, qtClient ? false, qt5 -, server ? true, readline -, enableSqlite ? true, sqlite +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + lua5_3, + pkg-config, + python3, + zlib, + bzip2, + curl, + xz, + gettext, + libiconv, + icu, + SDL2, + SDL2_mixer, + SDL2_image, + SDL2_ttf, + SDL2_gfx, + freetype, + fluidsynth, + sdl2Client ? false, + gtkClient ? true, + gtk3, + wrapGAppsHook3, + qtClient ? false, + qt5, + server ? true, + readline, + enableSqlite ? true, + sqlite, }: stdenv.mkDerivation rec { @@ -29,14 +53,36 @@ stdenv.mkDerivation rec { done ''; - nativeBuildInputs = [ autoreconfHook pkg-config ] + nativeBuildInputs = + [ + autoreconfHook + pkg-config + ] ++ lib.optionals qtClient [ qt5.wrapQtAppsHook ] ++ lib.optionals gtkClient [ wrapGAppsHook3 ]; - buildInputs = [ lua5_3 zlib bzip2 curl xz gettext libiconv icu ] - ++ [ SDL2 SDL2_mixer SDL2_image SDL2_ttf SDL2_gfx freetype fluidsynth ] + buildInputs = + [ + lua5_3 + zlib + bzip2 + curl + xz + gettext + libiconv + icu + ] + ++ [ + SDL2 + SDL2_mixer + SDL2_image + SDL2_ttf + SDL2_gfx + freetype + fluidsynth + ] ++ lib.optionals gtkClient [ gtk3 ] - ++ lib.optionals qtClient [ qt5.qtbase ] + ++ lib.optionals qtClient [ qt5.qtbase ] ++ lib.optional server readline ++ lib.optional enableSqlite sqlite; @@ -48,7 +94,8 @@ stdenv.mkDerivation rec { preConfigure = '' export CPPFLAGS="$(echo $SDL2_PATH | sed 's#/nix/store/#-I/nix/store/#g')" ''; - configureFlags = [ "--enable-shared" ] + configureFlags = + [ "--enable-shared" ] ++ lib.optionals sdl2Client [ "--enable-client=sdl2" "--enable-sdl-mixer=sdl2" @@ -57,16 +104,19 @@ stdenv.mkDerivation rec { "--enable-client=qt" "--with-qtver=qt5" "--with-qt5-includes=${qt5.qtbase.dev}/include" - ] ++ lib.optionals gtkClient [ "--enable-client=gtk3.22" ] + ] + ++ lib.optionals gtkClient [ "--enable-client=gtk3.22" ] ++ lib.optional enableSqlite "--enable-fcdb=sqlite3" ++ lib.optional (!gtkClient) "--enable-fcmp=cli" - ++ lib.optional (!server) "--disable-server"; + ++ lib.optional (!server) "--disable-server"; - postFixup = lib.optionalString qtClient '' - wrapQtApp $out/bin/freeciv-qt - '' + lib.optionalString gtkClient '' - wrapGApp $out/bin/freeciv-gtk3.22 - ''; + postFixup = + lib.optionalString qtClient '' + wrapQtApp $out/bin/freeciv-qt + '' + + lib.optionalString gtkClient '' + wrapGApp $out/bin/freeciv-gtk3.22 + ''; enableParallelBuilding = true; diff --git a/pkgs/games/fteqw/default.nix b/pkgs/games/fteqw/default.nix index 1e9a0b09676129..c99c4b28bee5b0 100644 --- a/pkgs/games/fteqw/default.nix +++ b/pkgs/games/fteqw/default.nix @@ -1,90 +1,100 @@ -{ lib -, stdenv -, fetchFromGitHub -, gzip -, libvorbis -, libmad -, SDL2 -, SDL2_mixer -, libpng -, alsa-lib -, gnutls -, zlib -, libjpeg -, vulkan-loader -, vulkan-headers -, speex -, libopus -, xorg -, libGL +{ + lib, + stdenv, + fetchFromGitHub, + gzip, + libvorbis, + libmad, + SDL2, + SDL2_mixer, + libpng, + alsa-lib, + gnutls, + zlib, + libjpeg, + vulkan-loader, + vulkan-headers, + speex, + libopus, + xorg, + libGL, }@attrs: { - fteqw = import ./generic.nix (rec { - pname = "fteqw"; + fteqw = import ./generic.nix ( + rec { + pname = "fteqw"; - buildFlags = [ "m-rel" ]; + buildFlags = [ "m-rel" ]; - nativeBuildInputs = [ - vulkan-headers - ]; + nativeBuildInputs = [ + vulkan-headers + ]; - buildInputs = [ - gzip - libvorbis - libmad - SDL2 - SDL2_mixer - libpng - alsa-lib - gnutls - libjpeg - vulkan-loader - speex - libopus - xorg.libXrandr - xorg.libXcursor - ]; + buildInputs = [ + gzip + libvorbis + libmad + SDL2 + SDL2_mixer + libpng + alsa-lib + gnutls + libjpeg + vulkan-loader + speex + libopus + xorg.libXrandr + xorg.libXcursor + ]; - postFixup = '' - patchelf $out/bin/${pname} \ - --add-needed ${SDL2}/lib/libSDL2.so \ - --add-needed ${libGL}/lib/libGLX.so \ - --add-needed ${libGL}/lib/libGL.so \ - --add-needed ${lib.getLib gnutls}/lib/libgnutls.so \ - --add-needed ${vulkan-loader}/lib/libvulkan.so - ''; + postFixup = '' + patchelf $out/bin/${pname} \ + --add-needed ${SDL2}/lib/libSDL2.so \ + --add-needed ${libGL}/lib/libGLX.so \ + --add-needed ${libGL}/lib/libGL.so \ + --add-needed ${lib.getLib gnutls}/lib/libgnutls.so \ + --add-needed ${vulkan-loader}/lib/libvulkan.so + ''; - description = "Hybrid and versatile game engine"; - } // attrs); + description = "Hybrid and versatile game engine"; + } + // attrs + ); - fteqw-dedicated = import ./generic.nix (rec { - pname = "fteqw-dedicated"; - releaseFile = "fteqw-sv"; + fteqw-dedicated = import ./generic.nix ( + rec { + pname = "fteqw-dedicated"; + releaseFile = "fteqw-sv"; - buildFlags = [ "sv-rel" ]; + buildFlags = [ "sv-rel" ]; - buildInputs = [ - gnutls - zlib - ]; + buildInputs = [ + gnutls + zlib + ]; - postFixup = '' - patchelf $out/bin/${pname} \ - --add-needed ${gnutls}/lib/libgnutls.so \ - ''; + postFixup = '' + patchelf $out/bin/${pname} \ + --add-needed ${gnutls}/lib/libgnutls.so \ + ''; - description = "Dedicated server for FTEQW"; - } // attrs); + description = "Dedicated server for FTEQW"; + } + // attrs + ); - fteqcc = import ./generic.nix ({ - pname = "fteqcc"; + fteqcc = import ./generic.nix ( + { + pname = "fteqcc"; - buildFlags = [ "qcc-rel" ]; + buildFlags = [ "qcc-rel" ]; - buildInputs = [ - zlib - ]; + buildInputs = [ + zlib + ]; - description = "User friendly QuakeC compiler"; - } // attrs); + description = "User friendly QuakeC compiler"; + } + // attrs + ); } diff --git a/pkgs/games/fteqw/generic.nix b/pkgs/games/fteqw/generic.nix index 2d83b8b2af81e6..1c158602bf876f 100644 --- a/pkgs/games/fteqw/generic.nix +++ b/pkgs/games/fteqw/generic.nix @@ -1,19 +1,27 @@ -{ lib -, fetchFromGitHub -, stdenv -, libopus -, xorg -, pname -, releaseFile ? pname -, buildFlags -, buildInputs -, nativeBuildInputs ? [] -, postFixup ? "" -, description -, ... }: +{ + lib, + fetchFromGitHub, + stdenv, + libopus, + xorg, + pname, + releaseFile ? pname, + buildFlags, + buildInputs, + nativeBuildInputs ? [ ], + postFixup ? "", + description, + ... +}: stdenv.mkDerivation { - inherit pname buildFlags buildInputs nativeBuildInputs postFixup; + inherit + pname + buildFlags + buildInputs + nativeBuildInputs + postFixup + ; version = "0-unstable-2024-04-13"; src = fetchFromGitHub { @@ -25,7 +33,8 @@ stdenv.mkDerivation { makeFlags = [ "PKGCONFIG=$(PKG_CONFIG)" - "-C" "engine" + "-C" + "engine" ]; enableParallelBuilding = true; diff --git a/pkgs/games/garden-of-coloured-lights/default.nix b/pkgs/games/garden-of-coloured-lights/default.nix index 00bf3a9d4278b9..a26cea27961295 100644 --- a/pkgs/games/garden-of-coloured-lights/default.nix +++ b/pkgs/games/garden-of-coloured-lights/default.nix @@ -1,10 +1,20 @@ -{ lib, stdenv, fetchurl, autoconf, automake, allegro }: +{ + lib, + stdenv, + fetchurl, + autoconf, + automake, + allegro, +}: stdenv.mkDerivation rec { pname = "garden-of-coloured-lights"; version = "1.0.9"; - nativeBuildInputs = [ autoconf automake ]; + nativeBuildInputs = [ + autoconf + automake + ]; buildInputs = [ allegro ]; prePatch = '' diff --git a/pkgs/games/gl-gsync-demo/default.nix b/pkgs/games/gl-gsync-demo/default.nix index 8ea4facb77b751..9a7be5418c8aa7 100644 --- a/pkgs/games/gl-gsync-demo/default.nix +++ b/pkgs/games/gl-gsync-demo/default.nix @@ -1,4 +1,13 @@ -{ stdenv, fetchFromGitHub, libX11, libglut, glew, libXNVCtrl, libXext, lib }: +{ + stdenv, + fetchFromGitHub, + libX11, + libglut, + glew, + libXNVCtrl, + libXext, + lib, +}: stdenv.mkDerivation rec { pname = "gl-gsync-demo"; @@ -11,7 +20,13 @@ stdenv.mkDerivation rec { sha256 = "1innsmpsd9n9ih80v16rhj2ijrl28jd7x6a4jmxdirba7mjibm8d"; }; - buildInputs = [ libX11 libglut glew libXNVCtrl libXext ]; + buildInputs = [ + libX11 + libglut + glew + libXNVCtrl + libXext + ]; installPhase = '' runHook preInstall diff --git a/pkgs/games/gogdl/default.nix b/pkgs/games/gogdl/default.nix index 0f96f0e4e36a4a..08161f7f3c1f87 100644 --- a/pkgs/games/gogdl/default.nix +++ b/pkgs/games/gogdl/default.nix @@ -1,11 +1,12 @@ -{ lib -, writeScript -, buildPythonApplication -, fetchFromGitHub -, pythonOlder -, setuptools -, requests -, cacert +{ + lib, + writeScript, + buildPythonApplication, + fetchFromGitHub, + pythonOlder, + setuptools, + requests, + cacert, }: buildPythonApplication rec { diff --git a/pkgs/games/gscrabble/default.nix b/pkgs/games/gscrabble/default.nix index c4a3614edd6a1c..95146c8f88048f 100644 --- a/pkgs/games/gscrabble/default.nix +++ b/pkgs/games/gscrabble/default.nix @@ -1,6 +1,14 @@ -{ lib, buildPythonApplication, fetchFromGitHub -, gtk3, wrapGAppsHook3, gst_all_1, gobject-introspection -, python3Packages, adwaita-icon-theme }: +{ + lib, + buildPythonApplication, + fetchFromGitHub, + gtk3, + wrapGAppsHook3, + gst_all_1, + gobject-introspection, + python3Packages, + adwaita-icon-theme, +}: buildPythonApplication { pname = "gscrabble"; @@ -15,14 +23,24 @@ buildPythonApplication { doCheck = false; - nativeBuildInputs = [ wrapGAppsHook3 gobject-introspection ]; + nativeBuildInputs = [ + wrapGAppsHook3 + gobject-introspection + ]; buildInputs = with gst_all_1; [ - gst-plugins-base gst-plugins-good gst-plugins-ugly gst-plugins-bad - adwaita-icon-theme gtk3 + gst-plugins-base + gst-plugins-good + gst-plugins-ugly + gst-plugins-bad + adwaita-icon-theme + gtk3 ]; - propagatedBuildInputs = with python3Packages; [ gst-python pygobject3 ]; + propagatedBuildInputs = with python3Packages; [ + gst-python + pygobject3 + ]; preFixup = '' gappsWrapperArgs+=( diff --git a/pkgs/games/gshogi/default.nix b/pkgs/games/gshogi/default.nix index 98bf06ac97410e..3fdd60a5fa2c40 100644 --- a/pkgs/games/gshogi/default.nix +++ b/pkgs/games/gshogi/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, gobject-introspection -, gtk3 -, python3 -, wrapGAppsHook3 +{ + lib, + fetchFromGitHub, + gobject-introspection, + gtk3, + python3, + wrapGAppsHook3, }: python3.pkgs.buildPythonApplication rec { @@ -17,13 +18,16 @@ python3.pkgs.buildPythonApplication rec { hash = "sha256-EPOIYPSFAhilxuZeYfuZ4Cd29ReJs/E4KNF5/lyzbxs="; }; - doCheck = false; # no tests available + doCheck = false; # no tests available buildInputs = [ gtk3 ]; - nativeBuildInputs = [ wrapGAppsHook3 gobject-introspection ]; + nativeBuildInputs = [ + wrapGAppsHook3 + gobject-introspection + ]; propagatedBuildInputs = with python3.pkgs; [ pygobject3 diff --git a/pkgs/games/hedgewars/default.nix b/pkgs/games/hedgewars/default.nix index 24ae078c770df6..f98183d8239d00 100644 --- a/pkgs/games/hedgewars/default.nix +++ b/pkgs/games/hedgewars/default.nix @@ -1,16 +1,47 @@ -{ stdenv, SDL2_image_2_6, SDL2_ttf, SDL2_net, fpc, haskell, ffmpeg, libglut -, lib, fetchurl, cmake, pkg-config, lua5_1, SDL2, SDL2_mixer -, zlib, libpng, libGL, libGLU, physfs -, qtbase, qttools, wrapQtAppsHook -, llvm -, withServer ? true +{ + stdenv, + SDL2_image_2_6, + SDL2_ttf, + SDL2_net, + fpc, + haskell, + ffmpeg, + libglut, + lib, + fetchurl, + cmake, + pkg-config, + lua5_1, + SDL2, + SDL2_mixer, + zlib, + libpng, + libGL, + libGLU, + physfs, + qtbase, + qttools, + wrapQtAppsHook, + llvm, + withServer ? true, }: let - ghc = haskell.packages.ghc94.ghcWithPackages (pkgs: with pkgs; [ - SHA bytestring entropy hslogger network pkgs.zlib random - regex-tdfa sandi utf8-string vector - ]); + ghc = haskell.packages.ghc94.ghcWithPackages ( + pkgs: with pkgs; [ + SHA + bytestring + entropy + hslogger + network + pkgs.zlib + random + regex-tdfa + sandi + utf8-string + vector + ] + ); in stdenv.mkDerivation rec { pname = "hedgewars"; @@ -27,13 +58,25 @@ stdenv.mkDerivation rec { ./support-ffmpeg-6.patch ]; - nativeBuildInputs = [ cmake pkg-config qttools wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + pkg-config + qttools + wrapQtAppsHook + ]; buildInputs = [ - SDL2_ttf SDL2_net SDL2 SDL2_mixer SDL2_image_2_6 - fpc lua5_1 + SDL2_ttf + SDL2_net + SDL2 + SDL2_mixer + SDL2_image_2_6 + fpc + lua5_1 llvm # hard-requirement on aarch64, for some reason not strictly necessary on x86-64 - ffmpeg libglut physfs + ffmpeg + libglut + physfs qtbase ] ++ lib.optional withServer ghc; @@ -57,7 +100,14 @@ stdenv.mkDerivation rec { ]; qtWrapperArgs = [ - "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ libGL libGLU libglut physfs ]}" + "--prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + libGL + libGLU + libglut + physfs + ] + }" ]; meta = with lib; { @@ -65,29 +115,32 @@ stdenv.mkDerivation rec { homepage = "https://hedgewars.org/"; license = licenses.gpl2Plus; longDescription = '' - Each player controls a team of several hedgehogs. During the course of - the game, players take turns with one of their hedgehogs. They then use - whatever tools and weapons are available to attack and kill the - opponents' hedgehogs, thereby winning the game. Hedgehogs may move - around the terrain in a variety of ways, normally by walking and jumping - but also by using particular tools such as the "Rope" or "Parachute", to - move to otherwise inaccessible areas. Each turn is time-limited to - ensure that players do not hold up the game with excessive thinking or - moving. + Each player controls a team of several hedgehogs. During the course of + the game, players take turns with one of their hedgehogs. They then use + whatever tools and weapons are available to attack and kill the + opponents' hedgehogs, thereby winning the game. Hedgehogs may move + around the terrain in a variety of ways, normally by walking and jumping + but also by using particular tools such as the "Rope" or "Parachute", to + move to otherwise inaccessible areas. Each turn is time-limited to + ensure that players do not hold up the game with excessive thinking or + moving. - A large variety of tools and weapons are available for players during - the game: Grenade, Cluster Bomb, Bazooka, UFO, Homing Bee, Shotgun, - Desert Eagle, Fire Punch, Baseball Bat, Dynamite, Mine, Rope, Pneumatic - pick, Parachute. Most weapons, when used, cause explosions that deform - the terrain, removing circular chunks. The landscape is an island - floating on a body of water, or a restricted cave with water at the - bottom. A hedgehog dies when it enters the water (either by falling off - the island, or through a hole in the bottom of it), it is thrown off - either side of the arena or when its health is reduced, typically from - contact with explosions, to zero (the damage dealt to the attacked - hedgehog or hedgehogs after a player's or CPU turn is shown only when - all movement on the battlefield has ceased).''; - maintainers = with maintainers; [ kragniz fpletz ]; + A large variety of tools and weapons are available for players during + the game: Grenade, Cluster Bomb, Bazooka, UFO, Homing Bee, Shotgun, + Desert Eagle, Fire Punch, Baseball Bat, Dynamite, Mine, Rope, Pneumatic + pick, Parachute. Most weapons, when used, cause explosions that deform + the terrain, removing circular chunks. The landscape is an island + floating on a body of water, or a restricted cave with water at the + bottom. A hedgehog dies when it enters the water (either by falling off + the island, or through a hole in the bottom of it), it is thrown off + either side of the arena or when its health is reduced, typically from + contact with explosions, to zero (the damage dealt to the attacked + hedgehog or hedgehogs after a player's or CPU turn is shown only when + all movement on the battlefield has ceased).''; + maintainers = with maintainers; [ + kragniz + fpletz + ]; broken = stdenv.hostPlatform.isDarwin; platforms = platforms.linux; }; diff --git a/pkgs/games/iortcw/default.nix b/pkgs/games/iortcw/default.nix index 44a554b9e7d6ca..49ceab43c5aa60 100644 --- a/pkgs/games/iortcw/default.nix +++ b/pkgs/games/iortcw/default.nix @@ -1,14 +1,22 @@ -{ buildEnv, callPackage, makeWrapper }: +{ + buildEnv, + callPackage, + makeWrapper, +}: let - sp = callPackage ./sp.nix {}; + sp = callPackage ./sp.nix { }; mp = sp.overrideAttrs (oldAttrs: { sourceRoot = "${oldAttrs.src.name}/MP"; }); -in buildEnv { +in +buildEnv { name = "iortcw"; - paths = [ sp mp ]; + paths = [ + sp + mp + ]; pathsToLink = [ "/opt" ]; diff --git a/pkgs/games/iortcw/sp.nix b/pkgs/games/iortcw/sp.nix index a61cb05c3319fd..92ee59c6891ccc 100644 --- a/pkgs/games/iortcw/sp.nix +++ b/pkgs/games/iortcw/sp.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, opusfile, libogg, SDL2, openal, freetype -, libjpeg, curl, makeWrapper }: +{ + lib, + stdenv, + fetchFromGitHub, + opusfile, + libogg, + SDL2, + openal, + freetype, + libjpeg, + curl, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "iortcw-sp"; @@ -26,7 +37,13 @@ stdenv.mkDerivation rec { installTargets = [ "copyfiles" ]; buildInputs = [ - opusfile libogg SDL2 freetype libjpeg openal curl + opusfile + libogg + SDL2 + freetype + libjpeg + openal + curl ]; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/games/ja2-stracciatella/default.nix b/pkgs/games/ja2-stracciatella/default.nix index 6b89a806e26b46..6ad1f4baa330c3 100644 --- a/pkgs/games/ja2-stracciatella/default.nix +++ b/pkgs/games/ja2-stracciatella/default.nix @@ -1,4 +1,18 @@ -{ stdenv, lib, fetchurl, fetchFromGitHub, cmake, python3, rustPlatform, SDL2, fltk, rapidjson, gtest, Carbon, Cocoa }: +{ + stdenv, + lib, + fetchurl, + fetchFromGitHub, + cmake, + python3, + rustPlatform, + SDL2, + fltk, + rapidjson, + gtest, + Carbon, + Cocoa, +}: let version = "0.17.0"; src = fetchFromGitHub { @@ -28,8 +42,21 @@ stdenv.mkDerivation { pname = "ja2-stracciatella"; inherit src version; - nativeBuildInputs = [ cmake python3 ]; - buildInputs = [ SDL2 fltk rapidjson gtest ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Carbon Cocoa ]; + nativeBuildInputs = [ + cmake + python3 + ]; + buildInputs = + [ + SDL2 + fltk + rapidjson + gtest + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Carbon + Cocoa + ]; patches = [ ./remove-rust-buildstep.patch diff --git a/pkgs/games/koboredux/default.nix b/pkgs/games/koboredux/default.nix index 178b592436b9ab..5f4d0a39a8a9bd 100644 --- a/pkgs/games/koboredux/default.nix +++ b/pkgs/games/koboredux/default.nix @@ -1,13 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchpatch -, requireFile -, cmake -, pkg-config -, SDL2 -, SDL2_image -, audiality2 -, useProprietaryAssets ? true +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + requireFile, + cmake, + pkg-config, + SDL2, + SDL2_image, + audiality2, + useProprietaryAssets ? true, }: let @@ -57,10 +59,12 @@ stdenv.mkDerivation rec { sourceRoot = main_src.name; # Fix clang build - patches = [(fetchpatch { - url = "https://github.com/olofson/koboredux/commit/cf92b8a61d002ccaa9fbcda7a96dab08a681dee4.patch"; - sha256 = "0dwhvis7ghf3mgzjd2rwn8hk3ndlgfwwcqaq581yc5rwd73v6vw4"; - })]; + patches = [ + (fetchpatch { + url = "https://github.com/olofson/koboredux/commit/cf92b8a61d002ccaa9fbcda7a96dab08a681dee4.patch"; + sha256 = "0dwhvis7ghf3mgzjd2rwn8hk3ndlgfwwcqaq581yc5rwd73v6vw4"; + }) + ]; postPatch = optionalString useProprietaryAssets '' cp -r ../koboredux-${version}-Linux/sfx/redux data/sfx/ @@ -80,23 +84,25 @@ stdenv.mkDerivation rec { ]; meta = { - description = "Frantic 80's style 2D shooter, similar to XKobo and Kobo Deluxe" + - optionalString (!useProprietaryAssets) " (built without proprietary assets)"; + description = + "Frantic 80's style 2D shooter, similar to XKobo and Kobo Deluxe" + + optionalString (!useProprietaryAssets) " (built without proprietary assets)"; mainProgram = "kobord"; - longDescription = '' - Kobo Redux is a frantic 80's style 2D shooter, inspired by the look and - feel of 90's arcade cabinets. The gameplay is fast and unforgiving, - although with less of the frustrating quirkiness of the actual games - of the 80's. A true challenge in the spirit of the arcade era! - '' + optionalString (!useProprietaryAssets) '' - - This version replaces the official proprietary assets with placeholders. - For the full experience, consider installing "koboredux" instead. - ''; + longDescription = + '' + Kobo Redux is a frantic 80's style 2D shooter, inspired by the look and + feel of 90's arcade cabinets. The gameplay is fast and unforgiving, + although with less of the frustrating quirkiness of the actual games + of the 80's. A true challenge in the spirit of the arcade era! + '' + + optionalString (!useProprietaryAssets) '' + + This version replaces the official proprietary assets with placeholders. + For the full experience, consider installing "koboredux" instead. + ''; homepage = "https://olofson.itch.io/kobo-redux"; license = with licenses; if useProprietaryAssets then unfree else gpl2Plus; platforms = platforms.all; maintainers = with maintainers; [ fgaz ]; }; } - diff --git a/pkgs/games/leela-zero/default.nix b/pkgs/games/leela-zero/default.nix index 073179e35b4723..da7c815fa0566b 100644 --- a/pkgs/games/leela-zero/default.nix +++ b/pkgs/games/leela-zero/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, boost -, opencl-headers -, ocl-icd -, qtbase -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + boost, + opencl-headers, + ocl-icd, + qtbase, + zlib, }: stdenv.mkDerivation rec { @@ -21,7 +22,13 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - buildInputs = [ boost opencl-headers ocl-icd qtbase zlib ]; + buildInputs = [ + boost + opencl-headers + ocl-icd + qtbase + zlib + ]; nativeBuildInputs = [ cmake ]; @@ -31,7 +38,10 @@ stdenv.mkDerivation rec { description = "Go engine modeled after AlphaGo Zero"; homepage = "https://github.com/gcp/leela-zero"; license = licenses.gpl3Plus; - maintainers = [ maintainers.averelld maintainers.omnipotententity ]; + maintainers = [ + maintainers.averelld + maintainers.omnipotententity + ]; platforms = platforms.linux; }; } diff --git a/pkgs/games/legendary-gl/default.nix b/pkgs/games/legendary-gl/default.nix index a802efd66587d4..7888c2111f5196 100644 --- a/pkgs/games/legendary-gl/default.nix +++ b/pkgs/games/legendary-gl/default.nix @@ -1,10 +1,11 @@ -{ lib -, gitUpdater -, fetchFromGitHub -, buildPythonApplication -, pythonOlder -, requests -, filelock +{ + lib, + gitUpdater, + fetchFromGitHub, + buildPythonApplication, + pythonOlder, + requests, + filelock, }: buildPythonApplication rec { diff --git a/pkgs/games/libremines/default.nix b/pkgs/games/libremines/default.nix index e639b981369e75..b3b7cda9d4c60a 100644 --- a/pkgs/games/libremines/default.nix +++ b/pkgs/games/libremines/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, wrapQtAppsHook -, qtmultimedia -, qtwayland +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + wrapQtAppsHook, + qtmultimedia, + qtwayland, }: stdenv.mkDerivation rec { @@ -18,14 +19,19 @@ stdenv.mkDerivation rec { hash = "sha256-TQwjEgtqAvKnrpia6VloRgFwtq5TNDmxU+ZWjtEK/n8="; }; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; - - buildInputs = [ - qtmultimedia - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - qtwayland + nativeBuildInputs = [ + cmake + wrapQtAppsHook ]; + buildInputs = + [ + qtmultimedia + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + qtwayland + ]; + cmakeFlags = [ "-DUSE_QT6=TRUE" ]; meta = with lib; { diff --git a/pkgs/games/lincity/default.nix b/pkgs/games/lincity/default.nix index deb4f2eb025091..9bfdc8e189c1ff 100644 --- a/pkgs/games/lincity/default.nix +++ b/pkgs/games/lincity/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, fetchpatch, libX11, libXext, xorgproto, libICE, libSM, libpng12, zlib }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + libX11, + libXext, + xorgproto, + libICE, + libSM, + libpng12, + zlib, +}: stdenv.mkDerivation rec { pname = "lincity"; @@ -10,8 +22,13 @@ stdenv.mkDerivation rec { }; buildInputs = [ - libICE libpng12 libSM libX11 libXext - xorgproto zlib + libICE + libpng12 + libSM + libX11 + libXext + xorgproto + zlib ]; patches = [ diff --git a/pkgs/games/lincity/ng.nix b/pkgs/games/lincity/ng.nix index ce3115d66de989..6ca8b8c6471599 100644 --- a/pkgs/games/lincity/ng.nix +++ b/pkgs/games/lincity/ng.nix @@ -1,22 +1,23 @@ -{ stdenv -, SDL2 -, SDL2_gfx -, SDL2_image -, SDL2_mixer -, SDL2_ttf -, autoreconfHook -, fetchFromGitHub -, jam -, lib -, libGL -, libGLU -, libX11 -, libxml2 -, libxslt -, physfs -, pkg-config -, xorgproto -, zlib +{ + stdenv, + SDL2, + SDL2_gfx, + SDL2_image, + SDL2_mixer, + SDL2_ttf, + autoreconfHook, + fetchFromGitHub, + jam, + lib, + libGL, + libGLU, + libX11, + libxml2, + libxslt, + physfs, + pkg-config, + xorgproto, + zlib, }: stdenv.mkDerivation { diff --git a/pkgs/games/linthesia/default.nix b/pkgs/games/linthesia/default.nix index 7bb3e30ef6af40..a214c80b779217 100644 --- a/pkgs/games/linthesia/default.nix +++ b/pkgs/games/linthesia/default.nix @@ -1,20 +1,21 @@ -{ lib -, SDL2 -, SDL2_image -, SDL2_ttf -, alsa-lib -, fetchFromGitHub -, glibmm -, gtk3 -, libGL -, libGLU -, meson -, ninja -, pkg-config -, python3 -, sqlite -, stdenv -, wrapGAppsHook3 +{ + lib, + SDL2, + SDL2_image, + SDL2_ttf, + alsa-lib, + fetchFromGitHub, + glibmm, + gtk3, + libGL, + libGLU, + meson, + ninja, + pkg-config, + python3, + sqlite, + stdenv, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -32,7 +33,13 @@ stdenv.mkDerivation rec { patchShebangs meson_post_install.py ''; - nativeBuildInputs = [ meson ninja pkg-config python3 wrapGAppsHook3 ]; + nativeBuildInputs = [ + meson + ninja + pkg-config + python3 + wrapGAppsHook3 + ]; buildInputs = [ libGL libGLU diff --git a/pkgs/games/liquidwar/5.nix b/pkgs/games/liquidwar/5.nix index 64ea76560f1346..1d49a6cef6e749 100644 --- a/pkgs/games/liquidwar/5.nix +++ b/pkgs/games/liquidwar/5.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, allegro }: +{ + lib, + stdenv, + fetchurl, + allegro, +}: stdenv.mkDerivation rec { version = "5.6.5"; pname = "liquidwar5"; diff --git a/pkgs/games/liquidwar/default.nix b/pkgs/games/liquidwar/default.nix index 83ac293f8b63d7..c974c71ecd50a7 100644 --- a/pkgs/games/liquidwar/default.nix +++ b/pkgs/games/liquidwar/default.nix @@ -1,10 +1,32 @@ -{ lib, stdenv, fetchurl, xorgproto, libX11, libXrender -, gmp, libjpeg, libpng -, expat, gettext, perl, guile -, SDL, SDL_image, SDL_mixer, SDL_ttf -, curl, sqlite, libtool, readline -, libogg, libvorbis, libcaca, csound, cunit -, pkg-config }: +{ + lib, + stdenv, + fetchurl, + xorgproto, + libX11, + libXrender, + gmp, + libjpeg, + libpng, + expat, + gettext, + perl, + guile, + SDL, + SDL_image, + SDL_mixer, + SDL_ttf, + curl, + sqlite, + libtool, + readline, + libogg, + libvorbis, + libcaca, + csound, + cunit, + pkg-config, +}: stdenv.mkDerivation rec { pname = "liquidwar6"; @@ -16,29 +38,47 @@ stdenv.mkDerivation rec { }; buildInputs = [ - xorgproto libX11 gmp guile - libjpeg libpng - expat gettext perl - SDL SDL_image SDL_mixer SDL_ttf - curl sqlite - libogg libvorbis csound - libXrender libcaca cunit - libtool readline + xorgproto + libX11 + gmp + guile + libjpeg + libpng + expat + gettext + perl + SDL + SDL_image + SDL_mixer + SDL_ttf + curl + sqlite + libogg + libvorbis + csound + libXrender + libcaca + cunit + libtool + readline ]; nativeBuildInputs = [ pkg-config ]; hardeningDisable = [ "format" ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ - # Needed with GCC 12 but problematic with some old GCCs - "-Wno-error=address" - "-Wno-error=use-after-free" - ] ++ [ - "-Wno-error=deprecated-declarations" - # Avoid GL_GLEXT_VERSION double definition - " -DNO_SDL_GLEXT" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "12") [ + # Needed with GCC 12 but problematic with some old GCCs + "-Wno-error=address" + "-Wno-error=use-after-free" + ] + ++ [ + "-Wno-error=deprecated-declarations" + # Avoid GL_GLEXT_VERSION double definition + " -DNO_SDL_GLEXT" + ] + ); # To avoid problems finding SDL_types.h. configureFlags = [ "CFLAGS=-I${lib.getDev SDL}/include/SDL" ]; diff --git a/pkgs/games/lzwolf/default.nix b/pkgs/games/lzwolf/default.nix index 7e3e932ba5cf05..9bfba6f916011a 100644 --- a/pkgs/games/lzwolf/default.nix +++ b/pkgs/games/lzwolf/default.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromBitbucket -, fetchpatch -, p7zip -, cmake -, SDL2 -, bzip2 -, zlib -, libjpeg -, libsndfile -, mpg123 -, pkg-config -, SDL2_net -, SDL2_mixer +{ + stdenv, + lib, + fetchFromBitbucket, + fetchpatch, + p7zip, + cmake, + SDL2, + bzip2, + zlib, + libjpeg, + libsndfile, + mpg123, + pkg-config, + SDL2_net, + SDL2_mixer, }: stdenv.mkDerivation rec { @@ -43,9 +44,20 @@ stdenv.mkDerivation rec { --replace 'SDL2::SDL2_net' 'SDL2_net::SDL2_net' ''; - nativeBuildInputs = [ p7zip pkg-config cmake ]; + nativeBuildInputs = [ + p7zip + pkg-config + cmake + ]; buildInputs = [ - SDL2 bzip2 zlib libjpeg SDL2_mixer SDL2_net libsndfile mpg123 + SDL2 + bzip2 + zlib + libjpeg + SDL2_mixer + SDL2_net + libsndfile + mpg123 ]; cmakeFlags = [ diff --git a/pkgs/games/macopix/default.nix b/pkgs/games/macopix/default.nix index ca9870727b2ca2..8820137b5a2f9a 100644 --- a/pkgs/games/macopix/default.nix +++ b/pkgs/games/macopix/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, pkg-config, gtk, openssl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gtk, + openssl, +}: stdenv.mkDerivation rec { pname = "macopix"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk openssl ]; + buildInputs = [ + gtk + openssl + ]; preConfigure = '' # Build fails on Linux with windres. diff --git a/pkgs/games/manaplus/default.nix b/pkgs/games/manaplus/default.nix index 768a971d834654..865a027503e9d0 100644 --- a/pkgs/games/manaplus/default.nix +++ b/pkgs/games/manaplus/default.nix @@ -1,6 +1,22 @@ -{ stdenv, lib, fetchurl, SDL2, SDL2_image, SDL2_ttf, SDL2_mixer -, SDL2_net , SDL2_gfx, zlib, physfs, curl, libxml2, libpng, pkg-config -, libGL, autoreconfHook }: +{ + stdenv, + lib, + fetchurl, + SDL2, + SDL2_image, + SDL2_ttf, + SDL2_mixer, + SDL2_net, + SDL2_gfx, + zlib, + physfs, + curl, + libxml2, + libpng, + pkg-config, + libGL, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "manaplus"; version = "2.1.3.17"; @@ -11,15 +27,29 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - autoreconfHook pkg-config + autoreconfHook + pkg-config ]; buildInputs = [ - SDL2 SDL2_image SDL2_ttf SDL2_mixer SDL2_net SDL2_gfx zlib - physfs curl libxml2 libpng libGL + SDL2 + SDL2_image + SDL2_ttf + SDL2_mixer + SDL2_net + SDL2_gfx + zlib + physfs + curl + libxml2 + libpng + libGL ]; - configureFlags = [ "--with-sdl2" "--without-dyecmd" ]; + configureFlags = [ + "--with-sdl2" + "--without-dyecmd" + ]; enableParallelBuilding = true; diff --git a/pkgs/games/maptool/default.nix b/pkgs/games/maptool/default.nix index 775879a957ad34..3e57c7055367c1 100644 --- a/pkgs/games/maptool/default.nix +++ b/pkgs/games/maptool/default.nix @@ -1,14 +1,15 @@ -{ lib -, copyDesktopItems -, fetchurl -, ffmpeg -, gitUpdater -, jre -, libarchive -, makeDesktopItem -, openjfx -, stdenvNoCC -, wrapGAppsHook3 +{ + lib, + copyDesktopItems, + fetchurl, + ffmpeg, + gitUpdater, + jre, + libarchive, + makeDesktopItem, + openjfx, + stdenvNoCC, + wrapGAppsHook3, }: let pname = "maptool"; @@ -32,7 +33,15 @@ let platforms = [ "x86_64-linux" ]; }; - javafxModules = [ "base" "controls" "media" "swing" "web" "fxml" "graphics" ]; + javafxModules = [ + "base" + "controls" + "media" + "swing" + "web" + "fxml" + "graphics" + ]; appClasspath = "share/${pname}"; @@ -41,11 +50,12 @@ let "${openjfx}/modules_src/javafx.${mod}/module-info.java" "${openjfx}/modules/javafx.${mod}" "${openjfx}/modules_libs/javafx.${mod}" - ]) javafxModules ++ - [ "$out/${appClasspath}/*" ]; + ]) javafxModules + ++ [ "$out/${appClasspath}/*" ]; jvmArgs = [ - "-cp" (lib.concatStringsSep ":" classpath) + "-cp" + (lib.concatStringsSep ":" classpath) "-Xss8M" "-Dsun.java2d.d3d=false" "-Dfile.encoding=UTF-8" @@ -72,7 +82,12 @@ let rdnsName = "net.rptools.maptool"; in stdenvNoCC.mkDerivation { - inherit pname version src meta; + inherit + pname + version + src + meta + ; dontUnpack = true; dontConfigure = true; diff --git a/pkgs/games/minecraft-servers/default.nix b/pkgs/games/minecraft-servers/default.nix index d49adda6da9d6d..0b5a9a28834ba5 100644 --- a/pkgs/games/minecraft-servers/default.nix +++ b/pkgs/games/minecraft-servers/default.nix @@ -1,4 +1,8 @@ -{ callPackage, lib, javaPackages }: +{ + callPackage, + lib, + javaPackages, +}: let versions = lib.importJSON ./versions.json; @@ -7,22 +11,24 @@ let getJavaVersion = v: (builtins.getAttr "openjdk${toString v}" javaPackages.compiler).headless; - packages = lib.mapAttrs' - (version: value: { - name = "vanilla-${escapeVersion version}"; - value = callPackage ./derivation.nix { - inherit (value) version url sha1; - jre_headless = getJavaVersion ( - if value.javaVersion == null then 8 - else if value.javaVersion == 16 then 17 - else value.javaVersion - ); # versions <= 1.6 will default to 8 - }; - }) - versions; + packages = lib.mapAttrs' (version: value: { + name = "vanilla-${escapeVersion version}"; + value = callPackage ./derivation.nix { + inherit (value) version url sha1; + jre_headless = getJavaVersion ( + if value.javaVersion == null then + 8 + else if value.javaVersion == 16 then + 17 + else + value.javaVersion + ); # versions <= 1.6 will default to 8 + }; + }) versions; in lib.recurseIntoAttrs ( - packages // { + packages + // { vanilla = builtins.getAttr "vanilla-${escapeVersion latestVersion}" packages; } ) diff --git a/pkgs/games/minecraft-servers/derivation.nix b/pkgs/games/minecraft-servers/derivation.nix index c6f26d73eb6f1d..a93ede2a89abf3 100644 --- a/pkgs/games/minecraft-servers/derivation.nix +++ b/pkgs/games/minecraft-servers/derivation.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, nixosTests, jre_headless, makeWrapper, udev, version, url, sha1 }: +{ + lib, + stdenv, + fetchurl, + nixosTests, + jre_headless, + makeWrapper, + udev, + version, + url, + sha1, +}: stdenv.mkDerivation { pname = "minecraft-server"; inherit version; @@ -34,6 +45,10 @@ stdenv.mkDerivation { sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.unfreeRedistributable; platforms = platforms.unix; - maintainers = with maintainers; [ thoughtpolice tomberek costrouc ]; + maintainers = with maintainers; [ + thoughtpolice + tomberek + costrouc + ]; }; } diff --git a/pkgs/games/mnemosyne/default.nix b/pkgs/games/mnemosyne/default.nix index cd8142574d8db8..5f1d03a3ed6f9d 100644 --- a/pkgs/games/mnemosyne/default.nix +++ b/pkgs/games/mnemosyne/default.nix @@ -1,6 +1,7 @@ -{ python -, fetchurl -, anki +{ + python, + fetchurl, + anki, }: python.pkgs.buildPythonApplication rec { @@ -8,7 +9,7 @@ python.pkgs.buildPythonApplication rec { version = "2.10.1"; src = fetchurl { - url = "mirror://sourceforge/project/mnemosyne-proj/mnemosyne/mnemosyne-${version}/Mnemosyne-${version}.tar.gz"; + url = "mirror://sourceforge/project/mnemosyne-proj/mnemosyne/mnemosyne-${version}/Mnemosyne-${version}.tar.gz"; sha256 = "sha256-zI79iuRXb5S0Y87KfdG+HKc0XVNQOAcBR7Zt/OdaBP4="; }; diff --git a/pkgs/games/mrrescue/default.nix b/pkgs/games/mrrescue/default.nix index 60650015a393e5..c42364f0d71d83 100644 --- a/pkgs/games/mrrescue/default.nix +++ b/pkgs/games/mrrescue/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, love, lua, makeWrapper, makeDesktopItem }: +{ + lib, + stdenv, + fetchurl, + love, + lua, + makeWrapper, + makeDesktopItem, +}: let pname = "mrrescue"; @@ -29,12 +37,15 @@ stdenv.mkDerivation { sha256 = "0kzahxrgpb4vsk9yavy7f8nc34d62d1jqjrpsxslmy9ywax4yfpi"; }; - nativeBuildInputs = [ lua love makeWrapper ]; + nativeBuildInputs = [ + lua + love + makeWrapper + ]; dontUnpack = true; - installPhase = - '' + installPhase = '' mkdir -p $out/bin mkdir -p $out/share/games/lovegames diff --git a/pkgs/games/nethack/default.nix b/pkgs/games/nethack/default.nix index 6d099cfcfe3123..c9f804c43e1525 100644 --- a/pkgs/games/nethack/default.nix +++ b/pkgs/games/nethack/default.nix @@ -1,46 +1,100 @@ -{ stdenv, lib, fetchurl, coreutils, ncurses, gzip, flex, bison -, less -, buildPackages -, x11Mode ? false, qtMode ? false, libXaw, libXext, libXpm, bdftopcf, mkfontdir, pkg-config, qt5 -, copyDesktopItems, makeDesktopItem +{ + stdenv, + lib, + fetchurl, + coreutils, + ncurses, + gzip, + flex, + bison, + less, + buildPackages, + x11Mode ? false, + qtMode ? false, + libXaw, + libXext, + libXpm, + bdftopcf, + mkfontdir, + pkg-config, + qt5, + copyDesktopItems, + makeDesktopItem, }: let platform = - if stdenv.hostPlatform.isUnix then "unix" - else throw "Unknown platform for NetHack: ${stdenv.hostPlatform.system}"; + if stdenv.hostPlatform.isUnix then + "unix" + else + throw "Unknown platform for NetHack: ${stdenv.hostPlatform.system}"; unixHint = - if x11Mode then "linux-x11" - else if qtMode then "linux-qt4" - else if stdenv.hostPlatform.isLinux then "linux" - else if stdenv.hostPlatform.isDarwin then "macosx10.14" + if x11Mode then + "linux-x11" + else if qtMode then + "linux-qt4" + else if stdenv.hostPlatform.isLinux then + "linux" + else if stdenv.hostPlatform.isDarwin then + "macosx10.14" # We probably want something different for Darwin - else "unix"; + else + "unix"; userDir = "~/.config/nethack"; - binPath = lib.makeBinPath [ coreutils less ]; + binPath = lib.makeBinPath [ + coreutils + less + ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { version = "3.6.7"; - pname = if x11Mode then "nethack-x11" - else if qtMode then "nethack-qt" - else "nethack"; + pname = + if x11Mode then + "nethack-x11" + else if qtMode then + "nethack-qt" + else + "nethack"; src = fetchurl { - url = "https://nethack.org/download/${version}/nethack-${lib.replaceStrings ["."] [""] version}-src.tgz"; + url = "https://nethack.org/download/${version}/nethack-${ + lib.replaceStrings [ "." ] [ "" ] version + }-src.tgz"; sha256 = "sha256-mM9n323r+WaKYXRaqEwJvKs2Ll0z9blE7FFV1E0qrLI="; }; - buildInputs = [ ncurses ] - ++ lib.optionals x11Mode [ libXaw libXext libXpm ] - ++ lib.optionals qtMode [ gzip qt5.qtbase.bin qt5.qtmultimedia.bin ]; - - nativeBuildInputs = [ flex bison copyDesktopItems ] - ++ lib.optionals x11Mode [ mkfontdir bdftopcf ] - ++ lib.optionals qtMode [ - pkg-config mkfontdir qt5.qtbase.dev - qt5.qtmultimedia.dev qt5.wrapQtAppsHook - bdftopcf - ]; + buildInputs = + [ ncurses ] + ++ lib.optionals x11Mode [ + libXaw + libXext + libXpm + ] + ++ lib.optionals qtMode [ + gzip + qt5.qtbase.bin + qt5.qtmultimedia.bin + ]; + + nativeBuildInputs = + [ + flex + bison + copyDesktopItems + ] + ++ lib.optionals x11Mode [ + mkfontdir + bdftopcf + ] + ++ lib.optionals qtMode [ + pkg-config + mkfontdir + qt5.qtbase.dev + qt5.qtmultimedia.dev + qt5.wrapQtAppsHook + bdftopcf + ]; makeFlags = [ "PREFIX=$(out)" ]; @@ -69,23 +123,24 @@ in stdenv.mkDerivation rec { -i sys/unix/hints/macosx10.14 sed -e '/define CHDIR/d' -i include/config.h ${lib.optionalString qtMode '' - sed \ - -e 's,^QTDIR *=.*,QTDIR=${qt5.qtbase.dev},' \ - -e 's,CFLAGS.*QtGui.*,CFLAGS += `pkg-config Qt5Gui --cflags`,' \ - -e 's,CFLAGS+=-DCOMPRESS.*,CFLAGS+=-DCOMPRESS=\\"${gzip}/bin/gzip\\" \\\ - -DCOMPRESS_EXTENSION=\\".gz\\",' \ - -e 's,moc-qt4,moc,' \ - -i sys/unix/hints/linux-qt4 + sed \ + -e 's,^QTDIR *=.*,QTDIR=${qt5.qtbase.dev},' \ + -e 's,CFLAGS.*QtGui.*,CFLAGS += `pkg-config Qt5Gui --cflags`,' \ + -e 's,CFLAGS+=-DCOMPRESS.*,CFLAGS+=-DCOMPRESS=\\"${gzip}/bin/gzip\\" \\\ + -DCOMPRESS_EXTENSION=\\".gz\\",' \ + -e 's,moc-qt4,moc,' \ + -i sys/unix/hints/linux-qt4 ''} ${lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) - # If we're cross-compiling, replace the paths to the data generation tools - # with the ones from the build platform's nethack package, since we can't - # run the ones we've built here. - '' - ${buildPackages.perl}/bin/perl -p \ - -e 's,[a-z./]+/(makedefs|dgn_comp|lev_comp|dlb)(?!\.),${buildPackages.nethack}/libexec/nethack/\1,g' \ - -i sys/unix/Makefile.* - ''} + # If we're cross-compiling, replace the paths to the data generation tools + # with the ones from the build platform's nethack package, since we can't + # run the ones we've built here. + '' + ${buildPackages.perl}/bin/perl -p \ + -e 's,[a-z./]+/(makedefs|dgn_comp|lev_comp|dlb)(?!\.),${buildPackages.nethack}/libexec/nethack/\1,g' \ + -i sys/unix/Makefile.* + '' + } sed -i -e '/rm -f $(MAKEDEFS)/d' sys/unix/Makefile.src # Fix building on darwin where otherwise __has_attribute fails with an empty parameter sed -e 's/define __warn_unused_result__ .*/define __warn_unused_result__ __unused__/' -i include/tradstdc.h @@ -151,13 +206,19 @@ in stdenv.mkDerivation rec { (makeDesktopItem { name = "NetHack"; exec = - if x11Mode then "nethack-x11" - else if qtMode then "nethack-qt" - else "nethack"; + if x11Mode then + "nethack-x11" + else if qtMode then + "nethack-qt" + else + "nethack"; icon = "nethack"; desktopName = "NetHack"; comment = "NetHack is a single player dungeon exploration game"; - categories = [ "Game" "ActionGame" ]; + categories = [ + "Game" + "ActionGame" + ]; }) ]; diff --git a/pkgs/games/nile/default.nix b/pkgs/games/nile/default.nix index 38fcced181279f..aa24289ba07042 100644 --- a/pkgs/games/nile/default.nix +++ b/pkgs/games/nile/default.nix @@ -1,15 +1,16 @@ -{ lib -, gitUpdater -, buildPythonApplication -, fetchFromGitHub -, pythonOlder -, setuptools -, requests -, protobuf -, pycryptodome -, zstandard -, json5 -, platformdirs +{ + lib, + gitUpdater, + buildPythonApplication, + fetchFromGitHub, + pythonOlder, + setuptools, + requests, + protobuf, + pycryptodome, + zstandard, + json5, + platformdirs, }: let diff --git a/pkgs/games/npush/default.nix b/pkgs/games/npush/default.nix index e3d199c7fa87bd..f8a5b732c066d6 100644 --- a/pkgs/games/npush/default.nix +++ b/pkgs/games/npush/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, ncurses +{ + lib, + stdenv, + fetchurl, + ncurses, }: stdenv.mkDerivation rec { @@ -13,7 +14,10 @@ stdenv.mkDerivation rec { hash = "sha256-8hbSsyeehzd4T3fUhDyebyI/oTHOHr3a8ArYAquivNk="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; buildInputs = [ ncurses diff --git a/pkgs/games/npush/run.nix b/pkgs/games/npush/run.nix index bc4a3b5fda3f20..0da93e880e3837 100644 --- a/pkgs/games/npush/run.nix +++ b/pkgs/games/npush/run.nix @@ -1,7 +1,8 @@ -{ runtimeShell -, symlinkJoin -, writeShellScriptBin -, npush +{ + runtimeShell, + symlinkJoin, + writeShellScriptBin, + npush, }: let diff --git a/pkgs/games/oilrush/default.nix b/pkgs/games/oilrush/default.nix index 62daeda24b4ab7..080fd3053b1fb1 100644 --- a/pkgs/games/oilrush/default.nix +++ b/pkgs/games/oilrush/default.nix @@ -1,20 +1,38 @@ -{ lib, stdenv, config, fetchurl, libX11, libXext, libXinerama, libXrandr -, libXrender, fontconfig, freetype, openal, runtimeShell }: +{ + lib, + stdenv, + config, + fetchurl, + libX11, + libXext, + libXinerama, + libXrandr, + libXrender, + fontconfig, + freetype, + openal, + runtimeShell, +}: -let inherit (lib) makeLibraryPath; in +let + inherit (lib) makeLibraryPath; +in stdenv.mkDerivation { name = "oilrush"; src = - let - url = config.oilrush.url or null; - sha256 = config.oilrush.sha256 or null; - in + let + url = config.oilrush.url or null; + sha256 = config.oilrush.sha256 or null; + in assert url != null && sha256 != null; fetchurl { inherit url sha256; }; shell = stdenv.shell; - arch = if stdenv.hostPlatform.system == "x86_64-linux" then "x64" - else lib.optionalString (stdenv.hostPlatform.system == "i686-linux") "x86"; + arch = + if stdenv.hostPlatform.system == "x86_64-linux" then + "x64" + else + lib.optionalString (stdenv.hostPlatform.system == "i686-linux") "x86"; unpackPhase = '' mkdir oilrush cd oilrush @@ -26,25 +44,68 @@ stdenv.mkDerivation { do patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" $f done - patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${makeLibraryPath [ stdenv.cc.cc libX11 libXext libXrender fontconfig freetype ]}\ + patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${ + makeLibraryPath [ + stdenv.cc.cc + libX11 + libXext + libXrender + fontconfig + freetype + ] + }\ launcher_$arch patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${lib.getLib stdenv.cc.cc}/lib\ libNetwork_$arch.so patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${lib.getLib stdenv.cc.cc}/lib\ libQtCoreUnigine_$arch.so.4 - patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${makeLibraryPath [ stdenv.cc.cc libX11 libXext libXrender fontconfig freetype ]}\ + patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${ + makeLibraryPath [ + stdenv.cc.cc + libX11 + libXext + libXrender + fontconfig + freetype + ] + }\ libQtGuiUnigine_$arch.so.4 patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${lib.getLib stdenv.cc.cc}/lib\ libQtNetworkUnigine_$arch.so.4 - patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${makeLibraryPath [ stdenv.cc.cc libX11 libXext libXrender fontconfig freetype ]}\ + patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${ + makeLibraryPath [ + stdenv.cc.cc + libX11 + libXext + libXrender + fontconfig + freetype + ] + }\ libQtWebKitUnigine_$arch.so.4 patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${lib.getLib stdenv.cc.cc}/lib\ libQtXmlUnigine_$arch.so.4 patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${lib.getLib stdenv.cc.cc}/lib\ libRakNet_$arch.so - patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${makeLibraryPath [ stdenv.cc.cc libX11 libXext libXinerama libXrandr ]}\ + patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${ + makeLibraryPath [ + stdenv.cc.cc + libX11 + libXext + libXinerama + libXrandr + ] + }\ libUnigine_$arch.so - patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${makeLibraryPath [ stdenv.cc.cc libX11 libXext libXinerama libXrandr ]}\ + patchelf --set-rpath ${lib.getLib stdenv.cc.cc}/lib64:${ + makeLibraryPath [ + stdenv.cc.cc + libX11 + libXext + libXinerama + libXrandr + ] + }\ OilRush_$arch ''; installPhase = '' @@ -71,7 +132,7 @@ stdenv.mkDerivation { license = lib.licenses.unfree; #maintainers = with lib.maintainers; [ astsmtl ]; platforms = lib.platforms.linux; - hydraPlatforms = []; + hydraPlatforms = [ ]; sourceProvenance = [ lib.sourceTypes.binaryNativeCode ]; }; diff --git a/pkgs/games/openloco/default.nix b/pkgs/games/openloco/default.nix index caa286c7ef62c0..00c281ca463014 100644 --- a/pkgs/games/openloco/default.nix +++ b/pkgs/games/openloco/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL2 -, cmake -, libpng -, libzip -, openal -, pkg-config -, yaml-cpp -, fmt +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + cmake, + libpng, + libzip, + openal, + pkg-config, + yaml-cpp, + fmt, }: stdenv.mkDerivation rec { diff --git a/pkgs/games/openmw/default.nix b/pkgs/games/openmw/default.nix index 6f1e45b1e68c71..91497b50bd19c4 100644 --- a/pkgs/games/openmw/default.nix +++ b/pkgs/games/openmw/default.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, cmake -, pkg-config -, wrapQtAppsHook -, SDL2 -, CoreMedia -, VideoToolbox -, VideoDecodeAcceleration -, boost -, bullet -# Please unpin this on the next OpenMW release. -, ffmpeg_6 -, libXt -, luajit -, lz4 -, mygui -, openal -, openscenegraph -, recastnavigation -, unshield -, yaml-cpp +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + cmake, + pkg-config, + wrapQtAppsHook, + SDL2, + CoreMedia, + VideoToolbox, + VideoDecodeAcceleration, + boost, + bullet, + # Please unpin this on the next OpenMW release. + ffmpeg_6, + libXt, + luajit, + lz4, + mygui, + openal, + openscenegraph, + recastnavigation, + unshield, + yaml-cpp, }: let @@ -36,12 +37,24 @@ let sha256 = "sha256-/CLRZofZHot8juH78VG1/qhTHPhy5DoPMN+oH8hC58U="; }) ]; - cmakeFlags = (old.cmakeFlags or [ ]) ++ [ - "-Wno-dev" - "-DOpenGL_GL_PREFERENCE=${GL}" - "-DBUILD_OSG_PLUGINS_BY_DEFAULT=0" - "-DBUILD_OSG_DEPRECATED_SERIALIZERS=0" - ] ++ (map (e: "-DBUILD_OSG_PLUGIN_${e}=1") [ "BMP" "DAE" "DDS" "FREETYPE" "JPEG" "OSG" "PNG" "TGA" ]); + cmakeFlags = + (old.cmakeFlags or [ ]) + ++ [ + "-Wno-dev" + "-DOpenGL_GL_PREFERENCE=${GL}" + "-DBUILD_OSG_PLUGINS_BY_DEFAULT=0" + "-DBUILD_OSG_DEPRECATED_SERIALIZERS=0" + ] + ++ (map (e: "-DBUILD_OSG_PLUGIN_${e}=1") [ + "BMP" + "DAE" + "DDS" + "FREETYPE" + "JPEG" + "OSG" + "PNG" + "TGA" + ]); }); bullet' = bullet.overrideDerivation (old: { @@ -65,50 +78,63 @@ stdenv.mkDerivation rec { hash = "sha256-zkjVt3GfQZsFXl2Ht3lCuQtDMYQWxhdFO4aGSb3rsyo="; }; - postPatch = '' - sed '1i#include ' -i components/myguiplatform/myguidatamanager.cpp # gcc12 - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Don't fix Darwin app bundle - sed -i '/fixup_bundle/d' CMakeLists.txt - ''; + postPatch = + '' + sed '1i#include ' -i components/myguiplatform/myguidatamanager.cpp # gcc12 + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Don't fix Darwin app bundle + sed -i '/fixup_bundle/d' CMakeLists.txt + ''; - nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + pkg-config + wrapQtAppsHook + ]; # If not set, OSG plugin .so files become shell scripts on Darwin. dontWrapQtApps = stdenv.hostPlatform.isDarwin; - buildInputs = [ - SDL2 - boost - bullet' - ffmpeg_6 - libXt - luajit - lz4 - mygui - openal - osg' - recastnavigation - unshield - yaml-cpp - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreMedia - VideoDecodeAcceleration - VideoToolbox - ]; + buildInputs = + [ + SDL2 + boost + bullet' + ffmpeg_6 + libXt + luajit + lz4 + mygui + openal + osg' + recastnavigation + unshield + yaml-cpp + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreMedia + VideoDecodeAcceleration + VideoToolbox + ]; - cmakeFlags = [ - "-DOpenGL_GL_PREFERENCE=${GL}" - "-DOPENMW_USE_SYSTEM_RECASTNAVIGATION=1" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DOPENMW_OSX_DEPLOYMENT=ON" - ]; + cmakeFlags = + [ + "-DOpenGL_GL_PREFERENCE=${GL}" + "-DOPENMW_USE_SYSTEM_RECASTNAVIGATION=1" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DOPENMW_OSX_DEPLOYMENT=ON" + ]; meta = with lib; { description = "Unofficial open source engine reimplementation of the game Morrowind"; homepage = "https://openmw.org"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ abbradar marius851000 ]; + maintainers = with maintainers; [ + abbradar + marius851000 + ]; platforms = platforms.linux ++ platforms.darwin; }; } diff --git a/pkgs/games/openmw/tes3mp.nix b/pkgs/games/openmw/tes3mp.nix index 318c28aff92209..f94d288f93d9cb 100644 --- a/pkgs/games/openmw/tes3mp.nix +++ b/pkgs/games/openmw/tes3mp.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, cmake -, openmw -, fetchFromGitHub -, fetchpatch -, luajit -, makeWrapper -, symlinkJoin +{ + lib, + stdenv, + cmake, + openmw, + fetchFromGitHub, + fetchpatch, + luajit, + makeWrapper, + symlinkJoin, }: # revisions are taken from https://github.com/GrimKriegor/TES3MP-deploy @@ -133,7 +134,10 @@ let homepage = "https://tes3mp.com/"; license = licenses.gpl3Only; maintainers = with maintainers; [ peterhoeg ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; }); diff --git a/pkgs/games/openra/default.nix b/pkgs/games/openra/default.nix index 19913a224f46fd..83986abc7c9f05 100644 --- a/pkgs/games/openra/default.nix +++ b/pkgs/games/openra/default.nix @@ -1,7 +1,7 @@ { callPackage }: let - buildOpenRAEngine = callPackage ./build-engine.nix {}; + buildOpenRAEngine = callPackage ./build-engine.nix { }; callPackage' = path: callPackage path { inherit buildOpenRAEngine; }; in { diff --git a/pkgs/games/openra/engines/devtest/deps.nix b/pkgs/games/openra/engines/devtest/deps.nix index 81e72b23038c14..a3d22042756c0e 100644 --- a/pkgs/games/openra/engines/devtest/deps.nix +++ b/pkgs/games/openra/engines/devtest/deps.nix @@ -1,113 +1,546 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "DiscordRichPresence"; version = "1.1.3.18"; sha256 = "0p4bhaggjjfd4gl06yiphqgncxgcq2bws4sjkrw0n2ldf3hgrps3"; }) - (fetchNuGet { pname = "Linguini.Bundle"; version = "0.4.0"; sha256 = "0zf46vfhkhpirw6zls9y7v5zwgckscy7dk8ns77qvxxw7ir6r6v5"; }) - (fetchNuGet { pname = "Linguini.Shared"; version = "0.4.0"; sha256 = "1cxjz4rv1jvxqhlyc1ighy16c5vsah3n0mpx7988cf77kqzm3pzs"; }) - (fetchNuGet { pname = "Linguini.Syntax"; version = "0.3.0"; sha256 = "1qgj6vbdjjl30cqcyn8df30jj15c2ahj7clgb5fwcja47mnw3jd8"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyModel"; version = "6.0.0"; sha256 = "08c4fh1n8vsish1vh7h73mva34g0as4ph29s4lvps7kmjb4z64nl"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.1"; sha256 = "164wycgng4mi9zqi2pnsf1pq6gccbqvw6ib916mqizgjmd8f44pj"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "5.0.0"; sha256 = "0mwpwdflidzgzfx2dlpkvvnkgkr2ayaf0s80737h4wa35gaj11rc"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.3.0"; sha256 = "0j0c1wj4ndj21zsgivsc24whiya605603kxrbiw6wkfdync464wq"; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "5.0.0"; sha256 = "102hvhq2gmlcbq8y2cb7hdr2dnmjzfp2k3asr1ycwrfacwyaak7n"; }) - (fetchNuGet { pname = "Mono.Nat"; version = "3.0.4"; sha256 = "10zvyq60wy02q21dszrk1h3ww23b7bkgjxaapx1ans4d9nwsmlrm"; }) - (fetchNuGet { pname = "MP3Sharp"; version = "1.0.5"; sha256 = "14h506d27g5j5c374dvw7iwn9sl0p7xp58kk95dacnpkzk0hv8yv"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.1"; sha256 = "0fijg0w6iwap8gvzyjnndds0q4b8anwxxvik7y8vgq97dram4srb"; }) - (fetchNuGet { pname = "NuGet.CommandLine"; version = "4.4.1"; sha256 = "1szk5hbw22c1k5747dk95mzsy5vjw7qmvwv1wc9h080h9xzj9aab"; }) - (fetchNuGet { pname = "NVorbis"; version = "0.10.4"; sha256 = "0l4f3vhqc6ly7s8mszwarszgirz6ywx1rjsr1jx0fdlsjl02x6p9"; }) - (fetchNuGet { pname = "OpenRA-Eluant"; version = "1.0.20"; sha256 = "0nq52kdpwsvmhxgcv26wajvn3yxd5l89918rnrzxa463hmyb2rmv"; }) - (fetchNuGet { pname = "OpenRA-Freetype6"; version = "1.0.9"; sha256 = "1i5clsxszmdkhjcdkp9324zidhzp0dsvn7cbcgrnafs18yabjmzq"; }) - (fetchNuGet { pname = "OpenRA-FuzzyLogicLibrary"; version = "1.0.1"; sha256 = "0kn0b8491srbllkpqvvkml02dkixs18y5hgcalnpbw8l5kkmwvim"; }) - (fetchNuGet { pname = "OpenRA-OpenAL-CS"; version = "1.0.19"; sha256 = "1ywm3b15qywrxby3s9wjs9flfjq7vld0gqz0xw4psgvz38gdgh7p"; }) - (fetchNuGet { pname = "OpenRA-SDL2-CS"; version = "1.0.36"; sha256 = "1vywf2bfqkq0mr58gfd5kafv12rri2bzfajajcj8ha9fmhdibj3s"; }) - (fetchNuGet { pname = "Pfim"; version = "0.10.3"; sha256 = "1myjs99g14q1yj3j5hzhx8ic7i3rqh2mi3qy9gdfzi6n9dlz1b3d"; }) - (fetchNuGet { pname = "rix0rrr.BeaconLib"; version = "1.0.2"; sha256 = "0f0yi7hp8v6jvhhv7k4whv8hqqxnx15nvbkll4f1ykaa1w2pr754"; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tracing"; version = "4.3.0"; sha256 = "00j6nv2xgmd3bi347k00m7wr542wjlig53rmj28pmw7ddcn97jbn"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization.Calendars"; version = "4.3.0"; sha256 = "1ghhhk5psqxcg6w88sxkqrc35bxcz27zbqm2y5p5298pv3v7g201"; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0rwpqngkqiapqc5c2cpkj7idhngrgss5qpnqg0yh40mbyflcxf8i"; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1n06gxwlinhs0w7s8a94r1q3lwqzvynxwd3mp10ws9bg6gck8n4r"; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0404wqrc7f2yc0wxv71y3nnybvqx8v4j9d47hlscxy759a525mc3"; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; }) - (fetchNuGet { pname = "runtime.native.System.Net.Http"; version = "4.3.0"; sha256 = "1n6rgz5132lcibbch1qlf0g9jk60r0kqv087hxc0lisy50zpm7kk"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; sha256 = "1b61p6gw1m02cc1ry996fl49liiwky6181dzr873g9ds92zl326q"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0zy5r25jppz48i2bkg8b9lfig24xixg6nm3xyr1379zdnqnpm8f6"; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "096ch4n4s8k82xga80lfmpimpzahd2ip1mgwdqgar0ywbbl6x438"; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1dm8fifl7rf1gy7lnwln78ch4rw54g0pl5g1c189vawavll7p6rj"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; sha256 = "10yc8jdrwgcl44b4g93f1ds76b176bajd3zqi2faf5rvh1vy9smi"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1m9z1k9kzva9n9kwinqxl97x2vgl79qhqjlv17k9s2ymcyv2bwr6"; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1cpx56mcfxz7cpn57wvj18sjisvzq8b5vd9rw16ihd2i6mcp3wa1"; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "15gsm1a8jdmgmf8j5v1slfz8ks124nfdhk2vxs2rw3asrxalg8hi"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0q0n5q1r1wnqmr5i5idsrd9ywl33k0js4pngkwq9p368mbxp8x1w"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1x0g58pbpjrmj2x2qw17rdwwnrcl0wvim2hdwz48lixvwvp22n9c"; }) - (fetchNuGet { pname = "runtime.unix.Microsoft.Win32.Primitives"; version = "4.3.0"; sha256 = "0y61k9zbxhdi0glg154v30kkq7f8646nif8lnnxbvkjpakggd5id"; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; }) - (fetchNuGet { pname = "runtime.unix.System.IO.FileSystem"; version = "4.3.0"; sha256 = "14nbkhvs7sji5r1saj2x8daz82rnf9kx28d3v2qss34qbr32dzix"; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Primitives"; version = "4.3.0"; sha256 = "0bdnglg59pzx9394sy4ic66kmxhqp8q8bvmykdxcbs5mm0ipwwm4"; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; }) - (fetchNuGet { pname = "SharpZipLib"; version = "1.4.2"; sha256 = "0ijrzz2szxjmv2cipk7rpmg14dfaigdkg7xabjvb38ih56m9a27y"; }) - (fetchNuGet { pname = "StyleCop.Analyzers"; version = "1.2.0-beta.435"; sha256 = "0dirz0av24ds2k7hgpss15y4wlhwlzz22qdjvkq0n3g3sxcckrsy"; }) - (fetchNuGet { pname = "StyleCop.Analyzers.Unstable"; version = "1.2.0.435"; sha256 = "1jv4ha4y2c9922n21yf2dvfkmi8qfa8z28gk5zsqdyck08izp9mh"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.3.0"; sha256 = "0fgns20ispwrfqll4q1zc1waqcmylb3zc50ys9x8zlwxh9pmd9jy"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.3.0"; sha256 = "0wi10md9aq33jrkh2c24wr2n9hrpyamsdhsxdcnf43b7y86kkii8"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "4.3.0"; sha256 = "0z6m3pbiy0qw6rn3n209rrzf9x1k4002zh90vwcrsym09ipm2liq"; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; sha256 = "1m3bx6c2s958qligl67q7grkwfz3w53hpy7nc97mh6f7j5k168c4"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.3.0"; sha256 = "1xwl230bkakzzkrggy1l1lxmm3xlhk4bq2pkv790j5lm8g887lxq"; }) - (fetchNuGet { pname = "System.Globalization.Extensions"; version = "4.3.0"; sha256 = "02a5zfxavhv3jd437bsncbhd2fp1zv4gxzakp1an9l6kdq1mcqls"; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; sha256 = "0z2dfrbra9i6y16mm9v1v6k47f0fm617vlb7s5iybjjsz6g1ilmw"; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.3"; sha256 = "0naqahm3wljxb5a911d37mwjqjdxv9l0b49p5dmfyijvni2ppy8a"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; }) - (fetchNuGet { pname = "System.Net.Http"; version = "4.3.4"; sha256 = "0kdp31b8819v88l719j6my0yas6myv9d1viql3qz5577mv819jhl"; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.3.0"; sha256 = "0c87k50rmdgmxx7df2khd9qj7q35j9rzdmm2572cc55dygmdk3ii"; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; }) - (fetchNuGet { pname = "System.Runtime.Loader"; version = "4.3.0"; sha256 = "07fgipa93g1xxgf7193a6vw677mpzgr0z0cfswbvqqb364cva8dk"; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.3.0"; sha256 = "19rav39sr5dky7afygh309qamqqmi9kcwvz3i0c5700v0c5cg61z"; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "5.0.0"; sha256 = "17n3lrrl6vahkqmhlpn3w20afgz09n7i6rv0r3qypngwi7wqdr5r"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.3.0"; sha256 = "03sq183pfl5kp7gkvq77myv7kbpdnq3y0xj7vi4q1kaw54sny0ml"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.3.0"; sha256 = "1k468aswafdgf56ab6yrn7649kfqx2wm9aslywjam1hdmk5yypmv"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Csp"; version = "4.3.0"; sha256 = "1x5wcrddf2s3hb8j78cry7yalca4lb5vfnkrysagbn6r9x6xvrx1"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.3.0"; sha256 = "1jr6w70igqn07k5zs1ph6xja97hxnb3mqbspdrff6cvssgrixs32"; }) - (fetchNuGet { pname = "System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0givpvvj8yc7gv4lhb6s1prq6p2c4147204a0wib89inqzd87gqc"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.3.0"; sha256 = "0pyzncsv48zwly3lw4f2dayqswcfvdwq2nz0dgwmi7fj3pn64wby"; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.3.0"; sha256 = "0valjcz5wksbvijylxijjxb1mp38mdhv03r533vnx1q3ikzdav9h"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; sha256 = "1mpk7xj76lxgz97a5yg93wi8lj0l8p157a5d50mmjy3gbz1904q8"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "6.0.0"; sha256 = "06n9ql3fmhpjl32g3492sj181zjml5dlcc5l76xq2h38c4f87sai"; }) - (fetchNuGet { pname = "System.Text.Json"; version = "6.0.0"; sha256 = "1si2my1g0q0qv1hiqnji4xh9wd05qavxnzj9dwgs23iqvgjky0gl"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; }) - (fetchNuGet { pname = "System.Threading.Channels"; version = "6.0.0"; sha256 = "1qbyi7yymqc56frqy7awvcqc1m7x3xrpx87a37dgb3mbrjg9hlcj"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; }) - (fetchNuGet { pname = "System.ValueTuple"; version = "4.5.0"; sha256 = "00k8ja51d0f9wrq4vv5z2jhq8hy31kac2rg0rv06prylcybzl8cy"; }) - (fetchNuGet { pname = "TagLibSharp"; version = "2.2.0"; sha256 = "0jb0f84p4jd59ha36spyk9q08g6fjap3xywq32rcs2xwzhhqiq0y"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "DiscordRichPresence"; + version = "1.1.3.18"; + sha256 = "0p4bhaggjjfd4gl06yiphqgncxgcq2bws4sjkrw0n2ldf3hgrps3"; + }) + (fetchNuGet { + pname = "Linguini.Bundle"; + version = "0.4.0"; + sha256 = "0zf46vfhkhpirw6zls9y7v5zwgckscy7dk8ns77qvxxw7ir6r6v5"; + }) + (fetchNuGet { + pname = "Linguini.Shared"; + version = "0.4.0"; + sha256 = "1cxjz4rv1jvxqhlyc1ighy16c5vsah3n0mpx7988cf77kqzm3pzs"; + }) + (fetchNuGet { + pname = "Linguini.Syntax"; + version = "0.3.0"; + sha256 = "1qgj6vbdjjl30cqcyn8df30jj15c2ahj7clgb5fwcja47mnw3jd8"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyModel"; + version = "6.0.0"; + sha256 = "08c4fh1n8vsish1vh7h73mva34g0as4ph29s4lvps7kmjb4z64nl"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.1"; + sha256 = "164wycgng4mi9zqi2pnsf1pq6gccbqvw6ib916mqizgjmd8f44pj"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "5.0.0"; + sha256 = "0mwpwdflidzgzfx2dlpkvvnkgkr2ayaf0s80737h4wa35gaj11rc"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.3.0"; + sha256 = "0j0c1wj4ndj21zsgivsc24whiya605603kxrbiw6wkfdync464wq"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "5.0.0"; + sha256 = "102hvhq2gmlcbq8y2cb7hdr2dnmjzfp2k3asr1ycwrfacwyaak7n"; + }) + (fetchNuGet { + pname = "Mono.Nat"; + version = "3.0.4"; + sha256 = "10zvyq60wy02q21dszrk1h3ww23b7bkgjxaapx1ans4d9nwsmlrm"; + }) + (fetchNuGet { + pname = "MP3Sharp"; + version = "1.0.5"; + sha256 = "14h506d27g5j5c374dvw7iwn9sl0p7xp58kk95dacnpkzk0hv8yv"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.1"; + sha256 = "0fijg0w6iwap8gvzyjnndds0q4b8anwxxvik7y8vgq97dram4srb"; + }) + (fetchNuGet { + pname = "NuGet.CommandLine"; + version = "4.4.1"; + sha256 = "1szk5hbw22c1k5747dk95mzsy5vjw7qmvwv1wc9h080h9xzj9aab"; + }) + (fetchNuGet { + pname = "NVorbis"; + version = "0.10.4"; + sha256 = "0l4f3vhqc6ly7s8mszwarszgirz6ywx1rjsr1jx0fdlsjl02x6p9"; + }) + (fetchNuGet { + pname = "OpenRA-Eluant"; + version = "1.0.20"; + sha256 = "0nq52kdpwsvmhxgcv26wajvn3yxd5l89918rnrzxa463hmyb2rmv"; + }) + (fetchNuGet { + pname = "OpenRA-Freetype6"; + version = "1.0.9"; + sha256 = "1i5clsxszmdkhjcdkp9324zidhzp0dsvn7cbcgrnafs18yabjmzq"; + }) + (fetchNuGet { + pname = "OpenRA-FuzzyLogicLibrary"; + version = "1.0.1"; + sha256 = "0kn0b8491srbllkpqvvkml02dkixs18y5hgcalnpbw8l5kkmwvim"; + }) + (fetchNuGet { + pname = "OpenRA-OpenAL-CS"; + version = "1.0.19"; + sha256 = "1ywm3b15qywrxby3s9wjs9flfjq7vld0gqz0xw4psgvz38gdgh7p"; + }) + (fetchNuGet { + pname = "OpenRA-SDL2-CS"; + version = "1.0.36"; + sha256 = "1vywf2bfqkq0mr58gfd5kafv12rri2bzfajajcj8ha9fmhdibj3s"; + }) + (fetchNuGet { + pname = "Pfim"; + version = "0.10.3"; + sha256 = "1myjs99g14q1yj3j5hzhx8ic7i3rqh2mi3qy9gdfzi6n9dlz1b3d"; + }) + (fetchNuGet { + pname = "rix0rrr.BeaconLib"; + version = "1.0.2"; + sha256 = "0f0yi7hp8v6jvhhv7k4whv8hqqxnx15nvbkll4f1ykaa1w2pr754"; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tracing"; + version = "4.3.0"; + sha256 = "00j6nv2xgmd3bi347k00m7wr542wjlig53rmj28pmw7ddcn97jbn"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization.Calendars"; + version = "4.3.0"; + sha256 = "1ghhhk5psqxcg6w88sxkqrc35bxcz27zbqm2y5p5298pv3v7g201"; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0rwpqngkqiapqc5c2cpkj7idhngrgss5qpnqg0yh40mbyflcxf8i"; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1n06gxwlinhs0w7s8a94r1q3lwqzvynxwd3mp10ws9bg6gck8n4r"; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0404wqrc7f2yc0wxv71y3nnybvqx8v4j9d47hlscxy759a525mc3"; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Http"; + version = "4.3.0"; + sha256 = "1n6rgz5132lcibbch1qlf0g9jk60r0kqv087hxc0lisy50zpm7kk"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + sha256 = "1b61p6gw1m02cc1ry996fl49liiwky6181dzr873g9ds92zl326q"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0zy5r25jppz48i2bkg8b9lfig24xixg6nm3xyr1379zdnqnpm8f6"; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "096ch4n4s8k82xga80lfmpimpzahd2ip1mgwdqgar0ywbbl6x438"; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1dm8fifl7rf1gy7lnwln78ch4rw54g0pl5g1c189vawavll7p6rj"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + sha256 = "10yc8jdrwgcl44b4g93f1ds76b176bajd3zqi2faf5rvh1vy9smi"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1m9z1k9kzva9n9kwinqxl97x2vgl79qhqjlv17k9s2ymcyv2bwr6"; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1cpx56mcfxz7cpn57wvj18sjisvzq8b5vd9rw16ihd2i6mcp3wa1"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "15gsm1a8jdmgmf8j5v1slfz8ks124nfdhk2vxs2rw3asrxalg8hi"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0q0n5q1r1wnqmr5i5idsrd9ywl33k0js4pngkwq9p368mbxp8x1w"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1x0g58pbpjrmj2x2qw17rdwwnrcl0wvim2hdwz48lixvwvp22n9c"; + }) + (fetchNuGet { + pname = "runtime.unix.Microsoft.Win32.Primitives"; + version = "4.3.0"; + sha256 = "0y61k9zbxhdi0glg154v30kkq7f8646nif8lnnxbvkjpakggd5id"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; + }) + (fetchNuGet { + pname = "runtime.unix.System.IO.FileSystem"; + version = "4.3.0"; + sha256 = "14nbkhvs7sji5r1saj2x8daz82rnf9kx28d3v2qss34qbr32dzix"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Primitives"; + version = "4.3.0"; + sha256 = "0bdnglg59pzx9394sy4ic66kmxhqp8q8bvmykdxcbs5mm0ipwwm4"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; + }) + (fetchNuGet { + pname = "SharpZipLib"; + version = "1.4.2"; + sha256 = "0ijrzz2szxjmv2cipk7rpmg14dfaigdkg7xabjvb38ih56m9a27y"; + }) + (fetchNuGet { + pname = "StyleCop.Analyzers"; + version = "1.2.0-beta.435"; + sha256 = "0dirz0av24ds2k7hgpss15y4wlhwlzz22qdjvkq0n3g3sxcckrsy"; + }) + (fetchNuGet { + pname = "StyleCop.Analyzers.Unstable"; + version = "1.2.0.435"; + sha256 = "1jv4ha4y2c9922n21yf2dvfkmi8qfa8z28gk5zsqdyck08izp9mh"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.3.0"; + sha256 = "0fgns20ispwrfqll4q1zc1waqcmylb3zc50ys9x8zlwxh9pmd9jy"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.3.0"; + sha256 = "0wi10md9aq33jrkh2c24wr2n9hrpyamsdhsxdcnf43b7y86kkii8"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "4.3.0"; + sha256 = "0z6m3pbiy0qw6rn3n209rrzf9x1k4002zh90vwcrsym09ipm2liq"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + sha256 = "1m3bx6c2s958qligl67q7grkwfz3w53hpy7nc97mh6f7j5k168c4"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.3.0"; + sha256 = "1xwl230bkakzzkrggy1l1lxmm3xlhk4bq2pkv790j5lm8g887lxq"; + }) + (fetchNuGet { + pname = "System.Globalization.Extensions"; + version = "4.3.0"; + sha256 = "02a5zfxavhv3jd437bsncbhd2fp1zv4gxzakp1an9l6kdq1mcqls"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + sha256 = "0z2dfrbra9i6y16mm9v1v6k47f0fm617vlb7s5iybjjsz6g1ilmw"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.3"; + sha256 = "0naqahm3wljxb5a911d37mwjqjdxv9l0b49p5dmfyijvni2ppy8a"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; + }) + (fetchNuGet { + pname = "System.Net.Http"; + version = "4.3.4"; + sha256 = "0kdp31b8819v88l719j6my0yas6myv9d1viql3qz5577mv819jhl"; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.3.0"; + sha256 = "0c87k50rmdgmxx7df2khd9qj7q35j9rzdmm2572cc55dygmdk3ii"; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; + }) + (fetchNuGet { + pname = "System.Runtime.Loader"; + version = "4.3.0"; + sha256 = "07fgipa93g1xxgf7193a6vw677mpzgr0z0cfswbvqqb364cva8dk"; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.3.0"; + sha256 = "19rav39sr5dky7afygh309qamqqmi9kcwvz3i0c5700v0c5cg61z"; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "5.0.0"; + sha256 = "17n3lrrl6vahkqmhlpn3w20afgz09n7i6rv0r3qypngwi7wqdr5r"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.3.0"; + sha256 = "03sq183pfl5kp7gkvq77myv7kbpdnq3y0xj7vi4q1kaw54sny0ml"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.3.0"; + sha256 = "1k468aswafdgf56ab6yrn7649kfqx2wm9aslywjam1hdmk5yypmv"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Csp"; + version = "4.3.0"; + sha256 = "1x5wcrddf2s3hb8j78cry7yalca4lb5vfnkrysagbn6r9x6xvrx1"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.3.0"; + sha256 = "1jr6w70igqn07k5zs1ph6xja97hxnb3mqbspdrff6cvssgrixs32"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0givpvvj8yc7gv4lhb6s1prq6p2c4147204a0wib89inqzd87gqc"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.3.0"; + sha256 = "0pyzncsv48zwly3lw4f2dayqswcfvdwq2nz0dgwmi7fj3pn64wby"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.3.0"; + sha256 = "0valjcz5wksbvijylxijjxb1mp38mdhv03r533vnx1q3ikzdav9h"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + sha256 = "1mpk7xj76lxgz97a5yg93wi8lj0l8p157a5d50mmjy3gbz1904q8"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "6.0.0"; + sha256 = "06n9ql3fmhpjl32g3492sj181zjml5dlcc5l76xq2h38c4f87sai"; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "6.0.0"; + sha256 = "1si2my1g0q0qv1hiqnji4xh9wd05qavxnzj9dwgs23iqvgjky0gl"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; + }) + (fetchNuGet { + pname = "System.Threading.Channels"; + version = "6.0.0"; + sha256 = "1qbyi7yymqc56frqy7awvcqc1m7x3xrpx87a37dgb3mbrjg9hlcj"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; + }) + (fetchNuGet { + pname = "System.ValueTuple"; + version = "4.5.0"; + sha256 = "00k8ja51d0f9wrq4vv5z2jhq8hy31kac2rg0rv06prylcybzl8cy"; + }) + (fetchNuGet { + pname = "TagLibSharp"; + version = "2.2.0"; + sha256 = "0jb0f84p4jd59ha36spyk9q08g6fjap3xywq32rcs2xwzhhqiq0y"; + }) ] diff --git a/pkgs/games/openra/engines/release/deps.nix b/pkgs/games/openra/engines/release/deps.nix index 877e93c6086363..175ebaf14c0df0 100644 --- a/pkgs/games/openra/engines/release/deps.nix +++ b/pkgs/games/openra/engines/release/deps.nix @@ -1,113 +1,546 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "DiscordRichPresence"; version = "1.1.3.18"; sha256 = "0p4bhaggjjfd4gl06yiphqgncxgcq2bws4sjkrw0n2ldf3hgrps3"; }) - (fetchNuGet { pname = "Linguini.Bundle"; version = "0.5.0"; sha256 = "0515ifvvqhmhwdf7kw1wpamxn588hi150v6b8p4jfmr07y1dc4ml"; }) - (fetchNuGet { pname = "Linguini.Shared"; version = "0.5.0"; sha256 = "1y45lf6ipa53469sdz110d16rxfyrkdr2xscgagwg07lr2833nbb"; }) - (fetchNuGet { pname = "Linguini.Syntax"; version = "0.5.0"; sha256 = "06438fc5mizi702n8d7pqa21n5i7kwl1bwzxfy1l883j9gh64gjp"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyModel"; version = "6.0.0"; sha256 = "08c4fh1n8vsish1vh7h73mva34g0as4ph29s4lvps7kmjb4z64nl"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.1"; sha256 = "164wycgng4mi9zqi2pnsf1pq6gccbqvw6ib916mqizgjmd8f44pj"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "5.0.0"; sha256 = "0mwpwdflidzgzfx2dlpkvvnkgkr2ayaf0s80737h4wa35gaj11rc"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.3.0"; sha256 = "0j0c1wj4ndj21zsgivsc24whiya605603kxrbiw6wkfdync464wq"; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "5.0.0"; sha256 = "102hvhq2gmlcbq8y2cb7hdr2dnmjzfp2k3asr1ycwrfacwyaak7n"; }) - (fetchNuGet { pname = "Mono.Nat"; version = "3.0.4"; sha256 = "10zvyq60wy02q21dszrk1h3ww23b7bkgjxaapx1ans4d9nwsmlrm"; }) - (fetchNuGet { pname = "MP3Sharp"; version = "1.0.5"; sha256 = "14h506d27g5j5c374dvw7iwn9sl0p7xp58kk95dacnpkzk0hv8yv"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.1"; sha256 = "0fijg0w6iwap8gvzyjnndds0q4b8anwxxvik7y8vgq97dram4srb"; }) - (fetchNuGet { pname = "NuGet.CommandLine"; version = "4.4.1"; sha256 = "1szk5hbw22c1k5747dk95mzsy5vjw7qmvwv1wc9h080h9xzj9aab"; }) - (fetchNuGet { pname = "NVorbis"; version = "0.10.5"; sha256 = "0yiqqlb8mmnz04yq4iykkxq9np4m29z29bjwm5ic0adyq8fr4cnl"; }) - (fetchNuGet { pname = "OpenRA-Eluant"; version = "1.0.22"; sha256 = "134ar57v7k5i4zb7xl9j2f6abwjjhl5kwx3cap5zrb5jdfb1x42p"; }) - (fetchNuGet { pname = "OpenRA-Freetype6"; version = "1.0.11"; sha256 = "1gb1mpckj2ji64fyca6cd1lbl7adyfjl5czgvhllhgv5h2jfwir1"; }) - (fetchNuGet { pname = "OpenRA-FuzzyLogicLibrary"; version = "1.0.1"; sha256 = "0kn0b8491srbllkpqvvkml02dkixs18y5hgcalnpbw8l5kkmwvim"; }) - (fetchNuGet { pname = "OpenRA-OpenAL-CS"; version = "1.0.22"; sha256 = "05bxqdams1s4la5fqlsijzmja1wf59gcy5y04jh91996q9glkq1d"; }) - (fetchNuGet { pname = "OpenRA-SDL2-CS"; version = "1.0.40"; sha256 = "0ysrryn63akysiv92mh0mra87pd8l8zvahp8pbxsliapdfq2n2qk"; }) - (fetchNuGet { pname = "Pfim"; version = "0.11.2"; sha256 = "1mf91sfxa4c5xp5qmgyc85v84aprhgdy951f1f41xmygvmkk94mp"; }) - (fetchNuGet { pname = "rix0rrr.BeaconLib"; version = "1.0.2"; sha256 = "0f0yi7hp8v6jvhhv7k4whv8hqqxnx15nvbkll4f1ykaa1w2pr754"; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tracing"; version = "4.3.0"; sha256 = "00j6nv2xgmd3bi347k00m7wr542wjlig53rmj28pmw7ddcn97jbn"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization.Calendars"; version = "4.3.0"; sha256 = "1ghhhk5psqxcg6w88sxkqrc35bxcz27zbqm2y5p5298pv3v7g201"; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0rwpqngkqiapqc5c2cpkj7idhngrgss5qpnqg0yh40mbyflcxf8i"; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1n06gxwlinhs0w7s8a94r1q3lwqzvynxwd3mp10ws9bg6gck8n4r"; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0404wqrc7f2yc0wxv71y3nnybvqx8v4j9d47hlscxy759a525mc3"; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; }) - (fetchNuGet { pname = "runtime.native.System.Net.Http"; version = "4.3.0"; sha256 = "1n6rgz5132lcibbch1qlf0g9jk60r0kqv087hxc0lisy50zpm7kk"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; sha256 = "1b61p6gw1m02cc1ry996fl49liiwky6181dzr873g9ds92zl326q"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0zy5r25jppz48i2bkg8b9lfig24xixg6nm3xyr1379zdnqnpm8f6"; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "096ch4n4s8k82xga80lfmpimpzahd2ip1mgwdqgar0ywbbl6x438"; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1dm8fifl7rf1gy7lnwln78ch4rw54g0pl5g1c189vawavll7p6rj"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; sha256 = "10yc8jdrwgcl44b4g93f1ds76b176bajd3zqi2faf5rvh1vy9smi"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1m9z1k9kzva9n9kwinqxl97x2vgl79qhqjlv17k9s2ymcyv2bwr6"; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1cpx56mcfxz7cpn57wvj18sjisvzq8b5vd9rw16ihd2i6mcp3wa1"; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "15gsm1a8jdmgmf8j5v1slfz8ks124nfdhk2vxs2rw3asrxalg8hi"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0q0n5q1r1wnqmr5i5idsrd9ywl33k0js4pngkwq9p368mbxp8x1w"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1x0g58pbpjrmj2x2qw17rdwwnrcl0wvim2hdwz48lixvwvp22n9c"; }) - (fetchNuGet { pname = "runtime.unix.Microsoft.Win32.Primitives"; version = "4.3.0"; sha256 = "0y61k9zbxhdi0glg154v30kkq7f8646nif8lnnxbvkjpakggd5id"; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; }) - (fetchNuGet { pname = "runtime.unix.System.IO.FileSystem"; version = "4.3.0"; sha256 = "14nbkhvs7sji5r1saj2x8daz82rnf9kx28d3v2qss34qbr32dzix"; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Primitives"; version = "4.3.0"; sha256 = "0bdnglg59pzx9394sy4ic66kmxhqp8q8bvmykdxcbs5mm0ipwwm4"; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; }) - (fetchNuGet { pname = "SharpZipLib"; version = "1.4.2"; sha256 = "0ijrzz2szxjmv2cipk7rpmg14dfaigdkg7xabjvb38ih56m9a27y"; }) - (fetchNuGet { pname = "StyleCop.Analyzers"; version = "1.2.0-beta.435"; sha256 = "0dirz0av24ds2k7hgpss15y4wlhwlzz22qdjvkq0n3g3sxcckrsy"; }) - (fetchNuGet { pname = "StyleCop.Analyzers.Unstable"; version = "1.2.0.435"; sha256 = "1jv4ha4y2c9922n21yf2dvfkmi8qfa8z28gk5zsqdyck08izp9mh"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.3.0"; sha256 = "0fgns20ispwrfqll4q1zc1waqcmylb3zc50ys9x8zlwxh9pmd9jy"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.3.0"; sha256 = "0wi10md9aq33jrkh2c24wr2n9hrpyamsdhsxdcnf43b7y86kkii8"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "4.3.0"; sha256 = "0z6m3pbiy0qw6rn3n209rrzf9x1k4002zh90vwcrsym09ipm2liq"; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; sha256 = "1m3bx6c2s958qligl67q7grkwfz3w53hpy7nc97mh6f7j5k168c4"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.3.0"; sha256 = "1xwl230bkakzzkrggy1l1lxmm3xlhk4bq2pkv790j5lm8g887lxq"; }) - (fetchNuGet { pname = "System.Globalization.Extensions"; version = "4.3.0"; sha256 = "02a5zfxavhv3jd437bsncbhd2fp1zv4gxzakp1an9l6kdq1mcqls"; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; sha256 = "0z2dfrbra9i6y16mm9v1v6k47f0fm617vlb7s5iybjjsz6g1ilmw"; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.3"; sha256 = "0naqahm3wljxb5a911d37mwjqjdxv9l0b49p5dmfyijvni2ppy8a"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; }) - (fetchNuGet { pname = "System.Net.Http"; version = "4.3.4"; sha256 = "0kdp31b8819v88l719j6my0yas6myv9d1viql3qz5577mv819jhl"; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.3.0"; sha256 = "0c87k50rmdgmxx7df2khd9qj7q35j9rzdmm2572cc55dygmdk3ii"; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; }) - (fetchNuGet { pname = "System.Runtime.Loader"; version = "4.3.0"; sha256 = "07fgipa93g1xxgf7193a6vw677mpzgr0z0cfswbvqqb364cva8dk"; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.3.0"; sha256 = "19rav39sr5dky7afygh309qamqqmi9kcwvz3i0c5700v0c5cg61z"; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "5.0.0"; sha256 = "17n3lrrl6vahkqmhlpn3w20afgz09n7i6rv0r3qypngwi7wqdr5r"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.3.0"; sha256 = "03sq183pfl5kp7gkvq77myv7kbpdnq3y0xj7vi4q1kaw54sny0ml"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.3.0"; sha256 = "1k468aswafdgf56ab6yrn7649kfqx2wm9aslywjam1hdmk5yypmv"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Csp"; version = "4.3.0"; sha256 = "1x5wcrddf2s3hb8j78cry7yalca4lb5vfnkrysagbn6r9x6xvrx1"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.3.0"; sha256 = "1jr6w70igqn07k5zs1ph6xja97hxnb3mqbspdrff6cvssgrixs32"; }) - (fetchNuGet { pname = "System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0givpvvj8yc7gv4lhb6s1prq6p2c4147204a0wib89inqzd87gqc"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.3.0"; sha256 = "0pyzncsv48zwly3lw4f2dayqswcfvdwq2nz0dgwmi7fj3pn64wby"; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.3.0"; sha256 = "0valjcz5wksbvijylxijjxb1mp38mdhv03r533vnx1q3ikzdav9h"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; sha256 = "1mpk7xj76lxgz97a5yg93wi8lj0l8p157a5d50mmjy3gbz1904q8"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "6.0.0"; sha256 = "06n9ql3fmhpjl32g3492sj181zjml5dlcc5l76xq2h38c4f87sai"; }) - (fetchNuGet { pname = "System.Text.Json"; version = "6.0.0"; sha256 = "1si2my1g0q0qv1hiqnji4xh9wd05qavxnzj9dwgs23iqvgjky0gl"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; }) - (fetchNuGet { pname = "System.Threading.Channels"; version = "6.0.0"; sha256 = "1qbyi7yymqc56frqy7awvcqc1m7x3xrpx87a37dgb3mbrjg9hlcj"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; }) - (fetchNuGet { pname = "System.ValueTuple"; version = "4.5.0"; sha256 = "00k8ja51d0f9wrq4vv5z2jhq8hy31kac2rg0rv06prylcybzl8cy"; }) - (fetchNuGet { pname = "TagLibSharp"; version = "2.3.0"; sha256 = "1z7v9lrkss1f8s42sclsq3az9zjihgmhyxnwhjyf0scgk1amngrw"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "DiscordRichPresence"; + version = "1.1.3.18"; + sha256 = "0p4bhaggjjfd4gl06yiphqgncxgcq2bws4sjkrw0n2ldf3hgrps3"; + }) + (fetchNuGet { + pname = "Linguini.Bundle"; + version = "0.5.0"; + sha256 = "0515ifvvqhmhwdf7kw1wpamxn588hi150v6b8p4jfmr07y1dc4ml"; + }) + (fetchNuGet { + pname = "Linguini.Shared"; + version = "0.5.0"; + sha256 = "1y45lf6ipa53469sdz110d16rxfyrkdr2xscgagwg07lr2833nbb"; + }) + (fetchNuGet { + pname = "Linguini.Syntax"; + version = "0.5.0"; + sha256 = "06438fc5mizi702n8d7pqa21n5i7kwl1bwzxfy1l883j9gh64gjp"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyModel"; + version = "6.0.0"; + sha256 = "08c4fh1n8vsish1vh7h73mva34g0as4ph29s4lvps7kmjb4z64nl"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.1"; + sha256 = "164wycgng4mi9zqi2pnsf1pq6gccbqvw6ib916mqizgjmd8f44pj"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "5.0.0"; + sha256 = "0mwpwdflidzgzfx2dlpkvvnkgkr2ayaf0s80737h4wa35gaj11rc"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.3.0"; + sha256 = "0j0c1wj4ndj21zsgivsc24whiya605603kxrbiw6wkfdync464wq"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "5.0.0"; + sha256 = "102hvhq2gmlcbq8y2cb7hdr2dnmjzfp2k3asr1ycwrfacwyaak7n"; + }) + (fetchNuGet { + pname = "Mono.Nat"; + version = "3.0.4"; + sha256 = "10zvyq60wy02q21dszrk1h3ww23b7bkgjxaapx1ans4d9nwsmlrm"; + }) + (fetchNuGet { + pname = "MP3Sharp"; + version = "1.0.5"; + sha256 = "14h506d27g5j5c374dvw7iwn9sl0p7xp58kk95dacnpkzk0hv8yv"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.1"; + sha256 = "0fijg0w6iwap8gvzyjnndds0q4b8anwxxvik7y8vgq97dram4srb"; + }) + (fetchNuGet { + pname = "NuGet.CommandLine"; + version = "4.4.1"; + sha256 = "1szk5hbw22c1k5747dk95mzsy5vjw7qmvwv1wc9h080h9xzj9aab"; + }) + (fetchNuGet { + pname = "NVorbis"; + version = "0.10.5"; + sha256 = "0yiqqlb8mmnz04yq4iykkxq9np4m29z29bjwm5ic0adyq8fr4cnl"; + }) + (fetchNuGet { + pname = "OpenRA-Eluant"; + version = "1.0.22"; + sha256 = "134ar57v7k5i4zb7xl9j2f6abwjjhl5kwx3cap5zrb5jdfb1x42p"; + }) + (fetchNuGet { + pname = "OpenRA-Freetype6"; + version = "1.0.11"; + sha256 = "1gb1mpckj2ji64fyca6cd1lbl7adyfjl5czgvhllhgv5h2jfwir1"; + }) + (fetchNuGet { + pname = "OpenRA-FuzzyLogicLibrary"; + version = "1.0.1"; + sha256 = "0kn0b8491srbllkpqvvkml02dkixs18y5hgcalnpbw8l5kkmwvim"; + }) + (fetchNuGet { + pname = "OpenRA-OpenAL-CS"; + version = "1.0.22"; + sha256 = "05bxqdams1s4la5fqlsijzmja1wf59gcy5y04jh91996q9glkq1d"; + }) + (fetchNuGet { + pname = "OpenRA-SDL2-CS"; + version = "1.0.40"; + sha256 = "0ysrryn63akysiv92mh0mra87pd8l8zvahp8pbxsliapdfq2n2qk"; + }) + (fetchNuGet { + pname = "Pfim"; + version = "0.11.2"; + sha256 = "1mf91sfxa4c5xp5qmgyc85v84aprhgdy951f1f41xmygvmkk94mp"; + }) + (fetchNuGet { + pname = "rix0rrr.BeaconLib"; + version = "1.0.2"; + sha256 = "0f0yi7hp8v6jvhhv7k4whv8hqqxnx15nvbkll4f1ykaa1w2pr754"; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tracing"; + version = "4.3.0"; + sha256 = "00j6nv2xgmd3bi347k00m7wr542wjlig53rmj28pmw7ddcn97jbn"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization.Calendars"; + version = "4.3.0"; + sha256 = "1ghhhk5psqxcg6w88sxkqrc35bxcz27zbqm2y5p5298pv3v7g201"; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0rwpqngkqiapqc5c2cpkj7idhngrgss5qpnqg0yh40mbyflcxf8i"; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1n06gxwlinhs0w7s8a94r1q3lwqzvynxwd3mp10ws9bg6gck8n4r"; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0404wqrc7f2yc0wxv71y3nnybvqx8v4j9d47hlscxy759a525mc3"; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Http"; + version = "4.3.0"; + sha256 = "1n6rgz5132lcibbch1qlf0g9jk60r0kqv087hxc0lisy50zpm7kk"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + sha256 = "1b61p6gw1m02cc1ry996fl49liiwky6181dzr873g9ds92zl326q"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0zy5r25jppz48i2bkg8b9lfig24xixg6nm3xyr1379zdnqnpm8f6"; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "096ch4n4s8k82xga80lfmpimpzahd2ip1mgwdqgar0ywbbl6x438"; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1dm8fifl7rf1gy7lnwln78ch4rw54g0pl5g1c189vawavll7p6rj"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + sha256 = "10yc8jdrwgcl44b4g93f1ds76b176bajd3zqi2faf5rvh1vy9smi"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1m9z1k9kzva9n9kwinqxl97x2vgl79qhqjlv17k9s2ymcyv2bwr6"; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1cpx56mcfxz7cpn57wvj18sjisvzq8b5vd9rw16ihd2i6mcp3wa1"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "15gsm1a8jdmgmf8j5v1slfz8ks124nfdhk2vxs2rw3asrxalg8hi"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0q0n5q1r1wnqmr5i5idsrd9ywl33k0js4pngkwq9p368mbxp8x1w"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1x0g58pbpjrmj2x2qw17rdwwnrcl0wvim2hdwz48lixvwvp22n9c"; + }) + (fetchNuGet { + pname = "runtime.unix.Microsoft.Win32.Primitives"; + version = "4.3.0"; + sha256 = "0y61k9zbxhdi0glg154v30kkq7f8646nif8lnnxbvkjpakggd5id"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; + }) + (fetchNuGet { + pname = "runtime.unix.System.IO.FileSystem"; + version = "4.3.0"; + sha256 = "14nbkhvs7sji5r1saj2x8daz82rnf9kx28d3v2qss34qbr32dzix"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Primitives"; + version = "4.3.0"; + sha256 = "0bdnglg59pzx9394sy4ic66kmxhqp8q8bvmykdxcbs5mm0ipwwm4"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; + }) + (fetchNuGet { + pname = "SharpZipLib"; + version = "1.4.2"; + sha256 = "0ijrzz2szxjmv2cipk7rpmg14dfaigdkg7xabjvb38ih56m9a27y"; + }) + (fetchNuGet { + pname = "StyleCop.Analyzers"; + version = "1.2.0-beta.435"; + sha256 = "0dirz0av24ds2k7hgpss15y4wlhwlzz22qdjvkq0n3g3sxcckrsy"; + }) + (fetchNuGet { + pname = "StyleCop.Analyzers.Unstable"; + version = "1.2.0.435"; + sha256 = "1jv4ha4y2c9922n21yf2dvfkmi8qfa8z28gk5zsqdyck08izp9mh"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.3.0"; + sha256 = "0fgns20ispwrfqll4q1zc1waqcmylb3zc50ys9x8zlwxh9pmd9jy"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.3.0"; + sha256 = "0wi10md9aq33jrkh2c24wr2n9hrpyamsdhsxdcnf43b7y86kkii8"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "4.3.0"; + sha256 = "0z6m3pbiy0qw6rn3n209rrzf9x1k4002zh90vwcrsym09ipm2liq"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + sha256 = "1m3bx6c2s958qligl67q7grkwfz3w53hpy7nc97mh6f7j5k168c4"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.3.0"; + sha256 = "1xwl230bkakzzkrggy1l1lxmm3xlhk4bq2pkv790j5lm8g887lxq"; + }) + (fetchNuGet { + pname = "System.Globalization.Extensions"; + version = "4.3.0"; + sha256 = "02a5zfxavhv3jd437bsncbhd2fp1zv4gxzakp1an9l6kdq1mcqls"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + sha256 = "0z2dfrbra9i6y16mm9v1v6k47f0fm617vlb7s5iybjjsz6g1ilmw"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.3"; + sha256 = "0naqahm3wljxb5a911d37mwjqjdxv9l0b49p5dmfyijvni2ppy8a"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; + }) + (fetchNuGet { + pname = "System.Net.Http"; + version = "4.3.4"; + sha256 = "0kdp31b8819v88l719j6my0yas6myv9d1viql3qz5577mv819jhl"; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.3.0"; + sha256 = "0c87k50rmdgmxx7df2khd9qj7q35j9rzdmm2572cc55dygmdk3ii"; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; + }) + (fetchNuGet { + pname = "System.Runtime.Loader"; + version = "4.3.0"; + sha256 = "07fgipa93g1xxgf7193a6vw677mpzgr0z0cfswbvqqb364cva8dk"; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.3.0"; + sha256 = "19rav39sr5dky7afygh309qamqqmi9kcwvz3i0c5700v0c5cg61z"; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "5.0.0"; + sha256 = "17n3lrrl6vahkqmhlpn3w20afgz09n7i6rv0r3qypngwi7wqdr5r"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.3.0"; + sha256 = "03sq183pfl5kp7gkvq77myv7kbpdnq3y0xj7vi4q1kaw54sny0ml"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.3.0"; + sha256 = "1k468aswafdgf56ab6yrn7649kfqx2wm9aslywjam1hdmk5yypmv"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Csp"; + version = "4.3.0"; + sha256 = "1x5wcrddf2s3hb8j78cry7yalca4lb5vfnkrysagbn6r9x6xvrx1"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.3.0"; + sha256 = "1jr6w70igqn07k5zs1ph6xja97hxnb3mqbspdrff6cvssgrixs32"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0givpvvj8yc7gv4lhb6s1prq6p2c4147204a0wib89inqzd87gqc"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.3.0"; + sha256 = "0pyzncsv48zwly3lw4f2dayqswcfvdwq2nz0dgwmi7fj3pn64wby"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.3.0"; + sha256 = "0valjcz5wksbvijylxijjxb1mp38mdhv03r533vnx1q3ikzdav9h"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + sha256 = "1mpk7xj76lxgz97a5yg93wi8lj0l8p157a5d50mmjy3gbz1904q8"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "6.0.0"; + sha256 = "06n9ql3fmhpjl32g3492sj181zjml5dlcc5l76xq2h38c4f87sai"; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "6.0.0"; + sha256 = "1si2my1g0q0qv1hiqnji4xh9wd05qavxnzj9dwgs23iqvgjky0gl"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; + }) + (fetchNuGet { + pname = "System.Threading.Channels"; + version = "6.0.0"; + sha256 = "1qbyi7yymqc56frqy7awvcqc1m7x3xrpx87a37dgb3mbrjg9hlcj"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; + }) + (fetchNuGet { + pname = "System.ValueTuple"; + version = "4.5.0"; + sha256 = "00k8ja51d0f9wrq4vv5z2jhq8hy31kac2rg0rv06prylcybzl8cy"; + }) + (fetchNuGet { + pname = "TagLibSharp"; + version = "2.3.0"; + sha256 = "1z7v9lrkss1f8s42sclsq3az9zjihgmhyxnwhjyf0scgk1amngrw"; + }) ] diff --git a/pkgs/games/openra_2019/common.nix b/pkgs/games/openra_2019/common.nix index f04f0cf5078a9b..a32f57d69e12de 100644 --- a/pkgs/games/openra_2019/common.nix +++ b/pkgs/games/openra_2019/common.nix @@ -1,12 +1,25 @@ -/* The reusable code, and package attributes, between OpenRA engine packages (engine.nix) - and out-of-tree mod packages (mod.nix). +/* + The reusable code, and package attributes, between OpenRA engine packages (engine.nix) + and out-of-tree mod packages (mod.nix). */ -{ lib, makeSetupHook, curl, unzip, dos2unix, pkg-config, makeWrapper -, lua, mono, python3 -, libGL, freetype, openal, SDL2 -# It is not necessary to run the game, but it is nicer to be given an error dialog in the case of failure, -# rather than having to look to the logs why it is not starting. -, zenity +{ + lib, + makeSetupHook, + curl, + unzip, + dos2unix, + pkg-config, + makeWrapper, + lua, + mono, + python3, + libGL, + freetype, + openal, + SDL2, + # It is not necessary to run the game, but it is nicer to be given an error dialog in the case of failure, + # rather than having to look to the logs why it is not starting. + zenity, }: let @@ -19,13 +32,25 @@ let platforms ; - path = makeBinPath ([ mono python3 ] ++ optional (zenity != null) zenity); - rpath = makeLibraryPath [ lua freetype openal SDL2 ]; + path = makeBinPath ( + [ + mono + python3 + ] + ++ optional (zenity != null) zenity + ); + rpath = makeLibraryPath [ + lua + freetype + openal + SDL2 + ]; mkdirp = makeSetupHook { name = "openra-mkdirp-hook"; } ./mkdirp.sh; -in { +in +{ patchEngine = dir: version: '' sed -i \ -e 's/^VERSION.*/VERSION = ${version}/g' \ @@ -70,7 +95,10 @@ in { dontStrip = true; meta = { - maintainers = with maintainers; [ fusion809 msteen ]; + maintainers = with maintainers; [ + fusion809 + msteen + ]; license = licenses.gpl3; platforms = platforms.linux; }; diff --git a/pkgs/games/openra_2019/default.nix b/pkgs/games/openra_2019/default.nix index 97cdb4335d2c32..77b2da8ad52501 100644 --- a/pkgs/games/openra_2019/default.nix +++ b/pkgs/games/openra_2019/default.nix @@ -1,69 +1,133 @@ -/* This file defines all OpenRA packages under `openraPackages`, - e.g. the OpenRA release engine can be found at `openraPackages.engines.release` (see `engines.nix`), - or the out-of-tree mod "Combined Arms" can be found at `openraPackages.mods.ca` (see `mods.nix`). - The `openra` package is just an alias to `openraPackages.engines.release`, - and just provides the mods included in the source code of the engine. - Additional engines or mods can be added with `openraPackages.buildOpenRAEngine` (function around `engine.nix`) - and `openraPackages.buildOpenRAMod` (function around `mod.nix`), respectively. +/* + This file defines all OpenRA packages under `openraPackages`, + e.g. the OpenRA release engine can be found at `openraPackages.engines.release` (see `engines.nix`), + or the out-of-tree mod "Combined Arms" can be found at `openraPackages.mods.ca` (see `mods.nix`). + The `openra` package is just an alias to `openraPackages.engines.release`, + and just provides the mods included in the source code of the engine. + Additional engines or mods can be added with `openraPackages.buildOpenRAEngine` (function around `engine.nix`) + and `openraPackages.buildOpenRAMod` (function around `mod.nix`), respectively. */ { pkgs, lib }: let - /* Building an engine or out-of-tree mod is very similar, - but different enough not to be able to build them with the same package definition, - so instaed we define what is common between them in a separate file. + /* + Building an engine or out-of-tree mod is very similar, + but different enough not to be able to build them with the same package definition, + so instaed we define what is common between them in a separate file. - Although `callPackage` could be used, it would require undoing `makeOverridable`, - because `common.nix` does not define a package, but just an attribute set, - which is directly passed as part of the argument to the engines and mods `callPackage`, - so either the attributes added by `makeOverridable` have to be removed - or the engine and mod package definitions will need to add `...` to the argument list. + Although `callPackage` could be used, it would require undoing `makeOverridable`, + because `common.nix` does not define a package, but just an attribute set, + which is directly passed as part of the argument to the engines and mods `callPackage`, + so either the attributes added by `makeOverridable` have to be removed + or the engine and mod package definitions will need to add `...` to the argument list. */ - common = let - f = import ./common.nix; - fArgs = lib.functionArgs f; - in f (builtins.intersectAttrs fArgs pkgs // { - lua = pkgs.lua5_1; - }); + common = + let + f = import ./common.nix; + fArgs = lib.functionArgs f; + in + f ( + builtins.intersectAttrs fArgs pkgs + // { + lua = pkgs.lua5_1; + } + ); - /* Building a set of engines or mods requires some dependencies as well, - so the sets will actually be defined as a function instead, - requiring the dependencies and returning the actual set. + /* + Building a set of engines or mods requires some dependencies as well, + so the sets will actually be defined as a function instead, + requiring the dependencies and returning the actual set. - Not all dependencies for defining a engine or mod set are shared, - so additional arguments can be passed as well. + Not all dependencies for defining a engine or mod set are shared, + so additional arguments can be passed as well. - The builders for engines and mods allow to delay specifying the name, - by returning a function that expects a name, which we use, in this case, - to base the name on the attribute name instead, preventing the need to specify the name twice - if the attribute name and engine/mod name are equal. + The builders for engines and mods allow to delay specifying the name, + by returning a function that expects a name, which we use, in this case, + to base the name on the attribute name instead, preventing the need to specify the name twice + if the attribute name and engine/mod name are equal. */ callWithName = name: value: if lib.isFunction value then value name else value; - buildOpenRASet = f: args: pkgs.recurseIntoAttrs (lib.mapAttrs callWithName (f ({ - inherit (pkgs) fetchFromGitHub; - postFetch = '' - sed -i 's/curl/curl --insecure/g' $out/thirdparty/{fetch-thirdparty-deps,noget}.sh - $out/thirdparty/fetch-thirdparty-deps.sh - ''; - } // args))); + buildOpenRASet = + f: args: + pkgs.recurseIntoAttrs ( + lib.mapAttrs callWithName ( + f ( + { + inherit (pkgs) fetchFromGitHub; + postFetch = '' + sed -i 's/curl/curl --insecure/g' $out/thirdparty/{fetch-thirdparty-deps,noget}.sh + $out/thirdparty/fetch-thirdparty-deps.sh + ''; + } + // args + ) + ) + ); -in pkgs.recurseIntoAttrs rec { +in +pkgs.recurseIntoAttrs rec { # The whole attribute set is destructered to ensure those (and only those) attributes are given # and to provide defaults for those that are optional. - buildOpenRAEngine = { name ? null, version, description, homepage, mods, src }@engine: + buildOpenRAEngine = + { + name ? null, + version, + description, + homepage, + mods, + src, + }@engine: # Allow specifying the name at a later point if no name has been given. - let builder = name: pkgs.callPackage ./engine.nix (common // { - engine = engine // { inherit name; }; - }); - in if name == null then builder else builder name; + let + builder = + name: + pkgs.callPackage ./engine.nix ( + common + // { + engine = engine // { + inherit name; + }; + } + ); + in + if name == null then builder else builder name; # See `buildOpenRAEngine`. - buildOpenRAMod = { name ? null, version, title, description, homepage, src, engine, assetsError ? "" }@mod: ({ version, mods ? [], src }@engine: - let builder = name: pkgs.callPackage ./mod.nix (common // { - mod = mod // { inherit name assetsError; }; - engine = engine // { inherit mods; }; - }); - in if name == null then builder else builder name) engine; + buildOpenRAMod = + { + name ? null, + version, + title, + description, + homepage, + src, + engine, + assetsError ? "", + }@mod: + ( + { + version, + mods ? [ ], + src, + }@engine: + let + builder = + name: + pkgs.callPackage ./mod.nix ( + common + // { + mod = mod // { + inherit name assetsError; + }; + engine = engine // { + inherit mods; + }; + } + ); + in + if name == null then builder else builder name + ) + engine; # See `buildOpenRASet`. engines = buildOpenRASet (import ./engines.nix) { inherit buildOpenRAEngine; }; diff --git a/pkgs/games/openra_2019/engine.nix b/pkgs/games/openra_2019/engine.nix index d63800be1e292e..d5d79ede9a4402 100644 --- a/pkgs/games/openra_2019/engine.nix +++ b/pkgs/games/openra_2019/engine.nix @@ -1,57 +1,68 @@ -/* The package defintion for an OpenRA engine. - It shares code with `mod.nix` by what is defined in `common.nix`. - Similar to `mod.nix` it is a generic package definition, - in order to make it easy to define multiple variants of the OpenRA engine. - For each mod provided by the engine, a wrapper script is created, - matching the naming convention used by `mod.nix`. - This package could be seen as providing a set of in-tree mods, - while the `mod.nix` pacakges provide a single out-of-tree mod. +/* + The package defintion for an OpenRA engine. + It shares code with `mod.nix` by what is defined in `common.nix`. + Similar to `mod.nix` it is a generic package definition, + in order to make it easy to define multiple variants of the OpenRA engine. + For each mod provided by the engine, a wrapper script is created, + matching the naming convention used by `mod.nix`. + This package could be seen as providing a set of in-tree mods, + while the `mod.nix` pacakges provide a single out-of-tree mod. */ -{ lib, stdenv -, packageAttrs -, patchEngine -, wrapLaunchGame -, engine +{ + lib, + stdenv, + packageAttrs, + patchEngine, + wrapLaunchGame, + engine, }: -stdenv.mkDerivation (lib.recursiveUpdate packageAttrs rec { - pname = "openra_2019"; - version = "${engine.name}-${engine.version}"; +stdenv.mkDerivation ( + lib.recursiveUpdate packageAttrs rec { + pname = "openra_2019"; + version = "${engine.name}-${engine.version}"; - src = engine.src; + src = engine.src; - postPatch = patchEngine "." version; + postPatch = patchEngine "." version; - configurePhase = '' - runHook preConfigure + configurePhase = '' + runHook preConfigure - make version VERSION=${lib.escapeShellArg version} + make version VERSION=${lib.escapeShellArg version} - runHook postConfigure - ''; + runHook postConfigure + ''; - buildFlags = [ "DEBUG=false" "default" "man-page" ]; + buildFlags = [ + "DEBUG=false" + "default" + "man-page" + ]; - checkTarget = "nunit test"; + checkTarget = "nunit test"; - installTargets = [ - "install" - "install-linux-icons" - "install-linux-desktop" - "install-linux-appdata" - "install-linux-mime" - "install-man-page" - ]; + installTargets = [ + "install" + "install-linux-icons" + "install-linux-desktop" + "install-linux-appdata" + "install-linux-mime" + "install-man-page" + ]; - postInstall = '' - ${wrapLaunchGame "" "openra"} + postInstall = '' + ${wrapLaunchGame "" "openra"} - ${lib.concatStrings (map (mod: '' - makeWrapper $out/bin/openra $out/bin/openra-${mod} --add-flags Game.Mod=${mod} - '') engine.mods)} - ''; + ${lib.concatStrings ( + map (mod: '' + makeWrapper $out/bin/openra $out/bin/openra-${mod} --add-flags Game.Mod=${mod} + '') engine.mods + )} + ''; - meta = { - inherit (engine) description homepage; - }; -}) + meta = { + inherit (engine) description homepage; + }; + } +) diff --git a/pkgs/games/openra_2019/engines.nix b/pkgs/games/openra_2019/engines.nix index bbb4947acd237a..3bbce300cfa534 100644 --- a/pkgs/games/openra_2019/engines.nix +++ b/pkgs/games/openra_2019/engines.nix @@ -1,37 +1,59 @@ -{ buildOpenRAEngine, fetchFromGitHub, postFetch }: +{ + buildOpenRAEngine, + fetchFromGitHub, + postFetch, +}: let - buildUpstreamOpenRAEngine = { version, rev, sha256 }: name: (buildOpenRAEngine { - inherit version; - description = "Open-source re-implementation of Westwood Studios' 2D Command and Conquer games"; - homepage = "https://www.openra.net/"; - mods = [ "cnc" "d2k" "ra" "ts" ]; - src = fetchFromGitHub { - owner = "OpenRA"; - repo = "OpenRA" ; - inherit rev sha256 postFetch; - }; - } name).overrideAttrs (origAttrs: { - postInstall = '' - ${origAttrs.postInstall} - cp -r mods/ts $out/lib/openra/mods/ - cp mods/ts/icon.png $(mkdirp $out/share/pixmaps)/openra-ts.png - ( cd $out/share/applications; sed -e 's/Dawn/Sun/g' -e 's/cnc/ts/g' openra-cnc.desktop > openra-ts.desktop ) - ''; - }); + buildUpstreamOpenRAEngine = + { + version, + rev, + sha256, + }: + name: + (buildOpenRAEngine { + inherit version; + description = "Open-source re-implementation of Westwood Studios' 2D Command and Conquer games"; + homepage = "https://www.openra.net/"; + mods = [ + "cnc" + "d2k" + "ra" + "ts" + ]; + src = fetchFromGitHub { + owner = "OpenRA"; + repo = "OpenRA"; + inherit rev sha256 postFetch; + }; + } name).overrideAttrs + (origAttrs: { + postInstall = '' + ${origAttrs.postInstall} + cp -r mods/ts $out/lib/openra/mods/ + cp mods/ts/icon.png $(mkdirp $out/share/pixmaps)/openra-ts.png + ( cd $out/share/applications; sed -e 's/Dawn/Sun/g' -e 's/cnc/ts/g' openra-cnc.desktop > openra-ts.desktop ) + ''; + }); -in { - release = name: (buildUpstreamOpenRAEngine rec { - version = "20190314"; - rev = "${name}-${version}"; - sha256 = "15pvn5cx3g0nzbrgpsfz8dngad5wkzp5dz25ydzn8bmxafiijvcr"; - } name); +in +{ + release = + name: + (buildUpstreamOpenRAEngine rec { + version = "20190314"; + rev = "${name}-${version}"; + sha256 = "15pvn5cx3g0nzbrgpsfz8dngad5wkzp5dz25ydzn8bmxafiijvcr"; + } name); - playtest = name: (buildUpstreamOpenRAEngine rec { - version = "20190302"; - rev = "${name}-${version}"; - sha256 = "1vqvfk2p2lpk3m0d3rpvj34i8cmk3mfc7w4cn4llqd9zp4kk9pya"; - } name); + playtest = + name: + (buildUpstreamOpenRAEngine rec { + version = "20190302"; + rev = "${name}-${version}"; + sha256 = "1vqvfk2p2lpk3m0d3rpvj34i8cmk3mfc7w4cn4llqd9zp4kk9pya"; + } name); bleed = buildUpstreamOpenRAEngine { version = "8ee1102"; diff --git a/pkgs/games/openra_2019/mod.nix b/pkgs/games/openra_2019/mod.nix index 2f945b4b4ddcbf..1241801e13c21a 100644 --- a/pkgs/games/openra_2019/mod.nix +++ b/pkgs/games/openra_2019/mod.nix @@ -1,103 +1,117 @@ -/* The package defintion for an OpenRA out-of-tree mod. - It shares code with `engine.nix` by what is defined in `common.nix`. - To build an out-of-tree mod it needs the source code of the engine available, - and they each need to be build with a specific version or fork of the engine, - so the engine needs to be supplied as an argument as well. - The engine is relatively small and quick to build, so this is not much of a problem. - Building a mod will result in a wrapper script that starts the mod inside the specified engine. +/* + The package defintion for an OpenRA out-of-tree mod. + It shares code with `engine.nix` by what is defined in `common.nix`. + To build an out-of-tree mod it needs the source code of the engine available, + and they each need to be build with a specific version or fork of the engine, + so the engine needs to be supplied as an argument as well. + The engine is relatively small and quick to build, so this is not much of a problem. + Building a mod will result in a wrapper script that starts the mod inside the specified engine. */ -{ lib, stdenv -, packageAttrs -, patchEngine -, wrapLaunchGame -, mod -, engine +{ + lib, + stdenv, + packageAttrs, + patchEngine, + wrapLaunchGame, + mod, + engine, }: let engineSourceName = engine.src.name or "engine"; modSourceName = mod.src.name or "mod"; +in # Based on: https://build.opensuse.org/package/show/home:fusion809/openra-ura -in stdenv.mkDerivation (lib.recursiveUpdate packageAttrs rec { - name = "${pname}-${version}"; - pname = "openra_2019-${mod.name}"; - inherit (mod) version; - - srcs = [ - mod.src - engine.src - ]; - - sourceRoot = "."; - - postUnpack = '' - mv ${engineSourceName} ${modSourceName} - cd ${modSourceName} - ''; - - postPatch = '' - cat <<'EOF' > fetch-engine.sh - #!/bin/sh - exit 0 - EOF - - sed -i 's/^VERSION.*/VERSION = ${version}/g' Makefile - - dos2unix *.md - - ${patchEngine engineSourceName engine.version} - ''; - - configurePhase = '' - runHook preConfigure - - make version VERSION=${lib.escapeShellArg version} - make -C ${engineSourceName} version VERSION=${lib.escapeShellArg engine.version} - - runHook postConfigure - ''; - - checkTarget = "test"; - - installPhase = '' - runHook preInstall - - make -C ${engineSourceName} install-engine install-common-mod-files DATA_INSTALL_DIR=$out/lib/${pname} - - cp -r ${engineSourceName}/mods/{${lib.concatStringsSep "," ([ "common" "modcontent" ] ++ engine.mods)}} mods/* \ - $out/lib/${pname}/mods/ - - substitute ${./mod-launch-game.sh} $out/lib/openra_2019-${mod.name}/launch-game.sh \ - --subst-var out \ - --subst-var-by name ${lib.escapeShellArg mod.name} \ - --subst-var-by title ${lib.escapeShellArg mod.title} \ - --subst-var-by assetsError ${lib.escapeShellArg mod.assetsError} - chmod +x $out/lib/openra_2019-${mod.name}/launch-game.sh - - ${wrapLaunchGame "_2019-${mod.name}" "openra-${mod.name}"} - - substitute ${./openra-mod.desktop} $(mkdirp $out/share/applications)/${pname}.desktop \ - --subst-var-by name ${lib.escapeShellArg mod.name} \ - --subst-var-by title ${lib.escapeShellArg mod.title} \ - --subst-var-by description ${lib.escapeShellArg mod.description} - - cp README.md $(mkdirp $out/share/doc/packages/${pname})/README.md - - [[ -e mods/${mod.name}/icon.png ]] && mod_icon=mods/${mod.name}/icon.png || { - [[ -e mods/${mod.name}/logo.png ]] && mod_icon=mods/${mod.name}/logo.png || mod_icon=packaging/linux/mod_256x256.png - } - cp "$mod_icon" $(mkdirp $out/share/pixmaps)/${pname}.png - - for size in 16 32 48 64 128 256; do - size=''${size}x''${size} - cp packaging/linux/mod_''${size}.png $(mkdirp $out/share/icons/hicolor/''${size}/apps)/${pname}.png - done - - runHook postInstall - ''; - - meta = { - inherit (mod) description homepage; - }; -}) +stdenv.mkDerivation ( + lib.recursiveUpdate packageAttrs rec { + name = "${pname}-${version}"; + pname = "openra_2019-${mod.name}"; + inherit (mod) version; + + srcs = [ + mod.src + engine.src + ]; + + sourceRoot = "."; + + postUnpack = '' + mv ${engineSourceName} ${modSourceName} + cd ${modSourceName} + ''; + + postPatch = '' + cat <<'EOF' > fetch-engine.sh + #!/bin/sh + exit 0 + EOF + + sed -i 's/^VERSION.*/VERSION = ${version}/g' Makefile + + dos2unix *.md + + ${patchEngine engineSourceName engine.version} + ''; + + configurePhase = '' + runHook preConfigure + + make version VERSION=${lib.escapeShellArg version} + make -C ${engineSourceName} version VERSION=${lib.escapeShellArg engine.version} + + runHook postConfigure + ''; + + checkTarget = "test"; + + installPhase = '' + runHook preInstall + + make -C ${engineSourceName} install-engine install-common-mod-files DATA_INSTALL_DIR=$out/lib/${pname} + + cp -r ${engineSourceName}/mods/{${ + lib.concatStringsSep "," ( + [ + "common" + "modcontent" + ] + ++ engine.mods + ) + }} mods/* \ + $out/lib/${pname}/mods/ + + substitute ${./mod-launch-game.sh} $out/lib/openra_2019-${mod.name}/launch-game.sh \ + --subst-var out \ + --subst-var-by name ${lib.escapeShellArg mod.name} \ + --subst-var-by title ${lib.escapeShellArg mod.title} \ + --subst-var-by assetsError ${lib.escapeShellArg mod.assetsError} + chmod +x $out/lib/openra_2019-${mod.name}/launch-game.sh + + ${wrapLaunchGame "_2019-${mod.name}" "openra-${mod.name}"} + + substitute ${./openra-mod.desktop} $(mkdirp $out/share/applications)/${pname}.desktop \ + --subst-var-by name ${lib.escapeShellArg mod.name} \ + --subst-var-by title ${lib.escapeShellArg mod.title} \ + --subst-var-by description ${lib.escapeShellArg mod.description} + + cp README.md $(mkdirp $out/share/doc/packages/${pname})/README.md + + [[ -e mods/${mod.name}/icon.png ]] && mod_icon=mods/${mod.name}/icon.png || { + [[ -e mods/${mod.name}/logo.png ]] && mod_icon=mods/${mod.name}/logo.png || mod_icon=packaging/linux/mod_256x256.png + } + cp "$mod_icon" $(mkdirp $out/share/pixmaps)/${pname}.png + + for size in 16 32 48 64 128 256; do + size=''${size}x''${size} + cp packaging/linux/mod_''${size}.png $(mkdirp $out/share/icons/hicolor/''${size}/apps)/${pname}.png + done + + runHook postInstall + ''; + + meta = { + inherit (mod) description homepage; + }; + } +) diff --git a/pkgs/games/openra_2019/mods.nix b/pkgs/games/openra_2019/mods.nix index 47e86fd09a7d2c..a9f95d0f25c815 100644 --- a/pkgs/games/openra_2019/mods.nix +++ b/pkgs/games/openra_2019/mods.nix @@ -1,11 +1,18 @@ -{ buildOpenRAMod, fetchFromGitHub, postFetch }: +{ + buildOpenRAMod, + fetchFromGitHub, + postFetch, +}: let - unsafeBuildOpenRAMod = attrs: name: (buildOpenRAMod attrs name).overrideAttrs (_: { - doCheck = false; - }); + unsafeBuildOpenRAMod = + attrs: name: + (buildOpenRAMod attrs name).overrideAttrs (_: { + doCheck = false; + }); -in { +in +{ ca = buildOpenRAMod { version = "96.git.fc3cf0b"; title = "Combined Arms"; @@ -21,7 +28,7 @@ in { version = "b8a7dd5"; src = fetchFromGitHub { owner = "Inq8"; - repo = "CAengine" ; + repo = "CAengine"; rev = "b8a7dd52ff893ed8225726d4ed4e14ecad748404"; sha256 = "0dyk861qagibx8ldshz7d2nrki9q550f6f0wy8pvayvf1gv1dbxj"; name = "engine"; @@ -43,10 +50,14 @@ in { }; engine = rec { version = "release-20181215"; - mods = [ "cnc" "d2k" "ra" ]; + mods = [ + "cnc" + "d2k" + "ra" + ]; src = fetchFromGitHub { owner = "OpenRA"; - repo = "OpenRA" ; + repo = "OpenRA"; rev = version; sha256 = "0p0izykjnz7pz02g2khp7msqa00jhjsrzk9y0g29dirmdv75qa4r"; name = "engine"; @@ -74,7 +85,7 @@ in { version = "DarkReign"; src = fetchFromGitHub { owner = "drogoganor"; - repo = "OpenRA" ; + repo = "OpenRA"; rev = "f91d3f2603bbf51afaa89357e4defcdc36138102"; sha256 = "05g900ri6q0zrkrk8rmjaz576vjggmi2y6jm0xz3cwli54prn11w"; name = "engine"; @@ -98,7 +109,7 @@ in { version = "gen-20190128_3"; src = fetchFromGitHub { owner = "MustaphaTR"; - repo = "OpenRA" ; + repo = "OpenRA"; rev = version; sha256 = "1x6byz37s8qcpqj902zvkvbv95rv2mv2kj35c12gbpyc92xkqkq0"; name = "generals-alpha-engine"; @@ -107,35 +118,41 @@ in { }; }; - kknd = let version = "145.git.5530bab"; in name: (buildOpenRAMod rec { - inherit version; - title = "Krush, Kill 'n' Destroy"; - description = "Re-imagination of the original ${title} game"; - homepage = "https://kknd-game.com/"; - src = fetchFromGitHub { - owner = "IceReaper"; - repo = "KKnD"; - rev = "5530babcb05170e0959e4cf2b079161e9fedde4f"; - sha256 = "07jczrarmgm6zdk0myzwgq200x19yvpjyxrnhdac08mjgyz75zk1"; - }; - engine = { - version = "4e8eab4ca00d1910203c8a103dfd2c002714daa8"; + kknd = + let + version = "145.git.5530bab"; + in + name: + (buildOpenRAMod rec { + inherit version; + title = "Krush, Kill 'n' Destroy"; + description = "Re-imagination of the original ${title} game"; + homepage = "https://kknd-game.com/"; src = fetchFromGitHub { owner = "IceReaper"; - repo = "OpenRA" ; - # commit does not exist on any branch on the target repository - rev = "4e8eab4ca00d1910203c8a103dfd2c002714daa8"; - sha256 = "1yyqparf93x8yzy1f46gsymgkj5jls25v2yc7ighr3f7mi3igdvq"; - name = "engine"; - inherit postFetch; + repo = "KKnD"; + rev = "5530babcb05170e0959e4cf2b079161e9fedde4f"; + sha256 = "07jczrarmgm6zdk0myzwgq200x19yvpjyxrnhdac08mjgyz75zk1"; }; - }; - } name).overrideAttrs (origAttrs: { - postPatch = '' - ${origAttrs.postPatch} - sed -i 's/{DEV_VERSION}/${version}/' mods/*/mod.yaml - ''; - }); + engine = { + version = "4e8eab4ca00d1910203c8a103dfd2c002714daa8"; + src = fetchFromGitHub { + owner = "IceReaper"; + repo = "OpenRA"; + # commit does not exist on any branch on the target repository + rev = "4e8eab4ca00d1910203c8a103dfd2c002714daa8"; + sha256 = "1yyqparf93x8yzy1f46gsymgkj5jls25v2yc7ighr3f7mi3igdvq"; + name = "engine"; + inherit postFetch; + }; + }; + } name).overrideAttrs + (origAttrs: { + postPatch = '' + ${origAttrs.postPatch} + sed -i 's/{DEV_VERSION}/${version}/' mods/*/mod.yaml + ''; + }); mw = buildOpenRAMod rec { version = "257.git.c9be8f2"; @@ -152,7 +169,7 @@ in { version = "MedievalWarfareEngine"; src = fetchFromGitHub { owner = "CombinE88"; - repo = "OpenRA" ; + repo = "OpenRA"; rev = "52109c0910f479753704c46fb19e8afaab353c83"; sha256 = "0ga3855j6bc7h81q03cw6laiaiz12915zg8aqah1idvxbzicfy7l"; name = "engine"; @@ -176,7 +193,7 @@ in { version = "release-20180923"; src = fetchFromGitHub { owner = "OpenRA"; - repo = "OpenRA" ; + repo = "OpenRA"; rev = version; sha256 = "1pgi3zaq9fwwdq6yh19bwxscslqgabjxkvl9bcn1a5agy4bfbqk5"; name = "engine"; @@ -204,7 +221,7 @@ in { version = "release-20190314"; src = fetchFromGitHub { owner = "OpenRA"; - repo = "OpenRA" ; + repo = "OpenRA"; rev = version; sha256 = "15pvn5cx3g0nzbrgpsfz8dngad5wkzp5dz25ydzn8bmxafiijvcr"; name = "engine"; @@ -255,10 +272,13 @@ in { }; engine = { version = "SP-22-04-19"; - mods = [ "as" "ts" ]; + mods = [ + "as" + "ts" + ]; src = fetchFromGitHub { owner = "ABrandau"; - repo = "OpenRA" ; + repo = "OpenRA"; rev = "bb0930008a57c07f3002421023f6b446e3e3af69"; sha256 = "1jvgpbf56hd02ikhklv49br4d1jiv5hphc5kl79qnjlaacnj222x"; name = "engine"; @@ -282,7 +302,7 @@ in { version = "6de92de"; src = fetchFromGitHub { owner = "OpenRA"; - repo = "OpenRA" ; + repo = "OpenRA"; rev = "6de92de8d982094a766eab97a92225c240d85493"; sha256 = "0ps9x379plrrj1hnj4fpr26lc46mzgxknv5imxi0bmrh5y4781ql"; name = "engine"; @@ -306,7 +326,7 @@ in { version = "unplugged-cd82382"; src = fetchFromGitHub { owner = "RAunplugged"; - repo = "OpenRA" ; + repo = "OpenRA"; rev = version; sha256 = "1p5hgxxvxlz8480vj0qkmnxjh7zj3hahk312m0zljxfdb40652w1"; name = "engine"; @@ -330,7 +350,7 @@ in { version = "release-20190314"; src = fetchFromGitHub { owner = "OpenRA"; - repo = "OpenRA" ; + repo = "OpenRA"; rev = version; sha256 = "15pvn5cx3g0nzbrgpsfz8dngad5wkzp5dz25ydzn8bmxafiijvcr"; name = "engine"; diff --git a/pkgs/games/openra_2019/packages.nix b/pkgs/games/openra_2019/packages.nix index a88bfd14e2e3e0..b38225464d8618 100644 --- a/pkgs/games/openra_2019/packages.nix +++ b/pkgs/games/openra_2019/packages.nix @@ -1,55 +1,120 @@ pkgs: let - /* Building an engine or out-of-tree mod is very similar, - but different enough not to be able to build them with the same package definition, - so instaed we define what is common between them in a separate file. - - Although `callPackage` could be used, it would require undoing `makeOverridable`, - because `common.nix` does not define a package, but just an attribute set, - which is directly passed as part of the argument to the engines and mods `callPackage`, - so either the attributes added by `makeOverridable` have to be removed - or the engine and mod package definitions will need to add `...` to the argument list. + /* + Building an engine or out-of-tree mod is very similar, + but different enough not to be able to build them with the same package definition, + so instaed we define what is common between them in a separate file. + + Although `callPackage` could be used, it would require undoing `makeOverridable`, + because `common.nix` does not define a package, but just an attribute set, + which is directly passed as part of the argument to the engines and mods `callPackage`, + so either the attributes added by `makeOverridable` have to be removed + or the engine and mod package definitions will need to add `...` to the argument list. */ - common = let f = import ./common.nix; in f (builtins.intersectAttrs (builtins.functionArgs f) pkgs // { - lua = pkgs.lua5_1; - }); + common = + let + f = import ./common.nix; + in + f ( + builtins.intersectAttrs (builtins.functionArgs f) pkgs + // { + lua = pkgs.lua5_1; + } + ); - /* Building a set of engines or mods requires some dependencies as well, - so the sets will actually be defined as a function instead, - requiring the dependencies and returning the actual set. + /* + Building a set of engines or mods requires some dependencies as well, + so the sets will actually be defined as a function instead, + requiring the dependencies and returning the actual set. - Not all dependencies for defining a engine or mod set are shared, - so additional arguments can be passed as well. + Not all dependencies for defining a engine or mod set are shared, + so additional arguments can be passed as well. - The builders for engines and mods allow to delay specifying the name, - by returning a function that expects a name, which we use, in this case, - to base the name on the attribute name instead, preventing the need to specify the name twice - if the attribute name and engine/mod name are equal. + The builders for engines and mods allow to delay specifying the name, + by returning a function that expects a name, which we use, in this case, + to base the name on the attribute name instead, preventing the need to specify the name twice + if the attribute name and engine/mod name are equal. */ - buildOpenRASet = f: args: builtins.mapAttrs (name: value: if builtins.isFunction value then value name else value) (f ({ - inherit (pkgs) fetchFromGitHub; - postFetch = '' - sed -i 's/curl/curl --insecure/g' $out/thirdparty/{fetch-thirdparty-deps,noget}.sh - $out/thirdparty/fetch-thirdparty-deps.sh - ''; - } // args)); - -in rec { + buildOpenRASet = + f: args: + builtins.mapAttrs (name: value: if builtins.isFunction value then value name else value) ( + f ( + { + inherit (pkgs) fetchFromGitHub; + postFetch = '' + sed -i 's/curl/curl --insecure/g' $out/thirdparty/{fetch-thirdparty-deps,noget}.sh + $out/thirdparty/fetch-thirdparty-deps.sh + ''; + } + // args + ) + ); + +in +rec { # The whole attribute set is destructered to ensure those (and only those) attributes are given # and to provide defaults for those that are optional. - buildOpenRAEngine = { name ? null, version, description, homepage, mods, src, installExperimental ? "" }@engine: + buildOpenRAEngine = + { + name ? null, + version, + description, + homepage, + mods, + src, + installExperimental ? "", + }@engine: # Allow specifying the name at a later point if no name has been given. - let builder = name: pkgs.callPackage ./engine.nix (common // { - engine = engine // { inherit name installExperimental; }; - }); in if name == null then builder else builder name; + let + builder = + name: + pkgs.callPackage ./engine.nix ( + common + // { + engine = engine // { + inherit name installExperimental; + }; + } + ); + in + if name == null then builder else builder name; # See `buildOpenRAEngine`. - buildOpenRAMod = { name ? null, version, title, description, homepage, src, engine }@mod: ({ version, mods ? [], src }@engine: - let builder = name: pkgs.callPackage ./mod.nix (common // { - mod = mod // { inherit name; }; - engine = engine // { inherit mods; }; - }); in if name == null then builder else builder name) engine; + buildOpenRAMod = + { + name ? null, + version, + title, + description, + homepage, + src, + engine, + }@mod: + ( + { + version, + mods ? [ ], + src, + }@engine: + let + builder = + name: + pkgs.callPackage ./mod.nix ( + common + // { + mod = mod // { + inherit name; + }; + engine = engine // { + inherit mods; + }; + } + ); + in + if name == null then builder else builder name + ) + engine; # See `buildOpenRASet`. engines = buildOpenRASet (import ./engines.nix) { inherit buildOpenRAEngine; }; diff --git a/pkgs/games/openrw/default.nix b/pkgs/games/openrw/default.nix index d2d86226af2612..fdec4d1fe77000 100644 --- a/pkgs/games/openrw/default.nix +++ b/pkgs/games/openrw/default.nix @@ -1,20 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -, sfml -, libGLU -, libGL -, bullet -, glm -, libmad -, openal -, SDL2 -, boost -, ffmpeg_6 -, Cocoa -, OpenAL }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + sfml, + libGLU, + libGL, + bullet, + glm, + libmad, + openal, + SDL2, + boost, + ffmpeg_6, + Cocoa, + OpenAL, +}: stdenv.mkDerivation { version = "0-unstable-2024-04-20"; @@ -34,16 +36,33 @@ stdenv.mkDerivation { ./fix-ffmpeg-6.patch ]; - postPatch = lib.optional (stdenv.cc.isClang && (lib.versionAtLeast stdenv.cc.version "9"))'' + postPatch = lib.optional (stdenv.cc.isClang && (lib.versionAtLeast stdenv.cc.version "9")) '' substituteInPlace cmake_configure.cmake \ --replace 'target_link_libraries(rw_interface INTERFACE "stdc++fs")' "" ''; - nativeBuildInputs = [ cmake ninja ]; + nativeBuildInputs = [ + cmake + ninja + ]; - buildInputs = [ - sfml libGLU libGL bullet glm libmad openal SDL2 boost ffmpeg_6 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ OpenAL Cocoa ]; + buildInputs = + [ + sfml + libGLU + libGL + bullet + glm + libmad + openal + SDL2 + boost + ffmpeg_6 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + OpenAL + Cocoa + ]; meta = with lib; { description = "Unofficial open source recreation of the classic Grand Theft Auto III game executable"; diff --git a/pkgs/games/openttd/default.nix b/pkgs/games/openttd/default.nix index 9276e094853d38..4a5e1551412448 100644 --- a/pkgs/games/openttd/default.nix +++ b/pkgs/games/openttd/default.nix @@ -1,11 +1,43 @@ -{ lib, stdenv, fetchzip, cmake, pkg-config -, SDL2, libpng, zlib, xz, freetype, fontconfig -, nlohmann_json, curl, icu, harfbuzz, expat, glib, pcre2 -, withOpenGFX ? true, withOpenSFX ? true, withOpenMSX ? true -, withFluidSynth ? true, audioDriver ? "alsa" -, fluidsynth, soundfont-fluid, libsndfile -, flac, libogg, libvorbis, libopus, libmpg123, pulseaudio, alsa-lib, libjack2 -, procps, writeScriptBin, makeWrapper, runtimeShell }: +{ + lib, + stdenv, + fetchzip, + cmake, + pkg-config, + SDL2, + libpng, + zlib, + xz, + freetype, + fontconfig, + nlohmann_json, + curl, + icu, + harfbuzz, + expat, + glib, + pcre2, + withOpenGFX ? true, + withOpenSFX ? true, + withOpenMSX ? true, + withFluidSynth ? true, + audioDriver ? "alsa", + fluidsynth, + soundfont-fluid, + libsndfile, + flac, + libogg, + libvorbis, + libopus, + libmpg123, + pulseaudio, + alsa-lib, + libjack2, + procps, + writeScriptBin, + makeWrapper, + runtimeShell, +}: let opengfx = fetchzip { @@ -39,14 +71,40 @@ stdenv.mkDerivation rec { hash = "sha256-YT4IE/rJ9pnpeMWKbOra6AbSUwW19RwOKlXkxwoMeKY="; }; - nativeBuildInputs = [ cmake pkg-config makeWrapper ]; - buildInputs = [ - SDL2 libpng xz zlib freetype fontconfig - nlohmann_json curl icu harfbuzz expat glib pcre2 - ] ++ lib.optionals withFluidSynth [ - fluidsynth soundfont-fluid libsndfile - flac libogg libvorbis libopus libmpg123 pulseaudio alsa-lib libjack2 + nativeBuildInputs = [ + cmake + pkg-config + makeWrapper ]; + buildInputs = + [ + SDL2 + libpng + xz + zlib + freetype + fontconfig + nlohmann_json + curl + icu + harfbuzz + expat + glib + pcre2 + ] + ++ lib.optionals withFluidSynth [ + fluidsynth + soundfont-fluid + libsndfile + flac + libogg + libvorbis + libopus + libmpg123 + pulseaudio + alsa-lib + libjack2 + ]; prefixKey = "--prefix-dir="; @@ -95,6 +153,9 @@ stdenv.mkDerivation rec { changelog = "https://cdn.openttd.org/openttd-releases/${version}/changelog.txt"; license = licenses.gpl2Only; platforms = platforms.linux; - maintainers = with maintainers; [ jcumming fpletz ]; + maintainers = with maintainers; [ + jcumming + fpletz + ]; }; } diff --git a/pkgs/games/openttd/grfcodec.nix b/pkgs/games/openttd/grfcodec.nix index af4e3153746378..e9d559793adf35 100644 --- a/pkgs/games/openttd/grfcodec.nix +++ b/pkgs/games/openttd/grfcodec.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, boost, cmake, git }: +{ + stdenv, + lib, + fetchFromGitHub, + boost, + cmake, + git, +}: stdenv.mkDerivation rec { pname = "openttd-grfcodec"; @@ -11,8 +18,11 @@ stdenv.mkDerivation rec { sha256 = "0b4xnnkqc01d3r834lhkq744ymar6c8iyxk51wc4c7hvz0vp9vmy"; }; - buildInputs = [boost]; - nativeBuildInputs = [cmake git]; + buildInputs = [ boost ]; + nativeBuildInputs = [ + cmake + git + ]; installPhase = '' mkdir -p $out/bin @@ -21,8 +31,8 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Low-level (dis)assembler and linter for OpenTTD GRF files"; - homepage = "http://openttd.org/"; - license = licenses.gpl2Plus; + homepage = "http://openttd.org/"; + license = licenses.gpl2Plus; maintainers = with maintainers; [ ToxicFrog ]; }; } diff --git a/pkgs/games/openttd/nml.nix b/pkgs/games/openttd/nml.nix index da4a387a7d4fc0..b2ce587d1aa4c9 100644 --- a/pkgs/games/openttd/nml.nix +++ b/pkgs/games/openttd/nml.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/games/openxcom/default.nix b/pkgs/games/openxcom/default.nix index 2af9368640afdd..920786ab93a45e 100644 --- a/pkgs/games/openxcom/default.nix +++ b/pkgs/games/openxcom/default.nix @@ -1,18 +1,19 @@ -{ boost -, cmake -, fetchFromGitHub -, lib -, libGLU -, libGL -, openssl -, pkg-config -, SDL -, SDL_image -, SDL_mixer -, SDL_gfx -, stdenv -, yaml-cpp -, zlib +{ + boost, + cmake, + fetchFromGitHub, + lib, + libGLU, + libGL, + openssl, + pkg-config, + SDL, + SDL_image, + SDL_mixer, + SDL_gfx, + stdenv, + yaml-cpp, + zlib, }: stdenv.mkDerivation { diff --git a/pkgs/games/openxray/default.nix b/pkgs/games/openxray/default.nix index 8bcedac52ad35d..5d761fbf7f71b5 100644 --- a/pkgs/games/openxray/default.nix +++ b/pkgs/games/openxray/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, gitUpdater -, cmake -, glew -, liblockfile -, openal -, libtheora -, SDL2 -, lzo -, libjpeg -, libogg -, pcre -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + cmake, + glew, + liblockfile, + openal, + libtheora, + SDL2, + lzo, + libjpeg, + libogg, + pcre, + makeWrapper, }: stdenv.mkDerivation (finalAttrs: { @@ -71,6 +72,12 @@ stdenv.mkDerivation (finalAttrs: { url = "https://github.com/OpenXRay/xray-16/blob/${finalAttrs.version}/License.txt"; }; maintainers = with maintainers; [ OPNA2608 ]; - platforms = [ "x86_64-linux" "i686-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; }; }) diff --git a/pkgs/games/orthorobot/default.nix b/pkgs/games/orthorobot/default.nix index bd491ce5c91372..5278cd20c6e125 100644 --- a/pkgs/games/orthorobot/default.nix +++ b/pkgs/games/orthorobot/default.nix @@ -1,14 +1,15 @@ -{ lib -, copyDesktopItems -, fetchFromGitHub -, fetchpatch -, fetchurl -, love -, makeDesktopItem -, makeWrapper -, stdenv -, strip-nondeterminism -, zip +{ + lib, + copyDesktopItems, + fetchFromGitHub, + fetchpatch, + fetchurl, + love, + makeDesktopItem, + makeWrapper, + stdenv, + strip-nondeterminism, + zip, }: stdenv.mkDerivation rec { diff --git a/pkgs/games/papermc/default.nix b/pkgs/games/papermc/default.nix index 037b307c6df37b..0fd50af5b1c22d 100644 --- a/pkgs/games/papermc/default.nix +++ b/pkgs/games/papermc/default.nix @@ -5,13 +5,14 @@ in let latestVersion = lib.last (builtins.sort lib.versionOlder (builtins.attrNames versions)); escapeVersion = builtins.replaceStrings [ "." ] [ "_" ]; - packages = lib.mapAttrs' - (version: value: { - name = "papermc-${escapeVersion version}"; - value = callPackage ./derivation.nix { inherit (value) version hash; }; - }) - versions; + packages = lib.mapAttrs' (version: value: { + name = "papermc-${escapeVersion version}"; + value = callPackage ./derivation.nix { inherit (value) version hash; }; + }) versions; in -lib.recurseIntoAttrs (packages // { - papermc = builtins.getAttr "papermc-${escapeVersion latestVersion}" packages; -}) +lib.recurseIntoAttrs ( + packages + // { + papermc = builtins.getAttr "papermc-${escapeVersion latestVersion}" packages; + } +) diff --git a/pkgs/games/papermc/derivation.nix b/pkgs/games/papermc/derivation.nix index c7ad650d00f699..90041b5642f279 100644 --- a/pkgs/games/papermc/derivation.nix +++ b/pkgs/games/papermc/derivation.nix @@ -1,4 +1,13 @@ -{ lib, stdenvNoCC, fetchurl, makeBinaryWrapper, jre, version, hash, udev }: +{ + lib, + stdenvNoCC, + fetchurl, + makeBinaryWrapper, + jre, + version, + hash, + udev, +}: stdenvNoCC.mkDerivation (finalAttrs: { pname = "papermc"; @@ -45,7 +54,11 @@ stdenvNoCC.mkDerivation (finalAttrs: { sourceProvenance = with lib.sourceTypes; [ binaryBytecode ]; license = lib.licenses.gpl3Only; platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ aaronjanse neonfuz MayNiklas ]; + maintainers = with lib.maintainers; [ + aaronjanse + neonfuz + MayNiklas + ]; mainProgram = "minecraft-server"; }; }) diff --git a/pkgs/games/pegasus-frontend/default.nix b/pkgs/games/pegasus-frontend/default.nix index be763bc6ae7260..de566c43e6a818 100644 --- a/pkgs/games/pegasus-frontend/default.nix +++ b/pkgs/games/pegasus-frontend/default.nix @@ -1,16 +1,17 @@ -{ lib -, fetchFromGitHub -, stdenv -, cmake -, qtbase -, qtgraphicaleffects -, qtmultimedia -, qtsvg -, qttools -, qtx11extras -, SDL2 -, sqlite -, wrapQtAppsHook +{ + lib, + fetchFromGitHub, + stdenv, + cmake, + qtbase, + qtgraphicaleffects, + qtmultimedia, + qtsvg, + qttools, + qtx11extras, + SDL2, + sqlite, + wrapQtAppsHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/games/pentobi/default.nix b/pkgs/games/pentobi/default.nix index 4974deca7e5ef4..cbcddf570b0321 100644 --- a/pkgs/games/pentobi/default.nix +++ b/pkgs/games/pentobi/default.nix @@ -1,5 +1,19 @@ -{ lib, mkDerivation, appstream, fetchFromGitHub, cmake, gettext, libxslt, librsvg, itstool -, qtbase, qtquickcontrols2, qtsvg, qttools, qtwebview, docbook_xsl +{ + lib, + mkDerivation, + appstream, + fetchFromGitHub, + cmake, + gettext, + libxslt, + librsvg, + itstool, + qtbase, + qtquickcontrols2, + qtsvg, + qttools, + qtwebview, + docbook_xsl, }: mkDerivation rec { @@ -13,8 +27,20 @@ mkDerivation rec { sha256 = "sha256-DQM3IJ0pRkX4OsrjZGROg50LfKb621UnpvtqSjxchz8="; }; - nativeBuildInputs = [ cmake docbook_xsl qttools ]; - buildInputs = [ appstream qtbase qtsvg qtquickcontrols2 qtwebview itstool librsvg ]; + nativeBuildInputs = [ + cmake + docbook_xsl + qttools + ]; + buildInputs = [ + appstream + qtbase + qtsvg + qtquickcontrols2 + qtwebview + itstool + librsvg + ]; patchPhase = '' substituteInPlace pentobi_thumbnailer/CMakeLists.txt --replace "/manpages" "/share/xml/docbook-xsl/manpages/" diff --git a/pkgs/games/pokerth/default.nix b/pkgs/games/pokerth/default.nix index 05b8fd7e58af88..f8ef4e598d0fcf 100644 --- a/pkgs/games/pokerth/default.nix +++ b/pkgs/games/pokerth/default.nix @@ -1,7 +1,23 @@ -{ lib, mkDerivation, fetchFromGitHub, fetchpatch, qmake, qtbase -, SDL, SDL_mixer, boost, curl, gsasl, libgcrypt, libircclient, protobuf, sqlite -, wrapQtAppsHook -, tinyxml2, target ? "client" }: +{ + lib, + mkDerivation, + fetchFromGitHub, + fetchpatch, + qmake, + qtbase, + SDL, + SDL_mixer, + boost, + curl, + gsasl, + libgcrypt, + libircclient, + protobuf, + sqlite, + wrapQtAppsHook, + tinyxml2, + target ? "client", +}: mkDerivation rec { pname = "pokerth-${target}"; @@ -41,7 +57,10 @@ mkDerivation rec { done ''; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; buildInputs = [ SDL diff --git a/pkgs/games/pro-office-calculator/default.nix b/pkgs/games/pro-office-calculator/default.nix index f345d4b5d58489..88894e2fb99d1c 100644 --- a/pkgs/games/pro-office-calculator/default.nix +++ b/pkgs/games/pro-office-calculator/default.nix @@ -1,16 +1,28 @@ -{ mkDerivation, lib, fetchFromGitHub, tinyxml-2, cmake, qtbase, qtmultimedia }: +{ + mkDerivation, + lib, + fetchFromGitHub, + tinyxml-2, + cmake, + qtbase, + qtmultimedia, +}: mkDerivation rec { version = "1.0.13"; pname = "pro-office-calculator"; src = fetchFromGitHub { - owner = "RobJinman"; - repo = "pro_office_calc"; - rev = "v${version}"; + owner = "RobJinman"; + repo = "pro_office_calc"; + rev = "v${version}"; sha256 = "1v75cysargmp4fk7px5zgib1p6h5ya4w39rndbzk614fcnv0iipd"; }; - buildInputs = [ qtbase qtmultimedia tinyxml-2 ]; + buildInputs = [ + qtbase + qtmultimedia + tinyxml-2 + ]; nativeBuildInputs = [ cmake ]; diff --git a/pkgs/games/qgo/default.nix b/pkgs/games/qgo/default.nix index 9c688a37d263e1..68b4a9325b3812 100644 --- a/pkgs/games/qgo/default.nix +++ b/pkgs/games/qgo/default.nix @@ -1,10 +1,11 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, qmake -, qtbase -, qtmultimedia -, qttools +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qtbase, + qtmultimedia, + qttools, }: mkDerivation { @@ -42,6 +43,12 @@ mkDerivation { postPatch = '' sed -i 's|@out@|'"''${out}"'|g' src/src.pro src/defines.h ''; - nativeBuildInputs = [ qmake qttools ]; - buildInputs = [ qtbase qtmultimedia ]; + nativeBuildInputs = [ + qmake + qttools + ]; + buildInputs = [ + qtbase + qtmultimedia + ]; } diff --git a/pkgs/games/qtads/default.nix b/pkgs/games/qtads/default.nix index 2d5ae31814e022..4de706b5c50dcb 100644 --- a/pkgs/games/qtads/default.nix +++ b/pkgs/games/qtads/default.nix @@ -1,5 +1,15 @@ -{ lib, mkDerivation, fetchFromGitHub, pkg-config, qmake -, SDL2, fluidsynth, libsndfile, libvorbis, mpg123, qtbase +{ + lib, + mkDerivation, + fetchFromGitHub, + pkg-config, + qmake, + SDL2, + fluidsynth, + libsndfile, + libvorbis, + mpg123, + qtbase, }: mkDerivation rec { @@ -13,9 +23,19 @@ mkDerivation rec { sha256 = "sha256-KIqufpvl7zeUtDBXUOAZxBIbfv+s51DoSaZr3jol+bw="; }; - nativeBuildInputs = [ pkg-config qmake ]; + nativeBuildInputs = [ + pkg-config + qmake + ]; - buildInputs = [ SDL2 fluidsynth libsndfile libvorbis mpg123 qtbase ]; + buildInputs = [ + SDL2 + fluidsynth + libsndfile + libvorbis + mpg123 + qtbase + ]; meta = with lib; { homepage = "https://realnc.github.io/qtads/"; diff --git a/pkgs/games/quake2/yquake2/default.nix b/pkgs/games/quake2/yquake2/default.nix index 63e07c040455a8..08d3c3e40dbef7 100644 --- a/pkgs/games/quake2/yquake2/default.nix +++ b/pkgs/games/quake2/yquake2/default.nix @@ -1,7 +1,18 @@ -{ stdenv, lib, fetchFromGitHub, buildEnv, makeWrapper, copyDesktopItems, makeDesktopItem -, SDL2, libGL, curl -, openalSupport ? true, openal -, Cocoa, OpenAL +{ + stdenv, + lib, + fetchFromGitHub, + buildEnv, + makeWrapper, + copyDesktopItems, + makeDesktopItem, + SDL2, + libGL, + curl, + openalSupport ? true, + openal, + Cocoa, + OpenAL, }: let @@ -9,7 +20,17 @@ let games = import ./games.nix { inherit stdenv lib fetchFromGitHub; }; - wrapper = import ./wrapper.nix { inherit stdenv lib buildEnv makeWrapper yquake2 copyDesktopItems makeDesktopItem; }; + wrapper = import ./wrapper.nix { + inherit + stdenv + lib + buildEnv + makeWrapper + yquake2 + copyDesktopItems + makeDesktopItem + ; + }; yquake2 = stdenv.mkDerivation rec { pname = "yquake2"; @@ -18,20 +39,30 @@ let src = fetchFromGitHub { owner = "yquake2"; repo = "yquake2"; - rev = "QUAKE2_${builtins.replaceStrings ["."] ["_"] version}"; + rev = "QUAKE2_${builtins.replaceStrings [ "." ] [ "_" ] version}"; sha256 = "sha256-8xvY8XYZJa/gAVcxR+ffpE8naUTbGyM8AyAdpG6nKtA="; }; - postPatch = '' - substituteInPlace src/client/curl/qcurl.c \ - --replace "\"libcurl.so.3\", \"libcurl.so.4\"" "\"${curl.out}/lib/libcurl.so\", \"libcurl.so.3\", \"libcurl.so.4\"" - '' + lib.optionalString (openalSupport && !stdenv.hostPlatform.isDarwin) '' - substituteInPlace Makefile \ - --replace "\"libopenal.so.1\"" "\"${openal}/lib/libopenal.so.1\"" - ''; - - buildInputs = [ SDL2 libGL curl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa OpenAL ] + postPatch = + '' + substituteInPlace src/client/curl/qcurl.c \ + --replace "\"libcurl.so.3\", \"libcurl.so.4\"" "\"${curl.out}/lib/libcurl.so\", \"libcurl.so.3\", \"libcurl.so.4\"" + '' + + lib.optionalString (openalSupport && !stdenv.hostPlatform.isDarwin) '' + substituteInPlace Makefile \ + --replace "\"libopenal.so.1\"" "\"${openal}/lib/libopenal.so.1\"" + ''; + + buildInputs = + [ + SDL2 + libGL + curl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + OpenAL + ] ++ lib.optional openalSupport openal; makeFlags = [ @@ -57,14 +88,19 @@ let runHook postInstall ''; - desktopItems = [ (makeDesktopItem { - name = "yquake2"; - exec = "yquake2"; - icon = "yamagi-quake2"; - desktopName = "yquake2"; - comment = "Yamagi Quake II client"; - categories = [ "Game" "Shooter" ]; - })]; + desktopItems = [ + (makeDesktopItem { + name = "yquake2"; + exec = "yquake2"; + icon = "yamagi-quake2"; + desktopName = "yquake2"; + comment = "Yamagi Quake II client"; + categories = [ + "Game" + "Shooter" + ]; + }) + ]; meta = with lib; { description = "Yamagi Quake II client"; @@ -75,7 +111,8 @@ let }; }; -in { +in +{ inherit yquake2; yquake2-ctf = wrapper { diff --git a/pkgs/games/quake2/yquake2/games.nix b/pkgs/games/quake2/yquake2/games.nix index aca5ffb5e3f556..2e1053eded7262 100644 --- a/pkgs/games/quake2/yquake2/games.nix +++ b/pkgs/games/quake2/yquake2/games.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchFromGitHub }: +{ + stdenv, + lib, + fetchFromGitHub, +}: let games = { @@ -24,34 +28,41 @@ let }; }; - toDrv = title: data: stdenv.mkDerivation rec { - inherit (data) id version description sha256; - inherit title; + toDrv = + title: data: + stdenv.mkDerivation rec { + inherit (data) + id + version + description + sha256 + ; + inherit title; - pname = "yquake2-${title}"; + pname = "yquake2-${title}"; - src = fetchFromGitHub { - inherit sha256; - owner = "yquake2"; - repo = data.id; - rev = "${lib.toUpper id}_${builtins.replaceStrings ["."] ["_"] version}"; - }; + src = fetchFromGitHub { + inherit sha256; + owner = "yquake2"; + repo = data.id; + rev = "${lib.toUpper id}_${builtins.replaceStrings [ "." ] [ "_" ] version}"; + }; + + installPhase = '' + runHook preInstall + mkdir -p $out/lib/yquake2/${id} + cp release/* $out/lib/yquake2/${id} + runHook postInstall + ''; - installPhase = '' - runHook preInstall - mkdir -p $out/lib/yquake2/${id} - cp release/* $out/lib/yquake2/${id} - runHook postInstall - ''; - - meta = with lib; { - inherit (data) description; - homepage = "https://www.yamagi.org/quake2/"; - license = licenses.unfree; - platforms = platforms.unix; - maintainers = with maintainers; [ tadfisher ]; + meta = with lib; { + inherit (data) description; + homepage = "https://www.yamagi.org/quake2/"; + license = licenses.unfree; + platforms = platforms.unix; + maintainers = with maintainers; [ tadfisher ]; + }; }; - }; in - lib.mapAttrs toDrv games +lib.mapAttrs toDrv games diff --git a/pkgs/games/quake2/yquake2/wrapper.nix b/pkgs/games/quake2/yquake2/wrapper.nix index fafc1d3eaebd8d..696e5b34ab9fda 100644 --- a/pkgs/games/quake2/yquake2/wrapper.nix +++ b/pkgs/games/quake2/yquake2/wrapper.nix @@ -1,8 +1,17 @@ -{ stdenv, lib, buildEnv, makeWrapper, yquake2, copyDesktopItems, makeDesktopItem }: +{ + stdenv, + lib, + buildEnv, + makeWrapper, + yquake2, + copyDesktopItems, + makeDesktopItem, +}: -{ games -, name -, description +{ + games, + name, + description, }: let @@ -16,33 +25,43 @@ stdenv.mkDerivation { pname = name; version = lib.getVersion yquake2; - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; dontUnpack = true; - installPhase = '' - runHook preInstall - mkdir -p $out/bin - '' + lib.concatMapStringsSep "\n" (game: '' - makeWrapper ${env}/bin/yquake2 $out/bin/yquake2-${game.title} \ - --add-flags "+set game ${game.id}" - makeWrapper ${env}/bin/yq2ded $out/bin/yq2ded-${game.title} \ - --add-flags "+set game ${game.id}" - '') games + '' - install -Dm644 ${yquake2}/share/pixmaps/yamagi-quake2.png $out/share/pixmaps/yamagi-quake2.png; - runHook postInstall - ''; - - desktopItems = map - (game: makeDesktopItem ({ + installPhase = + '' + runHook preInstall + mkdir -p $out/bin + '' + + lib.concatMapStringsSep "\n" (game: '' + makeWrapper ${env}/bin/yquake2 $out/bin/yquake2-${game.title} \ + --add-flags "+set game ${game.id}" + makeWrapper ${env}/bin/yq2ded $out/bin/yq2ded-${game.title} \ + --add-flags "+set game ${game.id}" + '') games + + '' + install -Dm644 ${yquake2}/share/pixmaps/yamagi-quake2.png $out/share/pixmaps/yamagi-quake2.png; + runHook postInstall + ''; + + desktopItems = map ( + game: + makeDesktopItem ({ name = game.id; exec = game.title; icon = "yamagi-quake2"; desktopName = game.id; comment = game.description; - categories = [ "Game" "Shooter" ]; - })) - games; + categories = [ + "Game" + "Shooter" + ]; + }) + ) games; meta = { inherit description; diff --git a/pkgs/games/quake3/content/demo.nix b/pkgs/games/quake3/content/demo.nix index 36d0396ec7960f..9b3b4d06245b83 100644 --- a/pkgs/games/quake3/content/demo.nix +++ b/pkgs/games/quake3/content/demo.nix @@ -1,8 +1,13 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let version = "1.11-6"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "quake3-demodata"; inherit version; diff --git a/pkgs/games/quake3/content/hires.nix b/pkgs/games/quake3/content/hires.nix index 7314028d540572..2195e41313529c 100644 --- a/pkgs/games/quake3/content/hires.nix +++ b/pkgs/games/quake3/content/hires.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchzip }: +{ + stdenv, + lib, + fetchzip, +}: stdenv.mkDerivation { pname = "quake3hires"; diff --git a/pkgs/games/quake3/content/pointrelease.nix b/pkgs/games/quake3/content/pointrelease.nix index d9c9a55ddce978..e3b54859607021 100644 --- a/pkgs/games/quake3/content/pointrelease.nix +++ b/pkgs/games/quake3/content/pointrelease.nix @@ -1,8 +1,13 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: let version = "1.32b-3"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "quake3-pointrelease"; inherit version; diff --git a/pkgs/games/quake3/wrapper/default.nix b/pkgs/games/quake3/wrapper/default.nix index a1a5bfb03d26f0..15be84199b66dd 100644 --- a/pkgs/games/quake3/wrapper/default.nix +++ b/pkgs/games/quake3/wrapper/default.nix @@ -1,15 +1,30 @@ -{ stdenv, buildEnv, lib, libGL, ioquake3, makeWrapper }: - -{ paks, name ? (lib.head paks).name, description ? "" }: +{ + stdenv, + buildEnv, + lib, + libGL, + ioquake3, + makeWrapper, +}: + +{ + paks, + name ? (lib.head paks).name, + description ? "", +}: let - libPath = lib.makeLibraryPath [ libGL stdenv.cc.cc ]; + libPath = lib.makeLibraryPath [ + libGL + stdenv.cc.cc + ]; env = buildEnv { name = "quake3-env"; paths = [ ioquake3 ] ++ paks; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { name = "${name}-${ioquake3.name}"; nativeBuildInputs = [ makeWrapper ]; diff --git a/pkgs/games/quakespasm/default.nix b/pkgs/games/quakespasm/default.nix index 68153b580d851f..c947356d226d3b 100644 --- a/pkgs/games/quakespasm/default.nix +++ b/pkgs/games/quakespasm/default.nix @@ -1,7 +1,26 @@ -{ lib, stdenv, SDL, SDL2, fetchurl, gzip, libvorbis, libmad, flac, libopus, opusfile, libogg, libxmp -, Cocoa, CoreAudio, CoreFoundation, IOKit, OpenGL -, copyDesktopItems, makeDesktopItem, pkg-config -, useSDL2 ? stdenv.hostPlatform.isDarwin # TODO: CoreAudio fails to initialize with SDL 1.x for some reason. +{ + lib, + stdenv, + SDL, + SDL2, + fetchurl, + gzip, + libvorbis, + libmad, + flac, + libopus, + opusfile, + libogg, + libxmp, + Cocoa, + CoreAudio, + CoreFoundation, + IOKit, + OpenGL, + copyDesktopItems, + makeDesktopItem, + pkg-config, + useSDL2 ? stdenv.hostPlatform.isDarwin, # TODO: CoreAudio fails to initialize with SDL 1.x for some reason. }: stdenv.mkDerivation rec { @@ -30,32 +49,47 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - gzip libvorbis libmad flac libopus opusfile libogg libxmp - (if useSDL2 then SDL2 else SDL) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Cocoa CoreAudio IOKit OpenGL - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && useSDL2) [ - CoreFoundation - ]; - - buildFlags = [ - "DO_USERDIRS=1" - # Makefile defaults, set here to enforce consistency on Darwin build - "USE_CODEC_WAVE=1" - "USE_CODEC_MP3=1" - "USE_CODEC_VORBIS=1" - "USE_CODEC_FLAC=1" - "USE_CODEC_OPUS=1" - "USE_CODEC_MIKMOD=0" - "USE_CODEC_UMX=0" - "USE_CODEC_XMP=1" - "MP3LIB=mad" - "VORBISLIB=vorbis" - ] ++ lib.optionals useSDL2 [ - "SDL_CONFIG=sdl2-config" - "USE_SDL2=1" - ]; + buildInputs = + [ + gzip + libvorbis + libmad + flac + libopus + opusfile + libogg + libxmp + (if useSDL2 then SDL2 else SDL) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + CoreAudio + IOKit + OpenGL + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && useSDL2) [ + CoreFoundation + ]; + + buildFlags = + [ + "DO_USERDIRS=1" + # Makefile defaults, set here to enforce consistency on Darwin build + "USE_CODEC_WAVE=1" + "USE_CODEC_MP3=1" + "USE_CODEC_VORBIS=1" + "USE_CODEC_FLAC=1" + "USE_CODEC_OPUS=1" + "USE_CODEC_MIKMOD=0" + "USE_CODEC_UMX=0" + "USE_CODEC_XMP=1" + "MP3LIB=mad" + "VORBISLIB=vorbis" + ] + ++ lib.optionals useSDL2 [ + "SDL_CONFIG=sdl2-config" + "USE_SDL2=1" + ]; makefile = if (stdenv.hostPlatform.isDarwin) then "Makefile.darwin" else "Makefile"; diff --git a/pkgs/games/quakespasm/vulkan.nix b/pkgs/games/quakespasm/vulkan.nix index 4c84267c1d4c96..137bf667f2f4e5 100644 --- a/pkgs/games/quakespasm/vulkan.nix +++ b/pkgs/games/quakespasm/vulkan.nix @@ -38,19 +38,21 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - SDL2 - flac - gzip - libmpg123 - libopus - libvorbis - opusfile - vulkan-loader - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - moltenvk - vulkan-headers - ]; + buildInputs = + [ + SDL2 + flac + gzip + libmpg123 + libopus + libvorbis + opusfile + vulkan-loader + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + moltenvk + vulkan-headers + ]; buildFlags = [ "DO_USERDIRS=1" ]; @@ -84,7 +86,10 @@ stdenv.mkDerivation rec { ''; platforms = with platforms; linux ++ darwin; - maintainers = with maintainers; [ PopeRigby ylh ]; + maintainers = with maintainers; [ + PopeRigby + ylh + ]; mainProgram = "vkquake"; }; } diff --git a/pkgs/games/qzdl/default.nix b/pkgs/games/qzdl/default.nix index ad880c09522f3b..de7cef007f2756 100644 --- a/pkgs/games/qzdl/default.nix +++ b/pkgs/games/qzdl/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, inih -, ninja -, pkg-config -, qtbase -, wrapQtAppsHook -, makeDesktopItem -, copyDesktopItems +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + inih, + ninja, + pkg-config, + qtbase, + wrapQtAppsHook, + makeDesktopItem, + copyDesktopItems, }: stdenv.mkDerivation rec { diff --git a/pkgs/games/rare/default.nix b/pkgs/games/rare/default.nix index ae65bdc2f17192..4df7d3cd69d743 100644 --- a/pkgs/games/rare/default.nix +++ b/pkgs/games/rare/default.nix @@ -1,16 +1,17 @@ -{ lib -, fetchFromGitHub -, buildPythonApplication -, qt5 -, legendary-gl -, orjson -, pypresence -, pyqt5 -, python -, qtawesome -, requests -, setuptools -, typing-extensions +{ + lib, + fetchFromGitHub, + buildPythonApplication, + qt5, + legendary-gl, + orjson, + pypresence, + pyqt5, + python, + qtawesome, + requests, + setuptools, + typing-extensions, }: buildPythonApplication rec { diff --git a/pkgs/games/rogue/default.nix b/pkgs/games/rogue/default.nix index 886450869f33c0..dcb16306767a62 100644 --- a/pkgs/games/rogue/default.nix +++ b/pkgs/games/rogue/default.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, ncurses}: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "rogue"; diff --git a/pkgs/games/rott/default.nix b/pkgs/games/rott/default.nix index e678994e47f0f5..a91187730151d6 100644 --- a/pkgs/games/rott/default.nix +++ b/pkgs/games/rott/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchurl -, writeShellScript -, SDL -, SDL_mixer -, makeDesktopItem -, copyDesktopItems -, runtimeShell -, buildShareware ? false +{ + stdenv, + lib, + fetchurl, + writeShellScript, + SDL, + SDL_mixer, + makeDesktopItem, + copyDesktopItems, + runtimeShell, + buildShareware ? false, }: let @@ -32,7 +33,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ copyDesktopItems ]; - buildInputs = [ SDL SDL_mixer ]; + buildInputs = [ + SDL + SDL_mixer + ]; sourceRoot = "rott-${version}/rott"; diff --git a/pkgs/games/scummvm/default.nix b/pkgs/games/scummvm/default.nix index 32e7524645c312..19e4dfe74bb07e 100644 --- a/pkgs/games/scummvm/default.nix +++ b/pkgs/games/scummvm/default.nix @@ -1,6 +1,30 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, nasm -, alsa-lib, curl, flac, fluidsynth, freetype, libjpeg, libmad, libmpeg2, libogg, libtheora, libvorbis, libGLU, libGL, SDL2, zlib -, Cocoa, AudioToolbox, Carbon, CoreMIDI, AudioUnit, cctools +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + nasm, + alsa-lib, + curl, + flac, + fluidsynth, + freetype, + libjpeg, + libmad, + libmpeg2, + libogg, + libtheora, + libvorbis, + libGLU, + libGL, + SDL2, + zlib, + Cocoa, + AudioToolbox, + Carbon, + CoreMIDI, + AudioUnit, + cctools, }: stdenv.mkDerivation rec { @@ -24,13 +48,33 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ nasm ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib libGLU libGL - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Cocoa AudioToolbox Carbon CoreMIDI AudioUnit - ] ++ [ - curl freetype flac fluidsynth libjpeg libmad libmpeg2 libogg libtheora libvorbis SDL2 zlib - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + libGLU + libGL + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + AudioToolbox + Carbon + CoreMIDI + AudioUnit + ] + ++ [ + curl + freetype + flac + fluidsynth + libjpeg + libmad + libmpeg2 + libogg + libtheora + libvorbis + SDL2 + zlib + ]; dontDisableStatic = true; @@ -42,13 +86,15 @@ stdenv.mkDerivation rec { ]; # They use 'install -s', that calls the native strip instead of the cross - postConfigure = '' - sed -i "s/-c -s/-c -s --strip-program=''${STRIP@Q}/" ports.mk - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace config.mk \ - --replace x86_64-apple-darwin-ranlib ${cctools}/bin/ranlib \ - --replace aarch64-apple-darwin-ranlib ${cctools}/bin/ranlib - ''; + postConfigure = + '' + sed -i "s/-c -s/-c -s --strip-program=''${STRIP@Q}/" ports.mk + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace config.mk \ + --replace x86_64-apple-darwin-ranlib ${cctools}/bin/ranlib \ + --replace aarch64-apple-darwin-ranlib ${cctools}/bin/ranlib + ''; NIX_CFLAGS_COMPILE = [ "-fpermissive" ]; diff --git a/pkgs/games/scummvm/games.nix b/pkgs/games/scummvm/games.nix index b146bf1bc49da7..adf358522abeed 100644 --- a/pkgs/games/scummvm/games.nix +++ b/pkgs/games/scummvm/games.nix @@ -1,66 +1,106 @@ -{ stdenv, lib, fetchurl, makeDesktopItem, unzip, writeText -, scummvm, runtimeShell }: +{ + stdenv, + lib, + fetchurl, + makeDesktopItem, + unzip, + writeText, + scummvm, + runtimeShell, +}: let - desktopItem = name: short: long: description: makeDesktopItem { - categories = [ "Game" "AdventureGame" ]; - comment = description; - desktopName = long; - exec = "@out@/bin/${short}"; - genericName = description; - icon = "scummvm"; - name = name; - }; - - run = name: short: code: writeText "${short}.sh" '' - #!${runtimeShell} -eu - - exec ${scummvm}/bin/scummvm \ - --path=@out@/share/${name} \ - --fullscreen \ - ${code} - ''; + desktopItem = + name: short: long: description: + makeDesktopItem { + categories = [ + "Game" + "AdventureGame" + ]; + comment = description; + desktopName = long; + exec = "@out@/bin/${short}"; + genericName = description; + icon = "scummvm"; + name = name; + }; - generic = { plong, pshort, pcode, description, version, files, docs ? [ "readme.txt" ], ... } @attrs: + run = + name: short: code: + writeText "${short}.sh" '' + #!${runtimeShell} -eu + + exec ${scummvm}/bin/scummvm \ + --path=@out@/share/${name} \ + --fullscreen \ + ${code} + ''; + + generic = + { + plong, + pshort, + pcode, + description, + version, + files, + docs ? [ "readme.txt" ], + ... + }@attrs: let - attrs' = builtins.removeAttrs attrs [ "plong" "pshort" "pcode" "description" "docs" "files" "version" ]; + attrs' = builtins.removeAttrs attrs [ + "plong" + "pshort" + "pcode" + "description" + "docs" + "files" + "version" + ]; pname = lib.replaceStrings [ " " ":" ] [ "-" "" ] (lib.toLower plong); - in stdenv.mkDerivation ({ - name = "${pname}-${version}"; + in + stdenv.mkDerivation ( + { + name = "${pname}-${version}"; - nativeBuildInputs = [ unzip ]; + nativeBuildInputs = [ unzip ]; - dontBuild = true; - dontFixup = true; + dontBuild = true; + dontFixup = true; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $out/bin $out/share/{applications,${pname},doc/${pname}} + mkdir -p $out/bin $out/share/{applications,${pname},doc/${pname}} - ${lib.concatStringsSep "\n" (map (f: "mv ${f} $out/share/doc/${pname}") docs)} - ${lib.concatStringsSep "\n" (map (f: "mv ${f} $out/share/${pname}") files)} + ${lib.concatStringsSep "\n" (map (f: "mv ${f} $out/share/doc/${pname}") docs)} + ${lib.concatStringsSep "\n" (map (f: "mv ${f} $out/share/${pname}") files)} - substitute ${run pname pshort pcode} $out/bin/${pshort} \ - --subst-var out - substitute ${desktopItem pname pshort plong description}/share/applications/${pname}.desktop $out/share/applications/${pname}.desktop \ - --subst-var out + substitute ${run pname pshort pcode} $out/bin/${pshort} \ + --subst-var out + substitute ${ + desktopItem pname pshort plong description + }/share/applications/${pname}.desktop $out/share/applications/${pname}.desktop \ + --subst-var out - chmod 0755 $out/bin/${pshort} + chmod 0755 $out/bin/${pshort} - runHook postInstall - ''; + runHook postInstall + ''; - meta = with lib; { - homepage = "https://www.scummvm.org"; - license = licenses.free; # refer to the readme for exact wording - maintainers = with maintainers; [ peterhoeg ]; - inherit description; - inherit (scummvm.meta) platforms; - }; - } // attrs'); + meta = with lib; { + homepage = "https://www.scummvm.org"; + license = licenses.free; # refer to the readme for exact wording + maintainers = with maintainers; [ peterhoeg ]; + inherit description; + inherit (scummvm.meta) platforms; + }; + } + // attrs' + ); -in { +in +{ beneath-a-steel-sky = generic rec { plong = "Beneath a Steel Sky"; pshort = "bass"; @@ -85,7 +125,10 @@ in { sha256 = "0ivj1vflfpih5bs5a902mab88s4d77fwm3ya3fk7pammzc8gjqzz"; }; sourceRoot = "."; - docs = [ "README" "license-original.txt" ]; + docs = [ + "README" + "license-original.txt" + ]; files = [ "data.b25c" ]; }; @@ -96,17 +139,20 @@ in { description = "Spanish 2D classic point & click style adventure with tons of humor and an easy interface"; version = "1.0"; # srcs = { - src = fetchurl { - url = "mirror://sourceforge/scummvm/${pshort}-${version}.zip"; - sha256 = "1pj29rpb754sn6a56f8brfv6f2m1p5qgaqik7d68pfi2bb5zccdp"; - }; - # audio = fetchurl { - # url = "mirror://sourceforge/scummvm/${pshort}-audio-flac-2.0.zip"; - # sha256 = "1zmqhrby8f5sj1qy6xjdgkvk9wyhr3nw8ljrrl58fmxb83x1rryw"; - # }; + src = fetchurl { + url = "mirror://sourceforge/scummvm/${pshort}-${version}.zip"; + sha256 = "1pj29rpb754sn6a56f8brfv6f2m1p5qgaqik7d68pfi2bb5zccdp"; + }; + # audio = fetchurl { + # url = "mirror://sourceforge/scummvm/${pshort}-audio-flac-2.0.zip"; + # sha256 = "1zmqhrby8f5sj1qy6xjdgkvk9wyhr3nw8ljrrl58fmxb83x1rryw"; + # }; # }; sourceRoot = "."; - docs = [ "readme.txt" "drascula.doc" ]; + docs = [ + "readme.txt" + "drascula.doc" + ]; files = [ "Packet.001" ]; }; @@ -122,7 +168,11 @@ in { }; sourceRoot = "."; docs = [ "license.txt" ]; - files = [ "DREAMWEB.*" "SPEECH" "track01.flac" ]; + files = [ + "DREAMWEB.*" + "SPEECH" + "track01.flac" + ]; }; flight-of-the-amazon-queen = generic rec { @@ -149,7 +199,12 @@ in { url = "mirror://sourceforge/scummvm/lure-${version}.zip"; sha256 = "0201i70qcs1m797kvxjx3ygkhg6kcl5yf49sihba2ga8l52q45zk"; }; - docs = [ "README" "*.txt" "*.pdf" "*.PDF" ]; + docs = [ + "README" + "*.txt" + "*.pdf" + "*.PDF" + ]; files = [ "*.vga" ]; }; } diff --git a/pkgs/games/sgt-puzzles/default.nix b/pkgs/games/sgt-puzzles/default.nix index 9fda50f71ba28b..43cccbdfb6805b 100644 --- a/pkgs/games/sgt-puzzles/default.nix +++ b/pkgs/games/sgt-puzzles/default.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, fetchurl, desktop-file-utils -, gtk3, libX11, cmake, imagemagick -, pkg-config, perl, wrapGAppsHook3, nixosTests, writeScript -, isMobile ? false +{ + lib, + stdenv, + fetchurl, + desktop-file-utils, + gtk3, + libX11, + cmake, + imagemagick, + pkg-config, + perl, + wrapGAppsHook3, + nixosTests, + writeScript, + isMobile ? false, }: stdenv.mkDerivation rec { @@ -29,7 +40,10 @@ stdenv.mkDerivation rec { env.NIX_CFLAGS_COMPILE = lib.optionalString isMobile "-DSTYLUS_BASED"; - buildInputs = [ gtk3 libX11 ]; + buildInputs = [ + gtk3 + libX11 + ]; postInstall = '' for i in $(basename -s $out/bin/*); do @@ -75,7 +89,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Simon Tatham's portable puzzle collection"; license = licenses.mit; - maintainers = with maintainers; [ raskin tomfitzhenry ]; + maintainers = with maintainers; [ + raskin + tomfitzhenry + ]; platforms = platforms.linux; homepage = "https://www.chiark.greenend.org.uk/~sgtatham/puzzles/"; }; diff --git a/pkgs/games/shattered-pixel-dungeon/default.nix b/pkgs/games/shattered-pixel-dungeon/default.nix index 8b57fcb2535225..68576174127e61 100644 --- a/pkgs/games/shattered-pixel-dungeon/default.nix +++ b/pkgs/games/shattered-pixel-dungeon/default.nix @@ -1,6 +1,7 @@ -{ callPackage -, fetchFromGitHub -, nixosTests +{ + callPackage, + fetchFromGitHub, + nixosTests, }: callPackage ./generic.nix rec { diff --git a/pkgs/games/shattered-pixel-dungeon/experienced-pixel-dungeon/default.nix b/pkgs/games/shattered-pixel-dungeon/experienced-pixel-dungeon/default.nix index 60a0b67232ca71..099f4f255989c1 100644 --- a/pkgs/games/shattered-pixel-dungeon/experienced-pixel-dungeon/default.nix +++ b/pkgs/games/shattered-pixel-dungeon/experienced-pixel-dungeon/default.nix @@ -1,5 +1,6 @@ -{ callPackage -, fetchFromGitHub +{ + callPackage, + fetchFromGitHub, }: callPackage ../generic.nix rec { diff --git a/pkgs/games/shattered-pixel-dungeon/generic.nix b/pkgs/games/shattered-pixel-dungeon/generic.nix index 30d7f3f472601d..496f54cf426e8d 100644 --- a/pkgs/games/shattered-pixel-dungeon/generic.nix +++ b/pkgs/games/shattered-pixel-dungeon/generic.nix @@ -1,23 +1,24 @@ # Generic builder for shattered pixel forks/mods -{ pname -, version -, src -, meta -, desktopName -, patches ? [ ./disable-beryx.patch ] -, depsPath ? null - -, lib -, stdenv -, makeWrapper -, gradle_8 -, perl -, jre -, libGL -, libpulseaudio -, makeDesktopItem -, copyDesktopItems -, ... +{ + pname, + version, + src, + meta, + desktopName, + patches ? [ ./disable-beryx.patch ], + depsPath ? null, + + lib, + stdenv, + makeWrapper, + gradle_8, + perl, + jre, + libGL, + libpulseaudio, + makeDesktopItem, + copyDesktopItems, + ... }@attrs: let @@ -49,8 +50,15 @@ let icon = pname; exec = pname; terminal = false; - categories = [ "Game" "AdventureGame" ]; - keywords = [ "roguelike" "dungeon" "crawler" ]; + categories = [ + "Game" + "AdventureGame" + ]; + keywords = [ + "roguelike" + "dungeon" + "crawler" + ]; }; depsPath' = if depsPath != null then depsPath else ./. + "/${pname}/deps.json"; @@ -58,59 +66,77 @@ let # "Deprecated Gradle features were used in this build, making it incompatible with Gradle 9.0." gradle = gradle_8; -in stdenv.mkDerivation (cleanAttrs // { - inherit pname version src patches postPatch; - - mitmCache = gradle.fetchDeps { - inherit pname; - data = depsPath'; - }; - - __darwinAllowLocalNetworking = true; - - nativeBuildInputs = [ - gradle - perl - makeWrapper - copyDesktopItems - ] ++ attrs.nativeBuildInputs or []; - - desktopItems = [ desktopItem ]; - - gradleBuildTask = "desktop:release"; - - installPhase = '' - runHook preInstall - - install -Dm644 desktop/build/libs/desktop-*.jar $out/share/${pname}.jar - mkdir $out/bin - makeWrapper ${jre}/bin/java $out/bin/${pname} \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ libGL libpulseaudio ]} \ - --add-flags "-jar $out/share/${pname}.jar" - - for s in 16 32 48 64 128 256; do - # Some forks only have some icons and/or name them slightly differently - if [ -f desktop/src/main/assets/icons/icon_$s.png ]; then - install -Dm644 desktop/src/main/assets/icons/icon_$s.png \ - $out/share/icons/hicolor/''${s}x$s/apps/${pname}.png - fi - if [ -f desktop/src/main/assets/icons/icon_''${s}x$s.png ]; then - install -Dm644 desktop/src/main/assets/icons/icon_''${s}x$s.png \ - $out/share/icons/hicolor/''${s}x$s/apps/${pname}.png - fi - done - - runHook postInstall - ''; - - meta = with lib; { - sourceProvenance = with sourceTypes; [ - fromSource - binaryBytecode # deps - ]; - license = licenses.gpl3Plus; - maintainers = with maintainers; [ fgaz ]; - platforms = platforms.all; - mainProgram = pname; - } // meta; -}) +in +stdenv.mkDerivation ( + cleanAttrs + // { + inherit + pname + version + src + patches + postPatch + ; + + mitmCache = gradle.fetchDeps { + inherit pname; + data = depsPath'; + }; + + __darwinAllowLocalNetworking = true; + + nativeBuildInputs = [ + gradle + perl + makeWrapper + copyDesktopItems + ] ++ attrs.nativeBuildInputs or [ ]; + + desktopItems = [ desktopItem ]; + + gradleBuildTask = "desktop:release"; + + installPhase = '' + runHook preInstall + + install -Dm644 desktop/build/libs/desktop-*.jar $out/share/${pname}.jar + mkdir $out/bin + makeWrapper ${jre}/bin/java $out/bin/${pname} \ + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + libGL + libpulseaudio + ] + } \ + --add-flags "-jar $out/share/${pname}.jar" + + for s in 16 32 48 64 128 256; do + # Some forks only have some icons and/or name them slightly differently + if [ -f desktop/src/main/assets/icons/icon_$s.png ]; then + install -Dm644 desktop/src/main/assets/icons/icon_$s.png \ + $out/share/icons/hicolor/''${s}x$s/apps/${pname}.png + fi + if [ -f desktop/src/main/assets/icons/icon_''${s}x$s.png ]; then + install -Dm644 desktop/src/main/assets/icons/icon_''${s}x$s.png \ + $out/share/icons/hicolor/''${s}x$s/apps/${pname}.png + fi + done + + runHook postInstall + ''; + + meta = + with lib; + { + sourceProvenance = with sourceTypes; [ + fromSource + binaryBytecode # deps + ]; + license = licenses.gpl3Plus; + maintainers = with maintainers; [ fgaz ]; + platforms = platforms.all; + mainProgram = pname; + } + // meta; + } +) diff --git a/pkgs/games/shattered-pixel-dungeon/rat-king-adventure/default.nix b/pkgs/games/shattered-pixel-dungeon/rat-king-adventure/default.nix index 8fab6cee257cf0..094641c94b1169 100644 --- a/pkgs/games/shattered-pixel-dungeon/rat-king-adventure/default.nix +++ b/pkgs/games/shattered-pixel-dungeon/rat-king-adventure/default.nix @@ -1,5 +1,6 @@ -{ callPackage -, fetchFromGitHub +{ + callPackage, + fetchFromGitHub, }: callPackage ../generic.nix rec { diff --git a/pkgs/games/shattered-pixel-dungeon/rkpd2/default.nix b/pkgs/games/shattered-pixel-dungeon/rkpd2/default.nix index 9efa5fde80ffef..3d2ef02739c464 100644 --- a/pkgs/games/shattered-pixel-dungeon/rkpd2/default.nix +++ b/pkgs/games/shattered-pixel-dungeon/rkpd2/default.nix @@ -1,5 +1,6 @@ -{ callPackage -, fetchFromGitHub +{ + callPackage, + fetchFromGitHub, }: callPackage ../generic.nix rec { diff --git a/pkgs/games/shattered-pixel-dungeon/shorter-pixel-dungeon/default.nix b/pkgs/games/shattered-pixel-dungeon/shorter-pixel-dungeon/default.nix index 8fb66c87b34535..7dde5e15b74726 100644 --- a/pkgs/games/shattered-pixel-dungeon/shorter-pixel-dungeon/default.nix +++ b/pkgs/games/shattered-pixel-dungeon/shorter-pixel-dungeon/default.nix @@ -1,5 +1,6 @@ -{ callPackage -, fetchFromGitHub +{ + callPackage, + fetchFromGitHub, }: callPackage ../generic.nix rec { diff --git a/pkgs/games/shattered-pixel-dungeon/summoning-pixel-dungeon/default.nix b/pkgs/games/shattered-pixel-dungeon/summoning-pixel-dungeon/default.nix index 86cd351f2c591f..d0b3e50fa5e6ee 100644 --- a/pkgs/games/shattered-pixel-dungeon/summoning-pixel-dungeon/default.nix +++ b/pkgs/games/shattered-pixel-dungeon/summoning-pixel-dungeon/default.nix @@ -1,7 +1,8 @@ -{ callPackage -, fetchFromGitHub -, fetchpatch -, substitute +{ + callPackage, + fetchFromGitHub, + fetchpatch, + substitute, }: callPackage ../generic.nix rec { @@ -19,7 +20,11 @@ callPackage ../generic.nix rec { patches = [ (substitute { src = ./disable-git-version.patch; - substitutions = [ "--subst-var-by" "version" version ]; + substitutions = [ + "--subst-var-by" + "version" + version + ]; }) # FIXME: Remove after next release (fetchpatch { diff --git a/pkgs/games/soi/default.nix b/pkgs/games/soi/default.nix index 67f1b5b211a71c..c99a422fe27d1a 100644 --- a/pkgs/games/soi/default.nix +++ b/pkgs/games/soi/default.nix @@ -1,5 +1,16 @@ -{ lib, stdenv, fetchurl, cmake -, boost, eigen2, lua, luabind, libGLU, libGL, SDL }: +{ + lib, + stdenv, + fetchurl, + cmake, + boost, + eigen2, + lua, + luabind, + libGLU, + libGL, + SDL, +}: stdenv.mkDerivation rec { pname = "soi"; @@ -12,7 +23,14 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ boost lua luabind libGLU libGL SDL ]; + buildInputs = [ + boost + lua + luabind + libGLU + libGL + SDL + ]; cmakeFlags = [ "-DEIGEN_INCLUDE_DIR=${eigen2}/include/eigen2" diff --git a/pkgs/games/solarus/default.nix b/pkgs/games/solarus/default.nix index b59c20c2b32269..90b988de4796e6 100644 --- a/pkgs/games/solarus/default.nix +++ b/pkgs/games/solarus/default.nix @@ -1,7 +1,20 @@ -{ lib, mkDerivation, fetchFromGitLab, cmake, luajit -, SDL2, SDL2_image, SDL2_ttf, physfs, glm -, openal, libmodplug, libvorbis -, qtbase, qttools }: +{ + lib, + mkDerivation, + fetchFromGitLab, + cmake, + luajit, + SDL2, + SDL2_image, + SDL2_ttf, + physfs, + glm, + openal, + libmodplug, + libvorbis, + qtbase, + qttools, +}: mkDerivation rec { pname = "solarus"; @@ -14,13 +27,28 @@ mkDerivation rec { sha256 = "sbdlf+R9OskDQ5U5rqUX2gF8l/fj0sDJv6BL7H1I1Ng="; }; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; - nativeBuildInputs = [ cmake qttools ]; - buildInputs = [ luajit SDL2 - SDL2_image SDL2_ttf physfs - openal libmodplug libvorbis - qtbase glm ]; + nativeBuildInputs = [ + cmake + qttools + ]; + buildInputs = [ + luajit + SDL2 + SDL2_image + SDL2_ttf + physfs + openal + libmodplug + libvorbis + qtbase + glm + ]; cmakeFlags = [ (lib.cmakeFeature "CMAKE_CXX_FLAGS" "-DGLM_ENABLE_EXPERIMENTAL") diff --git a/pkgs/games/space-station-14-launcher/default.nix b/pkgs/games/space-station-14-launcher/default.nix index ecf1d8781a5a41..d39129c092a2c7 100644 --- a/pkgs/games/space-station-14-launcher/default.nix +++ b/pkgs/games/space-station-14-launcher/default.nix @@ -1,7 +1,8 @@ -{ soundfont-fluid -, buildFHSEnv -, runCommand -, callPackage +{ + soundfont-fluid, + buildFHSEnv, + runCommand, + callPackage, }: let diff --git a/pkgs/games/space-station-14-launcher/deps.nix b/pkgs/games/space-station-14-launcher/deps.nix index 92ce23401995ca..c046903f24e657 100644 --- a/pkgs/games/space-station-14-launcher/deps.nix +++ b/pkgs/games/space-station-14-launcher/deps.nix @@ -1,143 +1,696 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Avalonia"; version = "11.0.5"; hash = "sha256-BqpHqQIObTb7DHTyZAgCD9A5I0pZkHhSoPTN2g6/G9E="; }) - (fetchNuGet { pname = "Avalonia.Angle.Windows.Natives"; version = "2.1.0.2023020321"; hash = "sha256-TWop9cvak6cMv2vrA/GlpuYBxS8Fuj5UmupGIV7Q5Ks="; }) - (fetchNuGet { pname = "Avalonia.BuildServices"; version = "0.0.29"; hash = "sha256-WPHRMNowRnYSCh88DWNBCltWsLPyOfzXGzBqLYE7tRY="; }) - (fetchNuGet { pname = "Avalonia.Controls.ColorPicker"; version = "11.0.5"; hash = "sha256-Iob8OyWhwXhmHKCdnea7dtL9VQvcrf6/gUGHJ30CKXA="; }) - (fetchNuGet { pname = "Avalonia.Controls.DataGrid"; version = "11.0.5"; hash = "sha256-2iVuMPRw7sbsYPGSG4XjQFGFky5WB5B05Jh1+I852ZI="; }) - (fetchNuGet { pname = "Avalonia.Desktop"; version = "11.0.5"; hash = "sha256-UKVibxhJoGNvEGh8J/Z0sq8J81FT8yth/yXVPSFHF/8="; }) - (fetchNuGet { pname = "Avalonia.Diagnostics"; version = "11.0.5"; hash = "sha256-0cUxPYJP2W11wnM6j4qNB3IvHlsUp9EZlY8I/NoAmd4="; }) - (fetchNuGet { pname = "Avalonia.FreeDesktop"; version = "11.0.5"; hash = "sha256-O20fC/9YXO3/MZNlh1EgWLHFSyi/ao083MKwjetgxmo="; }) - (fetchNuGet { pname = "Avalonia.Native"; version = "11.0.5"; hash = "sha256-KVUAXXT+f4VrtJ8widfEIzN25GBbtXWog/tpM354gdg="; }) - (fetchNuGet { pname = "Avalonia.ReactiveUI"; version = "11.0.5"; hash = "sha256-8tGLyA0PRKt1REb9YeCtEDz5oB886PRG35aO0uZm/jU="; }) - (fetchNuGet { pname = "Avalonia.Remote.Protocol"; version = "11.0.5"; hash = "sha256-wTqdxPU3Ql7jC4JFkChbUfaRR0nqUKrYKn8oexdFyig="; }) - (fetchNuGet { pname = "Avalonia.Skia"; version = "11.0.5"; hash = "sha256-rKOgkNLCwEVVcyLCimvhDUDKXnrDOguUryaGVOPFFwE="; }) - (fetchNuGet { pname = "Avalonia.Themes.Simple"; version = "11.0.5"; hash = "sha256-27evmgSrIx+EopF6E3N1cT7BvAUc/s99TVEMfmG83cQ="; }) - (fetchNuGet { pname = "Avalonia.Win32"; version = "11.0.5"; hash = "sha256-ncZLGKhpfjuuVPz4Fs+P6L3dM0KRnwAC3xJRqyvpKw8="; }) - (fetchNuGet { pname = "Avalonia.X11"; version = "11.0.5"; hash = "sha256-rvs3hwRh3F5E1j3JqcodWJTHV3BTWMKkvzq170tuPa4="; }) - (fetchNuGet { pname = "CodeHollow.FeedReader"; version = "1.2.6"; hash = "sha256-uw58N3j/ZsBmBaYeXrSwg6f4ObWChM2GduwAzmNDiak="; }) - (fetchNuGet { pname = "Dapper"; version = "2.0.123"; hash = "sha256-Ic3pMHtq5jF94tPi8l5MFDGyLnEZYofcqxbH5yDLHZY="; }) - (fetchNuGet { pname = "DynamicData"; version = "7.13.1"; hash = "sha256-wSMqsqAWKqVaIDVlRtycTiS0R3fQxknfEPfBaYVawkM="; }) - (fetchNuGet { pname = "Fody"; version = "6.6.4"; hash = "sha256-Xe9sGzIdQ970f0RwxD3KhdfqvGUoTpim2u2oqYHkDcI="; }) - (fetchNuGet { pname = "HarfBuzzSharp"; version = "2.8.2.3"; hash = "sha256-4tbdgUabPjlkBm3aUFeocj4Fdslmms2olDFpzOLyqoQ="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Linux"; version = "2.8.2.3"; hash = "sha256-3xwVfNfKTkuLdnT+e3bfG9tNTdEmar7ByzY+NTlUKLg="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.macOS"; version = "2.8.2.3"; hash = "sha256-ZohUEaovj/sRB4rjuJIOq6S9eim3m+qMlpHIebNDTRQ="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; version = "2.8.2.3"; hash = "sha256-ZsiBGpXfODHUHPgU/50k9QR/j6Klo7rsB0SUt8zYcBA="; }) - (fetchNuGet { pname = "HarfBuzzSharp.NativeAssets.Win32"; version = "2.8.2.3"; hash = "sha256-5GSzM5IUoOwK+zJg0d74WlT3n1VZly8pKlyjiqVocCI="; }) - (fetchNuGet { pname = "JetBrains.Annotations"; version = "2023.2.0-eap3"; hash = "sha256-s+SCNDcc8ZHFQXwXte0dfI9NOmqFUQK2IjBA0atT04k="; }) - (fetchNuGet { pname = "libsodium"; version = "1.0.18.2"; hash = "sha256-gjaW2AYXQSb3LLjtQDjWSxkTmEiqIoIb7NFx0+AlrQs="; }) - (fetchNuGet { pname = "Linguini.Bundle"; version = "0.8.1"; hash = "sha256-SirB65XjhxBkS+OERZP1e+6l2xZl9DFLz2ST5k2x9tw="; }) - (fetchNuGet { pname = "Linguini.Shared"; version = "0.8.0"; hash = "sha256-BnCgq61zLy6MMG6gNnZiIOjJNy/So1DPUsdR83m5ACM="; }) - (fetchNuGet { pname = "Linguini.Syntax"; version = "0.8.0"; hash = "sha256-x5PIdYJVCvIJxsDRP0GZ1PUbAPJl6K4i+K/LNpNE1D0="; }) - (fetchNuGet { pname = "MicroCom.Runtime"; version = "0.11.0"; hash = "sha256-VdwpP5fsclvNqJuppaOvwEwv2ofnAI5ZSz2V+UEdLF0="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.0.0"; hash = "sha256-KDbCfsBWSJ5ohEXUKp1s1LX9xA2NPvXE/xVzj68EdC0="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "3.8.0"; hash = "sha256-3G9vSc/gHH7FWgOySLTut1+eEaf3H66qcPOvNPLOx4o="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "3.8.0"; hash = "sha256-i/r3V/No/VzqmJlWxpGoirvlbJDbBPa/ONZtzYrxuc4="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp.Scripting"; version = "3.8.0"; hash = "sha256-fA9Qu+vTyMZ9REzxJ4aMg/SHCDRk4q9k4ZGUdynoHnA="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Scripting.Common"; version = "3.8.0"; hash = "sha256-866jMHp8kbc1FYpKuUWnd7ViU6kGJTAxPcL/IjXrT0I="; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.3.0"; hash = "sha256-a3dAiPaVuky0wpcHmpTVtAQJNGZ2v91/oArA+dpJgj8="; }) - (fetchNuGet { pname = "Microsoft.Data.Sqlite.Core"; version = "7.0.4"; hash = "sha256-+8pB6kjwp5dNxKZ54zM7xqWSkzQYRiB8AIw2JBeSDlY="; }) - (fetchNuGet { pname = "Microsoft.NET.ILLink.Tasks"; version = "8.0.0"; hash = "sha256-BAbtucZQvBgbiJ51UAL/Ilx+dz96LpWmfjnnNGlcw48="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "2.1.2"; hash = "sha256-gYQQO7zsqG+OtN4ywYQyfsiggS2zmxw4+cPXlK+FB5Q="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; }) - (fetchNuGet { pname = "Microsoft.Toolkit.Mvvm"; version = "7.1.2"; hash = "sha256-JOxZGQGm1WPkIpIDurQnlYk+QgHxJLPguJfCQLJ8NEM="; }) - (fetchNuGet { pname = "Microsoft.Win32.SystemEvents"; version = "6.0.0"; hash = "sha256-N9EVZbl5w1VnMywGXyaVWzT9lh84iaJ3aD48hIBk1zA="; }) - (fetchNuGet { pname = "Mono.Posix.NETStandard"; version = "1.0.0"; hash = "sha256-/F61k7MY/fu2FcfW7CkyjuUroKwlYAXPQFVeDs1QknY="; }) - (fetchNuGet { pname = "NSec.Cryptography"; version = "22.4.0"; hash = "sha256-TVB8MDXan3dQphaYG/rLQMWgpYJ6WE5ORiqiQrfnCW0="; }) - (fetchNuGet { pname = "ReactiveUI"; version = "18.4.26"; hash = "sha256-SvWTQfgwwIIwwj67J42fb+Gm8u74iawPd7JqYuYmEnY="; }) - (fetchNuGet { pname = "ReactiveUI.Fody"; version = "18.4.26"; hash = "sha256-ucLfi/HB3cJIdmNssfazZAXPC8QJ35YVA+GtWKVU6UQ="; }) - (fetchNuGet { pname = "Robust.Natives"; version = "0.1.1"; hash = "sha256-/DPbgIzIqZx7ClHKSgI88p03xwKSNWY/MqNri2ZX7uo="; }) - (fetchNuGet { pname = "Robust.Natives.Angle"; version = "0.1.1-chromium4758"; hash = "sha256-UGVYx1AZ0K/vzApEshxNQinx7jg43WAMB1lf0yRtnis="; }) - (fetchNuGet { pname = "Robust.Natives.Fluidsynth"; version = "0.1.0"; hash = "sha256-XRyvRqEcEFFvXSjcvNRl9MIMAY42nWRrC7pHqQvn0wI="; }) - (fetchNuGet { pname = "Robust.Natives.Freetype"; version = "0.1.0"; hash = "sha256-gufHmxKub3204pAYvcLegY80LMoKPY5u3Z3uIleReWo="; }) - (fetchNuGet { pname = "Robust.Natives.Glfw"; version = "0.1.0"; hash = "sha256-YDL7w5wVb2Il/O4PRlxPgYUOlM2Ksu+kIrlKc1qYynU="; }) - (fetchNuGet { pname = "Robust.Natives.OpenAL"; version = "0.1.0"; hash = "sha256-3dIpRKPASi8wu8eMWSC/M4CNJK1WKKJVB4XVXKSeihs="; }) - (fetchNuGet { pname = "Robust.Natives.Swnfd"; version = "0.1.0"; hash = "sha256-Qav0yDVQ30eV31Gz+oMXJvHQnP+XrOicakw4rb6hVus="; }) - (fetchNuGet { pname = "Robust.Shared.AuthLib"; version = "0.1.2"; hash = "sha256-ANaf6S0tsocsw37RJvk9d4LcvVQ0+1yO900iG1BLwe4="; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; }) - (fetchNuGet { pname = "Serilog"; version = "2.12.0"; hash = "sha256-JD+ud+CFoLGdYGasTWKTxx5PYj2W5pBv2lMybBK7HVM="; }) - (fetchNuGet { pname = "Serilog.Sinks.Console"; version = "4.1.0"; hash = "sha256-MXIj6YJ4GQbUS8553InMUZPPEfr8h33q2GtAhyu88+Y="; }) - (fetchNuGet { pname = "Serilog.Sinks.File"; version = "5.0.0"; hash = "sha256-GKy9hwOdlu2W0Rw8LiPyEwus+sDtSOTl8a5l9uqz+SQ="; }) - (fetchNuGet { pname = "SharpZstd.Interop"; version = "1.5.2-beta2"; hash = "sha256-Xkmf3Fui97lC5CROT6o1W0vD4EURrMh7RJQ+nS+VhYQ="; }) - (fetchNuGet { pname = "SkiaSharp"; version = "2.88.6"; hash = "sha256-y0wzgwdQXtgl5boCz/EgLWbK3SwC0cFVRUbBxOUPQXc="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Linux"; version = "2.88.6"; hash = "sha256-VjgGoi73tVvqO/UXmQb1w9ioAbFu2dxH8oHz1l5H4zE="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.macOS"; version = "2.88.6"; hash = "sha256-7hOMjlYTOiNPLNwfLFUjTcdgiGEtmYUI1EubiRiC6bo="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.WebAssembly"; version = "2.88.6"; hash = "sha256-CIb9fHVgHwIa0R1WafKJ3+GqtDHHRgDohA3ayTHvlws="; }) - (fetchNuGet { pname = "SkiaSharp.NativeAssets.Win32"; version = "2.88.6"; hash = "sha256-ljD4QmAO2/vwA6I8GIUNkONpOzmGsOVJJy9vPDnjVfA="; }) - (fetchNuGet { pname = "SpaceWizards.Sodium"; version = "0.2.1"; hash = "sha256-1x10ZvfWf1VGQM87c3Hc7ue9ibhslA1P2zE29FylOhU="; }) - (fetchNuGet { pname = "SpaceWizards.Sodium.Interop"; version = "1.0.18-beta4"; hash = "sha256-dvPwT6owmBRYZT3UhOd9xBWtVF4C2+Woa7t18Y+IqfA="; }) - (fetchNuGet { pname = "Splat"; version = "14.6.8"; hash = "sha256-XHTuUKAisBU0O3keA+Ojzb8yKKJUheWbRHakzLBeQNo="; }) - (fetchNuGet { pname = "SQLitePCLRaw.bundle_e_sqlite3"; version = "2.1.4"; hash = "sha256-4IHC1KMcKOKHKLlf+/TIAVCQCdEDhPQw5+FUlujVDWo="; }) - (fetchNuGet { pname = "SQLitePCLRaw.core"; version = "2.1.4"; hash = "sha256-jSI3SIE/HBLEvM+IzhfnAS0QU+JQzIokC/lGLNLvUyU="; }) - (fetchNuGet { pname = "SQLitePCLRaw.lib.e_sqlite3"; version = "2.1.4"; hash = "sha256-dk7eEcw+lgpZuWdZn2794hQ6GHDeIfCRNGSysPUsiIY="; }) - (fetchNuGet { pname = "SQLitePCLRaw.provider.e_sqlite3"; version = "2.1.4"; hash = "sha256-Zdj676VT6j6k9ZCL2hYVl4F8bi4TK/ldvQBPmW0oDi0="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "5.0.0"; hash = "sha256-GdwSIjLMM0uVfE56VUSLVNgpW0B//oCeSFj8/hSlbM8="; }) - (fetchNuGet { pname = "System.ComponentModel.Annotations"; version = "4.5.0"; hash = "sha256-15yE2NoT9vmL9oGCaxHClQR1jLW1j1ef5hHMg55xRso="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; }) - (fetchNuGet { pname = "System.Drawing.Common"; version = "6.0.0"; hash = "sha256-/9EaAbEeOjELRSMZaImS1O8FmUe8j4WuFUw1VOrPyAo="; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.3.0"; hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "6.0.0"; hash = "sha256-xfjF4UqTMJpf8KsBWUyJlJkzPTOO/H5MW023yTYNQSA="; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.3.0"; hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.3"; hash = "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; }) - (fetchNuGet { pname = "System.Net.Http.WinHttpHandler"; version = "8.0.0"; hash = "sha256-wSK5KtWvlDp8WLNddCmAM66uGyj9/KfJyCh8ht1PD1M="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.3.0"; hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; }) - (fetchNuGet { pname = "System.Reactive"; version = "5.0.0"; hash = "sha256-M5Z8pw8rVb8ilbnTdaOptzk5VFd5DlKa7zzCpuytTtE="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.3.0"; hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.3.0"; hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.3.0"; hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.3.0"; hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "5.0.0"; hash = "sha256-Wo+MiqhcP9dQ6NuFGrQTw6hpbJORFwp+TBNTq2yhGp8="; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.3.0"; hash = "sha256-4U4/XNQAnddgQIHIJq3P2T80hN0oPdU2uCeghsDTWng="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.7.1"; hash = "sha256-UvyoDV8O0oY3HPG1GbA56YVdvwTGEfjYR5gW1O7IK4U="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "4.5.1"; hash = "sha256-PIhkv59IXjyiuefdhKxS9hQfEwO9YWRuNudpo53HQfw="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; }) - (fetchNuGet { pname = "TerraFX.Interop.Windows"; version = "10.0.22621.1"; hash = "sha256-0golrteOhpZblYuKjM3YP2rswAv/hzWDQ6I9rT9TcWE="; }) - (fetchNuGet { pname = "Tmds.DBus.Protocol"; version = "0.15.0"; hash = "sha256-4gk2vXDjKFaBh82gTkwg3c/5GRjiH+bvM5elfDSbKTU="; }) - (fetchNuGet { pname = "YamlDotNet"; version = "13.0.2"; hash = "sha256-aCI7NH5iDAOcQJZNdyArt9ksqfrINreCzV7uFg3bNww="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Avalonia"; + version = "11.0.5"; + hash = "sha256-BqpHqQIObTb7DHTyZAgCD9A5I0pZkHhSoPTN2g6/G9E="; + }) + (fetchNuGet { + pname = "Avalonia.Angle.Windows.Natives"; + version = "2.1.0.2023020321"; + hash = "sha256-TWop9cvak6cMv2vrA/GlpuYBxS8Fuj5UmupGIV7Q5Ks="; + }) + (fetchNuGet { + pname = "Avalonia.BuildServices"; + version = "0.0.29"; + hash = "sha256-WPHRMNowRnYSCh88DWNBCltWsLPyOfzXGzBqLYE7tRY="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.ColorPicker"; + version = "11.0.5"; + hash = "sha256-Iob8OyWhwXhmHKCdnea7dtL9VQvcrf6/gUGHJ30CKXA="; + }) + (fetchNuGet { + pname = "Avalonia.Controls.DataGrid"; + version = "11.0.5"; + hash = "sha256-2iVuMPRw7sbsYPGSG4XjQFGFky5WB5B05Jh1+I852ZI="; + }) + (fetchNuGet { + pname = "Avalonia.Desktop"; + version = "11.0.5"; + hash = "sha256-UKVibxhJoGNvEGh8J/Z0sq8J81FT8yth/yXVPSFHF/8="; + }) + (fetchNuGet { + pname = "Avalonia.Diagnostics"; + version = "11.0.5"; + hash = "sha256-0cUxPYJP2W11wnM6j4qNB3IvHlsUp9EZlY8I/NoAmd4="; + }) + (fetchNuGet { + pname = "Avalonia.FreeDesktop"; + version = "11.0.5"; + hash = "sha256-O20fC/9YXO3/MZNlh1EgWLHFSyi/ao083MKwjetgxmo="; + }) + (fetchNuGet { + pname = "Avalonia.Native"; + version = "11.0.5"; + hash = "sha256-KVUAXXT+f4VrtJ8widfEIzN25GBbtXWog/tpM354gdg="; + }) + (fetchNuGet { + pname = "Avalonia.ReactiveUI"; + version = "11.0.5"; + hash = "sha256-8tGLyA0PRKt1REb9YeCtEDz5oB886PRG35aO0uZm/jU="; + }) + (fetchNuGet { + pname = "Avalonia.Remote.Protocol"; + version = "11.0.5"; + hash = "sha256-wTqdxPU3Ql7jC4JFkChbUfaRR0nqUKrYKn8oexdFyig="; + }) + (fetchNuGet { + pname = "Avalonia.Skia"; + version = "11.0.5"; + hash = "sha256-rKOgkNLCwEVVcyLCimvhDUDKXnrDOguUryaGVOPFFwE="; + }) + (fetchNuGet { + pname = "Avalonia.Themes.Simple"; + version = "11.0.5"; + hash = "sha256-27evmgSrIx+EopF6E3N1cT7BvAUc/s99TVEMfmG83cQ="; + }) + (fetchNuGet { + pname = "Avalonia.Win32"; + version = "11.0.5"; + hash = "sha256-ncZLGKhpfjuuVPz4Fs+P6L3dM0KRnwAC3xJRqyvpKw8="; + }) + (fetchNuGet { + pname = "Avalonia.X11"; + version = "11.0.5"; + hash = "sha256-rvs3hwRh3F5E1j3JqcodWJTHV3BTWMKkvzq170tuPa4="; + }) + (fetchNuGet { + pname = "CodeHollow.FeedReader"; + version = "1.2.6"; + hash = "sha256-uw58N3j/ZsBmBaYeXrSwg6f4ObWChM2GduwAzmNDiak="; + }) + (fetchNuGet { + pname = "Dapper"; + version = "2.0.123"; + hash = "sha256-Ic3pMHtq5jF94tPi8l5MFDGyLnEZYofcqxbH5yDLHZY="; + }) + (fetchNuGet { + pname = "DynamicData"; + version = "7.13.1"; + hash = "sha256-wSMqsqAWKqVaIDVlRtycTiS0R3fQxknfEPfBaYVawkM="; + }) + (fetchNuGet { + pname = "Fody"; + version = "6.6.4"; + hash = "sha256-Xe9sGzIdQ970f0RwxD3KhdfqvGUoTpim2u2oqYHkDcI="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp"; + version = "2.8.2.3"; + hash = "sha256-4tbdgUabPjlkBm3aUFeocj4Fdslmms2olDFpzOLyqoQ="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Linux"; + version = "2.8.2.3"; + hash = "sha256-3xwVfNfKTkuLdnT+e3bfG9tNTdEmar7ByzY+NTlUKLg="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.macOS"; + version = "2.8.2.3"; + hash = "sha256-ZohUEaovj/sRB4rjuJIOq6S9eim3m+qMlpHIebNDTRQ="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.WebAssembly"; + version = "2.8.2.3"; + hash = "sha256-ZsiBGpXfODHUHPgU/50k9QR/j6Klo7rsB0SUt8zYcBA="; + }) + (fetchNuGet { + pname = "HarfBuzzSharp.NativeAssets.Win32"; + version = "2.8.2.3"; + hash = "sha256-5GSzM5IUoOwK+zJg0d74WlT3n1VZly8pKlyjiqVocCI="; + }) + (fetchNuGet { + pname = "JetBrains.Annotations"; + version = "2023.2.0-eap3"; + hash = "sha256-s+SCNDcc8ZHFQXwXte0dfI9NOmqFUQK2IjBA0atT04k="; + }) + (fetchNuGet { + pname = "libsodium"; + version = "1.0.18.2"; + hash = "sha256-gjaW2AYXQSb3LLjtQDjWSxkTmEiqIoIb7NFx0+AlrQs="; + }) + (fetchNuGet { + pname = "Linguini.Bundle"; + version = "0.8.1"; + hash = "sha256-SirB65XjhxBkS+OERZP1e+6l2xZl9DFLz2ST5k2x9tw="; + }) + (fetchNuGet { + pname = "Linguini.Shared"; + version = "0.8.0"; + hash = "sha256-BnCgq61zLy6MMG6gNnZiIOjJNy/So1DPUsdR83m5ACM="; + }) + (fetchNuGet { + pname = "Linguini.Syntax"; + version = "0.8.0"; + hash = "sha256-x5PIdYJVCvIJxsDRP0GZ1PUbAPJl6K4i+K/LNpNE1D0="; + }) + (fetchNuGet { + pname = "MicroCom.Runtime"; + version = "0.11.0"; + hash = "sha256-VdwpP5fsclvNqJuppaOvwEwv2ofnAI5ZSz2V+UEdLF0="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.0.0"; + hash = "sha256-KDbCfsBWSJ5ohEXUKp1s1LX9xA2NPvXE/xVzj68EdC0="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "3.8.0"; + hash = "sha256-3G9vSc/gHH7FWgOySLTut1+eEaf3H66qcPOvNPLOx4o="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "3.8.0"; + hash = "sha256-i/r3V/No/VzqmJlWxpGoirvlbJDbBPa/ONZtzYrxuc4="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp.Scripting"; + version = "3.8.0"; + hash = "sha256-fA9Qu+vTyMZ9REzxJ4aMg/SHCDRk4q9k4ZGUdynoHnA="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Scripting.Common"; + version = "3.8.0"; + hash = "sha256-866jMHp8kbc1FYpKuUWnd7ViU6kGJTAxPcL/IjXrT0I="; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.3.0"; + hash = "sha256-a3dAiPaVuky0wpcHmpTVtAQJNGZ2v91/oArA+dpJgj8="; + }) + (fetchNuGet { + pname = "Microsoft.Data.Sqlite.Core"; + version = "7.0.4"; + hash = "sha256-+8pB6kjwp5dNxKZ54zM7xqWSkzQYRiB8AIw2JBeSDlY="; + }) + (fetchNuGet { + pname = "Microsoft.NET.ILLink.Tasks"; + version = "8.0.0"; + hash = "sha256-BAbtucZQvBgbiJ51UAL/Ilx+dz96LpWmfjnnNGlcw48="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "2.1.2"; + hash = "sha256-gYQQO7zsqG+OtN4ywYQyfsiggS2zmxw4+cPXlK+FB5Q="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + hash = "sha256-0AqQ2gMS8iNlYkrD+BxtIg7cXMnr9xZHtKAuN4bjfaQ="; + }) + (fetchNuGet { + pname = "Microsoft.Toolkit.Mvvm"; + version = "7.1.2"; + hash = "sha256-JOxZGQGm1WPkIpIDurQnlYk+QgHxJLPguJfCQLJ8NEM="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.SystemEvents"; + version = "6.0.0"; + hash = "sha256-N9EVZbl5w1VnMywGXyaVWzT9lh84iaJ3aD48hIBk1zA="; + }) + (fetchNuGet { + pname = "Mono.Posix.NETStandard"; + version = "1.0.0"; + hash = "sha256-/F61k7MY/fu2FcfW7CkyjuUroKwlYAXPQFVeDs1QknY="; + }) + (fetchNuGet { + pname = "NSec.Cryptography"; + version = "22.4.0"; + hash = "sha256-TVB8MDXan3dQphaYG/rLQMWgpYJ6WE5ORiqiQrfnCW0="; + }) + (fetchNuGet { + pname = "ReactiveUI"; + version = "18.4.26"; + hash = "sha256-SvWTQfgwwIIwwj67J42fb+Gm8u74iawPd7JqYuYmEnY="; + }) + (fetchNuGet { + pname = "ReactiveUI.Fody"; + version = "18.4.26"; + hash = "sha256-ucLfi/HB3cJIdmNssfazZAXPC8QJ35YVA+GtWKVU6UQ="; + }) + (fetchNuGet { + pname = "Robust.Natives"; + version = "0.1.1"; + hash = "sha256-/DPbgIzIqZx7ClHKSgI88p03xwKSNWY/MqNri2ZX7uo="; + }) + (fetchNuGet { + pname = "Robust.Natives.Angle"; + version = "0.1.1-chromium4758"; + hash = "sha256-UGVYx1AZ0K/vzApEshxNQinx7jg43WAMB1lf0yRtnis="; + }) + (fetchNuGet { + pname = "Robust.Natives.Fluidsynth"; + version = "0.1.0"; + hash = "sha256-XRyvRqEcEFFvXSjcvNRl9MIMAY42nWRrC7pHqQvn0wI="; + }) + (fetchNuGet { + pname = "Robust.Natives.Freetype"; + version = "0.1.0"; + hash = "sha256-gufHmxKub3204pAYvcLegY80LMoKPY5u3Z3uIleReWo="; + }) + (fetchNuGet { + pname = "Robust.Natives.Glfw"; + version = "0.1.0"; + hash = "sha256-YDL7w5wVb2Il/O4PRlxPgYUOlM2Ksu+kIrlKc1qYynU="; + }) + (fetchNuGet { + pname = "Robust.Natives.OpenAL"; + version = "0.1.0"; + hash = "sha256-3dIpRKPASi8wu8eMWSC/M4CNJK1WKKJVB4XVXKSeihs="; + }) + (fetchNuGet { + pname = "Robust.Natives.Swnfd"; + version = "0.1.0"; + hash = "sha256-Qav0yDVQ30eV31Gz+oMXJvHQnP+XrOicakw4rb6hVus="; + }) + (fetchNuGet { + pname = "Robust.Shared.AuthLib"; + version = "0.1.2"; + hash = "sha256-ANaf6S0tsocsw37RJvk9d4LcvVQ0+1yO900iG1BLwe4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + hash = "sha256-4PGZqyWhZ6/HCTF2KddDsbmTTjxs2oW79YfkberDZS8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + hash = "sha256-PaiITTFI2FfPylTEk7DwzfKeiA/g/aooSU1pDcdwWLU="; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + hash = "sha256-vej7ySRhyvM3pYh/ITMdC25ivSd0WLZAaIQbYj/6HVE="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + hash = "sha256-ns6f++lSA+bi1xXgmW1JkWFb2NaMD+w+YNTfMvyAiQk="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-Y2AnhOcJwJVYv7Rp6Jz6ma0fpITFqJW+8rsw106K2X8="; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-LkPXtiDQM3BcdYkAm5uSNOiz3uF4J45qpxn5aBiqNXQ="; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-9EvnmZslLgLLhJ00o5MWaPuJQlbUFcUF8itGQNVkcQ4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + hash = "sha256-qwhNXBaJ1DtDkuRacgHwnZmOZ1u9q7N8j0cWOLYOELM="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-PQRACwnSUuxgVySO1840KvqCC9F8iI9iTzxNW0RcBS4="; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-Kaw5PnLYIiqWbsoF3VKJhy7pkpoGsUwn4ZDCKscbbzA="; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-Q18B9q26MkWZx68exUfQT30+0PGmpFlDgaF0TnaIGCs="; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-agdOM0NXupfHbKAQzQT8XgbI9B8hVEh+a/2vqeHctg4="; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-LXUPLX3DJxsU1Pd3UwjO1PO9NM2elNEDXeu2Mu/vNps="; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-qeSqaUI80+lqw5MK4vMpmO0CZaqrmYktwp6L+vQAb0I="; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-SrHqT9wrCBsxILWtaJgGKd6Odmxm8/Mh7Kh0CUkZVzA="; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + hash = "sha256-ZBZaodnjvLXATWpXXakFgcy6P+gjhshFXmglrL5xD5Y="; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-Jy01KhtcCl2wjMpZWH+X3fhHcVn+SyllWFY8zWlz/6I="; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-wyv00gdlqf8ckxEdV7E+Ql9hJIoPcmYEuyeWb5Oz3mM="; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-zi+b4sCFrA9QBiSGDD7xPV27r3iHGlV99gpyVUjRmc4="; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-gybQU6mPgaWV3rBG2dbH6tT3tBq8mgze3PROdsuWnX0="; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-VsP72GVveWnGUvS/vjOQLv1U80H2K8nZ4fDAmI61Hm4="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-4yKGa/IrNCKuQ3zaDzILdNPD32bNdy6xr5gdJigyF5g="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-HmdJhhRsiVoOOCcUvAwdjpMRiyuSwdcgEv2j9hxi+Zc="; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + hash = "sha256-pVFUKuPPIx0edQKjzRon3zKq8zhzHEzko/lc01V/jdw="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-ReoazscfbGH+R6s6jkg5sIEHWNEvjEoHtIsMbpc7+tI="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-c5tXWhE/fYbJVl9rXs0uHh3pTsg44YD1dJvyOA0WoMs="; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-l8S9gt6dk3qYG6HYonHtdlYtBKyPb29uQ6NDjmrt3V4="; + }) + (fetchNuGet { + pname = "Serilog"; + version = "2.12.0"; + hash = "sha256-JD+ud+CFoLGdYGasTWKTxx5PYj2W5pBv2lMybBK7HVM="; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Console"; + version = "4.1.0"; + hash = "sha256-MXIj6YJ4GQbUS8553InMUZPPEfr8h33q2GtAhyu88+Y="; + }) + (fetchNuGet { + pname = "Serilog.Sinks.File"; + version = "5.0.0"; + hash = "sha256-GKy9hwOdlu2W0Rw8LiPyEwus+sDtSOTl8a5l9uqz+SQ="; + }) + (fetchNuGet { + pname = "SharpZstd.Interop"; + version = "1.5.2-beta2"; + hash = "sha256-Xkmf3Fui97lC5CROT6o1W0vD4EURrMh7RJQ+nS+VhYQ="; + }) + (fetchNuGet { + pname = "SkiaSharp"; + version = "2.88.6"; + hash = "sha256-y0wzgwdQXtgl5boCz/EgLWbK3SwC0cFVRUbBxOUPQXc="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Linux"; + version = "2.88.6"; + hash = "sha256-VjgGoi73tVvqO/UXmQb1w9ioAbFu2dxH8oHz1l5H4zE="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.macOS"; + version = "2.88.6"; + hash = "sha256-7hOMjlYTOiNPLNwfLFUjTcdgiGEtmYUI1EubiRiC6bo="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.WebAssembly"; + version = "2.88.6"; + hash = "sha256-CIb9fHVgHwIa0R1WafKJ3+GqtDHHRgDohA3ayTHvlws="; + }) + (fetchNuGet { + pname = "SkiaSharp.NativeAssets.Win32"; + version = "2.88.6"; + hash = "sha256-ljD4QmAO2/vwA6I8GIUNkONpOzmGsOVJJy9vPDnjVfA="; + }) + (fetchNuGet { + pname = "SpaceWizards.Sodium"; + version = "0.2.1"; + hash = "sha256-1x10ZvfWf1VGQM87c3Hc7ue9ibhslA1P2zE29FylOhU="; + }) + (fetchNuGet { + pname = "SpaceWizards.Sodium.Interop"; + version = "1.0.18-beta4"; + hash = "sha256-dvPwT6owmBRYZT3UhOd9xBWtVF4C2+Woa7t18Y+IqfA="; + }) + (fetchNuGet { + pname = "Splat"; + version = "14.6.8"; + hash = "sha256-XHTuUKAisBU0O3keA+Ojzb8yKKJUheWbRHakzLBeQNo="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.bundle_e_sqlite3"; + version = "2.1.4"; + hash = "sha256-4IHC1KMcKOKHKLlf+/TIAVCQCdEDhPQw5+FUlujVDWo="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.core"; + version = "2.1.4"; + hash = "sha256-jSI3SIE/HBLEvM+IzhfnAS0QU+JQzIokC/lGLNLvUyU="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.lib.e_sqlite3"; + version = "2.1.4"; + hash = "sha256-dk7eEcw+lgpZuWdZn2794hQ6GHDeIfCRNGSysPUsiIY="; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.provider.e_sqlite3"; + version = "2.1.4"; + hash = "sha256-Zdj676VT6j6k9ZCL2hYVl4F8bi4TK/ldvQBPmW0oDi0="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "5.0.0"; + hash = "sha256-GdwSIjLMM0uVfE56VUSLVNgpW0B//oCeSFj8/hSlbM8="; + }) + (fetchNuGet { + pname = "System.ComponentModel.Annotations"; + version = "4.5.0"; + hash = "sha256-15yE2NoT9vmL9oGCaxHClQR1jLW1j1ef5hHMg55xRso="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; + }) + (fetchNuGet { + pname = "System.Drawing.Common"; + version = "6.0.0"; + hash = "sha256-/9EaAbEeOjELRSMZaImS1O8FmUe8j4WuFUw1VOrPyAo="; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.3.0"; + hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + hash = "sha256-ruynQHekFP5wPrDiVyhNiRIXeZ/I9NpjK5pU+HPDiRY="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "6.0.0"; + hash = "sha256-xfjF4UqTMJpf8KsBWUyJlJkzPTOO/H5MW023yTYNQSA="; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.3.0"; + hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.3"; + hash = "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; + }) + (fetchNuGet { + pname = "System.Net.Http.WinHttpHandler"; + version = "8.0.0"; + hash = "sha256-wSK5KtWvlDp8WLNddCmAM66uGyj9/KfJyCh8ht1PD1M="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.3.0"; + hash = "sha256-gtmRkWP2Kwr3nHtDh0yYtce38z1wrGzb6fjm4v8wN6Q="; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + hash = "sha256-fVfgcoP4AVN1E5wHZbKBIOPYZ/xBeSIdsNF+bdukIRM="; + }) + (fetchNuGet { + pname = "System.Reactive"; + version = "5.0.0"; + hash = "sha256-M5Z8pw8rVb8ilbnTdaOptzk5VFd5DlKa7zzCpuytTtE="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.3.0"; + hash = "sha256-5LhkDmhy2FkSxulXR+bsTtMzdU3VyyuZzsxp7/DwyIU="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.3.0"; + hash = "sha256-mKRknEHNls4gkRwrEgi39B+vSaAz/Gt3IALtS98xNnA="; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.3.0"; + hash = "sha256-rKx4a9yZKcajloSZHr4CKTVJ6Vjh95ni+zszPxWjh2I="; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.3.0"; + hash = "sha256-mMOCYzUenjd4rWIfq7zIX9PFYk/daUyF0A8l1hbydAk="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "5.0.0"; + hash = "sha256-Wo+MiqhcP9dQ6NuFGrQTw6hpbJORFwp+TBNTq2yhGp8="; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + hash = "sha256-5ogwWB4vlQTl3jjk1xjniG2ozbFIjZTL9ug0usZQuBM="; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.3.0"; + hash = "sha256-4U4/XNQAnddgQIHIJq3P2T80hN0oPdU2uCeghsDTWng="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.7.1"; + hash = "sha256-UvyoDV8O0oY3HPG1GbA56YVdvwTGEfjYR5gW1O7IK4U="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + hash = "sha256-KJ5aXoGpB56Y6+iepBkdpx/AfaJDAitx4vrkLqR7gms="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "4.5.1"; + hash = "sha256-PIhkv59IXjyiuefdhKxS9hQfEwO9YWRuNudpo53HQfw="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; + }) + (fetchNuGet { + pname = "TerraFX.Interop.Windows"; + version = "10.0.22621.1"; + hash = "sha256-0golrteOhpZblYuKjM3YP2rswAv/hzWDQ6I9rT9TcWE="; + }) + (fetchNuGet { + pname = "Tmds.DBus.Protocol"; + version = "0.15.0"; + hash = "sha256-4gk2vXDjKFaBh82gTkwg3c/5GRjiH+bvM5elfDSbKTU="; + }) + (fetchNuGet { + pname = "YamlDotNet"; + version = "13.0.2"; + hash = "sha256-aCI7NH5iDAOcQJZNdyArt9ksqfrINreCzV7uFg3bNww="; + }) ] diff --git a/pkgs/games/speed-dreams/default.nix b/pkgs/games/speed-dreams/default.nix index f81c2f7f2f341e..520439b2321b0a 100644 --- a/pkgs/games/speed-dreams/default.nix +++ b/pkgs/games/speed-dreams/default.nix @@ -1,6 +1,40 @@ -{ fetchurl, lib, stdenv, libGLU, libGL, libglut, libX11, plib, openal, freealut, libXrandr, xorgproto, -libXext, libSM, libICE, libXi, libXt, libXrender, libXxf86vm, openscenegraph, expat, -libpng, zlib, bash, SDL2, SDL2_mixer, enet, libjpeg, cmake, pkg-config, libvorbis, runtimeShell, curl, copyDesktopItems, makeDesktopItem }: +{ + fetchurl, + lib, + stdenv, + libGLU, + libGL, + libglut, + libX11, + plib, + openal, + freealut, + libXrandr, + xorgproto, + libXext, + libSM, + libICE, + libXi, + libXt, + libXrender, + libXxf86vm, + openscenegraph, + expat, + libpng, + zlib, + bash, + SDL2, + SDL2_mixer, + enet, + libjpeg, + cmake, + pkg-config, + libvorbis, + runtimeShell, + curl, + copyDesktopItems, + makeDesktopItem, +}: let version = "2.3.0-r8786"; @@ -66,25 +100,58 @@ stdenv.mkDerivation rec { icon = "speed-dreams-2.png"; desktopName = "speed-dreams-2"; comment = "The Open Racing Car Simulator Fork"; - categories = [ "Application" "Game" ]; + categories = [ + "Application" + "Game" + ]; }) ]; # RPATH of binary /nix/store/.../lib64/games/speed-dreams-2/drivers/shadow_sc/shadow_sc.so contains a forbidden reference to /build/ cmakeFlags = [ "-DCMAKE_SKIP_BUILD_RPATH=ON" ]; - nativeBuildInputs = [ pkg-config cmake copyDesktopItems ]; + nativeBuildInputs = [ + pkg-config + cmake + copyDesktopItems + ]; - buildInputs = [ libpng libGLU libGL libglut libX11 plib openal freealut libXrandr xorgproto - libXext libSM libICE libXi libXt libXrender libXxf86vm zlib bash expat - SDL2 SDL2_mixer enet libjpeg openscenegraph libvorbis curl ]; + buildInputs = [ + libpng + libGLU + libGL + libglut + libX11 + plib + openal + freealut + libXrandr + xorgproto + libXext + libSM + libICE + libXi + libXt + libXrender + libXxf86vm + zlib + bash + expat + SDL2 + SDL2_mixer + enet + libjpeg + openscenegraph + libvorbis + curl + ]; meta = { description = "Car racing game - TORCS fork with more experimental approach"; homepage = "https://speed-dreams.sourceforge.net/"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [raskin]; + maintainers = with lib.maintainers; [ raskin ]; platforms = lib.platforms.linux; - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/games/spring/default.nix b/pkgs/games/spring/default.nix index 1185894dae66ce..410de8382c9383 100644 --- a/pkgs/games/spring/default.nix +++ b/pkgs/games/spring/default.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, asciidoc -, boost -, cmake -, curl -, docbook_xsl -, docbook_xsl_ns -, fetchurl -, freetype -, glew -, jdk -, libdevil -, libGL -, libGLU -, libunwind -, libvorbis -, makeWrapper -, minizip -, openal -, p7zip -, python3 -, SDL2 -, xorg -, xz -, zlib -, withAI ? true # support for AI Interfaces and Skirmish AIs +{ + lib, + stdenv, + asciidoc, + boost, + cmake, + curl, + docbook_xsl, + docbook_xsl_ns, + fetchurl, + freetype, + glew, + jdk, + libdevil, + libGL, + libGLU, + libunwind, + libvorbis, + makeWrapper, + minizip, + openal, + p7zip, + python3, + SDL2, + xorg, + xz, + zlib, + withAI ? true, # support for AI Interfaces and Skirmish AIs }: stdenv.mkDerivation rec { @@ -54,27 +55,37 @@ stdenv.mkDerivation rec { "-DPREFER_STATIC_LIBS:BOOL=OFF" ]; - nativeBuildInputs = [ cmake makeWrapper docbook_xsl docbook_xsl_ns asciidoc ]; - buildInputs = [ - boost - curl - freetype - glew - libdevil - libGL - libGLU - libunwind - libvorbis - minizip - openal - p7zip - SDL2 - xorg.libX11 - xorg.libXcursor - xz - zlib - ] - ++ lib.optionals withAI [ python3 jdk ]; + nativeBuildInputs = [ + cmake + makeWrapper + docbook_xsl + docbook_xsl_ns + asciidoc + ]; + buildInputs = + [ + boost + curl + freetype + glew + libdevil + libGL + libGLU + libunwind + libvorbis + minizip + openal + p7zip + SDL2 + xorg.libX11 + xorg.libXcursor + xz + zlib + ] + ++ lib.optionals withAI [ + python3 + jdk + ]; postInstall = '' wrapProgram "$out/bin/spring" \ @@ -85,7 +96,11 @@ stdenv.mkDerivation rec { homepage = "https://springrts.com/"; description = "Powerful real-time strategy (RTS) game engine"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ qknight domenkozar sorki ]; + maintainers = with maintainers; [ + qknight + domenkozar + sorki + ]; platforms = [ "x86_64-linux" ]; broken = true; }; diff --git a/pkgs/games/spring/springlobby.nix b/pkgs/games/spring/springlobby.nix index ab792cf41a49e9..dc3ae4ef6d7a71 100644 --- a/pkgs/games/spring/springlobby.nix +++ b/pkgs/games/spring/springlobby.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchurl -, cmake -, wxGTK32 -, openal -, pkg-config -, curl -, libtorrent-rasterbar -, libpng -, libX11 -, gettext -, boost -, libnotify -, gtk3 -, doxygen -, spring -, makeWrapper -, glib -, minizip -, alure -, pcre -, jsoncpp +{ + lib, + stdenv, + fetchurl, + cmake, + wxGTK32, + openal, + pkg-config, + curl, + libtorrent-rasterbar, + libpng, + libX11, + gettext, + boost, + libnotify, + gtk3, + doxygen, + spring, + makeWrapper, + glib, + minizip, + alure, + pcre, + jsoncpp, }: stdenv.mkDerivation rec { @@ -32,7 +33,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-XkU6i6ABCgw3H9vJu0xjHRO1BglueYM1LyJxcZdOrDk="; }; - nativeBuildInputs = [ cmake pkg-config gettext doxygen makeWrapper ]; + nativeBuildInputs = [ + cmake + pkg-config + gettext + doxygen + makeWrapper + ]; buildInputs = [ wxGTK32 openal @@ -65,7 +72,13 @@ stdenv.mkDerivation rec { homepage = "https://springlobby.springrts.com"; description = "Cross-platform lobby client for the Spring RTS project"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ qknight domenkozar ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + maintainers = with maintainers; [ + qknight + domenkozar + ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/games/starsector/default.nix b/pkgs/games/starsector/default.nix index 8e38f232f21e9f..7733bb7077fdc2 100644 --- a/pkgs/games/starsector/default.nix +++ b/pkgs/games/starsector/default.nix @@ -1,14 +1,15 @@ -{ lib -, fetchzip -, libGL -, makeWrapper -, openal -, openjdk -, stdenv -, xorg -, copyDesktopItems -, makeDesktopItem -, writeScript +{ + lib, + fetchzip, + libGL, + makeWrapper, + openal, + openjdk, + stdenv, + xorg, + copyDesktopItems, + makeDesktopItem, + writeScript, }: stdenv.mkDerivation rec { @@ -20,8 +21,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-KT4n0kBocaljD6dTbpr6xcwy6rBBZTFjov9m+jizDW4="; }; - nativeBuildInputs = [ copyDesktopItems makeWrapper ]; - buildInputs = [ xorg.libXxf86vm openal libGL ]; + nativeBuildInputs = [ + copyDesktopItems + makeWrapper + ]; + buildInputs = [ + xorg.libXxf86vm + openal + libGL + ]; dontBuild = true; @@ -51,7 +59,12 @@ stdenv.mkDerivation rec { $out/share/icons/hicolor/64x64/apps/starsector.png wrapProgram $out/share/starsector/starsector.sh \ - --prefix PATH : ${lib.makeBinPath [ openjdk xorg.xrandr ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + openjdk + xorg.xrandr + ] + } \ --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath buildInputs} \ --run 'mkdir -p ''${XDG_DATA_HOME:-~/.local/share}/starsector' \ --chdir "$out/share/starsector" @@ -88,6 +101,9 @@ stdenv.mkDerivation rec { homepage = "https://fractalsoftworks.com"; sourceProvenance = with sourceTypes; [ binaryBytecode ]; license = licenses.unfree; - maintainers = with maintainers; [ bbigras rafaelrc ]; + maintainers = with maintainers; [ + bbigras + rafaelrc + ]; }; } diff --git a/pkgs/games/stuntrally/default.nix b/pkgs/games/stuntrally/default.nix index 813701c6ccd148..c847ad4ceda48c 100644 --- a/pkgs/games/stuntrally/default.nix +++ b/pkgs/games/stuntrally/default.nix @@ -1,21 +1,22 @@ -{ lib -, fetchFromGitHub -, stdenv -, cmake -, boost -, ogre_13 -, mygui -, ois -, SDL2 -, libvorbis -, pkg-config -, makeWrapper -, enet -, libXcursor -, bullet -, openal -, tinyxml -, tinyxml-2 +{ + lib, + fetchFromGitHub, + stdenv, + cmake, + boost, + ogre_13, + mygui, + ois, + SDL2, + libvorbis, + pkg-config, + makeWrapper, + enet, + libXcursor, + bullet, + openal, + tinyxml, + tinyxml-2, }: let @@ -60,7 +61,11 @@ stdenv.mkDerivation rec { ln -s ${tracks}/ data/tracks ''; - nativeBuildInputs = [ cmake pkg-config makeWrapper ]; + nativeBuildInputs = [ + cmake + pkg-config + makeWrapper + ]; buildInputs = [ boost stuntrally_ogre diff --git a/pkgs/games/super-tux-kart/default.nix b/pkgs/games/super-tux-kart/default.nix index 69bdb24cea7c50..5e87d415a31891 100644 --- a/pkgs/games/super-tux-kart/default.nix +++ b/pkgs/games/super-tux-kart/default.nix @@ -1,31 +1,32 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchsvn -, cmake -, pkg-config -, makeWrapper -, SDL2 -, glew -, openal -, OpenAL -, libvorbis -, libogg -, curl -, freetype -, libjpeg -, libpng -, harfbuzz -, mcpp -, wiiuse -, angelscript -, libopenglrecorder -, sqlite -, Cocoa -, IOKit -, IOBluetooth -, libsamplerate -, shaderc +{ + lib, + stdenv, + fetchFromGitHub, + fetchsvn, + cmake, + pkg-config, + makeWrapper, + SDL2, + glew, + openal, + OpenAL, + libvorbis, + libogg, + curl, + freetype, + libjpeg, + libpng, + harfbuzz, + mcpp, + wiiuse, + angelscript, + libopenglrecorder, + sqlite, + Cocoa, + IOKit, + IOBluetooth, + libsamplerate, + shaderc, }: let assets = fetchsvn { @@ -94,28 +95,37 @@ stdenv.mkDerivation rec { makeWrapper ]; - buildInputs = [ - shaderc - SDL2 - glew - libvorbis - libogg - freetype - curl - libjpeg - libpng - harfbuzz - mcpp - wiiuse - angelscript - sqlite - ] - ++ lib.optional (stdenv.hostPlatform.isWindows || stdenv.hostPlatform.isLinux) libopenglrecorder - ++ lib.optional stdenv.hostPlatform.isLinux openal - ++ lib.optionals stdenv.hostPlatform.isDarwin [ OpenAL IOKit Cocoa IOBluetooth libsamplerate ]; + buildInputs = + [ + shaderc + SDL2 + glew + libvorbis + libogg + freetype + curl + libjpeg + libpng + harfbuzz + mcpp + wiiuse + angelscript + sqlite + ] + ++ lib.optional (stdenv.hostPlatform.isWindows || stdenv.hostPlatform.isLinux) libopenglrecorder + ++ lib.optional stdenv.hostPlatform.isLinux openal + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + OpenAL + IOKit + Cocoa + IOBluetooth + libsamplerate + ]; cmakeFlags = [ - "-DBUILD_RECORDER=${if (stdenv.hostPlatform.isWindows || stdenv.hostPlatform.isLinux) then "ON" else "OFF"}" + "-DBUILD_RECORDER=${ + if (stdenv.hostPlatform.isWindows || stdenv.hostPlatform.isLinux) then "ON" else "OFF" + }" "-DUSE_SYSTEM_ANGELSCRIPT=ON" "-DCHECK_ASSETS=OFF" "-DUSE_SYSTEM_WIIUSE=ON" @@ -153,7 +163,10 @@ stdenv.mkDerivation rec { ''; homepage = "https://supertuxkart.net/"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ pyrolagus peterhoeg ]; + maintainers = with maintainers; [ + pyrolagus + peterhoeg + ]; platforms = with platforms; unix; changelog = "https://github.com/supertuxkart/stk-code/blob/${version}/CHANGELOG.md"; }; diff --git a/pkgs/games/teeworlds/default.nix b/pkgs/games/teeworlds/default.nix index b07dbc311a2cc6..047562bc028ab2 100644 --- a/pkgs/games/teeworlds/default.nix +++ b/pkgs/games/teeworlds/default.nix @@ -1,8 +1,23 @@ -{ fetchFromGitHub, fetchpatch, lib, stdenv, cmake, pkg-config, python3, alsa-lib -, libX11, libGLU, SDL2, lua5_3, zlib, freetype, wavpack, icoutils -, nixosTests -, Cocoa -, buildClient ? true +{ + fetchFromGitHub, + fetchpatch, + lib, + stdenv, + cmake, + pkg-config, + python3, + alsa-lib, + libX11, + libGLU, + SDL2, + lua5_3, + zlib, + freetype, + wavpack, + icoutils, + nixosTests, + Cocoa, + buildClient ? true, }: stdenv.mkDerivation rec { @@ -48,48 +63,61 @@ stdenv.mkDerivation rec { # don't seem to be packaged in Nixpkgs, so don't unbundle them. ''; - nativeBuildInputs = [ - cmake - pkg-config - ] ++ lib.optionals (buildClient && stdenv.hostPlatform.isLinux) [ - icoutils - ]; + nativeBuildInputs = + [ + cmake + pkg-config + ] + ++ lib.optionals (buildClient && stdenv.hostPlatform.isLinux) [ + icoutils + ]; - buildInputs = [ - python3 lua5_3 zlib - wavpack - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Cocoa - ] ++ lib.optionals buildClient ([ - SDL2 - freetype - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libGLU - alsa-lib - libX11 - ]); + buildInputs = + [ + python3 + lua5_3 + zlib + wavpack + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + ] + ++ lib.optionals buildClient ( + [ + SDL2 + freetype + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libGLU + alsa-lib + libX11 + ] + ); cmakeFlags = [ "-DCLIENT=${if buildClient then "ON" else "OFF"}" ]; - postInstall = lib.optionalString buildClient (lib.optionalString stdenv.hostPlatform.isLinux '' - # Convert and install desktop icon - mkdir -p $out/share/pixmaps - icotool --extract --index 1 --output $out/share/pixmaps/teeworlds.png $src/other/icons/teeworlds.ico - - # Install menu item - install -D $src/other/teeworlds.desktop $out/share/applications/teeworlds.desktop - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - mkdir -p "$out/Applications/teeworlds.app/Contents/MacOS" - mkdir -p "$out/Applications/teeworlds.app/Contents/Resources" - - cp '../other/icons/teeworlds.icns' "$out/Applications/teeworlds.app/Contents/Resources/" - cp '../other/bundle/client/Info.plist.in' "$out/Applications/teeworlds.app/Contents/Info.plist" - cp '../other/bundle/client/PkgInfo' "$out/Applications/teeworlds.app/Contents/" - ln -s "$out/bin/teeworlds" "$out/Applications/teeworlds.app/Contents/MacOS/" - ln -s "$out/share/teeworlds/data" "$out/Applications/teeworlds.app/Contents/Resources/data" - ''); + postInstall = lib.optionalString buildClient ( + lib.optionalString stdenv.hostPlatform.isLinux '' + # Convert and install desktop icon + mkdir -p $out/share/pixmaps + icotool --extract --index 1 --output $out/share/pixmaps/teeworlds.png $src/other/icons/teeworlds.ico + + # Install menu item + install -D $src/other/teeworlds.desktop $out/share/applications/teeworlds.desktop + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + mkdir -p "$out/Applications/teeworlds.app/Contents/MacOS" + mkdir -p "$out/Applications/teeworlds.app/Contents/Resources" + + cp '../other/icons/teeworlds.icns' "$out/Applications/teeworlds.app/Contents/Resources/" + cp '../other/bundle/client/Info.plist.in' "$out/Applications/teeworlds.app/Contents/Info.plist" + cp '../other/bundle/client/PkgInfo' "$out/Applications/teeworlds.app/Contents/" + ln -s "$out/bin/teeworlds" "$out/Applications/teeworlds.app/Contents/MacOS/" + ln -s "$out/share/teeworlds/data" "$out/Applications/teeworlds.app/Contents/Resources/data" + '' + ); passthru.tests.teeworlds = nixosTests.teeworlds; @@ -109,7 +137,7 @@ stdenv.mkDerivation rec { # See https://github.com/teeworlds/teeworlds/blob/master/license.txt lib.licenses.zlib # Main license cc-by-sa-30 # All content under 'datasrc' except the fonts - ofl # datasrc/fonts/SourceHanSans.ttc + ofl # datasrc/fonts/SourceHanSans.ttc free # datasrc/fonts/DejaVuSans.ttf bsd2 # src/engine/external/json-parser/ bsd3 # src/engine/external/wavpack @@ -117,7 +145,10 @@ stdenv.mkDerivation rec { # zlib src/engine/external/pnglite/ # zlib src/engine/external/zlib/ ]; - maintainers = with lib.maintainers; [ astsmtl Luflosi ]; + maintainers = with lib.maintainers; [ + astsmtl + Luflosi + ]; platforms = lib.platforms.unix; }; } diff --git a/pkgs/games/the-butterfly-effect/default.nix b/pkgs/games/the-butterfly-effect/default.nix index fcfa6f1d14ae57..68ec57b17651ba 100644 --- a/pkgs/games/the-butterfly-effect/default.nix +++ b/pkgs/games/the-butterfly-effect/default.nix @@ -1,4 +1,13 @@ -{ lib, mkDerivation, fetchFromGitHub, cmake, qttools, wrapQtAppsHook, qtbase, qtsvg }: +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + qttools, + wrapQtAppsHook, + qtbase, + qtsvg, +}: mkDerivation rec { pname = "tbe"; @@ -18,8 +27,15 @@ mkDerivation rec { substituteInPlace i18n/CMakeLists.txt --replace qt5_create_translation qt_add_translation ''; - nativeBuildInputs = [ cmake qttools wrapQtAppsHook ]; - buildInputs = [ qtbase qtsvg ]; + nativeBuildInputs = [ + cmake + qttools + wrapQtAppsHook + ]; + buildInputs = [ + qtbase + qtsvg + ]; strictDeps = true; installPhase = '' diff --git a/pkgs/games/tibia/default.nix b/pkgs/games/tibia/default.nix index 5b932afbc49d09..4855f93390035f 100644 --- a/pkgs/games/tibia/default.nix +++ b/pkgs/games/tibia/default.nix @@ -1,11 +1,20 @@ -{ lib, stdenv, fetchurl, glibc, libX11, runtimeShell, libGLU, libGL }: +{ + lib, + stdenv, + fetchurl, + glibc, + libX11, + runtimeShell, + libGLU, + libGL, +}: stdenv.mkDerivation rec { pname = "tibia"; version = "10.90"; src = fetchurl { - url = "http://static.tibia.com/download/tibia${lib.replaceStrings ["."] [""] version}.tgz"; + url = "http://static.tibia.com/download/tibia${lib.replaceStrings [ "." ] [ "" ] version}.tgz"; sha256 = "11mkh2dynmbpay51yfaxm5dmcys3rnpk579s9ypfkhblsrchbkhx"; }; @@ -24,7 +33,14 @@ stdenv.mkDerivation rec { cp -r * $out/res patchelf --set-interpreter ${glibc.out}/lib/ld-linux.so.2 \ - --set-rpath ${lib.makeLibraryPath [ stdenv.cc.cc libX11 libGLU libGL ]} \ + --set-rpath ${ + lib.makeLibraryPath [ + stdenv.cc.cc + libX11 + libGLU + libGL + ] + } \ "$out/res/Tibia" # We've patchelf'd the files. The main ‘Tibia’ binary is a bit @@ -51,7 +67,7 @@ stdenv.mkDerivation rec { description = "Top-down MMORPG set in a fantasy world"; homepage = "http://tibia.com"; license = lib.licenses.unfree; - platforms = ["i686-linux"]; + platforms = [ "i686-linux" ]; maintainers = [ ]; }; } diff --git a/pkgs/games/toppler/default.nix b/pkgs/games/toppler/default.nix index 48fb4667d93fa1..0c9290dcc4d940 100644 --- a/pkgs/games/toppler/default.nix +++ b/pkgs/games/toppler/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitLab - -, pkg-config -, gettext -, povray -, imagemagick -, gimp - -, SDL2 -, SDL2_mixer -, SDL2_image -, libpng -, zlib +{ + lib, + stdenv, + fetchFromGitLab, + + pkg-config, + gettext, + povray, + imagemagick, + gimp, + + SDL2, + SDL2_mixer, + SDL2_image, + libpng, + zlib, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/games/ue4demos/default.nix b/pkgs/games/ue4demos/default.nix index ce3f3ad38f8dbd..b4a4568967aa2f 100644 --- a/pkgs/games/ue4demos/default.nix +++ b/pkgs/games/ue4demos/default.nix @@ -1,25 +1,40 @@ -{ lib, stdenv, fetchurl, unzip, patchelf, xorg, openal }: +{ + lib, + stdenv, + fetchurl, + unzip, + patchelf, + xorg, + openal, +}: let - urls = file: - [ - # Untrusted mirrors - do not update hashes - "https://ludios.org/mirror/ue4demos/${file}" - "https://web.archive.org/web/20140824192039/http://ue4linux.raxxy.com/${file}" - ]; - - buildDemo = { name, src }: + urls = file: [ + # Untrusted mirrors - do not update hashes + "https://ludios.org/mirror/ue4demos/${file}" + "https://web.archive.org/web/20140824192039/http://ue4linux.raxxy.com/${file}" + ]; + + buildDemo = + { name, src }: stdenv.mkDerivation rec { inherit name src; - nativeBuildInputs = [ unzip patchelf ]; - - rtdeps = lib.makeLibraryPath - [ xorg.libXxf86vm xorg.libXext openal ] - + ":" + lib.makeSearchPathOutput "lib" "lib64" [ stdenv.cc.cc ]; - - buildCommand = - '' + nativeBuildInputs = [ + unzip + patchelf + ]; + + rtdeps = + lib.makeLibraryPath [ + xorg.libXxf86vm + xorg.libXext + openal + ] + + ":" + + lib.makeSearchPathOutput "lib" "lib64" [ stdenv.cc.cc ]; + + buildCommand = '' mkdir -p "$out" cd $out unzip $src @@ -56,7 +71,8 @@ let }; }; -in { +in +{ tappy_chicken = buildDemo { name = "ue4demos-tappy_chicken"; src = fetchurl { diff --git a/pkgs/games/vcmi/default.nix b/pkgs/games/vcmi/default.nix index a6bc05d8bbff51..cf5524b180edd6 100644 --- a/pkgs/games/vcmi/default.nix +++ b/pkgs/games/vcmi/default.nix @@ -1,29 +1,30 @@ -{ lib -, stdenv -, fetchFromGitHub -, SDL2 -, SDL2_image -, SDL2_mixer -, SDL2_ttf -, boost -, cmake -, ffmpeg -, fuzzylite -, innoextract -, luajit -, minizip -, ninja -, pkg-config -, python3 -, qtbase -, qttools -, tbb -, unshield -, wrapQtAppsHook -, xz -, zlib -, testers -, vcmi +{ + lib, + stdenv, + fetchFromGitHub, + SDL2, + SDL2_image, + SDL2_mixer, + SDL2_ttf, + boost, + cmake, + ffmpeg, + fuzzylite, + innoextract, + luajit, + minizip, + ninja, + pkg-config, + python3, + qtbase, + qttools, + tbb, + unshield, + wrapQtAppsHook, + xz, + zlib, + testers, + vcmi, }: stdenv.mkDerivation rec { @@ -79,7 +80,13 @@ stdenv.mkDerivation rec { postFixup = '' wrapProgram $out/bin/vcmibuilder \ - --prefix PATH : "${lib.makeBinPath [ innoextract ffmpeg unshield ]}" + --prefix PATH : "${ + lib.makeBinPath [ + innoextract + ffmpeg + unshield + ] + }" ''; passthru.tests.version = testers.testVersion { @@ -94,7 +101,10 @@ stdenv.mkDerivation rec { description = "Open-source engine for Heroes of Might and Magic III"; homepage = "https://vcmi.eu"; changelog = "https://github.com/vcmi/vcmi/blob/${src.rev}/ChangeLog.md"; - license = with licenses; [ gpl2Plus cc-by-sa-40 ]; + license = with licenses; [ + gpl2Plus + cc-by-sa-40 + ]; maintainers = with maintainers; [ azahi ]; platforms = platforms.linux; mainProgram = "vcmilauncher"; diff --git a/pkgs/games/vessel/default.nix b/pkgs/games/vessel/default.nix index ddbbf68bbc0897..0aad0143aa6014 100644 --- a/pkgs/games/vessel/default.nix +++ b/pkgs/games/vessel/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, requireFile, SDL, libpulseaudio, alsa-lib, runtimeShell }: +{ + lib, + stdenv, + requireFile, + SDL, + libpulseaudio, + alsa-lib, + runtimeShell, +}: stdenv.mkDerivation rec { pname = "vessel"; @@ -11,18 +19,30 @@ stdenv.mkDerivation rec { directory where you saved it. ''; - src = if (stdenv.hostPlatform.isi686) then - requireFile { - message = goBuyItNow; - name = "vessel-${version}-bin"; - sha256 = "1vpwcrjiln2mx43h7ib3jnccyr3chk7a5x2bw9kb4lw8ycygvg96"; - } else throw "unsupported platform ${stdenv.hostPlatform.system} only i686-linux supported for now."; + src = + if (stdenv.hostPlatform.isi686) then + requireFile { + message = goBuyItNow; + name = "vessel-${version}-bin"; + sha256 = "1vpwcrjiln2mx43h7ib3jnccyr3chk7a5x2bw9kb4lw8ycygvg96"; + } + else + throw "unsupported platform ${stdenv.hostPlatform.system} only i686-linux supported for now."; phases = "installPhase"; ld_preload = ./isatty.c; - libPath = lib.makeLibraryPath [ stdenv.cc.cc stdenv.cc.libc ] - + ":" + lib.makeLibraryPath [ SDL libpulseaudio alsa-lib ] ; + libPath = + lib.makeLibraryPath [ + stdenv.cc.cc + stdenv.cc.libc + ] + + ":" + + lib.makeLibraryPath [ + SDL + libpulseaudio + alsa-lib + ]; installPhase = '' mkdir -p $out/libexec/strangeloop/vessel/ diff --git a/pkgs/games/vimgolf/default.nix b/pkgs/games/vimgolf/default.nix index 917dd3ffdfa940..f2e6c5075f14f3 100644 --- a/pkgs/games/vimgolf/default.nix +++ b/pkgs/games/vimgolf/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "vimgolf"; diff --git a/pkgs/games/vimgolf/gemset.nix b/pkgs/games/vimgolf/gemset.nix index 17d66b934b2282..f2c7c7c0d73529 100644 --- a/pkgs/games/vimgolf/gemset.nix +++ b/pkgs/games/vimgolf/gemset.nix @@ -1,40 +1,44 @@ { highline = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yclf57n2j3cw8144ania99h1zinf8q3f5zrhqa754j6gl95rp9d"; type = "gem"; }; version = "2.0.3"; }; json_pure = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05ddn30jkpw6anfakfm7lffnrl2i0265ryrrwa4j0ivihjr95y82"; type = "gem"; }; version = "2.6.1"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0inl77jh4ia03jw3iqm5ipr76ghal3hyjrd6r8zqsswwvi9j2xdi"; type = "gem"; }; version = "1.2.1"; }; vimgolf = { - dependencies = ["highline" "json_pure" "thor"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "highline" + "json_pure" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "190dzqkvshd4i6jf30xnpm4sczraw6rdh4wvfh6qnmg0czmj0sny"; type = "gem"; }; diff --git a/pkgs/games/warsow/default.nix b/pkgs/games/warsow/default.nix index 007b124ba58ced..57fe262babd4e8 100644 --- a/pkgs/games/warsow/default.nix +++ b/pkgs/games/warsow/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, warsow-engine, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + warsow-engine, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "warsow"; @@ -32,7 +38,10 @@ stdenv.mkDerivation rec { ''; homepage = "http://www.warsow.net"; license = licenses.unfreeRedistributable; - maintainers = with maintainers; [ astsmtl abbradar ]; + maintainers = with maintainers; [ + astsmtl + abbradar + ]; platforms = warsow-engine.meta.platforms; }; } diff --git a/pkgs/games/warsow/engine.nix b/pkgs/games/warsow/engine.nix index 71bf581f14fada..c824fadc8814dc 100644 --- a/pkgs/games/warsow/engine.nix +++ b/pkgs/games/warsow/engine.nix @@ -1,5 +1,20 @@ -{ stdenv, lib, substituteAll, fetchurl, cmake, libogg, libvorbis, libtheora, curl, freetype -, libjpeg, libpng, SDL2, libGL, openal, zlib +{ + stdenv, + lib, + substituteAll, + fetchurl, + cmake, + libogg, + libvorbis, + libtheora, + curl, + freetype, + libjpeg, + libpng, + SDL2, + libGL, + openal, + zlib, }: stdenv.mkDerivation rec { @@ -14,14 +29,32 @@ stdenv.mkDerivation rec { patches = [ (substituteAll { src = ./libpath.patch; - inherit zlib curl libpng libjpeg libogg libvorbis libtheora freetype; + inherit + zlib + curl + libpng + libjpeg + libogg + libvorbis + libtheora + freetype + ; }) ]; nativeBuildInputs = [ cmake ]; buildInputs = [ - libogg libvorbis libtheora curl freetype libjpeg SDL2 libGL openal zlib + libogg + libvorbis + libtheora + curl + freetype + libjpeg + SDL2 + libGL + openal + zlib libpng ]; @@ -52,7 +85,10 @@ stdenv.mkDerivation rec { description = "Multiplayer FPS game designed for competitive gaming (engine only)"; homepage = "http://www.warsow.net"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ astsmtl abbradar ]; + maintainers = with maintainers; [ + astsmtl + abbradar + ]; platforms = platforms.linux; broken = stdenv.hostPlatform.isAarch64; }; diff --git a/pkgs/games/xonotic/default.nix b/pkgs/games/xonotic/default.nix index 3977f87f8e9393..f4aa2de0d37cde 100644 --- a/pkgs/games/xonotic/default.nix +++ b/pkgs/games/xonotic/default.nix @@ -1,17 +1,38 @@ -{ lib, stdenv, fetchurl, fetchzip, makeWrapper, runCommand, makeDesktopItem -, xonotic-data, copyDesktopItems -, # required for both - unzip, libjpeg, zlib, libvorbis, curl, freetype, libpng, libtheora -, # glx - libX11, libGLU, libGL, libXpm, libXext, libXxf86vm, alsa-lib -, # sdl - SDL2 -, # blind - gmp - -, withSDL ? true -, withGLX ? false -, withDedicated ? true +{ + lib, + stdenv, + fetchurl, + fetchzip, + makeWrapper, + runCommand, + makeDesktopItem, + xonotic-data, + copyDesktopItems, + # required for both + unzip, + libjpeg, + zlib, + libvorbis, + curl, + freetype, + libpng, + libtheora, + # glx + libX11, + libGLU, + libGL, + libXpm, + libXext, + libXxf86vm, + alsa-lib, + # sdl + SDL2, + # blind + gmp, + + withSDL ? true, + withGLX ? false, + withDedicated ? true, }: let @@ -27,7 +48,8 @@ let "-glx" else if withDedicated then "-dedicated" - else "-what-even-am-i"; + else + "-what-even-am-i"; meta = { description = "A free fast-paced first-person shooter"; @@ -41,7 +63,10 @@ let ''; homepage = "https://www.xonotic.org/"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [ astsmtl zalakain ]; + maintainers = with lib.maintainers; [ + astsmtl + zalakain + ]; platforms = lib.platforms.linux; }; @@ -50,7 +75,10 @@ let exec = "xonotic"; comment = meta.description; desktopName = "Xonotic"; - categories = [ "Game" "Shooter" ]; + categories = [ + "Game" + "Shooter" + ]; icon = "xonotic"; startupNotify = false; }; @@ -65,8 +93,23 @@ let }; nativeBuildInputs = [ unzip ]; - buildInputs = [ libjpeg zlib libvorbis curl gmp ] - ++ lib.optionals withGLX [ libX11 libGLU libGL libXpm libXext libXxf86vm alsa-lib ] + buildInputs = + [ + libjpeg + zlib + libvorbis + curl + gmp + ] + ++ lib.optionals withGLX [ + libX11 + libGLU + libGL + libXpm + libXext + libXxf86vm + alsa-lib + ] ++ lib.optionals withSDL [ SDL2 ]; sourceRoot = "Xonotic/source/darkplaces"; @@ -82,73 +125,90 @@ let popd ''; - buildPhase = (lib.optionalString withDedicated '' - make -j $NIX_BUILD_CORES sv-${target} - '' + lib.optionalString withGLX '' - make -j $NIX_BUILD_CORES cl-${target} - '' + lib.optionalString withSDL '' - make -j $NIX_BUILD_CORES sdl-${target} - '') + '' - pushd ../d0_blind_id - make -j $NIX_BUILD_CORES - popd - ''; + buildPhase = + ( + lib.optionalString withDedicated '' + make -j $NIX_BUILD_CORES sv-${target} + '' + + lib.optionalString withGLX '' + make -j $NIX_BUILD_CORES cl-${target} + '' + + lib.optionalString withSDL '' + make -j $NIX_BUILD_CORES sdl-${target} + '' + ) + + '' + pushd ../d0_blind_id + make -j $NIX_BUILD_CORES + popd + ''; enableParallelBuilding = true; - installPhase = ('' - install -Dm644 ../../misc/logos/xonotic_icon.svg \ - $out/share/icons/hicolor/scalable/apps/xonotic.svg - pushd ../../misc/logos/icons_png - for img in *.png; do - size=''${img#xonotic_} - size=''${size%.png} - dimensions="''${size}x''${size}" - install -Dm644 $img \ - $out/share/icons/hicolor/$dimensions/apps/xonotic.png - done - popd - '' + lib.optionalString withDedicated '' - install -Dm755 darkplaces-dedicated "$out/bin/xonotic-dedicated" - '' + lib.optionalString withGLX '' - install -Dm755 darkplaces-glx "$out/bin/xonotic-glx" - '' + lib.optionalString withSDL '' - install -Dm755 darkplaces-sdl "$out/bin/xonotic-sdl" - '') + '' - pushd ../d0_blind_id - make install - popd - ''; + installPhase = + ( + '' + install -Dm644 ../../misc/logos/xonotic_icon.svg \ + $out/share/icons/hicolor/scalable/apps/xonotic.svg + pushd ../../misc/logos/icons_png + for img in *.png; do + size=''${img#xonotic_} + size=''${size%.png} + dimensions="''${size}x''${size}" + install -Dm644 $img \ + $out/share/icons/hicolor/$dimensions/apps/xonotic.png + done + popd + '' + + lib.optionalString withDedicated '' + install -Dm755 darkplaces-dedicated "$out/bin/xonotic-dedicated" + '' + + lib.optionalString withGLX '' + install -Dm755 darkplaces-glx "$out/bin/xonotic-glx" + '' + + lib.optionalString withSDL '' + install -Dm755 darkplaces-sdl "$out/bin/xonotic-sdl" + '' + ) + + '' + pushd ../d0_blind_id + make install + popd + ''; # Xonotic needs to find libcurl.so at runtime for map downloads dontPatchELF = true; - postFixup = lib.optionalString withDedicated '' - patchelf --add-needed ${curl.out}/lib/libcurl.so $out/bin/xonotic-dedicated - '' + lib.optionalString withGLX '' - patchelf \ - --add-needed ${curl.out}/lib/libcurl.so \ - --add-needed ${libvorbis}/lib/libvorbisfile.so \ - --add-needed ${libvorbis}/lib/libvorbisenc.so \ - --add-needed ${libvorbis}/lib/libvorbis.so \ - --add-needed ${libGL.out}/lib/libGL.so \ - --add-needed ${freetype}/lib/libfreetype.so \ - --add-needed ${libpng}/lib/libpng.so \ - --add-needed ${libtheora}/lib/libtheora.so \ - $out/bin/xonotic-glx - '' + lib.optionalString withSDL '' - patchelf \ - --add-needed ${curl.out}/lib/libcurl.so \ - --add-needed ${libvorbis}/lib/libvorbisfile.so \ - --add-needed ${libvorbis}/lib/libvorbisenc.so \ - --add-needed ${libvorbis}/lib/libvorbis.so \ - --add-needed ${freetype}/lib/libfreetype.so \ - --add-needed ${libpng}/lib/libpng.so \ - --add-needed ${libtheora}/lib/libtheora.so \ - $out/bin/xonotic-sdl - ''; + postFixup = + lib.optionalString withDedicated '' + patchelf --add-needed ${curl.out}/lib/libcurl.so $out/bin/xonotic-dedicated + '' + + lib.optionalString withGLX '' + patchelf \ + --add-needed ${curl.out}/lib/libcurl.so \ + --add-needed ${libvorbis}/lib/libvorbisfile.so \ + --add-needed ${libvorbis}/lib/libvorbisenc.so \ + --add-needed ${libvorbis}/lib/libvorbis.so \ + --add-needed ${libGL.out}/lib/libGL.so \ + --add-needed ${freetype}/lib/libfreetype.so \ + --add-needed ${libpng}/lib/libpng.so \ + --add-needed ${libtheora}/lib/libtheora.so \ + $out/bin/xonotic-glx + '' + + lib.optionalString withSDL '' + patchelf \ + --add-needed ${curl.out}/lib/libcurl.so \ + --add-needed ${libvorbis}/lib/libvorbisfile.so \ + --add-needed ${libvorbis}/lib/libvorbisenc.so \ + --add-needed ${libvorbis}/lib/libvorbis.so \ + --add-needed ${freetype}/lib/libfreetype.so \ + --add-needed ${libpng}/lib/libpng.so \ + --add-needed ${libtheora}/lib/libtheora.so \ + $out/bin/xonotic-sdl + ''; }; -in rec { +in +rec { xonotic-data = fetchzip { name = "xonotic-data"; url = "https://dl.xonotic.org/xonotic-${version}.zip"; @@ -157,35 +217,48 @@ in rec { cd $out rm -rf $(ls | grep -v "^data$" | grep -v "^key_0.d0pk$") ''; - meta.hydraPlatforms = []; + meta.hydraPlatforms = [ ]; inherit version pname; }; - xonotic = runCommand "xonotic${variant}-${version}" { - inherit xonotic-unwrapped version; - pname = "${pname}${variant}"; - nativeBuildInputs = [ makeWrapper copyDesktopItems ]; - desktopItems = [ desktopItem ]; - meta = meta // { - hydraPlatforms = []; - }; - } ('' - mkdir -p $out/bin - '' + lib.optionalString withDedicated '' - ln -s ${xonotic-unwrapped}/bin/xonotic-dedicated $out/bin/ - '' + lib.optionalString withGLX '' - ln -s ${xonotic-unwrapped}/bin/xonotic-glx $out/bin/xonotic-glx - ln -s $out/bin/xonotic-glx $out/bin/xonotic - '' + lib.optionalString withSDL '' - ln -s ${xonotic-unwrapped}/bin/xonotic-sdl $out/bin/xonotic-sdl - ln -sf $out/bin/xonotic-sdl $out/bin/xonotic - '' + lib.optionalString (withSDL || withGLX) '' - mkdir -p $out/share - ln -s ${xonotic-unwrapped}/share/icons $out/share/icons - copyDesktopItems - '' + '' - for binary in $out/bin/xonotic-*; do - wrapProgram $binary --add-flags "-basedir ${xonotic-data}" --prefix LD_LIBRARY_PATH : "${xonotic-unwrapped}/lib" - done - ''); + xonotic = + runCommand "xonotic${variant}-${version}" + { + inherit xonotic-unwrapped version; + pname = "${pname}${variant}"; + nativeBuildInputs = [ + makeWrapper + copyDesktopItems + ]; + desktopItems = [ desktopItem ]; + meta = meta // { + hydraPlatforms = [ ]; + }; + } + ( + '' + mkdir -p $out/bin + '' + + lib.optionalString withDedicated '' + ln -s ${xonotic-unwrapped}/bin/xonotic-dedicated $out/bin/ + '' + + lib.optionalString withGLX '' + ln -s ${xonotic-unwrapped}/bin/xonotic-glx $out/bin/xonotic-glx + ln -s $out/bin/xonotic-glx $out/bin/xonotic + '' + + lib.optionalString withSDL '' + ln -s ${xonotic-unwrapped}/bin/xonotic-sdl $out/bin/xonotic-sdl + ln -sf $out/bin/xonotic-sdl $out/bin/xonotic + '' + + lib.optionalString (withSDL || withGLX) '' + mkdir -p $out/share + ln -s ${xonotic-unwrapped}/share/icons $out/share/icons + copyDesktopItems + '' + + '' + for binary in $out/bin/xonotic-*; do + wrapProgram $binary --add-flags "-basedir ${xonotic-data}" --prefix LD_LIBRARY_PATH : "${xonotic-unwrapped}/lib" + done + '' + ); } diff --git a/pkgs/games/xpilot/bloodspilot-client.nix b/pkgs/games/xpilot/bloodspilot-client.nix index baf51d96a02832..96e4b0d8a73b15 100644 --- a/pkgs/games/xpilot/bloodspilot-client.nix +++ b/pkgs/games/xpilot/bloodspilot-client.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchurl, libX11, SDL, libGLU, libGL, expat, zlib, SDL_ttf, SDL_image }: +{ + lib, + stdenv, + fetchurl, + libX11, + SDL, + libGLU, + libGL, + expat, + zlib, + SDL_ttf, + SDL_image, +}: stdenv.mkDerivation rec { version = "1.5.0"; @@ -10,7 +22,14 @@ stdenv.mkDerivation rec { }; buildInputs = [ - libX11 SDL SDL_ttf SDL_image libGLU libGL expat zlib + libX11 + SDL + SDL_ttf + SDL_image + libGLU + libGL + expat + zlib ]; NIX_LDFLAGS = "-lX11"; @@ -19,8 +38,8 @@ stdenv.mkDerivation rec { description = "Multiplayer space combat game (client part)"; mainProgram = "bloodspilot-client-sdl"; homepage = "http://bloodspilot.sf.net/"; - license = lib.licenses.gpl2Plus ; - maintainers = [lib.maintainers.raskin]; + license = lib.licenses.gpl2Plus; + maintainers = [ lib.maintainers.raskin ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/games/xpilot/bloodspilot-server.nix b/pkgs/games/xpilot/bloodspilot-server.nix index 509da8eabbe01b..2e3ac840ea67ab 100644 --- a/pkgs/games/xpilot/bloodspilot-server.nix +++ b/pkgs/games/xpilot/bloodspilot-server.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, expat }: +{ + lib, + stdenv, + fetchurl, + expat, +}: stdenv.mkDerivation rec { pname = "bloodspilot-xpilot-fxi-server"; @@ -21,7 +26,7 @@ stdenv.mkDerivation rec { description = "Multiplayer X11 space combat game (server part)"; mainProgram = "xpilots"; homepage = "http://bloodspilot.sf.net/"; - license = licenses.gpl2Plus ; + license = licenses.gpl2Plus; maintainers = [ maintainers.raskin ]; platforms = platforms.linux; }; diff --git a/pkgs/games/xpilot/default.nix b/pkgs/games/xpilot/default.nix index 009ba7a7a7240d..bdc41a27de8a3c 100644 --- a/pkgs/games/xpilot/default.nix +++ b/pkgs/games/xpilot/default.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchurl, libX11, libSM, SDL, libGLU, libGL, expat, SDL_ttf -, SDL_image, zlib, libXxf86misc }: +{ + lib, + stdenv, + fetchurl, + libX11, + libSM, + SDL, + libGLU, + libGL, + expat, + SDL_ttf, + SDL_image, + zlib, + libXxf86misc, +}: stdenv.mkDerivation rec { pname = "xpilot-ng"; version = "4.7.3"; @@ -8,7 +21,16 @@ stdenv.mkDerivation rec { sha256 = "02a7pnp88kh88fzda5q8mzlckk6y9r5fw47j00h26wbsfly0k1zj"; }; buildInputs = [ - libX11 libSM SDL SDL_ttf SDL_image libGLU libGL expat zlib libXxf86misc + libX11 + libSM + SDL + SDL_ttf + SDL_image + libGLU + libGL + expat + zlib + libXxf86misc ]; meta = with lib; { description = "Multiplayer X11 space combat game"; diff --git a/pkgs/misc/apulse/default.nix b/pkgs/misc/apulse/default.nix index 00b53851b8297f..c8bc4d7140ec03 100644 --- a/pkgs/misc/apulse/default.nix +++ b/pkgs/misc/apulse/default.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, alsa-lib, cmake, pkg-config, glib -, tracingSupport ? true, logToStderr ? true }: +{ + lib, + stdenv, + fetchFromGitHub, + alsa-lib, + cmake, + pkg-config, + glib, + tracingSupport ? true, + logToStderr ? true, +}: -let oz = x: if x then "1" else "0"; in +let + oz = x: if x then "1" else "0"; +in stdenv.mkDerivation rec { pname = "apulse"; @@ -14,9 +25,15 @@ stdenv.mkDerivation rec { sha256 = "1p6fh6ah5v3qz7dxhcsixx38bxg44ypbim4m03bxk3ls5i9xslmn"; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; - buildInputs = [ alsa-lib glib ]; + buildInputs = [ + alsa-lib + glib + ]; cmakeFlags = [ "-DWITH_TRACE=${oz tracingSupport}" diff --git a/pkgs/misc/apulse/pressureaudio.nix b/pkgs/misc/apulse/pressureaudio.nix index 638334f44a5d1d..277c5c85ac2649 100644 --- a/pkgs/misc/apulse/pressureaudio.nix +++ b/pkgs/misc/apulse/pressureaudio.nix @@ -1,4 +1,10 @@ -{ stdenv, apulse, libpulseaudio, pkg-config, intltool }: +{ + stdenv, + apulse, + libpulseaudio, + pkg-config, + intltool, +}: stdenv.mkDerivation { pname = "libpressureaudio"; @@ -6,7 +12,10 @@ stdenv.mkDerivation { src = libpulseaudio.src; - nativeBuildInputs = [ pkg-config intltool ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; dontConfigure = true; dontBuild = true; diff --git a/pkgs/misc/autotiling/default.nix b/pkgs/misc/autotiling/default.nix index 41131cbb916bd8..fda86494b7ff57 100644 --- a/pkgs/misc/autotiling/default.nix +++ b/pkgs/misc/autotiling/default.nix @@ -1,4 +1,10 @@ -{ lib, buildPythonApplication, fetchFromGitHub, i3ipc, importlib-metadata }: +{ + lib, + buildPythonApplication, + fetchFromGitHub, + i3ipc, + importlib-metadata, +}: buildPythonApplication rec { pname = "autotiling"; @@ -11,7 +17,10 @@ buildPythonApplication rec { hash = "sha256-k+UiAGMB/fJiE+C737yGdyTpER1ciZrMkZezkcn/4yk="; }; - propagatedBuildInputs = [ i3ipc importlib-metadata ]; + propagatedBuildInputs = [ + i3ipc + importlib-metadata + ]; doCheck = false; meta = with lib; { @@ -23,4 +32,3 @@ buildPythonApplication rec { mainProgram = "autotiling"; }; } - diff --git a/pkgs/misc/barebox/default.nix b/pkgs/misc/barebox/default.nix index ab981d1f38c0ee..f6bb7caa15f13e 100644 --- a/pkgs/misc/barebox/default.nix +++ b/pkgs/misc/barebox/default.nix @@ -1,84 +1,93 @@ -{ stdenv -, lib -, fetchurl -, bison -, dtc -, flex -, libusb1 -, lzop -, openssl -, pkg-config -, buildPackages +{ + stdenv, + lib, + fetchurl, + bison, + dtc, + flex, + libusb1, + lzop, + openssl, + pkg-config, + buildPackages, }: let - buildBarebox = { - filesToInstall - , installDir ? "$out" - , defconfig - , extraMeta ? {} - , ... } @ args: stdenv.mkDerivation rec { - pname = "barebox-${defconfig}"; - - version = "2020.12.0"; - - src = fetchurl { - url = "https://www.barebox.org/download/barebox-${version}.tar.bz2"; - sha256 = "06vsd95ihaa2nywpqy6k0c7xwk2pzws4yvbp328yd2pfiigachrv"; - }; - - postPatch = '' - patchShebangs scripts - ''; - - nativeBuildInputs = [ - bison - dtc - flex - openssl - libusb1 - lzop - pkg-config - ]; - depsBuildBuild = [ buildPackages.stdenv.cc ]; - - hardeningDisable = [ "all" ]; - - makeFlags = [ - "DTC=dtc" - "CROSS_COMPILE=${stdenv.cc.targetPrefix}" - ]; - - configurePhase = '' - runHook preConfigure - - make ${defconfig} - - runHook postConfigure - ''; - - installPhase = '' - runHook preInstall - - mkdir -p ${installDir} - cp ${lib.concatStringsSep " " filesToInstall} ${installDir} - - runHook postInstall - ''; - - enableParallelBuilding = true; - - dontStrip = true; - - meta = with lib; { - homepage = "https://www.barebox.org"; - description = "Swiss Army Knive for bare metal"; - license = licenses.gpl2Only; - maintainers = with maintainers; [ emantor ]; - } // extraMeta; - } // removeAttrs args [ "extraMeta" ]; - -in { + buildBarebox = + { + filesToInstall, + installDir ? "$out", + defconfig, + extraMeta ? { }, + ... + }@args: + stdenv.mkDerivation rec { + pname = "barebox-${defconfig}"; + + version = "2020.12.0"; + + src = fetchurl { + url = "https://www.barebox.org/download/barebox-${version}.tar.bz2"; + sha256 = "06vsd95ihaa2nywpqy6k0c7xwk2pzws4yvbp328yd2pfiigachrv"; + }; + + postPatch = '' + patchShebangs scripts + ''; + + nativeBuildInputs = [ + bison + dtc + flex + openssl + libusb1 + lzop + pkg-config + ]; + depsBuildBuild = [ buildPackages.stdenv.cc ]; + + hardeningDisable = [ "all" ]; + + makeFlags = [ + "DTC=dtc" + "CROSS_COMPILE=${stdenv.cc.targetPrefix}" + ]; + + configurePhase = '' + runHook preConfigure + + make ${defconfig} + + runHook postConfigure + ''; + + installPhase = '' + runHook preInstall + + mkdir -p ${installDir} + cp ${lib.concatStringsSep " " filesToInstall} ${installDir} + + runHook postInstall + ''; + + enableParallelBuilding = true; + + dontStrip = true; + + meta = + with lib; + { + homepage = "https://www.barebox.org"; + description = "Swiss Army Knive for bare metal"; + license = licenses.gpl2Only; + maintainers = with maintainers; [ emantor ]; + } + // extraMeta; + } + // removeAttrs args [ "extraMeta" ]; + +in +{ inherit buildBarebox; bareboxTools = buildBarebox { diff --git a/pkgs/misc/calaos/installer/default.nix b/pkgs/misc/calaos/installer/default.nix index 853c187d38ae54..311b87f6b42970 100644 --- a/pkgs/misc/calaos/installer/default.nix +++ b/pkgs/misc/calaos/installer/default.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, stdenv, fetchFromGitHub, qmake, qttools, qtbase }: +{ + mkDerivation, + lib, + stdenv, + fetchFromGitHub, + qmake, + qttools, + qtbase, +}: mkDerivation rec { pname = "calaos_installer"; @@ -11,18 +19,25 @@ mkDerivation rec { sha256 = "sha256-e/f58VtGmKukdv4rIrGljXhA9d/xUycM5V6I1FT5qeY="; }; - nativeBuildInputs = [ qmake qttools ]; + nativeBuildInputs = [ + qmake + qttools + ]; buildInputs = [ qtbase ]; qmakeFlags = [ "REVISION=${version}" ]; - installPhase = if stdenv.hostPlatform.isDarwin then '' - mkdir -p $out/Applications - cp -a calaos_installer.app $out/Applications - '' else '' - mkdir -p $out/bin - cp -a calaos_installer $out/bin - ''; + installPhase = + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p $out/Applications + cp -a calaos_installer.app $out/Applications + '' + else + '' + mkdir -p $out/bin + cp -a calaos_installer $out/bin + ''; meta = with lib; { description = "Calaos Installer, a tool to create calaos configuration"; diff --git a/pkgs/misc/cliscord/default.nix b/pkgs/misc/cliscord/default.nix index 0617b0f8069bca..0ceb9ca462a29c 100644 --- a/pkgs/misc/cliscord/default.nix +++ b/pkgs/misc/cliscord/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, rustPlatform -, openssl -, pkg-config -, fetchFromGitHub -, Security +{ + lib, + stdenv, + rustPlatform, + openssl, + pkg-config, + fetchFromGitHub, + Security, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/misc/cups/cups-pk-helper.nix b/pkgs/misc/cups/cups-pk-helper.nix index 75f5122cfd03a0..ede2192354222b 100644 --- a/pkgs/misc/cups/cups-pk-helper.nix +++ b/pkgs/misc/cups/cups-pk-helper.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, intltool, pkg-config, glib, polkit, cups, fetchpatch }: +{ + lib, + stdenv, + fetchurl, + intltool, + pkg-config, + glib, + polkit, + cups, + fetchpatch, +}: stdenv.mkDerivation rec { version = "0.2.6"; @@ -9,8 +19,15 @@ stdenv.mkDerivation rec { sha256 = "0a52jw6rm7lr5nbyksiia0rn7sasyb5cjqcb95z1wxm2yprgi6lm"; }; - nativeBuildInputs = [ pkg-config intltool ]; - buildInputs = [ glib polkit cups ]; + nativeBuildInputs = [ + pkg-config + intltool + ]; + buildInputs = [ + glib + polkit + cups + ]; patches = [ # Don't use etc/dbus-1/system.d diff --git a/pkgs/misc/cups/drivers/brgenml1lpr/default.nix b/pkgs/misc/cups/drivers/brgenml1lpr/default.nix index 98116903ec64c4..c0dc26a5dfdc67 100644 --- a/pkgs/misc/cups/drivers/brgenml1lpr/default.nix +++ b/pkgs/misc/cups/drivers/brgenml1lpr/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, cups, perl, ghostscript, which, makeWrapper}: +{ + lib, + stdenv, + fetchurl, + cups, + perl, + ghostscript, + which, + makeWrapper, +}: /* [Setup instructions](http://support.brother.com/g/s/id/linux/en/instruction_prn1a.html). @@ -49,7 +58,13 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ cups perl stdenv.cc.libc ghostscript which ]; + buildInputs = [ + cups + perl + stdenv.cc.libc + ghostscript + which + ]; dontBuild = true; @@ -83,7 +98,6 @@ stdenv.mkDerivation rec { dontPatchELF = true; - meta = { description = "Brother BrGenML1 LPR driver"; homepage = "http://www.brother.com"; diff --git a/pkgs/misc/cups/drivers/brother/dcp375cw/default.nix b/pkgs/misc/cups/drivers/brother/dcp375cw/default.nix index c9e92e839a0e35..57cfd2ef45fad2 100644 --- a/pkgs/misc/cups/drivers/brother/dcp375cw/default.nix +++ b/pkgs/misc/cups/drivers/brother/dcp375cw/default.nix @@ -1,23 +1,44 @@ -{ lib, stdenv, fetchurl, cups, dpkg, gnused, makeWrapper, ghostscript, file -, a2ps, coreutils, gnugrep, which, gawk }: +{ + lib, + stdenv, + fetchurl, + cups, + dpkg, + gnused, + makeWrapper, + ghostscript, + file, + a2ps, + coreutils, + gnugrep, + which, + gawk, +}: let version = "1.1.3"; model = "dcp375cw"; -in rec { +in +rec { driver = stdenv.mkDerivation { pname = "${model}-lpr"; inherit version; src = fetchurl { - url = - "https://download.brother.com/welcome/dlf005427/dcp375cwlpr-${version}-1.i386.deb"; - sha256 = - "6daf0144b5802ea8da394ca14db0e6f0200d4049545649283791f899b7f7bd26"; + url = "https://download.brother.com/welcome/dlf005427/dcp375cwlpr-${version}-1.i386.deb"; + sha256 = "6daf0144b5802ea8da394ca14db0e6f0200d4049545649283791f899b7f7bd26"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; - buildInputs = [ cups ghostscript a2ps gawk ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; + buildInputs = [ + cups + ghostscript + a2ps + gawk + ]; unpackPhase = "dpkg-deb -x $src $out"; installPhase = '' @@ -51,8 +72,7 @@ in rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; platforms = platforms.linux; - downloadPage = - "https://support.brother.com/g/b/downloadlist.aspx?c=gb&lang=en&prod=${model}_all&os=128"; + downloadPage = "https://support.brother.com/g/b/downloadlist.aspx?c=gb&lang=en&prod=${model}_all&os=128"; maintainers = with maintainers; [ marcovergueira ]; }; }; @@ -62,20 +82,31 @@ in rec { inherit version; src = fetchurl { - url = - "https://download.brother.com/welcome/dlf005429/dcp375cwcupswrapper-${version}-1.i386.deb"; - sha256 = - "9a255728b595d2667b2caf9d0d332b677e1a6829a3ec1ed6d4e900a44069cf2d"; + url = "https://download.brother.com/welcome/dlf005429/dcp375cwcupswrapper-${version}-1.i386.deb"; + sha256 = "9a255728b595d2667b2caf9d0d332b677e1a6829a3ec1ed6d4e900a44069cf2d"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; - buildInputs = [ cups ghostscript a2ps gawk ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; + buildInputs = [ + cups + ghostscript + a2ps + gawk + ]; unpackPhase = "dpkg-deb -x $src $out"; installPhase = '' for f in $out/opt/brother/Printers/${model}/cupswrapper/cupswrapper${model}; do wrapProgram $f --prefix PATH : ${ - lib.makeBinPath [ coreutils ghostscript gnugrep gnused ] + lib.makeBinPath [ + coreutils + ghostscript + gnugrep + gnused + ] } done @@ -89,8 +120,7 @@ in rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; platforms = platforms.linux; - downloadPage = - "https://support.brother.com/g/b/downloadlist.aspx?c=gb&lang=en&prod=${model}_all&os=128"; + downloadPage = "https://support.brother.com/g/b/downloadlist.aspx?c=gb&lang=en&prod=${model}_all&os=128"; maintainers = with maintainers; [ marcovergueira ]; }; }; diff --git a/pkgs/misc/cups/drivers/brother/dcp9020cdw/default.nix b/pkgs/misc/cups/drivers/brother/dcp9020cdw/default.nix index ddae34eaec838b..1a1e5988f007fb 100644 --- a/pkgs/misc/cups/drivers/brother/dcp9020cdw/default.nix +++ b/pkgs/misc/cups/drivers/brother/dcp9020cdw/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchurl -, cups -, dpkg -, gnused -, makeWrapper -, ghostscript -, file -, a2ps -, coreutils -, gnugrep -, which -, gawk +{ + lib, + stdenv, + fetchurl, + cups, + dpkg, + gnused, + makeWrapper, + ghostscript, + file, + a2ps, + coreutils, + gnugrep, + which, + gawk, }: let @@ -28,8 +29,16 @@ rec { sha256 = "1z6nma489s0a0b0a8wyg38yxanz4k99dg29fyjs4jlprsvmwk56y"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; - buildInputs = [ cups ghostscript a2ps gawk ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; + buildInputs = [ + cups + ghostscript + a2ps + gawk + ]; unpackPhase = "dpkg-deb -x $src $out"; installPhase = '' @@ -43,16 +52,18 @@ rec { ln -s $out/opt/brother/Printers/${model}/lpd/filter${model} $out/lib/cups/filter/brother_lpdwrapper_${model} wrapProgram $out/opt/brother/Printers/${model}/lpd/filter${model} \ - --prefix PATH ":" ${lib.makeBinPath [ - gawk - ghostscript - a2ps - file - gnused - gnugrep - coreutils - which - ]} + --prefix PATH ":" ${ + lib.makeBinPath [ + gawk + ghostscript + a2ps + file + gnused + gnugrep + coreutils + which + ] + } ''; meta = with lib; { @@ -75,13 +86,28 @@ rec { sha256 = "04yqm1qv9p4hgp1p6mqq4siygl4056s6flv6kqln8mvmcr8zaq1s"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; - buildInputs = [ cups ghostscript a2ps gawk ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; + buildInputs = [ + cups + ghostscript + a2ps + gawk + ]; unpackPhase = "dpkg-deb -x $src $out"; installPhase = '' for f in $out/opt/brother/Printers/${model}/cupswrapper/cupswrapper${model}; do - wrapProgram $f --prefix PATH : ${lib.makeBinPath [ coreutils ghostscript gnugrep gnused ]} + wrapProgram $f --prefix PATH : ${ + lib.makeBinPath [ + coreutils + ghostscript + gnugrep + gnused + ] + } done mkdir -p $out/share/cups/model diff --git a/pkgs/misc/cups/drivers/brother/mfcl3770cdw/default.nix b/pkgs/misc/cups/drivers/brother/mfcl3770cdw/default.nix index de1d397f7b5817..b165938d487f87 100644 --- a/pkgs/misc/cups/drivers/brother/mfcl3770cdw/default.nix +++ b/pkgs/misc/cups/drivers/brother/mfcl3770cdw/default.nix @@ -1,15 +1,16 @@ -{ pkgsi686Linux -, stdenv -, fetchurl -, dpkg -, makeWrapper -, coreutils -, ghostscript -, gnugrep -, gnused -, which -, perl -, lib +{ + pkgsi686Linux, + stdenv, + fetchurl, + dpkg, + makeWrapper, + coreutils, + ghostscript, + gnugrep, + gnused, + which, + perl, + lib, }: let @@ -21,28 +22,38 @@ let }; reldir = "opt/brother/Printers/${model}/"; -in rec { +in +rec { driver = pkgsi686Linux.stdenv.mkDerivation rec { inherit src version; name = "${model}drv-${version}"; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; unpackPhase = "dpkg-deb -x $src $out"; installPhase = '' - dir="$out/${reldir}" - substituteInPlace $dir/lpd/filter_${model} \ - --replace /usr/bin/perl ${perl}/bin/perl \ - --replace "BR_PRT_PATH =~" "BR_PRT_PATH = \"$dir\"; #" \ - --replace "PRINTER =~" "PRINTER = \"${model}\"; #" - wrapProgram $dir/lpd/filter_${model} \ - --prefix PATH : ${lib.makeBinPath [ - coreutils ghostscript gnugrep gnused which - ]} - # need to use i686 glibc here, these are 32bit proprietary binaries - patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ - $dir/lpd/brmfcl3770cdwfilter + dir="$out/${reldir}" + substituteInPlace $dir/lpd/filter_${model} \ + --replace /usr/bin/perl ${perl}/bin/perl \ + --replace "BR_PRT_PATH =~" "BR_PRT_PATH = \"$dir\"; #" \ + --replace "PRINTER =~" "PRINTER = \"${model}\"; #" + wrapProgram $dir/lpd/filter_${model} \ + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + ghostscript + gnugrep + gnused + which + ] + } + # need to use i686 glibc here, these are 32bit proprietary binaries + patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ + $dir/lpd/brmfcl3770cdwfilter ''; meta = { @@ -50,7 +61,10 @@ in rec { homepage = "http://www.brother.com/"; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; license = lib.licenses.unfree; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ lib.maintainers.steveej ]; }; }; @@ -59,7 +73,10 @@ in rec { inherit version src; name = "${model}cupswrapper-${version}"; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; unpackPhase = "dpkg-deb -x $src $out"; @@ -71,7 +88,13 @@ in rec { --replace "basedir =~" "basedir = \"$basedir\"; #" \ --replace "PRINTER =~" "PRINTER = \"${model}\"; #" wrapProgram $dir/cupswrapper/brother_lpdwrapper_${model} \ - --prefix PATH : ${lib.makeBinPath [ coreutils gnugrep gnused ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + gnugrep + gnused + ] + } mkdir -p $out/lib/cups/filter mkdir -p $out/share/cups/model ln $dir/cupswrapper/brother_lpdwrapper_${model} $out/lib/cups/filter @@ -83,7 +106,10 @@ in rec { homepage = "http://www.brother.com/"; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; license = lib.licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = [ lib.maintainers.steveej ]; }; }; diff --git a/pkgs/misc/cups/drivers/cnijfilter_2_80/default.nix b/pkgs/misc/cups/drivers/cnijfilter_2_80/default.nix index 1a573c032e7fc9..85b02e6620df37 100644 --- a/pkgs/misc/cups/drivers/cnijfilter_2_80/default.nix +++ b/pkgs/misc/cups/drivers/cnijfilter_2_80/default.nix @@ -1,23 +1,36 @@ -{ stdenv, lib, fetchzip, - autoconf, automake, libtool, - cups, popt, libtiff, libpng, - ghostscript }: - -/* this derivation is basically just a transcription of the rpm .spec - file included in the tarball */ +{ + stdenv, + lib, + fetchzip, + autoconf, + automake, + libtool, + cups, + popt, + libtiff, + libpng, + ghostscript, +}: + +/* + this derivation is basically just a transcription of the rpm .spec + file included in the tarball +*/ stdenv.mkDerivation { pname = "cnijfilter"; - /* important note about versions: cnijfilter packages seem to use - versions in a non-standard way. the version indicates which - printers are supported in the package. so this package should - not be "upgraded" in the usual way. - - instead, if you want to include another version supporting your - printer, you should try to abstract out the common things (which - should be pretty much everything except the version and the 'pr' - and 'pr_id' values to loop over). */ + /* + important note about versions: cnijfilter packages seem to use + versions in a non-standard way. the version indicates which + printers are supported in the package. so this package should + not be "upgraded" in the usual way. + + instead, if you want to include another version supporting your + printer, you should try to abstract out the common things (which + should be pretty much everything except the version and the 'pr' + and 'pr_id' values to loop over). + */ version = "2.80"; src = fetchzip { @@ -25,13 +38,23 @@ stdenv.mkDerivation { sha256 = "06s9nl155yxmx56056y22kz1p5b2sb5fhr3gf4ddlczjkd1xch53"; }; - nativeBuildInputs = [ autoconf automake ]; - buildInputs = [ libtool - cups popt libtiff libpng - ghostscript ]; - - patches = [ ./patches/missing-include.patch - ./patches/libpng15.patch ]; + nativeBuildInputs = [ + autoconf + automake + ]; + buildInputs = [ + libtool + cups + popt + libtiff + libpng + ghostscript + ]; + + patches = [ + ./patches/missing-include.patch + ./patches/libpng15.patch + ]; postPatch = '' sed -i "s|/usr/lib/cups/backend|$out/lib/cups/backend|" backend/src/Makefile.am; @@ -90,14 +113,16 @@ stdenv.mkDerivation { popd; ''; - /* the tarball includes some pre-built shared libraries. we run - 'patchelf --set-rpath' on them just a few lines above, so that - they can find each other. but that's not quite enough. some of - those libraries load each other in non-standard ways -- they - don't list each other in the DT_NEEDED section. so, if the - standard 'patchelf --shrink-rpath' (from - pkgs/development/tools/misc/patchelf/setup-hook.sh) is run on - them, it undoes the --set-rpath. this prevents that. */ + /* + the tarball includes some pre-built shared libraries. we run + 'patchelf --set-rpath' on them just a few lines above, so that + they can find each other. but that's not quite enough. some of + those libraries load each other in non-standard ways -- they + don't list each other in the DT_NEEDED section. so, if the + standard 'patchelf --shrink-rpath' (from + pkgs/development/tools/misc/patchelf/setup-hook.sh) is run on + them, it undoes the --set-rpath. this prevents that. + */ dontPatchELF = true; # fortify hardening makes the filter crash diff --git a/pkgs/misc/cups/drivers/hl1110/default.nix b/pkgs/misc/cups/drivers/hl1110/default.nix index 07143b0991fb16..9900ad49817158 100644 --- a/pkgs/misc/cups/drivers/hl1110/default.nix +++ b/pkgs/misc/cups/drivers/hl1110/default.nix @@ -1,34 +1,56 @@ -{lib, stdenv, fetchurl, cups, dpkg, gnused, makeWrapper, ghostscript, file, a2ps, coreutils, gawk }: +{ + lib, + stdenv, + fetchurl, + cups, + dpkg, + gnused, + makeWrapper, + ghostscript, + file, + a2ps, + coreutils, + gawk, +}: let version = "3.0.1-1"; -cupsdeb = fetchurl { - url = "http://download.brother.com/welcome/dlf100421/hl1110cupswrapper-${version}.i386.deb"; - sha256 = "a87880f4ece764a724411b5b24d15d1b912f6ffc6ecbfd9fac4cd5eda13d2eb7"; -}; -srcdir = "hl1110cupswrapper-GPL_src-${version}"; -cupssrc = fetchurl { - url = "http://download.brother.com/welcome/dlf100422/${srcdir}.tar.gz"; - sha256 = "be1dce6a4608cb253b0b382db30bf5885da46b010e8eb595b15c435e2487761c"; -}; -lprdeb = fetchurl { - url = "http://download.brother.com/welcome/dlf100419/hl1110lpr-${version}.i386.deb"; - sha256 = "5af241782a0d500d7f47e06ea43d61127f4019b5b1c6e68b4c1cb4521a742c22"; -}; - in + cupsdeb = fetchurl { + url = "http://download.brother.com/welcome/dlf100421/hl1110cupswrapper-${version}.i386.deb"; + sha256 = "a87880f4ece764a724411b5b24d15d1b912f6ffc6ecbfd9fac4cd5eda13d2eb7"; + }; + srcdir = "hl1110cupswrapper-GPL_src-${version}"; + cupssrc = fetchurl { + url = "http://download.brother.com/welcome/dlf100422/${srcdir}.tar.gz"; + sha256 = "be1dce6a4608cb253b0b382db30bf5885da46b010e8eb595b15c435e2487761c"; + }; + lprdeb = fetchurl { + url = "http://download.brother.com/welcome/dlf100419/hl1110lpr-${version}.i386.deb"; + sha256 = "5af241782a0d500d7f47e06ea43d61127f4019b5b1c6e68b4c1cb4521a742c22"; + }; +in stdenv.mkDerivation { pname = "cups-brother-hl1110"; inherit version; - srcs = [ lprdeb cupssrc cupsdeb ]; + srcs = [ + lprdeb + cupssrc + cupsdeb + ]; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ cups ghostscript dpkg a2ps ]; + buildInputs = [ + cups + ghostscript + dpkg + a2ps + ]; unpackPhase = '' tar -xvf ${cupssrc} - ''; + ''; buildPhase = '' gcc -Wall ${srcdir}/brcupsconfig/brcupsconfig.c -o brcupsconfig4 - ''; + ''; installPhase = '' # install lpr dpkg-deb -x ${lprdeb} $out @@ -43,10 +65,24 @@ stdenv.mkDerivation { patchelf --set-interpreter ${stdenv.cc.libc}/lib/ld-linux.so.2 $out/opt/brother/Printers/HL1110/inf/braddprinter wrapProgram $out/opt/brother/Printers/HL1110/lpd/psconvert2 \ - --prefix PATH ":" ${ lib.makeBinPath [ gnused coreutils gawk ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + gnused + coreutils + gawk + ] + } wrapProgram $out/opt/brother/Printers/HL1110/lpd/filter_HL1110 \ - --prefix PATH ":" ${ lib.makeBinPath [ ghostscript a2ps file gnused coreutils ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + ghostscript + a2ps + file + gnused + coreutils + ] + } dpkg-deb -x ${cupsdeb} $out @@ -60,9 +96,15 @@ stdenv.mkDerivation { ln -s $out/opt/brother/Printers/HL1110/cupswrapper/brcupsconfig4 $out/lib/cups/filter/brcupsconfig4 wrapProgram $out/opt/brother/Printers/HL1110/cupswrapper/brother_lpdwrapper_HL1110 \ - --prefix PATH ":" ${ lib.makeBinPath [ gnused coreutils gawk ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + gnused + coreutils + gawk + ] + } - ''; + ''; meta = { homepage = "http://www.brother.com/"; diff --git a/pkgs/misc/cups/drivers/hl1210w/default.nix b/pkgs/misc/cups/drivers/hl1210w/default.nix index b4bf573d68e57c..9dbe1ffe56a7d5 100644 --- a/pkgs/misc/cups/drivers/hl1210w/default.nix +++ b/pkgs/misc/cups/drivers/hl1210w/default.nix @@ -1,4 +1,18 @@ -{lib, stdenv, pkgsi686Linux, fetchurl, cups, dpkg, gnused, makeWrapper, ghostscript, file, a2ps, coreutils, gawk}: +{ + lib, + stdenv, + pkgsi686Linux, + fetchurl, + cups, + dpkg, + gnused, + makeWrapper, + ghostscript, + file, + a2ps, + coreutils, + gawk, +}: let version = "3.0.1-1"; @@ -15,9 +29,17 @@ stdenv.mkDerivation { pname = "cups-brother-hl1210W"; inherit version; - srcs = [ lprdeb cupsdeb ]; + srcs = [ + lprdeb + cupsdeb + ]; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ cups ghostscript dpkg a2ps ]; + buildInputs = [ + cups + ghostscript + dpkg + a2ps + ]; dontUnpack = true; installPhase = '' @@ -34,9 +56,23 @@ stdenv.mkDerivation { patchelf --set-interpreter ${pkgsi686Linux.glibc.out}/lib/ld-linux.so.2 $out/opt/brother/Printers/HL1210W/inf/braddprinter wrapProgram $out/opt/brother/Printers/HL1210W/lpd/psconvert2 \ - --prefix PATH ":" ${ lib.makeBinPath [ gnused coreutils gawk ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + gnused + coreutils + gawk + ] + } wrapProgram $out/opt/brother/Printers/HL1210W/lpd/filter_HL1210W \ - --prefix PATH ":" ${ lib.makeBinPath [ ghostscript a2ps file gnused coreutils ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + ghostscript + a2ps + file + gnused + coreutils + ] + } # install cups dpkg-deb -x ${cupsdeb} $out @@ -50,8 +86,14 @@ stdenv.mkDerivation { ln -s $out/opt/brother/Printers/HL1210W/cupswrapper/brcupsconfig4 $out/lib/cups/filter/brcupsconfig4 wrapProgram $out/opt/brother/Printers/HL1210W/cupswrapper/brother_lpdwrapper_HL1210W \ - --prefix PATH ":" ${ lib.makeBinPath [ gnused coreutils gawk ] } - ''; + --prefix PATH ":" ${ + lib.makeBinPath [ + gnused + coreutils + gawk + ] + } + ''; meta = { homepage = "http://www.brother.com/"; diff --git a/pkgs/misc/cups/drivers/hl2260d/default.nix b/pkgs/misc/cups/drivers/hl2260d/default.nix index 9883bd99a314ec..22d1ab057f039b 100644 --- a/pkgs/misc/cups/drivers/hl2260d/default.nix +++ b/pkgs/misc/cups/drivers/hl2260d/default.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchurl, cups, dpkg, gnused, makeWrapper, ghostscript, coreutils, perl, gnugrep, which -, debugLvl ? "0" +{ + lib, + stdenv, + fetchurl, + cups, + dpkg, + gnused, + makeWrapper, + ghostscript, + coreutils, + perl, + gnugrep, + which, + debugLvl ? "0", }: let @@ -18,8 +30,15 @@ stdenv.mkDerivation { pname = "cups-brother-hl2260d"; inherit version; - nativeBuildInputs = [ makeWrapper dpkg ]; - buildInputs = [ cups ghostscript perl ]; + nativeBuildInputs = [ + makeWrapper + dpkg + ]; + buildInputs = [ + cups + ghostscript + perl + ]; dontPatchELF = true; dontBuild = true; @@ -71,18 +90,32 @@ stdenv.mkDerivation { makeWrapper \ $out/opt/brother/Printers/HL2260D/cupswrapper/brother_lpdwrapper_HL2260D \ $out/lib/cups/filter/brother_lpdwrapper_HL2260D \ - --prefix PATH : ${lib.makeBinPath [coreutils gnugrep gnused]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + gnugrep + gnused + ] + } wrapProgram $out/opt/brother/Printers/HL2260D/lpd/filter_HL2260D \ - --prefix PATH ":" ${ lib.makeBinPath [ ghostscript which ] } - ''; + --prefix PATH ":" ${ + lib.makeBinPath [ + ghostscript + which + ] + } + ''; meta = with lib; { homepage = "http://www.brother.com/"; description = "Brother HL-2260D printer driver"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; downloadPage = "https://support.brother.com/g/b/downloadtop.aspx?c=cn_ot&lang=en&prod=hl2260d_cn"; maintainers = with maintainers; [ u2x1 ]; }; diff --git a/pkgs/misc/cups/drivers/hl3140cw/default.nix b/pkgs/misc/cups/drivers/hl3140cw/default.nix index 2eceb64d3668da..01bf330149df2f 100644 --- a/pkgs/misc/cups/drivers/hl3140cw/default.nix +++ b/pkgs/misc/cups/drivers/hl3140cw/default.nix @@ -1,4 +1,17 @@ -{lib, stdenv, fetchurl, cups, dpkg, gnused, makeWrapper, ghostscript, file, a2ps, coreutils, gawk }: +{ + lib, + stdenv, + fetchurl, + cups, + dpkg, + gnused, + makeWrapper, + ghostscript, + file, + a2ps, + coreutils, + gawk, +}: let version = "1.1.4-0"; @@ -19,8 +32,15 @@ in stdenv.mkDerivation { pname = "cups-brother-hl3140cw"; inherit version; - nativeBuildInputs = [ makeWrapper dpkg ]; - buildInputs = [ cups ghostscript a2ps ]; + nativeBuildInputs = [ + makeWrapper + dpkg + ]; + buildInputs = [ + cups + ghostscript + a2ps + ]; unpackPhase = '' tar -xvf ${cupssrc} @@ -45,10 +65,24 @@ stdenv.mkDerivation { patchelf --set-interpreter ${stdenv.cc.libc}/lib/ld-linux.so.2 $out/usr/bin/brprintconf_hl3140cw wrapProgram $out/opt/brother/Printers/hl3140cw/lpd/psconvertij2 \ - --prefix PATH ":" ${ lib.makeBinPath [ gnused coreutils gawk ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + gnused + coreutils + gawk + ] + } wrapProgram $out/opt/brother/Printers/hl3140cw/lpd/filterhl3140cw \ - --prefix PATH ":" ${ lib.makeBinPath [ ghostscript a2ps file gnused coreutils ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + ghostscript + a2ps + file + gnused + coreutils + ] + } dpkg-deb -x ${cupsdeb} $out @@ -66,7 +100,13 @@ stdenv.mkDerivation { ln -s $out/opt/brother/Printers/hl3140cw/lpd/filterhl3140cw $out/lib/cups/filter/brother_lpdwrapper_hl3140cw wrapProgram $out/opt/brother/Printers/hl3140cw/cupswrapper/cupswrapperhl3140cw \ - --prefix PATH ":" ${ lib.makeBinPath [ gnused coreutils gawk ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + gnused + coreutils + gawk + ] + } ''; meta = { diff --git a/pkgs/misc/cups/drivers/hll2340dw/default.nix b/pkgs/misc/cups/drivers/hll2340dw/default.nix index 74f3c3819ae8e6..0f41b255e920b9 100644 --- a/pkgs/misc/cups/drivers/hll2340dw/default.nix +++ b/pkgs/misc/cups/drivers/hll2340dw/default.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchurl, cups, dpkg, gnused, makeWrapper, ghostscript, file -, a2ps, coreutils, perl, gnugrep, which +{ + lib, + stdenv, + fetchurl, + cups, + dpkg, + gnused, + makeWrapper, + ghostscript, + file, + a2ps, + coreutils, + perl, + gnugrep, + which, }: let @@ -20,7 +33,12 @@ stdenv.mkDerivation { inherit version; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ cups ghostscript dpkg a2ps ]; + buildInputs = [ + cups + ghostscript + dpkg + a2ps + ]; dontUnpack = true; @@ -45,9 +63,14 @@ stdenv.mkDerivation { $out/opt/brother/Printers/HLL2340D/cupswrapper/paperconfigml1 \ ; do wrapProgram $f \ - --prefix PATH : ${lib.makeBinPath [ - coreutils ghostscript gnugrep gnused - ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + ghostscript + gnugrep + gnused + ] + } done mkdir -p $out/lib/cups/filter/ @@ -57,8 +80,18 @@ stdenv.mkDerivation { ln -s $out/opt/brother/Printers/HLL2340D/cupswrapper/brother-HLL2340D-cups-en.ppd $out/share/cups/model/ wrapProgram $out/opt/brother/Printers/HLL2340D/lpd/filter_HLL2340D \ - --prefix PATH ":" ${ lib.makeBinPath [ ghostscript a2ps file gnused gnugrep coreutils which ] } - ''; + --prefix PATH ":" ${ + lib.makeBinPath [ + ghostscript + a2ps + file + gnused + gnugrep + coreutils + which + ] + } + ''; meta = with lib; { homepage = "http://www.brother.com/"; diff --git a/pkgs/misc/cups/drivers/hll3230cdw/default.nix b/pkgs/misc/cups/drivers/hll3230cdw/default.nix index aff134d7a33a82..3e7893b36cf84e 100644 --- a/pkgs/misc/cups/drivers/hll3230cdw/default.nix +++ b/pkgs/misc/cups/drivers/hll3230cdw/default.nix @@ -1,4 +1,14 @@ -{ stdenv, lib, fetchurl, perl, gnused, dpkg, makeWrapper, autoPatchelfHook, libredirect }: +{ + stdenv, + lib, + fetchurl, + perl, + gnused, + dpkg, + makeWrapper, + autoPatchelfHook, + libredirect, +}: stdenv.mkDerivation rec { pname = "cups-brother-hll3230cdw"; @@ -8,9 +18,17 @@ stdenv.mkDerivation rec { sha256 = "9d49abc584bf22bc381510618a34107ead6ab14562b51831fefd6009947aa5a9"; }; - nativeBuildInputs = [ dpkg makeWrapper autoPatchelfHook ]; + nativeBuildInputs = [ + dpkg + makeWrapper + autoPatchelfHook + ]; - buildInputs = [ perl gnused libredirect ]; + buildInputs = [ + perl + gnused + libredirect + ]; unpackPhase = "dpkg-deb -x $src ."; @@ -69,7 +87,10 @@ stdenv.mkDerivation rec { license = licenses.unfree; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; maintainers = with maintainers; [ aplund ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; homepage = "http://www.brother.com/"; downloadPage = "https://support.brother.com/g/b/downloadend.aspx?c=us&lang=en&prod=hll3230cdw_us_eu_as&os=128&dlid=dlf103925_000&flang=4&type3=10283"; }; diff --git a/pkgs/misc/cups/drivers/mfcj470dwlpr/default.nix b/pkgs/misc/cups/drivers/mfcj470dwlpr/default.nix index 28be1b580a44fc..b865e9adb2c1eb 100644 --- a/pkgs/misc/cups/drivers/mfcj470dwlpr/default.nix +++ b/pkgs/misc/cups/drivers/mfcj470dwlpr/default.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, cups, dpkg, ghostscript, a2ps, coreutils, gnused, gawk, file, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + cups, + dpkg, + ghostscript, + a2ps, + coreutils, + gnused, + gawk, + file, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "mfcj470dw-cupswrapper"; @@ -10,7 +23,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ cups ghostscript dpkg a2ps ]; + buildInputs = [ + cups + ghostscript + dpkg + a2ps + ]; dontUnpack = true; @@ -28,11 +46,25 @@ stdenv.mkDerivation rec { ln -s $out/opt/brother/Printers/mfcj470dw/lpd/filtermfcj470dw $out/lib/cups/filter/brother_lpdwrapper_mfcj470dw wrapProgram $out/opt/brother/Printers/mfcj470dw/lpd/psconvertij2 \ - --prefix PATH ":" ${ lib.makeBinPath [ gnused coreutils gawk ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + gnused + coreutils + gawk + ] + } wrapProgram $out/opt/brother/Printers/mfcj470dw/lpd/filtermfcj470dw \ - --prefix PATH ":" ${ lib.makeBinPath [ ghostscript a2ps file gnused coreutils ] } - ''; + --prefix PATH ":" ${ + lib.makeBinPath [ + ghostscript + a2ps + file + gnused + coreutils + ] + } + ''; meta = { homepage = "http://www.brother.com/"; diff --git a/pkgs/misc/cups/drivers/mfcj6510dwlpr/default.nix b/pkgs/misc/cups/drivers/mfcj6510dwlpr/default.nix index 0af79443ef6d47..b63b297a17aaab 100644 --- a/pkgs/misc/cups/drivers/mfcj6510dwlpr/default.nix +++ b/pkgs/misc/cups/drivers/mfcj6510dwlpr/default.nix @@ -1,5 +1,21 @@ -{ lib, stdenv, fetchurl, pkgsi686Linux, dpkg, makeWrapper, coreutils, gnused, gawk, file, cups, util-linux, xxd, runtimeShell -, ghostscript, a2ps }: +{ + lib, + stdenv, + fetchurl, + pkgsi686Linux, + dpkg, + makeWrapper, + coreutils, + gnused, + gawk, + file, + cups, + util-linux, + xxd, + runtimeShell, + ghostscript, + a2ps, +}: # Why: # The executable "brprintconf_mfcj6510dw" binary is looking for "/opt/brother/Printers/%s/inf/br%sfunc" and "/opt/brother/Printers/%s/inf/br%src". @@ -29,7 +45,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ cups ghostscript dpkg a2ps ]; + buildInputs = [ + cups + ghostscript + dpkg + a2ps + ]; dontUnpack = true; @@ -73,18 +94,32 @@ stdenv.mkDerivation rec { ln -s $out/opt/brother/Printers/mfcj6510dw/lpd/filtermfcj6510dw $out/lib/cups/filter/brother_lpdwrapper_mfcj6510dw wrapProgram $out/opt/brother/Printers/mfcj6510dw/lpd/psconvertij2 \ - --prefix PATH ":" ${ lib.makeBinPath [ coreutils gnused gawk ] } + --prefix PATH ":" ${ + lib.makeBinPath [ + coreutils + gnused + gawk + ] + } wrapProgram $out/opt/brother/Printers/mfcj6510dw/lpd/filtermfcj6510dw \ - --prefix PATH ":" ${ lib.makeBinPath [ coreutils gnused file ghostscript a2ps ] } - ''; + --prefix PATH ":" ${ + lib.makeBinPath [ + coreutils + gnused + file + ghostscript + a2ps + ] + } + ''; meta = with lib; { - description = "Brother MFC-J6510DW LPR driver"; + description = "Brother MFC-J6510DW LPR driver"; downloadPage = "http://support.brother.com/g/b/downloadlist.aspx?c=us&lang=en&prod=mfcj6510dw_all&os=128"; - homepage = "http://www.brother.com/"; + homepage = "http://www.brother.com/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = with licenses; unfree; - maintainers = with maintainers; [ ramkromberg ]; - platforms = with platforms; linux; + license = with licenses; unfree; + maintainers = with maintainers; [ ramkromberg ]; + platforms = with platforms; linux; }; } diff --git a/pkgs/misc/cups/drivers/mfcl2700dnlpr/default.nix b/pkgs/misc/cups/drivers/mfcl2700dnlpr/default.nix index 7e0c95582f533a..2370ec711f3595 100644 --- a/pkgs/misc/cups/drivers/mfcl2700dnlpr/default.nix +++ b/pkgs/misc/cups/drivers/mfcl2700dnlpr/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, coreutils, dpkg, fetchurl, ghostscript, gnugrep, gnused, makeWrapper, perl, which }: +{ + lib, + stdenv, + coreutils, + dpkg, + fetchurl, + ghostscript, + gnugrep, + gnused, + makeWrapper, + perl, + which, +}: stdenv.mkDerivation rec { pname = "mfcl2700dnlpr"; @@ -9,7 +21,10 @@ stdenv.mkDerivation rec { sha256 = "170qdzxlqikzvv2wphvfb37m19mn13az4aj88md87ka3rl5knk4m"; }; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; dontUnpack = true; @@ -24,9 +39,15 @@ stdenv.mkDerivation rec { --replace "PRINTER =~" "PRINTER = \"MFCL2700DN\"; #" wrapProgram $dir/lpd/filter_MFCL2700DN \ - --prefix PATH : ${lib.makeBinPath [ - coreutils ghostscript gnugrep gnused which - ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + ghostscript + gnugrep + gnused + which + ] + } interpreter=$(cat $NIX_CC/nix-support/dynamic-linker) patchelf --set-interpreter "$interpreter" $dir/inf/braddprinter diff --git a/pkgs/misc/cups/drivers/samsung/1.00.37.nix b/pkgs/misc/cups/drivers/samsung/1.00.37.nix index 326106b3887839..4d0bb0e96a24e2 100644 --- a/pkgs/misc/cups/drivers/samsung/1.00.37.nix +++ b/pkgs/misc/cups/drivers/samsung/1.00.37.nix @@ -1,12 +1,18 @@ -{ lib, stdenv, fetchurl, cups, libusb-compat-0_1, libxml2 }: +{ + lib, + stdenv, + fetchurl, + cups, + libusb-compat-0_1, + libxml2, +}: let - arch = if stdenv.hostPlatform.system == "x86_64-linux" - then "x86_64" - else "i386"; + arch = if stdenv.hostPlatform.system == "x86_64-linux" then "x86_64" else "i386"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "samsung-unified-linux-driver"; version = "1.00.37"; diff --git a/pkgs/misc/cups/drivers/samsung/4.01.17.nix b/pkgs/misc/cups/drivers/samsung/4.01.17.nix index b822fa140bb03f..05bf9c263d1548 100644 --- a/pkgs/misc/cups/drivers/samsung/4.01.17.nix +++ b/pkgs/misc/cups/drivers/samsung/4.01.17.nix @@ -11,12 +11,13 @@ # } # (This advice was tested on the 1st November 2016.) -{ lib -, stdenv -, cups -, libusb-compat-0_1 -, fetchurl -, patchPpdFilesHook +{ + lib, + stdenv, + cups, + libusb-compat-0_1, + fetchurl, + patchPpdFilesHook, }: # Do not bump lightly! Visit @@ -24,8 +25,14 @@ let installationPath = if stdenv.hostPlatform.system == "x86_64-linux" then "x86_64" else "i386"; appendPath = lib.optionalString (stdenv.hostPlatform.system == "x86_64-linux") "64"; - libPath = lib.makeLibraryPath [ cups libusb-compat-0_1 ] + ":$out/lib:${lib.getLib stdenv.cc.cc}/lib${appendPath}"; -in stdenv.mkDerivation rec { + libPath = + lib.makeLibraryPath [ + cups + libusb-compat-0_1 + ] + + ":$out/lib:${lib.getLib stdenv.cc.cc}/lib${appendPath}"; +in +stdenv.mkDerivation rec { pname = "samsung-UnifiedLinuxDriver"; version = "4.01.17"; diff --git a/pkgs/misc/cups/filters.nix b/pkgs/misc/cups/filters.nix index e4f44dbf29476f..86792c45624415 100644 --- a/pkgs/misc/cups/filters.nix +++ b/pkgs/misc/cups/filters.nix @@ -1,104 +1,125 @@ -{ lib -, bc -, coreutils -, cups -, dbus -, dejavu_fonts -, fetchFromGitHub -, fontconfig -, gawk -, ghostscript -, gnugrep -, gnused -, ijs -, libcupsfilters -, libppd -, libexif -, libjpeg -, liblouis -, libpng -, makeWrapper -, autoreconfHook -, mupdf -, perl -, pkg-config -, poppler -, poppler_utils -, qpdf -, stdenv -, which -, withAvahi ? true +{ + lib, + bc, + coreutils, + cups, + dbus, + dejavu_fonts, + fetchFromGitHub, + fontconfig, + gawk, + ghostscript, + gnugrep, + gnused, + ijs, + libcupsfilters, + libppd, + libexif, + libjpeg, + liblouis, + libpng, + makeWrapper, + autoreconfHook, + mupdf, + perl, + pkg-config, + poppler, + poppler_utils, + qpdf, + stdenv, + which, + withAvahi ? true, }: -(if !withAvahi then lib.warn "the 'withAvahi' parameter to 'cups-filters' is deprecated, as the cups-browsed component (which does not make sense without avahi) has been split out of the cups-filters package (which no longer needs avahi)" else lib.id) +( + if !withAvahi then + lib.warn "the 'withAvahi' parameter to 'cups-filters' is deprecated, as the cups-browsed component (which does not make sense without avahi) has been split out of the cups-filters package (which no longer needs avahi)" + else + lib.id +) -(let - binPath = lib.makeBinPath [ bc coreutils gawk gnused gnugrep which ]; + ( + let + binPath = lib.makeBinPath [ + bc + coreutils + gawk + gnused + gnugrep + which + ]; -in -stdenv.mkDerivation rec { - pname = "cups-filters"; - version = "2.0.1"; + in + stdenv.mkDerivation rec { + pname = "cups-filters"; + version = "2.0.1"; - src = fetchFromGitHub { - owner = "OpenPrinting"; - repo = "cups-filters"; - rev = version; - hash = "sha256-bLOl64bdeZ10JLcQ7GbU+VffJu3Lzo0ves7O7GQIOWY="; - }; + src = fetchFromGitHub { + owner = "OpenPrinting"; + repo = "cups-filters"; + rev = version; + hash = "sha256-bLOl64bdeZ10JLcQ7GbU+VffJu3Lzo0ves7O7GQIOWY="; + }; - nativeBuildInputs = [ pkg-config makeWrapper autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + autoreconfHook + ]; - buildInputs = [ - cups - ghostscript - libcupsfilters - libppd - mupdf - ]; + buildInputs = [ + cups + ghostscript + libcupsfilters + libppd + mupdf + ]; - configureFlags = [ - "--with-mutool-path=${mupdf}/bin/mutool" - "--with-gs-path=${ghostscript}/bin/gs" - "--with-ippfind-path=${cups}/bin/ippfind" - "--with-shell=${stdenv.shell}" - "--localstatedir=/var" - "--sysconfdir=/etc" - ]; + configureFlags = [ + "--with-mutool-path=${mupdf}/bin/mutool" + "--with-gs-path=${ghostscript}/bin/gs" + "--with-ippfind-path=${cups}/bin/ippfind" + "--with-shell=${stdenv.shell}" + "--localstatedir=/var" + "--sysconfdir=/etc" + ]; - makeFlags = [ "CUPS_SERVERBIN=$(out)/lib/cups" "CUPS_DATADIR=$(out)/share/cups" "CUPS_SERVERROOT=$(out)/etc/cups" ]; + makeFlags = [ + "CUPS_SERVERBIN=$(out)/lib/cups" + "CUPS_DATADIR=$(out)/share/cups" + "CUPS_SERVERROOT=$(out)/etc/cups" + ]; - # https://github.com/OpenPrinting/cups-filters/issues/512 - env.NIX_CFLAGS_COMPILE = "-std=c++17"; + # https://github.com/OpenPrinting/cups-filters/issues/512 + env.NIX_CFLAGS_COMPILE = "-std=c++17"; - postConfigure = - '' - # Ensure that bannertopdf can find the PDF templates in - # $out. (By default, it assumes that cups and cups-filters are - # installed in the same prefix.) - substituteInPlace config.h --replace ${cups.out}/share/cups/data $out/share/cups/data + postConfigure = '' + # Ensure that bannertopdf can find the PDF templates in + # $out. (By default, it assumes that cups and cups-filters are + # installed in the same prefix.) + substituteInPlace config.h --replace ${cups.out}/share/cups/data $out/share/cups/data - # Ensure that gstoraster can find gs in $PATH. - substituteInPlace filter/gstoraster.c --replace execve execvpe + # Ensure that gstoraster can find gs in $PATH. + substituteInPlace filter/gstoraster.c --replace execve execvpe - # Patch shebangs of generated build scripts - patchShebangs filter - ''; + # Patch shebangs of generated build scripts + patchShebangs filter + ''; - postInstall = - '' - for i in $out/lib/cups/filter/*; do - wrapProgram "$i" --prefix PATH ':' ${binPath} - done - ''; + postInstall = '' + for i in $out/lib/cups/filter/*; do + wrapProgram "$i" --prefix PATH ':' ${binPath} + done + ''; - enableParallelBuilding = true; - doCheck = true; + enableParallelBuilding = true; + doCheck = true; - meta = { - homepage = "http://www.linuxfoundation.org/collaborate/workgroups/openprinting/cups-filters"; - description = "Backends, filters, and other software that was once part of the core CUPS distribution but is no longer maintained by Apple Inc"; - license = lib.licenses.gpl2Plus; - platforms = lib.platforms.linux; - }; -}) + meta = { + homepage = "http://www.linuxfoundation.org/collaborate/workgroups/openprinting/cups-filters"; + description = "Backends, filters, and other software that was once part of the core CUPS distribution but is no longer maintained by Apple Inc"; + license = lib.licenses.gpl2Plus; + platforms = lib.platforms.linux; + }; + } + ) diff --git a/pkgs/misc/documentation-highlighter/default.nix b/pkgs/misc/documentation-highlighter/default.nix index 3a7f5b21c69e9e..fb9ddb8589f371 100644 --- a/pkgs/misc/documentation-highlighter/default.nix +++ b/pkgs/misc/documentation-highlighter/default.nix @@ -1,22 +1,26 @@ { lib, runCommand }: -runCommand "documentation-highlighter" { - meta = { - description = "Highlight.js sources for the Nix Ecosystem's documentation"; - homepage = "https://highlightjs.org"; - license = lib.licenses.bsd3; - platforms = lib.platforms.all; - maintainers = [ lib.maintainers.grahamc ]; - }; - src = lib.sources.cleanSourceWith { - src = ./.; - filter = path: type: lib.elem (baseNameOf path) ([ - "highlight.pack.js" - "LICENSE" - "loader.js" - "mono-blue.css" - "README.md" - ]); - }; -} '' - cp -r "$src" "$out" -'' +runCommand "documentation-highlighter" + { + meta = { + description = "Highlight.js sources for the Nix Ecosystem's documentation"; + homepage = "https://highlightjs.org"; + license = lib.licenses.bsd3; + platforms = lib.platforms.all; + maintainers = [ lib.maintainers.grahamc ]; + }; + src = lib.sources.cleanSourceWith { + src = ./.; + filter = + path: type: + lib.elem (baseNameOf path) ([ + "highlight.pack.js" + "LICENSE" + "loader.js" + "mono-blue.css" + "README.md" + ]); + }; + } + '' + cp -r "$src" "$out" + '' diff --git a/pkgs/misc/drivers/epkowa/default.nix b/pkgs/misc/drivers/epkowa/default.nix index bb0e1eb7b6fd57..21ad1bbc8873cf 100644 --- a/pkgs/misc/drivers/epkowa/default.nix +++ b/pkgs/misc/drivers/epkowa/default.nix @@ -1,27 +1,30 @@ -{ lib, stdenv -, fetchurl -, fetchpatch -, makeWrapper -, symlinkJoin -, pkg-config -, libtool -, gtk2 -, libxml2 -, libxslt -, libusb-compat-0_1 -, sane-backends -, rpm -, cpio -, getopt -, autoPatchelfHook -, gcc +{ + lib, + stdenv, + fetchurl, + fetchpatch, + makeWrapper, + symlinkJoin, + pkg-config, + libtool, + gtk2, + libxml2, + libxslt, + libusb-compat-0_1, + sane-backends, + rpm, + cpio, + getopt, + autoPatchelfHook, + gcc, }: -let common_meta = { - homepage = "http://download.ebz.epson.net/dsc/search/01/search/?OSC=LX"; - sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; - license = with lib.licenses; epson; - platforms = with lib.platforms; linux; -}; +let + common_meta = { + homepage = "http://download.ebz.epson.net/dsc/search/01/search/?OSC=LX"; + sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; + license = with lib.licenses; epson; + platforms = with lib.platforms; linux; + }; in ############################ # @@ -30,412 +33,469 @@ in ############################ # adding a plugin for another printer shouldn't be too difficult, but you need the firmware to test... -let plugins = { - v330 = stdenv.mkDerivation rec { - name = "iscan-v330-bundle"; - version = "2.30.4"; - - src = fetchurl { - # To find new versions, visit - # http://download.ebz.epson.net/dsc/search/01/search/?OSC=LX and search for - # some printer like for instance "WF-7210" to get to the most recent - # version. - # NOTE: Don't forget to update the webarchive link too! - urls = [ - "https://download2.ebz.epson.net/iscan/plugin/perfection-v330/rpm/x64/iscan-perfection-v330-bundle-${version}.x64.rpm.tar.gz" - "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/perfection-v330/rpm/x64/iscan-perfection-v330-bundle-${version}.x64.rpm.tar.gz" +let + plugins = { + v330 = stdenv.mkDerivation rec { + name = "iscan-v330-bundle"; + version = "2.30.4"; + + src = fetchurl { + # To find new versions, visit + # http://download.ebz.epson.net/dsc/search/01/search/?OSC=LX and search for + # some printer like for instance "WF-7210" to get to the most recent + # version. + # NOTE: Don't forget to update the webarchive link too! + urls = [ + "https://download2.ebz.epson.net/iscan/plugin/perfection-v330/rpm/x64/iscan-perfection-v330-bundle-${version}.x64.rpm.tar.gz" + "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/perfection-v330/rpm/x64/iscan-perfection-v330-bundle-${version}.x64.rpm.tar.gz" + ]; + sha256 = "056c04pfsf98nnknphg28l489isqb6y4l2c8g7wqhclwgj7m338i"; + }; + + nativeBuildInputs = [ + autoPatchelfHook + rpm ]; - sha256 = "056c04pfsf98nnknphg28l489isqb6y4l2c8g7wqhclwgj7m338i"; - }; - - nativeBuildInputs = [ autoPatchelfHook rpm ]; - installPhase = '' - ${rpm}/bin/rpm2cpio plugins/esci-interpreter-perfection-v330-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - mkdir $out{,/share,/lib} - cp -r ./usr/share/{iscan-data,esci}/ $out/share/ - cp -r ./usr/lib64/esci $out/lib - ''; - - passthru = { - registrationCommand = '' - $registry --add interpreter usb 0x04b8 0x0142 "$plugin/lib/esci/libesci-interpreter-perfection-v330 $plugin/share/esci/esfwad.bin" + installPhase = '' + ${rpm}/bin/rpm2cpio plugins/esci-interpreter-perfection-v330-*.x86_64.rpm | ${cpio}/bin/cpio -idmv + mkdir $out{,/share,/lib} + cp -r ./usr/share/{iscan-data,esci}/ $out/share/ + cp -r ./usr/lib64/esci $out/lib ''; - hw = "Perfection V330 Photo"; - }; - meta = common_meta // { description = "Plugin to support " + passthru.hw + " scanner in sane"; }; - }; - v370 = stdenv.mkDerivation rec { - name = "iscan-v370-bundle"; - version = "2.30.4"; - src = fetchurl { - urls = [ - "https://download2.ebz.epson.net/iscan/plugin/perfection-v370/rpm/x64/iscan-perfection-v370-bundle-${version}.x64.rpm.tar.gz" - "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/perfection-v370/rpm/x64/iscan-perfection-v370-bundle-${version}.x64.rpm.tar.gz" - ]; - sha256 = "1ff7adp9mha1i2ibllz540xkagpy8r757h4s3h60bgxbyzv2yggr"; + passthru = { + registrationCommand = '' + $registry --add interpreter usb 0x04b8 0x0142 "$plugin/lib/esci/libesci-interpreter-perfection-v330 $plugin/share/esci/esfwad.bin" + ''; + hw = "Perfection V330 Photo"; + }; + meta = common_meta // { + description = "Plugin to support " + passthru.hw + " scanner in sane"; + }; }; + v370 = stdenv.mkDerivation rec { + name = "iscan-v370-bundle"; + version = "2.30.4"; + + src = fetchurl { + urls = [ + "https://download2.ebz.epson.net/iscan/plugin/perfection-v370/rpm/x64/iscan-perfection-v370-bundle-${version}.x64.rpm.tar.gz" + "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/perfection-v370/rpm/x64/iscan-perfection-v370-bundle-${version}.x64.rpm.tar.gz" + ]; + sha256 = "1ff7adp9mha1i2ibllz540xkagpy8r757h4s3h60bgxbyzv2yggr"; + }; + + nativeBuildInputs = [ + autoPatchelfHook + rpm + ]; - nativeBuildInputs = [ autoPatchelfHook rpm ]; - - installPhase = '' - cd plugins - ${rpm}/bin/rpm2cpio iscan-plugin-perfection-v370-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - + installPhase = '' + cd plugins + ${rpm}/bin/rpm2cpio iscan-plugin-perfection-v370-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - mkdir -p $out/share $out/lib - cp -r usr/share/{iscan-data,iscan}/ $out/share - cp -r usr/lib64/iscan $out/lib - mv $out/share/iscan $out/share/esci - mv $out/lib/iscan $out/lib/esci - ''; - passthru = { - registrationCommand = '' - $registry --add interpreter usb 0x04b8 0x014a "$plugin/lib/esci/libiscan-plugin-perfection-v370 $plugin/share/esci/esfwdd.bin" + mkdir -p $out/share $out/lib + cp -r usr/share/{iscan-data,iscan}/ $out/share + cp -r usr/lib64/iscan $out/lib + mv $out/share/iscan $out/share/esci + mv $out/lib/iscan $out/lib/esci ''; - hw = "Perfection V37/V370"; - }; - meta = common_meta // { description = "Plugin to support " + passthru.hw + " scanner in sane"; }; - }; - v550 = stdenv.mkDerivation rec { - pname = "iscan-perfection-v550-bundle"; - version = "2.30.4"; - nativeBuildInputs = [ autoPatchelfHook rpm ]; - src = fetchurl { - urls = [ - "https://download2.ebz.epson.net/iscan/plugin/perfection-v550/rpm/x64/iscan-perfection-v550-bundle-${version}.x64.rpm.tar.gz" - "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/perfection-v550/rpm/x64/iscan-perfection-v550-bundle-${version}.x64.rpm.tar.gz" - ]; - sha256 = "f8b3abf21354fc5b9bc87753cef950b6c0f07bf322a94aaff2c163bafcf50cd9"; - }; - installPhase = '' - cd plugins - ${rpm}/bin/rpm2cpio iscan-plugin-perfection-v550-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - mkdir $out - cp -r usr/share $out - cp -r usr/lib64 $out/lib - mv $out/share/iscan $out/share/esci - mv $out/lib/iscan $out/lib/esci - ''; - passthru = { - registrationCommand = '' - $registry --add interpreter usb 0x04b8 0x013b "$plugin/lib/esci/libiscan-plugin-perfection-v550 $plugin/share/esci/esfweb.bin" - ''; - hw = "Perfection V550 Photo"; + passthru = { + registrationCommand = '' + $registry --add interpreter usb 0x04b8 0x014a "$plugin/lib/esci/libiscan-plugin-perfection-v370 $plugin/share/esci/esfwdd.bin" + ''; + hw = "Perfection V37/V370"; + }; + meta = common_meta // { + description = "Plugin to support " + passthru.hw + " scanner in sane"; + }; }; - meta = common_meta // { description = "Plugin to support " + passthru.hw + " scanner in sane"; }; - }; - v600 = stdenv.mkDerivation rec { - pname = "iscan-gt-x820-bundle"; - version = "2.30.4"; + v550 = stdenv.mkDerivation rec { + pname = "iscan-perfection-v550-bundle"; + version = "2.30.4"; - nativeBuildInputs = [ autoPatchelfHook rpm ]; - src = fetchurl { - urls = [ - "https://download2.ebz.epson.net/iscan/plugin/gt-x820/rpm/x64/iscan-gt-x820-bundle-${version}.x64.rpm.tar.gz" - "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-x820/rpm/x64/iscan-gt-x820-bundle-${version}.x64.rpm.tar.gz" + nativeBuildInputs = [ + autoPatchelfHook + rpm ]; - sha256 = "1vlba7dsgpk35nn3n7is8nwds3yzlk38q43mppjzwsz2d2n7sr33"; - }; - installPhase = '' - cd plugins - ${rpm}/bin/rpm2cpio iscan-plugin-gt-x820-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - mkdir $out - cp -r usr/share $out - cp -r usr/lib64 $out/lib - mv $out/share/iscan $out/share/esci - mv $out/lib/iscan $out/lib/esci - ''; - passthru = { - registrationCommand = '' - $registry --add interpreter usb 0x04b8 0x013a "$plugin/lib/esci/libesintA1 $plugin/share/esci/esfwA1.bin" + src = fetchurl { + urls = [ + "https://download2.ebz.epson.net/iscan/plugin/perfection-v550/rpm/x64/iscan-perfection-v550-bundle-${version}.x64.rpm.tar.gz" + "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/perfection-v550/rpm/x64/iscan-perfection-v550-bundle-${version}.x64.rpm.tar.gz" + ]; + sha256 = "f8b3abf21354fc5b9bc87753cef950b6c0f07bf322a94aaff2c163bafcf50cd9"; + }; + installPhase = '' + cd plugins + ${rpm}/bin/rpm2cpio iscan-plugin-perfection-v550-*.x86_64.rpm | ${cpio}/bin/cpio -idmv + mkdir $out + cp -r usr/share $out + cp -r usr/lib64 $out/lib + mv $out/share/iscan $out/share/esci + mv $out/lib/iscan $out/lib/esci ''; - hw = "Perfection V600 Photo"; + passthru = { + registrationCommand = '' + $registry --add interpreter usb 0x04b8 0x013b "$plugin/lib/esci/libiscan-plugin-perfection-v550 $plugin/share/esci/esfweb.bin" + ''; + hw = "Perfection V550 Photo"; + }; + meta = common_meta // { + description = "Plugin to support " + passthru.hw + " scanner in sane"; + }; }; - meta = common_meta // { description = "iscan esci x820 plugin for " + passthru.hw; }; - }; - x770 = stdenv.mkDerivation rec { - pname = "iscan-gt-x770-bundle"; - version = "2.30.4"; + v600 = stdenv.mkDerivation rec { + pname = "iscan-gt-x820-bundle"; + version = "2.30.4"; - nativeBuildInputs = [ autoPatchelfHook rpm ]; - src = fetchurl { - urls = [ - "https://download2.ebz.epson.net/iscan/plugin/gt-x770/rpm/x64/iscan-gt-x770-bundle-${version}.x64.rpm.tar.gz" - "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-x770/rpm/x64/iscan-gt-x770-bundle-${version}.x64.rpm.tar.gz" + nativeBuildInputs = [ + autoPatchelfHook + rpm ]; - sha256 = "1chxdm6smv2d14pn2jl9xyd0vr42diy7vpskd3b9a61gf5h3gj03"; - }; - installPhase = '' - cd plugins - ${rpm}/bin/rpm2cpio iscan-plugin-gt-x770-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - mkdir $out - cp -r usr/share $out - cp -r usr/lib64 $out/lib - mv $out/share/iscan $out/share/esci - mv $out/lib/iscan $out/lib/esci - ''; - passthru = { - registrationCommand = '' - $registry --add interpreter usb 0x04b8 0x0130 "$plugin/lib/esci/libesint7C $plugin/share/esci/esfw7C.bin" + src = fetchurl { + urls = [ + "https://download2.ebz.epson.net/iscan/plugin/gt-x820/rpm/x64/iscan-gt-x820-bundle-${version}.x64.rpm.tar.gz" + "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-x820/rpm/x64/iscan-gt-x820-bundle-${version}.x64.rpm.tar.gz" + ]; + sha256 = "1vlba7dsgpk35nn3n7is8nwds3yzlk38q43mppjzwsz2d2n7sr33"; + }; + installPhase = '' + cd plugins + ${rpm}/bin/rpm2cpio iscan-plugin-gt-x820-*.x86_64.rpm | ${cpio}/bin/cpio -idmv + mkdir $out + cp -r usr/share $out + cp -r usr/lib64 $out/lib + mv $out/share/iscan $out/share/esci + mv $out/lib/iscan $out/lib/esci ''; - hw = "Perfection V500 Photo"; + passthru = { + registrationCommand = '' + $registry --add interpreter usb 0x04b8 0x013a "$plugin/lib/esci/libesintA1 $plugin/share/esci/esfwA1.bin" + ''; + hw = "Perfection V600 Photo"; + }; + meta = common_meta // { + description = "iscan esci x820 plugin for " + passthru.hw; + }; }; - meta = common_meta // { description = "iscan esci x770 plugin for " + passthru.hw; }; - }; - f720 = stdenv.mkDerivation rec { - pname = "iscan-gt-f720-bundle"; - version = "2.30.4"; + x770 = stdenv.mkDerivation rec { + pname = "iscan-gt-x770-bundle"; + version = "2.30.4"; - nativeBuildInputs = [ autoPatchelfHook ]; - buildInputs = [ gcc.cc.lib ]; - src = fetchurl { - urls = [ - "https://download2.ebz.epson.net/iscan/plugin/gt-f720/rpm/x64/iscan-gt-f720-bundle-${version}.x64.rpm.tar.gz" - "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-f720/rpm/x64/iscan-gt-f720-bundle-${version}.x64.rpm.tar.gz" + nativeBuildInputs = [ + autoPatchelfHook + rpm ]; - sha256 = "1xnbmb2rn610kqpg1x6k1cc13zlmx2f3l2xnj6809rnhg96qqn20"; - }; - installPhase = '' - cd plugins - ${rpm}/bin/rpm2cpio esci-interpreter-gt-f720-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - mkdir $out - cp -r usr/share $out - cp -r usr/lib64 $out/lib - ''; - - passthru = { - registrationCommand = '' - $registry --add interpreter usb 0x04b8 0x0131 "$plugin/lib/esci/libesci-interpreter-gt-f720 $plugin/share/esci/esfw8b.bin" + src = fetchurl { + urls = [ + "https://download2.ebz.epson.net/iscan/plugin/gt-x770/rpm/x64/iscan-gt-x770-bundle-${version}.x64.rpm.tar.gz" + "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-x770/rpm/x64/iscan-gt-x770-bundle-${version}.x64.rpm.tar.gz" + ]; + sha256 = "1chxdm6smv2d14pn2jl9xyd0vr42diy7vpskd3b9a61gf5h3gj03"; + }; + installPhase = '' + cd plugins + ${rpm}/bin/rpm2cpio iscan-plugin-gt-x770-*.x86_64.rpm | ${cpio}/bin/cpio -idmv + mkdir $out + cp -r usr/share $out + cp -r usr/lib64 $out/lib + mv $out/share/iscan $out/share/esci + mv $out/lib/iscan $out/lib/esci ''; - hw = "GT-F720, GT-S620, Perfection V30, Perfection V300 Photo"; + passthru = { + registrationCommand = '' + $registry --add interpreter usb 0x04b8 0x0130 "$plugin/lib/esci/libesint7C $plugin/share/esci/esfw7C.bin" + ''; + hw = "Perfection V500 Photo"; + }; + meta = common_meta // { + description = "iscan esci x770 plugin for " + passthru.hw; + }; }; + f720 = stdenv.mkDerivation rec { + pname = "iscan-gt-f720-bundle"; + version = "2.30.4"; + + nativeBuildInputs = [ autoPatchelfHook ]; + buildInputs = [ gcc.cc.lib ]; + src = fetchurl { + urls = [ + "https://download2.ebz.epson.net/iscan/plugin/gt-f720/rpm/x64/iscan-gt-f720-bundle-${version}.x64.rpm.tar.gz" + "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-f720/rpm/x64/iscan-gt-f720-bundle-${version}.x64.rpm.tar.gz" + ]; + sha256 = "1xnbmb2rn610kqpg1x6k1cc13zlmx2f3l2xnj6809rnhg96qqn20"; + }; + installPhase = '' + cd plugins + ${rpm}/bin/rpm2cpio esci-interpreter-gt-f720-*.x86_64.rpm | ${cpio}/bin/cpio -idmv + mkdir $out + cp -r usr/share $out + cp -r usr/lib64 $out/lib + ''; - meta = common_meta // { description = "iscan esci f720 plugin for " + passthru.hw; }; - }; - s80 = stdenv.mkDerivation rec { - pname = "iscan-gt-s80-bundle"; - version = "2.30.4"; + passthru = { + registrationCommand = '' + $registry --add interpreter usb 0x04b8 0x0131 "$plugin/lib/esci/libesci-interpreter-gt-f720 $plugin/share/esci/esfw8b.bin" + ''; + hw = "GT-F720, GT-S620, Perfection V30, Perfection V300 Photo"; + }; - nativeBuildInputs = [ autoPatchelfHook ]; - buildInputs = [ gcc.cc.lib libtool ]; - src = fetchurl { - urls = [ - "https://download2.ebz.epson.net/iscan/plugin/gt-s80/rpm/x64/iscan-gt-s80-bundle-${version}.x64.rpm.tar.gz" - "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-s80/rpm/x64/iscan-gt-s80-bundle-${version}.x64.rpm.tar.gz" - ]; - sha256 = "00qfdgs03k7bbs67zjrk8hbxvlyinsmk890amp9cmpfjfzdxgg58"; + meta = common_meta // { + description = "iscan esci f720 plugin for " + passthru.hw; + }; }; - installPhase = '' - cd plugins - ${rpm}/bin/rpm2cpio esci-interpreter-gt-s80-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - ${rpm}/bin/rpm2cpio iscan-plugin-esdip-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - mkdir $out - cp -r usr/share $out - cp -r usr/lib64 $out/lib - mkdir $out/share/esci - ''; - - passthru = { - registrationCommand = '' - $registry --add interpreter usb 0x04b8 0x0136 "$plugin/lib/esci/libesci-interpreter-gt-s80.so" - $registry --add interpreter usb 0x04b8 0x0137 "$plugin/lib/esci/libesci-interpreter-gt-s50.so" - $registry --add interpreter usb 0x04b8 0x0143 "$plugin/lib/esci/libesci-interpreter-gt-s50.so" - $registry --add interpreter usb 0x04b8 0x0144 "$plugin/lib/esci/libesci-interpreter-gt-s80.so" + s80 = stdenv.mkDerivation rec { + pname = "iscan-gt-s80-bundle"; + version = "2.30.4"; + + nativeBuildInputs = [ autoPatchelfHook ]; + buildInputs = [ + gcc.cc.lib + libtool + ]; + src = fetchurl { + urls = [ + "https://download2.ebz.epson.net/iscan/plugin/gt-s80/rpm/x64/iscan-gt-s80-bundle-${version}.x64.rpm.tar.gz" + "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-s80/rpm/x64/iscan-gt-s80-bundle-${version}.x64.rpm.tar.gz" + ]; + sha256 = "00qfdgs03k7bbs67zjrk8hbxvlyinsmk890amp9cmpfjfzdxgg58"; + }; + installPhase = '' + cd plugins + ${rpm}/bin/rpm2cpio esci-interpreter-gt-s80-*.x86_64.rpm | ${cpio}/bin/cpio -idmv + ${rpm}/bin/rpm2cpio iscan-plugin-esdip-*.x86_64.rpm | ${cpio}/bin/cpio -idmv + mkdir $out + cp -r usr/share $out + cp -r usr/lib64 $out/lib + mkdir $out/share/esci ''; - hw = "ES-D200, ED-D350, ES-D400, GT-S50, GT-S55, GT-S80, GT-S85"; + + passthru = { + registrationCommand = '' + $registry --add interpreter usb 0x04b8 0x0136 "$plugin/lib/esci/libesci-interpreter-gt-s80.so" + $registry --add interpreter usb 0x04b8 0x0137 "$plugin/lib/esci/libesci-interpreter-gt-s50.so" + $registry --add interpreter usb 0x04b8 0x0143 "$plugin/lib/esci/libesci-interpreter-gt-s50.so" + $registry --add interpreter usb 0x04b8 0x0144 "$plugin/lib/esci/libesci-interpreter-gt-s80.so" + ''; + hw = "ES-D200, ED-D350, ES-D400, GT-S50, GT-S55, GT-S80, GT-S85"; + }; + + meta = common_meta // { + description = "iscan esci s80 plugin for " + passthru.hw; + }; }; + s600 = stdenv.mkDerivation rec { + name = "iscan-gt-s600-bundle"; + version = "2.30.4"; + + src = fetchurl { + urls = [ + "https://download2.ebz.epson.net/iscan/plugin/gt-s600/rpm/x64/iscan-gt-s600-bundle-${version}.x64.rpm.tar.gz" + "https://web.archive.org/web/20240614120113/https://download2.ebz.epson.net/iscan/plugin/gt-s600/rpm/x64/iscan-gt-s600-bundle-${version}.x64.rpm.tar.gz" + ]; + sha256 = "fe1356b1d5c40bc5ac985a5693166efb9e5049a78b412f49c385eb503eadf2c6"; + }; + + nativeBuildInputs = [ + autoPatchelfHook + rpm + ]; - meta = common_meta // { description = "iscan esci s80 plugin for " + passthru.hw; }; - }; - s600 = stdenv.mkDerivation rec { - name = "iscan-gt-s600-bundle"; - version = "2.30.4"; + installPhase = '' + cd plugins + ${rpm}/bin/rpm2cpio iscan-plugin-gt-s600-*.x86_64.rpm | ${cpio}/bin/cpio -idmv + mkdir $out + cp -r usr/share $out + cp -r usr/lib64 $out/lib + mv $out/share/iscan $out/share/esci + mv $out/lib/iscan $out/lib/esci + ''; - src = fetchurl { - urls = [ - "https://download2.ebz.epson.net/iscan/plugin/gt-s600/rpm/x64/iscan-gt-s600-bundle-${version}.x64.rpm.tar.gz" - "https://web.archive.org/web/20240614120113/https://download2.ebz.epson.net/iscan/plugin/gt-s600/rpm/x64/iscan-gt-s600-bundle-${version}.x64.rpm.tar.gz" - ]; - sha256 = "fe1356b1d5c40bc5ac985a5693166efb9e5049a78b412f49c385eb503eadf2c6"; + passthru = { + registrationCommand = '' + $registry --add interpreter usb 0x04b8 0x012d "$plugin/lib/esci/libesint66 $plugin/share/esci/esfw66.bin" + ''; + hw = "GT-F650, GT-S600, Perfection V10, Perfection V100 Photo"; + }; + meta = common_meta // { + description = "iscan gt-s600 plugin for " + passthru.hw; + }; }; + s650 = stdenv.mkDerivation rec { + name = "iscan-gt-s650-bundle"; + version = "2.30.4"; + + src = fetchurl { + urls = [ + "https://download2.ebz.epson.net/iscan/plugin/gt-s650/rpm/x64/iscan-gt-s650-bundle-${version}.x64.rpm.tar.gz" + "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-s650/rpm/x64/iscan-gt-s650-bundle-${version}.x64.rpm.tar.gz" + ]; + sha256 = "0fn4lz4g0a8l301v6yv7fwl37wgwhz5y90nf681f655xxc91hqh7"; + }; + + nativeBuildInputs = [ + autoPatchelfHook + rpm + ]; - nativeBuildInputs = [ autoPatchelfHook rpm ]; - - installPhase = '' - cd plugins - ${rpm}/bin/rpm2cpio iscan-plugin-gt-s600-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - mkdir $out - cp -r usr/share $out - cp -r usr/lib64 $out/lib - mv $out/share/iscan $out/share/esci - mv $out/lib/iscan $out/lib/esci - ''; - - passthru = { - registrationCommand = '' - $registry --add interpreter usb 0x04b8 0x012d "$plugin/lib/esci/libesint66 $plugin/share/esci/esfw66.bin" + installPhase = '' + cd plugins + ${rpm}/bin/rpm2cpio iscan-plugin-gt-s650-*.x86_64.rpm | ${cpio}/bin/cpio -idmv + mkdir $out + cp -r usr/share $out + cp -r usr/lib64 $out/lib + mv $out/share/iscan $out/share/esci + mv $out/lib/iscan $out/lib/esci ''; - hw = "GT-F650, GT-S600, Perfection V10, Perfection V100 Photo"; - }; - meta = common_meta // { description = "iscan gt-s600 plugin for " + passthru.hw; }; - }; - s650 = stdenv.mkDerivation rec { - name = "iscan-gt-s650-bundle"; - version = "2.30.4"; - src = fetchurl { - urls = [ - "https://download2.ebz.epson.net/iscan/plugin/gt-s650/rpm/x64/iscan-gt-s650-bundle-${version}.x64.rpm.tar.gz" - "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-s650/rpm/x64/iscan-gt-s650-bundle-${version}.x64.rpm.tar.gz" - ]; - sha256 = "0fn4lz4g0a8l301v6yv7fwl37wgwhz5y90nf681f655xxc91hqh7"; + passthru = { + registrationCommand = '' + $registry --add interpreter usb 0x04b8 0x013c "$plugin/lib/esci/libiscan-plugin-gt-s650 $plugin/share/esci/esfw010c.bin" + $registry --add interpreter usb 0x04b8 0x013d "$plugin/lib/esci/libiscan-plugin-gt-s650 $plugin/share/esci/esfw010c.bin" + ''; + hw = "GT-S650, Perfection V19, Perfection V39"; + }; + meta = common_meta // { + description = "iscan GT-S650 for " + passthru.hw; + }; }; + x750 = stdenv.mkDerivation rec { + name = "iscan-gt-x750-bundle"; + version = "2.30.4"; + + src = fetchurl { + urls = [ + "https://download2.ebz.epson.net/iscan/plugin/gt-x750/rpm/x64/iscan-gt-x750-bundle-${version}.x64.rpm.tar.gz" + "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-x750/rpm/x64/iscan-gt-x750-bundle-${version}.x64.rpm.tar.gz" + ]; + sha256 = "sha256-9EeBHmh1nwSxnTnevPP8RZ4WBdyY+itR3VXo2I7f5N0="; + }; + + nativeBuildInputs = [ + autoPatchelfHook + rpm + ]; - nativeBuildInputs = [ autoPatchelfHook rpm ]; - - installPhase = '' - cd plugins - ${rpm}/bin/rpm2cpio iscan-plugin-gt-s650-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - mkdir $out - cp -r usr/share $out - cp -r usr/lib64 $out/lib - mv $out/share/iscan $out/share/esci - mv $out/lib/iscan $out/lib/esci - ''; - - passthru = { - registrationCommand = '' - $registry --add interpreter usb 0x04b8 0x013c "$plugin/lib/esci/libiscan-plugin-gt-s650 $plugin/share/esci/esfw010c.bin" - $registry --add interpreter usb 0x04b8 0x013d "$plugin/lib/esci/libiscan-plugin-gt-s650 $plugin/share/esci/esfw010c.bin" + installPhase = '' + cd plugins + ${rpm}/bin/rpm2cpio iscan-plugin-gt-x750-*.x86_64.rpm | ${cpio}/bin/cpio -idmv + mkdir $out + cp -r usr/share $out + cp -r usr/lib64 $out/lib + mv $out/share/iscan $out/share/esci + mv $out/lib/iscan $out/lib/esci ''; - hw = "GT-S650, Perfection V19, Perfection V39"; - }; - meta = common_meta // { description = "iscan GT-S650 for " + passthru.hw; }; - }; - x750 = stdenv.mkDerivation rec { - name = "iscan-gt-x750-bundle"; - version = "2.30.4"; - src = fetchurl { - urls = [ - "https://download2.ebz.epson.net/iscan/plugin/gt-x750/rpm/x64/iscan-gt-x750-bundle-${version}.x64.rpm.tar.gz" - "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-x750/rpm/x64/iscan-gt-x750-bundle-${version}.x64.rpm.tar.gz" - ]; - sha256 = "sha256-9EeBHmh1nwSxnTnevPP8RZ4WBdyY+itR3VXo2I7f5N0="; + passthru = { + registrationCommand = '' + $registry --add interpreter usb 0x04b8 0x0119 "$plugin/lib/esci/libesint54 $plugin/share/esci/esfw54.bin" + ''; + hw = "GT-X750, Perfection 4490"; + }; + meta = common_meta // { + description = "iscan GT-X750 for " + passthru.hw; + }; }; + gt1500 = stdenv.mkDerivation rec { + name = "iscan-gt-1500-bundle"; + version = "2.30.4"; + + src = fetchurl { + urls = [ + "https://download2.ebz.epson.net/iscan/plugin/gt-1500/rpm/x64/iscan-gt-1500-bundle-${version}.x64.rpm.tar.gz" + "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-1500/rpm/x64/iscan-gt-1500-bundle-${version}.x64.rpm.tar.gz" + ]; + sha256 = "sha256-1rVsbBsb+QtCOT1FsyhgvCbZIN6IeQH7rZXNmsD7cl8="; + }; + + nativeBuildInputs = [ + autoPatchelfHook + rpm + ]; - nativeBuildInputs = [ autoPatchelfHook rpm ]; - - installPhase = '' - cd plugins - ${rpm}/bin/rpm2cpio iscan-plugin-gt-x750-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - mkdir $out - cp -r usr/share $out - cp -r usr/lib64 $out/lib - mv $out/share/iscan $out/share/esci - mv $out/lib/iscan $out/lib/esci - ''; - - passthru = { - registrationCommand = '' - $registry --add interpreter usb 0x04b8 0x0119 "$plugin/lib/esci/libesint54 $plugin/share/esci/esfw54.bin" + installPhase = '' + cd plugins + ${rpm}/bin/rpm2cpio iscan-plugin-gt-1500-*.x86_64.rpm | ${cpio}/bin/cpio -idmv + mkdir $out + cp -r usr/share $out + cp -r usr/lib64 $out/lib + mv $out/share/iscan $out/share/esci + mv $out/lib/iscan $out/lib/esci ''; - hw = "GT-X750, Perfection 4490"; - }; - meta = common_meta // { description = "iscan GT-X750 for " + passthru.hw; }; - }; - gt1500 = stdenv.mkDerivation rec { - name = "iscan-gt-1500-bundle"; - version = "2.30.4"; - src = fetchurl { - urls = [ - "https://download2.ebz.epson.net/iscan/plugin/gt-1500/rpm/x64/iscan-gt-1500-bundle-${version}.x64.rpm.tar.gz" - "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/plugin/gt-1500/rpm/x64/iscan-gt-1500-bundle-${version}.x64.rpm.tar.gz" - ]; - sha256 = "sha256-1rVsbBsb+QtCOT1FsyhgvCbZIN6IeQH7rZXNmsD7cl8="; + passthru = { + registrationCommand = '' + $registry --add interpreter usb 0x04b8 0x0133 "$plugin/lib/esci/libesint86 $plugin/share/esci/esfw86.bin" + ''; + hw = "GT-1500"; + }; + meta = common_meta // { + description = "iscan GT-1500 for " + passthru.hw; + }; }; - - nativeBuildInputs = [ autoPatchelfHook rpm ]; - - installPhase = '' - cd plugins - ${rpm}/bin/rpm2cpio iscan-plugin-gt-1500-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - mkdir $out - cp -r usr/share $out - cp -r usr/lib64 $out/lib - mv $out/share/iscan $out/share/esci - mv $out/lib/iscan $out/lib/esci - ''; - - passthru = { - registrationCommand = '' - $registry --add interpreter usb 0x04b8 0x0133 "$plugin/lib/esci/libesint86 $plugin/share/esci/esfw86.bin" + network = stdenv.mkDerivation rec { + pname = "iscan-nt-bundle"; + # for the version, look for the driver of XP-750 in the search page + version = "2.30.4"; + + buildInputs = [ (lib.getLib stdenv.cc.cc) ]; + nativeBuildInputs = [ autoPatchelfHook ]; + + src = fetchurl { + urls = [ + "https://download2.ebz.epson.net/iscan/general/rpm/x64/iscan-bundle-${version}.x64.rpm.tar.gz" + "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/general/rpm/x64/iscan-bundle-${version}.x64.rpm.tar.gz" + ]; + sha256 = "0jssigsgkxb9i7qa7db291a1gbvwl795i4ahvb7bnqp33czkj85k"; + }; + installPhase = '' + cd plugins + ${rpm}/bin/rpm2cpio iscan-network-nt-*.x86_64.rpm | ${cpio}/bin/cpio -idmv + + mkdir $out + cp -r usr/share $out + cp -r usr/lib64 $out/lib + mkdir $out/share/esci ''; - hw = "GT-1500"; + passthru = { + registrationCommand = ""; + hw = "network"; + }; + + meta = common_meta // { + description = "iscan network plugin"; + }; }; - meta = common_meta // { description = "iscan GT-1500 for " + passthru.hw; }; }; - network = stdenv.mkDerivation rec { - pname = "iscan-nt-bundle"; - # for the version, look for the driver of XP-750 in the search page - version = "2.30.4"; - - buildInputs = [ (lib.getLib stdenv.cc.cc) ]; - nativeBuildInputs = [ autoPatchelfHook ]; +in +let + fwdir = symlinkJoin { + name = "esci-firmware-dir"; + paths = lib.mapAttrsToList (name: value: value + /share/esci) plugins; + }; +in +let + iscan-data = stdenv.mkDerivation rec { + pname = "iscan-data"; + version = "1.39.2-1"; src = fetchurl { urls = [ - "https://download2.ebz.epson.net/iscan/general/rpm/x64/iscan-bundle-${version}.x64.rpm.tar.gz" - "https://web.archive.org/web/https://download2.ebz.epson.net/iscan/general/rpm/x64/iscan-bundle-${version}.x64.rpm.tar.gz" + "http://support.epson.net/linux/src/scanner/iscan/iscan-data_${version}.tar.gz" + "https://web.archive.org/web/http://support.epson.net/linux/src/scanner/iscan/iscan-data_${version}.tar.gz" ]; - sha256 = "0jssigsgkxb9i7qa7db291a1gbvwl795i4ahvb7bnqp33czkj85k"; + sha256 = "092qhlnjjgz11ifx6mng7mz20i44gc0nlccrbmw18xr5hipbqqka"; }; - installPhase = '' - cd plugins - ${rpm}/bin/rpm2cpio iscan-network-nt-*.x86_64.rpm | ${cpio}/bin/cpio -idmv - - mkdir $out - cp -r usr/share $out - cp -r usr/lib64 $out/lib - mkdir $out/share/esci - ''; - passthru = { - registrationCommand = ""; - hw = "network"; - }; - - meta = common_meta // { description = "iscan network plugin"; }; - }; -}; -in -let fwdir = symlinkJoin { - name = "esci-firmware-dir"; - paths = lib.mapAttrsToList (name: value: value + /share/esci) plugins; -}; -in -let iscan-data = stdenv.mkDerivation rec { - pname = "iscan-data"; - version = "1.39.2-1"; - src = fetchurl { - urls = [ - "http://support.epson.net/linux/src/scanner/iscan/iscan-data_${version}.tar.gz" - "https://web.archive.org/web/http://support.epson.net/linux/src/scanner/iscan/iscan-data_${version}.tar.gz" + buildInputs = [ + libxslt ]; - sha256 = "092qhlnjjgz11ifx6mng7mz20i44gc0nlccrbmw18xr5hipbqqka"; - }; - - buildInputs = [ - libxslt - ]; - meta = common_meta; -}; + meta = common_meta; + }; in stdenv.mkDerivation rec { pname = "iscan"; @@ -449,7 +509,11 @@ stdenv.mkDerivation rec { sha256 = "1ma76jj0k3bz0fy06fiyl4di4y77rcryb0mwjmzs5ms2vq9rjysr"; }; - nativeBuildInputs = [ pkg-config libtool makeWrapper ]; + nativeBuildInputs = [ + pkg-config + libtool + makeWrapper + ]; buildInputs = [ gtk2 libxml2 @@ -473,7 +537,10 @@ stdenv.mkDerivation rec { ]; patchFlags = [ "-p0" ]; - configureFlags = [ "--enable-dependency-reduction" "--disable-frontend" ]; + configureFlags = [ + "--enable-dependency-reduction" + "--disable-frontend" + ]; postConfigure = '' echo '#define NIX_ESCI_PREFIX "'${fwdir}'"' >> config.h @@ -487,24 +554,29 @@ stdenv.mkDerivation rec { mkdir -p $out/lib/iscan ln -s ${plugins.network}/lib/iscan/network $out/lib/iscan/network ''; - postFixup = '' - # iscan-registry is a shell script requiring getopt - wrapProgram $out/bin/iscan-registry --prefix PATH : ${getopt}/bin - registry=$out/bin/iscan-registry; - '' + - lib.concatStrings (lib.mapAttrsToList - (name: value: '' - plugin=${value}; - ${value.passthru.registrationCommand} - '') - plugins); + postFixup = + '' + # iscan-registry is a shell script requiring getopt + wrapProgram $out/bin/iscan-registry --prefix PATH : ${getopt}/bin + registry=$out/bin/iscan-registry; + '' + + lib.concatStrings ( + lib.mapAttrsToList (name: value: '' + plugin=${value}; + ${value.passthru.registrationCommand} + '') plugins + ); meta = common_meta // { description = "sane-epkowa backend for some epson scanners"; - longDescription = '' - Includes gui-less iscan (aka. Image Scan! for Linux). - Supported hardware: at least : - '' + - lib.concatStringsSep ", " (lib.mapAttrsToList (name: value: value.passthru.hw) plugins); - maintainers = with lib.maintainers; [ symphorien dominikh ]; + longDescription = + '' + Includes gui-less iscan (aka. Image Scan! for Linux). + Supported hardware: at least : + '' + + lib.concatStringsSep ", " (lib.mapAttrsToList (name: value: value.passthru.hw) plugins); + maintainers = with lib.maintainers; [ + symphorien + dominikh + ]; }; } diff --git a/pkgs/misc/drivers/epsonscan2/default.nix b/pkgs/misc/drivers/epsonscan2/default.nix index 6ee092b12e15b7..a13f4da4daec0d 100644 --- a/pkgs/misc/drivers/epsonscan2/default.nix +++ b/pkgs/misc/drivers/epsonscan2/default.nix @@ -1,24 +1,25 @@ -{ lib -, stdenv -, autoPatchelfHook -, boost -, cmake -, copyDesktopItems -, imagemagick -, fetchpatch -, fetchzip -, killall -, libjpeg -, libpng -, libtiff -, libtool -, libusb1 -, makeDesktopItem -, qtbase -, wrapQtAppsHook - -, withGui ? true -, withNonFreePlugins ? false +{ + lib, + stdenv, + autoPatchelfHook, + boost, + cmake, + copyDesktopItems, + imagemagick, + fetchpatch, + fetchzip, + killall, + libjpeg, + libpng, + libtiff, + libtool, + libusb1, + makeDesktopItem, + qtbase, + wrapQtAppsHook, + + withGui ? true, + withNonFreePlugins ? false, }: let @@ -32,19 +33,21 @@ let url = "https://download3.ebz.epson.net/dsc/f/03/00/15/17/69/0ef02802c476a6564f13cac929859c394f40326a/epsonscan2-6.7.63.0-1.src.tar.gz"; hash = "sha256-ZLnbIk0I7g6ext5anPD+/lD4qNlk6f2fL0xdIWLcfbY="; }; - bundle = { - "i686-linux" = fetchzip { - name = "${pname}-bundle"; - url = "https://download3.ebz.epson.net/dsc/f/03/00/15/17/67/ceae6a02aaa81cb61012899987fbb5ab891b6ab2/epsonscan2-bundle-6.7.63.0.i686.deb.tar.gz"; - hash = "sha256-h9beAzNdjOhTlZqW0rJbSQXGOpvFRGvTcWw0ZtOqiYY="; - }; - - "x86_64-linux" = fetchzip { - name = "${pname}-bundle"; - url = "https://download3.ebz.epson.net/dsc/f/03/00/15/17/68/050e5a55ed90f4efb4ca3bdd34e5797b149443ca/epsonscan2-bundle-6.7.63.0.x86_64.deb.tar.gz"; - hash = "sha256-+S17FfS2h4zZCvE6W+yZvdJb6+OWYTt0ZWCA+pe1NZc="; - }; - }."${system}" or (throw "Unsupported system: ${system}"); + bundle = + { + "i686-linux" = fetchzip { + name = "${pname}-bundle"; + url = "https://download3.ebz.epson.net/dsc/f/03/00/15/17/67/ceae6a02aaa81cb61012899987fbb5ab891b6ab2/epsonscan2-bundle-6.7.63.0.i686.deb.tar.gz"; + hash = "sha256-h9beAzNdjOhTlZqW0rJbSQXGOpvFRGvTcWw0ZtOqiYY="; + }; + + "x86_64-linux" = fetchzip { + name = "${pname}-bundle"; + url = "https://download3.ebz.epson.net/dsc/f/03/00/15/17/68/050e5a55ed90f4efb4ca3bdd34e5797b149443ca/epsonscan2-bundle-6.7.63.0.x86_64.deb.tar.gz"; + hash = "sha256-+S17FfS2h4zZCvE6W+yZvdJb6+OWYTt0ZWCA+pe1NZc="; + }; + } + ."${system}" or (throw "Unsupported system: ${system}"); in stdenv.mkDerivation { @@ -74,53 +77,64 @@ stdenv.mkDerivation { --replace '@OCR_ENGINE_GETROTATE@' $out/libexec/epsonscan2-ocr/ocr-engine-getrotate ''; - nativeBuildInputs = [ - cmake - ] ++ lib.optionals withGui [ - imagemagick # to make icons - wrapQtAppsHook - ] ++ lib.optionals withNonFreePlugins [ - autoPatchelfHook - ]; - - buildInputs = [ - boost - libjpeg - libpng - libtiff - libusb1 - ] ++ lib.optionals withGui [ - copyDesktopItems - qtbase - ] ++ lib.optionals withNonFreePlugins [ - libtool.lib - ]; - - cmakeFlags = [ - # The non-free (Debian) packages uses this directory structure so do the same when compiling - # from source so we can easily merge them. - "-DCMAKE_INSTALL_LIBDIR=lib/${system}-gnu" - ] ++ lib.optionals (!withGui) [ - "-DNO_GUI=ON" - ]; - - postInstall = '' - # But when we put all the libraries in lib/${system}-gnu, then SANE can't find the - # required libraries so create a symlink to where it expects them to be. - mkdir -p $out/lib/sane - for file in $out/lib/${system}-gnu/sane/*.so.*; do - ln -s $file $out/lib/sane/ - done - '' + lib.optionalString withGui '' - # The icon file extension is .ico but it's actually a png! - mkdir -p $out/share/icons/hicolor/{48x48,128x128}/apps - convert $src/Resources/Icons/escan2_app.ico -resize 48x48 $out/share/icons/hicolor/48x48/apps/epsonscan2.png - convert $src/Resources/Icons/escan2_app.ico -resize 128x128 $out/share/icons/hicolor/128x128/apps/epsonscan2.png - '' + lib.optionalString withNonFreePlugins '' - ar xf ${bundle}/plugins/epsonscan2-non-free-plugin_*.deb - tar Jxf data.tar.xz - cp -r usr/* $out - ''; + nativeBuildInputs = + [ + cmake + ] + ++ lib.optionals withGui [ + imagemagick # to make icons + wrapQtAppsHook + ] + ++ lib.optionals withNonFreePlugins [ + autoPatchelfHook + ]; + + buildInputs = + [ + boost + libjpeg + libpng + libtiff + libusb1 + ] + ++ lib.optionals withGui [ + copyDesktopItems + qtbase + ] + ++ lib.optionals withNonFreePlugins [ + libtool.lib + ]; + + cmakeFlags = + [ + # The non-free (Debian) packages uses this directory structure so do the same when compiling + # from source so we can easily merge them. + "-DCMAKE_INSTALL_LIBDIR=lib/${system}-gnu" + ] + ++ lib.optionals (!withGui) [ + "-DNO_GUI=ON" + ]; + + postInstall = + '' + # But when we put all the libraries in lib/${system}-gnu, then SANE can't find the + # required libraries so create a symlink to where it expects them to be. + mkdir -p $out/lib/sane + for file in $out/lib/${system}-gnu/sane/*.so.*; do + ln -s $file $out/lib/sane/ + done + '' + + lib.optionalString withGui '' + # The icon file extension is .ico but it's actually a png! + mkdir -p $out/share/icons/hicolor/{48x48,128x128}/apps + convert $src/Resources/Icons/escan2_app.ico -resize 48x48 $out/share/icons/hicolor/48x48/apps/epsonscan2.png + convert $src/Resources/Icons/escan2_app.ico -resize 128x128 $out/share/icons/hicolor/128x128/apps/epsonscan2.png + '' + + lib.optionalString withNonFreePlugins '' + ar xf ${bundle}/plugins/epsonscan2-non-free-plugin_*.deb + tar Jxf data.tar.xz + cp -r usr/* $out + ''; desktopItems = lib.optionals withGui [ (makeDesktopItem { @@ -130,7 +144,10 @@ stdenv.mkDerivation { desktopName = "Epson Scan 2"; genericName = "Epson Scan 2"; comment = description; - categories = [ "Graphics" "Scanning" ]; + categories = [ + "Graphics" + "Scanning" + ]; }) ]; @@ -153,10 +170,14 @@ stdenv.mkDerivation { ''; homepage = "https://support.epson.net/linux/en/epsonscan2.php"; - platforms = [ "i686-linux" "x86_64-linux" ]; - sourceProvenance = with lib.sourceTypes; [ fromSource ] ++ lib.optionals withNonFreePlugins [ binaryNativeCode ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; + sourceProvenance = + with lib.sourceTypes; + [ fromSource ] ++ lib.optionals withNonFreePlugins [ binaryNativeCode ]; license = with lib.licenses; if withNonFreePlugins then unfree else lgpl21Plus; maintainers = with lib.maintainers; [ james-atkins ]; }; } - diff --git a/pkgs/misc/drivers/gutenprint/bin.nix b/pkgs/misc/drivers/gutenprint/bin.nix index 4b74b191e7f0ff..66cf34baa2aaa5 100644 --- a/pkgs/misc/drivers/gutenprint/bin.nix +++ b/pkgs/misc/drivers/gutenprint/bin.nix @@ -1,45 +1,62 @@ -{ lib, stdenv, fetchurl, rpm, cpio, zlib }: - -/* usage: (sorry, its still impure but works!) - -impure directory: -mkdir /opt/gutenprint; sudo cp -r $(nix-build -A gutenprintBin -f $NIXPGS_ALL) /opt/gutenprint - -add the following lines to bindirCmds property of printing/cupsd.nix: - - ln -s ${pkgs.gutenprintBin}/lib/cups/backend/* $out/lib/cups/backend/ - ln -s ${pkgs.gutenprintBin}/lib/cups/filter/* $out/lib/cups/filter/ - mkdir -p $out/lib/cups/model - cat ${pkgs.gutenprintBin}/ppds/Canon/Canon-PIXMA_iP4000-gutenprint.5.0.sim-en.ppd.gz |gunzip > $out/lib/cups/model/Canon-PIXMA_iP4000-gutenprint.5.0.sim-en.ppd - sed -i 's@/opt/gutenprint/cups@${pkgs.gutenprintBin}/cups@' $out/lib/cups/model/Canon-PIXMA_iP4000-gutenprint.5.0.sim-en.ppd - -Then rebuild your system and add your printer using the the localhost:603 cups web interface -select the extracted .ppd file which can be found in the model directory of -sed -n 's/^ServerBin //p' $(sed -n 's/respawn.*-c \(.*''\) -F.*''/\1/p' /etc/event.d/cupsd) -(sorry, cups still doesn't see it. You could copy it into /nix/store/ -*-cups/lib/cups/model/ and you would be able to select canon -> PIXMA 4000 -then. I've tried that. - -TODO tidy this all up. Find source instead of binary. Fix paths ... Find out how to check ink levels etc - +{ + lib, + stdenv, + fetchurl, + rpm, + cpio, + zlib, +}: + +/* + usage: (sorry, its still impure but works!) + + impure directory: + mkdir /opt/gutenprint; sudo cp -r $(nix-build -A gutenprintBin -f $NIXPGS_ALL) /opt/gutenprint + + add the following lines to bindirCmds property of printing/cupsd.nix: + + ln -s ${pkgs.gutenprintBin}/lib/cups/backend/* $out/lib/cups/backend/ + ln -s ${pkgs.gutenprintBin}/lib/cups/filter/* $out/lib/cups/filter/ + mkdir -p $out/lib/cups/model + cat ${pkgs.gutenprintBin}/ppds/Canon/Canon-PIXMA_iP4000-gutenprint.5.0.sim-en.ppd.gz |gunzip > $out/lib/cups/model/Canon-PIXMA_iP4000-gutenprint.5.0.sim-en.ppd + sed -i 's@/opt/gutenprint/cups@${pkgs.gutenprintBin}/cups@' $out/lib/cups/model/Canon-PIXMA_iP4000-gutenprint.5.0.sim-en.ppd + + Then rebuild your system and add your printer using the the localhost:603 cups web interface + select the extracted .ppd file which can be found in the model directory of + sed -n 's/^ServerBin //p' $(sed -n 's/respawn.*-c \(.*''\) -F.*''/\1/p' /etc/event.d/cupsd) + (sorry, cups still doesn't see it. You could copy it into /nix/store/ + *-cups/lib/cups/model/ and you would be able to select canon -> PIXMA 4000 + then. I've tried that. + + TODO tidy this all up. Find source instead of binary. Fix paths ... Find out how to check ink levels etc */ stdenv.mkDerivation { pname = "cups-gutenprint-binary"; version = "5.0.1"; - src = if stdenv.hostPlatform.system == "x86_64-linux" then fetchurl { - url = "https://www.openprinting.org/download/printdriver/debian/dists/lsb3.1/main/binary-amd64/gutenprint_5.0.1-1lsb3.1_amd64.deb"; - sha256 = "0an5gba6r6v54r53s2gj2fjk8fzpl4lrksjas2333528b0k8gbbc"; - } else throw "TODO"; # get from openprint.com -> drivers -> gutenprint + src = + if stdenv.hostPlatform.system == "x86_64-linux" then + fetchurl { + url = "https://www.openprinting.org/download/printdriver/debian/dists/lsb3.1/main/binary-amd64/gutenprint_5.0.1-1lsb3.1_amd64.deb"; + sha256 = "0an5gba6r6v54r53s2gj2fjk8fzpl4lrksjas2333528b0k8gbbc"; + } + else + throw "TODO"; # get from openprint.com -> drivers -> gutenprint - buildInputs = [ rpm cpio ]; + buildInputs = [ + rpm + cpio + ]; dontUnpack = true; dontInstall = true; dontFixup = true; - libPath = lib.makeLibraryPath [ stdenv.cc.cc zlib ]; + libPath = lib.makeLibraryPath [ + stdenv.cc.cc + zlib + ]; buildPhase = '' ar -x $src data.tar.gz diff --git a/pkgs/misc/drivers/gutenprint/default.nix b/pkgs/misc/drivers/gutenprint/default.nix index e2d5b8ec6a82bd..56b628ad905461 100644 --- a/pkgs/misc/drivers/gutenprint/default.nix +++ b/pkgs/misc/drivers/gutenprint/default.nix @@ -1,8 +1,18 @@ # this package was called gimp-print in the past -{ stdenv, lib, fetchurl, makeWrapper, pkg-config -, ijs, zlib -, gimp2Support ? false, gimp -, cupsSupport ? true, cups, libusb1, perl +{ + stdenv, + lib, + fetchurl, + makeWrapper, + pkg-config, + ijs, + zlib, + gimp2Support ? false, + gimp, + cupsSupport ? true, + cups, + libusb1, + perl, }: stdenv.mkDerivation rec { @@ -15,12 +25,29 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ makeWrapper pkg-config ] - ++ lib.optionals cupsSupport [ cups perl ]; # for cups-config + nativeBuildInputs = + [ + makeWrapper + pkg-config + ] + ++ lib.optionals cupsSupport [ + cups + perl + ]; # for cups-config buildInputs = - [ ijs zlib ] - ++ lib.optionals gimp2Support [ gimp.gtk gimp ] - ++ lib.optionals cupsSupport [ cups libusb1 perl ]; + [ + ijs + zlib + ] + ++ lib.optionals gimp2Support [ + gimp.gtk + gimp + ] + ++ lib.optionals cupsSupport [ + cups + libusb1 + perl + ]; configureFlags = lib.optionals cupsSupport [ "--disable-static-genppd" # should be harmless on NixOS @@ -28,17 +55,19 @@ stdenv.mkDerivation rec { # FIXME: hacky because we modify generated configure, but I haven't found a better way. # makeFlags doesn't change this everywhere (e.g. in cups-genppdupdate). - preConfigure = lib.optionalString cupsSupport '' - sed -i \ - -e "s,cups_conf_datadir=.*,cups_conf_datadir=\"$out/share/cups\",g" \ - -e "s,cups_conf_serverbin=.*,cups_conf_serverbin=\"$out/lib/cups\",g" \ - -e "s,cups_conf_serverroot=.*,cups_conf_serverroot=\"$out/etc/cups\",g" \ - configure - '' + lib.optionalString gimp2Support '' - sed -i \ - -e "s,gimp2_plug_indir=.*,gimp2_plug_indir=\"$out/lib/gimp/${gimp.majorVersion}\",g" \ - configure - ''; + preConfigure = + lib.optionalString cupsSupport '' + sed -i \ + -e "s,cups_conf_datadir=.*,cups_conf_datadir=\"$out/share/cups\",g" \ + -e "s,cups_conf_serverbin=.*,cups_conf_serverbin=\"$out/lib/cups\",g" \ + -e "s,cups_conf_serverroot=.*,cups_conf_serverroot=\"$out/etc/cups\",g" \ + configure + '' + + lib.optionalString gimp2Support '' + sed -i \ + -e "s,gimp2_plug_indir=.*,gimp2_plug_indir=\"$out/lib/gimp/${gimp.majorVersion}\",g" \ + configure + ''; enableParallelBuilding = true; diff --git a/pkgs/misc/drivers/sc-controller/default.nix b/pkgs/misc/drivers/sc-controller/default.nix index 41614b27711c46..2694d914740270 100644 --- a/pkgs/misc/drivers/sc-controller/default.nix +++ b/pkgs/misc/drivers/sc-controller/default.nix @@ -1,9 +1,24 @@ -{ lib, buildPythonApplication, fetchFromGitHub, wrapGAppsHook3 -, pytestCheckHook -, gtk3, gobject-introspection, libappindicator-gtk3, librsvg -, evdev, pygobject3, pylibacl, bluez, vdf -, linuxHeaders -, libX11, libXext, libXfixes, libusb1, udev +{ + lib, + buildPythonApplication, + fetchFromGitHub, + wrapGAppsHook3, + pytestCheckHook, + gtk3, + gobject-introspection, + libappindicator-gtk3, + librsvg, + evdev, + pygobject3, + pylibacl, + bluez, + vdf, + linuxHeaders, + libX11, + libXext, + libXfixes, + libusb1, + udev, }: buildPythonApplication rec { @@ -17,11 +32,23 @@ buildPythonApplication rec { hash = "sha256-XakbCuwjIAXYFZxvJsAlDIJEl09pwFPT12h04onXd34="; }; - nativeBuildInputs = [ wrapGAppsHook3 gobject-introspection ]; + nativeBuildInputs = [ + wrapGAppsHook3 + gobject-introspection + ]; - buildInputs = [ gtk3 libappindicator-gtk3 librsvg ]; + buildInputs = [ + gtk3 + libappindicator-gtk3 + librsvg + ]; - propagatedBuildInputs = [ evdev pygobject3 pylibacl vdf ]; + propagatedBuildInputs = [ + evdev + pygobject3 + pylibacl + vdf + ]; nativeCheckInputs = [ pytestCheckHook ]; @@ -31,7 +58,14 @@ buildPythonApplication rec { substituteInPlace scc/device_monitor.py --replace "find_library('bluetooth')" "'libbluetooth.so.3'" ''; - LD_LIBRARY_PATH = lib.makeLibraryPath [ libX11 libXext libXfixes libusb1 udev bluez ]; + LD_LIBRARY_PATH = lib.makeLibraryPath [ + libX11 + libXext + libXfixes + libusb1 + udev + bluez + ]; preFixup = '' gappsWrapperArgs+=(--prefix LD_LIBRARY_PATH : "$LD_LIBRARY_PATH") @@ -47,11 +81,14 @@ buildPythonApplication rec { ''; meta = with lib; { - homepage = "https://github.com/C0rn3j/sc-controller"; + homepage = "https://github.com/C0rn3j/sc-controller"; # donations: https://www.patreon.com/kozec description = "User-mode driver and GUI for Steam Controller and other controllers"; - license = licenses.gpl2Only; - platforms = platforms.linux; - maintainers = with maintainers; [ orivej rnhmjoj ]; + license = licenses.gpl2Only; + platforms = platforms.linux; + maintainers = with maintainers; [ + orivej + rnhmjoj + ]; }; } diff --git a/pkgs/misc/drivers/utsushi/default.nix b/pkgs/misc/drivers/utsushi/default.nix index 1642e91bb109c9..65b9c3e2678ad6 100644 --- a/pkgs/misc/drivers/utsushi/default.nix +++ b/pkgs/misc/drivers/utsushi/default.nix @@ -1,10 +1,24 @@ -{ lib, stdenv, writeScriptBin, fetchpatch, fetchFromGitLab, autoreconfHook, pkg-config -, autoconf-archive, libxslt, boost, gtkmm2, imagemagick, sane-backends -, tesseract4, udev, libusb1 -, withNetworkScan ? false, utsushi-networkscan +{ + lib, + stdenv, + writeScriptBin, + fetchpatch, + fetchFromGitLab, + autoreconfHook, + pkg-config, + autoconf-archive, + libxslt, + boost, + gtkmm2, + imagemagick, + sane-backends, + tesseract4, + udev, + libusb1, + withNetworkScan ? false, + utsushi-networkscan, }: - let fakegit = writeScriptBin "git" '' #! ${stdenv.shell} -e @@ -13,7 +27,8 @@ let fi ''; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "imagescan"; version = "3.65.0"; @@ -66,7 +81,6 @@ in stdenv.mkDerivation rec { "-Wno-error=unused-variable" ]; - postPatch = '' # create fake udev and sane config mkdir -p $out/etc/{sane.d,udev/rules.d} @@ -174,7 +188,10 @@ in stdenv.mkDerivation rec { ''; homepage = "https://gitlab.com/utsushi/imagescan"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ wucke13 maxwilson ]; + maintainers = with maintainers; [ + wucke13 + maxwilson + ]; platforms = platforms.linux; }; } diff --git a/pkgs/misc/drivers/utsushi/networkscan.nix b/pkgs/misc/drivers/utsushi/networkscan.nix index b9aa1cbe904f4d..7f339c15e404dc 100644 --- a/pkgs/misc/drivers/utsushi/networkscan.nix +++ b/pkgs/misc/drivers/utsushi/networkscan.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, rpmextract }: +{ + lib, + stdenv, + fetchurl, + rpmextract, +}: stdenv.mkDerivation rec { pname = "imagescan-plugin-networkscan"; diff --git a/pkgs/misc/jackaudio/default.nix b/pkgs/misc/jackaudio/default.nix index 53087942b93382..ea9700f1c3038b 100644 --- a/pkgs/misc/jackaudio/default.nix +++ b/pkgs/misc/jackaudio/default.nix @@ -1,22 +1,40 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch2, pkg-config, python3Packages, makeWrapper -, libsamplerate, libsndfile, readline, eigen, celt -, wafHook -# Darwin Dependencies -, aften, AudioUnit, CoreAudio, libobjc, Accelerate - -# Optional Dependencies -, dbus ? null, libffado ? null, alsa-lib ? null -, libopus ? null - -# Extra options -, prefix ? "" - -, testers +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch2, + pkg-config, + python3Packages, + makeWrapper, + libsamplerate, + libsndfile, + readline, + eigen, + celt, + wafHook, + # Darwin Dependencies + aften, + AudioUnit, + CoreAudio, + libobjc, + Accelerate, + + # Optional Dependencies + dbus ? null, + libffado ? null, + alsa-lib ? null, + libopus ? null, + + # Extra options + prefix ? "", + + testers, }: let inherit (python3Packages) python dbus-python; - shouldUsePkg = pkg: if pkg != null && lib.meta.availableOn stdenv.hostPlatform pkg then pkg else null; + shouldUsePkg = + pkg: if pkg != null && lib.meta.availableOn stdenv.hostPlatform pkg then pkg else null; libOnly = prefix == "lib"; @@ -37,16 +55,37 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "sha256-Cslfys5fcZDy0oee9/nM5Bd1+Cg4s/ayXjJJOSQCL4E="; }; - outputs = [ "out" "dev" ]; - - nativeBuildInputs = [ pkg-config python wafHook ] - ++ lib.optionals (optDbus != null) [ makeWrapper ]; - buildInputs = [ libsamplerate libsndfile readline eigen celt - optDbus optPythonDBus optLibffado optAlsaLib optLibopus - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - aften AudioUnit CoreAudio Accelerate libobjc + outputs = [ + "out" + "dev" ]; + nativeBuildInputs = [ + pkg-config + python + wafHook + ] ++ lib.optionals (optDbus != null) [ makeWrapper ]; + buildInputs = + [ + libsamplerate + libsndfile + readline + eigen + celt + optDbus + optPythonDBus + optLibffado + optAlsaLib + optLibopus + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + aften + AudioUnit + CoreAudio + Accelerate + libobjc + ]; + patches = [ (fetchpatch2 { # Python 3.12 support @@ -60,19 +99,26 @@ stdenv.mkDerivation (finalAttrs: { patchShebangs --build svnversion_regenerate.sh ''; - wafConfigureFlags = [ - "--classic" - "--autostart=${if (optDbus != null) then "dbus" else "classic"}" - ] ++ lib.optional (optDbus != null) "--dbus" + wafConfigureFlags = + [ + "--classic" + "--autostart=${if (optDbus != null) then "dbus" else "classic"}" + ] + ++ lib.optional (optDbus != null) "--dbus" ++ lib.optional (optLibffado != null) "--firewire" ++ lib.optional (optAlsaLib != null) "--alsa"; - postInstall = (if libOnly then '' - rm -rf $out/{bin,share} - rm -rf $out/lib/{jack,libjacknet*,libjackserver*} - '' else lib.optionalString (optDbus != null) '' - wrapProgram $out/bin/jack_control --set PYTHONPATH $PYTHONPATH - ''); + postInstall = ( + if libOnly then + '' + rm -rf $out/{bin,share} + rm -rf $out/lib/{jack,libjacknet*,libjackserver*} + '' + else + lib.optionalString (optDbus != null) '' + wrapProgram $out/bin/jack_control --set PYTHONPATH $PYTHONPATH + '' + ); postFixup = '' substituteInPlace "$dev/lib/pkgconfig/jack.pc" \ diff --git a/pkgs/misc/jackaudio/jack1.nix b/pkgs/misc/jackaudio/jack1.nix index d50f21f53fcbbe..8d30e863fb9a8c 100644 --- a/pkgs/misc/jackaudio/jack1.nix +++ b/pkgs/misc/jackaudio/jack1.nix @@ -1,13 +1,22 @@ -{ lib, stdenv, fetchurl, pkg-config - -# Optional Dependencies -, alsa-lib ? null, db ? null, libuuid ? null, libffado ? null, celt ? null - -, testers +{ + lib, + stdenv, + fetchurl, + pkg-config, + + # Optional Dependencies + alsa-lib ? null, + db ? null, + libuuid ? null, + libffado ? null, + celt ? null, + + testers, }: let - shouldUsePkg = pkg: if pkg != null && lib.meta.availableOn stdenv.hostPlatform pkg then pkg else null; + shouldUsePkg = + pkg: if pkg != null && lib.meta.availableOn stdenv.hostPlatform pkg then pkg else null; optAlsaLib = shouldUsePkg alsa-lib; optDb = shouldUsePkg db; @@ -29,7 +38,12 @@ stdenv.mkDerivation (finalAttrs: { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ optAlsaLib optDb optLibffado optCelt ]; + buildInputs = [ + optAlsaLib + optDb + optLibffado + optCelt + ]; propagatedBuildInputs = [ optLibuuid ]; passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; @@ -38,7 +52,10 @@ stdenv.mkDerivation (finalAttrs: { broken = stdenv.hostPlatform.isDarwin; description = "JACK audio connection kit"; homepage = "https://jackaudio.org"; - license = with licenses; [ gpl2Plus lgpl21 ]; + license = with licenses; [ + gpl2Plus + lgpl21 + ]; pkgConfigModules = [ "jack" ]; platforms = platforms.unix; }; diff --git a/pkgs/misc/jackaudio/tools.nix b/pkgs/misc/jackaudio/tools.nix index 76826d30cae9e2..25b0b5af38ab09 100644 --- a/pkgs/misc/jackaudio/tools.nix +++ b/pkgs/misc/jackaudio/tools.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib +{ + stdenv, + lib, -, fetchFromGitHub + fetchFromGitHub, -, pkg-config -, meson -, ninja + pkg-config, + meson, + ninja, -, jack -, alsa-lib -, libopus -, libsamplerate -, libsndfile -, readline -, zita-alsa-pcmi -, zita-resampler + jack, + alsa-lib, + libopus, + libsamplerate, + libsndfile, + readline, + zita-alsa-pcmi, + zita-resampler, -, enableAlsa ? stdenv.hostPlatform.isLinux + enableAlsa ? stdenv.hostPlatform.isLinux, }: stdenv.mkDerivation (final: { @@ -34,18 +35,24 @@ stdenv.mkDerivation (final: { patchShebangs scripts ''; - nativeBuildInputs = [ pkg-config meson ninja ]; - buildInputs = [ - jack - libopus - libsamplerate - libsndfile - readline - ] ++ lib.optionals enableAlsa [ - alsa-lib - zita-alsa-pcmi - zita-resampler + nativeBuildInputs = [ + pkg-config + meson + ninja ]; + buildInputs = + [ + jack + libopus + libsamplerate + libsndfile + readline + ] + ++ lib.optionals enableAlsa [ + alsa-lib + zita-alsa-pcmi + zita-resampler + ]; mesonFlags = [ (lib.mesonEnable "alsa_in_out" enableAlsa) diff --git a/pkgs/misc/jitsi-meet-prosody/default.nix b/pkgs/misc/jitsi-meet-prosody/default.nix index e08ea2aa4a0333..4606c24453a7ed 100644 --- a/pkgs/misc/jitsi-meet-prosody/default.nix +++ b/pkgs/misc/jitsi-meet-prosody/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, dpkg, nixosTests }: +{ + lib, + stdenv, + fetchurl, + dpkg, + nixosTests, +}: stdenv.mkDerivation rec { pname = "jitsi-meet-prosody"; @@ -28,7 +34,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Prosody configuration for Jitsi Meet"; longDescription = '' - This package contains configuration for Prosody to be used with Jitsi Meet. + This package contains configuration for Prosody to be used with Jitsi Meet. ''; homepage = "https://github.com/jitsi/jitsi-meet/"; license = licenses.asl20; diff --git a/pkgs/misc/lilypond/default.nix b/pkgs/misc/lilypond/default.nix index 95bc57227e20dd..3892a3d733b6f0 100644 --- a/pkgs/misc/lilypond/default.nix +++ b/pkgs/misc/lilypond/default.nix @@ -1,9 +1,45 @@ -{ stdenv, lib, fetchurl, ghostscript, gyre-fonts, texinfo, imagemagick, texi2html, guile -, python3, gettext, flex, perl, bison, pkg-config, autoreconfHook, dblatex -, fontconfig, freetype, pango, fontforge, help2man, zip, netpbm, groff -, freefont_ttf, makeFontsConf -, makeWrapper, t1utils, boehmgc, rsync, coreutils -, texliveSmall, tex ? texliveSmall.withPackages (ps: with ps; [ lh metafont epsf fontinst ]) +{ + stdenv, + lib, + fetchurl, + ghostscript, + gyre-fonts, + texinfo, + imagemagick, + texi2html, + guile, + python3, + gettext, + flex, + perl, + bison, + pkg-config, + autoreconfHook, + dblatex, + fontconfig, + freetype, + pango, + fontforge, + help2man, + zip, + netpbm, + groff, + freefont_ttf, + makeFontsConf, + makeWrapper, + t1utils, + boehmgc, + rsync, + coreutils, + texliveSmall, + tex ? texliveSmall.withPackages ( + ps: with ps; [ + lh + metafont + epsf + fontinst + ] + ), }: stdenv.mkDerivation rec { @@ -21,14 +57,20 @@ stdenv.mkDerivation rec { # its Scheme libraries. wrapProgram "$f" \ --set GUILE_AUTO_COMPILE 0 \ - --prefix PATH : "${lib.makeBinPath [ ghostscript coreutils (placeholder "out") ]}" \ + --prefix PATH : "${ + lib.makeBinPath [ + ghostscript + coreutils + (placeholder "out") + ] + }" \ --argv0 "$f" done ''; configureFlags = [ "--disable-documentation" - # FIXME: these URW fonts are not OTF, configure reports "URW++ OTF files... no". + # FIXME: these URW fonts are not OTF, configure reports "URW++ OTF files... no". "--with-urwotf-dir=${ghostscript.fonts}/share/fonts" "--with-texgyre-dir=${gyre-fonts}/share/fonts/truetype/" ]; @@ -38,13 +80,37 @@ stdenv.mkDerivation rec { export HOME=$TMPDIR/home ''; - nativeBuildInputs = [ autoreconfHook bison flex makeWrapper pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + bison + flex + makeWrapper + pkg-config + ]; - buildInputs = - [ ghostscript texinfo imagemagick texi2html guile dblatex tex zip netpbm - python3 gettext perl fontconfig freetype pango - fontforge help2man groff t1utils boehmgc rsync - ]; + buildInputs = [ + ghostscript + texinfo + imagemagick + texi2html + guile + dblatex + tex + zip + netpbm + python3 + gettext + perl + fontconfig + freetype + pango + fontforge + help2man + groff + t1utils + boehmgc + rsync + ]; autoreconfPhase = "NOCONFIGURE=1 sh autogen.sh"; @@ -59,7 +125,10 @@ stdenv.mkDerivation rec { description = "Music typesetting system"; homepage = "http://lilypond.org/"; license = licenses.gpl3; - maintainers = with maintainers; [ marcweber yurrriq ]; + maintainers = with maintainers; [ + marcweber + yurrriq + ]; platforms = platforms.all; }; diff --git a/pkgs/misc/lilypond/fonts.nix b/pkgs/misc/lilypond/fonts.nix index b624498f0920e7..150d7ee9ea69c2 100644 --- a/pkgs/misc/lilypond/fonts.nix +++ b/pkgs/misc/lilypond/fonts.nix @@ -1,8 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, lilypond }: +{ + lib, + stdenv, + fetchFromGitHub, + lilypond, +}: let - olpFont = { fontName, rev, sha256, version ? rev, ... }: + olpFont = + { + fontName, + rev, + sha256, + version ? rev, + ... + }: stdenv.mkDerivation { inherit version; pname = "openlilypond-font-${fontName}"; diff --git a/pkgs/misc/lilypond/unstable.nix b/pkgs/misc/lilypond/unstable.nix index 33f7cd97a0c105..4935bd8e4b78f6 100644 --- a/pkgs/misc/lilypond/unstable.nix +++ b/pkgs/misc/lilypond/unstable.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, lilypond }: +{ + lib, + fetchurl, + lilypond, +}: lilypond.overrideAttrs (oldAttrs: rec { version = "2.25.21"; @@ -8,7 +12,10 @@ lilypond.overrideAttrs (oldAttrs: rec { }; passthru.updateScript = { - command = [ ./update.sh "unstable" ]; + command = [ + ./update.sh + "unstable" + ]; supportedFeatures = [ "commit" ]; }; }) diff --git a/pkgs/misc/lilypond/with-fonts.nix b/pkgs/misc/lilypond/with-fonts.nix index 2cfd1519795d91..ed2917b369a6bd 100644 --- a/pkgs/misc/lilypond/with-fonts.nix +++ b/pkgs/misc/lilypond/with-fonts.nix @@ -1,9 +1,13 @@ -{ lib, symlinkJoin, makeWrapper -, lilypond, openlilylib-fonts +{ + lib, + symlinkJoin, + makeWrapper, + lilypond, + openlilylib-fonts, }: lib.appendToName "with-fonts" (symlinkJoin { - inherit (lilypond) meta name version ; + inherit (lilypond) meta name version; paths = [ lilypond ] ++ openlilylib-fonts.all; diff --git a/pkgs/misc/logging/beats/7.x.nix b/pkgs/misc/logging/beats/7.x.nix index 70c1e26a49d675..58641f46a11f61 100644 --- a/pkgs/misc/logging/beats/7.x.nix +++ b/pkgs/misc/logging/beats/7.x.nix @@ -1,27 +1,45 @@ -{ lib, fetchFromGitHub, elk7Version, buildGoModule, libpcap, nixosTests, systemd, config }: +{ + lib, + fetchFromGitHub, + elk7Version, + buildGoModule, + libpcap, + nixosTests, + systemd, + config, +}: -let beat = package: extraArgs: buildGoModule (lib.attrsets.recursiveUpdate (rec { - pname = package; - version = elk7Version; +let + beat = + package: extraArgs: + buildGoModule ( + lib.attrsets.recursiveUpdate (rec { + pname = package; + version = elk7Version; - src = fetchFromGitHub { - owner = "elastic"; - repo = "beats"; - rev = "v${version}"; - hash = "sha256-0qwWHRIDLlnaPOCRmiiFGg+/jdanWuQtggM2QSaMR1o="; - }; + src = fetchFromGitHub { + owner = "elastic"; + repo = "beats"; + rev = "v${version}"; + hash = "sha256-0qwWHRIDLlnaPOCRmiiFGg+/jdanWuQtggM2QSaMR1o="; + }; - vendorHash = "sha256-rwCCpptppkpvwQWUtqTjBUumP8GSpPHBTCaj0nYVQv8="; + vendorHash = "sha256-rwCCpptppkpvwQWUtqTjBUumP8GSpPHBTCaj0nYVQv8="; - subPackages = [ package ]; + subPackages = [ package ]; - meta = with lib; { - homepage = "https://www.elastic.co/products/beats"; - license = licenses.asl20; - maintainers = with maintainers; [ fadenb basvandijk dfithian ]; - platforms = platforms.linux; - }; -}) extraArgs); + meta = with lib; { + homepage = "https://www.elastic.co/products/beats"; + license = licenses.asl20; + maintainers = with maintainers; [ + fadenb + basvandijk + dfithian + ]; + platforms = platforms.linux; + }; + }) extraArgs + ); in rec { auditbeat7 = beat "auditbeat" { meta.description = "Lightweight shipper for audit data"; }; @@ -36,13 +54,12 @@ rec { heartbeat7 = beat "heartbeat" { meta.description = "Lightweight shipper for uptime monitoring"; }; metricbeat7 = beat "metricbeat" { meta.description = "Lightweight shipper for metrics"; - passthru.tests = - lib.optionalAttrs config.allowUnfree ( - assert metricbeat7.drvPath == nixosTests.elk.unfree.ELK-7.elkPackages.metricbeat.drvPath; - { - elk = nixosTests.elk.unfree.ELK-7; - } - ); + passthru.tests = lib.optionalAttrs config.allowUnfree ( + assert metricbeat7.drvPath == nixosTests.elk.unfree.ELK-7.elkPackages.metricbeat.drvPath; + { + elk = nixosTests.elk.unfree.ELK-7; + } + ); }; packetbeat7 = beat "packetbeat" { buildInputs = [ libpcap ]; diff --git a/pkgs/misc/my-env/default.nix b/pkgs/misc/my-env/default.nix index df4c8fc6b63d08..710536e9869ae9 100644 --- a/pkgs/misc/my-env/default.nix +++ b/pkgs/misc/my-env/default.nix @@ -19,7 +19,6 @@ # and this will update your env vars to have 'make' and 'gcc' finding the SDL # headers and libs. - ##### Another example, more complicated but achieving more: ####### # Make an environment to build nix from source and create ctags (tagfiles can # be extracted from TAG_FILES) from every source package. Here would be a @@ -57,96 +56,112 @@ and show you a shell with a prefixed prompt. */ -{ mkDerivation, substituteAll, pkgs }: - { stdenv ? pkgs.stdenv, name, buildInputs ? [] - , propagatedBuildInputs ? [], gcc ? stdenv.cc, extraCmds ? "" - , cleanupCmds ? "", shell ? "${pkgs.bashInteractive}/bin/bash --norc"}: +{ + mkDerivation, + substituteAll, + pkgs, +}: +{ + stdenv ? pkgs.stdenv, + name, + buildInputs ? [ ], + propagatedBuildInputs ? [ ], + gcc ? stdenv.cc, + extraCmds ? "", + cleanupCmds ? "", + shell ? "${pkgs.bashInteractive}/bin/bash --norc", +}: mkDerivation { inherit buildInputs propagatedBuildInputs; name = "env-${name}"; - phases = [ "buildPhase" "fixupPhase" ]; + phases = [ + "buildPhase" + "fixupPhase" + ]; setupNew = substituteAll { src = ../../stdenv/generic/setup.sh; inherit gcc; }; - buildPhase = let - initialPath = import ../../stdenv/generic/common-path.nix { inherit pkgs; }; - in '' - set -x - mkdir -p "$out/dev-envs" "$out/nix-support" "$out/bin" - s="$out/nix-support/setup-new-modified" - # shut some warning up.., do not use set -e - sed -e 's@set -eu@@' \ - -e 's@assertEnvExists\s\+NIX_STORE@:@' \ - -e 's@trap.*@@' \ - -e '1i initialPath="${toString initialPath}"' \ - "$setupNew" > "$s" - cat >> "$out/dev-envs/''${name/env-/}" << EOF - defaultNativeBuildInputs="$defaultNativeBuildInputs" - buildInputs="$buildInputs" - propagatedBuildInputs="$propagatedBuildInputs" - # the setup-new script wants to write some data to a temp file.. so just let it do that and tidy up afterwards - tmp="\$("${pkgs.coreutils}/bin/mktemp" -d)" - NIX_BUILD_TOP="\$tmp" - phases= - # only do all the setup stuff in nix-support/* - set +e - # This prevents having -rpath /lib in NIX_LDFLAGS - export NIX_NO_SELF_RPATH=1 - if [[ -z "\$ZSH_VERSION" ]]; then - source "$s" - else - setopt interactivecomments - # fix bash indirection - # let's hope the bash arrays aren't used - # substitute is using bash array, so skip it - echo ' - setopt NO_BAD_PATTERN - setopt NO_BANG_HIST - setopt NO_BG_NICE - setopt NO_EQUALS - setopt NO_FUNCTION_ARGZERO - setopt GLOB_SUBST - setopt NO_HUP - setopt INTERACTIVE_COMMENTS - setopt KSH_ARRAYS - setopt NO_MULTIOS - setopt NO_NOMATCH - setopt RM_STAR_SILENT - setopt POSIX_BUILTINS - setopt SH_FILE_EXPANSION - setopt SH_GLOB - setopt SH_OPTION_LETTERS - setopt SH_WORD_SPLIT - ' >> "\$tmp/script" - sed -e 's/\''${!\([^}]*\)}/\''${(P)\1}/g' \ - -e 's/[[]\*\]//' \ - -e 's/substitute() {/ substitute() { return; /' \ - -e 's@PATH=\$@PATH=${pkgs.coreutils}/bin@' \ - "$s" >> "\$tmp/script" - echo "\$tmp/script"; - source "\$tmp/script"; - fi - ${pkgs.coreutils}/bin/rm -fr "\$tmp" - ${extraCmds} + buildPhase = + let + initialPath = import ../../stdenv/generic/common-path.nix { inherit pkgs; }; + in + '' + set -x + mkdir -p "$out/dev-envs" "$out/nix-support" "$out/bin" + s="$out/nix-support/setup-new-modified" + # shut some warning up.., do not use set -e + sed -e 's@set -eu@@' \ + -e 's@assertEnvExists\s\+NIX_STORE@:@' \ + -e 's@trap.*@@' \ + -e '1i initialPath="${toString initialPath}"' \ + "$setupNew" > "$s" + cat >> "$out/dev-envs/''${name/env-/}" << EOF + defaultNativeBuildInputs="$defaultNativeBuildInputs" + buildInputs="$buildInputs" + propagatedBuildInputs="$propagatedBuildInputs" + # the setup-new script wants to write some data to a temp file.. so just let it do that and tidy up afterwards + tmp="\$("${pkgs.coreutils}/bin/mktemp" -d)" + NIX_BUILD_TOP="\$tmp" + phases= + # only do all the setup stuff in nix-support/* + set +e + # This prevents having -rpath /lib in NIX_LDFLAGS + export NIX_NO_SELF_RPATH=1 + if [[ -z "\$ZSH_VERSION" ]]; then + source "$s" + else + setopt interactivecomments + # fix bash indirection + # let's hope the bash arrays aren't used + # substitute is using bash array, so skip it + echo ' + setopt NO_BAD_PATTERN + setopt NO_BANG_HIST + setopt NO_BG_NICE + setopt NO_EQUALS + setopt NO_FUNCTION_ARGZERO + setopt GLOB_SUBST + setopt NO_HUP + setopt INTERACTIVE_COMMENTS + setopt KSH_ARRAYS + setopt NO_MULTIOS + setopt NO_NOMATCH + setopt RM_STAR_SILENT + setopt POSIX_BUILTINS + setopt SH_FILE_EXPANSION + setopt SH_GLOB + setopt SH_OPTION_LETTERS + setopt SH_WORD_SPLIT + ' >> "\$tmp/script" + sed -e 's/\''${!\([^}]*\)}/\''${(P)\1}/g' \ + -e 's/[[]\*\]//' \ + -e 's/substitute() {/ substitute() { return; /' \ + -e 's@PATH=\$@PATH=${pkgs.coreutils}/bin@' \ + "$s" >> "\$tmp/script" + echo "\$tmp/script"; + source "\$tmp/script"; + fi + ${pkgs.coreutils}/bin/rm -fr "\$tmp" + ${extraCmds} - nix_cleanup() { - : - ${cleanupCmds} - } + nix_cleanup() { + : + ${cleanupCmds} + } - export PATH - echo $name loaded >&2 + export PATH + echo $name loaded >&2 - trap nix_cleanup EXIT - EOF + trap nix_cleanup EXIT + EOF - mkdir -p $out/bin - sed -e 's,@shell@,${shell},' -e s,@myenvpath@,$out/dev-envs/${name}, \ - -e 's,@name@,${name},' ${./loadenv.sh} > $out/bin/load-env-${name} - chmod +x $out/bin/load-env-${name} - ''; + mkdir -p $out/bin + sed -e 's,@shell@,${shell},' -e s,@myenvpath@,$out/dev-envs/${name}, \ + -e 's,@name@,${name},' ${./loadenv.sh} > $out/bin/load-env-${name} + chmod +x $out/bin/load-env-${name} + ''; } diff --git a/pkgs/misc/opcua-client-gui/default.nix b/pkgs/misc/opcua-client-gui/default.nix index 22669706036597..9315bdd8ca3da0 100644 --- a/pkgs/misc/opcua-client-gui/default.nix +++ b/pkgs/misc/opcua-client-gui/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, python3Packages -, fetchFromGitHub -, makeDesktopItem -, copyDesktopItems -, desktopToDarwinBundle -, wrapQtAppsHook +{ + lib, + stdenv, + python3Packages, + fetchFromGitHub, + makeDesktopItem, + copyDesktopItems, + desktopToDarwinBundle, + wrapQtAppsHook, }: python3Packages.buildPythonApplication rec { @@ -19,8 +20,10 @@ python3Packages.buildPythonApplication rec { hash = "sha256-0BH1Txr3z4a7iFcsfnovmBUreXMvIX2zpZa8QivQVx8="; }; - nativeBuildInputs = [ copyDesktopItems wrapQtAppsHook ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; + nativeBuildInputs = [ + copyDesktopItems + wrapQtAppsHook + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ desktopToDarwinBundle ]; makeWrapperArgs = [ "\${qtWrapperArgs[@]}" diff --git a/pkgs/misc/screensavers/slock/default.nix b/pkgs/misc/screensavers/slock/default.nix index e86358d2e4ea25..99c2372f09b9ae 100644 --- a/pkgs/misc/screensavers/slock/default.nix +++ b/pkgs/misc/screensavers/slock/default.nix @@ -1,10 +1,18 @@ -{ lib, stdenv, fetchurl, writeText -, xorgproto, libX11, libXext, libXrandr, libxcrypt -# default header can be obtained from -# https://git.suckless.org/slock/tree/config.def.h -, conf ? null -# update script dependencies -, gitUpdater +{ + lib, + stdenv, + fetchurl, + writeText, + xorgproto, + libX11, + libXext, + libXrandr, + libxcrypt, + # default header can be obtained from + # https://git.suckless.org/slock/tree/config.def.h + conf ? null, + # update script dependencies + gitUpdater, }: stdenv.mkDerivation (finalAttrs: { @@ -16,7 +24,13 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-ruHj+/aid/tiWjg4BzuXm2SD57rKTOgvVt4f8ZLbDk0="; }; - buildInputs = [ xorgproto libX11 libXext libXrandr libxcrypt ]; + buildInputs = [ + xorgproto + libX11 + libXext + libXrandr + libxcrypt + ]; installFlags = [ "PREFIX=$(out)" ]; @@ -40,7 +54,10 @@ stdenv.mkDerivation (finalAttrs: { Simple X display locker. This is the simplest X screen locker. ''; license = licenses.mit; - maintainers = with maintainers; [ astsmtl qusic ]; + maintainers = with maintainers; [ + astsmtl + qusic + ]; platforms = platforms.linux; }; }) diff --git a/pkgs/misc/source-and-tags/default.nix b/pkgs/misc/source-and-tags/default.nix index 9e73b77c59cf2d..a117beb45d5dd4 100644 --- a/pkgs/misc/source-and-tags/default.nix +++ b/pkgs/misc/source-and-tags/default.nix @@ -1,58 +1,84 @@ -{ stdenv, lib, glibcLocales, unzip, hasktags, ctags } : { +{ + stdenv, + lib, + glibcLocales, + unzip, + hasktags, + ctags, +}: +{ # optional srcDir - annotatedWithSourceAndTagInfo = x : (x ? passthru && x.passthru ? sourceWithTags - || x ? meta && x.meta ? sourceWithTags ); + annotatedWithSourceAndTagInfo = + x: (x ? passthru && x.passthru ? sourceWithTags || x ? meta && x.meta ? sourceWithTags); # hack because passthru doesn't work the way I'd expect. Don't have time to spend on this right now # that's why I'm abusing meta for the same purpose in ghcsAndLibs - sourceWithTagsFromDerivation = x : if x ? passthru && x.passthru ? sourceWithTags then x.passthru.sourceWithTags - else if x ? meta && x.meta ? sourceWithTags then x.meta.sourceWithTags - else null; + sourceWithTagsFromDerivation = + x: + if x ? passthru && x.passthru ? sourceWithTags then + x.passthru.sourceWithTags + else if x ? meta && x.meta ? sourceWithTags then + x.meta.sourceWithTags + else + null; # createTagFiles = [ { name = "my_tag_name_without_suffix", tagCmd = "ctags -R . -o \$TAG_FILE"; } ] # tag command must create file named $TAG_FILE - sourceWithTagsDerivation = {name, src, srcDir ? ".", tagSuffix ? "_tags", createTagFiles ? []} : + sourceWithTagsDerivation = + { + name, + src, + srcDir ? ".", + tagSuffix ? "_tags", + createTagFiles ? [ ], + }: stdenv.mkDerivation { - inherit src srcDir tagSuffix; - name = "${name}-source-with-tags"; - nativeBuildInputs = [ unzip ]; - # using separate tag directory so that you don't have to glob that much files when starting your editor - # is this a good choice? - installPhase = - let createTags = lib.concatStringsSep "\n" - (map (a: '' - TAG_FILE="$SRC_DEST/${a.name}$tagSuffix" - echo running tag cmd "${a.tagCmd}" in `pwd` - ${a.tagCmd} - TAG_FILES="$TAG_FILES''${TAG_FILES:+:}$TAG_FILE" - '') createTagFiles ); - in '' - SRC_DEST=$out/src/$name - mkdir -p $SRC_DEST - pwd; ls - cp -r $srcDir $SRC_DEST - cd $SRC_DEST - ${createTags} + inherit src srcDir tagSuffix; + name = "${name}-source-with-tags"; + nativeBuildInputs = [ unzip ]; + # using separate tag directory so that you don't have to glob that much files when starting your editor + # is this a good choice? + installPhase = + let + createTags = lib.concatStringsSep "\n" ( + map (a: '' + TAG_FILE="$SRC_DEST/${a.name}$tagSuffix" + echo running tag cmd "${a.tagCmd}" in `pwd` + ${a.tagCmd} + TAG_FILES="$TAG_FILES''${TAG_FILES:+:}$TAG_FILE" + '') createTagFiles + ); + in + '' + SRC_DEST=$out/src/$name + mkdir -p $SRC_DEST + pwd; ls + cp -r $srcDir $SRC_DEST + cd $SRC_DEST + ${createTags} - mkdir -p $out/nix-support - echo "TAG_FILES=\"\$TAG_FILES\''${TAG_FILES:+:}$TAG_FILES\"" >> $out/nix-support/setup-hook - ''; - }; + mkdir -p $out/nix-support + echo "TAG_FILES=\"\$TAG_FILES\''${TAG_FILES:+:}$TAG_FILES\"" >> $out/nix-support/setup-hook + ''; + }; # example usage #testSourceWithTags = sourceWithTagsDerivation (ghc68extraLibs ghcsAndLibs.ghc68).happs_server_darcs.passthru.sourceWithTags; - # creates annotated derivation (comments see above) - addHasktagsTaggingInfo = deriv : deriv // { + addHasktagsTaggingInfo = + deriv: + deriv + // { passthru = { sourceWithTags = { - inherit (deriv) src; - srcDir = if deriv ? srcDir then deriv.srcDir else "."; - name = deriv.name; - createTagFiles = [ - { name = "${deriv.name}_haskell"; - # tagCmd = "${toString ghcsAndLibs.ghc68.ghc}/bin/hasktags --ignore-close-implementation --ctags `find . -type f -name \"*.*hs\"`; sort tags > \$TAG_FILE"; } - # *.*hs.* to catch gtk2hs .hs.pp files - tagCmd = " + inherit (deriv) src; + srcDir = if deriv ? srcDir then deriv.srcDir else "."; + name = deriv.name; + createTagFiles = [ + { + name = "${deriv.name}_haskell"; + # tagCmd = "${toString ghcsAndLibs.ghc68.ghc}/bin/hasktags --ignore-close-implementation --ctags `find . -type f -name \"*.*hs\"`; sort tags > \$TAG_FILE"; } + # *.*hs.* to catch gtk2hs .hs.pp files + tagCmd = " srcs=\"`find . -type f -name \"*.*hs\"; find . -type f -name \"*.*hs*\";`\" [ -z \"$srcs\" ] || { # without this creating tag files for lifted-base fails @@ -63,32 +89,36 @@ ${toString hasktags}/bin/hasktags --ignore-close-implementation --ctags . mv tags \$TAG_FILE }"; - } + } ]; - }; + }; + }; }; - }; - - addCTaggingInfo = deriv : - deriv // { + addCTaggingInfo = + deriv: + deriv + // { passthru = { sourceWithTags = { - inherit (deriv) src; - name = "${deriv.name}-source-ctags"; - createTagFiles = [ - { inherit (deriv) name; - tagCmd = "${toString ctags}/bin/ctags --sort=yes -o \$TAG_FILE -R ."; } + inherit (deriv) src; + name = "${deriv.name}-source-ctags"; + createTagFiles = [ + { + inherit (deriv) name; + tagCmd = "${toString ctags}/bin/ctags --sort=yes -o \$TAG_FILE -R ."; + } ]; }; - }; }; + }; + }; } /* -experimental -idea: -a) Attach some information to a nexpression telling how to create a tag file which can then be used within your favourite editor - Do this in a way not affecting the expression (using passthru or meta which is ignored when calculating the hash) - implementations: addCTaggingInfo (C / C++) and addHasktagsTaggingInfo (Haskell) -b) use sourceWithTagsDerivation function to create a derivation installing the source along with the generated tag files - so that you can use them easily witihn your favourite text editor + experimental + idea: + a) Attach some information to a nexpression telling how to create a tag file which can then be used within your favourite editor + Do this in a way not affecting the expression (using passthru or meta which is ignored when calculating the hash) + implementations: addCTaggingInfo (C / C++) and addHasktagsTaggingInfo (Haskell) + b) use sourceWithTagsDerivation function to create a derivation installing the source along with the generated tag files + so that you can use them easily witihn your favourite text editor */ diff --git a/pkgs/misc/t-rec/default.nix b/pkgs/misc/t-rec/default.nix index c67a8d60557b58..9b2411d7a1f014 100644 --- a/pkgs/misc/t-rec/default.nix +++ b/pkgs/misc/t-rec/default.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, imagemagick, ffmpeg, rustPlatform, fetchFromGitHub, makeWrapper -, libiconv, Foundation }: +{ + lib, + stdenv, + imagemagick, + ffmpeg, + rustPlatform, + fetchFromGitHub, + makeWrapper, + libiconv, + Foundation, +}: let binPath = lib.makeBinPath [ @@ -19,8 +28,12 @@ rustPlatform.buildRustPackage rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ imagemagick ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv Foundation ]; + buildInputs = + [ imagemagick ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Foundation + ]; postInstall = '' wrapProgram "$out/bin/t-rec" --prefix PATH : "${binPath}" @@ -32,7 +45,10 @@ rustPlatform.buildRustPackage rec { description = "Blazingly fast terminal recorder that generates animated gif images for the web written in rust"; homepage = "https://github.com/sassman/t-rec-rs"; license = with licenses; [ gpl3Only ]; - maintainers = with maintainers; [ hoverbear matthiasbeyer ]; + maintainers = with maintainers; [ + hoverbear + matthiasbeyer + ]; mainProgram = "t-rec"; }; } diff --git a/pkgs/misc/tmux-plugins/tmux-thumbs/default.nix b/pkgs/misc/tmux-plugins/tmux-thumbs/default.nix index 80aa40e866cb28..d7abae1ed23a81 100644 --- a/pkgs/misc/tmux-plugins/tmux-thumbs/default.nix +++ b/pkgs/misc/tmux-plugins/tmux-thumbs/default.nix @@ -1,4 +1,8 @@ -{ mkTmuxPlugin, thumbs, substituteAll }: +{ + mkTmuxPlugin, + thumbs, + substituteAll, +}: mkTmuxPlugin { diff --git a/pkgs/misc/translatelocally-models/default.nix b/pkgs/misc/translatelocally-models/default.nix index 9fb4754ed50d10..f5b7ee3403d54f 100644 --- a/pkgs/misc/translatelocally-models/default.nix +++ b/pkgs/misc/translatelocally-models/default.nix @@ -2,11 +2,22 @@ let modelSpecs = (builtins.fromJSON (builtins.readFile ./models.json)); in -{ lib, stdenvNoCC, fetchurl }: +{ + lib, + stdenvNoCC, + fetchurl, +}: let withCodeAsKey = f: { code, ... }@attrs: lib.nameValuePair code (f attrs); - mkModelPackage = { name, code, version, url, checksum }: + mkModelPackage = + { + name, + code, + version, + url, + checksum, + }: stdenvNoCC.mkDerivation { pname = "translatelocally-model-${code}"; version = toString version; @@ -33,9 +44,10 @@ let license = lib.licenses.cc-by-sa-40; }; }; - allModelPkgs = - lib.listToAttrs (map (withCodeAsKey mkModelPackage) modelSpecs); + allModelPkgs = lib.listToAttrs (map (withCodeAsKey mkModelPackage) modelSpecs); -in allModelPkgs // { +in +allModelPkgs +// { passthru.updateScript = ./update.sh; } diff --git a/pkgs/misc/urbit/default.nix b/pkgs/misc/urbit/default.nix index 955b16bf693e4f..e0758ddba61c50 100644 --- a/pkgs/misc/urbit/default.nix +++ b/pkgs/misc/urbit/default.nix @@ -1,6 +1,7 @@ -{ stdenv -, lib -, fetchzip +{ + stdenv, + lib, + fetchzip, }: let @@ -14,12 +15,14 @@ stdenv.mkDerivation rec { src = fetchzip { url = "https://github.com/urbit/vere/releases/download/vere-v${version}/${platform}.tgz"; - sha256 = { - x86_64-linux = "sha256-51Zgv9QANQVMk/dc7/heYmCNfeu4k7mrYNke1/oz/94="; - aarch64-linux = "sha256-Tdn/ve9iCjsY/b39TZ7ErHV14mIAHdtmycgUPIzRihQ="; - x86_64-darwin = "sha256-y/FQIVcEn6dLWXPztC34+7+5eDMO7Xcx25D2+0p7Mxk="; - aarch64-darwin = "sha256-YJGRZlpTdm1x4P+GnZiKC1411tcEX+Jdnm+iyxUlsU0="; - }.${stdenv.hostPlatform.system} or (throw "unsupported system ${stdenv.hostPlatform.system}"); + sha256 = + { + x86_64-linux = "sha256-51Zgv9QANQVMk/dc7/heYmCNfeu4k7mrYNke1/oz/94="; + aarch64-linux = "sha256-Tdn/ve9iCjsY/b39TZ7ErHV14mIAHdtmycgUPIzRihQ="; + x86_64-darwin = "sha256-y/FQIVcEn6dLWXPztC34+7+5eDMO7Xcx25D2+0p7Mxk="; + aarch64-darwin = "sha256-YJGRZlpTdm1x4P+GnZiKC1411tcEX+Jdnm+iyxUlsU0="; + } + .${stdenv.hostPlatform.system} or (throw "unsupported system ${stdenv.hostPlatform.system}"); }; postInstall = '' @@ -31,7 +34,12 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://urbit.org"; description = "Operating function"; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin"]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; maintainers = [ maintainers.matthew-levan ]; license = licenses.mit; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; diff --git a/pkgs/os-specific/darwin/DarwinTools/default.nix b/pkgs/os-specific/darwin/DarwinTools/default.nix index 11e4c84395dabb..1473a664574a09 100644 --- a/pkgs/os-specific/darwin/DarwinTools/default.nix +++ b/pkgs/os-specific/darwin/DarwinTools/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "DarwinTools"; diff --git a/pkgs/os-specific/darwin/asitop/default.nix b/pkgs/os-specific/darwin/asitop/default.nix index 3ac385ec08ffee..7e20f26889b795 100644 --- a/pkgs/os-specific/darwin/asitop/default.nix +++ b/pkgs/os-specific/darwin/asitop/default.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/os-specific/darwin/defaultbrowser/default.nix b/pkgs/os-specific/darwin/defaultbrowser/default.nix index 7d50924625cdfc..f4f4c885d144ee 100644 --- a/pkgs/os-specific/darwin/defaultbrowser/default.nix +++ b/pkgs/os-specific/darwin/defaultbrowser/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, Foundation }: +{ + lib, + stdenv, + fetchFromGitHub, + Foundation, +}: stdenv.mkDerivation rec { pname = "defaultbrowser"; @@ -11,7 +16,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-SelUQXoKtShcDjq8uKg3wM0kG2opREa2DGQCDd6IsOQ="; }; - makeFlags = [ "CC=cc" "PREFIX=$(out)" ]; + makeFlags = [ + "CC=cc" + "PREFIX=$(out)" + ]; buildInputs = [ Foundation ]; diff --git a/pkgs/os-specific/darwin/ghc-standalone-archive/default.nix b/pkgs/os-specific/darwin/ghc-standalone-archive/default.nix index 46ba6828186880..28d598a397e24f 100644 --- a/pkgs/os-specific/darwin/ghc-standalone-archive/default.nix +++ b/pkgs/os-specific/darwin/ghc-standalone-archive/default.nix @@ -1,13 +1,27 @@ { runCommand, cctools }: -{ haskellPackages, src, deps ? p : [], name }: let +{ + haskellPackages, + src, + deps ? p: [ ], + name, +}: +let inherit (haskellPackages) ghc ghcWithPackages; with-env = ghcWithPackages deps; ghcName = "${ghc.targetPrefix}ghc"; -in runCommand name { buildInputs = [ with-env cctools ]; } '' - mkdir -p $out/lib - mkdir -p $out/include - ${ghcName} ${src} -staticlib -outputdir . -o $out/lib/${name}.a -stubdir $out/include - for file in ${ghc}/lib/${ghcName}-${ghc.version}/include/*; do - ln -sv $file $out/include - done -'' +in +runCommand name + { + buildInputs = [ + with-env + cctools + ]; + } + '' + mkdir -p $out/lib + mkdir -p $out/include + ${ghcName} ${src} -staticlib -outputdir . -o $out/lib/${name}.a -stubdir $out/include + for file in ${ghc}/lib/${ghcName}-${ghc.version}/include/*; do + ln -sv $file $out/include + done + '' diff --git a/pkgs/os-specific/darwin/impure-cmds/default.nix b/pkgs/os-specific/darwin/impure-cmds/default.nix index 51e345f048bdad..eac4f6b97fd2bc 100644 --- a/pkgs/os-specific/darwin/impure-cmds/default.nix +++ b/pkgs/os-specific/darwin/impure-cmds/default.nix @@ -6,29 +6,33 @@ let commands = { ditto = "/usr/bin/ditto"; # ditto is not opensource - sudo = "/usr/bin/sudo"; # sudo must be owned by uid 0 and have the setuid bit set + sudo = "/usr/bin/sudo"; # sudo must be owned by uid 0 and have the setuid bit set }; - mkImpureDrv = name: path: - runCommandLocal "${name}-impure-darwin" { - __impureHostDeps = [ path ]; + mkImpureDrv = + name: path: + runCommandLocal "${name}-impure-darwin" + { + __impureHostDeps = [ path ]; - meta = { - platforms = lib.platforms.darwin; - }; - } '' - if ! [ -x ${path} ]; then - echo Cannot find command ${path} - exit 1 - fi + meta = { + platforms = lib.platforms.darwin; + }; + } + '' + if ! [ -x ${path} ]; then + echo Cannot find command ${path} + exit 1 + fi - mkdir -p $out/bin - ln -s ${path} $out/bin + mkdir -p $out/bin + ln -s ${path} $out/bin - manpage="/usr/share/man/man1/${name}.1" - if [ -f $manpage ]; then - mkdir -p $out/share/man/man1 - ln -s $manpage $out/share/man/man1 - fi - ''; -in lib.mapAttrs mkImpureDrv commands + manpage="/usr/share/man/man1/${name}.1" + if [ -f $manpage ]; then + mkdir -p $out/share/man/man1 + ln -s $manpage $out/share/man/man1 + fi + ''; +in +lib.mapAttrs mkImpureDrv commands diff --git a/pkgs/os-specific/darwin/khd/default.nix b/pkgs/os-specific/darwin/khd/default.nix index 9c10dc89a69d38..474d750ecc8c70 100644 --- a/pkgs/os-specific/darwin/khd/default.nix +++ b/pkgs/os-specific/darwin/khd/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, Carbon, Cocoa }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + Carbon, + Cocoa, +}: stdenv.mkDerivation rec { pname = "khd"; @@ -19,7 +26,10 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ Carbon Cocoa ]; + buildInputs = [ + Carbon + Cocoa + ]; buildPhase = '' make install diff --git a/pkgs/os-specific/darwin/lsusb/default.nix b/pkgs/os-specific/darwin/lsusb/default.nix index 712e32f16fe4a3..a29df822daa69a 100644 --- a/pkgs/os-specific/darwin/lsusb/default.nix +++ b/pkgs/os-specific/darwin/lsusb/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation { version = "1.0"; diff --git a/pkgs/os-specific/darwin/macfuse/default.nix b/pkgs/os-specific/darwin/macfuse/default.nix index 4de9600e79108b..7f7c0cb5183bb8 100644 --- a/pkgs/os-specific/darwin/macfuse/default.nix +++ b/pkgs/os-specific/darwin/macfuse/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, cpio, xar, undmg, libtapi, DiskArbitration }: +{ + lib, + stdenv, + fetchurl, + cpio, + xar, + undmg, + libtapi, + DiskArbitration, +}: stdenv.mkDerivation rec { pname = "macfuse-stubs"; @@ -9,7 +18,12 @@ stdenv.mkDerivation rec { hash = "sha256-ucTzO2qdN4QkowMVvC3+4pjEVjbwMsB0xFk+bvQxwtQ="; }; - nativeBuildInputs = [ cpio xar undmg libtapi ]; + nativeBuildInputs = [ + cpio + xar + undmg + libtapi + ]; propagatedBuildInputs = [ DiskArbitration ]; postUnpack = '' diff --git a/pkgs/os-specific/darwin/noah/default.nix b/pkgs/os-specific/darwin/noah/default.nix index ed20f67e48e9c5..421b11df323233 100644 --- a/pkgs/os-specific/darwin/noah/default.nix +++ b/pkgs/os-specific/darwin/noah/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, cmake, Hypervisor }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + Hypervisor, +}: stdenv.mkDerivation rec { pname = "noah"; @@ -17,7 +23,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Bash on Ubuntu on macOS"; homepage = "https://github.com/linux-noah/noah"; - license = [ licenses.mit licenses.gpl2Only ]; + license = [ + licenses.mit + licenses.gpl2Only + ]; maintainers = [ ]; platforms = platforms.darwin; # never built on aarch64-darwin since first introduction in nixpkgs diff --git a/pkgs/os-specific/darwin/openwith/default.nix b/pkgs/os-specific/darwin/openwith/default.nix index 3631f7d495bee1..f9bf5ffb94e773 100644 --- a/pkgs/os-specific/darwin/openwith/default.nix +++ b/pkgs/os-specific/darwin/openwith/default.nix @@ -1,4 +1,8 @@ -{ lib, swiftPackages, fetchFromGitHub }: +{ + lib, + swiftPackages, + fetchFromGitHub, +}: let inherit (swiftPackages) stdenv swift; @@ -30,6 +34,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/jdek/openwith"; license = licenses.unlicense; maintainers = with maintainers; [ zowoq ]; - platforms = [ "aarch64-darwin" "x86_64-darwin" ]; + platforms = [ + "aarch64-darwin" + "x86_64-darwin" + ]; }; } diff --git a/pkgs/os-specific/darwin/osx-cpu-temp/default.nix b/pkgs/os-specific/darwin/osx-cpu-temp/default.nix index 2f3154fe9ea41d..59c92f9d434a5c 100644 --- a/pkgs/os-specific/darwin/osx-cpu-temp/default.nix +++ b/pkgs/os-specific/darwin/osx-cpu-temp/default.nix @@ -1,5 +1,8 @@ -{ lib, stdenv, fetchFromGitHub -, IOKit +{ + lib, + stdenv, + fetchFromGitHub, + IOKit, }: stdenv.mkDerivation rec { diff --git a/pkgs/os-specific/darwin/pngpaste/default.nix b/pkgs/os-specific/darwin/pngpaste/default.nix index 99ae8048f7fde2..3df66b88534aad 100644 --- a/pkgs/os-specific/darwin/pngpaste/default.nix +++ b/pkgs/os-specific/darwin/pngpaste/default.nix @@ -1,9 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, AppKit, Cocoa }: +{ + lib, + stdenv, + fetchFromGitHub, + AppKit, + Cocoa, +}: let pname = "pngpaste"; version = "0.2.3"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname version; src = fetchFromGitHub { owner = "jcsalterego"; @@ -12,7 +19,10 @@ in stdenv.mkDerivation { sha256 = "uvajxSelk1Wfd5is5kmT2fzDShlufBgC0PDCeabEOSE="; }; - buildInputs = [ AppKit Cocoa ]; + buildInputs = [ + AppKit + Cocoa + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/os-specific/darwin/print-reexports/default.nix b/pkgs/os-specific/darwin/print-reexports/default.nix index 992cf1bff8ea3a..88d8d8532cece3 100644 --- a/pkgs/os-specific/darwin/print-reexports/default.nix +++ b/pkgs/os-specific/darwin/print-reexports/default.nix @@ -1,8 +1,12 @@ -{ lib, stdenv, libyaml }: +{ + lib, + stdenv, + libyaml, +}: stdenv.mkDerivation { name = "print-reexports"; - src = lib.sourceFilesBySuffices ./. [".c"]; + src = lib.sourceFilesBySuffices ./. [ ".c" ]; buildInputs = [ libyaml ]; diff --git a/pkgs/os-specific/darwin/qes/default.nix b/pkgs/os-specific/darwin/qes/default.nix index dce6e526626013..5b824da0f58713 100644 --- a/pkgs/os-specific/darwin/qes/default.nix +++ b/pkgs/os-specific/darwin/qes/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, Carbon }: +{ + lib, + stdenv, + fetchFromGitHub, + Carbon, +}: stdenv.mkDerivation { pname = "qes"; @@ -7,7 +12,7 @@ stdenv.mkDerivation { src = fetchFromGitHub { owner = "koekeishiya"; repo = "qes"; - rev = "ddedf008f0c38b134501ad9f328447b671423d34"; # no tag + rev = "ddedf008f0c38b134501ad9f328447b671423d34"; # no tag sha256 = "1w9ppid7jg6f4q7pq40lhm0whg7xmnxcmf3pb9xqfkq2zj2f7dxv"; }; @@ -23,4 +28,3 @@ stdenv.mkDerivation { license = licenses.mit; }; } - diff --git a/pkgs/os-specific/darwin/reattach-to-user-namespace/default.nix b/pkgs/os-specific/darwin/reattach-to-user-namespace/default.nix index ea3dd694962e49..9aacbce1c790b1 100644 --- a/pkgs/os-specific/darwin/reattach-to-user-namespace/default.nix +++ b/pkgs/os-specific/darwin/reattach-to-user-namespace/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "reattach-to-user-namespace"; @@ -12,9 +16,12 @@ stdenv.mkDerivation rec { }; buildFlags = - if stdenv.hostPlatform.system == "x86_64-darwin" then [ "ARCHES=x86_64" ] - else if stdenv.hostPlatform.system == "aarch64-darwin" then [ "ARCHES=arm64" ] - else throw "reattach-to-user-namespace isn't being built for ${stdenv.hostPlatform.system} yet."; + if stdenv.hostPlatform.system == "x86_64-darwin" then + [ "ARCHES=x86_64" ] + else if stdenv.hostPlatform.system == "aarch64-darwin" then + [ "ARCHES=arm64" ] + else + throw "reattach-to-user-namespace isn't being built for ${stdenv.hostPlatform.system} yet."; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/os-specific/darwin/rewrite-tbd/default.nix b/pkgs/os-specific/darwin/rewrite-tbd/default.nix index 527cca8e87c1e0..1026d9a8983a38 100644 --- a/pkgs/os-specific/darwin/rewrite-tbd/default.nix +++ b/pkgs/os-specific/darwin/rewrite-tbd/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, libyaml }: +{ + stdenv, + lib, + fetchFromGitHub, + libyaml, +}: stdenv.mkDerivation { pname = "rewrite-tbd"; @@ -20,7 +25,11 @@ stdenv.mkDerivation { buildInputs = [ libyaml ]; - makeFlags = [ "-f" "Makefile.boot" "PREFIX=${placeholder "out"}"]; + makeFlags = [ + "-f" + "Makefile.boot" + "PREFIX=${placeholder "out"}" + ]; meta = with lib; { homepage = "https://github.com/thefloweringash/rewrite-tbd/"; diff --git a/pkgs/os-specific/darwin/signing-utils/default.nix b/pkgs/os-specific/darwin/signing-utils/default.nix index 035ac59b725aee..9cfe992132168d 100644 --- a/pkgs/os-specific/darwin/signing-utils/default.nix +++ b/pkgs/os-specific/darwin/signing-utils/default.nix @@ -1,6 +1,7 @@ -{ stdenvNoCC -, sigtool -, cctools +{ + stdenvNoCC, + sigtool, + cctools, }: let diff --git a/pkgs/os-specific/darwin/signing-utils/post-link-sign-hook.nix b/pkgs/os-specific/darwin/signing-utils/post-link-sign-hook.nix index 13595e3771a7ab..78576698420876 100644 --- a/pkgs/os-specific/darwin/signing-utils/post-link-sign-hook.nix +++ b/pkgs/os-specific/darwin/signing-utils/post-link-sign-hook.nix @@ -1,4 +1,8 @@ -{ writeTextFile, cctools, sigtool }: +{ + writeTextFile, + cctools, + sigtool, +}: writeTextFile { name = "post-link-sign-hook"; diff --git a/pkgs/os-specific/darwin/sigtool/default.nix b/pkgs/os-specific/darwin/sigtool/default.nix index 62474fdc78d215..41dccbfff6c0b8 100644 --- a/pkgs/os-specific/darwin/sigtool/default.nix +++ b/pkgs/os-specific/darwin/sigtool/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + openssl, +}: stdenv.mkDerivation rec { pname = "sigtool"; diff --git a/pkgs/os-specific/darwin/stubs/default.nix b/pkgs/os-specific/darwin/stubs/default.nix index 862305a069d608..832fdc557b5b9a 100644 --- a/pkgs/os-specific/darwin/stubs/default.nix +++ b/pkgs/os-specific/darwin/stubs/default.nix @@ -1,12 +1,22 @@ -{ lib, writeScriptBin, runtimeShell }: +{ + lib, + writeScriptBin, + runtimeShell, +}: -let fake = name: lib.overrideDerivation (writeScriptBin name '' - #!${runtimeShell} - echo >&2 "Faking call to ${name} with arguments:" - echo >&2 "$@" -'') (drv: { - name = "${name}-stub"; -}); in +let + fake = + name: + lib.overrideDerivation + (writeScriptBin name '' + #!${runtimeShell} + echo >&2 "Faking call to ${name} with arguments:" + echo >&2 "$@" + '') + (drv: { + name = "${name}-stub"; + }); +in { setfile = fake "SetFile"; diff --git a/pkgs/os-specific/darwin/swift-corelibs/corefoundation.nix b/pkgs/os-specific/darwin/swift-corelibs/corefoundation.nix index 0b7c85b588f209..96339ac47457c3 100644 --- a/pkgs/os-specific/darwin/swift-corelibs/corefoundation.nix +++ b/pkgs/os-specific/darwin/swift-corelibs/corefoundation.nix @@ -1,11 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, fetchurl, makeSetupHook, cmake, pkg-config, launchd, libdispatch, python3Minimal, libxml2, objc4, icu }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + makeSetupHook, + cmake, + pkg-config, + launchd, + libdispatch, + python3Minimal, + libxml2, + objc4, + icu, +}: let # 10.12 adds a new sysdir.h that our version of CF in the main derivation depends on, but # isn't available publicly, so instead we grab an older version of the same file that did # not use sysdir.h, but provided the same functionality. Luckily it's simple :) hack hack sysdir-free-system-directories = fetchurl { - url = "https://raw.githubusercontent.com/apple/swift-corelibs-foundation/9a5d8420f7793e63a8d5ec1ede516c4ebec939f0/CoreFoundation/Base.subproj/CFSystemDirectories.c"; + url = "https://raw.githubusercontent.com/apple/swift-corelibs-foundation/9a5d8420f7793e63a8d5ec1ede516c4ebec939f0/CoreFoundation/Base.subproj/CFSystemDirectories.c"; sha256 = "0krfyghj4f096arvvpf884ra5czqlmbrgf8yyc0b3avqmb613pcc"; }; in @@ -15,14 +29,24 @@ stdenv.mkDerivation { version = "unstable-2018-09-14"; src = fetchFromGitHub { - owner = "apple"; - repo = "swift-corelibs-foundation"; - rev = "71aaba20e1450a82c516af1342fe23268e15de0a"; + owner = "apple"; + repo = "swift-corelibs-foundation"; + rev = "71aaba20e1450a82c516af1342fe23268e15de0a"; sha256 = "17kpql0f27xxz4jjw84vpas5f5sn4vdqwv10g151rc3rswbwln1z"; }; - nativeBuildInputs = [ cmake pkg-config python3Minimal ]; - buildInputs = [ (lib.getDev launchd) libdispatch libxml2 objc4 icu ]; + nativeBuildInputs = [ + cmake + pkg-config + python3Minimal + ]; + buildInputs = [ + (lib.getDev launchd) + libdispatch + libxml2 + objc4 + icu + ]; patches = [ ./0001-Add-missing-TARGET_OS_-defines.patch diff --git a/pkgs/os-specific/darwin/swift-corelibs/libdispatch.nix b/pkgs/os-specific/darwin/swift-corelibs/libdispatch.nix index a5b4b2a52df16f..ed3512d7b5adc6 100644 --- a/pkgs/os-specific/darwin/swift-corelibs/libdispatch.nix +++ b/pkgs/os-specific/darwin/swift-corelibs/libdispatch.nix @@ -1,4 +1,10 @@ -{ stdenv, fetchFromGitHub, cmake, apple_sdk_sierra, xnu-new }: +{ + stdenv, + fetchFromGitHub, + cmake, + apple_sdk_sierra, + xnu-new, +}: stdenv.mkDerivation rec { name = "swift-corelibs-libdispatch"; @@ -9,5 +15,8 @@ stdenv.mkDerivation rec { sha256 = "1czkyyc9llq2mnqfp19mzcfsxzas0y8zrk0gr5hg60acna6jkz2l"; }; nativeBuildInputs = [ cmake ]; - buildInputs = [ apple_sdk_sierra.sdk xnu-new ]; + buildInputs = [ + apple_sdk_sierra.sdk + xnu-new + ]; } diff --git a/pkgs/os-specific/darwin/trash/default.nix b/pkgs/os-specific/darwin/trash/default.nix index a239f6607b1fbc..d3bfcf6420d1c4 100644 --- a/pkgs/os-specific/darwin/trash/default.nix +++ b/pkgs/os-specific/darwin/trash/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, perl, AppKit, Cocoa, ScriptingBridge }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, + AppKit, + Cocoa, + ScriptingBridge, +}: stdenv.mkDerivation rec { version = "0.9.2"; @@ -11,7 +19,12 @@ stdenv.mkDerivation rec { sha256 = "1d3rc03vgz32faj7qi18iiggxvxlqrj9lsk5jkpa9r1mcs5d89my"; }; - buildInputs = [ perl Cocoa AppKit ScriptingBridge ]; + buildInputs = [ + perl + Cocoa + AppKit + ScriptingBridge + ]; patches = [ ./trash.diff ]; diff --git a/pkgs/os-specific/darwin/xcode/default.nix b/pkgs/os-specific/darwin/xcode/default.nix index 86a2255d657a91..c2d99b075d32ee 100644 --- a/pkgs/os-specific/darwin/xcode/default.nix +++ b/pkgs/os-specific/darwin/xcode/default.nix @@ -1,49 +1,59 @@ -{ stdenv, requireFile, lib }: +{ + stdenv, + requireFile, + lib, +}: -let requireXcode = version: sha256: - let - xip = "Xcode_" + version + ".xip"; +let + requireXcode = + version: sha256: + let + xip = "Xcode_" + version + ".xip"; - unxip = if stdenv.buildPlatform.isDarwin - then '' - open -W ${xip} - rm -rf ${xip} - '' - else '' - xar -xf ${xip} - rm -rf ${xip} - pbzx -n Content | cpio -i - rm Content Metadata - rcodesign verify Xcode.app/Contents/MacOS/Xcode - ''; + unxip = + if stdenv.buildPlatform.isDarwin then + '' + open -W ${xip} + rm -rf ${xip} + '' + else + '' + xar -xf ${xip} + rm -rf ${xip} + pbzx -n Content | cpio -i + rm Content Metadata + rcodesign verify Xcode.app/Contents/MacOS/Xcode + ''; - app = requireFile rec { - name = "Xcode.app"; - url = "https://developer.apple.com/services-account/download?path=/Developer_Tools/Xcode_${version}/${xip}"; - hashMode = "recursive"; - inherit sha256; - message = '' - Unfortunately, we cannot download ${name} automatically. - Please go to ${url} - to download it yourself, and add it to the Nix store by running the following commands. - Note: download (~ 5GB), extraction and storing of Xcode will take a while + app = requireFile rec { + name = "Xcode.app"; + url = "https://developer.apple.com/services-account/download?path=/Developer_Tools/Xcode_${version}/${xip}"; + hashMode = "recursive"; + inherit sha256; + message = '' + Unfortunately, we cannot download ${name} automatically. + Please go to ${url} + to download it yourself, and add it to the Nix store by running the following commands. + Note: download (~ 5GB), extraction and storing of Xcode will take a while - ${unxip} - nix-store --add-fixed --recursive sha256 Xcode.app - rm -rf Xcode.app - ''; - }; - meta = with lib; { - homepage = "https://developer.apple.com/downloads/"; - description = "Apple's XCode SDK"; - license = licenses.unfree; - platforms = platforms.darwin ++ platforms.linux; - sourceProvenance = [ sourceTypes.binaryNativeCode ]; - }; + ${unxip} + nix-store --add-fixed --recursive sha256 Xcode.app + rm -rf Xcode.app + ''; + }; + meta = with lib; { + homepage = "https://developer.apple.com/downloads/"; + description = "Apple's XCode SDK"; + license = licenses.unfree; + platforms = platforms.darwin ++ platforms.linux; + sourceProvenance = [ sourceTypes.binaryNativeCode ]; + }; - in app.overrideAttrs ( oldAttrs: oldAttrs // { inherit meta; }); + in + app.overrideAttrs (oldAttrs: oldAttrs // { inherit meta; }); -in lib.makeExtensible (self: { +in +lib.makeExtensible (self: { xcode_8_1 = requireXcode "8.1" "sha256-VuAovU/b4rcLh+xMtcsZmbTWwTk35VGfMSp+fqPbsqM="; xcode_8_2 = requireXcode "8.2" "sha256-ohqgGD7JEEmXEvmfn/N9Ga2lM8jNwhIuh+ky7PQPzY4="; xcode_9_1 = requireXcode "9.1" "sha256-LG7pVMh1rNh5uP/bASvV9sKvGDrSGWH90J4gzwcgYSk="; @@ -90,5 +100,10 @@ in lib.makeExtensible (self: { xcode_15_4 = requireXcode "15.4" "sha256-yeo+sf6bBIJy9/1sQiMuPEMPniwGXMB6/FXXL0UrI5U="; xcode_16 = requireXcode "16" "sha256-i/MMcEi5wCpe5+nGo6gUTsFFCoorORydAn7D/GClEdo="; xcode_16_1 = requireXcode "16.1" "sha256-yYg6NRRnYM/5X3hhVMfcXcdoiOV36fIongJNQ5nviD8="; - xcode = self."xcode_${lib.replaceStrings ["."] ["_"] (if (stdenv.targetPlatform ? xcodeVer) then stdenv.targetPlatform.xcodeVer else "12.3")}"; + xcode = + self."xcode_${ + lib.replaceStrings [ "." ] [ "_" ] ( + if (stdenv.targetPlatform ? xcodeVer) then stdenv.targetPlatform.xcodeVer else "12.3" + ) + }"; }) diff --git a/pkgs/os-specific/darwin/xcode/sdk-pkgs.nix b/pkgs/os-specific/darwin/xcode/sdk-pkgs.nix index 45cb12b89f4cd3..05f9acf5b36c9b 100644 --- a/pkgs/os-specific/darwin/xcode/sdk-pkgs.nix +++ b/pkgs/os-specific/darwin/xcode/sdk-pkgs.nix @@ -1,18 +1,20 @@ -{ stdenv -, clang-unwrapped -, binutils-unwrapped -, runCommand - -, wrapBintoolsWith -, wrapCCWith -, buildIosSdk, targetIosSdkPkgs -, xcode -, lib +{ + stdenv, + clang-unwrapped, + binutils-unwrapped, + runCommand, + + wrapBintoolsWith, + wrapCCWith, + buildIosSdk, + targetIosSdkPkgs, + xcode, + lib, }: let -minSdkVersion = stdenv.targetPlatform.minSdkVersion or "9.0"; + minSdkVersion = stdenv.targetPlatform.minSdkVersion or "9.0"; in @@ -20,7 +22,9 @@ rec { sdk = rec { name = "ios-sdk"; type = "derivation"; - outPath = xcode + "/Contents/Developer/Platforms/${platform}.platform/Developer/SDKs/${platform}${version}.sdk"; + outPath = + xcode + + "/Contents/Developer/Platforms/${platform}.platform/Developer/SDKs/${platform}${version}.sdk"; platform = stdenv.targetPlatform.xcodePlatform or ""; version = stdenv.targetPlatform.sdkVer or ""; @@ -31,31 +35,39 @@ rec { bintools = binutils-unwrapped; }; - clang = (wrapCCWith { - cc = clang-unwrapped; - bintools = binutils; - libc = targetIosSdkPkgs.libraries; - extraPackages = [ "${sdk}/System" ]; - extraBuildCommands = '' - tr '\n' ' ' < $out/nix-support/cc-cflags > cc-cflags.tmp - mv cc-cflags.tmp $out/nix-support/cc-cflags - echo "-target ${stdenv.targetPlatform.config}" >> $out/nix-support/cc-cflags - echo "-isystem ${sdk}/usr/include${lib.optionalString (lib.versionAtLeast "10" sdk.version) " -isystem ${sdk}/usr/include/c++/4.2.1/ -stdlib=libstdc++"}" >> $out/nix-support/cc-cflags - ${lib.optionalString (lib.versionAtLeast sdk.version "14") "echo -isystem ${xcode}/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/include/c++/v1 >> $out/nix-support/cc-cflags"} - ''; - }) // { - inherit sdk; - }; - - libraries = let sdk = buildIosSdk; in runCommand "libSystem-prebuilt" { - passthru = { + clang = + (wrapCCWith { + cc = clang-unwrapped; + bintools = binutils; + libc = targetIosSdkPkgs.libraries; + extraPackages = [ "${sdk}/System" ]; + extraBuildCommands = '' + tr '\n' ' ' < $out/nix-support/cc-cflags > cc-cflags.tmp + mv cc-cflags.tmp $out/nix-support/cc-cflags + echo "-target ${stdenv.targetPlatform.config}" >> $out/nix-support/cc-cflags + echo "-isystem ${sdk}/usr/include${lib.optionalString (lib.versionAtLeast "10" sdk.version) " -isystem ${sdk}/usr/include/c++/4.2.1/ -stdlib=libstdc++"}" >> $out/nix-support/cc-cflags + ${lib.optionalString (lib.versionAtLeast sdk.version "14") "echo -isystem ${xcode}/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/include/c++/v1 >> $out/nix-support/cc-cflags"} + ''; + }) + // { inherit sdk; }; - } '' - if ! [ -d ${sdk} ]; then - echo "You must have version ${sdk.version} of the ${sdk.platform} sdk installed at ${sdk}" >&2 - exit 1 - fi - ln -s ${sdk}/usr $out - ''; + + libraries = + let + sdk = buildIosSdk; + in + runCommand "libSystem-prebuilt" + { + passthru = { + inherit sdk; + }; + } + '' + if ! [ -d ${sdk} ]; then + echo "You must have version ${sdk.version} of the ${sdk.platform} sdk installed at ${sdk}" >&2 + exit 1 + fi + ln -s ${sdk}/usr $out + ''; } diff --git a/pkgs/os-specific/linux/acpi-call/default.nix b/pkgs/os-specific/linux/acpi-call/default.nix index f812316fd77494..0b4101246930f5 100644 --- a/pkgs/os-specific/linux/acpi-call/default.nix +++ b/pkgs/os-specific/linux/acpi-call/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { pname = "acpi-call"; @@ -26,7 +31,10 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - maintainers = with maintainers; [ raskin mic92 ]; + maintainers = with maintainers; [ + raskin + mic92 + ]; homepage = "https://github.com/nix-community/acpi_call"; platforms = platforms.linux; description = "Module allowing arbitrary ACPI calls; use case: hybrid video"; diff --git a/pkgs/os-specific/linux/akvcam/default.nix b/pkgs/os-specific/linux/akvcam/default.nix index 3fdb247a33ebb1..f7c4a9edbc1a01 100644 --- a/pkgs/os-specific/linux/akvcam/default.nix +++ b/pkgs/os-specific/linux/akvcam/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { pname = "akvcam"; diff --git a/pkgs/os-specific/linux/anbox/default.nix b/pkgs/os-specific/linux/anbox/default.nix index 35d8a071fe111e..76b2617f0eeb86 100644 --- a/pkgs/os-specific/linux/anbox/default.nix +++ b/pkgs/os-specific/linux/anbox/default.nix @@ -1,31 +1,37 @@ -{ lib, stdenv, fetchFromGitHub -, callPackage -, fetchpatch -, cmake, pkg-config, dbus, makeWrapper -, boost -, elfutils # for libdw -, git -, glib -, glm -, gtest -, libbfd -, libcap -, libdwarf -, libGL -, libglvnd -, lxc -, mesa -, properties-cpp -, protobuf -, protobufc -, python3 -, runtimeShell -, SDL2 -, SDL2_image -, systemd -, writeText -, writeShellScript -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + callPackage, + fetchpatch, + cmake, + pkg-config, + dbus, + makeWrapper, + boost, + elfutils, # for libdw + git, + glib, + glm, + gtest, + libbfd, + libcap, + libdwarf, + libGL, + libglvnd, + lxc, + mesa, + properties-cpp, + protobuf, + protobufc, + python3, + runtimeShell, + SDL2, + SDL2_image, + systemd, + writeText, + writeShellScript, + nixosTests, }: let @@ -77,7 +83,8 @@ stdenv.mkDerivation rec { properties-cpp protobuf python3 - SDL2 SDL2_image + SDL2 + SDL2_image systemd ]; @@ -87,7 +94,7 @@ stdenv.mkDerivation rec { "-Wno-error=redundant-move" # Flag needed by GCC 12 but unrecognized by GCC 9 (aarch64-linux default now) (lib.optionalString (lib.versionAtLeast stdenv.cc.version "12") "-Wno-error=mismatched-new-delete") - ]); + ]); prePatch = '' patchShebangs scripts @@ -143,7 +150,12 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/anbox \ --set SDL_VIDEO_X11_WMCLASS "anbox" \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [libGL libglvnd]} \ + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + libGL + libglvnd + ] + } \ --prefix PATH : ${git}/bin mkdir -p $out/share/dbus-1/services @@ -167,7 +179,11 @@ stdenv.mkDerivation rec { description = "Android in a box"; license = licenses.gpl2Only; maintainers = with maintainers; [ edwtjo ]; - platforms = [ "armv7l-linux" "aarch64-linux" "x86_64-linux" ]; + platforms = [ + "armv7l-linux" + "aarch64-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/os-specific/linux/anbox/postmarketos-image.nix b/pkgs/os-specific/linux/anbox/postmarketos-image.nix index 648a1a5ea9a09a..5bcaa721e975d7 100644 --- a/pkgs/os-specific/linux/anbox/postmarketos-image.nix +++ b/pkgs/os-specific/linux/anbox/postmarketos-image.nix @@ -3,17 +3,18 @@ let imgroot = "https://web.archive.org/web/20211027150924/https://anbox.postmarketos.org"; in - { - armv7l-linux = fetchurl { - url = imgroot + "/android-7.1.2_r39.1-anbox_armv7a_neon-userdebug.img"; - sha256 = "1bgzqw4yp52a2q40dr1jlay1nh73jl5mx6wqsxvpb09xghxsng0a"; - }; - aarch64-linux = fetchurl { - url = imgroot + "/android-7.1.2_r39-anbox_arm64-userdebug.img"; - sha256 = "0dx8mhfcjbkak982zfh65bvy35slz5jk31yl4ara50ryrxsp32nx"; - }; - x86_64-linux = fetchurl { - url = imgroot + "/android-7.1.2_r39-anbox_x86_64-userdebug.img"; - sha256 = "16vmiz5al2r19wjpd44nagvz7d901ljxdms8gjp2w4xz1d91vzpm"; - }; - }.${stdenv.system} or (throw "Unsupported platform ${stdenv.system}") +{ + armv7l-linux = fetchurl { + url = imgroot + "/android-7.1.2_r39.1-anbox_armv7a_neon-userdebug.img"; + sha256 = "1bgzqw4yp52a2q40dr1jlay1nh73jl5mx6wqsxvpb09xghxsng0a"; + }; + aarch64-linux = fetchurl { + url = imgroot + "/android-7.1.2_r39-anbox_arm64-userdebug.img"; + sha256 = "0dx8mhfcjbkak982zfh65bvy35slz5jk31yl4ara50ryrxsp32nx"; + }; + x86_64-linux = fetchurl { + url = imgroot + "/android-7.1.2_r39-anbox_x86_64-userdebug.img"; + sha256 = "16vmiz5al2r19wjpd44nagvz7d901ljxdms8gjp2w4xz1d91vzpm"; + }; +} +.${stdenv.system} or (throw "Unsupported platform ${stdenv.system}") diff --git a/pkgs/os-specific/linux/apfs/default.nix b/pkgs/os-specific/linux/apfs/default.nix index 551c58d6a9a7d6..d8bf15f0a8458d 100644 --- a/pkgs/os-specific/linux/apfs/default.nix +++ b/pkgs/os-specific/linux/apfs/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, kernel -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + nixosTests, }: let diff --git a/pkgs/os-specific/linux/asus-ec-sensors/default.nix b/pkgs/os-specific/linux/asus-ec-sensors/default.nix index ae5c370ed21f65..46b362bc47efb5 100644 --- a/pkgs/os-specific/linux/asus-ec-sensors/default.nix +++ b/pkgs/os-specific/linux/asus-ec-sensors/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { name = "asus-ec-sensors-${version}-${kernel.version}"; diff --git a/pkgs/os-specific/linux/asus-wmi-sensors/default.nix b/pkgs/os-specific/linux/asus-wmi-sensors/default.nix index 074b2e4ff25af2..c73086722de5d4 100644 --- a/pkgs/os-specific/linux/asus-wmi-sensors/default.nix +++ b/pkgs/os-specific/linux/asus-wmi-sensors/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { name = "asus-wmi-sensors-${version}-${kernel.version}"; @@ -30,7 +35,10 @@ stdenv.mkDerivation rec { description = "Linux HWMON (lmsensors) sensors driver for various ASUS Ryzen and Threadripper motherboards"; homepage = "https://github.com/electrified/asus-wmi-sensors"; license = licenses.gpl2Only; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = with maintainers; [ Frostman ]; broken = versionOlder kernel.version "4.12"; }; diff --git a/pkgs/os-specific/linux/ax99100/default.nix b/pkgs/os-specific/linux/ax99100/default.nix index 0e99d9390c15f2..3641fc59b4e8a3 100644 --- a/pkgs/os-specific/linux/ax99100/default.nix +++ b/pkgs/os-specific/linux/ax99100/default.nix @@ -1,10 +1,20 @@ -{ kernel, stdenv, kmod, lib, fetchzip, dos2unix }: +{ + kernel, + stdenv, + kmod, + lib, + fetchzip, + dos2unix, +}: stdenv.mkDerivation { pname = "ax99100"; version = "1.8.0"; - nativeBuildInputs = [ dos2unix kmod ] ++ kernel.moduleBuildDependencies; + nativeBuildInputs = [ + dos2unix + kmod + ] ++ kernel.moduleBuildDependencies; src = fetchzip { url = "https://www.asix.com.tw/en/support/download/file/1229"; @@ -23,13 +33,15 @@ stdenv.mkDerivation { # We included them here instead of fetching them, because of line # ending issues that are easier to fix manually. Also the # set_termios patch needs to be applied for 6.1 not for 6.0. - patches = [ - ./kernel-5.18-pci_free_consistent-pci_alloc_consistent.patch - ./kernel-6.1-set_termios-const-ktermios.patch - ] ++ lib.optionals (lib.versionAtLeast kernel.version "6.2") [ - ./kernel-6.2-fix-pointer-type.patch - ./kernel-6.4-fix-define-semaphore.patch - ]; + patches = + [ + ./kernel-5.18-pci_free_consistent-pci_alloc_consistent.patch + ./kernel-6.1-set_termios-const-ktermios.patch + ] + ++ lib.optionals (lib.versionAtLeast kernel.version "6.2") [ + ./kernel-6.2-fix-pointer-type.patch + ./kernel-6.4-fix-define-semaphore.patch + ]; patchFlags = [ "-p0" ]; diff --git a/pkgs/os-specific/linux/batman-adv/alfred.nix b/pkgs/os-specific/linux/batman-adv/alfred.nix index 26c433b8a06d9e..925ff2bb169aaf 100644 --- a/pkgs/os-specific/linux/batman-adv/alfred.nix +++ b/pkgs/os-specific/linux/batman-adv/alfred.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchurl, pkg-config, gpsd, libcap, libnl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + gpsd, + libcap, + libnl, +}: -let cfg = import ./version.nix; in +let + cfg = import ./version.nix; +in stdenv.mkDerivation rec { pname = "alfred"; @@ -12,7 +22,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gpsd libcap libnl ]; + buildInputs = [ + gpsd + libcap + libnl + ]; preBuild = '' makeFlags="PREFIX=$out" diff --git a/pkgs/os-specific/linux/batman-adv/batctl.nix b/pkgs/os-specific/linux/batman-adv/batctl.nix index e42b1b18d58411..f01508ac7572ae 100644 --- a/pkgs/os-specific/linux/batman-adv/batctl.nix +++ b/pkgs/os-specific/linux/batman-adv/batctl.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchurl, pkg-config, libnl }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + libnl, +}: -let cfg = import ./version.nix; in +let + cfg = import ./version.nix; +in stdenv.mkDerivation rec { pname = "batctl"; diff --git a/pkgs/os-specific/linux/batman-adv/default.nix b/pkgs/os-specific/linux/batman-adv/default.nix index 8fa54664fb4dd0..d9a7890ae98a4f 100644 --- a/pkgs/os-specific/linux/batman-adv/default.nix +++ b/pkgs/os-specific/linux/batman-adv/default.nix @@ -1,10 +1,13 @@ -{ lib -, stdenv -, fetchurl -, kernel +{ + lib, + stdenv, + fetchurl, + kernel, }: -let cfg = import ./version.nix; in +let + cfg = import ./version.nix; +in stdenv.mkDerivation rec { pname = "batman-adv"; @@ -31,7 +34,10 @@ stdenv.mkDerivation rec { homepage = "https://www.open-mesh.org/projects/batman-adv/wiki/Wiki"; description = "B.A.T.M.A.N. routing protocol in a linux kernel module for layer 2"; license = lib.licenses.gpl2Only; - maintainers = with lib.maintainers; [ fpletz philiptaron ]; + maintainers = with lib.maintainers; [ + fpletz + philiptaron + ]; platforms = with lib.platforms; linux; }; } diff --git a/pkgs/os-specific/linux/bbswitch/default.nix b/pkgs/os-specific/linux/bbswitch/default.nix index a65bcab50ee25f..67c4bcbbcb0fdb 100644 --- a/pkgs/os-specific/linux/bbswitch/default.nix +++ b/pkgs/os-specific/linux/bbswitch/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, kernel, runtimeShell }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + kernel, + runtimeShell, +}: let baseName = "bbswitch"; @@ -56,7 +63,10 @@ stdenv.mkDerivation { meta = with lib; { description = "Module for powering off hybrid GPUs"; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; homepage = "https://github.com/Bumblebee-Project/bbswitch"; maintainers = with maintainers; [ abbradar ]; license = licenses.gpl2Plus; diff --git a/pkgs/os-specific/linux/bionic-prebuilt/default.nix b/pkgs/os-specific/linux/bionic-prebuilt/default.nix index 6aad7ebcacb372..be53b12a42ce59 100644 --- a/pkgs/os-specific/linux/bionic-prebuilt/default.nix +++ b/pkgs/os-specific/linux/bionic-prebuilt/default.nix @@ -1,16 +1,23 @@ -{ stdenv, stdenvNoCC, lib, fetchzip, pkgs -, enableStatic ? stdenv.hostPlatform.isStatic -, enableShared ? !stdenv.hostPlatform.isStatic +{ + stdenv, + stdenvNoCC, + lib, + fetchzip, + pkgs, + enableStatic ? stdenv.hostPlatform.isStatic, + enableShared ? !stdenv.hostPlatform.isStatic, }: let choosePlatform = - let pname = stdenv.hostPlatform.parsed.cpu.name; in + let + pname = stdenv.hostPlatform.parsed.cpu.name; + in pset: pset.${pname} or (throw "bionic-prebuilt: unsupported platform ${pname}"); prebuilt_crt = choosePlatform { aarch64 = fetchzip { - url = "https://android.googlesource.com/platform/prebuilts/gcc/linux-x86/aarch64/aarch64-linux-android-4.9/+archive/98dce673ad97a9640c5d90bbb1c718e75c21e071/lib/gcc/aarch64-linux-android/4.9.x.tar.gz"; + url = "https://android.googlesource.com/platform/prebuilts/gcc/linux-x86/aarch64/aarch64-linux-android-4.9/+archive/98dce673ad97a9640c5d90bbb1c718e75c21e071/lib/gcc/aarch64-linux-android/4.9.x.tar.gz"; sha256 = "sha256-LLD2OJi78sNN5NulOsJZl7Ei4F1EUYItGG6eUsKWULc="; stripRoot = false; }; @@ -48,7 +55,7 @@ let }; ndk_support_headers = fetchzip { - url ="https://android.googlesource.com/platform/prebuilts/clang/host/linux-x86/+archive/0e7f808fa26cce046f444c9616d9167dafbfb272/clang-r416183b/include/c++/v1/support.tar.gz"; + url = "https://android.googlesource.com/platform/prebuilts/clang/host/linux-x86/+archive/0e7f808fa26cce046f444c9616d9167dafbfb272/clang-r416183b/include/c++/v1/support.tar.gz"; sha256 = "sha256-NBv7Pk1CEaz8ns9moleEERr3x/rFmVmG33LgFSeO6fY="; stripRoot = false; }; @@ -90,59 +97,66 @@ stdenvNoCC.mkDerivation rec { "!defined(BIONIC_IOCTL_NO_SIGNEDNESS_OVERLOAD)" "0" ''; - installPhase= '' - # copy the bionic headers - mkdir -p $out/include/support $out/include/android - cp -vr libc/include/* $out/include - # copy the kernel headers - cp -vr ${kernelHeaders}/include/* $out/include/ - - chmod -R +w $out/include/linux - - # fix a bunch of kernel headers so that things can actually be found - sed -i 's,struct epoll_event {,#include \nstruct Xepoll_event {,' $out/include/linux/eventpoll.h - sed -i 's,struct in_addr {,typedef unsigned int in_addr_t;\nstruct in_addr {,' $out/include/linux/in.h - sed -i 's,struct udphdr {,struct Xudphdr {,' $out/include/linux/udp.h - sed -i 's,union semun {,union Xsemun {,' $out/include/linux/sem.h - sed -i 's,struct __kernel_sockaddr_storage,#define sockaddr_storage __kernel_sockaddr_storage\nstruct __kernel_sockaddr_storage,' $out/include/linux/socket.h - sed -i 's,#ifndef __UAPI_DEF_.*$,#if 1,' $out/include/linux/libc-compat.h - substituteInPlace $out/include/linux/in.h --replace "__be32 imr_" "struct in_addr imr_" - substituteInPlace $out/include/linux/in.h --replace "__be32 imsf_" "struct in_addr imsf_" - substituteInPlace $out/include/linux/sysctl.h --replace "__unused" "_unused" - - # what could possibly live in - touch $out/include/linux/compiler.h - - # copy the support headers - cp -vr ${ndk_support_headers}* $out/include/support/ - - mkdir $out/lib - cp -v ${prebuilt_crt.out}/*.o $out/lib/ - cp -v ${prebuilt_crt.out}/libgcc.a $out/lib/ - cp -v ${prebuilt_ndk_crt.out}/*.o $out/lib/ - '' + lib.optionalString enableShared '' - for i in libc.so libm.so libdl.so liblog.so; do - cp -v ${prebuilt_libs.out}/$i $out/lib/ - done - '' + lib.optionalString enableStatic '' - # no liblog.a; while it's also part of the base libraries, - # it's only available as shared object in the prebuilts. - for i in libc.a libm.a libdl.a; do - cp -v ${prebuilt_ndk_crt.out}/$i $out/lib/ - done - '' + '' - mkdir -p $dev/include - cp -v $out/include/*.h $dev/include/ - ''; - - outputs = [ "out" "dev" ]; + installPhase = + '' + # copy the bionic headers + mkdir -p $out/include/support $out/include/android + cp -vr libc/include/* $out/include + # copy the kernel headers + cp -vr ${kernelHeaders}/include/* $out/include/ + + chmod -R +w $out/include/linux + + # fix a bunch of kernel headers so that things can actually be found + sed -i 's,struct epoll_event {,#include \nstruct Xepoll_event {,' $out/include/linux/eventpoll.h + sed -i 's,struct in_addr {,typedef unsigned int in_addr_t;\nstruct in_addr {,' $out/include/linux/in.h + sed -i 's,struct udphdr {,struct Xudphdr {,' $out/include/linux/udp.h + sed -i 's,union semun {,union Xsemun {,' $out/include/linux/sem.h + sed -i 's,struct __kernel_sockaddr_storage,#define sockaddr_storage __kernel_sockaddr_storage\nstruct __kernel_sockaddr_storage,' $out/include/linux/socket.h + sed -i 's,#ifndef __UAPI_DEF_.*$,#if 1,' $out/include/linux/libc-compat.h + substituteInPlace $out/include/linux/in.h --replace "__be32 imr_" "struct in_addr imr_" + substituteInPlace $out/include/linux/in.h --replace "__be32 imsf_" "struct in_addr imsf_" + substituteInPlace $out/include/linux/sysctl.h --replace "__unused" "_unused" + + # what could possibly live in + touch $out/include/linux/compiler.h + + # copy the support headers + cp -vr ${ndk_support_headers}* $out/include/support/ + + mkdir $out/lib + cp -v ${prebuilt_crt.out}/*.o $out/lib/ + cp -v ${prebuilt_crt.out}/libgcc.a $out/lib/ + cp -v ${prebuilt_ndk_crt.out}/*.o $out/lib/ + '' + + lib.optionalString enableShared '' + for i in libc.so libm.so libdl.so liblog.so; do + cp -v ${prebuilt_libs.out}/$i $out/lib/ + done + '' + + lib.optionalString enableStatic '' + # no liblog.a; while it's also part of the base libraries, + # it's only available as shared object in the prebuilts. + for i in libc.a libm.a libdl.a; do + cp -v ${prebuilt_ndk_crt.out}/$i $out/lib/ + done + '' + + '' + mkdir -p $dev/include + cp -v $out/include/*.h $dev/include/ + ''; + + outputs = [ + "out" + "dev" + ]; passthru.linuxHeaders = kernelHeaders; meta = with lib; { description = "Android libc implementation"; - homepage = "https://android.googlesource.com/platform/bionic/"; - license = licenses.mit; - platforms = platforms.linux; + homepage = "https://android.googlesource.com/platform/bionic/"; + license = licenses.mit; + platforms = platforms.linux; maintainers = with maintainers; [ s1341 ]; }; } diff --git a/pkgs/os-specific/linux/busybox/sandbox-shell.nix b/pkgs/os-specific/linux/busybox/sandbox-shell.nix index 38df716997ca9d..1458dafcd5e101 100644 --- a/pkgs/os-specific/linux/busybox/sandbox-shell.nix +++ b/pkgs/os-specific/linux/busybox/sandbox-shell.nix @@ -1,29 +1,37 @@ -{ lib, stdenv, busybox, musl }: +{ + lib, + stdenv, + busybox, + musl, +}: # Minimal shell for use as basic /bin/sh in sandbox builds -busybox.override ({ - enableStatic = true; - enableMinimal = true; +busybox.override ( + { + enableStatic = true; + enableMinimal = true; - extraConfig = '' - CONFIG_FEATURE_FANCY_ECHO y - CONFIG_FEATURE_SH_MATH y - CONFIG_FEATURE_SH_MATH_64 y - CONFIG_FEATURE_TEST_64 y + extraConfig = '' + CONFIG_FEATURE_FANCY_ECHO y + CONFIG_FEATURE_SH_MATH y + CONFIG_FEATURE_SH_MATH_64 y + CONFIG_FEATURE_TEST_64 y - CONFIG_ASH y - CONFIG_ASH_OPTIMIZE_FOR_SIZE y + CONFIG_ASH y + CONFIG_ASH_OPTIMIZE_FOR_SIZE y - CONFIG_ASH_ALIAS y - CONFIG_ASH_BASH_COMPAT y - CONFIG_ASH_CMDCMD y - CONFIG_ASH_ECHO y - CONFIG_ASH_GETOPTS y - CONFIG_ASH_INTERNAL_GLOB y - CONFIG_ASH_JOB_CONTROL y - CONFIG_ASH_PRINTF y - CONFIG_ASH_TEST y - ''; -} // lib.optionalAttrs (stdenv.hostPlatform.isGnu && lib.meta.availableOn stdenv.hostPlatform musl) { - useMusl = true; -}) + CONFIG_ASH_ALIAS y + CONFIG_ASH_BASH_COMPAT y + CONFIG_ASH_CMDCMD y + CONFIG_ASH_ECHO y + CONFIG_ASH_GETOPTS y + CONFIG_ASH_INTERNAL_GLOB y + CONFIG_ASH_JOB_CONTROL y + CONFIG_ASH_PRINTF y + CONFIG_ASH_TEST y + ''; + } + // lib.optionalAttrs (stdenv.hostPlatform.isGnu && lib.meta.availableOn stdenv.hostPlatform musl) { + useMusl = true; + } +) diff --git a/pkgs/os-specific/linux/can-isotp/default.nix b/pkgs/os-specific/linux/can-isotp/default.nix index 06329478ded463..1a6f78d82824ae 100644 --- a/pkgs/os-specific/linux/can-isotp/default.nix +++ b/pkgs/os-specific/linux/can-isotp/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, kernel, fetchFromGitHub }: +{ + lib, + stdenv, + kernel, + fetchFromGitHub, +}: stdenv.mkDerivation { pname = "can-isotp"; diff --git a/pkgs/os-specific/linux/conky/default.nix b/pkgs/os-specific/linux/conky/default.nix index de2c16b8d55c58..63ad87c6a1fa8a 100644 --- a/pkgs/os-specific/linux/conky/default.nix +++ b/pkgs/os-specific/linux/conky/default.nix @@ -1,68 +1,99 @@ -{ config, lib, stdenv, fetchFromGitHub, pkg-config, cmake - -# dependencies -, glib, libXinerama, catch2 - -# lib.optional features without extra dependencies -, mpdSupport ? true -, ibmSupport ? true # IBM/Lenovo notebooks - -# lib.optional features with extra dependencies - -# ouch, this is ugly, but this gives the man page -, docsSupport ? true, docbook2x, libxslt ? null - , man ? null, less ? null - , docbook_xsl ? null , docbook_xml_dtd_44 ? null - -, ncursesSupport ? true , ncurses ? null -, x11Support ? true , freetype, xorg -, waylandSupport ? true , pango, wayland, wayland-protocols, wayland-scanner -, xdamageSupport ? x11Support, libXdamage ? null -, doubleBufferSupport ? x11Support -, imlib2Support ? x11Support, imlib2 ? null - -, luaSupport ? true , lua ? null -, luaImlib2Support ? luaSupport && imlib2Support -, luaCairoSupport ? luaSupport && (x11Support || waylandSupport), cairo ? null -, toluapp ? null - -, wirelessSupport ? true , wirelesstools ? null -, nvidiaSupport ? false , libXNVCtrl ? null -, pulseSupport ? config.pulseaudio or false, libpulseaudio ? null - -, curlSupport ? true , curl ? null -, rssSupport ? curlSupport -, weatherMetarSupport ? curlSupport -, weatherXoapSupport ? curlSupport -, journalSupport ? true, systemd ? null -, libxml2 ? null +{ + config, + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + + # dependencies + glib, + libXinerama, + catch2, + + # lib.optional features without extra dependencies + mpdSupport ? true, + ibmSupport ? true, # IBM/Lenovo notebooks + + # lib.optional features with extra dependencies + + # ouch, this is ugly, but this gives the man page + docsSupport ? true, + docbook2x, + libxslt ? null, + man ? null, + less ? null, + docbook_xsl ? null, + docbook_xml_dtd_44 ? null, + + ncursesSupport ? true, + ncurses ? null, + x11Support ? true, + freetype, + xorg, + waylandSupport ? true, + pango, + wayland, + wayland-protocols, + wayland-scanner, + xdamageSupport ? x11Support, + libXdamage ? null, + doubleBufferSupport ? x11Support, + imlib2Support ? x11Support, + imlib2 ? null, + + luaSupport ? true, + lua ? null, + luaImlib2Support ? luaSupport && imlib2Support, + luaCairoSupport ? luaSupport && (x11Support || waylandSupport), + cairo ? null, + toluapp ? null, + + wirelessSupport ? true, + wirelesstools ? null, + nvidiaSupport ? false, + libXNVCtrl ? null, + pulseSupport ? config.pulseaudio or false, + libpulseaudio ? null, + + curlSupport ? true, + curl ? null, + rssSupport ? curlSupport, + weatherMetarSupport ? curlSupport, + weatherXoapSupport ? curlSupport, + journalSupport ? true, + systemd ? null, + libxml2 ? null, }: -assert docsSupport -> docbook2x != null && libxslt != null - && man != null && less != null - && docbook_xsl != null && docbook_xml_dtd_44 != null; - -assert ncursesSupport -> ncurses != null; - -assert xdamageSupport -> x11Support && libXdamage != null; -assert imlib2Support -> x11Support && imlib2 != null; -assert luaSupport -> lua != null; -assert luaImlib2Support -> luaSupport && imlib2Support - && toluapp != null; -assert luaCairoSupport -> luaSupport && toluapp != null - && cairo != null; -assert luaCairoSupport || luaImlib2Support - -> lua.luaversion == "5.4"; - -assert wirelessSupport -> wirelesstools != null; -assert nvidiaSupport -> libXNVCtrl != null; -assert pulseSupport -> libpulseaudio != null; - -assert curlSupport -> curl != null; -assert rssSupport -> curlSupport && libxml2 != null; +assert + docsSupport + -> + docbook2x != null + && libxslt != null + && man != null + && less != null + && docbook_xsl != null + && docbook_xml_dtd_44 != null; + +assert ncursesSupport -> ncurses != null; + +assert xdamageSupport -> x11Support && libXdamage != null; +assert imlib2Support -> x11Support && imlib2 != null; +assert luaSupport -> lua != null; +assert luaImlib2Support -> luaSupport && imlib2Support && toluapp != null; +assert luaCairoSupport -> luaSupport && toluapp != null && cairo != null; +assert luaCairoSupport || luaImlib2Support -> lua.luaversion == "5.4"; + +assert wirelessSupport -> wirelesstools != null; +assert nvidiaSupport -> libXNVCtrl != null; +assert pulseSupport -> libpulseaudio != null; + +assert curlSupport -> curl != null; +assert rssSupport -> curlSupport && libxml2 != null; assert weatherMetarSupport -> curlSupport; -assert weatherXoapSupport -> curlSupport && libxml2 != null; -assert journalSupport -> systemd != null; +assert weatherXoapSupport -> curlSupport && libxml2 != null; +assert journalSupport -> systemd != null; stdenv.mkDerivation rec { pname = "conky"; @@ -75,14 +106,16 @@ stdenv.mkDerivation rec { hash = "sha256-L8YSbdk+qQl17L4IRajFD/AEWRXb2w7xH9sM9qPGrQo="; }; - postPatch = lib.optionalString docsSupport '' - substituteInPlace cmake/Conky.cmake --replace "# set(RELEASE true)" "set(RELEASE true)" + postPatch = + lib.optionalString docsSupport '' + substituteInPlace cmake/Conky.cmake --replace "# set(RELEASE true)" "set(RELEASE true)" - cp ${catch2}/include/catch2/catch.hpp tests/catch2/catch.hpp - '' + lib.optionalString waylandSupport '' - substituteInPlace src/CMakeLists.txt \ - --replace 'COMMAND ''${Wayland_SCANNER}' 'COMMAND wayland-scanner' - ''; + cp ${catch2}/include/catch2/catch.hpp tests/catch2/catch.hpp + '' + + lib.optionalString waylandSupport '' + substituteInPlace src/CMakeLists.txt \ + --replace 'COMMAND ''${Wayland_SCANNER}' 'COMMAND wayland-scanner' + ''; env = { # For some reason -Werror is on by default, causing the project to fail compilation. @@ -90,51 +123,75 @@ stdenv.mkDerivation rec { NIX_LDFLAGS = "-lgcc_s"; }; - nativeBuildInputs = [ cmake pkg-config ] - ++ lib.optionals docsSupport [ docbook2x docbook_xsl docbook_xml_dtd_44 libxslt man less ] - ++ lib.optional waylandSupport wayland-scanner - ++ lib.optional luaImlib2Support toluapp - ++ lib.optional luaCairoSupport toluapp - ; - buildInputs = [ glib libXinerama ] - ++ lib.optional ncursesSupport ncurses - ++ lib.optionals x11Support [ freetype xorg.libICE xorg.libX11 xorg.libXext xorg.libXft xorg.libSM ] - ++ lib.optionals waylandSupport [ pango wayland wayland-protocols ] - ++ lib.optional xdamageSupport libXdamage - ++ lib.optional imlib2Support imlib2 - ++ lib.optional luaSupport lua - ++ lib.optional luaImlib2Support imlib2 - ++ lib.optional luaCairoSupport cairo - ++ lib.optional wirelessSupport wirelesstools - ++ lib.optional curlSupport curl - ++ lib.optional rssSupport libxml2 - ++ lib.optional weatherXoapSupport libxml2 - ++ lib.optional nvidiaSupport libXNVCtrl - ++ lib.optional pulseSupport libpulseaudio - ++ lib.optional journalSupport systemd - ; - - cmakeFlags = [] - ++ lib.optional docsSupport "-DMAINTAINER_MODE=ON" - ++ lib.optional curlSupport "-DBUILD_CURL=ON" - ++ lib.optional (!ibmSupport) "-DBUILD_IBM=OFF" - ++ lib.optional imlib2Support "-DBUILD_IMLIB2=ON" - ++ lib.optional luaCairoSupport "-DBUILD_LUA_CAIRO=ON" - ++ lib.optional luaImlib2Support "-DBUILD_LUA_IMLIB2=ON" - ++ lib.optional (!mpdSupport) "-DBUILD_MPD=OFF" - ++ lib.optional (!ncursesSupport) "-DBUILD_NCURSES=OFF" - ++ lib.optional rssSupport "-DBUILD_RSS=ON" - ++ lib.optional (!x11Support) "-DBUILD_X11=OFF" - ++ lib.optional waylandSupport "-DBUILD_WAYLAND=ON" - ++ lib.optional xdamageSupport "-DBUILD_XDAMAGE=ON" + nativeBuildInputs = + [ + cmake + pkg-config + ] + ++ lib.optionals docsSupport [ + docbook2x + docbook_xsl + docbook_xml_dtd_44 + libxslt + man + less + ] + ++ lib.optional waylandSupport wayland-scanner + ++ lib.optional luaImlib2Support toluapp + ++ lib.optional luaCairoSupport toluapp; + buildInputs = + [ + glib + libXinerama + ] + ++ lib.optional ncursesSupport ncurses + ++ lib.optionals x11Support [ + freetype + xorg.libICE + xorg.libX11 + xorg.libXext + xorg.libXft + xorg.libSM + ] + ++ lib.optionals waylandSupport [ + pango + wayland + wayland-protocols + ] + ++ lib.optional xdamageSupport libXdamage + ++ lib.optional imlib2Support imlib2 + ++ lib.optional luaSupport lua + ++ lib.optional luaImlib2Support imlib2 + ++ lib.optional luaCairoSupport cairo + ++ lib.optional wirelessSupport wirelesstools + ++ lib.optional curlSupport curl + ++ lib.optional rssSupport libxml2 + ++ lib.optional weatherXoapSupport libxml2 + ++ lib.optional nvidiaSupport libXNVCtrl + ++ lib.optional pulseSupport libpulseaudio + ++ lib.optional journalSupport systemd; + + cmakeFlags = + [ ] + ++ lib.optional docsSupport "-DMAINTAINER_MODE=ON" + ++ lib.optional curlSupport "-DBUILD_CURL=ON" + ++ lib.optional (!ibmSupport) "-DBUILD_IBM=OFF" + ++ lib.optional imlib2Support "-DBUILD_IMLIB2=ON" + ++ lib.optional luaCairoSupport "-DBUILD_LUA_CAIRO=ON" + ++ lib.optional luaImlib2Support "-DBUILD_LUA_IMLIB2=ON" + ++ lib.optional (!mpdSupport) "-DBUILD_MPD=OFF" + ++ lib.optional (!ncursesSupport) "-DBUILD_NCURSES=OFF" + ++ lib.optional rssSupport "-DBUILD_RSS=ON" + ++ lib.optional (!x11Support) "-DBUILD_X11=OFF" + ++ lib.optional waylandSupport "-DBUILD_WAYLAND=ON" + ++ lib.optional xdamageSupport "-DBUILD_XDAMAGE=ON" ++ lib.optional doubleBufferSupport "-DBUILD_XDBE=ON" ++ lib.optional weatherMetarSupport "-DBUILD_WEATHER_METAR=ON" - ++ lib.optional weatherXoapSupport "-DBUILD_WEATHER_XOAP=ON" - ++ lib.optional wirelessSupport "-DBUILD_WLAN=ON" - ++ lib.optional nvidiaSupport "-DBUILD_NVIDIA=ON" - ++ lib.optional pulseSupport "-DBUILD_PULSEAUDIO=ON" - ++ lib.optional journalSupport "-DBUILD_JOURNAL=ON" - ; + ++ lib.optional weatherXoapSupport "-DBUILD_WEATHER_XOAP=ON" + ++ lib.optional wirelessSupport "-DBUILD_WLAN=ON" + ++ lib.optional nvidiaSupport "-DBUILD_NVIDIA=ON" + ++ lib.optional pulseSupport "-DBUILD_PULSEAUDIO=ON" + ++ lib.optional journalSupport "-DBUILD_JOURNAL=ON"; # `make -f src/CMakeFiles/conky.dir/build.make src/CMakeFiles/conky.dir/conky.cc.o`: # src/conky.cc:137:23: fatal error: defconfig.h: No such file or directory diff --git a/pkgs/os-specific/linux/cpupower-gui/default.nix b/pkgs/os-specific/linux/cpupower-gui/default.nix index ca6ce58bad455d..f29cce5b8f196e 100644 --- a/pkgs/os-specific/linux/cpupower-gui/default.nix +++ b/pkgs/os-specific/linux/cpupower-gui/default.nix @@ -1,24 +1,25 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, buildPythonApplication -, appstream-glib -, dbus-python -, desktop-file-utils -, gettext -, glib -, gobject-introspection -, gtk3 -, hicolor-icon-theme -, libappindicator -, libhandy -, meson -, ninja -, pkg-config -, pygobject3 -, pyxdg -, systemd -, wrapGAppsHook3 +{ + lib, + fetchFromGitHub, + fetchpatch, + buildPythonApplication, + appstream-glib, + dbus-python, + desktop-file-utils, + gettext, + glib, + gobject-introspection, + gtk3, + hicolor-icon-theme, + libappindicator, + libhandy, + meson, + ninja, + pkg-config, + pygobject3, + pyxdg, + systemd, + wrapGAppsHook3, }: buildPythonApplication rec { diff --git a/pkgs/os-specific/linux/cpupower/default.nix b/pkgs/os-specific/linux/cpupower/default.nix index f811455f8a6291..c2e881b33c3138 100644 --- a/pkgs/os-specific/linux/cpupower/default.nix +++ b/pkgs/os-specific/linux/cpupower/default.nix @@ -1,10 +1,21 @@ -{ lib, stdenv, buildPackages, kernel, pciutils, gettext, which }: +{ + lib, + stdenv, + buildPackages, + kernel, + pciutils, + gettext, + which, +}: stdenv.mkDerivation { pname = "cpupower"; inherit (kernel) version src patches; - nativeBuildInputs = [ gettext which ]; + nativeBuildInputs = [ + gettext + which + ]; buildInputs = [ pciutils ]; postPatch = '' @@ -20,8 +31,7 @@ stdenv.mkDerivation { "LD=${stdenv.cc.targetPrefix}cc" ]; - installFlags = lib.mapAttrsToList - (n: v: "${n}dir=${placeholder "out"}/${v}") { + installFlags = lib.mapAttrsToList (n: v: "${n}dir=${placeholder "out"}/${v}") { bin = "bin"; sbin = "sbin"; man = "share/man"; diff --git a/pkgs/os-specific/linux/ddcci/default.nix b/pkgs/os-specific/linux/ddcci/default.nix index a00df68246b25f..d674daabbecaaa 100644 --- a/pkgs/os-specific/linux/ddcci/default.nix +++ b/pkgs/os-specific/linux/ddcci/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitLab, kernel, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitLab, + kernel, + fetchpatch, +}: stdenv.mkDerivation rec { pname = "ddcci-driver"; diff --git a/pkgs/os-specific/linux/dddvb/default.nix b/pkgs/os-specific/linux/dddvb/default.nix index 02c4b3a1a77100..80482cd1b211e9 100644 --- a/pkgs/os-specific/linux/dddvb/default.nix +++ b/pkgs/os-specific/linux/dddvb/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, kernel +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + kernel, }: stdenv.mkDerivation rec { diff --git a/pkgs/os-specific/linux/decklink/default.nix b/pkgs/os-specific/linux/decklink/default.nix index 4916b8630ad4d7..c5d1b570ab5100 100644 --- a/pkgs/os-specific/linux/decklink/default.nix +++ b/pkgs/os-specific/linux/decklink/default.nix @@ -1,7 +1,8 @@ -{ stdenv -, lib -, blackmagic-desktop-video -, kernel +{ + stdenv, + lib, + blackmagic-desktop-video, + kernel, }: stdenv.mkDerivation (finalAttrs: { pname = "decklink"; @@ -14,15 +15,17 @@ stdenv.mkDerivation (finalAttrs: { KERNELDIR = "${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"; INSTALL_MOD_PATH = placeholder "out"; - nativeBuildInputs = kernel.moduleBuildDependencies; + nativeBuildInputs = kernel.moduleBuildDependencies; - postUnpack = let - arch = stdenv.hostPlatform.uname.processor; - in '' - tar xf Blackmagic_Desktop_Video_Linux_${lib.head (lib.splitString "a" finalAttrs.version)}/other/${arch}/desktopvideo-${finalAttrs.version}-${arch}.tar.gz - moduleRoot=$NIX_BUILD_TOP/desktopvideo-${finalAttrs.version}-${stdenv.hostPlatform.uname.processor}/usr/src - sourceRoot=$moduleRoot - ''; + postUnpack = + let + arch = stdenv.hostPlatform.uname.processor; + in + '' + tar xf Blackmagic_Desktop_Video_Linux_${lib.head (lib.splitString "a" finalAttrs.version)}/other/${arch}/desktopvideo-${finalAttrs.version}-${arch}.tar.gz + moduleRoot=$NIX_BUILD_TOP/desktopvideo-${finalAttrs.version}-${stdenv.hostPlatform.uname.processor}/usr/src + sourceRoot=$moduleRoot + ''; buildPhase = '' runHook preBuild diff --git a/pkgs/os-specific/linux/deepin-anything-module/default.nix b/pkgs/os-specific/linux/deepin-anything-module/default.nix index 5ee7c8a35e8155..416260f3a6e64e 100644 --- a/pkgs/os-specific/linux/deepin-anything-module/default.nix +++ b/pkgs/os-specific/linux/deepin-anything-module/default.nix @@ -1,6 +1,7 @@ -{ stdenv -, deepin -, kernel +{ + stdenv, + deepin, + kernel, }: stdenv.mkDerivation { @@ -26,4 +27,3 @@ stdenv.mkDerivation { description = "Deepin Anything file search tool (kernel modules)"; }; } - diff --git a/pkgs/os-specific/linux/device-tree/default.nix b/pkgs/os-specific/linux/device-tree/default.nix index b8c71cc5a8ae33..a40c2d7c355b69 100644 --- a/pkgs/os-specific/linux/device-tree/default.nix +++ b/pkgs/os-specific/linux/device-tree/default.nix @@ -1,36 +1,49 @@ -{ lib, stdenv, stdenvNoCC, dtc, writers, python3 }: +{ + lib, + stdenv, + stdenvNoCC, + dtc, + writers, + python3, +}: { # Compile single Device Tree overlay source # file (.dts) into its compiled variant (.dtb) - compileDTS = ({ - name, - dtsFile, - includePaths ? [], - extraPreprocessorFlags ? [] - }: stdenv.mkDerivation { - inherit name; + compileDTS = ( + { + name, + dtsFile, + includePaths ? [ ], + extraPreprocessorFlags ? [ ], + }: + stdenv.mkDerivation { + inherit name; - nativeBuildInputs = [ dtc ]; + nativeBuildInputs = [ dtc ]; - buildCommand = - let - includeFlagsStr = lib.concatMapStringsSep " " (includePath: "-I${includePath}") includePaths; - extraPreprocessorFlagsStr = lib.concatStringsSep " " extraPreprocessorFlags; - in - '' - $CC -E -nostdinc ${includeFlagsStr} -undef -D__DTS__ -x assembler-with-cpp ${extraPreprocessorFlagsStr} ${dtsFile} | \ - dtc -I dts -O dtb -@ -o $out - ''; - }); + buildCommand = + let + includeFlagsStr = lib.concatMapStringsSep " " (includePath: "-I${includePath}") includePaths; + extraPreprocessorFlagsStr = lib.concatStringsSep " " extraPreprocessorFlags; + in + '' + $CC -E -nostdinc ${includeFlagsStr} -undef -D__DTS__ -x assembler-with-cpp ${extraPreprocessorFlagsStr} ${dtsFile} | \ + dtc -I dts -O dtb -@ -o $out + ''; + } + ); - applyOverlays = (base: overlays': stdenvNoCC.mkDerivation { - name = "device-tree-overlays"; - nativeBuildInputs = [ - (python3.pythonOnBuildForHost.withPackages(ps: [ps.libfdt])) - ]; - buildCommand = '' - python ${./apply_overlays.py} --source ${base} --destination $out --overlays ${writers.writeJSON "overlays.json" overlays'} - ''; - }); + applyOverlays = ( + base: overlays': + stdenvNoCC.mkDerivation { + name = "device-tree-overlays"; + nativeBuildInputs = [ + (python3.pythonOnBuildForHost.withPackages (ps: [ ps.libfdt ])) + ]; + buildCommand = '' + python ${./apply_overlays.py} --source ${base} --destination $out --overlays ${writers.writeJSON "overlays.json" overlays'} + ''; + } + ); } diff --git a/pkgs/os-specific/linux/device-tree/raspberrypi.nix b/pkgs/os-specific/linux/device-tree/raspberrypi.nix index d9ccb70f1f0375..d7617f64cfc6c8 100644 --- a/pkgs/os-specific/linux/device-tree/raspberrypi.nix +++ b/pkgs/os-specific/linux/device-tree/raspberrypi.nix @@ -1,4 +1,8 @@ -{ lib, stdenvNoCC, raspberrypifw }: +{ + lib, + stdenvNoCC, + raspberrypifw, +}: stdenvNoCC.mkDerivation { pname = "raspberrypi-dtbs"; diff --git a/pkgs/os-specific/linux/dmraid/default.nix b/pkgs/os-specific/linux/dmraid/default.nix index fa26f38941b93e..ab366ad88ad556 100644 --- a/pkgs/os-specific/linux/dmraid/default.nix +++ b/pkgs/os-specific/linux/dmraid/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, fetchpatch, lvm2 }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + lvm2, +}: stdenv.mkDerivation rec { pname = "dmraid"; @@ -9,7 +15,8 @@ stdenv.mkDerivation rec { sha256 = "0m92971gyqp61darxbiri6a48jz3wq3gkp8r2k39320z0i6w8jgq"; }; - patches = [ ./hardening-format.patch ] + patches = + [ ./hardening-format.patch ] ++ lib.optionals stdenv.hostPlatform.isMusl [ (fetchpatch { url = "https://raw.githubusercontent.com/void-linux/void-packages/fceed4b8e96b3c1da07babf6f67b6ed1588a28b2/srcpkgs/dmraid/patches/006-musl-libc.patch"; @@ -25,11 +32,13 @@ stdenv.mkDerivation rec { }) ]; - postPatch = '' - sed -i 's/\[\[[^]]*\]\]/[ "''$''${n##*.}" = "so" ]/' */lib/Makefile.in - '' + lib.optionalString stdenv.hostPlatform.isMusl '' - NIX_CFLAGS_COMPILE+=" -D_GNU_SOURCE" - ''; + postPatch = + '' + sed -i 's/\[\[[^]]*\]\]/[ "''$''${n##*.}" = "so" ]/' */lib/Makefile.in + '' + + lib.optionalString stdenv.hostPlatform.isMusl '' + NIX_CFLAGS_COMPILE+=" -D_GNU_SOURCE" + ''; preConfigure = "cd */"; diff --git a/pkgs/os-specific/linux/dpdk-kmods/default.nix b/pkgs/os-specific/linux/dpdk-kmods/default.nix index 4205da7e7e80cd..6b19320dd9e324 100644 --- a/pkgs/os-specific/linux/dpdk-kmods/default.nix +++ b/pkgs/os-specific/linux/dpdk-kmods/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchzip, kernel }: +{ + lib, + stdenv, + fetchzip, + kernel, +}: stdenv.mkDerivation rec { pname = "dpdk-kmods"; diff --git a/pkgs/os-specific/linux/drbd/utils.nix b/pkgs/os-specific/linux/drbd/utils.nix index ad50c2c3e50a5a..408412481ac720 100644 --- a/pkgs/os-specific/linux/drbd/utils.nix +++ b/pkgs/os-specific/linux/drbd/utils.nix @@ -1,25 +1,26 @@ -{ lib -, stdenv -, docbook_xml_dtd_44 -, docbook_xml_dtd_45 -, docbook_xsl -, asciidoctor -, fetchurl -, flex -, kmod -, libxslt -, nixosTests -, perl -, perlPackages -, systemd -, keyutils +{ + lib, + stdenv, + docbook_xml_dtd_44, + docbook_xml_dtd_45, + docbook_xsl, + asciidoctor, + fetchurl, + flex, + kmod, + libxslt, + nixosTests, + perl, + perlPackages, + systemd, + keyutils, -# drbd-utils are compiled twice, once with forOCF = true to extract -# its OCF definitions for use in the ocf-resource-agents derivation, -# then again with forOCF = false, where the ocf-resource-agents is -# provided as the OCF_ROOT. -, forOCF ? false -, ocf-resource-agents + # drbd-utils are compiled twice, once with forOCF = true to extract + # its OCF definitions for use in the ocf-resource-agents derivation, + # then again with forOCF = false, where the ocf-resource-agents is + # provided as the OCF_ROOT. + forOCF ? false, + ocf-resource-agents, }: stdenv.mkDerivation rec { @@ -126,10 +127,14 @@ stdenv.mkDerivation rec { description = "Distributed Replicated Block Device, a distributed storage system for Linux (userspace utilities)"; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ ryantm astro birkb ]; + maintainers = with maintainers; [ + ryantm + astro + birkb + ]; longDescription = '' - DRBD is a software-based, shared-nothing, replicated storage solution - mirroring the content of block devices (hard disks, partitions, logical volumes, and so on) between hosts. + DRBD is a software-based, shared-nothing, replicated storage solution + mirroring the content of block devices (hard disks, partitions, logical volumes, and so on) between hosts. ''; }; } diff --git a/pkgs/os-specific/linux/e1000e/default.nix b/pkgs/os-specific/linux/e1000e/default.nix index 1ed7f6aa0193aa..92cfc49454e119 100644 --- a/pkgs/os-specific/linux/e1000e/default.nix +++ b/pkgs/os-specific/linux/e1000e/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, kernel }: +{ + lib, + stdenv, + fetchurl, + kernel, +}: assert lib.versionOlder kernel.version "4.10"; diff --git a/pkgs/os-specific/linux/error-inject/default.nix b/pkgs/os-specific/linux/error-inject/default.nix index 69b90169bda029..f5cc7a465191ea 100644 --- a/pkgs/os-specific/linux/error-inject/default.nix +++ b/pkgs/os-specific/linux/error-inject/default.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchzip -, bison, flex, rasdaemon +{ + lib, + stdenv, + fetchzip, + bison, + flex, + rasdaemon, }: { @@ -14,7 +19,10 @@ sha256 = "0gjapg2hrlxp8ssrnhvc19i3r1xpcnql7xv0zjgbv09zyha08g6z"; }; - nativeBuildInputs = [ bison flex ]; + nativeBuildInputs = [ + bison + flex + ]; makeFlags = [ "destdir=${placeholder "out"}" ]; @@ -43,7 +51,10 @@ sha256 = "0bh6mzpk2mr4xidkammmkfk21b4dbq793qjg25ryyxd1qv0c6cg4"; }; - nativeBuildInputs = [ bison flex ]; + nativeBuildInputs = [ + bison + flex + ]; # how is this necessary? makeFlags = [ "DESTDIR=${placeholder "out"}" ]; diff --git a/pkgs/os-specific/linux/exfat/default.nix b/pkgs/os-specific/linux/exfat/default.nix index c252238f7bd69c..d3af0056958365 100644 --- a/pkgs/os-specific/linux/exfat/default.nix +++ b/pkgs/os-specific/linux/exfat/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, kernel }: +{ + stdenv, + lib, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { name = "exfat-nofuse-${version}-${kernel.version}"; @@ -15,12 +20,14 @@ stdenv.mkDerivation rec { nativeBuildInputs = kernel.moduleBuildDependencies; - makeFlags = [ - "KDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" - "ARCH=${stdenv.hostPlatform.linuxArch}" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "CROSS_COMPILE=${stdenv.cc.targetPrefix}" - ]; + makeFlags = + [ + "KDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" + "ARCH=${stdenv.hostPlatform.linuxArch}" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "CROSS_COMPILE=${stdenv.cc.targetPrefix}" + ]; installPhase = '' install -m644 -b -D exfat.ko $out/lib/modules/${kernel.modDirVersion}/kernel/fs/exfat/exfat.ko diff --git a/pkgs/os-specific/linux/facetimehd/default.nix b/pkgs/os-specific/linux/facetimehd/default.nix index 4fa670afb39620..f90ace87caebf8 100644 --- a/pkgs/os-specific/linux/facetimehd/default.nix +++ b/pkgs/os-specific/linux/facetimehd/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, kernel }: +{ + stdenv, + lib, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { name = "facetimehd-${version}-${kernel.version}"; @@ -37,7 +42,14 @@ stdenv.mkDerivation rec { homepage = "https://github.com/patjak/bcwc_pcie"; description = "Linux driver for the Facetime HD (Broadcom 1570) PCIe webcam"; license = licenses.gpl2Only; - maintainers = with maintainers; [ womfoo grahamc kraem ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + maintainers = with maintainers; [ + womfoo + grahamc + kraem + ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/os-specific/linux/fanout/default.nix b/pkgs/os-specific/linux/fanout/default.nix index fc6bac80d6cd4d..2798f9da6233fc 100644 --- a/pkgs/os-specific/linux/fanout/default.nix +++ b/pkgs/os-specific/linux/fanout/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, kernel, kmod, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + kmod, + nixosTests, +}: stdenv.mkDerivation rec { pname = "fanout"; @@ -19,7 +26,10 @@ stdenv.mkDerivation rec { ./remove_auto_mknod.patch ]; - hardeningDisable = [ "format" "pic" ]; + hardeningDisable = [ + "format" + "pic" + ]; nativeBuildInputs = [ kmod ] ++ kernel.moduleBuildDependencies; diff --git a/pkgs/os-specific/linux/ffado/default.nix b/pkgs/os-specific/linux/ffado/default.nix index 2196a5730aa261..c607950c41ebe7 100644 --- a/pkgs/os-specific/linux/ffado/default.nix +++ b/pkgs/os-specific/linux/ffado/default.nix @@ -79,19 +79,21 @@ stdenv.mkDerivation rec { "PYTHON_INTERPRETER=${python.interpreter}" ]; - buildInputs = [ - dbus - dbus_cplusplus - glibmm - libavc1394 - libconfig - libiec61883 - libraw1394 - libxmlxx3 - python - ] ++ lib.optionals (!stdenv.hostPlatform.isGnu) [ - argp-standalone - ]; + buildInputs = + [ + dbus + dbus_cplusplus + glibmm + libavc1394 + libconfig + libiec61883 + libraw1394 + libxmlxx3 + python + ] + ++ lib.optionals (!stdenv.hostPlatform.isGnu) [ + argp-standalone + ]; NIX_LDFLAGS = lib.optionalString (!stdenv.hostPlatform.isGnu) "-largp"; diff --git a/pkgs/os-specific/linux/firmware/ath9k/default.nix b/pkgs/os-specific/linux/firmware/ath9k/default.nix index ab342d68c135f0..44a5d65358b444 100644 --- a/pkgs/os-specific/linux/firmware/ath9k/default.nix +++ b/pkgs/os-specific/linux/firmware/ath9k/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitHub -, m4 -, cmake -, perl -, writeScript -, enableUnstable ? false +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + m4, + cmake, + perl, + writeScript, + enableUnstable ? false, }: let @@ -17,24 +18,36 @@ stdenv.mkDerivation (finalAttrs: { pname = "ath9k-htc-blobless-firmware"; version = if enableUnstable then "unstable-2022-05-22" else stableVersion; - src = fetchFromGitHub ({ - owner = "qca"; - repo = "open-ath9k-htc-firmware"; - } // (if enableUnstable then { - rev = "d856466a068afe4069335257c0d28295ff777d92"; - hash = "sha256-9OE6qYGABeXjf1r/Depd+811EJ2e8I0Ni5ePHSOh9G4="; - } else { - rev = finalAttrs.version; - hash = "sha256-Q/A0ryIC5E1pt2Sh7o79gxHbe4OgdlrwflOWtxWSS5o="; - })); + src = fetchFromGitHub ( + { + owner = "qca"; + repo = "open-ath9k-htc-firmware"; + } + // ( + if enableUnstable then + { + rev = "d856466a068afe4069335257c0d28295ff777d92"; + hash = "sha256-9OE6qYGABeXjf1r/Depd+811EJ2e8I0Ni5ePHSOh9G4="; + } + else + { + rev = finalAttrs.version; + hash = "sha256-Q/A0ryIC5E1pt2Sh7o79gxHbe4OgdlrwflOWtxWSS5o="; + } + ) + ); postPatch = '' patchShebangs target_firmware/firmware-crc.pl ''; - nativeBuildInputs = [ m4 cmake perl ]; + nativeBuildInputs = [ + m4 + cmake + perl + ]; - env.NIX_CFLAGS_COMPILE = "-w"; # old libiberty emits fatal warnings + env.NIX_CFLAGS_COMPILE = "-w"; # old libiberty emits fatal warnings dontUseCmakeConfigure = true; enableParallelBuilding = true; @@ -43,25 +56,40 @@ stdenv.mkDerivation (finalAttrs: { # applied to the xtensa support in both gcc and binutils. preBuild = let - inherit (lib) toUpper splitString last listToAttrs pipe; + inherit (lib) + toUpper + splitString + last + listToAttrs + pipe + ; inherit (builtins) map; urls-and-hashes = import (./. + "/urls-and-hashes-${finalAttrs.version}.nix"); - make-links = pipe - [ "gcc" "binutils" "gmp" "mpfr" "mpc" ] - [ (map (vname: fetchurl rec { - url = urls-and-hashes."${(toUpper vname) + "_URL"}"; - sha256 = urls-and-hashes."${(toUpper vname) + "_SUM"}" or ""; - name = last (splitString "/" url); - })) - (map (v: "ln -sT ${v} toolchain/dl/${v.name}")) - (lib.concatStringsSep "\n") - ]; - in '' + make-links = + pipe + [ "gcc" "binutils" "gmp" "mpfr" "mpc" ] + [ + (map ( + vname: + fetchurl rec { + url = urls-and-hashes."${(toUpper vname) + "_URL"}"; + sha256 = urls-and-hashes."${(toUpper vname) + "_SUM"}" or ""; + name = last (splitString "/" url); + } + )) + (map (v: "ln -sT ${v} toolchain/dl/${v.name}")) + (lib.concatStringsSep "\n") + ]; + in + '' mkdir -p toolchain/dl ${make-links} ''; - makeTargets = [ "toolchain" "firmware" ]; + makeTargets = [ + "toolchain" + "firmware" + ]; installPhase = '' runHook preInstall @@ -80,31 +108,33 @@ stdenv.mkDerivation (finalAttrs: { ''; update = stdenv.mkDerivation { name = "${finalAttrs.pname}-${finalAttrs.version}-update"; - shellHook = '' - echo 'rec {' - echo ' BASEDIR="$NIX_BUILD_TOP";' - make --dry-run --print-data-base -f ${finalAttrs.src}/Makefile download \ - | egrep '^[A-Z]+_(VER|URL|SUM|DIR) = ' \ - | sed 's_\([^ ]*\) = \(.*\)_\1 = "\2\";_' \ - | tr \( \{ \ - | tr \) \} - '' - # sha256 checksums were not added to upstream's Makefile until - # after the 1.4.0 release. The following line is needed for - # the `enableUnstable==false` build but not for the - # `enableUnstable==true` build. We can remove the lines below - # as soon as `enableUnstable==false` points to a version - # greater than 1.4.0. - + lib.optionalString (finalAttrs.version == "1.4.0") '' - echo 'GCC_SUM = "sha256-kuYcbcOgpEnmLXKjgYX9pVAWioZwLeoHEl69PsOZYoI=";' - echo 'MPFR_SUM = "sha256-e2bD8T3IOF8IJkyAWFPz4aju2rgHHVgvPmYZccms1f0=";' - echo 'MPC_SUM = "sha256-7VqBXP6lJdx3jfDLN0aLnBtVSq8w2TKLFDHKcFt0AP8=";' - echo 'GMP_SUM = "sha256-H1iKrMxBu5rtlG+f44Uhwm2LKQ0APF34B/ZWkPKq3sk=";' - echo 'BINUTILS_SUM = "sha256-KrLlsD4IbRLGKV+DGtrUaz4UEKOiNJM6Lo+sZssuehk=";' - '' + '' - echo '}' - exit - ''; + shellHook = + '' + echo 'rec {' + echo ' BASEDIR="$NIX_BUILD_TOP";' + make --dry-run --print-data-base -f ${finalAttrs.src}/Makefile download \ + | egrep '^[A-Z]+_(VER|URL|SUM|DIR) = ' \ + | sed 's_\([^ ]*\) = \(.*\)_\1 = "\2\";_' \ + | tr \( \{ \ + | tr \) \} + '' + # sha256 checksums were not added to upstream's Makefile until + # after the 1.4.0 release. The following line is needed for + # the `enableUnstable==false` build but not for the + # `enableUnstable==true` build. We can remove the lines below + # as soon as `enableUnstable==false` points to a version + # greater than 1.4.0. + + lib.optionalString (finalAttrs.version == "1.4.0") '' + echo 'GCC_SUM = "sha256-kuYcbcOgpEnmLXKjgYX9pVAWioZwLeoHEl69PsOZYoI=";' + echo 'MPFR_SUM = "sha256-e2bD8T3IOF8IJkyAWFPz4aju2rgHHVgvPmYZccms1f0=";' + echo 'MPC_SUM = "sha256-7VqBXP6lJdx3jfDLN0aLnBtVSq8w2TKLFDHKcFt0AP8=";' + echo 'GMP_SUM = "sha256-H1iKrMxBu5rtlG+f44Uhwm2LKQ0APF34B/ZWkPKq3sk=";' + echo 'BINUTILS_SUM = "sha256-KrLlsD4IbRLGKV+DGtrUaz4UEKOiNJM6Lo+sZssuehk=";' + '' + + '' + echo '}' + exit + ''; }; }; @@ -127,23 +157,24 @@ stdenv.mkDerivation (finalAttrs: { dedicated general-purpose CPUs. This source code allows you to see what those CPUs are doing and modify their behavior. ''; - license = with lib.licenses; [ # see NOTICE.txt for details - bsd3 # almost everything; "the ClearBSD licence" - gpl2ClasspathPlus # **/*cmnos_printf.c, only three files - mit # **/xtos, **/xtensa + license = with lib.licenses; [ + # see NOTICE.txt for details + bsd3 # almost everything; "the ClearBSD licence" + gpl2ClasspathPlus # **/*cmnos_printf.c, only three files + mit # **/xtos, **/xtensa ]; # release 1.4.0 vendors a GMP which uses an ancient version of # autotools that does not work on aarch64 or powerpc. # However, enableUnstable (unreleased upstream) works. /* - # disabled until #195294 is merged - badPlatforms = - with lib.systems.inspect.patterns; - lib.optionals (!enableUnstable && lib.versionOlder finalAttrs.version "1.4.1") [ - isAarch64 - isPower64 - ]; + # disabled until #195294 is merged + badPlatforms = + with lib.systems.inspect.patterns; + lib.optionals (!enableUnstable && lib.versionOlder finalAttrs.version "1.4.1") [ + isAarch64 + isPower64 + ]; */ sourceProvenance = [ lib.sourceTypes.fromSource ]; diff --git a/pkgs/os-specific/linux/firmware/ath9k/urls-and-hashes-1.4.0.nix b/pkgs/os-specific/linux/firmware/ath9k/urls-and-hashes-1.4.0.nix index d67669c93b33eb..fcccf7505cc766 100644 --- a/pkgs/os-specific/linux/firmware/ath9k/urls-and-hashes-1.4.0.nix +++ b/pkgs/os-specific/linux/firmware/ath9k/urls-and-hashes-1.4.0.nix @@ -1,26 +1,26 @@ rec { - BASEDIR="$NIX_BUILD_TOP"; -BINUTILS_URL = "https://ftp.gnu.org/gnu/binutils/binutils-${BINUTILS_VER}.tar.bz2"; -DL_DIR = "${TOOLCHAIN_DIR}/dl"; -GMP_URL = "https://ftp.gnu.org/gnu/gmp/gmp-${GMP_VER}.tar.bz2"; -GCC_URL = "https://ftp.gnu.org/gnu/gcc/gcc-${GCC_VER}/gcc-${GCC_VER}.tar.bz2"; -BINUTILS_DIR = "binutils-${BINUTILS_VER}"; -GCC_VER = "4.7.4"; -MPFR_URL = "https://ftp.gnu.org/gnu/mpfr/mpfr-${MPFR_VER}.tar.bz2"; -MPC_VER = "1.0.1"; -GMP_DIR = "gmp-${GMP_VER}"; -MPC_URL = "https://ftp.gnu.org/gnu/mpc/mpc-${MPC_VER}.tar.gz"; -GCC_DIR = "gcc-${GCC_VER}"; -MPFR_DIR = "mpfr-${MPFR_VER}"; -MPC_DIR = "mpc-${MPC_VER}"; -MPFR_VER = "3.1.1"; -GMP_VER = "5.0.5"; -BINUTILS_VER = "2.23.1"; -BUILD_DIR = "${TOOLCHAIN_DIR}/build"; -TOOLCHAIN_DIR = "${BASEDIR}/toolchain"; -GCC_SUM = "sha256-kuYcbcOgpEnmLXKjgYX9pVAWioZwLeoHEl69PsOZYoI="; -MPFR_SUM = "sha256-e2bD8T3IOF8IJkyAWFPz4aju2rgHHVgvPmYZccms1f0="; -MPC_SUM = "sha256-7VqBXP6lJdx3jfDLN0aLnBtVSq8w2TKLFDHKcFt0AP8="; -GMP_SUM = "sha256-H1iKrMxBu5rtlG+f44Uhwm2LKQ0APF34B/ZWkPKq3sk="; -BINUTILS_SUM = "sha256-KrLlsD4IbRLGKV+DGtrUaz4UEKOiNJM6Lo+sZssuehk="; + BASEDIR = "$NIX_BUILD_TOP"; + BINUTILS_URL = "https://ftp.gnu.org/gnu/binutils/binutils-${BINUTILS_VER}.tar.bz2"; + DL_DIR = "${TOOLCHAIN_DIR}/dl"; + GMP_URL = "https://ftp.gnu.org/gnu/gmp/gmp-${GMP_VER}.tar.bz2"; + GCC_URL = "https://ftp.gnu.org/gnu/gcc/gcc-${GCC_VER}/gcc-${GCC_VER}.tar.bz2"; + BINUTILS_DIR = "binutils-${BINUTILS_VER}"; + GCC_VER = "4.7.4"; + MPFR_URL = "https://ftp.gnu.org/gnu/mpfr/mpfr-${MPFR_VER}.tar.bz2"; + MPC_VER = "1.0.1"; + GMP_DIR = "gmp-${GMP_VER}"; + MPC_URL = "https://ftp.gnu.org/gnu/mpc/mpc-${MPC_VER}.tar.gz"; + GCC_DIR = "gcc-${GCC_VER}"; + MPFR_DIR = "mpfr-${MPFR_VER}"; + MPC_DIR = "mpc-${MPC_VER}"; + MPFR_VER = "3.1.1"; + GMP_VER = "5.0.5"; + BINUTILS_VER = "2.23.1"; + BUILD_DIR = "${TOOLCHAIN_DIR}/build"; + TOOLCHAIN_DIR = "${BASEDIR}/toolchain"; + GCC_SUM = "sha256-kuYcbcOgpEnmLXKjgYX9pVAWioZwLeoHEl69PsOZYoI="; + MPFR_SUM = "sha256-e2bD8T3IOF8IJkyAWFPz4aju2rgHHVgvPmYZccms1f0="; + MPC_SUM = "sha256-7VqBXP6lJdx3jfDLN0aLnBtVSq8w2TKLFDHKcFt0AP8="; + GMP_SUM = "sha256-H1iKrMxBu5rtlG+f44Uhwm2LKQ0APF34B/ZWkPKq3sk="; + BINUTILS_SUM = "sha256-KrLlsD4IbRLGKV+DGtrUaz4UEKOiNJM6Lo+sZssuehk="; } diff --git a/pkgs/os-specific/linux/firmware/ath9k/urls-and-hashes-unstable-2022-05-22.nix b/pkgs/os-specific/linux/firmware/ath9k/urls-and-hashes-unstable-2022-05-22.nix index 4234f91ef978d0..3a94eff77cfd4d 100644 --- a/pkgs/os-specific/linux/firmware/ath9k/urls-and-hashes-unstable-2022-05-22.nix +++ b/pkgs/os-specific/linux/firmware/ath9k/urls-and-hashes-unstable-2022-05-22.nix @@ -1,26 +1,26 @@ rec { - BASEDIR="$NIX_BUILD_TOP"; -BINUTILS_URL = "https://ftp.gnu.org/gnu/binutils/binutils-${BINUTILS_VER}.tar.bz2"; -DL_DIR = "${TOOLCHAIN_DIR}/dl"; -GMP_SUM = "f51c99cb114deb21a60075ffb494c1a210eb9d7cb729ed042ddb7de9534451ea"; -GMP_URL = "https://ftp.gnu.org/gnu/gmp/gmp-${GMP_VER}.tar.bz2"; -GCC_URL = "https://ftp.gnu.org/gnu/gcc/gcc-${GCC_VER}/gcc-${GCC_VER}.tar.gz"; -BINUTILS_DIR = "binutils-${BINUTILS_VER}"; -GCC_VER = "10.2.0"; -MPFR_URL = "https://ftp.gnu.org/gnu/mpfr/mpfr-${MPFR_VER}.tar.bz2"; -MPC_VER = "1.1.0"; -GMP_DIR = "gmp-${GMP_VER}"; -MPC_URL = "https://ftp.gnu.org/gnu/mpc/mpc-${MPC_VER}.tar.gz"; -GCC_DIR = "gcc-${GCC_VER}"; -MPC_SUM = "6985c538143c1208dcb1ac42cedad6ff52e267b47e5f970183a3e75125b43c2e"; -GCC_SUM = "27e879dccc639cd7b0cc08ed575c1669492579529b53c9ff27b0b96265fa867d"; -BINUTILS_SUM = "7d24660f87093670738e58bcc7b7b06f121c0fcb0ca8fc44368d675a5ef9cff7"; -MPFR_DIR = "mpfr-${MPFR_VER}"; -MPC_DIR = "mpc-${MPC_VER}"; -MPFR_VER = "4.1.0"; -GMP_VER = "6.2.0"; -BINUTILS_VER = "2.35"; -BUILD_DIR = "${TOOLCHAIN_DIR}/build"; -MPFR_SUM = "feced2d430dd5a97805fa289fed3fc8ff2b094c02d05287fd6133e7f1f0ec926"; -TOOLCHAIN_DIR = "${BASEDIR}/toolchain"; + BASEDIR = "$NIX_BUILD_TOP"; + BINUTILS_URL = "https://ftp.gnu.org/gnu/binutils/binutils-${BINUTILS_VER}.tar.bz2"; + DL_DIR = "${TOOLCHAIN_DIR}/dl"; + GMP_SUM = "f51c99cb114deb21a60075ffb494c1a210eb9d7cb729ed042ddb7de9534451ea"; + GMP_URL = "https://ftp.gnu.org/gnu/gmp/gmp-${GMP_VER}.tar.bz2"; + GCC_URL = "https://ftp.gnu.org/gnu/gcc/gcc-${GCC_VER}/gcc-${GCC_VER}.tar.gz"; + BINUTILS_DIR = "binutils-${BINUTILS_VER}"; + GCC_VER = "10.2.0"; + MPFR_URL = "https://ftp.gnu.org/gnu/mpfr/mpfr-${MPFR_VER}.tar.bz2"; + MPC_VER = "1.1.0"; + GMP_DIR = "gmp-${GMP_VER}"; + MPC_URL = "https://ftp.gnu.org/gnu/mpc/mpc-${MPC_VER}.tar.gz"; + GCC_DIR = "gcc-${GCC_VER}"; + MPC_SUM = "6985c538143c1208dcb1ac42cedad6ff52e267b47e5f970183a3e75125b43c2e"; + GCC_SUM = "27e879dccc639cd7b0cc08ed575c1669492579529b53c9ff27b0b96265fa867d"; + BINUTILS_SUM = "7d24660f87093670738e58bcc7b7b06f121c0fcb0ca8fc44368d675a5ef9cff7"; + MPFR_DIR = "mpfr-${MPFR_VER}"; + MPC_DIR = "mpc-${MPC_VER}"; + MPFR_VER = "4.1.0"; + GMP_VER = "6.2.0"; + BINUTILS_VER = "2.35"; + BUILD_DIR = "${TOOLCHAIN_DIR}/build"; + MPFR_SUM = "feced2d430dd5a97805fa289fed3fc8ff2b094c02d05287fd6133e7f1f0ec926"; + TOOLCHAIN_DIR = "${BASEDIR}/toolchain"; } diff --git a/pkgs/os-specific/linux/firmware/b43-firmware/5.1.138.nix b/pkgs/os-specific/linux/firmware/b43-firmware/5.1.138.nix index a5683a1ce53529..62ba72222d4b5c 100644 --- a/pkgs/os-specific/linux/firmware/b43-firmware/5.1.138.nix +++ b/pkgs/os-specific/linux/firmware/b43-firmware/5.1.138.nix @@ -1,6 +1,13 @@ -{ lib, stdenvNoCC, fetchurl, b43FirmwareCutter }: +{ + lib, + stdenvNoCC, + fetchurl, + b43FirmwareCutter, +}: -let version = "5.100.138"; in +let + version = "5.100.138"; +in stdenvNoCC.mkDerivation { pname = "b43-firmware"; diff --git a/pkgs/os-specific/linux/firmware/b43-firmware/6.30.163.46.nix b/pkgs/os-specific/linux/firmware/b43-firmware/6.30.163.46.nix index e117db45b1829d..10ca576bd6ec3b 100644 --- a/pkgs/os-specific/linux/firmware/b43-firmware/6.30.163.46.nix +++ b/pkgs/os-specific/linux/firmware/b43-firmware/6.30.163.46.nix @@ -1,4 +1,9 @@ -{ lib, stdenvNoCC, fetchurl, b43FirmwareCutter }: +{ + lib, + stdenvNoCC, + fetchurl, + b43FirmwareCutter, +}: stdenvNoCC.mkDerivation rec { pname = "b43-firmware"; diff --git a/pkgs/os-specific/linux/firmware/linux-firmware/default.nix b/pkgs/os-specific/linux/firmware/linux-firmware/default.nix index 25ac7067982dd3..38bf35e37cd284 100644 --- a/pkgs/os-specific/linux/firmware/linux-firmware/default.nix +++ b/pkgs/os-specific/linux/firmware/linux-firmware/default.nix @@ -1,10 +1,11 @@ -{ stdenvNoCC -, fetchzip -, lib -, python3 -, rdfind -, which -, writeShellScriptBin +{ + stdenvNoCC, + fetchzip, + lib, + python3, + rdfind, + which, + writeShellScriptBin, }: let # check-whence.py attempts to call `git ls-files`, but we don't have a .git, @@ -18,7 +19,8 @@ let exit 1 fi ''; -in stdenvNoCC.mkDerivation rec { +in +stdenvNoCC.mkDerivation rec { pname = "linux-firmware"; version = "20241110"; @@ -38,7 +40,10 @@ in stdenvNoCC.mkDerivation rec { which ]; - installTargets = [ "install" "dedup" ]; + installTargets = [ + "install" + "dedup" + ]; makeFlags = [ "DESTDIR=$(out)" ]; # Firmware blobs do not need fixing and should not be modified diff --git a/pkgs/os-specific/linux/firmware/raspberrypi/armstubs.nix b/pkgs/os-specific/linux/firmware/raspberrypi/armstubs.nix index 0393174d889d6e..ec5ec8ef98c28b 100644 --- a/pkgs/os-specific/linux/firmware/raspberrypi/armstubs.nix +++ b/pkgs/os-specific/linux/firmware/raspberrypi/armstubs.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: let inherit (lib) optionals; @@ -22,19 +26,26 @@ stdenv.mkDerivation { cd armstubs ''; - makeFlags = [ - "CC8=${stdenv.cc.targetPrefix}cc" - "LD8=${stdenv.cc.targetPrefix}ld" - "OBJCOPY8=${stdenv.cc.targetPrefix}objcopy" - "OBJDUMP8=${stdenv.cc.targetPrefix}objdump" - "CC7=${stdenv.cc.targetPrefix}cc" - "LD7=${stdenv.cc.targetPrefix}ld" - "OBJCOPY7=${stdenv.cc.targetPrefix}objcopy" - "OBJDUMP7=${stdenv.cc.targetPrefix}objdump" - ] - ++ optionals (stdenv.hostPlatform.isAarch64) [ "armstub8.bin" "armstub8-gic.bin" ] - ++ optionals (stdenv.hostPlatform.isAarch32) [ "armstub7.bin" "armstub8-32.bin" "armstub8-32-gic.bin" ] - ; + makeFlags = + [ + "CC8=${stdenv.cc.targetPrefix}cc" + "LD8=${stdenv.cc.targetPrefix}ld" + "OBJCOPY8=${stdenv.cc.targetPrefix}objcopy" + "OBJDUMP8=${stdenv.cc.targetPrefix}objdump" + "CC7=${stdenv.cc.targetPrefix}cc" + "LD7=${stdenv.cc.targetPrefix}ld" + "OBJCOPY7=${stdenv.cc.targetPrefix}objcopy" + "OBJDUMP7=${stdenv.cc.targetPrefix}objdump" + ] + ++ optionals (stdenv.hostPlatform.isAarch64) [ + "armstub8.bin" + "armstub8-gic.bin" + ] + ++ optionals (stdenv.hostPlatform.isAarch32) [ + "armstub7.bin" + "armstub8-32.bin" + "armstub8-32-gic.bin" + ]; installPhase = '' runHook preInstall @@ -47,7 +58,11 @@ stdenv.mkDerivation { description = "Firmware related ARM stubs for the Raspberry Pi"; homepage = "https://github.com/raspberrypi/tools"; license = licenses.bsd3; - platforms = [ "armv6l-linux" "armv7l-linux" "aarch64-linux" ]; + platforms = [ + "armv6l-linux" + "armv7l-linux" + "aarch64-linux" + ]; maintainers = [ ]; }; } diff --git a/pkgs/os-specific/linux/framework-laptop-kmod/default.nix b/pkgs/os-specific/linux/framework-laptop-kmod/default.nix index d0ca1a3bb1d9c9..1b5b70af88e031 100644 --- a/pkgs/os-specific/linux/framework-laptop-kmod/default.nix +++ b/pkgs/os-specific/linux/framework-laptop-kmod/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, kernel -, fetchFromGitHub -, unstableGitUpdater +{ + lib, + stdenv, + kernel, + fetchFromGitHub, + unstableGitUpdater, }: stdenv.mkDerivation { @@ -28,7 +29,6 @@ stdenv.mkDerivation { runHook postInstall ''; - passthru.updateScript = unstableGitUpdater { }; meta = with lib; { diff --git a/pkgs/os-specific/linux/freefall/default.nix b/pkgs/os-specific/linux/freefall/default.nix index bad4849ca0bfd3..f195da10328940 100644 --- a/pkgs/os-specific/linux/freefall/default.nix +++ b/pkgs/os-specific/linux/freefall/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, kernel }: +{ + lib, + stdenv, + kernel, +}: stdenv.mkDerivation { inherit (kernel) version src; diff --git a/pkgs/os-specific/linux/freeipa/default.nix b/pkgs/os-specific/linux/freeipa/default.nix index f0256b55c8cb19..5a60b256bde167 100644 --- a/pkgs/os-specific/linux/freeipa/default.nix +++ b/pkgs/os-specific/linux/freeipa/default.nix @@ -1,38 +1,39 @@ -{ stdenv -, lib -, fetchurl -, pkg-config -, autoconf -, automake -, kerberos -, openldap -, popt -, sasl -, curl -, xmlrpc_c -, ding-libs -, p11-kit -, gettext -, nspr -, nss -, _389-ds-base -, svrcore -, libuuid -, talloc -, tevent -, samba -, libunistring -, libverto -, libpwquality -, systemd -, python3 -, bind -, sssd -, jre -, rhino -, lesscpy -, jansson -, runtimeShell +{ + stdenv, + lib, + fetchurl, + pkg-config, + autoconf, + automake, + kerberos, + openldap, + popt, + sasl, + curl, + xmlrpc_c, + ding-libs, + p11-kit, + gettext, + nspr, + nss, + _389-ds-base, + svrcore, + libuuid, + talloc, + tevent, + samba, + libunistring, + libverto, + libpwquality, + systemd, + python3, + bind, + sssd, + jre, + rhino, + lesscpy, + jansson, + runtimeShell, }: let diff --git a/pkgs/os-specific/linux/fuse/default.nix b/pkgs/os-specific/linux/fuse/default.nix index f692c2fb41c781..cf8992bcb089bc 100644 --- a/pkgs/os-specific/linux/fuse/default.nix +++ b/pkgs/os-specific/linux/fuse/default.nix @@ -1,10 +1,13 @@ { callPackage, util-linux }: let - mkFuse = args: callPackage (import ./common.nix args) { - inherit util-linux; - }; -in { + mkFuse = + args: + callPackage (import ./common.nix args) { + inherit util-linux; + }; +in +{ fuse_2 = mkFuse { version = "2.9.9"; hash = "sha256-dgjM6M7xk5MHi9xPyCyvF0vq0KM8UCsEYBcMhkrdvfs="; diff --git a/pkgs/os-specific/linux/fwts/module.nix b/pkgs/os-specific/linux/fwts/module.nix index a4083d275465aa..dd005e6dc4e68b 100644 --- a/pkgs/os-specific/linux/fwts/module.nix +++ b/pkgs/os-specific/linux/fwts/module.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fwts, kernel }: +{ + lib, + stdenv, + fwts, + kernel, +}: stdenv.mkDerivation rec { pname = "fwts-efi-runtime"; diff --git a/pkgs/os-specific/linux/gasket/default.nix b/pkgs/os-specific/linux/gasket/default.nix index 65516be7dcd17f..76e0bfd770c7a6 100644 --- a/pkgs/os-specific/linux/gasket/default.nix +++ b/pkgs/os-specific/linux/gasket/default.nix @@ -3,7 +3,7 @@ lib, fetchFromGitHub, fetchpatch2, - kernel + kernel, }: stdenv.mkDerivation rec { @@ -41,7 +41,10 @@ stdenv.mkDerivation rec { installFlags = [ "INSTALL_MOD_PATH=${placeholder "out"}" ]; installTargets = [ "modules_install" ]; - hardeningDisable = [ "pic" "format" ]; + hardeningDisable = [ + "pic" + "format" + ]; nativeBuildInputs = kernel.moduleBuildDependencies; meta = with lib; { diff --git a/pkgs/os-specific/linux/gcadapter-oc-kmod/default.nix b/pkgs/os-specific/linux/gcadapter-oc-kmod/default.nix index a1e3a8be430e5f..c56914fcee7a7d 100644 --- a/pkgs/os-specific/linux/gcadapter-oc-kmod/default.nix +++ b/pkgs/os-specific/linux/gcadapter-oc-kmod/default.nix @@ -1,12 +1,15 @@ -{ lib, stdenv -, fetchFromGitHub -, kernel -, kmod +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + kmod, }: let kerneldir = "lib/modules/${kernel.modDirVersion}"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "gcadapter-oc-kmod"; version = "unstable-2021-12-11"; diff --git a/pkgs/os-specific/linux/guvcview/default.nix b/pkgs/os-specific/linux/guvcview/default.nix index 6007b8869e27a9..af90c5d4f8d496 100644 --- a/pkgs/os-specific/linux/guvcview/default.nix +++ b/pkgs/os-specific/linux/guvcview/default.nix @@ -1,27 +1,29 @@ -{ config -, lib, stdenv -, fetchurl -, intltool -, pkg-config -, portaudio -, SDL2 -, ffmpeg -, udev -, libusb1 -, libv4l -, alsa-lib -, gsl -, libpng -, sfml -, pulseaudioSupport ? config.pulseaudio or stdenv.hostPlatform.isLinux -, libpulseaudio ? null -, useQt ? false -, qtbase ? null -, wrapQtAppsHook ? null -# can be turned off if used as a library -, useGtk ? true -, gtk3 ? null -, wrapGAppsHook3 ? null +{ + config, + lib, + stdenv, + fetchurl, + intltool, + pkg-config, + portaudio, + SDL2, + ffmpeg, + udev, + libusb1, + libv4l, + alsa-lib, + gsl, + libpng, + sfml, + pulseaudioSupport ? config.pulseaudio or stdenv.hostPlatform.isLinux, + libpulseaudio ? null, + useQt ? false, + qtbase ? null, + wrapQtAppsHook ? null, + # can be turned off if used as a library + useGtk ? true, + gtk3 ? null, + wrapGAppsHook3 ? null, }: assert pulseaudioSupport -> libpulseaudio != null; @@ -35,38 +37,38 @@ stdenv.mkDerivation rec { hash = "sha256-PZPkyfq40aepveGm278E1s+dNHwTS1EotFhqHZC2PPs="; }; - nativeBuildInputs = [ - intltool - pkg-config - ] + nativeBuildInputs = + [ + intltool + pkg-config + ] ++ lib.optionals (useGtk) [ wrapGAppsHook3 ] - ++ lib.optionals (useQt) [ wrapQtAppsHook ] - ; + ++ lib.optionals (useQt) [ wrapQtAppsHook ]; - buildInputs = [ - SDL2 - alsa-lib - ffmpeg - libusb1 - libv4l - portaudio - udev - gsl - libpng - sfml - ] + buildInputs = + [ + SDL2 + alsa-lib + ffmpeg + libusb1 + libv4l + portaudio + udev + gsl + libpng + sfml + ] ++ lib.optionals (pulseaudioSupport) [ libpulseaudio ] ++ lib.optionals (useGtk) [ gtk3 ] ++ lib.optionals (useQt) [ qtbase + ]; + configureFlags = + [ + "--enable-sfml" ] - ; - configureFlags = [ - "--enable-sfml" - ] ++ lib.optionals (useGtk) [ "--enable-gtk3" ] - ++ lib.optionals (useQt) [ "--enable-qt5" ] - ; + ++ lib.optionals (useQt) [ "--enable-qt5" ]; meta = with lib; { description = "Simple interface for devices supported by the linux UVC driver"; diff --git a/pkgs/os-specific/linux/hid-ite8291r3/default.nix b/pkgs/os-specific/linux/hid-ite8291r3/default.nix index d4f69c734ac018..e7d7ccb27a9fdd 100644 --- a/pkgs/os-specific/linux/hid-ite8291r3/default.nix +++ b/pkgs/os-specific/linux/hid-ite8291r3/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { pname = "hid-ite8291r3"; diff --git a/pkgs/os-specific/linux/i7z/default.nix b/pkgs/os-specific/linux/i7z/default.nix index 5a7279ba998cbe..cb01e684735ace 100644 --- a/pkgs/os-specific/linux/i7z/default.nix +++ b/pkgs/os-specific/linux/i7z/default.nix @@ -1,5 +1,12 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, ncurses -, withGui ? false, qtbase }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + ncurses, + withGui ? false, + qtbase, +}: stdenv.mkDerivation rec { pname = "i7z"; @@ -33,11 +40,11 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; postBuild = lib.optionalString withGui '' - cd GUI - qmake - make clean - make - cd .. + cd GUI + qmake + make clean + make + cd .. ''; makeFlags = [ "prefix=${placeholder "out"}" ]; diff --git a/pkgs/os-specific/linux/intel-speed-select/default.nix b/pkgs/os-specific/linux/intel-speed-select/default.nix index 97bfdbeb30d5cd..57b8284326f9e8 100644 --- a/pkgs/os-specific/linux/intel-speed-select/default.nix +++ b/pkgs/os-specific/linux/intel-speed-select/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, kernel }: +{ + lib, + stdenv, + kernel, +}: stdenv.mkDerivation { pname = "intel-speed-select"; @@ -16,7 +20,10 @@ stdenv.mkDerivation { mainProgram = "intel-speed-select"; homepage = "https://www.kernel.org/"; license = licenses.gpl2Only; - platforms = [ "i686-linux" "x86_64-linux" ]; # x86-specific + platforms = [ + "i686-linux" + "x86_64-linux" + ]; # x86-specific broken = kernel.kernelAtLeast "5.18"; }; } diff --git a/pkgs/os-specific/linux/iptables/default.nix b/pkgs/os-specific/linux/iptables/default.nix index afaa91ca2f37e3..6848b7dfee79fb 100644 --- a/pkgs/os-specific/linux/iptables/default.nix +++ b/pkgs/os-specific/linux/iptables/default.nix @@ -1,8 +1,19 @@ -{ lib, stdenv, fetchurl -, autoreconfHook, pkg-config, pruneLibtoolFiles, flex, bison -, libmnl, libnetfilter_conntrack, libnfnetlink, libnftnl, libpcap -, nftablesCompat ? true -, gitUpdater +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + pruneLibtoolFiles, + flex, + bison, + libmnl, + libnetfilter_conntrack, + libnfnetlink, + libnftnl, + libpcap, + nftablesCompat ? true, + gitUpdater, }: stdenv.mkDerivation rec { @@ -14,13 +25,27 @@ stdenv.mkDerivation rec { sha256 = "XMJVwYk1bjF9BwdVzpNx62Oht4PDRJj7jDAmTzzFnJw="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; nativeBuildInputs = [ - autoreconfHook pkg-config pruneLibtoolFiles flex bison + autoreconfHook + pkg-config + pruneLibtoolFiles + flex + bison ]; - buildInputs = [ libmnl libnetfilter_conntrack libnfnetlink libnftnl libpcap ]; + buildInputs = [ + libmnl + libnetfilter_conntrack + libnfnetlink + libnftnl + libpcap + ]; configureFlags = [ "--enable-bpf-compiler" diff --git a/pkgs/os-specific/linux/ipu6-drivers/default.nix b/pkgs/os-specific/linux/ipu6-drivers/default.nix index 117aefc25eca63..d3e37f5a5bd412 100644 --- a/pkgs/os-specific/linux/ipu6-drivers/default.nix +++ b/pkgs/os-specific/linux/ipu6-drivers/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, ivsc-driver -, kernel +{ + lib, + stdenv, + fetchFromGitHub, + ivsc-driver, + kernel, }: stdenv.mkDerivation rec { diff --git a/pkgs/os-specific/linux/iputils/default.nix b/pkgs/os-specific/linux/iputils/default.nix index b87fe51434f3e5..7bf1f155b21dab 100644 --- a/pkgs/os-specific/linux/iputils/default.nix +++ b/pkgs/os-specific/linux/iputils/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, gettext -, libxslt -, docbook_xsl_ns -, libcap -, libidn2 -, iproute2 -, apparmorRulesFromClosure +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + gettext, + libxslt, + docbook_xsl_ns, + libcap, + libidn2, + iproute2, + apparmorRulesFromClosure, }: stdenv.mkDerivation rec { @@ -24,24 +25,34 @@ stdenv.mkDerivation rec { hash = "sha256-2CjzIOe1hrW3He9DN+w+Wi2zaaMBkVEdA7dezTpkx8I="; }; - outputs = [ "out" "apparmor" ]; + outputs = [ + "out" + "apparmor" + ]; # We don't have the required permissions inside the build sandbox: # /build/source/build/ping/ping: socket: Operation not permitted doCheck = false; - mesonFlags = [ - "-DNO_SETCAP_OR_SUID=true" - "-Dsystemdunitdir=etc/systemd/system" - "-DINSTALL_SYSTEMD_UNITS=true" - "-DSKIP_TESTS=${lib.boolToString (!doCheck)}" - ] - # Disable idn usage w/musl (https://github.com/iputils/iputils/pull/111): - ++ lib.optional stdenv.hostPlatform.isMusl "-DUSE_IDN=false"; + mesonFlags = + [ + "-DNO_SETCAP_OR_SUID=true" + "-Dsystemdunitdir=etc/systemd/system" + "-DINSTALL_SYSTEMD_UNITS=true" + "-DSKIP_TESTS=${lib.boolToString (!doCheck)}" + ] + # Disable idn usage w/musl (https://github.com/iputils/iputils/pull/111): + ++ lib.optional stdenv.hostPlatform.isMusl "-DUSE_IDN=false"; - nativeBuildInputs = [ meson ninja pkg-config gettext libxslt.bin docbook_xsl_ns ]; - buildInputs = [ libcap ] - ++ lib.optional (!stdenv.hostPlatform.isMusl) libidn2; + nativeBuildInputs = [ + meson + ninja + pkg-config + gettext + libxslt.bin + docbook_xsl_ns + ]; + buildInputs = [ libcap ] ++ lib.optional (!stdenv.hostPlatform.isMusl) libidn2; nativeCheckInputs = [ iproute2 ]; postInstall = '' @@ -52,8 +63,11 @@ stdenv.mkDerivation rec { include include include - include "${apparmorRulesFromClosure { name = "ping"; } - ([libcap] ++ lib.optional (!stdenv.hostPlatform.isMusl) libidn2)}" + include "${ + apparmorRulesFromClosure { name = "ping"; } ( + [ libcap ] ++ lib.optional (!stdenv.hostPlatform.isMusl) libidn2 + ) + }" include capability net_raw, network inet raw, @@ -77,7 +91,10 @@ stdenv.mkDerivation rec { - ping: send ICMP ECHO_REQUEST to network hosts - tracepath: traces path to a network host discovering MTU along this path ''; - license = with licenses; [ gpl2Plus bsd3 ]; + license = with licenses; [ + gpl2Plus + bsd3 + ]; platforms = platforms.linux; maintainers = with maintainers; [ primeos ]; }; diff --git a/pkgs/os-specific/linux/isgx/default.nix b/pkgs/os-specific/linux/isgx/default.nix index 73a373c1f789b5..a883f4c879d9b3 100644 --- a/pkgs/os-specific/linux/isgx/default.nix +++ b/pkgs/os-specific/linux/isgx/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, kernel }: +{ + stdenv, + lib, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { name = "isgx-${version}-${kernel.version}"; @@ -38,7 +43,10 @@ stdenv.mkDerivation rec { based attestation on the platforms without Flexible Launch Control. ''; homepage = "https://github.com/intel/linux-sgx-driver"; - license = with licenses; [ bsd3 /* OR */ gpl2Only ]; + license = with licenses; [ + bsd3 # OR + gpl2Only + ]; maintainers = [ ]; platforms = [ "x86_64-linux" ]; # This kernel module is now in mainline so newer kernels should diff --git a/pkgs/os-specific/linux/it87/default.nix b/pkgs/os-specific/linux/it87/default.nix index 7416507e4a9d2b..d5d8c60d92fd50 100644 --- a/pkgs/os-specific/linux/it87/default.nix +++ b/pkgs/os-specific/linux/it87/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { name = "it87-${version}-${kernel.version}"; @@ -31,7 +36,10 @@ stdenv.mkDerivation rec { description = "Patched module for IT87xx superio chip sensors support"; homepage = "https://github.com/hannesha/it87"; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = teams.lumiguide.members; }; } diff --git a/pkgs/os-specific/linux/ithc/default.nix b/pkgs/os-specific/linux/ithc/default.nix index 69b202e7e20100..ff888ec165998c 100644 --- a/pkgs/os-specific/linux/ithc/default.nix +++ b/pkgs/os-specific/linux/ithc/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { pname = "ithc"; diff --git a/pkgs/os-specific/linux/ivsc-driver/default.nix b/pkgs/os-specific/linux/ivsc-driver/default.nix index 65733d99a65907..e4c6c9d5adcdd0 100644 --- a/pkgs/os-specific/linux/ivsc-driver/default.nix +++ b/pkgs/os-specific/linux/ivsc-driver/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, kernel +{ + lib, + stdenv, + fetchFromGitHub, + kernel, }: stdenv.mkDerivation { diff --git a/pkgs/os-specific/linux/ixgbevf/default.nix b/pkgs/os-specific/linux/ixgbevf/default.nix index 3cb9d06e7fcf4e..635c6463854c3d 100644 --- a/pkgs/os-specific/linux/ixgbevf/default.nix +++ b/pkgs/os-specific/linux/ixgbevf/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, kernel, kmod }: +{ + lib, + stdenv, + fetchurl, + kernel, + kmod, +}: stdenv.mkDerivation rec { name = "ixgbevf-${version}-${kernel.version}"; diff --git a/pkgs/os-specific/linux/kernel-headers/default.nix b/pkgs/os-specific/linux/kernel-headers/default.nix index b149b3f08d5c67..7538bec37f078a 100644 --- a/pkgs/os-specific/linux/kernel-headers/default.nix +++ b/pkgs/os-specific/linux/kernel-headers/default.nix @@ -1,6 +1,14 @@ -{ stdenvNoCC, lib, buildPackages, fetchurl, perl, elf-header -, bison, flex, rsync -, writeTextFile +{ + stdenvNoCC, + lib, + buildPackages, + fetchurl, + perl, + elf-header, + bison, + flex, + rsync, + writeTextFile, }: let @@ -29,89 +37,114 @@ let destination = "/include/byteswap.h"; }; - makeLinuxHeaders = { src, version, patches ? [] }: stdenvNoCC.mkDerivation { - inherit src; - - pname = "linux-headers"; - inherit version; - - ARCH = stdenvNoCC.hostPlatform.linuxArch; - - strictDeps = true; - enableParallelBuilding = true; - - # It may look odd that we use `stdenvNoCC`, and yet explicit depend on a cc. - # We do this so we have a build->build, not build->host, C compiler. - depsBuildBuild = [ buildPackages.stdenv.cc ]; - # `elf-header` is null when libc provides `elf.h`. - nativeBuildInputs = [ - perl elf-header - ] ++ lib.optionals stdenvNoCC.hostPlatform.isAndroid [ - bison flex rsync - ] ++ lib.optionals (stdenvNoCC.buildPlatform.isDarwin && - stdenvNoCC.hostPlatform.isMips) [ - darwin-endian-h - darwin-byteswap-h - ]; - - extraIncludeDirs = lib.optionals (with stdenvNoCC.hostPlatform; isPower && is32bit && isBigEndian) ["ppc"]; - - inherit patches; - - hardeningDisable = lib.optional stdenvNoCC.buildPlatform.isDarwin "format"; - - makeFlags = [ - "SHELL=bash" - # Avoid use of runtime build->host compilers for checks. These - # checks only cared to work around bugs in very old compilers, so - # these changes should be safe. - "cc-version:=9999" - "cc-fullversion:=999999" - # `$(..)` expanded by make alone - "HOSTCC:=$(CC_FOR_BUILD)" - "HOSTCXX:=$(CXX_FOR_BUILD)" - ]; - - # Skip clean on darwin, case-sensitivity issues. - buildPhase = lib.optionalString (!stdenvNoCC.buildPlatform.isDarwin) '' - make mrproper $makeFlags - '' + (if stdenvNoCC.hostPlatform.isAndroid then '' - make defconfig - make headers_install - '' else '' - make headers $makeFlags - ''); - - checkPhase = '' - make headers_check $makeFlags - ''; + makeLinuxHeaders = + { + src, + version, + patches ? [ ], + }: + stdenvNoCC.mkDerivation { + inherit src; - # The following command requires rsync: - # make headers_install INSTALL_HDR_PATH=$out $makeFlags - # but rsync depends on popt which does not compile on aarch64 without - # updateAutotoolsGnuConfigScriptsHook which is not enabled in stage2, - # so we replicate it with cp. This also reduces bootstrap closure size. - installPhase = '' - mkdir -p $out - cp -r usr/include $out - find $out -type f ! -name '*.h' -delete - '' - # Some builds (e.g. KVM) want a kernel.release. - + '' - mkdir -p $out/include/config - echo "${version}-default" > $out/include/config/kernel.release - ''; + pname = "linux-headers"; + inherit version; + + ARCH = stdenvNoCC.hostPlatform.linuxArch; + + strictDeps = true; + enableParallelBuilding = true; + + # It may look odd that we use `stdenvNoCC`, and yet explicit depend on a cc. + # We do this so we have a build->build, not build->host, C compiler. + depsBuildBuild = [ buildPackages.stdenv.cc ]; + # `elf-header` is null when libc provides `elf.h`. + nativeBuildInputs = + [ + perl + elf-header + ] + ++ lib.optionals stdenvNoCC.hostPlatform.isAndroid [ + bison + flex + rsync + ] + ++ lib.optionals (stdenvNoCC.buildPlatform.isDarwin && stdenvNoCC.hostPlatform.isMips) [ + darwin-endian-h + darwin-byteswap-h + ]; + + extraIncludeDirs = lib.optionals (with stdenvNoCC.hostPlatform; isPower && is32bit && isBigEndian) [ + "ppc" + ]; + + inherit patches; - meta = with lib; { - description = "Header files and scripts for Linux kernel"; - license = licenses.gpl2Only; - platforms = platforms.linux; + hardeningDisable = lib.optional stdenvNoCC.buildPlatform.isDarwin "format"; + + makeFlags = [ + "SHELL=bash" + # Avoid use of runtime build->host compilers for checks. These + # checks only cared to work around bugs in very old compilers, so + # these changes should be safe. + "cc-version:=9999" + "cc-fullversion:=999999" + # `$(..)` expanded by make alone + "HOSTCC:=$(CC_FOR_BUILD)" + "HOSTCXX:=$(CXX_FOR_BUILD)" + ]; + + # Skip clean on darwin, case-sensitivity issues. + buildPhase = + lib.optionalString (!stdenvNoCC.buildPlatform.isDarwin) '' + make mrproper $makeFlags + '' + + ( + if stdenvNoCC.hostPlatform.isAndroid then + '' + make defconfig + make headers_install + '' + else + '' + make headers $makeFlags + '' + ); + + checkPhase = '' + make headers_check $makeFlags + ''; + + # The following command requires rsync: + # make headers_install INSTALL_HDR_PATH=$out $makeFlags + # but rsync depends on popt which does not compile on aarch64 without + # updateAutotoolsGnuConfigScriptsHook which is not enabled in stage2, + # so we replicate it with cp. This also reduces bootstrap closure size. + installPhase = + '' + mkdir -p $out + cp -r usr/include $out + find $out -type f ! -name '*.h' -delete + '' + # Some builds (e.g. KVM) want a kernel.release. + + '' + mkdir -p $out/include/config + echo "${version}-default" > $out/include/config/kernel.release + ''; + + meta = with lib; { + description = "Header files and scripts for Linux kernel"; + license = licenses.gpl2Only; + platforms = platforms.linux; + }; }; - }; -in { +in +{ inherit makeLinuxHeaders; - linuxHeaders = let version = "6.10"; in + linuxHeaders = + let + version = "6.10"; + in makeLinuxHeaders { inherit version; src = fetchurl { diff --git a/pkgs/os-specific/linux/kernel/common-config.nix b/pkgs/os-specific/linux/kernel/common-config.nix index c2f89047b7b34f..f1abc7cab3fe1e 100644 --- a/pkgs/os-specific/linux/kernel/common-config.nix +++ b/pkgs/os-specific/linux/kernel/common-config.nix @@ -10,10 +10,13 @@ # hardware problems with a new one. # Configuration -{ lib, stdenv, version -, rustAvailable +{ + lib, + stdenv, + version, + rustAvailable, -, features ? {} + features ? { }, }: with lib.kernel; @@ -21,14 +24,23 @@ with (lib.kernel.whenHelpers version); let # configuration items have to be part of a subattrs - flattenKConf = nested: lib.mapAttrs (name: values: if lib.length values == 1 then lib.head values else throw "duplicate kernel configuration option: ${name}") (lib.zipAttrs (lib.attrValues nested)); - - whenPlatformHasEBPFJit = - lib.mkIf (stdenv.hostPlatform.isAarch32 || - stdenv.hostPlatform.isAarch64 || - stdenv.hostPlatform.isx86_64 || - (stdenv.hostPlatform.isPower && stdenv.hostPlatform.is64bit) || - (stdenv.hostPlatform.isMips && stdenv.hostPlatform.is64bit)); + flattenKConf = + nested: + lib.mapAttrs ( + name: values: + if lib.length values == 1 then + lib.head values + else + throw "duplicate kernel configuration option: ${name}" + ) (lib.zipAttrs (lib.attrValues nested)); + + whenPlatformHasEBPFJit = lib.mkIf ( + stdenv.hostPlatform.isAarch32 + || stdenv.hostPlatform.isAarch64 + || stdenv.hostPlatform.isx86_64 + || (stdenv.hostPlatform.isPower && stdenv.hostPlatform.is64bit) + || (stdenv.hostPlatform.isMips && stdenv.hostPlatform.is64bit) + ); forceRust = features.rust or false; kernelSupportsRust = lib.versionAtLeast version "6.7"; @@ -46,128 +58,130 @@ let debug = { # Necessary for BTF and crashkernel - DEBUG_INFO = yes; + DEBUG_INFO = yes; DEBUG_INFO_DWARF_TOOLCHAIN_DEFAULT = whenAtLeast "5.18" yes; # Reduced debug info conflict with BTF and have been enabled in # aarch64 defconfig since 5.13 - DEBUG_INFO_REDUCED = whenAtLeast "5.13" (option no); - DEBUG_INFO_BTF = option yes; + DEBUG_INFO_REDUCED = whenAtLeast "5.13" (option no); + DEBUG_INFO_BTF = option yes; # Allow loading modules with mismatched BTFs # FIXME: figure out how to actually make BTFs reproducible instead # See https://github.com/NixOS/nixpkgs/pull/181456 for details. MODULE_ALLOW_BTF_MISMATCH = whenAtLeast "5.18" (option yes); - BPF_LSM = whenAtLeast "5.7" (option yes); - DEBUG_KERNEL = yes; - DEBUG_DEVRES = no; - DYNAMIC_DEBUG = yes; - DEBUG_STACK_USAGE = no; - RCU_TORTURE_TEST = no; - SCHEDSTATS = yes; - DETECT_HUNG_TASK = yes; - CRASH_DUMP = yes; + BPF_LSM = whenAtLeast "5.7" (option yes); + DEBUG_KERNEL = yes; + DEBUG_DEVRES = no; + DYNAMIC_DEBUG = yes; + DEBUG_STACK_USAGE = no; + RCU_TORTURE_TEST = no; + SCHEDSTATS = yes; + DETECT_HUNG_TASK = yes; + CRASH_DUMP = yes; # Easier debugging of NFS issues. - SUNRPC_DEBUG = yes; + SUNRPC_DEBUG = yes; # Provide access to tunables like sched_migration_cost_ns - SCHED_DEBUG = yes; + SCHED_DEBUG = yes; # Count IRQ and steal CPU time separately - IRQ_TIME_ACCOUNTING = yes; - PARAVIRT_TIME_ACCOUNTING = yes; + IRQ_TIME_ACCOUNTING = yes; + PARAVIRT_TIME_ACCOUNTING = yes; # Enable CPU lockup detection - LOCKUP_DETECTOR = yes; - SOFTLOCKUP_DETECTOR = yes; - HARDLOCKUP_DETECTOR = yes; + LOCKUP_DETECTOR = yes; + SOFTLOCKUP_DETECTOR = yes; + HARDLOCKUP_DETECTOR = yes; # Enable streaming logs to a remote device over a network - NETCONSOLE = module; - NETCONSOLE_DYNAMIC = yes; + NETCONSOLE = module; + NETCONSOLE_DYNAMIC = yes; # Export known printks in debugfs - PRINTK_INDEX = whenAtLeast "5.15" yes; + PRINTK_INDEX = whenAtLeast "5.15" yes; # Enable crashkernel support - PROC_VMCORE = yes; + PROC_VMCORE = yes; }; - power-management = { - CPU_FREQ_DEFAULT_GOV_SCHEDUTIL = yes; - CPU_FREQ_GOV_SCHEDUTIL = yes; - PM_ADVANCED_DEBUG = yes; - PM_WAKELOCKS = yes; - POWERCAP = yes; - # ACPI Firmware Performance Data Table Support - ACPI_FPDT = whenAtLeast "5.12" (option yes); - # ACPI Heterogeneous Memory Attribute Table Support - ACPI_HMAT = option yes; - # ACPI Platform Error Interface - ACPI_APEI = (option yes); - # APEI Generic Hardware Error Source - ACPI_APEI_GHES = (option yes); - - # Enable lazy RCUs for power savings: - # https://lore.kernel.org/rcu/20221019225138.GA2499943@paulmck-ThinkPad-P17-Gen-1/ - # RCU_LAZY depends on RCU_NOCB_CPU depends on NO_HZ_FULL - # depends on HAVE_VIRT_CPU_ACCOUNTING_GEN depends on 64BIT, - # so we can't force-enable this - RCU_LAZY = whenAtLeast "6.2" (option yes); - - # Auto suspend Bluetooth devices at idle - BT_HCIBTUSB_AUTOSUSPEND = yes; - - # Expose cpufreq stats in sysfs - CPU_FREQ_STAT = yes; - - # Enable CPU energy model for scheduling - ENERGY_MODEL = whenAtLeast "5.0" yes; - - # Enable thermal interface netlink API - THERMAL_NETLINK = whenAtLeast "5.9" yes; - - # Prefer power-efficient workqueue implementation to per-CPU workqueues, - # which is slightly slower, but improves battery life. - # This is opt-in per workqueue, and can be disabled globally with a kernel command line option. - WQ_POWER_EFFICIENT_DEFAULT = yes; - - # Default SATA link power management to "medium with device initiated PM" - # for some extra power savings. - SATA_MOBILE_LPM_POLICY = whenAtLeast "5.18" (freeform "3"); - - # GPIO power management - POWER_RESET_GPIO = option yes; - POWER_RESET_GPIO_RESTART = option yes; - - # Enable Pulse-Width-Modulation support, commonly used for fan and backlight. - PWM = yes; - } // lib.optionalAttrs (stdenv.hostPlatform.isx86) { - INTEL_IDLE = yes; - INTEL_RAPL = module; - X86_INTEL_LPSS = yes; - X86_INTEL_PSTATE = yes; - X86_AMD_PSTATE = whenAtLeast "5.17" yes; - # Intel DPTF (Dynamic Platform and Thermal Framework) Support - ACPI_DPTF = whenAtLeast "5.10" yes; - - # Required to bring up some Bay Trail devices properly - I2C = yes; - I2C_DESIGNWARE_CORE = yes; - I2C_DESIGNWARE_PLATFORM = yes; - PMIC_OPREGION = whenAtLeast "5.10" yes; - INTEL_SOC_PMIC = whenAtLeast "5.10" yes; - BYTCRC_PMIC_OPREGION = whenAtLeast "5.10" yes; - CHTCRC_PMIC_OPREGION = whenAtLeast "5.10" yes; - XPOWER_PMIC_OPREGION = whenAtLeast "5.10" yes; - BXT_WC_PMIC_OPREGION = whenAtLeast "5.10" yes; - INTEL_SOC_PMIC_CHTWC = whenAtLeast "5.10" yes; - CHT_WC_PMIC_OPREGION = whenAtLeast "5.10" yes; - INTEL_SOC_PMIC_CHTDC_TI = whenAtLeast "5.10" yes; - CHT_DC_TI_PMIC_OPREGION = whenAtLeast "5.10" yes; - MFD_TPS68470 = whenBetween "5.10" "5.13" yes; - TPS68470_PMIC_OPREGION = whenAtLeast "5.10" yes; - - # Enable Intel thermal hardware feedback - INTEL_HFI_THERMAL = whenAtLeast "5.18" yes; - }; + power-management = + { + CPU_FREQ_DEFAULT_GOV_SCHEDUTIL = yes; + CPU_FREQ_GOV_SCHEDUTIL = yes; + PM_ADVANCED_DEBUG = yes; + PM_WAKELOCKS = yes; + POWERCAP = yes; + # ACPI Firmware Performance Data Table Support + ACPI_FPDT = whenAtLeast "5.12" (option yes); + # ACPI Heterogeneous Memory Attribute Table Support + ACPI_HMAT = option yes; + # ACPI Platform Error Interface + ACPI_APEI = (option yes); + # APEI Generic Hardware Error Source + ACPI_APEI_GHES = (option yes); + + # Enable lazy RCUs for power savings: + # https://lore.kernel.org/rcu/20221019225138.GA2499943@paulmck-ThinkPad-P17-Gen-1/ + # RCU_LAZY depends on RCU_NOCB_CPU depends on NO_HZ_FULL + # depends on HAVE_VIRT_CPU_ACCOUNTING_GEN depends on 64BIT, + # so we can't force-enable this + RCU_LAZY = whenAtLeast "6.2" (option yes); + + # Auto suspend Bluetooth devices at idle + BT_HCIBTUSB_AUTOSUSPEND = yes; + + # Expose cpufreq stats in sysfs + CPU_FREQ_STAT = yes; + + # Enable CPU energy model for scheduling + ENERGY_MODEL = whenAtLeast "5.0" yes; + + # Enable thermal interface netlink API + THERMAL_NETLINK = whenAtLeast "5.9" yes; + + # Prefer power-efficient workqueue implementation to per-CPU workqueues, + # which is slightly slower, but improves battery life. + # This is opt-in per workqueue, and can be disabled globally with a kernel command line option. + WQ_POWER_EFFICIENT_DEFAULT = yes; + + # Default SATA link power management to "medium with device initiated PM" + # for some extra power savings. + SATA_MOBILE_LPM_POLICY = whenAtLeast "5.18" (freeform "3"); + + # GPIO power management + POWER_RESET_GPIO = option yes; + POWER_RESET_GPIO_RESTART = option yes; + + # Enable Pulse-Width-Modulation support, commonly used for fan and backlight. + PWM = yes; + } + // lib.optionalAttrs (stdenv.hostPlatform.isx86) { + INTEL_IDLE = yes; + INTEL_RAPL = module; + X86_INTEL_LPSS = yes; + X86_INTEL_PSTATE = yes; + X86_AMD_PSTATE = whenAtLeast "5.17" yes; + # Intel DPTF (Dynamic Platform and Thermal Framework) Support + ACPI_DPTF = whenAtLeast "5.10" yes; + + # Required to bring up some Bay Trail devices properly + I2C = yes; + I2C_DESIGNWARE_CORE = yes; + I2C_DESIGNWARE_PLATFORM = yes; + PMIC_OPREGION = whenAtLeast "5.10" yes; + INTEL_SOC_PMIC = whenAtLeast "5.10" yes; + BYTCRC_PMIC_OPREGION = whenAtLeast "5.10" yes; + CHTCRC_PMIC_OPREGION = whenAtLeast "5.10" yes; + XPOWER_PMIC_OPREGION = whenAtLeast "5.10" yes; + BXT_WC_PMIC_OPREGION = whenAtLeast "5.10" yes; + INTEL_SOC_PMIC_CHTWC = whenAtLeast "5.10" yes; + CHT_WC_PMIC_OPREGION = whenAtLeast "5.10" yes; + INTEL_SOC_PMIC_CHTDC_TI = whenAtLeast "5.10" yes; + CHT_DC_TI_PMIC_OPREGION = whenAtLeast "5.10" yes; + MFD_TPS68470 = whenBetween "5.10" "5.13" yes; + TPS68470_PMIC_OPREGION = whenAtLeast "5.10" yes; + + # Enable Intel thermal hardware feedback + INTEL_HFI_THERMAL = whenAtLeast "5.18" yes; + }; external-firmware = { # Support drivers that need external firmware. @@ -176,7 +190,7 @@ let proc-config-gz = { # Make /proc/config.gz available - IKCONFIG = yes; + IKCONFIG = yes; IKCONFIG_PROC = yes; }; @@ -186,25 +200,27 @@ let CC_OPTIMIZE_FOR_SIZE = no; }; - memory = { - DAMON = whenAtLeast "5.15" yes; - DAMON_VADDR = whenAtLeast "5.15" yes; - DAMON_PADDR = whenAtLeast "5.16" yes; - DAMON_SYSFS = whenAtLeast "5.18" yes; - DAMON_DBGFS = whenBetween "5.15" "6.9" yes; - DAMON_RECLAIM = whenAtLeast "5.16" yes; - DAMON_LRU_SORT = whenAtLeast "6.0" yes; - # Support recovering from memory failures on systems with ECC and MCA recovery. - MEMORY_FAILURE = yes; - - # Collect ECC errors and retire pages that fail too often - RAS_CEC = yes; - } // lib.optionalAttrs (stdenv.hostPlatform.is32bit) { - # Enable access to the full memory range (aka PAE) on 32-bit architectures - # This check isn't super accurate but it's close enough - HIGHMEM = option yes; - BOUNCE = option yes; - }; + memory = + { + DAMON = whenAtLeast "5.15" yes; + DAMON_VADDR = whenAtLeast "5.15" yes; + DAMON_PADDR = whenAtLeast "5.16" yes; + DAMON_SYSFS = whenAtLeast "5.18" yes; + DAMON_DBGFS = whenBetween "5.15" "6.9" yes; + DAMON_RECLAIM = whenAtLeast "5.16" yes; + DAMON_LRU_SORT = whenAtLeast "6.0" yes; + # Support recovering from memory failures on systems with ECC and MCA recovery. + MEMORY_FAILURE = yes; + + # Collect ECC errors and retire pages that fail too often + RAS_CEC = yes; + } + // lib.optionalAttrs (stdenv.hostPlatform.is32bit) { + # Enable access to the full memory range (aka PAE) on 32-bit architectures + # This check isn't super accurate but it's close enough + HIGHMEM = option yes; + BOUNCE = option yes; + }; memtest = { MEMTEST = yes; @@ -214,7 +230,7 @@ let # module, so that the initrd gets a good I/O scheduler. scheduler = { IOSCHED_CFQ = whenOlder "5.0" yes; # Removed in 5.0-RC1 - BLK_CGROUP = yes; # required by CFQ" + BLK_CGROUP = yes; # required by CFQ" BLK_CGROUP_IOLATENCY = yes; BLK_CGROUP_IOCOST = yes; IOSCHED_DEADLINE = whenOlder "5.0" yes; # Removed in 5.0-RC1 @@ -227,7 +243,6 @@ let UCLAMP_TASK_GROUP = yes; }; - timer = { # Enable Full Dynticks System. # NO_HZ_FULL depends on HAVE_VIRT_CPU_ACCOUNTING_GEN depends on 64BIT @@ -236,185 +251,193 @@ let # Enable NUMA. numa = { - NUMA = option yes; + NUMA = option yes; NUMA_BALANCING = option yes; }; - networking = { - NET = yes; - IP_ADVANCED_ROUTER = yes; - IP_PNP = no; - IP_ROUTE_MULTIPATH = yes; - IP_VS_PROTO_TCP = yes; - IP_VS_PROTO_UDP = yes; - IP_VS_PROTO_ESP = yes; - IP_VS_PROTO_AH = yes; - IP_VS_IPV6 = yes; - IP_DCCP_CCID3 = no; # experimental - CLS_U32_PERF = yes; - CLS_U32_MARK = yes; - BPF_JIT = whenPlatformHasEBPFJit yes; - BPF_JIT_ALWAYS_ON = whenPlatformHasEBPFJit no; # whenPlatformHasEBPFJit yes; # see https://github.com/NixOS/nixpkgs/issues/79304 - HAVE_EBPF_JIT = whenPlatformHasEBPFJit yes; - BPF_STREAM_PARSER = yes; - XDP_SOCKETS = yes; - XDP_SOCKETS_DIAG = yes; - WAN = yes; - TCP_CONG_ADVANCED = yes; - TCP_CONG_CUBIC = yes; # This is the default congestion control algorithm since 2.6.19 - # Required by systemd per-cgroup firewalling - CGROUP_BPF = option yes; - CGROUP_NET_PRIO = yes; # Required by systemd - IP_ROUTE_VERBOSE = yes; - IP_MROUTE_MULTIPLE_TABLES = yes; - IP_MULTICAST = yes; - IP_MULTIPLE_TABLES = yes; - IPV6 = yes; - IPV6_ROUTER_PREF = yes; - IPV6_ROUTE_INFO = yes; - IPV6_OPTIMISTIC_DAD = yes; - IPV6_MULTIPLE_TABLES = yes; - IPV6_SUBTREES = yes; - IPV6_MROUTE = yes; - IPV6_MROUTE_MULTIPLE_TABLES = yes; - IPV6_PIMSM_V2 = yes; - IPV6_FOU_TUNNEL = module; - IPV6_SEG6_LWTUNNEL = yes; - IPV6_SEG6_HMAC = yes; - IPV6_SEG6_BPF = yes; - NET_CLS_BPF = module; - NET_ACT_BPF = module; - NET_SCHED = yes; - L2TP_V3 = yes; - L2TP_IP = module; - L2TP_ETH = module; - BRIDGE_VLAN_FILTERING = yes; - BONDING = module; - NET_L3_MASTER_DEV = option yes; - NET_FOU_IP_TUNNELS = option yes; - IP_NF_TARGET_REDIRECT = module; - - PPP_MULTILINK = yes; # PPP multilink support - PPP_FILTER = yes; - - # needed for iwd WPS support (wpa_supplicant replacement) - KEY_DH_OPERATIONS = yes; - - # needed for nftables - # Networking Options - NETFILTER = yes; - NETFILTER_ADVANCED = yes; - # Core Netfilter Configuration - NF_CONNTRACK_ZONES = yes; - NF_CONNTRACK_EVENTS = yes; - NF_CONNTRACK_TIMEOUT = yes; - NF_CONNTRACK_TIMESTAMP = yes; - NETFILTER_NETLINK_GLUE_CT = yes; - NF_TABLES_INET = yes; - NF_TABLES_NETDEV = yes; - NFT_REJECT_NETDEV = whenAtLeast "5.11" module; - - # IP: Netfilter Configuration - NF_TABLES_IPV4 = yes; - NF_TABLES_ARP = yes; - # IPv6: Netfilter Configuration - NF_TABLES_IPV6 = yes; - # Bridge Netfilter Configuration - NF_TABLES_BRIDGE = module; - # Expose some debug info - NF_CONNTRACK_PROCFS = yes; - NF_FLOW_TABLE_PROCFS = whenAtLeast "6.0" yes; - - # needed for `dropwatch` - # Builtin-only since https://github.com/torvalds/linux/commit/f4b6bcc7002f0e3a3428bac33cf1945abff95450 - NET_DROP_MONITOR = yes; - - # needed for ss - # Use a lower priority to allow these options to be overridden in hardened/config.nix - INET_DIAG = lib.mkDefault module; - INET_TCP_DIAG = lib.mkDefault module; - INET_UDP_DIAG = lib.mkDefault module; - INET_RAW_DIAG = lib.mkDefault module; - INET_DIAG_DESTROY = lib.mkDefault yes; - - # IPsec over TCP - INET_ESPINTCP = whenAtLeast "5.8" yes; - INET6_ESPINTCP = whenAtLeast "5.8" yes; - - # enable multipath-tcp - MPTCP = whenAtLeast "5.6" yes; - MPTCP_IPV6 = whenAtLeast "5.6" yes; - INET_MPTCP_DIAG = whenAtLeast "5.9" (lib.mkDefault module); - - # Kernel TLS - TLS = module; - TLS_DEVICE = yes; - - # infiniband - INFINIBAND = module; - INFINIBAND_IPOIB = module; - INFINIBAND_IPOIB_CM = yes; - - # Enable debugfs for wireless drivers - CFG80211_DEBUGFS = yes; - MAC80211_DEBUGFS = yes; - } // lib.optionalAttrs (stdenv.hostPlatform.system == "aarch64-linux") { - # Not enabled by default, hides modules behind it - NET_VENDOR_MEDIATEK = yes; - # Enable SoC interface for MT7915 module, required for MT798X. - MT7986_WMAC = whenBetween "5.18" "6.6" yes; - MT798X_WMAC = whenAtLeast "6.6" yes; - }; + networking = + { + NET = yes; + IP_ADVANCED_ROUTER = yes; + IP_PNP = no; + IP_ROUTE_MULTIPATH = yes; + IP_VS_PROTO_TCP = yes; + IP_VS_PROTO_UDP = yes; + IP_VS_PROTO_ESP = yes; + IP_VS_PROTO_AH = yes; + IP_VS_IPV6 = yes; + IP_DCCP_CCID3 = no; # experimental + CLS_U32_PERF = yes; + CLS_U32_MARK = yes; + BPF_JIT = whenPlatformHasEBPFJit yes; + BPF_JIT_ALWAYS_ON = whenPlatformHasEBPFJit no; # whenPlatformHasEBPFJit yes; # see https://github.com/NixOS/nixpkgs/issues/79304 + HAVE_EBPF_JIT = whenPlatformHasEBPFJit yes; + BPF_STREAM_PARSER = yes; + XDP_SOCKETS = yes; + XDP_SOCKETS_DIAG = yes; + WAN = yes; + TCP_CONG_ADVANCED = yes; + TCP_CONG_CUBIC = yes; # This is the default congestion control algorithm since 2.6.19 + # Required by systemd per-cgroup firewalling + CGROUP_BPF = option yes; + CGROUP_NET_PRIO = yes; # Required by systemd + IP_ROUTE_VERBOSE = yes; + IP_MROUTE_MULTIPLE_TABLES = yes; + IP_MULTICAST = yes; + IP_MULTIPLE_TABLES = yes; + IPV6 = yes; + IPV6_ROUTER_PREF = yes; + IPV6_ROUTE_INFO = yes; + IPV6_OPTIMISTIC_DAD = yes; + IPV6_MULTIPLE_TABLES = yes; + IPV6_SUBTREES = yes; + IPV6_MROUTE = yes; + IPV6_MROUTE_MULTIPLE_TABLES = yes; + IPV6_PIMSM_V2 = yes; + IPV6_FOU_TUNNEL = module; + IPV6_SEG6_LWTUNNEL = yes; + IPV6_SEG6_HMAC = yes; + IPV6_SEG6_BPF = yes; + NET_CLS_BPF = module; + NET_ACT_BPF = module; + NET_SCHED = yes; + L2TP_V3 = yes; + L2TP_IP = module; + L2TP_ETH = module; + BRIDGE_VLAN_FILTERING = yes; + BONDING = module; + NET_L3_MASTER_DEV = option yes; + NET_FOU_IP_TUNNELS = option yes; + IP_NF_TARGET_REDIRECT = module; + + PPP_MULTILINK = yes; # PPP multilink support + PPP_FILTER = yes; + + # needed for iwd WPS support (wpa_supplicant replacement) + KEY_DH_OPERATIONS = yes; + + # needed for nftables + # Networking Options + NETFILTER = yes; + NETFILTER_ADVANCED = yes; + # Core Netfilter Configuration + NF_CONNTRACK_ZONES = yes; + NF_CONNTRACK_EVENTS = yes; + NF_CONNTRACK_TIMEOUT = yes; + NF_CONNTRACK_TIMESTAMP = yes; + NETFILTER_NETLINK_GLUE_CT = yes; + NF_TABLES_INET = yes; + NF_TABLES_NETDEV = yes; + NFT_REJECT_NETDEV = whenAtLeast "5.11" module; + + # IP: Netfilter Configuration + NF_TABLES_IPV4 = yes; + NF_TABLES_ARP = yes; + # IPv6: Netfilter Configuration + NF_TABLES_IPV6 = yes; + # Bridge Netfilter Configuration + NF_TABLES_BRIDGE = module; + # Expose some debug info + NF_CONNTRACK_PROCFS = yes; + NF_FLOW_TABLE_PROCFS = whenAtLeast "6.0" yes; + + # needed for `dropwatch` + # Builtin-only since https://github.com/torvalds/linux/commit/f4b6bcc7002f0e3a3428bac33cf1945abff95450 + NET_DROP_MONITOR = yes; + + # needed for ss + # Use a lower priority to allow these options to be overridden in hardened/config.nix + INET_DIAG = lib.mkDefault module; + INET_TCP_DIAG = lib.mkDefault module; + INET_UDP_DIAG = lib.mkDefault module; + INET_RAW_DIAG = lib.mkDefault module; + INET_DIAG_DESTROY = lib.mkDefault yes; + + # IPsec over TCP + INET_ESPINTCP = whenAtLeast "5.8" yes; + INET6_ESPINTCP = whenAtLeast "5.8" yes; + + # enable multipath-tcp + MPTCP = whenAtLeast "5.6" yes; + MPTCP_IPV6 = whenAtLeast "5.6" yes; + INET_MPTCP_DIAG = whenAtLeast "5.9" (lib.mkDefault module); + + # Kernel TLS + TLS = module; + TLS_DEVICE = yes; + + # infiniband + INFINIBAND = module; + INFINIBAND_IPOIB = module; + INFINIBAND_IPOIB_CM = yes; + + # Enable debugfs for wireless drivers + CFG80211_DEBUGFS = yes; + MAC80211_DEBUGFS = yes; + } + // lib.optionalAttrs (stdenv.hostPlatform.system == "aarch64-linux") { + # Not enabled by default, hides modules behind it + NET_VENDOR_MEDIATEK = yes; + # Enable SoC interface for MT7915 module, required for MT798X. + MT7986_WMAC = whenBetween "5.18" "6.6" yes; + MT798X_WMAC = whenAtLeast "6.6" yes; + }; wireless = { - CFG80211_WEXT = option yes; # Without it, ipw2200 drivers don't build - IPW2100_MONITOR = option yes; # support promiscuous mode - IPW2200_MONITOR = option yes; # support promiscuous mode - HOSTAP_FIRMWARE = whenOlder "6.8" (option yes); # Support downloading firmware images with Host AP driver - HOSTAP_FIRMWARE_NVRAM = whenOlder "6.8" (option yes); - MAC80211_MESH = option yes; # Enable 802.11s (mesh networking) support - ATH9K_PCI = option yes; # Detect Atheros AR9xxx cards on PCI(e) bus - ATH9K_AHB = option yes; # Ditto, AHB bus + CFG80211_WEXT = option yes; # Without it, ipw2200 drivers don't build + IPW2100_MONITOR = option yes; # support promiscuous mode + IPW2200_MONITOR = option yes; # support promiscuous mode + HOSTAP_FIRMWARE = whenOlder "6.8" (option yes); # Support downloading firmware images with Host AP driver + HOSTAP_FIRMWARE_NVRAM = whenOlder "6.8" (option yes); + MAC80211_MESH = option yes; # Enable 802.11s (mesh networking) support + ATH9K_PCI = option yes; # Detect Atheros AR9xxx cards on PCI(e) bus + ATH9K_AHB = option yes; # Ditto, AHB bus # The description of this option makes it sound dangerous or even illegal # But OpenWRT enables it by default: https://github.com/openwrt/openwrt/blob/master/package/kernel/mac80211/Makefile#L55 # At the time of writing (25-06-2023): this is only used in a "correct" way by ath drivers for initiating DFS radiation # for "certified devices" - EXPERT = option yes; # this is needed for offering the certification option - RFKILL_INPUT = option yes; # counteract an undesired effect of setting EXPERT + EXPERT = option yes; # this is needed for offering the certification option + RFKILL_INPUT = option yes; # counteract an undesired effect of setting EXPERT CFG80211_CERTIFICATION_ONUS = option yes; # DFS: "Dynamic Frequency Selection" is a spectrum-sharing mechanism that allows # you to use certain interesting frequency when your local regulatory domain mandates it. # ATH drivers hides the feature behind this option and makes hostapd works with DFS frequencies. # OpenWRT enables it too: https://github.com/openwrt/openwrt/blob/master/package/kernel/mac80211/ath.mk#L42 - ATH9K_DFS_CERTIFIED = option yes; - ATH10K_DFS_CERTIFIED = option yes; - B43_PHY_HT = option yes; - BCMA_HOST_PCI = option yes; - RTW88 = module; - RTW88_8822BE = lib.mkMerge [ (whenOlder "5.8" yes) (whenAtLeast "5.8" module) ]; - RTW88_8822CE = lib.mkMerge [ (whenOlder "5.8" yes) (whenAtLeast "5.8" module) ]; + ATH9K_DFS_CERTIFIED = option yes; + ATH10K_DFS_CERTIFIED = option yes; + B43_PHY_HT = option yes; + BCMA_HOST_PCI = option yes; + RTW88 = module; + RTW88_8822BE = lib.mkMerge [ + (whenOlder "5.8" yes) + (whenAtLeast "5.8" module) + ]; + RTW88_8822CE = lib.mkMerge [ + (whenOlder "5.8" yes) + (whenAtLeast "5.8" module) + ]; }; fb = { - FB = yes; - FB_EFI = yes; - FB_NVIDIA_I2C = yes; # Enable DDC Support - FB_RIVA_I2C = yes; - FB_ATY_CT = yes; # Mach64 CT/VT/GT/LT (incl. 3D RAGE) support - FB_ATY_GX = yes; # Mach64 GX support - FB_SAVAGE_I2C = yes; - FB_SAVAGE_ACCEL = yes; - FB_SIS_300 = yes; - FB_SIS_315 = yes; - FB_3DFX_ACCEL = yes; - FB_VESA = yes; + FB = yes; + FB_EFI = yes; + FB_NVIDIA_I2C = yes; # Enable DDC Support + FB_RIVA_I2C = yes; + FB_ATY_CT = yes; # Mach64 CT/VT/GT/LT (incl. 3D RAGE) support + FB_ATY_GX = yes; # Mach64 GX support + FB_SAVAGE_I2C = yes; + FB_SAVAGE_ACCEL = yes; + FB_SIS_300 = yes; + FB_SIS_315 = yes; + FB_3DFX_ACCEL = yes; + FB_VESA = yes; FRAMEBUFFER_CONSOLE = yes; FRAMEBUFFER_CONSOLE_DEFERRED_TAKEOVER = yes; FRAMEBUFFER_CONSOLE_ROTATION = yes; FRAMEBUFFER_CONSOLE_DETECT_PRIMARY = yes; - FB_GEODE = lib.mkIf (stdenv.hostPlatform.system == "i686-linux") yes; + FB_GEODE = lib.mkIf (stdenv.hostPlatform.system == "i686-linux") yes; # Use simplefb on older kernels where we don't have simpledrm (enabled below) - FB_SIMPLE = whenOlder "5.15" yes; + FB_SIMPLE = whenOlder "5.15" yes; DRM_FBDEV_EMULATION = yes; }; @@ -427,81 +450,85 @@ let FONT_TER16x32 = whenAtLeast "5.0" yes; }; - video = let - whenHasDevicePrivate = lib.mkIf (!stdenv.hostPlatform.isx86_32); - in { - # compile in DRM so simpledrm can load before initrd if necessary - AGP = yes; - DRM = yes; - - DRM_LEGACY = whenOlder "6.8" no; - - NOUVEAU_LEGACY_CTX_SUPPORT = whenOlder "6.3" no; - - # Enable simpledrm and use it for generic framebuffer - # Technically added in 5.14, but adding more complex configuration is not worth it - DRM_SIMPLEDRM = whenAtLeast "5.15" yes; - SYSFB_SIMPLEFB = whenAtLeast "5.15" yes; - - # Allow specifying custom EDID on the kernel command line - DRM_LOAD_EDID_FIRMWARE = yes; - VGA_SWITCHEROO = yes; # Hybrid graphics support - DRM_GMA500 = whenAtLeast "5.12" module; - DRM_GMA600 = whenOlder "5.13" yes; - DRM_GMA3600 = whenOlder "5.12" yes; - DRM_VMWGFX_FBCON = whenOlder "6.1" yes; - # (experimental) amdgpu support for verde and newer chipsets - DRM_AMDGPU_SI = yes; - # (stable) amdgpu support for bonaire and newer chipsets - DRM_AMDGPU_CIK = yes; - # Allow device firmware updates - DRM_DP_AUX_CHARDEV = whenOlder "6.10" yes; - DRM_DISPLAY_DP_AUX_CHARDEV = whenAtLeast "6.10" yes; - # amdgpu display core (DC) support - DRM_AMD_DC_DCN1_0 = whenOlder "5.6" yes; - DRM_AMD_DC_DCN2_0 = whenOlder "5.6" yes; - DRM_AMD_DC_DCN2_1 = whenOlder "5.6" yes; - DRM_AMD_DC_DCN3_0 = whenBetween "5.9" "5.11" yes; - DRM_AMD_DC_DCN = whenBetween "5.11" "6.4" yes; - DRM_AMD_DC_FP = whenAtLeast "6.4" yes; - DRM_AMD_DC_HDCP = whenBetween "5.5" "6.4" yes; - DRM_AMD_DC_SI = whenAtLeast "5.10" yes; - - # Enable AMD Audio Coprocessor support for HDMI outputs - DRM_AMD_ACP = yes; - - # Enable AMD secure display when available - DRM_AMD_SECURE_DISPLAY = whenAtLeast "5.13" yes; - - # Enable AMD image signal processor - DRM_AMD_ISP = whenAtLeast "6.11" yes; - - # Enable new firmware (and by extension NVK) for compatible hardware on Nouveau - DRM_NOUVEAU_GSP_DEFAULT = whenAtLeast "6.8" yes; - - # Enable Nouveau shared virtual memory (used by OpenCL) - DEVICE_PRIVATE = whenHasDevicePrivate yes; - DRM_NOUVEAU_SVM = whenHasDevicePrivate yes; - - # Enable HDMI-CEC receiver support - RC_CORE = yes; - MEDIA_CEC_RC = whenAtLeast "5.10" yes; - - # Enable CEC over DisplayPort - DRM_DP_CEC = whenOlder "6.10" yes; - DRM_DISPLAY_DP_AUX_CEC = whenAtLeast "6.10" yes; - } // lib.optionalAttrs (stdenv.hostPlatform.system == "x86_64-linux") { - # Intel GVT-g graphics virtualization supports 64-bit only - DRM_I915_GVT = yes; - DRM_I915_GVT_KVMGT = module; - # Enable Hyper-V Synthetic DRM Driver - DRM_HYPERV = whenAtLeast "5.14" module; - } // lib.optionalAttrs (stdenv.hostPlatform.system == "aarch64-linux") { - # enable HDMI-CEC on RPi boards - DRM_VC4_HDMI_CEC = yes; - # Enable HDMI out on platforms using the RK3588 lineup of SoCs. - ROCKCHIP_DW_HDMI_QP = whenAtLeast "6.13" yes; - }; + video = + let + whenHasDevicePrivate = lib.mkIf (!stdenv.hostPlatform.isx86_32); + in + { + # compile in DRM so simpledrm can load before initrd if necessary + AGP = yes; + DRM = yes; + + DRM_LEGACY = whenOlder "6.8" no; + + NOUVEAU_LEGACY_CTX_SUPPORT = whenOlder "6.3" no; + + # Enable simpledrm and use it for generic framebuffer + # Technically added in 5.14, but adding more complex configuration is not worth it + DRM_SIMPLEDRM = whenAtLeast "5.15" yes; + SYSFB_SIMPLEFB = whenAtLeast "5.15" yes; + + # Allow specifying custom EDID on the kernel command line + DRM_LOAD_EDID_FIRMWARE = yes; + VGA_SWITCHEROO = yes; # Hybrid graphics support + DRM_GMA500 = whenAtLeast "5.12" module; + DRM_GMA600 = whenOlder "5.13" yes; + DRM_GMA3600 = whenOlder "5.12" yes; + DRM_VMWGFX_FBCON = whenOlder "6.1" yes; + # (experimental) amdgpu support for verde and newer chipsets + DRM_AMDGPU_SI = yes; + # (stable) amdgpu support for bonaire and newer chipsets + DRM_AMDGPU_CIK = yes; + # Allow device firmware updates + DRM_DP_AUX_CHARDEV = whenOlder "6.10" yes; + DRM_DISPLAY_DP_AUX_CHARDEV = whenAtLeast "6.10" yes; + # amdgpu display core (DC) support + DRM_AMD_DC_DCN1_0 = whenOlder "5.6" yes; + DRM_AMD_DC_DCN2_0 = whenOlder "5.6" yes; + DRM_AMD_DC_DCN2_1 = whenOlder "5.6" yes; + DRM_AMD_DC_DCN3_0 = whenBetween "5.9" "5.11" yes; + DRM_AMD_DC_DCN = whenBetween "5.11" "6.4" yes; + DRM_AMD_DC_FP = whenAtLeast "6.4" yes; + DRM_AMD_DC_HDCP = whenBetween "5.5" "6.4" yes; + DRM_AMD_DC_SI = whenAtLeast "5.10" yes; + + # Enable AMD Audio Coprocessor support for HDMI outputs + DRM_AMD_ACP = yes; + + # Enable AMD secure display when available + DRM_AMD_SECURE_DISPLAY = whenAtLeast "5.13" yes; + + # Enable AMD image signal processor + DRM_AMD_ISP = whenAtLeast "6.11" yes; + + # Enable new firmware (and by extension NVK) for compatible hardware on Nouveau + DRM_NOUVEAU_GSP_DEFAULT = whenAtLeast "6.8" yes; + + # Enable Nouveau shared virtual memory (used by OpenCL) + DEVICE_PRIVATE = whenHasDevicePrivate yes; + DRM_NOUVEAU_SVM = whenHasDevicePrivate yes; + + # Enable HDMI-CEC receiver support + RC_CORE = yes; + MEDIA_CEC_RC = whenAtLeast "5.10" yes; + + # Enable CEC over DisplayPort + DRM_DP_CEC = whenOlder "6.10" yes; + DRM_DISPLAY_DP_AUX_CEC = whenAtLeast "6.10" yes; + } + // lib.optionalAttrs (stdenv.hostPlatform.system == "x86_64-linux") { + # Intel GVT-g graphics virtualization supports 64-bit only + DRM_I915_GVT = yes; + DRM_I915_GVT_KVMGT = module; + # Enable Hyper-V Synthetic DRM Driver + DRM_HYPERV = whenAtLeast "5.14" module; + } + // lib.optionalAttrs (stdenv.hostPlatform.system == "aarch64-linux") { + # enable HDMI-CEC on RPi boards + DRM_VC4_HDMI_CEC = yes; + # Enable HDMI out on platforms using the RK3588 lineup of SoCs. + ROCKCHIP_DW_HDMI_QP = whenAtLeast "6.13" yes; + }; # Enable Rust and features that depend on it rust = lib.optionalAttrs withRust { @@ -515,61 +542,64 @@ let DRM_PANIC_SCREEN_QR_CODE = whenAtLeast "6.12" yes; }; - sound = { - SND_DYNAMIC_MINORS = yes; - SND_AC97_POWER_SAVE = yes; # AC97 Power-Saving Mode - # 10s for the idle timeout, Fedora does 1, Arch does 10. - # The kernel says we should do 10. - # Read: https://docs.kernel.org/sound/designs/powersave.html - SND_AC97_POWER_SAVE_DEFAULT = freeform "10"; - SND_HDA_POWER_SAVE_DEFAULT = freeform "10"; - SND_HDA_INPUT_BEEP = yes; # Support digital beep via input layer - SND_HDA_RECONFIG = yes; # Support reconfiguration of jack functions - # Support configuring jack functions via fw mechanism at boot - SND_HDA_PATCH_LOADER = yes; - SND_HDA_CODEC_CA0132_DSP = whenOlder "5.7" yes; # Enable DSP firmware loading on Creative Soundblaster Z/Zx/ZxR/Recon - SND_HDA_CODEC_CS8409 = whenAtLeast "6.6" module; # Cirrus Logic HDA Bridge CS8409 - SND_OSSEMUL = yes; - SND_USB_CAIAQ_INPUT = yes; - SND_USB_AUDIO_MIDI_V2 = whenAtLeast "6.5" yes; - # Enable Sound Open Firmware support - } // lib.optionalAttrs (stdenv.hostPlatform.system == "x86_64-linux" && - lib.versionAtLeast version "5.5") { - SND_SOC_INTEL_SOUNDWIRE_SOF_MACH = whenAtLeast "5.10" module; - SND_SOC_INTEL_USER_FRIENDLY_LONG_NAMES = whenAtLeast "5.10" yes; # dep of SOF_MACH - SND_SOC_SOF_INTEL_SOUNDWIRE_LINK = whenBetween "5.10" "5.11" yes; # dep of SOF_MACH - SND_SOC_SOF_TOPLEVEL = yes; - SND_SOC_SOF_ACPI = module; - SND_SOC_SOF_PCI = module; - SND_SOC_SOF_APOLLOLAKE = whenAtLeast "5.12" module; - SND_SOC_SOF_APOLLOLAKE_SUPPORT = whenOlder "5.12" yes; - SND_SOC_SOF_CANNONLAKE = whenAtLeast "5.12" module; - SND_SOC_SOF_CANNONLAKE_SUPPORT = whenOlder "5.12" yes; - SND_SOC_SOF_COFFEELAKE = whenAtLeast "5.12" module; - SND_SOC_SOF_COFFEELAKE_SUPPORT = whenOlder "5.12" yes; - SND_SOC_SOF_COMETLAKE = whenAtLeast "5.12" module; - SND_SOC_SOF_COMETLAKE_H_SUPPORT = whenOlder "5.8" yes; - SND_SOC_SOF_COMETLAKE_LP_SUPPORT = whenOlder "5.12" yes; - SND_SOC_SOF_ELKHARTLAKE = whenAtLeast "5.12" module; - SND_SOC_SOF_ELKHARTLAKE_SUPPORT = whenOlder "5.12" yes; - SND_SOC_SOF_GEMINILAKE = whenAtLeast "5.12" module; - SND_SOC_SOF_GEMINILAKE_SUPPORT = whenOlder "5.12" yes; - SND_SOC_SOF_HDA_AUDIO_CODEC = yes; - SND_SOC_SOF_HDA_COMMON_HDMI_CODEC = whenOlder "5.7" yes; - SND_SOC_SOF_HDA_LINK = yes; - SND_SOC_SOF_ICELAKE = whenAtLeast "5.12" module; - SND_SOC_SOF_ICELAKE_SUPPORT = whenOlder "5.12" yes; - SND_SOC_SOF_INTEL_TOPLEVEL = yes; - SND_SOC_SOF_JASPERLAKE = whenAtLeast "5.12" module; - SND_SOC_SOF_JASPERLAKE_SUPPORT = whenOlder "5.12" yes; - SND_SOC_SOF_MERRIFIELD = whenAtLeast "5.12" module; - SND_SOC_SOF_MERRIFIELD_SUPPORT = whenOlder "5.12" yes; - SND_SOC_SOF_TIGERLAKE = whenAtLeast "5.12" module; - SND_SOC_SOF_TIGERLAKE_SUPPORT = whenOlder "5.12" yes; - }; + sound = + { + SND_DYNAMIC_MINORS = yes; + SND_AC97_POWER_SAVE = yes; # AC97 Power-Saving Mode + # 10s for the idle timeout, Fedora does 1, Arch does 10. + # The kernel says we should do 10. + # Read: https://docs.kernel.org/sound/designs/powersave.html + SND_AC97_POWER_SAVE_DEFAULT = freeform "10"; + SND_HDA_POWER_SAVE_DEFAULT = freeform "10"; + SND_HDA_INPUT_BEEP = yes; # Support digital beep via input layer + SND_HDA_RECONFIG = yes; # Support reconfiguration of jack functions + # Support configuring jack functions via fw mechanism at boot + SND_HDA_PATCH_LOADER = yes; + SND_HDA_CODEC_CA0132_DSP = whenOlder "5.7" yes; # Enable DSP firmware loading on Creative Soundblaster Z/Zx/ZxR/Recon + SND_HDA_CODEC_CS8409 = whenAtLeast "6.6" module; # Cirrus Logic HDA Bridge CS8409 + SND_OSSEMUL = yes; + SND_USB_CAIAQ_INPUT = yes; + SND_USB_AUDIO_MIDI_V2 = whenAtLeast "6.5" yes; + # Enable Sound Open Firmware support + } + // lib.optionalAttrs + (stdenv.hostPlatform.system == "x86_64-linux" && lib.versionAtLeast version "5.5") + { + SND_SOC_INTEL_SOUNDWIRE_SOF_MACH = whenAtLeast "5.10" module; + SND_SOC_INTEL_USER_FRIENDLY_LONG_NAMES = whenAtLeast "5.10" yes; # dep of SOF_MACH + SND_SOC_SOF_INTEL_SOUNDWIRE_LINK = whenBetween "5.10" "5.11" yes; # dep of SOF_MACH + SND_SOC_SOF_TOPLEVEL = yes; + SND_SOC_SOF_ACPI = module; + SND_SOC_SOF_PCI = module; + SND_SOC_SOF_APOLLOLAKE = whenAtLeast "5.12" module; + SND_SOC_SOF_APOLLOLAKE_SUPPORT = whenOlder "5.12" yes; + SND_SOC_SOF_CANNONLAKE = whenAtLeast "5.12" module; + SND_SOC_SOF_CANNONLAKE_SUPPORT = whenOlder "5.12" yes; + SND_SOC_SOF_COFFEELAKE = whenAtLeast "5.12" module; + SND_SOC_SOF_COFFEELAKE_SUPPORT = whenOlder "5.12" yes; + SND_SOC_SOF_COMETLAKE = whenAtLeast "5.12" module; + SND_SOC_SOF_COMETLAKE_H_SUPPORT = whenOlder "5.8" yes; + SND_SOC_SOF_COMETLAKE_LP_SUPPORT = whenOlder "5.12" yes; + SND_SOC_SOF_ELKHARTLAKE = whenAtLeast "5.12" module; + SND_SOC_SOF_ELKHARTLAKE_SUPPORT = whenOlder "5.12" yes; + SND_SOC_SOF_GEMINILAKE = whenAtLeast "5.12" module; + SND_SOC_SOF_GEMINILAKE_SUPPORT = whenOlder "5.12" yes; + SND_SOC_SOF_HDA_AUDIO_CODEC = yes; + SND_SOC_SOF_HDA_COMMON_HDMI_CODEC = whenOlder "5.7" yes; + SND_SOC_SOF_HDA_LINK = yes; + SND_SOC_SOF_ICELAKE = whenAtLeast "5.12" module; + SND_SOC_SOF_ICELAKE_SUPPORT = whenOlder "5.12" yes; + SND_SOC_SOF_INTEL_TOPLEVEL = yes; + SND_SOC_SOF_JASPERLAKE = whenAtLeast "5.12" module; + SND_SOC_SOF_JASPERLAKE_SUPPORT = whenOlder "5.12" yes; + SND_SOC_SOF_MERRIFIELD = whenAtLeast "5.12" module; + SND_SOC_SOF_MERRIFIELD_SUPPORT = whenOlder "5.12" yes; + SND_SOC_SOF_TIGERLAKE = whenAtLeast "5.12" module; + SND_SOC_SOF_TIGERLAKE_SUPPORT = whenOlder "5.12" yes; + }; usb = { - USB = yes; # compile USB core into kernel, so we can use USB_SERIAL_CONSOLE before modules + USB = yes; # compile USB core into kernel, so we can use USB_SERIAL_CONSOLE before modules USB_EHCI_ROOT_HUB_TT = yes; # Root Hub Transaction Translators USB_EHCI_TT_NEWSCHED = yes; # Improved transaction translator scheduling @@ -581,46 +611,46 @@ let }; usb-serial = { - USB_SERIAL = yes; - USB_SERIAL_GENERIC = yes; # USB Generic Serial Driver - USB_SERIAL_CONSOLE = yes; # Allow using USB serial adapter as console - U_SERIAL_CONSOLE = whenAtLeast "5.10" yes; # Allow using USB gadget as console + USB_SERIAL = yes; + USB_SERIAL_GENERIC = yes; # USB Generic Serial Driver + USB_SERIAL_CONSOLE = yes; # Allow using USB serial adapter as console + U_SERIAL_CONSOLE = whenAtLeast "5.10" yes; # Allow using USB gadget as console }; # Filesystem options - in particular, enable extended attributes and # ACLs for all filesystems that support them. filesystem = { - FANOTIFY = yes; + FANOTIFY = yes; FANOTIFY_ACCESS_PERMISSIONS = yes; - TMPFS = yes; + TMPFS = yes; TMPFS_POSIX_ACL = yes; - FS_ENCRYPTION = yes; + FS_ENCRYPTION = yes; - EXT2_FS_XATTR = yes; + EXT2_FS_XATTR = yes; EXT2_FS_POSIX_ACL = yes; - EXT2_FS_SECURITY = yes; + EXT2_FS_SECURITY = yes; EXT3_FS_POSIX_ACL = yes; - EXT3_FS_SECURITY = yes; + EXT3_FS_SECURITY = yes; EXT4_FS_POSIX_ACL = yes; - EXT4_FS_SECURITY = yes; + EXT4_FS_SECURITY = yes; - NTFS_FS = whenBetween "5.15" "6.9" no; - NTFS3_LZX_XPRESS = whenAtLeast "5.15" yes; + NTFS_FS = whenBetween "5.15" "6.9" no; + NTFS3_LZX_XPRESS = whenAtLeast "5.15" yes; NTFS3_FS_POSIX_ACL = whenAtLeast "5.15" yes; - REISERFS_FS_XATTR = option yes; + REISERFS_FS_XATTR = option yes; REISERFS_FS_POSIX_ACL = option yes; - REISERFS_FS_SECURITY = option yes; + REISERFS_FS_SECURITY = option yes; JFS_POSIX_ACL = option yes; - JFS_SECURITY = option yes; + JFS_SECURITY = option yes; - XFS_QUOTA = option yes; + XFS_QUOTA = option yes; XFS_POSIX_ACL = option yes; - XFS_RT = option yes; # XFS Realtime subvolume support + XFS_RT = option yes; # XFS Realtime subvolume support XFS_ONLINE_SCRUB = option yes; OCFS2_DEBUG_MASKLOG = option no; @@ -632,51 +662,51 @@ let UBIFS_FS_ADVANCED_COMPR = option yes; - F2FS_FS = module; - F2FS_FS_SECURITY = option yes; + F2FS_FS = module; + F2FS_FS_SECURITY = option yes; F2FS_FS_COMPRESSION = whenAtLeast "5.6" yes; - UDF_FS = module; + UDF_FS = module; - NFSD_V2_ACL = whenOlder "5.10" yes; - NFSD_V3 = whenOlder "5.10" yes; - NFSD_V3_ACL = yes; - NFSD_V4 = yes; + NFSD_V2_ACL = whenOlder "5.10" yes; + NFSD_V3 = whenOlder "5.10" yes; + NFSD_V3_ACL = yes; + NFSD_V4 = yes; NFSD_V4_SECURITY_LABEL = yes; - NFS_FSCACHE = yes; - NFS_SWAP = yes; - NFS_V3_ACL = yes; - NFS_V4_1 = yes; # NFSv4.1 client support - NFS_V4_2 = yes; + NFS_FSCACHE = yes; + NFS_SWAP = yes; + NFS_V3_ACL = yes; + NFS_V4_1 = yes; # NFSv4.1 client support + NFS_V4_2 = yes; NFS_V4_SECURITY_LABEL = yes; - NFS_LOCALIO = whenAtLeast "6.12" yes; + NFS_LOCALIO = whenAtLeast "6.12" yes; - CIFS_XATTR = yes; - CIFS_POSIX = option yes; - CIFS_FSCACHE = yes; + CIFS_XATTR = yes; + CIFS_POSIX = option yes; + CIFS_FSCACHE = yes; CIFS_WEAK_PW_HASH = whenOlder "5.15" yes; - CIFS_UPCALL = yes; - CIFS_DFS_UPCALL = yes; + CIFS_UPCALL = yes; + CIFS_DFS_UPCALL = yes; - CEPH_FSCACHE = yes; + CEPH_FSCACHE = yes; CEPH_FS_POSIX_ACL = yes; - SQUASHFS_FILE_DIRECT = yes; + SQUASHFS_FILE_DIRECT = yes; SQUASHFS_DECOMP_MULTI_PERCPU = whenOlder "6.2" yes; SQUASHFS_CHOICE_DECOMP_BY_MOUNT = whenAtLeast "6.2" yes; - SQUASHFS_XATTR = yes; - SQUASHFS_ZLIB = yes; - SQUASHFS_LZO = yes; - SQUASHFS_XZ = yes; - SQUASHFS_LZ4 = yes; - SQUASHFS_ZSTD = yes; + SQUASHFS_XATTR = yes; + SQUASHFS_ZLIB = yes; + SQUASHFS_LZO = yes; + SQUASHFS_XZ = yes; + SQUASHFS_LZ4 = yes; + SQUASHFS_ZSTD = yes; # Native Language Support modules, needed by some filesystems - NLS = yes; - NLS_DEFAULT = freeform "utf8"; - NLS_UTF8 = module; + NLS = yes; + NLS_DEFAULT = freeform "utf8"; + NLS_UTF8 = module; NLS_CODEPAGE_437 = module; # VFAT default for the codepage= mount option - NLS_ISO8859_1 = module; # VFAT default for the iocharset= mount option + NLS_ISO8859_1 = module; # VFAT default for the iocharset= mount option # Needed to use the installation iso image. Not included in all defconfigs (e.g. arm64) ISO9660_FS = module; @@ -686,133 +716,136 @@ let UNICODE = yes; # Casefolding support for filesystems }; - security = { - # Report BUG() conditions and kill the offending process. - BUG = yes; - BUG_ON_DATA_CORRUPTION = yes; - - FORTIFY_SOURCE = option yes; - - # https://googleprojectzero.blogspot.com/2019/11/bad-binder-android-in-wild-exploit.html - DEBUG_LIST = yes; - - HARDENED_USERCOPY = yes; - RANDOMIZE_BASE = option yes; - STRICT_KERNEL_RWX = yes; - STRICT_MODULE_RWX = yes; - STRICT_DEVMEM = lib.mkDefault yes; # Filter access to /dev/mem - IO_STRICT_DEVMEM = lib.mkDefault yes; - - # Prevent processes from ptracing non-children processes - SECURITY_YAMA = option yes; - # The goal of Landlock is to enable to restrict ambient rights (e.g. global filesystem access) for a set of processes. - # This does not have any effect if a program does not support it - SECURITY_LANDLOCK = whenAtLeast "5.13" yes; - - DEVKMEM = whenOlder "5.13" no; # Disable /dev/kmem - - USER_NS = yes; # Support for user namespaces - - SECURITY_APPARMOR = yes; - DEFAULT_SECURITY_APPARMOR = yes; - - SECURITY_DMESG_RESTRICT = yes; - - RANDOM_TRUST_CPU = whenOlder "6.2" yes; # allow RDRAND to seed the RNG - RANDOM_TRUST_BOOTLOADER = whenOlder "6.2" yes; # allow the bootloader to seed the RNG - - MODULE_SIG = no; # r13y, generates a random key during build and bakes it in - # Depends on MODULE_SIG and only really helps when you sign your modules - # and enforce signatures which we don't do by default. - SECURITY_LOCKDOWN_LSM = no; - - # provides a register of persistent per-UID keyrings, useful for encrypting storage pools in stratis - PERSISTENT_KEYRINGS = yes; - # enable temporary caching of the last request_key() result - KEYS_REQUEST_CACHE = yes; - # randomized slab caches - RANDOM_KMALLOC_CACHES = whenAtLeast "6.6" yes; - - # NIST SP800-90A DRBG modes - enabled by most distributions - # and required by some out-of-tree modules (ShuffleCake) - # This does not include the NSA-backdoored Dual-EC mode from the same NIST publication. - CRYPTO_DRBG_HASH = yes; - CRYPTO_DRBG_CTR = yes; - - # Enable KFENCE - # See: https://docs.kernel.org/dev-tools/kfence.html - KFENCE = whenAtLeast "5.12" yes; - - # Enable support for page poisoning. Still needs to be enabled on the command line to actually work. - PAGE_POISONING = yes; - # Randomize page allocator when page_alloc.shuffle=1 - SHUFFLE_PAGE_ALLOCATOR = yes; - - INIT_ON_ALLOC_DEFAULT_ON = yes; - - # Enable stack smashing protections in schedule() - # See: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?h=v4.8&id=0d9e26329b0c9263d4d9e0422d80a0e73268c52f - SCHED_STACK_END_CHECK = yes; - - # Enable separate slab buckets for user controlled allocations - # See: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=67f2df3b82d091ed095d0e47e1f3a9d3e18e4e41 - SLAB_BUCKETS = whenAtLeast "6.11" yes; - } // lib.optionalAttrs stdenv.hostPlatform.isx86_64 { - # Enable Intel SGX - X86_SGX = whenAtLeast "5.11" yes; - # Allow KVM guests to load SGX enclaves - X86_SGX_KVM = whenAtLeast "5.13" yes; - - # AMD Cryptographic Coprocessor (CCP) - CRYPTO_DEV_CCP = yes; - # AMD SME - AMD_MEM_ENCRYPT = yes; - # AMD SEV and AMD SEV-SE - KVM_AMD_SEV = yes; - # AMD SEV-SNP - SEV_GUEST = whenAtLeast "5.19" module; - # Shadow stacks - X86_USER_SHADOW_STACK = whenAtLeast "6.6" yes; - - # Enable support for Intel Trust Domain Extensions (TDX) - INTEL_TDX_GUEST = whenAtLeast "5.19" yes; - TDX_GUEST_DRIVER = whenAtLeast "6.2" module; - - # Mitigate straight line speculation at the cost of some file size - SLS = whenBetween "5.17" "6.9" yes; - MITIGATION_SLS = whenAtLeast "6.9" yes; - - DEFAULT_MMAP_MIN_ADDR = freeform "65536"; - } // lib.optionalAttrs stdenv.hostPlatform.isAarch64 { - DEFAULT_MMAP_MIN_ADDR = freeform "32768"; - }; + security = + { + # Report BUG() conditions and kill the offending process. + BUG = yes; + BUG_ON_DATA_CORRUPTION = yes; + + FORTIFY_SOURCE = option yes; + + # https://googleprojectzero.blogspot.com/2019/11/bad-binder-android-in-wild-exploit.html + DEBUG_LIST = yes; + + HARDENED_USERCOPY = yes; + RANDOMIZE_BASE = option yes; + STRICT_KERNEL_RWX = yes; + STRICT_MODULE_RWX = yes; + STRICT_DEVMEM = lib.mkDefault yes; # Filter access to /dev/mem + IO_STRICT_DEVMEM = lib.mkDefault yes; + + # Prevent processes from ptracing non-children processes + SECURITY_YAMA = option yes; + # The goal of Landlock is to enable to restrict ambient rights (e.g. global filesystem access) for a set of processes. + # This does not have any effect if a program does not support it + SECURITY_LANDLOCK = whenAtLeast "5.13" yes; + + DEVKMEM = whenOlder "5.13" no; # Disable /dev/kmem + + USER_NS = yes; # Support for user namespaces + + SECURITY_APPARMOR = yes; + DEFAULT_SECURITY_APPARMOR = yes; + + SECURITY_DMESG_RESTRICT = yes; + + RANDOM_TRUST_CPU = whenOlder "6.2" yes; # allow RDRAND to seed the RNG + RANDOM_TRUST_BOOTLOADER = whenOlder "6.2" yes; # allow the bootloader to seed the RNG + + MODULE_SIG = no; # r13y, generates a random key during build and bakes it in + # Depends on MODULE_SIG and only really helps when you sign your modules + # and enforce signatures which we don't do by default. + SECURITY_LOCKDOWN_LSM = no; + + # provides a register of persistent per-UID keyrings, useful for encrypting storage pools in stratis + PERSISTENT_KEYRINGS = yes; + # enable temporary caching of the last request_key() result + KEYS_REQUEST_CACHE = yes; + # randomized slab caches + RANDOM_KMALLOC_CACHES = whenAtLeast "6.6" yes; + + # NIST SP800-90A DRBG modes - enabled by most distributions + # and required by some out-of-tree modules (ShuffleCake) + # This does not include the NSA-backdoored Dual-EC mode from the same NIST publication. + CRYPTO_DRBG_HASH = yes; + CRYPTO_DRBG_CTR = yes; + + # Enable KFENCE + # See: https://docs.kernel.org/dev-tools/kfence.html + KFENCE = whenAtLeast "5.12" yes; + + # Enable support for page poisoning. Still needs to be enabled on the command line to actually work. + PAGE_POISONING = yes; + # Randomize page allocator when page_alloc.shuffle=1 + SHUFFLE_PAGE_ALLOCATOR = yes; + + INIT_ON_ALLOC_DEFAULT_ON = yes; + + # Enable stack smashing protections in schedule() + # See: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?h=v4.8&id=0d9e26329b0c9263d4d9e0422d80a0e73268c52f + SCHED_STACK_END_CHECK = yes; + + # Enable separate slab buckets for user controlled allocations + # See: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=67f2df3b82d091ed095d0e47e1f3a9d3e18e4e41 + SLAB_BUCKETS = whenAtLeast "6.11" yes; + } + // lib.optionalAttrs stdenv.hostPlatform.isx86_64 { + # Enable Intel SGX + X86_SGX = whenAtLeast "5.11" yes; + # Allow KVM guests to load SGX enclaves + X86_SGX_KVM = whenAtLeast "5.13" yes; + + # AMD Cryptographic Coprocessor (CCP) + CRYPTO_DEV_CCP = yes; + # AMD SME + AMD_MEM_ENCRYPT = yes; + # AMD SEV and AMD SEV-SE + KVM_AMD_SEV = yes; + # AMD SEV-SNP + SEV_GUEST = whenAtLeast "5.19" module; + # Shadow stacks + X86_USER_SHADOW_STACK = whenAtLeast "6.6" yes; + + # Enable support for Intel Trust Domain Extensions (TDX) + INTEL_TDX_GUEST = whenAtLeast "5.19" yes; + TDX_GUEST_DRIVER = whenAtLeast "6.2" module; + + # Mitigate straight line speculation at the cost of some file size + SLS = whenBetween "5.17" "6.9" yes; + MITIGATION_SLS = whenAtLeast "6.9" yes; + + DEFAULT_MMAP_MIN_ADDR = freeform "65536"; + } + // lib.optionalAttrs stdenv.hostPlatform.isAarch64 { + DEFAULT_MMAP_MIN_ADDR = freeform "32768"; + }; microcode = { - MICROCODE = yes; + MICROCODE = yes; MICROCODE_INTEL = whenOlder "6.6" yes; - MICROCODE_AMD = whenOlder "6.6" yes; + MICROCODE_AMD = whenOlder "6.6" yes; # Write Back Throttling # https://lwn.net/Articles/682582/ # https://bugzilla.kernel.org/show_bug.cgi?id=12309#c655 - BLK_WBT = yes; + BLK_WBT = yes; BLK_WBT_SQ = whenOlder "5.0" yes; # Removed in 5.0-RC1 BLK_WBT_MQ = yes; }; container = { - NAMESPACES = yes; # Required by 'unshare' used by 'nixos-install' + NAMESPACES = yes; # Required by 'unshare' used by 'nixos-install' RT_GROUP_SCHED = no; - CGROUP_DEVICE = yes; + CGROUP_DEVICE = yes; CGROUP_HUGETLB = yes; - CGROUP_PERF = yes; - CGROUP_RDMA = yes; + CGROUP_PERF = yes; + CGROUP_RDMA = yes; - MEMCG = yes; - MEMCG_SWAP = whenOlder "6.1" yes; + MEMCG = yes; + MEMCG_SWAP = whenOlder "6.1" yes; - BLK_DEV_THROTTLING = yes; - CFQ_GROUP_IOSCHED = whenOlder "5.0" yes; # Removed in 5.0-RC1 - CGROUP_PIDS = yes; + BLK_DEV_THROTTLING = yes; + CFQ_GROUP_IOSCHED = whenOlder "5.0" yes; # Removed in 5.0-RC1 + CGROUP_PIDS = yes; }; staging = { @@ -824,45 +857,48 @@ let proc-events = { # PROC_EVENTS requires that the netlink connector is not built # as a module. This is required by libcgroup's cgrulesengd. - CONNECTOR = yes; + CONNECTOR = yes; PROC_EVENTS = yes; }; tracing = { - FTRACE = yes; - KPROBES = yes; - FUNCTION_TRACER = yes; - FTRACE_SYSCALLS = yes; - SCHED_TRACER = yes; - STACK_TRACER = yes; - UPROBE_EVENTS = option yes; - BPF_SYSCALL = yes; + FTRACE = yes; + KPROBES = yes; + FUNCTION_TRACER = yes; + FTRACE_SYSCALLS = yes; + SCHED_TRACER = yes; + STACK_TRACER = yes; + UPROBE_EVENTS = option yes; + BPF_SYSCALL = yes; BPF_UNPRIV_DEFAULT_OFF = whenBetween "5.10" "5.16" yes; - BPF_EVENTS = yes; - FUNCTION_PROFILER = yes; + BPF_EVENTS = yes; + FUNCTION_PROFILER = yes; RING_BUFFER_BENCHMARK = no; }; perf = { # enable AMD Zen branch sampling if available - PERF_EVENTS_AMD_BRS = whenAtLeast "5.19" (option yes); + PERF_EVENTS_AMD_BRS = whenAtLeast "5.19" (option yes); }; virtualisation = { PARAVIRT = option yes; HYPERVISOR_GUEST = yes; - PARAVIRT_SPINLOCKS = option yes; + PARAVIRT_SPINLOCKS = option yes; - KVM_ASYNC_PF = yes; + KVM_ASYNC_PF = yes; KVM_GENERIC_DIRTYLOG_READ_PROTECT = yes; - KVM_GUEST = yes; - KVM_MMIO = yes; - KVM_VFIO = yes; + KVM_GUEST = yes; + KVM_MMIO = yes; + KVM_VFIO = yes; KSM = yes; VIRT_DRIVERS = yes; # We need 64 GB (PAE) support for Xen guest support - HIGHMEM64G = { optional = true; tristate = lib.mkIf (!stdenv.hostPlatform.is64bit) "y";}; + HIGHMEM64G = { + optional = true; + tristate = lib.mkIf (!stdenv.hostPlatform.is64bit) "y"; + }; VFIO_PCI_VGA = lib.mkIf stdenv.hostPlatform.is64bit yes; @@ -874,22 +910,22 @@ let VBOXGUEST = option no; DRM_VBOXVIDEO = option no; - XEN = option yes; - XEN_DOM0 = option yes; - PCI_XEN = option yes; - HVC_XEN = option yes; - HVC_XEN_FRONTEND = option yes; - XEN_SYS_HYPERVISOR = option yes; - SWIOTLB_XEN = option yes; - XEN_BACKEND = option yes; - XEN_BALLOON = option yes; - XEN_BALLOON_MEMORY_HOTPLUG = option yes; - XEN_EFI = option yes; - XEN_HAVE_PVMMU = option yes; - XEN_MCE_LOG = option yes; - XEN_PVH = option yes; - XEN_PVHVM = option yes; - XEN_SAVE_RESTORE = option yes; + XEN = option yes; + XEN_DOM0 = option yes; + PCI_XEN = option yes; + HVC_XEN = option yes; + HVC_XEN_FRONTEND = option yes; + XEN_SYS_HYPERVISOR = option yes; + SWIOTLB_XEN = option yes; + XEN_BACKEND = option yes; + XEN_BALLOON = option yes; + XEN_BALLOON_MEMORY_HOTPLUG = option yes; + XEN_EFI = option yes; + XEN_HAVE_PVMMU = option yes; + XEN_MCE_LOG = option yes; + XEN_PVH = option yes; + XEN_PVHVM = option yes; + XEN_SAVE_RESTORE = option yes; # Enable device detection on virtio-mmio hypervisors VIRTIO_MMIO_CMDLINE_DEVICES = yes; @@ -897,454 +933,489 @@ let media = { MEDIA_DIGITAL_TV_SUPPORT = yes; - MEDIA_CAMERA_SUPPORT = yes; - MEDIA_CONTROLLER = yes; - MEDIA_PCI_SUPPORT = yes; - MEDIA_USB_SUPPORT = yes; - MEDIA_ANALOG_TV_SUPPORT = yes; - VIDEO_STK1160_COMMON = whenOlder "6.5" module; + MEDIA_CAMERA_SUPPORT = yes; + MEDIA_CONTROLLER = yes; + MEDIA_PCI_SUPPORT = yes; + MEDIA_USB_SUPPORT = yes; + MEDIA_ANALOG_TV_SUPPORT = yes; + VIDEO_STK1160_COMMON = whenOlder "6.5" module; }; "9p" = { # Enable the 9P cache to speed up NixOS VM tests. - "9P_FSCACHE" = option yes; + "9P_FSCACHE" = option yes; "9P_FS_POSIX_ACL" = option yes; }; huge-page = { - TRANSPARENT_HUGEPAGE = option yes; - TRANSPARENT_HUGEPAGE_ALWAYS = option no; + TRANSPARENT_HUGEPAGE = option yes; + TRANSPARENT_HUGEPAGE_ALWAYS = option no; TRANSPARENT_HUGEPAGE_MADVISE = option yes; }; zram = { - ZRAM = module; - ZRAM_WRITEBACK = option yes; - ZRAM_MULTI_COMP = whenAtLeast "6.2" yes; - ZRAM_BACKEND_842 = whenAtLeast "6.12" yes; - ZRAM_BACKEND_DEFLATE = whenAtLeast "6.12" yes; - ZRAM_BACKEND_LZ4 = whenAtLeast "6.12" yes; - ZRAM_BACKEND_LZ4HC = whenAtLeast "6.12" yes; - ZRAM_BACKEND_LZO = whenAtLeast "6.12" yes; - ZRAM_BACKEND_ZSTD = whenAtLeast "6.12" yes; - ZRAM_DEF_COMP_ZSTD = whenAtLeast "5.11" yes; - ZSWAP = option yes; + ZRAM = module; + ZRAM_WRITEBACK = option yes; + ZRAM_MULTI_COMP = whenAtLeast "6.2" yes; + ZRAM_BACKEND_842 = whenAtLeast "6.12" yes; + ZRAM_BACKEND_DEFLATE = whenAtLeast "6.12" yes; + ZRAM_BACKEND_LZ4 = whenAtLeast "6.12" yes; + ZRAM_BACKEND_LZ4HC = whenAtLeast "6.12" yes; + ZRAM_BACKEND_LZO = whenAtLeast "6.12" yes; + ZRAM_BACKEND_ZSTD = whenAtLeast "6.12" yes; + ZRAM_DEF_COMP_ZSTD = whenAtLeast "5.11" yes; + ZSWAP = option yes; ZSWAP_COMPRESSOR_DEFAULT_ZSTD = whenAtLeast "5.7" (lib.mkOptionDefault yes); - ZPOOL = yes; - ZSMALLOC = option yes; + ZPOOL = yes; + ZSMALLOC = option yes; }; brcmfmac = { # Enable PCIe and USB for the brcmfmac driver - BRCMFMAC_USB = option yes; + BRCMFMAC_USB = option yes; BRCMFMAC_PCIE = option yes; }; # Support x2APIC (which requires IRQ remapping) x2apic = lib.optionalAttrs (stdenv.hostPlatform.system == "x86_64-linux") { X86_X2APIC = yes; - IRQ_REMAP = yes; + IRQ_REMAP = yes; }; # Disable various self-test modules that have no use in a production system - tests = { - # This menu disables all/most of them on >= 4.16 - RUNTIME_TESTING_MENU = option no; - } // { - CRC32_SELFTEST = option no; - CRYPTO_TEST = option no; - EFI_TEST = option no; - GLOB_SELFTEST = option no; - LOCK_TORTURE_TEST = option no; - MTD_TESTS = option no; - NOTIFIER_ERROR_INJECTION = option no; - RCU_PERF_TEST = whenOlder "5.9" no; - RCU_SCALE_TEST = whenAtLeast "5.10" no; - TEST_ASYNC_DRIVER_PROBE = option no; - WW_MUTEX_SELFTEST = option no; - XZ_DEC_TEST = option no; - }; + tests = + { + # This menu disables all/most of them on >= 4.16 + RUNTIME_TESTING_MENU = option no; + } + // { + CRC32_SELFTEST = option no; + CRYPTO_TEST = option no; + EFI_TEST = option no; + GLOB_SELFTEST = option no; + LOCK_TORTURE_TEST = option no; + MTD_TESTS = option no; + NOTIFIER_ERROR_INJECTION = option no; + RCU_PERF_TEST = whenOlder "5.9" no; + RCU_SCALE_TEST = whenAtLeast "5.10" no; + TEST_ASYNC_DRIVER_PROBE = option no; + WW_MUTEX_SELFTEST = option no; + XZ_DEC_TEST = option no; + }; criu = { # Unconditionally enabled, because it is required for CRIU and # it provides the kcmp() system call that Mesa depends on. - CHECKPOINT_RESTORE = yes; + CHECKPOINT_RESTORE = yes; # Allows soft-dirty tracking on pages, used by CRIU. # See https://docs.kernel.org/admin-guide/mm/soft-dirty.html MEM_SOFT_DIRTY = lib.mkIf (!stdenv.hostPlatform.isx86_32) yes; }; - misc = let - # Use zstd for kernel compression if 64-bit and newer than 5.9, otherwise xz. - # i686 issues: https://github.com/NixOS/nixpkgs/pull/117961#issuecomment-812106375 - useZstd = stdenv.buildPlatform.is64bit && lib.versionAtLeast version "5.9"; - in { - # stdenv.hostPlatform.linux-kernel.target assumes uncompressed on RISC-V. - KERNEL_UNCOMPRESSED = lib.mkIf stdenv.hostPlatform.isRiscV yes; - KERNEL_XZ = lib.mkIf (!stdenv.hostPlatform.isRiscV && !useZstd) yes; - KERNEL_ZSTD = lib.mkIf (!stdenv.hostPlatform.isRiscV && useZstd) yes; - - HID_BATTERY_STRENGTH = yes; - # enabled by default in x86_64 but not arm64, so we do that here - HIDRAW = yes; - - # Enable loading HID fixups as eBPF from userspace - HID_BPF = whenAtLeast "6.3" yes; - - HID_ACRUX_FF = yes; - DRAGONRISE_FF = yes; - GREENASIA_FF = yes; - HOLTEK_FF = yes; - JOYSTICK_PSXPAD_SPI_FF = yes; - LOGIG940_FF = yes; - NINTENDO_FF = whenAtLeast "5.16" yes; - NVIDIA_SHIELD_FF = whenAtLeast "6.5" yes; - PLAYSTATION_FF = whenAtLeast "5.12" yes; - SONY_FF = yes; - SMARTJOYPLUS_FF = yes; - THRUSTMASTER_FF = yes; - ZEROPLUS_FF = yes; - - MODULE_COMPRESS = lib.mkMerge [ - (whenOlder "5.13" yes) - (whenAtLeast "6.12" yes) - ]; - MODULE_COMPRESS_ALL = whenAtLeast "6.12" yes; - MODULE_COMPRESS_XZ = yes; - - SYSVIPC = yes; # System-V IPC - - AIO = yes; # POSIX asynchronous I/O - - UNIX = yes; # Unix domain sockets. + misc = + let + # Use zstd for kernel compression if 64-bit and newer than 5.9, otherwise xz. + # i686 issues: https://github.com/NixOS/nixpkgs/pull/117961#issuecomment-812106375 + useZstd = stdenv.buildPlatform.is64bit && lib.versionAtLeast version "5.9"; + in + { + # stdenv.hostPlatform.linux-kernel.target assumes uncompressed on RISC-V. + KERNEL_UNCOMPRESSED = lib.mkIf stdenv.hostPlatform.isRiscV yes; + KERNEL_XZ = lib.mkIf (!stdenv.hostPlatform.isRiscV && !useZstd) yes; + KERNEL_ZSTD = lib.mkIf (!stdenv.hostPlatform.isRiscV && useZstd) yes; - MD = yes; # Device mapper (RAID, LVM, etc.) + HID_BATTERY_STRENGTH = yes; + # enabled by default in x86_64 but not arm64, so we do that here + HIDRAW = yes; - # Enable initrd support. - BLK_DEV_INITRD = yes; + # Enable loading HID fixups as eBPF from userspace + HID_BPF = whenAtLeast "6.3" yes; - # Allows debugging systems that get stuck during suspend/resume - PM_TRACE = yes; - PM_TRACE_RTC = yes; + HID_ACRUX_FF = yes; + DRAGONRISE_FF = yes; + GREENASIA_FF = yes; + HOLTEK_FF = yes; + JOYSTICK_PSXPAD_SPI_FF = yes; + LOGIG940_FF = yes; + NINTENDO_FF = whenAtLeast "5.16" yes; + NVIDIA_SHIELD_FF = whenAtLeast "6.5" yes; + PLAYSTATION_FF = whenAtLeast "5.12" yes; + SONY_FF = yes; + SMARTJOYPLUS_FF = yes; + THRUSTMASTER_FF = yes; + ZEROPLUS_FF = yes; - ACCESSIBILITY = yes; # Accessibility support - AUXDISPLAY = yes; # Auxiliary Display support - HIPPI = yes; - MTD_COMPLEX_MAPPINGS = yes; # needed for many devices + MODULE_COMPRESS = lib.mkMerge [ + (whenOlder "5.13" yes) + (whenAtLeast "6.12" yes) + ]; + MODULE_COMPRESS_ALL = whenAtLeast "6.12" yes; + MODULE_COMPRESS_XZ = yes; + + SYSVIPC = yes; # System-V IPC + + AIO = yes; # POSIX asynchronous I/O + + UNIX = yes; # Unix domain sockets. - SCSI_LOWLEVEL = yes; # enable lots of SCSI devices - SCSI_LOWLEVEL_PCMCIA = yes; - SCSI_SAS_ATA = yes; # added to enable detection of hard drive + MD = yes; # Device mapper (RAID, LVM, etc.) - SPI = yes; # needed for many devices - SPI_MASTER = yes; + # Enable initrd support. + BLK_DEV_INITRD = yes; + + # Allows debugging systems that get stuck during suspend/resume + PM_TRACE = yes; + PM_TRACE_RTC = yes; + + ACCESSIBILITY = yes; # Accessibility support + AUXDISPLAY = yes; # Auxiliary Display support + HIPPI = yes; + MTD_COMPLEX_MAPPINGS = yes; # needed for many devices + + SCSI_LOWLEVEL = yes; # enable lots of SCSI devices + SCSI_LOWLEVEL_PCMCIA = yes; + SCSI_SAS_ATA = yes; # added to enable detection of hard drive - "8139TOO_8129" = yes; - "8139TOO_PIO" = no; # PIO is slower + SPI = yes; # needed for many devices + SPI_MASTER = yes; - AIC79XX_DEBUG_ENABLE = no; - AIC7XXX_DEBUG_ENABLE = no; - AIC94XX_DEBUG = no; + "8139TOO_8129" = yes; + "8139TOO_PIO" = no; # PIO is slower - BLK_DEV_INTEGRITY = yes; - BLK_DEV_ZONED = yes; + AIC79XX_DEBUG_ENABLE = no; + AIC7XXX_DEBUG_ENABLE = no; + AIC94XX_DEBUG = no; + + BLK_DEV_INTEGRITY = yes; + BLK_DEV_ZONED = yes; + + BLK_SED_OPAL = yes; + + # Enable support for block layer inline encryption + BLK_INLINE_ENCRYPTION = whenAtLeast "5.8" yes; + # ...but fall back to CPU encryption if unavailable + BLK_INLINE_ENCRYPTION_FALLBACK = whenAtLeast "5.8" yes; + + BSD_PROCESS_ACCT_V3 = yes; + + SERIAL_DEV_BUS = yes; # enables support for serial devices + SERIAL_DEV_CTRL_TTYPORT = yes; # enables support for TTY serial devices + + BT_HCIBTUSB_MTK = yes; # MediaTek protocol support + + BT_HCIUART = module; # required for BT devices with serial port interface (QCA6390) + BT_HCIUART_BCM = option yes; # Broadcom Bluetooth support + BT_HCIUART_BCSP = option yes; # CSR BlueCore support + BT_HCIUART_H4 = option yes; # UART (H4) protocol support + BT_HCIUART_LL = option yes; # Texas Instruments BRF + BT_HCIUART_QCA = yes; # Qualcomm Atheros support + BT_HCIUART_SERDEV = yes; # required by BT_HCIUART_QCA + + BT_RFCOMM_TTY = option yes; # RFCOMM TTY support + BT_QCA = module; # enables QCA6390 bluetooth + + # Removed on 5.17 as it was unused + # upstream: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=0a4ee518185e902758191d968600399f3bc2be31 + CLEANCACHE = whenOlder "5.17" (option yes); + + FSCACHE_STATS = yes; - BLK_SED_OPAL = yes; + DVB_DYNAMIC_MINORS = option yes; # we use udev - # Enable support for block layer inline encryption - BLK_INLINE_ENCRYPTION = whenAtLeast "5.8" yes; - # ...but fall back to CPU encryption if unavailable - BLK_INLINE_ENCRYPTION_FALLBACK = whenAtLeast "5.8" yes; + EFI_STUB = yes; # EFI bootloader in the bzImage itself + EFI_GENERIC_STUB_INITRD_CMDLINE_LOADER = whenOlder "6.2" (whenAtLeast "5.8" yes); # initrd kernel parameter for EFI - BSD_PROCESS_ACCT_V3 = yes; + # Generic compression support for EFI payloads + # Add new platforms only after they have been verified to build and boot. + # This is unsupported on x86 due to a custom decompression mechanism. + EFI_ZBOOT = lib.mkIf stdenv.hostPlatform.isAarch64 (whenAtLeast "6.1" yes); - SERIAL_DEV_BUS = yes; # enables support for serial devices - SERIAL_DEV_CTRL_TTYPORT = yes; # enables support for TTY serial devices + CGROUPS = yes; # used by systemd + FHANDLE = yes; # used by systemd + SECCOMP = yes; # used by systemd >= 231 + SECCOMP_FILTER = yes; # ditto + POSIX_MQUEUE = yes; + FRONTSWAP = whenOlder "6.6" yes; + FUSION = yes; # Fusion MPT device support + IDE = whenOlder "5.14" no; # deprecated IDE support, removed in 5.14 + IDLE_PAGE_TRACKING = yes; - BT_HCIBTUSB_MTK = yes; # MediaTek protocol support + JOYSTICK_XPAD_FF = option yes; # X-Box gamepad rumble support + JOYSTICK_XPAD_LEDS = option yes; # LED Support for Xbox360 controller 'BigX' LED - BT_HCIUART = module; # required for BT devices with serial port interface (QCA6390) - BT_HCIUART_BCM = option yes; # Broadcom Bluetooth support - BT_HCIUART_BCSP = option yes; # CSR BlueCore support - BT_HCIUART_H4 = option yes; # UART (H4) protocol support - BT_HCIUART_LL = option yes; # Texas Instruments BRF - BT_HCIUART_QCA = yes; # Qualcomm Atheros support - BT_HCIUART_SERDEV = yes; # required by BT_HCIUART_QCA + KEYBOARD_APPLESPI = module; - BT_RFCOMM_TTY = option yes; # RFCOMM TTY support - BT_QCA = module; # enables QCA6390 bluetooth + KEXEC_FILE = option yes; + KEXEC_JUMP = option yes; - # Removed on 5.17 as it was unused - # upstream: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=0a4ee518185e902758191d968600399f3bc2be31 - CLEANCACHE = whenOlder "5.17" (option yes); + PARTITION_ADVANCED = yes; # Needed for LDM_PARTITION + # Windows Logical Disk Manager (Dynamic Disk) support + LDM_PARTITION = yes; + LOGIRUMBLEPAD2_FF = yes; # Logitech Rumblepad 2 force feedback + LOGO = no; # not needed + MEDIA_ATTACH = yes; + MEGARAID_NEWGEN = yes; - FSCACHE_STATS = yes; + MLX5_CORE_EN = option yes; - DVB_DYNAMIC_MINORS = option yes; # we use udev + NVME_MULTIPATH = yes; - EFI_STUB = yes; # EFI bootloader in the bzImage itself - EFI_GENERIC_STUB_INITRD_CMDLINE_LOADER = - whenOlder "6.2" (whenAtLeast "5.8" yes); # initrd kernel parameter for EFI + NVME_AUTH = lib.mkMerge [ + (whenBetween "6.0" "6.7" yes) + (whenAtLeast "6.7" module) + ]; - # Generic compression support for EFI payloads - # Add new platforms only after they have been verified to build and boot. - # This is unsupported on x86 due to a custom decompression mechanism. - EFI_ZBOOT = lib.mkIf stdenv.hostPlatform.isAarch64 (whenAtLeast "6.1" yes); + NVME_HOST_AUTH = whenAtLeast "6.7" yes; + NVME_TCP_TLS = whenAtLeast "6.7" yes; - CGROUPS = yes; # used by systemd - FHANDLE = yes; # used by systemd - SECCOMP = yes; # used by systemd >= 231 - SECCOMP_FILTER = yes; # ditto - POSIX_MQUEUE = yes; - FRONTSWAP = whenOlder "6.6" yes; - FUSION = yes; # Fusion MPT device support - IDE = whenOlder "5.14" no; # deprecated IDE support, removed in 5.14 - IDLE_PAGE_TRACKING = yes; + NVME_TARGET = module; + NVME_TARGET_PASSTHRU = whenAtLeast "5.9" yes; + NVME_TARGET_AUTH = whenAtLeast "6.0" yes; + NVME_TARGET_TCP_TLS = whenAtLeast "6.7" yes; - JOYSTICK_XPAD_FF = option yes; # X-Box gamepad rumble support - JOYSTICK_XPAD_LEDS = option yes; # LED Support for Xbox360 controller 'BigX' LED + PCI_P2PDMA = lib.mkIf (stdenv.hostPlatform.is64bit) yes; - KEYBOARD_APPLESPI = module; - - KEXEC_FILE = option yes; - KEXEC_JUMP = option yes; - - PARTITION_ADVANCED = yes; # Needed for LDM_PARTITION - # Windows Logical Disk Manager (Dynamic Disk) support - LDM_PARTITION = yes; - LOGIRUMBLEPAD2_FF = yes; # Logitech Rumblepad 2 force feedback - LOGO = no; # not needed - MEDIA_ATTACH = yes; - MEGARAID_NEWGEN = yes; - - MLX5_CORE_EN = option yes; - - NVME_MULTIPATH = yes; - - NVME_AUTH = lib.mkMerge [ - (whenBetween "6.0" "6.7" yes) - (whenAtLeast "6.7" module) - ]; - - NVME_HOST_AUTH = whenAtLeast "6.7" yes; - NVME_TCP_TLS = whenAtLeast "6.7" yes; - - NVME_TARGET = module; - NVME_TARGET_PASSTHRU = whenAtLeast "5.9" yes; - NVME_TARGET_AUTH = whenAtLeast "6.0" yes; - NVME_TARGET_TCP_TLS = whenAtLeast "6.7" yes; - - PCI_P2PDMA = lib.mkIf (stdenv.hostPlatform.is64bit) yes; - - PSI = yes; - - MOUSE_ELAN_I2C_SMBUS = yes; - MOUSE_PS2_ELANTECH = yes; # Elantech PS/2 protocol extension - MOUSE_PS2_VMMOUSE = yes; - MTRR_SANITIZER = yes; - NET_FC = yes; # Fibre Channel driver support - # Needed for touchpads to work on some AMD laptops - PINCTRL_AMD = whenAtLeast "5.19" yes; - # GPIO on Intel Bay Trail, for some Chromebook internal eMMC disks - PINCTRL_BAYTRAIL = yes; - # GPIO for Braswell and Cherryview devices - # Needs to be built-in to for integrated keyboards to function properly - PINCTRL_CHERRYVIEW = yes; - # 8 is default. Modern gpt tables on eMMC may go far beyond 8. - MMC_BLOCK_MINORS = freeform "32"; - - REGULATOR = yes; # Voltage and Current Regulator Support - RC_DEVICES = option yes; # Enable IR devices - RC_DECODERS = option yes; # Required for IR devices to work - - RT2800USB_RT53XX = yes; - RT2800USB_RT55XX = yes; - - SCHED_AUTOGROUP = yes; - CFS_BANDWIDTH = yes; - - SCSI_LOGGING = yes; # SCSI logging facility - SERIAL_8250 = yes; # 8250/16550 and compatible serial support - - SLAB_FREELIST_HARDENED = yes; - SLAB_FREELIST_RANDOM = yes; - - SLIP_COMPRESSED = yes; # CSLIP compressed headers - SLIP_SMART = yes; - - HWMON = yes; - THERMAL_HWMON = yes; # Hardware monitoring support - NVME_HWMON = whenAtLeast "5.5" yes; # NVMe drives temperature reporting - UEVENT_HELPER = no; - - USERFAULTFD = yes; - X86_CHECK_BIOS_CORRUPTION = yes; - X86_MCE = yes; - - RAS = yes; # Needed for EDAC support - - # Our initrd init uses shebang scripts, so can't be modular. - BINFMT_SCRIPT = yes; - # For systemd-binfmt - BINFMT_MISC = option yes; - - # Required for EDID overriding - FW_LOADER = yes; - # Disable the firmware helper fallback, udev doesn't implement it any more - FW_LOADER_USER_HELPER_FALLBACK = option no; - - FW_LOADER_COMPRESS = yes; - FW_LOADER_COMPRESS_ZSTD = whenAtLeast "5.19" yes; - - HOTPLUG_PCI_ACPI = yes; # PCI hotplug using ACPI - HOTPLUG_PCI_PCIE = yes; # PCI-Expresscard hotplug support - - # Enable AMD's ROCm GPU compute stack - HSA_AMD = lib.mkIf stdenv.hostPlatform.is64bit (yes); - ZONE_DEVICE = lib.mkIf stdenv.hostPlatform.is64bit (yes); - HMM_MIRROR = yes; - DRM_AMDGPU_USERPTR = yes; - - PREEMPT = no; - PREEMPT_VOLUNTARY = yes; - - X86_AMD_PLATFORM_DEVICE = yes; - X86_PLATFORM_DRIVERS_DELL = whenAtLeast "5.12" yes; - X86_PLATFORM_DRIVERS_HP = whenAtLeast "6.1" yes; - - LIRC = yes; - - SCHED_CORE = whenAtLeast "5.14" yes; - SCHED_CLASS_EXT = whenAtLeast "6.12" yes; - - LRU_GEN = whenAtLeast "6.1" yes; - LRU_GEN_ENABLED = whenAtLeast "6.1" yes; - - FSL_MC_UAPI_SUPPORT = lib.mkIf (stdenv.hostPlatform.system == "aarch64-linux") (whenAtLeast "5.12" yes); - - ASHMEM = { optional = true; tristate = whenBetween "5.0" "5.18" "y";}; - ANDROID = { optional = true; tristate = whenBetween "5.0" "5.19" "y";}; - ANDROID_BINDER_IPC = { optional = true; tristate = whenAtLeast "5.0" "y";}; - ANDROID_BINDERFS = { optional = true; tristate = whenAtLeast "5.0" "y";}; - ANDROID_BINDER_DEVICES = { optional = true; freeform = whenAtLeast "5.0" "binder,hwbinder,vndbinder";}; - - TASKSTATS = yes; - TASK_DELAY_ACCT = yes; - TASK_XACCT = yes; - TASK_IO_ACCOUNTING = yes; - - # Fresh toolchains frequently break -Werror build for minor issues. - WERROR = whenAtLeast "5.15" no; - - # > CONFIG_KUNIT should not be enabled in a production environment. Enabling KUnit disables Kernel Address-Space Layout Randomization (KASLR), and tests may affect the state of the kernel in ways not suitable for production. - # https://www.kernel.org/doc/html/latest/dev-tools/kunit/start.html - KUNIT = whenAtLeast "5.5" no; - - # Set system time from RTC on startup and resume - RTC_HCTOSYS = option yes; - - # Expose watchdog information in sysfs - WATCHDOG_SYSFS = yes; - - # Enable generic kernel watch queues - # See https://docs.kernel.org/core-api/watch_queue.html - WATCH_QUEUE = whenAtLeast "5.8" yes; - } // lib.optionalAttrs (stdenv.hostPlatform.system == "x86_64-linux" || stdenv.hostPlatform.system == "aarch64-linux") { - # Enable CPU/memory hotplug support - # Allows you to dynamically add & remove CPUs/memory to a VM client running NixOS without requiring a reboot - ACPI_HOTPLUG_CPU = yes; - ACPI_HOTPLUG_MEMORY = yes; - MEMORY_HOTPLUG = yes; - MEMORY_HOTREMOVE = yes; - HOTPLUG_CPU = yes; - MIGRATION = yes; - SPARSEMEM = yes; - - # Bump the maximum number of CPUs to support systems like EC2 x1.* - # instances and Xeon Phi. - NR_CPUS = freeform "384"; - - # Enable LEDS to display link-state status of PHY devices (i.e. eth lan/wan interfaces) - LED_TRIGGER_PHY = yes; - } // lib.optionalAttrs (stdenv.hostPlatform.system == "armv7l-linux" || stdenv.hostPlatform.system == "aarch64-linux") { - # Enables support for the Allwinner Display Engine 2.0 - SUN8I_DE2_CCU = yes; - - # See comments on https://github.com/NixOS/nixpkgs/commit/9b67ea9106102d882f53d62890468071900b9647 - CRYPTO_AEGIS128_SIMD = no; - - # Distros should configure the default as a kernel option. - # We previously defined it on the kernel command line as cma= - # The kernel command line will override a platform-specific configuration from its device tree. - # https://github.com/torvalds/linux/blob/856deb866d16e29bd65952e0289066f6078af773/kernel/dma/contiguous.c#L35-L44 - CMA_SIZE_MBYTES = freeform "32"; - - # Add debug interfaces for CMA - CMA_DEBUGFS = yes; - CMA_SYSFS = yes; - - # https://docs.kernel.org/arch/arm/mem_alignment.html - # tldr: - # when buggy userspace code emits illegal misaligned LDM, STM, - # LDRD and STRDs, the instructions trap, are caught, and then - # are emulated by the kernel. - # - # This is the default on armv7l, anyway, but it is explicitly - # enabled here for the sake of providing context for the - # aarch64 compat option which follows. - ALIGNMENT_TRAP = lib.mkIf (stdenv.hostPlatform.system == "armv7l-linux") yes; - - # https://patchwork.kernel.org/project/linux-arm-kernel/patch/20220701135322.3025321-1-ardb@kernel.org/ - # tldr: - # when encountering alignment faults under aarch64, this option - # makes the kernel attempt to handle the fault by doing the - # same style of misaligned emulation that is performed under - # armv7l (see above option). - # - # This minimizes the potential for aarch32 userspace to behave - # differently when run under aarch64 kernels compared to when - # it is run under an aarch32 kernel. - COMPAT_ALIGNMENT_FIXUPS = lib.mkIf (stdenv.hostPlatform.system == "aarch64-linux") (whenAtLeast "6.1" yes); - - # requirement for CP15_BARRIER_EMULATION - ARMV8_DEPRECATED = lib.mkIf (stdenv.hostPlatform.system == "aarch64-linux") yes; - # emulate a specific armv7 instruction that was removed from armv8 - # this instruction is required to build a native armv7 nodejs on an - # aarch64-linux builder, for example - CP15_BARRIER_EMULATION = lib.mkIf (stdenv.hostPlatform.system == "aarch64-linux") yes; - } // lib.optionalAttrs (stdenv.hostPlatform.system == "x86_64-linux" || stdenv.hostPlatform.system == "aarch64-linux") { - # Required for various hardware features on Chrome OS devices - CHROME_PLATFORMS = yes; - CHROMEOS_TBMC = module; - - CROS_EC = module; - - CROS_EC_I2C = module; - CROS_EC_SPI = module; - CROS_EC_LPC = module; - CROS_EC_ISHTP = module; - - CROS_KBD_LED_BACKLIGHT = module; - - TCG_TIS_SPI_CR50 = whenAtLeast "5.5" yes; - } // lib.optionalAttrs (stdenv.hostPlatform.system == "x86_64-linux") { - CHROMEOS_LAPTOP = module; - CHROMEOS_PSTORE = module; - - # Enable x86 resource control - X86_CPU_RESCTRL = whenAtLeast "5.0" yes; - - # Enable TSX on CPUs where it's not vulnerable - X86_INTEL_TSX_MODE_AUTO = yes; - - # Enable AMD Wi-Fi RF band mitigations - # See https://cateee.net/lkddb/web-lkddb/AMD_WBRF.html - AMD_WBRF = whenAtLeast "6.8" yes; - - # Enable Intel Turbo Boost Max 3.0 - INTEL_TURBO_MAX_3 = yes; - }; + PSI = yes; + + MOUSE_ELAN_I2C_SMBUS = yes; + MOUSE_PS2_ELANTECH = yes; # Elantech PS/2 protocol extension + MOUSE_PS2_VMMOUSE = yes; + MTRR_SANITIZER = yes; + NET_FC = yes; # Fibre Channel driver support + # Needed for touchpads to work on some AMD laptops + PINCTRL_AMD = whenAtLeast "5.19" yes; + # GPIO on Intel Bay Trail, for some Chromebook internal eMMC disks + PINCTRL_BAYTRAIL = yes; + # GPIO for Braswell and Cherryview devices + # Needs to be built-in to for integrated keyboards to function properly + PINCTRL_CHERRYVIEW = yes; + # 8 is default. Modern gpt tables on eMMC may go far beyond 8. + MMC_BLOCK_MINORS = freeform "32"; + + REGULATOR = yes; # Voltage and Current Regulator Support + RC_DEVICES = option yes; # Enable IR devices + RC_DECODERS = option yes; # Required for IR devices to work + + RT2800USB_RT53XX = yes; + RT2800USB_RT55XX = yes; + + SCHED_AUTOGROUP = yes; + CFS_BANDWIDTH = yes; + + SCSI_LOGGING = yes; # SCSI logging facility + SERIAL_8250 = yes; # 8250/16550 and compatible serial support + + SLAB_FREELIST_HARDENED = yes; + SLAB_FREELIST_RANDOM = yes; + + SLIP_COMPRESSED = yes; # CSLIP compressed headers + SLIP_SMART = yes; + + HWMON = yes; + THERMAL_HWMON = yes; # Hardware monitoring support + NVME_HWMON = whenAtLeast "5.5" yes; # NVMe drives temperature reporting + UEVENT_HELPER = no; + + USERFAULTFD = yes; + X86_CHECK_BIOS_CORRUPTION = yes; + X86_MCE = yes; + + RAS = yes; # Needed for EDAC support + + # Our initrd init uses shebang scripts, so can't be modular. + BINFMT_SCRIPT = yes; + # For systemd-binfmt + BINFMT_MISC = option yes; + + # Required for EDID overriding + FW_LOADER = yes; + # Disable the firmware helper fallback, udev doesn't implement it any more + FW_LOADER_USER_HELPER_FALLBACK = option no; + + FW_LOADER_COMPRESS = yes; + FW_LOADER_COMPRESS_ZSTD = whenAtLeast "5.19" yes; + + HOTPLUG_PCI_ACPI = yes; # PCI hotplug using ACPI + HOTPLUG_PCI_PCIE = yes; # PCI-Expresscard hotplug support + + # Enable AMD's ROCm GPU compute stack + HSA_AMD = lib.mkIf stdenv.hostPlatform.is64bit (yes); + ZONE_DEVICE = lib.mkIf stdenv.hostPlatform.is64bit (yes); + HMM_MIRROR = yes; + DRM_AMDGPU_USERPTR = yes; + + PREEMPT = no; + PREEMPT_VOLUNTARY = yes; + + X86_AMD_PLATFORM_DEVICE = yes; + X86_PLATFORM_DRIVERS_DELL = whenAtLeast "5.12" yes; + X86_PLATFORM_DRIVERS_HP = whenAtLeast "6.1" yes; + + LIRC = yes; + + SCHED_CORE = whenAtLeast "5.14" yes; + SCHED_CLASS_EXT = whenAtLeast "6.12" yes; + + LRU_GEN = whenAtLeast "6.1" yes; + LRU_GEN_ENABLED = whenAtLeast "6.1" yes; + + FSL_MC_UAPI_SUPPORT = lib.mkIf (stdenv.hostPlatform.system == "aarch64-linux") ( + whenAtLeast "5.12" yes + ); + + ASHMEM = { + optional = true; + tristate = whenBetween "5.0" "5.18" "y"; + }; + ANDROID = { + optional = true; + tristate = whenBetween "5.0" "5.19" "y"; + }; + ANDROID_BINDER_IPC = { + optional = true; + tristate = whenAtLeast "5.0" "y"; + }; + ANDROID_BINDERFS = { + optional = true; + tristate = whenAtLeast "5.0" "y"; + }; + ANDROID_BINDER_DEVICES = { + optional = true; + freeform = whenAtLeast "5.0" "binder,hwbinder,vndbinder"; + }; + + TASKSTATS = yes; + TASK_DELAY_ACCT = yes; + TASK_XACCT = yes; + TASK_IO_ACCOUNTING = yes; + + # Fresh toolchains frequently break -Werror build for minor issues. + WERROR = whenAtLeast "5.15" no; + + # > CONFIG_KUNIT should not be enabled in a production environment. Enabling KUnit disables Kernel Address-Space Layout Randomization (KASLR), and tests may affect the state of the kernel in ways not suitable for production. + # https://www.kernel.org/doc/html/latest/dev-tools/kunit/start.html + KUNIT = whenAtLeast "5.5" no; + + # Set system time from RTC on startup and resume + RTC_HCTOSYS = option yes; + + # Expose watchdog information in sysfs + WATCHDOG_SYSFS = yes; + + # Enable generic kernel watch queues + # See https://docs.kernel.org/core-api/watch_queue.html + WATCH_QUEUE = whenAtLeast "5.8" yes; + } + // + lib.optionalAttrs + (stdenv.hostPlatform.system == "x86_64-linux" || stdenv.hostPlatform.system == "aarch64-linux") + { + # Enable CPU/memory hotplug support + # Allows you to dynamically add & remove CPUs/memory to a VM client running NixOS without requiring a reboot + ACPI_HOTPLUG_CPU = yes; + ACPI_HOTPLUG_MEMORY = yes; + MEMORY_HOTPLUG = yes; + MEMORY_HOTREMOVE = yes; + HOTPLUG_CPU = yes; + MIGRATION = yes; + SPARSEMEM = yes; + + # Bump the maximum number of CPUs to support systems like EC2 x1.* + # instances and Xeon Phi. + NR_CPUS = freeform "384"; + + # Enable LEDS to display link-state status of PHY devices (i.e. eth lan/wan interfaces) + LED_TRIGGER_PHY = yes; + } + // + lib.optionalAttrs + (stdenv.hostPlatform.system == "armv7l-linux" || stdenv.hostPlatform.system == "aarch64-linux") + { + # Enables support for the Allwinner Display Engine 2.0 + SUN8I_DE2_CCU = yes; + + # See comments on https://github.com/NixOS/nixpkgs/commit/9b67ea9106102d882f53d62890468071900b9647 + CRYPTO_AEGIS128_SIMD = no; + + # Distros should configure the default as a kernel option. + # We previously defined it on the kernel command line as cma= + # The kernel command line will override a platform-specific configuration from its device tree. + # https://github.com/torvalds/linux/blob/856deb866d16e29bd65952e0289066f6078af773/kernel/dma/contiguous.c#L35-L44 + CMA_SIZE_MBYTES = freeform "32"; + + # Add debug interfaces for CMA + CMA_DEBUGFS = yes; + CMA_SYSFS = yes; + + # https://docs.kernel.org/arch/arm/mem_alignment.html + # tldr: + # when buggy userspace code emits illegal misaligned LDM, STM, + # LDRD and STRDs, the instructions trap, are caught, and then + # are emulated by the kernel. + # + # This is the default on armv7l, anyway, but it is explicitly + # enabled here for the sake of providing context for the + # aarch64 compat option which follows. + ALIGNMENT_TRAP = lib.mkIf (stdenv.hostPlatform.system == "armv7l-linux") yes; + + # https://patchwork.kernel.org/project/linux-arm-kernel/patch/20220701135322.3025321-1-ardb@kernel.org/ + # tldr: + # when encountering alignment faults under aarch64, this option + # makes the kernel attempt to handle the fault by doing the + # same style of misaligned emulation that is performed under + # armv7l (see above option). + # + # This minimizes the potential for aarch32 userspace to behave + # differently when run under aarch64 kernels compared to when + # it is run under an aarch32 kernel. + COMPAT_ALIGNMENT_FIXUPS = lib.mkIf (stdenv.hostPlatform.system == "aarch64-linux") ( + whenAtLeast "6.1" yes + ); + + # requirement for CP15_BARRIER_EMULATION + ARMV8_DEPRECATED = lib.mkIf (stdenv.hostPlatform.system == "aarch64-linux") yes; + # emulate a specific armv7 instruction that was removed from armv8 + # this instruction is required to build a native armv7 nodejs on an + # aarch64-linux builder, for example + CP15_BARRIER_EMULATION = lib.mkIf (stdenv.hostPlatform.system == "aarch64-linux") yes; + } + // + lib.optionalAttrs + (stdenv.hostPlatform.system == "x86_64-linux" || stdenv.hostPlatform.system == "aarch64-linux") + { + # Required for various hardware features on Chrome OS devices + CHROME_PLATFORMS = yes; + CHROMEOS_TBMC = module; + + CROS_EC = module; + + CROS_EC_I2C = module; + CROS_EC_SPI = module; + CROS_EC_LPC = module; + CROS_EC_ISHTP = module; + + CROS_KBD_LED_BACKLIGHT = module; + + TCG_TIS_SPI_CR50 = whenAtLeast "5.5" yes; + } + // lib.optionalAttrs (stdenv.hostPlatform.system == "x86_64-linux") { + CHROMEOS_LAPTOP = module; + CHROMEOS_PSTORE = module; + + # Enable x86 resource control + X86_CPU_RESCTRL = whenAtLeast "5.0" yes; + + # Enable TSX on CPUs where it's not vulnerable + X86_INTEL_TSX_MODE_AUTO = yes; + + # Enable AMD Wi-Fi RF band mitigations + # See https://cateee.net/lkddb/web-lkddb/AMD_WBRF.html + AMD_WBRF = whenAtLeast "6.8" yes; + + # Enable Intel Turbo Boost Max 3.0 + INTEL_TURBO_MAX_3 = yes; + }; accel = { # Build DRM accelerator devices @@ -1352,4 +1423,4 @@ let }; }; in - flattenKConf options +flattenKConf options diff --git a/pkgs/os-specific/linux/kernel/gpio-utils.nix b/pkgs/os-specific/linux/kernel/gpio-utils.nix index 88b8efbe540c2c..75bdf6434e6a61 100644 --- a/pkgs/os-specific/linux/kernel/gpio-utils.nix +++ b/pkgs/os-specific/linux/kernel/gpio-utils.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, linux }: +{ + lib, + stdenv, + linux, +}: stdenv.mkDerivation { pname = "gpio-utils"; @@ -11,7 +15,11 @@ stdenv.mkDerivation { ''; separateDebugInfo = true; - installFlags = [ "install" "DESTDIR=$(out)" "bindir=/bin" ]; + installFlags = [ + "install" + "DESTDIR=$(out)" + "bindir=/bin" + ]; meta = with lib; { description = "Linux tools to inspect the gpiochip interface"; diff --git a/pkgs/os-specific/linux/kernel/hardened/config.nix b/pkgs/os-specific/linux/kernel/hardened/config.nix index f655f85f490e27..b3c1d8e45bea44 100644 --- a/pkgs/os-specific/linux/kernel/hardened/config.nix +++ b/pkgs/os-specific/linux/kernel/hardened/config.nix @@ -8,7 +8,11 @@ # # See also -{ stdenv, lib, version }: +{ + stdenv, + lib, + version, +}: with lib.kernel; with (lib.kernel.whenHelpers version); @@ -25,15 +29,15 @@ assert (lib.versionAtLeast version "4.9"); # We set SECURITY_WRITABLE_HOOKS n primarily for documentation purposes; the # config builder fails to detect that it has indeed been unset. SECURITY_SELINUX_DISABLE = whenOlder "6.4" no; # On 6.4: error: unused option: SECURITY_SELINUX_DISABLE - SECURITY_WRITABLE_HOOKS = option no; + SECURITY_WRITABLE_HOOKS = option no; # Perform additional validation of commonly targeted structures. - DEBUG_CREDENTIALS = whenOlder "6.6" yes; - DEBUG_NOTIFIERS = yes; - DEBUG_PI_LIST = whenOlder "5.2" yes; # doesn't BUG() - DEBUG_PLIST = whenAtLeast "5.2" yes; - DEBUG_SG = yes; - DEBUG_VIRTUAL = yes; + DEBUG_CREDENTIALS = whenOlder "6.6" yes; + DEBUG_NOTIFIERS = yes; + DEBUG_PI_LIST = whenOlder "5.2" yes; # doesn't BUG() + DEBUG_PLIST = whenAtLeast "5.2" yes; + DEBUG_SG = yes; + DEBUG_VIRTUAL = yes; SCHED_STACK_END_CHECK = yes; REFCOUNT_FULL = whenOlder "5.4.208" yes; @@ -47,10 +51,10 @@ assert (lib.versionAtLeast version "4.9"); # Wipe higher-level memory allocations on free() with page_poison=1 PAGE_POISONING_NO_SANITY = whenOlder "5.11" yes; - PAGE_POISONING_ZERO = whenOlder "5.11" yes; + PAGE_POISONING_ZERO = whenOlder "5.11" yes; # Enable init_on_free by default - INIT_ON_FREE_DEFAULT_ON = whenAtLeast "5.3" yes; + INIT_ON_FREE_DEFAULT_ON = whenAtLeast "5.3" yes; # Wipe all caller-used registers on exit from a function ZERO_CALL_USED_REGS = whenAtLeast "5.15" yes; @@ -74,7 +78,7 @@ assert (lib.versionAtLeast version "4.9"); # Runtime undefined behaviour checks # https://www.kernel.org/doc/html/latest/dev-tools/ubsan.html # https://developers.redhat.com/blog/2014/10/16/gcc-undefined-behavior-sanitizer-ubsan - UBSAN = yes; + UBSAN = yes; UBSAN_TRAP = whenAtLeast "5.7" yes; UBSAN_BOUNDS = whenAtLeast "5.7" yes; UBSAN_SANITIZE_ALL = whenOlder "6.9" yes; @@ -87,23 +91,23 @@ assert (lib.versionAtLeast version "4.9"); # Disable various dangerous settings ACPI_CUSTOM_METHOD = whenOlder "6.9" no; # Allows writing directly to physical memory - PROC_KCORE = no; # Exposes kernel text image layout - INET_DIAG = no; # Has been used for heap based attacks in the past + PROC_KCORE = no; # Exposes kernel text image layout + INET_DIAG = no; # Has been used for heap based attacks in the past # INET_DIAG=n causes the following options to not exist anymore, but since they are defined in common-config.nix, # make them optional INET_DIAG_DESTROY = option no; - INET_RAW_DIAG = option no; - INET_TCP_DIAG = option no; - INET_UDP_DIAG = option no; - INET_MPTCP_DIAG = option no; + INET_RAW_DIAG = option no; + INET_TCP_DIAG = option no; + INET_UDP_DIAG = option no; + INET_MPTCP_DIAG = option no; # Use -fstack-protector-strong (gcc 4.9+) for best stack canary coverage. CC_STACKPROTECTOR_REGULAR = lib.mkForce (whenOlder "4.18" no); - CC_STACKPROTECTOR_STRONG = whenOlder "4.18" yes; + CC_STACKPROTECTOR_STRONG = whenOlder "4.18" yes; # CONFIG_DEVMEM=n causes these to not exist anymore. - STRICT_DEVMEM = option no; + STRICT_DEVMEM = option no; IO_STRICT_DEVMEM = option no; # stricter IOMMU TLB invalidation diff --git a/pkgs/os-specific/linux/kernel/htmldocs.nix b/pkgs/os-specific/linux/kernel/htmldocs.nix index b811cf12bb01df..f6c02fc5ea7efe 100644 --- a/pkgs/os-specific/linux/kernel/htmldocs.nix +++ b/pkgs/os-specific/linux/kernel/htmldocs.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, graphviz -, imagemagick -, linux_latest -, makeFontsConf -, perl -, python3 -, which +{ + lib, + stdenv, + graphviz, + imagemagick, + linux_latest, + makeFontsConf, + perl, + python3, + which, }: stdenv.mkDerivation { diff --git a/pkgs/os-specific/linux/kernel/linux-libre.nix b/pkgs/os-specific/linux/kernel/linux-libre.nix index e8df0375b03885..ca67dc436b55bc 100644 --- a/pkgs/os-specific/linux/kernel/linux-libre.nix +++ b/pkgs/os-specific/linux/kernel/linux-libre.nix @@ -1,11 +1,15 @@ -{ stdenv, lib, fetchsvn, linux -, scripts ? fetchsvn { +{ + stdenv, + lib, + fetchsvn, + linux, + scripts ? fetchsvn { url = "https://www.fsfla.org/svn/fsfla/software/linux-libre/releases/branches/"; rev = "19675"; sha256 = "sha256-vlWY3e9uf+a+I003CjFFw9e3suY059KlIqDf86LGmHM="; - } -, ... -} @ args: + }, + ... +}@args: let majorMinor = lib.versions.majorMinor linux.modDirVersion; @@ -15,11 +19,9 @@ let patch = lib.versions.patch linux.modDirVersion; # See http://linux-libre.fsfla.org/pub/linux-libre/releases - versionPrefix = if linux.kernelOlder "5.14" then - "gnu1" - else - "gnu"; -in linux.override { + versionPrefix = if linux.kernelOlder "5.14" then "gnu1" else "gnu"; +in +linux.override { argsOverride = { modDirVersion = "${linux.modDirVersion}-${versionPrefix}"; isLibre = true; @@ -45,4 +47,5 @@ in linux.override { maintainers = with lib.maintainers; [ qyliss ]; }; -} // (args.argsOverride or { }) +} +// (args.argsOverride or { }) diff --git a/pkgs/os-specific/linux/kernel/linux-rpi.nix b/pkgs/os-specific/linux/kernel/linux-rpi.nix index 4c701e5556a99e..247da436949c95 100644 --- a/pkgs/os-specific/linux/kernel/linux-rpi.nix +++ b/pkgs/os-specific/linux/kernel/linux-rpi.nix @@ -1,74 +1,106 @@ -{ stdenv, lib, buildPackages, fetchFromGitHub, fetchpatch, perl, buildLinux, rpiVersion, ... } @ args: +{ + stdenv, + lib, + buildPackages, + fetchFromGitHub, + fetchpatch, + perl, + buildLinux, + rpiVersion, + ... +}@args: let # NOTE: raspberrypifw & raspberryPiWirelessFirmware should be updated with this modDirVersion = "6.6.51"; tag = "stable_20241008"; in -lib.overrideDerivation (buildLinux (args // { - version = "${modDirVersion}-${tag}"; - inherit modDirVersion; - pname = "linux-rpi"; +lib.overrideDerivation + (buildLinux ( + args + // { + version = "${modDirVersion}-${tag}"; + inherit modDirVersion; + pname = "linux-rpi"; - src = fetchFromGitHub { - owner = "raspberrypi"; - repo = "linux"; - rev = tag; - hash = "sha256-phCxkuO+jUGZkfzSrBq6yErQeO2Td+inIGHxctXbD5U="; - }; + src = fetchFromGitHub { + owner = "raspberrypi"; + repo = "linux"; + rev = tag; + hash = "sha256-phCxkuO+jUGZkfzSrBq6yErQeO2Td+inIGHxctXbD5U="; + }; - defconfig = { - "1" = "bcmrpi_defconfig"; - "2" = "bcm2709_defconfig"; - "3" = if stdenv.hostPlatform.isAarch64 then "bcmrpi3_defconfig" else "bcm2709_defconfig"; - "4" = "bcm2711_defconfig"; - }.${toString rpiVersion}; + defconfig = + { + "1" = "bcmrpi_defconfig"; + "2" = "bcm2709_defconfig"; + "3" = if stdenv.hostPlatform.isAarch64 then "bcmrpi3_defconfig" else "bcm2709_defconfig"; + "4" = "bcm2711_defconfig"; + } + .${toString rpiVersion}; - features = { - efiBootStub = false; - } // (args.features or {}); + features = { + efiBootStub = false; + } // (args.features or { }); - extraMeta = if (rpiVersion < 3) then { - platforms = with lib.platforms; arm; - hydraPlatforms = []; - } else { - platforms = with lib.platforms; arm ++ aarch64; - hydraPlatforms = [ "aarch64-linux" ]; - }; -} // (args.argsOverride or {}))) (oldAttrs: { - postConfigure = '' - # The v7 defconfig has this set to '-v7' which screws up our modDirVersion. - sed -i $buildRoot/.config -e 's/^CONFIG_LOCALVERSION=.*/CONFIG_LOCALVERSION=""/' - sed -i $buildRoot/include/config/auto.conf -e 's/^CONFIG_LOCALVERSION=.*/CONFIG_LOCALVERSION=""/' - ''; - - # Make copies of the DTBs named after the upstream names so that U-Boot finds them. - # This is ugly as heck, but I don't know a better solution so far. - postFixup = '' - dtbDir=${if stdenv.hostPlatform.isAarch64 then "$out/dtbs/broadcom" else "$out/dtbs"} - rm $dtbDir/bcm283*.dtb - copyDTB() { - cp -v "$dtbDir/$1" "$dtbDir/$2" + extraMeta = + if (rpiVersion < 3) then + { + platforms = with lib.platforms; arm; + hydraPlatforms = [ ]; + } + else + { + platforms = with lib.platforms; arm ++ aarch64; + hydraPlatforms = [ "aarch64-linux" ]; + }; } - '' + lib.optionalString (lib.elem stdenv.hostPlatform.system ["armv6l-linux"]) '' - copyDTB bcm2708-rpi-zero-w.dtb bcm2835-rpi-zero.dtb - copyDTB bcm2708-rpi-zero-w.dtb bcm2835-rpi-zero-w.dtb - copyDTB bcm2708-rpi-b.dtb bcm2835-rpi-a.dtb - copyDTB bcm2708-rpi-b.dtb bcm2835-rpi-b.dtb - copyDTB bcm2708-rpi-b.dtb bcm2835-rpi-b-rev2.dtb - copyDTB bcm2708-rpi-b-plus.dtb bcm2835-rpi-a-plus.dtb - copyDTB bcm2708-rpi-b-plus.dtb bcm2835-rpi-b-plus.dtb - copyDTB bcm2708-rpi-b-plus.dtb bcm2835-rpi-zero.dtb - copyDTB bcm2708-rpi-cm.dtb bcm2835-rpi-cm.dtb - '' + lib.optionalString (lib.elem stdenv.hostPlatform.system ["armv7l-linux"]) '' - copyDTB bcm2709-rpi-2-b.dtb bcm2836-rpi-2-b.dtb - '' + lib.optionalString (lib.elem stdenv.hostPlatform.system ["armv7l-linux" "aarch64-linux"]) '' - copyDTB bcm2710-rpi-zero-2.dtb bcm2837-rpi-zero-2.dtb - copyDTB bcm2710-rpi-zero-2-w.dtb bcm2837-rpi-zero-2-w.dtb - copyDTB bcm2710-rpi-3-b.dtb bcm2837-rpi-3-b.dtb - copyDTB bcm2710-rpi-3-b-plus.dtb bcm2837-rpi-3-a-plus.dtb - copyDTB bcm2710-rpi-3-b-plus.dtb bcm2837-rpi-3-b-plus.dtb - copyDTB bcm2710-rpi-cm3.dtb bcm2837-rpi-cm3.dtb - copyDTB bcm2711-rpi-4-b.dtb bcm2838-rpi-4-b.dtb - ''; -}) + // (args.argsOverride or { }) + )) + (oldAttrs: { + postConfigure = '' + # The v7 defconfig has this set to '-v7' which screws up our modDirVersion. + sed -i $buildRoot/.config -e 's/^CONFIG_LOCALVERSION=.*/CONFIG_LOCALVERSION=""/' + sed -i $buildRoot/include/config/auto.conf -e 's/^CONFIG_LOCALVERSION=.*/CONFIG_LOCALVERSION=""/' + ''; + + # Make copies of the DTBs named after the upstream names so that U-Boot finds them. + # This is ugly as heck, but I don't know a better solution so far. + postFixup = + '' + dtbDir=${if stdenv.hostPlatform.isAarch64 then "$out/dtbs/broadcom" else "$out/dtbs"} + rm $dtbDir/bcm283*.dtb + copyDTB() { + cp -v "$dtbDir/$1" "$dtbDir/$2" + } + '' + + lib.optionalString (lib.elem stdenv.hostPlatform.system [ "armv6l-linux" ]) '' + copyDTB bcm2708-rpi-zero-w.dtb bcm2835-rpi-zero.dtb + copyDTB bcm2708-rpi-zero-w.dtb bcm2835-rpi-zero-w.dtb + copyDTB bcm2708-rpi-b.dtb bcm2835-rpi-a.dtb + copyDTB bcm2708-rpi-b.dtb bcm2835-rpi-b.dtb + copyDTB bcm2708-rpi-b.dtb bcm2835-rpi-b-rev2.dtb + copyDTB bcm2708-rpi-b-plus.dtb bcm2835-rpi-a-plus.dtb + copyDTB bcm2708-rpi-b-plus.dtb bcm2835-rpi-b-plus.dtb + copyDTB bcm2708-rpi-b-plus.dtb bcm2835-rpi-zero.dtb + copyDTB bcm2708-rpi-cm.dtb bcm2835-rpi-cm.dtb + '' + + lib.optionalString (lib.elem stdenv.hostPlatform.system [ "armv7l-linux" ]) '' + copyDTB bcm2709-rpi-2-b.dtb bcm2836-rpi-2-b.dtb + '' + + + lib.optionalString + (lib.elem stdenv.hostPlatform.system [ + "armv7l-linux" + "aarch64-linux" + ]) + '' + copyDTB bcm2710-rpi-zero-2.dtb bcm2837-rpi-zero-2.dtb + copyDTB bcm2710-rpi-zero-2-w.dtb bcm2837-rpi-zero-2-w.dtb + copyDTB bcm2710-rpi-3-b.dtb bcm2837-rpi-3-b.dtb + copyDTB bcm2710-rpi-3-b-plus.dtb bcm2837-rpi-3-a-plus.dtb + copyDTB bcm2710-rpi-3-b-plus.dtb bcm2837-rpi-3-b-plus.dtb + copyDTB bcm2710-rpi-cm3.dtb bcm2837-rpi-cm3.dtb + copyDTB bcm2711-rpi-4-b.dtb bcm2838-rpi-4-b.dtb + ''; + }) diff --git a/pkgs/os-specific/linux/kernel/linux-rt-5.10.nix b/pkgs/os-specific/linux/kernel/linux-rt-5.10.nix index be797faf8c10fc..b8d656b6c1433c 100644 --- a/pkgs/os-specific/linux/kernel/linux-rt-5.10.nix +++ b/pkgs/os-specific/linux/kernel/linux-rt-5.10.nix @@ -1,45 +1,61 @@ -{ lib, buildLinux, fetchurl -, kernelPatches ? [ ] -, structuredExtraConfig ? {} -, extraMeta ? {} -, argsOverride ? {} -, ... } @ args: +{ + lib, + buildLinux, + fetchurl, + kernelPatches ? [ ], + structuredExtraConfig ? { }, + extraMeta ? { }, + argsOverride ? { }, + ... +}@args: let version = "5.10.229-rt121"; # updated by ./update-rt.sh branch = lib.versions.majorMinor version; kversion = builtins.elemAt (lib.splitString "-" version) 0; -in buildLinux (args // { - inherit version; - pname = "linux-rt"; +in +buildLinux ( + args + // { + inherit version; + pname = "linux-rt"; - # modDirVersion needs a patch number, change X.Y-rtZ to X.Y.0-rtZ. - modDirVersion = lib.versions.pad 3 version; + # modDirVersion needs a patch number, change X.Y-rtZ to X.Y.0-rtZ. + modDirVersion = lib.versions.pad 3 version; - src = fetchurl { - url = "mirror://kernel/linux/kernel/v5.x/linux-${kversion}.tar.xz"; - sha256 = "1q6di05rk4bsy91r03zw6vz14zzcpvv25dv7gw0yz1gzpgkbb9h8"; - }; - - kernelPatches = let rt-patch = { - name = "rt"; - patch = fetchurl { - url = "mirror://kernel/linux/kernel/projects/rt/${branch}/older/patch-${version}.patch.xz"; - sha256 = "0bjmnk2nx50spyad2fq1l67jwp63yzxc7s39mx8sih6hm21d8y77"; + src = fetchurl { + url = "mirror://kernel/linux/kernel/v5.x/linux-${kversion}.tar.xz"; + sha256 = "1q6di05rk4bsy91r03zw6vz14zzcpvv25dv7gw0yz1gzpgkbb9h8"; }; - }; in [ rt-patch ] ++ kernelPatches; - structuredExtraConfig = with lib.kernel; { - PREEMPT_RT = yes; - # Fix error: unused option: PREEMPT_RT. - EXPERT = yes; # PREEMPT_RT depends on it (in kernel/Kconfig.preempt) - # Fix error: option not set correctly: PREEMPT_VOLUNTARY (wanted 'y', got 'n'). - PREEMPT_VOLUNTARY = lib.mkForce no; # PREEMPT_RT deselects it. - # Fix error: unused option: RT_GROUP_SCHED. - RT_GROUP_SCHED = lib.mkForce (option no); # Removed by sched-disable-rt-group-sched-on-rt.patch. - } // structuredExtraConfig; + kernelPatches = + let + rt-patch = { + name = "rt"; + patch = fetchurl { + url = "mirror://kernel/linux/kernel/projects/rt/${branch}/older/patch-${version}.patch.xz"; + sha256 = "0bjmnk2nx50spyad2fq1l67jwp63yzxc7s39mx8sih6hm21d8y77"; + }; + }; + in + [ rt-patch ] ++ kernelPatches; + + structuredExtraConfig = + with lib.kernel; + { + PREEMPT_RT = yes; + # Fix error: unused option: PREEMPT_RT. + EXPERT = yes; # PREEMPT_RT depends on it (in kernel/Kconfig.preempt) + # Fix error: option not set correctly: PREEMPT_VOLUNTARY (wanted 'y', got 'n'). + PREEMPT_VOLUNTARY = lib.mkForce no; # PREEMPT_RT deselects it. + # Fix error: unused option: RT_GROUP_SCHED. + RT_GROUP_SCHED = lib.mkForce (option no); # Removed by sched-disable-rt-group-sched-on-rt.patch. + } + // structuredExtraConfig; - extraMeta = extraMeta // { - inherit branch; - }; -} // argsOverride) + extraMeta = extraMeta // { + inherit branch; + }; + } + // argsOverride +) diff --git a/pkgs/os-specific/linux/kernel/linux-rt-5.15.nix b/pkgs/os-specific/linux/kernel/linux-rt-5.15.nix index bd48959b2b23cc..e6f1fc1a2378fd 100644 --- a/pkgs/os-specific/linux/kernel/linux-rt-5.15.nix +++ b/pkgs/os-specific/linux/kernel/linux-rt-5.15.nix @@ -1,46 +1,65 @@ -{ lib, buildLinux, fetchurl -, kernelPatches ? [ ] -, structuredExtraConfig ? {} -, extraMeta ? {} -, argsOverride ? {} -, ... } @ args: +{ + lib, + buildLinux, + fetchurl, + kernelPatches ? [ ], + structuredExtraConfig ? { }, + extraMeta ? { }, + argsOverride ? { }, + ... +}@args: let version = "5.15.170-rt81"; # updated by ./update-rt.sh branch = lib.versions.majorMinor version; kversion = builtins.elemAt (lib.splitString "-" version) 0; -in buildLinux (args // { - inherit version; - pname = "linux-rt"; +in +buildLinux ( + args + // { + inherit version; + pname = "linux-rt"; - # modDirVersion needs a patch number, change X.Y-rtZ to X.Y.0-rtZ. - modDirVersion = if (builtins.match "[^.]*[.][^.]*-.*" version) == null then version - else lib.replaceStrings ["-"] [".0-"] version; + # modDirVersion needs a patch number, change X.Y-rtZ to X.Y.0-rtZ. + modDirVersion = + if (builtins.match "[^.]*[.][^.]*-.*" version) == null then + version + else + lib.replaceStrings [ "-" ] [ ".0-" ] version; - src = fetchurl { - url = "mirror://kernel/linux/kernel/v5.x/linux-${kversion}.tar.xz"; - sha256 = "1ag7fvixhdcyxv6rqfsvq2wh02g64r4rx8izvfb33nfnld2nangx"; - }; - - kernelPatches = let rt-patch = { - name = "rt"; - patch = fetchurl { - url = "mirror://kernel/linux/kernel/projects/rt/${branch}/older/patch-${version}.patch.xz"; - sha256 = "0vr6c93dr0gcszx0hfnfhqbg5flkvxmkpf2hw13gi4rg8x4bx5ll"; + src = fetchurl { + url = "mirror://kernel/linux/kernel/v5.x/linux-${kversion}.tar.xz"; + sha256 = "1ag7fvixhdcyxv6rqfsvq2wh02g64r4rx8izvfb33nfnld2nangx"; }; - }; in [ rt-patch ] ++ kernelPatches; - structuredExtraConfig = with lib.kernel; { - PREEMPT_RT = yes; - # Fix error: unused option: PREEMPT_RT. - EXPERT = yes; # PREEMPT_RT depends on it (in kernel/Kconfig.preempt) - # Fix error: option not set correctly: PREEMPT_VOLUNTARY (wanted 'y', got 'n'). - PREEMPT_VOLUNTARY = lib.mkForce no; # PREEMPT_RT deselects it. - # Fix error: unused option: RT_GROUP_SCHED. - RT_GROUP_SCHED = lib.mkForce (option no); # Removed by sched-disable-rt-group-sched-on-rt.patch. - } // structuredExtraConfig; + kernelPatches = + let + rt-patch = { + name = "rt"; + patch = fetchurl { + url = "mirror://kernel/linux/kernel/projects/rt/${branch}/older/patch-${version}.patch.xz"; + sha256 = "0vr6c93dr0gcszx0hfnfhqbg5flkvxmkpf2hw13gi4rg8x4bx5ll"; + }; + }; + in + [ rt-patch ] ++ kernelPatches; + + structuredExtraConfig = + with lib.kernel; + { + PREEMPT_RT = yes; + # Fix error: unused option: PREEMPT_RT. + EXPERT = yes; # PREEMPT_RT depends on it (in kernel/Kconfig.preempt) + # Fix error: option not set correctly: PREEMPT_VOLUNTARY (wanted 'y', got 'n'). + PREEMPT_VOLUNTARY = lib.mkForce no; # PREEMPT_RT deselects it. + # Fix error: unused option: RT_GROUP_SCHED. + RT_GROUP_SCHED = lib.mkForce (option no); # Removed by sched-disable-rt-group-sched-on-rt.patch. + } + // structuredExtraConfig; - extraMeta = extraMeta // { - inherit branch; - }; -} // argsOverride) + extraMeta = extraMeta // { + inherit branch; + }; + } + // argsOverride +) diff --git a/pkgs/os-specific/linux/kernel/linux-rt-5.4.nix b/pkgs/os-specific/linux/kernel/linux-rt-5.4.nix index 4fa02ec8708054..69dc120a955e4e 100644 --- a/pkgs/os-specific/linux/kernel/linux-rt-5.4.nix +++ b/pkgs/os-specific/linux/kernel/linux-rt-5.4.nix @@ -1,42 +1,58 @@ -{ lib, buildLinux, fetchurl -, kernelPatches ? [ ] -, structuredExtraConfig ? {} -, extraMeta ? {} -, argsOverride ? {} -, ... } @ args: +{ + lib, + buildLinux, + fetchurl, + kernelPatches ? [ ], + structuredExtraConfig ? { }, + extraMeta ? { }, + argsOverride ? { }, + ... +}@args: let version = "5.4.285-rt93"; # updated by ./update-rt.sh branch = lib.versions.majorMinor version; kversion = builtins.elemAt (lib.splitString "-" version) 0; -in buildLinux (args // { - inherit version; - pname = "linux-rt"; +in +buildLinux ( + args + // { + inherit version; + pname = "linux-rt"; - src = fetchurl { - url = "mirror://kernel/linux/kernel/v5.x/linux-${kversion}.tar.xz"; - sha256 = "1722sc365ajxmqyr4r49yp73mzdckay3rx5c2gx29xzny9zc6cmy"; - }; - - kernelPatches = let rt-patch = { - name = "rt"; - patch = fetchurl { - url = "mirror://kernel/linux/kernel/projects/rt/${branch}/older/patch-${version}.patch.xz"; - sha256 = "1vj7b47cb7a94xmkdcfbqhx44g3ivqd7fif3vg256ikqlid8cl4q"; + src = fetchurl { + url = "mirror://kernel/linux/kernel/v5.x/linux-${kversion}.tar.xz"; + sha256 = "1722sc365ajxmqyr4r49yp73mzdckay3rx5c2gx29xzny9zc6cmy"; }; - }; in [ rt-patch ] ++ kernelPatches; - structuredExtraConfig = with lib.kernel; { - PREEMPT_RT = yes; - # Fix error: unused option: PREEMPT_RT. - EXPERT = yes; # PREEMPT_RT depends on it (in kernel/Kconfig.preempt) - # Fix error: option not set correctly: PREEMPT_VOLUNTARY (wanted 'y', got 'n'). - PREEMPT_VOLUNTARY = lib.mkForce no; # PREEMPT_RT deselects it. - # Fix error: unused option: RT_GROUP_SCHED. - RT_GROUP_SCHED = lib.mkForce (option no); # Removed by sched-disable-rt-group-sched-on-rt.patch. - } // structuredExtraConfig; + kernelPatches = + let + rt-patch = { + name = "rt"; + patch = fetchurl { + url = "mirror://kernel/linux/kernel/projects/rt/${branch}/older/patch-${version}.patch.xz"; + sha256 = "1vj7b47cb7a94xmkdcfbqhx44g3ivqd7fif3vg256ikqlid8cl4q"; + }; + }; + in + [ rt-patch ] ++ kernelPatches; + + structuredExtraConfig = + with lib.kernel; + { + PREEMPT_RT = yes; + # Fix error: unused option: PREEMPT_RT. + EXPERT = yes; # PREEMPT_RT depends on it (in kernel/Kconfig.preempt) + # Fix error: option not set correctly: PREEMPT_VOLUNTARY (wanted 'y', got 'n'). + PREEMPT_VOLUNTARY = lib.mkForce no; # PREEMPT_RT deselects it. + # Fix error: unused option: RT_GROUP_SCHED. + RT_GROUP_SCHED = lib.mkForce (option no); # Removed by sched-disable-rt-group-sched-on-rt.patch. + } + // structuredExtraConfig; - extraMeta = extraMeta // { - inherit branch; - }; -} // argsOverride) + extraMeta = extraMeta // { + inherit branch; + }; + } + // argsOverride +) diff --git a/pkgs/os-specific/linux/kernel/linux-rt-6.1.nix b/pkgs/os-specific/linux/kernel/linux-rt-6.1.nix index 4514adffd4a96e..10d987dd3fd4ad 100644 --- a/pkgs/os-specific/linux/kernel/linux-rt-6.1.nix +++ b/pkgs/os-specific/linux/kernel/linux-rt-6.1.nix @@ -1,46 +1,65 @@ -{ lib, buildLinux, fetchurl -, kernelPatches ? [ ] -, structuredExtraConfig ? {} -, extraMeta ? {} -, argsOverride ? {} -, ... } @ args: +{ + lib, + buildLinux, + fetchurl, + kernelPatches ? [ ], + structuredExtraConfig ? { }, + extraMeta ? { }, + argsOverride ? { }, + ... +}@args: let version = "6.1.119-rt45"; # updated by ./update-rt.sh branch = lib.versions.majorMinor version; kversion = builtins.elemAt (lib.splitString "-" version) 0; -in buildLinux (args // { - inherit version; - pname = "linux-rt"; +in +buildLinux ( + args + // { + inherit version; + pname = "linux-rt"; - # modDirVersion needs a patch number, change X.Y-rtZ to X.Y.0-rtZ. - modDirVersion = if (builtins.match "[^.]*[.][^.]*-.*" version) == null then version - else lib.replaceStrings ["-"] [".0-"] version; + # modDirVersion needs a patch number, change X.Y-rtZ to X.Y.0-rtZ. + modDirVersion = + if (builtins.match "[^.]*[.][^.]*-.*" version) == null then + version + else + lib.replaceStrings [ "-" ] [ ".0-" ] version; - src = fetchurl { - url = "mirror://kernel/linux/kernel/v6.x/linux-${kversion}.tar.xz"; - sha256 = "0y1j8bz99d5vkxklzpwhns5r77lpz2prszf6whfahi58s0wszkdf"; - }; - - kernelPatches = let rt-patch = { - name = "rt"; - patch = fetchurl { - url = "mirror://kernel/linux/kernel/projects/rt/${branch}/older/patch-${version}.patch.xz"; - sha256 = "0a7qga7xadp9ghhzz4iifdhap7vm288b789mv0xr9y8gnnk7cc9m"; + src = fetchurl { + url = "mirror://kernel/linux/kernel/v6.x/linux-${kversion}.tar.xz"; + sha256 = "0y1j8bz99d5vkxklzpwhns5r77lpz2prszf6whfahi58s0wszkdf"; }; - }; in [ rt-patch ] ++ kernelPatches; - structuredExtraConfig = with lib.kernel; { - PREEMPT_RT = yes; - # Fix error: unused option: PREEMPT_RT. - EXPERT = yes; # PREEMPT_RT depends on it (in kernel/Kconfig.preempt) - # Fix error: option not set correctly: PREEMPT_VOLUNTARY (wanted 'y', got 'n'). - PREEMPT_VOLUNTARY = lib.mkForce no; # PREEMPT_RT deselects it. - # Fix error: unused option: RT_GROUP_SCHED. - RT_GROUP_SCHED = lib.mkForce (option no); # Removed by sched-disable-rt-group-sched-on-rt.patch. - } // structuredExtraConfig; + kernelPatches = + let + rt-patch = { + name = "rt"; + patch = fetchurl { + url = "mirror://kernel/linux/kernel/projects/rt/${branch}/older/patch-${version}.patch.xz"; + sha256 = "0a7qga7xadp9ghhzz4iifdhap7vm288b789mv0xr9y8gnnk7cc9m"; + }; + }; + in + [ rt-patch ] ++ kernelPatches; + + structuredExtraConfig = + with lib.kernel; + { + PREEMPT_RT = yes; + # Fix error: unused option: PREEMPT_RT. + EXPERT = yes; # PREEMPT_RT depends on it (in kernel/Kconfig.preempt) + # Fix error: option not set correctly: PREEMPT_VOLUNTARY (wanted 'y', got 'n'). + PREEMPT_VOLUNTARY = lib.mkForce no; # PREEMPT_RT deselects it. + # Fix error: unused option: RT_GROUP_SCHED. + RT_GROUP_SCHED = lib.mkForce (option no); # Removed by sched-disable-rt-group-sched-on-rt.patch. + } + // structuredExtraConfig; - extraMeta = extraMeta // { - inherit branch; - }; -} // argsOverride) + extraMeta = extraMeta // { + inherit branch; + }; + } + // argsOverride +) diff --git a/pkgs/os-specific/linux/kernel/linux-rt-6.6.nix b/pkgs/os-specific/linux/kernel/linux-rt-6.6.nix index 3f5796cf627f77..7af5f9a39c6ca1 100644 --- a/pkgs/os-specific/linux/kernel/linux-rt-6.6.nix +++ b/pkgs/os-specific/linux/kernel/linux-rt-6.6.nix @@ -1,46 +1,65 @@ -{ lib, buildLinux, fetchurl -, kernelPatches ? [ ] -, structuredExtraConfig ? {} -, extraMeta ? {} -, argsOverride ? {} -, ... } @ args: +{ + lib, + buildLinux, + fetchurl, + kernelPatches ? [ ], + structuredExtraConfig ? { }, + extraMeta ? { }, + argsOverride ? { }, + ... +}@args: let version = "6.6.63-rt46"; # updated by ./update-rt.sh branch = lib.versions.majorMinor version; kversion = builtins.elemAt (lib.splitString "-" version) 0; -in buildLinux (args // { - inherit version; - pname = "linux-rt"; +in +buildLinux ( + args + // { + inherit version; + pname = "linux-rt"; - # modDirVersion needs a patch number, change X.Y-rtZ to X.Y.0-rtZ. - modDirVersion = if (builtins.match "[^.]*[.][^.]*-.*" version) == null then version - else lib.replaceStrings ["-"] [".0-"] version; + # modDirVersion needs a patch number, change X.Y-rtZ to X.Y.0-rtZ. + modDirVersion = + if (builtins.match "[^.]*[.][^.]*-.*" version) == null then + version + else + lib.replaceStrings [ "-" ] [ ".0-" ] version; - src = fetchurl { - url = "mirror://kernel/linux/kernel/v6.x/linux-${kversion}.tar.xz"; - sha256 = "0d8q0vwv3lcix3wiq2n53rir3h298flg2l0ghpify4rlh2s4l1fi"; - }; - - kernelPatches = let rt-patch = { - name = "rt"; - patch = fetchurl { - url = "mirror://kernel/linux/kernel/projects/rt/${branch}/older/patch-${version}.patch.xz"; - sha256 = "1p0kbkz21m2y9yjcyhbrnnnw9x885l3zamykjkmgxgg3s8awg025"; + src = fetchurl { + url = "mirror://kernel/linux/kernel/v6.x/linux-${kversion}.tar.xz"; + sha256 = "0d8q0vwv3lcix3wiq2n53rir3h298flg2l0ghpify4rlh2s4l1fi"; }; - }; in [ rt-patch ] ++ kernelPatches; - structuredExtraConfig = with lib.kernel; { - PREEMPT_RT = yes; - # Fix error: unused option: PREEMPT_RT. - EXPERT = yes; # PREEMPT_RT depends on it (in kernel/Kconfig.preempt) - # Fix error: option not set correctly: PREEMPT_VOLUNTARY (wanted 'y', got 'n'). - PREEMPT_VOLUNTARY = lib.mkForce no; # PREEMPT_RT deselects it. - # Fix error: unused option: RT_GROUP_SCHED. - RT_GROUP_SCHED = lib.mkForce (option no); # Removed by sched-disable-rt-group-sched-on-rt.patch. - } // structuredExtraConfig; + kernelPatches = + let + rt-patch = { + name = "rt"; + patch = fetchurl { + url = "mirror://kernel/linux/kernel/projects/rt/${branch}/older/patch-${version}.patch.xz"; + sha256 = "1p0kbkz21m2y9yjcyhbrnnnw9x885l3zamykjkmgxgg3s8awg025"; + }; + }; + in + [ rt-patch ] ++ kernelPatches; + + structuredExtraConfig = + with lib.kernel; + { + PREEMPT_RT = yes; + # Fix error: unused option: PREEMPT_RT. + EXPERT = yes; # PREEMPT_RT depends on it (in kernel/Kconfig.preempt) + # Fix error: option not set correctly: PREEMPT_VOLUNTARY (wanted 'y', got 'n'). + PREEMPT_VOLUNTARY = lib.mkForce no; # PREEMPT_RT deselects it. + # Fix error: unused option: RT_GROUP_SCHED. + RT_GROUP_SCHED = lib.mkForce (option no); # Removed by sched-disable-rt-group-sched-on-rt.patch. + } + // structuredExtraConfig; - extraMeta = extraMeta // { - inherit branch; - }; -} // argsOverride) + extraMeta = extraMeta // { + inherit branch; + }; + } + // argsOverride +) diff --git a/pkgs/os-specific/linux/kernel/mainline.nix b/pkgs/os-specific/linux/kernel/mainline.nix index 862ba8e8ddcce3..41c5a0218facdd 100644 --- a/pkgs/os-specific/linux/kernel/mainline.nix +++ b/pkgs/os-specific/linux/kernel/mainline.nix @@ -2,7 +2,14 @@ let allKernels = builtins.fromJSON (builtins.readFile ./kernels-org.json); in -{ branch, lib, fetchurl, fetchzip, buildLinux, ... } @ args: +{ + branch, + lib, + fetchurl, + fetchzip, + buildLinux, + ... +}@args: let thisKernel = allKernels.${branch}; @@ -10,21 +17,25 @@ let src = # testing kernels are a special case because they don't have tarballs on the CDN - if branch == "testing" - then fetchzip { + if branch == "testing" then + fetchzip { url = "https://git.kernel.org/torvalds/t/linux-${version}.tar.gz"; inherit (thisKernel) hash; } - else fetchurl { + else + fetchurl { url = "mirror://kernel/linux/kernel/v${lib.versions.major version}.x/linux-${version}.tar.xz"; inherit (thisKernel) hash; }; - args' = (builtins.removeAttrs args ["branch"]) // { - inherit src version; + args' = + (builtins.removeAttrs args [ "branch" ]) + // { + inherit src version; - modDirVersion = lib.versions.pad 3 version; - extraMeta.branch = branch; - } // (args.argsOverride or {}); + modDirVersion = lib.versions.pad 3 version; + extraMeta.branch = branch; + } + // (args.argsOverride or { }); in buildLinux args' diff --git a/pkgs/os-specific/linux/kernel/mptcp-config.nix b/pkgs/os-specific/linux/kernel/mptcp-config.nix index 59b11167ac2265..1fb5c3fe0c4d1b 100644 --- a/pkgs/os-specific/linux/kernel/mptcp-config.nix +++ b/pkgs/os-specific/linux/kernel/mptcp-config.nix @@ -1,28 +1,28 @@ { lib }: with lib.kernel; { - # DRM_AMDGPU = yes; + # DRM_AMDGPU = yes; - IPV6 = yes; - MPTCP = yes; - IP_MULTIPLE_TABLES = yes; + IPV6 = yes; + MPTCP = yes; + IP_MULTIPLE_TABLES = yes; - # Enable advanced path-managers... - MPTCP_PM_ADVANCED = yes; - MPTCP_FULLMESH = yes; - MPTCP_NDIFFPORTS = yes; - # ... but use none by default. - # The default is safer if source policy routing is not setup. - DEFAULT_DUMMY = yes; - DEFAULT_MPTCP_PM.freeform = "default"; + # Enable advanced path-managers... + MPTCP_PM_ADVANCED = yes; + MPTCP_FULLMESH = yes; + MPTCP_NDIFFPORTS = yes; + # ... but use none by default. + # The default is safer if source policy routing is not setup. + DEFAULT_DUMMY = yes; + DEFAULT_MPTCP_PM.freeform = "default"; - # MPTCP scheduler selection. - MPTCP_SCHED_ADVANCED = yes; - DEFAULT_MPTCP_SCHED.freeform = "default"; + # MPTCP scheduler selection. + MPTCP_SCHED_ADVANCED = yes; + DEFAULT_MPTCP_SCHED.freeform = "default"; - # Smarter TCP congestion controllers - TCP_CONG_LIA = module; - TCP_CONG_OLIA = module; - TCP_CONG_WVEGAS = module; - TCP_CONG_BALIA = module; + # Smarter TCP congestion controllers + TCP_CONG_LIA = module; + TCP_CONG_OLIA = module; + TCP_CONG_WVEGAS = module; + TCP_CONG_BALIA = module; } diff --git a/pkgs/os-specific/linux/kernel/patches.nix b/pkgs/os-specific/linux/kernel/patches.nix index 9e15991dd635ad..ddda525e70b0d8 100644 --- a/pkgs/os-specific/linux/kernel/patches.nix +++ b/pkgs/os-specific/linux/kernel/patches.nix @@ -1,4 +1,8 @@ -{ lib, fetchpatch, fetchurl }: +{ + lib, + fetchpatch, + fetchurl, +}: { ath_regd_optional = rec { @@ -14,10 +18,10 @@ }; }; - bridge_stp_helper = - { name = "bridge-stp-helper"; - patch = ./bridge-stp-helper.patch; - }; + bridge_stp_helper = { + name = "bridge-stp-helper"; + patch = ./bridge-stp-helper.patch; + }; # Reverts the buggy commit causing https://bugzilla.kernel.org/show_bug.cgi?id=217802 dell_xps_regression = { @@ -29,32 +33,44 @@ }; }; - request_key_helper = - { name = "request-key-helper"; - patch = ./request-key-helper.patch; - }; + request_key_helper = { + name = "request-key-helper"; + patch = ./request-key-helper.patch; + }; - request_key_helper_updated = - { name = "request-key-helper-updated"; - patch = ./request-key-helper-updated.patch; - }; + request_key_helper_updated = { + name = "request-key-helper-updated"; + patch = ./request-key-helper-updated.patch; + }; - hardened = let - mkPatch = kernelVersion: { version, sha256, patch }: let src = patch; in { - name = lib.removeSuffix ".patch" src.name; - patch = fetchurl (lib.filterAttrs (k: v: k != "extra") src); - extra = src.extra; - inherit version sha256; - }; - patches = lib.importJSON ./hardened/patches.json; - in lib.mapAttrs mkPatch patches; + hardened = + let + mkPatch = + kernelVersion: + { + version, + sha256, + patch, + }: + let + src = patch; + in + { + name = lib.removeSuffix ".patch" src.name; + patch = fetchurl (lib.filterAttrs (k: v: k != "extra") src); + extra = src.extra; + inherit version sha256; + }; + patches = lib.importJSON ./hardened/patches.json; + in + lib.mapAttrs mkPatch patches; # Adapted for Linux 5.4 from: # https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=04896832c94aae4842100cafb8d3a73e1bed3a45 - rtl8761b_support = - { name = "rtl8761b-support"; - patch = ./rtl8761b-support.patch; - }; + rtl8761b_support = { + name = "rtl8761b-support"; + patch = ./rtl8761b-support.patch; + }; export-rt-sched-migrate = { name = "export-rt-sched-migrate"; diff --git a/pkgs/os-specific/linux/kernel/perf/default.nix b/pkgs/os-specific/linux/kernel/perf/default.nix index b1f1f4e203b239..b947a2650f2d7a 100644 --- a/pkgs/os-specific/linux/kernel/perf/default.nix +++ b/pkgs/os-specific/linux/kernel/perf/default.nix @@ -1,43 +1,44 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, kernel -, elfutils -, python3 -, perl -, newt -, slang -, asciidoc -, xmlto -, makeWrapper -, docbook_xsl -, docbook_xml_dtd_45 -, libxslt -, flex -, bison -, pkg-config -, libunwind -, binutils-unwrapped -, libiberty -, audit -, libbfd -, libbfd_2_38 -, libopcodes -, libopcodes_2_38 -, libpfm -, libtraceevent -, openssl -, systemtap -, numactl -, zlib -, babeltrace -, withGtk ? false -, gtk2 -, withZstd ? true -, zstd -, withLibcap ? true -, libcap +{ + lib, + stdenv, + fetchurl, + fetchpatch, + kernel, + elfutils, + python3, + perl, + newt, + slang, + asciidoc, + xmlto, + makeWrapper, + docbook_xsl, + docbook_xml_dtd_45, + libxslt, + flex, + bison, + pkg-config, + libunwind, + binutils-unwrapped, + libiberty, + audit, + libbfd, + libbfd_2_38, + libopcodes, + libopcodes_2_38, + libpfm, + libtraceevent, + openssl, + systemtap, + numactl, + zlib, + babeltrace, + withGtk ? false, + gtk2, + withZstd ? true, + zstd, + withLibcap ? true, + libcap, }: let d3-flame-graph-templates = stdenv.mkDerivation rec { @@ -59,48 +60,61 @@ stdenv.mkDerivation { pname = "perf-linux"; inherit (kernel) version src; - patches = lib.optionals (lib.versionAtLeast kernel.version "5.10") [ - # fix wrong path to dmesg - ./fix-dmesg-path.diff - ] ++ lib.optionals (lib.versions.majorMinor kernel.version == "6.10") [ - (fetchpatch { - url = "https://git.kernel.org/pub/scm/linux/kernel/git/perf/perf-tools-next.git/patch/?id=0f0e1f44569061e3dc590cd0b8cb74d8fd53706b"; - hash = "sha256-9u/zhbsDgwOr4T4k9td/WJYRuSHIfbtfS+oNx8nbOlM="; - }) - (fetchpatch { - url = "https://git.kernel.org/pub/scm/linux/kernel/git/perf/perf-tools-next.git/patch/?id=366e17409f1f17ad872259ce4a4f8a92beb4c4ee"; - hash = "sha256-NZK1u40qvMwWcgkgJPGpEax2eMo9xHrCQxSYYOK0rbo="; - }) - (fetchpatch { - url = "https://git.kernel.org/pub/scm/linux/kernel/git/perf/perf-tools-next.git/patch/?id=1d302f626c2a23e4fd05bb810eff300e8f2174fd"; - hash = "sha256-KhCmof8LkyTcBBpfMEtolL3m3kmC5rukKzQvufVKCdI="; - }) - ]; - - postPatch = '' - # Linux scripts - patchShebangs scripts - patchShebangs tools/perf/check-headers.sh - '' + lib.optionalString (lib.versionAtLeast kernel.version "6.3") '' - # perf-specific scripts - patchShebangs tools/perf/pmu-events - '' + '' - cd tools/perf - - for x in util/build-id.c util/dso.c; do - substituteInPlace $x --replace /usr/lib/debug /run/current-system/sw/lib/debug - done - - '' + lib.optionalString (lib.versionAtLeast kernel.version "5.8") '' - substituteInPlace scripts/python/flamegraph.py \ - --replace "/usr/share/d3-flame-graph/d3-flamegraph-base.html" \ - "${d3-flame-graph-templates}/share/d3-flame-graph/d3-flamegraph-base.html" - - '' + lib.optionalString (lib.versionAtLeast kernel.version "6.0") '' - patchShebangs pmu-events/jevents.py - ''; + patches = + lib.optionals (lib.versionAtLeast kernel.version "5.10") [ + # fix wrong path to dmesg + ./fix-dmesg-path.diff + ] + ++ lib.optionals (lib.versions.majorMinor kernel.version == "6.10") [ + (fetchpatch { + url = "https://git.kernel.org/pub/scm/linux/kernel/git/perf/perf-tools-next.git/patch/?id=0f0e1f44569061e3dc590cd0b8cb74d8fd53706b"; + hash = "sha256-9u/zhbsDgwOr4T4k9td/WJYRuSHIfbtfS+oNx8nbOlM="; + }) + (fetchpatch { + url = "https://git.kernel.org/pub/scm/linux/kernel/git/perf/perf-tools-next.git/patch/?id=366e17409f1f17ad872259ce4a4f8a92beb4c4ee"; + hash = "sha256-NZK1u40qvMwWcgkgJPGpEax2eMo9xHrCQxSYYOK0rbo="; + }) + (fetchpatch { + url = "https://git.kernel.org/pub/scm/linux/kernel/git/perf/perf-tools-next.git/patch/?id=1d302f626c2a23e4fd05bb810eff300e8f2174fd"; + hash = "sha256-KhCmof8LkyTcBBpfMEtolL3m3kmC5rukKzQvufVKCdI="; + }) + ]; + + postPatch = + '' + # Linux scripts + patchShebangs scripts + patchShebangs tools/perf/check-headers.sh + '' + + lib.optionalString (lib.versionAtLeast kernel.version "6.3") '' + # perf-specific scripts + patchShebangs tools/perf/pmu-events + '' + + '' + cd tools/perf + + for x in util/build-id.c util/dso.c; do + substituteInPlace $x --replace /usr/lib/debug /run/current-system/sw/lib/debug + done + + '' + + lib.optionalString (lib.versionAtLeast kernel.version "5.8") '' + substituteInPlace scripts/python/flamegraph.py \ + --replace "/usr/share/d3-flame-graph/d3-flamegraph-base.html" \ + "${d3-flame-graph-templates}/share/d3-flame-graph/d3-flamegraph-base.html" + + '' + + lib.optionalString (lib.versionAtLeast kernel.version "6.0") '' + patchShebangs pmu-events/jevents.py + ''; - makeFlags = [ "prefix=$(out)" "WERROR=0" "ASCIIDOC8=1" ] ++ kernel.makeFlags + makeFlags = + [ + "prefix=$(out)" + "WERROR=0" + "ASCIIDOC8=1" + ] + ++ kernel.makeFlags ++ lib.optional (!withGtk) "NO_GTK2=1" ++ lib.optional (!withZstd) "NO_LIBZSTD=1" ++ lib.optional (!withLibcap) "NO_LIBCAP=1"; @@ -123,32 +137,46 @@ stdenv.mkDerivation { python3 ]; - buildInputs = [ - elfutils - newt - slang - libtraceevent - libunwind - zlib - openssl - numactl - python3 - perl - babeltrace - ] ++ (if (lib.versionAtLeast kernel.version "5.19") - then [ libbfd libopcodes ] - else [ libbfd_2_38 libopcodes_2_38 ]) - ++ lib.optional (lib.meta.availableOn stdenv.hostPlatform systemtap) systemtap.stapBuild - ++ lib.optional withGtk gtk2 - ++ lib.optional withZstd zstd - ++ lib.optional withLibcap libcap - ++ lib.optional (lib.versionAtLeast kernel.version "5.8") libpfm - ++ lib.optional (lib.versionAtLeast kernel.version "6.0") python3.pkgs.setuptools - # Python 3.12 no longer includes distutils, not needed for 6.0 and newer. - ++ lib.optional (!(lib.versionAtLeast kernel.version "6.0") && lib.versionAtLeast python3.version "3.12") [ - python3.pkgs.distutils - python3.pkgs.packaging - ]; + buildInputs = + [ + elfutils + newt + slang + libtraceevent + libunwind + zlib + openssl + numactl + python3 + perl + babeltrace + ] + ++ ( + if (lib.versionAtLeast kernel.version "5.19") then + [ + libbfd + libopcodes + ] + else + [ + libbfd_2_38 + libopcodes_2_38 + ] + ) + ++ lib.optional (lib.meta.availableOn stdenv.hostPlatform systemtap) systemtap.stapBuild + ++ lib.optional withGtk gtk2 + ++ lib.optional withZstd zstd + ++ lib.optional withLibcap libcap + ++ lib.optional (lib.versionAtLeast kernel.version "5.8") libpfm + ++ lib.optional (lib.versionAtLeast kernel.version "6.0") python3.pkgs.setuptools + # Python 3.12 no longer includes distutils, not needed for 6.0 and newer. + ++ + lib.optional + (!(lib.versionAtLeast kernel.version "6.0") && lib.versionAtLeast python3.version "3.12") + [ + python3.pkgs.distutils + python3.pkgs.packaging + ]; env.NIX_CFLAGS_COMPILE = toString [ "-Wno-error=cpp" @@ -159,7 +187,10 @@ stdenv.mkDerivation { doCheck = false; # requires "sparse" - installTargets = [ "install" "install-man" ]; + installTargets = [ + "install" + "install-man" + ]; # TODO: Add completions based on perf-completion.sh postInstall = '' @@ -174,7 +205,12 @@ stdenv.mkDerivation { # The embedded Python interpreter will search PATH to calculate the Python path configuration(Should be fixed by upstream). # Add python.interpreter to PATH for now. wrapProgram $out/bin/perf \ - --prefix PATH : ${lib.makeBinPath [ binutils-unwrapped python3 ]} + --prefix PATH : ${ + lib.makeBinPath [ + binutils-unwrapped + python3 + ] + } ''; meta = with lib; { diff --git a/pkgs/os-specific/linux/kernel/zen-kernels.nix b/pkgs/os-specific/linux/kernel/zen-kernels.nix index cf6d71ef6528f2..9a5b34e742ad2b 100644 --- a/pkgs/os-specific/linux/kernel/zen-kernels.nix +++ b/pkgs/os-specific/linux/kernel/zen-kernels.nix @@ -1,125 +1,153 @@ -{ lib, stdenv, fetchFromGitHub, buildLinux, variant, ... } @ args: +{ + lib, + stdenv, + fetchFromGitHub, + buildLinux, + variant, + ... +}@args: let # comments with variant added for update script variants = { # ./update-zen.py zen zen = { - version = "6.12.2"; #zen - suffix = "zen1"; #zen - sha256 = "0a6anmfm6495j6lwlywr62ghpwdvbdn54bl5baya5jz7vfqc1ghj"; #zen + version = "6.12.2"; # zen + suffix = "zen1"; # zen + sha256 = "0a6anmfm6495j6lwlywr62ghpwdvbdn54bl5baya5jz7vfqc1ghj"; # zen isLqx = false; }; # ./update-zen.py lqx lqx = { - version = "6.12.2"; #lqx - suffix = "lqx3"; #lqx - sha256 = "18ibc0dz70vxb61mzdhbhbjg0kfxgcsrl3zdki0cqlhcvfxwk19h"; #lqx + version = "6.12.2"; # lqx + suffix = "lqx3"; # lqx + sha256 = "18ibc0dz70vxb61mzdhbhbjg0kfxgcsrl3zdki0cqlhcvfxwk19h"; # lqx isLqx = true; }; }; - zenKernelsFor = { version, suffix, sha256, isLqx }: buildLinux (args // { - inherit version; - pname = "linux-${if isLqx then "lqx" else "zen"}"; - modDirVersion = lib.versions.pad 3 "${version}-${suffix}"; - isZen = true; - - src = fetchFromGitHub { - owner = "zen-kernel"; - repo = "zen-kernel"; - rev = "v${version}-${suffix}"; - inherit sha256; - }; - - # This is based on the following sources: - # - zen: https://gitlab.archlinux.org/archlinux/packaging/packages/linux-zen/-/blob/main/config - # - lqx: https://github.com/damentz/liquorix-package/blob/6.8/master/linux-liquorix/debian/config/kernelarch-x86/config-arch-64 - # - Liquorix features: https://liquorix.net/ - # The list below is not exhaustive, so the kernels probably doesn't match - # the upstream, but should bring most of the improvements that will be - # expected by users - structuredExtraConfig = with lib.kernel; { - # Zen Interactive tuning - ZEN_INTERACTIVE = yes; - - # FQ-Codel Packet Scheduling - NET_SCH_DEFAULT = yes; - DEFAULT_FQ_CODEL = yes; - - # Preempt (low-latency) - PREEMPT = lib.mkOverride 60 yes; - PREEMPT_VOLUNTARY = lib.mkOverride 60 no; - - # Preemptible tree-based hierarchical RCU - TREE_RCU = yes; - PREEMPT_RCU = yes; - RCU_EXPERT = yes; - TREE_SRCU = yes; - TASKS_RCU_GENERIC = yes; - TASKS_RCU = yes; - TASKS_RUDE_RCU = yes; - TASKS_TRACE_RCU = yes; - RCU_STALL_COMMON = yes; - RCU_NEED_SEGCBLIST = yes; - RCU_FANOUT = freeform "64"; - RCU_FANOUT_LEAF = freeform "16"; - RCU_BOOST = yes; - RCU_BOOST_DELAY = option (freeform "500"); - RCU_NOCB_CPU = yes; - RCU_LAZY = yes; - RCU_DOUBLE_CHECK_CB_TIME = yes; - - # BFQ I/O scheduler - IOSCHED_BFQ = lib.mkOverride 60 yes; - - # Futex WAIT_MULTIPLE implementation for Wine / Proton Fsync. - FUTEX = yes; - FUTEX_PI = yes; - - # NT synchronization primitive emulation - NTSYNC = yes; - - # Preemptive Full Tickless Kernel at 1000Hz - HZ = freeform "1000"; - HZ_1000 = yes; - - } // lib.optionalAttrs (isLqx) { - # Google's BBRv3 TCP congestion Control - TCP_CONG_BBR = yes; - DEFAULT_BBR = yes; - - # PDS Process Scheduler - SCHED_ALT = yes; - SCHED_PDS = yes; - - # https://github.com/damentz/liquorix-package/commit/a7055b936c0f4edb8f6afd5263fe1d2f8a5cd877 - RCU_BOOST = no; - RCU_LAZY = lib.mkOverride 60 no; - - # Swap storage is compressed with LZ4 using zswap - ZSWAP_COMPRESSOR_DEFAULT_LZ4 = lib.mkOptionDefault yes; - ZSWAP_COMPRESSOR_DEFAULT_ZSTD = lib.mkDefault no; - - # Fix error: unused option: XXX. - CFS_BANDWIDTH = lib.mkForce (option no); - PSI = lib.mkForce (option no); - RT_GROUP_SCHED = lib.mkForce (option no); - SCHED_AUTOGROUP = lib.mkForce (option no); - SCHED_CORE = lib.mkForce (option no); - UCLAMP_TASK = lib.mkForce (option no); - UCLAMP_TASK_GROUP = lib.mkForce (option no); - }; - - passthru.updateScript = [ ./update-zen.py (if isLqx then "lqx" else "zen") ]; - - extraMeta = { - branch = lib.versions.majorMinor version + "/master"; - maintainers = with lib.maintainers; [ thiagokokada jerrysm64 ]; - description = "Built using the best configuration and kernel sources for desktop, multimedia, and gaming workloads." + - lib.optionalString isLqx " (Same as linux_zen, but less aggressive release schedule and additional extra config)"; - broken = stdenv.hostPlatform.isAarch64; - }; - - } // (args.argsOverride or { })); + zenKernelsFor = + { + version, + suffix, + sha256, + isLqx, + }: + buildLinux ( + args + // { + inherit version; + pname = "linux-${if isLqx then "lqx" else "zen"}"; + modDirVersion = lib.versions.pad 3 "${version}-${suffix}"; + isZen = true; + + src = fetchFromGitHub { + owner = "zen-kernel"; + repo = "zen-kernel"; + rev = "v${version}-${suffix}"; + inherit sha256; + }; + + # This is based on the following sources: + # - zen: https://gitlab.archlinux.org/archlinux/packaging/packages/linux-zen/-/blob/main/config + # - lqx: https://github.com/damentz/liquorix-package/blob/6.8/master/linux-liquorix/debian/config/kernelarch-x86/config-arch-64 + # - Liquorix features: https://liquorix.net/ + # The list below is not exhaustive, so the kernels probably doesn't match + # the upstream, but should bring most of the improvements that will be + # expected by users + structuredExtraConfig = + with lib.kernel; + { + # Zen Interactive tuning + ZEN_INTERACTIVE = yes; + + # FQ-Codel Packet Scheduling + NET_SCH_DEFAULT = yes; + DEFAULT_FQ_CODEL = yes; + + # Preempt (low-latency) + PREEMPT = lib.mkOverride 60 yes; + PREEMPT_VOLUNTARY = lib.mkOverride 60 no; + + # Preemptible tree-based hierarchical RCU + TREE_RCU = yes; + PREEMPT_RCU = yes; + RCU_EXPERT = yes; + TREE_SRCU = yes; + TASKS_RCU_GENERIC = yes; + TASKS_RCU = yes; + TASKS_RUDE_RCU = yes; + TASKS_TRACE_RCU = yes; + RCU_STALL_COMMON = yes; + RCU_NEED_SEGCBLIST = yes; + RCU_FANOUT = freeform "64"; + RCU_FANOUT_LEAF = freeform "16"; + RCU_BOOST = yes; + RCU_BOOST_DELAY = option (freeform "500"); + RCU_NOCB_CPU = yes; + RCU_LAZY = yes; + RCU_DOUBLE_CHECK_CB_TIME = yes; + + # BFQ I/O scheduler + IOSCHED_BFQ = lib.mkOverride 60 yes; + + # Futex WAIT_MULTIPLE implementation for Wine / Proton Fsync. + FUTEX = yes; + FUTEX_PI = yes; + + # NT synchronization primitive emulation + NTSYNC = yes; + + # Preemptive Full Tickless Kernel at 1000Hz + HZ = freeform "1000"; + HZ_1000 = yes; + + } + // lib.optionalAttrs (isLqx) { + # Google's BBRv3 TCP congestion Control + TCP_CONG_BBR = yes; + DEFAULT_BBR = yes; + + # PDS Process Scheduler + SCHED_ALT = yes; + SCHED_PDS = yes; + + # https://github.com/damentz/liquorix-package/commit/a7055b936c0f4edb8f6afd5263fe1d2f8a5cd877 + RCU_BOOST = no; + RCU_LAZY = lib.mkOverride 60 no; + + # Swap storage is compressed with LZ4 using zswap + ZSWAP_COMPRESSOR_DEFAULT_LZ4 = lib.mkOptionDefault yes; + ZSWAP_COMPRESSOR_DEFAULT_ZSTD = lib.mkDefault no; + + # Fix error: unused option: XXX. + CFS_BANDWIDTH = lib.mkForce (option no); + PSI = lib.mkForce (option no); + RT_GROUP_SCHED = lib.mkForce (option no); + SCHED_AUTOGROUP = lib.mkForce (option no); + SCHED_CORE = lib.mkForce (option no); + UCLAMP_TASK = lib.mkForce (option no); + UCLAMP_TASK_GROUP = lib.mkForce (option no); + }; + + passthru.updateScript = [ + ./update-zen.py + (if isLqx then "lqx" else "zen") + ]; + + extraMeta = { + branch = lib.versions.majorMinor version + "/master"; + maintainers = with lib.maintainers; [ + thiagokokada + jerrysm64 + ]; + description = + "Built using the best configuration and kernel sources for desktop, multimedia, and gaming workloads." + + lib.optionalString isLqx " (Same as linux_zen, but less aggressive release schedule and additional extra config)"; + broken = stdenv.hostPlatform.isAarch64; + }; + + } + // (args.argsOverride or { }) + ); in zenKernelsFor variants.${variant} diff --git a/pkgs/os-specific/linux/klibc/default.nix b/pkgs/os-specific/linux/klibc/default.nix index 2b010e5c8bce2c..34414fb9959401 100644 --- a/pkgs/os-specific/linux/klibc/default.nix +++ b/pkgs/os-specific/linux/klibc/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, buildPackages, linuxHeaders, perl, nixosTests }: +{ + lib, + stdenv, + fetchurl, + buildPackages, + linuxHeaders, + perl, + nixosTests, +}: let commonMakeFlags = [ @@ -22,15 +30,23 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ perl ]; strictDeps = true; - hardeningDisable = [ "format" "stackprotector" ]; + hardeningDisable = [ + "format" + "stackprotector" + ]; - makeFlags = commonMakeFlags ++ [ - "KLIBCARCH=${if stdenv.hostPlatform.isRiscV64 then "riscv64" else stdenv.hostPlatform.linuxArch}" - "KLIBCKERNELSRC=${linuxHeaders}" - ] # TODO(@Ericson2314): We now can get the ABI from + makeFlags = + commonMakeFlags + ++ [ + "KLIBCARCH=${if stdenv.hostPlatform.isRiscV64 then "riscv64" else stdenv.hostPlatform.linuxArch}" + "KLIBCKERNELSRC=${linuxHeaders}" + ] + # TODO(@Ericson2314): We now can get the ABI from # `stdenv.hostPlatform.parsed.abi`, is this still a good idea? ++ lib.optional (stdenv.hostPlatform.linuxArch == "arm") "CONFIG_AEABI=y" - ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "CROSS_COMPILE=${stdenv.cc.targetPrefix}"; + ++ lib.optional ( + stdenv.hostPlatform != stdenv.buildPlatform + ) "CROSS_COMPILE=${stdenv.cc.targetPrefix}"; # Install static binaries as well. postInstall = '' diff --git a/pkgs/os-specific/linux/klibc/shrunk.nix b/pkgs/os-specific/linux/klibc/shrunk.nix index 8b79940ed78cd6..2cff3bcd87ea8b 100644 --- a/pkgs/os-specific/linux/klibc/shrunk.nix +++ b/pkgs/os-specific/linux/klibc/shrunk.nix @@ -1,4 +1,4 @@ -{stdenv, klibc}: +{ stdenv, klibc }: stdenv.mkDerivation { # !!! For now, the name has to be exactly as long as the original @@ -20,7 +20,7 @@ stdenv.mkDerivation { #patchelf --set-interpreter $new $i done ''; # */ - allowedReferences = ["out"]; + allowedReferences = [ "out" ]; inherit (klibc) meta; } diff --git a/pkgs/os-specific/linux/kmod/default.nix b/pkgs/os-specific/linux/kmod/default.nix index 1ea3a90005b950..6a73b3416db625 100644 --- a/pkgs/os-specific/linux/kmod/default.nix +++ b/pkgs/os-specific/linux/kmod/default.nix @@ -1,16 +1,35 @@ -{ stdenv, lib, fetchzip, fetchpatch, autoconf, automake, docbook_xml_dtd_42 -, docbook_xml_dtd_43, docbook_xsl, gtk-doc, libtool, pkg-config -, libxslt, xz, zstd, elf-header -, withDevdoc ? stdenv.hostPlatform == stdenv.buildPlatform -, withStatic ? stdenv.hostPlatform.isStatic -, gitUpdater +{ + stdenv, + lib, + fetchzip, + fetchpatch, + autoconf, + automake, + docbook_xml_dtd_42, + docbook_xml_dtd_43, + docbook_xsl, + gtk-doc, + libtool, + pkg-config, + libxslt, + xz, + zstd, + elf-header, + withDevdoc ? stdenv.hostPlatform == stdenv.buildPlatform, + withStatic ? stdenv.hostPlatform.isStatic, + gitUpdater, }: let - systems = [ "/run/booted-system/kernel-modules" "/run/current-system/kernel-modules" "" ]; + systems = [ + "/run/booted-system/kernel-modules" + "/run/current-system/kernel-modules" + "" + ]; modulesDirs = lib.concatMapStringsSep ":" (x: "${x}/lib/modules") systems; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "kmod"; version = "31"; @@ -24,15 +43,33 @@ in stdenv.mkDerivation rec { hash = "sha256-FNR015/AoYBbi7Eb1M2TXH3yxUuddKICCu+ot10CdeQ="; }; - outputs = [ "out" "dev" "lib" ] ++ lib.optional withDevdoc "devdoc"; + outputs = [ + "out" + "dev" + "lib" + ] ++ lib.optional withDevdoc "devdoc"; strictDeps = true; - nativeBuildInputs = [ - autoconf automake docbook_xsl libtool libxslt pkg-config + nativeBuildInputs = + [ + autoconf + automake + docbook_xsl + libtool + libxslt + pkg-config - docbook_xml_dtd_42 # for the man pages - ] ++ lib.optionals withDevdoc [ docbook_xml_dtd_43 gtk-doc ]; - buildInputs = [ xz zstd ] + docbook_xml_dtd_42 # for the man pages + ] + ++ lib.optionals withDevdoc [ + docbook_xml_dtd_43 + gtk-doc + ]; + buildInputs = + [ + xz + zstd + ] # gtk-doc is looked for with pkg-config ++ lib.optionals withDevdoc [ gtk-doc ]; @@ -83,7 +120,10 @@ in stdenv.mkDerivation rec { homepage = "https://git.kernel.org/pub/scm/utils/kernel/kmod/kmod.git/"; downloadPage = "https://www.kernel.org/pub/linux/utils/kernel/kmod/"; changelog = "https://git.kernel.org/pub/scm/utils/kernel/kmod/kmod.git/plain/NEWS?h=v${version}"; - license = with licenses; [ lgpl21Plus gpl2Plus ]; # GPLv2+ for tools + license = with licenses; [ + lgpl21Plus + gpl2Plus + ]; # GPLv2+ for tools platforms = platforms.linux; maintainers = with maintainers; [ artturin ]; }; diff --git a/pkgs/os-specific/linux/kvmfr/default.nix b/pkgs/os-specific/linux/kvmfr/default.nix index a527351262be83..a0d7a58fe87cd4 100644 --- a/pkgs/os-specific/linux/kvmfr/default.nix +++ b/pkgs/os-specific/linux/kvmfr/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchpatch, kernel, looking-glass-client }: +{ + lib, + stdenv, + fetchpatch, + kernel, + looking-glass-client, +}: stdenv.mkDerivation { pname = "kvmfr"; @@ -6,7 +12,10 @@ stdenv.mkDerivation { src = looking-glass-client.src; sourceRoot = "${looking-glass-client.src.name}/module"; - hardeningDisable = [ "pic" "format" ]; + hardeningDisable = [ + "pic" + "format" + ]; nativeBuildInputs = kernel.moduleBuildDependencies; patches = [ diff --git a/pkgs/os-specific/linux/lenovo-legion/default.nix b/pkgs/os-specific/linux/lenovo-legion/default.nix index a79c901a13126d..75d8a10b8d06a7 100644 --- a/pkgs/os-specific/linux/lenovo-legion/default.nix +++ b/pkgs/os-specific/linux/lenovo-legion/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, kernel, bash, lenovo-legion }: +{ + lib, + stdenv, + kernel, + bash, + lenovo-legion, +}: stdenv.mkDerivation { pname = "lenovo-legion-module"; diff --git a/pkgs/os-specific/linux/libbpf/0.x.nix b/pkgs/os-specific/linux/libbpf/0.x.nix index b34cca4a51af47..603fded29262e1 100644 --- a/pkgs/os-specific/linux/libbpf/0.x.nix +++ b/pkgs/os-specific/linux/libbpf/0.x.nix @@ -1,10 +1,11 @@ -{ fetchFromGitHub -, elfutils -, pkg-config -, stdenv -, zlib -, lib -, nixosTests +{ + fetchFromGitHub, + elfutils, + pkg-config, + stdenv, + zlib, + lib, + nixosTests, }: # update bot does not seem to limit updates here to 0.8.x despite @@ -24,10 +25,16 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ elfutils zlib ]; + buildInputs = [ + elfutils + zlib + ]; enableParallelBuilding = true; - makeFlags = [ "PREFIX=$(out)" "-C src" ]; + makeFlags = [ + "PREFIX=$(out)" + "-C src" + ]; passthru.tests = { bpf = nixosTests.bpf; @@ -47,8 +54,16 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Upstream mirror of libbpf"; homepage = "https://github.com/libbpf/libbpf"; - license = with licenses; [ lgpl21 /* or */ bsd2 ]; - maintainers = with maintainers; [ thoughtpolice vcunat saschagrunert martinetd ]; + license = with licenses; [ + lgpl21 # or + bsd2 + ]; + maintainers = with maintainers; [ + thoughtpolice + vcunat + saschagrunert + martinetd + ]; platforms = platforms.linux; }; } diff --git a/pkgs/os-specific/linux/libsemanage/default.nix b/pkgs/os-specific/linux/libsemanage/default.nix index 1c1d66432db433..f5b3a71b9545e9 100644 --- a/pkgs/os-specific/linux/libsemanage/default.nix +++ b/pkgs/os-specific/linux/libsemanage/default.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchurl, pkg-config, bison, flex, libsepol, libselinux, bzip2, audit -, enablePython ? true, swig ? null, python ? null +{ + lib, + stdenv, + fetchurl, + pkg-config, + bison, + flex, + libsepol, + libselinux, + bzip2, + audit, + enablePython ? true, + swig ? null, + python ? null, }: stdenv.mkDerivation rec { @@ -10,15 +22,27 @@ stdenv.mkDerivation rec { src = fetchurl { url = "${se_url}/${version}/libsemanage-${version}.tar.gz"; sha256 = "sha256-4WbK4ppBfasAjbnKCHQCPzU6MBewdpOgNu2XSH7aNbE="; - }; + }; - outputs = [ "out" "dev" "man" ] ++ lib.optional enablePython "py"; + outputs = [ + "out" + "dev" + "man" + ] ++ lib.optional enablePython "py"; strictDeps = true; - nativeBuildInputs = [ bison flex pkg-config ] ++ lib.optional enablePython swig; - buildInputs = [ libsepol libselinux bzip2 audit ] - ++ lib.optional enablePython python; + nativeBuildInputs = [ + bison + flex + pkg-config + ] ++ lib.optional enablePython swig; + buildInputs = [ + libsepol + libselinux + bzip2 + audit + ] ++ lib.optional enablePython python; makeFlags = [ "PREFIX=$(out)" @@ -45,7 +69,7 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - meta = removeAttrs libsepol.meta ["outputsToInstall"] // { + meta = removeAttrs libsepol.meta [ "outputsToInstall" ] // { description = "Policy management tools for SELinux"; license = lib.licenses.lgpl21; }; diff --git a/pkgs/os-specific/linux/liquidtux/default.nix b/pkgs/os-specific/linux/liquidtux/default.nix index ca4fb27c8f1990..a5a2387d637446 100644 --- a/pkgs/os-specific/linux/liquidtux/default.nix +++ b/pkgs/os-specific/linux/liquidtux/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { name = "liquidtux-${version}-${kernel.version}"; @@ -27,7 +32,10 @@ stdenv.mkDerivation rec { description = "Linux kernel hwmon drivers for AIO liquid coolers and other devices"; homepage = "https://github.com/liquidctl/liquidtux"; license = licenses.gpl2Only; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = with maintainers; [ nickhu ]; broken = lib.versionOlder kernel.version "5.10"; }; diff --git a/pkgs/os-specific/linux/mba6x_bl/default.nix b/pkgs/os-specific/linux/mba6x_bl/default.nix index 47466dc54051a4..2f5358e6ea15d3 100644 --- a/pkgs/os-specific/linux/mba6x_bl/default.nix +++ b/pkgs/os-specific/linux/mba6x_bl/default.nix @@ -1,4 +1,9 @@ -{ fetchFromGitHub, kernel, lib, stdenv }: +{ + fetchFromGitHub, + kernel, + lib, + stdenv, +}: stdenv.mkDerivation { pname = "mba6x_bl"; diff --git a/pkgs/os-specific/linux/mbp-modules/mbp2018-bridge-drv/default.nix b/pkgs/os-specific/linux/mbp-modules/mbp2018-bridge-drv/default.nix index 2670c725444916..6907ffeec75249 100644 --- a/pkgs/os-specific/linux/mbp-modules/mbp2018-bridge-drv/default.nix +++ b/pkgs/os-specific/linux/mbp-modules/mbp2018-bridge-drv/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, kernel, fetchFromGitHub, }: +{ + lib, + stdenv, + kernel, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "mbp2018-bridge-drv"; diff --git a/pkgs/os-specific/linux/mcelog/default.nix b/pkgs/os-specific/linux/mcelog/default.nix index 2a6727027f4845..28eb2ef55385d8 100644 --- a/pkgs/os-specific/linux/mcelog/default.nix +++ b/pkgs/os-specific/linux/mcelog/default.nix @@ -1,13 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, util-linux }: +{ + lib, + stdenv, + fetchFromGitHub, + util-linux, +}: stdenv.mkDerivation rec { pname = "mcelog"; version = "180"; src = fetchFromGitHub { - owner = "andikleen"; - repo = "mcelog"; - rev = "v${version}"; + owner = "andikleen"; + repo = "mcelog"; + rev = "v${version}"; sha256 = "1xy1082c67yd48idg5vwvrw7yx74gn6jj2d9c67d0rh6yji091ki"; }; @@ -26,7 +31,11 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - installFlags = [ "DESTDIR=$(out)" "prefix=" "DOCDIR=/share/doc" ]; + installFlags = [ + "DESTDIR=$(out)" + "prefix=" + "DOCDIR=/share/doc" + ]; postInstall = '' mkdir -p $out/lib/systemd/system diff --git a/pkgs/os-specific/linux/minimal-bootstrap/bash/2.nix b/pkgs/os-specific/linux/minimal-bootstrap/bash/2.nix index 5eea877803a5b6..fd273838c95448 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/bash/2.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/bash/2.nix @@ -1,13 +1,14 @@ -{ lib -, derivationWithMeta -, fetchurl -, kaem -, tinycc -, gnumake -, gnupatch -, coreutils -, mescc-tools-extra -, bash_2_05 +{ + lib, + derivationWithMeta, + fetchurl, + kaem, + tinycc, + gnumake, + gnupatch, + coreutils, + mescc-tools-extra, + bash_2_05, }: let pname = "bash"; @@ -66,92 +67,102 @@ let }) ]; in -kaem.runCommand "${pname}-${version}" { - inherit pname version; - - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnupatch - coreutils - ]; - - passthru.runCommand = name: env: buildCommand: - derivationWithMeta ({ - inherit name buildCommand; - builder = "${bash_2_05}/bin/bash"; - args = [ - "-e" - (builtins.toFile "bash-builder.sh" '' - export CONFIG_SHELL=$SHELL - - # Normalize the NIX_BUILD_CORES variable. The value might be 0, which - # means that we're supposed to try and auto-detect the number of - # available CPU cores at run-time. We don't have nproc to detect the - # number of available CPU cores so default to 1 if not set. - NIX_BUILD_CORES="''${NIX_BUILD_CORES:-1}" - if [ $NIX_BUILD_CORES -le 0 ]; then - NIX_BUILD_CORES=1 - fi - export NIX_BUILD_CORES - - bash -eux $buildCommandPath - '') - ]; - passAsFile = [ "buildCommand" ]; - - SHELL = "${bash_2_05}/bin/bash"; - PATH = lib.makeBinPath ((env.nativeBuildInputs or []) ++ [ - bash_2_05 - coreutils - # provides untar, ungz, and unbz2 - mescc-tools-extra - ]); - } // (builtins.removeAttrs env [ "nativeBuildInputs" ])); - - passthru.tests.get-version = result: - kaem.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/bash --version - mkdir ''${out} - ''; - - meta = with lib; { - description = "GNU Bourne-Again Shell, the de facto standard shell on Linux"; - homepage = "https://www.gnu.org/software/bash"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - ungz --file ${src} --output bash.tar - untar --file bash.tar - rm bash.tar - cd bash-${version} - - # Patch - ${lib.concatMapStringsSep "\n" (f: "patch -Np0 -i ${f}") patches} - - # Configure - cp ${main_mk} Makefile - cp ${builtins_mk} builtins/Makefile - cp ${common_mk} common.mk - touch config.h - touch include/version.h - touch include/pipesize.h - - # Build - make \ - CC="tcc -B ${tinycc.libs}/lib" \ - mkbuiltins - cd builtins - make \ - CC="tcc -B ${tinycc.libs}/lib" \ - libbuiltins.a - cd .. - make CC="tcc -B ${tinycc.libs}/lib" - - # Install - install -D bash ''${out}/bin/bash - ln -s bash ''${out}/bin/sh -'' +kaem.runCommand "${pname}-${version}" + { + inherit pname version; + + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnupatch + coreutils + ]; + + passthru.runCommand = + name: env: buildCommand: + derivationWithMeta ( + { + inherit name buildCommand; + builder = "${bash_2_05}/bin/bash"; + args = [ + "-e" + (builtins.toFile "bash-builder.sh" '' + export CONFIG_SHELL=$SHELL + + # Normalize the NIX_BUILD_CORES variable. The value might be 0, which + # means that we're supposed to try and auto-detect the number of + # available CPU cores at run-time. We don't have nproc to detect the + # number of available CPU cores so default to 1 if not set. + NIX_BUILD_CORES="''${NIX_BUILD_CORES:-1}" + if [ $NIX_BUILD_CORES -le 0 ]; then + NIX_BUILD_CORES=1 + fi + export NIX_BUILD_CORES + + bash -eux $buildCommandPath + '') + ]; + passAsFile = [ "buildCommand" ]; + + SHELL = "${bash_2_05}/bin/bash"; + PATH = lib.makeBinPath ( + (env.nativeBuildInputs or [ ]) + ++ [ + bash_2_05 + coreutils + # provides untar, ungz, and unbz2 + mescc-tools-extra + ] + ); + } + // (builtins.removeAttrs env [ "nativeBuildInputs" ]) + ); + + passthru.tests.get-version = + result: + kaem.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/bash --version + mkdir ''${out} + ''; + + meta = with lib; { + description = "GNU Bourne-Again Shell, the de facto standard shell on Linux"; + homepage = "https://www.gnu.org/software/bash"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + ungz --file ${src} --output bash.tar + untar --file bash.tar + rm bash.tar + cd bash-${version} + + # Patch + ${lib.concatMapStringsSep "\n" (f: "patch -Np0 -i ${f}") patches} + + # Configure + cp ${main_mk} Makefile + cp ${builtins_mk} builtins/Makefile + cp ${common_mk} common.mk + touch config.h + touch include/version.h + touch include/pipesize.h + + # Build + make \ + CC="tcc -B ${tinycc.libs}/lib" \ + mkbuiltins + cd builtins + make \ + CC="tcc -B ${tinycc.libs}/lib" \ + libbuiltins.a + cd .. + make CC="tcc -B ${tinycc.libs}/lib" + + # Install + install -D bash ''${out}/bin/bash + ln -s bash ''${out}/bin/sh + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/bash/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/bash/default.nix index 86fa3a58687b85..32daa77ed55da5 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/bash/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/bash/default.nix @@ -1,20 +1,21 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bootBash -, gnumake -, gnupatch -, gnused -, gnugrep -, gnutar -, gawk -, gzip -, diffutils -, tinycc -, derivationWithMeta -, bash -, coreutils +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bootBash, + gnumake, + gnupatch, + gnused, + gnugrep, + gnutar, + gawk, + gzip, + diffutils, + tinycc, + derivationWithMeta, + bash, + coreutils, }: let pname = "bash"; @@ -30,88 +31,98 @@ let ./mksignames-flush.patch ]; in -bootBash.runCommand "${pname}-${version}" { - inherit pname version; +bootBash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - coreutils - tinycc.compiler - gnumake - gnupatch - gnused - gnugrep - gnutar - gawk - gzip - diffutils - ]; + nativeBuildInputs = [ + coreutils + tinycc.compiler + gnumake + gnupatch + gnused + gnugrep + gnutar + gawk + gzip + diffutils + ]; - passthru.runCommand = name: env: buildCommand: - derivationWithMeta ({ - inherit name buildCommand; - builder = "${bash}/bin/bash"; - args = [ - "-e" - (builtins.toFile "bash-builder.sh" '' - export CONFIG_SHELL=$SHELL + passthru.runCommand = + name: env: buildCommand: + derivationWithMeta ( + { + inherit name buildCommand; + builder = "${bash}/bin/bash"; + args = [ + "-e" + (builtins.toFile "bash-builder.sh" '' + export CONFIG_SHELL=$SHELL - # Normalize the NIX_BUILD_CORES variable. The value might be 0, which - # means that we're supposed to try and auto-detect the number of - # available CPU cores at run-time. - NIX_BUILD_CORES="''${NIX_BUILD_CORES:-1}" - if ((NIX_BUILD_CORES <= 0)); then - guess=$(nproc 2>/dev/null || true) - ((NIX_BUILD_CORES = guess <= 0 ? 1 : guess)) - fi - export NIX_BUILD_CORES + # Normalize the NIX_BUILD_CORES variable. The value might be 0, which + # means that we're supposed to try and auto-detect the number of + # available CPU cores at run-time. + NIX_BUILD_CORES="''${NIX_BUILD_CORES:-1}" + if ((NIX_BUILD_CORES <= 0)); then + guess=$(nproc 2>/dev/null || true) + ((NIX_BUILD_CORES = guess <= 0 ? 1 : guess)) + fi + export NIX_BUILD_CORES - bash -eux $buildCommandPath - '') - ]; - passAsFile = [ "buildCommand" ]; + bash -eux $buildCommandPath + '') + ]; + passAsFile = [ "buildCommand" ]; - SHELL = "${bash}/bin/bash"; - PATH = lib.makeBinPath ((env.nativeBuildInputs or []) ++ [ - bash - coreutils - ]); - } // (builtins.removeAttrs env [ "nativeBuildInputs" ])); + SHELL = "${bash}/bin/bash"; + PATH = lib.makeBinPath ( + (env.nativeBuildInputs or [ ]) + ++ [ + bash + coreutils + ] + ); + } + // (builtins.removeAttrs env [ "nativeBuildInputs" ]) + ); - passthru.tests.get-version = result: - bootBash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/bash --version - mkdir $out - ''; + passthru.tests.get-version = + result: + bootBash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/bash --version + mkdir $out + ''; - meta = with lib; { - description = "GNU Bourne-Again Shell, the de facto standard shell on Linux"; - homepage = "https://www.gnu.org/software/bash"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - tar xzf ${src} - cd bash-${version} + meta = with lib; { + description = "GNU Bourne-Again Shell, the de facto standard shell on Linux"; + homepage = "https://www.gnu.org/software/bash"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + tar xzf ${src} + cd bash-${version} - # Patch - ${lib.concatMapStringsSep "\n" (f: "patch -Np1 -i ${f}") patches} + # Patch + ${lib.concatMapStringsSep "\n" (f: "patch -Np1 -i ${f}") patches} - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - export AR="tcc -ar" - export LD=tcc - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - --without-bash-malloc + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + export AR="tcc -ar" + export LD=tcc + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + --without-bash-malloc - # Build - make -j $NIX_BUILD_CORES SHELL=bash + # Build + make -j $NIX_BUILD_CORES SHELL=bash - # Install - make -j $NIX_BUILD_CORES install - ln -s bash $out/bin/sh -'' + # Install + make -j $NIX_BUILD_CORES install + ln -s bash $out/bin/sh + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/binutils/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/binutils/default.nix index 71e391efb55011..3292dd0528dd62 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/binutils/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/binutils/default.nix @@ -1,18 +1,19 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, coreutils -, gnumake -, gnupatch -, gnused -, gnugrep -, gawk -, diffutils -, gnutar -, xz -, tinycc +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + coreutils, + gnumake, + gnupatch, + gnused, + gnugrep, + gawk, + diffutils, + gnutar, + xz, + tinycc, }: let @@ -50,65 +51,68 @@ let "--with-lib-path=:" ]; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnupatch - gnused - gnugrep - gawk - diffutils - gnutar - xz - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnupatch + gnused + gnugrep + gawk + diffutils + gnutar + xz + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/ld --version - mkdir $out - ''; + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/ld --version + mkdir $out + ''; - meta = with lib; { - description = "Tools for manipulating binaries (linker, assembler, etc.)"; - homepage = "https://www.gnu.org/software/binutils"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - cp ${src} binutils.tar.xz - unxz binutils.tar.xz - tar xf binutils.tar - rm binutils.tar - cd binutils-${version} + meta = with lib; { + description = "Tools for manipulating binaries (linker, assembler, etc.)"; + homepage = "https://www.gnu.org/software/binutils"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + cp ${src} binutils.tar.xz + unxz binutils.tar.xz + tar xf binutils.tar + rm binutils.tar + cd binutils-${version} - # Patch - ${lib.concatMapStringsSep "\n" (f: "patch -Np1 -i ${f}") patches} - sed -i 's|/bin/sh|${bash}/bin/bash|' \ - missing install-sh mkinstalldirs - # see libtool's 74c8993c178a1386ea5e2363a01d919738402f30 - sed -i 's/| \$NL2SP/| sort | $NL2SP/' ltmain.sh - # alias makeinfo to true - mkdir aliases - ln -s ${coreutils}/bin/true aliases/makeinfo - export PATH="$(pwd)/aliases/:$PATH" + # Patch + ${lib.concatMapStringsSep "\n" (f: "patch -Np1 -i ${f}") patches} + sed -i 's|/bin/sh|${bash}/bin/bash|' \ + missing install-sh mkinstalldirs + # see libtool's 74c8993c178a1386ea5e2363a01d919738402f30 + sed -i 's/| \$NL2SP/| sort | $NL2SP/' ltmain.sh + # alias makeinfo to true + mkdir aliases + ln -s ${coreutils}/bin/true aliases/makeinfo + export PATH="$(pwd)/aliases/:$PATH" - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - export AR="tcc -ar" - export lt_cv_sys_max_cmd_len=32768 - export CFLAGS="-D__LITTLE_ENDIAN__=1" - bash ./configure ${lib.concatStringsSep " " configureFlags} + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + export AR="tcc -ar" + export lt_cv_sys_max_cmd_len=32768 + export CFLAGS="-D__LITTLE_ENDIAN__=1" + bash ./configure ${lib.concatStringsSep " " configureFlags} - # Build - make -j $NIX_BUILD_CORES all-libiberty all-gas all-bfd all-libctf all-zlib all-gprof - make all-ld # race condition on ld/.deps/ldwrite.Po, serialize - make -j $NIX_BUILD_CORES + # Build + make -j $NIX_BUILD_CORES all-libiberty all-gas all-bfd all-libctf all-zlib all-gprof + make all-ld # race condition on ld/.deps/ldwrite.Po, serialize + make -j $NIX_BUILD_CORES - # Install - make -j $NIX_BUILD_CORES install -'' + # Install + make -j $NIX_BUILD_CORES install + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/bzip2/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/bzip2/default.nix index 05da061ac263d8..ccceabe9a6e4fe 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/bzip2/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/bzip2/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchurl -, bash -, tinycc -, gnumake -, gnutar -, gzip +{ + lib, + fetchurl, + bash, + tinycc, + gnumake, + gnutar, + gzip, }: let pname = "bzip2"; @@ -15,41 +16,44 @@ let sha256 = "0s92986cv0p692icqlw1j42y9nld8zd83qwhzbqd61p1dqbh6nmb"; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnutar - gzip - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnutar + gzip + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/bzip2 --help - mkdir $out - ''; + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/bzip2 --help + mkdir $out + ''; - meta = with lib; { - description = "High-quality data compression program"; - homepage = "https://www.sourceware.org/bzip2"; - license = licenses.bsdOriginal; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - tar xzf ${src} - cd bzip2-${version} + meta = with lib; { + description = "High-quality data compression program"; + homepage = "https://www.sourceware.org/bzip2"; + license = licenses.bsdOriginal; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + tar xzf ${src} + cd bzip2-${version} - # Build - make \ - -j $NIX_BUILD_CORES \ - CC="tcc -B ${tinycc.libs}/lib" \ - AR="tcc -ar" \ - bzip2 bzip2recover + # Build + make \ + -j $NIX_BUILD_CORES \ + CC="tcc -B ${tinycc.libs}/lib" \ + AR="tcc -ar" \ + bzip2 bzip2recover - # Install - make install -j $NIX_BUILD_CORES PREFIX=$out -'' + # Install + make install -j $NIX_BUILD_CORES PREFIX=$out + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/coreutils/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/coreutils/default.nix index 1748c908e1a551..9edf6402fbed85 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/coreutils/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/coreutils/default.nix @@ -1,9 +1,10 @@ -{ lib -, fetchurl -, kaem -, tinycc -, gnumake -, gnupatch +{ + lib, + fetchurl, + kaem, + tinycc, + gnumake, + gnupatch, }: let pname = "bootstrap-coreutils"; @@ -70,48 +71,50 @@ let }) ]; in -kaem.runCommand "${pname}-${version}" { - inherit pname version; +kaem.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnupatch - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnupatch + ]; - meta = with lib; { - description = "GNU Core Utilities"; - homepage = "https://www.gnu.org/software/coreutils"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - ungz --file ${src} --output coreutils.tar - untar --file coreutils.tar - rm coreutils.tar - cd coreutils-${version} + meta = with lib; { + description = "GNU Core Utilities"; + homepage = "https://www.gnu.org/software/coreutils"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + ungz --file ${src} --output coreutils.tar + untar --file coreutils.tar + rm coreutils.tar + cd coreutils-${version} - # Patch - ${lib.concatMapStringsSep "\n" (f: "patch -Np0 -i ${f}") patches} + # Patch + ${lib.concatMapStringsSep "\n" (f: "patch -Np0 -i ${f}") patches} - # Configure - catm config.h - cp lib/fnmatch_.h lib/fnmatch.h - cp lib/ftw_.h lib/ftw.h - cp lib/search_.h lib/search.h - rm src/dircolors.h + # Configure + catm config.h + cp lib/fnmatch_.h lib/fnmatch.h + cp lib/ftw_.h lib/ftw.h + cp lib/search_.h lib/search.h + rm src/dircolors.h - # Build - make -f ${makefile} \ - CC="tcc -B ${tinycc.libs}/lib" \ - PREFIX=''${out} + # Build + make -f ${makefile} \ + CC="tcc -B ${tinycc.libs}/lib" \ + PREFIX=''${out} - # Check - ./src/echo "Hello coreutils!" + # Check + ./src/echo "Hello coreutils!" - # Install - ./src/mkdir -p ''${out}/bin - make -f ${makefile} install PREFIX=''${out} -'' + # Install + ./src/mkdir -p ''${out}/bin + make -f ${makefile} install PREFIX=''${out} + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/coreutils/musl.nix b/pkgs/os-specific/linux/minimal-bootstrap/coreutils/musl.nix index 9de71315fcc31e..b37e94a5f26327 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/coreutils/musl.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/coreutils/musl.nix @@ -1,15 +1,16 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, tinycc -, gnumake -, gnugrep -, gnused -, gawk -, gnutar -, gzip +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + tinycc, + gnumake, + gnugrep, + gnused, + gawk, + gnutar, + gzip, }: let pname = "bootstrap-coreutils-musl"; @@ -30,45 +31,48 @@ let "--enable-no-install-program=stdbuf" ]; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnused - gnugrep - gawk - gnutar - gzip - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnused + gnugrep + gawk + gnutar + gzip + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/cat --version - mkdir $out - ''; + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/cat --version + mkdir $out + ''; - meta = with lib; { - description = "GNU Core Utilities"; - homepage = "https://www.gnu.org/software/coreutils"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - tar xzf ${src} - cd coreutils-${version} + meta = with lib; { + description = "GNU Core Utilities"; + homepage = "https://www.gnu.org/software/coreutils"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + tar xzf ${src} + cd coreutils-${version} - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - export LD=tcc - bash ./configure ${lib.concatStringsSep " " configureFlags} + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + export LD=tcc + bash ./configure ${lib.concatStringsSep " " configureFlags} - # Build - make -j $NIX_BUILD_CORES AR="tcc -ar" MAKEINFO="true" + # Build + make -j $NIX_BUILD_CORES AR="tcc -ar" MAKEINFO="true" - # Install - make -j $NIX_BUILD_CORES install MAKEINFO="true" -'' + # Install + make -j $NIX_BUILD_CORES install MAKEINFO="true" + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/default.nix index d344b85a4d64b1..061727a470636f 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/default.nix @@ -1,229 +1,254 @@ -{ lib -, config -, buildPlatform -, hostPlatform -, fetchurl -, checkMeta +{ + lib, + config, + buildPlatform, + hostPlatform, + fetchurl, + checkMeta, }: lib.makeScope # Prevent using top-level attrs to protect against introducing dependency on # non-bootstrap packages by mistake. Any top-level inputs must be explicitly # declared here. - (extra: lib.callPackageWith ({ inherit lib config buildPlatform hostPlatform fetchurl checkMeta; } // extra)) - (self: with self; { - - bash_2_05 = callPackage ./bash/2.nix { tinycc = tinycc-mes; }; - - bash = callPackage ./bash { - bootBash = bash_2_05; - tinycc = tinycc-musl; - coreutils = coreutils-musl; - gnumake = gnumake-musl; - gnutar = gnutar-musl; - }; - - binutils = callPackage ./binutils { - tinycc = tinycc-musl; - gnumake = gnumake-musl; - gnutar = gnutar-musl; - }; - - bzip2 = callPackage ./bzip2 { - tinycc = tinycc-musl; - gnumake = gnumake-musl; - gnutar = gnutar-musl; - }; - - coreutils = callPackage ./coreutils { tinycc = tinycc-mes; }; - coreutils-musl = callPackage ./coreutils/musl.nix { - bash = bash_2_05; - tinycc = tinycc-musl; - gnumake = gnumake-musl; - gnutar = gnutar-musl; - }; - - diffutils = callPackage ./diffutils { - bash = bash_2_05; - tinycc = tinycc-musl; - gnumake = gnumake-musl; - gnutar = gnutar-musl; - }; - - findutils = callPackage ./findutils { - tinycc = tinycc-musl; - gnumake = gnumake-musl; - gnutar = gnutar-musl; - }; - - gawk-mes = callPackage ./gawk/mes.nix { - bash = bash_2_05; - tinycc = tinycc-mes; - gnused = gnused-mes; - }; - - gawk = callPackage ./gawk { - bash = bash_2_05; - tinycc = tinycc-musl; - gnumake = gnumake-musl; - gnutar = gnutar-musl; - bootGawk = gawk-mes; - }; - - gcc46 = callPackage ./gcc/4.6.nix { - tinycc = tinycc-musl; - gnumake = gnumake-musl; - gnutar = gnutar-musl; - # FIXME: not sure why new gawk doesn't work - gawk = gawk-mes; - }; - gcc46-cxx = callPackage ./gcc/4.6.cxx.nix { - gcc = gcc46; - gnumake = gnumake-musl; - gnutar = gnutar-musl; - # FIXME: not sure why new gawk doesn't work - gawk = gawk-mes; - }; - - gcc8 = callPackage ./gcc/8.nix { - gcc = gcc46-cxx; - gnumake = gnumake-musl; - gnutar = gnutar-latest; - # FIXME: not sure why new gawk doesn't work - gawk = gawk-mes; - }; - - gcc-latest = callPackage ./gcc/latest.nix { - gcc = gcc8; - gnumake = gnumake-musl; - gnutar = gnutar-latest; - # FIXME: not sure why new gawk doesn't work - gawk = gawk-mes; - }; - - gnugrep = callPackage ./gnugrep { - bash = bash_2_05; - tinycc = tinycc-mes; - }; - - gnumake = callPackage ./gnumake { tinycc = tinycc-mes; }; - - gnumake-musl = callPackage ./gnumake/musl.nix { - bash = bash_2_05; - tinycc = tinycc-musl; - gawk = gawk-mes; - gnumakeBoot = gnumake; - }; - - gnupatch = callPackage ./gnupatch { tinycc = tinycc-mes; }; - - gnused = callPackage ./gnused { - bash = bash_2_05; - tinycc = tinycc-musl; - gnused = gnused-mes; - }; - gnused-mes = callPackage ./gnused/mes.nix { - bash = bash_2_05; - tinycc = tinycc-mes; - }; - - gnutar = callPackage ./gnutar/mes.nix { - bash = bash_2_05; - tinycc = tinycc-mes; - gnused = gnused-mes; - }; - - gnutar-musl = callPackage ./gnutar/musl.nix { - bash = bash_2_05; - tinycc = tinycc-musl; - gnused = gnused-mes; - }; - - # FIXME: better package naming scheme - gnutar-latest = callPackage ./gnutar/latest.nix { - gcc = gcc46; - gnumake = gnumake-musl; - gnutarBoot = gnutar-musl; - }; - - gzip = callPackage ./gzip { - bash = bash_2_05; - tinycc = tinycc-mes; - gnused = gnused-mes; - }; - - heirloom = callPackage ./heirloom { - bash = bash_2_05; - tinycc = tinycc-mes; - }; - - heirloom-devtools = callPackage ./heirloom-devtools { tinycc = tinycc-mes; }; - - linux-headers = callPackage ./linux-headers { bash = bash_2_05; }; - - ln-boot = callPackage ./ln-boot { }; - - mes = callPackage ./mes { }; - mes-libc = callPackage ./mes/libc.nix { }; - - musl11 = callPackage ./musl/1.1.nix { - bash = bash_2_05; - tinycc = tinycc-mes; - gnused = gnused-mes; - }; - - musl = callPackage ./musl { - gcc = gcc46; - gnumake = gnumake-musl; - }; - - stage0-posix = callPackage ./stage0-posix { }; - - inherit (self.stage0-posix) kaem m2libc mescc-tools mescc-tools-extra; - - tinycc-bootstrappable = lib.recurseIntoAttrs (callPackage ./tinycc/bootstrappable.nix { }); - tinycc-mes = lib.recurseIntoAttrs (callPackage ./tinycc/mes.nix { }); - tinycc-musl = lib.recurseIntoAttrs (callPackage ./tinycc/musl.nix { - bash = bash_2_05; - musl = musl11; - }); - - xz = callPackage ./xz { - bash = bash_2_05; - tinycc = tinycc-musl; - gnumake = gnumake-musl; - gnutar = gnutar-musl; - }; - - inherit (callPackage ./utils.nix { }) derivationWithMeta writeTextFile writeText; - - test = kaem.runCommand "minimal-bootstrap-test" {} '' - echo ${bash.tests.get-version} - echo ${bash_2_05.tests.get-version} - echo ${binutils.tests.get-version} - echo ${bzip2.tests.get-version} - echo ${coreutils-musl.tests.get-version} - echo ${diffutils.tests.get-version} - echo ${findutils.tests.get-version} - echo ${gawk-mes.tests.get-version} - echo ${gawk.tests.get-version} - echo ${gcc46.tests.get-version} - echo ${gcc46-cxx.tests.hello-world} - echo ${gcc8.tests.hello-world} - echo ${gcc-latest.tests.hello-world} - echo ${gnugrep.tests.get-version} - echo ${gnused.tests.get-version} - echo ${gnused-mes.tests.get-version} - echo ${gnutar.tests.get-version} - echo ${gnutar-musl.tests.get-version} - echo ${gnutar-latest.tests.get-version} - echo ${gzip.tests.get-version} - echo ${heirloom.tests.get-version} - echo ${mes.compiler.tests.get-version} - echo ${musl.tests.hello-world} - echo ${tinycc-mes.compiler.tests.chain} - echo ${tinycc-musl.compiler.tests.hello-world} - echo ${xz.tests.get-version} - mkdir ''${out} - ''; - }) + ( + extra: + lib.callPackageWith ( + { + inherit + lib + config + buildPlatform + hostPlatform + fetchurl + checkMeta + ; + } + // extra + ) + ) + ( + self: with self; { + + bash_2_05 = callPackage ./bash/2.nix { tinycc = tinycc-mes; }; + + bash = callPackage ./bash { + bootBash = bash_2_05; + tinycc = tinycc-musl; + coreutils = coreutils-musl; + gnumake = gnumake-musl; + gnutar = gnutar-musl; + }; + + binutils = callPackage ./binutils { + tinycc = tinycc-musl; + gnumake = gnumake-musl; + gnutar = gnutar-musl; + }; + + bzip2 = callPackage ./bzip2 { + tinycc = tinycc-musl; + gnumake = gnumake-musl; + gnutar = gnutar-musl; + }; + + coreutils = callPackage ./coreutils { tinycc = tinycc-mes; }; + coreutils-musl = callPackage ./coreutils/musl.nix { + bash = bash_2_05; + tinycc = tinycc-musl; + gnumake = gnumake-musl; + gnutar = gnutar-musl; + }; + + diffutils = callPackage ./diffutils { + bash = bash_2_05; + tinycc = tinycc-musl; + gnumake = gnumake-musl; + gnutar = gnutar-musl; + }; + + findutils = callPackage ./findutils { + tinycc = tinycc-musl; + gnumake = gnumake-musl; + gnutar = gnutar-musl; + }; + + gawk-mes = callPackage ./gawk/mes.nix { + bash = bash_2_05; + tinycc = tinycc-mes; + gnused = gnused-mes; + }; + + gawk = callPackage ./gawk { + bash = bash_2_05; + tinycc = tinycc-musl; + gnumake = gnumake-musl; + gnutar = gnutar-musl; + bootGawk = gawk-mes; + }; + + gcc46 = callPackage ./gcc/4.6.nix { + tinycc = tinycc-musl; + gnumake = gnumake-musl; + gnutar = gnutar-musl; + # FIXME: not sure why new gawk doesn't work + gawk = gawk-mes; + }; + gcc46-cxx = callPackage ./gcc/4.6.cxx.nix { + gcc = gcc46; + gnumake = gnumake-musl; + gnutar = gnutar-musl; + # FIXME: not sure why new gawk doesn't work + gawk = gawk-mes; + }; + + gcc8 = callPackage ./gcc/8.nix { + gcc = gcc46-cxx; + gnumake = gnumake-musl; + gnutar = gnutar-latest; + # FIXME: not sure why new gawk doesn't work + gawk = gawk-mes; + }; + + gcc-latest = callPackage ./gcc/latest.nix { + gcc = gcc8; + gnumake = gnumake-musl; + gnutar = gnutar-latest; + # FIXME: not sure why new gawk doesn't work + gawk = gawk-mes; + }; + + gnugrep = callPackage ./gnugrep { + bash = bash_2_05; + tinycc = tinycc-mes; + }; + + gnumake = callPackage ./gnumake { tinycc = tinycc-mes; }; + + gnumake-musl = callPackage ./gnumake/musl.nix { + bash = bash_2_05; + tinycc = tinycc-musl; + gawk = gawk-mes; + gnumakeBoot = gnumake; + }; + + gnupatch = callPackage ./gnupatch { tinycc = tinycc-mes; }; + + gnused = callPackage ./gnused { + bash = bash_2_05; + tinycc = tinycc-musl; + gnused = gnused-mes; + }; + gnused-mes = callPackage ./gnused/mes.nix { + bash = bash_2_05; + tinycc = tinycc-mes; + }; + + gnutar = callPackage ./gnutar/mes.nix { + bash = bash_2_05; + tinycc = tinycc-mes; + gnused = gnused-mes; + }; + + gnutar-musl = callPackage ./gnutar/musl.nix { + bash = bash_2_05; + tinycc = tinycc-musl; + gnused = gnused-mes; + }; + + # FIXME: better package naming scheme + gnutar-latest = callPackage ./gnutar/latest.nix { + gcc = gcc46; + gnumake = gnumake-musl; + gnutarBoot = gnutar-musl; + }; + + gzip = callPackage ./gzip { + bash = bash_2_05; + tinycc = tinycc-mes; + gnused = gnused-mes; + }; + + heirloom = callPackage ./heirloom { + bash = bash_2_05; + tinycc = tinycc-mes; + }; + + heirloom-devtools = callPackage ./heirloom-devtools { tinycc = tinycc-mes; }; + + linux-headers = callPackage ./linux-headers { bash = bash_2_05; }; + + ln-boot = callPackage ./ln-boot { }; + + mes = callPackage ./mes { }; + mes-libc = callPackage ./mes/libc.nix { }; + + musl11 = callPackage ./musl/1.1.nix { + bash = bash_2_05; + tinycc = tinycc-mes; + gnused = gnused-mes; + }; + + musl = callPackage ./musl { + gcc = gcc46; + gnumake = gnumake-musl; + }; + + stage0-posix = callPackage ./stage0-posix { }; + + inherit (self.stage0-posix) + kaem + m2libc + mescc-tools + mescc-tools-extra + ; + + tinycc-bootstrappable = lib.recurseIntoAttrs (callPackage ./tinycc/bootstrappable.nix { }); + tinycc-mes = lib.recurseIntoAttrs (callPackage ./tinycc/mes.nix { }); + tinycc-musl = lib.recurseIntoAttrs ( + callPackage ./tinycc/musl.nix { + bash = bash_2_05; + musl = musl11; + } + ); + + xz = callPackage ./xz { + bash = bash_2_05; + tinycc = tinycc-musl; + gnumake = gnumake-musl; + gnutar = gnutar-musl; + }; + + inherit (callPackage ./utils.nix { }) derivationWithMeta writeTextFile writeText; + + test = kaem.runCommand "minimal-bootstrap-test" { } '' + echo ${bash.tests.get-version} + echo ${bash_2_05.tests.get-version} + echo ${binutils.tests.get-version} + echo ${bzip2.tests.get-version} + echo ${coreutils-musl.tests.get-version} + echo ${diffutils.tests.get-version} + echo ${findutils.tests.get-version} + echo ${gawk-mes.tests.get-version} + echo ${gawk.tests.get-version} + echo ${gcc46.tests.get-version} + echo ${gcc46-cxx.tests.hello-world} + echo ${gcc8.tests.hello-world} + echo ${gcc-latest.tests.hello-world} + echo ${gnugrep.tests.get-version} + echo ${gnused.tests.get-version} + echo ${gnused-mes.tests.get-version} + echo ${gnutar.tests.get-version} + echo ${gnutar-musl.tests.get-version} + echo ${gnutar-latest.tests.get-version} + echo ${gzip.tests.get-version} + echo ${heirloom.tests.get-version} + echo ${mes.compiler.tests.get-version} + echo ${musl.tests.hello-world} + echo ${tinycc-mes.compiler.tests.chain} + echo ${tinycc-musl.compiler.tests.hello-world} + echo ${xz.tests.get-version} + mkdir ''${out} + ''; + } + ) diff --git a/pkgs/os-specific/linux/minimal-bootstrap/diffutils/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/diffutils/default.nix index 24cd643b34972f..e6648b5987beec 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/diffutils/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/diffutils/default.nix @@ -1,15 +1,16 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, tinycc -, gnumake -, gnugrep -, gnused -, gawk -, gnutar -, xz +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + tinycc, + gnumake, + gnugrep, + gnused, + gawk, + gnutar, + xz, }: let pname = "diffutils"; @@ -21,51 +22,54 @@ let hash = "sha256-pr3X0bMSZtEcT03mwbdI1GB6sCMa9RiPwlM9CuJDj+w="; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnused - gnugrep - gawk - gnutar - xz - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnused + gnugrep + gawk + gnutar + xz + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/diff --version - mkdir $out - ''; + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/diff --version + mkdir $out + ''; - meta = with lib; { - description = "Commands for showing the differences between files (diff, cmp, etc.)"; - homepage = "https://www.gnu.org/software/diffutils/diffutils.html"; - license = licenses.gpl3Only; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - cp ${src} diffutils.tar.xz - unxz diffutils.tar.xz - tar xf diffutils.tar - rm diffutils.tar - cd diffutils-${version} + meta = with lib; { + description = "Commands for showing the differences between files (diff, cmp, etc.)"; + homepage = "https://www.gnu.org/software/diffutils/diffutils.html"; + license = licenses.gpl3Only; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + cp ${src} diffutils.tar.xz + unxz diffutils.tar.xz + tar xf diffutils.tar + rm diffutils.tar + cd diffutils-${version} - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - export LD=tcc - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + export LD=tcc + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} - # Build - make -j $NIX_BUILD_CORES AR="tcc -ar" + # Build + make -j $NIX_BUILD_CORES AR="tcc -ar" - # Install - make -j $NIX_BUILD_CORES install -'' + # Install + make -j $NIX_BUILD_CORES install + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/findutils/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/findutils/default.nix index 97418d218fb92a..d731ee8037e41c 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/findutils/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/findutils/default.nix @@ -1,15 +1,16 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, tinycc -, gnumake -, gnugrep -, gnused -, gawk -, gnutar -, xz +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + tinycc, + gnumake, + gnugrep, + gnused, + gawk, + gnutar, + xz, }: let pname = "findutils"; @@ -20,56 +21,59 @@ let hash = "sha256-or+4wJ1DZ3DtxZ9Q+kg+eFsWGjt7nVR1c8sIBl/UYv4="; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnused - gnugrep - gawk - gnutar - xz - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnused + gnugrep + gawk + gnutar + xz + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/find --version - mkdir $out - ''; + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/find --version + mkdir $out + ''; - meta = with lib; { - description = "GNU Find Utilities, the basic directory searching utilities of the GNU operating system"; - homepage = "https://www.gnu.org/software/findutils"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - cp ${src} findutils.tar.xz - unxz findutils.tar.xz - tar xf findutils.tar - rm findutils.tar - cd findutils-${version} + meta = with lib; { + description = "GNU Find Utilities, the basic directory searching utilities of the GNU operating system"; + homepage = "https://www.gnu.org/software/findutils"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + cp ${src} findutils.tar.xz + unxz findutils.tar.xz + tar xf findutils.tar + rm findutils.tar + cd findutils-${version} - # Patch - # configure fails to accurately detect PATH_MAX support - sed -i 's/chdir_long/chdir/' gl/lib/save-cwd.c + # Patch + # configure fails to accurately detect PATH_MAX support + sed -i 's/chdir_long/chdir/' gl/lib/save-cwd.c - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - export AR="tcc -ar" - export LD=tcc - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + export AR="tcc -ar" + export LD=tcc + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} - # Build - make -j $NIX_BUILD_CORES + # Build + make -j $NIX_BUILD_CORES - # Install - make -j $NIX_BUILD_CORES install -'' + # Install + make -j $NIX_BUILD_CORES install + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gawk/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/gawk/default.nix index 879b98bf00c547..e76aee2efa8871 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gawk/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gawk/default.nix @@ -1,15 +1,16 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, tinycc -, gnumake -, gnugrep -, gnused -, gnutar -, gzip -, bootGawk +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + tinycc, + gnumake, + gnugrep, + gnused, + gnutar, + gzip, + bootGawk, }: let inherit (import ./common.nix { inherit lib; }) meta; @@ -21,41 +22,44 @@ let hash = "sha256-lFrvfM/xAfILIqEIArwAXplKsrjqPnJMwaGXxi9B9lA="; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version meta; +bash.runCommand "${pname}-${version}" + { + inherit pname version meta; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnused - gnugrep - gnutar - gzip - bootGawk - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnused + gnugrep + gnutar + gzip + bootGawk + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/awk --version - mkdir $out - ''; -} '' - # Unpack - tar xzf ${src} - cd gawk-${version} + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/awk --version + mkdir $out + ''; + } + '' + # Unpack + tar xzf ${src} + cd gawk-${version} - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - export AR="tcc -ar" - export LD=tcc - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + export AR="tcc -ar" + export LD=tcc + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} - # Build - make -j $NIX_BUILD_CORES + # Build + make -j $NIX_BUILD_CORES - # Install - make -j $NIX_BUILD_CORES install -'' + # Install + make -j $NIX_BUILD_CORES install + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gawk/mes.nix b/pkgs/os-specific/linux/minimal-bootstrap/gawk/mes.nix index c14399309306f4..ed9b88213a102a 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gawk/mes.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gawk/mes.nix @@ -1,13 +1,14 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, tinycc -, gnumake -, gnupatch -, gnused -, gnugrep +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + tinycc, + gnumake, + gnupatch, + gnused, + gnugrep, }: let inherit (import ./common.nix { inherit lib; }) meta; @@ -25,46 +26,49 @@ let ./no-stamp.patch ]; in -bash.runCommand "${pname}-${version}" { - inherit pname version meta; +bash.runCommand "${pname}-${version}" + { + inherit pname version meta; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnupatch - gnused - gnugrep - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnupatch + gnused + gnugrep + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/awk --version - mkdir $out - ''; -} '' - # Unpack - ungz --file ${src} --output gawk.tar - untar --file gawk.tar - rm gawk.tar - cd gawk-${version} + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/awk --version + mkdir $out + ''; + } + '' + # Unpack + ungz --file ${src} --output gawk.tar + untar --file gawk.tar + rm gawk.tar + cd gawk-${version} - # Patch - ${lib.concatMapStringsSep "\n" (f: "patch -Np0 -i ${f}") patches} + # Patch + ${lib.concatMapStringsSep "\n" (f: "patch -Np0 -i ${f}") patches} - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - export ac_cv_func_getpgrp_void=yes - export ac_cv_func_tzset=yes - bash ./configure \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - --disable-nls \ - --prefix=$out + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + export ac_cv_func_getpgrp_void=yes + export ac_cv_func_tzset=yes + bash ./configure \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + --disable-nls \ + --prefix=$out - # Build - make gawk + # Build + make gawk - # Install - install -D gawk $out/bin/gawk - ln -s gawk $out/bin/awk -'' + # Install + install -D gawk $out/bin/gawk + ln -s gawk $out/bin/awk + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gcc/4.6.cxx.nix b/pkgs/os-specific/linux/minimal-bootstrap/gcc/4.6.cxx.nix index 277c5e82cc3dc3..f4f8ee6a230164 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gcc/4.6.cxx.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gcc/4.6.cxx.nix @@ -1,21 +1,22 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, coreutils -, gcc -, musl -, binutils -, gnumake -, gnupatch -, gnused -, gnugrep -, gawk -, diffutils -, findutils -, gnutar -, gzip +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + coreutils, + gcc, + musl, + binutils, + gnumake, + gnupatch, + gnused, + gnugrep, + gawk, + diffutils, + findutils, + gnutar, + gzip, }: let pname = "gcc-cxx"; @@ -54,87 +55,96 @@ let ./no-system-headers.patch ]; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - gcc - binutils - gnumake - gnupatch - gnused - gnugrep - gawk - diffutils - findutils - gnutar - gzip - ]; + nativeBuildInputs = [ + gcc + binutils + gnumake + gnupatch + gnused + gnugrep + gawk + diffutils + findutils + gnutar + gzip + ]; - passthru.tests.hello-world = result: - bash.runCommand "${pname}-simple-program-${version}" { - nativeBuildInputs = [ binutils musl result ]; - } '' - cat <> test.c - #include - int main() { - printf("Hello World!\n"); - return 0; + passthru.tests.hello-world = + result: + bash.runCommand "${pname}-simple-program-${version}" + { + nativeBuildInputs = [ + binutils + musl + result + ]; } - EOF - musl-gcc -o test test.c - ./test - mkdir $out - ''; + '' + cat <> test.c + #include + int main() { + printf("Hello World!\n"); + return 0; + } + EOF + musl-gcc -o test test.c + ./test + mkdir $out + ''; - meta = with lib; { - description = "GNU Compiler Collection, version ${version}"; - homepage = "https://gcc.gnu.org"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - tar xzf ${src} - tar xzf ${ccSrc} - tar xzf ${gmp} - tar xzf ${mpfr} - tar xzf ${mpc} - cd gcc-${version} + meta = with lib; { + description = "GNU Compiler Collection, version ${version}"; + homepage = "https://gcc.gnu.org"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + tar xzf ${src} + tar xzf ${ccSrc} + tar xzf ${gmp} + tar xzf ${mpfr} + tar xzf ${mpc} + cd gcc-${version} - ln -s ../gmp-${gmpVersion} gmp - ln -s ../mpfr-${mpfrVersion} mpfr - ln -s ../mpc-${mpcVersion} mpc + ln -s ../gmp-${gmpVersion} gmp + ln -s ../mpfr-${mpfrVersion} mpfr + ln -s ../mpc-${mpcVersion} mpc - # Patch - ${lib.concatMapStringsSep "\n" (f: "patch -Np1 -i ${f}") patches} - # doesn't recognise musl - sed -i 's|"os/gnu-linux"|"os/generic"|' libstdc++-v3/configure.host + # Patch + ${lib.concatMapStringsSep "\n" (f: "patch -Np1 -i ${f}") patches} + # doesn't recognise musl + sed -i 's|"os/gnu-linux"|"os/generic"|' libstdc++-v3/configure.host - # Configure - export CC="gcc -Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" - export CFLAGS_FOR_TARGET="-Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" - export C_INCLUDE_PATH="${musl}/include" - export CPLUS_INCLUDE_PATH="$C_INCLUDE_PATH" - export LIBRARY_PATH="${musl}/lib" + # Configure + export CC="gcc -Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" + export CFLAGS_FOR_TARGET="-Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" + export C_INCLUDE_PATH="${musl}/include" + export CPLUS_INCLUDE_PATH="$C_INCLUDE_PATH" + export LIBRARY_PATH="${musl}/lib" - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - --with-native-system-header-dir=${musl}/include \ - --with-build-sysroot=${musl} \ - --enable-languages=c,c++ \ - --disable-bootstrap \ - --disable-libmudflap \ - --disable-libstdcxx-pch \ - --disable-lto \ - --disable-multilib + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + --with-native-system-header-dir=${musl}/include \ + --with-build-sysroot=${musl} \ + --enable-languages=c,c++ \ + --disable-bootstrap \ + --disable-libmudflap \ + --disable-libstdcxx-pch \ + --disable-lto \ + --disable-multilib - # Build - make -j $NIX_BUILD_CORES + # Build + make -j $NIX_BUILD_CORES - # Install - make -j $NIX_BUILD_CORES install -'' + # Install + make -j $NIX_BUILD_CORES install + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gcc/4.6.nix b/pkgs/os-specific/linux/minimal-bootstrap/gcc/4.6.nix index 8b56dff58829c8..4a2ea3fd84ab8c 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gcc/4.6.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gcc/4.6.nix @@ -1,19 +1,20 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, tinycc -, binutils -, gnumake -, gnupatch -, gnused -, gnugrep -, gawk -, diffutils -, findutils -, gnutar -, gzip +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + tinycc, + binutils, + gnumake, + gnupatch, + gnused, + gnugrep, + gawk, + diffutils, + findutils, + gnutar, + gzip, }: let pname = "gcc"; @@ -52,94 +53,97 @@ let ./no-system-headers.patch ]; in -bash.runCommand "${pname}-${version}" { - inherit pname version; - - nativeBuildInputs = [ - tinycc.compiler - binutils - gnumake - gnupatch - gnused - gnugrep - gawk - diffutils - findutils - gnutar - gzip - ]; - - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/gcc --version - mkdir $out - ''; - - meta = with lib; { - description = "GNU Compiler Collection, version ${version}"; - homepage = "https://gcc.gnu.org"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - tar xzf ${src} - tar xzf ${ccSrc} - tar xzf ${gmp} - tar xzf ${mpfr} - tar xzf ${mpc} - cd gcc-${version} - - ln -s ../gmp-${gmpVersion} gmp - ln -s ../mpfr-${mpfrVersion} mpfr - ln -s ../mpc-${mpcVersion} mpc - - # Patch - ${lib.concatMapStringsSep "\n" (f: "patch -Np1 -i ${f}") patches} - - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - export C_INCLUDE_PATH="${tinycc.libs}/include:$(pwd)/mpfr/src" - export CPLUS_INCLUDE_PATH="$C_INCLUDE_PATH" - - # Avoid "Link tests are not allowed after GCC_NO_EXECUTABLES" - export lt_cv_shlibpath_overrides_runpath=yes - export ac_cv_func_memcpy=yes - export ac_cv_func_strerror=yes - - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - --with-native-system-header-dir=${tinycc.libs}/include \ - --with-build-sysroot=${tinycc.libs}/include \ - --disable-bootstrap \ - --disable-decimal-float \ - --disable-libatomic \ - --disable-libcilkrts \ - --disable-libgomp \ - --disable-libitm \ - --disable-libmudflap \ - --disable-libquadmath \ - --disable-libsanitizer \ - --disable-libssp \ - --disable-libvtv \ - --disable-lto \ - --disable-lto-plugin \ - --disable-multilib \ - --disable-plugin \ - --disable-threads \ - --enable-languages=c \ - --enable-static \ - --disable-shared \ - --enable-threads=single \ - --disable-libstdcxx-pch \ - --disable-build-with-cxx - - # Build - make -j $NIX_BUILD_CORES - - # Install - make -j $NIX_BUILD_CORES install -'' +bash.runCommand "${pname}-${version}" + { + inherit pname version; + + nativeBuildInputs = [ + tinycc.compiler + binutils + gnumake + gnupatch + gnused + gnugrep + gawk + diffutils + findutils + gnutar + gzip + ]; + + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/gcc --version + mkdir $out + ''; + + meta = with lib; { + description = "GNU Compiler Collection, version ${version}"; + homepage = "https://gcc.gnu.org"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + tar xzf ${src} + tar xzf ${ccSrc} + tar xzf ${gmp} + tar xzf ${mpfr} + tar xzf ${mpc} + cd gcc-${version} + + ln -s ../gmp-${gmpVersion} gmp + ln -s ../mpfr-${mpfrVersion} mpfr + ln -s ../mpc-${mpcVersion} mpc + + # Patch + ${lib.concatMapStringsSep "\n" (f: "patch -Np1 -i ${f}") patches} + + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + export C_INCLUDE_PATH="${tinycc.libs}/include:$(pwd)/mpfr/src" + export CPLUS_INCLUDE_PATH="$C_INCLUDE_PATH" + + # Avoid "Link tests are not allowed after GCC_NO_EXECUTABLES" + export lt_cv_shlibpath_overrides_runpath=yes + export ac_cv_func_memcpy=yes + export ac_cv_func_strerror=yes + + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + --with-native-system-header-dir=${tinycc.libs}/include \ + --with-build-sysroot=${tinycc.libs}/include \ + --disable-bootstrap \ + --disable-decimal-float \ + --disable-libatomic \ + --disable-libcilkrts \ + --disable-libgomp \ + --disable-libitm \ + --disable-libmudflap \ + --disable-libquadmath \ + --disable-libsanitizer \ + --disable-libssp \ + --disable-libvtv \ + --disable-lto \ + --disable-lto-plugin \ + --disable-multilib \ + --disable-plugin \ + --disable-threads \ + --enable-languages=c \ + --enable-static \ + --disable-shared \ + --enable-threads=single \ + --disable-libstdcxx-pch \ + --disable-build-with-cxx + + # Build + make -j $NIX_BUILD_CORES + + # Install + make -j $NIX_BUILD_CORES install + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gcc/8.nix b/pkgs/os-specific/linux/minimal-bootstrap/gcc/8.nix index ea9fdaf8854a27..7a158ff8f4362b 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gcc/8.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gcc/8.nix @@ -1,22 +1,23 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, coreutils -, gcc -, musl -, binutils -, gnumake -, gnused -, gnugrep -, gawk -, diffutils -, findutils -, gnutar -, gzip -, bzip2 -, xz +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + coreutils, + gcc, + musl, + binutils, + gnumake, + gnused, + gnugrep, + gawk, + diffutils, + findutils, + gnutar, + gzip, + bzip2, + xz, }: let pname = "gcc"; @@ -52,90 +53,99 @@ let hash = "sha256-/PeN2WVsEOuM+fvV9ZoLawE4YgX+GTSzsoegoYmBRcA="; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - gcc - binutils - gnumake - gnused - gnugrep - gawk - diffutils - findutils - gnutar - gzip - bzip2 - xz - ]; + nativeBuildInputs = [ + gcc + binutils + gnumake + gnused + gnugrep + gawk + diffutils + findutils + gnutar + gzip + bzip2 + xz + ]; - passthru.tests.hello-world = result: - bash.runCommand "${pname}-simple-program-${version}" { - nativeBuildInputs = [ binutils musl result ]; - } '' - cat <> test.c - #include - int main() { - printf("Hello World!\n"); - return 0; + passthru.tests.hello-world = + result: + bash.runCommand "${pname}-simple-program-${version}" + { + nativeBuildInputs = [ + binutils + musl + result + ]; } - EOF - musl-gcc -o test test.c - ./test - mkdir $out - ''; + '' + cat <> test.c + #include + int main() { + printf("Hello World!\n"); + return 0; + } + EOF + musl-gcc -o test test.c + ./test + mkdir $out + ''; - meta = with lib; { - description = "GNU Compiler Collection, version ${version}"; - homepage = "https://gcc.gnu.org"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - tar xf ${src} - tar xf ${gmp} - tar xf ${mpfr} - tar xf ${mpc} - tar xf ${isl} - cd gcc-${version} + meta = with lib; { + description = "GNU Compiler Collection, version ${version}"; + homepage = "https://gcc.gnu.org"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + tar xf ${src} + tar xf ${gmp} + tar xf ${mpfr} + tar xf ${mpc} + tar xf ${isl} + cd gcc-${version} - ln -s ../gmp-${gmpVersion} gmp - ln -s ../mpfr-${mpfrVersion} mpfr - ln -s ../mpc-${mpcVersion} mpc - ln -s ../isl-${islVersion} isl + ln -s ../gmp-${gmpVersion} gmp + ln -s ../mpfr-${mpfrVersion} mpfr + ln -s ../mpc-${mpcVersion} mpc + ln -s ../isl-${islVersion} isl - # Patch - # doesn't recognise musl - sed -i 's|"os/gnu-linux"|"os/generic"|' libstdc++-v3/configure.host + # Patch + # doesn't recognise musl + sed -i 's|"os/gnu-linux"|"os/generic"|' libstdc++-v3/configure.host - # Configure - export CC="gcc -Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" - export CXX="g++ -Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" - export CFLAGS_FOR_TARGET="-Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" - export C_INCLUDE_PATH="${musl}/include" - export CPLUS_INCLUDE_PATH="$C_INCLUDE_PATH" - export LIBRARY_PATH="${musl}/lib" + # Configure + export CC="gcc -Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" + export CXX="g++ -Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" + export CFLAGS_FOR_TARGET="-Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" + export C_INCLUDE_PATH="${musl}/include" + export CPLUS_INCLUDE_PATH="$C_INCLUDE_PATH" + export LIBRARY_PATH="${musl}/lib" - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - --with-native-system-header-dir=/include \ - --with-sysroot=${musl} \ - --enable-languages=c,c++ \ - --disable-bootstrap \ - --disable-libmpx \ - --disable-libsanitizer \ - --disable-lto \ - --disable-multilib \ - --disable-plugin + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + --with-native-system-header-dir=/include \ + --with-sysroot=${musl} \ + --enable-languages=c,c++ \ + --disable-bootstrap \ + --disable-libmpx \ + --disable-libsanitizer \ + --disable-lto \ + --disable-multilib \ + --disable-plugin - # Build - make -j $NIX_BUILD_CORES + # Build + make -j $NIX_BUILD_CORES - # Install - make -j $NIX_BUILD_CORES install-strip -'' + # Install + make -j $NIX_BUILD_CORES install-strip + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gcc/latest.nix b/pkgs/os-specific/linux/minimal-bootstrap/gcc/latest.nix index fba3b731a00485..f22570e940caf2 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gcc/latest.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gcc/latest.nix @@ -1,22 +1,23 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, coreutils -, gcc -, musl -, binutils -, gnumake -, gnused -, gnugrep -, gawk -, diffutils -, findutils -, gnutar -, gzip -, bzip2 -, xz +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + coreutils, + gcc, + musl, + binutils, + gnumake, + gnused, + gnugrep, + gawk, + diffutils, + findutils, + gnutar, + gzip, + bzip2, + xz, }: let pname = "gcc"; @@ -51,87 +52,96 @@ let hash = "sha256-/PeN2WVsEOuM+fvV9ZoLawE4YgX+GTSzsoegoYmBRcA="; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - gcc - binutils - gnumake - gnused - gnugrep - gawk - diffutils - findutils - gnutar - gzip - bzip2 - xz - ]; + nativeBuildInputs = [ + gcc + binutils + gnumake + gnused + gnugrep + gawk + diffutils + findutils + gnutar + gzip + bzip2 + xz + ]; - passthru.tests.hello-world = result: - bash.runCommand "${pname}-simple-program-${version}" { - nativeBuildInputs = [ binutils musl result ]; - } '' - cat <> test.c - #include - int main() { - printf("Hello World!\n"); - return 0; + passthru.tests.hello-world = + result: + bash.runCommand "${pname}-simple-program-${version}" + { + nativeBuildInputs = [ + binutils + musl + result + ]; } - EOF - musl-gcc -o test test.c - ./test - mkdir $out - ''; + '' + cat <> test.c + #include + int main() { + printf("Hello World!\n"); + return 0; + } + EOF + musl-gcc -o test test.c + ./test + mkdir $out + ''; - meta = with lib; { - description = "GNU Compiler Collection, version ${version}"; - homepage = "https://gcc.gnu.org"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - tar xf ${src} - tar xf ${gmp} - tar xf ${mpfr} - tar xf ${mpc} - tar xf ${isl} - cd gcc-${version} + meta = with lib; { + description = "GNU Compiler Collection, version ${version}"; + homepage = "https://gcc.gnu.org"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + tar xf ${src} + tar xf ${gmp} + tar xf ${mpfr} + tar xf ${mpc} + tar xf ${isl} + cd gcc-${version} - ln -s ../gmp-${gmpVersion} gmp - ln -s ../mpfr-${mpfrVersion} mpfr - ln -s ../mpc-${mpcVersion} mpc - ln -s ../isl-${islVersion} isl + ln -s ../gmp-${gmpVersion} gmp + ln -s ../mpfr-${mpfrVersion} mpfr + ln -s ../mpc-${mpcVersion} mpc + ln -s ../isl-${islVersion} isl - # Patch - # force musl even if host triple is gnu - sed -i 's|"os/gnu-linux"|"os/generic"|' libstdc++-v3/configure.host + # Patch + # force musl even if host triple is gnu + sed -i 's|"os/gnu-linux"|"os/generic"|' libstdc++-v3/configure.host - # Configure - export CC="gcc -Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" - export CXX="g++ -Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" - export CFLAGS_FOR_TARGET="-Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" - export LIBRARY_PATH="${musl}/lib" + # Configure + export CC="gcc -Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" + export CXX="g++ -Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" + export CFLAGS_FOR_TARGET="-Wl,-dynamic-linker -Wl,${musl}/lib/libc.so" + export LIBRARY_PATH="${musl}/lib" - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - --with-native-system-header-dir=/include \ - --with-sysroot=${musl} \ - --enable-languages=c,c++ \ - --disable-bootstrap \ - --disable-libsanitizer \ - --disable-lto \ - --disable-multilib \ - --disable-plugin + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + --with-native-system-header-dir=/include \ + --with-sysroot=${musl} \ + --enable-languages=c,c++ \ + --disable-bootstrap \ + --disable-libsanitizer \ + --disable-lto \ + --disable-multilib \ + --disable-plugin - # Build - make -j $NIX_BUILD_CORES + # Build + make -j $NIX_BUILD_CORES - # Install - make -j $NIX_BUILD_CORES install-strip -'' + # Install + make -j $NIX_BUILD_CORES install-strip + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gnugrep/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/gnugrep/default.nix index b2899961dfa2d4..62dd295eefe872 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gnugrep/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gnugrep/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchurl -, bash -, tinycc -, gnumake +{ + lib, + fetchurl, + bash, + tinycc, + gnumake, }: let pname = "gnugrep"; @@ -20,41 +21,44 @@ let sha256 = "08an9ljlqry3p15w28hahm6swnd3jxizsd2188przvvsj093j91k"; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version; - - nativeBuildInputs = [ - tinycc.compiler - gnumake - ]; - - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/grep --version - mkdir ''${out} - ''; - - meta = with lib; { - description = "GNU implementation of the Unix grep command"; - homepage = "https://www.gnu.org/software/grep"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - mainProgram = "grep"; - platforms = platforms.unix; - }; -} '' - # Unpack - ungz --file ${src} --output grep.tar - untar --file grep.tar - rm grep.tar - cd grep-${version} - - # Configure - cp ${makefile} Makefile - - # Build - make CC="tcc -B ${tinycc.libs}/lib" - - # Install - make install PREFIX=$out -'' +bash.runCommand "${pname}-${version}" + { + inherit pname version; + + nativeBuildInputs = [ + tinycc.compiler + gnumake + ]; + + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/grep --version + mkdir ''${out} + ''; + + meta = with lib; { + description = "GNU implementation of the Unix grep command"; + homepage = "https://www.gnu.org/software/grep"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + mainProgram = "grep"; + platforms = platforms.unix; + }; + } + '' + # Unpack + ungz --file ${src} --output grep.tar + untar --file grep.tar + rm grep.tar + cd grep-${version} + + # Configure + cp ${makefile} Makefile + + # Build + make CC="tcc -B ${tinycc.libs}/lib" + + # Install + make install PREFIX=$out + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gnumake/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/gnumake/default.nix index 270d4e36c78825..bced9602696534 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gnumake/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gnumake/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchurl -, kaem -, tinycc -, gnupatch +{ + lib, + fetchurl, + kaem, + tinycc, + gnupatch, }: let pname = "gnumake"; @@ -137,54 +138,66 @@ let "src/version.c" "src/vpath.c" ]; - glob_SOURCES = [ "lib/fnmatch.c" "lib/glob.c" ]; - remote_SOURCES = [ "src/remote-stub.c" ]; - sources = make_SOURCES ++ glob_SOURCES ++ remote_SOURCES ++ [ - "src/posixos.c" + glob_SOURCES = [ + "lib/fnmatch.c" + "lib/glob.c" ]; - - objects = map (x: lib.replaceStrings [".c"] [".o"] (builtins.baseNameOf x)) sources; + remote_SOURCES = [ "src/remote-stub.c" ]; + sources = + make_SOURCES + ++ glob_SOURCES + ++ remote_SOURCES + ++ [ + "src/posixos.c" + ]; + + objects = map (x: lib.replaceStrings [ ".c" ] [ ".o" ] (builtins.baseNameOf x)) sources; in -kaem.runCommand "${pname}-${version}" { - inherit pname version; - - nativeBuildInputs = [ tinycc.compiler gnupatch ]; - - meta = with lib; { - description = "Tool to control the generation of non-source files from sources"; - homepage = "https://www.gnu.org/software/make"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - mainProgram = "make"; - platforms = platforms.unix; - }; -} '' - # Unpack - ungz --file ${src} --output make.tar - untar --file make.tar - rm make.tar - cd make-${version} - - # Patch - ${lib.concatMapStringsSep "\n" (f: "patch -Np1 -i ${f}") patches} - - # Configure - catm src/config.h src/mkconfig.h src/mkcustom.h - cp lib/glob.in.h lib/glob.h - cp lib/fnmatch.in.h lib/fnmatch.h - - # Compile - alias CC="tcc -B ${tinycc.libs}/lib ${lib.concatStringsSep " " CFLAGS}" - ${lib.concatMapStringsSep "\n" (f: "CC -c ${f}") sources} - - # Link - CC -o make ${lib.concatStringsSep " " objects} - - # Check - ./make --version - - # Install - mkdir -p ''${out}/bin - cp ./make ''${out}/bin - chmod 555 ''${out}/bin/make -'' +kaem.runCommand "${pname}-${version}" + { + inherit pname version; + + nativeBuildInputs = [ + tinycc.compiler + gnupatch + ]; + + meta = with lib; { + description = "Tool to control the generation of non-source files from sources"; + homepage = "https://www.gnu.org/software/make"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + mainProgram = "make"; + platforms = platforms.unix; + }; + } + '' + # Unpack + ungz --file ${src} --output make.tar + untar --file make.tar + rm make.tar + cd make-${version} + + # Patch + ${lib.concatMapStringsSep "\n" (f: "patch -Np1 -i ${f}") patches} + + # Configure + catm src/config.h src/mkconfig.h src/mkcustom.h + cp lib/glob.in.h lib/glob.h + cp lib/fnmatch.in.h lib/fnmatch.h + + # Compile + alias CC="tcc -B ${tinycc.libs}/lib ${lib.concatStringsSep " " CFLAGS}" + ${lib.concatMapStringsSep "\n" (f: "CC -c ${f}") sources} + + # Link + CC -o make ${lib.concatStringsSep " " objects} + + # Check + ./make --version + + # Install + mkdir -p ''${out}/bin + cp ./make ''${out}/bin + chmod 555 ''${out}/bin/make + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gnumake/musl.nix b/pkgs/os-specific/linux/minimal-bootstrap/gnumake/musl.nix index 47b3de03c4ca9c..d2b53fb9a97fbe 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gnumake/musl.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gnumake/musl.nix @@ -1,16 +1,17 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, tinycc -, gnumakeBoot -, gnupatch -, gnused -, gnugrep -, gawk -, gnutar -, gzip +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + tinycc, + gnumakeBoot, + gnupatch, + gnused, + gnugrep, + gawk, + gnutar, + gzip, }: let pname = "gnumake-musl"; @@ -30,53 +31,56 @@ let ./0002-remove-impure-dirs.patch ]; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumakeBoot - gnupatch - gnused - gnugrep - gawk - gnutar - gzip - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumakeBoot + gnupatch + gnused + gnugrep + gawk + gnutar + gzip + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/make --version - mkdir $out - ''; + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/make --version + mkdir $out + ''; - meta = with lib; { - description = "Tool to control the generation of non-source files from sources"; - homepage = "https://www.gnu.org/software/make"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - mainProgram = "make"; - platforms = platforms.unix; - }; -} '' - # Unpack - tar xzf ${src} - cd make-${version} + meta = with lib; { + description = "Tool to control the generation of non-source files from sources"; + homepage = "https://www.gnu.org/software/make"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + mainProgram = "make"; + platforms = platforms.unix; + }; + } + '' + # Unpack + tar xzf ${src} + cd make-${version} - # Patch - ${lib.concatMapStringsSep "\n" (f: "patch -Np1 -i ${f}") patches} + # Patch + ${lib.concatMapStringsSep "\n" (f: "patch -Np1 -i ${f}") patches} - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - export LD=tcc - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + export LD=tcc + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} - # Build - make AR="tcc -ar" + # Build + make AR="tcc -ar" - # Install - make install -'' + # Install + make install + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gnupatch/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/gnupatch/default.nix index 8e6f6696c68ca7..66de5351204a8e 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gnupatch/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gnupatch/default.nix @@ -1,7 +1,8 @@ -{ lib -, fetchurl -, kaem -, tinycc +{ + lib, + fetchurl, + kaem, + tinycc, }: let pname = "gnupatch"; @@ -65,43 +66,45 @@ let "error.c" ]; - objects = map (x: lib.replaceStrings [".c"] [".o"] (builtins.baseNameOf x)) sources; + objects = map (x: lib.replaceStrings [ ".c" ] [ ".o" ] (builtins.baseNameOf x)) sources; in -kaem.runCommand "${pname}-${version}" { - inherit pname version; +kaem.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ tinycc.compiler ]; + nativeBuildInputs = [ tinycc.compiler ]; - meta = with lib; { - description = "GNU Patch, a program to apply differences to files"; - homepage = "https://www.gnu.org/software/patch"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - mainProgram = "patch"; - platforms = platforms.unix; - }; -} '' - # Unpack - ungz --file ${src} --output patch.tar - untar --file patch.tar - rm patch.tar - cd patch-${version} + meta = with lib; { + description = "GNU Patch, a program to apply differences to files"; + homepage = "https://www.gnu.org/software/patch"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + mainProgram = "patch"; + platforms = platforms.unix; + }; + } + '' + # Unpack + ungz --file ${src} --output patch.tar + untar --file patch.tar + rm patch.tar + cd patch-${version} - # Configure - catm config.h + # Configure + catm config.h - # Build - alias CC="tcc -B ${tinycc.libs}/lib ${lib.concatStringsSep " " CFLAGS}" - ${lib.concatMapStringsSep "\n" (f: "CC -c ${f}") sources} + # Build + alias CC="tcc -B ${tinycc.libs}/lib ${lib.concatStringsSep " " CFLAGS}" + ${lib.concatMapStringsSep "\n" (f: "CC -c ${f}") sources} - # Link - CC -o patch ${lib.concatStringsSep " " objects} + # Link + CC -o patch ${lib.concatStringsSep " " objects} - # Check - ./patch --version + # Check + ./patch --version - # Install - mkdir -p ''${out}/bin - cp ./patch ''${out}/bin - chmod 555 ''${out}/bin/patch -'' + # Install + mkdir -p ''${out}/bin + cp ./patch ''${out}/bin + chmod 555 ''${out}/bin/patch + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gnused/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/gnused/default.nix index ee566f93c16434..a5ef9673c399c8 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gnused/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gnused/default.nix @@ -1,14 +1,15 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, gnumake -, tinycc -, gnused -, gnugrep -, gnutar -, gzip +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + gnumake, + tinycc, + gnused, + gnugrep, + gnutar, + gzip, }: let @@ -22,42 +23,45 @@ let hash = "sha256-20XNY/0BDmUFN9ZdXfznaJplJ0UjZgbl5ceCk3Jn2YM="; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version meta; +bash.runCommand "${pname}-${version}" + { + inherit pname version meta; - nativeBuildInputs = [ - gnumake - tinycc.compiler - gnused - gnugrep - gnutar - gzip - ]; + nativeBuildInputs = [ + gnumake + tinycc.compiler + gnused + gnugrep + gnutar + gzip + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/sed --version - mkdir ''${out} - ''; -} ('' - # Unpack - tar xzf ${src} - cd sed-${version} + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/sed --version + mkdir ''${out} + ''; + } + ('' + # Unpack + tar xzf ${src} + cd sed-${version} - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - export LD=tcc - ./configure \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - --disable-shared \ - --disable-nls \ - --disable-dependency-tracking \ - --prefix=$out + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + export LD=tcc + ./configure \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + --disable-shared \ + --disable-nls \ + --disable-dependency-tracking \ + --prefix=$out - # Build - make AR="tcc -ar" + # Build + make AR="tcc -ar" - # Install - make install -'') + # Install + make install + '') diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gnused/mes.nix b/pkgs/os-specific/linux/minimal-bootstrap/gnused/mes.nix index 031b5b5f0db07c..f11881fa290a68 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gnused/mes.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gnused/mes.nix @@ -1,10 +1,11 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, gnumake -, tinycc +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + gnumake, + tinycc, }: let @@ -25,35 +26,38 @@ let sha256 = "0w1f5ri0g5zla31m6l6xyzbqwdvandqfnzrsw90dd6ak126w3mya"; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version meta; - - nativeBuildInputs = [ - gnumake - tinycc.compiler - ]; - - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/sed --version - mkdir ''${out} - ''; -} ('' - # Unpack - ungz --file ${src} --output sed.tar - untar --file sed.tar - rm sed.tar - cd sed-${version} - - # Configure - cp ${makefile} Makefile - catm config.h - - # Build - make \ - CC="tcc -B ${tinycc.libs}/lib" \ - LIBC=mes - - # Install - make install PREFIX=$out -'') +bash.runCommand "${pname}-${version}" + { + inherit pname version meta; + + nativeBuildInputs = [ + gnumake + tinycc.compiler + ]; + + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/sed --version + mkdir ''${out} + ''; + } + ('' + # Unpack + ungz --file ${src} --output sed.tar + untar --file sed.tar + rm sed.tar + cd sed-${version} + + # Configure + cp ${makefile} Makefile + catm config.h + + # Build + make \ + CC="tcc -B ${tinycc.libs}/lib" \ + LIBC=mes + + # Install + make install PREFIX=$out + '') diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gnutar/latest.nix b/pkgs/os-specific/linux/minimal-bootstrap/gnutar/latest.nix index 717ea9868fd9de..aa702b245b9784 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gnutar/latest.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gnutar/latest.nix @@ -1,17 +1,18 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, gcc -, musl -, binutils -, gnumake -, gnused -, gnugrep -, gawk -, gzip -, gnutarBoot +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + gcc, + musl, + binutils, + gnumake, + gnused, + gnugrep, + gawk, + gzip, + gnutarBoot, }: let pname = "gnutar"; @@ -22,50 +23,53 @@ let hash = "sha256-FNVeMgY+qVJuBX+/Nfyr1TN452l4fv95GcN1WwLStX4="; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - gcc - musl - binutils - gnumake - gnused - gnugrep - gawk - gzip - gnutarBoot - ]; + nativeBuildInputs = [ + gcc + musl + binutils + gnumake + gnused + gnugrep + gawk + gzip + gnutarBoot + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/tar --version - mkdir $out - ''; + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/tar --version + mkdir $out + ''; - meta = with lib; { - description = "GNU implementation of the `tar' archiver"; - homepage = "https://www.gnu.org/software/tar"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - mainProgram = "tar"; - platforms = platforms.unix; - }; -} '' - # Unpack - tar xzf ${src} - cd tar-${version} + meta = with lib; { + description = "GNU implementation of the `tar' archiver"; + homepage = "https://www.gnu.org/software/tar"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + mainProgram = "tar"; + platforms = platforms.unix; + }; + } + '' + # Unpack + tar xzf ${src} + cd tar-${version} - # Configure - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - CC=musl-gcc + # Configure + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + CC=musl-gcc - # Build - make -j $NIX_BUILD_CORES + # Build + make -j $NIX_BUILD_CORES - # Install - make -j $NIX_BUILD_CORES install -'' + # Install + make -j $NIX_BUILD_CORES install + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gnutar/mes.nix b/pkgs/os-specific/linux/minimal-bootstrap/gnutar/mes.nix index e07561b3e7e5cd..f674dcfffa9b57 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gnutar/mes.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gnutar/mes.nix @@ -1,12 +1,13 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, tinycc -, gnumake -, gnused -, gnugrep +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + tinycc, + gnumake, + gnused, + gnugrep, }: let pname = "gnutar"; @@ -18,48 +19,51 @@ let sha256 = "02m6gajm647n8l9a5bnld6fnbgdpyi4i3i83p7xcwv0kif47xhy6"; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnused - gnugrep - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnused + gnugrep + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/tar --version - mkdir $out - ''; + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/tar --version + mkdir $out + ''; - meta = with lib; { - description = "GNU implementation of the `tar' archiver"; - homepage = "https://www.gnu.org/software/tar"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - mainProgram = "tar"; - platforms = platforms.unix; - }; -} '' - # Unpack - ungz --file ${src} --output tar.tar - untar --file tar.tar - rm tar.tar - cd tar-${version} + meta = with lib; { + description = "GNU implementation of the `tar' archiver"; + homepage = "https://www.gnu.org/software/tar"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + mainProgram = "tar"; + platforms = platforms.unix; + }; + } + '' + # Unpack + ungz --file ${src} --output tar.tar + untar --file tar.tar + rm tar.tar + cd tar-${version} - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - bash ./configure \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - --disable-nls \ - --prefix=$out + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + bash ./configure \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + --disable-nls \ + --prefix=$out - # Build - make AR="tcc -ar" + # Build + make AR="tcc -ar" - # Install - make install -'' + # Install + make install + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gnutar/musl.nix b/pkgs/os-specific/linux/minimal-bootstrap/gnutar/musl.nix index 0818a0de39a2ba..84d46b8f5743fd 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gnutar/musl.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gnutar/musl.nix @@ -1,12 +1,13 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, tinycc -, gnumake -, gnugrep -, gnused +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + tinycc, + gnumake, + gnugrep, + gnused, }: let # gnutar with musl preserves modify times, allowing make to not try @@ -19,52 +20,55 @@ let hash = "sha256-xsN+iIsTbM76uQPFEUn0t71lnWnUrqISRfYQU6V6pgo="; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnused - gnugrep - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnused + gnugrep + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/tar --version - mkdir $out - ''; + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/tar --version + mkdir $out + ''; - meta = with lib; { - description = "GNU implementation of the `tar' archiver"; - homepage = "https://www.gnu.org/software/tar"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - mainProgram = "tar"; - platforms = platforms.unix; - }; -} '' - # Unpack - ungz --file ${src} --output tar.tar - untar --file tar.tar - rm tar.tar - cd tar-${version} + meta = with lib; { + description = "GNU implementation of the `tar' archiver"; + homepage = "https://www.gnu.org/software/tar"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + mainProgram = "tar"; + platforms = platforms.unix; + }; + } + '' + # Unpack + ungz --file ${src} --output tar.tar + untar --file tar.tar + rm tar.tar + cd tar-${version} - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - export LD=tcc - export ac_cv_sizeof_unsigned_long=4 - export ac_cv_sizeof_long_long=8 - export ac_cv_header_netdb_h=no - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - --disable-nls + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + export LD=tcc + export ac_cv_sizeof_unsigned_long=4 + export ac_cv_sizeof_long_long=8 + export ac_cv_header_netdb_h=no + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + --disable-nls - # Build - make AR="tcc -ar" + # Build + make AR="tcc -ar" - # Install - make install -'' + # Install + make install + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/gzip/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/gzip/default.nix index 39353bf2b48b13..8013bd5a91c5a7 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/gzip/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/gzip/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchurl -, bash -, tinycc -, gnumake -, gnused -, gnugrep +{ + lib, + fetchurl, + bash, + tinycc, + gnumake, + gnused, + gnugrep, }: let pname = "gzip"; @@ -15,44 +16,47 @@ let sha256 = "0ryr5b00qz3xcdcv03qwjdfji8pasp0007ay3ppmk71wl8c1i90w"; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnused - gnugrep - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnused + gnugrep + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/gzip --version - mkdir $out - ''; + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/gzip --version + mkdir $out + ''; - meta = with lib; { - description = "GNU zip compression program"; - homepage = "https://www.gnu.org/software/gzip"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - ungz --file ${src} --output gzip.tar - untar --file gzip.tar - rm gzip.tar - cd gzip-${version} + meta = with lib; { + description = "GNU zip compression program"; + homepage = "https://www.gnu.org/software/gzip"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + ungz --file ${src} --output gzip.tar + untar --file gzip.tar + rm gzip.tar + cd gzip-${version} - # Configure - export CC="tcc -B ${tinycc.libs}/lib -Dstrlwr=unused" - bash ./configure --prefix=$out + # Configure + export CC="tcc -B ${tinycc.libs}/lib -Dstrlwr=unused" + bash ./configure --prefix=$out - # Build - make + # Build + make - # Install - mkdir $out - make install -'' + # Install + mkdir $out + make install + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/heirloom-devtools/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/heirloom-devtools/default.nix index 88637811b9531a..5262083a1d0ac2 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/heirloom-devtools/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/heirloom-devtools/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchurl -, kaem -, tinycc -, gnumake -, gnupatch -, coreutils +{ + lib, + fetchurl, + kaem, + tinycc, + gnumake, + gnupatch, + coreutils, }: let pname = "heirloom-devtools"; @@ -32,66 +33,72 @@ let }) ]; in -kaem.runCommand "${pname}-${version}" { - inherit pname version; +kaem.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnupatch - coreutils - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnupatch + coreutils + ]; - meta = with lib; { - description = "Portable yacc and lex derived from OpenSolaris"; - homepage = "https://heirloom.sourceforge.net/devtools.html"; - license = with licenses; [ cddl bsdOriginalUC caldera ]; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - unbz2 --file ${src} --output heirloom-devtools.tar - untar --file heirloom-devtools.tar - rm heirloom-devtools.tar - build=''${NIX_BUILD_TOP}/heirloom-devtools-${version} - cd ''${build} + meta = with lib; { + description = "Portable yacc and lex derived from OpenSolaris"; + homepage = "https://heirloom.sourceforge.net/devtools.html"; + license = with licenses; [ + cddl + bsdOriginalUC + caldera + ]; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + unbz2 --file ${src} --output heirloom-devtools.tar + untar --file heirloom-devtools.tar + rm heirloom-devtools.tar + build=''${NIX_BUILD_TOP}/heirloom-devtools-${version} + cd ''${build} - # Patch - ${lib.concatLines (map (f: "patch -Np0 -i ${f}") patches)} + # Patch + ${lib.concatLines (map (f: "patch -Np0 -i ${f}") patches)} - # Build yacc - cd yacc - make -f Makefile.mk \ - CC="tcc -B ${tinycc.libs}/lib" \ - AR="tcc -ar" \ - CFLAGS="-DMAXPATHLEN=4096 -DEILSEQ=84 -DMB_LEN_MAX=100" \ - LDFLAGS="-lgetopt" \ - RANLIB=true \ - LIBDIR=''${out}/lib + # Build yacc + cd yacc + make -f Makefile.mk \ + CC="tcc -B ${tinycc.libs}/lib" \ + AR="tcc -ar" \ + CFLAGS="-DMAXPATHLEN=4096 -DEILSEQ=84 -DMB_LEN_MAX=100" \ + LDFLAGS="-lgetopt" \ + RANLIB=true \ + LIBDIR=''${out}/lib - # Install yacc - install -D yacc ''${out}/bin/yacc - install -Dm 444 liby.a ''${out}/lib/liby.a - install -Dm 444 yaccpar ''${out}/lib/yaccpar + # Install yacc + install -D yacc ''${out}/bin/yacc + install -Dm 444 liby.a ''${out}/lib/liby.a + install -Dm 444 yaccpar ''${out}/lib/yaccpar - # Make yacc available to lex - PATH="''${out}/bin:''${PATH}" + # Make yacc available to lex + PATH="''${out}/bin:''${PATH}" - # Build lex - cd ../lex - make -f Makefile.mk \ - CC="tcc -B ${tinycc.libs}/lib" \ - AR="tcc -ar" \ - CFLAGS="-DEILSEQ=84 -DMB_LEN_MAX=100" \ - LDFLAGS="-lgetopt" \ - RANLIB=true \ - LIBDIR=''${out}/lib + # Build lex + cd ../lex + make -f Makefile.mk \ + CC="tcc -B ${tinycc.libs}/lib" \ + AR="tcc -ar" \ + CFLAGS="-DEILSEQ=84 -DMB_LEN_MAX=100" \ + LDFLAGS="-lgetopt" \ + RANLIB=true \ + LIBDIR=''${out}/lib - # Install lex - install -D lex ''${out}/bin/lex - install -Dm 444 ncform ''${out}/lib/lex/ncform - install -Dm 444 nceucform ''${out}/lib/lex/nceucform - install -Dm 444 nrform ''${out}/lib/lex/nrform - install -Dm 444 libl.a ''${out}/lib/libl.a -'' + # Install lex + install -D lex ''${out}/bin/lex + install -Dm 444 ncform ''${out}/lib/lex/ncform + install -Dm 444 nceucform ''${out}/lib/lex/nceucform + install -Dm 444 nrform ''${out}/lib/lex/nrform + install -Dm 444 libl.a ''${out}/lib/libl.a + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/heirloom/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/heirloom/default.nix index 7e3d29b6d29ec2..2eece86cf1d31b 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/heirloom/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/heirloom/default.nix @@ -1,11 +1,12 @@ -{ lib -, fetchurl -, bash -, tinycc -, gnumake -, gnupatch -, heirloom-devtools -, heirloom +{ + lib, + fetchurl, + bash, + tinycc, + gnumake, + gnupatch, + heirloom-devtools, + heirloom, }: let pname = "heirloom"; @@ -70,61 +71,63 @@ let "LWCHAR='-L../libwchar -lwchar'" ]; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnupatch - heirloom-devtools - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnupatch + heirloom-devtools + ]; - passthru.sed = - bash.runCommand "${pname}-sed-${version}" {} '' + passthru.sed = bash.runCommand "${pname}-sed-${version}" { } '' install -D ${heirloom}/bin/sed $out/bin/sed ''; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/banner Hello Heirloom - mkdir $out - ''; + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/banner Hello Heirloom + mkdir $out + ''; - meta = with lib; { - description = "Heirloom Toolchest is a collection of standard Unix utilities"; - homepage = "https://heirloom.sourceforge.net/tools.html"; - license = with licenses; [ - # All licenses according to LICENSE/ - zlib - caldera - bsdOriginalUC - cddl - bsd3 - gpl2Plus - lgpl21Plus - lpl-102 - info-zip - ]; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - unbz2 --file ${src} --output heirloom.tar - untar --file heirloom.tar - rm heirloom.tar - cd heirloom-${version} + meta = with lib; { + description = "Heirloom Toolchest is a collection of standard Unix utilities"; + homepage = "https://heirloom.sourceforge.net/tools.html"; + license = with licenses; [ + # All licenses according to LICENSE/ + zlib + caldera + bsdOriginalUC + cddl + bsd3 + gpl2Plus + lgpl21Plus + lpl-102 + info-zip + ]; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + unbz2 --file ${src} --output heirloom.tar + untar --file heirloom.tar + rm heirloom.tar + cd heirloom-${version} - # Patch - ${lib.concatMapStringsSep "\n" (f: "patch -Np0 -i ${f}") patches} - cp ${./proctab.c} nawk/proctab.c + # Patch + ${lib.concatMapStringsSep "\n" (f: "patch -Np0 -i ${f}") patches} + cp ${./proctab.c} nawk/proctab.c - # Build - # These tools are required during later build steps - export PATH="$PATH:$PWD/ed:$PWD/nawk:$PWD/sed" - make ${lib.concatStringsSep " " makeFlags} + # Build + # These tools are required during later build steps + export PATH="$PATH:$PWD/ed:$PWD/nawk:$PWD/sed" + make ${lib.concatStringsSep " " makeFlags} - # Install - make install ROOT=$out ${lib.concatStringsSep " " makeFlags} -'' + # Install + make install ROOT=$out ${lib.concatStringsSep " " makeFlags} + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/linux-headers/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/linux-headers/default.nix index 965803c40d8f83..ec3fa5aa7bdf2c 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/linux-headers/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/linux-headers/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchurl -, bash -, gnutar -, xz +{ + lib, + fetchurl, + bash, + gnutar, + xz, }: let # WARNING: You probably don't want to use this package outside minimal-bootstrap @@ -23,27 +24,29 @@ let sha256 = "0sm2z9x4wk45bh6qfs94p0w1d6hsy6dqx9sw38qsqbvxwa1qzk8s"; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - gnutar - xz - ]; + nativeBuildInputs = [ + gnutar + xz + ]; - meta = with lib; { - description = "Header files and scripts for Linux kernel"; - license = licenses.gpl2Only; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.linux; - }; -} '' - # Unpack - cp ${src} linux-headers.tar.xz - unxz linux-headers.tar.xz - tar xf linux-headers.tar + meta = with lib; { + description = "Header files and scripts for Linux kernel"; + license = licenses.gpl2Only; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.linux; + }; + } + '' + # Unpack + cp ${src} linux-headers.tar.xz + unxz linux-headers.tar.xz + tar xf linux-headers.tar - # Install - mkdir $out - cp -r include $out -'' + # Install + mkdir $out + cp -r include $out + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/ln-boot/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/ln-boot/default.nix index c24504ec00a029..0aef4ced911b31 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/ln-boot/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/ln-boot/default.nix @@ -1,6 +1,7 @@ -{ lib -, kaem -, mes +{ + lib, + kaem, + mes, }: let pname = "ln-boot"; @@ -8,21 +9,23 @@ let src = ./ln.c; in -kaem.runCommand "${pname}-${version}" { - inherit pname version; +kaem.runCommand "${pname}-${version}" + { + inherit pname version; - meta = with lib; { - description = "Basic tool for creating symbolic links"; - license = licenses.mit; - maintainers = teams.minimal-bootstrap.members; - mainProgram = "ln"; - platforms = platforms.unix; - }; -} '' - mkdir -p ''${out}/bin - ${mes.compiler}/bin/mes --no-auto-compile -e main ${mes.srcPost.bin}/bin/mescc.scm -- \ - -L ${mes.libs}/lib \ - -lc+tcc \ - -o ''${out}/bin/ln \ - ${src} -'' + meta = with lib; { + description = "Basic tool for creating symbolic links"; + license = licenses.mit; + maintainers = teams.minimal-bootstrap.members; + mainProgram = "ln"; + platforms = platforms.unix; + }; + } + '' + mkdir -p ''${out}/bin + ${mes.compiler}/bin/mes --no-auto-compile -e main ${mes.srcPost.bin}/bin/mescc.scm -- \ + -L ${mes.libs}/lib \ + -lc+tcc \ + -o ''${out}/bin/ln \ + ${src} + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/mes/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/mes/default.nix index 03ce9300f316c7..dfde3aff704f2d 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/mes/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/mes/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchurl -, callPackage -, kaem -, mescc-tools +{ + lib, + fetchurl, + callPackage, + kaem, + mescc-tools, }: # Maintenance note: @@ -27,7 +28,12 @@ let ''; sources = (import ./sources.nix).x86.linux.mescc; - inherit (sources) libc_mini_SOURCES libmescc_SOURCES libc_SOURCES mes_SOURCES; + inherit (sources) + libc_mini_SOURCES + libmescc_SOURCES + libc_SOURCES + mes_SOURCES + ; # add symlink() to libc+tcc so we can use it in ln-boot libc_tcc_SOURCES = sources.libc_tcc_SOURCES ++ [ "lib/linux/symlink.c" ]; @@ -40,121 +46,132 @@ let platforms = [ "i686-linux" ]; }; - srcPost = kaem.runCommand "${pname}-src-${version}" { - outputs = [ "out" "bin" ]; - inherit meta; - } '' - # Unpack source - ungz --file ${src} --output mes.tar - mkdir ''${out} - cd ''${out} - untar --non-strict --file ''${NIX_BUILD_TOP}/mes.tar # ignore symlinks - - MES_PREFIX=''${out}/mes-${version} - - cd ''${MES_PREFIX} - - cp ${config_h} include/mes/config.h - - mkdir include/arch - cp include/linux/x86/syscall.h include/arch/syscall.h - cp include/linux/x86/kernel-stat.h include/arch/kernel-stat.h - - # Remove pregenerated files - rm mes/module/mes/psyntax.pp mes/module/mes/psyntax.pp.header - - # These files are symlinked in the repo - cp mes/module/srfi/srfi-9-struct.mes mes/module/srfi/srfi-9.mes - cp mes/module/srfi/srfi-9/gnu-struct.mes mes/module/srfi/srfi-9/gnu.mes - - # Remove environment impurities - __GUILE_LOAD_PATH="\"''${MES_PREFIX}/mes/module:''${MES_PREFIX}/module:${nyacc.guilePath}\"" - boot0_scm=mes/module/mes/boot-0.scm - guile_mes=mes/module/mes/guile.mes - replace --file ''${boot0_scm} --output ''${boot0_scm} --match-on "(getenv \"GUILE_LOAD_PATH\")" --replace-with ''${__GUILE_LOAD_PATH} - replace --file ''${guile_mes} --output ''${guile_mes} --match-on "(getenv \"GUILE_LOAD_PATH\")" --replace-with ''${__GUILE_LOAD_PATH} - - module_mescc_scm=module/mescc/mescc.scm - replace --file ''${module_mescc_scm} --output ''${module_mescc_scm} --match-on "(getenv \"M1\")" --replace-with "\"${mescc-tools}/bin/M1\"" - replace --file ''${module_mescc_scm} --output ''${module_mescc_scm} --match-on "(getenv \"HEX2\")" --replace-with "\"${mescc-tools}/bin/hex2\"" - replace --file ''${module_mescc_scm} --output ''${module_mescc_scm} --match-on "(getenv \"BLOOD_ELF\")" --replace-with "\"${mescc-tools}/bin/blood-elf\"" - replace --file ''${module_mescc_scm} --output ''${module_mescc_scm} --match-on "(getenv \"srcdest\")" --replace-with "\"''${MES_PREFIX}\"" - - mes_c=src/mes.c - replace --file ''${mes_c} --output ''${mes_c} --match-on "getenv (\"MES_PREFIX\")" --replace-with "\"''${MES_PREFIX}\"" - replace --file ''${mes_c} --output ''${mes_c} --match-on "getenv (\"srcdest\")" --replace-with "\"''${MES_PREFIX}\"" - - # Increase runtime resource limits - gc_c=src/gc.c - replace --file ''${gc_c} --output ''${gc_c} --match-on "getenv (\"MES_ARENA\")" --replace-with "\"100000000\"" - replace --file ''${gc_c} --output ''${gc_c} --match-on "getenv (\"MES_MAX_ARENA\")" --replace-with "\"100000000\"" - replace --file ''${gc_c} --output ''${gc_c} --match-on "getenv (\"MES_STACK\")" --replace-with "\"6000000\"" - - # Create mescc.scm - mescc_in=scripts/mescc.scm.in - replace --file ''${mescc_in} --output ''${mescc_in} --match-on "(getenv \"MES_PREFIX\")" --replace-with "\"''${MES_PREFIX}\"" - replace --file ''${mescc_in} --output ''${mescc_in} --match-on "(getenv \"includedir\")" --replace-with "\"''${MES_PREFIX}/include\"" - replace --file ''${mescc_in} --output ''${mescc_in} --match-on "(getenv \"libdir\")" --replace-with "\"''${MES_PREFIX}/lib\"" - replace --file ''${mescc_in} --output ''${mescc_in} --match-on @prefix@ --replace-with ''${MES_PREFIX} - replace --file ''${mescc_in} --output ''${mescc_in} --match-on @VERSION@ --replace-with ${version} - replace --file ''${mescc_in} --output ''${mescc_in} --match-on @mes_cpu@ --replace-with x86 - replace --file ''${mescc_in} --output ''${mescc_in} --match-on @mes_kernel@ --replace-with linux - mkdir -p ''${bin}/bin - cp ''${mescc_in} ''${bin}/bin/mescc.scm - - # Build mes-m2 - kaem --verbose --strict --file kaem.x86 - cp bin/mes-m2 ''${bin}/bin/mes-m2 - chmod 555 ''${bin}/bin/mes-m2 - ''; + srcPost = + kaem.runCommand "${pname}-src-${version}" + { + outputs = [ + "out" + "bin" + ]; + inherit meta; + } + '' + # Unpack source + ungz --file ${src} --output mes.tar + mkdir ''${out} + cd ''${out} + untar --non-strict --file ''${NIX_BUILD_TOP}/mes.tar # ignore symlinks + + MES_PREFIX=''${out}/mes-${version} + + cd ''${MES_PREFIX} + + cp ${config_h} include/mes/config.h + + mkdir include/arch + cp include/linux/x86/syscall.h include/arch/syscall.h + cp include/linux/x86/kernel-stat.h include/arch/kernel-stat.h + + # Remove pregenerated files + rm mes/module/mes/psyntax.pp mes/module/mes/psyntax.pp.header + + # These files are symlinked in the repo + cp mes/module/srfi/srfi-9-struct.mes mes/module/srfi/srfi-9.mes + cp mes/module/srfi/srfi-9/gnu-struct.mes mes/module/srfi/srfi-9/gnu.mes + + # Remove environment impurities + __GUILE_LOAD_PATH="\"''${MES_PREFIX}/mes/module:''${MES_PREFIX}/module:${nyacc.guilePath}\"" + boot0_scm=mes/module/mes/boot-0.scm + guile_mes=mes/module/mes/guile.mes + replace --file ''${boot0_scm} --output ''${boot0_scm} --match-on "(getenv \"GUILE_LOAD_PATH\")" --replace-with ''${__GUILE_LOAD_PATH} + replace --file ''${guile_mes} --output ''${guile_mes} --match-on "(getenv \"GUILE_LOAD_PATH\")" --replace-with ''${__GUILE_LOAD_PATH} + + module_mescc_scm=module/mescc/mescc.scm + replace --file ''${module_mescc_scm} --output ''${module_mescc_scm} --match-on "(getenv \"M1\")" --replace-with "\"${mescc-tools}/bin/M1\"" + replace --file ''${module_mescc_scm} --output ''${module_mescc_scm} --match-on "(getenv \"HEX2\")" --replace-with "\"${mescc-tools}/bin/hex2\"" + replace --file ''${module_mescc_scm} --output ''${module_mescc_scm} --match-on "(getenv \"BLOOD_ELF\")" --replace-with "\"${mescc-tools}/bin/blood-elf\"" + replace --file ''${module_mescc_scm} --output ''${module_mescc_scm} --match-on "(getenv \"srcdest\")" --replace-with "\"''${MES_PREFIX}\"" + + mes_c=src/mes.c + replace --file ''${mes_c} --output ''${mes_c} --match-on "getenv (\"MES_PREFIX\")" --replace-with "\"''${MES_PREFIX}\"" + replace --file ''${mes_c} --output ''${mes_c} --match-on "getenv (\"srcdest\")" --replace-with "\"''${MES_PREFIX}\"" + + # Increase runtime resource limits + gc_c=src/gc.c + replace --file ''${gc_c} --output ''${gc_c} --match-on "getenv (\"MES_ARENA\")" --replace-with "\"100000000\"" + replace --file ''${gc_c} --output ''${gc_c} --match-on "getenv (\"MES_MAX_ARENA\")" --replace-with "\"100000000\"" + replace --file ''${gc_c} --output ''${gc_c} --match-on "getenv (\"MES_STACK\")" --replace-with "\"6000000\"" + + # Create mescc.scm + mescc_in=scripts/mescc.scm.in + replace --file ''${mescc_in} --output ''${mescc_in} --match-on "(getenv \"MES_PREFIX\")" --replace-with "\"''${MES_PREFIX}\"" + replace --file ''${mescc_in} --output ''${mescc_in} --match-on "(getenv \"includedir\")" --replace-with "\"''${MES_PREFIX}/include\"" + replace --file ''${mescc_in} --output ''${mescc_in} --match-on "(getenv \"libdir\")" --replace-with "\"''${MES_PREFIX}/lib\"" + replace --file ''${mescc_in} --output ''${mescc_in} --match-on @prefix@ --replace-with ''${MES_PREFIX} + replace --file ''${mescc_in} --output ''${mescc_in} --match-on @VERSION@ --replace-with ${version} + replace --file ''${mescc_in} --output ''${mescc_in} --match-on @mes_cpu@ --replace-with x86 + replace --file ''${mescc_in} --output ''${mescc_in} --match-on @mes_kernel@ --replace-with linux + mkdir -p ''${bin}/bin + cp ''${mescc_in} ''${bin}/bin/mescc.scm + + # Build mes-m2 + kaem --verbose --strict --file kaem.x86 + cp bin/mes-m2 ''${bin}/bin/mes-m2 + chmod 555 ''${bin}/bin/mes-m2 + ''; srcPrefix = "${srcPost.out}/mes-${version}"; cc = "${srcPost.bin}/bin/mes-m2"; ccArgs = [ - "-e" "main" + "-e" + "main" "${srcPost.bin}/bin/mescc.scm" "--" - "-D" "HAVE_CONFIG_H=1" - "-I" "${srcPrefix}/include" - "-I" "${srcPrefix}/include/linux/x86" + "-D" + "HAVE_CONFIG_H=1" + "-I" + "${srcPrefix}/include" + "-I" + "${srcPrefix}/include/linux/x86" ]; CC = toString ([ cc ] ++ ccArgs); - stripExt = source: - lib.replaceStrings - [ ".c" ] - [ "" ] - (builtins.baseNameOf source); + stripExt = source: lib.replaceStrings [ ".c" ] [ "" ] (builtins.baseNameOf source); - compile = source: kaem.runCommand (stripExt source) {} '' - mkdir ''${out} - cd ''${out} - ${CC} -c ${srcPrefix}/${source} - ''; + compile = + source: + kaem.runCommand (stripExt source) { } '' + mkdir ''${out} + cd ''${out} + ${CC} -c ${srcPrefix}/${source} + ''; crt1 = compile "/lib/linux/x86-mes-mescc/crt1.c"; getRes = suffix: res: "${res}/${res.name}${suffix}"; - archive = out: sources: - "catm ${out} ${lib.concatMapStringsSep " " (getRes ".o") sources}"; - sourceArchive = out: sources: - "catm ${out} ${lib.concatMapStringsSep " " (getRes ".s") sources}"; - - mkLib = libname: sources: let - os = map compile sources; - in kaem.runCommand "${pname}-${libname}-${version}" { - inherit meta; - } '' - LIBDIR=''${out}/lib - mkdir -p ''${LIBDIR} - cd ''${LIBDIR} - - ${archive "${libname}.a" os} - ${sourceArchive "${libname}.s" os} - ''; + archive = out: sources: "catm ${out} ${lib.concatMapStringsSep " " (getRes ".o") sources}"; + sourceArchive = out: sources: "catm ${out} ${lib.concatMapStringsSep " " (getRes ".s") sources}"; + + mkLib = + libname: sources: + let + os = map compile sources; + in + kaem.runCommand "${pname}-${libname}-${version}" + { + inherit meta; + } + '' + LIBDIR=''${out}/lib + mkdir -p ''${LIBDIR} + cd ''${LIBDIR} + + ${archive "${libname}.a" os} + ${sourceArchive "${libname}.s" os} + ''; libc-mini = mkLib "libc-mini" libc_mini_SOURCES; libmescc = mkLib "libmescc" libmescc_SOURCES; @@ -162,68 +179,82 @@ let libc_tcc = mkLib "libc+tcc" libc_tcc_SOURCES; # Recompile Mes and Mes C library using mes-m2 bootstrapped Mes - libs = kaem.runCommand "${pname}-m2-libs-${version}" { - inherit pname version; - - passthru.tests.get-version = result: kaem.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/mes --version - mkdir ''${out} - ''; - - inherit meta; - } - '' - LIBDIR=''${out}/lib - mkdir -p ''${out} ''${LIBDIR} - - mkdir -p ''${LIBDIR}/x86-mes - - # crt1.o - cp ${crt1}/crt1.o ''${LIBDIR}/x86-mes - cp ${crt1}/crt1.s ''${LIBDIR}/x86-mes - - # libc-mini.a - cp ${libc-mini}/lib/libc-mini.a ''${LIBDIR}/x86-mes - cp ${libc-mini}/lib/libc-mini.s ''${LIBDIR}/x86-mes - - # libmescc.a - cp ${libmescc}/lib/libmescc.a ''${LIBDIR}/x86-mes - cp ${libmescc}/lib/libmescc.s ''${LIBDIR}/x86-mes - - # libc.a - cp ${libc}/lib/libc.a ''${LIBDIR}/x86-mes - cp ${libc}/lib/libc.s ''${LIBDIR}/x86-mes - - # libc+tcc.a - cp ${libc_tcc}/lib/libc+tcc.a ''${LIBDIR}/x86-mes - cp ${libc_tcc}/lib/libc+tcc.s ''${LIBDIR}/x86-mes - ''; + libs = + kaem.runCommand "${pname}-m2-libs-${version}" + { + inherit pname version; + + passthru.tests.get-version = + result: + kaem.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/mes --version + mkdir ''${out} + ''; + + inherit meta; + } + '' + LIBDIR=''${out}/lib + mkdir -p ''${out} ''${LIBDIR} + + mkdir -p ''${LIBDIR}/x86-mes + + # crt1.o + cp ${crt1}/crt1.o ''${LIBDIR}/x86-mes + cp ${crt1}/crt1.s ''${LIBDIR}/x86-mes + + # libc-mini.a + cp ${libc-mini}/lib/libc-mini.a ''${LIBDIR}/x86-mes + cp ${libc-mini}/lib/libc-mini.s ''${LIBDIR}/x86-mes + + # libmescc.a + cp ${libmescc}/lib/libmescc.a ''${LIBDIR}/x86-mes + cp ${libmescc}/lib/libmescc.s ''${LIBDIR}/x86-mes + + # libc.a + cp ${libc}/lib/libc.a ''${LIBDIR}/x86-mes + cp ${libc}/lib/libc.s ''${LIBDIR}/x86-mes + + # libc+tcc.a + cp ${libc_tcc}/lib/libc+tcc.a ''${LIBDIR}/x86-mes + cp ${libc_tcc}/lib/libc+tcc.s ''${LIBDIR}/x86-mes + ''; # Build mes itself - compiler = kaem.runCommand "${pname}-${version}" { - inherit pname version; - - passthru.tests.get-version = result: kaem.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/mes --version - mkdir ''${out} - ''; - - inherit meta; - } - '' - mkdir -p ''${out}/bin - - ${srcPost.bin}/bin/mes-m2 -e main ${srcPost.bin}/bin/mescc.scm -- \ - -L ''${srcPrefix}/lib \ - -L ${libs}/lib \ - -lc \ - -lmescc \ - -nostdlib \ - -o ''${out}/bin/mes \ - ${libs}/lib/x86-mes/crt1.o \ - ${lib.concatMapStringsSep " " (getRes ".o") (map compile mes_SOURCES)} - ''; -in { - inherit src srcPost srcPrefix nyacc; + compiler = + kaem.runCommand "${pname}-${version}" + { + inherit pname version; + + passthru.tests.get-version = + result: + kaem.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/mes --version + mkdir ''${out} + ''; + + inherit meta; + } + '' + mkdir -p ''${out}/bin + + ${srcPost.bin}/bin/mes-m2 -e main ${srcPost.bin}/bin/mescc.scm -- \ + -L ''${srcPrefix}/lib \ + -L ${libs}/lib \ + -lc \ + -lmescc \ + -nostdlib \ + -o ''${out}/bin/mes \ + ${libs}/lib/x86-mes/crt1.o \ + ${lib.concatMapStringsSep " " (getRes ".o") (map compile mes_SOURCES)} + ''; +in +{ + inherit + src + srcPost + srcPrefix + nyacc + ; inherit compiler libs; } diff --git a/pkgs/os-specific/linux/minimal-bootstrap/mes/libc.nix b/pkgs/os-specific/linux/minimal-bootstrap/mes/libc.nix index c6c89b98a2701a..e1224326e72040 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/mes/libc.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/mes/libc.nix @@ -1,8 +1,9 @@ -{ lib -, kaem -, ln-boot -, mes -, mes-libc +{ + lib, + kaem, + ln-boot, + mes, + mes-libc, }: let pname = "mes-libc"; @@ -20,41 +21,43 @@ let firstLibc = lib.take 100 libc_gnu_SOURCES; lastLibc = lib.drop 100 libc_gnu_SOURCES; in -kaem.runCommand "${pname}-${version}" { - inherit pname version; - - nativeBuildInputs = [ ln-boot ]; - - passthru.CFLAGS = "-DHAVE_CONFIG_H=1 -I${mes-libc}/include -I${mes-libc}/include/linux/x86"; - - meta = with lib; { - description = "Mes C Library"; - homepage = "https://www.gnu.org/software/mes"; - license = licenses.gpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = [ "i686-linux" ]; - }; -} '' - cd ${mes.srcPrefix} - - # mescc compiled libc.a - mkdir -p ''${out}/lib/x86-mes - - # libc.c - catm ''${TMPDIR}/first.c ${lib.concatStringsSep " " firstLibc} - catm ''${out}/lib/libc.c ''${TMPDIR}/first.c ${lib.concatStringsSep " " lastLibc} - - # crt{1,n,i}.c - cp lib/linux/x86-mes-gcc/crt1.c ''${out}/lib - cp lib/linux/x86-mes-gcc/crtn.c ''${out}/lib - cp lib/linux/x86-mes-gcc/crti.c ''${out}/lib - - # libtcc1.c - catm ''${out}/lib/libtcc1.c ${lib.concatStringsSep " " libtcc1_SOURCES} - - # getopt.c - cp lib/posix/getopt.c ''${out}/lib/libgetopt.c - - # Install headers - ln -s ${mes.srcPrefix}/include ''${out}/include -'' +kaem.runCommand "${pname}-${version}" + { + inherit pname version; + + nativeBuildInputs = [ ln-boot ]; + + passthru.CFLAGS = "-DHAVE_CONFIG_H=1 -I${mes-libc}/include -I${mes-libc}/include/linux/x86"; + + meta = with lib; { + description = "Mes C Library"; + homepage = "https://www.gnu.org/software/mes"; + license = licenses.gpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = [ "i686-linux" ]; + }; + } + '' + cd ${mes.srcPrefix} + + # mescc compiled libc.a + mkdir -p ''${out}/lib/x86-mes + + # libc.c + catm ''${TMPDIR}/first.c ${lib.concatStringsSep " " firstLibc} + catm ''${out}/lib/libc.c ''${TMPDIR}/first.c ${lib.concatStringsSep " " lastLibc} + + # crt{1,n,i}.c + cp lib/linux/x86-mes-gcc/crt1.c ''${out}/lib + cp lib/linux/x86-mes-gcc/crtn.c ''${out}/lib + cp lib/linux/x86-mes-gcc/crti.c ''${out}/lib + + # libtcc1.c + catm ''${out}/lib/libtcc1.c ${lib.concatStringsSep " " libtcc1_SOURCES} + + # getopt.c + cp lib/posix/getopt.c ''${out}/lib/libgetopt.c + + # Install headers + ln -s ${mes.srcPrefix}/include ''${out}/include + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/mes/nyacc.nix b/pkgs/os-specific/linux/minimal-bootstrap/mes/nyacc.nix index c384b4a4c0b435..12e7b1f833c622 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/mes/nyacc.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/mes/nyacc.nix @@ -1,7 +1,8 @@ -{ lib -, fetchurl -, kaem -, nyacc +{ + lib, + fetchurl, + kaem, + nyacc, }: let pname = "nyacc"; @@ -15,25 +16,27 @@ let sha256 = "065ksalfllbdrzl12dz9d9dcxrv97wqxblslngsc6kajvnvlyvpk"; }; in -kaem.runCommand "${pname}-${version}" { - inherit pname version; +kaem.runCommand "${pname}-${version}" + { + inherit pname version; - passthru.guilePath = "${nyacc}/share/${pname}-${version}/module"; + passthru.guilePath = "${nyacc}/share/${pname}-${version}/module"; - meta = with lib; { - description = "Modules for generating parsers and lexical analyzers"; - longDescription = '' - Not Yet Another Compiler Compiler is a set of guile modules for - generating computer language parsers and lexical analyzers. - ''; - homepage = "https://savannah.nongnu.org/projects/nyacc"; - license = licenses.lgpl3Plus; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.all; - }; -} '' - ungz --file ${src} --output nyacc.tar - mkdir -p ''${out}/share - cd ''${out}/share - untar --file ''${NIX_BUILD_TOP}/nyacc.tar -'' + meta = with lib; { + description = "Modules for generating parsers and lexical analyzers"; + longDescription = '' + Not Yet Another Compiler Compiler is a set of guile modules for + generating computer language parsers and lexical analyzers. + ''; + homepage = "https://savannah.nongnu.org/projects/nyacc"; + license = licenses.lgpl3Plus; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.all; + }; + } + '' + ungz --file ${src} --output nyacc.tar + mkdir -p ''${out}/share + cd ''${out}/share + untar --file ''${NIX_BUILD_TOP}/nyacc.tar + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/musl/1.1.nix b/pkgs/os-specific/linux/minimal-bootstrap/musl/1.1.nix index 704ee42edeb165..4ec34686cb5750 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/musl/1.1.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/musl/1.1.nix @@ -1,15 +1,16 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, tinycc -, gnumake -, gnupatch -, gnused -, gnugrep -, gnutar -, gzip +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + tinycc, + gnumake, + gnupatch, + gnused, + gnugrep, + gnutar, + gzip, }: let @@ -66,51 +67,53 @@ let }) ]; in -bash.runCommand "${pname}-${version}" { - inherit pname version meta; +bash.runCommand "${pname}-${version}" + { + inherit pname version meta; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnupatch - gnused - gnugrep - gnutar - gzip - ]; -} '' - # Unpack - tar xzf ${src} - cd musl-${version} + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnupatch + gnused + gnugrep + gnutar + gzip + ]; + } + '' + # Unpack + tar xzf ${src} + cd musl-${version} - # Patch - ${lib.concatMapStringsSep "\n" (f: "patch -Np0 -i ${f}") patches} - # tcc does not support complex types - rm -rf src/complex - # Configure fails without this - mkdir -p /dev - # https://github.com/ZilchOS/bootstrap-from-tcc/blob/2e0c68c36b3437386f786d619bc9a16177f2e149/using-nix/2a3-intermediate-musl.nix - sed -i 's|/bin/sh|${bash}/bin/bash|' \ - tools/*.sh - chmod 755 tools/*.sh - # patch popen/system to search in PATH instead of hardcoding /bin/sh - sed -i 's|posix_spawn(&pid, "/bin/sh",|posix_spawnp(\&pid, "sh",|' \ - src/stdio/popen.c src/process/system.c - sed -i 's|execl("/bin/sh", "sh", "-c",|execlp("sh", "-c",|'\ - src/misc/wordexp.c + # Patch + ${lib.concatMapStringsSep "\n" (f: "patch -Np0 -i ${f}") patches} + # tcc does not support complex types + rm -rf src/complex + # Configure fails without this + mkdir -p /dev + # https://github.com/ZilchOS/bootstrap-from-tcc/blob/2e0c68c36b3437386f786d619bc9a16177f2e149/using-nix/2a3-intermediate-musl.nix + sed -i 's|/bin/sh|${bash}/bin/bash|' \ + tools/*.sh + chmod 755 tools/*.sh + # patch popen/system to search in PATH instead of hardcoding /bin/sh + sed -i 's|posix_spawn(&pid, "/bin/sh",|posix_spawnp(\&pid, "sh",|' \ + src/stdio/popen.c src/process/system.c + sed -i 's|execl("/bin/sh", "sh", "-c",|execlp("sh", "-c",|'\ + src/misc/wordexp.c - # Configure - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - --disable-shared \ - CC=tcc + # Configure + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + --disable-shared \ + CC=tcc - # Build - make AR="tcc -ar" RANLIB=true CFLAGS="-DSYSCALL_NO_TLS" + # Build + make AR="tcc -ar" RANLIB=true CFLAGS="-DSYSCALL_NO_TLS" - # Install - make install - cp ${tinycc.libs}/lib/libtcc1.a $out/lib -'' + # Install + make install + cp ${tinycc.libs}/lib/libtcc1.a $out/lib + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/musl/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/musl/default.nix index 437ef342f6aee6..138e530efb5dc3 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/musl/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/musl/default.nix @@ -1,15 +1,16 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, gcc -, binutils -, gnumake -, gnugrep -, gnused -, gnutar -, gzip +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + gcc, + binutils, + gnumake, + gnugrep, + gnused, + gnutar, + gzip, }: let inherit (import ./common.nix { inherit lib; }) pname meta; @@ -20,62 +21,71 @@ let hash = "sha256-ejXq4z1TcqfA2hGI3nmHJvaIJVE7euPr6XqqpSEU8Dk="; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version meta; +bash.runCommand "${pname}-${version}" + { + inherit pname version meta; - nativeBuildInputs = [ - gcc - binutils - gnumake - gnused - gnugrep - gnutar - gzip - ]; + nativeBuildInputs = [ + gcc + binutils + gnumake + gnused + gnugrep + gnutar + gzip + ]; - passthru.tests.hello-world = result: - bash.runCommand "${pname}-simple-program-${version}" { - nativeBuildInputs = [ gcc binutils result ]; - } '' - cat <> test.c - #include - int main() { - printf("Hello World!\n"); - return 0; + passthru.tests.hello-world = + result: + bash.runCommand "${pname}-simple-program-${version}" + { + nativeBuildInputs = [ + gcc + binutils + result + ]; } - EOF - musl-gcc -o test test.c - ./test - mkdir $out - ''; -} '' - # Unpack - tar xzf ${src} - cd musl-${version} + '' + cat <> test.c + #include + int main() { + printf("Hello World!\n"); + return 0; + } + EOF + musl-gcc -o test test.c + ./test + mkdir $out + ''; + } + '' + # Unpack + tar xzf ${src} + cd musl-${version} - # Patch - # https://github.com/ZilchOS/bootstrap-from-tcc/blob/2e0c68c36b3437386f786d619bc9a16177f2e149/using-nix/2a3-intermediate-musl.nix - sed -i 's|/bin/sh|${bash}/bin/bash|' \ - tools/*.sh - # patch popen/system to search in PATH instead of hardcoding /bin/sh - sed -i 's|posix_spawn(&pid, "/bin/sh",|posix_spawnp(\&pid, "sh",|' \ - src/stdio/popen.c src/process/system.c - sed -i 's|execl("/bin/sh", "sh", "-c",|execlp("sh", "-c",|'\ - src/misc/wordexp.c + # Patch + # https://github.com/ZilchOS/bootstrap-from-tcc/blob/2e0c68c36b3437386f786d619bc9a16177f2e149/using-nix/2a3-intermediate-musl.nix + sed -i 's|/bin/sh|${bash}/bin/bash|' \ + tools/*.sh + # patch popen/system to search in PATH instead of hardcoding /bin/sh + sed -i 's|posix_spawn(&pid, "/bin/sh",|posix_spawnp(\&pid, "sh",|' \ + src/stdio/popen.c src/process/system.c + sed -i 's|execl("/bin/sh", "sh", "-c",|execlp("sh", "-c",|'\ + src/misc/wordexp.c - # Configure - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - --syslibdir=$out/lib \ - --enable-wrapper + # Configure + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + --syslibdir=$out/lib \ + --enable-wrapper - # Build - make -j $NIX_BUILD_CORES + # Build + make -j $NIX_BUILD_CORES - # Install - make -j $NIX_BUILD_CORES install - sed -i 's|/bin/sh|${bash}/bin/bash|' $out/bin/* - ln -s ../lib/libc.so $out/bin/ldd -'' + # Install + make -j $NIX_BUILD_CORES install + sed -i 's|/bin/sh|${bash}/bin/bash|' $out/bin/* + ln -s ../lib/libc.so $out/bin/ldd + '' diff --git a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/bootstrap-sources.nix b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/bootstrap-sources.nix index 7f2e8ab81a39e5..200e2d51bc6959 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/bootstrap-sources.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/bootstrap-sources.nix @@ -1,4 +1,5 @@ -{ hostPlatform +{ + hostPlatform, }: rec { @@ -9,58 +10,58 @@ rec { outputHash = "sha256-epUaShjKiAd749ICvc6rS6WhUkS8R4heKuPdwUjEtsQ="; /* - Since `make-minimal-bootstrap-sources` requires nixpkgs and nix it - will create a circular dependency if it is used in place of the - binary bootstrap-files. To break the circular dependency, - `minimal-bootstrap-sources` extends `make-minimal-bootstrap-sources` - by adding Fixed Output Derivation (FOD) attributes. These cause - the builder to be skipped if the expected output is found (by - its hash) in the store or on a substituter. + Since `make-minimal-bootstrap-sources` requires nixpkgs and nix it + will create a circular dependency if it is used in place of the + binary bootstrap-files. To break the circular dependency, + `minimal-bootstrap-sources` extends `make-minimal-bootstrap-sources` + by adding Fixed Output Derivation (FOD) attributes. These cause + the builder to be skipped if the expected output is found (by + its hash) in the store or on a substituter. - # How do I update the hash? + # How do I update the hash? - Run the following command: - ``` - nix hash path $(nix build --print-out-paths -f '' make-minimal-bootstrap-sources) - ``` + Run the following command: + ``` + nix hash path $(nix build --print-out-paths -f '' make-minimal-bootstrap-sources) + ``` - # Why do we need this `.nar` archive? + # Why do we need this `.nar` archive? - This archive exists only because of a quirk/limitation of Nix: in - restricted mode the builtin fetchers can download only single - files; they have no way to unpack multi-file archives except for - NAR archives: + This archive exists only because of a quirk/limitation of Nix: in + restricted mode the builtin fetchers can download only single + files; they have no way to unpack multi-file archives except for + NAR archives: - https://github.com/NixOS/nixpkgs/pull/232576#issuecomment-1592415619 + https://github.com/NixOS/nixpkgs/pull/232576#issuecomment-1592415619 - # Why don't we have to upload this to tarballs.nixos.org like the binary bootstrap-files did? + # Why don't we have to upload this to tarballs.nixos.org like the binary bootstrap-files did? - Unlike this archive, the binary bootstrap-files contained binaries, - which meant that we had to: + Unlike this archive, the binary bootstrap-files contained binaries, + which meant that we had to: - 1. Make sure they came from a trusted builder (Hydra) - 2. Keep careful track of exactly what toolchain (i.e. nixpkgs - commit) that builder used to create them. - 3. Keep copies of the built binaries, in case the toolchains that - produced them failed to be perfectly deterministic. + 1. Make sure they came from a trusted builder (Hydra) + 2. Keep careful track of exactly what toolchain (i.e. nixpkgs + commit) that builder used to create them. + 3. Keep copies of the built binaries, in case the toolchains that + produced them failed to be perfectly deterministic. - The curated archives at tarballs.nixos.org exist in order to - satisfy these requirements. + The curated archives at tarballs.nixos.org exist in order to + satisfy these requirements. - The second point created a significant burden: since the nixpkgs - toolchain used to build a given copy of the binary bootstrap-files - itself used a *previous* copy of the bootstrap-files, this meant - we had to track the provenance of all bootstrap-files tarballs - ever used, for all eternity. There was no explanation of where - the "original" bootstrap-files came from: turtles all the way - down. In spite of all this effort we still can't be sure of our - ability to reproduce the binary bootstrap-files, since the - compilers that built them don't always produce exactly bit-for-bit - deterministic results. + The second point created a significant burden: since the nixpkgs + toolchain used to build a given copy of the binary bootstrap-files + itself used a *previous* copy of the bootstrap-files, this meant + we had to track the provenance of all bootstrap-files tarballs + ever used, for all eternity. There was no explanation of where + the "original" bootstrap-files came from: turtles all the way + down. In spite of all this effort we still can't be sure of our + ability to reproduce the binary bootstrap-files, since the + compilers that built them don't always produce exactly bit-for-bit + deterministic results. - Since this archive contains no binaries and uses a format (NAR) - specifically designed for bit-exact reproducibility, none of the - requirements above apply to `minimal-bootstrap-sources`. + Since this archive contains no binaries and uses a format (NAR) + specifically designed for bit-exact reproducibility, none of the + requirements above apply to `minimal-bootstrap-sources`. */ minimal-bootstrap-sources = derivation { inherit name; diff --git a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/default.nix index 9f3d61b92bc918..bedcb52ede7569 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/default.nix @@ -1,27 +1,42 @@ -{ lib -, newScope +{ + lib, + newScope, }: -lib.makeScope newScope (self: with self; { - inherit (callPackage ./platforms.nix { }) platforms stage0Arch m2libcArch m2libcOS baseAddress; +lib.makeScope newScope ( + self: with self; { + inherit (callPackage ./platforms.nix { }) + platforms + stage0Arch + m2libcArch + m2libcOS + baseAddress + ; - inherit (self.callPackage ./bootstrap-sources.nix {}) version minimal-bootstrap-sources; + inherit (self.callPackage ./bootstrap-sources.nix { }) version minimal-bootstrap-sources; - src = minimal-bootstrap-sources; + src = minimal-bootstrap-sources; - m2libc = src + "/M2libc"; + m2libc = src + "/M2libc"; - hex0 = callPackage ./hex0.nix { }; - inherit (self.hex0) hex0-seed; + hex0 = callPackage ./hex0.nix { }; + inherit (self.hex0) hex0-seed; - kaem = callPackage ./kaem { }; - kaem-minimal = callPackage ./kaem/minimal.nix { }; + kaem = callPackage ./kaem { }; + kaem-minimal = callPackage ./kaem/minimal.nix { }; - mescc-tools-boot = callPackage ./mescc-tools-boot.nix { }; + mescc-tools-boot = callPackage ./mescc-tools-boot.nix { }; - inherit (self.mescc-tools-boot) blood-elf-0 hex2 kaem-unwrapped M1 M2; + inherit (self.mescc-tools-boot) + blood-elf-0 + hex2 + kaem-unwrapped + M1 + M2 + ; - mescc-tools = callPackage ./mescc-tools { }; + mescc-tools = callPackage ./mescc-tools { }; - mescc-tools-extra = callPackage ./mescc-tools-extra { }; -}) + mescc-tools-extra = callPackage ./mescc-tools-extra { }; + } +) diff --git a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/hex0.nix b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/hex0.nix index 9808e25711c159..cc6dbfca73ce39 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/hex0.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/hex0.nix @@ -1,18 +1,21 @@ -{ lib -, derivationWithMeta -, hostPlatform -, src -, version -, platforms -, stage0Arch +{ + lib, + derivationWithMeta, + hostPlatform, + src, + version, + platforms, + stage0Arch, }: let - hash = { - "AArch64" = "sha256-XTPsoKeI6wTZAF0UwEJPzuHelWOJe//wXg4HYO0dEJo="; - "AMD64" = "sha256-RCgK9oZRDQUiWLVkcIBSR2HeoB+Bh0czthrpjFEkCaY="; - "x86" = "sha256-QU3RPGy51W7M2xnfFY1IqruKzusrSLU+L190ztN6JW8="; - }.${stage0Arch} or (throw "Unsupported system: ${hostPlatform.system}"); + hash = + { + "AArch64" = "sha256-XTPsoKeI6wTZAF0UwEJPzuHelWOJe//wXg4HYO0dEJo="; + "AMD64" = "sha256-RCgK9oZRDQUiWLVkcIBSR2HeoB+Bh0czthrpjFEkCaY="; + "x86" = "sha256-QU3RPGy51W7M2xnfFY1IqruKzusrSLU+L190ztN6JW8="; + } + .${stage0Arch} or (throw "Unsupported system: ${hostPlatform.system}"); # Pinned from https://github.com/oriansj/stage0-posix/commit/3189b5f325b7ef8b88e3edec7c1cde4fce73c76c # This 256 byte seed is the only pre-compiled binary in the bootstrap chain. diff --git a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/kaem/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/kaem/default.nix index 547790835c5d5f..a18bb717a85769 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/kaem/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/kaem/default.nix @@ -1,12 +1,13 @@ -{ lib -, derivationWithMeta -, writeText -, kaem -, kaem-unwrapped -, mescc-tools -, mescc-tools-extra -, version -, platforms +{ + lib, + derivationWithMeta, + writeText, + kaem, + kaem-unwrapped, + mescc-tools, + mescc-tools-extra, + version, + platforms, }: # Once mescc-tools-extra is available we can install kaem at /bin/kaem @@ -27,20 +28,31 @@ derivationWithMeta { ]; PATH = lib.makeBinPath [ mescc-tools-extra ]; - passthru.runCommand = name: env: buildCommand: - derivationWithMeta ({ - inherit name; + passthru.runCommand = + name: env: buildCommand: + derivationWithMeta ( + { + inherit name; - builder = "${kaem}/bin/kaem"; - args = [ - "--verbose" - "--strict" - "--file" - (writeText "${name}-builder" buildCommand) - ]; + builder = "${kaem}/bin/kaem"; + args = [ + "--verbose" + "--strict" + "--file" + (writeText "${name}-builder" buildCommand) + ]; - PATH = lib.makeBinPath ((env.nativeBuildInputs or []) ++ [ kaem mescc-tools mescc-tools-extra ]); - } // (builtins.removeAttrs env [ "nativeBuildInputs" ])); + PATH = lib.makeBinPath ( + (env.nativeBuildInputs or [ ]) + ++ [ + kaem + mescc-tools + mescc-tools-extra + ] + ); + } + // (builtins.removeAttrs env [ "nativeBuildInputs" ]) + ); meta = with lib; { description = "Minimal build tool for running scripts on systems that lack any shell"; diff --git a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/kaem/minimal.nix b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/kaem/minimal.nix index ae31302894aab3..51fb5f5115f408 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/kaem/minimal.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/kaem/minimal.nix @@ -1,10 +1,11 @@ -{ lib -, derivationWithMeta -, src -, hex0 -, version -, platforms -, stage0Arch +{ + lib, + derivationWithMeta, + src, + hex0, + version, + platforms, + stage0Arch, }: derivationWithMeta { inherit version; @@ -23,4 +24,3 @@ derivationWithMeta { inherit platforms; }; } - diff --git a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/make-bootstrap-sources.nix b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/make-bootstrap-sources.nix index 6cc7cddb82af42..82f38b7d939cf3 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/make-bootstrap-sources.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/make-bootstrap-sources.nix @@ -11,10 +11,11 @@ # nix-build '' -A make-minimal-bootstrap-sources # -{ lib -, hostPlatform -, fetchFromGitHub -, fetchpatch +{ + lib, + hostPlatform, + fetchFromGitHub, + fetchpatch, }: let @@ -42,10 +43,12 @@ fetchFromGitHub { # aarch64: syscall: mkdir -> mkdirat # https://github.com/oriansj/M2libc/pull/17 - patch -Np1 -d $out/M2libc -i ${(fetchpatch { - url = "https://github.com/oriansj/M2libc/commit/ff7c3023b3ab6cfcffc5364620b25f8d0279e96b.patch"; - hash = "sha256-QAKddv4TixIQHpFa9SVu9fAkeKbzhQaxjaWzW2yJy7A="; - })} + patch -Np1 -d $out/M2libc -i ${ + (fetchpatch { + url = "https://github.com/oriansj/M2libc/commit/ff7c3023b3ab6cfcffc5364620b25f8d0279e96b.patch"; + hash = "sha256-QAKddv4TixIQHpFa9SVu9fAkeKbzhQaxjaWzW2yJy7A="; + }) + } ''; meta = with lib; { diff --git a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/mescc-tools-boot.nix b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/mescc-tools-boot.nix index 2114ffc707b187..c4ece4d0855353 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/mescc-tools-boot.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/mescc-tools-boot.nix @@ -27,17 +27,18 @@ # Warning all binaries prior to the use of blood-elf will not be readable by # Objdump, you may need to use ndism or gdb to view the assembly in the binary. -{ lib -, derivationWithMeta -, hostPlatform -, hex0 -, m2libc -, src -, version -, platforms -, stage0Arch -, m2libcArch -, baseAddress +{ + lib, + derivationWithMeta, + hostPlatform, + hex0, + m2libc, + src, + version, + platforms, + stage0Arch, + m2libcArch, + baseAddress, }: rec { out = placeholder "out"; @@ -46,9 +47,15 @@ rec { bloodFlags = lib.optional hostPlatform.is64bit "--64"; - run = pname: builder: args: + run = + pname: builder: args: derivationWithMeta { - inherit pname version builder args; + inherit + pname + version + builder + args + ; meta = with lib; { description = "Collection of tools written for use in bootstrapping"; @@ -63,7 +70,10 @@ rec { # Phase-1 Build hex1 from hex0 # ################################ - hex1 = run "hex1" hex0 ["${src}/${stage0Arch}/hex1_${stage0Arch}.hex0" out]; + hex1 = run "hex1" hex0 [ + "${src}/${stage0Arch}/hex1_${stage0Arch}.hex0" + out + ]; # hex1 adds support for single character labels and is available in various forms # in mescc-tools/x86_bootstrap to allow you various ways to verify correctness @@ -72,7 +82,10 @@ rec { # Phase-2 Build hex2 from hex1 # ################################ - hex2-0 = run "hex2" hex1 ["${src}/${stage0Arch}/hex2_${stage0Arch}.hex1" out]; + hex2-0 = run "hex2" hex1 [ + "${src}/${stage0Arch}/hex2_${stage0Arch}.hex1" + out + ]; # hex2 adds support for long labels and absolute addresses thus allowing it # to function as an effective linker for later stages of the bootstrap @@ -85,9 +98,15 @@ rec { catm = if hostPlatform.isAarch64 then - run "catm" hex1 ["${src}/${stage0Arch}/catm_${stage0Arch}.hex1" out] + run "catm" hex1 [ + "${src}/${stage0Arch}/catm_${stage0Arch}.hex1" + out + ] else - run "catm" hex2-0 ["${src}/${stage0Arch}/catm_${stage0Arch}.hex2" out]; + run "catm" hex2-0 [ + "${src}/${stage0Arch}/catm_${stage0Arch}.hex2" + out + ]; # catm removes the need for cat or shell support for redirection by providing # equivalent functionality via catm output_file input1 input2 ... inputN @@ -96,8 +115,15 @@ rec { # Phase-3 Build M0 from hex2 # ############################## - M0_hex2 = run "M0.hex2" catm [out "${m2libc}/${m2libcArch}/ELF-${m2libcArch}.hex2" "${src}/${stage0Arch}/M0_${stage0Arch}.hex2"]; - M0 = run "M0" hex2-0 [M0_hex2 out]; + M0_hex2 = run "M0.hex2" catm [ + out + "${m2libc}/${m2libcArch}/ELF-${m2libcArch}.hex2" + "${src}/${stage0Arch}/M0_${stage0Arch}.hex2" + ]; + M0 = run "M0" hex2-0 [ + M0_hex2 + out + ]; # M0 is the architecture specific version of M1 and is by design single # architecture only and will be replaced by the C code version of M1 @@ -106,9 +132,19 @@ rec { # Phase-4 Build cc_arch from M0 # ################################ - cc_arch-0_hex2 = run "cc_arch-0.hex2" M0 ["${src}/${stage0Arch}/cc_${m2libcArch}.M1" out]; - cc_arch-1_hex2 = run "cc_arch-1.hex2" catm [out "${m2libc}/${m2libcArch}/ELF-${m2libcArch}.hex2" cc_arch-0_hex2]; - cc_arch = run "cc_arch" hex2-0 [cc_arch-1_hex2 out]; + cc_arch-0_hex2 = run "cc_arch-0.hex2" M0 [ + "${src}/${stage0Arch}/cc_${m2libcArch}.M1" + out + ]; + cc_arch-1_hex2 = run "cc_arch-1.hex2" catm [ + out + "${m2libc}/${m2libcArch}/ELF-${m2libcArch}.hex2" + cc_arch-0_hex2 + ]; + cc_arch = run "cc_arch" hex2-0 [ + cc_arch-1_hex2 + out + ]; ######################################## # Phase-5 Build M2-Planet from cc_arch # @@ -127,30 +163,69 @@ rec { "${src}/M2-Planet/cc_macro.c" "${src}/M2-Planet/cc.c" ]; - M2-0_M1 = run "M2-0.M1" cc_arch [M2-0_c out]; - M2-0-0_M1 = run "M2-0-0.M1" catm [out "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" "${m2libc}/${m2libcArch}/libc-core.M1" M2-0_M1]; - M2-0_hex2 = run "M2-0.hex2" M0 [M2-0-0_M1 out]; - M2-0-0_hex2 = run "M2-0-0.hex2" catm [out "${m2libc}/${m2libcArch}/ELF-${m2libcArch}.hex2" M2-0_hex2]; - M2 = run "M2" hex2-0 [M2-0-0_hex2 out]; + M2-0_M1 = run "M2-0.M1" cc_arch [ + M2-0_c + out + ]; + M2-0-0_M1 = run "M2-0-0.M1" catm [ + out + "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" + "${m2libc}/${m2libcArch}/libc-core.M1" + M2-0_M1 + ]; + M2-0_hex2 = run "M2-0.hex2" M0 [ + M2-0-0_M1 + out + ]; + M2-0-0_hex2 = run "M2-0-0.hex2" catm [ + out + "${m2libc}/${m2libcArch}/ELF-${m2libcArch}.hex2" + M2-0_hex2 + ]; + M2 = run "M2" hex2-0 [ + M2-0-0_hex2 + out + ]; ############################################ # Phase-6 Build blood-elf-0 from C sources # ############################################ blood-elf-0_M1 = run "blood-elf-0.M1" M2 [ - "--architecture" m2libcArch - "-f" "${m2libc}/${m2libcArch}/linux/bootstrap.c" - "-f" "${m2libc}/bootstrappable.c" - "-f" "${src}/mescc-tools/stringify.c" - "-f" "${src}/mescc-tools/blood-elf.c" + "--architecture" + m2libcArch + "-f" + "${m2libc}/${m2libcArch}/linux/bootstrap.c" + "-f" + "${m2libc}/bootstrappable.c" + "-f" + "${src}/mescc-tools/stringify.c" + "-f" + "${src}/mescc-tools/blood-elf.c" "--bootstrap-mode" - "-o" out + "-o" + out ]; - blood-elf-0-0_M1 = run "blood-elf-0-0.M1" catm [out "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" "${m2libc}/${m2libcArch}/libc-core.M1" blood-elf-0_M1]; - blood-elf-0_hex2 = run "blood-elf-0.hex2" M0 [blood-elf-0-0_M1 out]; - blood-elf-0-0_hex2 = run "blood-elf-0-0.hex2" catm [out "${m2libc}/${m2libcArch}/ELF-${m2libcArch}.hex2" blood-elf-0_hex2]; - blood-elf-0 = run "blood-elf-0" hex2-0 [blood-elf-0-0_hex2 out]; + blood-elf-0-0_M1 = run "blood-elf-0-0.M1" catm [ + out + "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" + "${m2libc}/${m2libcArch}/libc-core.M1" + blood-elf-0_M1 + ]; + blood-elf-0_hex2 = run "blood-elf-0.hex2" M0 [ + blood-elf-0-0_M1 + out + ]; + blood-elf-0-0_hex2 = run "blood-elf-0-0.hex2" catm [ + out + "${m2libc}/${m2libcArch}/ELF-${m2libcArch}.hex2" + blood-elf-0_hex2 + ]; + blood-elf-0 = run "blood-elf-0" hex2-0 [ + blood-elf-0-0_hex2 + out + ]; # This is the last stage where the binaries will not have debug info # and the last piece built that isn't part of the output binaries @@ -160,21 +235,52 @@ rec { ##################################### M1-macro-0_M1 = run "M1-macro-0.M1" M2 [ - "--architecture" m2libcArch - "-f" "${m2libc}/${m2libcArch}/linux/bootstrap.c" - "-f" "${m2libc}/bootstrappable.c" - "-f" "${src}/mescc-tools/stringify.c" - "-f" "${src}/mescc-tools/M1-macro.c" + "--architecture" + m2libcArch + "-f" + "${m2libc}/${m2libcArch}/linux/bootstrap.c" + "-f" + "${m2libc}/bootstrappable.c" + "-f" + "${src}/mescc-tools/stringify.c" + "-f" + "${src}/mescc-tools/M1-macro.c" "--bootstrap-mode" "--debug" - "-o" out + "-o" + out ]; - M1-macro-0-footer_M1 = run "M1-macro-0-footer.M1" blood-elf-0 (bloodFlags ++ ["-f" M1-macro-0_M1 endianFlag "-o" out]); - M1-macro-0-0_M1 = run "M1-macro-0-0.M1" catm [out "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" "${m2libc}/${m2libcArch}/libc-core.M1" M1-macro-0_M1 M1-macro-0-footer_M1]; - M1-macro-0_hex2 = run "M1-macro-0.hex2" M0 [M1-macro-0-0_M1 out]; - M1-macro-0-0_hex2 = run "M1-macro-0-0.hex2" catm [out "${m2libc}/${m2libcArch}/ELF-${m2libcArch}-debug.hex2" M1-macro-0_hex2]; - M1-0 = run "M1-0" hex2-0 [M1-macro-0-0_hex2 out]; + M1-macro-0-footer_M1 = run "M1-macro-0-footer.M1" blood-elf-0 ( + bloodFlags + ++ [ + "-f" + M1-macro-0_M1 + endianFlag + "-o" + out + ] + ); + M1-macro-0-0_M1 = run "M1-macro-0-0.M1" catm [ + out + "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" + "${m2libc}/${m2libcArch}/libc-core.M1" + M1-macro-0_M1 + M1-macro-0-footer_M1 + ]; + M1-macro-0_hex2 = run "M1-macro-0.hex2" M0 [ + M1-macro-0-0_M1 + out + ]; + M1-macro-0-0_hex2 = run "M1-macro-0-0.hex2" catm [ + out + "${m2libc}/${m2libcArch}/ELF-${m2libcArch}-debug.hex2" + M1-macro-0_hex2 + ]; + M1-0 = run "M1-0" hex2-0 [ + M1-macro-0-0_hex2 + out + ]; # This is the last stage where catm will need to be used and the last stage where # M0 is used, as we will being using it's much more powerful and cross-platform @@ -185,40 +291,78 @@ rec { ####################################### hex2_linker-0_M1 = run "hex2_linker-0.M1" M2 [ - "--architecture" m2libcArch - "-f" "${m2libc}/sys/types.h" - "-f" "${m2libc}/stddef.h" - "-f" "${m2libc}/${m2libcArch}/linux/unistd.c" - "-f" "${m2libc}/${m2libcArch}/linux/fcntl.c" - "-f" "${m2libc}/fcntl.c" - "-f" "${m2libc}/${m2libcArch}/linux/sys/stat.c" - "-f" "${m2libc}/stdlib.c" - "-f" "${m2libc}/stdio.h" - "-f" "${m2libc}/stdio.c" - "-f" "${m2libc}/bootstrappable.c" - "-f" "${src}/mescc-tools/hex2.h" - "-f" "${src}/mescc-tools/hex2_linker.c" - "-f" "${src}/mescc-tools/hex2_word.c" - "-f" "${src}/mescc-tools/hex2.c" + "--architecture" + m2libcArch + "-f" + "${m2libc}/sys/types.h" + "-f" + "${m2libc}/stddef.h" + "-f" + "${m2libc}/${m2libcArch}/linux/unistd.c" + "-f" + "${m2libc}/${m2libcArch}/linux/fcntl.c" + "-f" + "${m2libc}/fcntl.c" + "-f" + "${m2libc}/${m2libcArch}/linux/sys/stat.c" + "-f" + "${m2libc}/stdlib.c" + "-f" + "${m2libc}/stdio.h" + "-f" + "${m2libc}/stdio.c" + "-f" + "${m2libc}/bootstrappable.c" + "-f" + "${src}/mescc-tools/hex2.h" + "-f" + "${src}/mescc-tools/hex2_linker.c" + "-f" + "${src}/mescc-tools/hex2_word.c" + "-f" + "${src}/mescc-tools/hex2.c" "--debug" - "-o" out + "-o" + out ]; - hex2_linker-0-footer_M1 = run "hex2_linker-0-footer.M1" blood-elf-0 (bloodFlags ++ ["-f" hex2_linker-0_M1 endianFlag "-o" out]); + hex2_linker-0-footer_M1 = run "hex2_linker-0-footer.M1" blood-elf-0 ( + bloodFlags + ++ [ + "-f" + hex2_linker-0_M1 + endianFlag + "-o" + out + ] + ); hex2_linker-0_hex2 = run "hex2_linker-0.hex2" M1-0 [ - "--architecture" m2libcArch + "--architecture" + m2libcArch endianFlag - "-f" "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" - "-f" "${m2libc}/${m2libcArch}/libc-full.M1" - "-f" hex2_linker-0_M1 - "-f" hex2_linker-0-footer_M1 - "-o" out + "-f" + "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" + "-f" + "${m2libc}/${m2libcArch}/libc-full.M1" + "-f" + hex2_linker-0_M1 + "-f" + hex2_linker-0-footer_M1 + "-o" + out ]; - hex2_linker-0-0_hex2 = run "hex2_linker-0-0.hex2" catm [out "${m2libc}/${m2libcArch}/ELF-${m2libcArch}-debug.hex2" hex2_linker-0_hex2]; + hex2_linker-0-0_hex2 = run "hex2_linker-0-0.hex2" catm [ + out + "${m2libc}/${m2libcArch}/ELF-${m2libcArch}-debug.hex2" + hex2_linker-0_hex2 + ]; - hex2-1 = run "hex2-1" hex2-0 [hex2_linker-0-0_hex2 out]; + hex2-1 = run "hex2-1" hex2-0 [ + hex2_linker-0-0_hex2 + out + ]; # This is the last stage where we will be using the handwritten hex2 and instead # be using the far more powerful, cross-platform version with a bunch more goodies @@ -228,42 +372,76 @@ rec { ################################### M1-macro-1_M1 = run "M1-macro-1.M1" M2 [ - "--architecture" m2libcArch - "-f" "${m2libc}/sys/types.h" - "-f" "${m2libc}/stddef.h" - "-f" "${m2libc}/${m2libcArch}/linux/fcntl.c" - "-f" "${m2libc}/fcntl.c" - "-f" "${m2libc}/${m2libcArch}/linux/unistd.c" - "-f" "${m2libc}/string.c" - "-f" "${m2libc}/stdlib.c" - "-f" "${m2libc}/stdio.h" - "-f" "${m2libc}/stdio.c" - "-f" "${m2libc}/bootstrappable.c" - "-f" "${src}/mescc-tools/stringify.c" - "-f" "${src}/mescc-tools/M1-macro.c" + "--architecture" + m2libcArch + "-f" + "${m2libc}/sys/types.h" + "-f" + "${m2libc}/stddef.h" + "-f" + "${m2libc}/${m2libcArch}/linux/fcntl.c" + "-f" + "${m2libc}/fcntl.c" + "-f" + "${m2libc}/${m2libcArch}/linux/unistd.c" + "-f" + "${m2libc}/string.c" + "-f" + "${m2libc}/stdlib.c" + "-f" + "${m2libc}/stdio.h" + "-f" + "${m2libc}/stdio.c" + "-f" + "${m2libc}/bootstrappable.c" + "-f" + "${src}/mescc-tools/stringify.c" + "-f" + "${src}/mescc-tools/M1-macro.c" "--debug" - "-o" out + "-o" + out ]; - M1-macro-1-footer_M1 = run "M1-macro-1-footer.M1" blood-elf-0 (bloodFlags ++ ["-f" M1-macro-1_M1 endianFlag "-o" out]); + M1-macro-1-footer_M1 = run "M1-macro-1-footer.M1" blood-elf-0 ( + bloodFlags + ++ [ + "-f" + M1-macro-1_M1 + endianFlag + "-o" + out + ] + ); M1-macro-1_hex2 = run "M1-macro-1.hex2" M1-0 [ - "--architecture" m2libcArch + "--architecture" + m2libcArch endianFlag - "-f" "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" - "-f" "${m2libc}/${m2libcArch}/libc-full.M1" - "-f" M1-macro-1_M1 - "-f" M1-macro-1-footer_M1 - "-o" out + "-f" + "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" + "-f" + "${m2libc}/${m2libcArch}/libc-full.M1" + "-f" + M1-macro-1_M1 + "-f" + M1-macro-1-footer_M1 + "-o" + out ]; M1 = run "M1" hex2-1 [ - "--architecture" m2libcArch + "--architecture" + m2libcArch endianFlag - "--base-address" baseAddress - "-f" "${m2libc}/${m2libcArch}/ELF-${m2libcArch}-debug.hex2" - "-f" M1-macro-1_hex2 - "-o" out + "--base-address" + baseAddress + "-f" + "${m2libc}/${m2libcArch}/ELF-${m2libcArch}-debug.hex2" + "-f" + M1-macro-1_hex2 + "-o" + out ]; ###################################### @@ -271,44 +449,80 @@ rec { ###################################### hex2_linker-2_M1 = run "hex2_linker-2.M1" M2 [ - "--architecture" m2libcArch - "-f" "${m2libc}/sys/types.h" - "-f" "${m2libc}/stddef.h" - "-f" "${m2libc}/${m2libcArch}/linux/unistd.c" - "-f" "${m2libc}/${m2libcArch}/linux/fcntl.c" - "-f" "${m2libc}/fcntl.c" - "-f" "${m2libc}/${m2libcArch}/linux/sys/stat.c" - "-f" "${m2libc}/stdlib.c" - "-f" "${m2libc}/stdio.h" - "-f" "${m2libc}/stdio.c" - "-f" "${m2libc}/bootstrappable.c" - "-f" "${src}/mescc-tools/hex2.h" - "-f" "${src}/mescc-tools/hex2_linker.c" - "-f" "${src}/mescc-tools/hex2_word.c" - "-f" "${src}/mescc-tools/hex2.c" + "--architecture" + m2libcArch + "-f" + "${m2libc}/sys/types.h" + "-f" + "${m2libc}/stddef.h" + "-f" + "${m2libc}/${m2libcArch}/linux/unistd.c" + "-f" + "${m2libc}/${m2libcArch}/linux/fcntl.c" + "-f" + "${m2libc}/fcntl.c" + "-f" + "${m2libc}/${m2libcArch}/linux/sys/stat.c" + "-f" + "${m2libc}/stdlib.c" + "-f" + "${m2libc}/stdio.h" + "-f" + "${m2libc}/stdio.c" + "-f" + "${m2libc}/bootstrappable.c" + "-f" + "${src}/mescc-tools/hex2.h" + "-f" + "${src}/mescc-tools/hex2_linker.c" + "-f" + "${src}/mescc-tools/hex2_word.c" + "-f" + "${src}/mescc-tools/hex2.c" "--debug" - "-o" out + "-o" + out ]; - hex2_linker-2-footer_M1 = run "hex2_linker-2-footer.M1" blood-elf-0 (bloodFlags ++ ["-f" hex2_linker-2_M1 endianFlag "-o" out]); + hex2_linker-2-footer_M1 = run "hex2_linker-2-footer.M1" blood-elf-0 ( + bloodFlags + ++ [ + "-f" + hex2_linker-2_M1 + endianFlag + "-o" + out + ] + ); hex2_linker-2_hex2 = run "hex2_linker-2.hex2" M1 [ - "--architecture" m2libcArch + "--architecture" + m2libcArch endianFlag - "-f" "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" - "-f" "${m2libc}/${m2libcArch}/libc-full.M1" - "-f" hex2_linker-2_M1 - "-f" hex2_linker-2-footer_M1 - "-o" out + "-f" + "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" + "-f" + "${m2libc}/${m2libcArch}/libc-full.M1" + "-f" + hex2_linker-2_M1 + "-f" + hex2_linker-2-footer_M1 + "-o" + out ]; hex2 = run "hex2" hex2-1 [ - "--architecture" m2libcArch + "--architecture" + m2libcArch endianFlag - "--base-address" baseAddress - "-f" "${m2libc}/${m2libcArch}/ELF-${m2libcArch}-debug.hex2" - "-f" hex2_linker-2_hex2 - "-o" out + "--base-address" + baseAddress + "-f" + "${m2libc}/${m2libcArch}/ELF-${m2libcArch}-debug.hex2" + "-f" + hex2_linker-2_hex2 + "-o" + out ]; ###################################### @@ -316,43 +530,79 @@ rec { ###################################### kaem_M1 = run "kaem.M1" M2 [ - "--architecture" m2libcArch - "-f" "${m2libc}/sys/types.h" - "-f" "${m2libc}/stddef.h" - "-f" "${m2libc}/string.c" - "-f" "${m2libc}/${m2libcArch}/linux/unistd.c" - "-f" "${m2libc}/${m2libcArch}/linux/fcntl.c" - "-f" "${m2libc}/fcntl.c" - "-f" "${m2libc}/stdlib.c" - "-f" "${m2libc}/stdio.h" - "-f" "${m2libc}/stdio.c" - "-f" "${m2libc}/bootstrappable.c" - "-f" "${src}/mescc-tools/Kaem/kaem.h" - "-f" "${src}/mescc-tools/Kaem/variable.c" - "-f" "${src}/mescc-tools/Kaem/kaem_globals.c" - "-f" "${src}/mescc-tools/Kaem/kaem.c" + "--architecture" + m2libcArch + "-f" + "${m2libc}/sys/types.h" + "-f" + "${m2libc}/stddef.h" + "-f" + "${m2libc}/string.c" + "-f" + "${m2libc}/${m2libcArch}/linux/unistd.c" + "-f" + "${m2libc}/${m2libcArch}/linux/fcntl.c" + "-f" + "${m2libc}/fcntl.c" + "-f" + "${m2libc}/stdlib.c" + "-f" + "${m2libc}/stdio.h" + "-f" + "${m2libc}/stdio.c" + "-f" + "${m2libc}/bootstrappable.c" + "-f" + "${src}/mescc-tools/Kaem/kaem.h" + "-f" + "${src}/mescc-tools/Kaem/variable.c" + "-f" + "${src}/mescc-tools/Kaem/kaem_globals.c" + "-f" + "${src}/mescc-tools/Kaem/kaem.c" "--debug" - "-o" out + "-o" + out ]; - kaem-footer_M1 = run "kaem-footer.M1" blood-elf-0 (bloodFlags ++ ["-f" kaem_M1 endianFlag "-o" out]); + kaem-footer_M1 = run "kaem-footer.M1" blood-elf-0 ( + bloodFlags + ++ [ + "-f" + kaem_M1 + endianFlag + "-o" + out + ] + ); kaem_hex2 = run "kaem.hex2" M1 [ - "--architecture" m2libcArch + "--architecture" + m2libcArch endianFlag - "-f" "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" - "-f" "${m2libc}/${m2libcArch}/libc-full.M1" - "-f" kaem_M1 - "-f" kaem-footer_M1 - "-o" out + "-f" + "${m2libc}/${m2libcArch}/${m2libcArch}_defs.M1" + "-f" + "${m2libc}/${m2libcArch}/libc-full.M1" + "-f" + kaem_M1 + "-f" + kaem-footer_M1 + "-o" + out ]; kaem-unwrapped = run "kaem-unwrapped" hex2 [ - "--architecture" m2libcArch + "--architecture" + m2libcArch endianFlag - "-f" "${m2libc}/${m2libcArch}/ELF-${m2libcArch}-debug.hex2" - "-f" kaem_hex2 - "--base-address" baseAddress - "-o" out + "-f" + "${m2libc}/${m2libcArch}/ELF-${m2libcArch}-debug.hex2" + "-f" + kaem_hex2 + "--base-address" + baseAddress + "-o" + out ]; } diff --git a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/mescc-tools-extra/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/mescc-tools-extra/default.nix index eee00491c44601..28381dc81ca610 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/mescc-tools-extra/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/mescc-tools-extra/default.nix @@ -1,15 +1,22 @@ -{ lib -, derivationWithMeta -, kaem-unwrapped -, mescc-tools -, src -, version -, platforms -, m2libcArch -, m2libcOS +{ + lib, + derivationWithMeta, + kaem-unwrapped, + mescc-tools, + src, + version, + platforms, + m2libcArch, + m2libcOS, }: derivationWithMeta { - inherit version src mescc-tools m2libcArch m2libcOS; + inherit + version + src + mescc-tools + m2libcArch + m2libcOS + ; pname = "mescc-tools-extra"; builder = kaem-unwrapped; args = [ diff --git a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/mescc-tools/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/mescc-tools/default.nix index 4a9c734981e2f1..769f0df3990937 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/mescc-tools/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/mescc-tools/default.nix @@ -1,17 +1,18 @@ -{ lib -, derivationWithMeta -, hostPlatform -, kaem-unwrapped -, M1 -, M2 -, blood-elf-0 -, hex2 -, m2libc -, src -, version -, platforms -, m2libcArch -, baseAddress +{ + lib, + derivationWithMeta, + hostPlatform, + kaem-unwrapped, + M1, + M2, + blood-elf-0, + hex2, + m2libc, + src, + version, + platforms, + m2libcArch, + baseAddress, }: let @@ -19,7 +20,8 @@ let bloodFlag = if hostPlatform.is64bit then "--64" else " "; # We need a few tools from mescc-tools-extra to assemble the output folder - buildMesccToolsExtraUtil = name: + buildMesccToolsExtraUtil = + name: derivationWithMeta { pname = "mescc-tools-extra-${name}"; builder = kaem-unwrapped; @@ -62,7 +64,15 @@ let -o ''${out} '') ]; - inherit version M1 M2 blood-elf-0 hex2 m2libc src; + inherit + version + M1 + M2 + blood-elf-0 + hex2 + m2libc + src + ; }; mkdir = buildMesccToolsExtraUtil "mkdir"; cp = buildMesccToolsExtraUtil "cp"; @@ -78,7 +88,23 @@ derivationWithMeta { "--file" ./build.kaem ]; - inherit version M1 M2 blood-elf-0 hex2 mkdir cp chmod replace m2libc src m2libcArch baseAddress bloodFlag endianFlag; + inherit + version + M1 + M2 + blood-elf-0 + hex2 + mkdir + cp + chmod + replace + m2libc + src + m2libcArch + baseAddress + bloodFlag + endianFlag + ; meta = with lib; { description = "Collection of tools written for use in bootstrapping"; diff --git a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/platforms.nix b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/platforms.nix index 53147df3344415..fb96f91fa91757 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/platforms.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/stage0-posix/platforms.nix @@ -1,6 +1,7 @@ # Platform specific constants -{ lib -, hostPlatform +{ + lib, + hostPlatform, }: rec { @@ -12,21 +13,26 @@ rec { ]; # system arch as used within the stage0 project - stage0Arch = { - "aarch64-linux" = "AArch64"; - "i686-linux" = "x86"; - "x86_64-linux" = "AMD64"; - }.${hostPlatform.system} or (throw "Unsupported system: ${hostPlatform.system}"); + stage0Arch = + { + "aarch64-linux" = "AArch64"; + "i686-linux" = "x86"; + "x86_64-linux" = "AMD64"; + } + .${hostPlatform.system} or (throw "Unsupported system: ${hostPlatform.system}"); # lower-case form is widely used by m2libc m2libcArch = lib.toLower stage0Arch; # Passed to M2-Mesoplanet as --operating-system - m2libcOS = if hostPlatform.isLinux then "linux" else throw "Unsupported system: ${hostPlatform.system}"; + m2libcOS = + if hostPlatform.isLinux then "linux" else throw "Unsupported system: ${hostPlatform.system}"; - baseAddress = { - "aarch64-linux" = "0x00600000"; - "i686-linux" = "0x08048000"; - "x86_64-linux" = "0x00600000"; - }.${hostPlatform.system} or (throw "Unsupported system: ${hostPlatform.system}"); + baseAddress = + { + "aarch64-linux" = "0x00600000"; + "i686-linux" = "0x08048000"; + "x86_64-linux" = "0x00600000"; + } + .${hostPlatform.system} or (throw "Unsupported system: ${hostPlatform.system}"); } diff --git a/pkgs/os-specific/linux/minimal-bootstrap/tinycc/bootstrappable.nix b/pkgs/os-specific/linux/minimal-bootstrap/tinycc/bootstrappable.nix index 83d89012b0fc35..594ac6768a60b8 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/tinycc/bootstrappable.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/tinycc/bootstrappable.nix @@ -7,12 +7,13 @@ # # SPDX-License-Identifier: GPL-3.0-or-later -{ lib -, callPackage -, fetchurl -, kaem -, mes -, mes-libc +{ + lib, + callPackage, + fetchurl, + kaem, + mes, + mes-libc, }: let inherit (callPackage ./common.nix { }) buildTinyccMes recompileLibc; @@ -24,17 +25,19 @@ let url = "https://gitlab.com/janneke/tinycc/-/archive/${rev}/tinycc-${rev}.tar.gz"; sha256 = "1a0cw9a62qc76qqn5sjmp3xrbbvsz2dxrw21lrnx9q0s74mwaxbq"; }; - src = (kaem.runCommand "tinycc-bootstrappable-${version}-source" {} '' - ungz --file ${tarball} --output tinycc.tar - mkdir -p ''${out} - cd ''${out} - untar --file ''${NIX_BUILD_TOP}/tinycc.tar + src = + (kaem.runCommand "tinycc-bootstrappable-${version}-source" { } '' + ungz --file ${tarball} --output tinycc.tar + mkdir -p ''${out} + cd ''${out} + untar --file ''${NIX_BUILD_TOP}/tinycc.tar - # Patch - cd tinycc-${rev} - # Static link by default - replace --file libtcc.c --output libtcc.c --match-on "s->ms_extensions = 1;" --replace-with "s->ms_extensions = 1; s->static_link = 1;" - '') + "/tinycc-${rev}"; + # Patch + cd tinycc-${rev} + # Static link by default + replace --file libtcc.c --output libtcc.c --match-on "s->ms_extensions = 1;" --replace-with "s->ms_extensions = 1; s->static_link = 1;" + '') + + "/tinycc-${rev}"; meta = with lib; { description = "Tiny C Compiler's bootstrappable fork"; @@ -47,43 +50,48 @@ let pname = "tinycc-boot-mes"; tinycc-boot-mes = rec { - compiler = kaem.runCommand "${pname}-${version}" { - passthru.tests.get-version = result: kaem.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/tcc -version - mkdir ''${out} - ''; - } '' - catm config.h - ${mes.compiler}/bin/mes --no-auto-compile -e main ${mes.srcPost.bin}/bin/mescc.scm -- \ - -S \ - -o tcc.s \ - -I . \ - -D BOOTSTRAP=1 \ - -I ${src} \ - -D TCC_TARGET_I386=1 \ - -D inline= \ - -D CONFIG_TCCDIR=\"\" \ - -D CONFIG_SYSROOT=\"\" \ - -D CONFIG_TCC_CRTPREFIX=\"{B}\" \ - -D CONFIG_TCC_ELFINTERP=\"/mes/loader\" \ - -D CONFIG_TCC_LIBPATHS=\"{B}\" \ - -D CONFIG_TCC_SYSINCLUDEPATHS=\"${mes-libc}/include\" \ - -D TCC_LIBGCC=\"${mes-libc}/lib/x86-mes/libc.a\" \ - -D CONFIG_TCC_LIBTCC1_MES=0 \ - -D CONFIG_TCCBOOT=1 \ - -D CONFIG_TCC_STATIC=1 \ - -D CONFIG_USE_LIBGCC=1 \ - -D TCC_MES_LIBC=1 \ - -D TCC_VERSION=\"${version}\" \ - -D ONE_SOURCE=1 \ - ${src}/tcc.c - mkdir -p ''${out}/bin - ${mes.compiler}/bin/mes --no-auto-compile -e main ${mes.srcPost.bin}/bin/mescc.scm -- \ - -L ${mes.libs}/lib \ - -l c+tcc \ - -o ''${out}/bin/tcc \ - tcc.s - ''; + compiler = + kaem.runCommand "${pname}-${version}" + { + passthru.tests.get-version = + result: + kaem.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/tcc -version + mkdir ''${out} + ''; + } + '' + catm config.h + ${mes.compiler}/bin/mes --no-auto-compile -e main ${mes.srcPost.bin}/bin/mescc.scm -- \ + -S \ + -o tcc.s \ + -I . \ + -D BOOTSTRAP=1 \ + -I ${src} \ + -D TCC_TARGET_I386=1 \ + -D inline= \ + -D CONFIG_TCCDIR=\"\" \ + -D CONFIG_SYSROOT=\"\" \ + -D CONFIG_TCC_CRTPREFIX=\"{B}\" \ + -D CONFIG_TCC_ELFINTERP=\"/mes/loader\" \ + -D CONFIG_TCC_LIBPATHS=\"{B}\" \ + -D CONFIG_TCC_SYSINCLUDEPATHS=\"${mes-libc}/include\" \ + -D TCC_LIBGCC=\"${mes-libc}/lib/x86-mes/libc.a\" \ + -D CONFIG_TCC_LIBTCC1_MES=0 \ + -D CONFIG_TCCBOOT=1 \ + -D CONFIG_TCC_STATIC=1 \ + -D CONFIG_USE_LIBGCC=1 \ + -D TCC_MES_LIBC=1 \ + -D TCC_VERSION=\"${version}\" \ + -D ONE_SOURCE=1 \ + ${src}/tcc.c + mkdir -p ''${out}/bin + ${mes.compiler}/bin/mes --no-auto-compile -e main ${mes.srcPost.bin}/bin/mescc.scm -- \ + -L ${mes.libs}/lib \ + -l c+tcc \ + -o ''${out}/bin/tcc \ + tcc.s + ''; libs = recompileLibc { inherit pname version; diff --git a/pkgs/os-specific/linux/minimal-bootstrap/tinycc/common.nix b/pkgs/os-specific/linux/minimal-bootstrap/tinycc/common.nix index 28dde329876729..7bee5011f0b814 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/tinycc/common.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/tinycc/common.nix @@ -1,104 +1,130 @@ -{ lib -, kaem -, mes-libc +{ + lib, + kaem, + mes-libc, }: rec { # Recompile libc: crt{1,n,i}, libtcc.a, libc.a, libgetopt.a recompileLibc = - { tcc - , pname - , version - , src - , libtccOptions + { + tcc, + pname, + version, + src, + libtccOptions, }: let - crt = kaem.runCommand "crt" {} '' - mkdir -p ''${out}/lib - ${tcc}/bin/tcc ${mes-libc.CFLAGS} -c -o ''${out}/lib/crt1.o ${mes-libc}/lib/crt1.c - ${tcc}/bin/tcc ${mes-libc.CFLAGS} -c -o ''${out}/lib/crtn.o ${mes-libc}/lib/crtn.c - ${tcc}/bin/tcc ${mes-libc.CFLAGS} -c -o ''${out}/lib/crti.o ${mes-libc}/lib/crti.c - ''; + crt = kaem.runCommand "crt" { } '' + mkdir -p ''${out}/lib + ${tcc}/bin/tcc ${mes-libc.CFLAGS} -c -o ''${out}/lib/crt1.o ${mes-libc}/lib/crt1.c + ${tcc}/bin/tcc ${mes-libc.CFLAGS} -c -o ''${out}/lib/crtn.o ${mes-libc}/lib/crtn.c + ${tcc}/bin/tcc ${mes-libc.CFLAGS} -c -o ''${out}/lib/crti.o ${mes-libc}/lib/crti.c + ''; - library = lib: options: source: kaem.runCommand "${lib}.a" {} '' - ${tcc}/bin/tcc ${options} -c -o ${lib}.o ${source} - ${tcc}/bin/tcc -ar cr ''${out} ${lib}.o - ''; + library = + lib: options: source: + kaem.runCommand "${lib}.a" { } '' + ${tcc}/bin/tcc ${options} -c -o ${lib}.o ${source} + ${tcc}/bin/tcc -ar cr ''${out} ${lib}.o + ''; - libtcc1 = library "libtcc1" libtccOptions "${src}/lib/libtcc1.c"; - libc = library "libc" mes-libc.CFLAGS "${mes-libc}/lib/libc.c"; - libgetopt = library "libgetopt" mes-libc.CFLAGS "${mes-libc}/lib/libgetopt.c"; - in - kaem.runCommand "${pname}-libs-${version}" {} '' - mkdir -p ''${out}/lib - cp ${crt}/lib/crt1.o ''${out}/lib - cp ${crt}/lib/crtn.o ''${out}/lib - cp ${crt}/lib/crti.o ''${out}/lib - cp ${libtcc1} ''${out}/lib/libtcc1.a - cp ${libc} ''${out}/lib/libc.a - cp ${libgetopt} ''${out}/lib/libgetopt.a - ''; + libtcc1 = library "libtcc1" libtccOptions "${src}/lib/libtcc1.c"; + libc = library "libc" mes-libc.CFLAGS "${mes-libc}/lib/libc.c"; + libgetopt = library "libgetopt" mes-libc.CFLAGS "${mes-libc}/lib/libgetopt.c"; + in + kaem.runCommand "${pname}-libs-${version}" { } '' + mkdir -p ''${out}/lib + cp ${crt}/lib/crt1.o ''${out}/lib + cp ${crt}/lib/crtn.o ''${out}/lib + cp ${crt}/lib/crti.o ''${out}/lib + cp ${libtcc1} ''${out}/lib/libtcc1.a + cp ${libc} ''${out}/lib/libc.a + cp ${libgetopt} ''${out}/lib/libgetopt.a + ''; buildTinyccMes = - { pname - , version - , src - , prev - , buildOptions - , libtccBuildOptions - , meta + { + pname, + version, + src, + prev, + buildOptions, + libtccBuildOptions, + meta, }: let options = lib.strings.concatStringsSep " " buildOptions; - libtccOptions = lib.strings.concatStringsSep " " - (["-c" "-D" "TCC_TARGET_I386=1" ] ++ libtccBuildOptions); - compiler = kaem.runCommand "${pname}-${version}" { - inherit pname version meta; - passthru.tests = rec { - get-version = result: kaem.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/tcc -version - mkdir ''${out} + libtccOptions = lib.strings.concatStringsSep " " ( + [ + "-c" + "-D" + "TCC_TARGET_I386=1" + ] + ++ libtccBuildOptions + ); + compiler = + kaem.runCommand "${pname}-${version}" + { + inherit pname version meta; + passthru.tests = rec { + get-version = + result: + kaem.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/tcc -version + mkdir ''${out} + ''; + chain = + result: + kaem.runCommand "${pname}-chain-${version}" { } '' + echo ${prev.compiler.tests.chain or prev.compiler.tests.get-version}; + ${result}/bin/tcc -version + mkdir ''${out} + ''; + }; + } + '' + catm config.h + mkdir -p ''${out}/bin + ${prev.compiler}/bin/tcc \ + -B ${prev.libs}/lib \ + -g \ + -v \ + -o ''${out}/bin/tcc \ + -D BOOTSTRAP=1 \ + ${options} \ + -I . \ + -I ${src} \ + -D TCC_TARGET_I386=1 \ + -D CONFIG_TCCDIR=\"\" \ + -D CONFIG_SYSROOT=\"\" \ + -D CONFIG_TCC_CRTPREFIX=\"{B}\" \ + -D CONFIG_TCC_ELFINTERP=\"\" \ + -D CONFIG_TCC_LIBPATHS=\"{B}\" \ + -D CONFIG_TCC_SYSINCLUDEPATHS=\"${mes-libc}/include\" \ + -D TCC_LIBGCC=\"libc.a\" \ + -D TCC_LIBTCC1=\"libtcc1.a\" \ + -D CONFIG_TCCBOOT=1 \ + -D CONFIG_TCC_STATIC=1 \ + -D CONFIG_USE_LIBGCC=1 \ + -D TCC_MES_LIBC=1 \ + -D TCC_VERSION=\"${version}\" \ + -D ONE_SOURCE=1 \ + ${src}/tcc.c ''; - chain = result: kaem.runCommand "${pname}-chain-${version}" {} '' - echo ${prev.compiler.tests.chain or prev.compiler.tests.get-version}; - ${result}/bin/tcc -version - mkdir ''${out} - ''; - }; - } '' - catm config.h - mkdir -p ''${out}/bin - ${prev.compiler}/bin/tcc \ - -B ${prev.libs}/lib \ - -g \ - -v \ - -o ''${out}/bin/tcc \ - -D BOOTSTRAP=1 \ - ${options} \ - -I . \ - -I ${src} \ - -D TCC_TARGET_I386=1 \ - -D CONFIG_TCCDIR=\"\" \ - -D CONFIG_SYSROOT=\"\" \ - -D CONFIG_TCC_CRTPREFIX=\"{B}\" \ - -D CONFIG_TCC_ELFINTERP=\"\" \ - -D CONFIG_TCC_LIBPATHS=\"{B}\" \ - -D CONFIG_TCC_SYSINCLUDEPATHS=\"${mes-libc}/include\" \ - -D TCC_LIBGCC=\"libc.a\" \ - -D TCC_LIBTCC1=\"libtcc1.a\" \ - -D CONFIG_TCCBOOT=1 \ - -D CONFIG_TCC_STATIC=1 \ - -D CONFIG_USE_LIBGCC=1 \ - -D TCC_MES_LIBC=1 \ - -D TCC_VERSION=\"${version}\" \ - -D ONE_SOURCE=1 \ - ${src}/tcc.c - ''; - libs = recompileLibc { - inherit pname version src libtccOptions; - tcc = compiler; + libs = recompileLibc { + inherit + pname + version + src + libtccOptions + ; + tcc = compiler; + }; + in + { + inherit prev compiler libs; }; - in { inherit prev compiler libs; }; } diff --git a/pkgs/os-specific/linux/minimal-bootstrap/tinycc/mes.nix b/pkgs/os-specific/linux/minimal-bootstrap/tinycc/mes.nix index 55f6321412db80..76f5ff9587ae4a 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/tinycc/mes.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/tinycc/mes.nix @@ -4,11 +4,12 @@ # # SPDX-License-Identifier: GPL-3.0-or-later -{ lib -, fetchurl -, callPackage -, kaem -, tinycc-bootstrappable +{ + lib, + fetchurl, + callPackage, + kaem, + tinycc-bootstrappable, }: let inherit (callPackage ./common.nix { }) buildTinyccMes; @@ -20,17 +21,19 @@ let url = "https://repo.or.cz/tinycc.git/snapshot/${rev}.tar.gz"; sha256 = "11idrvbwfgj1d03crv994mpbbbyg63j1k64lw1gjy7mkiifw2xap"; }; - src = (kaem.runCommand "tinycc-${version}-source" {} '' - ungz --file ${tarball} --output tinycc.tar - mkdir -p ''${out} - cd ''${out} - untar --file ''${NIX_BUILD_TOP}/tinycc.tar + src = + (kaem.runCommand "tinycc-${version}-source" { } '' + ungz --file ${tarball} --output tinycc.tar + mkdir -p ''${out} + cd ''${out} + untar --file ''${NIX_BUILD_TOP}/tinycc.tar - # Patch - cd tinycc-${builtins.substring 0 7 rev} - # Static link by default - replace --file libtcc.c --output libtcc.c --match-on "s->ms_extensions = 1;" --replace-with "s->ms_extensions = 1; s->static_link = 1;" - '') + "/tinycc-${builtins.substring 0 7 rev}"; + # Patch + cd tinycc-${builtins.substring 0 7 rev} + # Static link by default + replace --file libtcc.c --output libtcc.c --match-on "s->ms_extensions = 1;" --replace-with "s->ms_extensions = 1; s->static_link = 1;" + '') + + "/tinycc-${builtins.substring 0 7 rev}"; meta = with lib; { description = "Small, fast, and embeddable C compiler and interpreter"; @@ -40,7 +43,7 @@ let platforms = [ "i686-linux" ]; }; - tccdefs = kaem.runCommand "tccdefs-${version}" {} '' + tccdefs = kaem.runCommand "tccdefs-${version}" { } '' mkdir ''${out} ${tinycc-bootstrappable.compiler}/bin/tcc \ -B ${tinycc-bootstrappable.libs}/lib \ diff --git a/pkgs/os-specific/linux/minimal-bootstrap/tinycc/musl.nix b/pkgs/os-specific/linux/minimal-bootstrap/tinycc/musl.nix index 4d26faac20b16e..75b64f579c4828 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/tinycc/musl.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/tinycc/musl.nix @@ -1,12 +1,13 @@ -{ lib -, fetchurl -, callPackage -, bash -, tinycc-bootstrappable -, musl -, gnupatch -, gnutar -, gzip +{ + lib, + fetchurl, + callPackage, + bash, + tinycc-bootstrappable, + musl, + gnupatch, + gnutar, + gzip, }: let pname = "tinycc-musl"; @@ -33,103 +34,107 @@ let platforms = [ "i686-linux" ]; }; - tinycc-musl = bash.runCommand "${pname}-${version}" { - inherit pname version meta; + tinycc-musl = + bash.runCommand "${pname}-${version}" + { + inherit pname version meta; - nativeBuildInputs = [ - tinycc-bootstrappable.compiler - gnupatch - gnutar - gzip - ]; - } '' - # Unpack - tar xzf ${src} - cd tinycc-${builtins.substring 0 7 rev} + nativeBuildInputs = [ + tinycc-bootstrappable.compiler + gnupatch + gnutar + gzip + ]; + } + '' + # Unpack + tar xzf ${src} + cd tinycc-${builtins.substring 0 7 rev} - # Patch - ${lib.concatMapStringsSep "\n" (f: "patch -Np0 -i ${f}") patches} + # Patch + ${lib.concatMapStringsSep "\n" (f: "patch -Np0 -i ${f}") patches} - # Configure - touch config.h + # Configure + touch config.h - # Build - # We first have to recompile using tcc-0.9.26 as tcc-0.9.27 is not self-hosting, - # but when linked with musl it is. - ln -s ${musl}/lib/libtcc1.a ./libtcc1.a + # Build + # We first have to recompile using tcc-0.9.26 as tcc-0.9.27 is not self-hosting, + # but when linked with musl it is. + ln -s ${musl}/lib/libtcc1.a ./libtcc1.a - tcc \ - -B ${tinycc-bootstrappable.libs}/lib \ - -DC2STR \ - -o c2str \ - conftest.c - ./c2str include/tccdefs.h tccdefs_.h + tcc \ + -B ${tinycc-bootstrappable.libs}/lib \ + -DC2STR \ + -o c2str \ + conftest.c + ./c2str include/tccdefs.h tccdefs_.h - tcc -v \ - -static \ - -o tcc-musl \ - -D TCC_TARGET_I386=1 \ - -D CONFIG_TCCDIR=\"\" \ - -D CONFIG_TCC_CRTPREFIX=\"{B}\" \ - -D CONFIG_TCC_ELFINTERP=\"/musl/loader\" \ - -D CONFIG_TCC_LIBPATHS=\"{B}\" \ - -D CONFIG_TCC_SYSINCLUDEPATHS=\"${musl}/include\" \ - -D TCC_LIBGCC=\"libc.a\" \ - -D TCC_LIBTCC1=\"libtcc1.a\" \ - -D CONFIG_TCC_STATIC=1 \ - -D CONFIG_USE_LIBGCC=1 \ - -D TCC_VERSION=\"0.9.27\" \ - -D ONE_SOURCE=1 \ - -D TCC_MUSL=1 \ - -D CONFIG_TCC_PREDEFS=1 \ - -D CONFIG_TCC_SEMLOCK=0 \ - -B . \ - -B ${tinycc-bootstrappable.libs}/lib \ - tcc.c - # libtcc1.a - rm -f libtcc1.a - tcc -c -D HAVE_CONFIG_H=1 lib/libtcc1.c - tcc -ar cr libtcc1.a libtcc1.o + tcc -v \ + -static \ + -o tcc-musl \ + -D TCC_TARGET_I386=1 \ + -D CONFIG_TCCDIR=\"\" \ + -D CONFIG_TCC_CRTPREFIX=\"{B}\" \ + -D CONFIG_TCC_ELFINTERP=\"/musl/loader\" \ + -D CONFIG_TCC_LIBPATHS=\"{B}\" \ + -D CONFIG_TCC_SYSINCLUDEPATHS=\"${musl}/include\" \ + -D TCC_LIBGCC=\"libc.a\" \ + -D TCC_LIBTCC1=\"libtcc1.a\" \ + -D CONFIG_TCC_STATIC=1 \ + -D CONFIG_USE_LIBGCC=1 \ + -D TCC_VERSION=\"0.9.27\" \ + -D ONE_SOURCE=1 \ + -D TCC_MUSL=1 \ + -D CONFIG_TCC_PREDEFS=1 \ + -D CONFIG_TCC_SEMLOCK=0 \ + -B . \ + -B ${tinycc-bootstrappable.libs}/lib \ + tcc.c + # libtcc1.a + rm -f libtcc1.a + tcc -c -D HAVE_CONFIG_H=1 lib/libtcc1.c + tcc -ar cr libtcc1.a libtcc1.o - # Rebuild tcc-musl with itself - ./tcc-musl \ - -v \ - -static \ - -o tcc-musl \ - -D TCC_TARGET_I386=1 \ - -D CONFIG_TCCDIR=\"\" \ - -D CONFIG_TCC_CRTPREFIX=\"{B}\" \ - -D CONFIG_TCC_ELFINTERP=\"/musl/loader\" \ - -D CONFIG_TCC_LIBPATHS=\"{B}\" \ - -D CONFIG_TCC_SYSINCLUDEPATHS=\"${musl}/include\" \ - -D TCC_LIBGCC=\"libc.a\" \ - -D TCC_LIBTCC1=\"libtcc1.a\" \ - -D CONFIG_TCC_STATIC=1 \ - -D CONFIG_USE_LIBGCC=1 \ - -D TCC_VERSION=\"0.9.27\" \ - -D ONE_SOURCE=1 \ - -D TCC_MUSL=1 \ - -D CONFIG_TCC_PREDEFS=1 \ - -D CONFIG_TCC_SEMLOCK=0 \ - -B . \ - -B ${musl}/lib \ - tcc.c - # libtcc1.a - rm -f libtcc1.a - ./tcc-musl -c -D HAVE_CONFIG_H=1 lib/libtcc1.c - ./tcc-musl -c -D HAVE_CONFIG_H=1 lib/alloca.S - ./tcc-musl -ar cr libtcc1.a libtcc1.o alloca.o + # Rebuild tcc-musl with itself + ./tcc-musl \ + -v \ + -static \ + -o tcc-musl \ + -D TCC_TARGET_I386=1 \ + -D CONFIG_TCCDIR=\"\" \ + -D CONFIG_TCC_CRTPREFIX=\"{B}\" \ + -D CONFIG_TCC_ELFINTERP=\"/musl/loader\" \ + -D CONFIG_TCC_LIBPATHS=\"{B}\" \ + -D CONFIG_TCC_SYSINCLUDEPATHS=\"${musl}/include\" \ + -D TCC_LIBGCC=\"libc.a\" \ + -D TCC_LIBTCC1=\"libtcc1.a\" \ + -D CONFIG_TCC_STATIC=1 \ + -D CONFIG_USE_LIBGCC=1 \ + -D TCC_VERSION=\"0.9.27\" \ + -D ONE_SOURCE=1 \ + -D TCC_MUSL=1 \ + -D CONFIG_TCC_PREDEFS=1 \ + -D CONFIG_TCC_SEMLOCK=0 \ + -B . \ + -B ${musl}/lib \ + tcc.c + # libtcc1.a + rm -f libtcc1.a + ./tcc-musl -c -D HAVE_CONFIG_H=1 lib/libtcc1.c + ./tcc-musl -c -D HAVE_CONFIG_H=1 lib/alloca.S + ./tcc-musl -ar cr libtcc1.a libtcc1.o alloca.o - # Install - install -D tcc-musl $out/bin/tcc - install -Dm444 libtcc1.a $out/lib/libtcc1.a - ''; + # Install + install -D tcc-musl $out/bin/tcc + install -Dm444 libtcc1.a $out/lib/libtcc1.a + ''; in { compiler = bash.runCommand "${pname}-${version}-compiler" { inherit pname version meta; - passthru.tests.hello-world = result: - bash.runCommand "${pname}-simple-program-${version}" {} '' + passthru.tests.hello-world = + result: + bash.runCommand "${pname}-simple-program-${version}" { } '' cat <> test.c #include int main() { @@ -144,12 +149,15 @@ in passthru.tinycc-musl = tinycc-musl; } "install -D ${tinycc-musl}/bin/tcc $out/bin/tcc"; - libs = bash.runCommand "${pname}-${version}-libs" { - inherit pname version meta; - } '' - mkdir $out - cp -r ${musl}/* $out - chmod +w $out/lib/libtcc1.a - cp ${tinycc-musl}/lib/libtcc1.a $out/lib/libtcc1.a - ''; + libs = + bash.runCommand "${pname}-${version}-libs" + { + inherit pname version meta; + } + '' + mkdir $out + cp -r ${musl}/* $out + chmod +w $out/lib/libtcc1.a + cp ${tinycc-musl}/lib/libtcc1.a $out/lib/libtcc1.a + ''; } diff --git a/pkgs/os-specific/linux/minimal-bootstrap/utils.nix b/pkgs/os-specific/linux/minimal-bootstrap/utils.nix index cc8c04619169e5..ba6cd71b5e0cb5 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/utils.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/utils.nix @@ -1,34 +1,48 @@ -{ lib -, buildPlatform -, callPackage -, kaem -, mescc-tools-extra -, checkMeta +{ + lib, + buildPlatform, + callPackage, + kaem, + mescc-tools-extra, + checkMeta, }: rec { - derivationWithMeta = attrs: + derivationWithMeta = + attrs: let - passthru = attrs.passthru or {}; + passthru = attrs.passthru or { }; validity = checkMeta.assertValidity { inherit meta attrs; }; meta = checkMeta.commonMeta { inherit validity attrs; }; - baseDrv = derivation ({ - inherit (buildPlatform) system; - inherit (meta) name; - } // (builtins.removeAttrs attrs [ "meta" "passthru" ])); - passthru' = passthru // lib.optionalAttrs (passthru ? tests) { - tests = lib.mapAttrs (_: f: f baseDrv) passthru.tests; - }; + baseDrv = derivation ( + { + inherit (buildPlatform) system; + inherit (meta) name; + } + // (builtins.removeAttrs attrs [ + "meta" + "passthru" + ]) + ); + passthru' = + passthru + // lib.optionalAttrs (passthru ? tests) { + tests = lib.mapAttrs (_: f: f baseDrv) passthru.tests; + }; in - lib.extendDerivation - validity.handled - ({ inherit meta; passthru = passthru'; } // passthru') - baseDrv; + lib.extendDerivation validity.handled ( + { + inherit meta; + passthru = passthru'; + } + // passthru' + ) baseDrv; writeTextFile = - { name # the name of the derivation - , text - , executable ? false # run chmod +x ? - , destination ? "" # relative path appended to $out eg "/bin/foo" + { + name, # the name of the derivation + text, + executable ? false, # run chmod +x ? + destination ? "", # relative path appended to $out eg "/bin/foo" }: derivationWithMeta { inherit name text; @@ -39,15 +53,20 @@ rec { "--verbose" "--strict" "--file" - (builtins.toFile "write-text-file.kaem" ('' - target=''${out}''${destination} - '' + lib.optionalString (builtins.dirOf destination == ".") '' - mkdir -p ''${out}''${destinationDir} - '' + '' - cp ''${textPath} ''${target} - '' + lib.optionalString executable '' - chmod 555 ''${target} - '')) + (builtins.toFile "write-text-file.kaem" ( + '' + target=''${out}''${destination} + '' + + lib.optionalString (builtins.dirOf destination == ".") '' + mkdir -p ''${out}''${destinationDir} + '' + + '' + cp ''${textPath} ''${target} + '' + + lib.optionalString executable '' + chmod 555 ''${target} + '' + )) ]; PATH = lib.makeBinPath [ mescc-tools-extra ]; @@ -55,6 +74,6 @@ rec { inherit destination; }; - writeText = name: text: writeTextFile {inherit name text;}; + writeText = name: text: writeTextFile { inherit name text; }; } diff --git a/pkgs/os-specific/linux/minimal-bootstrap/xz/default.nix b/pkgs/os-specific/linux/minimal-bootstrap/xz/default.nix index 2533b617e5a60f..5ef744115642b3 100644 --- a/pkgs/os-specific/linux/minimal-bootstrap/xz/default.nix +++ b/pkgs/os-specific/linux/minimal-bootstrap/xz/default.nix @@ -1,15 +1,16 @@ -{ lib -, buildPlatform -, hostPlatform -, fetchurl -, bash -, tinycc -, gnumake -, gnused -, gnugrep -, gawk -, gnutar -, gzip +{ + lib, + buildPlatform, + hostPlatform, + fetchurl, + bash, + tinycc, + gnumake, + gnused, + gnugrep, + gawk, + gnutar, + gzip, }: let pname = "xz"; @@ -20,51 +21,57 @@ let hash = "sha256-HDguC8Lk4K9YOYqQPdYv/35RAXHS3keh6+BtFSjpt+k="; }; in -bash.runCommand "${pname}-${version}" { - inherit pname version; +bash.runCommand "${pname}-${version}" + { + inherit pname version; - nativeBuildInputs = [ - tinycc.compiler - gnumake - gnused - gnugrep - gawk - gnutar - gzip - ]; + nativeBuildInputs = [ + tinycc.compiler + gnumake + gnused + gnugrep + gawk + gnutar + gzip + ]; - passthru.tests.get-version = result: - bash.runCommand "${pname}-get-version-${version}" {} '' - ${result}/bin/xz --version - mkdir $out - ''; + passthru.tests.get-version = + result: + bash.runCommand "${pname}-get-version-${version}" { } '' + ${result}/bin/xz --version + mkdir $out + ''; - meta = with lib; { - description = "General-purpose data compression software, successor of LZMA"; - homepage = "https://tukaani.org/xz"; - license = with licenses; [ gpl2Plus lgpl21Plus ]; - maintainers = teams.minimal-bootstrap.members; - platforms = platforms.unix; - }; -} '' - # Unpack - tar xzf ${src} - cd xz-${version} + meta = with lib; { + description = "General-purpose data compression software, successor of LZMA"; + homepage = "https://tukaani.org/xz"; + license = with licenses; [ + gpl2Plus + lgpl21Plus + ]; + maintainers = teams.minimal-bootstrap.members; + platforms = platforms.unix; + }; + } + '' + # Unpack + tar xzf ${src} + cd xz-${version} - # Configure - export CC="tcc -B ${tinycc.libs}/lib" - export AR="tcc -ar" - export LD=tcc - bash ./configure \ - --prefix=$out \ - --build=${buildPlatform.config} \ - --host=${hostPlatform.config} \ - --disable-shared \ - --disable-assembler + # Configure + export CC="tcc -B ${tinycc.libs}/lib" + export AR="tcc -ar" + export LD=tcc + bash ./configure \ + --prefix=$out \ + --build=${buildPlatform.config} \ + --host=${hostPlatform.config} \ + --disable-shared \ + --disable-assembler - # Build - make -j $NIX_BUILD_CORES + # Build + make -j $NIX_BUILD_CORES - # Install - make -j $NIX_BUILD_CORES install -'' + # Install + make -j $NIX_BUILD_CORES install + '' diff --git a/pkgs/os-specific/linux/mm-tools/default.nix b/pkgs/os-specific/linux/mm-tools/default.nix index 38f16ca4e7d27a..ed592fc83514ad 100644 --- a/pkgs/os-specific/linux/mm-tools/default.nix +++ b/pkgs/os-specific/linux/mm-tools/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, linux }: +{ + lib, + stdenv, + linux, +}: stdenv.mkDerivation { pname = "mm-tools"; diff --git a/pkgs/os-specific/linux/mwprocapture/default.nix b/pkgs/os-specific/linux/mwprocapture/default.nix index c83596a1fbe047..28c2e11e429cb9 100644 --- a/pkgs/os-specific/linux/mwprocapture/default.nix +++ b/pkgs/os-specific/linux/mwprocapture/default.nix @@ -1,11 +1,19 @@ -{ lib, stdenv, fetchurl, kernel, alsa-lib }: +{ + lib, + stdenv, + fetchurl, + kernel, + alsa-lib, +}: let - bits = - if stdenv.hostPlatform.is64bit then "64" - else "32"; + bits = if stdenv.hostPlatform.is64bit then "64" else "32"; - libpath = lib.makeLibraryPath [ stdenv.cc.cc stdenv.cc.libc alsa-lib ]; + libpath = lib.makeLibraryPath [ + stdenv.cc.cc + stdenv.cc.libc + alsa-lib + ]; in stdenv.mkDerivation rec { @@ -25,7 +33,10 @@ stdenv.mkDerivation rec { export INSTALL_MOD_PATH="$out" ''; - hardeningDisable = [ "pic" "format" ]; + hardeningDisable = [ + "pic" + "format" + ]; makeFlags = [ "KERNELDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" diff --git a/pkgs/os-specific/linux/mxu11x0/default.nix b/pkgs/os-specific/linux/mxu11x0/default.nix index 17d0c693820690..7020dd608442ac 100644 --- a/pkgs/os-specific/linux/mxu11x0/default.nix +++ b/pkgs/os-specific/linux/mxu11x0/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, kernel }: +{ + lib, + stdenv, + fetchurl, + kernel, +}: let srcs = import (./srcs.nix) { inherit fetchurl; }; @@ -7,7 +12,8 @@ stdenv.mkDerivation rec { pname = "mxu11x0"; src = if lib.versionAtLeast kernel.version "5.0" then srcs.mxu11x0_5.src else srcs.mxu11x0_4.src; - mxu_version = if lib.versionAtLeast kernel.version "5.0" then srcs.mxu11x0_5.version else srcs.mxu11x0_4.version; + mxu_version = + if lib.versionAtLeast kernel.version "5.0" then srcs.mxu11x0_5.version else srcs.mxu11x0_4.version; version = mxu_version + "-${kernel.version}"; diff --git a/pkgs/os-specific/linux/nct6687d/default.nix b/pkgs/os-specific/linux/nct6687d/default.nix index 4d17604853dcc9..19d52276ecef3f 100644 --- a/pkgs/os-specific/linux/nct6687d/default.nix +++ b/pkgs/os-specific/linux/nct6687d/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, kernel -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + nix-update-script, }: stdenv.mkDerivation rec { @@ -23,7 +24,8 @@ stdenv.mkDerivation rec { nativeBuildInputs = kernel.moduleBuildDependencies; makeFlags = kernel.makeFlags ++ [ - "-C" "${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" + "-C" + "${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" "M=$(sourceRoot)" ]; diff --git a/pkgs/os-specific/linux/ndiswrapper/default.nix b/pkgs/os-specific/linux/ndiswrapper/default.nix index 39a8d919d8be6e..fec41a4a778f33 100644 --- a/pkgs/os-specific/linux/ndiswrapper/default.nix +++ b/pkgs/os-specific/linux/ndiswrapper/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, kernel, perl, kmod, elfutils }: +{ + lib, + stdenv, + fetchurl, + kernel, + perl, + kmod, + elfutils, +}: let version = "1.63"; in @@ -34,13 +42,19 @@ stdenv.mkDerivation { sha256 = "1v6b66jhisl110jfl00hm43lmnrav32vs39d85gcbxrjqnmcx08g"; }; - buildInputs = [ perl elfutils ]; + buildInputs = [ + perl + elfutils + ]; meta = { description = "Ndis driver wrapper for the Linux kernel"; homepage = "https://sourceforge.net/projects/ndiswrapper"; license = "GPL"; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; broken = lib.versionAtLeast kernel.version "5.8"; }; } diff --git a/pkgs/os-specific/linux/net-tools/default.nix b/pkgs/os-specific/linux/net-tools/default.nix index 3b37ce4b8136e6..4361f28f87d8d5 100644 --- a/pkgs/os-specific/linux/net-tools/default.nix +++ b/pkgs/os-specific/linux/net-tools/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "net-tools"; @@ -9,10 +13,9 @@ stdenv.mkDerivation rec { sha256 = "sha256-smJDWlJB6Jv6UcPKvVEzdTlS96e3uT8y4Iy52W9YDWk="; }; - preBuild = - '' - cp ${./config.h} config.h - ''; + preBuild = '' + cp ${./config.h} config.h + ''; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" diff --git a/pkgs/os-specific/linux/netatop/default.nix b/pkgs/os-specific/linux/netatop/default.nix index 91b525af0cb034..4b8cf9019efac1 100644 --- a/pkgs/os-specific/linux/netatop/default.nix +++ b/pkgs/os-specific/linux/netatop/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, kernel, kmod, zlib }: +{ + lib, + stdenv, + fetchurl, + kernel, + kmod, + zlib, +}: let version = "3.1"; @@ -13,7 +20,10 @@ stdenv.mkDerivation { }; nativeBuildInputs = kernel.moduleBuildDependencies; - buildInputs = [ kmod zlib ]; + buildInputs = [ + kmod + zlib + ]; hardeningDisable = [ "pic" ]; env.NIX_CFLAGS_COMPILE = toString [ "-Wno-error=implicit-fallthrough" ]; diff --git a/pkgs/os-specific/linux/nftables/default.nix b/pkgs/os-specific/linux/nftables/default.nix index 0af8886f24e7c0..8c6906098b31a7 100644 --- a/pkgs/os-specific/linux/nftables/default.nix +++ b/pkgs/os-specific/linux/nftables/default.nix @@ -1,13 +1,28 @@ -{ lib, stdenv, fetchurl, pkg-config, bison, flex -, asciidoc, libxslt, findXMLCatalogs, docbook_xml_dtd_45, docbook_xsl -, libmnl, libnftnl, libpcap -, gmp, jansson -, autoreconfHook -, withDebugSymbols ? false -, withCli ? true, libedit -, withXtables ? true, iptables -, nixosTests -, gitUpdater +{ + lib, + stdenv, + fetchurl, + pkg-config, + bison, + flex, + asciidoc, + libxslt, + findXMLCatalogs, + docbook_xml_dtd_45, + docbook_xsl, + libmnl, + libnftnl, + libpcap, + gmp, + jansson, + autoreconfHook, + withDebugSymbols ? false, + withCli ? true, + libedit, + withXtables ? true, + iptables, + nixosTests, + gitUpdater, }: stdenv.mkDerivation rec { @@ -21,20 +36,33 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook - pkg-config bison flex - asciidoc docbook_xml_dtd_45 docbook_xsl findXMLCatalogs libxslt + pkg-config + bison + flex + asciidoc + docbook_xml_dtd_45 + docbook_xsl + findXMLCatalogs + libxslt ]; - buildInputs = [ - libmnl libnftnl libpcap - gmp jansson - ] ++ lib.optional withCli libedit + buildInputs = + [ + libmnl + libnftnl + libpcap + gmp + jansson + ] + ++ lib.optional withCli libedit ++ lib.optional withXtables iptables; - configureFlags = [ - "--with-json" - (lib.withFeatureAs withCli "cli" "editline") - ] ++ lib.optional (!withDebugSymbols) "--disable-debug" + configureFlags = + [ + "--with-json" + (lib.withFeatureAs withCli "cli" "editline") + ] + ++ lib.optional (!withDebugSymbols) "--disable-debug" ++ lib.optional withXtables "--with-xtables"; enableParallelBuilding = true; diff --git a/pkgs/os-specific/linux/nftables/python.nix b/pkgs/os-specific/linux/nftables/python.nix index bb9ebd621fcdcd..f010993a908340 100644 --- a/pkgs/os-specific/linux/nftables/python.nix +++ b/pkgs/os-specific/linux/nftables/python.nix @@ -1,6 +1,7 @@ -{ buildPythonPackage -, setuptools -, nftables +{ + buildPythonPackage, + setuptools, + nftables, }: buildPythonPackage { @@ -20,6 +21,12 @@ buildPythonPackage { pythonImportsCheck = [ "nftables" ]; meta = { - inherit (nftables.meta) description homepage license platforms maintainers; + inherit (nftables.meta) + description + homepage + license + platforms + maintainers + ; }; } diff --git a/pkgs/os-specific/linux/nixos-rebuild/default.nix b/pkgs/os-specific/linux/nixos-rebuild/default.nix index ee07f6cce4f759..8e8f7f44b1034e 100644 --- a/pkgs/os-specific/linux/nixos-rebuild/default.nix +++ b/pkgs/os-specific/linux/nixos-rebuild/default.nix @@ -1,17 +1,18 @@ -{ callPackage -, substitute -, runtimeShell -, coreutils -, gnused -, gnugrep -, jq -, util-linux -, nix -, lib -, nixosTests -, installShellFiles -, binlore -, nixos-rebuild +{ + callPackage, + substitute, + runtimeShell, + coreutils, + gnused, + gnugrep, + jq, + util-linux, + nix, + lib, + nixosTests, + installShellFiles, + binlore, + nixos-rebuild, }: let fallback = import ./../../../../nixos/modules/installer/tools/nix-fallback-paths.nix; @@ -23,12 +24,30 @@ substitute { isExecutable = true; substitutions = [ - "--subst-var-by" "runtimeShell" runtimeShell - "--subst-var-by" "nix" nix - "--subst-var-by" "nix_x86_64_linux" fallback.x86_64-linux - "--subst-var-by" "nix_i686_linux" fallback.i686-linux - "--subst-var-by" "nix_aarch64_linux" fallback.aarch64-linux - "--subst-var-by" "path" (lib.makeBinPath [ coreutils gnused gnugrep jq util-linux ]) + "--subst-var-by" + "runtimeShell" + runtimeShell + "--subst-var-by" + "nix" + nix + "--subst-var-by" + "nix_x86_64_linux" + fallback.x86_64-linux + "--subst-var-by" + "nix_i686_linux" + fallback.i686-linux + "--subst-var-by" + "nix_aarch64_linux" + fallback.aarch64-linux + "--subst-var-by" + "path" + (lib.makeBinPath [ + coreutils + gnused + gnugrep + jq + util-linux + ]) ]; nativeBuildInputs = [ @@ -45,7 +64,7 @@ substitute { # run some a simple installer tests to make sure nixos-rebuild still works for them passthru.tests = { install-bootloader = nixosTests.nixos-rebuild-install-bootloader; - repl = callPackage ./test/repl.nix {}; + repl = callPackage ./test/repl.nix { }; simple-installer = nixosTests.installer.simple; specialisations = nixosTests.nixos-rebuild-specialisations; target-host = nixosTests.nixos-rebuild-target-host; @@ -62,7 +81,10 @@ substitute { description = "Rebuild your NixOS configuration and switch to it, on local hosts and remote"; homepage = "https://github.com/NixOS/nixpkgs/tree/master/pkgs/os-specific/linux/nixos-rebuild"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ Profpatsch thiagokokada ]; + maintainers = with lib.maintainers; [ + Profpatsch + thiagokokada + ]; mainProgram = "nixos-rebuild"; }; } diff --git a/pkgs/os-specific/linux/nixos-rebuild/test/repl.nix b/pkgs/os-specific/linux/nixos-rebuild/test/repl.nix index c17546851cbf58..045f32958b7a16 100644 --- a/pkgs/os-specific/linux/nixos-rebuild/test/repl.nix +++ b/pkgs/os-specific/linux/nixos-rebuild/test/repl.nix @@ -1,4 +1,5 @@ -{ lib, +{ + lib, expect, nix, nixos-rebuild, @@ -28,132 +29,134 @@ let # In case we want/need to evaluate packages or the assertions or whatever, # we want to have a linux system. # TODO: make the non-flake test use thise. - linuxSystem = lib.replaceStrings ["darwin"] ["linux"] stdenv.hostPlatform.system; + linuxSystem = lib.replaceStrings [ "darwin" ] [ "linux" ] stdenv.hostPlatform.system; in -runCommand "test-nixos-rebuild-repl" { - nativeBuildInputs = [ - expect - nix - nixos-rebuild - ]; - nixpkgs = - if builtins.pathExists (path + "/.git") - then lib.cleanSource path - else path; -} '' - export HOME=$(mktemp -d) - export TEST_ROOT=$PWD/test-tmp - - # Prepare for running Nix in sandbox - export NIX_BUILD_HOOK= - export NIX_CONF_DIR=$TEST_ROOT/etc - export NIX_LOCALSTATE_DIR=$TEST_ROOT/var - export NIX_LOG_DIR=$TEST_ROOT/var/log/nix - export NIX_STATE_DIR=$TEST_ROOT/var/nix - export NIX_STORE_DIR=$TEST_ROOT/store - export PAGER=cat - mkdir -p $TEST_ROOT $NIX_CONF_DIR - - echo General setup - ################## - - export NIX_PATH=nixpkgs=$nixpkgs:nixos-config=$HOME/configuration.nix - cat >> ~/configuration.nix <> ~/configuration.nix < ~/hardware-configuration.nix + echo '{ }' > ~/hardware-configuration.nix - echo Test traditional NixOS configuration - ######################################### + echo Test traditional NixOS configuration + ######################################### - expect ${writeText "test-nixos-rebuild-repl-expect" '' - ${expectSetup} - spawn nixos-rebuild repl --fast + expect ${writeText "test-nixos-rebuild-repl-expect" '' + ${expectSetup} + spawn nixos-rebuild repl --fast - expect "nix-repl> " + expect "nix-repl> " - send "config.networking.hostName\n" - expect "\"nixos\"" - ''} + send "config.networking.hostName\n" + expect "\"nixos\"" + ''} - echo Test flake based NixOS configuration - ######################################### + echo Test flake based NixOS configuration + ######################################### - # Switch to flake flavored environment - unset NIX_PATH - cat > $NIX_CONF_DIR/nix.conf < $NIX_CONF_DIR/nix.conf < ~/hardware-configuration.nix + # Make the config pure + echo '{ nixpkgs.hostPlatform = "${linuxSystem}"; }' > ~/hardware-configuration.nix - cat >~/flake.nix <~/flake.nix <" - - send "config.networking.hostName\n" - expect_simple "itsme" - - expect_simple "nix-repl>" - send "lib.version\n" - expect_simple ${escapeExpect ( - # The version string is a bit different in the flake lib, so we expect a prefix and ignore the rest - # Furthermore, including the revision (suffix) would cause unnecessary rebuilds. - # Note that a length of 4 only matches e.g. "24. - lib.strings.substring 0 4 (lib.strings.escapeNixString lib.version))} - - # Make sure it's the right lib - should be the flake lib, not Nixpkgs lib. - expect_simple "nix-repl>" - send "lib?nixosSystem\n" - expect_simple "true" - expect_simple "nix-repl>" - send "lib?nixos\n" - expect_simple "true" - ''} - - pushd "$HOME" - expect ${writeText "test-nixos-rebuild-repl-relative-path-expect" '' - ${expectSetup} - spawn sh -c "nixos-rebuild repl --fast --flake .#testconf" - - expect_simple "nix-repl>" - - send "config.networking.hostName\n" - expect_simple "itsme" - ''} - popd - - echo - - ######### - echo Done - touch $out -'' + } + EOF + + # cat -n ~/flake.nix + + expect ${writeText "test-nixos-rebuild-repl-absolute-path-expect" '' + ${expectSetup} + spawn sh -c "nixos-rebuild repl --fast --flake path:\$HOME#testconf" + + expect_simple "nix-repl>" + + send "config.networking.hostName\n" + expect_simple "itsme" + + expect_simple "nix-repl>" + send "lib.version\n" + expect_simple ${ + escapeExpect ( + # The version string is a bit different in the flake lib, so we expect a prefix and ignore the rest + # Furthermore, including the revision (suffix) would cause unnecessary rebuilds. + # Note that a length of 4 only matches e.g. "24. + lib.strings.substring 0 4 (lib.strings.escapeNixString lib.version) + ) + } + + # Make sure it's the right lib - should be the flake lib, not Nixpkgs lib. + expect_simple "nix-repl>" + send "lib?nixosSystem\n" + expect_simple "true" + expect_simple "nix-repl>" + send "lib?nixos\n" + expect_simple "true" + ''} + + pushd "$HOME" + expect ${writeText "test-nixos-rebuild-repl-relative-path-expect" '' + ${expectSetup} + spawn sh -c "nixos-rebuild repl --fast --flake .#testconf" + + expect_simple "nix-repl>" + + send "config.networking.hostName\n" + expect_simple "itsme" + ''} + popd + + echo + + ######### + echo Done + touch $out + '' diff --git a/pkgs/os-specific/linux/nvidia-x11/fabricmanager.nix b/pkgs/os-specific/linux/nvidia-x11/fabricmanager.nix index 818d847f21961b..f032ade0d83719 100644 --- a/pkgs/os-specific/linux/nvidia-x11/fabricmanager.nix +++ b/pkgs/os-specific/linux/nvidia-x11/fabricmanager.nix @@ -1,10 +1,15 @@ nvidia_x11: sha256: -{ stdenv, lib, fetchurl, patchelf }: +{ + stdenv, + lib, + fetchurl, + patchelf, +}: let sys = lib.concatStringsSep "-" (lib.reverseList (lib.splitString "-" stdenv.system)); - bsys = builtins.replaceStrings ["_"] ["-"] sys; + bsys = builtins.replaceStrings [ "_" ] [ "-" ] sys; fmver = nvidia_x11.version; in @@ -12,8 +17,9 @@ stdenv.mkDerivation rec { pname = "fabricmanager"; version = fmver; src = fetchurl { - url = "https://developer.download.nvidia.com/compute/nvidia-driver/redist/fabricmanager/" + - "${sys}/${pname}-${sys}-${fmver}-archive.tar.xz"; + url = + "https://developer.download.nvidia.com/compute/nvidia-driver/redist/fabricmanager/" + + "${sys}/${pname}-${sys}-${fmver}-archive.tar.xz"; inherit sha256; }; diff --git a/pkgs/os-specific/linux/nvidia-x11/persistenced.nix b/pkgs/os-specific/linux/nvidia-x11/persistenced.nix index dcdd22044e2a6d..805eaffab03ac7 100644 --- a/pkgs/os-specific/linux/nvidia-x11/persistenced.nix +++ b/pkgs/os-specific/linux/nvidia-x11/persistenced.nix @@ -1,10 +1,11 @@ nvidia_x11: sha256: -{ stdenv -, lib -, fetchFromGitHub -, m4 -, libtirpc +{ + stdenv, + lib, + fetchFromGitHub, + m4, + libtirpc, }: stdenv.mkDerivation rec { diff --git a/pkgs/os-specific/linux/nvidiabl/default.nix b/pkgs/os-specific/linux/nvidiabl/default.nix index 68991e12895985..4d38b42eb63d2e 100644 --- a/pkgs/os-specific/linux/nvidiabl/default.nix +++ b/pkgs/os-specific/linux/nvidiabl/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { name = "nvidiabl-${version}-${kernel.version}"; @@ -30,7 +35,10 @@ stdenv.mkDerivation rec { description = "Linux driver for setting the backlight brightness on laptops using NVIDIA GPU"; homepage = "https://github.com/yorickvP/nvidiabl"; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; maintainers = with maintainers; [ yorickvp ]; broken = kernel.kernelAtLeast "5.18"; }; diff --git a/pkgs/os-specific/linux/openrazer/driver.nix b/pkgs/os-specific/linux/openrazer/driver.nix index 42e6be93dae4d3..38b4312cc31f9c 100644 --- a/pkgs/os-specific/linux/openrazer/driver.nix +++ b/pkgs/os-specific/linux/openrazer/driver.nix @@ -1,51 +1,57 @@ -{ coreutils -, fetchFromGitHub -, kernel -, stdenv -, lib -, util-linux +{ + coreutils, + fetchFromGitHub, + kernel, + stdenv, + lib, + util-linux, }: let - common = import ../../../development/python-modules/openrazer/common.nix { inherit lib fetchFromGitHub; }; -in -stdenv.mkDerivation (common // { - pname = "openrazer"; - version = "${common.version}-${kernel.version}"; - - nativeBuildInputs = kernel.moduleBuildDependencies; - - makeFlags = kernel.makeFlags ++ [ - "KERNELDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" - ]; - - installPhase = '' - runHook preInstall - - binDir="$out/lib/modules/${kernel.modDirVersion}/kernel/drivers/hid" - mkdir -p "$binDir" - cp -v driver/*.ko "$binDir" - RAZER_MOUNT_OUT="$out/bin/razer_mount" - RAZER_RULES_OUT="$out/etc/udev/rules.d/99-razer.rules" - install -m 644 -v -D install_files/udev/99-razer.rules $RAZER_RULES_OUT - install -m 755 -v -D install_files/udev/razer_mount $RAZER_MOUNT_OUT - substituteInPlace $RAZER_RULES_OUT \ - --replace razer_mount $RAZER_MOUNT_OUT \ - --replace plugdev openrazer - substituteInPlace $RAZER_MOUNT_OUT \ - --replace /usr/bin/logger ${util-linux}/bin/logger \ - --replace chgrp ${coreutils}/bin/chgrp \ - --replace "PATH='/sbin:/bin:/usr/sbin:/usr/bin'" "" \ - --replace plugdev openrazer - - runHook postInstall - ''; - - enableParallelBuilding = true; - - meta = common.meta // { - description = "Entirely open source Linux driver that allows you to manage your Razer peripherals on GNU/Linux"; - mainProgram = "razer_mount"; - broken = kernel.kernelOlder "4.19"; + common = import ../../../development/python-modules/openrazer/common.nix { + inherit lib fetchFromGitHub; }; -}) +in +stdenv.mkDerivation ( + common + // { + pname = "openrazer"; + version = "${common.version}-${kernel.version}"; + + nativeBuildInputs = kernel.moduleBuildDependencies; + + makeFlags = kernel.makeFlags ++ [ + "KERNELDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" + ]; + + installPhase = '' + runHook preInstall + + binDir="$out/lib/modules/${kernel.modDirVersion}/kernel/drivers/hid" + mkdir -p "$binDir" + cp -v driver/*.ko "$binDir" + RAZER_MOUNT_OUT="$out/bin/razer_mount" + RAZER_RULES_OUT="$out/etc/udev/rules.d/99-razer.rules" + install -m 644 -v -D install_files/udev/99-razer.rules $RAZER_RULES_OUT + install -m 755 -v -D install_files/udev/razer_mount $RAZER_MOUNT_OUT + substituteInPlace $RAZER_RULES_OUT \ + --replace razer_mount $RAZER_MOUNT_OUT \ + --replace plugdev openrazer + substituteInPlace $RAZER_MOUNT_OUT \ + --replace /usr/bin/logger ${util-linux}/bin/logger \ + --replace chgrp ${coreutils}/bin/chgrp \ + --replace "PATH='/sbin:/bin:/usr/sbin:/usr/bin'" "" \ + --replace plugdev openrazer + + runHook postInstall + ''; + + enableParallelBuilding = true; + + meta = common.meta // { + description = "Entirely open source Linux driver that allows you to manage your Razer peripherals on GNU/Linux"; + mainProgram = "razer_mount"; + broken = kernel.kernelOlder "4.19"; + }; + } +) diff --git a/pkgs/os-specific/linux/opensnitch-ebpf/default.nix b/pkgs/os-specific/linux/opensnitch-ebpf/default.nix index e012819254d721..1c3fd836d813bf 100644 --- a/pkgs/os-specific/linux/opensnitch-ebpf/default.nix +++ b/pkgs/os-specific/linux/opensnitch-ebpf/default.nix @@ -1,13 +1,14 @@ -{ lib -, kernel -, stdenv -, clang-tools -, llvmPackages -, elfutils -, flex -, bison -, bc -, opensnitch +{ + lib, + kernel, + stdenv, + clang-tools, + llvmPackages, + elfutils, + flex, + bison, + bc, + opensnitch, }: stdenv.mkDerivation rec { @@ -33,10 +34,10 @@ stdenv.mkDerivation rec { # https://aur.archlinux.org/cgit/aur.git/tree/PKGBUILD?h=opensnitch-ebpf-module&id=984b952a784eb701f691dd9f2d45dfeb8d15053b env.NIX_CFLAGS_COMPILE = "-fno-stack-protector"; - env.KERNEL_DIR="${kernel.dev}/lib/modules/${kernel.modDirVersion}/source"; - env.KERNEL_HEADERS="${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"; + env.KERNEL_DIR = "${kernel.dev}/lib/modules/${kernel.modDirVersion}/source"; + env.KERNEL_HEADERS = "${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"; - extraConfig ='' + extraConfig = '' CONFIG_UPROBE_EVENTS=y ''; diff --git a/pkgs/os-specific/linux/phc-intel/default.nix b/pkgs/os-specific/linux/phc-intel/default.nix index a2e2456ad6e09f..9da1adfda75d35 100644 --- a/pkgs/os-specific/linux/phc-intel/default.nix +++ b/pkgs/os-specific/linux/phc-intel/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, kernel, which }: +{ + lib, + stdenv, + fetchurl, + kernel, + which, +}: # Don't bother with older versions, though some might even work: assert lib.versionAtLeast kernel.version "4.10"; @@ -6,7 +12,8 @@ assert lib.versionAtLeast kernel.version "4.10"; let release = "0.4.0"; revbump = "rev25"; # don't forget to change forum download id... -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { name = "linux-phc-intel-${version}-${kernel.version}"; version = "${release}-${revbump}"; @@ -46,7 +53,10 @@ in stdenv.mkDerivation rec { ''; homepage = "https://github.com/danielw86dev/phc-intel-dkms"; license = licenses.gpl2Plus; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; broken = lib.versionAtLeast kernel.version "4.18"; }; } diff --git a/pkgs/os-specific/linux/ply/default.nix b/pkgs/os-specific/linux/ply/default.nix index 0c8e323b434949..3e1dfa2967061f 100644 --- a/pkgs/os-specific/linux/ply/default.nix +++ b/pkgs/os-specific/linux/ply/default.nix @@ -1,10 +1,26 @@ -{ lib, stdenv, kernel, fetchFromGitHub, autoreconfHook, bison, flex, p7zip, rsync }: +{ + lib, + stdenv, + kernel, + fetchFromGitHub, + autoreconfHook, + bison, + flex, + p7zip, + rsync, +}: stdenv.mkDerivation rec { pname = "ply"; version = "2.1.1-${lib.substring 0 7 src.rev}"; - nativeBuildInputs = [ autoreconfHook flex bison p7zip rsync ]; + nativeBuildInputs = [ + autoreconfHook + flex + bison + p7zip + rsync + ]; src = fetchFromGitHub { owner = "iovisor"; @@ -35,6 +51,9 @@ stdenv.mkDerivation rec { mainProgram = "ply"; homepage = "https://wkz.github.io/ply/"; license = [ licenses.gpl2Only ]; - maintainers = with maintainers; [ mic92 mbbx6spp ]; + maintainers = with maintainers; [ + mic92 + mbbx6spp + ]; }; } diff --git a/pkgs/os-specific/linux/prl-tools/default.nix b/pkgs/os-specific/linux/prl-tools/default.nix index 212df9715714e4..862eda8b22177d 100644 --- a/pkgs/os-specific/linux/prl-tools/default.nix +++ b/pkgs/os-specific/linux/prl-tools/default.nix @@ -1,31 +1,35 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, bbe -, makeWrapper -, p7zip -, perl -, undmg -, dbus-glib -, fuse -, glib -, xorg -, zlib -, kernel -, bash -, cups -, gawk -, netcat -, timetrap -, util-linux +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + bbe, + makeWrapper, + p7zip, + perl, + undmg, + dbus-glib, + fuse, + glib, + xorg, + zlib, + kernel, + bash, + cups, + gawk, + netcat, + timetrap, + util-linux, }: let kernelVersion = kernel.modDirVersion; kernelDir = "${kernel.dev}/lib/modules/${kernelVersion}"; - libPath = lib.concatStringsSep ":" [ "${glib.out}/lib" "${xorg.libXrandr}/lib" ]; + libPath = lib.concatStringsSep ":" [ + "${glib.out}/lib" + "${xorg.libXrandr}/lib" + ]; scriptPath = lib.concatStringsSep ":" [ "${bash}/bin" "${cups}/sbin" @@ -46,7 +50,10 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-R7pQhmLpMOHExPwH4YM3WDnp1PcwpH5Bif3C1/N55Bg="; }; - hardeningDisable = [ "pic" "format" ]; + hardeningDisable = [ + "pic" + "format" + ]; nativeBuildInputs = [ autoPatchelfHook @@ -111,12 +118,18 @@ stdenv.mkDerivation (finalAttrs: { cp prl_fs/SharedFolders/Guest/Linux/prl_fs/prl_fs.ko $out/lib/modules/${kernelVersion}/extra cp prl_fs_freeze/Snapshot/Guest/Linux/prl_freeze/prl_fs_freeze.ko $out/lib/modules/${kernelVersion}/extra cp prl_tg/Toolgate/Guest/Linux/prl_tg/prl_tg.ko $out/lib/modules/${kernelVersion}/extra - ${lib.optionalString stdenv.hostPlatform.isAarch64 - "cp prl_notifier/Installation/lnx/prl_notifier/prl_notifier.ko $out/lib/modules/${kernelVersion}/extra"} + ${lib.optionalString stdenv.hostPlatform.isAarch64 "cp prl_notifier/Installation/lnx/prl_notifier/prl_notifier.ko $out/lib/modules/${kernelVersion}/extra"} ) ( # tools - cd tools/tools${if stdenv.hostPlatform.isAarch64 then "-arm64" else if stdenv.hostPlatform.isx86_64 then "64" else "32"} + cd tools/tools${ + if stdenv.hostPlatform.isAarch64 then + "-arm64" + else if stdenv.hostPlatform.isx86_64 then + "64" + else + "32" + } mkdir -p $out/lib # prltoolsd contains hardcoded /bin/bash path @@ -175,7 +188,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Parallels Tools for Linux guests"; homepage = "https://parallels.com"; license = licenses.unfree; - maintainers = with maintainers; [ wegank codgician ]; + maintainers = with maintainers; [ + wegank + codgician + ]; platforms = platforms.linux; }; }) diff --git a/pkgs/os-specific/linux/procps-ng/default.nix b/pkgs/os-specific/linux/procps-ng/default.nix index ead3c19a1ae484..59cdf14af493b9 100644 --- a/pkgs/os-specific/linux/procps-ng/default.nix +++ b/pkgs/os-specific/linux/procps-ng/default.nix @@ -1,23 +1,24 @@ -{ lib -, stdenv -, fetchurl -, ncurses -, pkg-config -, autoreconfHook +{ + lib, + stdenv, + fetchurl, + ncurses, + pkg-config, + autoreconfHook, # `ps` with systemd support is able to properly report different # attributes like unit name, so we want to have it on linux. -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, systemd + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, # procps is mostly Linux-only. Most commands require a running Linux # system (or very similar like that found in Cygwin). The one # exception is ‘watch’ which is portable enough to run on pretty much # any UNIX-compatible system. -, watchOnly ? !(stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isCygwin) + watchOnly ? !(stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isCygwin), -, binlore -, procps + binlore, + procps, }: stdenv.mkDerivation rec { @@ -30,23 +31,28 @@ stdenv.mkDerivation rec { hash = "sha256-IocNb+skeK22F85PCaeHrdry0mDFqKp7F9iJqWLF5C4="; }; - buildInputs = [ ncurses ] - ++ lib.optional withSystemd systemd; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + buildInputs = [ ncurses ] ++ lib.optional withSystemd systemd; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; - makeFlags = [ "usrbin_execdir=$(out)/bin" ] - ++ lib.optionals watchOnly [ "src/watch" ]; + makeFlags = [ "usrbin_execdir=$(out)/bin" ] ++ lib.optionals watchOnly [ "src/watch" ]; enableParallelBuilding = true; # Too red; 8bit support for fixing https://github.com/NixOS/nixpkgs/issues/275220 - configureFlags = [ "--disable-modern-top" "--enable-watch8bit" ] + configureFlags = + [ + "--disable-modern-top" + "--enable-watch8bit" + ] ++ lib.optional withSystemd "--with-systemd" ++ lib.optional stdenv.hostPlatform.isMusl "--disable-w" ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "ac_cv_func_malloc_0_nonnull=yes" - "ac_cv_func_realloc_0_nonnull=yes" - ]; + "ac_cv_func_malloc_0_nonnull=yes" + "ac_cv_func_realloc_0_nonnull=yes" + ]; installPhase = lib.optionalString watchOnly '' install -m 0755 -D src/watch $out/bin/watch diff --git a/pkgs/os-specific/linux/projecteur/default.nix b/pkgs/os-specific/linux/projecteur/default.nix index 96d6ed0327033d..fc74771d74d629 100644 --- a/pkgs/os-specific/linux/projecteur/default.nix +++ b/pkgs/os-specific/linux/projecteur/default.nix @@ -1,11 +1,12 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, cmake -, pkg-config -, qtbase -, qtgraphicaleffects -, wrapQtAppsHook +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + pkg-config, + qtbase, + qtgraphicaleffects, + wrapQtAppsHook, }: mkDerivation rec { @@ -46,7 +47,10 @@ mkDerivation rec { homepage = "https://github.com/jahnf/Projecteur"; license = lib.licenses.mit; mainProgram = "projecteur"; - maintainers = with lib.maintainers; [ benneti drupol ]; + maintainers = with lib.maintainers; [ + benneti + drupol + ]; platforms = lib.platforms.linux; }; } diff --git a/pkgs/os-specific/linux/qc71_laptop/default.nix b/pkgs/os-specific/linux/qc71_laptop/default.nix index bb4bf20ad0f691..effd8ed5818e8a 100644 --- a/pkgs/os-specific/linux/qc71_laptop/default.nix +++ b/pkgs/os-specific/linux/qc71_laptop/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { pname = "qc71_laptop"; diff --git a/pkgs/os-specific/linux/r8125/default.nix b/pkgs/os-specific/linux/r8125/default.nix index ef271585efcefd..3b2bdb45e8125b 100644 --- a/pkgs/os-specific/linux/r8125/default.nix +++ b/pkgs/os-specific/linux/r8125/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, kernel }: +{ + stdenv, + lib, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { pname = "r8125"; diff --git a/pkgs/os-specific/linux/rfkill/udev.nix b/pkgs/os-specific/linux/rfkill/udev.nix index 53cbf68330c645..1b17349f33d84c 100644 --- a/pkgs/os-specific/linux/rfkill/udev.nix +++ b/pkgs/os-specific/linux/rfkill/udev.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, substituteAll }: +{ + lib, + stdenv, + substituteAll, +}: # Provides a facility to hook into rfkill changes. # @@ -25,13 +29,13 @@ # in the rfkill package. let - rfkillHook = - substituteAll { - inherit (stdenv) shell; - isExecutable = true; - src = ./rfkill-hook.sh; - }; -in stdenv.mkDerivation { + rfkillHook = substituteAll { + inherit (stdenv) shell; + isExecutable = true; + src = ./rfkill-hook.sh; + }; +in +stdenv.mkDerivation { name = "rfkill-udev"; dontUnpack = true; diff --git a/pkgs/os-specific/linux/rtl8189es/default.nix b/pkgs/os-specific/linux/rtl8189es/default.nix index 8e95ceafd3367f..a0588c5ce20c0e 100644 --- a/pkgs/os-specific/linux/rtl8189es/default.nix +++ b/pkgs/os-specific/linux/rtl8189es/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, kernel, bc, nukeReferences }: +{ + stdenv, + lib, + fetchFromGitHub, + kernel, + bc, + nukeReferences, +}: stdenv.mkDerivation rec { name = "rtl8189es-${kernel.version}-${version}"; @@ -11,9 +18,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-n7Bsstr1H1RvguAyJnVqk/JgEx8WEZWaVg7ZfEYykR0="; }; - nativeBuildInputs = [ bc nukeReferences ] ++ kernel.moduleBuildDependencies; + nativeBuildInputs = [ + bc + nukeReferences + ] ++ kernel.moduleBuildDependencies; - hardeningDisable = [ "pic" "format" ]; + hardeningDisable = [ + "pic" + "format" + ]; prePatch = '' substituteInPlace ./Makefile --replace /lib/modules/ "${kernel.dev}/lib/modules/" @@ -23,7 +36,10 @@ stdenv.mkDerivation rec { makeFlags = kernel.makeFlags ++ [ "KSRC=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" - ("CONFIG_PLATFORM_I386_PC=" + (if (stdenv.hostPlatform.isi686 || stdenv.hostPlatform.isx86_64) then "y" else "n")) + ( + "CONFIG_PLATFORM_I386_PC=" + + (if (stdenv.hostPlatform.isi686 || stdenv.hostPlatform.isx86_64) then "y" else "n") + ) ("CONFIG_PLATFORM_ARM_RPI=" + (if stdenv.hostPlatform.isAarch then "y" else "n")) ]; diff --git a/pkgs/os-specific/linux/rtl8189fs/default.nix b/pkgs/os-specific/linux/rtl8189fs/default.nix index 87b0944c4d3264..520d4feeaee69f 100644 --- a/pkgs/os-specific/linux/rtl8189fs/default.nix +++ b/pkgs/os-specific/linux/rtl8189fs/default.nix @@ -1,4 +1,9 @@ -{ lib, kernel, rtl8189es, fetchFromGitHub }: +{ + lib, + kernel, + rtl8189es, + fetchFromGitHub, +}: # rtl8189fs is a branch of the rtl8189es driver rtl8189es.overrideAttrs (drv: rec { diff --git a/pkgs/os-specific/linux/rtl8192eu/default.nix b/pkgs/os-specific/linux/rtl8192eu/default.nix index 425edf3309ca46..0737d1fae87c9a 100644 --- a/pkgs/os-specific/linux/rtl8192eu/default.nix +++ b/pkgs/os-specific/linux/rtl8192eu/default.nix @@ -1,8 +1,16 @@ -{ stdenv, lib, fetchFromGitHub, kernel, bc }: - -let modDestDir = "$out/lib/modules/${kernel.modDirVersion}/kernel/drivers/net/wireless/realtek/rtl8192eu"; - -in stdenv.mkDerivation { +{ + stdenv, + lib, + fetchFromGitHub, + kernel, + bc, +}: + +let + modDestDir = "$out/lib/modules/${kernel.modDirVersion}/kernel/drivers/net/wireless/realtek/rtl8192eu"; + +in +stdenv.mkDerivation { pname = "rtl8192eu"; version = "${kernel.version}-4.4.1.20240507"; diff --git a/pkgs/os-specific/linux/rtl8723ds/default.nix b/pkgs/os-specific/linux/rtl8723ds/default.nix index d1f7e016e3bf3b..bc7b9e51a7542d 100644 --- a/pkgs/os-specific/linux/rtl8723ds/default.nix +++ b/pkgs/os-specific/linux/rtl8723ds/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, kernel, bc }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + bc, +}: stdenv.mkDerivation { pname = "rtl8723ds"; @@ -15,11 +21,13 @@ stdenv.mkDerivation { nativeBuildInputs = [ bc ] ++ kernel.moduleBuildDependencies; - makeFlags = [ - "ARCH=${stdenv.hostPlatform.linuxArch}" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "CROSS_COMPILE=${stdenv.cc.targetPrefix}" - ]; + makeFlags = + [ + "ARCH=${stdenv.hostPlatform.linuxArch}" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "CROSS_COMPILE=${stdenv.cc.targetPrefix}" + ]; postPatch = '' substituteInPlace ./Makefile \ diff --git a/pkgs/os-specific/linux/rtl8812au/default.nix b/pkgs/os-specific/linux/rtl8812au/default.nix index 6aab44d92c72e8..a429d075feb502 100644 --- a/pkgs/os-specific/linux/rtl8812au/default.nix +++ b/pkgs/os-specific/linux/rtl8812au/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, kernel, bc, nukeReferences }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + bc, + nukeReferences, +}: stdenv.mkDerivation { pname = "rtl8812au"; @@ -11,8 +18,14 @@ stdenv.mkDerivation { hash = "sha256-ZS0iUb77XnXR5BUMeQ1EDuly7hStRt430ECueFW4v4w="; }; - nativeBuildInputs = [ bc nukeReferences ] ++ kernel.moduleBuildDependencies; - hardeningDisable = [ "pic" "format" ]; + nativeBuildInputs = [ + bc + nukeReferences + ] ++ kernel.moduleBuildDependencies; + hardeningDisable = [ + "pic" + "format" + ]; prePatch = '' substituteInPlace ./Makefile \ @@ -21,13 +34,15 @@ stdenv.mkDerivation { --replace '$(MODDESTDIR)' "$out/lib/modules/${kernel.modDirVersion}/kernel/net/wireless/" ''; - makeFlags = [ - "ARCH=${stdenv.hostPlatform.linuxArch}" - ("CONFIG_PLATFORM_I386_PC=" + (if stdenv.hostPlatform.isx86 then "y" else "n")) - ("CONFIG_PLATFORM_ARM_RPI=" + (if stdenv.hostPlatform.isAarch then "y" else "n")) - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "CROSS_COMPILE=${stdenv.cc.targetPrefix}" - ]; + makeFlags = + [ + "ARCH=${stdenv.hostPlatform.linuxArch}" + ("CONFIG_PLATFORM_I386_PC=" + (if stdenv.hostPlatform.isx86 then "y" else "n")) + ("CONFIG_PLATFORM_ARM_RPI=" + (if stdenv.hostPlatform.isAarch then "y" else "n")) + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "CROSS_COMPILE=${stdenv.cc.targetPrefix}" + ]; preInstall = '' mkdir -p "$out/lib/modules/${kernel.modDirVersion}/kernel/net/wireless/" diff --git a/pkgs/os-specific/linux/rtl8814au/default.nix b/pkgs/os-specific/linux/rtl8814au/default.nix index fbe1d62f28d3d5..c808fa95dd243d 100644 --- a/pkgs/os-specific/linux/rtl8814au/default.nix +++ b/pkgs/os-specific/linux/rtl8814au/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation { pname = "rtl8814au"; diff --git a/pkgs/os-specific/linux/rtl8821au/default.nix b/pkgs/os-specific/linux/rtl8821au/default.nix index e8be48cc403c86..dacc0d1a357fac 100644 --- a/pkgs/os-specific/linux/rtl8821au/default.nix +++ b/pkgs/os-specific/linux/rtl8821au/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, kernel, bc, nukeReferences }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + bc, + nukeReferences, +}: stdenv.mkDerivation { pname = "rtl8821au"; @@ -11,19 +18,30 @@ stdenv.mkDerivation { hash = "sha256-eB9RCoU5jg5fgZkfcef9fsQ6tyD8gTPD+wYcR6PbWNw="; }; - nativeBuildInputs = [ bc nukeReferences ] ++ kernel.moduleBuildDependencies; + nativeBuildInputs = [ + bc + nukeReferences + ] ++ kernel.moduleBuildDependencies; - hardeningDisable = [ "pic" "format" ]; + hardeningDisable = [ + "pic" + "format" + ]; env.NIX_CFLAGS_COMPILE = "-Wno-error=incompatible-pointer-types"; - makeFlags = [ - "ARCH=${stdenv.hostPlatform.linuxArch}" - ("CONFIG_PLATFORM_I386_PC=" + (if stdenv.hostPlatform.isx86 then "y" else "n")) - ("CONFIG_PLATFORM_ARM_RPI=" + (if (stdenv.hostPlatform.isAarch32 || stdenv.hostPlatform.isAarch64) then "y" else "n")) - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "CROSS_COMPILE=${stdenv.cc.targetPrefix}" - ]; + makeFlags = + [ + "ARCH=${stdenv.hostPlatform.linuxArch}" + ("CONFIG_PLATFORM_I386_PC=" + (if stdenv.hostPlatform.isx86 then "y" else "n")) + ( + "CONFIG_PLATFORM_ARM_RPI=" + + (if (stdenv.hostPlatform.isAarch32 || stdenv.hostPlatform.isAarch64) then "y" else "n") + ) + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "CROSS_COMPILE=${stdenv.cc.targetPrefix}" + ]; prePatch = '' substituteInPlace ./Makefile \ diff --git a/pkgs/os-specific/linux/rtl8821cu/default.nix b/pkgs/os-specific/linux/rtl8821cu/default.nix index 440a66ca341f2c..270d6832f4127d 100644 --- a/pkgs/os-specific/linux/rtl8821cu/default.nix +++ b/pkgs/os-specific/linux/rtl8821cu/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, kernel, bc }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + bc, +}: stdenv.mkDerivation { pname = "rtl8821cu"; diff --git a/pkgs/os-specific/linux/rtl8852au/default.nix b/pkgs/os-specific/linux/rtl8852au/default.nix index 97ac0c75b17e19..5adbffc6fba9ab 100644 --- a/pkgs/os-specific/linux/rtl8852au/default.nix +++ b/pkgs/os-specific/linux/rtl8852au/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, kernel, bc, nukeReferences }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + bc, + nukeReferences, +}: stdenv.mkDerivation (finalAttrs: { pname = "rtl8852au"; @@ -11,8 +18,14 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-c2dpnZS6a0waL1khB9ZEglTwJIBsyRebTMig1B4A0xU="; }; - nativeBuildInputs = [ bc nukeReferences ] ++ kernel.moduleBuildDependencies; - hardeningDisable = [ "pic" "format" ]; + nativeBuildInputs = [ + bc + nukeReferences + ] ++ kernel.moduleBuildDependencies; + hardeningDisable = [ + "pic" + "format" + ]; postPatch = '' substituteInPlace ./Makefile \ @@ -23,13 +36,15 @@ stdenv.mkDerivation (finalAttrs: { --replace-fail /lib/modules "${kernel.dev}/lib/modules" ''; - makeFlags = [ - "ARCH=${stdenv.hostPlatform.linuxArch}" - ("CONFIG_PLATFORM_I386_PC=" + (if stdenv.hostPlatform.isx86 then "y" else "n")) - ("CONFIG_PLATFORM_ARM_RPI=" + (if stdenv.hostPlatform.isAarch then "y" else "n")) - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "CROSS_COMPILE=${stdenv.cc.targetPrefix}" - ]; + makeFlags = + [ + "ARCH=${stdenv.hostPlatform.linuxArch}" + ("CONFIG_PLATFORM_I386_PC=" + (if stdenv.hostPlatform.isx86 then "y" else "n")) + ("CONFIG_PLATFORM_ARM_RPI=" + (if stdenv.hostPlatform.isAarch then "y" else "n")) + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "CROSS_COMPILE=${stdenv.cc.targetPrefix}" + ]; preInstall = '' mkdir -p "$out/lib/modules/${kernel.modDirVersion}/kernel/net/wireless/" diff --git a/pkgs/os-specific/linux/rtl8852bu/default.nix b/pkgs/os-specific/linux/rtl8852bu/default.nix index 4b5366cab9d0c8..db6c419a354169 100644 --- a/pkgs/os-specific/linux/rtl8852bu/default.nix +++ b/pkgs/os-specific/linux/rtl8852bu/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, kernel, bc, nukeReferences }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + bc, + nukeReferences, +}: stdenv.mkDerivation rec { pname = "rtl8852bu"; @@ -11,8 +18,14 @@ stdenv.mkDerivation rec { hash = "sha256-22vzAdzzM5YnfU8kRWSK3HXxw6BA4FOWXLdWEb7T5IE="; }; - nativeBuildInputs = [ bc nukeReferences ] ++ kernel.moduleBuildDependencies; - hardeningDisable = [ "pic" "format" ]; + nativeBuildInputs = [ + bc + nukeReferences + ] ++ kernel.moduleBuildDependencies; + hardeningDisable = [ + "pic" + "format" + ]; postPatch = '' substituteInPlace ./Makefile \ @@ -22,13 +35,15 @@ stdenv.mkDerivation rec { --replace-fail /lib/modules "${kernel.dev}/lib/modules" ''; - makeFlags = [ - "ARCH=${stdenv.hostPlatform.linuxArch}" - ("CONFIG_PLATFORM_I386_PC=" + (if stdenv.hostPlatform.isx86 then "y" else "n")) - ("CONFIG_PLATFORM_ARM_RPI=" + (if stdenv.hostPlatform.isAarch then "y" else "n")) - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "CROSS_COMPILE=${stdenv.cc.targetPrefix}" - ]; + makeFlags = + [ + "ARCH=${stdenv.hostPlatform.linuxArch}" + ("CONFIG_PLATFORM_I386_PC=" + (if stdenv.hostPlatform.isx86 then "y" else "n")) + ("CONFIG_PLATFORM_ARM_RPI=" + (if stdenv.hostPlatform.isAarch then "y" else "n")) + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "CROSS_COMPILE=${stdenv.cc.targetPrefix}" + ]; preInstall = '' mkdir -p "$out/lib/modules/${kernel.modDirVersion}/kernel/net/wireless/" diff --git a/pkgs/os-specific/linux/rtl88xxau-aircrack/default.nix b/pkgs/os-specific/linux/rtl88xxau-aircrack/default.nix index 2f6ab211d32e22..58f810fe0830aa 100644 --- a/pkgs/os-specific/linux/rtl88xxau-aircrack/default.nix +++ b/pkgs/os-specific/linux/rtl88xxau-aircrack/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { pname = "rtl88xxau-aircrack"; @@ -34,7 +39,14 @@ stdenv.mkDerivation rec { (8811au, 8812au, 8814au and 8821au chipsets) with monitor mode and injection support.''; homepage = "https://github.com/aircrack-ng/rtl8812au"; license = licenses.gpl2Only; - maintainers = [ maintainers.ja1den maintainers.jethro ]; - platforms = [ "x86_64-linux" "i686-linux" "aarch64-linux" ]; + maintainers = [ + maintainers.ja1den + maintainers.jethro + ]; + platforms = [ + "x86_64-linux" + "i686-linux" + "aarch64-linux" + ]; }; } diff --git a/pkgs/os-specific/linux/rtw88/default.nix b/pkgs/os-specific/linux/rtw88/default.nix index 5dcee061edd7e7..095f4135c82d9e 100644 --- a/pkgs/os-specific/linux/rtw88/default.nix +++ b/pkgs/os-specific/linux/rtw88/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, kernel }: +{ + stdenv, + lib, + fetchFromGitHub, + kernel, +}: let modDestDir = "$out/lib/modules/${kernel.modDirVersion}/kernel/drivers/net/wireless/realtek/rtw88"; @@ -32,8 +37,14 @@ stdenv.mkDerivation { meta = with lib; { description = "Backport of the latest Realtek RTW88 driver from wireless-next for older kernels"; homepage = "https://github.com/lwfinger/rtw88"; - license = with licenses; [ bsd3 gpl2Only ]; - maintainers = with maintainers; [ tvorog atila ]; + license = with licenses; [ + bsd3 + gpl2Only + ]; + maintainers = with maintainers; [ + tvorog + atila + ]; platforms = platforms.linux; broken = kernel.kernelOlder "4.20"; priority = -1; diff --git a/pkgs/os-specific/linux/rtw89/default.nix b/pkgs/os-specific/linux/rtw89/default.nix index 1bb42860a8c764..a704f75ec17410 100644 --- a/pkgs/os-specific/linux/rtw89/default.nix +++ b/pkgs/os-specific/linux/rtw89/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, kernel }: +{ + stdenv, + lib, + fetchFromGitHub, + kernel, +}: let modDestDir = "$out/lib/modules/${kernel.modDirVersion}/kernel/drivers/net/wireless/realtek/rtw89"; diff --git a/pkgs/os-specific/linux/rust-out-of-tree-module/default.nix b/pkgs/os-specific/linux/rust-out-of-tree-module/default.nix index ba0bd561d5977e..c2a4a52c20e5f3 100644 --- a/pkgs/os-specific/linux/rust-out-of-tree-module/default.nix +++ b/pkgs/os-specific/linux/rust-out-of-tree-module/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, kernel, unstableGitUpdater }: +{ + lib, + fetchFromGitHub, + kernel, + unstableGitUpdater, +}: kernel.stdenv.mkDerivation { pname = "rust-out-of-tree-module"; version = "0-unstable-2024-05-06"; @@ -25,8 +30,7 @@ kernel.stdenv.mkDerivation { homepage = "https://github.com/Rust-for-Linux/rust-out-of-tree-module"; license = lib.licenses.gpl2Only; maintainers = [ lib.maintainers.blitz ]; - platforms = [ "x86_64-linux" ] - ++ lib.optional (kernel.kernelAtLeast "6.9") "aarch64-linux"; + platforms = [ "x86_64-linux" ] ++ lib.optional (kernel.kernelAtLeast "6.9") "aarch64-linux"; }; } diff --git a/pkgs/os-specific/linux/ryzen-smu/default.nix b/pkgs/os-specific/linux/ryzen-smu/default.nix index 87fb02fd08fe27..40226010ec9e87 100644 --- a/pkgs/os-specific/linux/ryzen-smu/default.nix +++ b/pkgs/os-specific/linux/ryzen-smu/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, kernel +{ + lib, + stdenv, + fetchFromGitHub, + kernel, }: let @@ -27,12 +28,12 @@ let ]; installPhase = '' - runHook preInstall + runHook preInstall - install userspace/monitor_cpu -Dm755 -t $out/bin + install userspace/monitor_cpu -Dm755 -t $out/bin - runHook postInstall - ''; + runHook postInstall + ''; }; in @@ -62,7 +63,10 @@ stdenv.mkDerivation { description = "Linux kernel driver that exposes access to the SMU (System Management Unit) for certain AMD Ryzen Processors"; homepage = "https://gitlab.com/leogx9r/ryzen_smu"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ Cryolitia phdyellow ]; + maintainers = with maintainers; [ + Cryolitia + phdyellow + ]; platforms = [ "x86_64-linux" ]; mainProgram = "monitor_cpu"; }; diff --git a/pkgs/os-specific/linux/scx/scx_cscheds.nix b/pkgs/os-specific/linux/scx/scx_cscheds.nix index b333589ae11e86..b6d984f8b0001f 100644 --- a/pkgs/os-specific/linux/scx/scx_cscheds.nix +++ b/pkgs/os-specific/linux/scx/scx_cscheds.nix @@ -84,13 +84,16 @@ llvmPackages.stdenv.mkDerivation (finalAttrs: { --replace-fail '[build_bpftool' "['${misbehaviorBash}', build_bpftool" ''; - nativeBuildInputs = [ - meson - ninja - jq - pkg-config - zstd - ] ++ bpftools.buildInputs ++ bpftools.nativeBuildInputs; + nativeBuildInputs = + [ + meson + ninja + jq + pkg-config + zstd + ] + ++ bpftools.buildInputs + ++ bpftools.nativeBuildInputs; buildInputs = [ elfutils diff --git a/pkgs/os-specific/linux/sgx/psw/default.nix b/pkgs/os-specific/linux/sgx/psw/default.nix index 6a73775dbf83f5..2b3e97604f9733 100644 --- a/pkgs/os-specific/linux/sgx/psw/default.nix +++ b/pkgs/os-specific/linux/sgx/psw/default.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, fetchurl -, fetchFromGitHub -, cmake -, coreutils -, curl -, file -, git -, makeWrapper -, nixosTests -, protobuf -, python3 -, ocaml -, ocamlPackages -, which -, debug ? false +{ + stdenv, + lib, + fetchurl, + fetchFromGitHub, + cmake, + coreutils, + curl, + file, + git, + makeWrapper, + nixosTests, + protobuf, + python3, + ocaml, + ocamlPackages, + which, + debug ? false, }: stdenv.mkDerivation rec { pname = "sgx-psw"; @@ -263,7 +264,11 @@ stdenv.mkDerivation rec { meta = { description = "Intel SGX Architectural Enclave Service Manager"; homepage = "https://github.com/intel/linux-sgx"; - maintainers = with lib.maintainers; [ phlip9 veehaitch citadelcore ]; + maintainers = with lib.maintainers; [ + phlip9 + veehaitch + citadelcore + ]; platforms = [ "x86_64-linux" ]; license = [ lib.licenses.bsd3 ]; }; diff --git a/pkgs/os-specific/linux/sgx/samples/default.nix b/pkgs/os-specific/linux/sgx/samples/default.nix index 0cbd6db02838a0..7b31a96240cd6e 100644 --- a/pkgs/os-specific/linux/sgx/samples/default.nix +++ b/pkgs/os-specific/linux/sgx/samples/default.nix @@ -1,70 +1,74 @@ -{ stdenv -, lib -, makeWrapper -, openssl -, sgx-sdk -, sgx-psw -, which +{ + stdenv, + lib, + makeWrapper, + openssl, + sgx-sdk, + sgx-psw, + which, # "SIM" or "HW" -, sgxMode + sgxMode, }: let isSimulation = sgxMode == "SIM"; - buildSample = name: stdenv.mkDerivation { - pname = name; - version = sgxMode; + buildSample = + name: + stdenv.mkDerivation { + pname = name; + version = sgxMode; - src = sgx-sdk.out; - sourceRoot = "${sgx-sdk.name}/share/SampleCode/${name}"; + src = sgx-sdk.out; + sourceRoot = "${sgx-sdk.name}/share/SampleCode/${name}"; - nativeBuildInputs = [ - makeWrapper - openssl - which - ]; + nativeBuildInputs = [ + makeWrapper + openssl + which + ]; - buildInputs = [ - sgx-sdk - ]; + buildInputs = [ + sgx-sdk + ]; - # The samples don't have proper support for parallel building - # causing them to fail randomly. - enableParallelBuilding = false; + # The samples don't have proper support for parallel building + # causing them to fail randomly. + enableParallelBuilding = false; - buildFlags = [ - "SGX_MODE=${sgxMode}" - ]; + buildFlags = [ + "SGX_MODE=${sgxMode}" + ]; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $out/{bin,lib} - install -m 755 app $out/bin - install *.so $out/lib + mkdir -p $out/{bin,lib} + install -m 755 app $out/bin + install *.so $out/lib - wrapProgram "$out/bin/app" \ - --chdir "$out/lib" \ - ${lib.optionalString (!isSimulation) - ''--prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ sgx-psw ]}"''} + wrapProgram "$out/bin/app" \ + --chdir "$out/lib" \ + ${lib.optionalString (!isSimulation) + ''--prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ sgx-psw ]}"'' + } - runHook postInstall - ''; + runHook postInstall + ''; - # Breaks the signature of the enclaves - dontFixup = true; + # Breaks the signature of the enclaves + dontFixup = true; - # We don't have access to real SGX hardware during the build - doInstallCheck = isSimulation; - installCheckPhase = '' - runHook preInstallCheck + # We don't have access to real SGX hardware during the build + doInstallCheck = isSimulation; + installCheckPhase = '' + runHook preInstallCheck - pushd / - echo a | $out/bin/app - popd + pushd / + echo a | $out/bin/app + popd - runHook preInstallCheck - ''; - }; + runHook preInstallCheck + ''; + }; in { cxx11SGXDemo = buildSample "Cxx11SGXDemo"; @@ -82,7 +86,8 @@ in wrapProgram $bin \ --chdir "$out/lib" \ ${lib.optionalString (!isSimulation) - ''--prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ sgx-psw ]}"''} + ''--prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ sgx-psw ]}"'' + } done runHook postInstall @@ -112,7 +117,8 @@ in switchless = buildSample "Switchless"; # # Requires SGX-patched openssl (sgxssl) build # sampleAttestedTLS = buildSample "SampleAttestedTLS"; -} // lib.optionalAttrs (!isSimulation) { +} +// lib.optionalAttrs (!isSimulation) { # # Requires kernel >= v6.2 && HW SGX # sampleAEXNotify = buildSample "SampleAEXNotify"; @@ -129,7 +135,7 @@ in wrapProgram "$out/bin/app" \ --chdir "$out/lib" \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [sgx-psw]}" + --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ sgx-psw ]}" runHook postInstall ''; diff --git a/pkgs/os-specific/linux/sgx/sdk/default.nix b/pkgs/os-specific/linux/sgx/sdk/default.nix index 4f7374d634f36f..5e9b99af143f15 100644 --- a/pkgs/os-specific/linux/sgx/sdk/default.nix +++ b/pkgs/os-specific/linux/sgx/sdk/default.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, binutils -, callPackage -, cmake -, file -, gdb -, git -, libtool -, linkFarmFromDrvs -, ocaml -, ocamlPackages -, openssl -, perl -, python3 -, texinfo -, validatePkgConfig -, writeShellApplication -, writeShellScript -, writeText -, debug ? false +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + binutils, + callPackage, + cmake, + file, + gdb, + git, + libtool, + linkFarmFromDrvs, + ocaml, + ocamlPackages, + openssl, + perl, + python3, + texinfo, + validatePkgConfig, + writeShellApplication, + writeShellScript, + writeText, + debug ? false, }: stdenv.mkDerivation rec { pname = "sgx-sdk"; @@ -141,11 +142,13 @@ stdenv.mkDerivation rec { popd ''; - buildFlags = [ - "sdk_install_pkg" - ] ++ lib.optionals debug [ - "DEBUG=1" - ]; + buildFlags = + [ + "sdk_install_pkg" + ] + ++ lib.optionals debug [ + "DEBUG=1" + ]; postBuild = '' patchShebangs linux/installer/bin/sgx_linux_x64_sdk_${version}.bin @@ -291,7 +294,12 @@ stdenv.mkDerivation rec { meta = { description = "Intel SGX SDK for Linux built with IPP Crypto Library"; homepage = "https://github.com/intel/linux-sgx"; - maintainers = with lib.maintainers; [ phlip9 sbellem arturcygan veehaitch ]; + maintainers = with lib.maintainers; [ + phlip9 + sbellem + arturcygan + veehaitch + ]; platforms = [ "x86_64-linux" ]; license = [ lib.licenses.bsd3 ]; }; diff --git a/pkgs/os-specific/linux/sgx/sdk/ipp-crypto.nix b/pkgs/os-specific/linux/sgx/sdk/ipp-crypto.nix index eba9e7f6a0e5ca..d75654fdcf1a22 100644 --- a/pkgs/os-specific/linux/sgx/sdk/ipp-crypto.nix +++ b/pkgs/os-specific/linux/sgx/sdk/ipp-crypto.nix @@ -1,10 +1,11 @@ -{ gcc11Stdenv -, fetchFromGitHub -, cmake -, nasm -, openssl -, python3 -, extraCmakeFlags ? [ ] +{ + gcc11Stdenv, + fetchFromGitHub, + cmake, + nasm, + openssl, + python3, + extraCmakeFlags ? [ ], }: gcc11Stdenv.mkDerivation rec { pname = "ipp-crypto"; diff --git a/pkgs/os-specific/linux/sinit/default.nix b/pkgs/os-specific/linux/sinit/default.nix index 680e1ae2771c2e..8cbfa053bc211e 100644 --- a/pkgs/os-specific/linux/sinit/default.nix +++ b/pkgs/os-specific/linux/sinit/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchgit, rcinit ? null, rcshutdown ? null, rcreboot ? null }: +{ + lib, + stdenv, + fetchgit, + rcinit ? null, + rcshutdown ? null, + rcreboot ? null, +}: stdenv.mkDerivation rec { pname = "sinit"; @@ -13,11 +20,17 @@ stdenv.mkDerivation rec { (lib.getOutput "static" stdenv.cc.libc) ]; makeFlags = [ "PREFIX=$(out)" ]; - preConfigure = "" - + (lib.optionalString (rcinit != null) ''sed -re 's@(rcinitcmd[^"]*")[^"]*"@\1${rcinit}"@' -i config.def.h; '') - + (lib.optionalString (rcshutdown != null) ''sed -re 's@(rc(reboot|poweroff)cmd[^"]*")[^"]*"@\1${rcshutdown}"@' -i config.def.h; '') - + (lib.optionalString (rcreboot != null) ''sed -re 's@(rc(reboot)cmd[^"]*")[^"]*"@\1${rcreboot}"@' -i config.def.h; '') - ; + preConfigure = + "" + + (lib.optionalString ( + rcinit != null + ) ''sed -re 's@(rcinitcmd[^"]*")[^"]*"@\1${rcinit}"@' -i config.def.h; '') + + (lib.optionalString ( + rcshutdown != null + ) ''sed -re 's@(rc(reboot|poweroff)cmd[^"]*")[^"]*"@\1${rcshutdown}"@' -i config.def.h; '') + + (lib.optionalString ( + rcreboot != null + ) ''sed -re 's@(rc(reboot)cmd[^"]*")[^"]*"@\1${rcreboot}"@' -i config.def.h; ''); meta = with lib; { description = "Very minimal Linux init implementation from suckless.org"; diff --git a/pkgs/os-specific/linux/sssd/default.nix b/pkgs/os-specific/linux/sssd/default.nix index b3395c7a4ceae7..ae9eb0d16c083a 100644 --- a/pkgs/os-specific/linux/sssd/default.nix +++ b/pkgs/os-specific/linux/sssd/default.nix @@ -1,12 +1,60 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, makeWrapper, glibc, adcli, augeas, dnsutils, c-ares, curl, - cyrus_sasl, ding-libs, libnl, libunistring, nss, samba, nfs-utils, doxygen, - python3, pam, popt, talloc, tdb, tevent, pkg-config, ldb, openldap, - pcre2, libkrb5, cifs-utils, glib, keyutils, dbus, fakeroot, libxslt, libxml2, - libuuid, systemd, nspr, check, cmocka, uid_wrapper, p11-kit, - nss_wrapper, ncurses, Po4a, jansson, jose, - docbook_xsl, docbook_xml_dtd_45, - testers, nix-update-script, nixosTests, - withSudo ? false }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + makeWrapper, + glibc, + adcli, + augeas, + dnsutils, + c-ares, + curl, + cyrus_sasl, + ding-libs, + libnl, + libunistring, + nss, + samba, + nfs-utils, + doxygen, + python3, + pam, + popt, + talloc, + tdb, + tevent, + pkg-config, + ldb, + openldap, + pcre2, + libkrb5, + cifs-utils, + glib, + keyutils, + dbus, + fakeroot, + libxslt, + libxml2, + libuuid, + systemd, + nspr, + check, + cmocka, + uid_wrapper, + p11-kit, + nss_wrapper, + ncurses, + Po4a, + jansson, + jose, + docbook_xsl, + docbook_xml_dtd_45, + testers, + nix-update-script, + nixosTests, + withSudo ? false, +}: let docbookFiles = "${docbook_xsl}/share/xml/docbook-xsl/catalog.xml:${docbook_xml_dtd_45}/xml/dtd/docbook/catalog.xml"; @@ -32,59 +80,103 @@ stdenv.mkDerivation (finalAttrs: { "-I${libxml2.dev}/include/libxml2" ]; - preConfigure = '' - export SGML_CATALOG_FILES="${docbookFiles}" - export PYTHONPATH=$(find ${python3.pkgs.python-ldap} -type d -name site-packages) - export PATH=$PATH:${openldap}/libexec + preConfigure = + '' + export SGML_CATALOG_FILES="${docbookFiles}" + export PYTHONPATH=$(find ${python3.pkgs.python-ldap} -type d -name site-packages) + export PATH=$PATH:${openldap}/libexec - configureFlagsArray=( - --prefix=$out - --sysconfdir=/etc - --localstatedir=/var - --enable-pammoddir=$out/lib/security - --with-os=fedora - --with-pid-path=/run - --with-python3-bindings - --with-syslog=journald - --without-selinux - --without-semanage - --with-xml-catalog-path=''${SGML_CATALOG_FILES%%:*} - --with-ldb-lib-dir=$out/modules/ldb - --with-nscd=${glibc.bin}/sbin/nscd - ) - '' + lib.optionalString withSudo '' - configureFlagsArray+=("--with-sudo") - ''; + configureFlagsArray=( + --prefix=$out + --sysconfdir=/etc + --localstatedir=/var + --enable-pammoddir=$out/lib/security + --with-os=fedora + --with-pid-path=/run + --with-python3-bindings + --with-syslog=journald + --without-selinux + --without-semanage + --with-xml-catalog-path=''${SGML_CATALOG_FILES%%:*} + --with-ldb-lib-dir=$out/modules/ldb + --with-nscd=${glibc.bin}/sbin/nscd + ) + '' + + lib.optionalString withSudo '' + configureFlagsArray+=("--with-sudo") + ''; enableParallelBuilding = true; # Disable parallel install due to missing depends: # libtool: error: error: relink '_py3sss.la' with the above command before installing i enableParallelInstalling = false; - nativeBuildInputs = [ autoreconfHook makeWrapper pkg-config doxygen ]; - buildInputs = [ augeas dnsutils c-ares curl cyrus_sasl ding-libs libnl libunistring nss - samba nfs-utils p11-kit python3 popt - talloc tdb tevent ldb pam openldap pcre2 libkrb5 - cifs-utils glib keyutils dbus fakeroot libxslt libxml2 - libuuid python3.pkgs.python-ldap systemd nspr check cmocka uid_wrapper - nss_wrapper ncurses Po4a jansson jose ]; + nativeBuildInputs = [ + autoreconfHook + makeWrapper + pkg-config + doxygen + ]; + buildInputs = [ + augeas + dnsutils + c-ares + curl + cyrus_sasl + ding-libs + libnl + libunistring + nss + samba + nfs-utils + p11-kit + python3 + popt + talloc + tdb + tevent + ldb + pam + openldap + pcre2 + libkrb5 + cifs-utils + glib + keyutils + dbus + fakeroot + libxslt + libxml2 + libuuid + python3.pkgs.python-ldap + systemd + nspr + check + cmocka + uid_wrapper + nss_wrapper + ncurses + Po4a + jansson + jose + ]; makeFlags = [ "SGML_CATALOG_FILES=${docbookFiles}" ]; installFlags = [ - "sysconfdir=$(out)/etc" - "localstatedir=$(out)/var" - "pidpath=$(out)/run" - "sss_statedir=$(out)/var/lib/sss" - "logpath=$(out)/var/log/sssd" - "pubconfpath=$(out)/var/lib/sss/pubconf" - "dbpath=$(out)/var/lib/sss/db" - "mcpath=$(out)/var/lib/sss/mc" - "pipepath=$(out)/var/lib/sss/pipes" - "gpocachepath=$(out)/var/lib/sss/gpo_cache" - "secdbpath=$(out)/var/lib/sss/secrets" - "initdir=$(out)/rc.d/init" + "sysconfdir=$(out)/etc" + "localstatedir=$(out)/var" + "pidpath=$(out)/run" + "sss_statedir=$(out)/var/lib/sss" + "logpath=$(out)/var/log/sssd" + "pubconfpath=$(out)/var/lib/sss/pubconf" + "dbpath=$(out)/var/lib/sss/db" + "mcpath=$(out)/var/lib/sss/mc" + "pipepath=$(out)/var/lib/sss/pipes" + "gpocachepath=$(out)/var/lib/sss/gpo_cache" + "secdbpath=$(out)/var/lib/sss/secrets" + "initdir=$(out)/rc.d/init" ]; postInstall = '' diff --git a/pkgs/os-specific/linux/sysdig/default.nix b/pkgs/os-specific/linux/sysdig/default.nix index 38779e28ceb172..0568f183b1cef0 100644 --- a/pkgs/os-specific/linux/sysdig/default.nix +++ b/pkgs/os-specific/linux/sysdig/default.nix @@ -98,7 +98,10 @@ stdenv.mkDerivation { bpftools ] ++ lib.optionals (kernel != null) kernel.moduleBuildDependencies; - hardeningDisable = [ "pic" "zerocallusedregs" ]; + hardeningDisable = [ + "pic" + "zerocallusedregs" + ]; postUnpack = '' cp -r ${ diff --git a/pkgs/os-specific/linux/system76-acpi/default.nix b/pkgs/os-specific/linux/system76-acpi/default.nix index b384cf6394872a..2df682506c3860 100644 --- a/pkgs/os-specific/linux/system76-acpi/default.nix +++ b/pkgs/os-specific/linux/system76-acpi/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: let version = "1.0.2"; sha256 = "1i7zjn5cdv9h00fgjg46b8yrz4d3dqvfr25g3f13967ycy58m48h"; @@ -32,7 +37,10 @@ stdenv.mkDerivation { meta = with lib; { maintainers = [ maintainers.khumba ]; license = [ licenses.gpl2Only ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; broken = kernel.kernelOlder "5.2"; description = "System76 ACPI Driver (DKMS)"; homepage = "https://github.com/pop-os/system76-acpi-dkms"; diff --git a/pkgs/os-specific/linux/system76-io/default.nix b/pkgs/os-specific/linux/system76-io/default.nix index 772ef9f06d091d..257c56d59d720a 100644 --- a/pkgs/os-specific/linux/system76-io/default.nix +++ b/pkgs/os-specific/linux/system76-io/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: let version = "1.0.4"; hash = "sha256-VE6sCehjXlRuOVcK4EN2H+FhaVaBi/jrAYx4TZjbreA="; @@ -28,9 +33,16 @@ stdenv.mkDerivation { ''; meta = { - maintainers = with lib.maintainers; [ khumba ahoneybun ]; + maintainers = with lib.maintainers; [ + khumba + ahoneybun + ]; license = lib.licenses.gpl2Plus; - platforms = [ "i686-linux" "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + "aarch64-linux" + ]; broken = lib.versionOlder kernel.version "5.10"; description = "DKMS module for controlling System76 Io board"; homepage = "https://github.com/pop-os/system76-io-dkms"; diff --git a/pkgs/os-specific/linux/system76/default.nix b/pkgs/os-specific/linux/system76/default.nix index b42b31c5a214f3..95576c8861f089 100644 --- a/pkgs/os-specific/linux/system76/default.nix +++ b/pkgs/os-specific/linux/system76/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: let version = "1.0.16"; hash = "sha256-jsBLy5WDl2l8o/2ccIk1XMqOukeDX5eZ+VH5Dyo5BaA="; @@ -32,7 +37,10 @@ stdenv.mkDerivation { meta = { maintainers = [ lib.maintainers.khumba ]; license = [ lib.licenses.gpl2Plus ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; description = "System76 DKMS driver"; homepage = "https://github.com/pop-os/system76-dkms"; longDescription = '' diff --git a/pkgs/os-specific/linux/tmon/default.nix b/pkgs/os-specific/linux/tmon/default.nix index c4222cfc3a2457..764891a4bbc1ea 100644 --- a/pkgs/os-specific/linux/tmon/default.nix +++ b/pkgs/os-specific/linux/tmon/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, kernel, ncurses }: +{ + lib, + stdenv, + kernel, + ncurses, +}: stdenv.mkDerivation { pname = "tmon"; @@ -12,7 +17,10 @@ stdenv.mkDerivation { cd tools/thermal/tmon ''; - makeFlags = kernel.makeFlags ++ [ "INSTALL_ROOT=\"$(out)\"" "BINDIR=bin" ]; + makeFlags = kernel.makeFlags ++ [ + "INSTALL_ROOT=\"$(out)\"" + "BINDIR=bin" + ]; NIX_CFLAGS_LINK = "-lgcc_s"; enableParallelBuilding = true; diff --git a/pkgs/os-specific/linux/tp_smapi/default.nix b/pkgs/os-specific/linux/tp_smapi/default.nix index b0f760e3b00adc..6d8a46afd2c6d7 100644 --- a/pkgs/os-specific/linux/tp_smapi/default.nix +++ b/pkgs/os-specific/linux/tp_smapi/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, kernel -, writeScript -, coreutils -, gnugrep -, jq -, curl -, common-updater-scripts -, runtimeShell +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + kernel, + writeScript, + coreutils, + gnugrep, + jq, + curl, + common-updater-scripts, + runtimeShell, }: stdenv.mkDerivation rec { @@ -53,7 +54,16 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; passthru.updateScript = import ./update.nix { - inherit lib writeScript coreutils gnugrep jq curl common-updater-scripts runtimeShell; + inherit + lib + writeScript + coreutils + gnugrep + jq + curl + common-updater-scripts + runtimeShell + ; }; meta = { @@ -62,6 +72,9 @@ stdenv.mkDerivation rec { license = lib.licenses.gpl2Plus; maintainers = [ ]; # driver is only ment for linux thinkpads i think bellow platforms should cover it. - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; }; } diff --git a/pkgs/os-specific/linux/tp_smapi/update.nix b/pkgs/os-specific/linux/tp_smapi/update.nix index 65b557e454572a..8b6fde3c0eaab0 100644 --- a/pkgs/os-specific/linux/tp_smapi/update.nix +++ b/pkgs/os-specific/linux/tp_smapi/update.nix @@ -1,11 +1,28 @@ -{ lib, writeScript, coreutils, curl, gnugrep, jq, common-updater-scripts, runtimeShell }: +{ + lib, + writeScript, + coreutils, + curl, + gnugrep, + jq, + common-updater-scripts, + runtimeShell, +}: writeScript "update-tp_smapi" '' -#!${runtimeShell} -PATH=${lib.makeBinPath [ common-updater-scripts coreutils curl gnugrep jq ]} + #!${runtimeShell} + PATH=${ + lib.makeBinPath [ + common-updater-scripts + coreutils + curl + gnugrep + jq + ] + } -tags=`curl -s https://api.github.com/repos/evgeni/tp_smapi/tags` -latest_tag=`echo $tags | jq -r '.[] | .name' | grep -oP "^tp-smapi/\K.*" | sort --version-sort | tail -1` + tags=`curl -s https://api.github.com/repos/evgeni/tp_smapi/tags` + latest_tag=`echo $tags | jq -r '.[] | .name' | grep -oP "^tp-smapi/\K.*" | sort --version-sort | tail -1` -update-source-version linuxPackages.tp_smapi "$latest_tag" + update-source-version linuxPackages.tp_smapi "$latest_tag" '' diff --git a/pkgs/os-specific/linux/trace-cmd/default.nix b/pkgs/os-specific/linux/trace-cmd/default.nix index 5c339c093dd5ee..6557063373e745 100644 --- a/pkgs/os-specific/linux/trace-cmd/default.nix +++ b/pkgs/os-specific/linux/trace-cmd/default.nix @@ -1,11 +1,26 @@ -{ lib, stdenv, fetchzip, pkg-config, asciidoc, xmlto, docbook_xsl, docbook_xml_dtd_45, libxslt, libtraceevent, libtracefs, zstd, sourceHighlight, gitUpdater }: +{ + lib, + stdenv, + fetchzip, + pkg-config, + asciidoc, + xmlto, + docbook_xsl, + docbook_xml_dtd_45, + libxslt, + libtraceevent, + libtracefs, + zstd, + sourceHighlight, + gitUpdater, +}: stdenv.mkDerivation rec { pname = "trace-cmd"; version = "3.3.1"; src = fetchzip { - url = "https://git.kernel.org/pub/scm/utils/trace-cmd/trace-cmd.git/snapshot/trace-cmd-v${version}.tar.gz"; - hash = "sha256-kEji3qDqQsSK0tL8Fx2ycSd2lTXBXOHHTvsb6XDNSa8="; + url = "https://git.kernel.org/pub/scm/utils/trace-cmd/trace-cmd.git/snapshot/trace-cmd-v${version}.tar.gz"; + hash = "sha256-kEji3qDqQsSK0tL8Fx2ycSd2lTXBXOHHTvsb6XDNSa8="; }; # Don't build and install html documentation @@ -15,13 +30,31 @@ stdenv.mkDerivation rec { patchShebangs check-manpages.sh ''; - nativeBuildInputs = [ asciidoc libxslt pkg-config xmlto docbook_xsl docbook_xml_dtd_45 sourceHighlight ]; + nativeBuildInputs = [ + asciidoc + libxslt + pkg-config + xmlto + docbook_xsl + docbook_xml_dtd_45 + sourceHighlight + ]; - buildInputs = [ libtraceevent libtracefs zstd ]; + buildInputs = [ + libtraceevent + libtracefs + zstd + ]; - outputs = [ "out" "lib" "dev" "man" "devman" ]; + outputs = [ + "out" + "lib" + "dev" + "man" + "devman" + ]; - MANPAGE_DOCBOOK_XSL="${docbook_xsl}/xml/xsl/docbook/manpages/docbook.xsl"; + MANPAGE_DOCBOOK_XSL = "${docbook_xsl}/xml/xsl/docbook/manpages/docbook.xsl"; dontConfigure = true; @@ -62,9 +95,16 @@ stdenv.mkDerivation rec { meta = with lib; { description = "User-space tools for the Linux kernel ftrace subsystem"; mainProgram = "trace-cmd"; - homepage = "https://www.trace-cmd.org/"; - license = with licenses; [ lgpl21Only gpl2Only ]; - platforms = platforms.linux; - maintainers = with maintainers; [ thoughtpolice basvandijk wentasah ]; + homepage = "https://www.trace-cmd.org/"; + license = with licenses; [ + lgpl21Only + gpl2Only + ]; + platforms = platforms.linux; + maintainers = with maintainers; [ + thoughtpolice + basvandijk + wentasah + ]; }; } diff --git a/pkgs/os-specific/linux/trace-cmd/kernelshark.nix b/pkgs/os-specific/linux/trace-cmd/kernelshark.nix index 9f3d22c8a70773..9c1ba81d8d07f3 100644 --- a/pkgs/os-specific/linux/trace-cmd/kernelshark.nix +++ b/pkgs/os-specific/linux/trace-cmd/kernelshark.nix @@ -1,6 +1,22 @@ -{ lib, stdenv, fetchzip, qtbase, qtscxml, cmake, asciidoc -, docbook_xsl, json_c, mesa_glu, libglut, trace-cmd, pkg-config -, libtraceevent, libtracefs, freefont_ttf, wrapQtAppsHook, qtwayland +{ + lib, + stdenv, + fetchzip, + qtbase, + qtscxml, + cmake, + asciidoc, + docbook_xsl, + json_c, + mesa_glu, + libglut, + trace-cmd, + pkg-config, + libtraceevent, + libtracefs, + freefont_ttf, + wrapQtAppsHook, + qtwayland, }: stdenv.mkDerivation (finalAttrs: { @@ -14,9 +30,23 @@ stdenv.mkDerivation (finalAttrs: { outputs = [ "out" ]; - nativeBuildInputs = [ pkg-config cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + pkg-config + cmake + wrapQtAppsHook + ]; - buildInputs = [ qtbase qtscxml qtwayland json_c mesa_glu libglut libtraceevent libtracefs trace-cmd ]; + buildInputs = [ + qtbase + qtscxml + qtwayland + json_c + mesa_glu + libglut + libtraceevent + libtracefs + trace-cmd + ]; cmakeFlags = [ "-D_INSTALL_PREFIX=${placeholder "out"}" @@ -27,9 +57,9 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { description = "GUI for trace-cmd which is an interface for the Linux kernel ftrace subsystem"; - homepage = "https://kernelshark.org/"; - license = licenses.gpl2Only; - platforms = platforms.linux; + homepage = "https://kernelshark.org/"; + license = licenses.gpl2Only; + platforms = platforms.linux; maintainers = with maintainers; [ basvandijk ]; }; }) diff --git a/pkgs/os-specific/linux/trelay/default.nix b/pkgs/os-specific/linux/trelay/default.nix index aea5b57dfca108..291d8a2111bb67 100644 --- a/pkgs/os-specific/linux/trelay/default.nix +++ b/pkgs/os-specific/linux/trelay/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchgit, kernel, kmod }: +{ + stdenv, + lib, + fetchgit, + kernel, + kmod, +}: let version = "22.03.5"; in @@ -14,7 +20,10 @@ stdenv.mkDerivation (finalAttrs: { }; sourceRoot = "${finalAttrs.src.name}/package/kernel/trelay/src"; - hardeningDisable = [ "pic" "format" ]; + hardeningDisable = [ + "pic" + "format" + ]; nativeBuildInputs = [ kmod ] ++ kernel.moduleBuildDependencies; postPatch = '' diff --git a/pkgs/os-specific/linux/turbostat/default.nix b/pkgs/os-specific/linux/turbostat/default.nix index 92aafcfe173f69..dcec8df4eca9fa 100644 --- a/pkgs/os-specific/linux/turbostat/default.nix +++ b/pkgs/os-specific/linux/turbostat/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, kernel, libcap }: +{ + lib, + stdenv, + kernel, + libcap, +}: stdenv.mkDerivation { pname = "turbostat"; @@ -16,7 +21,9 @@ stdenv.mkDerivation { mainProgram = "turbostat"; homepage = "https://www.kernel.org/"; license = licenses.gpl2Only; - platforms = [ "i686-linux" "x86_64-linux" ]; # x86-specific + platforms = [ + "i686-linux" + "x86_64-linux" + ]; # x86-specific }; } - diff --git a/pkgs/os-specific/linux/udisks/2-default.nix b/pkgs/os-specific/linux/udisks/2-default.nix index 51a342aa5e92e7..9672e776154228 100644 --- a/pkgs/os-specific/linux/udisks/2-default.nix +++ b/pkgs/os-specific/linux/udisks/2-default.nix @@ -1,9 +1,40 @@ -{ lib, stdenv, fetchFromGitHub, substituteAll, pkg-config, gnused, autoreconfHook -, gtk-doc, acl, systemd, glib, libatasmart, polkit, coreutils, bash, which -, expat, libxslt, docbook_xsl, util-linux, mdadm, libgudev, libblockdev, parted -, gobject-introspection, docbook_xml_dtd_412, docbook_xml_dtd_43 -, xfsprogs, f2fs-tools, dosfstools, e2fsprogs, btrfs-progs, exfat, nilfs-utils, ntfs3g -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + pkg-config, + gnused, + autoreconfHook, + gtk-doc, + acl, + systemd, + glib, + libatasmart, + polkit, + coreutils, + bash, + which, + expat, + libxslt, + docbook_xsl, + util-linux, + mdadm, + libgudev, + libblockdev, + parted, + gobject-introspection, + docbook_xml_dtd_412, + docbook_xml_dtd_43, + xfsprogs, + f2fs-tools, + dosfstools, + e2fsprogs, + btrfs-progs, + exfat, + nilfs-utils, + ntfs3g, + nixosTests, }: stdenv.mkDerivation rec { @@ -17,7 +48,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-L8jr1+SJWsCizkPXC8VKDy2eVa7/FpqdB8SkBYq6vwc="; }; - outputs = [ "out" "man" "dev" ] ++ lib.optional (stdenv.hostPlatform == stdenv.buildPlatform) "devdoc"; + outputs = [ + "out" + "man" + "dev" + ] ++ lib.optional (stdenv.hostPlatform == stdenv.buildPlatform) "devdoc"; patches = [ (substituteAll { @@ -35,8 +70,17 @@ stdenv.mkDerivation rec { (substituteAll { src = ./force-path.patch; path = lib.makeBinPath [ - btrfs-progs coreutils dosfstools e2fsprogs exfat f2fs-tools nilfs-utils - xfsprogs ntfs3g parted util-linux + btrfs-progs + coreutils + dosfstools + e2fsprogs + exfat + f2fs-tools + nilfs-utils + xfsprogs + ntfs3g + parted + util-linux ]; }) ]; @@ -45,18 +89,33 @@ stdenv.mkDerivation rec { # pkg-config had to be in both to find gtk-doc and gobject-introspection depsBuildBuild = [ pkg-config ]; nativeBuildInputs = [ - autoreconfHook which gobject-introspection pkg-config - gtk-doc libxslt docbook_xml_dtd_412 docbook_xml_dtd_43 docbook_xsl + autoreconfHook + which + gobject-introspection + pkg-config + gtk-doc + libxslt + docbook_xml_dtd_412 + docbook_xml_dtd_43 + docbook_xsl ]; postPatch = lib.optionalString stdenv.hostPlatform.isMusl '' - substituteInPlace udisks/udisksclient.c \ - --replace 'defined( __GNUC_PREREQ)' 1 \ - --replace '__GNUC_PREREQ(4,6)' 1 + substituteInPlace udisks/udisksclient.c \ + --replace 'defined( __GNUC_PREREQ)' 1 \ + --replace '__GNUC_PREREQ(4,6)' 1 ''; buildInputs = [ - expat libgudev libblockdev acl systemd glib libatasmart polkit util-linux + expat + libgudev + libblockdev + acl + systemd + glib + libatasmart + polkit + util-linux ]; preConfigure = "NOCONFIGURE=1 ./autogen.sh"; @@ -91,7 +150,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Daemon, tools and libraries to access and manipulate disks, storage devices and technologies"; homepage = "https://www.freedesktop.org/wiki/Software/udisks/"; - license = with licenses; [ lgpl2Plus gpl2Plus ]; # lgpl2Plus for the library, gpl2Plus for the tools & daemon + license = with licenses; [ + lgpl2Plus + gpl2Plus + ]; # lgpl2Plus for the library, gpl2Plus for the tools & daemon maintainers = teams.freedesktop.members ++ (with maintainers; [ johnazoidberg ]); platforms = platforms.linux; }; diff --git a/pkgs/os-specific/linux/usbip/default.nix b/pkgs/os-specific/linux/usbip/default.nix index adaaab868b78a7..61f85f6cdd64b9 100644 --- a/pkgs/os-specific/linux/usbip/default.nix +++ b/pkgs/os-specific/linux/usbip/default.nix @@ -1,18 +1,34 @@ -{ lib, stdenv, kernel, udev, autoconf, automake, libtool, hwdata, kernelOlder }: +{ + lib, + stdenv, + kernel, + udev, + autoconf, + automake, + libtool, + hwdata, + kernelOlder, +}: stdenv.mkDerivation { name = "usbip-${kernel.name}"; src = kernel.src; - patches = lib.optionals (kernelOlder "5.4") [ - # fixes build with gcc8 - ./fix-snprintf-truncation.patch - # fixes build with gcc9 - ./fix-strncpy-truncation.patch - ] ++ kernel.patches; - - nativeBuildInputs = [ autoconf automake libtool ]; + patches = + lib.optionals (kernelOlder "5.4") [ + # fixes build with gcc8 + ./fix-snprintf-truncation.patch + # fixes build with gcc9 + ./fix-strncpy-truncation.patch + ] + ++ kernel.patches; + + nativeBuildInputs = [ + autoconf + automake + libtool + ]; buildInputs = [ udev ]; env.NIX_CFLAGS_COMPILE = toString [ "-Wno-error=address-of-packed-member" ]; @@ -27,7 +43,10 @@ stdenv.mkDerivation { meta = with lib; { homepage = "https://github.com/torvalds/linux/tree/master/tools/usb/usbip"; description = "allows to pass USB device from server to client over the network"; - license = with licenses; [ gpl2Only gpl2Plus ]; + license = with licenses; [ + gpl2Only + gpl2Plus + ]; platforms = platforms.linux; broken = kernelOlder "4.10"; }; diff --git a/pkgs/os-specific/linux/usbrelay/daemon.nix b/pkgs/os-specific/linux/usbrelay/daemon.nix index 6e4e4661fd53ad..ed63a5d154128c 100644 --- a/pkgs/os-specific/linux/usbrelay/daemon.nix +++ b/pkgs/os-specific/linux/usbrelay/daemon.nix @@ -1,6 +1,16 @@ -{ stdenv, usbrelay, python3, installShellFiles }: +{ + stdenv, + usbrelay, + python3, + installShellFiles, +}: let - python = python3.withPackages (ps: with ps; [ usbrelay-py paho-mqtt ]); + python = python3.withPackages ( + ps: with ps; [ + usbrelay-py + paho-mqtt + ] + ); in # This is a separate derivation, not just an additional output of # usbrelay, because otherwise, we have a cyclic dependency between @@ -34,6 +44,11 @@ stdenv.mkDerivation { meta = { description = "USB Relay MQTT service"; - inherit (usbrelay.meta) homepage license maintainers platforms; + inherit (usbrelay.meta) + homepage + license + maintainers + platforms + ; }; } diff --git a/pkgs/os-specific/linux/usbrelay/default.nix b/pkgs/os-specific/linux/usbrelay/default.nix index 656808d8389b9c..bf5935b6af677d 100644 --- a/pkgs/os-specific/linux/usbrelay/default.nix +++ b/pkgs/os-specific/linux/usbrelay/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, fetchFromGitHub, hidapi, installShellFiles }: +{ + stdenv, + lib, + fetchFromGitHub, + hidapi, + installShellFiles, +}: stdenv.mkDerivation (finalAttrs: { pname = "usbrelay"; version = "1.2.1"; diff --git a/pkgs/os-specific/linux/usbrelay/test.nix b/pkgs/os-specific/linux/usbrelay/test.nix index 58e4375dab8da5..b7894b0da773d0 100644 --- a/pkgs/os-specific/linux/usbrelay/test.nix +++ b/pkgs/os-specific/linux/usbrelay/test.nix @@ -14,51 +14,56 @@ # https://discourse.nixos.org/t/hardware-dependent-nixos-tests/18564 # for discussion of other alternatives). -import ../../../../nixos/tests/make-test-python.nix ({ pkgs, ... }: { - name = "usbrelayd"; +import ../../../../nixos/tests/make-test-python.nix ( + { pkgs, ... }: + { + name = "usbrelayd"; - nodes.machine = { - virtualisation.qemu.options = [ - "-device qemu-xhci" - "-device usb-host,vendorid=0x16c0,productid=0x05df" - ]; - services.usbrelayd.enable = true; - systemd.services.usbrelayd = { - after = [ "mosquitto.service" ]; + nodes.machine = { + virtualisation.qemu.options = [ + "-device qemu-xhci" + "-device usb-host,vendorid=0x16c0,productid=0x05df" + ]; + services.usbrelayd.enable = true; + systemd.services.usbrelayd = { + after = [ "mosquitto.service" ]; + }; + services.mosquitto = { + enable = true; + listeners = [ + { + acl = [ "pattern readwrite #" ]; + omitPasswordAuth = true; + settings.allow_anonymous = true; + } + ]; + }; + environment.systemPackages = [ + pkgs.usbrelay + pkgs.mosquitto + ]; + documentation.nixos.enable = false; # building nixos manual takes long time }; - services.mosquitto = { - enable = true; - listeners = [{ - acl = [ "pattern readwrite #" ]; - omitPasswordAuth = true; - settings.allow_anonymous = true; - }]; - }; - environment.systemPackages = [ - pkgs.usbrelay - pkgs.mosquitto - ]; - documentation.nixos.enable = false; # building nixos manual takes long time - }; - testScript = '' - import os - if os.waitstatus_to_exitcode(os.system("lsusb -d 16c0:05df")) != 0: - print("No USB relay detected, skipping test") - import sys - sys.exit(2) - machine.start() - # usbrelayd is started by udev when an relay is detected - machine.wait_for_unit("usbrelayd.service") + testScript = '' + import os + if os.waitstatus_to_exitcode(os.system("lsusb -d 16c0:05df")) != 0: + print("No USB relay detected, skipping test") + import sys + sys.exit(2) + machine.start() + # usbrelayd is started by udev when an relay is detected + machine.wait_for_unit("usbrelayd.service") - stdout = machine.succeed("usbrelay") - relay_id = stdout.split(sep="_")[0] - assert relay_id != "" - import time - time.sleep(1) - machine.succeed(f"mosquitto_pub -h localhost -t cmnd/{relay_id}/1 -m ON") - time.sleep(1) - machine.succeed(f"mosquitto_pub -h localhost -t cmnd/{relay_id}/1 -m OFF") - print("Did you see the relay switching on and off?") - ''; -}) + stdout = machine.succeed("usbrelay") + relay_id = stdout.split(sep="_")[0] + assert relay_id != "" + import time + time.sleep(1) + machine.succeed(f"mosquitto_pub -h localhost -t cmnd/{relay_id}/1 -m ON") + time.sleep(1) + machine.succeed(f"mosquitto_pub -h localhost -t cmnd/{relay_id}/1 -m OFF") + print("Did you see the relay switching on and off?") + ''; + } +) diff --git a/pkgs/os-specific/linux/v4l-utils/default.nix b/pkgs/os-specific/linux/v4l-utils/default.nix index 87fd282f6960f8..293af14921989a 100644 --- a/pkgs/os-specific/linux/v4l-utils/default.nix +++ b/pkgs/os-specific/linux/v4l-utils/default.nix @@ -1,7 +1,19 @@ -{ stdenv, lib, fetchurl, pkg-config, perl -, argp-standalone, libjpeg, udev -, withUtils ? true -, withGUI ? true, alsa-lib, libX11, qtbase, libGLU, wrapQtAppsHook +{ + stdenv, + lib, + fetchurl, + pkg-config, + perl, + argp-standalone, + libjpeg, + udev, + withUtils ? true, + withGUI ? true, + alsa-lib, + libX11, + qtbase, + libGLU, + wrapQtAppsHook, }: # See libv4l in all-packages.nix for the libs only (overrides alsa, libX11 & QT) @@ -9,8 +21,9 @@ let withQt = withUtils && withGUI; +in # we need to use stdenv.mkDerivation in order not to pollute the libv4l’s closure with Qt -in stdenv.mkDerivation rec { +stdenv.mkDerivation rec { pname = "v4l-utils"; version = "1.24.1"; @@ -21,23 +34,37 @@ in stdenv.mkDerivation rec { outputs = [ "out" ] ++ lib.optional withUtils "lib" ++ [ "dev" ]; - configureFlags = (if withUtils then [ - "--with-localedir=${placeholder "lib"}/share/locale" - "--with-udevdir=${placeholder "out"}/lib/udev" - ] else [ - "--disable-v4l-utils" - ]); + configureFlags = ( + if withUtils then + [ + "--with-localedir=${placeholder "lib"}/share/locale" + "--with-udevdir=${placeholder "out"}/lib/udev" + ] + else + [ + "--disable-v4l-utils" + ] + ); postFixup = '' # Create symlink for V4l1 compatibility ln -s "$dev/include/libv4l1-videodev.h" "$dev/include/videodev.h" ''; - nativeBuildInputs = [ pkg-config perl ] ++ lib.optional withQt wrapQtAppsHook; + nativeBuildInputs = [ + pkg-config + perl + ] ++ lib.optional withQt wrapQtAppsHook; - buildInputs = [ udev ] + buildInputs = + [ udev ] ++ lib.optional (!stdenv.hostPlatform.isGnu) argp-standalone - ++ lib.optionals withQt [ alsa-lib libX11 qtbase libGLU ]; + ++ lib.optionals withQt [ + alsa-lib + libX11 + qtbase + libGLU + ]; propagatedBuildInputs = [ libjpeg ]; @@ -51,7 +78,10 @@ in stdenv.mkDerivation rec { description = "V4L utils and libv4l, provide common image formats regardless of the v4l device"; homepage = "https://linuxtv.org/projects.php"; changelog = "https://git.linuxtv.org/v4l-utils.git/plain/ChangeLog?h=v4l-utils-${version}"; - license = with licenses; [ lgpl21Plus gpl2Plus ]; + license = with licenses; [ + lgpl21Plus + gpl2Plus + ]; maintainers = with maintainers; [ codyopel ]; platforms = platforms.linux; }; diff --git a/pkgs/os-specific/linux/v86d/default.nix b/pkgs/os-specific/linux/v86d/default.nix index 12e9b57d001cb9..a86fa31baec04f 100644 --- a/pkgs/os-specific/linux/v86d/default.nix +++ b/pkgs/os-specific/linux/v86d/default.nix @@ -1,13 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, kernel -, klibc +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + klibc, }: let pversion = "0.1.10"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "v86d"; version = "${pversion}-${kernel.version}"; @@ -22,7 +24,10 @@ in stdenv.mkDerivation rec { patchShebangs configure ''; - configureFlags = [ "--with-klibc" "--with-x86emu" ]; + configureFlags = [ + "--with-klibc" + "--with-x86emu" + ]; hardeningDisable = [ "stackprotector" ]; @@ -43,6 +48,9 @@ in stdenv.mkDerivation rec { homepage = "https://github.com/mjanusz/v86d"; license = licenses.gpl2Only; maintainers = with maintainers; [ codyopel ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; } diff --git a/pkgs/os-specific/linux/veikk-linux-driver/default.nix b/pkgs/os-specific/linux/veikk-linux-driver/default.nix index 8cf4896ae02703..7fc01712951f3e 100644 --- a/pkgs/os-specific/linux/veikk-linux-driver/default.nix +++ b/pkgs/os-specific/linux/veikk-linux-driver/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, kernel }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { pname = "veikk-linux-driver"; diff --git a/pkgs/os-specific/linux/vendor-reset/default.nix b/pkgs/os-specific/linux/vendor-reset/default.nix index 6050af58466bf0..7e9151a5555de6 100644 --- a/pkgs/os-specific/linux/vendor-reset/default.nix +++ b/pkgs/os-specific/linux/vendor-reset/default.nix @@ -1,4 +1,10 @@ -{ stdenv, fetchFromGitHub, fetchpatch, kernel, lib }: +{ + stdenv, + fetchFromGitHub, + fetchpatch, + kernel, + lib, +}: stdenv.mkDerivation rec { pname = "vendor-reset"; diff --git a/pkgs/os-specific/linux/virtualbox/default.nix b/pkgs/os-specific/linux/virtualbox/default.nix index 3aae58933c8f62..f6846eb1945d27 100644 --- a/pkgs/os-specific/linux/virtualbox/default.nix +++ b/pkgs/os-specific/linux/virtualbox/default.nix @@ -1,11 +1,17 @@ -{ stdenv, virtualbox, kernel }: +{ + stdenv, + virtualbox, + kernel, +}: stdenv.mkDerivation { pname = "virtualbox-modules"; version = "${virtualbox.version}-${kernel.version}"; src = virtualbox.modsrc; hardeningDisable = [ - "fortify" "pic" "stackprotector" + "fortify" + "pic" + "stackprotector" ]; nativeBuildInputs = kernel.moduleBuildDependencies; diff --git a/pkgs/os-specific/linux/vmm_clock/default.nix b/pkgs/os-specific/linux/vmm_clock/default.nix index 870bfbe0bd6ccd..e4dbbf89b10555 100644 --- a/pkgs/os-specific/linux/vmm_clock/default.nix +++ b/pkgs/os-specific/linux/vmm_clock/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, kernel }: +{ + stdenv, + lib, + fetchFromGitHub, + kernel, +}: stdenv.mkDerivation rec { pname = "vmm_clock"; @@ -11,7 +16,10 @@ stdenv.mkDerivation rec { hash = "sha256-XYRxrVixvImxr2j3qxBcv1df1LvPRKqKKgegW3HqUcQ="; }; - hardeningDisable = [ "pic" "format" ]; + hardeningDisable = [ + "pic" + "format" + ]; nativeBuildInputs = kernel.moduleBuildDependencies; extraConfig = '' @@ -26,12 +34,14 @@ stdenv.mkDerivation rec { ]; meta = with lib; { - description = - "Experimental implementation of a kvmclock-derived clocksource for Linux guests under OpenBSD's hypervisor"; + description = "Experimental implementation of a kvmclock-derived clocksource for Linux guests under OpenBSD's hypervisor"; homepage = "https://github.com/voutilad/vmm_clock"; license = licenses.gpl2Plus; maintainers = with maintainers; [ qbit ]; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; }; enableParallelBuilding = true; diff --git a/pkgs/os-specific/linux/vmware/default.nix b/pkgs/os-specific/linux/vmware/default.nix index 9269ec20d9d36b..3a536210456657 100644 --- a/pkgs/os-specific/linux/vmware/default.nix +++ b/pkgs/os-specific/linux/vmware/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, kernel, kmod, gnugrep }: +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + kmod, + gnugrep, +}: stdenv.mkDerivation rec { pname = "vmware-modules"; @@ -42,6 +49,9 @@ stdenv.mkDerivation rec { license = licenses.gpl2Only; platforms = [ "x86_64-linux" ]; broken = (kernel.kernelOlder "5.5" && kernel.isHardened); - maintainers = with maintainers; [ deinferno vifino ]; + maintainers = with maintainers; [ + deinferno + vifino + ]; }; } diff --git a/pkgs/os-specific/linux/wireguard/default.nix b/pkgs/os-specific/linux/wireguard/default.nix index 8d8342cce980be..64925ce884b65a 100644 --- a/pkgs/os-specific/linux/wireguard/default.nix +++ b/pkgs/os-specific/linux/wireguard/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchzip, kernel, perl, wireguard-tools, bc }: +{ + lib, + stdenv, + fetchzip, + kernel, + perl, + wireguard-tools, + bc, +}: # wireguard upstreamed since 5.6 https://lists.zx2c4.com/pipermail/wireguard/2019-December/004704.html assert lib.versionOlder kernel.version "5.6"; @@ -16,15 +24,20 @@ stdenv.mkDerivation rec { KERNELDIR = "${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"; - nativeBuildInputs = [ perl bc ] ++ kernel.moduleBuildDependencies; + nativeBuildInputs = [ + perl + bc + ] ++ kernel.moduleBuildDependencies; preBuild = "cd src"; buildFlags = [ "module" ]; - makeFlags = [ - "ARCH=${stdenv.hostPlatform.linuxArch}" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "CROSS_COMPILE=${stdenv.cc.targetPrefix}" - ]; + makeFlags = + [ + "ARCH=${stdenv.hostPlatform.linuxArch}" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "CROSS_COMPILE=${stdenv.cc.targetPrefix}" + ]; INSTALL_MOD_PATH = placeholder "out"; installFlags = [ "DEPMOD=true" ]; diff --git a/pkgs/os-specific/linux/wpa_supplicant/default.nix b/pkgs/os-specific/linux/wpa_supplicant/default.nix index 6463e46842a4b7..75c17d40a0e0bb 100644 --- a/pkgs/os-specific/linux/wpa_supplicant/default.nix +++ b/pkgs/os-specific/linux/wpa_supplicant/default.nix @@ -1,8 +1,19 @@ -{ lib, stdenv, fetchurl, fetchpatch, openssl, pkg-config, libnl -, nixosTests, wpa_supplicant_gui -, dbusSupport ? !stdenv.hostPlatform.isStatic, dbus -, withReadline ? true, readline -, withPcsclite ? !stdenv.hostPlatform.isStatic, pcsclite +{ + lib, + stdenv, + fetchurl, + fetchpatch, + openssl, + pkg-config, + libnl, + nixosTests, + wpa_supplicant_gui, + dbusSupport ? !stdenv.hostPlatform.isStatic, + dbus, + withReadline ? true, + readline, + withPcsclite ? !stdenv.hostPlatform.isStatic, + pcsclite, }: stdenv.mkDerivation rec { @@ -27,72 +38,81 @@ stdenv.mkDerivation rec { # TODO: Patch epoll so that the dbus actually responds # TODO: Figure out how to get privsep working, currently getting SIGBUS - extraConfig = '' - #CONFIG_ELOOP_EPOLL=y - #CONFIG_PRIVSEP=y - #CONFIG_TLSV12=y see #8332 - CONFIG_AP=y - CONFIG_BGSCAN_LEARN=y - CONFIG_BGSCAN_SIMPLE=y - CONFIG_DEBUG_SYSLOG=y - CONFIG_EAP_EKE=y - CONFIG_EAP_FAST=y - CONFIG_EAP_GPSK=y - CONFIG_EAP_GPSK_SHA256=y - CONFIG_EAP_IKEV2=y - CONFIG_EAP_PAX=y - CONFIG_EAP_PWD=y - CONFIG_EAP_SAKE=y - CONFIG_ELOOP=eloop - CONFIG_EXT_PASSWORD_FILE=y - CONFIG_HS20=y - CONFIG_HT_OVERRIDES=y - CONFIG_IEEE80211AC=y - CONFIG_IEEE80211AX=y - CONFIG_IEEE80211BE=y - CONFIG_IEEE80211N=y - CONFIG_IEEE80211R=y - CONFIG_IEEE80211W=y - CONFIG_INTERNETWORKING=y - CONFIG_L2_PACKET=linux - CONFIG_LIBNL32=y - CONFIG_MESH=y - CONFIG_OWE=y - CONFIG_P2P=y - CONFIG_SAE_PK=y - CONFIG_TDLS=y - CONFIG_TLS=openssl - CONFIG_TLSV11=y - CONFIG_VHT_OVERRIDES=y - CONFIG_WNM=y - CONFIG_WPS=y - CONFIG_WPS_ER=y - CONFIG_WPS_NFS=y - CONFIG_SUITEB=y - CONFIG_SUITEB192=y - '' + lib.optionalString withPcsclite '' - CONFIG_EAP_SIM=y - CONFIG_EAP_AKA=y - CONFIG_EAP_AKA_PRIME=y - CONFIG_PCSC=y - '' + lib.optionalString dbusSupport '' - CONFIG_CTRL_IFACE_DBUS=y - CONFIG_CTRL_IFACE_DBUS_NEW=y - CONFIG_CTRL_IFACE_DBUS_INTRO=y - '' + extraConfig = + '' + #CONFIG_ELOOP_EPOLL=y + #CONFIG_PRIVSEP=y + #CONFIG_TLSV12=y see #8332 + CONFIG_AP=y + CONFIG_BGSCAN_LEARN=y + CONFIG_BGSCAN_SIMPLE=y + CONFIG_DEBUG_SYSLOG=y + CONFIG_EAP_EKE=y + CONFIG_EAP_FAST=y + CONFIG_EAP_GPSK=y + CONFIG_EAP_GPSK_SHA256=y + CONFIG_EAP_IKEV2=y + CONFIG_EAP_PAX=y + CONFIG_EAP_PWD=y + CONFIG_EAP_SAKE=y + CONFIG_ELOOP=eloop + CONFIG_EXT_PASSWORD_FILE=y + CONFIG_HS20=y + CONFIG_HT_OVERRIDES=y + CONFIG_IEEE80211AC=y + CONFIG_IEEE80211AX=y + CONFIG_IEEE80211BE=y + CONFIG_IEEE80211N=y + CONFIG_IEEE80211R=y + CONFIG_IEEE80211W=y + CONFIG_INTERNETWORKING=y + CONFIG_L2_PACKET=linux + CONFIG_LIBNL32=y + CONFIG_MESH=y + CONFIG_OWE=y + CONFIG_P2P=y + CONFIG_SAE_PK=y + CONFIG_TDLS=y + CONFIG_TLS=openssl + CONFIG_TLSV11=y + CONFIG_VHT_OVERRIDES=y + CONFIG_WNM=y + CONFIG_WPS=y + CONFIG_WPS_ER=y + CONFIG_WPS_NFS=y + CONFIG_SUITEB=y + CONFIG_SUITEB192=y + '' + + lib.optionalString withPcsclite '' + CONFIG_EAP_SIM=y + CONFIG_EAP_AKA=y + CONFIG_EAP_AKA_PRIME=y + CONFIG_PCSC=y + '' + + lib.optionalString dbusSupport '' + CONFIG_CTRL_IFACE_DBUS=y + CONFIG_CTRL_IFACE_DBUS_NEW=y + CONFIG_CTRL_IFACE_DBUS_INTRO=y + '' # Upstream uses conditionals based on ifdef, so opposite of =y is # not =n, as one may expect, but undefine. # # This config is sourced into makefile. + lib.optionalString (!dbusSupport) '' - undefine CONFIG_CTRL_IFACE_DBUS - undefine CONFIG_CTRL_IFACE_DBUS_NEW - undefine CONFIG_CTRL_IFACE_DBUS_INTRO - '' + (if withReadline then '' - CONFIG_READLINE=y - '' else '' - CONFIG_WPA_CLI_EDIT=y - ''); + undefine CONFIG_CTRL_IFACE_DBUS + undefine CONFIG_CTRL_IFACE_DBUS_NEW + undefine CONFIG_CTRL_IFACE_DBUS_INTRO + '' + + ( + if withReadline then + '' + CONFIG_READLINE=y + '' + else + '' + CONFIG_WPA_CLI_EDIT=y + '' + ); preBuild = '' for manpage in wpa_supplicant/doc/docbook/wpa_supplicant.conf* ; do @@ -108,28 +128,33 @@ stdenv.mkDerivation rec { ${lib.optionalString withPcsclite "-I${lib.getDev pcsclite}/include/PCSC/"}" ''; - buildInputs = [ openssl libnl ] + buildInputs = + [ + openssl + libnl + ] ++ lib.optional dbusSupport dbus ++ lib.optional withReadline readline ++ lib.optional withPcsclite pcsclite; nativeBuildInputs = [ pkg-config ]; - postInstall = '' - mkdir -p $out/share/man/man5 $out/share/man/man8 - cp -v "doc/docbook/"*.5 $out/share/man/man5/ - cp -v "doc/docbook/"*.8 $out/share/man/man8/ - '' - + lib.optionalString dbusSupport '' - mkdir -p $out/share/dbus-1/system.d $out/share/dbus-1/system-services $out/etc/systemd/system - cp -v "dbus/"*service $out/share/dbus-1/system-services - cp -v dbus/dbus-wpa_supplicant.conf $out/share/dbus-1/system.d - cp -v "systemd/"*.service $out/etc/systemd/system - '' - + '' - rm $out/share/man/man8/wpa_priv.8 - install -Dm444 wpa_supplicant.conf $out/share/doc/wpa_supplicant/wpa_supplicant.conf.example - ''; + postInstall = + '' + mkdir -p $out/share/man/man5 $out/share/man/man8 + cp -v "doc/docbook/"*.5 $out/share/man/man5/ + cp -v "doc/docbook/"*.8 $out/share/man/man8/ + '' + + lib.optionalString dbusSupport '' + mkdir -p $out/share/dbus-1/system.d $out/share/dbus-1/system-services $out/etc/systemd/system + cp -v "dbus/"*service $out/share/dbus-1/system-services + cp -v dbus/dbus-wpa_supplicant.conf $out/share/dbus-1/system.d + cp -v "systemd/"*.service $out/etc/systemd/system + '' + + '' + rm $out/share/man/man8/wpa_priv.8 + install -Dm444 wpa_supplicant.conf $out/share/doc/wpa_supplicant/wpa_supplicant.conf.example + ''; passthru.tests = { inherit (nixosTests) wpa_supplicant; @@ -140,7 +165,10 @@ stdenv.mkDerivation rec { homepage = "https://w1.fi/wpa_supplicant/"; description = "Tool for connecting to WPA and WPA2-protected wireless networks"; license = licenses.bsd3; - maintainers = with maintainers; [ marcweber ma27 ]; + maintainers = with maintainers; [ + marcweber + ma27 + ]; platforms = platforms.linux; }; } diff --git a/pkgs/os-specific/linux/wpa_supplicant/gui.nix b/pkgs/os-specific/linux/wpa_supplicant/gui.nix index 45eedb25a9531f..60289d136c9601 100644 --- a/pkgs/os-specific/linux/wpa_supplicant/gui.nix +++ b/pkgs/os-specific/linux/wpa_supplicant/gui.nix @@ -1,11 +1,23 @@ -{ lib, mkDerivation, qtbase, qmake, inkscape, imagemagick, wpa_supplicant }: +{ + lib, + mkDerivation, + qtbase, + qmake, + inkscape, + imagemagick, + wpa_supplicant, +}: mkDerivation { pname = "wpa_gui"; inherit (wpa_supplicant) version src; buildInputs = [ qtbase ]; - nativeBuildInputs = [ qmake inkscape imagemagick ]; + nativeBuildInputs = [ + qmake + inkscape + imagemagick + ]; postPatch = '' cd wpa_supplicant/wpa_gui-qt4 diff --git a/pkgs/os-specific/linux/x86_energy_perf_policy/default.nix b/pkgs/os-specific/linux/x86_energy_perf_policy/default.nix index 309d9865bebc68..1183b4dc32b77a 100644 --- a/pkgs/os-specific/linux/x86_energy_perf_policy/default.nix +++ b/pkgs/os-specific/linux/x86_energy_perf_policy/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, kernel }: +{ + lib, + stdenv, + kernel, +}: stdenv.mkDerivation { pname = "x86_energy_perf_policy"; @@ -22,6 +26,9 @@ stdenv.mkDerivation { mainProgram = "x86_energy_perf_policy"; homepage = "https://www.kernel.org/"; license = licenses.gpl2Only; - platforms = [ "i686-linux" "x86_64-linux" ]; # x86-specific + platforms = [ + "i686-linux" + "x86_64-linux" + ]; # x86-specific }; } diff --git a/pkgs/os-specific/linux/xp-pen-drivers/deco-01-v2/default.nix b/pkgs/os-specific/linux/xp-pen-drivers/deco-01-v2/default.nix index ba3dc3b373515e..c983b0cfa89a0b 100644 --- a/pkgs/os-specific/linux/xp-pen-drivers/deco-01-v2/default.nix +++ b/pkgs/os-specific/linux/xp-pen-drivers/deco-01-v2/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchzip -, libusb1 -, glibc -, libGL -, xorg -, makeWrapper -, qtx11extras -, wrapQtAppsHook -, autoPatchelfHook -, libX11 -, libXtst -, libXi -, libXrandr -, libXinerama +{ + lib, + stdenv, + fetchzip, + libusb1, + glibc, + libGL, + xorg, + makeWrapper, + qtx11extras, + wrapQtAppsHook, + autoPatchelfHook, + libX11, + libXtst, + libXi, + libXrandr, + libXinerama, }: let diff --git a/pkgs/os-specific/linux/xp-pen-drivers/g430/default.nix b/pkgs/os-specific/linux/xp-pen-drivers/g430/default.nix index 9381463c8fa1a0..f316217cf3478f 100644 --- a/pkgs/os-specific/linux/xp-pen-drivers/g430/default.nix +++ b/pkgs/os-specific/linux/xp-pen-drivers/g430/default.nix @@ -1,13 +1,26 @@ -{ lib, stdenv, mkDerivation, fetchzip, autoPatchelfHook, libusb1, libX11, libXtst, qtbase, libglvnd }: +{ + lib, + stdenv, + mkDerivation, + fetchzip, + autoPatchelfHook, + libusb1, + libX11, + libXtst, + qtbase, + libglvnd, +}: mkDerivation rec { pname = "xp-pen-g430-driver"; version = "1.2.13.1"; - src = fetchzip { - url = "https://download01.xp-pen.com/file/2020/04/Linux_Pentablet_V${version}.tar.gz(20200428).zip"; - sha256 = "1r423hcpi26v82pzl59br1zw5vablikclqsy6mcqi0v5p84hfrdd"; - } + /Linux_Pentablet_V1.2.13.1.tar.gz; + src = + fetchzip { + url = "https://download01.xp-pen.com/file/2020/04/Linux_Pentablet_V${version}.tar.gz(20200428).zip"; + sha256 = "1r423hcpi26v82pzl59br1zw5vablikclqsy6mcqi0v5p84hfrdd"; + } + + /Linux_Pentablet_V1.2.13.1.tar.gz; nativeBuildInputs = [ autoPatchelfHook diff --git a/pkgs/os-specific/linux/xpadneo/default.nix b/pkgs/os-specific/linux/xpadneo/default.nix index 96c610b57c80ef..f0e5f443c97261 100644 --- a/pkgs/os-specific/linux/xpadneo/default.nix +++ b/pkgs/os-specific/linux/xpadneo/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, kernel -, bluez -, nixosTests -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + kernel, + bluez, + nixosTests, + nix-update-script, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/os-specific/linux/zenpower/default.nix b/pkgs/os-specific/linux/zenpower/default.nix index f5819f0d1d2211..019734b0a8ebdf 100644 --- a/pkgs/os-specific/linux/zenpower/default.nix +++ b/pkgs/os-specific/linux/zenpower/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, kernel, fetchFromGitea }: +{ + lib, + stdenv, + kernel, + fetchFromGitea, +}: stdenv.mkDerivation rec { pname = "zenpower"; @@ -26,7 +31,10 @@ stdenv.mkDerivation rec { inherit (src.meta) homepage; description = "Linux kernel driver for reading temperature, voltage(SVI2), current(SVI2) and power(SVI2) for AMD Zen family CPUs"; license = licenses.gpl2Plus; - maintainers = with maintainers; [ alexbakker artturin ]; + maintainers = with maintainers; [ + alexbakker + artturin + ]; platforms = [ "x86_64-linux" ]; broken = versionOlder kernel.version "4.14"; }; diff --git a/pkgs/os-specific/linux/zfs/2_2.nix b/pkgs/os-specific/linux/zfs/2_2.nix index 9d8be86258d564..96f4462f22bf08 100644 --- a/pkgs/os-specific/linux/zfs/2_2.nix +++ b/pkgs/os-specific/linux/zfs/2_2.nix @@ -1,10 +1,11 @@ -{ callPackage -, kernel ? null -, stdenv -, lib -, nixosTests -, ... -} @ args: +{ + callPackage, + kernel ? null, + stdenv, + lib, + nixosTests, + ... +}@args: let stdenv' = if kernel == null then stdenv else kernel.stdenv; @@ -23,7 +24,10 @@ callPackage ./generic.nix args { inherit (nixosTests.zfs) installer series_2_2; }; - maintainers = with lib.maintainers; [ adamcstephens amarshall ]; + maintainers = with lib.maintainers; [ + adamcstephens + amarshall + ]; hash = "sha256-wkgoYg6uQOHVq8a9sJXzO/QXJ6q28l7JXWkC+BFvOb0="; } diff --git a/pkgs/os-specific/linux/zfs/generic.nix b/pkgs/os-specific/linux/zfs/generic.nix index d267de0eb175ab..ad6fd902c6827e 100644 --- a/pkgs/os-specific/linux/zfs/generic.nix +++ b/pkgs/os-specific/linux/zfs/generic.nix @@ -1,248 +1,351 @@ let genericBuild = - { lib, stdenv, fetchFromGitHub - , autoreconfHook269, util-linux, nukeReferences, coreutils - , linuxPackages - , perl - , configFile ? "all" - - # Userspace dependencies - , zlib, libuuid, python3, attr, openssl - , libtirpc - , nfs-utils, samba - , gawk, gnugrep, gnused, systemd - , smartmontools, enableMail ? false - , sysstat, pkg-config - , curl - , pam - - # Kernel dependencies - , kernel ? null - , enablePython ? true - , ... - }@outerArgs: - - assert (configFile == "kernel") -> (kernel != null); - { version - , hash - , kernelModuleAttribute - , extraLongDescription ? "" - , extraPatches ? [] - , rev ? "zfs-${version}" - , kernelCompatible ? null - , maintainers ? (with lib.maintainers; [ amarshall ]) - , tests - }@innerArgs: - - let - inherit (lib) any optionalString optionals optional makeBinPath versionAtLeast; - - smartmon = smartmontools.override { inherit enableMail; }; - - buildKernel = any (n: n == configFile) [ "kernel" "all" ]; - buildUser = any (n: n == configFile) [ "user" "all" ]; - isAtLeast22Series = versionAtLeast version "2.2.0"; - - # XXX: You always want to build kernel modules with the same stdenv as the - # kernel was built with. However, since zfs can also be built for userspace we - # need to correctly pick between the provided/default stdenv, and the one used - # by the kernel. - # If you don't do this your ZFS builds will fail on any non-standard (e.g. - # clang-built) kernels. - stdenv' = if kernel == null then stdenv else kernel.stdenv; - in - - stdenv'.mkDerivation { - name = "zfs-${configFile}-${version}${optionalString buildKernel "-${kernel.version}"}"; - pname = "zfs"; - inherit version; - - src = fetchFromGitHub { - owner = "openzfs"; - repo = "zfs"; - inherit rev hash; + { + lib, + stdenv, + fetchFromGitHub, + autoreconfHook269, + util-linux, + nukeReferences, + coreutils, + linuxPackages, + perl, + configFile ? "all", + + # Userspace dependencies + zlib, + libuuid, + python3, + attr, + openssl, + libtirpc, + nfs-utils, + samba, + gawk, + gnugrep, + gnused, + systemd, + smartmontools, + enableMail ? false, + sysstat, + pkg-config, + curl, + pam, + + # Kernel dependencies + kernel ? null, + enablePython ? true, + ... + }@outerArgs: + + assert (configFile == "kernel") -> (kernel != null); + { + version, + hash, + kernelModuleAttribute, + extraLongDescription ? "", + extraPatches ? [ ], + rev ? "zfs-${version}", + kernelCompatible ? null, + maintainers ? (with lib.maintainers; [ amarshall ]), + tests, + }@innerArgs: + + let + inherit (lib) + any + optionalString + optionals + optional + makeBinPath + versionAtLeast + ; + + smartmon = smartmontools.override { inherit enableMail; }; + + buildKernel = any (n: n == configFile) [ + "kernel" + "all" + ]; + buildUser = any (n: n == configFile) [ + "user" + "all" + ]; + isAtLeast22Series = versionAtLeast version "2.2.0"; + + # XXX: You always want to build kernel modules with the same stdenv as the + # kernel was built with. However, since zfs can also be built for userspace we + # need to correctly pick between the provided/default stdenv, and the one used + # by the kernel. + # If you don't do this your ZFS builds will fail on any non-standard (e.g. + # clang-built) kernels. + stdenv' = if kernel == null then stdenv else kernel.stdenv; + in + + stdenv'.mkDerivation { + name = "zfs-${configFile}-${version}${optionalString buildKernel "-${kernel.version}"}"; + pname = "zfs"; + inherit version; + + src = fetchFromGitHub { + owner = "openzfs"; + repo = "zfs"; + inherit rev hash; + }; + + patches = extraPatches; + + postPatch = + optionalString buildKernel '' + patchShebangs scripts + # The arrays must remain the same length, so we repeat a flag that is + # already part of the command and therefore has no effect. + substituteInPlace ./module/os/linux/zfs/zfs_ctldir.c \ + --replace-fail '"/usr/bin/env", "umount"' '"${util-linux}/bin/umount", "-n"' \ + --replace-fail '"/usr/bin/env", "mount"' '"${util-linux}/bin/mount", "-n"' + '' + + optionalString buildUser '' + substituteInPlace ./lib/libshare/os/linux/nfs.c --replace-fail "/usr/sbin/exportfs" "${ + # We don't *need* python support, but we set it like this to minimize closure size: + # If it's disabled by default, no need to enable it, even if we have python enabled + # And if it's enabled by default, only change that if we explicitly disable python to remove python from the closure + nfs-utils.override (old: { + enablePython = old.enablePython or true && enablePython; + }) + }/bin/exportfs" + substituteInPlace ./lib/libshare/smb.h --replace-fail "/usr/bin/net" "${samba}/bin/net" + # Disable dynamic loading of libcurl + substituteInPlace ./config/user-libfetch.m4 --replace-fail "curl-config --built-shared" "true" + substituteInPlace ./config/user-systemd.m4 --replace-fail "/usr/lib/modules-load.d" "$out/etc/modules-load.d" + substituteInPlace ./config/zfs-build.m4 --replace-fail "\$sysconfdir/init.d" "$out/etc/init.d" \ + --replace-fail "/etc/default" "$out/etc/default" + substituteInPlace ./contrib/initramfs/Makefile.am \ + --replace-fail "/usr/share/initramfs-tools" "$out/usr/share/initramfs-tools" + '' + + optionalString isAtLeast22Series '' + substituteInPlace ./udev/vdev_id \ + --replace-fail "PATH=/bin:/sbin:/usr/bin:/usr/sbin" \ + "PATH=${ + makeBinPath [ + coreutils + gawk + gnused + gnugrep + systemd + ] + }" + + substituteInPlace ./config/zfs-build.m4 \ + --replace-fail "bashcompletiondir=/etc/bash_completion.d" \ + "bashcompletiondir=$out/share/bash-completion/completions" + + substituteInPlace ./cmd/arc_summary --replace-fail "/sbin/modinfo" "modinfo" + '' + + optionalString (!isAtLeast22Series) '' + substituteInPlace ./etc/zfs/Makefile.am --replace-fail "\$(sysconfdir)/zfs" "$out/etc/zfs" + + find ./contrib/initramfs -name Makefile.am -exec sed -i -e 's|/usr/share/initramfs-tools|'$out'/share/initramfs-tools|g' {} \; + + substituteInPlace ./cmd/arc_summary/arc_summary3 --replace-fail "/sbin/modinfo" "modinfo" + substituteInPlace ./cmd/vdev_id/vdev_id \ + --replace-fail "PATH=/bin:/sbin:/usr/bin:/usr/sbin" \ + "PATH=${ + makeBinPath [ + coreutils + gawk + gnused + gnugrep + systemd + ] + }" + ''; + + nativeBuildInputs = + [ + autoreconfHook269 + nukeReferences + ] + ++ optionals buildKernel (kernel.moduleBuildDependencies ++ [ perl ]) + ++ optional buildUser pkg-config; + buildInputs = + optionals buildUser [ + zlib + libuuid + attr + libtirpc + pam + ] + ++ optional buildUser openssl + ++ optional buildUser curl + ++ optional (buildUser && enablePython) python3; + + # for zdb to get the rpath to libgcc_s, needed for pthread_cancel to work + NIX_CFLAGS_LINK = "-lgcc_s"; + + hardeningDisable = [ + "fortify" + "stackprotector" + "pic" + ]; + + configureFlags = + [ + "--with-config=${configFile}" + "--with-tirpc=1" + (lib.withFeatureAs (buildUser && enablePython) "python" python3.interpreter) + ] + ++ optionals buildUser [ + "--with-dracutdir=$(out)/lib/dracut" + "--with-udevdir=$(out)/lib/udev" + "--with-systemdunitdir=$(out)/etc/systemd/system" + "--with-systemdpresetdir=$(out)/etc/systemd/system-preset" + "--with-systemdgeneratordir=$(out)/lib/systemd/system-generator" + "--with-mounthelperdir=$(out)/bin" + "--libexecdir=$(out)/libexec" + "--sysconfdir=/etc" + "--localstatedir=/var" + "--enable-systemd" + "--enable-pam" + ] + ++ optionals buildKernel ( + [ + "--with-linux=${kernel.dev}/lib/modules/${kernel.modDirVersion}/source" + "--with-linux-obj=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" + ] + ++ kernel.makeFlags + ); + + makeFlags = optionals buildKernel kernel.makeFlags; + + enableParallelBuilding = true; + + installFlags = [ + "sysconfdir=\${out}/etc" + "DEFAULT_INITCONF_DIR=\${out}/default" + "INSTALL_MOD_PATH=\${out}" + ]; + + preConfigure = '' + # The kernel module builds some tests during the configurePhase, this envvar controls their parallelism + export TEST_JOBS=$NIX_BUILD_CORES + if [ -z "$enableParallelBuilding" ]; then + export TEST_JOBS=1 + fi + ''; + + # Enabling BTF causes zfs to be build with debug symbols. + # Since zfs compress kernel modules on installation, our strip hooks skip stripping them. + # Hence we strip modules prior to compression. + postBuild = optionalString buildKernel '' + find . -name "*.ko" -print0 | xargs -0 -P$NIX_BUILD_CORES ${stdenv.cc.targetPrefix}strip --strip-debug + ''; + + postInstall = + optionalString buildKernel '' + # Add reference that cannot be detected due to compressed kernel module + mkdir -p "$out/nix-support" + echo "${util-linux}" >> "$out/nix-support/extra-refs" + '' + + optionalString buildUser '' + # Remove provided services as they are buggy + rm $out/etc/systemd/system/zfs-import-*.service + + for i in $out/etc/systemd/system/*; do + if [ -L $i ]; then + continue + fi + sed -i '/zfs-import-scan.service/d' $i + substituteInPlace $i --replace-warn "zfs-import-cache.service" "zfs-import.target" + done + + # Remove tests because they add a runtime dependency on gcc + rm -rf $out/share/zfs/zfs-tests + + ${optionalString (lib.versionOlder version "2.2") '' + # Add Bash completions. + install -v -m444 -D -t $out/share/bash-completion/completions contrib/bash_completion.d/zfs + (cd $out/share/bash-completion/completions; ln -s zfs zpool) + ''} + ''; + + postFixup = + let + path = "PATH=${ + makeBinPath [ + coreutils + gawk + gnused + gnugrep + util-linux + smartmon + sysstat + ] + }:$PATH"; + in + '' + for i in $out/libexec/zfs/zpool.d/*; do + sed -i '2i${path}' $i + done + ''; + + outputs = [ "out" ] ++ optionals buildUser [ "dev" ]; + + passthru = { + inherit enableMail kernelModuleAttribute; + latestCompatibleLinuxPackages = lib.warn "zfs.latestCompatibleLinuxPackages is deprecated and is now pointing at the default kernel. If using the stable LTS kernel (default `linuxPackages` is not possible then you must explicitly pin a specific kernel release. For example, `boot.kernelPackages = pkgs.linuxPackages_6_6`. Please be aware that non-LTS kernels are likely to go EOL before ZFS supports the latest supported non-LTS release, requiring manual intervention." linuxPackages; + + # The corresponding userspace tools to this instantiation + # of the ZFS package set. + userspaceTools = genericBuild ( + outerArgs + // { + configFile = "user"; + } + ) innerArgs; + + inherit tests; + }; + + meta = { + description = "ZFS Filesystem Linux" + (if buildUser then " Userspace Tools" else " Kernel Module"); + longDescription = + '' + ZFS is a filesystem that combines a logical volume manager with a + Copy-On-Write filesystem with data integrity detection and repair, + snapshotting, cloning, block devices, deduplication, and more. + + ${ + if buildUser then "This is the userspace tools package." else "This is the kernel module package." + } + '' + + extraLongDescription; + homepage = "https://github.com/openzfs/zfs"; + changelog = "https://github.com/openzfs/zfs/releases/tag/zfs-${version}"; + license = lib.licenses.cddl; + + # The case-block for TARGET_CPU has branches for only some CPU families, + # which prevents ZFS from building on any other platform. Since the NixOS + # `boot.zfs.enabled` property is `readOnly`, excluding platforms where ZFS + # does not build is the only way to produce a NixOS installer on such + # platforms. + # https://github.com/openzfs/zfs/blob/6723d1110f6daf93be93db74d5ea9f6b64c9bce5/config/always-arch.m4#L12 + platforms = + with lib.systems.inspect.patterns; + map (p: p // isLinux) ( + [ + isx86_32 + isx86_64 + isPower + isAarch64 + isSparc + ] + ++ isArmv7 + ); + + inherit maintainers; + mainProgram = "zfs"; + broken = buildKernel && (kernelCompatible != null) && !(kernelCompatible kernel); + }; }; - - patches = extraPatches; - - postPatch = optionalString buildKernel '' - patchShebangs scripts - # The arrays must remain the same length, so we repeat a flag that is - # already part of the command and therefore has no effect. - substituteInPlace ./module/os/linux/zfs/zfs_ctldir.c \ - --replace-fail '"/usr/bin/env", "umount"' '"${util-linux}/bin/umount", "-n"' \ - --replace-fail '"/usr/bin/env", "mount"' '"${util-linux}/bin/mount", "-n"' - '' + optionalString buildUser '' - substituteInPlace ./lib/libshare/os/linux/nfs.c --replace-fail "/usr/sbin/exportfs" "${ - # We don't *need* python support, but we set it like this to minimize closure size: - # If it's disabled by default, no need to enable it, even if we have python enabled - # And if it's enabled by default, only change that if we explicitly disable python to remove python from the closure - nfs-utils.override (old: { enablePython = old.enablePython or true && enablePython; }) - }/bin/exportfs" - substituteInPlace ./lib/libshare/smb.h --replace-fail "/usr/bin/net" "${samba}/bin/net" - # Disable dynamic loading of libcurl - substituteInPlace ./config/user-libfetch.m4 --replace-fail "curl-config --built-shared" "true" - substituteInPlace ./config/user-systemd.m4 --replace-fail "/usr/lib/modules-load.d" "$out/etc/modules-load.d" - substituteInPlace ./config/zfs-build.m4 --replace-fail "\$sysconfdir/init.d" "$out/etc/init.d" \ - --replace-fail "/etc/default" "$out/etc/default" - substituteInPlace ./contrib/initramfs/Makefile.am \ - --replace-fail "/usr/share/initramfs-tools" "$out/usr/share/initramfs-tools" - '' + optionalString isAtLeast22Series '' - substituteInPlace ./udev/vdev_id \ - --replace-fail "PATH=/bin:/sbin:/usr/bin:/usr/sbin" \ - "PATH=${makeBinPath [ coreutils gawk gnused gnugrep systemd ]}" - - substituteInPlace ./config/zfs-build.m4 \ - --replace-fail "bashcompletiondir=/etc/bash_completion.d" \ - "bashcompletiondir=$out/share/bash-completion/completions" - - substituteInPlace ./cmd/arc_summary --replace-fail "/sbin/modinfo" "modinfo" - '' + optionalString (!isAtLeast22Series) '' - substituteInPlace ./etc/zfs/Makefile.am --replace-fail "\$(sysconfdir)/zfs" "$out/etc/zfs" - - find ./contrib/initramfs -name Makefile.am -exec sed -i -e 's|/usr/share/initramfs-tools|'$out'/share/initramfs-tools|g' {} \; - - substituteInPlace ./cmd/arc_summary/arc_summary3 --replace-fail "/sbin/modinfo" "modinfo" - substituteInPlace ./cmd/vdev_id/vdev_id \ - --replace-fail "PATH=/bin:/sbin:/usr/bin:/usr/sbin" \ - "PATH=${makeBinPath [ coreutils gawk gnused gnugrep systemd ]}" - ''; - - nativeBuildInputs = [ autoreconfHook269 nukeReferences ] - ++ optionals buildKernel (kernel.moduleBuildDependencies ++ [ perl ]) - ++ optional buildUser pkg-config; - buildInputs = optionals buildUser [ zlib libuuid attr libtirpc pam ] - ++ optional buildUser openssl - ++ optional buildUser curl - ++ optional (buildUser && enablePython) python3; - - # for zdb to get the rpath to libgcc_s, needed for pthread_cancel to work - NIX_CFLAGS_LINK = "-lgcc_s"; - - hardeningDisable = [ "fortify" "stackprotector" "pic" ]; - - configureFlags = [ - "--with-config=${configFile}" - "--with-tirpc=1" - (lib.withFeatureAs (buildUser && enablePython) "python" python3.interpreter) - ] ++ optionals buildUser [ - "--with-dracutdir=$(out)/lib/dracut" - "--with-udevdir=$(out)/lib/udev" - "--with-systemdunitdir=$(out)/etc/systemd/system" - "--with-systemdpresetdir=$(out)/etc/systemd/system-preset" - "--with-systemdgeneratordir=$(out)/lib/systemd/system-generator" - "--with-mounthelperdir=$(out)/bin" - "--libexecdir=$(out)/libexec" - "--sysconfdir=/etc" - "--localstatedir=/var" - "--enable-systemd" - "--enable-pam" - ] ++ optionals buildKernel ([ - "--with-linux=${kernel.dev}/lib/modules/${kernel.modDirVersion}/source" - "--with-linux-obj=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build" - ] ++ kernel.makeFlags); - - makeFlags = optionals buildKernel kernel.makeFlags; - - enableParallelBuilding = true; - - installFlags = [ - "sysconfdir=\${out}/etc" - "DEFAULT_INITCONF_DIR=\${out}/default" - "INSTALL_MOD_PATH=\${out}" - ]; - - preConfigure = '' - # The kernel module builds some tests during the configurePhase, this envvar controls their parallelism - export TEST_JOBS=$NIX_BUILD_CORES - if [ -z "$enableParallelBuilding" ]; then - export TEST_JOBS=1 - fi - ''; - - # Enabling BTF causes zfs to be build with debug symbols. - # Since zfs compress kernel modules on installation, our strip hooks skip stripping them. - # Hence we strip modules prior to compression. - postBuild = optionalString buildKernel '' - find . -name "*.ko" -print0 | xargs -0 -P$NIX_BUILD_CORES ${stdenv.cc.targetPrefix}strip --strip-debug - ''; - - postInstall = optionalString buildKernel '' - # Add reference that cannot be detected due to compressed kernel module - mkdir -p "$out/nix-support" - echo "${util-linux}" >> "$out/nix-support/extra-refs" - '' + optionalString buildUser '' - # Remove provided services as they are buggy - rm $out/etc/systemd/system/zfs-import-*.service - - for i in $out/etc/systemd/system/*; do - if [ -L $i ]; then - continue - fi - sed -i '/zfs-import-scan.service/d' $i - substituteInPlace $i --replace-warn "zfs-import-cache.service" "zfs-import.target" - done - - # Remove tests because they add a runtime dependency on gcc - rm -rf $out/share/zfs/zfs-tests - - ${optionalString (lib.versionOlder version "2.2") '' - # Add Bash completions. - install -v -m444 -D -t $out/share/bash-completion/completions contrib/bash_completion.d/zfs - (cd $out/share/bash-completion/completions; ln -s zfs zpool) - ''} - ''; - - postFixup = let - path = "PATH=${makeBinPath [ coreutils gawk gnused gnugrep util-linux smartmon sysstat ]}:$PATH"; - in '' - for i in $out/libexec/zfs/zpool.d/*; do - sed -i '2i${path}' $i - done - ''; - - outputs = [ "out" ] ++ optionals buildUser [ "dev" ]; - - passthru = { - inherit enableMail kernelModuleAttribute; - latestCompatibleLinuxPackages = lib.warn "zfs.latestCompatibleLinuxPackages is deprecated and is now pointing at the default kernel. If using the stable LTS kernel (default `linuxPackages` is not possible then you must explicitly pin a specific kernel release. For example, `boot.kernelPackages = pkgs.linuxPackages_6_6`. Please be aware that non-LTS kernels are likely to go EOL before ZFS supports the latest supported non-LTS release, requiring manual intervention." linuxPackages ; - - # The corresponding userspace tools to this instantiation - # of the ZFS package set. - userspaceTools = genericBuild (outerArgs // { - configFile = "user"; - }) innerArgs; - - inherit tests; - }; - - meta = { - description = "ZFS Filesystem Linux" + (if buildUser then " Userspace Tools" else " Kernel Module"); - longDescription = '' - ZFS is a filesystem that combines a logical volume manager with a - Copy-On-Write filesystem with data integrity detection and repair, - snapshotting, cloning, block devices, deduplication, and more. - - ${if buildUser then "This is the userspace tools package." else "This is the kernel module package."} - '' + extraLongDescription; - homepage = "https://github.com/openzfs/zfs"; - changelog = "https://github.com/openzfs/zfs/releases/tag/zfs-${version}"; - license = lib.licenses.cddl; - - # The case-block for TARGET_CPU has branches for only some CPU families, - # which prevents ZFS from building on any other platform. Since the NixOS - # `boot.zfs.enabled` property is `readOnly`, excluding platforms where ZFS - # does not build is the only way to produce a NixOS installer on such - # platforms. - # https://github.com/openzfs/zfs/blob/6723d1110f6daf93be93db74d5ea9f6b64c9bce5/config/always-arch.m4#L12 - platforms = - with lib.systems.inspect.patterns; - map (p: p // isLinux) ([ isx86_32 isx86_64 isPower isAarch64 isSparc ] ++ isArmv7); - - inherit maintainers; - mainProgram = "zfs"; - broken = buildKernel && (kernelCompatible != null) && !(kernelCompatible kernel); - }; - }; in - genericBuild +genericBuild diff --git a/pkgs/os-specific/linux/zfs/unstable.nix b/pkgs/os-specific/linux/zfs/unstable.nix index c60bb0e47f43d5..fe504e9db6e27f 100644 --- a/pkgs/os-specific/linux/zfs/unstable.nix +++ b/pkgs/os-specific/linux/zfs/unstable.nix @@ -1,10 +1,11 @@ -{ callPackage -, kernel ? null -, stdenv -, nixosTests -, fetchpatch -, ... -} @ args: +{ + callPackage, + kernel ? null, + stdenv, + nixosTests, + fetchpatch, + ... +}@args: let stdenv' = if kernel == null then stdenv else kernel.stdenv; diff --git a/pkgs/pkgs-lib/default.nix b/pkgs/pkgs-lib/default.nix index 113dcebf8c68b3..3aa2faa88c3c3f 100644 --- a/pkgs/pkgs-lib/default.nix +++ b/pkgs/pkgs-lib/default.nix @@ -1,11 +1,11 @@ # pkgs-lib is for functions and values that can't be in lib because # they depend on some packages. This notably is *not* for supporting package # building, instead pkgs/build-support is the place for that. -{ lib, pkgs }: { +{ lib, pkgs }: +{ # setting format types and generators. These do not fit in lib/types.nix, # because they depend on pkgs for rendering some formats formats = import ./formats.nix { inherit lib pkgs; }; } - diff --git a/pkgs/pkgs-lib/formats/hocon/default.nix b/pkgs/pkgs-lib/formats/hocon/default.nix index 696e600740fa14..681aae9f3eae7e 100644 --- a/pkgs/pkgs-lib/formats/hocon/default.nix +++ b/pkgs/pkgs-lib/formats/hocon/default.nix @@ -1,5 +1,6 @@ -{ lib -, pkgs +{ + lib, + pkgs, }: let inherit (pkgs) buildPackages callPackage; @@ -14,136 +15,165 @@ let cargoLock.lockFile = ./src/Cargo.lock; }; - hocon-validator = pkgs.writers.writePython3Bin "hocon-validator" { - libraries = [ pkgs.python3Packages.pyhocon ]; - } '' - from sys import argv - from pyhocon import ConfigFactory + hocon-validator = + pkgs.writers.writePython3Bin "hocon-validator" + { + libraries = [ pkgs.python3Packages.pyhocon ]; + } + '' + from sys import argv + from pyhocon import ConfigFactory - if not len(argv) == 2: - print("USAGE: hocon-validator ") + if not len(argv) == 2: + print("USAGE: hocon-validator ") - ConfigFactory.parse_file(argv[1]) - ''; + ConfigFactory.parse_file(argv[1]) + ''; in { - format = { - generator ? hocon-generator - , validator ? hocon-validator - , doCheck ? true - }: let - hoconLib = { - mkInclude = value: let - includeStatement = if lib.isAttrs value && !(lib.isDerivation value) then { - required = false; - type = null; - _type = "include"; - } // value else { - value = toString value; - required = false; - type = null; - _type = "include"; + format = + { + generator ? hocon-generator, + validator ? hocon-validator, + doCheck ? true, + }: + let + hoconLib = { + mkInclude = + value: + let + includeStatement = + if lib.isAttrs value && !(lib.isDerivation value) then + { + required = false; + type = null; + _type = "include"; + } + // value + else + { + value = toString value; + required = false; + type = null; + _type = "include"; + }; + in + assert lib.assertMsg + (lib.elem includeStatement.type [ + "file" + "url" + "classpath" + null + ]) + '' + Type of HOCON mkInclude is not of type 'file', 'url' or 'classpath': + ${(lib.generators.toPretty { }) includeStatement} + ''; + includeStatement; + + mkAppend = value: { + inherit value; + _type = "append"; }; - in - assert lib.assertMsg (lib.elem includeStatement.type [ "file" "url" "classpath" null ]) '' - Type of HOCON mkInclude is not of type 'file', 'url' or 'classpath': - ${(lib.generators.toPretty {}) includeStatement} - ''; - includeStatement; - - mkAppend = value: { - inherit value; - _type = "append"; + + mkSubstitution = + value: + if lib.isString value then + { + inherit value; + optional = false; + _type = "substitution"; + } + else + assert lib.assertMsg (lib.isAttrs value) '' + Value of invalid type provided to `hocon.lib.mkSubstitution`: ${lib.typeOf value} + ''; + assert lib.assertMsg (value ? "value") '' + Argument to `hocon.lib.mkSubstitution` is missing a `value`: + ${builtins.toJSON value} + ''; + { + value = value.value; + optional = value.optional or false; + _type = "substitution"; + }; }; - mkSubstitution = value: - if lib.isString value - then + in + { + type = + let + type' = + with lib.types; + let + atomType = nullOr (oneOf [ + bool + float + int + path + str + ]); + in + (oneOf [ + atomType + (listOf atomType) + (attrsOf type') + ]) + // { + description = "HOCON value"; + }; + in + type'; + + lib = hoconLib; + + generate = + name: value: + callPackage + ( + { + stdenvNoCC, + hocon-generator, + hocon-validator, + writeText, + }: + stdenvNoCC.mkDerivation rec { + inherit name; + + dontUnpack = true; + preferLocalBuild = true; + + json = builtins.toJSON value; + passAsFile = [ "json" ]; + + strictDeps = true; + nativeBuildInputs = [ hocon-generator ]; + buildPhase = '' + runHook preBuild + hocon-generator < $jsonPath > output.conf + runHook postBuild + ''; + + inherit doCheck; + nativeCheckInputs = [ hocon-validator ]; + checkPhase = '' + runHook preCheck + hocon-validator output.conf + runHook postCheck + ''; + + installPhase = '' + runHook preInstall + mv output.conf $out + runHook postInstall + ''; + + passthru.json = writeText "${name}.json" json; + } + ) { - inherit value; - optional = false; - _type = "substitution"; - } - else - assert lib.assertMsg (lib.isAttrs value) '' - Value of invalid type provided to `hocon.lib.mkSubstitution`: ${lib.typeOf value} - ''; - assert lib.assertMsg (value ? "value") '' - Argument to `hocon.lib.mkSubstitution` is missing a `value`: - ${builtins.toJSON value} - ''; - { - value = value.value; - optional = value.optional or false; - _type = "substitution"; + hocon-generator = generator; + hocon-validator = validator; }; }; - - in { - type = let - type' = with lib.types; let - atomType = nullOr (oneOf [ - bool - float - int - path - str - ]); - in (oneOf [ - atomType - (listOf atomType) - (attrsOf type') - ]) // { - description = "HOCON value"; - }; - in type'; - - lib = hoconLib; - - generate = name: value: - callPackage - ({ - stdenvNoCC - , hocon-generator - , hocon-validator - , writeText - }: - stdenvNoCC.mkDerivation rec { - inherit name; - - dontUnpack = true; - preferLocalBuild = true; - - json = builtins.toJSON value; - passAsFile = [ "json" ]; - - strictDeps = true; - nativeBuildInputs = [ hocon-generator ]; - buildPhase = '' - runHook preBuild - hocon-generator < $jsonPath > output.conf - runHook postBuild - ''; - - inherit doCheck; - nativeCheckInputs = [ hocon-validator ]; - checkPhase = '' - runHook preCheck - hocon-validator output.conf - runHook postCheck - ''; - - installPhase = '' - runHook preInstall - mv output.conf $out - runHook postInstall - ''; - - passthru.json = writeText "${name}.json" json; - }) - { - hocon-generator = generator; - hocon-validator = validator; - }; - }; } diff --git a/pkgs/pkgs-lib/formats/hocon/test/comprehensive/default.nix b/pkgs/pkgs-lib/formats/hocon/test/comprehensive/default.nix index ae4fae443d41b5..14b708140eb5eb 100644 --- a/pkgs/pkgs-lib/formats/hocon/test/comprehensive/default.nix +++ b/pkgs/pkgs-lib/formats/hocon/test/comprehensive/default.nix @@ -1,14 +1,24 @@ -{ lib, formats, stdenvNoCC, writeText, ... }: +{ + lib, + formats, + stdenvNoCC, + writeText, + ... +}: let hocon = formats.hocon { }; - include_file = (writeText "hocon-test-include.conf" '' - "val" = 1 - '').overrideAttrs (_: _: { - outputHashAlgo = "sha256"; - outputHashMode = "flat"; - outputHash = "sha256-UhkJLhT3bD6znq+IdDjs/ahP19mLzrLCy/R14pVrfew="; - }); + include_file = + (writeText "hocon-test-include.conf" '' + "val" = 1 + '').overrideAttrs + ( + _: _: { + outputHashAlgo = "sha256"; + outputHashMode = "flat"; + outputHash = "sha256-UhkJLhT3bD6znq+IdDjs/ahP19mLzrLCy/R14pVrfew="; + } + ); expression = { simple_top_level_attr = "1.0"; @@ -16,8 +26,16 @@ let some_floaty = 29.95; array2d = [ - [ 1 2 "a" ] - [ 2 1 "b" ] + [ + 1 + 2 + "a" + ] + [ + 2 + 1 + "b" + ] ]; nasty_string = "\"@\n\\\t^*\b\f\n\0\";'''$"; @@ -55,29 +73,29 @@ let hocon-test-conf = hocon.generate "hocon-test.conf" expression; in - stdenvNoCC.mkDerivation { - name = "pkgs.formats.hocon-test-comprehensive"; +stdenvNoCC.mkDerivation { + name = "pkgs.formats.hocon-test-comprehensive"; - dontUnpack = true; - dontBuild = true; + dontUnpack = true; + dontBuild = true; - doCheck = true; - checkPhase = '' - runHook preCheck + doCheck = true; + checkPhase = '' + runHook preCheck - diff -U3 ${./expected.txt} ${hocon-test-conf} + diff -U3 ${./expected.txt} ${hocon-test-conf} - runHook postCheck - ''; + runHook postCheck + ''; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir $out - cp ${./expected.txt} $out/expected.txt - cp ${hocon-test-conf} $out/hocon-test.conf - cp ${hocon-test-conf.passthru.json} $out/hocon-test.json + mkdir $out + cp ${./expected.txt} $out/expected.txt + cp ${hocon-test-conf} $out/hocon-test.conf + cp ${hocon-test-conf.passthru.json} $out/hocon-test.json - runHook postInstall - ''; - } + runHook postInstall + ''; +} diff --git a/pkgs/pkgs-lib/formats/java-properties/default.nix b/pkgs/pkgs-lib/formats/java-properties/default.nix index 50eabb8cf3f31c..18b80629ae6e72 100644 --- a/pkgs/pkgs-lib/formats/java-properties/default.nix +++ b/pkgs/pkgs-lib/formats/java-properties/default.nix @@ -1,133 +1,153 @@ { lib, pkgs }: let inherit (lib) types; - inherit (types) attrsOf oneOf coercedTo str bool int float package; + inherit (types) + attrsOf + oneOf + coercedTo + str + bool + int + float + package + ; in { - javaProperties = { comment ? "Generated with Nix", boolToString ? lib.boolToString }: { + javaProperties = + { + comment ? "Generated with Nix", + boolToString ? lib.boolToString, + }: + { - # Design note: - # A nested representation of inevitably leads to bad UX: - # 1. keys like "a.b" must be disallowed, or - # the addition of options in a freeformType module - # become breaking changes - # 2. adding a value for "a" after "a"."b" was already - # defined leads to a somewhat hard to understand - # Nix error, because that's not something you can - # do with attrset syntax. Workaround: "a"."", but - # that's too little too late. Another workaround: - # mkMerge [ { a = ...; } { a.b = ...; } ]. - # - # Choosing a non-nested representation does mean that - # we sacrifice the ability to override at the (conceptual) - # hierarchical levels, _if_ an application exhibits those. - # - # Some apps just use periods instead of spaces in an odd - # mix of attempted categorization and natural language, - # with no meaningful hierarchy. - # - # We _can_ choose to support hierarchical config files - # via nested attrsets, but the module author should - # make sure that problem (2) does not occur. - type = let - elemType = - oneOf ([ - # `package` isn't generalized to `path` because path values - # are ambiguous. Are they host path strings (toString /foo/bar) - # or should they be added to the store? ("${/foo/bar}") - # The user must decide. - (coercedTo package toString str) + # Design note: + # A nested representation of inevitably leads to bad UX: + # 1. keys like "a.b" must be disallowed, or + # the addition of options in a freeformType module + # become breaking changes + # 2. adding a value for "a" after "a"."b" was already + # defined leads to a somewhat hard to understand + # Nix error, because that's not something you can + # do with attrset syntax. Workaround: "a"."", but + # that's too little too late. Another workaround: + # mkMerge [ { a = ...; } { a.b = ...; } ]. + # + # Choosing a non-nested representation does mean that + # we sacrifice the ability to override at the (conceptual) + # hierarchical levels, _if_ an application exhibits those. + # + # Some apps just use periods instead of spaces in an odd + # mix of attempted categorization and natural language, + # with no meaningful hierarchy. + # + # We _can_ choose to support hierarchical config files + # via nested attrsets, but the module author should + # make sure that problem (2) does not occur. + type = + let + elemType = + oneOf ([ + # `package` isn't generalized to `path` because path values + # are ambiguous. Are they host path strings (toString /foo/bar) + # or should they be added to the store? ("${/foo/bar}") + # The user must decide. + (coercedTo package toString str) - (coercedTo bool boolToString str) - (coercedTo int toString str) - (coercedTo float toString str) - ]) - // { description = "string, package, bool, int or float"; }; - in attrsOf elemType; + (coercedTo bool boolToString str) + (coercedTo int toString str) + (coercedTo float toString str) + ]) + // { + description = "string, package, bool, int or float"; + }; + in + attrsOf elemType; - generate = name: value: - pkgs.runCommand name - { - # Requirements - # ============ - # - # 1. Strings in Nix carry over to the same - # strings in Java => need proper escapes - # 2. Generate files quickly - # - A JVM would have to match the app's - # JVM to avoid build closure bloat - # - Even then, JVM startup would slow - # down config generation. - # - # - # Implementation - # ============== - # - # Escaping has two steps - # - # 1. jq - # Escape known separators, in order not - # to break up the keys and values. - # This handles typical whitespace correctly, - # but may produce garbage for other control - # characters. - # - # 2. iconv - # Escape >ascii code points to java escapes, - # as .properties files are supposed to be - # encoded in ISO 8859-1. It's an old format. - # UTF-8 behavior may exist in some apps and - # libraries, but we can't rely on this in - # general. + generate = + name: value: + pkgs.runCommand name + { + # Requirements + # ============ + # + # 1. Strings in Nix carry over to the same + # strings in Java => need proper escapes + # 2. Generate files quickly + # - A JVM would have to match the app's + # JVM to avoid build closure bloat + # - Even then, JVM startup would slow + # down config generation. + # + # + # Implementation + # ============== + # + # Escaping has two steps + # + # 1. jq + # Escape known separators, in order not + # to break up the keys and values. + # This handles typical whitespace correctly, + # but may produce garbage for other control + # characters. + # + # 2. iconv + # Escape >ascii code points to java escapes, + # as .properties files are supposed to be + # encoded in ISO 8859-1. It's an old format. + # UTF-8 behavior may exist in some apps and + # libraries, but we can't rely on this in + # general. - preferLocalBuild = true; - passAsFile = [ "value" ]; - value = builtins.toJSON value; - nativeBuildInputs = [ - pkgs.jq - pkgs.libiconvReal - ]; + preferLocalBuild = true; + passAsFile = [ "value" ]; + value = builtins.toJSON value; + nativeBuildInputs = [ + pkgs.jq + pkgs.libiconvReal + ]; - jqCode = - let - main = '' - to_entries - | .[] - | "\( - .key - | ${commonEscapes} - | gsub(" "; "\\ ") - | gsub("="; "\\=") - ) = \( - .value - | ${commonEscapes} - | gsub("^ "; "\\ ") - | gsub("\\n "; "\n\\ ") - )" - ''; - # Most escapes are equal for both keys and values. - commonEscapes = '' - gsub("\\\\"; "\\\\") - | gsub("\\n"; "\\n\\\n") - | gsub("#"; "\\#") - | gsub("!"; "\\!") - | gsub("\\t"; "\\t") - | gsub("\r"; "\\r") - ''; - in - main; + jqCode = + let + main = '' + to_entries + | .[] + | "\( + .key + | ${commonEscapes} + | gsub(" "; "\\ ") + | gsub("="; "\\=") + ) = \( + .value + | ${commonEscapes} + | gsub("^ "; "\\ ") + | gsub("\\n "; "\n\\ ") + )" + ''; + # Most escapes are equal for both keys and values. + commonEscapes = '' + gsub("\\\\"; "\\\\") + | gsub("\\n"; "\\n\\\n") + | gsub("#"; "\\#") + | gsub("!"; "\\!") + | gsub("\\t"; "\\t") + | gsub("\r"; "\\r") + ''; + in + main; - inputEncoding = "UTF-8"; + inputEncoding = "UTF-8"; - inherit comment; + inherit comment; - } '' - ( - echo "$comment" | while read -r ln; do echo "# $ln"; done - echo - jq -r --arg hash '#' "$jqCode" "$valuePath" \ - | iconv --from-code "$inputEncoding" --to-code JAVA \ - ) > "$out" - ''; - }; + } + '' + ( + echo "$comment" | while read -r ln; do echo "# $ln"; done + echo + jq -r --arg hash '#' "$jqCode" "$valuePath" \ + | iconv --from-code "$inputEncoding" --to-code JAVA \ + ) > "$out" + ''; + }; } diff --git a/pkgs/pkgs-lib/formats/java-properties/test/default.nix b/pkgs/pkgs-lib/formats/java-properties/test/default.nix index 3c03ec66bd1251..fdc589d2c1cd4c 100644 --- a/pkgs/pkgs-lib/formats/java-properties/test/default.nix +++ b/pkgs/pkgs-lib/formats/java-properties/test/default.nix @@ -1,8 +1,9 @@ -{ formats -, glibcLocales -, jdk -, lib -, stdenv +{ + formats, + glibcLocales, + jdk, + lib, + stdenv, }: # This test primarily tests correct escaping. @@ -59,19 +60,17 @@ stdenv.mkDerivation { # Expected output as printed by Main.java passAsFile = [ "expected" ]; - expected = concatStrings (attrValues ( - mapAttrs - (key: value: - '' - KEY - ${key} - VALUE - ${value} + expected = concatStrings ( + attrValues ( + mapAttrs (key: value: '' + KEY + ${key} + VALUE + ${value} - '' - ) - input - )); + '') input + ) + ); src = lib.sourceByRegex ./. [ ".*\.java" diff --git a/pkgs/pkgs-lib/formats/libconfig/default.nix b/pkgs/pkgs-lib/formats/libconfig/default.nix index e30c6c3c930048..ab0cb6afd12d40 100644 --- a/pkgs/pkgs-lib/formats/libconfig/default.nix +++ b/pkgs/pkgs-lib/formats/libconfig/default.nix @@ -1,5 +1,6 @@ -{ lib -, pkgs +{ + lib, + pkgs, }: let inherit (pkgs) buildPackages callPackage; @@ -14,101 +15,114 @@ let cargoLock.lockFile = ./src/Cargo.lock; }; - libconfig-validator = buildPackages.runCommandCC "libconfig-validator" - { - buildInputs = with buildPackages; [ libconfig ]; - } - '' - mkdir -p "$out/bin" - $CC -lconfig -x c - -o "$out/bin/libconfig-validator" ${./validator.c} - ''; + libconfig-validator = + buildPackages.runCommandCC "libconfig-validator" + { + buildInputs = with buildPackages; [ libconfig ]; + } + '' + mkdir -p "$out/bin" + $CC -lconfig -x c - -o "$out/bin/libconfig-validator" ${./validator.c} + ''; in { - format = { generator ? libconfig-generator, validator ? libconfig-validator }: { - inherit generator; + format = + { + generator ? libconfig-generator, + validator ? libconfig-validator, + }: + { + inherit generator; - type = with lib.types; - let - valueType = (oneOf [ - bool - int - float - str - path - (attrsOf valueType) - (listOf valueType) - ]) // { - description = "libconfig value"; - }; - in - attrsOf valueType; + type = + with lib.types; + let + valueType = + (oneOf [ + bool + int + float + str + path + (attrsOf valueType) + (listOf valueType) + ]) + // { + description = "libconfig value"; + }; + in + attrsOf valueType; - lib = { - mkHex = value: { - _type = "hex"; - inherit value; - }; - mkOctal = value: { - _type = "octal"; - inherit value; - }; - mkFloat = value: { - _type = "float"; - inherit value; - }; - mkArray = value: { - _type = "array"; - inherit value; - }; - mkList = value: { - _type = "list"; - inherit value; + lib = { + mkHex = value: { + _type = "hex"; + inherit value; + }; + mkOctal = value: { + _type = "octal"; + inherit value; + }; + mkFloat = value: { + _type = "float"; + inherit value; + }; + mkArray = value: { + _type = "array"; + inherit value; + }; + mkList = value: { + _type = "list"; + inherit value; + }; }; - }; - generate = name: value: - callPackage - ({ - stdenvNoCC - , libconfig-generator - , libconfig-validator - , writeText - }: stdenvNoCC.mkDerivation rec { - inherit name; + generate = + name: value: + callPackage + ( + { + stdenvNoCC, + libconfig-generator, + libconfig-validator, + writeText, + }: + stdenvNoCC.mkDerivation rec { + inherit name; - dontUnpack = true; - preferLocalBuild = true; + dontUnpack = true; + preferLocalBuild = true; - json = builtins.toJSON value; - passAsFile = [ "json" ]; + json = builtins.toJSON value; + passAsFile = [ "json" ]; - strictDeps = true; - nativeBuildInputs = [ libconfig-generator ]; - buildPhase = '' - runHook preBuild - libconfig-generator < $jsonPath > output.cfg - runHook postBuild - ''; + strictDeps = true; + nativeBuildInputs = [ libconfig-generator ]; + buildPhase = '' + runHook preBuild + libconfig-generator < $jsonPath > output.cfg + runHook postBuild + ''; - doCheck = true; - nativeCheckInputs = [ libconfig-validator ]; - checkPhase = '' - runHook preCheck - libconfig-validator output.cfg - runHook postCheck - ''; + doCheck = true; + nativeCheckInputs = [ libconfig-validator ]; + checkPhase = '' + runHook preCheck + libconfig-validator output.cfg + runHook postCheck + ''; - installPhase = '' - runHook preInstall - mv output.cfg $out - runHook postInstall - ''; + installPhase = '' + runHook preInstall + mv output.cfg $out + runHook postInstall + ''; - passthru.json = writeText "${name}.json" json; - }) - { - libconfig-generator = generator; - libconfig-validator = validator; - }; - }; + passthru.json = writeText "${name}.json" json; + } + ) + { + libconfig-generator = generator; + libconfig-validator = validator; + }; + }; } diff --git a/pkgs/pkgs-lib/formats/libconfig/test/comprehensive/default.nix b/pkgs/pkgs-lib/formats/libconfig/test/comprehensive/default.nix index e14fcce2f0993e..94b782f943287d 100644 --- a/pkgs/pkgs-lib/formats/libconfig/test/comprehensive/default.nix +++ b/pkgs/pkgs-lib/formats/libconfig/test/comprehensive/default.nix @@ -1,4 +1,10 @@ -{ lib, formats, stdenvNoCC, writeText, ... }: +{ + lib, + formats, + stdenvNoCC, + writeText, + ... +}: let libconfig = formats.libconfig { }; @@ -19,14 +25,41 @@ let nested.level-dash = "pass"; ## Same syntax here on these two, but they should get serialized differently: # > A list may have zero or more elements, each of which can be a scalar value, an array, a group, or another list. - list1d = libconfig.lib.mkList [ 1 "mixed!" 5 2 ]; + list1d = libconfig.lib.mkList [ + 1 + "mixed!" + 5 + 2 + ]; # You might also omit the mkList, as a list will be a list (in contrast to an array) by default. - list2d = [ 1 [ 1 1.2 "foo" ] [ "bar" 1.2 1 ] ]; + list2d = [ + 1 + [ + 1 + 1.2 + "foo" + ] + [ + "bar" + 1.2 + 1 + ] + ]; # > An array may have zero or more elements, but the elements must all be scalar values of the same type. - array1d = libconfig.lib.mkArray [ 1 5 2 ]; + array1d = libconfig.lib.mkArray [ + 1 + 5 + 2 + ]; array2d = [ - (libconfig.lib.mkArray [ 1 2 ]) - (libconfig.lib.mkArray [ 2 1 ]) + (libconfig.lib.mkArray [ + 1 + 2 + ]) + (libconfig.lib.mkArray [ + 2 + 1 + ]) ]; nasty_string = "\"@\n\\\t^*\b\f\n\0\";'''$"; @@ -55,25 +88,24 @@ let libconfig-test-cfg = libconfig.generate "libconfig-test.cfg" expression; in - stdenvNoCC.mkDerivation { - name = "pkgs.formats.libconfig-test-comprehensive"; +stdenvNoCC.mkDerivation { + name = "pkgs.formats.libconfig-test-comprehensive"; - dontUnpack = true; - dontBuild = true; + dontUnpack = true; + dontBuild = true; - doCheck = true; - checkPhase = '' - cp ${./expected.txt} expected.txt - substituteInPlace expected.txt \ - --subst-var-by include_file "${include_file}" - diff -U3 ./expected.txt ${libconfig-test-cfg} - ''; - - installPhase = '' - mkdir $out - cp expected.txt $out - cp ${libconfig-test-cfg} $out/libconfig-test.cfg - cp ${libconfig-test-cfg.passthru.json} $out/libconfig-test.json - ''; - } + doCheck = true; + checkPhase = '' + cp ${./expected.txt} expected.txt + substituteInPlace expected.txt \ + --subst-var-by include_file "${include_file}" + diff -U3 ./expected.txt ${libconfig-test-cfg} + ''; + installPhase = '' + mkdir $out + cp expected.txt $out + cp ${libconfig-test-cfg} $out/libconfig-test.cfg + cp ${libconfig-test-cfg.passthru.json} $out/libconfig-test.json + ''; +} diff --git a/pkgs/pkgs-lib/formats/php/default.nix b/pkgs/pkgs-lib/formats/php/default.nix index 9bd1de958d0be0..0904eab86858f6 100644 --- a/pkgs/pkgs-lib/formats/php/default.nix +++ b/pkgs/pkgs-lib/formats/php/default.nix @@ -1,69 +1,97 @@ -{pkgs, lib}: { +{ pkgs, lib }: +{ # Format for defining configuration of some PHP services, that use "include 'config.php';" approach. - format = {finalVariable ? null}: let - toPHP = value: { - "null" = "null"; - "bool" = if value then "true" else "false"; - "int" = toString value; - "float" = toString value; - "string" = string value; - "set" = attrs value; - "list" = list value; - } - .${builtins.typeOf value} or - (abort "should never happen: unknown value type ${builtins.typeOf value}"); + format = + { + finalVariable ? null, + }: + let + toPHP = + value: + { + "null" = "null"; + "bool" = if value then "true" else "false"; + "int" = toString value; + "float" = toString value; + "string" = string value; + "set" = attrs value; + "list" = list value; + } + .${builtins.typeOf value} + or (abort "should never happen: unknown value type ${builtins.typeOf value}"); - # https://www.php.net/manual/en/language.types.string.php#language.types.string.syntax.single - escapeSingleQuotedString = lib.escape [ "'" "\\" ]; - string = value: "'${escapeSingleQuotedString value}'"; + # https://www.php.net/manual/en/language.types.string.php#language.types.string.syntax.single + escapeSingleQuotedString = lib.escape [ + "'" + "\\" + ]; + string = value: "'${escapeSingleQuotedString value}'"; - listContent = values: lib.concatStringsSep ", " (map toPHP values); - list = values: "[" + (listContent values) + "]"; + listContent = values: lib.concatStringsSep ", " (map toPHP values); + list = values: "[" + (listContent values) + "]"; - attrsContent = values: lib.pipe values [ - (lib.mapAttrsToList (k: v: "${toPHP k} => ${toPHP v}")) - (lib.concatStringsSep ", ") - ]; - attrs = set: - if set ? _phpType then specialType set - else - "[" + attrsContent set + "]"; + attrsContent = + values: + lib.pipe values [ + (lib.mapAttrsToList (k: v: "${toPHP k} => ${toPHP v}")) + (lib.concatStringsSep ", ") + ]; + attrs = set: if set ? _phpType then specialType set else "[" + attrsContent set + "]"; - mixedArray = {list, set}: if list == [] then attrs set else "[${listContent list}, ${attrsContent set}]"; + mixedArray = + { list, set }: if list == [ ] then attrs set else "[${listContent list}, ${attrsContent set}]"; - specialType = {value, _phpType}: { - "mixed_array" = mixedArray value; - "raw" = value; - }.${_phpType}; + specialType = + { value, _phpType }: + { + "mixed_array" = mixedArray value; + "raw" = value; + } + .${_phpType}; - type = with lib.types; - nullOr (oneOf [ - bool - int - float - str - (attrsOf type) - (listOf type) - ]) - // { - description = "PHP value"; - }; - in { + type = + with lib.types; + nullOr (oneOf [ + bool + int + float + str + (attrsOf type) + (listOf type) + ]) + // { + description = "PHP value"; + }; + in + { - inherit type; + inherit type; - lib = { - mkMixedArray = list: set: {_phpType = "mixed_array"; value = { inherit list set;}; }; - mkRaw = raw: {_phpType = "raw"; value = raw;}; - }; + lib = { + mkMixedArray = list: set: { + _phpType = "mixed_array"; + value = { inherit list set; }; + }; + mkRaw = raw: { + _phpType = "raw"; + value = raw; + }; + }; - generate = name: value: pkgs.writeTextFile { - inherit name; - text = let - # strict_types enabled here to easily debug problems when calling functions of incorrect type using `mkRaw`. - phpHeader = "> third-party/pjproject/Makefile.rules - ''; - - src = fetchurl { - url = "https://downloads.asterisk.org/pub/telephony/asterisk/old-releases/asterisk-${version}.tar.gz"; - inherit sha256; - }; - - # The default libdir is $PREFIX/usr/lib, which causes problems when paths - # compiled into Asterisk expect ${out}/usr/lib rather than ${out}/lib. - - # Copy in externals to avoid them being downloaded; - # they have to be copied, because the modification date is checked. - # If you are getting a permission denied error on this dir, - # you're likely missing an automatically downloaded dependency - preConfigure = '' - mkdir externals_cache - - ${lib.concatStringsSep "\n" - (lib.mapAttrsToList (dst: src: "cp -r --no-preserve=mode ${src} ${dst}") externals)} - - ${lib.optionalString (externals ? "addons/mp3") "bash contrib/scripts/get_mp3_source.sh || true"} - - chmod -w externals_cache - ${lib.optionalString withOpus '' - cp ${asterisk-opus}/include/asterisk/* ./include/asterisk - cp ${asterisk-opus}/codecs/* ./codecs - cp ${asterisk-opus}/formats/* ./formats - ''} - ${lib.concatMapStringsSep "\n" (patch: '' - cp ${patch} ./third-party/pjproject/patches/${patch.name} - '') pjsip_patches} - ./bootstrap.sh - ''; - - configureFlags = [ - "--libdir=\${out}/lib" - "--with-lua=${lua}/lib" - "--with-pjproject-bundled" - "--with-externals-cache=$(PWD)/externals_cache" - ]; - - preBuild = '' - cat third-party/pjproject/source/pjlib-util/src/pjlib-util/scanner.c - make menuselect.makeopts - ${lib.optionalString (externals ? "addons/mp3") '' - substituteInPlace menuselect.makeopts --replace 'format_mp3 ' "" - ''} - ${lib.optionalString withOpus '' - substituteInPlace menuselect.makeopts --replace 'codec_opus_open_source ' "" - substituteInPlace menuselect.makeopts --replace 'format_ogg_opus_open_source ' "" - ''} - ''; - - postInstall = '' - # Install sample configuration files for this version of Asterisk - make samples - ${lib.optionalString (lib.versionAtLeast version "17.0.0") "make install-headers"} - ''; - - meta = with lib; { - description = "Software implementation of a telephone private branch exchange (PBX)"; - homepage = "https://www.asterisk.org/"; - license = licenses.gpl2Only; - mainProgram = "asterisk"; - maintainers = with maintainers; [ auntie DerTim1 yorickvp ]; + common = + { + version, + sha256, + externals, + pjsip_patches ? [ ], + }: + stdenv.mkDerivation { + inherit version; + pname = "asterisk" + lib.optionalString ldapSupport "-ldap"; + + buildInputs = + [ + jansson + libedit + libxml2 + libxslt + ncurses + openssl + sqlite + dmidecode + libuuid + newt + lua + speex + srtp + wget + curl + iksemel + ] + ++ lib.optionals withOpus [ + libopus + opusfile + libogg + ] + ++ lib.optionals ldapSupport [ openldap ]; + nativeBuildInputs = [ + util-linux + pkg-config + autoconf + libtool + automake + ]; + + patches = [ + # We want the Makefile to install the default /var skeleton + # under ${out}/var but we also want to use /var at runtime. + # This patch changes the runtime behavior to look for state + # directories in /var rather than ${out}/var. + ./runtime-vardirs.patch + ] ++ lib.optional withOpus "${asterisk-opus}/asterisk.patch"; + + postPatch = '' + echo "PJPROJECT_CONFIG_OPTS += --prefix=$out" >> third-party/pjproject/Makefile.rules + ''; + + src = fetchurl { + url = "https://downloads.asterisk.org/pub/telephony/asterisk/old-releases/asterisk-${version}.tar.gz"; + inherit sha256; + }; + + # The default libdir is $PREFIX/usr/lib, which causes problems when paths + # compiled into Asterisk expect ${out}/usr/lib rather than ${out}/lib. + + # Copy in externals to avoid them being downloaded; + # they have to be copied, because the modification date is checked. + # If you are getting a permission denied error on this dir, + # you're likely missing an automatically downloaded dependency + preConfigure = '' + mkdir externals_cache + + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList (dst: src: "cp -r --no-preserve=mode ${src} ${dst}") externals + )} + + ${lib.optionalString (externals ? "addons/mp3") "bash contrib/scripts/get_mp3_source.sh || true"} + + chmod -w externals_cache + ${lib.optionalString withOpus '' + cp ${asterisk-opus}/include/asterisk/* ./include/asterisk + cp ${asterisk-opus}/codecs/* ./codecs + cp ${asterisk-opus}/formats/* ./formats + ''} + ${lib.concatMapStringsSep "\n" (patch: '' + cp ${patch} ./third-party/pjproject/patches/${patch.name} + '') pjsip_patches} + ./bootstrap.sh + ''; + + configureFlags = [ + "--libdir=\${out}/lib" + "--with-lua=${lua}/lib" + "--with-pjproject-bundled" + "--with-externals-cache=$(PWD)/externals_cache" + ]; + + preBuild = '' + cat third-party/pjproject/source/pjlib-util/src/pjlib-util/scanner.c + make menuselect.makeopts + ${lib.optionalString (externals ? "addons/mp3") '' + substituteInPlace menuselect.makeopts --replace 'format_mp3 ' "" + ''} + ${lib.optionalString withOpus '' + substituteInPlace menuselect.makeopts --replace 'codec_opus_open_source ' "" + substituteInPlace menuselect.makeopts --replace 'format_ogg_opus_open_source ' "" + ''} + ''; + + postInstall = '' + # Install sample configuration files for this version of Asterisk + make samples + ${lib.optionalString (lib.versionAtLeast version "17.0.0") "make install-headers"} + ''; + + meta = with lib; { + description = "Software implementation of a telephone private branch exchange (PBX)"; + homepage = "https://www.asterisk.org/"; + license = licenses.gpl2Only; + mainProgram = "asterisk"; + maintainers = with maintainers; [ + auntie + DerTim1 + yorickvp + ]; + }; }; - }; - pjproject_2_14_1 = fetchurl - { + pjproject_2_14_1 = + fetchurl { url = "https://raw.githubusercontent.com/asterisk/third-party/master/pjproject/2.14.1/pjproject-2.14.1.tar.bz2"; hash = "sha256-MtsK8bOc0fT/H/pUydqK/ahMIVg8yiRDt3TSM1uhUFQ="; - } // { - pjsip_patches = [ ]; - }; + } + // { + pjsip_patches = [ ]; + }; mp3-202 = fetchsvn { url = "http://svn.digium.com/svn/thirdparty/mp3/trunk"; @@ -164,22 +187,29 @@ let }; # auto-generated by update.py - versions = lib.mapAttrs - (_: { version, sha256 }: - let - pjsip = pjproject_2_14_1; - in - common { - inherit version sha256; - inherit (pjsip) pjsip_patches; - externals = { - "externals_cache/${pjsip.name}" = pjsip; - "addons/mp3" = mp3-202; - }; - }) - (lib.importJSON ./versions.json); - - updateScript_python = python3.withPackages (p: with p; [ packaging beautifulsoup4 requests ]); + versions = lib.mapAttrs ( + _: + { version, sha256 }: + let + pjsip = pjproject_2_14_1; + in + common { + inherit version sha256; + inherit (pjsip) pjsip_patches; + externals = { + "externals_cache/${pjsip.name}" = pjsip; + "addons/mp3" = mp3-202; + }; + } + ) (lib.importJSON ./versions.json); + + updateScript_python = python3.withPackages ( + p: with p; [ + packaging + beautifulsoup4 + requests + ] + ); updateScript = writeScript "asterisk-update" '' #!/usr/bin/env bash exec ${updateScript_python}/bin/python ${toString ./update.py} @@ -201,7 +231,10 @@ in asterisk-lts = versions.asterisk_18; asterisk-stable = versions.asterisk_20; asterisk = versions.asterisk_20.overrideAttrs (o: { - passthru = (o.passthru or { }) // { inherit updateScript; }; + passthru = (o.passthru or { }) // { + inherit updateScript; + }; }); -} // versions +} +// versions diff --git a/pkgs/servers/authelia/default.nix b/pkgs/servers/authelia/default.nix index 4a9fec901fc0d5..2c49c09b0550bf 100644 --- a/pkgs/servers/authelia/default.nix +++ b/pkgs/servers/authelia/default.nix @@ -1,11 +1,30 @@ -{ lib, nodejs, pnpm, fetchFromGitHub, buildGoModule, installShellFiles, callPackage, nixosTests }: +{ + lib, + nodejs, + pnpm, + fetchFromGitHub, + buildGoModule, + installShellFiles, + callPackage, + nixosTests, +}: let - inherit (import ./sources.nix { inherit fetchFromGitHub; }) pname version src vendorHash; + inherit (import ./sources.nix { inherit fetchFromGitHub; }) + pname + version + src + vendorHash + ; web = callPackage ./web.nix { inherit nodejs pnpm fetchFromGitHub; }; in buildGoModule rec { - inherit pname version src vendorHash; + inherit + pname + version + src + vendorHash + ; nativeBuildInputs = [ installShellFiles ]; @@ -74,7 +93,11 @@ buildGoModule rec { authentication. ''; license = licenses.asl20; - maintainers = with maintainers; [ jk dit7ya nicomem ]; + maintainers = with maintainers; [ + jk + dit7ya + nicomem + ]; mainProgram = "authelia"; }; } diff --git a/pkgs/servers/authelia/web.nix b/pkgs/servers/authelia/web.nix index 3ca69cbd580779..7b3083600603ad 100644 --- a/pkgs/servers/authelia/web.nix +++ b/pkgs/servers/authelia/web.nix @@ -1,7 +1,17 @@ -{ stdenv, nodejs, pnpm, fetchFromGitHub }: +{ + stdenv, + nodejs, + pnpm, + fetchFromGitHub, +}: let - inherit (import ./sources.nix { inherit fetchFromGitHub; }) pname version src pnpmDepsHash; + inherit (import ./sources.nix { inherit fetchFromGitHub; }) + pname + version + src + pnpmDepsHash + ; in stdenv.mkDerivation (finalAttrs: { pname = "${pname}-web"; @@ -15,7 +25,12 @@ stdenv.mkDerivation (finalAttrs: { ]; pnpmDeps = pnpm.fetchDeps { - inherit (finalAttrs) pname version src sourceRoot; + inherit (finalAttrs) + pname + version + src + sourceRoot + ; hash = pnpmDepsHash; }; diff --git a/pkgs/servers/bindle/default.nix b/pkgs/servers/bindle/default.nix index 7655bc31107dfd..07507e00adde77 100644 --- a/pkgs/servers/bindle/default.nix +++ b/pkgs/servers/bindle/default.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, pkg-config, openssl }: +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, +}: rustPlatform.buildRustPackage rec { pname = "bindle"; @@ -23,8 +29,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-RECEeo0uoGO5bBe+r++zpTjYYX3BIkT58uht2MLYkN0="; cargoBuildFlags = [ - "--bin" "bindle" - "--bin" "bindle-server" + "--bin" + "bindle" + "--bin" + "bindle-server" "--all-features" ]; @@ -36,4 +44,3 @@ rustPlatform.buildRustPackage rec { platforms = platforms.unix; }; } - diff --git a/pkgs/servers/binserve/default.nix b/pkgs/servers/binserve/default.nix index 6ec3c073ac9133..df1cf540b52cee 100644 --- a/pkgs/servers/binserve/default.nix +++ b/pkgs/servers/binserve/default.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, rustPlatform }: +{ + lib, + fetchFromGitHub, + rustPlatform, +}: rustPlatform.buildRustPackage rec { pname = "binserve"; diff --git a/pkgs/servers/clickhouse/default.nix b/pkgs/servers/clickhouse/default.nix index 609877ae1f9c39..a7837947852ebe 100644 --- a/pkgs/servers/clickhouse/default.nix +++ b/pkgs/servers/clickhouse/default.nix @@ -1,33 +1,38 @@ -{ lib -, llvmPackages -, fetchFromGitHub -, fetchpatch -, cmake -, ninja -, python3 -, perl -, nasm -, yasm -, nixosTests -, darwin -, findutils -, libiconv - -, rustSupport ? true - -, corrosion -, rustc -, cargo -, rustPlatform +{ + lib, + llvmPackages, + fetchFromGitHub, + fetchpatch, + cmake, + ninja, + python3, + perl, + nasm, + yasm, + nixosTests, + darwin, + findutils, + libiconv, + + rustSupport ? true, + + corrosion, + rustc, + cargo, + rustPlatform, }: let inherit (llvmPackages) stdenv; - mkDerivation = ( - if stdenv.hostPlatform.isDarwin - then darwin.apple_sdk_11_0.llvmPackages_16.stdenv - else llvmPackages.stdenv).mkDerivation; -in mkDerivation rec { + mkDerivation = + ( + if stdenv.hostPlatform.isDarwin then + darwin.apple_sdk_11_0.llvmPackages_16.stdenv + else + llvmPackages.stdenv + ).mkDerivation; +in +mkDerivation rec { pname = "clickhouse"; version = "24.3.7.30"; @@ -77,46 +82,62 @@ in mkDerivation rec { ]; strictDeps = true; - nativeBuildInputs = [ - cmake - ninja - python3 - perl - llvmPackages.lld - ] ++ lib.optionals stdenv.hostPlatform.isx86_64 [ - nasm - yasm - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - llvmPackages.bintools - findutils - darwin.bootstrap_cmds - ] ++ lib.optionals rustSupport [ - rustc - cargo - rustPlatform.cargoSetupHook - ]; + nativeBuildInputs = + [ + cmake + ninja + python3 + perl + llvmPackages.lld + ] + ++ lib.optionals stdenv.hostPlatform.isx86_64 [ + nasm + yasm + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + llvmPackages.bintools + findutils + darwin.bootstrap_cmds + ] + ++ lib.optionals rustSupport [ + rustc + cargo + rustPlatform.cargoSetupHook + ]; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv ]; # their vendored version is too old and missing this patch: https://github.com/corrosion-rs/corrosion/pull/205 - corrosionSrc = if rustSupport then fetchFromGitHub { - owner = "corrosion-rs"; - repo = "corrosion"; - rev = "v0.3.5"; - hash = "sha256-r/jrck4RiQynH1+Hx4GyIHpw/Kkr8dHe1+vTHg+fdRs="; - } else null; - corrosionDeps = if rustSupport then rustPlatform.fetchCargoTarball { - src = corrosionSrc; - name = "corrosion-deps"; - preBuild = "cd generator"; - hash = "sha256-dhUgpwSjE9NZ2mCkhGiydI51LIOClA5wwk1O3mnnbM8="; - } else null; - rustDeps = if rustSupport then rustPlatform.fetchCargoTarball { - inherit src; - name = "rust-deps"; - preBuild = "cd rust"; - hash = "sha256-rbEfCRB2QAZ2WBgSLYYUqeYtI4Y5d9oQ2G8/mPirIp4="; - } else null; + corrosionSrc = + if rustSupport then + fetchFromGitHub { + owner = "corrosion-rs"; + repo = "corrosion"; + rev = "v0.3.5"; + hash = "sha256-r/jrck4RiQynH1+Hx4GyIHpw/Kkr8dHe1+vTHg+fdRs="; + } + else + null; + corrosionDeps = + if rustSupport then + rustPlatform.fetchCargoTarball { + src = corrosionSrc; + name = "corrosion-deps"; + preBuild = "cd generator"; + hash = "sha256-dhUgpwSjE9NZ2mCkhGiydI51LIOClA5wwk1O3mnnbM8="; + } + else + null; + rustDeps = + if rustSupport then + rustPlatform.fetchCargoTarball { + inherit src; + name = "rust-deps"; + preBuild = "cd rust"; + hash = "sha256-rbEfCRB2QAZ2WBgSLYYUqeYtI4Y5d9oQ2G8/mPirIp4="; + } + else + null; dontCargoSetupPostUnpack = true; postUnpack = lib.optionalString rustSupport '' @@ -141,53 +162,62 @@ in mkDerivation rec { popd ''; - postPatch = '' - patchShebangs src/ - - substituteInPlace src/Storages/System/StorageSystemLicenses.sh \ - --replace 'git rev-parse --show-toplevel' '$src' - substituteInPlace utils/check-style/check-duplicate-includes.sh \ - --replace 'git rev-parse --show-toplevel' '$src' - substituteInPlace utils/check-style/check-ungrouped-includes.sh \ - --replace 'git rev-parse --show-toplevel' '$src' - substituteInPlace utils/list-licenses/list-licenses.sh \ - --replace 'git rev-parse --show-toplevel' '$src' - substituteInPlace utils/check-style/check-style \ - --replace 'git rev-parse --show-toplevel' '$src' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - sed -i 's|gfind|find|' cmake/tools.cmake - sed -i 's|ggrep|grep|' cmake/tools.cmake - '' + lib.optionalString rustSupport '' - - pushd contrib/corrosion/generator - cargoDepsCopy="$corrosionDepsCopy" cargoSetupPostPatchHook - popd - - pushd rust - cargoDepsCopy="$rustDepsCopy" cargoSetupPostPatchHook - popd - - cargoSetupPostPatchHook() { true; } - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Make sure Darwin invokes lld.ld64 not lld. - substituteInPlace cmake/tools.cmake \ - --replace '--ld-path=''${LLD_PATH}' '-fuse-ld=lld' - ''; + postPatch = + '' + patchShebangs src/ + + substituteInPlace src/Storages/System/StorageSystemLicenses.sh \ + --replace 'git rev-parse --show-toplevel' '$src' + substituteInPlace utils/check-style/check-duplicate-includes.sh \ + --replace 'git rev-parse --show-toplevel' '$src' + substituteInPlace utils/check-style/check-ungrouped-includes.sh \ + --replace 'git rev-parse --show-toplevel' '$src' + substituteInPlace utils/list-licenses/list-licenses.sh \ + --replace 'git rev-parse --show-toplevel' '$src' + substituteInPlace utils/check-style/check-style \ + --replace 'git rev-parse --show-toplevel' '$src' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + sed -i 's|gfind|find|' cmake/tools.cmake + sed -i 's|ggrep|grep|' cmake/tools.cmake + '' + + lib.optionalString rustSupport '' + + pushd contrib/corrosion/generator + cargoDepsCopy="$corrosionDepsCopy" cargoSetupPostPatchHook + popd + + pushd rust + cargoDepsCopy="$rustDepsCopy" cargoSetupPostPatchHook + popd + + cargoSetupPostPatchHook() { true; } + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Make sure Darwin invokes lld.ld64 not lld. + substituteInPlace cmake/tools.cmake \ + --replace '--ld-path=''${LLD_PATH}' '-fuse-ld=lld' + ''; - cmakeFlags = [ - "-DENABLE_TESTS=OFF" - "-DCOMPILER_CACHE=disabled" - "-DENABLE_EMBEDDED_COMPILER=ON" - ] ++ - lib.optional (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) "-DNO_ARMV81_OR_HIGHER=1"; + cmakeFlags = + [ + "-DENABLE_TESTS=OFF" + "-DCOMPILER_CACHE=disabled" + "-DENABLE_EMBEDDED_COMPILER=ON" + ] + ++ lib.optional ( + stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64 + ) "-DNO_ARMV81_OR_HIGHER=1"; env = { NIX_CFLAGS_COMPILE = # undefined reference to '__sync_val_compare_and_swap_16' - lib.optionalString stdenv.hostPlatform.isx86_64 " -mcx16" + - # Silence ``-Wimplicit-const-int-float-conversion` error in MemoryTracker.cpp and - # ``-Wno-unneeded-internal-declaration` TreeOptimizer.cpp. - lib.optionalString stdenv.hostPlatform.isDarwin " -Wno-implicit-const-int-float-conversion -Wno-unneeded-internal-declaration"; + lib.optionalString stdenv.hostPlatform.isx86_64 " -mcx16" + + + # Silence ``-Wimplicit-const-int-float-conversion` error in MemoryTracker.cpp and + # ``-Wno-unneeded-internal-declaration` TreeOptimizer.cpp. + lib.optionalString stdenv.hostPlatform.isDarwin + " -Wno-implicit-const-int-float-conversion -Wno-unneeded-internal-declaration"; }; # https://github.com/ClickHouse/ClickHouse/issues/49988 @@ -213,7 +243,10 @@ in mkDerivation rec { homepage = "https://clickhouse.com"; description = "Column-oriented database management system"; license = licenses.asl20; - maintainers = with maintainers; [ orivej mbalatsko ]; + maintainers = with maintainers; [ + orivej + mbalatsko + ]; # not supposed to work on 32-bit https://github.com/ClickHouse/ClickHouse/pull/23959#issuecomment-835343685 platforms = lib.filter (x: (lib.systems.elaborate x).is64bit) (platforms.linux ++ platforms.darwin); diff --git a/pkgs/servers/code-server/default.nix b/pkgs/servers/code-server/default.nix index 5662dc5d333b50..4121a5e8b4d3a2 100644 --- a/pkgs/servers/code-server/default.nix +++ b/pkgs/servers/code-server/default.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildGoModule -, makeWrapper -, cacert -, moreutils -, jq -, git -, rsync -, pkg-config -, yarn -, python3 -, esbuild -, nodejs -, node-gyp -, libsecret -, xorg -, ripgrep -, AppKit -, Cocoa -, CoreServices -, Security -, cctools -, xcbuild -, quilt -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + buildGoModule, + makeWrapper, + cacert, + moreutils, + jq, + git, + rsync, + pkg-config, + yarn, + python3, + esbuild, + nodejs, + node-gyp, + libsecret, + xorg, + ripgrep, + AppKit, + Cocoa, + CoreServices, + Security, + cctools, + xcbuild, + quilt, + nixosTests, }: let @@ -35,16 +36,21 @@ let defaultYarnOpts = [ ]; esbuild' = esbuild.override { - buildGoModule = args: buildGoModule (args // rec { - version = "0.16.17"; - src = fetchFromGitHub { - owner = "evanw"; - repo = "esbuild"; - rev = "v${version}"; - hash = "sha256-8L8h0FaexNsb3Mj6/ohA37nYLFogo5wXkAhGztGUUsQ="; - }; - vendorHash = "sha256-+BfxCyg0KkDQpHt/wycy/8CTG6YBA/VJvJFhhzUnSiQ="; - }); + buildGoModule = + args: + buildGoModule ( + args + // rec { + version = "0.16.17"; + src = fetchFromGitHub { + owner = "evanw"; + repo = "esbuild"; + rev = "v${version}"; + hash = "sha256-8L8h0FaexNsb3Mj6/ohA37nYLFogo5wXkAhGztGUUsQ="; + }; + vendorHash = "sha256-+BfxCyg0KkDQpHt/wycy/8CTG6YBA/VJvJFhhzUnSiQ="; + } + ); }; # replaces esbuild's download script with a binary from nixpkgs @@ -89,7 +95,11 @@ stdenv.mkDerivation (finalAttrs: { name = "${finalAttrs.pname}-${finalAttrs.version}-${system}-yarn-cache"; inherit (finalAttrs) src; - nativeBuildInputs = [ yarn' git cacert ]; + nativeBuildInputs = [ + yarn' + git + cacert + ]; buildPhase = '' runHook preBuild @@ -130,19 +140,22 @@ stdenv.mkDerivation (finalAttrs: { quilt ]; - buildInputs = [ - xorg.libX11 - xorg.libxkbfile - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - libsecret - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - Cocoa - CoreServices - Security - cctools - xcbuild - ]; + buildInputs = + [ + xorg.libX11 + xorg.libxkbfile + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libsecret + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + Cocoa + CoreServices + Security + cctools + xcbuild + ]; patches = [ # Remove all git calls from the VS Code build script except `git rev-parse @@ -193,95 +206,98 @@ stdenv.mkDerivation (finalAttrs: { runHook postConfigure ''; - buildPhase = '' - runHook preBuild - - # Apply patches. - quilt push -a - - export PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD=1 - export SKIP_SUBMODULE_DEPS=1 - export NODE_OPTIONS="--openssl-legacy-provider --max-old-space-size=4096" - - # Remove all built-in extensions, as these are 3rd party extensions that - # get downloaded from the VS Code marketplace. - jq --slurp '.[0] * .[1]' "./lib/vscode/product.json" <( - cat << EOF - { - "builtInExtensions": [] - } - EOF - ) | sponge ./lib/vscode/product.json - - # Disable automatic updates. - sed -i '/update.mode/,/\}/{s/default:.*/default: "none",/g}' \ - lib/vscode/src/vs/platform/update/common/update.config.contribution.ts + buildPhase = + '' + runHook preBuild - # Patch out remote download of nodejs from build script. - patch -p1 -i ${./remove-node-download.patch} + # Apply patches. + quilt push -a + + export PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD=1 + export SKIP_SUBMODULE_DEPS=1 + export NODE_OPTIONS="--openssl-legacy-provider --max-old-space-size=4096" + + # Remove all built-in extensions, as these are 3rd party extensions that + # get downloaded from the VS Code marketplace. + jq --slurp '.[0] * .[1]' "./lib/vscode/product.json" <( + cat << EOF + { + "builtInExtensions": [] + } + EOF + ) | sponge ./lib/vscode/product.json + + # Disable automatic updates. + sed -i '/update.mode/,/\}/{s/default:.*/default: "none",/g}' \ + lib/vscode/src/vs/platform/update/common/update.config.contribution.ts + + # Patch out remote download of nodejs from build script. + patch -p1 -i ${./remove-node-download.patch} + + # Install dependencies. + patchShebangs . + find . -name "yarn.lock" -printf "%h\n" | \ + xargs -I {} yarn --cwd {} \ + --offline --frozen-lockfile --ignore-scripts --ignore-engines + patchShebangs . + + # Use esbuild from nixpkgs. + ${patchEsbuild "./lib/vscode/build" "0.12.6"} + ${patchEsbuild "./lib/vscode/extensions" "0.11.23"} + + # Kerberos errors while building, so remove it for now as it is not + # required. + yarn remove kerberos --cwd lib/vscode/remote --offline --frozen-lockfile --ignore-scripts --ignore-engines + + # Put ripgrep binary into bin, so post-install does not try to download it. + find -name ripgrep -type d \ + -execdir mkdir -p {}/bin \; \ + -execdir ln -s ${ripgrep}/bin/rg {}/bin/rg \; + + # Run post-install scripts after patching. + find ./lib/vscode \( -path "*/node_modules/*" -or -path "*/extensions/*" \) \ + -and -type f -name "yarn.lock" -printf "%h\n" | \ + xargs -I {} sh -c 'jq -e ".scripts.postinstall" {}/package.json >/dev/null && yarn --cwd {} postinstall --frozen-lockfile --offline || true' + patchShebangs . + + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Use prebuilt binary for @parcel/watcher, which requires macOS SDK 10.13+ + # (see issue #101229). + pushd ./lib/vscode/remote/node_modules/@parcel/watcher + mkdir -p ./build/Release + mv ./prebuilds/darwin-x64/node.napi.glibc.node ./build/Release/watcher.node + jq "del(.scripts) | .gypfile = false" ./package.json | sponge ./package.json + popd + '' + + '' + + # Build binary packages (argon2, node-pty, etc). + npm rebuild --offline + npm rebuild --offline --prefix lib/vscode/remote + + # Build code-server and VS Code. + yarn build + VERSION=${finalAttrs.version} yarn build:vscode + + # Inject version into package.json. + jq --slurp '.[0] * .[1]' ./package.json <( + cat << EOF + { + "version": "${finalAttrs.version}" + } + EOF + ) | sponge ./package.json + + # Create release, keeping all dependencies. + KEEP_MODULES=1 yarn release + + # Prune development dependencies. We only need to do this for the root as + # the VS Code build process already does this for VS Code. + npm prune --omit=dev --prefix release - # Install dependencies. - patchShebangs . - find . -name "yarn.lock" -printf "%h\n" | \ - xargs -I {} yarn --cwd {} \ - --offline --frozen-lockfile --ignore-scripts --ignore-engines - patchShebangs . - - # Use esbuild from nixpkgs. - ${patchEsbuild "./lib/vscode/build" "0.12.6"} - ${patchEsbuild "./lib/vscode/extensions" "0.11.23"} - - # Kerberos errors while building, so remove it for now as it is not - # required. - yarn remove kerberos --cwd lib/vscode/remote --offline --frozen-lockfile --ignore-scripts --ignore-engines - - # Put ripgrep binary into bin, so post-install does not try to download it. - find -name ripgrep -type d \ - -execdir mkdir -p {}/bin \; \ - -execdir ln -s ${ripgrep}/bin/rg {}/bin/rg \; - - # Run post-install scripts after patching. - find ./lib/vscode \( -path "*/node_modules/*" -or -path "*/extensions/*" \) \ - -and -type f -name "yarn.lock" -printf "%h\n" | \ - xargs -I {} sh -c 'jq -e ".scripts.postinstall" {}/package.json >/dev/null && yarn --cwd {} postinstall --frozen-lockfile --offline || true' - patchShebangs . - - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Use prebuilt binary for @parcel/watcher, which requires macOS SDK 10.13+ - # (see issue #101229). - pushd ./lib/vscode/remote/node_modules/@parcel/watcher - mkdir -p ./build/Release - mv ./prebuilds/darwin-x64/node.napi.glibc.node ./build/Release/watcher.node - jq "del(.scripts) | .gypfile = false" ./package.json | sponge ./package.json - popd - '' + '' - - # Build binary packages (argon2, node-pty, etc). - npm rebuild --offline - npm rebuild --offline --prefix lib/vscode/remote - - # Build code-server and VS Code. - yarn build - VERSION=${finalAttrs.version} yarn build:vscode - - # Inject version into package.json. - jq --slurp '.[0] * .[1]' ./package.json <( - cat << EOF - { - "version": "${finalAttrs.version}" - } - EOF - ) | sponge ./package.json - - # Create release, keeping all dependencies. - KEEP_MODULES=1 yarn release - - # Prune development dependencies. We only need to do this for the root as - # the VS Code build process already does this for VS Code. - npm prune --omit=dev --prefix release - - runHook postBuild - ''; + runHook postBuild + ''; installPhase = '' runHook preInstall @@ -319,8 +335,16 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://github.com/coder/code-server"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ offline henkery code-asher ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" ]; + maintainers = with lib.maintainers; [ + offline + henkery + code-asher + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + ]; mainProgram = "code-server"; }; }) diff --git a/pkgs/servers/dcnnt/default.nix b/pkgs/servers/dcnnt/default.nix index 505ee26ab95dbd..9506193c5bc51a 100644 --- a/pkgs/servers/dcnnt/default.nix +++ b/pkgs/servers/dcnnt/default.nix @@ -1,4 +1,9 @@ -{ buildPythonApplication, fetchPypi, lib, pycryptodome }: +{ + buildPythonApplication, + fetchPypi, + lib, + pycryptodome, +}: buildPythonApplication rec { pname = "dcnnt"; diff --git a/pkgs/servers/deconz/default.nix b/pkgs/servers/deconz/default.nix index 809c990152b8d9..ab6e4c3121788e 100644 --- a/pkgs/servers/deconz/default.nix +++ b/pkgs/servers/deconz/default.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchurl -, wrapQtAppsHook -, dpkg -, autoPatchelfHook -, qtserialport -, qtwebsockets -, openssl -, libredirect -, makeWrapper -, gzip -, gnutar -, nixosTests +{ + stdenv, + lib, + fetchurl, + wrapQtAppsHook, + dpkg, + autoPatchelfHook, + qtserialport, + qtwebsockets, + openssl, + libredirect, + makeWrapper, + gzip, + gnutar, + nixosTests, }: stdenv.mkDerivation rec { @@ -23,9 +24,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-uHbo0XerUx81o7gXK570iJKiotkQ0aCXUVcyYelMu4k="; }; - nativeBuildInputs = [ dpkg autoPatchelfHook makeWrapper wrapQtAppsHook ]; + nativeBuildInputs = [ + dpkg + autoPatchelfHook + makeWrapper + wrapQtAppsHook + ]; - buildInputs = [ qtserialport qtwebsockets openssl ]; + buildInputs = [ + qtserialport + qtwebsockets + openssl + ]; unpackPhase = '' runHook preUnpack @@ -61,7 +71,12 @@ stdenv.mkDerivation rec { wrapProgram "$p" \ --set LD_PRELOAD "${libredirect}/lib/libredirect.so" \ --set NIX_REDIRECTS "/usr/share=$out/share:/usr/bin=$out/bin" \ - --prefix PATH : "${lib.makeBinPath [ gzip gnutar ]}" + --prefix PATH : "${ + lib.makeBinPath [ + gzip + gnutar + ] + }" done runHook postInstall diff --git a/pkgs/servers/dict/default.nix b/pkgs/servers/dict/default.nix index a85b6f8b88c56a..547c12534e945d 100644 --- a/pkgs/servers/dict/default.nix +++ b/pkgs/servers/dict/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, which, bison, flex, libmaa, zlib, libtool }: +{ + lib, + stdenv, + fetchurl, + which, + bison, + flex, + libmaa, + zlib, + libtool, +}: stdenv.mkDerivation rec { pname = "dictd"; @@ -9,9 +19,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-5PGmfRaJTYSUVp19yUQsFcw4wBHyuWMcfxzGInZlKhs="; }; - buildInputs = [ libmaa zlib ]; + buildInputs = [ + libmaa + zlib + ]; - nativeBuildInputs = [ bison flex libtool which ]; + nativeBuildInputs = [ + bison + flex + libtool + which + ]; # In earlier versions, parallel building was not supported but it's OK with 1.13 enableParallelBuilding = true; @@ -23,9 +41,11 @@ stdenv.mkDerivation rec { "--sysconfdir=/etc" ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-error=implicit-function-declaration" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-error=implicit-function-declaration" + ] + ); postInstall = '' install -Dm444 -t $out/share/doc/${pname} NEWS README diff --git a/pkgs/servers/dict/dictd-db-collector.nix b/pkgs/servers/dict/dictd-db-collector.nix index 83844f9a5a5f03..f8555126205f2a 100644 --- a/pkgs/servers/dict/dictd-db-collector.nix +++ b/pkgs/servers/dict/dictd-db-collector.nix @@ -1,85 +1,91 @@ -{ stdenv, lib, dict, libfaketime }: -({ dictlist, allowList ? [ "127.0.0.1" ], denyList ? [ ] }: +{ + stdenv, + lib, + dict, + libfaketime, +}: +( + { + dictlist, + allowList ? [ "127.0.0.1" ], + denyList ? [ ], + }: -/* - dictlist is a list of form - [ { filename = /path/to/files/basename; - name = "name"; } ] - basename.dict.dz and basename.index should be - dict files. Or look below for other options. - allowList is a list of IP/domain *-wildcarded strings - denyList is the same.. -*/ + /* + dictlist is a list of form + [ { filename = /path/to/files/basename; + name = "name"; } ] + basename.dict.dz and basename.index should be + dict files. Or look below for other options. + allowList is a list of IP/domain *-wildcarded strings + denyList is the same.. + */ -let - link_arguments = map - (x: ''"${x.filename}" '') - dictlist; - databases = lib.concatStrings (map - (x: - "${x.name} ${x.filename}\n") - dictlist); - allow = lib.concatStrings (map (x: "allow ${x}\n") allowList); - deny = lib.concatStrings (map (x: "deny ${x}\n") denyList); - accessSection = " + let + link_arguments = map (x: ''"${x.filename}" '') dictlist; + databases = lib.concatStrings (map (x: "${x.name} ${x.filename}\n") dictlist); + allow = lib.concatStrings (map (x: "allow ${x}\n") allowList); + deny = lib.concatStrings (map (x: "deny ${x}\n") denyList); + accessSection = " access { ${allow} ${deny} } "; - installPhase = '' - mkdir -p $out/share/dictd - cd $out/share/dictd - echo "${databases}" >databases.names - echo "${accessSection}" > dictd.conf - for j in ${toString link_arguments}; do - name="$(egrep ' '"$j"\$ databases.names)" - name=''${name% $j} - if test -d "$j"; then - if test -d "$j"/share/dictd ; then - echo "Got store path $j" - j="$j"/share/dictd + installPhase = '' + mkdir -p $out/share/dictd + cd $out/share/dictd + echo "${databases}" >databases.names + echo "${accessSection}" > dictd.conf + for j in ${toString link_arguments}; do + name="$(egrep ' '"$j"\$ databases.names)" + name=''${name% $j} + if test -d "$j"; then + if test -d "$j"/share/dictd ; then + echo "Got store path $j" + j="$j"/share/dictd + fi + echo "Directory reference: $j" + i=$(ls "$j""/"*.index) + i="''${i%.index}"; + else + i="$j"; fi - echo "Directory reference: $j" - i=$(ls "$j""/"*.index) - i="''${i%.index}"; - else - i="$j"; - fi - echo "Basename is $i" - locale=$(cat "$(dirname "$i")"/locale) - base="$(basename "$i")" - echo "Locale is $locale" - export LC_ALL=$locale - export LANG=$locale - if test -e "$i".dict.dz; then - ln -s "$i".dict.dz - else - cp "$i".dict . - source_date=$(date --utc --date=@$SOURCE_DATE_EPOCH "+%F %T") - faketime -f "$source_date" dictzip "$base".dict - fi - ln -s "$i".index . - dictfmt_index2word --locale $locale < "$base".index > "$base".word || true - dictfmt_index2suffix --locale $locale < "$base".index > "$base".suffix || true + echo "Basename is $i" + locale=$(cat "$(dirname "$i")"/locale) + base="$(basename "$i")" + echo "Locale is $locale" + export LC_ALL=$locale + export LANG=$locale + if test -e "$i".dict.dz; then + ln -s "$i".dict.dz + else + cp "$i".dict . + source_date=$(date --utc --date=@$SOURCE_DATE_EPOCH "+%F %T") + faketime -f "$source_date" dictzip "$base".dict + fi + ln -s "$i".index . + dictfmt_index2word --locale $locale < "$base".index > "$base".word || true + dictfmt_index2suffix --locale $locale < "$base".index > "$base".suffix || true - echo "database $name {" >> dictd.conf - echo " data $out/share/dictd/$base.dict.dz" >> dictd.conf - echo " index $out/share/dictd/$base.index" >> dictd.conf - echo " index_word $out/share/dictd/$base.word" >> dictd.conf - echo " index_suffix $out/share/dictd/$base.suffix" >> dictd.conf - echo "}" >> dictd.conf - done - ''; + echo "database $name {" >> dictd.conf + echo " data $out/share/dictd/$base.dict.dz" >> dictd.conf + echo " index $out/share/dictd/$base.index" >> dictd.conf + echo " index_word $out/share/dictd/$base.word" >> dictd.conf + echo " index_suffix $out/share/dictd/$base.suffix" >> dictd.conf + echo "}" >> dictd.conf + done + ''; -in + in -stdenv.mkDerivation { - name = "dictd-dbs"; + stdenv.mkDerivation { + name = "dictd-dbs"; - nativeBuildInputs = [ libfaketime ]; - buildInputs = [ dict ]; + nativeBuildInputs = [ libfaketime ]; + buildInputs = [ dict ]; - dontUnpack = true; - inherit installPhase; -}) + dontUnpack = true; + inherit installPhase; + } +) diff --git a/pkgs/servers/dict/dictd-db.nix b/pkgs/servers/dict/dictd-db.nix index 2e2191c5aaa3e3..3f6af00de4f52b 100644 --- a/pkgs/servers/dict/dictd-db.nix +++ b/pkgs/servers/dict/dictd-db.nix @@ -1,33 +1,41 @@ -{ lib, stdenv, fetchurl, callPackage }: +{ + lib, + stdenv, + fetchurl, + callPackage, +}: let - # Probably a bug in some FreeDict release files, but easier to trivially - # work around than report. Not that it can cause any other problems.. - makeDictdDBFreedict = src: name: locale: - makeDictdDB src name "{.,bin}" locale; + # Probably a bug in some FreeDict release files, but easier to trivially + # work around than report. Not that it can cause any other problems.. + makeDictdDBFreedict = + src: name: locale: + makeDictdDB src name "{.,bin}" locale; - makeDictdDB = src: _name: _subdir: _locale: - stdenv.mkDerivation { - name = "dictd-db-${_name}"; - inherit src; - locale = _locale; - dbName = _name; - dontBuild = true; - unpackPhase = '' - tar xf ${src} - ''; - installPhase = '' - mkdir -p $out/share/dictd - cp $(ls ./${_subdir}/*.{dict*,index} || true) $out/share/dictd - echo "${_locale}" >$out/share/dictd/locale - ''; + makeDictdDB = + src: _name: _subdir: _locale: + stdenv.mkDerivation { + name = "dictd-db-${_name}"; + inherit src; + locale = _locale; + dbName = _name; + dontBuild = true; + unpackPhase = '' + tar xf ${src} + ''; + installPhase = '' + mkdir -p $out/share/dictd + cp $(ls ./${_subdir}/*.{dict*,index} || true) $out/share/dictd + echo "${_locale}" >$out/share/dictd/locale + ''; - meta = { - description = "dictd-db dictionary for dictd"; - platforms = lib.platforms.linux; - }; - }; -in rec { + meta = { + description = "dictd-db dictionary for dictd"; + platforms = lib.platforms.linux; + }; + }; +in +rec { deu2eng = makeDictdDBFreedict (fetchurl { url = "mirror://sourceforge/freedict/deu-eng.tar.gz"; sha256 = "0dqrhv04g4f5s84nbgisgcfwk5x0rpincif0yfhfh4sc1bsvzsrb"; @@ -40,7 +48,7 @@ in rec { url = "mirror://sourceforge/freedict/nld-eng.tar.gz"; sha256 = "1vhw81pphb64fzsjvpzsnnyr34ka2fxizfwilnxyjcmpn9360h07"; }) "nld-eng" "nl_NL"; - eng2nld = makeDictdDBFreedict (fetchurl { + eng2nld = makeDictdDBFreedict (fetchurl { url = "mirror://sourceforge/freedict/eng-nld.tar.gz"; sha256 = "0rcg28ldykv0w2mpxc6g4rqmfs33q7pbvf68ssy1q9gpf6mz7vcl"; }) "eng-nld" "en_UK"; @@ -61,13 +69,19 @@ in rec { sha256 = "095xwqfc43dnm0g74i83lg03542f064jy2xbn3qnjxiwysz9ksnz"; }) "epo-eng" "epo-eng" "eo"; jpn2eng = makeDictdDB (fetchurl { - url = let version = "0.1"; - in "mirror://sourceforge/freedict/jpn-eng/${version}/freedict-jpn-eng-${version}.dictd.tar.xz"; + url = + let + version = "0.1"; + in + "mirror://sourceforge/freedict/jpn-eng/${version}/freedict-jpn-eng-${version}.dictd.tar.xz"; sha256 = "sha256-juJBoEq7EztLZzOomc7uoZhXVaQPKoUvIxxPLB0xByc="; }) "jpn-eng" "jpn-eng" "ja_JP"; eng2jpn = makeDictdDB (fetchurl { - url = let version = "2022.04.06"; - in "https://download.freedict.org/dictionaries/eng-jpn/${version}/freedict-eng-jpn-${version}.dictd.tar.xz"; + url = + let + version = "2022.04.06"; + in + "https://download.freedict.org/dictionaries/eng-jpn/${version}/freedict-eng-jpn-${version}.dictd.tar.xz"; sha256 = "sha256-kfRT2kgbV3XKarCr4mqDRT5A1jR8M8APky5M5MFYatE="; }) "eng-jpn" "eng-jpn" "en_UK"; mueller_eng2rus_pkg = makeDictdDB (fetchurl { @@ -104,6 +118,6 @@ in rec { dbName = "mueller-names"; locale = "en_UK"; }; - wordnet = callPackage ./dictd-wordnet.nix {}; - wiktionary = callPackage ./wiktionary {}; + wordnet = callPackage ./dictd-wordnet.nix { }; + wiktionary = callPackage ./wiktionary { }; } diff --git a/pkgs/servers/dict/dictd-wordnet.nix b/pkgs/servers/dict/dictd-wordnet.nix index c07aa429358710..3fa2744ff2128d 100644 --- a/pkgs/servers/dict/dictd-wordnet.nix +++ b/pkgs/servers/dict/dictd-wordnet.nix @@ -1,10 +1,21 @@ -{lib, stdenv, python3, wordnet, writeScript, libfaketime}: +{ + lib, + stdenv, + python3, + wordnet, + writeScript, + libfaketime, +}: stdenv.mkDerivation rec { version = "542"; pname = "dict-db-wordnet"; - buildInputs = [python3 wordnet libfaketime]; + buildInputs = [ + python3 + wordnet + libfaketime + ]; convert = ./wordnet_structures.py; builder = writeScript "builder.sh" '' diff --git a/pkgs/servers/dict/libmaa.nix b/pkgs/servers/dict/libmaa.nix index 9b31732ed124ac..b9deb77368d770 100644 --- a/pkgs/servers/dict/libmaa.nix +++ b/pkgs/servers/dict/libmaa.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libtool }: +{ + lib, + stdenv, + fetchurl, + libtool, +}: stdenv.mkDerivation rec { version = "1.3.2"; diff --git a/pkgs/servers/dict/wiktionary/default.nix b/pkgs/servers/dict/wiktionary/default.nix index bb3aac6f753120..ea3ba3bfd8249b 100644 --- a/pkgs/servers/dict/wiktionary/default.nix +++ b/pkgs/servers/dict/wiktionary/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, python3, dict, glibcLocales, libfaketime }: +{ + lib, + stdenv, + fetchurl, + python3, + dict, + glibcLocales, + libfaketime, +}: stdenv.mkDerivation rec { pname = "dict-db-wiktionary"; @@ -9,7 +17,12 @@ stdenv.mkDerivation rec { sha256 = "f37e899a9091a1b01137c7b0f3d58813edf3039e9e94ae656694c88859bbe756"; }; - nativeBuildInputs = [ python3 dict glibcLocales libfaketime ]; + nativeBuildInputs = [ + python3 + dict + glibcLocales + libfaketime + ]; dontUnpack = true; @@ -30,6 +43,9 @@ stdenv.mkDerivation rec { homepage = "https://en.wiktionary.org/"; maintainers = with maintainers; [ qyliss ]; platforms = platforms.all; - license = with licenses; [ cc-by-sa-30 fdl11Plus ]; + license = with licenses; [ + cc-by-sa-30 + fdl11Plus + ]; }; } diff --git a/pkgs/servers/diod/default.nix b/pkgs/servers/diod/default.nix index a96f9e1ada289e..21d3f5d9a43a75 100644 --- a/pkgs/servers/diod/default.nix +++ b/pkgs/servers/diod/default.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchurl, munge, lua, - libcap, perl, ncurses +{ + lib, + stdenv, + fetchurl, + munge, + lua, + libcap, + perl, + ncurses, }: stdenv.mkDerivation rec { @@ -16,12 +23,18 @@ stdenv.mkDerivation rec { sed -i -e '/sys\/types\.h>/a #include ' diod/ops.c ''; - buildInputs = [ munge lua libcap perl ncurses ]; + buildInputs = [ + munge + lua + libcap + perl + ncurses + ]; meta = with lib; { description = "I/O forwarding server that implements a variant of the 9P protocol"; maintainers = with maintainers; [ rnhmjoj ]; - platforms = platforms.linux; - license = licenses.gpl2Plus; + platforms = platforms.linux; + license = licenses.gpl2Plus; }; } diff --git a/pkgs/servers/dns/acme-dns/default.nix b/pkgs/servers/dns/acme-dns/default.nix index db6ea4bbea0095..6359b9dac22141 100644 --- a/pkgs/servers/dns/acme-dns/default.nix +++ b/pkgs/servers/dns/acme-dns/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/servers/dns/doh-proxy-rust/default.nix b/pkgs/servers/dns/doh-proxy-rust/default.nix index 5de2732b186a44..2dcb7c06d16a5c 100644 --- a/pkgs/servers/dns/doh-proxy-rust/default.nix +++ b/pkgs/servers/dns/doh-proxy-rust/default.nix @@ -1,4 +1,12 @@ -{ lib, rustPlatform, fetchCrate, stdenv, Security, libiconv, nixosTests }: +{ + lib, + rustPlatform, + fetchCrate, + stdenv, + Security, + libiconv, + nixosTests, +}: rustPlatform.buildRustPackage rec { pname = "doh-proxy-rust"; @@ -12,7 +20,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-eXPAn2ziSdciZa6YrOIa7y7Lms681X+yVAD9HrvsZHg="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Security libiconv ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + Security + libiconv + ]; passthru.tests = { inherit (nixosTests) doh-proxy-rust; }; diff --git a/pkgs/servers/dns/knot-resolver/default.nix b/pkgs/servers/dns/knot-resolver/default.nix index 315a1e3aaf0d1b..c5b58811e7e4d6 100644 --- a/pkgs/servers/dns/knot-resolver/default.nix +++ b/pkgs/servers/dns/knot-resolver/default.nix @@ -1,137 +1,197 @@ -{ lib, stdenv, fetchurl -# native deps. -, runCommand, pkg-config, meson, ninja, makeWrapper -# build+runtime deps. -, knot-dns, luajitPackages, libuv, gnutls, lmdb -, jemalloc, systemd, libcap_ng, dns-root-data, nghttp2 # optionals, in principle -, fstrm, protobufc # more optionals -# test-only deps. -, cmocka, which, cacert -, extraFeatures ? false /* catch-all if defaults aren't enough */ +{ + lib, + stdenv, + fetchurl, + # native deps. + runCommand, + pkg-config, + meson, + ninja, + makeWrapper, + # build+runtime deps. + knot-dns, + luajitPackages, + libuv, + gnutls, + lmdb, + jemalloc, + systemd, + libcap_ng, + dns-root-data, + nghttp2, # optionals, in principle + fstrm, + protobufc, # more optionals + # test-only deps. + cmocka, + which, + cacert, + extraFeatures ? false, # catch-all if defaults aren't enough }: let # un-indented, over the whole file -result = if extraFeatures then wrapped-full else unwrapped; + result = if extraFeatures then wrapped-full else unwrapped; -inherit (lib) optional optionals optionalString; -lua = luajitPackages; + inherit (lib) optional optionals optionalString; + lua = luajitPackages; -unwrapped = stdenv.mkDerivation rec { - pname = "knot-resolver"; - version = "5.7.4"; + unwrapped = stdenv.mkDerivation rec { + pname = "knot-resolver"; + version = "5.7.4"; - src = fetchurl { - url = "https://secure.nic.cz/files/knot-resolver/${pname}-${version}.tar.xz"; - hash = "sha256-a22m7PBoKAQa+tRN+iJ3gfCuNK0YOmZwCFCTVdGL2cg="; - }; + src = fetchurl { + url = "https://secure.nic.cz/files/knot-resolver/${pname}-${version}.tar.xz"; + hash = "sha256-a22m7PBoKAQa+tRN+iJ3gfCuNK0YOmZwCFCTVdGL2cg="; + }; + + outputs = [ + "out" + "dev" + ]; + + # Path fixups for the NixOS service. + postPatch = + '' + patch meson.build < daemon/lua/trust_anchors.test/bootstrap.test.lua + sed -E '/^[[:blank:]]*test_(dstaddr|headers),?$/d' -i \ + tests/config/doh2.test.lua modules/http/http_doh.test.lua + ''; + + preConfigure = '' + patchShebangs scripts/ + ''; + + nativeBuildInputs = [ + pkg-config + meson + ninja + ]; - outputs = [ "out" "dev" ]; - - # Path fixups for the NixOS service. - postPatch = '' - patch meson.build < daemon/lua/trust_anchors.test/bootstrap.test.lua - sed -E '/^[[:blank:]]*test_(dstaddr|headers),?$/d' -i \ - tests/config/doh2.test.lua modules/http/http_doh.test.lua - ''; - - preConfigure = '' - patchShebangs scripts/ - ''; - - nativeBuildInputs = [ pkg-config meson ninja ]; - - # http://knot-resolver.readthedocs.io/en/latest/build.html#requirements - buildInputs = [ knot-dns lua.lua libuv gnutls lmdb ] - ## the rest are optional dependencies - ++ optionals stdenv.hostPlatform.isLinux [ /*lib*/systemd libcap_ng ] - ++ [ jemalloc nghttp2 ] - ++ [ fstrm protobufc ] # dnstap support + # http://knot-resolver.readthedocs.io/en/latest/build.html#requirements + buildInputs = + [ + knot-dns + lua.lua + libuv + gnutls + lmdb + ] + ## the rest are optional dependencies + ++ optionals stdenv.hostPlatform.isLinux [ + # lib + systemd + libcap_ng + ] + ++ [ + jemalloc + nghttp2 + ] + ++ [ + fstrm + protobufc + ] # dnstap support ; - mesonFlags = [ - "-Dkeyfile_default=${dns-root-data}/root.ds" - "-Droot_hints=${dns-root-data}/root.hints" - "-Dinstall_kresd_conf=disabled" # not really useful; examples are inside share/doc/ - "-Dmalloc=jemalloc" - "--default-library=static" # not used by anyone - ] - ++ optional doInstallCheck "-Dunit_tests=enabled" - ++ optional doInstallCheck "-Dconfig_tests=enabled" - ++ optional stdenv.hostPlatform.isLinux "-Dsystemd_files=enabled" # used by NixOS service + mesonFlags = + [ + "-Dkeyfile_default=${dns-root-data}/root.ds" + "-Droot_hints=${dns-root-data}/root.hints" + "-Dinstall_kresd_conf=disabled" # not really useful; examples are inside share/doc/ + "-Dmalloc=jemalloc" + "--default-library=static" # not used by anyone + ] + ++ optional doInstallCheck "-Dunit_tests=enabled" + ++ optional doInstallCheck "-Dconfig_tests=enabled" + ++ optional stdenv.hostPlatform.isLinux "-Dsystemd_files=enabled" # used by NixOS service #"-Dextra_tests=enabled" # not suitable as in-distro tests; many deps, too. - ; - - postInstall = '' - rm "$out"/lib/libkres.a - rm "$out"/lib/knot-resolver/upgrade-4-to-5.lua # not meaningful on NixOS - '' + optionalString stdenv.hostPlatform.isLinux '' - rm -r "$out"/lib/sysusers.d/ # ATM more likely to harm than help - ''; - - doInstallCheck = with stdenv; hostPlatform == buildPlatform; - nativeInstallCheckInputs = [ cmocka which cacert lua.cqueues lua.basexx lua.http ]; - installCheckPhase = '' - meson test --print-errorlogs --no-suite snowflake - ''; - - meta = with lib; { - description = "Caching validating DNS resolver, from .cz domain registry"; - homepage = "https://knot-resolver.cz"; - license = licenses.gpl3Plus; - platforms = platforms.unix; - maintainers = [ maintainers.vcunat /* upstream developer */ ]; - mainProgram = "kresd"; - }; -}; - -wrapped-full = runCommand unwrapped.name - { - nativeBuildInputs = [ makeWrapper ]; - buildInputs = with luajitPackages; [ - # For http module, prefill module, trust anchor bootstrap. - # It brings lots of deps; some are useful elsewhere (e.g. cqueues). - http - # used by policy.slice_randomize_psl() - psl + ; + + postInstall = + '' + rm "$out"/lib/libkres.a + rm "$out"/lib/knot-resolver/upgrade-4-to-5.lua # not meaningful on NixOS + '' + + optionalString stdenv.hostPlatform.isLinux '' + rm -r "$out"/lib/sysusers.d/ # ATM more likely to harm than help + ''; + + doInstallCheck = with stdenv; hostPlatform == buildPlatform; + nativeInstallCheckInputs = [ + cmocka + which + cacert + lua.cqueues + lua.basexx + lua.http ]; - preferLocalBuild = true; - allowSubstitutes = false; - inherit (unwrapped) meta; - } - ('' - mkdir -p "$out"/bin - makeWrapper '${unwrapped}/bin/kresd' "$out"/bin/kresd \ - --set LUA_PATH "$LUA_PATH" \ - --set LUA_CPATH "$LUA_CPATH" - - ln -sr '${unwrapped}/share' "$out"/ - ln -sr '${unwrapped}/lib' "$out"/ # useful in NixOS service - ln -sr "$out"/{bin,sbin} - '' + lib.optionalString unwrapped.doInstallCheck '' - echo "Checking that 'http' module loads, i.e. lua search paths work:" - echo "modules.load('http')" > test-http.lua - echo -e 'quit()' | env -i "$out"/bin/kresd -a 127.0.0.1#53535 -c test-http.lua - ''); - -in result + installCheckPhase = '' + meson test --print-errorlogs --no-suite snowflake + ''; + + meta = with lib; { + description = "Caching validating DNS resolver, from .cz domain registry"; + homepage = "https://knot-resolver.cz"; + license = licenses.gpl3Plus; + platforms = platforms.unix; + maintainers = [ + maintainers.vcunat # upstream developer + ]; + mainProgram = "kresd"; + }; + }; + + wrapped-full = + runCommand unwrapped.name + { + nativeBuildInputs = [ makeWrapper ]; + buildInputs = with luajitPackages; [ + # For http module, prefill module, trust anchor bootstrap. + # It brings lots of deps; some are useful elsewhere (e.g. cqueues). + http + # used by policy.slice_randomize_psl() + psl + ]; + preferLocalBuild = true; + allowSubstitutes = false; + inherit (unwrapped) meta; + } + ( + '' + mkdir -p "$out"/bin + makeWrapper '${unwrapped}/bin/kresd' "$out"/bin/kresd \ + --set LUA_PATH "$LUA_PATH" \ + --set LUA_CPATH "$LUA_CPATH" + + ln -sr '${unwrapped}/share' "$out"/ + ln -sr '${unwrapped}/lib' "$out"/ # useful in NixOS service + ln -sr "$out"/{bin,sbin} + '' + + lib.optionalString unwrapped.doInstallCheck '' + echo "Checking that 'http' module loads, i.e. lua search paths work:" + echo "modules.load('http')" > test-http.lua + echo -e 'quit()' | env -i "$out"/bin/kresd -a 127.0.0.1#53535 -c test-http.lua + '' + ); + +in +result diff --git a/pkgs/servers/elasticmq-server-bin/default.nix b/pkgs/servers/elasticmq-server-bin/default.nix index 5500ee30d74780..0a126b1d99fe03 100644 --- a/pkgs/servers/elasticmq-server-bin/default.nix +++ b/pkgs/servers/elasticmq-server-bin/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, jdk, jre, makeBinaryWrapper, runCommand, python3Packages, writeText }: +{ + lib, + stdenv, + fetchurl, + jdk, + jre, + makeBinaryWrapper, + runCommand, + python3Packages, + writeText, +}: stdenv.mkDerivation (finalAttrs: { pname = "elasticmq-server"; diff --git a/pkgs/servers/elasticmq-server-bin/elasticmq-test.nix b/pkgs/servers/elasticmq-server-bin/elasticmq-test.nix index 044b7450898256..bd7f43c86893e0 100644 --- a/pkgs/servers/elasticmq-server-bin/elasticmq-test.nix +++ b/pkgs/servers/elasticmq-server-bin/elasticmq-test.nix @@ -1,47 +1,60 @@ -{ elasticmq-server, python3Packages, runCommand, writeText}: +{ + elasticmq-server, + python3Packages, + runCommand, + writeText, +}: -runCommand "${elasticmq-server.name}-tests" (let - commonPy = '' - import boto3 - client = boto3.resource( - "sqs", - endpoint_url="http://localhost:9324", - region_name="elasticmq", - aws_secret_access_key="x", - aws_access_key_id="x", - use_ssl=False, - ) - queue = client.get_queue_by_name(QueueName="foobar") - ''; -in { - buildInputs = with python3Packages; [ python boto3 ]; - emqConfig = writeText "emq-test.conf" '' - generate-node-address = true +runCommand "${elasticmq-server.name}-tests" + ( + let + commonPy = '' + import boto3 + client = boto3.resource( + "sqs", + endpoint_url="http://localhost:9324", + region_name="elasticmq", + aws_secret_access_key="x", + aws_access_key_id="x", + use_ssl=False, + ) + queue = client.get_queue_by_name(QueueName="foobar") + ''; + in + { + buildInputs = with python3Packages; [ + python + boto3 + ]; + emqConfig = writeText "emq-test.conf" '' + generate-node-address = true - queues { - foobar {} + queues { + foobar {} + } + ''; + putMessagePy = writeText "put_message.py" '' + ${commonPy} + queue.send_message(MessageBody="bazqux") + ''; + checkMessagePy = writeText "check_message.py" '' + ${commonPy} + messages = queue.receive_messages() + print(f"Received {messages!r}") + assert len(messages) == 1 + assert messages[0].body == "bazqux" + ''; } - ''; - putMessagePy = writeText "put_message.py" '' - ${commonPy} - queue.send_message(MessageBody="bazqux") - ''; - checkMessagePy = writeText "check_message.py" '' - ${commonPy} - messages = queue.receive_messages() - print(f"Received {messages!r}") - assert len(messages) == 1 - assert messages[0].body == "bazqux" - ''; -}) '' - JAVA_TOOL_OPTIONS="-Dconfig.file=$emqConfig" ${elasticmq-server}/bin/elasticmq-server & - SERVER_PID=$! - sleep 10 + ) + '' + JAVA_TOOL_OPTIONS="-Dconfig.file=$emqConfig" ${elasticmq-server}/bin/elasticmq-server & + SERVER_PID=$! + sleep 10 - python $putMessagePy - python $checkMessagePy - touch $out + python $putMessagePy + python $checkMessagePy + touch $out - # needed on darwin - kill $SERVER_PID -'' + # needed on darwin + kill $SERVER_PID + '' diff --git a/pkgs/servers/etcd/3.4.nix b/pkgs/servers/etcd/3.4.nix index 597cad35021b83..ee7b4919f194b6 100644 --- a/pkgs/servers/etcd/3.4.nix +++ b/pkgs/servers/etcd/3.4.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "etcd"; diff --git a/pkgs/servers/etcd/3.5/default.nix b/pkgs/servers/etcd/3.5/default.nix index 090ae82e12725f..6ee0b49c888c84 100644 --- a/pkgs/servers/etcd/3.5/default.nix +++ b/pkgs/servers/etcd/3.5/default.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, symlinkJoin, nixosTests, k3s }: +{ + lib, + buildGoModule, + fetchFromGitHub, + symlinkJoin, + nixosTests, + k3s, +}: let version = "3.5.16"; @@ -27,7 +34,12 @@ let etcdserver = buildGoModule rec { pname = "etcdserver"; - inherit CGO_ENABLED meta src version; + inherit + CGO_ENABLED + meta + src + version + ; vendorHash = etcdServerVendorHash; @@ -47,7 +59,12 @@ let etcdutl = buildGoModule rec { pname = "etcdutl"; - inherit CGO_ENABLED meta src version; + inherit + CGO_ENABLED + meta + src + version + ; vendorHash = etcdUtlVendorHash; @@ -57,7 +74,12 @@ let etcdctl = buildGoModule rec { pname = "etcdctl"; - inherit CGO_ENABLED meta src version; + inherit + CGO_ENABLED + meta + src + version + ; vendorHash = etcdCtlVendorHash; diff --git a/pkgs/servers/fedigroups/default.nix b/pkgs/servers/fedigroups/default.nix index 764dee9ff4b16d..83e53c195fcf9b 100644 --- a/pkgs/servers/fedigroups/default.nix +++ b/pkgs/servers/fedigroups/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitea -, rustPlatform -, pkg-config -, git -, openssl -, Security +{ + lib, + stdenv, + fetchFromGitea, + rustPlatform, + pkg-config, + git, + openssl, + Security, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/servers/felix/default.nix b/pkgs/servers/felix/default.nix index 5a16812cb5b6da..186b97d710e8b5 100644 --- a/pkgs/servers/felix/default.nix +++ b/pkgs/servers/felix/default.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl}: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "apache-felix"; @@ -7,8 +11,7 @@ stdenv.mkDerivation rec { url = "mirror://apache/felix/org.apache.felix.main.distribution-${version}.tar.gz"; sha256 = "sha256-N9mbkIzMkMV2RLONv15EiosJxMU9iEJvwPWEauPIEe8="; }; - buildCommand = - '' + buildCommand = '' tar xfvz $src cd felix-framework-* mkdir -p $out diff --git a/pkgs/servers/felix/remoteshell.nix b/pkgs/servers/felix/remoteshell.nix index 2fe628db0466be..7d8bbdf5b197e6 100644 --- a/pkgs/servers/felix/remoteshell.nix +++ b/pkgs/servers/felix/remoteshell.nix @@ -1,4 +1,4 @@ -{stdenv, fetchurl}: +{ stdenv, fetchurl }: stdenv.mkDerivation rec { version = "1.1.2"; @@ -7,8 +7,7 @@ stdenv.mkDerivation rec { url = "http://apache.proserve.nl/felix/org.apache.felix.shell.remote-${version}.jar"; sha256 = "147zw5ppn98wfl3pr32isyb267xm3gwsvdfdvjr33m9g2v1z69aq"; }; - buildCommand = - '' + buildCommand = '' mkdir -p $out/bundle cp ${src} $out/bundle/org.apache.felix.shell.remote-${version}.jar ''; diff --git a/pkgs/servers/foundationdb/default.nix b/pkgs/servers/foundationdb/default.nix index 966069e6ed6e13..95b4aeddcedf29 100644 --- a/pkgs/servers/foundationdb/default.nix +++ b/pkgs/servers/foundationdb/default.nix @@ -1,18 +1,31 @@ -{ gccStdenv, llvmPackages -, lib, fetchFromGitHub, fetchpatch +{ + gccStdenv, + llvmPackages, + lib, + fetchFromGitHub, + fetchpatch, -, cmake, ninja, python3, openjdk8, mono, openssl, boost178 -, pkg-config, msgpack-cxx, toml11 + cmake, + ninja, + python3, + openjdk8, + mono, + openssl, + boost178, + pkg-config, + msgpack-cxx, + toml11, }@args: let cmakeBuild = import ./cmake.nix args; -in { +in +{ foundationdb71 = cmakeBuild { version = "7.1.32"; - hash = "sha256-CNJ4w1ECadj2KtcfbBPBQpXQeq9BAiw54hUgRTWPFzY="; - boost = boost178; - ssl = openssl; + hash = "sha256-CNJ4w1ECadj2KtcfbBPBQpXQeq9BAiw54hUgRTWPFzY="; + boost = boost178; + ssl = openssl; patches = [ ./patches/disable-flowbench.patch diff --git a/pkgs/servers/foundationdb/python.nix b/pkgs/servers/foundationdb/python.nix index 29d1f0906df747..152f704ee1473d 100644 --- a/pkgs/servers/foundationdb/python.nix +++ b/pkgs/servers/foundationdb/python.nix @@ -1,4 +1,8 @@ -{ buildPythonPackage, lib, foundationdb }: +{ + buildPythonPackage, + lib, + foundationdb, +}: buildPythonPackage { pname = "foundationdb"; @@ -16,9 +20,8 @@ buildPythonPackage { meta = with lib; { description = "Python bindings for FoundationDB"; - homepage = "https://www.foundationdb.org"; - license = with licenses; [ asl20 ]; + homepage = "https://www.foundationdb.org"; + license = with licenses; [ asl20 ]; maintainers = with maintainers; [ thoughtpolice ]; }; } - diff --git a/pkgs/servers/gemini/stargazer/default.nix b/pkgs/servers/gemini/stargazer/default.nix index 3bc5bc00632c2a..da7a432d2375db 100644 --- a/pkgs/servers/gemini/stargazer/default.nix +++ b/pkgs/servers/gemini/stargazer/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromSourcehut -, rustPlatform -, installShellFiles -, scdoc -, nixosTests -, nix-update-script +{ + lib, + fetchFromSourcehut, + rustPlatform, + installShellFiles, + scdoc, + nixosTests, + nix-update-script, }: rustPlatform.buildRustPackage rec { @@ -25,7 +26,10 @@ rustPlatform.buildRustPackage rec { updateScript = nix-update-script { }; }; - nativeBuildInputs = [ installShellFiles scdoc ]; + nativeBuildInputs = [ + installShellFiles + scdoc + ]; postInstall = '' scdoc < doc/stargazer.scd > stargazer.1 diff --git a/pkgs/servers/geospatial/martin/default.nix b/pkgs/servers/geospatial/martin/default.nix index dbd1c527ef6a97..f23ea254a336d1 100644 --- a/pkgs/servers/geospatial/martin/default.nix +++ b/pkgs/servers/geospatial/martin/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, pkg-config, openssl, Security, SystemConfiguration }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + Security, + SystemConfiguration, +}: rustPlatform.buildRustPackage rec { pname = "martin"; @@ -15,7 +24,12 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security SystemConfiguration ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + ]; checkFlags = [ "--skip function_source_schemas" @@ -50,7 +64,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Blazing fast and lightweight PostGIS vector tiles server"; homepage = "https://martin.maplibre.org/"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ sikmir ]; }; } diff --git a/pkgs/servers/gpm/default.nix b/pkgs/servers/gpm/default.nix index 245f26434cef60..3b71f1033474b4 100644 --- a/pkgs/servers/gpm/default.nix +++ b/pkgs/servers/gpm/default.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, automake, autoconf, libtool, flex, bison, texinfo, fetchpatch, pkgsStatic -, withNcurses ? true, ncurses +{ + lib, + stdenv, + fetchFromGitHub, + automake, + autoconf, + libtool, + flex, + bison, + texinfo, + fetchpatch, + pkgsStatic, + withNcurses ? true, + ncurses, }: stdenv.mkDerivation rec { @@ -17,13 +29,21 @@ stdenv.mkDerivation rec { substituteInPlace src/prog/gpm-root.y --replace __sigemptyset sigemptyset ''; - nativeBuildInputs = [ automake autoconf libtool flex bison texinfo ]; + nativeBuildInputs = [ + automake + autoconf + libtool + flex + bison + texinfo + ]; buildInputs = [ ncurses ]; hardeningDisable = [ "format" ]; patches = [ - (fetchpatch { # pull request telmich/gpm#42 + (fetchpatch { + # pull request telmich/gpm#42 url = "https://github.com/kaction/gpm/commit/217b4fe4c9b62298a4e9a54c1f07e3b52b013a09.patch"; sha256 = "1f74h12iph4z1dldbxk9imcq11805c3ai2xhbsqvx8jpjrcfp19q"; }) diff --git a/pkgs/servers/hbase/default.nix b/pkgs/servers/hbase/default.nix index 93afa6d5e19f06..be4396a2d56bfe 100644 --- a/pkgs/servers/hbase/default.nix +++ b/pkgs/servers/hbase/default.nix @@ -1,40 +1,48 @@ -{ lib -, stdenv -, fetchurl -, makeWrapper -, jdk11_headless -, nixosTests +{ + lib, + stdenv, + fetchurl, + makeWrapper, + jdk11_headless, + nixosTests, }: -let common = { version, hash, jdk ? jdk11_headless, tests }: - stdenv.mkDerivation rec { - pname = "hbase"; - inherit version; +let + common = + { + version, + hash, + jdk ? jdk11_headless, + tests, + }: + stdenv.mkDerivation rec { + pname = "hbase"; + inherit version; - src = fetchurl { - url = "mirror://apache/hbase/${version}/hbase-${version}-bin.tar.gz"; - inherit hash; - }; + src = fetchurl { + url = "mirror://apache/hbase/${version}/hbase-${version}-bin.tar.gz"; + inherit hash; + }; - nativeBuildInputs = [ makeWrapper ]; - installPhase = '' - mkdir -p $out - cp -R * $out - wrapProgram $out/bin/hbase --set-default JAVA_HOME ${jdk.home} \ - --run "test -d /etc/hadoop-conf && export HBASE_CONF_DIR=\''${HBASE_CONF_DIR-'/etc/hadoop-conf/'}" \ - --set-default HBASE_CONF_DIR "$out/conf/" - ''; + nativeBuildInputs = [ makeWrapper ]; + installPhase = '' + mkdir -p $out + cp -R * $out + wrapProgram $out/bin/hbase --set-default JAVA_HOME ${jdk.home} \ + --run "test -d /etc/hadoop-conf && export HBASE_CONF_DIR=\''${HBASE_CONF_DIR-'/etc/hadoop-conf/'}" \ + --set-default HBASE_CONF_DIR "$out/conf/" + ''; - passthru = { inherit tests; }; + passthru = { inherit tests; }; - meta = with lib; { - description = "Distributed, scalable, big data store"; - homepage = "https://hbase.apache.org"; - license = licenses.asl20; - maintainers = with lib.maintainers; [ illustris ]; - platforms = lib.platforms.linux; + meta = with lib; { + description = "Distributed, scalable, big data store"; + homepage = "https://hbase.apache.org"; + license = licenses.asl20; + maintainers = with lib.maintainers; [ illustris ]; + platforms = lib.platforms.linux; + }; }; - }; in { hbase_2_4 = common { diff --git a/pkgs/servers/hockeypuck/server.nix b/pkgs/servers/hockeypuck/server.nix index 4a59ebe77463e8..deb5a52ee20050 100644 --- a/pkgs/servers/hockeypuck/server.nix +++ b/pkgs/servers/hockeypuck/server.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: let sources = (import ./sources.nix) { inherit fetchFromGitHub; }; diff --git a/pkgs/servers/hockeypuck/web.nix b/pkgs/servers/hockeypuck/web.nix index 32f2b1acd22e19..2d6a75975ad43c 100644 --- a/pkgs/servers/hockeypuck/web.nix +++ b/pkgs/servers/hockeypuck/web.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, nixosTests }: +{ + stdenv, + lib, + fetchFromGitHub, + nixosTests, +}: let sources = (import ./sources.nix) { inherit fetchFromGitHub; }; diff --git a/pkgs/servers/home-assistant/appdaemon.nix b/pkgs/servers/home-assistant/appdaemon.nix index c2bb51cc14a013..00bc9aa07967d8 100644 --- a/pkgs/servers/home-assistant/appdaemon.nix +++ b/pkgs/servers/home-assistant/appdaemon.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/servers/home-assistant/build-custom-component/default.nix b/pkgs/servers/home-assistant/build-custom-component/default.nix index dc2663e8f7246b..ccc869c52c2269 100644 --- a/pkgs/servers/home-assistant/build-custom-component/default.nix +++ b/pkgs/servers/home-assistant/build-custom-component/default.nix @@ -1,13 +1,15 @@ -{ lib -, home-assistant -, makeSetupHook +{ + lib, + home-assistant, + makeSetupHook, }: -{ owner -, domain -, version -, format ? "other" -, ... +{ + owner, + domain, + version, + format ? "other", + ... }@args: let @@ -33,11 +35,14 @@ home-assistant.python.pkgs.buildPythonPackage ( runHook postInstall ''; - nativeCheckInputs = with home-assistant.python.pkgs; [ - importlib-metadata - manifestRequirementsCheckHook - packaging - ] ++ (args.nativeCheckInputs or []); + nativeCheckInputs = + with home-assistant.python.pkgs; + [ + importlib-metadata + manifestRequirementsCheckHook + packaging + ] + ++ (args.nativeCheckInputs or [ ]); passthru = { isHomeAssistantComponent = true; @@ -47,5 +52,10 @@ home-assistant.python.pkgs.buildPythonPackage ( inherit (home-assistant.meta) platforms; } // args.meta or { }; - } // builtins.removeAttrs args [ "meta" "nativeCheckInputs" "passthru" ] + } + // builtins.removeAttrs args [ + "meta" + "nativeCheckInputs" + "passthru" + ] ) diff --git a/pkgs/servers/home-assistant/build-custom-component/manifest-requirements-check-hook.nix b/pkgs/servers/home-assistant/build-custom-component/manifest-requirements-check-hook.nix index 76317c9d0bc8d2..ada031db22e6bc 100644 --- a/pkgs/servers/home-assistant/build-custom-component/manifest-requirements-check-hook.nix +++ b/pkgs/servers/home-assistant/build-custom-component/manifest-requirements-check-hook.nix @@ -1,5 +1,6 @@ -{ python -, makeSetupHook +{ + python, + makeSetupHook, }: makeSetupHook { diff --git a/pkgs/servers/home-assistant/component-packages.nix b/pkgs/servers/home-assistant/component-packages.nix index af28371ac6d1ae..9279b53b6da492 100644 --- a/pkgs/servers/home-assistant/component-packages.nix +++ b/pkgs/servers/home-assistant/component-packages.nix @@ -4,5060 +4,6377 @@ { version = "2024.11.3"; components = { - "3_day_blinds" = ps: with ps; [ - ]; - "abode" = ps: with ps; [ - jaraco-abode - ]; - "accuweather" = ps: with ps; [ - accuweather - ]; - "acer_projector" = ps: with ps; [ - pyserial - ]; - "acmeda" = ps: with ps; [ - aiopulse - ]; - "acomax" = ps: with ps; [ - ]; - "actiontec" = ps: with ps; [ - ]; - "adax" = ps: with ps; [ - adax - adax-local - ]; - "adguard" = ps: with ps; [ - adguardhome - ]; - "ads" = ps: with ps; [ - pyads - ]; - "advantage_air" = ps: with ps; [ - advantage-air - ]; - "aemet" = ps: with ps; [ - aemet-opendata - ]; - "aep_ohio" = ps: with ps; [ - ]; - "aep_texas" = ps: with ps; [ - ]; - "aftership" = ps: with ps; [ - pyaftership - ]; - "agent_dvr" = ps: with ps; [ - agent-py - ]; - "air_quality" = ps: with ps; [ - ]; - "airgradient" = ps: with ps; [ - airgradient - ]; - "airly" = ps: with ps; [ - airly - ]; - "airnow" = ps: with ps; [ - pyairnow - ]; - "airq" = ps: with ps; [ - aioairq - ]; - "airthings" = ps: with ps; [ - airthings-cloud - ]; - "airthings_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - airthings-ble - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "airtouch4" = ps: with ps; [ - airtouch4pyapi - ]; - "airtouch5" = ps: with ps; [ - airtouch5py - ]; - "airvisual" = ps: with ps; [ - pyairvisual - ]; - "airvisual_pro" = ps: with ps; [ - pyairvisual - ]; - "airzone" = ps: with ps; [ - aioairzone - ]; - "airzone_cloud" = ps: with ps; [ - aioairzone-cloud - ]; - "aladdin_connect" = ps: with ps; [ - ]; - "alarm_control_panel" = ps: with ps; [ - ]; - "alarmdecoder" = ps: with ps; [ - adext - ]; - "alert" = ps: with ps; [ - ]; - "alexa" = ps: with ps; [ - pyturbojpeg - ]; - "alpha_vantage" = ps: with ps; [ - alpha-vantage - ]; - "amazon_polly" = ps: with ps; [ - boto3 - ]; - "amberelectric" = ps: with ps; [ - amberelectric - ]; - "ambient_network" = ps: with ps; [ - aioambient - ]; - "ambient_station" = ps: with ps; [ - aioambient - ]; - "amcrest" = ps: with ps; [ - amcrest - ha-ffmpeg - ]; - "amp_motorization" = ps: with ps; [ - ]; - "ampio" = ps: with ps; [ - asmog - ]; - "analytics" = ps: with ps; [ - aiohasupervisor - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; - "analytics_insights" = ps: with ps; [ - python-homeassistant-analytics - ]; - "android_ip_webcam" = ps: with ps; [ - pydroid-ipcam - ]; - "androidtv" = ps: with ps; [ - adb-shell - androidtv - pure-python-adb - ] - ++ adb-shell.optional-dependencies.async - ++ androidtv.optional-dependencies.async - ++ pure-python-adb.optional-dependencies.async; - "androidtv_remote" = ps: with ps; [ - androidtvremote2 - ]; - "anel_pwrctrl" = ps: with ps; [ - anel-pwrctrl-homeassistant - ]; - "anova" = ps: with ps; [ - anova-wifi - ]; - "anthemav" = ps: with ps; [ - anthemav - ]; - "anthropic" = ps: with ps; [ - anthropic - ha-ffmpeg - hassil - home-assistant-intents - mutagen - pymicro-vad - pyspeex-noise - ]; - "anwb_energie" = ps: with ps; [ - ]; - "aosmith" = ps: with ps; [ - py-aosmith - ]; - "apache_kafka" = ps: with ps; [ - aiokafka - ]; - "apcupsd" = ps: with ps; [ - aioapcaccess - ]; - "api" = ps: with ps; [ - ]; - "appalachianpower" = ps: with ps; [ - ]; - "apple_tv" = ps: with ps; [ - ifaddr - pyatv - zeroconf - ]; - "application_credentials" = ps: with ps; [ - ]; - "apprise" = ps: with ps; [ - apprise - ]; - "aprilaire" = ps: with ps; [ - pyaprilaire - ]; - "aprs" = ps: with ps; [ - aprslib - geopy - ]; - "aps" = ps: with ps; [ - ]; - "apsystems" = ps: with ps; [ - apsystems-ez1 - ]; - "aquacell" = ps: with ps; [ - aioaquacell - ifaddr - ]; - "aqualogic" = ps: with ps; [ - aqualogic - ]; - "aquostv" = ps: with ps; [ - sharp-aquos-rc - ]; - "aranet" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - aranet4 - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "arcam_fmj" = ps: with ps; [ - arcam-fmj - ]; - "arest" = ps: with ps; [ - ]; - "arris_tg2492lg" = ps: with ps; [ - arris-tg2492lg - ]; - "artsound" = ps: with ps; [ - ]; - "aruba" = ps: with ps; [ - pexpect - ]; - "arve" = ps: with ps; [ - asyncarve - ]; - "arwn" = ps: with ps; [ - aiohasupervisor - paho-mqtt_1 - ]; - "aseko_pool_live" = ps: with ps; [ - aioaseko - ]; - "assist_pipeline" = ps: with ps; [ - ha-ffmpeg - hassil - home-assistant-intents - mutagen - pymicro-vad - pyspeex-noise - ]; - "assist_satellite" = ps: with ps; [ - ha-ffmpeg - hassil - home-assistant-intents - mutagen - pymicro-vad - pyspeex-noise - ]; - "asuswrt" = ps: with ps; [ - aioasuswrt - pyasuswrt - ]; - "atag" = ps: with ps; [ - pyatag - ]; - "aten_pe" = ps: with ps; [ - atenpdu - ]; - "atlanticcityelectric" = ps: with ps; [ - ]; - "atome" = ps: with ps; [ - pyatome - ]; - "august" = ps: with ps; [ - yalexs - yalexs-ble - ]; - "august_ble" = ps: with ps; [ - ]; - "aurora" = ps: with ps; [ - auroranoaa - ]; - "aurora_abb_powerone" = ps: with ps; [ - aurorapy - ]; - "aussie_broadband" = ps: with ps; [ - pyaussiebb - ]; - "autarco" = ps: with ps; [ - autarco - ]; - "auth" = ps: with ps; [ - ]; - "automation" = ps: with ps; [ - ]; - "avea" = ps: with ps; [ - avea - ]; - "avion" = ps: with ps; [ - avion - ]; - "awair" = ps: with ps; [ - python-awair - ]; - "aws" = ps: with ps; [ - aiobotocore - botocore - ]; - "axis" = ps: with ps; [ - aiohasupervisor - axis - paho-mqtt_1 - ]; - "azure_data_explorer" = ps: with ps; [ - azure-kusto-data - azure-kusto-ingest - ] - ++ azure-kusto-data.optional-dependencies.aio; - "azure_devops" = ps: with ps; [ - aioazuredevops - ]; - "azure_event_hub" = ps: with ps; [ - azure-eventhub - ]; - "azure_service_bus" = ps: with ps; [ - azure-servicebus - ]; - "backup" = ps: with ps; [ - securetar - ]; - "baf" = ps: with ps; [ - aiobafi6 - ]; - "baidu" = ps: with ps; [ - ]; # missing inputs: baidu-aip - "balboa" = ps: with ps; [ - pybalboa - ]; - "bang_olufsen" = ps: with ps; [ - mozart-api - ]; - "bayesian" = ps: with ps; [ - ]; - "bbox" = ps: with ps; [ - ]; # missing inputs: pybbox - "beewi_smartclim" = ps: with ps; [ - ]; # missing inputs: beewi-smartclim - "bge" = ps: with ps; [ - ]; - "binary_sensor" = ps: with ps; [ - ]; - "bitcoin" = ps: with ps; [ - blockchain - ]; - "bizkaibus" = ps: with ps; [ - bizkaibus - ]; - "blackbird" = ps: with ps; [ - pyblackbird - ]; - "blebox" = ps: with ps; [ - blebox-uniapi - ]; - "blink" = ps: with ps; [ - blinkpy - ]; - "bliss_automation" = ps: with ps; [ - ]; - "bloc_blinds" = ps: with ps; [ - ]; - "blockchain" = ps: with ps; [ - ]; # missing inputs: python-blockchain-api - "blue_current" = ps: with ps; [ - bluecurrent-api - ]; - "bluemaestro" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluemaestro-ble - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "blueprint" = ps: with ps; [ - ]; - "bluesound" = ps: with ps; [ - ifaddr - pyblu - zeroconf - ]; - "bluetooth" = ps: with ps; [ - bleak - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - habluetooth - pyserial - pyudev - ]; - "bluetooth_adapters" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "bluetooth_le_tracker" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "bluetooth_tracker" = ps: with ps; [ - bt-proximity - pybluez - ]; - "bmw_connected_drive" = ps: with ps; [ - bimmer-connected - ] - ++ bimmer-connected.optional-dependencies.china; - "bond" = ps: with ps; [ - bond-async - ]; - "bosch_shc" = ps: with ps; [ - boschshcpy - ifaddr - zeroconf - ]; - "brandt" = ps: with ps; [ - ]; - "braviatv" = ps: with ps; [ - pybravia - ]; - "brel_home" = ps: with ps; [ - ]; - "bring" = ps: with ps; [ - bring-api - ]; - "broadlink" = ps: with ps; [ - broadlink - ]; - "brother" = ps: with ps; [ - brother - pysnmp - ]; - "brottsplatskartan" = ps: with ps; [ - brottsplatskartan - ]; - "browser" = ps: with ps; [ - ]; - "brunt" = ps: with ps; [ - brunt - ]; - "bryant_evolution" = ps: with ps; [ - evolutionhttp - ]; - "bsblan" = ps: with ps; [ - python-bsblan - ]; - "bswitch" = ps: with ps; [ - ]; - "bt_home_hub_5" = ps: with ps; [ - bthomehub5-devicelist - ]; - "bt_smarthub" = ps: with ps; [ - btsmarthub-devicelist - ]; - "bthome" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - bthome-ble - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "bticino" = ps: with ps; [ - ]; - "bubendorff" = ps: with ps; [ - ]; - "buienradar" = ps: with ps; [ - buienradar - ]; - "button" = ps: with ps; [ - ]; - "caldav" = ps: with ps; [ - caldav - ]; - "calendar" = ps: with ps; [ - ]; - "cambridge_audio" = ps: with ps; [ - aiostreammagic - ]; - "camera" = ps: with ps; [ - pyturbojpeg - ]; - "canary" = ps: with ps; [ - ha-ffmpeg - py-canary - ]; - "cast" = ps: with ps; [ - aiohasupervisor - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-intents - ifaddr - mutagen - plexapi - plexauth - plexwebsocket - pychromecast - pymicro-vad - pyspeex-noise - python-matter-server - pyturbojpeg - zeroconf - ]; - "ccm15" = ps: with ps; [ - py-ccm15 - ]; - "cert_expiry" = ps: with ps; [ - ]; - "chacon_dio" = ps: with ps; [ - dio-chacon-wifi-api - ]; - "channels" = ps: with ps; [ - pychannels - ]; - "cisco_ios" = ps: with ps; [ - pexpect - ]; - "cisco_mobility_express" = ps: with ps; [ - ciscomobilityexpress - ]; - "cisco_webex_teams" = ps: with ps; [ - webexpythonsdk - ]; - "citybikes" = ps: with ps; [ - ]; - "clementine" = ps: with ps; [ - ]; # missing inputs: python-clementine-remote - "clickatell" = ps: with ps; [ - ]; - "clicksend" = ps: with ps; [ - ]; - "clicksend_tts" = ps: with ps; [ - ]; - "climate" = ps: with ps; [ - ]; - "cloud" = ps: with ps; [ - aiohasupervisor - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-intents - mutagen - pymicro-vad - pyspeex-noise - python-matter-server - pyturbojpeg - ]; - "cloudflare" = ps: with ps; [ - pycfdns - ]; - "cmus" = ps: with ps; [ - ]; # missing inputs: pycmus - "co2signal" = ps: with ps; [ - aioelectricitymaps - ]; - "coautilities" = ps: with ps; [ - ]; - "coinbase" = ps: with ps; [ - ]; # missing inputs: coinbase coinbase-advanced-py - "color_extractor" = ps: with ps; [ - colorthief - ]; - "comed" = ps: with ps; [ - ]; - "comed_hourly_pricing" = ps: with ps; [ - ]; - "comelit" = ps: with ps; [ - aiocomelit - ]; - "comfoconnect" = ps: with ps; [ - pycomfoconnect - ]; - "command_line" = ps: with ps; [ - jsonpath - ]; - "compensation" = ps: with ps; [ - numpy_1 - ]; - "concord232" = ps: with ps; [ - ]; # missing inputs: concord232 - "coned" = ps: with ps; [ - ]; - "config" = ps: with ps; [ - ]; - "configurator" = ps: with ps; [ - ]; - "control4" = ps: with ps; [ - pycontrol4 - ]; - "conversation" = ps: with ps; [ - hassil - home-assistant-intents - ]; - "coolmaster" = ps: with ps; [ - pycoolmasternet-async - ]; - "counter" = ps: with ps; [ - ]; - "cover" = ps: with ps; [ - ]; - "cozytouch" = ps: with ps; [ - ]; - "cppm_tracker" = ps: with ps; [ - ]; # missing inputs: clearpasspy - "cpuspeed" = ps: with ps; [ - py-cpuinfo - ]; - "cribl" = ps: with ps; [ - ]; - "crownstone" = ps: with ps; [ - crownstone-cloud - crownstone-sse - crownstone-uart - pyserial - pyudev - ]; - "cups" = ps: with ps; [ - pycups - ]; - "currencylayer" = ps: with ps; [ - ]; - "dacia" = ps: with ps; [ - ]; - "daikin" = ps: with ps; [ - pydaikin - ]; - "danfoss_air" = ps: with ps; [ - pydanfossair - ]; - "datadog" = ps: with ps; [ - datadog - ]; - "date" = ps: with ps; [ - ]; - "datetime" = ps: with ps; [ - ]; - "ddwrt" = ps: with ps; [ - ]; - "deako" = ps: with ps; [ - ifaddr - pydeako - zeroconf - ]; - "debugpy" = ps: with ps; [ - debugpy - ]; - "deconz" = ps: with ps; [ - pydeconz - ]; - "decora" = ps: with ps; [ - bluepy - ]; # missing inputs: decora - "decora_wifi" = ps: with ps; [ - ]; # missing inputs: decora-wifi - "default_config" = ps: with ps; [ - aiodhcpwatcher - aiodiscover - aiohasupervisor - async-upnp-client - av - bleak - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - cached-ipaddress - dbus-fast - fnv-hash-fast - go2rtc-client - ha-ffmpeg - habluetooth - hass-nabucasa - hassil - home-assistant-frontend - home-assistant-intents - ifaddr - mutagen - numpy_1 - pillow - psutil-home-assistant - pymicro-vad - pynacl - pyserial - pyspeex-noise - python-matter-server - pyturbojpeg - pyudev - securetar - sqlalchemy - zeroconf - ]; - "delijn" = ps: with ps; [ - pydelijn - ]; - "delmarva" = ps: with ps; [ - ]; - "deluge" = ps: with ps; [ - deluge-client - ]; - "demo" = ps: with ps; [ - hassil - home-assistant-intents - ]; - "denon" = ps: with ps; [ - ]; - "denonavr" = ps: with ps; [ - denonavr - ]; - "derivative" = ps: with ps; [ - ]; - "devialet" = ps: with ps; [ - devialet - ifaddr - zeroconf - ]; - "device_automation" = ps: with ps; [ - ]; - "device_sun_light_trigger" = ps: with ps; [ - pillow - ]; - "device_tracker" = ps: with ps; [ - ]; - "devolo_home_control" = ps: with ps; [ - devolo-home-control-api - ifaddr - zeroconf - ]; - "devolo_home_network" = ps: with ps; [ - devolo-plc-api - ]; - "dexcom" = ps: with ps; [ - pydexcom - ]; - "dhcp" = ps: with ps; [ - aiodhcpwatcher - aiodiscover - cached-ipaddress - ]; - "diagnostics" = ps: with ps; [ - ]; - "dialogflow" = ps: with ps; [ - ]; - "diaz" = ps: with ps; [ - ]; - "digital_loggers" = ps: with ps; [ - ]; - "digital_ocean" = ps: with ps; [ - python-digitalocean - ]; - "directv" = ps: with ps; [ - directv - ]; - "discogs" = ps: with ps; [ - discogs-client - ]; - "discord" = ps: with ps; [ - nextcord - ]; - "discovergy" = ps: with ps; [ - pydiscovergy - ]; - "dlib_face_detect" = ps: with ps; [ - face-recognition - ]; - "dlib_face_identify" = ps: with ps; [ - face-recognition - ]; - "dlink" = ps: with ps; [ - ]; # missing inputs: pyW215 - "dlna_dmr" = ps: with ps; [ - async-upnp-client - getmac - ifaddr - ]; - "dlna_dms" = ps: with ps; [ - async-upnp-client - ifaddr - ]; - "dnsip" = ps: with ps; [ - aiodns - ]; - "dominos" = ps: with ps; [ - ]; # missing inputs: pizzapi - "doods" = ps: with ps; [ - pillow - pydoods - ]; - "doorbird" = ps: with ps; [ - doorbirdpy - ]; - "dooya" = ps: with ps; [ - ]; - "dormakaba_dkey" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - py-dormakaba-dkey - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "downloader" = ps: with ps; [ - ]; - "dremel_3d_printer" = ps: with ps; [ - dremel3dpy - ]; - "drop_connect" = ps: with ps; [ - aiohasupervisor - dropmqttapi - paho-mqtt_1 - ]; - "dsmr" = ps: with ps; [ - dsmr-parser - ]; - "dsmr_reader" = ps: with ps; [ - aiohasupervisor - paho-mqtt_1 - ]; - "dte_energy_bridge" = ps: with ps; [ - ]; - "dublin_bus_transport" = ps: with ps; [ - ]; - "duckdns" = ps: with ps; [ - ]; - "duke_energy" = ps: with ps; [ - aiodukeenergy - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; - "dunehd" = ps: with ps; [ - pdunehd - ]; - "duotecno" = ps: with ps; [ - pyduotecno - ]; - "duquesne_light" = ps: with ps; [ - ]; - "dwd_weather_warnings" = ps: with ps; [ - dwdwfsapi - ]; - "dweet" = ps: with ps; [ - ]; # missing inputs: dweepy - "dynalite" = ps: with ps; [ - aiohasupervisor - dynalite-devices - dynalite-panel - home-assistant-frontend - pillow - ]; - "eafm" = ps: with ps; [ - aioeafm - ]; - "eastron" = ps: with ps; [ - ]; - "easyenergy" = ps: with ps; [ - easyenergy - ]; - "ebox" = ps: with ps; [ - ]; # missing inputs: pyebox - "ebusd" = ps: with ps; [ - ]; # missing inputs: ebusdpy - "ecoal_boiler" = ps: with ps; [ - ecoaliface - ]; - "ecobee" = ps: with ps; [ - python-ecobee-api - ]; - "ecoforest" = ps: with ps; [ - pyecoforest - ]; - "econet" = ps: with ps; [ - pyeconet - ]; - "ecovacs" = ps: with ps; [ - deebot-client - py-sucks - ]; - "ecowitt" = ps: with ps; [ - aioecowitt - ]; - "eddystone_temperature" = ps: with ps; [ - ]; # missing inputs: beacontools - "edimax" = ps: with ps; [ - pyedimax - ]; - "edl21" = ps: with ps; [ - pysml - ]; - "efergy" = ps: with ps; [ - pyefergy - ]; - "egardia" = ps: with ps; [ - pythonegardia - ]; - "eight_sleep" = ps: with ps; [ - ]; - "electrasmart" = ps: with ps; [ - pyelectra - ]; - "electric_kiwi" = ps: with ps; [ - ]; # missing inputs: electrickiwi-api - "elevenlabs" = ps: with ps; [ - elevenlabs - ]; - "elgato" = ps: with ps; [ - elgato - ]; - "eliqonline" = ps: with ps; [ - eliqonline - ]; - "elkm1" = ps: with ps; [ - elkm1-lib - ifaddr - ]; - "elmax" = ps: with ps; [ - elmax-api - ]; - "elv" = ps: with ps; [ - pypca - ]; - "elvia" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; # missing inputs: elvia - "emby" = ps: with ps; [ - pyemby - ]; - "emoncms" = ps: with ps; [ - pyemoncms - ]; - "emoncms_history" = ps: with ps; [ - ]; - "emonitor" = ps: with ps; [ - aioemonitor - ]; - "emulated_hue" = ps: with ps; [ - ifaddr - ]; - "emulated_kasa" = ps: with ps; [ - sense-energy - ]; - "emulated_roku" = ps: with ps; [ - emulated-roku - ifaddr - ]; - "energenie_power_sockets" = ps: with ps; [ - pyegps - ]; - "energie_vanons" = ps: with ps; [ - ]; - "energy" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; - "energyzero" = ps: with ps; [ - energyzero - ]; - "enigma2" = ps: with ps; [ - openwebifpy - ]; - "enmax" = ps: with ps; [ - ]; - "enocean" = ps: with ps; [ - enocean - ]; - "enphase_envoy" = ps: with ps; [ - pyenphase - ]; - "entur_public_transport" = ps: with ps; [ - enturclient - ]; - "environment_canada" = ps: with ps; [ - env-canada - ]; - "envisalink" = ps: with ps; [ - pyenvisalink - ]; - "ephember" = ps: with ps; [ - pyephember - ]; - "epic_games_store" = ps: with ps; [ - epicstore-api - ]; - "epion" = ps: with ps; [ - epion - ]; - "epson" = ps: with ps; [ - epson-projector - ]; - "eq3btsmart" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - eq3btsmart - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "escea" = ps: with ps; [ - pescea - ]; - "esera_onewire" = ps: with ps; [ - ]; - "esphome" = ps: with ps; [ - aioesphomeapi - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "etherscan" = ps: with ps; [ - ]; # missing inputs: python-etherscan-api - "eufy" = ps: with ps; [ - lakeside - ]; - "eufylife_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - eufylife-ble-client - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "event" = ps: with ps; [ - ]; - "evergy" = ps: with ps; [ - ]; - "everlights" = ps: with ps; [ - pyeverlights - ]; - "evil_genius_labs" = ps: with ps; [ - pyevilgenius - ]; - "evohome" = ps: with ps; [ - evohome-async - ]; - "ezviz" = ps: with ps; [ - ha-ffmpeg - pyezviz - ]; - "faa_delays" = ps: with ps; [ - faadelays - ]; - "facebook" = ps: with ps; [ - ]; - "fail2ban" = ps: with ps; [ - ]; - "familyhub" = ps: with ps; [ - python-family-hub-local - ]; - "fan" = ps: with ps; [ - ]; - "fastdotcom" = ps: with ps; [ - ]; # missing inputs: fastdotcom - "feedreader" = ps: with ps; [ - feedparser - ]; - "ffmpeg" = ps: with ps; [ - ha-ffmpeg - ]; - "ffmpeg_motion" = ps: with ps; [ - ha-ffmpeg - ]; - "ffmpeg_noise" = ps: with ps; [ - ha-ffmpeg - ]; - "fibaro" = ps: with ps; [ - pyfibaro - ]; - "fido" = ps: with ps; [ - pyfido - ]; - "file" = ps: with ps; [ - file-read-backwards - ]; - "file_upload" = ps: with ps; [ - ]; - "filesize" = ps: with ps; [ - ]; - "filter" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; - "fints" = ps: with ps; [ - fints - ]; - "fire_tv" = ps: with ps; [ - ]; - "fireservicerota" = ps: with ps; [ - pyfireservicerota - ]; - "firmata" = ps: with ps; [ - pymata-express - ]; - "fitbit" = ps: with ps; [ - fitbit - ]; - "fivem" = ps: with ps; [ - fivem-api - ]; - "fixer" = ps: with ps; [ - fixerio - ]; - "fjaraskupan" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - fjaraskupan - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "fleetgo" = ps: with ps; [ - ritassist - ]; - "flexit" = ps: with ps; [ - pymodbus - ]; - "flexit_bacnet" = ps: with ps; [ - flexit-bacnet - ]; - "flexom" = ps: with ps; [ - ]; - "flic" = ps: with ps; [ - pyflic - ]; - "flick_electric" = ps: with ps; [ - pyflick - ]; - "flipr" = ps: with ps; [ - flipr-api - ]; - "flo" = ps: with ps; [ - aioflo - ]; - "flock" = ps: with ps; [ - ]; - "flume" = ps: with ps; [ - pyflume - ]; - "flux" = ps: with ps; [ - ]; - "flux_led" = ps: with ps; [ - flux-led - ifaddr - ]; - "folder" = ps: with ps; [ - ]; - "folder_watcher" = ps: with ps; [ - watchdog - ]; - "foobot" = ps: with ps; [ - foobot-async - ]; - "forecast_solar" = ps: with ps; [ - forecast-solar - ]; - "forked_daapd" = ps: with ps; [ - spotifyaio - ]; # missing inputs: pyforked-daapd pylibrespot-java - "fortios" = ps: with ps; [ - fortiosapi - ]; - "foscam" = ps: with ps; [ - libpyfoscam - ]; - "foursquare" = ps: with ps; [ - ]; - "free_mobile" = ps: with ps; [ - ]; # missing inputs: freesms - "freebox" = ps: with ps; [ - freebox-api - ha-ffmpeg - ]; - "freedns" = ps: with ps; [ - ]; - "freedompro" = ps: with ps; [ - pyfreedompro - ]; - "fritz" = ps: with ps; [ - fritzconnection - ifaddr - xmltodict - ] - ++ fritzconnection.optional-dependencies.qr; - "fritzbox" = ps: with ps; [ - pyfritzhome - ]; - "fritzbox_callmonitor" = ps: with ps; [ - fritzconnection - ] - ++ fritzconnection.optional-dependencies.qr; - "fronius" = ps: with ps; [ - pyfronius - ]; - "frontend" = ps: with ps; [ - aiohasupervisor - home-assistant-frontend - pillow - ]; - "frontier_silicon" = ps: with ps; [ - afsapi - ]; - "fujitsu_anywair" = ps: with ps; [ - ]; - "fujitsu_fglair" = ps: with ps; [ - ayla-iot-unofficial - ]; - "fully_kiosk" = ps: with ps; [ - aiohasupervisor - paho-mqtt_1 - python-fullykiosk - ]; - "futurenow" = ps: with ps; [ - pyfnip - ]; - "fyta" = ps: with ps; [ - fyta-cli - ]; - "garadget" = ps: with ps; [ - ]; - "garages_amsterdam" = ps: with ps; [ - odp-amsterdam - ]; - "gardena_bluetooth" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - gardena-bluetooth - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "gaviota" = ps: with ps; [ - ]; - "gc100" = ps: with ps; [ - ]; # missing inputs: python-gc100 - "gdacs" = ps: with ps; [ - aio-georss-gdacs - ]; - "generic" = ps: with ps; [ - av - pillow - ]; - "generic_hygrostat" = ps: with ps; [ - ]; - "generic_thermostat" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; - "geniushub" = ps: with ps; [ - geniushub-client - ]; - "geo_json_events" = ps: with ps; [ - aio-geojson-generic-client - ]; - "geo_location" = ps: with ps; [ - ]; - "geo_rss_events" = ps: with ps; [ - georss-generic-client - ]; - "geocaching" = ps: with ps; [ - geocachingapi - ]; - "geofency" = ps: with ps; [ - ]; - "geonetnz_quakes" = ps: with ps; [ - aio-geojson-geonetnz-quakes - ]; - "geonetnz_volcano" = ps: with ps; [ - aio-geojson-geonetnz-volcano - ]; - "gios" = ps: with ps; [ - gios - ]; - "github" = ps: with ps; [ - aiogithubapi - ]; - "gitlab_ci" = ps: with ps; [ - python-gitlab - ]; - "gitter" = ps: with ps; [ - ]; # missing inputs: gitterpy - "glances" = ps: with ps; [ - glances-api - ]; - "go2rtc" = ps: with ps; [ - go2rtc-client - pyturbojpeg - ]; - "goalzero" = ps: with ps; [ - goalzero - ]; - "gogogate2" = ps: with ps; [ - ismartgate - ]; - "goodwe" = ps: with ps; [ - goodwe - ]; - "google" = ps: with ps; [ - gcal-sync - ical - oauth2client - ]; - "google_assistant" = ps: with ps; [ - aiohasupervisor - python-matter-server - pyturbojpeg - ]; - "google_assistant_sdk" = ps: with ps; [ - gassist-text - ]; - "google_cloud" = ps: with ps; [ - google-cloud-speech - google-cloud-texttospeech - ]; - "google_generative_ai_conversation" = ps: with ps; [ - google-generativeai - ha-ffmpeg - hassil - home-assistant-intents - mutagen - pymicro-vad - pyspeex-noise - ]; - "google_mail" = ps: with ps; [ - google-api-python-client - ]; - "google_maps" = ps: with ps; [ - locationsharinglib - ]; - "google_photos" = ps: with ps; [ - google-photos-library-api - ]; - "google_pubsub" = ps: with ps; [ - google-cloud-pubsub - ]; - "google_sheets" = ps: with ps; [ - gspread - ]; - "google_tasks" = ps: with ps; [ - google-api-python-client - ]; - "google_translate" = ps: with ps; [ - gtts - ]; - "google_travel_time" = ps: with ps; [ - googlemaps - ]; - "google_wifi" = ps: with ps; [ - ]; - "govee_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - govee-ble - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "govee_light_local" = ps: with ps; [ - govee-local-api - ifaddr - ]; - "gpsd" = ps: with ps; [ - gps3 - ]; - "gpslogger" = ps: with ps; [ - ]; - "graphite" = ps: with ps; [ - ]; - "gree" = ps: with ps; [ - greeclimate - ifaddr - ]; - "greeneye_monitor" = ps: with ps; [ - greeneye-monitor - ]; - "greenwave" = ps: with ps; [ - ]; # missing inputs: greenwavereality - "group" = ps: with ps; [ - ]; - "growatt_server" = ps: with ps; [ - growattserver - ]; - "gstreamer" = ps: with ps; [ - ]; # missing inputs: gstreamer-player - "gtfs" = ps: with ps; [ - pygtfs - ]; - "guardian" = ps: with ps; [ - aioguardian - ]; - "habitica" = ps: with ps; [ - habitipy - ]; - "hardkernel" = ps: with ps; [ - aiohasupervisor - psutil-home-assistant - ]; - "hardware" = ps: with ps; [ - psutil-home-assistant - ]; - "harman_kardon_avr" = ps: with ps; [ - hkavr - ]; - "harmony" = ps: with ps; [ - aioharmony - ]; - "hassio" = ps: with ps; [ - aiohasupervisor - ]; - "havana_shade" = ps: with ps; [ - ]; - "haveibeenpwned" = ps: with ps; [ - ]; - "hddtemp" = ps: with ps; [ - ]; - "hdmi_cec" = ps: with ps; [ - pycec - ]; - "heatmiser" = ps: with ps; [ - heatmiserv3 - ]; - "heiwa" = ps: with ps; [ - ]; - "heos" = ps: with ps; [ - pyheos - ]; - "here_travel_time" = ps: with ps; [ - here-routing - here-transit - ]; - "hexaom" = ps: with ps; [ - ]; - "hi_kumo" = ps: with ps; [ - ]; - "hikvision" = ps: with ps; [ - ]; # missing inputs: pyHik - "hikvisioncam" = ps: with ps; [ - hikvision - ]; - "hisense_aehw4a1" = ps: with ps; [ - pyaehw4a1 - ]; - "history" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; - "history_stats" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; - "hitron_coda" = ps: with ps; [ - ]; - "hive" = ps: with ps; [ - pyhiveapi - ]; - "hko" = ps: with ps; [ - ]; # missing inputs: hko - "hlk_sw16" = ps: with ps; [ - hlk-sw16 - ]; - "holiday" = ps: with ps; [ - babel - holidays - ]; - "home_connect" = ps: with ps; [ - homeconnect - ]; - "home_plus_control" = ps: with ps; [ - ]; - "homeassistant" = ps: with ps; [ - ]; - "homeassistant_alerts" = ps: with ps; [ - aiohasupervisor - ]; - "homeassistant_green" = ps: with ps; [ - aiohasupervisor - pillow - psutil-home-assistant - pyserial - pyudev - universal-silabs-flasher - zha - ]; - "homeassistant_hardware" = ps: with ps; [ - aiohasupervisor - pillow - pyserial - pyudev - universal-silabs-flasher - zha - ]; - "homeassistant_sky_connect" = ps: with ps; [ - aiohasupervisor - pillow - psutil-home-assistant - pyserial - pyudev - universal-silabs-flasher - zha - ]; - "homeassistant_yellow" = ps: with ps; [ - aiohasupervisor - pillow - psutil-home-assistant - pyserial - pyudev - universal-silabs-flasher - zha - ]; - "homekit" = ps: with ps; [ - base36 - fnv-hash-fast - ha-ffmpeg - hap-python - ifaddr - pyqrcode - pyturbojpeg - zeroconf - ]; - "homekit_controller" = ps: with ps; [ - aioesphomeapi - aiohomekit - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyroute2 - pyserial - pyspeex-noise - python-otbr-api - pyudev - zeroconf - ]; - "homematic" = ps: with ps; [ - pyhomematic - ]; - "homematicip_cloud" = ps: with ps; [ - homematicip - ]; - "homewizard" = ps: with ps; [ - python-homewizard-energy - ]; - "homeworks" = ps: with ps; [ - pyhomeworks - ]; - "honeywell" = ps: with ps; [ - aiosomecomfort - ]; - "horizon" = ps: with ps; [ - ]; # missing inputs: horimote - "hp_ilo" = ps: with ps; [ - python-hpilo - ]; - "html5" = ps: with ps; [ - pywebpush - ]; - "http" = ps: with ps; [ - ]; - "huawei_lte" = ps: with ps; [ - huawei-lte-api - stringcase - url-normalize - ]; - "hue" = ps: with ps; [ - aiohue - ]; - "huisbaasje" = ps: with ps; [ - energyflip-client - ]; - "humidifier" = ps: with ps; [ - ]; - "hunterdouglas_powerview" = ps: with ps; [ - aiopvapi - ]; - "hurrican_shutters_wholesale" = ps: with ps; [ - ]; - "husqvarna_automower" = ps: with ps; [ - aioautomower - ]; - "husqvarna_automower_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - automower-ble - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "huum" = ps: with ps; [ - huum - ]; - "hvv_departures" = ps: with ps; [ - pygti - ]; - "hydrawise" = ps: with ps; [ - pydrawise - ]; - "hyperion" = ps: with ps; [ - hyperion-py - ]; - "ialarm" = ps: with ps; [ - pyialarm - ]; - "iammeter" = ps: with ps; [ - iammeter - ]; - "iaqualink" = ps: with ps; [ - h2 - iaqualink - ]; - "ibeacon" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ibeacon-ble - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "icloud" = ps: with ps; [ - pyicloud - ]; - "idasen_desk" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - idasen-ha - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "idteck_prox" = ps: with ps; [ - ]; # missing inputs: rfk101py - "ifttt" = ps: with ps; [ - pyfttt - ]; - "iglo" = ps: with ps; [ - ]; # missing inputs: iglo - "ign_sismologia" = ps: with ps; [ - georss-ign-sismologia-client - ]; - "ihc" = ps: with ps; [ - defusedxml - ihcsdk - ]; - "image" = ps: with ps; [ - ]; - "image_processing" = ps: with ps; [ - pyturbojpeg - ]; - "image_upload" = ps: with ps; [ - pillow - ]; - "imap" = ps: with ps; [ - aioimaplib - ]; - "imgw_pib" = ps: with ps; [ - imgw-pib - ]; - "improv_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - py-improv-ble-client - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "incomfort" = ps: with ps; [ - incomfort-client - ]; - "indianamichiganpower" = ps: with ps; [ - ]; - "influxdb" = ps: with ps; [ - influxdb - influxdb-client - ]; - "inkbird" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - inkbird-ble - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "input_boolean" = ps: with ps; [ - ]; - "input_button" = ps: with ps; [ - ]; - "input_datetime" = ps: with ps; [ - ]; - "input_number" = ps: with ps; [ - ]; - "input_select" = ps: with ps; [ - ]; - "input_text" = ps: with ps; [ - ]; - "inspired_shades" = ps: with ps; [ - ]; - "insteon" = ps: with ps; [ - aiohasupervisor - home-assistant-frontend - insteon-frontend-home-assistant - pillow - pyinsteon - pyserial - pyudev - ]; - "integration" = ps: with ps; [ - ]; - "intellifire" = ps: with ps; [ - intellifire4py - ]; - "intent" = ps: with ps; [ - ]; - "intent_script" = ps: with ps; [ - ]; - "intesishome" = ps: with ps; [ - pyintesishome - ]; - "ios" = ps: with ps; [ - ifaddr - zeroconf - ]; - "iotawatt" = ps: with ps; [ - ]; # missing inputs: ha-iotawattpy - "iotty" = ps: with ps; [ - iottycloud - ]; - "iperf3" = ps: with ps; [ - ]; # missing inputs: iperf3 - "ipma" = ps: with ps; [ - pyipma - ]; - "ipp" = ps: with ps; [ - pyipp - ]; - "iqvia" = ps: with ps; [ - numpy_1 - pyiqvia - ]; - "irish_rail_transport" = ps: with ps; [ - ]; # missing inputs: pyirishrail - "iron_os" = ps: with ps; [ - aioesphomeapi - aiogithubapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pynecil - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "isal" = ps: with ps; [ - isal - ]; - "iskra" = ps: with ps; [ - pyiskra - ]; - "islamic_prayer_times" = ps: with ps; [ - prayer-times-calculator-offline - ]; - "ismartwindow" = ps: with ps; [ - ]; - "israel_rail" = ps: with ps; [ - israel-rail-api - ]; - "iss" = ps: with ps; [ - ]; # missing inputs: pyiss - "ista_ecotrend" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - pyecotrend-ista - sqlalchemy - ]; - "isy994" = ps: with ps; [ - pyisy - ]; - "itach" = ps: with ps; [ - ]; # missing inputs: pyitachip2ir - "itunes" = ps: with ps; [ - ]; - "izone" = ps: with ps; [ - python-izone - ]; - "jellyfin" = ps: with ps; [ - jellyfin-apiclient-python - ]; - "jewish_calendar" = ps: with ps; [ - hdate - ]; - "joaoapps_join" = ps: with ps; [ - ]; # missing inputs: python-join-api - "juicenet" = ps: with ps; [ - python-juicenet - ]; - "justnimbus" = ps: with ps; [ - justnimbus - ]; - "jvc_projector" = ps: with ps; [ - ]; # missing inputs: pyjvcprojector - "kaiterra" = ps: with ps; [ - ]; # missing inputs: kaiterra-async-client - "kaleidescape" = ps: with ps; [ - pykaleidescape - ]; - "kankun" = ps: with ps; [ - ]; - "keba" = ps: with ps; [ - keba-kecontact - ]; - "keenetic_ndms2" = ps: with ps; [ - ndms2-client - ]; - "kef" = ps: with ps; [ - aiokef - getmac - ]; - "kegtron" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - kegtron-ble - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "kentuckypower" = ps: with ps; [ - ]; - "keyboard" = ps: with ps; [ - ]; # missing inputs: pyuserinput - "keyboard_remote" = ps: with ps; [ - asyncinotify - evdev - ]; - "keymitt_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pymicrobot - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "kira" = ps: with ps; [ - pykira - ]; - "kitchen_sink" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; - "kiwi" = ps: with ps; [ - kiwiki-client - ]; - "kmtronic" = ps: with ps; [ - pykmtronic - ]; - "knocki" = ps: with ps; [ - knocki - ]; - "knx" = ps: with ps; [ - aiohasupervisor - home-assistant-frontend - knx-frontend - pillow - xknx - xknxproject - ]; - "kodi" = ps: with ps; [ - pykodi - ]; - "konnected" = ps: with ps; [ - konnected - ]; - "kostal_plenticore" = ps: with ps; [ - pykoplenti - ]; - "kraken" = ps: with ps; [ - krakenex - pykrakenapi - ]; - "krispol" = ps: with ps; [ - ]; - "kulersky" = ps: with ps; [ - pykulersky - ]; - "kwb" = ps: with ps; [ - pykwb - ]; - "lacrosse" = ps: with ps; [ - pylacrosse - ]; - "lacrosse_view" = ps: with ps; [ - ]; # missing inputs: lacrosse-view - "lamarzocco" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; # missing inputs: lmcloud - "lametric" = ps: with ps; [ - demetriek - ]; - "landisgyr_heat_meter" = ps: with ps; [ - pyserial - pyudev - ultraheat-api - ]; - "lannouncer" = ps: with ps; [ - ]; - "lastfm" = ps: with ps; [ - pylast - ]; - "launch_library" = ps: with ps; [ - pylaunches - ]; - "laundrify" = ps: with ps; [ - laundrify-aio - ]; - "lawn_mower" = ps: with ps; [ - ]; - "lcn" = ps: with ps; [ - aiohasupervisor - home-assistant-frontend - lcn-frontend - pillow - pypck - ]; - "ld2410_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - ld2410-ble - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "leaone" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - leaone-ble - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "led_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - led-ble - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "legrand" = ps: with ps; [ - ]; - "lektrico" = ps: with ps; [ - lektricowifi - ]; - "lg_netcast" = ps: with ps; [ - ifaddr - pylgnetcast - ]; - "lg_soundbar" = ps: with ps; [ - temescal - ]; - "lg_thinq" = ps: with ps; [ - thinqconnect - ]; - "lidarr" = ps: with ps; [ - aiopyarr - ]; - "life360" = ps: with ps; [ - ]; - "lifx" = ps: with ps; [ - aiolifx - aiolifx-effects - aiolifx-themes - ifaddr - ]; - "lifx_cloud" = ps: with ps; [ - ]; - "light" = ps: with ps; [ - ]; - "lightwave" = ps: with ps; [ - lightwave - ]; - "limitlessled" = ps: with ps; [ - limitlessled - ]; - "linear_garage_door" = ps: with ps; [ - linear-garage-door - ]; - "linkplay" = ps: with ps; [ - python-linkplay - ]; - "linksys_smart" = ps: with ps; [ - ]; - "linode" = ps: with ps; [ - linode-api - ]; - "linux_battery" = ps: with ps; [ - batinfo - ]; - "lirc" = ps: with ps; [ - ]; # missing inputs: python-lirc - "litejet" = ps: with ps; [ - pylitejet - ]; - "litterrobot" = ps: with ps; [ - pylitterbot - ]; - "livisi" = ps: with ps; [ - aiolivisi - ]; - "llamalab_automate" = ps: with ps; [ - ]; - "local_calendar" = ps: with ps; [ - ical - ]; - "local_file" = ps: with ps; [ - ]; - "local_ip" = ps: with ps; [ - ifaddr - ]; - "local_todo" = ps: with ps; [ - ical - ]; - "locative" = ps: with ps; [ - ]; - "lock" = ps: with ps; [ - ]; - "logbook" = ps: with ps; [ - aiohasupervisor - fnv-hash-fast - home-assistant-frontend - pillow - psutil-home-assistant - sqlalchemy - ]; - "logentries" = ps: with ps; [ - ]; - "logger" = ps: with ps; [ - ]; - "london_air" = ps: with ps; [ - ]; - "london_underground" = ps: with ps; [ - ]; # missing inputs: london-tube-status - "lookin" = ps: with ps; [ - aiolookin - ]; - "loqed" = ps: with ps; [ - aiohasupervisor - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-intents - loqedapi - mutagen - pymicro-vad - pyspeex-noise - python-matter-server - pyturbojpeg - ]; - "lovelace" = ps: with ps; [ - aiohasupervisor - pillow - ]; - "luci" = ps: with ps; [ - openwrt-luci-rpc - ]; - "luftdaten" = ps: with ps; [ - luftdaten - ]; - "lupusec" = ps: with ps; [ - lupupy - ]; - "lutron" = ps: with ps; [ - pylutron - ]; - "lutron_caseta" = ps: with ps; [ - pylutron-caseta - ]; - "luxaflex" = ps: with ps; [ - ]; - "lw12wifi" = ps: with ps; [ - ]; # missing inputs: lw12 - "lyric" = ps: with ps; [ - aiolyric - ]; - "madeco" = ps: with ps; [ - ]; - "madvr" = ps: with ps; [ - py-madvr2 - ]; - "mailgun" = ps: with ps; [ - pymailgunner - ]; - "manual" = ps: with ps; [ - ]; - "manual_mqtt" = ps: with ps; [ - aiohasupervisor - paho-mqtt_1 - ]; - "marantz" = ps: with ps; [ - ]; - "martec" = ps: with ps; [ - ]; - "marytts" = ps: with ps; [ - ]; # missing inputs: speak2mary - "mastodon" = ps: with ps; [ - mastodon-py - ]; - "matrix" = ps: with ps; [ - matrix-nio - pillow - ]; - "matter" = ps: with ps; [ - aiohasupervisor - python-matter-server - ]; - "maxcube" = ps: with ps; [ - maxcube-api - ]; - "mazda" = ps: with ps; [ - ]; - "mealie" = ps: with ps; [ - aiomealie - ]; - "meater" = ps: with ps; [ - meater-python - ]; - "medcom_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; # missing inputs: medcom-ble - "media_extractor" = ps: with ps; [ - yt-dlp - ] - ++ yt-dlp.optional-dependencies.default; - "media_player" = ps: with ps; [ - ]; - "media_source" = ps: with ps; [ - ]; - "mediaroom" = ps: with ps; [ - pymediaroom - ]; - "melcloud" = ps: with ps; [ - pymelcloud - ]; - "melissa" = ps: with ps; [ - ]; # missing inputs: py-melissa-climate - "melnor" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - melnor-bluetooth - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "meraki" = ps: with ps; [ - ]; - "mercury_nz" = ps: with ps; [ - ]; - "message_bird" = ps: with ps; [ - messagebird - ]; - "met" = ps: with ps; [ - pymetno - ]; - "met_eireann" = ps: with ps; [ - pymeteireann - ]; - "meteo_france" = ps: with ps; [ - meteofrance-api - ]; - "meteoalarm" = ps: with ps; [ - meteoalertapi - ]; - "meteoclimatic" = ps: with ps; [ - pymeteoclimatic - ]; - "metoffice" = ps: with ps; [ - datapoint - ]; - "mfi" = ps: with ps; [ - ]; # missing inputs: mficlient - "microbees" = ps: with ps; [ - ]; # missing inputs: microBeesPy - "microsoft" = ps: with ps; [ - ]; # missing inputs: pycsspeechtts - "microsoft_face" = ps: with ps; [ - pyturbojpeg - ]; - "microsoft_face_detect" = ps: with ps; [ - pyturbojpeg - ]; - "microsoft_face_identify" = ps: with ps; [ - pyturbojpeg - ]; - "mijndomein_energie" = ps: with ps; [ - ]; - "mikrotik" = ps: with ps; [ - librouteros - ]; - "mill" = ps: with ps; [ - mill-local - millheater - ]; - "min_max" = ps: with ps; [ - ]; - "minecraft_server" = ps: with ps; [ - mcstatus - ]; - "mini_connected" = ps: with ps; [ - ]; - "minio" = ps: with ps; [ - minio - ]; - "mjpeg" = ps: with ps; [ - ]; - "moat" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - moat-ble - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "mobile_app" = ps: with ps; [ - aiohasupervisor - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-intents - mutagen - pillow - pymicro-vad - pynacl - pyspeex-noise - python-matter-server - pyturbojpeg - ]; - "mochad" = ps: with ps; [ - ]; # missing inputs: pymochad - "modbus" = ps: with ps; [ - pymodbus - ]; - "modem_callerid" = ps: with ps; [ - phone-modem - pyserial - pyudev - ]; - "modern_forms" = ps: with ps; [ - aiomodernforms - ]; - "moehlenhoff_alpha2" = ps: with ps; [ - ]; # missing inputs: moehlenhoff-alpha2 - "mold_indicator" = ps: with ps; [ - ]; - "monarch_money" = ps: with ps; [ - ]; # missing inputs: typedmonarchmoney - "monessen" = ps: with ps; [ - ]; - "monoprice" = ps: with ps; [ - ]; # missing inputs: pymonoprice - "monzo" = ps: with ps; [ - monzopy - ]; - "moon" = ps: with ps; [ - ]; - "mopeka" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mopeka-iot-ble - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "motion_blinds" = ps: with ps; [ - ifaddr - motionblinds - ]; - "motionblinds_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - motionblindsble - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "motioneye" = ps: with ps; [ - motioneye-client - ]; - "motionmount" = ps: with ps; [ - python-motionmount - ]; - "mpd" = ps: with ps; [ - mpd2 - ]; - "mqtt" = ps: with ps; [ - aiohasupervisor - paho-mqtt_1 - ]; - "mqtt_eventstream" = ps: with ps; [ - aiohasupervisor - paho-mqtt_1 - ]; - "mqtt_json" = ps: with ps; [ - aiohasupervisor - paho-mqtt_1 - ]; - "mqtt_room" = ps: with ps; [ - aiohasupervisor - paho-mqtt_1 - ]; - "mqtt_statestream" = ps: with ps; [ - aiohasupervisor - paho-mqtt_1 - ]; - "msteams" = ps: with ps; [ - pymsteams - ]; - "mullvad" = ps: with ps; [ - mullvad-api - ]; - "mutesync" = ps: with ps; [ - mutesync - ]; - "my" = ps: with ps; [ - aiohasupervisor - home-assistant-frontend - pillow - ]; - "myq" = ps: with ps; [ - ]; - "mysensors" = ps: with ps; [ - aiohasupervisor - paho-mqtt_1 - pymysensors - ]; - "mystrom" = ps: with ps; [ - python-mystrom - ]; - "mythicbeastsdns" = ps: with ps; [ - mbddns - ]; - "myuplink" = ps: with ps; [ - myuplink - ]; - "nad" = ps: with ps; [ - nad-receiver - ]; - "nam" = ps: with ps; [ - nettigo-air-monitor - ]; - "namecheapdns" = ps: with ps; [ - defusedxml - ]; - "nanoleaf" = ps: with ps; [ - aionanoleaf - ]; - "neato" = ps: with ps; [ - pybotvac - ]; - "nederlandse_spoorwegen" = ps: with ps; [ - nsapi - ]; - "ness_alarm" = ps: with ps; [ - nessclient - ]; - "nest" = ps: with ps; [ - google-nest-sdm - ha-ffmpeg - ]; - "netatmo" = ps: with ps; [ - aiohasupervisor - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-intents - mutagen - pyatmo - pymicro-vad - pyspeex-noise - python-matter-server - pyturbojpeg - ]; - "netdata" = ps: with ps; [ - netdata - ]; - "netgear" = ps: with ps; [ - pynetgear - ]; - "netgear_lte" = ps: with ps; [ - eternalegypt - ]; - "netio" = ps: with ps; [ - ]; # missing inputs: pynetio - "network" = ps: with ps; [ - ifaddr - ]; - "neurio_energy" = ps: with ps; [ - ]; # missing inputs: neurio - "nexia" = ps: with ps; [ - nexia - ]; - "nexity" = ps: with ps; [ - ]; - "nextbus" = ps: with ps; [ - py-nextbusnext - ]; - "nextcloud" = ps: with ps; [ - nextcloudmonitor - ]; - "nextdns" = ps: with ps; [ - nextdns - ]; - "nfandroidtv" = ps: with ps; [ - notifications-android-tv - ]; - "nibe_heatpump" = ps: with ps; [ - nibe - ]; - "nice_go" = ps: with ps; [ - nice-go - ]; - "nightscout" = ps: with ps; [ - py-nightscout - ]; - "niko_home_control" = ps: with ps; [ - niko-home-control - ]; - "nilu" = ps: with ps; [ - niluclient - ]; - "nina" = ps: with ps; [ - pynina - ]; - "nissan_leaf" = ps: with ps; [ - pycarwings2 - ]; - "nmap_tracker" = ps: with ps; [ - aiooui - getmac - ifaddr - netmap - ]; - "nmbs" = ps: with ps; [ - ]; # missing inputs: pyrail - "no_ip" = ps: with ps; [ - ]; - "noaa_tides" = ps: with ps; [ - ]; # missing inputs: noaa-coops - "nobo_hub" = ps: with ps; [ - pynobo - ]; - "norway_air" = ps: with ps; [ - pymetno - ]; - "notify" = ps: with ps; [ - ]; - "notify_events" = ps: with ps; [ - notify-events - ]; - "notion" = ps: with ps; [ - aionotion - ]; - "nsw_fuel_station" = ps: with ps; [ - ]; # missing inputs: nsw-fuel-api-client - "nsw_rural_fire_service_feed" = ps: with ps; [ - aio-geojson-nsw-rfs-incidents - ]; - "nuheat" = ps: with ps; [ - nuheat - ]; - "nuki" = ps: with ps; [ - pynuki - ]; - "numato" = ps: with ps; [ - ]; # missing inputs: numato-gpio - "number" = ps: with ps; [ - ]; - "nut" = ps: with ps; [ - aionut - ]; - "nutrichef" = ps: with ps; [ - ]; - "nws" = ps: with ps; [ - pynws - ] - ++ pynws.optional-dependencies.retry; - "nx584" = ps: with ps; [ - pynx584 - ]; - "nyt_games" = ps: with ps; [ - ]; # missing inputs: nyt_games - "nzbget" = ps: with ps; [ - ]; # missing inputs: pynzbgetapi - "oasa_telematics" = ps: with ps; [ - oasatelematics - ]; - "obihai" = ps: with ps; [ - pyobihai - ]; - "octoprint" = ps: with ps; [ - pyoctoprintapi - ]; - "oem" = ps: with ps; [ - oemthermostat - ]; - "ohmconnect" = ps: with ps; [ - defusedxml - ]; - "ollama" = ps: with ps; [ - ha-ffmpeg - hassil - home-assistant-intents - mutagen - ollama - pymicro-vad - pyspeex-noise - ]; - "ombi" = ps: with ps; [ - pyombi - ]; - "omnilogic" = ps: with ps; [ - omnilogic - ]; - "onboarding" = ps: with ps; [ - aiohasupervisor - pillow - ]; - "oncue" = ps: with ps; [ - aiooncue - ]; - "ondilo_ico" = ps: with ps; [ - ondilo - ]; - "onewire" = ps: with ps; [ - pyownet - ]; - "onkyo" = ps: with ps; [ - ]; # missing inputs: pyeiscp - "onvif" = ps: with ps; [ - ha-ffmpeg - onvif-zeep-async - wsdiscovery - ]; - "open_meteo" = ps: with ps; [ - open-meteo - ]; - "openai_conversation" = ps: with ps; [ - ha-ffmpeg - hassil - home-assistant-intents - mutagen - openai - pymicro-vad - pyspeex-noise - ]; - "openalpr_cloud" = ps: with ps; [ - ]; - "openerz" = ps: with ps; [ - openerz-api - ]; - "openevse" = ps: with ps; [ - openevsewifi - ]; - "openexchangerates" = ps: with ps; [ - aioopenexchangerates - ]; - "opengarage" = ps: with ps; [ - open-garage - ]; - "openhardwaremonitor" = ps: with ps; [ - ]; - "openhome" = ps: with ps; [ - openhomedevice - ]; - "opensensemap" = ps: with ps; [ - opensensemap-api - ]; - "opensky" = ps: with ps; [ - python-opensky - ]; - "opentherm_gw" = ps: with ps; [ - pyotgw - ]; - "openuv" = ps: with ps; [ - pyopenuv - ]; - "openweathermap" = ps: with ps; [ - pyopenweathermap - ]; - "opnsense" = ps: with ps; [ - pyopnsense - ]; - "opower" = ps: with ps; [ - fnv-hash-fast - opower - psutil-home-assistant - sqlalchemy - ]; - "opple" = ps: with ps; [ - ]; # missing inputs: pyoppleio-legacy - "oralb" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - oralb-ble - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "oru" = ps: with ps; [ - ]; # missing inputs: oru - "oru_opower" = ps: with ps; [ - ]; - "orvibo" = ps: with ps; [ - orvibo - ]; - "osoenergy" = ps: with ps; [ - ]; # missing inputs: pyosoenergyapi - "osramlightify" = ps: with ps; [ - ]; # missing inputs: lightify - "otbr" = ps: with ps; [ - aiohasupervisor - ifaddr - pillow - psutil-home-assistant - pyroute2 - pyserial - python-otbr-api - pyudev - universal-silabs-flasher - zeroconf - zha - ]; - "otp" = ps: with ps; [ - pyotp - ]; - "ourgroceries" = ps: with ps; [ - ]; # missing inputs: ourgroceries - "overkiz" = ps: with ps; [ - pyoverkiz - ]; - "ovo_energy" = ps: with ps; [ - ovoenergy - ]; - "owntracks" = ps: with ps; [ - aiohasupervisor - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-intents - mutagen - paho-mqtt_1 - pymicro-vad - pynacl - pyspeex-noise - python-matter-server - pyturbojpeg - ]; - "p1_monitor" = ps: with ps; [ - p1monitor - ]; - "palazzetti" = ps: with ps; [ - pypalazzetti - ]; - "panasonic_bluray" = ps: with ps; [ - panacotta - ]; - "panasonic_viera" = ps: with ps; [ - panasonic-viera - ]; - "pandora" = ps: with ps; [ - pexpect - ]; - "panel_custom" = ps: with ps; [ - aiohasupervisor - home-assistant-frontend - pillow - ]; - "pcs_lighting" = ps: with ps; [ - ]; - "peco" = ps: with ps; [ - peco - ]; - "peco_opower" = ps: with ps; [ - ]; - "pegel_online" = ps: with ps; [ - aiopegelonline - ]; - "pencom" = ps: with ps; [ - pencompy - ]; - "pepco" = ps: with ps; [ - ]; - "permobil" = ps: with ps; [ - mypermobil - ]; - "persistent_notification" = ps: with ps; [ - ]; - "person" = ps: with ps; [ - pillow - ]; - "pge" = ps: with ps; [ - ]; - "philips_js" = ps: with ps; [ - ha-philipsjs - ]; - "pi_hole" = ps: with ps; [ - hole - ]; - "picnic" = ps: with ps; [ - python-picnic-api - ]; - "picotts" = ps: with ps; [ - ]; - "pilight" = ps: with ps; [ - ]; # missing inputs: pilight - "pinecil" = ps: with ps; [ - ]; - "ping" = ps: with ps; [ - icmplib - ]; - "pioneer" = ps: with ps; [ - ]; - "piper" = ps: with ps; [ - ]; - "pjlink" = ps: with ps; [ - ]; # missing inputs: pypjlink2 - "plaato" = ps: with ps; [ - aiohasupervisor - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-intents - mutagen - pymicro-vad - pyplaato - pyspeex-noise - python-matter-server - pyturbojpeg - ]; - "plant" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; - "plex" = ps: with ps; [ - plexapi - plexauth - plexwebsocket - ]; - "plugwise" = ps: with ps; [ - plugwise - ]; - "plum_lightpad" = ps: with ps; [ - ]; # missing inputs: plumlightpad - "pocketcasts" = ps: with ps; [ - pycketcasts - ]; - "point" = ps: with ps; [ - pypoint - ]; - "poolsense" = ps: with ps; [ - poolsense - ]; - "portlandgeneral" = ps: with ps; [ - ]; - "powerwall" = ps: with ps; [ - tesla-powerwall - ]; - "private_ble_device" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - zeroconf - ]; - "profiler" = ps: with ps; [ - guppy3 - objgraph - pyprof2calltree - ]; - "progettihwsw" = ps: with ps; [ - ]; # missing inputs: ProgettiHWSW - "proliphix" = ps: with ps; [ - ]; # missing inputs: proliphix - "prometheus" = ps: with ps; [ - prometheus-client - ]; - "prosegur" = ps: with ps; [ - pyprosegur - ]; - "prowl" = ps: with ps; [ - ]; - "proximity" = ps: with ps; [ - ]; - "proxmoxve" = ps: with ps; [ - proxmoxer - ]; - "proxy" = ps: with ps; [ - pillow - ]; - "prusalink" = ps: with ps; [ - pyprusalink - ]; - "ps4" = ps: with ps; [ - ]; # missing inputs: pyps4-2ndscreen - "pse" = ps: with ps; [ - ]; - "psoklahoma" = ps: with ps; [ - ]; - "pulseaudio_loopback" = ps: with ps; [ - pulsectl - ]; - "pure_energie" = ps: with ps; [ - gridnet - ]; - "purpleair" = ps: with ps; [ - aiopurpleair - ]; - "push" = ps: with ps; [ - ]; - "pushbullet" = ps: with ps; [ - pushbullet-py - ]; - "pushover" = ps: with ps; [ - pushover-complete - ]; - "pushsafer" = ps: with ps; [ - ]; - "pvoutput" = ps: with ps; [ - pvo - ]; - "pvpc_hourly_pricing" = ps: with ps; [ - aiopvpc - ]; - "pyload" = ps: with ps; [ - pyloadapi - ]; - "python_script" = ps: with ps; [ - restrictedpython - ]; - "qbittorrent" = ps: with ps; [ - qbittorrent-api - ]; - "qingping" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - qingping-ble - zeroconf - ]; - "qld_bushfire" = ps: with ps; [ - georss-qld-bushfire-alert-client - ]; - "qnap" = ps: with ps; [ - qnapstats - ]; - "qnap_qsw" = ps: with ps; [ - aioqsw - ]; - "qrcode" = ps: with ps; [ - pillow - pyzbar - ]; - "quadrafire" = ps: with ps; [ - ]; - "quantum_gateway" = ps: with ps; [ - quantum-gateway - ]; - "qvr_pro" = ps: with ps; [ - pyqvrpro - ]; - "qwikswitch" = ps: with ps; [ - pyqwikswitch - ]; - "rabbitair" = ps: with ps; [ - ifaddr - python-rabbitair - zeroconf - ]; - "rachio" = ps: with ps; [ - aiohasupervisor - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-intents - mutagen - pymicro-vad - pyspeex-noise - python-matter-server - pyturbojpeg - rachiopy - ]; - "radarr" = ps: with ps; [ - aiopyarr - ]; - "radio_browser" = ps: with ps; [ - pycountry - radios - ]; - "radiotherm" = ps: with ps; [ - radiotherm - ]; - "rainbird" = ps: with ps; [ - pyrainbird - ]; - "raincloud" = ps: with ps; [ - raincloudy - ]; - "rainforest_eagle" = ps: with ps; [ - aioeagle - eagle100 - ]; - "rainforest_raven" = ps: with ps; [ - aioraven - pyserial - pyudev - ]; - "rainmachine" = ps: with ps; [ - regenmaschine - ]; - "random" = ps: with ps; [ - ]; - "rapt_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - rapt-ble - zeroconf - ]; - "raspberry_pi" = ps: with ps; [ - aiohasupervisor - psutil-home-assistant - ]; - "raspyrfm" = ps: with ps; [ - ]; # missing inputs: raspyrfm-client - "raven_rock_mfg" = ps: with ps; [ - ]; - "rdw" = ps: with ps; [ - vehicle - ]; - "recollect_waste" = ps: with ps; [ - aiorecollect - ]; - "recorder" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; - "recovery_mode" = ps: with ps; [ - aiohasupervisor - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-frontend - home-assistant-intents - mutagen - pillow - pymicro-vad - pyspeex-noise - python-matter-server - pyturbojpeg - ]; - "recswitch" = ps: with ps; [ - ]; # missing inputs: pyrecswitch - "reddit" = ps: with ps; [ - praw - ]; - "refoss" = ps: with ps; [ - refoss-ha - ]; - "rejseplanen" = ps: with ps; [ - rjpl - ]; - "remember_the_milk" = ps: with ps; [ - httplib2 - ]; # missing inputs: RtmAPI - "remote" = ps: with ps; [ - ]; - "remote_rpi_gpio" = ps: with ps; [ - gpiozero - ]; # missing inputs: pigpio - "renault" = ps: with ps; [ - renault-api - ]; - "renson" = ps: with ps; [ - renson-endura-delta - ]; - "reolink" = ps: with ps; [ - reolink-aio - ]; - "repairs" = ps: with ps; [ - ]; - "repetier" = ps: with ps; [ - ]; # missing inputs: pyrepetierng - "rest" = ps: with ps; [ - jsonpath - xmltodict - ]; - "rest_command" = ps: with ps; [ - ]; - "rexel" = ps: with ps; [ - ]; - "rflink" = ps: with ps; [ - rflink - ]; - "rfxtrx" = ps: with ps; [ - pyrfxtrx - ]; - "rhasspy" = ps: with ps; [ - ]; - "ridwell" = ps: with ps; [ - aioridwell - ]; - "ring" = ps: with ps; [ - ha-ffmpeg - ring-doorbell - ]; - "ripple" = ps: with ps; [ - ]; # missing inputs: python-ripple-api - "risco" = ps: with ps; [ - pyrisco - ]; - "rituals_perfume_genie" = ps: with ps; [ - pyrituals - ]; - "rmvtransport" = ps: with ps; [ - pyrmvtransport - ]; - "roborock" = ps: with ps; [ - python-roborock - vacuum-map-parser-roborock - ]; - "rocketchat" = ps: with ps; [ - rocketchat-api - ]; - "roku" = ps: with ps; [ - rokuecp - ]; - "romy" = ps: with ps; [ - romy - ]; - "roomba" = ps: with ps; [ - roombapy - ]; - "roon" = ps: with ps; [ - roonapi - ]; - "route53" = ps: with ps; [ - boto3 - ]; - "rova" = ps: with ps; [ - rova - ]; - "rpi_camera" = ps: with ps; [ - ]; - "rpi_power" = ps: with ps; [ - rpi-bad-power - ]; - "rss_feed_template" = ps: with ps; [ - ]; - "rtorrent" = ps: with ps; [ - ]; - "rtsp_to_webrtc" = ps: with ps; [ - pyturbojpeg - rtsp-to-webrtc - ]; - "ruckus_unleashed" = ps: with ps; [ - aioruckus - ]; - "russound_rio" = ps: with ps; [ - aiorussound - ]; - "russound_rnet" = ps: with ps; [ - ]; # missing inputs: russound - "ruuvi_gateway" = ps: with ps; [ - aioruuvigateway - bleak - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - habluetooth - pyserial - pyudev - ]; - "ruuvitag_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - ruuvitag-ble - zeroconf - ]; - "rympro" = ps: with ps; [ - pyrympro - ]; - "sabnzbd" = ps: with ps; [ - pysabnzbd - ]; - "saj" = ps: with ps; [ - pysaj - ]; - "samsam" = ps: with ps; [ - ]; - "samsungtv" = ps: with ps; [ - async-upnp-client - getmac - ifaddr - samsungctl - samsungtvws - wakeonlan - ] - ++ samsungctl.optional-dependencies.websocket - ++ samsungtvws.optional-dependencies.async - ++ samsungtvws.optional-dependencies.encrypted; - "sanix" = ps: with ps; [ - sanix - ]; - "satel_integra" = ps: with ps; [ - ]; # missing inputs: satel-integra - "scene" = ps: with ps; [ - ]; - "schedule" = ps: with ps; [ - ]; - "schlage" = ps: with ps; [ - pyschlage - ]; - "schluter" = ps: with ps; [ - ]; # missing inputs: py-schluter - "scl" = ps: with ps; [ - ]; - "scrape" = ps: with ps; [ - beautifulsoup4 - jsonpath - lxml - xmltodict - ]; - "screenaway" = ps: with ps; [ - ]; - "screenlogic" = ps: with ps; [ - screenlogicpy - ]; - "script" = ps: with ps; [ - ]; - "scsgate" = ps: with ps; [ - ]; # missing inputs: scsgate - "search" = ps: with ps; [ - ]; - "season" = ps: with ps; [ - ephem - ]; - "select" = ps: with ps; [ - ]; - "sendgrid" = ps: with ps; [ - sendgrid - ]; - "sense" = ps: with ps; [ - sense-energy - ]; - "sensibo" = ps: with ps; [ - pysensibo - ]; - "sensirion_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - sensirion-ble - zeroconf - ]; - "sensor" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; - "sensorblue" = ps: with ps; [ - ]; - "sensorpro" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - sensorpro-ble - zeroconf - ]; - "sensorpush" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - sensorpush-ble - zeroconf - ]; - "sensoterra" = ps: with ps; [ - sensoterra - ]; - "sentry" = ps: with ps; [ - sentry-sdk - ]; - "senz" = ps: with ps; [ - aiosenz - ]; - "serial" = ps: with ps; [ - pyserial-asyncio-fast - ]; - "serial_pm" = ps: with ps; [ - pmsensor - ]; - "sesame" = ps: with ps; [ - ]; # missing inputs: pysesame2 - "seven_segments" = ps: with ps; [ - pillow - ]; - "seventeentrack" = ps: with ps; [ - pyseventeentrack - ]; - "sfr_box" = ps: with ps; [ - sfrbox-api - ]; - "sharkiq" = ps: with ps; [ - sharkiq - ]; - "shell_command" = ps: with ps; [ - ]; - "shelly" = ps: with ps; [ - aioshelly - bleak - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - habluetooth - ifaddr - pyserial - pyudev - ]; - "shodan" = ps: with ps; [ - shodan - ]; - "shopping_list" = ps: with ps; [ - ]; - "sia" = ps: with ps; [ - pysiaalarm - ]; - "sigfox" = ps: with ps; [ - ]; - "sighthound" = ps: with ps; [ - pillow - simplehound - ]; - "signal_messenger" = ps: with ps; [ - pysignalclirestapi - ]; - "simplefin" = ps: with ps; [ - simplefin4py - ]; - "simplepush" = ps: with ps; [ - simplepush - ]; - "simplisafe" = ps: with ps; [ - simplisafe-python - ]; - "simply_automated" = ps: with ps; [ - ]; - "simu" = ps: with ps; [ - ]; - "simulated" = ps: with ps; [ - ]; - "sinch" = ps: with ps; [ - ]; # missing inputs: clx-sdk-xms - "siren" = ps: with ps; [ - ]; - "sisyphus" = ps: with ps; [ - sisyphus-control - ]; - "sky_hub" = ps: with ps; [ - pyskyqhub - ]; - "skybeacon" = ps: with ps; [ - pygatt - ] - ++ pygatt.optional-dependencies.GATTTOOL; - "skybell" = ps: with ps; [ - aioskybell - ha-ffmpeg - ]; - "slack" = ps: with ps; [ - slack-sdk - ]; - "sleepiq" = ps: with ps; [ - asyncsleepiq - ]; - "slide" = ps: with ps; [ - ]; # missing inputs: goslide-api - "slimproto" = ps: with ps; [ - aioslimproto - ]; - "sma" = ps: with ps; [ - pysma - ]; - "smappee" = ps: with ps; [ - pysmappee - ]; - "smart_blinds" = ps: with ps; [ - ]; - "smart_home" = ps: with ps; [ - ]; - "smart_meter_texas" = ps: with ps; [ - smart-meter-texas - ]; - "smarther" = ps: with ps; [ - ]; - "smartthings" = ps: with ps; [ - aiohasupervisor - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-intents - mutagen - pymicro-vad - pysmartapp - pysmartthings - pyspeex-noise - python-matter-server - pyturbojpeg - ]; - "smarttub" = ps: with ps; [ - python-smarttub - ]; - "smarty" = ps: with ps; [ - ]; # missing inputs: pysmarty2 - "smhi" = ps: with ps; [ - smhi-pkg - ]; - "smlight" = ps: with ps; [ - pysmlight - ]; - "sms" = ps: with ps; [ - python-gammu - ]; - "smtp" = ps: with ps; [ - ]; - "smud" = ps: with ps; [ - ]; - "snapcast" = ps: with ps; [ - snapcast - ]; - "snips" = ps: with ps; [ - aiohasupervisor - paho-mqtt_1 - ]; - "snmp" = ps: with ps; [ - pysnmp - ]; - "snooz" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pysnooz - pyspeex-noise - pyudev - zeroconf - ]; - "solaredge" = ps: with ps; [ - aiosolaredge - stringcase - ]; - "solaredge_local" = ps: with ps; [ - ]; # missing inputs: solaredge-local - "solarlog" = ps: with ps; [ - solarlog-cli - ]; - "solax" = ps: with ps; [ - solax - ]; - "soma" = ps: with ps; [ - pysoma - ]; - "somfy" = ps: with ps; [ - ]; - "somfy_mylink" = ps: with ps; [ - somfy-mylink-synergy - ]; - "sonarr" = ps: with ps; [ - aiopyarr - ]; - "songpal" = ps: with ps; [ - python-songpal - ]; - "sonos" = ps: with ps; [ - async-upnp-client - ifaddr - plexapi - plexauth - plexwebsocket - soco - sonos-websocket - spotifyaio - zeroconf - ]; - "sony_projector" = ps: with ps; [ - pysdcp - ]; - "soundtouch" = ps: with ps; [ - libsoundtouch - ]; - "spaceapi" = ps: with ps; [ - ]; - "spc" = ps: with ps; [ - pyspcwebgw - ]; - "speedtestdotnet" = ps: with ps; [ - speedtest-cli - ]; - "spider" = ps: with ps; [ - ]; - "splunk" = ps: with ps; [ - hass-splunk - ]; - "spotify" = ps: with ps; [ - spotifyaio - ]; - "sql" = ps: with ps; [ - sqlalchemy - sqlparse - ]; - "squeezebox" = ps: with ps; [ - pysqueezebox - ]; - "srp_energy" = ps: with ps; [ - srpenergy - ]; - "ssdp" = ps: with ps; [ - async-upnp-client - ifaddr - ]; - "starline" = ps: with ps; [ - starline - ]; - "starlingbank" = ps: with ps; [ - ]; # missing inputs: starlingbank - "starlink" = ps: with ps; [ - ]; # missing inputs: starlink-grpc-core - "startca" = ps: with ps; [ - xmltodict - ]; - "statistics" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - sqlalchemy - ]; - "statsd" = ps: with ps; [ - statsd - ]; - "steam_online" = ps: with ps; [ - steamodd - ]; - "steamist" = ps: with ps; [ - aiosteamist - discovery30303 - ifaddr - ]; - "stiebel_eltron" = ps: with ps; [ - pymodbus - ]; # missing inputs: pystiebeleltron - "stookalert" = ps: with ps; [ - stookalert - ]; - "stookwijzer" = ps: with ps; [ - stookwijzer - ]; - "stream" = ps: with ps; [ - av - numpy_1 - pyturbojpeg - ]; - "streamlabswater" = ps: with ps; [ - streamlabswater - ]; - "stt" = ps: with ps; [ - ]; - "subaru" = ps: with ps; [ - subarulink - ]; - "suez_water" = ps: with ps; [ - pysuez - ]; - "sun" = ps: with ps; [ - ]; - "sunweg" = ps: with ps; [ - sunweg - ]; - "supervisord" = ps: with ps; [ - ]; - "supla" = ps: with ps; [ - ]; # missing inputs: asyncpysupla - "surepetcare" = ps: with ps; [ - surepy - ]; - "swepco" = ps: with ps; [ - ]; - "swiss_hydrological_data" = ps: with ps; [ - swisshydrodata - ]; - "swiss_public_transport" = ps: with ps; [ - python-opendata-transport - ]; - "swisscom" = ps: with ps; [ - ]; - "switch" = ps: with ps; [ - ]; - "switch_as_x" = ps: with ps; [ - ]; - "switchbee" = ps: with ps; [ - pyswitchbee - ]; - "switchbot" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyswitchbot - pyudev - zeroconf - ]; - "switchbot_cloud" = ps: with ps; [ - switchbot-api - ]; - "switcher_kis" = ps: with ps; [ - aioswitcher - ]; - "switchmate" = ps: with ps; [ - ]; # missing inputs: PySwitchmate - "symfonisk" = ps: with ps; [ - ]; - "syncthing" = ps: with ps; [ - aiosyncthing - ]; - "syncthru" = ps: with ps; [ - pysyncthru - url-normalize - ]; - "synology_chat" = ps: with ps; [ - ]; - "synology_dsm" = ps: with ps; [ - py-synologydsm-api - ]; - "synology_srm" = ps: with ps; [ - ]; # missing inputs: synology-srm - "syslog" = ps: with ps; [ - ]; - "system_bridge" = ps: with ps; [ - ifaddr - systembridgeconnector - systembridgemodels - zeroconf - ]; - "system_health" = ps: with ps; [ - ]; - "system_log" = ps: with ps; [ - ]; - "systemmonitor" = ps: with ps; [ - psutil - psutil-home-assistant - ]; - "tado" = ps: with ps; [ - python-tado - ]; - "tag" = ps: with ps; [ - ]; - "tailscale" = ps: with ps; [ - tailscale - ]; - "tailwind" = ps: with ps; [ - gotailwind - ]; - "tami4" = ps: with ps; [ - ]; # missing inputs: Tami4EdgeAPI - "tank_utility" = ps: with ps; [ - tank-utility - ]; - "tankerkoenig" = ps: with ps; [ - aiotankerkoenig - ]; - "tapsaff" = ps: with ps; [ - ]; # missing inputs: tapsaff - "tasmota" = ps: with ps; [ - aiohasupervisor - hatasmota - paho-mqtt_1 - ]; - "tautulli" = ps: with ps; [ - pytautulli - ]; - "tcp" = ps: with ps; [ - ]; - "technove" = ps: with ps; [ - python-technove - ]; - "ted5000" = ps: with ps; [ - xmltodict - ]; - "tedee" = ps: with ps; [ - pytedee-async - ]; - "telegram" = ps: with ps; [ - python-telegram-bot - ] - ++ python-telegram-bot.optional-dependencies.socks; - "telegram_bot" = ps: with ps; [ - python-telegram-bot - ] - ++ python-telegram-bot.optional-dependencies.socks; - "tellduslive" = ps: with ps; [ - tellduslive - ]; - "tellstick" = ps: with ps; [ - ]; # missing inputs: tellcore-net tellcore-py - "telnet" = ps: with ps; [ - ]; - "temper" = ps: with ps; [ - temperusb - ]; - "template" = ps: with ps; [ - ]; - "tensorflow" = ps: with ps; [ - numpy_1 - pillow - pycocotools - tensorflow - ]; # missing inputs: tf-models-official - "tesla_fleet" = ps: with ps; [ - tesla-fleet-api - ]; - "tesla_wall_connector" = ps: with ps; [ - tesla-wall-connector - ]; - "teslemetry" = ps: with ps; [ - tesla-fleet-api - teslemetry-stream - ]; - "tessie" = ps: with ps; [ - tesla-fleet-api - ]; # missing inputs: tessie-api - "text" = ps: with ps; [ - ]; - "thermobeacon" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - thermobeacon-ble - zeroconf - ]; - "thermoplus" = ps: with ps; [ - ]; - "thermopro" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - thermopro-ble - zeroconf - ]; - "thethingsnetwork" = ps: with ps; [ - ttn-client - ]; - "thingspeak" = ps: with ps; [ - ]; # missing inputs: thingspeak - "thinkingcleaner" = ps: with ps; [ - ]; # missing inputs: pythinkingcleaner - "thomson" = ps: with ps; [ - ]; - "thread" = ps: with ps; [ - ifaddr - pyroute2 - python-otbr-api - zeroconf - ]; - "threshold" = ps: with ps; [ - ]; - "tibber" = ps: with ps; [ - fnv-hash-fast - psutil-home-assistant - pytibber - sqlalchemy - ]; - "tikteck" = ps: with ps; [ - ]; # missing inputs: tikteck - "tile" = ps: with ps; [ - pytile - ]; - "tilt_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - tilt-ble - zeroconf - ]; - "time" = ps: with ps; [ - ]; - "time_date" = ps: with ps; [ - ]; - "timer" = ps: with ps; [ - ]; - "tmb" = ps: with ps; [ - tmb - ]; - "tod" = ps: with ps; [ - ]; - "todo" = ps: with ps; [ - ]; - "todoist" = ps: with ps; [ - todoist-api-python - ]; - "tolo" = ps: with ps; [ - tololib - ]; - "tomato" = ps: with ps; [ - ]; - "tomorrowio" = ps: with ps; [ - pytomorrowio - ]; - "toon" = ps: with ps; [ - aiohasupervisor - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-intents - mutagen - pymicro-vad - pyspeex-noise - python-matter-server - pyturbojpeg - toonapi - ]; - "torque" = ps: with ps; [ - ]; - "totalconnect" = ps: with ps; [ - total-connect-client - ]; - "touchline" = ps: with ps; [ - ]; # missing inputs: pytouchline - "touchline_sl" = ps: with ps; [ - pytouchlinesl - ]; - "tplink" = ps: with ps; [ - ifaddr - python-kasa - ] - ++ python-kasa.optional-dependencies.speedups; - "tplink_lte" = ps: with ps; [ - ]; # missing inputs: tp-connected - "tplink_omada" = ps: with ps; [ - tplink-omada-client - ]; - "tplink_tapo" = ps: with ps; [ - ]; - "traccar" = ps: with ps; [ - pytraccar - stringcase - ]; - "traccar_server" = ps: with ps; [ - pytraccar - ]; - "trace" = ps: with ps; [ - ]; - "tractive" = ps: with ps; [ - aiotractive - ]; - "tradfri" = ps: with ps; [ - pytradfri - ] - ++ pytradfri.optional-dependencies.async; - "trafikverket_camera" = ps: with ps; [ - pytrafikverket - ]; - "trafikverket_ferry" = ps: with ps; [ - pytrafikverket - ]; - "trafikverket_train" = ps: with ps; [ - pytrafikverket - ]; - "trafikverket_weatherstation" = ps: with ps; [ - pytrafikverket - ]; - "transmission" = ps: with ps; [ - transmission-rpc - ]; - "transport_nsw" = ps: with ps; [ - pytransportnsw - ]; - "travisci" = ps: with ps; [ - ]; # missing inputs: TravisPy - "trend" = ps: with ps; [ - numpy_1 - ]; - "triggercmd" = ps: with ps; [ - ]; # missing inputs: triggercmd - "tts" = ps: with ps; [ - ha-ffmpeg - mutagen - ]; - "tuya" = ps: with ps; [ - ha-ffmpeg - tuya-device-sharing-sdk - ]; - "twentemilieu" = ps: with ps; [ - twentemilieu - ]; - "twilio" = ps: with ps; [ - twilio - ]; - "twilio_call" = ps: with ps; [ - twilio - ]; - "twilio_sms" = ps: with ps; [ - twilio - ]; - "twinkly" = ps: with ps; [ - ttls - ]; - "twitch" = ps: with ps; [ - twitchapi - ]; - "twitter" = ps: with ps; [ - twitterapi - ]; - "ubiwizz" = ps: with ps; [ - ]; - "ubus" = ps: with ps; [ - openwrt-ubus-rpc - ]; - "uk_transport" = ps: with ps; [ - ]; - "ukraine_alarm" = ps: with ps; [ - uasiren - ]; - "ultraloq" = ps: with ps; [ - ]; - "unifi" = ps: with ps; [ - aiounifi - ]; - "unifi_direct" = ps: with ps; [ - unifi-ap - ]; - "unifiled" = ps: with ps; [ - unifiled - ]; - "unifiprotect" = ps: with ps; [ - uiprotect - unifi-discovery - ]; - "universal" = ps: with ps; [ - ]; - "upb" = ps: with ps; [ - upb-lib - ]; - "upc_connect" = ps: with ps; [ - connect-box - ]; - "upcloud" = ps: with ps; [ - upcloud-api - ]; - "update" = ps: with ps; [ - ]; - "upnp" = ps: with ps; [ - async-upnp-client - getmac - ifaddr - ]; - "uprise_smart_shades" = ps: with ps; [ - ]; - "uptime" = ps: with ps; [ - ]; - "uptimerobot" = ps: with ps; [ - pyuptimerobot - ]; - "usb" = ps: with ps; [ - pyserial - pyudev - ]; - "usgs_earthquakes_feed" = ps: with ps; [ - aio-geojson-usgs-earthquakes - ]; - "utility_meter" = ps: with ps; [ - croniter - ]; - "uvc" = ps: with ps; [ - uvcclient - ]; - "v2c" = ps: with ps; [ - pytrydan - ]; - "vacuum" = ps: with ps; [ - ]; - "vallox" = ps: with ps; [ - vallox-websocket-api - ]; - "valve" = ps: with ps; [ - ]; - "vasttrafik" = ps: with ps; [ - vtjp - ]; - "velbus" = ps: with ps; [ - pyserial - pyudev - velbus-aio - ]; - "velux" = ps: with ps; [ - pyvlx - ]; - "venstar" = ps: with ps; [ - venstarcolortouch - ]; - "vera" = ps: with ps; [ - pyvera - ]; - "verisure" = ps: with ps; [ - vsure - ]; - "vermont_castings" = ps: with ps; [ - ]; - "versasense" = ps: with ps; [ - pyversasense - ]; - "version" = ps: with ps; [ - pyhaversion - ]; - "vesync" = ps: with ps; [ - pyvesync - ]; - "viaggiatreno" = ps: with ps; [ - ]; - "vicare" = ps: with ps; [ - pyvicare - ]; - "vilfo" = ps: with ps; [ - vilfo-api-client - ]; - "vivotek" = ps: with ps; [ - libpyvivotek - ]; - "vizio" = ps: with ps; [ - pyvizio - ]; - "vlc" = ps: with ps; [ - python-vlc - ]; - "vlc_telnet" = ps: with ps; [ - aiovlc - ]; - "vodafone_station" = ps: with ps; [ - aiovodafone - ]; - "voicerss" = ps: with ps; [ - ]; - "voip" = ps: with ps; [ - ha-ffmpeg - hassil - home-assistant-intents - mutagen - pymicro-vad - pyspeex-noise - voip-utils - ]; - "volkszaehler" = ps: with ps; [ - volkszaehler - ]; - "volumio" = ps: with ps; [ - pyvolumio - ]; - "volvooncall" = ps: with ps; [ - volvooncall - ]; - "vulcan" = ps: with ps; [ - vulcan-api - ]; - "vultr" = ps: with ps; [ - vultr - ]; - "w800rf32" = ps: with ps; [ - ]; # missing inputs: pyW800rf32 - "wake_on_lan" = ps: with ps; [ - wakeonlan - ]; - "wake_word" = ps: with ps; [ - ]; - "wallbox" = ps: with ps; [ - wallbox - ]; - "waqi" = ps: with ps; [ - aiowaqi - ]; - "water_heater" = ps: with ps; [ - ]; - "waterfurnace" = ps: with ps; [ - waterfurnace - ]; - "watson_iot" = ps: with ps; [ - ]; # missing inputs: ibmiotf - "watttime" = ps: with ps; [ - aiowatttime - ]; - "waze_travel_time" = ps: with ps; [ - pywaze - ]; - "weather" = ps: with ps; [ - ]; - "weatherflow" = ps: with ps; [ - pyweatherflowudp - ]; - "weatherflow_cloud" = ps: with ps; [ - weatherflow4py - ]; - "weatherkit" = ps: with ps; [ - apple-weatherkit - ]; - "webhook" = ps: with ps; [ - ]; - "webmin" = ps: with ps; [ - webmin-xmlrpc - ]; - "webostv" = ps: with ps; [ - aiowebostv - ]; - "websocket_api" = ps: with ps; [ - ]; - "weheat" = ps: with ps; [ - weheat - ]; - "wemo" = ps: with ps; [ - pywemo - ]; - "whirlpool" = ps: with ps; [ - whirlpool-sixth-sense - ]; - "whisper" = ps: with ps; [ - ]; - "whois" = ps: with ps; [ - whois - ]; - "wiffi" = ps: with ps; [ - wiffi - ]; - "wilight" = ps: with ps; [ - pywilight - ]; - "wirelesstag" = ps: with ps; [ - ]; # missing inputs: wirelesstagpy - "withings" = ps: with ps; [ - aiohasupervisor - aiowithings - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-intents - mutagen - pymicro-vad - pyspeex-noise - python-matter-server - pyturbojpeg - ]; - "wiz" = ps: with ps; [ - ifaddr - pywizlight - ]; - "wled" = ps: with ps; [ - wled - ]; - "wmspro" = ps: with ps; [ - ]; # missing inputs: pywmspro - "wolflink" = ps: with ps; [ - ]; # missing inputs: wolf-comm - "workday" = ps: with ps; [ - holidays - ]; - "worldclock" = ps: with ps; [ - ]; - "worldtidesinfo" = ps: with ps; [ - ]; - "worxlandroid" = ps: with ps; [ - ]; - "ws66i" = ps: with ps; [ - pyws66i - ]; - "wsdot" = ps: with ps; [ - ]; - "wyoming" = ps: with ps; [ - ha-ffmpeg - hassil - home-assistant-intents - mutagen - pymicro-vad - pyspeex-noise - wyoming - ]; - "x10" = ps: with ps; [ - ]; - "xbox" = ps: with ps; [ - xbox-webapi - ]; - "xeoma" = ps: with ps; [ - pyxeoma - ]; - "xiaomi" = ps: with ps; [ - ha-ffmpeg - ]; - "xiaomi_aqara" = ps: with ps; [ - pyxiaomigateway - ]; - "xiaomi_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - xiaomi-ble - zeroconf - ]; - "xiaomi_miio" = ps: with ps; [ - construct - micloud - python-miio - ]; - "xiaomi_tv" = ps: with ps; [ - pymitv - ]; - "xmpp" = ps: with ps; [ - emoji - slixmpp - ]; - "xs1" = ps: with ps; [ - ]; # missing inputs: xs1-api-client - "yale" = ps: with ps; [ - aiohasupervisor - ha-ffmpeg - hass-nabucasa - hassil - home-assistant-intents - mutagen - pymicro-vad - pyspeex-noise - python-matter-server - pyturbojpeg - yalexs - yalexs-ble - ]; - "yale_home" = ps: with ps; [ - ]; - "yale_smart_alarm" = ps: with ps; [ - yalesmartalarmclient - ]; - "yalexs_ble" = ps: with ps; [ - aioesphomeapi - aioruuvigateway - aioshelly - bleak - bleak-esphome - bleak-retry-connector - bluetooth-adapters - bluetooth-auto-recovery - bluetooth-data-tools - dbus-fast - esphome-dashboard-api - ha-ffmpeg - habluetooth - hassil - home-assistant-intents - ifaddr - mutagen - pymicro-vad - pyserial - pyspeex-noise - pyudev - yalexs-ble - zeroconf - ]; - "yamaha" = ps: with ps; [ - rxv - ]; - "yamaha_musiccast" = ps: with ps; [ - aiomusiccast - async-upnp-client - ifaddr - ]; - "yandex_transport" = ps: with ps; [ - aioymaps - ]; - "yandextts" = ps: with ps; [ - ]; - "yardian" = ps: with ps; [ - pyyardian - ]; - "yeelight" = ps: with ps; [ - async-upnp-client - ifaddr - yeelight - ]; - "yeelightsunflower" = ps: with ps; [ - ]; # missing inputs: yeelightsunflower - "yi" = ps: with ps; [ - aioftp - ha-ffmpeg - ]; - "yolink" = ps: with ps; [ - yolink-api - ]; - "youless" = ps: with ps; [ - youless-api - ]; - "youtube" = ps: with ps; [ - youtubeaio - ]; - "zabbix" = ps: with ps; [ - py-zabbix - ]; - "zamg" = ps: with ps; [ - zamg - ]; - "zengge" = ps: with ps; [ - bluepy - ]; # missing inputs: zengge - "zeroconf" = ps: with ps; [ - ifaddr - zeroconf - ]; - "zerproc" = ps: with ps; [ - pyzerproc - ]; - "zestimate" = ps: with ps; [ - xmltodict - ]; - "zeversolar" = ps: with ps; [ - zeversolar - ]; - "zha" = ps: with ps; [ - aiohasupervisor - pillow - pyserial - pyudev - universal-silabs-flasher - zha - ]; - "zhong_hong" = ps: with ps; [ - ]; # missing inputs: zhong-hong-hvac - "ziggo_mediabox_xl" = ps: with ps; [ - ]; # missing inputs: ziggo-mediabox-xl - "zodiac" = ps: with ps; [ - ]; - "zondergas" = ps: with ps; [ - ]; - "zone" = ps: with ps; [ - ]; - "zoneminder" = ps: with ps; [ - zm-py - ]; - "zwave_js" = ps: with ps; [ - aiohasupervisor - pyserial - pyudev - zwave-js-server-python - ]; - "zwave_me" = ps: with ps; [ - ifaddr - url-normalize - zeroconf - zwave-me-ws - ]; + "3_day_blinds" = + ps: with ps; [ + ]; + "abode" = + ps: with ps; [ + jaraco-abode + ]; + "accuweather" = + ps: with ps; [ + accuweather + ]; + "acer_projector" = + ps: with ps; [ + pyserial + ]; + "acmeda" = + ps: with ps; [ + aiopulse + ]; + "acomax" = + ps: with ps; [ + ]; + "actiontec" = + ps: with ps; [ + ]; + "adax" = + ps: with ps; [ + adax + adax-local + ]; + "adguard" = + ps: with ps; [ + adguardhome + ]; + "ads" = + ps: with ps; [ + pyads + ]; + "advantage_air" = + ps: with ps; [ + advantage-air + ]; + "aemet" = + ps: with ps; [ + aemet-opendata + ]; + "aep_ohio" = + ps: with ps; [ + ]; + "aep_texas" = + ps: with ps; [ + ]; + "aftership" = + ps: with ps; [ + pyaftership + ]; + "agent_dvr" = + ps: with ps; [ + agent-py + ]; + "air_quality" = + ps: with ps; [ + ]; + "airgradient" = + ps: with ps; [ + airgradient + ]; + "airly" = + ps: with ps; [ + airly + ]; + "airnow" = + ps: with ps; [ + pyairnow + ]; + "airq" = + ps: with ps; [ + aioairq + ]; + "airthings" = + ps: with ps; [ + airthings-cloud + ]; + "airthings_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + airthings-ble + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "airtouch4" = + ps: with ps; [ + airtouch4pyapi + ]; + "airtouch5" = + ps: with ps; [ + airtouch5py + ]; + "airvisual" = + ps: with ps; [ + pyairvisual + ]; + "airvisual_pro" = + ps: with ps; [ + pyairvisual + ]; + "airzone" = + ps: with ps; [ + aioairzone + ]; + "airzone_cloud" = + ps: with ps; [ + aioairzone-cloud + ]; + "aladdin_connect" = + ps: with ps; [ + ]; + "alarm_control_panel" = + ps: with ps; [ + ]; + "alarmdecoder" = + ps: with ps; [ + adext + ]; + "alert" = + ps: with ps; [ + ]; + "alexa" = + ps: with ps; [ + pyturbojpeg + ]; + "alpha_vantage" = + ps: with ps; [ + alpha-vantage + ]; + "amazon_polly" = + ps: with ps; [ + boto3 + ]; + "amberelectric" = + ps: with ps; [ + amberelectric + ]; + "ambient_network" = + ps: with ps; [ + aioambient + ]; + "ambient_station" = + ps: with ps; [ + aioambient + ]; + "amcrest" = + ps: with ps; [ + amcrest + ha-ffmpeg + ]; + "amp_motorization" = + ps: with ps; [ + ]; + "ampio" = + ps: with ps; [ + asmog + ]; + "analytics" = + ps: with ps; [ + aiohasupervisor + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; + "analytics_insights" = + ps: with ps; [ + python-homeassistant-analytics + ]; + "android_ip_webcam" = + ps: with ps; [ + pydroid-ipcam + ]; + "androidtv" = + ps: + with ps; + [ + adb-shell + androidtv + pure-python-adb + ] + ++ adb-shell.optional-dependencies.async + ++ androidtv.optional-dependencies.async + ++ pure-python-adb.optional-dependencies.async; + "androidtv_remote" = + ps: with ps; [ + androidtvremote2 + ]; + "anel_pwrctrl" = + ps: with ps; [ + anel-pwrctrl-homeassistant + ]; + "anova" = + ps: with ps; [ + anova-wifi + ]; + "anthemav" = + ps: with ps; [ + anthemav + ]; + "anthropic" = + ps: with ps; [ + anthropic + ha-ffmpeg + hassil + home-assistant-intents + mutagen + pymicro-vad + pyspeex-noise + ]; + "anwb_energie" = + ps: with ps; [ + ]; + "aosmith" = + ps: with ps; [ + py-aosmith + ]; + "apache_kafka" = + ps: with ps; [ + aiokafka + ]; + "apcupsd" = + ps: with ps; [ + aioapcaccess + ]; + "api" = + ps: with ps; [ + ]; + "appalachianpower" = + ps: with ps; [ + ]; + "apple_tv" = + ps: with ps; [ + ifaddr + pyatv + zeroconf + ]; + "application_credentials" = + ps: with ps; [ + ]; + "apprise" = + ps: with ps; [ + apprise + ]; + "aprilaire" = + ps: with ps; [ + pyaprilaire + ]; + "aprs" = + ps: with ps; [ + aprslib + geopy + ]; + "aps" = + ps: with ps; [ + ]; + "apsystems" = + ps: with ps; [ + apsystems-ez1 + ]; + "aquacell" = + ps: with ps; [ + aioaquacell + ifaddr + ]; + "aqualogic" = + ps: with ps; [ + aqualogic + ]; + "aquostv" = + ps: with ps; [ + sharp-aquos-rc + ]; + "aranet" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + aranet4 + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "arcam_fmj" = + ps: with ps; [ + arcam-fmj + ]; + "arest" = + ps: with ps; [ + ]; + "arris_tg2492lg" = + ps: with ps; [ + arris-tg2492lg + ]; + "artsound" = + ps: with ps; [ + ]; + "aruba" = + ps: with ps; [ + pexpect + ]; + "arve" = + ps: with ps; [ + asyncarve + ]; + "arwn" = + ps: with ps; [ + aiohasupervisor + paho-mqtt_1 + ]; + "aseko_pool_live" = + ps: with ps; [ + aioaseko + ]; + "assist_pipeline" = + ps: with ps; [ + ha-ffmpeg + hassil + home-assistant-intents + mutagen + pymicro-vad + pyspeex-noise + ]; + "assist_satellite" = + ps: with ps; [ + ha-ffmpeg + hassil + home-assistant-intents + mutagen + pymicro-vad + pyspeex-noise + ]; + "asuswrt" = + ps: with ps; [ + aioasuswrt + pyasuswrt + ]; + "atag" = + ps: with ps; [ + pyatag + ]; + "aten_pe" = + ps: with ps; [ + atenpdu + ]; + "atlanticcityelectric" = + ps: with ps; [ + ]; + "atome" = + ps: with ps; [ + pyatome + ]; + "august" = + ps: with ps; [ + yalexs + yalexs-ble + ]; + "august_ble" = + ps: with ps; [ + ]; + "aurora" = + ps: with ps; [ + auroranoaa + ]; + "aurora_abb_powerone" = + ps: with ps; [ + aurorapy + ]; + "aussie_broadband" = + ps: with ps; [ + pyaussiebb + ]; + "autarco" = + ps: with ps; [ + autarco + ]; + "auth" = + ps: with ps; [ + ]; + "automation" = + ps: with ps; [ + ]; + "avea" = + ps: with ps; [ + avea + ]; + "avion" = + ps: with ps; [ + avion + ]; + "awair" = + ps: with ps; [ + python-awair + ]; + "aws" = + ps: with ps; [ + aiobotocore + botocore + ]; + "axis" = + ps: with ps; [ + aiohasupervisor + axis + paho-mqtt_1 + ]; + "azure_data_explorer" = + ps: + with ps; + [ + azure-kusto-data + azure-kusto-ingest + ] + ++ azure-kusto-data.optional-dependencies.aio; + "azure_devops" = + ps: with ps; [ + aioazuredevops + ]; + "azure_event_hub" = + ps: with ps; [ + azure-eventhub + ]; + "azure_service_bus" = + ps: with ps; [ + azure-servicebus + ]; + "backup" = + ps: with ps; [ + securetar + ]; + "baf" = + ps: with ps; [ + aiobafi6 + ]; + "baidu" = + ps: with ps; [ + ]; # missing inputs: baidu-aip + "balboa" = + ps: with ps; [ + pybalboa + ]; + "bang_olufsen" = + ps: with ps; [ + mozart-api + ]; + "bayesian" = + ps: with ps; [ + ]; + "bbox" = + ps: with ps; [ + ]; # missing inputs: pybbox + "beewi_smartclim" = + ps: with ps; [ + ]; # missing inputs: beewi-smartclim + "bge" = + ps: with ps; [ + ]; + "binary_sensor" = + ps: with ps; [ + ]; + "bitcoin" = + ps: with ps; [ + blockchain + ]; + "bizkaibus" = + ps: with ps; [ + bizkaibus + ]; + "blackbird" = + ps: with ps; [ + pyblackbird + ]; + "blebox" = + ps: with ps; [ + blebox-uniapi + ]; + "blink" = + ps: with ps; [ + blinkpy + ]; + "bliss_automation" = + ps: with ps; [ + ]; + "bloc_blinds" = + ps: with ps; [ + ]; + "blockchain" = + ps: with ps; [ + ]; # missing inputs: python-blockchain-api + "blue_current" = + ps: with ps; [ + bluecurrent-api + ]; + "bluemaestro" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluemaestro-ble + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "blueprint" = + ps: with ps; [ + ]; + "bluesound" = + ps: with ps; [ + ifaddr + pyblu + zeroconf + ]; + "bluetooth" = + ps: with ps; [ + bleak + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + habluetooth + pyserial + pyudev + ]; + "bluetooth_adapters" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "bluetooth_le_tracker" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "bluetooth_tracker" = + ps: with ps; [ + bt-proximity + pybluez + ]; + "bmw_connected_drive" = + ps: + with ps; + [ + bimmer-connected + ] + ++ bimmer-connected.optional-dependencies.china; + "bond" = + ps: with ps; [ + bond-async + ]; + "bosch_shc" = + ps: with ps; [ + boschshcpy + ifaddr + zeroconf + ]; + "brandt" = + ps: with ps; [ + ]; + "braviatv" = + ps: with ps; [ + pybravia + ]; + "brel_home" = + ps: with ps; [ + ]; + "bring" = + ps: with ps; [ + bring-api + ]; + "broadlink" = + ps: with ps; [ + broadlink + ]; + "brother" = + ps: with ps; [ + brother + pysnmp + ]; + "brottsplatskartan" = + ps: with ps; [ + brottsplatskartan + ]; + "browser" = + ps: with ps; [ + ]; + "brunt" = + ps: with ps; [ + brunt + ]; + "bryant_evolution" = + ps: with ps; [ + evolutionhttp + ]; + "bsblan" = + ps: with ps; [ + python-bsblan + ]; + "bswitch" = + ps: with ps; [ + ]; + "bt_home_hub_5" = + ps: with ps; [ + bthomehub5-devicelist + ]; + "bt_smarthub" = + ps: with ps; [ + btsmarthub-devicelist + ]; + "bthome" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + bthome-ble + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "bticino" = + ps: with ps; [ + ]; + "bubendorff" = + ps: with ps; [ + ]; + "buienradar" = + ps: with ps; [ + buienradar + ]; + "button" = + ps: with ps; [ + ]; + "caldav" = + ps: with ps; [ + caldav + ]; + "calendar" = + ps: with ps; [ + ]; + "cambridge_audio" = + ps: with ps; [ + aiostreammagic + ]; + "camera" = + ps: with ps; [ + pyturbojpeg + ]; + "canary" = + ps: with ps; [ + ha-ffmpeg + py-canary + ]; + "cast" = + ps: with ps; [ + aiohasupervisor + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-intents + ifaddr + mutagen + plexapi + plexauth + plexwebsocket + pychromecast + pymicro-vad + pyspeex-noise + python-matter-server + pyturbojpeg + zeroconf + ]; + "ccm15" = + ps: with ps; [ + py-ccm15 + ]; + "cert_expiry" = + ps: with ps; [ + ]; + "chacon_dio" = + ps: with ps; [ + dio-chacon-wifi-api + ]; + "channels" = + ps: with ps; [ + pychannels + ]; + "cisco_ios" = + ps: with ps; [ + pexpect + ]; + "cisco_mobility_express" = + ps: with ps; [ + ciscomobilityexpress + ]; + "cisco_webex_teams" = + ps: with ps; [ + webexpythonsdk + ]; + "citybikes" = + ps: with ps; [ + ]; + "clementine" = + ps: with ps; [ + ]; # missing inputs: python-clementine-remote + "clickatell" = + ps: with ps; [ + ]; + "clicksend" = + ps: with ps; [ + ]; + "clicksend_tts" = + ps: with ps; [ + ]; + "climate" = + ps: with ps; [ + ]; + "cloud" = + ps: with ps; [ + aiohasupervisor + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-intents + mutagen + pymicro-vad + pyspeex-noise + python-matter-server + pyturbojpeg + ]; + "cloudflare" = + ps: with ps; [ + pycfdns + ]; + "cmus" = + ps: with ps; [ + ]; # missing inputs: pycmus + "co2signal" = + ps: with ps; [ + aioelectricitymaps + ]; + "coautilities" = + ps: with ps; [ + ]; + "coinbase" = + ps: with ps; [ + ]; # missing inputs: coinbase coinbase-advanced-py + "color_extractor" = + ps: with ps; [ + colorthief + ]; + "comed" = + ps: with ps; [ + ]; + "comed_hourly_pricing" = + ps: with ps; [ + ]; + "comelit" = + ps: with ps; [ + aiocomelit + ]; + "comfoconnect" = + ps: with ps; [ + pycomfoconnect + ]; + "command_line" = + ps: with ps; [ + jsonpath + ]; + "compensation" = + ps: with ps; [ + numpy_1 + ]; + "concord232" = + ps: with ps; [ + ]; # missing inputs: concord232 + "coned" = + ps: with ps; [ + ]; + "config" = + ps: with ps; [ + ]; + "configurator" = + ps: with ps; [ + ]; + "control4" = + ps: with ps; [ + pycontrol4 + ]; + "conversation" = + ps: with ps; [ + hassil + home-assistant-intents + ]; + "coolmaster" = + ps: with ps; [ + pycoolmasternet-async + ]; + "counter" = + ps: with ps; [ + ]; + "cover" = + ps: with ps; [ + ]; + "cozytouch" = + ps: with ps; [ + ]; + "cppm_tracker" = + ps: with ps; [ + ]; # missing inputs: clearpasspy + "cpuspeed" = + ps: with ps; [ + py-cpuinfo + ]; + "cribl" = + ps: with ps; [ + ]; + "crownstone" = + ps: with ps; [ + crownstone-cloud + crownstone-sse + crownstone-uart + pyserial + pyudev + ]; + "cups" = + ps: with ps; [ + pycups + ]; + "currencylayer" = + ps: with ps; [ + ]; + "dacia" = + ps: with ps; [ + ]; + "daikin" = + ps: with ps; [ + pydaikin + ]; + "danfoss_air" = + ps: with ps; [ + pydanfossair + ]; + "datadog" = + ps: with ps; [ + datadog + ]; + "date" = + ps: with ps; [ + ]; + "datetime" = + ps: with ps; [ + ]; + "ddwrt" = + ps: with ps; [ + ]; + "deako" = + ps: with ps; [ + ifaddr + pydeako + zeroconf + ]; + "debugpy" = + ps: with ps; [ + debugpy + ]; + "deconz" = + ps: with ps; [ + pydeconz + ]; + "decora" = + ps: with ps; [ + bluepy + ]; # missing inputs: decora + "decora_wifi" = + ps: with ps; [ + ]; # missing inputs: decora-wifi + "default_config" = + ps: with ps; [ + aiodhcpwatcher + aiodiscover + aiohasupervisor + async-upnp-client + av + bleak + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + cached-ipaddress + dbus-fast + fnv-hash-fast + go2rtc-client + ha-ffmpeg + habluetooth + hass-nabucasa + hassil + home-assistant-frontend + home-assistant-intents + ifaddr + mutagen + numpy_1 + pillow + psutil-home-assistant + pymicro-vad + pynacl + pyserial + pyspeex-noise + python-matter-server + pyturbojpeg + pyudev + securetar + sqlalchemy + zeroconf + ]; + "delijn" = + ps: with ps; [ + pydelijn + ]; + "delmarva" = + ps: with ps; [ + ]; + "deluge" = + ps: with ps; [ + deluge-client + ]; + "demo" = + ps: with ps; [ + hassil + home-assistant-intents + ]; + "denon" = + ps: with ps; [ + ]; + "denonavr" = + ps: with ps; [ + denonavr + ]; + "derivative" = + ps: with ps; [ + ]; + "devialet" = + ps: with ps; [ + devialet + ifaddr + zeroconf + ]; + "device_automation" = + ps: with ps; [ + ]; + "device_sun_light_trigger" = + ps: with ps; [ + pillow + ]; + "device_tracker" = + ps: with ps; [ + ]; + "devolo_home_control" = + ps: with ps; [ + devolo-home-control-api + ifaddr + zeroconf + ]; + "devolo_home_network" = + ps: with ps; [ + devolo-plc-api + ]; + "dexcom" = + ps: with ps; [ + pydexcom + ]; + "dhcp" = + ps: with ps; [ + aiodhcpwatcher + aiodiscover + cached-ipaddress + ]; + "diagnostics" = + ps: with ps; [ + ]; + "dialogflow" = + ps: with ps; [ + ]; + "diaz" = + ps: with ps; [ + ]; + "digital_loggers" = + ps: with ps; [ + ]; + "digital_ocean" = + ps: with ps; [ + python-digitalocean + ]; + "directv" = + ps: with ps; [ + directv + ]; + "discogs" = + ps: with ps; [ + discogs-client + ]; + "discord" = + ps: with ps; [ + nextcord + ]; + "discovergy" = + ps: with ps; [ + pydiscovergy + ]; + "dlib_face_detect" = + ps: with ps; [ + face-recognition + ]; + "dlib_face_identify" = + ps: with ps; [ + face-recognition + ]; + "dlink" = + ps: with ps; [ + ]; # missing inputs: pyW215 + "dlna_dmr" = + ps: with ps; [ + async-upnp-client + getmac + ifaddr + ]; + "dlna_dms" = + ps: with ps; [ + async-upnp-client + ifaddr + ]; + "dnsip" = + ps: with ps; [ + aiodns + ]; + "dominos" = + ps: with ps; [ + ]; # missing inputs: pizzapi + "doods" = + ps: with ps; [ + pillow + pydoods + ]; + "doorbird" = + ps: with ps; [ + doorbirdpy + ]; + "dooya" = + ps: with ps; [ + ]; + "dormakaba_dkey" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + py-dormakaba-dkey + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "downloader" = + ps: with ps; [ + ]; + "dremel_3d_printer" = + ps: with ps; [ + dremel3dpy + ]; + "drop_connect" = + ps: with ps; [ + aiohasupervisor + dropmqttapi + paho-mqtt_1 + ]; + "dsmr" = + ps: with ps; [ + dsmr-parser + ]; + "dsmr_reader" = + ps: with ps; [ + aiohasupervisor + paho-mqtt_1 + ]; + "dte_energy_bridge" = + ps: with ps; [ + ]; + "dublin_bus_transport" = + ps: with ps; [ + ]; + "duckdns" = + ps: with ps; [ + ]; + "duke_energy" = + ps: with ps; [ + aiodukeenergy + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; + "dunehd" = + ps: with ps; [ + pdunehd + ]; + "duotecno" = + ps: with ps; [ + pyduotecno + ]; + "duquesne_light" = + ps: with ps; [ + ]; + "dwd_weather_warnings" = + ps: with ps; [ + dwdwfsapi + ]; + "dweet" = + ps: with ps; [ + ]; # missing inputs: dweepy + "dynalite" = + ps: with ps; [ + aiohasupervisor + dynalite-devices + dynalite-panel + home-assistant-frontend + pillow + ]; + "eafm" = + ps: with ps; [ + aioeafm + ]; + "eastron" = + ps: with ps; [ + ]; + "easyenergy" = + ps: with ps; [ + easyenergy + ]; + "ebox" = + ps: with ps; [ + ]; # missing inputs: pyebox + "ebusd" = + ps: with ps; [ + ]; # missing inputs: ebusdpy + "ecoal_boiler" = + ps: with ps; [ + ecoaliface + ]; + "ecobee" = + ps: with ps; [ + python-ecobee-api + ]; + "ecoforest" = + ps: with ps; [ + pyecoforest + ]; + "econet" = + ps: with ps; [ + pyeconet + ]; + "ecovacs" = + ps: with ps; [ + deebot-client + py-sucks + ]; + "ecowitt" = + ps: with ps; [ + aioecowitt + ]; + "eddystone_temperature" = + ps: with ps; [ + ]; # missing inputs: beacontools + "edimax" = + ps: with ps; [ + pyedimax + ]; + "edl21" = + ps: with ps; [ + pysml + ]; + "efergy" = + ps: with ps; [ + pyefergy + ]; + "egardia" = + ps: with ps; [ + pythonegardia + ]; + "eight_sleep" = + ps: with ps; [ + ]; + "electrasmart" = + ps: with ps; [ + pyelectra + ]; + "electric_kiwi" = + ps: with ps; [ + ]; # missing inputs: electrickiwi-api + "elevenlabs" = + ps: with ps; [ + elevenlabs + ]; + "elgato" = + ps: with ps; [ + elgato + ]; + "eliqonline" = + ps: with ps; [ + eliqonline + ]; + "elkm1" = + ps: with ps; [ + elkm1-lib + ifaddr + ]; + "elmax" = + ps: with ps; [ + elmax-api + ]; + "elv" = + ps: with ps; [ + pypca + ]; + "elvia" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; # missing inputs: elvia + "emby" = + ps: with ps; [ + pyemby + ]; + "emoncms" = + ps: with ps; [ + pyemoncms + ]; + "emoncms_history" = + ps: with ps; [ + ]; + "emonitor" = + ps: with ps; [ + aioemonitor + ]; + "emulated_hue" = + ps: with ps; [ + ifaddr + ]; + "emulated_kasa" = + ps: with ps; [ + sense-energy + ]; + "emulated_roku" = + ps: with ps; [ + emulated-roku + ifaddr + ]; + "energenie_power_sockets" = + ps: with ps; [ + pyegps + ]; + "energie_vanons" = + ps: with ps; [ + ]; + "energy" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; + "energyzero" = + ps: with ps; [ + energyzero + ]; + "enigma2" = + ps: with ps; [ + openwebifpy + ]; + "enmax" = + ps: with ps; [ + ]; + "enocean" = + ps: with ps; [ + enocean + ]; + "enphase_envoy" = + ps: with ps; [ + pyenphase + ]; + "entur_public_transport" = + ps: with ps; [ + enturclient + ]; + "environment_canada" = + ps: with ps; [ + env-canada + ]; + "envisalink" = + ps: with ps; [ + pyenvisalink + ]; + "ephember" = + ps: with ps; [ + pyephember + ]; + "epic_games_store" = + ps: with ps; [ + epicstore-api + ]; + "epion" = + ps: with ps; [ + epion + ]; + "epson" = + ps: with ps; [ + epson-projector + ]; + "eq3btsmart" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + eq3btsmart + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "escea" = + ps: with ps; [ + pescea + ]; + "esera_onewire" = + ps: with ps; [ + ]; + "esphome" = + ps: with ps; [ + aioesphomeapi + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "etherscan" = + ps: with ps; [ + ]; # missing inputs: python-etherscan-api + "eufy" = + ps: with ps; [ + lakeside + ]; + "eufylife_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + eufylife-ble-client + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "event" = + ps: with ps; [ + ]; + "evergy" = + ps: with ps; [ + ]; + "everlights" = + ps: with ps; [ + pyeverlights + ]; + "evil_genius_labs" = + ps: with ps; [ + pyevilgenius + ]; + "evohome" = + ps: with ps; [ + evohome-async + ]; + "ezviz" = + ps: with ps; [ + ha-ffmpeg + pyezviz + ]; + "faa_delays" = + ps: with ps; [ + faadelays + ]; + "facebook" = + ps: with ps; [ + ]; + "fail2ban" = + ps: with ps; [ + ]; + "familyhub" = + ps: with ps; [ + python-family-hub-local + ]; + "fan" = + ps: with ps; [ + ]; + "fastdotcom" = + ps: with ps; [ + ]; # missing inputs: fastdotcom + "feedreader" = + ps: with ps; [ + feedparser + ]; + "ffmpeg" = + ps: with ps; [ + ha-ffmpeg + ]; + "ffmpeg_motion" = + ps: with ps; [ + ha-ffmpeg + ]; + "ffmpeg_noise" = + ps: with ps; [ + ha-ffmpeg + ]; + "fibaro" = + ps: with ps; [ + pyfibaro + ]; + "fido" = + ps: with ps; [ + pyfido + ]; + "file" = + ps: with ps; [ + file-read-backwards + ]; + "file_upload" = + ps: with ps; [ + ]; + "filesize" = + ps: with ps; [ + ]; + "filter" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; + "fints" = + ps: with ps; [ + fints + ]; + "fire_tv" = + ps: with ps; [ + ]; + "fireservicerota" = + ps: with ps; [ + pyfireservicerota + ]; + "firmata" = + ps: with ps; [ + pymata-express + ]; + "fitbit" = + ps: with ps; [ + fitbit + ]; + "fivem" = + ps: with ps; [ + fivem-api + ]; + "fixer" = + ps: with ps; [ + fixerio + ]; + "fjaraskupan" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + fjaraskupan + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "fleetgo" = + ps: with ps; [ + ritassist + ]; + "flexit" = + ps: with ps; [ + pymodbus + ]; + "flexit_bacnet" = + ps: with ps; [ + flexit-bacnet + ]; + "flexom" = + ps: with ps; [ + ]; + "flic" = + ps: with ps; [ + pyflic + ]; + "flick_electric" = + ps: with ps; [ + pyflick + ]; + "flipr" = + ps: with ps; [ + flipr-api + ]; + "flo" = + ps: with ps; [ + aioflo + ]; + "flock" = + ps: with ps; [ + ]; + "flume" = + ps: with ps; [ + pyflume + ]; + "flux" = + ps: with ps; [ + ]; + "flux_led" = + ps: with ps; [ + flux-led + ifaddr + ]; + "folder" = + ps: with ps; [ + ]; + "folder_watcher" = + ps: with ps; [ + watchdog + ]; + "foobot" = + ps: with ps; [ + foobot-async + ]; + "forecast_solar" = + ps: with ps; [ + forecast-solar + ]; + "forked_daapd" = + ps: with ps; [ + spotifyaio + ]; # missing inputs: pyforked-daapd pylibrespot-java + "fortios" = + ps: with ps; [ + fortiosapi + ]; + "foscam" = + ps: with ps; [ + libpyfoscam + ]; + "foursquare" = + ps: with ps; [ + ]; + "free_mobile" = + ps: with ps; [ + ]; # missing inputs: freesms + "freebox" = + ps: with ps; [ + freebox-api + ha-ffmpeg + ]; + "freedns" = + ps: with ps; [ + ]; + "freedompro" = + ps: with ps; [ + pyfreedompro + ]; + "fritz" = + ps: + with ps; + [ + fritzconnection + ifaddr + xmltodict + ] + ++ fritzconnection.optional-dependencies.qr; + "fritzbox" = + ps: with ps; [ + pyfritzhome + ]; + "fritzbox_callmonitor" = + ps: + with ps; + [ + fritzconnection + ] + ++ fritzconnection.optional-dependencies.qr; + "fronius" = + ps: with ps; [ + pyfronius + ]; + "frontend" = + ps: with ps; [ + aiohasupervisor + home-assistant-frontend + pillow + ]; + "frontier_silicon" = + ps: with ps; [ + afsapi + ]; + "fujitsu_anywair" = + ps: with ps; [ + ]; + "fujitsu_fglair" = + ps: with ps; [ + ayla-iot-unofficial + ]; + "fully_kiosk" = + ps: with ps; [ + aiohasupervisor + paho-mqtt_1 + python-fullykiosk + ]; + "futurenow" = + ps: with ps; [ + pyfnip + ]; + "fyta" = + ps: with ps; [ + fyta-cli + ]; + "garadget" = + ps: with ps; [ + ]; + "garages_amsterdam" = + ps: with ps; [ + odp-amsterdam + ]; + "gardena_bluetooth" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + gardena-bluetooth + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "gaviota" = + ps: with ps; [ + ]; + "gc100" = + ps: with ps; [ + ]; # missing inputs: python-gc100 + "gdacs" = + ps: with ps; [ + aio-georss-gdacs + ]; + "generic" = + ps: with ps; [ + av + pillow + ]; + "generic_hygrostat" = + ps: with ps; [ + ]; + "generic_thermostat" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; + "geniushub" = + ps: with ps; [ + geniushub-client + ]; + "geo_json_events" = + ps: with ps; [ + aio-geojson-generic-client + ]; + "geo_location" = + ps: with ps; [ + ]; + "geo_rss_events" = + ps: with ps; [ + georss-generic-client + ]; + "geocaching" = + ps: with ps; [ + geocachingapi + ]; + "geofency" = + ps: with ps; [ + ]; + "geonetnz_quakes" = + ps: with ps; [ + aio-geojson-geonetnz-quakes + ]; + "geonetnz_volcano" = + ps: with ps; [ + aio-geojson-geonetnz-volcano + ]; + "gios" = + ps: with ps; [ + gios + ]; + "github" = + ps: with ps; [ + aiogithubapi + ]; + "gitlab_ci" = + ps: with ps; [ + python-gitlab + ]; + "gitter" = + ps: with ps; [ + ]; # missing inputs: gitterpy + "glances" = + ps: with ps; [ + glances-api + ]; + "go2rtc" = + ps: with ps; [ + go2rtc-client + pyturbojpeg + ]; + "goalzero" = + ps: with ps; [ + goalzero + ]; + "gogogate2" = + ps: with ps; [ + ismartgate + ]; + "goodwe" = + ps: with ps; [ + goodwe + ]; + "google" = + ps: with ps; [ + gcal-sync + ical + oauth2client + ]; + "google_assistant" = + ps: with ps; [ + aiohasupervisor + python-matter-server + pyturbojpeg + ]; + "google_assistant_sdk" = + ps: with ps; [ + gassist-text + ]; + "google_cloud" = + ps: with ps; [ + google-cloud-speech + google-cloud-texttospeech + ]; + "google_generative_ai_conversation" = + ps: with ps; [ + google-generativeai + ha-ffmpeg + hassil + home-assistant-intents + mutagen + pymicro-vad + pyspeex-noise + ]; + "google_mail" = + ps: with ps; [ + google-api-python-client + ]; + "google_maps" = + ps: with ps; [ + locationsharinglib + ]; + "google_photos" = + ps: with ps; [ + google-photos-library-api + ]; + "google_pubsub" = + ps: with ps; [ + google-cloud-pubsub + ]; + "google_sheets" = + ps: with ps; [ + gspread + ]; + "google_tasks" = + ps: with ps; [ + google-api-python-client + ]; + "google_translate" = + ps: with ps; [ + gtts + ]; + "google_travel_time" = + ps: with ps; [ + googlemaps + ]; + "google_wifi" = + ps: with ps; [ + ]; + "govee_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + govee-ble + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "govee_light_local" = + ps: with ps; [ + govee-local-api + ifaddr + ]; + "gpsd" = + ps: with ps; [ + gps3 + ]; + "gpslogger" = + ps: with ps; [ + ]; + "graphite" = + ps: with ps; [ + ]; + "gree" = + ps: with ps; [ + greeclimate + ifaddr + ]; + "greeneye_monitor" = + ps: with ps; [ + greeneye-monitor + ]; + "greenwave" = + ps: with ps; [ + ]; # missing inputs: greenwavereality + "group" = + ps: with ps; [ + ]; + "growatt_server" = + ps: with ps; [ + growattserver + ]; + "gstreamer" = + ps: with ps; [ + ]; # missing inputs: gstreamer-player + "gtfs" = + ps: with ps; [ + pygtfs + ]; + "guardian" = + ps: with ps; [ + aioguardian + ]; + "habitica" = + ps: with ps; [ + habitipy + ]; + "hardkernel" = + ps: with ps; [ + aiohasupervisor + psutil-home-assistant + ]; + "hardware" = + ps: with ps; [ + psutil-home-assistant + ]; + "harman_kardon_avr" = + ps: with ps; [ + hkavr + ]; + "harmony" = + ps: with ps; [ + aioharmony + ]; + "hassio" = + ps: with ps; [ + aiohasupervisor + ]; + "havana_shade" = + ps: with ps; [ + ]; + "haveibeenpwned" = + ps: with ps; [ + ]; + "hddtemp" = + ps: with ps; [ + ]; + "hdmi_cec" = + ps: with ps; [ + pycec + ]; + "heatmiser" = + ps: with ps; [ + heatmiserv3 + ]; + "heiwa" = + ps: with ps; [ + ]; + "heos" = + ps: with ps; [ + pyheos + ]; + "here_travel_time" = + ps: with ps; [ + here-routing + here-transit + ]; + "hexaom" = + ps: with ps; [ + ]; + "hi_kumo" = + ps: with ps; [ + ]; + "hikvision" = + ps: with ps; [ + ]; # missing inputs: pyHik + "hikvisioncam" = + ps: with ps; [ + hikvision + ]; + "hisense_aehw4a1" = + ps: with ps; [ + pyaehw4a1 + ]; + "history" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; + "history_stats" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; + "hitron_coda" = + ps: with ps; [ + ]; + "hive" = + ps: with ps; [ + pyhiveapi + ]; + "hko" = + ps: with ps; [ + ]; # missing inputs: hko + "hlk_sw16" = + ps: with ps; [ + hlk-sw16 + ]; + "holiday" = + ps: with ps; [ + babel + holidays + ]; + "home_connect" = + ps: with ps; [ + homeconnect + ]; + "home_plus_control" = + ps: with ps; [ + ]; + "homeassistant" = + ps: with ps; [ + ]; + "homeassistant_alerts" = + ps: with ps; [ + aiohasupervisor + ]; + "homeassistant_green" = + ps: with ps; [ + aiohasupervisor + pillow + psutil-home-assistant + pyserial + pyudev + universal-silabs-flasher + zha + ]; + "homeassistant_hardware" = + ps: with ps; [ + aiohasupervisor + pillow + pyserial + pyudev + universal-silabs-flasher + zha + ]; + "homeassistant_sky_connect" = + ps: with ps; [ + aiohasupervisor + pillow + psutil-home-assistant + pyserial + pyudev + universal-silabs-flasher + zha + ]; + "homeassistant_yellow" = + ps: with ps; [ + aiohasupervisor + pillow + psutil-home-assistant + pyserial + pyudev + universal-silabs-flasher + zha + ]; + "homekit" = + ps: with ps; [ + base36 + fnv-hash-fast + ha-ffmpeg + hap-python + ifaddr + pyqrcode + pyturbojpeg + zeroconf + ]; + "homekit_controller" = + ps: with ps; [ + aioesphomeapi + aiohomekit + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyroute2 + pyserial + pyspeex-noise + python-otbr-api + pyudev + zeroconf + ]; + "homematic" = + ps: with ps; [ + pyhomematic + ]; + "homematicip_cloud" = + ps: with ps; [ + homematicip + ]; + "homewizard" = + ps: with ps; [ + python-homewizard-energy + ]; + "homeworks" = + ps: with ps; [ + pyhomeworks + ]; + "honeywell" = + ps: with ps; [ + aiosomecomfort + ]; + "horizon" = + ps: with ps; [ + ]; # missing inputs: horimote + "hp_ilo" = + ps: with ps; [ + python-hpilo + ]; + "html5" = + ps: with ps; [ + pywebpush + ]; + "http" = + ps: with ps; [ + ]; + "huawei_lte" = + ps: with ps; [ + huawei-lte-api + stringcase + url-normalize + ]; + "hue" = + ps: with ps; [ + aiohue + ]; + "huisbaasje" = + ps: with ps; [ + energyflip-client + ]; + "humidifier" = + ps: with ps; [ + ]; + "hunterdouglas_powerview" = + ps: with ps; [ + aiopvapi + ]; + "hurrican_shutters_wholesale" = + ps: with ps; [ + ]; + "husqvarna_automower" = + ps: with ps; [ + aioautomower + ]; + "husqvarna_automower_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + automower-ble + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "huum" = + ps: with ps; [ + huum + ]; + "hvv_departures" = + ps: with ps; [ + pygti + ]; + "hydrawise" = + ps: with ps; [ + pydrawise + ]; + "hyperion" = + ps: with ps; [ + hyperion-py + ]; + "ialarm" = + ps: with ps; [ + pyialarm + ]; + "iammeter" = + ps: with ps; [ + iammeter + ]; + "iaqualink" = + ps: with ps; [ + h2 + iaqualink + ]; + "ibeacon" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ibeacon-ble + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "icloud" = + ps: with ps; [ + pyicloud + ]; + "idasen_desk" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + idasen-ha + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "idteck_prox" = + ps: with ps; [ + ]; # missing inputs: rfk101py + "ifttt" = + ps: with ps; [ + pyfttt + ]; + "iglo" = + ps: with ps; [ + ]; # missing inputs: iglo + "ign_sismologia" = + ps: with ps; [ + georss-ign-sismologia-client + ]; + "ihc" = + ps: with ps; [ + defusedxml + ihcsdk + ]; + "image" = + ps: with ps; [ + ]; + "image_processing" = + ps: with ps; [ + pyturbojpeg + ]; + "image_upload" = + ps: with ps; [ + pillow + ]; + "imap" = + ps: with ps; [ + aioimaplib + ]; + "imgw_pib" = + ps: with ps; [ + imgw-pib + ]; + "improv_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + py-improv-ble-client + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "incomfort" = + ps: with ps; [ + incomfort-client + ]; + "indianamichiganpower" = + ps: with ps; [ + ]; + "influxdb" = + ps: with ps; [ + influxdb + influxdb-client + ]; + "inkbird" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + inkbird-ble + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "input_boolean" = + ps: with ps; [ + ]; + "input_button" = + ps: with ps; [ + ]; + "input_datetime" = + ps: with ps; [ + ]; + "input_number" = + ps: with ps; [ + ]; + "input_select" = + ps: with ps; [ + ]; + "input_text" = + ps: with ps; [ + ]; + "inspired_shades" = + ps: with ps; [ + ]; + "insteon" = + ps: with ps; [ + aiohasupervisor + home-assistant-frontend + insteon-frontend-home-assistant + pillow + pyinsteon + pyserial + pyudev + ]; + "integration" = + ps: with ps; [ + ]; + "intellifire" = + ps: with ps; [ + intellifire4py + ]; + "intent" = + ps: with ps; [ + ]; + "intent_script" = + ps: with ps; [ + ]; + "intesishome" = + ps: with ps; [ + pyintesishome + ]; + "ios" = + ps: with ps; [ + ifaddr + zeroconf + ]; + "iotawatt" = + ps: with ps; [ + ]; # missing inputs: ha-iotawattpy + "iotty" = + ps: with ps; [ + iottycloud + ]; + "iperf3" = + ps: with ps; [ + ]; # missing inputs: iperf3 + "ipma" = + ps: with ps; [ + pyipma + ]; + "ipp" = + ps: with ps; [ + pyipp + ]; + "iqvia" = + ps: with ps; [ + numpy_1 + pyiqvia + ]; + "irish_rail_transport" = + ps: with ps; [ + ]; # missing inputs: pyirishrail + "iron_os" = + ps: with ps; [ + aioesphomeapi + aiogithubapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pynecil + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "isal" = + ps: with ps; [ + isal + ]; + "iskra" = + ps: with ps; [ + pyiskra + ]; + "islamic_prayer_times" = + ps: with ps; [ + prayer-times-calculator-offline + ]; + "ismartwindow" = + ps: with ps; [ + ]; + "israel_rail" = + ps: with ps; [ + israel-rail-api + ]; + "iss" = + ps: with ps; [ + ]; # missing inputs: pyiss + "ista_ecotrend" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + pyecotrend-ista + sqlalchemy + ]; + "isy994" = + ps: with ps; [ + pyisy + ]; + "itach" = + ps: with ps; [ + ]; # missing inputs: pyitachip2ir + "itunes" = + ps: with ps; [ + ]; + "izone" = + ps: with ps; [ + python-izone + ]; + "jellyfin" = + ps: with ps; [ + jellyfin-apiclient-python + ]; + "jewish_calendar" = + ps: with ps; [ + hdate + ]; + "joaoapps_join" = + ps: with ps; [ + ]; # missing inputs: python-join-api + "juicenet" = + ps: with ps; [ + python-juicenet + ]; + "justnimbus" = + ps: with ps; [ + justnimbus + ]; + "jvc_projector" = + ps: with ps; [ + ]; # missing inputs: pyjvcprojector + "kaiterra" = + ps: with ps; [ + ]; # missing inputs: kaiterra-async-client + "kaleidescape" = + ps: with ps; [ + pykaleidescape + ]; + "kankun" = + ps: with ps; [ + ]; + "keba" = + ps: with ps; [ + keba-kecontact + ]; + "keenetic_ndms2" = + ps: with ps; [ + ndms2-client + ]; + "kef" = + ps: with ps; [ + aiokef + getmac + ]; + "kegtron" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + kegtron-ble + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "kentuckypower" = + ps: with ps; [ + ]; + "keyboard" = + ps: with ps; [ + ]; # missing inputs: pyuserinput + "keyboard_remote" = + ps: with ps; [ + asyncinotify + evdev + ]; + "keymitt_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pymicrobot + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "kira" = + ps: with ps; [ + pykira + ]; + "kitchen_sink" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; + "kiwi" = + ps: with ps; [ + kiwiki-client + ]; + "kmtronic" = + ps: with ps; [ + pykmtronic + ]; + "knocki" = + ps: with ps; [ + knocki + ]; + "knx" = + ps: with ps; [ + aiohasupervisor + home-assistant-frontend + knx-frontend + pillow + xknx + xknxproject + ]; + "kodi" = + ps: with ps; [ + pykodi + ]; + "konnected" = + ps: with ps; [ + konnected + ]; + "kostal_plenticore" = + ps: with ps; [ + pykoplenti + ]; + "kraken" = + ps: with ps; [ + krakenex + pykrakenapi + ]; + "krispol" = + ps: with ps; [ + ]; + "kulersky" = + ps: with ps; [ + pykulersky + ]; + "kwb" = + ps: with ps; [ + pykwb + ]; + "lacrosse" = + ps: with ps; [ + pylacrosse + ]; + "lacrosse_view" = + ps: with ps; [ + ]; # missing inputs: lacrosse-view + "lamarzocco" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; # missing inputs: lmcloud + "lametric" = + ps: with ps; [ + demetriek + ]; + "landisgyr_heat_meter" = + ps: with ps; [ + pyserial + pyudev + ultraheat-api + ]; + "lannouncer" = + ps: with ps; [ + ]; + "lastfm" = + ps: with ps; [ + pylast + ]; + "launch_library" = + ps: with ps; [ + pylaunches + ]; + "laundrify" = + ps: with ps; [ + laundrify-aio + ]; + "lawn_mower" = + ps: with ps; [ + ]; + "lcn" = + ps: with ps; [ + aiohasupervisor + home-assistant-frontend + lcn-frontend + pillow + pypck + ]; + "ld2410_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + ld2410-ble + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "leaone" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + leaone-ble + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "led_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + led-ble + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "legrand" = + ps: with ps; [ + ]; + "lektrico" = + ps: with ps; [ + lektricowifi + ]; + "lg_netcast" = + ps: with ps; [ + ifaddr + pylgnetcast + ]; + "lg_soundbar" = + ps: with ps; [ + temescal + ]; + "lg_thinq" = + ps: with ps; [ + thinqconnect + ]; + "lidarr" = + ps: with ps; [ + aiopyarr + ]; + "life360" = + ps: with ps; [ + ]; + "lifx" = + ps: with ps; [ + aiolifx + aiolifx-effects + aiolifx-themes + ifaddr + ]; + "lifx_cloud" = + ps: with ps; [ + ]; + "light" = + ps: with ps; [ + ]; + "lightwave" = + ps: with ps; [ + lightwave + ]; + "limitlessled" = + ps: with ps; [ + limitlessled + ]; + "linear_garage_door" = + ps: with ps; [ + linear-garage-door + ]; + "linkplay" = + ps: with ps; [ + python-linkplay + ]; + "linksys_smart" = + ps: with ps; [ + ]; + "linode" = + ps: with ps; [ + linode-api + ]; + "linux_battery" = + ps: with ps; [ + batinfo + ]; + "lirc" = + ps: with ps; [ + ]; # missing inputs: python-lirc + "litejet" = + ps: with ps; [ + pylitejet + ]; + "litterrobot" = + ps: with ps; [ + pylitterbot + ]; + "livisi" = + ps: with ps; [ + aiolivisi + ]; + "llamalab_automate" = + ps: with ps; [ + ]; + "local_calendar" = + ps: with ps; [ + ical + ]; + "local_file" = + ps: with ps; [ + ]; + "local_ip" = + ps: with ps; [ + ifaddr + ]; + "local_todo" = + ps: with ps; [ + ical + ]; + "locative" = + ps: with ps; [ + ]; + "lock" = + ps: with ps; [ + ]; + "logbook" = + ps: with ps; [ + aiohasupervisor + fnv-hash-fast + home-assistant-frontend + pillow + psutil-home-assistant + sqlalchemy + ]; + "logentries" = + ps: with ps; [ + ]; + "logger" = + ps: with ps; [ + ]; + "london_air" = + ps: with ps; [ + ]; + "london_underground" = + ps: with ps; [ + ]; # missing inputs: london-tube-status + "lookin" = + ps: with ps; [ + aiolookin + ]; + "loqed" = + ps: with ps; [ + aiohasupervisor + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-intents + loqedapi + mutagen + pymicro-vad + pyspeex-noise + python-matter-server + pyturbojpeg + ]; + "lovelace" = + ps: with ps; [ + aiohasupervisor + pillow + ]; + "luci" = + ps: with ps; [ + openwrt-luci-rpc + ]; + "luftdaten" = + ps: with ps; [ + luftdaten + ]; + "lupusec" = + ps: with ps; [ + lupupy + ]; + "lutron" = + ps: with ps; [ + pylutron + ]; + "lutron_caseta" = + ps: with ps; [ + pylutron-caseta + ]; + "luxaflex" = + ps: with ps; [ + ]; + "lw12wifi" = + ps: with ps; [ + ]; # missing inputs: lw12 + "lyric" = + ps: with ps; [ + aiolyric + ]; + "madeco" = + ps: with ps; [ + ]; + "madvr" = + ps: with ps; [ + py-madvr2 + ]; + "mailgun" = + ps: with ps; [ + pymailgunner + ]; + "manual" = + ps: with ps; [ + ]; + "manual_mqtt" = + ps: with ps; [ + aiohasupervisor + paho-mqtt_1 + ]; + "marantz" = + ps: with ps; [ + ]; + "martec" = + ps: with ps; [ + ]; + "marytts" = + ps: with ps; [ + ]; # missing inputs: speak2mary + "mastodon" = + ps: with ps; [ + mastodon-py + ]; + "matrix" = + ps: with ps; [ + matrix-nio + pillow + ]; + "matter" = + ps: with ps; [ + aiohasupervisor + python-matter-server + ]; + "maxcube" = + ps: with ps; [ + maxcube-api + ]; + "mazda" = + ps: with ps; [ + ]; + "mealie" = + ps: with ps; [ + aiomealie + ]; + "meater" = + ps: with ps; [ + meater-python + ]; + "medcom_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; # missing inputs: medcom-ble + "media_extractor" = + ps: + with ps; + [ + yt-dlp + ] + ++ yt-dlp.optional-dependencies.default; + "media_player" = + ps: with ps; [ + ]; + "media_source" = + ps: with ps; [ + ]; + "mediaroom" = + ps: with ps; [ + pymediaroom + ]; + "melcloud" = + ps: with ps; [ + pymelcloud + ]; + "melissa" = + ps: with ps; [ + ]; # missing inputs: py-melissa-climate + "melnor" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + melnor-bluetooth + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "meraki" = + ps: with ps; [ + ]; + "mercury_nz" = + ps: with ps; [ + ]; + "message_bird" = + ps: with ps; [ + messagebird + ]; + "met" = + ps: with ps; [ + pymetno + ]; + "met_eireann" = + ps: with ps; [ + pymeteireann + ]; + "meteo_france" = + ps: with ps; [ + meteofrance-api + ]; + "meteoalarm" = + ps: with ps; [ + meteoalertapi + ]; + "meteoclimatic" = + ps: with ps; [ + pymeteoclimatic + ]; + "metoffice" = + ps: with ps; [ + datapoint + ]; + "mfi" = + ps: with ps; [ + ]; # missing inputs: mficlient + "microbees" = + ps: with ps; [ + ]; # missing inputs: microBeesPy + "microsoft" = + ps: with ps; [ + ]; # missing inputs: pycsspeechtts + "microsoft_face" = + ps: with ps; [ + pyturbojpeg + ]; + "microsoft_face_detect" = + ps: with ps; [ + pyturbojpeg + ]; + "microsoft_face_identify" = + ps: with ps; [ + pyturbojpeg + ]; + "mijndomein_energie" = + ps: with ps; [ + ]; + "mikrotik" = + ps: with ps; [ + librouteros + ]; + "mill" = + ps: with ps; [ + mill-local + millheater + ]; + "min_max" = + ps: with ps; [ + ]; + "minecraft_server" = + ps: with ps; [ + mcstatus + ]; + "mini_connected" = + ps: with ps; [ + ]; + "minio" = + ps: with ps; [ + minio + ]; + "mjpeg" = + ps: with ps; [ + ]; + "moat" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + moat-ble + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "mobile_app" = + ps: with ps; [ + aiohasupervisor + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-intents + mutagen + pillow + pymicro-vad + pynacl + pyspeex-noise + python-matter-server + pyturbojpeg + ]; + "mochad" = + ps: with ps; [ + ]; # missing inputs: pymochad + "modbus" = + ps: with ps; [ + pymodbus + ]; + "modem_callerid" = + ps: with ps; [ + phone-modem + pyserial + pyudev + ]; + "modern_forms" = + ps: with ps; [ + aiomodernforms + ]; + "moehlenhoff_alpha2" = + ps: with ps; [ + ]; # missing inputs: moehlenhoff-alpha2 + "mold_indicator" = + ps: with ps; [ + ]; + "monarch_money" = + ps: with ps; [ + ]; # missing inputs: typedmonarchmoney + "monessen" = + ps: with ps; [ + ]; + "monoprice" = + ps: with ps; [ + ]; # missing inputs: pymonoprice + "monzo" = + ps: with ps; [ + monzopy + ]; + "moon" = + ps: with ps; [ + ]; + "mopeka" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mopeka-iot-ble + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "motion_blinds" = + ps: with ps; [ + ifaddr + motionblinds + ]; + "motionblinds_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + motionblindsble + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "motioneye" = + ps: with ps; [ + motioneye-client + ]; + "motionmount" = + ps: with ps; [ + python-motionmount + ]; + "mpd" = + ps: with ps; [ + mpd2 + ]; + "mqtt" = + ps: with ps; [ + aiohasupervisor + paho-mqtt_1 + ]; + "mqtt_eventstream" = + ps: with ps; [ + aiohasupervisor + paho-mqtt_1 + ]; + "mqtt_json" = + ps: with ps; [ + aiohasupervisor + paho-mqtt_1 + ]; + "mqtt_room" = + ps: with ps; [ + aiohasupervisor + paho-mqtt_1 + ]; + "mqtt_statestream" = + ps: with ps; [ + aiohasupervisor + paho-mqtt_1 + ]; + "msteams" = + ps: with ps; [ + pymsteams + ]; + "mullvad" = + ps: with ps; [ + mullvad-api + ]; + "mutesync" = + ps: with ps; [ + mutesync + ]; + "my" = + ps: with ps; [ + aiohasupervisor + home-assistant-frontend + pillow + ]; + "myq" = + ps: with ps; [ + ]; + "mysensors" = + ps: with ps; [ + aiohasupervisor + paho-mqtt_1 + pymysensors + ]; + "mystrom" = + ps: with ps; [ + python-mystrom + ]; + "mythicbeastsdns" = + ps: with ps; [ + mbddns + ]; + "myuplink" = + ps: with ps; [ + myuplink + ]; + "nad" = + ps: with ps; [ + nad-receiver + ]; + "nam" = + ps: with ps; [ + nettigo-air-monitor + ]; + "namecheapdns" = + ps: with ps; [ + defusedxml + ]; + "nanoleaf" = + ps: with ps; [ + aionanoleaf + ]; + "neato" = + ps: with ps; [ + pybotvac + ]; + "nederlandse_spoorwegen" = + ps: with ps; [ + nsapi + ]; + "ness_alarm" = + ps: with ps; [ + nessclient + ]; + "nest" = + ps: with ps; [ + google-nest-sdm + ha-ffmpeg + ]; + "netatmo" = + ps: with ps; [ + aiohasupervisor + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-intents + mutagen + pyatmo + pymicro-vad + pyspeex-noise + python-matter-server + pyturbojpeg + ]; + "netdata" = + ps: with ps; [ + netdata + ]; + "netgear" = + ps: with ps; [ + pynetgear + ]; + "netgear_lte" = + ps: with ps; [ + eternalegypt + ]; + "netio" = + ps: with ps; [ + ]; # missing inputs: pynetio + "network" = + ps: with ps; [ + ifaddr + ]; + "neurio_energy" = + ps: with ps; [ + ]; # missing inputs: neurio + "nexia" = + ps: with ps; [ + nexia + ]; + "nexity" = + ps: with ps; [ + ]; + "nextbus" = + ps: with ps; [ + py-nextbusnext + ]; + "nextcloud" = + ps: with ps; [ + nextcloudmonitor + ]; + "nextdns" = + ps: with ps; [ + nextdns + ]; + "nfandroidtv" = + ps: with ps; [ + notifications-android-tv + ]; + "nibe_heatpump" = + ps: with ps; [ + nibe + ]; + "nice_go" = + ps: with ps; [ + nice-go + ]; + "nightscout" = + ps: with ps; [ + py-nightscout + ]; + "niko_home_control" = + ps: with ps; [ + niko-home-control + ]; + "nilu" = + ps: with ps; [ + niluclient + ]; + "nina" = + ps: with ps; [ + pynina + ]; + "nissan_leaf" = + ps: with ps; [ + pycarwings2 + ]; + "nmap_tracker" = + ps: with ps; [ + aiooui + getmac + ifaddr + netmap + ]; + "nmbs" = + ps: with ps; [ + ]; # missing inputs: pyrail + "no_ip" = + ps: with ps; [ + ]; + "noaa_tides" = + ps: with ps; [ + ]; # missing inputs: noaa-coops + "nobo_hub" = + ps: with ps; [ + pynobo + ]; + "norway_air" = + ps: with ps; [ + pymetno + ]; + "notify" = + ps: with ps; [ + ]; + "notify_events" = + ps: with ps; [ + notify-events + ]; + "notion" = + ps: with ps; [ + aionotion + ]; + "nsw_fuel_station" = + ps: with ps; [ + ]; # missing inputs: nsw-fuel-api-client + "nsw_rural_fire_service_feed" = + ps: with ps; [ + aio-geojson-nsw-rfs-incidents + ]; + "nuheat" = + ps: with ps; [ + nuheat + ]; + "nuki" = + ps: with ps; [ + pynuki + ]; + "numato" = + ps: with ps; [ + ]; # missing inputs: numato-gpio + "number" = + ps: with ps; [ + ]; + "nut" = + ps: with ps; [ + aionut + ]; + "nutrichef" = + ps: with ps; [ + ]; + "nws" = + ps: + with ps; + [ + pynws + ] + ++ pynws.optional-dependencies.retry; + "nx584" = + ps: with ps; [ + pynx584 + ]; + "nyt_games" = + ps: with ps; [ + ]; # missing inputs: nyt_games + "nzbget" = + ps: with ps; [ + ]; # missing inputs: pynzbgetapi + "oasa_telematics" = + ps: with ps; [ + oasatelematics + ]; + "obihai" = + ps: with ps; [ + pyobihai + ]; + "octoprint" = + ps: with ps; [ + pyoctoprintapi + ]; + "oem" = + ps: with ps; [ + oemthermostat + ]; + "ohmconnect" = + ps: with ps; [ + defusedxml + ]; + "ollama" = + ps: with ps; [ + ha-ffmpeg + hassil + home-assistant-intents + mutagen + ollama + pymicro-vad + pyspeex-noise + ]; + "ombi" = + ps: with ps; [ + pyombi + ]; + "omnilogic" = + ps: with ps; [ + omnilogic + ]; + "onboarding" = + ps: with ps; [ + aiohasupervisor + pillow + ]; + "oncue" = + ps: with ps; [ + aiooncue + ]; + "ondilo_ico" = + ps: with ps; [ + ondilo + ]; + "onewire" = + ps: with ps; [ + pyownet + ]; + "onkyo" = + ps: with ps; [ + ]; # missing inputs: pyeiscp + "onvif" = + ps: with ps; [ + ha-ffmpeg + onvif-zeep-async + wsdiscovery + ]; + "open_meteo" = + ps: with ps; [ + open-meteo + ]; + "openai_conversation" = + ps: with ps; [ + ha-ffmpeg + hassil + home-assistant-intents + mutagen + openai + pymicro-vad + pyspeex-noise + ]; + "openalpr_cloud" = + ps: with ps; [ + ]; + "openerz" = + ps: with ps; [ + openerz-api + ]; + "openevse" = + ps: with ps; [ + openevsewifi + ]; + "openexchangerates" = + ps: with ps; [ + aioopenexchangerates + ]; + "opengarage" = + ps: with ps; [ + open-garage + ]; + "openhardwaremonitor" = + ps: with ps; [ + ]; + "openhome" = + ps: with ps; [ + openhomedevice + ]; + "opensensemap" = + ps: with ps; [ + opensensemap-api + ]; + "opensky" = + ps: with ps; [ + python-opensky + ]; + "opentherm_gw" = + ps: with ps; [ + pyotgw + ]; + "openuv" = + ps: with ps; [ + pyopenuv + ]; + "openweathermap" = + ps: with ps; [ + pyopenweathermap + ]; + "opnsense" = + ps: with ps; [ + pyopnsense + ]; + "opower" = + ps: with ps; [ + fnv-hash-fast + opower + psutil-home-assistant + sqlalchemy + ]; + "opple" = + ps: with ps; [ + ]; # missing inputs: pyoppleio-legacy + "oralb" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + oralb-ble + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "oru" = + ps: with ps; [ + ]; # missing inputs: oru + "oru_opower" = + ps: with ps; [ + ]; + "orvibo" = + ps: with ps; [ + orvibo + ]; + "osoenergy" = + ps: with ps; [ + ]; # missing inputs: pyosoenergyapi + "osramlightify" = + ps: with ps; [ + ]; # missing inputs: lightify + "otbr" = + ps: with ps; [ + aiohasupervisor + ifaddr + pillow + psutil-home-assistant + pyroute2 + pyserial + python-otbr-api + pyudev + universal-silabs-flasher + zeroconf + zha + ]; + "otp" = + ps: with ps; [ + pyotp + ]; + "ourgroceries" = + ps: with ps; [ + ]; # missing inputs: ourgroceries + "overkiz" = + ps: with ps; [ + pyoverkiz + ]; + "ovo_energy" = + ps: with ps; [ + ovoenergy + ]; + "owntracks" = + ps: with ps; [ + aiohasupervisor + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-intents + mutagen + paho-mqtt_1 + pymicro-vad + pynacl + pyspeex-noise + python-matter-server + pyturbojpeg + ]; + "p1_monitor" = + ps: with ps; [ + p1monitor + ]; + "palazzetti" = + ps: with ps; [ + pypalazzetti + ]; + "panasonic_bluray" = + ps: with ps; [ + panacotta + ]; + "panasonic_viera" = + ps: with ps; [ + panasonic-viera + ]; + "pandora" = + ps: with ps; [ + pexpect + ]; + "panel_custom" = + ps: with ps; [ + aiohasupervisor + home-assistant-frontend + pillow + ]; + "pcs_lighting" = + ps: with ps; [ + ]; + "peco" = + ps: with ps; [ + peco + ]; + "peco_opower" = + ps: with ps; [ + ]; + "pegel_online" = + ps: with ps; [ + aiopegelonline + ]; + "pencom" = + ps: with ps; [ + pencompy + ]; + "pepco" = + ps: with ps; [ + ]; + "permobil" = + ps: with ps; [ + mypermobil + ]; + "persistent_notification" = + ps: with ps; [ + ]; + "person" = + ps: with ps; [ + pillow + ]; + "pge" = + ps: with ps; [ + ]; + "philips_js" = + ps: with ps; [ + ha-philipsjs + ]; + "pi_hole" = + ps: with ps; [ + hole + ]; + "picnic" = + ps: with ps; [ + python-picnic-api + ]; + "picotts" = + ps: with ps; [ + ]; + "pilight" = + ps: with ps; [ + ]; # missing inputs: pilight + "pinecil" = + ps: with ps; [ + ]; + "ping" = + ps: with ps; [ + icmplib + ]; + "pioneer" = + ps: with ps; [ + ]; + "piper" = + ps: with ps; [ + ]; + "pjlink" = + ps: with ps; [ + ]; # missing inputs: pypjlink2 + "plaato" = + ps: with ps; [ + aiohasupervisor + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-intents + mutagen + pymicro-vad + pyplaato + pyspeex-noise + python-matter-server + pyturbojpeg + ]; + "plant" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; + "plex" = + ps: with ps; [ + plexapi + plexauth + plexwebsocket + ]; + "plugwise" = + ps: with ps; [ + plugwise + ]; + "plum_lightpad" = + ps: with ps; [ + ]; # missing inputs: plumlightpad + "pocketcasts" = + ps: with ps; [ + pycketcasts + ]; + "point" = + ps: with ps; [ + pypoint + ]; + "poolsense" = + ps: with ps; [ + poolsense + ]; + "portlandgeneral" = + ps: with ps; [ + ]; + "powerwall" = + ps: with ps; [ + tesla-powerwall + ]; + "private_ble_device" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + zeroconf + ]; + "profiler" = + ps: with ps; [ + guppy3 + objgraph + pyprof2calltree + ]; + "progettihwsw" = + ps: with ps; [ + ]; # missing inputs: ProgettiHWSW + "proliphix" = + ps: with ps; [ + ]; # missing inputs: proliphix + "prometheus" = + ps: with ps; [ + prometheus-client + ]; + "prosegur" = + ps: with ps; [ + pyprosegur + ]; + "prowl" = + ps: with ps; [ + ]; + "proximity" = + ps: with ps; [ + ]; + "proxmoxve" = + ps: with ps; [ + proxmoxer + ]; + "proxy" = + ps: with ps; [ + pillow + ]; + "prusalink" = + ps: with ps; [ + pyprusalink + ]; + "ps4" = + ps: with ps; [ + ]; # missing inputs: pyps4-2ndscreen + "pse" = + ps: with ps; [ + ]; + "psoklahoma" = + ps: with ps; [ + ]; + "pulseaudio_loopback" = + ps: with ps; [ + pulsectl + ]; + "pure_energie" = + ps: with ps; [ + gridnet + ]; + "purpleair" = + ps: with ps; [ + aiopurpleair + ]; + "push" = + ps: with ps; [ + ]; + "pushbullet" = + ps: with ps; [ + pushbullet-py + ]; + "pushover" = + ps: with ps; [ + pushover-complete + ]; + "pushsafer" = + ps: with ps; [ + ]; + "pvoutput" = + ps: with ps; [ + pvo + ]; + "pvpc_hourly_pricing" = + ps: with ps; [ + aiopvpc + ]; + "pyload" = + ps: with ps; [ + pyloadapi + ]; + "python_script" = + ps: with ps; [ + restrictedpython + ]; + "qbittorrent" = + ps: with ps; [ + qbittorrent-api + ]; + "qingping" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + qingping-ble + zeroconf + ]; + "qld_bushfire" = + ps: with ps; [ + georss-qld-bushfire-alert-client + ]; + "qnap" = + ps: with ps; [ + qnapstats + ]; + "qnap_qsw" = + ps: with ps; [ + aioqsw + ]; + "qrcode" = + ps: with ps; [ + pillow + pyzbar + ]; + "quadrafire" = + ps: with ps; [ + ]; + "quantum_gateway" = + ps: with ps; [ + quantum-gateway + ]; + "qvr_pro" = + ps: with ps; [ + pyqvrpro + ]; + "qwikswitch" = + ps: with ps; [ + pyqwikswitch + ]; + "rabbitair" = + ps: with ps; [ + ifaddr + python-rabbitair + zeroconf + ]; + "rachio" = + ps: with ps; [ + aiohasupervisor + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-intents + mutagen + pymicro-vad + pyspeex-noise + python-matter-server + pyturbojpeg + rachiopy + ]; + "radarr" = + ps: with ps; [ + aiopyarr + ]; + "radio_browser" = + ps: with ps; [ + pycountry + radios + ]; + "radiotherm" = + ps: with ps; [ + radiotherm + ]; + "rainbird" = + ps: with ps; [ + pyrainbird + ]; + "raincloud" = + ps: with ps; [ + raincloudy + ]; + "rainforest_eagle" = + ps: with ps; [ + aioeagle + eagle100 + ]; + "rainforest_raven" = + ps: with ps; [ + aioraven + pyserial + pyudev + ]; + "rainmachine" = + ps: with ps; [ + regenmaschine + ]; + "random" = + ps: with ps; [ + ]; + "rapt_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + rapt-ble + zeroconf + ]; + "raspberry_pi" = + ps: with ps; [ + aiohasupervisor + psutil-home-assistant + ]; + "raspyrfm" = + ps: with ps; [ + ]; # missing inputs: raspyrfm-client + "raven_rock_mfg" = + ps: with ps; [ + ]; + "rdw" = + ps: with ps; [ + vehicle + ]; + "recollect_waste" = + ps: with ps; [ + aiorecollect + ]; + "recorder" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; + "recovery_mode" = + ps: with ps; [ + aiohasupervisor + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-frontend + home-assistant-intents + mutagen + pillow + pymicro-vad + pyspeex-noise + python-matter-server + pyturbojpeg + ]; + "recswitch" = + ps: with ps; [ + ]; # missing inputs: pyrecswitch + "reddit" = + ps: with ps; [ + praw + ]; + "refoss" = + ps: with ps; [ + refoss-ha + ]; + "rejseplanen" = + ps: with ps; [ + rjpl + ]; + "remember_the_milk" = + ps: with ps; [ + httplib2 + ]; # missing inputs: RtmAPI + "remote" = + ps: with ps; [ + ]; + "remote_rpi_gpio" = + ps: with ps; [ + gpiozero + ]; # missing inputs: pigpio + "renault" = + ps: with ps; [ + renault-api + ]; + "renson" = + ps: with ps; [ + renson-endura-delta + ]; + "reolink" = + ps: with ps; [ + reolink-aio + ]; + "repairs" = + ps: with ps; [ + ]; + "repetier" = + ps: with ps; [ + ]; # missing inputs: pyrepetierng + "rest" = + ps: with ps; [ + jsonpath + xmltodict + ]; + "rest_command" = + ps: with ps; [ + ]; + "rexel" = + ps: with ps; [ + ]; + "rflink" = + ps: with ps; [ + rflink + ]; + "rfxtrx" = + ps: with ps; [ + pyrfxtrx + ]; + "rhasspy" = + ps: with ps; [ + ]; + "ridwell" = + ps: with ps; [ + aioridwell + ]; + "ring" = + ps: with ps; [ + ha-ffmpeg + ring-doorbell + ]; + "ripple" = + ps: with ps; [ + ]; # missing inputs: python-ripple-api + "risco" = + ps: with ps; [ + pyrisco + ]; + "rituals_perfume_genie" = + ps: with ps; [ + pyrituals + ]; + "rmvtransport" = + ps: with ps; [ + pyrmvtransport + ]; + "roborock" = + ps: with ps; [ + python-roborock + vacuum-map-parser-roborock + ]; + "rocketchat" = + ps: with ps; [ + rocketchat-api + ]; + "roku" = + ps: with ps; [ + rokuecp + ]; + "romy" = + ps: with ps; [ + romy + ]; + "roomba" = + ps: with ps; [ + roombapy + ]; + "roon" = + ps: with ps; [ + roonapi + ]; + "route53" = + ps: with ps; [ + boto3 + ]; + "rova" = + ps: with ps; [ + rova + ]; + "rpi_camera" = + ps: with ps; [ + ]; + "rpi_power" = + ps: with ps; [ + rpi-bad-power + ]; + "rss_feed_template" = + ps: with ps; [ + ]; + "rtorrent" = + ps: with ps; [ + ]; + "rtsp_to_webrtc" = + ps: with ps; [ + pyturbojpeg + rtsp-to-webrtc + ]; + "ruckus_unleashed" = + ps: with ps; [ + aioruckus + ]; + "russound_rio" = + ps: with ps; [ + aiorussound + ]; + "russound_rnet" = + ps: with ps; [ + ]; # missing inputs: russound + "ruuvi_gateway" = + ps: with ps; [ + aioruuvigateway + bleak + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + habluetooth + pyserial + pyudev + ]; + "ruuvitag_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + ruuvitag-ble + zeroconf + ]; + "rympro" = + ps: with ps; [ + pyrympro + ]; + "sabnzbd" = + ps: with ps; [ + pysabnzbd + ]; + "saj" = + ps: with ps; [ + pysaj + ]; + "samsam" = + ps: with ps; [ + ]; + "samsungtv" = + ps: + with ps; + [ + async-upnp-client + getmac + ifaddr + samsungctl + samsungtvws + wakeonlan + ] + ++ samsungctl.optional-dependencies.websocket + ++ samsungtvws.optional-dependencies.async + ++ samsungtvws.optional-dependencies.encrypted; + "sanix" = + ps: with ps; [ + sanix + ]; + "satel_integra" = + ps: with ps; [ + ]; # missing inputs: satel-integra + "scene" = + ps: with ps; [ + ]; + "schedule" = + ps: with ps; [ + ]; + "schlage" = + ps: with ps; [ + pyschlage + ]; + "schluter" = + ps: with ps; [ + ]; # missing inputs: py-schluter + "scl" = + ps: with ps; [ + ]; + "scrape" = + ps: with ps; [ + beautifulsoup4 + jsonpath + lxml + xmltodict + ]; + "screenaway" = + ps: with ps; [ + ]; + "screenlogic" = + ps: with ps; [ + screenlogicpy + ]; + "script" = + ps: with ps; [ + ]; + "scsgate" = + ps: with ps; [ + ]; # missing inputs: scsgate + "search" = + ps: with ps; [ + ]; + "season" = + ps: with ps; [ + ephem + ]; + "select" = + ps: with ps; [ + ]; + "sendgrid" = + ps: with ps; [ + sendgrid + ]; + "sense" = + ps: with ps; [ + sense-energy + ]; + "sensibo" = + ps: with ps; [ + pysensibo + ]; + "sensirion_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + sensirion-ble + zeroconf + ]; + "sensor" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; + "sensorblue" = + ps: with ps; [ + ]; + "sensorpro" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + sensorpro-ble + zeroconf + ]; + "sensorpush" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + sensorpush-ble + zeroconf + ]; + "sensoterra" = + ps: with ps; [ + sensoterra + ]; + "sentry" = + ps: with ps; [ + sentry-sdk + ]; + "senz" = + ps: with ps; [ + aiosenz + ]; + "serial" = + ps: with ps; [ + pyserial-asyncio-fast + ]; + "serial_pm" = + ps: with ps; [ + pmsensor + ]; + "sesame" = + ps: with ps; [ + ]; # missing inputs: pysesame2 + "seven_segments" = + ps: with ps; [ + pillow + ]; + "seventeentrack" = + ps: with ps; [ + pyseventeentrack + ]; + "sfr_box" = + ps: with ps; [ + sfrbox-api + ]; + "sharkiq" = + ps: with ps; [ + sharkiq + ]; + "shell_command" = + ps: with ps; [ + ]; + "shelly" = + ps: with ps; [ + aioshelly + bleak + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + habluetooth + ifaddr + pyserial + pyudev + ]; + "shodan" = + ps: with ps; [ + shodan + ]; + "shopping_list" = + ps: with ps; [ + ]; + "sia" = + ps: with ps; [ + pysiaalarm + ]; + "sigfox" = + ps: with ps; [ + ]; + "sighthound" = + ps: with ps; [ + pillow + simplehound + ]; + "signal_messenger" = + ps: with ps; [ + pysignalclirestapi + ]; + "simplefin" = + ps: with ps; [ + simplefin4py + ]; + "simplepush" = + ps: with ps; [ + simplepush + ]; + "simplisafe" = + ps: with ps; [ + simplisafe-python + ]; + "simply_automated" = + ps: with ps; [ + ]; + "simu" = + ps: with ps; [ + ]; + "simulated" = + ps: with ps; [ + ]; + "sinch" = + ps: with ps; [ + ]; # missing inputs: clx-sdk-xms + "siren" = + ps: with ps; [ + ]; + "sisyphus" = + ps: with ps; [ + sisyphus-control + ]; + "sky_hub" = + ps: with ps; [ + pyskyqhub + ]; + "skybeacon" = + ps: + with ps; + [ + pygatt + ] + ++ pygatt.optional-dependencies.GATTTOOL; + "skybell" = + ps: with ps; [ + aioskybell + ha-ffmpeg + ]; + "slack" = + ps: with ps; [ + slack-sdk + ]; + "sleepiq" = + ps: with ps; [ + asyncsleepiq + ]; + "slide" = + ps: with ps; [ + ]; # missing inputs: goslide-api + "slimproto" = + ps: with ps; [ + aioslimproto + ]; + "sma" = + ps: with ps; [ + pysma + ]; + "smappee" = + ps: with ps; [ + pysmappee + ]; + "smart_blinds" = + ps: with ps; [ + ]; + "smart_home" = + ps: with ps; [ + ]; + "smart_meter_texas" = + ps: with ps; [ + smart-meter-texas + ]; + "smarther" = + ps: with ps; [ + ]; + "smartthings" = + ps: with ps; [ + aiohasupervisor + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-intents + mutagen + pymicro-vad + pysmartapp + pysmartthings + pyspeex-noise + python-matter-server + pyturbojpeg + ]; + "smarttub" = + ps: with ps; [ + python-smarttub + ]; + "smarty" = + ps: with ps; [ + ]; # missing inputs: pysmarty2 + "smhi" = + ps: with ps; [ + smhi-pkg + ]; + "smlight" = + ps: with ps; [ + pysmlight + ]; + "sms" = + ps: with ps; [ + python-gammu + ]; + "smtp" = + ps: with ps; [ + ]; + "smud" = + ps: with ps; [ + ]; + "snapcast" = + ps: with ps; [ + snapcast + ]; + "snips" = + ps: with ps; [ + aiohasupervisor + paho-mqtt_1 + ]; + "snmp" = + ps: with ps; [ + pysnmp + ]; + "snooz" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pysnooz + pyspeex-noise + pyudev + zeroconf + ]; + "solaredge" = + ps: with ps; [ + aiosolaredge + stringcase + ]; + "solaredge_local" = + ps: with ps; [ + ]; # missing inputs: solaredge-local + "solarlog" = + ps: with ps; [ + solarlog-cli + ]; + "solax" = + ps: with ps; [ + solax + ]; + "soma" = + ps: with ps; [ + pysoma + ]; + "somfy" = + ps: with ps; [ + ]; + "somfy_mylink" = + ps: with ps; [ + somfy-mylink-synergy + ]; + "sonarr" = + ps: with ps; [ + aiopyarr + ]; + "songpal" = + ps: with ps; [ + python-songpal + ]; + "sonos" = + ps: with ps; [ + async-upnp-client + ifaddr + plexapi + plexauth + plexwebsocket + soco + sonos-websocket + spotifyaio + zeroconf + ]; + "sony_projector" = + ps: with ps; [ + pysdcp + ]; + "soundtouch" = + ps: with ps; [ + libsoundtouch + ]; + "spaceapi" = + ps: with ps; [ + ]; + "spc" = + ps: with ps; [ + pyspcwebgw + ]; + "speedtestdotnet" = + ps: with ps; [ + speedtest-cli + ]; + "spider" = + ps: with ps; [ + ]; + "splunk" = + ps: with ps; [ + hass-splunk + ]; + "spotify" = + ps: with ps; [ + spotifyaio + ]; + "sql" = + ps: with ps; [ + sqlalchemy + sqlparse + ]; + "squeezebox" = + ps: with ps; [ + pysqueezebox + ]; + "srp_energy" = + ps: with ps; [ + srpenergy + ]; + "ssdp" = + ps: with ps; [ + async-upnp-client + ifaddr + ]; + "starline" = + ps: with ps; [ + starline + ]; + "starlingbank" = + ps: with ps; [ + ]; # missing inputs: starlingbank + "starlink" = + ps: with ps; [ + ]; # missing inputs: starlink-grpc-core + "startca" = + ps: with ps; [ + xmltodict + ]; + "statistics" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + sqlalchemy + ]; + "statsd" = + ps: with ps; [ + statsd + ]; + "steam_online" = + ps: with ps; [ + steamodd + ]; + "steamist" = + ps: with ps; [ + aiosteamist + discovery30303 + ifaddr + ]; + "stiebel_eltron" = + ps: with ps; [ + pymodbus + ]; # missing inputs: pystiebeleltron + "stookalert" = + ps: with ps; [ + stookalert + ]; + "stookwijzer" = + ps: with ps; [ + stookwijzer + ]; + "stream" = + ps: with ps; [ + av + numpy_1 + pyturbojpeg + ]; + "streamlabswater" = + ps: with ps; [ + streamlabswater + ]; + "stt" = + ps: with ps; [ + ]; + "subaru" = + ps: with ps; [ + subarulink + ]; + "suez_water" = + ps: with ps; [ + pysuez + ]; + "sun" = + ps: with ps; [ + ]; + "sunweg" = + ps: with ps; [ + sunweg + ]; + "supervisord" = + ps: with ps; [ + ]; + "supla" = + ps: with ps; [ + ]; # missing inputs: asyncpysupla + "surepetcare" = + ps: with ps; [ + surepy + ]; + "swepco" = + ps: with ps; [ + ]; + "swiss_hydrological_data" = + ps: with ps; [ + swisshydrodata + ]; + "swiss_public_transport" = + ps: with ps; [ + python-opendata-transport + ]; + "swisscom" = + ps: with ps; [ + ]; + "switch" = + ps: with ps; [ + ]; + "switch_as_x" = + ps: with ps; [ + ]; + "switchbee" = + ps: with ps; [ + pyswitchbee + ]; + "switchbot" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyswitchbot + pyudev + zeroconf + ]; + "switchbot_cloud" = + ps: with ps; [ + switchbot-api + ]; + "switcher_kis" = + ps: with ps; [ + aioswitcher + ]; + "switchmate" = + ps: with ps; [ + ]; # missing inputs: PySwitchmate + "symfonisk" = + ps: with ps; [ + ]; + "syncthing" = + ps: with ps; [ + aiosyncthing + ]; + "syncthru" = + ps: with ps; [ + pysyncthru + url-normalize + ]; + "synology_chat" = + ps: with ps; [ + ]; + "synology_dsm" = + ps: with ps; [ + py-synologydsm-api + ]; + "synology_srm" = + ps: with ps; [ + ]; # missing inputs: synology-srm + "syslog" = + ps: with ps; [ + ]; + "system_bridge" = + ps: with ps; [ + ifaddr + systembridgeconnector + systembridgemodels + zeroconf + ]; + "system_health" = + ps: with ps; [ + ]; + "system_log" = + ps: with ps; [ + ]; + "systemmonitor" = + ps: with ps; [ + psutil + psutil-home-assistant + ]; + "tado" = + ps: with ps; [ + python-tado + ]; + "tag" = + ps: with ps; [ + ]; + "tailscale" = + ps: with ps; [ + tailscale + ]; + "tailwind" = + ps: with ps; [ + gotailwind + ]; + "tami4" = + ps: with ps; [ + ]; # missing inputs: Tami4EdgeAPI + "tank_utility" = + ps: with ps; [ + tank-utility + ]; + "tankerkoenig" = + ps: with ps; [ + aiotankerkoenig + ]; + "tapsaff" = + ps: with ps; [ + ]; # missing inputs: tapsaff + "tasmota" = + ps: with ps; [ + aiohasupervisor + hatasmota + paho-mqtt_1 + ]; + "tautulli" = + ps: with ps; [ + pytautulli + ]; + "tcp" = + ps: with ps; [ + ]; + "technove" = + ps: with ps; [ + python-technove + ]; + "ted5000" = + ps: with ps; [ + xmltodict + ]; + "tedee" = + ps: with ps; [ + pytedee-async + ]; + "telegram" = + ps: + with ps; + [ + python-telegram-bot + ] + ++ python-telegram-bot.optional-dependencies.socks; + "telegram_bot" = + ps: + with ps; + [ + python-telegram-bot + ] + ++ python-telegram-bot.optional-dependencies.socks; + "tellduslive" = + ps: with ps; [ + tellduslive + ]; + "tellstick" = + ps: with ps; [ + ]; # missing inputs: tellcore-net tellcore-py + "telnet" = + ps: with ps; [ + ]; + "temper" = + ps: with ps; [ + temperusb + ]; + "template" = + ps: with ps; [ + ]; + "tensorflow" = + ps: with ps; [ + numpy_1 + pillow + pycocotools + tensorflow + ]; # missing inputs: tf-models-official + "tesla_fleet" = + ps: with ps; [ + tesla-fleet-api + ]; + "tesla_wall_connector" = + ps: with ps; [ + tesla-wall-connector + ]; + "teslemetry" = + ps: with ps; [ + tesla-fleet-api + teslemetry-stream + ]; + "tessie" = + ps: with ps; [ + tesla-fleet-api + ]; # missing inputs: tessie-api + "text" = + ps: with ps; [ + ]; + "thermobeacon" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + thermobeacon-ble + zeroconf + ]; + "thermoplus" = + ps: with ps; [ + ]; + "thermopro" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + thermopro-ble + zeroconf + ]; + "thethingsnetwork" = + ps: with ps; [ + ttn-client + ]; + "thingspeak" = + ps: with ps; [ + ]; # missing inputs: thingspeak + "thinkingcleaner" = + ps: with ps; [ + ]; # missing inputs: pythinkingcleaner + "thomson" = + ps: with ps; [ + ]; + "thread" = + ps: with ps; [ + ifaddr + pyroute2 + python-otbr-api + zeroconf + ]; + "threshold" = + ps: with ps; [ + ]; + "tibber" = + ps: with ps; [ + fnv-hash-fast + psutil-home-assistant + pytibber + sqlalchemy + ]; + "tikteck" = + ps: with ps; [ + ]; # missing inputs: tikteck + "tile" = + ps: with ps; [ + pytile + ]; + "tilt_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + tilt-ble + zeroconf + ]; + "time" = + ps: with ps; [ + ]; + "time_date" = + ps: with ps; [ + ]; + "timer" = + ps: with ps; [ + ]; + "tmb" = + ps: with ps; [ + tmb + ]; + "tod" = + ps: with ps; [ + ]; + "todo" = + ps: with ps; [ + ]; + "todoist" = + ps: with ps; [ + todoist-api-python + ]; + "tolo" = + ps: with ps; [ + tololib + ]; + "tomato" = + ps: with ps; [ + ]; + "tomorrowio" = + ps: with ps; [ + pytomorrowio + ]; + "toon" = + ps: with ps; [ + aiohasupervisor + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-intents + mutagen + pymicro-vad + pyspeex-noise + python-matter-server + pyturbojpeg + toonapi + ]; + "torque" = + ps: with ps; [ + ]; + "totalconnect" = + ps: with ps; [ + total-connect-client + ]; + "touchline" = + ps: with ps; [ + ]; # missing inputs: pytouchline + "touchline_sl" = + ps: with ps; [ + pytouchlinesl + ]; + "tplink" = + ps: + with ps; + [ + ifaddr + python-kasa + ] + ++ python-kasa.optional-dependencies.speedups; + "tplink_lte" = + ps: with ps; [ + ]; # missing inputs: tp-connected + "tplink_omada" = + ps: with ps; [ + tplink-omada-client + ]; + "tplink_tapo" = + ps: with ps; [ + ]; + "traccar" = + ps: with ps; [ + pytraccar + stringcase + ]; + "traccar_server" = + ps: with ps; [ + pytraccar + ]; + "trace" = + ps: with ps; [ + ]; + "tractive" = + ps: with ps; [ + aiotractive + ]; + "tradfri" = + ps: + with ps; + [ + pytradfri + ] + ++ pytradfri.optional-dependencies.async; + "trafikverket_camera" = + ps: with ps; [ + pytrafikverket + ]; + "trafikverket_ferry" = + ps: with ps; [ + pytrafikverket + ]; + "trafikverket_train" = + ps: with ps; [ + pytrafikverket + ]; + "trafikverket_weatherstation" = + ps: with ps; [ + pytrafikverket + ]; + "transmission" = + ps: with ps; [ + transmission-rpc + ]; + "transport_nsw" = + ps: with ps; [ + pytransportnsw + ]; + "travisci" = + ps: with ps; [ + ]; # missing inputs: TravisPy + "trend" = + ps: with ps; [ + numpy_1 + ]; + "triggercmd" = + ps: with ps; [ + ]; # missing inputs: triggercmd + "tts" = + ps: with ps; [ + ha-ffmpeg + mutagen + ]; + "tuya" = + ps: with ps; [ + ha-ffmpeg + tuya-device-sharing-sdk + ]; + "twentemilieu" = + ps: with ps; [ + twentemilieu + ]; + "twilio" = + ps: with ps; [ + twilio + ]; + "twilio_call" = + ps: with ps; [ + twilio + ]; + "twilio_sms" = + ps: with ps; [ + twilio + ]; + "twinkly" = + ps: with ps; [ + ttls + ]; + "twitch" = + ps: with ps; [ + twitchapi + ]; + "twitter" = + ps: with ps; [ + twitterapi + ]; + "ubiwizz" = + ps: with ps; [ + ]; + "ubus" = + ps: with ps; [ + openwrt-ubus-rpc + ]; + "uk_transport" = + ps: with ps; [ + ]; + "ukraine_alarm" = + ps: with ps; [ + uasiren + ]; + "ultraloq" = + ps: with ps; [ + ]; + "unifi" = + ps: with ps; [ + aiounifi + ]; + "unifi_direct" = + ps: with ps; [ + unifi-ap + ]; + "unifiled" = + ps: with ps; [ + unifiled + ]; + "unifiprotect" = + ps: with ps; [ + uiprotect + unifi-discovery + ]; + "universal" = + ps: with ps; [ + ]; + "upb" = + ps: with ps; [ + upb-lib + ]; + "upc_connect" = + ps: with ps; [ + connect-box + ]; + "upcloud" = + ps: with ps; [ + upcloud-api + ]; + "update" = + ps: with ps; [ + ]; + "upnp" = + ps: with ps; [ + async-upnp-client + getmac + ifaddr + ]; + "uprise_smart_shades" = + ps: with ps; [ + ]; + "uptime" = + ps: with ps; [ + ]; + "uptimerobot" = + ps: with ps; [ + pyuptimerobot + ]; + "usb" = + ps: with ps; [ + pyserial + pyudev + ]; + "usgs_earthquakes_feed" = + ps: with ps; [ + aio-geojson-usgs-earthquakes + ]; + "utility_meter" = + ps: with ps; [ + croniter + ]; + "uvc" = + ps: with ps; [ + uvcclient + ]; + "v2c" = + ps: with ps; [ + pytrydan + ]; + "vacuum" = + ps: with ps; [ + ]; + "vallox" = + ps: with ps; [ + vallox-websocket-api + ]; + "valve" = + ps: with ps; [ + ]; + "vasttrafik" = + ps: with ps; [ + vtjp + ]; + "velbus" = + ps: with ps; [ + pyserial + pyudev + velbus-aio + ]; + "velux" = + ps: with ps; [ + pyvlx + ]; + "venstar" = + ps: with ps; [ + venstarcolortouch + ]; + "vera" = + ps: with ps; [ + pyvera + ]; + "verisure" = + ps: with ps; [ + vsure + ]; + "vermont_castings" = + ps: with ps; [ + ]; + "versasense" = + ps: with ps; [ + pyversasense + ]; + "version" = + ps: with ps; [ + pyhaversion + ]; + "vesync" = + ps: with ps; [ + pyvesync + ]; + "viaggiatreno" = + ps: with ps; [ + ]; + "vicare" = + ps: with ps; [ + pyvicare + ]; + "vilfo" = + ps: with ps; [ + vilfo-api-client + ]; + "vivotek" = + ps: with ps; [ + libpyvivotek + ]; + "vizio" = + ps: with ps; [ + pyvizio + ]; + "vlc" = + ps: with ps; [ + python-vlc + ]; + "vlc_telnet" = + ps: with ps; [ + aiovlc + ]; + "vodafone_station" = + ps: with ps; [ + aiovodafone + ]; + "voicerss" = + ps: with ps; [ + ]; + "voip" = + ps: with ps; [ + ha-ffmpeg + hassil + home-assistant-intents + mutagen + pymicro-vad + pyspeex-noise + voip-utils + ]; + "volkszaehler" = + ps: with ps; [ + volkszaehler + ]; + "volumio" = + ps: with ps; [ + pyvolumio + ]; + "volvooncall" = + ps: with ps; [ + volvooncall + ]; + "vulcan" = + ps: with ps; [ + vulcan-api + ]; + "vultr" = + ps: with ps; [ + vultr + ]; + "w800rf32" = + ps: with ps; [ + ]; # missing inputs: pyW800rf32 + "wake_on_lan" = + ps: with ps; [ + wakeonlan + ]; + "wake_word" = + ps: with ps; [ + ]; + "wallbox" = + ps: with ps; [ + wallbox + ]; + "waqi" = + ps: with ps; [ + aiowaqi + ]; + "water_heater" = + ps: with ps; [ + ]; + "waterfurnace" = + ps: with ps; [ + waterfurnace + ]; + "watson_iot" = + ps: with ps; [ + ]; # missing inputs: ibmiotf + "watttime" = + ps: with ps; [ + aiowatttime + ]; + "waze_travel_time" = + ps: with ps; [ + pywaze + ]; + "weather" = + ps: with ps; [ + ]; + "weatherflow" = + ps: with ps; [ + pyweatherflowudp + ]; + "weatherflow_cloud" = + ps: with ps; [ + weatherflow4py + ]; + "weatherkit" = + ps: with ps; [ + apple-weatherkit + ]; + "webhook" = + ps: with ps; [ + ]; + "webmin" = + ps: with ps; [ + webmin-xmlrpc + ]; + "webostv" = + ps: with ps; [ + aiowebostv + ]; + "websocket_api" = + ps: with ps; [ + ]; + "weheat" = + ps: with ps; [ + weheat + ]; + "wemo" = + ps: with ps; [ + pywemo + ]; + "whirlpool" = + ps: with ps; [ + whirlpool-sixth-sense + ]; + "whisper" = + ps: with ps; [ + ]; + "whois" = + ps: with ps; [ + whois + ]; + "wiffi" = + ps: with ps; [ + wiffi + ]; + "wilight" = + ps: with ps; [ + pywilight + ]; + "wirelesstag" = + ps: with ps; [ + ]; # missing inputs: wirelesstagpy + "withings" = + ps: with ps; [ + aiohasupervisor + aiowithings + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-intents + mutagen + pymicro-vad + pyspeex-noise + python-matter-server + pyturbojpeg + ]; + "wiz" = + ps: with ps; [ + ifaddr + pywizlight + ]; + "wled" = + ps: with ps; [ + wled + ]; + "wmspro" = + ps: with ps; [ + ]; # missing inputs: pywmspro + "wolflink" = + ps: with ps; [ + ]; # missing inputs: wolf-comm + "workday" = + ps: with ps; [ + holidays + ]; + "worldclock" = + ps: with ps; [ + ]; + "worldtidesinfo" = + ps: with ps; [ + ]; + "worxlandroid" = + ps: with ps; [ + ]; + "ws66i" = + ps: with ps; [ + pyws66i + ]; + "wsdot" = + ps: with ps; [ + ]; + "wyoming" = + ps: with ps; [ + ha-ffmpeg + hassil + home-assistant-intents + mutagen + pymicro-vad + pyspeex-noise + wyoming + ]; + "x10" = + ps: with ps; [ + ]; + "xbox" = + ps: with ps; [ + xbox-webapi + ]; + "xeoma" = + ps: with ps; [ + pyxeoma + ]; + "xiaomi" = + ps: with ps; [ + ha-ffmpeg + ]; + "xiaomi_aqara" = + ps: with ps; [ + pyxiaomigateway + ]; + "xiaomi_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + xiaomi-ble + zeroconf + ]; + "xiaomi_miio" = + ps: with ps; [ + construct + micloud + python-miio + ]; + "xiaomi_tv" = + ps: with ps; [ + pymitv + ]; + "xmpp" = + ps: with ps; [ + emoji + slixmpp + ]; + "xs1" = + ps: with ps; [ + ]; # missing inputs: xs1-api-client + "yale" = + ps: with ps; [ + aiohasupervisor + ha-ffmpeg + hass-nabucasa + hassil + home-assistant-intents + mutagen + pymicro-vad + pyspeex-noise + python-matter-server + pyturbojpeg + yalexs + yalexs-ble + ]; + "yale_home" = + ps: with ps; [ + ]; + "yale_smart_alarm" = + ps: with ps; [ + yalesmartalarmclient + ]; + "yalexs_ble" = + ps: with ps; [ + aioesphomeapi + aioruuvigateway + aioshelly + bleak + bleak-esphome + bleak-retry-connector + bluetooth-adapters + bluetooth-auto-recovery + bluetooth-data-tools + dbus-fast + esphome-dashboard-api + ha-ffmpeg + habluetooth + hassil + home-assistant-intents + ifaddr + mutagen + pymicro-vad + pyserial + pyspeex-noise + pyudev + yalexs-ble + zeroconf + ]; + "yamaha" = + ps: with ps; [ + rxv + ]; + "yamaha_musiccast" = + ps: with ps; [ + aiomusiccast + async-upnp-client + ifaddr + ]; + "yandex_transport" = + ps: with ps; [ + aioymaps + ]; + "yandextts" = + ps: with ps; [ + ]; + "yardian" = + ps: with ps; [ + pyyardian + ]; + "yeelight" = + ps: with ps; [ + async-upnp-client + ifaddr + yeelight + ]; + "yeelightsunflower" = + ps: with ps; [ + ]; # missing inputs: yeelightsunflower + "yi" = + ps: with ps; [ + aioftp + ha-ffmpeg + ]; + "yolink" = + ps: with ps; [ + yolink-api + ]; + "youless" = + ps: with ps; [ + youless-api + ]; + "youtube" = + ps: with ps; [ + youtubeaio + ]; + "zabbix" = + ps: with ps; [ + py-zabbix + ]; + "zamg" = + ps: with ps; [ + zamg + ]; + "zengge" = + ps: with ps; [ + bluepy + ]; # missing inputs: zengge + "zeroconf" = + ps: with ps; [ + ifaddr + zeroconf + ]; + "zerproc" = + ps: with ps; [ + pyzerproc + ]; + "zestimate" = + ps: with ps; [ + xmltodict + ]; + "zeversolar" = + ps: with ps; [ + zeversolar + ]; + "zha" = + ps: with ps; [ + aiohasupervisor + pillow + pyserial + pyudev + universal-silabs-flasher + zha + ]; + "zhong_hong" = + ps: with ps; [ + ]; # missing inputs: zhong-hong-hvac + "ziggo_mediabox_xl" = + ps: with ps; [ + ]; # missing inputs: ziggo-mediabox-xl + "zodiac" = + ps: with ps; [ + ]; + "zondergas" = + ps: with ps; [ + ]; + "zone" = + ps: with ps; [ + ]; + "zoneminder" = + ps: with ps; [ + zm-py + ]; + "zwave_js" = + ps: with ps; [ + aiohasupervisor + pyserial + pyudev + zwave-js-server-python + ]; + "zwave_me" = + ps: with ps; [ + ifaddr + url-normalize + zeroconf + zwave-me-ws + ]; }; # components listed in tests/components for which all dependencies are packaged supportedComponentsWithTests = [ diff --git a/pkgs/servers/home-assistant/custom-components/adaptive_lighting/package.nix b/pkgs/servers/home-assistant/custom-components/adaptive_lighting/package.nix index 403bb18826353c..a60f6df2f2ef0f 100644 --- a/pkgs/servers/home-assistant/custom-components/adaptive_lighting/package.nix +++ b/pkgs/servers/home-assistant/custom-components/adaptive_lighting/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildHomeAssistantComponent -, ulid-transform +{ + lib, + fetchFromGitHub, + buildHomeAssistantComponent, + ulid-transform, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/auth-header/package.nix b/pkgs/servers/home-assistant/custom-components/auth-header/package.nix index 9062b138590c7e..e5ccefc1ffc465 100644 --- a/pkgs/servers/home-assistant/custom-components/auth-header/package.nix +++ b/pkgs/servers/home-assistant/custom-components/auth-header/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitHub +{ + lib, + buildHomeAssistantComponent, + fetchFromGitHub, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/awtrix/package.nix b/pkgs/servers/home-assistant/custom-components/awtrix/package.nix index 738dbbea5dbcae..79150e74b83b8b 100644 --- a/pkgs/servers/home-assistant/custom-components/awtrix/package.nix +++ b/pkgs/servers/home-assistant/custom-components/awtrix/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildHomeAssistantComponent -, requests +{ + lib, + fetchFromGitHub, + buildHomeAssistantComponent, + requests, }: buildHomeAssistantComponent rec { @@ -27,4 +28,3 @@ buildHomeAssistantComponent rec { license = licenses.mit; }; } - diff --git a/pkgs/servers/home-assistant/custom-components/emporia_vue/package.nix b/pkgs/servers/home-assistant/custom-components/emporia_vue/package.nix index 64b55e214a6dee..7c1e00e4cd913d 100644 --- a/pkgs/servers/home-assistant/custom-components/emporia_vue/package.nix +++ b/pkgs/servers/home-assistant/custom-components/emporia_vue/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildHomeAssistantComponent -, pyemvue +{ + lib, + fetchFromGitHub, + buildHomeAssistantComponent, + pyemvue, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/epex_spot/package.nix b/pkgs/servers/home-assistant/custom-components/epex_spot/package.nix index 00efbdd24f9af3..db8830b3cd53cb 100644 --- a/pkgs/servers/home-assistant/custom-components/epex_spot/package.nix +++ b/pkgs/servers/home-assistant/custom-components/epex_spot/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildHomeAssistantComponent -, beautifulsoup4 +{ + lib, + fetchFromGitHub, + buildHomeAssistantComponent, + beautifulsoup4, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/govee-lan/package.nix b/pkgs/servers/home-assistant/custom-components/govee-lan/package.nix index 6d66dc8fe357f9..5443ae8e6b7c05 100644 --- a/pkgs/servers/home-assistant/custom-components/govee-lan/package.nix +++ b/pkgs/servers/home-assistant/custom-components/govee-lan/package.nix @@ -1,11 +1,12 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitHub -, fetchpatch2 -, govee-led-wez -, pytest-cov-stub -, pytest-homeassistant-custom-component -, pytestCheckHook +{ + lib, + buildHomeAssistantComponent, + fetchFromGitHub, + fetchpatch2, + govee-led-wez, + pytest-cov-stub, + pytest-homeassistant-custom-component, + pytestCheckHook, }: buildHomeAssistantComponent { diff --git a/pkgs/servers/home-assistant/custom-components/gpio/package.nix b/pkgs/servers/home-assistant/custom-components/gpio/package.nix index ff06822d664aaa..aa61ae326b3c74 100644 --- a/pkgs/servers/home-assistant/custom-components/gpio/package.nix +++ b/pkgs/servers/home-assistant/custom-components/gpio/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitea -, libgpiod +{ + lib, + buildHomeAssistantComponent, + fetchFromGitea, + libgpiod, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/homematicip_local/package.nix b/pkgs/servers/home-assistant/custom-components/homematicip_local/package.nix index de8574900e0db7..b460d174882427 100644 --- a/pkgs/servers/home-assistant/custom-components/homematicip_local/package.nix +++ b/pkgs/servers/home-assistant/custom-components/homematicip_local/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitHub -, hahomematic +{ + lib, + buildHomeAssistantComponent, + fetchFromGitHub, + hahomematic, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/local_luftdaten/package.nix b/pkgs/servers/home-assistant/custom-components/local_luftdaten/package.nix index 10a75e14ab7056..19c5cc3d4d0e2a 100644 --- a/pkgs/servers/home-assistant/custom-components/local_luftdaten/package.nix +++ b/pkgs/servers/home-assistant/custom-components/local_luftdaten/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitHub +{ + lib, + buildHomeAssistantComponent, + fetchFromGitHub, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/localtuya/package.nix b/pkgs/servers/home-assistant/custom-components/localtuya/package.nix index 8773f981e45f63..2b0e06cf1b4b27 100644 --- a/pkgs/servers/home-assistant/custom-components/localtuya/package.nix +++ b/pkgs/servers/home-assistant/custom-components/localtuya/package.nix @@ -1,6 +1,7 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitHub +{ + lib, + buildHomeAssistantComponent, + fetchFromGitHub, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/mass/package.nix b/pkgs/servers/home-assistant/custom-components/mass/package.nix index 7b8b8525329147..7ea860769956ee 100644 --- a/pkgs/servers/home-assistant/custom-components/mass/package.nix +++ b/pkgs/servers/home-assistant/custom-components/mass/package.nix @@ -1,13 +1,14 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitHub -, toPythonModule -, async-timeout -, music-assistant -, pytestCheckHook -, pytest-asyncio -, pytest-cov-stub -, pytest-homeassistant-custom-component +{ + lib, + buildHomeAssistantComponent, + fetchFromGitHub, + toPythonModule, + async-timeout, + music-assistant, + pytestCheckHook, + pytest-asyncio, + pytest-cov-stub, + pytest-homeassistant-custom-component, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/midea-air-appliances-lan/package.nix b/pkgs/servers/home-assistant/custom-components/midea-air-appliances-lan/package.nix index f533b84fd8324b..dd70412b640983 100644 --- a/pkgs/servers/home-assistant/custom-components/midea-air-appliances-lan/package.nix +++ b/pkgs/servers/home-assistant/custom-components/midea-air-appliances-lan/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitHub -, midea-beautiful-air +{ + lib, + buildHomeAssistantComponent, + fetchFromGitHub, + midea-beautiful-air, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/midea_ac_lan/package.nix b/pkgs/servers/home-assistant/custom-components/midea_ac_lan/package.nix index 98ba5281c5dfc8..58b264b5e02be0 100644 --- a/pkgs/servers/home-assistant/custom-components/midea_ac_lan/package.nix +++ b/pkgs/servers/home-assistant/custom-components/midea_ac_lan/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitHub -, pycryptodome +{ + lib, + buildHomeAssistantComponent, + fetchFromGitHub, + pycryptodome, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/ntfy/package.nix b/pkgs/servers/home-assistant/custom-components/ntfy/package.nix index 43920dbaef9e8e..39bebb70ada7d0 100644 --- a/pkgs/servers/home-assistant/custom-components/ntfy/package.nix +++ b/pkgs/servers/home-assistant/custom-components/ntfy/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildHomeAssistantComponent -, requests +{ + lib, + fetchFromGitHub, + buildHomeAssistantComponent, + requests, }: buildHomeAssistantComponent rec { @@ -27,4 +28,3 @@ buildHomeAssistantComponent rec { license = licenses.gpl3; }; } - diff --git a/pkgs/servers/home-assistant/custom-components/omnik_inverter/package.nix b/pkgs/servers/home-assistant/custom-components/omnik_inverter/package.nix index 38dd56feb00007..75e54c51435453 100644 --- a/pkgs/servers/home-assistant/custom-components/omnik_inverter/package.nix +++ b/pkgs/servers/home-assistant/custom-components/omnik_inverter/package.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildHomeAssistantComponent -, omnikinverter +{ + lib, + fetchFromGitHub, + buildHomeAssistantComponent, + omnikinverter, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/prometheus_sensor/package.nix b/pkgs/servers/home-assistant/custom-components/prometheus_sensor/package.nix index 812ee1445d0799..1c1fb34742f7bf 100644 --- a/pkgs/servers/home-assistant/custom-components/prometheus_sensor/package.nix +++ b/pkgs/servers/home-assistant/custom-components/prometheus_sensor/package.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, buildHomeAssistantComponent +{ + lib, + fetchFromGitHub, + buildHomeAssistantComponent, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/smartthinq-sensors/package.nix b/pkgs/servers/home-assistant/custom-components/smartthinq-sensors/package.nix index e107d1dcd5e65e..b4146bef9d0110 100644 --- a/pkgs/servers/home-assistant/custom-components/smartthinq-sensors/package.nix +++ b/pkgs/servers/home-assistant/custom-components/smartthinq-sensors/package.nix @@ -1,9 +1,10 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitHub -, charset-normalizer -, pycountry -, xmltodict +{ + lib, + buildHomeAssistantComponent, + fetchFromGitHub, + charset-normalizer, + pycountry, + xmltodict, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/spook/package.nix b/pkgs/servers/home-assistant/custom-components/spook/package.nix index 280f7b9491b2a8..c93844570c224a 100644 --- a/pkgs/servers/home-assistant/custom-components/spook/package.nix +++ b/pkgs/servers/home-assistant/custom-components/spook/package.nix @@ -19,7 +19,7 @@ buildHomeAssistantComponent rec { hash = "sha256-ChHsevryWuim8BEFqXVkCOW9fGMrt5vol+B2SreMUws="; }; - patches = [./remove-sub-integration-symlink-hack.patch]; + patches = [ ./remove-sub-integration-symlink-hack.patch ]; dependencies = [ pillow @@ -33,6 +33,6 @@ buildHomeAssistantComponent rec { description = "Toolbox for Home Assistant"; homepage = "https://spook.boo/"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [kkoniuszy]; + maintainers = with lib.maintainers; [ kkoniuszy ]; }; } diff --git a/pkgs/servers/home-assistant/custom-components/tuya_local/package.nix b/pkgs/servers/home-assistant/custom-components/tuya_local/package.nix index a097dac5d6efec..e4d4387d82fb0e 100644 --- a/pkgs/servers/home-assistant/custom-components/tuya_local/package.nix +++ b/pkgs/servers/home-assistant/custom-components/tuya_local/package.nix @@ -1,10 +1,11 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitHub +{ + lib, + buildHomeAssistantComponent, + fetchFromGitHub, -# dependencies -, tinytuya -, tuya-device-sharing-sdk + # dependencies + tinytuya, + tuya-device-sharing-sdk, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-components/waste_collection_schedule/package.nix b/pkgs/servers/home-assistant/custom-components/waste_collection_schedule/package.nix index 91ba2467a0fda0..a51f827456d1fe 100644 --- a/pkgs/servers/home-assistant/custom-components/waste_collection_schedule/package.nix +++ b/pkgs/servers/home-assistant/custom-components/waste_collection_schedule/package.nix @@ -1,12 +1,13 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitHub -, beautifulsoup4 -, icalendar -, icalevents -, lxml -, pycryptodome -, recurring-ical-events +{ + lib, + buildHomeAssistantComponent, + fetchFromGitHub, + beautifulsoup4, + icalendar, + icalevents, + lxml, + pycryptodome, + recurring-ical-events, }: buildHomeAssistantComponent rec { @@ -34,7 +35,7 @@ buildHomeAssistantComponent rec { changelog = "https://github.com/mampfes/hacs_waste_collection_schedule/releases/tag/${version}"; description = "Home Assistant integration framework for (garbage collection) schedules"; homepage = "https://github.com/mampfes/hacs_waste_collection_schedule"; - maintainers = with maintainers; [jamiemagee]; + maintainers = with maintainers; [ jamiemagee ]; license = licenses.mit; }; } diff --git a/pkgs/servers/home-assistant/custom-components/yassi/package.nix b/pkgs/servers/home-assistant/custom-components/yassi/package.nix index 3e69dc6ae8bba2..d2e6dc946fa25b 100644 --- a/pkgs/servers/home-assistant/custom-components/yassi/package.nix +++ b/pkgs/servers/home-assistant/custom-components/yassi/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildHomeAssistantComponent -, fetchFromGitHub -, pysmartthings +{ + lib, + buildHomeAssistantComponent, + fetchFromGitHub, + pysmartthings, }: buildHomeAssistantComponent rec { diff --git a/pkgs/servers/home-assistant/custom-lovelace-modules/button-card/default.nix b/pkgs/servers/home-assistant/custom-lovelace-modules/button-card/default.nix index d6ec293f31de26..e0c4883406cc58 100644 --- a/pkgs/servers/home-assistant/custom-lovelace-modules/button-card/default.nix +++ b/pkgs/servers/home-assistant/custom-lovelace-modules/button-card/default.nix @@ -1,7 +1,8 @@ -{ lib -, mkYarnPackage -, fetchYarnDeps -, fetchFromGitHub +{ + lib, + mkYarnPackage, + fetchYarnDeps, + fetchFromGitHub, }: mkYarnPackage rec { diff --git a/pkgs/servers/home-assistant/custom-lovelace-modules/card-mod/default.nix b/pkgs/servers/home-assistant/custom-lovelace-modules/card-mod/default.nix index bdca8771d00f04..28f3c6f6e94ccb 100644 --- a/pkgs/servers/home-assistant/custom-lovelace-modules/card-mod/default.nix +++ b/pkgs/servers/home-assistant/custom-lovelace-modules/card-mod/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/servers/home-assistant/custom-lovelace-modules/decluttering-card/default.nix b/pkgs/servers/home-assistant/custom-lovelace-modules/decluttering-card/default.nix index 44a83e71e5505d..bed75c9c63b726 100644 --- a/pkgs/servers/home-assistant/custom-lovelace-modules/decluttering-card/default.nix +++ b/pkgs/servers/home-assistant/custom-lovelace-modules/decluttering-card/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/servers/home-assistant/custom-lovelace-modules/default.nix b/pkgs/servers/home-assistant/custom-lovelace-modules/default.nix index be2b26c7a00405..8a51d530a0bfc5 100644 --- a/pkgs/servers/home-assistant/custom-lovelace-modules/default.nix +++ b/pkgs/servers/home-assistant/custom-lovelace-modules/default.nix @@ -23,9 +23,9 @@ light-entity-card = callPackage ./light-entity-card { }; - mini-graph-card = callPackage ./mini-graph-card {}; + mini-graph-card = callPackage ./mini-graph-card { }; - mini-media-player = callPackage ./mini-media-player {}; + mini-media-player = callPackage ./mini-media-player { }; multiple-entity-row = callPackage ./multiple-entity-row { }; @@ -48,7 +48,5 @@ zigbee2mqtt-networkmap = callPackage ./zigbee2mqtt-networkmap { }; } // lib.optionalAttrs pkgs.config.allowAliases { - android-tv-card = - lib.warnOnInstantiate "`home-assistant-custom-lovelace-modules.android-tv-card` has been renamed to `universal-remote-card`" - pkgs.home-assistant-custom-lovelace-modules.universal-remote-card; + android-tv-card = lib.warnOnInstantiate "`home-assistant-custom-lovelace-modules.android-tv-card` has been renamed to `universal-remote-card`" pkgs.home-assistant-custom-lovelace-modules.universal-remote-card; } diff --git a/pkgs/servers/home-assistant/custom-lovelace-modules/lg-webos-remote-control/default.nix b/pkgs/servers/home-assistant/custom-lovelace-modules/lg-webos-remote-control/default.nix index 9911fbfdce1ad9..674dd3b4e7416d 100644 --- a/pkgs/servers/home-assistant/custom-lovelace-modules/lg-webos-remote-control/default.nix +++ b/pkgs/servers/home-assistant/custom-lovelace-modules/lg-webos-remote-control/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/servers/home-assistant/custom-lovelace-modules/light-entity-card/default.nix b/pkgs/servers/home-assistant/custom-lovelace-modules/light-entity-card/default.nix index 529e2f736bb243..82a46f40e5ba74 100644 --- a/pkgs/servers/home-assistant/custom-lovelace-modules/light-entity-card/default.nix +++ b/pkgs/servers/home-assistant/custom-lovelace-modules/light-entity-card/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/servers/home-assistant/custom-lovelace-modules/mini-graph-card/default.nix b/pkgs/servers/home-assistant/custom-lovelace-modules/mini-graph-card/default.nix index 1846339bd1e472..8acd2f29809d35 100644 --- a/pkgs/servers/home-assistant/custom-lovelace-modules/mini-graph-card/default.nix +++ b/pkgs/servers/home-assistant/custom-lovelace-modules/mini-graph-card/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { @@ -35,4 +36,3 @@ buildNpmPackage rec { license = licenses.mit; }; } - diff --git a/pkgs/servers/home-assistant/custom-lovelace-modules/mini-media-player/default.nix b/pkgs/servers/home-assistant/custom-lovelace-modules/mini-media-player/default.nix index 83f1dae71b9ecf..ebfca7e424378c 100644 --- a/pkgs/servers/home-assistant/custom-lovelace-modules/mini-media-player/default.nix +++ b/pkgs/servers/home-assistant/custom-lovelace-modules/mini-media-player/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/servers/home-assistant/custom-lovelace-modules/multiple-entity-row/default.nix b/pkgs/servers/home-assistant/custom-lovelace-modules/multiple-entity-row/default.nix index 0ba1bcec0cc656..2ece70bd477da6 100644 --- a/pkgs/servers/home-assistant/custom-lovelace-modules/multiple-entity-row/default.nix +++ b/pkgs/servers/home-assistant/custom-lovelace-modules/multiple-entity-row/default.nix @@ -1,7 +1,8 @@ -{ lib -, mkYarnPackage -, fetchFromGitHub -, fetchYarnDeps +{ + lib, + mkYarnPackage, + fetchFromGitHub, + fetchYarnDeps, }: mkYarnPackage rec { diff --git a/pkgs/servers/home-assistant/custom-lovelace-modules/mushroom/default.nix b/pkgs/servers/home-assistant/custom-lovelace-modules/mushroom/default.nix index c9d60c4eeeccdc..61b4ff21e4ec3c 100644 --- a/pkgs/servers/home-assistant/custom-lovelace-modules/mushroom/default.nix +++ b/pkgs/servers/home-assistant/custom-lovelace-modules/mushroom/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/servers/home-assistant/custom-lovelace-modules/universal-remote-card/default.nix b/pkgs/servers/home-assistant/custom-lovelace-modules/universal-remote-card/default.nix index 44b1aba071f5e0..7ebb02264ee0bd 100644 --- a/pkgs/servers/home-assistant/custom-lovelace-modules/universal-remote-card/default.nix +++ b/pkgs/servers/home-assistant/custom-lovelace-modules/universal-remote-card/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/servers/home-assistant/custom-lovelace-modules/valetudo-map-card/default.nix b/pkgs/servers/home-assistant/custom-lovelace-modules/valetudo-map-card/default.nix index 3203c59e7cd9f8..d08b8dd0ba60f1 100644 --- a/pkgs/servers/home-assistant/custom-lovelace-modules/valetudo-map-card/default.nix +++ b/pkgs/servers/home-assistant/custom-lovelace-modules/valetudo-map-card/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/servers/home-assistant/default.nix b/pkgs/servers/home-assistant/default.nix index f1fa3e4920cc2d..2f317538db2eab 100644 --- a/pkgs/servers/home-assistant/default.nix +++ b/pkgs/servers/home-assistant/default.nix @@ -1,29 +1,31 @@ -{ stdenv -, lib -, callPackage -, fetchFromGitHub -, fetchPypi -, python312 -, substituteAll -, ffmpeg-headless -, inetutils -, nixosTests -, home-assistant -, testers - -# Look up dependencies of specified components in component-packages.nix -, extraComponents ? [ ] - -# Additional packages to add to propagatedBuildInputs -, extraPackages ? ps: [] - -# Override Python packages using -# self: super: { pkg = super.pkg.overridePythonAttrs (oldAttrs: { ... }); } -# Applied after defaultOverrides -, packageOverrides ? self: super: {} - -# Skip pip install of required packages on startup -, skipPip ? true }: +{ + stdenv, + lib, + callPackage, + fetchFromGitHub, + fetchPypi, + python312, + substituteAll, + ffmpeg-headless, + inetutils, + nixosTests, + home-assistant, + testers, + + # Look up dependencies of specified components in component-packages.nix + extraComponents ? [ ], + + # Additional packages to add to propagatedBuildInputs + extraPackages ? ps: [ ], + + # Override Python packages using + # self: super: { pkg = super.pkg.overridePythonAttrs (oldAttrs: { ... }); } + # Applied after defaultOverrides + packageOverrides ? self: super: { }, + + # Skip pip install of required packages on startup + skipPip ? true, +}: let defaultOverrides = [ @@ -95,7 +97,7 @@ let --replace-fail "poetry>=1.0.0b1" "poetry-core" \ --replace-fail "poetry.masonry" "poetry.core.masonry" ''; - propagatedBuildInputs = (oldAttrs.propagatedBuildInputs or []) ++ [ + propagatedBuildInputs = (oldAttrs.propagatedBuildInputs or [ ]) ++ [ self.pytz ]; }); @@ -221,7 +223,7 @@ let rev = "refs/tags/v${version}"; hash = "sha256-kIE3y/qlsO9Y1MjEQcX0pfaBeIzCCHk4f1Xa215BBHo="; }; - dependencies = oldAttrs.propagatedBuildInputs or [] ++ [ + dependencies = oldAttrs.propagatedBuildInputs or [ ] ++ [ self.pytz ]; }); @@ -418,7 +420,9 @@ let home-assistant-frontend = self.callPackage ./frontend.nix { }; home-assistant-intents = self.callPackage ./intents.nix { }; homeassistant = self.toPythonModule home-assistant; - pytest-homeassistant-custom-component = self.callPackage ./pytest-homeassistant-custom-component.nix { }; + pytest-homeassistant-custom-component = + self.callPackage ./pytest-homeassistant-custom-component.nix + { }; }) ]; @@ -443,9 +447,12 @@ let # Don't forget to run update-component-packages.py after updating hassVersion = "2024.11.3"; -in python.pkgs.buildPythonApplication rec { +in +python.pkgs.buildPythonApplication rec { pname = "homeassistant"; - version = assert (componentPackages.version == hassVersion); hassVersion; + version = + assert (componentPackages.version == hassVersion); + hassVersion; pyproject = true; # check REQUIRED_PYTHON_VER in homeassistant/const.py @@ -570,32 +577,35 @@ in python.pkgs.buildPythonApplication rec { # upstream only tests on Linux, so do we. doCheck = stdenv.hostPlatform.isLinux; - nativeCheckInputs = with python.pkgs; [ - # test infrastructure (selectively from requirement_test.txt) - freezegun - pytest-asyncio - pytest-aiohttp - pytest-freezer - pytest-mock - pytest-rerunfailures - pytest-socket - pytest-timeout - pytest-unordered - pytest-xdist - pytestCheckHook - requests-mock - respx - syrupy - tomli - # Sneakily imported in tests/conftest.py - paho-mqtt - # Used in tests/non_packaged_scripts/test_alexa_locales.py - beautifulsoup4 - ] ++ lib.concatMap (component: getPackages component python.pkgs) [ - # some components are needed even if tests in tests/components are disabled - "default_config" - "hue" - ]; + nativeCheckInputs = + with python.pkgs; + [ + # test infrastructure (selectively from requirement_test.txt) + freezegun + pytest-asyncio + pytest-aiohttp + pytest-freezer + pytest-mock + pytest-rerunfailures + pytest-socket + pytest-timeout + pytest-unordered + pytest-xdist + pytestCheckHook + requests-mock + respx + syrupy + tomli + # Sneakily imported in tests/conftest.py + paho-mqtt + # Used in tests/non_packaged_scripts/test_alexa_locales.py + beautifulsoup4 + ] + ++ lib.concatMap (component: getPackages component python.pkgs) [ + # some components are needed even if tests in tests/components are disabled + "default_config" + "hue" + ]; pytestFlagsArray = [ # assign tests grouped by file to workers @@ -651,7 +661,8 @@ in python.pkgs.buildPythonApplication rec { extraComponents getPackages python - supportedComponentsWithTests; + supportedComponentsWithTests + ; pythonPath = python.pkgs.makePythonPath (componentBuildInputs ++ extraBuildInputs); frontend = python.pkgs.home-assistant-frontend; intents = python.pkgs.home-assistant-intents; diff --git a/pkgs/servers/home-assistant/frontend.nix b/pkgs/servers/home-assistant/frontend.nix index 53bc67e5317957..11f376e412582a 100644 --- a/pkgs/servers/home-assistant/frontend.nix +++ b/pkgs/servers/home-assistant/frontend.nix @@ -1,4 +1,8 @@ -{ lib, fetchPypi, buildPythonPackage }: +{ + lib, + fetchPypi, + buildPythonPackage, +}: buildPythonPackage rec { # the frontend version corresponding to a specific home-assistant version can be found here diff --git a/pkgs/servers/home-assistant/intents.nix b/pkgs/servers/home-assistant/intents.nix index a88446e8acba0c..b33c9e227fe025 100644 --- a/pkgs/servers/home-assistant/intents.nix +++ b/pkgs/servers/home-assistant/intents.nix @@ -1,22 +1,23 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, pythonOlder +{ + lib, + buildPythonPackage, + fetchFromGitHub, + pythonOlder, -# build-system -, setuptools + # build-system + setuptools, -# codegen -, hassil -, python -, pyyaml -, voluptuous -, regex -, jinja2 + # codegen + hassil, + python, + pyyaml, + voluptuous, + regex, + jinja2, -# tests -, pytest-xdist -, pytestCheckHook + # tests + pytest-xdist, + pytestCheckHook, }: buildPythonPackage rec { diff --git a/pkgs/servers/home-assistant/stubs.nix b/pkgs/servers/home-assistant/stubs.nix index 9dcf47815bb7c5..3af62cab6a4703 100644 --- a/pkgs/servers/home-assistant/stubs.nix +++ b/pkgs/servers/home-assistant/stubs.nix @@ -1,10 +1,11 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, hatchling -, hatch-vcs -, home-assistant -, python +{ + lib, + buildPythonPackage, + fetchFromGitHub, + hatchling, + hatch-vcs, + home-assistant, + python, }: buildPythonPackage rec { diff --git a/pkgs/servers/home-assistant/tests.nix b/pkgs/servers/home-assistant/tests.nix index 10389600386c2d..67d46af841e191 100644 --- a/pkgs/servers/home-assistant/tests.nix +++ b/pkgs/servers/home-assistant/tests.nix @@ -1,5 +1,6 @@ -{ lib -, home-assistant +{ + lib, + home-assistant, }: let @@ -109,37 +110,54 @@ let "--deselect=tests/components/vicare/test_sensor.py::test_all_entities" ]; }; -in lib.listToAttrs (map (component: lib.nameValuePair component ( - home-assistant.overridePythonAttrs (old: { - pname = "homeassistant-test-${component}"; - pyproject = null; - format = "other"; +in +lib.listToAttrs ( + map ( + component: + lib.nameValuePair component ( + home-assistant.overridePythonAttrs (old: { + pname = "homeassistant-test-${component}"; + pyproject = null; + format = "other"; - dontBuild = true; - dontInstall = true; + dontBuild = true; + dontInstall = true; - nativeCheckInputs = old.nativeCheckInputs - ++ home-assistant.getPackages component home-assistant.python.pkgs - ++ extraCheckInputs.${component} or [ ]; + nativeCheckInputs = + old.nativeCheckInputs + ++ home-assistant.getPackages component home-assistant.python.pkgs + ++ extraCheckInputs.${component} or [ ]; - disabledTests = old.disabledTests or [] ++ extraDisabledTests.${component} or []; - disabledTestPaths = old.disabledTestPaths or [] ++ extraDisabledTestPaths.${component} or [ ]; + disabledTests = old.disabledTests or [ ] ++ extraDisabledTests.${component} or [ ]; + disabledTestPaths = old.disabledTestPaths or [ ] ++ extraDisabledTestPaths.${component} or [ ]; - # components are more often racy than the core - dontUsePytestXdist = true; + # components are more often racy than the core + dontUsePytestXdist = true; - pytestFlagsArray = lib.remove "tests" old.pytestFlagsArray - ++ extraPytestFlagsArray.${component} or [ ] - ++ [ "tests/components/${component}" ]; + pytestFlagsArray = + lib.remove "tests" old.pytestFlagsArray + ++ extraPytestFlagsArray.${component} or [ ] + ++ [ "tests/components/${component}" ]; - preCheck = old.preCheck + lib.optionalString (builtins.elem component [ "emulated_hue" "songpal" "system_log" ]) '' - patch -p1 < ${./patches/tests-mock-source-ip.patch} - ''; + preCheck = + old.preCheck + + + lib.optionalString + (builtins.elem component [ + "emulated_hue" + "songpal" + "system_log" + ]) + '' + patch -p1 < ${./patches/tests-mock-source-ip.patch} + ''; - meta = old.meta // { - broken = lib.elem component [ ]; - # upstream only tests on Linux, so do we. - platforms = lib.platforms.linux; - }; - }) -)) home-assistant.supportedComponentsWithTests) + meta = old.meta // { + broken = lib.elem component [ ]; + # upstream only tests on Linux, so do we. + platforms = lib.platforms.linux; + }; + }) + ) + ) home-assistant.supportedComponentsWithTests +) diff --git a/pkgs/servers/http/angie/console-light.nix b/pkgs/servers/http/angie/console-light.nix index 0966e9b94a2145..1c7be0b681d506 100644 --- a/pkgs/servers/http/angie/console-light.nix +++ b/pkgs/servers/http/angie/console-light.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, brotli +{ + lib, + stdenv, + fetchurl, + brotli, }: stdenv.mkDerivation rec { @@ -13,7 +14,10 @@ stdenv.mkDerivation rec { hash = "sha256-Oz+FdMrIGNmJKHl/wOVZCP1b0AJODcURvDUKz4gCqYU="; }; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; nativeBuildInputs = [ brotli ]; @@ -35,13 +39,13 @@ stdenv.mkDerivation rec { -exec brotli --best --keep --no-copy-stat {} ';' runHook postInstall - ''; + ''; meta = { description = "Console Light is a lightweight, real-time activity monitoring interface"; - homepage = "https://angie.software/en/console/"; - license = lib.licenses.asl20; - platforms = lib.platforms.all; + homepage = "https://angie.software/en/console/"; + license = lib.licenses.asl20; + platforms = lib.platforms.all; maintainers = with lib.maintainers; [ izorkin ]; }; } diff --git a/pkgs/servers/http/angie/default.nix b/pkgs/servers/http/angie/default.nix index a0bd7bbceee161..bc93c5f9c2e07c 100644 --- a/pkgs/servers/http/angie/default.nix +++ b/pkgs/servers/http/angie/default.nix @@ -1,10 +1,11 @@ -{ callPackage -, lib -, fetchurl -, nixosTests -, withAcme ? false -, withQuic ? false -, ... +{ + callPackage, + lib, + fetchurl, + nixosTests, + withAcme ? false, + withQuic ? false, + ... }@args: callPackage ../nginx/generic.nix args rec { @@ -16,12 +17,14 @@ callPackage ../nginx/generic.nix args rec { hash = "sha256-B5fm4BgV/bMLvJ9wOAA4fJyLLGARManDlQmjPXPyHAE="; }; - configureFlags = lib.optionals withAcme [ - "--with-http_acme_module" - "--http-acme-client-path=/var/lib/nginx/acme" - ] ++ lib.optionals withQuic [ - "--with-http_v3_module" - ]; + configureFlags = + lib.optionals withAcme [ + "--with-http_acme_module" + "--http-acme-client-path=/var/lib/nginx/acme" + ] + ++ lib.optionals withQuic [ + "--with-http_v3_module" + ]; preInstall = '' if [[ -e man/angie.8 ]]; then @@ -41,9 +44,9 @@ callPackage ../nginx/generic.nix args rec { meta = { description = "Angie is an efficient, powerful, and scalable web server that was forked from nginx"; - homepage = "https://angie.software/en/"; - license = lib.licenses.bsd2; - platforms = lib.platforms.all; + homepage = "https://angie.software/en/"; + license = lib.licenses.bsd2; + platforms = lib.platforms.all; maintainers = with lib.maintainers; [ izorkin ]; }; } diff --git a/pkgs/servers/http/apache-modules/mod_auth_mellon/default.nix b/pkgs/servers/http/apache-modules/mod_auth_mellon/default.nix index b8b3b72d54328c..3691aa8e80bbee 100644 --- a/pkgs/servers/http/apache-modules/mod_auth_mellon/default.nix +++ b/pkgs/servers/http/apache-modules/mod_auth_mellon/default.nix @@ -1,4 +1,21 @@ -{ lib, stdenv, apacheHttpd, autoconf, automake, autoreconfHook, curl, fetchFromGitHub, glib, lasso, libtool, libxml2, libxslt, openssl, pkg-config, xmlsec }: +{ + lib, + stdenv, + apacheHttpd, + autoconf, + automake, + autoreconfHook, + curl, + fetchFromGitHub, + glib, + lasso, + libtool, + libxml2, + libxslt, + openssl, + pkg-config, + xmlsec, +}: stdenv.mkDerivation rec { @@ -12,10 +29,28 @@ stdenv.mkDerivation rec { sha256 = "sha256-VcR+HZ5S7fLrGqT1SHCQLQw6v516G0x+wf8Wb5Sy4Gk="; }; - nativeBuildInputs = [ autoreconfHook pkg-config autoconf automake ]; - buildInputs = [ apacheHttpd curl glib lasso libtool libxml2 libxslt openssl xmlsec ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + autoconf + automake + ]; + buildInputs = [ + apacheHttpd + curl + glib + lasso + libtool + libxml2 + libxslt + openssl + xmlsec + ]; - configureFlags = ["--with-apxs2=${apacheHttpd.dev}/bin/apxs" "--exec-prefix=$out"]; + configureFlags = [ + "--with-apxs2=${apacheHttpd.dev}/bin/apxs" + "--exec-prefix=$out" + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/servers/http/apache-modules/mod_cspnonce/default.nix b/pkgs/servers/http/apache-modules/mod_cspnonce/default.nix index 68486d5d28942f..2ee6f59041a497 100644 --- a/pkgs/servers/http/apache-modules/mod_cspnonce/default.nix +++ b/pkgs/servers/http/apache-modules/mod_cspnonce/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, apacheHttpd }: +{ + stdenv, + lib, + fetchFromGitHub, + apacheHttpd, +}: stdenv.mkDerivation rec { pname = "mod_cspnonce"; diff --git a/pkgs/servers/http/apache-modules/mod_fastcgi/default.nix b/pkgs/servers/http/apache-modules/mod_fastcgi/default.nix index bb1d3acc4a293a..d2f6a7ae3bb596 100644 --- a/pkgs/servers/http/apache-modules/mod_fastcgi/default.nix +++ b/pkgs/servers/http/apache-modules/mod_fastcgi/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, apacheHttpd }: +{ + lib, + stdenv, + fetchFromGitHub, + apacheHttpd, +}: stdenv.mkDerivation rec { pname = "mod_fastcgi"; diff --git a/pkgs/servers/http/apache-modules/mod_itk/default.nix b/pkgs/servers/http/apache-modules/mod_itk/default.nix index 1cbf78a577820b..514be6f129947a 100644 --- a/pkgs/servers/http/apache-modules/mod_itk/default.nix +++ b/pkgs/servers/http/apache-modules/mod_itk/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, mod_ca -, apr -, aprutil -, apacheHttpd +{ + lib, + stdenv, + fetchurl, + pkg-config, + mod_ca, + apr, + aprutil, + apacheHttpd, }: stdenv.mkDerivation rec { @@ -18,7 +19,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ mod_ca apr aprutil apacheHttpd ]; + buildInputs = [ + mod_ca + apr + aprutil + apacheHttpd + ]; installPhase = '' runHook preInstall diff --git a/pkgs/servers/http/apache-modules/mod_mbtiles/default.nix b/pkgs/servers/http/apache-modules/mod_mbtiles/default.nix index c2bf88cbac1a41..abf2ddaa3f524d 100644 --- a/pkgs/servers/http/apache-modules/mod_mbtiles/default.nix +++ b/pkgs/servers/http/apache-modules/mod_mbtiles/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, apacheHttpd, sqlite }: +{ + lib, + stdenv, + fetchFromGitHub, + apacheHttpd, + sqlite, +}: stdenv.mkDerivation rec { pname = "mod_mbtiles"; @@ -11,7 +17,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-wOoLSNLgh0YXHUFn7WfUkQXpyWsgCrVZlMg55rvi9q4="; }; - buildInputs = [ apacheHttpd sqlite ]; + buildInputs = [ + apacheHttpd + sqlite + ]; buildPhase = '' apxs -lsqlite3 -ca mod_mbtiles.c diff --git a/pkgs/servers/http/apache-modules/mod_tile/default.nix b/pkgs/servers/http/apache-modules/mod_tile/default.nix index 1f86587c7d1c13..971441bf5a902e 100644 --- a/pkgs/servers/http/apache-modules/mod_tile/default.nix +++ b/pkgs/servers/http/apache-modules/mod_tile/default.nix @@ -1,21 +1,22 @@ -{ fetchFromGitHub -, lib -, stdenv -, cmake -, pkg-config -, apacheHttpd -, apr -, aprutil -, boost -, cairo -, curl -, glib -, harfbuzz -, icu -, iniparser -, libmemcached -, mapnik -, nix-update-script +{ + fetchFromGitHub, + lib, + stdenv, + cmake, + pkg-config, + apacheHttpd, + apr, + aprutil, + boost, + cairo, + curl, + glib, + harfbuzz, + icu, + iniparser, + libmemcached, + mapnik, + nix-update-script, }: stdenv.mkDerivation rec { diff --git a/pkgs/servers/http/apache-modules/mod_timestamp/default.nix b/pkgs/servers/http/apache-modules/mod_timestamp/default.nix index 1dbe4101dfe6c8..2de2d5a65b3c38 100644 --- a/pkgs/servers/http/apache-modules/mod_timestamp/default.nix +++ b/pkgs/servers/http/apache-modules/mod_timestamp/default.nix @@ -26,10 +26,12 @@ stdenv.mkDerivation rec { mod_ca ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.cc.isClang [ - "-Wno-error=int-conversion" - "-Wno-error=implicit-function-declaration" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.cc.isClang [ + "-Wno-error=int-conversion" + "-Wno-error=implicit-function-declaration" + ] + ); inherit (mod_ca) configureFlags installFlags; diff --git a/pkgs/servers/http/apache-modules/mod_wsgi/default.nix b/pkgs/servers/http/apache-modules/mod_wsgi/default.nix index 8f9e77956de779..83940d9e1fab29 100644 --- a/pkgs/servers/http/apache-modules/mod_wsgi/default.nix +++ b/pkgs/servers/http/apache-modules/mod_wsgi/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, apacheHttpd, python3, ncurses }: +{ + lib, + stdenv, + fetchFromGitHub, + apacheHttpd, + python3, + ncurses, +}: stdenv.mkDerivation rec { pname = "mod_wsgi"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { hash = "sha256-FhOSU8/4QoWa73bNi/qkgKm3CeEEdboh2MgxgQxcYzE="; }; - buildInputs = [ apacheHttpd python3 ncurses ]; + buildInputs = [ + apacheHttpd + python3 + ncurses + ]; postPatch = '' substituteInPlace configure --replace '/usr/bin/lipo' 'lipo' diff --git a/pkgs/servers/http/jboss/default.nix b/pkgs/servers/http/jboss/default.nix index 4ad126afa501f9..bb51b273753737 100644 --- a/pkgs/servers/http/jboss/default.nix +++ b/pkgs/servers/http/jboss/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, jdk }: +{ + lib, + stdenv, + fetchurl, + jdk, +}: stdenv.mkDerivation rec { pname = "jboss-as"; diff --git a/pkgs/servers/http/jetty/common.nix b/pkgs/servers/http/jetty/common.nix index 9b9e064e993f4b..bd643a1b90ad08 100644 --- a/pkgs/servers/http/jetty/common.nix +++ b/pkgs/servers/http/jetty/common.nix @@ -1,6 +1,11 @@ { version, hash }: -{ lib, stdenvNoCC, fetchurl, gitUpdater }: +{ + lib, + stdenvNoCC, + fetchurl, + gitUpdater, +}: stdenvNoCC.mkDerivation rec { pname = "jetty"; @@ -32,7 +37,13 @@ stdenvNoCC.mkDerivation rec { homepage = "https://jetty.org/"; platforms = platforms.all; sourceProvenance = with sourceTypes; [ binaryBytecode ]; - license = with licenses; [ asl20 epl10 ]; - maintainers = with maintainers; [ emmanuelrosa anthonyroussel ]; + license = with licenses; [ + asl20 + epl10 + ]; + maintainers = with maintainers; [ + emmanuelrosa + anthonyroussel + ]; }; } diff --git a/pkgs/servers/http/nginx/generic.nix b/pkgs/servers/http/nginx/generic.nix index 23f42fa49df4e3..b4d630c6f693fb 100644 --- a/pkgs/servers/http/nginx/generic.nix +++ b/pkgs/servers/http/nginx/generic.nix @@ -1,50 +1,76 @@ -outer@{ lib, stdenv, fetchurl, fetchpatch, openssl, zlib-ng, pcre2, libxml2, libxslt -, nginx-doc - -, nixosTests -, installShellFiles, substituteAll, removeReferencesTo, gd, geoip, perl -, withDebug ? false -, withGeoIP ? false -, withImageFilter ? false -, withKTLS ? true -, withStream ? true -, withMail ? false -, withPerl ? true -, withSlice ? false -, modules ? [] -, ... +outer@{ + lib, + stdenv, + fetchurl, + fetchpatch, + openssl, + zlib-ng, + pcre2, + libxml2, + libxslt, + nginx-doc, + + nixosTests, + installShellFiles, + substituteAll, + removeReferencesTo, + gd, + geoip, + perl, + withDebug ? false, + withGeoIP ? false, + withImageFilter ? false, + withKTLS ? true, + withStream ? true, + withMail ? false, + withPerl ? true, + withSlice ? false, + modules ? [ ], + ... }: -{ pname ? "nginx" -, version -, nginxVersion ? version -, src ? null # defaults to upstream nginx ${version} -, hash ? null # when not specifying src -, configureFlags ? [] -, nativeBuildInputs ? [] -, buildInputs ? [] -, extraPatches ? [] -, fixPatch ? p: p -, postPatch ? "" -, preConfigure ? "" -, preInstall ? "" -, postInstall ? "" -, meta ? null -, nginx-doc ? outer.nginx-doc -, passthru ? { tests = {}; } +{ + pname ? "nginx", + version, + nginxVersion ? version, + src ? null, # defaults to upstream nginx ${version} + hash ? null, # when not specifying src + configureFlags ? [ ], + nativeBuildInputs ? [ ], + buildInputs ? [ ], + extraPatches ? [ ], + fixPatch ? p: p, + postPatch ? "", + preConfigure ? "", + preInstall ? "", + postInstall ? "", + meta ? null, + nginx-doc ? outer.nginx-doc, + passthru ? { + tests = { }; + }, }: let - moduleNames = map (mod: mod.name or (throw "The nginx module with source ${toString mod.src} does not have a `name` attribute. This prevents duplicate module detection and is no longer supported.")) - modules; + moduleNames = map ( + mod: + mod.name + or (throw "The nginx module with source ${toString mod.src} does not have a `name` attribute. This prevents duplicate module detection and is no longer supported.") + ) modules; - mapModules = attrPath: lib.flip lib.concatMap modules - (mod: - let supports = mod.supports or (_: true); + mapModules = + attrPath: + lib.flip lib.concatMap modules ( + mod: + let + supports = mod.supports or (_: true); in - if supports nginxVersion then mod.${attrPath} or [] - else throw "Module at ${toString mod.src} does not support nginx version ${nginxVersion}!"); + if supports nginxVersion then + mod.${attrPath} or [ ] + else + throw "Module at ${toString mod.src} does not support nginx version ${nginxVersion}!" + ); in @@ -54,135 +80,172 @@ assert lib.assertMsg (lib.unique moduleNames == moduleNames) stdenv.mkDerivation { inherit pname version nginxVersion; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; - src = if src != null then src else fetchurl { - url = "https://nginx.org/download/nginx-${version}.tar.gz"; - inherit hash; - }; + src = + if src != null then + src + else + fetchurl { + url = "https://nginx.org/download/nginx-${version}.tar.gz"; + inherit hash; + }; nativeBuildInputs = [ installShellFiles removeReferencesTo ] ++ nativeBuildInputs; - buildInputs = [ openssl zlib-ng pcre2 libxml2 libxslt perl ] + buildInputs = + [ + openssl + zlib-ng + pcre2 + libxml2 + libxslt + perl + ] ++ buildInputs ++ mapModules "inputs" ++ lib.optional withGeoIP geoip ++ lib.optional withImageFilter gd; - configureFlags = [ - "--sbin-path=bin/nginx" - "--with-http_ssl_module" - "--with-http_v2_module" - "--with-http_realip_module" - "--with-http_addition_module" - "--with-http_xslt_module" - "--with-http_sub_module" - "--with-http_dav_module" - "--with-http_flv_module" - "--with-http_mp4_module" - "--with-http_gunzip_module" - "--with-http_gzip_static_module" - "--with-http_auth_request_module" - "--with-http_random_index_module" - "--with-http_secure_link_module" - "--with-http_degradation_module" - "--with-http_stub_status_module" - "--with-threads" - "--with-pcre-jit" - "--http-log-path=/var/log/nginx/access.log" - "--error-log-path=/var/log/nginx/error.log" - "--pid-path=/var/log/nginx/nginx.pid" - "--http-client-body-temp-path=/tmp/nginx_client_body" - "--http-proxy-temp-path=/tmp/nginx_proxy" - "--http-fastcgi-temp-path=/tmp/nginx_fastcgi" - "--http-uwsgi-temp-path=/tmp/nginx_uwsgi" - "--http-scgi-temp-path=/tmp/nginx_scgi" - ] ++ lib.optionals withDebug [ - "--with-debug" - ] ++ lib.optionals withKTLS [ - "--with-openssl-opt=enable-ktls" - ] ++ lib.optionals withStream [ - "--with-stream" - "--with-stream_realip_module" - "--with-stream_ssl_module" - "--with-stream_ssl_preread_module" - ] ++ lib.optionals withMail [ - "--with-mail" - "--with-mail_ssl_module" - ] ++ lib.optionals withPerl [ - "--with-http_perl_module" - "--with-perl=${perl}/bin/perl" - "--with-perl_modules_path=lib/perl5" - ] ++ lib.optional withImageFilter "--with-http_image_filter_module" + configureFlags = + [ + "--sbin-path=bin/nginx" + "--with-http_ssl_module" + "--with-http_v2_module" + "--with-http_realip_module" + "--with-http_addition_module" + "--with-http_xslt_module" + "--with-http_sub_module" + "--with-http_dav_module" + "--with-http_flv_module" + "--with-http_mp4_module" + "--with-http_gunzip_module" + "--with-http_gzip_static_module" + "--with-http_auth_request_module" + "--with-http_random_index_module" + "--with-http_secure_link_module" + "--with-http_degradation_module" + "--with-http_stub_status_module" + "--with-threads" + "--with-pcre-jit" + "--http-log-path=/var/log/nginx/access.log" + "--error-log-path=/var/log/nginx/error.log" + "--pid-path=/var/log/nginx/nginx.pid" + "--http-client-body-temp-path=/tmp/nginx_client_body" + "--http-proxy-temp-path=/tmp/nginx_proxy" + "--http-fastcgi-temp-path=/tmp/nginx_fastcgi" + "--http-uwsgi-temp-path=/tmp/nginx_uwsgi" + "--http-scgi-temp-path=/tmp/nginx_scgi" + ] + ++ lib.optionals withDebug [ + "--with-debug" + ] + ++ lib.optionals withKTLS [ + "--with-openssl-opt=enable-ktls" + ] + ++ lib.optionals withStream [ + "--with-stream" + "--with-stream_realip_module" + "--with-stream_ssl_module" + "--with-stream_ssl_preread_module" + ] + ++ lib.optionals withMail [ + "--with-mail" + "--with-mail_ssl_module" + ] + ++ lib.optionals withPerl [ + "--with-http_perl_module" + "--with-perl=${perl}/bin/perl" + "--with-perl_modules_path=lib/perl5" + ] + ++ lib.optional withImageFilter "--with-http_image_filter_module" ++ lib.optional withSlice "--with-http_slice_module" - ++ lib.optionals withGeoIP ([ "--with-http_geoip_module" ] ++ lib.optional withStream "--with-stream_geoip_module") + ++ lib.optionals withGeoIP ( + [ "--with-http_geoip_module" ] ++ lib.optional withStream "--with-stream_geoip_module" + ) ++ lib.optional (with stdenv.hostPlatform; isLinux || isFreeBSD) "--with-file-aio" ++ configureFlags ++ map (mod: "--add-module=${mod.src}") modules; - env.NIX_CFLAGS_COMPILE = toString ([ - "-I${libxml2.dev}/include/libxml2" - "-Wno-error=implicit-fallthrough" - ( - # zlig-ng patch needs this - if stdenv.cc.isGNU then - "-Wno-error=discarded-qualifiers" - else - "-Wno-error=incompatible-pointer-types-discards-qualifiers" - ) - ] ++ lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "11") [ - # fix build vts module on gcc11 - "-Wno-error=stringop-overread" - ] ++ lib.optionals stdenv.cc.isClang [ - "-Wno-error=deprecated-declarations" - "-Wno-error=gnu-folding-constant" - "-Wno-error=unused-but-set-variable" - ] ++ lib.optionals stdenv.hostPlatform.isMusl [ - # fix sys/cdefs.h is deprecated - "-Wno-error=cpp" - ]); - - configurePlatforms = []; + env.NIX_CFLAGS_COMPILE = toString ( + [ + "-I${libxml2.dev}/include/libxml2" + "-Wno-error=implicit-fallthrough" + ( + # zlig-ng patch needs this + if stdenv.cc.isGNU then + "-Wno-error=discarded-qualifiers" + else + "-Wno-error=incompatible-pointer-types-discards-qualifiers" + ) + ] + ++ lib.optionals (stdenv.cc.isGNU && lib.versionAtLeast stdenv.cc.version "11") [ + # fix build vts module on gcc11 + "-Wno-error=stringop-overread" + ] + ++ lib.optionals stdenv.cc.isClang [ + "-Wno-error=deprecated-declarations" + "-Wno-error=gnu-folding-constant" + "-Wno-error=unused-but-set-variable" + ] + ++ lib.optionals stdenv.hostPlatform.isMusl [ + # fix sys/cdefs.h is deprecated + "-Wno-error=cpp" + ] + ); + + configurePlatforms = [ ]; # Disable _multioutConfig hook which adds --bindir=$out/bin into configureFlags, # which breaks build, since nginx does not actually use autoconf. - preConfigure = '' - setOutputFlags= - '' + preConfigure - + lib.concatMapStringsSep "\n" (mod: mod.preConfigure or "") modules; - - patches = map fixPatch ([ - (substituteAll { - src = ./nix-etag-1.15.4.patch; - preInstall = '' - export nixStoreDir="$NIX_STORE" nixStoreDirLen="''${#NIX_STORE}" - ''; - }) - ./nix-skip-check-logs-path.patch - ] ++ lib.optionals (pname != "openresty") [ - # https://github.com/NixOS/nixpkgs/issues/357522 - # https://github.com/zlib-ng/patches/blob/5a036c0a00120c75ee573b27f4f44ade80d82ff2/nginx/README.md - (fetchpatch { - url = "https://raw.githubusercontent.com/zlib-ng/patches/38756e6325a5d2cc32709b8e9549984c63a78815/nginx/1.26.2-zlib-ng.patch"; - hash = "sha256-LX5kP6jFiqgt4ApKw5eqOAFJNkc5QI6kX8ZRvBYTi9k="; - }) - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - (fetchpatch { - url = "https://raw.githubusercontent.com/openwrt/packages/c057dfb09c7027287c7862afab965a4cd95293a3/net/nginx/patches/102-sizeof_test_fix.patch"; - sha256 = "0i2k30ac8d7inj9l6bl0684kjglam2f68z8lf3xggcc2i5wzhh8a"; - }) - (fetchpatch { - url = "https://raw.githubusercontent.com/openwrt/packages/c057dfb09c7027287c7862afab965a4cd95293a3/net/nginx/patches/101-feature_test_fix.patch"; - sha256 = "0v6890a85aqmw60pgj3mm7g8nkaphgq65dj4v9c6h58wdsrc6f0y"; - }) - (fetchpatch { - url = "https://raw.githubusercontent.com/openwrt/packages/c057dfb09c7027287c7862afab965a4cd95293a3/net/nginx/patches/103-sys_nerr.patch"; - sha256 = "0s497x6mkz947aw29wdy073k8dyjq8j99lax1a1mzpikzr4rxlmd"; - }) - ] ++ mapModules "patches") + preConfigure = + '' + setOutputFlags= + '' + + preConfigure + + lib.concatMapStringsSep "\n" (mod: mod.preConfigure or "") modules; + + patches = + map fixPatch ( + [ + (substituteAll { + src = ./nix-etag-1.15.4.patch; + preInstall = '' + export nixStoreDir="$NIX_STORE" nixStoreDirLen="''${#NIX_STORE}" + ''; + }) + ./nix-skip-check-logs-path.patch + ] + ++ lib.optionals (pname != "openresty") [ + # https://github.com/NixOS/nixpkgs/issues/357522 + # https://github.com/zlib-ng/patches/blob/5a036c0a00120c75ee573b27f4f44ade80d82ff2/nginx/README.md + (fetchpatch { + url = "https://raw.githubusercontent.com/zlib-ng/patches/38756e6325a5d2cc32709b8e9549984c63a78815/nginx/1.26.2-zlib-ng.patch"; + hash = "sha256-LX5kP6jFiqgt4ApKw5eqOAFJNkc5QI6kX8ZRvBYTi9k="; + }) + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + (fetchpatch { + url = "https://raw.githubusercontent.com/openwrt/packages/c057dfb09c7027287c7862afab965a4cd95293a3/net/nginx/patches/102-sizeof_test_fix.patch"; + sha256 = "0i2k30ac8d7inj9l6bl0684kjglam2f68z8lf3xggcc2i5wzhh8a"; + }) + (fetchpatch { + url = "https://raw.githubusercontent.com/openwrt/packages/c057dfb09c7027287c7862afab965a4cd95293a3/net/nginx/patches/101-feature_test_fix.patch"; + sha256 = "0v6890a85aqmw60pgj3mm7g8nkaphgq65dj4v9c6h58wdsrc6f0y"; + }) + (fetchpatch { + url = "https://raw.githubusercontent.com/openwrt/packages/c057dfb09c7027287c7862afab965a4cd95293a3/net/nginx/patches/103-sys_nerr.patch"; + sha256 = "0s497x6mkz947aw29wdy073k8dyjq8j99lax1a1mzpikzr4rxlmd"; + }) + ] + ++ mapModules "patches" + ) ++ extraPatches; inherit postPatch; @@ -191,40 +254,68 @@ stdenv.mkDerivation { enableParallelBuilding = true; - preInstall = '' - mkdir -p $doc - cp -r ${nginx-doc}/* $doc + preInstall = + '' + mkdir -p $doc + cp -r ${nginx-doc}/* $doc - # TODO: make it unconditional when `openresty` and `nginx` are not - # sharing this code. - if [[ -e man/nginx.8 ]]; then - installManPage man/nginx.8 - fi - '' + preInstall; + # TODO: make it unconditional when `openresty` and `nginx` are not + # sharing this code. + if [[ -e man/nginx.8 ]]; then + installManPage man/nginx.8 + fi + '' + + preInstall; disallowedReferences = map (m: m.src) modules; postInstall = let - noSourceRefs = lib.concatMapStrings (m: "remove-references-to -t ${m.src} $(readlink -fn $out/bin/nginx)\n") modules; - in postInstall + noSourceRefs; + noSourceRefs = lib.concatMapStrings ( + m: "remove-references-to -t ${m.src} $(readlink -fn $out/bin/nginx)\n" + ) modules; + in + postInstall + noSourceRefs; passthru = { inherit modules; tests = { - inherit (nixosTests) nginx nginx-auth nginx-etag nginx-etag-compression nginx-globalredirect nginx-http3 nginx-proxyprotocol nginx-pubhtml nginx-sso nginx-status-page nginx-unix-socket; + inherit (nixosTests) + nginx + nginx-auth + nginx-etag + nginx-etag-compression + nginx-globalredirect + nginx-http3 + nginx-proxyprotocol + nginx-pubhtml + nginx-sso + nginx-status-page + nginx-unix-socket + ; variants = lib.recurseIntoAttrs nixosTests.nginx-variants; acme-integration = nixosTests.acme; } // passthru.tests; }; - meta = if meta != null then meta else with lib; { - description = "Reverse proxy and lightweight webserver"; - mainProgram = "nginx"; - homepage = "http://nginx.org"; - license = [ licenses.bsd2 ] - ++ concatMap (m: m.meta.license) modules; - platforms = platforms.all; - maintainers = with maintainers; [ fpletz raitobezarius ] ++ teams.helsinki-systems.members ++ teams.stridtech.members; - }; + meta = + if meta != null then + meta + else + with lib; + { + description = "Reverse proxy and lightweight webserver"; + mainProgram = "nginx"; + homepage = "http://nginx.org"; + license = [ licenses.bsd2 ] ++ concatMap (m: m.meta.license) modules; + platforms = platforms.all; + maintainers = + with maintainers; + [ + fpletz + raitobezarius + ] + ++ teams.helsinki-systems.members + ++ teams.stridtech.members; + }; } diff --git a/pkgs/servers/http/nginx/quic.nix b/pkgs/servers/http/nginx/quic.nix index ea5af571f11079..a3db09f16bb872 100644 --- a/pkgs/servers/http/nginx/quic.nix +++ b/pkgs/servers/http/nginx/quic.nix @@ -1,7 +1,8 @@ -{ callPackage -, nginxMainline -, ... -} @ args: +{ + callPackage, + nginxMainline, + ... +}@args: callPackage ./generic.nix args { pname = "nginxQuic"; diff --git a/pkgs/servers/http/nginx/stable.nix b/pkgs/servers/http/nginx/stable.nix index 48c1f99b240c38..e1c69c4263b0cc 100644 --- a/pkgs/servers/http/nginx/stable.nix +++ b/pkgs/servers/http/nginx/stable.nix @@ -1,4 +1,4 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: callPackage ./generic.nix args { version = "1.26.2"; diff --git a/pkgs/servers/http/openresty/default.nix b/pkgs/servers/http/openresty/default.nix index 0073fae047bedb..d40cb644cf4d28 100644 --- a/pkgs/servers/http/openresty/default.nix +++ b/pkgs/servers/http/openresty/default.nix @@ -1,12 +1,13 @@ -{ callPackage -, runCommand -, lib -, fetchurl -, perl -, postgresql -, nixosTests -, withPostgres ? true -, ... +{ + callPackage, + runCommand, + lib, + fetchurl, + perl, + postgresql, + nixosTests, + withPostgres ? true, + ... }@args: callPackage ../nginx/generic.nix args rec { @@ -22,8 +23,11 @@ callPackage ../nginx/generic.nix args rec { # generic.nix applies fixPatch on top of every patch defined there. # This allows updating the patch destination, as openresty has # nginx source code in a different folder. - fixPatch = patch: - let name = patch.name or (builtins.baseNameOf patch); in + fixPatch = + patch: + let + name = patch.name or (builtins.baseNameOf patch); + in runCommand "openresty-${name}" { src = patch; } '' substitute $src $out \ --replace "a/" "a/bundle/nginx-${nginxVersion}/" \ @@ -57,6 +61,9 @@ callPackage ../nginx/generic.nix args rec { homepage = "https://openresty.org"; license = lib.licenses.bsd2; platforms = lib.platforms.all; - maintainers = with lib.maintainers; [ thoughtpolice lblasc ]; + maintainers = with lib.maintainers; [ + thoughtpolice + lblasc + ]; }; } diff --git a/pkgs/servers/http/showoff/default.nix b/pkgs/servers/http/showoff/default.nix index c3deae28ec0e22..9c94b43b77d6a8 100644 --- a/pkgs/servers/http/showoff/default.nix +++ b/pkgs/servers/http/showoff/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "showoff"; @@ -13,6 +17,9 @@ bundlerApp { homepage = "https://puppetlabs.github.io/showoff/"; license = with licenses; mit; platforms = platforms.unix; - maintainers = with maintainers; [ maxwilson nicknovitski ]; + maintainers = with maintainers; [ + maxwilson + nicknovitski + ]; }; } diff --git a/pkgs/servers/http/showoff/gemset.nix b/pkgs/servers/http/showoff/gemset.nix index d493a0a79751fc..e2f42b5abb4d03 100644 --- a/pkgs/servers/http/showoff/gemset.nix +++ b/pkgs/servers/http/showoff/gemset.nix @@ -1,17 +1,17 @@ { addressable = { - dependencies = ["public_suffix"]; + dependencies = [ "public_suffix" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bcm2hchn897xjhqj9zzsxf3n9xhddymj4lsclz508f4vw3av46l"; type = "gem"; }; version = "2.6.0"; }; commonmarker = { - dependencies = ["ruby-enum"]; + dependencies = [ "ruby-enum" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "122dy5mzx4p86flpzyg3raf742zp5ab9bjr7zk29p3ixpncf0rdk"; type = "gem"; }; @@ -19,7 +19,7 @@ }; concurrent-ruby = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x07r23s7836cpp5z9yrlbpljcxpax14yw4fy4bnp6crhr6x24an"; type = "gem"; }; @@ -27,16 +27,19 @@ }; daemons = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0l5gai3vd4g7aqff0k1mp41j9zcsvm2rbwmqn115a325k9r7pf4w"; type = "gem"; }; version = "1.3.1"; }; em-websocket = { - dependencies = ["addressable" "eventmachine"]; + dependencies = [ + "addressable" + "eventmachine" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xkb1rc6dd3y5s7qsp4wqrri3n9gwsbvnwwv6xwgp241jxdpp4iq"; type = "gem"; }; @@ -44,16 +47,16 @@ }; eventmachine = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wh9aqb0skz80fhfn66lbpr4f86ya2z5rx6gm5xlfhd05bj1ch4r"; type = "gem"; }; version = "1.2.7"; }; fidget = { - dependencies = ["ruby-dbus"]; + dependencies = [ "ruby-dbus" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04g2846wjlb8ms5041lv37aqs4jzsziwv58bxg7yzc61pdvi4ksb"; type = "gem"; }; @@ -61,7 +64,7 @@ }; gli = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "133glfzsq67ykmdsgp251s9kddg9x4qki2jpbjv25h3hawlql4hs"; type = "gem"; }; @@ -69,16 +72,16 @@ }; htmlentities = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nkklqsn8ir8wizzlakncfv42i32wc0w9hxp00hvdlgjr7376nhj"; type = "gem"; }; version = "4.3.4"; }; i18n = { - dependencies = ["concurrent-ruby"]; + dependencies = [ "concurrent-ruby" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1hfxnlyr618s25xpafw9mypa82qppjccbh292c4l3bj36az7f6wl"; type = "gem"; }; @@ -86,7 +89,7 @@ }; iso-639 = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10k1gpkkbxbasgjzh4hd32ygxzjb5312rphipm46ryxkpx556zzz"; type = "gem"; }; @@ -94,7 +97,7 @@ }; json = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sx97bm9by389rbzv8r1f43h06xcz8vwi3h5jv074gvparql7lcx"; type = "gem"; }; @@ -102,16 +105,16 @@ }; mini_portile2 = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15zplpfw3knqifj9bpf604rb3wc1vhq6363pd6lvhayng8wql5vy"; type = "gem"; }; version = "2.4.0"; }; nokogiri = { - dependencies = ["mini_portile2"]; + dependencies = [ "mini_portile2" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09zll7c6j7xr6wyvh5mm5ncj6pkryp70ybcsxdbw1nyphx5dh184"; type = "gem"; }; @@ -119,7 +122,7 @@ }; parslet = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12nrzfwjphjlakb9pmpj70hgjwgzvnr8i1zfzddifgyd44vspl88"; type = "gem"; }; @@ -127,7 +130,7 @@ }; public_suffix = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08q64b5br692dd3v0a9wq9q5dvycc6kmiqmjbdxkxbfizggsvx6l"; type = "gem"; }; @@ -135,25 +138,25 @@ }; rack = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g9926ln2lw12lfxm4ylq1h6nl0rafl10za3xvjzc87qvnqic87f"; type = "gem"; }; version = "1.6.11"; }; rack-contrib = { - dependencies = ["rack"]; + dependencies = [ "rack" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l7m0av4pjl5p64l8j7pkip1jwhkp80a8kc2j7b9lrwh04fgx5wx"; type = "gem"; }; version = "1.8.0"; }; rack-protection = { - dependencies = ["rack"]; + dependencies = [ "rack" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0my0wlw4a5l3hs79jkx2xzv7djhajgf8d28k8ai1ddlnxxb0v7ss"; type = "gem"; }; @@ -161,7 +164,7 @@ }; redcarpet = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h9qz2hik4s9knpmbwrzb3jcp3vc5vygp9ya8lcpl7f1l9khmcd7"; type = "gem"; }; @@ -169,52 +172,80 @@ }; ruby-dbus = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16lsqdwas6ngyyvq51l7lynj5ayis17zm5hpsg5x3m3n6r5k2gv4"; type = "gem"; }; version = "0.14.1"; }; ruby-enum = { - dependencies = ["i18n"]; + dependencies = [ "i18n" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h62avini866kxpjzqxlqnajma3yvj0y25l6hn9h2mv5pp6fcrhx"; type = "gem"; }; version = "0.7.2"; }; showoff = { - dependencies = ["commonmarker" "fidget" "gli" "htmlentities" "i18n" "iso-639" "json" "nokogiri" "parslet" "rack-contrib" "redcarpet" "sinatra" "sinatra-websocket" "thin" "tilt"]; + dependencies = [ + "commonmarker" + "fidget" + "gli" + "htmlentities" + "i18n" + "iso-639" + "json" + "nokogiri" + "parslet" + "rack-contrib" + "redcarpet" + "sinatra" + "sinatra-websocket" + "thin" + "tilt" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14884kh7vrp5b72dpn7q26h49y7igxqza72girkv1h28qx4kqw4r"; type = "gem"; }; version = "0.20.1"; }; sinatra = { - dependencies = ["rack" "rack-protection" "tilt"]; + dependencies = [ + "rack" + "rack-protection" + "tilt" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0byxzl7rx3ki0xd7aiv1x8mbah7hzd8f81l65nq8857kmgzj1jqq"; type = "gem"; }; version = "1.4.8"; }; sinatra-websocket = { - dependencies = ["em-websocket" "eventmachine" "thin"]; + dependencies = [ + "em-websocket" + "eventmachine" + "thin" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0as52mfw34z3ba6qjab009h2rdn0za0iwrc42kw948hbb8qzcm5m"; type = "gem"; }; version = "0.3.1"; }; thin = { - dependencies = ["daemons" "eventmachine" "rack"]; + dependencies = [ + "daemons" + "eventmachine" + "rack" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nagbf9pwy1vg09k6j4xqhbjjzrg5dwzvkn4ffvlj76fsn6vv61f"; type = "gem"; }; @@ -222,7 +253,7 @@ }; tilt = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ca4k0clwf0rkvy7726x4nxpjxkpv67w043i39saxgldxd97zmwz"; type = "gem"; }; diff --git a/pkgs/servers/http/tengine/default.nix b/pkgs/servers/http/tengine/default.nix index bddb334e8c5d48..812784ebd394d5 100644 --- a/pkgs/servers/http/tengine/default.nix +++ b/pkgs/servers/http/tengine/default.nix @@ -1,10 +1,24 @@ -{ lib, stdenv, fetchFromGitHub, openssl, zlib, pcre, libxcrypt, libxml2, libxslt -, substituteAll, gd, geoip, gperftools, jemalloc, nixosTests -, withDebug ? false -, withMail ? false -, withStream ? false -, modules ? [] -, ... +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + zlib, + pcre, + libxcrypt, + libxml2, + libxslt, + substituteAll, + gd, + geoip, + gperftools, + jemalloc, + nixosTests, + withDebug ? false, + withMail ? false, + withStream ? false, + modules ? [ ], + ... }: let @@ -21,85 +35,104 @@ stdenv.mkDerivation rec { hash = "sha256-cClSNBlresMHqJrqSFWvUo589TlwJ2tL5FWJG9QBuis="; }; - buildInputs = - [ openssl zlib pcre libxcrypt libxml2 libxslt gd geoip gperftools jemalloc ] - ++ lib.concatMap (mod: mod.inputs or []) modules; + buildInputs = [ + openssl + zlib + pcre + libxcrypt + libxml2 + libxslt + gd + geoip + gperftools + jemalloc + ] ++ lib.concatMap (mod: mod.inputs or [ ]) modules; - patches = lib.singleton (substituteAll { - src = ../nginx/nix-etag-1.15.4.patch; - preInstall = '' - export nixStoreDir="$NIX_STORE" nixStoreDirLen="''${#NIX_STORE}" - ''; - }) ++ [ - ./check-resolv-conf.patch - ../nginx/nix-skip-check-logs-path.patch - ]; + patches = + lib.singleton (substituteAll { + src = ../nginx/nix-etag-1.15.4.patch; + preInstall = '' + export nixStoreDir="$NIX_STORE" nixStoreDirLen="''${#NIX_STORE}" + ''; + }) + ++ [ + ./check-resolv-conf.patch + ../nginx/nix-skip-check-logs-path.patch + ]; - configureFlags = [ - "--with-http_ssl_module" - "--with-http_v2_module" - "--with-http_realip_module" - "--with-http_addition_module" - "--with-http_xslt_module" - "--with-http_geoip_module" - "--with-http_sub_module" - "--with-http_dav_module" - "--with-http_flv_module" - "--with-http_mp4_module" - "--with-http_gunzip_module" - "--with-http_gzip_static_module" - "--with-http_auth_request_module" - "--with-http_random_index_module" - "--with-http_secure_link_module" - "--with-http_degradation_module" - "--with-http_stub_status_module" - "--with-threads" - "--with-pcre-jit" - "--with-http_slice_module" - "--with-select_module" - "--with-poll_module" - "--with-google_perftools_module" - "--with-jemalloc" - "--http-log-path=/var/log/nginx/access.log" - "--error-log-path=/var/log/nginx/error.log" - "--pid-path=/var/log/nginx/nginx.pid" - "--http-client-body-temp-path=/var/cache/nginx/client_body" - "--http-proxy-temp-path=/var/cache/nginx/proxy" - "--http-fastcgi-temp-path=/var/cache/nginx/fastcgi" - "--http-uwsgi-temp-path=/var/cache/nginx/uwsgi" - "--http-scgi-temp-path=/var/cache/nginx/scgi" - ] ++ optionals withDebug [ - "--with-debug" - ] ++ optionals withMail [ - "--with-mail" - "--with-mail_ssl_module" - ] ++ optionals (!withMail) [ - "--without-mail_pop3_module" - "--without-mail_imap_module" - "--without-mail_smtp_module" - ] ++ optionals withStream [ - "--with-stream" - "--with-stream_ssl_module" - "--with-stream_realip_module" - "--with-stream_geoip_module" - "--with-stream_ssl_preread_module" - "--with-stream_sni" - ] ++ optionals (!withStream) [ - "--without-stream_limit_conn_module" - "--without-stream_access_module" - "--without-stream_geo_module" - "--without-stream_map_module" - "--without-stream_split_clients_module" - "--without-stream_return_module" - "--without-stream_upstream_hash_module" - "--without-stream_upstream_least_conn_module" - "--without-stream_upstream_random_module" - "--without-stream_upstream_zone_module" - ] ++ optional (gd != null) "--with-http_image_filter_module" + configureFlags = + [ + "--with-http_ssl_module" + "--with-http_v2_module" + "--with-http_realip_module" + "--with-http_addition_module" + "--with-http_xslt_module" + "--with-http_geoip_module" + "--with-http_sub_module" + "--with-http_dav_module" + "--with-http_flv_module" + "--with-http_mp4_module" + "--with-http_gunzip_module" + "--with-http_gzip_static_module" + "--with-http_auth_request_module" + "--with-http_random_index_module" + "--with-http_secure_link_module" + "--with-http_degradation_module" + "--with-http_stub_status_module" + "--with-threads" + "--with-pcre-jit" + "--with-http_slice_module" + "--with-select_module" + "--with-poll_module" + "--with-google_perftools_module" + "--with-jemalloc" + "--http-log-path=/var/log/nginx/access.log" + "--error-log-path=/var/log/nginx/error.log" + "--pid-path=/var/log/nginx/nginx.pid" + "--http-client-body-temp-path=/var/cache/nginx/client_body" + "--http-proxy-temp-path=/var/cache/nginx/proxy" + "--http-fastcgi-temp-path=/var/cache/nginx/fastcgi" + "--http-uwsgi-temp-path=/var/cache/nginx/uwsgi" + "--http-scgi-temp-path=/var/cache/nginx/scgi" + ] + ++ optionals withDebug [ + "--with-debug" + ] + ++ optionals withMail [ + "--with-mail" + "--with-mail_ssl_module" + ] + ++ optionals (!withMail) [ + "--without-mail_pop3_module" + "--without-mail_imap_module" + "--without-mail_smtp_module" + ] + ++ optionals withStream [ + "--with-stream" + "--with-stream_ssl_module" + "--with-stream_realip_module" + "--with-stream_geoip_module" + "--with-stream_ssl_preread_module" + "--with-stream_sni" + ] + ++ optionals (!withStream) [ + "--without-stream_limit_conn_module" + "--without-stream_access_module" + "--without-stream_geo_module" + "--without-stream_map_module" + "--without-stream_split_clients_module" + "--without-stream_return_module" + "--without-stream_upstream_hash_module" + "--without-stream_upstream_least_conn_module" + "--without-stream_upstream_random_module" + "--without-stream_upstream_zone_module" + ] + ++ optional (gd != null) "--with-http_image_filter_module" ++ optional (with stdenv.hostPlatform; isLinux || isFreeBSD) "--with-file-aio" ++ map (mod: "--add-module=${mod.src}") modules; - env.NIX_CFLAGS_COMPILE = "-I${libxml2.dev}/include/libxml2 -Wno-error=implicit-fallthrough" + env.NIX_CFLAGS_COMPILE = + "-I${libxml2.dev}/include/libxml2 -Wno-error=implicit-fallthrough" + optionalString stdenv.hostPlatform.isDarwin " -Wno-error=deprecated-declarations"; preConfigure = (lib.concatMapStringsSep "\n" (mod: mod.preConfigure or "") modules); @@ -120,9 +153,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Web server based on Nginx and has many advanced features, originated by Taobao"; mainProgram = "nginx"; - homepage = "https://tengine.taobao.org"; - license = licenses.bsd2; - platforms = platforms.all; + homepage = "https://tengine.taobao.org"; + license = licenses.bsd2; + platforms = platforms.all; maintainers = with maintainers; [ izorkin ]; }; } diff --git a/pkgs/servers/http/tomcat/tomcat-native.nix b/pkgs/servers/http/tomcat/tomcat-native.nix index d95296b7614960..e2d621e9cdc645 100644 --- a/pkgs/servers/http/tomcat/tomcat-native.nix +++ b/pkgs/servers/http/tomcat/tomcat-native.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, apr, jdk, openssl }: +{ + lib, + stdenv, + fetchurl, + apr, + jdk, + openssl, +}: stdenv.mkDerivation rec { pname = "tomcat-native"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { sourceRoot = "${pname}-${version}-src/native"; - buildInputs = [ apr jdk openssl ]; + buildInputs = [ + apr + jdk + openssl + ]; configureFlags = [ "--with-apr=${apr.dev}" diff --git a/pkgs/servers/icingaweb2/default.nix b/pkgs/servers/icingaweb2/default.nix index a6d3a8125753bd..20ad08cde1a047 100644 --- a/pkgs/servers/icingaweb2/default.nix +++ b/pkgs/servers/icingaweb2/default.nix @@ -1,4 +1,11 @@ -{ stdenvNoCC, lib, fetchFromGitHub, makeWrapper, php, nixosTests }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, + makeWrapper, + php, + nixosTests, +}: stdenvNoCC.mkDerivation rec { pname = "icingaweb2"; diff --git a/pkgs/servers/icingaweb2/ipl.nix b/pkgs/servers/icingaweb2/ipl.nix index 4512dfaa6ca6aa..e935c283f30669 100644 --- a/pkgs/servers/icingaweb2/ipl.nix +++ b/pkgs/servers/icingaweb2/ipl.nix @@ -1,4 +1,9 @@ -{ stdenvNoCC, lib, fetchFromGitHub, nixosTests }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, + nixosTests, +}: stdenvNoCC.mkDerivation rec { pname = "icingaweb2-ipl"; diff --git a/pkgs/servers/icingaweb2/theme-april/default.nix b/pkgs/servers/icingaweb2/theme-april/default.nix index 05f9b9c971b72a..51633ea0a8d017 100644 --- a/pkgs/servers/icingaweb2/theme-april/default.nix +++ b/pkgs/servers/icingaweb2/theme-april/default.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/servers/icingaweb2/theme-lsd/default.nix b/pkgs/servers/icingaweb2/theme-lsd/default.nix index e2c60ef7986953..5e3afdc72bb3e1 100644 --- a/pkgs/servers/icingaweb2/theme-lsd/default.nix +++ b/pkgs/servers/icingaweb2/theme-lsd/default.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/servers/icingaweb2/theme-particles/default.nix b/pkgs/servers/icingaweb2/theme-particles/default.nix index 7e8adb72c6d938..da9aaaf6a49963 100644 --- a/pkgs/servers/icingaweb2/theme-particles/default.nix +++ b/pkgs/servers/icingaweb2/theme-particles/default.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/servers/icingaweb2/theme-snow/default.nix b/pkgs/servers/icingaweb2/theme-snow/default.nix index 9b571b948b523a..e38ea325e2ab46 100644 --- a/pkgs/servers/icingaweb2/theme-snow/default.nix +++ b/pkgs/servers/icingaweb2/theme-snow/default.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/servers/icingaweb2/theme-spring/default.nix b/pkgs/servers/icingaweb2/theme-spring/default.nix index 8392124eb072aa..618e78a1bd7473 100644 --- a/pkgs/servers/icingaweb2/theme-spring/default.nix +++ b/pkgs/servers/icingaweb2/theme-spring/default.nix @@ -1,6 +1,7 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/servers/icingaweb2/theme-unicorn/default.nix b/pkgs/servers/icingaweb2/theme-unicorn/default.nix index 39c4e7b9274384..7fc162b90b25a9 100644 --- a/pkgs/servers/icingaweb2/theme-unicorn/default.nix +++ b/pkgs/servers/icingaweb2/theme-unicorn/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitHub +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, }: stdenv.mkDerivation rec { diff --git a/pkgs/servers/icingaweb2/thirdparty.nix b/pkgs/servers/icingaweb2/thirdparty.nix index 3ba9aee65221e5..87a12d2f578843 100644 --- a/pkgs/servers/icingaweb2/thirdparty.nix +++ b/pkgs/servers/icingaweb2/thirdparty.nix @@ -1,4 +1,9 @@ -{ stdenvNoCC, lib, fetchFromGitHub, nixosTests }: +{ + stdenvNoCC, + lib, + fetchFromGitHub, + nixosTests, +}: stdenvNoCC.mkDerivation rec { pname = "icingaweb2-thirdparty"; diff --git a/pkgs/servers/irc/charybdis/default.nix b/pkgs/servers/irc/charybdis/default.nix index 387914e8a6abda..1b9dc07574661d 100644 --- a/pkgs/servers/irc/charybdis/default.nix +++ b/pkgs/servers/irc/charybdis/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, bison, flex, openssl, gnutls }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + bison, + flex, + openssl, + gnutls, +}: stdenv.mkDerivation rec { pname = "charybdis"; @@ -25,15 +34,22 @@ stdenv.mkDerivation rec { "--with-program-prefix=charybdis-" ]; - nativeBuildInputs = [ autoreconfHook bison flex ]; - buildInputs = [ openssl gnutls ]; + nativeBuildInputs = [ + autoreconfHook + bison + flex + ]; + buildInputs = [ + openssl + gnutls + ]; meta = with lib; { description = "IRCv3 server designed to be highly scalable"; - homepage = "https://github.com/charybdis-ircd/charybdis"; - license = licenses.gpl2Plus; + homepage = "https://github.com/charybdis-ircd/charybdis"; + license = licenses.gpl2Plus; maintainers = with maintainers; [ lassulus ]; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/servers/irc/solanum/default.nix b/pkgs/servers/irc/solanum/default.nix index b31a7e16cd1fa1..da41c55c7e7e83 100644 --- a/pkgs/servers/irc/solanum/default.nix +++ b/pkgs/servers/irc/solanum/default.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, autoreconfHook -, bison -, fetchFromGitHub -, flex -, lksctp-tools -, openssl -, pkg-config -, sqlite -, util-linux -, nixosTests +{ + lib, + stdenv, + autoreconfHook, + bison, + fetchFromGitHub, + flex, + lksctp-tools, + openssl, + pkg-config, + sqlite, + util-linux, + nixosTests, }: stdenv.mkDerivation rec { @@ -30,17 +32,19 @@ stdenv.mkDerivation rec { substituteInPlace include/defaults.h --replace 'ETCPATH "' '"/etc/solanum' ''; - configureFlags = [ - "--enable-epoll" - "--enable-ipv6" - "--enable-openssl=${openssl.dev}" - "--with-program-prefix=solanum-" - "--localstatedir=/var/lib" - "--with-rundir=/run" - "--with-logdir=/var/log" - ] ++ lib.optionals (stdenv.hostPlatform.isLinux) [ - "--enable-sctp=${lksctp-tools.out}/lib" - ]; + configureFlags = + [ + "--enable-epoll" + "--enable-ipv6" + "--enable-openssl=${openssl.dev}" + "--with-program-prefix=solanum-" + "--localstatedir=/var/lib" + "--with-rundir=/run" + "--with-logdir=/var/log" + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux) [ + "--enable-sctp=${lksctp-tools.out}/lib" + ]; nativeBuildInputs = [ autoreconfHook diff --git a/pkgs/servers/isso/default.nix b/pkgs/servers/isso/default.nix index 6d5de7429be1c7..7613cd0f0caae5 100644 --- a/pkgs/servers/isso/default.nix +++ b/pkgs/servers/isso/default.nix @@ -1,4 +1,13 @@ -{ pkgs, nodejs, lib, python3Packages, fetchFromGitHub, nixosTests, fetchNpmDeps, npmHooks }: +{ + pkgs, + nodejs, + lib, + python3Packages, + fetchFromGitHub, + nixosTests, + fetchNpmDeps, + npmHooks, +}: with python3Packages; diff --git a/pkgs/servers/jackett/default.nix b/pkgs/servers/jackett/default.nix index bf88379b2b6ce1..d3f3a011f52409 100644 --- a/pkgs/servers/jackett/default.nix +++ b/pkgs/servers/jackett/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, buildDotnetModule -, fetchFromGitHub -, dotnetCorePackages -, openssl -, mono -, nixosTests +{ + lib, + stdenv, + buildDotnetModule, + fetchFromGitHub, + dotnetCorePackages, + openssl, + mono, + nixosTests, }: buildDotnetModule rec { @@ -48,6 +49,10 @@ buildDotnetModule rec { homepage = "https://github.com/Jackett/Jackett/"; changelog = "https://github.com/Jackett/Jackett/releases/tag/v${version}"; license = licenses.gpl2Only; - maintainers = with maintainers; [ edwtjo nyanloutre purcell ]; + maintainers = with maintainers; [ + edwtjo + nyanloutre + purcell + ]; }; } diff --git a/pkgs/servers/jackett/deps.nix b/pkgs/servers/jackett/deps.nix index b96c5d9c95ed8e..d40f302a9c48b7 100644 --- a/pkgs/servers/jackett/deps.nix +++ b/pkgs/servers/jackett/deps.nix @@ -1,286 +1,1411 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "AngleSharp"; version = "1.1.2"; hash = "sha256-LvJDD+C/NiPLVjEnIWkR+39UkzoeWgPd7BBXakij0WU="; }) - (fetchNuGet { pname = "AngleSharp.Xml"; version = "1.0.0"; hash = "sha256-UzxXWH6qG2BEAH/ULosGkUn2RhghUOguyVTPYl78spM="; }) - (fetchNuGet { pname = "Autofac"; version = "8.0.0"; hash = "sha256-7XhDXw8hatQFjQMTIorQ5XrfDCc7EVNVyi6bGbc5fnA="; }) - (fetchNuGet { pname = "Autofac.Extensions.DependencyInjection"; version = "9.0.0"; hash = "sha256-hEqvbTkJqcI4S4LpxVOMyc5m+KeN0nRLk7FqQHSLRd4="; }) - (fetchNuGet { pname = "BencodeNET"; version = "4.0.0"; hash = "sha256-Bjlpq7laGbrxpYf6GpxklF9AalIh7dTYefU8cDS+fxY="; }) - (fetchNuGet { pname = "CommandLineParser"; version = "2.9.1"; hash = "sha256-ApU9y1yX60daSjPk3KYDBeJ7XZByKW8hse9NRZGcjeo="; }) - (fetchNuGet { pname = "coverlet.msbuild"; version = "6.0.2"; hash = "sha256-Ptj/f41dJ1T+DYvJ8bUo7Bnjp5R+xFOKGVhg3GA+f/A="; }) - (fetchNuGet { pname = "DotNet4.SocksProxy"; version = "1.4.0.1"; hash = "sha256-a+sqVAHupD9DLFfRptjvPoW7YU+qT5yxUYGAqmNS4sU="; }) - (fetchNuGet { pname = "FlareSolverrSharp"; version = "3.0.7"; hash = "sha256-zropUtNiHVSG0ULK01wOhqgZSlWi+CXZ+4SKWok33BI="; }) - (fetchNuGet { pname = "FluentAssertions"; version = "6.12.1"; hash = "sha256-R/Fi9eee6T8t8JECxL9+HFd8jAxRMkCg18j+fAQLNqM="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore"; version = "2.2.0"; hash = "sha256-yZUh/m5s/tgGZOKGylcbPaZ67AHi/mM0xE/bqhk8W28="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Antiforgery"; version = "2.2.0"; hash = "sha256-NBUF/oT5TYVvuUW4/lws//1OfX8ldrAxY4+CLnmT3Ag="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Authentication"; version = "2.2.0"; hash = "sha256-9lUsjz9egaM7QwDh7FLvrhzKtA/LvrTMrNcXjEH7Dns="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Authentication.Abstractions"; version = "2.2.0"; hash = "sha256-0JcJYAoU+AEM0dWaXk2qnqxrVM0Ak9/ntCU1MC90R24="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Authentication.Cookies"; version = "2.2.0"; hash = "sha256-rVy2jwHGg67zaUheYz/JYewtnSnrSRWEQ/AWvGs78XQ="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Authentication.Core"; version = "2.2.0"; hash = "sha256-EE2zKcwPHzm05R+9f7iDvdXE8PuwMUJZmu3EVl0h9vE="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Authorization"; version = "2.2.0"; hash = "sha256-PaMYICjQ0rprUv53Uza/jQvvWTcbPjGLMMp12utF+NY="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Authorization.Policy"; version = "2.2.0"; hash = "sha256-onFYB+jtCbGyfZsIglReCPRdDMmwah2EDMhJN4uBP7Q="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Connections.Abstractions"; version = "2.2.0"; hash = "sha256-MoieWAe7zT/0a7PAn3gMKO8YpHTbOtiGIwF/sFAmieY="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Cors"; version = "2.2.0"; hash = "sha256-TB+sGspJ9kmKco1R0ecMQi3PmMLe4U7ncpOceNBfU2M="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Cryptography.Internal"; version = "2.2.0"; hash = "sha256-WzP/Rs5oBzdmLzkx3knpZcgdNWVGw9xeo4esgroTjwY="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Cryptography.Internal"; version = "8.0.10"; hash = "sha256-zR9xbcGD4yU/oo/c9dQ4AKTMFT+HSBsfu0oNV6bjPNo="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.DataProtection"; version = "2.2.0"; hash = "sha256-/aEB1KEQDlBdB2MXG9q/YsOLnGv49uV6D753gsBdnyY="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.DataProtection"; version = "8.0.10"; hash = "sha256-JYzSF9NxaGA0tXobfaV2ODQdcVCbQBGtcILCRUgcKiY="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.DataProtection.Abstractions"; version = "2.2.0"; hash = "sha256-3zGsOkU/9QrXI96cREJfIni38IazRVNpcS3nqvWFJL4="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.DataProtection.Abstractions"; version = "8.0.10"; hash = "sha256-Fa3PLGFHOvIvAkpTRls1iESyg9ZxqY1/I5Q4elmA2SE="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Diagnostics"; version = "2.2.0"; hash = "sha256-YSW+mjK2ZsLSvoO7yYidV5s62NDityXKIOGICaDQBUM="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Diagnostics.Abstractions"; version = "2.2.0"; hash = "sha256-oOYGMhmHhUrHjJjAtOQg56K+kZmP1QizC07wAiVsLBg="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.HostFiltering"; version = "2.2.0"; hash = "sha256-g3Tm1j/54w/CiZlOHm7Lo0prDzWEoGd+94kTAdd8ixs="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Hosting"; version = "2.2.0"; hash = "sha256-Hcp+bQfnsoIaXSKb0GIvQPKvgSgStH7IHTETdWQNZto="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Hosting.Abstractions"; version = "2.1.1"; hash = "sha256-tZZ4Ka0H0TJb+m5ntO7YN7tlcrDz5hJhvX1sh5Vl1PI="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Hosting.Abstractions"; version = "2.2.0"; hash = "sha256-GzqYrTqCCVy41AOfmgIRY1kkqxekn5T0gFC7tUMxcxA="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Hosting.Server.Abstractions"; version = "2.1.1"; hash = "sha256-13BN1yOL4y2/emMObr3Wb9Q21LbqkPeGvir3A+H+jX4="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Hosting.Server.Abstractions"; version = "2.2.0"; hash = "sha256-8PnZFCkMwAeEHySmmjJOnQvOyx2199PesYHBnfka51s="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Html.Abstractions"; version = "2.2.0"; hash = "sha256-O3j05VLAwWTOX0QywPWK6nq5jnSES9/9zpcnmNaftPw="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Http"; version = "2.1.22"; hash = "sha256-r6vBdzoF0pHOcZzVwfCdi+W/ZgVBTfJxWoAni4YsFiY="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Http"; version = "2.2.0"; hash = "sha256-+ARZomTXSD1m/PR3TWwifXb67cQtoqDVWEqfoq5Tmbk="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Http"; version = "2.2.2"; hash = "sha256-iIlNsdylaZUyVsc1+VmcjhrSs0oUP7ta+tT7hu+WryY="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Http.Abstractions"; version = "2.1.1"; hash = "sha256-2s8Vb62COXBvJrJ2yQdjzt+G9lS3fGfzzuBLtyZ8Wgo="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Http.Abstractions"; version = "2.2.0"; hash = "sha256-y3j3Wo9Xl7kUdGkfnUc8Wexwbc2/vgxy7c3fJk1lSI8="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Http.Extensions"; version = "2.2.0"; hash = "sha256-1rXxGQnkNR+SiNMtDShYoQVGOZbvu4P4ZtWj5Wq4D4U="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Http.Features"; version = "2.1.1"; hash = "sha256-bXB9eARdVnjptjj02ubs81ljH8Ortj3Je9d6x4uCLm4="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Http.Features"; version = "2.2.0"; hash = "sha256-odvntHm669YtViNG5fJIxU4B+akA2SL8//DvYCLCNHc="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.HttpOverrides"; version = "2.2.0"; hash = "sha256-xsscB33I0DhRGWbksHpU82w1WEOIYuUxcfnR2D+rdd0="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.JsonPatch"; version = "2.2.0"; hash = "sha256-ApJHL7yy/YJEf/IkRTOsxyxwJW8sx20FeVtNrMuCkR0="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.JsonPatch"; version = "8.0.10"; hash = "sha256-1MUbEqkePx6A4JkUu7bffBuuYmiP8BVTmJ3aDqwa8nk="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Localization"; version = "2.2.0"; hash = "sha256-BzrYpQXLWRxcLxOYI4ls7Sziq/F/raVLi8wfz8BhdiI="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc"; version = "2.2.0"; hash = "sha256-LG2M3+XPgPXUiaX99qMaEhre+0M3lAIlyaRN7tmMWZo="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.Abstractions"; version = "2.2.0"; hash = "sha256-C0zyeeqBcP/rnTqLup4jy9ir9/Spd+T3CSWFduMh5CY="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.Analyzers"; version = "2.2.0"; hash = "sha256-LkHqzbsaCpPweCjWv+zbgm093V9E2QjLF/D9BcAvJ60="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.ApiExplorer"; version = "2.2.0"; hash = "sha256-6vKZ/f3SdPMopYA3v5tWa8dGYS1kY3Iizc+B0Wpo0Oc="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.Core"; version = "2.2.0"; hash = "sha256-FfgVtIWGocm+w/ZzcvRMj3HmLH58Sb8/02Wqn+ab1Mw="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.Cors"; version = "2.2.0"; hash = "sha256-mITcLm/0nJnKirHA3mV8TBtt58+gvHKMJjmXCWyX+xw="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.DataAnnotations"; version = "2.2.0"; hash = "sha256-hvrGSIrAXLR4u3npETWCkO/bDYZ1zxfOO18RmJVssG0="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.Formatters.Json"; version = "2.2.0"; hash = "sha256-KhkAsq4uaeJkPwHfX0QfeXExIo1DBIoD+kahLxxzQRA="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.Localization"; version = "2.2.0"; hash = "sha256-hj1+wKnsgDafmcp4L/+DZfhLsnjmZ82UPHJkzXPsRzQ="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.NewtonsoftJson"; version = "8.0.10"; hash = "sha256-PYFjjSZjehd9R3J6wUK+OKfvTzMw6IqC+gJKocfXJbs="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.Razor"; version = "2.2.0"; hash = "sha256-+GQvxmGcJs0YNRLO865pwjnZ2hkeznsbHNJt7/J52Bk="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.Razor.Extensions"; version = "2.2.0"; hash = "sha256-rKcOpp0yYCRflpTxCo+UT6n4kiASECrxVLOe/RfeShI="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.RazorPages"; version = "2.2.0"; hash = "sha256-deGOWu6VR9egzZ3WmEAYuJxo1Y2gQZa8w5MO+rvDHn8="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.TagHelpers"; version = "2.2.0"; hash = "sha256-kaJ/ZCi/k+9IlfHCjEocYNZiKkNh3NqABVFcHdDMV5k="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Mvc.ViewFeatures"; version = "2.2.0"; hash = "sha256-9sS9JwZQ6dOAU6128NfqSpA2v67b07YtdrY4B9amTsc="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Razor"; version = "2.2.0"; hash = "sha256-4H6U3qOsJMJonF328ZbQy4h8+pYp4eaA4jaVqHe+yws="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Razor.Design"; version = "2.2.0"; hash = "sha256-xmp6h+NHngykeQU3axYb2NKIFTsLofIUBAVwXxdr7A4="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Razor.Language"; version = "2.2.0"; hash = "sha256-n/SNZ4Yw63n8yuvGtLYmzm4+WbRq1Add9bx4fmPDqFg="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Razor.Runtime"; version = "2.2.0"; hash = "sha256-JRnPViWEWt3dtn324/Sh+obHmxGOVW7TuK9UGyUsMtk="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.ResponseCaching.Abstractions"; version = "2.2.0"; hash = "sha256-ZzyrjN7tN2+ie5tz5T9L7CRGsy1vsxo4Xcayt0QUVwc="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.ResponseCompression"; version = "2.2.0"; hash = "sha256-5F9k0dsJ8BGhVEkH6Qd9H8JI8VdLbHbYpUqUI9K0TVU="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Rewrite"; version = "2.2.0"; hash = "sha256-TiUkuLanNAuWKwekR8Z7G+oWHIbbJlW+66zvyU3aQTg="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Routing"; version = "2.2.0"; hash = "sha256-mvsF973Cm48XUB6lPBiGp7U7vkfBjB3oILdnIQUwe4o="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Routing.Abstractions"; version = "2.1.1"; hash = "sha256-8aUd2zQdVPTL18uRiQaxszNXP8S6a4CD36STMbUXvRE="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Routing.Abstractions"; version = "2.2.0"; hash = "sha256-nqJjxKXkdPAY1XvQjIRNW2y855Xi+LAX1S5AncPnPDU="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Server.IIS"; version = "2.2.0"; hash = "sha256-c9brbUYLhJ5l3WUYV5LsBOqTchUH2Hxk3m+aLDvi/jE="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Server.IISIntegration"; version = "2.2.0"; hash = "sha256-7NaCUiWkPlkGCpC2GXHEtx/aG0i3r/CYS08A6Bkys7Y="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Server.Kestrel"; version = "2.2.0"; hash = "sha256-LofHjJaXkCye9IzTblOL+tmIR2etlwZy0h2nmICDB3I="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Server.Kestrel.Core"; version = "2.2.0"; hash = "sha256-+aTIllcBnMkUHoAwaZPPWMV309aLIPeBvuhyiHRzrhw="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Server.Kestrel.Https"; version = "2.2.0"; hash = "sha256-DOm2ebBGpa4SFeYxzphPT5+Q7ShDq1pposP/lfkh5CM="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Server.Kestrel.Transport.Abstractions"; version = "2.2.0"; hash = "sha256-y+2Dx2p2dE5p/CB6IyMQgbyZohIbeZ1D919/4n9JciE="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.Server.Kestrel.Transport.Sockets"; version = "2.2.0"; hash = "sha256-ZaaJbCZWsKSG5z/9L4O1MD/mHG2vfRYQE1+LsK1jEW4="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.StaticFiles"; version = "2.2.0"; hash = "sha256-8lrbOXoPrOEQggbiXQO37PSRIzPLL4plCFGhbq9/764="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.WebUtilities"; version = "2.1.1"; hash = "sha256-+z46dL+HhGDfg2uyVz1U+YQIHgMJg+4UPeIvAth4hJw="; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.WebUtilities"; version = "2.2.0"; hash = "sha256-UdfOwSWqOUXdb0mGrSMx6Z+d536/P+v5clSRZyN5QTM="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "6.0.0"; hash = "sha256-49+H/iFwp+AfCICvWcqo9us4CzxApPKC37Q5Eqrw+JU="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "7.0.0"; hash = "sha256-1e031E26iraIqun84ad0fCIR4MJZ1hcQo4yFN+B7UfE="; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "8.0.0"; hash = "sha256-9aWmiwMJKrKr9ohD1KSuol37y+jdDxPGJct3m2/Bknw="; }) - (fetchNuGet { pname = "Microsoft.Bcl.TimeProvider"; version = "8.0.0"; hash = "sha256-fBvDSXDSIYMzTa8+A+98KqhEXYP6E17wLo+UNwlyf4U="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "1.1.0"; hash = "sha256-7KrZfK3kUbmeT82eVadvHurZcaFq3FDj4qkIIeExJiM="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "2.8.0"; hash = "sha256-ksCgE7YQaWMQywT3pY26bYIEAqtEp3kTxBRloF0gkDw="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "2.8.0"; hash = "sha256-3LhgErOul0ndBvY57ipiN6uXxzWdyLC577Y6AQPfPVw="; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Razor"; version = "2.2.0"; hash = "sha256-poFN+Jh3ZWm3ZT78DM17czL4zedafPdztdr2blVLlQ0="; }) - (fetchNuGet { pname = "Microsoft.CodeCoverage"; version = "17.10.0"; hash = "sha256-yQFwqVChRtIRpbtkJr92JH2i+O7xn91NGbYgnKs8G2g="; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.5.0"; hash = "sha256-dAhj/CgXG5VIy2dop1xplUsLje7uBPFjxasz9rdFIgY="; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.7.0"; hash = "sha256-Enknv2RsFF68lEPdrf5M+BpV1kHoLTVRApKUwuk/pj0="; }) - (fetchNuGet { pname = "Microsoft.DiaSymReader.Native"; version = "1.7.0"; hash = "sha256-tjvIswyubNy+rJgDlbiZgOb5G4aBdFyBiPa2k28fXFA="; }) - (fetchNuGet { pname = "Microsoft.DotNet.PlatformAbstractions"; version = "2.1.0"; hash = "sha256-vrZhYp94SjycUMGaVYCFWJ4p7KBKfqVyLWtIG73fzeM="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Caching.Abstractions"; version = "2.2.0"; hash = "sha256-osgeoVggP5UqGBG7GbrZmsVvBJmA47aCgsqJclthHUI="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Caching.Memory"; version = "2.2.0"; hash = "sha256-u5W1RY7IG7+ZGu18aijpNohFLY2dgLaM4QZptYvV+S8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "2.1.0"; hash = "sha256-ou/T+Gtw5FcT5nkBGtdf2lAMriTGvb+ulDJkytGgMhM="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "2.2.0"; hash = "sha256-dGJjKmio5BNFdwhK09NxJyCBapwVtO3eWxjLoTMGRQg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "8.0.0"; hash = "sha256-9BPsASlxrV8ilmMCjdb3TiUcm5vFZxkBnAI/fNBSEyA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "2.1.0"; hash = "sha256-rd8zK6YWSxSP5HLrP+IR8o5/+/sheTNDtj3I9Eem/w0="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "2.1.1"; hash = "sha256-3DdHcNmy+JKWB4Q8ixzE4N/hUAvx2o4YlYal4Riwiyw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "2.2.0"; hash = "sha256-5Jjn+0WZQ6OiN8AkNlGV0XIaw8L+a/wAq9hBD88RZbs="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "8.0.0"; hash = "sha256-4eBpDkf7MJozTZnOwQvwcfgRKQGcNXe0K/kF+h5Rl8o="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "2.1.0"; hash = "sha256-FNOrXx7bJbc6qrscne8RhRj28kxK3uq+3ltdXzhCKHQ="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "2.2.0"; hash = "sha256-cigv0t9SntPWjJyRWMy3Q5KnuF17HoDyeKq26meTHoM="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.CommandLine"; version = "2.2.0"; hash = "sha256-0e3cpwsKrR5Tgt2ZXnfvs8NZbV2FEH8q6zRl84w6bCY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; version = "2.2.0"; hash = "sha256-haG2U6qEM6y+Mi4reFNGmarQc7pbc1RH0dXwSgcAxqk="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.FileExtensions"; version = "2.2.0"; hash = "sha256-DVfJkCR5BRZGln4X/OIrPMW/Vi4SJE9ttakIbOAMky8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Json"; version = "2.2.0"; hash = "sha256-bG+jKsdugEfuVuLlTJxi1OEknnT8rUbp7SscBunOlaE="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.UserSecrets"; version = "2.2.0"; hash = "sha256-l+fI+81CZMINKkJ4yTE4w30ymh9Kzuk0HIbgs2TOCpc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "2.2.0"; hash = "sha256-k/3UKceE1hbgv1sfV9H85hzWvMwooE8PcasHvHMhe1M="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "8.0.0"; hash = "sha256-+qIDR8hRzreCHNEDtUcPfVHQdurzWPo/mqviCH78+EQ="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "2.1.0"; hash = "sha256-WgS/QtxbITCpVjs1JPCWuJRrZSoplOtY7VfOXjLqDDA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "2.1.1"; hash = "sha256-BMU00QmmhtH3jP5cepJnoTrxrPESWeDU0i5UrIpIwGY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "2.2.0"; hash = "sha256-pf+UQToJnhAe8VuGjxyCTvua1nIX8n5NHzAUk3Jz38s="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.0"; hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "8.0.2"; hash = "sha256-UfLfEQAkXxDaVPC7foE/J3FVEXd31Pu6uQIhTic3JgY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyModel"; version = "2.1.0"; hash = "sha256-7dFo5itkB2OgSgS7dN87h0Xf2p5/f6fl2Ka6+CTEhDY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Diagnostics.Abstractions"; version = "8.0.1"; hash = "sha256-d5DVXhA8qJFY9YbhZjsTqs5w5kDuxF5v+GD/WZR1QL0="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "2.1.1"; hash = "sha256-2nfsrYlWR3VE30Fa5Lleh4Acav+kdYD7zIfNz9htFOo="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "2.2.0"; hash = "sha256-pLAxP15+PncMiRrUT5bBAhWg7lC6/dfQk5TLTpZzA7k="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "8.0.0"; hash = "sha256-uQSXmt47X2HGoVniavjLICbPtD2ReQOYQMgy3l0xuMU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Composite"; version = "2.2.0"; hash = "sha256-KEwhWadHe24jYSNW2UI18wHC+9kyuZXfMCvZC1Z3eEw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Physical"; version = "2.2.0"; hash = "sha256-/UD6JMXqSKRVlNAQ+wV8XjQ1u9X48z+TNfwe4/oiOFM="; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileSystemGlobbing"; version = "2.2.0"; hash = "sha256-gm05niqMBRcGmGSwogHlOAXCfutn5qFxMZaQZYM+XAY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting.Abstractions"; version = "2.1.1"; hash = "sha256-FCQqPxMNaaN+CD8xE42+evaxKjPWdznJ45U+qoVf8e0="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting.Abstractions"; version = "2.2.0"; hash = "sha256-YZcyKXL6jOpyGrDbFLu46vncfUw2FuqhclMdbEPuh/U="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting.Abstractions"; version = "8.0.1"; hash = "sha256-/bIVL9uvBQhV/KQmjA1ZjR74sMfaAlBb15sVXsGDEVA="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Localization"; version = "2.2.0"; hash = "sha256-07D6Zh5un5dKl2zM18oVDgWeWQq3Y0RP823nisuc48w="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Localization.Abstractions"; version = "2.2.0"; hash = "sha256-/p2UA5VBmC6jxu0boS/hK9g2YgeS+gwe5Ubmk3rR+Ps="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "2.1.0"; hash = "sha256-BtRVc8o7NruFCblOITHPZD3llUmri3+1dStSo09EMTY="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "2.2.0"; hash = "sha256-lY9axb6/MyPAhE+N8VtfCIpD80AFCtxUnnGxvb2koy8="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "8.0.0"; hash = "sha256-Meh0Z0X7KyOEG4l0RWBcuHHihcABcvCyfUXgasmQ91o="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "2.1.0"; hash = "sha256-0i4YUnMQ4DE0KDp47pssJLUIw8YAsHf2NZN0xoOLb78="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "2.1.1"; hash = "sha256-TzbYgz4EemrYKHMvB9HWDkFmq0BkTetKPUwBpYHk9+k="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "2.2.0"; hash = "sha256-lJeKyhBnDc4stX2Wd7WpcG+ZKxPTFHILZSezKM2Fhws="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "8.0.0"; hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "8.0.2"; hash = "sha256-cHpe8X2BgYa5DzulZfq24rg8O2K5Lmq2OiLhoyAVgJc="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Configuration"; version = "2.2.0"; hash = "sha256-KeAgb1vzW3HOd1+Bp741nHshe2DVVH2OCEU4suam69o="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Console"; version = "2.2.0"; hash = "sha256-7qmSYQZGqjuW1JYLzUQCTjl/Ox6ZLjIBJQswNUNjnLw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Debug"; version = "2.2.0"; hash = "sha256-1x4AdGEmpN5br+UKXp15EboqMIjtsUn9/r3wNoj7v/w="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.EventSource"; version = "2.2.0"; hash = "sha256-DyEQNzKE9ACtCAN2gpVe1Z2ovpDznyBJM9L9A+oSf6I="; }) - (fetchNuGet { pname = "Microsoft.Extensions.ObjectPool"; version = "2.1.1"; hash = "sha256-ivQH0mOjHNwEh/VWUxdrXi/i0SZqRHDMxU9SiW9ygeU="; }) - (fetchNuGet { pname = "Microsoft.Extensions.ObjectPool"; version = "2.2.0"; hash = "sha256-P+QUM50j/V8f45zrRqat8fz6Gu3lFP+hDjESwTZNOFg="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "2.1.0"; hash = "sha256-ol0tKlHOyX1qAQqNWuag0thb2mMCU2JHNiw0nzUhJnE="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "2.1.1"; hash = "sha256-dCPA56Wv9cLuz720PmVbk2oXda1t9ZSAlP8/clDU93E="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "2.2.0"; hash = "sha256-YBtPoWBEs+dlHPQ7qOmss+U9gnvG0T1irZY8NwD0QKw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "8.0.0"; hash = "sha256-n2m4JSegQKUTlOsKLZUUHHKMq926eJ0w9N9G+I3FoFw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "8.0.2"; hash = "sha256-AjcldddddtN/9aH9pg7ClEZycWtFHLi9IPe1GGhNQys="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; version = "2.2.0"; hash = "sha256-TZKLbSNM32hTzzDIKlRNcu6V2NhLfXTz+ew7QPvNJXE="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "2.1.0"; hash = "sha256-q1oDnqfQiiKgzlv/WDHgNGTlWfm+fkuY1R6t6hr/L+U="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "2.1.1"; hash = "sha256-nbu2OeQGWeG8QKpoAOxIQ8aPzDbWHgbzLXh55xqeeQw="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "2.2.0"; hash = "sha256-DMCTC3HW+sHaRlh/9F1sDwof+XgvVp9IzAqzlZWByn4="; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "8.0.0"; hash = "sha256-FU8qj3DR8bDdc1c+WeGZx/PCZeqqndweZM9epcpXjSo="; }) - (fetchNuGet { pname = "Microsoft.Extensions.WebEncoders"; version = "2.2.0"; hash = "sha256-wwfvTcAgSnHQCuqqUwsiF588QxQYjXaGk9VwxiCLFtY="; }) - (fetchNuGet { pname = "Microsoft.Net.Http.Headers"; version = "2.1.1"; hash = "sha256-jdod0MQ58QG8ezS3nYhO85Qk4D7xh0LnOz4XIXvtBBs="; }) - (fetchNuGet { pname = "Microsoft.Net.Http.Headers"; version = "2.2.0"; hash = "sha256-pb8AoacSvy8hGNGodU6Lhv1ooWtUSCZwjmwd89PM1HA="; }) - (fetchNuGet { pname = "Microsoft.NET.Test.Sdk"; version = "17.10.0"; hash = "sha256-rkHIqB2mquNXF89XBTFpUL2z5msjTBsOcyjSBCh36I0="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "5.0.0"; hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies"; version = "1.0.3"; hash = "sha256-FBoJP5DHZF0QHM0xLm9yd4HJZVQOuSpSKA+VQRpphEE="; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies.net462"; version = "1.0.3"; hash = "sha256-7mkqhFdDUAkQhV1MMwym6e+HwW4W90DkR00YcYXWbiE="; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.ObjectModel"; version = "17.10.0"; hash = "sha256-3YjVGK2zEObksBGYg8b/CqoJgLQ1jUv4GCWNjDhLRh4="; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.TestHost"; version = "17.10.0"; hash = "sha256-+yzP3FY6WoOosSpYnB7duZLhOPUZMQYy8zJ1d3Q4hK4="; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "4.5.0"; hash = "sha256-WMBXsIb0DgPFPaFkNVxY9b9vcMxPqtgFgijKYMJfV/0="; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "5.0.0"; hash = "sha256-9kylPGfKZc58yFqNKa77stomcoNnMeERXozWJzDcUIA="; }) - (fetchNuGet { pname = "MimeMapping"; version = "1.0.1.50"; hash = "sha256-oz7GTUIqqj+224Xe5AiYmI6pEjXQ485QzVdLHAQ0gok="; }) - (fetchNuGet { pname = "Mono.Posix"; version = "7.1.0-final.1.21458.1"; hash = "sha256-kbpbruyWKfWfRg9IX0wR8UirykgJdLZl2d5PqUgFxz4="; }) - (fetchNuGet { pname = "Mono.Unix"; version = "7.1.0-final.1.21458.1"; hash = "sha256-tm3niOm4OFCe/kL5M5zwCZgfHEaPtmDqsOLN6GExYHs="; }) - (fetchNuGet { pname = "MSTest.TestAdapter"; version = "3.0.2"; hash = "sha256-53zaLSghO4Un9GUF4W3bV34X5UHeQ80h2y7fCm1J9t8="; }) - (fetchNuGet { pname = "MSTest.TestFramework"; version = "3.0.2"; hash = "sha256-WMXSFNAxUtZVyrtrNcJu6KofR+A+/A3SbsleFCGIPPo="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.0"; hash = "sha256-Pp7fRylai8JrE1O+9TGfIEJrAOmnWTJRLWE+qJBahK0="; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "10.0.1"; hash = "sha256-Gw7dQIsmYfmcR5ASTuMsB8cqaI4g3osw0j+LO1jEzJY="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "11.0.2"; hash = "sha256-YhlAbGfwoxQzxb3Hef4iyV9eGdPQJJNd2GgSR0jsBJ0="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.1"; hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.3"; hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "9.0.1"; hash = "sha256-mYCBrgUhIJFzRuLLV9SIiIFHovzfR8Uuqfg6e08EnlU="; }) - (fetchNuGet { pname = "Newtonsoft.Json.Bson"; version = "1.0.1"; hash = "sha256-qofIFqViDsdBOE/X0IvzfGUklSrULaH8MoZQ+YrcMOQ="; }) - (fetchNuGet { pname = "Newtonsoft.Json.Bson"; version = "1.0.2"; hash = "sha256-ZUj6YFSMZp5CZtXiamw49eZmbp1iYBuNsIKNnjxcRzA="; }) - (fetchNuGet { pname = "NLog"; version = "5.3.2"; hash = "sha256-b/y/IFUSe7qsSeJ8JVB0VFmJlkviFb8h934ktnn9Fgc="; }) - (fetchNuGet { pname = "NLog.Extensions.Logging"; version = "5.3.11"; hash = "sha256-DP3R51h+9kk06N63U+1C4/JCZTFiADeYTROToAA2R0g="; }) - (fetchNuGet { pname = "NLog.Web.AspNetCore"; version = "5.3.11"; hash = "sha256-6bMYbKyNWtb0tn8k3418mWBuogofIAfwT9NHSopUu58="; }) - (fetchNuGet { pname = "NUnit"; version = "3.14.0"; hash = "sha256-CuP/q5HovPWfAW3Cty/QxRi7VpjykJ3TDLq5TENI6KY="; }) - (fetchNuGet { pname = "NUnit.ConsoleRunner"; version = "3.17.0"; hash = "sha256-aGf4/XDPs4VByjN/RHeN9+0tr598H4t6UsmatOLbVmI="; }) - (fetchNuGet { pname = "NUnit3TestAdapter"; version = "4.5.0"; hash = "sha256-ER3ogl0L5FYyc6pVVPY1ch+AQxG/WgFcnWECnYQJPes="; }) - (fetchNuGet { pname = "Polly"; version = "8.4.2"; hash = "sha256-cuaH3SdTEdwLA1VddtY6CsmHTiDuYk0dVJ79r/6jSpQ="; }) - (fetchNuGet { pname = "Polly.Core"; version = "8.4.2"; hash = "sha256-4fn5n6Bu29uqWg8ciii3MDsi9bO2/moPa9B3cJ9Ihe8="; }) - (fetchNuGet { pname = "SharpZipLib"; version = "1.4.2"; hash = "sha256-/giVqikworG2XKqfN9uLyjUSXr35zBuZ2FX2r8X/WUY="; }) - (fetchNuGet { pname = "System.AppContext"; version = "4.3.0"; hash = "sha256-yg95LNQOwFlA1tWxXdQkVyJqT4AnoDc+ACmrNvzGiZg="; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.4.0"; hash = "sha256-KTxAhYawFG2V5VX1jw3pzx3IrQXRgn1TsvgjPgxAbqA="; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.0"; hash = "sha256-THw2znu+KibfJRfD7cE3nRYHsm7Fyn5pjOOZVonFjvs="; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; hash = "sha256-wws90sfi9M7kuCPWkv1CEYMJtCqx9QB/kj0ymlsNaxI="; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.3.0"; hash = "sha256-KMY5DfJnDeIsa13DpqvyN8NkReZEMAFnlmNglVoFIXI="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "1.3.1"; hash = "sha256-areGRq/dO08KhxiWuAK+cWAjOWYtuB1R9zGXLvIqwZw="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "1.5.0"; hash = "sha256-BliqYlL9ntbMXo5d7NUrKXwYN+PqdyqDIS5bp4qVr7Q="; }) - (fetchNuGet { pname = "System.ComponentModel.Annotations"; version = "4.5.0"; hash = "sha256-15yE2NoT9vmL9oGCaxHClQR1jLW1j1ef5hHMg55xRso="; }) - (fetchNuGet { pname = "System.Configuration.ConfigurationManager"; version = "4.4.0"; hash = "sha256-+8wGYllXnIxRzy9dLhZFB88GoPj8ivYXS0KUfcivT8I="; }) - (fetchNuGet { pname = "System.Console"; version = "4.3.0"; hash = "sha256-Xh3PPBZr0pDbDaK8AEHbdGz7ePK6Yi1ZyRWI1JM6mbo="; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "4.5.0"; hash = "sha256-0r8bsmgsb30bHJnvi98oPTFcxLfuqqt9mcoeEcYFFfk="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "7.0.2"; hash = "sha256-8Uawe7mWOQsDzMSAAP16nuGD1FRSajyS8q+cA++MJ8E="; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "8.0.1"; hash = "sha256-zmwHjcJgKcbkkwepH038QhcnsWMJcHys+PEbFGC0Jgo="; }) - (fetchNuGet { pname = "System.Diagnostics.EventLog"; version = "8.0.1"; hash = "sha256-zvqd72pwgcGoa1nH3ZT1C0mP9k53vFLJ69r5MCQ1saA="; }) - (fetchNuGet { pname = "System.Diagnostics.FileVersionInfo"; version = "4.3.0"; hash = "sha256-JyqOf5/lsUNLMpIqK8XffcFTxB6vHWzGWHssmojokCQ="; }) - (fetchNuGet { pname = "System.Diagnostics.StackTrace"; version = "4.3.0"; hash = "sha256-Tfq7F61N0VfujVyI5A9MZvyWewQ5HepB1f1UMBMkUCs="; }) - (fetchNuGet { pname = "System.Diagnostics.Tools"; version = "4.3.0"; hash = "sha256-gVOv1SK6Ape0FQhCVlNOd9cvQKBvMxRX9K0JPVi8w0Y="; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.3.0"; hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; }) - (fetchNuGet { pname = "System.IO.Compression"; version = "4.3.0"; hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; }) - (fetchNuGet { pname = "System.IO.FileSystem.AccessControl"; version = "5.0.0"; hash = "sha256-c9MlDKJfj63YRvl7brRBNs59olrmbL+G1A6oTS8ytEc="; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "4.5.2"; hash = "sha256-AXsErCMtJnoT1ZhYlChyObzAimwEp1Cl1L6X6fewuhA="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "4.6.0"; hash = "sha256-cCtFmQlk0TFBWbZLVh/c258lyF3X4mPWkyb625d8PmU="; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "5.0.1"; hash = "sha256-2zT5uBiyYm+jLIoJppIKJttTtpcMNKxd7Li0QEVjbv8="; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.3.0"; hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.0"; hash = "sha256-YOz1pCR4RpP1ywYoJsgXnVlzsWtC2uYKQJTg0NnFXtE="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.1"; hash = "sha256-7JhQNSvE6JigM1qmmhzOX3NiZ6ek82R4whQNb+FpBzg="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.3"; hash = "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.5"; hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.4.0"; hash = "sha256-auXQK2flL/JpnB/rEcAcUm4vYMCYMEMiWOCAlIaqu2U="; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "1.4.2"; hash = "sha256-cYd2SWmnacNq14fTpyW9vGcnbZSD4DPRjpR+tgdZZyE="; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "1.6.0"; hash = "sha256-JJfgaPav7UfEh4yRAQdGhLZF1brr0tUWPl6qmfNWq/E="; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.0"; hash = "sha256-g9jIdQtXSAhY+ezQtYNgHEUoQR3HzznHs3JMzD9bip4="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.1"; hash = "sha256-Lucrfpuhz72Ns+DOS7MjuNT2KWgi+m4bJkg87kqXmfU="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.2"; hash = "sha256-8eUXXGWO2LL7uATMZye2iCpQOETn2jCcjUhG6coR5O8="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.3"; hash = "sha256-lnZMUqRO4RYRUeSO8HSJ9yBHqFHLVbmenwHWkIU20ak="; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices.RuntimeInformation"; version = "4.0.0"; hash = "sha256-5j53amb76A3SPiE3B0llT2XPx058+CgE7OXL4bLalT4="; }) - (fetchNuGet { pname = "System.Runtime.InteropServices.RuntimeInformation"; version = "4.3.0"; hash = "sha256-MYpl6/ZyC6hjmzWRIe+iDoldOMW1mfbwXsduAnXIKGA="; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.3.0"; hash = "sha256-P5jHCgMbgFMYiONvzmaKFeOqcAIDPu/U8bOVrNPYKqc="; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "4.5.0"; hash = "sha256-AFsKPb/nTk2/mqH/PYpaoI8PLsiKKimaXf+7Mb5VfPM="; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "5.0.0"; hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.3.0"; hash = "sha256-tAJvNSlczYBJ3Ed24Ae27a55tq/n4D3fubNQdwcKWA8="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.5.0"; hash = "sha256-9llRbEcY1fHYuTn3vGZaCxsFxSAqXl4bDA6Rz9b0pN4="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.3.0"; hash = "sha256-Yuge89N6M+NcblcvXMeyHZ6kZDfwBv3LPMDiF8HhJss="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Pkcs"; version = "8.0.1"; hash = "sha256-KMNIkJ3yQ/5O6WIhPjyAIarsvIMhkp26A6aby5KkneU="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.3.0"; hash = "sha256-fnFi7B3SnVj5a+BbgXnbjnGNvWrCEU6Hp/wjsjWz318="; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "4.4.0"; hash = "sha256-Ri53QmFX8I8UH0x4PikQ1ZA07ZSnBUXStd5rBfGWFOE="; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "8.0.0"; hash = "sha256-fb0pa9sQxN+mr0vnXg1Igbx49CaOqS+GDkTfWNboUvs="; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.3.0"; hash = "sha256-MG3V/owDh273GCUPsGGraNwaVpcydupl3EtPXj6TVG0="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Xml"; version = "4.5.0"; hash = "sha256-FIGpgYPbdA1NX0I4NmAr4gdt5VM/emm7PjM5XUEHZOY="; }) - (fetchNuGet { pname = "System.Security.Cryptography.Xml"; version = "8.0.2"; hash = "sha256-9TCmVyMB4+By/ipU8vdYDtSnw1tkkebnXXVRdT78+28="; }) - (fetchNuGet { pname = "System.Security.Permissions"; version = "4.5.0"; hash = "sha256-Fa6dX6Gyse1A/RBoin8cVaHQePbfBvp6jjWxUXPhXKQ="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.5.0"; hash = "sha256-BkUYNguz0e4NJp1kkW7aJBn3dyH9STwB5N8XqnlCsmY="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; }) - (fetchNuGet { pname = "System.ServiceProcess.ServiceController"; version = "8.0.1"; hash = "sha256-2cXTzNOyXqJinFPzdVJ9Gu6qrFtycfivu7RHDzBJic8="; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "8.0.0"; hash = "sha256-fjCLQc1PRW0Ix5IZldg0XKv+J1DqPSfu9pjMyNBp7dE="; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "4.5.0"; hash = "sha256-o+jikyFOG30gX57GoeZztmuJ878INQ5SFMmKovYqLWs="; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "4.5.1"; hash = "sha256-F3YY+z86YxC5TQW7RToelnemrqRN7gdRNbpdot8byl8="; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "8.0.0"; hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; }) - (fetchNuGet { pname = "System.Text.Json"; version = "8.0.5"; hash = "sha256-yKxo54w5odWT6nPruUVsaX53oPRe+gKzGvLnnxtwP68="; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.0"; hash = "sha256-SIdUoXOGGSmBGXLWW76fz0OEoFYDJ8ZoU/xFdVibtxY="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.1"; hash = "sha256-3NeBC+r7eTVz3f+cEm1NkVhxSr7LrYGX/NdUwje9ecY="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.2"; hash = "sha256-EqJF9TppMHTKvpR6emrdA61zalMW3HwrZ7j6Bn4bBuo="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; }) - (fetchNuGet { pname = "System.Threading.Tasks.Parallel"; version = "4.3.0"; hash = "sha256-8H2vRmsn29MNfMmCeIL5vHfbM19jWaLDKNLzDonCI+c="; }) - (fetchNuGet { pname = "System.Threading.Thread"; version = "4.3.0"; hash = "sha256-pMs6RNFC3nQOGz9EqIcyWmO8YLaqay+q/Qde5hqPXXg="; }) - (fetchNuGet { pname = "System.ValueTuple"; version = "4.3.0"; hash = "sha256-tkMwiobmGQn/t8LDqpkM+Q7XJOebEl3bwVf11d2ZR4g="; }) - (fetchNuGet { pname = "System.ValueTuple"; version = "4.5.0"; hash = "sha256-niH6l2fU52vAzuBlwdQMw0OEoRS/7E1w5smBFoqSaAI="; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.3.0"; hash = "sha256-QQ8KgU0lu4F5Unh+TbechO//zaAGZ4MfgvW72Cn1hzA="; }) - (fetchNuGet { pname = "System.Xml.XDocument"; version = "4.3.0"; hash = "sha256-rWtdcmcuElNOSzCehflyKwHkDRpiOhJJs8CeQ0l1CCI="; }) - (fetchNuGet { pname = "System.Xml.XmlDocument"; version = "4.3.0"; hash = "sha256-kbuV4Y7rVJkfMp2Kgoi8Zvdatm9CZNmlKB3GZgANvy4="; }) - (fetchNuGet { pname = "System.Xml.XPath"; version = "4.3.0"; hash = "sha256-kd1JMqj6obhxzEPRJeYvcUyJqkOs/9A0UOQccC6oYrM="; }) - (fetchNuGet { pname = "System.Xml.XPath.XDocument"; version = "4.3.0"; hash = "sha256-dqk4CWuwocj5qsUAYlS+XAe6GGcY/N/HIPEGe5afrPM="; }) - (fetchNuGet { pname = "YamlDotNet"; version = "13.0.1"; hash = "sha256-vrPm3nActRBC+psOSDGu2sjy/FL1Sak/okZPwurOUB8="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "AngleSharp"; + version = "1.1.2"; + hash = "sha256-LvJDD+C/NiPLVjEnIWkR+39UkzoeWgPd7BBXakij0WU="; + }) + (fetchNuGet { + pname = "AngleSharp.Xml"; + version = "1.0.0"; + hash = "sha256-UzxXWH6qG2BEAH/ULosGkUn2RhghUOguyVTPYl78spM="; + }) + (fetchNuGet { + pname = "Autofac"; + version = "8.0.0"; + hash = "sha256-7XhDXw8hatQFjQMTIorQ5XrfDCc7EVNVyi6bGbc5fnA="; + }) + (fetchNuGet { + pname = "Autofac.Extensions.DependencyInjection"; + version = "9.0.0"; + hash = "sha256-hEqvbTkJqcI4S4LpxVOMyc5m+KeN0nRLk7FqQHSLRd4="; + }) + (fetchNuGet { + pname = "BencodeNET"; + version = "4.0.0"; + hash = "sha256-Bjlpq7laGbrxpYf6GpxklF9AalIh7dTYefU8cDS+fxY="; + }) + (fetchNuGet { + pname = "CommandLineParser"; + version = "2.9.1"; + hash = "sha256-ApU9y1yX60daSjPk3KYDBeJ7XZByKW8hse9NRZGcjeo="; + }) + (fetchNuGet { + pname = "coverlet.msbuild"; + version = "6.0.2"; + hash = "sha256-Ptj/f41dJ1T+DYvJ8bUo7Bnjp5R+xFOKGVhg3GA+f/A="; + }) + (fetchNuGet { + pname = "DotNet4.SocksProxy"; + version = "1.4.0.1"; + hash = "sha256-a+sqVAHupD9DLFfRptjvPoW7YU+qT5yxUYGAqmNS4sU="; + }) + (fetchNuGet { + pname = "FlareSolverrSharp"; + version = "3.0.7"; + hash = "sha256-zropUtNiHVSG0ULK01wOhqgZSlWi+CXZ+4SKWok33BI="; + }) + (fetchNuGet { + pname = "FluentAssertions"; + version = "6.12.1"; + hash = "sha256-R/Fi9eee6T8t8JECxL9+HFd8jAxRMkCg18j+fAQLNqM="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore"; + version = "2.2.0"; + hash = "sha256-yZUh/m5s/tgGZOKGylcbPaZ67AHi/mM0xE/bqhk8W28="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Antiforgery"; + version = "2.2.0"; + hash = "sha256-NBUF/oT5TYVvuUW4/lws//1OfX8ldrAxY4+CLnmT3Ag="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Authentication"; + version = "2.2.0"; + hash = "sha256-9lUsjz9egaM7QwDh7FLvrhzKtA/LvrTMrNcXjEH7Dns="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Authentication.Abstractions"; + version = "2.2.0"; + hash = "sha256-0JcJYAoU+AEM0dWaXk2qnqxrVM0Ak9/ntCU1MC90R24="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Authentication.Cookies"; + version = "2.2.0"; + hash = "sha256-rVy2jwHGg67zaUheYz/JYewtnSnrSRWEQ/AWvGs78XQ="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Authentication.Core"; + version = "2.2.0"; + hash = "sha256-EE2zKcwPHzm05R+9f7iDvdXE8PuwMUJZmu3EVl0h9vE="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Authorization"; + version = "2.2.0"; + hash = "sha256-PaMYICjQ0rprUv53Uza/jQvvWTcbPjGLMMp12utF+NY="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Authorization.Policy"; + version = "2.2.0"; + hash = "sha256-onFYB+jtCbGyfZsIglReCPRdDMmwah2EDMhJN4uBP7Q="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Connections.Abstractions"; + version = "2.2.0"; + hash = "sha256-MoieWAe7zT/0a7PAn3gMKO8YpHTbOtiGIwF/sFAmieY="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Cors"; + version = "2.2.0"; + hash = "sha256-TB+sGspJ9kmKco1R0ecMQi3PmMLe4U7ncpOceNBfU2M="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Cryptography.Internal"; + version = "2.2.0"; + hash = "sha256-WzP/Rs5oBzdmLzkx3knpZcgdNWVGw9xeo4esgroTjwY="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Cryptography.Internal"; + version = "8.0.10"; + hash = "sha256-zR9xbcGD4yU/oo/c9dQ4AKTMFT+HSBsfu0oNV6bjPNo="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.DataProtection"; + version = "2.2.0"; + hash = "sha256-/aEB1KEQDlBdB2MXG9q/YsOLnGv49uV6D753gsBdnyY="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.DataProtection"; + version = "8.0.10"; + hash = "sha256-JYzSF9NxaGA0tXobfaV2ODQdcVCbQBGtcILCRUgcKiY="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.DataProtection.Abstractions"; + version = "2.2.0"; + hash = "sha256-3zGsOkU/9QrXI96cREJfIni38IazRVNpcS3nqvWFJL4="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.DataProtection.Abstractions"; + version = "8.0.10"; + hash = "sha256-Fa3PLGFHOvIvAkpTRls1iESyg9ZxqY1/I5Q4elmA2SE="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Diagnostics"; + version = "2.2.0"; + hash = "sha256-YSW+mjK2ZsLSvoO7yYidV5s62NDityXKIOGICaDQBUM="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Diagnostics.Abstractions"; + version = "2.2.0"; + hash = "sha256-oOYGMhmHhUrHjJjAtOQg56K+kZmP1QizC07wAiVsLBg="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.HostFiltering"; + version = "2.2.0"; + hash = "sha256-g3Tm1j/54w/CiZlOHm7Lo0prDzWEoGd+94kTAdd8ixs="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Hosting"; + version = "2.2.0"; + hash = "sha256-Hcp+bQfnsoIaXSKb0GIvQPKvgSgStH7IHTETdWQNZto="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Hosting.Abstractions"; + version = "2.1.1"; + hash = "sha256-tZZ4Ka0H0TJb+m5ntO7YN7tlcrDz5hJhvX1sh5Vl1PI="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Hosting.Abstractions"; + version = "2.2.0"; + hash = "sha256-GzqYrTqCCVy41AOfmgIRY1kkqxekn5T0gFC7tUMxcxA="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Hosting.Server.Abstractions"; + version = "2.1.1"; + hash = "sha256-13BN1yOL4y2/emMObr3Wb9Q21LbqkPeGvir3A+H+jX4="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Hosting.Server.Abstractions"; + version = "2.2.0"; + hash = "sha256-8PnZFCkMwAeEHySmmjJOnQvOyx2199PesYHBnfka51s="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Html.Abstractions"; + version = "2.2.0"; + hash = "sha256-O3j05VLAwWTOX0QywPWK6nq5jnSES9/9zpcnmNaftPw="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Http"; + version = "2.1.22"; + hash = "sha256-r6vBdzoF0pHOcZzVwfCdi+W/ZgVBTfJxWoAni4YsFiY="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Http"; + version = "2.2.0"; + hash = "sha256-+ARZomTXSD1m/PR3TWwifXb67cQtoqDVWEqfoq5Tmbk="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Http"; + version = "2.2.2"; + hash = "sha256-iIlNsdylaZUyVsc1+VmcjhrSs0oUP7ta+tT7hu+WryY="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Http.Abstractions"; + version = "2.1.1"; + hash = "sha256-2s8Vb62COXBvJrJ2yQdjzt+G9lS3fGfzzuBLtyZ8Wgo="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Http.Abstractions"; + version = "2.2.0"; + hash = "sha256-y3j3Wo9Xl7kUdGkfnUc8Wexwbc2/vgxy7c3fJk1lSI8="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Http.Extensions"; + version = "2.2.0"; + hash = "sha256-1rXxGQnkNR+SiNMtDShYoQVGOZbvu4P4ZtWj5Wq4D4U="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Http.Features"; + version = "2.1.1"; + hash = "sha256-bXB9eARdVnjptjj02ubs81ljH8Ortj3Je9d6x4uCLm4="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Http.Features"; + version = "2.2.0"; + hash = "sha256-odvntHm669YtViNG5fJIxU4B+akA2SL8//DvYCLCNHc="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.HttpOverrides"; + version = "2.2.0"; + hash = "sha256-xsscB33I0DhRGWbksHpU82w1WEOIYuUxcfnR2D+rdd0="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.JsonPatch"; + version = "2.2.0"; + hash = "sha256-ApJHL7yy/YJEf/IkRTOsxyxwJW8sx20FeVtNrMuCkR0="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.JsonPatch"; + version = "8.0.10"; + hash = "sha256-1MUbEqkePx6A4JkUu7bffBuuYmiP8BVTmJ3aDqwa8nk="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Localization"; + version = "2.2.0"; + hash = "sha256-BzrYpQXLWRxcLxOYI4ls7Sziq/F/raVLi8wfz8BhdiI="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc"; + version = "2.2.0"; + hash = "sha256-LG2M3+XPgPXUiaX99qMaEhre+0M3lAIlyaRN7tmMWZo="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.Abstractions"; + version = "2.2.0"; + hash = "sha256-C0zyeeqBcP/rnTqLup4jy9ir9/Spd+T3CSWFduMh5CY="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.Analyzers"; + version = "2.2.0"; + hash = "sha256-LkHqzbsaCpPweCjWv+zbgm093V9E2QjLF/D9BcAvJ60="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.ApiExplorer"; + version = "2.2.0"; + hash = "sha256-6vKZ/f3SdPMopYA3v5tWa8dGYS1kY3Iizc+B0Wpo0Oc="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.Core"; + version = "2.2.0"; + hash = "sha256-FfgVtIWGocm+w/ZzcvRMj3HmLH58Sb8/02Wqn+ab1Mw="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.Cors"; + version = "2.2.0"; + hash = "sha256-mITcLm/0nJnKirHA3mV8TBtt58+gvHKMJjmXCWyX+xw="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.DataAnnotations"; + version = "2.2.0"; + hash = "sha256-hvrGSIrAXLR4u3npETWCkO/bDYZ1zxfOO18RmJVssG0="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.Formatters.Json"; + version = "2.2.0"; + hash = "sha256-KhkAsq4uaeJkPwHfX0QfeXExIo1DBIoD+kahLxxzQRA="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.Localization"; + version = "2.2.0"; + hash = "sha256-hj1+wKnsgDafmcp4L/+DZfhLsnjmZ82UPHJkzXPsRzQ="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.NewtonsoftJson"; + version = "8.0.10"; + hash = "sha256-PYFjjSZjehd9R3J6wUK+OKfvTzMw6IqC+gJKocfXJbs="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.Razor"; + version = "2.2.0"; + hash = "sha256-+GQvxmGcJs0YNRLO865pwjnZ2hkeznsbHNJt7/J52Bk="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.Razor.Extensions"; + version = "2.2.0"; + hash = "sha256-rKcOpp0yYCRflpTxCo+UT6n4kiASECrxVLOe/RfeShI="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.RazorPages"; + version = "2.2.0"; + hash = "sha256-deGOWu6VR9egzZ3WmEAYuJxo1Y2gQZa8w5MO+rvDHn8="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.TagHelpers"; + version = "2.2.0"; + hash = "sha256-kaJ/ZCi/k+9IlfHCjEocYNZiKkNh3NqABVFcHdDMV5k="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Mvc.ViewFeatures"; + version = "2.2.0"; + hash = "sha256-9sS9JwZQ6dOAU6128NfqSpA2v67b07YtdrY4B9amTsc="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Razor"; + version = "2.2.0"; + hash = "sha256-4H6U3qOsJMJonF328ZbQy4h8+pYp4eaA4jaVqHe+yws="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Razor.Design"; + version = "2.2.0"; + hash = "sha256-xmp6h+NHngykeQU3axYb2NKIFTsLofIUBAVwXxdr7A4="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Razor.Language"; + version = "2.2.0"; + hash = "sha256-n/SNZ4Yw63n8yuvGtLYmzm4+WbRq1Add9bx4fmPDqFg="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Razor.Runtime"; + version = "2.2.0"; + hash = "sha256-JRnPViWEWt3dtn324/Sh+obHmxGOVW7TuK9UGyUsMtk="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.ResponseCaching.Abstractions"; + version = "2.2.0"; + hash = "sha256-ZzyrjN7tN2+ie5tz5T9L7CRGsy1vsxo4Xcayt0QUVwc="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.ResponseCompression"; + version = "2.2.0"; + hash = "sha256-5F9k0dsJ8BGhVEkH6Qd9H8JI8VdLbHbYpUqUI9K0TVU="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Rewrite"; + version = "2.2.0"; + hash = "sha256-TiUkuLanNAuWKwekR8Z7G+oWHIbbJlW+66zvyU3aQTg="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Routing"; + version = "2.2.0"; + hash = "sha256-mvsF973Cm48XUB6lPBiGp7U7vkfBjB3oILdnIQUwe4o="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Routing.Abstractions"; + version = "2.1.1"; + hash = "sha256-8aUd2zQdVPTL18uRiQaxszNXP8S6a4CD36STMbUXvRE="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Routing.Abstractions"; + version = "2.2.0"; + hash = "sha256-nqJjxKXkdPAY1XvQjIRNW2y855Xi+LAX1S5AncPnPDU="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Server.IIS"; + version = "2.2.0"; + hash = "sha256-c9brbUYLhJ5l3WUYV5LsBOqTchUH2Hxk3m+aLDvi/jE="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Server.IISIntegration"; + version = "2.2.0"; + hash = "sha256-7NaCUiWkPlkGCpC2GXHEtx/aG0i3r/CYS08A6Bkys7Y="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Server.Kestrel"; + version = "2.2.0"; + hash = "sha256-LofHjJaXkCye9IzTblOL+tmIR2etlwZy0h2nmICDB3I="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Server.Kestrel.Core"; + version = "2.2.0"; + hash = "sha256-+aTIllcBnMkUHoAwaZPPWMV309aLIPeBvuhyiHRzrhw="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Server.Kestrel.Https"; + version = "2.2.0"; + hash = "sha256-DOm2ebBGpa4SFeYxzphPT5+Q7ShDq1pposP/lfkh5CM="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Server.Kestrel.Transport.Abstractions"; + version = "2.2.0"; + hash = "sha256-y+2Dx2p2dE5p/CB6IyMQgbyZohIbeZ1D919/4n9JciE="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.Server.Kestrel.Transport.Sockets"; + version = "2.2.0"; + hash = "sha256-ZaaJbCZWsKSG5z/9L4O1MD/mHG2vfRYQE1+LsK1jEW4="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.StaticFiles"; + version = "2.2.0"; + hash = "sha256-8lrbOXoPrOEQggbiXQO37PSRIzPLL4plCFGhbq9/764="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.WebUtilities"; + version = "2.1.1"; + hash = "sha256-+z46dL+HhGDfg2uyVz1U+YQIHgMJg+4UPeIvAth4hJw="; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.WebUtilities"; + version = "2.2.0"; + hash = "sha256-UdfOwSWqOUXdb0mGrSMx6Z+d536/P+v5clSRZyN5QTM="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "6.0.0"; + hash = "sha256-49+H/iFwp+AfCICvWcqo9us4CzxApPKC37Q5Eqrw+JU="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "7.0.0"; + hash = "sha256-1e031E26iraIqun84ad0fCIR4MJZ1hcQo4yFN+B7UfE="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "8.0.0"; + hash = "sha256-9aWmiwMJKrKr9ohD1KSuol37y+jdDxPGJct3m2/Bknw="; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.TimeProvider"; + version = "8.0.0"; + hash = "sha256-fBvDSXDSIYMzTa8+A+98KqhEXYP6E17wLo+UNwlyf4U="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "1.1.0"; + hash = "sha256-7KrZfK3kUbmeT82eVadvHurZcaFq3FDj4qkIIeExJiM="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "2.8.0"; + hash = "sha256-ksCgE7YQaWMQywT3pY26bYIEAqtEp3kTxBRloF0gkDw="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "2.8.0"; + hash = "sha256-3LhgErOul0ndBvY57ipiN6uXxzWdyLC577Y6AQPfPVw="; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Razor"; + version = "2.2.0"; + hash = "sha256-poFN+Jh3ZWm3ZT78DM17czL4zedafPdztdr2blVLlQ0="; + }) + (fetchNuGet { + pname = "Microsoft.CodeCoverage"; + version = "17.10.0"; + hash = "sha256-yQFwqVChRtIRpbtkJr92JH2i+O7xn91NGbYgnKs8G2g="; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.5.0"; + hash = "sha256-dAhj/CgXG5VIy2dop1xplUsLje7uBPFjxasz9rdFIgY="; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.7.0"; + hash = "sha256-Enknv2RsFF68lEPdrf5M+BpV1kHoLTVRApKUwuk/pj0="; + }) + (fetchNuGet { + pname = "Microsoft.DiaSymReader.Native"; + version = "1.7.0"; + hash = "sha256-tjvIswyubNy+rJgDlbiZgOb5G4aBdFyBiPa2k28fXFA="; + }) + (fetchNuGet { + pname = "Microsoft.DotNet.PlatformAbstractions"; + version = "2.1.0"; + hash = "sha256-vrZhYp94SjycUMGaVYCFWJ4p7KBKfqVyLWtIG73fzeM="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Caching.Abstractions"; + version = "2.2.0"; + hash = "sha256-osgeoVggP5UqGBG7GbrZmsVvBJmA47aCgsqJclthHUI="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Caching.Memory"; + version = "2.2.0"; + hash = "sha256-u5W1RY7IG7+ZGu18aijpNohFLY2dgLaM4QZptYvV+S8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "2.1.0"; + hash = "sha256-ou/T+Gtw5FcT5nkBGtdf2lAMriTGvb+ulDJkytGgMhM="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "2.2.0"; + hash = "sha256-dGJjKmio5BNFdwhK09NxJyCBapwVtO3eWxjLoTMGRQg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "8.0.0"; + hash = "sha256-9BPsASlxrV8ilmMCjdb3TiUcm5vFZxkBnAI/fNBSEyA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "2.1.0"; + hash = "sha256-rd8zK6YWSxSP5HLrP+IR8o5/+/sheTNDtj3I9Eem/w0="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "2.1.1"; + hash = "sha256-3DdHcNmy+JKWB4Q8ixzE4N/hUAvx2o4YlYal4Riwiyw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "2.2.0"; + hash = "sha256-5Jjn+0WZQ6OiN8AkNlGV0XIaw8L+a/wAq9hBD88RZbs="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "8.0.0"; + hash = "sha256-4eBpDkf7MJozTZnOwQvwcfgRKQGcNXe0K/kF+h5Rl8o="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "2.1.0"; + hash = "sha256-FNOrXx7bJbc6qrscne8RhRj28kxK3uq+3ltdXzhCKHQ="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "2.2.0"; + hash = "sha256-cigv0t9SntPWjJyRWMy3Q5KnuF17HoDyeKq26meTHoM="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.CommandLine"; + version = "2.2.0"; + hash = "sha256-0e3cpwsKrR5Tgt2ZXnfvs8NZbV2FEH8q6zRl84w6bCY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; + version = "2.2.0"; + hash = "sha256-haG2U6qEM6y+Mi4reFNGmarQc7pbc1RH0dXwSgcAxqk="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.FileExtensions"; + version = "2.2.0"; + hash = "sha256-DVfJkCR5BRZGln4X/OIrPMW/Vi4SJE9ttakIbOAMky8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Json"; + version = "2.2.0"; + hash = "sha256-bG+jKsdugEfuVuLlTJxi1OEknnT8rUbp7SscBunOlaE="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.UserSecrets"; + version = "2.2.0"; + hash = "sha256-l+fI+81CZMINKkJ4yTE4w30ymh9Kzuk0HIbgs2TOCpc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "2.2.0"; + hash = "sha256-k/3UKceE1hbgv1sfV9H85hzWvMwooE8PcasHvHMhe1M="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "8.0.0"; + hash = "sha256-+qIDR8hRzreCHNEDtUcPfVHQdurzWPo/mqviCH78+EQ="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "2.1.0"; + hash = "sha256-WgS/QtxbITCpVjs1JPCWuJRrZSoplOtY7VfOXjLqDDA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "2.1.1"; + hash = "sha256-BMU00QmmhtH3jP5cepJnoTrxrPESWeDU0i5UrIpIwGY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "2.2.0"; + hash = "sha256-pf+UQToJnhAe8VuGjxyCTvua1nIX8n5NHzAUk3Jz38s="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.0"; + hash = "sha256-75KzEGWjbRELczJpCiJub+ltNUMMbz5A/1KQU+5dgP8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "8.0.2"; + hash = "sha256-UfLfEQAkXxDaVPC7foE/J3FVEXd31Pu6uQIhTic3JgY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyModel"; + version = "2.1.0"; + hash = "sha256-7dFo5itkB2OgSgS7dN87h0Xf2p5/f6fl2Ka6+CTEhDY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Diagnostics.Abstractions"; + version = "8.0.1"; + hash = "sha256-d5DVXhA8qJFY9YbhZjsTqs5w5kDuxF5v+GD/WZR1QL0="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "2.1.1"; + hash = "sha256-2nfsrYlWR3VE30Fa5Lleh4Acav+kdYD7zIfNz9htFOo="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "2.2.0"; + hash = "sha256-pLAxP15+PncMiRrUT5bBAhWg7lC6/dfQk5TLTpZzA7k="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "8.0.0"; + hash = "sha256-uQSXmt47X2HGoVniavjLICbPtD2ReQOYQMgy3l0xuMU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Composite"; + version = "2.2.0"; + hash = "sha256-KEwhWadHe24jYSNW2UI18wHC+9kyuZXfMCvZC1Z3eEw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Physical"; + version = "2.2.0"; + hash = "sha256-/UD6JMXqSKRVlNAQ+wV8XjQ1u9X48z+TNfwe4/oiOFM="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileSystemGlobbing"; + version = "2.2.0"; + hash = "sha256-gm05niqMBRcGmGSwogHlOAXCfutn5qFxMZaQZYM+XAY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting.Abstractions"; + version = "2.1.1"; + hash = "sha256-FCQqPxMNaaN+CD8xE42+evaxKjPWdznJ45U+qoVf8e0="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting.Abstractions"; + version = "2.2.0"; + hash = "sha256-YZcyKXL6jOpyGrDbFLu46vncfUw2FuqhclMdbEPuh/U="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting.Abstractions"; + version = "8.0.1"; + hash = "sha256-/bIVL9uvBQhV/KQmjA1ZjR74sMfaAlBb15sVXsGDEVA="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Localization"; + version = "2.2.0"; + hash = "sha256-07D6Zh5un5dKl2zM18oVDgWeWQq3Y0RP823nisuc48w="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Localization.Abstractions"; + version = "2.2.0"; + hash = "sha256-/p2UA5VBmC6jxu0boS/hK9g2YgeS+gwe5Ubmk3rR+Ps="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "2.1.0"; + hash = "sha256-BtRVc8o7NruFCblOITHPZD3llUmri3+1dStSo09EMTY="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "2.2.0"; + hash = "sha256-lY9axb6/MyPAhE+N8VtfCIpD80AFCtxUnnGxvb2koy8="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "8.0.0"; + hash = "sha256-Meh0Z0X7KyOEG4l0RWBcuHHihcABcvCyfUXgasmQ91o="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "2.1.0"; + hash = "sha256-0i4YUnMQ4DE0KDp47pssJLUIw8YAsHf2NZN0xoOLb78="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "2.1.1"; + hash = "sha256-TzbYgz4EemrYKHMvB9HWDkFmq0BkTetKPUwBpYHk9+k="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "2.2.0"; + hash = "sha256-lJeKyhBnDc4stX2Wd7WpcG+ZKxPTFHILZSezKM2Fhws="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "8.0.0"; + hash = "sha256-Jmddjeg8U5S+iBTwRlVAVLeIHxc4yrrNgqVMOB7EjM4="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "8.0.2"; + hash = "sha256-cHpe8X2BgYa5DzulZfq24rg8O2K5Lmq2OiLhoyAVgJc="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Configuration"; + version = "2.2.0"; + hash = "sha256-KeAgb1vzW3HOd1+Bp741nHshe2DVVH2OCEU4suam69o="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Console"; + version = "2.2.0"; + hash = "sha256-7qmSYQZGqjuW1JYLzUQCTjl/Ox6ZLjIBJQswNUNjnLw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Debug"; + version = "2.2.0"; + hash = "sha256-1x4AdGEmpN5br+UKXp15EboqMIjtsUn9/r3wNoj7v/w="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.EventSource"; + version = "2.2.0"; + hash = "sha256-DyEQNzKE9ACtCAN2gpVe1Z2ovpDznyBJM9L9A+oSf6I="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.ObjectPool"; + version = "2.1.1"; + hash = "sha256-ivQH0mOjHNwEh/VWUxdrXi/i0SZqRHDMxU9SiW9ygeU="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.ObjectPool"; + version = "2.2.0"; + hash = "sha256-P+QUM50j/V8f45zrRqat8fz6Gu3lFP+hDjESwTZNOFg="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "2.1.0"; + hash = "sha256-ol0tKlHOyX1qAQqNWuag0thb2mMCU2JHNiw0nzUhJnE="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "2.1.1"; + hash = "sha256-dCPA56Wv9cLuz720PmVbk2oXda1t9ZSAlP8/clDU93E="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "2.2.0"; + hash = "sha256-YBtPoWBEs+dlHPQ7qOmss+U9gnvG0T1irZY8NwD0QKw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "8.0.0"; + hash = "sha256-n2m4JSegQKUTlOsKLZUUHHKMq926eJ0w9N9G+I3FoFw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "8.0.2"; + hash = "sha256-AjcldddddtN/9aH9pg7ClEZycWtFHLi9IPe1GGhNQys="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; + version = "2.2.0"; + hash = "sha256-TZKLbSNM32hTzzDIKlRNcu6V2NhLfXTz+ew7QPvNJXE="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "2.1.0"; + hash = "sha256-q1oDnqfQiiKgzlv/WDHgNGTlWfm+fkuY1R6t6hr/L+U="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "2.1.1"; + hash = "sha256-nbu2OeQGWeG8QKpoAOxIQ8aPzDbWHgbzLXh55xqeeQw="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "2.2.0"; + hash = "sha256-DMCTC3HW+sHaRlh/9F1sDwof+XgvVp9IzAqzlZWByn4="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "8.0.0"; + hash = "sha256-FU8qj3DR8bDdc1c+WeGZx/PCZeqqndweZM9epcpXjSo="; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.WebEncoders"; + version = "2.2.0"; + hash = "sha256-wwfvTcAgSnHQCuqqUwsiF588QxQYjXaGk9VwxiCLFtY="; + }) + (fetchNuGet { + pname = "Microsoft.Net.Http.Headers"; + version = "2.1.1"; + hash = "sha256-jdod0MQ58QG8ezS3nYhO85Qk4D7xh0LnOz4XIXvtBBs="; + }) + (fetchNuGet { + pname = "Microsoft.Net.Http.Headers"; + version = "2.2.0"; + hash = "sha256-pb8AoacSvy8hGNGodU6Lhv1ooWtUSCZwjmwd89PM1HA="; + }) + (fetchNuGet { + pname = "Microsoft.NET.Test.Sdk"; + version = "17.10.0"; + hash = "sha256-rkHIqB2mquNXF89XBTFpUL2z5msjTBsOcyjSBCh36I0="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + hash = "sha256-FeM40ktcObQJk4nMYShB61H/E8B7tIKfl9ObJ0IOcCM="; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "5.0.0"; + hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies"; + version = "1.0.3"; + hash = "sha256-FBoJP5DHZF0QHM0xLm9yd4HJZVQOuSpSKA+VQRpphEE="; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies.net462"; + version = "1.0.3"; + hash = "sha256-7mkqhFdDUAkQhV1MMwym6e+HwW4W90DkR00YcYXWbiE="; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.ObjectModel"; + version = "17.10.0"; + hash = "sha256-3YjVGK2zEObksBGYg8b/CqoJgLQ1jUv4GCWNjDhLRh4="; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.TestHost"; + version = "17.10.0"; + hash = "sha256-+yzP3FY6WoOosSpYnB7duZLhOPUZMQYy8zJ1d3Q4hK4="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "4.5.0"; + hash = "sha256-WMBXsIb0DgPFPaFkNVxY9b9vcMxPqtgFgijKYMJfV/0="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "5.0.0"; + hash = "sha256-9kylPGfKZc58yFqNKa77stomcoNnMeERXozWJzDcUIA="; + }) + (fetchNuGet { + pname = "MimeMapping"; + version = "1.0.1.50"; + hash = "sha256-oz7GTUIqqj+224Xe5AiYmI6pEjXQ485QzVdLHAQ0gok="; + }) + (fetchNuGet { + pname = "Mono.Posix"; + version = "7.1.0-final.1.21458.1"; + hash = "sha256-kbpbruyWKfWfRg9IX0wR8UirykgJdLZl2d5PqUgFxz4="; + }) + (fetchNuGet { + pname = "Mono.Unix"; + version = "7.1.0-final.1.21458.1"; + hash = "sha256-tm3niOm4OFCe/kL5M5zwCZgfHEaPtmDqsOLN6GExYHs="; + }) + (fetchNuGet { + pname = "MSTest.TestAdapter"; + version = "3.0.2"; + hash = "sha256-53zaLSghO4Un9GUF4W3bV34X5UHeQ80h2y7fCm1J9t8="; + }) + (fetchNuGet { + pname = "MSTest.TestFramework"; + version = "3.0.2"; + hash = "sha256-WMXSFNAxUtZVyrtrNcJu6KofR+A+/A3SbsleFCGIPPo="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.0"; + hash = "sha256-Pp7fRylai8JrE1O+9TGfIEJrAOmnWTJRLWE+qJBahK0="; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + hash = "sha256-Prh2RPebz/s8AzHb2sPHg3Jl8s31inv9k+Qxd293ybo="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "10.0.1"; + hash = "sha256-Gw7dQIsmYfmcR5ASTuMsB8cqaI4g3osw0j+LO1jEzJY="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "11.0.2"; + hash = "sha256-YhlAbGfwoxQzxb3Hef4iyV9eGdPQJJNd2GgSR0jsBJ0="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.1"; + hash = "sha256-K2tSVW4n4beRPzPu3rlVaBEMdGvWSv/3Q1fxaDh4Mjo="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.3"; + hash = "sha256-hy/BieY4qxBWVVsDqqOPaLy1QobiIapkbrESm6v2PHc="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "9.0.1"; + hash = "sha256-mYCBrgUhIJFzRuLLV9SIiIFHovzfR8Uuqfg6e08EnlU="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json.Bson"; + version = "1.0.1"; + hash = "sha256-qofIFqViDsdBOE/X0IvzfGUklSrULaH8MoZQ+YrcMOQ="; + }) + (fetchNuGet { + pname = "Newtonsoft.Json.Bson"; + version = "1.0.2"; + hash = "sha256-ZUj6YFSMZp5CZtXiamw49eZmbp1iYBuNsIKNnjxcRzA="; + }) + (fetchNuGet { + pname = "NLog"; + version = "5.3.2"; + hash = "sha256-b/y/IFUSe7qsSeJ8JVB0VFmJlkviFb8h934ktnn9Fgc="; + }) + (fetchNuGet { + pname = "NLog.Extensions.Logging"; + version = "5.3.11"; + hash = "sha256-DP3R51h+9kk06N63U+1C4/JCZTFiADeYTROToAA2R0g="; + }) + (fetchNuGet { + pname = "NLog.Web.AspNetCore"; + version = "5.3.11"; + hash = "sha256-6bMYbKyNWtb0tn8k3418mWBuogofIAfwT9NHSopUu58="; + }) + (fetchNuGet { + pname = "NUnit"; + version = "3.14.0"; + hash = "sha256-CuP/q5HovPWfAW3Cty/QxRi7VpjykJ3TDLq5TENI6KY="; + }) + (fetchNuGet { + pname = "NUnit.ConsoleRunner"; + version = "3.17.0"; + hash = "sha256-aGf4/XDPs4VByjN/RHeN9+0tr598H4t6UsmatOLbVmI="; + }) + (fetchNuGet { + pname = "NUnit3TestAdapter"; + version = "4.5.0"; + hash = "sha256-ER3ogl0L5FYyc6pVVPY1ch+AQxG/WgFcnWECnYQJPes="; + }) + (fetchNuGet { + pname = "Polly"; + version = "8.4.2"; + hash = "sha256-cuaH3SdTEdwLA1VddtY6CsmHTiDuYk0dVJ79r/6jSpQ="; + }) + (fetchNuGet { + pname = "Polly.Core"; + version = "8.4.2"; + hash = "sha256-4fn5n6Bu29uqWg8ciii3MDsi9bO2/moPa9B3cJ9Ihe8="; + }) + (fetchNuGet { + pname = "SharpZipLib"; + version = "1.4.2"; + hash = "sha256-/giVqikworG2XKqfN9uLyjUSXr35zBuZ2FX2r8X/WUY="; + }) + (fetchNuGet { + pname = "System.AppContext"; + version = "4.3.0"; + hash = "sha256-yg95LNQOwFlA1tWxXdQkVyJqT4AnoDc+ACmrNvzGiZg="; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.4.0"; + hash = "sha256-KTxAhYawFG2V5VX1jw3pzx3IrQXRgn1TsvgjPgxAbqA="; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.0"; + hash = "sha256-THw2znu+KibfJRfD7cE3nRYHsm7Fyn5pjOOZVonFjvs="; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + hash = "sha256-wws90sfi9M7kuCPWkv1CEYMJtCqx9QB/kj0ymlsNaxI="; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + hash = "sha256-afY7VUtD6w/5mYqrce8kQrvDIfS2GXDINDh73IjxJKc="; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.3.0"; + hash = "sha256-KMY5DfJnDeIsa13DpqvyN8NkReZEMAFnlmNglVoFIXI="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "1.3.1"; + hash = "sha256-areGRq/dO08KhxiWuAK+cWAjOWYtuB1R9zGXLvIqwZw="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "1.5.0"; + hash = "sha256-BliqYlL9ntbMXo5d7NUrKXwYN+PqdyqDIS5bp4qVr7Q="; + }) + (fetchNuGet { + pname = "System.ComponentModel.Annotations"; + version = "4.5.0"; + hash = "sha256-15yE2NoT9vmL9oGCaxHClQR1jLW1j1ef5hHMg55xRso="; + }) + (fetchNuGet { + pname = "System.Configuration.ConfigurationManager"; + version = "4.4.0"; + hash = "sha256-+8wGYllXnIxRzy9dLhZFB88GoPj8ivYXS0KUfcivT8I="; + }) + (fetchNuGet { + pname = "System.Console"; + version = "4.3.0"; + hash = "sha256-Xh3PPBZr0pDbDaK8AEHbdGz7ePK6Yi1ZyRWI1JM6mbo="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + hash = "sha256-fkA79SjPbSeiEcrbbUsb70u9B7wqbsdM9s1LnoKj0gM="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "4.5.0"; + hash = "sha256-0r8bsmgsb30bHJnvi98oPTFcxLfuqqt9mcoeEcYFFfk="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "7.0.2"; + hash = "sha256-8Uawe7mWOQsDzMSAAP16nuGD1FRSajyS8q+cA++MJ8E="; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "8.0.1"; + hash = "sha256-zmwHjcJgKcbkkwepH038QhcnsWMJcHys+PEbFGC0Jgo="; + }) + (fetchNuGet { + pname = "System.Diagnostics.EventLog"; + version = "8.0.1"; + hash = "sha256-zvqd72pwgcGoa1nH3ZT1C0mP9k53vFLJ69r5MCQ1saA="; + }) + (fetchNuGet { + pname = "System.Diagnostics.FileVersionInfo"; + version = "4.3.0"; + hash = "sha256-JyqOf5/lsUNLMpIqK8XffcFTxB6vHWzGWHssmojokCQ="; + }) + (fetchNuGet { + pname = "System.Diagnostics.StackTrace"; + version = "4.3.0"; + hash = "sha256-Tfq7F61N0VfujVyI5A9MZvyWewQ5HepB1f1UMBMkUCs="; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tools"; + version = "4.3.0"; + hash = "sha256-gVOv1SK6Ape0FQhCVlNOd9cvQKBvMxRX9K0JPVi8w0Y="; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.3.0"; + hash = "sha256-k75gjOYimIQtLBD5NDzwwi3ZMUBPRW3jmc3evDMMJbU="; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + hash = "sha256-caL0pRmFSEsaoeZeWN5BTQtGrAtaQPwFi8YOZPZG5rI="; + }) + (fetchNuGet { + pname = "System.IO.Compression"; + version = "4.3.0"; + hash = "sha256-f5PrQlQgj5Xj2ZnHxXW8XiOivaBvfqDao9Sb6AVinyA="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + hash = "sha256-vNIYnvlayuVj0WfRfYKpDrhDptlhp1pN8CYmlVd2TXw="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.AccessControl"; + version = "5.0.0"; + hash = "sha256-c9MlDKJfj63YRvl7brRBNs59olrmbL+G1A6oTS8ytEc="; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + hash = "sha256-LMnfg8Vwavs9cMnq9nNH8IWtAtSfk0/Fy4s4Rt9r1kg="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "4.5.2"; + hash = "sha256-AXsErCMtJnoT1ZhYlChyObzAimwEp1Cl1L6X6fewuhA="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "4.6.0"; + hash = "sha256-cCtFmQlk0TFBWbZLVh/c258lyF3X4mPWkyb625d8PmU="; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "5.0.1"; + hash = "sha256-2zT5uBiyYm+jLIoJppIKJttTtpcMNKxd7Li0QEVjbv8="; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + hash = "sha256-R5uiSL3l6a3XrXSSL6jz+q/PcyVQzEAByiuXZNSqD/A="; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.3.0"; + hash = "sha256-+3pvhZY7rip8HCbfdULzjlC9FPZFpYoQxhkcuFm2wk8="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.0"; + hash = "sha256-YOz1pCR4RpP1ywYoJsgXnVlzsWtC2uYKQJTg0NnFXtE="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.1"; + hash = "sha256-7JhQNSvE6JigM1qmmhzOX3NiZ6ek82R4whQNb+FpBzg="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.3"; + hash = "sha256-Cvl7RbRbRu9qKzeRBWjavUkseT2jhZBUWV1SPipUWFk="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + hash = "sha256-3sCEfzO4gj5CYGctl9ZXQRRhwAraMQfse7yzKoRe65E="; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.5"; + hash = "sha256-EPQ9o1Kin7KzGI5O3U3PUQAZTItSbk9h/i4rViN3WiI="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.4.0"; + hash = "sha256-auXQK2flL/JpnB/rEcAcUm4vYMCYMEMiWOCAlIaqu2U="; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + hash = "sha256-qdSTIFgf2htPS+YhLGjAGiLN8igCYJnCCo6r78+Q+c8="; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + hash = "sha256-NQSZRpZLvtPWDlvmMIdGxcVuyUnw92ZURo0hXsEshXY="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "1.4.2"; + hash = "sha256-cYd2SWmnacNq14fTpyW9vGcnbZSD4DPRjpR+tgdZZyE="; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "1.6.0"; + hash = "sha256-JJfgaPav7UfEh4yRAQdGhLZF1brr0tUWPl6qmfNWq/E="; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + hash = "sha256-idiOD93xbbrbwwSnD4mORA9RYi/D/U48eRUsn/WnWGo="; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + hash = "sha256-51813WXpBIsuA6fUtE5XaRQjcWdQ2/lmEokJt97u0Rg="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.0"; + hash = "sha256-g9jIdQtXSAhY+ezQtYNgHEUoQR3HzznHs3JMzD9bip4="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.1"; + hash = "sha256-Lucrfpuhz72Ns+DOS7MjuNT2KWgi+m4bJkg87kqXmfU="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.2"; + hash = "sha256-8eUXXGWO2LL7uATMZye2iCpQOETn2jCcjUhG6coR5O8="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.3"; + hash = "sha256-lnZMUqRO4RYRUeSO8HSJ9yBHqFHLVbmenwHWkIU20ak="; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + hash = "sha256-bEG1PnDp7uKYz/OgLOWs3RWwQSVYm+AnPwVmAmcgp2I="; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + hash = "sha256-wLDHmozr84v1W2zYCWYxxj0FR0JDYHSVRaRuDm0bd/o="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + hash = "sha256-8sDH+WUJfCR+7e4nfpftj/+lstEiZixWUBueR2zmHgI="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices.RuntimeInformation"; + version = "4.0.0"; + hash = "sha256-5j53amb76A3SPiE3B0llT2XPx058+CgE7OXL4bLalT4="; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices.RuntimeInformation"; + version = "4.3.0"; + hash = "sha256-MYpl6/ZyC6hjmzWRIe+iDoldOMW1mfbwXsduAnXIKGA="; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.3.0"; + hash = "sha256-P5jHCgMbgFMYiONvzmaKFeOqcAIDPu/U8bOVrNPYKqc="; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "4.5.0"; + hash = "sha256-AFsKPb/nTk2/mqH/PYpaoI8PLsiKKimaXf+7Mb5VfPM="; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "5.0.0"; + hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.3.0"; + hash = "sha256-tAJvNSlczYBJ3Ed24Ae27a55tq/n4D3fubNQdwcKWA8="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.5.0"; + hash = "sha256-9llRbEcY1fHYuTn3vGZaCxsFxSAqXl4bDA6Rz9b0pN4="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.3.0"; + hash = "sha256-Yuge89N6M+NcblcvXMeyHZ6kZDfwBv3LPMDiF8HhJss="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Pkcs"; + version = "8.0.1"; + hash = "sha256-KMNIkJ3yQ/5O6WIhPjyAIarsvIMhkp26A6aby5KkneU="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.3.0"; + hash = "sha256-fnFi7B3SnVj5a+BbgXnbjnGNvWrCEU6Hp/wjsjWz318="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "4.4.0"; + hash = "sha256-Ri53QmFX8I8UH0x4PikQ1ZA07ZSnBUXStd5rBfGWFOE="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "8.0.0"; + hash = "sha256-fb0pa9sQxN+mr0vnXg1Igbx49CaOqS+GDkTfWNboUvs="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.3.0"; + hash = "sha256-MG3V/owDh273GCUPsGGraNwaVpcydupl3EtPXj6TVG0="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Xml"; + version = "4.5.0"; + hash = "sha256-FIGpgYPbdA1NX0I4NmAr4gdt5VM/emm7PjM5XUEHZOY="; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Xml"; + version = "8.0.2"; + hash = "sha256-9TCmVyMB4+By/ipU8vdYDtSnw1tkkebnXXVRdT78+28="; + }) + (fetchNuGet { + pname = "System.Security.Permissions"; + version = "4.5.0"; + hash = "sha256-Fa6dX6Gyse1A/RBoin8cVaHQePbfBvp6jjWxUXPhXKQ="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.5.0"; + hash = "sha256-BkUYNguz0e4NJp1kkW7aJBn3dyH9STwB5N8XqnlCsmY="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; + }) + (fetchNuGet { + pname = "System.ServiceProcess.ServiceController"; + version = "8.0.1"; + hash = "sha256-2cXTzNOyXqJinFPzdVJ9Gu6qrFtycfivu7RHDzBJic8="; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + hash = "sha256-GctHVGLZAa/rqkBNhsBGnsiWdKyv6VDubYpGkuOkBLg="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "8.0.0"; + hash = "sha256-fjCLQc1PRW0Ix5IZldg0XKv+J1DqPSfu9pjMyNBp7dE="; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + hash = "sha256-vufHXg8QAKxHlujPHHcrtGwAqFmsCD6HKjfDAiHyAYc="; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "4.5.0"; + hash = "sha256-o+jikyFOG30gX57GoeZztmuJ878INQ5SFMmKovYqLWs="; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "4.5.1"; + hash = "sha256-F3YY+z86YxC5TQW7RToelnemrqRN7gdRNbpdot8byl8="; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "8.0.0"; + hash = "sha256-IUQkQkV9po1LC0QsqrilqwNzPvnc+4eVvq+hCvq8fvE="; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "8.0.5"; + hash = "sha256-yKxo54w5odWT6nPruUVsaX53oPRe+gKzGvLnnxtwP68="; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + hash = "sha256-ZDQ3dR4pzVwmaqBg4hacZaVenQ/3yAF/uV7BXZXjiWc="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + hash = "sha256-Z5rXfJ1EXp3G32IKZGiZ6koMjRu0n8C1NGrwpdIen4w="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.0"; + hash = "sha256-SIdUoXOGGSmBGXLWW76fz0OEoFYDJ8ZoU/xFdVibtxY="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.1"; + hash = "sha256-3NeBC+r7eTVz3f+cEm1NkVhxSr7LrYGX/NdUwje9ecY="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.2"; + hash = "sha256-EqJF9TppMHTKvpR6emrdA61zalMW3HwrZ7j6Bn4bBuo="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + hash = "sha256-owSpY8wHlsUXn5xrfYAiu847L6fAKethlvYx97Ri1ng="; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Parallel"; + version = "4.3.0"; + hash = "sha256-8H2vRmsn29MNfMmCeIL5vHfbM19jWaLDKNLzDonCI+c="; + }) + (fetchNuGet { + pname = "System.Threading.Thread"; + version = "4.3.0"; + hash = "sha256-pMs6RNFC3nQOGz9EqIcyWmO8YLaqay+q/Qde5hqPXXg="; + }) + (fetchNuGet { + pname = "System.ValueTuple"; + version = "4.3.0"; + hash = "sha256-tkMwiobmGQn/t8LDqpkM+Q7XJOebEl3bwVf11d2ZR4g="; + }) + (fetchNuGet { + pname = "System.ValueTuple"; + version = "4.5.0"; + hash = "sha256-niH6l2fU52vAzuBlwdQMw0OEoRS/7E1w5smBFoqSaAI="; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.3.0"; + hash = "sha256-QQ8KgU0lu4F5Unh+TbechO//zaAGZ4MfgvW72Cn1hzA="; + }) + (fetchNuGet { + pname = "System.Xml.XDocument"; + version = "4.3.0"; + hash = "sha256-rWtdcmcuElNOSzCehflyKwHkDRpiOhJJs8CeQ0l1CCI="; + }) + (fetchNuGet { + pname = "System.Xml.XmlDocument"; + version = "4.3.0"; + hash = "sha256-kbuV4Y7rVJkfMp2Kgoi8Zvdatm9CZNmlKB3GZgANvy4="; + }) + (fetchNuGet { + pname = "System.Xml.XPath"; + version = "4.3.0"; + hash = "sha256-kd1JMqj6obhxzEPRJeYvcUyJqkOs/9A0UOQccC6oYrM="; + }) + (fetchNuGet { + pname = "System.Xml.XPath.XDocument"; + version = "4.3.0"; + hash = "sha256-dqk4CWuwocj5qsUAYlS+XAe6GGcY/N/HIPEGe5afrPM="; + }) + (fetchNuGet { + pname = "YamlDotNet"; + version = "13.0.1"; + hash = "sha256-vrPm3nActRBC+psOSDGu2sjy/FL1Sak/okZPwurOUB8="; + }) ] diff --git a/pkgs/servers/jibri/default.nix b/pkgs/servers/jibri/default.nix index 29aed51d63af0a..786a18086b6a57 100644 --- a/pkgs/servers/jibri/default.nix +++ b/pkgs/servers/jibri/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchurl, dpkg, jdk11_headless, makeWrapper, writeText, xorg, nixosTests }: +{ + lib, + stdenv, + fetchurl, + dpkg, + jdk11_headless, + makeWrapper, + writeText, + xorg, + nixosTests, +}: let xorgModulePaths = writeText "module-paths" '' @@ -20,7 +30,10 @@ stdenv.mkDerivation rec { }; dontBuild = true; - nativeBuildInputs = [ dpkg makeWrapper ]; + nativeBuildInputs = [ + dpkg + makeWrapper + ]; installPhase = '' runHook preInstall diff --git a/pkgs/servers/jicofo/default.nix b/pkgs/servers/jicofo/default.nix index cb55d43e39ad54..fd8fc8bfcfe84e 100644 --- a/pkgs/servers/jicofo/default.nix +++ b/pkgs/servers/jicofo/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, dpkg, jre_headless, nixosTests }: +{ + lib, + stdenv, + fetchurl, + dpkg, + jre_headless, + nixosTests, +}: let pname = "jicofo"; diff --git a/pkgs/servers/jitsi-videobridge/default.nix b/pkgs/servers/jitsi-videobridge/default.nix index 086b6e2c81fb76..194b929502c087 100644 --- a/pkgs/servers/jitsi-videobridge/default.nix +++ b/pkgs/servers/jitsi-videobridge/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, makeWrapper, dpkg, jre_headless, openssl, nixosTests }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + dpkg, + jre_headless, + openssl, + nixosTests, +}: let pname = "jitsi-videobridge2"; diff --git a/pkgs/servers/klipper/klipper-firmware.nix b/pkgs/servers/klipper/klipper-firmware.nix index 53a57279a3649c..b314379be190b1 100644 --- a/pkgs/servers/klipper/klipper-firmware.nix +++ b/pkgs/servers/klipper/klipper-firmware.nix @@ -1,19 +1,21 @@ -{ stdenv -, lib -, pkg-config -, pkgsCross -, bintools-unwrapped -, libffi -, libusb1 -, wxGTK32 -, python3 -, gcc-arm-embedded -, klipper -, avrdude -, stm32flash -, mcu ? "mcu" -, firmwareConfig ? ./simulator.cfg -}: stdenv.mkDerivation rec { +{ + stdenv, + lib, + pkg-config, + pkgsCross, + bintools-unwrapped, + libffi, + libusb1, + wxGTK32, + python3, + gcc-arm-embedded, + klipper, + avrdude, + stm32flash, + mcu ? "mcu", + firmwareConfig ? ./simulator.cfg, +}: +stdenv.mkDerivation rec { name = "klipper-firmware-${mcu}-${version}"; version = klipper.version; src = klipper.src; diff --git a/pkgs/servers/klipper/klipper-flash.nix b/pkgs/servers/klipper/klipper-flash.nix index 2f37745fd631fc..866e398421673e 100644 --- a/pkgs/servers/klipper/klipper-flash.nix +++ b/pkgs/servers/klipper/klipper-flash.nix @@ -1,28 +1,38 @@ -{ lib -, writeShellApplication -, gnumake -, pkgsCross -, klipper -, klipper-firmware -, python3 -, avrdude -, stm32flash -, mcu ? "mcu" -, flashDevice ? "/dev/null" -, firmwareConfig ? ./simulator.cfg +{ + lib, + writeShellApplication, + gnumake, + pkgsCross, + klipper, + klipper-firmware, + python3, + avrdude, + stm32flash, + mcu ? "mcu", + flashDevice ? "/dev/null", + firmwareConfig ? ./simulator.cfg, }: let - supportedArches = [ "avr" "stm32" "lpc176x" ]; - matchBoard = with builtins; match ''^.*CONFIG_BOARD_DIRECTORY="([a-zA-Z0-9_]+)".*$'' (readFile firmwareConfig); + supportedArches = [ + "avr" + "stm32" + "lpc176x" + ]; + matchBoard = + with builtins; + match ''^.*CONFIG_BOARD_DIRECTORY="([a-zA-Z0-9_]+)".*$'' (readFile firmwareConfig); boardArch = if matchBoard == null then null else builtins.head matchBoard; in writeShellApplication { name = "klipper-flash-${mcu}"; - runtimeInputs = [ - python3 - pkgsCross.avr.stdenv.cc - gnumake - ] ++ lib.optionals (boardArch == "avr") [ avrdude ] ++ lib.optionals (boardArch == "stm32") [ stm32flash ]; + runtimeInputs = + [ + python3 + pkgsCross.avr.stdenv.cc + gnumake + ] + ++ lib.optionals (boardArch == "avr") [ avrdude ] + ++ lib.optionals (boardArch == "stm32") [ stm32flash ]; text = '' if ${lib.boolToString (!builtins.elem boardArch supportedArches)}; then printf "Flashing Klipper firmware to your board is not supported yet.\n" diff --git a/pkgs/servers/klipper/klipper-genconf.nix b/pkgs/servers/klipper/klipper-genconf.nix index 293a8112007bf3..919fe8e6c97ed9 100644 --- a/pkgs/servers/klipper/klipper-genconf.nix +++ b/pkgs/servers/klipper/klipper-genconf.nix @@ -1,8 +1,10 @@ -{ writeShellApplication -, klipper -, python3 -, gnumake -}: writeShellApplication { +{ + writeShellApplication, + klipper, + python3, + gnumake, +}: +writeShellApplication { name = "klipper-genconf"; runtimeInputs = [ python3 diff --git a/pkgs/servers/krill/default.nix b/pkgs/servers/krill/default.nix index f310b4d020effa..61703b16f7d87d 100644 --- a/pkgs/servers/krill/default.nix +++ b/pkgs/servers/krill/default.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, openssl -, pkg-config -, stdenv -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + openssl, + pkg-config, + stdenv, + Security, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/servers/mail/dovecot/default.nix b/pkgs/servers/mail/dovecot/default.nix index 7a2c42fad1f9ff..ebfb9be622c617 100644 --- a/pkgs/servers/mail/dovecot/default.nix +++ b/pkgs/servers/mail/dovecot/default.nix @@ -1,23 +1,64 @@ -{ stdenv, lib, fetchurl, perl, pkg-config, systemd, openssl -, bzip2, zlib, lz4, inotify-tools, pam, libcap, coreutils -, clucene_core_2, icu, openldap, libsodium, libstemmer, cyrus_sasl -, nixosTests -, fetchpatch -# Auth modules -, withMySQL ? false, libmysqlclient -, withPgSQL ? false, postgresql -, withSQLite ? true, sqlite -, withLua ? false, lua5_3 +{ + stdenv, + lib, + fetchurl, + perl, + pkg-config, + systemd, + openssl, + bzip2, + zlib, + lz4, + inotify-tools, + pam, + libcap, + coreutils, + clucene_core_2, + icu, + openldap, + libsodium, + libstemmer, + cyrus_sasl, + nixosTests, + fetchpatch, + # Auth modules + withMySQL ? false, + libmysqlclient, + withPgSQL ? false, + postgresql, + withSQLite ? true, + sqlite, + withLua ? false, + lua5_3, }: stdenv.mkDerivation rec { pname = "dovecot"; version = "2.3.21.1"; - nativeBuildInputs = [ perl pkg-config ]; + nativeBuildInputs = [ + perl + pkg-config + ]; buildInputs = - [ openssl bzip2 zlib lz4 clucene_core_2 icu openldap libsodium libstemmer cyrus_sasl.dev ] - ++ lib.optionals (stdenv.hostPlatform.isLinux) [ systemd pam libcap inotify-tools ] + [ + openssl + bzip2 + zlib + lz4 + clucene_core_2 + icu + openldap + libsodium + libstemmer + cyrus_sasl.dev + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux) [ + systemd + pam + libcap + inotify-tools + ] ++ lib.optional withMySQL libmysqlclient ++ lib.optional withPgSQL postgresql ++ lib.optional withSQLite sqlite @@ -30,23 +71,25 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; - postPatch = '' - sed -i -E \ - -e 's!/bin/sh\b!${stdenv.shell}!g' \ - -e 's!([^[:alnum:]/_-])/bin/([[:alnum:]]+)\b!\1${coreutils}/bin/\2!g' \ - -e 's!([^[:alnum:]/_-])(head|sleep|cat)\b!\1${coreutils}/bin/\2!g' \ - src/lib-program-client/test-program-client-local.c + postPatch = + '' + sed -i -E \ + -e 's!/bin/sh\b!${stdenv.shell}!g' \ + -e 's!([^[:alnum:]/_-])/bin/([[:alnum:]]+)\b!\1${coreutils}/bin/\2!g' \ + -e 's!([^[:alnum:]/_-])(head|sleep|cat)\b!\1${coreutils}/bin/\2!g' \ + src/lib-program-client/test-program-client-local.c - patchShebangs src/lib-smtp/test-bin/*.sh - sed -i -s -E 's!\bcat\b!${coreutils}/bin/cat!g' src/lib-smtp/test-bin/*.sh + patchShebangs src/lib-smtp/test-bin/*.sh + sed -i -s -E 's!\bcat\b!${coreutils}/bin/cat!g' src/lib-smtp/test-bin/*.sh - patchShebangs src/config/settings-get.pl + patchShebangs src/config/settings-get.pl - # DES-encrypted passwords are not supported by NixPkgs anymore - sed '/test_password_scheme("CRYPT"/d' -i src/auth/test-libpassword.c - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - export systemdsystemunitdir=$out/etc/systemd/system - ''; + # DES-encrypted passwords are not supported by NixPkgs anymore + sed '/test_password_scheme("CRYPT"/d' -i src/auth/test-libpassword.c + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + export systemdsystemunitdir=$out/etc/systemd/system + ''; # We need this for sysconfdir, see remark below. installFlags = [ "DESTDIR=$(out)" ]; @@ -56,51 +99,56 @@ stdenv.mkDerivation rec { rm -rf $out/$(echo "$out" | cut -d "/" -f2) ''; - patches = [ - # Make dovecot look for plugins in /etc/dovecot/modules - # so we can symlink plugins from several packages there. - # The symlinking needs to be done in NixOS. - ./2.3.x-module_dir.patch - # fix openssl 3.0 compatibility - (fetchpatch { - url = "https://salsa.debian.org/debian/dovecot/-/raw/debian/1%252.3.19.1+dfsg1-2/debian/patches/Support-openssl-3.0.patch"; - hash = "sha256-PbBB1jIY3jIC8Js1NY93zkV0gISGUq7Nc67Ul5tN7sw="; - }) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # fix timespec calls - ./timespec.patch - ]; + patches = + [ + # Make dovecot look for plugins in /etc/dovecot/modules + # so we can symlink plugins from several packages there. + # The symlinking needs to be done in NixOS. + ./2.3.x-module_dir.patch + # fix openssl 3.0 compatibility + (fetchpatch { + url = "https://salsa.debian.org/debian/dovecot/-/raw/debian/1%252.3.19.1+dfsg1-2/debian/patches/Support-openssl-3.0.patch"; + hash = "sha256-PbBB1jIY3jIC8Js1NY93zkV0gISGUq7Nc67Ul5tN7sw="; + }) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # fix timespec calls + ./timespec.patch + ]; - configureFlags = [ - # It will hardcode this for /var/lib/dovecot. - # http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=626211 - "--localstatedir=/var" - # We need this so utilities default to reading /etc/dovecot/dovecot.conf file. - "--sysconfdir=/etc" - "--with-ldap" - "--with-ssl=openssl" - "--with-zlib" - "--with-bzlib" - "--with-lz4" - "--with-ldap" - "--with-lucene" - "--with-icu" - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "i_cv_epoll_works=${if stdenv.hostPlatform.isLinux then "yes" else "no"}" - "i_cv_posix_fallocate_works=${if stdenv.hostPlatform.isDarwin then "no" else "yes"}" - "i_cv_inotify_works=${if stdenv.hostPlatform.isLinux then "yes" else "no"}" - "i_cv_signed_size_t=no" - "i_cv_signed_time_t=yes" - "i_cv_c99_vsnprintf=yes" - "lib_cv_va_copy=yes" - "i_cv_mmap_plays_with_write=yes" - "i_cv_gmtime_max_time_t=${toString stdenv.hostPlatform.parsed.cpu.bits}" - "i_cv_signed_time_t=yes" - "i_cv_fd_passing=yes" - "lib_cv_va_copy=yes" - "lib_cv___va_copy=yes" - "lib_cv_va_val_copy=yes" - ] ++ lib.optional stdenv.hostPlatform.isLinux "--with-systemd" + configureFlags = + [ + # It will hardcode this for /var/lib/dovecot. + # http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=626211 + "--localstatedir=/var" + # We need this so utilities default to reading /etc/dovecot/dovecot.conf file. + "--sysconfdir=/etc" + "--with-ldap" + "--with-ssl=openssl" + "--with-zlib" + "--with-bzlib" + "--with-lz4" + "--with-ldap" + "--with-lucene" + "--with-icu" + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + "i_cv_epoll_works=${if stdenv.hostPlatform.isLinux then "yes" else "no"}" + "i_cv_posix_fallocate_works=${if stdenv.hostPlatform.isDarwin then "no" else "yes"}" + "i_cv_inotify_works=${if stdenv.hostPlatform.isLinux then "yes" else "no"}" + "i_cv_signed_size_t=no" + "i_cv_signed_time_t=yes" + "i_cv_c99_vsnprintf=yes" + "lib_cv_va_copy=yes" + "i_cv_mmap_plays_with_write=yes" + "i_cv_gmtime_max_time_t=${toString stdenv.hostPlatform.parsed.cpu.bits}" + "i_cv_signed_time_t=yes" + "i_cv_fd_passing=yes" + "lib_cv_va_copy=yes" + "lib_cv___va_copy=yes" + "lib_cv_va_val_copy=yes" + ] + ++ lib.optional stdenv.hostPlatform.isLinux "--with-systemd" ++ lib.optional stdenv.hostPlatform.isDarwin "--enable-static" ++ lib.optional withMySQL "--with-mysql" ++ lib.optional withPgSQL "--with-pgsql" @@ -112,9 +160,21 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://dovecot.org/"; description = "Open source IMAP and POP3 email server written with security primarily in mind"; - license = with licenses; [ mit publicDomain lgpl21Only bsd3 bsdOriginal ]; + license = with licenses; [ + mit + publicDomain + lgpl21Only + bsd3 + bsdOriginal + ]; mainProgram = "dovecot"; - maintainers = with maintainers; [ fpletz globin ] ++ teams.helsinki-systems.members; + maintainers = + with maintainers; + [ + fpletz + globin + ] + ++ teams.helsinki-systems.members; platforms = platforms.unix; }; passthru.tests = { diff --git a/pkgs/servers/mail/mailman/default.nix b/pkgs/servers/mail/mailman/default.nix index 5571a5bef7f32f..3295bdbb68d6c9 100644 --- a/pkgs/servers/mail/mailman/default.nix +++ b/pkgs/servers/mail/mailman/default.nix @@ -1,35 +1,65 @@ -{ newScope, lib, python3 }: +{ + newScope, + lib, + python3, +}: let - self = lib.makeExtensible (self: let inherit (self) callPackage; in { - callPackage = newScope self; + self = lib.makeExtensible ( + self: + let + inherit (self) callPackage; + in + { + callPackage = newScope self; - python3 = callPackage ./python.nix { inherit python3; }; + python3 = callPackage ./python.nix { inherit python3; }; - hyperkitty = callPackage ./hyperkitty.nix { }; + hyperkitty = callPackage ./hyperkitty.nix { }; - mailman = callPackage ./package.nix { }; + mailman = callPackage ./package.nix { }; - mailman-hyperkitty = callPackage ./mailman-hyperkitty.nix { }; + mailman-hyperkitty = callPackage ./mailman-hyperkitty.nix { }; - postorius = callPackage ./postorius.nix { }; + postorius = callPackage ./postorius.nix { }; - web = callPackage ./web.nix { }; + web = callPackage ./web.nix { }; - buildEnvs = { web ? self.web - , mailman ? self.mailman - , mailman-hyperkitty ? self.mailman-hyperkitty - , withHyperkitty ? false - , withLDAP ? false - }: - { - mailmanEnv = self.python3.withPackages - (ps: [ mailman ps.psycopg2 ] + buildEnvs = + { + web ? self.web, + mailman ? self.mailman, + mailman-hyperkitty ? self.mailman-hyperkitty, + withHyperkitty ? false, + withLDAP ? false, + }: + { + mailmanEnv = self.python3.withPackages ( + ps: + [ + mailman + ps.psycopg2 + ] ++ lib.optional withHyperkitty mailman-hyperkitty - ++ lib.optionals withLDAP [ ps.python-ldap ps.django-auth-ldap ]); - webEnv = self.python3.withPackages - (ps: [ web ps.psycopg2 ] ++ lib.optionals withLDAP [ ps.python-ldap ps.django-auth-ldap ]); - }; - }); + ++ lib.optionals withLDAP [ + ps.python-ldap + ps.django-auth-ldap + ] + ); + webEnv = self.python3.withPackages ( + ps: + [ + web + ps.psycopg2 + ] + ++ lib.optionals withLDAP [ + ps.python-ldap + ps.django-auth-ldap + ] + ); + }; + } + ); -in self +in +self diff --git a/pkgs/servers/mail/mailman/mailman-hyperkitty.nix b/pkgs/servers/mail/mailman/mailman-hyperkitty.nix index 2aac1665f81b40..b4537fca7489bd 100644 --- a/pkgs/servers/mail/mailman/mailman-hyperkitty.nix +++ b/pkgs/servers/mail/mailman/mailman-hyperkitty.nix @@ -1,8 +1,9 @@ -{ lib -, python3 -, fetchPypi -, mailman -, nixosTests +{ + lib, + python3, + fetchPypi, + mailman, + nixosTests, }: with python3.pkgs; diff --git a/pkgs/servers/mail/mailman/package.nix b/pkgs/servers/mail/mailman/package.nix index cbdbea48d09c40..cb5dc354cf74c0 100644 --- a/pkgs/servers/mail/mailman/package.nix +++ b/pkgs/servers/mail/mailman/package.nix @@ -1,10 +1,11 @@ -{ lib -, fetchpatch -, python3 -, fetchPypi -, postfix -, lynx -, nixosTests +{ + lib, + fetchpatch, + python3, + fetchPypi, + postfix, + lynx, + nixosTests, }: with python3.pkgs; diff --git a/pkgs/servers/mail/mailman/postorius.nix b/pkgs/servers/mail/mailman/postorius.nix index 1a0b2394148557..086a2e97e7f468 100644 --- a/pkgs/servers/mail/mailman/postorius.nix +++ b/pkgs/servers/mail/mailman/postorius.nix @@ -1,4 +1,9 @@ -{ lib, python3, fetchPypi, nixosTests }: +{ + lib, + python3, + fetchPypi, + nixosTests, +}: with python3.pkgs; @@ -12,9 +17,14 @@ buildPythonPackage rec { }; propagatedBuildInputs = [ - django-mailman3 readme-renderer + django-mailman3 + readme-renderer ] ++ readme-renderer.optional-dependencies.md; - nativeCheckInputs = [ beautifulsoup4 vcrpy mock ]; + nativeCheckInputs = [ + beautifulsoup4 + vcrpy + mock + ]; # Tries to connect to database. doCheck = false; diff --git a/pkgs/servers/mail/mailman/web.nix b/pkgs/servers/mail/mailman/web.nix index ae4320fd443a2a..abe62fa2fd7c17 100644 --- a/pkgs/servers/mail/mailman/web.nix +++ b/pkgs/servers/mail/mailman/web.nix @@ -1,6 +1,11 @@ -{ lib, python3, fetchPypi -, sassc, hyperkitty, postorius -, nixosTests +{ + lib, + python3, + fetchPypi, + sassc, + hyperkitty, + postorius, + nixosTests, }: with python3.pkgs; @@ -26,7 +31,11 @@ buildPythonPackage rec { ''; nativeBuildInputs = [ pdm-backend ]; - propagatedBuildInputs = [ hyperkitty postorius whoosh ]; + propagatedBuildInputs = [ + hyperkitty + postorius + whoosh + ]; # Tries to check runtime configuration. doCheck = false; @@ -42,6 +51,9 @@ buildPythonPackage rec { description = "Django project for Mailman 3 web interface"; mainProgram = "mailman-web"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ qyliss m1cr0man ]; + maintainers = with maintainers; [ + qyliss + m1cr0man + ]; }; } diff --git a/pkgs/servers/mail/mailpit/default.nix b/pkgs/servers/mail/mailpit/default.nix index c29baacd447cbf..a7c327f9d2c54a 100644 --- a/pkgs/servers/mail/mailpit/default.nix +++ b/pkgs/servers/mail/mailpit/default.nix @@ -18,7 +18,8 @@ let inherit (source) version - vendorHash; + vendorHash + ; src = fetchFromGitHub { owner = "axllent"; diff --git a/pkgs/servers/mail/nullmailer/default.nix b/pkgs/servers/mail/nullmailer/default.nix index f223f163fdcbff..d91d8f4cb93098 100644 --- a/pkgs/servers/mail/nullmailer/default.nix +++ b/pkgs/servers/mail/nullmailer/default.nix @@ -1,4 +1,10 @@ -{ stdenv, fetchurl, lib, tls ? true, gnutls ? null }: +{ + stdenv, + fetchurl, + lib, + tls ? true, + gnutls ? null, +}: assert tls -> gnutls != null; @@ -46,6 +52,6 @@ stdenv.mkDerivation rec { ''; license = lib.licenses.gpl2Plus; platforms = lib.platforms.all; - maintainers = with lib.maintainers ; [ sargon ]; + maintainers = with lib.maintainers; [ sargon ]; }; } diff --git a/pkgs/servers/mail/opensmtpd/extras.nix b/pkgs/servers/mail/opensmtpd/extras.nix index f179bf96368ff8..0acf74133d9b53 100644 --- a/pkgs/servers/mail/opensmtpd/extras.nix +++ b/pkgs/servers/mail/opensmtpd/extras.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchurl, openssl, libevent, libasr, ncurses, - pkg-config, lua5, perl, libmysqlclient, postgresql, sqlite, hiredis, +{ + lib, + stdenv, + fetchurl, + openssl, + libevent, + libasr, + ncurses, + pkg-config, + lua5, + perl, + libmysqlclient, + postgresql, + sqlite, + hiredis, enableLua ? true, enablePerl ? true, enableMysql ? true, @@ -18,66 +31,84 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl libevent - libasr lua5 perl libmysqlclient postgresql sqlite hiredis ]; + buildInputs = [ + openssl + libevent + libasr + lua5 + perl + libmysqlclient + postgresql + sqlite + hiredis + ]; - configureFlags = [ - "--sysconfdir=/etc" - "--localstatedir=/var" - "--with-privsep-user=smtpd" - "--with-libevent-dir=${libevent.dev}" + configureFlags = + [ + "--sysconfdir=/etc" + "--localstatedir=/var" + "--with-privsep-user=smtpd" + "--with-libevent-dir=${libevent.dev}" - "--with-filter-clamav" - "--with-filter-dkim-signer" - "--with-filter-dnsbl" - "--with-filter-monkey" - "--with-filter-pause" - "--with-filter-regex" - "--with-filter-spamassassin" - "--with-filter-stub" - "--with-filter-trace" - "--with-filter-void" - "--with-queue-null" - "--with-queue-ram" - "--with-queue-stub" - "--with-table-ldap" - "--with-table-socketmap" - "--with-table-passwd" - "--with-table-stub" - "--with-scheduler-ram" - "--with-scheduler-stub" + "--with-filter-clamav" + "--with-filter-dkim-signer" + "--with-filter-dnsbl" + "--with-filter-monkey" + "--with-filter-pause" + "--with-filter-regex" + "--with-filter-spamassassin" + "--with-filter-stub" + "--with-filter-trace" + "--with-filter-void" + "--with-queue-null" + "--with-queue-ram" + "--with-queue-stub" + "--with-table-ldap" + "--with-table-socketmap" + "--with-table-passwd" + "--with-table-stub" + "--with-scheduler-ram" + "--with-scheduler-stub" - ] ++ lib.optionals enableLua [ - "--with-lua=${pkg-config}" - "--with-filter-lua" + ] + ++ lib.optionals enableLua [ + "--with-lua=${pkg-config}" + "--with-filter-lua" - ] ++ lib.optionals enablePerl [ - "--with-perl=${perl}" - "--with-filter-perl" + ] + ++ lib.optionals enablePerl [ + "--with-perl=${perl}" + "--with-filter-perl" - ] ++ lib.optionals enableMysql [ - "--with-table-mysql" + ] + ++ lib.optionals enableMysql [ + "--with-table-mysql" - ] ++ lib.optionals enablePostgres [ - "--with-table-postgres" + ] + ++ lib.optionals enablePostgres [ + "--with-table-postgres" - ] ++ lib.optionals enableSqlite [ - "--with-table-sqlite" + ] + ++ lib.optionals enableSqlite [ + "--with-table-sqlite" - ] ++ lib.optionals enableRedis [ - "--with-table-redis" - ]; + ] + ++ lib.optionals enableRedis [ + "--with-table-redis" + ]; - env.NIX_CFLAGS_COMPILE = lib.optionalString enableRedis - "-I${hiredis}/include/hiredis -lhiredis" - + lib.optionalString enableMysql - " -L${libmysqlclient}/lib/mysql"; + env.NIX_CFLAGS_COMPILE = + lib.optionalString enableRedis "-I${hiredis}/include/hiredis -lhiredis" + + lib.optionalString enableMysql " -L${libmysqlclient}/lib/mysql"; meta = with lib; { homepage = "https://www.opensmtpd.org/"; description = "Extra plugins for the OpenSMTPD mail server"; license = licenses.isc; platforms = platforms.linux; - maintainers = with maintainers; [ gebner ekleog ]; + maintainers = with maintainers; [ + gebner + ekleog + ]; }; } diff --git a/pkgs/servers/mail/opensmtpd/filter-rspamd.nix b/pkgs/servers/mail/opensmtpd/filter-rspamd.nix index b491068d0530bc..0cba39036ffe80 100644 --- a/pkgs/servers/mail/opensmtpd/filter-rspamd.nix +++ b/pkgs/servers/mail/opensmtpd/filter-rspamd.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/servers/mail/postfix/default.nix b/pkgs/servers/mail/postfix/default.nix index 07442ea95a3924..bed6bcd2772087 100644 --- a/pkgs/servers/mail/postfix/default.nix +++ b/pkgs/servers/mail/postfix/default.nix @@ -1,29 +1,71 @@ -{ stdenv, lib, fetchurl, makeWrapper, gnused, db, openssl, cyrus_sasl, libnsl -, coreutils, findutils, gnugrep, gawk, icu, pcre2, m4 -, fetchpatch -, buildPackages, nixosTests -, withLDAP ? true, openldap -, withPgSQL ? false, postgresql -, withMySQL ? false, libmysqlclient -, withSQLite ? false, sqlite +{ + stdenv, + lib, + fetchurl, + makeWrapper, + gnused, + db, + openssl, + cyrus_sasl, + libnsl, + coreutils, + findutils, + gnugrep, + gawk, + icu, + pcre2, + m4, + fetchpatch, + buildPackages, + nixosTests, + withLDAP ? true, + openldap, + withPgSQL ? false, + postgresql, + withMySQL ? false, + libmysqlclient, + withSQLite ? false, + sqlite, }: let - ccargs = lib.concatStringsSep " " ([ - "-DUSE_TLS" "-DUSE_SASL_AUTH" "-DUSE_CYRUS_SASL" "-I${cyrus_sasl.dev}/include/sasl" - "-DHAS_DB_BYPASS_MAKEDEFS_CHECK" - ] ++ lib.optional withPgSQL "-DHAS_PGSQL" - ++ lib.optionals withMySQL [ "-DHAS_MYSQL" "-I${libmysqlclient.dev}/include/mysql" "-L${libmysqlclient}/lib/mysql" ] - ++ lib.optional withSQLite "-DHAS_SQLITE" - ++ lib.optionals withLDAP ["-DHAS_LDAP" "-DUSE_LDAP_SASL"]); - auxlibs = lib.concatStringsSep " " ([ - "-ldb" "-lnsl" "-lresolv" "-lsasl2" "-lcrypto" "-lssl" - ] ++ lib.optional withPgSQL "-lpq" - ++ lib.optional withMySQL "-lmysqlclient" - ++ lib.optional withSQLite "-lsqlite3" - ++ lib.optional withLDAP "-lldap"); - -in stdenv.mkDerivation rec { + ccargs = lib.concatStringsSep " " ( + [ + "-DUSE_TLS" + "-DUSE_SASL_AUTH" + "-DUSE_CYRUS_SASL" + "-I${cyrus_sasl.dev}/include/sasl" + "-DHAS_DB_BYPASS_MAKEDEFS_CHECK" + ] + ++ lib.optional withPgSQL "-DHAS_PGSQL" + ++ lib.optionals withMySQL [ + "-DHAS_MYSQL" + "-I${libmysqlclient.dev}/include/mysql" + "-L${libmysqlclient}/lib/mysql" + ] + ++ lib.optional withSQLite "-DHAS_SQLITE" + ++ lib.optionals withLDAP [ + "-DHAS_LDAP" + "-DUSE_LDAP_SASL" + ] + ); + auxlibs = lib.concatStringsSep " " ( + [ + "-ldb" + "-lnsl" + "-lresolv" + "-lsasl2" + "-lcrypto" + "-lssl" + ] + ++ lib.optional withPgSQL "-lpq" + ++ lib.optional withMySQL "-lmysqlclient" + ++ lib.optional withSQLite "-lsqlite3" + ++ lib.optional withLDAP "-lldap" + ); + +in +stdenv.mkDerivation rec { pname = "postfix"; version = "3.9.1"; @@ -32,8 +74,19 @@ in stdenv.mkDerivation rec { hash = "sha256-xIiUTrA2JXbRj1+MxLmzKjW8s11xuUfarJdkr0dw9kM="; }; - nativeBuildInputs = [ makeWrapper m4 ]; - buildInputs = [ db openssl cyrus_sasl icu libnsl pcre2 ] + nativeBuildInputs = [ + makeWrapper + m4 + ]; + buildInputs = + [ + db + openssl + cyrus_sasl + icu + libnsl + pcre2 + ] ++ lib.optional withPgSQL postgresql ++ lib.optional withMySQL libmysqlclient ++ lib.optional withSQLite sqlite @@ -55,15 +108,17 @@ in stdenv.mkDerivation rec { }) ]; - postPatch = lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' - sed -e 's!bin/postconf!${buildPackages.postfix}/bin/postconf!' -i postfix-install - '' + '' - sed -e '/^PATH=/d' -i postfix-install - sed -e "s|@PACKAGE@|$out|" -i conf/post-install + postPatch = + lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' + sed -e 's!bin/postconf!${buildPackages.postfix}/bin/postconf!' -i postfix-install + '' + + '' + sed -e '/^PATH=/d' -i postfix-install + sed -e "s|@PACKAGE@|$out|" -i conf/post-install - # post-install need skip permissions check/set on all symlinks following to /nix/store - sed -e "s|@NIX_STORE@|$NIX_STORE|" -i conf/post-install - ''; + # post-install need skip permissions check/set on all symlinks following to /nix/store + sed -e "s|@NIX_STORE@|$NIX_STORE|" -i conf/post-install + ''; postConfigure = '' export command_directory=$out/sbin @@ -98,9 +153,23 @@ in stdenv.mkDerivation rec { cp -rv installdir/etc $out sed -e '/^PATH=/d' -i $out/libexec/postfix/post-install wrapProgram $out/libexec/postfix/post-install \ - --prefix PATH ":" ${lib.makeBinPath [ coreutils findutils gnugrep ]} + --prefix PATH ":" ${ + lib.makeBinPath [ + coreutils + findutils + gnugrep + ] + } wrapProgram $out/libexec/postfix/postfix-script \ - --prefix PATH ":" ${lib.makeBinPath [ coreutils findutils gnugrep gawk gnused ]} + --prefix PATH ":" ${ + lib.makeBinPath [ + coreutils + findutils + gnugrep + gawk + gnused + ] + } # Avoid dev-only outputs from being retained in final closure. # `makedefs.out` is a documenttation-only file. It should be safe @@ -118,8 +187,15 @@ in stdenv.mkDerivation rec { homepage = "http://www.postfix.org/"; changelog = "https://www.postfix.org/announcements/postfix-${version}.html"; description = "Fast, easy to administer, and secure mail server"; - license = with licenses; [ ipl10 epl20 ]; + license = with licenses; [ + ipl10 + epl20 + ]; platforms = platforms.linux; - maintainers = with maintainers; [ globin dotlambda lewo ]; + maintainers = with maintainers; [ + globin + dotlambda + lewo + ]; }; } diff --git a/pkgs/servers/mail/postfix/pfixtools.nix b/pkgs/servers/mail/postfix/pfixtools.nix index 03527e1ce2b9d6..1733aadb6ec698 100644 --- a/pkgs/servers/mail/postfix/pfixtools.nix +++ b/pkgs/servers/mail/postfix/pfixtools.nix @@ -1,4 +1,17 @@ -{ stdenv, lib, fetchFromGitHub, git, gperf, pcre, unbound, libev, tokyocabinet, pkg-config, bash, libsrs2 }: +{ + stdenv, + lib, + fetchFromGitHub, + git, + gperf, + pcre, + unbound, + libev, + tokyocabinet, + pkg-config, + bash, + libsrs2, +}: let version = "0.9"; @@ -30,7 +43,16 @@ stdenv.mkDerivation { patches = [ ./0001-Fix-build-with-unbound-1.6.1.patch ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [git gperf pcre unbound libev tokyocabinet bash libsrs2]; + buildInputs = [ + git + gperf + pcre + unbound + libev + tokyocabinet + bash + libsrs2 + ]; postUnpack = '' cp -Rp ${libCommonSrc}/* ${srcRoot}/common; @@ -47,7 +69,10 @@ stdenv.mkDerivation { env.NIX_CFLAGS_COMPILE = "-Wno-error=unused-result -Wno-error=nonnull-compare -Wno-error=format-truncation"; - makeFlags = [ "DESTDIR=$(out)" "prefix=" ]; + makeFlags = [ + "DESTDIR=$(out)" + "prefix=" + ]; meta = { description = "Collection of postfix-related tools"; diff --git a/pkgs/servers/mail/postfix/pflogsumm.nix b/pkgs/servers/mail/postfix/pflogsumm.nix index d70cde6b9da263..bc5624b52e831b 100644 --- a/pkgs/servers/mail/postfix/pflogsumm.nix +++ b/pkgs/servers/mail/postfix/pflogsumm.nix @@ -1,4 +1,8 @@ -{ lib, fetchurl, perlPackages }: +{ + lib, + fetchurl, + perlPackages, +}: perlPackages.buildPerlPackage rec { pname = "pflogsumm"; @@ -9,7 +13,10 @@ perlPackages.buildPerlPackage rec { sha256 = "0hkim9s5f1yg5sfs5048jydhy3sbxafls496wcjk0cggxb113py4"; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; buildInputs = [ perlPackages.DateCalc ]; preConfigure = '' diff --git a/pkgs/servers/mail/public-inbox/default.nix b/pkgs/servers/mail/public-inbox/default.nix index 72caae6a5b05eb..9360f1bef003c7 100644 --- a/pkgs/servers/mail/public-inbox/default.nix +++ b/pkgs/servers/mail/public-inbox/default.nix @@ -1,43 +1,48 @@ -{ stdenv, lib, fetchurl, makeWrapper, nixosTests -, buildPerlPackage -, coreutils -, curl -, git -, gnumake -, highlight -, libgit2 -, libxcrypt -, man -, openssl -, pkg-config -, sqlite -, xapian -, AnyURIEscape -, DBDSQLite -, DBI -, EmailAddressXS -, EmailMIME -, IOSocketSSL -# FIXME: to be packaged -#, IOSocketSocks -, IPCRun -, Inline -, InlineC -, LinuxInotify2 -, MailIMAPClient -# FIXME: to be packaged -#, NetNetrc -# FIXME: to be packaged -#, NetNNTP -, ParseRecDescent -, Plack -, PlackMiddlewareReverseProxy -, PlackTestExternalServer -, SearchXapian -, TestSimple13 -, TimeDate -, URI -, XMLTreePP +{ + stdenv, + lib, + fetchurl, + makeWrapper, + nixosTests, + buildPerlPackage, + coreutils, + curl, + git, + gnumake, + highlight, + libgit2, + libxcrypt, + man, + openssl, + pkg-config, + sqlite, + xapian, + AnyURIEscape, + DBDSQLite, + DBI, + EmailAddressXS, + EmailMIME, + IOSocketSSL, + # FIXME: to be packaged + #, IOSocketSocks + IPCRun, + Inline, + InlineC, + LinuxInotify2, + MailIMAPClient, + # FIXME: to be packaged + #, NetNetrc + # FIXME: to be packaged + #, NetNNTP + ParseRecDescent, + Plack, + PlackMiddlewareReverseProxy, + PlackTestExternalServer, + SearchXapian, + TestSimple13, + TimeDate, + URI, + XMLTreePP, }: let @@ -91,7 +96,11 @@ buildPerlPackage rec { sha256 = "sha256-ENnT2YK7rpODII9TqiEYSCp5mpWOnxskeSuAf8Ilqro="; }; - outputs = [ "out" "devdoc" "sa_config" ]; + outputs = [ + "out" + "devdoc" + "sa_config" + ]; postConfigure = '' substituteInPlace Makefile --replace 'TEST_FILES = t/*.t' \ @@ -127,20 +136,22 @@ buildPerlPackage rec { ]; doCheck = !stdenv.hostPlatform.isDarwin; - nativeCheckInputs = [ - curl - git - openssl - pkg-config - sqlite - xapian - EmailMIME - PlackTestExternalServer - TestSimple13 - XMLTreePP - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - LinuxInotify2 - ]; + nativeCheckInputs = + [ + curl + git + openssl + pkg-config + sqlite + xapian + EmailMIME + PlackTestExternalServer + TestSimple13 + XMLTreePP + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + LinuxInotify2 + ]; preCheck = '' perl certs/create-certs.perl export TEST_LEI_ERR_LOUD=1 @@ -153,13 +164,15 @@ buildPerlPackage rec { for prog in $out/bin/*; do wrapProgram $prog \ --set NIX_CFLAGS_COMPILE_${stdenv.cc.suffixSalt} -I${lib.getDev libxcrypt}/include \ - --prefix PATH : ${lib.makeBinPath [ - git - xapian - /* for InlineC */ - gnumake - stdenv.cc - ]} + --prefix PATH : ${ + lib.makeBinPath [ + git + xapian + # for InlineC + gnumake + stdenv.cc + ] + } done mv sa_config $sa_config @@ -172,7 +185,10 @@ buildPerlPackage rec { meta = with lib; { homepage = "https://public-inbox.org/"; license = licenses.agpl3Plus; - maintainers = with maintainers; [ julm qyliss ]; + maintainers = with maintainers; [ + julm + qyliss + ]; platforms = platforms.all; }; } diff --git a/pkgs/servers/mail/spf-engine/default.nix b/pkgs/servers/mail/spf-engine/default.nix index 326d42d5d78c38..ee5d6d74d1d0ef 100644 --- a/pkgs/servers/mail/spf-engine/default.nix +++ b/pkgs/servers/mail/spf-engine/default.nix @@ -1,4 +1,13 @@ -{ lib, buildPythonApplication, fetchurl, flit-core, pyspf, dnspython, authres, pymilter }: +{ + lib, + buildPythonApplication, + fetchurl, + flit-core, + pyspf, + dnspython, + authres, + pymilter, +}: buildPythonApplication rec { pname = "spf-engine"; @@ -12,7 +21,12 @@ buildPythonApplication rec { nativeBuildInputs = [ flit-core ]; - propagatedBuildInputs = [ pyspf dnspython authres pymilter ]; + propagatedBuildInputs = [ + pyspf + dnspython + authres + pymilter + ]; pythonImportsCheck = [ "spf_engine" diff --git a/pkgs/servers/mail/system-sendmail/default.nix b/pkgs/servers/mail/system-sendmail/default.nix index c3574c8f17fceb..3bef265103eb45 100644 --- a/pkgs/servers/mail/system-sendmail/default.nix +++ b/pkgs/servers/mail/system-sendmail/default.nix @@ -1,19 +1,26 @@ -{ lib, stdenv, writeText, runtimeShell }: +{ + lib, + stdenv, + writeText, + runtimeShell, +}: -let script = writeText "script" '' - #!${runtimeShell} +let + script = writeText "script" '' + #!${runtimeShell} - if command -v sendmail > /dev/null 2>&1 && [ "$(command -v sendmail)" != "{{MYPATH}}" ]; then - exec sendmail "$@" - elif [ -x /run/wrappers/bin/sendmail ]; then - exec /run/wrappers/bin/sendmail "$@" - elif [ -x /run/current-system/sw/bin/sendmail ]; then - exec /run/current-system/sw/bin/sendmail "$@" - else - echo "Unable to find system sendmail." >&2 - exit 1 - fi -''; in + if command -v sendmail > /dev/null 2>&1 && [ "$(command -v sendmail)" != "{{MYPATH}}" ]; then + exec sendmail "$@" + elif [ -x /run/wrappers/bin/sendmail ]; then + exec /run/wrappers/bin/sendmail "$@" + elif [ -x /run/current-system/sw/bin/sendmail ]; then + exec /run/current-system/sw/bin/sendmail "$@" + else + echo "Unable to find system sendmail." >&2 + exit 1 + fi + ''; +in stdenv.mkDerivation { pname = "system-sendmail"; version = "1.0"; diff --git a/pkgs/servers/mastodon/default.nix b/pkgs/servers/mastodon/default.nix index 979dd74635c2d0..6c71ac6e7b4f93 100644 --- a/pkgs/servers/mastodon/default.nix +++ b/pkgs/servers/mastodon/default.nix @@ -1,15 +1,24 @@ -{ lib, stdenv, nodejs-slim, bundlerEnv, nixosTests -, yarn-berry, callPackage, ruby, writeShellScript -, brotli, python3 +{ + lib, + stdenv, + nodejs-slim, + bundlerEnv, + nixosTests, + yarn-berry, + callPackage, + ruby, + writeShellScript, + brotli, + python3, # Allow building a fork or custom version of Mastodon: -, pname ? "mastodon" -, version ? srcOverride.version -, patches ? [] + pname ? "mastodon", + version ? srcOverride.version, + patches ? [ ], # src is a package -, srcOverride ? callPackage ./source.nix { inherit patches; } -, gemset ? ./. + "/gemset.nix" -, yarnHash ? srcOverride.yarnHash + srcOverride ? callPackage ./source.nix { inherit patches; }, + gemset ? ./. + "/gemset.nix", + yarnHash ? srcOverride.yarnHash, }: stdenv.mkDerivation rec { @@ -32,7 +41,14 @@ stdenv.mkDerivation rec { hash = yarnHash; }; - nativeBuildInputs = [ nodejs-slim yarn-berry mastodonGems mastodonGems.wrappedRuby brotli python3 ]; + nativeBuildInputs = [ + nodejs-slim + yarn-berry + mastodonGems + mastodonGems.wrappedRuby + brotli + python3 + ]; RAILS_ENV = "production"; NODE_ENV = "production"; @@ -86,7 +102,10 @@ stdenv.mkDerivation rec { propagatedBuildInputs = [ mastodonGems.wrappedRuby ]; nativeBuildInputs = [ brotli ]; - buildInputs = [ mastodonGems nodejs-slim ]; + buildInputs = [ + mastodonGems + nodejs-slim + ]; buildPhase = '' runHook preBuild @@ -128,21 +147,23 @@ stdenv.mkDerivation rec { runHook postBuild ''; - installPhase = let - run-streaming = writeShellScript "run-streaming.sh" '' - # NixOS helper script to consistently use the same NodeJS version the package was built with. - ${nodejs-slim}/bin/node ./streaming - ''; - in '' - runHook preInstall + installPhase = + let + run-streaming = writeShellScript "run-streaming.sh" '' + # NixOS helper script to consistently use the same NodeJS version the package was built with. + ${nodejs-slim}/bin/node ./streaming + ''; + in + '' + runHook preInstall - mkdir -p $out - mv .{env*,ruby*} $out/ - mv * $out/ - ln -s ${run-streaming} $out/run-streaming.sh + mkdir -p $out + mv .{env*,ruby*} $out/ + mv * $out/ + ln -s ${run-streaming} $out/run-streaming.sh - runHook postInstall - ''; + runHook postInstall + ''; passthru = { tests.mastodon = nixosTests.mastodon; @@ -154,7 +175,16 @@ stdenv.mkDerivation rec { description = "Self-hosted, globally interconnected microblogging software based on ActivityPub"; homepage = "https://joinmastodon.org"; license = licenses.agpl3Plus; - platforms = [ "x86_64-linux" "i686-linux" "aarch64-linux" ]; - maintainers = with maintainers; [ happy-river erictapen izorkin ghuntley ]; + platforms = [ + "x86_64-linux" + "i686-linux" + "aarch64-linux" + ]; + maintainers = with maintainers; [ + happy-river + erictapen + izorkin + ghuntley + ]; }; } diff --git a/pkgs/servers/mastodon/gemset.nix b/pkgs/servers/mastodon/gemset.nix index f5f0ec29087afa..c3a2253b86fb0b 100644 --- a/pkgs/servers/mastodon/gemset.nix +++ b/pkgs/servers/mastodon/gemset.nix @@ -1,3576 +1,4658 @@ { actioncable = { - dependencies = ["actionpack" "activesupport" "nio4r" "websocket-driver" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "nio4r" + "websocket-driver" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1mfb5x6kwxwprprhzj2a1hff7vw37v1wd9hl70nqq23xr82w20wx"; type = "gem"; }; version = "7.1.4.1"; }; actionmailbox = { - dependencies = ["actionpack" "activejob" "activerecord" "activestorage" "activesupport" "mail" "net-imap" "net-pop" "net-smtp"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activejob" + "activerecord" + "activestorage" + "activesupport" + "mail" + "net-imap" + "net-pop" + "net-smtp" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1z95jcq4cmk7zzy4jjgxjbigk0zaxm2gpf8p0s0jn3b5px0k3ljk"; type = "gem"; }; version = "7.1.4.1"; }; actionmailer = { - dependencies = ["actionpack" "actionview" "activejob" "activesupport" "mail" "net-imap" "net-pop" "net-smtp" "rails-dom-testing"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "actionview" + "activejob" + "activesupport" + "mail" + "net-imap" + "net-pop" + "net-smtp" + "rails-dom-testing" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1h39ffp0zs0r46bfm8bbgvc8icwamq4icsf1qn32xskdssnb8xyr"; type = "gem"; }; version = "7.1.4.1"; }; actionpack = { - dependencies = ["actionview" "activesupport" "nokogiri" "racc" "rack" "rack-session" "rack-test" "rails-dom-testing" "rails-html-sanitizer"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionview" + "activesupport" + "nokogiri" + "racc" + "rack" + "rack-session" + "rack-test" + "rails-dom-testing" + "rails-html-sanitizer" + ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1mrdaql56iqnqcg7n3frc0r48bca8b4g9f2ifc69f15dpps2wfsx"; type = "gem"; }; version = "7.1.4.1"; }; actiontext = { - dependencies = ["actionpack" "activerecord" "activestorage" "activesupport" "globalid" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activerecord" + "activestorage" + "activesupport" + "globalid" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "06az0qalnvz0hv1wq8nn5q70gak9r50b6b95avmkz860lhbpx70d"; type = "gem"; }; version = "7.1.4.1"; }; actionview = { - dependencies = ["activesupport" "builder" "erubi" "rails-dom-testing" "rails-html-sanitizer"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "builder" + "erubi" + "rails-dom-testing" + "rails-html-sanitizer" + ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "02zrp7x6k6sgd4rrpsh2b9k2h0qhx538fsb1grsw25ss8d9k2b2j"; type = "gem"; }; version = "7.1.4.1"; }; active_model_serializers = { - dependencies = ["actionpack" "activemodel" "case_transform" "jsonapi-renderer"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activemodel" + "case_transform" + "jsonapi-renderer" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "13n1ipn0dg3k852xhfzdvkr1ljq76xvfnm79qzdix2ishiy1gphl"; type = "gem"; }; version = "0.10.14"; }; activejob = { - dependencies = ["activesupport" "globalid"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "globalid" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1r0i34jrsibwkbg61kjm1xjbc8ppy8r91bnach8rv7jgjrid4dyl"; type = "gem"; }; version = "7.1.4.1"; }; activemodel = { - dependencies = ["activesupport"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "activesupport" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1dpdfa132zsfw5l754p2iwialbscvhp9dblq9fg65ww306s3g0pl"; type = "gem"; }; version = "7.1.4.1"; }; activerecord = { - dependencies = ["activemodel" "activesupport" "timeout"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activemodel" + "activesupport" + "timeout" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1cwx0a7pbl2shm0jc0m7aylacb84j2p4f3h0v7f6aas2b8s6lkf1"; type = "gem"; }; version = "7.1.4.1"; }; activestorage = { - dependencies = ["actionpack" "activejob" "activerecord" "activesupport" "marcel"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activejob" + "activerecord" + "activesupport" + "marcel" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07zw4r8n3ag3d8jfynngpk0cxjwwlh7pxg3hrz1fdww2fnl6nan8"; type = "gem"; }; version = "7.1.4.1"; }; activesupport = { - dependencies = ["base64" "bigdecimal" "concurrent-ruby" "connection_pool" "drb" "i18n" "minitest" "mutex_m" "tzinfo"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "bigdecimal" + "concurrent-ruby" + "connection_pool" + "drb" + "i18n" + "minitest" + "mutex_m" + "tzinfo" + ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0p3167vw7csidyfl731hbp27xaz90w0v31l3fqzrsipci69p7qw0"; type = "gem"; }; version = "7.1.4.1"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "public_suffix" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; aes_key_wrap = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19bn0y70qm6mfj4y1m0j3s8ggh6dvxwrwrj5vfamhdrpddsz8ddr"; type = "gem"; }; version = "1.1.0"; }; android_key_attestation = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02spc1sh7zsljl02v9d5rdb717b628vw2k7jkkplifyjk4db0zj6"; type = "gem"; }; version = "0.3.0"; }; annotate = { - dependencies = ["activerecord" "rake"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activerecord" + "rake" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1lw0fxb5mirsdp3bp20gjyvs7clvi19jbxnrm2ihm20kzfhvlqcs"; type = "gem"; }; version = "3.2.0"; }; ast = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04nc8x27hlzlrr5c2gn7mar4vdr0apw5xg22wp6m8dx3wqr04a0y"; type = "gem"; }; version = "2.4.2"; }; attr_required = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16fbwr6nmsn97n0a6k1nwbpyz08zpinhd6g7196lz1syndbgrszh"; type = "gem"; }; version = "1.0.2"; }; awrence = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gj8f8c54r9cabkm41s59sa1ca5wpbipw7gq3sfl87x9296227fx"; type = "gem"; }; version = "1.2.1"; }; aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gvdg4yx4p9av2glmp7vsxhs0n8fj1ga9kq2xdb8f95j7b04qhzi"; type = "gem"; }; version = "1.3.0"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pm4dxz3w1f5ksiid7bxdaxhz0rklci3zfyb4v1f6j9psa11cwh1"; type = "gem"; }; version = "1.978.0"; }; aws-sdk-core = { - dependencies = ["aws-eventstream" "aws-partitions" "aws-sigv4" "jmespath"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-eventstream" + "aws-partitions" + "aws-sigv4" + "jmespath" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0hm87r5ph1mi7n6b5y17hc54x38insbkgbflr7viqigbwy2slw3v"; type = "gem"; }; version = "3.209.0"; }; aws-sdk-kms = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1acx3bhqkhni3kbl7xnjdgy8raq5y7p0zyniq61bsihzkwcj7imh"; type = "gem"; }; version = "1.94.0"; }; aws-sdk-s3 = { - dependencies = ["aws-sdk-core" "aws-sdk-kms" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sdk-kms" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0zpww3lxpjg8smmznz2nbx5hrpnkzflbasllxjwprkqr56rrrjap"; type = "gem"; }; version = "1.166.0"; }; aws-sigv4 = { - dependencies = ["aws-eventstream"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-eventstream" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "176zh13m1vhwgys0drlqiw79ljmmx84vva036shsb7rzr4yi36qm"; type = "gem"; }; version = "1.10.0"; }; azure-storage-blob = { - dependencies = ["azure-storage-common" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "azure-storage-common" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0qq3knsy7nj7a0r8m19spg2bgzns9b3j5vjbs9mpg49whhc63dv1"; type = "gem"; }; version = "2.0.3"; }; azure-storage-common = { - dependencies = ["faraday" "faraday_middleware" "net-http-persistent" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "faraday_middleware" + "net-http-persistent" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0swmsvvpmy8cdcl305p3dl2pi7m3dqjd7zywfcxmhsz0n2m4v3v0"; type = "gem"; }; version = "2.0.4"; }; base64 = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bcp47_spec = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "043qld01c163yc7fxlar3046dac2833rlcg44jbbs9n1jvgjxmiz"; type = "gem"; }; version = "0.2.1"; }; bcrypt = { - groups = ["default" "pam_authentication"]; - platforms = []; + groups = [ + "default" + "pam_authentication" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16a0g2q40biv93i1hch3gw8rbmhp77qnnifj1k0a6m7dng3zh444"; type = "gem"; }; version = "3.1.20"; }; better_errors = { - dependencies = ["erubi" "rack" "rouge"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "erubi" + "rack" + "rouge" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0wqazisnn6hn1wsza412xribpw5wzx6b5z5p4mcpfgizr6xg367p"; type = "gem"; }; version = "2.10.1"; }; bigdecimal = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; bindata = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08r67nglsqnxrbn803szf5bdnqhchhq8kf2by94f37fcl65wpp19"; type = "gem"; }; version = "2.5.0"; }; binding_of_caller = { - dependencies = ["debug_inspector"]; - groups = ["development"]; - platforms = []; + dependencies = [ "debug_inspector" ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16mjj15ks5ws53v2y31hxcmf46d0qjdvdaadpk7xsij2zymh4a9b"; type = "gem"; }; version = "1.0.1"; }; blurhash = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wni86h2mlb7sj51nq3iwsvkrzlaggls9xlf4p9dzr1ns79dphca"; type = "gem"; }; version = "0.1.8"; }; bootsnap = { - dependencies = ["msgpack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "msgpack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mdgj9yw1hmx3xh2qxyjc31y8igmxzd9h0c245ay2zkz76pl4k5c"; type = "gem"; }; version = "1.18.4"; }; brakeman = { - dependencies = ["racc"]; - groups = ["development"]; - platforms = []; + dependencies = [ "racc" ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "078syvjnnkbair5ffyvchxj9yd2c8215c1271kfh1gqsmaf70bl6"; type = "gem"; }; version = "6.2.1"; }; browser = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0g4bcpax07kqqr9cp7cjc7i0pcij4nqpn1rdsg2wdwhzf00m6x32"; type = "gem"; }; version = "5.3.1"; }; brpoplpush-redis_script = { - dependencies = ["concurrent-ruby" "redis"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "redis" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1nd5zj5yqmhv9lrsqz8s2dqq28v4ywy95qrw7nzhhf89dl4dq49l"; type = "gem"; }; version = "0.1.3"; }; builder = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0pw3r2lyagsxkm71bf44v5b74f7l9r7di22brbyji9fwz791hya9"; type = "gem"; }; version = "3.3.0"; }; bundler-audit = { - dependencies = ["thor"]; - groups = ["development"]; - platforms = []; + dependencies = [ "thor" ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j0h5cgnzk0ms17ssjkzfzwz65ggrs3lsp53a1j46p4616m1s1bk"; type = "gem"; }; version = "0.9.2"; }; capybara = { - dependencies = ["addressable" "matrix" "mini_mime" "nokogiri" "rack" "rack-test" "regexp_parser" "xpath"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "matrix" + "mini_mime" + "nokogiri" + "rack" + "rack-test" + "regexp_parser" + "xpath" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vxfah83j6zpw3v5hic0j70h519nvmix2hbszmjwm8cfawhagns2"; type = "gem"; }; version = "3.40.0"; }; case_transform = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fzyws6spn5arqf6q604dh9mrj84a36k5hsc8z7jgcpfvhc49bg2"; type = "gem"; }; version = "0.2"; }; cbor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dsf9gjc2cj79vrnz2vgq573biqjw7ad4b0idm05xg6rb3y9gq4y"; type = "gem"; }; version = "0.5.9.8"; }; charlock_holmes = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c1dws56r7p8y363dhyikg7205z59a3bn4amnv2y488rrq8qm7ml"; type = "gem"; }; version = "0.7.9"; }; chewy = { - dependencies = ["activesupport" "elasticsearch" "elasticsearch-dsl"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "elasticsearch" + "elasticsearch-dsl" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0kgqj7hcs09ln7i1rds1xify08rzjk02ryzvjdvnllg1fkh3vm2b"; type = "gem"; }; version = "7.6.0"; }; childprocess = { - dependencies = ["logger"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "logger" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1v5nalaarxnfdm6rxb7q6fmc6nx097jd630ax6h9ch7xw95li3cs"; type = "gem"; }; version = "5.1.0"; }; chunky_png = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znw5x86hmm9vfhidwdsijz8m38pqgmv98l9ryilvky0aldv7mc9"; type = "gem"; }; version = "1.4.0"; }; climate_control = { - groups = ["test"]; - platforms = []; + groups = [ "test" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "198aswdyqlvcw9jkd95b7b8dp3fg0wx89kd1dx9wia1z36b1icin"; type = "gem"; }; version = "1.2.0"; }; cocoon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "038z97pkhvsqbh6cmyyzj58ya968p24k7r0f0rx7sa2kjvk193yh"; type = "gem"; }; version = "1.2.15"; }; color_diff = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01dpvqlzybpb3pkcwd9ik5sbjw283618ywvdphxslhiy8ps3kp4r"; type = "gem"; }; version = "0.1"; }; concurrent-ruby = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; connection_pool = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; cose = { - dependencies = ["cbor" "openssl-signature_algorithm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "cbor" + "openssl-signature_algorithm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1rbdzl9n8ppyp38y75hw06s17kp922ybj6jfvhz52p83dg6xpm6m"; type = "gem"; }; version = "1.3.1"; }; crack = { - dependencies = ["bigdecimal" "rexml"]; - groups = ["default" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bigdecimal" + "rexml" + ]; + groups = [ + "default" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0jaa7is4fw1cxigm8vlyhg05bw4nqy4f91zjqxk7pp4c8bdyyfn8"; type = "gem"; }; version = "1.0.0"; }; crass = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0pfl5c0pyqaparxaqxi6s4gfl21bdldwiawrc0aknyvflli60lfw"; type = "gem"; }; version = "1.0.6"; }; css_parser = { - dependencies = ["addressable"]; - groups = ["default"]; - platforms = []; + dependencies = [ "addressable" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xs3d0ihwg1z4h28d51hb07k926d1rlwy6c2c9ygbicg76srk0qa"; type = "gem"; }; version = "1.19.0"; }; csv = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zfn40dvgjk1xv1z8l11hr9jfg3jncwsc9yhzsz4l4rivkpivg8b"; type = "gem"; }; version = "3.3.0"; }; database_cleaner-active_record = { - dependencies = ["activerecord" "database_cleaner-core"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activerecord" + "database_cleaner-core" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1iz1hv2b1z7509dxvxdwzay1hhs24glxls5ldbyh688zxkcdca1j"; type = "gem"; }; version = "2.2.0"; }; database_cleaner-core = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0v44bn386ipjjh4m2kl53dal8g4d41xajn2jggnmjbhn6965fil6"; type = "gem"; }; version = "2.0.1"; }; date = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "149jknsq999gnhy865n33fkk22s0r447k76x9pmcnnwldfv2q7wp"; type = "gem"; }; version = "3.3.4"; }; debug = { - dependencies = ["irb" "reline"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "irb" + "reline" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1z77qyzcmvz3ciny6cb24s79a243jqkybqk30b310yichp02dq28"; type = "gem"; }; version = "1.9.2"; }; debug_inspector = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18k8x9viqlkh7dbmjzh8crbjy8w480arpa766cw1dnn3xcpa1pwv"; type = "gem"; }; version = "1.2.0"; }; devise = { - dependencies = ["bcrypt" "orm_adapter" "railties" "responders" "warden"]; - groups = ["default" "pam_authentication"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bcrypt" + "orm_adapter" + "railties" + "responders" + "warden" + ]; + groups = [ + "default" + "pam_authentication" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1y57fpcvy1kjd4nb7zk7mvzq62wqcpfynrgblj558k3hbvz4404j"; type = "gem"; }; version = "4.9.4"; }; devise-two-factor = { - dependencies = ["activesupport" "devise" "railties" "rotp"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "devise" + "railties" + "rotp" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yx6ym8a9szwnq9yziljidqjn6gf99blvz1yib9qdd0qcg5x5hp8"; type = "gem"; }; version = "6.0.0"; }; devise_pam_authenticatable2 = { - dependencies = ["devise" "rpam2"]; - groups = ["pam_authentication"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "devise" + "rpam2" + ]; + groups = [ "pam_authentication" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "13ipl52pkhc6vxp8ca31viwv01237bi2bfk3b1fixq1x46nf87p2"; type = "gem"; }; version = "9.2.0"; }; diff-lcs = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1znxccz83m4xgpd239nyqxlifdb7m8rlfayk6s259186nkgj6ci7"; type = "gem"; }; version = "1.5.1"; }; discard = { - dependencies = ["activerecord"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activerecord" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rysimck60hkj1japwb2np75kaf4jq8jvfzijh2izhadrabqj8am"; type = "gem"; }; version = "1.3.0"; }; docile = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07pj4z3h8wk4fgdn6s62vw1lwvhj0ac0x10vfbdkr9xzk7krn5cn"; type = "gem"; }; version = "1.4.1"; }; domain_name = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cyr2xm576gqhqicsyqnhanni47408w2pgvrfi8pd13h2li3nsaz"; type = "gem"; }; version = "0.6.20240107"; }; doorkeeper = { - dependencies = ["railties"]; - groups = ["default"]; - platforms = []; + dependencies = [ "railties" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a6nbc12nfz355am2vwm1ql2p8zck7mr941glghmnl32djaga24b"; type = "gem"; }; version = "5.7.1"; }; dotenv = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0aanng90ad6vg9sm3qlq1223k456qw2xli9kcx13a3ga33kh5ibd"; type = "gem"; }; version = "3.1.4"; }; drb = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0h5kbj9hvg5hb3c7l425zpds0vb42phvln2knab8nmazg2zp5m79"; type = "gem"; }; version = "2.2.1"; }; elasticsearch = { - dependencies = ["elasticsearch-api" "elasticsearch-transport"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "elasticsearch-api" + "elasticsearch-transport" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "11pw5x7kg6f6m8rqy2kpbzdlnvijjpmbqkj2gz8237wkbl40y27d"; type = "gem"; }; version = "7.17.11"; }; elasticsearch-api = { - dependencies = ["multi_json"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multi_json" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01wi43a3zylrq2vca08vir5va142g5m3jcsak3rprjck8jvggn7y"; type = "gem"; }; version = "7.17.11"; }; elasticsearch-dsl = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "174m3fwm3mawbkjg2xbmqvljq7ava4s95m8vpg5khcvfj506wxfk"; type = "gem"; }; version = "0.1.10"; }; elasticsearch-transport = { - dependencies = ["base64" "faraday" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "faraday" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00qgyyvjyyv7z22qjd408pby1h7902gdwkh8h3z3jk2y57amg06i"; type = "gem"; }; version = "7.17.11"; }; email_spec = { - dependencies = ["htmlentities" "launchy" "mail"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "htmlentities" + "launchy" + "mail" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "049dhlyy2hcksp1wj9mx2fngk5limkm3afxysnizg1hi2dxbw8yz"; type = "gem"; }; version = "2.3.0"; }; erubi = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0qnd6ff4az22ysnmni3730c41b979xinilahzg86bn7gv93ip9pw"; type = "gem"; }; version = "1.13.0"; }; et-orbi = { - dependencies = ["tzinfo"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tzinfo" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0r6zylqjfv0xhdxvldr0kgmnglm57nm506pcm6085f0xqa68cvnj"; type = "gem"; }; version = "1.2.11"; }; excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ala6123d3cv965ss48iyi0q4hcbzrznfwv2f1mr91sy98cigq4h"; type = "gem"; }; version = "0.111.0"; }; fabrication = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1al5iv3as21l5clci0b5cg27z136pan7gkj7plp4l0w83c6z2y9c"; type = "gem"; }; version = "2.31.0"; }; faker = { - dependencies = ["i18n"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "i18n" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1xj0xx2snnxzjipxpxwiki7053441jkdg10h0rmjiri040s5lssi"; type = "gem"; }; version = "3.4.2"; }; faraday = { - dependencies = ["faraday-em_http" "faraday-em_synchrony" "faraday-excon" "faraday-httpclient" "faraday-multipart" "faraday-net_http" "faraday-net_http_persistent" "faraday-patron" "faraday-rack" "faraday-retry" "ruby2_keywords"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-em_http" + "faraday-em_synchrony" + "faraday-excon" + "faraday-httpclient" + "faraday-multipart" + "faraday-net_http" + "faraday-net_http_persistent" + "faraday-patron" + "faraday-rack" + "faraday-retry" + "ruby2_keywords" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1c760q0ks4vj4wmaa7nh1dgvgqiwaw0mjr7v8cymy7i3ffgjxx90"; type = "gem"; }; version = "1.10.3"; }; faraday-em_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12cnqpbak4vhikrh2cdn94assh3yxza8rq2p9w2j34bqg5q4qgbs"; type = "gem"; }; version = "1.0.0"; }; faraday-em_synchrony = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vgrbhkp83sngv6k4mii9f2s9v5lmp693hylfxp2ssfc60fas3a6"; type = "gem"; }; version = "1.0.0"; }; faraday-excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h09wkb0k0bhm6dqsd47ac601qiaah8qdzjh8gvxfd376x1chmdh"; type = "gem"; }; version = "1.1.0"; }; faraday-httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fyk0jd3ks7fdn8nv3spnwjpzx2lmxmg2gh4inz3by1zjzqg33sc"; type = "gem"; }; version = "1.0.1"; }; faraday-multipart = { - dependencies = ["multipart-post"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multipart-post" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09871c4hd7s5ws1wl4gs7js1k2wlby6v947m2bbzg43pnld044lh"; type = "gem"; }; version = "1.0.4"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10n6wikd442mfm15hd6gzm0qb527161w1wwch4h5m4iclkz2x6b3"; type = "gem"; }; version = "1.0.2"; }; faraday-net_http_persistent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dc36ih95qw3rlccffcb0vgxjhmipsvxhn6cw71l7ffs0f7vq30b"; type = "gem"; }; version = "1.2.0"; }; faraday-patron = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19wgsgfq0xkski1g7m96snv39la3zxz6x7nbdgiwhg5v82rxfb6w"; type = "gem"; }; version = "1.0.0"; }; faraday-rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h184g4vqql5jv9s9im6igy00jp6mrah2h14py6mpf9bkabfqq7g"; type = "gem"; }; version = "1.0.0"; }; faraday-retry = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "153i967yrwnswqgvnnajgwp981k9p50ys1h80yz3q94rygs59ldd"; type = "gem"; }; version = "1.0.3"; }; faraday_middleware = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bw8mfh4yin2xk7138rg3fhb2p5g2dlmdma88k82psah9mbmvlfy"; type = "gem"; }; version = "1.2.0"; }; fast_blank = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1shpmamyzyhyxmv95r96ja5rylzaw60r19647d0fdm7y2h2c77r6"; type = "gem"; }; version = "1.0.1"; }; fastimage = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sfc7svf7h1ja6zmsq9f3ps6pg0q4hymphh6rk7ipmp7ygqjkii3"; type = "gem"; }; version = "2.3.1"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yvii03hcgqj30maavddqamqy50h7y6xcn2wcyq72wn823zl4ckd"; type = "gem"; }; version = "1.16.3"; }; ffi-compiler = { - dependencies = ["ffi" "rake"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ffi" + "rake" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1844j58cdg2q6g0rqfwg4rrambnhf059h4yg9rfmrbrcs60kskx9"; type = "gem"; }; version = "1.3.2"; }; flatware = { - dependencies = ["drb" "thor"]; - groups = ["default" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "drb" + "thor" + ]; + groups = [ + "default" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "13wcwdpdx1asjxvqpyxwlcazzsjisls28jjn28d9cqw9zwszcm1p"; type = "gem"; }; version = "2.3.3"; }; flatware-rspec = { - dependencies = ["flatware" "rspec"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "flatware" + "rspec" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0dgl20mi9a5iwcy6v9jq148ljy9rrvyjhp1rpd1sgadfw6kxzbhc"; type = "gem"; }; version = "2.3.3"; }; fog-core = { - dependencies = ["builder" "excon" "formatador" "mime-types"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "builder" + "excon" + "formatador" + "mime-types" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vf21i2qpl1hagapds0qjlfl6gsyrbssifn2br2ifn3fg9j80yxl"; type = "gem"; }; version = "2.5.0"; }; fog-json = { - dependencies = ["fog-core" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "fog-core" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zj8llzc119zafbmfa4ai3z5s7c4vp9akfs0f9l2piyvcarmlkyx"; type = "gem"; }; version = "1.2.0"; }; fog-openstack = { - dependencies = ["fog-core" "fog-json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "fog-core" + "fog-json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1z7k3al9bb5ypzkrvi5szpfyi8sksggq68fwxrxywq6rky5lvhdq"; type = "gem"; }; version = "1.1.3"; }; formatador = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l06bv4avphbdmr1y4g0rqlczr38k6r65b3zghrbj2ynyhm3xqjl"; type = "gem"; }; version = "1.1.0"; }; fugit = { - dependencies = ["et-orbi" "raabro"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "et-orbi" + "raabro" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0s4qhq3mjl0gak5wl20w9d5jhq069mk1393dkj76s8i2pvkqb578"; type = "gem"; }; version = "1.11.1"; }; globalid = { - dependencies = ["activesupport"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "activesupport" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1sbw6b66r7cwdx3jhs46s4lr991969hvigkjpbdl7y3i31qpdgvh"; type = "gem"; }; version = "1.2.1"; }; google-protobuf = { - groups = ["default" "opentelemetry"]; - platforms = []; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fanhdf3vzghma51w1hqpp8s585mwzxgqkwvxj5is4q9j0pgwcs3"; type = "gem"; }; version = "3.25.5"; }; googleapis-common-protos-types = { - dependencies = ["google-protobuf"]; - groups = ["default" "opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "google-protobuf" ]; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0sqmmfdxjp3fy7hzvl35bnd0yb0ds9030np5jqh338qz4w661cap"; type = "gem"; }; version = "1.15.0"; }; haml = { - dependencies = ["temple" "thor" "tilt"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "temple" + "thor" + "tilt" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15yxph91zswbnfy7szpdcfbdfqqn595ff290hm4f6fcnhryvhvlf"; type = "gem"; }; version = "6.3.0"; }; haml-rails = { - dependencies = ["actionpack" "activesupport" "haml" "railties"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "haml" + "railties" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1sjrdwc4azzfpsp2xk0365z031482gcrs0c54d5wx0igkqca0fr7"; type = "gem"; }; version = "2.1.0"; }; haml_lint = { - dependencies = ["haml" "parallel" "rainbow" "rubocop" "sysexits"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "haml" + "parallel" + "rainbow" + "rubocop" + "sysexits" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1mf24djxk6968n0ypwbib790nzijcf03m4kw0dnks8csfxj6hy9g"; type = "gem"; }; version = "0.58.0"; }; hashdiff = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0slky0n6n12gjgimzdbdigpwyg5wgq8fysjwkzzfw33ff8b675n7"; type = "gem"; }; version = "1.1.1"; }; hashie = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nh3arcrbz1rc1cr59qm53sdhqm137b258y8rcb4cvd3y98lwv4x"; type = "gem"; }; version = "5.0.0"; }; hcaptcha = { - dependencies = ["json"]; - groups = ["default"]; - platforms = []; + dependencies = [ "json" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fh6391zlv2ikvzqj2gymb70k1avk1j9da8bzgw0scsz2wqq98m2"; type = "gem"; }; version = "7.1.0"; }; highline = { - dependencies = ["reline"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "reline" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1q0f7izfi542sp93gl276spm0xyws1kpqxm0alrwwmz06mz4i0ks"; type = "gem"; }; version = "3.1.1"; }; hiredis = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04jj8k7lxqxw24sp0jiravigdkgsyrpprxpxm71ba93x1wr2w1bz"; type = "gem"; }; version = "0.6.3"; }; hkdf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04fixg0a51n4vy0j6c1hvisa2yl33m3jrrpxpb5sq6j511vjriil"; type = "gem"; }; version = "0.3.0"; }; htmlentities = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nkklqsn8ir8wizzlakncfv42i32wc0w9hxp00hvdlgjr7376nhj"; type = "gem"; }; version = "4.3.4"; }; http = { - dependencies = ["addressable" "base64" "http-cookie" "http-form_data" "llhttp-ffi"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "base64" + "http-cookie" + "http-form_data" + "llhttp-ffi" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05b1khh7wxga9jviy9yi8z1nckxbm3svlzv40y0zvq3nag3d77mr"; type = "gem"; }; version = "5.2.0"; }; http-cookie = { - dependencies = ["domain_name"]; - groups = ["default"]; - platforms = []; + dependencies = [ "domain_name" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13rilvlv8kwbzqfb644qp6hrbsj82cbqmnzcvqip1p6vqx36sxbk"; type = "gem"; }; version = "1.0.5"; }; http-form_data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wx591jdhy84901pklh1n9sgh74gnvq1qyqxwchni1yrc49ynknc"; type = "gem"; }; version = "2.3.0"; }; http_accept_language = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0d0nlfz9vm4jr1l6q0chx4rp2hrnrfbx3gadc1dz930lbbaz0hq0"; type = "gem"; }; version = "2.1.1"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; httplog = { - dependencies = ["rack" "rainbow"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rack" + "rainbow" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "098n4dfmiydbm9if52h17kxglbli9gihjgzhcghv274ni2c9ab49"; type = "gem"; }; version = "1.7.0"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "concurrent-ruby" ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k31wcgnvcvd14snz0pfqj976zv6drfsnq6x8acz10fiyms9l8nw"; type = "gem"; }; version = "1.14.6"; }; i18n-tasks = { - dependencies = ["activesupport" "ast" "erubi" "highline" "i18n" "parser" "rails-i18n" "rainbow" "terminal-table"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "ast" + "erubi" + "highline" + "i18n" + "parser" + "rails-i18n" + "rainbow" + "terminal-table" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1v03380ffwwa84xzsc6dhkc57cs156qx5aij4bfdcs1j5bpxmn1s"; type = "gem"; }; version = "1.0.14"; }; idn-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dy04jx3n1ddz744b80mg7hp87miysnjp0h21lqr43hpmhdglxih"; type = "gem"; }; version = "0.1.5"; }; inline_svg = { - dependencies = ["activesupport" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "03x1z55sh7cpb63g46cbd6135jmp13idcgqzqsnzinbg4cs2jrav"; type = "gem"; }; version = "1.10.0"; }; io-console = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08d2lx42pa8jjav0lcjbzfzmw61b8imxr9041pva8xzqabrczp7h"; type = "gem"; }; version = "0.7.2"; }; irb = { - dependencies = ["rdoc" "reline"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rdoc" + "reline" + ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1y40dv3caswr81dlsyln6vnmmpzf5jcal2rqjbsglvnkb0xh0xar"; type = "gem"; }; version = "1.14.1"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cdw9vw2qly7q7r41s7phnac264rbsdqgj4l0h4nqgbjb157g393"; type = "gem"; }; version = "1.6.2"; }; json = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b4qsi8gay7ncmigr0pnbxyb17y3h8kavdyhsh7nrlqwr35vb60q"; type = "gem"; }; version = "2.7.2"; }; json-canonicalization = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0illsmkly0hhi24lm1l6jjjdr6jykvydkwi1cxf4ad3mra68m16l"; type = "gem"; }; version = "1.0.0"; }; json-jwt = { - dependencies = ["activesupport" "aes_key_wrap" "bindata" "httpclient"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "aes_key_wrap" + "bindata" + "httpclient" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "13xhvkh2fxydcf466az172nwfykzppm3g9ckp8mafsib45w77clj"; type = "gem"; }; version = "1.15.3.1"; }; json-ld = { - dependencies = ["htmlentities" "json-canonicalization" "link_header" "multi_json" "rack" "rdf" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "htmlentities" + "json-canonicalization" + "link_header" + "multi_json" + "rack" + "rdf" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "09xbw6kc95qgmqcfjp0jjw8dnfm28lw9b5lf8bdh3p2vpy9ihlxr"; type = "gem"; }; version = "3.3.2"; }; json-ld-preloaded = { - dependencies = ["json-ld" "rdf"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "json-ld" + "rdf" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1f28ipp845xmqkgd0c22lw5fpv4fiama4ms3z1z5p0kbvi22f2c1"; type = "gem"; }; version = "3.3.0"; }; json-schema = { - dependencies = ["addressable"]; - groups = ["test"]; - platforms = []; + dependencies = [ "addressable" ]; + groups = [ "test" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yn0k02pdb7ds1fszwadxqdsjbkm7xjkfhwpzy7iqij47g0kwv7g"; type = "gem"; }; version = "5.0.0"; }; jsonapi-renderer = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ys4drd0k9rw5ixf8n8fx8v0pjh792w4myh0cpdspd317l1lpi5m"; type = "gem"; }; version = "0.2.2"; }; jwt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16z11alz13vfc4zs5l3fk6n51n2jw9lskvc4h4prnww0y797qd87"; type = "gem"; }; version = "2.7.1"; }; kaminari = { - dependencies = ["activesupport" "kaminari-actionview" "kaminari-activerecord" "kaminari-core"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "kaminari-actionview" + "kaminari-activerecord" + "kaminari-core" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gia8irryvfhcr6bsr64kpisbgdbqjsqfgrk12a11incmpwny1y4"; type = "gem"; }; version = "1.2.2"; }; kaminari-actionview = { - dependencies = ["actionview" "kaminari-core"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionview" + "kaminari-core" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "02f9ghl3a9b5q7l079d3yzmqjwkr4jigi7sldbps992rigygcc0k"; type = "gem"; }; version = "1.2.2"; }; kaminari-activerecord = { - dependencies = ["activerecord" "kaminari-core"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activerecord" + "kaminari-core" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0c148z97s1cqivzbwrak149z7kl1rdmj7dxk6rpkasimmdxsdlqd"; type = "gem"; }; version = "1.2.2"; }; kaminari-core = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zw3pg6kj39y7jxakbx7if59pl28lhk98fx71ks5lr3hfgn6zliv"; type = "gem"; }; version = "1.2.2"; }; kt-paperclip = { - dependencies = ["activemodel" "activesupport" "marcel" "mime-types" "terrapin"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activemodel" + "activesupport" + "marcel" + "mime-types" + "terrapin" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1j8z0757rb4kly4ghdzd6ihch6x5i0d53r543x2y9xa8cyrj7c4m"; type = "gem"; }; version = "7.2.2"; }; language_server-protocol = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gvb1j8xsqxms9mww01rmdl78zkd72zgxaap56bhv8j45z05hp1x"; type = "gem"; }; version = "3.17.0.3"; }; launchy = { - dependencies = ["addressable" "childprocess"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "childprocess" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0b3zi9ydbibyyrrkr6l8mcs6l7yam18a4wg22ivgaz0rl2yn1ymp"; type = "gem"; }; version = "3.0.1"; }; letter_opener = { - dependencies = ["launchy"]; - groups = ["development"]; - platforms = []; + dependencies = [ "launchy" ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cnv3ggnzyagl50vzs1693aacv08bhwlprcvjp8jcg2w7cp3zwrg"; type = "gem"; }; version = "1.10.0"; }; letter_opener_web = { - dependencies = ["actionmailer" "letter_opener" "railties" "rexml"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionmailer" + "letter_opener" + "railties" + "rexml" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0q4qfi5wnn5bv93zjf10agmzap3sn7gkfmdbryz296wb1vz1wf9z"; type = "gem"; }; version = "3.0.0"; }; link_header = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yamrdq4rywmnpdhbygnkkl9fdy249fg5r851nrkkxr97gj5rihm"; type = "gem"; }; version = "0.0.8"; }; llhttp-ffi = { - dependencies = ["ffi-compiler" "rake"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ffi-compiler" + "rake" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yph78m8w8l6i9833fc7shy5krk4mnqjc7ys0bg9kgxw8jnl0vs9"; type = "gem"; }; version = "0.5.0"; }; logger = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; lograge = { - dependencies = ["actionpack" "activesupport" "railties" "request_store"]; - groups = ["production"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "railties" + "request_store" + ]; + groups = [ "production" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1qcsvh9k4c0cp6agqm9a8m4x2gg7vifryqr7yxkg2x9ph9silds2"; type = "gem"; }; version = "0.14.0"; }; loofah = { - dependencies = ["crass" "nokogiri"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "crass" + "nokogiri" + ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zkjqf37v2d7s11176cb35cl83wls5gm3adnfkn2zcc61h3nxmqh"; type = "gem"; }; version = "2.22.0"; }; mail = { - dependencies = ["mini_mime" "net-imap" "net-pop" "net-smtp"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_mime" + "net-imap" + "net-pop" + "net-smtp" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1bf9pysw1jfgynv692hhaycfxa8ckay1gjw5hz3madrbrynryfzc"; type = "gem"; }; version = "2.8.1"; }; marcel = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "190n2mk8m1l708kr88fh6mip9sdsh339d2s6sgrik3sbnvz4jmhd"; type = "gem"; }; version = "1.0.4"; }; mario-redis-lock = { - dependencies = ["redis"]; - groups = ["default"]; - platforms = []; + dependencies = [ "redis" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1v9wdjcjqzpns2migxp4a5b4w82mipi0fwihbqz3q2qj2qm7wc17"; type = "gem"; }; version = "1.2.1"; }; matrix = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h2cgkpzkh3dd0flnnwfq6f3nl2b1zff9lvqz8xs853ssv5kq23i"; type = "gem"; }; version = "0.4.2"; }; md-paperclip-azure = { - dependencies = ["addressable" "azure-storage-blob" "hashie"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "azure-storage-blob" + "hashie" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1hb1a06x3i8zrhl715jf46ha8r4iy0srcpdhnmp9l14qnnhzn0l5"; type = "gem"; }; version = "2.2.0"; }; memory_profiler = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1y58ba08n4lx123c0hjcc752fc4x802mjy39qj1hq50ak3vpv8br"; type = "gem"; }; version = "1.1.0"; }; mime-types = { - dependencies = ["mime-types-data"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mime-types-data" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1r64z0m5zrn4k37wabfnv43wa6yivgdfk6cf2rpmmirlz889yaf1"; type = "gem"; }; version = "3.5.2"; }; mime-types-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vdgz66z8kgw9xrwvrzrcjb5dary9k9hwm0pkk5fq6f5h6i73zds"; type = "gem"; }; version = "3.2024.0820"; }; mini_mime = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vycif7pjzkr29mfk4dlqv3disc5dn0va04lkwajlpr1wkibg0c6"; type = "gem"; }; version = "1.1.5"; }; mini_portile2 = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1q1f2sdw3y3y9mnym9dhjgsjr72sq975cfg5c4yx7gwv8nmzbvhk"; type = "gem"; }; version = "2.8.7"; }; minitest = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1n1akmc6bibkbxkzm1p1wmfb4n9vv397knkgz0ffykb3h1d7kdix"; type = "gem"; }; version = "5.25.1"; }; msgpack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a5adcb7bwan09mqhj3wi9ib52hmdzmqg7q08pggn3adibyn5asr"; type = "gem"; }; version = "1.7.2"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a5lrlvmg2kb2dhw3lxcsv6x276bwgsxpnka1752082miqxd0wlq"; type = "gem"; }; version = "2.4.1"; }; mutex_m = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ma093ayps1m92q845hmpk0dmadicvifkbf05rpq9pifhin0rvxn"; type = "gem"; }; version = "0.2.0"; }; net-http = { - dependencies = ["uri"]; - groups = ["default"]; - platforms = []; + dependencies = [ "uri" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10n2n9aq00ih8v881af88l1zyrqgs5cl3njdw8argjwbl5ggqvm9"; type = "gem"; }; version = "0.4.1"; }; net-http-persistent = { - dependencies = ["connection_pool"]; - groups = ["default"]; - platforms = []; + dependencies = [ "connection_pool" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0i1as2lgnw7b4jid0gw5glv5hnxz36nmfsbr9rmxbcap72ijgy03"; type = "gem"; }; version = "4.0.2"; }; net-imap = { - dependencies = ["date" "net-protocol"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "date" + "net-protocol" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gdmhc6nh8cdq2hdlqyrmnl2pdmvab9j7s6fpfvq5kyga0fi4s74"; type = "gem"; }; version = "0.4.15"; }; net-ldap = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0g9gz39bs2iy4ky4fhjphimqd9m9wdsaz50anxgwg3yjrff3famy"; type = "gem"; }; version = "0.19.0"; }; net-pop = { - dependencies = ["net-protocol"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "net-protocol" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1wyz41jd4zpjn0v1xsf9j778qx1vfrl24yc20cpmph8k42c4x2w4"; type = "gem"; }; version = "0.1.2"; }; net-protocol = { - dependencies = ["timeout"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "timeout" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1a32l4x73hz200cm587bc29q8q9az278syw3x6fkc9d1lv5y0wxa"; type = "gem"; }; version = "0.2.2"; }; net-smtp = { - dependencies = ["net-protocol"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "net-protocol" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0amlhz8fhnjfmsiqcjajip57ici2xhw089x7zqyhpk51drg43h2z"; type = "gem"; }; version = "0.5.0"; }; nio4r = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "017nbw87dpr4wyk81cgj8kxkxqgsgblrkxnmmadc77cg9gflrfal"; type = "gem"; }; version = "2.7.3"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15gysw8rassqgdq3kwgl4mhqmrgh7nk2qvrcqp4ijyqazgywn6gq"; type = "gem"; }; version = "1.16.7"; }; oj = { - dependencies = ["bigdecimal" "ostruct"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bigdecimal" + "ostruct" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1k2skb0n7mf2azznnbsa6irwghdxlmnhdxv9qs6jqg3gd0k2n4zx"; type = "gem"; }; version = "3.16.6"; }; omniauth = { - dependencies = ["hashie" "rack" "rack-protection"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "hashie" + "rack" + "rack-protection" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1km0wqx9pj609jidvrqfsvzbzfgdnlpdnv7i7xfqm3wb55vk5w6y"; type = "gem"; }; version = "2.1.2"; }; omniauth-cas = { - dependencies = ["addressable" "nokogiri" "omniauth"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "nokogiri" + "omniauth" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "13z686dmkdssm4d5b0k45ydavhjrzcaqzyqxvvmaqn3a0vc6klbs"; type = "gem"; }; version = "3.0.0"; }; omniauth-rails_csrf_protection = { - dependencies = ["actionpack" "omniauth"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "omniauth" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1q2zvkw34vk1vyhn5kp30783w1wzam9i9g5ygsdjn2gz59kzsw0i"; type = "gem"; }; version = "1.0.2"; }; omniauth-saml = { - dependencies = ["omniauth" "ruby-saml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "omniauth" + "ruby-saml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00nn24s74miy7p65y8lwpjfwgcn7fwld61f9ghngal4asgw6pfwa"; type = "gem"; }; version = "2.2.1"; }; omniauth_openid_connect = { - dependencies = ["omniauth" "openid_connect"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "omniauth" + "openid_connect" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08yl0x203k6nrshc70zawfqh79ap1c3fyka9zwwy61cvn7sih4sz"; type = "gem"; }; version = "0.6.1"; }; openid_connect = { - dependencies = ["activemodel" "attr_required" "json-jwt" "net-smtp" "rack-oauth2" "swd" "tzinfo" "validate_email" "validate_url" "webfinger"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activemodel" + "attr_required" + "json-jwt" + "net-smtp" + "rack-oauth2" + "swd" + "tzinfo" + "validate_email" + "validate_url" + "webfinger" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1k9kdivp45v6vhzdrnl5fzhd378gjj2hl4w9bazbqnfm15rsnzc8"; type = "gem"; }; version = "1.4.2"; }; openssl = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "054d6ybgjdzxw567m7rbnd46yp6gkdbc5ihr536vxd3p15vbhjrw"; type = "gem"; }; version = "3.2.0"; }; openssl-signature_algorithm = { - dependencies = ["openssl"]; - groups = ["default"]; - platforms = []; + dependencies = [ "openssl" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "103yjl68wqhl5kxaciir5jdnyi7iv9yckishdr52s5knh9g0pd53"; type = "gem"; }; version = "1.3.0"; }; opentelemetry-api = { - groups = ["default" "opentelemetry"]; - platforms = []; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dj0cqxz0fl2934pmq4pvnb4wpapjfcsjnzb8vll08bcspjdwcx7"; type = "gem"; }; version = "1.4.0"; }; opentelemetry-common = { - dependencies = ["opentelemetry-api"]; - groups = ["default" "opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "opentelemetry-api" ]; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "160ws06d8mzx3hwjss2i954h8r86dp3sw95k2wrbq81sb121m2gy"; type = "gem"; }; version = "0.21.0"; }; opentelemetry-exporter-otlp = { - dependencies = ["google-protobuf" "googleapis-common-protos-types" "opentelemetry-api" "opentelemetry-common" "opentelemetry-sdk" "opentelemetry-semantic_conventions"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "google-protobuf" + "googleapis-common-protos-types" + "opentelemetry-api" + "opentelemetry-common" + "opentelemetry-sdk" + "opentelemetry-semantic_conventions" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yl10v1vvb9krvvks0si5nbjpknz8lcbbcryqkf2g0db3kha072d"; type = "gem"; }; version = "0.29.0"; }; opentelemetry-helpers-sql-obfuscation = { - dependencies = ["opentelemetry-common"]; - groups = ["default" "opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "opentelemetry-common" ]; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0v44n3lgkclnfjg9iz5jaay7fkcqvb35jrkm2b68fr2cyy778mnz"; type = "gem"; }; version = "0.2.0"; }; opentelemetry-instrumentation-action_mailer = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-active_support" "opentelemetry-instrumentation-base"]; - groups = ["default" "opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-active_support" + "opentelemetry-instrumentation-base" + ]; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1afibmwprdiqnkin7lb6zdxng36rqa7qbl5fl9wx0lchpc039zjj"; type = "gem"; }; version = "0.1.0"; }; opentelemetry-instrumentation-action_pack = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base" "opentelemetry-instrumentation-rack"]; - groups = ["default" "opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + "opentelemetry-instrumentation-rack" + ]; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "16nbkayp8jb2zkqj2rmqd4d1mz4wdf0zg6jx8b0vzkf9mxr89py5"; type = "gem"; }; version = "0.9.0"; }; opentelemetry-instrumentation-action_view = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-active_support" "opentelemetry-instrumentation-base"]; - groups = ["default" "opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-active_support" + "opentelemetry-instrumentation-base" + ]; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "17qild0js6rgv95rphhs19jhd6ixspv1qvpijchqxmxg8waxmwih"; type = "gem"; }; version = "0.7.2"; }; opentelemetry-instrumentation-active_job = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1a5afx39bf0pzi0w75ic8zs8447i96993h056ww4vr23zl585f2x"; type = "gem"; }; version = "0.7.7"; }; opentelemetry-instrumentation-active_model_serializers = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0yw98f8z6k4c8ns7p8ik2dc68p4vbi12xnavzw0vqhlnny4nx0n7"; type = "gem"; }; version = "0.20.2"; }; opentelemetry-instrumentation-active_record = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["default" "opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0vr690556iaycwdipr962k3pfv97a2sgv4b6f6jwm9hg3mqfqcpg"; type = "gem"; }; version = "0.7.3"; }; opentelemetry-instrumentation-active_support = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["default" "opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1q07nn9ipq2yd7xjj24hh00cbvlda269k1l0xfkc8d8iw8mixrsg"; type = "gem"; }; version = "0.6.0"; }; opentelemetry-instrumentation-base = { - dependencies = ["opentelemetry-api" "opentelemetry-common" "opentelemetry-registry"]; - groups = ["default" "opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-common" + "opentelemetry-registry" + ]; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0psjpqigi7k0fky1kd54jzf9r779vh2c86ngjppn7ifmnh4n3r9y"; type = "gem"; }; version = "0.22.6"; }; opentelemetry-instrumentation-concurrent_ruby = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1khlhzwb37mqnzr1vr49ljhi4bplmq9w8ndm0k8xbfsr8h8wivq4"; type = "gem"; }; version = "0.21.4"; }; opentelemetry-instrumentation-excon = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14g6dvk31kz9v9qbr2w6ggxk96v3kaadm8wvnw3qsrsc4pd9ycns"; type = "gem"; }; version = "0.22.4"; }; opentelemetry-instrumentation-faraday = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0np6wnckn12df6mwcr695fvjy3x2s6541ywr7ahw8a8dszs0qjsh"; type = "gem"; }; version = "0.24.6"; }; opentelemetry-instrumentation-http = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05mrlg8msp59bagpc18ycr9333760kqp780gw8fgqn1798dl02qr"; type = "gem"; }; version = "0.23.4"; }; opentelemetry-instrumentation-http_client = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0g6f5zv0bq585ppgzhm6acrpkz32j1h7zyrcy1r8n3ha41daip1z"; type = "gem"; }; version = "0.22.7"; }; opentelemetry-instrumentation-net_http = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1l26f8sqsjjcc72a5xr9as3gibm4sgj8n004y15i5vbvdgzjfx60"; type = "gem"; }; version = "0.22.7"; }; opentelemetry-instrumentation-pg = { - dependencies = ["opentelemetry-api" "opentelemetry-helpers-sql-obfuscation" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-helpers-sql-obfuscation" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1lgkjp0h0hf51n6afgafqaswvm06ybsvj3yf7dxxkzjpnzgxvjvg"; type = "gem"; }; version = "0.29.0"; }; opentelemetry-instrumentation-rack = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1dmfxcc2xz2qa4zp0sks5zrqcfr4fbpbc9xdgvcv8ys0ipf7pwn0"; type = "gem"; }; version = "0.24.6"; }; opentelemetry-instrumentation-rails = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-action_mailer" "opentelemetry-instrumentation-action_pack" "opentelemetry-instrumentation-action_view" "opentelemetry-instrumentation-active_job" "opentelemetry-instrumentation-active_record" "opentelemetry-instrumentation-active_support" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-action_mailer" + "opentelemetry-instrumentation-action_pack" + "opentelemetry-instrumentation-action_view" + "opentelemetry-instrumentation-active_job" + "opentelemetry-instrumentation-active_record" + "opentelemetry-instrumentation-active_support" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "12k4s1k9wa257bqfny33byscb4ai86jw4q6ygrzsj3iv2bij07w9"; type = "gem"; }; version = "0.31.2"; }; opentelemetry-instrumentation-redis = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1qrgnk2x64sks9gqb7fycfa6sass6ddqzh5dms4hdbz1bzag581f"; type = "gem"; }; version = "0.25.7"; }; opentelemetry-instrumentation-sidekiq = { - dependencies = ["opentelemetry-api" "opentelemetry-instrumentation-base"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-instrumentation-base" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cfzw1avv52idxvq02y95g3byxsswccck78zch5hmnnzvp5f59nn"; type = "gem"; }; version = "0.25.7"; }; opentelemetry-registry = { - dependencies = ["opentelemetry-api"]; - groups = ["default" "opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "opentelemetry-api" ]; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1pw87n9vpv40hf7f6gyl2vvbl11hzdkv4psbbv3x23jvccs8593k"; type = "gem"; }; version = "0.3.1"; }; opentelemetry-sdk = { - dependencies = ["opentelemetry-api" "opentelemetry-common" "opentelemetry-registry" "opentelemetry-semantic_conventions"]; - groups = ["opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "opentelemetry-api" + "opentelemetry-common" + "opentelemetry-registry" + "opentelemetry-semantic_conventions" + ]; + groups = [ "opentelemetry" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0div7n5wac7x1l9fwdpb3bllw18cns93c7xccy27r4gmvv02f46s"; type = "gem"; }; version = "1.5.0"; }; opentelemetry-semantic_conventions = { - dependencies = ["opentelemetry-api"]; - groups = ["default" "opentelemetry"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "opentelemetry-api" ]; + groups = [ + "default" + "opentelemetry" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "10anxw736pg85nw8vb11xnr5faq7qj8a1d8c62qbpjs6m0izi77y"; type = "gem"; }; version = "1.10.1"; }; orm_adapter = { - groups = ["default" "pam_authentication"]; - platforms = []; + groups = [ + "default" + "pam_authentication" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fg9jpjlzf5y49qs9mlpdrgs5rpcyihq1s4k79nv9js0spjhnpda"; type = "gem"; }; version = "0.5.0"; }; ostruct = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11dsv71gfbhy92yzj3xkckjzdai2bsz5a4fydgimv62dkz4kc5rv"; type = "gem"; }; version = "0.6.0"; }; ox = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0w9gavjrvciip497hpdjpcs2c18vf6cgmlj696ynpaqv96804glr"; type = "gem"; }; version = "2.14.18"; }; parallel = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vy7sjs2pgz4i96v5yk9b7aafbffnvq7nn419fgvw55qlavsnsyq"; type = "gem"; }; version = "1.26.3"; }; parser = { - dependencies = ["ast" "racc"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ast" + "racc" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1cqs31cyg2zp8yx2zzm3zkih0j93q870wasbviy2w343nxqvn3pk"; type = "gem"; }; version = "3.3.5.0"; }; parslet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01pnw6ymz6nynklqvqxs4bcai25kcvnd5x4id9z3vd1rbmlk0lfl"; type = "gem"; }; version = "2.0.0"; }; pastel = { - dependencies = ["tty-color"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-color" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xash2gj08dfjvq4hy6l1z22s5v30fhizwgs10d6nviggpxsj7a8"; type = "gem"; }; version = "0.8.0"; }; pg = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dsgcmzc55w7i9cpghfkzhmiskzndvp1vijd8c5ryv8xvlwikmzg"; type = "gem"; }; version = "1.5.8"; }; pghero = { - dependencies = ["activerecord"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activerecord" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "028icy2wr33a5wbh2szar1mf0syh42p3szd4bfxl1zwrby3cpnfa"; type = "gem"; }; version = "3.6.0"; }; premailer = { - dependencies = ["addressable" "css_parser" "htmlentities"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "css_parser" + "htmlentities" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ryivdnij1990hcqqmq4s0x1vjvfl0awjc9b91f8af17v2639qhg"; type = "gem"; }; version = "1.27.0"; }; premailer-rails = { - dependencies = ["actionmailer" "net-smtp" "premailer"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionmailer" + "net-smtp" + "premailer" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0004f73kgrglida336fqkgx906m6n05nnfc17mypzg5rc78iaf61"; type = "gem"; }; version = "1.12.0"; }; propshaft = { - dependencies = ["actionpack" "activesupport" "rack" "railties"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "rack" + "railties" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0sqg0xf46xd47zdpm8d12kfnwl0y5jb2hj10imzb3bk6mwgkd2fk"; type = "gem"; }; version = "1.1.0"; }; psych = { - dependencies = ["stringio"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "stringio" ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0s5383m6004q76xm3lb732bp4sjzb6mxb6rbgn129gy2izsj4wrk"; type = "gem"; }; version = "5.1.2"; }; public_suffix = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0vqcw3iwby3yc6avs1vb3gfd0vcp2v7q310665dvxfswmcf4xm31"; type = "gem"; }; version = "6.0.1"; }; puma = { - dependencies = ["nio4r"]; - groups = ["default"]; - platforms = []; + dependencies = [ "nio4r" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gml1rixrfb0naciq3mrnqkpcvm9ahgps1c04hzxh4b801f69914"; type = "gem"; }; version = "6.4.3"; }; pundit = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wkm850z17gy5gph5lbmaz62wx7nvkj9r690017w10phkmxd5rj3"; type = "gem"; }; version = "2.4.0"; }; raabro = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10m8bln9d00dwzjil1k42i5r7l82x25ysbi45fwyv4932zsrzynl"; type = "gem"; }; version = "1.4.0"; }; racc = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0byn0c9nkahsl93y9ln5bysq4j31q8xkf2ws42swighxd4lnjzsa"; type = "gem"; }; version = "1.8.1"; }; rack = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0hj0rkw2z9r1lcg2wlrcld2n3phwrcgqcp7qd1g9a7hwgalh2qzx"; type = "gem"; }; version = "2.2.9"; }; rack-attack = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0z6pj5vjgl6swq7a33gssf795k958mss8gpmdb4v4cydcs7px91w"; type = "gem"; }; version = "6.7.0"; }; rack-cors = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06ysmn14pdf2wyr7agm0qvvr9pzcgyf39w4yvk2n05w9k4alwpa1"; type = "gem"; }; version = "2.0.2"; }; rack-oauth2 = { - dependencies = ["activesupport" "attr_required" "httpclient" "json-jwt" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "attr_required" + "httpclient" + "json-jwt" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1fknwsxz4429w1hndl6y30cmm2n34wmmaaj2hhp6jrm8ssfsfwjf"; type = "gem"; }; version = "1.21.3"; }; rack-protection = { - dependencies = ["base64" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zzvivmdb4dkscc58i3gmcyrnypynsjwp6xgc4ylarlhqmzvlx1w"; type = "gem"; }; version = "3.2.0"; }; rack-proxy = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12jw7401j543fj8cc83lmw72d8k6bxvkp9rvbifi88hh01blnsj4"; type = "gem"; }; version = "0.7.7"; }; rack-session = { - dependencies = ["rack"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rack" ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0xhxhlsz6shh8nm44jsmd9276zcnyzii364vhcvf0k8b8bjia8d0"; type = "gem"; }; version = "1.0.2"; }; rack-test = { - dependencies = ["rack"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rack" ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ysx29gk9k14a14zsp5a8czys140wacvp91fja8xcja0j1hzqq8c"; type = "gem"; }; version = "2.1.0"; }; rackup = { - dependencies = ["rack" "webrick"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rack" + "webrick" + ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1wbr03334ba9ilcq25wh9913xciwj0j117zs60vsqm0zgwdkwpp9"; type = "gem"; }; version = "1.0.0"; }; rails = { - dependencies = ["actioncable" "actionmailbox" "actionmailer" "actionpack" "actiontext" "actionview" "activejob" "activemodel" "activerecord" "activestorage" "activesupport" "railties"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actioncable" + "actionmailbox" + "actionmailer" + "actionpack" + "actiontext" + "actionview" + "activejob" + "activemodel" + "activerecord" + "activestorage" + "activesupport" + "railties" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fa7maxd1ydbnws0fym43pv8j2c6k5dkg0z0fkq31j8jr1aqk7ja"; type = "gem"; }; version = "7.1.4.1"; }; rails-controller-testing = { - dependencies = ["actionpack" "actionview" "activesupport"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "actionview" + "activesupport" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "151f303jcvs8s149mhx2g5mn67487x0blrf9dzl76q1nb7dlh53l"; type = "gem"; }; version = "1.0.5"; }; rails-dom-testing = { - dependencies = ["activesupport" "minitest" "nokogiri"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "minitest" + "nokogiri" + ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fx9dx1ag0s1lr6lfr34lbx5i1bvn3bhyf3w3mx6h7yz90p725g5"; type = "gem"; }; version = "2.2.0"; }; rails-html-sanitizer = { - dependencies = ["loofah" "nokogiri"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "loofah" + "nokogiri" + ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1pm4z853nyz1bhhqr7fzl44alnx4bjachcr6rh6qjj375sfz3sc6"; type = "gem"; }; version = "1.6.0"; }; rails-i18n = { - dependencies = ["i18n" "railties"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "i18n" + "railties" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0s8kvic2ia34ngssz6h15wqj0k3wwblhyh0f9v0j3gy7ly0dp161"; type = "gem"; }; version = "7.0.9"; }; railties = { - dependencies = ["actionpack" "activesupport" "irb" "rackup" "rake" "thor" "zeitwerk"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "irb" + "rackup" + "rake" + "thor" + "zeitwerk" + ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ypihpilhxdz5p3sb5g37jn2sbfjhf2ydkxj097kkn7ri7a7702x"; type = "gem"; }; version = "7.1.4.1"; }; rainbow = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0smwg4mii0fm38pyb5fddbmrdpifwv22zv3d3px2xx497am93503"; type = "gem"; }; version = "3.1.1"; }; rake = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "17850wcwkgi30p7yqh60960ypn7yibacjjha0av78zaxwvd3ijs6"; type = "gem"; }; version = "13.2.1"; }; rdf = { - dependencies = ["bcp47_spec" "bigdecimal" "link_header"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bcp47_spec" + "bigdecimal" + "link_header" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1mlalmbj1wkwvjha92f7v91v0pbjar9gdb2ddxdyqd24zcifn3ln"; type = "gem"; }; version = "3.3.2"; }; rdf-normalize = { - dependencies = ["rdf"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rdf" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1glyhg7lmzbq1w7bvvf84g7kvqxcn0mw3gsh1f8w4qfvvnbl8dwj"; type = "gem"; }; version = "0.7.0"; }; rdoc = { - dependencies = ["psych"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "psych" ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ygk2zk0ky3d88v3ll7qh6xqvbvw5jin0hqdi1xkv1dhaw7myzdi"; type = "gem"; }; version = "6.7.0"; }; redcarpet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sg9sbf9pm91l7lac7fs4silabyn0vflxwaa2x3lrzsm0ff8ilca"; type = "gem"; }; version = "3.6.0"; }; redis = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fikjg6j12ka6hh36dxzhfkpqqmilzjfzcdf59iwkzsgd63f0ziq"; type = "gem"; }; version = "4.8.1"; }; redis-namespace = { - dependencies = ["redis"]; - groups = ["default"]; - platforms = []; + dependencies = [ "redis" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f92i9cwlp6xj6fyn7qn4qsaqvxfw4wqvayll7gbd26qnai1l6p9"; type = "gem"; }; version = "1.11.0"; }; redlock = { - dependencies = ["redis"]; - groups = ["default"]; - platforms = []; + dependencies = [ "redis" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xvjwfzq7rqj4k311kidwmv5app3i7glz4miys6ixqy6c8yylz3c"; type = "gem"; }; version = "1.3.2"; }; regexp_parser = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ik40vcv7mqigsfpqpca36hpmnx0536xa825ai5qlkv3mmkyf9ss"; type = "gem"; }; version = "2.9.2"; }; reline = { - dependencies = ["io-console"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "io-console" ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0rl1jmxs7pay58l7lkxkrn6nkdpk52k8rvnfwqsd1swjlxlwjq0n"; type = "gem"; }; version = "0.5.10"; }; request_store = { - dependencies = ["rack"]; - groups = ["default" "production"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rack" ]; + groups = [ + "default" + "production" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0kd4w7aa0sbk59b19s39pwhd636r7fjamrqalixsw5d53hs4sb1d"; type = "gem"; }; version = "1.6.0"; }; responders = { - dependencies = ["actionpack" "railties"]; - groups = ["default" "pam_authentication"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "railties" + ]; + groups = [ + "default" + "pam_authentication" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "06ilkbbwvc8d0vppf8ywn1f79ypyymlb9krrhqv4g0q215zaiwlj"; type = "gem"; }; version = "3.1.1"; }; rexml = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1j9p66pmfgxnzp76ksssyfyqqrg7281dyi3xyknl3wwraaw7a66p"; type = "gem"; }; version = "3.3.9"; }; rotp = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0m48hv6wpmmm6cjr6q92q78h1i610riml19k5h1dil2yws3h1m3m"; type = "gem"; }; version = "6.3.0"; }; rouge = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "072qvvrcqj0yfr3b0j932mlhvn41i38bq37z7z07i3ikagndkqwy"; type = "gem"; }; version = "4.3.0"; }; rpam2 = { - groups = ["default" "pam_authentication"]; - platforms = []; + groups = [ + "default" + "pam_authentication" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zvli3s4z1hf2l7gyfickm5i3afjrnycc3ihbiax6ji6arpbyf33"; type = "gem"; }; version = "4.0.2"; }; rqrcode = { - dependencies = ["chunky_png" "rqrcode_core"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "chunky_png" + "rqrcode_core" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1hggzz8i1l62pkkiybhiqv6ypxw7q844sddrrbbfczjcnj5sivi3"; type = "gem"; }; version = "2.2.0"; }; rqrcode_core = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06ld6386hbdhy5h0k09axmgn424kavpc8f27k1vjhknjhbf8jjfg"; type = "gem"; }; version = "1.2.0"; }; rspec = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks"]; - groups = ["default" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + ]; + groups = [ + "default" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14xrp8vq6i9zx37vh0yp4h9m0anx9paw200l1r5ad9fmq559346l"; type = "gem"; }; version = "3.13.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rspec-support" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0s688wfw77fjldzayvczg8bgwcgh6bh552dw7qcj1rhjk3r4zalx"; type = "gem"; }; version = "3.13.1"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0nm4qx9bgfzwfc1q0l3sj50vf88q1mbwkkqndbzc08wrnd5bjpsn"; type = "gem"; }; version = "3.13.2"; }; rspec-github = { - dependencies = ["rspec-core"]; - groups = ["test"]; - platforms = []; + dependencies = [ "rspec-core" ]; + groups = [ "test" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kqjmd85v2fpb06d0rx43dc51f0igc1gmm8y3nz0wvmy7zg02njm"; type = "gem"; }; version = "2.4.0"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0f3vgp43hajw716vmgjv6f4ar6f97zf50snny6y3fy9kkj4qjw88"; type = "gem"; }; version = "3.13.1"; }; rspec-rails = { - dependencies = ["actionpack" "activesupport" "railties" "rspec-core" "rspec-expectations" "rspec-mocks" "rspec-support"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "railties" + "rspec-core" + "rspec-expectations" + "rspec-mocks" + "rspec-support" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ycjggcmzbgrfjk04v26b43c3fj5jq2qic911qk7585wvav2qaxd"; type = "gem"; }; version = "7.0.1"; }; rspec-sidekiq = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks" "sidekiq"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + "sidekiq" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08sbi3cdh6pxj0mj34vzr7675rb4n2r2q5yxlgs0w9xnm5c0jpdx"; type = "gem"; }; version = "5.0.0"; }; rspec-support = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "03z7gpqz5xkw9rf53835pa8a9vgj4lic54rnix9vfwmp2m7pv1s8"; type = "gem"; }; version = "3.13.1"; }; rubocop = { - dependencies = ["json" "language_server-protocol" "parallel" "parser" "rainbow" "regexp_parser" "rubocop-ast" "ruby-progressbar" "unicode-display_width"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "json" + "language_server-protocol" + "parallel" + "parser" + "rainbow" + "regexp_parser" + "rubocop-ast" + "ruby-progressbar" + "unicode-display_width" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1rsyxrl647bz49gpa4flh8igg6wy7qxyh2jrp01x0kqnn5iw4y86"; type = "gem"; }; version = "1.66.1"; }; rubocop-ast = { - dependencies = ["parser"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "parser" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "03zywfpm4540q6hw8srhi8pzp0gg51w65ir8jkaw58vk3j31w820"; type = "gem"; }; version = "1.32.3"; }; rubocop-capybara = { - dependencies = ["rubocop"]; - groups = ["development"]; - platforms = []; + dependencies = [ "rubocop" ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1aw0n8jwhsr39r9q2k90xjmcz8ai2k7xx2a87ld0iixnv3ylw9jx"; type = "gem"; }; version = "2.21.0"; }; rubocop-performance = { - dependencies = ["rubocop" "rubocop-ast"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rubocop" + "rubocop-ast" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0yd616imfjvlpwsk7lw5kq9h4iz6qkmf10xlaib6b47fy5x77ncy"; type = "gem"; }; version = "1.22.1"; }; rubocop-rails = { - dependencies = ["activesupport" "rack" "rubocop" "rubocop-ast"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "rack" + "rubocop" + "rubocop-ast" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1bc4xpyx0gldjdmbl9aaqav5bjiqfc2zdw7k2r1zblmgsq4ilmpm"; type = "gem"; }; version = "2.26.2"; }; rubocop-rspec = { - dependencies = ["rubocop"]; - groups = ["development"]; - platforms = []; + dependencies = [ "rubocop" ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03vyjxs5rzrsn5graljffgzy1fgbyn99w5fz69y243dhn6gy5a66"; type = "gem"; }; version = "3.0.5"; }; rubocop-rspec_rails = { - dependencies = ["rubocop" "rubocop-rspec"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rubocop" + "rubocop-rspec" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ijc1kw81884k0wjq1sgwaxa854n1fdddscp4fnzfzlx7zl150c8"; type = "gem"; }; version = "2.30.0"; }; ruby-prof = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hnalxnvli6248g34n0bj8p3v35vpabak34qjg778bbaavbqg5h5"; type = "gem"; }; version = "1.7.0"; }; ruby-progressbar = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cwvyb7j47m7wihpfaq7rc47zwwx9k4v7iqd9s1xch5nm53rrz40"; type = "gem"; }; version = "1.13.0"; }; ruby-saml = { - dependencies = ["nokogiri" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "nokogiri" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1adq06m684gnpjp6qyb8shgj8jjy2npcfg7y6mg2ab9ilfdq6684"; type = "gem"; }; version = "1.17.0"; }; ruby-vips = { - dependencies = ["ffi" "logger"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ffi" + "logger" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0nyxwib3y2fc1lciaac0s03y3i915kyfq1kn9m19hyl5yblyhnxg"; type = "gem"; }; version = "2.2.2"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; rubyzip = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; rufus-scheduler = { - dependencies = ["fugit"]; - groups = ["default"]; - platforms = []; + dependencies = [ "fugit" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14lr8c2sswn0sisvrfi4448pmr34za279k3zlxgh581rl1y0gjjz"; type = "gem"; }; version = "3.9.1"; }; safety_net_attestation = { - dependencies = ["jwt"]; - groups = ["default"]; - platforms = []; + dependencies = [ "jwt" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1khq0y5w7lf2b9a220298hphf3pakd216jc9a4x4a9pdwxs2vgln"; type = "gem"; }; version = "0.4.0"; }; sanitize = { - dependencies = ["crass" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "crass" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0lj1jjxn1znxmaf6jnngfrz26rw85smxb69m4jl6a9yq6gwyab54"; type = "gem"; }; version = "6.1.3"; }; scenic = { - dependencies = ["activerecord" "railties"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activerecord" + "railties" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0w0dafg0gz3snm30247wwai0cy3j235ynwx2karyh05ayfqhm4ii"; type = "gem"; }; version = "1.8.0"; }; selenium-webdriver = { - dependencies = ["base64" "logger" "rexml" "rubyzip" "websocket"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "logger" + "rexml" + "rubyzip" + "websocket" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1md0sixm8dq8a7riv50x4q1z273q47b5jvcbv5hxympxn3ran4by"; type = "gem"; }; version = "4.25.0"; }; semantic_range = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dlp97vg95plrsaaqj7x8l7z9vsjbhnqk4rw1l30gy26lmxpfrih"; type = "gem"; }; version = "3.0.0"; }; shoulda-matchers = { - dependencies = ["activesupport"]; - groups = ["test"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "test" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c082vpfdf3865xq6xayxw2hwqswhnc9g030p1gi4hmk9dzvnmch"; type = "gem"; }; version = "6.4.0"; }; sidekiq = { - dependencies = ["connection_pool" "rack" "redis"]; - groups = ["default" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "connection_pool" + "rack" + "redis" + ]; + groups = [ + "default" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0zqr9is8y7mg5dfs1q8w5jl9spwvqkhbi9r6np8208n40hi3pydl"; type = "gem"; }; version = "6.5.12"; }; sidekiq-bulk = { - dependencies = ["sidekiq"]; - groups = ["default"]; - platforms = []; + dependencies = [ "sidekiq" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08nyxzmgf742irafy3l4fj09d4s5pyvsh0dzlh8y4hl51rgkh4xv"; type = "gem"; }; version = "0.2.0"; }; sidekiq-scheduler = { - dependencies = ["rufus-scheduler" "sidekiq" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rufus-scheduler" + "sidekiq" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1gnm98hdw1ndw0sryjimp4a0805yhwhjxg6njhz8xmdh5ycgljda"; type = "gem"; }; version = "5.0.6"; }; sidekiq-unique-jobs = { - dependencies = ["brpoplpush-redis_script" "concurrent-ruby" "redis" "sidekiq" "thor"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "brpoplpush-redis_script" + "concurrent-ruby" + "redis" + "sidekiq" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1am17wfx023z1x9sxq90cyjarcmcwb95mi456mcf13m783r4n190"; type = "gem"; }; version = "7.1.33"; }; simple-navigation = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wc1rapwhqymcjfxmlgam4cvbyhnzfxada2damq88ij2p77pjz4q"; type = "gem"; }; version = "4.4.0"; }; simple_form = { - dependencies = ["actionpack" "activemodel"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activemodel" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0q3lwin7pk5rsxy2a663x6lph5arax9lqqk12fgwdy57i5ma749q"; type = "gem"; }; version = "5.3.1"; }; simplecov = { - dependencies = ["docile" "simplecov-html" "simplecov_json_formatter"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "docile" + "simplecov-html" + "simplecov_json_formatter" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "198kcbrjxhhzca19yrdcd6jjj9sb51aaic3b0sc3pwjghg3j49py"; type = "gem"; }; version = "0.22.0"; }; simplecov-html = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yx01bxa8pbf9ip4hagqkp5m0mqfnwnw2xk8kjraiywz4lrss6jb"; type = "gem"; }; version = "0.12.3"; }; simplecov-lcov = { - groups = ["test"]; - platforms = []; + groups = [ "test" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h8kswnshgb9zidvc88f4zjy4gflgz3854sx9wrw8ppgnwfg6581"; type = "gem"; }; version = "0.8.0"; }; simplecov_json_formatter = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a5l0733hj7sk51j81ykfmlk2vd5vaijlq9d5fn165yyx3xii52j"; type = "gem"; }; version = "0.1.4"; }; stackprof = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gdqqwnampxmc54nf6zfy9apkmkpdavzipvfssmjlhnrrjy8qh7f"; type = "gem"; }; version = "0.2.26"; }; stoplight = { - dependencies = ["redlock"]; - groups = ["default"]; - platforms = []; + dependencies = [ "redlock" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qq3z6mwbgj1q3b9hpxxi98i63jpqycbv13fqb8362ngk7cv06x8"; type = "gem"; }; version = "4.1.0"; }; stringio = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07mfqb40b2wh53k33h91zva78f9zwcdnl85jiq74wnaw2wa6wiak"; type = "gem"; }; version = "3.1.1"; }; strong_migrations = { - dependencies = ["activerecord"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activerecord" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07ahzxbmngwa5v2jhybaxm9zb5f15wgr19pdfk38xq838hlhyxc8"; type = "gem"; }; version = "2.0.0"; }; swd = { - dependencies = ["activesupport" "attr_required" "httpclient"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "attr_required" + "httpclient" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "12b3q2sw42nnilfb51nlqdv07f31vdv2j595kd99asnkw4cjlf5w"; type = "gem"; }; version = "1.3.0"; }; sysexits = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qjng6pllznmprzx8vb0zg0c86hdrkyjs615q41s9fjpmv2430jr"; type = "gem"; }; version = "1.2.0"; }; temple = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fwia5hvc1xz9w7vprzjnsym3v9j5l9ggdvy70jixbvpcpz4acfz"; type = "gem"; }; version = "0.10.3"; }; terminal-table = { - dependencies = ["unicode-display_width"]; - groups = ["default" "development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "unicode-display_width" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14dfmfjppmng5hwj7c5ka6qdapawm3h6k9lhn8zj001ybypvclgr"; type = "gem"; }; version = "3.0.2"; }; terrapin = { - dependencies = ["climate_control"]; - groups = ["default"]; - platforms = []; + dependencies = [ "climate_control" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k968xzamd4y92zflrdilvc7wp8cj49n9lz34vnm95rg1j2gbqnx"; type = "gem"; }; version = "1.0.1"; }; test-prof = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1mydvmcm4m5501322wyl3pwmc6i5ijvwh4kb242l085j88hiqp4n"; type = "gem"; }; version = "1.4.2"; }; thor = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1nmymd86a0vb39pzj2cwv57avdrl6pl3lf5bsz58q594kqxjkw7f"; type = "gem"; }; version = "1.3.2"; }; tilt = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kds7wkxmb038cwp6ravnwn8k65ixc68wpm8j5jx5bhx8ndg4x6z"; type = "gem"; }; version = "2.4.0"; }; timeout = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16mvvsmx90023wrhf8dxc1lpqh0m8alk65shb7xcya6a9gflw7vg"; type = "gem"; }; version = "0.4.1"; }; tpm-key_attestation = { - dependencies = ["bindata" "openssl" "openssl-signature_algorithm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bindata" + "openssl" + "openssl-signature_algorithm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "18xc7hyasg5ja2i2vb23d9c5pd6rf316kzwqxqx5d8vbs2z1a4rw"; type = "gem"; }; version = "0.12.1"; }; tty-color = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0aik4kmhwwrmkysha7qibi2nyzb4c8kp42bd5vxnf8sf7b53g73g"; type = "gem"; }; version = "0.6.0"; }; tty-cursor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j5zw041jgkmn605ya1zc151bxgxl6v192v2i26qhxx7ws2l2lvr"; type = "gem"; }; version = "0.7.1"; }; tty-prompt = { - dependencies = ["pastel" "tty-reader"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pastel" + "tty-reader" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1j4y8ik82azjxshgd4i1v4wwhsv3g9cngpygxqkkz69qaa8cxnzw"; type = "gem"; }; version = "0.23.1"; }; tty-reader = { - dependencies = ["tty-cursor" "tty-screen" "wisper"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "tty-cursor" + "tty-screen" + "wisper" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1cf2k7w7d84hshg4kzrjvk9pkyc2g1m3nx2n1rpmdcf0hp4p4af6"; type = "gem"; }; version = "0.9.0"; }; tty-screen = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0l4vh6g333jxm9lakilkva2gn17j6gb052626r1pdbmy2lhnb460"; type = "gem"; }; version = "0.8.2"; }; twitter-text = { - dependencies = ["idn-ruby" "unf"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "idn-ruby" + "unf" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1dnmp0bj3l01nbb52zby2c7hrazcdwfg846knkrjdfl0yfmv793z"; type = "gem"; }; version = "3.1.0"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "concurrent-ruby" ]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; tzinfo-data = { - dependencies = ["tzinfo"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tzinfo" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cw6xv9a525mcs7202bq9768aic1dwx353prm1bss4fp2nq24a3j"; type = "gem"; }; version = "1.2024.2"; }; unf = { - dependencies = ["unf_ext"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unf_ext" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bh2cf73i2ffh4fcpdn9ir4mhq8zi50ik0zqa1braahzadx536a9"; type = "gem"; }; version = "0.1.4"; }; unf_ext = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sf6bxvf6x8gihv6j63iakixmdddgls58cpxpg32chckb2l18qcj"; type = "gem"; }; version = "0.0.9.1"; }; unicode-display_width = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d0azx233nags5jx3fqyr23qa2rhgzbhv8pxp46dgbg1mpf82xky"; type = "gem"; }; version = "2.5.0"; }; uri = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07ndgxyhzd02cg94s6rnfhkb9rwx9z72lzk368sa9j78wc9qnbfz"; type = "gem"; }; version = "0.13.1"; }; validate_email = { - dependencies = ["activemodel" "mail"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activemodel" + "mail" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1r1fz29l699arka177c9xw7409d1a3ff95bf7a6pmc97slb91zlx"; type = "gem"; }; version = "0.1.6"; }; validate_url = { - dependencies = ["activemodel" "public_suffix"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activemodel" + "public_suffix" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0lblym140w5n88ijyfgcvkxvpfj8m6z00rxxf2ckmmhk0x61dzkj"; type = "gem"; }; version = "1.0.15"; }; warden = { - dependencies = ["rack"]; - groups = ["default" "pam_authentication"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rack" ]; + groups = [ + "default" + "pam_authentication" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1l7gl7vms023w4clg02pm4ky9j12la2vzsixi2xrv9imbn44ys26"; type = "gem"; }; version = "1.2.9"; }; webauthn = { - dependencies = ["android_key_attestation" "awrence" "bindata" "cbor" "cose" "openssl" "safety_net_attestation" "tpm-key_attestation"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "android_key_attestation" + "awrence" + "bindata" + "cbor" + "cose" + "openssl" + "safety_net_attestation" + "tpm-key_attestation" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1dwh2xrpwhbzyncb1wvgzz8fmln3r15iqz53c48q4swagpqzqig5"; type = "gem"; }; version = "3.1.0"; }; webfinger = { - dependencies = ["activesupport" "httpclient"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "httpclient" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "18jj50b44a471ig7hw1ax90wxaaz40acmrf6cm7m2iyshlffy53q"; type = "gem"; }; version = "1.2.0"; }; webmock = { - dependencies = ["addressable" "crack" "hashdiff"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "crack" + "hashdiff" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08kixkdp41dw39kqfxf2wp5m4z9b6fxg6yfa6xin0wy7dxzka0dy"; type = "gem"; }; version = "3.24.0"; }; webpacker = { - dependencies = ["activesupport" "rack-proxy" "railties" "semantic_range"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "rack-proxy" + "railties" + "semantic_range" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fh4vijqiq1h7w28llk67y9csc0m4wkdivrsl4fsxg279v6j5z3i"; type = "gem"; }; version = "5.4.4"; }; webpush = { - dependencies = ["hkdf" "jwt"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "hkdf" + "jwt" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { fetchSubmodules = false; rev = "f14a4d52e201128b1b00245d11b6de80d6cfdcd9"; @@ -3581,86 +4663,103 @@ version = "0.3.8"; }; webrick = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "089gy5494j560b242vi173wnbj2913hwlwnjkpzld58r96ilc5s3"; type = "gem"; }; version = "1.8.2"; }; websocket = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dr78vh3ag0d1q5gfd8960g1ca9g6arjd2w54mffid8h4i7agrxp"; type = "gem"; }; version = "1.2.11"; }; websocket-driver = { - dependencies = ["websocket-extensions"]; - groups = ["default"]; - platforms = []; + dependencies = [ "websocket-extensions" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nyh873w4lvahcl8kzbjfca26656d5c6z3md4sbqg5y1gfz0157n"; type = "gem"; }; version = "0.7.6"; }; websocket-extensions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hc2g9qps8lmhibl5baa91b4qx8wqw872rgwagml78ydj8qacsqw"; type = "gem"; }; version = "0.1.5"; }; wisper = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rpsi0ziy78cj82sbyyywby4d0aw0a5q84v65qd28vqn79fbq5yf"; type = "gem"; }; version = "2.0.1"; }; xorcist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dbbiy8xlcfvn9ais37xfb5rci4liwakkmxzbkp72wmvlgcrf339"; type = "gem"; }; version = "1.1.3"; }; xpath = { - dependencies = ["nokogiri"]; - groups = ["default" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "nokogiri" ]; + groups = [ + "default" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0bh8lk9hvlpn7vmi6h4hkcwjzvs2y0cmkk3yjjdr8fxvj6fsgzbd"; type = "gem"; }; version = "3.2.0"; }; zeitwerk = { - groups = ["default" "development" "pam_authentication" "production" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "pam_authentication" + "production" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "10cpfdswql21vildiin0q7drg5zfzf2sahnk9hv3nyzzjqwj2bdx"; type = "gem"; }; version = "2.6.18"; }; } - diff --git a/pkgs/servers/mastodon/source.nix b/pkgs/servers/mastodon/source.nix index 8a752ce7d22d58..9d2b79d74b413c 100644 --- a/pkgs/servers/mastodon/source.nix +++ b/pkgs/servers/mastodon/source.nix @@ -1,18 +1,22 @@ # This file was generated by pkgs.mastodon.updateScript. -{ fetchFromGitHub, applyPatches, patches ? [] }: +{ + fetchFromGitHub, + applyPatches, + patches ? [ ], +}: let version = "4.3.2"; in -( - applyPatches { - src = fetchFromGitHub { - owner = "mastodon"; - repo = "mastodon"; - rev = "v${version}"; - hash = "sha256-A1sSUBtlztKFsZ3TY/c9CXFV8LhttRW2JmSU0QSVOIg="; - }; - patches = patches ++ []; - }) // { +(applyPatches { + src = fetchFromGitHub { + owner = "mastodon"; + repo = "mastodon"; + rev = "v${version}"; + hash = "sha256-A1sSUBtlztKFsZ3TY/c9CXFV8LhttRW2JmSU0QSVOIg="; + }; + patches = patches ++ [ ]; +}) +// { inherit version; yarnHash = "sha256-e5c04M6XplAgaVyldU5HmYMYtY3MAWs+a8Z/BGSyGBg="; } diff --git a/pkgs/servers/matrix-appservice-discord/default.nix b/pkgs/servers/matrix-appservice-discord/default.nix index 08240c4ecb4e31..0b139fb2b50be3 100644 --- a/pkgs/servers/matrix-appservice-discord/default.nix +++ b/pkgs/servers/matrix-appservice-discord/default.nix @@ -1,20 +1,22 @@ -{ lib -, mkYarnPackage -, fetchYarnDeps -, fetchFromGitHub -, srcOnly -, makeWrapper -, removeReferencesTo -, python3 -, nodejs -, matrix-sdk-crypto-nodejs +{ + lib, + mkYarnPackage, + fetchYarnDeps, + fetchFromGitHub, + srcOnly, + makeWrapper, + removeReferencesTo, + python3, + nodejs, + matrix-sdk-crypto-nodejs, }: let pin = lib.importJSON ./pin.json; nodeSources = srcOnly nodejs; -in mkYarnPackage rec { +in +mkYarnPackage rec { pname = "matrix-appservice-discord"; inherit (pin) version; @@ -49,7 +51,7 @@ in mkYarnPackage rec { find build -type f -exec \ ${removeReferencesTo}/bin/remove-references-to \ -t "${nodeSources}" {} \; - ''; + ''; }; }; diff --git a/pkgs/servers/matrix-synapse/default.nix b/pkgs/servers/matrix-synapse/default.nix index 1f56420e72c044..39a9f59ce2632e 100644 --- a/pkgs/servers/matrix-synapse/default.nix +++ b/pkgs/servers/matrix-synapse/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 -, openssl -, libiconv -, cargo -, rustPlatform -, rustc -, nixosTests -, callPackage +{ + lib, + stdenv, + fetchFromGitHub, + python3, + openssl, + libiconv, + cargo, + rustPlatform, + rustc, + nixosTests, + callPackage, }: let @@ -56,52 +57,60 @@ python3.pkgs.buildPythonApplication rec { rustc ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + ]; - propagatedBuildInputs = with python3.pkgs; [ - attrs - bcrypt - bleach - canonicaljson - cryptography - ijson - immutabledict - jinja2 - jsonschema - matrix-common - msgpack - python-multipart - netaddr - packaging - phonenumbers - pillow - prometheus-client - pyasn1 - pyasn1-modules - pydantic - pymacaroons - pyopenssl - pyyaml - service-identity - signedjson - sortedcontainers - treq - twisted - typing-extensions - unpaddedbase64 - ] - ++ twisted.optional-dependencies.tls; + propagatedBuildInputs = + with python3.pkgs; + [ + attrs + bcrypt + bleach + canonicaljson + cryptography + ijson + immutabledict + jinja2 + jsonschema + matrix-common + msgpack + python-multipart + netaddr + packaging + phonenumbers + pillow + prometheus-client + pyasn1 + pyasn1-modules + pydantic + pymacaroons + pyopenssl + pyyaml + service-identity + signedjson + sortedcontainers + treq + twisted + typing-extensions + unpaddedbase64 + ] + ++ twisted.optional-dependencies.tls; optional-dependencies = with python3.pkgs; { - postgres = if isPyPy then [ - psycopg2cffi - ] else [ - psycopg2 - ]; + postgres = + if isPyPy then + [ + psycopg2cffi + ] + else + [ + psycopg2 + ]; saml2 = [ pysaml2 ]; @@ -132,13 +141,15 @@ python3.pkgs.buildPythonApplication rec { ]; }; - nativeCheckInputs = [ - openssl - ] ++ (with python3.pkgs; [ - mock - parameterized - ]) - ++ lib.flatten (lib.attrValues optional-dependencies); + nativeCheckInputs = + [ + openssl + ] + ++ (with python3.pkgs; [ + mock + parameterized + ]) + ++ lib.flatten (lib.attrValues optional-dependencies); doCheck = !stdenv.hostPlatform.isDarwin; diff --git a/pkgs/servers/matrix-synapse/matrix-appservice-slack/default.nix b/pkgs/servers/matrix-synapse/matrix-appservice-slack/default.nix index a2f75244b9b35a..1407bda888867d 100644 --- a/pkgs/servers/matrix-synapse/matrix-appservice-slack/default.nix +++ b/pkgs/servers/matrix-synapse/matrix-appservice-slack/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, fetchYarnDeps -, makeWrapper -, matrix-sdk-crypto-nodejs -, mkYarnPackage -, nodejs +{ + lib, + fetchFromGitHub, + fetchYarnDeps, + makeWrapper, + matrix-sdk-crypto-nodejs, + mkYarnPackage, + nodejs, }: let @@ -29,7 +30,8 @@ mkYarnPackage rec { sha256 = data.yarnHash; }; packageResolutions = { - "@matrix-org/matrix-sdk-crypto-nodejs" = "${matrix-sdk-crypto-nodejs}/lib/node_modules/@matrix-org/matrix-sdk-crypto-nodejs"; + "@matrix-org/matrix-sdk-crypto-nodejs" = + "${matrix-sdk-crypto-nodejs}/lib/node_modules/@matrix-org/matrix-sdk-crypto-nodejs"; }; nativeBuildInputs = [ makeWrapper ]; @@ -50,7 +52,10 @@ mkYarnPackage rec { meta = with lib; { description = "Matrix <--> Slack bridge"; mainProgram = "matrix-appservice-slack"; - maintainers = with maintainers; [ beardhatcode chvp ]; + maintainers = with maintainers; [ + beardhatcode + chvp + ]; license = licenses.asl20; }; } diff --git a/pkgs/servers/matrix-synapse/plugins/ldap3.nix b/pkgs/servers/matrix-synapse/plugins/ldap3.nix index 6a631f4f262f03..fa38d1f7b7726b 100644 --- a/pkgs/servers/matrix-synapse/plugins/ldap3.nix +++ b/pkgs/servers/matrix-synapse/plugins/ldap3.nix @@ -1,14 +1,15 @@ -{ lib -, buildPythonPackage -, fetchpatch -, fetchPypi -, ldap3 -, ldaptor -, matrix-synapse-unwrapped -, pytestCheckHook -, service-identity -, setuptools -, twisted +{ + lib, + buildPythonPackage, + fetchpatch, + fetchPypi, + ldap3, + ldaptor, + matrix-synapse-unwrapped, + pytestCheckHook, + service-identity, + setuptools, + twisted, }: buildPythonPackage rec { @@ -31,9 +32,17 @@ buildPythonPackage rec { nativeBuildInputs = [ setuptools ]; - propagatedBuildInputs = [ service-identity ldap3 twisted ]; + propagatedBuildInputs = [ + service-identity + ldap3 + twisted + ]; - nativeCheckInputs = [ ldaptor matrix-synapse-unwrapped pytestCheckHook ]; + nativeCheckInputs = [ + ldaptor + matrix-synapse-unwrapped + pytestCheckHook + ]; pythonImportsCheck = [ "ldap_auth_provider" ]; diff --git a/pkgs/servers/matrix-synapse/plugins/mjolnir-antispam.nix b/pkgs/servers/matrix-synapse/plugins/mjolnir-antispam.nix index 0f7b3d7e4dd965..0aab990f3c22e6 100644 --- a/pkgs/servers/matrix-synapse/plugins/mjolnir-antispam.nix +++ b/pkgs/servers/matrix-synapse/plugins/mjolnir-antispam.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, buildPythonPackage, fetchFromGitHub, matrix-synapse-unwrapped }: +{ + lib, + stdenv, + buildPythonPackage, + fetchFromGitHub, + matrix-synapse-unwrapped, +}: buildPythonPackage rec { pname = "matrix-synapse-mjolnir-antispam"; diff --git a/pkgs/servers/matrix-synapse/plugins/pam.nix b/pkgs/servers/matrix-synapse/plugins/pam.nix index a2f0324883c009..5f535a6be4d7f1 100644 --- a/pkgs/servers/matrix-synapse/plugins/pam.nix +++ b/pkgs/servers/matrix-synapse/plugins/pam.nix @@ -1,4 +1,10 @@ -{ lib, buildPythonPackage, fetchFromGitHub, twisted, python-pam }: +{ + lib, + buildPythonPackage, + fetchFromGitHub, + twisted, + python-pam, +}: buildPythonPackage rec { pname = "matrix-synapse-pam"; @@ -11,7 +17,10 @@ buildPythonPackage rec { sha256 = "0jgz49cwiyih5cg3hr4byva04zjnq8aj7rima9874la9fc5sd2wf"; }; - propagatedBuildInputs = [ twisted python-pam ]; + propagatedBuildInputs = [ + twisted + python-pam + ]; # has no tests doCheck = false; diff --git a/pkgs/servers/matrix-synapse/plugins/rendezvous.nix b/pkgs/servers/matrix-synapse/plugins/rendezvous.nix index 82874d3b3bd1ac..921a62adf9cb3a 100644 --- a/pkgs/servers/matrix-synapse/plugins/rendezvous.nix +++ b/pkgs/servers/matrix-synapse/plugins/rendezvous.nix @@ -1,4 +1,10 @@ -{ lib, buildPythonPackage, fetchFromGitHub, rustPlatform, setuptools-rust }: +{ + lib, + buildPythonPackage, + fetchFromGitHub, + rustPlatform, + setuptools-rust, +}: buildPythonPackage rec { pname = "matrix-http-rendezvous-synapse"; @@ -22,16 +28,17 @@ buildPythonPackage rec { hash = "sha256-TyxDq6YxZUArRj5gpjB1afDQgtUlCVer3Uhq6YKvVYM="; }; - nativeBuildInputs = [ - setuptools-rust - ] ++ (with rustPlatform; [ - cargoSetupHook - maturinBuildHook - ]); + nativeBuildInputs = + [ + setuptools-rust + ] + ++ (with rustPlatform; [ + cargoSetupHook + maturinBuildHook + ]); buildAndTestSubdir = "synapse"; - pythonImportsCheck = [ "matrix_http_rendezvous_synapse" ]; meta = with lib; { diff --git a/pkgs/servers/matrix-synapse/plugins/s3-storage-provider.nix b/pkgs/servers/matrix-synapse/plugins/s3-storage-provider.nix index ba85de7aba2f1c..82a8d0046b3e95 100644 --- a/pkgs/servers/matrix-synapse/plugins/s3-storage-provider.nix +++ b/pkgs/servers/matrix-synapse/plugins/s3-storage-provider.nix @@ -1,13 +1,14 @@ -{ lib -, boto3 -, buildPythonPackage -, fetchFromGitHub -, humanize -, matrix-synapse-unwrapped -, pythonOlder -, tqdm -, twisted -, psycopg2 +{ + lib, + boto3, + buildPythonPackage, + fetchFromGitHub, + humanize, + matrix-synapse-unwrapped, + pythonOlder, + tqdm, + twisted, + psycopg2, }: buildPythonPackage rec { @@ -33,15 +34,16 @@ buildPythonPackage rec { matrix-synapse-unwrapped ]; - propagatedBuildInputs = [ - boto3 - humanize - tqdm - twisted - psycopg2 - ] - # For the s3_media_upload script - ++ matrix-synapse-unwrapped.propagatedBuildInputs; + propagatedBuildInputs = + [ + boto3 + humanize + tqdm + twisted + psycopg2 + ] + # For the s3_media_upload script + ++ matrix-synapse-unwrapped.propagatedBuildInputs; # Tests need network access doCheck = false; diff --git a/pkgs/servers/matrix-synapse/plugins/shared-secret-auth.nix b/pkgs/servers/matrix-synapse/plugins/shared-secret-auth.nix index b5be02a4b21af2..d2455a0009b24e 100644 --- a/pkgs/servers/matrix-synapse/plugins/shared-secret-auth.nix +++ b/pkgs/servers/matrix-synapse/plugins/shared-secret-auth.nix @@ -1,4 +1,10 @@ -{ lib, buildPythonPackage, fetchFromGitHub, matrix-synapse-unwrapped, twisted }: +{ + lib, + buildPythonPackage, + fetchFromGitHub, + matrix-synapse-unwrapped, + twisted, +}: buildPythonPackage rec { pname = "matrix-synapse-shared-secret-auth"; diff --git a/pkgs/servers/matrix-synapse/tools/rust-synapse-compress-state/default.nix b/pkgs/servers/matrix-synapse/tools/rust-synapse-compress-state/default.nix index de1cc21cf47df3..67c8f7497834c5 100644 --- a/pkgs/servers/matrix-synapse/tools/rust-synapse-compress-state/default.nix +++ b/pkgs/servers/matrix-synapse/tools/rust-synapse-compress-state/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, rustPlatform, python3, fetchFromGitHub, pkg-config, openssl }: +{ + lib, + stdenv, + rustPlatform, + python3, + fetchFromGitHub, + pkg-config, + openssl, +}: rustPlatform.buildRustPackage rec { pname = "rust-synapse-compress-state"; @@ -25,7 +33,10 @@ rustPlatform.buildRustPackage rec { # Needed to get openssl-sys to use pkgconfig. env.OPENSSL_NO_VENDOR = 1; - nativeBuildInputs = [ python3 pkg-config ]; + nativeBuildInputs = [ + python3 + pkg-config + ]; buildInputs = [ openssl ]; @@ -34,6 +45,9 @@ rustPlatform.buildRustPackage rec { description = "Tool to compress some state in a Synapse instance's database"; homepage = "https://github.com/matrix-org/rust-synapse-compress-state"; license = licenses.asl20; - maintainers = with maintainers; [ hexa maralorn ]; + maintainers = with maintainers; [ + hexa + maralorn + ]; }; } diff --git a/pkgs/servers/matrix-synapse/tools/synadm.nix b/pkgs/servers/matrix-synapse/tools/synadm.nix index ab66d61c816470..bb932252c77124 100644 --- a/pkgs/servers/matrix-synapse/tools/synadm.nix +++ b/pkgs/servers/matrix-synapse/tools/synadm.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchPypi -, nix-update-script +{ + lib, + python3, + fetchPypi, + nix-update-script, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/servers/matrix-synapse/wrapper.nix b/pkgs/servers/matrix-synapse/wrapper.nix index a0b44e683a7e33..084816b1f38351 100644 --- a/pkgs/servers/matrix-synapse/wrapper.nix +++ b/pkgs/servers/matrix-synapse/wrapper.nix @@ -1,18 +1,23 @@ -{ lib -, stdenv -, makeWrapper -, matrix-synapse-unwrapped -, extras ? [ - "postgres" - "url-preview" - "user-search" - ] ++ lib.optional (lib.meta.availableOn stdenv.hostPlatform matrix-synapse-unwrapped.python.pkgs.systemd) "systemd" -, plugins ? [ ] -, ... +{ + lib, + stdenv, + makeWrapper, + matrix-synapse-unwrapped, + extras ? + [ + "postgres" + "url-preview" + "user-search" + ] + ++ lib.optional (lib.meta.availableOn stdenv.hostPlatform matrix-synapse-unwrapped.python.pkgs.systemd) "systemd", + plugins ? [ ], + ... }: let - extraPackages = lib.concatMap (extra: matrix-synapse-unwrapped.optional-dependencies.${extra}) (lib.unique extras); + extraPackages = lib.concatMap (extra: matrix-synapse-unwrapped.optional-dependencies.${extra}) ( + lib.unique extras + ); pythonEnv = matrix-synapse-unwrapped.python.buildEnv.override { extraLibs = extraPackages ++ plugins; diff --git a/pkgs/servers/mautrix-telegram/default.nix b/pkgs/servers/mautrix-telegram/default.nix index 53bdb18c22ae85..e09c4a4be02252 100644 --- a/pkgs/servers/mautrix-telegram/default.nix +++ b/pkgs/servers/mautrix-telegram/default.nix @@ -1,8 +1,9 @@ -{ lib -, python3 -, fetchPypi -, fetchFromGitHub -, withE2BE ? true +{ + lib, + python3, + fetchPypi, + fetchFromGitHub, + withE2BE ? true, }: let @@ -37,38 +38,43 @@ python.pkgs.buildPythonPackage rec { patches = [ ./0001-Re-add-entrypoint.patch ]; - propagatedBuildInputs = with python.pkgs; ([ - ruamel-yaml - python-magic - commonmark - aiohttp - yarl - (mautrix.override { withOlm = withE2BE; }) - tulir-telethon - asyncpg - mako - setuptools - # speedups - cryptg - aiodns - brotli - # qr_login - pillow - qrcode - # formattednumbers - phonenumbers - # metrics - prometheus-client - # sqlite - aiosqlite - # proxy support - pysocks - ] ++ lib.optionals withE2BE [ - # e2be - python-olm - pycryptodome - unpaddedbase64 - ]); + propagatedBuildInputs = + with python.pkgs; + ( + [ + ruamel-yaml + python-magic + commonmark + aiohttp + yarl + (mautrix.override { withOlm = withE2BE; }) + tulir-telethon + asyncpg + mako + setuptools + # speedups + cryptg + aiodns + brotli + # qr_login + pillow + qrcode + # formattednumbers + phonenumbers + # metrics + prometheus-client + # sqlite + aiosqlite + # proxy support + pysocks + ] + ++ lib.optionals withE2BE [ + # e2be + python-olm + pycryptodome + unpaddedbase64 + ] + ); # has no tests doCheck = false; @@ -78,7 +84,11 @@ python.pkgs.buildPythonPackage rec { description = "Matrix-Telegram hybrid puppeting/relaybot bridge"; license = licenses.agpl3Plus; platforms = platforms.linux; - maintainers = with maintainers; [ nyanloutre ma27 nickcao ]; + maintainers = with maintainers; [ + nyanloutre + ma27 + nickcao + ]; mainProgram = "mautrix-telegram"; }; } diff --git a/pkgs/servers/memos/default.nix b/pkgs/servers/memos/default.nix index c389245dc7426b..1037aa4379d881 100644 --- a/pkgs/servers/memos/default.nix +++ b/pkgs/servers/memos/default.nix @@ -1,4 +1,11 @@ -{ fetchFromGitHub, buildGoModule, jq, buildNpmPackage, lib, makeWrapper }: +{ + fetchFromGitHub, + buildGoModule, + jq, + buildNpmPackage, + lib, + makeWrapper, +}: let version = "0.13.2"; diff --git a/pkgs/servers/minio/default.nix b/pkgs/servers/minio/default.nix index 9af26fb2af303e..1437c2e42536c0 100644 --- a/pkgs/servers/minio/default.nix +++ b/pkgs/servers/minio/default.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: let # The web client verifies, that the server version is a valid datetime string: @@ -7,11 +12,15 @@ let # Example: # versionToTimestamp "2021-04-22T15-44-28Z" # => "2021-04-22T15:44:28Z" - versionToTimestamp = version: + versionToTimestamp = + version: let splitTS = builtins.elemAt (builtins.split "(.*)(T.*)" version) 1; in - builtins.concatStringsSep "" [ (builtins.elemAt splitTS 0) (builtins.replaceStrings [ "-" ] [ ":" ] (builtins.elemAt splitTS 1)) ]; + builtins.concatStringsSep "" [ + (builtins.elemAt splitTS 0) + (builtins.replaceStrings [ "-" ] [ ":" ] (builtins.elemAt splitTS 1)) + ]; # CopyrightYear will be printed to the CLI UI. # Example: @@ -40,14 +49,18 @@ buildGoModule rec { tags = [ "kqueue" ]; - ldflags = let t = "github.com/minio/minio/cmd"; in [ - "-s" - "-w" - "-X ${t}.Version=${versionToTimestamp version}" - "-X ${t}.CopyrightYear=${versionToYear version}" - "-X ${t}.ReleaseTag=RELEASE.${version}" - "-X ${t}.CommitID=${src.rev}" - ]; + ldflags = + let + t = "github.com/minio/minio/cmd"; + in + [ + "-s" + "-w" + "-X ${t}.Version=${versionToTimestamp version}" + "-X ${t}.CopyrightYear=${versionToYear version}" + "-X ${t}.ReleaseTag=RELEASE.${version}" + "-X ${t}.CommitID=${src.rev}" + ]; passthru.tests.minio = nixosTests.minio; diff --git a/pkgs/servers/minio/legacy_fs.nix b/pkgs/servers/minio/legacy_fs.nix index 2ba0f26ed4249a..20998bfd22077d 100644 --- a/pkgs/servers/minio/legacy_fs.nix +++ b/pkgs/servers/minio/legacy_fs.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: let # The web client verifies, that the server version is a valid datetime string: @@ -7,11 +12,15 @@ let # Example: # versionToTimestamp "2021-04-22T15-44-28Z" # => "2021-04-22T15:44:28Z" - versionToTimestamp = version: + versionToTimestamp = + version: let splitTS = builtins.elemAt (builtins.split "(.*)(T.*)" version) 1; in - builtins.concatStringsSep "" [ (builtins.elemAt splitTS 0) (builtins.replaceStrings [ "-" ] [ ":" ] (builtins.elemAt splitTS 1)) ]; + builtins.concatStringsSep "" [ + (builtins.elemAt splitTS 0) + (builtins.replaceStrings [ "-" ] [ ":" ] (builtins.elemAt splitTS 1)) + ]; in buildGoModule rec { pname = "minio"; @@ -34,9 +43,17 @@ buildGoModule rec { tags = [ "kqueue" ]; - ldflags = let t = "github.com/minio/minio/cmd"; in [ - "-s" "-w" "-X ${t}.Version=${versionToTimestamp version}" "-X ${t}.ReleaseTag=RELEASE.${version}" "-X ${t}.CommitID=${src.rev}" - ]; + ldflags = + let + t = "github.com/minio/minio/cmd"; + in + [ + "-s" + "-w" + "-X ${t}.Version=${versionToTimestamp version}" + "-X ${t}.ReleaseTag=RELEASE.${version}" + "-X ${t}.CommitID=${src.rev}" + ]; passthru.tests.minio = nixosTests.minio; diff --git a/pkgs/servers/misc/qremotecontrol-server/default.nix b/pkgs/servers/misc/qremotecontrol-server/default.nix index 104a2b876c9ba6..02a044e5250ad1 100644 --- a/pkgs/servers/misc/qremotecontrol-server/default.nix +++ b/pkgs/servers/misc/qremotecontrol-server/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchgit -, qmake -, wrapQtAppsHook -, qtbase -, xorg +{ + lib, + stdenv, + fetchgit, + qmake, + wrapQtAppsHook, + qtbase, + xorg, }: stdenv.mkDerivation { diff --git a/pkgs/servers/mobilizon/default.nix b/pkgs/servers/mobilizon/default.nix index e4a75a4c91cebb..a007a30f6f2606 100644 --- a/pkgs/servers/mobilizon/default.nix +++ b/pkgs/servers/mobilizon/default.nix @@ -1,14 +1,15 @@ -{ lib -, callPackage -, writeShellScriptBin -, beamPackages -, mix2nix -, fetchFromGitHub -, git -, cmake -, nixosTests -, mobilizon-frontend -, ... +{ + lib, + callPackage, + writeShellScriptBin, + beamPackages, + mix2nix, + fetchFromGitHub, + git, + cmake, + nixosTests, + mobilizon-frontend, + ... }: let @@ -18,16 +19,22 @@ in mixRelease rec { inherit (common) pname version src; - nativeBuildInputs = [ git cmake ]; + nativeBuildInputs = [ + git + cmake + ]; mixNixDeps = import ./mix.nix { inherit beamPackages lib; - overrides = (final: prev: - (lib.mapAttrs - (_: value: value.override { + overrides = ( + final: prev: + (lib.mapAttrs ( + _: value: + value.override { appConfigPath = src + "/config"; - }) - prev) // { + } + ) prev) + // { fast_html = prev.fast_html.override { nativeBuildInputs = [ cmake ]; }; @@ -38,7 +45,8 @@ mixRelease rec { owner = "elixir-cldr"; repo = "cldr"; rev = "v${old.version}"; - sha256 = assert old.version == "2.37.5"; + sha256 = + assert old.version == "2.37.5"; "sha256-T5Qvuo+xPwpgBsqHNZYnTCA4loToeBn1LKTMsDcCdYs="; }; postInstall = '' @@ -60,7 +68,10 @@ mixRelease rec { rev = "6e143dcde0a2854c4f0d72816b7ecab696432779"; sha256 = "sha256-Da+/28SPZuUQBi8fQj31zmMvhMrYUaQIW4U4E+mRtMg="; }; - beamDeps = with final; [ httpoison jose ]; + beamDeps = with final; [ + httpoison + jose + ]; }; icalendar = buildMix rec { name = "icalendar"; @@ -71,7 +82,11 @@ mixRelease rec { rev = "1033d922c82a7223db0ec138e2316557b70ff49f"; sha256 = "sha256-N3bJZznNazLewHS4c2B7LP1lgxd1wev+EWVlQ7rOwfU="; }; - beamDeps = with final; [ mix_test_watch ex_doc timex ]; + beamDeps = with final; [ + mix_test_watch + ex_doc + timex + ]; }; rajska = buildMix rec { name = "rajska"; @@ -82,7 +97,14 @@ mixRelease rec { rev = "0c036448e261e8be6a512581c592fadf48982d84"; sha256 = "sha256-4pfply1vTAIT2Xvm3kONmrCK05xKfXFvcb8EKoSCXBE="; }; - beamDeps = with final; [ ex_doc credo absinthe excoveralls hammer mock ]; + beamDeps = with final; [ + ex_doc + credo + absinthe + excoveralls + hammer + mock + ]; }; exkismet = buildMix rec { name = "exkismet"; @@ -93,18 +115,24 @@ mixRelease rec { rev = "8b5485fde00fafbde20f315bec387a77f7358334"; sha256 = "sha256-ttgCWoBKU7VTjZJBhZNtqVF4kN7psBr/qOeR65MbTqw="; }; - beamDeps = with final; [ httpoison ex_doc credo doctor dialyxir ]; + beamDeps = with final; [ + httpoison + ex_doc + credo + doctor + dialyxir + ]; }; - }); + } + ); }; # Install the compiled js part - preBuild = - '' - cp -a "${mobilizon-frontend}/static" ./priv - chmod 770 -R ./priv - ''; + preBuild = '' + cp -a "${mobilizon-frontend}/static" ./priv + chmod 770 -R ./priv + ''; postBuild = '' mix phx.digest --no-deps-check @@ -124,6 +152,9 @@ mixRelease rec { description = "Mobilizon is an online tool to help manage your events, your profiles and your groups"; homepage = "https://joinmobilizon.org/"; license = licenses.agpl3Plus; - maintainers = with maintainers; [ minijackson erictapen ]; + maintainers = with maintainers; [ + minijackson + erictapen + ]; }; } diff --git a/pkgs/servers/mobilizon/mix.nix b/pkgs/servers/mobilizon/mix.nix index ca33f819723ac7..2df0969e909421 100644 --- a/pkgs/servers/mobilizon/mix.nix +++ b/pkgs/servers/mobilizon/mix.nix @@ -1,4 +1,8 @@ -{ lib, beamPackages, overrides ? (x: y: {}) }: +{ + lib, + beamPackages, + overrides ? (x: y: { }), +}: let buildRebar3 = lib.makeOverridable beamPackages.buildRebar3; @@ -7,2008 +11,2269 @@ let self = packages // (overrides self packages); - packages = with beamPackages; with self; { - absinthe = buildMix rec { - name = "absinthe"; - version = "1.7.6"; + packages = + with beamPackages; + with self; + { + absinthe = buildMix rec { + name = "absinthe"; + version = "1.7.6"; + + src = fetchHex { + pkg = "absinthe"; + version = "${version}"; + sha256 = "e7626951ca5eec627da960615b51009f3a774765406ff02722b1d818f17e5778"; + }; + + beamDeps = [ + dataloader + decimal + nimble_parsec + telemetry + ]; + }; + + absinthe_phoenix = buildMix rec { + name = "absinthe_phoenix"; + version = "2.0.2"; + + src = fetchHex { + pkg = "absinthe_phoenix"; + version = "${version}"; + sha256 = "d36918925c380dc7d2ed7d039c9a3b4182ec36723f7417a68745ade5aab22f8d"; + }; + + beamDeps = [ + absinthe + absinthe_plug + decimal + phoenix + phoenix_html + phoenix_pubsub + ]; + }; + + absinthe_plug = buildMix rec { + name = "absinthe_plug"; + version = "1.5.8"; + + src = fetchHex { + pkg = "absinthe_plug"; + version = "${version}"; + sha256 = "bbb04176647b735828861e7b2705465e53e2cf54ccf5a73ddd1ebd855f996e5a"; + }; + + beamDeps = [ + absinthe + plug + ]; + }; + + argon2_elixir = buildMix rec { + name = "argon2_elixir"; + version = "4.0.0"; - src = fetchHex { - pkg = "absinthe"; - version = "${version}"; - sha256 = "e7626951ca5eec627da960615b51009f3a774765406ff02722b1d818f17e5778"; - }; - - beamDeps = [ dataloader decimal nimble_parsec telemetry ]; - }; - - absinthe_phoenix = buildMix rec { - name = "absinthe_phoenix"; - version = "2.0.2"; - - src = fetchHex { - pkg = "absinthe_phoenix"; - version = "${version}"; - sha256 = "d36918925c380dc7d2ed7d039c9a3b4182ec36723f7417a68745ade5aab22f8d"; - }; + src = fetchHex { + pkg = "argon2_elixir"; + version = "${version}"; + sha256 = "f9da27cf060c9ea61b1bd47837a28d7e48a8f6fa13a745e252556c14f9132c7f"; + }; - beamDeps = [ absinthe absinthe_plug decimal phoenix phoenix_html phoenix_pubsub ]; - }; - - absinthe_plug = buildMix rec { - name = "absinthe_plug"; - version = "1.5.8"; - - src = fetchHex { - pkg = "absinthe_plug"; - version = "${version}"; - sha256 = "bbb04176647b735828861e7b2705465e53e2cf54ccf5a73ddd1ebd855f996e5a"; + beamDeps = [ + comeonin + elixir_make + ]; }; - beamDeps = [ absinthe plug ]; - }; - - argon2_elixir = buildMix rec { - name = "argon2_elixir"; - version = "4.0.0"; + atomex = buildMix rec { + name = "atomex"; + version = "0.5.1"; + + src = fetchHex { + pkg = "atomex"; + version = "${version}"; + sha256 = "6248891b5fcab8503982e090eedeeadb757a6311c2ef2e2998b874f7d319ab3f"; + }; - src = fetchHex { - pkg = "argon2_elixir"; - version = "${version}"; - sha256 = "f9da27cf060c9ea61b1bd47837a28d7e48a8f6fa13a745e252556c14f9132c7f"; + beamDeps = [ xml_builder ]; }; - beamDeps = [ comeonin elixir_make ]; - }; - - atomex = buildMix rec { - name = "atomex"; - version = "0.5.1"; - - src = fetchHex { - pkg = "atomex"; - version = "${version}"; - sha256 = "6248891b5fcab8503982e090eedeeadb757a6311c2ef2e2998b874f7d319ab3f"; - }; - - beamDeps = [ xml_builder ]; - }; - - bandit = buildMix rec { - name = "bandit"; - version = "1.2.3"; - - src = fetchHex { - pkg = "bandit"; - version = "${version}"; - sha256 = "3e29150245a9b5f56944434e5240966e75c917dad248f689ab589b32187a81af"; - }; - - beamDeps = [ hpax plug telemetry thousand_island websock ]; - }; - - bunt = buildMix rec { - name = "bunt"; - version = "1.0.0"; - - src = fetchHex { - pkg = "bunt"; - version = "${version}"; - sha256 = "dc5f86aa08a5f6fa6b8096f0735c4e76d54ae5c9fa2c143e5a1fc7c1cd9bb6b5"; + bandit = buildMix rec { + name = "bandit"; + version = "1.2.3"; + + src = fetchHex { + pkg = "bandit"; + version = "${version}"; + sha256 = "3e29150245a9b5f56944434e5240966e75c917dad248f689ab589b32187a81af"; + }; + + beamDeps = [ + hpax + plug + telemetry + thousand_island + websock + ]; }; - beamDeps = []; - }; + bunt = buildMix rec { + name = "bunt"; + version = "1.0.0"; - cachex = buildMix rec { - name = "cachex"; - version = "3.6.0"; + src = fetchHex { + pkg = "bunt"; + version = "${version}"; + sha256 = "dc5f86aa08a5f6fa6b8096f0735c4e76d54ae5c9fa2c143e5a1fc7c1cd9bb6b5"; + }; - src = fetchHex { - pkg = "cachex"; - version = "${version}"; - sha256 = "ebf24e373883bc8e0c8d894a63bbe102ae13d918f790121f5cfe6e485cc8e2e2"; + beamDeps = [ ]; }; - beamDeps = [ eternal jumper sleeplocks unsafe ]; - }; + cachex = buildMix rec { + name = "cachex"; + version = "3.6.0"; - castore = buildMix rec { - name = "castore"; - version = "1.0.5"; + src = fetchHex { + pkg = "cachex"; + version = "${version}"; + sha256 = "ebf24e373883bc8e0c8d894a63bbe102ae13d918f790121f5cfe6e485cc8e2e2"; + }; - src = fetchHex { - pkg = "castore"; - version = "${version}"; - sha256 = "8d7c597c3e4a64c395980882d4bca3cebb8d74197c590dc272cfd3b6a6310578"; + beamDeps = [ + eternal + jumper + sleeplocks + unsafe + ]; }; - beamDeps = []; - }; + castore = buildMix rec { + name = "castore"; + version = "1.0.5"; - certifi = buildRebar3 rec { - name = "certifi"; - version = "2.12.0"; + src = fetchHex { + pkg = "castore"; + version = "${version}"; + sha256 = "8d7c597c3e4a64c395980882d4bca3cebb8d74197c590dc272cfd3b6a6310578"; + }; - src = fetchHex { - pkg = "certifi"; - version = "${version}"; - sha256 = "ee68d85df22e554040cdb4be100f33873ac6051387baf6a8f6ce82272340ff1c"; + beamDeps = [ ]; }; - beamDeps = []; - }; + certifi = buildRebar3 rec { + name = "certifi"; + version = "2.12.0"; - cldr_utils = buildMix rec { - name = "cldr_utils"; - version = "2.24.2"; + src = fetchHex { + pkg = "certifi"; + version = "${version}"; + sha256 = "ee68d85df22e554040cdb4be100f33873ac6051387baf6a8f6ce82272340ff1c"; + }; - src = fetchHex { - pkg = "cldr_utils"; - version = "${version}"; - sha256 = "3362b838836a9f0fa309de09a7127e36e67310e797d556db92f71b548832c7cf"; + beamDeps = [ ]; }; - beamDeps = [ castore certifi decimal ]; - }; + cldr_utils = buildMix rec { + name = "cldr_utils"; + version = "2.24.2"; - codepagex = buildMix rec { - name = "codepagex"; - version = "0.1.6"; + src = fetchHex { + pkg = "cldr_utils"; + version = "${version}"; + sha256 = "3362b838836a9f0fa309de09a7127e36e67310e797d556db92f71b548832c7cf"; + }; - src = fetchHex { - pkg = "codepagex"; - version = "${version}"; - sha256 = "1521461097dde281edf084062f525a4edc6a5e49f4fd1f5ec41c9c4955d5bd59"; + beamDeps = [ + castore + certifi + decimal + ]; }; - beamDeps = []; - }; + codepagex = buildMix rec { + name = "codepagex"; + version = "0.1.6"; - combine = buildMix rec { - name = "combine"; - version = "0.10.0"; + src = fetchHex { + pkg = "codepagex"; + version = "${version}"; + sha256 = "1521461097dde281edf084062f525a4edc6a5e49f4fd1f5ec41c9c4955d5bd59"; + }; - src = fetchHex { - pkg = "combine"; - version = "${version}"; - sha256 = "1b1dbc1790073076580d0d1d64e42eae2366583e7aecd455d1215b0d16f2451b"; + beamDeps = [ ]; }; - beamDeps = []; - }; + combine = buildMix rec { + name = "combine"; + version = "0.10.0"; - comeonin = buildMix rec { - name = "comeonin"; - version = "5.4.0"; + src = fetchHex { + pkg = "combine"; + version = "${version}"; + sha256 = "1b1dbc1790073076580d0d1d64e42eae2366583e7aecd455d1215b0d16f2451b"; + }; - src = fetchHex { - pkg = "comeonin"; - version = "${version}"; - sha256 = "796393a9e50d01999d56b7b8420ab0481a7538d0caf80919da493b4a6e51faf1"; + beamDeps = [ ]; }; - beamDeps = []; - }; + comeonin = buildMix rec { + name = "comeonin"; + version = "5.4.0"; - cors_plug = buildMix rec { - name = "cors_plug"; - version = "3.0.3"; + src = fetchHex { + pkg = "comeonin"; + version = "${version}"; + sha256 = "796393a9e50d01999d56b7b8420ab0481a7538d0caf80919da493b4a6e51faf1"; + }; - src = fetchHex { - pkg = "cors_plug"; - version = "${version}"; - sha256 = "3f2d759e8c272ed3835fab2ef11b46bddab8c1ab9528167bd463b6452edf830d"; + beamDeps = [ ]; }; - beamDeps = [ plug ]; - }; + cors_plug = buildMix rec { + name = "cors_plug"; + version = "3.0.3"; - credo = buildMix rec { - name = "credo"; - version = "1.7.5"; + src = fetchHex { + pkg = "cors_plug"; + version = "${version}"; + sha256 = "3f2d759e8c272ed3835fab2ef11b46bddab8c1ab9528167bd463b6452edf830d"; + }; - src = fetchHex { - pkg = "credo"; - version = "${version}"; - sha256 = "f799e9b5cd1891577d8c773d245668aa74a2fcd15eb277f51a0131690ebfb3fd"; + beamDeps = [ plug ]; }; - beamDeps = [ bunt file_system jason ]; - }; + credo = buildMix rec { + name = "credo"; + version = "1.7.5"; - credo_code_climate = buildMix rec { - name = "credo_code_climate"; - version = "0.1.0"; + src = fetchHex { + pkg = "credo"; + version = "${version}"; + sha256 = "f799e9b5cd1891577d8c773d245668aa74a2fcd15eb277f51a0131690ebfb3fd"; + }; - src = fetchHex { - pkg = "credo_code_climate"; - version = "${version}"; - sha256 = "75529fe38056f4e229821d604758282838b8397c82e2c12e409fda16b16821ca"; + beamDeps = [ + bunt + file_system + jason + ]; }; - beamDeps = [ credo jason ]; - }; + credo_code_climate = buildMix rec { + name = "credo_code_climate"; + version = "0.1.0"; - dataloader = buildMix rec { - name = "dataloader"; - version = "2.0.0"; + src = fetchHex { + pkg = "credo_code_climate"; + version = "${version}"; + sha256 = "75529fe38056f4e229821d604758282838b8397c82e2c12e409fda16b16821ca"; + }; - src = fetchHex { - pkg = "dataloader"; - version = "${version}"; - sha256 = "09d61781b76ce216e395cdbc883ff00d00f46a503e215c22722dba82507dfef0"; + beamDeps = [ + credo + jason + ]; }; - beamDeps = [ ecto telemetry ]; - }; + dataloader = buildMix rec { + name = "dataloader"; + version = "2.0.0"; - db_connection = buildMix rec { - name = "db_connection"; - version = "2.6.0"; + src = fetchHex { + pkg = "dataloader"; + version = "${version}"; + sha256 = "09d61781b76ce216e395cdbc883ff00d00f46a503e215c22722dba82507dfef0"; + }; - src = fetchHex { - pkg = "db_connection"; - version = "${version}"; - sha256 = "c2f992d15725e721ec7fbc1189d4ecdb8afef76648c746a8e1cad35e3b8a35f3"; + beamDeps = [ + ecto + telemetry + ]; }; - beamDeps = [ telemetry ]; - }; + db_connection = buildMix rec { + name = "db_connection"; + version = "2.6.0"; - decimal = buildMix rec { - name = "decimal"; - version = "2.1.1"; + src = fetchHex { + pkg = "db_connection"; + version = "${version}"; + sha256 = "c2f992d15725e721ec7fbc1189d4ecdb8afef76648c746a8e1cad35e3b8a35f3"; + }; - src = fetchHex { - pkg = "decimal"; - version = "${version}"; - sha256 = "53cfe5f497ed0e7771ae1a475575603d77425099ba5faef9394932b35020ffcc"; + beamDeps = [ telemetry ]; }; - beamDeps = []; - }; + decimal = buildMix rec { + name = "decimal"; + version = "2.1.1"; - dialyxir = buildMix rec { - name = "dialyxir"; - version = "1.4.3"; + src = fetchHex { + pkg = "decimal"; + version = "${version}"; + sha256 = "53cfe5f497ed0e7771ae1a475575603d77425099ba5faef9394932b35020ffcc"; + }; - src = fetchHex { - pkg = "dialyxir"; - version = "${version}"; - sha256 = "bf2cfb75cd5c5006bec30141b131663299c661a864ec7fbbc72dfa557487a986"; + beamDeps = [ ]; }; - beamDeps = [ erlex ]; - }; + dialyxir = buildMix rec { + name = "dialyxir"; + version = "1.4.3"; - digital_token = buildMix rec { - name = "digital_token"; - version = "0.6.0"; + src = fetchHex { + pkg = "dialyxir"; + version = "${version}"; + sha256 = "bf2cfb75cd5c5006bec30141b131663299c661a864ec7fbbc72dfa557487a986"; + }; - src = fetchHex { - pkg = "digital_token"; - version = "${version}"; - sha256 = "2455d626e7c61a128b02a4a8caddb092548c3eb613ac6f6a85e4cbb6caddc4d1"; + beamDeps = [ erlex ]; }; - beamDeps = [ cldr_utils jason ]; - }; + digital_token = buildMix rec { + name = "digital_token"; + version = "0.6.0"; - doctor = buildMix rec { - name = "doctor"; - version = "0.21.0"; + src = fetchHex { + pkg = "digital_token"; + version = "${version}"; + sha256 = "2455d626e7c61a128b02a4a8caddb092548c3eb613ac6f6a85e4cbb6caddc4d1"; + }; - src = fetchHex { - pkg = "doctor"; - version = "${version}"; - sha256 = "a227831daa79784eb24cdeedfa403c46a4cb7d0eab0e31232ec654314447e4e0"; + beamDeps = [ + cldr_utils + jason + ]; }; - beamDeps = [ decimal ]; - }; + doctor = buildMix rec { + name = "doctor"; + version = "0.21.0"; - earmark_parser = buildMix rec { - name = "earmark_parser"; - version = "1.4.39"; + src = fetchHex { + pkg = "doctor"; + version = "${version}"; + sha256 = "a227831daa79784eb24cdeedfa403c46a4cb7d0eab0e31232ec654314447e4e0"; + }; - src = fetchHex { - pkg = "earmark_parser"; - version = "${version}"; - sha256 = "06553a88d1f1846da9ef066b87b57c6f605552cfbe40d20bd8d59cc6bde41944"; + beamDeps = [ decimal ]; }; - beamDeps = []; - }; + earmark_parser = buildMix rec { + name = "earmark_parser"; + version = "1.4.39"; - eblurhash = buildRebar3 rec { - name = "eblurhash"; - version = "1.2.2"; + src = fetchHex { + pkg = "earmark_parser"; + version = "${version}"; + sha256 = "06553a88d1f1846da9ef066b87b57c6f605552cfbe40d20bd8d59cc6bde41944"; + }; - src = fetchHex { - pkg = "eblurhash"; - version = "${version}"; - sha256 = "8c20ca00904de023a835a9dcb7b7762fed32264c85a80c3cafa85288e405044c"; + beamDeps = [ ]; }; - beamDeps = []; - }; + eblurhash = buildRebar3 rec { + name = "eblurhash"; + version = "1.2.2"; - ecto = buildMix rec { - name = "ecto"; - version = "3.11.1"; + src = fetchHex { + pkg = "eblurhash"; + version = "${version}"; + sha256 = "8c20ca00904de023a835a9dcb7b7762fed32264c85a80c3cafa85288e405044c"; + }; - src = fetchHex { - pkg = "ecto"; - version = "${version}"; - sha256 = "ebd3d3772cd0dfcd8d772659e41ed527c28b2a8bde4b00fe03e0463da0f1983b"; + beamDeps = [ ]; }; - beamDeps = [ decimal jason telemetry ]; - }; + ecto = buildMix rec { + name = "ecto"; + version = "3.11.1"; - ecto_autoslug_field = buildMix rec { - name = "ecto_autoslug_field"; - version = "3.1.0"; + src = fetchHex { + pkg = "ecto"; + version = "${version}"; + sha256 = "ebd3d3772cd0dfcd8d772659e41ed527c28b2a8bde4b00fe03e0463da0f1983b"; + }; - src = fetchHex { - pkg = "ecto_autoslug_field"; - version = "${version}"; - sha256 = "b6ddd614805263e24b5c169532c934440d0289181cce873061fca3a8e92fd9ff"; + beamDeps = [ + decimal + jason + telemetry + ]; }; - beamDeps = [ ecto slugify ]; - }; + ecto_autoslug_field = buildMix rec { + name = "ecto_autoslug_field"; + version = "3.1.0"; - ecto_dev_logger = buildMix rec { - name = "ecto_dev_logger"; - version = "0.10.0"; + src = fetchHex { + pkg = "ecto_autoslug_field"; + version = "${version}"; + sha256 = "b6ddd614805263e24b5c169532c934440d0289181cce873061fca3a8e92fd9ff"; + }; - src = fetchHex { - pkg = "ecto_dev_logger"; - version = "${version}"; - sha256 = "a55e58bad5d5c9b8ef2a3c3347dbdf7efa880a5371cf1457e44b41f489a43927"; + beamDeps = [ + ecto + slugify + ]; }; - beamDeps = [ ecto jason ]; - }; + ecto_dev_logger = buildMix rec { + name = "ecto_dev_logger"; + version = "0.10.0"; - ecto_enum = buildMix rec { - name = "ecto_enum"; - version = "1.4.0"; + src = fetchHex { + pkg = "ecto_dev_logger"; + version = "${version}"; + sha256 = "a55e58bad5d5c9b8ef2a3c3347dbdf7efa880a5371cf1457e44b41f489a43927"; + }; - src = fetchHex { - pkg = "ecto_enum"; - version = "${version}"; - sha256 = "8fb55c087181c2b15eee406519dc22578fa60dd82c088be376d0010172764ee4"; + beamDeps = [ + ecto + jason + ]; }; - beamDeps = [ ecto ecto_sql postgrex ]; - }; + ecto_enum = buildMix rec { + name = "ecto_enum"; + version = "1.4.0"; - ecto_shortuuid = buildMix rec { - name = "ecto_shortuuid"; - version = "0.2.0"; + src = fetchHex { + pkg = "ecto_enum"; + version = "${version}"; + sha256 = "8fb55c087181c2b15eee406519dc22578fa60dd82c088be376d0010172764ee4"; + }; - src = fetchHex { - pkg = "ecto_shortuuid"; - version = "${version}"; - sha256 = "b92e3b71e86be92f5a7ef6f3de170e7864454e630f7b01dd930414baf38efb65"; + beamDeps = [ + ecto + ecto_sql + postgrex + ]; }; - beamDeps = [ ecto shortuuid ]; - }; + ecto_shortuuid = buildMix rec { + name = "ecto_shortuuid"; + version = "0.2.0"; - ecto_sql = buildMix rec { - name = "ecto_sql"; - version = "3.11.1"; + src = fetchHex { + pkg = "ecto_shortuuid"; + version = "${version}"; + sha256 = "b92e3b71e86be92f5a7ef6f3de170e7864454e630f7b01dd930414baf38efb65"; + }; - src = fetchHex { - pkg = "ecto_sql"; - version = "${version}"; - sha256 = "ce14063ab3514424276e7e360108ad6c2308f6d88164a076aac8a387e1fea634"; + beamDeps = [ + ecto + shortuuid + ]; }; - beamDeps = [ db_connection ecto postgrex telemetry ]; - }; + ecto_sql = buildMix rec { + name = "ecto_sql"; + version = "3.11.1"; - elixir_feed_parser = buildMix rec { - name = "elixir_feed_parser"; - version = "2.1.0"; + src = fetchHex { + pkg = "ecto_sql"; + version = "${version}"; + sha256 = "ce14063ab3514424276e7e360108ad6c2308f6d88164a076aac8a387e1fea634"; + }; - src = fetchHex { - pkg = "elixir_feed_parser"; - version = "${version}"; - sha256 = "2d3c62fe7b396ee3b73d7160bc8fadbd78bfe9597c98c7d79b3f1038d9cba28f"; + beamDeps = [ + db_connection + ecto + postgrex + telemetry + ]; }; - beamDeps = [ timex ]; - }; + elixir_feed_parser = buildMix rec { + name = "elixir_feed_parser"; + version = "2.1.0"; - elixir_make = buildMix rec { - name = "elixir_make"; - version = "0.7.8"; + src = fetchHex { + pkg = "elixir_feed_parser"; + version = "${version}"; + sha256 = "2d3c62fe7b396ee3b73d7160bc8fadbd78bfe9597c98c7d79b3f1038d9cba28f"; + }; - src = fetchHex { - pkg = "elixir_make"; - version = "${version}"; - sha256 = "7a71945b913d37ea89b06966e1342c85cfe549b15e6d6d081e8081c493062c07"; + beamDeps = [ timex ]; }; - beamDeps = [ castore certifi ]; - }; + elixir_make = buildMix rec { + name = "elixir_make"; + version = "0.7.8"; - erlex = buildMix rec { - name = "erlex"; - version = "0.2.6"; + src = fetchHex { + pkg = "elixir_make"; + version = "${version}"; + sha256 = "7a71945b913d37ea89b06966e1342c85cfe549b15e6d6d081e8081c493062c07"; + }; - src = fetchHex { - pkg = "erlex"; - version = "${version}"; - sha256 = "2ed2e25711feb44d52b17d2780eabf998452f6efda104877a3881c2f8c0c0c75"; + beamDeps = [ + castore + certifi + ]; }; - beamDeps = []; - }; + erlex = buildMix rec { + name = "erlex"; + version = "0.2.6"; - erlport = buildRebar3 rec { - name = "erlport"; - version = "0.11.0"; + src = fetchHex { + pkg = "erlex"; + version = "${version}"; + sha256 = "2ed2e25711feb44d52b17d2780eabf998452f6efda104877a3881c2f8c0c0c75"; + }; - src = fetchHex { - pkg = "erlport"; - version = "${version}"; - sha256 = "8eb136ccaf3948d329b8d1c3278ad2e17e2a7319801bc4cc2da6db278204eee4"; + beamDeps = [ ]; }; - beamDeps = []; - }; + erlport = buildRebar3 rec { + name = "erlport"; + version = "0.11.0"; - eternal = buildMix rec { - name = "eternal"; - version = "1.2.2"; + src = fetchHex { + pkg = "erlport"; + version = "${version}"; + sha256 = "8eb136ccaf3948d329b8d1c3278ad2e17e2a7319801bc4cc2da6db278204eee4"; + }; - src = fetchHex { - pkg = "eternal"; - version = "${version}"; - sha256 = "2c9fe32b9c3726703ba5e1d43a1d255a4f3f2d8f8f9bc19f094c7cb1a7a9e782"; + beamDeps = [ ]; }; - beamDeps = []; - }; + eternal = buildMix rec { + name = "eternal"; + version = "1.2.2"; - ex_cldr = buildMix rec { - name = "ex_cldr"; - version = "2.37.5"; + src = fetchHex { + pkg = "eternal"; + version = "${version}"; + sha256 = "2c9fe32b9c3726703ba5e1d43a1d255a4f3f2d8f8f9bc19f094c7cb1a7a9e782"; + }; - src = fetchHex { - pkg = "ex_cldr"; - version = "${version}"; - sha256 = "74ad5ddff791112ce4156382e171a5f5d3766af9d5c4675e0571f081fe136479"; + beamDeps = [ ]; }; - beamDeps = [ cldr_utils decimal gettext jason nimble_parsec ]; - }; + ex_cldr = buildMix rec { + name = "ex_cldr"; + version = "2.37.5"; - ex_cldr_calendars = buildMix rec { - name = "ex_cldr_calendars"; - version = "1.23.0"; + src = fetchHex { + pkg = "ex_cldr"; + version = "${version}"; + sha256 = "74ad5ddff791112ce4156382e171a5f5d3766af9d5c4675e0571f081fe136479"; + }; - src = fetchHex { - pkg = "ex_cldr_calendars"; - version = "${version}"; - sha256 = "06d2407e699032d5cdc515593b7ce7869f10ce28e98a4ed68d9b21e5001036d4"; + beamDeps = [ + cldr_utils + decimal + gettext + jason + nimble_parsec + ]; }; - beamDeps = [ ex_cldr_numbers ex_doc jason ]; - }; - - ex_cldr_currencies = buildMix rec { - name = "ex_cldr_currencies"; - version = "2.15.1"; + ex_cldr_calendars = buildMix rec { + name = "ex_cldr_calendars"; + version = "1.23.0"; + + src = fetchHex { + pkg = "ex_cldr_calendars"; + version = "${version}"; + sha256 = "06d2407e699032d5cdc515593b7ce7869f10ce28e98a4ed68d9b21e5001036d4"; + }; - src = fetchHex { - pkg = "ex_cldr_currencies"; - version = "${version}"; - sha256 = "31df8bd37688340f8819bdd770eb17d659652078d34db632b85d4a32864d6a25"; + beamDeps = [ + ex_cldr_numbers + ex_doc + jason + ]; }; - beamDeps = [ ex_cldr jason ]; - }; + ex_cldr_currencies = buildMix rec { + name = "ex_cldr_currencies"; + version = "2.15.1"; - ex_cldr_dates_times = buildMix rec { - name = "ex_cldr_dates_times"; - version = "2.16.0"; - - src = fetchHex { - pkg = "ex_cldr_dates_times"; - version = "${version}"; - sha256 = "0f2f250d479cadda4e0ef3a5e3d936ae7ba1a3f1199db6791e284e86203495b1"; + src = fetchHex { + pkg = "ex_cldr_currencies"; + version = "${version}"; + sha256 = "31df8bd37688340f8819bdd770eb17d659652078d34db632b85d4a32864d6a25"; + }; + + beamDeps = [ + ex_cldr + jason + ]; }; - beamDeps = [ ex_cldr_calendars ex_cldr_numbers jason ]; - }; + ex_cldr_dates_times = buildMix rec { + name = "ex_cldr_dates_times"; + version = "2.16.0"; - ex_cldr_languages = buildMix rec { - name = "ex_cldr_languages"; - version = "0.3.3"; + src = fetchHex { + pkg = "ex_cldr_dates_times"; + version = "${version}"; + sha256 = "0f2f250d479cadda4e0ef3a5e3d936ae7ba1a3f1199db6791e284e86203495b1"; + }; - src = fetchHex { - pkg = "ex_cldr_languages"; - version = "${version}"; - sha256 = "22fb1fef72b7b4b4872d243b34e7b83734247a78ad87377986bf719089cc447a"; + beamDeps = [ + ex_cldr_calendars + ex_cldr_numbers + jason + ]; }; - beamDeps = [ ex_cldr jason ]; - }; - - ex_cldr_numbers = buildMix rec { - name = "ex_cldr_numbers"; - version = "2.32.4"; + ex_cldr_languages = buildMix rec { + name = "ex_cldr_languages"; + version = "0.3.3"; - src = fetchHex { - pkg = "ex_cldr_numbers"; - version = "${version}"; - sha256 = "6fd5a82f0785418fa8b698c0be2b1845dff92b77f1b3172c763d37868fb503d2"; + src = fetchHex { + pkg = "ex_cldr_languages"; + version = "${version}"; + sha256 = "22fb1fef72b7b4b4872d243b34e7b83734247a78ad87377986bf719089cc447a"; + }; + + beamDeps = [ + ex_cldr + jason + ]; }; - beamDeps = [ decimal digital_token ex_cldr ex_cldr_currencies jason ]; - }; + ex_cldr_numbers = buildMix rec { + name = "ex_cldr_numbers"; + version = "2.32.4"; + + src = fetchHex { + pkg = "ex_cldr_numbers"; + version = "${version}"; + sha256 = "6fd5a82f0785418fa8b698c0be2b1845dff92b77f1b3172c763d37868fb503d2"; + }; - ex_cldr_plugs = buildMix rec { - name = "ex_cldr_plugs"; - version = "1.3.1"; + beamDeps = [ + decimal + digital_token + ex_cldr + ex_cldr_currencies + jason + ]; + }; - src = fetchHex { - pkg = "ex_cldr_plugs"; - version = "${version}"; - sha256 = "4f7b4a5fe061734cef7b62ff29118ed6ac72698cdd7bcfc97495db73611fe0fe"; - }; + ex_cldr_plugs = buildMix rec { + name = "ex_cldr_plugs"; + version = "1.3.1"; + + src = fetchHex { + pkg = "ex_cldr_plugs"; + version = "${version}"; + sha256 = "4f7b4a5fe061734cef7b62ff29118ed6ac72698cdd7bcfc97495db73611fe0fe"; + }; - beamDeps = [ ex_cldr gettext jason plug ]; - }; - - ex_doc = buildMix rec { - name = "ex_doc"; - version = "0.31.1"; - - src = fetchHex { - pkg = "ex_doc"; - version = "${version}"; - sha256 = "3178c3a407c557d8343479e1ff117a96fd31bafe52a039079593fb0524ef61b0"; + beamDeps = [ + ex_cldr + gettext + jason + plug + ]; }; - beamDeps = [ earmark_parser makeup_elixir makeup_erlang ]; - }; + ex_doc = buildMix rec { + name = "ex_doc"; + version = "0.31.1"; - ex_ical = buildMix rec { - name = "ex_ical"; - version = "0.2.0"; + src = fetchHex { + pkg = "ex_doc"; + version = "${version}"; + sha256 = "3178c3a407c557d8343479e1ff117a96fd31bafe52a039079593fb0524ef61b0"; + }; - src = fetchHex { - pkg = "ex_ical"; - version = "${version}"; - sha256 = "db76473b2ae0259e6633c6c479a5a4d8603f09497f55c88f9ef4d53d2b75befb"; + beamDeps = [ + earmark_parser + makeup_elixir + makeup_erlang + ]; }; - beamDeps = [ timex ]; - }; + ex_ical = buildMix rec { + name = "ex_ical"; + version = "0.2.0"; - ex_machina = buildMix rec { - name = "ex_machina"; - version = "2.7.0"; + src = fetchHex { + pkg = "ex_ical"; + version = "${version}"; + sha256 = "db76473b2ae0259e6633c6c479a5a4d8603f09497f55c88f9ef4d53d2b75befb"; + }; - src = fetchHex { - pkg = "ex_machina"; - version = "${version}"; - sha256 = "419aa7a39bde11894c87a615c4ecaa52d8f107bbdd81d810465186f783245bf8"; + beamDeps = [ timex ]; }; - beamDeps = [ ecto ecto_sql ]; - }; + ex_machina = buildMix rec { + name = "ex_machina"; + version = "2.7.0"; - ex_optimizer = buildMix rec { - name = "ex_optimizer"; - version = "0.1.1"; + src = fetchHex { + pkg = "ex_machina"; + version = "${version}"; + sha256 = "419aa7a39bde11894c87a615c4ecaa52d8f107bbdd81d810465186f783245bf8"; + }; - src = fetchHex { - pkg = "ex_optimizer"; - version = "${version}"; - sha256 = "e6f5c059bcd58b66be2f6f257fdc4f69b74b0fa5c9ddd669486af012e4b52286"; + beamDeps = [ + ecto + ecto_sql + ]; }; - beamDeps = [ file_info ]; - }; + ex_optimizer = buildMix rec { + name = "ex_optimizer"; + version = "0.1.1"; - ex_unit_notifier = buildMix rec { - name = "ex_unit_notifier"; - version = "1.3.0"; + src = fetchHex { + pkg = "ex_optimizer"; + version = "${version}"; + sha256 = "e6f5c059bcd58b66be2f6f257fdc4f69b74b0fa5c9ddd669486af012e4b52286"; + }; - src = fetchHex { - pkg = "ex_unit_notifier"; - version = "${version}"; - sha256 = "55fffd6062e8d962fc44e8b06fa30a87dc7251ee2a69f520781a3bb29858c365"; + beamDeps = [ file_info ]; }; - beamDeps = []; - }; + ex_unit_notifier = buildMix rec { + name = "ex_unit_notifier"; + version = "1.3.0"; - excoveralls = buildMix rec { - name = "excoveralls"; - version = "0.18.0"; + src = fetchHex { + pkg = "ex_unit_notifier"; + version = "${version}"; + sha256 = "55fffd6062e8d962fc44e8b06fa30a87dc7251ee2a69f520781a3bb29858c365"; + }; - src = fetchHex { - pkg = "excoveralls"; - version = "${version}"; - sha256 = "1109bb911f3cb583401760be49c02cbbd16aed66ea9509fc5479335d284da60b"; + beamDeps = [ ]; }; - beamDeps = [ castore jason ]; - }; + excoveralls = buildMix rec { + name = "excoveralls"; + version = "0.18.0"; - exgravatar = buildMix rec { - name = "exgravatar"; - version = "2.0.3"; + src = fetchHex { + pkg = "excoveralls"; + version = "${version}"; + sha256 = "1109bb911f3cb583401760be49c02cbbd16aed66ea9509fc5479335d284da60b"; + }; - src = fetchHex { - pkg = "exgravatar"; - version = "${version}"; - sha256 = "aca18ff9bd8991d3be3e5446d3bdefc051be084c1ffc9ab2d43b3e65339300e1"; + beamDeps = [ + castore + jason + ]; }; - beamDeps = []; - }; + exgravatar = buildMix rec { + name = "exgravatar"; + version = "2.0.3"; - expo = buildMix rec { - name = "expo"; - version = "0.5.2"; + src = fetchHex { + pkg = "exgravatar"; + version = "${version}"; + sha256 = "aca18ff9bd8991d3be3e5446d3bdefc051be084c1ffc9ab2d43b3e65339300e1"; + }; - src = fetchHex { - pkg = "expo"; - version = "${version}"; - sha256 = "8c9bfa06ca017c9cb4020fabe980bc7fdb1aaec059fd004c2ab3bff03b1c599c"; + beamDeps = [ ]; }; - beamDeps = []; - }; + expo = buildMix rec { + name = "expo"; + version = "0.5.2"; - export = buildMix rec { - name = "export"; - version = "0.1.1"; + src = fetchHex { + pkg = "expo"; + version = "${version}"; + sha256 = "8c9bfa06ca017c9cb4020fabe980bc7fdb1aaec059fd004c2ab3bff03b1c599c"; + }; - src = fetchHex { - pkg = "export"; - version = "${version}"; - sha256 = "3da7444ff4053f1824352f4bdb13fbd2c28c93c2011786fb686b649fdca1021f"; + beamDeps = [ ]; }; - beamDeps = [ erlport ]; - }; + export = buildMix rec { + name = "export"; + version = "0.1.1"; - fast_html = buildMix rec { - name = "fast_html"; - version = "2.3.0"; + src = fetchHex { + pkg = "export"; + version = "${version}"; + sha256 = "3da7444ff4053f1824352f4bdb13fbd2c28c93c2011786fb686b649fdca1021f"; + }; - src = fetchHex { - pkg = "fast_html"; - version = "${version}"; - sha256 = "f18e3c7668f82d3ae0b15f48d48feeb257e28aa5ab1b0dbf781c7312e5da029d"; + beamDeps = [ erlport ]; }; - beamDeps = [ elixir_make nimble_pool ]; - }; + fast_html = buildMix rec { + name = "fast_html"; + version = "2.3.0"; - fast_sanitize = buildMix rec { - name = "fast_sanitize"; - version = "0.2.3"; + src = fetchHex { + pkg = "fast_html"; + version = "${version}"; + sha256 = "f18e3c7668f82d3ae0b15f48d48feeb257e28aa5ab1b0dbf781c7312e5da029d"; + }; - src = fetchHex { - pkg = "fast_sanitize"; - version = "${version}"; - sha256 = "e8ad286d10d0386e15d67d0ee125245ebcfbc7d7290b08712ba9013c8c5e56e2"; + beamDeps = [ + elixir_make + nimble_pool + ]; }; - beamDeps = [ fast_html plug ]; - }; + fast_sanitize = buildMix rec { + name = "fast_sanitize"; + version = "0.2.3"; - file_info = buildMix rec { - name = "file_info"; - version = "0.0.4"; + src = fetchHex { + pkg = "fast_sanitize"; + version = "${version}"; + sha256 = "e8ad286d10d0386e15d67d0ee125245ebcfbc7d7290b08712ba9013c8c5e56e2"; + }; - src = fetchHex { - pkg = "file_info"; - version = "${version}"; - sha256 = "50e7ad01c2c8b9339010675fe4dc4a113b8d6ca7eddce24d1d74fd0e762781a5"; + beamDeps = [ + fast_html + plug + ]; }; - beamDeps = [ mimetype_parser ]; - }; + file_info = buildMix rec { + name = "file_info"; + version = "0.0.4"; - file_system = buildMix rec { - name = "file_system"; - version = "0.2.10"; + src = fetchHex { + pkg = "file_info"; + version = "${version}"; + sha256 = "50e7ad01c2c8b9339010675fe4dc4a113b8d6ca7eddce24d1d74fd0e762781a5"; + }; - src = fetchHex { - pkg = "file_system"; - version = "${version}"; - sha256 = "41195edbfb562a593726eda3b3e8b103a309b733ad25f3d642ba49696bf715dc"; + beamDeps = [ mimetype_parser ]; }; - beamDeps = []; - }; + file_system = buildMix rec { + name = "file_system"; + version = "0.2.10"; - floki = buildMix rec { - name = "floki"; - version = "0.35.4"; + src = fetchHex { + pkg = "file_system"; + version = "${version}"; + sha256 = "41195edbfb562a593726eda3b3e8b103a309b733ad25f3d642ba49696bf715dc"; + }; - src = fetchHex { - pkg = "floki"; - version = "${version}"; - sha256 = "27fa185d3469bd8fc5947ef0f8d5c4e47f0af02eb6b070b63c868f69e3af0204"; + beamDeps = [ ]; }; - beamDeps = []; - }; + floki = buildMix rec { + name = "floki"; + version = "0.35.4"; - gen_smtp = buildRebar3 rec { - name = "gen_smtp"; - version = "1.2.0"; + src = fetchHex { + pkg = "floki"; + version = "${version}"; + sha256 = "27fa185d3469bd8fc5947ef0f8d5c4e47f0af02eb6b070b63c868f69e3af0204"; + }; - src = fetchHex { - pkg = "gen_smtp"; - version = "${version}"; - sha256 = "5ee0375680bca8f20c4d85f58c2894441443a743355430ff33a783fe03296779"; + beamDeps = [ ]; }; - beamDeps = [ ranch ]; - }; + gen_smtp = buildRebar3 rec { + name = "gen_smtp"; + version = "1.2.0"; - geo = buildMix rec { - name = "geo"; - version = "3.6.0"; + src = fetchHex { + pkg = "gen_smtp"; + version = "${version}"; + sha256 = "5ee0375680bca8f20c4d85f58c2894441443a743355430ff33a783fe03296779"; + }; - src = fetchHex { - pkg = "geo"; - version = "${version}"; - sha256 = "1dbdebf617183b54bc3c8ad7a36531a9a76ada8ca93f75f573b0ae94006168da"; + beamDeps = [ ranch ]; }; - beamDeps = [ jason ]; - }; + geo = buildMix rec { + name = "geo"; + version = "3.6.0"; - geo_postgis = buildMix rec { - name = "geo_postgis"; - version = "3.5.0"; + src = fetchHex { + pkg = "geo"; + version = "${version}"; + sha256 = "1dbdebf617183b54bc3c8ad7a36531a9a76ada8ca93f75f573b0ae94006168da"; + }; - src = fetchHex { - pkg = "geo_postgis"; - version = "${version}"; - sha256 = "0bebc5b00f8b11835066bd6213fbeeec03704b4a1c206920b81c1ec2201d185f"; + beamDeps = [ jason ]; }; - beamDeps = [ ecto geo jason postgrex ]; - }; + geo_postgis = buildMix rec { + name = "geo_postgis"; + version = "3.5.0"; - geohax = buildMix rec { - name = "geohax"; - version = "1.0.0"; + src = fetchHex { + pkg = "geo_postgis"; + version = "${version}"; + sha256 = "0bebc5b00f8b11835066bd6213fbeeec03704b4a1c206920b81c1ec2201d185f"; + }; - src = fetchHex { - pkg = "geohax"; - version = "${version}"; - sha256 = "893ef2f905213acb67c615d2c955d926b1be3676bfc2bd5ed7271b641dfa2224"; + beamDeps = [ + ecto + geo + jason + postgrex + ]; }; - beamDeps = []; - }; + geohax = buildMix rec { + name = "geohax"; + version = "1.0.0"; - geolix = buildMix rec { - name = "geolix"; - version = "2.0.0"; + src = fetchHex { + pkg = "geohax"; + version = "${version}"; + sha256 = "893ef2f905213acb67c615d2c955d926b1be3676bfc2bd5ed7271b641dfa2224"; + }; - src = fetchHex { - pkg = "geolix"; - version = "${version}"; - sha256 = "8742bf588ed0bb7def2c443204d09d355990846c6efdff96ded66aac24c301df"; + beamDeps = [ ]; }; - beamDeps = []; - }; + geolix = buildMix rec { + name = "geolix"; + version = "2.0.0"; - geolix_adapter_mmdb2 = buildMix rec { - name = "geolix_adapter_mmdb2"; - version = "0.6.0"; + src = fetchHex { + pkg = "geolix"; + version = "${version}"; + sha256 = "8742bf588ed0bb7def2c443204d09d355990846c6efdff96ded66aac24c301df"; + }; - src = fetchHex { - pkg = "geolix_adapter_mmdb2"; - version = "${version}"; - sha256 = "06ff962feae8a310cffdf86b74bfcda6e2d0dccb439bb1f62df2b657b1c0269b"; + beamDeps = [ ]; }; - beamDeps = [ geolix mmdb2_decoder ]; - }; + geolix_adapter_mmdb2 = buildMix rec { + name = "geolix_adapter_mmdb2"; + version = "0.6.0"; - gettext = buildMix rec { - name = "gettext"; - version = "0.24.0"; + src = fetchHex { + pkg = "geolix_adapter_mmdb2"; + version = "${version}"; + sha256 = "06ff962feae8a310cffdf86b74bfcda6e2d0dccb439bb1f62df2b657b1c0269b"; + }; - src = fetchHex { - pkg = "gettext"; - version = "${version}"; - sha256 = "bdf75cdfcbe9e4622dd18e034b227d77dd17f0f133853a1c73b97b3d6c770e8b"; + beamDeps = [ + geolix + mmdb2_decoder + ]; }; - beamDeps = [ expo ]; - }; + gettext = buildMix rec { + name = "gettext"; + version = "0.24.0"; - guardian = buildMix rec { - name = "guardian"; - version = "2.3.2"; + src = fetchHex { + pkg = "gettext"; + version = "${version}"; + sha256 = "bdf75cdfcbe9e4622dd18e034b227d77dd17f0f133853a1c73b97b3d6c770e8b"; + }; - src = fetchHex { - pkg = "guardian"; - version = "${version}"; - sha256 = "b189ff38cd46a22a8a824866a6867ca8722942347f13c33f7d23126af8821b52"; + beamDeps = [ expo ]; }; - beamDeps = [ jose plug ]; - }; + guardian = buildMix rec { + name = "guardian"; + version = "2.3.2"; - guardian_db = buildMix rec { - name = "guardian_db"; - version = "3.0.0"; + src = fetchHex { + pkg = "guardian"; + version = "${version}"; + sha256 = "b189ff38cd46a22a8a824866a6867ca8722942347f13c33f7d23126af8821b52"; + }; - src = fetchHex { - pkg = "guardian_db"; - version = "${version}"; - sha256 = "9c2ec4278efa34f9f1cc6ba795e552d41fdc7ffba5319d67eeb533b89392d183"; + beamDeps = [ + jose + plug + ]; }; - beamDeps = [ ecto ecto_sql guardian postgrex ]; - }; + guardian_db = buildMix rec { + name = "guardian_db"; + version = "3.0.0"; - guardian_phoenix = buildMix rec { - name = "guardian_phoenix"; - version = "2.0.1"; + src = fetchHex { + pkg = "guardian_db"; + version = "${version}"; + sha256 = "9c2ec4278efa34f9f1cc6ba795e552d41fdc7ffba5319d67eeb533b89392d183"; + }; - src = fetchHex { - pkg = "guardian_phoenix"; - version = "${version}"; - sha256 = "21f439246715192b231f228680465d1ed5fbdf01555a4a3b17165532f5f9a08c"; + beamDeps = [ + ecto + ecto_sql + guardian + postgrex + ]; }; - beamDeps = [ guardian phoenix ]; - }; + guardian_phoenix = buildMix rec { + name = "guardian_phoenix"; + version = "2.0.1"; - hackney = buildRebar3 rec { - name = "hackney"; - version = "1.20.1"; + src = fetchHex { + pkg = "guardian_phoenix"; + version = "${version}"; + sha256 = "21f439246715192b231f228680465d1ed5fbdf01555a4a3b17165532f5f9a08c"; + }; - src = fetchHex { - pkg = "hackney"; - version = "${version}"; - sha256 = "fe9094e5f1a2a2c0a7d10918fee36bfec0ec2a979994cff8cfe8058cd9af38e3"; + beamDeps = [ + guardian + phoenix + ]; }; - beamDeps = [ certifi idna metrics mimerl parse_trans ssl_verify_fun unicode_util_compat ]; - }; + hackney = buildRebar3 rec { + name = "hackney"; + version = "1.20.1"; - hammer = buildMix rec { - name = "hammer"; - version = "6.2.1"; + src = fetchHex { + pkg = "hackney"; + version = "${version}"; + sha256 = "fe9094e5f1a2a2c0a7d10918fee36bfec0ec2a979994cff8cfe8058cd9af38e3"; + }; - src = fetchHex { - pkg = "hammer"; - version = "${version}"; - sha256 = "b9476d0c13883d2dc0cc72e786bac6ac28911fba7cc2e04b70ce6a6d9c4b2bdc"; + beamDeps = [ + certifi + idna + metrics + mimerl + parse_trans + ssl_verify_fun + unicode_util_compat + ]; }; - beamDeps = [ poolboy ]; - }; + hammer = buildMix rec { + name = "hammer"; + version = "6.2.1"; - haversine = buildMix rec { - name = "haversine"; - version = "0.1.0"; + src = fetchHex { + pkg = "hammer"; + version = "${version}"; + sha256 = "b9476d0c13883d2dc0cc72e786bac6ac28911fba7cc2e04b70ce6a6d9c4b2bdc"; + }; - src = fetchHex { - pkg = "haversine"; - version = "${version}"; - sha256 = "54dc48e895bc18a59437a37026c873634e17b648a64cb87bfafb96f64d607060"; + beamDeps = [ poolboy ]; }; - beamDeps = []; - }; + haversine = buildMix rec { + name = "haversine"; + version = "0.1.0"; - hpax = buildMix rec { - name = "hpax"; - version = "0.1.2"; + src = fetchHex { + pkg = "haversine"; + version = "${version}"; + sha256 = "54dc48e895bc18a59437a37026c873634e17b648a64cb87bfafb96f64d607060"; + }; - src = fetchHex { - pkg = "hpax"; - version = "${version}"; - sha256 = "2c87843d5a23f5f16748ebe77969880e29809580efdaccd615cd3bed628a8c13"; + beamDeps = [ ]; }; - beamDeps = []; - }; + hpax = buildMix rec { + name = "hpax"; + version = "0.1.2"; - html_entities = buildMix rec { - name = "html_entities"; - version = "0.5.2"; + src = fetchHex { + pkg = "hpax"; + version = "${version}"; + sha256 = "2c87843d5a23f5f16748ebe77969880e29809580efdaccd615cd3bed628a8c13"; + }; - src = fetchHex { - pkg = "html_entities"; - version = "${version}"; - sha256 = "c53ba390403485615623b9531e97696f076ed415e8d8058b1dbaa28181f4fdcc"; + beamDeps = [ ]; }; - beamDeps = []; - }; + html_entities = buildMix rec { + name = "html_entities"; + version = "0.5.2"; - http_signatures = buildMix rec { - name = "http_signatures"; - version = "0.1.2"; + src = fetchHex { + pkg = "html_entities"; + version = "${version}"; + sha256 = "c53ba390403485615623b9531e97696f076ed415e8d8058b1dbaa28181f4fdcc"; + }; - src = fetchHex { - pkg = "http_signatures"; - version = "${version}"; - sha256 = "f08aa9ac121829dae109d608d83c84b940ef2f183ae50f2dd1e9a8bc619d8be7"; + beamDeps = [ ]; }; - beamDeps = []; - }; + http_signatures = buildMix rec { + name = "http_signatures"; + version = "0.1.2"; - httpoison = buildMix rec { - name = "httpoison"; - version = "1.8.2"; + src = fetchHex { + pkg = "http_signatures"; + version = "${version}"; + sha256 = "f08aa9ac121829dae109d608d83c84b940ef2f183ae50f2dd1e9a8bc619d8be7"; + }; - src = fetchHex { - pkg = "httpoison"; - version = "${version}"; - sha256 = "2bb350d26972e30c96e2ca74a1aaf8293d61d0742ff17f01e0279fef11599921"; + beamDeps = [ ]; }; - beamDeps = [ hackney ]; - }; + httpoison = buildMix rec { + name = "httpoison"; + version = "1.8.2"; - idna = buildRebar3 rec { - name = "idna"; - version = "6.1.1"; + src = fetchHex { + pkg = "httpoison"; + version = "${version}"; + sha256 = "2bb350d26972e30c96e2ca74a1aaf8293d61d0742ff17f01e0279fef11599921"; + }; - src = fetchHex { - pkg = "idna"; - version = "${version}"; - sha256 = "92376eb7894412ed19ac475e4a86f7b413c1b9fbb5bd16dccd57934157944cea"; + beamDeps = [ hackney ]; }; - beamDeps = [ unicode_util_compat ]; - }; + idna = buildRebar3 rec { + name = "idna"; + version = "6.1.1"; - inet_cidr = buildMix rec { - name = "inet_cidr"; - version = "1.0.8"; + src = fetchHex { + pkg = "idna"; + version = "${version}"; + sha256 = "92376eb7894412ed19ac475e4a86f7b413c1b9fbb5bd16dccd57934157944cea"; + }; - src = fetchHex { - pkg = "inet_cidr"; - version = "${version}"; - sha256 = "d5b26da66603bb56c933c65214c72152f0de9a6ea53618b56d63302a68f6a90e"; + beamDeps = [ unicode_util_compat ]; }; - beamDeps = []; - }; + inet_cidr = buildMix rec { + name = "inet_cidr"; + version = "1.0.8"; - ip_reserved = buildMix rec { - name = "ip_reserved"; - version = "0.1.1"; + src = fetchHex { + pkg = "inet_cidr"; + version = "${version}"; + sha256 = "d5b26da66603bb56c933c65214c72152f0de9a6ea53618b56d63302a68f6a90e"; + }; - src = fetchHex { - pkg = "ip_reserved"; - version = "${version}"; - sha256 = "55fcd2b6e211caef09ea3f54ef37d43030bec486325d12fe865ab5ed8140a4fe"; + beamDeps = [ ]; }; - beamDeps = [ inet_cidr ]; - }; + ip_reserved = buildMix rec { + name = "ip_reserved"; + version = "0.1.1"; - jason = buildMix rec { - name = "jason"; - version = "1.4.1"; + src = fetchHex { + pkg = "ip_reserved"; + version = "${version}"; + sha256 = "55fcd2b6e211caef09ea3f54ef37d43030bec486325d12fe865ab5ed8140a4fe"; + }; - src = fetchHex { - pkg = "jason"; - version = "${version}"; - sha256 = "fbb01ecdfd565b56261302f7e1fcc27c4fb8f32d56eab74db621fc154604a7a1"; + beamDeps = [ inet_cidr ]; }; - beamDeps = [ decimal ]; - }; + jason = buildMix rec { + name = "jason"; + version = "1.4.1"; - jose = buildMix rec { - name = "jose"; - version = "1.11.6"; + src = fetchHex { + pkg = "jason"; + version = "${version}"; + sha256 = "fbb01ecdfd565b56261302f7e1fcc27c4fb8f32d56eab74db621fc154604a7a1"; + }; - src = fetchHex { - pkg = "jose"; - version = "${version}"; - sha256 = "6275cb75504f9c1e60eeacb771adfeee4905a9e182103aa59b53fed651ff9738"; + beamDeps = [ decimal ]; }; - beamDeps = []; - }; + jose = buildMix rec { + name = "jose"; + version = "1.11.6"; - jumper = buildMix rec { - name = "jumper"; - version = "1.0.2"; + src = fetchHex { + pkg = "jose"; + version = "${version}"; + sha256 = "6275cb75504f9c1e60eeacb771adfeee4905a9e182103aa59b53fed651ff9738"; + }; - src = fetchHex { - pkg = "jumper"; - version = "${version}"; - sha256 = "9b7782409021e01ab3c08270e26f36eb62976a38c1aa64b2eaf6348422f165e1"; + beamDeps = [ ]; }; - beamDeps = []; - }; + jumper = buildMix rec { + name = "jumper"; + version = "1.0.2"; - junit_formatter = buildMix rec { - name = "junit_formatter"; - version = "3.3.1"; + src = fetchHex { + pkg = "jumper"; + version = "${version}"; + sha256 = "9b7782409021e01ab3c08270e26f36eb62976a38c1aa64b2eaf6348422f165e1"; + }; - src = fetchHex { - pkg = "junit_formatter"; - version = "${version}"; - sha256 = "761fc5be4b4c15d8ba91a6dafde0b2c2ae6db9da7b8832a55b5a1deb524da72b"; + beamDeps = [ ]; }; - beamDeps = []; - }; + junit_formatter = buildMix rec { + name = "junit_formatter"; + version = "3.3.1"; - linkify = buildMix rec { - name = "linkify"; - version = "0.5.3"; + src = fetchHex { + pkg = "junit_formatter"; + version = "${version}"; + sha256 = "761fc5be4b4c15d8ba91a6dafde0b2c2ae6db9da7b8832a55b5a1deb524da72b"; + }; - src = fetchHex { - pkg = "linkify"; - version = "${version}"; - sha256 = "3ef35a1377d47c25506e07c1c005ea9d38d700699d92ee92825f024434258177"; + beamDeps = [ ]; }; - beamDeps = []; - }; + linkify = buildMix rec { + name = "linkify"; + version = "0.5.3"; - makeup = buildMix rec { - name = "makeup"; - version = "1.1.1"; + src = fetchHex { + pkg = "linkify"; + version = "${version}"; + sha256 = "3ef35a1377d47c25506e07c1c005ea9d38d700699d92ee92825f024434258177"; + }; - src = fetchHex { - pkg = "makeup"; - version = "${version}"; - sha256 = "5dc62fbdd0de44de194898b6710692490be74baa02d9d108bc29f007783b0b48"; + beamDeps = [ ]; }; - beamDeps = [ nimble_parsec ]; - }; + makeup = buildMix rec { + name = "makeup"; + version = "1.1.1"; - makeup_elixir = buildMix rec { - name = "makeup_elixir"; - version = "0.16.1"; + src = fetchHex { + pkg = "makeup"; + version = "${version}"; + sha256 = "5dc62fbdd0de44de194898b6710692490be74baa02d9d108bc29f007783b0b48"; + }; - src = fetchHex { - pkg = "makeup_elixir"; - version = "${version}"; - sha256 = "e127a341ad1b209bd80f7bd1620a15693a9908ed780c3b763bccf7d200c767c6"; + beamDeps = [ nimble_parsec ]; }; - beamDeps = [ makeup nimble_parsec ]; - }; + makeup_elixir = buildMix rec { + name = "makeup_elixir"; + version = "0.16.1"; - makeup_erlang = buildMix rec { - name = "makeup_erlang"; - version = "0.1.5"; + src = fetchHex { + pkg = "makeup_elixir"; + version = "${version}"; + sha256 = "e127a341ad1b209bd80f7bd1620a15693a9908ed780c3b763bccf7d200c767c6"; + }; - src = fetchHex { - pkg = "makeup_erlang"; - version = "${version}"; - sha256 = "94d2e986428585a21516d7d7149781480013c56e30c6a233534bedf38867a59a"; + beamDeps = [ + makeup + nimble_parsec + ]; }; - beamDeps = [ makeup ]; - }; + makeup_erlang = buildMix rec { + name = "makeup_erlang"; + version = "0.1.5"; - meck = buildRebar3 rec { - name = "meck"; - version = "0.9.2"; + src = fetchHex { + pkg = "makeup_erlang"; + version = "${version}"; + sha256 = "94d2e986428585a21516d7d7149781480013c56e30c6a233534bedf38867a59a"; + }; - src = fetchHex { - pkg = "meck"; - version = "${version}"; - sha256 = "81344f561357dc40a8344afa53767c32669153355b626ea9fcbc8da6b3045826"; + beamDeps = [ makeup ]; }; - beamDeps = []; - }; + meck = buildRebar3 rec { + name = "meck"; + version = "0.9.2"; - metrics = buildRebar3 rec { - name = "metrics"; - version = "1.0.1"; + src = fetchHex { + pkg = "meck"; + version = "${version}"; + sha256 = "81344f561357dc40a8344afa53767c32669153355b626ea9fcbc8da6b3045826"; + }; - src = fetchHex { - pkg = "metrics"; - version = "${version}"; - sha256 = "69b09adddc4f74a40716ae54d140f93beb0fb8978d8636eaded0c31b6f099f16"; + beamDeps = [ ]; }; - beamDeps = []; - }; + metrics = buildRebar3 rec { + name = "metrics"; + version = "1.0.1"; - mime = buildMix rec { - name = "mime"; - version = "2.0.5"; + src = fetchHex { + pkg = "metrics"; + version = "${version}"; + sha256 = "69b09adddc4f74a40716ae54d140f93beb0fb8978d8636eaded0c31b6f099f16"; + }; - src = fetchHex { - pkg = "mime"; - version = "${version}"; - sha256 = "da0d64a365c45bc9935cc5c8a7fc5e49a0e0f9932a761c55d6c52b142780a05c"; + beamDeps = [ ]; }; - beamDeps = []; - }; + mime = buildMix rec { + name = "mime"; + version = "2.0.5"; - mimerl = buildRebar3 rec { - name = "mimerl"; - version = "1.2.0"; + src = fetchHex { + pkg = "mime"; + version = "${version}"; + sha256 = "da0d64a365c45bc9935cc5c8a7fc5e49a0e0f9932a761c55d6c52b142780a05c"; + }; - src = fetchHex { - pkg = "mimerl"; - version = "${version}"; - sha256 = "f278585650aa581986264638ebf698f8bb19df297f66ad91b18910dfc6e19323"; + beamDeps = [ ]; }; - beamDeps = []; - }; + mimerl = buildRebar3 rec { + name = "mimerl"; + version = "1.2.0"; - mimetype_parser = buildMix rec { - name = "mimetype_parser"; - version = "0.1.3"; + src = fetchHex { + pkg = "mimerl"; + version = "${version}"; + sha256 = "f278585650aa581986264638ebf698f8bb19df297f66ad91b18910dfc6e19323"; + }; - src = fetchHex { - pkg = "mimetype_parser"; - version = "${version}"; - sha256 = "7d8f80c567807ce78cd93c938e7f4b0a20b1aaaaab914bf286f68457d9f7a852"; + beamDeps = [ ]; }; - beamDeps = []; - }; + mimetype_parser = buildMix rec { + name = "mimetype_parser"; + version = "0.1.3"; - mix_test_watch = buildMix rec { - name = "mix_test_watch"; - version = "1.1.2"; + src = fetchHex { + pkg = "mimetype_parser"; + version = "${version}"; + sha256 = "7d8f80c567807ce78cd93c938e7f4b0a20b1aaaaab914bf286f68457d9f7a852"; + }; - src = fetchHex { - pkg = "mix_test_watch"; - version = "${version}"; - sha256 = "8ce79fc69a304eec81ab6c1a05de2eb026a8959f65fb47f933ce8eb56018ba35"; + beamDeps = [ ]; }; - beamDeps = [ file_system ]; - }; + mix_test_watch = buildMix rec { + name = "mix_test_watch"; + version = "1.1.2"; - mmdb2_decoder = buildMix rec { - name = "mmdb2_decoder"; - version = "3.0.1"; + src = fetchHex { + pkg = "mix_test_watch"; + version = "${version}"; + sha256 = "8ce79fc69a304eec81ab6c1a05de2eb026a8959f65fb47f933ce8eb56018ba35"; + }; - src = fetchHex { - pkg = "mmdb2_decoder"; - version = "${version}"; - sha256 = "316af0f388fac824782d944f54efe78e7c9691bbbdb0afd5cccdd0510adf559d"; + beamDeps = [ file_system ]; }; - beamDeps = []; - }; + mmdb2_decoder = buildMix rec { + name = "mmdb2_decoder"; + version = "3.0.1"; - mock = buildMix rec { - name = "mock"; - version = "0.3.8"; + src = fetchHex { + pkg = "mmdb2_decoder"; + version = "${version}"; + sha256 = "316af0f388fac824782d944f54efe78e7c9691bbbdb0afd5cccdd0510adf559d"; + }; - src = fetchHex { - pkg = "mock"; - version = "${version}"; - sha256 = "7fa82364c97617d79bb7d15571193fc0c4fe5afd0c932cef09426b3ee6fe2022"; + beamDeps = [ ]; }; - beamDeps = [ meck ]; - }; + mock = buildMix rec { + name = "mock"; + version = "0.3.8"; - mogrify = buildMix rec { - name = "mogrify"; - version = "0.9.3"; + src = fetchHex { + pkg = "mock"; + version = "${version}"; + sha256 = "7fa82364c97617d79bb7d15571193fc0c4fe5afd0c932cef09426b3ee6fe2022"; + }; - src = fetchHex { - pkg = "mogrify"; - version = "${version}"; - sha256 = "0189b1e1de27455f2b9ae8cf88239cefd23d38de9276eb5add7159aea51731e6"; + beamDeps = [ meck ]; }; - beamDeps = []; - }; + mogrify = buildMix rec { + name = "mogrify"; + version = "0.9.3"; - mox = buildMix rec { - name = "mox"; - version = "1.1.0"; + src = fetchHex { + pkg = "mogrify"; + version = "${version}"; + sha256 = "0189b1e1de27455f2b9ae8cf88239cefd23d38de9276eb5add7159aea51731e6"; + }; - src = fetchHex { - pkg = "mox"; - version = "${version}"; - sha256 = "d44474c50be02d5b72131070281a5d3895c0e7a95c780e90bc0cfe712f633a13"; + beamDeps = [ ]; }; - beamDeps = []; - }; + mox = buildMix rec { + name = "mox"; + version = "1.1.0"; - nimble_csv = buildMix rec { - name = "nimble_csv"; - version = "1.2.0"; + src = fetchHex { + pkg = "mox"; + version = "${version}"; + sha256 = "d44474c50be02d5b72131070281a5d3895c0e7a95c780e90bc0cfe712f633a13"; + }; - src = fetchHex { - pkg = "nimble_csv"; - version = "${version}"; - sha256 = "d0628117fcc2148178b034044c55359b26966c6eaa8e2ce15777be3bbc91b12a"; + beamDeps = [ ]; }; - beamDeps = []; - }; + nimble_csv = buildMix rec { + name = "nimble_csv"; + version = "1.2.0"; - nimble_parsec = buildMix rec { - name = "nimble_parsec"; - version = "1.4.0"; + src = fetchHex { + pkg = "nimble_csv"; + version = "${version}"; + sha256 = "d0628117fcc2148178b034044c55359b26966c6eaa8e2ce15777be3bbc91b12a"; + }; - src = fetchHex { - pkg = "nimble_parsec"; - version = "${version}"; - sha256 = "9c565862810fb383e9838c1dd2d7d2c437b3d13b267414ba6af33e50d2d1cf28"; + beamDeps = [ ]; }; - beamDeps = []; - }; + nimble_parsec = buildMix rec { + name = "nimble_parsec"; + version = "1.4.0"; - nimble_pool = buildMix rec { - name = "nimble_pool"; - version = "0.2.6"; + src = fetchHex { + pkg = "nimble_parsec"; + version = "${version}"; + sha256 = "9c565862810fb383e9838c1dd2d7d2c437b3d13b267414ba6af33e50d2d1cf28"; + }; - src = fetchHex { - pkg = "nimble_pool"; - version = "${version}"; - sha256 = "1c715055095d3f2705c4e236c18b618420a35490da94149ff8b580a2144f653f"; + beamDeps = [ ]; }; - beamDeps = []; - }; + nimble_pool = buildMix rec { + name = "nimble_pool"; + version = "0.2.6"; - oauth2 = buildMix rec { - name = "oauth2"; - version = "2.1.0"; + src = fetchHex { + pkg = "nimble_pool"; + version = "${version}"; + sha256 = "1c715055095d3f2705c4e236c18b618420a35490da94149ff8b580a2144f653f"; + }; - src = fetchHex { - pkg = "oauth2"; - version = "${version}"; - sha256 = "8ac07f85b3307dd1acfeb0ec852f64161b22f57d0ce0c15e616a1dfc8ebe2b41"; + beamDeps = [ ]; }; - beamDeps = [ tesla ]; - }; + oauth2 = buildMix rec { + name = "oauth2"; + version = "2.1.0"; - oauther = buildMix rec { - name = "oauther"; - version = "1.3.0"; + src = fetchHex { + pkg = "oauth2"; + version = "${version}"; + sha256 = "8ac07f85b3307dd1acfeb0ec852f64161b22f57d0ce0c15e616a1dfc8ebe2b41"; + }; - src = fetchHex { - pkg = "oauther"; - version = "${version}"; - sha256 = "78eb888ea875c72ca27b0864a6f550bc6ee84f2eeca37b093d3d833fbcaec04e"; + beamDeps = [ tesla ]; }; - beamDeps = []; - }; + oauther = buildMix rec { + name = "oauther"; + version = "1.3.0"; - oban = buildMix rec { - name = "oban"; - version = "2.17.5"; + src = fetchHex { + pkg = "oauther"; + version = "${version}"; + sha256 = "78eb888ea875c72ca27b0864a6f550bc6ee84f2eeca37b093d3d833fbcaec04e"; + }; - src = fetchHex { - pkg = "oban"; - version = "${version}"; - sha256 = "fd3ccbbfdbb2bc77107c8790946f9821a831ed0720688485ee6adcd7863886cf"; + beamDeps = [ ]; }; - beamDeps = [ ecto_sql jason postgrex telemetry ]; - }; + oban = buildMix rec { + name = "oban"; + version = "2.17.5"; - paasaa = buildMix rec { - name = "paasaa"; - version = "0.6.0"; + src = fetchHex { + pkg = "oban"; + version = "${version}"; + sha256 = "fd3ccbbfdbb2bc77107c8790946f9821a831ed0720688485ee6adcd7863886cf"; + }; - src = fetchHex { - pkg = "paasaa"; - version = "${version}"; - sha256 = "732ddfc21bac0831edb26aec468af3ec2b8997d74f6209810b1cc53199c29f2e"; + beamDeps = [ + ecto_sql + jason + postgrex + telemetry + ]; }; - beamDeps = []; - }; + paasaa = buildMix rec { + name = "paasaa"; + version = "0.6.0"; - parse_trans = buildRebar3 rec { - name = "parse_trans"; - version = "3.4.1"; + src = fetchHex { + pkg = "paasaa"; + version = "${version}"; + sha256 = "732ddfc21bac0831edb26aec468af3ec2b8997d74f6209810b1cc53199c29f2e"; + }; - src = fetchHex { - pkg = "parse_trans"; - version = "${version}"; - sha256 = "620a406ce75dada827b82e453c19cf06776be266f5a67cff34e1ef2cbb60e49a"; + beamDeps = [ ]; }; - beamDeps = []; - }; + parse_trans = buildRebar3 rec { + name = "parse_trans"; + version = "3.4.1"; - phoenix = buildMix rec { - name = "phoenix"; - version = "1.7.11"; + src = fetchHex { + pkg = "parse_trans"; + version = "${version}"; + sha256 = "620a406ce75dada827b82e453c19cf06776be266f5a67cff34e1ef2cbb60e49a"; + }; - src = fetchHex { - pkg = "phoenix"; - version = "${version}"; - sha256 = "b1ec57f2e40316b306708fe59b92a16b9f6f4bf50ccfa41aa8c7feb79e0ec02a"; + beamDeps = [ ]; }; - beamDeps = [ castore jason phoenix_pubsub phoenix_template phoenix_view plug plug_crypto telemetry websock_adapter ]; - }; + phoenix = buildMix rec { + name = "phoenix"; + version = "1.7.11"; - phoenix_ecto = buildMix rec { - name = "phoenix_ecto"; - version = "4.4.3"; + src = fetchHex { + pkg = "phoenix"; + version = "${version}"; + sha256 = "b1ec57f2e40316b306708fe59b92a16b9f6f4bf50ccfa41aa8c7feb79e0ec02a"; + }; - src = fetchHex { - pkg = "phoenix_ecto"; - version = "${version}"; - sha256 = "d36c401206f3011fefd63d04e8ef626ec8791975d9d107f9a0817d426f61ac07"; + beamDeps = [ + castore + jason + phoenix_pubsub + phoenix_template + phoenix_view + plug + plug_crypto + telemetry + websock_adapter + ]; }; - beamDeps = [ ecto phoenix_html plug ]; - }; + phoenix_ecto = buildMix rec { + name = "phoenix_ecto"; + version = "4.4.3"; - phoenix_html = buildMix rec { - name = "phoenix_html"; - version = "3.3.3"; + src = fetchHex { + pkg = "phoenix_ecto"; + version = "${version}"; + sha256 = "d36c401206f3011fefd63d04e8ef626ec8791975d9d107f9a0817d426f61ac07"; + }; - src = fetchHex { - pkg = "phoenix_html"; - version = "${version}"; - sha256 = "923ebe6fec6e2e3b3e569dfbdc6560de932cd54b000ada0208b5f45024bdd76c"; + beamDeps = [ + ecto + phoenix_html + plug + ]; }; - beamDeps = [ plug ]; - }; - - phoenix_live_reload = buildMix rec { - name = "phoenix_live_reload"; - version = "1.4.1"; + phoenix_html = buildMix rec { + name = "phoenix_html"; + version = "3.3.3"; + + src = fetchHex { + pkg = "phoenix_html"; + version = "${version}"; + sha256 = "923ebe6fec6e2e3b3e569dfbdc6560de932cd54b000ada0208b5f45024bdd76c"; + }; - src = fetchHex { - pkg = "phoenix_live_reload"; - version = "${version}"; - sha256 = "9bffb834e7ddf08467fe54ae58b5785507aaba6255568ae22b4d46e2bb3615ab"; + beamDeps = [ plug ]; }; - beamDeps = [ file_system phoenix ]; - }; - - phoenix_live_view = buildMix rec { - name = "phoenix_live_view"; - version = "0.20.10"; - - src = fetchHex { - pkg = "phoenix_live_view"; - version = "${version}"; - sha256 = "daa17b3fbdfd6347aaade4db01a5dd24d23af0f4344e2e24934e8adfb4a11607"; + phoenix_live_reload = buildMix rec { + name = "phoenix_live_reload"; + version = "1.4.1"; + + src = fetchHex { + pkg = "phoenix_live_reload"; + version = "${version}"; + sha256 = "9bffb834e7ddf08467fe54ae58b5785507aaba6255568ae22b4d46e2bb3615ab"; + }; + + beamDeps = [ + file_system + phoenix + ]; }; - beamDeps = [ jason phoenix phoenix_html phoenix_template phoenix_view plug telemetry ]; - }; + phoenix_live_view = buildMix rec { + name = "phoenix_live_view"; + version = "0.20.10"; - phoenix_pubsub = buildMix rec { - name = "phoenix_pubsub"; - version = "2.1.3"; + src = fetchHex { + pkg = "phoenix_live_view"; + version = "${version}"; + sha256 = "daa17b3fbdfd6347aaade4db01a5dd24d23af0f4344e2e24934e8adfb4a11607"; + }; + + beamDeps = [ + jason + phoenix + phoenix_html + phoenix_template + phoenix_view + plug + telemetry + ]; + }; + + phoenix_pubsub = buildMix rec { + name = "phoenix_pubsub"; + version = "2.1.3"; - src = fetchHex { - pkg = "phoenix_pubsub"; - version = "${version}"; - sha256 = "bba06bc1dcfd8cb086759f0edc94a8ba2bc8896d5331a1e2c2902bf8e36ee502"; - }; - - beamDeps = []; - }; + src = fetchHex { + pkg = "phoenix_pubsub"; + version = "${version}"; + sha256 = "bba06bc1dcfd8cb086759f0edc94a8ba2bc8896d5331a1e2c2902bf8e36ee502"; + }; - phoenix_swoosh = buildMix rec { - name = "phoenix_swoosh"; - version = "1.2.1"; + beamDeps = [ ]; + }; + + phoenix_swoosh = buildMix rec { + name = "phoenix_swoosh"; + version = "1.2.1"; + + src = fetchHex { + pkg = "phoenix_swoosh"; + version = "${version}"; + sha256 = "4000eeba3f9d7d1a6bf56d2bd56733d5cadf41a7f0d8ffe5bb67e7d667e204a2"; + }; - src = fetchHex { - pkg = "phoenix_swoosh"; - version = "${version}"; - sha256 = "4000eeba3f9d7d1a6bf56d2bd56733d5cadf41a7f0d8ffe5bb67e7d667e204a2"; + beamDeps = [ + hackney + phoenix + phoenix_html + phoenix_view + swoosh + ]; }; - beamDeps = [ hackney phoenix phoenix_html phoenix_view swoosh ]; - }; + phoenix_template = buildMix rec { + name = "phoenix_template"; + version = "1.0.4"; - phoenix_template = buildMix rec { - name = "phoenix_template"; - version = "1.0.4"; + src = fetchHex { + pkg = "phoenix_template"; + version = "${version}"; + sha256 = "2c0c81f0e5c6753faf5cca2f229c9709919aba34fab866d3bc05060c9c444206"; + }; - src = fetchHex { - pkg = "phoenix_template"; - version = "${version}"; - sha256 = "2c0c81f0e5c6753faf5cca2f229c9709919aba34fab866d3bc05060c9c444206"; + beamDeps = [ phoenix_html ]; }; - beamDeps = [ phoenix_html ]; - }; + phoenix_view = buildMix rec { + name = "phoenix_view"; + version = "2.0.3"; - phoenix_view = buildMix rec { - name = "phoenix_view"; - version = "2.0.3"; + src = fetchHex { + pkg = "phoenix_view"; + version = "${version}"; + sha256 = "cd34049af41be2c627df99cd4eaa71fc52a328c0c3d8e7d4aa28f880c30e7f64"; + }; - src = fetchHex { - pkg = "phoenix_view"; - version = "${version}"; - sha256 = "cd34049af41be2c627df99cd4eaa71fc52a328c0c3d8e7d4aa28f880c30e7f64"; + beamDeps = [ + phoenix_html + phoenix_template + ]; }; - beamDeps = [ phoenix_html phoenix_template ]; - }; + plug = buildMix rec { + name = "plug"; + version = "1.15.3"; - plug = buildMix rec { - name = "plug"; - version = "1.15.3"; + src = fetchHex { + pkg = "plug"; + version = "${version}"; + sha256 = "cc4365a3c010a56af402e0809208873d113e9c38c401cabd88027ef4f5c01fd2"; + }; - src = fetchHex { - pkg = "plug"; - version = "${version}"; - sha256 = "cc4365a3c010a56af402e0809208873d113e9c38c401cabd88027ef4f5c01fd2"; + beamDeps = [ + mime + plug_crypto + telemetry + ]; }; - beamDeps = [ mime plug_crypto telemetry ]; - }; + plug_crypto = buildMix rec { + name = "plug_crypto"; + version = "2.0.0"; - plug_crypto = buildMix rec { - name = "plug_crypto"; - version = "2.0.0"; + src = fetchHex { + pkg = "plug_crypto"; + version = "${version}"; + sha256 = "53695bae57cc4e54566d993eb01074e4d894b65a3766f1c43e2c61a1b0f45ea9"; + }; - src = fetchHex { - pkg = "plug_crypto"; - version = "${version}"; - sha256 = "53695bae57cc4e54566d993eb01074e4d894b65a3766f1c43e2c61a1b0f45ea9"; + beamDeps = [ ]; }; - beamDeps = []; - }; + poolboy = buildRebar3 rec { + name = "poolboy"; + version = "1.5.2"; - poolboy = buildRebar3 rec { - name = "poolboy"; - version = "1.5.2"; + src = fetchHex { + pkg = "poolboy"; + version = "${version}"; + sha256 = "dad79704ce5440f3d5a3681c8590b9dc25d1a561e8f5a9c995281012860901e3"; + }; - src = fetchHex { - pkg = "poolboy"; - version = "${version}"; - sha256 = "dad79704ce5440f3d5a3681c8590b9dc25d1a561e8f5a9c995281012860901e3"; + beamDeps = [ ]; }; - beamDeps = []; - }; + postgrex = buildMix rec { + name = "postgrex"; + version = "0.17.4"; - postgrex = buildMix rec { - name = "postgrex"; - version = "0.17.4"; + src = fetchHex { + pkg = "postgrex"; + version = "${version}"; + sha256 = "6458f7d5b70652bc81c3ea759f91736c16a31be000f306d3c64bcdfe9a18b3cc"; + }; - src = fetchHex { - pkg = "postgrex"; - version = "${version}"; - sha256 = "6458f7d5b70652bc81c3ea759f91736c16a31be000f306d3c64bcdfe9a18b3cc"; + beamDeps = [ + db_connection + decimal + jason + ]; }; - beamDeps = [ db_connection decimal jason ]; - }; + progress_bar = buildMix rec { + name = "progress_bar"; + version = "3.0.0"; - progress_bar = buildMix rec { - name = "progress_bar"; - version = "3.0.0"; + src = fetchHex { + pkg = "progress_bar"; + version = "${version}"; + sha256 = "6981c2b25ab24aecc91a2dc46623658e1399c21a2ae24db986b90d678530f2b7"; + }; - src = fetchHex { - pkg = "progress_bar"; - version = "${version}"; - sha256 = "6981c2b25ab24aecc91a2dc46623658e1399c21a2ae24db986b90d678530f2b7"; + beamDeps = [ decimal ]; }; - beamDeps = [ decimal ]; - }; + ranch = buildRebar3 rec { + name = "ranch"; + version = "2.1.0"; - ranch = buildRebar3 rec { - name = "ranch"; - version = "2.1.0"; + src = fetchHex { + pkg = "ranch"; + version = "${version}"; + sha256 = "244ee3fa2a6175270d8e1fc59024fd9dbc76294a321057de8f803b1479e76916"; + }; - src = fetchHex { - pkg = "ranch"; - version = "${version}"; - sha256 = "244ee3fa2a6175270d8e1fc59024fd9dbc76294a321057de8f803b1479e76916"; + beamDeps = [ ]; }; - beamDeps = []; - }; + remote_ip = buildMix rec { + name = "remote_ip"; + version = "1.1.0"; - remote_ip = buildMix rec { - name = "remote_ip"; - version = "1.1.0"; + src = fetchHex { + pkg = "remote_ip"; + version = "${version}"; + sha256 = "616ffdf66aaad6a72fc546dabf42eed87e2a99e97b09cbd92b10cc180d02ed74"; + }; - src = fetchHex { - pkg = "remote_ip"; - version = "${version}"; - sha256 = "616ffdf66aaad6a72fc546dabf42eed87e2a99e97b09cbd92b10cc180d02ed74"; + beamDeps = [ + combine + plug + ]; }; - beamDeps = [ combine plug ]; - }; + replug = buildMix rec { + name = "replug"; + version = "0.1.0"; - replug = buildMix rec { - name = "replug"; - version = "0.1.0"; + src = fetchHex { + pkg = "replug"; + version = "${version}"; + sha256 = "f71f7a57e944e854fe4946060c6964098e53958074c69fb844b96e0bd58cfa60"; + }; - src = fetchHex { - pkg = "replug"; - version = "${version}"; - sha256 = "f71f7a57e944e854fe4946060c6964098e53958074c69fb844b96e0bd58cfa60"; + beamDeps = [ plug ]; }; - beamDeps = [ plug ]; - }; + sentry = buildMix rec { + name = "sentry"; + version = "8.1.0"; - sentry = buildMix rec { - name = "sentry"; - version = "8.1.0"; + src = fetchHex { + pkg = "sentry"; + version = "${version}"; + sha256 = "f9fc7641ef61e885510f5e5963c2948b9de1de597c63f781e9d3d6c9c8681ab4"; + }; - src = fetchHex { - pkg = "sentry"; - version = "${version}"; - sha256 = "f9fc7641ef61e885510f5e5963c2948b9de1de597c63f781e9d3d6c9c8681ab4"; + beamDeps = [ + hackney + jason + plug + ]; }; - beamDeps = [ hackney jason plug ]; - }; + shortuuid = buildMix rec { + name = "shortuuid"; + version = "3.0.0"; - shortuuid = buildMix rec { - name = "shortuuid"; - version = "3.0.0"; + src = fetchHex { + pkg = "shortuuid"; + version = "${version}"; + sha256 = "dfd8f80f514cbb91622cb83f4ac0d6e2f06d98cc6d4aeba94444a212289d0d39"; + }; - src = fetchHex { - pkg = "shortuuid"; - version = "${version}"; - sha256 = "dfd8f80f514cbb91622cb83f4ac0d6e2f06d98cc6d4aeba94444a212289d0d39"; + beamDeps = [ ]; }; - beamDeps = []; - }; + sitemapper = buildMix rec { + name = "sitemapper"; + version = "0.8.0"; - sitemapper = buildMix rec { - name = "sitemapper"; - version = "0.8.0"; + src = fetchHex { + pkg = "sitemapper"; + version = "${version}"; + sha256 = "7cd42b454035da457151c9b6a314b688b5bbe5383add95badc65d013c25989c5"; + }; - src = fetchHex { - pkg = "sitemapper"; - version = "${version}"; - sha256 = "7cd42b454035da457151c9b6a314b688b5bbe5383add95badc65d013c25989c5"; + beamDeps = [ xml_builder ]; }; - beamDeps = [ xml_builder ]; - }; + sleeplocks = buildRebar3 rec { + name = "sleeplocks"; + version = "1.1.2"; - sleeplocks = buildRebar3 rec { - name = "sleeplocks"; - version = "1.1.2"; + src = fetchHex { + pkg = "sleeplocks"; + version = "${version}"; + sha256 = "9fe5d048c5b781d6305c1a3a0f40bb3dfc06f49bf40571f3d2d0c57eaa7f59a5"; + }; - src = fetchHex { - pkg = "sleeplocks"; - version = "${version}"; - sha256 = "9fe5d048c5b781d6305c1a3a0f40bb3dfc06f49bf40571f3d2d0c57eaa7f59a5"; + beamDeps = [ ]; }; - beamDeps = []; - }; + slugger = buildMix rec { + name = "slugger"; + version = "0.3.0"; - slugger = buildMix rec { - name = "slugger"; - version = "0.3.0"; + src = fetchHex { + pkg = "slugger"; + version = "${version}"; + sha256 = "20d0ded0e712605d1eae6c5b4889581c3460d92623a930ddda91e0e609b5afba"; + }; - src = fetchHex { - pkg = "slugger"; - version = "${version}"; - sha256 = "20d0ded0e712605d1eae6c5b4889581c3460d92623a930ddda91e0e609b5afba"; + beamDeps = [ ]; }; - beamDeps = []; - }; + slugify = buildMix rec { + name = "slugify"; + version = "1.3.1"; - slugify = buildMix rec { - name = "slugify"; - version = "1.3.1"; + src = fetchHex { + pkg = "slugify"; + version = "${version}"; + sha256 = "cb090bbeb056b312da3125e681d98933a360a70d327820e4b7f91645c4d8be76"; + }; - src = fetchHex { - pkg = "slugify"; - version = "${version}"; - sha256 = "cb090bbeb056b312da3125e681d98933a360a70d327820e4b7f91645c4d8be76"; + beamDeps = [ ]; }; - beamDeps = []; - }; + sobelow = buildMix rec { + name = "sobelow"; + version = "0.13.0"; - sobelow = buildMix rec { - name = "sobelow"; - version = "0.13.0"; + src = fetchHex { + pkg = "sobelow"; + version = "${version}"; + sha256 = "cd6e9026b85fc35d7529da14f95e85a078d9dd1907a9097b3ba6ac7ebbe34a0d"; + }; - src = fetchHex { - pkg = "sobelow"; - version = "${version}"; - sha256 = "cd6e9026b85fc35d7529da14f95e85a078d9dd1907a9097b3ba6ac7ebbe34a0d"; + beamDeps = [ jason ]; }; - beamDeps = [ jason ]; - }; + ssl_verify_fun = buildRebar3 rec { + name = "ssl_verify_fun"; + version = "1.1.7"; - ssl_verify_fun = buildRebar3 rec { - name = "ssl_verify_fun"; - version = "1.1.7"; + src = fetchHex { + pkg = "ssl_verify_fun"; + version = "${version}"; + sha256 = "fe4c190e8f37401d30167c8c405eda19469f34577987c76dde613e838bbc67f8"; + }; - src = fetchHex { - pkg = "ssl_verify_fun"; - version = "${version}"; - sha256 = "fe4c190e8f37401d30167c8c405eda19469f34577987c76dde613e838bbc67f8"; + beamDeps = [ ]; }; - beamDeps = []; - }; + struct_access = buildMix rec { + name = "struct_access"; + version = "1.1.2"; - struct_access = buildMix rec { - name = "struct_access"; - version = "1.1.2"; + src = fetchHex { + pkg = "struct_access"; + version = "${version}"; + sha256 = "e4c411dcc0226081b95709909551fc92b8feb1a3476108348ea7e3f6c12e586a"; + }; - src = fetchHex { - pkg = "struct_access"; - version = "${version}"; - sha256 = "e4c411dcc0226081b95709909551fc92b8feb1a3476108348ea7e3f6c12e586a"; + beamDeps = [ ]; }; - beamDeps = []; - }; + sweet_xml = buildMix rec { + name = "sweet_xml"; + version = "0.7.4"; - sweet_xml = buildMix rec { - name = "sweet_xml"; - version = "0.7.4"; + src = fetchHex { + pkg = "sweet_xml"; + version = "${version}"; + sha256 = "e7c4b0bdbf460c928234951def54fe87edf1a170f6896675443279e2dbeba167"; + }; - src = fetchHex { - pkg = "sweet_xml"; - version = "${version}"; - sha256 = "e7c4b0bdbf460c928234951def54fe87edf1a170f6896675443279e2dbeba167"; + beamDeps = [ ]; }; - beamDeps = []; - }; + swoosh = buildMix rec { + name = "swoosh"; + version = "1.15.3"; - swoosh = buildMix rec { - name = "swoosh"; - version = "1.15.3"; + src = fetchHex { + pkg = "swoosh"; + version = "${version}"; + sha256 = "97a667b96ca8cc48a4679f6cd1f40a36d8701cf052587298473614caa70f164a"; + }; - src = fetchHex { - pkg = "swoosh"; - version = "${version}"; - sha256 = "97a667b96ca8cc48a4679f6cd1f40a36d8701cf052587298473614caa70f164a"; + beamDeps = [ + bandit + gen_smtp + hackney + jason + mime + plug + telemetry + ]; }; - beamDeps = [ bandit gen_smtp hackney jason mime plug telemetry ]; - }; + telemetry = buildRebar3 rec { + name = "telemetry"; + version = "1.2.1"; - telemetry = buildRebar3 rec { - name = "telemetry"; - version = "1.2.1"; + src = fetchHex { + pkg = "telemetry"; + version = "${version}"; + sha256 = "dad9ce9d8effc621708f99eac538ef1cbe05d6a874dd741de2e689c47feafed5"; + }; - src = fetchHex { - pkg = "telemetry"; - version = "${version}"; - sha256 = "dad9ce9d8effc621708f99eac538ef1cbe05d6a874dd741de2e689c47feafed5"; + beamDeps = [ ]; }; - beamDeps = []; - }; + tesla = buildMix rec { + name = "tesla"; + version = "1.8.0"; - tesla = buildMix rec { - name = "tesla"; - version = "1.8.0"; + src = fetchHex { + pkg = "tesla"; + version = "${version}"; + sha256 = "10501f360cd926a309501287470372af1a6e1cbed0f43949203a4c13300bc79f"; + }; - src = fetchHex { - pkg = "tesla"; - version = "${version}"; - sha256 = "10501f360cd926a309501287470372af1a6e1cbed0f43949203a4c13300bc79f"; + beamDeps = [ + castore + hackney + jason + mime + telemetry + ]; }; - beamDeps = [ castore hackney jason mime telemetry ]; - }; + thousand_island = buildMix rec { + name = "thousand_island"; + version = "1.3.5"; - thousand_island = buildMix rec { - name = "thousand_island"; - version = "1.3.5"; + src = fetchHex { + pkg = "thousand_island"; + version = "${version}"; + sha256 = "2be6954916fdfe4756af3239fb6b6d75d0b8063b5df03ba76fd8a4c87849e180"; + }; - src = fetchHex { - pkg = "thousand_island"; - version = "${version}"; - sha256 = "2be6954916fdfe4756af3239fb6b6d75d0b8063b5df03ba76fd8a4c87849e180"; + beamDeps = [ telemetry ]; }; - beamDeps = [ telemetry ]; - }; + timex = buildMix rec { + name = "timex"; + version = "3.7.11"; - timex = buildMix rec { - name = "timex"; - version = "3.7.11"; + src = fetchHex { + pkg = "timex"; + version = "${version}"; + sha256 = "8b9024f7efbabaf9bd7aa04f65cf8dcd7c9818ca5737677c7b76acbc6a94d1aa"; + }; - src = fetchHex { - pkg = "timex"; - version = "${version}"; - sha256 = "8b9024f7efbabaf9bd7aa04f65cf8dcd7c9818ca5737677c7b76acbc6a94d1aa"; + beamDeps = [ + combine + gettext + tzdata + ]; }; - beamDeps = [ combine gettext tzdata ]; - }; + tls_certificate_check = buildRebar3 rec { + name = "tls_certificate_check"; + version = "1.21.0"; - tls_certificate_check = buildRebar3 rec { - name = "tls_certificate_check"; - version = "1.21.0"; + src = fetchHex { + pkg = "tls_certificate_check"; + version = "${version}"; + sha256 = "6cee6cffc35a390840d48d463541d50746a7b0e421acaadb833cfc7961e490e7"; + }; - src = fetchHex { - pkg = "tls_certificate_check"; - version = "${version}"; - sha256 = "6cee6cffc35a390840d48d463541d50746a7b0e421acaadb833cfc7961e490e7"; + beamDeps = [ ssl_verify_fun ]; }; - beamDeps = [ ssl_verify_fun ]; - }; + tz_world = buildMix rec { + name = "tz_world"; + version = "1.3.2"; - tz_world = buildMix rec { - name = "tz_world"; - version = "1.3.2"; + src = fetchHex { + pkg = "tz_world"; + version = "${version}"; + sha256 = "d1a345e07b3378c4c902ad54fbd5d54c8c3dd55dba883b7407fe57bcec45ff2a"; + }; - src = fetchHex { - pkg = "tz_world"; - version = "${version}"; - sha256 = "d1a345e07b3378c4c902ad54fbd5d54c8c3dd55dba883b7407fe57bcec45ff2a"; + beamDeps = [ + castore + certifi + geo + jason + ]; }; - beamDeps = [ castore certifi geo jason ]; - }; + tzdata = buildMix rec { + name = "tzdata"; + version = "1.1.1"; - tzdata = buildMix rec { - name = "tzdata"; - version = "1.1.1"; + src = fetchHex { + pkg = "tzdata"; + version = "${version}"; + sha256 = "a69cec8352eafcd2e198dea28a34113b60fdc6cb57eb5ad65c10292a6ba89787"; + }; - src = fetchHex { - pkg = "tzdata"; - version = "${version}"; - sha256 = "a69cec8352eafcd2e198dea28a34113b60fdc6cb57eb5ad65c10292a6ba89787"; + beamDeps = [ hackney ]; }; - beamDeps = [ hackney ]; - }; + ueberauth = buildMix rec { + name = "ueberauth"; + version = "0.10.8"; - ueberauth = buildMix rec { - name = "ueberauth"; - version = "0.10.8"; + src = fetchHex { + pkg = "ueberauth"; + version = "${version}"; + sha256 = "f2d3172e52821375bccb8460e5fa5cb91cfd60b19b636b6e57e9759b6f8c10c1"; + }; - src = fetchHex { - pkg = "ueberauth"; - version = "${version}"; - sha256 = "f2d3172e52821375bccb8460e5fa5cb91cfd60b19b636b6e57e9759b6f8c10c1"; + beamDeps = [ plug ]; }; - beamDeps = [ plug ]; - }; + ueberauth_cas = buildMix rec { + name = "ueberauth_cas"; + version = "2.3.1"; - ueberauth_cas = buildMix rec { - name = "ueberauth_cas"; - version = "2.3.1"; + src = fetchHex { + pkg = "ueberauth_cas"; + version = "${version}"; + sha256 = "5068ae2b9e217c2f05aa9a67483a6531e21ba0be9a6f6c8749bb7fd1599be321"; + }; - src = fetchHex { - pkg = "ueberauth_cas"; - version = "${version}"; - sha256 = "5068ae2b9e217c2f05aa9a67483a6531e21ba0be9a6f6c8749bb7fd1599be321"; + beamDeps = [ + httpoison + sweet_xml + ueberauth + ]; }; - beamDeps = [ httpoison sweet_xml ueberauth ]; - }; + ueberauth_discord = buildMix rec { + name = "ueberauth_discord"; + version = "0.7.0"; - ueberauth_discord = buildMix rec { - name = "ueberauth_discord"; - version = "0.7.0"; + src = fetchHex { + pkg = "ueberauth_discord"; + version = "${version}"; + sha256 = "d6f98ef91abb4ddceada4b7acba470e0e68c4d2de9735ff2f24172a8e19896b4"; + }; - src = fetchHex { - pkg = "ueberauth_discord"; - version = "${version}"; - sha256 = "d6f98ef91abb4ddceada4b7acba470e0e68c4d2de9735ff2f24172a8e19896b4"; + beamDeps = [ + oauth2 + ueberauth + ]; }; - beamDeps = [ oauth2 ueberauth ]; - }; + ueberauth_facebook = buildMix rec { + name = "ueberauth_facebook"; + version = "0.10.0"; - ueberauth_facebook = buildMix rec { - name = "ueberauth_facebook"; - version = "0.10.0"; + src = fetchHex { + pkg = "ueberauth_facebook"; + version = "${version}"; + sha256 = "bf8ce5d66b1c50da8abff77e8086c1b710bdde63f4acaef19a651ba43a9537a8"; + }; - src = fetchHex { - pkg = "ueberauth_facebook"; - version = "${version}"; - sha256 = "bf8ce5d66b1c50da8abff77e8086c1b710bdde63f4acaef19a651ba43a9537a8"; + beamDeps = [ + oauth2 + ueberauth + ]; }; - beamDeps = [ oauth2 ueberauth ]; - }; + ueberauth_github = buildMix rec { + name = "ueberauth_github"; + version = "0.8.3"; - ueberauth_github = buildMix rec { - name = "ueberauth_github"; - version = "0.8.3"; + src = fetchHex { + pkg = "ueberauth_github"; + version = "${version}"; + sha256 = "ae0ab2879c32cfa51d7287a48219b262bfdab0b7ec6629f24160564247493cc6"; + }; - src = fetchHex { - pkg = "ueberauth_github"; - version = "${version}"; - sha256 = "ae0ab2879c32cfa51d7287a48219b262bfdab0b7ec6629f24160564247493cc6"; + beamDeps = [ + oauth2 + ueberauth + ]; }; - beamDeps = [ oauth2 ueberauth ]; - }; + ueberauth_gitlab_strategy = buildMix rec { + name = "ueberauth_gitlab_strategy"; + version = "0.4.0"; - ueberauth_gitlab_strategy = buildMix rec { - name = "ueberauth_gitlab_strategy"; - version = "0.4.0"; + src = fetchHex { + pkg = "ueberauth_gitlab_strategy"; + version = "${version}"; + sha256 = "e86e2e794bb063c07c05a6b1301b73f2be3ba9308d8f47ecc4d510ef9226091e"; + }; - src = fetchHex { - pkg = "ueberauth_gitlab_strategy"; - version = "${version}"; - sha256 = "e86e2e794bb063c07c05a6b1301b73f2be3ba9308d8f47ecc4d510ef9226091e"; + beamDeps = [ + oauth2 + ueberauth + ]; }; - beamDeps = [ oauth2 ueberauth ]; - }; + ueberauth_google = buildMix rec { + name = "ueberauth_google"; + version = "0.12.1"; - ueberauth_google = buildMix rec { - name = "ueberauth_google"; - version = "0.12.1"; + src = fetchHex { + pkg = "ueberauth_google"; + version = "${version}"; + sha256 = "7f7deacd679b2b66e3bffb68ecc77aa1b5396a0cbac2941815f253128e458c38"; + }; - src = fetchHex { - pkg = "ueberauth_google"; - version = "${version}"; - sha256 = "7f7deacd679b2b66e3bffb68ecc77aa1b5396a0cbac2941815f253128e458c38"; + beamDeps = [ + oauth2 + ueberauth + ]; }; - beamDeps = [ oauth2 ueberauth ]; - }; + ueberauth_keycloak_strategy = buildMix rec { + name = "ueberauth_keycloak_strategy"; + version = "0.4.0"; - ueberauth_keycloak_strategy = buildMix rec { - name = "ueberauth_keycloak_strategy"; - version = "0.4.0"; + src = fetchHex { + pkg = "ueberauth_keycloak_strategy"; + version = "${version}"; + sha256 = "c03027937bddcbd9ff499e457f9bb05f79018fa321abf79ebcfed2af0007211b"; + }; - src = fetchHex { - pkg = "ueberauth_keycloak_strategy"; - version = "${version}"; - sha256 = "c03027937bddcbd9ff499e457f9bb05f79018fa321abf79ebcfed2af0007211b"; + beamDeps = [ + oauth2 + ueberauth + ]; }; - beamDeps = [ oauth2 ueberauth ]; - }; + ueberauth_twitter = buildMix rec { + name = "ueberauth_twitter"; + version = "0.4.1"; - ueberauth_twitter = buildMix rec { - name = "ueberauth_twitter"; - version = "0.4.1"; + src = fetchHex { + pkg = "ueberauth_twitter"; + version = "${version}"; + sha256 = "83ca8ea3e1a3f976f1adbebfb323b9ebf53af453fbbf57d0486801a303b16065"; + }; - src = fetchHex { - pkg = "ueberauth_twitter"; - version = "${version}"; - sha256 = "83ca8ea3e1a3f976f1adbebfb323b9ebf53af453fbbf57d0486801a303b16065"; + beamDeps = [ + httpoison + oauther + ueberauth + ]; }; - beamDeps = [ httpoison oauther ueberauth ]; - }; + unicode_util_compat = buildRebar3 rec { + name = "unicode_util_compat"; + version = "0.7.0"; - unicode_util_compat = buildRebar3 rec { - name = "unicode_util_compat"; - version = "0.7.0"; + src = fetchHex { + pkg = "unicode_util_compat"; + version = "${version}"; + sha256 = "25eee6d67df61960cf6a794239566599b09e17e668d3700247bc498638152521"; + }; - src = fetchHex { - pkg = "unicode_util_compat"; - version = "${version}"; - sha256 = "25eee6d67df61960cf6a794239566599b09e17e668d3700247bc498638152521"; + beamDeps = [ ]; }; - beamDeps = []; - }; + unplug = buildMix rec { + name = "unplug"; + version = "1.0.0"; - unplug = buildMix rec { - name = "unplug"; - version = "1.0.0"; + src = fetchHex { + pkg = "unplug"; + version = "${version}"; + sha256 = "d171a85758aa412d4e85b809c203e1b1c4c76a4d6ab58e68dc9a8a8acd9b7c3a"; + }; - src = fetchHex { - pkg = "unplug"; - version = "${version}"; - sha256 = "d171a85758aa412d4e85b809c203e1b1c4c76a4d6ab58e68dc9a8a8acd9b7c3a"; + beamDeps = [ plug ]; }; - beamDeps = [ plug ]; - }; + unsafe = buildMix rec { + name = "unsafe"; + version = "1.0.2"; - unsafe = buildMix rec { - name = "unsafe"; - version = "1.0.2"; + src = fetchHex { + pkg = "unsafe"; + version = "${version}"; + sha256 = "b485231683c3ab01a9cd44cb4a79f152c6f3bb87358439c6f68791b85c2df675"; + }; - src = fetchHex { - pkg = "unsafe"; - version = "${version}"; - sha256 = "b485231683c3ab01a9cd44cb4a79f152c6f3bb87358439c6f68791b85c2df675"; + beamDeps = [ ]; }; - beamDeps = []; - }; + vite_phx = buildMix rec { + name = "vite_phx"; + version = "0.3.1"; - vite_phx = buildMix rec { - name = "vite_phx"; - version = "0.3.1"; + src = fetchHex { + pkg = "vite_phx"; + version = "${version}"; + sha256 = "08b1726094a131490ff0a2c7764c4cdd4b5cdf8ba9762638a5dd4bcd9e5fc936"; + }; - src = fetchHex { - pkg = "vite_phx"; - version = "${version}"; - sha256 = "08b1726094a131490ff0a2c7764c4cdd4b5cdf8ba9762638a5dd4bcd9e5fc936"; + beamDeps = [ + jason + phoenix + ]; }; - beamDeps = [ jason phoenix ]; - }; + websock = buildMix rec { + name = "websock"; + version = "0.5.3"; - websock = buildMix rec { - name = "websock"; - version = "0.5.3"; + src = fetchHex { + pkg = "websock"; + version = "${version}"; + sha256 = "6105453d7fac22c712ad66fab1d45abdf049868f253cf719b625151460b8b453"; + }; - src = fetchHex { - pkg = "websock"; - version = "${version}"; - sha256 = "6105453d7fac22c712ad66fab1d45abdf049868f253cf719b625151460b8b453"; + beamDeps = [ ]; }; - beamDeps = []; - }; + websock_adapter = buildMix rec { + name = "websock_adapter"; + version = "0.5.5"; - websock_adapter = buildMix rec { - name = "websock_adapter"; - version = "0.5.5"; + src = fetchHex { + pkg = "websock_adapter"; + version = "${version}"; + sha256 = "4b977ba4a01918acbf77045ff88de7f6972c2a009213c515a445c48f224ffce9"; + }; - src = fetchHex { - pkg = "websock_adapter"; - version = "${version}"; - sha256 = "4b977ba4a01918acbf77045ff88de7f6972c2a009213c515a445c48f224ffce9"; + beamDeps = [ + bandit + plug + websock + ]; }; - beamDeps = [ bandit plug websock ]; - }; + xml_builder = buildMix rec { + name = "xml_builder"; + version = "2.2.0"; - xml_builder = buildMix rec { - name = "xml_builder"; - version = "2.2.0"; + src = fetchHex { + pkg = "xml_builder"; + version = "${version}"; + sha256 = "9d66d52fb917565d358166a4314078d39ef04d552904de96f8e73f68f64a62c9"; + }; - src = fetchHex { - pkg = "xml_builder"; - version = "${version}"; - sha256 = "9d66d52fb917565d358166a4314078d39ef04d552904de96f8e73f68f64a62c9"; + beamDeps = [ ]; }; - - beamDeps = []; }; - }; -in self - +in +self diff --git a/pkgs/servers/monitoring/alerta/client.nix b/pkgs/servers/monitoring/alerta/client.nix index ea1e589ad4f291..80c59beb8174fe 100644 --- a/pkgs/servers/monitoring/alerta/client.nix +++ b/pkgs/servers/monitoring/alerta/client.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { @@ -13,7 +14,12 @@ python3.pkgs.buildPythonApplication rec { }; propagatedBuildInputs = with python3.pkgs; [ - six click requests requests-hawk pytz tabulate + six + click + requests + requests-hawk + pytz + tabulate ]; doCheck = false; diff --git a/pkgs/servers/monitoring/alerta/default.nix b/pkgs/servers/monitoring/alerta/default.nix index 61e878286ce2fa..4d2fae037fbd37 100644 --- a/pkgs/servers/monitoring/alerta/default.nix +++ b/pkgs/servers/monitoring/alerta/default.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchPypi +{ + lib, + python3, + fetchPypi, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/servers/monitoring/grafana/default.nix b/pkgs/servers/monitoring/grafana/default.nix index 7bcece9ffb17b3..91888297cd0db3 100644 --- a/pkgs/servers/monitoring/grafana/default.nix +++ b/pkgs/servers/monitoring/grafana/default.nix @@ -1,16 +1,32 @@ -{ lib, stdenv, buildGoModule, fetchFromGitHub, removeReferencesTo -, tzdata, wire -, yarn, nodejs, python3, cacert -, jq, moreutils -, nix-update-script, nixosTests, xcbuild -, faketty +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + removeReferencesTo, + tzdata, + wire, + yarn, + nodejs, + python3, + cacert, + jq, + moreutils, + nix-update-script, + nixosTests, + xcbuild, + faketty, }: buildGoModule rec { pname = "grafana"; version = "11.4.0"; - subPackages = [ "pkg/cmd/grafana" "pkg/cmd/grafana-server" "pkg/cmd/grafana-cli" ]; + subPackages = [ + "pkg/cmd/grafana" + "pkg/cmd/grafana-server" + "pkg/cmd/grafana-cli" + ]; src = fetchFromGitHub { owner = "grafana"; @@ -20,21 +36,27 @@ buildGoModule rec { }; # borrowed from: https://github.com/NixOS/nixpkgs/blob/d70d9425f49f9aba3c49e2c389fe6d42bac8c5b0/pkgs/development/tools/analysis/snyk/default.nix#L20-L22 - env = { - CYPRESS_INSTALL_BINARY = 0; - } // lib.optionalAttrs (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) { - # Fix error: no member named 'aligned_alloc' in the global namespace. - # Occurs while building @esfx/equatable@npm:1.0.2 on x86_64-darwin - NIX_CFLAGS_COMPILE = "-D_LIBCPP_HAS_NO_LIBRARY_ALIGNED_ALLOCATION=1"; - }; + env = + { + CYPRESS_INSTALL_BINARY = 0; + } + // lib.optionalAttrs (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) { + # Fix error: no member named 'aligned_alloc' in the global namespace. + # Occurs while building @esfx/equatable@npm:1.0.2 on x86_64-darwin + NIX_CFLAGS_COMPILE = "-D_LIBCPP_HAS_NO_LIBRARY_ALIGNED_ALLOCATION=1"; + }; offlineCache = stdenv.mkDerivation { name = "${pname}-${version}-yarn-offline-cache"; inherit src env; nativeBuildInputs = [ - yarn nodejs cacert - jq moreutils python3 - # @esfx/equatable@npm:1.0.2 fails to build on darwin as it requires `xcbuild` + yarn + nodejs + cacert + jq + moreutils + python3 + # @esfx/equatable@npm:1.0.2 fails to build on darwin as it requires `xcbuild` ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ xcbuild.xcbuild ]; buildPhase = '' runHook preBuild @@ -50,12 +72,14 @@ buildGoModule rec { dontInstall = true; dontFixup = true; outputHashMode = "recursive"; - outputHash = rec { - x86_64-linux = "sha256-5/l0vXVjHC4oG7ahVscJOwS74be7F8jei9nq6m2v2tQ="; - aarch64-linux = x86_64-linux; - aarch64-darwin = "sha256-+texKSlcvtoi83ySEXy2E4SqnfyQ0l4MixTBpdemWvI="; - x86_64-darwin = aarch64-darwin; - }.${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + outputHash = + rec { + x86_64-linux = "sha256-5/l0vXVjHC4oG7ahVscJOwS74be7F8jei9nq6m2v2tQ="; + aarch64-linux = x86_64-linux; + aarch64-darwin = "sha256-+texKSlcvtoi83ySEXy2E4SqnfyQ0l4MixTBpdemWvI="; + x86_64-darwin = aarch64-darwin; + } + .${stdenv.hostPlatform.system} or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); }; disallowedRequisites = [ offlineCache ]; @@ -64,8 +88,15 @@ buildGoModule rec { proxyVendor = true; - nativeBuildInputs = [ wire yarn jq moreutils removeReferencesTo python3 faketty ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ xcbuild.xcbuild ]; + nativeBuildInputs = [ + wire + yarn + jq + moreutils + removeReferencesTo + python3 + faketty + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ xcbuild.xcbuild ]; postConfigure = '' # Generate DI code that's required to compile the package. @@ -102,7 +133,9 @@ buildGoModule rec { ''; ldflags = [ - "-s" "-w" "-X main.version=${version}" + "-s" + "-w" + "-X main.version=${version}" ]; # Tests start http servers which need to bind to local addresses: @@ -135,8 +168,20 @@ buildGoModule rec { description = "Gorgeous metric viz, dashboards & editors for Graphite, InfluxDB & OpenTSDB"; license = licenses.agpl3Only; homepage = "https://grafana.com"; - maintainers = with maintainers; [ offline fpletz willibutz globin ma27 Frostman ]; - platforms = [ "x86_64-linux" "x86_64-darwin" "aarch64-linux" "aarch64-darwin" ]; + maintainers = with maintainers; [ + offline + fpletz + willibutz + globin + ma27 + Frostman + ]; + platforms = [ + "x86_64-linux" + "x86_64-darwin" + "aarch64-linux" + "aarch64-darwin" + ]; mainProgram = "grafana-server"; }; } diff --git a/pkgs/servers/monitoring/grafana/plugins/default.nix b/pkgs/servers/monitoring/grafana/plugins/default.nix index 95be470831c1d3..d388c3c5868879 100644 --- a/pkgs/servers/monitoring/grafana/plugins/default.nix +++ b/pkgs/servers/monitoring/grafana/plugins/default.nix @@ -4,4 +4,4 @@ let callPackage = newScope (pkgs // plugins); plugins = import ./plugins.nix { inherit callPackage; }; in - plugins +plugins diff --git a/pkgs/servers/monitoring/grafana/plugins/grafana-plugin.nix b/pkgs/servers/monitoring/grafana/plugins/grafana-plugin.nix index 2351df623a5611..e9262c2cac7633 100644 --- a/pkgs/servers/monitoring/grafana/plugins/grafana-plugin.nix +++ b/pkgs/servers/monitoring/grafana/plugins/grafana-plugin.nix @@ -1,41 +1,73 @@ -{ stdenvNoCC, fetchurl, unzip, lib }: +{ + stdenvNoCC, + fetchurl, + unzip, + lib, +}: -{ pname, versionPrefix ? "", version, zipHash, meta ? {}, passthru ? {}, ... }@args: -let plat = stdenvNoCC.hostPlatform.system; in stdenvNoCC.mkDerivation ({ - inherit pname versionPrefix version; +{ + pname, + versionPrefix ? "", + version, + zipHash, + meta ? { }, + passthru ? { }, + ... +}@args: +let + plat = stdenvNoCC.hostPlatform.system; +in +stdenvNoCC.mkDerivation ( + { + inherit pname versionPrefix version; - src = if lib.isAttrs zipHash then - fetchurl { - name = "${pname}-${versionPrefix}${version}-${plat}.zip"; - hash = zipHash.${plat} or (throw "Unsupported system: ${plat}"); - url = "https://grafana.com/api/plugins/${pname}/versions/${versionPrefix}${version}/download" + { - x86_64-linux = "?os=linux&arch=amd64"; - aarch64-linux = "?os=linux&arch=arm64"; - x86_64-darwin = "?os=darwin&arch=amd64"; - aarch64-darwin = "?os=darwin&arch=arm64"; - }.${plat} or (throw "Unsupported system: ${plat}"); - } - else - fetchurl { - name = "${pname}-${versionPrefix}${version}.zip"; - hash = zipHash; - url = "https://grafana.com/api/plugins/${pname}/versions/${versionPrefix}${version}/download"; - } - ; + src = + if lib.isAttrs zipHash then + fetchurl { + name = "${pname}-${versionPrefix}${version}-${plat}.zip"; + hash = zipHash.${plat} or (throw "Unsupported system: ${plat}"); + url = + "https://grafana.com/api/plugins/${pname}/versions/${versionPrefix}${version}/download" + + { + x86_64-linux = "?os=linux&arch=amd64"; + aarch64-linux = "?os=linux&arch=arm64"; + x86_64-darwin = "?os=darwin&arch=amd64"; + aarch64-darwin = "?os=darwin&arch=arm64"; + } + .${plat} or (throw "Unsupported system: ${plat}"); + } + else + fetchurl { + name = "${pname}-${versionPrefix}${version}.zip"; + hash = zipHash; + url = "https://grafana.com/api/plugins/${pname}/versions/${versionPrefix}${version}/download"; + }; - nativeBuildInputs = [ unzip ]; + nativeBuildInputs = [ unzip ]; - installPhase = '' - cp -R "." "$out" - chmod -R a-w "$out" - chmod u+w "$out" - ''; + installPhase = '' + cp -R "." "$out" + chmod -R a-w "$out" + chmod u+w "$out" + ''; - passthru = { - updateScript = [ ./update-grafana-plugin.sh pname ]; - } // passthru; + passthru = { + updateScript = [ + ./update-grafana-plugin.sh + pname + ]; + } // passthru; - meta = { - homepage = "https://grafana.com/grafana/plugins/${pname}"; - } // meta; -} // (builtins.removeAttrs args [ "zipHash" "pname" "versionPrefix" "version" "sha256" "meta" ])) + meta = { + homepage = "https://grafana.com/grafana/plugins/${pname}"; + } // meta; + } + // (builtins.removeAttrs args [ + "zipHash" + "pname" + "versionPrefix" + "version" + "sha256" + "meta" + ]) +) diff --git a/pkgs/servers/monitoring/icinga2/default.nix b/pkgs/servers/monitoring/icinga2/default.nix index 1b833e9ccbafe1..c5646a7b5b8b32 100644 --- a/pkgs/servers/monitoring/icinga2/default.nix +++ b/pkgs/servers/monitoring/icinga2/default.nix @@ -1,11 +1,31 @@ -{ stdenv, runCommand, lib, fetchFromGitHub, cmake, flex, bison, systemd -, boost, openssl, patchelf, mariadb-connector-c, postgresql, zlib, tzdata -# Databases -, withMysql ? true, withPostgresql ? false -# Features -, withChecker ? true, withCompat ? false, withLivestatus ? false -, withNotification ? true, withPerfdata ? true, withIcingadb ? true -, nameSuffix ? "" }: +{ + stdenv, + runCommand, + lib, + fetchFromGitHub, + cmake, + flex, + bison, + systemd, + boost, + openssl, + patchelf, + mariadb-connector-c, + postgresql, + zlib, + tzdata, + # Databases + withMysql ? true, + withPostgresql ? false, + # Features + withChecker ? true, + withCompat ? false, + withLivestatus ? false, + withNotification ? true, + withPerfdata ? true, + withIcingadb ? true, + nameSuffix ? "", +}: stdenv.mkDerivation rec { pname = "icinga2${nameSuffix}"; @@ -24,40 +44,53 @@ stdenv.mkDerivation rec { ./no-var-directories.patch # Prevent /var directories from being created ]; - cmakeFlags = let - mkFeatureFlag = label: value: "-DICINGA2_WITH_${label}=${if value then "ON" else "OFF"}"; - in [ - # Paths - "-DCMAKE_INSTALL_SYSCONFDIR=etc" - "-DCMAKE_INSTALL_LOCALSTATEDIR=/var" - "-DCMAKE_INSTALL_FULL_SBINDIR=bin" - "-DICINGA2_RUNDIR=/run" - "-DMYSQL_INCLUDE_DIR=${mariadb-connector-c.dev}/include/mariadb" - "-DMYSQL_LIB=${mariadb-connector-c.out}/lib/mariadb/libmysqlclient.a" - "-DICINGA2_PLUGINDIR=bin" - "-DICINGA2_LTO_BUILD=yes" - # Features - (mkFeatureFlag "MYSQL" withMysql) - (mkFeatureFlag "PGSQL" withPostgresql) - (mkFeatureFlag "CHECKER" withChecker) - (mkFeatureFlag "COMPAT" withCompat) - (mkFeatureFlag "LIVESTATUS" withLivestatus) - (mkFeatureFlag "NOTIFICATION" withNotification) - (mkFeatureFlag "PERFDATA" withPerfdata) - (mkFeatureFlag "ICINGADB" withIcingadb) - # Misc. - "-DICINGA2_USER=icinga2" - "-DICINGA2_GROUP=icinga2" - "-DICINGA2_GIT_VERSION_INFO=OFF" - "-DUSE_SYSTEMD=ON" - ]; + cmakeFlags = + let + mkFeatureFlag = label: value: "-DICINGA2_WITH_${label}=${if value then "ON" else "OFF"}"; + in + [ + # Paths + "-DCMAKE_INSTALL_SYSCONFDIR=etc" + "-DCMAKE_INSTALL_LOCALSTATEDIR=/var" + "-DCMAKE_INSTALL_FULL_SBINDIR=bin" + "-DICINGA2_RUNDIR=/run" + "-DMYSQL_INCLUDE_DIR=${mariadb-connector-c.dev}/include/mariadb" + "-DMYSQL_LIB=${mariadb-connector-c.out}/lib/mariadb/libmysqlclient.a" + "-DICINGA2_PLUGINDIR=bin" + "-DICINGA2_LTO_BUILD=yes" + # Features + (mkFeatureFlag "MYSQL" withMysql) + (mkFeatureFlag "PGSQL" withPostgresql) + (mkFeatureFlag "CHECKER" withChecker) + (mkFeatureFlag "COMPAT" withCompat) + (mkFeatureFlag "LIVESTATUS" withLivestatus) + (mkFeatureFlag "NOTIFICATION" withNotification) + (mkFeatureFlag "PERFDATA" withPerfdata) + (mkFeatureFlag "ICINGADB" withIcingadb) + # Misc. + "-DICINGA2_USER=icinga2" + "-DICINGA2_GROUP=icinga2" + "-DICINGA2_GIT_VERSION_INFO=OFF" + "-DUSE_SYSTEMD=ON" + ]; - outputs = [ "out" "doc" ]; + outputs = [ + "out" + "doc" + ]; - buildInputs = [ boost openssl systemd ] - ++ lib.optional withPostgresql postgresql; + buildInputs = [ + boost + openssl + systemd + ] ++ lib.optional withPostgresql postgresql; - nativeBuildInputs = [ cmake flex bison patchelf ]; + nativeBuildInputs = [ + cmake + flex + bison + patchelf + ]; doCheck = true; nativeCheckInputs = [ tzdata ]; # legacytimeperiod/dst needs this diff --git a/pkgs/servers/monitoring/laurel/default.nix b/pkgs/servers/monitoring/laurel/default.nix index 54d38a52c6165c..2d5e9fe9262e5b 100644 --- a/pkgs/servers/monitoring/laurel/default.nix +++ b/pkgs/servers/monitoring/laurel/default.nix @@ -1,7 +1,8 @@ -{ acl -, fetchFromGitHub -, lib -, rustPlatform +{ + acl, + fetchFromGitHub, + lib, + rustPlatform, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/servers/monitoring/loki/promtail.nix b/pkgs/servers/monitoring/loki/promtail.nix index 15bf192e2351e0..2e2df636c26f5e 100644 --- a/pkgs/servers/monitoring/loki/promtail.nix +++ b/pkgs/servers/monitoring/loki/promtail.nix @@ -2,6 +2,6 @@ grafana-loki.overrideAttrs (o: { pname = "promtail"; - subPackages = ["clients/cmd/promtail"]; + subPackages = [ "clients/cmd/promtail" ]; CGO_ENABLED = 1; }) diff --git a/pkgs/servers/monitoring/openobserve/default.nix b/pkgs/servers/monitoring/openobserve/default.nix index 0948f72fcb09ed..7bc779d552d5de 100644 --- a/pkgs/servers/monitoring/openobserve/default.nix +++ b/pkgs/servers/monitoring/openobserve/default.nix @@ -1,17 +1,18 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, protobuf -, bzip2 -, oniguruma -, sqlite -, xz -, zlib -, zstd -, stdenv -, apple_sdk -, buildNpmPackage +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + protobuf, + bzip2, + oniguruma, + sqlite, + xz, + zlib, + zstd, + stdenv, + apple_sdk, + buildNpmPackage, }: let @@ -75,20 +76,25 @@ rustPlatform.buildRustPackage { protobuf ]; - buildInputs = [ - bzip2 - oniguruma - sqlite - xz - zlib - zstd - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with apple_sdk.frameworks; [ - CoreFoundation - CoreServices - IOKit - Security - SystemConfiguration - ]); + buildInputs = + [ + bzip2 + oniguruma + sqlite + xz + zlib + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with apple_sdk.frameworks; + [ + CoreFoundation + CoreServices + IOKit + Security + SystemConfiguration + ] + ); env = { RUSTONIG_SYSTEM_LIBONIG = true; diff --git a/pkgs/servers/monitoring/prometheus/alertmanager.nix b/pkgs/servers/monitoring/prometheus/alertmanager.nix index 1db975f591d985..57d8823e978776 100644 --- a/pkgs/servers/monitoring/prometheus/alertmanager.nix +++ b/pkgs/servers/monitoring/prometheus/alertmanager.nix @@ -1,9 +1,10 @@ -{ lib -, go -, buildGoModule -, fetchFromGitHub -, installShellFiles -, nixosTests +{ + lib, + go, + buildGoModule, + fetchFromGitHub, + installShellFiles, + nixosTests, }: buildGoModule rec { @@ -20,17 +21,24 @@ buildGoModule rec { vendorHash = "sha256-zkHIdEdAy44iV2F929NB3ISuUbxdecaeZcsNQQGd06E="; - subPackages = [ "cmd/alertmanager" "cmd/amtool" ]; - - ldflags = let t = "github.com/prometheus/common/version"; in [ - "-X ${t}.Version=${version}" - "-X ${t}.Revision=${src.rev}" - "-X ${t}.Branch=unknown" - "-X ${t}.BuildUser=nix@nixpkgs" - "-X ${t}.BuildDate=unknown" - "-X ${t}.GoVersion=${lib.getVersion go}" + subPackages = [ + "cmd/alertmanager" + "cmd/amtool" ]; + ldflags = + let + t = "github.com/prometheus/common/version"; + in + [ + "-X ${t}.Version=${version}" + "-X ${t}.Revision=${src.rev}" + "-X ${t}.Branch=unknown" + "-X ${t}.BuildUser=nix@nixpkgs" + "-X ${t}.BuildDate=unknown" + "-X ${t}.GoVersion=${lib.getVersion go}" + ]; + nativeBuildInputs = [ installShellFiles ]; postInstall = '' @@ -47,6 +55,11 @@ buildGoModule rec { homepage = "https://github.com/prometheus/alertmanager"; changelog = "https://github.com/prometheus/alertmanager/blob/v${version}/CHANGELOG.md"; license = licenses.asl20; - maintainers = with maintainers; [ benley fpletz globin Frostman ]; + maintainers = with maintainers; [ + benley + fpletz + globin + Frostman + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/apcupsd-exporter.nix b/pkgs/servers/monitoring/prometheus/apcupsd-exporter.nix index 1f6dd51d8989ad..585f0ca58c992e 100644 --- a/pkgs/servers/monitoring/prometheus/apcupsd-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/apcupsd-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "apcupsd-exporter"; @@ -20,6 +25,9 @@ buildGoModule rec { mainProgram = "apcupsd_exporter"; homepage = "https://github.com/mdlayher/apcupsd_exporter"; license = licenses.mit; - maintainers = with maintainers; [ _1000101 mdlayher ]; + maintainers = with maintainers; [ + _1000101 + mdlayher + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/artifactory-exporter.nix b/pkgs/servers/monitoring/prometheus/artifactory-exporter.nix index b9a11f47d8dbe8..a36851d7b28c05 100644 --- a/pkgs/servers/monitoring/prometheus/artifactory-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/artifactory-exporter.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/servers/monitoring/prometheus/atlas-exporter.nix b/pkgs/servers/monitoring/prometheus/atlas-exporter.nix index 755f1d64e15c80..5aaa34f65c52f7 100644 --- a/pkgs/servers/monitoring/prometheus/atlas-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/atlas-exporter.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "atlas-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/aws-s3-exporter.nix b/pkgs/servers/monitoring/prometheus/aws-s3-exporter.nix index b3855f532e9a61..bdfee37adbde48 100644 --- a/pkgs/servers/monitoring/prometheus/aws-s3-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/aws-s3-exporter.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "aws-s3-exporter"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = null; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Exports Prometheus metrics about S3 buckets and objects"; diff --git a/pkgs/servers/monitoring/prometheus/bird-exporter.nix b/pkgs/servers/monitoring/prometheus/bird-exporter.nix index 25a90e1fdb0a3a..b25523083d23c2 100644 --- a/pkgs/servers/monitoring/prometheus/bird-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/bird-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "bird-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/bitcoin-exporter.nix b/pkgs/servers/monitoring/prometheus/bitcoin-exporter.nix index 2f92d69d356086..6740df977e4ea1 100644 --- a/pkgs/servers/monitoring/prometheus/bitcoin-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/bitcoin-exporter.nix @@ -1,4 +1,8 @@ -{ lib, fetchFromGitHub, python3Packages }: +{ + lib, + fetchFromGitHub, + python3Packages, +}: python3Packages.buildPythonApplication rec { pname = "bitcoin-prometheus-exporter"; @@ -17,7 +21,11 @@ python3Packages.buildPythonApplication rec { # The makefile builds docker containers. dontBuild = true; - propagatedBuildInputs = with python3Packages; [ prometheus-client python-bitcoinlib riprova ]; + propagatedBuildInputs = with python3Packages; [ + prometheus-client + python-bitcoinlib + riprova + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/servers/monitoring/prometheus/blackbox-exporter.nix b/pkgs/servers/monitoring/prometheus/blackbox-exporter.nix index 66456a85e150f9..e0f97425ccc90a 100644 --- a/pkgs/servers/monitoring/prometheus/blackbox-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/blackbox-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "blackbox_exporter"; @@ -34,6 +39,12 @@ buildGoModule rec { mainProgram = "blackbox_exporter"; homepage = "https://github.com/prometheus/blackbox_exporter"; license = licenses.asl20; - maintainers = with maintainers; [ globin fpletz willibutz Frostman ma27 ]; + maintainers = with maintainers; [ + globin + fpletz + willibutz + Frostman + ma27 + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/collectd-exporter.nix b/pkgs/servers/monitoring/prometheus/collectd-exporter.nix index 56943bd502fd1e..e50c4f2fe54990 100644 --- a/pkgs/servers/monitoring/prometheus/collectd-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/collectd-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "collectd-exporter"; @@ -13,7 +18,10 @@ buildGoModule rec { vendorHash = "sha256-kr8mHprIfXc/Yj/w2UKBkqIYZHmWtBLjqYDvKSXlozQ="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; passthru.tests = { inherit (nixosTests.prometheus-exporters) collectd; }; diff --git a/pkgs/servers/monitoring/prometheus/consul-exporter.nix b/pkgs/servers/monitoring/prometheus/consul-exporter.nix index 5c386a898eda3c..24c23564f545c0 100644 --- a/pkgs/servers/monitoring/prometheus/consul-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/consul-exporter.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/servers/monitoring/prometheus/dnsmasq-exporter.nix b/pkgs/servers/monitoring/prometheus/dnsmasq-exporter.nix index e78efeb22d85e2..15dde30d122ede 100644 --- a/pkgs/servers/monitoring/prometheus/dnsmasq-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/dnsmasq-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGo122Module, fetchFromGitHub, nixosTests }: +{ + lib, + buildGo122Module, + fetchFromGitHub, + nixosTests, +}: buildGo122Module rec { pname = "dnsmasq_exporter"; @@ -22,6 +27,9 @@ buildGo122Module rec { description = "Dnsmasq exporter for Prometheus"; mainProgram = "dnsmasq_exporter"; license = licenses.asl20; - maintainers = with maintainers; [ willibutz globin ]; + maintainers = with maintainers; [ + willibutz + globin + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/domain-exporter.nix b/pkgs/servers/monitoring/prometheus/domain-exporter.nix index 8e25a2c523ad92..e09cfa5cb77590 100644 --- a/pkgs/servers/monitoring/prometheus/domain-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/domain-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "domain-exporter"; @@ -22,6 +27,11 @@ buildGoModule rec { description = "Exports the expiration time of your domains as prometheus metrics"; mainProgram = "domain_exporter"; license = licenses.mit; - maintainers = with maintainers; [ mmilata prusnak peterhoeg caarlos0 ]; + maintainers = with maintainers; [ + mmilata + prusnak + peterhoeg + caarlos0 + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/fastly-exporter.nix b/pkgs/servers/monitoring/prometheus/fastly-exporter.nix index 277d2a96d32ce2..fba05cc25c236d 100644 --- a/pkgs/servers/monitoring/prometheus/fastly-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/fastly-exporter.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/servers/monitoring/prometheus/flow-exporter.nix b/pkgs/servers/monitoring/prometheus/flow-exporter.nix index e5fa4a7dcf8322..2de347f3010d65 100644 --- a/pkgs/servers/monitoring/prometheus/flow-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/flow-exporter.nix @@ -1,4 +1,8 @@ -{ buildGoModule, fetchFromGitHub, lib }: +{ + buildGoModule, + fetchFromGitHub, + lib, +}: buildGoModule rec { pname = "flow-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/fritzbox-exporter.nix b/pkgs/servers/monitoring/prometheus/fritzbox-exporter.nix index d964f90cba44c4..922e6998564cd3 100644 --- a/pkgs/servers/monitoring/prometheus/fritzbox-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/fritzbox-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "fritzbox-exporter"; @@ -22,6 +27,10 @@ buildGoModule rec { mainProgram = "exporter"; homepage = "https://github.com/mxschmitt/fritzbox_exporter"; license = licenses.asl20; - maintainers = with maintainers; [ bachp flokli sbruder ]; + maintainers = with maintainers; [ + bachp + flokli + sbruder + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/gitlab-ci-pipelines-exporter.nix b/pkgs/servers/monitoring/prometheus/gitlab-ci-pipelines-exporter.nix index 6be53d0acd31dd..e8b8bcab6fad43 100644 --- a/pkgs/servers/monitoring/prometheus/gitlab-ci-pipelines-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/gitlab-ci-pipelines-exporter.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gitlab-ci-pipelines-exporter"; @@ -25,6 +29,9 @@ buildGoModule rec { mainProgram = "gitlab-ci-pipelines-exporter"; homepage = "https://github.com/mvisonneau/gitlab-ci-pipelines-exporter"; license = licenses.asl20; - maintainers = with maintainers; [ mmahut mvisonneau ]; + maintainers = with maintainers; [ + mmahut + mvisonneau + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/graphite-exporter.nix b/pkgs/servers/monitoring/prometheus/graphite-exporter.nix index ca0c735476af40..4837b6d6190a5c 100644 --- a/pkgs/servers/monitoring/prometheus/graphite-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/graphite-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "graphite-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/haproxy-exporter.nix b/pkgs/servers/monitoring/prometheus/haproxy-exporter.nix index 6795885afd3d40..527c8e0b2d0d46 100644 --- a/pkgs/servers/monitoring/prometheus/haproxy-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/haproxy-exporter.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "haproxy_exporter"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-s9UVtV8N2SJ1ik864P6p2hPXJ2jstFY/XnWt9fuCDo0="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "HAProxy Exporter for the Prometheus monitoring system"; diff --git a/pkgs/servers/monitoring/prometheus/idrac-exporter.nix b/pkgs/servers/monitoring/prometheus/idrac-exporter.nix index 1160984f00230f..716a108443b2d3 100644 --- a/pkgs/servers/monitoring/prometheus/idrac-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/idrac-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "idrac_exporter"; @@ -15,7 +20,10 @@ buildGoModule rec { patches = [ ./idrac-exporter/config-from-environment.patch ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; doCheck = true; diff --git a/pkgs/servers/monitoring/prometheus/imap-mailstat-exporter.nix b/pkgs/servers/monitoring/prometheus/imap-mailstat-exporter.nix index bd06041d0209b0..e8f18e916bdca4 100644 --- a/pkgs/servers/monitoring/prometheus/imap-mailstat-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/imap-mailstat-exporter.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/servers/monitoring/prometheus/influxdb-exporter.nix b/pkgs/servers/monitoring/prometheus/influxdb-exporter.nix index 1dd3422f76efaf..fd7e307e0ee73a 100644 --- a/pkgs/servers/monitoring/prometheus/influxdb-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/influxdb-exporter.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/servers/monitoring/prometheus/ipmi-exporter.nix b/pkgs/servers/monitoring/prometheus/ipmi-exporter.nix index 09b9d1be1cffca..9432dcd839b1dd 100644 --- a/pkgs/servers/monitoring/prometheus/ipmi-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/ipmi-exporter.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests, makeWrapper, freeipmi }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, + makeWrapper, + freeipmi, +}: buildGoModule rec { pname = "ipmi_exporter"; diff --git a/pkgs/servers/monitoring/prometheus/jitsi-exporter.nix b/pkgs/servers/monitoring/prometheus/jitsi-exporter.nix index 775818ca154845..7dff722c658fca 100644 --- a/pkgs/servers/monitoring/prometheus/jitsi-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/jitsi-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchgit, nixosTests }: +{ + lib, + buildGoModule, + fetchgit, + nixosTests, +}: buildGoModule rec { pname = "jitsiexporter"; diff --git a/pkgs/servers/monitoring/prometheus/jmx-httpserver.nix b/pkgs/servers/monitoring/prometheus/jmx-httpserver.nix index 9326e5bdff3fe2..94051a4bbc0f68 100644 --- a/pkgs/servers/monitoring/prometheus/jmx-httpserver.nix +++ b/pkgs/servers/monitoring/prometheus/jmx-httpserver.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, jre, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "jmx-prometheus-httpserver"; diff --git a/pkgs/servers/monitoring/prometheus/json-exporter.nix b/pkgs/servers/monitoring/prometheus/json-exporter.nix index 2f168c4c603338..0e9f7dbd63eae5 100644 --- a/pkgs/servers/monitoring/prometheus/json-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/json-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "prometheus-json-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/kea-exporter.nix b/pkgs/servers/monitoring/prometheus/kea-exporter.nix index f4965bd54fa879..06e0fee6a3b055 100644 --- a/pkgs/servers/monitoring/prometheus/kea-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/kea-exporter.nix @@ -1,7 +1,8 @@ -{ lib -, python3Packages -, fetchPypi -, nixosTests +{ + lib, + python3Packages, + fetchPypi, + nixosTests, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/servers/monitoring/prometheus/keylight-exporter.nix b/pkgs/servers/monitoring/prometheus/keylight-exporter.nix index 59dcd621ca728d..45525cd946e25b 100644 --- a/pkgs/servers/monitoring/prometheus/keylight-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/keylight-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "keylight-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/knot-exporter.nix b/pkgs/servers/monitoring/prometheus/knot-exporter.nix index 55c62327a0df4a..e48763d699896a 100644 --- a/pkgs/servers/monitoring/prometheus/knot-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/knot-exporter.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchPypi -, nixosTests +{ + lib, + python3, + fetchPypi, + nixosTests, }: python3.pkgs.buildPythonApplication rec { @@ -35,7 +36,10 @@ python3.pkgs.buildPythonApplication rec { description = "Prometheus exporter for Knot DNS"; homepage = "https://gitlab.nic.cz/knot/knot-dns/-/tree/master/python/knot_exporter"; license = licenses.gpl3Only; - maintainers = with maintainers; [ ma27 hexa ]; + maintainers = with maintainers; [ + ma27 + hexa + ]; mainProgram = "knot-exporter"; }; } diff --git a/pkgs/servers/monitoring/prometheus/kthxbye.nix b/pkgs/servers/monitoring/prometheus/kthxbye.nix index a0eb30f6819b6c..5d2a5c41709616 100644 --- a/pkgs/servers/monitoring/prometheus/kthxbye.nix +++ b/pkgs/servers/monitoring/prometheus/kthxbye.nix @@ -1,8 +1,9 @@ -{ pkgs -, lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + pkgs, + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: buildGoModule rec { diff --git a/pkgs/servers/monitoring/prometheus/lnd-exporter.nix b/pkgs/servers/monitoring/prometheus/lnd-exporter.nix index 7181fbfe224d0a..69e504dba38473 100644 --- a/pkgs/servers/monitoring/prometheus/lnd-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/lnd-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "lndmon"; diff --git a/pkgs/servers/monitoring/prometheus/mail-exporter.nix b/pkgs/servers/monitoring/prometheus/mail-exporter.nix index 851d297e760f8a..62b9697dca2230 100644 --- a/pkgs/servers/monitoring/prometheus/mail-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/mail-exporter.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + nixosTests, +}: buildGoModule { pname = "mailexporter"; @@ -27,7 +33,10 @@ buildGoModule { mainProgram = "mailexporter"; homepage = "https://github.com/cherti/mailexporter"; license = licenses.gpl3; - maintainers = with maintainers; [ willibutz globin ]; + maintainers = with maintainers; [ + willibutz + globin + ]; platforms = platforms.linux; }; } diff --git a/pkgs/servers/monitoring/prometheus/mikrotik-exporter.nix b/pkgs/servers/monitoring/prometheus/mikrotik-exporter.nix index 5d335f504bb3f0..57c1f78b151edc 100644 --- a/pkgs/servers/monitoring/prometheus/mikrotik-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/mikrotik-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "mikrotik-exporter-unstable"; diff --git a/pkgs/servers/monitoring/prometheus/modemmanager-exporter.nix b/pkgs/servers/monitoring/prometheus/modemmanager-exporter.nix index 6975f257043552..e6b2afa7500a47 100644 --- a/pkgs/servers/monitoring/prometheus/modemmanager-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/modemmanager-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "modemmanager-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/mongodb-exporter.nix b/pkgs/servers/monitoring/prometheus/mongodb-exporter.nix index bb077e1da97892..5b61a585a75c91 100644 --- a/pkgs/servers/monitoring/prometheus/mongodb-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/mongodb-exporter.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "mongodb_exporter"; @@ -28,12 +32,11 @@ buildGoModule rec { # nixpkgs doesn't have mongodb application available; doCheck = false; - meta = with lib; - { - description = "Prometheus exporter for MongoDB including sharding, replication and storage engines"; - homepage = "https://github.com/percona/mongodb_exporter"; - license = licenses.asl20; - maintainers = with maintainers; [ undefined-moe ]; - mainProgram = "mongodb_exporter"; - }; + meta = with lib; { + description = "Prometheus exporter for MongoDB including sharding, replication and storage engines"; + homepage = "https://github.com/percona/mongodb_exporter"; + license = licenses.asl20; + maintainers = with maintainers; [ undefined-moe ]; + mainProgram = "mongodb_exporter"; + }; } diff --git a/pkgs/servers/monitoring/prometheus/mysqld-exporter.nix b/pkgs/servers/monitoring/prometheus/mysqld-exporter.nix index fe489b3e41229a..e23db58e2bc339 100644 --- a/pkgs/servers/monitoring/prometheus/mysqld-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/mysqld-exporter.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "mysqld_exporter"; @@ -13,14 +17,19 @@ buildGoModule rec { vendorHash = "sha256-9mrvqY0wtoMVAL0PEJ/NWtFzaQPcQDAJvYPluwd2Nx4="; - ldflags = let t = "github.com/prometheus/common/version"; in [ - "-s" "-w" - "-X ${t}.Version=${version}" - "-X ${t}.Revision=${src.rev}" - "-X ${t}.Branch=unknown" - "-X ${t}.BuildUser=nix@nixpkgs" - "-X ${t}.BuildDate=unknown" - ]; + ldflags = + let + t = "github.com/prometheus/common/version"; + in + [ + "-s" + "-w" + "-X ${t}.Version=${version}" + "-X ${t}.Revision=${src.rev}" + "-X ${t}.Branch=unknown" + "-X ${t}.BuildUser=nix@nixpkgs" + "-X ${t}.BuildDate=unknown" + ]; # skips tests with external dependencies, e.g. on mysqld checkFlags = [ @@ -32,6 +41,9 @@ buildGoModule rec { mainProgram = "mysqld_exporter"; homepage = "https://github.com/prometheus/mysqld_exporter"; license = licenses.asl20; - maintainers = with maintainers; [ benley globin ]; + maintainers = with maintainers; [ + benley + globin + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/nats-exporter.nix b/pkgs/servers/monitoring/prometheus/nats-exporter.nix index 3bad1d97ac44db..3ea933d485272a 100644 --- a/pkgs/servers/monitoring/prometheus/nats-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/nats-exporter.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, gitUpdater, testers, prometheus-nats-exporter }: +{ + lib, + buildGoModule, + fetchFromGitHub, + gitUpdater, + testers, + prometheus-nats-exporter, +}: buildGoModule rec { pname = "prometheus-nats-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/nextcloud-exporter.nix b/pkgs/servers/monitoring/prometheus/nextcloud-exporter.nix index 1a8abfcb2c37c3..f07f4e099f489d 100644 --- a/pkgs/servers/monitoring/prometheus/nextcloud-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/nextcloud-exporter.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildGoModule, nixosTests }: +{ + lib, + fetchFromGitHub, + buildGoModule, + nixosTests, +}: buildGoModule rec { pname = "prometheus-nextcloud-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/nginx-exporter.nix b/pkgs/servers/monitoring/prometheus/nginx-exporter.nix index 0f279e0c339743..334a49bcdf6a8a 100644 --- a/pkgs/servers/monitoring/prometheus/nginx-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/nginx-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "nginx_exporter"; @@ -13,14 +18,18 @@ buildGoModule rec { vendorHash = "sha256-ua3Cm1VXRs3M58vJ/fEt7SH+ZYegt0WjOGRV/iU8qZk="; - ldflags = let t = "github.com/prometheus/common/version"; in [ - "-s" - "-w" - "-X ${t}.Version=${version}" - "-X ${t}.Branch=unknown" - "-X ${t}.BuildUser=nix@nixpkgs" - "-X ${t}.BuildDate=unknown" - ]; + ldflags = + let + t = "github.com/prometheus/common/version"; + in + [ + "-s" + "-w" + "-X ${t}.Version=${version}" + "-X ${t}.Branch=unknown" + "-X ${t}.BuildUser=nix@nixpkgs" + "-X ${t}.BuildDate=unknown" + ]; passthru.tests = { inherit (nixosTests.prometheus-exporters) nginx; }; @@ -29,6 +38,11 @@ buildGoModule rec { mainProgram = "nginx-prometheus-exporter"; homepage = "https://github.com/nginxinc/nginx-prometheus-exporter"; license = licenses.asl20; - maintainers = with maintainers; [ benley fpletz willibutz globin ]; + maintainers = with maintainers; [ + benley + fpletz + willibutz + globin + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/nginxlog-exporter.nix b/pkgs/servers/monitoring/prometheus/nginxlog-exporter.nix index 3883cdaff5cc52..08e49707907dd8 100644 --- a/pkgs/servers/monitoring/prometheus/nginxlog-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/nginxlog-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "nginxlog_exporter"; diff --git a/pkgs/servers/monitoring/prometheus/nut-exporter.nix b/pkgs/servers/monitoring/prometheus/nut-exporter.nix index c9ec09a92172ab..92ba73329bb45f 100644 --- a/pkgs/servers/monitoring/prometheus/nut-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/nut-exporter.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "nut-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/pgbouncer-exporter.nix b/pkgs/servers/monitoring/prometheus/pgbouncer-exporter.nix index d55bebea8aef80..569e8450109975 100644 --- a/pkgs/servers/monitoring/prometheus/pgbouncer-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/pgbouncer-exporter.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pgbouncer-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/php-fpm-exporter.nix b/pkgs/servers/monitoring/prometheus/php-fpm-exporter.nix index a9ede30627d6d0..c4c25909beddb3 100644 --- a/pkgs/servers/monitoring/prometheus/php-fpm-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/php-fpm-exporter.nix @@ -1,12 +1,13 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, installShellFiles -, getent -, nix-update-script -, testers -, prometheus-php-fpm-exporter +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + installShellFiles, + getent, + nix-update-script, + testers, + prometheus-php-fpm-exporter, }: buildGoModule rec { @@ -22,7 +23,10 @@ buildGoModule rec { vendorHash = "sha256-OK36tHkBtosdfEWFPYMtlbzCkh5cF35NBWYyJrb9fwg="; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; ldflags = [ "-X main.version=${version}" diff --git a/pkgs/servers/monitoring/prometheus/pihole-exporter.nix b/pkgs/servers/monitoring/prometheus/pihole-exporter.nix index 61a91bfd6de5b2..27ce43d42d599b 100644 --- a/pkgs/servers/monitoring/prometheus/pihole-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/pihole-exporter.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pihole-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/ping-exporter.nix b/pkgs/servers/monitoring/prometheus/ping-exporter.nix index 5419903508a408..60e60a795e3bae 100644 --- a/pkgs/servers/monitoring/prometheus/ping-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/ping-exporter.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "ping-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/postfix-exporter.nix b/pkgs/servers/monitoring/prometheus/postfix-exporter.nix index b34a9b3feba8db..5ae8b92f3d9c88 100644 --- a/pkgs/servers/monitoring/prometheus/postfix-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/postfix-exporter.nix @@ -1,10 +1,11 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, makeWrapper -, nixosTests -, systemd -, withSystemdSupport ? true +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + nixosTests, + systemd, + withSystemdSupport ? true, }: buildGoModule rec { @@ -20,7 +21,10 @@ buildGoModule rec { vendorHash = "sha256-a4Lk4wh4mvXEjLgFksZIVVtbp+zTUyjtLVuk7vuot2k="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; nativeBuildInputs = lib.optionals withSystemdSupport [ makeWrapper ]; buildInputs = lib.optionals withSystemdSupport [ systemd ]; @@ -38,6 +42,9 @@ buildGoModule rec { description = "Prometheus exporter for Postfix"; mainProgram = "postfix_exporter"; license = licenses.asl20; - maintainers = with maintainers; [ willibutz globin ]; + maintainers = with maintainers; [ + willibutz + globin + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/postgres-exporter.nix b/pkgs/servers/monitoring/prometheus/postgres-exporter.nix index 9156a01ed87d15..a8b8d36523b796 100644 --- a/pkgs/servers/monitoring/prometheus/postgres-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/postgres-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "postgres_exporter"; @@ -17,7 +22,9 @@ buildGoModule rec { let t = "github.com/prometheus/common/version"; in - [ "-s" "-w" + [ + "-s" + "-w" "-X ${t}.Version=${version}" "-X ${t}.Revision=unknown" "-X ${t}.Branch=unknown" @@ -34,6 +41,11 @@ buildGoModule rec { description = "Prometheus exporter for PostgreSQL"; mainProgram = "postgres_exporter"; license = licenses.asl20; - maintainers = with maintainers; [ fpletz globin willibutz ma27 ]; + maintainers = with maintainers; [ + fpletz + globin + willibutz + ma27 + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/process-exporter.nix b/pkgs/servers/monitoring/prometheus/process-exporter.nix index 7b80f8d3230875..8be36a4576b84d 100644 --- a/pkgs/servers/monitoring/prometheus/process-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/process-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "process-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/prom2json.nix b/pkgs/servers/monitoring/prometheus/prom2json.nix index 63f1d7e7b89e0b..d11e1a16aa2145 100644 --- a/pkgs/servers/monitoring/prometheus/prom2json.nix +++ b/pkgs/servers/monitoring/prometheus/prom2json.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "prom2json"; diff --git a/pkgs/servers/monitoring/prometheus/pve-exporter.nix b/pkgs/servers/monitoring/prometheus/pve-exporter.nix index e456af2ce10621..1ffd7baaace543 100644 --- a/pkgs/servers/monitoring/prometheus/pve-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/pve-exporter.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchPypi -, nixosTests +{ + lib, + python3, + fetchPypi, + nixosTests, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/servers/monitoring/prometheus/rabbitmq-exporter.nix b/pkgs/servers/monitoring/prometheus/rabbitmq-exporter.nix index f1d7f534c71e50..87144e1c6bdbe4 100644 --- a/pkgs/servers/monitoring/prometheus/rabbitmq-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/rabbitmq-exporter.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "rabbitmq_exporter"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-ER0vK0xYUbQT3bqUosQMFT7HBycb3U8oI4Eak72myzs="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; checkFlags = [ # Disable flaky tests on Darwin diff --git a/pkgs/servers/monitoring/prometheus/redis-exporter.nix b/pkgs/servers/monitoring/prometheus/redis-exporter.nix index 8197f3d08b95b8..6f1ed7ef5cf1e1 100644 --- a/pkgs/servers/monitoring/prometheus/redis-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/redis-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "redis_exporter"; @@ -29,6 +34,10 @@ buildGoModule rec { mainProgram = "redis_exporter"; homepage = "https://github.com/oliver006/redis_exporter"; license = licenses.mit; - maintainers = with maintainers; [ eskytthe srhb ma27 ]; + maintainers = with maintainers; [ + eskytthe + srhb + ma27 + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/rtl_433-exporter.nix b/pkgs/servers/monitoring/prometheus/rtl_433-exporter.nix index 7319f8e2a7f4e8..80f1ecc37cc5fe 100644 --- a/pkgs/servers/monitoring/prometheus/rtl_433-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/rtl_433-exporter.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, bash, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + bash, + nixosTests, +}: buildGoModule rec { pname = "rtl_433-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/sachet.nix b/pkgs/servers/monitoring/prometheus/sachet.nix index 3b1bc1a5f83a31..8011b96e23a2e6 100644 --- a/pkgs/servers/monitoring/prometheus/sachet.nix +++ b/pkgs/servers/monitoring/prometheus/sachet.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/servers/monitoring/prometheus/script-exporter.nix b/pkgs/servers/monitoring/prometheus/script-exporter.nix index dae56703ebd61f..a3e1d76a3ec537 100644 --- a/pkgs/servers/monitoring/prometheus/script-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/script-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "script_exporter"; diff --git a/pkgs/servers/monitoring/prometheus/shelly-exporter.nix b/pkgs/servers/monitoring/prometheus/shelly-exporter.nix index 8dde552e665e99..e5917819b6311c 100644 --- a/pkgs/servers/monitoring/prometheus/shelly-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/shelly-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "shelly_exporter"; @@ -20,6 +25,6 @@ buildGoModule rec { mainProgram = "shelly_exporter"; homepage = "https://github.com/aexel90/shelly_exporter"; license = licenses.asl20; - maintainers = with maintainers; [drupol]; + maintainers = with maintainers; [ drupol ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/smokeping-prober.nix b/pkgs/servers/monitoring/prometheus/smokeping-prober.nix index 5b1bf36f68e7f0..62bcb6e7a3d5dd 100644 --- a/pkgs/servers/monitoring/prometheus/smokeping-prober.nix +++ b/pkgs/servers/monitoring/prometheus/smokeping-prober.nix @@ -1,20 +1,31 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "smokeping_prober"; version = "0.8.1"; - ldflags = let - setVars = rec { - Version = version; - Revision = "722200c4adbd6d1e5d847dfbbd9dec07aa4ca38d"; - Branch = Revision; - BuildUser = "nix"; - }; - varFlags = lib.concatStringsSep " " (lib.mapAttrsToList (name: value: "-X github.com/prometheus/common/version.${name}=${value}") setVars); - in [ - "${varFlags}" "-s" "-w" - ]; + ldflags = + let + setVars = rec { + Version = version; + Revision = "722200c4adbd6d1e5d847dfbbd9dec07aa4ca38d"; + Branch = Revision; + BuildUser = "nix"; + }; + varFlags = lib.concatStringsSep " " ( + lib.mapAttrsToList (name: value: "-X github.com/prometheus/common/version.${name}=${value}") setVars + ); + in + [ + "${varFlags}" + "-s" + "-w" + ]; src = fetchFromGitHub { owner = "SuperQ"; diff --git a/pkgs/servers/monitoring/prometheus/snmp-exporter.nix b/pkgs/servers/monitoring/prometheus/snmp-exporter.nix index 2f8c4f7ba37117..b4f395c18361a0 100644 --- a/pkgs/servers/monitoring/prometheus/snmp-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/snmp-exporter.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, net-snmp, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + net-snmp, + nixosTests, +}: buildGoModule rec { pname = "snmp_exporter"; @@ -23,6 +29,9 @@ buildGoModule rec { description = "SNMP Exporter for Prometheus"; homepage = "https://github.com/prometheus/snmp_exporter"; license = licenses.asl20; - maintainers = with maintainers; [ oida Frostman ]; + maintainers = with maintainers; [ + oida + Frostman + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/sql-exporter.nix b/pkgs/servers/monitoring/prometheus/sql-exporter.nix index ed3602aa6d5930..6826e16145c46c 100644 --- a/pkgs/servers/monitoring/prometheus/sql-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/sql-exporter.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, go, prometheus-sql-exporter, testers }: +{ + lib, + buildGoModule, + fetchFromGitHub, + go, + prometheus-sql-exporter, + testers, +}: buildGoModule rec { pname = "sql_exporter"; @@ -13,7 +20,10 @@ buildGoModule rec { vendorHash = null; - ldflags = let t = "github.com/prometheus/common/version"; in + ldflags = + let + t = "github.com/prometheus/common/version"; + in [ "-X ${t}.Version=${version}" "-X ${t}.Revision=${src.rev}" diff --git a/pkgs/servers/monitoring/prometheus/statsd-exporter.nix b/pkgs/servers/monitoring/prometheus/statsd-exporter.nix index 192433906023bc..c2874b4b6a675a 100644 --- a/pkgs/servers/monitoring/prometheus/statsd-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/statsd-exporter.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { @@ -18,7 +19,9 @@ buildGoModule rec { let t = "github.com/prometheus/common/version"; in - [ "-s" "-w" + [ + "-s" + "-w" "-X ${t}.Version=${version}" "-X ${t}.Revision=unknown" "-X ${t}.Branch=unknown" @@ -34,6 +37,9 @@ buildGoModule rec { homepage = "https://github.com/prometheus/statsd_exporter"; changelog = "https://github.com/prometheus/statsd_exporter/blob/v${version}/CHANGELOG.md"; license = licenses.asl20; - maintainers = with maintainers; [ benley ivan ]; + maintainers = with maintainers; [ + benley + ivan + ]; }; } diff --git a/pkgs/servers/monitoring/prometheus/systemd-exporter.nix b/pkgs/servers/monitoring/prometheus/systemd-exporter.nix index 5448aeb52d59af..eb8305e13c99e8 100644 --- a/pkgs/servers/monitoring/prometheus/systemd-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/systemd-exporter.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "systemd_exporter"; diff --git a/pkgs/servers/monitoring/prometheus/unbound-exporter.nix b/pkgs/servers/monitoring/prometheus/unbound-exporter.nix index 649009184498fc..d6281a0264a9e3 100644 --- a/pkgs/servers/monitoring/prometheus/unbound-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/unbound-exporter.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, }: let diff --git a/pkgs/servers/monitoring/prometheus/v2ray-exporter.nix b/pkgs/servers/monitoring/prometheus/v2ray-exporter.nix index 841837325d8412..9a3f339b5fbff8 100644 --- a/pkgs/servers/monitoring/prometheus/v2ray-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/v2ray-exporter.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "v2ray-exporter"; diff --git a/pkgs/servers/monitoring/prometheus/varnish-exporter.nix b/pkgs/servers/monitoring/prometheus/varnish-exporter.nix index ff3a301d3340f1..772069ddeb06d8 100644 --- a/pkgs/servers/monitoring/prometheus/varnish-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/varnish-exporter.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, makeWrapper, varnish, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + varnish, + nixosTests, +}: buildGoModule rec { pname = "prometheus_varnish_exporter"; diff --git a/pkgs/servers/monitoring/prometheus/wireguard-exporter.nix b/pkgs/servers/monitoring/prometheus/wireguard-exporter.nix index 51a13f1efcd032..388441b1c640b7 100644 --- a/pkgs/servers/monitoring/prometheus/wireguard-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/wireguard-exporter.nix @@ -1,4 +1,12 @@ -{ stdenv, rustPlatform, fetchFromGitHub, lib, libiconv, Security, nixosTests }: +{ + stdenv, + rustPlatform, + fetchFromGitHub, + lib, + libiconv, + Security, + nixosTests, +}: rustPlatform.buildRustPackage rec { pname = "wireguard-exporter"; @@ -18,7 +26,10 @@ rustPlatform.buildRustPackage rec { rm .cargo/config.toml ''; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv Security ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Security + ]; passthru.tests = { inherit (nixosTests.prometheus-exporters) wireguard; }; @@ -26,7 +37,10 @@ rustPlatform.buildRustPackage rec { description = "Prometheus exporter for WireGuard, written in Rust"; homepage = "https://github.com/MindFlavor/prometheus_wireguard_exporter"; license = licenses.mit; - maintainers = with maintainers; [ ma27 globin ]; + maintainers = with maintainers; [ + ma27 + globin + ]; mainProgram = "prometheus_wireguard_exporter"; }; } diff --git a/pkgs/servers/monitoring/prometheus/xmpp-alerts.nix b/pkgs/servers/monitoring/prometheus/xmpp-alerts.nix index d710eea6c0813a..3e397eb0cfc8a7 100644 --- a/pkgs/servers/monitoring/prometheus/xmpp-alerts.nix +++ b/pkgs/servers/monitoring/prometheus/xmpp-alerts.nix @@ -1,9 +1,10 @@ -{ lib -, fetchFromGitHub -, python3Packages -, prometheus-alertmanager -, runCommand -, prometheus-xmpp-alerts +{ + lib, + fetchFromGitHub, + python3Packages, + prometheus-alertmanager, + runCommand, + prometheus-xmpp-alerts, }: python3Packages.buildPythonApplication rec { @@ -23,17 +24,19 @@ python3Packages.buildPythonApplication rec { --replace "bs4" "beautifulsoup4" ''; - propagatedBuildInputs = [ - prometheus-alertmanager - ] ++ (with python3Packages; [ - aiohttp - aiohttp-openmetrics - beautifulsoup4 - jinja2 - slixmpp - prometheus-client - pyyaml - ]); + propagatedBuildInputs = + [ + prometheus-alertmanager + ] + ++ (with python3Packages; [ + aiohttp + aiohttp-openmetrics + beautifulsoup4 + jinja2 + slixmpp + prometheus-client + pyyaml + ]); nativeCheckInputs = with python3Packages; [ setuptools @@ -44,7 +47,7 @@ python3Packages.buildPythonApplication rec { pythonImportsCheck = [ "prometheus_xmpp" ]; passthru.tests = { - binaryWorks = runCommand "${pname}-binary-test" {} '' + binaryWorks = runCommand "${pname}-binary-test" { } '' # Running with --help to avoid it erroring due to a missing config file ${prometheus-xmpp-alerts}/bin/prometheus-xmpp-alerts --help | tee $out grep "usage: prometheus-xmpp-alerts" $out diff --git a/pkgs/servers/monitoring/prometheus/zfs-exporter.nix b/pkgs/servers/monitoring/prometheus/zfs-exporter.nix index 3ba1402dc7a999..0091485c92464a 100644 --- a/pkgs/servers/monitoring/prometheus/zfs-exporter.nix +++ b/pkgs/servers/monitoring/prometheus/zfs-exporter.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, lib -, fetchFromGitHub +{ + buildGoModule, + lib, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/servers/monitoring/riemann-dash/default.nix b/pkgs/servers/monitoring/riemann-dash/default.nix index 7af5c520ab1976..5c3133df603654 100644 --- a/pkgs/servers/monitoring/riemann-dash/default.nix +++ b/pkgs/servers/monitoring/riemann-dash/default.nix @@ -1,4 +1,8 @@ -{ bundlerApp, lib, bundlerUpdateScript }: +{ + bundlerApp, + lib, + bundlerUpdateScript, +}: bundlerApp { pname = "riemann-dash"; @@ -11,7 +15,10 @@ bundlerApp { description = "Javascript, websockets-powered dashboard for Riemann"; homepage = "https://github.com/riemann/riemann-dash"; license = licenses.mit; - maintainers = with maintainers; [ manveru nicknovitski ]; + maintainers = with maintainers; [ + manveru + nicknovitski + ]; platforms = platforms.unix; }; } diff --git a/pkgs/servers/monitoring/riemann-dash/gemset.nix b/pkgs/servers/monitoring/riemann-dash/gemset.nix index 742dbde6b17a67..9a5bb65ef394f7 100644 --- a/pkgs/servers/monitoring/riemann-dash/gemset.nix +++ b/pkgs/servers/monitoring/riemann-dash/gemset.nix @@ -1,135 +1,148 @@ { erubis = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fj827xqjs91yqsydf0zmfyw9p4l2jz5yikg3mppz6d7fi8kyrb3"; type = "gem"; }; version = "2.7.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j8pzj8raxbir5w5k6s7a042sb5k02pg0f8s4na1r5lan901j00p"; type = "gem"; }; version = "1.10.0"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0q2zjfvd2ibds9g9nzf2p1b47fc1wqliwfywv5pw85w15lmy91yr"; type = "gem"; }; version = "1.3.6"; }; rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g9926ln2lw12lfxm4ylq1h6nl0rafl10za3xvjzc87qvnqic87f"; type = "gem"; }; version = "1.6.11"; }; rack-protection = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0my0wlw4a5l3hs79jkx2xzv7djhajgf8d28k8ai1ddlnxxb0v7ss"; type = "gem"; }; version = "1.5.5"; }; rb-fsevent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1lm1k7wpz69jx7jrc92w3ggczkjyjbfziq5mg62vjnxmzs383xx8"; type = "gem"; }; version = "0.10.3"; }; rb-inotify = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fs7hxm9g6ywv2yih83b879klhc4fs8i0p9166z795qmd77dk0a4"; type = "gem"; }; version = "0.10.0"; }; riemann-dash = { - dependencies = ["erubis" "multi_json" "sass" "sinatra" "webrick"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "erubis" + "multi_json" + "sass" + "sinatra" + "webrick" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h366knb1vx5l4a46ppfr2sb467bb4m448fh8q2al0ixw7wqncvr"; type = "gem"; }; version = "0.2.14"; }; sass = { - dependencies = ["sass-listen"]; - groups = ["default"]; - platforms = []; + dependencies = [ "sass-listen" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p95lhs0jza5l7hqci1isflxakz83xkj97lkvxl919is0lwhv2w0"; type = "gem"; }; version = "3.7.4"; }; sass-listen = { - dependencies = ["rb-fsevent" "rb-inotify"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "rb-fsevent" + "rb-inotify" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xw3q46cmahkgyldid5hwyiwacp590zj2vmswlll68ryvmvcp7df"; type = "gem"; }; version = "4.0.0"; }; sinatra = { - dependencies = ["rack" "rack-protection" "tilt"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "rack" + "rack-protection" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0byxzl7rx3ki0xd7aiv1x8mbah7hzd8f81l65nq8857kmgzj1jqq"; type = "gem"; }; version = "1.4.8"; }; tilt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ca4k0clwf0rkvy7726x4nxpjxkpv67w043i39saxgldxd97zmwz"; type = "gem"; }; version = "2.0.9"; }; webrick = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0s42mxihcl2bx0h9q0v2syl70qndydfkl39a06h9il17p895ya8g"; type = "gem"; }; diff --git a/pkgs/servers/monitoring/sensu-go/default.nix b/pkgs/servers/monitoring/sensu-go/default.nix index 97c2dcde13f646..2ddfdb4f4de61f 100644 --- a/pkgs/servers/monitoring/sensu-go/default.nix +++ b/pkgs/servers/monitoring/sensu-go/default.nix @@ -1,7 +1,17 @@ -{ buildGo122Module, fetchFromGitHub, lib }: +{ + buildGo122Module, + fetchFromGitHub, + lib, +}: let - generic = { subPackages, pname, postInstall ? "", mainProgram }: + generic = + { + subPackages, + pname, + postInstall ? "", + mainProgram, + }: buildGo122Module rec { inherit pname; version = "6.11.0"; @@ -27,19 +37,24 @@ let doCheck = false; - ldflags = let - versionPkg = "github.com/sensu/sensu-go/version"; - in [ - "-X ${versionPkg}.Version=${version}" - "-X ${versionPkg}.BuildSHA=${shortRev}" - ]; + ldflags = + let + versionPkg = "github.com/sensu/sensu-go/version"; + in + [ + "-X ${versionPkg}.Version=${version}" + "-X ${versionPkg}.BuildSHA=${shortRev}" + ]; meta = { inherit mainProgram; homepage = "https://sensu.io"; description = "Open source monitoring tool for ephemeral infrastructure & distributed applications"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ thefloweringash teutat3s ]; + maintainers = with lib.maintainers; [ + thefloweringash + teutat3s + ]; }; }; in diff --git a/pkgs/servers/mpd/default.nix b/pkgs/servers/mpd/default.nix index a8decc0a33bacf..84c8d7ce74bb9f 100644 --- a/pkgs/servers/mpd/default.nix +++ b/pkgs/servers/mpd/default.nix @@ -1,159 +1,248 @@ -{ lib, stdenv, fetchFromGitHub, meson, ninja, pkg-config, glib, systemd, boost, fmt, buildPackages -# Darwin inputs -, AudioToolbox, AudioUnit -# Inputs -, curl, libcdio, libcdio-paranoia, libmms, libnfs, liburing, samba -# Archive support -, bzip2, zziplib -# Codecs -, audiofile, faad2, ffmpeg, flac, fluidsynth, game-music-emu -, libmad, libmikmod, mpg123, libopus, libvorbis, lame -# Filters -, libsamplerate, soxr -# Outputs -, alsa-lib, libjack2, libpulseaudio, libshout, pipewire -# Misc -, icu, sqlite, avahi, dbus, pcre2, libgcrypt, expat -# Services -, yajl -# Client support -, libmpdclient -# Tag support -, libid3tag -, nixosTests -# For documentation -, doxygen -, python3Packages # for sphinx-build -# For tests -, gtest -, zip +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + glib, + systemd, + boost, + fmt, + buildPackages, + # Darwin inputs + AudioToolbox, + AudioUnit, + # Inputs + curl, + libcdio, + libcdio-paranoia, + libmms, + libnfs, + liburing, + samba, + # Archive support + bzip2, + zziplib, + # Codecs + audiofile, + faad2, + ffmpeg, + flac, + fluidsynth, + game-music-emu, + libmad, + libmikmod, + mpg123, + libopus, + libvorbis, + lame, + # Filters + libsamplerate, + soxr, + # Outputs + alsa-lib, + libjack2, + libpulseaudio, + libshout, + pipewire, + # Misc + icu, + sqlite, + avahi, + dbus, + pcre2, + libgcrypt, + expat, + # Services + yajl, + # Client support + libmpdclient, + # Tag support + libid3tag, + nixosTests, + # For documentation + doxygen, + python3Packages, # for sphinx-build + # For tests + gtest, + zip, }: let - concatAttrVals = nameList: set: lib.concatMap (x: set.${x} or []) nameList; + concatAttrVals = nameList: set: lib.concatMap (x: set.${x} or [ ]) nameList; featureDependencies = { # Storage plugins - udisks = [ dbus ]; - webdav = [ curl expat ]; + udisks = [ dbus ]; + webdav = [ + curl + expat + ]; # Input plugins - cdio_paranoia = [ libcdio libcdio-paranoia ]; - curl = [ curl ]; - io_uring = [ liburing ]; - mms = [ libmms ]; - nfs = [ libnfs ]; - smbclient = [ samba ]; + cdio_paranoia = [ + libcdio + libcdio-paranoia + ]; + curl = [ curl ]; + io_uring = [ liburing ]; + mms = [ libmms ]; + nfs = [ libnfs ]; + smbclient = [ samba ]; # Archive support - bzip2 = [ bzip2 ]; - zzip = [ zziplib ]; + bzip2 = [ bzip2 ]; + zzip = [ zziplib ]; # Decoder plugins - audiofile = [ audiofile ]; - faad = [ faad2 ]; - ffmpeg = [ ffmpeg ]; - flac = [ flac ]; - fluidsynth = [ fluidsynth ]; - gme = [ game-music-emu ]; - mad = [ libmad ]; - mikmod = [ libmikmod ]; - mpg123 = [ mpg123 ]; - opus = [ libopus ]; - vorbis = [ libvorbis ]; + audiofile = [ audiofile ]; + faad = [ faad2 ]; + ffmpeg = [ ffmpeg ]; + flac = [ flac ]; + fluidsynth = [ fluidsynth ]; + gme = [ game-music-emu ]; + mad = [ libmad ]; + mikmod = [ libmikmod ]; + mpg123 = [ mpg123 ]; + opus = [ libopus ]; + vorbis = [ libvorbis ]; # Encoder plugins - vorbisenc = [ libvorbis ]; - lame = [ lame ]; + vorbisenc = [ libvorbis ]; + lame = [ lame ]; # Filter plugins libsamplerate = [ libsamplerate ]; - soxr = [ soxr ]; + soxr = [ soxr ]; # Output plugins - alsa = [ alsa-lib ]; - jack = [ libjack2 ]; - pipewire = [ pipewire ]; - pulse = [ libpulseaudio ]; - shout = [ libshout ]; + alsa = [ alsa-lib ]; + jack = [ libjack2 ]; + pipewire = [ pipewire ]; + pulse = [ libpulseaudio ]; + shout = [ libshout ]; # Commercial services - qobuz = [ curl libgcrypt yajl ]; - soundcloud = [ curl yajl ]; + qobuz = [ + curl + libgcrypt + yajl + ]; + soundcloud = [ + curl + yajl + ]; # Client support - libmpdclient = [ libmpdclient ]; + libmpdclient = [ libmpdclient ]; # Tag support - id3tag = [ libid3tag ]; + id3tag = [ libid3tag ]; # Misc - dbus = [ dbus ]; - expat = [ expat ]; - icu = [ icu ]; - pcre = [ pcre2 ]; - sqlite = [ sqlite ]; - syslog = [ ]; - systemd = [ systemd ]; - yajl = [ yajl ]; - zeroconf = [ avahi dbus ]; + dbus = [ dbus ]; + expat = [ expat ]; + icu = [ icu ]; + pcre = [ pcre2 ]; + sqlite = [ sqlite ]; + syslog = [ ]; + systemd = [ systemd ]; + yajl = [ yajl ]; + zeroconf = [ + avahi + dbus + ]; }; nativeFeatureDependencies = { - documentation = [ doxygen python3Packages.sphinx ]; + documentation = [ + doxygen + python3Packages.sphinx + ]; }; - run = { features ? null }: + run = + { + features ? null, + }: let # Disable platform specific features if needed # using libmad to decode mp3 files on darwin is causing a segfault -- there # is probably a solution, but I'm disabling it for now - platformMask = lib.optionals stdenv.hostPlatform.isDarwin [ "mad" "pulse" "jack" "smbclient" ] - ++ lib.optionals (!stdenv.hostPlatform.isLinux) [ "alsa" "pipewire" "io_uring" "systemd" "syslog" ]; + platformMask = + lib.optionals stdenv.hostPlatform.isDarwin [ + "mad" + "pulse" + "jack" + "smbclient" + ] + ++ lib.optionals (!stdenv.hostPlatform.isLinux) [ + "alsa" + "pipewire" + "io_uring" + "systemd" + "syslog" + ]; - knownFeatures = builtins.attrNames featureDependencies ++ builtins.attrNames nativeFeatureDependencies; + knownFeatures = + builtins.attrNames featureDependencies + ++ builtins.attrNames nativeFeatureDependencies; platformFeatures = lib.subtractLists platformMask knownFeatures; - features_ = if (features == null ) - then platformFeatures + features_ = + if (features == null) then + platformFeatures else - let unknown = lib.subtractLists knownFeatures features; in - if (unknown != []) - then throw "Unknown feature(s): ${lib.concatStringsSep " " unknown}" + let + unknown = lib.subtractLists knownFeatures features; + in + if (unknown != [ ]) then + throw "Unknown feature(s): ${lib.concatStringsSep " " unknown}" + else + let + unsupported = lib.subtractLists platformFeatures features; + in + if (unsupported != [ ]) then + throw "Feature(s) ${lib.concatStringsSep " " unsupported} are not supported on ${stdenv.hostPlatform.system}" else - let unsupported = lib.subtractLists platformFeatures features; in - if (unsupported != []) - then throw "Feature(s) ${lib.concatStringsSep " " unsupported} are not supported on ${stdenv.hostPlatform.system}" - else features; + features; - in stdenv.mkDerivation rec { + in + stdenv.mkDerivation rec { pname = "mpd"; version = "0.23.16"; src = fetchFromGitHub { - owner = "MusicPlayerDaemon"; - repo = "MPD"; - rev = "v${version}"; + owner = "MusicPlayerDaemon"; + repo = "MPD"; + rev = "v${version}"; sha256 = "sha256-0To+V+4xLjymGpRSpsyE/Une5uUpCEiAg+d041guPA0="; }; - buildInputs = [ - glib - boost - fmt - # According to the configurePhase of meson, gtest is considered a - # runtime dependency. Quoting: - # - # Run-time dependency GTest found: YES 1.10.0 - gtest - ] + buildInputs = + [ + glib + boost + fmt + # According to the configurePhase of meson, gtest is considered a + # runtime dependency. Quoting: + # + # Run-time dependency GTest found: YES 1.10.0 + gtest + ] ++ concatAttrVals features_ featureDependencies - ++ lib.optionals stdenv.hostPlatform.isDarwin [ AudioToolbox AudioUnit ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AudioToolbox + AudioUnit + ]; nativeBuildInputs = [ meson ninja pkg-config - ] - ++ concatAttrVals features_ nativeFeatureDependencies; + ] ++ concatAttrVals features_ nativeFeatureDependencies; depsBuildBuild = [ buildPackages.stdenv.cc ]; - postPatch = lib.optionalString (stdenv.hostPlatform.isDarwin && lib.versionOlder stdenv.hostPlatform.darwinSdkVersion "12.0") '' - substituteInPlace src/output/plugins/OSXOutputPlugin.cxx \ - --replace kAudioObjectPropertyElement{Main,Master} \ - --replace kAudioHardwareServiceDeviceProperty_Virtual{Main,Master}Volume - ''; + postPatch = + lib.optionalString + (stdenv.hostPlatform.isDarwin && lib.versionOlder stdenv.hostPlatform.darwinSdkVersion "12.0") + '' + substituteInPlace src/output/plugins/OSXOutputPlugin.cxx \ + --replace kAudioObjectPropertyElement{Main,Master} \ + --replace kAudioHardwareServiceDeviceProperty_Virtual{Main,Master}Volume + ''; # Otherwise, the meson log says: # @@ -164,33 +253,37 @@ let mesonAutoFeatures = "disabled"; - outputs = [ "out" "doc" ] - ++ lib.optional (builtins.elem "documentation" features_) "man"; + outputs = [ + "out" + "doc" + ] ++ lib.optional (builtins.elem "documentation" features_) "man"; CXXFLAGS = lib.optionals stdenv.hostPlatform.isDarwin [ "-D__ASSERT_MACROS_DEFINE_VERSIONS_WITHOUT_UNDERSCORES=0" ]; - mesonFlags = [ - "-Dtest=true" - "-Dmanpages=true" - "-Dhtml_manual=true" - ] + mesonFlags = + [ + "-Dtest=true" + "-Dmanpages=true" + "-Dhtml_manual=true" + ] ++ map (x: "-D${x}=enabled") features_ ++ map (x: "-D${x}=disabled") (lib.subtractLists features_ knownFeatures) - ++ lib.optional (builtins.elem "zeroconf" features_) - "-Dzeroconf=avahi" - ++ lib.optional (builtins.elem "systemd" features_) - "-Dsystemd_system_unit_dir=etc/systemd/system"; + ++ lib.optional (builtins.elem "zeroconf" features_) "-Dzeroconf=avahi" + ++ lib.optional (builtins.elem "systemd" features_) "-Dsystemd_system_unit_dir=etc/systemd/system"; passthru.tests.nixos = nixosTests.mpd; meta = with lib; { description = "Flexible, powerful daemon for playing music"; - homepage = "https://www.musicpd.org/"; - license = licenses.gpl2Only; - maintainers = with maintainers; [ astsmtl tobim ]; - platforms = platforms.unix; + homepage = "https://www.musicpd.org/"; + license = licenses.gpl2Only; + maintainers = with maintainers; [ + astsmtl + tobim + ]; + platforms = platforms.unix; mainProgram = "mpd"; longDescription = '' @@ -203,18 +296,45 @@ let in { mpd = run { }; - mpd-small = run { features = [ - "webdav" "curl" "mms" "bzip2" "zzip" "nfs" - "audiofile" "faad" "flac" "gme" - "mpg123" "opus" "vorbis" "vorbisenc" - "lame" "libsamplerate" "shout" - "libmpdclient" "id3tag" "expat" "pcre" - "yajl" "sqlite" - "soundcloud" "qobuz" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "alsa" "systemd" "syslog" "io_uring" - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - "mad" "jack" - ]; }; + mpd-small = run { + features = + [ + "webdav" + "curl" + "mms" + "bzip2" + "zzip" + "nfs" + "audiofile" + "faad" + "flac" + "gme" + "mpg123" + "opus" + "vorbis" + "vorbisenc" + "lame" + "libsamplerate" + "shout" + "libmpdclient" + "id3tag" + "expat" + "pcre" + "yajl" + "sqlite" + "soundcloud" + "qobuz" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "alsa" + "systemd" + "syslog" + "io_uring" + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + "mad" + "jack" + ]; + }; mpdWithFeatures = run; } diff --git a/pkgs/servers/mtprotoproxy/default.nix b/pkgs/servers/mtprotoproxy/default.nix index 44ecc6481ecd8e..4c0ed8d0abda5a 100644 --- a/pkgs/servers/mtprotoproxy/default.nix +++ b/pkgs/servers/mtprotoproxy/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, python, pyaes, pycrypto, uvloop, wrapPython }: +{ + lib, + stdenv, + fetchFromGitHub, + python, + pyaes, + pycrypto, + uvloop, + wrapPython, +}: stdenv.mkDerivation rec { pname = "mtprotoproxy"; @@ -12,7 +21,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ wrapPython ]; - pythonPath = [ pyaes pycrypto uvloop ]; + pythonPath = [ + pyaes + pycrypto + uvloop + ]; installPhase = '' install -Dm755 mtprotoproxy.py $out/bin/mtprotoproxy @@ -21,9 +34,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Async MTProto proxy for Telegram"; - license = licenses.mit; - homepage = "https://github.com/alexbers/mtprotoproxy"; - platforms = python.meta.platforms; + license = licenses.mit; + homepage = "https://github.com/alexbers/mtprotoproxy"; + platforms = python.meta.platforms; maintainers = with maintainers; [ abbradar ]; mainProgram = "mtprotoproxy"; }; diff --git a/pkgs/servers/mx-puppet-discord/node-composition.nix b/pkgs/servers/mx-puppet-discord/node-composition.nix index f47a724999ed71..12460bea17a169 100644 --- a/pkgs/servers/mx-puppet-discord/node-composition.nix +++ b/pkgs/servers/mx-puppet-discord/node-composition.nix @@ -1,17 +1,34 @@ # This file has been generated by node2nix 1.11.1. Do not edit! -{pkgs ? import ../../.. { +{ + pkgs ? import ../../.. { inherit system; - }, system ? builtins.currentSystem, nodejs ? pkgs."nodejs_18"}: + }, + system ? builtins.currentSystem, + nodejs ? pkgs."nodejs_18", +}: let nodeEnv = import ../../development/node-packages/node-env.nix { - inherit (pkgs) stdenv lib python2 runCommand writeTextFile writeShellScript; + inherit (pkgs) + stdenv + lib + python2 + runCommand + writeTextFile + writeShellScript + ; inherit pkgs nodejs; libtool = if pkgs.stdenv.hostPlatform.isDarwin then pkgs.cctools or pkgs.darwin.cctools else null; }; in import ./node-packages.nix { - inherit (pkgs) fetchurl nix-gitignore stdenv lib fetchgit; + inherit (pkgs) + fetchurl + nix-gitignore + stdenv + lib + fetchgit + ; inherit nodeEnv; } diff --git a/pkgs/servers/mx-puppet-discord/node-packages.nix b/pkgs/servers/mx-puppet-discord/node-packages.nix index 9cf1324ae6fa99..ac126426d54f94 100644 --- a/pkgs/servers/mx-puppet-discord/node-packages.nix +++ b/pkgs/servers/mx-puppet-discord/node-packages.nix @@ -1,6 +1,14 @@ # This file has been generated by node2nix 1.11.1. Do not edit! -{nodeEnv, fetchurl, fetchgit, nix-gitignore, stdenv, lib, globalBuildInputs ? []}: +{ + nodeEnv, + fetchurl, + fetchgit, + nix-gitignore, + stdenv, + lib, + globalBuildInputs ? [ ], +}: let sources = { @@ -3262,15 +3270,18 @@ let dependencies = [ sources."@babel/code-frame-7.18.6" sources."@babel/helper-validator-identifier-7.19.1" - (sources."@babel/highlight-7.18.6" // { - dependencies = [ - sources."ansi-styles-3.2.1" - sources."chalk-2.4.2" - sources."escape-string-regexp-1.0.5" - sources."has-flag-3.0.0" - sources."supports-color-5.5.0" - ]; - }) + ( + sources."@babel/highlight-7.18.6" + // { + dependencies = [ + sources."ansi-styles-3.2.1" + sources."chalk-2.4.2" + sources."escape-string-regexp-1.0.5" + sources."has-flag-3.0.0" + sources."supports-color-5.5.0" + ]; + } + ) sources."@colors/colors-1.5.0" sources."@dabh/diagnostics-2.0.3" sources."@discordjs/collection-0.1.6" @@ -3306,12 +3317,15 @@ let sources."accepts-1.3.8" sources."agent-base-6.0.2" sources."ansi-regex-5.0.1" - (sources."ansi-styles-4.3.0" // { - dependencies = [ - sources."color-convert-2.0.1" - sources."color-name-1.1.4" - ]; - }) + ( + sources."ansi-styles-4.3.0" + // { + dependencies = [ + sources."color-convert-2.0.1" + sources."color-name-1.1.4" + ]; + } + ) sources."aproba-2.0.0" sources."are-we-there-yet-2.0.0" sources."argparse-1.0.10" @@ -3322,22 +3336,28 @@ let sources."asynckit-0.4.0" sources."balanced-match-1.0.2" sources."base64-js-1.5.1" - (sources."basic-auth-2.0.1" // { - dependencies = [ - sources."safe-buffer-5.1.2" - ]; - }) + ( + sources."basic-auth-2.0.1" + // { + dependencies = [ + sources."safe-buffer-5.1.2" + ]; + } + ) sources."better-sqlite3-7.6.2" sources."bindings-1.5.0" sources."bintrees-1.0.2" sources."bl-4.1.0" sources."blurhash-1.1.5" - (sources."body-parser-1.20.0" // { - dependencies = [ - sources."debug-2.6.9" - sources."ms-2.0.0" - ]; - }) + ( + sources."body-parser-1.20.0" + // { + dependencies = [ + sources."debug-2.6.9" + sources."ms-2.0.0" + ]; + } + ) sources."brace-expansion-1.1.11" sources."buffer-5.7.1" sources."buffer-writer-2.0.0" @@ -3349,11 +3369,14 @@ let sources."canvas-2.10.1" sources."chalk-4.1.2" sources."chownr-2.0.0" - (sources."clone-response-1.0.3" // { - dependencies = [ - sources."mimic-response-1.0.1" - ]; - }) + ( + sources."clone-response-1.0.3" + // { + dependencies = [ + sources."mimic-response-1.0.1" + ]; + } + ) sources."color-3.2.1" sources."color-convert-1.9.3" sources."color-name-1.1.3" @@ -3363,17 +3386,20 @@ let sources."colorspace-1.1.4" sources."combined-stream-1.0.8" sources."command-line-args-5.2.1" - (sources."command-line-usage-5.0.5" // { - dependencies = [ - sources."ansi-styles-3.2.1" - sources."array-back-2.0.0" - sources."chalk-2.4.2" - sources."escape-string-regexp-1.0.5" - sources."has-flag-3.0.0" - sources."supports-color-5.5.0" - sources."typical-2.6.1" - ]; - }) + ( + sources."command-line-usage-5.0.5" + // { + dependencies = [ + sources."ansi-styles-3.2.1" + sources."array-back-2.0.0" + sources."chalk-2.4.2" + sources."escape-string-regexp-1.0.5" + sources."has-flag-3.0.0" + sources."supports-color-5.5.0" + sources."typical-2.6.1" + ]; + } + ) sources."commander-2.20.3" sources."concat-map-0.0.1" sources."console-control-strings-1.1.0" @@ -3394,19 +3420,25 @@ let sources."destroy-1.2.0" sources."detect-libc-2.0.1" sources."diff-4.0.2" - (sources."dom-serializer-1.4.1" // { - dependencies = [ - sources."domhandler-4.3.1" - sources."entities-2.2.0" - ]; - }) + ( + sources."dom-serializer-1.4.1" + // { + dependencies = [ + sources."domhandler-4.3.1" + sources."entities-2.2.0" + ]; + } + ) sources."domelementtype-2.3.0" sources."domhandler-3.3.0" - (sources."domutils-2.8.0" // { - dependencies = [ - sources."domhandler-4.3.1" - ]; - }) + ( + sources."domutils-2.8.0" + // { + dependencies = [ + sources."domhandler-4.3.1" + ]; + } + ) sources."ee-first-1.1.1" sources."emoji-regex-8.0.0" sources."enabled-2.0.0" @@ -3421,24 +3453,30 @@ let sources."events-3.3.0" sources."expand-template-2.0.3" sources."expire-set-1.0.0" - (sources."express-4.18.1" // { - dependencies = [ - sources."debug-2.6.9" - sources."ms-2.0.0" - ]; - }) + ( + sources."express-4.18.1" + // { + dependencies = [ + sources."debug-2.6.9" + sources."ms-2.0.0" + ]; + } + ) sources."extend-shallow-2.0.1" sources."fast-safe-stringify-2.1.1" sources."fecha-4.2.3" sources."file-stream-rotator-0.4.1" sources."file-type-12.4.2" sources."file-uri-to-path-1.0.0" - (sources."finalhandler-1.2.0" // { - dependencies = [ - sources."debug-2.6.9" - sources."ms-2.0.0" - ]; - }) + ( + sources."finalhandler-1.2.0" + // { + dependencies = [ + sources."debug-2.6.9" + sources."ms-2.0.0" + ]; + } + ) sources."find-replace-3.0.0" sources."fn.name-1.1.0" sources."forwarded-0.2.0" @@ -3453,12 +3491,15 @@ let sources."github-from-package-0.0.0" sources."glob-7.2.3" sources."glob-to-regexp-0.4.1" - (sources."got-11.8.5" // { - dependencies = [ - sources."decompress-response-6.0.0" - sources."mimic-response-3.1.0" - ]; - }) + ( + sources."got-11.8.5" + // { + dependencies = [ + sources."decompress-response-6.0.0" + sources."mimic-response-3.1.0" + ]; + } + ) sources."graceful-fs-4.2.10" sources."has-1.0.3" sources."has-flag-4.0.0" @@ -3470,11 +3511,14 @@ let sources."highlight.js-10.7.3" sources."html-to-text-6.0.0" sources."htmlencode-0.0.4" - (sources."htmlparser2-4.1.0" // { - dependencies = [ - sources."entities-2.2.0" - ]; - }) + ( + sources."htmlparser2-4.1.0" + // { + dependencies = [ + sources."entities-2.2.0" + ]; + } + ) sources."http-cache-semantics-4.1.0" sources."http-errors-2.0.0" sources."http2-wrapper-1.0.3" @@ -3505,11 +3549,14 @@ let sources."lowdb-1.0.0" sources."lowercase-keys-2.0.0" sources."lru-cache-6.0.0" - (sources."make-dir-3.1.0" // { - dependencies = [ - sources."semver-6.3.0" - ]; - }) + ( + sources."make-dir-3.1.0" + // { + dependencies = [ + sources."semver-6.3.0" + ]; + } + ) sources."markdown-it-9.1.0" sources."mdurl-1.0.1" sources."media-typer-0.3.0" @@ -3527,13 +3574,16 @@ let sources."mkdirp-1.0.4" sources."mkdirp-classic-0.5.3" sources."moment-2.29.4" - (sources."morgan-1.10.0" // { - dependencies = [ - sources."debug-2.6.9" - sources."ms-2.0.0" - sources."on-finished-2.3.0" - ]; - }) + ( + sources."morgan-1.10.0" + // { + dependencies = [ + sources."debug-2.6.9" + sources."ms-2.0.0" + sources."on-finished-2.3.0" + ]; + } + ) sources."ms-2.1.2" sources."nan-2.16.0" sources."nanoid-3.3.4" @@ -3579,13 +3629,16 @@ let sources."postgres-bytea-1.0.0" sources."postgres-date-1.0.7" sources."postgres-interval-1.2.0" - (sources."prebuild-install-7.1.1" // { - dependencies = [ - sources."decompress-response-6.0.0" - sources."mimic-response-3.1.0" - sources."simple-get-4.0.1" - ]; - }) + ( + sources."prebuild-install-7.1.1" + // { + dependencies = [ + sources."decompress-response-6.0.0" + sources."mimic-response-3.1.0" + sources."simple-get-4.0.1" + ]; + } + ) sources."prism-media-1.3.4" sources."process-0.11.10" sources."prom-client-13.2.0" @@ -3605,30 +3658,42 @@ let sources."safe-buffer-5.2.1" sources."safe-stable-stringify-2.4.0" sources."safer-buffer-2.1.2" - (sources."sanitize-html-2.7.2" // { - dependencies = [ - sources."domhandler-4.3.1" - sources."entities-2.2.0" - sources."htmlparser2-6.1.0" - ]; - }) + ( + sources."sanitize-html-2.7.2" + // { + dependencies = [ + sources."domhandler-4.3.1" + sources."entities-2.2.0" + sources."htmlparser2-6.1.0" + ]; + } + ) sources."semver-7.3.7" - (sources."semver-closest-0.1.2" // { - dependencies = [ - sources."semver-5.7.1" - ]; - }) - (sources."send-0.18.0" // { - dependencies = [ - (sources."debug-2.6.9" // { - dependencies = [ - sources."ms-2.0.0" - ]; - }) - sources."mime-1.6.0" - sources."ms-2.1.3" - ]; - }) + ( + sources."semver-closest-0.1.2" + // { + dependencies = [ + sources."semver-5.7.1" + ]; + } + ) + ( + sources."send-0.18.0" + // { + dependencies = [ + ( + sources."debug-2.6.9" + // { + dependencies = [ + sources."ms-2.0.0" + ]; + } + ) + sources."mime-1.6.0" + sources."ms-2.1.3" + ]; + } + ) sources."serve-static-1.15.0" sources."set-blocking-2.0.0" sources."setimmediate-1.0.5" @@ -3652,18 +3717,24 @@ let sources."strip-json-comments-2.0.1" sources."supports-color-7.2.0" sources."supports-preserve-symlinks-flag-1.0.0" - (sources."table-layout-0.4.5" // { - dependencies = [ - sources."array-back-2.0.0" - sources."typical-2.6.1" - ]; - }) + ( + sources."table-layout-0.4.5" + // { + dependencies = [ + sources."array-back-2.0.0" + sources."typical-2.6.1" + ]; + } + ) sources."tar-6.1.11" - (sources."tar-fs-2.1.1" // { - dependencies = [ - sources."chownr-1.1.4" - ]; - }) + ( + sources."tar-fs-2.1.1" + // { + dependencies = [ + sources."chownr-1.1.4" + ]; + } + ) sources."tar-stream-2.2.0" sources."tdigest-0.1.2" sources."text-hex-1.0.0" @@ -3671,17 +3742,20 @@ let sources."tr46-0.0.3" sources."triple-beam-1.3.0" sources."tslib-1.14.1" - (sources."tslint-5.20.1" // { - dependencies = [ - sources."ansi-styles-3.2.1" - sources."chalk-2.4.2" - sources."escape-string-regexp-1.0.5" - sources."has-flag-3.0.0" - sources."mkdirp-0.5.6" - sources."semver-5.7.1" - sources."supports-color-5.5.0" - ]; - }) + ( + sources."tslint-5.20.1" + // { + dependencies = [ + sources."ansi-styles-3.2.1" + sources."chalk-2.4.2" + sources."escape-string-regexp-1.0.5" + sources."has-flag-3.0.0" + sources."mkdirp-0.5.6" + sources."semver-5.7.1" + sources."supports-color-5.5.0" + ]; + } + ) sources."tsutils-2.29.0" sources."tunnel-agent-0.6.0" sources."tweetnacl-1.0.3" @@ -3693,16 +3767,22 @@ let sources."unescape-1.0.1" sources."unescape-html-1.1.0" sources."unpipe-1.0.0" - (sources."useragent-generator-1.1.1-amkt-22079-finish.1" // { - dependencies = [ - sources."semver-5.7.1" - ]; - }) - (sources."util-0.10.4" // { - dependencies = [ - sources."inherits-2.0.3" - ]; - }) + ( + sources."useragent-generator-1.1.1-amkt-22079-finish.1" + // { + dependencies = [ + sources."semver-5.7.1" + ]; + } + ) + ( + sources."util-0.10.4" + // { + dependencies = [ + sources."inherits-2.0.3" + ]; + } + ) sources."util-deprecate-1.0.2" sources."utils-merge-1.0.1" sources."uuid-3.4.0" @@ -3711,23 +3791,32 @@ let sources."whatwg-url-5.0.0" sources."wide-align-1.1.5" sources."winston-3.8.2" - (sources."winston-compat-0.1.5" // { - dependencies = [ - sources."fecha-2.3.3" - sources."logform-1.10.0" - ]; - }) - (sources."winston-daily-rotate-file-3.10.0" // { - dependencies = [ - sources."semver-6.3.0" - ]; - }) + ( + sources."winston-compat-0.1.5" + // { + dependencies = [ + sources."fecha-2.3.3" + sources."logform-1.10.0" + ]; + } + ) + ( + sources."winston-daily-rotate-file-3.10.0" + // { + dependencies = [ + sources."semver-6.3.0" + ]; + } + ) sources."winston-transport-4.5.0" - (sources."wordwrapjs-3.0.0" // { - dependencies = [ - sources."typical-2.6.1" - ]; - }) + ( + sources."wordwrapjs-3.0.0" + // { + dependencies = [ + sources."typical-2.6.1" + ]; + } + ) sources."wrappy-1.0.2" sources."ws-7.5.9" sources."xtend-4.0.2" @@ -3748,16 +3837,18 @@ in tarball = nodeEnv.buildNodeSourceDist args; package = nodeEnv.buildNodePackage args; shell = nodeEnv.buildNodeShell args; - nodeDependencies = nodeEnv.buildNodeDependencies (lib.overrideExisting args { - src = stdenv.mkDerivation { - name = args.name + "-package-json"; - src = nix-gitignore.gitignoreSourcePure [ - "*" - "!package.json" - "!package-lock.json" - ] args.src; - dontBuild = true; - installPhase = "mkdir -p $out; cp -r ./* $out;"; - }; - }); + nodeDependencies = nodeEnv.buildNodeDependencies ( + lib.overrideExisting args { + src = stdenv.mkDerivation { + name = args.name + "-package-json"; + src = nix-gitignore.gitignoreSourcePure [ + "*" + "!package.json" + "!package-lock.json" + ] args.src; + dontBuild = true; + installPhase = "mkdir -p $out; cp -r ./* $out;"; + }; + } + ); } diff --git a/pkgs/servers/news/leafnode/1.nix b/pkgs/servers/news/leafnode/1.nix index 1b744ed322b679..7218a82c2564da 100644 --- a/pkgs/servers/news/leafnode/1.nix +++ b/pkgs/servers/news/leafnode/1.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, pcre2 }: +{ + lib, + stdenv, + fetchurl, + pcre2, +}: stdenv.mkDerivation (finalAttrs: { pname = "leafnode"; diff --git a/pkgs/servers/news/leafnode/default.nix b/pkgs/servers/news/leafnode/default.nix index 01bd7b011a77ef..e7faa5be35a7e0 100644 --- a/pkgs/servers/news/leafnode/default.nix +++ b/pkgs/servers/news/leafnode/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, pcre, libxcrypt }: +{ + lib, + stdenv, + fetchurl, + pcre, + libxcrypt, +}: stdenv.mkDerivation (finalAttrs: { pname = "leafnode"; @@ -27,7 +33,10 @@ stdenv.mkDerivation (finalAttrs: { sed -i validatefqdn.c -e 's/int is_validfqdn(const char \*f) {/int is_validfqdn(const char *f) { return 1;/;' ''; - buildInputs = [ pcre libxcrypt ]; + buildInputs = [ + pcre + libxcrypt + ]; meta = { homepage = "https://leafnode.sourceforge.io/index.shtml"; diff --git a/pkgs/servers/nextcloud/news-updater.nix b/pkgs/servers/nextcloud/news-updater.nix index d72f13687124bc..f26ba5fdaff495 100644 --- a/pkgs/servers/nextcloud/news-updater.nix +++ b/pkgs/servers/nextcloud/news-updater.nix @@ -1,4 +1,9 @@ -{ lib, fetchurl, python3Packages, php }: +{ + lib, + fetchurl, + python3Packages, + php, +}: python3Packages.buildPythonApplication rec { pname = "nextcloud-news-updater"; diff --git a/pkgs/servers/nextcloud/notify_push.nix b/pkgs/servers/nextcloud/notify_push.nix index c84f17086b2c59..b6f1058af18fdd 100644 --- a/pkgs/servers/nextcloud/notify_push.nix +++ b/pkgs/servers/nextcloud/notify_push.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, nixosTests -, rustPlatform +{ + lib, + fetchFromGitHub, + nixosTests, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -31,9 +32,9 @@ rustPlatform.buildRustPackage rec { }; }; tests = - lib.filterAttrs - (key: lib.const (lib.hasPrefix "with-postgresql-and-redis" key)) - nixosTests.nextcloud + lib.filterAttrs ( + key: lib.const (lib.hasPrefix "with-postgresql-and-redis" key) + ) nixosTests.nextcloud // { inherit test_client; }; diff --git a/pkgs/servers/nextcloud/packages/nc-versions.nix b/pkgs/servers/nextcloud/packages/nc-versions.nix index 06349531f20847..25d2ae1d931d29 100644 --- a/pkgs/servers/nextcloud/packages/nc-versions.nix +++ b/pkgs/servers/nextcloud/packages/nc-versions.nix @@ -2,12 +2,18 @@ # Licensed under: MIT # this file is used to figure out which versions of nextcloud we have in nixpkgs -{ pkgs ? import ../../../.. {}, lib ? pkgs.lib }: +{ + pkgs ? import ../../../.. { }, + lib ? pkgs.lib, +}: let n = lib.mapAttrsToList (_: v: v.version) ( - lib.filterAttrs (k: v: builtins.match "nextcloud[0-9]+" k != null && (builtins.tryEval v.version).success) - pkgs); -in { + lib.filterAttrs ( + k: v: builtins.match "nextcloud[0-9]+" k != null && (builtins.tryEval v.version).success + ) pkgs + ); +in +{ inherit n; e = lib.concatStringsSep "," n; } diff --git a/pkgs/servers/nominatim/default.nix b/pkgs/servers/nominatim/default.nix index 529849625d93b9..55fd98d6366740 100644 --- a/pkgs/servers/nominatim/default.nix +++ b/pkgs/servers/nominatim/default.nix @@ -1,8 +1,22 @@ -{ stdenv, lib, fetchFromGitHub, fetchurl -, clang-tools, cmake, bzip2, zlib, expat, boost, git, pandoc, nlohmann_json -# Nominatim needs to be built with the same postgres version it will target -, postgresql -, python3, php, lua +{ + stdenv, + lib, + fetchFromGitHub, + fetchurl, + clang-tools, + cmake, + bzip2, + zlib, + expat, + boost, + git, + pandoc, + nlohmann_json, + # Nominatim needs to be built with the same postgres version it will target + postgresql, + python3, + php, + lua, }: let @@ -39,18 +53,20 @@ stdenv.mkDerivation rec { expat boost nlohmann_json - (python3.withPackages (ps: with ps; [ - pyyaml - python-dotenv - psycopg2 - sqlalchemy - asyncpg - psutil - jinja2 - pyicu - datrie - pyosmium - ])) + (python3.withPackages ( + ps: with ps; [ + pyyaml + python-dotenv + psycopg2 + sqlalchemy + asyncpg + psutil + jinja2 + pyicu + datrie + pyosmium + ] + )) # python3Packages.pylint # We don't want to run pylint because the package could break on pylint bumps which is really annoying. # python3Packages.pytest # disabled since I can't get it to run tests anyway # python3Packages.behave # disabled since I can't get it to run tests anyway diff --git a/pkgs/servers/nosql/apache-jena/binary.nix b/pkgs/servers/nosql/apache-jena/binary.nix index 840c1ff4886f91..8e2eb98f4bd8b8 100644 --- a/pkgs/servers/nosql/apache-jena/binary.nix +++ b/pkgs/servers/nosql/apache-jena/binary.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, java, makeWrapper }: +{ + lib, + stdenv, + fetchurl, + java, + makeWrapper, +}: stdenv.mkDerivation rec { pname = "apache-jena"; diff --git a/pkgs/servers/nosql/apache-jena/fuseki-binary.nix b/pkgs/servers/nosql/apache-jena/fuseki-binary.nix index ade900bacb60f7..e0db8d18f3a9b3 100644 --- a/pkgs/servers/nosql/apache-jena/fuseki-binary.nix +++ b/pkgs/servers/nosql/apache-jena/fuseki-binary.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchurl -, java -, coreutils -, which -, makeWrapper +{ + lib, + stdenv, + fetchurl, + java, + coreutils, + which, + makeWrapper, # For the test -, pkgs + pkgs, }: stdenv.mkDerivation rec { @@ -43,7 +44,10 @@ stdenv.mkDerivation rec { license = licenses.asl20; maintainers = with maintainers; [ raskin ]; platforms = platforms.all; - sourceProvenance = with sourceTypes; [ binaryBytecode binaryNativeCode ]; + sourceProvenance = with sourceTypes; [ + binaryBytecode + binaryNativeCode + ]; homepage = "https://jena.apache.org"; downloadPage = "https://archive.apache.org/dist/jena/binaries/"; mainProgram = "fuseki"; diff --git a/pkgs/servers/nosql/apache-jena/fuseki-test.nix b/pkgs/servers/nosql/apache-jena/fuseki-test.nix index dd8a82d8494f0a..af0991cb666d33 100644 --- a/pkgs/servers/nosql/apache-jena/fuseki-test.nix +++ b/pkgs/servers/nosql/apache-jena/fuseki-test.nix @@ -1,18 +1,28 @@ -{ runCommand, apache-jena-fuseki, curl }: +{ + runCommand, + apache-jena-fuseki, + curl, +}: runCommand "fuseki-test-${apache-jena-fuseki.name}" -{ nativeBuildInputs = [ curl apache-jena-fuseki ]; } '' - export FUSEKI_BASE="$PWD/fuseki-base" - mkdir -p "$FUSEKI_BASE/db" - FUSEKI_ARGS="--update --loc=$FUSEKI_BASE/db /dataset" fuseki start - fuseki status - for i in $(seq 120); do - if curl http://127.0.0.1:3030/dataset/data; then - break; - fi - sleep 1 - done - curl -d 'update=insert+data+{++++}' http://127.0.0.1:3030/dataset/update > /dev/null - curl http://127.0.0.1:3030/dataset/data | grep -C999 'test://predicate' - curl -d 'query=select+?s+?p+?o+where+{+?s+?p+?o+.+}' http://127.0.0.1:3030/dataset/query | grep -C999 'test://predicate' - touch $out -'' + { + nativeBuildInputs = [ + curl + apache-jena-fuseki + ]; + } + '' + export FUSEKI_BASE="$PWD/fuseki-base" + mkdir -p "$FUSEKI_BASE/db" + FUSEKI_ARGS="--update --loc=$FUSEKI_BASE/db /dataset" fuseki start + fuseki status + for i in $(seq 120); do + if curl http://127.0.0.1:3030/dataset/data; then + break; + fi + sleep 1 + done + curl -d 'update=insert+data+{++++}' http://127.0.0.1:3030/dataset/update > /dev/null + curl http://127.0.0.1:3030/dataset/data | grep -C999 'test://predicate' + curl -d 'query=select+?s+?p+?o+where+{+?s+?p+?o+.+}' http://127.0.0.1:3030/dataset/query | grep -C999 'test://predicate' + touch $out + '' diff --git a/pkgs/servers/nosql/cassandra/3.0.nix b/pkgs/servers/nosql/cassandra/3.0.nix index ce2da3391be1c1..29377500337ea8 100644 --- a/pkgs/servers/nosql/cassandra/3.0.nix +++ b/pkgs/servers/nosql/cassandra/3.0.nix @@ -1,7 +1,8 @@ -{ callPackage, lib, ... } @ args: +{ callPackage, lib, ... }@args: callPackage ./generic.nix ( args // lib.importJSON ./3.0.json // { generation = "3_0"; - }) + } +) diff --git a/pkgs/servers/nosql/cassandra/3.11.nix b/pkgs/servers/nosql/cassandra/3.11.nix index 695478f05030e9..90763d44f2daaa 100644 --- a/pkgs/servers/nosql/cassandra/3.11.nix +++ b/pkgs/servers/nosql/cassandra/3.11.nix @@ -1,7 +1,8 @@ -{ callPackage, lib, ... } @ args: +{ callPackage, lib, ... }@args: callPackage ./generic.nix ( args // lib.importJSON ./3.11.json // { generation = "3_11"; - }) + } +) diff --git a/pkgs/servers/nosql/cassandra/4.nix b/pkgs/servers/nosql/cassandra/4.nix index 5674d48664759e..b61e8abbb8e431 100644 --- a/pkgs/servers/nosql/cassandra/4.nix +++ b/pkgs/servers/nosql/cassandra/4.nix @@ -1,8 +1,9 @@ # GENERATED BY update.sh -{ callPackage, lib, ... } @ args: +{ callPackage, lib, ... }@args: callPackage ./generic.nix ( args // lib.importJSON ./4.json // { generation = "4"; - }) + } +) diff --git a/pkgs/servers/nosql/cassandra/generic.nix b/pkgs/servers/nosql/cassandra/generic.nix index 7e6d5f02ddfc13..42708ce9b5c110 100644 --- a/pkgs/servers/nosql/cassandra/generic.nix +++ b/pkgs/servers/nosql/cassandra/generic.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchurl -, python311Packages -, makeWrapper -, gawk -, bash -, getopt -, procps -, which -, jre -, nixosTests +{ + lib, + stdenv, + fetchurl, + python311Packages, + makeWrapper, + gawk, + bash, + getopt, + procps, + which, + jre, + nixosTests, # generation is the attribute version suffix such as 3_11 in pkgs.cassandra_3_11 -, generation -, version -, sha256 -, extraMeta ? { } -, callPackage -, ... + generation, + version, + sha256, + extraMeta ? { }, + callPackage, + ... }: let @@ -128,15 +129,18 @@ stdenv.mkDerivation rec { updateScript = callPackage ./update-script.nix { inherit generation; }; }; - meta = with lib; { - homepage = "https://cassandra.apache.org/"; - description = "Massively scalable open source NoSQL database"; - platforms = platforms.unix; - license = licenses.asl20; - sourceProvenance = with sourceTypes; [ - binaryBytecode - binaryNativeCode # bundled dependency libsigar - ]; - maintainers = [ maintainers.roberth ]; - } // extraMeta; + meta = + with lib; + { + homepage = "https://cassandra.apache.org/"; + description = "Massively scalable open source NoSQL database"; + platforms = platforms.unix; + license = licenses.asl20; + sourceProvenance = with sourceTypes; [ + binaryBytecode + binaryNativeCode # bundled dependency libsigar + ]; + maintainers = [ maintainers.roberth ]; + } + // extraMeta; } diff --git a/pkgs/servers/nosql/cassandra/update-script.nix b/pkgs/servers/nosql/cassandra/update-script.nix index b407b704fdfd2f..4cbcbe12861eff 100644 --- a/pkgs/servers/nosql/cassandra/update-script.nix +++ b/pkgs/servers/nosql/cassandra/update-script.nix @@ -1,9 +1,10 @@ -{ git -, lib -, runtimeShell -, writeScript -, generation -, gnupg +{ + git, + lib, + runtimeShell, + writeScript, + generation, + gnupg, }: let inherit (lib) makeBinPath; @@ -18,7 +19,12 @@ writeScript "update-cassandra_${generation}" '' exit 1 } cd pkgs/servers/nosql/cassandra - PATH="${makeBinPath [git gnupg]}:$PATH" + PATH="${ + makeBinPath [ + git + gnupg + ] + }:$PATH" tmp="$(mktemp -d)" cleanup() { diff --git a/pkgs/servers/nosql/eventstore/deps.nix b/pkgs/servers/nosql/eventstore/deps.nix index c1bdacfbf074a1..eb34d439b87cba 100644 --- a/pkgs/servers/nosql/eventstore/deps.nix +++ b/pkgs/servers/nosql/eventstore/deps.nix @@ -1,315 +1,1556 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "CompareNETObjects"; version = "4.78.0"; sha256 = "0vs0bxnw7287rh7yigq55750hfdzh04xbcaahawfdl9467vp4dgm"; }) - (fetchNuGet { pname = "ConfigureAwaitChecker.Analyzer"; version = "5.0.0.1"; sha256 = "01llfwhra5m3jj1qpa4rj1hbh01drirakzjc2963vkl9iwrzscyl"; }) - (fetchNuGet { pname = "dotnet-retire"; version = "4.0.1"; sha256 = "0zqyivj00mjagzhhkvzckdk5d5ldxhxhv7qk985pis9krfkgzhww"; }) - (fetchNuGet { pname = "Esprima"; version = "3.0.0-rc-01"; sha256 = "068xfs4h34irqab9zbq5s45iycxhbrv2r6fdv47zsxcday9xq617"; }) - (fetchNuGet { pname = "EventStore.Client"; version = "21.2.0"; sha256 = "1crnk0nbwcz4l2dv3ia96skmfn274nbyh5j1p0g9rjbzyy7kzf5j"; }) - (fetchNuGet { pname = "EventStore.Plugins"; version = "22.10.3"; sha256 = "0irii0xk806bc1pfnyn5dgksy4x9nqj9x2m01h9ddnzkzds2n9bi"; }) - (fetchNuGet { pname = "GitHubActionsTestLogger"; version = "2.0.1"; sha256 = "155d1fmnxlq7p7wk4v74b8v8h36nq0i6bq1vhdjf8sbq7f95fj0f"; }) - (fetchNuGet { pname = "GitInfo"; version = "2.0.26"; sha256 = "050l74vkamvbsp8f02b8aknizcknk4fr26dvwvw86mm8iw1dlvrv"; }) - (fetchNuGet { pname = "Google.Protobuf"; version = "3.22.0"; sha256 = "1wjxxlqdrjjb0f3py8sbgsivqms8d22m7xk1zx68gfmyih671in7"; }) - (fetchNuGet { pname = "gpr"; version = "0.1.122"; sha256 = "0z65n8zqdz0p2ackha572gpdjydhgnfszb46rca44773ak6mfa2b"; }) - (fetchNuGet { pname = "Grpc.AspNetCore"; version = "2.52.0"; sha256 = "1apbsqzkns2p0rn31j0q21n3a4lbnp06b4kh2wf44kancvhaj4ch"; }) - (fetchNuGet { pname = "Grpc.AspNetCore.Server"; version = "2.52.0"; sha256 = "0bvi61phh4r48ha0xc8mp0n79n3l0pniik08kvc2cwyq2fk3iiji"; }) - (fetchNuGet { pname = "Grpc.AspNetCore.Server.ClientFactory"; version = "2.52.0"; sha256 = "192bqxg63mn0nc8d8v21xnq3qmchiz90df6liqpbnisdl3avdyhk"; }) - (fetchNuGet { pname = "Grpc.Core"; version = "2.46.5"; sha256 = "0s1vyb1cx5id62kwx67qaqx25bykwpqnm2nmwsmcyqpzgyy0zwy2"; }) - (fetchNuGet { pname = "Grpc.Core.Api"; version = "2.46.5"; sha256 = "0m0vjr69rfqllvvij6rvv79mbks27rhh7b4wnfvj88v43zvvlnq0"; }) - (fetchNuGet { pname = "Grpc.Core.Api"; version = "2.52.0"; sha256 = "1mrc8zkcgvklrc0xalky9xxy9dkq5yk92idj1wm5zgdh6pghsa11"; }) - (fetchNuGet { pname = "Grpc.Net.Client"; version = "2.52.0"; sha256 = "0f8m8nmx30bb5wk61i7aqxnwz00rflyc7l8pl9i60mr8ybq5n671"; }) - (fetchNuGet { pname = "Grpc.Net.ClientFactory"; version = "2.52.0"; sha256 = "18zcrbzhg06f6wvm120176zfkz2sy9jal6p9wh2xsapjk52qin27"; }) - (fetchNuGet { pname = "Grpc.Net.Common"; version = "2.52.0"; sha256 = "1dhf98h89xbcpx4v6lmr3gq51br9r8jm38zhrs9dw8l9vy73x1jy"; }) - (fetchNuGet { pname = "Grpc.Tools"; version = "2.49.1"; sha256 = "1nsxm73b1bn4jjjpz5q6hvqjm77l9vhl4wi36b1pxwgdbdspy5rm"; }) - (fetchNuGet { pname = "Grpc.Tools"; version = "2.52.0"; sha256 = "1a13rrdryykazhq71q339r0xpsyi8vlj2zprrpriak2yn7zhxiqh"; }) - (fetchNuGet { pname = "HdrHistogram"; version = "2.5.0"; sha256 = "1s2np7m3pp17rgambax9a3x5pd2grx74cr325q3xapjz2gd58sj1"; }) - (fetchNuGet { pname = "HostStat.NET"; version = "1.0.2"; sha256 = "1khxpp1fy36njjcmikr0xnxk7zv9d3rcnm6f7x2s94agins23hg7"; }) - (fetchNuGet { pname = "Jint"; version = "3.0.0-beta-2048"; sha256 = "1iyfzpj36b8ybiwrjxwxqz42jgx2wsm8l0dmkiaip8ds0lal71iw"; }) - (fetchNuGet { pname = "Microsoft.AspNetCore.TestHost"; version = "6.0.16"; sha256 = "1zpiiq9yjwgcwq89j3jj7jdd2ycp15d3pklqdmhfxclv43ssn3hf"; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "1.1.0"; sha256 = "1dq5yw7cy6s42193yl4iqscfw5vzkjkgv0zyy32scr4jza6ni1a1"; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "5.0.0"; sha256 = "0cp5jbax2mf6xr3dqiljzlwi05fv6n9a35z337s92jcljiq674kf"; }) - (fetchNuGet { pname = "Microsoft.Bcl.AsyncInterfaces"; version = "6.0.0"; sha256 = "15gqy2m14fdlvy1g59207h5kisznm355kbw010gy19vh47z8gpz3"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Analyzers"; version = "3.3.3"; sha256 = "09m4cpry8ivm9ga1abrxmvw16sslxhy2k5sl14zckhqb1j164im6"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.Common"; version = "4.3.0"; sha256 = "0qpxygiq53v2d2wl6hccnkjf1lhlxjh4q3w5b6d23aq9pw5qj626"; }) - (fetchNuGet { pname = "Microsoft.CodeAnalysis.CSharp"; version = "4.3.0"; sha256 = "0m9qqn391ayfi1ffkzvhpij790hs96q6dbhzfkj2ahvw6qx47b30"; }) - (fetchNuGet { pname = "Microsoft.CodeCoverage"; version = "17.3.2"; sha256 = "1f05l2vm8inlwhk36lfbyszjlcnvdd2qw2832npaah0dldn6dz00"; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.0.1"; sha256 = "0zxc0apx1gcx361jlq8smc9pfdgmyjh6hpka8dypc9w23nlsh6yj"; }) - (fetchNuGet { pname = "Microsoft.CSharp"; version = "4.7.0"; sha256 = "0gd67zlw554j098kabg887b5a6pq9kzavpa3jjy5w53ccjzjfy8j"; }) - (fetchNuGet { pname = "Microsoft.Data.Sqlite"; version = "6.0.10"; sha256 = "0lshgxw6xvjaky1rg0nhdxw91h9m88fq2q3hrq9x0pk1wblsgkjp"; }) - (fetchNuGet { pname = "Microsoft.Data.Sqlite.Core"; version = "6.0.10"; sha256 = "1sdh5rw2pyg6c64z0haxf57bakd5kwaav624vlqif1m59iz26rag"; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.NETCore.Client"; version = "0.2.328102"; sha256 = "0i4wvjjcvxdr806s5yzwbjd1w9x8bcshrrq18kmc9ymjd1pkzpxk"; }) - (fetchNuGet { pname = "Microsoft.Diagnostics.Tracing.TraceEvent"; version = "3.0.5"; sha256 = "0j2w8q7a20s46a4nq8vnv8n14aamdamqcfvia9zkvx5xl7l22yb0"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "2.0.0"; sha256 = "0yssxq9di5h6xw2cayp5hj3l9b2p0jw9wcjz73rwk4586spac9s9"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "2.1.1"; sha256 = "0244czr3jflvzcj6axq61j10dkl0f16ad34rw81ryg57v4cvlwx6"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "3.0.3"; sha256 = "0fiwv35628rzkpixpbqcj8ln4c0hnwhr3is8ha38a9pdzlrs6zx8"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "3.1.0"; sha256 = "1rszgz0rd5kvib5fscz6ss3pkxyjwqy0xpd4f2ypgzf5z5g5d398"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration"; version = "6.0.0"; sha256 = "1zdyai2rzngmsp3706d12qrdk315c1s3ja218fzb3nc3wd1vz0s8"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "2.0.0"; sha256 = "1ilz2yrgg9rbjyhn6a5zh9pr51nmh11z7sixb4p7vivgydj9gxwf"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "2.1.0"; sha256 = "03gzlr3z9j1xnr1k6y91zgxpz3pj27i3zsvjwj7i8jqnlqmk7pxd"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "2.1.1"; sha256 = "0b4bn0cf39c6jlc8xnpi1d8f3pz0qhf8ng440yb95y5jv5q4fdyw"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "3.0.3"; sha256 = "18l6ys6z7j07vf5pa3g0d018dfgk5vb9hf3393cmmh448rpjq41m"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "3.1.0"; sha256 = "1f7h52kamljglx5k08ccryilvk6d6cvr9c26lcb6b2c091znzk0q"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Abstractions"; version = "6.0.0"; sha256 = "0w6wwxv12nbc3sghvr68847wc9skkdgsicrz3fx4chgng1i3xy0j"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "2.0.0"; sha256 = "1prvdbma6r18n5agbhhabv6g357p1j70gq4m9g0vs859kf44nrgc"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "2.1.1"; sha256 = "0n91s6cjfv8plf5swhr307s849jmq2pa3i1rbpb0cb0grxml0mqm"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "3.0.3"; sha256 = "0zy90kvlvxinwqz38cwj1jmp06a8gar1crdbycjk5wy8d6w5m0br"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Binder"; version = "3.1.0"; sha256 = "13jj7jxihiswmhmql7r5jydbca4x5qj6h7zq10z17gagys6dc7pw"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; version = "3.1.0"; sha256 = "1bkcrsmm37i7dcg4arffwqmd90vfhaxhrc6vh8mjwwp41q09ghna"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.FileExtensions"; version = "6.0.0"; sha256 = "02nna984iwnyyz4jjh9vs405nlj0yk1g5vz4v2x30z2c89mx5f9w"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Configuration.Json"; version = "6.0.0"; sha256 = "1c6l5szma1pdn61ncq1kaqibg0dz65hbma2xl626a8d1m6awn353"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "3.0.3"; sha256 = "0nd36n0zfqv5l4w4jlbs2smaw0x7lw49aw1wgk3wsyv69s74p3gj"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection"; version = "3.1.0"; sha256 = "1xc61dy07bn2q73mx1z3ylrw80xpa682qjby13gklnqq636a3gab"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "2.0.0"; sha256 = "1pwrfh9b72k9rq6mb2jab5qhhi225d5rjalzkapiayggmygc8nhz"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "2.1.0"; sha256 = "0c0cx8r5xkjpxmcfp51959jnp55qjvq28d9vaslk08avvi1by12s"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "2.1.1"; sha256 = "0rn0925aqm1fsbaf0n8jy6ng2fm1cy97lp7yikvx31m6178k9i84"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "3.0.3"; sha256 = "1hyilp5gr19xz7zcyar6h8jpfksqbn5s9kz0qrfqwvqhq2p7sm5g"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "3.1.0"; sha256 = "1pvms778xkyv1a3gfwrxnh8ja769cxi416n7pcidn9wvg15ifvbh"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; version = "5.0.0"; sha256 = "17cz6s80va0ch0a6nqa1wbbbp3p8sqxb96lj4qcw67ivkp2yxiyj"; }) - (fetchNuGet { pname = "Microsoft.Extensions.DependencyModel"; version = "3.0.0"; sha256 = "1cm0hycgb33mf1ja9q91wxi3gk13d1p462gdq7gndrya23hw2jm5"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "2.1.0"; sha256 = "1sxls5f5cgb0wr8cwb05skqmz074683hrhmd3hhq6m5dasnzb8n3"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Abstractions"; version = "6.0.0"; sha256 = "1fbqmfapxdz77drcv1ndyj2ybvd2rv4c9i9pgiykcpl4fa6dc65q"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Composite"; version = "6.0.0"; sha256 = "1yn0cnclbm3lv12fmf6z0mxqsyjk8s8r952fcw4fdv54mvqbfgkl"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Embedded"; version = "6.0.9"; sha256 = "0pni3y0drcjfr3cgpw8iiac589rsh6z5c2h2xnzy3yvk5lx5pl0d"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileProviders.Physical"; version = "6.0.0"; sha256 = "1ikc3kf325xig6njbi2aj5kmww4xlaq9lsrpc8v764fsm4x10474"; }) - (fetchNuGet { pname = "Microsoft.Extensions.FileSystemGlobbing"; version = "6.0.0"; sha256 = "09gyyv4fwy9ys84z3aq4lm9y09b7bd1d4l4gfdinmg0z9678f1a4"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Hosting.Abstractions"; version = "2.1.0"; sha256 = "04vm9mdjjzg3lpp2rzpgkpn8h5bzdl3bwcr22lshd3kp602ws4k9"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Http"; version = "3.0.3"; sha256 = "0glfid82amr4mxjqpq2ar6vhq6wv88sp463yvhg4pravkcrd0611"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "2.0.0"; sha256 = "1jkwjcq1ld9znz1haazk8ili2g4pzfdp6i7r7rki4hg3jcadn386"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "2.1.1"; sha256 = "12pag6rf01xfa8x1h30mf4czfhlhg2kgi5q712jicy3h12c02w8y"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "3.0.3"; sha256 = "0kyh6bk9iywbdvn29zm1770fwmag58y7c8rfpx886anxs6p9rh61"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging"; version = "3.1.0"; sha256 = "1d3yhqj1rav7vswm747j7w8fh8paybji4rz941hhlq4b12mfqfh4"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "2.0.0"; sha256 = "1x5isi71z02khikzvm7vaschb006pqqrsv86ky1x08a4hir4s43h"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "2.1.0"; sha256 = "1gvgif1wcx4k6pv7gc00qv1hid945jdywy1s50s33q0hfd91hbnj"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "2.1.1"; sha256 = "1sgpwj0sa0ac7m5fnkb482mnch8fsv8hfbvk53c6lyh47s1xhdjg"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "3.0.3"; sha256 = "1wj871vl1azasbn2lrzzycvzkk72rvaxywnj193xwv11420b0mjh"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Abstractions"; version = "3.1.0"; sha256 = "1zyalrcksszmn9r5xjnirfh7847axncgzxkk3k5srbvlcch8fw8g"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Logging.Configuration"; version = "3.1.0"; sha256 = "00bx95j2j0lkrr1znm53qicigvrj4sbc7snh27nqwsp4vkjnpz5h"; }) - (fetchNuGet { pname = "Microsoft.Extensions.ObjectPool"; version = "5.0.10"; sha256 = "07fk669pjydkcg6bxxv7aj548fzab4yb7ba8370d719lgi9y425l"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "2.0.0"; sha256 = "0g4zadlg73f507krilhaaa7h0jdga216syrzjlyf5fdk25gxmjqh"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "2.1.1"; sha256 = "0wgpsi874gzzjj099xbdmmsifslkbdjkxd5xrzpc5xdglpkw08vl"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "3.0.3"; sha256 = "0lq433x3z3dhf4w10vrxnqami6xsr6mwasla3qhmfx7yfybgz7y0"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options"; version = "5.0.0"; sha256 = "1rdmgpg770x8qwaaa6ryc27zh93p697fcyvn5vkxp0wimlhqkbay"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; version = "3.1.0"; sha256 = "13bhi1q4s79k4qb19m4p94364543jr3a1f8kacjvdhigpmqa732r"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "2.0.0"; sha256 = "1xppr5jbny04slyjgngxjdm0maxdh47vq481ps944d7jrfs0p3mb"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "2.1.0"; sha256 = "1r9gzwdfmb8ysnc4nzmyz5cyar1lw0qmizsvrsh252nhlyg06nmb"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "2.1.1"; sha256 = "033rkqdffybq5prhc7nn6v68zij393n00s5a82yf2n86whwvdfwx"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "2.2.0"; sha256 = "0znah6arbcqari49ymigg3wiy2hgdifz8zsq8vdc3ynnf45r7h0c"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "3.0.3"; sha256 = "08zlr6kl92znj9v2cs1wsjw6s98nxbkwnxk8pccbv0b4c7xhb3pf"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "3.1.0"; sha256 = "1w1y22njywwysi8qjnj4m83qhbq0jr4mmjib0hfawz6cwamh7xrb"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "5.0.0"; sha256 = "0swqcknyh87ns82w539z1mvy804pfwhgzs97cr3nwqk6g5s42gd6"; }) - (fetchNuGet { pname = "Microsoft.Extensions.Primitives"; version = "6.0.0"; sha256 = "1kjiw6s4yfz9gm7mx3wkhp06ghnbs95icj9hi505shz9rjrg42q2"; }) - (fetchNuGet { pname = "Microsoft.FASTER.Core"; version = "1.9.5"; sha256 = "1vp2644301bsdad0sd20pjqa8lbf1vc8yvd9rkl986h56hgwczsj"; }) - (fetchNuGet { pname = "Microsoft.Net.Http.Headers"; version = "2.2.8"; sha256 = "1s0n68z6v5mbys4jjrd4jdxrrz81iq4dzmmbmxzmlf59769x8rj9"; }) - (fetchNuGet { pname = "Microsoft.NET.Test.Sdk"; version = "17.3.2"; sha256 = "0pm06nxqi8aw04lciqy7iz8ln1qm5mx06cpwgqa2dfwvnjp7zxnm"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.0.1"; sha256 = "01al6cfxp68dscl15z7rxfw9zvhm64dncsw09a1vmdkacsa2v6lr"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.0"; sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "1.1.1"; sha256 = "164wycgng4mi9zqi2pnsf1pq6gccbqvw6ib916mqizgjmd8f44pj"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "2.1.0"; sha256 = "0nmdnkmwyxj8cp746hs9an57zspqlmqdm55b00i7yk8a22s6akxz"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.0.1"; sha256 = "0ppdkwy6s9p7x9jix3v4402wb171cdiibq7js7i13nxpdky7074p"; }) - (fetchNuGet { pname = "Microsoft.NETCore.Targets"; version = "1.1.0"; sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies"; version = "1.0.0"; sha256 = "0na724xhvqm63vq9y18fl9jw9q2v99bdwr353378s5fsi11qzxp9"; }) - (fetchNuGet { pname = "Microsoft.NETFramework.ReferenceAssemblies.net461"; version = "1.0.0"; sha256 = "00vkn4c6i0rn1l9pv912y0wgb9h6ks76qah8hvk441nari8fqbm1"; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.ObjectModel"; version = "17.2.0"; sha256 = "0l05smcgjzdfa5f60f9q5lylap3i21aswxbava92s19bgv46w2rv"; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.ObjectModel"; version = "17.3.2"; sha256 = "0bs38r5kdw1xpbjbi5l82xbhfnfbzr5xhg5520lk05pg914d1ln1"; }) - (fetchNuGet { pname = "Microsoft.TestPlatform.TestHost"; version = "17.3.2"; sha256 = "089nmaxzvm5xcf20pm4iiavz2k6lwh69r51xlbqg0ry605mnl869"; }) - (fetchNuGet { pname = "Microsoft.Win32.Primitives"; version = "4.3.0"; sha256 = "0j0c1wj4ndj21zsgivsc24whiya605603kxrbiw6wkfdync464wq"; }) - (fetchNuGet { pname = "Microsoft.Win32.SystemEvents"; version = "6.0.0"; sha256 = "0c6pcj088g1yd1vs529q3ybgsd2vjlk5y1ic6dkmbhvrp5jibl9p"; }) - (fetchNuGet { pname = "MinVer"; version = "4.2.0"; sha256 = "00skhyfh6q2dmqgh1bmcryvkg79kvgc6d9qxbpg43fvaifwxxl99"; }) - (fetchNuGet { pname = "minver-cli"; version = "2.2.0"; sha256 = "0whxllmgyin9n02pvq97633ncflg7k4z0c7p28j4wydv55iz3cxv"; }) - (fetchNuGet { pname = "Mono.Posix.NETStandard"; version = "1.0.0"; sha256 = "0xlja36hwpjm837haq15mjh2prcf68lyrmn72nvgpz8qnf9vappw"; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.0"; sha256 = "1bc4ba8ahgk15m8k4nd7x406nhi0kwqzbgjk2dmw52ss553xz7iy"; }) - (fetchNuGet { pname = "NETStandard.Library"; version = "2.0.3"; sha256 = "1fn9fxppfcg4jgypp2pmrpr6awl3qz1xmnri0cygpkwvyx27df1y"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "11.0.2"; sha256 = "1784xi44f4k8v1fr696hsccmwpy94bz7kixxqlri98zhcxn406b2"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "13.0.2"; sha256 = "1p9splg1min274dpz7xdfgzrwkyfd3xlkygwpr1xgjvvyjvs6b0i"; }) - (fetchNuGet { pname = "Newtonsoft.Json"; version = "9.0.1"; sha256 = "0mcy0i7pnfpqm4pcaiyzzji4g0c8i3a5gjz28rrr28110np8304r"; }) - (fetchNuGet { pname = "NuGet.Frameworks"; version = "5.11.0"; sha256 = "0wv26gq39hfqw9md32amr5771s73f5zn1z9vs4y77cgynxr73s4z"; }) - (fetchNuGet { pname = "NUnit"; version = "3.13.3"; sha256 = "0wdzfkygqnr73s6lpxg5b1pwaqz9f414fxpvpdmf72bvh4jaqzv6"; }) - (fetchNuGet { pname = "NUnit3TestAdapter"; version = "4.2.1"; sha256 = "0gildh4xcb6gkxcrrgh5a1j7lq0a7l670jpbs71akl5b5bgy5gc3"; }) - (fetchNuGet { pname = "OpenTelemetry"; version = "1.4.0-rc.1"; sha256 = "17cbj0dx6fxk169rs0ds6cph75z9r1i90xgjdapx1zmx1kwcdn00"; }) - (fetchNuGet { pname = "OpenTelemetry.Api"; version = "1.4.0-rc.1"; sha256 = "09pc8vbhgjq5bibvjw39gjdb99x3nclsggzp509qfcxv8gizcs21"; }) - (fetchNuGet { pname = "OpenTelemetry.Exporter.Prometheus.AspNetCore"; version = "1.4.0-rc.1"; sha256 = "129qk929f21akx87g66f8h1ckj2lj2ij5by5ma7bdm19jpk2yhdx"; }) - (fetchNuGet { pname = "OpenTelemetry.Extensions.DependencyInjection"; version = "1.4.0-rc.1"; sha256 = "19sraav8y53yi1pf8dsjd2n5cnffqd876rjxmlkkbi550qdr9l0v"; }) - (fetchNuGet { pname = "OpenTelemetry.Extensions.Hosting"; version = "1.4.0-rc.1"; sha256 = "0h781wdirsqz1hxwmag6dzzng3kpk7nqrmfg0j04z3q23zi9rp9h"; }) - (fetchNuGet { pname = "protobuf-net"; version = "2.4.0"; sha256 = "106lxm9afga7ihlknyy7mlfplyq40mrndksqrsn8ia2a47fbqqld"; }) - (fetchNuGet { pname = "Quickenshtein"; version = "1.5.1"; sha256 = "0mhnywivqxlpznr2fk7jp8g0bshsbq0yyyggcn51blkaabf18grl"; }) - (fetchNuGet { pname = "runtime.any.System.Collections"; version = "4.3.0"; sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tools"; version = "4.3.0"; sha256 = "1wl76vk12zhdh66vmagni66h5xbhgqq7zkdpgw21jhxhvlbcl8pk"; }) - (fetchNuGet { pname = "runtime.any.System.Diagnostics.Tracing"; version = "4.3.0"; sha256 = "00j6nv2xgmd3bi347k00m7wr542wjlig53rmj28pmw7ddcn97jbn"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization"; version = "4.3.0"; sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; }) - (fetchNuGet { pname = "runtime.any.System.Globalization.Calendars"; version = "4.3.0"; sha256 = "1ghhhk5psqxcg6w88sxkqrc35bxcz27zbqm2y5p5298pv3v7g201"; }) - (fetchNuGet { pname = "runtime.any.System.IO"; version = "4.3.0"; sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection"; version = "4.3.0"; sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Extensions"; version = "4.3.0"; sha256 = "0zyri97dfc5vyaz9ba65hjj1zbcrzaffhsdlpxc9bh09wy22fq33"; }) - (fetchNuGet { pname = "runtime.any.System.Reflection.Primitives"; version = "4.3.0"; sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; }) - (fetchNuGet { pname = "runtime.any.System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime"; version = "4.3.0"; sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.Handles"; version = "4.3.0"; sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; }) - (fetchNuGet { pname = "runtime.any.System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding"; version = "4.3.0"; sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; }) - (fetchNuGet { pname = "runtime.any.System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; }) - (fetchNuGet { pname = "runtime.any.System.Threading.Tasks"; version = "4.3.0"; sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "16rnxzpk5dpbbl1x354yrlsbvwylrq456xzpsha1n9y3glnhyx9d"; }) - (fetchNuGet { pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0rwpqngkqiapqc5c2cpkj7idhngrgss5qpnqg0yh40mbyflcxf8i"; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0hkg03sgm2wyq8nqk6dbm9jh5vcq57ry42lkqdmfklrw89lsmr59"; }) - (fetchNuGet { pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1n06gxwlinhs0w7s8a94r1q3lwqzvynxwd3mp10ws9bg6gck8n4r"; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0c2p354hjx58xhhz7wv6div8xpi90sc6ibdm40qin21bvi7ymcaa"; }) - (fetchNuGet { pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0404wqrc7f2yc0wxv71y3nnybvqx8v4j9d47hlscxy759a525mc3"; }) - (fetchNuGet { pname = "runtime.native.System"; version = "4.3.0"; sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; }) - (fetchNuGet { pname = "runtime.native.System.Net.Http"; version = "4.3.0"; sha256 = "1n6rgz5132lcibbch1qlf0g9jk60r0kqv087hxc0lisy50zpm7kk"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; sha256 = "1b61p6gw1m02cc1ry996fl49liiwky6181dzr873g9ds92zl326q"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "18pzfdlwsg2nb1jjjjzyb5qlgy6xjxzmhnfaijq5s2jw3cm3ab97"; }) - (fetchNuGet { pname = "runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0zy5r25jppz48i2bkg8b9lfig24xixg6nm3xyr1379zdnqnpm8f6"; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0qyynf9nz5i7pc26cwhgi8j62ps27sqmf78ijcfgzab50z9g8ay3"; }) - (fetchNuGet { pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "096ch4n4s8k82xga80lfmpimpzahd2ip1mgwdqgar0ywbbl6x438"; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "1klrs545awhayryma6l7g2pvnp9xy4z0r1i40r80zb45q3i9nbyf"; }) - (fetchNuGet { pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1dm8fifl7rf1gy7lnwln78ch4rw54g0pl5g1c189vawavll7p6rj"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; version = "4.3.0"; sha256 = "10yc8jdrwgcl44b4g93f1ds76b176bajd3zqi2faf5rvh1vy9smi"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0zcxjv5pckplvkg0r6mw3asggm7aqzbdjimhvsasb0cgm59x09l3"; }) - (fetchNuGet { pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1m9z1k9kzva9n9kwinqxl97x2vgl79qhqjlv17k9s2ymcyv2bwr6"; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0vhynn79ih7hw7cwjazn87rm9z9fj0rvxgzlab36jybgcpcgphsn"; }) - (fetchNuGet { pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1cpx56mcfxz7cpn57wvj18sjisvzq8b5vd9rw16ihd2i6mcp3wa1"; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "160p68l2c7cqmyqjwxydcvgw7lvl1cr0znkw8fp24d1by9mqc8p3"; }) - (fetchNuGet { pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "15gsm1a8jdmgmf8j5v1slfz8ks124nfdhk2vxs2rw3asrxalg8hi"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "15zrc8fgd8zx28hdghcj5f5i34wf3l6bq5177075m2bc2j34jrqy"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "0q0n5q1r1wnqmr5i5idsrd9ywl33k0js4pngkwq9p368mbxp8x1w"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "1p4dgxax6p7rlgj4q73k73rslcnz4wdcv8q2flg1s8ygwcm58ld5"; }) - (fetchNuGet { pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; version = "4.3.2"; sha256 = "1x0g58pbpjrmj2x2qw17rdwwnrcl0wvim2hdwz48lixvwvp22n9c"; }) - (fetchNuGet { pname = "runtime.unix.Microsoft.Win32.Primitives"; version = "4.3.0"; sha256 = "0y61k9zbxhdi0glg154v30kkq7f8646nif8lnnxbvkjpakggd5id"; }) - (fetchNuGet { pname = "runtime.unix.System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; }) - (fetchNuGet { pname = "runtime.unix.System.IO.FileSystem"; version = "4.3.0"; sha256 = "14nbkhvs7sji5r1saj2x8daz82rnf9kx28d3v2qss34qbr32dzix"; }) - (fetchNuGet { pname = "runtime.unix.System.Net.Primitives"; version = "4.3.0"; sha256 = "0bdnglg59pzx9394sy4ic66kmxhqp8q8bvmykdxcbs5mm0ipwwm4"; }) - (fetchNuGet { pname = "runtime.unix.System.Private.Uri"; version = "4.3.0"; sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; }) - (fetchNuGet { pname = "runtime.unix.System.Runtime.Extensions"; version = "4.3.0"; sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; }) - (fetchNuGet { pname = "Serilog"; version = "2.0.0"; sha256 = "194c39cwribx7p2sic0w8hjmc83194bc985kl7aqpmljfz376gsc"; }) - (fetchNuGet { pname = "Serilog"; version = "2.12.0"; sha256 = "0lqxpc96qcjkv9pr1rln7mi4y7n7jdi4vb36c2fv3845w1vswgr4"; }) - (fetchNuGet { pname = "Serilog.Enrichers.Process"; version = "2.0.2"; sha256 = "0wivpxljx5s2vh9rw0h8g64siaq3ajm6rpg6y8v3qnxfmlhlas6s"; }) - (fetchNuGet { pname = "Serilog.Enrichers.Thread"; version = "3.1.0"; sha256 = "1y75aiv2k1sxnh012ixkx92fq1yl8srqggy8l439igg4p223hcqi"; }) - (fetchNuGet { pname = "Serilog.Expressions"; version = "3.4.0"; sha256 = "10knpl8nnxmksbsq3l7p486kq1n5y5kn8ibvcscmcig6wxhcw05h"; }) - (fetchNuGet { pname = "Serilog.Extensions.Logging"; version = "3.1.0"; sha256 = "0lv370ks2fjdn1nsgkbzbmw6hybnincw3jabr471a5w39pp4fl1c"; }) - (fetchNuGet { pname = "Serilog.Filters.Expressions"; version = "2.1.0"; sha256 = "0pwlcisijbkdhgab2k4vwjqimminxnkzgdrxvq7pz5ba2brsy28l"; }) - (fetchNuGet { pname = "Serilog.Settings.Configuration"; version = "3.4.0"; sha256 = "1l6fyy9y5a168i1mm107aqyrwzhqmpy0cp1v13l2b89yv8dc105j"; }) - (fetchNuGet { pname = "Serilog.Sinks.Async"; version = "1.5.0"; sha256 = "0bcb3n6lmg5wfj806mziybfmbb8gyiszrivs3swf0msy8w505gyg"; }) - (fetchNuGet { pname = "Serilog.Sinks.Console"; version = "4.1.0"; sha256 = "1rpkphmqfh3bv3m7v1zwz88wz4sirj4xqyff9ga0c6bqhblj6wii"; }) - (fetchNuGet { pname = "Serilog.Sinks.File"; version = "5.0.0"; sha256 = "097rngmgcrdfy7jy8j7dq3xaq2qky8ijwg0ws6bfv5lx0f3vvb0q"; }) - (fetchNuGet { pname = "Serilog.Sinks.InMemory"; version = "0.11.0"; sha256 = "0kmnj3wx1hwxvgp06avn2zw1mzsfjamrgpaav44ir40100g4hdkd"; }) - (fetchNuGet { pname = "Serilog.Sinks.TextWriter"; version = "2.1.0"; sha256 = "0p13m8spj6psybwdw21gjaxw854va8n6m2rbdy0w78q135br1kcd"; }) - (fetchNuGet { pname = "SQLitePCLRaw.bundle_e_sqlite3"; version = "2.1.2"; sha256 = "07rc4pj3rphi8nhzkcvilnm0fv27qcdp68jdwk4g0zjk7yfvbcay"; }) - (fetchNuGet { pname = "SQLitePCLRaw.core"; version = "2.1.2"; sha256 = "19hxv895lairrjmk4gkzd3mcb6b0na45xn4n551h4kckplqadg3d"; }) - (fetchNuGet { pname = "SQLitePCLRaw.lib.e_sqlite3"; version = "2.1.2"; sha256 = "0jn98bkjk8h4smi09z31ib6s6392054lwmkziqmkqf5gf614k2fz"; }) - (fetchNuGet { pname = "SQLitePCLRaw.provider.e_sqlite3"; version = "2.1.2"; sha256 = "0bnm2fhvcsyg5ry74gal2cziqnyf5a8d2cb491vsa7j41hbbx7kv"; }) - (fetchNuGet { pname = "Superpower"; version = "2.3.0"; sha256 = "0bdsc3c0d6jb0wr67siqfba0ldl0jxbwis6xr0whzqzf6m2cyahm"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.3.0"; sha256 = "0fgns20ispwrfqll4q1zc1waqcmylb3zc50ys9x8zlwxh9pmd9jy"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.0"; sha256 = "1ywfqn4md6g3iilpxjn5dsr0f5lx6z0yvhqp4pgjcamygg73cz2c"; }) - (fetchNuGet { pname = "System.Buffers"; version = "4.5.1"; sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.0.11"; sha256 = "1ga40f5lrwldiyw6vy67d0sg7jd7ww6kgwbksm19wrvq9hr0bsm6"; }) - (fetchNuGet { pname = "System.Collections"; version = "4.3.0"; sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; }) - (fetchNuGet { pname = "System.Collections.Concurrent"; version = "4.3.0"; sha256 = "0wi10md9aq33jrkh2c24wr2n9hrpyamsdhsxdcnf43b7y86kkii8"; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "6.0.0"; sha256 = "1js98kmjn47ivcvkjqdmyipzknb9xbndssczm8gq224pbaj1p88c"; }) - (fetchNuGet { pname = "System.ComponentModel.Composition"; version = "6.0.0"; sha256 = "16zfx5mivkkykp76krw8x68izmjf79ldfmn26k9x3m55lmp9i77c"; }) - (fetchNuGet { pname = "System.Configuration.ConfigurationManager"; version = "6.0.0"; sha256 = "0sqapr697jbb4ljkq46msg0xx1qpmc31ivva6llyz2wzq3mpmxbw"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.0.11"; sha256 = "0gmjghrqmlgzxivd2xl50ncbglb7ljzb66rlx8ws6dv8jm0d5siz"; }) - (fetchNuGet { pname = "System.Diagnostics.Debug"; version = "4.3.0"; sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "4.3.0"; sha256 = "0z6m3pbiy0qw6rn3n209rrzf9x1k4002zh90vwcrsym09ipm2liq"; }) - (fetchNuGet { pname = "System.Diagnostics.DiagnosticSource"; version = "7.0.0"; sha256 = "1jxhvsh5mzdf0sgb4dfmbys1b12ylyr5pcfyj1map354fiq3qsgm"; }) - (fetchNuGet { pname = "System.Diagnostics.PerformanceCounter"; version = "6.0.1"; sha256 = "17p5vwbgrycsrvv9a9ksxbiziy75x4s25dw71fnbw1ci5kpp8yz7"; }) - (fetchNuGet { pname = "System.Diagnostics.Tools"; version = "4.0.1"; sha256 = "19cknvg07yhakcvpxg3cxa0bwadplin6kyxd8mpjjpwnp56nl85x"; }) - (fetchNuGet { pname = "System.Diagnostics.Tracing"; version = "4.3.0"; sha256 = "1m3bx6c2s958qligl67q7grkwfz3w53hpy7nc97mh6f7j5k168c4"; }) - (fetchNuGet { pname = "System.Drawing.Common"; version = "6.0.0"; sha256 = "02n8rzm58dac2np8b3xw8ychbvylja4nh6938l5k2fhyn40imlgz"; }) - (fetchNuGet { pname = "System.Dynamic.Runtime"; version = "4.0.11"; sha256 = "1pla2dx8gkidf7xkciig6nifdsb494axjvzvann8g2lp3dbqasm9"; }) - (fetchNuGet { pname = "System.Formats.Asn1"; version = "7.0.0"; sha256 = "1a14kgpqz4k7jhi7bs2gpgf67ym5wpj99203zxgwjypj7x47xhbq"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.0.11"; sha256 = "070c5jbas2v7smm660zaf1gh0489xanjqymkvafcs4f8cdrs1d5d"; }) - (fetchNuGet { pname = "System.Globalization"; version = "4.3.0"; sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; }) - (fetchNuGet { pname = "System.Globalization.Calendars"; version = "4.3.0"; sha256 = "1xwl230bkakzzkrggy1l1lxmm3xlhk4bq2pkv790j5lm8g887lxq"; }) - (fetchNuGet { pname = "System.Globalization.Extensions"; version = "4.3.0"; sha256 = "02a5zfxavhv3jd437bsncbhd2fp1zv4gxzakp1an9l6kdq1mcqls"; }) - (fetchNuGet { pname = "System.Interactive.Async"; version = "5.0.0"; sha256 = "00flf80ahpyhrsny2kfl9bsyh1mxmsdsigpq3rzhaps9wgdbmzjz"; }) - (fetchNuGet { pname = "System.IO"; version = "4.1.0"; sha256 = "1g0yb8p11vfd0kbkyzlfsbsp5z44lwsvyc0h3dpw6vqnbi035ajp"; }) - (fetchNuGet { pname = "System.IO"; version = "4.3.0"; sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.0.1"; sha256 = "0kgfpw6w4djqra3w5crrg8xivbanh1w9dh3qapb28q060wb9flp1"; }) - (fetchNuGet { pname = "System.IO.FileSystem"; version = "4.3.0"; sha256 = "0z2dfrbra9i6y16mm9v1v6k47f0fm617vlb7s5iybjjsz6g1ilmw"; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.0.1"; sha256 = "1s0mniajj3lvbyf7vfb5shp4ink5yibsx945k6lvxa96r8la1612"; }) - (fetchNuGet { pname = "System.IO.FileSystem.Primitives"; version = "4.3.0"; sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; }) - (fetchNuGet { pname = "System.IO.Pipelines"; version = "6.0.3"; sha256 = "1jgdazpmwc21dd9naq3l9n5s8a1jnbwlvgkf1pnm0aji6jd4xqdz"; }) - (fetchNuGet { pname = "System.Linq"; version = "4.1.0"; sha256 = "1ppg83svb39hj4hpp5k7kcryzrf3sfnm08vxd5sm2drrijsla2k5"; }) - (fetchNuGet { pname = "System.Linq"; version = "4.3.0"; sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; }) - (fetchNuGet { pname = "System.Linq.Async"; version = "6.0.1"; sha256 = "10ira8hmv0i54yp9ggrrdm1c06j538sijfjpn1kmnh9j2xk5yzmq"; }) - (fetchNuGet { pname = "System.Linq.Expressions"; version = "4.1.0"; sha256 = "1gpdxl6ip06cnab7n3zlcg6mqp7kknf73s8wjinzi4p0apw82fpg"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.0"; sha256 = "1layqpcx1q4l805fdnj2dfqp6ncx2z42ca06rgsr6ikq4jjgbv30"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.1"; sha256 = "0f07d7hny38lq9w69wx4lxkn4wszrqf9m9js6fh9is645csm167c"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.3"; sha256 = "0naqahm3wljxb5a911d37mwjqjdxv9l0b49p5dmfyijvni2ppy8a"; }) - (fetchNuGet { pname = "System.Memory"; version = "4.5.4"; sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; }) - (fetchNuGet { pname = "System.Net.Http"; version = "4.3.4"; sha256 = "0kdp31b8819v88l719j6my0yas6myv9d1viql3qz5577mv819jhl"; }) - (fetchNuGet { pname = "System.Net.Primitives"; version = "4.3.0"; sha256 = "0c87k50rmdgmxx7df2khd9qj7q35j9rzdmm2572cc55dygmdk3ii"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.4.0"; sha256 = "0rdvma399070b0i46c4qq1h2yvjj3k013sqzkilz4bz5cwmx1rba"; }) - (fetchNuGet { pname = "System.Numerics.Vectors"; version = "4.5.0"; sha256 = "1kzrj37yzawf1b19jq0253rcs8hsq1l2q8g69d7ipnhzb0h97m59"; }) - (fetchNuGet { pname = "System.ObjectModel"; version = "4.0.12"; sha256 = "1sybkfi60a4588xn34nd9a58png36i0xr4y4v4kqpg8wlvy5krrj"; }) - (fetchNuGet { pname = "System.Private.ServiceModel"; version = "4.10.0"; sha256 = "0048hmv4j4wfpa9hwn8d5l3ag3hwmhp5r26iarfbsxj0q3i2d1a8"; }) - (fetchNuGet { pname = "System.Private.ServiceModel"; version = "4.5.3"; sha256 = "0nyw9m9dj327hn0qb0jmgwpch0f40jv301fk4mrchga8g99xbpng"; }) - (fetchNuGet { pname = "System.Private.Uri"; version = "4.3.0"; sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.1.0"; sha256 = "1js89429pfw79mxvbzp8p3q93il6rdff332hddhzi5wqglc4gml9"; }) - (fetchNuGet { pname = "System.Reflection"; version = "4.3.0"; sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; }) - (fetchNuGet { pname = "System.Reflection.DispatchProxy"; version = "4.5.0"; sha256 = "0v9sg38h91aljvjyc77m1y5v34p50hjdbxvvxwa1whlajhafadcn"; }) - (fetchNuGet { pname = "System.Reflection.DispatchProxy"; version = "4.7.1"; sha256 = "10yh3q2i71gcw7c0dfz9qxql2vlvnqjav1hyf1q9rpbvdbgsabrs"; }) - (fetchNuGet { pname = "System.Reflection.Emit"; version = "4.0.1"; sha256 = "0ydqcsvh6smi41gyaakglnv252625hf29f7kywy2c70nhii2ylqp"; }) - (fetchNuGet { pname = "System.Reflection.Emit.ILGeneration"; version = "4.0.1"; sha256 = "1pcd2ig6bg144y10w7yxgc9d22r7c7ww7qn1frdfwgxr24j9wvv0"; }) - (fetchNuGet { pname = "System.Reflection.Emit.Lightweight"; version = "4.0.1"; sha256 = "1s4b043zdbx9k39lfhvsk68msv1nxbidhkq6nbm27q7sf8xcsnxr"; }) - (fetchNuGet { pname = "System.Reflection.Extensions"; version = "4.0.1"; sha256 = "0m7wqwq0zqq9gbpiqvgk3sr92cbrw7cp3xn53xvw7zj6rz6fdirn"; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "1.6.0"; sha256 = "1wdbavrrkajy7qbdblpbpbalbdl48q3h34cchz24gvdgyrlf15r4"; }) - (fetchNuGet { pname = "System.Reflection.Metadata"; version = "5.0.0"; sha256 = "17qsl5nanlqk9iz0l5wijdn6ka632fs1m1fvx18dfgswm258r3ss"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.0.1"; sha256 = "1bangaabhsl4k9fg8khn83wm6yial8ik1sza7401621jc6jrym28"; }) - (fetchNuGet { pname = "System.Reflection.Primitives"; version = "4.3.0"; sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; }) - (fetchNuGet { pname = "System.Reflection.TypeExtensions"; version = "4.1.0"; sha256 = "1bjli8a7sc7jlxqgcagl9nh8axzfl11f4ld3rjqsyxc516iijij7"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.0.1"; sha256 = "0b4i7mncaf8cnai85jv3wnw6hps140cxz8vylv2bik6wyzgvz7bi"; }) - (fetchNuGet { pname = "System.Resources.ResourceManager"; version = "4.3.0"; sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.1.0"; sha256 = "02hdkgk13rvsd6r9yafbwzss8kr55wnj8d5c7xjnp8gqrwc8sn0m"; }) - (fetchNuGet { pname = "System.Runtime"; version = "4.3.0"; sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.4.0"; sha256 = "0a6ahgi5b148sl5qyfpyw383p3cb4yrkm802k29fsi4mxkiwir29"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.0"; sha256 = "17labczwqk3jng3kkky73m0jhi8wc21vbl7cz5c0hj2p1dswin43"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "4.5.1"; sha256 = "1xcrjx5fwg284qdnxyi2d0lzdm5q4frlpkp0nf6vvkx1kdz2prrf"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "5.0.0"; sha256 = "02k25ivn50dmqx5jn8hawwmz24yf0454fjd823qk6lygj9513q4x"; }) - (fetchNuGet { pname = "System.Runtime.CompilerServices.Unsafe"; version = "6.0.0"; sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.1.0"; sha256 = "0rw4rm4vsm3h3szxp9iijc3ksyviwsv6f63dng3vhqyg4vjdkc2z"; }) - (fetchNuGet { pname = "System.Runtime.Extensions"; version = "4.3.0"; sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.0.1"; sha256 = "1g0zrdi5508v49pfm3iii2hn6nm00bgvfpjq1zxknfjrxxa20r4g"; }) - (fetchNuGet { pname = "System.Runtime.Handles"; version = "4.3.0"; sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.1.0"; sha256 = "01kxqppx3dr3b6b286xafqilv4s2n0gqvfgzfd4z943ga9i81is1"; }) - (fetchNuGet { pname = "System.Runtime.InteropServices"; version = "4.3.0"; sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; }) - (fetchNuGet { pname = "System.Runtime.Numerics"; version = "4.3.0"; sha256 = "19rav39sr5dky7afygh309qamqqmi9kcwvz3i0c5700v0c5cg61z"; }) - (fetchNuGet { pname = "System.Runtime.Serialization.Primitives"; version = "4.1.1"; sha256 = "042rfjixknlr6r10vx2pgf56yming8lkjikamg3g4v29ikk78h7k"; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "6.0.0"; sha256 = "0a678bzj8yxxiffyzy60z2w1nczzpi8v97igr4ip3byd2q89dv58"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Algorithms"; version = "4.3.0"; sha256 = "03sq183pfl5kp7gkvq77myv7kbpdnq3y0xj7vi4q1kaw54sny0ml"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Cng"; version = "4.3.0"; sha256 = "1k468aswafdgf56ab6yrn7649kfqx2wm9aslywjam1hdmk5yypmv"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Csp"; version = "4.3.0"; sha256 = "1x5wcrddf2s3hb8j78cry7yalca4lb5vfnkrysagbn6r9x6xvrx1"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Encoding"; version = "4.3.0"; sha256 = "1jr6w70igqn07k5zs1ph6xja97hxnb3mqbspdrff6cvssgrixs32"; }) - (fetchNuGet { pname = "System.Security.Cryptography.OpenSsl"; version = "4.3.0"; sha256 = "0givpvvj8yc7gv4lhb6s1prq6p2c4147204a0wib89inqzd87gqc"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Pkcs"; version = "7.0.2"; sha256 = "0px6snb8gdb6mpwsqrhlpbkmjgd63h4yamqm2gvyf9rwibymjbm9"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Primitives"; version = "4.3.0"; sha256 = "0pyzncsv48zwly3lw4f2dayqswcfvdwq2nz0dgwmi7fj3pn64wby"; }) - (fetchNuGet { pname = "System.Security.Cryptography.ProtectedData"; version = "6.0.0"; sha256 = "05kd3a8w7658hjxq9vvszxip30a479fjmfq4bq1r95nrsvs4hbss"; }) - (fetchNuGet { pname = "System.Security.Cryptography.X509Certificates"; version = "4.3.0"; sha256 = "0valjcz5wksbvijylxijjxb1mp38mdhv03r533vnx1q3ikzdav9h"; }) - (fetchNuGet { pname = "System.Security.Cryptography.Xml"; version = "7.0.1"; sha256 = "0p6kx6ag0il7rxxcvm84w141phvr7fafjzxybf920bxwa0jkwzq8"; }) - (fetchNuGet { pname = "System.Security.Permissions"; version = "6.0.0"; sha256 = "0jsl4xdrkqi11iwmisi1r2f2qn5pbvl79mzq877gndw6ans2zhzw"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "4.5.0"; sha256 = "0rmj89wsl5yzwh0kqjgx45vzf694v9p92r4x4q6yxldk1cv1hi86"; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; sha256 = "1mpk7xj76lxgz97a5yg93wi8lj0l8p157a5d50mmjy3gbz1904q8"; }) - (fetchNuGet { pname = "System.ServiceModel.Http"; version = "4.10.0"; sha256 = "1b6dzgrj5ybpr21zh1gnmzbmx7k3xsc53ksmv8ilhj717gpvaz9d"; }) - (fetchNuGet { pname = "System.ServiceModel.Primitives"; version = "4.10.0"; sha256 = "1a1b0li9g7nhmy7r850nprpihkpfhw9gscfbgl38xzyr9crd236w"; }) - (fetchNuGet { pname = "System.ServiceModel.Primitives"; version = "4.5.3"; sha256 = "1v90pci049cn44y0km885k1vrilhb34w6q2zva4y6f3ay84klrih"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.0.11"; sha256 = "1dyqv0hijg265dwxg6l7aiv74102d6xjiwplh2ar1ly6xfaa4iiw"; }) - (fetchNuGet { pname = "System.Text.Encoding"; version = "4.3.0"; sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; }) - (fetchNuGet { pname = "System.Text.Encoding.CodePages"; version = "6.0.0"; sha256 = "0gm2kiz2ndm9xyzxgi0jhazgwslcs427waxgfa30m7yqll1kcrww"; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.0.11"; sha256 = "08nsfrpiwsg9x5ml4xyl3zyvjfdi4mvbqf93kjdh11j4fwkznizs"; }) - (fetchNuGet { pname = "System.Text.Encoding.Extensions"; version = "4.3.0"; sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; }) - (fetchNuGet { pname = "System.Text.Encodings.Web"; version = "6.0.0"; sha256 = "06n9ql3fmhpjl32g3492sj181zjml5dlcc5l76xq2h38c4f87sai"; }) - (fetchNuGet { pname = "System.Text.Json"; version = "4.6.0"; sha256 = "0ism236hwi0k6axssfq58s1d8lihplwiz058pdvl8al71hagri39"; }) - (fetchNuGet { pname = "System.Text.Json"; version = "6.0.0"; sha256 = "1si2my1g0q0qv1hiqnji4xh9wd05qavxnzj9dwgs23iqvgjky0gl"; }) - (fetchNuGet { pname = "System.Text.RegularExpressions"; version = "4.1.0"; sha256 = "1mw7vfkkyd04yn2fbhm38msk7dz2xwvib14ygjsb8dq2lcvr18y7"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.0.11"; sha256 = "19x946h926bzvbsgj28csn46gak2crv2skpwsx80hbgazmkgb1ls"; }) - (fetchNuGet { pname = "System.Threading"; version = "4.3.0"; sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.0.11"; sha256 = "0nr1r41rak82qfa5m0lhk9mp0k93bvfd7bbd9sdzwx9mb36g28p5"; }) - (fetchNuGet { pname = "System.Threading.Tasks"; version = "4.3.0"; sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.0.0"; sha256 = "1cb51z062mvc2i8blpzmpn9d9mm4y307xrwi65di8ri18cz5r1zr"; }) - (fetchNuGet { pname = "System.Threading.Tasks.Extensions"; version = "4.5.4"; sha256 = "0y6ncasgfcgnjrhynaf0lwpkpkmv4a07sswwkwbwb5h7riisj153"; }) - (fetchNuGet { pname = "System.Windows.Extensions"; version = "6.0.0"; sha256 = "1wy9pq9vn1bqg5qnv53iqrbx04yzdmjw4x5yyi09y3459vaa1sip"; }) - (fetchNuGet { pname = "System.Xml.ReaderWriter"; version = "4.0.11"; sha256 = "0c6ky1jk5ada9m94wcadih98l6k1fvf6vi7vhn1msjixaha419l5"; }) - (fetchNuGet { pname = "System.Xml.XDocument"; version = "4.0.11"; sha256 = "0n4lvpqzy9kc7qy1a4acwwd7b7pnvygv895az5640idl2y9zbz18"; }) - (fetchNuGet { pname = "YamlDotNet"; version = "12.0.1"; sha256 = "0axlq2xm3lb8kq24b0fsi5yg3gm63fjsy30xkxwngnnx7wd75y2y"; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "CompareNETObjects"; + version = "4.78.0"; + sha256 = "0vs0bxnw7287rh7yigq55750hfdzh04xbcaahawfdl9467vp4dgm"; + }) + (fetchNuGet { + pname = "ConfigureAwaitChecker.Analyzer"; + version = "5.0.0.1"; + sha256 = "01llfwhra5m3jj1qpa4rj1hbh01drirakzjc2963vkl9iwrzscyl"; + }) + (fetchNuGet { + pname = "dotnet-retire"; + version = "4.0.1"; + sha256 = "0zqyivj00mjagzhhkvzckdk5d5ldxhxhv7qk985pis9krfkgzhww"; + }) + (fetchNuGet { + pname = "Esprima"; + version = "3.0.0-rc-01"; + sha256 = "068xfs4h34irqab9zbq5s45iycxhbrv2r6fdv47zsxcday9xq617"; + }) + (fetchNuGet { + pname = "EventStore.Client"; + version = "21.2.0"; + sha256 = "1crnk0nbwcz4l2dv3ia96skmfn274nbyh5j1p0g9rjbzyy7kzf5j"; + }) + (fetchNuGet { + pname = "EventStore.Plugins"; + version = "22.10.3"; + sha256 = "0irii0xk806bc1pfnyn5dgksy4x9nqj9x2m01h9ddnzkzds2n9bi"; + }) + (fetchNuGet { + pname = "GitHubActionsTestLogger"; + version = "2.0.1"; + sha256 = "155d1fmnxlq7p7wk4v74b8v8h36nq0i6bq1vhdjf8sbq7f95fj0f"; + }) + (fetchNuGet { + pname = "GitInfo"; + version = "2.0.26"; + sha256 = "050l74vkamvbsp8f02b8aknizcknk4fr26dvwvw86mm8iw1dlvrv"; + }) + (fetchNuGet { + pname = "Google.Protobuf"; + version = "3.22.0"; + sha256 = "1wjxxlqdrjjb0f3py8sbgsivqms8d22m7xk1zx68gfmyih671in7"; + }) + (fetchNuGet { + pname = "gpr"; + version = "0.1.122"; + sha256 = "0z65n8zqdz0p2ackha572gpdjydhgnfszb46rca44773ak6mfa2b"; + }) + (fetchNuGet { + pname = "Grpc.AspNetCore"; + version = "2.52.0"; + sha256 = "1apbsqzkns2p0rn31j0q21n3a4lbnp06b4kh2wf44kancvhaj4ch"; + }) + (fetchNuGet { + pname = "Grpc.AspNetCore.Server"; + version = "2.52.0"; + sha256 = "0bvi61phh4r48ha0xc8mp0n79n3l0pniik08kvc2cwyq2fk3iiji"; + }) + (fetchNuGet { + pname = "Grpc.AspNetCore.Server.ClientFactory"; + version = "2.52.0"; + sha256 = "192bqxg63mn0nc8d8v21xnq3qmchiz90df6liqpbnisdl3avdyhk"; + }) + (fetchNuGet { + pname = "Grpc.Core"; + version = "2.46.5"; + sha256 = "0s1vyb1cx5id62kwx67qaqx25bykwpqnm2nmwsmcyqpzgyy0zwy2"; + }) + (fetchNuGet { + pname = "Grpc.Core.Api"; + version = "2.46.5"; + sha256 = "0m0vjr69rfqllvvij6rvv79mbks27rhh7b4wnfvj88v43zvvlnq0"; + }) + (fetchNuGet { + pname = "Grpc.Core.Api"; + version = "2.52.0"; + sha256 = "1mrc8zkcgvklrc0xalky9xxy9dkq5yk92idj1wm5zgdh6pghsa11"; + }) + (fetchNuGet { + pname = "Grpc.Net.Client"; + version = "2.52.0"; + sha256 = "0f8m8nmx30bb5wk61i7aqxnwz00rflyc7l8pl9i60mr8ybq5n671"; + }) + (fetchNuGet { + pname = "Grpc.Net.ClientFactory"; + version = "2.52.0"; + sha256 = "18zcrbzhg06f6wvm120176zfkz2sy9jal6p9wh2xsapjk52qin27"; + }) + (fetchNuGet { + pname = "Grpc.Net.Common"; + version = "2.52.0"; + sha256 = "1dhf98h89xbcpx4v6lmr3gq51br9r8jm38zhrs9dw8l9vy73x1jy"; + }) + (fetchNuGet { + pname = "Grpc.Tools"; + version = "2.49.1"; + sha256 = "1nsxm73b1bn4jjjpz5q6hvqjm77l9vhl4wi36b1pxwgdbdspy5rm"; + }) + (fetchNuGet { + pname = "Grpc.Tools"; + version = "2.52.0"; + sha256 = "1a13rrdryykazhq71q339r0xpsyi8vlj2zprrpriak2yn7zhxiqh"; + }) + (fetchNuGet { + pname = "HdrHistogram"; + version = "2.5.0"; + sha256 = "1s2np7m3pp17rgambax9a3x5pd2grx74cr325q3xapjz2gd58sj1"; + }) + (fetchNuGet { + pname = "HostStat.NET"; + version = "1.0.2"; + sha256 = "1khxpp1fy36njjcmikr0xnxk7zv9d3rcnm6f7x2s94agins23hg7"; + }) + (fetchNuGet { + pname = "Jint"; + version = "3.0.0-beta-2048"; + sha256 = "1iyfzpj36b8ybiwrjxwxqz42jgx2wsm8l0dmkiaip8ds0lal71iw"; + }) + (fetchNuGet { + pname = "Microsoft.AspNetCore.TestHost"; + version = "6.0.16"; + sha256 = "1zpiiq9yjwgcwq89j3jj7jdd2ycp15d3pklqdmhfxclv43ssn3hf"; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "1.1.0"; + sha256 = "1dq5yw7cy6s42193yl4iqscfw5vzkjkgv0zyy32scr4jza6ni1a1"; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "5.0.0"; + sha256 = "0cp5jbax2mf6xr3dqiljzlwi05fv6n9a35z337s92jcljiq674kf"; + }) + (fetchNuGet { + pname = "Microsoft.Bcl.AsyncInterfaces"; + version = "6.0.0"; + sha256 = "15gqy2m14fdlvy1g59207h5kisznm355kbw010gy19vh47z8gpz3"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Analyzers"; + version = "3.3.3"; + sha256 = "09m4cpry8ivm9ga1abrxmvw16sslxhy2k5sl14zckhqb1j164im6"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.Common"; + version = "4.3.0"; + sha256 = "0qpxygiq53v2d2wl6hccnkjf1lhlxjh4q3w5b6d23aq9pw5qj626"; + }) + (fetchNuGet { + pname = "Microsoft.CodeAnalysis.CSharp"; + version = "4.3.0"; + sha256 = "0m9qqn391ayfi1ffkzvhpij790hs96q6dbhzfkj2ahvw6qx47b30"; + }) + (fetchNuGet { + pname = "Microsoft.CodeCoverage"; + version = "17.3.2"; + sha256 = "1f05l2vm8inlwhk36lfbyszjlcnvdd2qw2832npaah0dldn6dz00"; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.0.1"; + sha256 = "0zxc0apx1gcx361jlq8smc9pfdgmyjh6hpka8dypc9w23nlsh6yj"; + }) + (fetchNuGet { + pname = "Microsoft.CSharp"; + version = "4.7.0"; + sha256 = "0gd67zlw554j098kabg887b5a6pq9kzavpa3jjy5w53ccjzjfy8j"; + }) + (fetchNuGet { + pname = "Microsoft.Data.Sqlite"; + version = "6.0.10"; + sha256 = "0lshgxw6xvjaky1rg0nhdxw91h9m88fq2q3hrq9x0pk1wblsgkjp"; + }) + (fetchNuGet { + pname = "Microsoft.Data.Sqlite.Core"; + version = "6.0.10"; + sha256 = "1sdh5rw2pyg6c64z0haxf57bakd5kwaav624vlqif1m59iz26rag"; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.NETCore.Client"; + version = "0.2.328102"; + sha256 = "0i4wvjjcvxdr806s5yzwbjd1w9x8bcshrrq18kmc9ymjd1pkzpxk"; + }) + (fetchNuGet { + pname = "Microsoft.Diagnostics.Tracing.TraceEvent"; + version = "3.0.5"; + sha256 = "0j2w8q7a20s46a4nq8vnv8n14aamdamqcfvia9zkvx5xl7l22yb0"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "2.0.0"; + sha256 = "0yssxq9di5h6xw2cayp5hj3l9b2p0jw9wcjz73rwk4586spac9s9"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "2.1.1"; + sha256 = "0244czr3jflvzcj6axq61j10dkl0f16ad34rw81ryg57v4cvlwx6"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "3.0.3"; + sha256 = "0fiwv35628rzkpixpbqcj8ln4c0hnwhr3is8ha38a9pdzlrs6zx8"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "3.1.0"; + sha256 = "1rszgz0rd5kvib5fscz6ss3pkxyjwqy0xpd4f2ypgzf5z5g5d398"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration"; + version = "6.0.0"; + sha256 = "1zdyai2rzngmsp3706d12qrdk315c1s3ja218fzb3nc3wd1vz0s8"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "2.0.0"; + sha256 = "1ilz2yrgg9rbjyhn6a5zh9pr51nmh11z7sixb4p7vivgydj9gxwf"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "2.1.0"; + sha256 = "03gzlr3z9j1xnr1k6y91zgxpz3pj27i3zsvjwj7i8jqnlqmk7pxd"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "2.1.1"; + sha256 = "0b4bn0cf39c6jlc8xnpi1d8f3pz0qhf8ng440yb95y5jv5q4fdyw"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "3.0.3"; + sha256 = "18l6ys6z7j07vf5pa3g0d018dfgk5vb9hf3393cmmh448rpjq41m"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "3.1.0"; + sha256 = "1f7h52kamljglx5k08ccryilvk6d6cvr9c26lcb6b2c091znzk0q"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Abstractions"; + version = "6.0.0"; + sha256 = "0w6wwxv12nbc3sghvr68847wc9skkdgsicrz3fx4chgng1i3xy0j"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "2.0.0"; + sha256 = "1prvdbma6r18n5agbhhabv6g357p1j70gq4m9g0vs859kf44nrgc"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "2.1.1"; + sha256 = "0n91s6cjfv8plf5swhr307s849jmq2pa3i1rbpb0cb0grxml0mqm"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "3.0.3"; + sha256 = "0zy90kvlvxinwqz38cwj1jmp06a8gar1crdbycjk5wy8d6w5m0br"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Binder"; + version = "3.1.0"; + sha256 = "13jj7jxihiswmhmql7r5jydbca4x5qj6h7zq10z17gagys6dc7pw"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.EnvironmentVariables"; + version = "3.1.0"; + sha256 = "1bkcrsmm37i7dcg4arffwqmd90vfhaxhrc6vh8mjwwp41q09ghna"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.FileExtensions"; + version = "6.0.0"; + sha256 = "02nna984iwnyyz4jjh9vs405nlj0yk1g5vz4v2x30z2c89mx5f9w"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Configuration.Json"; + version = "6.0.0"; + sha256 = "1c6l5szma1pdn61ncq1kaqibg0dz65hbma2xl626a8d1m6awn353"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "3.0.3"; + sha256 = "0nd36n0zfqv5l4w4jlbs2smaw0x7lw49aw1wgk3wsyv69s74p3gj"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection"; + version = "3.1.0"; + sha256 = "1xc61dy07bn2q73mx1z3ylrw80xpa682qjby13gklnqq636a3gab"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "2.0.0"; + sha256 = "1pwrfh9b72k9rq6mb2jab5qhhi225d5rjalzkapiayggmygc8nhz"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "2.1.0"; + sha256 = "0c0cx8r5xkjpxmcfp51959jnp55qjvq28d9vaslk08avvi1by12s"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "2.1.1"; + sha256 = "0rn0925aqm1fsbaf0n8jy6ng2fm1cy97lp7yikvx31m6178k9i84"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "3.0.3"; + sha256 = "1hyilp5gr19xz7zcyar6h8jpfksqbn5s9kz0qrfqwvqhq2p7sm5g"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "3.1.0"; + sha256 = "1pvms778xkyv1a3gfwrxnh8ja769cxi416n7pcidn9wvg15ifvbh"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyInjection.Abstractions"; + version = "5.0.0"; + sha256 = "17cz6s80va0ch0a6nqa1wbbbp3p8sqxb96lj4qcw67ivkp2yxiyj"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.DependencyModel"; + version = "3.0.0"; + sha256 = "1cm0hycgb33mf1ja9q91wxi3gk13d1p462gdq7gndrya23hw2jm5"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "2.1.0"; + sha256 = "1sxls5f5cgb0wr8cwb05skqmz074683hrhmd3hhq6m5dasnzb8n3"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Abstractions"; + version = "6.0.0"; + sha256 = "1fbqmfapxdz77drcv1ndyj2ybvd2rv4c9i9pgiykcpl4fa6dc65q"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Composite"; + version = "6.0.0"; + sha256 = "1yn0cnclbm3lv12fmf6z0mxqsyjk8s8r952fcw4fdv54mvqbfgkl"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Embedded"; + version = "6.0.9"; + sha256 = "0pni3y0drcjfr3cgpw8iiac589rsh6z5c2h2xnzy3yvk5lx5pl0d"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileProviders.Physical"; + version = "6.0.0"; + sha256 = "1ikc3kf325xig6njbi2aj5kmww4xlaq9lsrpc8v764fsm4x10474"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.FileSystemGlobbing"; + version = "6.0.0"; + sha256 = "09gyyv4fwy9ys84z3aq4lm9y09b7bd1d4l4gfdinmg0z9678f1a4"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Hosting.Abstractions"; + version = "2.1.0"; + sha256 = "04vm9mdjjzg3lpp2rzpgkpn8h5bzdl3bwcr22lshd3kp602ws4k9"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Http"; + version = "3.0.3"; + sha256 = "0glfid82amr4mxjqpq2ar6vhq6wv88sp463yvhg4pravkcrd0611"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "2.0.0"; + sha256 = "1jkwjcq1ld9znz1haazk8ili2g4pzfdp6i7r7rki4hg3jcadn386"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "2.1.1"; + sha256 = "12pag6rf01xfa8x1h30mf4czfhlhg2kgi5q712jicy3h12c02w8y"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "3.0.3"; + sha256 = "0kyh6bk9iywbdvn29zm1770fwmag58y7c8rfpx886anxs6p9rh61"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging"; + version = "3.1.0"; + sha256 = "1d3yhqj1rav7vswm747j7w8fh8paybji4rz941hhlq4b12mfqfh4"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "2.0.0"; + sha256 = "1x5isi71z02khikzvm7vaschb006pqqrsv86ky1x08a4hir4s43h"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "2.1.0"; + sha256 = "1gvgif1wcx4k6pv7gc00qv1hid945jdywy1s50s33q0hfd91hbnj"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "2.1.1"; + sha256 = "1sgpwj0sa0ac7m5fnkb482mnch8fsv8hfbvk53c6lyh47s1xhdjg"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "3.0.3"; + sha256 = "1wj871vl1azasbn2lrzzycvzkk72rvaxywnj193xwv11420b0mjh"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Abstractions"; + version = "3.1.0"; + sha256 = "1zyalrcksszmn9r5xjnirfh7847axncgzxkk3k5srbvlcch8fw8g"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Logging.Configuration"; + version = "3.1.0"; + sha256 = "00bx95j2j0lkrr1znm53qicigvrj4sbc7snh27nqwsp4vkjnpz5h"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.ObjectPool"; + version = "5.0.10"; + sha256 = "07fk669pjydkcg6bxxv7aj548fzab4yb7ba8370d719lgi9y425l"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "2.0.0"; + sha256 = "0g4zadlg73f507krilhaaa7h0jdga216syrzjlyf5fdk25gxmjqh"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "2.1.1"; + sha256 = "0wgpsi874gzzjj099xbdmmsifslkbdjkxd5xrzpc5xdglpkw08vl"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "3.0.3"; + sha256 = "0lq433x3z3dhf4w10vrxnqami6xsr6mwasla3qhmfx7yfybgz7y0"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options"; + version = "5.0.0"; + sha256 = "1rdmgpg770x8qwaaa6ryc27zh93p697fcyvn5vkxp0wimlhqkbay"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Options.ConfigurationExtensions"; + version = "3.1.0"; + sha256 = "13bhi1q4s79k4qb19m4p94364543jr3a1f8kacjvdhigpmqa732r"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "2.0.0"; + sha256 = "1xppr5jbny04slyjgngxjdm0maxdh47vq481ps944d7jrfs0p3mb"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "2.1.0"; + sha256 = "1r9gzwdfmb8ysnc4nzmyz5cyar1lw0qmizsvrsh252nhlyg06nmb"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "2.1.1"; + sha256 = "033rkqdffybq5prhc7nn6v68zij393n00s5a82yf2n86whwvdfwx"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "2.2.0"; + sha256 = "0znah6arbcqari49ymigg3wiy2hgdifz8zsq8vdc3ynnf45r7h0c"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "3.0.3"; + sha256 = "08zlr6kl92znj9v2cs1wsjw6s98nxbkwnxk8pccbv0b4c7xhb3pf"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "3.1.0"; + sha256 = "1w1y22njywwysi8qjnj4m83qhbq0jr4mmjib0hfawz6cwamh7xrb"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "5.0.0"; + sha256 = "0swqcknyh87ns82w539z1mvy804pfwhgzs97cr3nwqk6g5s42gd6"; + }) + (fetchNuGet { + pname = "Microsoft.Extensions.Primitives"; + version = "6.0.0"; + sha256 = "1kjiw6s4yfz9gm7mx3wkhp06ghnbs95icj9hi505shz9rjrg42q2"; + }) + (fetchNuGet { + pname = "Microsoft.FASTER.Core"; + version = "1.9.5"; + sha256 = "1vp2644301bsdad0sd20pjqa8lbf1vc8yvd9rkl986h56hgwczsj"; + }) + (fetchNuGet { + pname = "Microsoft.Net.Http.Headers"; + version = "2.2.8"; + sha256 = "1s0n68z6v5mbys4jjrd4jdxrrz81iq4dzmmbmxzmlf59769x8rj9"; + }) + (fetchNuGet { + pname = "Microsoft.NET.Test.Sdk"; + version = "17.3.2"; + sha256 = "0pm06nxqi8aw04lciqy7iz8ln1qm5mx06cpwgqa2dfwvnjp7zxnm"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.0.1"; + sha256 = "01al6cfxp68dscl15z7rxfw9zvhm64dncsw09a1vmdkacsa2v6lr"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.0"; + sha256 = "08vh1r12g6ykjygq5d3vq09zylgb84l63k49jc4v8faw9g93iqqm"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "1.1.1"; + sha256 = "164wycgng4mi9zqi2pnsf1pq6gccbqvw6ib916mqizgjmd8f44pj"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "2.1.0"; + sha256 = "0nmdnkmwyxj8cp746hs9an57zspqlmqdm55b00i7yk8a22s6akxz"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.0.1"; + sha256 = "0ppdkwy6s9p7x9jix3v4402wb171cdiibq7js7i13nxpdky7074p"; + }) + (fetchNuGet { + pname = "Microsoft.NETCore.Targets"; + version = "1.1.0"; + sha256 = "193xwf33fbm0ni3idxzbr5fdq3i2dlfgihsac9jj7whj0gd902nh"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies"; + version = "1.0.0"; + sha256 = "0na724xhvqm63vq9y18fl9jw9q2v99bdwr353378s5fsi11qzxp9"; + }) + (fetchNuGet { + pname = "Microsoft.NETFramework.ReferenceAssemblies.net461"; + version = "1.0.0"; + sha256 = "00vkn4c6i0rn1l9pv912y0wgb9h6ks76qah8hvk441nari8fqbm1"; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.ObjectModel"; + version = "17.2.0"; + sha256 = "0l05smcgjzdfa5f60f9q5lylap3i21aswxbava92s19bgv46w2rv"; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.ObjectModel"; + version = "17.3.2"; + sha256 = "0bs38r5kdw1xpbjbi5l82xbhfnfbzr5xhg5520lk05pg914d1ln1"; + }) + (fetchNuGet { + pname = "Microsoft.TestPlatform.TestHost"; + version = "17.3.2"; + sha256 = "089nmaxzvm5xcf20pm4iiavz2k6lwh69r51xlbqg0ry605mnl869"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Primitives"; + version = "4.3.0"; + sha256 = "0j0c1wj4ndj21zsgivsc24whiya605603kxrbiw6wkfdync464wq"; + }) + (fetchNuGet { + pname = "Microsoft.Win32.SystemEvents"; + version = "6.0.0"; + sha256 = "0c6pcj088g1yd1vs529q3ybgsd2vjlk5y1ic6dkmbhvrp5jibl9p"; + }) + (fetchNuGet { + pname = "MinVer"; + version = "4.2.0"; + sha256 = "00skhyfh6q2dmqgh1bmcryvkg79kvgc6d9qxbpg43fvaifwxxl99"; + }) + (fetchNuGet { + pname = "minver-cli"; + version = "2.2.0"; + sha256 = "0whxllmgyin9n02pvq97633ncflg7k4z0c7p28j4wydv55iz3cxv"; + }) + (fetchNuGet { + pname = "Mono.Posix.NETStandard"; + version = "1.0.0"; + sha256 = "0xlja36hwpjm837haq15mjh2prcf68lyrmn72nvgpz8qnf9vappw"; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.0"; + sha256 = "1bc4ba8ahgk15m8k4nd7x406nhi0kwqzbgjk2dmw52ss553xz7iy"; + }) + (fetchNuGet { + pname = "NETStandard.Library"; + version = "2.0.3"; + sha256 = "1fn9fxppfcg4jgypp2pmrpr6awl3qz1xmnri0cygpkwvyx27df1y"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "11.0.2"; + sha256 = "1784xi44f4k8v1fr696hsccmwpy94bz7kixxqlri98zhcxn406b2"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "13.0.2"; + sha256 = "1p9splg1min274dpz7xdfgzrwkyfd3xlkygwpr1xgjvvyjvs6b0i"; + }) + (fetchNuGet { + pname = "Newtonsoft.Json"; + version = "9.0.1"; + sha256 = "0mcy0i7pnfpqm4pcaiyzzji4g0c8i3a5gjz28rrr28110np8304r"; + }) + (fetchNuGet { + pname = "NuGet.Frameworks"; + version = "5.11.0"; + sha256 = "0wv26gq39hfqw9md32amr5771s73f5zn1z9vs4y77cgynxr73s4z"; + }) + (fetchNuGet { + pname = "NUnit"; + version = "3.13.3"; + sha256 = "0wdzfkygqnr73s6lpxg5b1pwaqz9f414fxpvpdmf72bvh4jaqzv6"; + }) + (fetchNuGet { + pname = "NUnit3TestAdapter"; + version = "4.2.1"; + sha256 = "0gildh4xcb6gkxcrrgh5a1j7lq0a7l670jpbs71akl5b5bgy5gc3"; + }) + (fetchNuGet { + pname = "OpenTelemetry"; + version = "1.4.0-rc.1"; + sha256 = "17cbj0dx6fxk169rs0ds6cph75z9r1i90xgjdapx1zmx1kwcdn00"; + }) + (fetchNuGet { + pname = "OpenTelemetry.Api"; + version = "1.4.0-rc.1"; + sha256 = "09pc8vbhgjq5bibvjw39gjdb99x3nclsggzp509qfcxv8gizcs21"; + }) + (fetchNuGet { + pname = "OpenTelemetry.Exporter.Prometheus.AspNetCore"; + version = "1.4.0-rc.1"; + sha256 = "129qk929f21akx87g66f8h1ckj2lj2ij5by5ma7bdm19jpk2yhdx"; + }) + (fetchNuGet { + pname = "OpenTelemetry.Extensions.DependencyInjection"; + version = "1.4.0-rc.1"; + sha256 = "19sraav8y53yi1pf8dsjd2n5cnffqd876rjxmlkkbi550qdr9l0v"; + }) + (fetchNuGet { + pname = "OpenTelemetry.Extensions.Hosting"; + version = "1.4.0-rc.1"; + sha256 = "0h781wdirsqz1hxwmag6dzzng3kpk7nqrmfg0j04z3q23zi9rp9h"; + }) + (fetchNuGet { + pname = "protobuf-net"; + version = "2.4.0"; + sha256 = "106lxm9afga7ihlknyy7mlfplyq40mrndksqrsn8ia2a47fbqqld"; + }) + (fetchNuGet { + pname = "Quickenshtein"; + version = "1.5.1"; + sha256 = "0mhnywivqxlpznr2fk7jp8g0bshsbq0yyyggcn51blkaabf18grl"; + }) + (fetchNuGet { + pname = "runtime.any.System.Collections"; + version = "4.3.0"; + sha256 = "0bv5qgm6vr47ynxqbnkc7i797fdi8gbjjxii173syrx14nmrkwg0"; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tools"; + version = "4.3.0"; + sha256 = "1wl76vk12zhdh66vmagni66h5xbhgqq7zkdpgw21jhxhvlbcl8pk"; + }) + (fetchNuGet { + pname = "runtime.any.System.Diagnostics.Tracing"; + version = "4.3.0"; + sha256 = "00j6nv2xgmd3bi347k00m7wr542wjlig53rmj28pmw7ddcn97jbn"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization"; + version = "4.3.0"; + sha256 = "1daqf33hssad94lamzg01y49xwndy2q97i2lrb7mgn28656qia1x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Globalization.Calendars"; + version = "4.3.0"; + sha256 = "1ghhhk5psqxcg6w88sxkqrc35bxcz27zbqm2y5p5298pv3v7g201"; + }) + (fetchNuGet { + pname = "runtime.any.System.IO"; + version = "4.3.0"; + sha256 = "0l8xz8zn46w4d10bcn3l4yyn4vhb3lrj2zw8llvz7jk14k4zps5x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection"; + version = "4.3.0"; + sha256 = "02c9h3y35pylc0zfq3wcsvc5nqci95nrkq0mszifc0sjx7xrzkly"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Extensions"; + version = "4.3.0"; + sha256 = "0zyri97dfc5vyaz9ba65hjj1zbcrzaffhsdlpxc9bh09wy22fq33"; + }) + (fetchNuGet { + pname = "runtime.any.System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "0x1mm8c6iy8rlxm8w9vqw7gb7s1ljadrn049fmf70cyh42vdfhrf"; + }) + (fetchNuGet { + pname = "runtime.any.System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "03kickal0iiby82wa5flar18kyv82s9s6d4xhk5h4bi5kfcyfjzl"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime"; + version = "4.3.0"; + sha256 = "1cqh1sv3h5j7ixyb7axxbdkqx6cxy00p4np4j91kpm492rf4s25b"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0bh5bi25nk9w9xi8z23ws45q5yia6k7dg3i4axhfqlnj145l011x"; + }) + (fetchNuGet { + pname = "runtime.any.System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "0c3g3g3jmhlhw4klrc86ka9fjbl7i59ds1fadsb2l8nqf8z3kb19"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding"; + version = "4.3.0"; + sha256 = "0aqqi1v4wx51h51mk956y783wzags13wa7mgqyclacmsmpv02ps3"; + }) + (fetchNuGet { + pname = "runtime.any.System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "0lqhgqi0i8194ryqq6v2gqx0fb86db2gqknbm0aq31wb378j7ip8"; + }) + (fetchNuGet { + pname = "runtime.any.System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "03mnvkhskbzxddz4hm113zsch1jyzh2cs450dk3rgfjp8crlw1va"; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "16rnxzpk5dpbbl1x354yrlsbvwylrq456xzpsha1n9y3glnhyx9d"; + }) + (fetchNuGet { + pname = "runtime.debian.8-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0rwpqngkqiapqc5c2cpkj7idhngrgss5qpnqg0yh40mbyflcxf8i"; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0hkg03sgm2wyq8nqk6dbm9jh5vcq57ry42lkqdmfklrw89lsmr59"; + }) + (fetchNuGet { + pname = "runtime.fedora.23-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1n06gxwlinhs0w7s8a94r1q3lwqzvynxwd3mp10ws9bg6gck8n4r"; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0c2p354hjx58xhhz7wv6div8xpi90sc6ibdm40qin21bvi7ymcaa"; + }) + (fetchNuGet { + pname = "runtime.fedora.24-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0404wqrc7f2yc0wxv71y3nnybvqx8v4j9d47hlscxy759a525mc3"; + }) + (fetchNuGet { + pname = "runtime.native.System"; + version = "4.3.0"; + sha256 = "15hgf6zaq9b8br2wi1i3x0zvmk410nlmsmva9p0bbg73v6hml5k4"; + }) + (fetchNuGet { + pname = "runtime.native.System.Net.Http"; + version = "4.3.0"; + sha256 = "1n6rgz5132lcibbch1qlf0g9jk60r0kqv087hxc0lisy50zpm7kk"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + sha256 = "1b61p6gw1m02cc1ry996fl49liiwky6181dzr873g9ds92zl326q"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "18pzfdlwsg2nb1jjjjzyb5qlgy6xjxzmhnfaijq5s2jw3cm3ab97"; + }) + (fetchNuGet { + pname = "runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0zy5r25jppz48i2bkg8b9lfig24xixg6nm3xyr1379zdnqnpm8f6"; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0qyynf9nz5i7pc26cwhgi8j62ps27sqmf78ijcfgzab50z9g8ay3"; + }) + (fetchNuGet { + pname = "runtime.opensuse.13.2-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "096ch4n4s8k82xga80lfmpimpzahd2ip1mgwdqgar0ywbbl6x438"; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "1klrs545awhayryma6l7g2pvnp9xy4z0r1i40r80zb45q3i9nbyf"; + }) + (fetchNuGet { + pname = "runtime.opensuse.42.1-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1dm8fifl7rf1gy7lnwln78ch4rw54g0pl5g1c189vawavll7p6rj"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.Apple"; + version = "4.3.0"; + sha256 = "10yc8jdrwgcl44b4g93f1ds76b176bajd3zqi2faf5rvh1vy9smi"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0zcxjv5pckplvkg0r6mw3asggm7aqzbdjimhvsasb0cgm59x09l3"; + }) + (fetchNuGet { + pname = "runtime.osx.10.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1m9z1k9kzva9n9kwinqxl97x2vgl79qhqjlv17k9s2ymcyv2bwr6"; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0vhynn79ih7hw7cwjazn87rm9z9fj0rvxgzlab36jybgcpcgphsn"; + }) + (fetchNuGet { + pname = "runtime.rhel.7-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1cpx56mcfxz7cpn57wvj18sjisvzq8b5vd9rw16ihd2i6mcp3wa1"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "160p68l2c7cqmyqjwxydcvgw7lvl1cr0znkw8fp24d1by9mqc8p3"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.14.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "15gsm1a8jdmgmf8j5v1slfz8ks124nfdhk2vxs2rw3asrxalg8hi"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "15zrc8fgd8zx28hdghcj5f5i34wf3l6bq5177075m2bc2j34jrqy"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.04-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "0q0n5q1r1wnqmr5i5idsrd9ywl33k0js4pngkwq9p368mbxp8x1w"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "1p4dgxax6p7rlgj4q73k73rslcnz4wdcv8q2flg1s8ygwcm58ld5"; + }) + (fetchNuGet { + pname = "runtime.ubuntu.16.10-x64.runtime.native.System.Security.Cryptography.OpenSsl"; + version = "4.3.2"; + sha256 = "1x0g58pbpjrmj2x2qw17rdwwnrcl0wvim2hdwz48lixvwvp22n9c"; + }) + (fetchNuGet { + pname = "runtime.unix.Microsoft.Win32.Primitives"; + version = "4.3.0"; + sha256 = "0y61k9zbxhdi0glg154v30kkq7f8646nif8lnnxbvkjpakggd5id"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "1lps7fbnw34bnh3lm31gs5c0g0dh7548wfmb8zz62v0zqz71msj5"; + }) + (fetchNuGet { + pname = "runtime.unix.System.IO.FileSystem"; + version = "4.3.0"; + sha256 = "14nbkhvs7sji5r1saj2x8daz82rnf9kx28d3v2qss34qbr32dzix"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Net.Primitives"; + version = "4.3.0"; + sha256 = "0bdnglg59pzx9394sy4ic66kmxhqp8q8bvmykdxcbs5mm0ipwwm4"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Private.Uri"; + version = "4.3.0"; + sha256 = "1jx02q6kiwlvfksq1q9qr17fj78y5v6mwsszav4qcz9z25d5g6vk"; + }) + (fetchNuGet { + pname = "runtime.unix.System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "0pnxxmm8whx38dp6yvwgmh22smknxmqs5n513fc7m4wxvs1bvi4p"; + }) + (fetchNuGet { + pname = "Serilog"; + version = "2.0.0"; + sha256 = "194c39cwribx7p2sic0w8hjmc83194bc985kl7aqpmljfz376gsc"; + }) + (fetchNuGet { + pname = "Serilog"; + version = "2.12.0"; + sha256 = "0lqxpc96qcjkv9pr1rln7mi4y7n7jdi4vb36c2fv3845w1vswgr4"; + }) + (fetchNuGet { + pname = "Serilog.Enrichers.Process"; + version = "2.0.2"; + sha256 = "0wivpxljx5s2vh9rw0h8g64siaq3ajm6rpg6y8v3qnxfmlhlas6s"; + }) + (fetchNuGet { + pname = "Serilog.Enrichers.Thread"; + version = "3.1.0"; + sha256 = "1y75aiv2k1sxnh012ixkx92fq1yl8srqggy8l439igg4p223hcqi"; + }) + (fetchNuGet { + pname = "Serilog.Expressions"; + version = "3.4.0"; + sha256 = "10knpl8nnxmksbsq3l7p486kq1n5y5kn8ibvcscmcig6wxhcw05h"; + }) + (fetchNuGet { + pname = "Serilog.Extensions.Logging"; + version = "3.1.0"; + sha256 = "0lv370ks2fjdn1nsgkbzbmw6hybnincw3jabr471a5w39pp4fl1c"; + }) + (fetchNuGet { + pname = "Serilog.Filters.Expressions"; + version = "2.1.0"; + sha256 = "0pwlcisijbkdhgab2k4vwjqimminxnkzgdrxvq7pz5ba2brsy28l"; + }) + (fetchNuGet { + pname = "Serilog.Settings.Configuration"; + version = "3.4.0"; + sha256 = "1l6fyy9y5a168i1mm107aqyrwzhqmpy0cp1v13l2b89yv8dc105j"; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Async"; + version = "1.5.0"; + sha256 = "0bcb3n6lmg5wfj806mziybfmbb8gyiszrivs3swf0msy8w505gyg"; + }) + (fetchNuGet { + pname = "Serilog.Sinks.Console"; + version = "4.1.0"; + sha256 = "1rpkphmqfh3bv3m7v1zwz88wz4sirj4xqyff9ga0c6bqhblj6wii"; + }) + (fetchNuGet { + pname = "Serilog.Sinks.File"; + version = "5.0.0"; + sha256 = "097rngmgcrdfy7jy8j7dq3xaq2qky8ijwg0ws6bfv5lx0f3vvb0q"; + }) + (fetchNuGet { + pname = "Serilog.Sinks.InMemory"; + version = "0.11.0"; + sha256 = "0kmnj3wx1hwxvgp06avn2zw1mzsfjamrgpaav44ir40100g4hdkd"; + }) + (fetchNuGet { + pname = "Serilog.Sinks.TextWriter"; + version = "2.1.0"; + sha256 = "0p13m8spj6psybwdw21gjaxw854va8n6m2rbdy0w78q135br1kcd"; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.bundle_e_sqlite3"; + version = "2.1.2"; + sha256 = "07rc4pj3rphi8nhzkcvilnm0fv27qcdp68jdwk4g0zjk7yfvbcay"; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.core"; + version = "2.1.2"; + sha256 = "19hxv895lairrjmk4gkzd3mcb6b0na45xn4n551h4kckplqadg3d"; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.lib.e_sqlite3"; + version = "2.1.2"; + sha256 = "0jn98bkjk8h4smi09z31ib6s6392054lwmkziqmkqf5gf614k2fz"; + }) + (fetchNuGet { + pname = "SQLitePCLRaw.provider.e_sqlite3"; + version = "2.1.2"; + sha256 = "0bnm2fhvcsyg5ry74gal2cziqnyf5a8d2cb491vsa7j41hbbx7kv"; + }) + (fetchNuGet { + pname = "Superpower"; + version = "2.3.0"; + sha256 = "0bdsc3c0d6jb0wr67siqfba0ldl0jxbwis6xr0whzqzf6m2cyahm"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.3.0"; + sha256 = "0fgns20ispwrfqll4q1zc1waqcmylb3zc50ys9x8zlwxh9pmd9jy"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.0"; + sha256 = "1ywfqn4md6g3iilpxjn5dsr0f5lx6z0yvhqp4pgjcamygg73cz2c"; + }) + (fetchNuGet { + pname = "System.Buffers"; + version = "4.5.1"; + sha256 = "04kb1mdrlcixj9zh1xdi5as0k0qi8byr5mi3p3jcxx72qz93s2y3"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.0.11"; + sha256 = "1ga40f5lrwldiyw6vy67d0sg7jd7ww6kgwbksm19wrvq9hr0bsm6"; + }) + (fetchNuGet { + pname = "System.Collections"; + version = "4.3.0"; + sha256 = "19r4y64dqyrq6k4706dnyhhw7fs24kpp3awak7whzss39dakpxk9"; + }) + (fetchNuGet { + pname = "System.Collections.Concurrent"; + version = "4.3.0"; + sha256 = "0wi10md9aq33jrkh2c24wr2n9hrpyamsdhsxdcnf43b7y86kkii8"; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "6.0.0"; + sha256 = "1js98kmjn47ivcvkjqdmyipzknb9xbndssczm8gq224pbaj1p88c"; + }) + (fetchNuGet { + pname = "System.ComponentModel.Composition"; + version = "6.0.0"; + sha256 = "16zfx5mivkkykp76krw8x68izmjf79ldfmn26k9x3m55lmp9i77c"; + }) + (fetchNuGet { + pname = "System.Configuration.ConfigurationManager"; + version = "6.0.0"; + sha256 = "0sqapr697jbb4ljkq46msg0xx1qpmc31ivva6llyz2wzq3mpmxbw"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.0.11"; + sha256 = "0gmjghrqmlgzxivd2xl50ncbglb7ljzb66rlx8ws6dv8jm0d5siz"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Debug"; + version = "4.3.0"; + sha256 = "00yjlf19wjydyr6cfviaph3vsjzg3d5nvnya26i2fvfg53sknh3y"; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "4.3.0"; + sha256 = "0z6m3pbiy0qw6rn3n209rrzf9x1k4002zh90vwcrsym09ipm2liq"; + }) + (fetchNuGet { + pname = "System.Diagnostics.DiagnosticSource"; + version = "7.0.0"; + sha256 = "1jxhvsh5mzdf0sgb4dfmbys1b12ylyr5pcfyj1map354fiq3qsgm"; + }) + (fetchNuGet { + pname = "System.Diagnostics.PerformanceCounter"; + version = "6.0.1"; + sha256 = "17p5vwbgrycsrvv9a9ksxbiziy75x4s25dw71fnbw1ci5kpp8yz7"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tools"; + version = "4.0.1"; + sha256 = "19cknvg07yhakcvpxg3cxa0bwadplin6kyxd8mpjjpwnp56nl85x"; + }) + (fetchNuGet { + pname = "System.Diagnostics.Tracing"; + version = "4.3.0"; + sha256 = "1m3bx6c2s958qligl67q7grkwfz3w53hpy7nc97mh6f7j5k168c4"; + }) + (fetchNuGet { + pname = "System.Drawing.Common"; + version = "6.0.0"; + sha256 = "02n8rzm58dac2np8b3xw8ychbvylja4nh6938l5k2fhyn40imlgz"; + }) + (fetchNuGet { + pname = "System.Dynamic.Runtime"; + version = "4.0.11"; + sha256 = "1pla2dx8gkidf7xkciig6nifdsb494axjvzvann8g2lp3dbqasm9"; + }) + (fetchNuGet { + pname = "System.Formats.Asn1"; + version = "7.0.0"; + sha256 = "1a14kgpqz4k7jhi7bs2gpgf67ym5wpj99203zxgwjypj7x47xhbq"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.0.11"; + sha256 = "070c5jbas2v7smm660zaf1gh0489xanjqymkvafcs4f8cdrs1d5d"; + }) + (fetchNuGet { + pname = "System.Globalization"; + version = "4.3.0"; + sha256 = "1cp68vv683n6ic2zqh2s1fn4c2sd87g5hpp6l4d4nj4536jz98ki"; + }) + (fetchNuGet { + pname = "System.Globalization.Calendars"; + version = "4.3.0"; + sha256 = "1xwl230bkakzzkrggy1l1lxmm3xlhk4bq2pkv790j5lm8g887lxq"; + }) + (fetchNuGet { + pname = "System.Globalization.Extensions"; + version = "4.3.0"; + sha256 = "02a5zfxavhv3jd437bsncbhd2fp1zv4gxzakp1an9l6kdq1mcqls"; + }) + (fetchNuGet { + pname = "System.Interactive.Async"; + version = "5.0.0"; + sha256 = "00flf80ahpyhrsny2kfl9bsyh1mxmsdsigpq3rzhaps9wgdbmzjz"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.1.0"; + sha256 = "1g0yb8p11vfd0kbkyzlfsbsp5z44lwsvyc0h3dpw6vqnbi035ajp"; + }) + (fetchNuGet { + pname = "System.IO"; + version = "4.3.0"; + sha256 = "05l9qdrzhm4s5dixmx68kxwif4l99ll5gqmh7rqgw554fx0agv5f"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.0.1"; + sha256 = "0kgfpw6w4djqra3w5crrg8xivbanh1w9dh3qapb28q060wb9flp1"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem"; + version = "4.3.0"; + sha256 = "0z2dfrbra9i6y16mm9v1v6k47f0fm617vlb7s5iybjjsz6g1ilmw"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.0.1"; + sha256 = "1s0mniajj3lvbyf7vfb5shp4ink5yibsx945k6lvxa96r8la1612"; + }) + (fetchNuGet { + pname = "System.IO.FileSystem.Primitives"; + version = "4.3.0"; + sha256 = "0j6ndgglcf4brg2lz4wzsh1av1gh8xrzdsn9f0yznskhqn1xzj9c"; + }) + (fetchNuGet { + pname = "System.IO.Pipelines"; + version = "6.0.3"; + sha256 = "1jgdazpmwc21dd9naq3l9n5s8a1jnbwlvgkf1pnm0aji6jd4xqdz"; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.1.0"; + sha256 = "1ppg83svb39hj4hpp5k7kcryzrf3sfnm08vxd5sm2drrijsla2k5"; + }) + (fetchNuGet { + pname = "System.Linq"; + version = "4.3.0"; + sha256 = "1w0gmba695rbr80l1k2h4mrwzbzsyfl2z4klmpbsvsg5pm4a56s7"; + }) + (fetchNuGet { + pname = "System.Linq.Async"; + version = "6.0.1"; + sha256 = "10ira8hmv0i54yp9ggrrdm1c06j538sijfjpn1kmnh9j2xk5yzmq"; + }) + (fetchNuGet { + pname = "System.Linq.Expressions"; + version = "4.1.0"; + sha256 = "1gpdxl6ip06cnab7n3zlcg6mqp7kknf73s8wjinzi4p0apw82fpg"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.0"; + sha256 = "1layqpcx1q4l805fdnj2dfqp6ncx2z42ca06rgsr6ikq4jjgbv30"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.1"; + sha256 = "0f07d7hny38lq9w69wx4lxkn4wszrqf9m9js6fh9is645csm167c"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.3"; + sha256 = "0naqahm3wljxb5a911d37mwjqjdxv9l0b49p5dmfyijvni2ppy8a"; + }) + (fetchNuGet { + pname = "System.Memory"; + version = "4.5.4"; + sha256 = "14gbbs22mcxwggn0fcfs1b062521azb9fbb7c113x0mq6dzq9h6y"; + }) + (fetchNuGet { + pname = "System.Net.Http"; + version = "4.3.4"; + sha256 = "0kdp31b8819v88l719j6my0yas6myv9d1viql3qz5577mv819jhl"; + }) + (fetchNuGet { + pname = "System.Net.Primitives"; + version = "4.3.0"; + sha256 = "0c87k50rmdgmxx7df2khd9qj7q35j9rzdmm2572cc55dygmdk3ii"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.4.0"; + sha256 = "0rdvma399070b0i46c4qq1h2yvjj3k013sqzkilz4bz5cwmx1rba"; + }) + (fetchNuGet { + pname = "System.Numerics.Vectors"; + version = "4.5.0"; + sha256 = "1kzrj37yzawf1b19jq0253rcs8hsq1l2q8g69d7ipnhzb0h97m59"; + }) + (fetchNuGet { + pname = "System.ObjectModel"; + version = "4.0.12"; + sha256 = "1sybkfi60a4588xn34nd9a58png36i0xr4y4v4kqpg8wlvy5krrj"; + }) + (fetchNuGet { + pname = "System.Private.ServiceModel"; + version = "4.10.0"; + sha256 = "0048hmv4j4wfpa9hwn8d5l3ag3hwmhp5r26iarfbsxj0q3i2d1a8"; + }) + (fetchNuGet { + pname = "System.Private.ServiceModel"; + version = "4.5.3"; + sha256 = "0nyw9m9dj327hn0qb0jmgwpch0f40jv301fk4mrchga8g99xbpng"; + }) + (fetchNuGet { + pname = "System.Private.Uri"; + version = "4.3.0"; + sha256 = "04r1lkdnsznin0fj4ya1zikxiqr0h6r6a1ww2dsm60gqhdrf0mvx"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.1.0"; + sha256 = "1js89429pfw79mxvbzp8p3q93il6rdff332hddhzi5wqglc4gml9"; + }) + (fetchNuGet { + pname = "System.Reflection"; + version = "4.3.0"; + sha256 = "0xl55k0mw8cd8ra6dxzh974nxif58s3k1rjv1vbd7gjbjr39j11m"; + }) + (fetchNuGet { + pname = "System.Reflection.DispatchProxy"; + version = "4.5.0"; + sha256 = "0v9sg38h91aljvjyc77m1y5v34p50hjdbxvvxwa1whlajhafadcn"; + }) + (fetchNuGet { + pname = "System.Reflection.DispatchProxy"; + version = "4.7.1"; + sha256 = "10yh3q2i71gcw7c0dfz9qxql2vlvnqjav1hyf1q9rpbvdbgsabrs"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit"; + version = "4.0.1"; + sha256 = "0ydqcsvh6smi41gyaakglnv252625hf29f7kywy2c70nhii2ylqp"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.ILGeneration"; + version = "4.0.1"; + sha256 = "1pcd2ig6bg144y10w7yxgc9d22r7c7ww7qn1frdfwgxr24j9wvv0"; + }) + (fetchNuGet { + pname = "System.Reflection.Emit.Lightweight"; + version = "4.0.1"; + sha256 = "1s4b043zdbx9k39lfhvsk68msv1nxbidhkq6nbm27q7sf8xcsnxr"; + }) + (fetchNuGet { + pname = "System.Reflection.Extensions"; + version = "4.0.1"; + sha256 = "0m7wqwq0zqq9gbpiqvgk3sr92cbrw7cp3xn53xvw7zj6rz6fdirn"; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "1.6.0"; + sha256 = "1wdbavrrkajy7qbdblpbpbalbdl48q3h34cchz24gvdgyrlf15r4"; + }) + (fetchNuGet { + pname = "System.Reflection.Metadata"; + version = "5.0.0"; + sha256 = "17qsl5nanlqk9iz0l5wijdn6ka632fs1m1fvx18dfgswm258r3ss"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.0.1"; + sha256 = "1bangaabhsl4k9fg8khn83wm6yial8ik1sza7401621jc6jrym28"; + }) + (fetchNuGet { + pname = "System.Reflection.Primitives"; + version = "4.3.0"; + sha256 = "04xqa33bld78yv5r93a8n76shvc8wwcdgr1qvvjh959g3rc31276"; + }) + (fetchNuGet { + pname = "System.Reflection.TypeExtensions"; + version = "4.1.0"; + sha256 = "1bjli8a7sc7jlxqgcagl9nh8axzfl11f4ld3rjqsyxc516iijij7"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.0.1"; + sha256 = "0b4i7mncaf8cnai85jv3wnw6hps140cxz8vylv2bik6wyzgvz7bi"; + }) + (fetchNuGet { + pname = "System.Resources.ResourceManager"; + version = "4.3.0"; + sha256 = "0sjqlzsryb0mg4y4xzf35xi523s4is4hz9q4qgdvlvgivl7qxn49"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.1.0"; + sha256 = "02hdkgk13rvsd6r9yafbwzss8kr55wnj8d5c7xjnp8gqrwc8sn0m"; + }) + (fetchNuGet { + pname = "System.Runtime"; + version = "4.3.0"; + sha256 = "066ixvgbf2c929kgknshcxqj6539ax7b9m570cp8n179cpfkapz7"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.4.0"; + sha256 = "0a6ahgi5b148sl5qyfpyw383p3cb4yrkm802k29fsi4mxkiwir29"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.0"; + sha256 = "17labczwqk3jng3kkky73m0jhi8wc21vbl7cz5c0hj2p1dswin43"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "4.5.1"; + sha256 = "1xcrjx5fwg284qdnxyi2d0lzdm5q4frlpkp0nf6vvkx1kdz2prrf"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "5.0.0"; + sha256 = "02k25ivn50dmqx5jn8hawwmz24yf0454fjd823qk6lygj9513q4x"; + }) + (fetchNuGet { + pname = "System.Runtime.CompilerServices.Unsafe"; + version = "6.0.0"; + sha256 = "0qm741kh4rh57wky16sq4m0v05fxmkjjr87krycf5vp9f0zbahbc"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.1.0"; + sha256 = "0rw4rm4vsm3h3szxp9iijc3ksyviwsv6f63dng3vhqyg4vjdkc2z"; + }) + (fetchNuGet { + pname = "System.Runtime.Extensions"; + version = "4.3.0"; + sha256 = "1ykp3dnhwvm48nap8q23893hagf665k0kn3cbgsqpwzbijdcgc60"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.0.1"; + sha256 = "1g0zrdi5508v49pfm3iii2hn6nm00bgvfpjq1zxknfjrxxa20r4g"; + }) + (fetchNuGet { + pname = "System.Runtime.Handles"; + version = "4.3.0"; + sha256 = "0sw2gfj2xr7sw9qjn0j3l9yw07x73lcs97p8xfc9w1x9h5g5m7i8"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.1.0"; + sha256 = "01kxqppx3dr3b6b286xafqilv4s2n0gqvfgzfd4z943ga9i81is1"; + }) + (fetchNuGet { + pname = "System.Runtime.InteropServices"; + version = "4.3.0"; + sha256 = "00hywrn4g7hva1b2qri2s6rabzwgxnbpw9zfxmz28z09cpwwgh7j"; + }) + (fetchNuGet { + pname = "System.Runtime.Numerics"; + version = "4.3.0"; + sha256 = "19rav39sr5dky7afygh309qamqqmi9kcwvz3i0c5700v0c5cg61z"; + }) + (fetchNuGet { + pname = "System.Runtime.Serialization.Primitives"; + version = "4.1.1"; + sha256 = "042rfjixknlr6r10vx2pgf56yming8lkjikamg3g4v29ikk78h7k"; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "6.0.0"; + sha256 = "0a678bzj8yxxiffyzy60z2w1nczzpi8v97igr4ip3byd2q89dv58"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Algorithms"; + version = "4.3.0"; + sha256 = "03sq183pfl5kp7gkvq77myv7kbpdnq3y0xj7vi4q1kaw54sny0ml"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Cng"; + version = "4.3.0"; + sha256 = "1k468aswafdgf56ab6yrn7649kfqx2wm9aslywjam1hdmk5yypmv"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Csp"; + version = "4.3.0"; + sha256 = "1x5wcrddf2s3hb8j78cry7yalca4lb5vfnkrysagbn6r9x6xvrx1"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Encoding"; + version = "4.3.0"; + sha256 = "1jr6w70igqn07k5zs1ph6xja97hxnb3mqbspdrff6cvssgrixs32"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.OpenSsl"; + version = "4.3.0"; + sha256 = "0givpvvj8yc7gv4lhb6s1prq6p2c4147204a0wib89inqzd87gqc"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Pkcs"; + version = "7.0.2"; + sha256 = "0px6snb8gdb6mpwsqrhlpbkmjgd63h4yamqm2gvyf9rwibymjbm9"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Primitives"; + version = "4.3.0"; + sha256 = "0pyzncsv48zwly3lw4f2dayqswcfvdwq2nz0dgwmi7fj3pn64wby"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.ProtectedData"; + version = "6.0.0"; + sha256 = "05kd3a8w7658hjxq9vvszxip30a479fjmfq4bq1r95nrsvs4hbss"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.X509Certificates"; + version = "4.3.0"; + sha256 = "0valjcz5wksbvijylxijjxb1mp38mdhv03r533vnx1q3ikzdav9h"; + }) + (fetchNuGet { + pname = "System.Security.Cryptography.Xml"; + version = "7.0.1"; + sha256 = "0p6kx6ag0il7rxxcvm84w141phvr7fafjzxybf920bxwa0jkwzq8"; + }) + (fetchNuGet { + pname = "System.Security.Permissions"; + version = "6.0.0"; + sha256 = "0jsl4xdrkqi11iwmisi1r2f2qn5pbvl79mzq877gndw6ans2zhzw"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "4.5.0"; + sha256 = "0rmj89wsl5yzwh0kqjgx45vzf694v9p92r4x4q6yxldk1cv1hi86"; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + sha256 = "1mpk7xj76lxgz97a5yg93wi8lj0l8p157a5d50mmjy3gbz1904q8"; + }) + (fetchNuGet { + pname = "System.ServiceModel.Http"; + version = "4.10.0"; + sha256 = "1b6dzgrj5ybpr21zh1gnmzbmx7k3xsc53ksmv8ilhj717gpvaz9d"; + }) + (fetchNuGet { + pname = "System.ServiceModel.Primitives"; + version = "4.10.0"; + sha256 = "1a1b0li9g7nhmy7r850nprpihkpfhw9gscfbgl38xzyr9crd236w"; + }) + (fetchNuGet { + pname = "System.ServiceModel.Primitives"; + version = "4.5.3"; + sha256 = "1v90pci049cn44y0km885k1vrilhb34w6q2zva4y6f3ay84klrih"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.0.11"; + sha256 = "1dyqv0hijg265dwxg6l7aiv74102d6xjiwplh2ar1ly6xfaa4iiw"; + }) + (fetchNuGet { + pname = "System.Text.Encoding"; + version = "4.3.0"; + sha256 = "1f04lkir4iladpp51sdgmis9dj4y8v08cka0mbmsy0frc9a4gjqr"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.CodePages"; + version = "6.0.0"; + sha256 = "0gm2kiz2ndm9xyzxgi0jhazgwslcs427waxgfa30m7yqll1kcrww"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.0.11"; + sha256 = "08nsfrpiwsg9x5ml4xyl3zyvjfdi4mvbqf93kjdh11j4fwkznizs"; + }) + (fetchNuGet { + pname = "System.Text.Encoding.Extensions"; + version = "4.3.0"; + sha256 = "11q1y8hh5hrp5a3kw25cb6l00v5l5dvirkz8jr3sq00h1xgcgrxy"; + }) + (fetchNuGet { + pname = "System.Text.Encodings.Web"; + version = "6.0.0"; + sha256 = "06n9ql3fmhpjl32g3492sj181zjml5dlcc5l76xq2h38c4f87sai"; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "4.6.0"; + sha256 = "0ism236hwi0k6axssfq58s1d8lihplwiz058pdvl8al71hagri39"; + }) + (fetchNuGet { + pname = "System.Text.Json"; + version = "6.0.0"; + sha256 = "1si2my1g0q0qv1hiqnji4xh9wd05qavxnzj9dwgs23iqvgjky0gl"; + }) + (fetchNuGet { + pname = "System.Text.RegularExpressions"; + version = "4.1.0"; + sha256 = "1mw7vfkkyd04yn2fbhm38msk7dz2xwvib14ygjsb8dq2lcvr18y7"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.0.11"; + sha256 = "19x946h926bzvbsgj28csn46gak2crv2skpwsx80hbgazmkgb1ls"; + }) + (fetchNuGet { + pname = "System.Threading"; + version = "4.3.0"; + sha256 = "0rw9wfamvhayp5zh3j7p1yfmx9b5khbf4q50d8k5rk993rskfd34"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.0.11"; + sha256 = "0nr1r41rak82qfa5m0lhk9mp0k93bvfd7bbd9sdzwx9mb36g28p5"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks"; + version = "4.3.0"; + sha256 = "134z3v9abw3a6jsw17xl3f6hqjpak5l682k2vz39spj4kmydg6k7"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.0.0"; + sha256 = "1cb51z062mvc2i8blpzmpn9d9mm4y307xrwi65di8ri18cz5r1zr"; + }) + (fetchNuGet { + pname = "System.Threading.Tasks.Extensions"; + version = "4.5.4"; + sha256 = "0y6ncasgfcgnjrhynaf0lwpkpkmv4a07sswwkwbwb5h7riisj153"; + }) + (fetchNuGet { + pname = "System.Windows.Extensions"; + version = "6.0.0"; + sha256 = "1wy9pq9vn1bqg5qnv53iqrbx04yzdmjw4x5yyi09y3459vaa1sip"; + }) + (fetchNuGet { + pname = "System.Xml.ReaderWriter"; + version = "4.0.11"; + sha256 = "0c6ky1jk5ada9m94wcadih98l6k1fvf6vi7vhn1msjixaha419l5"; + }) + (fetchNuGet { + pname = "System.Xml.XDocument"; + version = "4.0.11"; + sha256 = "0n4lvpqzy9kc7qy1a4acwwd7b7pnvygv895az5640idl2y9zbz18"; + }) + (fetchNuGet { + pname = "YamlDotNet"; + version = "12.0.1"; + sha256 = "0axlq2xm3lb8kq24b0fsi5yg3gm63fjsy30xkxwngnnx7wd75y2y"; + }) ] diff --git a/pkgs/servers/nosql/influxdb/default.nix b/pkgs/servers/nosql/influxdb/default.nix index 384958624611ab..030590dabe0c8f 100644 --- a/pkgs/servers/nosql/influxdb/default.nix +++ b/pkgs/servers/nosql/influxdb/default.nix @@ -1,4 +1,14 @@ -{ lib, buildGoModule, fetchFromGitHub, stdenv, pkg-config, rustPlatform, libiconv, fetchpatch, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + stdenv, + pkg-config, + rustPlatform, + libiconv, + fetchpatch, + nixosTests, +}: let libflux_version = "0.194.5"; @@ -37,14 +47,16 @@ let Libs: -L/out/lib -lflux -lpthread ''; passAsFile = [ "pkgcfg" ]; - postInstall = '' - mkdir -p $out/include $out/pkgconfig - cp -r $NIX_BUILD_TOP/source/libflux/include/influxdata $out/include - substitute $pkgcfgPath $out/pkgconfig/flux.pc \ - --replace /out $out - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install_name_tool -id $out/lib/libflux.dylib $out/lib/libflux.dylib - ''; + postInstall = + '' + mkdir -p $out/include $out/pkgconfig + cp -r $NIX_BUILD_TOP/source/libflux/include/influxdata $out/include + substitute $pkgcfgPath $out/pkgconfig/flux.pc \ + --replace /out $out + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install_name_tool -id $out/lib/libflux.dylib $out/lib/libflux.dylib + ''; }; in buildGoModule rec { @@ -75,7 +87,11 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; excludedPackages = "test"; @@ -85,6 +101,9 @@ buildGoModule rec { description = "Open-source distributed time series database"; license = licenses.mit; homepage = "https://influxdata.com/"; - maintainers = with maintainers; [ offline zimbatm ]; + maintainers = with maintainers; [ + offline + zimbatm + ]; }; } diff --git a/pkgs/servers/nosql/influxdb2/cli.nix b/pkgs/servers/nosql/influxdb2/cli.nix index f00f09a96aa13e..85b3e910b69698 100644 --- a/pkgs/servers/nosql/influxdb2/cli.nix +++ b/pkgs/servers/nosql/influxdb2/cli.nix @@ -1,8 +1,9 @@ -{ buildGoModule -, fetchFromGitHub -, installShellFiles -, lib -, stdenv +{ + buildGoModule, + fetchFromGitHub, + installShellFiles, + lib, + stdenv, }: let @@ -15,7 +16,8 @@ let sha256 = "sha256-0Gyoy9T5pA+40k8kKybWBMtOfpKZxw3Vvp4ZB4ptcJs="; }; -in buildGoModule { +in +buildGoModule { pname = "influx-cli"; version = version; inherit src; @@ -25,7 +27,10 @@ in buildGoModule { vendorHash = "sha256-Ov0TPoMm0qi7kkWUUni677sCP1LwkT9+n3KHcAlQkDA="; subPackages = [ "cmd/influx" ]; - ldflags = [ "-X main.commit=v${version}" "-X main.version=${version}" ]; + ldflags = [ + "-X main.commit=v${version}" + "-X main.version=${version}" + ]; postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' installShellCompletion --cmd influx \ diff --git a/pkgs/servers/nosql/influxdb2/default.nix b/pkgs/servers/nosql/influxdb2/default.nix index 99ae9bc38c2bf5..56277135f041d4 100644 --- a/pkgs/servers/nosql/influxdb2/default.nix +++ b/pkgs/servers/nosql/influxdb2/default.nix @@ -1,15 +1,16 @@ -{ buildGoModule -, fetchFromGitHub -, fetchurl -, fetchpatch -, go-bindata -, lib -, perl -, pkg-config -, rustPlatform -, stdenv -, libiconv -, nixosTests +{ + buildGoModule, + fetchFromGitHub, + fetchurl, + fetchpatch, + go-bindata, + lib, + perl, + pkg-config, + rustPlatform, + stdenv, + libiconv, + nixosTests, }: let @@ -62,25 +63,35 @@ let Libs: -L/out/lib -lflux -lpthread ''; passAsFile = [ "pkgcfg" ]; - postInstall = '' - mkdir -p $out/include $out/pkgconfig - cp -r $NIX_BUILD_TOP/source/libflux/include/influxdata $out/include - substitute $pkgcfgPath $out/pkgconfig/flux.pc \ - --replace /out $out - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install_name_tool -id $out/lib/libflux.dylib $out/lib/libflux.dylib - ''; + postInstall = + '' + mkdir -p $out/include $out/pkgconfig + cp -r $NIX_BUILD_TOP/source/libflux/include/influxdata $out/include + substitute $pkgcfgPath $out/pkgconfig/flux.pc \ + --replace /out $out + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install_name_tool -id $out/lib/libflux.dylib $out/lib/libflux.dylib + ''; }; -in buildGoModule { +in +buildGoModule { pname = "influxdb"; version = version; inherit src; - nativeBuildInputs = [ go-bindata pkg-config perl ]; + nativeBuildInputs = [ + go-bindata + pkg-config + perl + ]; vendorHash = "sha256-3Vf8BCrOwliXrH+gmZ4RJ1YBEbqL0Szx2prW3ie9CNg="; - subPackages = [ "cmd/influxd" "cmd/telemetryd" ]; + subPackages = [ + "cmd/influxd" + "cmd/telemetryd" + ]; PKG_CONFIG_PATH = "${flux}/pkgconfig"; @@ -116,7 +127,10 @@ in buildGoModule { tags = [ "assets" ]; - ldflags = [ "-X main.commit=v${version}" "-X main.version=${version}" ]; + ldflags = [ + "-X main.commit=v${version}" + "-X main.version=${version}" + ]; passthru.tests = { inherit (nixosTests) influxdb2; }; diff --git a/pkgs/servers/nosql/influxdb2/provision.nix b/pkgs/servers/nosql/influxdb2/provision.nix index 0d0740969cd460..01be841f6a8a88 100644 --- a/pkgs/servers/nosql/influxdb2/provision.nix +++ b/pkgs/servers/nosql/influxdb2/provision.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3Packages -, makeWrapper +{ + lib, + stdenv, + fetchFromGitHub, + python3Packages, + makeWrapper, }: stdenv.mkDerivation rec { @@ -17,7 +18,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ python3Packages.python python3Packages.influxdb-client ]; + buildInputs = [ + python3Packages.python + python3Packages.influxdb-client + ]; installPhase = '' install -Dm0555 influxdb2-provision.py $out/bin/influxdb2-provision @@ -28,7 +32,7 @@ stdenv.mkDerivation rec { description = "Small utility to help provisioning influxdb2"; homepage = "https://github.com/oddlama/influxdb2-provision"; license = licenses.mit; - maintainers = with maintainers; [oddlama]; + maintainers = with maintainers; [ oddlama ]; mainProgram = "influxdb2-provision"; }; } diff --git a/pkgs/servers/nosql/influxdb2/token-manipulator.nix b/pkgs/servers/nosql/influxdb2/token-manipulator.nix index 88713941b465dc..12db726fdb56d5 100644 --- a/pkgs/servers/nosql/influxdb2/token-manipulator.nix +++ b/pkgs/servers/nosql/influxdb2/token-manipulator.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, fetchFromGitHub -, lib +{ + buildGoModule, + fetchFromGitHub, + lib, }: buildGoModule rec { @@ -20,7 +21,7 @@ buildGoModule rec { description = "Utility program to manipulate influxdb api tokens for declarative setups"; homepage = "https://github.com/oddlama/influxdb2-token-manipulator"; license = licenses.mit; - maintainers = with maintainers; [oddlama]; + maintainers = with maintainers; [ oddlama ]; mainProgram = "influxdb2-token-manipulator"; }; } diff --git a/pkgs/servers/nosql/mongodb/6.0.nix b/pkgs/servers/nosql/mongodb/6.0.nix index 1143a4f50b684b..20adcf8b024c60 100644 --- a/pkgs/servers/nosql/mongodb/6.0.nix +++ b/pkgs/servers/nosql/mongodb/6.0.nix @@ -1,11 +1,25 @@ -{ stdenv, callPackage, fetchpatch -, sasl, boost, Security, CoreFoundation, cctools -, avxSupport ? stdenv.hostPlatform.avxSupport +{ + stdenv, + callPackage, + fetchpatch, + sasl, + boost, + Security, + CoreFoundation, + cctools, + avxSupport ? stdenv.hostPlatform.avxSupport, }: let buildMongoDB = callPackage ./mongodb.nix { - inherit sasl boost Security CoreFoundation cctools stdenv; + inherit + sasl + boost + Security + CoreFoundation + cctools + stdenv + ; }; in buildMongoDB { diff --git a/pkgs/servers/nosql/mongodb/mongodb.nix b/pkgs/servers/nosql/mongodb/mongodb.nix index 37fc0a2e8a573d..1d0bda28616973 100644 --- a/pkgs/servers/nosql/mongodb/mongodb.nix +++ b/pkgs/servers/nosql/mongodb/mongodb.nix @@ -1,58 +1,66 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildPackages -, boost -, gperftools -, pcre2 -, pcre-cpp -, snappy -, zlib -, yaml-cpp -, sasl -, net-snmp -, openldap -, openssl -, libpcap -, curl -, Security -, CoreFoundation -, cctools -, xz +{ + lib, + stdenv, + fetchFromGitHub, + buildPackages, + boost, + gperftools, + pcre2, + pcre-cpp, + snappy, + zlib, + yaml-cpp, + sasl, + net-snmp, + openldap, + openssl, + libpcap, + curl, + Security, + CoreFoundation, + cctools, + xz, }: # Note: # The command line administrative tools are part of other packages: # see pkgs.mongodb-tools and pkgs.mongosh. -{ version, sha256, patches ? [] -, license ? lib.licenses.sspl -, avxSupport ? stdenv.hostPlatform.avxSupport -, passthru ? {} +{ + version, + sha256, + patches ? [ ], + license ? lib.licenses.sspl, + avxSupport ? stdenv.hostPlatform.avxSupport, + passthru ? { }, }: let scons = buildPackages.scons; - python = scons.python.withPackages (ps: with ps; [ - pyyaml - cheetah3 - psutil - setuptools - distutils - packaging - pymongo - ]); - - system-libraries = [ - "boost" - "snappy" - "yaml" - "zlib" - #"asio" -- XXX use package? - #"stemmer" -- not nice to package yet (no versioning, no makefile, no shared libs). - #"valgrind" -- mongodb only requires valgrind.h, which is vendored in the source. - #"wiredtiger" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ "tcmalloc" ] + python = scons.python.withPackages ( + ps: with ps; [ + pyyaml + cheetah3 + psutil + setuptools + distutils + packaging + pymongo + ] + ); + + system-libraries = + [ + "boost" + "snappy" + "yaml" + "zlib" + #"asio" -- XXX use package? + #"stemmer" -- not nice to package yet (no versioning, no makefile, no shared libs). + #"valgrind" -- mongodb only requires valgrind.h, which is vendored in the source. + #"wiredtiger" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ "tcmalloc" ] ++ lib.optionals (lib.versionOlder version "7.0") [ "pcre" ] @@ -61,7 +69,8 @@ let ]; inherit (lib) systems subtractLists; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { inherit version passthru; pname = "mongodb"; @@ -77,46 +86,54 @@ in stdenv.mkDerivation rec { python ] ++ lib.optional stdenv.hostPlatform.isLinux net-snmp; - buildInputs = [ - boost - curl - gperftools - libpcap - yaml-cpp - openssl - openldap - pcre2 - pcre-cpp - sasl - snappy - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security CoreFoundation cctools ] - ++ lib.optional stdenv.hostPlatform.isLinux net-snmp - ++ [ xz ]; + buildInputs = + [ + boost + curl + gperftools + libpcap + yaml-cpp + openssl + openldap + pcre2 + pcre-cpp + sasl + snappy + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + CoreFoundation + cctools + ] + ++ lib.optional stdenv.hostPlatform.isLinux net-snmp + ++ [ xz ]; # MongoDB keeps track of its build parameters, which tricks nix into # keeping dependencies to build inputs in the final output. # We remove the build flags from buildInfo data. inherit patches; - postPatch = '' - # fix environment variable reading - substituteInPlace SConstruct \ - --replace "env = Environment(" "env = Environment(ENV = os.environ," - '' + '' - # Fix debug gcc 11 and clang 12 builds on Fedora - # https://github.com/mongodb/mongo/commit/e78b2bf6eaa0c43bd76dbb841add167b443d2bb0.patch - substituteInPlace src/mongo/db/query/plan_summary_stats.h --replace '#include ' '#include - #include ' - substituteInPlace src/mongo/db/exec/plan_stats.h --replace '#include ' '#include - #include ' - '' + lib.optionalString (!avxSupport) '' - substituteInPlace SConstruct \ - --replace-fail "default=['+sandybridge']," 'default=[],' - ''; - - env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang - "-Wno-unused-command-line-argument"; + postPatch = + '' + # fix environment variable reading + substituteInPlace SConstruct \ + --replace "env = Environment(" "env = Environment(ENV = os.environ," + '' + + '' + # Fix debug gcc 11 and clang 12 builds on Fedora + # https://github.com/mongodb/mongo/commit/e78b2bf6eaa0c43bd76dbb841add167b443d2bb0.patch + substituteInPlace src/mongo/db/query/plan_summary_stats.h --replace '#include ' '#include + #include ' + substituteInPlace src/mongo/db/exec/plan_stats.h --replace '#include ' '#include + #include ' + '' + + lib.optionalString (!avxSupport) '' + substituteInPlace SConstruct \ + --replace-fail "default=['+sandybridge']," 'default=[],' + ''; + + env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-unused-command-line-argument"; sconsFlags = [ "--release" @@ -129,20 +146,22 @@ in stdenv.mkDerivation rec { "VARIANT_DIR=nixos" # Needed so we don't produce argument lists that are too long for gcc / ld "--link-model=static" "MONGO_VERSION=${version}" - ] - ++ map (lib: "--use-system-${lib}") system-libraries; + ] ++ map (lib: "--use-system-${lib}") system-libraries; # This seems to fix mongodb not able to find OpenSSL's crypto.h during build hardeningDisable = [ "fortify3" ]; - preBuild = '' - sconsFlags+=" CC=$CC" - sconsFlags+=" CXX=$CXX" - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - sconsFlags+=" AR=$AR" - '' + lib.optionalString stdenv.hostPlatform.isAarch64 '' - sconsFlags+=" CCFLAGS='-march=armv8-a+crc'" - ''; + preBuild = + '' + sconsFlags+=" CC=$CC" + sconsFlags+=" CXX=$CXX" + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + sconsFlags+=" AR=$AR" + '' + + lib.optionalString stdenv.hostPlatform.isAarch64 '' + sconsFlags+=" CCFLAGS='-march=armv8-a+crc'" + ''; preInstall = '' mkdir -p "$out/lib" @@ -172,7 +191,10 @@ in stdenv.mkDerivation rec { homepage = "http://www.mongodb.org"; inherit license; - maintainers = with maintainers; [ bluescreen303 offline ]; + maintainers = with maintainers; [ + bluescreen303 + offline + ]; platforms = subtractLists systems.doubles.i686 systems.doubles.unix; }; } diff --git a/pkgs/servers/nosql/rethinkdb/default.nix b/pkgs/servers/nosql/rethinkdb/default.nix index 03aed49f564b71..686ad7eadc7472 100644 --- a/pkgs/servers/nosql/rethinkdb/default.nix +++ b/pkgs/servers/nosql/rethinkdb/default.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchurl, which, m4 -, protobuf, boost, zlib, curl, openssl, icu, jemalloc, libtool -, python3Packages, makeWrapper +{ + lib, + stdenv, + fetchurl, + which, + m4, + protobuf, + boost, + zlib, + curl, + openssl, + icu, + jemalloc, + libtool, + python3Packages, + makeWrapper, }: stdenv.mkDerivation rec { @@ -30,11 +43,24 @@ stdenv.mkDerivation rec { makeFlags = [ "rethinkdb" ]; - buildInputs = [ protobuf boost zlib curl openssl icu ] + buildInputs = + [ + protobuf + boost + zlib + curl + openssl + icu + ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) jemalloc ++ lib.optional stdenv.hostPlatform.isDarwin libtool; - nativeBuildInputs = [ which m4 python3Packages.python makeWrapper ]; + nativeBuildInputs = [ + which + m4 + python3Packages.python + makeWrapper + ]; enableParallelBuilding = true; @@ -52,9 +78,12 @@ stdenv.mkDerivation rec { query language that supports really useful queries like table joins and group by, and is easy to setup and learn. ''; - homepage = "https://rethinkdb.com"; - license = lib.licenses.asl20; - platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ thoughtpolice bluescreen303 ]; + homepage = "https://rethinkdb.com"; + license = lib.licenses.asl20; + platforms = lib.platforms.unix; + maintainers = with lib.maintainers; [ + thoughtpolice + bluescreen303 + ]; }; } diff --git a/pkgs/servers/ombi/default.nix b/pkgs/servers/ombi/default.nix index a9fb9aa335862a..6487afea694640 100644 --- a/pkgs/servers/ombi/default.nix +++ b/pkgs/servers/ombi/default.nix @@ -1,21 +1,37 @@ -{ lib, stdenv, fetchurl, makeWrapper, autoPatchelfHook, fixDarwinDylibNames, zlib, krb5, openssl, icu, nixosTests }: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + autoPatchelfHook, + fixDarwinDylibNames, + zlib, + krb5, + openssl, + icu, + nixosTests, +}: let os = if stdenv.hostPlatform.isDarwin then "osx" else "linux"; - arch = { - x86_64-linux = "x64"; - aarch64-linux = "arm64"; - x86_64-darwin = "x64"; - }."${stdenv.hostPlatform.system}" or (throw - "Unsupported system: ${stdenv.hostPlatform.system}"); - - hash = { - x64-linux_hash = "sha256-wyGvTXsXSsfTrlWVBaqbeDhj5s6w31+Ixi0sxsHcOjA="; - arm64-linux_hash = "sha256-iqgyCNY62FBIyjcHXDk1zZY0RzFhUA5IQ8EDzAonKRE="; - x64-osx_hash = "sha256-h9qKe1GL2DSBAFhtztS254ILMCeIZqlCXyO0AvSA5Zo="; - }."${arch}-${os}_hash"; - -in stdenv.mkDerivation rec { + arch = + { + x86_64-linux = "x64"; + aarch64-linux = "arm64"; + x86_64-darwin = "x64"; + } + ."${stdenv.hostPlatform.system}" or (throw "Unsupported system: ${stdenv.hostPlatform.system}"); + + hash = + { + x64-linux_hash = "sha256-wyGvTXsXSsfTrlWVBaqbeDhj5s6w31+Ixi0sxsHcOjA="; + arm64-linux_hash = "sha256-iqgyCNY62FBIyjcHXDk1zZY0RzFhUA5IQ8EDzAonKRE="; + x64-osx_hash = "sha256-h9qKe1GL2DSBAFhtztS254ILMCeIZqlCXyO0AvSA5Zo="; + } + ."${arch}-${os}_hash"; + +in +stdenv.mkDerivation rec { pname = "ombi"; version = "4.44.1"; @@ -26,18 +42,28 @@ in stdenv.mkDerivation rec { sha256 = hash; }; - nativeBuildInputs = [ makeWrapper ] + nativeBuildInputs = + [ makeWrapper ] ++ lib.optional stdenv.hostPlatform.isLinux autoPatchelfHook ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; - propagatedBuildInputs = [ stdenv.cc.cc zlib krb5 ]; + propagatedBuildInputs = [ + stdenv.cc.cc + zlib + krb5 + ]; installPhase = '' mkdir -p $out/{bin,share/${pname}-${version}} cp -r * $out/share/${pname}-${version} makeWrapper $out/share/${pname}-${version}/Ombi $out/bin/Ombi \ - --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ openssl icu ]} \ + --prefix LD_LIBRARY_PATH : ${ + lib.makeLibraryPath [ + openssl + icu + ] + } \ --chdir "$out/share/${pname}-${version}" ''; @@ -52,7 +78,11 @@ in stdenv.mkDerivation rec { sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.gpl2Only; maintainers = with maintainers; [ woky ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + ]; mainProgram = "Ombi"; }; } diff --git a/pkgs/servers/openafs/1.8/default.nix b/pkgs/servers/openafs/1.8/default.nix index 4ae1b0d13b6f3d..1f8b92c6d6c733 100644 --- a/pkgs/servers/openafs/1.8/default.nix +++ b/pkgs/servers/openafs/1.8/default.nix @@ -1,27 +1,28 @@ -{ lib -, stdenv -, buildPackages -, fetchurl -, which -, autoconf -, automake -, flex -, bison -, glibc -, perl -, libkrb5 -, libxslt -, docbook_xsl -, file -, docbook_xml_dtd_43 -, libtool_2 -, withDevdoc ? false -, doxygen -, dblatex # Extra developer documentation -, withNcurses ? false -, ncurses # Extra ncurses utilities. Needed for debugging and monitoring. -, withTsm ? false -, tsm-client # Tivoli Storage Manager Backup Client from IBM +{ + lib, + stdenv, + buildPackages, + fetchurl, + which, + autoconf, + automake, + flex, + bison, + glibc, + perl, + libkrb5, + libxslt, + docbook_xsl, + file, + docbook_xml_dtd_43, + libtool_2, + withDevdoc ? false, + doxygen, + dblatex, # Extra developer documentation + withNcurses ? false, + ncurses, # Extra ncurses utilities. Needed for debugging and monitoring. + withTsm ? false, + tsm-client, # Tivoli Storage Manager Backup Client from IBM }: with (import ./srcs.nix { inherit fetchurl; }); @@ -34,23 +35,35 @@ stdenv.mkDerivation { inherit version srcs; depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ - autoconf - automake - flex - libxslt - libtool_2 - perl - which - bison - ] ++ optionals withDevdoc [ doxygen dblatex ]; + nativeBuildInputs = + [ + autoconf + automake + flex + libxslt + libtool_2 + perl + which + bison + ] + ++ optionals withDevdoc [ + doxygen + dblatex + ]; buildInputs = [ libkrb5 ] ++ optional withNcurses ncurses; - patches = [ ./bosserver.patch ./cross-build.patch ] - ++ optional withTsm ./tsmbac.patch; + patches = [ + ./bosserver.patch + ./cross-build.patch + ] ++ optional withTsm ./tsmbac.patch; - outputs = [ "out" "dev" "man" "doc" ] ++ optional withDevdoc "devdoc"; + outputs = [ + "out" + "dev" + "man" + "doc" + ] ++ optional withDevdoc "devdoc"; enableParallelBuilding = false; @@ -59,63 +72,69 @@ stdenv.mkDerivation { # Makefiles don't include install targets for all new shared libs, yet. dontDisableStatic = true; - preConfigure = '' - patchShebangs . - for i in `grep -l -R '/usr/\(include\|src\)' .`; do - echo "Patch /usr/include and /usr/src in $i" - substituteInPlace $i \ - --replace "/usr/include" "${glibc.dev}/include" \ - --replace "/usr/src" "$TMP" - done - - for i in ./doc/xml/{AdminGuide,QuickStartUnix,UserGuide}/*.xml; do - substituteInPlace "''${i}" --replace "http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" \ - "${docbook_xml_dtd_43}/xml/dtd/docbook/docbookx.dtd" - done - - ./regen.sh - - - configureFlagsArray=( - "--with-krb5" - "--sysconfdir=/etc" - "--localstatedir=/var" - "--disable-kernel-module" - "--disable-fuse-client" - "--with-docbook-stylesheets=${docbook_xsl}/share/xml/docbook-xsl" - ${optionalString withTsm "--enable-tivoli-tsm"} - ${optionalString (!withNcurses) "--disable-gtx"} - "--disable-linux-d_splice-alias-extra-iput" - ) - '' + optionalString withTsm '' - export XBSA_CFLAGS="-Dxbsa -DNEW_XBSA -I${tsm-client}/lib64/sample -DXBSA_TSMLIB=\\\"${tsm-client}/lib64/libApiTSM64.so\\\"" - ''; + preConfigure = + '' + patchShebangs . + for i in `grep -l -R '/usr/\(include\|src\)' .`; do + echo "Patch /usr/include and /usr/src in $i" + substituteInPlace $i \ + --replace "/usr/include" "${glibc.dev}/include" \ + --replace "/usr/src" "$TMP" + done + + for i in ./doc/xml/{AdminGuide,QuickStartUnix,UserGuide}/*.xml; do + substituteInPlace "''${i}" --replace "http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" \ + "${docbook_xml_dtd_43}/xml/dtd/docbook/docbookx.dtd" + done + + ./regen.sh + + + configureFlagsArray=( + "--with-krb5" + "--sysconfdir=/etc" + "--localstatedir=/var" + "--disable-kernel-module" + "--disable-fuse-client" + "--with-docbook-stylesheets=${docbook_xsl}/share/xml/docbook-xsl" + ${optionalString withTsm "--enable-tivoli-tsm"} + ${optionalString (!withNcurses) "--disable-gtx"} + "--disable-linux-d_splice-alias-extra-iput" + ) + '' + + optionalString withTsm '' + export XBSA_CFLAGS="-Dxbsa -DNEW_XBSA -I${tsm-client}/lib64/sample -DXBSA_TSMLIB=\\\"${tsm-client}/lib64/libApiTSM64.so\\\"" + ''; buildFlags = [ "all_nolibafs" ]; - postBuild = '' - for d in doc/xml/{AdminGuide,QuickStartUnix,UserGuide}; do - make -C "''${d}" index.html - done - '' + optionalString withDevdoc '' - make dox - ''; - - postInstall = '' - mkdir -p $doc/share/doc/openafs/{AdminGuide,QuickStartUnix,UserGuide} - cp -r doc/txt README LICENSE $doc/share/doc/openafs - for d in AdminGuide QuickStartUnix UserGuide ; do - cp "doc/xml/''${d}"/*.html "$doc/share/doc/openafs/''${d}" - done - - cp src/tools/dumpscan/{afsdump_dirlist,afsdump_extract,afsdump_scan,dumptool} $out/bin - - rm -r $out/lib/openafs - '' + optionalString withDevdoc '' - mkdir -p $devdoc/share/devhelp/openafs/doxygen - cp -r doc/{pdf,protocol} $devdoc/share/devhelp/openafs - cp -r doc/doxygen/output/html $devdoc/share/devhelp/openafs/doxygen - ''; + postBuild = + '' + for d in doc/xml/{AdminGuide,QuickStartUnix,UserGuide}; do + make -C "''${d}" index.html + done + '' + + optionalString withDevdoc '' + make dox + ''; + + postInstall = + '' + mkdir -p $doc/share/doc/openafs/{AdminGuide,QuickStartUnix,UserGuide} + cp -r doc/txt README LICENSE $doc/share/doc/openafs + for d in AdminGuide QuickStartUnix UserGuide ; do + cp "doc/xml/''${d}"/*.html "$doc/share/doc/openafs/''${d}" + done + + cp src/tools/dumpscan/{afsdump_dirlist,afsdump_extract,afsdump_scan,dumptool} $out/bin + + rm -r $out/lib/openafs + '' + + optionalString withDevdoc '' + mkdir -p $devdoc/share/devhelp/openafs/doxygen + cp -r doc/{pdf,protocol} $devdoc/share/devhelp/openafs + cp -r doc/doxygen/output/html $devdoc/share/devhelp/openafs/doxygen + ''; # remove forbidden references to $TMPDIR preFixup = '' @@ -127,11 +146,18 @@ stdenv.mkDerivation { ''; meta = with lib; { - outputsToInstall = [ "out" "doc" "man" ]; + outputsToInstall = [ + "out" + "doc" + "man" + ]; description = "Open AFS client"; homepage = "https://www.openafs.org"; license = licenses.ipl10; platforms = platforms.linux; - maintainers = [ maintainers.maggesi maintainers.spacefrogg ]; + maintainers = [ + maintainers.maggesi + maintainers.spacefrogg + ]; }; } diff --git a/pkgs/servers/openvscode-server/default.nix b/pkgs/servers/openvscode-server/default.nix index f21693591672af..309030b4d303e6 100644 --- a/pkgs/servers/openvscode-server/default.nix +++ b/pkgs/servers/openvscode-server/default.nix @@ -1,53 +1,65 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildGoModule -, makeWrapper -, cacert -, moreutils -, jq -, git -, pkg-config -, yarn -, python3 -, esbuild -, nodejs -, node-gyp -, libsecret -, libkrb5 -, xorg -, ripgrep -, AppKit -, Cocoa -, Security -, cctools -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + buildGoModule, + makeWrapper, + cacert, + moreutils, + jq, + git, + pkg-config, + yarn, + python3, + esbuild, + nodejs, + node-gyp, + libsecret, + libkrb5, + xorg, + ripgrep, + AppKit, + Cocoa, + Security, + cctools, + nixosTests, }: let system = stdenv.hostPlatform.system; yarn' = yarn.override { inherit nodejs; }; - defaultYarnOpts = [ "frozen-lockfile" "non-interactive" "no-progress" ]; + defaultYarnOpts = [ + "frozen-lockfile" + "non-interactive" + "no-progress" + ]; - vsBuildTarget = { - x86_64-linux = "linux-x64"; - aarch64-linux = "linux-arm64"; - x86_64-darwin = "darwin-x64"; - aarch64-darwin = "darwin-arm64"; - }.${system} or (throw "Unsupported system ${system}"); + vsBuildTarget = + { + x86_64-linux = "linux-x64"; + aarch64-linux = "linux-arm64"; + x86_64-darwin = "darwin-x64"; + aarch64-darwin = "darwin-arm64"; + } + .${system} or (throw "Unsupported system ${system}"); esbuild' = esbuild.override { - buildGoModule = args: buildGoModule (args // rec { - version = "0.17.14"; - src = fetchFromGitHub { - owner = "evanw"; - repo = "esbuild"; - rev = "v${version}"; - hash = "sha256-4TC1d5FOZHUMuEMTcTOBLZZM+sFUswhyblI5HVWyvPA="; - }; - vendorHash = "sha256-+BfxCyg0KkDQpHt/wycy/8CTG6YBA/VJvJFhhzUnSiQ="; - }); + buildGoModule = + args: + buildGoModule ( + args + // rec { + version = "0.17.14"; + src = fetchFromGitHub { + owner = "evanw"; + repo = "esbuild"; + rev = "v${version}"; + hash = "sha256-4TC1d5FOZHUMuEMTcTOBLZZM+sFUswhyblI5HVWyvPA="; + }; + vendorHash = "sha256-+BfxCyg0KkDQpHt/wycy/8CTG6YBA/VJvJFhhzUnSiQ="; + } + ); }; # replaces esbuild's download script with a binary from nixpkgs @@ -72,7 +84,11 @@ stdenv.mkDerivation (finalAttrs: { yarnCache = stdenv.mkDerivation { name = "${finalAttrs.pname}-${finalAttrs.version}-${system}-yarn-cache"; inherit (finalAttrs) src; - nativeBuildInputs = [ cacert yarn' git ]; + nativeBuildInputs = [ + cacert + yarn' + git + ]; buildPhase = '' export HOME=$PWD @@ -103,14 +119,19 @@ stdenv.mkDerivation (finalAttrs: { moreutils ]; - buildInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ libsecret ] - ++ (with xorg; [ libX11 libxkbfile libkrb5 ]) + buildInputs = + lib.optionals (!stdenv.hostPlatform.isDarwin) [ libsecret ] + ++ (with xorg; [ + libX11 + libxkbfile + libkrb5 + ]) ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - Cocoa - Security - cctools - ]; + AppKit + Cocoa + Security + cctools + ]; patches = [ # Patch out remote download of nodejs from build script @@ -159,54 +180,57 @@ stdenv.mkDerivation (finalAttrs: { runHook postConfigure ''; - buildPhase = '' - runHook preBuild - - # install dependencies - yarn --offline --ignore-scripts - - # run yarn install everywhere, skipping postinstall so we can patch esbuild - find . -path "*node_modules" -prune -o \ - -path "./*/*" -name "yarn.lock" -printf "%h\n" | \ - xargs -I {} yarn --cwd {} \ - --frozen-lockfile --offline --ignore-scripts --ignore-engines - - ${patchEsbuild "./build" "0.12.6"} - ${patchEsbuild "./extensions" "0.11.23"} - - # patch shebangs of node_modules to allow binary packages to build - patchShebangs ./remote/node_modules - - # put ripgrep binary into bin so postinstall does not try to download it - find -path "*@vscode/ripgrep" -type d \ - -execdir mkdir -p {}/bin \; \ - -execdir ln -s ${ripgrep}/bin/rg {}/bin/rg \; - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # use prebuilt binary for @parcel/watcher, which requires macOS SDK 10.13+ - # (see issue #101229) - pushd ./remote/node_modules/@parcel/watcher - mkdir -p ./build/Release - mv ./prebuilds/darwin-x64/node.napi.glibc.node ./build/Release/watcher.node - jq "del(.scripts) | .gypfile = false" ./package.json | sponge ./package.json - popd - '' + '' - export NODE_OPTIONS=--openssl-legacy-provider - - # rebuild binaries, we use npm here, as yarn does not provide an alternative - # that would not attempt to try to reinstall everything and break our - # patching attempts - npm --prefix ./remote rebuild --build-from-source - - # run postinstall scripts after patching - find . -path "*node_modules" -prune -o \ - -path "./*/*" -name "yarn.lock" -printf "%h\n" | \ - xargs -I {} sh -c 'jq -e ".scripts.postinstall" {}/package.json >/dev/null && yarn --cwd {} postinstall --frozen-lockfile --offline || true' - - # build and minify - yarn --offline gulp vscode-reh-web-${vsBuildTarget}-min - - runHook postBuild - ''; + buildPhase = + '' + runHook preBuild + + # install dependencies + yarn --offline --ignore-scripts + + # run yarn install everywhere, skipping postinstall so we can patch esbuild + find . -path "*node_modules" -prune -o \ + -path "./*/*" -name "yarn.lock" -printf "%h\n" | \ + xargs -I {} yarn --cwd {} \ + --frozen-lockfile --offline --ignore-scripts --ignore-engines + + ${patchEsbuild "./build" "0.12.6"} + ${patchEsbuild "./extensions" "0.11.23"} + + # patch shebangs of node_modules to allow binary packages to build + patchShebangs ./remote/node_modules + + # put ripgrep binary into bin so postinstall does not try to download it + find -path "*@vscode/ripgrep" -type d \ + -execdir mkdir -p {}/bin \; \ + -execdir ln -s ${ripgrep}/bin/rg {}/bin/rg \; + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # use prebuilt binary for @parcel/watcher, which requires macOS SDK 10.13+ + # (see issue #101229) + pushd ./remote/node_modules/@parcel/watcher + mkdir -p ./build/Release + mv ./prebuilds/darwin-x64/node.napi.glibc.node ./build/Release/watcher.node + jq "del(.scripts) | .gypfile = false" ./package.json | sponge ./package.json + popd + '' + + '' + export NODE_OPTIONS=--openssl-legacy-provider + + # rebuild binaries, we use npm here, as yarn does not provide an alternative + # that would not attempt to try to reinstall everything and break our + # patching attempts + npm --prefix ./remote rebuild --build-from-source + + # run postinstall scripts after patching + find . -path "*node_modules" -prune -o \ + -path "./*/*" -name "yarn.lock" -printf "%h\n" | \ + xargs -I {} sh -c 'jq -e ".scripts.postinstall" {}/package.json >/dev/null && yarn --cwd {} postinstall --frozen-lockfile --offline || true' + + # build and minify + yarn --offline gulp vscode-reh-web-${vsBuildTarget}-min + + runHook postBuild + ''; installPhase = '' runHook preInstall @@ -230,8 +254,17 @@ stdenv.mkDerivation (finalAttrs: { ''; homepage = "https://github.com/gitpod-io/openvscode-server"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ dguenther ghuntley emilytrau ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + maintainers = with lib.maintainers; [ + dguenther + ghuntley + emilytrau + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; mainProgram = "openvscode-server"; }; }) diff --git a/pkgs/servers/osmocom/libasn1c/default.nix b/pkgs/servers/osmocom/libasn1c/default.nix index b727b1b1ee6998..17bbd5200c3361 100644 --- a/pkgs/servers/osmocom/libasn1c/default.nix +++ b/pkgs/servers/osmocom/libasn1c/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, autoreconfHook -, fetchFromGitHub -, pkg-config -, talloc +{ + lib, + stdenv, + autoreconfHook, + fetchFromGitHub, + pkg-config, + talloc, }: stdenv.mkDerivation rec { diff --git a/pkgs/servers/peertube/default.nix b/pkgs/servers/peertube/default.nix index 7999a2c0ddb789..2dc3918825c66d 100644 --- a/pkgs/servers/peertube/default.nix +++ b/pkgs/servers/peertube/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, callPackage -, fetchurl -, fetchFromGitHub -, fetchYarnDeps -, nixosTests -, brotli -, fixup-yarn-lock -, jq -, fd -, nodejs -, which -, yarn +{ + lib, + stdenv, + callPackage, + fetchurl, + fetchFromGitHub, + fetchYarnDeps, + nixosTests, + brotli, + fixup-yarn-lock, + jq, + fd, + nodejs, + which, + yarn, }: let bcryptHostPlatformAttrs = { @@ -36,8 +37,9 @@ let hash = "sha256-JMnELVUxoU1C57Tzue3Sg6OfDFAjfCnzgDit0BWzmlo="; }; }; - bcryptAttrs = bcryptHostPlatformAttrs."${stdenv.hostPlatform.system}" or - (throw "Unsupported architecture: ${stdenv.hostPlatform.system}"); + bcryptAttrs = + bcryptHostPlatformAttrs."${stdenv.hostPlatform.system}" + or (throw "Unsupported architecture: ${stdenv.hostPlatform.system}"); bcryptVersion = "5.1.1"; bcryptLib = fetchurl { url = "https://github.com/kelektiv/node.bcrypt.js/releases/download/v${bcryptVersion}/bcrypt_lib-v${bcryptVersion}-napi-v3-${bcryptAttrs.arch}-${bcryptAttrs.libc}.tar.gz"; @@ -75,9 +77,20 @@ stdenv.mkDerivation rec { hash = "sha256-x5qFCprn8q0xC88HudLV7W53X1Nkbz3F52RMp2PxIu8="; }; - outputs = [ "out" "cli" "runner" ]; - - nativeBuildInputs = [ brotli fixup-yarn-lock jq which yarn fd ]; + outputs = [ + "out" + "cli" + "runner" + ]; + + nativeBuildInputs = [ + brotli + fixup-yarn-lock + jq + which + yarn + fd + ]; buildInputs = [ nodejs ]; @@ -191,10 +204,15 @@ stdenv.mkDerivation rec { license = licenses.agpl3Plus; homepage = "https://joinpeertube.org/"; platforms = [ - "x86_64-linux" "aarch64-linux" + "x86_64-linux" + "aarch64-linux" # feasible, looking for maintainer to help out # "x86_64-darwin" "aarch64-darwin" ]; - maintainers = with maintainers; [ immae izorkin stevenroose ]; + maintainers = with maintainers; [ + immae + izorkin + stevenroose + ]; }; } diff --git a/pkgs/servers/persistent-evdev/default.nix b/pkgs/servers/persistent-evdev/default.nix index 83518b904a5094..36f125c913fa0a 100644 --- a/pkgs/servers/persistent-evdev/default.nix +++ b/pkgs/servers/persistent-evdev/default.nix @@ -1,4 +1,9 @@ -{ lib, buildPythonPackage, fetchFromGitHub, python3Packages }: +{ + lib, + buildPythonPackage, + fetchFromGitHub, + python3Packages, +}: buildPythonPackage rec { pname = "persistent-evdev"; @@ -13,7 +18,8 @@ buildPythonPackage rec { }; propagatedBuildInputs = with python3Packages; [ - evdev pyudev + evdev + pyudev ]; postPatch = '' diff --git a/pkgs/servers/pinnwand/default.nix b/pkgs/servers/pinnwand/default.nix index 1b7ac24eadfbb0..67ccc2eff5e19d 100644 --- a/pkgs/servers/pinnwand/default.nix +++ b/pkgs/servers/pinnwand/default.nix @@ -1,10 +1,12 @@ -{ lib -, python3 -, fetchFromGitHub -, nixosTests +{ + lib, + python3, + fetchFromGitHub, + nixosTests, }: -with python3.pkgs; buildPythonApplication rec { +with python3.pkgs; +buildPythonApplication rec { pname = "pinnwand"; version = "1.6.0"; pyproject = true; @@ -60,4 +62,3 @@ with python3.pkgs; buildPythonApplication rec { platforms = platforms.linux; }; } - diff --git a/pkgs/servers/pinnwand/steck.nix b/pkgs/servers/pinnwand/steck.nix index 32e2141d2a9d63..f4f8578c0797a4 100644 --- a/pkgs/servers/pinnwand/steck.nix +++ b/pkgs/servers/pinnwand/steck.nix @@ -1,8 +1,9 @@ -{ lib -, pkgs -, python3Packages -, fetchPypi -, nixosTests +{ + lib, + pkgs, + python3Packages, + fetchPypi, + nixosTests, }: python3Packages.buildPythonApplication rec { @@ -48,4 +49,3 @@ python3Packages.buildPythonApplication rec { maintainers = with maintainers; [ hexa ]; }; } - diff --git a/pkgs/servers/piping-server-rust/default.nix b/pkgs/servers/piping-server-rust/default.nix index 0e081884e4cf8f..5b4d101b2ff0ea 100644 --- a/pkgs/servers/piping-server-rust/default.nix +++ b/pkgs/servers/piping-server-rust/default.nix @@ -1,4 +1,11 @@ -{ lib, rustPlatform, fetchFromGitHub, stdenv, CoreServices, Security }: +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + CoreServices, + Security, +}: rustPlatform.buildRustPackage rec { pname = "piping-server-rust"; @@ -13,7 +20,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-YSiClSnjgqFqT2IGJoatcy7j3NUKcff826AvJ/+RNNU="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices Security ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + Security + ]; meta = with lib; { description = "Infinitely transfer between every device over pure HTTP with pipes or browsers"; diff --git a/pkgs/servers/pleroma/mix.nix b/pkgs/servers/pleroma/mix.nix index 65ab75c39d4a67..bc12377910358e 100644 --- a/pkgs/servers/pleroma/mix.nix +++ b/pkgs/servers/pleroma/mix.nix @@ -1,4 +1,8 @@ -{ lib, beamPackages, overrides ? (x: y: {}) }: +{ + lib, + beamPackages, + overrides ? (x: y: { }), +}: let buildRebar3 = lib.makeOverridable beamPackages.buildRebar3; @@ -7,1865 +11,2097 @@ let self = packages // (overrides self packages); - packages = with beamPackages; with self; { - accept = buildRebar3 rec { - name = "accept"; - version = "0.3.5"; + packages = + with beamPackages; + with self; + { + accept = buildRebar3 rec { + name = "accept"; + version = "0.3.5"; - src = fetchHex { - pkg = "accept"; - version = "${version}"; - sha256 = "11b18c220bcc2eab63b5470c038ef10eb6783bcb1fcdb11aa4137defa5ac1bb8"; - }; - - beamDeps = []; - }; + src = fetchHex { + pkg = "accept"; + version = "${version}"; + sha256 = "11b18c220bcc2eab63b5470c038ef10eb6783bcb1fcdb11aa4137defa5ac1bb8"; + }; - bandit = buildMix rec { - name = "bandit"; - version = "1.5.5"; - - src = fetchHex { - pkg = "bandit"; - version = "${version}"; - sha256 = "f21579a29ea4bc08440343b2b5f16f7cddf2fea5725d31b72cf973ec729079e1"; + beamDeps = [ ]; }; - beamDeps = [ hpax plug telemetry thousand_island websock ]; - }; + bandit = buildMix rec { + name = "bandit"; + version = "1.5.5"; - base62 = buildMix rec { - name = "base62"; - version = "1.2.2"; + src = fetchHex { + pkg = "bandit"; + version = "${version}"; + sha256 = "f21579a29ea4bc08440343b2b5f16f7cddf2fea5725d31b72cf973ec729079e1"; + }; - src = fetchHex { - pkg = "base62"; - version = "${version}"; - sha256 = "d41336bda8eaa5be197f1e4592400513ee60518e5b9f4dcf38f4b4dae6f377bb"; + beamDeps = [ + hpax + plug + telemetry + thousand_island + websock + ]; }; - beamDeps = [ custom_base ]; - }; + base62 = buildMix rec { + name = "base62"; + version = "1.2.2"; - bbcode_pleroma = buildMix rec { - name = "bbcode_pleroma"; - version = "0.2.0"; + src = fetchHex { + pkg = "base62"; + version = "${version}"; + sha256 = "d41336bda8eaa5be197f1e4592400513ee60518e5b9f4dcf38f4b4dae6f377bb"; + }; - src = fetchHex { - pkg = "bbcode_pleroma"; - version = "${version}"; - sha256 = "19851074419a5fedb4ef49e1f01b30df504bb5dbb6d6adfc135238063bebd1c3"; + beamDeps = [ custom_base ]; }; - beamDeps = [ nimble_parsec ]; - }; + bbcode_pleroma = buildMix rec { + name = "bbcode_pleroma"; + version = "0.2.0"; - bcrypt_elixir = buildMix rec { - name = "bcrypt_elixir"; - version = "2.3.1"; + src = fetchHex { + pkg = "bbcode_pleroma"; + version = "${version}"; + sha256 = "19851074419a5fedb4ef49e1f01b30df504bb5dbb6d6adfc135238063bebd1c3"; + }; - src = fetchHex { - pkg = "bcrypt_elixir"; - version = "${version}"; - sha256 = "42182d5f46764def15bf9af83739e3bf4ad22661b1c34fc3e88558efced07279"; + beamDeps = [ nimble_parsec ]; }; - beamDeps = [ comeonin elixir_make ]; - }; + bcrypt_elixir = buildMix rec { + name = "bcrypt_elixir"; + version = "2.3.1"; - benchee = buildMix rec { - name = "benchee"; - version = "1.3.0"; + src = fetchHex { + pkg = "bcrypt_elixir"; + version = "${version}"; + sha256 = "42182d5f46764def15bf9af83739e3bf4ad22661b1c34fc3e88558efced07279"; + }; - src = fetchHex { - pkg = "benchee"; - version = "${version}"; - sha256 = "34f4294068c11b2bd2ebf2c59aac9c7da26ffa0068afdf3419f1b176e16c5f81"; + beamDeps = [ + comeonin + elixir_make + ]; }; - beamDeps = [ deep_merge statistex ]; - }; + benchee = buildMix rec { + name = "benchee"; + version = "1.3.0"; - blurhash = buildMix rec { - name = "blurhash"; - version = "0.1.0"; + src = fetchHex { + pkg = "benchee"; + version = "${version}"; + sha256 = "34f4294068c11b2bd2ebf2c59aac9c7da26ffa0068afdf3419f1b176e16c5f81"; + }; - src = fetchHex { - pkg = "rinpatch_blurhash"; - version = "${version}"; - sha256 = "19911a5dcbb0acb9710169a72f702bce6cb048822b12de566ccd82b2cc42b907"; + beamDeps = [ + deep_merge + statistex + ]; }; - beamDeps = [ mogrify ]; - }; + blurhash = buildMix rec { + name = "blurhash"; + version = "0.1.0"; - bunt = buildMix rec { - name = "bunt"; - version = "1.0.0"; + src = fetchHex { + pkg = "rinpatch_blurhash"; + version = "${version}"; + sha256 = "19911a5dcbb0acb9710169a72f702bce6cb048822b12de566ccd82b2cc42b907"; + }; - src = fetchHex { - pkg = "bunt"; - version = "${version}"; - sha256 = "dc5f86aa08a5f6fa6b8096f0735c4e76d54ae5c9fa2c143e5a1fc7c1cd9bb6b5"; + beamDeps = [ mogrify ]; }; - beamDeps = []; - }; + bunt = buildMix rec { + name = "bunt"; + version = "1.0.0"; - cachex = buildMix rec { - name = "cachex"; - version = "3.6.0"; + src = fetchHex { + pkg = "bunt"; + version = "${version}"; + sha256 = "dc5f86aa08a5f6fa6b8096f0735c4e76d54ae5c9fa2c143e5a1fc7c1cd9bb6b5"; + }; - src = fetchHex { - pkg = "cachex"; - version = "${version}"; - sha256 = "ebf24e373883bc8e0c8d894a63bbe102ae13d918f790121f5cfe6e485cc8e2e2"; + beamDeps = [ ]; }; - beamDeps = [ eternal jumper sleeplocks unsafe ]; - }; + cachex = buildMix rec { + name = "cachex"; + version = "3.6.0"; - calendar = buildMix rec { - name = "calendar"; - version = "1.0.0"; + src = fetchHex { + pkg = "cachex"; + version = "${version}"; + sha256 = "ebf24e373883bc8e0c8d894a63bbe102ae13d918f790121f5cfe6e485cc8e2e2"; + }; - src = fetchHex { - pkg = "calendar"; - version = "${version}"; - sha256 = "990e9581920c82912a5ee50e62ff5ef96da6b15949a2ee4734f935fdef0f0a6f"; + beamDeps = [ + eternal + jumper + sleeplocks + unsafe + ]; }; - beamDeps = [ tzdata ]; - }; + calendar = buildMix rec { + name = "calendar"; + version = "1.0.0"; - castore = buildMix rec { - name = "castore"; - version = "0.1.22"; + src = fetchHex { + pkg = "calendar"; + version = "${version}"; + sha256 = "990e9581920c82912a5ee50e62ff5ef96da6b15949a2ee4734f935fdef0f0a6f"; + }; - src = fetchHex { - pkg = "castore"; - version = "${version}"; - sha256 = "c17576df47eb5aa1ee40cc4134316a99f5cad3e215d5c77b8dd3cfef12a22cac"; + beamDeps = [ tzdata ]; }; - beamDeps = []; - }; + castore = buildMix rec { + name = "castore"; + version = "0.1.22"; - cc_precompiler = buildMix rec { - name = "cc_precompiler"; - version = "0.1.9"; + src = fetchHex { + pkg = "castore"; + version = "${version}"; + sha256 = "c17576df47eb5aa1ee40cc4134316a99f5cad3e215d5c77b8dd3cfef12a22cac"; + }; - src = fetchHex { - pkg = "cc_precompiler"; - version = "${version}"; - sha256 = "9dcab3d0f3038621f1601f13539e7a9ee99843862e66ad62827b0c42b2f58a54"; + beamDeps = [ ]; }; - beamDeps = [ elixir_make ]; - }; + cc_precompiler = buildMix rec { + name = "cc_precompiler"; + version = "0.1.9"; - certifi = buildRebar3 rec { - name = "certifi"; - version = "2.12.0"; + src = fetchHex { + pkg = "cc_precompiler"; + version = "${version}"; + sha256 = "9dcab3d0f3038621f1601f13539e7a9ee99843862e66ad62827b0c42b2f58a54"; + }; - src = fetchHex { - pkg = "certifi"; - version = "${version}"; - sha256 = "ee68d85df22e554040cdb4be100f33873ac6051387baf6a8f6ce82272340ff1c"; + beamDeps = [ elixir_make ]; }; - beamDeps = []; - }; + certifi = buildRebar3 rec { + name = "certifi"; + version = "2.12.0"; - combine = buildMix rec { - name = "combine"; - version = "0.10.0"; + src = fetchHex { + pkg = "certifi"; + version = "${version}"; + sha256 = "ee68d85df22e554040cdb4be100f33873ac6051387baf6a8f6ce82272340ff1c"; + }; - src = fetchHex { - pkg = "combine"; - version = "${version}"; - sha256 = "1b1dbc1790073076580d0d1d64e42eae2366583e7aecd455d1215b0d16f2451b"; + beamDeps = [ ]; }; - beamDeps = []; - }; + combine = buildMix rec { + name = "combine"; + version = "0.10.0"; - comeonin = buildMix rec { - name = "comeonin"; - version = "5.4.0"; + src = fetchHex { + pkg = "combine"; + version = "${version}"; + sha256 = "1b1dbc1790073076580d0d1d64e42eae2366583e7aecd455d1215b0d16f2451b"; + }; - src = fetchHex { - pkg = "comeonin"; - version = "${version}"; - sha256 = "796393a9e50d01999d56b7b8420ab0481a7538d0caf80919da493b4a6e51faf1"; + beamDeps = [ ]; }; - beamDeps = []; - }; + comeonin = buildMix rec { + name = "comeonin"; + version = "5.4.0"; - concurrent_limiter = buildMix rec { - name = "concurrent_limiter"; - version = "0.1.1"; + src = fetchHex { + pkg = "comeonin"; + version = "${version}"; + sha256 = "796393a9e50d01999d56b7b8420ab0481a7538d0caf80919da493b4a6e51faf1"; + }; - src = fetchHex { - pkg = "concurrent_limiter"; - version = "${version}"; - sha256 = "53968ff238c0fbb4d7ed76ddb1af0be6f3b2f77909f6796e249e737c505a16eb"; + beamDeps = [ ]; }; - beamDeps = [ telemetry ]; - }; + concurrent_limiter = buildMix rec { + name = "concurrent_limiter"; + version = "0.1.1"; - connection = buildMix rec { - name = "connection"; - version = "1.1.0"; + src = fetchHex { + pkg = "concurrent_limiter"; + version = "${version}"; + sha256 = "53968ff238c0fbb4d7ed76ddb1af0be6f3b2f77909f6796e249e737c505a16eb"; + }; - src = fetchHex { - pkg = "connection"; - version = "${version}"; - sha256 = "722c1eb0a418fbe91ba7bd59a47e28008a189d47e37e0e7bb85585a016b2869c"; + beamDeps = [ telemetry ]; }; - beamDeps = []; - }; + connection = buildMix rec { + name = "connection"; + version = "1.1.0"; - cors_plug = buildMix rec { - name = "cors_plug"; - version = "2.0.3"; + src = fetchHex { + pkg = "connection"; + version = "${version}"; + sha256 = "722c1eb0a418fbe91ba7bd59a47e28008a189d47e37e0e7bb85585a016b2869c"; + }; - src = fetchHex { - pkg = "cors_plug"; - version = "${version}"; - sha256 = "ee4ae1418e6ce117fc42c2ba3e6cbdca4e95ecd2fe59a05ec6884ca16d469aea"; + beamDeps = [ ]; }; - beamDeps = [ plug ]; - }; + cors_plug = buildMix rec { + name = "cors_plug"; + version = "2.0.3"; - covertool = buildRebar3 rec { - name = "covertool"; - version = "2.0.6"; + src = fetchHex { + pkg = "cors_plug"; + version = "${version}"; + sha256 = "ee4ae1418e6ce117fc42c2ba3e6cbdca4e95ecd2fe59a05ec6884ca16d469aea"; + }; - src = fetchHex { - pkg = "covertool"; - version = "${version}"; - sha256 = "5db3fcd82180d8ea4ad857d4d1ab21a8d31b5aee0d60d2f6c0f9e25a411d1e21"; + beamDeps = [ plug ]; }; - beamDeps = []; - }; + covertool = buildRebar3 rec { + name = "covertool"; + version = "2.0.6"; - cowboy = buildErlangMk rec { - name = "cowboy"; - version = "2.12.0"; + src = fetchHex { + pkg = "covertool"; + version = "${version}"; + sha256 = "5db3fcd82180d8ea4ad857d4d1ab21a8d31b5aee0d60d2f6c0f9e25a411d1e21"; + }; - src = fetchHex { - pkg = "cowboy"; - version = "${version}"; - sha256 = "8a7abe6d183372ceb21caa2709bec928ab2b72e18a3911aa1771639bef82651e"; + beamDeps = [ ]; }; - beamDeps = [ cowlib ranch ]; - }; + cowboy = buildErlangMk rec { + name = "cowboy"; + version = "2.12.0"; - cowboy_telemetry = buildRebar3 rec { - name = "cowboy_telemetry"; - version = "0.4.0"; + src = fetchHex { + pkg = "cowboy"; + version = "${version}"; + sha256 = "8a7abe6d183372ceb21caa2709bec928ab2b72e18a3911aa1771639bef82651e"; + }; - src = fetchHex { - pkg = "cowboy_telemetry"; - version = "${version}"; - sha256 = "7d98bac1ee4565d31b62d59f8823dfd8356a169e7fcbb83831b8a5397404c9de"; + beamDeps = [ + cowlib + ranch + ]; }; - beamDeps = [ cowboy telemetry ]; - }; + cowboy_telemetry = buildRebar3 rec { + name = "cowboy_telemetry"; + version = "0.4.0"; - cowlib = buildRebar3 rec { - name = "cowlib"; - version = "2.13.0"; + src = fetchHex { + pkg = "cowboy_telemetry"; + version = "${version}"; + sha256 = "7d98bac1ee4565d31b62d59f8823dfd8356a169e7fcbb83831b8a5397404c9de"; + }; - src = fetchHex { - pkg = "cowlib"; - version = "${version}"; - sha256 = "e1e1284dc3fc030a64b1ad0d8382ae7e99da46c3246b815318a4b848873800a4"; + beamDeps = [ + cowboy + telemetry + ]; }; - beamDeps = []; - }; + cowlib = buildRebar3 rec { + name = "cowlib"; + version = "2.13.0"; - credo = buildMix rec { - name = "credo"; - version = "1.7.3"; + src = fetchHex { + pkg = "cowlib"; + version = "${version}"; + sha256 = "e1e1284dc3fc030a64b1ad0d8382ae7e99da46c3246b815318a4b848873800a4"; + }; - src = fetchHex { - pkg = "credo"; - version = "${version}"; - sha256 = "35ea675a094c934c22fb1dca3696f3c31f2728ae6ef5a53b5d648c11180a4535"; + beamDeps = [ ]; }; - beamDeps = [ bunt file_system jason ]; - }; + credo = buildMix rec { + name = "credo"; + version = "1.7.3"; - crontab = buildMix rec { - name = "crontab"; - version = "1.1.8"; + src = fetchHex { + pkg = "credo"; + version = "${version}"; + sha256 = "35ea675a094c934c22fb1dca3696f3c31f2728ae6ef5a53b5d648c11180a4535"; + }; - src = fetchHex { - pkg = "crontab"; - version = "${version}"; - sha256 = "1gkb7ps38j789acj8dw2q7jnhhw43idyvh36fb3i52yjkhli7ra8"; + beamDeps = [ + bunt + file_system + jason + ]; }; - beamDeps = [ ecto ]; - }; + crontab = buildMix rec { + name = "crontab"; + version = "1.1.8"; - custom_base = buildMix rec { - name = "custom_base"; - version = "0.2.1"; + src = fetchHex { + pkg = "crontab"; + version = "${version}"; + sha256 = "1gkb7ps38j789acj8dw2q7jnhhw43idyvh36fb3i52yjkhli7ra8"; + }; - src = fetchHex { - pkg = "custom_base"; - version = "${version}"; - sha256 = "8df019facc5ec9603e94f7270f1ac73ddf339f56ade76a721eaa57c1493ba463"; + beamDeps = [ ecto ]; }; - beamDeps = []; - }; + custom_base = buildMix rec { + name = "custom_base"; + version = "0.2.1"; - db_connection = buildMix rec { - name = "db_connection"; - version = "2.7.0"; + src = fetchHex { + pkg = "custom_base"; + version = "${version}"; + sha256 = "8df019facc5ec9603e94f7270f1ac73ddf339f56ade76a721eaa57c1493ba463"; + }; - src = fetchHex { - pkg = "db_connection"; - version = "${version}"; - sha256 = "dcf08f31b2701f857dfc787fbad78223d61a32204f217f15e881dd93e4bdd3ff"; + beamDeps = [ ]; }; - beamDeps = [ telemetry ]; - }; + db_connection = buildMix rec { + name = "db_connection"; + version = "2.7.0"; - decimal = buildMix rec { - name = "decimal"; - version = "2.1.1"; + src = fetchHex { + pkg = "db_connection"; + version = "${version}"; + sha256 = "dcf08f31b2701f857dfc787fbad78223d61a32204f217f15e881dd93e4bdd3ff"; + }; - src = fetchHex { - pkg = "decimal"; - version = "${version}"; - sha256 = "53cfe5f497ed0e7771ae1a475575603d77425099ba5faef9394932b35020ffcc"; + beamDeps = [ telemetry ]; }; - beamDeps = []; - }; + decimal = buildMix rec { + name = "decimal"; + version = "2.1.1"; - deep_merge = buildMix rec { - name = "deep_merge"; - version = "1.0.0"; + src = fetchHex { + pkg = "decimal"; + version = "${version}"; + sha256 = "53cfe5f497ed0e7771ae1a475575603d77425099ba5faef9394932b35020ffcc"; + }; - src = fetchHex { - pkg = "deep_merge"; - version = "${version}"; - sha256 = "ce708e5f094b9cd4e8f2be4f00d2f4250c4095be93f8cd6d018c753894885430"; + beamDeps = [ ]; }; - beamDeps = []; - }; + deep_merge = buildMix rec { + name = "deep_merge"; + version = "1.0.0"; - dialyxir = buildMix rec { - name = "dialyxir"; - version = "1.4.3"; + src = fetchHex { + pkg = "deep_merge"; + version = "${version}"; + sha256 = "ce708e5f094b9cd4e8f2be4f00d2f4250c4095be93f8cd6d018c753894885430"; + }; - src = fetchHex { - pkg = "dialyxir"; - version = "${version}"; - sha256 = "bf2cfb75cd5c5006bec30141b131663299c661a864ec7fbbc72dfa557487a986"; + beamDeps = [ ]; }; - beamDeps = [ erlex ]; - }; + dialyxir = buildMix rec { + name = "dialyxir"; + version = "1.4.3"; - earmark = buildMix rec { - name = "earmark"; - version = "1.4.46"; + src = fetchHex { + pkg = "dialyxir"; + version = "${version}"; + sha256 = "bf2cfb75cd5c5006bec30141b131663299c661a864ec7fbbc72dfa557487a986"; + }; - src = fetchHex { - pkg = "earmark"; - version = "${version}"; - sha256 = "798d86db3d79964e759ddc0c077d5eb254968ed426399fbf5a62de2b5ff8910a"; + beamDeps = [ erlex ]; }; - beamDeps = []; - }; + earmark = buildMix rec { + name = "earmark"; + version = "1.4.46"; - earmark_parser = buildMix rec { - name = "earmark_parser"; - version = "1.4.39"; + src = fetchHex { + pkg = "earmark"; + version = "${version}"; + sha256 = "798d86db3d79964e759ddc0c077d5eb254968ed426399fbf5a62de2b5ff8910a"; + }; - src = fetchHex { - pkg = "earmark_parser"; - version = "${version}"; - sha256 = "06553a88d1f1846da9ef066b87b57c6f605552cfbe40d20bd8d59cc6bde41944"; + beamDeps = [ ]; }; - beamDeps = []; - }; + earmark_parser = buildMix rec { + name = "earmark_parser"; + version = "1.4.39"; - ecto = buildMix rec { - name = "ecto"; - version = "3.11.2"; + src = fetchHex { + pkg = "earmark_parser"; + version = "${version}"; + sha256 = "06553a88d1f1846da9ef066b87b57c6f605552cfbe40d20bd8d59cc6bde41944"; + }; - src = fetchHex { - pkg = "ecto"; - version = "${version}"; - sha256 = "3c38bca2c6f8d8023f2145326cc8a80100c3ffe4dcbd9842ff867f7fc6156c65"; + beamDeps = [ ]; }; - beamDeps = [ decimal jason telemetry ]; - }; + ecto = buildMix rec { + name = "ecto"; + version = "3.11.2"; - ecto_enum = buildMix rec { - name = "ecto_enum"; - version = "1.4.0"; + src = fetchHex { + pkg = "ecto"; + version = "${version}"; + sha256 = "3c38bca2c6f8d8023f2145326cc8a80100c3ffe4dcbd9842ff867f7fc6156c65"; + }; - src = fetchHex { - pkg = "ecto_enum"; - version = "${version}"; - sha256 = "8fb55c087181c2b15eee406519dc22578fa60dd82c088be376d0010172764ee4"; + beamDeps = [ + decimal + jason + telemetry + ]; }; - beamDeps = [ ecto ecto_sql postgrex ]; - }; + ecto_enum = buildMix rec { + name = "ecto_enum"; + version = "1.4.0"; - ecto_psql_extras = buildMix rec { - name = "ecto_psql_extras"; - version = "0.7.15"; + src = fetchHex { + pkg = "ecto_enum"; + version = "${version}"; + sha256 = "8fb55c087181c2b15eee406519dc22578fa60dd82c088be376d0010172764ee4"; + }; - src = fetchHex { - pkg = "ecto_psql_extras"; - version = "${version}"; - sha256 = "b6127f3a5c6fc3d84895e4768cc7c199f22b48b67d6c99b13fbf4a374e73f039"; + beamDeps = [ + ecto + ecto_sql + postgrex + ]; }; - beamDeps = [ ecto_sql postgrex table_rex ]; - }; + ecto_psql_extras = buildMix rec { + name = "ecto_psql_extras"; + version = "0.7.15"; - ecto_sql = buildMix rec { - name = "ecto_sql"; - version = "3.11.3"; + src = fetchHex { + pkg = "ecto_psql_extras"; + version = "${version}"; + sha256 = "b6127f3a5c6fc3d84895e4768cc7c199f22b48b67d6c99b13fbf4a374e73f039"; + }; - src = fetchHex { - pkg = "ecto_sql"; - version = "${version}"; - sha256 = "e5f36e3d736b99c7fee3e631333b8394ade4bafe9d96d35669fca2d81c2be928"; + beamDeps = [ + ecto_sql + postgrex + table_rex + ]; }; - beamDeps = [ db_connection ecto postgrex telemetry ]; - }; + ecto_sql = buildMix rec { + name = "ecto_sql"; + version = "3.11.3"; - eimp = buildRebar3 rec { - name = "eimp"; - version = "1.0.14"; + src = fetchHex { + pkg = "ecto_sql"; + version = "${version}"; + sha256 = "e5f36e3d736b99c7fee3e631333b8394ade4bafe9d96d35669fca2d81c2be928"; + }; - src = fetchHex { - pkg = "eimp"; - version = "${version}"; - sha256 = "501133f3112079b92d9e22da8b88bf4f0e13d4d67ae9c15c42c30bd25ceb83b6"; + beamDeps = [ + db_connection + ecto + postgrex + telemetry + ]; }; - beamDeps = [ p1_utils ]; - }; + eimp = buildRebar3 rec { + name = "eimp"; + version = "1.0.14"; - elixir_make = buildMix rec { - name = "elixir_make"; - version = "0.7.8"; + src = fetchHex { + pkg = "eimp"; + version = "${version}"; + sha256 = "501133f3112079b92d9e22da8b88bf4f0e13d4d67ae9c15c42c30bd25ceb83b6"; + }; - src = fetchHex { - pkg = "elixir_make"; - version = "${version}"; - sha256 = "7a71945b913d37ea89b06966e1342c85cfe549b15e6d6d081e8081c493062c07"; + beamDeps = [ p1_utils ]; }; - beamDeps = [ castore certifi ]; - }; + elixir_make = buildMix rec { + name = "elixir_make"; + version = "0.7.8"; - erlex = buildMix rec { - name = "erlex"; - version = "0.2.6"; + src = fetchHex { + pkg = "elixir_make"; + version = "${version}"; + sha256 = "7a71945b913d37ea89b06966e1342c85cfe549b15e6d6d081e8081c493062c07"; + }; - src = fetchHex { - pkg = "erlex"; - version = "${version}"; - sha256 = "2ed2e25711feb44d52b17d2780eabf998452f6efda104877a3881c2f8c0c0c75"; + beamDeps = [ + castore + certifi + ]; }; - beamDeps = []; - }; + erlex = buildMix rec { + name = "erlex"; + version = "0.2.6"; - esbuild = buildMix rec { - name = "esbuild"; - version = "0.5.0"; + src = fetchHex { + pkg = "erlex"; + version = "${version}"; + sha256 = "2ed2e25711feb44d52b17d2780eabf998452f6efda104877a3881c2f8c0c0c75"; + }; - src = fetchHex { - pkg = "esbuild"; - version = "${version}"; - sha256 = "f183a0b332d963c4cfaf585477695ea59eef9a6f2204fdd0efa00e099694ffe5"; + beamDeps = [ ]; }; - beamDeps = [ castore ]; - }; + esbuild = buildMix rec { + name = "esbuild"; + version = "0.5.0"; - eternal = buildMix rec { - name = "eternal"; - version = "1.2.2"; + src = fetchHex { + pkg = "esbuild"; + version = "${version}"; + sha256 = "f183a0b332d963c4cfaf585477695ea59eef9a6f2204fdd0efa00e099694ffe5"; + }; - src = fetchHex { - pkg = "eternal"; - version = "${version}"; - sha256 = "2c9fe32b9c3726703ba5e1d43a1d255a4f3f2d8f8f9bc19f094c7cb1a7a9e782"; + beamDeps = [ castore ]; }; - beamDeps = []; - }; + eternal = buildMix rec { + name = "eternal"; + version = "1.2.2"; - ex_aws = buildMix rec { - name = "ex_aws"; - version = "2.1.9"; + src = fetchHex { + pkg = "eternal"; + version = "${version}"; + sha256 = "2c9fe32b9c3726703ba5e1d43a1d255a4f3f2d8f8f9bc19f094c7cb1a7a9e782"; + }; - src = fetchHex { - pkg = "ex_aws"; - version = "${version}"; - sha256 = "3e6c776703c9076001fbe1f7c049535f042cb2afa0d2cbd3b47cbc4e92ac0d10"; + beamDeps = [ ]; }; - beamDeps = [ hackney jason sweet_xml ]; - }; - - ex_aws_s3 = buildMix rec { - name = "ex_aws_s3"; - version = "2.5.3"; - - src = fetchHex { - pkg = "ex_aws_s3"; - version = "${version}"; - sha256 = "4f09dd372cc386550e484808c5ac5027766c8d0cd8271ccc578b82ee6ef4f3b8"; - }; - - beamDeps = [ ex_aws sweet_xml ]; - }; - - ex_const = buildMix rec { - name = "ex_const"; - version = "0.2.4"; - - src = fetchHex { - pkg = "ex_const"; - version = "${version}"; - sha256 = "96fd346610cc992b8f896ed26a98be82ac4efb065a0578f334a32d60a3ba9767"; - }; - - beamDeps = []; - }; - - ex_doc = buildMix rec { - name = "ex_doc"; - version = "0.31.1"; - - src = fetchHex { - pkg = "ex_doc"; - version = "${version}"; - sha256 = "3178c3a407c557d8343479e1ff117a96fd31bafe52a039079593fb0524ef61b0"; - }; - - beamDeps = [ earmark_parser makeup_elixir makeup_erlang ]; - }; - - ex_machina = buildMix rec { - name = "ex_machina"; - version = "2.7.0"; - - src = fetchHex { - pkg = "ex_machina"; - version = "${version}"; - sha256 = "419aa7a39bde11894c87a615c4ecaa52d8f107bbdd81d810465186f783245bf8"; - }; - - beamDeps = [ ecto ecto_sql ]; - }; + ex_aws = buildMix rec { + name = "ex_aws"; + version = "2.1.9"; - ex_syslogger = buildMix rec { - name = "ex_syslogger"; - version = "1.5.2"; + src = fetchHex { + pkg = "ex_aws"; + version = "${version}"; + sha256 = "3e6c776703c9076001fbe1f7c049535f042cb2afa0d2cbd3b47cbc4e92ac0d10"; + }; - src = fetchHex { - pkg = "ex_syslogger"; - version = "${version}"; - sha256 = "ab9fab4136dbc62651ec6f16fa4842f10cf02ab4433fa3d0976c01be99398399"; + beamDeps = [ + hackney + jason + sweet_xml + ]; }; - beamDeps = [ poison syslog ]; - }; + ex_aws_s3 = buildMix rec { + name = "ex_aws_s3"; + version = "2.5.3"; - exile = buildMix rec { - name = "exile"; - version = "0.10.0"; + src = fetchHex { + pkg = "ex_aws_s3"; + version = "${version}"; + sha256 = "4f09dd372cc386550e484808c5ac5027766c8d0cd8271ccc578b82ee6ef4f3b8"; + }; - src = fetchHex { - pkg = "exile"; - version = "${version}"; - sha256 = "c62ee8fee565b5ac4a898d0dcd58d2b04fb5eec1655af1ddcc9eb582c6732c33"; + beamDeps = [ + ex_aws + sweet_xml + ]; }; - beamDeps = [ elixir_make ]; - }; + ex_const = buildMix rec { + name = "ex_const"; + version = "0.2.4"; - expo = buildMix rec { - name = "expo"; - version = "0.5.1"; + src = fetchHex { + pkg = "ex_const"; + version = "${version}"; + sha256 = "96fd346610cc992b8f896ed26a98be82ac4efb065a0578f334a32d60a3ba9767"; + }; - src = fetchHex { - pkg = "expo"; - version = "${version}"; - sha256 = "68a4233b0658a3d12ee00d27d37d856b1ba48607e7ce20fd376958d0ba6ce92b"; + beamDeps = [ ]; }; - beamDeps = []; - }; + ex_doc = buildMix rec { + name = "ex_doc"; + version = "0.31.1"; - fast_html = buildMix rec { - name = "fast_html"; - version = "2.2.0"; + src = fetchHex { + pkg = "ex_doc"; + version = "${version}"; + sha256 = "3178c3a407c557d8343479e1ff117a96fd31bafe52a039079593fb0524ef61b0"; + }; - src = fetchHex { - pkg = "fast_html"; - version = "${version}"; - sha256 = "064c4f23b4a6168f9187dac8984b056f2c531bb0787f559fd6a8b34b38aefbae"; + beamDeps = [ + earmark_parser + makeup_elixir + makeup_erlang + ]; }; - beamDeps = [ elixir_make nimble_pool ]; - }; + ex_machina = buildMix rec { + name = "ex_machina"; + version = "2.7.0"; - fast_sanitize = buildMix rec { - name = "fast_sanitize"; - version = "0.2.3"; + src = fetchHex { + pkg = "ex_machina"; + version = "${version}"; + sha256 = "419aa7a39bde11894c87a615c4ecaa52d8f107bbdd81d810465186f783245bf8"; + }; - src = fetchHex { - pkg = "fast_sanitize"; - version = "${version}"; - sha256 = "e8ad286d10d0386e15d67d0ee125245ebcfbc7d7290b08712ba9013c8c5e56e2"; + beamDeps = [ + ecto + ecto_sql + ]; }; - beamDeps = [ fast_html plug ]; - }; + ex_syslogger = buildMix rec { + name = "ex_syslogger"; + version = "1.5.2"; - file_system = buildMix rec { - name = "file_system"; - version = "0.2.10"; + src = fetchHex { + pkg = "ex_syslogger"; + version = "${version}"; + sha256 = "ab9fab4136dbc62651ec6f16fa4842f10cf02ab4433fa3d0976c01be99398399"; + }; - src = fetchHex { - pkg = "file_system"; - version = "${version}"; - sha256 = "41195edbfb562a593726eda3b3e8b103a309b733ad25f3d642ba49696bf715dc"; + beamDeps = [ + poison + syslog + ]; }; - beamDeps = []; - }; + exile = buildMix rec { + name = "exile"; + version = "0.10.0"; - finch = buildMix rec { - name = "finch"; - version = "0.18.0"; + src = fetchHex { + pkg = "exile"; + version = "${version}"; + sha256 = "c62ee8fee565b5ac4a898d0dcd58d2b04fb5eec1655af1ddcc9eb582c6732c33"; + }; - src = fetchHex { - pkg = "finch"; - version = "${version}"; - sha256 = "69f5045b042e531e53edc2574f15e25e735b522c37e2ddb766e15b979e03aa65"; + beamDeps = [ elixir_make ]; }; - beamDeps = [ castore mime mint nimble_options nimble_pool telemetry ]; - }; + expo = buildMix rec { + name = "expo"; + version = "0.5.1"; - flake_id = buildMix rec { - name = "flake_id"; - version = "0.1.0"; + src = fetchHex { + pkg = "expo"; + version = "${version}"; + sha256 = "68a4233b0658a3d12ee00d27d37d856b1ba48607e7ce20fd376958d0ba6ce92b"; + }; - src = fetchHex { - pkg = "flake_id"; - version = "${version}"; - sha256 = "31fc8090fde1acd267c07c36ea7365b8604055f897d3a53dd967658c691bd827"; + beamDeps = [ ]; }; - beamDeps = [ base62 ecto ]; - }; + fast_html = buildMix rec { + name = "fast_html"; + version = "2.2.0"; - floki = buildMix rec { - name = "floki"; - version = "0.35.2"; + src = fetchHex { + pkg = "fast_html"; + version = "${version}"; + sha256 = "064c4f23b4a6168f9187dac8984b056f2c531bb0787f559fd6a8b34b38aefbae"; + }; - src = fetchHex { - pkg = "floki"; - version = "${version}"; - sha256 = "6b05289a8e9eac475f644f09c2e4ba7e19201fd002b89c28c1293e7bd16773d9"; + beamDeps = [ + elixir_make + nimble_pool + ]; }; - beamDeps = []; - }; + fast_sanitize = buildMix rec { + name = "fast_sanitize"; + version = "0.2.3"; - gen_smtp = buildRebar3 rec { - name = "gen_smtp"; - version = "0.15.0"; + src = fetchHex { + pkg = "fast_sanitize"; + version = "${version}"; + sha256 = "e8ad286d10d0386e15d67d0ee125245ebcfbc7d7290b08712ba9013c8c5e56e2"; + }; - src = fetchHex { - pkg = "gen_smtp"; - version = "${version}"; - sha256 = "29bd14a88030980849c7ed2447b8db6d6c9278a28b11a44cafe41b791205440f"; + beamDeps = [ + fast_html + plug + ]; }; - beamDeps = []; - }; + file_system = buildMix rec { + name = "file_system"; + version = "0.2.10"; - gettext = buildMix rec { - name = "gettext"; - version = "0.24.0"; + src = fetchHex { + pkg = "file_system"; + version = "${version}"; + sha256 = "41195edbfb562a593726eda3b3e8b103a309b733ad25f3d642ba49696bf715dc"; + }; - src = fetchHex { - pkg = "gettext"; - version = "${version}"; - sha256 = "bdf75cdfcbe9e4622dd18e034b227d77dd17f0f133853a1c73b97b3d6c770e8b"; + beamDeps = [ ]; }; - beamDeps = [ expo ]; - }; + finch = buildMix rec { + name = "finch"; + version = "0.18.0"; - gun = buildRebar3 rec { - name = "gun"; - version = "2.0.1"; + src = fetchHex { + pkg = "finch"; + version = "${version}"; + sha256 = "69f5045b042e531e53edc2574f15e25e735b522c37e2ddb766e15b979e03aa65"; + }; - src = fetchHex { - pkg = "gun"; - version = "${version}"; - sha256 = "a10bc8d6096b9502205022334f719cc9a08d9adcfbfc0dbee9ef31b56274a20b"; + beamDeps = [ + castore + mime + mint + nimble_options + nimble_pool + telemetry + ]; }; - beamDeps = [ cowlib ]; - }; + flake_id = buildMix rec { + name = "flake_id"; + version = "0.1.0"; - hackney = buildRebar3 rec { - name = "hackney"; - version = "1.18.2"; + src = fetchHex { + pkg = "flake_id"; + version = "${version}"; + sha256 = "31fc8090fde1acd267c07c36ea7365b8604055f897d3a53dd967658c691bd827"; + }; - src = fetchHex { - pkg = "hackney"; - version = "${version}"; - sha256 = "af94d5c9f97857db257090a4a10e5426ecb6f4918aa5cc666798566ae14b65fd"; + beamDeps = [ + base62 + ecto + ]; }; - beamDeps = [ certifi idna metrics mimerl parse_trans ssl_verify_fun unicode_util_compat ]; - }; + floki = buildMix rec { + name = "floki"; + version = "0.35.2"; - hpax = buildMix rec { - name = "hpax"; - version = "0.2.0"; + src = fetchHex { + pkg = "floki"; + version = "${version}"; + sha256 = "6b05289a8e9eac475f644f09c2e4ba7e19201fd002b89c28c1293e7bd16773d9"; + }; - src = fetchHex { - pkg = "hpax"; - version = "${version}"; - sha256 = "bea06558cdae85bed075e6c036993d43cd54d447f76d8190a8db0dc5893fa2f1"; + beamDeps = [ ]; }; - beamDeps = []; - }; + gen_smtp = buildRebar3 rec { + name = "gen_smtp"; + version = "0.15.0"; - html_entities = buildMix rec { - name = "html_entities"; - version = "0.5.2"; + src = fetchHex { + pkg = "gen_smtp"; + version = "${version}"; + sha256 = "29bd14a88030980849c7ed2447b8db6d6c9278a28b11a44cafe41b791205440f"; + }; - src = fetchHex { - pkg = "html_entities"; - version = "${version}"; - sha256 = "c53ba390403485615623b9531e97696f076ed415e8d8058b1dbaa28181f4fdcc"; + beamDeps = [ ]; }; - beamDeps = []; - }; + gettext = buildMix rec { + name = "gettext"; + version = "0.24.0"; - http_signatures = buildMix rec { - name = "http_signatures"; - version = "0.1.2"; + src = fetchHex { + pkg = "gettext"; + version = "${version}"; + sha256 = "bdf75cdfcbe9e4622dd18e034b227d77dd17f0f133853a1c73b97b3d6c770e8b"; + }; - src = fetchHex { - pkg = "http_signatures"; - version = "${version}"; - sha256 = "f08aa9ac121829dae109d608d83c84b940ef2f183ae50f2dd1e9a8bc619d8be7"; + beamDeps = [ expo ]; }; - beamDeps = []; - }; + gun = buildRebar3 rec { + name = "gun"; + version = "2.0.1"; - httpoison = buildMix rec { - name = "httpoison"; - version = "1.8.2"; + src = fetchHex { + pkg = "gun"; + version = "${version}"; + sha256 = "a10bc8d6096b9502205022334f719cc9a08d9adcfbfc0dbee9ef31b56274a20b"; + }; - src = fetchHex { - pkg = "httpoison"; - version = "${version}"; - sha256 = "2bb350d26972e30c96e2ca74a1aaf8293d61d0742ff17f01e0279fef11599921"; + beamDeps = [ cowlib ]; }; - beamDeps = [ hackney ]; - }; + hackney = buildRebar3 rec { + name = "hackney"; + version = "1.18.2"; - idna = buildRebar3 rec { - name = "idna"; - version = "6.1.1"; + src = fetchHex { + pkg = "hackney"; + version = "${version}"; + sha256 = "af94d5c9f97857db257090a4a10e5426ecb6f4918aa5cc666798566ae14b65fd"; + }; - src = fetchHex { - pkg = "idna"; - version = "${version}"; - sha256 = "92376eb7894412ed19ac475e4a86f7b413c1b9fbb5bd16dccd57934157944cea"; + beamDeps = [ + certifi + idna + metrics + mimerl + parse_trans + ssl_verify_fun + unicode_util_compat + ]; }; - beamDeps = [ unicode_util_compat ]; - }; + hpax = buildMix rec { + name = "hpax"; + version = "0.2.0"; - inet_cidr = buildMix rec { - name = "inet_cidr"; - version = "1.0.8"; + src = fetchHex { + pkg = "hpax"; + version = "${version}"; + sha256 = "bea06558cdae85bed075e6c036993d43cd54d447f76d8190a8db0dc5893fa2f1"; + }; - src = fetchHex { - pkg = "inet_cidr"; - version = "${version}"; - sha256 = "d5b26da66603bb56c933c65214c72152f0de9a6ea53618b56d63302a68f6a90e"; + beamDeps = [ ]; }; - beamDeps = []; - }; + html_entities = buildMix rec { + name = "html_entities"; + version = "0.5.2"; - jason = buildMix rec { - name = "jason"; - version = "1.4.3"; + src = fetchHex { + pkg = "html_entities"; + version = "${version}"; + sha256 = "c53ba390403485615623b9531e97696f076ed415e8d8058b1dbaa28181f4fdcc"; + }; - src = fetchHex { - pkg = "jason"; - version = "${version}"; - sha256 = "9a90e868927f7c777689baa16d86f4d0e086d968db5c05d917ccff6d443e58a3"; + beamDeps = [ ]; }; - beamDeps = [ decimal ]; - }; + http_signatures = buildMix rec { + name = "http_signatures"; + version = "0.1.2"; - joken = buildMix rec { - name = "joken"; - version = "2.6.0"; + src = fetchHex { + pkg = "http_signatures"; + version = "${version}"; + sha256 = "f08aa9ac121829dae109d608d83c84b940ef2f183ae50f2dd1e9a8bc619d8be7"; + }; - src = fetchHex { - pkg = "joken"; - version = "${version}"; - sha256 = "5a95b05a71cd0b54abd35378aeb1d487a23a52c324fa7efdffc512b655b5aaa7"; + beamDeps = [ ]; }; - beamDeps = [ jose ]; - }; + httpoison = buildMix rec { + name = "httpoison"; + version = "1.8.2"; - jose = buildMix rec { - name = "jose"; - version = "1.11.6"; + src = fetchHex { + pkg = "httpoison"; + version = "${version}"; + sha256 = "2bb350d26972e30c96e2ca74a1aaf8293d61d0742ff17f01e0279fef11599921"; + }; - src = fetchHex { - pkg = "jose"; - version = "${version}"; - sha256 = "6275cb75504f9c1e60eeacb771adfeee4905a9e182103aa59b53fed651ff9738"; + beamDeps = [ hackney ]; }; - beamDeps = []; - }; + idna = buildRebar3 rec { + name = "idna"; + version = "6.1.1"; - jumper = buildMix rec { - name = "jumper"; - version = "1.0.2"; + src = fetchHex { + pkg = "idna"; + version = "${version}"; + sha256 = "92376eb7894412ed19ac475e4a86f7b413c1b9fbb5bd16dccd57934157944cea"; + }; - src = fetchHex { - pkg = "jumper"; - version = "${version}"; - sha256 = "9b7782409021e01ab3c08270e26f36eb62976a38c1aa64b2eaf6348422f165e1"; + beamDeps = [ unicode_util_compat ]; }; - beamDeps = []; - }; + inet_cidr = buildMix rec { + name = "inet_cidr"; + version = "1.0.8"; - linkify = buildMix rec { - name = "linkify"; - version = "0.5.3"; + src = fetchHex { + pkg = "inet_cidr"; + version = "${version}"; + sha256 = "d5b26da66603bb56c933c65214c72152f0de9a6ea53618b56d63302a68f6a90e"; + }; - src = fetchHex { - pkg = "linkify"; - version = "${version}"; - sha256 = "3ef35a1377d47c25506e07c1c005ea9d38d700699d92ee92825f024434258177"; + beamDeps = [ ]; }; - beamDeps = []; - }; + jason = buildMix rec { + name = "jason"; + version = "1.4.3"; - logger_backends = buildMix rec { - name = "logger_backends"; - version = "1.0.0"; + src = fetchHex { + pkg = "jason"; + version = "${version}"; + sha256 = "9a90e868927f7c777689baa16d86f4d0e086d968db5c05d917ccff6d443e58a3"; + }; - src = fetchHex { - pkg = "logger_backends"; - version = "${version}"; - sha256 = "1faceb3e7ec3ef66a8f5746c5afd020e63996df6fd4eb8cdb789e5665ae6c9ce"; + beamDeps = [ decimal ]; }; - beamDeps = []; - }; + joken = buildMix rec { + name = "joken"; + version = "2.6.0"; - majic = buildMix rec { - name = "majic"; - version = "1.0.0"; + src = fetchHex { + pkg = "joken"; + version = "${version}"; + sha256 = "5a95b05a71cd0b54abd35378aeb1d487a23a52c324fa7efdffc512b655b5aaa7"; + }; - src = fetchHex { - pkg = "majic"; - version = "${version}"; - sha256 = "7905858f76650d49695f14ea55cd9aaaee0c6654fa391671d4cf305c275a0a9e"; + beamDeps = [ jose ]; }; - beamDeps = [ elixir_make mime nimble_pool plug ]; - }; + jose = buildMix rec { + name = "jose"; + version = "1.11.6"; - makeup = buildMix rec { - name = "makeup"; - version = "1.0.5"; + src = fetchHex { + pkg = "jose"; + version = "${version}"; + sha256 = "6275cb75504f9c1e60eeacb771adfeee4905a9e182103aa59b53fed651ff9738"; + }; - src = fetchHex { - pkg = "makeup"; - version = "${version}"; - sha256 = "cfa158c02d3f5c0c665d0af11512fed3fba0144cf1aadee0f2ce17747fba2ca9"; + beamDeps = [ ]; }; - beamDeps = [ nimble_parsec ]; - }; + jumper = buildMix rec { + name = "jumper"; + version = "1.0.2"; - makeup_elixir = buildMix rec { - name = "makeup_elixir"; - version = "0.14.1"; + src = fetchHex { + pkg = "jumper"; + version = "${version}"; + sha256 = "9b7782409021e01ab3c08270e26f36eb62976a38c1aa64b2eaf6348422f165e1"; + }; - src = fetchHex { - pkg = "makeup_elixir"; - version = "${version}"; - sha256 = "f2438b1a80eaec9ede832b5c41cd4f373b38fd7aa33e3b22d9db79e640cbde11"; + beamDeps = [ ]; }; - beamDeps = [ makeup ]; - }; + linkify = buildMix rec { + name = "linkify"; + version = "0.5.3"; - makeup_erlang = buildMix rec { - name = "makeup_erlang"; - version = "0.1.3"; + src = fetchHex { + pkg = "linkify"; + version = "${version}"; + sha256 = "3ef35a1377d47c25506e07c1c005ea9d38d700699d92ee92825f024434258177"; + }; - src = fetchHex { - pkg = "makeup_erlang"; - version = "${version}"; - sha256 = "b78dc853d2e670ff6390b605d807263bf606da3c82be37f9d7f68635bd886fc9"; + beamDeps = [ ]; }; - beamDeps = [ makeup ]; - }; + logger_backends = buildMix rec { + name = "logger_backends"; + version = "1.0.0"; - meck = buildRebar3 rec { - name = "meck"; - version = "0.9.2"; + src = fetchHex { + pkg = "logger_backends"; + version = "${version}"; + sha256 = "1faceb3e7ec3ef66a8f5746c5afd020e63996df6fd4eb8cdb789e5665ae6c9ce"; + }; - src = fetchHex { - pkg = "meck"; - version = "${version}"; - sha256 = "81344f561357dc40a8344afa53767c32669153355b626ea9fcbc8da6b3045826"; + beamDeps = [ ]; }; - beamDeps = []; - }; + majic = buildMix rec { + name = "majic"; + version = "1.0.0"; - metrics = buildRebar3 rec { - name = "metrics"; - version = "1.0.1"; + src = fetchHex { + pkg = "majic"; + version = "${version}"; + sha256 = "7905858f76650d49695f14ea55cd9aaaee0c6654fa391671d4cf305c275a0a9e"; + }; - src = fetchHex { - pkg = "metrics"; - version = "${version}"; - sha256 = "69b09adddc4f74a40716ae54d140f93beb0fb8978d8636eaded0c31b6f099f16"; + beamDeps = [ + elixir_make + mime + nimble_pool + plug + ]; }; - beamDeps = []; - }; + makeup = buildMix rec { + name = "makeup"; + version = "1.0.5"; - mime = buildMix rec { - name = "mime"; - version = "1.6.0"; + src = fetchHex { + pkg = "makeup"; + version = "${version}"; + sha256 = "cfa158c02d3f5c0c665d0af11512fed3fba0144cf1aadee0f2ce17747fba2ca9"; + }; - src = fetchHex { - pkg = "mime"; - version = "${version}"; - sha256 = "31a1a8613f8321143dde1dafc36006a17d28d02bdfecb9e95a880fa7aabd19a7"; + beamDeps = [ nimble_parsec ]; }; - beamDeps = []; - }; + makeup_elixir = buildMix rec { + name = "makeup_elixir"; + version = "0.14.1"; - mimerl = buildRebar3 rec { - name = "mimerl"; - version = "1.3.0"; + src = fetchHex { + pkg = "makeup_elixir"; + version = "${version}"; + sha256 = "f2438b1a80eaec9ede832b5c41cd4f373b38fd7aa33e3b22d9db79e640cbde11"; + }; - src = fetchHex { - pkg = "mimerl"; - version = "${version}"; - sha256 = "a1e15a50d1887217de95f0b9b0793e32853f7c258a5cd227650889b38839fe9d"; + beamDeps = [ makeup ]; }; - beamDeps = []; - }; + makeup_erlang = buildMix rec { + name = "makeup_erlang"; + version = "0.1.3"; - mint = buildMix rec { - name = "mint"; - version = "1.6.1"; + src = fetchHex { + pkg = "makeup_erlang"; + version = "${version}"; + sha256 = "b78dc853d2e670ff6390b605d807263bf606da3c82be37f9d7f68635bd886fc9"; + }; - src = fetchHex { - pkg = "mint"; - version = "${version}"; - sha256 = "4fc518dcc191d02f433393a72a7ba3f6f94b101d094cb6bf532ea54c89423780"; + beamDeps = [ makeup ]; }; - beamDeps = [ castore hpax ]; - }; + meck = buildRebar3 rec { + name = "meck"; + version = "0.9.2"; - mochiweb = buildRebar3 rec { - name = "mochiweb"; - version = "2.18.0"; + src = fetchHex { + pkg = "meck"; + version = "${version}"; + sha256 = "81344f561357dc40a8344afa53767c32669153355b626ea9fcbc8da6b3045826"; + }; - src = fetchHex { - pkg = "mochiweb"; - version = "${version}"; - sha256 = "16j8cfn3hq0g474xc5xl8nk2v46hwvwpfwi9rkzavnsbaqg2ngmr"; + beamDeps = [ ]; }; - beamDeps = []; - }; + metrics = buildRebar3 rec { + name = "metrics"; + version = "1.0.1"; - mock = buildMix rec { - name = "mock"; - version = "0.3.8"; + src = fetchHex { + pkg = "metrics"; + version = "${version}"; + sha256 = "69b09adddc4f74a40716ae54d140f93beb0fb8978d8636eaded0c31b6f099f16"; + }; - src = fetchHex { - pkg = "mock"; - version = "${version}"; - sha256 = "7fa82364c97617d79bb7d15571193fc0c4fe5afd0c932cef09426b3ee6fe2022"; + beamDeps = [ ]; }; - beamDeps = [ meck ]; - }; + mime = buildMix rec { + name = "mime"; + version = "1.6.0"; - mogrify = buildMix rec { - name = "mogrify"; - version = "0.8.0"; + src = fetchHex { + pkg = "mime"; + version = "${version}"; + sha256 = "31a1a8613f8321143dde1dafc36006a17d28d02bdfecb9e95a880fa7aabd19a7"; + }; - src = fetchHex { - pkg = "mogrify"; - version = "${version}"; - sha256 = "2278d245f07056ea3b586e98801e933695147066fa4cf563f552c1b4f0ff8ad9"; + beamDeps = [ ]; }; - beamDeps = []; - }; + mimerl = buildRebar3 rec { + name = "mimerl"; + version = "1.3.0"; - mox = buildMix rec { - name = "mox"; - version = "1.1.0"; + src = fetchHex { + pkg = "mimerl"; + version = "${version}"; + sha256 = "a1e15a50d1887217de95f0b9b0793e32853f7c258a5cd227650889b38839fe9d"; + }; - src = fetchHex { - pkg = "mox"; - version = "${version}"; - sha256 = "d44474c50be02d5b72131070281a5d3895c0e7a95c780e90bc0cfe712f633a13"; + beamDeps = [ ]; }; - beamDeps = []; - }; + mint = buildMix rec { + name = "mint"; + version = "1.6.1"; - nimble_options = buildMix rec { - name = "nimble_options"; - version = "1.1.1"; + src = fetchHex { + pkg = "mint"; + version = "${version}"; + sha256 = "4fc518dcc191d02f433393a72a7ba3f6f94b101d094cb6bf532ea54c89423780"; + }; - src = fetchHex { - pkg = "nimble_options"; - version = "${version}"; - sha256 = "821b2470ca9442c4b6984882fe9bb0389371b8ddec4d45a9504f00a66f650b44"; + beamDeps = [ + castore + hpax + ]; }; - beamDeps = []; - }; + mochiweb = buildRebar3 rec { + name = "mochiweb"; + version = "2.18.0"; - nimble_parsec = buildMix rec { - name = "nimble_parsec"; - version = "0.6.0"; + src = fetchHex { + pkg = "mochiweb"; + version = "${version}"; + sha256 = "16j8cfn3hq0g474xc5xl8nk2v46hwvwpfwi9rkzavnsbaqg2ngmr"; + }; - src = fetchHex { - pkg = "nimble_parsec"; - version = "${version}"; - sha256 = "27eac315a94909d4dc68bc07a4a83e06c8379237c5ea528a9acff4ca1c873c52"; + beamDeps = [ ]; }; - beamDeps = []; - }; + mock = buildMix rec { + name = "mock"; + version = "0.3.8"; - nimble_pool = buildMix rec { - name = "nimble_pool"; - version = "0.2.6"; + src = fetchHex { + pkg = "mock"; + version = "${version}"; + sha256 = "7fa82364c97617d79bb7d15571193fc0c4fe5afd0c932cef09426b3ee6fe2022"; + }; - src = fetchHex { - pkg = "nimble_pool"; - version = "${version}"; - sha256 = "1c715055095d3f2705c4e236c18b618420a35490da94149ff8b580a2144f653f"; + beamDeps = [ meck ]; }; - beamDeps = []; - }; + mogrify = buildMix rec { + name = "mogrify"; + version = "0.8.0"; - oban = buildMix rec { - name = "oban"; - version = "2.17.12"; + src = fetchHex { + pkg = "mogrify"; + version = "${version}"; + sha256 = "2278d245f07056ea3b586e98801e933695147066fa4cf563f552c1b4f0ff8ad9"; + }; - src = fetchHex { - pkg = "oban"; - version = "${version}"; - sha256 = "7a647d6cd6bb300073db17faabce22d80ae135da3baf3180a064fa7c4fa046e3"; + beamDeps = [ ]; }; - beamDeps = [ ecto_sql jason postgrex telemetry ]; - }; + mox = buildMix rec { + name = "mox"; + version = "1.1.0"; - oban_live_dashboard = buildMix rec { - name = "oban_live_dashboard"; - version = "0.1.1"; + src = fetchHex { + pkg = "mox"; + version = "${version}"; + sha256 = "d44474c50be02d5b72131070281a5d3895c0e7a95c780e90bc0cfe712f633a13"; + }; - src = fetchHex { - pkg = "oban_live_dashboard"; - version = "${version}"; - sha256 = "16dc4ce9c9a95aa2e655e35ed4e675652994a8def61731a18af85e230e1caa63"; + beamDeps = [ ]; }; - beamDeps = [ oban phoenix_live_dashboard ]; - }; + nimble_options = buildMix rec { + name = "nimble_options"; + version = "1.1.1"; - octo_fetch = buildMix rec { - name = "octo_fetch"; - version = "0.4.0"; + src = fetchHex { + pkg = "nimble_options"; + version = "${version}"; + sha256 = "821b2470ca9442c4b6984882fe9bb0389371b8ddec4d45a9504f00a66f650b44"; + }; - src = fetchHex { - pkg = "octo_fetch"; - version = "${version}"; - sha256 = "cf8be6f40cd519d7000bb4e84adcf661c32e59369ca2827c4e20042eda7a7fc6"; + beamDeps = [ ]; }; - beamDeps = [ castore ssl_verify_fun ]; - }; + nimble_parsec = buildMix rec { + name = "nimble_parsec"; + version = "0.6.0"; - open_api_spex = buildMix rec { - name = "open_api_spex"; - version = "3.18.2"; + src = fetchHex { + pkg = "nimble_parsec"; + version = "${version}"; + sha256 = "27eac315a94909d4dc68bc07a4a83e06c8379237c5ea528a9acff4ca1c873c52"; + }; - src = fetchHex { - pkg = "open_api_spex"; - version = "${version}"; - sha256 = "aa3e6dcfc0ad6a02596b2172662da21c9dd848dac145ea9e603f54e3d81b8d2b"; + beamDeps = [ ]; }; - beamDeps = [ jason plug poison ]; - }; + nimble_pool = buildMix rec { + name = "nimble_pool"; + version = "0.2.6"; - parse_trans = buildRebar3 rec { - name = "parse_trans"; - version = "3.4.1"; + src = fetchHex { + pkg = "nimble_pool"; + version = "${version}"; + sha256 = "1c715055095d3f2705c4e236c18b618420a35490da94149ff8b580a2144f653f"; + }; - src = fetchHex { - pkg = "parse_trans"; - version = "${version}"; - sha256 = "620a406ce75dada827b82e453c19cf06776be266f5a67cff34e1ef2cbb60e49a"; + beamDeps = [ ]; }; - beamDeps = []; - }; + oban = buildMix rec { + name = "oban"; + version = "2.17.12"; - pbkdf2_elixir = buildMix rec { - name = "pbkdf2_elixir"; - version = "1.2.1"; + src = fetchHex { + pkg = "oban"; + version = "${version}"; + sha256 = "7a647d6cd6bb300073db17faabce22d80ae135da3baf3180a064fa7c4fa046e3"; + }; - src = fetchHex { - pkg = "pbkdf2_elixir"; - version = "${version}"; - sha256 = "d3b40a4a4630f0b442f19eca891fcfeeee4c40871936fed2f68e1c4faa30481f"; + beamDeps = [ + ecto_sql + jason + postgrex + telemetry + ]; }; - beamDeps = [ comeonin ]; - }; + oban_live_dashboard = buildMix rec { + name = "oban_live_dashboard"; + version = "0.1.1"; - phoenix = buildMix rec { - name = "phoenix"; - version = "1.7.14"; + src = fetchHex { + pkg = "oban_live_dashboard"; + version = "${version}"; + sha256 = "16dc4ce9c9a95aa2e655e35ed4e675652994a8def61731a18af85e230e1caa63"; + }; - src = fetchHex { - pkg = "phoenix"; - version = "${version}"; - sha256 = "c7859bc56cc5dfef19ecfc240775dae358cbaa530231118a9e014df392ace61a"; + beamDeps = [ + oban + phoenix_live_dashboard + ]; }; - beamDeps = [ castore jason phoenix_pubsub phoenix_template phoenix_view plug plug_cowboy plug_crypto telemetry websock_adapter ]; - }; + octo_fetch = buildMix rec { + name = "octo_fetch"; + version = "0.4.0"; - phoenix_ecto = buildMix rec { - name = "phoenix_ecto"; - version = "4.4.3"; + src = fetchHex { + pkg = "octo_fetch"; + version = "${version}"; + sha256 = "cf8be6f40cd519d7000bb4e84adcf661c32e59369ca2827c4e20042eda7a7fc6"; + }; - src = fetchHex { - pkg = "phoenix_ecto"; - version = "${version}"; - sha256 = "d36c401206f3011fefd63d04e8ef626ec8791975d9d107f9a0817d426f61ac07"; + beamDeps = [ + castore + ssl_verify_fun + ]; }; - beamDeps = [ ecto phoenix_html plug ]; - }; + open_api_spex = buildMix rec { + name = "open_api_spex"; + version = "3.18.2"; - phoenix_html = buildMix rec { - name = "phoenix_html"; - version = "3.3.4"; + src = fetchHex { + pkg = "open_api_spex"; + version = "${version}"; + sha256 = "aa3e6dcfc0ad6a02596b2172662da21c9dd848dac145ea9e603f54e3d81b8d2b"; + }; - src = fetchHex { - pkg = "phoenix_html"; - version = "${version}"; - sha256 = "0249d3abec3714aff3415e7ee3d9786cb325be3151e6c4b3021502c585bf53fb"; + beamDeps = [ + jason + plug + poison + ]; }; - beamDeps = [ plug ]; - }; - - phoenix_live_dashboard = buildMix rec { - name = "phoenix_live_dashboard"; - version = "0.8.3"; + parse_trans = buildRebar3 rec { + name = "parse_trans"; + version = "3.4.1"; - src = fetchHex { - pkg = "phoenix_live_dashboard"; - version = "${version}"; - sha256 = "f9470a0a8bae4f56430a23d42f977b5a6205fdba6559d76f932b876bfaec652d"; - }; - - beamDeps = [ ecto ecto_psql_extras mime phoenix_live_view telemetry_metrics ]; - }; + src = fetchHex { + pkg = "parse_trans"; + version = "${version}"; + sha256 = "620a406ce75dada827b82e453c19cf06776be266f5a67cff34e1ef2cbb60e49a"; + }; - phoenix_live_reload = buildMix rec { - name = "phoenix_live_reload"; - version = "1.3.3"; + beamDeps = [ ]; + }; + + pbkdf2_elixir = buildMix rec { + name = "pbkdf2_elixir"; + version = "1.2.1"; - src = fetchHex { - pkg = "phoenix_live_reload"; - version = "${version}"; - sha256 = "766796676e5f558dbae5d1bdb066849673e956005e3730dfd5affd7a6da4abac"; + src = fetchHex { + pkg = "pbkdf2_elixir"; + version = "${version}"; + sha256 = "d3b40a4a4630f0b442f19eca891fcfeeee4c40871936fed2f68e1c4faa30481f"; + }; + + beamDeps = [ comeonin ]; + }; + + phoenix = buildMix rec { + name = "phoenix"; + version = "1.7.14"; + + src = fetchHex { + pkg = "phoenix"; + version = "${version}"; + sha256 = "c7859bc56cc5dfef19ecfc240775dae358cbaa530231118a9e014df392ace61a"; + }; + + beamDeps = [ + castore + jason + phoenix_pubsub + phoenix_template + phoenix_view + plug + plug_cowboy + plug_crypto + telemetry + websock_adapter + ]; }; - beamDeps = [ file_system phoenix ]; - }; - - phoenix_live_view = buildMix rec { - name = "phoenix_live_view"; - version = "0.19.5"; - - src = fetchHex { - pkg = "phoenix_live_view"; - version = "${version}"; - sha256 = "b2eaa0dd3cfb9bd7fb949b88217df9f25aed915e986a28ad5c8a0d054e7ca9d3"; + phoenix_ecto = buildMix rec { + name = "phoenix_ecto"; + version = "4.4.3"; + + src = fetchHex { + pkg = "phoenix_ecto"; + version = "${version}"; + sha256 = "d36c401206f3011fefd63d04e8ef626ec8791975d9d107f9a0817d426f61ac07"; + }; + + beamDeps = [ + ecto + phoenix_html + plug + ]; + }; + + phoenix_html = buildMix rec { + name = "phoenix_html"; + version = "3.3.4"; + + src = fetchHex { + pkg = "phoenix_html"; + version = "${version}"; + sha256 = "0249d3abec3714aff3415e7ee3d9786cb325be3151e6c4b3021502c585bf53fb"; + }; + + beamDeps = [ plug ]; + }; + + phoenix_live_dashboard = buildMix rec { + name = "phoenix_live_dashboard"; + version = "0.8.3"; + + src = fetchHex { + pkg = "phoenix_live_dashboard"; + version = "${version}"; + sha256 = "f9470a0a8bae4f56430a23d42f977b5a6205fdba6559d76f932b876bfaec652d"; + }; + + beamDeps = [ + ecto + ecto_psql_extras + mime + phoenix_live_view + telemetry_metrics + ]; }; - beamDeps = [ jason phoenix phoenix_html phoenix_template phoenix_view telemetry ]; - }; - - phoenix_pubsub = buildMix rec { - name = "phoenix_pubsub"; - version = "2.1.3"; + phoenix_live_reload = buildMix rec { + name = "phoenix_live_reload"; + version = "1.3.3"; + + src = fetchHex { + pkg = "phoenix_live_reload"; + version = "${version}"; + sha256 = "766796676e5f558dbae5d1bdb066849673e956005e3730dfd5affd7a6da4abac"; + }; + + beamDeps = [ + file_system + phoenix + ]; + }; + + phoenix_live_view = buildMix rec { + name = "phoenix_live_view"; + version = "0.19.5"; + + src = fetchHex { + pkg = "phoenix_live_view"; + version = "${version}"; + sha256 = "b2eaa0dd3cfb9bd7fb949b88217df9f25aed915e986a28ad5c8a0d054e7ca9d3"; + }; + + beamDeps = [ + jason + phoenix + phoenix_html + phoenix_template + phoenix_view + telemetry + ]; + }; + + phoenix_pubsub = buildMix rec { + name = "phoenix_pubsub"; + version = "2.1.3"; + + src = fetchHex { + pkg = "phoenix_pubsub"; + version = "${version}"; + sha256 = "bba06bc1dcfd8cb086759f0edc94a8ba2bc8896d5331a1e2c2902bf8e36ee502"; + }; - src = fetchHex { - pkg = "phoenix_pubsub"; - version = "${version}"; - sha256 = "bba06bc1dcfd8cb086759f0edc94a8ba2bc8896d5331a1e2c2902bf8e36ee502"; + beamDeps = [ ]; }; - beamDeps = []; - }; - - phoenix_swoosh = buildMix rec { - name = "phoenix_swoosh"; - version = "1.2.1"; + phoenix_swoosh = buildMix rec { + name = "phoenix_swoosh"; + version = "1.2.1"; + + src = fetchHex { + pkg = "phoenix_swoosh"; + version = "${version}"; + sha256 = "4000eeba3f9d7d1a6bf56d2bd56733d5cadf41a7f0d8ffe5bb67e7d667e204a2"; + }; - src = fetchHex { - pkg = "phoenix_swoosh"; - version = "${version}"; - sha256 = "4000eeba3f9d7d1a6bf56d2bd56733d5cadf41a7f0d8ffe5bb67e7d667e204a2"; + beamDeps = [ + finch + hackney + phoenix + phoenix_html + phoenix_view + swoosh + ]; }; - beamDeps = [ finch hackney phoenix phoenix_html phoenix_view swoosh ]; - }; + phoenix_template = buildMix rec { + name = "phoenix_template"; + version = "1.0.4"; - phoenix_template = buildMix rec { - name = "phoenix_template"; - version = "1.0.4"; + src = fetchHex { + pkg = "phoenix_template"; + version = "${version}"; + sha256 = "2c0c81f0e5c6753faf5cca2f229c9709919aba34fab866d3bc05060c9c444206"; + }; - src = fetchHex { - pkg = "phoenix_template"; - version = "${version}"; - sha256 = "2c0c81f0e5c6753faf5cca2f229c9709919aba34fab866d3bc05060c9c444206"; + beamDeps = [ phoenix_html ]; }; - beamDeps = [ phoenix_html ]; - }; + phoenix_view = buildMix rec { + name = "phoenix_view"; + version = "2.0.4"; - phoenix_view = buildMix rec { - name = "phoenix_view"; - version = "2.0.4"; + src = fetchHex { + pkg = "phoenix_view"; + version = "${version}"; + sha256 = "4e992022ce14f31fe57335db27a28154afcc94e9983266835bb3040243eb620b"; + }; - src = fetchHex { - pkg = "phoenix_view"; - version = "${version}"; - sha256 = "4e992022ce14f31fe57335db27a28154afcc94e9983266835bb3040243eb620b"; + beamDeps = [ + phoenix_html + phoenix_template + ]; }; - beamDeps = [ phoenix_html phoenix_template ]; - }; + plug = buildMix rec { + name = "plug"; + version = "1.16.1"; - plug = buildMix rec { - name = "plug"; - version = "1.16.1"; + src = fetchHex { + pkg = "plug"; + version = "${version}"; + sha256 = "a13ff6b9006b03d7e33874945b2755253841b238c34071ed85b0e86057f8cddc"; + }; - src = fetchHex { - pkg = "plug"; - version = "${version}"; - sha256 = "a13ff6b9006b03d7e33874945b2755253841b238c34071ed85b0e86057f8cddc"; + beamDeps = [ + mime + plug_crypto + telemetry + ]; }; - beamDeps = [ mime plug_crypto telemetry ]; - }; + plug_cowboy = buildMix rec { + name = "plug_cowboy"; + version = "2.7.1"; - plug_cowboy = buildMix rec { - name = "plug_cowboy"; - version = "2.7.1"; + src = fetchHex { + pkg = "plug_cowboy"; + version = "${version}"; + sha256 = "02dbd5f9ab571b864ae39418db7811618506256f6d13b4a45037e5fe78dc5de3"; + }; - src = fetchHex { - pkg = "plug_cowboy"; - version = "${version}"; - sha256 = "02dbd5f9ab571b864ae39418db7811618506256f6d13b4a45037e5fe78dc5de3"; + beamDeps = [ + cowboy + cowboy_telemetry + plug + ]; }; - beamDeps = [ cowboy cowboy_telemetry plug ]; - }; + plug_crypto = buildMix rec { + name = "plug_crypto"; + version = "2.1.0"; - plug_crypto = buildMix rec { - name = "plug_crypto"; - version = "2.1.0"; + src = fetchHex { + pkg = "plug_crypto"; + version = "${version}"; + sha256 = "131216a4b030b8f8ce0f26038bc4421ae60e4bb95c5cf5395e1421437824c4fa"; + }; - src = fetchHex { - pkg = "plug_crypto"; - version = "${version}"; - sha256 = "131216a4b030b8f8ce0f26038bc4421ae60e4bb95c5cf5395e1421437824c4fa"; + beamDeps = [ ]; }; - beamDeps = []; - }; + plug_static_index_html = buildMix rec { + name = "plug_static_index_html"; + version = "1.0.0"; - plug_static_index_html = buildMix rec { - name = "plug_static_index_html"; - version = "1.0.0"; + src = fetchHex { + pkg = "plug_static_index_html"; + version = "${version}"; + sha256 = "79fd4fcf34d110605c26560cbae8f23c603ec4158c08298bd4360fdea90bb5cf"; + }; - src = fetchHex { - pkg = "plug_static_index_html"; - version = "${version}"; - sha256 = "79fd4fcf34d110605c26560cbae8f23c603ec4158c08298bd4360fdea90bb5cf"; + beamDeps = [ plug ]; }; - beamDeps = [ plug ]; - }; + poison = buildMix rec { + name = "poison"; + version = "3.1.0"; - poison = buildMix rec { - name = "poison"; - version = "3.1.0"; + src = fetchHex { + pkg = "poison"; + version = "${version}"; + sha256 = "fec8660eb7733ee4117b85f55799fd3833eb769a6df71ccf8903e8dc5447cfce"; + }; - src = fetchHex { - pkg = "poison"; - version = "${version}"; - sha256 = "fec8660eb7733ee4117b85f55799fd3833eb769a6df71ccf8903e8dc5447cfce"; + beamDeps = [ ]; }; - beamDeps = []; - }; + poolboy = buildRebar3 rec { + name = "poolboy"; + version = "1.5.2"; - poolboy = buildRebar3 rec { - name = "poolboy"; - version = "1.5.2"; + src = fetchHex { + pkg = "poolboy"; + version = "${version}"; + sha256 = "dad79704ce5440f3d5a3681c8590b9dc25d1a561e8f5a9c995281012860901e3"; + }; - src = fetchHex { - pkg = "poolboy"; - version = "${version}"; - sha256 = "dad79704ce5440f3d5a3681c8590b9dc25d1a561e8f5a9c995281012860901e3"; + beamDeps = [ ]; }; - beamDeps = []; - }; + postgrex = buildMix rec { + name = "postgrex"; + version = "0.17.5"; - postgrex = buildMix rec { - name = "postgrex"; - version = "0.17.5"; + src = fetchHex { + pkg = "postgrex"; + version = "${version}"; + sha256 = "50b8b11afbb2c4095a3ba675b4f055c416d0f3d7de6633a595fc131a828a67eb"; + }; - src = fetchHex { - pkg = "postgrex"; - version = "${version}"; - sha256 = "50b8b11afbb2c4095a3ba675b4f055c416d0f3d7de6633a595fc131a828a67eb"; + beamDeps = [ + db_connection + decimal + jason + ]; }; - beamDeps = [ db_connection decimal jason ]; - }; + pot = buildRebar3 rec { + name = "pot"; + version = "1.0.2"; - pot = buildRebar3 rec { - name = "pot"; - version = "1.0.2"; + src = fetchHex { + pkg = "pot"; + version = "${version}"; + sha256 = "78fe127f5a4f5f919d6ea5a2a671827bd53eb9d37e5b4128c0ad3df99856c2e0"; + }; - src = fetchHex { - pkg = "pot"; - version = "${version}"; - sha256 = "78fe127f5a4f5f919d6ea5a2a671827bd53eb9d37e5b4128c0ad3df99856c2e0"; + beamDeps = [ ]; }; - beamDeps = []; - }; + prom_ex = buildMix rec { + name = "prom_ex"; + version = "1.9.0"; - prom_ex = buildMix rec { - name = "prom_ex"; - version = "1.9.0"; + src = fetchHex { + pkg = "prom_ex"; + version = "${version}"; + sha256 = "01f3d4f69ec93068219e686cc65e58a29c42bea5429a8ff4e2121f19db178ee6"; + }; - src = fetchHex { - pkg = "prom_ex"; - version = "${version}"; - sha256 = "01f3d4f69ec93068219e686cc65e58a29c42bea5429a8ff4e2121f19db178ee6"; + beamDeps = [ + ecto + finch + jason + oban + octo_fetch + phoenix + phoenix_live_view + plug + plug_cowboy + telemetry + telemetry_metrics + telemetry_metrics_prometheus_core + telemetry_poller + ]; }; - beamDeps = [ ecto finch jason oban octo_fetch phoenix phoenix_live_view plug plug_cowboy telemetry telemetry_metrics telemetry_metrics_prometheus_core telemetry_poller ]; - }; + prometheus = buildMix rec { + name = "prometheus"; + version = "4.10.0"; - prometheus = buildMix rec { - name = "prometheus"; - version = "4.10.0"; + src = fetchHex { + pkg = "prometheus"; + version = "${version}"; + sha256 = "2a99bb6dce85e238c7236fde6b0064f9834dc420ddbd962aac4ea2a3c3d59384"; + }; - src = fetchHex { - pkg = "prometheus"; - version = "${version}"; - sha256 = "2a99bb6dce85e238c7236fde6b0064f9834dc420ddbd962aac4ea2a3c3d59384"; + beamDeps = [ quantile_estimator ]; }; - beamDeps = [ quantile_estimator ]; - }; + prometheus_ecto = buildMix rec { + name = "prometheus_ecto"; + version = "1.4.3"; - prometheus_ecto = buildMix rec { - name = "prometheus_ecto"; - version = "1.4.3"; + src = fetchHex { + pkg = "prometheus_ecto"; + version = "${version}"; + sha256 = "8d66289f77f913b37eda81fd287340c17e61a447549deb28efc254532b2bed82"; + }; - src = fetchHex { - pkg = "prometheus_ecto"; - version = "${version}"; - sha256 = "8d66289f77f913b37eda81fd287340c17e61a447549deb28efc254532b2bed82"; + beamDeps = [ + ecto + prometheus_ex + ]; }; - beamDeps = [ ecto prometheus_ex ]; - }; + prometheus_plugs = buildMix rec { + name = "prometheus_plugs"; + version = "1.1.5"; - prometheus_plugs = buildMix rec { - name = "prometheus_plugs"; - version = "1.1.5"; + src = fetchHex { + pkg = "prometheus_plugs"; + version = "${version}"; + sha256 = "0273a6483ccb936d79ca19b0ab629aef0dba958697c94782bb728b920dfc6a79"; + }; - src = fetchHex { - pkg = "prometheus_plugs"; - version = "${version}"; - sha256 = "0273a6483ccb936d79ca19b0ab629aef0dba958697c94782bb728b920dfc6a79"; + beamDeps = [ + accept + plug + prometheus_ex + ]; }; - beamDeps = [ accept plug prometheus_ex ]; - }; + quantile_estimator = buildRebar3 rec { + name = "quantile_estimator"; + version = "0.2.1"; - quantile_estimator = buildRebar3 rec { - name = "quantile_estimator"; - version = "0.2.1"; + src = fetchHex { + pkg = "quantile_estimator"; + version = "${version}"; + sha256 = "282a8a323ca2a845c9e6f787d166348f776c1d4a41ede63046d72d422e3da946"; + }; - src = fetchHex { - pkg = "quantile_estimator"; - version = "${version}"; - sha256 = "282a8a323ca2a845c9e6f787d166348f776c1d4a41ede63046d72d422e3da946"; + beamDeps = [ ]; }; - beamDeps = []; - }; + ranch = buildRebar3 rec { + name = "ranch"; + version = "1.8.0"; - ranch = buildRebar3 rec { - name = "ranch"; - version = "1.8.0"; + src = fetchHex { + pkg = "ranch"; + version = "${version}"; + sha256 = "49fbcfd3682fab1f5d109351b61257676da1a2fdbe295904176d5e521a2ddfe5"; + }; - src = fetchHex { - pkg = "ranch"; - version = "${version}"; - sha256 = "49fbcfd3682fab1f5d109351b61257676da1a2fdbe295904176d5e521a2ddfe5"; + beamDeps = [ ]; }; - beamDeps = []; - }; + recon = buildMix rec { + name = "recon"; + version = "2.5.4"; - recon = buildMix rec { - name = "recon"; - version = "2.5.4"; + src = fetchHex { + pkg = "recon"; + version = "${version}"; + sha256 = "e9ab01ac7fc8572e41eb59385efeb3fb0ff5bf02103816535bacaedf327d0263"; + }; - src = fetchHex { - pkg = "recon"; - version = "${version}"; - sha256 = "e9ab01ac7fc8572e41eb59385efeb3fb0ff5bf02103816535bacaedf327d0263"; + beamDeps = [ ]; }; - beamDeps = []; - }; + rustler = buildMix rec { + name = "rustler"; + version = "0.30.0"; - rustler = buildMix rec { - name = "rustler"; - version = "0.30.0"; + src = fetchHex { + pkg = "rustler"; + version = "${version}"; + sha256 = "9ef1abb6a7dda35c47cfc649e6a5a61663af6cf842a55814a554a84607dee389"; + }; - src = fetchHex { - pkg = "rustler"; - version = "${version}"; - sha256 = "9ef1abb6a7dda35c47cfc649e6a5a61663af6cf842a55814a554a84607dee389"; + beamDeps = [ + jason + toml + ]; }; - beamDeps = [ jason toml ]; - }; + sleeplocks = buildRebar3 rec { + name = "sleeplocks"; + version = "1.1.2"; - sleeplocks = buildRebar3 rec { - name = "sleeplocks"; - version = "1.1.2"; + src = fetchHex { + pkg = "sleeplocks"; + version = "${version}"; + sha256 = "9fe5d048c5b781d6305c1a3a0f40bb3dfc06f49bf40571f3d2d0c57eaa7f59a5"; + }; - src = fetchHex { - pkg = "sleeplocks"; - version = "${version}"; - sha256 = "9fe5d048c5b781d6305c1a3a0f40bb3dfc06f49bf40571f3d2d0c57eaa7f59a5"; + beamDeps = [ ]; }; - beamDeps = []; - }; + ssl_verify_fun = buildRebar3 rec { + name = "ssl_verify_fun"; + version = "1.1.7"; - ssl_verify_fun = buildRebar3 rec { - name = "ssl_verify_fun"; - version = "1.1.7"; + src = fetchHex { + pkg = "ssl_verify_fun"; + version = "${version}"; + sha256 = "fe4c190e8f37401d30167c8c405eda19469f34577987c76dde613e838bbc67f8"; + }; - src = fetchHex { - pkg = "ssl_verify_fun"; - version = "${version}"; - sha256 = "fe4c190e8f37401d30167c8c405eda19469f34577987c76dde613e838bbc67f8"; + beamDeps = [ ]; }; - beamDeps = []; - }; + statistex = buildMix rec { + name = "statistex"; + version = "1.0.0"; - statistex = buildMix rec { - name = "statistex"; - version = "1.0.0"; + src = fetchHex { + pkg = "statistex"; + version = "${version}"; + sha256 = "ff9d8bee7035028ab4742ff52fc80a2aa35cece833cf5319009b52f1b5a86c27"; + }; - src = fetchHex { - pkg = "statistex"; - version = "${version}"; - sha256 = "ff9d8bee7035028ab4742ff52fc80a2aa35cece833cf5319009b52f1b5a86c27"; + beamDeps = [ ]; }; - beamDeps = []; - }; + sweet_xml = buildMix rec { + name = "sweet_xml"; + version = "0.7.4"; - sweet_xml = buildMix rec { - name = "sweet_xml"; - version = "0.7.4"; + src = fetchHex { + pkg = "sweet_xml"; + version = "${version}"; + sha256 = "e7c4b0bdbf460c928234951def54fe87edf1a170f6896675443279e2dbeba167"; + }; - src = fetchHex { - pkg = "sweet_xml"; - version = "${version}"; - sha256 = "e7c4b0bdbf460c928234951def54fe87edf1a170f6896675443279e2dbeba167"; + beamDeps = [ ]; }; - beamDeps = []; - }; + swoosh = buildMix rec { + name = "swoosh"; + version = "1.16.9"; - swoosh = buildMix rec { - name = "swoosh"; - version = "1.16.9"; + src = fetchHex { + pkg = "swoosh"; + version = "${version}"; + sha256 = "878b1a7a6c10ebbf725a3349363f48f79c5e3d792eb621643b0d276a38acc0a6"; + }; - src = fetchHex { - pkg = "swoosh"; - version = "${version}"; - sha256 = "878b1a7a6c10ebbf725a3349363f48f79c5e3d792eb621643b0d276a38acc0a6"; + beamDeps = [ + bandit + cowboy + ex_aws + finch + gen_smtp + hackney + jason + mime + plug + plug_cowboy + telemetry + ]; }; - beamDeps = [ bandit cowboy ex_aws finch gen_smtp hackney jason mime plug plug_cowboy telemetry ]; - }; + syslog = buildRebar3 rec { + name = "syslog"; + version = "1.1.0"; - syslog = buildRebar3 rec { - name = "syslog"; - version = "1.1.0"; + src = fetchHex { + pkg = "syslog"; + version = "${version}"; + sha256 = "4c6a41373c7e20587be33ef841d3de6f3beba08519809329ecc4d27b15b659e1"; + }; - src = fetchHex { - pkg = "syslog"; - version = "${version}"; - sha256 = "4c6a41373c7e20587be33ef841d3de6f3beba08519809329ecc4d27b15b659e1"; + beamDeps = [ ]; }; - beamDeps = []; - }; + table_rex = buildMix rec { + name = "table_rex"; + version = "4.0.0"; - table_rex = buildMix rec { - name = "table_rex"; - version = "4.0.0"; + src = fetchHex { + pkg = "table_rex"; + version = "${version}"; + sha256 = "c35c4d5612ca49ebb0344ea10387da4d2afe278387d4019e4d8111e815df8f55"; + }; - src = fetchHex { - pkg = "table_rex"; - version = "${version}"; - sha256 = "c35c4d5612ca49ebb0344ea10387da4d2afe278387d4019e4d8111e815df8f55"; + beamDeps = [ ]; }; - beamDeps = []; - }; + telemetry = buildRebar3 rec { + name = "telemetry"; + version = "1.0.0"; - telemetry = buildRebar3 rec { - name = "telemetry"; - version = "1.0.0"; + src = fetchHex { + pkg = "telemetry"; + version = "${version}"; + sha256 = "73bc09fa59b4a0284efb4624335583c528e07ec9ae76aca96ea0673850aec57a"; + }; - src = fetchHex { - pkg = "telemetry"; - version = "${version}"; - sha256 = "73bc09fa59b4a0284efb4624335583c528e07ec9ae76aca96ea0673850aec57a"; + beamDeps = [ ]; }; - beamDeps = []; - }; + telemetry_metrics = buildMix rec { + name = "telemetry_metrics"; + version = "0.6.2"; - telemetry_metrics = buildMix rec { - name = "telemetry_metrics"; - version = "0.6.2"; + src = fetchHex { + pkg = "telemetry_metrics"; + version = "${version}"; + sha256 = "9b43db0dc33863930b9ef9d27137e78974756f5f198cae18409970ed6fa5b561"; + }; - src = fetchHex { - pkg = "telemetry_metrics"; - version = "${version}"; - sha256 = "9b43db0dc33863930b9ef9d27137e78974756f5f198cae18409970ed6fa5b561"; + beamDeps = [ telemetry ]; }; - beamDeps = [ telemetry ]; - }; + telemetry_metrics_prometheus_core = buildMix rec { + name = "telemetry_metrics_prometheus_core"; + version = "1.2.0"; - telemetry_metrics_prometheus_core = buildMix rec { - name = "telemetry_metrics_prometheus_core"; - version = "1.2.0"; + src = fetchHex { + pkg = "telemetry_metrics_prometheus_core"; + version = "${version}"; + sha256 = "9cba950e1c4733468efbe3f821841f34ac05d28e7af7798622f88ecdbbe63ea3"; + }; - src = fetchHex { - pkg = "telemetry_metrics_prometheus_core"; - version = "${version}"; - sha256 = "9cba950e1c4733468efbe3f821841f34ac05d28e7af7798622f88ecdbbe63ea3"; + beamDeps = [ + telemetry + telemetry_metrics + ]; }; - beamDeps = [ telemetry telemetry_metrics ]; - }; + telemetry_poller = buildRebar3 rec { + name = "telemetry_poller"; + version = "1.0.0"; - telemetry_poller = buildRebar3 rec { - name = "telemetry_poller"; - version = "1.0.0"; + src = fetchHex { + pkg = "telemetry_poller"; + version = "${version}"; + sha256 = "b3a24eafd66c3f42da30fc3ca7dda1e9d546c12250a2d60d7b81d264fbec4f6e"; + }; - src = fetchHex { - pkg = "telemetry_poller"; - version = "${version}"; - sha256 = "b3a24eafd66c3f42da30fc3ca7dda1e9d546c12250a2d60d7b81d264fbec4f6e"; + beamDeps = [ telemetry ]; }; - beamDeps = [ telemetry ]; - }; + tesla = buildMix rec { + name = "tesla"; + version = "1.11.0"; - tesla = buildMix rec { - name = "tesla"; - version = "1.11.0"; + src = fetchHex { + pkg = "tesla"; + version = "${version}"; + sha256 = "b83ab5d4c2d202e1ea2b7e17a49f788d49a699513d7c4f08f2aef2c281be69db"; + }; - src = fetchHex { - pkg = "tesla"; - version = "${version}"; - sha256 = "b83ab5d4c2d202e1ea2b7e17a49f788d49a699513d7c4f08f2aef2c281be69db"; + beamDeps = [ + castore + finch + gun + hackney + jason + mime + mint + poison + telemetry + ]; }; - beamDeps = [ castore finch gun hackney jason mime mint poison telemetry ]; - }; + thousand_island = buildMix rec { + name = "thousand_island"; + version = "1.3.5"; - thousand_island = buildMix rec { - name = "thousand_island"; - version = "1.3.5"; + src = fetchHex { + pkg = "thousand_island"; + version = "${version}"; + sha256 = "2be6954916fdfe4756af3239fb6b6d75d0b8063b5df03ba76fd8a4c87849e180"; + }; - src = fetchHex { - pkg = "thousand_island"; - version = "${version}"; - sha256 = "2be6954916fdfe4756af3239fb6b6d75d0b8063b5df03ba76fd8a4c87849e180"; + beamDeps = [ telemetry ]; }; - beamDeps = [ telemetry ]; - }; + timex = buildMix rec { + name = "timex"; + version = "3.7.7"; - timex = buildMix rec { - name = "timex"; - version = "3.7.7"; + src = fetchHex { + pkg = "timex"; + version = "${version}"; + sha256 = "0ec4b09f25fe311321f9fc04144a7e3affe48eb29481d7a5583849b6c4dfa0a7"; + }; - src = fetchHex { - pkg = "timex"; - version = "${version}"; - sha256 = "0ec4b09f25fe311321f9fc04144a7e3affe48eb29481d7a5583849b6c4dfa0a7"; + beamDeps = [ + combine + gettext + tzdata + ]; }; - beamDeps = [ combine gettext tzdata ]; - }; + toml = buildMix rec { + name = "toml"; + version = "0.7.0"; - toml = buildMix rec { - name = "toml"; - version = "0.7.0"; + src = fetchHex { + pkg = "toml"; + version = "${version}"; + sha256 = "0690246a2478c1defd100b0c9b89b4ea280a22be9a7b313a8a058a2408a2fa70"; + }; - src = fetchHex { - pkg = "toml"; - version = "${version}"; - sha256 = "0690246a2478c1defd100b0c9b89b4ea280a22be9a7b313a8a058a2408a2fa70"; + beamDeps = [ ]; }; - beamDeps = []; - }; + trailing_format_plug = buildMix rec { + name = "trailing_format_plug"; + version = "0.0.7"; - trailing_format_plug = buildMix rec { - name = "trailing_format_plug"; - version = "0.0.7"; + src = fetchHex { + pkg = "trailing_format_plug"; + version = "${version}"; + sha256 = "bd4fde4c15f3e993a999e019d64347489b91b7a9096af68b2bdadd192afa693f"; + }; - src = fetchHex { - pkg = "trailing_format_plug"; - version = "${version}"; - sha256 = "bd4fde4c15f3e993a999e019d64347489b91b7a9096af68b2bdadd192afa693f"; + beamDeps = [ plug ]; }; - beamDeps = [ plug ]; - }; + tzdata = buildMix rec { + name = "tzdata"; + version = "1.0.5"; - tzdata = buildMix rec { - name = "tzdata"; - version = "1.0.5"; + src = fetchHex { + pkg = "tzdata"; + version = "${version}"; + sha256 = "55519aa2a99e5d2095c1e61cc74c9be69688f8ab75c27da724eb8279ff402a5a"; + }; - src = fetchHex { - pkg = "tzdata"; - version = "${version}"; - sha256 = "55519aa2a99e5d2095c1e61cc74c9be69688f8ab75c27da724eb8279ff402a5a"; + beamDeps = [ hackney ]; }; - beamDeps = [ hackney ]; - }; + ueberauth = buildMix rec { + name = "ueberauth"; + version = "0.10.7"; - ueberauth = buildMix rec { - name = "ueberauth"; - version = "0.10.7"; + src = fetchHex { + pkg = "ueberauth"; + version = "${version}"; + sha256 = "0bccf73e2ffd6337971340832947ba232877aa8122dba4c95be9f729c8987377"; + }; - src = fetchHex { - pkg = "ueberauth"; - version = "${version}"; - sha256 = "0bccf73e2ffd6337971340832947ba232877aa8122dba4c95be9f729c8987377"; + beamDeps = [ plug ]; }; - beamDeps = [ plug ]; - }; + unicode_util_compat = buildRebar3 rec { + name = "unicode_util_compat"; + version = "0.7.0"; - unicode_util_compat = buildRebar3 rec { - name = "unicode_util_compat"; - version = "0.7.0"; + src = fetchHex { + pkg = "unicode_util_compat"; + version = "${version}"; + sha256 = "25eee6d67df61960cf6a794239566599b09e17e668d3700247bc498638152521"; + }; - src = fetchHex { - pkg = "unicode_util_compat"; - version = "${version}"; - sha256 = "25eee6d67df61960cf6a794239566599b09e17e668d3700247bc498638152521"; + beamDeps = [ ]; }; - beamDeps = []; - }; + unsafe = buildMix rec { + name = "unsafe"; + version = "1.0.2"; - unsafe = buildMix rec { - name = "unsafe"; - version = "1.0.2"; + src = fetchHex { + pkg = "unsafe"; + version = "${version}"; + sha256 = "b485231683c3ab01a9cd44cb4a79f152c6f3bb87358439c6f68791b85c2df675"; + }; - src = fetchHex { - pkg = "unsafe"; - version = "${version}"; - sha256 = "b485231683c3ab01a9cd44cb4a79f152c6f3bb87358439c6f68791b85c2df675"; + beamDeps = [ ]; }; - beamDeps = []; - }; + vix = buildMix rec { + name = "vix"; + version = "0.26.0"; - vix = buildMix rec { - name = "vix"; - version = "0.26.0"; + src = fetchHex { + pkg = "vix"; + version = "${version}"; + sha256 = "71b0a79ae7f199cacfc8e679b0e4ba25ee47dc02e182c5b9097efb29fbe14efd"; + }; - src = fetchHex { - pkg = "vix"; - version = "${version}"; - sha256 = "71b0a79ae7f199cacfc8e679b0e4ba25ee47dc02e182c5b9097efb29fbe14efd"; + beamDeps = [ + castore + cc_precompiler + elixir_make + ]; }; - beamDeps = [ castore cc_precompiler elixir_make ]; - }; + web_push_encryption = buildMix rec { + name = "web_push_encryption"; + version = "0.3.1"; - web_push_encryption = buildMix rec { - name = "web_push_encryption"; - version = "0.3.1"; + src = fetchHex { + pkg = "web_push_encryption"; + version = "${version}"; + sha256 = "4f82b2e57622fb9337559058e8797cb0df7e7c9790793bdc4e40bc895f70e2a2"; + }; - src = fetchHex { - pkg = "web_push_encryption"; - version = "${version}"; - sha256 = "4f82b2e57622fb9337559058e8797cb0df7e7c9790793bdc4e40bc895f70e2a2"; + beamDeps = [ + httpoison + jose + ]; }; - beamDeps = [ httpoison jose ]; - }; + websock = buildMix rec { + name = "websock"; + version = "0.5.3"; - websock = buildMix rec { - name = "websock"; - version = "0.5.3"; + src = fetchHex { + pkg = "websock"; + version = "${version}"; + sha256 = "6105453d7fac22c712ad66fab1d45abdf049868f253cf719b625151460b8b453"; + }; - src = fetchHex { - pkg = "websock"; - version = "${version}"; - sha256 = "6105453d7fac22c712ad66fab1d45abdf049868f253cf719b625151460b8b453"; + beamDeps = [ ]; }; - beamDeps = []; - }; + websock_adapter = buildMix rec { + name = "websock_adapter"; + version = "0.5.6"; - websock_adapter = buildMix rec { - name = "websock_adapter"; - version = "0.5.6"; + src = fetchHex { + pkg = "websock_adapter"; + version = "${version}"; + sha256 = "e04378d26b0af627817ae84c92083b7e97aca3121196679b73c73b99d0d133ea"; + }; - src = fetchHex { - pkg = "websock_adapter"; - version = "${version}"; - sha256 = "e04378d26b0af627817ae84c92083b7e97aca3121196679b73c73b99d0d133ea"; + beamDeps = [ + bandit + plug + plug_cowboy + websock + ]; }; - beamDeps = [ bandit plug plug_cowboy websock ]; - }; + websockex = buildMix rec { + name = "websockex"; + version = "0.4.3"; - websockex = buildMix rec { - name = "websockex"; - version = "0.4.3"; + src = fetchHex { + pkg = "websockex"; + version = "${version}"; + sha256 = "95f2e7072b85a3a4cc385602d42115b73ce0b74a9121d0d6dbbf557645ac53e4"; + }; - src = fetchHex { - pkg = "websockex"; - version = "${version}"; - sha256 = "95f2e7072b85a3a4cc385602d42115b73ce0b74a9121d0d6dbbf557645ac53e4"; + beamDeps = [ ]; }; - - beamDeps = []; }; - }; -in self - +in +self diff --git a/pkgs/servers/plex/default.nix b/pkgs/servers/plex/default.nix index ab56662fa402cf..fac5f199bfd696 100644 --- a/pkgs/servers/plex/default.nix +++ b/pkgs/servers/plex/default.nix @@ -1,12 +1,13 @@ # The actual Plex package that we run is a FHS userenv of the "raw" package. -{ stdenv -, buildFHSEnv -, writeScript -, plexRaw - -# Old argument for overriding the Plex data directory; not used for this -# version of Plex, but still around for backwards-compatibility. -, dataDir ? "/var/lib/plex" +{ + stdenv, + buildFHSEnv, + writeScript, + plexRaw, + + # Old argument for overriding the Plex data directory; not used for this + # version of Plex, but still around for backwards-compatibility. + dataDir ? "/var/lib/plex", }: buildFHSEnv { diff --git a/pkgs/servers/plex/raw.nix b/pkgs/servers/plex/raw.nix index 2bc2b23db04773..029fd07e987f10 100644 --- a/pkgs/servers/plex/raw.nix +++ b/pkgs/servers/plex/raw.nix @@ -1,10 +1,12 @@ -{ lib, stdenv -, fetchurl -, dpkg -, writeScript -, curl -, jq -, common-updater-scripts +{ + lib, + stdenv, + fetchurl, + dpkg, + writeScript, + curl, + jq, + common-updater-scripts, }: # The raw package that fetches and extracts the Plex RPM. Override the source @@ -16,15 +18,22 @@ stdenv.mkDerivation rec { pname = "plexmediaserver"; # Fetch the source - src = if stdenv.hostPlatform.system == "aarch64-linux" then fetchurl { - url = "https://downloads.plex.tv/plex-media-server-new/${version}/debian/plexmediaserver_${version}_arm64.deb"; - sha256 = "sha256-VTWyeve+Uz3TdWQ06CmZ9w+Gk9jBHP7EuYi0N9DTB4Q="; - } else fetchurl { - url = "https://downloads.plex.tv/plex-media-server-new/${version}/debian/plexmediaserver_${version}_amd64.deb"; - sha256 = "sha256-HmgtnUsDzRIUThYdlZIzhiU02n9jSU7wtwnEA0+r1iQ="; - }; + src = + if stdenv.hostPlatform.system == "aarch64-linux" then + fetchurl { + url = "https://downloads.plex.tv/plex-media-server-new/${version}/debian/plexmediaserver_${version}_arm64.deb"; + sha256 = "sha256-VTWyeve+Uz3TdWQ06CmZ9w+Gk9jBHP7EuYi0N9DTB4Q="; + } + else + fetchurl { + url = "https://downloads.plex.tv/plex-media-server-new/${version}/debian/plexmediaserver_${version}_amd64.deb"; + sha256 = "sha256-HmgtnUsDzRIUThYdlZIzhiU02n9jSU7wtwnEA0+r1iQ="; + }; - outputs = [ "out" "basedb" ]; + outputs = [ + "out" + "basedb" + ]; nativeBuildInputs = [ dpkg ]; @@ -55,7 +64,13 @@ stdenv.mkDerivation rec { passthru.updateScript = writeScript "${pname}-updater" '' #!${stdenv.shell} set -eu -o pipefail - PATH=${lib.makeBinPath [curl jq common-updater-scripts]}:$PATH + PATH=${ + lib.makeBinPath [ + curl + jq + common-updater-scripts + ] + }:$PATH plexApiJson=$(curl -sS https://plex.tv/api/downloads/5.json) latestVersion="$(echo $plexApiJson | jq .computer.Linux.version | tr -d '"\n')" @@ -74,7 +89,10 @@ stdenv.mkDerivation rec { homepage = "https://plex.tv/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; maintainers = with maintainers; [ badmutex forkk diff --git a/pkgs/servers/plik/default.nix b/pkgs/servers/plik/default.nix index 29ba48487a37ae..dd0b0d7b446f73 100644 --- a/pkgs/servers/plik/default.nix +++ b/pkgs/servers/plik/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchurl, makeWrapper, runCommand, callPackage }: +{ + lib, + fetchurl, + makeWrapper, + runCommand, + callPackage, +}: let version = "1.3.7"; @@ -15,15 +21,18 @@ in inherit (programs) plik plikd-unwrapped; - plikd = runCommand "plikd-${version}" { - nativeBuildInputs = [ makeWrapper ]; - inherit (programs.plikd-unwrapped) passthru; - } '' - mkdir -p $out/libexec/plikd/{bin,webapp} $out/bin - tar xf ${webapp} plik-${version}-linux-amd64/webapp/dist/ - mv plik-*/webapp/dist $out/libexec/plikd/webapp - cp ${programs.plikd-unwrapped}/bin/plikd $out/libexec/plikd/bin/plikd - makeWrapper $out/libexec/plikd/bin/plikd $out/bin/plikd \ - --chdir "$out/libexec/plikd/bin" - ''; + plikd = + runCommand "plikd-${version}" + { + nativeBuildInputs = [ makeWrapper ]; + inherit (programs.plikd-unwrapped) passthru; + } + '' + mkdir -p $out/libexec/plikd/{bin,webapp} $out/bin + tar xf ${webapp} plik-${version}-linux-amd64/webapp/dist/ + mv plik-*/webapp/dist $out/libexec/plikd/webapp + cp ${programs.plikd-unwrapped}/bin/plikd $out/libexec/plikd/bin/plikd + makeWrapper $out/libexec/plikd/bin/plikd $out/bin/plikd \ + --chdir "$out/libexec/plikd/bin" + ''; } diff --git a/pkgs/servers/plik/programs.nix b/pkgs/servers/plik/programs.nix index 2b8b5176fb9a72..791cd96d03b791 100644 --- a/pkgs/servers/plik/programs.nix +++ b/pkgs/servers/plik/programs.nix @@ -1,4 +1,11 @@ -{ lib, buildGoModule, fetchFromGitHub, makeWrapper, runCommand, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + makeWrapper, + runCommand, + nixosTests, +}: let version = "1.3.8"; @@ -34,7 +41,14 @@ in plik = buildGoModule { pname = "plik"; - inherit version meta src vendorHash postPatch passthru; + inherit + version + meta + src + vendorHash + postPatch + passthru + ; subPackages = [ "client" ]; postInstall = '' @@ -44,7 +58,13 @@ in plikd-unwrapped = buildGoModule { pname = "plikd-unwrapped"; - inherit version src vendorHash postPatch passthru; + inherit + version + src + vendorHash + postPatch + passthru + ; subPackages = [ "server" ]; postFixup = '' diff --git a/pkgs/servers/polaris/web.nix b/pkgs/servers/polaris/web.nix index 1834c01a0547b4..39cc8e90656128 100644 --- a/pkgs/servers/polaris/web.nix +++ b/pkgs/servers/polaris/web.nix @@ -1,6 +1,7 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub +{ + lib, + buildNpmPackage, + fetchFromGitHub, }: buildNpmPackage rec { diff --git a/pkgs/servers/pulseaudio/default.nix b/pkgs/servers/pulseaudio/default.nix index 44f89234ec6d90..fa3333433ebb8b 100644 --- a/pkgs/servers/pulseaudio/default.nix +++ b/pkgs/servers/pulseaudio/default.nix @@ -1,40 +1,70 @@ -{ lib, stdenv, fetchurl, pkg-config -, libsndfile, libtool, makeWrapper, perlPackages -, xorg, libcap, alsa-lib, glib, dconf -, avahi, libjack2, libasyncns, lirc, dbus -, sbc, bluez5, udev, openssl, fftwFloat -, soxr, speexdsp, systemd, webrtc-audio-processing_1 -, gst_all_1 -, check, libintl, meson, ninja, m4, wrapGAppsHook3 -, fetchpatch2 -, nixosTests +{ + lib, + stdenv, + fetchurl, + pkg-config, + libsndfile, + libtool, + makeWrapper, + perlPackages, + xorg, + libcap, + alsa-lib, + glib, + dconf, + avahi, + libjack2, + libasyncns, + lirc, + dbus, + sbc, + bluez5, + udev, + openssl, + fftwFloat, + soxr, + speexdsp, + systemd, + webrtc-audio-processing_1, + gst_all_1, + check, + libintl, + meson, + ninja, + m4, + wrapGAppsHook3, + fetchpatch2, + nixosTests, -, x11Support ? false + x11Support ? false, -, useSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd + useSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, -, # Whether to support the JACK sound system as a backend. - jackaudioSupport ? false + # Whether to support the JACK sound system as a backend. + jackaudioSupport ? false, -, # Whether to build the OSS wrapper ("padsp"). - ossWrapper ? true + # Whether to build the OSS wrapper ("padsp"). + ossWrapper ? true, -, airtunesSupport ? false + airtunesSupport ? false, -, bluetoothSupport ? stdenv.hostPlatform.isLinux -, advancedBluetoothCodecs ? false + bluetoothSupport ? stdenv.hostPlatform.isLinux, + advancedBluetoothCodecs ? false, -, remoteControlSupport ? false + remoteControlSupport ? false, -, zeroconfSupport ? false + zeroconfSupport ? false, -, alsaSupport ? stdenv.hostPlatform.isLinux -, udevSupport ? stdenv.hostPlatform.isLinux + alsaSupport ? stdenv.hostPlatform.isLinux, + udevSupport ? stdenv.hostPlatform.isLinux, -, # Whether to build only the library. - libOnly ? false + # Whether to build only the library. + libOnly ? false, -, AudioUnit, Cocoa, CoreServices, CoreAudio + AudioUnit, + Cocoa, + CoreServices, + CoreAudio, }: stdenv.mkDerivation rec { @@ -65,78 +95,132 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; - nativeBuildInputs = [ pkg-config meson ninja makeWrapper perlPackages.perl perlPackages.XMLParser m4 ] + nativeBuildInputs = + [ + pkg-config + meson + ninja + makeWrapper + perlPackages.perl + perlPackages.XMLParser + m4 + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ glib ] # gstreamer plugin discovery requires wrapping ++ lib.optional (bluetoothSupport && advancedBluetoothCodecs) wrapGAppsHook3; - propagatedBuildInputs = - lib.optionals stdenv.hostPlatform.isLinux [ libcap ]; + propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libcap ]; buildInputs = - [ libtool libsndfile soxr speexdsp fftwFloat check ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ glib dbus ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ AudioUnit Cocoa CoreServices CoreAudio libintl ] + [ + libtool + libsndfile + soxr + speexdsp + fftwFloat + check + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + glib + dbus + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AudioUnit + Cocoa + CoreServices + CoreAudio + libintl + ] ++ lib.optionals (!libOnly) ( - [ libasyncns webrtc-audio-processing_1 ] + [ + libasyncns + webrtc-audio-processing_1 + ] ++ lib.optional jackaudioSupport libjack2 - ++ lib.optionals x11Support [ xorg.libICE xorg.libSM xorg.libX11 xorg.libXi xorg.libXtst ] + ++ lib.optionals x11Support [ + xorg.libICE + xorg.libSM + xorg.libX11 + xorg.libXi + xorg.libXtst + ] ++ lib.optional useSystemd systemd - ++ lib.optionals stdenv.hostPlatform.isLinux [ alsa-lib udev ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + udev + ] ++ lib.optional airtunesSupport openssl - ++ lib.optionals bluetoothSupport [ bluez5 sbc ] + ++ lib.optionals bluetoothSupport [ + bluez5 + sbc + ] # aptX and LDAC codecs are in gst-plugins-bad so far, rtpldacpay is in -good - ++ lib.optionals (bluetoothSupport && advancedBluetoothCodecs) (builtins.attrValues { inherit (gst_all_1) gst-plugins-bad gst-plugins-good gst-plugins-base gstreamer; }) + ++ lib.optionals (bluetoothSupport && advancedBluetoothCodecs) ( + builtins.attrValues { + inherit (gst_all_1) + gst-plugins-bad + gst-plugins-good + gst-plugins-base + gstreamer + ; + } + ) ++ lib.optional remoteControlSupport lirc - ++ lib.optional zeroconfSupport avahi - ); - - mesonFlags = [ - (lib.mesonEnable "alsa" (!libOnly && alsaSupport)) - (lib.mesonEnable "asyncns" (!libOnly)) - (lib.mesonEnable "avahi" zeroconfSupport) - (lib.mesonEnable "bluez5" (!libOnly && bluetoothSupport)) - # advanced bluetooth audio codecs are provided by gstreamer - (lib.mesonEnable "bluez5-gstreamer" (!libOnly && bluetoothSupport && advancedBluetoothCodecs)) - (lib.mesonOption "database" "simple") - (lib.mesonBool "doxygen" false) - (lib.mesonEnable "elogind" false) - # gsettings does not support cross-compilation - (lib.mesonEnable "gsettings" (stdenv.hostPlatform.isLinux && (stdenv.buildPlatform == stdenv.hostPlatform))) - (lib.mesonEnable "gstreamer" false) - (lib.mesonEnable "gtk" false) - (lib.mesonEnable "jack" (jackaudioSupport && !libOnly)) - (lib.mesonEnable "lirc" remoteControlSupport) - (lib.mesonEnable "openssl" airtunesSupport) - (lib.mesonEnable "orc" false) - (lib.mesonEnable "systemd" (useSystemd && !libOnly)) - (lib.mesonEnable "tcpwrap" false) - (lib.mesonEnable "udev" (!libOnly && udevSupport)) - (lib.mesonEnable "valgrind" false) - (lib.mesonEnable "webrtc-aec" (!libOnly)) - (lib.mesonEnable "x11" x11Support) - - (lib.mesonOption "localstatedir" "/var") - (lib.mesonOption "sysconfdir" "/etc") - (lib.mesonOption "sysconfdir_install" "${placeholder "out"}/etc") - (lib.mesonOption "udevrulesdir" "${placeholder "out"}/lib/udev/rules.d") - - # pulseaudio complains if its binary is moved after installation; - # this is needed so that wrapGApp can operate *without* - # renaming the unwrapped binaries (see below) - "--bindir=${placeholder "out"}/.bin-unwrapped" - ] - ++ lib.optionals (stdenv.hostPlatform.isLinux && useSystemd) [ - (lib.mesonOption "systemduserunitdir" "${placeholder "out"}/lib/systemd/user") - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - (lib.mesonEnable "consolekit" false) - (lib.mesonEnable "dbus" false) - (lib.mesonEnable "glib" false) - (lib.mesonEnable "oss-output" false) - ]; + ++ lib.optional zeroconfSupport avahi + ); + + mesonFlags = + [ + (lib.mesonEnable "alsa" (!libOnly && alsaSupport)) + (lib.mesonEnable "asyncns" (!libOnly)) + (lib.mesonEnable "avahi" zeroconfSupport) + (lib.mesonEnable "bluez5" (!libOnly && bluetoothSupport)) + # advanced bluetooth audio codecs are provided by gstreamer + (lib.mesonEnable "bluez5-gstreamer" (!libOnly && bluetoothSupport && advancedBluetoothCodecs)) + (lib.mesonOption "database" "simple") + (lib.mesonBool "doxygen" false) + (lib.mesonEnable "elogind" false) + # gsettings does not support cross-compilation + (lib.mesonEnable "gsettings" ( + stdenv.hostPlatform.isLinux && (stdenv.buildPlatform == stdenv.hostPlatform) + )) + (lib.mesonEnable "gstreamer" false) + (lib.mesonEnable "gtk" false) + (lib.mesonEnable "jack" (jackaudioSupport && !libOnly)) + (lib.mesonEnable "lirc" remoteControlSupport) + (lib.mesonEnable "openssl" airtunesSupport) + (lib.mesonEnable "orc" false) + (lib.mesonEnable "systemd" (useSystemd && !libOnly)) + (lib.mesonEnable "tcpwrap" false) + (lib.mesonEnable "udev" (!libOnly && udevSupport)) + (lib.mesonEnable "valgrind" false) + (lib.mesonEnable "webrtc-aec" (!libOnly)) + (lib.mesonEnable "x11" x11Support) + + (lib.mesonOption "localstatedir" "/var") + (lib.mesonOption "sysconfdir" "/etc") + (lib.mesonOption "sysconfdir_install" "${placeholder "out"}/etc") + (lib.mesonOption "udevrulesdir" "${placeholder "out"}/lib/udev/rules.d") + + # pulseaudio complains if its binary is moved after installation; + # this is needed so that wrapGApp can operate *without* + # renaming the unwrapped binaries (see below) + "--bindir=${placeholder "out"}/.bin-unwrapped" + ] + ++ lib.optionals (stdenv.hostPlatform.isLinux && useSystemd) [ + (lib.mesonOption "systemduserunitdir" "${placeholder "out"}/lib/systemd/user") + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + (lib.mesonEnable "consolekit" false) + (lib.mesonEnable "dbus" false) + (lib.mesonEnable "glib" false) + (lib.mesonEnable "oss-output" false) + ]; # tests fail on Darwin because of timeouts doCheck = !stdenv.hostPlatform.isDarwin; @@ -144,53 +228,55 @@ stdenv.mkDerivation rec { export HOME=$(mktemp -d) ''; - postInstall = lib.optionalString libOnly '' - find $out/share -maxdepth 1 -mindepth 1 ! -name "vala" -prune -exec rm -r {} \; - find $out/share/vala -maxdepth 1 -mindepth 1 ! -name "vapi" -prune -exec rm -r {} \; - rm -r $out/{.bin-unwrapped,etc,lib/pulse-*} - '' + postInstall = + lib.optionalString libOnly '' + find $out/share -maxdepth 1 -mindepth 1 ! -name "vala" -prune -exec rm -r {} \; + find $out/share/vala -maxdepth 1 -mindepth 1 ! -name "vapi" -prune -exec rm -r {} \; + rm -r $out/{.bin-unwrapped,etc,lib/pulse-*} + '' + '' - moveToOutput lib/cmake "$dev" - rm -f $out/.bin-unwrapped/qpaeq # this is packaged by the "qpaeq" package now, because of missing deps + moveToOutput lib/cmake "$dev" + rm -f $out/.bin-unwrapped/qpaeq # this is packaged by the "qpaeq" package now, because of missing deps - cp config.h $dev/include/pulse - ''; + cp config.h $dev/include/pulse + ''; - preFixup = lib.optionalString (stdenv.hostPlatform.isLinux && (stdenv.hostPlatform == stdenv.buildPlatform)) '' - wrapProgram $out/libexec/pulse/gsettings-helper \ - --prefix XDG_DATA_DIRS : "$out/share/gsettings-schemas/${pname}-${version}" \ - --prefix GIO_EXTRA_MODULES : "${lib.getLib dconf}/lib/gio/modules" - '' - # add .so symlinks for modules to be found under macOS - + lib.optionalString stdenv.hostPlatform.isDarwin '' - for file in $out/lib/pulseaudio/modules/*.dylib; do - ln -s "''$file" "''${file%.dylib}.so" - ln -s "''$file" "$out/lib/pulseaudio/''$(basename ''$file .dylib).so" - done - '' - # put symlinks to binaries in `$prefix/bin`; - # then wrapGApp will *rename these symlinks* instead of - # the original binaries in `$prefix/.bin-unwrapped` (see above); - # when pulseaudio is looking for its own binary (it does!), - # it will be happy to find it in its original installation location - + lib.optionalString (!libOnly) '' - mkdir -p $out/bin - ln -st $out/bin $out/.bin-unwrapped/* - - # Ensure that service files use the wrapped binaries. - find "$out" -name "*.service" | while read f; do - substituteInPlace "$f" --replace "$out/.bin-unwrapped/" "$out/bin/" - done - ''; + preFixup = + lib.optionalString (stdenv.hostPlatform.isLinux && (stdenv.hostPlatform == stdenv.buildPlatform)) '' + wrapProgram $out/libexec/pulse/gsettings-helper \ + --prefix XDG_DATA_DIRS : "$out/share/gsettings-schemas/${pname}-${version}" \ + --prefix GIO_EXTRA_MODULES : "${lib.getLib dconf}/lib/gio/modules" + '' + # add .so symlinks for modules to be found under macOS + + lib.optionalString stdenv.hostPlatform.isDarwin '' + for file in $out/lib/pulseaudio/modules/*.dylib; do + ln -s "''$file" "''${file%.dylib}.so" + ln -s "''$file" "$out/lib/pulseaudio/''$(basename ''$file .dylib).so" + done + '' + # put symlinks to binaries in `$prefix/bin`; + # then wrapGApp will *rename these symlinks* instead of + # the original binaries in `$prefix/.bin-unwrapped` (see above); + # when pulseaudio is looking for its own binary (it does!), + # it will be happy to find it in its original installation location + + lib.optionalString (!libOnly) '' + mkdir -p $out/bin + ln -st $out/bin $out/.bin-unwrapped/* + + # Ensure that service files use the wrapped binaries. + find "$out" -name "*.service" | while read f; do + substituteInPlace "$f" --replace "$out/.bin-unwrapped/" "$out/bin/" + done + ''; passthru.tests = { inherit (nixosTests) pulseaudio; }; meta = { description = "Sound server for POSIX and Win32 systems"; - homepage = "http://www.pulseaudio.org/"; - license = lib.licenses.lgpl2Plus; + homepage = "http://www.pulseaudio.org/"; + license = lib.licenses.lgpl2Plus; maintainers = with lib.maintainers; [ lovek323 ]; - platforms = lib.platforms.unix; + platforms = lib.platforms.unix; # https://gitlab.freedesktop.org/pulseaudio/pulseaudio/-/issues/1089 badPlatforms = [ lib.systems.inspect.platformPatterns.isStatic ]; diff --git a/pkgs/servers/pulseaudio/hsphfpd.nix b/pkgs/servers/pulseaudio/hsphfpd.nix index bcb3934fb7b744..ced6bdbb0695c0 100644 --- a/pkgs/servers/pulseaudio/hsphfpd.nix +++ b/pkgs/servers/pulseaudio/hsphfpd.nix @@ -1,7 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, perlPackages }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + perlPackages, +}: let - perlLibs = with perlPackages; [ NetDBus XMLTwig XMLParser ]; + perlLibs = with perlPackages; [ + NetDBus + XMLTwig + XMLParser + ]; in stdenv.mkDerivation { pname = "hsphfpd"; diff --git a/pkgs/servers/pulseaudio/qpaeq.nix b/pkgs/servers/pulseaudio/qpaeq.nix index 8e899b024b4945..bfdb6c1731834e 100644 --- a/pkgs/servers/pulseaudio/qpaeq.nix +++ b/pkgs/servers/pulseaudio/qpaeq.nix @@ -1,8 +1,9 @@ -{ mkDerivation -, makeDesktopItem -, python3 -, lib -, pulseaudio +{ + mkDerivation, + makeDesktopItem, + python3, + lib, + pulseaudio, }: let @@ -12,7 +13,11 @@ let icon = "audio-volume-high"; desktopName = "qpaeq"; genericName = "Audio equalizer"; - categories = [ "AudioVideo" "Audio" "Mixer" ]; + categories = [ + "AudioVideo" + "Audio" + "Mixer" + ]; startupNotify = false; }; in @@ -21,10 +26,14 @@ mkDerivation rec { inherit (pulseaudio) version src; buildInputs = [ - ((python3.withPackages (ps: with ps; [ + ( + (python3.withPackages ( + ps: with ps; [ pyqt5 dbus-python - ]))) + ] + )) + ) ]; dontBuild = true; diff --git a/pkgs/servers/rainloop/default.nix b/pkgs/servers/rainloop/default.nix index f034f83f483541..b434178fb28aa9 100644 --- a/pkgs/servers/rainloop/default.nix +++ b/pkgs/servers/rainloop/default.nix @@ -1,10 +1,23 @@ -{ lib, stdenv, fetchurl, unzip, writeText, dos2unix, dataPath ? "/var/lib/rainloop" }: let - common = { edition, sha256 }: +{ + lib, + stdenv, + fetchurl, + unzip, + writeText, + dos2unix, + dataPath ? "/var/lib/rainloop", +}: +let + common = + { edition, sha256 }: stdenv.mkDerivation (rec { pname = "rainloop${lib.optionalString (edition != "") "-${edition}"}"; version = "1.16.0"; - nativeBuildInputs = [ unzip dos2unix ]; + nativeBuildInputs = [ + unzip + dos2unix + ]; unpackPhase = '' mkdir rainloop @@ -12,7 +25,9 @@ ''; src = fetchurl { - url = "https://github.com/RainLoop/rainloop-webmail/releases/download/v${version}/rainloop-${edition}${lib.optionalString (edition != "") "-"}${version}.zip"; + url = "https://github.com/RainLoop/rainloop-webmail/releases/download/v${version}/rainloop-${edition}${ + lib.optionalString (edition != "") "-" + }${version}.zip"; sha256 = sha256; }; @@ -59,7 +74,8 @@ maintainers = with maintainers; [ das_j ]; }; }); -in { +in +{ rainloop-community = common { edition = "community"; sha256 = "sha256-25ScQ2OwSKAuqg8GomqDhpebhzQZjCk57h6MxUNiymc="; diff --git a/pkgs/servers/roapi/http.nix b/pkgs/servers/roapi/http.nix index 8c0dc4ee59f241..21d5359e7fd7a3 100644 --- a/pkgs/servers/roapi/http.nix +++ b/pkgs/servers/roapi/http.nix @@ -1,6 +1,7 @@ -{ stdenv -, lib -, fetchurl +{ + stdenv, + lib, + fetchurl, }: let pname = "roapi-http"; diff --git a/pkgs/servers/roundcube/default.nix b/pkgs/servers/roundcube/default.nix index db49d376c62d15..15b6ca2544e94d 100644 --- a/pkgs/servers/roundcube/default.nix +++ b/pkgs/servers/roundcube/default.nix @@ -1,4 +1,12 @@ -{ fetchurl, lib, stdenv, buildEnv, roundcube, roundcubePlugins, nixosTests }: +{ + fetchurl, + lib, + stdenv, + buildEnv, + roundcube, + roundcubePlugins, + nixosTests, +}: stdenv.mkDerivation rec { pname = "roundcube"; @@ -22,16 +30,22 @@ stdenv.mkDerivation rec { rm $out/composer.json-dist ''; - passthru.withPlugins = f: buildEnv { - name = "${roundcube.name}-with-plugins"; - paths = (f roundcubePlugins) ++ [ roundcube ]; - }; + passthru.withPlugins = + f: + buildEnv { + name = "${roundcube.name}-with-plugins"; + paths = (f roundcubePlugins) ++ [ roundcube ]; + }; passthru.tests = { inherit (nixosTests) roundcube; }; meta = { description = "Open Source Webmail Software"; - maintainers = with lib.maintainers; [ vskilet globin ma27 ]; + maintainers = with lib.maintainers; [ + vskilet + globin + ma27 + ]; license = lib.licenses.gpl3; platforms = lib.platforms.all; }; diff --git a/pkgs/servers/roundcube/plugins/default.nix b/pkgs/servers/roundcube/plugins/default.nix index 42333b69eb15d4..ccb5ad9f4e9c21 100644 --- a/pkgs/servers/roundcube/plugins/default.nix +++ b/pkgs/servers/roundcube/plugins/default.nix @@ -8,4 +8,4 @@ let in - plugins +plugins diff --git a/pkgs/servers/roundcube/plugins/roundcube-plugin.nix b/pkgs/servers/roundcube/plugins/roundcube-plugin.nix index a756a3140cb2ef..404481c601f19f 100644 --- a/pkgs/servers/roundcube/plugins/roundcube-plugin.nix +++ b/pkgs/servers/roundcube/plugins/roundcube-plugin.nix @@ -1,5 +1,9 @@ { runCommand }: -{ pname, version, src }: +{ + pname, + version, + src, +}: runCommand "roundcube-plugin-${pname}-${version}" { } '' mkdir -p $out/plugins/ diff --git a/pkgs/servers/rtrtr/default.nix b/pkgs/servers/rtrtr/default.nix index 3697043c246e2a..2926438523ffc2 100644 --- a/pkgs/servers/rtrtr/default.nix +++ b/pkgs/servers/rtrtr/default.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, stdenv -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + stdenv, + Security, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/servers/rustdesk-server/default.nix b/pkgs/servers/rustdesk-server/default.nix index 30446299f144b0..11aae268c537b9 100644 --- a/pkgs/servers/rustdesk-server/default.nix +++ b/pkgs/servers/rustdesk-server/default.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, libsodium -, Security -, sqlite -, nix-update-script -, testers -, rustdesk-server +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + libsodium, + Security, + sqlite, + nix-update-script, + testers, + rustdesk-server, }: rustPlatform.buildRustPackage rec { @@ -35,12 +36,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - libsodium - sqlite - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - ]; + buildInputs = + [ + libsodium + sqlite + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + ]; passthru = { updateScript = nix-update-script { }; @@ -57,6 +60,9 @@ rustPlatform.buildRustPackage rec { changelog = "https://github.com/rustdesk/rustdesk-server/releases/tag/${version}"; license = licenses.agpl3Only; platforms = platforms.unix; - maintainers = with maintainers; [ gaelreyrol tjni ]; + maintainers = with maintainers; [ + gaelreyrol + tjni + ]; }; } diff --git a/pkgs/servers/samba/4.x.nix b/pkgs/servers/samba/4.x.nix index 2b06fb9175a0d2..10946a0803d499 100644 --- a/pkgs/servers/samba/4.x.nix +++ b/pkgs/servers/samba/4.x.nix @@ -1,54 +1,68 @@ -{ lib, stdenv -, buildPackages -, fetchurl -, fetchpatch -, wafHook -, pkg-config -, bison -, flex -, perl -, libxslt -, docbook_xsl -, fixDarwinDylibNames -, docbook_xml_dtd_45 -, readline -, popt -, dbus -, libbsd -, libarchive -, zlib -, liburing -, gnutls -, systemd -, samba -, talloc -, jansson -, ldb -, libtasn1 -, tdb -, tevent -, libxcrypt -, libxcrypt-legacy -, cmocka -, rpcsvc-proto -, bash -, python3Packages -, nixosTests -, libiconv -, testers -, pkgsCross +{ + lib, + stdenv, + buildPackages, + fetchurl, + fetchpatch, + wafHook, + pkg-config, + bison, + flex, + perl, + libxslt, + docbook_xsl, + fixDarwinDylibNames, + docbook_xml_dtd_45, + readline, + popt, + dbus, + libbsd, + libarchive, + zlib, + liburing, + gnutls, + systemd, + samba, + talloc, + jansson, + ldb, + libtasn1, + tdb, + tevent, + libxcrypt, + libxcrypt-legacy, + cmocka, + rpcsvc-proto, + bash, + python3Packages, + nixosTests, + libiconv, + testers, + pkgsCross, -, enableLDAP ? false, openldap -, enablePrinting ? false, cups -, enableProfiling ? true -, enableMDNS ? false, avahi -, enableDomainController ? false, gpgme, lmdb -, enableRegedit ? true, ncurses -, enableCephFS ? false, ceph -, enableGlusterFS ? false, glusterfs, libuuid -, enableAcl ? (!stdenv.hostPlatform.isDarwin), acl -, enableLibunwind ? (!stdenv.hostPlatform.isDarwin), libunwind -, enablePam ? (!stdenv.hostPlatform.isDarwin), pam + enableLDAP ? false, + openldap, + enablePrinting ? false, + cups, + enableProfiling ? true, + enableMDNS ? false, + avahi, + enableDomainController ? false, + gpgme, + lmdb, + enableRegedit ? true, + ncurses, + enableCephFS ? false, + ceph, + enableGlusterFS ? false, + glusterfs, + libuuid, + enableAcl ? (!stdenv.hostPlatform.isDarwin), + acl, + enableLibunwind ? (!stdenv.hostPlatform.isDarwin), + libunwind, + enablePam ? (!stdenv.hostPlatform.isDarwin), + pam, }: let @@ -72,7 +86,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-OpLpfq6zRbazIjL1A+FNNPA6eqZMRR/owlihG72pCOU="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; patches = [ ./4.x-no-persistent-install.patch @@ -88,54 +106,76 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - nativeBuildInputs = [ - python3Packages.python - wafHook - pkg-config - bison - flex - perl - perl.pkgs.ParseYapp - perl.pkgs.JSON - libxslt - docbook_xsl - docbook_xml_dtd_45 - cmocka - rpcsvc-proto - ] ++ optionals stdenv.hostPlatform.isLinux [ - buildPackages.stdenv.cc - ] ++ optional (stdenv.buildPlatform != stdenv.hostPlatform) samba # asn1_compile/compile_et + nativeBuildInputs = + [ + python3Packages.python + wafHook + pkg-config + bison + flex + perl + perl.pkgs.ParseYapp + perl.pkgs.JSON + libxslt + docbook_xsl + docbook_xml_dtd_45 + cmocka + rpcsvc-proto + ] + ++ optionals stdenv.hostPlatform.isLinux [ + buildPackages.stdenv.cc + ] + ++ optional (stdenv.buildPlatform != stdenv.hostPlatform) samba # asn1_compile/compile_et ++ optionals stdenv.hostPlatform.isDarwin [ - fixDarwinDylibNames - ]; + fixDarwinDylibNames + ]; wafPath = "buildtools/bin/waf"; - buildInputs = [ - bash - wrapPython - python - readline - popt - dbus - jansson - libbsd - libarchive - zlib - gnutls - libtasn1 - tdb - libxcrypt - ] ++ optionals stdenv.hostPlatform.isLinux [ liburing systemd ] + buildInputs = + [ + bash + wrapPython + python + readline + popt + dbus + jansson + libbsd + libarchive + zlib + gnutls + libtasn1 + tdb + libxcrypt + ] + ++ optionals stdenv.hostPlatform.isLinux [ + liburing + systemd + ] ++ optionals stdenv.hostPlatform.isDarwin [ libiconv ] - ++ optionals enableLDAP [ openldap.dev python3Packages.markdown ] - ++ optionals (!enableLDAP && stdenv.hostPlatform.isLinux) [ ldb talloc tevent ] + ++ optionals enableLDAP [ + openldap.dev + python3Packages.markdown + ] + ++ optionals (!enableLDAP && stdenv.hostPlatform.isLinux) [ + ldb + talloc + tevent + ] ++ optional enablePrinting cups ++ optional enableMDNS avahi - ++ optionals enableDomainController [ gpgme lmdb python3Packages.dnspython ] + ++ optionals enableDomainController [ + gpgme + lmdb + python3Packages.dnspython + ] ++ optional enableRegedit ncurses ++ optional (enableCephFS && stdenv.hostPlatform.isLinux) (lib.getDev ceph) - ++ optionals (enableGlusterFS && stdenv.hostPlatform.isLinux) [ glusterfs libuuid ] + ++ optionals (enableGlusterFS && stdenv.hostPlatform.isLinux) [ + glusterfs + libuuid + ] ++ optional enableAcl acl ++ optional enableLibunwind libunwind ++ optional enablePam pam; @@ -155,49 +195,57 @@ stdenv.mkDerivation (finalAttrs: { export PYTHONHASHSEED=1 ''; - wafConfigureFlags = [ - "--with-static-modules=NONE" - "--with-shared-modules=ALL" - "--enable-fhs" - "--sysconfdir=/etc" - "--localstatedir=/var" - "--disable-rpath" - # otherwise third_party/waf/waflib/Tools/python.py would - # get the wrong pythondir from build platform python - "--pythondir=${placeholder "out"}/${python.sitePackages}" - (lib.enableFeature enablePrinting "cups") - ] ++ optional (!enableDomainController) - "--without-ad-dc" - ++ optionals (!enableLDAP) [ - "--without-ldap" - "--without-ads" - ] ++ optionals (!enableLDAP && stdenv.hostPlatform.isLinux) [ - "--bundled-libraries=!ldb,!pyldb-util!talloc,!pytalloc-util,!tevent,!tdb,!pytdb" - ] ++ optional enableLibunwind "--with-libunwind" + wafConfigureFlags = + [ + "--with-static-modules=NONE" + "--with-shared-modules=ALL" + "--enable-fhs" + "--sysconfdir=/etc" + "--localstatedir=/var" + "--disable-rpath" + # otherwise third_party/waf/waflib/Tools/python.py would + # get the wrong pythondir from build platform python + "--pythondir=${placeholder "out"}/${python.sitePackages}" + (lib.enableFeature enablePrinting "cups") + ] + ++ optional (!enableDomainController) "--without-ad-dc" + ++ optionals (!enableLDAP) [ + "--without-ldap" + "--without-ads" + ] + ++ optionals (!enableLDAP && stdenv.hostPlatform.isLinux) [ + "--bundled-libraries=!ldb,!pyldb-util!talloc,!pytalloc-util,!tevent,!tdb,!pytdb" + ] + ++ optional enableLibunwind "--with-libunwind" ++ optional enableProfiling "--with-profiling-data" ++ optional (!enableAcl) "--without-acl-support" ++ optional (!enablePam) "--without-pam" ++ optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ - "--bundled-libraries=!asn1_compile,!compile_et" - "--cross-compile" - "--cross-execute=${stdenv.hostPlatform.emulator buildPackages}" - ] ++ optionals stdenv.buildPlatform.is32bit [ - # By default `waf configure` spawns as many as available CPUs. On - # 32-bit systems with many CPUs (like `i686` chroot on `x86_64` - # kernel) it can easily exhaust 32-bit address space and hang up: - # https://github.com/NixOS/nixpkgs/issues/287339#issuecomment-1949462057 - # https://bugs.gentoo.org/683148 - # Limit the job count down to the minimal on system with limited address - # space. - "--jobs 1" - ]; + "--bundled-libraries=!asn1_compile,!compile_et" + "--cross-compile" + "--cross-execute=${stdenv.hostPlatform.emulator buildPackages}" + ] + ++ optionals stdenv.buildPlatform.is32bit [ + # By default `waf configure` spawns as many as available CPUs. On + # 32-bit systems with many CPUs (like `i686` chroot on `x86_64` + # kernel) it can easily exhaust 32-bit address space and hang up: + # https://github.com/NixOS/nixpkgs/issues/287339#issuecomment-1949462057 + # https://bugs.gentoo.org/683148 + # Limit the job count down to the minimal on system with limited address + # space. + "--jobs 1" + ]; # python-config from build Python gives incorrect values when cross-compiling. # If python-config is not found, the build falls back to using the sysconfig # module, which works correctly in all cases. PYTHON_CONFIG = "/invalid"; - pythonPath = [ python3Packages.dnspython python3Packages.markdown tdb ]; + pythonPath = [ + python3Packages.dnspython + python3Packages.markdown + tdb + ]; preBuild = '' export MAKEFLAGS="-j $NIX_BUILD_CORES" @@ -213,40 +261,44 @@ stdenv.mkDerivation (finalAttrs: { # Some libraries don't have /lib/samba in RPATH but need it. # Use find -type f -executable -exec echo {} \; -exec sh -c 'ldd {} | grep "not found"' \; # Looks like a bug in installer scripts. - postFixup = '' - export SAMBA_LIBS="$(find $out -type f -regex '.*\${stdenv.hostPlatform.extensions.sharedLibrary}\(\..*\)?' -exec dirname {} \; | sort | uniq)" - read -r -d "" SCRIPT << EOF || true - [ -z "\$SAMBA_LIBS" ] && exit 1; - BIN='{}'; - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - OLD_LIBS="\$(patchelf --print-rpath "\$BIN" 2>/dev/null | tr ':' '\n')"; - ALL_LIBS="\$(echo -e "\$SAMBA_LIBS\n\$OLD_LIBS" | sort | uniq | tr '\n' ':')"; - patchelf --set-rpath "\$ALL_LIBS" "\$BIN" 2>/dev/null || exit $?; - patchelf --shrink-rpath "\$BIN"; - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install_name_tool -id \$BIN \$BIN - for old_rpath in \$(otool -L \$BIN | grep /private/tmp/ | awk '{print \$1}'); do - new_rpath=\$(find \$SAMBA_LIBS -name \$(basename \$old_rpath) | head -n 1) - install_name_tool -change \$old_rpath \$new_rpath \$BIN - done - '' + '' - EOF - find $out -type f -regex '.*\${stdenv.hostPlatform.extensions.sharedLibrary}\(\..*\)?' -exec $SHELL -c "$SCRIPT" \; - find $out/bin -type f -exec $SHELL -c "$SCRIPT" \; + postFixup = + '' + export SAMBA_LIBS="$(find $out -type f -regex '.*\${stdenv.hostPlatform.extensions.sharedLibrary}\(\..*\)?' -exec dirname {} \; | sort | uniq)" + read -r -d "" SCRIPT << EOF || true + [ -z "\$SAMBA_LIBS" ] && exit 1; + BIN='{}'; + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + OLD_LIBS="\$(patchelf --print-rpath "\$BIN" 2>/dev/null | tr ':' '\n')"; + ALL_LIBS="\$(echo -e "\$SAMBA_LIBS\n\$OLD_LIBS" | sort | uniq | tr '\n' ':')"; + patchelf --set-rpath "\$ALL_LIBS" "\$BIN" 2>/dev/null || exit $?; + patchelf --shrink-rpath "\$BIN"; + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install_name_tool -id \$BIN \$BIN + for old_rpath in \$(otool -L \$BIN | grep /private/tmp/ | awk '{print \$1}'); do + new_rpath=\$(find \$SAMBA_LIBS -name \$(basename \$old_rpath) | head -n 1) + install_name_tool -change \$old_rpath \$new_rpath \$BIN + done + '' + + '' + EOF + find $out -type f -regex '.*\${stdenv.hostPlatform.extensions.sharedLibrary}\(\..*\)?' -exec $SHELL -c "$SCRIPT" \; + find $out/bin -type f -exec $SHELL -c "$SCRIPT" \; - # Fix PYTHONPATH for some tools - wrapPythonPrograms + # Fix PYTHONPATH for some tools + wrapPythonPrograms - # Samba does its own shebang patching, but uses build Python - find $out/bin -type f -executable | while read file; do - isScript "$file" || continue - sed -i 's^${lib.getBin buildPackages.python3Packages.python}^${lib.getBin python}^' "$file" - done - ''; + # Samba does its own shebang patching, but uses build Python + find $out/bin -type f -executable | while read file; do + isScript "$file" || continue + sed -i 's^${lib.getBin buildPackages.python3Packages.python}^${lib.getBin python}^' "$file" + done + ''; - disallowedReferences = - lib.optionals (buildPackages.python3Packages.python != python3Packages.python) - [ buildPackages.python3Packages.python ]; + disallowedReferences = lib.optionals ( + buildPackages.python3Packages.python != python3Packages.python + ) [ buildPackages.python3Packages.python ]; passthru.tests = { samba = nixosTests.samba; diff --git a/pkgs/servers/search/elasticsearch/7.x.nix b/pkgs/servers/search/elasticsearch/7.x.nix index 0244783c58735c..1dd885e7d07c9d 100644 --- a/pkgs/servers/search/elasticsearch/7.x.nix +++ b/pkgs/servers/search/elasticsearch/7.x.nix @@ -1,27 +1,27 @@ -{ elk7Version -, lib -, stdenv -, fetchurl -, makeWrapper -, jre_headless -, util-linux -, gnugrep -, coreutils -, autoPatchelfHook -, zlib +{ + elk7Version, + lib, + stdenv, + fetchurl, + makeWrapper, + jre_headless, + util-linux, + gnugrep, + coreutils, + autoPatchelfHook, + zlib, }: let info = lib.splitString "-" stdenv.hostPlatform.system; arch = lib.elemAt info 0; plat = lib.elemAt info 1; - hashes = - { - x86_64-linux = "sha512-OiWGRxaCdRxXuxE/W04v87ytzOeUEcHRjF5nyRkdqSbZSnLXUyKOYQ4fKmk4til0VBOaKZYId20XyPiu/XTXNw=="; - x86_64-darwin = "sha512-V/vKYL96+M1lp7ZJlvuneRBePWZmucUANfUrFPMuq+fnUP4nN69RStLWcgwgt65EspFMBwKVyQbak4swV8rWxw=="; - aarch64-linux = "sha512-fNgVRaIIGx01reNHOnGKhMOG1aYU7gC8HLpIESSbM3+9xO1q9IHIaL/ObI/w2RYj/lD22d7PAdX5N6Hd1pVSAA=="; - aarch64-darwin = "sha512-DgexeyoxZ1YTPw9HjSUAM6eC8XtzIw7MY1WUVsIa8zl5j3RpCp25s3oI12BWefjYYCTjdtFDMsnoFSqZBabLig=="; - }; + hashes = { + x86_64-linux = "sha512-OiWGRxaCdRxXuxE/W04v87ytzOeUEcHRjF5nyRkdqSbZSnLXUyKOYQ4fKmk4til0VBOaKZYId20XyPiu/XTXNw=="; + x86_64-darwin = "sha512-V/vKYL96+M1lp7ZJlvuneRBePWZmucUANfUrFPMuq+fnUP4nN69RStLWcgwgt65EspFMBwKVyQbak4swV8rWxw=="; + aarch64-linux = "sha512-fNgVRaIIGx01reNHOnGKhMOG1aYU7gC8HLpIESSbM3+9xO1q9IHIaL/ObI/w2RYj/lD22d7PAdX5N6Hd1pVSAA=="; + aarch64-darwin = "sha512-DgexeyoxZ1YTPw9HjSUAM6eC8XtzIw7MY1WUVsIa8zl5j3RpCp25s3oI12BWefjYYCTjdtFDMsnoFSqZBabLig=="; + }; in stdenv.mkDerivation rec { pname = "elasticsearch"; @@ -44,10 +44,15 @@ stdenv.mkDerivation rec { "ES_CLASSPATH=\"\$ES_CLASSPATH:$out/\$additional_classpath_directory/*\"" ''; - nativeBuildInputs = [ makeWrapper ] - ++ lib.optional (!stdenv.hostPlatform.isDarwin) autoPatchelfHook; + nativeBuildInputs = [ + makeWrapper + ] ++ lib.optional (!stdenv.hostPlatform.isDarwin) autoPatchelfHook; - buildInputs = [ jre_headless util-linux zlib ]; + buildInputs = [ + jre_headless + util-linux + zlib + ]; runtimeDependencies = [ zlib ]; @@ -61,13 +66,21 @@ stdenv.mkDerivation rec { --replace 'bin/elasticsearch-keystore' "$out/bin/elasticsearch-keystore" wrapProgram $out/bin/elasticsearch \ - --prefix PATH : "${lib.makeBinPath [ util-linux coreutils gnugrep ]}" \ + --prefix PATH : "${ + lib.makeBinPath [ + util-linux + coreutils + gnugrep + ] + }" \ --set JAVA_HOME "${jre_headless}" wrapProgram $out/bin/elasticsearch-plugin --set JAVA_HOME "${jre_headless}" ''; - passthru = { enableUnfree = true; }; + passthru = { + enableUnfree = true; + }; meta = with lib; { description = "Open Source, Distributed, RESTful Search Engine"; @@ -77,6 +90,9 @@ stdenv.mkDerivation rec { ]; license = licenses.elastic20; platforms = platforms.unix; - maintainers = with maintainers; [ apeschar basvandijk ]; + maintainers = with maintainers; [ + apeschar + basvandijk + ]; }; } diff --git a/pkgs/servers/search/lnx/default.nix b/pkgs/servers/search/lnx/default.nix index 7cda5d44c4423f..99ebed0a823790 100644 --- a/pkgs/servers/search/lnx/default.nix +++ b/pkgs/servers/search/lnx/default.nix @@ -1,14 +1,16 @@ -{ stdenv -, lib -, rustPlatform -, fetchFromGitHub -, DiskArbitration -, Foundation +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + DiskArbitration, + Foundation, }: # unstable was chosen because of an added Cargo.lock # revert to stable for the version after 0.9.0 -let version = "unstable-2022-06-25"; +let + version = "unstable-2022-06-25"; in rustPlatform.buildRustPackage { pname = "lnx"; @@ -25,7 +27,10 @@ rustPlatform.buildRustPackage { "compose-0.1.0" = "sha256-zcniGI3wa+gI3jFTDqHcesX+6hAtNEbW81ABPUcFTXk="; }; }; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ DiskArbitration Foundation ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + DiskArbitration + Foundation + ]; meta = with lib; { description = "Insanely fast, Feature-rich searching. lnx is the adaptable, typo tollerant deployment of the tantivy search engine. Standing on the shoulders of giants."; mainProgram = "lnx"; diff --git a/pkgs/servers/search/qdrant/default.nix b/pkgs/servers/search/qdrant/default.nix index 744161f5cf737a..fb434246323e90 100644 --- a/pkgs/servers/search/qdrant/default.nix +++ b/pkgs/servers/search/qdrant/default.nix @@ -1,14 +1,15 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, protobuf -, stdenv -, pkg-config -, openssl -, rust-jemalloc-sys -, nix-update-script -, Security -, SystemConfiguration +{ + lib, + rustPlatform, + fetchFromGitHub, + protobuf, + stdenv, + pkg-config, + openssl, + rust-jemalloc-sys, + nix-update-script, + Security, + SystemConfiguration, }: rustPlatform.buildRustPackage rec { @@ -30,22 +31,30 @@ rustPlatform.buildRustPackage rec { }; }; - buildInputs = [ - openssl - rust-jemalloc-sys - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - SystemConfiguration - ]; + buildInputs = + [ + openssl + rust-jemalloc-sys + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + ]; - nativeBuildInputs = [ protobuf rustPlatform.bindgenHook pkg-config ]; + nativeBuildInputs = [ + protobuf + rustPlatform.bindgenHook + pkg-config + ]; - env = { - # Needed to get openssl-sys to use pkg-config. - OPENSSL_NO_VENDOR = 1; - } // lib.optionalAttrs stdenv.cc.isClang { - NIX_CFLAGS_COMPILE = "-faligned-allocation"; - }; + env = + { + # Needed to get openssl-sys to use pkg-config. + OPENSSL_NO_VENDOR = 1; + } + // lib.optionalAttrs stdenv.cc.isClang { + NIX_CFLAGS_COMPILE = "-faligned-allocation"; + }; passthru = { updateScript = nix-update-script { }; diff --git a/pkgs/servers/search/quickwit/default.nix b/pkgs/servers/search/quickwit/default.nix index 8dbb25398bc1ac..f056a726d47627 100644 --- a/pkgs/servers/search/quickwit/default.nix +++ b/pkgs/servers/search/quickwit/default.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, rustPlatform -, nixosTests -, nix-update-script -, protobuf -, rust-jemalloc-sys -, Security -, nodejs -, yarn -, fetchYarnDeps -, fixup-yarn-lock +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + nixosTests, + nix-update-script, + protobuf, + rust-jemalloc-sys, + Security, + nodejs, + yarn, + fetchYarnDeps, + fixup-yarn-lock, }: let diff --git a/pkgs/servers/search/typesense/default.nix b/pkgs/servers/search/typesense/default.nix index 2a641cd752fc4a..5558ef38ad5e06 100644 --- a/pkgs/servers/search/typesense/default.nix +++ b/pkgs/servers/search/typesense/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, nixosTests +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + nixosTests, }: let inherit (stdenv.hostPlatform) system; diff --git a/pkgs/servers/shairplay/default.nix b/pkgs/servers/shairplay/default.nix index 63de8df58fd846..3bfdd8ead9afb3 100644 --- a/pkgs/servers/shairplay/default.nix +++ b/pkgs/servers/shairplay/default.nix @@ -1,20 +1,33 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config -, avahi, libao }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + avahi, + libao, +}: stdenv.mkDerivation rec { pname = "shairplay-unstable"; version = "2018-08-24"; src = fetchFromGitHub { - owner = "juhovh"; - repo = "shairplay"; - rev = "096b61ad14c90169f438e690d096e3fcf87e504e"; + owner = "juhovh"; + repo = "shairplay"; + rev = "096b61ad14c90169f438e690d096e3fcf87e504e"; sha256 = "02xkd9al79pbqh8rhzz5w99vv43jg5vqkqg7kxsw8c8sz9di9wsa"; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ avahi libao ]; + buildInputs = [ + avahi + libao + ]; enableParallelBuilding = true; @@ -28,9 +41,9 @@ stdenv.mkDerivation rec { meta = with lib; { inherit (src.meta) homepage; description = "Apple AirPlay and RAOP protocol server"; - license = licenses.mit; + license = licenses.mit; maintainers = with maintainers; [ peterhoeg ]; - platforms = platforms.unix; + platforms = platforms.unix; mainProgram = "shairplay"; }; } diff --git a/pkgs/servers/shishi/default.nix b/pkgs/servers/shishi/default.nix index 926486c73c9752..264b225b0c08cd 100644 --- a/pkgs/servers/shishi/default.nix +++ b/pkgs/servers/shishi/default.nix @@ -1,12 +1,21 @@ -{ lib, stdenv, fetchurl, pkg-config -, libgcrypt, libgpg-error, libtasn1 +{ + lib, + stdenv, + fetchurl, + pkg-config, + libgcrypt, + libgpg-error, + libtasn1, -# Optional Dependencies -, pam ? null, libidn ? null, gnutls ? null + # Optional Dependencies + pam ? null, + libidn ? null, + gnutls ? null, }: let - shouldUsePkg = pkg: if pkg != null && lib.meta.availableOn stdenv.hostPlatform pkg then pkg else null; + shouldUsePkg = + pkg: if pkg != null && lib.meta.availableOn stdenv.hostPlatform pkg then pkg else null; optPam = shouldUsePkg pam; optLibidn = shouldUsePkg libidn; @@ -26,52 +35,65 @@ stdenv.mkDerivation rec { separateDebugInfo = true; # Fixes support for gcrypt 1.6+ - patches = [ ./gcrypt-fix.patch ./freebsd-unistd.patch ]; + patches = [ + ./gcrypt-fix.patch + ./freebsd-unistd.patch + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libgcrypt libgpg-error libtasn1 optPam optLibidn optGnutls ]; + buildInputs = [ + libgcrypt + libgpg-error + libtasn1 + optPam + optLibidn + optGnutls + ]; configureFlags = [ "--sysconfdir=/etc" "--localstatedir=/var" - (enableFeature true "libgcrypt") - (enableFeature (optPam != null) "pam") - (enableFeature true "ipv6") - (withFeature (optLibidn != null) "stringprep") + (enableFeature true "libgcrypt") + (enableFeature (optPam != null) "pam") + (enableFeature true "ipv6") + (withFeature (optLibidn != null) "stringprep") (enableFeature (optGnutls != null) "starttls") - (enableFeature true "des") - (enableFeature true "3des") - (enableFeature true "aes") - (enableFeature true "md") - (enableFeature false "null") - (enableFeature true "arcfour") + (enableFeature true "des") + (enableFeature true "3des") + (enableFeature true "aes") + (enableFeature true "md") + (enableFeature false "null") + (enableFeature true "arcfour") ]; - env.NIX_CFLAGS_COMPILE - = optionalString stdenv.hostPlatform.isDarwin "-DBIND_8_COMPAT"; + env.NIX_CFLAGS_COMPILE = optionalString stdenv.hostPlatform.isDarwin "-DBIND_8_COMPAT"; doCheck = true; installFlags = [ "sysconfdir=\${out}/etc" ]; # Fix *.la files - postInstall = '' - sed -i $out/lib/libshi{sa,shi}.la \ - '' + optionalString (optLibidn != null) '' + postInstall = + '' + sed -i $out/lib/libshi{sa,shi}.la \ + '' + + optionalString (optLibidn != null) '' -e 's,\(-lidn\),-L${optLibidn.out}/lib \1,' \ - '' + optionalString (optGnutls != null) '' + '' + + optionalString (optGnutls != null) '' -e 's,\(-lgnutls\),-L${optGnutls.out}/lib \1,' \ - '' + '' + '' + + '' -e 's,\(-lgcrypt\),-L${libgcrypt.out}/lib \1,' \ -e 's,\(-lgpg-error\),-L${libgpg-error.out}/lib \1,' \ -e 's,\(-ltasn1\),-L${libtasn1.out}/lib \1,' - ''; + ''; meta = with lib; { - homepage = "https://www.gnu.org/software/shishi/"; + homepage = "https://www.gnu.org/software/shishi/"; description = "Implementation of the Kerberos 5 network security system"; - license = licenses.gpl3Plus; + license = licenses.gpl3Plus; maintainers = with maintainers; [ lovek323 ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/servers/sickbeard/sickgear.nix b/pkgs/servers/sickbeard/sickgear.nix index 3184b642505631..1bbf138e6786ef 100644 --- a/pkgs/servers/sickbeard/sickgear.nix +++ b/pkgs/servers/sickbeard/sickgear.nix @@ -1,8 +1,21 @@ -{ lib, stdenv, fetchFromGitHub, python3, makeWrapper, libarchive }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, + makeWrapper, + libarchive, +}: let - pythonEnv = python3.withPackages(ps: with ps; [ cheetah3 lxml ]); -in stdenv.mkDerivation rec { + pythonEnv = python3.withPackages ( + ps: with ps; [ + cheetah3 + lxml + ] + ); +in +stdenv.mkDerivation rec { pname = "sickgear"; version = "3.32.11"; @@ -21,7 +34,10 @@ in stdenv.mkDerivation rec { doCheck = false; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ pythonEnv libarchive ]; + buildInputs = [ + pythonEnv + libarchive + ]; installPhase = '' mkdir -p $out/bin $out/opt/sickgear @@ -34,8 +50,8 @@ in stdenv.mkDerivation rec { meta = with lib; { description = "Most reliable stable TV fork of the great Sick-Beard to fully automate TV enjoyment with innovation"; mainProgram = "sickgear"; - license = licenses.gpl3; - homepage = "https://github.com/SickGear/SickGear"; + license = licenses.gpl3; + homepage = "https://github.com/SickGear/SickGear"; maintainers = with lib.maintainers; [ rembo10 ]; }; } diff --git a/pkgs/servers/sip/freeswitch/default.nix b/pkgs/servers/sip/freeswitch/default.nix index 9d11ad68a40565..bbbccaea5fc2fb 100644 --- a/pkgs/servers/sip/freeswitch/default.nix +++ b/pkgs/servers/sip/freeswitch/default.nix @@ -1,103 +1,110 @@ -{ fetchFromGitHub -, stdenv -, lib -, pkg-config -, autoreconfHook -, ncurses -, gnutls -, readline -, openssl -, perl -, sqlite -, libjpeg -, speex -, pcre -, libuuid -, ldns -, libedit -, yasm -, which -, libsndfile -, libtiff -, libxcrypt -, callPackage -, SystemConfiguration -, modules ? null -, nixosTests +{ + fetchFromGitHub, + stdenv, + lib, + pkg-config, + autoreconfHook, + ncurses, + gnutls, + readline, + openssl, + perl, + sqlite, + libjpeg, + speex, + pcre, + libuuid, + ldns, + libedit, + yasm, + which, + libsndfile, + libtiff, + libxcrypt, + callPackage, + SystemConfiguration, + modules ? null, + nixosTests, }: let -availableModules = callPackage ./modules.nix { }; - -# the default list from v1.8.7, except with applications/mod_signalwire also disabled -defaultModules = mods: with mods; [ - applications.commands - applications.conference - applications.db - applications.dptools - applications.enum - applications.esf - applications.expr - applications.fifo - applications.fsv - applications.hash - applications.httapi - applications.sms - applications.spandsp - applications.valet_parking - applications.voicemail - - applications.curl - - codecs.amr - codecs.b64 - codecs.g723_1 - codecs.g729 - codecs.h26x - codecs.opus - - databases.mariadb - databases.pgsql - - dialplans.asterisk - dialplans.xml - - endpoints.loopback - endpoints.rtc - endpoints.skinny - endpoints.sofia - endpoints.verto - - event_handlers.cdr_csv - event_handlers.cdr_sqlite - event_handlers.event_socket - - formats.local_stream - formats.native_file - formats.png - formats.sndfile - formats.tone_stream - - languages.lua - - loggers.console - loggers.logfile - loggers.syslog - - say.en - - xml_int.cdr - xml_int.rpc - xml_int.scgi -] ++ lib.optionals stdenv.hostPlatform.isLinux [ endpoints.gsmopen ]; - -enabledModules = (if modules != null then modules else defaultModules) availableModules; - -modulesConf = let - lst = builtins.map (mod: mod.path) enabledModules; - str = lib.strings.concatStringsSep "\n" lst; - in builtins.toFile "modules.conf" str; + availableModules = callPackage ./modules.nix { }; + + # the default list from v1.8.7, except with applications/mod_signalwire also disabled + defaultModules = + mods: + with mods; + [ + applications.commands + applications.conference + applications.db + applications.dptools + applications.enum + applications.esf + applications.expr + applications.fifo + applications.fsv + applications.hash + applications.httapi + applications.sms + applications.spandsp + applications.valet_parking + applications.voicemail + + applications.curl + + codecs.amr + codecs.b64 + codecs.g723_1 + codecs.g729 + codecs.h26x + codecs.opus + + databases.mariadb + databases.pgsql + + dialplans.asterisk + dialplans.xml + + endpoints.loopback + endpoints.rtc + endpoints.skinny + endpoints.sofia + endpoints.verto + + event_handlers.cdr_csv + event_handlers.cdr_sqlite + event_handlers.event_socket + + formats.local_stream + formats.native_file + formats.png + formats.sndfile + formats.tone_stream + + languages.lua + + loggers.console + loggers.logfile + loggers.syslog + + say.en + + xml_int.cdr + xml_int.rpc + xml_int.scgi + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ endpoints.gsmopen ]; + + enabledModules = (if modules != null then modules else defaultModules) availableModules; + + modulesConf = + let + lst = builtins.map (mod: mod.path) enabledModules; + str = lib.strings.concatStringsSep "\n" lst; + in + builtins.toFile "modules.conf" str; in @@ -126,15 +133,32 @@ stdenv.mkDerivation rec { ''; strictDeps = true; - nativeBuildInputs = [ pkg-config autoreconfHook perl which yasm ]; - buildInputs = [ - openssl ncurses gnutls readline libjpeg - sqlite pcre speex ldns libedit - libsndfile libtiff - libuuid libxcrypt - ] - ++ lib.unique (lib.concatMap (mod: mod.inputs) enabledModules) - ++ lib.optionals stdenv.hostPlatform.isDarwin [ SystemConfiguration ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + perl + which + yasm + ]; + buildInputs = + [ + openssl + ncurses + gnutls + readline + libjpeg + sqlite + pcre + speex + ldns + libedit + libsndfile + libtiff + libuuid + libxcrypt + ] + ++ lib.unique (lib.concatMap (mod: mod.inputs) enabledModules) + ++ lib.optionals stdenv.hostPlatform.isDarwin [ SystemConfiguration ]; enableParallelBuilding = true; diff --git a/pkgs/servers/sks/default.nix b/pkgs/servers/sks/default.nix index afb46a2950891c..e93d3e4cd95068 100644 --- a/pkgs/servers/sks/default.nix +++ b/pkgs/servers/sks/default.nix @@ -1,5 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, ocamlPackages, perl -, zlib, db +{ + lib, + stdenv, + fetchFromGitHub, + ocamlPackages, + perl, + zlib, + db, }: let @@ -27,12 +33,27 @@ stdenv.mkDerivation rec { ./adapt-to-nixos.patch ]; - outputs = [ "out" "webSamples" ]; + outputs = [ + "out" + "webSamples" + ]; - nativeBuildInputs = [ ocaml findlib perl ]; - buildInputs = [ zlib db cryptokit num ]; + nativeBuildInputs = [ + ocaml + findlib + perl + ]; + buildInputs = [ + zlib + db + cryptokit + num + ]; - makeFlags = [ "PREFIX=$(out)" "MANDIR=$(out)/share/man" ]; + makeFlags = [ + "PREFIX=$(out)" + "MANDIR=$(out)/share/man" + ]; preConfigure = '' cp Makefile.local.unused Makefile.local sed -i \ @@ -63,4 +84,3 @@ stdenv.mkDerivation rec { maintainers = [ ]; }; } - diff --git a/pkgs/servers/snac2/default.nix b/pkgs/servers/snac2/default.nix index 653bc9c5ccfaef..6b205a98a858d0 100644 --- a/pkgs/servers/snac2/default.nix +++ b/pkgs/servers/snac2/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitea -, curl -, openssl -, nix-update-script -, testers -, snac2 +{ + stdenv, + lib, + fetchFromGitea, + curl, + openssl, + nix-update-script, + testers, + snac2, }: stdenv.mkDerivation rec { @@ -20,14 +21,19 @@ stdenv.mkDerivation rec { hash = "sha256-jzkimE4JPrlsHP0jPawhloXMDNaWG1Sgfp5NiZxm1xo="; }; - buildInputs = [ curl openssl ]; + buildInputs = [ + curl + openssl + ]; makeFlags = [ "PREFIX=$(out)" ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-Dst_mtim=st_mtimespec" - "-Dst_ctim=st_ctimespec" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-Dst_mtim=st_mtimespec" + "-Dst_ctim=st_ctimespec" + ] + ); passthru = { tests.version = testers.testVersion { diff --git a/pkgs/servers/spicedb/zed.nix b/pkgs/servers/spicedb/zed.nix index 07a523cd2fd486..98364e02609895 100644 --- a/pkgs/servers/spicedb/zed.nix +++ b/pkgs/servers/spicedb/zed.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/servers/sql/mariadb/connector-c/3_1.nix b/pkgs/servers/sql/mariadb/connector-c/3_1.nix index a51fc1d104b1eb..2846717930ab0c 100644 --- a/pkgs/servers/sql/mariadb/connector-c/3_1.nix +++ b/pkgs/servers/sql/mariadb/connector-c/3_1.nix @@ -1,6 +1,9 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./. (args // { - version = "3.1.21"; - hash = "sha256-guN3Rcsb/EV4rxPE3yhJRSsT1+z44zUetg7ZBA4WjIc="; -}) +callPackage ./. ( + args + // { + version = "3.1.21"; + hash = "sha256-guN3Rcsb/EV4rxPE3yhJRSsT1+z44zUetg7ZBA4WjIc="; + } +) diff --git a/pkgs/servers/sql/mariadb/connector-c/3_2.nix b/pkgs/servers/sql/mariadb/connector-c/3_2.nix index 6619e261650c73..392c43580c2e57 100644 --- a/pkgs/servers/sql/mariadb/connector-c/3_2.nix +++ b/pkgs/servers/sql/mariadb/connector-c/3_2.nix @@ -1,6 +1,9 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./. (args // { - version = "3.2.7"; - hash = "sha256-F7s9fcbJiz6lsWrvlTpY+ZET8MPwlyWPKJZOvHEwBvo="; -}) +callPackage ./. ( + args + // { + version = "3.2.7"; + hash = "sha256-F7s9fcbJiz6lsWrvlTpY+ZET8MPwlyWPKJZOvHEwBvo="; + } +) diff --git a/pkgs/servers/sql/mariadb/connector-c/3_3.nix b/pkgs/servers/sql/mariadb/connector-c/3_3.nix index 9f750fe8108bee..ccd15c48f966c9 100644 --- a/pkgs/servers/sql/mariadb/connector-c/3_3.nix +++ b/pkgs/servers/sql/mariadb/connector-c/3_3.nix @@ -1,6 +1,9 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./. (args // { - version = "3.3.5"; - hash = "sha256-RLHx8PyfbfIDr6X6ky5/w0XsGMFd+v5PgmQHvYOaf+k="; -}) +callPackage ./. ( + args + // { + version = "3.3.5"; + hash = "sha256-RLHx8PyfbfIDr6X6ky5/w0XsGMFd+v5PgmQHvYOaf+k="; + } +) diff --git a/pkgs/servers/sql/mariadb/connector-c/default.nix b/pkgs/servers/sql/mariadb/connector-c/default.nix index e27179e8ab2f17..6b5a5674078f60 100644 --- a/pkgs/servers/sql/mariadb/connector-c/default.nix +++ b/pkgs/servers/sql/mariadb/connector-c/default.nix @@ -1,13 +1,23 @@ -{ lib, stdenv, fetchFromGitHub, cmake -, curl, openssl, zlib, zstd -, libiconv -, version, hash, ... +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + curl, + openssl, + zlib, + zstd, + libiconv, + version, + hash, + ... }: let isVer33 = lib.versionAtLeast version "3.3"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "mariadb-connector-c"; inherit version; @@ -18,7 +28,10 @@ in stdenv.mkDerivation { inherit hash; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; cmakeFlags = [ "-DMARIADB_UNIX_ADDR=/run/mysqld/mysqld.sock" @@ -27,21 +40,23 @@ in stdenv.mkDerivation { "-DWITH_MYSQLCOMPAT=ON" ]; - postPatch = '' - substituteInPlace mariadb_config/mariadb_config.c.in \ - --replace '#define INCLUDE "-I%s/@INSTALL_INCLUDEDIR@ -I%s/@INSTALL_INCLUDEDIR@/mysql"' "#define INCLUDE \"-I$dev/include -I$dev/include/mysql\"" \ - --replace '#define LIBS "-L%s/@INSTALL_LIBDIR@/ -lmariadb"' "#define LIBS \"-L$out/lib/mariadb -lmariadb\"" \ - --replace '#define PKG_LIBDIR "%s/@INSTALL_LIBDIR@"' "#define PKG_LIBDIR \"$out/lib/mariadb\"" \ - --replace '#define PLUGIN_DIR "%s/@INSTALL_PLUGINDIR@"' "#define PLUGIN_DIR \"$out/lib/mariadb/plugin\"" \ - --replace '#define PKG_PLUGINDIR "%s/@INSTALL_PLUGINDIR@"' "#define PKG_PLUGINDIR \"$out/lib/mariadb/plugin\"" - '' + lib.optionalString stdenv.hostPlatform.isStatic '' - # Disables all dynamic plugins - substituteInPlace cmake/plugins.cmake \ - --replace 'if(''${CC_PLUGIN_DEFAULT} STREQUAL "DYNAMIC")' 'if(''${CC_PLUGIN_DEFAULT} STREQUAL "INVALID")' - # Force building static libraries - substituteInPlace libmariadb/CMakeLists.txt \ - --replace 'libmariadb SHARED' 'libmariadb STATIC' - ''; + postPatch = + '' + substituteInPlace mariadb_config/mariadb_config.c.in \ + --replace '#define INCLUDE "-I%s/@INSTALL_INCLUDEDIR@ -I%s/@INSTALL_INCLUDEDIR@/mysql"' "#define INCLUDE \"-I$dev/include -I$dev/include/mysql\"" \ + --replace '#define LIBS "-L%s/@INSTALL_LIBDIR@/ -lmariadb"' "#define LIBS \"-L$out/lib/mariadb -lmariadb\"" \ + --replace '#define PKG_LIBDIR "%s/@INSTALL_LIBDIR@"' "#define PKG_LIBDIR \"$out/lib/mariadb\"" \ + --replace '#define PLUGIN_DIR "%s/@INSTALL_PLUGINDIR@"' "#define PLUGIN_DIR \"$out/lib/mariadb/plugin\"" \ + --replace '#define PKG_PLUGINDIR "%s/@INSTALL_PLUGINDIR@"' "#define PKG_PLUGINDIR \"$out/lib/mariadb/plugin\"" + '' + + lib.optionalString stdenv.hostPlatform.isStatic '' + # Disables all dynamic plugins + substituteInPlace cmake/plugins.cmake \ + --replace 'if(''${CC_PLUGIN_DEFAULT} STREQUAL "DYNAMIC")' 'if(''${CC_PLUGIN_DEFAULT} STREQUAL "INVALID")' + # Force building static libraries + substituteInPlace libmariadb/CMakeLists.txt \ + --replace 'libmariadb SHARED' 'libmariadb STATIC' + ''; # The cmake setup-hook uses $out/lib by default, this is not the case here. preConfigure = lib.optionalString stdenv.hostPlatform.isDarwin '' @@ -49,7 +64,11 @@ in stdenv.mkDerivation { ''; nativeBuildInputs = [ cmake ]; - propagatedBuildInputs = [ curl openssl zlib ] ++ lib.optional isVer33 zstd; + propagatedBuildInputs = [ + curl + openssl + zlib + ] ++ lib.optional isVer33 zstd; buildInputs = [ libiconv ]; postInstall = '' diff --git a/pkgs/servers/sql/mariadb/default.nix b/pkgs/servers/sql/mariadb/default.nix index 76ce8d6b6dc9af..9f6e2a4314fe7b 100644 --- a/pkgs/servers/sql/mariadb/default.nix +++ b/pkgs/servers/sql/mariadb/default.nix @@ -1,269 +1,390 @@ let # shared across all versions generic = - { version, hash - , lib, stdenv, fetchurl, nixosTests, buildPackages - # Native buildInputs components - , bison, boost, cmake, fixDarwinDylibNames, flex, makeWrapper, pkg-config - # Common components - , curl, libiconv, ncurses, openssl, pcre2 - , libkrb5, libaio, liburing, systemd - , CoreServices, cctools, perl - , jemalloc, less, libedit - # Server components - , bzip2, lz4, lzo, snappy, xz, zlib, zstd - , cracklib, judy, libevent, libxml2 - , linux-pam, numactl - , fmt_8 - , withStorageMroonga ? true, kytea, libsodium, msgpack, zeromq - , withStorageRocks ? true - , withEmbedded ? false - , withNuma ? false + { + version, + hash, + lib, + stdenv, + fetchurl, + nixosTests, + buildPackages, + # Native buildInputs components + bison, + boost, + cmake, + fixDarwinDylibNames, + flex, + makeWrapper, + pkg-config, + # Common components + curl, + libiconv, + ncurses, + openssl, + pcre2, + libkrb5, + libaio, + liburing, + systemd, + CoreServices, + cctools, + perl, + jemalloc, + less, + libedit, + # Server components + bzip2, + lz4, + lzo, + snappy, + xz, + zlib, + zstd, + cracklib, + judy, + libevent, + libxml2, + linux-pam, + numactl, + fmt_8, + withStorageMroonga ? true, + kytea, + libsodium, + msgpack, + zeromq, + withStorageRocks ? true, + withEmbedded ? false, + withNuma ? false, }: - let - isCross = stdenv.buildPlatform != stdenv.hostPlatform; + let + isCross = stdenv.buildPlatform != stdenv.hostPlatform; - libExt = stdenv.hostPlatform.extensions.sharedLibrary; + libExt = stdenv.hostPlatform.extensions.sharedLibrary; - mytopEnv = buildPackages.perl.withPackages (p: with p; [ DBDmysql DBI TermReadKey ]); + mytopEnv = buildPackages.perl.withPackages ( + p: with p; [ + DBDmysql + DBI + TermReadKey + ] + ); - common = rec { # attributes common to both builds - inherit version; + common = rec { + # attributes common to both builds + inherit version; - src = fetchurl { - url = "https://archive.mariadb.org/mariadb-${version}/source/mariadb-${version}.tar.gz"; - inherit hash; - }; + src = fetchurl { + url = "https://archive.mariadb.org/mariadb-${version}/source/mariadb-${version}.tar.gz"; + inherit hash; + }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - nativeBuildInputs = [ cmake pkg-config ] - ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames - ++ lib.optional (!stdenv.hostPlatform.isDarwin) makeWrapper; + nativeBuildInputs = + [ + cmake + pkg-config + ] + ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames + ++ lib.optional (!stdenv.hostPlatform.isDarwin) makeWrapper; - buildInputs = [ - libiconv ncurses zlib - pcre2 - openssl - curl - ] ++ lib.optionals stdenv.hostPlatform.isLinux ([ libkrb5 systemd ] - ++ (if (lib.versionOlder version "10.6") then [ libaio ] else [ liburing ])) - ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices cctools perl libedit ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ jemalloc ]; + buildInputs = + [ + libiconv + ncurses + zlib + pcre2 + openssl + curl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux ( + [ + libkrb5 + systemd + ] + ++ (if (lib.versionOlder version "10.6") then [ libaio ] else [ liburing ]) + ) + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + cctools + perl + libedit + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ jemalloc ]; - prePatch = '' - sed -i 's,[^"]*/var/log,/var/log,g' storage/mroonga/vendor/groonga/CMakeLists.txt - ''; + prePatch = '' + sed -i 's,[^"]*/var/log,/var/log,g' storage/mroonga/vendor/groonga/CMakeLists.txt + ''; - patches = [ - ./patch/cmake-includedir.patch - ] - # Fixes a build issue as documented on - # https://jira.mariadb.org/browse/MDEV-26769?focusedCommentId=206073&page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel#comment-206073 - ++ lib.optional (!stdenv.hostPlatform.isLinux && lib.versionAtLeast version "10.6") ./patch/macos-MDEV-26769-regression-fix.patch; + patches = + [ + ./patch/cmake-includedir.patch + ] + # Fixes a build issue as documented on + # https://jira.mariadb.org/browse/MDEV-26769?focusedCommentId=206073&page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel#comment-206073 + ++ lib.optional ( + !stdenv.hostPlatform.isLinux && lib.versionAtLeast version "10.6" + ) ./patch/macos-MDEV-26769-regression-fix.patch; - cmakeFlags = [ - "-DBUILD_CONFIG=mysql_release" - "-DMANUFACTURER=nixos.org" - "-DDEFAULT_CHARSET=utf8mb4" - "-DDEFAULT_COLLATION=utf8mb4_unicode_ci" - "-DSECURITY_HARDENED=ON" + cmakeFlags = + [ + "-DBUILD_CONFIG=mysql_release" + "-DMANUFACTURER=nixos.org" + "-DDEFAULT_CHARSET=utf8mb4" + "-DDEFAULT_COLLATION=utf8mb4_unicode_ci" + "-DSECURITY_HARDENED=ON" - "-DINSTALL_UNIX_ADDRDIR=/run/mysqld/mysqld.sock" - "-DINSTALL_BINDIR=bin" - "-DINSTALL_DOCDIR=share/doc/mysql" - "-DINSTALL_DOCREADMEDIR=share/doc/mysql" - "-DINSTALL_INCLUDEDIR=include/mysql" - "-DINSTALL_LIBDIR=lib" - "-DINSTALL_PLUGINDIR=lib/mysql/plugin" - "-DINSTALL_INFODIR=share/mysql/docs" - "-DINSTALL_MANDIR=share/man" - "-DINSTALL_MYSQLSHAREDIR=share/mysql" - "-DINSTALL_SCRIPTDIR=bin" - "-DINSTALL_SUPPORTFILESDIR=share/doc/mysql" - "-DINSTALL_MYSQLTESTDIR=OFF" - "-DINSTALL_SQLBENCHDIR=OFF" - "-DINSTALL_PAMDIR=share/pam/lib/security" - "-DINSTALL_PAMDATADIR=share/pam/etc/security" + "-DINSTALL_UNIX_ADDRDIR=/run/mysqld/mysqld.sock" + "-DINSTALL_BINDIR=bin" + "-DINSTALL_DOCDIR=share/doc/mysql" + "-DINSTALL_DOCREADMEDIR=share/doc/mysql" + "-DINSTALL_INCLUDEDIR=include/mysql" + "-DINSTALL_LIBDIR=lib" + "-DINSTALL_PLUGINDIR=lib/mysql/plugin" + "-DINSTALL_INFODIR=share/mysql/docs" + "-DINSTALL_MANDIR=share/man" + "-DINSTALL_MYSQLSHAREDIR=share/mysql" + "-DINSTALL_SCRIPTDIR=bin" + "-DINSTALL_SUPPORTFILESDIR=share/doc/mysql" + "-DINSTALL_MYSQLTESTDIR=OFF" + "-DINSTALL_SQLBENCHDIR=OFF" + "-DINSTALL_PAMDIR=share/pam/lib/security" + "-DINSTALL_PAMDATADIR=share/pam/etc/security" - "-DWITH_ZLIB=system" - "-DWITH_SSL=system" - "-DWITH_PCRE=system" - "-DWITH_SAFEMALLOC=OFF" - "-DWITH_UNIT_TESTS=OFF" - "-DEMBEDDED_LIBRARY=OFF" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # On Darwin without sandbox, CMake will find the system java and attempt to build with java support, but - # then it will fail during the actual build. Let's just disable the flag explicitly until someone decides - # to pass in java explicitly. - "-DCONNECT_WITH_JDBC=OFF" - "-DCURSES_LIBRARY=${ncurses.out}/lib/libncurses.dylib" - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && lib.versionAtLeast version "10.6") [ - # workaround for https://jira.mariadb.org/browse/MDEV-29925 - "-Dhave_C__Wl___as_needed=" - ] ++ lib.optionals isCross [ - # revisit this if nixpkgs supports any architecture whose stack grows upwards - "-DSTACK_DIRECTION=-1" - "-DCMAKE_CROSSCOMPILING_EMULATOR=${stdenv.hostPlatform.emulator buildPackages}" - ]; + "-DWITH_ZLIB=system" + "-DWITH_SSL=system" + "-DWITH_PCRE=system" + "-DWITH_SAFEMALLOC=OFF" + "-DWITH_UNIT_TESTS=OFF" + "-DEMBEDDED_LIBRARY=OFF" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # On Darwin without sandbox, CMake will find the system java and attempt to build with java support, but + # then it will fail during the actual build. Let's just disable the flag explicitly until someone decides + # to pass in java explicitly. + "-DCONNECT_WITH_JDBC=OFF" + "-DCURSES_LIBRARY=${ncurses.out}/lib/libncurses.dylib" + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && lib.versionAtLeast version "10.6") [ + # workaround for https://jira.mariadb.org/browse/MDEV-29925 + "-Dhave_C__Wl___as_needed=" + ] + ++ lib.optionals isCross [ + # revisit this if nixpkgs supports any architecture whose stack grows upwards + "-DSTACK_DIRECTION=-1" + "-DCMAKE_CROSSCOMPILING_EMULATOR=${stdenv.hostPlatform.emulator buildPackages}" + ]; - postInstall = lib.optionalString (!withEmbedded) '' - # Remove Development components. Need to use libmysqlclient. - rm "$out"/lib/mysql/plugin/daemon_example.ini - rm "$out"/lib/{libmariadb.a,libmariadbclient.a,libmysqlclient.a,libmysqlclient_r.a,libmysqlservices.a} - rm -f "$out"/bin/{mariadb-config,mariadb_config,mysql_config} - rm -r $out/include - rm -r $out/lib/pkgconfig - ''; + postInstall = lib.optionalString (!withEmbedded) '' + # Remove Development components. Need to use libmysqlclient. + rm "$out"/lib/mysql/plugin/daemon_example.ini + rm "$out"/lib/{libmariadb.a,libmariadbclient.a,libmysqlclient.a,libmysqlclient_r.a,libmysqlservices.a} + rm -f "$out"/bin/{mariadb-config,mariadb_config,mysql_config} + rm -r $out/include + rm -r $out/lib/pkgconfig + ''; - # perlPackages.DBDmysql is broken on darwin - postFixup = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - wrapProgram $out/bin/mytop --set PATH ${lib.makeBinPath [ less ncurses ]} - ''; + # perlPackages.DBDmysql is broken on darwin + postFixup = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + wrapProgram $out/bin/mytop --set PATH ${ + lib.makeBinPath [ + less + ncurses + ] + } + ''; - passthru.tests = let - testVersion = "mariadb_${builtins.replaceStrings ["."] [""] (lib.versions.majorMinor version)}"; - in { - mariadb-galera-rsync = nixosTests.mariadb-galera.${testVersion}; - mysql = nixosTests.mysql.${testVersion}; - mysql-autobackup = nixosTests.mysql-autobackup.${testVersion}; - mysql-backup = nixosTests.mysql-backup.${testVersion}; - mysql-replication = nixosTests.mysql-replication.${testVersion}; - }; + passthru.tests = + let + testVersion = "mariadb_${builtins.replaceStrings [ "." ] [ "" ] (lib.versions.majorMinor version)}"; + in + { + mariadb-galera-rsync = nixosTests.mariadb-galera.${testVersion}; + mysql = nixosTests.mysql.${testVersion}; + mysql-autobackup = nixosTests.mysql-autobackup.${testVersion}; + mysql-backup = nixosTests.mysql-backup.${testVersion}; + mysql-replication = nixosTests.mysql-replication.${testVersion}; + }; - meta = with lib; { - description = "Enhanced, drop-in replacement for MySQL"; - homepage = "https://mariadb.org/"; - license = licenses.gpl2Plus; - maintainers = with maintainers; [ thoughtpolice ] ++ teams.helsinki-systems.members; - platforms = platforms.all; + meta = with lib; { + description = "Enhanced, drop-in replacement for MySQL"; + homepage = "https://mariadb.org/"; + license = licenses.gpl2Plus; + maintainers = with maintainers; [ thoughtpolice ] ++ teams.helsinki-systems.members; + platforms = platforms.all; + }; }; - }; - client = stdenv.mkDerivation (common // { - pname = "mariadb-client"; + client = stdenv.mkDerivation ( + common + // { + pname = "mariadb-client"; - patches = common.patches ++ [ - ./patch/cmake-plugin-includedir.patch - ]; + patches = common.patches ++ [ + ./patch/cmake-plugin-includedir.patch + ]; - buildInputs = common.buildInputs - ++ lib.optionals (lib.versionAtLeast common.version "10.7") [ fmt_8 ]; + buildInputs = + common.buildInputs + ++ lib.optionals (lib.versionAtLeast common.version "10.7") [ fmt_8 ]; - cmakeFlags = common.cmakeFlags ++ [ - "-DPLUGIN_AUTH_PAM=NO" - "-DWITHOUT_SERVER=ON" - "-DWITH_WSREP=OFF" - "-DINSTALL_MYSQLSHAREDIR=share/mysql-client" - ]; + cmakeFlags = common.cmakeFlags ++ [ + "-DPLUGIN_AUTH_PAM=NO" + "-DWITHOUT_SERVER=ON" + "-DWITH_WSREP=OFF" + "-DINSTALL_MYSQLSHAREDIR=share/mysql-client" + ]; - postInstall = common.postInstall + '' - rm "$out"/bin/{mariadb-test,mysqltest} - libmysqlclient_path=$(readlink -f $out/lib/libmysqlclient${libExt}) - rm "$out"/lib/{libmariadb${libExt},libmysqlclient${libExt},libmysqlclient_r${libExt}} - mv "$libmysqlclient_path" "$out"/lib/libmysqlclient${libExt} - ln -sv libmysqlclient${libExt} "$out"/lib/libmysqlclient_r${libExt} - ''; - }); + postInstall = + common.postInstall + + '' + rm "$out"/bin/{mariadb-test,mysqltest} + libmysqlclient_path=$(readlink -f $out/lib/libmysqlclient${libExt}) + rm "$out"/lib/{libmariadb${libExt},libmysqlclient${libExt},libmysqlclient_r${libExt}} + mv "$libmysqlclient_path" "$out"/lib/libmysqlclient${libExt} + ln -sv libmysqlclient${libExt} "$out"/lib/libmysqlclient_r${libExt} + ''; + } + ); - server = stdenv.mkDerivation (common // { - pname = "mariadb-server"; + server = stdenv.mkDerivation ( + common + // { + pname = "mariadb-server"; - nativeBuildInputs = common.nativeBuildInputs ++ [ bison boost.dev flex ]; + nativeBuildInputs = common.nativeBuildInputs ++ [ + bison + boost.dev + flex + ]; - buildInputs = common.buildInputs ++ [ - bzip2 lz4 lzo snappy xz zstd - cracklib judy libevent libxml2 - ] ++ lib.optional withNuma numactl - ++ lib.optionals stdenv.hostPlatform.isLinux [ linux-pam ] - ++ lib.optional (!stdenv.hostPlatform.isDarwin) mytopEnv - ++ lib.optionals withStorageMroonga [ kytea libsodium msgpack zeromq ] - ++ lib.optionals (lib.versionAtLeast common.version "10.7") [ fmt_8 ]; + buildInputs = + common.buildInputs + ++ [ + bzip2 + lz4 + lzo + snappy + xz + zstd + cracklib + judy + libevent + libxml2 + ] + ++ lib.optional withNuma numactl + ++ lib.optionals stdenv.hostPlatform.isLinux [ linux-pam ] + ++ lib.optional (!stdenv.hostPlatform.isDarwin) mytopEnv + ++ lib.optionals withStorageMroonga [ + kytea + libsodium + msgpack + zeromq + ] + ++ lib.optionals (lib.versionAtLeast common.version "10.7") [ fmt_8 ]; - propagatedBuildInputs = lib.optional withNuma numactl; + propagatedBuildInputs = lib.optional withNuma numactl; - postPatch = '' - substituteInPlace scripts/galera_new_cluster.sh \ - --replace ":-mariadb" ":-mysql" - ''; + postPatch = '' + substituteInPlace scripts/galera_new_cluster.sh \ + --replace ":-mariadb" ":-mysql" + ''; - cmakeFlags = common.cmakeFlags ++ [ - "-DMYSQL_DATADIR=/var/lib/mysql" - "-DENABLED_LOCAL_INFILE=OFF" - "-DWITH_READLINE=ON" - "-DWITH_EXTRA_CHARSETS=all" - "-DWITH_EMBEDDED_SERVER=${if withEmbedded then "ON" else "OFF"}" - "-DWITH_UNIT_TESTS=OFF" - "-DWITH_WSREP=ON" - "-DWITH_INNODB_DISALLOW_WRITES=ON" - "-DWITHOUT_EXAMPLE=1" - "-DWITHOUT_FEDERATED=1" - "-DWITHOUT_TOKUDB=1" - ] ++ lib.optionals withNuma [ - "-DWITH_NUMA=ON" - ] ++ lib.optionals (!withStorageMroonga) [ - "-DWITHOUT_MROONGA=1" - ] ++ lib.optionals (!withStorageRocks) [ - "-DWITHOUT_ROCKSDB=1" - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin && withStorageRocks) [ - "-DWITH_ROCKSDB_JEMALLOC=ON" - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - "-DWITH_JEMALLOC=yes" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DPLUGIN_AUTH_PAM=NO" - "-DPLUGIN_AUTH_PAM_V1=NO" - "-DWITHOUT_OQGRAPH=1" - "-DWITHOUT_PLUGIN_S3=1" - ]; + cmakeFlags = + common.cmakeFlags + ++ [ + "-DMYSQL_DATADIR=/var/lib/mysql" + "-DENABLED_LOCAL_INFILE=OFF" + "-DWITH_READLINE=ON" + "-DWITH_EXTRA_CHARSETS=all" + "-DWITH_EMBEDDED_SERVER=${if withEmbedded then "ON" else "OFF"}" + "-DWITH_UNIT_TESTS=OFF" + "-DWITH_WSREP=ON" + "-DWITH_INNODB_DISALLOW_WRITES=ON" + "-DWITHOUT_EXAMPLE=1" + "-DWITHOUT_FEDERATED=1" + "-DWITHOUT_TOKUDB=1" + ] + ++ lib.optionals withNuma [ + "-DWITH_NUMA=ON" + ] + ++ lib.optionals (!withStorageMroonga) [ + "-DWITHOUT_MROONGA=1" + ] + ++ lib.optionals (!withStorageRocks) [ + "-DWITHOUT_ROCKSDB=1" + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin && withStorageRocks) [ + "-DWITH_ROCKSDB_JEMALLOC=ON" + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + "-DWITH_JEMALLOC=yes" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DPLUGIN_AUTH_PAM=NO" + "-DPLUGIN_AUTH_PAM_V1=NO" + "-DWITHOUT_OQGRAPH=1" + "-DWITHOUT_PLUGIN_S3=1" + ]; - preConfigure = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - patchShebangs scripts/mytop.sh - ''; + preConfigure = lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + patchShebangs scripts/mytop.sh + ''; - postInstall = common.postInstall + '' - rm -r "$out"/share/aclocal - chmod +x "$out"/bin/wsrep_sst_common - rm -f "$out"/bin/{mariadb-client-test,mariadb-test,mysql_client_test,mysqltest} - '' + lib.optionalString withStorageMroonga '' - mv "$out"/share/{groonga,groonga-normalizer-mysql} "$out"/share/doc/mysql - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin && lib.versionAtLeast common.version "10.4") '' - mv "$out"/OFF/suite/plugins/pam/pam_mariadb_mtr.so "$out"/share/pam/lib/security - mv "$out"/OFF/suite/plugins/pam/mariadb_mtr "$out"/share/pam/etc/security - rm -r "$out"/OFF - ''; + postInstall = + common.postInstall + + '' + rm -r "$out"/share/aclocal + chmod +x "$out"/bin/wsrep_sst_common + rm -f "$out"/bin/{mariadb-client-test,mariadb-test,mysql_client_test,mysqltest} + '' + + lib.optionalString withStorageMroonga '' + mv "$out"/share/{groonga,groonga-normalizer-mysql} "$out"/share/doc/mysql + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin && lib.versionAtLeast common.version "10.4") '' + mv "$out"/OFF/suite/plugins/pam/pam_mariadb_mtr.so "$out"/share/pam/lib/security + mv "$out"/OFF/suite/plugins/pam/mariadb_mtr "$out"/share/pam/etc/security + rm -r "$out"/OFF + ''; - CXXFLAGS = lib.optionalString stdenv.hostPlatform.isi686 "-fpermissive"; - }); - in - server // { + CXXFLAGS = lib.optionalString stdenv.hostPlatform.isi686 "-fpermissive"; + } + ); + in + server + // { inherit client server; }; in - self: { - # see https://mariadb.org/about/#maintenance-policy for EOLs - mariadb_105 = self.callPackage generic { - # Supported until 2025-06-24 - version = "10.5.27"; - hash = "sha256-76ZPpfczuCKrGmeV4evBecFgwIaQ7Ncduh6w9hru3RQ="; - inherit (self.darwin.apple_sdk.frameworks) CoreServices; - }; - mariadb_106 = self.callPackage generic { - # Supported until 2026-07-06 - version = "10.6.20"; - hash = "sha256-R/BavH2+uz8msx51AisbOWnbvEdSxK5wH4kgpgSJbUE="; - inherit (self.darwin.apple_sdk.frameworks) CoreServices; - }; - mariadb_1011 = self.callPackage generic { - # Supported until 2028-02-16 - version = "10.11.10"; - hash = "sha256-sGp0ZQuDoWqpqwmJhEgrAo51sABnSxH/KIdyxhmm8CI="; - inherit (self.darwin.apple_sdk.frameworks) CoreServices; - }; - mariadb_114 = self.callPackage generic { - # Supported until 2029-05-29 - version = "11.4.4"; - hash = "sha256-lvvS5uk/t+izc+6nXYW2/qV8DhEaAgkMu+/tUlmdx3s="; - inherit (self.darwin.apple_sdk.frameworks) CoreServices; - }; - } +self: { + # see https://mariadb.org/about/#maintenance-policy for EOLs + mariadb_105 = self.callPackage generic { + # Supported until 2025-06-24 + version = "10.5.27"; + hash = "sha256-76ZPpfczuCKrGmeV4evBecFgwIaQ7Ncduh6w9hru3RQ="; + inherit (self.darwin.apple_sdk.frameworks) CoreServices; + }; + mariadb_106 = self.callPackage generic { + # Supported until 2026-07-06 + version = "10.6.20"; + hash = "sha256-R/BavH2+uz8msx51AisbOWnbvEdSxK5wH4kgpgSJbUE="; + inherit (self.darwin.apple_sdk.frameworks) CoreServices; + }; + mariadb_1011 = self.callPackage generic { + # Supported until 2028-02-16 + version = "10.11.10"; + hash = "sha256-sGp0ZQuDoWqpqwmJhEgrAo51sABnSxH/KIdyxhmm8CI="; + inherit (self.darwin.apple_sdk.frameworks) CoreServices; + }; + mariadb_114 = self.callPackage generic { + # Supported until 2029-05-29 + version = "11.4.4"; + hash = "sha256-lvvS5uk/t+izc+6nXYW2/qV8DhEaAgkMu+/tUlmdx3s="; + inherit (self.darwin.apple_sdk.frameworks) CoreServices; + }; +} diff --git a/pkgs/servers/sql/mssql/jdbc/default.nix b/pkgs/servers/sql/mssql/jdbc/default.nix index 2a8be0d6ac6ec9..d822ddc7f31558 100644 --- a/pkgs/servers/sql/mssql/jdbc/default.nix +++ b/pkgs/servers/sql/mssql/jdbc/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "mssql-jdbc"; diff --git a/pkgs/servers/sql/mssql/jdbc/jtds.nix b/pkgs/servers/sql/mssql/jdbc/jtds.nix index 71561409c7582e..91b3dfd03ba27b 100644 --- a/pkgs/servers/sql/mssql/jdbc/jtds.nix +++ b/pkgs/servers/sql/mssql/jdbc/jtds.nix @@ -1,4 +1,9 @@ -{lib, stdenv, fetchurl, unzip}: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "jtds"; diff --git a/pkgs/servers/sql/mysql/8.0.x.nix b/pkgs/servers/sql/mysql/8.0.x.nix index e4427a495680c0..dedefb65da869c 100644 --- a/pkgs/servers/sql/mysql/8.0.x.nix +++ b/pkgs/servers/sql/mysql/8.0.x.nix @@ -1,6 +1,32 @@ -{ lib, stdenv, fetchurl, bison, cmake, pkg-config -, boost, icu, libedit, libevent, lz4, ncurses, openssl, protobuf, re2, readline, zlib, zstd, libfido2 -, numactl, cctools, CoreServices, developer_cmds, libtirpc, rpcsvc-proto, curl, DarwinTools, nixosTests +{ + lib, + stdenv, + fetchurl, + bison, + cmake, + pkg-config, + boost, + icu, + libedit, + libevent, + lz4, + ncurses, + openssl, + protobuf, + re2, + readline, + zlib, + zstd, + libfido2, + numactl, + cctools, + CoreServices, + developer_cmds, + libtirpc, + rpcsvc-proto, + curl, + DarwinTools, + nixosTests, }: stdenv.mkDerivation (finalAttrs: { @@ -12,8 +38,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-At/ZQ/lnQvf5zXiFWzJwjqTfVIycFK+Sc4F/O72dIrI="; }; - nativeBuildInputs = [ bison cmake pkg-config ] - ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ rpcsvc-proto ]; + nativeBuildInputs = [ + bison + cmake + pkg-config + ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ rpcsvc-proto ]; patches = [ ./no-force-outline-atomics.patch # Do not force compilers to turn on -moutline-atomics switch @@ -25,16 +54,38 @@ stdenv.mkDerivation (finalAttrs: { substituteInPlace cmake/os/Darwin.cmake --replace /usr/bin/libtool libtool ''; - buildInputs = [ - boost (curl.override { inherit openssl; }) icu libedit libevent lz4 ncurses openssl protobuf re2 readline zlib - zstd libfido2 - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - numactl libtirpc - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - cctools CoreServices developer_cmds DarwinTools - ]; + buildInputs = + [ + boost + (curl.override { inherit openssl; }) + icu + libedit + libevent + lz4 + ncurses + openssl + protobuf + re2 + readline + zlib + zstd + libfido2 + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + numactl + libtirpc + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + cctools + CoreServices + developer_cmds + DarwinTools + ]; - outputs = [ "out" "static" ]; + outputs = [ + "out" + "static" + ]; cmakeFlags = [ "-DFORCE_UNSUPPORTED_COMPILER=1" # To configure on Darwin. diff --git a/pkgs/servers/sql/postgresql/default.nix b/pkgs/servers/sql/postgresql/default.nix index 56c0158eca6d19..c964767ccf5fe4 100644 --- a/pkgs/servers/sql/postgresql/default.nix +++ b/pkgs/servers/sql/postgresql/default.nix @@ -16,14 +16,18 @@ let postgresql_17 = ./17.nix; }; - mkAttributes = jitSupport: - self.lib.mapAttrs' (version: path: + mkAttributes = + jitSupport: + self.lib.mapAttrs' ( + version: path: let attrName = if jitSupport then "${version}_jit" else version; in - self.lib.nameValuePair attrName (import path { - inherit jitSupport self; - }) + self.lib.nameValuePair attrName ( + import path { + inherit jitSupport self; + } + ) ) versions; in diff --git a/pkgs/servers/sql/postgresql/ext/age.nix b/pkgs/servers/sql/postgresql/ext/age.nix index 4811ec01ccb535..ca052c4c7ff784 100644 --- a/pkgs/servers/sql/postgresql/ext/age.nix +++ b/pkgs/servers/sql/postgresql/ext/age.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, bison, fetchFromGitHub, flex, perl, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + bison, + fetchFromGitHub, + flex, + perl, + postgresql, + buildPostgresqlExtension, +}: let hashes = { @@ -18,8 +27,12 @@ buildPostgresqlExtension rec { src = fetchFromGitHub { owner = "apache"; repo = "age"; - rev = "PG${lib.versions.major postgresql.version}/v${builtins.replaceStrings ["."] ["_"] version}"; - hash = hashes.${lib.versions.major postgresql.version} or (throw "Source for Age is not available for ${postgresql.version}"); + rev = "PG${lib.versions.major postgresql.version}/v${ + builtins.replaceStrings [ "." ] [ "_" ] version + }"; + hash = + hashes.${lib.versions.major postgresql.version} + or (throw "Source for Age is not available for ${postgresql.version}"); }; makeFlags = [ @@ -36,22 +49,24 @@ buildPostgresqlExtension rec { dontConfigure = true; - buildPhase = let - postgresqlAge = postgresql.withPackages (ps: [ ps.age ]); - in '' - # The regression tests need to be run in the order specified in the Makefile. - echo -e "include Makefile\nfiles:\n\t@echo \$(REGRESS)" > Makefile.regress - REGRESS_TESTS=$(make -f Makefile.regress files) + buildPhase = + let + postgresqlAge = postgresql.withPackages (ps: [ ps.age ]); + in + '' + # The regression tests need to be run in the order specified in the Makefile. + echo -e "include Makefile\nfiles:\n\t@echo \$(REGRESS)" > Makefile.regress + REGRESS_TESTS=$(make -f Makefile.regress files) - ${lib.getDev postgresql}/lib/pgxs/src/test/regress/pg_regress \ - --inputdir=./ \ - --bindir='${postgresqlAge}/bin' \ - --encoding=UTF-8 \ - --load-extension=age \ - --inputdir=./regress --outputdir=./regress --temp-instance=./regress/instance \ - --port=61958 --dbname=contrib_regression \ - $REGRESS_TESTS - ''; + ${lib.getDev postgresql}/lib/pgxs/src/test/regress/pg_regress \ + --inputdir=./ \ + --bindir='${postgresqlAge}/bin' \ + --encoding=UTF-8 \ + --load-extension=age \ + --inputdir=./regress --outputdir=./regress --temp-instance=./regress/instance \ + --port=61958 --dbname=contrib_regression \ + $REGRESS_TESTS + ''; installPhase = '' touch $out diff --git a/pkgs/servers/sql/postgresql/ext/anonymizer.nix b/pkgs/servers/sql/postgresql/ext/anonymizer.nix index 66de2544eae678..6b6b11cd82ced7 100644 --- a/pkgs/servers/sql/postgresql/ext/anonymizer.nix +++ b/pkgs/servers/sql/postgresql/ext/anonymizer.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, pg-dump-anon, postgresql, runtimeShell, jitSupport, llvm, buildPostgresqlExtension, nixosTests }: +{ + lib, + stdenv, + pg-dump-anon, + postgresql, + runtimeShell, + jitSupport, + llvm, + buildPostgresqlExtension, + nixosTests, +}: buildPostgresqlExtension (finalAttrs: { pname = "postgresql_anonymizer"; diff --git a/pkgs/servers/sql/postgresql/ext/apache_datasketches.nix b/pkgs/servers/sql/postgresql/ext/apache_datasketches.nix index 46b5fac3852b42..b93695b932d558 100644 --- a/pkgs/servers/sql/postgresql/ext/apache_datasketches.nix +++ b/pkgs/servers/sql/postgresql/ext/apache_datasketches.nix @@ -1,22 +1,30 @@ -{ stdenv, lib, fetchFromGitHub, postgresql, boost182, postgresqlTestExtension, buildPostgresqlExtension }: +{ + stdenv, + lib, + fetchFromGitHub, + postgresql, + boost182, + postgresqlTestExtension, + buildPostgresqlExtension, +}: let version = "1.7.0"; main_src = fetchFromGitHub { - name = "datasketches-postgresql"; - owner = "apache"; - repo = "datasketches-postgresql"; - rev = "refs/tags/${version}"; - hash = "sha256-W41uAs3W4V7c9O/wBw3rut65bcmY8EdQS1/tPszMGqA="; + name = "datasketches-postgresql"; + owner = "apache"; + repo = "datasketches-postgresql"; + rev = "refs/tags/${version}"; + hash = "sha256-W41uAs3W4V7c9O/wBw3rut65bcmY8EdQS1/tPszMGqA="; }; cpp_src = fetchFromGitHub { - name = "datasketches-cpp"; - owner = "apache"; - repo = "datasketches-cpp"; - rev = "refs/tags/5.0.2"; - hash = "sha256-yGk1OckYipAgLTQK6w6p6EdHMxBIQSjPV/MMND3cDks="; + name = "datasketches-cpp"; + owner = "apache"; + repo = "datasketches-cpp"; + rev = "refs/tags/5.0.2"; + hash = "sha256-yGk1OckYipAgLTQK6w6p6EdHMxBIQSjPV/MMND3cDks="; }; in @@ -24,7 +32,10 @@ buildPostgresqlExtension (finalAttrs: { pname = "apache_datasketches"; inherit version; - srcs = [ main_src cpp_src ]; + srcs = [ + main_src + cpp_src + ]; sourceRoot = main_src.name; @@ -48,9 +59,9 @@ buildPostgresqlExtension (finalAttrs: { meta = { description = "PostgreSQL extension providing approximate algorithms for distinct item counts, quantile estimation and frequent items detection"; longDescription = '' - apache_datasketches is an extension to support approximate algorithms on PostgreSQL. The implementation - is based on the Apache Datasketches CPP library, and provides support for HyperLogLog, - Compressed Probabilistic Counting, KLL, Frequent strings, and Theta sketches. + apache_datasketches is an extension to support approximate algorithms on PostgreSQL. The implementation + is based on the Apache Datasketches CPP library, and provides support for HyperLogLog, + Compressed Probabilistic Counting, KLL, Frequent strings, and Theta sketches. ''; homepage = "https://datasketches.apache.org/"; platforms = postgresql.meta.platforms; diff --git a/pkgs/servers/sql/postgresql/ext/citus.nix b/pkgs/servers/sql/postgresql/ext/citus.nix index 8e46d4addfb476..ec5aa5f90fcf69 100644 --- a/pkgs/servers/sql/postgresql/ext/citus.nix +++ b/pkgs/servers/sql/postgresql/ext/citus.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, curl -, fetchFromGitHub -, lz4 -, postgresql -, buildPostgresqlExtension +{ + lib, + stdenv, + curl, + fetchFromGitHub, + lz4, + postgresql, + buildPostgresqlExtension, }: buildPostgresqlExtension rec { @@ -27,10 +28,12 @@ buildPostgresqlExtension rec { # "Our soft policy for Postgres version compatibility is to support Citus' # latest release with Postgres' 3 latest releases." # https://www.citusdata.com/updates/v12-0/#deprecated_features - broken = versionOlder postgresql.version "14" || - # PostgreSQL 17 support issue upstream: https://github.com/citusdata/citus/issues/7708 - # Check after next package update. - (versionAtLeast postgresql.version "17" && version == "12.1.6"); + broken = + versionOlder postgresql.version "14" + || + # PostgreSQL 17 support issue upstream: https://github.com/citusdata/citus/issues/7708 + # Check after next package update. + (versionAtLeast postgresql.version "17" && version == "12.1.6"); description = "Distributed PostgreSQL as an extension"; homepage = "https://www.citusdata.com/"; changelog = "https://github.com/citusdata/citus/blob/${src.rev}/CHANGELOG.md"; diff --git a/pkgs/servers/sql/postgresql/ext/cstore_fdw.nix b/pkgs/servers/sql/postgresql/ext/cstore_fdw.nix index 4b5499bfe9fa08..232eec17e0ab92 100644 --- a/pkgs/servers/sql/postgresql/ext/cstore_fdw.nix +++ b/pkgs/servers/sql/postgresql/ext/cstore_fdw.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, protobufc, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + protobufc, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "cstore_fdw"; @@ -7,18 +14,18 @@ buildPostgresqlExtension rec { nativeBuildInputs = [ protobufc ]; src = fetchFromGitHub { - owner = "citusdata"; - repo = "cstore_fdw"; - rev = "90e22b62fbee6852529104fdd463f532cf7a3311"; + owner = "citusdata"; + repo = "cstore_fdw"; + rev = "90e22b62fbee6852529104fdd463f532cf7a3311"; sha256 = "sha256-02wcCqs8A5ZOZX080fgcNJTQrYQctnlwnA8+YPaRTZc="; }; meta = with lib; { - broken = versionAtLeast postgresql.version "14"; + broken = versionAtLeast postgresql.version "14"; description = "Columnar storage for PostgreSQL"; - homepage = "https://github.com/citusdata/cstore_fdw"; + homepage = "https://github.com/citusdata/cstore_fdw"; maintainers = with maintainers; [ thoughtpolice ]; - platforms = postgresql.meta.platforms; - license = licenses.asl20; + platforms = postgresql.meta.platforms; + license = licenses.asl20; }; } diff --git a/pkgs/servers/sql/postgresql/ext/h3-pg.nix b/pkgs/servers/sql/postgresql/ext/h3-pg.nix index 3893ea310d8eb1..67a1b33c968a16 100644 --- a/pkgs/servers/sql/postgresql/ext/h3-pg.nix +++ b/pkgs/servers/sql/postgresql/ext/h3-pg.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, h3_4 -, postgresql -, postgresqlTestExtension -, buildPostgresqlExtension +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + h3_4, + postgresql, + postgresqlTestExtension, + buildPostgresqlExtension, }: buildPostgresqlExtension (finalAttrs: { @@ -19,16 +20,18 @@ buildPostgresqlExtension (finalAttrs: { hash = "sha256-uZ4XI/VXRr636CI1r24D6ykPQqO5qZNxNQLUQKmoPtg="; }; - postPatch = '' - substituteInPlace CMakeLists.txt \ - --replace-fail "add_subdirectory(cmake/h3)" "include_directories(${lib.getDev h3_4}/include/h3)" - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace cmake/AddPostgreSQLExtension.cmake \ - --replace-fail "INTERPROCEDURAL_OPTIMIZATION TRUE" "" - # Commented upstream: https://github.com/zachasme/h3-pg/pull/141/files#r1844970927 - substituteInPlace cmake/FindPostgreSQL.cmake \ - --replace-fail 'list(APPEND PostgreSQL_INCLUDE_DIRS "/usr/local/include")' "" - ''; + postPatch = + '' + substituteInPlace CMakeLists.txt \ + --replace-fail "add_subdirectory(cmake/h3)" "include_directories(${lib.getDev h3_4}/include/h3)" + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace cmake/AddPostgreSQLExtension.cmake \ + --replace-fail "INTERPROCEDURAL_OPTIMIZATION TRUE" "" + # Commented upstream: https://github.com/zachasme/h3-pg/pull/141/files#r1844970927 + substituteInPlace cmake/FindPostgreSQL.cmake \ + --replace-fail 'list(APPEND PostgreSQL_INCLUDE_DIRS "/usr/local/include")' "" + ''; nativeBuildInputs = [ cmake diff --git a/pkgs/servers/sql/postgresql/ext/hypopg.nix b/pkgs/servers/sql/postgresql/ext/hypopg.nix index 3bc868a79f49a7..f85a743d9fca20 100644 --- a/pkgs/servers/sql/postgresql/ext/hypopg.nix +++ b/pkgs/servers/sql/postgresql/ext/hypopg.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, gitUpdater, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + gitUpdater, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "hypopg"; diff --git a/pkgs/servers/sql/postgresql/ext/jsonb_deep_sum.nix b/pkgs/servers/sql/postgresql/ext/jsonb_deep_sum.nix index 7fe4f22254f31a..dbff8f7e8eb803 100644 --- a/pkgs/servers/sql/postgresql/ext/jsonb_deep_sum.nix +++ b/pkgs/servers/sql/postgresql/ext/jsonb_deep_sum.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "jsonb_deep_sum"; diff --git a/pkgs/servers/sql/postgresql/ext/lantern.nix b/pkgs/servers/sql/postgresql/ext/lantern.nix index 23c7415f3f1538..75f653607e4e07 100644 --- a/pkgs/servers/sql/postgresql/ext/lantern.nix +++ b/pkgs/servers/sql/postgresql/ext/lantern.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, openssl -, postgresql -, postgresqlTestExtension -, buildPostgresqlExtension +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + openssl, + postgresql, + postgresqlTestExtension, + buildPostgresqlExtension, }: buildPostgresqlExtension (finalAttrs: { @@ -22,7 +23,7 @@ buildPostgresqlExtension (finalAttrs: { postPatch = '' patchShebangs --build lantern_hnsw/scripts/link_llvm_objects.sh - ''; + ''; nativeBuildInputs = [ cmake @@ -58,6 +59,7 @@ buildPostgresqlExtension (finalAttrs: { maintainers = [ ]; platforms = postgresql.meta.platforms; # error: use of undeclared identifier 'aligned_alloc' - broken = stdenv.hostPlatform.isDarwin && lib.versionOlder stdenv.hostPlatform.darwinMinVersion "10.13"; + broken = + stdenv.hostPlatform.isDarwin && lib.versionOlder stdenv.hostPlatform.darwinMinVersion "10.13"; }; }) diff --git a/pkgs/servers/sql/postgresql/ext/periods.nix b/pkgs/servers/sql/postgresql/ext/periods.nix index cc751a49d3c0d0..343482d26c7bd6 100644 --- a/pkgs/servers/sql/postgresql/ext/periods.nix +++ b/pkgs/servers/sql/postgresql/ext/periods.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "periods"; diff --git a/pkgs/servers/sql/postgresql/ext/pg_auto_failover.nix b/pkgs/servers/sql/postgresql/ext/pg_auto_failover.nix index 45b8f9562bf238..0d43faa7fe2ecb 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_auto_failover.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_auto_failover.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pg_auto_failover"; diff --git a/pkgs/servers/sql/postgresql/ext/pg_bigm.nix b/pkgs/servers/sql/postgresql/ext/pg_bigm.nix index 58dba27e960194..bf05673a549346 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_bigm.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_bigm.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pg_bigm"; diff --git a/pkgs/servers/sql/postgresql/ext/pg_cron.nix b/pkgs/servers/sql/postgresql/ext/pg_cron.nix index 2fef4b7c22c397..4803f0a7b76104 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_cron.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_cron.nix @@ -1,22 +1,28 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pg_cron"; version = "1.6.4"; src = fetchFromGitHub { - owner = "citusdata"; - repo = pname; - rev = "v${version}"; - hash = "sha256-t1DpFkPiSfdoGG2NgNT7g1lkvSooZoRoUrix6cBID40="; + owner = "citusdata"; + repo = pname; + rev = "v${version}"; + hash = "sha256-t1DpFkPiSfdoGG2NgNT7g1lkvSooZoRoUrix6cBID40="; }; meta = with lib; { description = "Run Cron jobs through PostgreSQL"; - homepage = "https://github.com/citusdata/pg_cron"; - changelog = "https://github.com/citusdata/pg_cron/releases/tag/v${version}"; + homepage = "https://github.com/citusdata/pg_cron"; + changelog = "https://github.com/citusdata/pg_cron/releases/tag/v${version}"; maintainers = with maintainers; [ thoughtpolice ]; - platforms = postgresql.meta.platforms; - license = licenses.postgresql; + platforms = postgresql.meta.platforms; + license = licenses.postgresql; }; } diff --git a/pkgs/servers/sql/postgresql/ext/pg_ed25519.nix b/pkgs/servers/sql/postgresql/ext/pg_ed25519.nix index c815a02229e81f..fc64df1db49944 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_ed25519.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_ed25519.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitLab, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitLab, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pg_ed25519"; @@ -20,4 +26,3 @@ buildPostgresqlExtension rec { broken = lib.versionAtLeast postgresql.version "16" && stdenv.cc.isClang; }; } - diff --git a/pkgs/servers/sql/postgresql/ext/pg_hint_plan.nix b/pkgs/servers/sql/postgresql/ext/pg_hint_plan.nix index 5adf5486113f96..20d31530164e05 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_hint_plan.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_hint_plan.nix @@ -1,32 +1,41 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: let - source = { - "17" = { - version = "1.7.0"; - hash = "sha256-MNQMePDmGxC8OFIJuVJrhfgU566vkng00+tjeGpGKvs="; - }; - "16" = { - version = "1.6.0"; - hash = "sha256-lg7N0QblluTgtNo1tGZjirNJSyQXtcAEs9Jqd3zx0Sg="; - }; - "15" = { - version = "1.5.1"; - hash = "sha256-o8Hepf/Mc1ClRTLZ6PBdqU4jSdlz+ijVgl2vJKmIc6M="; - }; - "14" = { - version = "1.4.2"; - hash = "sha256-nGyKcNY57RdQdZKSaBPk2/YbT0Annz1ZevH0lKswdhA="; - }; - "13" = { - version = "1.3.9"; - hash = "sha256-KGcHDwk8CgNHPZARfLBfS8r7TRCP9LPjT+m4fNSnnW0="; - }; - "12" = { - version = "1.3.9"; - hash = "sha256-64/dlm6e4flCxMQ8efsxfKSlja+Tko0zsghTgLatN+Y="; - }; - }.${lib.versions.major postgresql.version} or (throw "Source for pg_hint_plan is not available for ${postgresql.version}"); + source = + { + "17" = { + version = "1.7.0"; + hash = "sha256-MNQMePDmGxC8OFIJuVJrhfgU566vkng00+tjeGpGKvs="; + }; + "16" = { + version = "1.6.0"; + hash = "sha256-lg7N0QblluTgtNo1tGZjirNJSyQXtcAEs9Jqd3zx0Sg="; + }; + "15" = { + version = "1.5.1"; + hash = "sha256-o8Hepf/Mc1ClRTLZ6PBdqU4jSdlz+ijVgl2vJKmIc6M="; + }; + "14" = { + version = "1.4.2"; + hash = "sha256-nGyKcNY57RdQdZKSaBPk2/YbT0Annz1ZevH0lKswdhA="; + }; + "13" = { + version = "1.3.9"; + hash = "sha256-KGcHDwk8CgNHPZARfLBfS8r7TRCP9LPjT+m4fNSnnW0="; + }; + "12" = { + version = "1.3.9"; + hash = "sha256-64/dlm6e4flCxMQ8efsxfKSlja+Tko0zsghTgLatN+Y="; + }; + } + .${lib.versions.major postgresql.version} + or (throw "Source for pg_hint_plan is not available for ${postgresql.version}"); in buildPostgresqlExtension { pname = "pg_hint_plan"; @@ -35,7 +44,9 @@ buildPostgresqlExtension { src = fetchFromGitHub { owner = "ossc-db"; repo = "pg_hint_plan"; - rev = "REL${lib.versions.major postgresql.version}_${builtins.replaceStrings ["."] ["_"] source.version}"; + rev = "REL${lib.versions.major postgresql.version}_${ + builtins.replaceStrings [ "." ] [ "_" ] source.version + }"; inherit (source) hash; }; diff --git a/pkgs/servers/sql/postgresql/ext/pg_hll.nix b/pkgs/servers/sql/postgresql/ext/pg_hll.nix index 4a754bf81a9fe5..709424365e7cdf 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_hll.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_hll.nix @@ -1,22 +1,28 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pg_hll"; version = "2.18"; src = fetchFromGitHub { - owner = "citusdata"; - repo = "postgresql-hll"; - rev = "refs/tags/v${version}"; - hash = "sha256-Latdxph1Ura8yKEokEjalJ+/GY+pAKOT3GXjuLprj6c="; + owner = "citusdata"; + repo = "postgresql-hll"; + rev = "refs/tags/v${version}"; + hash = "sha256-Latdxph1Ura8yKEokEjalJ+/GY+pAKOT3GXjuLprj6c="; }; meta = with lib; { description = "HyperLogLog for PostgreSQL"; - homepage = "https://github.com/citusdata/postgresql-hll"; - changelog = "https://github.com/citusdata/postgresql-hll/blob/v${version}/CHANGELOG.md"; + homepage = "https://github.com/citusdata/postgresql-hll"; + changelog = "https://github.com/citusdata/postgresql-hll/blob/v${version}/CHANGELOG.md"; maintainers = with maintainers; [ thoughtpolice ]; - platforms = postgresql.meta.platforms; - license = licenses.asl20; + platforms = postgresql.meta.platforms; + license = licenses.asl20; }; } diff --git a/pkgs/servers/sql/postgresql/ext/pg_ivm.nix b/pkgs/servers/sql/postgresql/ext/pg_ivm.nix index 3abf23077bb2d6..675eab8fee5c1c 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_ivm.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_ivm.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pg_ivm"; diff --git a/pkgs/servers/sql/postgresql/ext/pg_libversion.nix b/pkgs/servers/sql/postgresql/ext/pg_libversion.nix index 174a8ffc8993ae..2360944e555d60 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_libversion.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_libversion.nix @@ -1,11 +1,12 @@ - { lib -, stdenv -, fetchFromGitHub -, gitUpdater -, pkg-config -, postgresql -, libversion -, buildPostgresqlExtension +{ + lib, + stdenv, + fetchFromGitHub, + gitUpdater, + pkg-config, + postgresql, + libversion, + buildPostgresqlExtension, }: buildPostgresqlExtension (finalAttrs: { @@ -37,4 +38,3 @@ buildPostgresqlExtension (finalAttrs: { platforms = postgresql.meta.platforms; }; }) - diff --git a/pkgs/servers/sql/postgresql/ext/pg_net.nix b/pkgs/servers/sql/postgresql/ext/pg_net.nix index be7a6da5d633a7..efe4c6c765bc61 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_net.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_net.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, curl, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + curl, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pg_net"; @@ -7,20 +14,20 @@ buildPostgresqlExtension rec { buildInputs = [ curl ]; src = fetchFromGitHub { - owner = "supabase"; - repo = pname; - rev = "refs/tags/v${version}"; - hash = "sha256-FRaTZPCJQPYAFmsJg22hYJJ0+gH1tMdDQoCQgiqEnaA="; + owner = "supabase"; + repo = pname; + rev = "refs/tags/v${version}"; + hash = "sha256-FRaTZPCJQPYAFmsJg22hYJJ0+gH1tMdDQoCQgiqEnaA="; }; env.NIX_CFLAGS_COMPILE = "-Wno-error"; meta = with lib; { description = "Async networking for Postgres"; - homepage = "https://github.com/supabase/pg_net"; - changelog = "https://github.com/supabase/pg_net/releases/tag/v${version}"; + homepage = "https://github.com/supabase/pg_net"; + changelog = "https://github.com/supabase/pg_net/releases/tag/v${version}"; maintainers = with maintainers; [ thoughtpolice ]; - platforms = postgresql.meta.platforms; - license = licenses.postgresql; + platforms = postgresql.meta.platforms; + license = licenses.postgresql; }; } diff --git a/pkgs/servers/sql/postgresql/ext/pg_partman.nix b/pkgs/servers/sql/postgresql/ext/pg_partman.nix index 765599e00f1d4c..6e326538fe5a06 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_partman.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_partman.nix @@ -1,23 +1,29 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pg_partman"; version = "5.2.1"; src = fetchFromGitHub { - owner = "pgpartman"; - repo = pname; - rev = "refs/tags/v${version}"; + owner = "pgpartman"; + repo = pname; + rev = "refs/tags/v${version}"; sha256 = "sha256-DdF1UwfeAM4tlcvdXaiz28JA2UwNwPpXnSw5D9eZDlQ="; }; meta = with lib; { description = "Partition management extension for PostgreSQL"; - homepage = "https://github.com/pgpartman/pg_partman"; - changelog = "https://github.com/pgpartman/pg_partman/blob/v${version}/CHANGELOG.md"; + homepage = "https://github.com/pgpartman/pg_partman"; + changelog = "https://github.com/pgpartman/pg_partman/blob/v${version}/CHANGELOG.md"; maintainers = with maintainers; [ ggpeti ]; - platforms = postgresql.meta.platforms; - license = licenses.postgresql; - broken = versionOlder postgresql.version "14"; + platforms = postgresql.meta.platforms; + license = licenses.postgresql; + broken = versionOlder postgresql.version "14"; }; } diff --git a/pkgs/servers/sql/postgresql/ext/pg_rational.nix b/pkgs/servers/sql/postgresql/ext/pg_rational.nix index 084c51e7846e0d..d2131b9f8c7860 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_rational.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_rational.nix @@ -1,8 +1,9 @@ -{ stdenv -, fetchFromGitHub -, lib -, postgresql -, buildPostgresqlExtension +{ + stdenv, + fetchFromGitHub, + lib, + postgresql, + buildPostgresqlExtension, }: buildPostgresqlExtension rec { @@ -10,17 +11,17 @@ buildPostgresqlExtension rec { version = "0.0.2"; src = fetchFromGitHub { - owner = "begriffs"; - repo = "pg_rational"; - rev = "v${version}"; + owner = "begriffs"; + repo = "pg_rational"; + rev = "v${version}"; sha256 = "sha256-Sp5wuX2nP3KGyWw7MFa11rI1CPIKIWBt8nvBSsASIEw="; }; meta = with lib; { description = "Precise fractional arithmetic for PostgreSQL"; - homepage = "https://github.com/begriffs/pg_rational"; + homepage = "https://github.com/begriffs/pg_rational"; maintainers = with maintainers; [ netcrns ]; - platforms = postgresql.meta.platforms; - license = licenses.mit; + platforms = postgresql.meta.platforms; + license = licenses.mit; }; } diff --git a/pkgs/servers/sql/postgresql/ext/pg_relusage.nix b/pkgs/servers/sql/postgresql/ext/pg_relusage.nix index 1dc879275ca765..4379dc1ffdc91c 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_relusage.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_relusage.nix @@ -1,21 +1,27 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pg_relusage"; version = "0.0.1"; src = fetchFromGitHub { - owner = "adept"; - repo = pname; - rev = "refs/tags/${version}"; + owner = "adept"; + repo = pname; + rev = "refs/tags/${version}"; sha256 = "8hJNjQ9MaBk3J9a73l+yQMwMW/F2N8vr5PO2o+5GvYs="; }; meta = with lib; { description = "pg_relusage extension for PostgreSQL: discover and log the relations used in your statements"; - homepage = "https://github.com/adept/pg_relusage"; + homepage = "https://github.com/adept/pg_relusage"; maintainers = with maintainers; [ thenonameguy ]; - platforms = postgresql.meta.platforms; - license = licenses.postgresql; + platforms = postgresql.meta.platforms; + license = licenses.postgresql; }; } diff --git a/pkgs/servers/sql/postgresql/ext/pg_repack.nix b/pkgs/servers/sql/postgresql/ext/pg_repack.nix index 7c70294de13071..c7d0ab33f69de8 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_repack.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_repack.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, postgresql -, postgresqlTestExtension -, testers -, buildPostgresqlExtension +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + postgresqlTestExtension, + testers, + buildPostgresqlExtension, }: buildPostgresqlExtension (finalAttrs: { diff --git a/pkgs/servers/sql/postgresql/ext/pg_roaringbitmap.nix b/pkgs/servers/sql/postgresql/ext/pg_roaringbitmap.nix index 644548f4ed9873..eeade122d1e160 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_roaringbitmap.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_roaringbitmap.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, postgresqlTestHook, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + postgresqlTestHook, + buildPostgresqlExtension, +}: buildPostgresqlExtension (finalAttrs: { pname = "pg_roaringbitmap"; diff --git a/pkgs/servers/sql/postgresql/ext/pg_safeupdate.nix b/pkgs/servers/sql/postgresql/ext/pg_safeupdate.nix index 14d4db41592321..17ffa9a6720349 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_safeupdate.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_safeupdate.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: with { "12" = { @@ -25,25 +31,27 @@ with { version = "1.5"; sha256 = "sha256-RRSpkWLFuif+6RCncnsb1NnjKnIIRY9KgebKkjCN5cs="; }; -}."${lib.versions.major postgresql.version}" or (throw "pg_safeupdate: version specification for pg ${postgresql.version} missing."); +} +."${lib.versions.major postgresql.version}" + or (throw "pg_safeupdate: version specification for pg ${postgresql.version} missing."); buildPostgresqlExtension rec { pname = "pg-safeupdate"; inherit version; src = fetchFromGitHub { - owner = "eradman"; - repo = pname; - rev = version; + owner = "eradman"; + repo = pname; + rev = version; inherit sha256; }; meta = with lib; { description = "Simple extension to PostgreSQL that requires criteria for UPDATE and DELETE"; - homepage = "https://github.com/eradman/pg-safeupdate"; - changelog = "https://github.com/eradman/pg-safeupdate/raw/${src.rev}/NEWS"; - platforms = postgresql.meta.platforms; + homepage = "https://github.com/eradman/pg-safeupdate"; + changelog = "https://github.com/eradman/pg-safeupdate/raw/${src.rev}/NEWS"; + platforms = postgresql.meta.platforms; maintainers = with maintainers; [ wolfgangwalther ]; - license = licenses.postgresql; + license = licenses.postgresql; }; } diff --git a/pkgs/servers/sql/postgresql/ext/pg_similarity.nix b/pkgs/servers/sql/postgresql/ext/pg_similarity.nix index 19441807b51555..41b663864ba297 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_similarity.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_similarity.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitHub, fetchpatch, postgresql, buildPostgresqlExtension }: +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension { pname = "pg_similarity"; @@ -26,9 +33,9 @@ buildPostgresqlExtension { meta = { description = "Extension to support similarity queries on PostgreSQL"; longDescription = '' - pg_similarity is an extension to support similarity queries on PostgreSQL. The implementation - is tightly integrated in the RDBMS in the sense that it defines operators so instead of the traditional - operators (= and <>) you can use ~~~ and ~!~ (any of these operators represents a similarity function). + pg_similarity is an extension to support similarity queries on PostgreSQL. The implementation + is tightly integrated in the RDBMS in the sense that it defines operators so instead of the traditional + operators (= and <>) you can use ~~~ and ~!~ (any of these operators represents a similarity function). ''; platforms = postgresql.meta.platforms; license = lib.licenses.bsd3; diff --git a/pkgs/servers/sql/postgresql/ext/pg_squeeze.nix b/pkgs/servers/sql/postgresql/ext/pg_squeeze.nix index fa4225f3389d9d..13bbd7a330b7de 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_squeeze.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_squeeze.nix @@ -1,8 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, postgresqlTestExtension, buildPostgresqlExtension, nix-update-script }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + postgresqlTestExtension, + buildPostgresqlExtension, + nix-update-script, +}: buildPostgresqlExtension (finalAttrs: { pname = "pg_squeeze"; - version = "${builtins.replaceStrings ["_"] ["."] (lib.strings.removePrefix "REL" finalAttrs.src.rev)}"; + version = "${builtins.replaceStrings [ "_" ] [ "." ] ( + lib.strings.removePrefix "REL" finalAttrs.src.rev + )}"; src = fetchFromGitHub { owner = "cybertec-postgresql"; diff --git a/pkgs/servers/sql/postgresql/ext/pg_topn.nix b/pkgs/servers/sql/postgresql/ext/pg_topn.nix index 8c6aa60be32aad..3271c6ac7a6851 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_topn.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_topn.nix @@ -1,22 +1,28 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pg_topn"; version = "2.7.0"; src = fetchFromGitHub { - owner = "citusdata"; - repo = "postgresql-topn"; - rev = "refs/tags/v${version}"; + owner = "citusdata"; + repo = "postgresql-topn"; + rev = "refs/tags/v${version}"; sha256 = "sha256-lP6Iil/BUv4ga+co+oBpKv1FBqFuBGfNjueEolM6png="; }; meta = with lib; { description = "Efficient querying of 'top values' for PostgreSQL"; - homepage = "https://github.com/citusdata/postgresql-topn"; - changelog = "https://github.com/citusdata/postgresql-topn/raw/v${version}/CHANGELOG.md"; + homepage = "https://github.com/citusdata/postgresql-topn"; + changelog = "https://github.com/citusdata/postgresql-topn/raw/v${version}/CHANGELOG.md"; maintainers = with maintainers; [ thoughtpolice ]; - platforms = postgresql.meta.platforms; - license = licenses.agpl3Only; + platforms = postgresql.meta.platforms; + license = licenses.agpl3Only; }; } diff --git a/pkgs/servers/sql/postgresql/ext/pg_uuidv7.nix b/pkgs/servers/sql/postgresql/ext/pg_uuidv7.nix index 7418b833716d03..a11332dd6192d0 100644 --- a/pkgs/servers/sql/postgresql/ext/pg_uuidv7.nix +++ b/pkgs/servers/sql/postgresql/ext/pg_uuidv7.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, postgresql -, buildPostgresqlExtension +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, }: buildPostgresqlExtension rec { diff --git a/pkgs/servers/sql/postgresql/ext/pgaudit.nix b/pkgs/servers/sql/postgresql/ext/pgaudit.nix index 91c081eaf95509..13e5ad29ff4a0d 100644 --- a/pkgs/servers/sql/postgresql/ext/pgaudit.nix +++ b/pkgs/servers/sql/postgresql/ext/pgaudit.nix @@ -1,32 +1,43 @@ -{ lib, stdenv, fetchFromGitHub, libkrb5, openssl, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + libkrb5, + openssl, + postgresql, + buildPostgresqlExtension, +}: let - source = { - "17" = { - version = "17.0"; - hash = "sha256-3ksq09wiudQPuBQI3dhEQi8IkXKLVIsPFgBnwLiicro="; - }; - "16" = { - version = "16.0"; - hash = "sha256-8+tGOl1U5y9Zgu+9O5UDDE4bec4B0JC/BQ6GLhHzQzc="; - }; - "15" = { - version = "1.7.0"; - hash = "sha256-8pShPr4HJaJQPjW1iPJIpj3CutTx8Tgr+rOqoXtgCcw="; - }; - "14" = { - version = "1.6.2"; - hash = "sha256-Bl7Jk2B0deZUDiI391vk4nilwuVGHd1wuaQRSCoA3Mk="; - }; - "13" = { - version = "1.5.2"; - hash = "sha256-fyf2Ym0fAAXjc28iFCGDEftPAyDLXmEgi/0DaTJJiIg="; - }; - "12" = { - version = "1.4.3"; - hash = "sha256-c8/xUFIHalu2bMCs57DeylK0oW0VnQwmUCpdp+tYqk4="; - }; - }.${lib.versions.major postgresql.version} or (throw "Source for pgaudit is not available for ${postgresql.version}"); + source = + { + "17" = { + version = "17.0"; + hash = "sha256-3ksq09wiudQPuBQI3dhEQi8IkXKLVIsPFgBnwLiicro="; + }; + "16" = { + version = "16.0"; + hash = "sha256-8+tGOl1U5y9Zgu+9O5UDDE4bec4B0JC/BQ6GLhHzQzc="; + }; + "15" = { + version = "1.7.0"; + hash = "sha256-8pShPr4HJaJQPjW1iPJIpj3CutTx8Tgr+rOqoXtgCcw="; + }; + "14" = { + version = "1.6.2"; + hash = "sha256-Bl7Jk2B0deZUDiI391vk4nilwuVGHd1wuaQRSCoA3Mk="; + }; + "13" = { + version = "1.5.2"; + hash = "sha256-fyf2Ym0fAAXjc28iFCGDEftPAyDLXmEgi/0DaTJJiIg="; + }; + "12" = { + version = "1.4.3"; + hash = "sha256-c8/xUFIHalu2bMCs57DeylK0oW0VnQwmUCpdp+tYqk4="; + }; + } + .${lib.versions.major postgresql.version} + or (throw "Source for pgaudit is not available for ${postgresql.version}"); in buildPostgresqlExtension { pname = "pgaudit"; @@ -39,7 +50,10 @@ buildPostgresqlExtension { hash = source.hash; }; - buildInputs = [ libkrb5 openssl ]; + buildInputs = [ + libkrb5 + openssl + ]; makeFlags = [ "USE_PGXS=1" ]; diff --git a/pkgs/servers/sql/postgresql/ext/pgjwt.nix b/pkgs/servers/sql/postgresql/ext/pgjwt.nix index b0a75a44fcfc81..9b3afd821dbd9b 100644 --- a/pkgs/servers/sql/postgresql/ext/pgjwt.nix +++ b/pkgs/servers/sql/postgresql/ext/pgjwt.nix @@ -1,13 +1,22 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, unstableGitUpdater, nixosTests, postgresqlTestExtension, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + unstableGitUpdater, + nixosTests, + postgresqlTestExtension, + buildPostgresqlExtension, +}: buildPostgresqlExtension (finalAttrs: { pname = "pgjwt"; version = "0-unstable-2023-03-02"; src = fetchFromGitHub { - owner = "michelp"; - repo = "pgjwt"; - rev = "f3d82fd30151e754e19ce5d6a06c71c20689ce3d"; + owner = "michelp"; + repo = "pgjwt"; + rev = "f3d82fd30151e754e19ce5d6a06c71c20689ce3d"; sha256 = "sha256-nDZEDf5+sFc1HDcG2eBNQj+kGcdAYRXJseKi9oww+JU="; }; @@ -32,6 +41,6 @@ buildPostgresqlExtension (finalAttrs: { ''; license = licenses.mit; platforms = postgresql.meta.platforms; - maintainers = with maintainers; [spinus]; + maintainers = with maintainers; [ spinus ]; }; }) diff --git a/pkgs/servers/sql/postgresql/ext/pgroonga.nix b/pkgs/servers/sql/postgresql/ext/pgroonga.nix index ac778ec5d98007..028ec517f56f78 100644 --- a/pkgs/servers/sql/postgresql/ext/pgroonga.nix +++ b/pkgs/servers/sql/postgresql/ext/pgroonga.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, postgresql, msgpack-c, groonga, buildPostgresqlExtension, xxHash }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + postgresql, + msgpack-c, + groonga, + buildPostgresqlExtension, + xxHash, +}: buildPostgresqlExtension rec { pname = "pgroonga"; @@ -12,7 +22,11 @@ buildPostgresqlExtension rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ msgpack-c groonga xxHash ]; + buildInputs = [ + msgpack-c + groonga + xxHash + ]; makeFlags = [ "HAVE_XXHASH=1" diff --git a/pkgs/servers/sql/postgresql/ext/pgrouting.nix b/pkgs/servers/sql/postgresql/ext/pgrouting.nix index 9a1c940b288884..9c480c4c91acb3 100644 --- a/pkgs/servers/sql/postgresql/ext/pgrouting.nix +++ b/pkgs/servers/sql/postgresql/ext/pgrouting.nix @@ -1,25 +1,37 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, perl, cmake, boost, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + perl, + cmake, + boost, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pgrouting"; version = "3.7.0"; - nativeBuildInputs = [ cmake perl ]; + nativeBuildInputs = [ + cmake + perl + ]; buildInputs = [ boost ]; src = fetchFromGitHub { - owner = "pgRouting"; - repo = "pgrouting"; - rev = "v${version}"; - hash = "sha256-IwH8bEdyJyPMFYtCfWLRr+jVmS5sOr5QFOhGykGPYh4="; + owner = "pgRouting"; + repo = "pgrouting"; + rev = "v${version}"; + hash = "sha256-IwH8bEdyJyPMFYtCfWLRr+jVmS5sOr5QFOhGykGPYh4="; }; meta = with lib; { description = "PostgreSQL/PostGIS extension that provides geospatial routing functionality"; - homepage = "https://pgrouting.org/"; - changelog = "https://github.com/pgRouting/pgrouting/releases/tag/v${version}"; + homepage = "https://pgrouting.org/"; + changelog = "https://github.com/pgRouting/pgrouting/releases/tag/v${version}"; maintainers = with maintainers; teams.geospatial.members ++ [ steve-chavez ]; - platforms = postgresql.meta.platforms; - license = licenses.gpl2Plus; + platforms = postgresql.meta.platforms; + license = licenses.gpl2Plus; }; } diff --git a/pkgs/servers/sql/postgresql/ext/pgsodium.nix b/pkgs/servers/sql/postgresql/ext/pgsodium.nix index 9e72787c56ee20..c92cd819cafe56 100644 --- a/pkgs/servers/sql/postgresql/ext/pgsodium.nix +++ b/pkgs/servers/sql/postgresql/ext/pgsodium.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, libsodium -, postgresql -, postgresqlTestExtension -, buildPostgresqlExtension +{ + lib, + stdenv, + fetchFromGitHub, + libsodium, + postgresql, + postgresqlTestExtension, + buildPostgresqlExtension, }: buildPostgresqlExtension (finalAttrs: { diff --git a/pkgs/servers/sql/postgresql/ext/pgsql-http.nix b/pkgs/servers/sql/postgresql/ext/pgsql-http.nix index 11aa6dfec74879..50daa0d3e826f8 100644 --- a/pkgs/servers/sql/postgresql/ext/pgsql-http.nix +++ b/pkgs/servers/sql/postgresql/ext/pgsql-http.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, curl, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + curl, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pgsql-http"; diff --git a/pkgs/servers/sql/postgresql/ext/pgtap.nix b/pkgs/servers/sql/postgresql/ext/pgtap.nix index b09734c5f07dca..314b1530583da9 100644 --- a/pkgs/servers/sql/postgresql/ext/pgtap.nix +++ b/pkgs/servers/sql/postgresql/ext/pgtap.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, buildPostgresqlExtension -, fetchFromGitHub -, perl -, perlPackages -, postgresql -, postgresqlTestHook -, which +{ + lib, + stdenv, + buildPostgresqlExtension, + fetchFromGitHub, + perl, + perlPackages, + postgresql, + postgresqlTestHook, + which, }: buildPostgresqlExtension (finalAttrs: { @@ -20,13 +21,21 @@ buildPostgresqlExtension (finalAttrs: { sha256 = "sha256-YgvfLGF7pLVcCKD66NnWAydDxtoYHH1DpLiYTEKHJ0E="; }; - nativeBuildInputs = [ postgresql perl perlPackages.TAPParserSourceHandlerpgTAP which ]; + nativeBuildInputs = [ + postgresql + perl + perlPackages.TAPParserSourceHandlerpgTAP + which + ]; passthru.tests.extension = stdenv.mkDerivation { name = "pgtap-test"; dontUnpack = true; doCheck = true; - nativeCheckInputs = [ postgresqlTestHook (postgresql.withPackages (_: [ finalAttrs.finalPackage ])) ]; + nativeCheckInputs = [ + postgresqlTestHook + (postgresql.withPackages (_: [ finalAttrs.finalPackage ])) + ]; passAsFile = [ "sql" ]; sql = '' CREATE EXTENSION pgtap; diff --git a/pkgs/servers/sql/postgresql/ext/pgvector.nix b/pkgs/servers/sql/postgresql/ext/pgvector.nix index eed91a3a8c4589..3eb06fc9b06ca8 100644 --- a/pkgs/servers/sql/postgresql/ext/pgvector.nix +++ b/pkgs/servers/sql/postgresql/ext/pgvector.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "pgvector"; diff --git a/pkgs/servers/sql/postgresql/ext/plpgsql_check.nix b/pkgs/servers/sql/postgresql/ext/plpgsql_check.nix index 8d10de848f1bb6..86095dd7a6e52d 100644 --- a/pkgs/servers/sql/postgresql/ext/plpgsql_check.nix +++ b/pkgs/servers/sql/postgresql/ext/plpgsql_check.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, postgresqlTestExtension, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + postgresqlTestExtension, + buildPostgresqlExtension, +}: buildPostgresqlExtension (finalAttrs: { pname = "plpgsql-check"; diff --git a/pkgs/servers/sql/postgresql/ext/plr.nix b/pkgs/servers/sql/postgresql/ext/plr.nix index 2aece8cee9d185..c1148bf92c395d 100644 --- a/pkgs/servers/sql/postgresql/ext/plr.nix +++ b/pkgs/servers/sql/postgresql/ext/plr.nix @@ -1,8 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, R, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + R, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "plr"; - version = "${builtins.replaceStrings ["_"] ["."] (lib.strings.removePrefix "REL" src.rev)}"; + version = "${builtins.replaceStrings [ "_" ] [ "." ] (lib.strings.removePrefix "REL" src.rev)}"; src = fetchFromGitHub { owner = "postgres-plr"; diff --git a/pkgs/servers/sql/postgresql/ext/plv8/default.nix b/pkgs/servers/sql/postgresql/ext/plv8/default.nix index e9a9195078ed7b..3e00db9400fe1f 100644 --- a/pkgs/servers/sql/postgresql/ext/plv8/default.nix +++ b/pkgs/servers/sql/postgresql/ext/plv8/default.nix @@ -1,20 +1,22 @@ -{ stdenv -, lib -, fetchFromGitHub -, nodejs_20 -, perl -, postgresql -, jitSupport -, buildPostgresqlExtension -# For test -, runCommand -, coreutils -, gnugrep +{ + stdenv, + lib, + fetchFromGitHub, + nodejs_20, + perl, + postgresql, + jitSupport, + buildPostgresqlExtension, + # For test + runCommand, + coreutils, + gnugrep, }: let libv8 = nodejs_20.libv8; -in buildPostgresqlExtension (finalAttrs: { +in +buildPostgresqlExtension (finalAttrs: { pname = "plv8"; version = "3.2.3"; @@ -61,13 +63,16 @@ in buildPostgresqlExtension (finalAttrs: { postgresqlWithSelf = postgresql.withPackages (_: [ finalAttrs.finalPackage ]); - in { - smoke = runCommand "plv8-smoke-test" {} '' - export PATH=${lib.makeBinPath [ - postgresqlWithSelf - coreutils - gnugrep - ]} + in + { + smoke = runCommand "plv8-smoke-test" { } '' + export PATH=${ + lib.makeBinPath [ + postgresqlWithSelf + coreutils + gnugrep + ] + } db="$PWD/testdb" initdb "$db" postgres -k "$db" -D "$db" & @@ -90,7 +95,13 @@ in buildPostgresqlExtension (finalAttrs: { regression = stdenv.mkDerivation { name = "plv8-regression"; - inherit (finalAttrs) src patches nativeBuildInputs buildInputs dontConfigure; + inherit (finalAttrs) + src + patches + nativeBuildInputs + buildInputs + dontConfigure + ; buildPhase = '' runHook preBuild @@ -124,7 +135,10 @@ in buildPostgresqlExtension (finalAttrs: { homepage = "https://plv8.github.io/"; changelog = "https://github.com/plv8/plv8/blob/r${finalAttrs.version}/Changes"; maintainers = [ ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; license = licenses.postgresql; broken = jitSupport; }; diff --git a/pkgs/servers/sql/postgresql/ext/repmgr.nix b/pkgs/servers/sql/postgresql/ext/repmgr.nix index 5cdeaaebc2d239..a80ac369b7d485 100644 --- a/pkgs/servers/sql/postgresql/ext/repmgr.nix +++ b/pkgs/servers/sql/postgresql/ext/repmgr.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, postgresql -, flex -, curl -, json_c -, buildPostgresqlExtension +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + flex, + curl, + json_c, + buildPostgresqlExtension, }: buildPostgresqlExtension rec { @@ -21,7 +22,10 @@ buildPostgresqlExtension rec { nativeBuildInputs = [ flex ]; - buildInputs = postgresql.buildInputs ++ [ curl json_c ]; + buildInputs = postgresql.buildInputs ++ [ + curl + json_c + ]; meta = with lib; { homepage = "https://repmgr.org/"; @@ -31,4 +35,3 @@ buildPostgresqlExtension rec { maintainers = with maintainers; [ zimbatm ]; }; } - diff --git a/pkgs/servers/sql/postgresql/ext/smlar.nix b/pkgs/servers/sql/postgresql/ext/smlar.nix index 478abc1b0b9a4e..fa788db081ad52 100644 --- a/pkgs/servers/sql/postgresql/ext/smlar.nix +++ b/pkgs/servers/sql/postgresql/ext/smlar.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchgit, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchgit, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "smlar-unstable"; diff --git a/pkgs/servers/sql/postgresql/ext/tds_fdw.nix b/pkgs/servers/sql/postgresql/ext/tds_fdw.nix index 97d5dec1566cbf..56b9c164d74ad7 100644 --- a/pkgs/servers/sql/postgresql/ext/tds_fdw.nix +++ b/pkgs/servers/sql/postgresql/ext/tds_fdw.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, freetds, unstableGitUpdater, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + freetds, + unstableGitUpdater, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "tds_fdw"; @@ -7,18 +15,18 @@ buildPostgresqlExtension rec { buildInputs = [ freetds ]; src = fetchFromGitHub { - owner = "tds-fdw"; - repo = "tds_fdw"; - rev = "v${version}"; - hash = "sha256-ruelOHueaHx1royLPvDM8Abd1rQD62R4KXgtHY9qqTw="; + owner = "tds-fdw"; + repo = "tds_fdw"; + rev = "v${version}"; + hash = "sha256-ruelOHueaHx1royLPvDM8Abd1rQD62R4KXgtHY9qqTw="; }; meta = with lib; { description = "PostgreSQL foreign data wrapper to connect to TDS databases (Sybase and Microsoft SQL Server)"; - homepage = "https://github.com/tds-fdw/tds_fdw"; + homepage = "https://github.com/tds-fdw/tds_fdw"; changelog = "https://github.com/tds-fdw/tds_fdw/releases/tag/v${version}"; maintainers = [ maintainers.steve-chavez ]; - platforms = postgresql.meta.platforms; - license = licenses.postgresql; + platforms = postgresql.meta.platforms; + license = licenses.postgresql; }; } diff --git a/pkgs/servers/sql/postgresql/ext/temporal_tables.nix b/pkgs/servers/sql/postgresql/ext/temporal_tables.nix index 0be3dd60db8d31..03692a3ad7b638 100644 --- a/pkgs/servers/sql/postgresql/ext/temporal_tables.nix +++ b/pkgs/servers/sql/postgresql/ext/temporal_tables.nix @@ -1,21 +1,27 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension rec { pname = "temporal_tables"; version = "1.2.2"; src = fetchFromGitHub { - owner = "arkhipov"; - repo = "temporal_tables"; - rev = "v${version}"; + owner = "arkhipov"; + repo = "temporal_tables"; + rev = "v${version}"; sha256 = "sha256-7+DCSPAPhsokWDq/5IXNhd7jY6FfzxxUjlsg/VJeD3k="; }; meta = with lib; { description = "Temporal Tables PostgreSQL Extension"; - homepage = "https://github.com/arkhipov/temporal_tables"; + homepage = "https://github.com/arkhipov/temporal_tables"; maintainers = with maintainers; [ ggpeti ]; - platforms = postgresql.meta.platforms; - license = licenses.bsd2; + platforms = postgresql.meta.platforms; + license = licenses.bsd2; }; } diff --git a/pkgs/servers/sql/postgresql/ext/timescaledb_toolkit.nix b/pkgs/servers/sql/postgresql/ext/timescaledb_toolkit.nix index ce04690059a63e..e877aadd66d13c 100644 --- a/pkgs/servers/sql/postgresql/ext/timescaledb_toolkit.nix +++ b/pkgs/servers/sql/postgresql/ext/timescaledb_toolkit.nix @@ -1,10 +1,11 @@ -{ lib -, fetchFromGitHub -, buildPgrxExtension -, postgresql -, nixosTests -, cargo-pgrx_0_12_6 -, nix-update-script +{ + lib, + fetchFromGitHub, + buildPgrxExtension, + postgresql, + nixosTests, + cargo-pgrx_0_12_6, + nix-update-script, }: (buildPgrxExtension.override { cargo-pgrx = cargo-pgrx_0_12_6; }) rec { diff --git a/pkgs/servers/sql/postgresql/ext/tsearch_extras.nix b/pkgs/servers/sql/postgresql/ext/tsearch_extras.nix index d1e1fe4741df6e..ddde43a983b7fb 100644 --- a/pkgs/servers/sql/postgresql/ext/tsearch_extras.nix +++ b/pkgs/servers/sql/postgresql/ext/tsearch_extras.nix @@ -1,13 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, postgresql, buildPostgresqlExtension }: +{ + lib, + stdenv, + fetchFromGitHub, + postgresql, + buildPostgresqlExtension, +}: buildPostgresqlExtension { pname = "tsearch-extras"; version = "0.4"; src = fetchFromGitHub { - owner = "zulip"; - repo = "tsearch_extras"; - rev = "84e78f00931c4ef261d98197d6b5d94fc141f742"; # no release tag? + owner = "zulip"; + repo = "tsearch_extras"; + rev = "84e78f00931c4ef261d98197d6b5d94fc141f742"; # no release tag? sha256 = "18j0saqblg3jhrz38splk173xjwdf32c67ymm18m8n5y94h8d2ba"; }; diff --git a/pkgs/servers/sql/postgresql/ext/tsja.nix b/pkgs/servers/sql/postgresql/ext/tsja.nix index cb6a38951551d7..15df1763e2bf35 100644 --- a/pkgs/servers/sql/postgresql/ext/tsja.nix +++ b/pkgs/servers/sql/postgresql/ext/tsja.nix @@ -1,9 +1,10 @@ -{ lib -, fetchzip -, nixosTests -, stdenv -, mecab -, postgresql +{ + lib, + fetchzip, + nixosTests, + stdenv, + mecab, + postgresql, }: stdenv.mkDerivation rec { @@ -23,7 +24,10 @@ stdenv.mkDerivation rec { substituteInPlace tsja.c --replace-fail /usr/local/lib/mecab ${mecab}/lib/mecab ''; - buildInputs = [ mecab postgresql ]; + buildInputs = [ + mecab + postgresql + ]; installPhase = '' mkdir -p $out/lib $out/share/postgresql/extension diff --git a/pkgs/servers/sql/postgresql/generic.nix b/pkgs/servers/sql/postgresql/generic.nix index af643c6c0e2b27..8b4e592b1f527b 100644 --- a/pkgs/servers/sql/postgresql/generic.nix +++ b/pkgs/servers/sql/postgresql/generic.nix @@ -1,342 +1,452 @@ let generic = - # dependencies - { stdenv, lib, fetchurl, fetchpatch, makeWrapper - , glibc, zlib, readline, openssl, icu, lz4, zstd, systemdLibs, libuuid - , pkg-config, libxml2, tzdata, libkrb5, substituteAll, darwin - , linux-pam, bison, flex, perl, docbook_xml_dtd_45, docbook-xsl-nons, libxslt - - , removeReferencesTo, writeShellScriptBin - - , systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemdLibs - , gssSupport ? with stdenv.hostPlatform; !isWindows && !isStatic + # dependencies + { + stdenv, + lib, + fetchurl, + fetchpatch, + makeWrapper, + glibc, + zlib, + readline, + openssl, + icu, + lz4, + zstd, + systemdLibs, + libuuid, + pkg-config, + libxml2, + tzdata, + libkrb5, + substituteAll, + darwin, + linux-pam, + bison, + flex, + perl, + docbook_xml_dtd_45, + docbook-xsl-nons, + libxslt, + + removeReferencesTo, + writeShellScriptBin, + + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemdLibs, + gssSupport ? with stdenv.hostPlatform; !isWindows && !isStatic, # for postgresql.pkgs - , self, newScope, buildEnv - , stdenvNoCC, postgresqlTestHook + self, + newScope, + buildEnv, + stdenvNoCC, + postgresqlTestHook, # source specification - , version, hash, muslPatches ? {} + version, + hash, + muslPatches ? { }, # for tests - , testers, nixosTests + testers, + nixosTests, # JIT - , jitSupport - , nukeReferences, llvmPackages, overrideCC + jitSupport, + nukeReferences, + llvmPackages, + overrideCC, # PL/Python - , pythonSupport ? false - , python3 - } @args: - let - atLeast = lib.versionAtLeast version; - olderThan = lib.versionOlder version; - lz4Enabled = atLeast "14"; - zstdEnabled = atLeast "15"; - - dlSuffix = if olderThan "16" then ".so" else stdenv.hostPlatform.extensions.sharedLibrary; - - pname = "postgresql"; - - stdenv' = - if jitSupport && !stdenv.cc.isClang then - overrideCC llvmPackages.stdenv (llvmPackages.stdenv.cc.override { - # LLVM bintools are not used by default, but are needed to make -flto work below. - bintools = llvmPackages.bintools; - }) - else - stdenv; - - pg_config = writeShellScriptBin "pg_config" (builtins.readFile ./pg_config.sh); - in stdenv'.mkDerivation (finalAttrs: { - inherit version; - pname = pname + lib.optionalString jitSupport "-jit"; - - src = fetchurl { - url = "mirror://postgresql/source/v${version}/${pname}-${version}.tar.bz2"; - inherit hash; - }; + pythonSupport ? false, + python3, + }@args: + let + atLeast = lib.versionAtLeast version; + olderThan = lib.versionOlder version; + lz4Enabled = atLeast "14"; + zstdEnabled = atLeast "15"; + + dlSuffix = if olderThan "16" then ".so" else stdenv.hostPlatform.extensions.sharedLibrary; + + pname = "postgresql"; + + stdenv' = + if jitSupport && !stdenv.cc.isClang then + overrideCC llvmPackages.stdenv ( + llvmPackages.stdenv.cc.override { + # LLVM bintools are not used by default, but are needed to make -flto work below. + bintools = llvmPackages.bintools; + } + ) + else + stdenv; + + pg_config = writeShellScriptBin "pg_config" (builtins.readFile ./pg_config.sh); + in + stdenv'.mkDerivation (finalAttrs: { + inherit version; + pname = pname + lib.optionalString jitSupport "-jit"; + + src = fetchurl { + url = "mirror://postgresql/source/v${version}/${pname}-${version}.tar.bz2"; + inherit hash; + }; - __structuredAttrs = true; + __structuredAttrs = true; - hardeningEnable = lib.optionals (!stdenv'.cc.isClang) [ "pie" ]; + hardeningEnable = lib.optionals (!stdenv'.cc.isClang) [ "pie" ]; - outputs = [ "out" "dev" "doc" "lib" "man" ]; - outputChecks.out = { - disallowedReferences = [ "dev" "doc" "man" ]; - disallowedRequisites = [ - stdenv'.cc - ] ++ ( - map lib.getDev (builtins.filter (drv: drv ? "dev") finalAttrs.buildInputs) - ) ++ lib.optionals jitSupport [ - llvmPackages.llvm.out - ]; - }; - outputChecks.lib = { - disallowedReferences = [ "out" "dev" "doc" "man" ]; - disallowedRequisites = [ - stdenv'.cc - ] ++ ( - map lib.getDev (builtins.filter (drv: drv ? "dev") finalAttrs.buildInputs) - ) ++ lib.optionals jitSupport [ - llvmPackages.llvm.out + outputs = [ + "out" + "dev" + "doc" + "lib" + "man" ]; - }; + outputChecks.out = { + disallowedReferences = [ + "dev" + "doc" + "man" + ]; + disallowedRequisites = + [ + stdenv'.cc + ] + ++ (map lib.getDev (builtins.filter (drv: drv ? "dev") finalAttrs.buildInputs)) + ++ lib.optionals jitSupport [ + llvmPackages.llvm.out + ]; + }; + outputChecks.lib = { + disallowedReferences = [ + "out" + "dev" + "doc" + "man" + ]; + disallowedRequisites = + [ + stdenv'.cc + ] + ++ (map lib.getDev (builtins.filter (drv: drv ? "dev") finalAttrs.buildInputs)) + ++ lib.optionals jitSupport [ + llvmPackages.llvm.out + ]; + }; - buildInputs = [ - zlib - readline - openssl - (libxml2.override {enableHttp = true;}) - icu - libuuid - ] - ++ lib.optionals jitSupport [ llvmPackages.llvm ] - ++ lib.optionals lz4Enabled [ lz4 ] - ++ lib.optionals zstdEnabled [ zstd ] - ++ lib.optionals systemdSupport [ systemdLibs ] - ++ lib.optionals pythonSupport [ python3 ] - ++ lib.optionals gssSupport [ libkrb5 ] - ++ lib.optionals stdenv'.hostPlatform.isLinux [ linux-pam ]; - - nativeBuildInputs = [ - makeWrapper - pkg-config - removeReferencesTo - ] - ++ lib.optionals jitSupport [ llvmPackages.llvm.dev nukeReferences ] - ++ lib.optionals (atLeast "17") [ bison flex perl docbook_xml_dtd_45 docbook-xsl-nons libxslt ]; - - enableParallelBuilding = true; - - separateDebugInfo = true; - - buildFlags = [ "world" ]; - - # libpgcommon.a and libpgport.a contain all paths returned by pg_config and are linked - # into all binaries. However, almost no binaries actually use those paths. The following - # flags will remove unused sections from all shared libraries and binaries - including - # those paths. This avoids a lot of circular dependency problems with different outputs, - # and allows splitting them cleanly. - env.CFLAGS = "-fdata-sections -ffunction-sections" - + (if stdenv'.cc.isClang then " -flto" else " -fmerge-constants -Wl,--gc-sections"); - - configureFlags = [ - "--with-openssl" - "--with-libxml" - "--with-icu" - "--sysconfdir=/etc" - "--with-system-tzdata=${tzdata}/share/zoneinfo" - "--enable-debug" - (lib.optionalString systemdSupport "--with-systemd") - "--with-uuid=e2fs" - ] ++ lib.optionals lz4Enabled [ "--with-lz4" ] - ++ lib.optionals zstdEnabled [ "--with-zstd" ] - ++ lib.optionals gssSupport [ "--with-gssapi" ] - ++ lib.optionals pythonSupport [ "--with-python" ] - ++ lib.optionals jitSupport [ "--with-llvm" ] - ++ lib.optionals stdenv'.hostPlatform.isLinux [ "--with-pam" ] - # This could be removed once the upstream issue is resolved: - # https://postgr.es/m/flat/427c7c25-e8e1-4fc5-a1fb-01ceff185e5b%40technowledgy.de - ++ lib.optionals (stdenv'.hostPlatform.isDarwin && atLeast "16") [ "LDFLAGS_EX_BE=-Wl,-export_dynamic" ] - ++ lib.optionals (atLeast "17") [ "--without-perl" ]; - - patches = [ - (if atLeast "16" then ./patches/relative-to-symlinks-16+.patch else ./patches/relative-to-symlinks.patch) - (if atLeast "15" then ./patches/empty-pg-config-view-15+.patch else ./patches/empty-pg-config-view.patch) - ./patches/less-is-more.patch - ./patches/paths-for-split-outputs.patch - ./patches/paths-with-postgresql-suffix.patch - - (substituteAll { - src = ./patches/locale-binary-path.patch; - locale = "${if stdenv.hostPlatform.isDarwin then darwin.adv_cmds else lib.getBin stdenv.cc.libc}/bin/locale"; - }) - ] ++ lib.optionals stdenv'.hostPlatform.isMusl ( - # Using fetchurl instead of fetchpatch on purpose: https://github.com/NixOS/nixpkgs/issues/240141 - map fetchurl (lib.attrValues muslPatches) - ) ++ lib.optionals stdenv'.hostPlatform.isLinux [ - ./patches/socketdir-in-run-13+.patch - ] ++ lib.optionals (stdenv'.hostPlatform.isDarwin && olderThan "16") [ - ./patches/export-dynamic-darwin-15-.patch - ]; - - installTargets = [ "install-world" ]; - - postPatch = '' - substituteInPlace "src/Makefile.global.in" --subst-var out - # Hardcode the path to pgxs so pg_config returns the path in $dev - substituteInPlace "src/common/config_info.c" --subst-var dev - ''; - - postInstall = - '' - moveToOutput "bin/ecpg" "$dev" - moveToOutput "lib/pgxs" "$dev" - - # Pretend pg_config is located in $out/bin to return correct paths, but - # actually have it in -dev to avoid pulling in all other outputs. See the - # pg_config.sh script's comments for details. - moveToOutput "bin/pg_config" "$dev" - install -c -m 755 "${pg_config}"/bin/pg_config "$out/bin/pg_config" - wrapProgram "$dev/bin/pg_config" --argv0 "$out/bin/pg_config" - - # postgres exposes external symbols get_pkginclude_path and similar. Those - # can't be stripped away by --gc-sections/LTO, because they could theoretically - # be used by dynamically loaded modules / extensions. To avoid circular dependencies, - # references to -dev, -doc and -man are removed here. References to -lib must be kept, - # because there is a realistic use-case for extensions to locate the /lib directory to - # load other shared modules. - remove-references-to -t "$dev" -t "$doc" -t "$man" "$out/bin/postgres" - - if [ -z "''${dontDisableStatic:-}" ]; then - # Remove static libraries in case dynamic are available. - for i in $lib/lib/*.a; do - name="$(basename "$i")" - ext="${stdenv'.hostPlatform.extensions.sharedLibrary}" - if [ -e "$lib/lib/''${name%.a}$ext" ] || [ -e "''${i%.a}$ext" ]; then - rm "$i" - fi - done - fi - # The remaining static libraries are libpgcommon.a, libpgport.a and related. - # Those are only used when building e.g. extensions, so go to $dev. - moveToOutput "lib/*.a" "$dev" - '' + lib.optionalString jitSupport '' - # In the case of JIT support, prevent useless dependencies on header files - find "$out/lib" -iname '*.bc' -type f -exec nuke-refs '{}' + - - # Stop lib depending on the -dev output of llvm - remove-references-to -t ${llvmPackages.llvm.dev} "$out/lib/llvmjit${dlSuffix}" + buildInputs = + [ + zlib + readline + openssl + (libxml2.override { enableHttp = true; }) + icu + libuuid + ] + ++ lib.optionals jitSupport [ llvmPackages.llvm ] + ++ lib.optionals lz4Enabled [ lz4 ] + ++ lib.optionals zstdEnabled [ zstd ] + ++ lib.optionals systemdSupport [ systemdLibs ] + ++ lib.optionals pythonSupport [ python3 ] + ++ lib.optionals gssSupport [ libkrb5 ] + ++ lib.optionals stdenv'.hostPlatform.isLinux [ linux-pam ]; + + nativeBuildInputs = + [ + makeWrapper + pkg-config + removeReferencesTo + ] + ++ lib.optionals jitSupport [ + llvmPackages.llvm.dev + nukeReferences + ] + ++ lib.optionals (atLeast "17") [ + bison + flex + perl + docbook_xml_dtd_45 + docbook-xsl-nons + libxslt + ]; + + enableParallelBuilding = true; + + separateDebugInfo = true; + + buildFlags = [ "world" ]; + + # libpgcommon.a and libpgport.a contain all paths returned by pg_config and are linked + # into all binaries. However, almost no binaries actually use those paths. The following + # flags will remove unused sections from all shared libraries and binaries - including + # those paths. This avoids a lot of circular dependency problems with different outputs, + # and allows splitting them cleanly. + env.CFLAGS = + "-fdata-sections -ffunction-sections" + + (if stdenv'.cc.isClang then " -flto" else " -fmerge-constants -Wl,--gc-sections"); + + configureFlags = + [ + "--with-openssl" + "--with-libxml" + "--with-icu" + "--sysconfdir=/etc" + "--with-system-tzdata=${tzdata}/share/zoneinfo" + "--enable-debug" + (lib.optionalString systemdSupport "--with-systemd") + "--with-uuid=e2fs" + ] + ++ lib.optionals lz4Enabled [ "--with-lz4" ] + ++ lib.optionals zstdEnabled [ "--with-zstd" ] + ++ lib.optionals gssSupport [ "--with-gssapi" ] + ++ lib.optionals pythonSupport [ "--with-python" ] + ++ lib.optionals jitSupport [ "--with-llvm" ] + ++ lib.optionals stdenv'.hostPlatform.isLinux [ "--with-pam" ] + # This could be removed once the upstream issue is resolved: + # https://postgr.es/m/flat/427c7c25-e8e1-4fc5-a1fb-01ceff185e5b%40technowledgy.de + ++ lib.optionals (stdenv'.hostPlatform.isDarwin && atLeast "16") [ + "LDFLAGS_EX_BE=-Wl,-export_dynamic" + ] + ++ lib.optionals (atLeast "17") [ "--without-perl" ]; + + patches = + [ + ( + if atLeast "16" then + ./patches/relative-to-symlinks-16+.patch + else + ./patches/relative-to-symlinks.patch + ) + ( + if atLeast "15" then + ./patches/empty-pg-config-view-15+.patch + else + ./patches/empty-pg-config-view.patch + ) + ./patches/less-is-more.patch + ./patches/paths-for-split-outputs.patch + ./patches/paths-with-postgresql-suffix.patch + + (substituteAll { + src = ./patches/locale-binary-path.patch; + locale = "${ + if stdenv.hostPlatform.isDarwin then darwin.adv_cmds else lib.getBin stdenv.cc.libc + }/bin/locale"; + }) + ] + ++ lib.optionals stdenv'.hostPlatform.isMusl ( + # Using fetchurl instead of fetchpatch on purpose: https://github.com/NixOS/nixpkgs/issues/240141 + map fetchurl (lib.attrValues muslPatches) + ) + ++ lib.optionals stdenv'.hostPlatform.isLinux [ + ./patches/socketdir-in-run-13+.patch + ] + ++ lib.optionals (stdenv'.hostPlatform.isDarwin && olderThan "16") [ + ./patches/export-dynamic-darwin-15-.patch + ]; + + installTargets = [ "install-world" ]; + + postPatch = '' + substituteInPlace "src/Makefile.global.in" --subst-var out + # Hardcode the path to pgxs so pg_config returns the path in $dev + substituteInPlace "src/common/config_info.c" --subst-var dev ''; - postFixup = lib.optionalString stdenv'.hostPlatform.isGnu - '' + postInstall = + '' + moveToOutput "bin/ecpg" "$dev" + moveToOutput "lib/pgxs" "$dev" + + # Pretend pg_config is located in $out/bin to return correct paths, but + # actually have it in -dev to avoid pulling in all other outputs. See the + # pg_config.sh script's comments for details. + moveToOutput "bin/pg_config" "$dev" + install -c -m 755 "${pg_config}"/bin/pg_config "$out/bin/pg_config" + wrapProgram "$dev/bin/pg_config" --argv0 "$out/bin/pg_config" + + # postgres exposes external symbols get_pkginclude_path and similar. Those + # can't be stripped away by --gc-sections/LTO, because they could theoretically + # be used by dynamically loaded modules / extensions. To avoid circular dependencies, + # references to -dev, -doc and -man are removed here. References to -lib must be kept, + # because there is a realistic use-case for extensions to locate the /lib directory to + # load other shared modules. + remove-references-to -t "$dev" -t "$doc" -t "$man" "$out/bin/postgres" + + if [ -z "''${dontDisableStatic:-}" ]; then + # Remove static libraries in case dynamic are available. + for i in $lib/lib/*.a; do + name="$(basename "$i")" + ext="${stdenv'.hostPlatform.extensions.sharedLibrary}" + if [ -e "$lib/lib/''${name%.a}$ext" ] || [ -e "''${i%.a}$ext" ]; then + rm "$i" + fi + done + fi + # The remaining static libraries are libpgcommon.a, libpgport.a and related. + # Those are only used when building e.g. extensions, so go to $dev. + moveToOutput "lib/*.a" "$dev" + '' + + lib.optionalString jitSupport '' + # In the case of JIT support, prevent useless dependencies on header files + find "$out/lib" -iname '*.bc' -type f -exec nuke-refs '{}' + + + # Stop lib depending on the -dev output of llvm + remove-references-to -t ${llvmPackages.llvm.dev} "$out/lib/llvmjit${dlSuffix}" + ''; + + postFixup = lib.optionalString stdenv'.hostPlatform.isGnu '' # initdb needs access to "locale" command from glibc. wrapProgram $out/bin/initdb --prefix PATH ":" ${glibc.bin}/bin ''; - doCheck = !stdenv'.hostPlatform.isDarwin; - # autodetection doesn't seem to able to find this, but it's there. - checkTarget = "check-world"; - - passthru = let - this = self.callPackage generic args; - jitToggle = this.override { - jitSupport = !jitSupport; - }; - in - { - inherit dlSuffix; - - psqlSchema = lib.versions.major version; - - withJIT = if jitSupport then this else jitToggle; - withoutJIT = if jitSupport then jitToggle else this; - - pkgs = let - scope = { - inherit jitSupport; - inherit (llvmPackages) llvm; - postgresql = this; - stdenv = stdenv'; - postgresqlTestExtension = { finalPackage, withPackages ? [], ... } @ extraArgs: - stdenvNoCC.mkDerivation ({ - name = "${finalPackage.name}-test-extension"; - dontUnpack = true; - doCheck = true; - nativeCheckInputs = [ - postgresqlTestHook - (this.withPackages (ps: [ finalPackage ] ++ (map (p: ps."${p}") withPackages))) - ]; - failureHook = "postgresqlStop"; - postgresqlTestUserOptions = "LOGIN SUPERUSER"; - passAsFile = [ "sql" ]; - checkPhase = '' - runHook preCheck - psql -a -v ON_ERROR_STOP=1 -f "$sqlPath" - runHook postCheck - ''; - installPhase = "touch $out"; - } // extraArgs); - buildPostgresqlExtension = newSuper.callPackage ./buildPostgresqlExtension.nix {}; + doCheck = !stdenv'.hostPlatform.isDarwin; + # autodetection doesn't seem to able to find this, but it's there. + checkTarget = "check-world"; + + passthru = + let + this = self.callPackage generic args; + jitToggle = this.override { + jitSupport = !jitSupport; + }; + in + { + inherit dlSuffix; + + psqlSchema = lib.versions.major version; + + withJIT = if jitSupport then this else jitToggle; + withoutJIT = if jitSupport then jitToggle else this; + + pkgs = + let + scope = { + inherit jitSupport; + inherit (llvmPackages) llvm; + postgresql = this; + stdenv = stdenv'; + postgresqlTestExtension = + { + finalPackage, + withPackages ? [ ], + ... + }@extraArgs: + stdenvNoCC.mkDerivation ( + { + name = "${finalPackage.name}-test-extension"; + dontUnpack = true; + doCheck = true; + nativeCheckInputs = [ + postgresqlTestHook + (this.withPackages (ps: [ finalPackage ] ++ (map (p: ps."${p}") withPackages))) + ]; + failureHook = "postgresqlStop"; + postgresqlTestUserOptions = "LOGIN SUPERUSER"; + passAsFile = [ "sql" ]; + checkPhase = '' + runHook preCheck + psql -a -v ON_ERROR_STOP=1 -f "$sqlPath" + runHook postCheck + ''; + installPhase = "touch $out"; + } + // extraArgs + ); + buildPostgresqlExtension = newSuper.callPackage ./buildPostgresqlExtension.nix { }; + }; + newSelf = self // scope; + newSuper = { + callPackage = newScope (scope // this.pkgs); + }; + in + import ./ext newSelf newSuper; + + withPackages = postgresqlWithPackages { + inherit buildEnv; + postgresql = this; + }; + + tests = + { + postgresql = nixosTests.postgresql.postgresql.passthru.override finalAttrs.finalPackage; + postgresql-tls-client-cert = nixosTests.postgresql.postgresql-tls-client-cert.passthru.override finalAttrs.finalPackage; + postgresql-wal-receiver = nixosTests.postgresql.postgresql-wal-receiver.passthru.override finalAttrs.finalPackage; + pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; + } + // lib.optionalAttrs jitSupport { + postgresql-jit = nixosTests.postgresql.postgresql-jit.passthru.override finalAttrs.finalPackage; + }; }; - newSelf = self // scope; - newSuper = { callPackage = newScope (scope // this.pkgs); }; - in import ./ext newSelf newSuper; - - withPackages = postgresqlWithPackages { - inherit buildEnv; - postgresql = this; - }; - - tests = { - postgresql = nixosTests.postgresql.postgresql.passthru.override finalAttrs.finalPackage; - postgresql-tls-client-cert = nixosTests.postgresql.postgresql-tls-client-cert.passthru.override finalAttrs.finalPackage; - postgresql-wal-receiver = nixosTests.postgresql.postgresql-wal-receiver.passthru.override finalAttrs.finalPackage; - pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; - } // lib.optionalAttrs jitSupport { - postgresql-jit = nixosTests.postgresql.postgresql-jit.passthru.override finalAttrs.finalPackage; - }; - }; - meta = with lib; { - homepage = "https://www.postgresql.org"; - description = "Powerful, open source object-relational database system"; - license = licenses.postgresql; - changelog = "https://www.postgresql.org/docs/release/${finalAttrs.version}/"; - maintainers = with maintainers; teams.postgres.members; - pkgConfigModules = [ "libecpg" "libecpg_compat" "libpgtypes" "libpq" ]; - platforms = platforms.unix; - - # JIT support doesn't work with cross-compilation. It is attempted to build LLVM-bytecode - # (`%.bc` is the corresponding `make(1)`-rule) for each sub-directory in `backend/` for - # the JIT apparently, but with a $(CLANG) that can produce binaries for the build, not the - # host-platform. - # - # I managed to get a cross-build with JIT support working with - # `depsBuildBuild = [ llvmPackages.clang ] ++ buildInputs`, but considering that the - # resulting LLVM IR isn't platform-independent this doesn't give you much. - # In fact, I tried to test the result in a VM-test, but as soon as JIT was used to optimize - # a query, postgres would coredump with `Illegal instruction`. - broken = jitSupport && !stdenv.hostPlatform.canExecute stdenv.buildPlatform; - }; - }); + meta = with lib; { + homepage = "https://www.postgresql.org"; + description = "Powerful, open source object-relational database system"; + license = licenses.postgresql; + changelog = "https://www.postgresql.org/docs/release/${finalAttrs.version}/"; + maintainers = with maintainers; teams.postgres.members; + pkgConfigModules = [ + "libecpg" + "libecpg_compat" + "libpgtypes" + "libpq" + ]; + platforms = platforms.unix; + + # JIT support doesn't work with cross-compilation. It is attempted to build LLVM-bytecode + # (`%.bc` is the corresponding `make(1)`-rule) for each sub-directory in `backend/` for + # the JIT apparently, but with a $(CLANG) that can produce binaries for the build, not the + # host-platform. + # + # I managed to get a cross-build with JIT support working with + # `depsBuildBuild = [ llvmPackages.clang ] ++ buildInputs`, but considering that the + # resulting LLVM IR isn't platform-independent this doesn't give you much. + # In fact, I tried to test the result in a VM-test, but as soon as JIT was used to optimize + # a query, postgres would coredump with `Illegal instruction`. + broken = jitSupport && !stdenv.hostPlatform.canExecute stdenv.buildPlatform; + }; + }); - postgresqlWithPackages = { postgresql, buildEnv }: f: let - installedExtensions = f postgresql.pkgs; - in buildEnv { - name = "${postgresql.pname}-and-plugins-${postgresql.version}"; - paths = installedExtensions ++ [ + postgresqlWithPackages = + { postgresql, buildEnv }: + f: + let + installedExtensions = f postgresql.pkgs; + in + buildEnv { + name = "${postgresql.pname}-and-plugins-${postgresql.version}"; + paths = installedExtensions ++ [ postgresql - postgresql.man # in case user installs this into environment - ]; - - pathsToLink = ["/"]; - - passthru = { - inherit installedExtensions; - inherit (postgresql) - psqlSchema - version - ; - - withJIT = postgresqlWithPackages { - inherit buildEnv; - postgresql = postgresql.withJIT; - } f; - withoutJIT = postgresqlWithPackages { - inherit buildEnv; - postgresql = postgresql.withoutJIT; - } f; + postgresql.man # in case user installs this into environment + ]; + + pathsToLink = [ "/" ]; + + passthru = { + inherit installedExtensions; + inherit (postgresql) + psqlSchema + version + ; + + withJIT = postgresqlWithPackages { + inherit buildEnv; + postgresql = postgresql.withJIT; + } f; + withoutJIT = postgresqlWithPackages { + inherit buildEnv; + postgresql = postgresql.withoutJIT; + } f; + }; }; - }; in # passed by .nix versionArgs: # passed by default.nix -{ self, ... } @defaultArgs: +{ self, ... }@defaultArgs: self.callPackage generic (defaultArgs // versionArgs) diff --git a/pkgs/servers/sunshine/default.nix b/pkgs/servers/sunshine/default.nix index 6ced9624b74189..71e52ec39f45a4 100644 --- a/pkgs/servers/sunshine/default.nix +++ b/pkgs/servers/sunshine/default.nix @@ -1,52 +1,53 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoPatchelfHook -, autoAddDriverRunpath -, makeWrapper -, buildNpmPackage -, nixosTests -, cmake -, avahi -, libevdev -, libpulseaudio -, xorg -, libxcb -, openssl -, libopus -, boost -, pkg-config -, libdrm -, wayland -, wayland-scanner -, libffi -, libcap -, mesa -, curl -, pcre -, pcre2 -, python3 -, libuuid -, libselinux -, libsepol -, libthai -, libdatrie -, libxkbcommon -, libepoxy -, libva -, libvdpau -, libglvnd -, numactl -, amf-headers -, intel-media-sdk -, svt-av1 -, vulkan-loader -, libappindicator -, libnotify -, miniupnpc -, config -, cudaSupport ? config.cudaSupport -, cudaPackages ? { } +{ + lib, + stdenv, + fetchFromGitHub, + autoPatchelfHook, + autoAddDriverRunpath, + makeWrapper, + buildNpmPackage, + nixosTests, + cmake, + avahi, + libevdev, + libpulseaudio, + xorg, + libxcb, + openssl, + libopus, + boost, + pkg-config, + libdrm, + wayland, + wayland-scanner, + libffi, + libcap, + mesa, + curl, + pcre, + pcre2, + python3, + libuuid, + libselinux, + libsepol, + libthai, + libdatrie, + libxkbcommon, + libepoxy, + libva, + libvdpau, + libglvnd, + numactl, + amf-headers, + intel-media-sdk, + svt-av1, + vulkan-loader, + libappindicator, + libnotify, + miniupnpc, + config, + cudaSupport ? config.cudaSupport, + cudaPackages ? { }, }: let stdenv' = if cudaSupport then cudaPackages.backendStdenv else stdenv; @@ -86,62 +87,67 @@ stdenv'.mkDerivation rec { ''; }; - nativeBuildInputs = [ - cmake - pkg-config - python3 - makeWrapper - wayland-scanner - # Avoid fighting upstream's usage of vendored ffmpeg libraries - autoPatchelfHook - ] ++ lib.optionals cudaSupport [ - autoAddDriverRunpath - ]; - - buildInputs = [ - avahi - libevdev - libpulseaudio - xorg.libX11 - libxcb - xorg.libXfixes - xorg.libXrandr - xorg.libXtst - xorg.libXi - openssl - libopus - boost - libdrm - wayland - libffi - libevdev - libcap - libdrm - curl - pcre - pcre2 - libuuid - libselinux - libsepol - libthai - libdatrie - xorg.libXdmcp - libxkbcommon - libepoxy - libva - libvdpau - numactl - mesa - amf-headers - svt-av1 - libappindicator - libnotify - miniupnpc - ] ++ lib.optionals cudaSupport [ - cudaPackages.cudatoolkit - ] ++ lib.optionals stdenv.hostPlatform.isx86_64 [ - intel-media-sdk - ]; + nativeBuildInputs = + [ + cmake + pkg-config + python3 + makeWrapper + wayland-scanner + # Avoid fighting upstream's usage of vendored ffmpeg libraries + autoPatchelfHook + ] + ++ lib.optionals cudaSupport [ + autoAddDriverRunpath + ]; + + buildInputs = + [ + avahi + libevdev + libpulseaudio + xorg.libX11 + libxcb + xorg.libXfixes + xorg.libXrandr + xorg.libXtst + xorg.libXi + openssl + libopus + boost + libdrm + wayland + libffi + libevdev + libcap + libdrm + curl + pcre + pcre2 + libuuid + libselinux + libsepol + libthai + libdatrie + xorg.libXdmcp + libxkbcommon + libepoxy + libva + libvdpau + numactl + mesa + amf-headers + svt-av1 + libappindicator + libnotify + miniupnpc + ] + ++ lib.optionals cudaSupport [ + cudaPackages.cudatoolkit + ] + ++ lib.optionals stdenv.hostPlatform.isx86_64 [ + intel-media-sdk + ]; runtimeDependencies = [ avahi diff --git a/pkgs/servers/tang/default.nix b/pkgs/servers/tang/default.nix index e6581921fcb7fb..851269ed855791 100644 --- a/pkgs/servers/tang/default.nix +++ b/pkgs/servers/tang/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, asciidoc -, jansson -, jose -, http-parser -, systemd -, meson -, ninja -, makeWrapper -, testers -, tang -, gitUpdater -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + asciidoc, + jansson, + jose, + http-parser, + systemd, + meson, + ninja, + makeWrapper, + testers, + tang, + gitUpdater, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/servers/tautulli/default.nix b/pkgs/servers/tautulli/default.nix index 64454b9fe83d66..d9d3bffc55967c 100644 --- a/pkgs/servers/tautulli/default.nix +++ b/pkgs/servers/tautulli/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchFromGitHub, buildPythonApplication, setuptools, wrapPython, makeWrapper }: +{ + lib, + fetchFromGitHub, + buildPythonApplication, + setuptools, + wrapPython, + makeWrapper, +}: buildPythonApplication rec { pname = "Tautulli"; @@ -6,7 +13,10 @@ buildPythonApplication rec { format = "other"; pythonPath = [ setuptools ]; - nativeBuildInputs = [ wrapPython makeWrapper ]; + nativeBuildInputs = [ + wrapPython + makeWrapper + ]; src = fetchFromGitHub { owner = "Tautulli"; @@ -43,7 +53,7 @@ buildPythonApplication rec { runHook postCheck ''; - meta = with lib; { + meta = with lib; { description = "Python based monitoring and tracking tool for Plex Media Server"; homepage = "https://tautulli.com/"; license = licenses.gpl3Plus; diff --git a/pkgs/servers/teleport/15/default.nix b/pkgs/servers/teleport/15/default.nix index 12cedd53969671..7df86df8c40d0e 100644 --- a/pkgs/servers/teleport/15/default.nix +++ b/pkgs/servers/teleport/15/default.nix @@ -1,22 +1,25 @@ { wasm-bindgen-cli, ... }@args: -import ../generic.nix (args // { - version = "15.4.21"; - hash = "sha256-n5dAJ5ilq5nHo3neQzCUFnDRwLhArwleMSho4/g0MT4="; - vendorHash = "sha256-bW8ztNeSzxUNtbuBtxIya9TeGfktC+/fz9iXB0GL0Mg="; - yarnHash = "sha256-ZaLLrcwAeq6TQ1SaA2few4s0HqktOZEpxCTcNGloGfk="; - cargoLock = { - lockFile = ./Cargo.lock; - outputHashes = { - "boring-4.4.0" = "sha256-4wdl2kIA5oHQ0H6IddKQ+B5kRwrTeMbKe1+tAYZt2uw="; - "ironrdp-async-0.1.0" = "sha256-nE5O/wRJ3vJqJG5zdYmpVkhx6JC6Yb92pR4EKSWSdkA="; - "sspi-0.10.1" = "sha256-fkclC/plTh2d8zcmqthYmr5yXqbPTeFxI1VuaPX5vxk="; +import ../generic.nix ( + args + // { + version = "15.4.21"; + hash = "sha256-n5dAJ5ilq5nHo3neQzCUFnDRwLhArwleMSho4/g0MT4="; + vendorHash = "sha256-bW8ztNeSzxUNtbuBtxIya9TeGfktC+/fz9iXB0GL0Mg="; + yarnHash = "sha256-ZaLLrcwAeq6TQ1SaA2few4s0HqktOZEpxCTcNGloGfk="; + cargoLock = { + lockFile = ./Cargo.lock; + outputHashes = { + "boring-4.4.0" = "sha256-4wdl2kIA5oHQ0H6IddKQ+B5kRwrTeMbKe1+tAYZt2uw="; + "ironrdp-async-0.1.0" = "sha256-nE5O/wRJ3vJqJG5zdYmpVkhx6JC6Yb92pR4EKSWSdkA="; + "sspi-0.10.1" = "sha256-fkclC/plTh2d8zcmqthYmr5yXqbPTeFxI1VuaPX5vxk="; + }; }; - }; - # wasm-bindgen-cli version must match the version of wasm-bindgen in Cargo.lock - wasm-bindgen-cli = wasm-bindgen-cli.override { - version = "0.2.92"; - hash = "sha256-1VwY8vQy7soKEgbki4LD+v259751kKxSxmo/gqE6yV0="; - cargoHash = "sha256-aACJ+lYNEU8FFBs158G1/JG8sc6Rq080PeKCMnwdpH0="; - }; -}) + # wasm-bindgen-cli version must match the version of wasm-bindgen in Cargo.lock + wasm-bindgen-cli = wasm-bindgen-cli.override { + version = "0.2.92"; + hash = "sha256-1VwY8vQy7soKEgbki4LD+v259751kKxSxmo/gqE6yV0="; + cargoHash = "sha256-aACJ+lYNEU8FFBs158G1/JG8sc6Rq080PeKCMnwdpH0="; + }; + } +) diff --git a/pkgs/servers/teleport/16/default.nix b/pkgs/servers/teleport/16/default.nix index ecd714d77d0632..5ef66c9ce8a35a 100644 --- a/pkgs/servers/teleport/16/default.nix +++ b/pkgs/servers/teleport/16/default.nix @@ -1,21 +1,24 @@ { wasm-bindgen-cli, ... }@args: -import ../generic.nix (args // { - version = "16.4.6"; - hash = "sha256-TdOCFs6YeqINM8aPryrjYPaXEjc/gIqu7kzVYDnMsjg="; - vendorHash = "sha256-iyYfht0aB9Vv2hsaqrieFHXbDhlotKQYfLn4JFqpve8="; - pnpmHash = "sha256-NF45Wp4itYud01VzxC8bRHZ3xZ1T1du1QmZTDMS5nOk="; - cargoLock = { - lockFile = ./Cargo.lock; - outputHashes = { - "boring-4.7.0" = "sha256-ACzw4Bfo6OUrwvi3h21tvx5CpdQaWCEIDkslzjzy9o8="; - "ironrdp-async-0.1.0" = "sha256-DOwDHavDaEda+JK9M6kbvseoXe2LxJg3MLTY/Nu+PN0="; - }; - }; +import ../generic.nix ( + args + // { + version = "16.4.6"; + hash = "sha256-TdOCFs6YeqINM8aPryrjYPaXEjc/gIqu7kzVYDnMsjg="; + vendorHash = "sha256-iyYfht0aB9Vv2hsaqrieFHXbDhlotKQYfLn4JFqpve8="; + pnpmHash = "sha256-NF45Wp4itYud01VzxC8bRHZ3xZ1T1du1QmZTDMS5nOk="; + cargoLock = { + lockFile = ./Cargo.lock; + outputHashes = { + "boring-4.7.0" = "sha256-ACzw4Bfo6OUrwvi3h21tvx5CpdQaWCEIDkslzjzy9o8="; + "ironrdp-async-0.1.0" = "sha256-DOwDHavDaEda+JK9M6kbvseoXe2LxJg3MLTY/Nu+PN0="; + }; + }; - # wasm-bindgen-cli version must match the version of wasm-bindgen in Cargo.lock - wasm-bindgen-cli = wasm-bindgen-cli.override { - version = "0.2.93"; - hash = "sha256-DDdu5mM3gneraM85pAepBXWn3TMofarVR4NbjMdz3r0="; - cargoHash = "sha256-birrg+XABBHHKJxfTKAMSlmTVYLmnmqMDfRnmG6g/YQ="; - }; -}) + # wasm-bindgen-cli version must match the version of wasm-bindgen in Cargo.lock + wasm-bindgen-cli = wasm-bindgen-cli.override { + version = "0.2.93"; + hash = "sha256-DDdu5mM3gneraM85pAepBXWn3TMofarVR4NbjMdz3r0="; + cargoHash = "sha256-birrg+XABBHHKJxfTKAMSlmTVYLmnmqMDfRnmG6g/YQ="; + }; + } +) diff --git a/pkgs/servers/teleport/generic.nix b/pkgs/servers/teleport/generic.nix index ed2ce5d8a7d1c1..5c5f6dfbd29b49 100644 --- a/pkgs/servers/teleport/generic.nix +++ b/pkgs/servers/teleport/generic.nix @@ -1,38 +1,39 @@ -{ lib -, buildGoModule -, rustPlatform -, fetchFromGitHub -, fetchYarnDeps -, makeWrapper -, CoreFoundation -, AppKit -, binaryen -, cargo -, libfido2 -, nodejs -, openssl -, pkg-config -, pnpm_9 -, rustc -, Security -, stdenv -, xdg-utils -, yarn -, wasm-bindgen-cli -, wasm-pack -, fixup-yarn-lock -, nixosTests - -, withRdpClient ? true - -, version -, hash -, vendorHash -, extPatches ? [] -, cargoHash ? null -, cargoLock ? null -, yarnHash ? null -, pnpmHash ? null +{ + lib, + buildGoModule, + rustPlatform, + fetchFromGitHub, + fetchYarnDeps, + makeWrapper, + CoreFoundation, + AppKit, + binaryen, + cargo, + libfido2, + nodejs, + openssl, + pkg-config, + pnpm_9, + rustc, + Security, + stdenv, + xdg-utils, + yarn, + wasm-bindgen-cli, + wasm-pack, + fixup-yarn-lock, + nixosTests, + + withRdpClient ? true, + + version, + hash, + vendorHash, + extPatches ? [ ], + cargoHash ? null, + cargoLock ? null, + yarnHash ? null, + pnpmHash ? null, }: assert yarnHash != null || pnpmHash != null; let @@ -53,8 +54,12 @@ let buildAndTestSubdir = "lib/srv/desktop/rdp/rdpclient"; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreFoundation Security ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreFoundation + Security + ]; nativeBuildInputs = [ pkg-config ]; # https://github.com/NixOS/nixpkgs/issues/161570 , @@ -80,21 +85,36 @@ let cargoDeps = rustPlatform.importCargoLock cargoLock; - pnpmDeps = if pnpmHash != null then pnpm_9.fetchDeps { - inherit src pname version; - hash = pnpmHash; - } else null; - - nativeBuildInputs = [ nodejs ] ++ lib.optional (lib.versionAtLeast version "15") [ - binaryen - cargo - nodejs - rustc - rustc.llvmPackages.lld - rustPlatform.cargoSetupHook - wasm-bindgen-cli - wasm-pack - ] ++ (if lib.versionAtLeast version "16" then [ pnpm_9.configHook ] else [ yarn fixup-yarn-lock ]); + pnpmDeps = + if pnpmHash != null then + pnpm_9.fetchDeps { + inherit src pname version; + hash = pnpmHash; + } + else + null; + + nativeBuildInputs = + [ nodejs ] + ++ lib.optional (lib.versionAtLeast version "15") [ + binaryen + cargo + nodejs + rustc + rustc.llvmPackages.lld + rustPlatform.cargoSetupHook + wasm-bindgen-cli + wasm-pack + ] + ++ ( + if lib.versionAtLeast version "16" then + [ pnpm_9.configHook ] + else + [ + yarn + fixup-yarn-lock + ] + ); configurePhase = '' runHook preConfigure @@ -117,15 +137,18 @@ let PATH=$PATH:$PWD/node_modules/.bin - ${if lib.versionAtLeast version "15" - then '' - pushd web/packages/teleport - # https://github.com/gravitational/teleport/blob/6b91fe5bbb9e87db4c63d19f94ed4f7d0f9eba43/web/packages/teleport/README.md?plain=1#L18-L20 - RUST_MIN_STACK=16777216 wasm-pack build ./src/ironrdp --target web --mode no-install - vite build - popd - '' - else "yarn build-ui-oss"} + ${ + if lib.versionAtLeast version "15" then + '' + pushd web/packages/teleport + # https://github.com/gravitational/teleport/blob/6b91fe5bbb9e87db4c63d19f94ed4f7d0f9eba43/web/packages/teleport/README.md?plain=1#L18-L20 + RUST_MIN_STACK=16777216 wasm-pack build ./src/ironrdp --target web --mode no-install + vite build + popd + '' + else + "yarn build-ui-oss" + } ''; installPhase = '' @@ -139,13 +162,31 @@ buildGoModule rec { inherit vendorHash; proxyVendor = true; - subPackages = [ "tool/tbot" "tool/tctl" "tool/teleport" "tool/tsh" ]; - tags = [ "libfido2" "webassets_embed" ] - ++ lib.optional withRdpClient "desktop_access_rdp"; - - buildInputs = [ openssl libfido2 ] - ++ lib.optionals (stdenv.hostPlatform.isDarwin && withRdpClient) [ CoreFoundation Security AppKit ]; - nativeBuildInputs = [ makeWrapper pkg-config ]; + subPackages = [ + "tool/tbot" + "tool/tctl" + "tool/teleport" + "tool/tsh" + ]; + tags = [ + "libfido2" + "webassets_embed" + ] ++ lib.optional withRdpClient "desktop_access_rdp"; + + buildInputs = + [ + openssl + libfido2 + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && withRdpClient) [ + CoreFoundation + Security + AppKit + ]; + nativeBuildInputs = [ + makeWrapper + pkg-config + ]; patches = extPatches ++ [ ./0001-fix-add-nix-path-to-exec-env.patch @@ -154,14 +195,19 @@ buildGoModule rec { ]; # Reduce closure size for client machines - outputs = [ "out" "client" ]; + outputs = [ + "out" + "client" + ]; - preBuild = '' - cp -r ${webassets} webassets - '' + lib.optionalString withRdpClient '' - ln -s ${rdpClient}/lib/* lib/ - ln -s ${rdpClient}/include/* lib/srv/desktop/rdp/rdpclient/ - ''; + preBuild = + '' + cp -r ${webassets} webassets + '' + + lib.optionalString withRdpClient '' + ln -s ${rdpClient}/lib/* lib/ + ln -s ${rdpClient}/include/* lib/srv/desktop/rdp/rdpclient/ + ''; # Multiple tests fail in the build sandbox # due to trying to spawn nixbld's shell (/noshell), etc. @@ -191,7 +237,14 @@ buildGoModule rec { description = "Certificate authority and access plane for SSH, Kubernetes, web applications, and databases"; homepage = "https://goteleport.com/"; license = if lib.versionAtLeast version "15" then licenses.agpl3Plus else licenses.asl20; - maintainers = with maintainers; [ arianvp justinas sigma tomberek freezeboy techknowlogick ]; + maintainers = with maintainers; [ + arianvp + justinas + sigma + tomberek + freezeboy + techknowlogick + ]; platforms = platforms.unix; # go-libfido2 is broken on platforms with less than 64-bit because it defines an array # which occupies more than 31 bits of address space. diff --git a/pkgs/servers/tracing/honeycomb/honeymarker/default.nix b/pkgs/servers/tracing/honeycomb/honeymarker/default.nix index 9691d08b871077..a615567005e538 100644 --- a/pkgs/servers/tracing/honeycomb/honeymarker/default.nix +++ b/pkgs/servers/tracing/honeycomb/honeymarker/default.nix @@ -1,23 +1,28 @@ -{ lib, buildGoModule, fetchFromGitHub }: -import ./versions.nix ({version, sha256}: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: +import ./versions.nix ( + { version, sha256 }: buildGoModule { - pname = "honeymarker"; - inherit version; - vendorHash = "sha256-ZuDobjC/nizZ7G0o/zVTQmDfDjcdBhfPcmkhgwFc7VU="; + pname = "honeymarker"; + inherit version; + vendorHash = "sha256-ZuDobjC/nizZ7G0o/zVTQmDfDjcdBhfPcmkhgwFc7VU="; - src = fetchFromGitHub { - owner = "honeycombio"; - repo = "honeymarker"; - rev = "v${version}"; - hash = sha256; - }; - inherit (buildGoModule.go) GOOS GOARCH; - - meta = with lib; { - description = "provides a simple CRUD interface for dealing with per-dataset markers on honeycomb.io"; - homepage = "https://honeycomb.io/"; - license = licenses.asl20; - maintainers = [ maintainers.iand675 ]; - }; -}) + src = fetchFromGitHub { + owner = "honeycombio"; + repo = "honeymarker"; + rev = "v${version}"; + hash = sha256; + }; + inherit (buildGoModule.go) GOOS GOARCH; + meta = with lib; { + description = "provides a simple CRUD interface for dealing with per-dataset markers on honeycomb.io"; + homepage = "https://honeycomb.io/"; + license = licenses.asl20; + maintainers = [ maintainers.iand675 ]; + }; + } +) diff --git a/pkgs/servers/tracing/honeycomb/honeytail/default.nix b/pkgs/servers/tracing/honeycomb/honeytail/default.nix index 846bfbdd68be00..ecc6306bdce75e 100644 --- a/pkgs/servers/tracing/honeycomb/honeytail/default.nix +++ b/pkgs/servers/tracing/honeycomb/honeytail/default.nix @@ -1,23 +1,28 @@ -{ lib, buildGoModule, fetchFromGitHub }: -import ./versions.nix ({version, sha256}: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: +import ./versions.nix ( + { version, sha256 }: buildGoModule { - pname = "honeytail"; - inherit version; - vendorHash = "sha256-LtiiLGLjhbfT49A6Fw5CbSbnmTHMxtcUssr+ayCVrvY="; + pname = "honeytail"; + inherit version; + vendorHash = "sha256-LtiiLGLjhbfT49A6Fw5CbSbnmTHMxtcUssr+ayCVrvY="; - src = fetchFromGitHub { - owner = "honeycombio"; - repo = "honeytail"; - rev = "v${version}"; - hash = sha256; - }; - inherit (buildGoModule.go) GOOS GOARCH; - - meta = with lib; { - description = "agent for ingesting log file data into honeycomb.io and making it available for exploration"; - homepage = "https://honeycomb.io/"; - license = licenses.asl20; - maintainers = [ maintainers.iand675 ]; - }; -}) + src = fetchFromGitHub { + owner = "honeycombio"; + repo = "honeytail"; + rev = "v${version}"; + hash = sha256; + }; + inherit (buildGoModule.go) GOOS GOARCH; + meta = with lib; { + description = "agent for ingesting log file data into honeycomb.io and making it available for exploration"; + homepage = "https://honeycomb.io/"; + license = licenses.asl20; + maintainers = [ maintainers.iand675 ]; + }; + } +) diff --git a/pkgs/servers/tracing/honeycomb/honeyvent/default.nix b/pkgs/servers/tracing/honeycomb/honeyvent/default.nix index e950980f0375a9..036795d5fb7925 100644 --- a/pkgs/servers/tracing/honeycomb/honeyvent/default.nix +++ b/pkgs/servers/tracing/honeycomb/honeyvent/default.nix @@ -1,23 +1,28 @@ -{ lib, buildGoModule, fetchFromGitHub }: -import ./versions.nix ({version, sha256}: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: +import ./versions.nix ( + { version, sha256 }: buildGoModule { - pname = "honeyvent"; - inherit version; - vendorHash = null; + pname = "honeyvent"; + inherit version; + vendorHash = null; - src = fetchFromGitHub { - owner = "honeycombio"; - repo = "honeyvent"; - rev = "v${version}"; - hash = sha256; - }; - inherit (buildGoModule.go) GOOS GOARCH; - - meta = with lib; { - description = "CLI for sending individual events to honeycomb.io"; - homepage = "https://honeycomb.io/"; - license = licenses.asl20; - maintainers = [ maintainers.iand675 ]; - }; -}) + src = fetchFromGitHub { + owner = "honeycombio"; + repo = "honeyvent"; + rev = "v${version}"; + hash = sha256; + }; + inherit (buildGoModule.go) GOOS GOARCH; + meta = with lib; { + description = "CLI for sending individual events to honeycomb.io"; + homepage = "https://honeycomb.io/"; + license = licenses.asl20; + maintainers = [ maintainers.iand675 ]; + }; + } +) diff --git a/pkgs/servers/trezord/default.nix b/pkgs/servers/trezord/default.nix index 3852f139935c57..0bfabf974e6e89 100644 --- a/pkgs/servers/trezord/default.nix +++ b/pkgs/servers/trezord/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, fetchpatch -, trezor-udev-rules -, nixosTests -, AppKit +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + fetchpatch, + trezor-udev-rules, + nixosTests, + AppKit, }: buildGoModule rec { @@ -30,11 +31,13 @@ buildGoModule rec { }) ]; - propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ trezor-udev-rules ] + propagatedBuildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ trezor-udev-rules ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ AppKit ]; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X main.githash=${commit}" ]; @@ -44,7 +47,13 @@ buildGoModule rec { description = "Trezor Communication Daemon aka Trezor Bridge"; homepage = "https://trezor.io"; license = licenses.lgpl3Only; - maintainers = with maintainers; [ canndrew jb55 prusnak mmahut _1000101 ]; + maintainers = with maintainers; [ + canndrew + jb55 + prusnak + mmahut + _1000101 + ]; mainProgram = "trezord-go"; }; } diff --git a/pkgs/servers/trickster/trickster.nix b/pkgs/servers/trickster/trickster.nix index 2f0a3b60f217c2..bcdfb989bee8d2 100644 --- a/pkgs/servers/trickster/trickster.nix +++ b/pkgs/servers/trickster/trickster.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, go -, nixosTests +{ + lib, + buildGoModule, + fetchFromGitHub, + go, + nixosTests, }: buildGoModule rec { @@ -22,8 +23,12 @@ buildGoModule rec { subPackages = [ "cmd/trickster" ]; ldflags = - [ "-extldflags '-static'" "-s" "-w" ] ++ - (lib.mapAttrsToList (n: v: "-X main.application${n}=${v}") { + [ + "-extldflags '-static'" + "-s" + "-w" + ] + ++ (lib.mapAttrsToList (n: v: "-X main.application${n}=${v}") { BuildTime = "1970-01-01T00:00:00+0000"; GitCommitID = rev; GoVersion = "go${go.version}}"; diff --git a/pkgs/servers/unpackerr/default.nix b/pkgs/servers/unpackerr/default.nix index 30091834a8567c..0e01767fa2ba71 100644 --- a/pkgs/servers/unpackerr/default.nix +++ b/pkgs/servers/unpackerr/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, buildGoModule, Cocoa, WebKit }: +{ + lib, + stdenv, + fetchFromGitHub, + buildGoModule, + Cocoa, + WebKit, +}: buildGoModule rec { pname = "unpackerr"; @@ -13,9 +20,16 @@ buildGoModule rec { vendorHash = "sha256-wWIw0gNn5tqRq0udzPy/n2OkiIVESpSotOSn2YlBNS4="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa WebKit ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + WebKit + ]; - ldflags = [ "-s" "-w" "-X golift.io/version.Version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X golift.io/version.Version=${version}" + ]; meta = with lib; { description = "Extracts downloads for Radarr, Sonarr, Lidarr - Deletes extracted files after import"; diff --git a/pkgs/servers/unstructured-api/default.nix b/pkgs/servers/unstructured-api/default.nix index 759096ea1b555a..2e15a83250469d 100644 --- a/pkgs/servers/unstructured-api/default.nix +++ b/pkgs/servers/unstructured-api/default.nix @@ -9,25 +9,34 @@ nltk-data, }: let - pythonEnv = python3.withPackages (packages: with packages; [ - unstructured-api-tools - unstructured - pydantic - click - ratelimit - requests - pypdf - pycryptodome - safetensors - uvicorn - ] ++ packages.unstructured.optional-dependencies.local-inference); + pythonEnv = python3.withPackages ( + packages: + with packages; + [ + unstructured-api-tools + unstructured + pydantic + click + ratelimit + requests + pypdf + pycryptodome + safetensors + uvicorn + ] + ++ packages.unstructured.optional-dependencies.local-inference + ); version = "0.0.61"; unstructured_api_nltk_data = symlinkJoin { name = "unstructured_api_nltk_data"; - paths = [ nltk-data.punkt nltk-data.averaged_perceptron_tagger ]; + paths = [ + nltk-data.punkt + nltk-data.averaged_perceptron_tagger + ]; }; -in stdenvNoCC.mkDerivation { +in +stdenvNoCC.mkDerivation { pname = "unstructured-api"; inherit version; diff --git a/pkgs/servers/varnish/default.nix b/pkgs/servers/varnish/default.nix index 23cd855cf715c4..d1d67d74b1532e 100644 --- a/pkgs/servers/varnish/default.nix +++ b/pkgs/servers/varnish/default.nix @@ -1,8 +1,30 @@ -{ lib, stdenv, fetchurl, pcre, pcre2, jemalloc, libunwind, libxslt, groff, ncurses, pkg-config, readline, libedit -, coreutils, python3, makeWrapper, nixosTests }: +{ + lib, + stdenv, + fetchurl, + pcre, + pcre2, + jemalloc, + libunwind, + libxslt, + groff, + ncurses, + pkg-config, + readline, + libedit, + coreutils, + python3, + makeWrapper, + nixosTests, +}: let - common = { version, hash, extraNativeBuildInputs ? [] }: + common = + { + version, + hash, + extraNativeBuildInputs ? [ ], + }: stdenv.mkDerivation rec { pname = "varnish"; inherit version; @@ -12,14 +34,25 @@ let inherit hash; }; - nativeBuildInputs = with python3.pkgs; [ pkg-config docutils sphinx makeWrapper]; - buildInputs = [ - libxslt groff ncurses readline libedit python3 - ] - ++ lib.optional (lib.versionOlder version "7") pcre - ++ lib.optional (lib.versionAtLeast version "7") pcre2 - ++ lib.optional stdenv.hostPlatform.isDarwin libunwind - ++ lib.optional stdenv.hostPlatform.isLinux jemalloc; + nativeBuildInputs = with python3.pkgs; [ + pkg-config + docutils + sphinx + makeWrapper + ]; + buildInputs = + [ + libxslt + groff + ncurses + readline + libedit + python3 + ] + ++ lib.optional (lib.versionOlder version "7") pcre + ++ lib.optional (lib.versionAtLeast version "7") pcre2 + ++ lib.optional stdenv.hostPlatform.isDarwin libunwind + ++ lib.optional stdenv.hostPlatform.isLinux jemalloc; buildFlags = [ "localstatedir=/var/spool" ]; @@ -34,11 +67,16 @@ let # https://github.com/varnishcache/varnish-cache/issues/1875 env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.hostPlatform.isi686 "-fexcess-precision=standard"; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; passthru = { python = python3; - tests = nixosTests."varnish${builtins.replaceStrings [ "." ] [ "" ] (lib.versions.majorMinor version)}"; + tests = + nixosTests."varnish${builtins.replaceStrings [ "." ] [ "" ] (lib.versions.majorMinor version)}"; }; meta = with lib; { diff --git a/pkgs/servers/varnish/digest.nix b/pkgs/servers/varnish/digest.nix index c3bac64ef85146..763e534a56976b 100644 --- a/pkgs/servers/varnish/digest.nix +++ b/pkgs/servers/varnish/digest.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, varnish, libmhash, docutils, coreutils, version, sha256 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + varnish, + libmhash, + docutils, + coreutils, + version, + sha256, +}: stdenv.mkDerivation rec { pname = "${varnish.name}-digest"; @@ -11,8 +23,15 @@ stdenv.mkDerivation rec { inherit sha256; }; - nativeBuildInputs = [ autoreconfHook pkg-config docutils ]; - buildInputs = [ varnish libmhash ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + docutils + ]; + buildInputs = [ + varnish + libmhash + ]; postPatch = '' substituteInPlace autogen.sh --replace "''${dataroot}/aclocal" "${varnish.dev}/share/aclocal" diff --git a/pkgs/servers/varnish/dynamic.nix b/pkgs/servers/varnish/dynamic.nix index 78fd4d10641292..da1df5fc50a69c 100644 --- a/pkgs/servers/varnish/dynamic.nix +++ b/pkgs/servers/varnish/dynamic.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook269, pkg-config, varnish, docutils, version, sha256 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook269, + pkg-config, + varnish, + docutils, + version, + sha256, +}: stdenv.mkDerivation { pname = "${varnish.name}-dynamic"; @@ -11,7 +21,12 @@ stdenv.mkDerivation { inherit sha256; }; - nativeBuildInputs = [ pkg-config docutils autoreconfHook269 varnish.python ]; + nativeBuildInputs = [ + pkg-config + docutils + autoreconfHook269 + varnish.python + ]; buildInputs = [ varnish ]; postPatch = '' substituteInPlace Makefile.am --replace "''${LIBVARNISHAPI_DATAROOTDIR}/aclocal" "${varnish.dev}/share/aclocal" diff --git a/pkgs/servers/varnish/modules.nix b/pkgs/servers/varnish/modules.nix index 8e6db1b7a28e7e..225d5c5e9f42ee 100644 --- a/pkgs/servers/varnish/modules.nix +++ b/pkgs/servers/varnish/modules.nix @@ -1,6 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, varnish, docutils, removeReferencesTo }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + varnish, + docutils, + removeReferencesTo, +}: let - common = { version, hash, extraNativeBuildInputs ? [] }: + common = + { + version, + hash, + extraNativeBuildInputs ? [ ], + }: stdenv.mkDerivation rec { pname = "${varnish.name}-modules"; inherit version; @@ -17,7 +31,7 @@ let docutils pkg-config removeReferencesTo - varnish.python # use same python version as varnish server + varnish.python # use same python version as varnish server ]; buildInputs = [ varnish ]; diff --git a/pkgs/servers/varnish/packages.nix b/pkgs/servers/varnish/packages.nix index 2396b4b3de9ae2..f5d72f8226da14 100644 --- a/pkgs/servers/varnish/packages.nix +++ b/pkgs/servers/varnish/packages.nix @@ -1,13 +1,19 @@ -{ callPackages, callPackage, varnish60, varnish75 }: { +{ + callPackages, + callPackage, + varnish60, + varnish75, +}: +{ varnish60Packages = rec { varnish = varnish60; modules = (callPackages ./modules.nix { inherit varnish; }).modules15; - digest = callPackage ./digest.nix { + digest = callPackage ./digest.nix { inherit varnish; version = "libvmod-digest-1.0.2"; sha256 = "0jwkqqalydn0pwfdhirl5zjhbc3hldvhh09hxrahibr72fgmgpbx"; }; - dynamic = callPackage ./dynamic.nix { + dynamic = callPackage ./dynamic.nix { inherit varnish; version = "0.4"; sha256 = "1n94slrm6vn3hpymfkla03gw9603jajclg84bjhwb8kxsk3rxpmk"; diff --git a/pkgs/servers/web-apps/bookstack/composer-env.nix b/pkgs/servers/web-apps/bookstack/composer-env.nix index 71714b76400821..b050628e8d1b4d 100644 --- a/pkgs/servers/web-apps/bookstack/composer-env.nix +++ b/pkgs/servers/web-apps/bookstack/composer-env.nix @@ -1,14 +1,28 @@ # This file originates from composer2nix -{ stdenv, lib, writeTextFile, fetchurl, php, unzip, phpPackages }: +{ + stdenv, + lib, + writeTextFile, + fetchurl, + php, + unzip, + phpPackages, +}: let inherit (phpPackages) composer; - filterSrc = src: - builtins.filterSource (path: type: type != "directory" || (baseNameOf path != ".git" && baseNameOf path != ".git" && baseNameOf path != ".svn")) src; + filterSrc = + src: + builtins.filterSource ( + path: type: + type != "directory" + || (baseNameOf path != ".git" && baseNameOf path != ".git" && baseNameOf path != ".svn") + ) src; - buildZipPackage = { name, src }: + buildZipPackage = + { name, src }: stdenv.mkDerivation { inherit name src; nativeBuildInputs = [ unzip ]; @@ -23,20 +37,22 @@ let }; buildPackage = - { name - , src - , packages ? {} - , devPackages ? {} - , buildInputs ? [] - , symlinkDependencies ? false - , executable ? false - , removeComposerArtifacts ? false - , postInstall ? "" - , noDev ? false - , composerExtraArgs ? "" - , unpackPhase ? "true" - , buildPhase ? "true" - , ...}@args: + { + name, + src, + packages ? { }, + devPackages ? { }, + buildInputs ? [ ], + symlinkDependencies ? false, + executable ? false, + removeComposerArtifacts ? false, + postInstall ? "", + noDev ? false, + composerExtraArgs ? "", + unpackPhase ? "true", + buildPhase ? "true", + ... + }@args: let reconstructInstalled = writeTextFile { @@ -113,128 +129,153 @@ let ''; }; - bundleDependencies = dependencies: - lib.concatMapStrings (dependencyName: + bundleDependencies = + dependencies: + lib.concatMapStrings ( + dependencyName: let dependency = dependencies.${dependencyName}; in '' - ${if dependency.targetDir == "" then '' - vendorDir="$(dirname ${dependencyName})" - mkdir -p "$vendorDir" - ${if symlinkDependencies then - ''ln -s "${dependency.src}" "$vendorDir/$(basename "${dependencyName}")"'' - else - ''cp -av "${dependency.src}" "$vendorDir/$(basename "${dependencyName}")"'' - } - '' else '' - namespaceDir="${dependencyName}/$(dirname "${dependency.targetDir}")" - mkdir -p "$namespaceDir" - ${if symlinkDependencies then - ''ln -s "${dependency.src}" "$namespaceDir/$(basename "${dependency.targetDir}")"'' + ${ + if dependency.targetDir == "" then + '' + vendorDir="$(dirname ${dependencyName})" + mkdir -p "$vendorDir" + ${ + if symlinkDependencies then + ''ln -s "${dependency.src}" "$vendorDir/$(basename "${dependencyName}")"'' + else + ''cp -av "${dependency.src}" "$vendorDir/$(basename "${dependencyName}")"'' + } + '' else - ''cp -av "${dependency.src}" "$namespaceDir/$(basename "${dependency.targetDir}")"'' - } - ''} - '') (builtins.attrNames dependencies); + '' + namespaceDir="${dependencyName}/$(dirname "${dependency.targetDir}")" + mkdir -p "$namespaceDir" + ${ + if symlinkDependencies then + ''ln -s "${dependency.src}" "$namespaceDir/$(basename "${dependency.targetDir}")"'' + else + ''cp -av "${dependency.src}" "$namespaceDir/$(basename "${dependency.targetDir}")"'' + } + '' + } + '' + ) (builtins.attrNames dependencies); - extraArgs = removeAttrs args [ "packages" "devPackages" "buildInputs" ]; + extraArgs = removeAttrs args [ + "packages" + "devPackages" + "buildInputs" + ]; in - stdenv.mkDerivation ({ - buildInputs = [ php composer ] ++ buildInputs; - - inherit unpackPhase buildPhase; - - installPhase = '' - ${if executable then '' - mkdir -p $out/share/php - cp -av $src $out/share/php/$name - chmod -R u+w $out/share/php/$name - cd $out/share/php/$name - '' else '' - cp -av $src $out - chmod -R u+w $out - cd $out - ''} - - # Remove unwanted files - rm -f *.nix - - export HOME=$TMPDIR - - # Remove the provided vendor folder if it exists - rm -Rf vendor - - # If there is no composer.lock file, compose a dummy file. - # Otherwise, composer attempts to download the package.json file from - # the registry which we do not want. - if [ ! -f composer.lock ] - then - cat > composer.lock < vendor/composer/installed.json - - # Copy or symlink the provided dependencies - cd vendor - ${bundleDependencies packages} - ${lib.optionalString (!noDev) (bundleDependencies devPackages)} - cd .. - - # Reconstruct autoload scripts - # We use the optimize feature because Nix packages cannot change after they have been built - # Using the dynamic loader for a Nix package is useless since there is nothing to dynamically reload. - composer dump-autoload --optimize ${lib.optionalString noDev "--no-dev"} ${composerExtraArgs} - - # Run the install step as a validation to confirm that everything works out as expected - composer install --optimize-autoloader ${lib.optionalString noDev "--no-dev"} ${composerExtraArgs} - - ${lib.optionalString executable '' - # Reconstruct the bin/ folder if we deploy an executable project - ${php}/bin/php ${constructBin} composer.json - ln -s $(pwd)/vendor/bin $out/bin - ''} - - ${lib.optionalString (!symlinkDependencies) '' - # Patch the shebangs if possible - if [ -d $(pwd)/vendor/bin ] + stdenv.mkDerivation ( + { + buildInputs = [ + php + composer + ] ++ buildInputs; + + inherit unpackPhase buildPhase; + + installPhase = '' + ${ + if executable then + '' + mkdir -p $out/share/php + cp -av $src $out/share/php/$name + chmod -R u+w $out/share/php/$name + cd $out/share/php/$name + '' + else + '' + cp -av $src $out + chmod -R u+w $out + cd $out + '' + } + + # Remove unwanted files + rm -f *.nix + + export HOME=$TMPDIR + + # Remove the provided vendor folder if it exists + rm -Rf vendor + + # If there is no composer.lock file, compose a dummy file. + # Otherwise, composer attempts to download the package.json file from + # the registry which we do not want. + if [ ! -f composer.lock ] + then + cat > composer.lock < vendor/composer/installed.json + + # Copy or symlink the provided dependencies + cd vendor + ${bundleDependencies packages} + ${lib.optionalString (!noDev) (bundleDependencies devPackages)} + cd .. + + # Reconstruct autoload scripts + # We use the optimize feature because Nix packages cannot change after they have been built + # Using the dynamic loader for a Nix package is useless since there is nothing to dynamically reload. + composer dump-autoload --optimize ${lib.optionalString noDev "--no-dev"} ${composerExtraArgs} + + # Run the install step as a validation to confirm that everything works out as expected + composer install --optimize-autoloader ${lib.optionalString noDev "--no-dev"} ${composerExtraArgs} + + ${lib.optionalString executable '' + # Reconstruct the bin/ folder if we deploy an executable project + ${php}/bin/php ${constructBin} composer.json + ln -s $(pwd)/vendor/bin $out/bin + ''} + + ${lib.optionalString (!symlinkDependencies) '' + # Patch the shebangs if possible + if [ -d $(pwd)/vendor/bin ] + then + # Look for all executables in bin/ + for i in $(pwd)/vendor/bin/* + do + # Look for their location + realFile=$(readlink -f "$i") + + # Restore write permissions + chmod u+wx "$(dirname "$realFile")" + chmod u+w "$realFile" + + # Patch shebang + sed -e "s|#!/usr/bin/php|#!${php}/bin/php|" \ + -e "s|#!/usr/bin/env php|#!${php}/bin/php|" \ + "$realFile" > tmp + mv tmp "$realFile" + chmod u+x "$realFile" + done + fi + ''} + + if [ "$removeComposerArtifacts" = "1" ] then - # Look for all executables in bin/ - for i in $(pwd)/vendor/bin/* - do - # Look for their location - realFile=$(readlink -f "$i") - - # Restore write permissions - chmod u+wx "$(dirname "$realFile")" - chmod u+w "$realFile" - - # Patch shebang - sed -e "s|#!/usr/bin/php|#!${php}/bin/php|" \ - -e "s|#!/usr/bin/env php|#!${php}/bin/php|" \ - "$realFile" > tmp - mv tmp "$realFile" - chmod u+x "$realFile" - done + # Remove composer stuff + rm -f composer.json composer.lock fi - ''} - - if [ "$removeComposerArtifacts" = "1" ] - then - # Remove composer stuff - rm -f composer.json composer.lock - fi - - # Execute post install hook - runHook postInstall - ''; - } // extraArgs); + + # Execute post install hook + runHook postInstall + ''; + } + // extraArgs + ); in { inherit filterSrc; diff --git a/pkgs/servers/web-apps/bookstack/composition.nix b/pkgs/servers/web-apps/bookstack/composition.nix index d8df4b81fa3e4a..938847416b5d0a 100644 --- a/pkgs/servers/web-apps/bookstack/composition.nix +++ b/pkgs/servers/web-apps/bookstack/composition.nix @@ -1,15 +1,31 @@ -{pkgs ? import { +{ + pkgs ? import { inherit system; - }, system ? builtins.currentSystem, noDev ? false, php ? pkgs.php, phpPackages ? pkgs.phpPackages}: + }, + system ? builtins.currentSystem, + noDev ? false, + php ? pkgs.php, + phpPackages ? pkgs.phpPackages, +}: let composerEnv = import ./composer-env.nix { - inherit (pkgs) stdenv lib writeTextFile fetchurl unzip; + inherit (pkgs) + stdenv + lib + writeTextFile + fetchurl + unzip + ; inherit php phpPackages; }; in import ./php-packages.nix { inherit composerEnv noDev; - inherit (pkgs) fetchurl fetchgit fetchhg fetchsvn; + inherit (pkgs) + fetchurl + fetchgit + fetchhg + fetchsvn + ; } - diff --git a/pkgs/servers/web-apps/bookstack/default.nix b/pkgs/servers/web-apps/bookstack/default.nix index f8e4be274be4b5..46a4e1e0b564b3 100644 --- a/pkgs/servers/web-apps/bookstack/default.nix +++ b/pkgs/servers/web-apps/bookstack/default.nix @@ -1,20 +1,31 @@ -{ pkgs, stdenv, lib, fetchFromGitHub, dataDir ? "/var/lib/bookstack" }: +{ + pkgs, + stdenv, + lib, + fetchFromGitHub, + dataDir ? "/var/lib/bookstack", +}: let - package = (import ./composition.nix { - inherit pkgs; - inherit (stdenv.hostPlatform) system; - noDev = true; # Disable development dependencies - }).overrideAttrs (attrs : { - installPhase = attrs.installPhase + '' - rm -R $out/storage $out/public/uploads - ln -s ${dataDir}/.env $out/.env - ln -s ${dataDir}/storage $out/storage - ln -s ${dataDir}/public/uploads $out/public/uploads - ''; - }); + package = + (import ./composition.nix { + inherit pkgs; + inherit (stdenv.hostPlatform) system; + noDev = true; # Disable development dependencies + }).overrideAttrs + (attrs: { + installPhase = + attrs.installPhase + + '' + rm -R $out/storage $out/public/uploads + ln -s ${dataDir}/.env $out/.env + ln -s ${dataDir}/storage $out/storage + ln -s ${dataDir}/public/uploads $out/public/uploads + ''; + }); -in package.override rec { +in +package.override rec { pname = "bookstack"; version = "24.05.4"; diff --git a/pkgs/servers/web-apps/bookstack/php-packages.nix b/pkgs/servers/web-apps/bookstack/php-packages.nix index 423fd28c8736e8..97bf21609d6560 100644 --- a/pkgs/servers/web-apps/bookstack/php-packages.nix +++ b/pkgs/servers/web-apps/bookstack/php-packages.nix @@ -1,4 +1,11 @@ -{composerEnv, fetchurl, fetchgit ? null, fetchhg ? null, fetchsvn ? null, noDev ? false}: +{ + composerEnv, + fetchurl, + fetchgit ? null, + fetchhg ? null, + fetchsvn ? null, + noDev ? false, +}: let packages = { @@ -1113,7 +1120,7 @@ let }; }; }; - devPackages = {}; + devPackages = { }; in composerEnv.buildPackage { inherit packages devPackages noDev; @@ -1125,4 +1132,3 @@ composerEnv.buildPackage { license = "MIT"; }; } - diff --git a/pkgs/servers/web-apps/discourse/default.nix b/pkgs/servers/web-apps/discourse/default.nix index 1f702d13502b96..9b0e635d9ba860 100644 --- a/pkgs/servers/web-apps/discourse/default.nix +++ b/pkgs/servers/web-apps/discourse/default.nix @@ -1,49 +1,50 @@ -{ stdenv -, pkgs -, makeWrapper -, runCommand -, lib -, writeShellScript -, fetchFromGitHub -, bundlerEnv -, callPackage - -, ruby_3_2 -, replace -, gzip -, gnutar -, git -, cacert -, util-linux -, gawk -, nettools -, imagemagick -, optipng -, pngquant -, libjpeg -, jpegoptim -, gifsicle -, jhead -, oxipng -, libpsl -, redis -, postgresql -, which -, brotli -, procps -, rsync -, icu -, fetchYarnDeps -, yarn -, fixup-yarn-lock -, nodePackages -, nodejs_18 -, jq -, moreutils -, terser -, uglify-js - -, plugins ? [] +{ + stdenv, + pkgs, + makeWrapper, + runCommand, + lib, + writeShellScript, + fetchFromGitHub, + bundlerEnv, + callPackage, + + ruby_3_2, + replace, + gzip, + gnutar, + git, + cacert, + util-linux, + gawk, + nettools, + imagemagick, + optipng, + pngquant, + libjpeg, + jpegoptim, + gifsicle, + jhead, + oxipng, + libpsl, + redis, + postgresql, + which, + brotli, + procps, + rsync, + icu, + fetchYarnDeps, + yarn, + fixup-yarn-lock, + nodePackages, + nodejs_18, + jq, + moreutils, + terser, + uglify-js, + + plugins ? [ ], }@args: let @@ -70,10 +71,10 @@ let # Misc required system utils which - procps # For ps and kill - util-linux # For renice + procps # For ps and kill + util-linux # For renice gawk - nettools # For hostname + nettools # For hostname # Image optimization imagemagick @@ -94,54 +95,77 @@ let }; mkDiscoursePlugin = - { name ? null - , pname ? null - , version ? null - , meta ? null - , bundlerEnvArgs ? {} - , preserveGemsDir ? false - , src - , ... + { + name ? null, + pname ? null, + version ? null, + meta ? null, + bundlerEnvArgs ? { }, + preserveGemsDir ? false, + src, + ... }@args: let - rubyEnv = bundlerEnv (bundlerEnvArgs // { - inherit name pname version ruby; - }); + rubyEnv = bundlerEnv ( + bundlerEnvArgs + // { + inherit + name + pname + version + ruby + ; + } + ); in - stdenv.mkDerivation (builtins.removeAttrs args [ "bundlerEnvArgs" ] // { + stdenv.mkDerivation ( + builtins.removeAttrs args [ "bundlerEnvArgs" ] + // { pluginName = if name != null then name else "${pname}-${version}"; dontConfigure = true; dontBuild = true; - installPhase = '' - runHook preInstall - mkdir -p $out - cp -r * $out/ - '' + lib.optionalString (bundlerEnvArgs != {}) ( - if preserveGemsDir then '' - cp -r ${rubyEnv}/lib/ruby/gems/* $out/gems/ + installPhase = '' - else '' - if [[ -e $out/gems ]]; then - echo "Warning: The repo contains a 'gems' directory which will be removed!" - echo " If you need to preserve it, set 'preserveGemsDir = true'." - rm -r $out/gems - fi - ln -sf ${rubyEnv}/lib/ruby/gems $out/gems - '' + '' - runHook postInstall - ''); - }); - - rake = runCommand "discourse-rake" { - nativeBuildInputs = [ makeWrapper ]; - } '' - mkdir -p $out/bin - makeWrapper ${rubyEnv}/bin/rake $out/bin/discourse-rake \ - ${lib.concatStrings (lib.mapAttrsToList (name: value: "--set ${name} '${value}' ") runtimeEnv)} \ - --prefix PATH : ${lib.makeBinPath runtimeDeps} \ - --set RAKEOPT '-f ${discourse}/share/discourse/Rakefile' \ - --chdir '${discourse}/share/discourse' - ''; + runHook preInstall + mkdir -p $out + cp -r * $out/ + '' + + lib.optionalString (bundlerEnvArgs != { }) ( + if preserveGemsDir then + '' + cp -r ${rubyEnv}/lib/ruby/gems/* $out/gems/ + '' + else + '' + if [[ -e $out/gems ]]; then + echo "Warning: The repo contains a 'gems' directory which will be removed!" + echo " If you need to preserve it, set 'preserveGemsDir = true'." + rm -r $out/gems + fi + ln -sf ${rubyEnv}/lib/ruby/gems $out/gems + '' + + '' + runHook postInstall + '' + ); + } + ); + + rake = + runCommand "discourse-rake" + { + nativeBuildInputs = [ makeWrapper ]; + } + '' + mkdir -p $out/bin + makeWrapper ${rubyEnv}/bin/rake $out/bin/discourse-rake \ + ${ + lib.concatStrings (lib.mapAttrsToList (name: value: "--set ${name} '${value}' ") runtimeEnv) + } \ + --prefix PATH : ${lib.makeBinPath runtimeDeps} \ + --set RAKEOPT '-f ${discourse}/share/discourse/Rakefile' \ + --chdir '${discourse}/share/discourse' + ''; rubyEnv = bundlerEnv { name = "discourse-ruby-env-${version}"; @@ -151,50 +175,56 @@ let let gems = import ./rubyEnv/gemset.nix; in - gems // { - mini_racer = gems.mini_racer // { - buildInputs = [ icu ]; - dontBuild = false; - NIX_LDFLAGS = "-licui18n"; - }; - libv8-node = - let - noopScript = writeShellScript "noop" "exit 0"; - linkFiles = writeShellScript "link-files" '' - cd ../.. - - mkdir -p vendor/v8/${stdenv.hostPlatform.system}/libv8/obj/ - ln -s "${nodejs_18.libv8}/lib/libv8.a" vendor/v8/${stdenv.hostPlatform.system}/libv8/obj/libv8_monolith.a - - ln -s ${nodejs_18.libv8}/include vendor/v8/include - - mkdir -p ext/libv8-node - echo '--- !ruby/object:Libv8::Node::Location::Vendor {}' >ext/libv8-node/.location.yml - ''; - in gems.libv8-node // { - dontBuild = false; - postPatch = '' - cp ${noopScript} libexec/build-libv8 - cp ${noopScript} libexec/build-monolith - cp ${noopScript} libexec/download-node - cp ${noopScript} libexec/extract-node - cp ${linkFiles} libexec/inject-libv8 - ''; - }; - mini_suffix = gems.mini_suffix // { - propagatedBuildInputs = [ libpsl ]; + gems + // { + mini_racer = gems.mini_racer // { + buildInputs = [ icu ]; + dontBuild = false; + NIX_LDFLAGS = "-licui18n"; + }; + libv8-node = + let + noopScript = writeShellScript "noop" "exit 0"; + linkFiles = writeShellScript "link-files" '' + cd ../.. + + mkdir -p vendor/v8/${stdenv.hostPlatform.system}/libv8/obj/ + ln -s "${nodejs_18.libv8}/lib/libv8.a" vendor/v8/${stdenv.hostPlatform.system}/libv8/obj/libv8_monolith.a + + ln -s ${nodejs_18.libv8}/include vendor/v8/include + + mkdir -p ext/libv8-node + echo '--- !ruby/object:Libv8::Node::Location::Vendor {}' >ext/libv8-node/.location.yml + ''; + in + gems.libv8-node + // { dontBuild = false; - # Use our libpsl instead of the vendored one, which isn't - # available for aarch64. It has to be called - # libpsl.x86_64.so or it isn't found. postPatch = '' - cp $(readlink -f ${lib.getLib libpsl}/lib/libpsl.so) vendor/libpsl.x86_64.so + cp ${noopScript} libexec/build-libv8 + cp ${noopScript} libexec/build-monolith + cp ${noopScript} libexec/download-node + cp ${noopScript} libexec/extract-node + cp ${linkFiles} libexec/inject-libv8 ''; }; + mini_suffix = gems.mini_suffix // { + propagatedBuildInputs = [ libpsl ]; + dontBuild = false; + # Use our libpsl instead of the vendored one, which isn't + # available for aarch64. It has to be called + # libpsl.x86_64.so or it isn't found. + postPatch = '' + cp $(readlink -f ${lib.getLib libpsl}/lib/libpsl.so) vendor/libpsl.x86_64.so + ''; }; + }; groups = [ - "default" "assets" "development" "test" + "default" + "assets" + "development" + "test" ]; }; @@ -218,7 +248,11 @@ let fixup-yarn-lock ]; - outputs = [ "out" "javascripts" "node_modules" ]; + outputs = [ + "out" + "javascripts" + "node_modules" + ]; patches = [ # Use the Ruby API version in the plugin gem path, to match the @@ -324,7 +358,9 @@ let inherit version src; buildInputs = [ - rubyEnv rubyEnv.wrappedRuby rubyEnv.bundler + rubyEnv + rubyEnv.wrappedRuby + rubyEnv.bundler ]; patches = [ @@ -395,7 +431,9 @@ let ln -sf ${assets} $out/share/discourse/public.dist/assets rm -r $out/share/discourse/app/assets/javascripts ln -sf ${assets.javascripts} $out/share/discourse/app/assets/javascripts - ${lib.concatMapStringsSep "\n" (p: "ln -sf ${p} $out/share/discourse/plugins/${p.pluginName or ""}") plugins} + ${lib.concatMapStringsSep "\n" ( + p: "ln -sf ${p} $out/share/discourse/plugins/${p.pluginName or ""}" + ) plugins} runHook postInstall ''; @@ -409,10 +447,17 @@ let }; passthru = { - inherit rubyEnv runtimeEnv runtimeDeps rake mkDiscoursePlugin assets; + inherit + rubyEnv + runtimeEnv + runtimeDeps + rake + mkDiscoursePlugin + assets + ; inherit (pkgs) discourseAllPlugins - ; + ; enabledPlugins = plugins; plugins = callPackage ./plugins/all-plugins.nix { inherit mkDiscoursePlugin; }; ruby = rubyEnv.wrappedRuby; @@ -423,4 +468,5 @@ let }; }; }; -in discourse +in +discourse diff --git a/pkgs/servers/web-apps/discourse/plugins/all-plugins.nix b/pkgs/servers/web-apps/discourse/plugins/all-plugins.nix index 5845f16b2d27c2..864bdb978d4f53 100644 --- a/pkgs/servers/web-apps/discourse/plugins/all-plugins.nix +++ b/pkgs/servers/web-apps/discourse/plugins/all-plugins.nix @@ -3,25 +3,25 @@ let callPackage = newScope args; in { - discourse-assign = callPackage ./discourse-assign {}; - discourse-bbcode-color = callPackage ./discourse-bbcode-color {}; - discourse-calendar = callPackage ./discourse-calendar {}; - discourse-canned-replies = callPackage ./discourse-canned-replies {}; - discourse-chat-integration = callPackage ./discourse-chat-integration {}; - discourse-checklist = callPackage ./discourse-checklist {}; - discourse-data-explorer = callPackage ./discourse-data-explorer {}; - discourse-docs = callPackage ./discourse-docs {}; - discourse-github = callPackage ./discourse-github {}; - discourse-ldap-auth = callPackage ./discourse-ldap-auth {}; - discourse-math = callPackage ./discourse-math {}; - discourse-migratepassword = callPackage ./discourse-migratepassword {}; - discourse-oauth2-basic = callPackage ./discourse-oauth2-basic {}; - discourse-openid-connect = callPackage ./discourse-openid-connect {}; - discourse-prometheus = callPackage ./discourse-prometheus {}; - discourse-reactions = callPackage ./discourse-reactions {}; - discourse-saved-searches = callPackage ./discourse-saved-searches {}; - discourse-solved = callPackage ./discourse-solved {}; - discourse-spoiler-alert = callPackage ./discourse-spoiler-alert {}; - discourse-voting = callPackage ./discourse-voting {}; - discourse-yearly-review = callPackage ./discourse-yearly-review {}; + discourse-assign = callPackage ./discourse-assign { }; + discourse-bbcode-color = callPackage ./discourse-bbcode-color { }; + discourse-calendar = callPackage ./discourse-calendar { }; + discourse-canned-replies = callPackage ./discourse-canned-replies { }; + discourse-chat-integration = callPackage ./discourse-chat-integration { }; + discourse-checklist = callPackage ./discourse-checklist { }; + discourse-data-explorer = callPackage ./discourse-data-explorer { }; + discourse-docs = callPackage ./discourse-docs { }; + discourse-github = callPackage ./discourse-github { }; + discourse-ldap-auth = callPackage ./discourse-ldap-auth { }; + discourse-math = callPackage ./discourse-math { }; + discourse-migratepassword = callPackage ./discourse-migratepassword { }; + discourse-oauth2-basic = callPackage ./discourse-oauth2-basic { }; + discourse-openid-connect = callPackage ./discourse-openid-connect { }; + discourse-prometheus = callPackage ./discourse-prometheus { }; + discourse-reactions = callPackage ./discourse-reactions { }; + discourse-saved-searches = callPackage ./discourse-saved-searches { }; + discourse-solved = callPackage ./discourse-solved { }; + discourse-spoiler-alert = callPackage ./discourse-spoiler-alert { }; + discourse-voting = callPackage ./discourse-voting { }; + discourse-yearly-review = callPackage ./discourse-yearly-review { }; } diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-assign/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-assign/default.nix index 289ed1b6599b97..e90a8e49485681 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-assign/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-assign/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-assign"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-bbcode-color/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-bbcode-color/default.nix index 9dc50e51db03de..b07422f3a58b11 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-bbcode-color/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-bbcode-color/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-bbcode-color"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-calendar/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-calendar/default.nix index 00f447b49c7b85..4c162508575e08 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-calendar/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-calendar/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-calendar"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-calendar/gemset.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-calendar/gemset.nix index 51922b163d4b50..8fdcbcd0fa3556 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-calendar/gemset.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-calendar/gemset.nix @@ -1,113 +1,123 @@ { activesupport = { - dependencies = ["base64" "bigdecimal" "concurrent-ruby" "connection_pool" "drb" "i18n" "minitest" "mutex_m" "tzinfo"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "base64" + "bigdecimal" + "concurrent-ruby" + "connection_pool" + "drb" + "i18n" + "minitest" + "mutex_m" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0z8kygxmz99krz9pwp947znkzf0jr64sml28df0vf1gzxlg7y57i"; type = "gem"; }; version = "7.1.3.3"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qh1b14jwbbj242klkyz5fc7npd4j0mvndz62gajhvl1l3wd7zc2"; type = "gem"; }; version = "1.2.3"; }; connection_pool = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; drb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h5kbj9hvg5hb3c7l425zpds0vb42phvln2knab8nmazg2zp5m79"; type = "gem"; }; version = "2.2.1"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ffix518y7976qih9k1lgnc17i3v6yrlh0a3mckpxdb4wc2vrp16"; type = "gem"; }; version = "1.14.5"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gkslxvkhh44s21rbjvka3zsvfxxrf5pcl6f75rv2vyrzzbgis7i"; type = "gem"; }; version = "5.23.1"; }; mutex_m = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ma093ayps1m92q845hmpk0dmadicvifkbf05rpq9pifhin0rvxn"; type = "gem"; }; version = "0.2.0"; }; rrule = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04h3q0ws0wswqj3mwjyv44yx59d9ima9a820ay9w5bwnlb73syj2"; type = "gem"; }; version = "0.4.4"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-canned-replies/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-canned-replies/default.nix index d5628fed4003fe..b6f6c113ea248f 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-canned-replies/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-canned-replies/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-canned-replies"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-chat-integration/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-chat-integration/default.nix index e5413340c1dae1..75c022b66250b2 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-chat-integration/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-chat-integration/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-chat-integration"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-checklist/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-checklist/default.nix index a44c9771cd01a9..d9934bc3d8729f 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-checklist/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-checklist/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-checklist"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-data-explorer/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-data-explorer/default.nix index 38c9507e1dc560..51e565b143e3c1 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-data-explorer/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-data-explorer/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-data-explorer"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-docs/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-docs/default.nix index 7da74adeda00ea..b87cf87d990f0a 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-docs/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-docs/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-docs"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-github/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-github/default.nix index b7f3d247277607..8809625fd6dfec 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-github/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-github/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-github"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-github/gemset.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-github/gemset.nix index bed6505c5fe0bd..b7faea9c8a6aa6 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-github/gemset.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-github/gemset.nix @@ -1,105 +1,115 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; faraday = { - dependencies = ["faraday-net_http" "json" "logger"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "faraday-net_http" + "json" + "logger" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05s5pyxh7y68jphb0lgrh0ksxbp4lmbsc6a6qg0ahj15pjqx01ni"; type = "gem"; }; version = "2.12.0"; }; faraday-net_http = { - dependencies = ["net-http"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-http" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rg54k4skaz8z7j358p6pdzc9pr84fjq7sdlpicf7s5ig7vb1rlk"; type = "gem"; }; version = "3.3.0"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1prbjd8r4rq6hjc6d5hn8hlpf4g9h62swxj7absjac7qqnzwrhvw"; type = "gem"; }; version = "2.7.3"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; net-http = { - dependencies = ["uri"]; - groups = ["default"]; - platforms = []; + dependencies = [ "uri" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10n2n9aq00ih8v881af88l1zyrqgs5cl3njdw8argjwbl5ggqvm9"; type = "gem"; }; version = "0.4.1"; }; octokit = { - dependencies = ["faraday" "sawyer"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "faraday" + "sawyer" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15g4kyag6gmxxq6d03472h7srm3imlsks1wg6nac7hl3mb1b5vs8"; type = "gem"; }; version = "5.6.1"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vqcw3iwby3yc6avs1vb3gfd0vcp2v7q310665dvxfswmcf4xm31"; type = "gem"; }; version = "6.0.1"; }; sawyer = { - dependencies = ["addressable" "faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "addressable" + "faraday" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jks1qjbmqm8f9kvwa81vqj39avaj9wdnzc531xm29a55bb74fps"; type = "gem"; }; version = "0.9.2"; }; uri = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07ndgxyhzd02cg94s6rnfhkb9rwx9z72lzk368sa9j78wc9qnbfz"; type = "gem"; }; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-ldap-auth/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-ldap-auth/default.nix index 04e0a735fc2bcd..52b7dbc093fe33 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-ldap-auth/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-ldap-auth/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-ldap-auth"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-ldap-auth/gemset.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-ldap-auth/gemset.nix index 9df3292f7b8234..97d9bac530d820 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-ldap-auth/gemset.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-ldap-auth/gemset.nix @@ -1,71 +1,79 @@ { hashie = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nh3arcrbz1rc1cr59qm53sdhqm137b258y8rcb4cvd3y98lwv4x"; type = "gem"; }; version = "5.0.0"; }; net-ldap = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ycw0qsw3hap8svakl0i30jkj0ffd4lpyrn17a1j0w8mz5ainmsj"; type = "gem"; }; version = "0.17.1"; }; omniauth = { - dependencies = ["hashie" "rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "hashie" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jn9j54l5h7xcba2vjq74l1dk0xrwvsjxam4qhylpi52nw0h5502"; type = "gem"; }; version = "1.9.2"; }; omniauth-ldap = { - dependencies = ["net-ldap" "omniauth" "pyu-ruby-sasl" "rubyntlm"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "net-ldap" + "omniauth" + "pyu-ruby-sasl" + "rubyntlm" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ld3mx46xa1qhc0cpnck1n06xcxs0ag4n41zgabxri27a772f9wz"; type = "gem"; }; version = "1.0.5"; }; pyu-ruby-sasl = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rcpjiz9lrvyb3rd8k8qni0v4ps08psympffyldmmnrqayyad0sn"; type = "gem"; }; version = "0.0.3.3"; }; rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w217k9z02c4hqizym8dkj6bqmmzx4qdvqpnskgzf174a5pwdxk"; type = "gem"; }; version = "2.2.7"; }; rubyntlm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18d1lxhx62swggf4cqg76h7hp04f5801c8h07w08cm9xng2niqby"; type = "gem"; }; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-math/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-math/default.nix index 58433a887e594e..9fec32d7f7493b 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-math/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-math/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-math"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-migratepassword/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-migratepassword/default.nix index d220f050e20a22..862e53fa44333b 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-migratepassword/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-migratepassword/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-migratepassword"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-migratepassword/gemset.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-migratepassword/gemset.nix index bff0d82479a3a0..d1c88454e8bcc0 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-migratepassword/gemset.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-migratepassword/gemset.nix @@ -1,61 +1,67 @@ { argon2 = { - dependencies = ["ffi" "ffi-compiler"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "ffi" + "ffi-compiler" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wdllcqlr81nzyf485ldv1p660xsi476p79ghbj7zsf3n9n86gwd"; type = "gem"; }; version = "2.2.0"; }; bcrypt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ai0m15jg3n0b22mimk09ppnga316dc7dyvz06w8rrqh5gy1lslp"; type = "gem"; }; version = "3.1.13"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; ffi-compiler = { - dependencies = ["ffi" "rake"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "ffi" + "rake" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0c2caqm9wqnbidcb8dj4wd3s902z15qmgxplwyfyqbwa0ydki7q1"; type = "gem"; }; version = "1.0.1"; }; rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17850wcwkgi30p7yqh60960ypn7yibacjjha0av78zaxwvd3ijs6"; type = "gem"; }; version = "13.2.1"; }; unix-crypt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wflipsmmicmgvqilp9pml4x19b337kh6p6jgrzqrzpkq2z52gdq"; type = "gem"; }; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-oauth2-basic/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-oauth2-basic/default.nix index b9fa198143917d..a938d6ea1ae678 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-oauth2-basic/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-oauth2-basic/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin rec { name = "discourse-oauth2-basic"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-oauth2-basic/gemset.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-oauth2-basic/gemset.nix index bbb35327787b2d..8bbea6576bf1ea 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-oauth2-basic/gemset.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-oauth2-basic/gemset.nix @@ -1,124 +1,169 @@ { ast = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04nc8x27hlzlrr5c2gn7mar4vdr0apw5xg22wp6m8dx3wqr04a0y"; type = "gem"; }; version = "2.4.2"; }; parallel = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07vnk6bb54k4yc06xnwck7php50l09vvlw1ga8wdz0pia461zpzb"; type = "gem"; }; version = "1.22.1"; }; parser = { - dependencies = ["ast"]; - groups = ["default" "development"]; - platforms = []; + dependencies = [ "ast" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zaghgvva2q4jqbachg8jvpwgbg3w1jqr0d00m8rqciqznjgsw3c"; type = "gem"; }; version = "3.1.1.0"; }; rainbow = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0smwg4mii0fm38pyb5fddbmrdpifwv22zv3d3px2xx497am93503"; type = "gem"; }; version = "3.1.1"; }; regexp_parser = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "155f6cr4rrfw5bs5xd3m5kfw32qhc5fsi4nk82rhif56rc6cs0wm"; type = "gem"; }; version = "2.2.1"; }; rexml = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08ximcyfjy94pm1rhcx04ny1vx2sk0x4y185gzn86yfsbzwkng53"; type = "gem"; }; version = "3.2.5"; }; rubocop = { - dependencies = ["parallel" "parser" "rainbow" "regexp_parser" "rexml" "rubocop-ast" "ruby-progressbar" "unicode-display_width"]; - groups = ["default" "development"]; - platforms = []; + dependencies = [ + "parallel" + "parser" + "rainbow" + "regexp_parser" + "rexml" + "rubocop-ast" + "ruby-progressbar" + "unicode-display_width" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06105yrqajpm5l07fng1nbk55y9490hny542zclnan8hg841pjgl"; type = "gem"; }; version = "1.26.1"; }; rubocop-ast = { - dependencies = ["parser"]; - groups = ["default" "development"]; - platforms = []; + dependencies = [ "parser" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bd2z82ly7fix8415gvfiwzb6bjialz5rs3sr72kv1lk68rd23wv"; type = "gem"; }; version = "1.16.0"; }; rubocop-discourse = { - dependencies = ["rubocop" "rubocop-rspec"]; - groups = ["development"]; - platforms = []; + dependencies = [ + "rubocop" + "rubocop-rspec" + ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01f4y7am9cq276zl8vsgv64w8wfmhpbzg7vzsifhgnnh92g6s04g"; type = "gem"; }; version = "2.5.0"; }; rubocop-rspec = { - dependencies = ["rubocop"]; - groups = ["default" "development"]; - platforms = []; + dependencies = [ "rubocop" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "051gq9pz49iv4gq34d3n089iaa6cb418n2fhin6gd6fpysbi3nf6"; type = "gem"; }; version = "2.9.0"; }; ruby-progressbar = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02nmaw7yx9kl7rbaan5pl8x5nn0y4j5954mzrkzi9i3dhsrps4nc"; type = "gem"; }; version = "1.11.0"; }; unicode-display_width = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0csjm9shhfik0ci9mgimb7hf3xgh7nx45rkd9rzgdz6vkwr8rzxn"; type = "gem"; }; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-openid-connect/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-openid-connect/default.nix index ac8d308b1fb86e..3a2c9e026a1f3c 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-openid-connect/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-openid-connect/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-openid-connect"; @@ -16,4 +20,3 @@ mkDiscoursePlugin { description = "Discourse plugin to integrate Discourse with an openid-connect login provider"; }; } - diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-openid-connect/gemset.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-openid-connect/gemset.nix index 2a546e7a1c87a4..37d643eb7d03cc 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-openid-connect/gemset.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-openid-connect/gemset.nix @@ -1,124 +1,169 @@ { ast = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l3468czzjmxl93ap40hp7z94yxp4nbag0bxqs789bm30md90m2a"; type = "gem"; }; version = "2.4.1"; }; parallel = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17b127xxmm2yqdz146qwbs57046kn0js1h8synv01dwqz2z1kp2l"; type = "gem"; }; version = "1.19.2"; }; parser = { - dependencies = ["ast"]; - groups = ["default" "development"]; - platforms = []; + dependencies = [ "ast" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1f7gmm60yla325wlnd3qkxs59qm2y0aan8ljpg6k18rwzrrfil6z"; type = "gem"; }; version = "2.7.2.0"; }; rainbow = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bb2fpjspydr6x0s8pn1pqkzmxszvkfapv0p4627mywl7ky4zkhk"; type = "gem"; }; version = "3.0.0"; }; regexp_parser = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0n9d14ppshnx71i3mi1pnm3hwhcbb6m6vsc0b0dqgsab8r2rs96n"; type = "gem"; }; version = "1.8.1"; }; rexml = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08ximcyfjy94pm1rhcx04ny1vx2sk0x4y185gzn86yfsbzwkng53"; type = "gem"; }; version = "3.2.5"; }; rubocop = { - dependencies = ["parallel" "parser" "rainbow" "regexp_parser" "rexml" "rubocop-ast" "ruby-progressbar" "unicode-display_width"]; - groups = ["default" "development"]; - platforms = []; + dependencies = [ + "parallel" + "parser" + "rainbow" + "regexp_parser" + "rexml" + "rubocop-ast" + "ruby-progressbar" + "unicode-display_width" + ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nrv7i81549addig09grw17qkab3l4319dcsf9y7psl7aa76ng3a"; type = "gem"; }; version = "0.93.0"; }; rubocop-ast = { - dependencies = ["parser"]; - groups = ["default" "development"]; - platforms = []; + dependencies = [ "parser" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "129hgz4swc8n0g01715v7y00k0h4mlzkxh63q7z27q7mjp54rl74"; type = "gem"; }; version = "0.7.1"; }; rubocop-discourse = { - dependencies = ["rubocop" "rubocop-rspec"]; - groups = ["development"]; - platforms = []; + dependencies = [ + "rubocop" + "rubocop-rspec" + ]; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10l2wwnvd4xccgqsyhxrhc5bw10b7an4awl0v90fw5xf2qdjiflw"; type = "gem"; }; version = "2.3.2"; }; rubocop-rspec = { - dependencies = ["rubocop"]; - groups = ["default" "development"]; - platforms = []; + dependencies = [ "rubocop" ]; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sc0bwdxzfr8byxzwvfyf22lwzqcaa6ca7wzxx31mk7vvy7r7dhl"; type = "gem"; }; version = "1.43.2"; }; ruby-progressbar = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1k77i0d4wsn23ggdd2msrcwfy0i376cglfqypkk2q77r2l3408zf"; type = "gem"; }; version = "1.10.1"; }; unicode-display_width = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06i3id27s60141x6fdnjn5rar1cywdwy64ilc59cz937303q3mna"; type = "gem"; }; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-prometheus/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-prometheus/default.nix index d6af6a08476b63..6ad453601be4ec 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-prometheus/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-prometheus/default.nix @@ -1,6 +1,10 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: - mkDiscoursePlugin { +mkDiscoursePlugin { bundlerEnvArgs.gemdir = ./.; name = "discourse-prometheus"; src = fetchFromGitHub { diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-prometheus/gemset.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-prometheus/gemset.nix index 9e889f98841451..d4e5472420b5b3 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-prometheus/gemset.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-prometheus/gemset.nix @@ -1,20 +1,20 @@ { prometheus_exporter = { - dependencies = ["webrick"]; - groups = ["default"]; - platforms = []; + dependencies = [ "webrick" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb4k6px8b36bvnw3d14j31s33ns60dcwxixbcgvhpzavd7fparb"; type = "gem"; }; version = "2.0.6"; }; webrick = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13qm7s0gr2pmfcl7dxrmq38asaza4w0i2n9my4yzs499j731wh8r"; type = "gem"; }; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-reactions/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-reactions/default.nix index 52bbc5ca2df4bc..50881d6782fb51 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-reactions/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-reactions/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-reactions"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-saved-searches/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-saved-searches/default.nix index 3403667cc1b820..4d9fe87853a28e 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-saved-searches/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-saved-searches/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-saved-searches"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-solved/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-solved/default.nix index 0e24578d364896..14aac40df9bd8b 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-solved/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-solved/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-solved"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-spoiler-alert/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-spoiler-alert/default.nix index 56240177a73e54..75f78b9d6b70fe 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-spoiler-alert/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-spoiler-alert/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-spoiler-alert"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-voting/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-voting/default.nix index 554cce44ae8a8b..1fe9b05ccadc4b 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-voting/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-voting/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-voting"; diff --git a/pkgs/servers/web-apps/discourse/plugins/discourse-yearly-review/default.nix b/pkgs/servers/web-apps/discourse/plugins/discourse-yearly-review/default.nix index a75392526c6e7b..f9fa3c75593143 100644 --- a/pkgs/servers/web-apps/discourse/plugins/discourse-yearly-review/default.nix +++ b/pkgs/servers/web-apps/discourse/plugins/discourse-yearly-review/default.nix @@ -1,4 +1,8 @@ -{ lib, mkDiscoursePlugin, fetchFromGitHub }: +{ + lib, + mkDiscoursePlugin, + fetchFromGitHub, +}: mkDiscoursePlugin { name = "discourse-yearly-review"; diff --git a/pkgs/servers/web-apps/discourse/rubyEnv/gemset.nix b/pkgs/servers/web-apps/discourse/rubyEnv/gemset.nix index b6f82fc701f438..df6e08bb6e4632 100644 --- a/pkgs/servers/web-apps/discourse/rubyEnv/gemset.nix +++ b/pkgs/servers/web-apps/discourse/rubyEnv/gemset.nix @@ -1,2749 +1,3488 @@ { actionmailer = { - dependencies = ["actionpack" "actionview" "activejob" "activesupport" "mail" "net-imap" "net-pop" "net-smtp" "rails-dom-testing"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "actionview" + "activejob" + "activesupport" + "mail" + "net-imap" + "net-pop" + "net-smtp" + "rails-dom-testing" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0l835a50h95wlzcy76c2vg54ix3i55kqmnrmz67b11q5fjb6068z"; type = "gem"; }; version = "7.1.3.4"; }; actionpack = { - dependencies = ["actionview" "activesupport" "nokogiri" "racc" "rack" "rack-session" "rack-test" "rails-dom-testing" "rails-html-sanitizer"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionview" + "activesupport" + "nokogiri" + "racc" + "rack" + "rack-session" + "rack-test" + "rails-dom-testing" + "rails-html-sanitizer" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1lpd0lvn6abcq5k8g0qw8kmzx6igirlqxvd1hhwmr5vaxhdwgbyw"; type = "gem"; }; version = "7.1.3.4"; }; actionview = { - dependencies = ["activesupport" "builder" "erubi" "rails-dom-testing" "rails-html-sanitizer"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "builder" + "erubi" + "rails-dom-testing" + "rails-html-sanitizer" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0nv1ifjhm59abc52k2hwazl38r9cc4bkfgdsl00f24gc5ljgbz21"; type = "gem"; }; version = "7.1.3.4"; }; actionview_precompiler = { - dependencies = ["actionview"]; - groups = ["default"]; - platforms = []; + dependencies = [ "actionview" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "077d83avfm73nd0yji853jn94jpbr496apyz5zh5df61qipbvdik"; type = "gem"; }; version = "0.4.0"; }; active_model_serializers = { - dependencies = ["activemodel"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activemodel" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k3mgia2ahh7mbk30hjq9pzqbk0kh281s91kq2z6p555nv9y6l3k"; type = "gem"; }; version = "0.8.4"; }; activejob = { - dependencies = ["activesupport" "globalid"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "globalid" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0qhg0izdckgyqmrsgigh1vkqg8ccrkdjhf36k9gxcbgvzpqfx2iz"; type = "gem"; }; version = "7.1.3.4"; }; activemodel = { - dependencies = ["activesupport"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "activesupport" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0wmdw440l4h75zk6c4ynbnv21bj26dh8kb1kwikqkjnzfvm3ij7l"; type = "gem"; }; version = "7.1.3.4"; }; activerecord = { - dependencies = ["activemodel" "activesupport" "timeout"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activemodel" + "activesupport" + "timeout" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1wihj9xhr7yj10hh8fqw6ralanbwlisncbam8pa92czjssjfqkkq"; type = "gem"; }; version = "7.1.3.4"; }; activesupport = { - dependencies = ["base64" "bigdecimal" "concurrent-ruby" "connection_pool" "drb" "i18n" "minitest" "mutex_m" "tzinfo"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "bigdecimal" + "concurrent-ruby" + "connection_pool" + "drb" + "i18n" + "minitest" + "mutex_m" + "tzinfo" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0283wk1zxb76lg79dk501kcf5xy9h25qiw15m86s4nrfv11vqns5"; type = "gem"; }; version = "7.1.3.4"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "public_suffix" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; annotate = { - dependencies = ["activerecord" "rake"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activerecord" + "rake" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1lw0fxb5mirsdp3bp20gjyvs7clvi19jbxnrm2ihm20kzfhvlqcs"; type = "gem"; }; version = "3.2.0"; }; ast = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "04nc8x27hlzlrr5c2gn7mar4vdr0apw5xg22wp6m8dx3wqr04a0y"; type = "gem"; }; version = "2.4.2"; }; aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gvdg4yx4p9av2glmp7vsxhs0n8fj1ga9kq2xdb8f95j7b04qhzi"; type = "gem"; }; version = "1.3.0"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fhym2gsm9kzl74nvzk3hhw288n1l77kxinhik43p37ayranzcv5"; type = "gem"; }; version = "1.894.0"; }; aws-sdk-core = { - dependencies = ["aws-eventstream" "aws-partitions" "aws-sigv4" "jmespath"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-eventstream" + "aws-partitions" + "aws-sigv4" + "jmespath" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "088nq8yz9n4p7pnhjwp9nbxlkj7jwchpkzvnl4nybfb1dkvk4dns"; type = "gem"; }; version = "3.191.3"; }; aws-sdk-kms = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1gbxms3daszl4mk89swjrpq3fqgm9lg0wl65yjfp0nfz8jm4jyqf"; type = "gem"; }; version = "1.77.0"; }; aws-sdk-s3 = { - dependencies = ["aws-sdk-core" "aws-sdk-kms" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sdk-kms" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1safbxycz517m2v981z8kbmdiqx9jypl093ia0mcrskkgh4fyb3s"; type = "gem"; }; version = "1.143.0"; }; aws-sdk-sns = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ql1y276lfk27dyisk8ak1wdnysklw2dcir3kgy05glzzc9j4z1w"; type = "gem"; }; version = "1.72.0"; }; aws-sigv4 = { - dependencies = ["aws-eventstream"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-eventstream" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g3w27wzjy4si6kp49w10as6ml6g6zl3xrfqs5ikpfciidv9kpc4"; type = "gem"; }; version = "1.8.0"; }; base64 = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; better_errors = { - dependencies = ["erubi" "rack" "rouge"]; - groups = ["development"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "erubi" + "rack" + "rouge" + ]; + groups = [ "development" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0wqazisnn6hn1wsza412xribpw5wzx6b5z5p4mcpfgizr6xg367p"; type = "gem"; }; version = "2.10.1"; }; bigdecimal = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; binding_of_caller = { - dependencies = ["debug_inspector"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "debug_inspector" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "16mjj15ks5ws53v2y31hxcmf46d0qjdvdaadpk7xsij2zymh4a9b"; type = "gem"; }; version = "1.0.1"; }; bootsnap = { - dependencies = ["msgpack"]; - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "msgpack" ]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1srlq3gqirzdkhv12ljpnp5cb0f8jfrl3n8xs9iivyz2c7khvdyp"; type = "gem"; }; version = "1.18.3"; }; builder = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0pw3r2lyagsxkm71bf44v5b74f7l9r7di22brbyji9fwz791hya9"; type = "gem"; }; version = "3.3.0"; }; bullet = { - dependencies = ["activesupport" "uniform_notifier"]; - groups = ["development"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "uniform_notifier" + ]; + groups = [ "development" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "12gacycw1adsdjp14pm43619c6lcdaddhgbdizy7gnzmnjhwh0im"; type = "gem"; }; version = "7.2.0"; }; byebug = { - groups = ["development" "test"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "development" + "test" + ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0nx3yjf4xzdgb8jkmk2344081gqr22pgjqnmjg2q64mj5d6r9194"; type = "gem"; }; version = "11.1.3"; }; capybara = { - dependencies = ["addressable" "matrix" "mini_mime" "nokogiri" "rack" "rack-test" "regexp_parser" "xpath"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "matrix" + "mini_mime" + "nokogiri" + "rack" + "rack-test" + "regexp_parser" + "xpath" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vxfah83j6zpw3v5hic0j70h519nvmix2hbszmjwm8cfawhagns2"; type = "gem"; }; version = "3.40.0"; }; cbor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dsf9gjc2cj79vrnz2vgq573biqjw7ad4b0idm05xg6rb3y9gq4y"; type = "gem"; }; version = "0.5.9.8"; }; certified = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1706p6p0a8adyvd943af2a3093xakvislgffw3v9dvp7j07dyk5a"; type = "gem"; }; version = "1.0.0"; }; cgi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0c5494n3n6l51n1w1vc118zckbqdzk7r6b656hswg72w0bif2ja3"; type = "gem"; }; version = "0.4.1"; }; chunky_png = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znw5x86hmm9vfhidwdsijz8m38pqgmv98l9ryilvky0aldv7mc9"; type = "gem"; }; version = "1.4.0"; }; coderay = { - groups = ["default" "development"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0jvxqxzply1lwp7ysn94zjhh57vc14mcshw1ygw14ib8lhc00lyw"; type = "gem"; }; version = "1.1.3"; }; colored2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zj06gjqwykgzxmbkp2hmg3wv5kv8zz5d77acxipzcgicdjgvfan"; type = "gem"; }; version = "4.0.0"; }; concurrent-ruby = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0skwdasxq7mnlcccn6aqabl7n9r3jd7k19ryzlzzip64cn4x572g"; type = "gem"; }; version = "1.3.3"; }; connection_pool = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; cose = { - dependencies = ["cbor" "openssl-signature_algorithm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "cbor" + "openssl-signature_algorithm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00c6x4ha7qiaaf88qdbyf240mk146zz78rbm4qwyaxmwlmk7q933"; type = "gem"; }; version = "1.3.0"; }; cppjieba_rb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ijzvnm5jclyhf6ls30kv7dqy05f3hbha69f59jwbzdid7dndla5"; type = "gem"; }; version = "0.4.2"; }; crack = { - dependencies = ["bigdecimal" "rexml"]; - groups = ["default" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bigdecimal" + "rexml" + ]; + groups = [ + "default" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0jaa7is4fw1cxigm8vlyhg05bw4nqy4f91zjqxk7pp4c8bdyyfn8"; type = "gem"; }; version = "1.0.0"; }; crass = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0pfl5c0pyqaparxaqxi6s4gfl21bdldwiawrc0aknyvflli60lfw"; type = "gem"; }; version = "1.0.6"; }; css_parser = { - dependencies = ["addressable"]; - groups = ["default"]; - platforms = []; + dependencies = [ "addressable" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rhqn05w27w2mjrf0a6ppb4fxpxbfvyhwgdxa8z886jr4qnhywzb"; type = "gem"; }; version = "1.17.1"; }; csv = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zfn40dvgjk1xv1z8l11hr9jfg3jncwsc9yhzsz4l4rivkpivg8b"; type = "gem"; }; version = "3.3.0"; }; date = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "149jknsq999gnhy865n33fkk22s0r447k76x9pmcnnwldfv2q7wp"; type = "gem"; }; version = "3.3.4"; }; debug_inspector = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18k8x9viqlkh7dbmjzh8crbjy8w480arpa766cw1dnn3xcpa1pwv"; type = "gem"; }; version = "1.2.0"; }; diff-lcs = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1znxccz83m4xgpd239nyqxlifdb7m8rlfayk6s259186nkgj6ci7"; type = "gem"; }; version = "1.5.1"; }; diffy = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qcsv29ljfhy76gq4xi8zpn6dc6nv15c41r131bdr38kwpxjzd1n"; type = "gem"; }; version = "3.4.2"; }; digest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qkpbkxq83ip3iysfh2kjrg9sh2n2q91prhyxh3vq10lcfzv9l1"; type = "gem"; }; version = "3.1.1"; }; discourse-fonts = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q1q9fmqc7dir2nj94nai58h26zsh6fqmbr6hfax5d6xpy4pm1yf"; type = "gem"; }; version = "0.0.9"; }; discourse-seed-fu = { - dependencies = ["activerecord" "activesupport"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activerecord" + "activesupport" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1r3mbi72cx3xx8dnva1zhvxcacdma4xfn16d8s860m7d25fdjqag"; type = "gem"; }; version = "2.3.12"; }; discourse_dev_assets = { - dependencies = ["faker" "literate_randomizer"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faker" + "literate_randomizer" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ncd6n34vm7qd5mpza8wrqfkgfc6xbd5rxjcbdnvsv94zxr75rm1"; type = "gem"; }; version = "0.0.4"; }; docile = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07pj4z3h8wk4fgdn6s62vw1lwvhj0ac0x10vfbdkr9xzk7krn5cn"; type = "gem"; }; version = "1.4.1"; }; drb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h5kbj9hvg5hb3c7l425zpds0vb42phvln2knab8nmazg2zp5m79"; type = "gem"; }; version = "2.2.1"; }; email_reply_trimmer = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jgcxifm48xq5dz9k47q43pqm5bfnf14l62l3bqhmv8f6z8dw4ki"; type = "gem"; }; version = "0.1.13"; }; erubi = { - groups = ["default" "development" "test"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0qnd6ff4az22ysnmni3730c41b979xinilahzg86bn7gv93ip9pw"; type = "gem"; }; version = "1.13.0"; }; excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ala6123d3cv965ss48iyi0q4hcbzrznfwv2f1mr91sy98cigq4h"; type = "gem"; }; version = "0.111.0"; }; execjs = { - groups = ["assets" "default"]; - platforms = []; + groups = [ + "assets" + "default" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yywajqlpjhrj1m43s3lfg3i4lkb6pxwccmwps7qw37ndmphdzg8"; type = "gem"; }; version = "2.9.1"; }; exifr = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11v201jljn327fwjqcsglrbdnyhivnj7j6nh6wym5zjqgrwxy3kn"; type = "gem"; }; version = "1.4.0"; }; fabrication = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1al5iv3as21l5clci0b5cg27z136pan7gkj7plp4l0w83c6z2y9c"; type = "gem"; }; version = "2.31.0"; }; faker = { - dependencies = ["i18n"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "i18n" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1wslw5gh335zcahxmdd497xaa7h0d8l60c0jfv942mn47fxy8m47"; type = "gem"; }; version = "2.23.0"; }; fakeweb = { - groups = ["test"]; - platforms = []; + groups = [ "test" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a09z9nb369bvwpghncgd5y4f95lh28w0q258srh02h22fz9dj8y"; type = "gem"; }; version = "1.3.0"; }; faraday = { - dependencies = ["faraday-net_http" "logger"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-net_http" + "logger" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1adx342h7s3imyrwwbda73g9ni1y07qj35br9lrzq4f5mh16qghs"; type = "gem"; }; version = "2.10.0"; }; faraday-net_http = { - dependencies = ["net-http"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-http" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f49frpfdr8czwm2mjkfny4pini6fy49b6hamw4jrppl4vsg14ys"; type = "gem"; }; version = "3.1.1"; }; faraday-retry = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "023ncwlagnf2irx2ckyj1pg1f1x436jgr4a5y45mih298p8zwij1"; type = "gem"; }; version = "2.2.1"; }; fast_blank = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "rbx"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "rbx"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1shpmamyzyhyxmv95r96ja5rylzaw60r19647d0fdm7y2h2c77r6"; type = "gem"; }; version = "1.0.1"; }; fastimage = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sfc7svf7h1ja6zmsq9f3ps6pg0q4hymphh6rk7ipmp7ygqjkii3"; type = "gem"; }; version = "2.3.1"; }; ffi = { - groups = ["default" "development" "test"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; fspath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xcxikkrjv8ws328nn5ax5pyfjs8pn7djg1hks7qyb3yp6prpb5m"; type = "gem"; }; version = "3.1.2"; }; globalid = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sbw6b66r7cwdx3jhs46s4lr991969hvigkjpbdl7y3i31qpdgvh"; type = "gem"; }; version = "1.2.1"; }; google-protobuf = { - dependencies = ["bigdecimal" "rake"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bigdecimal" + "rake" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0vwnr6fmxig4pkag86yzbznpxk8ii7rhjz0rrprkqvnymhhfnscz"; type = "gem"; }; version = "4.27.2"; }; guess_html_encoding = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16700fk6kmif3q3kpc1ldhy3nsc9pkxlgl8sqhznff2zjj5lddna"; type = "gem"; }; version = "0.0.11"; }; hana = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03cvrv2wl25j9n4n509hjvqnmwa60k92j741b64a1zjisr1dn9al"; type = "gem"; }; version = "1.3.7"; }; hashdiff = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jf9dxgjz6z7fvymyz2acyvn9iyvwkn6d9sk7y4fxwbmfc75yimm"; type = "gem"; }; version = "1.1.0"; }; hashie = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nh3arcrbz1rc1cr59qm53sdhqm137b258y8rcb4cvd3y98lwv4x"; type = "gem"; }; version = "5.0.0"; }; highline = { - dependencies = ["reline"]; - groups = ["default"]; - platforms = []; + dependencies = [ "reline" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sxqnaz6wvkwbwzsipwsqcg1zw2kn67x7l362whv87zl5133w60l"; type = "gem"; }; version = "3.1.0"; }; htmlentities = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nkklqsn8ir8wizzlakncfv42i32wc0w9hxp00hvdlgjr7376nhj"; type = "gem"; }; version = "4.3.4"; }; http_accept_language = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0d0nlfz9vm4jr1l6q0chx4rp2hrnrfbx3gadc1dz930lbbaz0hq0"; type = "gem"; }; version = "2.1.1"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "concurrent-ruby" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ffix518y7976qih9k1lgnc17i3v6yrlh0a3mckpxdb4wc2vrp16"; type = "gem"; }; version = "1.14.5"; }; image_optim = { - dependencies = ["exifr" "fspath" "image_size" "in_threads" "progress"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "exifr" + "fspath" + "image_size" + "in_threads" + "progress" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "02iw1plldayr1l8bdw2gshq0h083h0fxwji1m1nfhzikz917c07p"; type = "gem"; }; version = "0.31.3"; }; image_size = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16h2gxxk212mlvphf03x1z1ddb9k3vm0lgsxbvi4fjg77x8q19f6"; type = "gem"; }; version = "3.4.0"; }; in_threads = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j9132d4g8prjafgdh4pw948j527kr09m2lvylrcd797il9yd9wi"; type = "gem"; }; version = "1.6.0"; }; io-console = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08d2lx42pa8jjav0lcjbzfzmw61b8imxr9041pva8xzqabrczp7h"; type = "gem"; }; version = "0.7.2"; }; irb = { - dependencies = ["rdoc" "reline"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rdoc" + "reline" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05g6vpz3997q4j3xhrliswfx3g5flsn5cfn1p1s4h6dx7c0hbn2k"; type = "gem"; }; version = "1.14.0"; }; iso8601 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18js898rhh6byp0znvchiv6mcxi5l8v3v0bj2ddajpxynwajp319"; type = "gem"; }; version = "0.13.0"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cdw9vw2qly7q7r41s7phnac264rbsdqgj4l0h4nqgbjb157g393"; type = "gem"; }; version = "1.6.2"; }; json = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0b4qsi8gay7ncmigr0pnbxyb17y3h8kavdyhsh7nrlqwr35vb60q"; type = "gem"; }; version = "2.7.2"; }; json-schema = { - dependencies = ["addressable"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "addressable" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "09bq393nrxa7hmphc3li8idgxdnb5hwgj15d0q5qsh4l5g1qvrnm"; type = "gem"; }; version = "4.3.1"; }; json_schemer = { - dependencies = ["bigdecimal" "hana" "regexp_parser" "simpleidn"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "bigdecimal" + "hana" + "regexp_parser" + "simpleidn" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0dgbrps0ydiyxcgj5n4dny0cmzwj125x1s792l7m5jjrp1rs27wz"; type = "gem"; }; version = "2.3.0"; }; jwt = { - dependencies = ["base64"]; - groups = ["default"]; - platforms = []; + dependencies = [ "base64" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04mw326i9vsdcqwm4bf0zvnqw237f8l7022nhlbmak92bqqpg62s"; type = "gem"; }; version = "2.8.2"; }; kgio = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "rbx"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "rbx"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ipzvw7n0kz1w8rkqybyxvf3hb601a770khm0xdqm68mc4aa59xx"; type = "gem"; }; version = "2.11.4"; }; language_server-protocol = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gvb1j8xsqxms9mww01rmdl78zkd72zgxaap56bhv8j45z05hp1x"; type = "gem"; }; version = "3.17.0.3"; }; libv8-node = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13gmrl4lq1rfpdn76v5nid2hsajhrw27s6n88j09v26f0axgp4vp"; type = "gem"; }; version = "18.19.0.0"; }; listen = { - dependencies = ["rb-fsevent" "rb-inotify"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rb-fsevent" + "rb-inotify" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0rwwsmvq79qwzl6324yc53py02kbrcww35si720490z5w0j497nv"; type = "gem"; }; version = "3.9.0"; }; literate_randomizer = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c8p8aw93bx4ygpkwfv6dv41psb86jb0pi16gvnv30rr72dkq1q5"; type = "gem"; }; version = "0.4.0"; }; logger = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gpg8gzi0xwymw4aaq2iafcbx31i3xzkg3fb30mdxn1d4qhc3dqa"; type = "gem"; }; version = "1.6.0"; }; lograge = { - dependencies = ["actionpack" "activesupport" "railties" "request_store"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "railties" + "request_store" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1qcsvh9k4c0cp6agqm9a8m4x2gg7vifryqr7yxkg2x9ph9silds2"; type = "gem"; }; version = "0.14.0"; }; logstash-event = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bk7fhhryjxp1klr3hq6i6srrc21wl4p980bysjp0w66z9hdr9w9"; type = "gem"; }; version = "1.2.02"; }; logster = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bmvpa5mk779rgl4s4qy8nyhjh1lpf5gn4pmv40xyalnv2whryf3"; type = "gem"; }; version = "2.20.0"; }; loofah = { - dependencies = ["crass" "nokogiri"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "crass" + "nokogiri" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zkjqf37v2d7s11176cb35cl83wls5gm3adnfkn2zcc61h3nxmqh"; type = "gem"; }; version = "2.22.0"; }; lru_redux = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yxghzg7476sivz8yyr9nkak2dlbls0b89vc2kg52k0nmg6d0wgf"; type = "gem"; }; version = "1.1.0"; }; lz4-ruby = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "rbx"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "rbx"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "12fymsvcb9kw6ycyfzc8b9svriq0afqf1qnl121xrz8c4gpfa6q1"; type = "gem"; }; version = "0.3.3"; }; mail = { - dependencies = ["mini_mime" "net-imap" "net-pop" "net-smtp"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_mime" + "net-imap" + "net-pop" + "net-smtp" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1bf9pysw1jfgynv692hhaycfxa8ckay1gjw5hz3madrbrynryfzc"; type = "gem"; }; version = "2.8.1"; }; matrix = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h2cgkpzkh3dd0flnnwfq6f3nl2b1zff9lvqz8xs853ssv5kq23i"; type = "gem"; }; version = "0.4.2"; }; maxminddb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zlhqilyggiryywgswfi624bv10qnkm66hggmg79vvgv73j3p4sh"; type = "gem"; }; version = "0.1.22"; }; memory_profiler = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1pv28xh8mss25fj4nd5r6zds1br8ssr2bpxr0md5pskv38m5qz0f"; type = "gem"; }; version = "1.0.2"; }; message_bus = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15xqp7pnicjh2868fsc6fmxw8cw32bpiaqpc5bz8cwdib09ns3qk"; type = "gem"; }; version = "4.3.8"; }; messageformat-wrapper = { - dependencies = ["mini_racer"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mini_racer" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g30y5qv6jx39qz5g0yai37n46mvzjn7si8whjyd24p44sb8gspc"; type = "gem"; }; version = "1.1.0"; }; method_source = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1igmc3sq9ay90f8xjvfnswd1dybj1s3fi0dwd53inwsvqk4h24qq"; type = "gem"; }; version = "1.1.0"; }; mini_mime = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vycif7pjzkr29mfk4dlqv3disc5dn0va04lkwajlpr1wkibg0c6"; type = "gem"; }; version = "1.1.5"; }; mini_portile2 = { - groups = ["default" "development" "generic_import" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "generic_import" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1q1f2sdw3y3y9mnym9dhjgsjr72sq975cfg5c4yx7gwv8nmzbvhk"; type = "gem"; }; version = "2.8.7"; }; mini_racer = { - dependencies = ["libv8-node"]; - groups = ["default"]; - platforms = []; + dependencies = [ "libv8-node" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ling4ynn7na1cw69wzn8zn00jifwjrnprnynn05rcca1pzs58d1"; type = "gem"; }; version = "0.14.1"; }; mini_scheduler = { - dependencies = ["sidekiq"]; - groups = ["default"]; - platforms = []; + dependencies = [ "sidekiq" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19c72wlr0zsrg1fiak61h0z1b3glv2l23041xvlwv2i71fw5xavy"; type = "gem"; }; version = "0.16.0"; }; mini_sql = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yrxjmwhfnvcwbj9vscyq0z67sq09zl8qhmzgakq2ywy4yvcpwgg"; type = "gem"; }; version = "1.5.0"; }; mini_suffix = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rr2nx1kixd7ccxqdnswjnflg46s6lr1f9vxkdy298k95zwk67cd"; type = "gem"; }; version = "0.3.3"; }; minio_runner = { - groups = ["test"]; - platforms = []; + groups = [ "test" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c0bld2bpnfrld7g0pli3pp3b1z3a21cgahhw70i5cjr33sx88pi"; type = "gem"; }; version = "0.1.2"; }; minitest = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0jj629q3vw5yn90q4di4dyb87pil4a8qfm2srhgy5nc8j2n33v1i"; type = "gem"; }; version = "5.24.1"; }; mocha = { - dependencies = ["ruby2_keywords"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "ruby2_keywords" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "04k1k9cmdv7q2p1b2z2y1k9dn1hhwjdlwkrp46gfq84v7887xhdl"; type = "gem"; }; version = "2.4.5"; }; msgpack = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1a5adcb7bwan09mqhj3wi9ib52hmdzmqg7q08pggn3adibyn5asr"; type = "gem"; }; version = "1.7.2"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; multi_xml = { - dependencies = ["bigdecimal"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bigdecimal" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06x61ca5j84nyhr1mwh9r436yiphnc5hmacb3gwqyn5gd0611kjg"; type = "gem"; }; version = "0.7.1"; }; mustache = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l0p4wx15mi3wnamfv92ipkia4nsx8qi132c6g51jfdma3fiz2ch"; type = "gem"; }; version = "1.1.1"; }; mutex_m = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ma093ayps1m92q845hmpk0dmadicvifkbf05rpq9pifhin0rvxn"; type = "gem"; }; version = "0.2.0"; }; net-http = { - dependencies = ["uri"]; - groups = ["default"]; - platforms = []; + dependencies = [ "uri" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10n2n9aq00ih8v881af88l1zyrqgs5cl3njdw8argjwbl5ggqvm9"; type = "gem"; }; version = "0.4.1"; }; net-imap = { - dependencies = ["date" "net-protocol"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "date" + "net-protocol" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0rc08fxm10vv73bg0nqyp5bdvl4cvzb3y4cdk4kwmxx414zln652"; type = "gem"; }; version = "0.4.14"; }; net-pop = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wyz41jd4zpjn0v1xsf9j778qx1vfrl24yc20cpmph8k42c4x2w4"; type = "gem"; }; version = "0.1.2"; }; net-protocol = { - dependencies = ["timeout"]; - groups = ["default"]; - platforms = []; + dependencies = [ "timeout" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a32l4x73hz200cm587bc29q8q9az278syw3x6fkc9d1lv5y0wxa"; type = "gem"; }; version = "0.2.2"; }; net-smtp = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0amlhz8fhnjfmsiqcjajip57ici2xhw089x7zqyhpk51drg43h2z"; type = "gem"; }; version = "0.5.0"; }; nio4r = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "017nbw87dpr4wyk81cgj8kxkxqgsgblrkxnmmadc77cg9gflrfal"; type = "gem"; }; version = "2.7.3"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15gysw8rassqgdq3kwgl4mhqmrgh7nk2qvrcqp4ijyqazgywn6gq"; type = "gem"; }; version = "1.16.7"; }; oauth = { - dependencies = ["oauth-tty" "snaky_hash" "version_gem"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "oauth-tty" + "snaky_hash" + "version_gem" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1syx3hfimaqycy21kn8gmal1cb3bw3hzalv3in2ixnay1xzjp41q"; type = "gem"; }; version = "1.1.0"; }; oauth-tty = { - dependencies = ["version_gem"]; - groups = ["default"]; - platforms = []; + dependencies = [ "version_gem" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05wb5n36i4h23hh9dx2m2cwjxx5vj0vgyrn2xr6rsl54glq5rqil"; type = "gem"; }; version = "1.0.5"; }; oauth2 = { - dependencies = ["faraday" "jwt" "multi_json" "multi_xml" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "jwt" + "multi_json" + "multi_xml" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "042w5lamxhllfxsv0y8v9cvdhmlasy5kxbhcdd3lzj9bhz4gqfb7"; type = "gem"; }; version = "1.4.11"; }; oj = { - dependencies = ["bigdecimal"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bigdecimal" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b2narmcw4723lfyy7j0l4pfyv5n0qnmkm4mqgi832p5cg31k090"; type = "gem"; }; version = "3.16.4"; }; omniauth = { - dependencies = ["hashie" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "hashie" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1jn9j54l5h7xcba2vjq74l1dk0xrwvsjxam4qhylpi52nw0h5502"; type = "gem"; }; version = "1.9.2"; }; omniauth-facebook = { - dependencies = ["omniauth-oauth2"]; - groups = ["default"]; - platforms = []; + dependencies = [ "omniauth-oauth2" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0m7q38kjm94wgq6h7hk9546yg33wcs3vf1v6zp0vx7nwkvfxh2j4"; type = "gem"; }; version = "9.0.0"; }; omniauth-github = { - dependencies = ["omniauth" "omniauth-oauth2"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "omniauth" + "omniauth-oauth2" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0xbk0dbxqfpyfb33ghz6vrlz3m6442rp18ryf13gwzlnifcawhlb"; type = "gem"; }; version = "1.4.0"; }; omniauth-google-oauth2 = { - dependencies = ["jwt" "oauth2" "omniauth" "omniauth-oauth2"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "jwt" + "oauth2" + "omniauth" + "omniauth-oauth2" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "10pnxvb6wpnf58dja3yz4ja527443x3q13hzhcbays4amnnp8i4a"; type = "gem"; }; version = "0.8.2"; }; omniauth-oauth = { - dependencies = ["oauth" "omniauth"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "oauth" + "omniauth" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0yw2vzx633p9wpdkd4jxsih6mw604mj7f6myyfikmj4d95c8d9z7"; type = "gem"; }; version = "1.2.0"; }; omniauth-oauth2 = { - dependencies = ["oauth2" "omniauth"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "oauth2" + "omniauth" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ia73zcbmhf02krlkq2rxmksx93jp777ax5x58fzkq3jzacqyniz"; type = "gem"; }; version = "1.7.3"; }; omniauth-twitter = { - dependencies = ["omniauth-oauth" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "omniauth-oauth" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0r5j65hkpgzhvvbs90id3nfsjgsad6ymzggbm7zlaxvnrmvnrk65"; type = "gem"; }; version = "1.4.0"; }; openssl = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "054d6ybgjdzxw567m7rbnd46yp6gkdbc5ihr536vxd3p15vbhjrw"; type = "gem"; }; version = "3.2.0"; }; openssl-signature_algorithm = { - dependencies = ["openssl"]; - groups = ["default"]; - platforms = []; + dependencies = [ "openssl" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "103yjl68wqhl5kxaciir5jdnyi7iv9yckishdr52s5knh9g0pd53"; type = "gem"; }; version = "1.3.0"; }; optimist = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0q4jqq3v1bxlfr9jgqmahnygkvl81lr6s1rhm8qg66c9xr9nz241"; type = "gem"; }; version = "3.1.0"; }; parallel = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "145bn5q7ysnjj02jdf1x4nc1f0xxrv7ihgz9yr1j7sinmawqkq0j"; type = "gem"; }; version = "1.25.1"; }; parallel_tests = { - dependencies = ["parallel"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "parallel" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0q5q38sfrpwgcqwf5sl6xals5w11xayh8i9nq1vxya2sbrzrgbcq"; type = "gem"; }; version = "4.7.1"; }; parser = { - dependencies = ["ast" "racc"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ast" + "racc" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "10ly2wind06nylyqa5724ld2l0l46d3ag4fm04ifjgw7qdlpf94d"; type = "gem"; }; version = "3.3.4.0"; }; pg = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pfj771p5a29yyyw58qacks464sl86d5m3jxjl5rlqqw2m3v5xq4"; type = "gem"; }; version = "1.5.4"; }; prettier_print = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ybgks9862zmlx71zd4j20ky86fsrp6j6m0az4hzzb1zyaskha57"; type = "gem"; }; version = "1.2.1"; }; progress = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wymdk40cwrqn32gwg1kw94s5p1n0z3n7ma7x1s62gd4vw3d63in"; type = "gem"; }; version = "3.6.0"; }; pry = { - dependencies = ["coderay" "method_source"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "coderay" + "method_source" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k9kqkd9nps1w1r1rb7wjr31hqzkka2bhi8b518x78dcxppm9zn4"; type = "gem"; }; version = "0.14.2"; }; pry-byebug = { - dependencies = ["byebug" "pry"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "byebug" + "pry" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1y41al94ks07166qbp2200yzyr5y60hm7xaiw4lxpgsm4b1pbyf8"; type = "gem"; }; version = "3.10.1"; }; pry-rails = { - dependencies = ["pry"]; - groups = ["default"]; - platforms = []; + dependencies = [ "pry" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0garafb0lxbm3sx2r9pqgs7ky9al58cl3wmwc0gmvmrl9bi2i7m6"; type = "gem"; }; version = "0.3.11"; }; pry-stack_explorer = { - dependencies = ["binding_of_caller" "pry"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "binding_of_caller" + "pry" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0h7kp99r8vpvpbvia079i58932qjz2ci9qhwbk7h1bf48ydymnx2"; type = "gem"; }; version = "0.6.1"; }; psych = { - dependencies = ["stringio"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "stringio" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0s5383m6004q76xm3lb732bp4sjzb6mxb6rbgn129gy2izsj4wrk"; type = "gem"; }; version = "5.1.2"; }; public_suffix = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0vqcw3iwby3yc6avs1vb3gfd0vcp2v7q310665dvxfswmcf4xm31"; type = "gem"; }; version = "6.0.1"; }; puma = { - dependencies = ["nio4r"]; - groups = ["default"]; - platforms = []; + dependencies = [ "nio4r" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0i2vaww6qcazj0ywva1plmjnj6rk23b01szswc5jhcq7s2cikd1y"; type = "gem"; }; version = "6.4.2"; }; racc = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "021s7maw0c4d9a6s07vbmllrzqsj2sgmrwimlh8ffkvwqdjrld09"; type = "gem"; }; version = "1.8.0"; }; rack = { - groups = ["default" "development" "test"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0hj0rkw2z9r1lcg2wlrcld2n3phwrcgqcp7qd1g9a7hwgalh2qzx"; type = "gem"; }; version = "2.2.9"; }; rack-mini-profiler = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00d80wjavaakhs177b7g542qs3n55kj4icjkwj0lbxcmaxyxxw1b"; type = "gem"; }; version = "3.3.1"; }; rack-protection = { - dependencies = ["base64" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zzvivmdb4dkscc58i3gmcyrnypynsjwp6xgc4ylarlhqmzvlx1w"; type = "gem"; }; version = "3.2.0"; }; rack-session = { - dependencies = ["rack"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rack" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0xhxhlsz6shh8nm44jsmd9276zcnyzii364vhcvf0k8b8bjia8d0"; type = "gem"; }; version = "1.0.2"; }; rack-test = { - dependencies = ["rack"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rack" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ysx29gk9k14a14zsp5a8czys140wacvp91fja8xcja0j1hzqq8c"; type = "gem"; }; version = "2.1.0"; }; rackup = { - dependencies = ["rack" "webrick"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rack" + "webrick" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1wbr03334ba9ilcq25wh9913xciwj0j117zs60vsqm0zgwdkwpp9"; type = "gem"; }; version = "1.0.0"; }; rails-dom-testing = { - dependencies = ["activesupport" "minitest" "nokogiri"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "minitest" + "nokogiri" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fx9dx1ag0s1lr6lfr34lbx5i1bvn3bhyf3w3mx6h7yz90p725g5"; type = "gem"; }; version = "2.2.0"; }; rails-html-sanitizer = { - dependencies = ["loofah" "nokogiri"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "loofah" + "nokogiri" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1pm4z853nyz1bhhqr7fzl44alnx4bjachcr6rh6qjj375sfz3sc6"; type = "gem"; }; version = "1.6.0"; }; rails_failover = { - dependencies = ["activerecord" "concurrent-ruby" "railties"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activerecord" + "concurrent-ruby" + "railties" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yxbh9xim46jqv9ap63ygvwv9bglbkqssn5hvr065gqly32mi407"; type = "gem"; }; version = "2.1.1"; }; rails_multisite = { - dependencies = ["activerecord" "railties"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activerecord" + "railties" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zlfmm19k0p19jzknimqhhzs1phswmfgispph9b5fkag0w3ajxci"; type = "gem"; }; version = "6.0.0"; }; railties = { - dependencies = ["actionpack" "activesupport" "irb" "rackup" "rake" "thor" "zeitwerk"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "irb" + "rackup" + "rake" + "thor" + "zeitwerk" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1z0slb2dlwrwgqijbk37hl4r9bh4h8vzcyswz6a9srl8lzrljq3c"; type = "gem"; }; version = "7.1.3.4"; }; rainbow = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0smwg4mii0fm38pyb5fddbmrdpifwv22zv3d3px2xx497am93503"; type = "gem"; }; version = "3.1.1"; }; raindrops = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "rbx"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "rbx"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0c27mcglrj928zkm4d2spj9yh2xkkka8ns5s6bidkwild3zvj3ma"; type = "gem"; }; version = "0.20.1"; }; rake = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "17850wcwkgi30p7yqh60960ypn7yibacjjha0av78zaxwvd3ijs6"; type = "gem"; }; version = "13.2.1"; }; rb-fsevent = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zmf31rnpm8553lqwibvv3kkx0v7majm1f341xbxc0bk5sbhp423"; type = "gem"; }; version = "0.11.2"; }; rb-inotify = { - dependencies = ["ffi"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "ffi" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0vmy8xgahixcz6hzwy4zdcyn2y6d6ri8dqv5xccgzc1r292019x0"; type = "gem"; }; version = "0.11.1"; }; rbtrace = { - dependencies = ["ffi" "msgpack" "optimist"]; - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ffi" + "msgpack" + "optimist" + ]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1p65p6f917al0f07sn5ca9yj92f7mk52xgnp0ahqpyrb8r6sdjz8"; type = "gem"; }; version = "0.5.1"; }; rchardet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1isj1b3ywgg2m1vdlnr41lpvpm3dbyarf1lla4dfibfmad9csfk9"; type = "gem"; }; version = "1.8.0"; }; rdoc = { - dependencies = ["psych"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "psych" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ygk2zk0ky3d88v3ll7qh6xqvbvw5jin0hqdi1xkv1dhaw7myzdi"; type = "gem"; }; version = "6.7.0"; }; redcarpet = { - groups = ["generic_import"]; - platforms = []; + groups = [ "generic_import" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sg9sbf9pm91l7lac7fs4silabyn0vflxwaa2x3lrzsm0ff8ilca"; type = "gem"; }; version = "3.6.0"; }; redis = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fikjg6j12ka6hh36dxzhfkpqqmilzjfzcdf59iwkzsgd63f0ziq"; type = "gem"; }; version = "4.8.1"; }; redis-namespace = { - dependencies = ["redis"]; - groups = ["default"]; - platforms = []; + dependencies = [ "redis" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f92i9cwlp6xj6fyn7qn4qsaqvxfw4wqvayll7gbd26qnai1l6p9"; type = "gem"; }; version = "1.11.0"; }; regexp_parser = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ik40vcv7mqigsfpqpca36hpmnx0536xa825ai5qlkv3mmkyf9ss"; type = "gem"; }; version = "2.9.2"; }; reline = { - dependencies = ["io-console"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "io-console" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0y6kyz7kcilwdpfy3saqfgnar38vr5ys9sp40ndffy6h1znxfbax"; type = "gem"; }; version = "0.5.9"; }; request_store = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jw89j9s5p5cq2k7ffj5p4av4j4fxwvwjs1a4i9g85d38r9mvdz1"; type = "gem"; }; version = "1.7.0"; }; rexml = { - dependencies = ["strscan"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "strscan" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0zr5qpa8lampaqzhdcjcvyqnrqcjl7439mqjlkjz43wdhmpnh4s5"; type = "gem"; }; version = "3.3.2"; }; rinku = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zcdha17s1wzxyc5814j6319wqg33jbn58pg6wmxpws36476fq4b"; type = "gem"; }; version = "2.0.6"; }; rotp = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0m48hv6wpmmm6cjr6q92q78h1i610riml19k5h1dil2yws3h1m3m"; type = "gem"; }; version = "6.3.0"; }; rouge = { - groups = ["default" "development"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "072qvvrcqj0yfr3b0j932mlhvn41i38bq37z7z07i3ikagndkqwy"; type = "gem"; }; version = "4.3.0"; }; rqrcode = { - dependencies = ["chunky_png" "rqrcode_core"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "chunky_png" + "rqrcode_core" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1hggzz8i1l62pkkiybhiqv6ypxw7q844sddrrbbfczjcnj5sivi3"; type = "gem"; }; version = "2.2.0"; }; rqrcode_core = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06ld6386hbdhy5h0k09axmgn424kavpc8f27k1vjhknjhbf8jjfg"; type = "gem"; }; version = "1.2.0"; }; rrule = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05ln9vfx1m2hb8cpmi8i7m1hhdxdra77xi6ri1inl27byx6kn4mx"; type = "gem"; }; version = "0.6.0"; }; rspec = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14xrp8vq6i9zx37vh0yp4h9m0anx9paw200l1r5ad9fmq559346l"; type = "gem"; }; version = "3.13.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rspec-support" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k252n7s80bvjvpskgfm285a3djjjqyjcarlh3aq7a4dx2s94xsm"; type = "gem"; }; version = "3.13.0"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0022nxs9gqfhx35n4klibig770n0j31pnkd8anz00yvrvkdghk41"; type = "gem"; }; version = "3.13.1"; }; rspec-html-matchers = { - dependencies = ["nokogiri" "rspec"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "nokogiri" + "rspec" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1bp9q28qw4xmxknrrp3ppcr08bbcnnand6r9prw4920407mvy96l"; type = "gem"; }; version = "0.10.0"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0f3vgp43hajw716vmgjv6f4ar6f97zf50snny6y3fy9kkj4qjw88"; type = "gem"; }; version = "3.13.1"; }; rspec-rails = { - dependencies = ["actionpack" "activesupport" "railties" "rspec-core" "rspec-expectations" "rspec-mocks" "rspec-support"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "railties" + "rspec-core" + "rspec-expectations" + "rspec-mocks" + "rspec-support" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0nqwvyma86zchh4ki416h7cms38h521ghyypaq27b6yvkmp3h8yw"; type = "gem"; }; version = "6.1.3"; }; rspec-support = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "03z7gpqz5xkw9rf53835pa8a9vgj4lic54rnix9vfwmp2m7pv1s8"; type = "gem"; }; version = "3.13.1"; }; rss = { - dependencies = ["rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rexml" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wv27axi39hhr0nmaffdl5bdjqiafcvp9xhfgnsgfczsblja50sn"; type = "gem"; }; version = "0.3.0"; }; rswag-specs = { - dependencies = ["activesupport" "json-schema" "railties" "rspec-core"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "json-schema" + "railties" + "rspec-core" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1iyqd95l8r8m6jna451xb20lsp0jiajk1gbw845qlyqf6d69xyx2"; type = "gem"; }; version = "2.13.0"; }; rtlcss = { - dependencies = ["mini_racer"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mini_racer" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0q5zlx1k4gqyq0rvnfkljvrwa73ysycxc5m5ly9py9k1pw05lg91"; type = "gem"; }; version = "0.2.1"; }; rubocop = { - dependencies = ["json" "language_server-protocol" "parallel" "parser" "rainbow" "regexp_parser" "rexml" "rubocop-ast" "ruby-progressbar" "unicode-display_width"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "json" + "language_server-protocol" + "parallel" + "parser" + "rainbow" + "regexp_parser" + "rexml" + "rubocop-ast" + "ruby-progressbar" + "unicode-display_width" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "18g462bccr0rvszc7kirr89laggdf6254p7pqsckk3izg901chv2"; type = "gem"; }; version = "1.65.0"; }; rubocop-ast = { - dependencies = ["parser"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "parser" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "063qgvqbyv354icl2sgx758z22wzq38hd9skc3n96sbpv0cdc1qv"; type = "gem"; }; version = "1.31.3"; }; rubocop-capybara = { - dependencies = ["rubocop"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rubocop" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1aw0n8jwhsr39r9q2k90xjmcz8ai2k7xx2a87ld0iixnv3ylw9jx"; type = "gem"; }; version = "2.21.0"; }; rubocop-discourse = { - dependencies = ["activesupport" "rubocop" "rubocop-capybara" "rubocop-factory_bot" "rubocop-rails" "rubocop-rspec" "rubocop-rspec_rails"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "rubocop" + "rubocop-capybara" + "rubocop-factory_bot" + "rubocop-rails" + "rubocop-rspec" + "rubocop-rspec_rails" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1bcy1zl88f4fxjsda2nf6k13kqrj60z8nsqdv9z51fdkv0aj82wk"; type = "gem"; }; version = "3.8.1"; }; rubocop-factory_bot = { - dependencies = ["rubocop"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rubocop" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1aljadsjx7affcarzbhz7pydpy6fgqb8hl951y0cmrffxpa3rqcd"; type = "gem"; }; version = "2.26.1"; }; rubocop-rails = { - dependencies = ["activesupport" "rack" "rubocop" "rubocop-ast"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "rack" + "rubocop" + "rubocop-ast" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "19g6m8ladix1dq8darrqnhbj6n3cgp2ivxnh48yj3nrgw0z97229"; type = "gem"; }; version = "2.25.1"; }; rubocop-rspec = { - dependencies = ["rubocop"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "rubocop" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0495y1bwv5j6r9dak7860i6qnm68c53vz2bx2js5lwm6p7py147f"; type = "gem"; }; version = "3.0.3"; }; rubocop-rspec_rails = { - dependencies = ["rubocop" "rubocop-rspec"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rubocop" + "rubocop-rspec" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ijc1kw81884k0wjq1sgwaxa854n1fdddscp4fnzfzlx7zl150c8"; type = "gem"; }; version = "2.30.0"; }; ruby-prof = { - groups = ["development"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ "development" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0hnalxnvli6248g34n0bj8p3v35vpabak34qjg778bbaavbqg5h5"; type = "gem"; }; version = "1.7.0"; }; ruby-progressbar = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cwvyb7j47m7wihpfaq7rc47zwwx9k4v7iqd9s1xch5nm53rrz40"; type = "gem"; }; version = "1.13.0"; }; ruby-readability = { - dependencies = ["guess_html_encoding" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "guess_html_encoding" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "11kqx5yp6syd99k1ksnw84b0sc3cr7icf63dibn2m025qg27ml2i"; type = "gem"; }; version = "0.7.1"; }; ruby2_keywords = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; sanitize = { - dependencies = ["crass" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "crass" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1c9j1rwdp87k7b7mawf8agpdycdr2dsl2wvjipmcy1c55kllp2qp"; type = "gem"; }; version = "6.1.2"; }; sass-embedded = { - dependencies = ["google-protobuf" "rake"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "google-protobuf" + "rake" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1nmy052pm46781s7ca6x3l4yb5p3glh8sf201xwcwpk9rv2av9m2"; type = "gem"; }; version = "1.77.5"; }; sassc-embedded = { - dependencies = ["sass-embedded"]; - groups = ["default"]; - platforms = []; + dependencies = [ "sass-embedded" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07pddxi18asxzkn652kvgh43dl1b0nf5p8ha62yhg2r0vzapzzvv"; type = "gem"; }; version = "1.77.7"; }; selenium-devtools = { - dependencies = ["selenium-webdriver"]; - groups = ["test"]; - platforms = []; + dependencies = [ "selenium-webdriver" ]; + groups = [ "test" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ph7b947h5cgqyhb5a4jk467bggx48xy619ggh6p38ys8bjszp1l"; type = "gem"; }; version = "0.126.0"; }; selenium-webdriver = { - dependencies = ["base64" "logger" "rexml" "rubyzip" "websocket"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "logger" + "rexml" + "rubyzip" + "websocket" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00dq3450kadsvxh1lpndasy0bab0ilrjhrnvlicfmkvrx3gfs2j9"; type = "gem"; }; version = "4.23.0"; }; shoulda-matchers = { - dependencies = ["activesupport"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "activesupport" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1pfq0w167v4055k0km64sxik1qslhsi32wl2jlidmfzkqmcw00m7"; type = "gem"; }; version = "6.2.0"; }; sidekiq = { - dependencies = ["connection_pool" "rack" "redis"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "connection_pool" + "rack" + "redis" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0zqr9is8y7mg5dfs1q8w5jl9spwvqkhbi9r6np8208n40hi3pydl"; type = "gem"; }; version = "6.5.12"; }; simplecov = { - dependencies = ["docile" "simplecov-html" "simplecov_json_formatter"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "docile" + "simplecov-html" + "simplecov_json_formatter" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "198kcbrjxhhzca19yrdcd6jjj9sb51aaic3b0sc3pwjghg3j49py"; type = "gem"; }; version = "0.22.0"; }; simplecov-html = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yx01bxa8pbf9ip4hagqkp5m0mqfnwnw2xk8kjraiywz4lrss6jb"; type = "gem"; }; version = "0.12.3"; }; simplecov_json_formatter = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a5l0733hj7sk51j81ykfmlk2vd5vaijlq9d5fn165yyx3xii52j"; type = "gem"; }; version = "0.1.4"; }; simpleidn = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a9c1mdy12y81ck7mcn9f9i2s2wwzjh1nr92ps354q517zq9dkh8"; type = "gem"; }; version = "0.2.3"; }; snaky_hash = { - dependencies = ["hashie" "version_gem"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "hashie" + "version_gem" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cfwvdcr46pk0c7m5aw2w3izbrp1iba0q7l21r37mzpwaz0pxj0s"; type = "gem"; }; version = "2.0.1"; }; sprockets = { - dependencies = ["base64" "concurrent-ruby" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "concurrent-ruby" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0lyc6mx4yalsnxc9yp4a5xra4nz1nwwbk5634wlfncml0ll1bnnw"; type = "gem"; }; version = "3.7.3"; }; sprockets-rails = { - dependencies = ["actionpack" "activesupport" "sprockets"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "actionpack" + "activesupport" + "sprockets" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0j7gwm749b3ff6544wxa878fpd1kvf2qc9fafassi8c7735jcin4"; type = "gem"; }; version = "3.5.1"; }; sqlite3 = { - dependencies = ["mini_portile2"]; - groups = ["generic_import"]; - platforms = []; + dependencies = [ "mini_portile2" ]; + groups = [ "generic_import" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k8myqn1g7sfmxs1h0x7jijh5ybszxw5153l0aq0w1cxp3zm6vij"; type = "gem"; }; version = "2.0.2"; }; sshkey = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1k8i5pzjhcnyf0bhcyn5iixpfp4pz0556rcxwpglh6p0sr8s6nv5"; type = "gem"; }; version = "3.0.0"; }; stackprof = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1gdqqwnampxmc54nf6zfy9apkmkpdavzipvfssmjlhnrrjy8qh7f"; type = "gem"; }; version = "0.2.26"; }; stringio = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07mfqb40b2wh53k33h91zva78f9zwcdnl85jiq74wnaw2wa6wiak"; type = "gem"; }; version = "3.1.1"; }; strscan = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0mamrl7pxacbc79ny5hzmakc9grbjysm3yy6119ppgsg44fsif01"; type = "gem"; }; version = "3.1.0"; }; syntax_tree = { - dependencies = ["prettier_print"]; - groups = ["development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "prettier_print" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0g9l9acknjr2yz8ynfxbcrwx2ws3wh96pfzdb31g66k08v1022m5"; type = "gem"; }; version = "6.2.0"; }; syntax_tree-disable_ternary = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gdi6zx4hqpxd81zas3dlw1jrdp98fvsqj4p7f42x5lhpfzz04zc"; type = "gem"; }; version = "1.0.0"; }; test-prof = { - groups = ["test"]; - platforms = []; + groups = [ "test" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lxik4ngvbphivyhss9i59c67zxkc0z7k0r683qshw1gdkfxzd8f"; type = "gem"; }; version = "1.3.3.1"; }; thor = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vq1fjp45az9hfp6fxljhdrkv75cvbab1jfrwcw738pnsiqk8zps"; type = "gem"; }; version = "1.3.1"; }; timeout = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16mvvsmx90023wrhf8dxc1lpqh0m8alk65shb7xcya6a9gflw7vg"; type = "gem"; }; version = "0.4.1"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "concurrent-ruby" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; tzinfo-data = { - dependencies = ["tzinfo"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tzinfo" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rg1dmx6mknjazb8qq0j9sb9fah470my5sbjb6f3pa6si5018682"; type = "gem"; }; version = "1.2024.1"; }; uglifier = { - dependencies = ["execjs"]; - groups = ["assets"]; - platforms = []; + dependencies = [ "execjs" ]; + groups = [ "assets" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wgh7bzy68vhv9v68061519dd8samcy8sazzz0w3k8kqpy3g4s5f"; type = "gem"; }; version = "4.2.0"; }; unf = { - dependencies = ["unf_ext"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unf_ext" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bh2cf73i2ffh4fcpdn9ir4mhq8zi50ik0zqa1braahzadx536a9"; type = "gem"; }; version = "0.1.4"; }; unf_ext = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sf6bxvf6x8gihv6j63iakixmdddgls58cpxpg32chckb2l18qcj"; type = "gem"; }; version = "0.0.9.1"; }; unicode-display_width = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1d0azx233nags5jx3fqyr23qa2rhgzbhv8pxp46dgbg1mpf82xky"; type = "gem"; }; version = "2.5.0"; }; unicorn = { - dependencies = ["kgio" "raindrops"]; - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "rbx"; - } { - engine = "ruby"; - }]; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "kgio" + "raindrops" + ]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "rbx"; + } + { + engine = "ruby"; + } + ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1h0gma14jjxiz6piyi6p99q7lya2mxrq79l03160hascvmx9ipa5"; type = "gem"; }; version = "6.1.0"; }; uniform_notifier = { - groups = ["default" "development"]; - platforms = []; + groups = [ + "default" + "development" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dfvqixshwvm82b9qwdidvnkavdj7s0fbdbmyd4knkl6l3j9xcwr"; type = "gem"; }; version = "1.16.0"; }; uri = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "094gk72ckazf495qc76gk09b5i318d5l9m7bicg2wxlrjcm3qm96"; type = "gem"; }; version = "0.13.0"; }; version_gem = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08a6agx7xk1f6cr9a95dq42vl45si2ln21h33b96li59sv3555y6"; type = "gem"; }; version = "1.1.4"; }; web-push = { - dependencies = ["jwt" "openssl"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "jwt" + "openssl" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "13diqh61rl658gwq0c2ds41z59i0x4plj5k4v98qkgd3pgrd4kav"; type = "gem"; }; version = "3.0.1"; }; webmock = { - dependencies = ["addressable" "crack" "hashdiff"]; - groups = ["test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "crack" + "hashdiff" + ]; + groups = [ "test" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "158d2ikjfzw43kgm095klp43ihphk0cv5xjprk44w73xfv03i9qg"; type = "gem"; }; version = "3.23.1"; }; webrick = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "13qm7s0gr2pmfcl7dxrmq38asaza4w0i2n9my4yzs499j731wh8r"; type = "gem"; }; version = "1.8.1"; }; websocket = { - groups = ["default" "test"]; - platforms = []; + groups = [ + "default" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dr78vh3ag0d1q5gfd8960g1ca9g6arjd2w54mffid8h4i7agrxp"; type = "gem"; }; version = "1.2.11"; }; xpath = { - dependencies = ["nokogiri"]; - groups = ["default" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ "nokogiri" ]; + groups = [ + "default" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0bh8lk9hvlpn7vmi6h4hkcwjzvs2y0cmkk3yjjdr8fxvj6fsgzbd"; type = "gem"; }; version = "3.2.0"; }; yaml-lint = { - groups = ["development"]; - platforms = []; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12jc68af2mwdkr9iqay2v6qgq47yk5g82sd171riibk62wbhp5p3"; type = "gem"; }; version = "0.1.2"; }; yard = { - groups = ["development"]; - platforms = []; + groups = [ "development" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1r0b8w58p7gy06wph1qdjv2p087hfnmhd9jk23vjdj803dn761am"; type = "gem"; }; version = "0.9.36"; }; zeitwerk = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08cfb35232p9s1r4jqv8wacv38vxh699mgbr9y03ga89gx9lipqp"; type = "gem"; }; diff --git a/pkgs/servers/web-apps/ethercalc/default.nix b/pkgs/servers/web-apps/ethercalc/default.nix index 9c7e160e6c427f..5b2af5aed37f91 100644 --- a/pkgs/servers/web-apps/ethercalc/default.nix +++ b/pkgs/servers/web-apps/ethercalc/default.nix @@ -1,7 +1,8 @@ -{ stdenv -, pkgs -, lib -, nodejs_20 +{ + stdenv, + pkgs, + lib, + nodejs_20, }: let @@ -17,11 +18,18 @@ let combined = ethercalc.override { meta = with lib; { description = "Online collaborative spreadsheet"; - license = with licenses; [ cpal10 artistic2 mit asl20 cc0 mpl20 ]; + license = with licenses; [ + cpal10 + artistic2 + mit + asl20 + cc0 + mpl20 + ]; homepage = "https://github.com/audreyt/ethercalc"; maintainers = with maintainers; [ iblech ]; platforms = platforms.unix; }; }; in - combined +combined diff --git a/pkgs/servers/web-apps/ethercalc/node-packages-generated.nix b/pkgs/servers/web-apps/ethercalc/node-packages-generated.nix index 3baba4ac727a8a..b3aa97ff3a4902 100644 --- a/pkgs/servers/web-apps/ethercalc/node-packages-generated.nix +++ b/pkgs/servers/web-apps/ethercalc/node-packages-generated.nix @@ -1,6 +1,14 @@ # This file has been generated by node2nix 1.11.1. Do not edit! -{nodeEnv, fetchurl, fetchgit, nix-gitignore, stdenv, lib, globalBuildInputs ? []}: +{ + nodeEnv, + fetchurl, + fetchgit, + nix-gitignore, + stdenv, + lib, + globalBuildInputs ? [ ], +}: let sources = { @@ -1716,16 +1724,17 @@ let sha512 = "C3SsHOLbx05UCN4iRW6iL/JdO1XyPzv7XzNmLInfo2jVfZAL2XoJx3fj5q8fIZZaHI7/7uYqToQzHmHIyWTOJw=="; }; }; - "xmlhttprequest-https://github.com/LearnBoost/node-XMLHttpRequest/archive/0f36d0b5ebc03d85f860d42a64ae9791e1daa433.tar.gz" = { - name = "xmlhttprequest"; - packageName = "xmlhttprequest"; - version = "1.5.0"; - src = fetchurl { - name = "xmlhttprequest-1.5.0.tar.gz"; - url = "https://codeload.github.com/LearnBoost/node-XMLHttpRequest/tar.gz/0f36d0b5ebc03d85f860d42a64ae9791e1daa433"; - sha256 = "28dd0394d85befe8be4e9cd9f6803102780c62cbb09298cb174b52ff9777624f"; + "xmlhttprequest-https://github.com/LearnBoost/node-XMLHttpRequest/archive/0f36d0b5ebc03d85f860d42a64ae9791e1daa433.tar.gz" = + { + name = "xmlhttprequest"; + packageName = "xmlhttprequest"; + version = "1.5.0"; + src = fetchurl { + name = "xmlhttprequest-1.5.0.tar.gz"; + url = "https://codeload.github.com/LearnBoost/node-XMLHttpRequest/tar.gz/0f36d0b5ebc03d85f860d42a64ae9791e1daa433"; + sha256 = "28dd0394d85befe8be4e9cd9f6803102780c62cbb09298cb174b52ff9777624f"; + }; }; - }; "xoauth2-1.2.0" = { name = "xoauth2"; packageName = "xoauth2"; @@ -1747,307 +1756,386 @@ let }; in { - "whitebophir-git+https://github.com/audreyt/ethercalc.git#b196277081d677be991d104e454a52d242ef0189" = nodeEnv.buildNodePackage { - name = "ethercalc"; - packageName = "ethercalc"; - version = "0.20201228.1"; - src = fetchgit { - url = "https://github.com/audreyt/ethercalc.git"; - rev = "b196277081d677be991d104e454a52d242ef0189"; - sha256 = "4494bada571057d86009f27470cc34f1e8a3b2c03b395cdba639c08d502a9bfe"; - }; - dependencies = [ - sources."accepts-1.0.7" - sources."adler-32-1.2.0" - sources."after-0.8.1" - sources."amdefine-1.0.1" - sources."any-promise-1.3.0" - sources."arraybuffer.slice-0.0.6" - sources."async-0.2.10" - sources."babyparse-0.2.1" - sources."balanced-match-1.0.2" - sources."base64-arraybuffer-0.1.2" - sources."base64-url-1.2.1" - sources."base64id-0.1.0" - sources."basic-auth-1.0.0" - sources."basic-auth-connect-1.0.0" - sources."batch-0.5.1" - sources."better-assert-1.0.2" - sources."blob-0.0.2" - (sources."body-parser-1.6.7" // { - dependencies = [ - sources."iconv-lite-0.4.4" - ]; - }) - sources."brace-expansion-2.0.1" - sources."buffer-crc32-0.2.3" - sources."buffer-from-1.1.2" - sources."bytes-1.0.0" - sources."callsite-1.0.0" - (sources."cfb-1.2.2" // { - dependencies = [ - sources."adler-32-1.3.1" - ]; - }) - (sources."codepage-1.14.0" // { - dependencies = [ - sources."commander-2.14.1" - ]; - }) - sources."coffee-css-0.0.5" - sources."coffee-script-1.12.7" - (sources."coffeecup-0.3.21" // { - dependencies = [ - sources."uglify-js-1.2.6" - ]; - }) - sources."colors-0.6.2" - sources."commander-2.17.1" - sources."component-bind-1.0.0" - sources."component-emitter-1.1.2" - sources."component-inherit-0.0.3" - sources."compressible-1.1.1" - (sources."compression-1.0.11" // { - dependencies = [ - sources."vary-1.0.1" - ]; - }) - sources."concat-stream-2.0.0" - sources."connect-2.25.9" - sources."connect-timeout-1.2.2" - sources."cookie-0.1.2" - sources."cookie-parser-1.3.2" - sources."cookie-signature-1.0.4" - sources."core-util-is-1.0.3" - sources."cors-2.8.5" - sources."crc-32-1.2.2" - sources."csrf-2.0.7" - sources."cssom-0.2.5" - sources."csurf-1.4.1" - sources."csv-parse-0.0.6" - sources."debug-1.0.4" - sources."deep-is-0.1.4" - sources."depd-0.4.4" - sources."destroy-1.0.3" - sources."ee-first-1.0.5" - sources."emitter-http://github.com/component/emitter/archive/1.0.1.tar.gz" - (sources."engine.io-1.3.1" // { - dependencies = [ - sources."debug-0.6.0" - ]; - }) - (sources."engine.io-client-1.3.1" // { - dependencies = [ - sources."debug-0.7.4" - ]; - }) - sources."engine.io-parser-1.0.6" - sources."errorhandler-1.1.1" - sources."escape-html-1.0.1" - sources."exit-on-epipe-1.0.1" - (sources."express-3.16.9" // { - dependencies = [ - sources."commander-1.3.2" - sources."vary-0.1.0" - ]; - }) - (sources."express-session-1.7.6" // { - dependencies = [ - sources."uid-safe-1.0.1" - ]; - }) - sources."fast-levenshtein-2.0.6" - sources."finalhandler-0.1.0" - sources."frac-1.1.2" - sources."fresh-0.2.2" - sources."global-https://github.com/component/global/archive/v2.0.1.tar.gz" - sources."graceful-readlink-1.0.1" - (sources."harb-0.1.1" // { - dependencies = [ - sources."frac-0.3.1" - sources."ssf-0.8.2" - ]; - }) - sources."has-binary-data-0.1.1" - sources."has-cors-1.0.3" - sources."iconv-lite-0.4.24" - sources."indexof-0.0.1" - sources."inherits-2.0.4" - sources."ipaddr.js-0.1.2" - sources."isarray-0.0.1" - (sources."j-0.4.5" // { - dependencies = [ - sources."adler-32-1.0.0" - sources."cfb-0.11.1" - sources."codepage-1.8.1" - sources."crc-32-1.0.2" - sources."frac-1.0.6" - sources."ssf-0.9.4" - (sources."xlsx-0.9.13" // { + "whitebophir-git+https://github.com/audreyt/ethercalc.git#b196277081d677be991d104e454a52d242ef0189" = + nodeEnv.buildNodePackage { + name = "ethercalc"; + packageName = "ethercalc"; + version = "0.20201228.1"; + src = fetchgit { + url = "https://github.com/audreyt/ethercalc.git"; + rev = "b196277081d677be991d104e454a52d242ef0189"; + sha256 = "4494bada571057d86009f27470cc34f1e8a3b2c03b395cdba639c08d502a9bfe"; + }; + dependencies = [ + sources."accepts-1.0.7" + sources."adler-32-1.2.0" + sources."after-0.8.1" + sources."amdefine-1.0.1" + sources."any-promise-1.3.0" + sources."arraybuffer.slice-0.0.6" + sources."async-0.2.10" + sources."babyparse-0.2.1" + sources."balanced-match-1.0.2" + sources."base64-arraybuffer-0.1.2" + sources."base64-url-1.2.1" + sources."base64id-0.1.0" + sources."basic-auth-1.0.0" + sources."basic-auth-connect-1.0.0" + sources."batch-0.5.1" + sources."better-assert-1.0.2" + sources."blob-0.0.2" + ( + sources."body-parser-1.6.7" + // { dependencies = [ - sources."commander-2.9.0" + sources."iconv-lite-0.4.4" ]; - }) - ]; - }) - sources."json3-3.2.6" - sources."keypress-0.1.0" - sources."levn-0.3.0" - sources."livescript-1.5.0" - sources."media-typer-0.2.0" - sources."merge-descriptors-0.0.2" - (sources."method-override-2.1.3" // { - dependencies = [ - sources."vary-1.0.1" - ]; - }) - sources."methods-1.1.0" - sources."mime-1.2.11" - sources."mime-types-1.0.2" - sources."minimatch-9.0.0" - sources."minimist-0.0.10" - (sources."mkdirp-0.5.0" // { - dependencies = [ - sources."minimist-0.0.8" - ]; - }) - sources."morgan-1.2.3" - sources."ms-0.6.2" - (sources."multiparty-3.3.2" // { - dependencies = [ - sources."readable-stream-1.1.14" - sources."string_decoder-0.10.31" - ]; - }) - sources."mz-1.3.0" - sources."nan-0.3.2" - sources."native-or-bluebird-1.1.2" - sources."negotiator-0.4.7" - sources."node-uuid-1.4.1" - sources."object-assign-4.1.1" - sources."object-component-0.0.3" - sources."on-finished-2.1.0" - sources."on-headers-1.0.2" - sources."optimist-0.6.1" - sources."optionator-0.8.3" - sources."options-0.0.6" - sources."optparse-1.0.3" - sources."parsejson-0.0.1" - sources."parseqs-0.0.2" - sources."parseuri-0.0.2" - sources."parseurl-1.3.3" - sources."pause-0.0.1" - sources."prelude-ls-1.1.2" - sources."printj-1.1.2" - sources."proxy-addr-1.0.1" - sources."qs-2.2.2" - sources."range-parser-1.0.0" - (sources."raw-body-1.3.0" // { - dependencies = [ - sources."iconv-lite-0.4.4" - ]; - }) - sources."readable-stream-3.6.2" - sources."redis-0.12.1" - sources."response-time-2.0.1" - sources."rndm-1.1.1" - sources."safe-buffer-5.2.1" - sources."safer-buffer-2.1.2" - sources."scmp-1.0.0" - sources."send-0.8.3" - sources."serve-favicon-2.0.1" - sources."serve-index-1.1.6" - (sources."serve-static-1.5.4" // { - dependencies = [ - sources."send-0.8.5" - ]; - }) - sources."socialcalc-2.3.0" - (sources."socket.io-1.0.6" // { - dependencies = [ - sources."debug-0.7.4" - ]; - }) - (sources."socket.io-adapter-0.2.0" // { - dependencies = [ - sources."debug-0.7.4" - sources."emitter-http://github.com/component/emitter/archive/1.0.1.tar.gz" - sources."socket.io-parser-2.1.2" - ]; - }) - (sources."socket.io-client-1.0.6" // { - dependencies = [ - sources."debug-0.7.4" - ]; - }) - (sources."socket.io-parser-2.2.0" // { - dependencies = [ - sources."debug-0.7.4" - ]; - }) - sources."source-map-0.5.7" - sources."ssf-0.10.3" - (sources."stream-counter-0.2.0" // { - dependencies = [ - sources."readable-stream-1.1.14" - sources."string_decoder-0.10.31" - ]; - }) - sources."string_decoder-1.3.0" - (sources."stylus-0.27.2" // { - dependencies = [ - sources."mkdirp-0.3.5" - ]; - }) - sources."thenify-3.3.1" - sources."thenify-all-1.6.0" - sources."tinycolor-0.0.1" - sources."to-array-0.1.3" - sources."type-check-0.3.2" - sources."type-is-1.3.2" - sources."typedarray-0.0.6" - (sources."uglify-js-2.4.15" // { - dependencies = [ - sources."optimist-0.3.7" - sources."source-map-0.1.34" - ]; - }) - sources."uglify-to-browserify-1.0.2" - sources."uid-safe-1.1.0" - sources."underscore-1.13.6" - sources."utf8-2.0.0" - sources."util-deprecate-1.0.2" - sources."utils-merge-1.0.0" - sources."uuid-pure-1.0.10" - sources."vary-1.1.2" - sources."vhost-2.0.0" - sources."voc-1.2.0" - sources."word-wrap-1.2.3" - sources."wordwrap-0.0.3" - (sources."ws-0.4.31" // { - dependencies = [ - sources."commander-0.6.1" - ]; - }) - (sources."xlsjs-0.7.6" // { - dependencies = [ - sources."cfb-0.11.1" - sources."frac-0.3.1" - sources."ssf-0.8.2" - ]; - }) - sources."xlsx-0.14.5" - sources."xmlhttprequest-https://github.com/LearnBoost/node-XMLHttpRequest/archive/0f36d0b5ebc03d85f860d42a64ae9791e1daa433.tar.gz" - sources."xoauth2-1.2.0" - sources."zappajs-0.5.0" - ]; - buildInputs = globalBuildInputs; - meta = { - description = "Multi-User Spreadsheet Server"; - homepage = "http://ethercalc.net/"; - }; - production = true; - bypassCache = true; - reconstructLock = true; - }; + } + ) + sources."brace-expansion-2.0.1" + sources."buffer-crc32-0.2.3" + sources."buffer-from-1.1.2" + sources."bytes-1.0.0" + sources."callsite-1.0.0" + ( + sources."cfb-1.2.2" + // { + dependencies = [ + sources."adler-32-1.3.1" + ]; + } + ) + ( + sources."codepage-1.14.0" + // { + dependencies = [ + sources."commander-2.14.1" + ]; + } + ) + sources."coffee-css-0.0.5" + sources."coffee-script-1.12.7" + ( + sources."coffeecup-0.3.21" + // { + dependencies = [ + sources."uglify-js-1.2.6" + ]; + } + ) + sources."colors-0.6.2" + sources."commander-2.17.1" + sources."component-bind-1.0.0" + sources."component-emitter-1.1.2" + sources."component-inherit-0.0.3" + sources."compressible-1.1.1" + ( + sources."compression-1.0.11" + // { + dependencies = [ + sources."vary-1.0.1" + ]; + } + ) + sources."concat-stream-2.0.0" + sources."connect-2.25.9" + sources."connect-timeout-1.2.2" + sources."cookie-0.1.2" + sources."cookie-parser-1.3.2" + sources."cookie-signature-1.0.4" + sources."core-util-is-1.0.3" + sources."cors-2.8.5" + sources."crc-32-1.2.2" + sources."csrf-2.0.7" + sources."cssom-0.2.5" + sources."csurf-1.4.1" + sources."csv-parse-0.0.6" + sources."debug-1.0.4" + sources."deep-is-0.1.4" + sources."depd-0.4.4" + sources."destroy-1.0.3" + sources."ee-first-1.0.5" + sources."emitter-http://github.com/component/emitter/archive/1.0.1.tar.gz" + ( + sources."engine.io-1.3.1" + // { + dependencies = [ + sources."debug-0.6.0" + ]; + } + ) + ( + sources."engine.io-client-1.3.1" + // { + dependencies = [ + sources."debug-0.7.4" + ]; + } + ) + sources."engine.io-parser-1.0.6" + sources."errorhandler-1.1.1" + sources."escape-html-1.0.1" + sources."exit-on-epipe-1.0.1" + ( + sources."express-3.16.9" + // { + dependencies = [ + sources."commander-1.3.2" + sources."vary-0.1.0" + ]; + } + ) + ( + sources."express-session-1.7.6" + // { + dependencies = [ + sources."uid-safe-1.0.1" + ]; + } + ) + sources."fast-levenshtein-2.0.6" + sources."finalhandler-0.1.0" + sources."frac-1.1.2" + sources."fresh-0.2.2" + sources."global-https://github.com/component/global/archive/v2.0.1.tar.gz" + sources."graceful-readlink-1.0.1" + ( + sources."harb-0.1.1" + // { + dependencies = [ + sources."frac-0.3.1" + sources."ssf-0.8.2" + ]; + } + ) + sources."has-binary-data-0.1.1" + sources."has-cors-1.0.3" + sources."iconv-lite-0.4.24" + sources."indexof-0.0.1" + sources."inherits-2.0.4" + sources."ipaddr.js-0.1.2" + sources."isarray-0.0.1" + ( + sources."j-0.4.5" + // { + dependencies = [ + sources."adler-32-1.0.0" + sources."cfb-0.11.1" + sources."codepage-1.8.1" + sources."crc-32-1.0.2" + sources."frac-1.0.6" + sources."ssf-0.9.4" + ( + sources."xlsx-0.9.13" + // { + dependencies = [ + sources."commander-2.9.0" + ]; + } + ) + ]; + } + ) + sources."json3-3.2.6" + sources."keypress-0.1.0" + sources."levn-0.3.0" + sources."livescript-1.5.0" + sources."media-typer-0.2.0" + sources."merge-descriptors-0.0.2" + ( + sources."method-override-2.1.3" + // { + dependencies = [ + sources."vary-1.0.1" + ]; + } + ) + sources."methods-1.1.0" + sources."mime-1.2.11" + sources."mime-types-1.0.2" + sources."minimatch-9.0.0" + sources."minimist-0.0.10" + ( + sources."mkdirp-0.5.0" + // { + dependencies = [ + sources."minimist-0.0.8" + ]; + } + ) + sources."morgan-1.2.3" + sources."ms-0.6.2" + ( + sources."multiparty-3.3.2" + // { + dependencies = [ + sources."readable-stream-1.1.14" + sources."string_decoder-0.10.31" + ]; + } + ) + sources."mz-1.3.0" + sources."nan-0.3.2" + sources."native-or-bluebird-1.1.2" + sources."negotiator-0.4.7" + sources."node-uuid-1.4.1" + sources."object-assign-4.1.1" + sources."object-component-0.0.3" + sources."on-finished-2.1.0" + sources."on-headers-1.0.2" + sources."optimist-0.6.1" + sources."optionator-0.8.3" + sources."options-0.0.6" + sources."optparse-1.0.3" + sources."parsejson-0.0.1" + sources."parseqs-0.0.2" + sources."parseuri-0.0.2" + sources."parseurl-1.3.3" + sources."pause-0.0.1" + sources."prelude-ls-1.1.2" + sources."printj-1.1.2" + sources."proxy-addr-1.0.1" + sources."qs-2.2.2" + sources."range-parser-1.0.0" + ( + sources."raw-body-1.3.0" + // { + dependencies = [ + sources."iconv-lite-0.4.4" + ]; + } + ) + sources."readable-stream-3.6.2" + sources."redis-0.12.1" + sources."response-time-2.0.1" + sources."rndm-1.1.1" + sources."safe-buffer-5.2.1" + sources."safer-buffer-2.1.2" + sources."scmp-1.0.0" + sources."send-0.8.3" + sources."serve-favicon-2.0.1" + sources."serve-index-1.1.6" + ( + sources."serve-static-1.5.4" + // { + dependencies = [ + sources."send-0.8.5" + ]; + } + ) + sources."socialcalc-2.3.0" + ( + sources."socket.io-1.0.6" + // { + dependencies = [ + sources."debug-0.7.4" + ]; + } + ) + ( + sources."socket.io-adapter-0.2.0" + // { + dependencies = [ + sources."debug-0.7.4" + sources."emitter-http://github.com/component/emitter/archive/1.0.1.tar.gz" + sources."socket.io-parser-2.1.2" + ]; + } + ) + ( + sources."socket.io-client-1.0.6" + // { + dependencies = [ + sources."debug-0.7.4" + ]; + } + ) + ( + sources."socket.io-parser-2.2.0" + // { + dependencies = [ + sources."debug-0.7.4" + ]; + } + ) + sources."source-map-0.5.7" + sources."ssf-0.10.3" + ( + sources."stream-counter-0.2.0" + // { + dependencies = [ + sources."readable-stream-1.1.14" + sources."string_decoder-0.10.31" + ]; + } + ) + sources."string_decoder-1.3.0" + ( + sources."stylus-0.27.2" + // { + dependencies = [ + sources."mkdirp-0.3.5" + ]; + } + ) + sources."thenify-3.3.1" + sources."thenify-all-1.6.0" + sources."tinycolor-0.0.1" + sources."to-array-0.1.3" + sources."type-check-0.3.2" + sources."type-is-1.3.2" + sources."typedarray-0.0.6" + ( + sources."uglify-js-2.4.15" + // { + dependencies = [ + sources."optimist-0.3.7" + sources."source-map-0.1.34" + ]; + } + ) + sources."uglify-to-browserify-1.0.2" + sources."uid-safe-1.1.0" + sources."underscore-1.13.6" + sources."utf8-2.0.0" + sources."util-deprecate-1.0.2" + sources."utils-merge-1.0.0" + sources."uuid-pure-1.0.10" + sources."vary-1.1.2" + sources."vhost-2.0.0" + sources."voc-1.2.0" + sources."word-wrap-1.2.3" + sources."wordwrap-0.0.3" + ( + sources."ws-0.4.31" + // { + dependencies = [ + sources."commander-0.6.1" + ]; + } + ) + ( + sources."xlsjs-0.7.6" + // { + dependencies = [ + sources."cfb-0.11.1" + sources."frac-0.3.1" + sources."ssf-0.8.2" + ]; + } + ) + sources."xlsx-0.14.5" + sources."xmlhttprequest-https://github.com/LearnBoost/node-XMLHttpRequest/archive/0f36d0b5ebc03d85f860d42a64ae9791e1daa433.tar.gz" + sources."xoauth2-1.2.0" + sources."zappajs-0.5.0" + ]; + buildInputs = globalBuildInputs; + meta = { + description = "Multi-User Spreadsheet Server"; + homepage = "http://ethercalc.net/"; + }; + production = true; + bypassCache = true; + reconstructLock = true; + }; } diff --git a/pkgs/servers/web-apps/ethercalc/node-packages.nix b/pkgs/servers/web-apps/ethercalc/node-packages.nix index 0a4e2b7c9aba74..1042cdba2cb661 100644 --- a/pkgs/servers/web-apps/ethercalc/node-packages.nix +++ b/pkgs/servers/web-apps/ethercalc/node-packages.nix @@ -1,17 +1,34 @@ # This file has been generated by node2nix 1.11.1. Do not edit! -{pkgs ? import { +{ + pkgs ? import { inherit system; - }, system ? builtins.currentSystem, nodejs ? pkgs."nodejs_20"}: + }, + system ? builtins.currentSystem, + nodejs ? pkgs."nodejs_20", +}: let nodeEnv = import ../../../development/node-packages/node-env.nix { - inherit (pkgs) stdenv lib python2 runCommand writeTextFile writeShellScript; + inherit (pkgs) + stdenv + lib + python2 + runCommand + writeTextFile + writeShellScript + ; inherit pkgs nodejs; libtool = if pkgs.stdenv.hostPlatform.isDarwin then pkgs.cctools or pkgs.darwin.cctools else null; }; in import ./node-packages-generated.nix { - inherit (pkgs) fetchurl nix-gitignore stdenv lib fetchgit; + inherit (pkgs) + fetchurl + nix-gitignore + stdenv + lib + fetchgit + ; inherit nodeEnv; } diff --git a/pkgs/servers/web-apps/freshrss/extensions/default.nix b/pkgs/servers/web-apps/freshrss/extensions/default.nix index deb8d4de471fed..f22c5279e75743 100644 --- a/pkgs/servers/web-apps/freshrss/extensions/default.nix +++ b/pkgs/servers/web-apps/freshrss/extensions/default.nix @@ -1,8 +1,9 @@ -{ config -, lib -, fetchFromGitHub -, fetchFromGitLab -, callPackage +{ + config, + lib, + fetchFromGitHub, + fetchFromGitLab, + callPackage, }: let @@ -133,6 +134,7 @@ let toFix = lib.foldl' (lib.flip lib.extends) baseExtensions overlays; in -(lib.fix toFix) // { +(lib.fix toFix) +// { inherit buildFreshRssExtension; } diff --git a/pkgs/servers/web-apps/freshrss/extensions/freshrss-utils.nix b/pkgs/servers/web-apps/freshrss/extensions/freshrss-utils.nix index bd0fc8f6de546f..6cbb443bf946ac 100644 --- a/pkgs/servers/web-apps/freshrss/extensions/freshrss-utils.nix +++ b/pkgs/servers/web-apps/freshrss/extensions/freshrss-utils.nix @@ -1,44 +1,56 @@ { stdenv, unzip }: let buildFreshRssExtension = - args@{ pname - , version - , src - , FreshRssExtUniqueId - , configurePhase ? '' + args@{ + pname, + version, + src, + FreshRssExtUniqueId, + configurePhase ? '' runHook preConfigure runHook postConfigure - '' - , buildPhase ? '' + '', + buildPhase ? '' runHook preBuild runHook postBuild - '' - , dontPatchELF ? true - , dontStrip ? true - , passthru ? { } - , sourceRoot ? "source" - , ... + '', + dontPatchELF ? true, + dontStrip ? true, + passthru ? { }, + sourceRoot ? "source", + ... }: - stdenv.mkDerivation ((removeAttrs args [ "FreshRssExtUniqueId" ]) // { - pname = "freshrss-extension-${pname}"; + stdenv.mkDerivation ( + (removeAttrs args [ "FreshRssExtUniqueId" ]) + // { + pname = "freshrss-extension-${pname}"; - inherit version src configurePhase buildPhase dontPatchELF dontStrip sourceRoot; + inherit + version + src + configurePhase + buildPhase + dontPatchELF + dontStrip + sourceRoot + ; - installPrefix = "share/freshrss/extensions/xExtension-${FreshRssExtUniqueId}"; + installPrefix = "share/freshrss/extensions/xExtension-${FreshRssExtUniqueId}"; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p "$out/$installPrefix" - find . -mindepth 1 -maxdepth 1 | xargs -d'\n' mv -t "$out/$installPrefix/" + mkdir -p "$out/$installPrefix" + find . -mindepth 1 -maxdepth 1 | xargs -d'\n' mv -t "$out/$installPrefix/" - runHook postInstall - ''; + runHook postInstall + ''; - passthru = passthru // { - inherit FreshRssExtUniqueId; - }; - }); + passthru = passthru // { + inherit FreshRssExtUniqueId; + }; + } + ); in { inherit buildFreshRssExtension; diff --git a/pkgs/servers/web-apps/jitsi-meet/default.nix b/pkgs/servers/web-apps/jitsi-meet/default.nix index fe7b6ba66c6087..5702b0b9299b92 100644 --- a/pkgs/servers/web-apps/jitsi-meet/default.nix +++ b/pkgs/servers/web-apps/jitsi-meet/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, nixosTests, olm }: +{ + lib, + stdenv, + fetchurl, + nixosTests, + olm, +}: stdenv.mkDerivation rec { pname = "jitsi-meet"; diff --git a/pkgs/servers/web-apps/lemmy/server.nix b/pkgs/servers/web-apps/lemmy/server.nix index 8c9407afff4442..6a8bd6f06daf3a 100644 --- a/pkgs/servers/web-apps/lemmy/server.nix +++ b/pkgs/servers/web-apps/lemmy/server.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, openssl -, postgresql -, libiconv -, Security -, SystemConfiguration -, protobuf -, rustfmt -, nixosTests +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + openssl, + postgresql, + libiconv, + Security, + SystemConfiguration, + protobuf, + rustfmt, + nixosTests, }: let pinData = lib.importJSON ./pin.json; @@ -33,8 +34,13 @@ rustPlatform.buildRustPackage rec { cargoHash = pinData.serverCargoHash; - buildInputs = [ postgresql ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv Security SystemConfiguration ]; + buildInputs = + [ postgresql ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Security + SystemConfiguration + ]; # Using OPENSSL_NO_VENDOR is not an option on darwin # As of version 0.10.35 rust-openssl looks for openssl on darwin @@ -45,7 +51,10 @@ rustPlatform.buildRustPackage rec { PROTOC = "${protobuf}/bin/protoc"; PROTOC_INCLUDE = "${protobuf}/include"; - nativeBuildInputs = [ protobuf rustfmt ]; + nativeBuildInputs = [ + protobuf + rustfmt + ]; checkFlags = [ # test requires database access @@ -63,7 +72,11 @@ rustPlatform.buildRustPackage rec { description = "🐀 Building a federated alternative to reddit in rust"; homepage = "https://join-lemmy.org/"; license = licenses.agpl3Only; - maintainers = with maintainers; [ happysalada billewanick georgyo ]; + maintainers = with maintainers; [ + happysalada + billewanick + georgyo + ]; mainProgram = "lemmy_server"; }; } diff --git a/pkgs/servers/web-apps/lemmy/ui.nix b/pkgs/servers/web-apps/lemmy/ui.nix index ab103921114b7e..b423bcd8748fb4 100644 --- a/pkgs/servers/web-apps/lemmy/ui.nix +++ b/pkgs/servers/web-apps/lemmy/ui.nix @@ -1,17 +1,17 @@ -{ lib -, stdenvNoCC -, libsass -, nodejs -, pnpm_9 -, fetchFromGitHub -, nixosTests -, vips +{ + lib, + stdenvNoCC, + libsass, + nodejs, + pnpm_9, + fetchFromGitHub, + nixosTests, + vips, }: let pinData = lib.importJSON ./pin.json; - in stdenvNoCC.mkDerivation (finalAttrs: { @@ -19,20 +19,25 @@ stdenvNoCC.mkDerivation (finalAttrs: { pname = "lemmy-ui"; version = pinData.uiVersion; - src = with finalAttrs; fetchFromGitHub { - owner = "LemmyNet"; - repo = pname; - rev = version; - fetchSubmodules = true; - hash = pinData.uiHash; - }; + src = + with finalAttrs; + fetchFromGitHub { + owner = "LemmyNet"; + repo = pname; + rev = version; + fetchSubmodules = true; + hash = pinData.uiHash; + }; nativeBuildInputs = [ nodejs pnpm_9.configHook ]; - buildInputs = [libsass vips ]; + buildInputs = [ + libsass + vips + ]; extraBuildInputs = [ libsass ]; pnpmDeps = pnpm_9.fetchDeps { @@ -71,7 +76,6 @@ stdenvNoCC.mkDerivation (finalAttrs: { done ''; - distPhase = "true"; passthru.updateScript = ./update.py; @@ -82,7 +86,11 @@ stdenvNoCC.mkDerivation (finalAttrs: { description = "Building a federated alternative to reddit in rust"; homepage = "https://join-lemmy.org/"; license = licenses.agpl3Only; - maintainers = with maintainers; [ happysalada billewanick georgyo ]; + maintainers = with maintainers; [ + happysalada + billewanick + georgyo + ]; inherit (nodejs.meta) platforms; }; }) diff --git a/pkgs/servers/web-apps/livebook/default.nix b/pkgs/servers/web-apps/livebook/default.nix index 6429079b3747b2..c346aa664be095 100644 --- a/pkgs/servers/web-apps/livebook/default.nix +++ b/pkgs/servers/web-apps/livebook/default.nix @@ -1,4 +1,13 @@ -{ lib, beamPackages, makeWrapper, rebar3, elixir, erlang, fetchFromGitHub, nixosTests }: +{ + lib, + beamPackages, + makeWrapper, + rebar3, + elixir, + erlang, + fetchFromGitHub, + nixosTests, +}: beamPackages.mixRelease rec { pname = "livebook"; version = "0.14.4"; @@ -24,9 +33,14 @@ beamPackages.mixRelease rec { postInstall = '' wrapProgram $out/bin/livebook \ - --prefix PATH : ${lib.makeBinPath [ elixir erlang ]} \ + --prefix PATH : ${ + lib.makeBinPath [ + elixir + erlang + ] + } \ --set MIX_REBAR3 ${rebar3}/bin/rebar3 - ''; + ''; passthru.tests = { livebook-service = nixosTests.livebook-service; @@ -36,7 +50,10 @@ beamPackages.mixRelease rec { license = licenses.asl20; homepage = "https://livebook.dev/"; description = "Automate code & data workflows with interactive Elixir notebooks"; - maintainers = with maintainers; [ munksgaard scvalex ]; + maintainers = with maintainers; [ + munksgaard + scvalex + ]; platforms = platforms.unix; }; } diff --git a/pkgs/servers/web-apps/moodle/moodle-utils.nix b/pkgs/servers/web-apps/moodle/moodle-utils.nix index 090d87cb1ee833..eb818f84eb03e8 100644 --- a/pkgs/servers/web-apps/moodle/moodle-utils.nix +++ b/pkgs/servers/web-apps/moodle/moodle-utils.nix @@ -1,33 +1,38 @@ { stdenv, unzip, ... }: let - buildMoodlePlugin = a@{ - name, - src, - pluginType, - configurePhase ? ":", - buildPhase ? ":", - buildInputs ? [ ], - nativeBuildInputs ? [ ], - ... - }: - stdenv.mkDerivation (a // { - name = name; + buildMoodlePlugin = + a@{ + name, + src, + pluginType, + configurePhase ? ":", + buildPhase ? ":", + buildInputs ? [ ], + nativeBuildInputs ? [ ], + ... + }: + stdenv.mkDerivation ( + a + // { + name = name; - inherit pluginType; - inherit configurePhase buildPhase buildInputs; + inherit pluginType; + inherit configurePhase buildPhase buildInputs; - nativeBuildInputs = [ unzip ] ++ nativeBuildInputs; + nativeBuildInputs = [ unzip ] ++ nativeBuildInputs; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p "$out" - mv * $out/ + mkdir -p "$out" + mv * $out/ - runHook postInstall - ''; - }); -in { + runHook postInstall + ''; + } + ); +in +{ inherit buildMoodlePlugin; } diff --git a/pkgs/servers/web-apps/netbox/generic.nix b/pkgs/servers/web-apps/netbox/generic.nix index c7a5225a66e303..23e9e20095ea25 100644 --- a/pkgs/servers/web-apps/netbox/generic.nix +++ b/pkgs/servers/web-apps/netbox/generic.nix @@ -1,113 +1,119 @@ -{ lib -, fetchFromGitHub -, python3 -, version -, hash -, plugins ? ps: [] -, extraPatches ? [] -, tests ? {} -, maintainers ? [] -, eol ? false +{ + lib, + fetchFromGitHub, + python3, + version, + hash, + plugins ? ps: [ ], + extraPatches ? [ ], + tests ? { }, + maintainers ? [ ], + eol ? false, }: - let - extraBuildInputs = plugins python3.pkgs; - in - python3.pkgs.buildPythonApplication rec { - pname = "netbox"; - inherit version; +let + extraBuildInputs = plugins python3.pkgs; +in +python3.pkgs.buildPythonApplication rec { + pname = "netbox"; + inherit version; - format = "other"; + format = "other"; - src = fetchFromGitHub { - owner = "netbox-community"; - repo = pname; - rev = "refs/tags/v${version}"; - inherit hash; - }; + src = fetchFromGitHub { + owner = "netbox-community"; + repo = pname; + rev = "refs/tags/v${version}"; + inherit hash; + }; - patches = extraPatches; + patches = extraPatches; - propagatedBuildInputs = with python3.pkgs; [ - bleach - boto3 - django_4 - django-cors-headers - django-debug-toolbar - django-filter - django-graphiql-debug-toolbar - django-mptt - django-pglocks - django-prometheus - django-redis - django-rq - django-tables2 - django-taggit - django-timezone-field - djangorestframework - drf-spectacular - drf-spectacular-sidecar - drf-yasg - dulwich - swagger-spec-validator # from drf-yasg[validation] - feedparser - graphene-django - jinja2 - markdown - markdown-include - netaddr - pillow - psycopg2 - pyyaml - requests - sentry-sdk - social-auth-core - social-auth-app-django - svgwrite - tablib - jsonschema - ] ++ extraBuildInputs; + propagatedBuildInputs = + with python3.pkgs; + [ + bleach + boto3 + django_4 + django-cors-headers + django-debug-toolbar + django-filter + django-graphiql-debug-toolbar + django-mptt + django-pglocks + django-prometheus + django-redis + django-rq + django-tables2 + django-taggit + django-timezone-field + djangorestframework + drf-spectacular + drf-spectacular-sidecar + drf-yasg + dulwich + swagger-spec-validator # from drf-yasg[validation] + feedparser + graphene-django + jinja2 + markdown + markdown-include + netaddr + pillow + psycopg2 + pyyaml + requests + sentry-sdk + social-auth-core + social-auth-app-django + svgwrite + tablib + jsonschema + ] + ++ extraBuildInputs; - buildInputs = with python3.pkgs; [ - mkdocs-material - mkdocs-material-extensions - mkdocstrings - mkdocstrings-python - ]; + buildInputs = with python3.pkgs; [ + mkdocs-material + mkdocs-material-extensions + mkdocstrings + mkdocstrings-python + ]; - nativeBuildInputs = [ - python3.pkgs.mkdocs - ]; + nativeBuildInputs = [ + python3.pkgs.mkdocs + ]; - postBuild = '' - PYTHONPATH=$PYTHONPATH:netbox/ - python -m mkdocs build - ''; + postBuild = '' + PYTHONPATH=$PYTHONPATH:netbox/ + python -m mkdocs build + ''; - installPhase = '' - mkdir -p $out/opt/netbox - cp -r . $out/opt/netbox - chmod +x $out/opt/netbox/netbox/manage.py - makeWrapper $out/opt/netbox/netbox/manage.py $out/bin/netbox \ - --prefix PYTHONPATH : "$PYTHONPATH" - ''; + installPhase = '' + mkdir -p $out/opt/netbox + cp -r . $out/opt/netbox + chmod +x $out/opt/netbox/netbox/manage.py + makeWrapper $out/opt/netbox/netbox/manage.py $out/bin/netbox \ + --prefix PYTHONPATH : "$PYTHONPATH" + ''; - passthru = { - python = python3; - # PYTHONPATH of all dependencies used by the package - pythonPath = python3.pkgs.makePythonPath propagatedBuildInputs; - gunicorn = python3.pkgs.gunicorn; - inherit tests; - }; + passthru = { + python = python3; + # PYTHONPATH of all dependencies used by the package + pythonPath = python3.pkgs.makePythonPath propagatedBuildInputs; + gunicorn = python3.pkgs.gunicorn; + inherit tests; + }; - meta = { - homepage = "https://github.com/netbox-community/netbox"; - description = "IP address management (IPAM) and data center infrastructure management (DCIM) tool"; - mainProgram = "netbox"; - license = lib.licenses.asl20; - knownVulnerabilities = (lib.optional eol "Netbox version ${version} is EOL; please upgrade by following the current release notes instructions."); - # Warning: - # Notice the missing `lib` in the inherit: it is using this function argument rather than a `with lib;` argument. - # If you replace this by `with lib;`, pay attention it does not inherit all maintainers in nixpkgs. - inherit maintainers; - }; - } + meta = { + homepage = "https://github.com/netbox-community/netbox"; + description = "IP address management (IPAM) and data center infrastructure management (DCIM) tool"; + mainProgram = "netbox"; + license = lib.licenses.asl20; + knownVulnerabilities = ( + lib.optional eol "Netbox version ${version} is EOL; please upgrade by following the current release notes instructions." + ); + # Warning: + # Notice the missing `lib` in the inherit: it is using this function argument rather than a `with lib;` argument. + # If you replace this by `with lib;`, pay attention it does not inherit all maintainers in nixpkgs. + inherit maintainers; + }; +} diff --git a/pkgs/servers/web-apps/outline/default.nix b/pkgs/servers/web-apps/outline/default.nix index 1fbfc016cbe1d1..f6cee4bd1c8aa9 100644 --- a/pkgs/servers/web-apps/outline/default.nix +++ b/pkgs/servers/web-apps/outline/default.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchYarnDeps -, makeWrapper -, nix-update-script -, prefetch-yarn-deps -, fixup-yarn-lock -, nodejs -, yarn -, nixosTests +{ + stdenv, + lib, + fetchFromGitHub, + fetchYarnDeps, + makeWrapper, + nix-update-script, + prefetch-yarn-deps, + fixup-yarn-lock, + nodejs, + yarn, + nixosTests, }: stdenv.mkDerivation rec { @@ -22,8 +23,15 @@ stdenv.mkDerivation rec { hash = "sha256-P0JDkuEm5eeVwi0+C7uSytA2NPQXUgJEDxqPiJfRNvs="; }; - nativeBuildInputs = [ makeWrapper prefetch-yarn-deps fixup-yarn-lock ]; - buildInputs = [ yarn nodejs ]; + nativeBuildInputs = [ + makeWrapper + prefetch-yarn-deps + fixup-yarn-lock + ]; + buildInputs = [ + yarn + nodejs + ]; yarnOfflineCache = fetchYarnDeps { yarnLock = "${src}/yarn.lock"; @@ -85,7 +93,13 @@ stdenv.mkDerivation rec { homepage = "https://www.getoutline.com/"; changelog = "https://github.com/outline/outline/releases"; license = licenses.bsl11; - maintainers = with maintainers; [ cab404 yrd ] ++ teams.cyberus.members; + maintainers = + with maintainers; + [ + cab404 + yrd + ] + ++ teams.cyberus.members; platforms = platforms.linux; }; } diff --git a/pkgs/servers/web-apps/wiki-js/default.nix b/pkgs/servers/web-apps/wiki-js/default.nix index 362230da8dd21f..e3d6fd960b0881 100644 --- a/pkgs/servers/web-apps/wiki-js/default.nix +++ b/pkgs/servers/web-apps/wiki-js/default.nix @@ -1,4 +1,9 @@ -{ stdenv, fetchurl, lib, nixosTests }: +{ + stdenv, + fetchurl, + lib, + nixosTests, +}: stdenv.mkDerivation rec { pname = "wiki-js"; diff --git a/pkgs/servers/web-apps/wordpress/default.nix b/pkgs/servers/web-apps/wordpress/default.nix index 185662312543a1..1641616f8d7c73 100644 --- a/pkgs/servers/web-apps/wordpress/default.nix +++ b/pkgs/servers/web-apps/wordpress/default.nix @@ -1,4 +1,5 @@ -{ callPackage }: builtins.mapAttrs (_: callPackage ./generic.nix) rec { +{ callPackage }: +builtins.mapAttrs (_: callPackage ./generic.nix) rec { wordpress = wordpress_6_7; wordpress_6_7 = { version = "6.7.1"; diff --git a/pkgs/servers/web-apps/wordpress/generic.nix b/pkgs/servers/web-apps/wordpress/generic.nix index cfe0975abb2f21..640fb34f1b9146 100644 --- a/pkgs/servers/web-apps/wordpress/generic.nix +++ b/pkgs/servers/web-apps/wordpress/generic.nix @@ -1,4 +1,12 @@ -{ lib, version, hash, stdenv, fetchurl, nixosTests, writeScript }: +{ + lib, + version, + hash, + stdenv, + fetchurl, + nixosTests, + writeScript, +}: stdenv.mkDerivation rec { pname = "wordpress"; diff --git a/pkgs/servers/web-apps/wordpress/packages/default.nix b/pkgs/servers/web-apps/wordpress/packages/default.nix index cce6897cb91934..d874bf3b4db227 100644 --- a/pkgs/servers/web-apps/wordpress/packages/default.nix +++ b/pkgs/servers/web-apps/wordpress/packages/default.nix @@ -2,94 +2,203 @@ # Licensed under: MIT # Slightly modified -{ lib, newScope, plugins, themes, languages, callPackage }: +{ + lib, + newScope, + plugins, + themes, + languages, + callPackage, +}: -let packages = self: - let - generatedJson = { - inherit plugins themes languages; - }; - sourceJson = { - plugins = builtins.fromJSON (builtins.readFile ./wordpress-plugins.json); - themes = builtins.fromJSON (builtins.readFile ./wordpress-themes.json); - languages = builtins.fromJSON (builtins.readFile ./wordpress-languages.json); - }; +let + packages = + self: + let + generatedJson = { + inherit plugins themes languages; + }; + sourceJson = { + plugins = builtins.fromJSON (builtins.readFile ./wordpress-plugins.json); + themes = builtins.fromJSON (builtins.readFile ./wordpress-themes.json); + languages = builtins.fromJSON (builtins.readFile ./wordpress-languages.json); + }; - in { - # Create a generic WordPress package. Most arguments are just passed - # to `mkDerivation`. The version is automatically filtered for weird characters. - mkWordpressDerivation = self.callPackage ({ stdenvNoCC, lib, filterWPString, gettext, wp-cli }: - { type, pname, version, license, ... }@args: - assert lib.any (x: x == type) [ "plugin" "theme" "language" ]; - stdenvNoCC.mkDerivation ({ - pname = "wordpress-${type}-${pname}"; - version = filterWPString version; + in + { + # Create a generic WordPress package. Most arguments are just passed + # to `mkDerivation`. The version is automatically filtered for weird characters. + mkWordpressDerivation = self.callPackage ( + { + stdenvNoCC, + lib, + filterWPString, + gettext, + wp-cli, + }: + { + type, + pname, + version, + license, + ... + }@args: + assert lib.any (x: x == type) [ + "plugin" + "theme" + "language" + ]; + stdenvNoCC.mkDerivation ( + { + pname = "wordpress-${type}-${pname}"; + version = filterWPString version; - dontConfigure = true; - dontBuild = true; + dontConfigure = true; + dontBuild = true; - installPhase = '' - runHook preInstall - cp -R ./. $out - runHook postInstall - ''; + installPhase = '' + runHook preInstall + cp -R ./. $out + runHook postInstall + ''; - passthru = { - wpName = pname; - }; + passthru = { + wpName = pname; + }; - meta = { - license = lib.licenses.${license}; - } // (args.passthru or {}); - } // lib.optionalAttrs (type == "language") { - nativeBuildInputs = [ gettext wp-cli ]; - dontBuild = false; - buildPhase = '' - runHook preBuild + meta = { + license = lib.licenses.${license}; + } // (args.passthru or { }); + } + // lib.optionalAttrs (type == "language") { + nativeBuildInputs = [ + gettext + wp-cli + ]; + dontBuild = false; + buildPhase = '' + runHook preBuild - find -name '*.po' -print0 | while IFS= read -d "" -r po; do - msgfmt -o $(basename "$po" .po).mo "$po" - done - wp i18n make-json . - rm *.po + find -name '*.po' -print0 | while IFS= read -d "" -r po; do + msgfmt -o $(basename "$po" .po).mo "$po" + done + wp i18n make-json . + rm *.po - runHook postBuild - ''; - } // removeAttrs args [ "type" "pname" "version" "passthru" ])) {}; + runHook postBuild + ''; + } + // removeAttrs args [ + "type" + "pname" + "version" + "passthru" + ] + ) + ) { }; - # Create a derivation from the official wordpress.org packages. - # This takes the type, the pname and the data generated from the go tool. - mkOfficialWordpressDerivation = self.callPackage ({ mkWordpressDerivation, fetchWordpress }: - { type, pname, data, license }: - mkWordpressDerivation { - inherit type pname license; - version = data.version; + # Create a derivation from the official wordpress.org packages. + # This takes the type, the pname and the data generated from the go tool. + mkOfficialWordpressDerivation = self.callPackage ( + { mkWordpressDerivation, fetchWordpress }: + { + type, + pname, + data, + license, + }: + mkWordpressDerivation { + inherit type pname license; + version = data.version; - src = fetchWordpress type data; - }) {}; + src = fetchWordpress type data; + } + ) { }; - # Filter out all characters that might occur in a version string but that that are not allowed - # in store paths. - filterWPString = builtins.replaceStrings [ " " "," "/" "&" ";" ''"'' "'" "$" ":" "(" ")" "[" "]" "{" "}" "|" "*" "\t" ] [ "_" "." "." "" "" "" "" "" "" "" "" "" "" "" "" "-" "" "" ]; + # Filter out all characters that might occur in a version string but that that are not allowed + # in store paths. + filterWPString = + builtins.replaceStrings + [ + " " + "," + "/" + "&" + ";" + ''"'' + "'" + "$" + ":" + "(" + ")" + "[" + "]" + "{" + "}" + "|" + "*" + "\t" + ] + [ + "_" + "." + "." + "" + "" + "" + "" + "" + "" + "" + "" + "" + "" + "" + "" + "-" + "" + "" + ]; - # Fetch a package from the official wordpress.org SVN. - # The data supplied is the data straight from the go tool. - fetchWordpress = self.callPackage ({ fetchsvn }: type: data: fetchsvn { - inherit (data) rev sha256; - url = if type == "plugin" || type == "theme" then - "https://" + type + "s.svn.wordpress.org/" + data.path - else if type == "language" then - "https://i18n.svn.wordpress.org/core/" + data.version + "/" + data.path - else if type == "pluginLanguage" then - "https://i18n.svn.wordpress.org/plugins/" + data.path - else if type == "themeLanguage" then - "https://i18n.svn.wordpress.org/themes/" + data.path - else - throw "fetchWordpress: invalid package type ${type}"; - }) {}; + # Fetch a package from the official wordpress.org SVN. + # The data supplied is the data straight from the go tool. + fetchWordpress = self.callPackage ( + { fetchsvn }: + type: data: + fetchsvn { + inherit (data) rev sha256; + url = + if type == "plugin" || type == "theme" then + "https://" + type + "s.svn.wordpress.org/" + data.path + else if type == "language" then + "https://i18n.svn.wordpress.org/core/" + data.version + "/" + data.path + else if type == "pluginLanguage" then + "https://i18n.svn.wordpress.org/plugins/" + data.path + else if type == "themeLanguage" then + "https://i18n.svn.wordpress.org/themes/" + data.path + else + throw "fetchWordpress: invalid package type ${type}"; + } + ) { }; - } // lib.mapAttrs ( - type: pkgs: lib.makeExtensible (_: lib.mapAttrs (pname: data: self.mkOfficialWordpressDerivation {type = lib.removeSuffix "s" type; inherit pname data; license = sourceJson.${type}.${pname}; }) pkgs)) generatedJson; + } + // lib.mapAttrs ( + type: pkgs: + lib.makeExtensible ( + _: + lib.mapAttrs ( + pname: data: + self.mkOfficialWordpressDerivation { + type = lib.removeSuffix "s" type; + inherit pname data; + license = sourceJson.${type}.${pname}; + } + ) pkgs + ) + ) generatedJson; +in # This creates an extensible scope. -in lib.recursiveUpdate ((lib.makeExtensible (_: (lib.makeScope newScope packages))).extend (selfWP: superWP: {})) (callPackage ./thirdparty.nix {}) +lib.recursiveUpdate ((lib.makeExtensible (_: (lib.makeScope newScope packages))).extend ( + selfWP: superWP: { } +)) (callPackage ./thirdparty.nix { }) diff --git a/pkgs/servers/web-apps/wordpress/packages/thirdparty.nix b/pkgs/servers/web-apps/wordpress/packages/thirdparty.nix index 764408470064e5..535e57b526ca69 100644 --- a/pkgs/servers/web-apps/wordpress/packages/thirdparty.nix +++ b/pkgs/servers/web-apps/wordpress/packages/thirdparty.nix @@ -1,4 +1,9 @@ -{fetchzip, stdenv, lib}: { +{ + fetchzip, + stdenv, + lib, +}: +{ plugins.civicrm = stdenv.mkDerivation rec { pname = "civicrm"; version = "5.56.0"; @@ -41,4 +46,3 @@ }; }; } - diff --git a/pkgs/servers/x11/quartz-wm/default.nix b/pkgs/servers/x11/quartz-wm/default.nix index d8ad96b97dd1a4..b6a1c1f525be42 100644 --- a/pkgs/servers/x11/quartz-wm/default.nix +++ b/pkgs/servers/x11/quartz-wm/default.nix @@ -1,7 +1,19 @@ -{ lib, stdenv, fetchurl, xorg, pixman, pkg-config, AppKit, Foundation, Xplugin }: +{ + lib, + stdenv, + fetchurl, + xorg, + pixman, + pkg-config, + AppKit, + Foundation, + Xplugin, +}: -let version = "1.3.1"; -in stdenv.mkDerivation { +let + version = "1.3.1"; +in +stdenv.mkDerivation { pname = "quartz-wm"; inherit version; src = fetchurl { @@ -21,7 +33,9 @@ in stdenv.mkDerivation { xorg.libXrandr xorg.libXext pixman - AppKit Xplugin Foundation + AppKit + Xplugin + Foundation ]; meta = with lib; { license = licenses.apple-psl20; diff --git a/pkgs/servers/x11/xorg/xcb-util-xrm.nix b/pkgs/servers/x11/xorg/xcb-util-xrm.nix index 0235ad29cc6e0a..487e0cb406616c 100644 --- a/pkgs/servers/x11/xorg/xcb-util-xrm.nix +++ b/pkgs/servers/x11/xorg/xcb-util-xrm.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, pkg-config, m4, libxcb, xcbutil, libX11 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + m4, + libxcb, + xcbutil, + libX11, +}: stdenv.mkDerivation rec { version = "1.3"; @@ -11,9 +20,16 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ pkg-config m4 ]; + nativeBuildInputs = [ + pkg-config + m4 + ]; doCheck = true; - buildInputs = [ libxcb xcbutil libX11 ]; + buildInputs = [ + libxcb + xcbutil + libX11 + ]; meta = with lib; { description = "XCB utility functions for the X resource manager"; diff --git a/pkgs/servers/x11/xorg/xwayland.nix b/pkgs/servers/x11/xorg/xwayland.nix index 8bfc01d7993328..eb46bb349a4335 100644 --- a/pkgs/servers/x11/xorg/xwayland.nix +++ b/pkgs/servers/x11/xorg/xwayland.nix @@ -1,50 +1,52 @@ -{ egl-wayland -, bash -, libepoxy -, fetchurl -, fontutil -, lib -, libdecor -, libei -, libGL -, libGLU -, libX11 -, libXau -, libXaw -, libXdmcp -, libXext -, libXfixes -, libXfont2 -, libXmu -, libXpm -, libXrender -, libXres -, libXt -, libdrm -, libtirpc -, withLibunwind ? true, libunwind -, libxcb -, libxkbfile -, libxshmfence -, libxcvt -, mesa -, meson -, ninja -, openssl -, pkg-config -, pixman -, stdenv -, systemd -, wayland -, wayland-protocols -, wayland-scanner -, xkbcomp -, xkeyboard_config -, xorgproto -, xtrans -, zlib -, defaultFontPath ? "" -, gitUpdater +{ + egl-wayland, + bash, + libepoxy, + fetchurl, + fontutil, + lib, + libdecor, + libei, + libGL, + libGLU, + libX11, + libXau, + libXaw, + libXdmcp, + libXext, + libXfixes, + libXfont2, + libXmu, + libXpm, + libXrender, + libXres, + libXt, + libdrm, + libtirpc, + withLibunwind ? true, + libunwind, + libxcb, + libxkbfile, + libxshmfence, + libxcvt, + mesa, + meson, + ninja, + openssl, + pkg-config, + pixman, + stdenv, + systemd, + wayland, + wayland-protocols, + wayland-scanner, + xkbcomp, + xkeyboard_config, + xorgproto, + xtrans, + zlib, + defaultFontPath ? "", + gitUpdater, }: stdenv.mkDerivation rec { @@ -70,45 +72,47 @@ stdenv.mkDerivation rec { ninja wayland-scanner ]; - buildInputs = [ - egl-wayland - libdecor - libepoxy - libei - fontutil - libGL - libGLU - libX11 - libXau - libXaw - libXdmcp - libXext - libXfixes - libXfont2 - libXmu - libXpm - libXrender - libXres - libXt - libdrm - libtirpc - libxcb - libxkbfile - libxshmfence - libxcvt - mesa - openssl - pixman - systemd - wayland - wayland-protocols - xkbcomp - xorgproto - xtrans - zlib - ] ++ lib.optionals withLibunwind [ - libunwind - ]; + buildInputs = + [ + egl-wayland + libdecor + libepoxy + libei + fontutil + libGL + libGLU + libX11 + libXau + libXaw + libXdmcp + libXext + libXfixes + libXfont2 + libXmu + libXpm + libXrender + libXres + libXt + libdrm + libtirpc + libxcb + libxkbfile + libxshmfence + libxcvt + mesa + openssl + pixman + systemd + wayland + wayland-protocols + xkbcomp + xorgproto + xtrans + zlib + ] + ++ lib.optionals withLibunwind [ + libunwind + ]; mesonFlags = [ (lib.mesonBool "xcsecurity" true) (lib.mesonOption "default_font_path" defaultFontPath) @@ -129,7 +133,10 @@ stdenv.mkDerivation rec { homepage = "https://wayland.freedesktop.org/xserver.html"; license = licenses.mit; mainProgram = "Xwayland"; - maintainers = with maintainers; [ emantor k900 ]; + maintainers = with maintainers; [ + emantor + k900 + ]; platforms = platforms.linux; }; } diff --git a/pkgs/shells/bash/bash-5.2-patches.nix b/pkgs/shells/bash/bash-5.2-patches.nix index da5380c7a55ad1..b5197b6e0bca83 100644 --- a/pkgs/shells/bash/bash-5.2-patches.nix +++ b/pkgs/shells/bash/bash-5.2-patches.nix @@ -1,41 +1,41 @@ # Automatically generated by `update-patch-set.sh'; do not edit. patch: [ -(patch "001" "02iibpd3jq8p1bhdzgik8ps6gi1145vr463a82gj1hivjbp2ybzl") -(patch "002" "1f6p1z85qh1lavdp3xikgp0bfv0vqhvgpgwmdzlywl35hwdmxk25") -(patch "003" "1zxsi869jd90hksx3nyypgyqwrxhw2ws3r6hmk76yc1lsgdhq2ba") -(patch "004" "04i5liw5cg6dqkdxfgazqc2jrw40bmclx3dx45bwy259pcj7g0iq") -(patch "005" "0mykflv9qnbx3jz71l4f7isadiw9knm4qimqkwsv9cv88dafpq7c") -(patch "006" "13265akl8w6zyrg0l7f0x6arjgqjhllcwl6lk46rl53x4mm5dq6i") -(patch "007" "146lrwkn5wgxzs6vx34wl47g69zsxdy032k40qzi626b47ya6015") -(patch "008" "1s5i8hcayrv25lc8fxcr431v634yx5sii53b8fmip789s0pxjjvb") -(patch "009" "1kfk25151ka9wkmk1myf12irgcmvhsd8b0nfifvhrszah9w82npr") -(patch "010" "1kf1jrwm30js0v3d1r2rk4x09s1pyjp70wnd1qqhf9bmkw15ww67") -(patch "011" "1x5nkvbj6hci7gx42q7qa72hg2a9wwxh85dk79gn521ypwjmy6w3") -(patch "012" "0b6lcwzm7v5bzjiwaz2c8n5aj77w8ckhp2vwk4v3zsdq3z70gc9g") -(patch "013" "1rkwpibd6j2ghppfhqsva2jm4kdni6b7jpdsxdps52643gc4yjq9") -(patch "014" "09766vqqw4ffnmysm725v35qkhp1g9j4qgqag941xvq655pj9y9y") -(patch "015" "12im449abnq5gaqjmdxr5i38kmp02fa8l8wffad3jryvd58r0wzg") -(patch "016" "05arb0hzmng03cr357lf6p8af0x2a1pznsd3psll03nibfy56n0m") -(patch "017" "129cvx4gfz8n23iw1lhbknbw86fyw6vh60jqj1wj3d5pr75wwj0w") -(patch "018" "105am94qxjc27gga4a8asvsi01090xwjfim3s16lafwjvm4xsha6") -(patch "019" "10njgv5mrc5rhsp5lvxcbm0pnzn59a8spi2nhdasifyl1a32cp1j") -(patch "020" "07f0wlmqjdfarp44w3gj9gdqbqm5x20rvlhpn34ngklmxcm2bz5n") -(patch "021" "1kahfqqalcwi4m73pg3ssz6lh0kcqsqax09myac7a15d2y0vhd43") -(patch "022" "0w74aym0g1fh48864a3qxh89f26iaq7wsbg7244c6kjr94527dbq") -(patch "023" "1lywjqbc36j5pdzfcvnz1zy30j76aqmsm190p888av0hw815b45g") -(patch "024" "1hq23djqbr7s9y2324jq9mxr5bwdkmgizn3zgpchbsqp054k85cp") -(patch "025" "0x9hc4silzl4d3zw4p43i5dm7w86k50j47f87lracwfgwy3z8f2i") -(patch "026" "1b1fhm1dsi67r8ip17s0xvx2qq31fsxc1g9n3r931dd0k9a1zvln") -(patch "027" "0fdbhvs9dkf4knncifh98a76q4gylhyvfrffq5p9q3ag5q58jap1") -(patch "028" "1hdacd6sssjshmry1sscdnxxfb2r51bvdyghlfjaqgc9l85phhk0") -(patch "029" "11wrlb20w6v89b96krg0gwxipwhvrda6rq1y9f972m32gsrsqp0j") -(patch "030" "13v9fqgim082dmvkslsr0hs793yzhsij2s91mjswsfhj1qip7zy3") -(patch "031" "15d7rddj6spwc1fy997lxx6zvzq0zbxgf2h20mhi4wgp5nzbglf2") -(patch "032" "05ia6yf32hjprmyyxqawhgckxs3684ikfx8xg08zfgx9xkd7g73v") -(patch "033" "1qm2aad9mf2xah6xwchga7s5pk3v308mrv9lgh50d65d236ccgh1") -(patch "034" "0bi38dhkkwpm2qrzp8zpykglq6gibvv2n9f8m59gwj406cxvp7w9") -(patch "035" "1r8k34y82v02yfkgws17j7i53ybb74dqnwl2jjiv0av9z93hl6l2") -(patch "036" "0mwhr9hfbh2czf8klbxg6nbd2g9xl9kygvgk061vird56r4kzj8m") -(patch "037" "156sbi3srzkyxajkmhb7iigq0j4nvwnpsbw88xdsxn95a4xiqb4a") + (patch "001" "02iibpd3jq8p1bhdzgik8ps6gi1145vr463a82gj1hivjbp2ybzl") + (patch "002" "1f6p1z85qh1lavdp3xikgp0bfv0vqhvgpgwmdzlywl35hwdmxk25") + (patch "003" "1zxsi869jd90hksx3nyypgyqwrxhw2ws3r6hmk76yc1lsgdhq2ba") + (patch "004" "04i5liw5cg6dqkdxfgazqc2jrw40bmclx3dx45bwy259pcj7g0iq") + (patch "005" "0mykflv9qnbx3jz71l4f7isadiw9knm4qimqkwsv9cv88dafpq7c") + (patch "006" "13265akl8w6zyrg0l7f0x6arjgqjhllcwl6lk46rl53x4mm5dq6i") + (patch "007" "146lrwkn5wgxzs6vx34wl47g69zsxdy032k40qzi626b47ya6015") + (patch "008" "1s5i8hcayrv25lc8fxcr431v634yx5sii53b8fmip789s0pxjjvb") + (patch "009" "1kfk25151ka9wkmk1myf12irgcmvhsd8b0nfifvhrszah9w82npr") + (patch "010" "1kf1jrwm30js0v3d1r2rk4x09s1pyjp70wnd1qqhf9bmkw15ww67") + (patch "011" "1x5nkvbj6hci7gx42q7qa72hg2a9wwxh85dk79gn521ypwjmy6w3") + (patch "012" "0b6lcwzm7v5bzjiwaz2c8n5aj77w8ckhp2vwk4v3zsdq3z70gc9g") + (patch "013" "1rkwpibd6j2ghppfhqsva2jm4kdni6b7jpdsxdps52643gc4yjq9") + (patch "014" "09766vqqw4ffnmysm725v35qkhp1g9j4qgqag941xvq655pj9y9y") + (patch "015" "12im449abnq5gaqjmdxr5i38kmp02fa8l8wffad3jryvd58r0wzg") + (patch "016" "05arb0hzmng03cr357lf6p8af0x2a1pznsd3psll03nibfy56n0m") + (patch "017" "129cvx4gfz8n23iw1lhbknbw86fyw6vh60jqj1wj3d5pr75wwj0w") + (patch "018" "105am94qxjc27gga4a8asvsi01090xwjfim3s16lafwjvm4xsha6") + (patch "019" "10njgv5mrc5rhsp5lvxcbm0pnzn59a8spi2nhdasifyl1a32cp1j") + (patch "020" "07f0wlmqjdfarp44w3gj9gdqbqm5x20rvlhpn34ngklmxcm2bz5n") + (patch "021" "1kahfqqalcwi4m73pg3ssz6lh0kcqsqax09myac7a15d2y0vhd43") + (patch "022" "0w74aym0g1fh48864a3qxh89f26iaq7wsbg7244c6kjr94527dbq") + (patch "023" "1lywjqbc36j5pdzfcvnz1zy30j76aqmsm190p888av0hw815b45g") + (patch "024" "1hq23djqbr7s9y2324jq9mxr5bwdkmgizn3zgpchbsqp054k85cp") + (patch "025" "0x9hc4silzl4d3zw4p43i5dm7w86k50j47f87lracwfgwy3z8f2i") + (patch "026" "1b1fhm1dsi67r8ip17s0xvx2qq31fsxc1g9n3r931dd0k9a1zvln") + (patch "027" "0fdbhvs9dkf4knncifh98a76q4gylhyvfrffq5p9q3ag5q58jap1") + (patch "028" "1hdacd6sssjshmry1sscdnxxfb2r51bvdyghlfjaqgc9l85phhk0") + (patch "029" "11wrlb20w6v89b96krg0gwxipwhvrda6rq1y9f972m32gsrsqp0j") + (patch "030" "13v9fqgim082dmvkslsr0hs793yzhsij2s91mjswsfhj1qip7zy3") + (patch "031" "15d7rddj6spwc1fy997lxx6zvzq0zbxgf2h20mhi4wgp5nzbglf2") + (patch "032" "05ia6yf32hjprmyyxqawhgckxs3684ikfx8xg08zfgx9xkd7g73v") + (patch "033" "1qm2aad9mf2xah6xwchga7s5pk3v308mrv9lgh50d65d236ccgh1") + (patch "034" "0bi38dhkkwpm2qrzp8zpykglq6gibvv2n9f8m59gwj406cxvp7w9") + (patch "035" "1r8k34y82v02yfkgws17j7i53ybb74dqnwl2jjiv0av9z93hl6l2") + (patch "036" "0mwhr9hfbh2czf8klbxg6nbd2g9xl9kygvgk061vird56r4kzj8m") + (patch "037" "156sbi3srzkyxajkmhb7iigq0j4nvwnpsbw88xdsxn95a4xiqb4a") ] diff --git a/pkgs/shells/carapace/default.nix b/pkgs/shells/carapace/default.nix index 555f70e255e5f5..c2107abb3fc00c 100644 --- a/pkgs/shells/carapace/default.nix +++ b/pkgs/shells/carapace/default.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchFromGitHub, testers, carapace }: +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + carapace, +}: buildGoModule rec { pname = "carapace"; diff --git a/pkgs/shells/fish/babelfish.nix b/pkgs/shells/fish/babelfish.nix index a08944262cc480..d5a317b6186340 100644 --- a/pkgs/shells/fish/babelfish.nix +++ b/pkgs/shells/fish/babelfish.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "babelfish"; version = "1.2.1"; @@ -17,6 +21,9 @@ buildGoModule rec { mainProgram = "babelfish"; homepage = "https://github.com/bouk/babelfish"; license = licenses.mit; - maintainers = with maintainers; [ bouk kevingriffin ]; + maintainers = with maintainers; [ + bouk + kevingriffin + ]; }; } diff --git a/pkgs/shells/fish/default.nix b/pkgs/shells/fish/default.nix index 16462ba09f6e4b..76d9a9b2fbc783 100644 --- a/pkgs/shells/fish/default.nix +++ b/pkgs/shells/fish/default.nix @@ -1,32 +1,33 @@ -{ stdenv -, lib -, fetchurl -, fetchpatch -, coreutils -, which -, gnused -, gnugrep -, groff -, gawk -, man-db -, getent -, libiconv -, pcre2 -, gettext -, ncurses -, python3 -, cmake -, fishPlugins -, procps - -# used to generate autocompletions from manpages and for configuration editing in the browser -, usePython ? true - -, runCommand -, writeText -, nixosTests -, nix-update-script -, useOperatingSystemEtc ? true +{ + stdenv, + lib, + fetchurl, + fetchpatch, + coreutils, + which, + gnused, + gnugrep, + groff, + gawk, + man-db, + getent, + libiconv, + pcre2, + gettext, + ncurses, + python3, + cmake, + fishPlugins, + procps, + + # used to generate autocompletions from manpages and for configuration editing in the browser + usePython ? true, + + runCommand, + writeText, + nixosTests, + nix-update-script, + useOperatingSystemEtc ? true, # An optional string containing Fish code that initializes the environment. # This is run at the very beginning of initialization. If it sets $NIX_PROFILES # then Fish will use that to configure its function, completion, and conf.d paths. @@ -35,7 +36,7 @@ # It can also be a function that takes one argument, which is a function that # takes a path to a bash file and converts it to fish. For example: # fishEnvPreInit = source: source "${nix}/etc/profile.d/nix-daemon.sh"; -, fishEnvPreInit ? null + fishEnvPreInit ? null, }: let etcConfigAppendix = writeText "config.fish.appendix" '' @@ -81,12 +82,19 @@ let # 2. Before the shell is initialized, so that config snippets can find the commands they use on the PATH builtin status is-login or test -z "$__fish_nixos_env_preinit_sourced" -a -z "$ETC_PROFILE_SOURCED" -a -z "$ETC_ZSHENV_SOURCED" - ${if fishEnvPreInit != null then '' - and begin - ${lib.removeSuffix "\n" (if lib.isFunction fishEnvPreInit then fishEnvPreInit sourceWithFenv else fishEnvPreInit)} - end'' else '' - and test -f /etc/fish/nixos-env-preinit.fish - and source /etc/fish/nixos-env-preinit.fish''} + ${ + if fishEnvPreInit != null then + '' + and begin + ${lib.removeSuffix "\n" ( + if lib.isFunction fishEnvPreInit then fishEnvPreInit sourceWithFenv else fishEnvPreInit + )} + end'' + else + '' + and test -f /etc/fish/nixos-env-preinit.fish + and source /etc/fish/nixos-env-preinit.fish'' + } and set -gx __fish_nixos_env_preinit_sourced 1 test -n "$NIX_PROFILES" @@ -163,51 +171,57 @@ let ]; # Fix FHS paths in tests - postPatch = '' - # src/fish_tests.cpp - sed -i 's|/bin/ls|${coreutils}/bin/ls|' src/fish_tests.cpp - sed -i 's|is_potential_path(L"/usr"|is_potential_path(L"/nix"|' src/fish_tests.cpp - sed -i 's|L"/bin/echo"|L"${coreutils}/bin/echo"|' src/fish_tests.cpp - sed -i 's|L"/bin/c"|L"${coreutils}/bin/c"|' src/fish_tests.cpp - sed -i 's|L"/bin/ca"|L"${coreutils}/bin/ca"|' src/fish_tests.cpp - # disable flakey test - sed -i '/{TEST_GROUP("history_races"), history_tests_t::test_history_races},/d' src/fish_tests.cpp - - # tests/checks/cd.fish - sed -i 's|/bin/pwd|${coreutils}/bin/pwd|' tests/checks/cd.fish - - # tests/checks/redirect.fish - sed -i 's|/bin/echo|${coreutils}/bin/echo|' tests/checks/redirect.fish - - # tests/checks/vars_as_commands.fish - sed -i 's|/usr/bin|${coreutils}/bin|' tests/checks/vars_as_commands.fish - - # tests/checks/jobs.fish - sed -i 's|ps -o stat|${procps}/bin/ps -o stat|' tests/checks/jobs.fish - sed -i 's|/bin/echo|${coreutils}/bin/echo|' tests/checks/jobs.fish - - # tests/checks/job-control-noninteractive.fish - sed -i 's|/bin/echo|${coreutils}/bin/echo|' tests/checks/job-control-noninteractive.fish - - # tests/checks/complete.fish - sed -i 's|/bin/ls|${coreutils}/bin/ls|' tests/checks/complete.fish - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # Tests use pkill/pgrep which are currently not built on Darwin - # See https://github.com/NixOS/nixpkgs/pull/103180 - rm tests/pexpects/exit.py - rm tests/pexpects/job_summary.py - rm tests/pexpects/signals.py - - # pexpect tests are flaky in general - # See https://github.com/fish-shell/fish-shell/issues/8789 - rm tests/pexpects/bind.py - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - # pexpect tests are flaky on aarch64-linux (also x86_64-linux) - # See https://github.com/fish-shell/fish-shell/issues/8789 - rm tests/pexpects/exit_handlers.py - ''; - - outputs = [ "out" "doc" ]; + postPatch = + '' + # src/fish_tests.cpp + sed -i 's|/bin/ls|${coreutils}/bin/ls|' src/fish_tests.cpp + sed -i 's|is_potential_path(L"/usr"|is_potential_path(L"/nix"|' src/fish_tests.cpp + sed -i 's|L"/bin/echo"|L"${coreutils}/bin/echo"|' src/fish_tests.cpp + sed -i 's|L"/bin/c"|L"${coreutils}/bin/c"|' src/fish_tests.cpp + sed -i 's|L"/bin/ca"|L"${coreutils}/bin/ca"|' src/fish_tests.cpp + # disable flakey test + sed -i '/{TEST_GROUP("history_races"), history_tests_t::test_history_races},/d' src/fish_tests.cpp + + # tests/checks/cd.fish + sed -i 's|/bin/pwd|${coreutils}/bin/pwd|' tests/checks/cd.fish + + # tests/checks/redirect.fish + sed -i 's|/bin/echo|${coreutils}/bin/echo|' tests/checks/redirect.fish + + # tests/checks/vars_as_commands.fish + sed -i 's|/usr/bin|${coreutils}/bin|' tests/checks/vars_as_commands.fish + + # tests/checks/jobs.fish + sed -i 's|ps -o stat|${procps}/bin/ps -o stat|' tests/checks/jobs.fish + sed -i 's|/bin/echo|${coreutils}/bin/echo|' tests/checks/jobs.fish + + # tests/checks/job-control-noninteractive.fish + sed -i 's|/bin/echo|${coreutils}/bin/echo|' tests/checks/job-control-noninteractive.fish + + # tests/checks/complete.fish + sed -i 's|/bin/ls|${coreutils}/bin/ls|' tests/checks/complete.fish + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # Tests use pkill/pgrep which are currently not built on Darwin + # See https://github.com/NixOS/nixpkgs/pull/103180 + rm tests/pexpects/exit.py + rm tests/pexpects/job_summary.py + rm tests/pexpects/signals.py + + # pexpect tests are flaky in general + # See https://github.com/fish-shell/fish-shell/issues/8789 + rm tests/pexpects/bind.py + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + # pexpect tests are flaky on aarch64-linux (also x86_64-linux) + # See https://github.com/fish-shell/fish-shell/issues/8789 + rm tests/pexpects/exit_handlers.py + ''; + + outputs = [ + "out" + "doc" + ]; strictDeps = true; nativeBuildInputs = [ cmake @@ -220,11 +234,13 @@ let pcre2 ]; - cmakeFlags = [ - "-DCMAKE_INSTALL_DOCDIR=${placeholder "doc"}/share/doc/fish" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DMAC_CODESIGN_ID=OFF" - ]; + cmakeFlags = + [ + "-DCMAKE_INSTALL_DOCDIR=${placeholder "doc"}/share/doc/fish" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DMAC_CODESIGN_ID=OFF" + ]; # Fish’s test suite needs to be able to look up process information and send signals. sandboxProfile = lib.optionalString stdenv.hostPlatform.isDarwin '' @@ -236,11 +252,13 @@ let # Fish needs coreutils as a runtime dependency, and it gets put into # CMAKE_PREFIX_PATH, which cmake uses to look up build time programs, so it # was clobbering the PATH. It probably needs to be fixed at a lower level. - preConfigure = '' - patchShebangs ./build_tools/git_version_gen.sh - '' + lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' - export CMAKE_PREFIX_PATH= - ''; + preConfigure = + '' + patchShebangs ./build_tools/git_version_gen.sh + '' + + lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) '' + export CMAKE_PREFIX_PATH= + ''; # Required binaries during execution propagatedBuildInputs = [ @@ -263,51 +281,57 @@ let make test ''; - postInstall = '' - sed -r "s|command grep|command ${gnugrep}/bin/grep|" \ - -i "$out/share/fish/functions/grep.fish" - sed -e "s|\|cut|\|${coreutils}/bin/cut|" \ - -i "$out/share/fish/functions/fish_prompt.fish" - sed -e "s|uname|${coreutils}/bin/uname|" \ - -i "$out/share/fish/functions/__fish_pwd.fish" \ - "$out/share/fish/functions/prompt_pwd.fish" - sed -e "s|sed |${gnused}/bin/sed |" \ - -i "$out/share/fish/functions/alias.fish" \ - "$out/share/fish/functions/prompt_pwd.fish" - sed -i "s|nroff|${groff}/bin/nroff|" \ - "$out/share/fish/functions/__fish_print_help.fish" - sed -e "s|clear;|${lib.getBin ncurses}/bin/clear;|" \ - -i "$out/share/fish/functions/fish_default_key_bindings.fish" - sed -i "s|/usr/local/sbin /sbin /usr/sbin||" \ - $out/share/fish/completions/{sudo.fish,doas.fish} - sed -e "s| awk | ${gawk}/bin/awk |" \ - -i $out/share/fish/functions/{__fish_print_packages.fish,__fish_print_addresses.fish,__fish_describe_command.fish,__fish_complete_man.fish,__fish_complete_convert_options.fish} \ - $out/share/fish/completions/{cwebp,adb,ezjail-admin,grunt,helm,heroku,lsusb,make,p4,psql,rmmod,vim-addons}.fish - - '' + lib.optionalString usePython '' - cat > $out/share/fish/functions/__fish_anypython.fish < $out/share/fish/functions/__fish_anypython.fish <> webconfig.py - - # and check whether the message appears on the page - # cannot test the http server because it needs a localhost port - cat (${python3}/bin/python ./webconfig.py \ - | tail -n1 | ${lib.getExe gnused} -e 's|file://||' \ - ) | ${lib.getExe gnugrep} -q 'a href="http://localhost.*Start the Fish Web config' - ''; + let + fishScript = writeText "test.fish" '' + set -x __fish_bin_dir ${fish}/bin + echo $__fish_bin_dir + cp -r ${fish}/share/fish/tools/web_config/* . + chmod -R +w * + + # if we don't set `delete=False`, the file will get cleaned up + # automatically (leading the test to fail because there's no + # tempfile to check) + ${lib.getExe gnused} -e 's@, mode="w"@, mode="w", delete=False@' -i webconfig.py + + # we delete everything after the fileurl is assigned + ${lib.getExe gnused} -e '/fileurl =/q' -i webconfig.py + echo "print(fileurl)" >> webconfig.py + + # and check whether the message appears on the page + # cannot test the http server because it needs a localhost port + cat (${python3}/bin/python ./webconfig.py \ + | tail -n1 | ${lib.getExe gnused} -e 's|file://||' \ + ) | ${lib.getExe gnugrep} -q 'a href="http://localhost.*Start the Fish Web config' + ''; in runCommand "test-web-config" { } '' HOME=$(mktemp -d) diff --git a/pkgs/shells/fish/plugins/async-prompt.nix b/pkgs/shells/fish/plugins/async-prompt.nix index ff3a1e6d989147..2f25dcf87060e8 100644 --- a/pkgs/shells/fish/plugins/async-prompt.nix +++ b/pkgs/shells/fish/plugins/async-prompt.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin rec { pname = "async-prompt"; diff --git a/pkgs/shells/fish/plugins/autopair.nix b/pkgs/shells/fish/plugins/autopair.nix index 7c75cc12360103..6832c0bf746ba3 100644 --- a/pkgs/shells/fish/plugins/autopair.nix +++ b/pkgs/shells/fish/plugins/autopair.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin rec { pname = "autopair"; @@ -15,6 +19,10 @@ buildFishPlugin rec { description = "Auto-complete matching pairs in the Fish command line"; homepage = "https://github.com/jorgebucaran/autopair.fish"; license = licenses.mit; - maintainers = with maintainers; [ figsoda kidonng pyrox0 ]; + maintainers = with maintainers; [ + figsoda + kidonng + pyrox0 + ]; }; } diff --git a/pkgs/shells/fish/plugins/bass.nix b/pkgs/shells/fish/plugins/bass.nix index 01fea3c8a0e5c6..f14be816f7af8c 100644 --- a/pkgs/shells/fish/plugins/bass.nix +++ b/pkgs/shells/fish/plugins/bass.nix @@ -1,4 +1,9 @@ -{ lib, buildFishPlugin, fetchFromGitHub, python3 }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, + python3, +}: buildFishPlugin rec { pname = "bass"; diff --git a/pkgs/shells/fish/plugins/bobthefish.nix b/pkgs/shells/fish/plugins/bobthefish.nix index e4b7ead9769460..b2c723b275e9c2 100644 --- a/pkgs/shells/fish/plugins/bobthefish.nix +++ b/pkgs/shells/fish/plugins/bobthefish.nix @@ -1,7 +1,7 @@ -{ lib -, buildFishPlugin -, fetchFromGitHub -, +{ + lib, + buildFishPlugin, + fetchFromGitHub, }: buildFishPlugin { pname = "bobthefish"; diff --git a/pkgs/shells/fish/plugins/bobthefisher.nix b/pkgs/shells/fish/plugins/bobthefisher.nix index db114704c79cb0..39d16ea6100b42 100644 --- a/pkgs/shells/fish/plugins/bobthefisher.nix +++ b/pkgs/shells/fish/plugins/bobthefisher.nix @@ -1,7 +1,7 @@ -{ lib -, buildFishPlugin -, fetchFromGitHub -, +{ + lib, + buildFishPlugin, + fetchFromGitHub, }: buildFishPlugin { pname = "bobthefisher"; diff --git a/pkgs/shells/fish/plugins/build-fish-plugin.nix b/pkgs/shells/fish/plugins/build-fish-plugin.nix index 807d5835f1ee00..7f57cf2c6f2e7c 100644 --- a/pkgs/shells/fish/plugins/build-fish-plugin.nix +++ b/pkgs/shells/fish/plugins/build-fish-plugin.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, writeScript, wrapFish }: +{ + stdenv, + lib, + writeScript, + wrapFish, +}: attrs@{ pname, @@ -12,11 +17,11 @@ attrs@{ preInstall ? "", postInstall ? "", - nativeCheckInputs ? [], + nativeCheckInputs ? [ ], # plugin packages to add to the vendor paths of the test fish shell - checkPlugins ? [], + checkPlugins ? [ ], # vendor directories to add to the function path of the test fish shell - checkFunctionDirs ? [], + checkFunctionDirs ? [ ], # test script to be executed in a fish shell checkPhase ? "", doCheck ? checkPhase != "", @@ -32,44 +37,49 @@ let ]; in -stdenv.mkDerivation (drvAttrs // { - inherit name; - inherit unpackPhase configurePhase buildPhase; +stdenv.mkDerivation ( + drvAttrs + // { + inherit name; + inherit unpackPhase configurePhase buildPhase; - inherit preInstall postInstall; - installPhase = '' - runHook preInstall + inherit preInstall postInstall; + installPhase = '' + runHook preInstall - ( - install_vendor_files() { - source="$1" - target="$out/share/fish/vendor_$2.d" + ( + install_vendor_files() { + source="$1" + target="$out/share/fish/vendor_$2.d" - # Check if any .fish file exists in $source - [ -n "$(shopt -s nullglob; echo $source/*.fish)" ] || return 0 + # Check if any .fish file exists in $source + [ -n "$(shopt -s nullglob; echo $source/*.fish)" ] || return 0 - mkdir -p $target - cp $source/*.fish "$target/" - } + mkdir -p $target + cp $source/*.fish "$target/" + } - install_vendor_files completions completions - install_vendor_files functions functions - install_vendor_files conf conf - install_vendor_files conf.d conf - ) + install_vendor_files completions completions + install_vendor_files functions functions + install_vendor_files conf conf + install_vendor_files conf.d conf + ) - runHook postInstall - ''; + runHook postInstall + ''; - inherit doCheck; + inherit doCheck; - nativeCheckInputs = [ (wrapFish { - pluginPkgs = checkPlugins; - functionDirs = checkFunctionDirs; - }) ] ++ nativeCheckInputs; + nativeCheckInputs = [ + (wrapFish { + pluginPkgs = checkPlugins; + functionDirs = checkFunctionDirs; + }) + ] ++ nativeCheckInputs; - checkPhase = '' - export HOME=$(mktemp -d) # fish wants a writable home - fish "${writeScript "${name}-test" checkPhase}" - ''; -}) + checkPhase = '' + export HOME=$(mktemp -d) # fish wants a writable home + fish "${writeScript "${name}-test" checkPhase}" + ''; + } +) diff --git a/pkgs/shells/fish/plugins/clownfish.nix b/pkgs/shells/fish/plugins/clownfish.nix index 90b1f0b86c9cb4..386ba8d6332f66 100644 --- a/pkgs/shells/fish/plugins/clownfish.nix +++ b/pkgs/shells/fish/plugins/clownfish.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin { pname = "clownfish"; diff --git a/pkgs/shells/fish/plugins/colored-man-pages.nix b/pkgs/shells/fish/plugins/colored-man-pages.nix index 07222395b63bfe..b2c76ce1d86e89 100644 --- a/pkgs/shells/fish/plugins/colored-man-pages.nix +++ b/pkgs/shells/fish/plugins/colored-man-pages.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin rec { pname = "colored-man-pages"; diff --git a/pkgs/shells/fish/plugins/done.nix b/pkgs/shells/fish/plugins/done.nix index 4e5aa8e9a09004..7c94772dc8df3f 100644 --- a/pkgs/shells/fish/plugins/done.nix +++ b/pkgs/shells/fish/plugins/done.nix @@ -1,4 +1,9 @@ -{ lib, buildFishPlugin, fetchFromGitHub, fishtape }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, + fishtape, +}: buildFishPlugin rec { pname = "done"; diff --git a/pkgs/shells/fish/plugins/fishtape.nix b/pkgs/shells/fish/plugins/fishtape.nix index 82f2375d5e3f87..ab94045c107eee 100644 --- a/pkgs/shells/fish/plugins/fishtape.nix +++ b/pkgs/shells/fish/plugins/fishtape.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin rec { pname = "fishtape"; diff --git a/pkgs/shells/fish/plugins/fishtape_3.nix b/pkgs/shells/fish/plugins/fishtape_3.nix index 893e6d65ffb397..04814634c6cfa0 100644 --- a/pkgs/shells/fish/plugins/fishtape_3.nix +++ b/pkgs/shells/fish/plugins/fishtape_3.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin rec { pname = "fishtape"; diff --git a/pkgs/shells/fish/plugins/foreign-env/default.nix b/pkgs/shells/fish/plugins/foreign-env/default.nix index 4b317571b2991a..ac9548b23523ab 100644 --- a/pkgs/shells/fish/plugins/foreign-env/default.nix +++ b/pkgs/shells/fish/plugins/foreign-env/default.nix @@ -1,4 +1,11 @@ -{ lib, buildFishPlugin, fetchFromGitHub, gnused, bash, coreutils }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, + gnused, + bash, + coreutils, +}: buildFishPlugin { pname = "foreign-env"; diff --git a/pkgs/shells/fish/plugins/forgit.nix b/pkgs/shells/fish/plugins/forgit.nix index 876cee959dcdd2..ff883f4f258d1d 100644 --- a/pkgs/shells/fish/plugins/forgit.nix +++ b/pkgs/shells/fish/plugins/forgit.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin rec { pname = "forgit"; diff --git a/pkgs/shells/fish/plugins/fzf-fish.nix b/pkgs/shells/fish/plugins/fzf-fish.nix index 1ad4764c46c58c..a77207a8829bd2 100644 --- a/pkgs/shells/fish/plugins/fzf-fish.nix +++ b/pkgs/shells/fish/plugins/fzf-fish.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, pkgs, buildFishPlugin, fetchFromGitHub, fd, unixtools, procps, clownfish, fishtape_3, }: +{ + lib, + stdenv, + pkgs, + buildFishPlugin, + fetchFromGitHub, + fd, + unixtools, + procps, + clownfish, + fishtape_3, +}: let # we want `pkgs.fzf`, not `fishPlugins.fzf` inherit (pkgs) fzf; @@ -14,32 +25,47 @@ buildFishPlugin rec { hash = "sha256-T8KYLA/r/gOKvAivKRoeqIwE2pINlxFQtZJHpOy9GMM="; }; - nativeCheckInputs = [ fzf fd unixtools.script procps ]; - checkPlugins = [ clownfish fishtape_3 ]; + nativeCheckInputs = [ + fzf + fd + unixtools.script + procps + ]; + checkPlugins = [ + clownfish + fishtape_3 + ]; checkFunctionDirs = [ "./functions" ]; - checkPhase = '' - # Disable git tests which inspect the project's git repo, which isn't - # possible since we strip the impure .git from our build input - rm -r tests/*git* - rm -r tests/preview_changed_file/modified_path_with_spaces.fish - rm -r tests/preview_changed_file/renamed_path_modifications.fish + checkPhase = + '' + # Disable git tests which inspect the project's git repo, which isn't + # possible since we strip the impure .git from our build input + rm -r tests/*git* + rm -r tests/preview_changed_file/modified_path_with_spaces.fish + rm -r tests/preview_changed_file/renamed_path_modifications.fish - # Disable tests that are failing, probably because of our wrappers - rm -r tests/configure_bindings - rm -r tests/search_variables + # Disable tests that are failing, probably because of our wrappers + rm -r tests/configure_bindings + rm -r tests/search_variables - # Disable tests that are failing, because there is not 'rev' command - rm tests/preview_file/custom_file_preview.fish - '' + ( - if stdenv.hostPlatform.isDarwin then ''script /dev/null fish -c "fishtape tests/*/*.fish"'' - else ''script -c 'fish -c "fishtape tests/*/*.fish"' '' - ); + # Disable tests that are failing, because there is not 'rev' command + rm tests/preview_file/custom_file_preview.fish + '' + + ( + if stdenv.hostPlatform.isDarwin then + ''script /dev/null fish -c "fishtape tests/*/*.fish"'' + else + ''script -c 'fish -c "fishtape tests/*/*.fish"' '' + ); meta = with lib; { description = "Augment your fish command line with fzf key bindings"; homepage = "https://github.com/PatrickF1/fzf.fish"; changelog = "https://github.com/PatrickF1/fzf.fish/releases/tag/${src.rev}"; license = licenses.mit; - maintainers = with maintainers; [ pacien natsukium ]; + maintainers = with maintainers; [ + pacien + natsukium + ]; }; } diff --git a/pkgs/shells/fish/plugins/fzf.nix b/pkgs/shells/fish/plugins/fzf.nix index 66e1c562ec5e75..8e9d99a18a9daf 100644 --- a/pkgs/shells/fish/plugins/fzf.nix +++ b/pkgs/shells/fish/plugins/fzf.nix @@ -1,7 +1,7 @@ -{ lib -, buildFishPlugin -, fetchFromGitHub -, +{ + lib, + buildFishPlugin, + fetchFromGitHub, }: buildFishPlugin rec { pname = "fzf"; diff --git a/pkgs/shells/fish/plugins/git-abbr.nix b/pkgs/shells/fish/plugins/git-abbr.nix index 2ec33f6c7976a1..664c897500827d 100644 --- a/pkgs/shells/fish/plugins/git-abbr.nix +++ b/pkgs/shells/fish/plugins/git-abbr.nix @@ -18,6 +18,6 @@ buildFishPlugin rec { description = "Abbreviations for git for the fish shell 🐟"; homepage = "https://github.com/lewisacidic/fish-git-abbr"; license = licenses.mit; - maintainers = with maintainers; [hmajid2301]; + maintainers = with maintainers; [ hmajid2301 ]; }; } diff --git a/pkgs/shells/fish/plugins/github-copilot-cli-fish.nix b/pkgs/shells/fish/plugins/github-copilot-cli-fish.nix index 14b57b9a62c652..0a1370f7156166 100644 --- a/pkgs/shells/fish/plugins/github-copilot-cli-fish.nix +++ b/pkgs/shells/fish/plugins/github-copilot-cli-fish.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin rec { pname = "github-copilot-cli.fish"; diff --git a/pkgs/shells/fish/plugins/grc.nix b/pkgs/shells/fish/plugins/grc.nix index 9e74ae44088f43..af713bcc20137e 100644 --- a/pkgs/shells/fish/plugins/grc.nix +++ b/pkgs/shells/fish/plugins/grc.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin { pname = "grc"; diff --git a/pkgs/shells/fish/plugins/gruvbox.nix b/pkgs/shells/fish/plugins/gruvbox.nix index 50110116c89d0d..c4822659f69929 100644 --- a/pkgs/shells/fish/plugins/gruvbox.nix +++ b/pkgs/shells/fish/plugins/gruvbox.nix @@ -1,4 +1,8 @@ -{ lib , buildFishPlugin , fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin { pname = "gruvbox"; version = "0-unstable-2021-10-12"; diff --git a/pkgs/shells/fish/plugins/humantime-fish.nix b/pkgs/shells/fish/plugins/humantime-fish.nix index 417967b72c5fec..33e708e94f82e1 100644 --- a/pkgs/shells/fish/plugins/humantime-fish.nix +++ b/pkgs/shells/fish/plugins/humantime-fish.nix @@ -1,8 +1,8 @@ -{ lib -, buildFishPlugin -, fetchFromGitHub -, fishtape -, +{ + lib, + buildFishPlugin, + fetchFromGitHub, + fishtape, }: buildFishPlugin rec { pname = "humantime-fish"; diff --git a/pkgs/shells/fish/plugins/hydro.nix b/pkgs/shells/fish/plugins/hydro.nix index 7e3f86c347eb1f..4b7a7c3eeb4065 100644 --- a/pkgs/shells/fish/plugins/hydro.nix +++ b/pkgs/shells/fish/plugins/hydro.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin rec { pname = "hydro"; diff --git a/pkgs/shells/fish/plugins/pisces.nix b/pkgs/shells/fish/plugins/pisces.nix index c1ed37f41227b2..be59b248277b30 100644 --- a/pkgs/shells/fish/plugins/pisces.nix +++ b/pkgs/shells/fish/plugins/pisces.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin rec { pname = "pisces"; diff --git a/pkgs/shells/fish/plugins/plugin-git.nix b/pkgs/shells/fish/plugins/plugin-git.nix index d457df7dd498da..bef76a97e1fa44 100644 --- a/pkgs/shells/fish/plugins/plugin-git.nix +++ b/pkgs/shells/fish/plugins/plugin-git.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin rec { pname = "plugin-git"; @@ -16,6 +20,9 @@ buildFishPlugin rec { homepage = "https://github.com/jhillyerd/plugin-git"; changelog = "https://github.com/jhillyerd/plugin-git/releases/tag/v${version}"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ GaetanLepage unsolvedcypher ]; + maintainers = with lib.maintainers; [ + GaetanLepage + unsolvedcypher + ]; }; } diff --git a/pkgs/shells/fish/plugins/pure.nix b/pkgs/shells/fish/plugins/pure.nix index 25ea8aea89b8b9..717c72dcf32222 100644 --- a/pkgs/shells/fish/plugins/pure.nix +++ b/pkgs/shells/fish/plugins/pure.nix @@ -1,4 +1,10 @@ -{ lib, buildFishPlugin, fetchFromGitHub, git, fishtape_3 }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, + git, + fishtape_3, +}: buildFishPlugin rec { pname = "pure"; diff --git a/pkgs/shells/fish/plugins/sdkman-for-fish.nix b/pkgs/shells/fish/plugins/sdkman-for-fish.nix index 6a0c7c7d25f04b..c137cc2cded9f1 100644 --- a/pkgs/shells/fish/plugins/sdkman-for-fish.nix +++ b/pkgs/shells/fish/plugins/sdkman-for-fish.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin rec { pname = "sdkman-for-fish"; diff --git a/pkgs/shells/fish/plugins/sponge.nix b/pkgs/shells/fish/plugins/sponge.nix index 8528452e783bf6..81b29d77536623 100644 --- a/pkgs/shells/fish/plugins/sponge.nix +++ b/pkgs/shells/fish/plugins/sponge.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: buildFishPlugin rec { pname = "sponge"; diff --git a/pkgs/shells/fish/plugins/tide.nix b/pkgs/shells/fish/plugins/tide.nix index 74ab2e8a27a8dc..a0bfc69e95e7af 100644 --- a/pkgs/shells/fish/plugins/tide.nix +++ b/pkgs/shells/fish/plugins/tide.nix @@ -1,4 +1,8 @@ -{ lib, buildFishPlugin, fetchFromGitHub }: +{ + lib, + buildFishPlugin, + fetchFromGitHub, +}: # Due to a quirk in tide breaking wrapFish, we need to add additional commands in the config.fish # Refer to the following comment to get you setup: https://github.com/NixOS/nixpkgs/pull/201646#issuecomment-1320893716 @@ -25,4 +29,3 @@ buildFishPlugin rec { maintainers = [ maintainers.jocelynthode ]; }; } - diff --git a/pkgs/shells/fish/plugins/transient-fish.nix b/pkgs/shells/fish/plugins/transient-fish.nix index 846436d2d1960a..8acdec2cbd65e0 100644 --- a/pkgs/shells/fish/plugins/transient-fish.nix +++ b/pkgs/shells/fish/plugins/transient-fish.nix @@ -1,6 +1,7 @@ -{ lib -, buildFishPlugin -, fetchFromGitHub +{ + lib, + buildFishPlugin, + fetchFromGitHub, }: buildFishPlugin { pname = "transient-fish"; diff --git a/pkgs/shells/fish/plugins/wakatime-fish.nix b/pkgs/shells/fish/plugins/wakatime-fish.nix index c434ab7175982a..743164202ddf4d 100644 --- a/pkgs/shells/fish/plugins/wakatime-fish.nix +++ b/pkgs/shells/fish/plugins/wakatime-fish.nix @@ -1,7 +1,8 @@ -{ lib -, wakatime-cli -, buildFishPlugin -, fetchFromGitHub +{ + lib, + wakatime-cli, + buildFishPlugin, + fetchFromGitHub, }: buildFishPlugin rec { diff --git a/pkgs/shells/fish/plugins/z.nix b/pkgs/shells/fish/plugins/z.nix index 722cafa90d029c..0bf42ecb56fd74 100644 --- a/pkgs/shells/fish/plugins/z.nix +++ b/pkgs/shells/fish/plugins/z.nix @@ -1,7 +1,7 @@ -{ lib -, buildFishPlugin -, fetchFromGitHub -, +{ + lib, + buildFishPlugin, + fetchFromGitHub, }: buildFishPlugin rec { pname = "z"; diff --git a/pkgs/shells/nushell/default.nix b/pkgs/shells/nushell/default.nix index f3fad63c0b85f3..eab87fd8c5b5bb 100644 --- a/pkgs/shells/nushell/default.nix +++ b/pkgs/shells/nushell/default.nix @@ -1,23 +1,24 @@ -{ stdenv -, lib -, fetchFromGitHub -, rustPlatform -, openssl -, zlib -, zstd -, pkg-config -, python3 -, xorg -, Libsystem -, AppKit -, Security -, nghttp2 -, libgit2 -, withDefaultFeatures ? true -, additionalFeatures ? (p: p) -, testers -, nushell -, nix-update-script +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + openssl, + zlib, + zstd, + pkg-config, + python3, + xorg, + Libsystem, + AppKit, + Security, + nghttp2, + libgit2, + withDefaultFeatures ? true, + additionalFeatures ? (p: p), + testers, + nushell, + nix-update-script, }: let @@ -37,19 +38,32 @@ rustPlatform.buildRustPackage { cargoHash = "sha256-omC/qcpgy65Md1MC0QGUVCRVNl9sWlFcCRxdS4aeU+g="; - nativeBuildInputs = [ pkg-config ] + nativeBuildInputs = + [ pkg-config ] ++ lib.optionals (withDefaultFeatures && stdenv.hostPlatform.isLinux) [ python3 ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ rustPlatform.bindgenHook ]; - buildInputs = [ openssl zstd ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ zlib Libsystem Security ] + buildInputs = + [ + openssl + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + zlib + Libsystem + Security + ] ++ lib.optionals (withDefaultFeatures && stdenv.hostPlatform.isLinux) [ xorg.libX11 ] - ++ lib.optionals (withDefaultFeatures && stdenv.hostPlatform.isDarwin) [ AppKit nghttp2 libgit2 ]; + ++ lib.optionals (withDefaultFeatures && stdenv.hostPlatform.isDarwin) [ + AppKit + nghttp2 + libgit2 + ]; buildNoDefaultFeatures = !withDefaultFeatures; buildFeatures = additionalFeatures [ ]; - doCheck = ! stdenv.hostPlatform.isDarwin; # Skip checks on darwin. Failing tests since 0.96.0 + doCheck = !stdenv.hostPlatform.isDarwin; # Skip checks on darwin. Failing tests since 0.96.0 checkPhase = '' runHook preCheck @@ -79,7 +93,11 @@ rustPlatform.buildRustPackage { description = "Modern shell written in Rust"; homepage = "https://www.nushell.sh/"; license = licenses.mit; - maintainers = with maintainers; [ Br1ght0ne johntitor joaquintrinanes ]; + maintainers = with maintainers; [ + Br1ght0ne + johntitor + joaquintrinanes + ]; mainProgram = "nu"; }; } diff --git a/pkgs/shells/zsh/default.nix b/pkgs/shells/zsh/default.nix index 90ac2934f145ad..e84ddddd9fcfb1 100644 --- a/pkgs/shells/zsh/default.nix +++ b/pkgs/shells/zsh/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, autoreconfHook -, yodl -, perl -, groff -, util-linux -, texinfo -, ncurses -, pcre -, pkg-config -, buildPackages -, nixosTests +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + yodl, + perl, + groff, + util-linux, + texinfo, + ncurses, + pcre, + pkg-config, + buildPackages, + nixosTests, }: let @@ -22,64 +23,86 @@ in stdenv.mkDerivation { pname = "zsh"; inherit version; - outputs = [ "out" "doc" "info" "man" ]; + outputs = [ + "out" + "doc" + "info" + "man" + ]; src = fetchurl { url = "mirror://sourceforge/zsh/zsh-${version}.tar.xz"; sha256 = "sha256-m40ezt1bXoH78ZGOh2dSp92UjgXBoNuhCrhjhC1FrNU="; }; - patches = [ - # fix location of timezone data for TZ= completion - ./tz_completion.patch - # Fixes configure misdetection when using clang 16, resulting in broken subshells on Darwin. - # This patch can be dropped with the next release of zsh. - (fetchpatch { - url = "https://github.com/zsh-users/zsh/commit/ab4d62eb975a4c4c51dd35822665050e2ddc6918.patch"; - hash = "sha256-nXB4w7qqjZJC7/+CDxnNy6wu9qNwmS3ezjj/xK7JfeU="; - excludes = [ "ChangeLog" ]; - }) - # Fixes compatibility with texinfo 7.1. This patch can be dropped with the next release of zsh. - (fetchpatch { - url = "https://github.com/zsh-users/zsh/commit/ecd3f9c9506c7720dc6c0833dc5d5eb00e4459c4.patch"; - hash = "sha256-oA8GC8LmuqNKGuPqGfiQVhL5nWb7ArLWGUI6wjpsIW8="; - excludes = [ "ChangeLog" ]; - }) - ] ++ lib.optionals stdenv.cc.isGNU [ - # Fixes compilation with gcc >= 14. - (fetchpatch { - url = "https://github.com/zsh-users/zsh/commit/4c89849c98172c951a9def3690e8647dae76308f.patch"; - hash = "sha256-l5IHQuIXo0N6ynLlZoQA7wJd/C7KrW3G7nMzfjQINkw="; - excludes = [ "ChangeLog" ]; - }) - ]; + patches = + [ + # fix location of timezone data for TZ= completion + ./tz_completion.patch + # Fixes configure misdetection when using clang 16, resulting in broken subshells on Darwin. + # This patch can be dropped with the next release of zsh. + (fetchpatch { + url = "https://github.com/zsh-users/zsh/commit/ab4d62eb975a4c4c51dd35822665050e2ddc6918.patch"; + hash = "sha256-nXB4w7qqjZJC7/+CDxnNy6wu9qNwmS3ezjj/xK7JfeU="; + excludes = [ "ChangeLog" ]; + }) + # Fixes compatibility with texinfo 7.1. This patch can be dropped with the next release of zsh. + (fetchpatch { + url = "https://github.com/zsh-users/zsh/commit/ecd3f9c9506c7720dc6c0833dc5d5eb00e4459c4.patch"; + hash = "sha256-oA8GC8LmuqNKGuPqGfiQVhL5nWb7ArLWGUI6wjpsIW8="; + excludes = [ "ChangeLog" ]; + }) + ] + ++ lib.optionals stdenv.cc.isGNU [ + # Fixes compilation with gcc >= 14. + (fetchpatch { + url = "https://github.com/zsh-users/zsh/commit/4c89849c98172c951a9def3690e8647dae76308f.patch"; + hash = "sha256-l5IHQuIXo0N6ynLlZoQA7wJd/C7KrW3G7nMzfjQINkw="; + excludes = [ "ChangeLog" ]; + }) + ]; strictDeps = true; - nativeBuildInputs = [ autoreconfHook perl groff texinfo pkg-config ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ util-linux yodl ]; + nativeBuildInputs = + [ + autoreconfHook + perl + groff + texinfo + pkg-config + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + util-linux + yodl + ]; - buildInputs = [ ncurses pcre ]; - - configureFlags = [ - "--enable-maildir-support" - "--enable-multibyte" - "--with-tcsetpgrp" - "--enable-pcre" - "--enable-zshenv=${placeholder "out"}/etc/zshenv" - "--disable-site-fndir" - # --enable-function-subdirs is not enabled due to it being slow at runtime in some cases - ] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform && !stdenv.hostPlatform.isStatic) [ - # Also see: https://github.com/buildroot/buildroot/commit/2f32e668aa880c2d4a2cce6c789b7ca7ed6221ba - "zsh_cv_shared_environ=yes" - "zsh_cv_shared_tgetent=yes" - "zsh_cv_shared_tigetstr=yes" - "zsh_cv_sys_dynamic_clash_ok=yes" - "zsh_cv_sys_dynamic_rtld_global=yes" - "zsh_cv_sys_dynamic_execsyms=yes" - "zsh_cv_sys_dynamic_strip_exe=yes" - "zsh_cv_sys_dynamic_strip_lib=yes" + buildInputs = [ + ncurses + pcre ]; + configureFlags = + [ + "--enable-maildir-support" + "--enable-multibyte" + "--with-tcsetpgrp" + "--enable-pcre" + "--enable-zshenv=${placeholder "out"}/etc/zshenv" + "--disable-site-fndir" + # --enable-function-subdirs is not enabled due to it being slow at runtime in some cases + ] + ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform && !stdenv.hostPlatform.isStatic) [ + # Also see: https://github.com/buildroot/buildroot/commit/2f32e668aa880c2d4a2cce6c789b7ca7ed6221ba + "zsh_cv_shared_environ=yes" + "zsh_cv_shared_tgetent=yes" + "zsh_cv_shared_tigetstr=yes" + "zsh_cv_sys_dynamic_clash_ok=yes" + "zsh_cv_sys_dynamic_rtld_global=yes" + "zsh_cv_sys_dynamic_execsyms=yes" + "zsh_cv_sys_dynamic_strip_exe=yes" + "zsh_cv_sys_dynamic_strip_lib=yes" + ]; + postPatch = '' substituteInPlace Src/Modules/pcre.mdd \ --replace 'pcre-config' 'true' @@ -96,42 +119,47 @@ stdenv.mkDerivation { # XXX: think/discuss about this, also with respect to nixos vs nix-on-X postInstall = '' - make install.info install.html - mkdir -p $out/etc/ - cat > $out/etc/zshenv < $out/etc/zshenv <$out"; - tar-all = pack-all "XZ_OPT=\"-9 -e -T $NIX_BUILD_CORES\" tar cJf $out --hard-dereference --sort=name --numeric-owner --owner=0 --group=0 --mtime=@1 ."; - coreutils-big = pkgs.coreutils.override { singleBinary = false; }; - mkdir = runCommand "mkdir" { coreutils = coreutils-big; } '' - mkdir -p $out/bin - cp $coreutils/bin/mkdir $out/bin - ''; - in rec { - unpack = nar-all "unpack.nar.xz" (with pkgs; [bash mkdir xz gnutar]) '' - rm -rf include lib/*.a lib/i18n lib/bash share + '' + ); + nar-all = pack-all "dumpnar . | xz -9 -e -T $NIX_BUILD_CORES >$out"; + tar-all = pack-all "XZ_OPT=\"-9 -e -T $NIX_BUILD_CORES\" tar cJf $out --hard-dereference --sort=name --numeric-owner --owner=0 --group=0 --mtime=@1 ."; + coreutils-big = pkgs.coreutils.override { singleBinary = false; }; + mkdir = runCommand "mkdir" { coreutils = coreutils-big; } '' + mkdir -p $out/bin + cp $coreutils/bin/mkdir $out/bin ''; +in +rec { + unpack = + nar-all "unpack.nar.xz" + (with pkgs; [ + bash + mkdir + xz + gnutar + ]) + '' + rm -rf include lib/*.a lib/i18n lib/bash share + ''; bootstrap-tools = tar-all "bootstrap-tools.tar.xz" ( with pkgs; # SYNCME: this version number must be synced with the one in default.nix - let llvmPackages = llvmPackages_18; in + let + llvmPackages = llvmPackages_18; + in [ (runCommand "bsdcp" { } "mkdir -p $out/bin; cp ${freebsd.cp}/bin/cp $out/bin/bsdcp") coreutils diff --git a/pkgs/stdenv/generic/common-path.nix b/pkgs/stdenv/generic/common-path.nix index 8c1acfb50dd682..32c8e278ad27f1 100644 --- a/pkgs/stdenv/generic/common-path.nix +++ b/pkgs/stdenv/generic/common-path.nix @@ -1,4 +1,5 @@ -{pkgs}: [ +{ pkgs }: +[ pkgs.coreutils pkgs.findutils pkgs.diffutils diff --git a/pkgs/stdenv/generic/default.nix b/pkgs/stdenv/generic/default.nix index 9952a6ae0623f7..fe9843c6b1202f 100644 --- a/pkgs/stdenv/generic/default.nix +++ b/pkgs/stdenv/generic/default.nix @@ -1,138 +1,161 @@ -let lib = import ../../../lib; stdenv-overridable = lib.makeOverridable ( - -argsStdenv@{ name ? "stdenv", preHook ? "", initialPath - -, # If we don't have a C compiler, we might either have `cc = null` or `cc = - # throw ...`, but if we do have a C compiler we should definiely have `cc != - # null`. - # - # TODO(@Ericson2314): Add assert without creating infinite recursion - hasCC ? cc != null, cc - -, shell -, allowedRequisites ? null, extraAttrs ? {}, overrides ? (self: super: {}), config -, disallowedRequisites ? [] - -, # The `fetchurl' to use for downloading curl and its dependencies - # (see all-packages.nix). - fetchurlBoot - -, setupScript ? ./setup.sh - -, extraNativeBuildInputs ? [] -, extraBuildInputs ? [] -, __stdenvImpureHostDeps ? [] -, __extraImpureHostDeps ? [] -, stdenvSandboxProfile ? "" -, extraSandboxProfile ? "" - - ## Platform parameters - ## - ## The "build" "host" "target" terminology below comes from GNU Autotools. See - ## its documentation for more information on what those words mean. Note that - ## each should always be defined, even when not cross compiling. - ## - ## For purposes of bootstrapping, think of each stage as a "sliding window" - ## over a list of platforms. Specifically, the host platform of the previous - ## stage becomes the build platform of the current one, and likewise the - ## target platform of the previous stage becomes the host platform of the - ## current one. - ## - -, # The platform on which packages are built. Consists of `system`, a - # string (e.g.,`i686-linux') identifying the most import attributes of the - # build platform, and `platform` a set of other details. - buildPlatform - -, # The platform on which packages run. - hostPlatform - -, # The platform which build tools (especially compilers) build for in this stage, - targetPlatform - -, # The implementation of `mkDerivation`, parameterized with the final stdenv so we can tie the knot. - # This is convient to have as a parameter so the stdenv "adapters" work better - mkDerivationFromStdenv ? stdenv: (import ./make-derivation.nix { inherit lib config; } stdenv).mkDerivation -}: - let - defaultNativeBuildInputs = extraNativeBuildInputs ++ - [ - ../../build-support/setup-hooks/audit-tmpdir.sh - ../../build-support/setup-hooks/compress-man-pages.sh - ../../build-support/setup-hooks/make-symlinks-relative.sh - ../../build-support/setup-hooks/move-docs.sh - ../../build-support/setup-hooks/move-lib64.sh - ../../build-support/setup-hooks/move-sbin.sh - ../../build-support/setup-hooks/move-systemd-user-units.sh - ../../build-support/setup-hooks/multiple-outputs.sh - ../../build-support/setup-hooks/patch-shebangs.sh - ../../build-support/setup-hooks/prune-libtool-files.sh - ../../build-support/setup-hooks/reproducible-builds.sh - ../../build-support/setup-hooks/set-source-date-epoch-to-latest.sh - ../../build-support/setup-hooks/strip.sh - ] ++ lib.optionals hasCC [ cc ]; - - defaultBuildInputs = extraBuildInputs; - - stdenv = (stdenv-overridable argsStdenv); - - # The stdenv that we are producing. - in - derivation ( - lib.optionalAttrs (allowedRequisites != null) { - allowedRequisites = allowedRequisites - ++ defaultNativeBuildInputs ++ defaultBuildInputs; - } - // lib.optionalAttrs config.contentAddressedByDefault { - __contentAddressed = true; - outputHashAlgo = "sha256"; - outputHashMode = "recursive"; - } - // { - inherit name; - inherit disallowedRequisites; - - # Nix itself uses the `system` field of a derivation to decide where to - # build it. This is a bit confusing for cross compilation. - inherit (buildPlatform) system; - - builder = shell; - - args = ["-e" ./builder.sh]; - - setup = setupScript; - - # We pretty much never need rpaths on Darwin, since all library path references - # are absolute unless we go out of our way to make them relative (like with CF) - # TODO: This really wants to be in stdenv/darwin but we don't have hostPlatform - # there (yet?) so it goes here until then. - preHook = preHook + lib.optionalString buildPlatform.isDarwin '' - export NIX_DONT_SET_RPATH_FOR_BUILD=1 - '' + lib.optionalString (hostPlatform.isDarwin || (!hostPlatform.isElf && !hostPlatform.isMacho)) '' - export NIX_DONT_SET_RPATH=1 - export NIX_NO_SELF_RPATH=1 - '' + lib.optionalString (hostPlatform.isDarwin && hostPlatform.isMacOS) '' - export MACOSX_DEPLOYMENT_TARGET=${hostPlatform.darwinMinVersion} - '' - # TODO this should be uncommented, but it causes stupid mass rebuilds due to - # `pkgsCross.*.buildPackages` not being the same, resulting in cross-compiling - # for a target rebuilding all of `nativeBuildInputs` for that target. + lib = import ../../../lib; + stdenv-overridable = lib.makeOverridable ( + + argsStdenv@{ + name ? "stdenv", + preHook ? "", + initialPath, + + # If we don't have a C compiler, we might either have `cc = null` or `cc = + # throw ...`, but if we do have a C compiler we should definiely have `cc != + # null`. # - # I think the best solution would just be to fixup linux RPATHs so we don't - # need to set `-rpath` anywhere. - # + lib.optionalString targetPlatform.isDarwin '' - # export NIX_DONT_SET_RPATH_FOR_TARGET=1 - # '' - ; - - inherit initialPath shell - defaultNativeBuildInputs defaultBuildInputs; - } - // lib.optionalAttrs buildPlatform.isDarwin { - __sandboxProfile = stdenvSandboxProfile; - __impureHostDeps = __stdenvImpureHostDeps; - }) + # TODO(@Ericson2314): Add assert without creating infinite recursion + hasCC ? cc != null, + cc, + + shell, + allowedRequisites ? null, + extraAttrs ? { }, + overrides ? (self: super: { }), + config, + disallowedRequisites ? [ ], + + # The `fetchurl' to use for downloading curl and its dependencies + # (see all-packages.nix). + fetchurlBoot, + + setupScript ? ./setup.sh, + + extraNativeBuildInputs ? [ ], + extraBuildInputs ? [ ], + __stdenvImpureHostDeps ? [ ], + __extraImpureHostDeps ? [ ], + stdenvSandboxProfile ? "", + extraSandboxProfile ? "", + + ## Platform parameters + ## + ## The "build" "host" "target" terminology below comes from GNU Autotools. See + ## its documentation for more information on what those words mean. Note that + ## each should always be defined, even when not cross compiling. + ## + ## For purposes of bootstrapping, think of each stage as a "sliding window" + ## over a list of platforms. Specifically, the host platform of the previous + ## stage becomes the build platform of the current one, and likewise the + ## target platform of the previous stage becomes the host platform of the + ## current one. + ## + + # The platform on which packages are built. Consists of `system`, a + # string (e.g.,`i686-linux') identifying the most import attributes of the + # build platform, and `platform` a set of other details. + buildPlatform, + + # The platform on which packages run. + hostPlatform, + + # The platform which build tools (especially compilers) build for in this stage, + targetPlatform, + + # The implementation of `mkDerivation`, parameterized with the final stdenv so we can tie the knot. + # This is convient to have as a parameter so the stdenv "adapters" work better + mkDerivationFromStdenv ? + stdenv: (import ./make-derivation.nix { inherit lib config; } stdenv).mkDerivation, + }: + + let + defaultNativeBuildInputs = + extraNativeBuildInputs + ++ [ + ../../build-support/setup-hooks/audit-tmpdir.sh + ../../build-support/setup-hooks/compress-man-pages.sh + ../../build-support/setup-hooks/make-symlinks-relative.sh + ../../build-support/setup-hooks/move-docs.sh + ../../build-support/setup-hooks/move-lib64.sh + ../../build-support/setup-hooks/move-sbin.sh + ../../build-support/setup-hooks/move-systemd-user-units.sh + ../../build-support/setup-hooks/multiple-outputs.sh + ../../build-support/setup-hooks/patch-shebangs.sh + ../../build-support/setup-hooks/prune-libtool-files.sh + ../../build-support/setup-hooks/reproducible-builds.sh + ../../build-support/setup-hooks/set-source-date-epoch-to-latest.sh + ../../build-support/setup-hooks/strip.sh + ] + ++ lib.optionals hasCC [ cc ]; + + defaultBuildInputs = extraBuildInputs; + + stdenv = (stdenv-overridable argsStdenv); + + in + # The stdenv that we are producing. + derivation ( + lib.optionalAttrs (allowedRequisites != null) { + allowedRequisites = allowedRequisites ++ defaultNativeBuildInputs ++ defaultBuildInputs; + } + // lib.optionalAttrs config.contentAddressedByDefault { + __contentAddressed = true; + outputHashAlgo = "sha256"; + outputHashMode = "recursive"; + } + // { + inherit name; + inherit disallowedRequisites; + + # Nix itself uses the `system` field of a derivation to decide where to + # build it. This is a bit confusing for cross compilation. + inherit (buildPlatform) system; + + builder = shell; + + args = [ + "-e" + ./builder.sh + ]; + + setup = setupScript; + + # We pretty much never need rpaths on Darwin, since all library path references + # are absolute unless we go out of our way to make them relative (like with CF) + # TODO: This really wants to be in stdenv/darwin but we don't have hostPlatform + # there (yet?) so it goes here until then. + preHook = + preHook + + lib.optionalString buildPlatform.isDarwin '' + export NIX_DONT_SET_RPATH_FOR_BUILD=1 + '' + + lib.optionalString (hostPlatform.isDarwin || (!hostPlatform.isElf && !hostPlatform.isMacho)) '' + export NIX_DONT_SET_RPATH=1 + export NIX_NO_SELF_RPATH=1 + '' + + lib.optionalString (hostPlatform.isDarwin && hostPlatform.isMacOS) '' + export MACOSX_DEPLOYMENT_TARGET=${hostPlatform.darwinMinVersion} + '' + # TODO this should be uncommented, but it causes stupid mass rebuilds due to + # `pkgsCross.*.buildPackages` not being the same, resulting in cross-compiling + # for a target rebuilding all of `nativeBuildInputs` for that target. + # + # I think the best solution would just be to fixup linux RPATHs so we don't + # need to set `-rpath` anywhere. + # + lib.optionalString targetPlatform.isDarwin '' + # export NIX_DONT_SET_RPATH_FOR_TARGET=1 + # '' + ; + + inherit + initialPath + shell + defaultNativeBuildInputs + defaultBuildInputs + ; + } + // lib.optionalAttrs buildPlatform.isDarwin { + __sandboxProfile = stdenvSandboxProfile; + __impureHostDeps = __stdenvImpureHostDeps; + } + ) // { @@ -143,15 +166,32 @@ let inherit buildPlatform hostPlatform targetPlatform; - inherit extraNativeBuildInputs extraBuildInputs - __extraImpureHostDeps extraSandboxProfile; + inherit + extraNativeBuildInputs + extraBuildInputs + __extraImpureHostDeps + extraSandboxProfile + ; # Utility flags to test the type of platform. inherit (hostPlatform) - isDarwin isLinux isSunOS isCygwin isBSD isFreeBSD isOpenBSD - isi686 isx86_32 isx86_64 - is32bit is64bit - isAarch32 isAarch64 isMips isBigEndian; + isDarwin + isLinux + isSunOS + isCygwin + isBSD + isFreeBSD + isOpenBSD + isi686 + isx86_32 + isx86_64 + is32bit + is64bit + isAarch32 + isAarch64 + isMips + isBigEndian + ; # Override `system` so that packages can get the system of the host # platform through `stdenv.system`. `system` is originally set to the @@ -183,4 +223,6 @@ let # all-packages.nix for that platform (meaning that it has a line # like curl = if stdenv ? curl then stdenv.curl else ...). // extraAttrs -); in stdenv-overridable + ); +in +stdenv-overridable diff --git a/pkgs/stdenv/generic/meta-types.nix b/pkgs/stdenv/generic/meta-types.nix index ddbd1daca696ea..a51ae2b1271130 100644 --- a/pkgs/stdenv/generic/meta-types.nix +++ b/pkgs/stdenv/generic/meta-types.nix @@ -5,7 +5,19 @@ # TODO: add a method to the module system types # see https://github.com/NixOS/nixpkgs/pull/273935#issuecomment-1854173100 let - inherit (builtins) isString isInt isAttrs isList all any attrValues isFunction isBool concatStringsSep isFloat; + inherit (builtins) + isString + isInt + isAttrs + isList + all + any + attrValues + isFunction + isBool + concatStringsSep + isFloat + ; isTypeDef = t: isAttrs t && t ? name && isString t.name && t ? verify && isFunction t.verify; in @@ -14,7 +26,7 @@ lib.fix (self: { name = "string"; verify = isString; }; - str = self.string; # Type alias + str = self.string; # Type alias any = { name = "any"; @@ -46,31 +58,41 @@ lib.fix (self: { verify = isList; }; - attrsOf = t: assert isTypeDef t; let - inherit (t) verify; - in { - name = "attrsOf<${t.name}>"; - verify = - # attrsOf can be optimised to just isAttrs - if t == self.any then isAttrs - else attrs: isAttrs attrs && all verify (attrValues attrs); - }; + attrsOf = + t: + assert isTypeDef t; + let + inherit (t) verify; + in + { + name = "attrsOf<${t.name}>"; + verify = + # attrsOf can be optimised to just isAttrs + if t == self.any then isAttrs else attrs: isAttrs attrs && all verify (attrValues attrs); + }; - listOf = t: assert isTypeDef t; let - inherit (t) verify; - in { - name = "listOf<${t.name}>"; - verify = - # listOf can be optimised to just isList - if t == self.any then isList - else v: isList v && all verify v; - }; + listOf = + t: + assert isTypeDef t; + let + inherit (t) verify; + in + { + name = "listOf<${t.name}>"; + verify = + # listOf can be optimised to just isList + if t == self.any then isList else v: isList v && all verify v; + }; - union = types: assert all isTypeDef types; let - # Store a list of functions so we don't have to pay the cost of attrset lookups at runtime. - funcs = map (t: t.verify) types; - in { - name = "union<${concatStringsSep "," (map (t: t.name) types)}>"; - verify = v: any (func: func v) funcs; - }; + union = + types: + assert all isTypeDef types; + let + # Store a list of functions so we don't have to pay the cost of attrset lookups at runtime. + funcs = map (t: t.verify) types; + in + { + name = "union<${concatStringsSep "," (map (t: t.name) types)}>"; + verify = v: any (func: func v) funcs; + }; }) diff --git a/pkgs/stdenv/linux/bootstrap-files/mips64el-unknown-linux-gnuabi64.nix b/pkgs/stdenv/linux/bootstrap-files/mips64el-unknown-linux-gnuabi64.nix index 452a247fb0b9c7..a72ab784b014b1 100644 --- a/pkgs/stdenv/linux/bootstrap-files/mips64el-unknown-linux-gnuabi64.nix +++ b/pkgs/stdenv/linux/bootstrap-files/mips64el-unknown-linux-gnuabi64.nix @@ -18,7 +18,7 @@ sha256 = "sha256-sTE58ofjqAqX3Xtq1g9wDxzIe6Vo//GHbicfqJoivDI="; executable = true; }; - bootstrapTools =import { + bootstrapTools = import { url = "http://tarballs.nixos.org/stdenv-linux/mips64el/ef3fe254f3c59455386bc92fe84164f9679b92b1/bootstrap-tools.tar.xz"; sha256 = "sha256-tTgjeXpd2YgnfP4JvRuO0bXd2j8GqzBcd57JI3wH9x0="; }; diff --git a/pkgs/stdenv/linux/default.nix b/pkgs/stdenv/linux/default.nix index b8111f34e30afe..40b4b1db194d01 100644 --- a/pkgs/stdenv/linux/default.nix +++ b/pkgs/stdenv/linux/default.nix @@ -53,48 +53,66 @@ # For a TUI (rather than CLI) view, you can use: # # $ nix-tree --derivation $(nix-instantiate -A stdenv) -{ lib -, localSystem, crossSystem, config, overlays, crossOverlays ? [] - -, bootstrapFiles ? - let table = { - glibc = { - i686-linux = import ./bootstrap-files/i686-unknown-linux-gnu.nix; - x86_64-linux = import ./bootstrap-files/x86_64-unknown-linux-gnu.nix; - armv5tel-linux = import ./bootstrap-files/armv5tel-unknown-linux-gnueabi.nix; - armv6l-linux = import ./bootstrap-files/armv6l-unknown-linux-gnueabihf.nix; - armv7l-linux = import ./bootstrap-files/armv7l-unknown-linux-gnueabihf.nix; - aarch64-linux = import ./bootstrap-files/aarch64-unknown-linux-gnu.nix; - mipsel-linux = import ./bootstrap-files/mipsel-unknown-linux-gnu.nix; - mips64el-linux = import - (if localSystem.isMips64n32 - then ./bootstrap-files/mips64el-unknown-linux-gnuabin32.nix - else ./bootstrap-files/mips64el-unknown-linux-gnuabi64.nix); - powerpc64-linux = import ./bootstrap-files/powerpc64-unknown-linux-gnuabielfv2.nix; - powerpc64le-linux = import ./bootstrap-files/powerpc64le-unknown-linux-gnu.nix; - riscv64-linux = import ./bootstrap-files/riscv64-unknown-linux-gnu.nix; - s390x-linux = import ./bootstrap-files/s390x-unknown-linux-gnu.nix; - }; - musl = { - aarch64-linux = import ./bootstrap-files/aarch64-unknown-linux-musl.nix; - armv6l-linux = import ./bootstrap-files/armv6l-unknown-linux-musleabihf.nix; - x86_64-linux = import ./bootstrap-files/x86_64-unknown-linux-musl.nix; - }; - }; +{ + lib, + localSystem, + crossSystem, + config, + overlays, + crossOverlays ? [ ], + + bootstrapFiles ? + let + table = { + glibc = { + i686-linux = import ./bootstrap-files/i686-unknown-linux-gnu.nix; + x86_64-linux = import ./bootstrap-files/x86_64-unknown-linux-gnu.nix; + armv5tel-linux = import ./bootstrap-files/armv5tel-unknown-linux-gnueabi.nix; + armv6l-linux = import ./bootstrap-files/armv6l-unknown-linux-gnueabihf.nix; + armv7l-linux = import ./bootstrap-files/armv7l-unknown-linux-gnueabihf.nix; + aarch64-linux = import ./bootstrap-files/aarch64-unknown-linux-gnu.nix; + mipsel-linux = import ./bootstrap-files/mipsel-unknown-linux-gnu.nix; + mips64el-linux = import ( + if localSystem.isMips64n32 then + ./bootstrap-files/mips64el-unknown-linux-gnuabin32.nix + else + ./bootstrap-files/mips64el-unknown-linux-gnuabi64.nix + ); + powerpc64-linux = import ./bootstrap-files/powerpc64-unknown-linux-gnuabielfv2.nix; + powerpc64le-linux = import ./bootstrap-files/powerpc64le-unknown-linux-gnu.nix; + riscv64-linux = import ./bootstrap-files/riscv64-unknown-linux-gnu.nix; + s390x-linux = import ./bootstrap-files/s390x-unknown-linux-gnu.nix; + }; + musl = { + aarch64-linux = import ./bootstrap-files/aarch64-unknown-linux-musl.nix; + armv6l-linux = import ./bootstrap-files/armv6l-unknown-linux-musleabihf.nix; + x86_64-linux = import ./bootstrap-files/x86_64-unknown-linux-musl.nix; + }; + }; - # Try to find an architecture compatible with our current system. We - # just try every bootstrap we’ve got and test to see if it is - # compatible with or current architecture. - getCompatibleTools = lib.foldl (v: system: - if v != null then v - else if localSystem.canExecute (lib.systems.elaborate { inherit system; }) then archLookupTable.${system} - else null) null (lib.attrNames archLookupTable); - - archLookupTable = table.${localSystem.libc} - or (throw "unsupported libc for the pure Linux stdenv"); - files = archLookupTable.${localSystem.system} or (if getCompatibleTools != null then getCompatibleTools - else (throw "unsupported platform for the pure Linux stdenv")); - in (config.replaceBootstrapFiles or lib.id) files + # Try to find an architecture compatible with our current system. We + # just try every bootstrap we’ve got and test to see if it is + # compatible with or current architecture. + getCompatibleTools = lib.foldl ( + v: system: + if v != null then + v + else if localSystem.canExecute (lib.systems.elaborate { inherit system; }) then + archLookupTable.${system} + else + null + ) null (lib.attrNames archLookupTable); + + archLookupTable = table.${localSystem.libc} or (throw "unsupported libc for the pure Linux stdenv"); + files = + archLookupTable.${localSystem.system} or ( + if getCompatibleTools != null then + getCompatibleTools + else + (throw "unsupported platform for the pure Linux stdenv") + ); + in + (config.replaceBootstrapFiles or lib.id) files, }: assert crossSystem == localSystem; @@ -103,12 +121,9 @@ let inherit (localSystem) system; isFromNixpkgs = pkg: !(isFromBootstrapFiles pkg); - isFromBootstrapFiles = - pkg: pkg.passthru.isFromBootstrapFiles or false; - isBuiltByNixpkgsCompiler = - pkg: isFromNixpkgs pkg && isFromNixpkgs pkg.stdenv.cc.cc; - isBuiltByBootstrapFilesCompiler = - pkg: isFromNixpkgs pkg && isFromBootstrapFiles pkg.stdenv.cc.cc; + isFromBootstrapFiles = pkg: pkg.passthru.isFromBootstrapFiles or false; + isBuiltByNixpkgsCompiler = pkg: isFromNixpkgs pkg && isFromNixpkgs pkg.stdenv.cc.cc; + isBuiltByBootstrapFilesCompiler = pkg: isFromNixpkgs pkg && isFromBootstrapFiles pkg.stdenv.cc.cc; commonGccOverrides = { # Use a deterministically built compiler @@ -125,20 +140,16 @@ let disableGdbPlugin = true; }; - commonPreHook = - '' - export NIX_ENFORCE_PURITY="''${NIX_ENFORCE_PURITY-1}" - export NIX_ENFORCE_NO_NATIVE="''${NIX_ENFORCE_NO_NATIVE-1}" - ''; - + commonPreHook = '' + export NIX_ENFORCE_PURITY="''${NIX_ENFORCE_PURITY-1}" + export NIX_ENFORCE_NO_NATIVE="''${NIX_ENFORCE_NO_NATIVE-1}" + ''; # The bootstrap process proceeds in several steps. - # Create a standard environment by downloading pre-built binaries of # coreutils, GCC, etc. - # Download and unpack the bootstrap tools (coreutils, GCC, Glibc, ...). bootstrapTools = import ./bootstrap-tools { inherit (localSystem) libc system; @@ -148,12 +159,16 @@ let getLibc = stage: stage.${localSystem.libc}; - # This function builds the various standard environments used during # the bootstrap. In all stages, we build an stdenv and the package # set that can be built with that stdenv. - stageFun = prevStage: - { name, overrides ? (self: super: {}), extraNativeBuildInputs ? [] }: + stageFun = + prevStage: + { + name, + overrides ? (self: super: { }), + extraNativeBuildInputs ? [ ], + }: let @@ -163,114 +178,130 @@ let hostPlatform = localSystem; targetPlatform = localSystem; inherit config extraNativeBuildInputs; - preHook = - '' - # Don't patch #!/interpreter because it leads to retained - # dependencies on the bootstrapTools in the final stdenv. - dontPatchShebangs=1 - ${commonPreHook} - ''; + preHook = '' + # Don't patch #!/interpreter because it leads to retained + # dependencies on the bootstrapTools in the final stdenv. + dontPatchShebangs=1 + ${commonPreHook} + ''; shell = "${bootstrapTools}/bin/bash"; - initialPath = [bootstrapTools]; + initialPath = [ bootstrapTools ]; fetchurlBoot = import ../../build-support/fetchurl/boot.nix { inherit system; }; - cc = if prevStage.gcc-unwrapped == null - then null - else (lib.makeOverridable (import ../../build-support/cc-wrapper) { - name = "${name}-gcc-wrapper"; - nativeTools = false; - nativeLibc = false; - expand-response-params = lib.optionalString - (prevStage.stdenv.hasCC or false && prevStage.stdenv.cc != "/dev/null") - prevStage.expand-response-params; - cc = prevStage.gcc-unwrapped; - bintools = prevStage.binutils; - isGNU = true; - libc = getLibc prevStage; - inherit lib; - inherit (prevStage) coreutils gnugrep; - stdenvNoCC = prevStage.ccWrapperStdenv; - fortify-headers = prevStage.fortify-headers; - runtimeShell = prevStage.ccWrapperStdenv.shell; - }).overrideAttrs(a: lib.optionalAttrs (prevStage.gcc-unwrapped.passthru.isXgcc or false) { - # This affects only `xgcc` (the compiler which compiles the final compiler). - postFixup = (a.postFixup or "") + '' - echo "--sysroot=${lib.getDev (getLibc prevStage)}" >> $out/nix-support/cc-cflags - ''; - }); + cc = + if prevStage.gcc-unwrapped == null then + null + else + (lib.makeOverridable (import ../../build-support/cc-wrapper) { + name = "${name}-gcc-wrapper"; + nativeTools = false; + nativeLibc = false; + expand-response-params = lib.optionalString ( + prevStage.stdenv.hasCC or false && prevStage.stdenv.cc != "/dev/null" + ) prevStage.expand-response-params; + cc = prevStage.gcc-unwrapped; + bintools = prevStage.binutils; + isGNU = true; + libc = getLibc prevStage; + inherit lib; + inherit (prevStage) coreutils gnugrep; + stdenvNoCC = prevStage.ccWrapperStdenv; + fortify-headers = prevStage.fortify-headers; + runtimeShell = prevStage.ccWrapperStdenv.shell; + }).overrideAttrs + ( + a: + lib.optionalAttrs (prevStage.gcc-unwrapped.passthru.isXgcc or false) { + # This affects only `xgcc` (the compiler which compiles the final compiler). + postFixup = + (a.postFixup or "") + + '' + echo "--sysroot=${lib.getDev (getLibc prevStage)}" >> $out/nix-support/cc-cflags + ''; + } + ); overrides = self: super: (overrides self super) // { fetchurl = thisStdenv.fetchurlBoot; }; }; - in { + in + { inherit config overlays; stdenv = thisStdenv; }; in - assert bootstrapTools.passthru.isFromBootstrapFiles or false; # sanity check +assert bootstrapTools.passthru.isFromBootstrapFiles or false; # sanity check [ - ({}: { - __raw = true; + ( + { }: + { + __raw = true; - gcc-unwrapped = null; - binutils = null; - coreutils = null; - gnugrep = null; - }) + gcc-unwrapped = null; + binutils = null; + coreutils = null; + gnugrep = null; + } + ) # Build a dummy stdenv with no GCC or working fetchurl. This is # because we need a stdenv to build the GCC wrapper and fetchurl. - (prevStage: stageFun prevStage { - name = "bootstrap-stage0"; - - overrides = self: super: { - # We thread stage0's stdenv through under this name so downstream stages - # can use it for wrapping gcc too. This way, downstream stages don't need - # to refer to this stage directly, which violates the principle that each - # stage should only access the stage that came before it. - ccWrapperStdenv = self.stdenv; - # The Glibc include directory cannot have the same prefix as the - # GCC include directory, since GCC gets confused otherwise (it - # will search the Glibc headers before the GCC headers). So - # create a dummy Glibc here, which will be used in the stdenv of - # stage1. - ${localSystem.libc} = self.stdenv.mkDerivation { - pname = "bootstrap-stage0-${localSystem.libc}"; - strictDeps = true; - version = "bootstrapFiles"; - enableParallelBuilding = true; - buildCommand = '' - mkdir -p $out - ln -s ${bootstrapTools}/lib $out/lib - '' + lib.optionalString (localSystem.libc == "glibc") '' - ln -s ${bootstrapTools}/include-glibc $out/include - '' + lib.optionalString (localSystem.libc == "musl") '' - ln -s ${bootstrapTools}/include-libc $out/include - ''; - passthru.isFromBootstrapFiles = true; - }; - gcc-unwrapped = bootstrapTools; - binutils = import ../../build-support/bintools-wrapper { - name = "bootstrap-stage0-binutils-wrapper"; - nativeTools = false; - nativeLibc = false; - expand-response-params = ""; - libc = getLibc self; - inherit lib; - inherit (self) stdenvNoCC coreutils gnugrep; - bintools = bootstrapTools; - runtimeShell = "${bootstrapTools}/bin/bash"; - }; - coreutils = bootstrapTools; - gnugrep = bootstrapTools; - }; - }) + ( + prevStage: + stageFun prevStage { + name = "bootstrap-stage0"; + overrides = self: super: { + # We thread stage0's stdenv through under this name so downstream stages + # can use it for wrapping gcc too. This way, downstream stages don't need + # to refer to this stage directly, which violates the principle that each + # stage should only access the stage that came before it. + ccWrapperStdenv = self.stdenv; + # The Glibc include directory cannot have the same prefix as the + # GCC include directory, since GCC gets confused otherwise (it + # will search the Glibc headers before the GCC headers). So + # create a dummy Glibc here, which will be used in the stdenv of + # stage1. + ${localSystem.libc} = self.stdenv.mkDerivation { + pname = "bootstrap-stage0-${localSystem.libc}"; + strictDeps = true; + version = "bootstrapFiles"; + enableParallelBuilding = true; + buildCommand = + '' + mkdir -p $out + ln -s ${bootstrapTools}/lib $out/lib + '' + + lib.optionalString (localSystem.libc == "glibc") '' + ln -s ${bootstrapTools}/include-glibc $out/include + '' + + lib.optionalString (localSystem.libc == "musl") '' + ln -s ${bootstrapTools}/include-libc $out/include + ''; + passthru.isFromBootstrapFiles = true; + }; + gcc-unwrapped = bootstrapTools; + binutils = import ../../build-support/bintools-wrapper { + name = "bootstrap-stage0-binutils-wrapper"; + nativeTools = false; + nativeLibc = false; + expand-response-params = ""; + libc = getLibc self; + inherit lib; + inherit (self) stdenvNoCC coreutils gnugrep; + bintools = bootstrapTools; + runtimeShell = "${bootstrapTools}/bin/bash"; + }; + coreutils = bootstrapTools; + gnugrep = bootstrapTools; + }; + } + ) # Create the first "real" standard environment. This one consists # of bootstrap tools only, and a minimal Glibc to keep the GCC @@ -282,7 +313,8 @@ in # If we ever need to use a package from more than one stage back, we # simply re-export those packages in the middle stage(s) using the # overrides attribute and the inherit syntax. - (prevStage: + ( + prevStage: # previous stage0 stdenv: assert isFromBootstrapFiles prevStage.binutils.bintools; assert isFromBootstrapFiles prevStage."${localSystem.libc}"; @@ -290,46 +322,66 @@ in assert isFromBootstrapFiles prevStage.coreutils; assert isFromBootstrapFiles prevStage.gnugrep; stageFun prevStage { - name = "bootstrap-stage1"; + name = "bootstrap-stage1"; - # Rebuild binutils to use from stage2 onwards. - overrides = self: super: { - binutils-unwrapped = super.binutils-unwrapped.override { - enableGold = false; + # Rebuild binutils to use from stage2 onwards. + overrides = self: super: { + binutils-unwrapped = super.binutils-unwrapped.override { + enableGold = false; + }; + inherit (prevStage) + ccWrapperStdenv + gcc-unwrapped + coreutils + gnugrep + binutils + ; + + ${localSystem.libc} = getLibc prevStage; + + # A threaded perl build needs glibc/libpthread_nonshared.a, + # which is not included in bootstrapTools, so disable threading. + # This is not an issue for the final stdenv, because this perl + # won't be included in the final stdenv and won't be exported to + # top-level pkgs as an override either. + perl = super.perl.override { + enableThreading = false; + enableCrypt = false; + }; }; - inherit (prevStage) - ccWrapperStdenv - gcc-unwrapped coreutils gnugrep binutils; - - ${localSystem.libc} = getLibc prevStage; - - # A threaded perl build needs glibc/libpthread_nonshared.a, - # which is not included in bootstrapTools, so disable threading. - # This is not an issue for the final stdenv, because this perl - # won't be included in the final stdenv and won't be exported to - # top-level pkgs as an override either. - perl = super.perl.override { enableThreading = false; enableCrypt = false; }; - }; - # `gettext` comes with obsolete config.sub/config.guess that don't recognize LoongArch64. - extraNativeBuildInputs = [ prevStage.updateAutotoolsGnuConfigScriptsHook ]; - }) + # `gettext` comes with obsolete config.sub/config.guess that don't recognize LoongArch64. + extraNativeBuildInputs = [ prevStage.updateAutotoolsGnuConfigScriptsHook ]; + } + ) # First rebuild of gcc; this is linked against all sorts of junk # from the bootstrap-files, but we only care about the code that # this compiler *emits*. The `gcc` binary produced in this stage # is not part of the final stdenv. - (prevStage: + ( + prevStage: assert isBuiltByBootstrapFilesCompiler prevStage.binutils-unwrapped; - assert isFromBootstrapFiles prevStage."${localSystem.libc}"; - assert isFromBootstrapFiles prevStage.gcc-unwrapped; - assert isFromBootstrapFiles prevStage.coreutils; - assert isFromBootstrapFiles prevStage.gnugrep; + assert isFromBootstrapFiles prevStage."${localSystem.libc}"; + assert isFromBootstrapFiles prevStage.gcc-unwrapped; + assert isFromBootstrapFiles prevStage.coreutils; + assert isFromBootstrapFiles prevStage.gnugrep; assert isBuiltByBootstrapFilesCompiler prevStage.patchelf; stageFun prevStage { name = "bootstrap-stage-xgcc"; overrides = self: super: { - inherit (prevStage) ccWrapperStdenv coreutils gnugrep gettext bison texinfo zlib gnum4 perl patchelf; + inherit (prevStage) + ccWrapperStdenv + coreutils + gnugrep + gettext + bison + texinfo + zlib + gnum4 + perl + patchelf + ; ${localSystem.libc} = getLibc prevStage; gmp = super.gmp.override { cxx = false; }; # This stage also rebuilds binutils which will of course be used only in the next stage. @@ -341,246 +393,321 @@ in runtimeShell = "${bootstrapTools}/bin/bash"; }; gcc-unwrapped = - (super.gcc-unwrapped.override (commonGccOverrides // { - # The most logical name for this package would be something like - # "gcc-stage1". Unfortunately "stage" is already reserved for the - # layers of stdenv, so using "stage" in the name of this package - # would cause massive confusion. - # - # Gcc calls its "stage1" compiler `xgcc` (--disable-bootstrap results - # in `xgcc` being copied to $prefix/bin/gcc). So we imitate that. - # - name = "xgcc"; - - # xgcc uses ld linked against nixpkgs' glibc and gcc built - # against bootstrapTools glibc. We can't allow loading - # $out/libexec/gcc/x86_64-unknown-linux-gnu/13.0.1/liblto_plugin.so - # to mix libc.so: - # ...-binutils-patchelfed-ld-2.40/bin/ld: ...-xgcc-13.0.0/libexec/gcc/x86_64-unknown-linux-gnu/13.0.1/liblto_plugin.so: - # error loading plugin: ...-bootstrap-tools/lib/libpthread.so.0: undefined symbol: __libc_vfork, version GLIBC_PRIVATE - enableLTO = false; - })).overrideAttrs (a: { - - # This signals to cc-wrapper (as overridden above in this file) to add `--sysroot` - # to `$out/nix-support/cc-cflags`. - passthru = a.passthru // { isXgcc = true; }; - - # Gcc will look for the C library headers in - # - # ${with_build_sysroot}${native_system_header_dir} - # - # The ordinary gcc expression sets `--with-build-sysroot=/` and sets - # `native-system-header-dir` to `"${lib.getDev stdenv.cc.libc}/include`. - # - # Unfortunately the value of "--with-native-system-header-dir=" gets "burned in" to the - # compiler, and it is quite difficult to get the compiler to change or ignore it - # afterwards. On the other hand, the `sysroot` is very easy to change; you can just pass - # a `--sysroot` flag to `gcc`. - # - # So we override the expression to remove the default settings for these flags, and - # replace them such that the concatenated value will be the same as before, but we split - # the value between the two variables differently: `--native-system-header-dir=/include`, - # and `--with-build-sysroot=${lib.getDev stdenv.cc.libc}`. - # - configureFlags = (a.configureFlags or []) ++ [ - "--with-native-system-header-dir=/include" - "--with-build-sysroot=${lib.getDev self.stdenv.cc.libc}" - ]; - - # This is a separate phase because gcc assembles its phase scripts - # in bash instead of nix (we should fix that). - preFixupPhases = (a.preFixupPhases or []) ++ [ "preFixupXgccPhase" ]; - - # This is needed to prevent "error: cycle detected in build of '...-xgcc-....drv' - # in the references of output 'lib' from output 'out'" - preFixupXgccPhase = '' - find $lib/lib/ -name \*.so\* -exec patchelf --shrink-rpath {} \; || true - ''; - }); + (super.gcc-unwrapped.override ( + commonGccOverrides + // { + # The most logical name for this package would be something like + # "gcc-stage1". Unfortunately "stage" is already reserved for the + # layers of stdenv, so using "stage" in the name of this package + # would cause massive confusion. + # + # Gcc calls its "stage1" compiler `xgcc` (--disable-bootstrap results + # in `xgcc` being copied to $prefix/bin/gcc). So we imitate that. + # + name = "xgcc"; + + # xgcc uses ld linked against nixpkgs' glibc and gcc built + # against bootstrapTools glibc. We can't allow loading + # $out/libexec/gcc/x86_64-unknown-linux-gnu/13.0.1/liblto_plugin.so + # to mix libc.so: + # ...-binutils-patchelfed-ld-2.40/bin/ld: ...-xgcc-13.0.0/libexec/gcc/x86_64-unknown-linux-gnu/13.0.1/liblto_plugin.so: + # error loading plugin: ...-bootstrap-tools/lib/libpthread.so.0: undefined symbol: __libc_vfork, version GLIBC_PRIVATE + enableLTO = false; + } + )).overrideAttrs + (a: { + + # This signals to cc-wrapper (as overridden above in this file) to add `--sysroot` + # to `$out/nix-support/cc-cflags`. + passthru = a.passthru // { + isXgcc = true; + }; + + # Gcc will look for the C library headers in + # + # ${with_build_sysroot}${native_system_header_dir} + # + # The ordinary gcc expression sets `--with-build-sysroot=/` and sets + # `native-system-header-dir` to `"${lib.getDev stdenv.cc.libc}/include`. + # + # Unfortunately the value of "--with-native-system-header-dir=" gets "burned in" to the + # compiler, and it is quite difficult to get the compiler to change or ignore it + # afterwards. On the other hand, the `sysroot` is very easy to change; you can just pass + # a `--sysroot` flag to `gcc`. + # + # So we override the expression to remove the default settings for these flags, and + # replace them such that the concatenated value will be the same as before, but we split + # the value between the two variables differently: `--native-system-header-dir=/include`, + # and `--with-build-sysroot=${lib.getDev stdenv.cc.libc}`. + # + configureFlags = (a.configureFlags or [ ]) ++ [ + "--with-native-system-header-dir=/include" + "--with-build-sysroot=${lib.getDev self.stdenv.cc.libc}" + ]; + + # This is a separate phase because gcc assembles its phase scripts + # in bash instead of nix (we should fix that). + preFixupPhases = (a.preFixupPhases or [ ]) ++ [ "preFixupXgccPhase" ]; + + # This is needed to prevent "error: cycle detected in build of '...-xgcc-....drv' + # in the references of output 'lib' from output 'out'" + preFixupXgccPhase = '' + find $lib/lib/ -name \*.so\* -exec patchelf --shrink-rpath {} \; || true + ''; + }); }; # `gettext` comes with obsolete config.sub/config.guess that don't recognize LoongArch64. extraNativeBuildInputs = [ prevStage.updateAutotoolsGnuConfigScriptsHook ]; - }) + } + ) # 2nd stdenv that contains our own rebuilt binutils and is used for # compiling our own Glibc. # - (prevStage: + ( + prevStage: # previous stage1 stdenv: assert isBuiltByBootstrapFilesCompiler prevStage.binutils-unwrapped; - assert isFromBootstrapFiles prevStage."${localSystem.libc}"; + assert isFromBootstrapFiles prevStage."${localSystem.libc}"; assert isBuiltByBootstrapFilesCompiler prevStage.gcc-unwrapped; - assert isFromBootstrapFiles prevStage.coreutils; - assert isFromBootstrapFiles prevStage.gnugrep; + assert isFromBootstrapFiles prevStage.coreutils; + assert isFromBootstrapFiles prevStage.gnugrep; assert isBuiltByBootstrapFilesCompiler prevStage.patchelf; stageFun prevStage { - name = "bootstrap-stage2"; - - overrides = self: super: { - inherit (prevStage) - ccWrapperStdenv gettext - gcc-unwrapped coreutils gnugrep - perl gnum4 bison texinfo which; - dejagnu = super.dejagnu.overrideAttrs (a: { doCheck = false; } ); - - # We need libidn2 and its dependency libunistring as glibc dependency. - # To avoid the cycle, we build against bootstrap libc, nuke references, - # and use the result as input for our final glibc. We also pass this pair - # through, so the final package-set uses exactly the same builds. - libunistring = super.libunistring.overrideAttrs (attrs: { - postFixup = attrs.postFixup or "" + '' - ${self.nukeReferences}/bin/nuke-refs "$out"/lib/lib*.so.*.* - ''; - # Apparently iconv won't work with bootstrap glibc, but it will be used - # with glibc built later where we keep *this* build of libunistring, - # so we need to trick it into supporting libiconv. - env = attrs.env or {} // { am_cv_func_iconv_works = "yes"; }; - }); - libidn2 = super.libidn2.overrideAttrs (attrs: { - postFixup = attrs.postFixup or "" + '' - ${self.nukeReferences}/bin/nuke-refs -e '${lib.getLib self.libunistring}' \ - "$out"/lib/lib*.so.*.* - ''; - }); - - # This also contains the full, dynamically linked, final Glibc. - binutils = prevStage.binutils.override { - # Rewrap the binutils with the new glibc, so both the next - # stage's wrappers use it. - libc = getLibc self; - - # Unfortunately, when building gcc in the next stage, its LTO plugin - # would use the final libc but `ld` would use the bootstrap one, - # and that can fail to load. Therefore we upgrade `ld` to use newer libc; - # apparently the interpreter needs to match libc, too. - bintools = self.stdenvNoCC.mkDerivation { - pname = prevStage.bintools.bintools.pname + "-patchelfed-ld"; - inherit (prevStage.bintools.bintools) version; - passthru = { inherit (prevStage.bintools.passthru) isFromBootstrapFiles; }; - enableParallelBuilding = true; - dontUnpack = true; - dontBuild = true; - strictDeps = true; - # We wouldn't need to *copy* all, but it's easier and the result is temporary anyway. - installPhase = '' - mkdir -p "$out"/bin - cp -a '${prevStage.bintools.bintools}'/bin/* "$out"/bin/ - chmod +w "$out"/bin/ld.bfd - patchelf --set-interpreter '${getLibc self}'/lib/ld*.so.? \ - --set-rpath "${getLibc self}/lib:$(patchelf --print-rpath "$out"/bin/ld.bfd)" \ - "$out"/bin/ld.bfd - ''; - }; - }; + name = "bootstrap-stage2"; - # TODO(amjoseph): It is not yet entirely clear why this is necessary. - # Something strange is going on with xgcc and libstdc++ on pkgsMusl. - patchelf = super.patchelf.overrideAttrs(previousAttrs: - lib.optionalAttrs super.stdenv.hostPlatform.isMusl { - NIX_CFLAGS_COMPILE = (previousAttrs.NIX_CFLAGS_COMPILE or "") + " -static-libstdc++"; + overrides = self: super: { + inherit (prevStage) + ccWrapperStdenv + gettext + gcc-unwrapped + coreutils + gnugrep + perl + gnum4 + bison + texinfo + which + ; + dejagnu = super.dejagnu.overrideAttrs (a: { + doCheck = false; }); - }; + # We need libidn2 and its dependency libunistring as glibc dependency. + # To avoid the cycle, we build against bootstrap libc, nuke references, + # and use the result as input for our final glibc. We also pass this pair + # through, so the final package-set uses exactly the same builds. + libunistring = super.libunistring.overrideAttrs (attrs: { + postFixup = + attrs.postFixup or "" + + '' + ${self.nukeReferences}/bin/nuke-refs "$out"/lib/lib*.so.*.* + ''; + # Apparently iconv won't work with bootstrap glibc, but it will be used + # with glibc built later where we keep *this* build of libunistring, + # so we need to trick it into supporting libiconv. + env = attrs.env or { } // { + am_cv_func_iconv_works = "yes"; + }; + }); + libidn2 = super.libidn2.overrideAttrs (attrs: { + postFixup = + attrs.postFixup or "" + + '' + ${self.nukeReferences}/bin/nuke-refs -e '${lib.getLib self.libunistring}' \ + "$out"/lib/lib*.so.*.* + ''; + }); - # `gettext` comes with obsolete config.sub/config.guess that don't recognize LoongArch64. - # `libtool` comes with obsolete config.sub/config.guess that don't recognize Risc-V. - extraNativeBuildInputs = [ prevStage.updateAutotoolsGnuConfigScriptsHook ]; - }) + # This also contains the full, dynamically linked, final Glibc. + binutils = prevStage.binutils.override { + # Rewrap the binutils with the new glibc, so both the next + # stage's wrappers use it. + libc = getLibc self; + + # Unfortunately, when building gcc in the next stage, its LTO plugin + # would use the final libc but `ld` would use the bootstrap one, + # and that can fail to load. Therefore we upgrade `ld` to use newer libc; + # apparently the interpreter needs to match libc, too. + bintools = self.stdenvNoCC.mkDerivation { + pname = prevStage.bintools.bintools.pname + "-patchelfed-ld"; + inherit (prevStage.bintools.bintools) version; + passthru = { inherit (prevStage.bintools.passthru) isFromBootstrapFiles; }; + enableParallelBuilding = true; + dontUnpack = true; + dontBuild = true; + strictDeps = true; + # We wouldn't need to *copy* all, but it's easier and the result is temporary anyway. + installPhase = '' + mkdir -p "$out"/bin + cp -a '${prevStage.bintools.bintools}'/bin/* "$out"/bin/ + chmod +w "$out"/bin/ld.bfd + patchelf --set-interpreter '${getLibc self}'/lib/ld*.so.? \ + --set-rpath "${getLibc self}/lib:$(patchelf --print-rpath "$out"/bin/ld.bfd)" \ + "$out"/bin/ld.bfd + ''; + }; + }; + # TODO(amjoseph): It is not yet entirely clear why this is necessary. + # Something strange is going on with xgcc and libstdc++ on pkgsMusl. + patchelf = super.patchelf.overrideAttrs ( + previousAttrs: + lib.optionalAttrs super.stdenv.hostPlatform.isMusl { + NIX_CFLAGS_COMPILE = (previousAttrs.NIX_CFLAGS_COMPILE or "") + " -static-libstdc++"; + } + ); + + }; + + # `gettext` comes with obsolete config.sub/config.guess that don't recognize LoongArch64. + # `libtool` comes with obsolete config.sub/config.guess that don't recognize Risc-V. + extraNativeBuildInputs = [ prevStage.updateAutotoolsGnuConfigScriptsHook ]; + } + ) # Construct a third stdenv identical to the 2nd, except that this # one uses the rebuilt Glibc from stage2. It still uses the recent # binutils and rest of the bootstrap tools, including GCC. - (prevStage: + ( + prevStage: # previous stage2 stdenv: - assert isBuiltByNixpkgsCompiler prevStage.binutils-unwrapped; - assert isBuiltByNixpkgsCompiler prevStage.${localSystem.libc}; + assert isBuiltByNixpkgsCompiler prevStage.binutils-unwrapped; + assert isBuiltByNixpkgsCompiler prevStage.${localSystem.libc}; assert isBuiltByBootstrapFilesCompiler prevStage.gcc-unwrapped; - assert isFromBootstrapFiles prevStage.coreutils; - assert isFromBootstrapFiles prevStage.gnugrep; - assert isBuiltByNixpkgsCompiler prevStage.patchelf; - assert lib.all isBuiltByNixpkgsCompiler [ prevStage.gmp prevStage.isl_0_20 prevStage.libmpc prevStage.mpfr ]; - stageFun prevStage { - name = "bootstrap-stage3"; - - overrides = self: super: rec { - inherit (prevStage) - ccWrapperStdenv - binutils coreutils gnugrep gettext - perl patchelf linuxHeaders gnum4 bison libidn2 libunistring libxcrypt; - # We build a special copy of libgmp which doesn't use libstdc++, because - # xgcc++'s libstdc++ references the bootstrap-files (which is what - # compiles xgcc++). - gmp = super.gmp.override { cxx = false; }; - } // { - ${localSystem.libc} = getLibc prevStage; - gcc-unwrapped = (super.gcc-unwrapped.override (commonGccOverrides // { - inherit (prevStage) which; - } - )).overrideAttrs (a: { - # so we can add them to allowedRequisites below - passthru = a.passthru // { inherit (self) gmp mpfr libmpc isl; }; - }); - }; - extraNativeBuildInputs = [ - prevStage.patchelf - # Many tarballs come with obsolete config.sub/config.guess that don't recognize aarch64. - prevStage.updateAutotoolsGnuConfigScriptsHook + assert isFromBootstrapFiles prevStage.coreutils; + assert isFromBootstrapFiles prevStage.gnugrep; + assert isBuiltByNixpkgsCompiler prevStage.patchelf; + assert lib.all isBuiltByNixpkgsCompiler [ + prevStage.gmp + prevStage.isl_0_20 + prevStage.libmpc + prevStage.mpfr ]; - }) - + stageFun prevStage { + name = "bootstrap-stage3"; + + overrides = + self: super: + rec { + inherit (prevStage) + ccWrapperStdenv + binutils + coreutils + gnugrep + gettext + perl + patchelf + linuxHeaders + gnum4 + bison + libidn2 + libunistring + libxcrypt + ; + # We build a special copy of libgmp which doesn't use libstdc++, because + # xgcc++'s libstdc++ references the bootstrap-files (which is what + # compiles xgcc++). + gmp = super.gmp.override { cxx = false; }; + } + // { + ${localSystem.libc} = getLibc prevStage; + gcc-unwrapped = + (super.gcc-unwrapped.override ( + commonGccOverrides + // { + inherit (prevStage) which; + } + )).overrideAttrs + (a: { + # so we can add them to allowedRequisites below + passthru = a.passthru // { + inherit (self) + gmp + mpfr + libmpc + isl + ; + }; + }); + }; + extraNativeBuildInputs = [ + prevStage.patchelf + # Many tarballs come with obsolete config.sub/config.guess that don't recognize aarch64. + prevStage.updateAutotoolsGnuConfigScriptsHook + ]; + } + ) # Construct a fourth stdenv that uses the new GCC. But coreutils is # still from the bootstrap tools. # - (prevStage: + ( + prevStage: # previous stage3 stdenv: assert isBuiltByNixpkgsCompiler prevStage.binutils-unwrapped; assert isBuiltByNixpkgsCompiler prevStage.${localSystem.libc}; assert isBuiltByNixpkgsCompiler prevStage.gcc-unwrapped; - assert isFromBootstrapFiles prevStage.coreutils; - assert isFromBootstrapFiles prevStage.gnugrep; + assert isFromBootstrapFiles prevStage.coreutils; + assert isFromBootstrapFiles prevStage.gnugrep; assert isBuiltByNixpkgsCompiler prevStage.patchelf; stageFun prevStage { - name = "bootstrap-stage4"; - - overrides = self: super: { - # Zlib has to be inherited and not rebuilt in this stage, - # because gcc (since JAR support) already depends on zlib, and - # then if we already have a zlib we want to use that for the - # other purposes (binutils and top-level pkgs) too. - inherit (prevStage) gettext gnum4 bison perl texinfo zlib linuxHeaders libidn2 libunistring; - ${localSystem.libc} = getLibc prevStage; - # Since this is the first fresh build of binutils since stage2, our own runtimeShell will be used. - binutils = super.binutils.override { - # Build expand-response-params with last stage like below - inherit (prevStage) expand-response-params; - }; + name = "bootstrap-stage4"; + + overrides = self: super: { + # Zlib has to be inherited and not rebuilt in this stage, + # because gcc (since JAR support) already depends on zlib, and + # then if we already have a zlib we want to use that for the + # other purposes (binutils and top-level pkgs) too. + inherit (prevStage) + gettext + gnum4 + bison + perl + texinfo + zlib + linuxHeaders + libidn2 + libunistring + ; + ${localSystem.libc} = getLibc prevStage; + # Since this is the first fresh build of binutils since stage2, our own runtimeShell will be used. + binutils = super.binutils.override { + # Build expand-response-params with last stage like below + inherit (prevStage) expand-response-params; + }; + + # To allow users' overrides inhibit dependencies too heavy for + # bootstrap, like guile: https://github.com/NixOS/nixpkgs/issues/181188 + gnumake = super.gnumake.override { inBootstrap = true; }; - # To allow users' overrides inhibit dependencies too heavy for - # bootstrap, like guile: https://github.com/NixOS/nixpkgs/issues/181188 - gnumake = super.gnumake.override { inBootstrap = true; }; - - gcc = lib.makeOverridable (import ../../build-support/cc-wrapper) { - nativeTools = false; - nativeLibc = false; - isGNU = true; - inherit (prevStage) expand-response-params; - cc = prevStage.gcc-unwrapped; - bintools = self.binutils; - libc = getLibc self; - inherit lib; - inherit (self) stdenvNoCC coreutils gnugrep runtimeShell; - fortify-headers = self.fortify-headers; + gcc = lib.makeOverridable (import ../../build-support/cc-wrapper) { + nativeTools = false; + nativeLibc = false; + isGNU = true; + inherit (prevStage) expand-response-params; + cc = prevStage.gcc-unwrapped; + bintools = self.binutils; + libc = getLibc self; + inherit lib; + inherit (self) + stdenvNoCC + coreutils + gnugrep + runtimeShell + ; + fortify-headers = self.fortify-headers; + }; }; - }; - extraNativeBuildInputs = [ - prevStage.patchelf prevStage.xz - # Many tarballs come with obsolete config.sub/config.guess that don't recognize aarch64. - prevStage.updateAutotoolsGnuConfigScriptsHook - ]; - }) + extraNativeBuildInputs = [ + prevStage.patchelf + prevStage.xz + # Many tarballs come with obsolete config.sub/config.guess that don't recognize aarch64. + prevStage.updateAutotoolsGnuConfigScriptsHook + ]; + } + ) # Construct the final stdenv. It uses the Glibc and GCC, and adds # in a new binutils that doesn't depend on bootstrap-tools, as well @@ -590,7 +717,8 @@ in # dependency (`nix-store -qR') on bootstrapTools or the first # binutils built. # - (prevStage: + ( + prevStage: # previous stage4 stdenv; see stage3 comment regarding gcc, # which applies here as well. assert isBuiltByNixpkgsCompiler prevStage.binutils-unwrapped; @@ -600,93 +728,186 @@ in assert isBuiltByNixpkgsCompiler prevStage.gnugrep; assert isBuiltByNixpkgsCompiler prevStage.patchelf; { - inherit config overlays; - stdenv = import ../generic rec { - name = "stdenv-linux"; + inherit config overlays; + stdenv = import ../generic rec { + name = "stdenv-linux"; - buildPlatform = localSystem; - hostPlatform = localSystem; - targetPlatform = localSystem; - inherit config; + buildPlatform = localSystem; + hostPlatform = localSystem; + targetPlatform = localSystem; + inherit config; - preHook = commonPreHook; + preHook = commonPreHook; - initialPath = - ((import ../generic/common-path.nix) {pkgs = prevStage;}); + initialPath = ((import ../generic/common-path.nix) { pkgs = prevStage; }); - extraNativeBuildInputs = [ - prevStage.patchelf - # Many tarballs come with obsolete config.sub/config.guess that don't recognize aarch64. - prevStage.updateAutotoolsGnuConfigScriptsHook - ]; + extraNativeBuildInputs = [ + prevStage.patchelf + # Many tarballs come with obsolete config.sub/config.guess that don't recognize aarch64. + prevStage.updateAutotoolsGnuConfigScriptsHook + ]; - cc = prevStage.gcc; + cc = prevStage.gcc; - shell = cc.shell; + shell = cc.shell; - inherit (prevStage.stdenv) fetchurlBoot; + inherit (prevStage.stdenv) fetchurlBoot; - extraAttrs = { - inherit bootstrapTools; - shellPackage = prevStage.bash; - }; - - disallowedRequisites = [ bootstrapTools.out ]; + extraAttrs = { + inherit bootstrapTools; + shellPackage = prevStage.bash; + }; - # Mainly avoid reference to bootstrap tools - allowedRequisites = let - inherit (prevStage) gzip bzip2 xz zlib bash binutils coreutils diffutils findutils - gawk gmp gnumake gnused gnutar gnugrep gnupatch patchelf ed file glibc - attr acl libidn2 libunistring linuxHeaders gcc fortify-headers gcc-unwrapped - ; - in - # Simple executable tools - lib.concatMap (p: [ (lib.getBin p) (lib.getLib p) ]) [ - gzip bzip2 xz bash binutils.bintools coreutils diffutils findutils - gawk gmp gnumake gnused gnutar gnugrep gnupatch patchelf ed file + disallowedRequisites = [ bootstrapTools.out ]; + + # Mainly avoid reference to bootstrap tools + allowedRequisites = + let + inherit (prevStage) + gzip + bzip2 + xz + zlib + bash + binutils + coreutils + diffutils + findutils + gawk + gmp + gnumake + gnused + gnutar + gnugrep + gnupatch + patchelf + ed + file + glibc + attr + acl + libidn2 + libunistring + linuxHeaders + gcc + fortify-headers + gcc-unwrapped + ; + in + # Simple executable tools + lib.concatMap + (p: [ + (lib.getBin p) + (lib.getLib p) + ]) + [ + gzip + bzip2 + xz + bash + binutils.bintools + coreutils + diffutils + findutils + gawk + gmp + gnumake + gnused + gnutar + gnugrep + gnupatch + patchelf + ed + file + ] + # Library dependencies + ++ map lib.getLib [ + attr + acl + zlib + gnugrep.pcre2 + libidn2 + libunistring ] - # Library dependencies - ++ map lib.getLib [ attr acl zlib gnugrep.pcre2 libidn2 libunistring ] - # More complicated cases - ++ (map (x: lib.getOutput x (getLibc prevStage)) [ "out" "dev" "bin" ] ) - ++ [ linuxHeaders # propagated from .dev - binutils gcc gcc.cc gcc.cc.lib - gcc.expand-response-params # != (prevStage.)expand-response-params - gcc.cc.libgcc glibc.passthru.libgcc + # More complicated cases + ++ (map (x: lib.getOutput x (getLibc prevStage)) [ + "out" + "dev" + "bin" + ]) + ++ [ + linuxHeaders # propagated from .dev + binutils + gcc + gcc.cc + gcc.cc.lib + gcc.expand-response-params # != (prevStage.)expand-response-params + gcc.cc.libgcc + glibc.passthru.libgcc ] - ++ lib.optionals (localSystem.libc == "musl") [ fortify-headers ] - ++ [ prevStage.updateAutotoolsGnuConfigScriptsHook prevStage.gnu-config ] - ++ [ - gcc-unwrapped.gmp gcc-unwrapped.libmpc gcc-unwrapped.mpfr gcc-unwrapped.isl - ] - ; - - overrides = self: super: { - inherit (prevStage) - gzip bzip2 xz bash coreutils diffutils findutils gawk - gnused gnutar gnugrep gnupatch patchelf - attr acl zlib libunistring; - inherit (prevStage.gnugrep) pcre2; - ${localSystem.libc} = getLibc prevStage; - - # Hack: avoid libidn2.{bin,dev} referencing bootstrap tools. There's a logical cycle. - libidn2 = import ../../development/libraries/libidn2/no-bootstrap-reference.nix { - inherit lib; - inherit (prevStage) libidn2; - inherit (self) stdenv runCommandLocal patchelf libunistring; - }; - - gnumake = super.gnumake.override { inBootstrap = false; }; - } // lib.optionalAttrs (super.stdenv.targetPlatform == localSystem) { - # Need to get rid of these when cross-compiling. - inherit (prevStage) binutils binutils-unwrapped; - gcc = cc; + ++ lib.optionals (localSystem.libc == "musl") [ fortify-headers ] + ++ [ + prevStage.updateAutotoolsGnuConfigScriptsHook + prevStage.gnu-config + ] + ++ [ + gcc-unwrapped.gmp + gcc-unwrapped.libmpc + gcc-unwrapped.mpfr + gcc-unwrapped.isl + ]; + + overrides = + self: super: + { + inherit (prevStage) + gzip + bzip2 + xz + bash + coreutils + diffutils + findutils + gawk + gnused + gnutar + gnugrep + gnupatch + patchelf + attr + acl + zlib + libunistring + ; + inherit (prevStage.gnugrep) pcre2; + ${localSystem.libc} = getLibc prevStage; + + # Hack: avoid libidn2.{bin,dev} referencing bootstrap tools. There's a logical cycle. + libidn2 = import ../../development/libraries/libidn2/no-bootstrap-reference.nix { + inherit lib; + inherit (prevStage) libidn2; + inherit (self) + stdenv + runCommandLocal + patchelf + libunistring + ; + }; + + gnumake = super.gnumake.override { inBootstrap = false; }; + } + // lib.optionalAttrs (super.stdenv.targetPlatform == localSystem) { + # Need to get rid of these when cross-compiling. + inherit (prevStage) binutils binutils-unwrapped; + gcc = cc; + }; }; - }; - }) + } + ) # This "no-op" stage is just a place to put the assertions about stage5. - (prevStage: + ( + prevStage: # previous stage5 stdenv; see stage3 comment regarding gcc, # which applies here as well. assert isBuiltByNixpkgsCompiler prevStage.binutils-unwrapped; @@ -695,5 +916,8 @@ in assert isBuiltByNixpkgsCompiler prevStage.coreutils; assert isBuiltByNixpkgsCompiler prevStage.gnugrep; assert isBuiltByNixpkgsCompiler prevStage.patchelf; - { inherit (prevStage) config overlays stdenv; }) + { + inherit (prevStage) config overlays stdenv; + } + ) ] diff --git a/pkgs/stdenv/linux/make-bootstrap-tools-cross.nix b/pkgs/stdenv/linux/make-bootstrap-tools-cross.nix index 8984cdf23c6ce7..694d90d970e302 100644 --- a/pkgs/stdenv/linux/make-bootstrap-tools-cross.nix +++ b/pkgs/stdenv/linux/make-bootstrap-tools-cross.nix @@ -1,37 +1,45 @@ -{system ? builtins.currentSystem}: +{ + system ? builtins.currentSystem, +}: let inherit (releaseLib) lib; releaseLib = import ../../top-level/release-lib.nix { # We're not using any functions from release-lib.nix that look at # supportedSystems. - supportedSystems = []; + supportedSystems = [ ]; }; - make = crossSystem: import ./make-bootstrap-tools.nix { - pkgs = releaseLib.pkgsForCross crossSystem system; - }; -in lib.mapAttrs (n: make) (with lib.systems.examples; { - # NOTE: Only add platforms for which there are files in `./bootstrap-files` - # or for which you plan to request the tarball upload soon. See the - # maintainers/scripts/bootstrap-files/README.md - # on how to request an upload. - # Sort following the sorting in `./default.nix` `bootstrapFiles` argument. + make = + crossSystem: + import ./make-bootstrap-tools.nix { + pkgs = releaseLib.pkgsForCross crossSystem system; + }; +in +lib.mapAttrs (n: make) ( + with lib.systems.examples; + { + # NOTE: Only add platforms for which there are files in `./bootstrap-files` + # or for which you plan to request the tarball upload soon. See the + # maintainers/scripts/bootstrap-files/README.md + # on how to request an upload. + # Sort following the sorting in `./default.nix` `bootstrapFiles` argument. - armv5tel-unknown-linux-gnueabi = sheevaplug; - armv6l-unknown-linux-gnueabihf = raspberryPi; - armv7l-unknown-linux-gnueabihf = armv7l-hf-multiplatform; - aarch64-unknown-linux-gnu = aarch64-multiplatform; - mipsel-unknown-linux-gnu = mipsel-linux-gnu; - mips64el-unknown-linux-gnuabin32 = mips64el-linux-gnuabin32; - mips64el-unknown-linux-gnuabi64 = mips64el-linux-gnuabi64; - powerpc64-unknown-linux-gnuabielfv2 = ppc64; - powerpc64le-unknown-linux-gnu = powernv; - riscv64-unknown-linux-gnu = riscv64; - s390x-unknown-linux-gnu = s390x; + armv5tel-unknown-linux-gnueabi = sheevaplug; + armv6l-unknown-linux-gnueabihf = raspberryPi; + armv7l-unknown-linux-gnueabihf = armv7l-hf-multiplatform; + aarch64-unknown-linux-gnu = aarch64-multiplatform; + mipsel-unknown-linux-gnu = mipsel-linux-gnu; + mips64el-unknown-linux-gnuabin32 = mips64el-linux-gnuabin32; + mips64el-unknown-linux-gnuabi64 = mips64el-linux-gnuabi64; + powerpc64-unknown-linux-gnuabielfv2 = ppc64; + powerpc64le-unknown-linux-gnu = powernv; + riscv64-unknown-linux-gnu = riscv64; + s390x-unknown-linux-gnu = s390x; - # musl - aarch64-unknown-linux-musl = aarch64-multiplatform-musl; - armv6l-unknown-linux-musleabihf = muslpi; - x86_64-unknown-linux-musl = musl64; -}) + # musl + aarch64-unknown-linux-musl = aarch64-multiplatform-musl; + armv6l-unknown-linux-musleabihf = muslpi; + x86_64-unknown-linux-musl = musl64; + } +) diff --git a/pkgs/stdenv/native/default.nix b/pkgs/stdenv/native/default.nix index 242bf9d1b3f900..66ac2aa7d129b9 100644 --- a/pkgs/stdenv/native/default.nix +++ b/pkgs/stdenv/native/default.nix @@ -1,5 +1,10 @@ -{ lib -, localSystem, crossSystem, config, overlays, crossOverlays ? [] +{ + lib, + localSystem, + crossSystem, + config, + overlays, + crossOverlays ? [ ], }: assert crossSystem == localSystem; @@ -8,14 +13,20 @@ let inherit (localSystem) system; shell = - if system == "i686-freebsd" || system == "x86_64-freebsd" then "/usr/local/bin/bash" - else "/bin/bash"; + if system == "i686-freebsd" || system == "x86_64-freebsd" then + "/usr/local/bin/bash" + else + "/bin/bash"; path = - (lib.optionals (system == "i686-solaris") [ "/usr/gnu" ]) ++ - (lib.optionals (system == "i686-netbsd") [ "/usr/pkg" ]) ++ - (lib.optionals (system == "x86_64-solaris") [ "/opt/local/gnu" ]) ++ - ["/" "/usr" "/usr/local"]; + (lib.optionals (system == "i686-solaris") [ "/usr/gnu" ]) + ++ (lib.optionals (system == "i686-netbsd") [ "/usr/pkg" ]) + ++ (lib.optionals (system == "x86_64-solaris") [ "/opt/local/gnu" ]) + ++ [ + "/" + "/usr" + "/usr/local" + ]; prehookBase = '' # Disable purity tests; it's allowed (even needed) to link to @@ -66,19 +77,34 @@ let export lt_cv_deplibs_check_method=pass_all ''; - extraNativeBuildInputsCygwin = [ - ../cygwin/all-buildinputs-as-runtimedep.sh - ../cygwin/wrap-exes-to-find-dlls.sh - ] ++ (if system == "i686-cygwin" then [ - ../cygwin/rebase-i686.sh - ] else if system == "x86_64-cygwin" then [ - ../cygwin/rebase-x86_64.sh - ] else []); + extraNativeBuildInputsCygwin = + [ + ../cygwin/all-buildinputs-as-runtimedep.sh + ../cygwin/wrap-exes-to-find-dlls.sh + ] + ++ ( + if system == "i686-cygwin" then + [ + ../cygwin/rebase-i686.sh + ] + else if system == "x86_64-cygwin" then + [ + ../cygwin/rebase-x86_64.sh + ] + else + [ ] + ); # A function that builds a "native" stdenv (one that uses tools in # /usr etc.). makeStdenv = - { cc, fetchurl, extraPath ? [], overrides ? (self: super: { }), extraNativeBuildInputs ? [] }: + { + cc, + fetchurl, + extraPath ? [ ], + overrides ? (self: super: { }), + extraNativeBuildInputs ? [ ], + }: import ../generic { buildPlatform = localSystem; @@ -86,76 +112,103 @@ let targetPlatform = localSystem; preHook = - if system == "i686-freebsd" then prehookFreeBSD else - if system == "x86_64-freebsd" then prehookFreeBSD else - if system == "i686-openbsd" then prehookOpenBSD else - if system == "i686-netbsd" then prehookNetBSD else - if system == "i686-cygwin" then prehookCygwin else - if system == "x86_64-cygwin" then prehookCygwin else - prehookBase; - - extraNativeBuildInputs = extraNativeBuildInputs ++ - (if system == "i686-cygwin" then extraNativeBuildInputsCygwin else - if system == "x86_64-cygwin" then extraNativeBuildInputsCygwin else - []); + if system == "i686-freebsd" then + prehookFreeBSD + else if system == "x86_64-freebsd" then + prehookFreeBSD + else if system == "i686-openbsd" then + prehookOpenBSD + else if system == "i686-netbsd" then + prehookNetBSD + else if system == "i686-cygwin" then + prehookCygwin + else if system == "x86_64-cygwin" then + prehookCygwin + else + prehookBase; + + extraNativeBuildInputs = + extraNativeBuildInputs + ++ ( + if system == "i686-cygwin" then + extraNativeBuildInputsCygwin + else if system == "x86_64-cygwin" then + extraNativeBuildInputsCygwin + else + [ ] + ); initialPath = extraPath ++ path; fetchurlBoot = fetchurl; - inherit shell cc overrides config; + inherit + shell + cc + overrides + config + ; }; in [ - ({}: rec { - __raw = true; + ( + { }: + rec { + __raw = true; - stdenv = makeStdenv { - cc = null; - fetchurl = null; - }; - stdenvNoCC = stdenv; - - cc = let - nativePrefix = { # switch - i686-solaris = "/usr/gnu"; - x86_64-solaris = "/opt/local/gcc47"; - }.${system} or "/usr"; - in - import ../../build-support/cc-wrapper { - name = "cc-native"; - nativeTools = true; - nativeLibc = true; - inherit lib nativePrefix; - bintools = import ../../build-support/bintools-wrapper { - name = "bintools"; - inherit lib stdenvNoCC nativePrefix; - nativeTools = true; - nativeLibc = true; + stdenv = makeStdenv { + cc = null; + fetchurl = null; + }; + stdenvNoCC = stdenv; + + cc = + let + nativePrefix = + { + # switch + i686-solaris = "/usr/gnu"; + x86_64-solaris = "/opt/local/gcc47"; + } + .${system} or "/usr"; + in + import ../../build-support/cc-wrapper { + name = "cc-native"; + nativeTools = true; + nativeLibc = true; + inherit lib nativePrefix; + bintools = import ../../build-support/bintools-wrapper { + name = "bintools"; + inherit lib stdenvNoCC nativePrefix; + nativeTools = true; + nativeLibc = true; + }; + inherit stdenvNoCC; + }; + + fetchurl = import ../../build-support/fetchurl { + inherit lib stdenvNoCC; + # Curl should be in /usr/bin or so. + curl = null; }; - inherit stdenvNoCC; - }; - - fetchurl = import ../../build-support/fetchurl { - inherit lib stdenvNoCC; - # Curl should be in /usr/bin or so. - curl = null; - }; - }) + } + ) # First build a stdenv based only on tools outside the store. (prevStage: { inherit config overlays; - stdenv = makeStdenv { - inherit (prevStage) cc fetchurl; - overrides = self: super: { inherit (prevStage) fetchurl; }; - } // { - inherit (prevStage) fetchurl; - }; + stdenv = + makeStdenv { + inherit (prevStage) cc fetchurl; + overrides = self: super: { inherit (prevStage) fetchurl; }; + } + // { + inherit (prevStage) fetchurl; + }; }) # Using that, build a stdenv that adds the ‘xz’ command (which most systems @@ -166,7 +219,7 @@ in inherit (prevStage.stdenv) cc fetchurl; extraPath = [ prevStage.xz ]; overrides = self: super: { inherit (prevStage) fetchurl xz; }; - extraNativeBuildInputs = if localSystem.isLinux then [ prevStage.patchelf ] else []; + extraNativeBuildInputs = if localSystem.isLinux then [ prevStage.patchelf ] else [ ]; }; }) diff --git a/pkgs/stdenv/nix/default.nix b/pkgs/stdenv/nix/default.nix index e9e9936ccd801c..59e67960aef1fc 100644 --- a/pkgs/stdenv/nix/default.nix +++ b/pkgs/stdenv/nix/default.nix @@ -1,12 +1,17 @@ -{ lib -, crossSystem, localSystem, config, overlays -, bootStages -, ... +{ + lib, + crossSystem, + localSystem, + config, + overlays, + bootStages, + ... }: assert crossSystem == localSystem; -bootStages ++ [ +bootStages +++ [ (prevStage: { inherit config overlays; @@ -28,7 +33,12 @@ bootStages ++ [ nativeTools = false; nativePrefix = lib.optionalString hostPlatform.isSunOS "/usr"; nativeLibc = true; - inherit (prevStage) stdenvNoCC binutils coreutils gnugrep; + inherit (prevStage) + stdenvNoCC + binutils + coreutils + gnugrep + ; cc = prevStage.gcc.cc; isGNU = true; shell = prevStage.bash + "/bin/sh"; @@ -42,8 +52,21 @@ bootStages ++ [ inherit cc; inherit (cc) binutils; inherit (prevStage) - gzip bzip2 xz bash coreutils diffutils findutils gawk - gnumake gnused gnutar gnugrep gnupatch perl; + gzip + bzip2 + xz + bash + coreutils + diffutils + findutils + gawk + gnumake + gnused + gnutar + gnugrep + gnupatch + perl + ; }; }; }) diff --git a/pkgs/test/auto-patchelf-hook/package.nix b/pkgs/test/auto-patchelf-hook/package.nix index 37413c7301eef8..c67aa2ca375bf1 100644 --- a/pkgs/test/auto-patchelf-hook/package.nix +++ b/pkgs/test/auto-patchelf-hook/package.nix @@ -2,27 +2,30 @@ # which uses the hook. We took the derivation from tonelib-jam, which sounds # like a good candidate with a small closure, and trimmed it down. -{ stdenv -, lib -, fetchurl -, autoPatchelfHook -, dpkg -, freetype -, curl -# This test checks that the behavior of autoPatchelfHook is correct whether -# __structuredAttrs -# (https://nixos.org/manual/nix/stable/language/advanced-attributes#adv-attr-structuredAttrs) -# is set or not. Hence __structuredAttrs is provided as a parameter. -, __structuredAttrs +{ + stdenv, + lib, + fetchurl, + autoPatchelfHook, + dpkg, + freetype, + curl, + # This test checks that the behavior of autoPatchelfHook is correct whether + # __structuredAttrs + # (https://nixos.org/manual/nix/stable/language/advanced-attributes#adv-attr-structuredAttrs) + # is set or not. Hence __structuredAttrs is provided as a parameter. + __structuredAttrs, }: -let runtimeDependencies = [ - (lib.getLib curl) - "/some/dep" - "/some/other/dep" -] -# A dependency with space only works with __structuredAttrs set to true. -++ lib.lists.optional __structuredAttrs "/some/dep with space"; +let + runtimeDependencies = + [ + (lib.getLib curl) + "/some/dep" + "/some/other/dep" + ] + # A dependency with space only works with __structuredAttrs set to true. + ++ lib.lists.optional __structuredAttrs "/some/dep with space"; in stdenv.mkDerivation { @@ -59,7 +62,8 @@ stdenv.mkDerivation { # Additional phase performing the actual test. installCheckPhase = - let allDeps = runtimeDependencies ++ [ + let + allDeps = runtimeDependencies ++ [ (lib.getLib freetype) ]; in @@ -82,16 +86,18 @@ stdenv.mkDerivation { echo "[auto-patchelf-hook-test]: Check that the runpath contains the expected runtime deps" '' - + lib.strings.concatStringsSep "\n" - (lib.lists.imap0 - (i: path: - let iAsStr = builtins.toString i; in - '' - echo "[auto-patchelf-hook-test]: Check that entry ${iAsStr} is ${path}" - test "''${paths[${iAsStr}]}" = "$path" - '') - allDeps - ); + + lib.strings.concatStringsSep "\n" ( + lib.lists.imap0 ( + i: path: + let + iAsStr = builtins.toString i; + in + '' + echo "[auto-patchelf-hook-test]: Check that entry ${iAsStr} is ${path}" + test "''${paths[${iAsStr}]}" = "$path" + '' + ) allDeps + ); doInstallCheck = true; inherit __structuredAttrs; diff --git a/pkgs/test/buildFHSEnv/default.nix b/pkgs/test/buildFHSEnv/default.nix index 5ded03ea1f99ab..ac0494fefb2606 100644 --- a/pkgs/test/buildFHSEnv/default.nix +++ b/pkgs/test/buildFHSEnv/default.nix @@ -1,79 +1,92 @@ -{ lib -, buildFHSEnv -, runCommand -, stdenv -, fetchurl -, dpkg -, glibc -, callPackage +{ + lib, + buildFHSEnv, + runCommand, + stdenv, + fetchurl, + dpkg, + glibc, + callPackage, }: let - getSharedObjectFromDebian = sharedObjectName: src: stdenv.mkDerivation { - name = "${sharedObjectName}-fetcher"; - inherit src; - nativeBuildInputs = [ - dpkg - ]; - dontBuild = true; - dontConfigure = true; - dontFixup = true; - installPhase = '' - echo shared objects found are: - ls -l usr/lib/*/ - cp usr/lib/*/${sharedObjectName} $out - ''; - }; - - makeSharedObjectTest = sharedObject: targetPkgs: let - lddFHSEnv = buildFHSEnv { - name = "ldd-with-ncurses-FHS-env"; - inherit targetPkgs; - runScript = "ldd"; - }; - ldd-in-FHS = "${lddFHSEnv}/bin/${lddFHSEnv.name}"; - ldd = "${lib.getBin glibc}/bin/ldd"; - find_libFHSEnv = buildFHSEnv { - name = "ls-with-ncurses-FHS-env"; - targetPkgs = p: [ - p.ncurses5 + getSharedObjectFromDebian = + sharedObjectName: src: + stdenv.mkDerivation { + name = "${sharedObjectName}-fetcher"; + inherit src; + nativeBuildInputs = [ + dpkg ]; - runScript = "find /lib/ -executable"; + dontBuild = true; + dontConfigure = true; + dontFixup = true; + installPhase = '' + echo shared objects found are: + ls -l usr/lib/*/ + cp usr/lib/*/${sharedObjectName} $out + ''; }; - find_lib-in-FHS = "${find_libFHSEnv}/bin/${find_libFHSEnv.name}"; - in runCommand "FHS-lib-test" {} '' - echo original ldd output is: - ${ldd} ${sharedObject} - lddOutput="$(${ldd-in-FHS} ${sharedObject})" - echo ldd output inside FHS is: - echo "$lddOutput" - if echo $lddOutput | grep -q "not found"; then - echo "shared object could not find all dependencies in the FHS!" - echo The libraries below where found in the FHS: - ${find_lib-in-FHS} - exit 1 - else - echo $lddOutput > $out - fi - ''; -in { + makeSharedObjectTest = + sharedObject: targetPkgs: + let + lddFHSEnv = buildFHSEnv { + name = "ldd-with-ncurses-FHS-env"; + inherit targetPkgs; + runScript = "ldd"; + }; + ldd-in-FHS = "${lddFHSEnv}/bin/${lddFHSEnv.name}"; + ldd = "${lib.getBin glibc}/bin/ldd"; + find_libFHSEnv = buildFHSEnv { + name = "ls-with-ncurses-FHS-env"; + targetPkgs = p: [ + p.ncurses5 + ]; + runScript = "find /lib/ -executable"; + }; + find_lib-in-FHS = "${find_libFHSEnv}/bin/${find_libFHSEnv.name}"; + in + runCommand "FHS-lib-test" { } '' + echo original ldd output is: + ${ldd} ${sharedObject} + lddOutput="$(${ldd-in-FHS} ${sharedObject})" + echo ldd output inside FHS is: + echo "$lddOutput" + if echo $lddOutput | grep -q "not found"; then + echo "shared object could not find all dependencies in the FHS!" + echo The libraries below where found in the FHS: + ${find_lib-in-FHS} + exit 1 + else + echo $lddOutput > $out + fi + ''; + +in +{ # This test proves an issue with buildFHSEnv - don't expect it to succeed, # this is discussed in https://github.com/NixOS/nixpkgs/pull/279844 . - libtinfo = makeSharedObjectTest (getSharedObjectFromDebian "libedit.so.2.0.70" (fetchurl { - url = "mirror://debian/pool/main/libe/libedit/libedit2_3.1-20221030-2_amd64.deb"; - hash = "sha256-HPFKvycW0yedsS0GV6VzfPcAdKHnHTvfcyBmJePInOY="; - })) (p: [ - p.libtinfo - p.libbsd - ]); + libtinfo = + makeSharedObjectTest + (getSharedObjectFromDebian "libedit.so.2.0.70" (fetchurl { + url = "mirror://debian/pool/main/libe/libedit/libedit2_3.1-20221030-2_amd64.deb"; + hash = "sha256-HPFKvycW0yedsS0GV6VzfPcAdKHnHTvfcyBmJePInOY="; + })) + (p: [ + p.libtinfo + p.libbsd + ]); - liblzma = makeSharedObjectTest (getSharedObjectFromDebian "libxml2.so.2.9.14" (fetchurl { - url = "mirror://debian/pool/main/libx/libxml2/libxml2_2.9.14+dfsg-1.3~deb12u1_amd64.deb"; - hash = "sha256-NbdstwOPwclAIEpPBfM/+3nQJzU85Gk5fZrc+Pmz4ac="; - })) (p: [ - p.xz - p.zlib - p.icu72 - ]); + liblzma = + makeSharedObjectTest + (getSharedObjectFromDebian "libxml2.so.2.9.14" (fetchurl { + url = "mirror://debian/pool/main/libx/libxml2/libxml2_2.9.14+dfsg-1.3~deb12u1_amd64.deb"; + hash = "sha256-NbdstwOPwclAIEpPBfM/+3nQJzU85Gk5fZrc+Pmz4ac="; + })) + (p: [ + p.xz + p.zlib + p.icu72 + ]); } diff --git a/pkgs/test/cc-wrapper/default.nix b/pkgs/test/cc-wrapper/default.nix index 9f477ccdc3b327..11a0d390235596 100644 --- a/pkgs/test/cc-wrapper/default.nix +++ b/pkgs/test/cc-wrapper/default.nix @@ -1,20 +1,32 @@ -{ lib, stdenv, glibc, buildPackages }: +{ + lib, + stdenv, + glibc, + buildPackages, +}: let # Sanitizers are not supported on Darwin. # Sanitizer headers aren't available in older libc++ stdenvs due to a bug - sanitizersWorking = (stdenv.buildPlatform == stdenv.hostPlatform) && !stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isMusl && ( - (stdenv.cc.isClang && lib.versionAtLeast (lib.getVersion stdenv.cc.name) "5.0.0") - || (stdenv.cc.isGNU && stdenv.hostPlatform.isLinux) - ); + sanitizersWorking = + (stdenv.buildPlatform == stdenv.hostPlatform) + && !stdenv.hostPlatform.isDarwin + && !stdenv.hostPlatform.isMusl + && ( + (stdenv.cc.isClang && lib.versionAtLeast (lib.getVersion stdenv.cc.name) "5.0.0") + || (stdenv.cc.isGNU && stdenv.hostPlatform.isLinux) + ); staticLibc = lib.optionalString (stdenv.hostPlatform.libc == "glibc") "-L ${glibc.static}/lib"; - emulator = lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) (stdenv.hostPlatform.emulator buildPackages); + emulator = lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) ( + stdenv.hostPlatform.emulator buildPackages + ); isCxx = stdenv.cc.libcxx != null; libcxxStdenvSuffix = lib.optionalString isCxx "-libcxx"; CC = "PATH= ${lib.getExe' stdenv.cc "${stdenv.cc.targetPrefix}cc"}"; CXX = "PATH= ${lib.getExe' stdenv.cc "${stdenv.cc.targetPrefix}c++"}"; READELF = "PATH= ${lib.getExe' stdenv.cc "${stdenv.cc.targetPrefix}readelf"}"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "cc-wrapper-test-${stdenv.cc.cc.pname}${libcxxStdenvSuffix}"; version = stdenv.cc.version; @@ -45,7 +57,9 @@ in stdenv.mkDerivation { ${lib.optionalString (!isCxx) '' # https://github.com/NixOS/nixpkgs/issues/91285 echo "checking whether libatomic.so can be linked... " >&2 - ${CXX} -shared -o atomics.so ${./atomics.cc} -latomic ${lib.optionalString (stdenv.cc.isClang && lib.versionOlder stdenv.cc.version "6.0.0" ) "-std=c++17"} + ${CXX} -shared -o atomics.so ${./atomics.cc} -latomic ${ + lib.optionalString (stdenv.cc.isClang && lib.versionOlder stdenv.cc.version "6.0.0") "-std=c++17" + } ${READELF} -d ./atomics.so | grep libatomic.so && echo "ok" >&2 || echo "failed" >&2 ''} @@ -72,14 +86,17 @@ in stdenv.mkDerivation { echo "checking whether compiler builds valid static C binaries... " >&2 ${CC} ${staticLibc} -static -o cc-static ${./cc-main.c} ${emulator} ./cc-static - ${lib.optionalString (stdenv.cc.isGNU && lib.versionAtLeast (lib.getVersion stdenv.cc.name) "8.0.0") '' - echo "checking whether compiler builds valid static pie C binaries... " >&2 - ${CC} ${staticLibc} -static-pie -o cc-static-pie ${./cc-main.c} - ${emulator} ./cc-static-pie - ''} + ${lib.optionalString (stdenv.cc.isGNU && lib.versionAtLeast (lib.getVersion stdenv.cc.name) "8.0.0") + '' + echo "checking whether compiler builds valid static pie C binaries... " >&2 + ${CC} ${staticLibc} -static-pie -o cc-static-pie ${./cc-main.c} + ${emulator} ./cc-static-pie + '' + } ''} - ${# See: https://github.com/llvm/llvm-project/commit/ed1d07282cc9d8e4c25d585e03e5c8a1b6f63a74 + ${ + # See: https://github.com/llvm/llvm-project/commit/ed1d07282cc9d8e4c25d585e03e5c8a1b6f63a74 # `gcc` does not support this so we gate the test on `clang` lib.optionalString stdenv.cc.isClang '' echo "checking whether cc-wrapper accepts -- followed by positional (file) args..." >&2 @@ -98,7 +115,8 @@ in stdenv.mkDerivation { ${CC} -c -DVALUE=42 -o positional/foo.o -- ${./foo.c} ${CC} -o positional/main -- positional/foo.o ${./ldflags-main.c} ${emulator} ./positional/main - ''} + '' + } echo "checking whether compiler uses NIX_CFLAGS_COMPILE... " >&2 mkdir -p foo/include diff --git a/pkgs/test/checkpointBuild/default.nix b/pkgs/test/checkpointBuild/default.nix index 0843dcd3d6eba4..69021aa15019ca 100644 --- a/pkgs/test/checkpointBuild/default.nix +++ b/pkgs/test/checkpointBuild/default.nix @@ -1,4 +1,11 @@ -{ hello, checkpointBuildTools, runCommand, texinfo, stdenv, rsync }: +{ + hello, + checkpointBuildTools, + runCommand, + texinfo, + stdenv, + rsync, +}: let baseHelloArtifacts = checkpointBuildTools.prepareCheckpointBuild hello; patchedHello = hello.overrideAttrs (old: { @@ -20,9 +27,11 @@ let ''; }); - baseHelloRemoveFileArtifacts = checkpointBuildTools.prepareCheckpointBuild (hello.overrideAttrs (old: { - patches = [ ./hello-additionalFile.patch ]; - })); + baseHelloRemoveFileArtifacts = checkpointBuildTools.prepareCheckpointBuild ( + hello.overrideAttrs (old: { + patches = [ ./hello-additionalFile.patch ]; + }) + ); preparedHelloRemoveFileSrc = runCommand "patch-hello-src" { } '' mkdir -p $out @@ -54,4 +63,3 @@ stdenv.mkDerivation { [ "$(${checkpointBuiltHelloWithRemovedFile}/bin/hello)" = "Hello, incremental world!" ] ''; } - diff --git a/pkgs/test/config.nix b/pkgs/test/config.nix index 24a840af0aeada..91cb312b4be0ef 100644 --- a/pkgs/test/config.nix +++ b/pkgs/test/config.nix @@ -10,12 +10,14 @@ lib.recurseIntoAttrs { # # Instead of `builtins.seq`, the list may be constructed based on actual package info. allowPkgsInPermittedInsecurePackages = - let pkgs = import ../.. { - config = { - permittedInsecurePackages = builtins.seq pkgs.glibc.version []; - }; + let + pkgs = import ../.. { + config = { + permittedInsecurePackages = builtins.seq pkgs.glibc.version [ ]; }; + }; - in pkgs.hello; + in + pkgs.hello; } diff --git a/pkgs/test/coq/default.nix b/pkgs/test/coq/default.nix index cf59dd473b4c77..e0fa0e26ace94c 100644 --- a/pkgs/test/coq/default.nix +++ b/pkgs/test/coq/default.nix @@ -3,4 +3,3 @@ lib.recurseIntoAttrs { overrideCoqDerivation = callPackage ./overrideCoqDerivation { }; } - diff --git a/pkgs/test/coq/overrideCoqDerivation/default.nix b/pkgs/test/coq/overrideCoqDerivation/default.nix index c251c498e6099d..03253981af6892 100644 --- a/pkgs/test/coq/overrideCoqDerivation/default.nix +++ b/pkgs/test/coq/overrideCoqDerivation/default.nix @@ -1,4 +1,9 @@ -{ lib, coq, mkCoqPackages, runCommand }: +{ + lib, + coq, + mkCoqPackages, + runCommand, +}: let @@ -6,7 +11,9 @@ let # dontFilter to true here so that _all_ packages are visibile in coqPackages. # There may be some versions of the top-level coq and coqPackages that don't # build QuickChick, which is what we are using for this test below. - coqWithAllPackages = coq // { dontFilter = true; }; + coqWithAllPackages = coq // { + dontFilter = true; + }; coqPackages = mkCoqPackages coqWithAllPackages; @@ -15,18 +22,14 @@ let # # Here, we override the defaultVersion and release arguments to # mkCoqDerivation. - overriddenQuickChick = - coqPackages.lib.overrideCoqDerivation - { - defaultVersion = "9999"; - release."9999".sha256 = lib.fakeSha256; - } - coqPackages.QuickChick; + overriddenQuickChick = coqPackages.lib.overrideCoqDerivation { + defaultVersion = "9999"; + release."9999".sha256 = lib.fakeSha256; + } coqPackages.QuickChick; in -runCommand - "coq-overrideCoqDerivation-test-0.1" - { meta.maintainers = with lib.maintainers; [cdepillabout]; } +runCommand "coq-overrideCoqDerivation-test-0.1" + { meta.maintainers = with lib.maintainers; [ cdepillabout ]; } '' # Confirm that the computed version number for the overridden QuickChick does # actually become 9999, as set above. diff --git a/pkgs/test/cross/default.nix b/pkgs/test/cross/default.nix index f07e9c6220de7b..f1696c915c3430 100644 --- a/pkgs/test/cross/default.nix +++ b/pkgs/test/cross/default.nix @@ -2,118 +2,165 @@ let - testedSystems = lib.filterAttrs (name: value: let - platform = lib.systems.elaborate value; - in platform.isLinux || platform.isWindows + testedSystems = lib.filterAttrs ( + name: value: + let + platform = lib.systems.elaborate value; + in + platform.isLinux || platform.isWindows ) lib.systems.examples; - getExecutable = pkgs: pkgFun: exec: + getExecutable = + pkgs: pkgFun: exec: "${pkgFun pkgs}${exec}${pkgs.stdenv.hostPlatform.extensions.executable}"; - compareTest = { emulator, pkgFun, hostPkgs, crossPkgs, exec, args ? [] }: let - pkgName = (pkgFun hostPkgs).name; - args' = lib.concatStringsSep " " args; - in crossPkgs.runCommand "test-${pkgName}-${crossPkgs.stdenv.hostPlatform.config}" { - nativeBuildInputs = [ pkgs.dos2unix ]; - } '' - # Just in case we are using wine, get rid of that annoying extra - # stuff. - export WINEDEBUG=-all - - HOME=$(pwd) - mkdir -p $out - - # We need to remove whitespace, unfortunately - # Windows programs use \r but Unix programs use \n - - echo Running native-built program natively - - # find expected value natively - ${getExecutable hostPkgs pkgFun exec} ${args'} \ - | dos2unix > $out/expected - - echo Running cross-built program in emulator - - # run emulator to get actual value - ${emulator} ${getExecutable crossPkgs pkgFun exec} ${args'} \ - | dos2unix > $out/actual - - echo Comparing results... - - if [ "$(cat $out/actual)" != "$(cat $out/expected)" ]; then - echo "${pkgName} did not output expected value:" - cat $out/expected - echo "instead it output:" - cat $out/actual - exit 1 - else - echo "${pkgName} test passed" - echo "both produced output:" - cat $out/actual - fi - ''; - - mapMultiPlatformTest = crossSystemFun: test: lib.mapAttrs (name: system: test rec { - crossPkgs = import pkgs.path { - localSystem = { inherit (pkgs.stdenv.hostPlatform) config; }; - crossSystem = crossSystemFun system; - }; - - emulator = crossPkgs.stdenv.hostPlatform.emulator pkgs; - - # Apply some transformation on windows to get dlls in the right - # place. Unfortunately mingw doesn’t seem to be able to do linking - # properly. - platformFun = pkg: if crossPkgs.stdenv.hostPlatform.isWindows then - pkgs.buildEnv { - name = "${pkg.name}-winlinks"; - paths = [pkg] ++ pkg.buildInputs; - } else pkg; - }) testedSystems; + compareTest = + { + emulator, + pkgFun, + hostPkgs, + crossPkgs, + exec, + args ? [ ], + }: + let + pkgName = (pkgFun hostPkgs).name; + args' = lib.concatStringsSep " " args; + in + crossPkgs.runCommand "test-${pkgName}-${crossPkgs.stdenv.hostPlatform.config}" + { + nativeBuildInputs = [ pkgs.dos2unix ]; + } + '' + # Just in case we are using wine, get rid of that annoying extra + # stuff. + export WINEDEBUG=-all + + HOME=$(pwd) + mkdir -p $out + + # We need to remove whitespace, unfortunately + # Windows programs use \r but Unix programs use \n + + echo Running native-built program natively + + # find expected value natively + ${getExecutable hostPkgs pkgFun exec} ${args'} \ + | dos2unix > $out/expected + + echo Running cross-built program in emulator + + # run emulator to get actual value + ${emulator} ${getExecutable crossPkgs pkgFun exec} ${args'} \ + | dos2unix > $out/actual + + echo Comparing results... + + if [ "$(cat $out/actual)" != "$(cat $out/expected)" ]; then + echo "${pkgName} did not output expected value:" + cat $out/expected + echo "instead it output:" + cat $out/actual + exit 1 + else + echo "${pkgName} test passed" + echo "both produced output:" + cat $out/actual + fi + ''; + + mapMultiPlatformTest = + crossSystemFun: test: + lib.mapAttrs ( + name: system: + test rec { + crossPkgs = import pkgs.path { + localSystem = { inherit (pkgs.stdenv.hostPlatform) config; }; + crossSystem = crossSystemFun system; + }; + + emulator = crossPkgs.stdenv.hostPlatform.emulator pkgs; + + # Apply some transformation on windows to get dlls in the right + # place. Unfortunately mingw doesn’t seem to be able to do linking + # properly. + platformFun = + pkg: + if crossPkgs.stdenv.hostPlatform.isWindows then + pkgs.buildEnv { + name = "${pkg.name}-winlinks"; + paths = [ pkg ] ++ pkg.buildInputs; + } + else + pkg; + } + ) testedSystems; tests = { - file = {platformFun, crossPkgs, emulator}: compareTest { - inherit emulator crossPkgs; - hostPkgs = pkgs; - exec = "/bin/file"; - args = [ - "${pkgs.file}/share/man/man1/file.1.gz" - "${pkgs.dejavu_fonts}/share/fonts/truetype/DejaVuMathTeXGyre.ttf" - ]; - pkgFun = pkgs: platformFun pkgs.file; - }; - - hello = {platformFun, crossPkgs, emulator}: compareTest { - inherit emulator crossPkgs; - hostPkgs = pkgs; - exec = "/bin/hello"; - pkgFun = pkgs: pkgs.hello; - }; - - pkg-config = {platformFun, crossPkgs, emulator}: crossPkgs.runCommand - "test-pkg-config-${crossPkgs.stdenv.hostPlatform.config}" - { - depsBuildBuild = [ crossPkgs.pkgsBuildBuild.pkg-config ]; - nativeBuildInputs = [ crossPkgs.pkgsBuildHost.pkg-config crossPkgs.buildPackages.zlib ]; - depsBuildTarget = [ crossPkgs.pkgsBuildTarget.pkg-config ]; - buildInputs = [ crossPkgs.zlib ]; - NIX_DEBUG = 7; - } '' - mkdir $out - ${crossPkgs.pkgsBuildBuild.pkg-config.targetPrefix}pkg-config --cflags zlib > "$out/for-build" - ${crossPkgs.pkgsBuildHost.pkg-config.targetPrefix}pkg-config --cflags zlib > "$out/for-host" - ! diff "$out/for-build" "$out/for-host" - ''; + file = + { + platformFun, + crossPkgs, + emulator, + }: + compareTest { + inherit emulator crossPkgs; + hostPkgs = pkgs; + exec = "/bin/file"; + args = [ + "${pkgs.file}/share/man/man1/file.1.gz" + "${pkgs.dejavu_fonts}/share/fonts/truetype/DejaVuMathTeXGyre.ttf" + ]; + pkgFun = pkgs: platformFun pkgs.file; + }; + + hello = + { + platformFun, + crossPkgs, + emulator, + }: + compareTest { + inherit emulator crossPkgs; + hostPkgs = pkgs; + exec = "/bin/hello"; + pkgFun = pkgs: pkgs.hello; + }; + + pkg-config = + { + platformFun, + crossPkgs, + emulator, + }: + crossPkgs.runCommand "test-pkg-config-${crossPkgs.stdenv.hostPlatform.config}" + { + depsBuildBuild = [ crossPkgs.pkgsBuildBuild.pkg-config ]; + nativeBuildInputs = [ + crossPkgs.pkgsBuildHost.pkg-config + crossPkgs.buildPackages.zlib + ]; + depsBuildTarget = [ crossPkgs.pkgsBuildTarget.pkg-config ]; + buildInputs = [ crossPkgs.zlib ]; + NIX_DEBUG = 7; + } + '' + mkdir $out + ${crossPkgs.pkgsBuildBuild.pkg-config.targetPrefix}pkg-config --cflags zlib > "$out/for-build" + ${crossPkgs.pkgsBuildHost.pkg-config.targetPrefix}pkg-config --cflags zlib > "$out/for-host" + ! diff "$out/for-build" "$out/for-host" + ''; }; # see https://github.com/NixOS/nixpkgs/issues/213453 # this is a good test of a lot of tricky glibc/libgcc corner cases - mbuffer = let - mbuffer = pkgs.pkgsCross.aarch64-multiplatform.mbuffer; - emulator = with lib.systems; (elaborate examples.aarch64-multiplatform).emulator pkgs; - in - pkgs.runCommand "test-mbuffer" {} '' + mbuffer = + let + mbuffer = pkgs.pkgsCross.aarch64-multiplatform.mbuffer; + emulator = with lib.systems; (elaborate examples.aarch64-multiplatform).emulator pkgs; + in + pkgs.runCommand "test-mbuffer" { } '' echo hello | ${emulator} ${mbuffer}/bin/mbuffer touch $out ''; @@ -127,45 +174,48 @@ let # so we can ask @ofborg to check it, yet should have good examples # of things that often break. So, no buckshot `mapTestOnCross` # calls here. - sanity = [ - mbuffer - #pkgs.pkgsCross.gnu64.bash # https://github.com/NixOS/nixpkgs/issues/243164 - pkgs.gcc_multi.cc - pkgs.pkgsMusl.stdenv - pkgs.pkgsLLVM.stdenv - pkgs.pkgsStatic.bash - #pkgs.pkgsCross.gnu64_simplekernel.bash # https://github.com/NixOS/nixpkgs/issues/264989 - pkgs.pkgsCross.arm-embedded.stdenv - pkgs.pkgsCross.sheevaplug.stdenv # for armv5tel - pkgs.pkgsCross.raspberryPi.stdenv # for armv6l - pkgs.pkgsCross.armv7l-hf-multiplatform.stdenv - pkgs.pkgsCross.m68k.stdenv - pkgs.pkgsCross.aarch64-multiplatform.pkgsBuildTarget.gcc - pkgs.pkgsCross.powernv.pkgsBuildTarget.gcc - pkgs.pkgsCross.s390.stdenv - pkgs.pkgsCross.mips64el-linux-gnuabi64.stdenv - pkgs.pkgsCross.mips64el-linux-gnuabin32.stdenv - pkgs.pkgsCross.mingwW64.stdenv - # Uses the expression that is used by the most cross-compil_ed_ GHCs - pkgs.pkgsCross.riscv64.haskell.compiler.native-bignum.ghc948 - - ] ++ lib.optionals (with pkgs.stdenv.buildPlatform; isx86_64 && isLinux) [ - # Musl-to-glibc cross on the same architecture tends to turn up - # lots of interesting corner cases. Only expected to work for - # x86_64-linux buildPlatform. - pkgs.pkgsMusl.pkgsCross.gnu64.hello - - # Two web browsers -- exercises almost the entire packageset - pkgs.pkgsCross.aarch64-multiplatform.qutebrowser-qt5 - pkgs.pkgsCross.aarch64-multiplatform.firefox - - # Uses pkgsCross.riscv64-embedded; see https://github.com/NixOS/nixpkgs/issues/267859 - pkgs.spike - ]; - -in { - gcc = (lib.mapAttrs (_: mapMultiPlatformTest (system: system // {useLLVM = false;})) tests); - llvm = (lib.mapAttrs (_: mapMultiPlatformTest (system: system // {useLLVM = true;})) tests); + sanity = + [ + mbuffer + #pkgs.pkgsCross.gnu64.bash # https://github.com/NixOS/nixpkgs/issues/243164 + pkgs.gcc_multi.cc + pkgs.pkgsMusl.stdenv + pkgs.pkgsLLVM.stdenv + pkgs.pkgsStatic.bash + #pkgs.pkgsCross.gnu64_simplekernel.bash # https://github.com/NixOS/nixpkgs/issues/264989 + pkgs.pkgsCross.arm-embedded.stdenv + pkgs.pkgsCross.sheevaplug.stdenv # for armv5tel + pkgs.pkgsCross.raspberryPi.stdenv # for armv6l + pkgs.pkgsCross.armv7l-hf-multiplatform.stdenv + pkgs.pkgsCross.m68k.stdenv + pkgs.pkgsCross.aarch64-multiplatform.pkgsBuildTarget.gcc + pkgs.pkgsCross.powernv.pkgsBuildTarget.gcc + pkgs.pkgsCross.s390.stdenv + pkgs.pkgsCross.mips64el-linux-gnuabi64.stdenv + pkgs.pkgsCross.mips64el-linux-gnuabin32.stdenv + pkgs.pkgsCross.mingwW64.stdenv + # Uses the expression that is used by the most cross-compil_ed_ GHCs + pkgs.pkgsCross.riscv64.haskell.compiler.native-bignum.ghc948 + + ] + ++ lib.optionals (with pkgs.stdenv.buildPlatform; isx86_64 && isLinux) [ + # Musl-to-glibc cross on the same architecture tends to turn up + # lots of interesting corner cases. Only expected to work for + # x86_64-linux buildPlatform. + pkgs.pkgsMusl.pkgsCross.gnu64.hello + + # Two web browsers -- exercises almost the entire packageset + pkgs.pkgsCross.aarch64-multiplatform.qutebrowser-qt5 + pkgs.pkgsCross.aarch64-multiplatform.firefox + + # Uses pkgsCross.riscv64-embedded; see https://github.com/NixOS/nixpkgs/issues/267859 + pkgs.spike + ]; + +in +{ + gcc = (lib.mapAttrs (_: mapMultiPlatformTest (system: system // { useLLVM = false; })) tests); + llvm = (lib.mapAttrs (_: mapMultiPlatformTest (system: system // { useLLVM = true; })) tests); inherit mbuffer sanity; } diff --git a/pkgs/test/cue/default.nix b/pkgs/test/cue/default.nix index 2cc8bf34bb043d..c5adf662b0ab37 100644 --- a/pkgs/test/cue/default.nix +++ b/pkgs/test/cue/default.nix @@ -1,14 +1,18 @@ -{ writeCueValidator, runCommand, writeText, ... }: +{ + writeCueValidator, + runCommand, + writeText, + ... +}: let - validator = writeCueValidator - (writeText "schema.cue" '' - #Def1: { - field1: string - } - '') - { document = "#Def1"; }; -in runCommand "cue-validation" {} '' + validator = writeCueValidator (writeText "schema.cue" '' + #Def1: { + field1: string + } + '') { document = "#Def1"; }; +in +runCommand "cue-validation" { } '' cat > valid.json <"$out" - ''); + without-fallback = testers.testBuildFailure ( + runCommand "use-dotnet-from-env-without-fallback-test" { } '' + ${appWithoutFallback}/bin/Application >"$out" + '' + ); # NB assumes that without-fallback above to passes. use-dotnet-root-env = testers.testEqualContents { assertion = "buildDotnetModule uses DOTNET_ROOT from environment in wrapper"; expected = runtimeVersionFile; - actual = runCommand "use-dotnet-from-env-root-test" { env.DOTNET_ROOT = "${dotnet-runtime}/share/dotnet"; } '' - ${appWithoutFallback}/bin/Application >"$out" - ''; + actual = + runCommand "use-dotnet-from-env-root-test" { env.DOTNET_ROOT = "${dotnet-runtime}/share/dotnet"; } + '' + ${appWithoutFallback}/bin/Application >"$out" + ''; }; use-dotnet-path-env = testers.testEqualContents { assertion = "buildDotnetModule uses DOTNET_ROOT from dotnet in PATH in wrapper"; diff --git a/pkgs/test/dotnet/use-dotnet-from-env/nuget-deps.nix b/pkgs/test/dotnet/use-dotnet-from-env/nuget-deps.nix index f3a17967e25c81..dbfecc1b26058f 100644 --- a/pkgs/test/dotnet/use-dotnet-from-env/nuget-deps.nix +++ b/pkgs/test/dotnet/use-dotnet-from-env/nuget-deps.nix @@ -1,5 +1,6 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ +{ fetchNuGet }: +[ ] diff --git a/pkgs/test/haskell/cabalSdist/default.nix b/pkgs/test/haskell/cabalSdist/default.nix index 4432e95ab56ecb..d9dc2bada6e22a 100644 --- a/pkgs/test/haskell/cabalSdist/default.nix +++ b/pkgs/test/haskell/cabalSdist/default.nix @@ -1,4 +1,9 @@ -{ lib, haskell, haskellPackages, runCommand }: +{ + lib, + haskell, + haskellPackages, + runCommand, +}: let src = lib.fileset.toSource { @@ -12,7 +17,7 @@ let # This prevents the source from depending on the formatting of the ./local/generated.nix file localRaw = haskell.lib.compose.overrideSrc { inherit src; - } (haskellPackages.callPackage ./local/generated.nix {}); + } (haskellPackages.callPackage ./local/generated.nix { }); in lib.recurseIntoAttrs rec { @@ -28,17 +33,23 @@ lib.recurseIntoAttrs rec { # it doesn't do anything. If this test fails, either the test setup was broken, # or Haskell packaging has changed the way `src` is treated in such a way that # either the test or the design of `buildFromCabalSdist` needs to be reconsidered. - assumptionLocalHasDirectReference = runCommand "localHasDirectReference" { - drvPath = builtins.unsafeDiscardOutputDependency localRaw.drvPath; - } '' - grep ${src} $drvPath >/dev/null - touch $out - ''; + assumptionLocalHasDirectReference = + runCommand "localHasDirectReference" + { + drvPath = builtins.unsafeDiscardOutputDependency localRaw.drvPath; + } + '' + grep ${src} $drvPath >/dev/null + touch $out + ''; - localHasNoDirectReference = runCommand "localHasNoDirectReference" { - drvPath = builtins.unsafeDiscardOutputDependency localFromCabalSdist.drvPath; - } '' - grep -v ${src} $drvPath >/dev/null - touch $out - ''; + localHasNoDirectReference = + runCommand "localHasNoDirectReference" + { + drvPath = builtins.unsafeDiscardOutputDependency localFromCabalSdist.drvPath; + } + '' + grep -v ${src} $drvPath >/dev/null + touch $out + ''; } diff --git a/pkgs/test/haskell/cabalSdist/local/generated.nix b/pkgs/test/haskell/cabalSdist/local/generated.nix index fae1e45f3d9784..f0f52a03e0d038 100644 --- a/pkgs/test/haskell/cabalSdist/local/generated.nix +++ b/pkgs/test/haskell/cabalSdist/local/generated.nix @@ -1,5 +1,9 @@ # nix run ../../../../..#cabal2nix -- ./. -{ mkDerivation, base, lib }: +{ + mkDerivation, + base, + lib, +}: mkDerivation { pname = "local"; version = "0.1.0.0"; diff --git a/pkgs/test/haskell/documentationTarball/default.nix b/pkgs/test/haskell/documentationTarball/default.nix index 33751028101287..6c4d2179114f5b 100644 --- a/pkgs/test/haskell/documentationTarball/default.nix +++ b/pkgs/test/haskell/documentationTarball/default.nix @@ -4,18 +4,21 @@ let drv = haskellPackages.vector; docs = pkgs.haskell.lib.compose.documentationTarball drv; -in pkgs.runCommand "test haskell.lib.compose.documentationTarball" { - meta = { - inherit (docs.meta) platforms; - }; -} '' - tar xvzf "${docs}/${drv.name}-docs.tar.gz" +in +pkgs.runCommand "test haskell.lib.compose.documentationTarball" + { + meta = { + inherit (docs.meta) platforms; + }; + } + '' + tar xvzf "${docs}/${drv.name}-docs.tar.gz" - # Check for Haddock html - find "${drv.name}-docs" | grep -q "Data-Vector.html" + # Check for Haddock html + find "${drv.name}-docs" | grep -q "Data-Vector.html" - # Check for source html - find "${drv.name}-docs" | grep -q "src/Data.Vector.html" + # Check for source html + find "${drv.name}-docs" | grep -q "src/Data.Vector.html" - touch "$out" -'' + touch "$out" + '' diff --git a/pkgs/test/haskell/incremental/default.nix b/pkgs/test/haskell/incremental/default.nix index c7bd43b11af6ee..fa08c9315b9279 100644 --- a/pkgs/test/haskell/incremental/default.nix +++ b/pkgs/test/haskell/incremental/default.nix @@ -3,7 +3,11 @@ # See: https://www.haskellforall.com/2022/12/nixpkgs-support-for-incremental-haskell.html # See: https://felixspringer.xyz/homepage/blog/incrementalHaskellBuildsWithNix -{ haskell, haskellPackages, lib }: +{ + haskell, + haskellPackages, + lib, +}: let inherit (haskell.lib.compose) overrideCabal; @@ -28,8 +32,8 @@ let previousIntermediates = temporary-full-build-with-incremental-output.intermediates; }) temporary; in - temporary-incremental-build.overrideAttrs (old: { - meta = { - maintainers = lib.teams.mercury.members; - }; - }) +temporary-incremental-build.overrideAttrs (old: { + meta = { + maintainers = lib.teams.mercury.members; + }; +}) diff --git a/pkgs/test/haskell/setBuildTarget/default.nix b/pkgs/test/haskell/setBuildTarget/default.nix index 39d5db698bcd0f..012bce8541e67c 100644 --- a/pkgs/test/haskell/setBuildTarget/default.nix +++ b/pkgs/test/haskell/setBuildTarget/default.nix @@ -3,49 +3,57 @@ let # This can be regenerated by running `cabal2nix .` in the current directory. pkgDef = - { mkDerivation, base, lib }: - mkDerivation { - pname = "haskell-setBuildTarget"; - version = "0.1.0.0"; - src = lib.fileset.toSource { - root = ./.; - fileset = lib.fileset.unions [ - ./haskell-setBuildTarget.cabal - ./Bar.hs - ./Foo.hs - ./Setup.hs - ]; - }; - isLibrary = false; - isExecutable = true; - executableHaskellDepends = [ base ]; - license = lib.licenses.bsd3; + { + mkDerivation, + base, + lib, + }: + mkDerivation { + pname = "haskell-setBuildTarget"; + version = "0.1.0.0"; + src = lib.fileset.toSource { + root = ./.; + fileset = lib.fileset.unions [ + ./haskell-setBuildTarget.cabal + ./Bar.hs + ./Foo.hs + ./Setup.hs + ]; }; + isLibrary = false; + isExecutable = true; + executableHaskellDepends = [ base ]; + license = lib.licenses.bsd3; + }; - drv = haskellPackages.callPackage pkgDef {}; + drv = haskellPackages.callPackage pkgDef { }; - test = target: excluded: - let only = pkgs.haskell.lib.compose.setBuildTarget target drv; - in '' - if [[ ! -f "${only}/bin/${target}" ]]; then - echo "${target} was not built" - exit 1 - fi + test = + target: excluded: + let + only = pkgs.haskell.lib.compose.setBuildTarget target drv; + in + '' + if [[ ! -f "${only}/bin/${target}" ]]; then + echo "${target} was not built" + exit 1 + fi - if [[ -f "${only}/bin/${excluded}" ]]; then - echo "${excluded} was built, when it should not have been" - exit 1 - fi - ''; + if [[ -f "${only}/bin/${excluded}" ]]; then + echo "${excluded} was built, when it should not have been" + exit 1 + fi + ''; in -pkgs.runCommand "test haskell.lib.compose.setBuildTarget" { - meta = { - inherit (drv.meta) platforms; - }; -} '' - ${test "foo" "bar"} - ${test "bar" "foo"} - touch "$out" -'' - +pkgs.runCommand "test haskell.lib.compose.setBuildTarget" + { + meta = { + inherit (drv.meta) platforms; + }; + } + '' + ${test "foo" "bar"} + ${test "bar" "foo"} + touch "$out" + '' diff --git a/pkgs/test/haskell/shellFor/default.nix b/pkgs/test/haskell/shellFor/default.nix index 82cd9e38e73159..3e0f3ed749347f 100644 --- a/pkgs/test/haskell/shellFor/default.nix +++ b/pkgs/test/haskell/shellFor/default.nix @@ -1,14 +1,26 @@ -{ lib, writeText, haskellPackages, cabal-install }: +{ + lib, + writeText, + haskellPackages, + cabal-install, +}: (haskellPackages.shellFor { - packages = p: [ p.constraints p.cereal ]; + packages = p: [ + p.constraints + p.cereal + ]; # WARNING: When updating this, make sure that the libraries passed to # `extraDependencies` are not actually transitive dependencies of libraries in # `packages` above. We explicitly want to test that it is possible to specify # `extraDependencies` that are not in the closure of `packages`. extraDependencies = p: { libraryHaskellDepends = [ p.conduit ]; }; nativeBuildInputs = [ cabal-install ]; - phases = [ "unpackPhase" "buildPhase" "installPhase" ]; + phases = [ + "unpackPhase" + "buildPhase" + "installPhase" + ]; unpackPhase = '' sourceRoot=$(pwd)/scratch mkdir -p "$sourceRoot" @@ -42,16 +54,18 @@ installPhase = '' touch $out ''; -}).overrideAttrs (oldAttrs: { - meta = - let - oldMeta = oldAttrs.meta or {}; - oldMaintainers = oldMeta.maintainers or []; - additionalMaintainers = with lib.maintainers; [ cdepillabout ]; - allMaintainers = oldMaintainers ++ additionalMaintainers; - in - oldMeta // { - maintainers = allMaintainers; - inherit (cabal-install.meta) platforms; - }; -}) +}).overrideAttrs + (oldAttrs: { + meta = + let + oldMeta = oldAttrs.meta or { }; + oldMaintainers = oldMeta.maintainers or [ ]; + additionalMaintainers = with lib.maintainers; [ cdepillabout ]; + allMaintainers = oldMaintainers ++ additionalMaintainers; + in + oldMeta + // { + maintainers = allMaintainers; + inherit (cabal-install.meta) platforms; + }; + }) diff --git a/pkgs/test/haskell/upstreamStackHpackVersion/default.nix b/pkgs/test/haskell/upstreamStackHpackVersion/default.nix index f3ddbcd3e01671..788a3e2db5ef82 100644 --- a/pkgs/test/haskell/upstreamStackHpackVersion/default.nix +++ b/pkgs/test/haskell/upstreamStackHpackVersion/default.nix @@ -1,4 +1,3 @@ - # This derivation confirms that the version of hpack used by stack in Nixpkgs # is the exact same version as the upstream stack release. # @@ -11,21 +10,24 @@ # This test is written as a fixed-output derivation, because we need to access # accesses the internet to download the upstream stack release. -{ cacert, curl, lib, stack, stdenv }: +{ + cacert, + curl, + lib, + stack, + stdenv, +}: let # Find the hpack derivation that is a dependency of stack. Throw exception # if hpack cannot be found. hpack = - lib.findFirst - (v: v.pname or "" == "hpack") - (throw "could not find stack's hpack dependency") + lib.findFirst (v: v.pname or "" == "hpack") (throw "could not find stack's hpack dependency") stack.passthru.getCabalDeps.executableHaskellDepends; # This is a statically linked version of stack, so it should be usable within # the Nixpkgs builder (at least on x86_64-linux). - stackDownloadUrl = - "https://github.com/commercialhaskell/stack/releases/download/v${stack.version}/stack-${stack.version}-linux-x86_64.tar.gz"; + stackDownloadUrl = "https://github.com/commercialhaskell/stack/releases/download/v${stack.version}/stack-${stack.version}-linux-x86_64.tar.gz"; # This test code has been explicitly pulled out of the derivation below so # that it can be hashed and added to the `name` of the derivation. This is @@ -127,18 +129,23 @@ stdenv.mkDerivation { outputHashMode = "flat"; outputHashAlgo = "sha256"; - nativeBuildInputs = [ curl stack ]; + nativeBuildInputs = [ + curl + stack + ]; impureEnvVars = lib.fetchers.proxyImpureEnvVars; - buildCommand = '' - # Make sure curl can access HTTPS sites, like GitHub. - # - # Note that we absolutely don't want the Nix store path of the cacert - # derivation in the testScript, because we don't want to rebuild this - # derivation when only the cacert derivation changes. - export SSL_CERT_FILE="${cacert}/etc/ssl/certs/ca-bundle.crt" - '' + testScript; + buildCommand = + '' + # Make sure curl can access HTTPS sites, like GitHub. + # + # Note that we absolutely don't want the Nix store path of the cacert + # derivation in the testScript, because we don't want to rebuild this + # derivation when only the cacert derivation changes. + export SSL_CERT_FILE="${cacert}/etc/ssl/certs/ca-bundle.crt" + '' + + testScript; meta = with lib; { description = "Test that the stack in Nixpkgs uses the same version of Hpack as the upstream stack release"; diff --git a/pkgs/test/hooks/default.nix b/pkgs/test/hooks/default.nix index aabf939b68657b..92604ce73fabc4 100644 --- a/pkgs/test/hooks/default.nix +++ b/pkgs/test/hooks/default.nix @@ -1,7 +1,11 @@ # To run these tests: # nix-build -A tests.hooks -{ stdenv, tests, lib }: +{ + stdenv, + tests, + lib, +}: { default-stdenv-hooks = lib.recurseIntoAttrs tests.stdenv.hooks; diff --git a/pkgs/test/kernel.nix b/pkgs/test/kernel.nix index 210d69f7ffae35..8c4aecf462d3f8 100644 --- a/pkgs/test/kernel.nix +++ b/pkgs/test/kernel.nix @@ -6,13 +6,14 @@ let lts_kernel = pkgs.linuxPackages.kernel; # to see the result once the module transformed the lose structured config - getConfig = structuredConfig: + getConfig = + structuredConfig: (lts_kernel.override { structuredExtraConfig = structuredConfig; }).configfile.structuredConfig; mandatoryVsOptionalConfig = lib.mkMerge [ - { NIXOS_FAKE_USB_DEBUG = lib.kernel.yes;} + { NIXOS_FAKE_USB_DEBUG = lib.kernel.yes; } { NIXOS_FAKE_USB_DEBUG = lib.kernel.option lib.kernel.yes; } ]; @@ -22,19 +23,23 @@ let ]; mkDefaultWorksConfig = lib.mkMerge [ - { "NIXOS_TEST_BOOLEAN" = lib.kernel.yes; } - { "NIXOS_TEST_BOOLEAN" = lib.mkDefault lib.kernel.no; } + { "NIXOS_TEST_BOOLEAN" = lib.kernel.yes; } + { "NIXOS_TEST_BOOLEAN" = lib.mkDefault lib.kernel.no; } ]; allOptionalRemainOptional = lib.mkMerge [ - { NIXOS_FAKE_USB_DEBUG = lib.kernel.option lib.kernel.yes;} - { NIXOS_FAKE_USB_DEBUG = lib.kernel.option lib.kernel.yes;} + { NIXOS_FAKE_USB_DEBUG = lib.kernel.option lib.kernel.yes; } + { NIXOS_FAKE_USB_DEBUG = lib.kernel.option lib.kernel.yes; } ]; failures = lib.runTests { testEasy = { - expr = (getConfig { NIXOS_FAKE_USB_DEBUG = lib.kernel.yes;}).NIXOS_FAKE_USB_DEBUG; - expected = { tristate = "y"; optional = false; freeform = null; }; + expr = (getConfig { NIXOS_FAKE_USB_DEBUG = lib.kernel.yes; }).NIXOS_FAKE_USB_DEBUG; + expected = { + tristate = "y"; + optional = false; + freeform = null; + }; }; # mandatory flag should win over optional @@ -56,15 +61,18 @@ let # check that freeform options are unique # Should trigger # > The option `settings.NIXOS_FAKE_MMC_BLOCK_MINORS.freeform' has conflicting definitions, in `' and `' - testTreeform = let - res = builtins.tryEval ( (getConfig freeformConfig).NIXOS_FAKE_MMC_BLOCK_MINORS.freeform); - in { - expr = res.success; - expected = false; - }; + testTreeform = + let + res = builtins.tryEval ((getConfig freeformConfig).NIXOS_FAKE_MMC_BLOCK_MINORS.freeform); + in + { + expr = res.success; + expected = false; + }; }; in -lib.optional (failures != []) - (throw "The following kernel unit tests failed: ${lib.generators.toPretty {} failures}") +lib.optional (failures != [ ]) ( + throw "The following kernel unit tests failed: ${lib.generators.toPretty { } failures}" +) diff --git a/pkgs/test/ld-library-path/default.nix b/pkgs/test/ld-library-path/default.nix index 74c52cef25328c..2e25b3051afe98 100644 --- a/pkgs/test/ld-library-path/default.nix +++ b/pkgs/test/ld-library-path/default.nix @@ -70,7 +70,8 @@ let ''; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { name = "test-LD_LIBRARY_PATH"; nativeBuildInputs = [ testProgram ]; diff --git a/pkgs/test/make-binary-wrapper/cross.nix b/pkgs/test/make-binary-wrapper/cross.nix index 64912364b863bf..b2caae738cd8f1 100644 --- a/pkgs/test/make-binary-wrapper/cross.nix +++ b/pkgs/test/make-binary-wrapper/cross.nix @@ -1,28 +1,30 @@ -{ stdenv -, runCommand -, makeBinaryWrapper -, binutils -, lib -, expectedArch ? stdenv.hostPlatform.parsed.cpu.name +{ + stdenv, + runCommand, + makeBinaryWrapper, + binutils, + lib, + expectedArch ? stdenv.hostPlatform.parsed.cpu.name, }: - -runCommand "make-binary-wrapper-test-cross" { - nativeBuildInputs = [ - makeBinaryWrapper - binutils - ]; - # For x86_64-linux the machine field is - # Advanced Micro Devices X86-64 - # and uses a dash instead of a underscore unlike x86_64-linux in hostPlatform.parsed.cpu.name - expectedArch = lib.replaceStrings ["_"] ["-"] expectedArch; -} '' - touch prog - chmod +x prog - makeWrapper prog $out - read -r _ arch < <($READELF --file-header $out | grep Machine:) - if [[ ''${arch,,} != *"''${expectedArch,,}"* ]]; then - echo "expected $expectedArch, got $arch" - exit 1 - fi -'' +runCommand "make-binary-wrapper-test-cross" + { + nativeBuildInputs = [ + makeBinaryWrapper + binutils + ]; + # For x86_64-linux the machine field is + # Advanced Micro Devices X86-64 + # and uses a dash instead of a underscore unlike x86_64-linux in hostPlatform.parsed.cpu.name + expectedArch = lib.replaceStrings [ "_" ] [ "-" ] expectedArch; + } + '' + touch prog + chmod +x prog + makeWrapper prog $out + read -r _ arch < <($READELF --file-header $out | grep Machine:) + if [[ ''${arch,,} != *"''${expectedArch,,}"* ]]; then + echo "expected $expectedArch, got $arch" + exit 1 + fi + '' diff --git a/pkgs/test/make-binary-wrapper/default.nix b/pkgs/test/make-binary-wrapper/default.nix index 29e4272fd672c6..036b70f7594e76 100644 --- a/pkgs/test/make-binary-wrapper/default.nix +++ b/pkgs/test/make-binary-wrapper/default.nix @@ -1,70 +1,83 @@ -{ lib -, stdenv -, pkgsCross -, makeBinaryWrapper -, writeText -, runCommand -, runCommandCC +{ + lib, + stdenv, + pkgsCross, + makeBinaryWrapper, + writeText, + runCommand, + runCommandCC, }: let - env = { nativeBuildInputs = [ makeBinaryWrapper ]; }; + env = { + nativeBuildInputs = [ makeBinaryWrapper ]; + }; envCheck = runCommandCC "envcheck" env '' cc -Wall -Werror -Wpedantic -o $out ${./envcheck.c} ''; - makeGoldenTest = testname: runCommand "make-binary-wrapper-test-${testname}" env '' - mkdir -p tmp/foo # for the chdir test + makeGoldenTest = + testname: + runCommand "make-binary-wrapper-test-${testname}" env '' + mkdir -p tmp/foo # for the chdir test - source=${lib.fileset.toSource { - root = ./.; - fileset = lib.fileset.unions [ - (./. + "/${testname}.cmdline") - (./. + "/${testname}.c") - (lib.fileset.maybeMissing (./. + "/${testname}.env")) - ]; - }} + source=${ + lib.fileset.toSource { + root = ./.; + fileset = lib.fileset.unions [ + (./. + "/${testname}.cmdline") + (./. + "/${testname}.c") + (lib.fileset.maybeMissing (./. + "/${testname}.env")) + ]; + } + } - params=$(<"$source/${testname}.cmdline") - eval "makeCWrapper /send/me/flags $params" > wrapper.c + params=$(<"$source/${testname}.cmdline") + eval "makeCWrapper /send/me/flags $params" > wrapper.c - diff wrapper.c "$source/${testname}.c" + diff wrapper.c "$source/${testname}.c" - if [ -f "$source/${testname}.env" ]; then - eval "makeWrapper ${envCheck} wrapped $params" - env -i ./wrapped > env.txt - sed "s#SUBST_ARGV0#${envCheck}#;s#SUBST_CWD#$PWD#" \ - "$source/${testname}.env" > golden-env.txt - if ! diff env.txt golden-env.txt; then - echo "env/argv should be:" - cat golden-env.txt - echo "env/argv output is:" - cat env.txt - exit 1 + if [ -f "$source/${testname}.env" ]; then + eval "makeWrapper ${envCheck} wrapped $params" + env -i ./wrapped > env.txt + sed "s#SUBST_ARGV0#${envCheck}#;s#SUBST_CWD#$PWD#" \ + "$source/${testname}.env" > golden-env.txt + if ! diff env.txt golden-env.txt; then + echo "env/argv should be:" + cat golden-env.txt + echo "env/argv output is:" + cat env.txt + exit 1 + fi + else + # without a golden env, we expect the wrapper compilation to fail + ! eval "makeWrapper ${envCheck} wrapped $params" &> error.txt fi - else - # without a golden env, we expect the wrapper compilation to fail - ! eval "makeWrapper ${envCheck} wrapped $params" &> error.txt - fi - cp wrapper.c $out - ''; - tests = lib.genAttrs [ - "add-flags" - "argv0" - "basic" - "chdir" - "combination" - "env" - "inherit-argv0" - "invalid-env" - "overlength-strings" - "prefix" - "suffix" - ] makeGoldenTest // lib.optionalAttrs (! stdenv.hostPlatform.isDarwin) { - cross = pkgsCross.${if stdenv.buildPlatform.isAarch64 then "gnu64" else "aarch64-multiplatform"}.callPackage ./cross.nix { }; - }; + cp wrapper.c $out + ''; + tests = + lib.genAttrs [ + "add-flags" + "argv0" + "basic" + "chdir" + "combination" + "env" + "inherit-argv0" + "invalid-env" + "overlength-strings" + "prefix" + "suffix" + ] makeGoldenTest + // lib.optionalAttrs (!stdenv.hostPlatform.isDarwin) { + cross = + pkgsCross.${if stdenv.buildPlatform.isAarch64 then "gnu64" else "aarch64-multiplatform"}.callPackage + ./cross.nix + { }; + }; in writeText "make-binary-wrapper-tests" '' ${lib.concatStringsSep "\n" (builtins.attrValues tests)} -'' // tests +'' +// tests diff --git a/pkgs/test/make-hardcode-gsettings-patch/default.nix b/pkgs/test/make-hardcode-gsettings-patch/default.nix index e27a6f17920857..66e1c5eeb666a9 100644 --- a/pkgs/test/make-hardcode-gsettings-patch/default.nix +++ b/pkgs/test/make-hardcode-gsettings-patch/default.nix @@ -1,8 +1,9 @@ -{ runCommandLocal -, lib -, git -, clang-tools -, makeHardcodeGsettingsPatch +{ + runCommandLocal, + lib, + git, + clang-tools, + makeHardcodeGsettingsPatch, }: let @@ -21,8 +22,7 @@ let inherit patches; }); in - runCommandLocal - "makeHardcodeGsettingsPatch-tests-${name}" + runCommandLocal "makeHardcodeGsettingsPatch-tests-${name}" { nativeBuildInputs = [ diff --git a/pkgs/test/make-wrapper/default.nix b/pkgs/test/make-wrapper/default.nix index 5cc7cee5a864b4..db54a01946a105 100644 --- a/pkgs/test/make-wrapper/default.nix +++ b/pkgs/test/make-wrapper/default.nix @@ -1,11 +1,12 @@ -{ lib -, writeText -, writeCBin -, writeShellScript -, makeWrapper -, runCommand -, which -, ... +{ + lib, + writeText, + writeCBin, + writeShellScript, + makeWrapper, + runCommand, + which, + ... }: let @@ -30,13 +31,20 @@ let echo "$@" ''; - mkWrapperBinary = { name, args, wrapped ? wrappedBinaryVar }: runCommand name + mkWrapperBinary = { - nativeBuildInputs = [ makeWrapper ]; - } '' - mkdir -p $out/bin - makeWrapper "${wrapped}" "$out/bin/${name}" ${lib.escapeShellArgs args} - ''; + name, + args, + wrapped ? wrappedBinaryVar, + }: + runCommand name + { + nativeBuildInputs = [ makeWrapper ]; + } + '' + mkdir -p $out/bin + makeWrapper "${wrapped}" "$out/bin/${name}" ${lib.escapeShellArgs args} + ''; mkTest = cmd: toExpect: '' output="$(${cmd})" @@ -53,27 +61,154 @@ let ''; in runCommand "make-wrapper-test" -{ - nativeBuildInputs = [ - which - (mkWrapperBinary { name = "test-argv0"; args = [ "--argv0" "foo" ]; wrapped = "${wrappedArgv0}/bin/wrapped-argv0"; }) - (mkWrapperBinary { name = "test-set"; args = [ "--set" "VAR" "abc" ]; }) - (mkWrapperBinary { name = "test-set-default"; args = [ "--set-default" "VAR" "abc" ]; }) - (mkWrapperBinary { name = "test-unset"; args = [ "--unset" "VAR" ]; }) - (mkWrapperBinary { name = "test-run"; args = [ "--run" "echo bar" ]; }) - (mkWrapperBinary { name = "test-run-and-set"; args = [ "--run" "export VAR=foo" "--set" "VAR" "bar" ]; }) - (mkWrapperBinary { name = "test-args"; args = [ "--add-flags" "abc" "--append-flags" "xyz" ]; wrapped = wrappedBinaryArgs; }) - (mkWrapperBinary { name = "test-prefix"; args = [ "--prefix" "VAR" ":" "abc" ]; }) - (mkWrapperBinary { name = "test-prefix-noglob"; args = [ "--prefix" "VAR" ":" "./*" ]; }) - (mkWrapperBinary { name = "test-suffix"; args = [ "--suffix" "VAR" ":" "abc" ]; }) - (mkWrapperBinary { name = "test-prefix-and-suffix"; args = [ "--prefix" "VAR" ":" "foo" "--suffix" "VAR" ":" "bar" ]; }) - (mkWrapperBinary { name = "test-prefix-multi"; args = [ "--prefix" "VAR" ":" "abc:foo:foo" ]; }) - (mkWrapperBinary { name = "test-suffix-each"; args = [ "--suffix-each" "VAR" ":" "foo bar:def" ]; }) - (mkWrapperBinary { name = "test-prefix-each"; args = [ "--prefix-each" "VAR" ":" "foo bar:def" ]; }) - (mkWrapperBinary { name = "test-suffix-contents"; args = [ "--suffix-contents" "VAR" ":" "${foofile} ${barfile}" ]; }) - (mkWrapperBinary { name = "test-prefix-contents"; args = [ "--prefix-contents" "VAR" ":" "${foofile} ${barfile}" ]; }) - ]; -} + { + nativeBuildInputs = [ + which + (mkWrapperBinary { + name = "test-argv0"; + args = [ + "--argv0" + "foo" + ]; + wrapped = "${wrappedArgv0}/bin/wrapped-argv0"; + }) + (mkWrapperBinary { + name = "test-set"; + args = [ + "--set" + "VAR" + "abc" + ]; + }) + (mkWrapperBinary { + name = "test-set-default"; + args = [ + "--set-default" + "VAR" + "abc" + ]; + }) + (mkWrapperBinary { + name = "test-unset"; + args = [ + "--unset" + "VAR" + ]; + }) + (mkWrapperBinary { + name = "test-run"; + args = [ + "--run" + "echo bar" + ]; + }) + (mkWrapperBinary { + name = "test-run-and-set"; + args = [ + "--run" + "export VAR=foo" + "--set" + "VAR" + "bar" + ]; + }) + (mkWrapperBinary { + name = "test-args"; + args = [ + "--add-flags" + "abc" + "--append-flags" + "xyz" + ]; + wrapped = wrappedBinaryArgs; + }) + (mkWrapperBinary { + name = "test-prefix"; + args = [ + "--prefix" + "VAR" + ":" + "abc" + ]; + }) + (mkWrapperBinary { + name = "test-prefix-noglob"; + args = [ + "--prefix" + "VAR" + ":" + "./*" + ]; + }) + (mkWrapperBinary { + name = "test-suffix"; + args = [ + "--suffix" + "VAR" + ":" + "abc" + ]; + }) + (mkWrapperBinary { + name = "test-prefix-and-suffix"; + args = [ + "--prefix" + "VAR" + ":" + "foo" + "--suffix" + "VAR" + ":" + "bar" + ]; + }) + (mkWrapperBinary { + name = "test-prefix-multi"; + args = [ + "--prefix" + "VAR" + ":" + "abc:foo:foo" + ]; + }) + (mkWrapperBinary { + name = "test-suffix-each"; + args = [ + "--suffix-each" + "VAR" + ":" + "foo bar:def" + ]; + }) + (mkWrapperBinary { + name = "test-prefix-each"; + args = [ + "--prefix-each" + "VAR" + ":" + "foo bar:def" + ]; + }) + (mkWrapperBinary { + name = "test-suffix-contents"; + args = [ + "--suffix-contents" + "VAR" + ":" + "${foofile} ${barfile}" + ]; + }) + (mkWrapperBinary { + name = "test-prefix-contents"; + args = [ + "--prefix-contents" + "VAR" + ":" + "${foofile} ${barfile}" + ]; + }) + ]; + } ( # --argv0 works mkTest "test-argv0" "argv0=foo" @@ -116,7 +251,6 @@ runCommand "make-wrapper-test" # --prefix doesn't expand globs + mkTest "VAR=f?oo test-prefix-noglob" "VAR=./*:f?oo" - # --suffix works + mkTest "VAR=foo test-suffix" "VAR=foo:abc" # sets variable if not set yet diff --git a/pkgs/test/nixos-functions/default.nix b/pkgs/test/nixos-functions/default.nix index fc9a726570ff6a..dc8e0b3ead315d 100644 --- a/pkgs/test/nixos-functions/default.nix +++ b/pkgs/test/nixos-functions/default.nix @@ -1,15 +1,18 @@ /* + This file is a test that makes sure that the `pkgs.nixos` and + `pkgs.testers.nixosTest` functions work. It's far from a perfect test suite, + but better than not checking them at all on hydra. -This file is a test that makes sure that the `pkgs.nixos` and -`pkgs.testers.nixosTest` functions work. It's far from a perfect test suite, -but better than not checking them at all on hydra. + To run this test: -To run this test: - - nixpkgs$ nix-build -A tests.nixos-functions - - */ -{ pkgs, lib, stdenv, ... }: + nixpkgs$ nix-build -A tests.nixos-functions +*/ +{ + pkgs, + lib, + stdenv, + ... +}: let dummyVersioning = { @@ -17,13 +20,15 @@ let versionSuffix = "test"; label = "test"; }; -in pkgs.recurseIntoAttrs { +in +pkgs.recurseIntoAttrs { - nixos-test = (pkgs.nixos { - system.nixos = dummyVersioning; - boot.loader.grub.enable = false; - fileSystems."/".device = "/dev/null"; - system.stateVersion = lib.trivial.release; - }).toplevel; + nixos-test = + (pkgs.nixos { + system.nixos = dummyVersioning; + boot.loader.grub.enable = false; + fileSystems."/".device = "/dev/null"; + system.stateVersion = lib.trivial.release; + }).toplevel; } diff --git a/pkgs/test/php/default.nix b/pkgs/test/php/default.nix index 3c6c8f61b6dba9..cef46d3e3fa6be 100644 --- a/pkgs/test/php/default.nix +++ b/pkgs/test/php/default.nix @@ -1,30 +1,33 @@ -{ lib -, php -, runCommand +{ + lib, + php, + runCommand, }: let - runTest = name: body: runCommand name { } '' - testFailed= - checking() { - echo -n "Checking $1... " > /dev/stderr - } - ok() { - echo ok > /dev/stderr - } - nok() { - echo fail > /dev/stderr - testFailed=1 - } - - ${body} - - if test -n "$testFailed"; then - exit 1 - fi - - touch $out - ''; + runTest = + name: body: + runCommand name { } '' + testFailed= + checking() { + echo -n "Checking $1... " > /dev/stderr + } + ok() { + echo ok > /dev/stderr + } + nok() { + echo fail > /dev/stderr + testFailed=1 + } + + ${body} + + if test -n "$testFailed"; then + exit 1 + fi + + touch $out + ''; check = cond: if cond then "ok" else "nok"; in @@ -42,12 +45,13 @@ in overrideAttrs-preserves-enabled-extensions = let - customPhp = - (php.withExtensions ({ all, ... }: [ all.imagick ])).overrideAttrs (attrs: { - postInstall = attrs.postInstall or "" + '' + customPhp = (php.withExtensions ({ all, ... }: [ all.imagick ])).overrideAttrs (attrs: { + postInstall = + attrs.postInstall or "" + + '' touch "$out/oApee-was-here" ''; - }); + }); in runTest "php-test-overrideAttrs-preserves-enabled-extensions" '' php="${customPhp}" @@ -66,20 +70,29 @@ in unwrapped-overrideAttrs-stacks = let - customPhp = - lib.pipe php.unwrapped [ - (pkg: pkg.overrideAttrs (attrs: { - postInstall = attrs.postInstall or "" + '' - touch "$out/oAs-first" - ''; - })) - - (pkg: pkg.overrideAttrs (attrs: { - postInstall = attrs.postInstall or "" + '' - touch "$out/oAs-second" - ''; - })) - ]; + customPhp = lib.pipe php.unwrapped [ + ( + pkg: + pkg.overrideAttrs (attrs: { + postInstall = + attrs.postInstall or "" + + '' + touch "$out/oAs-first" + ''; + }) + ) + + ( + pkg: + pkg.overrideAttrs (attrs: { + postInstall = + attrs.postInstall or "" + + '' + touch "$out/oAs-second" + ''; + }) + ) + ]; in runTest "php-test-unwrapped-overrideAttrs-stacks" '' checking "if first override remained" @@ -91,20 +104,29 @@ in wrapped-overrideAttrs-stacks = let - customPhp = - lib.pipe php [ - (pkg: pkg.overrideAttrs (attrs: { - postInstall = attrs.postInstall or "" + '' - touch "$out/oAs-first" - ''; - })) - - (pkg: pkg.overrideAttrs (attrs: { - postInstall = attrs.postInstall or "" + '' - touch "$out/oAs-second" - ''; - })) - ]; + customPhp = lib.pipe php [ + ( + pkg: + pkg.overrideAttrs (attrs: { + postInstall = + attrs.postInstall or "" + + '' + touch "$out/oAs-first" + ''; + }) + ) + + ( + pkg: + pkg.overrideAttrs (attrs: { + postInstall = + attrs.postInstall or "" + + '' + touch "$out/oAs-second" + ''; + }) + ) + ]; in runTest "php-test-wrapped-overrideAttrs-stacks" '' checking "if first override remained" diff --git a/pkgs/test/stdenv-inputs/default.nix b/pkgs/test/stdenv-inputs/default.nix index deb97b8224237d..e52dd0a68c5417 100644 --- a/pkgs/test/stdenv-inputs/default.nix +++ b/pkgs/test/stdenv-inputs/default.nix @@ -20,7 +20,10 @@ let bar = stdenv.mkDerivation { name = "bar-test"; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; dontUnpack = true; @@ -41,7 +44,10 @@ stdenv.mkDerivation { name = "stdenv-inputs-test"; phases = [ "buildPhase" ]; - buildInputs = [ foo bar ]; + buildInputs = [ + foo + bar + ]; buildPhase = '' env diff --git a/pkgs/test/stdenv/hooks.nix b/pkgs/test/stdenv/hooks.nix index eb1b3f61bda629..6a419ab51e5d03 100644 --- a/pkgs/test/stdenv/hooks.nix +++ b/pkgs/test/stdenv/hooks.nix @@ -1,4 +1,8 @@ -{ stdenv, pkgs, lib }: +{ + stdenv, + pkgs, + lib, +}: # ordering should match defaultNativeBuildInputs @@ -23,7 +27,10 @@ }; make-symlinks-relative = stdenv.mkDerivation { name = "test-make-symlinks-relative"; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; buildCommand = '' mkdir -p $out/{bar,baz} mkdir -p $man/share/{x,y} diff --git a/pkgs/test/stdenv/patch-shebangs.nix b/pkgs/test/stdenv/patch-shebangs.nix index 51edf128f7d555..78b177593e86d9 100644 --- a/pkgs/test/stdenv/patch-shebangs.nix +++ b/pkgs/test/stdenv/patch-shebangs.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, pkgs }: +{ + lib, + stdenv, + pkgs, +}: # since the tests are using a early stdenv, the stdenv will have dontPatchShebangs=1, so it has to be unset # https://github.com/NixOS/nixpkgs/blob/768a982bfc9d29a6bd3beb963ed4b054451ce3d0/pkgs/stdenv/linux/default.nix#L148-L153 @@ -105,7 +109,15 @@ let in stdenv.mkDerivation { name = "test-patch-shebangs"; - passthru = { inherit (tests) bad-shebang ignores-nix-store updates-nix-store split-string without-trailing-newline; }; + passthru = { + inherit (tests) + bad-shebang + ignores-nix-store + updates-nix-store + split-string + without-trailing-newline + ; + }; buildCommand = '' validate() { local name=$1 @@ -129,9 +141,11 @@ stdenv.mkDerivation { echo "checking whether patchShebangs works properly... ">&2 fail= - ${lib.concatStringsSep "\n" (lib.mapAttrsToList (_: test: '' - validate "${test.name}" "${test}" ${lib.escapeShellArg test.assertion} || fail=1 - '') tests)} + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList (_: test: '' + validate "${test.name}" "${test}" ${lib.escapeShellArg test.assertion} || fail=1 + '') tests + )} if [ "$fail" ]; then echo "failed" diff --git a/pkgs/test/substitute/default.nix b/pkgs/test/substitute/default.nix index 3ff346b1465842..b3e207280a45ea 100644 --- a/pkgs/test/substitute/default.nix +++ b/pkgs/test/substitute/default.nix @@ -1,16 +1,23 @@ -{ substitute, testers, runCommand }: +{ + substitute, + testers, + runCommand, +}: let # Ofborg doesn't allow any traces on stderr, # so mock `lib` to not trace warnings, # because substitute gives a deprecation warning substituteSilent = substitute.override (prevArgs: { - lib = prevArgs.lib.extend (finalLib: prevLib: { - trivial = prevLib.trivial // { - warn = msg: value: value; - }; - }); + lib = prevArgs.lib.extend ( + finalLib: prevLib: { + trivial = prevLib.trivial // { + warn = msg: value: value; + }; + } + ); }); -in { +in +{ substitutions = testers.testEqualContents { assertion = "substitutions-spaces"; @@ -36,7 +43,9 @@ in { Hello world! ''; replacements = [ - "--replace-fail" "world" "paul" + "--replace-fail" + "world" + "paul" ]; }; expected = builtins.toFile "expected" '' @@ -92,5 +101,4 @@ in { ''; }; - } diff --git a/pkgs/test/systemd/nixos/default.nix b/pkgs/test/systemd/nixos/default.nix index 37b42ea7ae2736..8547c19478f4ec 100644 --- a/pkgs/test/systemd/nixos/default.nix +++ b/pkgs/test/systemd/nixos/default.nix @@ -1,11 +1,17 @@ -{ pkgs, lib, stdenv, ... }: +{ + pkgs, + lib, + stdenv, + ... +}: let failures = lib.runTests { # Merging two non-list definitions must still result in an error # about a conflicting definition. test-unitOption-merging-non-lists-conflict = - let nixos = pkgs.nixos { + let + nixos = pkgs.nixos { system.stateVersion = lib.trivial.release; systemd.services.systemd-test-nixos = { serviceConfig = lib.mkMerge [ @@ -14,29 +20,38 @@ let ]; }; }; - in { - expr = (builtins.tryEval (nixos.config.systemd.services.systemd-test-nixos.serviceConfig.StateDirectory)).success; - expected = false; - }; + in + { + expr = + (builtins.tryEval (nixos.config.systemd.services.systemd-test-nixos.serviceConfig.StateDirectory)) + .success; + expected = false; + }; # Merging must lift non-list definitions to a list # if at least one of them is a list. test-unitOption-merging-list-non-list-append = - let nixos = pkgs.nixos { + let + nixos = pkgs.nixos { system.stateVersion = lib.trivial.release; systemd.services.systemd-test-nixos = { serviceConfig = lib.mkMerge [ { StateDirectory = "foo"; } - { StateDirectory = ["bar"]; } + { StateDirectory = [ "bar" ]; } ]; }; }; - in { - expr = nixos.config.systemd.services.systemd-test-nixos.serviceConfig.StateDirectory; - expected = [ "foo" "bar" ]; - }; + in + { + expr = nixos.config.systemd.services.systemd-test-nixos.serviceConfig.StateDirectory; + expected = [ + "foo" + "bar" + ]; + }; }; in -lib.optional (failures != []) - (throw "The following systemd unit tests failed: ${lib.generators.toPretty {} failures}") +lib.optional (failures != [ ]) ( + throw "The following systemd unit tests failed: ${lib.generators.toPretty { } failures}" +) diff --git a/pkgs/test/texlive/default.nix b/pkgs/test/texlive/default.nix index 4efd858594fe2e..ced751e1762395 100644 --- a/pkgs/test/texlive/default.nix +++ b/pkgs/test/texlive/default.nix @@ -1,21 +1,45 @@ -{ lib, stdenv, buildEnv, runCommand, fetchurl, file, texlive, writeShellScript, writeText, texliveInfraOnly, texliveConTeXt, texliveSmall, texliveMedium, texliveFull }: +{ + lib, + stdenv, + buildEnv, + runCommand, + fetchurl, + file, + texlive, + writeShellScript, + writeText, + texliveInfraOnly, + texliveConTeXt, + texliveSmall, + texliveMedium, + texliveFull, +}: rec { mkTeXTest = lib.makeOverridable ( - { name - , format - , text - , texLive ? texliveSmall - , options ? "-interaction=errorstopmode" - , preTest ? "" - , postTest ? "" - , ... - }@attrs: runCommand "texlive-test-tex-${name}" - ({ - nativeBuildInputs = [ texLive ] ++ attrs.nativeBuildInputs or [ ]; - text = builtins.toFile "${name}.tex" text; - } // builtins.removeAttrs attrs [ "nativeBuildInputs" "text" "texLive" ]) + { + name, + format, + text, + texLive ? texliveSmall, + options ? "-interaction=errorstopmode", + preTest ? "", + postTest ? "", + ... + }@attrs: + runCommand "texlive-test-tex-${name}" + ( + { + nativeBuildInputs = [ texLive ] ++ attrs.nativeBuildInputs or [ ]; + text = builtins.toFile "${name}.tex" text; + } + // builtins.removeAttrs attrs [ + "nativeBuildInputs" + "text" + "texLive" + ] + ) '' export HOME="$(mktemp -d)" mkdir "$out" @@ -27,14 +51,16 @@ rec { '' ); - tlpdbNix = runCommand "texlive-test-tlpdb-nix" { - nixpkgsTlpdbNix = ../../tools/typesetting/tex/texlive/tlpdb.nix; - tlpdbNix = texlive.tlpdb.nix; - } - '' - mkdir -p "$out" - diff -u "''${nixpkgsTlpdbNix}" "''${tlpdbNix}" | tee "$out/tlpdb.nix.patch" - ''; + tlpdbNix = + runCommand "texlive-test-tlpdb-nix" + { + nixpkgsTlpdbNix = ../../tools/typesetting/tex/texlive/tlpdb.nix; + tlpdbNix = texlive.tlpdb.nix; + } + '' + mkdir -p "$out" + diff -u "''${nixpkgsTlpdbNix}" "''${tlpdbNix}" | tee "$out/tlpdb.nix.patch" + ''; # test two completely different font discovery mechanisms, both of which were once broken: # - lualatex uses its own luaotfload script (#220228) @@ -59,23 +85,26 @@ rec { }; }; - chktex = runCommand "texlive-test-chktex" { - nativeBuildInputs = [ - (texlive.withPackages (ps: [ ps.chktex ])) - ]; - input = builtins.toFile "chktex-sample.tex" '' - \documentclass{article} - \begin{document} - \LaTeX is great - \end{document} - ''; - } '' - # chktex is supposed to return 2 when it (successfully) finds warnings, but no errors, - # see http://git.savannah.nongnu.org/cgit/chktex.git/commit/?id=ec0fb9b58f02a62ff0bfec98b997208e9d7a5998 - (set +e; chktex -v -nall -w1 "$input" 2>&1; [ $? = 2 ] || exit 1; set -e) | tee "$out" - # also check that the output does indeed contain "One warning printed" - grep "One warning printed" "$out" - ''; + chktex = + runCommand "texlive-test-chktex" + { + nativeBuildInputs = [ + (texlive.withPackages (ps: [ ps.chktex ])) + ]; + input = builtins.toFile "chktex-sample.tex" '' + \documentclass{article} + \begin{document} + \LaTeX is great + \end{document} + ''; + } + '' + # chktex is supposed to return 2 when it (successfully) finds warnings, but no errors, + # see http://git.savannah.nongnu.org/cgit/chktex.git/commit/?id=ec0fb9b58f02a62ff0bfec98b997208e9d7a5998 + (set +e; chktex -v -nall -w1 "$input" 2>&1; [ $? = 2 ] || exit 1; set -e) | tee "$out" + # also check that the output does indeed contain "One warning printed" + grep "One warning printed" "$out" + ''; context = mkTeXTest { name = "texlive-test-context"; @@ -100,104 +129,129 @@ rec { dvipng = lib.recurseIntoAttrs { # https://github.com/NixOS/nixpkgs/issues/75605 - basic = runCommand "texlive-test-dvipng-basic" { - nativeBuildInputs = [ file texliveMedium ]; - input = fetchurl { - name = "test_dvipng.tex"; - url = "http://git.savannah.nongnu.org/cgit/dvipng.git/plain/test_dvipng.tex?id=b872753590a18605260078f56cbd6f28d39dc035"; - sha256 = "1pjpf1jvwj2pv5crzdgcrzvbmn7kfmgxa39pcvskl4pa0c9hl88n"; - }; - } '' - cp "$input" ./document.tex - - latex document.tex - dvipng -T tight -strict -picky document.dvi - for f in document*.png; do - file "$f" | tee output - grep PNG output - done - - mkdir "$out" - mv document*.png "$out"/ - ''; + basic = + runCommand "texlive-test-dvipng-basic" + { + nativeBuildInputs = [ + file + texliveMedium + ]; + input = fetchurl { + name = "test_dvipng.tex"; + url = "http://git.savannah.nongnu.org/cgit/dvipng.git/plain/test_dvipng.tex?id=b872753590a18605260078f56cbd6f28d39dc035"; + sha256 = "1pjpf1jvwj2pv5crzdgcrzvbmn7kfmgxa39pcvskl4pa0c9hl88n"; + }; + } + '' + cp "$input" ./document.tex + + latex document.tex + dvipng -T tight -strict -picky document.dvi + for f in document*.png; do + file "$f" | tee output + grep PNG output + done + + mkdir "$out" + mv document*.png "$out"/ + ''; # test dvipng's limited capability to render postscript specials via GS - ghostscript = runCommand "texlive-test-ghostscript" { - nativeBuildInputs = [ file (texliveSmall.withPackages (ps: [ ps.dvipng ])) ]; - input = builtins.toFile "postscript-sample.tex" '' - \documentclass{minimal} - \begin{document} - Ni - \special{ps: - newpath - 0 0 moveto - 7 7 rlineto - 0 7 moveto - 7 -7 rlineto - stroke - showpage - } - \end{document} - ''; - gs_trap = writeShellScript "gs_trap.sh" '' - exit 1 - ''; - } '' - cp "$gs_trap" ./gs - export PATH=$PWD:$PATH - # check that the trap works - gs && exit 1 - - cp "$input" ./document.tex - - latex document.tex - dvipng -T 1in,1in -strict -picky document.dvi - for f in document*.png; do - file "$f" | tee output - grep PNG output - done - - mkdir "$out" - mv document*.png "$out"/ - ''; + ghostscript = + runCommand "texlive-test-ghostscript" + { + nativeBuildInputs = [ + file + (texliveSmall.withPackages (ps: [ ps.dvipng ])) + ]; + input = builtins.toFile "postscript-sample.tex" '' + \documentclass{minimal} + \begin{document} + Ni + \special{ps: + newpath + 0 0 moveto + 7 7 rlineto + 0 7 moveto + 7 -7 rlineto + stroke + showpage + } + \end{document} + ''; + gs_trap = writeShellScript "gs_trap.sh" '' + exit 1 + ''; + } + '' + cp "$gs_trap" ./gs + export PATH=$PWD:$PATH + # check that the trap works + gs && exit 1 + + cp "$input" ./document.tex + + latex document.tex + dvipng -T 1in,1in -strict -picky document.dvi + for f in document*.png; do + file "$f" | tee output + grep PNG output + done + + mkdir "$out" + mv document*.png "$out"/ + ''; }; # https://github.com/NixOS/nixpkgs/issues/75070 - dvisvgm = runCommand "texlive-test-dvisvgm" { - nativeBuildInputs = [ file texliveMedium ]; - input = builtins.toFile "dvisvgm-sample.tex" '' - \documentclass{article} - \begin{document} - mwe - \end{document} - ''; - } '' - cp "$input" ./document.tex - - latex document.tex - dvisvgm document.dvi -n -o document_dvi.svg - cat document_dvi.svg - file document_dvi.svg | grep SVG - - pdflatex document.tex - dvisvgm -P document.pdf -n -o document_pdf.svg - cat document_pdf.svg - file document_pdf.svg | grep SVG - - mkdir "$out" - mv document*.svg "$out"/ - ''; - - texdoc = runCommand "texlive-test-texdoc" { - nativeBuildInputs = [ - (texlive.withPackages (ps: [ ps.luatex ps.texdoc ps.texdoc.texdoc ])) - ]; - } '' - texdoc --version - - texdoc --debug --list texdoc | tee "$out" - grep texdoc.pdf "$out" - ''; + dvisvgm = + runCommand "texlive-test-dvisvgm" + { + nativeBuildInputs = [ + file + texliveMedium + ]; + input = builtins.toFile "dvisvgm-sample.tex" '' + \documentclass{article} + \begin{document} + mwe + \end{document} + ''; + } + '' + cp "$input" ./document.tex + + latex document.tex + dvisvgm document.dvi -n -o document_dvi.svg + cat document_dvi.svg + file document_dvi.svg | grep SVG + + pdflatex document.tex + dvisvgm -P document.pdf -n -o document_pdf.svg + cat document_pdf.svg + file document_pdf.svg | grep SVG + + mkdir "$out" + mv document*.svg "$out"/ + ''; + + texdoc = + runCommand "texlive-test-texdoc" + { + nativeBuildInputs = [ + (texlive.withPackages (ps: [ + ps.luatex + ps.texdoc + ps.texdoc.texdoc + ])) + ]; + } + '' + texdoc --version + + texdoc --debug --list texdoc | tee "$out" + grep texdoc.pdf "$out" + ''; # check that the default language is US English defaultLanguage = lib.recurseIntoAttrs rec { @@ -235,7 +289,11 @@ rec { }; # check that all languages are available, including synonyms - allLanguages = let hyphenBase = texlive.pkgs.hyphen-base; texLive = texliveFull; in + allLanguages = + let + hyphenBase = texlive.pkgs.hyphen-base; + texLive = texliveFull; + in lib.recurseIntoAttrs { # language.def etex = mkTeXTest { @@ -309,57 +367,66 @@ rec { }; # test that language files are generated as expected - hyphen-base = runCommand "texlive-test-hyphen-base" { - hyphenBase = texlive.pkgs.hyphen-base; - schemeFull = texliveFull; - schemeInfraOnly = texliveInfraOnly; - } '' - mkdir -p "$out"/{scheme-infraonly,scheme-full} - - # create language files with no hyphenation patterns - cat "$hyphenBase"/tex/generic/config/language.us >language.dat - cat "$hyphenBase"/tex/generic/config/language.us.def >language.def - cat "$hyphenBase"/tex/generic/config/language.us.lua >language.dat.lua - - cat >>language.dat.lua <>language.def <language.dat + cat "$hyphenBase"/tex/generic/config/language.us.def >language.def + cat "$hyphenBase"/tex/generic/config/language.us.lua >language.dat.lua + + cat >>language.dat.lua <>language.def <&1 || true) | grep forbidden >/dev/null - (repstopdf --gscmd echo /dev/null 2>&1 || true) | grep forbidden >/dev/null - mkdir "$out" - ''; + repstopdf = + runCommand "texlive-test-repstopdf" + { + nativeBuildInputs = [ (texlive.withPackages (ps: [ ps.epstopdf ])) ]; + } + '' + ! (epstopdf --gscmd echo /dev/null 2>&1 || true) | grep forbidden >/dev/null + (repstopdf --gscmd echo /dev/null 2>&1 || true) | grep forbidden >/dev/null + mkdir "$out" + ''; # verify that the restricted mode gets enabled when # needed (detected by checking if it disallows --gscmd) - rpdfcrop = runCommand "texlive-test-rpdfcrop" { - nativeBuildInputs = [ (texlive.withPackages (ps: [ ps.pdfcrop ])) ]; - } '' - ! (pdfcrop --gscmd echo $(command -v pdfcrop) 2>&1 || true) | grep 'restricted mode' >/dev/null - (rpdfcrop --gscmd echo $(command -v pdfcrop) 2>&1 || true) | grep 'restricted mode' >/dev/null - mkdir "$out" - ''; + rpdfcrop = + runCommand "texlive-test-rpdfcrop" + { + nativeBuildInputs = [ (texlive.withPackages (ps: [ ps.pdfcrop ])) ]; + } + '' + ! (pdfcrop --gscmd echo $(command -v pdfcrop) 2>&1 || true) | grep 'restricted mode' >/dev/null + (rpdfcrop --gscmd echo $(command -v pdfcrop) 2>&1 || true) | grep 'restricted mode' >/dev/null + mkdir "$out" + ''; # check that all binaries run successfully, in the following sense: # (1) run --version, -v, --help, -h successfully; or @@ -367,7 +434,8 @@ rec { # (3) run successfully on a test.tex or similar file # we ignore the binaries that cannot be tested as above, and are either # compiled binaries or trivial shell wrappers - binaries = let + binaries = + let # TODO known broken binaries broken = [ # *.inc files in source container rather than run @@ -375,42 +443,190 @@ rec { # 'Error initialising QuantumRenderer: no suitable pipeline found' "tlcockpit" - ] ++ lib.optional stdenv.hostPlatform.isDarwin "epspdftk"; # wish shebang is a script, not a binary! + ] ++ lib.optional stdenv.hostPlatform.isDarwin "epspdftk"; # wish shebang is a script, not a binary! # (1) binaries requiring -v - shortVersion = [ "devnag" "diadia" "pmxchords" "ptex2pdf" "simpdftex" "ttf2afm" ]; + shortVersion = [ + "devnag" + "diadia" + "pmxchords" + "ptex2pdf" + "simpdftex" + "ttf2afm" + ]; # (1) binaries requiring --help or -h - help = [ "arlatex" "bundledoc" "cachepic" "checklistings" "dvipos" "extractres" "fig4latex" "fragmaster" - "kpsewhere" "latex-git-log" "ltxfileinfo" "mendex" "pdflatexpicscale" "perltex" "pn2pdf" "psbook" "psnup" "psresize" "purifyeps" - "simpdftex" "tex2xindy" "texluac" "texluajitc" "upmendex" "urlbst" "yplan" ]; - shortHelp = [ "adhocfilelist" "authorindex" "bbl2bib" "bibdoiadd" "bibmradd" "biburl2doi" "bibzbladd" "bookshelf-listallfonts" "bookshelf-mkfontsel" "ctanupload" - "disdvi" "dvibook" "dviconcat" "getmapdl" "latex2man" "listings-ext.sh" "pygmentex" ]; + help = [ + "arlatex" + "bundledoc" + "cachepic" + "checklistings" + "dvipos" + "extractres" + "fig4latex" + "fragmaster" + "kpsewhere" + "latex-git-log" + "ltxfileinfo" + "mendex" + "pdflatexpicscale" + "perltex" + "pn2pdf" + "psbook" + "psnup" + "psresize" + "purifyeps" + "simpdftex" + "tex2xindy" + "texluac" + "texluajitc" + "upmendex" + "urlbst" + "yplan" + ]; + shortHelp = [ + "adhocfilelist" + "authorindex" + "bbl2bib" + "bibdoiadd" + "bibmradd" + "biburl2doi" + "bibzbladd" + "bookshelf-listallfonts" + "bookshelf-mkfontsel" + "ctanupload" + "disdvi" + "dvibook" + "dviconcat" + "getmapdl" + "latex2man" + "listings-ext.sh" + "pygmentex" + ]; # (2) binaries that return non-zero exit code even if correctly asked for help - ignoreExitCode = [ "authorindex" "bookshelf-listallfonts" "bookshelf-mkfontsel" "dvibook" "dviconcat" "dvipos" "extractres" "fig4latex" "fragmaster" "latex2man" - "latex-git-log" "listings-ext.sh" "psbook" "psnup" "psresize" "purifyeps" "tex2xindy" "texluac" - "texluajitc" ]; + ignoreExitCode = [ + "authorindex" + "bookshelf-listallfonts" + "bookshelf-mkfontsel" + "dvibook" + "dviconcat" + "dvipos" + "extractres" + "fig4latex" + "fragmaster" + "latex2man" + "latex-git-log" + "listings-ext.sh" + "psbook" + "psnup" + "psresize" + "purifyeps" + "tex2xindy" + "texluac" + "texluajitc" + ]; # (2) binaries that print help on no argument, returning non-zero exit code - noArg = [ "a2ping" "bg5+latex" "bg5+pdflatex" "bg5latex" "bg5pdflatex" "cef5latex" "cef5pdflatex" "ceflatex" - "cefpdflatex" "cefslatex" "cefspdflatex" "chkdvifont" "dvi2fax" "dvired" "dviselect" "dvitodvi" "epsffit" - "findhyph" "gbklatex" "gbkpdflatex" "komkindex" "kpsepath" "listbib" "listings-ext" "mag" "mathspic" "mf2pt1" - "mk4ht" "mkt1font" "mkgrkindex" "musixflx" "pdf2ps" "pdfclose" "pdftosrc" "pdfxup" "pedigree" "pfb2pfa" "pk2bm" - "prepmx" "ps2pk" "psselect" "pstops" "rubibtex" "rubikrotation" "sjislatex" "sjispdflatex" "srcredact" "t4ht" - "teckit_compile" "tex4ht" "texdiff" "texdirflatten" "texplate" "tie" "ttf2kotexfont" "ttfdump" "vlna" "vpl2ovp" - "vpl2vpl" "yplan" ]; + noArg = [ + "a2ping" + "bg5+latex" + "bg5+pdflatex" + "bg5latex" + "bg5pdflatex" + "cef5latex" + "cef5pdflatex" + "ceflatex" + "cefpdflatex" + "cefslatex" + "cefspdflatex" + "chkdvifont" + "dvi2fax" + "dvired" + "dviselect" + "dvitodvi" + "epsffit" + "findhyph" + "gbklatex" + "gbkpdflatex" + "komkindex" + "kpsepath" + "listbib" + "listings-ext" + "mag" + "mathspic" + "mf2pt1" + "mk4ht" + "mkt1font" + "mkgrkindex" + "musixflx" + "pdf2ps" + "pdfclose" + "pdftosrc" + "pdfxup" + "pedigree" + "pfb2pfa" + "pk2bm" + "prepmx" + "ps2pk" + "psselect" + "pstops" + "rubibtex" + "rubikrotation" + "sjislatex" + "sjispdflatex" + "srcredact" + "t4ht" + "teckit_compile" + "tex4ht" + "texdiff" + "texdirflatten" + "texplate" + "tie" + "ttf2kotexfont" + "ttfdump" + "vlna" + "vpl2ovp" + "vpl2vpl" + "yplan" + ]; # (3) binaries requiring a .tex file contextTest = [ "htcontext" ]; - latexTest = [ "de-macro" "e2pall" "htlatex" "htxelatex" "makeindex" "pslatex" "rumakeindex" "tpic2pdftex" - "wordcount" "xhlatex" ]; - texTest = [ "fontinst" "htmex" "httex" "httexi" "htxetex" ]; + latexTest = [ + "de-macro" + "e2pall" + "htlatex" + "htxelatex" + "makeindex" + "pslatex" + "rumakeindex" + "tpic2pdftex" + "wordcount" + "xhlatex" + ]; + texTest = [ + "fontinst" + "htmex" + "httex" + "httexi" + "htxetex" + ]; # tricky binaries or scripts that are obviously working but are hard to test # (e.g. because they expect user input no matter the arguments) # (printafm comes from ghostscript, not texlive) ignored = [ # compiled binaries - "dt2dv" "dv2dt" "dvi2tty" "dvidvi" "dvispc" "otp2ocp" "outocp" "pmxab" + "dt2dv" + "dv2dt" + "dvi2tty" + "dvidvi" + "dvispc" + "otp2ocp" + "outocp" + "pmxab" # GUI scripts that accept no argument or crash without a graphics server; please test manualy - "epspdftk" "texdoctk" "tlshell" "xasy" + "epspdftk" + "texdoctk" + "tlshell" + "xasy" # requires Cinderella, not open source and not distributed via Nixpkgs "ketcindy" @@ -424,31 +640,89 @@ rec { "bibexport" # crossrefware: require bibtexperllibs under TEXMFROOT - "bbl2bib" "bibdoiadd" "bibmradd" "biburl2doi" "bibzbladd" "checkcites" "ltx2crossrefxml" + "bbl2bib" + "bibdoiadd" + "bibmradd" + "biburl2doi" + "bibzbladd" + "checkcites" + "ltx2crossrefxml" # epstopdf: requires kpsewhich - "epstopdf" "repstopdf" + "epstopdf" + "repstopdf" # requires kpsewhich - "memoize-extract.pl" "memoize-extract.py" + "memoize-extract.pl" + "memoize-extract.py" # require other texlive binaries in PATH - "allcm" "allec" "chkweb" "fontinst" "ht*" "installfont-tl" "kanji-config-updmap-sys" "kanji-config-updmap-user" - "kpse*" "latexfileversion" "mkocp" "mkofm" "mtxrunjit" "pdftex-quiet" "pslatex" "rumakeindex" "texconfig" - "texconfig-sys" "texexec" "texlinks" "texmfstart" "typeoutfileinfo" "wordcount" "xdvi" "xhlatex" + "allcm" + "allec" + "chkweb" + "fontinst" + "ht*" + "installfont-tl" + "kanji-config-updmap-sys" + "kanji-config-updmap-user" + "kpse*" + "latexfileversion" + "mkocp" + "mkofm" + "mtxrunjit" + "pdftex-quiet" + "pslatex" + "rumakeindex" + "texconfig" + "texconfig-sys" + "texexec" + "texlinks" + "texmfstart" + "typeoutfileinfo" + "wordcount" + "xdvi" + "xhlatex" # misc luatex binaries searching for luatex in PATH - "citeproc-lua" "context" "contextjit" "ctanbib" "digestif" "epspdf" "l3build" "luafindfont" "luaotfload-tool" - "luatools" "make4ht" "pmxchords" "tex4ebook" "texblend" "texdoc" "texfindpkg" "texlogsieve" "xindex" + "citeproc-lua" + "context" + "contextjit" + "ctanbib" + "digestif" + "epspdf" + "l3build" + "luafindfont" + "luaotfload-tool" + "luatools" + "make4ht" + "pmxchords" + "tex4ebook" + "texblend" + "texdoc" + "texfindpkg" + "texlogsieve" + "xindex" # requires full TEXMFROOT (e.g. for config) - "mktexfmt" "mktexmf" "mktexpk" "mktextfm" "psnup" "psresize" "pstops" "tlmgr" "updmap" "webquiz" + "mktexfmt" + "mktexmf" + "mktexpk" + "mktextfm" + "psnup" + "psresize" + "pstops" + "tlmgr" + "updmap" + "webquiz" # texlive-scripts: requires texlive.infra's TeXLive::TLUtils under TEXMFROOT - "fmtutil" "fmtutil-sys" "fmtutil-user" + "fmtutil" + "fmtutil-sys" + "fmtutil-user" # texlive-scripts: not used in nixpkgs, need updmap in PATH - "updmap-sys" "updmap-user" + "updmap-sys" + "updmap-user" ]; # simple test files @@ -470,11 +744,19 @@ rec { # link all binaries in single derivation binPackages = lib.catAttrs "out" (lib.attrValues texlive.pkgs); - binaries = buildEnv { name = "texlive-binaries"; paths = binPackages; }; + binaries = buildEnv { + name = "texlive-binaries"; + paths = binPackages; + }; in runCommand "texlive-test-binaries" { - inherit binaries contextTestTex latexTestTex texTestTex; + inherit + binaries + contextTestTex + latexTestTex + texTestTex + ; texliveScheme = texliveFull; } '' @@ -585,35 +867,34 @@ rec { ''; # check that all scripts have a Nix shebang - shebangs = let + shebangs = + let binPackages = lib.catAttrs "out" (lib.attrValues texlive.pkgs); in - runCommand "texlive-test-shebangs" { } - ('' + runCommand "texlive-test-shebangs" { } ( + '' echo "checking that all texlive scripts shebangs are in '$NIX_STORE'" declare -i scriptCount=0 invalidCount=0 - '' + - (lib.concatMapStrings - (pkg: '' - for bin in '${pkg.outPath}'/bin/* ; do - grep -I -q . "$bin" || continue # ignore binary files - [[ -x "$bin" ]] || continue # ignore non-executable files (such as context.lua) - scriptCount=$((scriptCount + 1)) - read -r cmdline < "$bin" - read -r interp <<< "$cmdline" - if [[ "$interp" != "#!$NIX_STORE"/* && "$interp" != "#! $NIX_STORE"/* ]] ; then - echo "error: non-nix shebang '$interp' in script '$bin'" - invalidCount=$((invalidCount + 1)) - fi - done - '') - binPackages) + '' + + (lib.concatMapStrings (pkg: '' + for bin in '${pkg.outPath}'/bin/* ; do + grep -I -q . "$bin" || continue # ignore binary files + [[ -x "$bin" ]] || continue # ignore non-executable files (such as context.lua) + scriptCount=$((scriptCount + 1)) + read -r cmdline < "$bin" + read -r interp <<< "$cmdline" + if [[ "$interp" != "#!$NIX_STORE"/* && "$interp" != "#! $NIX_STORE"/* ]] ; then + echo "error: non-nix shebang '$interp' in script '$bin'" + invalidCount=$((invalidCount + 1)) + fi + done + '') binPackages) + '' echo "checked $scriptCount scripts, found $invalidCount non-nix shebangs" [[ $invalidCount -gt 0 ]] && exit 1 mkdir -p "$out" '' - ); + ); # verify that the precomputed licensing information in default.nix # does indeed match the metadata of the individual packages. @@ -623,69 +904,78 @@ rec { # also builds a derivation, even though it is essentially an eval-time assertion. licenses = let - concatLicenses = builtins.foldl' (acc: el: if builtins.elem el acc then acc else acc ++ [ el ]); - # converts a license to its attribute name in lib.licenses - licenseToAttrName = license: - builtins.head (builtins.attrNames - (lib.filterAttrs (n: v: license == v) lib.licenses)); - lt = (a: b: a < b); - - savedLicenses = scheme: scheme.meta.license; - savedLicensesAttrNames = scheme: map licenseToAttrName (savedLicenses scheme); - - correctLicenses = scheme: builtins.foldl' - (acc: pkg: concatLicenses acc (lib.toList (pkg.meta.license or []))) - [] - scheme.passthru.requiredTeXPackages; - correctLicensesAttrNames = scheme: - lib.sort lt - (map licenseToAttrName (correctLicenses scheme)); - - hasLicenseMismatch = scheme: - (lib.isDerivation scheme) && - (savedLicensesAttrNames scheme) != (correctLicensesAttrNames scheme); - incorrectSchemes = lib.filterAttrs - (n: hasLicenseMismatch) - (texlive.combined // texlive.schemes); - prettyPrint = name: scheme: + concatLicenses = builtins.foldl' (acc: el: if builtins.elem el acc then acc else acc ++ [ el ]); + # converts a license to its attribute name in lib.licenses + licenseToAttrName = + license: builtins.head (builtins.attrNames (lib.filterAttrs (n: v: license == v) lib.licenses)); + lt = (a: b: a < b); + + savedLicenses = scheme: scheme.meta.license; + savedLicensesAttrNames = scheme: map licenseToAttrName (savedLicenses scheme); + + correctLicenses = + scheme: + builtins.foldl' ( + acc: pkg: concatLicenses acc (lib.toList (pkg.meta.license or [ ])) + ) [ ] scheme.passthru.requiredTeXPackages; + correctLicensesAttrNames = scheme: lib.sort lt (map licenseToAttrName (correctLicenses scheme)); + + hasLicenseMismatch = + scheme: + (lib.isDerivation scheme) && (savedLicensesAttrNames scheme) != (correctLicensesAttrNames scheme); + incorrectSchemes = lib.filterAttrs (n: hasLicenseMismatch) (texlive.combined // texlive.schemes); + prettyPrint = name: scheme: '' + license info for ${name} is incorrect! Note that order is enforced. + saved: [ ${lib.concatStringsSep " " (savedLicensesAttrNames scheme)} ] + correct: [ ${lib.concatStringsSep " " (correctLicensesAttrNames scheme)} ] + ''; + errorText = lib.concatStringsSep "\n\n" (lib.mapAttrsToList prettyPrint incorrectSchemes); + in + runCommand "texlive-test-license" + { + inherit errorText; + } + ( + if (incorrectSchemes == { }) then + "echo everything is fine! > $out" + else '' - license info for ${name} is incorrect! Note that order is enforced. - saved: [ ${lib.concatStringsSep " " (savedLicensesAttrNames scheme)} ] - correct: [ ${lib.concatStringsSep " " (correctLicensesAttrNames scheme)} ] - ''; - errorText = lib.concatStringsSep "\n\n" (lib.mapAttrsToList prettyPrint incorrectSchemes); - in - runCommand "texlive-test-license" { - inherit errorText; - } - (if (incorrectSchemes == {}) - then "echo everything is fine! > $out" - else '' - echo "$errorText" - false - ''); + echo "$errorText" + false + '' + ); # verify that all fixed hashes are present # this is effectively an eval-time assertion, converted into a derivation for # ease of testing - fixedHashes = let - fods = lib.concatMap - (p: lib.optional (p ? tex && lib.isDerivation p.tex) p.tex + fixedHashes = + let + fods = lib.concatMap ( + p: + lib.optional (p ? tex && lib.isDerivation p.tex) p.tex ++ lib.optional (p ? texdoc) p.texdoc ++ lib.optional (p ? texsource) p.texsource - ++ lib.optional (p ? tlpkg) p.tlpkg) - (lib.attrValues texlive.pkgs); - errorText = lib.concatMapStrings (p: lib.optionalString (! p ? outputHash) "${p.pname}-${p.tlOutputName} does not have a fixed output hash\n") fods; - in runCommand "texlive-test-fixed-hashes" { - inherit errorText; - passAsFile = [ "errorText" ]; - } '' - if [[ -s "$errorTextPath" ]] ; then - cat "$errorTextPath" - echo Failed: some TeX Live packages do not have fixed output hashes. Please read UPGRADING.md for how to generate a new fixed-hashes.nix. - exit 1 - else - touch "$out" - fi - ''; + ++ lib.optional (p ? tlpkg) p.tlpkg + ) (lib.attrValues texlive.pkgs); + errorText = lib.concatMapStrings ( + p: + lib.optionalString ( + !p ? outputHash + ) "${p.pname}-${p.tlOutputName} does not have a fixed output hash\n" + ) fods; + in + runCommand "texlive-test-fixed-hashes" + { + inherit errorText; + passAsFile = [ "errorText" ]; + } + '' + if [[ -s "$errorTextPath" ]] ; then + cat "$errorTextPath" + echo Failed: some TeX Live packages do not have fixed output hashes. Please read UPGRADING.md for how to generate a new fixed-hashes.nix. + exit 1 + else + touch "$out" + fi + ''; } diff --git a/pkgs/test/vim/default.nix b/pkgs/test/vim/default.nix index 5a3bf376fb8846..eb76745d038e1e 100644 --- a/pkgs/test/vim/default.nix +++ b/pkgs/test/vim/default.nix @@ -1,12 +1,20 @@ -{ vimUtils, vim-full, vimPlugins, pkgs }: +{ + vimUtils, + vim-full, + vimPlugins, + pkgs, +}: let inherit (vimUtils) buildVimPlugin; packages.myVimPackage.start = with vimPlugins; [ vim-nix ]; in - pkgs.recurseIntoAttrs (rec { - vim_empty_config = vimUtils.vimrcFile { beforePlugins = ""; customRC = ""; }; +pkgs.recurseIntoAttrs (rec { + vim_empty_config = vimUtils.vimrcFile { + beforePlugins = ""; + customRC = ""; + }; ### vim tests ################## diff --git a/pkgs/tools/X11/bumblebee/default.nix b/pkgs/tools/X11/bumblebee/default.nix index 01aaeca044deb7..50c9209288e185 100644 --- a/pkgs/tools/X11/bumblebee/default.nix +++ b/pkgs/tools/X11/bumblebee/default.nix @@ -16,33 +16,56 @@ # # To use at startup, see hardware.bumblebee options. -{ stdenv, lib, fetchurl, fetchpatch, pkg-config, help2man, makeWrapper -, glib, libbsd -, libX11, xorgserver, kmod, xf86videonouveau -, nvidia_x11, virtualgl, libglvnd -, automake111x, autoconf -# The below should only be non-null in a x86_64 system. On a i686 -# system the above nvidia_x11 and virtualgl will be the i686 packages. -# TODO: Confusing. Perhaps use "SubArch" instead of i686? -, nvidia_x11_i686 ? null -, libglvnd_i686 ? null -, useDisplayDevice ? false -, extraNvidiaDeviceOptions ? "" -, extraNouveauDeviceOptions ? "" -, useNvidia ? true +{ + stdenv, + lib, + fetchurl, + fetchpatch, + pkg-config, + help2man, + makeWrapper, + glib, + libbsd, + libX11, + xorgserver, + kmod, + xf86videonouveau, + nvidia_x11, + virtualgl, + libglvnd, + automake111x, + autoconf, + # The below should only be non-null in a x86_64 system. On a i686 + # system the above nvidia_x11 and virtualgl will be the i686 packages. + # TODO: Confusing. Perhaps use "SubArch" instead of i686? + nvidia_x11_i686 ? null, + libglvnd_i686 ? null, + useDisplayDevice ? false, + extraNvidiaDeviceOptions ? "", + extraNouveauDeviceOptions ? "", + useNvidia ? true, }: let - nvidia_x11s = [ nvidia_x11 ] - ++ lib.optional nvidia_x11.useGLVND libglvnd - ++ lib.optionals (nvidia_x11_i686 != null) - ([ nvidia_x11_i686 ] ++ lib.optional nvidia_x11_i686.useGLVND libglvnd_i686); + nvidia_x11s = + [ nvidia_x11 ] + ++ lib.optional nvidia_x11.useGLVND libglvnd + ++ lib.optionals (nvidia_x11_i686 != null) ( + [ nvidia_x11_i686 ] ++ lib.optional nvidia_x11_i686.useGLVND libglvnd_i686 + ); nvidiaLibs = lib.makeLibraryPath nvidia_x11s; - bbdPath = lib.makeBinPath [ kmod xorgserver ]; + bbdPath = lib.makeBinPath [ + kmod + xorgserver + ]; - xmodules = lib.concatStringsSep "," (map (x: "${x.out or x}/lib/xorg/modules") ([ xorgserver ] ++ lib.optional (!useNvidia) xf86videonouveau)); + xmodules = lib.concatStringsSep "," ( + map (x: "${x.out or x}/lib/xorg/modules") ( + [ xorgserver ] ++ lib.optional (!useNvidia) xf86videonouveau + ) + ); modprobePatch = fetchpatch { url = "https://github.com/Bumblebee-Project/Bumblebee/commit/1ada79fe5916961fc4e4917f8c63bb184908d986.patch"; @@ -57,7 +80,8 @@ let hash = "sha256-3b5tLoMrGYSdg9Hz5bh0c44VIrbSZrY56JpWEyU/Pik="; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "bumblebee"; version = "3.2.1"; @@ -75,11 +99,13 @@ in stdenv.mkDerivation rec { ]; # By default we don't want to use a display device - nvidiaDeviceOptions = lib.optionalString (!useDisplayDevice) '' - # Disable display device - Option "UseEDID" "false" - Option "UseDisplayDevice" "none" - '' + extraNvidiaDeviceOptions; + nvidiaDeviceOptions = + lib.optionalString (!useDisplayDevice) '' + # Disable display device + Option "UseEDID" "false" + Option "UseDisplayDevice" "none" + '' + + extraNvidiaDeviceOptions; nouveauDeviceOptions = extraNouveauDeviceOptions; @@ -105,8 +131,19 @@ in stdenv.mkDerivation rec { # Build-time dependencies of bumblebeed and optirun. # Note that it has several runtime dependencies. - buildInputs = [ libX11 glib libbsd kmod ]; - nativeBuildInputs = [ makeWrapper pkg-config help2man automake111x autoconf ]; + buildInputs = [ + libX11 + glib + libbsd + kmod + ]; + nativeBuildInputs = [ + makeWrapper + pkg-config + help2man + automake111x + autoconf + ]; # The order of LDPATH is very specific: First X11 then the host # environment then the optional sub architecture paths. @@ -115,14 +152,16 @@ in stdenv.mkDerivation rec { # includes the acceleration driver. As this is used for the X11 # server, which runs under the host architecture, this does not # include the sub architecture components. - configureFlags = [ - "--with-udev-rules=$out/lib/udev/rules.d" - # see #10282 - #"CONF_PRIMUS_LD_PATH=${primusLibs}" - ] ++ lib.optionals useNvidia [ - "CONF_LDPATH_NVIDIA=${nvidiaLibs}" - "CONF_MODPATH_NVIDIA=${nvidia_x11.bin}/lib/xorg/modules" - ]; + configureFlags = + [ + "--with-udev-rules=$out/lib/udev/rules.d" + # see #10282 + #"CONF_PRIMUS_LD_PATH=${primusLibs}" + ] + ++ lib.optionals useNvidia [ + "CONF_LDPATH_NVIDIA=${nvidiaLibs}" + "CONF_MODPATH_NVIDIA=${nvidia_x11.bin}/lib/xorg/modules" + ]; CFLAGS = [ "-DX_MODULE_APPENDS=\\\"${xmodules}\\\"" diff --git a/pkgs/tools/X11/kdocker/default.nix b/pkgs/tools/X11/kdocker/default.nix index 70b183aef58ead..01c3b246f91fd1 100644 --- a/pkgs/tools/X11/kdocker/default.nix +++ b/pkgs/tools/X11/kdocker/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, fetchFromGitHub -, qmake -, wrapQtAppsHook -, libX11 -, libXmu -, libXpm -, qtbase -, qtx11extras +{ + stdenv, + lib, + fetchFromGitHub, + qmake, + wrapQtAppsHook, + libX11, + libXmu, + libXpm, + qtbase, + qtx11extras, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/tools/X11/libstrangle/default.nix b/pkgs/tools/X11/libstrangle/default.nix index f7deb69561e938..bf6a529848c016 100644 --- a/pkgs/tools/X11/libstrangle/default.nix +++ b/pkgs/tools/X11/libstrangle/default.nix @@ -1,10 +1,20 @@ -{ lib, stdenv, fetchFromGitLab, fetchpatch, libGL, libX11 }: +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + libGL, + libX11, +}: stdenv.mkDerivation rec { pname = "libstrangle"; version = "unstable-202202022"; - buildInputs = [ libGL libX11 ]; + buildInputs = [ + libGL + libX11 + ]; src = fetchFromGitLab { owner = "torkel104"; @@ -13,7 +23,10 @@ stdenv.mkDerivation rec { hash = "sha256-h10QA7m7hIQHq1g/vCYuZsFR2NVbtWBB46V6OWP5wgM="; }; - makeFlags = [ "prefix=" "DESTDIR=$(out)" ]; + makeFlags = [ + "prefix=" + "DESTDIR=$(out)" + ]; patches = [ ./nixos.patch diff --git a/pkgs/tools/X11/primus/default.nix b/pkgs/tools/X11/primus/default.nix index eb8aa042e7b02f..1f4964e3aa3add 100644 --- a/pkgs/tools/X11/primus/default.nix +++ b/pkgs/tools/X11/primus/default.nix @@ -3,14 +3,15 @@ # Using steam under wine can involve both 32bit and 64bit process. All of which inherit the # same LD_LIBRARY_PATH. # Other distributions do the same. -{ stdenv -, stdenv_i686 -, lib -, primusLib -, writeScriptBin -, runtimeShell -, primusLib_i686 ? null -, useNvidia ? true +{ + stdenv, + stdenv_i686, + lib, + primusLib, + writeScriptBin, + runtimeShell, + primusLib_i686 ? null, + useNvidia ? true, }: let @@ -19,13 +20,23 @@ let primusLib_i686_ = primusLib_i686.override { stdenv = stdenv_i686; }; primus = if useNvidia then primusLib_ else primusLib_.override { nvidia_x11 = null; }; - primus_i686 = if useNvidia then primusLib_i686_ else primusLib_i686_.override { nvidia_x11 = null; }; - ldPath = lib.makeLibraryPath (lib.filter (x: x != null) ( - [ primus primus.glvnd ] - ++ lib.optionals (primusLib_i686 != null) [ primus_i686 primus_i686.glvnd ] - )); + primus_i686 = + if useNvidia then primusLib_i686_ else primusLib_i686_.override { nvidia_x11 = null; }; + ldPath = lib.makeLibraryPath ( + lib.filter (x: x != null) ( + [ + primus + primus.glvnd + ] + ++ lib.optionals (primusLib_i686 != null) [ + primus_i686 + primus_i686.glvnd + ] + ) + ); -in writeScriptBin "primusrun" '' +in +writeScriptBin "primusrun" '' #!${runtimeShell} export LD_LIBRARY_PATH=${ldPath}''${LD_LIBRARY_PATH:+:}$LD_LIBRARY_PATH # https://bugs.launchpad.net/ubuntu/+source/bumblebee/+bug/1758243 diff --git a/pkgs/tools/X11/primus/lib.nix b/pkgs/tools/X11/primus/lib.nix index 43e0a8233fd0b8..7e6572f66a9a53 100644 --- a/pkgs/tools/X11/primus/lib.nix +++ b/pkgs/tools/X11/primus/lib.nix @@ -1,19 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, libX11 -, libGL -, mesa -, nvidia_x11 ? null -, libglvnd +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + libX11, + libGL, + mesa, + nvidia_x11 ? null, + libglvnd, }: let aPackage = - if nvidia_x11 == null then libGL - else if nvidia_x11.useGLVND then libglvnd - else nvidia_x11; + if nvidia_x11 == null then + libGL + else if nvidia_x11.useGLVND then + libglvnd + else + nvidia_x11; in stdenv.mkDerivation { @@ -35,7 +39,10 @@ stdenv.mkDerivation { }) ]; - buildInputs = [ libX11 libGL ]; + buildInputs = [ + libX11 + libGL + ]; makeFlags = [ "LIBDIR=$(out)/lib" @@ -53,7 +60,10 @@ stdenv.mkDerivation { meta = with lib; { description = "Low-overhead client-side GPU offloading"; homepage = "https://github.com/amonakov/primus"; - platforms = [ "i686-linux" "x86_64-linux" ]; + platforms = [ + "i686-linux" + "x86_64-linux" + ]; license = licenses.bsd2; maintainers = with maintainers; [ abbradar ]; }; diff --git a/pkgs/tools/X11/virtualgl/default.nix b/pkgs/tools/X11/virtualgl/default.nix index 05c0f1c69b4079..4736c645d8f31c 100644 --- a/pkgs/tools/X11/virtualgl/default.nix +++ b/pkgs/tools/X11/virtualgl/default.nix @@ -1,6 +1,8 @@ -{ stdenv, lib -, virtualglLib -, virtualglLib_i686 ? null +{ + stdenv, + lib, + virtualglLib, + virtualglLib_i686 ? null, }: stdenv.mkDerivation { @@ -9,14 +11,16 @@ stdenv.mkDerivation { paths = [ virtualglLib ]; - buildCommand = '' - mkdir -p $out/bin - for i in ${virtualglLib}/bin/* ${virtualglLib}/bin/.vglrun*; do - ln -s "$i" $out/bin - done - '' + lib.optionalString (virtualglLib_i686 != null) '' - ln -sf ${virtualglLib_i686}/bin/.vglrun.vars32 $out/bin - ''; + buildCommand = + '' + mkdir -p $out/bin + for i in ${virtualglLib}/bin/* ${virtualglLib}/bin/.vglrun*; do + ln -s "$i" $out/bin + done + '' + + lib.optionalString (virtualglLib_i686 != null) '' + ln -sf ${virtualglLib_i686}/bin/.vglrun.vars32 $out/bin + ''; meta = { platforms = lib.platforms.linux; diff --git a/pkgs/tools/X11/virtualgl/lib.nix b/pkgs/tools/X11/virtualgl/lib.nix index a0f2741edd7887..6a3a2c6637b621 100644 --- a/pkgs/tools/X11/virtualgl/lib.nix +++ b/pkgs/tools/X11/virtualgl/lib.nix @@ -1,7 +1,19 @@ -{ lib, stdenv, fetchurl, cmake -, libGL, libGLU, libXv, libXtst, libXi, libjpeg_turbo, fltk -, xorg -, opencl-headers, opencl-clhpp, ocl-icd +{ + lib, + stdenv, + fetchurl, + cmake, + libGL, + libGLU, + libXv, + libXtst, + libXi, + libjpeg_turbo, + fltk, + xorg, + opencl-headers, + opencl-clhpp, + ocl-icd, }: stdenv.mkDerivation rec { @@ -20,15 +32,27 @@ stdenv.mkDerivation rec { mv server/CMakeLists2.txt server/CMakeLists.txt ''; - cmakeFlags = [ "-DVGL_SYSTEMFLTK=1" "-DTJPEG_LIBRARY=${libjpeg_turbo.out}/lib/libturbojpeg.so" ]; + cmakeFlags = [ + "-DVGL_SYSTEMFLTK=1" + "-DTJPEG_LIBRARY=${libjpeg_turbo.out}/lib/libturbojpeg.so" + ]; makeFlags = [ "PREFIX=$(out)" ]; nativeBuildInputs = [ cmake ]; - buildInputs = [ libjpeg_turbo libGL libGLU fltk - libXv libXtst libXi xorg.xcbutilkeysyms - opencl-headers opencl-clhpp ocl-icd + buildInputs = [ + libjpeg_turbo + libGL + libGLU + fltk + libXv + libXtst + libXi + xorg.xcbutilkeysyms + opencl-headers + opencl-clhpp + ocl-icd ]; fixupPhase = '' diff --git a/pkgs/tools/X11/xbindkeys-config/default.nix b/pkgs/tools/X11/xbindkeys-config/default.nix index 8a5c07ef96ecd5..660c1e2c884366 100644 --- a/pkgs/tools/X11/xbindkeys-config/default.nix +++ b/pkgs/tools/X11/xbindkeys-config/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, gtk, pkg-config, procps, makeWrapper, ... }: +{ + lib, + stdenv, + fetchurl, + gtk, + pkg-config, + procps, + makeWrapper, + ... +}: stdenv.mkDerivation rec { pname = "xbindkeys-config"; @@ -8,7 +17,10 @@ stdenv.mkDerivation rec { # gcc-10. env.NIX_CFLAGS_COMPILE = "-fcommon"; - nativeBuildInputs = [ pkg-config makeWrapper ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; buildInputs = [ gtk ]; src = fetchurl { @@ -22,7 +34,7 @@ stdenv.mkDerivation rec { homepage = "https://packages.debian.org/source/xbindkeys-config"; description = "Graphical interface for configuring xbindkeys"; license = lib.licenses.gpl2Plus; - maintainers = with lib.maintainers; [benley]; + maintainers = with lib.maintainers; [ benley ]; platforms = with lib.platforms; linux; mainProgram = "xbindkeys-config"; }; diff --git a/pkgs/tools/X11/xdragon/default.nix b/pkgs/tools/X11/xdragon/default.nix index 9f12a78e29361c..babdb75224cb8a 100644 --- a/pkgs/tools/X11/xdragon/default.nix +++ b/pkgs/tools/X11/xdragon/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, gtk3 }: +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + gtk3, +}: stdenv.mkDerivation (finalAttrs: { pname = "xdragon"; diff --git a/pkgs/tools/X11/xidlehook/default.nix b/pkgs/tools/X11/xidlehook/default.nix index 6c7aa89e01d3b3..c2a209d7f513f3 100644 --- a/pkgs/tools/X11/xidlehook/default.nix +++ b/pkgs/tools/X11/xidlehook/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitLab -, python3 -, xorg -, libpulseaudio -, pkg-config -, patchelf -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitLab, + python3, + xorg, + libpulseaudio, + pkg-config, + patchelf, + Security, }: rustPlatform.buildRustPackage rec { @@ -26,8 +27,16 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-uroO0PgnCkFRNYAZgdTZWgDDbBqq1ZM+dni/A2Qw9fg="; - buildInputs = [ xorg.libX11 xorg.libXScrnSaver libpulseaudio ] ++ lib.optional stdenv.hostPlatform.isDarwin Security; - nativeBuildInputs = [ pkg-config patchelf python3 ]; + buildInputs = [ + xorg.libX11 + xorg.libXScrnSaver + libpulseaudio + ] ++ lib.optional stdenv.hostPlatform.isDarwin Security; + nativeBuildInputs = [ + pkg-config + patchelf + python3 + ]; buildNoDefaultFeatures = !stdenv.hostPlatform.isLinux; buildFeatures = lib.optional (!stdenv.hostPlatform.isLinux) "pulse"; diff --git a/pkgs/tools/X11/xpra/default.nix b/pkgs/tools/X11/xpra/default.nix index 324fe3aeeb3046..a46532a9206f2f 100644 --- a/pkgs/tools/X11/xpra/default.nix +++ b/pkgs/tools/X11/xpra/default.nix @@ -1,43 +1,44 @@ -{ lib -, fetchFromGitHub -, pkg-config -, runCommand -, writeText -, wrapGAppsHook3 -, withNvenc ? false -, atk -, cairo -, cudatoolkit -, ffmpeg -, gdk-pixbuf -, getopt -, glib -, gobject-introspection -, gst_all_1 -, gtk3 -, libappindicator -, libfakeXinerama -, librsvg -, libvpx -, libwebp -, lz4 -, nv-codec-headers-10 -, nvidia_x11 ? null -, pam -, pandoc -, pango -, pulseaudio -, python3 -, stdenv -, util-linux -, which -, x264 -, x265 -, xauth -, xdg-utils -, xorg -, xorgserver -, xxHash +{ + lib, + fetchFromGitHub, + pkg-config, + runCommand, + writeText, + wrapGAppsHook3, + withNvenc ? false, + atk, + cairo, + cudatoolkit, + ffmpeg, + gdk-pixbuf, + getopt, + glib, + gobject-introspection, + gst_all_1, + gtk3, + libappindicator, + libfakeXinerama, + librsvg, + libvpx, + libwebp, + lz4, + nv-codec-headers-10, + nvidia_x11 ? null, + pam, + pandoc, + pango, + pulseaudio, + python3, + stdenv, + util-linux, + which, + x264, + x265, + xauth, + xdg-utils, + xorg, + xorgserver, + xxHash, }: let @@ -61,14 +62,18 @@ let EndSection ''; - nvencHeaders = runCommand "nvenc-headers" { - inherit nvidia_x11; - } '' - mkdir -p $out/include $out/lib/pkgconfig - cp ${nv-codec-headers-10}/include/ffnvcodec/nvEncodeAPI.h $out/include - substituteAll ${./nvenc.pc} $out/lib/pkgconfig/nvenc.pc - ''; -in buildPythonApplication rec { + nvencHeaders = + runCommand "nvenc-headers" + { + inherit nvidia_x11; + } + '' + mkdir -p $out/include $out/lib/pkgconfig + cp ${nv-codec-headers-10}/include/ffnvcodec/nvEncodeAPI.h $out/include + substituteAll ${./nvenc.pc} $out/lib/pkgconfig/nvenc.pc + ''; +in +buildPythonApplication rec { pname = "xpra"; version = "6.2.1"; @@ -80,7 +85,7 @@ in buildPythonApplication rec { }; patches = [ - ./fix-41106.patch # https://github.com/NixOS/nixpkgs/issues/41106 + ./fix-41106.patch # https://github.com/NixOS/nixpkgs/issues/41106 ./fix-122159.patch # https://github.com/NixOS/nixpkgs/issues/122159 ]; @@ -98,70 +103,80 @@ in buildPythonApplication rec { pandoc ] ++ lib.optional withNvenc cudatoolkit; - buildInputs = with xorg; [ - libX11 - libXcomposite - libXdamage - libXfixes - libXi - libxkbfile - libXrandr - libXrender - libXres - libXtst - xorgproto - ] ++ (with gst_all_1; [ - gst-libav - gst-plugins-bad - gst-plugins-base - gst-plugins-good - gstreamer - ]) ++ [ - atk.out - cairo - cython - ffmpeg - gdk-pixbuf - glib - gtk3 - libappindicator - librsvg - libvpx - libwebp - lz4 - pam - pango - x264 - x265 - xxHash - ] ++ lib.optional withNvenc nvencHeaders; - - propagatedBuildInputs = with python3.pkgs; ([ - cryptography - dbus-python - gst-python - idna - lz4 - netifaces - numpy - opencv4 - pam - paramiko - pillow - pycairo - pycrypto - pycups - pygobject3 - pyinotify - pyopengl - python-uinput - pyxdg - rencode - invoke - ] ++ lib.optionals withNvenc [ - pycuda - pynvml - ]); + buildInputs = + with xorg; + [ + libX11 + libXcomposite + libXdamage + libXfixes + libXi + libxkbfile + libXrandr + libXrender + libXres + libXtst + xorgproto + ] + ++ (with gst_all_1; [ + gst-libav + gst-plugins-bad + gst-plugins-base + gst-plugins-good + gstreamer + ]) + ++ [ + atk.out + cairo + cython + ffmpeg + gdk-pixbuf + glib + gtk3 + libappindicator + librsvg + libvpx + libwebp + lz4 + pam + pango + x264 + x265 + xxHash + ] + ++ lib.optional withNvenc nvencHeaders; + + propagatedBuildInputs = + with python3.pkgs; + ( + [ + cryptography + dbus-python + gst-python + idna + lz4 + netifaces + numpy + opencv4 + pam + paramiko + pillow + pycairo + pycrypto + pycups + pygobject3 + pyinotify + pyopengl + python-uinput + pyxdg + rencode + invoke + ] + ++ lib.optionals withNvenc [ + pycuda + pynvml + ] + ); # error: 'import_cairo' defined but not used env.NIX_CFLAGS_COMPILE = "-Wno-error=unused-function"; @@ -178,20 +193,32 @@ in buildPythonApplication rec { dontWrapGApps = true; - preFixup = '' - makeWrapperArgs+=( - "''${gappsWrapperArgs[@]}" - --set XPRA_INSTALL_PREFIX "$out" - --set XPRA_COMMAND "$out/bin/xpra" - --set XPRA_XKB_CONFIG_ROOT "${xorg.xkeyboardconfig}/share/X11/xkb" - --set XORG_CONFIG_PREFIX "" - --prefix LD_LIBRARY_PATH : ${libfakeXinerama}/lib - --prefix PATH : ${lib.makeBinPath [ getopt xorgserver xauth which util-linux pulseaudio ]} - '' + lib.optionalString withNvenc '' + preFixup = + '' + makeWrapperArgs+=( + "''${gappsWrapperArgs[@]}" + --set XPRA_INSTALL_PREFIX "$out" + --set XPRA_COMMAND "$out/bin/xpra" + --set XPRA_XKB_CONFIG_ROOT "${xorg.xkeyboardconfig}/share/X11/xkb" + --set XORG_CONFIG_PREFIX "" + --prefix LD_LIBRARY_PATH : ${libfakeXinerama}/lib + --prefix PATH : ${ + lib.makeBinPath [ + getopt + xorgserver + xauth + which + util-linux + pulseaudio + ] + } + '' + + lib.optionalString withNvenc '' --prefix LD_LIBRARY_PATH : ${nvidia_x11}/lib - '' + '' - ) - ''; + '' + + '' + ) + ''; postInstall = '' # append module paths to xorg.conf @@ -220,6 +247,10 @@ in buildPythonApplication rec { changelog = "https://github.com/Xpra-org/xpra/releases/tag/v${version}"; platforms = platforms.linux; license = licenses.gpl2Only; - maintainers = with maintainers; [ offline numinit mvnetbiz ]; + maintainers = with maintainers; [ + offline + numinit + mvnetbiz + ]; }; } diff --git a/pkgs/tools/X11/xpra/libfakeXinerama.nix b/pkgs/tools/X11/xpra/libfakeXinerama.nix index 4ec1f7f4370d82..2b533c1aaccaec 100644 --- a/pkgs/tools/X11/xpra/libfakeXinerama.nix +++ b/pkgs/tools/X11/xpra/libfakeXinerama.nix @@ -1,6 +1,12 @@ -{ lib, stdenv, fetchurl, libX11, libXinerama }: - -stdenv.mkDerivation rec { +{ + lib, + stdenv, + fetchurl, + libX11, + libXinerama, +}: + +stdenv.mkDerivation rec { pname = "libfakeXinerama"; version = "0.1.0"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "0gxb8jska2anbb3c1m8asbglgnwylgdr44x9lr8yh91hjxsqadkx"; }; - buildInputs = [ libX11 libXinerama ]; + buildInputs = [ + libX11 + libXinerama + ]; buildPhase = '' runHook preBuild diff --git a/pkgs/tools/admin/ansible/doctor.nix b/pkgs/tools/admin/ansible/doctor.nix index e6a370c46f9090..31468f7e9ffae1 100644 --- a/pkgs/tools/admin/ansible/doctor.nix +++ b/pkgs/tools/admin/ansible/doctor.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, python3 +{ + lib, + fetchFromGitHub, + fetchpatch, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/tools/admin/ansible/later.nix b/pkgs/tools/admin/ansible/later.nix index dadd182d8ce2d6..aec0c0b802043c 100644 --- a/pkgs/tools/admin/ansible/later.nix +++ b/pkgs/tools/admin/ansible/later.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, python3 +{ + lib, + fetchFromGitHub, + fetchpatch, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/tools/admin/ansible/lint.nix b/pkgs/tools/admin/ansible/lint.nix index 0e2757d548e8ff..77127afd093a2a 100644 --- a/pkgs/tools/admin/ansible/lint.nix +++ b/pkgs/tools/admin/ansible/lint.nix @@ -1,7 +1,8 @@ -{ lib -, python3 -, fetchPypi -, ansible +{ + lib, + python3, + fetchPypi, + ansible, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/tools/admin/aws-mfa/default.nix b/pkgs/tools/admin/aws-mfa/default.nix index 67ebd255c39786..69b2a5a566228b 100644 --- a/pkgs/tools/admin/aws-mfa/default.nix +++ b/pkgs/tools/admin/aws-mfa/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, fetchpatch -, setuptools -, boto3 +{ + lib, + buildPythonApplication, + fetchFromGitHub, + fetchpatch, + setuptools, + boto3, }: buildPythonApplication rec { diff --git a/pkgs/tools/admin/awsume/default.nix b/pkgs/tools/admin/awsume/default.nix index 42de084b7cdba7..d8b11d58394808 100644 --- a/pkgs/tools/admin/awsume/default.nix +++ b/pkgs/tools/admin/awsume/default.nix @@ -1,13 +1,14 @@ -{ lib -, python3 -, installShellFiles -, buildPythonApplication -, fetchFromGitHub -, boto3 -, colorama -, psutil -, pluggy -, pyyaml +{ + lib, + python3, + installShellFiles, + buildPythonApplication, + fetchFromGitHub, + boto3, + colorama, + psutil, + pluggy, + pyyaml, }: buildPythonApplication rec { @@ -47,7 +48,6 @@ buildPythonApplication rec { rm -f $out/bin/awsume.bat ''; - doCheck = false; meta = with lib; { diff --git a/pkgs/tools/admin/cdist/default.nix b/pkgs/tools/admin/cdist/default.nix index a84eeb4a1a27ef..d15ce58e056644 100644 --- a/pkgs/tools/admin/cdist/default.nix +++ b/pkgs/tools/admin/cdist/default.nix @@ -1,15 +1,20 @@ -{ lib -, buildPythonApplication -, fetchFromGitea -, six -, sphinxHook -, sphinx-rtd-theme +{ + lib, + buildPythonApplication, + fetchFromGitea, + six, + sphinxHook, + sphinx-rtd-theme, }: buildPythonApplication rec { pname = "cdist"; version = "7.0.0"; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; src = fetchFromGitea { domain = "code.ungleich.ch"; diff --git a/pkgs/tools/admin/coldsnap/default.nix b/pkgs/tools/admin/coldsnap/default.nix index cebf69b70a6a6e..d6bff3a6ae67a0 100644 --- a/pkgs/tools/admin/coldsnap/default.nix +++ b/pkgs/tools/admin/coldsnap/default.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, openssl -, pkg-config +{ + lib, + rustPlatform, + fetchFromGitHub, + openssl, + pkg-config, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/tools/admin/drawterm/default.nix b/pkgs/tools/admin/drawterm/default.nix index d670c28539ca4e..0ea9ab1a1b751d 100644 --- a/pkgs/tools/admin/drawterm/default.nix +++ b/pkgs/tools/admin/drawterm/default.nix @@ -1,20 +1,21 @@ -{ stdenv -, lib -, fetchFrom9Front -, unstableGitUpdater -, installShellFiles -, makeWrapper -, xorg -, pkg-config -, wayland-scanner -, pipewire -, wayland -, wayland-protocols -, libxkbcommon -, wlr-protocols -, pulseaudio -, config -, nixosTests +{ + stdenv, + lib, + fetchFrom9Front, + unstableGitUpdater, + installShellFiles, + makeWrapper, + xorg, + pkg-config, + wayland-scanner, + pipewire, + wayland, + wayland-protocols, + libxkbcommon, + wlr-protocols, + pulseaudio, + config, + nixosTests, }: stdenv.mkDerivation { @@ -30,32 +31,52 @@ stdenv.mkDerivation { enableParallelBuilding = true; strictDeps = true; - nativeBuildInputs = [ installShellFiles ] ++ { - linux = [ pkg-config wayland-scanner ]; - unix = [ makeWrapper ]; - }."${config}" or (throw "unsupported CONF"); + nativeBuildInputs = + [ installShellFiles ] + ++ { + linux = [ + pkg-config + wayland-scanner + ]; + unix = [ makeWrapper ]; + } + ."${config}" or (throw "unsupported CONF"); - buildInputs = { - linux = [ pipewire wayland wayland-protocols libxkbcommon wlr-protocols ]; - unix = [ xorg.libX11 xorg.libXt ]; - }."${config}" or (throw "unsupported CONF"); + buildInputs = + { + linux = [ + pipewire + wayland + wayland-protocols + libxkbcommon + wlr-protocols + ]; + unix = [ + xorg.libX11 + xorg.libXt + ]; + } + ."${config}" or (throw "unsupported CONF"); # TODO: macos makeFlags = [ "CONF=${config}" ]; - installPhase = { - linux = '' - install -Dm755 -t $out/bin/ drawterm + installPhase = + { + linux = '' + install -Dm755 -t $out/bin/ drawterm + ''; + unix = '' + # wrapping the oss output with pulse seems to be the easiest + mv drawterm drawterm.bin + install -Dm755 -t $out/bin/ drawterm.bin + makeWrapper ${pulseaudio}/bin/padsp $out/bin/drawterm --add-flags $out/bin/drawterm.bin + ''; + } + ."${config}" or (throw "unsupported CONF") + + '' + installManPage drawterm.1 ''; - unix = '' - # wrapping the oss output with pulse seems to be the easiest - mv drawterm drawterm.bin - install -Dm755 -t $out/bin/ drawterm.bin - makeWrapper ${pulseaudio}/bin/padsp $out/bin/drawterm --add-flags $out/bin/drawterm.bin - ''; - }."${config}" or (throw "unsupported CONF") + '' - installManPage drawterm.1 - ''; passthru = { updateScript = unstableGitUpdater { shallowClone = false; }; diff --git a/pkgs/tools/admin/fastlane/default.nix b/pkgs/tools/admin/fastlane/default.nix index 16c668a268a54e..ef7b6ed16eede2 100644 --- a/pkgs/tools/admin/fastlane/default.nix +++ b/pkgs/tools/admin/fastlane/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerApp, bundlerUpdateScript, makeBinaryWrapper }: +{ + lib, + bundlerApp, + bundlerUpdateScript, + makeBinaryWrapper, +}: bundlerApp { pname = "fastlane"; diff --git a/pkgs/tools/admin/fastlane/gemset.nix b/pkgs/tools/admin/fastlane/gemset.nix index 1019d157c1e5f5..eb46a8fe55c5a5 100644 --- a/pkgs/tools/admin/fastlane/gemset.nix +++ b/pkgs/tools/admin/fastlane/gemset.nix @@ -1,901 +1,1016 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0irbdwkkjwzajq1ip6ba46q49sxnrl2cw7ddkdhsfhb6aprnm3vr"; type = "gem"; }; version = "2.8.6"; }; artifactory = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qzj389l2a3zig040h882mf6cxfa71pm2nk51l4p85n3ck4xa8rh"; type = "gem"; }; version = "3.0.17"; }; atomos = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17vq6sjyswr5jfzwdccw748kgph6bdw30bakwnn6p8sl4hpv4hvx"; type = "gem"; }; version = "0.1.3"; }; aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gvdg4yx4p9av2glmp7vsxhs0n8fj1ga9kq2xdb8f95j7b04qhzi"; type = "gem"; }; version = "1.3.0"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00iknq94smbskgmxqmlxlcgpq5famd968l12nvv8bxi7gk1hagsk"; type = "gem"; }; version = "1.909.0"; }; aws-sdk-core = { - dependencies = ["aws-eventstream" "aws-partitions" "aws-sigv4" "jmespath"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-eventstream" + "aws-partitions" + "aws-sigv4" + "jmespath" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08h9apxdn2aflkg751j4i56ks4750znfbj56w4zlxf4jk7jxkbyk"; type = "gem"; }; version = "3.191.6"; }; aws-sdk-kms = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fbp2vw5qnyiya63hlmwiqkbh30lipyqplancmhm84ad7i98ambb"; type = "gem"; }; version = "1.78.0"; }; aws-sdk-s3 = { - dependencies = ["aws-sdk-core" "aws-sdk-kms" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sdk-kms" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1al80phz4x9wwfnr07q1l8h5f0qxgfrrycbg8jvznhxm3zhrakrq"; type = "gem"; }; version = "1.146.1"; }; aws-sigv4 = { - dependencies = ["aws-eventstream"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-eventstream" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g3w27wzjy4si6kp49w10as6ml6g6zl3xrfqs5ikpfciidv9kpc4"; type = "gem"; }; version = "1.8.0"; }; babosa = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16dwqn33kmxkqkv51cwiikdkbrdjfsymlnc0rgbjwilmym8a9phq"; type = "gem"; }; version = "1.0.4"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; CFPropertyList = { - dependencies = ["base64" "nkf" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "nkf" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k1w5i4lb1z941m7ds858nly33f3iv12wvr1zav5x3fa99hj2my4"; type = "gem"; }; version = "3.0.7"; }; claide = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bpqhc0kqjp1bh9b7ffc395l9gfls0337rrhmab4v46ykl45qg3d"; type = "gem"; }; version = "1.1.0"; }; colored = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b0x5jmsyi0z69bm6sij1k89z7h0laag3cb4mdn7zkl9qmxb90lx"; type = "gem"; }; version = "1.2"; }; colored2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jlbqa9q4mvrm73aw9mxh23ygzbjiqwisl32d8szfb5fxvbjng5i"; type = "gem"; }; version = "3.1.2"; }; commander = { - dependencies = ["highline"]; - groups = ["default"]; - platforms = []; + dependencies = [ "highline" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n8k547hqq9hvbyqbx2qi08g0bky20bbjca1df8cqq5frhzxq7bx"; type = "gem"; }; version = "4.6.0"; }; declarative = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yczgnqrbls7shrg63y88g7wand2yp9h6sf56c9bdcksn5nds8c0"; type = "gem"; }; version = "0.0.20"; }; digest-crc = { - dependencies = ["rake"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rake" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09114ndpnnyamc2q07bmpzw7kp3rbbfv7plmxcbzzi9d6prmd92w"; type = "gem"; }; version = "0.6.5"; }; domain_name = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cyr2xm576gqhqicsyqnhanni47408w2pgvrfi8pd13h2li3nsaz"; type = "gem"; }; version = "0.6.20240107"; }; dotenv = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n0pi8x8ql5h1mijvm8lgn6bhq4xjb5a500p5r1krq4s6j9lg565"; type = "gem"; }; version = "2.8.1"; }; emoji_regex = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jsnrkfy345v66jlm2xrz8znivfnamg3mfzkddn414bndf2vxn7c"; type = "gem"; }; version = "3.2.3"; }; excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1m3gzvp1wqki0yh4b7761qhdy4pyr4phy429b7s9w25nrkhp4lsz"; type = "gem"; }; version = "0.110.0"; }; faraday = { - dependencies = ["faraday-em_http" "faraday-em_synchrony" "faraday-excon" "faraday-httpclient" "faraday-multipart" "faraday-net_http" "faraday-net_http_persistent" "faraday-patron" "faraday-rack" "faraday-retry" "ruby2_keywords"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-em_http" + "faraday-em_synchrony" + "faraday-excon" + "faraday-httpclient" + "faraday-multipart" + "faraday-net_http" + "faraday-net_http_persistent" + "faraday-patron" + "faraday-rack" + "faraday-retry" + "ruby2_keywords" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1c760q0ks4vj4wmaa7nh1dgvgqiwaw0mjr7v8cymy7i3ffgjxx90"; type = "gem"; }; version = "1.10.3"; }; faraday-cookie_jar = { - dependencies = ["faraday" "http-cookie"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "http-cookie" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00hligx26w9wdnpgsrf0qdnqld4rdccy8ym6027h5m735mpvxjzk"; type = "gem"; }; version = "0.0.7"; }; faraday-em_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12cnqpbak4vhikrh2cdn94assh3yxza8rq2p9w2j34bqg5q4qgbs"; type = "gem"; }; version = "1.0.0"; }; faraday-em_synchrony = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vgrbhkp83sngv6k4mii9f2s9v5lmp693hylfxp2ssfc60fas3a6"; type = "gem"; }; version = "1.0.0"; }; faraday-excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h09wkb0k0bhm6dqsd47ac601qiaah8qdzjh8gvxfd376x1chmdh"; type = "gem"; }; version = "1.1.0"; }; faraday-httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fyk0jd3ks7fdn8nv3spnwjpzx2lmxmg2gh4inz3by1zjzqg33sc"; type = "gem"; }; version = "1.0.1"; }; faraday-multipart = { - dependencies = ["multipart-post"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multipart-post" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09871c4hd7s5ws1wl4gs7js1k2wlby6v947m2bbzg43pnld044lh"; type = "gem"; }; version = "1.0.4"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fi8sda5hc54v1w3mqfl5yz09nhx35kglyx72w7b8xxvdr0cwi9j"; type = "gem"; }; version = "1.0.1"; }; faraday-net_http_persistent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dc36ih95qw3rlccffcb0vgxjhmipsvxhn6cw71l7ffs0f7vq30b"; type = "gem"; }; version = "1.2.0"; }; faraday-patron = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19wgsgfq0xkski1g7m96snv39la3zxz6x7nbdgiwhg5v82rxfb6w"; type = "gem"; }; version = "1.0.0"; }; faraday-rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h184g4vqql5jv9s9im6igy00jp6mrah2h14py6mpf9bkabfqq7g"; type = "gem"; }; version = "1.0.0"; }; faraday-retry = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "153i967yrwnswqgvnnajgwp981k9p50ys1h80yz3q94rygs59ldd"; type = "gem"; }; version = "1.0.3"; }; faraday_middleware = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bw8mfh4yin2xk7138rg3fhb2p5g2dlmdma88k82psah9mbmvlfy"; type = "gem"; }; version = "1.2.0"; }; fastimage = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sfc7svf7h1ja6zmsq9f3ps6pg0q4hymphh6rk7ipmp7ygqjkii3"; type = "gem"; }; version = "2.3.1"; }; fastlane = { - dependencies = ["CFPropertyList" "addressable" "artifactory" "aws-sdk-s3" "babosa" "colored" "commander" "dotenv" "emoji_regex" "excon" "faraday" "faraday-cookie_jar" "faraday_middleware" "fastimage" "gh_inspector" "google-apis-androidpublisher_v3" "google-apis-playcustomapp_v1" "google-cloud-env" "google-cloud-storage" "highline" "http-cookie" "json" "jwt" "mini_magick" "multipart-post" "naturally" "optparse" "plist" "rubyzip" "security" "simctl" "terminal-notifier" "terminal-table" "tty-screen" "tty-spinner" "word_wrap" "xcodeproj" "xcpretty" "xcpretty-travis-formatter"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "CFPropertyList" + "addressable" + "artifactory" + "aws-sdk-s3" + "babosa" + "colored" + "commander" + "dotenv" + "emoji_regex" + "excon" + "faraday" + "faraday-cookie_jar" + "faraday_middleware" + "fastimage" + "gh_inspector" + "google-apis-androidpublisher_v3" + "google-apis-playcustomapp_v1" + "google-cloud-env" + "google-cloud-storage" + "highline" + "http-cookie" + "json" + "jwt" + "mini_magick" + "multipart-post" + "naturally" + "optparse" + "plist" + "rubyzip" + "security" + "simctl" + "terminal-notifier" + "terminal-table" + "tty-screen" + "tty-spinner" + "word_wrap" + "xcodeproj" + "xcpretty" + "xcpretty-travis-formatter" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14ywmlipmryzdxzn4235ah67hy06wh5hf32jbs3a9j7byc2x1kx3"; type = "gem"; }; version = "2.220.0"; }; gh_inspector = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f8r9byajj3bi2c7c5sqrc7m0zrv3nblfcd4782lw5l73cbsgk04"; type = "gem"; }; version = "1.1.3"; }; google-apis-androidpublisher_v3 = { - dependencies = ["google-apis-core"]; - groups = ["default"]; - platforms = []; + dependencies = [ "google-apis-core" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "046j100lrh5dhb8p3gr38fyqrw8vcif97pqb55ysipy874lafw49"; type = "gem"; }; version = "0.54.0"; }; google-apis-core = { - dependencies = ["addressable" "googleauth" "httpclient" "mini_mime" "representable" "retriable" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "googleauth" + "httpclient" + "mini_mime" + "representable" + "retriable" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15ycm7al9dizabbqmri5xmiz8mbcci343ygb64ndbmr9n49p08a3"; type = "gem"; }; version = "0.11.3"; }; google-apis-iamcredentials_v1 = { - dependencies = ["google-apis-core"]; - groups = ["default"]; - platforms = []; + dependencies = [ "google-apis-core" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ysil0bkh755kmf9xvw5szhk1yyh3gqzwfsrbwsrl77gsv7jarcs"; type = "gem"; }; version = "0.17.0"; }; google-apis-playcustomapp_v1 = { - dependencies = ["google-apis-core"]; - groups = ["default"]; - platforms = []; + dependencies = [ "google-apis-core" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1mlgwiid5lgg41y7qk8ca9lzhwx5njs25hz5fbf1mdal0kwm37lm"; type = "gem"; }; version = "0.13.0"; }; google-apis-storage_v1 = { - dependencies = ["google-apis-core"]; - groups = ["default"]; - platforms = []; + dependencies = [ "google-apis-core" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13yvc9r8bhs16vq3fjc93qlffmq9p6zx97c9g1c3wh0jbrvwrs03"; type = "gem"; }; version = "0.31.0"; }; google-cloud-core = { - dependencies = ["google-cloud-env" "google-cloud-errors"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "google-cloud-env" + "google-cloud-errors" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0dagdfx3rnk9xplnj19gqpqn41fd09xfn8lp2p75psihhnj2i03l"; type = "gem"; }; version = "1.7.0"; }; google-cloud-env = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05gshdqscg4kil6ppfzmikyavsx449bxyj47j33r4n4p8swsqyb1"; type = "gem"; }; version = "1.6.0"; }; google-cloud-errors = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "056yw9cg771c1xqvw15wpdfdw9lz3m13fh5b6a3p1c9xaq7jwkhb"; type = "gem"; }; version = "1.4.0"; }; google-cloud-storage = { - dependencies = ["addressable" "digest-crc" "google-apis-iamcredentials_v1" "google-apis-storage_v1" "google-cloud-core" "googleauth" "mini_mime"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "digest-crc" + "google-apis-iamcredentials_v1" + "google-apis-storage_v1" + "google-cloud-core" + "googleauth" + "mini_mime" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0xpb3s7zr7g647xg66y2mavdargk5ixsfbfdmi4m2jc3khdd0hxm"; type = "gem"; }; version = "1.47.0"; }; googleauth = { - dependencies = ["faraday" "jwt" "multi_json" "os" "signet"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "jwt" + "multi_json" + "os" + "signet" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ry9v23kndgx2pxq9v31l68k9lnnrcz1w4v75bkxq88jmbddljl1"; type = "gem"; }; version = "1.8.1"; }; highline = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yclf57n2j3cw8144ania99h1zinf8q3f5zrhqa754j6gl95rp9d"; type = "gem"; }; version = "2.0.3"; }; http-cookie = { - dependencies = ["domain_name"]; - groups = ["default"]; - platforms = []; + dependencies = [ "domain_name" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13rilvlv8kwbzqfb644qp6hrbsj82cbqmnzcvqip1p6vqx36sxbk"; type = "gem"; }; version = "1.0.5"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cdw9vw2qly7q7r41s7phnac264rbsdqgj4l0h4nqgbjb157g393"; type = "gem"; }; version = "1.6.2"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b4qsi8gay7ncmigr0pnbxyb17y3h8kavdyhsh7nrlqwr35vb60q"; type = "gem"; }; version = "2.7.2"; }; jwt = { - dependencies = ["base64"]; - groups = ["default"]; - platforms = []; + dependencies = [ "base64" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02m3vza49pb9dirwpn8vmzbcypi3fc6l3a9dh253jwm1121g7ajb"; type = "gem"; }; version = "2.8.1"; }; mini_magick = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0slh78f9z6n0l1i2km7m48yz7l4fjrk88sj1f4mh1wb39sl2yc37"; type = "gem"; }; version = "4.12.0"; }; mini_mime = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vycif7pjzkr29mfk4dlqv3disc5dn0va04lkwajlpr1wkibg0c6"; type = "gem"; }; version = "1.1.5"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1033p35166d9p97y4vajbbvr13pmkk9zwn7sylxpmk9jrpk8ri67"; type = "gem"; }; version = "2.4.0"; }; nanaimo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xi36h3f7nm8bc2k0b6svpda1lyank2gf872lxjbhw3h95hdrbma"; type = "gem"; }; version = "0.3.0"; }; naturally = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04x1nkx6gkqzlc4phdvq05v3vjds6mgqhjqzqpcs6vdh5xyqrf59"; type = "gem"; }; version = "2.2.1"; }; nkf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09piyp2pd74klb9wcn0zw4mb5l0k9wzwppxggxi1yi95l2ym3hgv"; type = "gem"; }; version = "0.2.0"; }; optparse = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pmsn1g1q5fpkjrc4h1wlw6lxlqp165sdcd951xyl47n6k0az17m"; type = "gem"; }; version = "0.4.0"; }; os = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gwd20smyhxbm687vdikfh1gpi96h8qb1x28s2pdcysf6dm6v0ap"; type = "gem"; }; version = "1.1.4"; }; plist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b643i5b7b7galvlb2fc414ifmb78b5lsq47gnvhzl8m27dl559z"; type = "gem"; }; version = "3.7.1"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14y4vzjwf5gp0mqgs880kis0k7n2biq8i6ci6q2n315kichl1hvj"; type = "gem"; }; version = "5.0.5"; }; rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17850wcwkgi30p7yqh60960ypn7yibacjjha0av78zaxwvd3ijs6"; type = "gem"; }; version = "13.2.1"; }; representable = { - dependencies = ["declarative" "trailblazer-option" "uber"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "declarative" + "trailblazer-option" + "uber" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kms3r6w6pnryysnaqqa9fsn0v73zx1ilds9d1c565n3xdzbyafc"; type = "gem"; }; version = "3.2.0"; }; retriable = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q48hqws2dy1vws9schc0kmina40gy7sn5qsndpsfqdslh65snha"; type = "gem"; }; version = "3.1.2"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05i8518ay14kjbma550mv0jm8a6di8yp5phzrd8rj44z9qnrlrp0"; type = "gem"; }; version = "3.2.6"; }; rouge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sfikq1q8xyqqx690iiz7ybhzx87am4w50w8f2nq36l3asw4x89d"; type = "gem"; }; version = "2.0.7"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; security = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1drkm2wgjazwzj09db1szrllkag036bdvc3dr42fh1kpr877m5rs"; type = "gem"; }; version = "0.1.5"; }; signet = { - dependencies = ["addressable" "faraday" "jwt" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "faraday" + "jwt" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cfxa11wy1nv9slmnzjczkdgld0gqizajsb03rliy53zylwkjzsk"; type = "gem"; }; version = "0.19.0"; }; simctl = { - dependencies = ["CFPropertyList" "naturally"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "CFPropertyList" + "naturally" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0sr3z4kmp6ym7synicyilj9vic7i9nxgaszqx6n1xn1ss7s7g45r"; type = "gem"; }; version = "1.6.10"; }; terminal-notifier = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1slc0y8pjpw30hy21v8ypafi8r7z9jlj4bjbgz03b65b28i2n3bs"; type = "gem"; }; version = "2.0.0"; }; terminal-table = { - dependencies = ["unicode-display_width"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unicode-display_width" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14dfmfjppmng5hwj7c5ka6qdapawm3h6k9lhn8zj001ybypvclgr"; type = "gem"; }; version = "3.0.2"; }; trailblazer-option = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18s48fndi2kfvrfzmq6rxvjfwad347548yby0341ixz1lhpg3r10"; type = "gem"; }; version = "0.1.2"; }; tty-cursor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j5zw041jgkmn605ya1zc151bxgxl6v192v2i26qhxx7ws2l2lvr"; type = "gem"; }; version = "0.7.1"; }; tty-screen = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0l4vh6g333jxm9lakilkva2gn17j6gb052626r1pdbmy2lhnb460"; type = "gem"; }; version = "0.8.2"; }; tty-spinner = { - dependencies = ["tty-cursor"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-cursor" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hh5awmijnzw9flmh5ak610x1d00xiqagxa5mbr63ysggc26y0qf"; type = "gem"; }; version = "0.9.3"; }; uber = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1p1mm7mngg40x05z52md3mbamkng0zpajbzqjjwmsyw0zw3v9vjv"; type = "gem"; }; version = "0.1.0"; }; unicode-display_width = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d0azx233nags5jx3fqyr23qa2rhgzbhv8pxp46dgbg1mpf82xky"; type = "gem"; }; version = "2.5.0"; }; word_wrap = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1iyc5bc7dbgsd8j3yk1i99ral39f23l6wapi0083fbl19hid8mpm"; type = "gem"; }; version = "1.0.0"; }; xcodeproj = { - dependencies = ["CFPropertyList" "atomos" "claide" "colored2" "nanaimo" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "CFPropertyList" + "atomos" + "claide" + "colored2" + "nanaimo" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1wpg4n7b8571j2h8h7v2kk8pr141rgf6m8mhk221k990fissrq56"; type = "gem"; }; version = "1.24.0"; }; xcpretty = { - dependencies = ["rouge"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rouge" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xq47q2h5llj7b54rws4796904vnnjz7qqnacdv7wlp3gdbwrivm"; type = "gem"; }; version = "0.3.0"; }; xcpretty-travis-formatter = { - dependencies = ["xcpretty"]; - groups = ["default"]; - platforms = []; + dependencies = [ "xcpretty" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14rg4f70klrs910n7rsgfa4dn8s2qyny55194ax2qyyb2wpk7k5a"; type = "gem"; }; diff --git a/pkgs/tools/admin/google-cloud-sdk/components.nix b/pkgs/tools/admin/google-cloud-sdk/components.nix index c337112762b648..30c16ff1ef4481 100644 --- a/pkgs/tools/admin/google-cloud-sdk/components.nix +++ b/pkgs/tools/admin/google-cloud-sdk/components.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, system -, snapshotPath -, autoPatchelfHook -, python3 -, libxcrypt-legacy +{ + lib, + stdenv, + fetchurl, + system, + snapshotPath, + autoPatchelfHook, + python3, + libxcrypt-legacy, }: let @@ -25,7 +26,8 @@ let }; # Convert an archicecture + OS to a Nix platform - toNixPlatform = arch: os: + toNixPlatform = + arch: os: let arch' = arches.${arch} or (throw "unsupported architecture '${arch}'"); os' = oses.${os} or (throw "unsupported OS '${os}'"); @@ -44,10 +46,11 @@ let # installed with google-cloud-sdk to let it know which components are # available. snapshotFromComponent = - { component - , revision - , schema_version - , version + { + component, + revision, + schema_version, + version, }: builtins.toJSON { components = [ component ]; @@ -56,21 +59,27 @@ let # Generate a set of components from a JSON file describing these components componentsFromSnapshot = - { components - , revision - , schema_version - , version - , ... + { + components, + revision, + schema_version, + version, + ... }: lib.fix ( self: builtins.listToAttrs ( - builtins.map - (component: { - name = component.id; - value = componentFromSnapshot self { inherit component revision schema_version version; }; - }) - components + builtins.map (component: { + name = component.id; + value = componentFromSnapshot self { + inherit + component + revision + schema_version + version + ; + }; + }) components ) ); @@ -80,69 +89,68 @@ let # Component derivations that can be used as dependencies components: # This component's snapshot - { component - , revision - , schema_version - , version - } @ attrs: + { + component, + revision, + schema_version, + version, + }@attrs: let baseUrl = builtins.dirOf schema_version.url; # Architectures supported by this component. Defaults to all available # architectures. - architectures = builtins.filter - (arch: builtins.elem arch (builtins.attrNames arches)) - (lib.attrByPath [ "platform" "architectures" ] allArches component); + architectures = builtins.filter (arch: builtins.elem arch (builtins.attrNames arches)) ( + lib.attrByPath [ "platform" "architectures" ] allArches component + ); # Operating systems supported by this component - operating_systems = builtins.filter - (os: builtins.elem os (builtins.attrNames oses)) - component.platform.operating_systems; + operating_systems = builtins.filter ( + os: builtins.elem os (builtins.attrNames oses) + ) component.platform.operating_systems; in - mkComponent - { - pname = component.id; - version = component.version.version_string; - src = - lib.optionalString (lib.hasAttrByPath [ "data" "source" ] component) "${baseUrl}/${component.data.source}"; - sha256 = lib.attrByPath [ "data" "checksum" ] "" component; - dependencies = builtins.map (dep: builtins.getAttr dep components) component.dependencies; - platforms = - if component.platform == { } - then lib.platforms.all - else - builtins.concatMap - (arch: builtins.map (os: toNixPlatform arch os) operating_systems) - architectures; - snapshot = snapshotFromComponent attrs; - }; + mkComponent { + pname = component.id; + version = component.version.version_string; + src = lib.optionalString (lib.hasAttrByPath [ + "data" + "source" + ] component) "${baseUrl}/${component.data.source}"; + sha256 = lib.attrByPath [ "data" "checksum" ] "" component; + dependencies = builtins.map (dep: builtins.getAttr dep components) component.dependencies; + platforms = + if component.platform == { } then + lib.platforms.all + else + builtins.concatMap (arch: builtins.map (os: toNixPlatform arch os) operating_systems) architectures; + snapshot = snapshotFromComponent attrs; + }; # Filter out dependencies not supported by current system filterForSystem = builtins.filter (drv: builtins.elem system drv.meta.platforms); # Make a google-cloud-sdk component mkComponent = - { pname - , version + { + pname, + version, # Source tarball, if any - , src ? "" + src ? "", # Checksum for the source tarball, if there is a source - , sha256 ? "" + sha256 ? "", # Other components this one depends on - , dependencies ? [ ] + dependencies ? [ ], # Short text describing the component - , description ? "" + description ? "", # Platforms supported - , platforms ? lib.platforms.all + platforms ? lib.platforms.all, # The snapshot corresponding to this component - , snapshot - }: stdenv.mkDerivation { + snapshot, + }: + stdenv.mkDerivation { inherit pname version snapshot; - src = - lib.optionalString (src != "") - (fetchurl - { - url = src; - inherit sha256; - }); + src = lib.optionalString (src != "") (fetchurl { + url = src; + inherit sha256; + }); dontUnpack = true; installPhase = '' mkdir -p $out/google-cloud-sdk/.install @@ -161,12 +169,14 @@ let # Write the snapshot file to the `.install` folder cp $snapshotPath $out/google-cloud-sdk/.install/${pname}.snapshot.json ''; - nativeBuildInputs = [ - python3 - stdenv.cc.cc - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - autoPatchelfHook - ]; + nativeBuildInputs = + [ + python3 + stdenv.cc.cc + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + autoPatchelfHook + ]; buildInputs = [ libxcrypt-legacy ]; diff --git a/pkgs/tools/admin/google-cloud-sdk/data.nix b/pkgs/tools/admin/google-cloud-sdk/data.nix index 5e695041c01f49..7060d52e3bb997 100644 --- a/pkgs/tools/admin/google-cloud-sdk/data.nix +++ b/pkgs/tools/admin/google-cloud-sdk/data.nix @@ -3,30 +3,25 @@ { version = "501.0.0"; googleCloudSdkPkgs = { - x86_64-linux = - { - url = "https://dl.google.com/dl/cloudsdk/channels/rapid/downloads/google-cloud-sdk-501.0.0-linux-x86_64.tar.gz"; - sha256 = "1naswkfjjmmhb6n3zsma246pang3cnadwqgi683fimznmcc228sa"; - }; - x86_64-darwin = - { - url = "https://dl.google.com/dl/cloudsdk/channels/rapid/downloads/google-cloud-sdk-501.0.0-darwin-x86_64.tar.gz"; - sha256 = "1k5is68s6y6bxmq8mhdsd2pfqw0rx9maakqis7wxnzvfpwdmamqc"; - }; - aarch64-linux = - { - url = "https://dl.google.com/dl/cloudsdk/channels/rapid/downloads/google-cloud-sdk-501.0.0-linux-arm.tar.gz"; - sha256 = "1926lc0wbf06qwm0936jj3l98j82d6llljwsly99yrqwyfibi0h0"; - }; - aarch64-darwin = - { - url = "https://dl.google.com/dl/cloudsdk/channels/rapid/downloads/google-cloud-sdk-501.0.0-darwin-arm.tar.gz"; - sha256 = "19zjb4l067q81jg4djv4x1l95scdbk4kp3bj3dxm1rxaz3ik0jcl"; - }; - i686-linux = - { - url = "https://dl.google.com/dl/cloudsdk/channels/rapid/downloads/google-cloud-sdk-501.0.0-linux-x86.tar.gz"; - sha256 = "03vggxqfml0hl7jyjcmp51c5vw88d5zrsc18782rb533dd586g0n"; - }; + x86_64-linux = { + url = "https://dl.google.com/dl/cloudsdk/channels/rapid/downloads/google-cloud-sdk-501.0.0-linux-x86_64.tar.gz"; + sha256 = "1naswkfjjmmhb6n3zsma246pang3cnadwqgi683fimznmcc228sa"; + }; + x86_64-darwin = { + url = "https://dl.google.com/dl/cloudsdk/channels/rapid/downloads/google-cloud-sdk-501.0.0-darwin-x86_64.tar.gz"; + sha256 = "1k5is68s6y6bxmq8mhdsd2pfqw0rx9maakqis7wxnzvfpwdmamqc"; + }; + aarch64-linux = { + url = "https://dl.google.com/dl/cloudsdk/channels/rapid/downloads/google-cloud-sdk-501.0.0-linux-arm.tar.gz"; + sha256 = "1926lc0wbf06qwm0936jj3l98j82d6llljwsly99yrqwyfibi0h0"; + }; + aarch64-darwin = { + url = "https://dl.google.com/dl/cloudsdk/channels/rapid/downloads/google-cloud-sdk-501.0.0-darwin-arm.tar.gz"; + sha256 = "19zjb4l067q81jg4djv4x1l95scdbk4kp3bj3dxm1rxaz3ik0jcl"; + }; + i686-linux = { + url = "https://dl.google.com/dl/cloudsdk/channels/rapid/downloads/google-cloud-sdk-501.0.0-linux-x86.tar.gz"; + sha256 = "03vggxqfml0hl7jyjcmp51c5vw88d5zrsc18782rb533dd586g0n"; + }; }; } diff --git a/pkgs/tools/admin/google-cloud-sdk/default.nix b/pkgs/tools/admin/google-cloud-sdk/default.nix index 87cb27b57d19cf..8c4c33f2d686d8 100644 --- a/pkgs/tools/admin/google-cloud-sdk/default.nix +++ b/pkgs/tools/admin/google-cloud-sdk/default.nix @@ -7,20 +7,35 @@ # 3) used by `google-cloud-sdk` only on GCE guests # -{ stdenv, lib, fetchurl, makeWrapper, python, openssl, jq, callPackage, installShellFiles, with-gce ? false }: +{ + stdenv, + lib, + fetchurl, + makeWrapper, + python, + openssl, + jq, + callPackage, + installShellFiles, + with-gce ? false, +}: let - pythonEnv = python.withPackages (p: with p; [ - cffi - cryptography - pyopenssl - crcmod - numpy - ] ++ lib.optional (with-gce) google-compute-engine); + pythonEnv = python.withPackages ( + p: + with p; + [ + cffi + cryptography + pyopenssl + crcmod + numpy + ] + ++ lib.optional (with-gce) google-compute-engine + ); data = import ./data.nix { }; - sources = system: - data.googleCloudSdkPkgs.${system} or (throw "Unsupported system: ${system}"); + sources = system: data.googleCloudSdkPkgs.${system} or (throw "Unsupported system: ${system}"); components = callPackage ./components.nix { snapshotPath = ./components.json; @@ -28,7 +43,8 @@ let withExtraComponents = callPackage ./withExtraComponents.nix { inherit components; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "google-cloud-sdk"; inherit (data) version; @@ -36,7 +52,11 @@ in stdenv.mkDerivation rec { buildInputs = [ python ]; - nativeBuildInputs = [ jq makeWrapper installShellFiles ]; + nativeBuildInputs = [ + jq + makeWrapper + installShellFiles + ]; patches = [ # For kubectl configs, don't store the absolute path of the `gcloud` binary as it can be garbage-collected @@ -135,13 +155,19 @@ in stdenv.mkDerivation rec { longDescription = "The Google Cloud SDK for GCE hosts. Used by `google-cloud-sdk` only on GCE guests."; sourceProvenance = with sourceTypes; [ fromSource - binaryNativeCode # anthoscli and possibly more + binaryNativeCode # anthoscli and possibly more ]; # This package contains vendored dependencies. All have free licenses. license = licenses.free; homepage = "https://cloud.google.com/sdk/"; changelog = "https://cloud.google.com/sdk/docs/release-notes"; - maintainers = with maintainers; [ iammrinal0 marcusramberg pradyuman stephenmw zimbatm ]; + maintainers = with maintainers; [ + iammrinal0 + marcusramberg + pradyuman + stephenmw + zimbatm + ]; platforms = builtins.attrNames data.googleCloudSdkPkgs; mainProgram = "gcloud"; }; diff --git a/pkgs/tools/admin/google-cloud-sdk/withExtraComponents.nix b/pkgs/tools/admin/google-cloud-sdk/withExtraComponents.nix index 63070a85dd8fe5..29cdc6334f893b 100644 --- a/pkgs/tools/admin/google-cloud-sdk/withExtraComponents.nix +++ b/pkgs/tools/admin/google-cloud-sdk/withExtraComponents.nix @@ -1,4 +1,9 @@ -{ lib, google-cloud-sdk, symlinkJoin, components }: +{ + lib, + google-cloud-sdk, + symlinkJoin, + components, +}: comps_: @@ -6,19 +11,34 @@ let # Remove components which are already installed by default filterPreInstalled = let - preInstalledComponents = with components; [ bq bq-nix core core-nix gcloud-deps gcloud gsutil gsutil-nix ]; + preInstalledComponents = with components; [ + bq + bq-nix + core + core-nix + gcloud-deps + gcloud + gsutil + gsutil-nix + ]; in builtins.filter (drv: !(builtins.elem drv preInstalledComponents)); # Recursively build a list of components with their dependencies # TODO this could be made faster, it checks the dependencies too many times - findDepsRecursive = lib.converge - (drvs: lib.unique (drvs ++ (builtins.concatMap (drv: drv.dependencies) drvs))); + findDepsRecursive = lib.converge ( + drvs: lib.unique (drvs ++ (builtins.concatMap (drv: drv.dependencies) drvs)) + ); # Components to install by default - defaultComponents = with components; [ alpha beta ]; + defaultComponents = with components; [ + alpha + beta + ]; - comps = [ google-cloud-sdk ] ++ filterPreInstalled (findDepsRecursive (defaultComponents ++ comps_)); + comps = [ + google-cloud-sdk + ] ++ filterPreInstalled (findDepsRecursive (defaultComponents ++ comps_)); installCheck = let diff --git a/pkgs/tools/admin/itamae/default.nix b/pkgs/tools/admin/itamae/default.nix index d84da4fd974126..fbcb6e3c05f934 100644 --- a/pkgs/tools/admin/itamae/default.nix +++ b/pkgs/tools/admin/itamae/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "itamae"; diff --git a/pkgs/tools/admin/itamae/gemset.nix b/pkgs/tools/admin/itamae/gemset.nix index 207a2aed7ab024..f0accad4dd1019 100644 --- a/pkgs/tools/admin/itamae/gemset.nix +++ b/pkgs/tools/admin/itamae/gemset.nix @@ -1,153 +1,167 @@ { ansi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14ims9zfal4gs2wpx2m5rd8zsrl2k794d359shkrsgg3fhr2a22l"; type = "gem"; }; version = "1.5.0"; }; bcrypt_pbkdf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ndamfaivnkhc6hy0yqyk2gkwr6f3bz6216lh74hsiiyk3axz445"; type = "gem"; }; version = "1.1.0"; }; docker-api = { - dependencies = ["excon" "multi_json"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "excon" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0g7dbniz15b3l2sy6xh0j0998dr5jypf3xg3bsygp0108vv7waxy"; type = "gem"; }; version = "2.2.0"; }; ed25519 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zb2dr2ihb1qiknn5iaj1ha1w9p7lj9yq5waasndlfadz225ajji"; type = "gem"; }; version = "1.3.0"; }; excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j826kfvzn7nc5pv950n270r0sx1702k988ad11cdlav3dcxxw09"; type = "gem"; }; version = "0.99.0"; }; hashie = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nh3arcrbz1rc1cr59qm53sdhqm137b258y8rcb4cvd3y98lwv4x"; type = "gem"; }; version = "5.0.0"; }; itamae = { - dependencies = ["ansi" "hashie" "schash" "specinfra" "thor"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "ansi" + "hashie" + "schash" + "specinfra" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zhx0cknipkjqp33qdxjlv7lcybgmh1jv9npp55vxaazd8cyfylx"; type = "gem"; }; version = "1.14.1"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; net-scp = { - dependencies = ["net-ssh"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-ssh" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1si2nq9l6jy5n2zw1q59a5gaji7v9vhy8qx08h4fg368906ysbdk"; type = "gem"; }; version = "4.0.0"; }; net-ssh = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qp3i8bi7ji1np0530bp2p9zrrn6galvmbsivxwpkjdpjdyn19sr"; type = "gem"; }; version = "7.0.1"; }; net-telnet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13qxznpwmc3hs51b76wqx2w29r158gzzh8719kv2gpi56844c8fx"; type = "gem"; }; version = "0.1.1"; }; schash = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ia62xi56pkxy4y6wg3v5kwabjncyh3g78nqll4fs34zhdf7v8ad"; type = "gem"; }; version = "0.1.2"; }; sfl = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qm4hvhq9pszi9zs1cl9qgwx1n4wxq0af0hq9sbf6qihqd8rwwwr"; type = "gem"; }; version = "2.3"; }; specinfra = { - dependencies = ["net-scp" "net-ssh" "net-telnet" "sfl"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "net-scp" + "net-ssh" + "net-telnet" + "sfl" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qzhb7k66gi375ymnkwiy4alr7jw2c9ih7hv1lv5j5nda10hfb1p"; type = "gem"; }; version = "2.84.1"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0inl77jh4ia03jw3iqm5ipr76ghal3hyjrd6r8zqsswwvi9j2xdi"; type = "gem"; }; diff --git a/pkgs/tools/admin/meraki-cli/default.nix b/pkgs/tools/admin/meraki-cli/default.nix index 2097dab07750bf..30d8dc648c8cd1 100644 --- a/pkgs/tools/admin/meraki-cli/default.nix +++ b/pkgs/tools/admin/meraki-cli/default.nix @@ -1,12 +1,13 @@ -{ lib -, argcomplete -, jinja2 -, meraki -, rich -, fetchPypi -, buildPythonApplication -, pytestCheckHook -, requests-mock +{ + lib, + argcomplete, + jinja2, + meraki, + rich, + fetchPypi, + buildPythonApplication, + pytestCheckHook, + requests-mock, }: buildPythonApplication rec { diff --git a/pkgs/tools/admin/meshcentral/default.nix b/pkgs/tools/admin/meshcentral/default.nix index ef5e1e7bf5c70f..bfcf476a005c51 100644 --- a/pkgs/tools/admin/meshcentral/default.nix +++ b/pkgs/tools/admin/meshcentral/default.nix @@ -1,10 +1,11 @@ -{ lib -, fetchzip -, fetchpatch -, fetchYarnDeps -, yarn2nix-moretea -, nodejs_18 -, dos2unix +{ + lib, + fetchzip, + fetchpatch, + fetchYarnDeps, + yarn2nix-moretea, + nodejs_18, + dos2unix, }: yarn2nix-moretea.mkYarnPackage { diff --git a/pkgs/tools/admin/oxidized/default.nix b/pkgs/tools/admin/oxidized/default.nix index a9771d339a3e6b..28a25b3f1d74d9 100644 --- a/pkgs/tools/admin/oxidized/default.nix +++ b/pkgs/tools/admin/oxidized/default.nix @@ -1,4 +1,9 @@ -{ lib, ruby, bundlerApp, bundlerUpdateScript }: +{ + lib, + ruby, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "oxidized"; @@ -6,15 +11,18 @@ bundlerApp { inherit ruby; - exes = [ "oxidized" "oxs" ]; + exes = [ + "oxidized" + "oxs" + ]; passthru.updateScript = bundlerUpdateScript "oxidized"; meta = with lib; { description = "Network device configuration backup tool. It's a RANCID replacement"; - homepage = "https://github.com/ytti/oxidized"; - license = licenses.asl20; + homepage = "https://github.com/ytti/oxidized"; + license = licenses.asl20; maintainers = with maintainers; [ nicknovitski ] ++ teams.wdz.members; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/tools/admin/oxidized/gemset.nix b/pkgs/tools/admin/oxidized/gemset.nix index eef644b6157c1f..e392920b774310 100644 --- a/pkgs/tools/admin/oxidized/gemset.nix +++ b/pkgs/tools/admin/oxidized/gemset.nix @@ -1,205 +1,226 @@ { asetus = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0li09rcpgc21ymfayvhnjwvfl10s75g8aj52973gk0gvygscrhah"; type = "gem"; }; version = "0.4.0"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bcrypt_pbkdf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04rb3rp9bdxn1y3qiflfpj7ccwb8ghrfbydh5vfz1l9px3fpg41g"; type = "gem"; }; version = "1.1.1"; }; charlock_holmes = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c1dws56r7p8y363dhyikg7205z59a3bn4amnv2y488rrq8qm7ml"; type = "gem"; }; version = "0.7.9"; }; date = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "149jknsq999gnhy865n33fkk22s0r447k76x9pmcnnwldfv2q7wp"; type = "gem"; }; version = "3.3.4"; }; ed25519 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zb2dr2ihb1qiknn5iaj1ha1w9p7lj9yq5waasndlfadz225ajji"; type = "gem"; }; version = "1.3.0"; }; emk-sinatra-url-for = { - dependencies = ["sinatra"]; - groups = ["default"]; - platforms = []; + dependencies = [ "sinatra" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rd5b1lraklv0hblzdnmw2z3dragfg0qqk7wxbpn58f8y7jxzjgj"; type = "gem"; }; version = "0.2.1"; }; haml = { - dependencies = ["temple" "thor" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "temple" + "thor" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15yxph91zswbnfy7szpdcfbdfqqn595ff290hm4f6fcnhryvhvlf"; type = "gem"; }; version = "6.3.0"; }; htmlentities = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nkklqsn8ir8wizzlakncfv42i32wc0w9hxp00hvdlgjr7376nhj"; type = "gem"; }; version = "4.3.4"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b4qsi8gay7ncmigr0pnbxyb17y3h8kavdyhsh7nrlqwr35vb60q"; type = "gem"; }; version = "2.7.2"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; mustermann = { - dependencies = ["ruby2_keywords"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ruby2_keywords" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rwbq20s2gdh8dljjsgj5s6wqqfmnbclhvv2c2608brv7jm6jdbd"; type = "gem"; }; version = "3.0.0"; }; net-ftp = { - dependencies = ["net-protocol" "time"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "net-protocol" + "time" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vhwqx8k5xscl6j6gdf1xs1lz6fwm8k8s1n7pwhk22cxnxcfmnnh"; type = "gem"; }; version = "0.3.7"; }; net-protocol = { - dependencies = ["timeout"]; - groups = ["default"]; - platforms = []; + dependencies = [ "timeout" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a32l4x73hz200cm587bc29q8q9az278syw3x6fkc9d1lv5y0wxa"; type = "gem"; }; version = "0.2.2"; }; net-scp = { - dependencies = ["net-ssh"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-ssh" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1si2nq9l6jy5n2zw1q59a5gaji7v9vhy8qx08h4fg368906ysbdk"; type = "gem"; }; version = "4.0.0"; }; net-ssh = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sqbq5aks9xxnldbd2hy20ypnd59zcra98ql0r7jjc26s5rgc18n"; type = "gem"; }; version = "7.2.3"; }; net-telnet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16nkxc79nqm7fd6w1fba4kb98vpgwnyfnlwxarpdcgywz300fc15"; type = "gem"; }; version = "0.2.0"; }; nio4r = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "017nbw87dpr4wyk81cgj8kxkxqgsgblrkxnmmadc77cg9gflrfal"; type = "gem"; }; version = "2.7.3"; }; oxidized = { - dependencies = ["asetus" "bcrypt_pbkdf" "ed25519" "net-ftp" "net-scp" "net-ssh" "net-telnet" "psych" "rugged" "slop"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "asetus" + "bcrypt_pbkdf" + "ed25519" + "net-ftp" + "net-scp" + "net-ssh" + "net-telnet" + "psych" + "rugged" + "slop" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ry9rwksjb80wxd42zv5m5444n5hwhkbr4spa895jk2c1k5q1y0c"; type = "gem"; }; version = "0.30.1"; }; oxidized-script = { - dependencies = ["oxidized" "slop"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "oxidized" + "slop" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { fetchSubmodules = false; rev = "988cded5d89f52e274afb545bd3e011e19d5d22d"; @@ -210,167 +231,192 @@ version = "0.6.0"; }; oxidized-web = { - dependencies = ["charlock_holmes" "emk-sinatra-url-for" "haml" "htmlentities" "json" "oxidized" "puma" "sinatra" "sinatra-contrib"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "charlock_holmes" + "emk-sinatra-url-for" + "haml" + "htmlentities" + "json" + "oxidized" + "puma" + "sinatra" + "sinatra-contrib" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0mf1kxjg49fxf988sqd9cni8j5r8xsp3218370ppinsy39l50782"; type = "gem"; }; version = "0.14.0"; }; psych = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "186i2hc6sfvg4skhqf82kxaf4mb60g65fsif8w8vg1hc9mbyiaph"; type = "gem"; }; version = "3.3.4"; }; puma = { - dependencies = ["nio4r"]; - groups = ["default"]; - platforms = []; + dependencies = [ "nio4r" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0i2vaww6qcazj0ywva1plmjnj6rk23b01szswc5jhcq7s2cikd1y"; type = "gem"; }; version = "6.4.2"; }; rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12z55b90vvr4sh93az2yfr3fg91jivsag8lcg0k360d99vdq568f"; type = "gem"; }; version = "3.1.7"; }; rack-protection = { - dependencies = ["base64" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1xmvcxgm1jq92hqxm119gfk95wzl0d46nb2c2c6qqsm4ra2n3nyh"; type = "gem"; }; version = "4.0.0"; }; rack-session = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10afdpmy9kh0qva96slcyc59j4gkk9av8ilh58cnj0qq7q3b416v"; type = "gem"; }; version = "2.0.0"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; rugged = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sccng15h8h3mcjxfgvxy85lfpswbj0nhmzwwsqdffbzqgsb2jch"; type = "gem"; }; version = "1.7.2"; }; sinatra = { - dependencies = ["mustermann" "rack" "rack-protection" "rack-session" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mustermann" + "rack" + "rack-protection" + "rack-session" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0za92lv4s7xhgkkm6xxf7ib0b3bsyj8drxgkrskgsb5g3mxnixjl"; type = "gem"; }; version = "4.0.0"; }; sinatra-contrib = { - dependencies = ["multi_json" "mustermann" "rack-protection" "sinatra" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "multi_json" + "mustermann" + "rack-protection" + "sinatra" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0r9khg85m60w0i77jpnm2irh9m4k0ia4mlicapj8dr7s6ykqd9dh"; type = "gem"; }; version = "4.0.0"; }; slop = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1iyrjskgxyn8i1679qwkzns85p909aq77cgx2m4fs5ygzysj4hw4"; type = "gem"; }; version = "4.10.1"; }; temple = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fwia5hvc1xz9w7vprzjnsym3v9j5l9ggdvy70jixbvpcpz4acfz"; type = "gem"; }; version = "0.10.3"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vq1fjp45az9hfp6fxljhdrkv75cvbab1jfrwcw738pnsiqk8zps"; type = "gem"; }; version = "1.3.1"; }; tilt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kds7wkxmb038cwp6ravnwn8k65ixc68wpm8j5jx5bhx8ndg4x6z"; type = "gem"; }; version = "2.4.0"; }; time = { - dependencies = ["date"]; - groups = ["default"]; - platforms = []; + dependencies = [ "date" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0c15v19hyxjcfzaviqlwhgajgyrrlb0pjilza6mkv49bhspy6av6"; type = "gem"; }; version = "0.3.0"; }; timeout = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16mvvsmx90023wrhf8dxc1lpqh0m8alk65shb7xcya6a9gflw7vg"; type = "gem"; }; diff --git a/pkgs/tools/admin/pulumi-bin/update-pulumi-shell.nix b/pkgs/tools/admin/pulumi-bin/update-pulumi-shell.nix index a972b633abb016..8101f1b5b926e3 100644 --- a/pkgs/tools/admin/pulumi-bin/update-pulumi-shell.nix +++ b/pkgs/tools/admin/pulumi-bin/update-pulumi-shell.nix @@ -1,4 +1,6 @@ -{ nixpkgs ? import ../../../.. { } }: +{ + nixpkgs ? import ../../../.. { }, +}: with nixpkgs; mkShell { packages = [ diff --git a/pkgs/tools/admin/pulumi-packages/pulumi-aws-native.nix b/pkgs/tools/admin/pulumi-packages/pulumi-aws-native.nix index 51971963fc3789..af57f166b7029e 100644 --- a/pkgs/tools/admin/pulumi-packages/pulumi-aws-native.nix +++ b/pkgs/tools/admin/pulumi-packages/pulumi-aws-native.nix @@ -1,5 +1,6 @@ -{ lib -, mkPulumiPackage +{ + lib, + mkPulumiPackage, }: mkPulumiPackage rec { owner = "pulumi"; @@ -30,6 +31,9 @@ mkPulumiPackage rec { mainProgram = "pulumi-resource-aws-native"; homepage = "https://github.com/pulumi/pulumi-aws-native"; license = licenses.asl20; - maintainers = with maintainers; [ veehaitch trundle ]; + maintainers = with maintainers; [ + veehaitch + trundle + ]; }; } diff --git a/pkgs/tools/admin/pulumi-packages/pulumi-azure-native.nix b/pkgs/tools/admin/pulumi-packages/pulumi-azure-native.nix index 7b37577da56618..75356bff02218e 100644 --- a/pkgs/tools/admin/pulumi-packages/pulumi-azure-native.nix +++ b/pkgs/tools/admin/pulumi-packages/pulumi-azure-native.nix @@ -1,5 +1,6 @@ -{ lib -, mkPulumiPackage +{ + lib, + mkPulumiPackage, }: mkPulumiPackage rec { owner = "pulumi"; @@ -35,6 +36,9 @@ mkPulumiPackage rec { mainProgram = "pulumi-resource-azure-native"; homepage = "https://github.com/pulumi/pulumi-azure-native"; license = licenses.asl20; - maintainers = with maintainers; [ veehaitch trundle ]; + maintainers = with maintainers; [ + veehaitch + trundle + ]; }; } diff --git a/pkgs/tools/admin/pulumi-packages/pulumi-command.nix b/pkgs/tools/admin/pulumi-packages/pulumi-command.nix index 1fc6df0cfafa55..30910187208b36 100644 --- a/pkgs/tools/admin/pulumi-packages/pulumi-command.nix +++ b/pkgs/tools/admin/pulumi-packages/pulumi-command.nix @@ -1,5 +1,6 @@ -{ lib -, mkPulumiPackage +{ + lib, + mkPulumiPackage, }: mkPulumiPackage rec { owner = "pulumi"; @@ -29,6 +30,9 @@ mkPulumiPackage rec { mainProgram = "pulumi-resource-command"; homepage = "https://github.com/pulumi/pulumi-command"; license = licenses.asl20; - maintainers = with maintainers; [ veehaitch trundle ]; + maintainers = with maintainers; [ + veehaitch + trundle + ]; }; } diff --git a/pkgs/tools/admin/pulumi-packages/pulumi-language-go.nix b/pkgs/tools/admin/pulumi-packages/pulumi-language-go.nix index fe05f336e969bf..01d1fec500c515 100644 --- a/pkgs/tools/admin/pulumi-packages/pulumi-language-go.nix +++ b/pkgs/tools/admin/pulumi-packages/pulumi-language-go.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, pulumi +{ + lib, + buildGoModule, + pulumi, }: buildGoModule rec { pname = "pulumi-language-go"; diff --git a/pkgs/tools/admin/pulumi-packages/pulumi-language-nodejs.nix b/pkgs/tools/admin/pulumi-packages/pulumi-language-nodejs.nix index cca79b1d9607de..3fcd92e58d217c 100644 --- a/pkgs/tools/admin/pulumi-packages/pulumi-language-nodejs.nix +++ b/pkgs/tools/admin/pulumi-packages/pulumi-language-nodejs.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, pulumi -, nodejs +{ + buildGoModule, + pulumi, + nodejs, }: buildGoModule rec { inherit (pulumi) version src; diff --git a/pkgs/tools/admin/pulumi-packages/pulumi-language-python.nix b/pkgs/tools/admin/pulumi-packages/pulumi-language-python.nix index 371a4f7c95fbc7..b685a8ff633599 100644 --- a/pkgs/tools/admin/pulumi-packages/pulumi-language-python.nix +++ b/pkgs/tools/admin/pulumi-packages/pulumi-language-python.nix @@ -1,6 +1,7 @@ -{ buildGoModule -, pulumi -, python3 +{ + buildGoModule, + pulumi, + python3, }: buildGoModule rec { inherit (pulumi) version src; diff --git a/pkgs/tools/admin/pulumi-packages/pulumi-random.nix b/pkgs/tools/admin/pulumi-packages/pulumi-random.nix index 6fcf4b2d5ccc37..63461ae1371367 100644 --- a/pkgs/tools/admin/pulumi-packages/pulumi-random.nix +++ b/pkgs/tools/admin/pulumi-packages/pulumi-random.nix @@ -1,5 +1,6 @@ -{ lib -, mkPulumiPackage +{ + lib, + mkPulumiPackage, }: mkPulumiPackage rec { owner = "pulumi"; @@ -19,6 +20,9 @@ mkPulumiPackage rec { mainProgram = "pulumi-resource-random"; homepage = "https://github.com/pulumi/pulumi-random"; license = licenses.asl20; - maintainers = with maintainers; [ veehaitch trundle ]; + maintainers = with maintainers; [ + veehaitch + trundle + ]; }; } diff --git a/pkgs/tools/admin/pulumi-packages/pulumi-yandex-unofficial.nix b/pkgs/tools/admin/pulumi-packages/pulumi-yandex-unofficial.nix index 52079fbda066e6..f74d82ec1268b5 100644 --- a/pkgs/tools/admin/pulumi-packages/pulumi-yandex-unofficial.nix +++ b/pkgs/tools/admin/pulumi-packages/pulumi-yandex-unofficial.nix @@ -1,5 +1,6 @@ -{ lib -, mkPulumiPackage +{ + lib, + mkPulumiPackage, }: # Note that we are not using https://github.com/pulumi/pulumi-yandex because # it has been archived in 2022. @@ -21,7 +22,11 @@ mkPulumiPackage rec { description = "Unofficial Yandex Cloud Resource Provider"; homepage = "https://github.com/Regrau/pulumi-yandex"; license = licenses.asl20; - maintainers = with maintainers; [ tie veehaitch trundle ]; + maintainers = with maintainers; [ + tie + veehaitch + trundle + ]; mainProgram = cmdRes; }; } diff --git a/pkgs/tools/admin/trinsic-cli/default.nix b/pkgs/tools/admin/trinsic-cli/default.nix index afa431ecd76fdf..06926669fc7598 100644 --- a/pkgs/tools/admin/trinsic-cli/default.nix +++ b/pkgs/tools/admin/trinsic-cli/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, rustPlatform, fetchurl, Security }: +{ + lib, + stdenv, + rustPlatform, + fetchurl, + Security, +}: rustPlatform.buildRustPackage rec { pname = "trinsic-cli"; diff --git a/pkgs/tools/admin/turbovnc/default.nix b/pkgs/tools/admin/turbovnc/default.nix index ed3c873d162f69..c78086181e189e 100644 --- a/pkgs/tools/admin/turbovnc/default.nix +++ b/pkgs/tools/admin/turbovnc/default.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchFromGitHub -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + nixosTests, -# Dependencies -, bzip2 -, cmake -, freetype -, libGL -, libjpeg_turbo -, makeWrapper -, mesa # for built-in 3D software rendering using swrast -, openjdk # for the client with Java GUI -, openjdk_headless # for the server -, openssh -, openssl -, pam -, perl -, pkg-config -, python3 -, which -, xkbcomp -, xkeyboard_config -, xorg -, xterm -, zlib + # Dependencies + bzip2, + cmake, + freetype, + libGL, + libjpeg_turbo, + makeWrapper, + mesa, # for built-in 3D software rendering using swrast + openjdk, # for the client with Java GUI + openjdk_headless, # for the server + openssh, + openssl, + pam, + perl, + pkg-config, + python3, + which, + xkbcomp, + xkeyboard_config, + xorg, + xterm, + zlib, }: stdenv.mkDerivation (finalAttrs: { @@ -58,30 +59,32 @@ stdenv.mkDerivation (finalAttrs: { python3 ]; - buildInputs = [ - bzip2 - freetype - libGL # for -DTVNC_SYSTEMX11=1 - libjpeg_turbo - openssl - pam - perl - zlib - ] ++ (with xorg; [ - libfontenc # for -DTVNC_SYSTEMX11=1 - libSM - libX11 - libXdamage # for -DTVNC_SYSTEMX11=1 - libXdmcp # for -DTVNC_SYSTEMX11=1 - libXext - libXfont2 # for -DTVNC_SYSTEMX11=1 - libxkbfile # for -DTVNC_SYSTEMX11=1 - libXi - mesa # for -DTVNC_SYSTEMX11=1 - pixman # for -DTVNC_SYSTEMX11=1 - xorgproto - xtrans # for -DTVNC_SYSTEMX11=1 - ]); + buildInputs = + [ + bzip2 + freetype + libGL # for -DTVNC_SYSTEMX11=1 + libjpeg_turbo + openssl + pam + perl + zlib + ] + ++ (with xorg; [ + libfontenc # for -DTVNC_SYSTEMX11=1 + libSM + libX11 + libXdamage # for -DTVNC_SYSTEMX11=1 + libXdmcp # for -DTVNC_SYSTEMX11=1 + libXext + libXfont2 # for -DTVNC_SYSTEMX11=1 + libxkbfile # for -DTVNC_SYSTEMX11=1 + libXi + mesa # for -DTVNC_SYSTEMX11=1 + pixman # for -DTVNC_SYSTEMX11=1 + xorgproto + xtrans # for -DTVNC_SYSTEMX11=1 + ]); postPatch = '' substituteInPlace unix/Xvnc/CMakeLists.txt --replace 'string(REGEX REPLACE "X11" "Xfont2" X11_Xfont2_LIB' 'set(X11_Xfont2_LIB ${xorg.libXfont2}/lib/libXfont2.so) #' @@ -118,7 +121,14 @@ stdenv.mkDerivation (finalAttrs: { # It checks for it using `which twm`. # vncserver needs also needs `xauth` and we add in `xterm` for convenience wrapProgram $out/bin/vncserver \ - --prefix PATH : ${lib.makeBinPath [ which xorg.twm xorg.xauth xterm ]} + --prefix PATH : ${ + lib.makeBinPath [ + which + xorg.twm + xorg.xauth + xterm + ] + } # Patch /usr/bin/perl patchShebangs $out/bin/vncserver diff --git a/pkgs/tools/archivers/arj/default.nix b/pkgs/tools/archivers/arj/default.nix index 5ec946788d927f..ad512f5834b503 100644 --- a/pkgs/tools/archivers/arj/default.nix +++ b/pkgs/tools/archivers/arj/default.nix @@ -1,4 +1,10 @@ -{stdenv, lib, fetchurl, fetchpatch, autoreconfHook}: +{ + stdenv, + lib, + fetchurl, + fetchpatch, + autoreconfHook, +}: stdenv.mkDerivation rec { pname = "arj"; diff --git a/pkgs/tools/archivers/gbl/default.nix b/pkgs/tools/archivers/gbl/default.nix index 6bbc31a6b1c622..889c6b5ad1a7c5 100644 --- a/pkgs/tools/archivers/gbl/default.nix +++ b/pkgs/tools/archivers/gbl/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, fetchpatch -, pkg-config -, openssl -, testers -, gbl -, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + fetchpatch, + pkg-config, + openssl, + testers, + gbl, + Security, }: rustPlatform.buildRustPackage rec { @@ -40,8 +41,7 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; - passthru.tests.version = - testers.testVersion { package = gbl; }; + passthru.tests.version = testers.testVersion { package = gbl; }; meta = with lib; { description = "GBL Firmware file manipulation"; diff --git a/pkgs/tools/archivers/gnutar/default.nix b/pkgs/tools/archivers/gnutar/default.nix index 292b39738dfc78..02eae53b58e023 100644 --- a/pkgs/tools/archivers/gnutar/default.nix +++ b/pkgs/tools/archivers/gnutar/default.nix @@ -1,6 +1,12 @@ -{ lib, stdenv, fetchurl, autoreconfHook, updateAutotoolsGnuConfigScriptsHook -, libintl -, aclSupport ? lib.meta.availableOn stdenv.hostPlatform acl, acl +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + updateAutotoolsGnuConfigScriptsHook, + libintl, + aclSupport ? lib.meta.availableOn stdenv.hostPlatform acl, + acl, }: # Note: this package is used for bootstrapping fetchurl, and thus @@ -28,7 +34,10 @@ stdenv.mkDerivation rec { substituteInPlace src/system.c --replace '_(' 'N_(' ''; - outputs = [ "out" "info" ]; + outputs = [ + "out" + "info" + ]; nativeBuildInputs = [ autoreconfHook ]; @@ -41,11 +50,17 @@ stdenv.mkDerivation rec { # May have some issues with root compilation because the bootstrap tool # cannot be used as a login shell for now. - FORCE_UNSAFE_CONFIGURE = lib.optionalString (stdenv.hostPlatform.system == "armv7l-linux" || stdenv.hostPlatform.isSunOS) "1"; - - preConfigure = if stdenv.hostPlatform.isCygwin then '' - sed -i gnu/fpending.h -e 's,include ,,' - '' else null; + FORCE_UNSAFE_CONFIGURE = lib.optionalString ( + stdenv.hostPlatform.system == "armv7l-linux" || stdenv.hostPlatform.isSunOS + ) "1"; + + preConfigure = + if stdenv.hostPlatform.isCygwin then + '' + sed -i gnu/fpending.h -e 's,include ,,' + '' + else + null; doCheck = false; # fails doInstallCheck = false; # fails diff --git a/pkgs/tools/archivers/p7zip/default.nix b/pkgs/tools/archivers/p7zip/default.nix index e77904e120d601..7faa76e01ee8b1 100644 --- a/pkgs/tools/archivers/p7zip/default.nix +++ b/pkgs/tools/archivers/p7zip/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, enableUnfree ? false }: +{ + lib, + stdenv, + fetchFromGitHub, + enableUnfree ? false, +}: stdenv.mkDerivation (finalAttrs: { pname = "p7zip"; @@ -8,10 +13,12 @@ stdenv.mkDerivation (finalAttrs: { owner = "p7zip-project"; repo = "p7zip"; rev = "v${finalAttrs.version}"; - sha256 = { - free = "sha256-5r7M9BVcAryZNTkqJ/BfHnSSWov1PwoZhUnLBwEbJoA="; - unfree = "sha256-z3qXgv/TkNRbb85Ew1OcJNxoyssfzHShc0b0/4NZOb0="; - }.${if enableUnfree then "unfree" else "free"}; + sha256 = + { + free = "sha256-5r7M9BVcAryZNTkqJ/BfHnSSWov1PwoZhUnLBwEbJoA="; + unfree = "sha256-z3qXgv/TkNRbb85Ew1OcJNxoyssfzHShc0b0/4NZOb0="; + } + .${if enableUnfree then "unfree" else "free"}; # remove the unRAR related code from the src drv # > the license requires that you agree to these use restrictions, # > or you must remove the software (source and binary) from your hard disks @@ -23,26 +30,30 @@ stdenv.mkDerivation (finalAttrs: { }; # Default makefile is full of impurities on Darwin. The patch doesn't hurt Linux so I'm leaving it unconditional - postPatch = '' - sed -i '/CC=\/usr/d' makefile.macosx_llvm_64bits - # Avoid writing timestamps into compressed manpages - # to maintain determinism. - substituteInPlace install.sh --replace 'gzip' 'gzip -n' - chmod +x install.sh + postPatch = + '' + sed -i '/CC=\/usr/d' makefile.macosx_llvm_64bits + # Avoid writing timestamps into compressed manpages + # to maintain determinism. + substituteInPlace install.sh --replace 'gzip' 'gzip -n' + chmod +x install.sh - # I think this is a typo and should be CXX? Either way let's kill it - sed -i '/XX=\/usr/d' makefile.macosx_llvm_64bits - '' + lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' - substituteInPlace makefile.machine \ - --replace 'CC=gcc' 'CC=${stdenv.cc.targetPrefix}gcc' \ - --replace 'CXX=g++' 'CXX=${stdenv.cc.targetPrefix}g++' - ''; + # I think this is a typo and should be CXX? Either way let's kill it + sed -i '/XX=\/usr/d' makefile.macosx_llvm_64bits + '' + + lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' + substituteInPlace makefile.machine \ + --replace 'CC=gcc' 'CC=${stdenv.cc.targetPrefix}gcc' \ + --replace 'CXX=g++' 'CXX=${stdenv.cc.targetPrefix}g++' + ''; - preConfigure = '' - buildFlags=all3 - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - cp makefile.macosx_llvm_64bits makefile.machine - ''; + preConfigure = + '' + buildFlags=all3 + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + cp makefile.macosx_llvm_64bits makefile.machine + ''; enableParallelBuilding = true; env.NIX_CFLAGS_COMPILE = lib.optionalString stdenv.cc.isClang "-Wno-error=c++11-narrowing"; @@ -54,7 +65,12 @@ stdenv.mkDerivation (finalAttrs: { "DEST_SHARE_DOC=${placeholder "doc"}/share/doc/p7zip" ]; - outputs = [ "out" "lib" "doc" "man" ]; + outputs = [ + "out" + "lib" + "doc" + "man" + ]; setupHook = ./setup-hook.sh; passthru.updateScript = ./update.sh; @@ -62,14 +78,22 @@ stdenv.mkDerivation (finalAttrs: { meta = with lib; { homepage = "https://github.com/p7zip-project/p7zip"; description = "New p7zip fork with additional codecs and improvements (forked from https://sourceforge.net/projects/p7zip/)"; - license = with licenses; + license = + with licenses; # p7zip code is largely lgpl2Plus # CPP/7zip/Compress/LzfseDecoder.cpp is bsd3 - [ lgpl2Plus /* and */ bsd3 ] ++ - # and CPP/7zip/Compress/Rar* are unfree with the unRAR license restriction - # the unRAR compression code is disabled by default - lib.optionals enableUnfree [ unfree ]; - maintainers = with maintainers; [ raskin jk ]; + [ + lgpl2Plus # and + bsd3 + ] + ++ + # and CPP/7zip/Compress/Rar* are unfree with the unRAR license restriction + # the unRAR compression code is disabled by default + lib.optionals enableUnfree [ unfree ]; + maintainers = with maintainers; [ + raskin + jk + ]; platforms = platforms.unix; mainProgram = "7z"; }; diff --git a/pkgs/tools/archivers/pax/default.nix b/pkgs/tools/archivers/pax/default.nix index b486f5e353d283..bc1673b9d7f9a9 100644 --- a/pkgs/tools/archivers/pax/default.nix +++ b/pkgs/tools/archivers/pax/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, utmp, musl-fts }: +{ + lib, + stdenv, + fetchurl, + utmp, + musl-fts, +}: stdenv.mkDerivation rec { pname = "pax"; @@ -9,7 +15,8 @@ stdenv.mkDerivation rec { sha256 = "sha256-6VXV06+Xrt4KP0Y6mlm4Po0Qg6rxQutvOIxUmn0YLms="; }; - buildInputs = lib.optional stdenv.hostPlatform.isDarwin utmp + buildInputs = + lib.optional stdenv.hostPlatform.isDarwin utmp ++ lib.optional stdenv.hostPlatform.isMusl musl-fts; NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isMusl "-lfts"; diff --git a/pkgs/tools/archivers/quickbms/default.nix b/pkgs/tools/archivers/quickbms/default.nix index 9c3aa89774bfd1..15e2a2e4d91e52 100644 --- a/pkgs/tools/archivers/quickbms/default.nix +++ b/pkgs/tools/archivers/quickbms/default.nix @@ -1,12 +1,13 @@ -{ stdenv -, lib -, fetchzip -, fetchpatch -, bzip2 -, lzo -, openssl_1_1 -, opensslSupport ? false -, zlib +{ + stdenv, + lib, + fetchzip, + fetchpatch, + bzip2, + lzo, + openssl_1_1, + opensslSupport ? false, + zlib, }: stdenv.mkDerivation rec { @@ -28,8 +29,11 @@ stdenv.mkDerivation rec { }) ] ++ lib.optional (!opensslSupport) ./0002-disable-openssl.patch; - buildInputs = [ bzip2 lzo zlib ] - ++ lib.optional (opensslSupport) openssl_1_1; + buildInputs = [ + bzip2 + lzo + zlib + ] ++ lib.optional (opensslSupport) openssl_1_1; makeFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/tools/archivers/rar/default.nix b/pkgs/tools/archivers/rar/default.nix index fb95f4de5650ab..dedd67f20cd3f2 100644 --- a/pkgs/tools/archivers/rar/default.nix +++ b/pkgs/tools/archivers/rar/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, installShellFiles +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + installShellFiles, }: let @@ -37,14 +38,17 @@ stdenv.mkDerivation { pname = "rar"; inherit version; - src = fetchurl (srcs.${stdenv.hostPlatform.system} or (throw "unsupported system ${stdenv.hostPlatform.system}")); + src = fetchurl ( + srcs.${stdenv.hostPlatform.system} or (throw "unsupported system ${stdenv.hostPlatform.system}") + ); dontBuild = true; buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ (lib.getLib stdenv.cc.cc) ]; - nativeBuildInputs = [ installShellFiles ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ autoPatchelfHook ]; + nativeBuildInputs = [ + installShellFiles + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ autoPatchelfHook ]; installPhase = '' runHook preInstall diff --git a/pkgs/tools/archivers/unrar-wrapper/default.nix b/pkgs/tools/archivers/unrar-wrapper/default.nix index 7452969cbdb4a1..0355624b27642f 100644 --- a/pkgs/tools/archivers/unrar-wrapper/default.nix +++ b/pkgs/tools/archivers/unrar-wrapper/default.nix @@ -1,4 +1,9 @@ -{ lib, buildPythonApplication, fetchFromGitHub, unar }: +{ + lib, + buildPythonApplication, + fetchFromGitHub, + unar, +}: buildPythonApplication rec { pname = "unrar-wrapper"; @@ -12,7 +17,10 @@ buildPythonApplication rec { }; makeWrapperArgs = [ - "--prefix" "PATH" ":" "${lib.makeBinPath [ unar ]}" + "--prefix" + "PATH" + ":" + "${lib.makeBinPath [ unar ]}" ]; postFixup = '' diff --git a/pkgs/tools/archivers/zpaq/default.nix b/pkgs/tools/archivers/zpaq/default.nix index 791c4fd14f3a0d..af927a4a45de98 100644 --- a/pkgs/tools/archivers/zpaq/default.nix +++ b/pkgs/tools/archivers/zpaq/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, perl }: +{ + lib, + stdenv, + fetchFromGitHub, + perl, +}: stdenv.mkDerivation rec { pname = "zpaq"; @@ -11,11 +16,17 @@ stdenv.mkDerivation rec { sha256 = "0v44rlg9gvwc4ggr2lhcqll8ppal3dk7zsg5bqwcc5lg3ynk2pz4"; }; - nativeBuildInputs = [ perl /* for pod2man */ ]; + nativeBuildInputs = [ + perl # for pod2man + ]; - CPPFLAGS = [ "-Dunix" ] ++ - lib.optional (!stdenv.hostPlatform.isi686 && !stdenv.hostPlatform.isx86_64) "-DNOJIT"; - CXXFLAGS = [ "-O3" "-DNDEBUG" ]; + CPPFLAGS = [ + "-Dunix" + ] ++ lib.optional (!stdenv.hostPlatform.isi686 && !stdenv.hostPlatform.isx86_64) "-DNOJIT"; + CXXFLAGS = [ + "-O3" + "-DNDEBUG" + ]; enableParallelBuilding = true; @@ -25,7 +36,7 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Incremental journaling backup utility and archiver"; homepage = "http://mattmahoney.net/dc/zpaq.html"; - license = licenses.gpl3Plus ; + license = licenses.gpl3Plus; maintainers = with maintainers; [ raskin ]; platforms = platforms.unix; mainProgram = "zpaq"; diff --git a/pkgs/tools/archivers/zpaq/zpaqd.nix b/pkgs/tools/archivers/zpaq/zpaqd.nix index 07ef4db4d6b059..7a56de6a2cd2b0 100644 --- a/pkgs/tools/archivers/zpaq/zpaqd.nix +++ b/pkgs/tools/archivers/zpaq/zpaqd.nix @@ -1,9 +1,19 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: let - compileFlags = lib.concatStringsSep " " ([ "-O3" "-DNDEBUG" ] + compileFlags = lib.concatStringsSep " " ( + [ + "-O3" + "-DNDEBUG" + ] ++ lib.optional (stdenv.hostPlatform.isUnix) "-Dunix -pthread" - ++ lib.optional (!stdenv.hostPlatform.isx86) "-DNOJIT"); + ++ lib.optional (!stdenv.hostPlatform.isx86) "-DNOJIT" + ); in stdenv.mkDerivation rec { pname = "zpaqd"; diff --git a/pkgs/tools/audio/kaldi/default.nix b/pkgs/tools/audio/kaldi/default.nix index 9a2eb15fee14c8..9f023b67d5cfaf 100644 --- a/pkgs/tools/audio/kaldi/default.nix +++ b/pkgs/tools/audio/kaldi/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, openblas -, blas -, lapack -, icu -, cmake -, pkg-config -, fetchFromGitHub -, python3 -, Accelerate -, _experimental-update-script-combinators -, common-updater-scripts -, ripgrep -, unstableGitUpdater -, writeShellScript +{ + lib, + stdenv, + openblas, + blas, + lapack, + icu, + cmake, + pkg-config, + fetchFromGitHub, + python3, + Accelerate, + _experimental-update-script-combinators, + common-updater-scripts, + ripgrep, + unstableGitUpdater, + writeShellScript, }: assert blas.implementation == "openblas" && lapack.implementation == "openblas"; @@ -36,12 +37,14 @@ stdenv.mkDerivation (finalAttrs: { "-DFETCHCONTENT_SOURCE_DIR_OPENFST:PATH=${finalAttrs.passthru.sources.openfst}" ]; - buildInputs = [ - openblas - icu - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Accelerate - ]; + buildInputs = + [ + openblas + icu + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Accelerate + ]; nativeBuildInputs = [ cmake @@ -77,7 +80,7 @@ stdenv.mkDerivation (finalAttrs: { updateScript = let - updateSource = unstableGitUpdater {}; + updateSource = unstableGitUpdater { }; updateOpenfst = writeShellScript "update-openfst" '' hash=$(${ripgrep}/bin/rg --multiline --pcre2 --only-matching 'FetchContent_Declare\(\s*openfst[^)]*GIT_TAG\s*([0-9a-f]{40})' --replace '$1' "${finalAttrs.src}/cmake/third_party/openfst.cmake") ${common-updater-scripts}/bin/update-source-version kaldi.sources.openfst "$hash" --source-key=out "--version-key=rev" diff --git a/pkgs/tools/audio/liquidsoap/full.nix b/pkgs/tools/audio/liquidsoap/full.nix index a845f467775480..0d526b2ce6aa97 100644 --- a/pkgs/tools/audio/liquidsoap/full.nix +++ b/pkgs/tools/audio/liquidsoap/full.nix @@ -1,8 +1,24 @@ -{ lib, stdenv, makeWrapper, fetchFromGitHub, which, pkg-config -, libjpeg -, ocamlPackages -, awscli2, bubblewrap, curl, ffmpeg, yt-dlp -, runtimePackages ? [ awscli2 bubblewrap curl ffmpeg yt-dlp ] +{ + lib, + stdenv, + makeWrapper, + fetchFromGitHub, + which, + pkg-config, + libjpeg, + ocamlPackages, + awscli2, + bubblewrap, + curl, + ffmpeg, + yt-dlp, + runtimePackages ? [ + awscli2 + bubblewrap + curl + ffmpeg + yt-dlp + ], }: let @@ -136,8 +152,11 @@ stdenv.mkDerivation { mainProgram = "liquidsoap"; homepage = "https://www.liquidsoap.info/"; changelog = "https://raw.githubusercontent.com/savonet/liquidsoap/main/CHANGES.md"; - maintainers = with lib.maintainers; [ dandellion ehmry ]; + maintainers = with lib.maintainers; [ + dandellion + ehmry + ]; license = lib.licenses.gpl2Plus; - platforms = ocamlPackages.ocaml.meta.platforms or []; + platforms = ocamlPackages.ocaml.meta.platforms or [ ]; }; } diff --git a/pkgs/tools/audio/mpd-sima/default.nix b/pkgs/tools/audio/mpd-sima/default.nix index 7752f9d1bf22ae..cd8196e1b1e58e 100644 --- a/pkgs/tools/audio/mpd-sima/default.nix +++ b/pkgs/tools/audio/mpd-sima/default.nix @@ -1,8 +1,10 @@ -{ lib -, buildPythonApplication -, fetchFromGitLab -, python-musicpd -, requests}: +{ + lib, + buildPythonApplication, + fetchFromGitLab, + python-musicpd, + requests, +}: buildPythonApplication rec { pname = "mpd-sima"; @@ -11,7 +13,7 @@ buildPythonApplication rec { src = fetchFromGitLab { owner = "kaliko"; repo = "sima"; - rev = version; + rev = version; hash = "sha256-lMvM1EqS1govhv4B2hJzIg5DFQYgEr4yJJtgOQxnVlY="; }; diff --git a/pkgs/tools/audio/opl3bankeditor/common.nix b/pkgs/tools/audio/opl3bankeditor/common.nix index abbd24efd87e8e..8c0ce9eabfee3f 100644 --- a/pkgs/tools/audio/opl3bankeditor/common.nix +++ b/pkgs/tools/audio/opl3bankeditor/common.nix @@ -1,17 +1,24 @@ -{ pname, chip, version, sha256, extraPatches ? [] }: +{ + pname, + chip, + version, + sha256, + extraPatches ? [ ], +}: -{ mkDerivation -, stdenv -, lib -, fetchFromGitHub -, dos2unix -, cmake -, pkg-config -, qttools -, qtbase -, qwt6_1 -, rtaudio -, rtmidi +{ + mkDerivation, + stdenv, + lib, + fetchFromGitHub, + dos2unix, + cmake, + pkg-config, + qttools, + qtbase, + qwt6_1, + rtaudio, + rtmidi, }: let diff --git a/pkgs/tools/audio/piper/default.nix b/pkgs/tools/audio/piper/default.nix index eff78d05bf512b..336c05cb35ea1a 100644 --- a/pkgs/tools/audio/piper/default.nix +++ b/pkgs/tools/audio/piper/default.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub +{ + lib, + stdenv, + fetchFromGitHub, -# build time -, cmake -, pkg-config + # build time + cmake, + pkg-config, -# runtime -, fmt -, onnxruntime -, pcaudiolib -, piper-phonemize -, spdlog + # runtime + fmt, + onnxruntime, + pcaudiolib, + piper-phonemize, + spdlog, -# tests -, piper-train + # tests + piper-train, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/tools/audio/piper/train.nix b/pkgs/tools/audio/piper/train.nix index 476138e7883799..fa781ca4ab2dde 100644 --- a/pkgs/tools/audio/piper/train.nix +++ b/pkgs/tools/audio/piper/train.nix @@ -1,5 +1,6 @@ -{ piper-tts -, python3 +{ + piper-tts, + python3, }: let diff --git a/pkgs/tools/audio/qastools/default.nix b/pkgs/tools/audio/qastools/default.nix index f8b705a8fa153d..37af3d9e7a61fd 100644 --- a/pkgs/tools/audio/qastools/default.nix +++ b/pkgs/tools/audio/qastools/default.nix @@ -1,4 +1,14 @@ -{ mkDerivation, lib, fetchFromGitLab, cmake, alsa-lib, udev, qtbase, qtsvg, qttools }: +{ + mkDerivation, + lib, + fetchFromGitLab, + cmake, + alsa-lib, + udev, + qtbase, + qtsvg, + qttools, +}: mkDerivation rec { pname = "qastools"; @@ -12,7 +22,13 @@ mkDerivation rec { }; nativeBuildInputs = [ cmake ]; - buildInputs = [ alsa-lib udev qtbase qtsvg qttools ]; + buildInputs = [ + alsa-lib + udev + qtbase + qtsvg + qttools + ]; meta = with lib; { description = "Collection of desktop applications for ALSA configuration"; diff --git a/pkgs/tools/audio/tidal-dl/default.nix b/pkgs/tools/audio/tidal-dl/default.nix index eb7c597d2d75f4..cbc65e76561179 100644 --- a/pkgs/tools/audio/tidal-dl/default.nix +++ b/pkgs/tools/audio/tidal-dl/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildPythonApplication -, fetchPypi -, aigpy +{ + lib, + buildPythonApplication, + fetchPypi, + aigpy, }: buildPythonApplication rec { diff --git a/pkgs/tools/audio/video2midi/default.nix b/pkgs/tools/audio/video2midi/default.nix index 5d5cf08c8974f6..fac1ba01dc9a8e 100644 --- a/pkgs/tools/audio/video2midi/default.nix +++ b/pkgs/tools/audio/video2midi/default.nix @@ -1,12 +1,20 @@ -{ lib, fetchFromGitHub, pythonPackages, opencv4 }: +{ + lib, + fetchFromGitHub, + pythonPackages, + opencv4, +}: let - opencv4_ = pythonPackages.toPythonModule (opencv4.override { - inherit pythonPackages; - enablePython = true; - enableFfmpeg = true; - }); -in pythonPackages.buildPythonApplication rec { + opencv4_ = pythonPackages.toPythonModule ( + opencv4.override { + inherit pythonPackages; + enablePython = true; + enableFfmpeg = true; + } + ); +in +pythonPackages.buildPythonApplication rec { pname = "video2midi"; version = "0.4.9"; @@ -19,7 +27,12 @@ in pythonPackages.buildPythonApplication rec { sha256 = "sha256-mjqlNUCEiP5dQS0a8HAejOJyEvY6jGFJFpVcnzU2Vds="; }; - propagatedBuildInputs = with pythonPackages; [ opencv4_ midiutil pygame pyopengl ]; + propagatedBuildInputs = with pythonPackages; [ + opencv4_ + midiutil + pygame + pyopengl + ]; installPhase = '' install -Dm755 v2m.py $out/bin/v2m.py diff --git a/pkgs/tools/audio/wyoming/faster-whisper.nix b/pkgs/tools/audio/wyoming/faster-whisper.nix index 3ed21f60d158dd..7ac5ea4b0562ed 100644 --- a/pkgs/tools/audio/wyoming/faster-whisper.nix +++ b/pkgs/tools/audio/wyoming/faster-whisper.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/tools/audio/wyoming/openwakeword.nix b/pkgs/tools/audio/wyoming/openwakeword.nix index 1610f45c2a7f50..83339d62cee589 100644 --- a/pkgs/tools/audio/wyoming/openwakeword.nix +++ b/pkgs/tools/audio/wyoming/openwakeword.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/tools/audio/wyoming/piper.nix b/pkgs/tools/audio/wyoming/piper.nix index ed79d289c0d86c..f85c634cd34308 100644 --- a/pkgs/tools/audio/wyoming/piper.nix +++ b/pkgs/tools/audio/wyoming/piper.nix @@ -1,6 +1,7 @@ -{ lib -, python3Packages -, fetchFromGitHub +{ + lib, + python3Packages, + fetchFromGitHub, }: python3Packages.buildPythonApplication rec { diff --git a/pkgs/tools/audio/yabridge/default.nix b/pkgs/tools/audio/yabridge/default.nix index 540ffb8eaff320..fc258317b1b228 100644 --- a/pkgs/tools/audio/yabridge/default.nix +++ b/pkgs/tools/audio/yabridge/default.nix @@ -1,15 +1,16 @@ -{ lib -, multiStdenv -, fetchFromGitHub -, substituteAll -, pkgsi686Linux -, dbus -, meson -, ninja -, pkg-config -, wine -, libxcb -, nix-update-script +{ + lib, + multiStdenv, + fetchFromGitHub, + substituteAll, + pkgsi686Linux, + dbus, + meson, + ninja, + pkg-config, + wine, + libxcb, + nix-update-script, }: let @@ -134,7 +135,8 @@ multiStdenv.mkDerivation (finalAttrs: { ]; mesonFlags = [ - "--cross-file" "cross-wine.conf" + "--cross-file" + "cross-wine.conf" "-Dbitbridge=true" # Requires CMake and is unnecessary diff --git a/pkgs/tools/audio/yabridgectl/default.nix b/pkgs/tools/audio/yabridgectl/default.nix index 98b078056da18a..4e69dc8462da13 100644 --- a/pkgs/tools/audio/yabridgectl/default.nix +++ b/pkgs/tools/audio/yabridgectl/default.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, yabridge -, makeWrapper -, wine +{ + lib, + rustPlatform, + yabridge, + makeWrapper, + wine, }: rustPlatform.buildRustPackage { @@ -32,9 +33,11 @@ rustPlatform.buildRustPackage { postFixup = '' wrapProgram "$out/bin/yabridgectl" \ - --prefix PATH : ${lib.makeBinPath [ - wine # winedump - ]} + --prefix PATH : ${ + lib.makeBinPath [ + wine # winedump + ] + } ''; meta = with lib; { diff --git a/pkgs/tools/backup/awsbck/default.nix b/pkgs/tools/backup/awsbck/default.nix index a853a704b9d3ee..097143e5442117 100644 --- a/pkgs/tools/backup/awsbck/default.nix +++ b/pkgs/tools/backup/awsbck/default.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, rustPlatform +{ + lib, + fetchFromGitHub, + rustPlatform, }: rustPlatform.buildRustPackage rec { @@ -22,7 +23,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Backup a folder to AWS S3, once or periodically"; homepage = "https://github.com/beeb/awsbck"; - license = with licenses; [ mit asl20 ]; + license = with licenses; [ + mit + asl20 + ]; maintainers = with maintainers; [ beeb ]; mainProgram = "awsbck"; }; diff --git a/pkgs/tools/backup/bacula/default.nix b/pkgs/tools/backup/bacula/default.nix index 5ab53918d1495c..7e63b75652966c 100644 --- a/pkgs/tools/backup/bacula/default.nix +++ b/pkgs/tools/backup/bacula/default.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchurl, sqlite, postgresql, zlib, acl, ncurses, openssl, readline -, gettext, CoreFoundation, IOKit, Kerberos +{ + lib, + stdenv, + fetchurl, + sqlite, + postgresql, + zlib, + acl, + ncurses, + openssl, + readline, + gettext, + CoreFoundation, + IOKit, + Kerberos, }: stdenv.mkDerivation rec { @@ -7,7 +20,7 @@ stdenv.mkDerivation rec { version = "15.0.2"; src = fetchurl { - url = "mirror://sourceforge/bacula/${pname}-${version}.tar.gz"; + url = "mirror://sourceforge/bacula/${pname}-${version}.tar.gz"; sha256 = "sha256-VVFcKmavmoa5VdrqQIk3i4ZNBRsubjA4O+825pOs6no="; }; @@ -17,7 +30,15 @@ stdenv.mkDerivation rec { --replace "10.*)" "*)" ''; - buildInputs = [ postgresql sqlite zlib ncurses openssl readline ] + buildInputs = + [ + postgresql + sqlite + zlib + ncurses + openssl + readline + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ gettext # bacula requires CoreFoundation, but its `configure` script will only link it when it detects libintl. CoreFoundation @@ -27,19 +48,21 @@ stdenv.mkDerivation rec { # acl relies on attr, which I can't get to build on darwin ++ lib.optional (!stdenv.hostPlatform.isDarwin) acl; - configureFlags = [ - "--with-sqlite3=${sqlite.dev}" - "--with-postgresql=${lib.getDev postgresql}" - "--with-logdir=/var/log/bacula" - "--with-working-dir=/var/lib/bacula" - "--mandir=\${out}/share/man" - ] ++ lib.optional (stdenv.buildPlatform != stdenv.hostPlatform) "ac_cv_func_setpgrp_void=yes" + configureFlags = + [ + "--with-sqlite3=${sqlite.dev}" + "--with-postgresql=${lib.getDev postgresql}" + "--with-logdir=/var/log/bacula" + "--with-working-dir=/var/lib/bacula" + "--mandir=\${out}/share/man" + ] + ++ lib.optional (stdenv.buildPlatform != stdenv.hostPlatform) "ac_cv_func_setpgrp_void=yes" ++ lib.optionals stdenv.hostPlatform.isDarwin [ # bacula’s `configure` script fails to detect CoreFoundation correctly, # but these symbols are available in the nixpkgs CoreFoundation framework. "gt_cv_func_CFLocaleCopyCurrent=yes" "gt_cv_func_CFPreferencesCopyAppValue=yes" - ]; + ]; installFlags = [ "logdir=\${out}/logdir" @@ -53,9 +76,15 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Enterprise ready, Network Backup Tool"; - homepage = "http://bacula.org/"; - license = with licenses; [ agpl3Only bsd2 ]; - maintainers = with maintainers; [ lovek323 eleanor ]; - platforms = platforms.all; + homepage = "http://bacula.org/"; + license = with licenses; [ + agpl3Only + bsd2 + ]; + maintainers = with maintainers; [ + lovek323 + eleanor + ]; + platforms = platforms.all; }; } diff --git a/pkgs/tools/backup/bupstash/default.nix b/pkgs/tools/backup/bupstash/default.nix index c164c2ecc96b76..5897238ef42ab0 100644 --- a/pkgs/tools/backup/bupstash/default.nix +++ b/pkgs/tools/backup/bupstash/default.nix @@ -1,4 +1,12 @@ -{ lib, fetchFromGitHub, installShellFiles, rustPlatform, ronn, pkg-config, libsodium }: +{ + lib, + fetchFromGitHub, + installShellFiles, + rustPlatform, + ronn, + pkg-config, + libsodium, +}: rustPlatform.buildRustPackage rec { pname = "bupstash"; version = "0.12.0"; @@ -12,7 +20,11 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-hkGmE7WseEjMxmmPyR8C4osbdbpIt8qG9sfVGuC4d84="; - nativeBuildInputs = [ ronn pkg-config installShellFiles ]; + nativeBuildInputs = [ + ronn + pkg-config + installShellFiles + ]; buildInputs = [ libsodium ]; postBuild = '' diff --git a/pkgs/tools/backup/httrack/default.nix b/pkgs/tools/backup/httrack/default.nix index 8ac3bf74041236..9187f6ce515708 100644 --- a/pkgs/tools/backup/httrack/default.nix +++ b/pkgs/tools/backup/httrack/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, zlib, openssl, libiconv }: +{ + lib, + stdenv, + fetchurl, + zlib, + openssl, + libiconv, +}: stdenv.mkDerivation rec { version = "3.49.2"; @@ -9,14 +16,18 @@ stdenv.mkDerivation rec { sha256 = "09a0gm67nml86qby1k1gh7rdxamnrnzwr6l9r5iiq94favjs0xrl"; }; - buildInputs = [ libiconv openssl zlib ]; + buildInputs = [ + libiconv + openssl + zlib + ]; enableParallelBuilding = true; meta = with lib; { description = "Easy-to-use offline browser / website mirroring utility"; - homepage = "http://www.httrack.com"; - license = licenses.gpl3; - platforms = with platforms; unix; + homepage = "http://www.httrack.com"; + license = licenses.gpl3; + platforms = with platforms; unix; }; } diff --git a/pkgs/tools/backup/httrack/qt.nix b/pkgs/tools/backup/httrack/qt.nix index d178185229fda4..bc9eba0b923b03 100644 --- a/pkgs/tools/backup/httrack/qt.nix +++ b/pkgs/tools/backup/httrack/qt.nix @@ -1,5 +1,15 @@ -{ stdenv, mkDerivation, lib, fetchurl, cmake, pkg-config, makeWrapper -, httrack, qtbase, qtmultimedia }: +{ + stdenv, + mkDerivation, + lib, + fetchurl, + cmake, + pkg-config, + makeWrapper, + httrack, + qtbase, + qtmultimedia, +}: mkDerivation rec { pname = "httraqt"; @@ -10,9 +20,17 @@ mkDerivation rec { sha256 = "0pjxqnqchpbla4xiq4rklc06484n46cpahnjy03n9rghwwcad25b"; }; - buildInputs = [ httrack qtbase qtmultimedia ]; + buildInputs = [ + httrack + qtbase + qtmultimedia + ]; - nativeBuildInputs = [ cmake makeWrapper pkg-config ]; + nativeBuildInputs = [ + cmake + makeWrapper + pkg-config + ]; prePatch = '' substituteInPlace cmake/HTTRAQTFindHttrack.cmake \ @@ -32,9 +50,9 @@ mkDerivation rec { broken = stdenv.hostPlatform.isDarwin; description = "Easy-to-use offline browser / website mirroring utility - QT frontend"; mainProgram = "httraqt"; - homepage = "http://www.httrack.com"; - license = licenses.gpl3; + homepage = "http://www.httrack.com"; + license = licenses.gpl3; maintainers = with maintainers; [ peterhoeg ]; - platforms = with platforms; unix; + platforms = with platforms; unix; }; } diff --git a/pkgs/tools/backup/monolith/default.nix b/pkgs/tools/backup/monolith/default.nix index 454fed104ec15e..fa567086015b04 100644 --- a/pkgs/tools/backup/monolith/default.nix +++ b/pkgs/tools/backup/monolith/default.nix @@ -1,12 +1,14 @@ -{ lib, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, libiconv -, Security -, SystemConfiguration -, nix-update-script +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + libiconv, + Security, + SystemConfiguration, + nix-update-script, }: rustPlatform.buildRustPackage rec { @@ -25,8 +27,13 @@ rustPlatform.buildRustPackage rec { OPENSSL_NO_VENDOR = true; nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv Security SystemConfiguration ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Security + SystemConfiguration + ]; checkFlags = [ "--skip=tests::cli" ]; diff --git a/pkgs/tools/backup/percona-xtrabackup/8_4.nix b/pkgs/tools/backup/percona-xtrabackup/8_4.nix index 0bfcbb12e23625..47efd663a1d4e9 100644 --- a/pkgs/tools/backup/percona-xtrabackup/8_4.nix +++ b/pkgs/tools/backup/percona-xtrabackup/8_4.nix @@ -9,9 +9,8 @@ callPackage ./generic.nix ( # includes https://github.com/Percona-Lab/libkmip.git fetchSubmodules = true; - extraPatches = - [ - ]; + extraPatches = [ + ]; extraPostInstall = ''''; } diff --git a/pkgs/tools/backup/pyznap/default.nix b/pkgs/tools/backup/pyznap/default.nix index fcb3ee17cb5a41..847ee32f8c2fab 100644 --- a/pkgs/tools/backup/pyznap/default.nix +++ b/pkgs/tools/backup/pyznap/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildPythonApplication -, fetchPypi -, setuptools +{ + lib, + buildPythonApplication, + fetchPypi, + setuptools, }: buildPythonApplication rec { diff --git a/pkgs/tools/backup/rdedup/default.nix b/pkgs/tools/backup/rdedup/default.nix index fdda197f18c59e..b11c7c9aab1c32 100644 --- a/pkgs/tools/backup/rdedup/default.nix +++ b/pkgs/tools/backup/rdedup/default.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, pkg-config, openssl, libsodium -, xz -, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + libsodium, + xz, + Security, +}: rustPlatform.buildRustPackage rec { pname = "rdedup"; @@ -15,9 +23,15 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-I6d3IyPBcUsrvlzF7W0hFM4hcXi4wWro9bCeP4eArHI="; - nativeBuildInputs = [ pkg-config rustPlatform.bindgenHook ]; - buildInputs = [ openssl libsodium xz ] - ++ (lib.optional stdenv.hostPlatform.isDarwin Security); + nativeBuildInputs = [ + pkg-config + rustPlatform.bindgenHook + ]; + buildInputs = [ + openssl + libsodium + xz + ] ++ (lib.optional stdenv.hostPlatform.isDarwin Security); meta = with lib; { description = "Data deduplication with compression and public key encryption"; diff --git a/pkgs/tools/backup/restic/default.nix b/pkgs/tools/backup/restic/default.nix index cc9ff35a233170..6192d0b37248f3 100644 --- a/pkgs/tools/backup/restic/default.nix +++ b/pkgs/tools/backup/restic/default.nix @@ -1,5 +1,14 @@ -{ stdenv, lib, buildGoModule, fetchFromGitHub, installShellFiles, makeWrapper -, nixosTests, rclone, python3 }: +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, + makeWrapper, + nixosTests, + rclone, + python3, +}: buildGoModule rec { pname = "restic"; @@ -21,7 +30,10 @@ buildGoModule rec { subPackages = [ "cmd/restic" ]; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; nativeCheckInputs = [ python3 ]; @@ -33,17 +45,19 @@ buildGoModule rec { rm cmd/restic/cmd_mount_integration_test.go ''; - postInstall = '' - wrapProgram $out/bin/restic --prefix PATH : '${rclone}/bin' - '' + lib.optionalString (stdenv.hostPlatform == stdenv.buildPlatform) '' - $out/bin/restic generate \ - --bash-completion restic.bash \ - --fish-completion restic.fish \ - --zsh-completion restic.zsh \ - --man . - installShellCompletion restic.{bash,fish,zsh} - installManPage *.1 - ''; + postInstall = + '' + wrapProgram $out/bin/restic --prefix PATH : '${rclone}/bin' + '' + + lib.optionalString (stdenv.hostPlatform == stdenv.buildPlatform) '' + $out/bin/restic generate \ + --bash-completion restic.bash \ + --fish-completion restic.fish \ + --zsh-completion restic.zsh \ + --man . + installShellCompletion restic.{bash,fish,zsh} + installManPage *.1 + ''; meta = with lib; { homepage = "https://restic.net"; @@ -51,7 +65,10 @@ buildGoModule rec { description = "Backup program that is fast, efficient and secure"; platforms = platforms.linux ++ platforms.darwin; license = licenses.bsd2; - maintainers = [ maintainers.mbrgm maintainers.dotlambda ]; + maintainers = [ + maintainers.mbrgm + maintainers.dotlambda + ]; mainProgram = "restic"; }; } diff --git a/pkgs/tools/backup/restic/rest-server.nix b/pkgs/tools/backup/restic/rest-server.nix index 8d8cedb339be5c..5d6938a0570a57 100644 --- a/pkgs/tools/backup/restic/rest-server.nix +++ b/pkgs/tools/backup/restic/rest-server.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "restic-rest-server"; diff --git a/pkgs/tools/backup/ugarit-manifest-maker/default.nix b/pkgs/tools/backup/ugarit-manifest-maker/default.nix index dc497150041c46..0334352c876269 100644 --- a/pkgs/tools/backup/ugarit-manifest-maker/default.nix +++ b/pkgs/tools/backup/ugarit-manifest-maker/default.nix @@ -1,4 +1,9 @@ -{ pkgs, lib, eggDerivation, fetchegg }: +{ + pkgs, + lib, + eggDerivation, + fetchegg, +}: let eggs = import ./eggs.nix { inherit eggDerivation fetchegg; }; diff --git a/pkgs/tools/backup/ugarit-manifest-maker/eggs.nix b/pkgs/tools/backup/ugarit-manifest-maker/eggs.nix index 889d698188e29f..eaf2b9617ccef7 100644 --- a/pkgs/tools/backup/ugarit-manifest-maker/eggs.nix +++ b/pkgs/tools/backup/ugarit-manifest-maker/eggs.nix @@ -39,7 +39,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -53,7 +53,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -113,7 +113,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -146,7 +146,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -160,7 +160,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -190,7 +190,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -204,7 +204,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -218,7 +218,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -232,7 +232,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -246,7 +246,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -275,7 +275,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -289,7 +289,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -428,4 +428,3 @@ rec { ]; }; } - diff --git a/pkgs/tools/backup/ugarit/default.nix b/pkgs/tools/backup/ugarit/default.nix index 94dd3219fc24b5..724f65495b5ce6 100644 --- a/pkgs/tools/backup/ugarit/default.nix +++ b/pkgs/tools/backup/ugarit/default.nix @@ -1,4 +1,9 @@ -{ lib, eggDerivation, fetchegg, z3 }: +{ + lib, + eggDerivation, + fetchegg, + z3, +}: let eggs = import ./eggs.nix { inherit eggDerivation fetchegg; }; diff --git a/pkgs/tools/backup/ugarit/eggs.nix b/pkgs/tools/backup/ugarit/eggs.nix index fe958cb55cc614..dbbb9a56c47b87 100644 --- a/pkgs/tools/backup/ugarit/eggs.nix +++ b/pkgs/tools/backup/ugarit/eggs.nix @@ -10,7 +10,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -53,7 +53,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -113,7 +113,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -146,7 +146,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -176,7 +176,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -190,7 +190,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -204,7 +204,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -218,7 +218,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -232,7 +232,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -275,7 +275,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -289,7 +289,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -452,7 +452,7 @@ rec { }; buildInputs = [ - + ]; }; @@ -466,7 +466,7 @@ rec { }; buildInputs = [ - + ]; }; diff --git a/pkgs/tools/backup/zbackup/default.nix b/pkgs/tools/backup/zbackup/default.nix index f7bfb646332aa1..21df241f7db83e 100644 --- a/pkgs/tools/backup/zbackup/default.nix +++ b/pkgs/tools/backup/zbackup/default.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchFromGitHub -, cmake, protobufc -, libunwind, lzo, openssl, protobuf, zlib +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + protobufc, + libunwind, + lzo, + openssl, + protobuf, + zlib, }: stdenv.mkDerivation rec { @@ -24,8 +32,17 @@ stdenv.mkDerivation rec { # allowed in C++17 env.NIX_CFLAGS_COMPILE = toString [ "--std=c++14" ]; - buildInputs = [ zlib openssl protobuf lzo libunwind ]; - nativeBuildInputs = [ cmake protobufc ]; + buildInputs = [ + zlib + openssl + protobuf + lzo + libunwind + ]; + nativeBuildInputs = [ + cmake + protobufc + ]; meta = { description = "Versatile deduplicating backup tool"; diff --git a/pkgs/tools/backup/zfs-replicate/default.nix b/pkgs/tools/backup/zfs-replicate/default.nix index 210355b700a670..37781400c15b42 100644 --- a/pkgs/tools/backup/zfs-replicate/default.nix +++ b/pkgs/tools/backup/zfs-replicate/default.nix @@ -1,12 +1,13 @@ -{ buildPythonApplication -, click -, fetchPypi -, hypothesis -, lib -, poetry-core -, pytest-cov-stub -, pytestCheckHook -, stringcase +{ + buildPythonApplication, + click, + fetchPypi, + hypothesis, + lib, + poetry-core, + pytest-cov-stub, + pytestCheckHook, + stringcase, }: buildPythonApplication rec { diff --git a/pkgs/tools/cd-dvd/brasero/default.nix b/pkgs/tools/cd-dvd/brasero/default.nix index 34225dd8bd2a2b..508a588041da23 100644 --- a/pkgs/tools/cd-dvd/brasero/default.nix +++ b/pkgs/tools/cd-dvd/brasero/default.nix @@ -1,13 +1,33 @@ -{ stdenv, lib, fetchurl, pkg-config, gtk3, itstool, gst_all_1, libxml2, libnotify -, libcanberra-gtk3, intltool, dvdauthor, libburn, libisofs -, vcdimager, wrapGAppsHook3, hicolor-icon-theme }: +{ + stdenv, + lib, + fetchurl, + pkg-config, + gtk3, + itstool, + gst_all_1, + libxml2, + libnotify, + libcanberra-gtk3, + intltool, + dvdauthor, + libburn, + libisofs, + vcdimager, + wrapGAppsHook3, + hicolor-icon-theme, +}: let major = "3.12"; minor = "3"; - binpath = lib.makeBinPath [ dvdauthor vcdimager ]; + binpath = lib.makeBinPath [ + dvdauthor + vcdimager + ]; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { version = "${major}.${minor}"; pname = "brasero"; @@ -16,13 +36,28 @@ in stdenv.mkDerivation rec { hash = "sha256-h3SerjOhQSB9GwC+IzttgEWYLtMkntS5ja4fOpdf6hU="; }; - nativeBuildInputs = [ pkg-config itstool intltool wrapGAppsHook3 ]; + nativeBuildInputs = [ + pkg-config + itstool + intltool + wrapGAppsHook3 + ]; - buildInputs = [ gtk3 libxml2 libnotify libcanberra-gtk3 libburn libisofs - hicolor-icon-theme - gst_all_1.gstreamer gst_all_1.gst-plugins-base - gst_all_1.gst-plugins-good gst_all_1.gst-plugins-bad - gst_all_1.gst-plugins-ugly gst_all_1.gst-libav ]; + buildInputs = [ + gtk3 + libxml2 + libnotify + libcanberra-gtk3 + libburn + libisofs + hicolor-icon-theme + gst_all_1.gstreamer + gst_all_1.gst-plugins-base + gst_all_1.gst-plugins-good + gst_all_1.gst-plugins-bad + gst_all_1.gst-plugins-ugly + gst_all_1.gst-libav + ]; # brasero checks that the applications it uses aren't symlinks, but this # will obviously not work on nix diff --git a/pkgs/tools/cd-dvd/brasero/wrapper.nix b/pkgs/tools/cd-dvd/brasero/wrapper.nix index dc5c6fc4ad30b9..2747bc99479641 100644 --- a/pkgs/tools/cd-dvd/brasero/wrapper.nix +++ b/pkgs/tools/cd-dvd/brasero/wrapper.nix @@ -1,8 +1,16 @@ -{ lib, symlinkJoin, brasero-unwrapped, cdrtools, libdvdcss, makeWrapper }: +{ + lib, + symlinkJoin, + brasero-unwrapped, + cdrtools, + libdvdcss, + makeWrapper, +}: let binPath = lib.makeBinPath [ cdrtools ]; -in symlinkJoin { +in +symlinkJoin { name = "brasero-${brasero-unwrapped.version}"; paths = [ brasero-unwrapped ]; diff --git a/pkgs/tools/cd-dvd/cdrdao/default.nix b/pkgs/tools/cd-dvd/cdrdao/default.nix index b4e93adce8644e..5f9c0ca5073ed0 100644 --- a/pkgs/tools/cd-dvd/cdrdao/default.nix +++ b/pkgs/tools/cd-dvd/cdrdao/default.nix @@ -21,21 +21,27 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-0ZtnyFPF26JAavqrbNeI53817r5jTKxGeVKEd8e+AbY="; }; - makeFlags = [ "RM=rm" "LN=ln" "MV=mv" ]; + makeFlags = [ + "RM=rm" + "LN=ln" + "MV=mv" + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - libiconv - libvorbis - libmad - libao - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreServices - IOKit - ]; + buildInputs = + [ + libiconv + libvorbis + libmad + libao + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + IOKit + ]; hardeningDisable = [ "format" ]; diff --git a/pkgs/tools/cd-dvd/cdrtools/default.nix b/pkgs/tools/cd-dvd/cdrtools/default.nix index d264a0f8bdb343..b64837ac2b295d 100644 --- a/pkgs/tools/cd-dvd/cdrtools/default.nix +++ b/pkgs/tools/cd-dvd/cdrtools/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, m4, acl, libcap, Carbon, IOKit }: +{ + lib, + stdenv, + fetchurl, + m4, + acl, + libcap, + Carbon, + IOKit, +}: stdenv.mkDerivation rec { pname = "cdrtools"; @@ -10,7 +19,17 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ m4 ]; - buildInputs = if stdenv.hostPlatform.isDarwin then [ Carbon IOKit ] else [ acl libcap ]; + buildInputs = + if stdenv.hostPlatform.isDarwin then + [ + Carbon + IOKit + ] + else + [ + acl + libcap + ]; postPatch = '' sed "/\.mk3/d" -i libschily/Targets.man @@ -25,7 +44,12 @@ stdenv.mkDerivation rec { dontConfigure = true; - makeFlags = [ "GMAKE_NOWARN=true" "INS_BASE=/" "INS_RBASE=/" "DESTDIR=${placeholder "out"}" ]; + makeFlags = [ + "GMAKE_NOWARN=true" + "INS_BASE=/" + "INS_RBASE=/" + "DESTDIR=${placeholder "out"}" + ]; enableParallelBuilding = false; # parallel building fails on some linux machines @@ -34,11 +58,15 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://cdrtools.sourceforge.net/private/cdrecord.html"; description = "Highly portable CD/DVD/BluRay command line recording software"; - license = with licenses; [ cddl gpl2Plus lgpl21 ]; + license = with licenses; [ + cddl + gpl2Plus + lgpl21 + ]; platforms = with platforms; linux ++ darwin; # Licensing issues: This package contains code licensed under CDDL, GPL2 # and LGPL2. There is a debate regarding the legality of distributing this # package in binary form. - hydraPlatforms = []; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/tools/cd-dvd/unetbootin/default.nix b/pkgs/tools/cd-dvd/unetbootin/default.nix index 7dc1efb82852db..bd2e66c72b473a 100644 --- a/pkgs/tools/cd-dvd/unetbootin/default.nix +++ b/pkgs/tools/cd-dvd/unetbootin/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, coreutils -, fetchFromGitHub -, mtools -, p7zip -, wrapQtAppsHook -, qtbase -, qttools -, qmake -, syslinux -, util-linux -, which +{ + lib, + stdenv, + coreutils, + fetchFromGitHub, + mtools, + p7zip, + wrapQtAppsHook, + qtbase, + qttools, + qmake, + syslinux, + util-linux, + which, }: stdenv.mkDerivation rec { @@ -70,7 +71,13 @@ stdenv.mkDerivation rec { ''; qtWrapperArgs = [ - "--prefix PATH : ${lib.makeBinPath [ mtools p7zip which ]}" + "--prefix PATH : ${ + lib.makeBinPath [ + mtools + p7zip + which + ] + }" "--set QT_X11_NO_MITSHM 1" ]; diff --git a/pkgs/tools/compression/bzip2/1_1.nix b/pkgs/tools/compression/bzip2/1_1.nix index 520cc393b0ac9b..c39868078bdae0 100644 --- a/pkgs/tools/compression/bzip2/1_1.nix +++ b/pkgs/tools/compression/bzip2/1_1.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitLab -, meson -, python3 -, ninja -, testers +{ + lib, + stdenv, + fetchFromGitLab, + meson, + python3, + ninja, + testers, }: stdenv.mkDerivation (finalAttrs: { @@ -27,7 +29,12 @@ stdenv.mkDerivation (finalAttrs: { ninja ]; - outputs = [ "bin" "dev" "out" "man" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + ]; mesonFlags = [ "-Ddocs=disabled" diff --git a/pkgs/tools/compression/bzip2/default.nix b/pkgs/tools/compression/bzip2/default.nix index 0268b60afc52cc..46cd16374b321e 100644 --- a/pkgs/tools/compression/bzip2/default.nix +++ b/pkgs/tools/compression/bzip2/default.nix @@ -1,8 +1,11 @@ -{ lib, stdenv, fetchurl -, enableStatic ? with stdenv.hostPlatform; isStatic || isCygwin -, enableShared ? true -, autoreconfHook -, testers +{ + lib, + stdenv, + fetchurl, + enableStatic ? with stdenv.hostPlatform; isStatic || isCygwin, + enableShared ? true, + autoreconfHook, + testers, }: # Note: this package is used for bootstrapping fetchurl, and thus @@ -10,66 +13,75 @@ # cgit) that are needed here should be included directly in Nixpkgs as # files. -stdenv.mkDerivation (finalAttrs: let - inherit (finalAttrs) version; -in { - pname = "bzip2"; - version = "1.0.8"; +stdenv.mkDerivation ( + finalAttrs: + let + inherit (finalAttrs) version; + in + { + pname = "bzip2"; + version = "1.0.8"; - src = fetchurl { - url = "https://sourceware.org/pub/bzip2/bzip2-${version}.tar.gz"; - sha256 = "sha256-q1oDF27hBtPw+pDjgdpHjdrkBZGBU8yiSOaCzQxKImk="; - }; + src = fetchurl { + url = "https://sourceware.org/pub/bzip2/bzip2-${version}.tar.gz"; + sha256 = "sha256-q1oDF27hBtPw+pDjgdpHjdrkBZGBU8yiSOaCzQxKImk="; + }; - patchFlags = ["-p0"]; + patchFlags = [ "-p0" ]; - patches = [ - (fetchurl { - url = "ftp://ftp.suse.com/pub/people/sbrabec/bzip2/for_downstream/bzip2-1.0.6.2-autoconfiscated.patch"; - sha256 = "sha256-QMufl6ffJVVVVZespvkCbFpB6++R1lnq1687jEsUjr0="; - }) - ]; - # Fix up hardcoded version from the above patch, e.g. seen in bzip2.pc or libbz2.so.1.0.N - postPatch = '' - patch <<-EOF - --- configure.ac - +++ configure.ac - @@ -3,3 +3,3 @@ - -AC_INIT([bzip2], [1.0.6], [Julian Seward ]) - +AC_INIT([bzip2], [${version}], [Julian Seward ]) - BZIP2_LT_CURRENT=1 - -BZIP2_LT_REVISION=6 - +BZIP2_LT_REVISION=${lib.versions.patch version} - EOF - ''; + patches = [ + (fetchurl { + url = "ftp://ftp.suse.com/pub/people/sbrabec/bzip2/for_downstream/bzip2-1.0.6.2-autoconfiscated.patch"; + sha256 = "sha256-QMufl6ffJVVVVZespvkCbFpB6++R1lnq1687jEsUjr0="; + }) + ]; + # Fix up hardcoded version from the above patch, e.g. seen in bzip2.pc or libbz2.so.1.0.N + postPatch = '' + patch <<-EOF + --- configure.ac + +++ configure.ac + @@ -3,3 +3,3 @@ + -AC_INIT([bzip2], [1.0.6], [Julian Seward ]) + +AC_INIT([bzip2], [${version}], [Julian Seward ]) + BZIP2_LT_CURRENT=1 + -BZIP2_LT_REVISION=6 + +BZIP2_LT_REVISION=${lib.versions.patch version} + EOF + ''; - strictDeps = true; - nativeBuildInputs = [ autoreconfHook ]; + strictDeps = true; + nativeBuildInputs = [ autoreconfHook ]; - outputs = [ "bin" "dev" "out" "man" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + ]; - configureFlags = lib.concatLists [ - (lib.optional enableStatic "--enable-static") - (lib.optional (!enableShared) "--disable-shared") - ]; + configureFlags = lib.concatLists [ + (lib.optional enableStatic "--enable-static") + (lib.optional (!enableShared) "--disable-shared") + ]; - dontDisableStatic = enableStatic; + dontDisableStatic = enableStatic; - enableParallelBuilding = true; + enableParallelBuilding = true; - postInstall = '' - ln -s $out/lib/libbz2.so.1.0.* $out/lib/libbz2.so.1.0 - ''; + postInstall = '' + ln -s $out/lib/libbz2.so.1.0.* $out/lib/libbz2.so.1.0 + ''; - passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; + passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage; - meta = with lib; { - description = "High-quality data compression program"; - homepage = "https://www.sourceware.org/bzip2"; - changelog = "https://sourceware.org/git/?p=bzip2.git;a=blob;f=CHANGES;hb=HEAD"; - license = licenses.bsdOriginal; - pkgConfigModules = [ "bzip2" ]; - platforms = platforms.all; - maintainers = with maintainers; [ mic92 ]; - }; -}) + meta = with lib; { + description = "High-quality data compression program"; + homepage = "https://www.sourceware.org/bzip2"; + changelog = "https://sourceware.org/git/?p=bzip2.git;a=blob;f=CHANGES;hb=HEAD"; + license = licenses.bsdOriginal; + pkgConfigModules = [ "bzip2" ]; + platforms = platforms.all; + maintainers = with maintainers; [ mic92 ]; + }; + } +) diff --git a/pkgs/tools/compression/bzip3/default.nix b/pkgs/tools/compression/bzip3/default.nix index 889f64b52d8b9f..463c4c670594f4 100644 --- a/pkgs/tools/compression/bzip3/default.nix +++ b/pkgs/tools/compression/bzip3/default.nix @@ -1,16 +1,21 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, testers +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + testers, }: stdenv.mkDerivation (finalAttrs: { pname = "bzip3"; version = "1.4.0"; - outputs = [ "bin" "dev" "out" ]; + outputs = [ + "bin" + "dev" + "out" + ]; src = fetchFromGitHub { owner = "kspalaiologos"; diff --git a/pkgs/tools/compression/kzipmix/default.nix b/pkgs/tools/compression/kzipmix/default.nix index 9da423396593ba..a039143821e1a5 100644 --- a/pkgs/tools/compression/kzipmix/default.nix +++ b/pkgs/tools/compression/kzipmix/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "kzipmix"; diff --git a/pkgs/tools/compression/xdelta/default.nix b/pkgs/tools/compression/xdelta/default.nix index 7ce9417d40cc3d..971811517a2e03 100644 --- a/pkgs/tools/compression/xdelta/default.nix +++ b/pkgs/tools/compression/xdelta/default.nix @@ -1,14 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook -, lzmaSupport ? true, xz ? null +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + lzmaSupport ? true, + xz ? null, }: assert lzmaSupport -> xz != null; let - mkWith = flag: name: if flag - then "--with-${name}" - else "--without-${name}"; -in stdenv.mkDerivation rec { + mkWith = flag: name: if flag then "--with-${name}" else "--without-${name}"; +in +stdenv.mkDerivation rec { pname = "xdelta"; version = "3.1.0"; @@ -20,8 +24,7 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [] - ++ lib.optionals lzmaSupport [ xz ]; + buildInputs = [ ] ++ lib.optionals lzmaSupport [ xz ]; postPatch = '' cd xdelta3 diff --git a/pkgs/tools/compression/xdelta/unstable.nix b/pkgs/tools/compression/xdelta/unstable.nix index 2ac8398dbc2dfb..a8272fdb765340 100644 --- a/pkgs/tools/compression/xdelta/unstable.nix +++ b/pkgs/tools/compression/xdelta/unstable.nix @@ -1,14 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook -, lzmaSupport ? true, xz ? null +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + lzmaSupport ? true, + xz ? null, }: assert lzmaSupport -> xz != null; let - mkWith = flag: name: if flag - then "--with-${name}" - else "--without-${name}"; -in stdenv.mkDerivation rec { + mkWith = flag: name: if flag then "--with-${name}" else "--without-${name}"; +in +stdenv.mkDerivation rec { pname = "xdelta"; version = "3.1.0"; @@ -20,8 +24,7 @@ in stdenv.mkDerivation rec { }; nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [] - ++ lib.optionals lzmaSupport [ xz ]; + buildInputs = [ ] ++ lib.optionals lzmaSupport [ xz ]; postPatch = '' cd xdelta3 diff --git a/pkgs/tools/compression/xz/default.nix b/pkgs/tools/compression/xz/default.nix index 47619ac751b3c5..658e8d8216a8a0 100644 --- a/pkgs/tools/compression/xz/default.nix +++ b/pkgs/tools/compression/xz/default.nix @@ -1,7 +1,10 @@ -{ lib, stdenv, fetchurl -, enableStatic ? stdenv.hostPlatform.isStatic -, writeScript -, testers +{ + lib, + stdenv, + fetchurl, + enableStatic ? stdenv.hostPlatform.isStatic, + writeScript, + testers, }: # Note: this package is used for bootstrapping fetchurl, and thus @@ -14,12 +17,20 @@ stdenv.mkDerivation (finalAttrs: { version = "5.6.3"; src = fetchurl { - url = with finalAttrs; "https://github.com/tukaani-project/xz/releases/download/v${version}/xz-${version}.tar.xz"; + url = + with finalAttrs; + "https://github.com/tukaani-project/xz/releases/download/v${version}/xz-${version}.tar.xz"; hash = "sha256-2wWQYptvD6NudK6l+XMdxvjfBoznt7r6RTAYMqXuvDo="; }; strictDeps = true; - outputs = [ "bin" "dev" "out" "man" "doc" ]; + outputs = [ + "bin" + "dev" + "out" + "man" + "doc" + ]; configureFlags = lib.optional enableStatic "--disable-shared"; @@ -78,7 +89,10 @@ stdenv.mkDerivation (finalAttrs: { create 30 % smaller output than gzip and 15 % smaller output than bzip2. ''; - license = with licenses; [ gpl2Plus lgpl21Plus ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + ]; maintainers = with maintainers; [ sander ]; platforms = platforms.all; pkgConfigModules = [ "liblzma" ]; diff --git a/pkgs/tools/compression/zstd/default.nix b/pkgs/tools/compression/zstd/default.nix index f9d3a3d074c90b..27f66232b7adf0 100644 --- a/pkgs/tools/compression/zstd/default.nix +++ b/pkgs/tools/compression/zstd/default.nix @@ -1,22 +1,28 @@ -{ lib, stdenv, fetchFromGitHub, cmake, bash, gnugrep -, fixDarwinDylibNames -, file -, legacySupport ? false -, static ? stdenv.hostPlatform.isStatic # generates static libraries *only* -, enableStatic ? static -# these need to be ran on the host, thus disable when cross-compiling -, buildContrib ? stdenv.hostPlatform == stdenv.buildPlatform -, doCheck ? stdenv.hostPlatform == stdenv.buildPlatform -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + bash, + gnugrep, + fixDarwinDylibNames, + file, + legacySupport ? false, + static ? stdenv.hostPlatform.isStatic, # generates static libraries *only* + enableStatic ? static, + # these need to be ran on the host, thus disable when cross-compiling + buildContrib ? stdenv.hostPlatform == stdenv.buildPlatform, + doCheck ? stdenv.hostPlatform == stdenv.buildPlatform, + nix-update-script, -# for passthru.tests -, libarchive -, rocksdb -, arrow-cpp -, libzip -, curl -, python3Packages -, haskellPackages + # for passthru.tests + libarchive, + rocksdb, + arrow-cpp, + libzip, + curl, + python3Packages, + haskellPackages, }: stdenv.mkDerivation rec { @@ -30,8 +36,7 @@ stdenv.mkDerivation rec { hash = "sha256-qcd92hQqVBjMT3hyntjcgk29o9wGQsg5Hg7HE5C0UNc="; }; - nativeBuildInputs = [ cmake ] - ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; + nativeBuildInputs = [ cmake ] ++ lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames; buildInputs = lib.optional stdenv.hostPlatform.isUnix bash; patches = [ @@ -50,15 +55,16 @@ stdenv.mkDerivation rec { tests/playTests.sh ''; - cmakeFlags = lib.attrsets.mapAttrsToList - (name: value: "-DZSTD_${name}:BOOL=${if value then "ON" else "OFF"}") { - BUILD_SHARED = !static; - BUILD_STATIC = enableStatic; - BUILD_CONTRIB = buildContrib; - PROGRAMS_LINK_SHARED = !static; - LEGACY_SUPPORT = legacySupport; - BUILD_TESTS = doCheck; - }; + cmakeFlags = + lib.attrsets.mapAttrsToList (name: value: "-DZSTD_${name}:BOOL=${if value then "ON" else "OFF"}") + { + BUILD_SHARED = !static; + BUILD_STATIC = enableStatic; + BUILD_CONTRIB = buildContrib; + PROGRAMS_LINK_SHARED = !static; + LEGACY_SUPPORT = legacySupport; + BUILD_TESTS = doCheck; + }; cmakeDir = "../build/cmake"; dontUseCmakeBuildDir = true; @@ -76,23 +82,30 @@ stdenv.mkDerivation rec { runHook postCheck ''; - preInstall = '' - mkdir -p $bin/bin - substituteInPlace ../programs/zstdgrep \ - --replace ":-grep" ":-${gnugrep}/bin/grep" \ - --replace ":-zstdcat" ":-$bin/bin/zstdcat" - - substituteInPlace ../programs/zstdless \ - --replace "zstdcat" "$bin/bin/zstdcat" - '' + lib.optionalString buildContrib ( + preInstall = '' - cp contrib/pzstd/pzstd $bin/bin/pzstd - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - install_name_tool -change @rpath/libzstd.1.dylib $out/lib/libzstd.1.dylib $bin/bin/pzstd + mkdir -p $bin/bin + substituteInPlace ../programs/zstdgrep \ + --replace ":-grep" ":-${gnugrep}/bin/grep" \ + --replace ":-zstdcat" ":-$bin/bin/zstdcat" + + substituteInPlace ../programs/zstdless \ + --replace "zstdcat" "$bin/bin/zstdcat" '' - ); + + lib.optionalString buildContrib ( + '' + cp contrib/pzstd/pzstd $bin/bin/pzstd + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + install_name_tool -change @rpath/libzstd.1.dylib $out/lib/libzstd.1.dylib $bin/bin/pzstd + '' + ); - outputs = [ "bin" "dev" ] + outputs = + [ + "bin" + "dev" + ] ++ lib.optional stdenv.hostPlatform.isUnix "man" ++ [ "out" ]; diff --git a/pkgs/tools/filesystems/afsctool/default.nix b/pkgs/tools/filesystems/afsctool/default.nix index f0d8f0ba7af04e..4ebcd4e1da6784 100644 --- a/pkgs/tools/filesystems/afsctool/default.nix +++ b/pkgs/tools/filesystems/afsctool/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, cmake -, git -, zlib -, sparsehash +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + git, + zlib, + sparsehash, }: stdenv.mkDerivation rec { @@ -19,8 +20,15 @@ stdenv.mkDerivation rec { hash = "sha256-cZ0P9cygj+5GgkDRpQk7P9z8zh087fpVfrYXMRRVUAI="; }; - nativeBuildInputs = [ pkg-config cmake git ]; - buildInputs = [ zlib sparsehash ]; + nativeBuildInputs = [ + pkg-config + cmake + git + ]; + buildInputs = [ + zlib + sparsehash + ]; meta = with lib; { description = "Utility that allows end-users to leverage HFS+/APFS compression"; diff --git a/pkgs/tools/filesystems/android-file-transfer/default.nix b/pkgs/tools/filesystems/android-file-transfer/default.nix index 78d60b90b39554..d7a48f8ed9ed28 100644 --- a/pkgs/tools/filesystems/android-file-transfer/default.nix +++ b/pkgs/tools/filesystems/android-file-transfer/default.nix @@ -1,14 +1,16 @@ -{ lib -, stdenv -, mkDerivation -, fetchFromGitHub -, cmake -, fuse -, readline -, pkg-config -, qtbase -, qttools -, wrapQtAppsHook }: +{ + lib, + stdenv, + mkDerivation, + fetchFromGitHub, + cmake, + fuse, + readline, + pkg-config, + qtbase, + qttools, + wrapQtAppsHook, +}: mkDerivation rec { pname = "android-file-transfer"; @@ -23,8 +25,17 @@ mkDerivation rec { patches = [ ./darwin-dont-vendor-dependencies.patch ]; - nativeBuildInputs = [ cmake readline pkg-config wrapQtAppsHook ]; - buildInputs = [ fuse qtbase qttools ]; + nativeBuildInputs = [ + cmake + readline + pkg-config + wrapQtAppsHook + ]; + buildInputs = [ + fuse + qtbase + qttools + ]; postInstall = lib.optionalString stdenv.hostPlatform.isDarwin '' mkdir $out/Applications diff --git a/pkgs/tools/filesystems/catcli/default.nix b/pkgs/tools/filesystems/catcli/default.nix index fc075f52c70db3..94c7eb532aefec 100644 --- a/pkgs/tools/filesystems/catcli/default.nix +++ b/pkgs/tools/filesystems/catcli/default.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/tools/filesystems/ceph/default.nix b/pkgs/tools/filesystems/ceph/default.nix index 004d0bbca94b61..5fde26dee5bc0d 100644 --- a/pkgs/tools/filesystems/ceph/default.nix +++ b/pkgs/tools/filesystems/ceph/default.nix @@ -1,106 +1,108 @@ -{ lib -, stdenv -, runCommand -, fetchurl -, fetchFromGitHub -, fetchPypi -, fetchpatch2 - -# Build time -, autoconf -, automake -, cmake -, ensureNewerSourcesHook -, fmt -, git -, libtool -, makeWrapper -, nasm -, pkg-config -, which - -# Tests -, nixosTests - -# Runtime dependencies -, arrow-cpp -, babeltrace -, boost182 # using the version installed by ceph's `install-deps.sh` -, bzip2 -, cryptsetup -, cunit -, e2fsprogs -, doxygen -, gperf -, graphviz -, gnugrep -, gtest -, icu -, kmod -, libcap -, libcap_ng -, libnl -, libxml2 -, lmdb -, lttng-ust -, lua -, lvm2 -, lz4 -, oath-toolkit -, openldap -, parted -, python311 # to get an idea which Python versions are supported by Ceph, see upstream `do_cmake.sh` (see `PYBUILD=` variable) -, rdkafka -, rocksdb -, snappy -, openssh -, sqlite -, utf8proc -, xfsprogs -, zlib -, zstd - -# Dependencies of overridden Python dependencies, hopefully we can remove these soon. -, rustPlatform - -# Optional Dependencies -, curl ? null -, expat ? null -, fuse ? null -, libatomic_ops ? null -, libedit ? null -, libs3 ? null -, yasm ? null - -# Mallocs -, gperftools ? null -, jemalloc ? null - -# Crypto Dependencies -, cryptopp ? null -, nspr ? null -, nss ? null - -# Linux Only Dependencies -, linuxHeaders -, util-linux -, libuuid -, udev -, keyutils -, rdma-core -, rabbitmq-c -, libaio ? null -, libxfs ? null -, liburing ? null -, zfs ? null -, ... +{ + lib, + stdenv, + runCommand, + fetchurl, + fetchFromGitHub, + fetchPypi, + fetchpatch2, + + # Build time + autoconf, + automake, + cmake, + ensureNewerSourcesHook, + fmt, + git, + libtool, + makeWrapper, + nasm, + pkg-config, + which, + + # Tests + nixosTests, + + # Runtime dependencies + arrow-cpp, + babeltrace, + boost182, # using the version installed by ceph's `install-deps.sh` + bzip2, + cryptsetup, + cunit, + e2fsprogs, + doxygen, + gperf, + graphviz, + gnugrep, + gtest, + icu, + kmod, + libcap, + libcap_ng, + libnl, + libxml2, + lmdb, + lttng-ust, + lua, + lvm2, + lz4, + oath-toolkit, + openldap, + parted, + python311, # to get an idea which Python versions are supported by Ceph, see upstream `do_cmake.sh` (see `PYBUILD=` variable) + rdkafka, + rocksdb, + snappy, + openssh, + sqlite, + utf8proc, + xfsprogs, + zlib, + zstd, + + # Dependencies of overridden Python dependencies, hopefully we can remove these soon. + rustPlatform, + + # Optional Dependencies + curl ? null, + expat ? null, + fuse ? null, + libatomic_ops ? null, + libedit ? null, + libs3 ? null, + yasm ? null, + + # Mallocs + gperftools ? null, + jemalloc ? null, + + # Crypto Dependencies + cryptopp ? null, + nspr ? null, + nss ? null, + + # Linux Only Dependencies + linuxHeaders, + util-linux, + libuuid, + udev, + keyutils, + rdma-core, + rabbitmq-c, + libaio ? null, + libxfs ? null, + liburing ? null, + zfs ? null, + ... }: # We must have one crypto library assert cryptopp != null || (nss != null && nspr != null); let - shouldUsePkg = pkg: if pkg != null && lib.meta.availableOn stdenv.hostPlatform pkg then pkg else null; + shouldUsePkg = + pkg: if pkg != null && lib.meta.availableOn stdenv.hostPlatform pkg then pkg else null; optYasm = shouldUsePkg yasm; optExpat = shouldUsePkg expat; @@ -138,122 +140,149 @@ let malloc = if optJemalloc != null then optJemalloc else optGperftools; # We prefer nss over cryptopp - cryptoStr = if optNss != null && optNspr != null then "nss" else - if optCryptopp != null then "cryptopp" else "none"; + cryptoStr = + if optNss != null && optNspr != null then + "nss" + else if optCryptopp != null then + "cryptopp" + else + "none"; cryptoLibsMap = { - nss = [ optNss optNspr ]; + nss = [ + optNss + optNspr + ]; cryptopp = [ optCryptopp ]; none = [ ]; }; getMeta = description: { - homepage = "https://ceph.io/en/"; - inherit description; - license = with lib.licenses; [ lgpl21 gpl2Only bsd3 mit publicDomain ]; - maintainers = with lib.maintainers; [ adev ak johanot krav nh2 ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; - }; - - ceph-common = with python.pkgs; buildPythonPackage { - pname = "ceph-common"; - inherit src version; + homepage = "https://ceph.io/en/"; + inherit description; + license = with lib.licenses; [ + lgpl21 + gpl2Only + bsd3 + mit + publicDomain + ]; + maintainers = with lib.maintainers; [ + adev + ak + johanot + krav + nh2 + ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; + }; - sourceRoot = "ceph-${version}/src/python-common"; + ceph-common = + with python.pkgs; + buildPythonPackage { + pname = "ceph-common"; + inherit src version; - propagatedBuildInputs = [ - pyyaml - ]; + sourceRoot = "ceph-${version}/src/python-common"; - nativeCheckInputs = [ - pytestCheckHook - ]; + propagatedBuildInputs = [ + pyyaml + ]; - disabledTests = [ - # requires network access - "test_valid_addr" - ]; + nativeCheckInputs = [ + pytestCheckHook + ]; - meta = getMeta "Ceph common module for code shared by manager modules"; - }; + disabledTests = [ + # requires network access + "test_valid_addr" + ]; + + meta = getMeta "Ceph common module for code shared by manager modules"; + }; # Watch out for python <> boost compatibility python = python311.override { self = python; - packageOverrides = self: super: let - bcryptOverrideVersion = "4.0.1"; - in { - # Ceph does not support the following yet: - # * `bcrypt` > 4.0 - # * `cryptography` > 40 - # See: - # * https://github.com/NixOS/nixpkgs/pull/281858#issuecomment-1899358602 - # * Upstream issue: https://tracker.ceph.com/issues/63529 - # > Python Sub-Interpreter Model Used by ceph-mgr Incompatible With Python Modules Based on PyO3 - # * Moved to issue: https://tracker.ceph.com/issues/64213 - # > MGR modules incompatible with later PyO3 versions - PyO3 modules may only be initialized once per interpreter process - - bcrypt = super.bcrypt.overridePythonAttrs (old: rec { - pname = "bcrypt"; - version = bcryptOverrideVersion; - src = fetchPypi { - inherit pname version; - hash = "sha256-J9N1kDrIJhz+QEf2cJ0W99GNObHskqr3KvmJVSplDr0="; - }; - cargoRoot = "src/_bcrypt"; - cargoDeps = rustPlatform.fetchCargoTarball { - inherit src; - sourceRoot = "${pname}-${version}/${cargoRoot}"; - name = "${pname}-${version}"; - hash = "sha256-lDWX69YENZFMu7pyBmavUZaalGvFqbHSHfkwkzmDQaY="; - }; - }); - - # We pin the older `cryptography` 40 here; - # this also forces us to pin an older `pyopenssl` because the current one - # is not compatible with older `cryptography`, see: - # https://github.com/pyca/pyopenssl/blob/d9752e44127ba36041b045417af8a0bf16ec4f1e/CHANGELOG.rst#2320-2023-05-30 - cryptography = self.callPackage ./old-python-packages/cryptography.nix {}; - - # This is the most recent version of `pyopenssl` that's still compatible with `cryptography` 40. - # See https://github.com/NixOS/nixpkgs/pull/281858#issuecomment-1899358602 - pyopenssl = super.pyopenssl.overridePythonAttrs (old: rec { - version = "23.1.1"; - src = fetchPypi { - pname = "pyOpenSSL"; - inherit version; - hash = "sha256-hBSYub7GFiOxtsR+u8AjZ8B9YODhlfGXkIF/EMyNsLc="; - }; - disabledTests = old.disabledTests or [ ] ++ [ - "test_export_md5_digest" - ]; - propagatedBuildInputs = old.propagatedBuildInputs or [ ] ++ [ - self.flaky - ]; - }); - - - fastapi = super.fastapi.overridePythonAttrs (old: rec { - # Flaky test: - # ResourceWarning: Unclosed - # Unclear whether it's flaky in general or only in this overridden package set. - doCheck = false; - }); - - # Ceph does not support `kubernetes` >= 19, see: - # https://github.com/NixOS/nixpkgs/pull/281858#issuecomment-1900324090 - kubernetes = super.kubernetes.overridePythonAttrs (old: rec { - version = "18.20.0"; - src = fetchFromGitHub { - owner = "kubernetes-client"; - repo = "python"; - rev = "v${version}"; - sha256 = "1sawp62j7h0yksmg9jlv4ik9b9i1a1w9syywc9mv8x89wibf5ql1"; - fetchSubmodules = true; - }; - }); + packageOverrides = + self: super: + let + bcryptOverrideVersion = "4.0.1"; + in + { + # Ceph does not support the following yet: + # * `bcrypt` > 4.0 + # * `cryptography` > 40 + # See: + # * https://github.com/NixOS/nixpkgs/pull/281858#issuecomment-1899358602 + # * Upstream issue: https://tracker.ceph.com/issues/63529 + # > Python Sub-Interpreter Model Used by ceph-mgr Incompatible With Python Modules Based on PyO3 + # * Moved to issue: https://tracker.ceph.com/issues/64213 + # > MGR modules incompatible with later PyO3 versions - PyO3 modules may only be initialized once per interpreter process + + bcrypt = super.bcrypt.overridePythonAttrs (old: rec { + pname = "bcrypt"; + version = bcryptOverrideVersion; + src = fetchPypi { + inherit pname version; + hash = "sha256-J9N1kDrIJhz+QEf2cJ0W99GNObHskqr3KvmJVSplDr0="; + }; + cargoRoot = "src/_bcrypt"; + cargoDeps = rustPlatform.fetchCargoTarball { + inherit src; + sourceRoot = "${pname}-${version}/${cargoRoot}"; + name = "${pname}-${version}"; + hash = "sha256-lDWX69YENZFMu7pyBmavUZaalGvFqbHSHfkwkzmDQaY="; + }; + }); + + # We pin the older `cryptography` 40 here; + # this also forces us to pin an older `pyopenssl` because the current one + # is not compatible with older `cryptography`, see: + # https://github.com/pyca/pyopenssl/blob/d9752e44127ba36041b045417af8a0bf16ec4f1e/CHANGELOG.rst#2320-2023-05-30 + cryptography = self.callPackage ./old-python-packages/cryptography.nix { }; + + # This is the most recent version of `pyopenssl` that's still compatible with `cryptography` 40. + # See https://github.com/NixOS/nixpkgs/pull/281858#issuecomment-1899358602 + pyopenssl = super.pyopenssl.overridePythonAttrs (old: rec { + version = "23.1.1"; + src = fetchPypi { + pname = "pyOpenSSL"; + inherit version; + hash = "sha256-hBSYub7GFiOxtsR+u8AjZ8B9YODhlfGXkIF/EMyNsLc="; + }; + disabledTests = old.disabledTests or [ ] ++ [ + "test_export_md5_digest" + ]; + propagatedBuildInputs = old.propagatedBuildInputs or [ ] ++ [ + self.flaky + ]; + }); + + fastapi = super.fastapi.overridePythonAttrs (old: rec { + # Flaky test: + # ResourceWarning: Unclosed + # Unclear whether it's flaky in general or only in this overridden package set. + doCheck = false; + }); + + # Ceph does not support `kubernetes` >= 19, see: + # https://github.com/NixOS/nixpkgs/pull/281858#issuecomment-1900324090 + kubernetes = super.kubernetes.overridePythonAttrs (old: rec { + version = "18.20.0"; + src = fetchFromGitHub { + owner = "kubernetes-client"; + repo = "python"; + rev = "v${version}"; + sha256 = "1sawp62j7h0yksmg9jlv4ik9b9i1a1w9syywc9mv8x89wibf5ql1"; + fetchSubmodules = true; + }; + }); - }; + }; }; boost = boost182.override { @@ -262,46 +291,48 @@ let }; # TODO: split this off in build and runtime environment - ceph-python-env = python.withPackages (ps: with ps; [ - ceph-common - - # build time - cython_0 - - # debian/control - bcrypt - cherrypy - influxdb - jinja2 - kubernetes - natsort - numpy - pecan - prettytable - pyjwt - pyopenssl - python-dateutil - pyyaml - requests - routes - scikit-learn - scipy - setuptools - sphinx - virtualenv - werkzeug - - # src/cephadm/zipapp-reqs.txt - markupsafe - - # src/pybind/mgr/requirements-required.txt - cryptography - jsonpatch - - # src/tools/cephfs/shell/setup.py - cmd2 - colorama - ]); + ceph-python-env = python.withPackages ( + ps: with ps; [ + ceph-common + + # build time + cython_0 + + # debian/control + bcrypt + cherrypy + influxdb + jinja2 + kubernetes + natsort + numpy + pecan + prettytable + pyjwt + pyopenssl + python-dateutil + pyyaml + requests + routes + scikit-learn + scipy + setuptools + sphinx + virtualenv + werkzeug + + # src/cephadm/zipapp-reqs.txt + markupsafe + + # src/pybind/mgr/requirements-required.txt + cryptography + jsonpatch + + # src/tools/cephfs/shell/setup.py + cmd2 + colorama + ] + ); inherit (ceph-python-env.python) sitePackages; version = "19.2.0"; @@ -309,7 +340,8 @@ let url = "https://download.ceph.com/tarballs/ceph-${version}.tar.gz"; hash = "sha256-30vkW1j49hFIxyxzkssSKVSq0VqiwLfDtOb62xfxadM="; }; -in rec { +in +rec { ceph = stdenv.mkDerivation { pname = "ceph"; inherit src version; @@ -344,64 +376,68 @@ in rec { graphviz ]; - buildInputs = cryptoLibsMap.${cryptoStr} ++ [ - arrow-cpp - babeltrace - boost - bzip2 - # Adding `ceph-python-env` here adds the env's `site-packages` to `PYTHONPATH` during the build. - # This is important, otherwise the build system may not find the Python deps and then - # silently skip installing ceph-volume and other Ceph python tools. - ceph-python-env - cryptsetup - cunit - e2fsprogs # according to `debian/control` file, `ceph-volume` is supposed to use it - gperf - gtest - icu - libcap - libnl - libxml2 - lmdb - lttng-ust - lua - lvm2 # according to `debian/control` file, e.g. `pvs` command used by `src/ceph-volume/ceph_volume/api/lvm.py` - lz4 - malloc - oath-toolkit - openldap - optLibatomic_ops - optLibs3 - optYasm - parted # according to `debian/control` file, used by `src/ceph-volume/ceph_volume/util/disk.py` - rdkafka - rocksdb' - snappy - openssh # according to `debian/control` file, `ssh` command used by `cephadm` - sqlite - utf8proc - xfsprogs # according to `debian/control` file, `ceph-volume` is supposed to use it - zlib - zstd - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - keyutils - libcap_ng - liburing - libuuid - linuxHeaders - optLibaio - optLibxfs - optZfs - rabbitmq-c - rdma-core - udev - util-linux - ] ++ lib.optionals hasRadosgw [ - optCurl - optExpat - optFuse - optLibedit - ]; + buildInputs = + cryptoLibsMap.${cryptoStr} + ++ [ + arrow-cpp + babeltrace + boost + bzip2 + # Adding `ceph-python-env` here adds the env's `site-packages` to `PYTHONPATH` during the build. + # This is important, otherwise the build system may not find the Python deps and then + # silently skip installing ceph-volume and other Ceph python tools. + ceph-python-env + cryptsetup + cunit + e2fsprogs # according to `debian/control` file, `ceph-volume` is supposed to use it + gperf + gtest + icu + libcap + libnl + libxml2 + lmdb + lttng-ust + lua + lvm2 # according to `debian/control` file, e.g. `pvs` command used by `src/ceph-volume/ceph_volume/api/lvm.py` + lz4 + malloc + oath-toolkit + openldap + optLibatomic_ops + optLibs3 + optYasm + parted # according to `debian/control` file, used by `src/ceph-volume/ceph_volume/util/disk.py` + rdkafka + rocksdb' + snappy + openssh # according to `debian/control` file, `ssh` command used by `cephadm` + sqlite + utf8proc + xfsprogs # according to `debian/control` file, `ceph-volume` is supposed to use it + zlib + zstd + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + keyutils + libcap_ng + liburing + libuuid + linuxHeaders + optLibaio + optLibxfs + optZfs + rabbitmq-c + rdma-core + udev + util-linux + ] + ++ lib.optionals hasRadosgw [ + optCurl + optExpat + optFuse + optLibedit + ]; # Picked up, amongst others, by `wrapPythonPrograms`. pythonPath = [ @@ -411,7 +447,7 @@ in rec { # replace /sbin and /bin based paths with direct nix store paths # increase the `command` buffer size since 2 nix store paths cannot fit within 128 characters - preConfigure ='' + preConfigure = '' substituteInPlace src/common/module.c \ --replace "char command[128];" "char command[256];" \ --replace "/sbin/modinfo" "${kmod}/bin/modinfo" \ @@ -484,7 +520,13 @@ in rec { test -f $out/bin/ceph-volume ''; - outputs = [ "out" "lib" "dev" "doc" "man" ]; + outputs = [ + "out" + "lib" + "dev" + "doc" + "man" + ]; doCheck = false; # uses pip to install things from the internet @@ -501,25 +543,29 @@ in rec { ceph-multi-node ceph-single-node ceph-single-node-bluestore - ceph-single-node-bluestore-dmcrypt; + ceph-single-node-bluestore-dmcrypt + ; }; }; }; - ceph-client = runCommand "ceph-client-${version}" { - meta = getMeta "Tools needed to mount Ceph's RADOS Block Devices/Cephfs"; - } '' - mkdir -p $out/{bin,etc,${sitePackages},share/bash-completion/completions} - cp -r ${ceph}/bin/{ceph,.ceph-wrapped,rados,rbd,rbdmap} $out/bin - cp -r ${ceph}/bin/ceph-{authtool,conf,dencoder,rbdnamer,syn} $out/bin - cp -r ${ceph}/bin/rbd-replay* $out/bin - cp -r ${ceph}/sbin/mount.ceph $out/bin - cp -r ${ceph}/sbin/mount.fuse.ceph $out/bin - ln -s bin $out/sbin - cp -r ${ceph}/${sitePackages}/* $out/${sitePackages} - cp -r ${ceph}/etc/bash_completion.d $out/share/bash-completion/completions - # wrapPythonPrograms modifies .ceph-wrapped, so lets just update its paths - substituteInPlace $out/bin/ceph --replace ${ceph} $out - substituteInPlace $out/bin/.ceph-wrapped --replace ${ceph} $out - ''; + ceph-client = + runCommand "ceph-client-${version}" + { + meta = getMeta "Tools needed to mount Ceph's RADOS Block Devices/Cephfs"; + } + '' + mkdir -p $out/{bin,etc,${sitePackages},share/bash-completion/completions} + cp -r ${ceph}/bin/{ceph,.ceph-wrapped,rados,rbd,rbdmap} $out/bin + cp -r ${ceph}/bin/ceph-{authtool,conf,dencoder,rbdnamer,syn} $out/bin + cp -r ${ceph}/bin/rbd-replay* $out/bin + cp -r ${ceph}/sbin/mount.ceph $out/bin + cp -r ${ceph}/sbin/mount.fuse.ceph $out/bin + ln -s bin $out/sbin + cp -r ${ceph}/${sitePackages}/* $out/${sitePackages} + cp -r ${ceph}/etc/bash_completion.d $out/share/bash-completion/completions + # wrapPythonPrograms modifies .ceph-wrapped, so lets just update its paths + substituteInPlace $out/bin/ceph --replace ${ceph} $out + substituteInPlace $out/bin/.ceph-wrapped --replace ${ceph} $out + ''; } diff --git a/pkgs/tools/filesystems/disorderfs/default.nix b/pkgs/tools/filesystems/disorderfs/default.nix index 062173f6972e3d..294222cb504476 100644 --- a/pkgs/tools/filesystems/disorderfs/default.nix +++ b/pkgs/tools/filesystems/disorderfs/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, fuse, attr, asciidoc }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + fuse, + attr, + asciidoc, +}: stdenv.mkDerivation rec { pname = "disorderfs"; @@ -9,9 +17,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-KqAMKVUykCgVdNyjacZjpVXqVdeob76v0iOuSd4TNIY="; }; - nativeBuildInputs = [ pkg-config asciidoc ]; + nativeBuildInputs = [ + pkg-config + asciidoc + ]; - buildInputs = [ fuse attr ]; + buildInputs = [ + fuse + attr + ]; installFlags = [ "PREFIX=$(out)" ]; diff --git a/pkgs/tools/filesystems/duff/default.nix b/pkgs/tools/filesystems/duff/default.nix index 1059f89ea5d3ec..3fca46a96bbd1f 100644 --- a/pkgs/tools/filesystems/duff/default.nix +++ b/pkgs/tools/filesystems/duff/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, gettext }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gettext, +}: stdenv.mkDerivation { pname = "duff"; @@ -11,7 +17,10 @@ stdenv.mkDerivation { owner = "elmindreda"; }; - nativeBuildInputs = [ autoreconfHook gettext ]; + nativeBuildInputs = [ + autoreconfHook + gettext + ]; preAutoreconf = '' # gettexttize rightly refuses to run non-interactively: diff --git a/pkgs/tools/filesystems/encfs/default.nix b/pkgs/tools/filesystems/encfs/default.nix index 4f546932c733b2..0cbcc4ab832eb0 100644 --- a/pkgs/tools/filesystems/encfs/default.nix +++ b/pkgs/tools/filesystems/encfs/default.nix @@ -1,6 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch -, cmake, pkg-config, perl -, gettext, fuse, openssl, tinyxml2 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + cmake, + pkg-config, + perl, + gettext, + fuse, + openssl, + tinyxml2, }: stdenv.mkDerivation rec { @@ -23,19 +32,31 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ gettext fuse openssl tinyxml2 ]; - nativeBuildInputs = [ cmake pkg-config perl ]; + buildInputs = [ + gettext + fuse + openssl + tinyxml2 + ]; + nativeBuildInputs = [ + cmake + pkg-config + perl + ]; - cmakeFlags = - [ "-DUSE_INTERNAL_TINYXML=OFF" - "-DBUILD_SHARED_LIBS=ON" - "-DINSTALL_LIBENCFS=ON" - ]; + cmakeFlags = [ + "-DUSE_INTERNAL_TINYXML=OFF" + "-DBUILD_SHARED_LIBS=ON" + "-DINSTALL_LIBENCFS=ON" + ]; meta = with lib; { description = "Encrypted filesystem in user-space via FUSE"; homepage = "https://vgough.github.io/encfs"; - license = with licenses; [ gpl3Plus lgpl3Plus ]; + license = with licenses; [ + gpl3Plus + lgpl3Plus + ]; platforms = platforms.unix; }; } diff --git a/pkgs/tools/filesystems/fuse-ext2/default.nix b/pkgs/tools/filesystems/fuse-ext2/default.nix index e608bc5a41db86..49ae5aa6e2f148 100644 --- a/pkgs/tools/filesystems/fuse-ext2/default.nix +++ b/pkgs/tools/filesystems/fuse-ext2/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, e2fsprogs -, fuse +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + e2fsprogs, + fuse, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/tools/filesystems/garage/default.nix b/pkgs/tools/filesystems/garage/default.nix index 3f8f2389a81ddb..0afd39c0f4fe29 100644 --- a/pkgs/tools/filesystems/garage/default.nix +++ b/pkgs/tools/filesystems/garage/default.nix @@ -1,91 +1,114 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitea -, openssl -, pkg-config -, protobuf -, cacert -, garage -, nixosTests +{ + lib, + stdenv, + rustPlatform, + fetchFromGitea, + openssl, + pkg-config, + protobuf, + cacert, + garage, + nixosTests, }: let - generic = { version, hash, cargoHash, cargoPatches ? [], eol ? false, broken ? false }: rustPlatform.buildRustPackage { - pname = "garage"; - inherit version; - - src = fetchFromGitea { - domain = "git.deuxfleurs.fr"; - owner = "Deuxfleurs"; - repo = "garage"; - rev = "v${version}"; - inherit hash; + generic = + { + version, + hash, + cargoHash, + cargoPatches ? [ ], + eol ? false, + broken ? false, + }: + rustPlatform.buildRustPackage { + pname = "garage"; + inherit version; + + src = fetchFromGitea { + domain = "git.deuxfleurs.fr"; + owner = "Deuxfleurs"; + repo = "garage"; + rev = "v${version}"; + inherit hash; + }; + + postPatch = '' + # Starting in 0.9.x series, Garage is using mold in local development + # and this leaks in this packaging, we remove it to use the default linker. + rm .cargo/config.toml || true + ''; + + inherit cargoHash cargoPatches; + + nativeBuildInputs = [ + protobuf + pkg-config + ]; + + buildInputs = [ + openssl + ]; + + checkInputs = [ + cacert + ]; + + OPENSSL_NO_VENDOR = true; + + # See https://git.deuxfleurs.fr/Deuxfleurs/garage/src/tag/v0.8.2/nix/compile.nix#L192-L198 + # on version changes for checking if changes are required here + buildFeatures = + [ + "kubernetes-discovery" + "bundled-libs" + ] + ++ lib.optional (lib.versionOlder version "1.0") "sled" + ++ [ + "metrics" + "k2v" + "telemetry-otlp" + "lmdb" + "sqlite" + "consul-discovery" + ]; + + # To make integration tests pass, we include the optional k2v feature here, + # but in buildFeatures only for version 0.8+, where it's enabled by default. + # See: https://garagehq.deuxfleurs.fr/documentation/reference-manual/k2v/ + checkFeatures = + [ + "k2v" + "kubernetes-discovery" + "bundled-libs" + ] + ++ lib.optional (lib.versionOlder version "1.0") "sled" + ++ [ + "lmdb" + "sqlite" + ]; + + disabledTests = [ + # Upstream told us this test is flakey. + "k2v::poll::test_poll_item" + ]; + + passthru.tests = nixosTests.garage; + + meta = { + description = "S3-compatible object store for small self-hosted geo-distributed deployments"; + changelog = "https://git.deuxfleurs.fr/Deuxfleurs/garage/releases/tag/v${version}"; + homepage = "https://garagehq.deuxfleurs.fr"; + license = lib.licenses.agpl3Only; + maintainers = with lib.maintainers; [ + nickcao + _0x4A6F + teutat3s + ]; + knownVulnerabilities = (lib.optional eol "Garage version ${version} is EOL"); + inherit broken; + mainProgram = "garage"; + }; }; - - postPatch = '' - # Starting in 0.9.x series, Garage is using mold in local development - # and this leaks in this packaging, we remove it to use the default linker. - rm .cargo/config.toml || true - ''; - - inherit cargoHash cargoPatches; - - nativeBuildInputs = [ protobuf pkg-config ]; - - buildInputs = [ - openssl - ]; - - checkInputs = [ - cacert - ]; - - OPENSSL_NO_VENDOR = true; - - # See https://git.deuxfleurs.fr/Deuxfleurs/garage/src/tag/v0.8.2/nix/compile.nix#L192-L198 - # on version changes for checking if changes are required here - buildFeatures = [ - "kubernetes-discovery" - "bundled-libs" - ] ++ lib.optional (lib.versionOlder version "1.0") "sled" ++ [ - "metrics" - "k2v" - "telemetry-otlp" - "lmdb" - "sqlite" - "consul-discovery" - ]; - - # To make integration tests pass, we include the optional k2v feature here, - # but in buildFeatures only for version 0.8+, where it's enabled by default. - # See: https://garagehq.deuxfleurs.fr/documentation/reference-manual/k2v/ - checkFeatures = [ - "k2v" - "kubernetes-discovery" - "bundled-libs" - ] ++ lib.optional (lib.versionOlder version "1.0") "sled" ++ [ - "lmdb" - "sqlite" - ]; - - disabledTests = [ - # Upstream told us this test is flakey. - "k2v::poll::test_poll_item" - ]; - - passthru.tests = nixosTests.garage; - - meta = { - description = "S3-compatible object store for small self-hosted geo-distributed deployments"; - changelog = "https://git.deuxfleurs.fr/Deuxfleurs/garage/releases/tag/v${version}"; - homepage = "https://garagehq.deuxfleurs.fr"; - license = lib.licenses.agpl3Only; - maintainers = with lib.maintainers; [ nickcao _0x4A6F teutat3s ]; - knownVulnerabilities = (lib.optional eol "Garage version ${version} is EOL"); - inherit broken; - mainProgram = "garage"; - }; - }; in rec { # Until Garage hits 1.0, 0.7.3 is equivalent to 7.3.0 for now, therefore diff --git a/pkgs/tools/filesystems/irods/common.nix b/pkgs/tools/filesystems/irods/common.nix index aaa96fdec84bfd..9f77802b66ce71 100644 --- a/pkgs/tools/filesystems/irods/common.nix +++ b/pkgs/tools/filesystems/irods/common.nix @@ -28,7 +28,7 @@ curl, spdlog_rods, bison, - flex + flex, }: # Common attributes of irods packages diff --git a/pkgs/tools/filesystems/irods/default.nix b/pkgs/tools/filesystems/irods/default.nix index ca5fe7fa7329c5..e5e6f29e7eb429 100644 --- a/pkgs/tools/filesystems/irods/default.nix +++ b/pkgs/tools/filesystems/irods/default.nix @@ -29,7 +29,7 @@ spdlog_llvm, curl, bison, - flex + flex, }: let @@ -127,7 +127,7 @@ rec { meta = common.meta // { longDescription = common.meta.longDescription + "This package provides the servers and libraries."; - mainProgram = "irodsServer"; + mainProgram = "irodsServer"; }; } ); diff --git a/pkgs/tools/filesystems/juicefs/default.nix b/pkgs/tools/filesystems/juicefs/default.nix index 496cdb0db53797..17e20bdcc2af48 100644 --- a/pkgs/tools/filesystems/juicefs/default.nix +++ b/pkgs/tools/filesystems/juicefs/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromGitHub +{ + lib, + buildGoModule, + fetchFromGitHub, }: buildGoModule rec { diff --git a/pkgs/tools/filesystems/kdiskmark/default.nix b/pkgs/tools/filesystems/kdiskmark/default.nix index 95105b5ece1ae6..e094f6ce5ee8a6 100644 --- a/pkgs/tools/filesystems/kdiskmark/default.nix +++ b/pkgs/tools/filesystems/kdiskmark/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, lib -, wrapQtAppsHook -, qtbase -, qttools -, fio -, cmake -, polkit-qt -, extra-cmake-modules -, fetchFromGitHub +{ + stdenv, + lib, + wrapQtAppsHook, + qtbase, + qttools, + fio, + cmake, + polkit-qt, + extra-cmake-modules, + fetchFromGitHub, }: stdenv.mkDerivation rec { pname = "kdiskmark"; @@ -21,7 +22,10 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; buildInputs = [ qtbase @@ -35,8 +39,12 @@ stdenv.mkDerivation rec { --replace \$\{POLKITQT-1_POLICY_FILES_INSTALL_DIR\} $out/share/polkit-1/actions ''; - qtWrapperArgs = - [ "--prefix" "PATH" ":" (lib.makeBinPath [ fio ]) ]; + qtWrapperArgs = [ + "--prefix" + "PATH" + ":" + (lib.makeBinPath [ fio ]) + ]; meta = with lib; { description = "HDD and SSD benchmark tool with a friendly graphical user interface"; @@ -52,4 +60,3 @@ stdenv.mkDerivation rec { mainProgram = "kdiskmark"; }; } - diff --git a/pkgs/tools/filesystems/kio-fuse/default.nix b/pkgs/tools/filesystems/kio-fuse/default.nix index 5d8e290592612b..72fff84067026d 100644 --- a/pkgs/tools/filesystems/kio-fuse/default.nix +++ b/pkgs/tools/filesystems/kio-fuse/default.nix @@ -1,10 +1,11 @@ -{ lib -, mkDerivation -, fetchgit -, cmake -, extra-cmake-modules -, kio -, fuse3 +{ + lib, + mkDerivation, + fetchgit, + cmake, + extra-cmake-modules, + kio, + fuse3, }: mkDerivation rec { @@ -17,9 +18,15 @@ mkDerivation rec { rev = "v${version}"; }; - nativeBuildInputs = [ cmake extra-cmake-modules ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; - buildInputs = [ kio fuse3 ]; + buildInputs = [ + kio + fuse3 + ]; meta = with lib; { description = "FUSE Interface for KIO"; diff --git a/pkgs/tools/filesystems/mergerfs/default.nix b/pkgs/tools/filesystems/mergerfs/default.nix index 27cab657132d83..ff57c0c4ba785e 100644 --- a/pkgs/tools/filesystems/mergerfs/default.nix +++ b/pkgs/tools/filesystems/mergerfs/default.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, automake, autoconf, pkg-config, gettext, libtool, pandoc, which, attr, libiconv }: +{ + lib, + stdenv, + fetchFromGitHub, + automake, + autoconf, + pkg-config, + gettext, + libtool, + pandoc, + which, + attr, + libiconv, +}: stdenv.mkDerivation rec { pname = "mergerfs"; @@ -12,18 +25,32 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - automake autoconf pkg-config gettext libtool pandoc which + automake + autoconf + pkg-config + gettext + libtool + pandoc + which ]; prePatch = '' sed -i -e '/chown/d' -e '/chmod/d' libfuse/Makefile ''; - buildInputs = [ attr libiconv ]; + buildInputs = [ + attr + libiconv + ]; preConfigure = '' echo "${version}" > VERSION ''; - makeFlags = [ "DESTDIR=${placeholder "out"}" "XATTR_AVAILABLE=1" "PREFIX=/" "SBINDIR=/bin" ]; + makeFlags = [ + "DESTDIR=${placeholder "out"}" + "XATTR_AVAILABLE=1" + "PREFIX=/" + "SBINDIR=/bin" + ]; enableParallelBuilding = true; postFixup = '' diff --git a/pkgs/tools/filesystems/mergerfs/tools.nix b/pkgs/tools/filesystems/mergerfs/tools.nix index 2708328bf4d6eb..3b89c3c00c79a0 100644 --- a/pkgs/tools/filesystems/mergerfs/tools.nix +++ b/pkgs/tools/filesystems/mergerfs/tools.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub, coreutils, makeWrapper -, rsync, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + coreutils, + makeWrapper, + rsync, + python3, +}: stdenv.mkDerivation rec { pname = "mergerfs-tools"; diff --git a/pkgs/tools/filesystems/mkspiffs/default.nix b/pkgs/tools/filesystems/mkspiffs/default.nix index c2712376da6bb7..808b27dd687dfe 100644 --- a/pkgs/tools/filesystems/mkspiffs/default.nix +++ b/pkgs/tools/filesystems/mkspiffs/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: # Changing the variables CPPFLAGS and BUILD_CONFIG_NAME can be done by # overriding the same-named attributes. See ./presets.nix for examples. diff --git a/pkgs/tools/filesystems/mkspiffs/presets.nix b/pkgs/tools/filesystems/mkspiffs/presets.nix index d4008b2fa3c3c0..4bd747c06298fb 100644 --- a/pkgs/tools/filesystems/mkspiffs/presets.nix +++ b/pkgs/tools/filesystems/mkspiffs/presets.nix @@ -2,19 +2,22 @@ # We provide the same presets as the upstream -lib.mapAttrs ( - name: { CPPFLAGS }: - mkspiffs.overrideAttrs { - inherit CPPFLAGS; - BUILD_CONFIG_NAME = "-${name}"; - } -) { - arduino-esp8266.CPPFLAGS = [ - "-DSPIFFS_USE_MAGIC_LENGTH=0" - "-DSPIFFS_ALIGNED_OBJECT_INDEX_TABLES=1" - ]; +lib.mapAttrs + ( + name: + { CPPFLAGS }: + mkspiffs.overrideAttrs { + inherit CPPFLAGS; + BUILD_CONFIG_NAME = "-${name}"; + } + ) + { + arduino-esp8266.CPPFLAGS = [ + "-DSPIFFS_USE_MAGIC_LENGTH=0" + "-DSPIFFS_ALIGNED_OBJECT_INDEX_TABLES=1" + ]; - arduino-esp32.CPPFLAGS = [ "-DSPIFFS_OBJ_META_LEN=4" ]; + arduino-esp32.CPPFLAGS = [ "-DSPIFFS_OBJ_META_LEN=4" ]; - esp-idf.CPPFLAGS = [ "-DSPIFFS_OBJ_META_LEN=4" ]; -} + esp-idf.CPPFLAGS = [ "-DSPIFFS_OBJ_META_LEN=4" ]; + } diff --git a/pkgs/tools/filesystems/ntfs-3g/default.nix b/pkgs/tools/filesystems/ntfs-3g/default.nix index 5a9426cee486c4..ff1347c6c7e1df 100644 --- a/pkgs/tools/filesystems/ntfs-3g/default.nix +++ b/pkgs/tools/filesystems/ntfs-3g/default.nix @@ -1,13 +1,30 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config -, gettext, mount, libuuid, kmod, macfuse-stubs, DiskArbitration -, crypto ? false, libgcrypt, gnutls +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + gettext, + mount, + libuuid, + kmod, + macfuse-stubs, + DiskArbitration, + crypto ? false, + libgcrypt, + gnutls, }: stdenv.mkDerivation rec { pname = "ntfs3g"; version = "2022.10.3"; - outputs = [ "out" "dev" "man" "doc" ]; + outputs = [ + "out" + "dev" + "man" + "doc" + ]; src = fetchFromGitHub { owner = "tuxera"; @@ -16,13 +33,27 @@ stdenv.mkDerivation rec { sha256 = "sha256-nuFTsGkm3zmSzpwmhyY7Ke0VZfZU0jHOzEWaLBbglQk="; }; - buildInputs = [ gettext libuuid ] - ++ lib.optionals crypto [ gnutls libgcrypt ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ macfuse-stubs DiskArbitration ]; + buildInputs = + [ + gettext + libuuid + ] + ++ lib.optionals crypto [ + gnutls + libgcrypt + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + macfuse-stubs + DiskArbitration + ]; # Note: libgcrypt is listed here non-optionally because its m4 macros are # being used in ntfs-3g's configure.ac. - nativeBuildInputs = [ autoreconfHook libgcrypt pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + libgcrypt + pkg-config + ]; patches = [ # https://github.com/tuxera/ntfs-3g/pull/39 @@ -30,25 +61,26 @@ stdenv.mkDerivation rec { ./consistent-sbindir-usage.patch ]; - configureFlags = [ - "--disable-ldconfig" - "--exec-prefix=\${prefix}" - "--enable-mount-helper" - "--enable-posix-acls" - "--enable-xattr-mappings" - "--${if crypto then "enable" else "disable"}-crypto" - "--enable-extras" - "--with-mount-helper=${mount}/bin/mount" - "--with-umount-helper=${mount}/bin/umount" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "--with-modprobe-helper=${kmod}/bin/modprobe" - ]; + configureFlags = + [ + "--disable-ldconfig" + "--exec-prefix=\${prefix}" + "--enable-mount-helper" + "--enable-posix-acls" + "--enable-xattr-mappings" + "--${if crypto then "enable" else "disable"}-crypto" + "--enable-extras" + "--with-mount-helper=${mount}/bin/mount" + "--with-umount-helper=${mount}/bin/umount" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "--with-modprobe-helper=${kmod}/bin/modprobe" + ]; - postInstall = - '' - # Prefer ntfs-3g over the ntfs driver in the kernel. - ln -sv mount.ntfs-3g $out/sbin/mount.ntfs - ''; + postInstall = '' + # Prefer ntfs-3g over the ntfs driver in the kernel. + ln -sv mount.ntfs-3g $out/sbin/mount.ntfs + ''; enableParallelBuilding = true; diff --git a/pkgs/tools/filesystems/orangefs/default.nix b/pkgs/tools/filesystems/orangefs/default.nix index 0566a8a4c12949..69080eec167e16 100644 --- a/pkgs/tools/filesystems/orangefs/default.nix +++ b/pkgs/tools/filesystems/orangefs/default.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, fetchurl, fetchpatch, bison, flex, autoreconfHook -, openssl, db, attr, perl, tcsh -, nixosTests -} : +{ + lib, + stdenv, + fetchurl, + fetchpatch, + bison, + flex, + autoreconfHook, + openssl, + db, + attr, + perl, + tcsh, + nixosTests, +}: stdenv.mkDerivation rec { pname = "orangefs"; @@ -21,8 +32,18 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ bison flex perl autoreconfHook ]; - buildInputs = [ openssl db attr tcsh ]; + nativeBuildInputs = [ + bison + flex + perl + autoreconfHook + ]; + buildInputs = [ + openssl + db + attr + tcsh + ]; postPatch = '' # Issue introduced by attr-2.4.48 @@ -45,7 +66,6 @@ stdenv.mkDerivation rec { "--with-ssl=${lib.getDev openssl}" ]; - enableParallelBuilding = true; postInstall = '' @@ -66,7 +86,14 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Scale-out network file system for use on high-end computing systems"; homepage = "http://www.orangefs.org/"; - license = with licenses; [ asl20 bsd3 gpl2Only lgpl21 lgpl21Plus openldap ]; + license = with licenses; [ + asl20 + bsd3 + gpl2Only + lgpl21 + lgpl21Plus + openldap + ]; platforms = [ "x86_64-linux" ]; maintainers = with maintainers; [ markuskowa ]; }; diff --git a/pkgs/tools/filesystems/romdirfs/default.nix b/pkgs/tools/filesystems/romdirfs/default.nix index 1b7e2f17a1afea..387d17ce1861c2 100644 --- a/pkgs/tools/filesystems/romdirfs/default.nix +++ b/pkgs/tools/filesystems/romdirfs/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, fuse }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + pkg-config, + fuse, +}: stdenv.mkDerivation rec { pname = "romdirfs"; @@ -11,7 +18,10 @@ stdenv.mkDerivation rec { sha256 = "1jbsmpklrycz5q86qmzvbz4iz2g5fvd7p9nca160aw2izwpws0g7"; }; - nativeBuildInputs = [ cmake pkg-config ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; buildInputs = [ fuse ]; meta = with lib; { diff --git a/pkgs/tools/filesystems/s3fs/default.nix b/pkgs/tools/filesystems/s3fs/default.nix index 3ffa8064050706..4ca4d71a8f6b41 100644 --- a/pkgs/tools/filesystems/s3fs/default.nix +++ b/pkgs/tools/filesystems/s3fs/default.nix @@ -1,18 +1,36 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, curl, openssl, libxml2, fuse }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + curl, + openssl, + libxml2, + fuse, +}: stdenv.mkDerivation rec { pname = "s3fs-fuse"; version = "1.95"; src = fetchFromGitHub { - owner = "s3fs-fuse"; - repo = "s3fs-fuse"; - rev = "v${version}"; + owner = "s3fs-fuse"; + repo = "s3fs-fuse"; + rev = "v${version}"; sha256 = "sha256-wHszw3S+fuZRwTvJy+FkxQTR2BAvr8H924Wd4/C5heE="; }; - buildInputs = [ curl openssl libxml2 fuse ]; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + buildInputs = [ + curl + openssl + libxml2 + fuse + ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; configureFlags = [ "--with-openssl" diff --git a/pkgs/tools/filesystems/securefs/default.nix b/pkgs/tools/filesystems/securefs/default.nix index fe148e955cb2a6..1dd426b55a370d 100644 --- a/pkgs/tools/filesystems/securefs/default.nix +++ b/pkgs/tools/filesystems/securefs/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, fuse +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + fuse, }: stdenv.mkDerivation rec { @@ -33,7 +34,10 @@ stdenv.mkDerivation rec { automatically updated to contain the encrypted and authenticated contents. ''; - license = with licenses; [ bsd2 mit ]; + license = with licenses; [ + bsd2 + mit + ]; platforms = platforms.unix; mainProgram = "securefs"; }; diff --git a/pkgs/tools/filesystems/squashfs-tools-ng/default.nix b/pkgs/tools/filesystems/squashfs-tools-ng/default.nix index c6aa557d77fbbd..5e8625f3f53551 100644 --- a/pkgs/tools/filesystems/squashfs-tools-ng/default.nix +++ b/pkgs/tools/filesystems/squashfs-tools-ng/default.nix @@ -1,5 +1,17 @@ -{ stdenv, lib, fetchurl, doxygen, graphviz, perl, pkg-config -, bzip2, lz4, lzo, xz, zlib, zstd +{ + stdenv, + lib, + fetchurl, + doxygen, + graphviz, + perl, + pkg-config, + bzip2, + lz4, + lzo, + xz, + zlib, + zstd, }: stdenv.mkDerivation rec { @@ -11,8 +23,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-DZB6w+c1w1HkfIZ/tR2Uv/o7BfuVvsAfMehIt8RCFak="; }; - nativeBuildInputs = [ doxygen graphviz pkg-config perl ]; - buildInputs = [ bzip2 zlib xz lz4 lzo zstd ]; + nativeBuildInputs = [ + doxygen + graphviz + pkg-config + perl + ]; + buildInputs = [ + bzip2 + zlib + xz + lz4 + lzo + zstd + ]; enableParallelBuilding = true; diff --git a/pkgs/tools/filesystems/ssdfs-utils/default.nix b/pkgs/tools/filesystems/ssdfs-utils/default.nix index 38efbad0f2c390..b176a4530e3005 100644 --- a/pkgs/tools/filesystems/ssdfs-utils/default.nix +++ b/pkgs/tools/filesystems/ssdfs-utils/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, libtool -, libuuid -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + libtool, + libuuid, + zlib, }: stdenv.mkDerivation { diff --git a/pkgs/tools/games/ajour/default.nix b/pkgs/tools/games/ajour/default.nix index 5ed670a77de6fe..d0e4dc5285ce0e 100644 --- a/pkgs/tools/games/ajour/default.nix +++ b/pkgs/tools/games/ajour/default.nix @@ -1,26 +1,27 @@ -{ stdenv -, lib -, fetchFromGitHub -, rustPlatform -, autoPatchelfHook -, cmake -, makeWrapper -, pkg-config -, python3 -, expat -, freetype -, kdialog -, zenity -, openssl -, libglvnd -, libX11 -, libxcb -, libXcursor -, libXi -, libxkbcommon -, libXrandr -, vulkan-loader -, wayland +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + autoPatchelfHook, + cmake, + makeWrapper, + pkg-config, + python3, + expat, + freetype, + kdialog, + zenity, + openssl, + libglvnd, + libX11, + libxcb, + libXcursor, + libXi, + libxkbcommon, + libXrandr, + vulkan-loader, + wayland, }: let @@ -35,7 +36,8 @@ let wayland ]; -in rustPlatform.buildRustPackage rec { +in +rustPlatform.buildRustPackage rec { pname = "ajour"; version = "1.3.2"; @@ -78,7 +80,12 @@ in rustPlatform.buildRustPackage rec { fixupPhase = '' patchelf --set-rpath "${lib.makeLibraryPath rpathLibs}:$(patchelf --print-rpath $out/bin/ajour)" $out/bin/ajour - wrapProgram $out/bin/ajour --prefix PATH ":" ${lib.makeBinPath [ zenity kdialog ]} + wrapProgram $out/bin/ajour --prefix PATH ":" ${ + lib.makeBinPath [ + zenity + kdialog + ] + } ''; meta = with lib; { diff --git a/pkgs/tools/games/alice-tools/default.nix b/pkgs/tools/games/alice-tools/default.nix index 07d96cbd03fa0c..7964aa77c38a78 100644 --- a/pkgs/tools/games/alice-tools/default.nix +++ b/pkgs/tools/games/alice-tools/default.nix @@ -1,21 +1,22 @@ -{ stdenv -, lib -, gitUpdater -, testers -, fetchFromGitHub -, meson -, ninja -, pkg-config -, bison -, flex -, libiconv -, libpng -, libjpeg -, libwebp -, zlib -, withGUI ? true -, qtbase ? null -, wrapQtAppsHook ? null +{ + stdenv, + lib, + gitUpdater, + testers, + fetchFromGitHub, + meson, + ninja, + pkg-config, + bison, + flex, + libiconv, + libpng, + libjpeg, + libwebp, + zlib, + withGUI ? true, + qtbase ? null, + wrapQtAppsHook ? null, }: assert withGUI -> qtbase != null && wrapQtAppsHook != null; @@ -46,46 +47,55 @@ stdenv.mkDerivation (finalAttrs: { "-Dcpp_std=c++17" ]; - nativeBuildInputs = [ - meson - ninja - pkg-config - bison - flex - ] ++ lib.optionals withGUI [ - wrapQtAppsHook - ]; + nativeBuildInputs = + [ + meson + ninja + pkg-config + bison + flex + ] + ++ lib.optionals withGUI [ + wrapQtAppsHook + ]; - buildInputs = [ - libiconv - libpng - libjpeg - libwebp - zlib - ] ++ lib.optionals withGUI [ - qtbase - ]; + buildInputs = + [ + libiconv + libpng + libjpeg + libwebp + zlib + ] + ++ lib.optionals withGUI [ + qtbase + ]; dontWrapQtApps = true; # Default install step only installs a static library of a build dependency - installPhase = '' - runHook preInstall + installPhase = + '' + runHook preInstall - install -Dm755 src/alice $out/bin/alice - '' + lib.optionalString withGUI '' - install -Dm755 src/galice $out/bin/galice - wrapQtApp $out/bin/galice - '' + '' + install -Dm755 src/alice $out/bin/alice + '' + + lib.optionalString withGUI '' + install -Dm755 src/galice $out/bin/galice + wrapQtApp $out/bin/galice + '' + + '' - runHook postInstall - ''; + runHook postInstall + ''; passthru = { updateScript = gitUpdater { }; tests.version = testers.testVersion { package = finalAttrs.finalPackage; - command = lib.optionalString withGUI "env QT_QPA_PLATFORM=minimal " + "${lib.getExe finalAttrs.finalPackage} --version"; + command = + lib.optionalString withGUI "env QT_QPA_PLATFORM=minimal " + + "${lib.getExe finalAttrs.finalPackage} --version"; }; }; diff --git a/pkgs/tools/games/gamemode/default.nix b/pkgs/tools/games/gamemode/default.nix index 6744bcdb60801b..0156033f1d3904 100644 --- a/pkgs/tools/games/gamemode/default.nix +++ b/pkgs/tools/games/gamemode/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchFromGitHub -, libgamemode32 -, makeWrapper -, meson -, ninja -, pkg-config -, dbus -, inih -, systemd -, appstream -, findutils -, gawk -, procps -, nix-update-script +{ + lib, + stdenv, + fetchFromGitHub, + libgamemode32, + makeWrapper, + meson, + ninja, + pkg-config, + dbus, + inih, + systemd, + appstream, + findutils, + gawk, + procps, + nix-update-script, }: stdenv.mkDerivation (finalAttrs: { @@ -27,7 +28,12 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-JkDFhFLUHlgD6RKxlxMjrSF2zQ4AWmRUQMLbWYwIZmg="; }; - outputs = [ "out" "dev" "lib" "man" ]; + outputs = [ + "out" + "dev" + "lib" + "man" + ]; patches = [ # Add @libraryPath@ template variable to fix loading the PRELOAD library @@ -36,12 +42,17 @@ stdenv.mkDerivation (finalAttrs: { postPatch = '' substituteInPlace data/gamemoderun \ - --subst-var-by libraryPath ${lib.makeLibraryPath ([ - (placeholder "lib") - ] ++ lib.optionals (stdenv.hostPlatform.system == "x86_64-linux") [ - # Support wrapping 32bit applications on a 64bit linux system - libgamemode32 - ])} + --subst-var-by libraryPath ${ + lib.makeLibraryPath ( + [ + (placeholder "lib") + ] + ++ lib.optionals (stdenv.hostPlatform.system == "x86_64-linux") [ + # Support wrapping 32bit applications on a 64bit linux system + libgamemode32 + ] + ) + } ''; nativeBuildInputs = [ @@ -83,11 +94,13 @@ stdenv.mkDerivation (finalAttrs: { done wrapProgram "$out/bin/gamemodelist" \ - --prefix PATH : ${lib.makeBinPath [ - findutils - gawk - procps - ]} + --prefix PATH : ${ + lib.makeBinPath [ + findutils + gawk + procps + ] + } ''; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/tools/games/minecraft/mcaselector/default.nix b/pkgs/tools/games/minecraft/mcaselector/default.nix index cdec4e13923167..8745c9b5ba99d5 100644 --- a/pkgs/tools/games/minecraft/mcaselector/default.nix +++ b/pkgs/tools/games/minecraft/mcaselector/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, fetchurl -, makeWrapper -, wrapGAppsHook3 -, jre +{ + lib, + stdenvNoCC, + fetchurl, + makeWrapper, + wrapGAppsHook3, + jre, }: stdenvNoCC.mkDerivation (finalAttrs: { @@ -18,7 +19,11 @@ stdenvNoCC.mkDerivation (finalAttrs: { dontUnpack = true; dontBuild = true; - nativeBuildInputs = [ jre makeWrapper wrapGAppsHook3 ]; + nativeBuildInputs = [ + jre + makeWrapper + wrapGAppsHook3 + ]; dontWrapGApps = true; diff --git a/pkgs/tools/games/minecraft/optifine/default.nix b/pkgs/tools/games/minecraft/optifine/default.nix index e5608559af0da7..7eefb18fcc6080 100644 --- a/pkgs/tools/games/minecraft/optifine/default.nix +++ b/pkgs/tools/games/minecraft/optifine/default.nix @@ -1,6 +1,7 @@ -{ recurseIntoAttrs -, callPackage -, lib +{ + recurseIntoAttrs, + callPackage, + lib, }: # All versions are taken from `version.json` created by `update.py`, and realised with `generic.nix`. @@ -11,7 +12,5 @@ # $ nix-shell ./maintainers/scripts/update.nix --argstr package optifinePackages.optifine-latest --argstr commit true recurseIntoAttrs ( - lib.mapAttrs - (name: value: callPackage ./generic.nix value) - (lib.importJSON ./versions.json) + lib.mapAttrs (name: value: callPackage ./generic.nix value) (lib.importJSON ./versions.json) ) diff --git a/pkgs/tools/games/minecraft/optifine/generic.nix b/pkgs/tools/games/minecraft/optifine/generic.nix index a375ac9def7b87..124e8eb1598b2f 100644 --- a/pkgs/tools/games/minecraft/optifine/generic.nix +++ b/pkgs/tools/games/minecraft/optifine/generic.nix @@ -1,50 +1,56 @@ -{ version -, sha256 -, lib -, runCommand -, fetchurl -, makeWrapper -, jre +{ + version, + sha256, + lib, + runCommand, + fetchurl, + makeWrapper, + jre, }: let mcVersion = builtins.head (lib.splitString "_" version); in -runCommand "optifine-${mcVersion}" { - pname = "optifine"; - inherit version; +runCommand "optifine-${mcVersion}" + { + pname = "optifine"; + inherit version; - src = fetchurl { - url = "https://optifine.net/download?f=OptiFine_${version}.jar"; - inherit sha256; - name = "OptiFine_${version}.jar"; - }; + src = fetchurl { + url = "https://optifine.net/download?f=OptiFine_${version}.jar"; + inherit sha256; + name = "OptiFine_${version}.jar"; + }; - nativeBuildInputs = [ jre makeWrapper ]; + nativeBuildInputs = [ + jre + makeWrapper + ]; - passthru.updateScript = { - command = [ ./update.py ]; - supportedFeatures = [ "commit" ]; - }; + passthru.updateScript = { + command = [ ./update.py ]; + supportedFeatures = [ "commit" ]; + }; - meta = with lib; { - homepage = "https://optifine.net/"; - description = "Minecraft ${mcVersion} optimization mod"; - longDescription = '' - OptiFine is a Minecraft optimization mod. - It allows Minecraft to run faster and look better with full support for HD textures and many configuration options. - This is for version ${mcVersion} of Minecraft. - ''; - sourceProvenance = with sourceTypes; [ binaryBytecode ]; - license = licenses.unfree; - maintainers = [ ]; - platforms = platforms.unix; - mainProgram = "optifine"; - }; -} '' - mkdir -p $out/{bin,lib/optifine} - cp $src $out/lib/optifine/optifine.jar + meta = with lib; { + homepage = "https://optifine.net/"; + description = "Minecraft ${mcVersion} optimization mod"; + longDescription = '' + OptiFine is a Minecraft optimization mod. + It allows Minecraft to run faster and look better with full support for HD textures and many configuration options. + This is for version ${mcVersion} of Minecraft. + ''; + sourceProvenance = with sourceTypes; [ binaryBytecode ]; + license = licenses.unfree; + maintainers = [ ]; + platforms = platforms.unix; + mainProgram = "optifine"; + }; + } + '' + mkdir -p $out/{bin,lib/optifine} + cp $src $out/lib/optifine/optifine.jar - makeWrapper ${jre}/bin/java $out/bin/optifine \ - --add-flags "-jar $out/lib/optifine/optifine.jar" -'' + makeWrapper ${jre}/bin/java $out/bin/optifine \ + --add-flags "-jar $out/lib/optifine/optifine.jar" + '' diff --git a/pkgs/tools/games/mymcplus/default.nix b/pkgs/tools/games/mymcplus/default.nix index 9fa3c779785208..b6623698d9c9ca 100644 --- a/pkgs/tools/games/mymcplus/default.nix +++ b/pkgs/tools/games/mymcplus/default.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromSourcehut -, pythonPackages -, wrapGAppsHook3 +{ + lib, + fetchFromSourcehut, + pythonPackages, + wrapGAppsHook3, }: pythonPackages.buildPythonApplication rec { diff --git a/pkgs/tools/games/pokefinder/default.nix b/pkgs/tools/games/pokefinder/default.nix index 6ea5f168a8f4bd..ed9d62db08ce21 100644 --- a/pkgs/tools/games/pokefinder/default.nix +++ b/pkgs/tools/games/pokefinder/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, copyDesktopItems -, makeDesktopItem -, fetchFromGitHub -, fetchpatch -, cmake -, python3 -, qtbase -, qttools -, qtwayland -, imagemagick -, wrapQtAppsHook -, gitUpdater +{ + lib, + stdenv, + copyDesktopItems, + makeDesktopItem, + fetchFromGitHub, + fetchpatch, + cmake, + python3, + qtbase, + qttools, + qtwayland, + imagemagick, + wrapQtAppsHook, + gitUpdater, }: stdenv.mkDerivation rec { @@ -40,20 +41,33 @@ stdenv.mkDerivation rec { patchShebangs Source/Core/Resources/ ''; - installPhase = '' - runHook preInstall - '' + lib.optionalString (stdenv.hostPlatform.isDarwin) '' - mkdir -p $out/Applications - cp -R Source/PokeFinder.app $out/Applications - '' + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' - install -D Source/PokeFinder $out/bin/PokeFinder - mkdir -p $out/share/pixmaps - convert "$src/Source/Form/Images/pokefinder.ico[-1]" $out/share/pixmaps/pokefinder.png - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + '' + + lib.optionalString (stdenv.hostPlatform.isDarwin) '' + mkdir -p $out/Applications + cp -R Source/PokeFinder.app $out/Applications + '' + + lib.optionalString (!stdenv.hostPlatform.isDarwin) '' + install -D Source/PokeFinder $out/bin/PokeFinder + mkdir -p $out/share/pixmaps + convert "$src/Source/Form/Images/pokefinder.ico[-1]" $out/share/pixmaps/pokefinder.png + '' + + '' + runHook postInstall + ''; - nativeBuildInputs = [ cmake wrapQtAppsHook python3 ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ copyDesktopItems imagemagick ]; + nativeBuildInputs = + [ + cmake + wrapQtAppsHook + python3 + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + copyDesktopItems + imagemagick + ]; desktopItems = [ (makeDesktopItem { @@ -66,8 +80,10 @@ stdenv.mkDerivation rec { }) ]; - buildInputs = [ qtbase qttools ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ qtwayland ]; + buildInputs = [ + qtbase + qttools + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ qtwayland ]; passthru.updateScript = gitUpdater { rev-prefix = "v"; diff --git a/pkgs/tools/games/slipstream/default.nix b/pkgs/tools/games/slipstream/default.nix index f1fa38f893f899..8269072876f383 100644 --- a/pkgs/tools/games/slipstream/default.nix +++ b/pkgs/tools/games/slipstream/default.nix @@ -1,4 +1,10 @@ -{ lib, fetchFromGitHub, makeWrapper, maven, jdk }: +{ + lib, + fetchFromGitHub, + makeWrapper, + maven, + jdk, +}: maven.buildMavenPackage rec { pname = "slipstream"; diff --git a/pkgs/tools/games/steamback/default.nix b/pkgs/tools/games/steamback/default.nix index a41b5f3ca7fb26..662b6a06c6d88d 100644 --- a/pkgs/tools/games/steamback/default.nix +++ b/pkgs/tools/games/steamback/default.nix @@ -1,15 +1,16 @@ -{ lib -, buildPythonApplication -, fetchPypi -, setuptools -, setuptools-scm -, wheel -, pillow -, psutil -, async-tkinter-loop -, timeago -, platformdirs -, sv-ttk +{ + lib, + buildPythonApplication, + fetchPypi, + setuptools, + setuptools-scm, + wheel, + pillow, + psutil, + async-tkinter-loop, + timeago, + platformdirs, + sv-ttk, }: buildPythonApplication rec { diff --git a/pkgs/tools/graphics/asymptote/default.nix b/pkgs/tools/graphics/asymptote/default.nix index d2fb26e3e336b0..59d6745ebb2d38 100644 --- a/pkgs/tools/graphics/asymptote/default.nix +++ b/pkgs/tools/graphics/asymptote/default.nix @@ -1,19 +1,50 @@ -{ lib, stdenv, fetchurl -, autoreconfHook, bison, glm, flex, wrapQtAppsHook, cmake, pkg-config -, libglut, ghostscriptX, imagemagick, fftw, eigen, libtirpc -, boehmgc, libGLU, libGL, ncurses, readline, gsl, libsigsegv -, python3, qtbase, qtsvg, boost -, zlib, perl, curl -, texinfo -, texliveSmall -, darwin +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + bison, + glm, + flex, + wrapQtAppsHook, + cmake, + pkg-config, + libglut, + ghostscriptX, + imagemagick, + fftw, + eigen, + libtirpc, + boehmgc, + libGLU, + libGL, + ncurses, + readline, + gsl, + libsigsegv, + python3, + qtbase, + qtsvg, + boost, + zlib, + perl, + curl, + texinfo, + texliveSmall, + darwin, }: stdenv.mkDerivation (finalAttrs: { version = "2.92"; pname = "asymptote"; - outputs = [ "out" "man" "info" "doc" "tex" ]; + outputs = [ + "out" + "man" + "info" + "doc" + "tex" + ]; src = fetchurl { url = "mirror://sourceforge/asymptote/${finalAttrs.version}/asymptote-${finalAttrs.version}.src.tgz"; @@ -24,32 +55,72 @@ stdenv.mkDerivation (finalAttrs: { texContainer = null; texdocContainer = null; - nativeBuildInputs = [ - autoreconfHook - bison - flex - bison - texinfo - wrapQtAppsHook - cmake - pkg-config - ] ++ lib.optional (finalAttrs.texContainer == null || finalAttrs.texdocContainer == null) - (texliveSmall.withPackages (ps: with ps; [ epsf cm-super ps.texinfo media9 ocgx2 collection-latexextra ])); + nativeBuildInputs = + [ + autoreconfHook + bison + flex + bison + texinfo + wrapQtAppsHook + cmake + pkg-config + ] + ++ lib.optional (finalAttrs.texContainer == null || finalAttrs.texdocContainer == null) ( + texliveSmall.withPackages ( + ps: with ps; [ + epsf + cm-super + ps.texinfo + media9 + ocgx2 + collection-latexextra + ] + ) + ); buildInputs = [ - ghostscriptX imagemagick fftw eigen - boehmgc ncurses readline gsl libsigsegv - zlib perl curl qtbase qtsvg boost - (python3.withPackages (ps: with ps; [ cson numpy pyqt5 ])) + ghostscriptX + imagemagick + fftw + eigen + boehmgc + ncurses + readline + gsl + libsigsegv + zlib + perl + curl + qtbase + qtsvg + boost + (python3.withPackages ( + ps: with ps; [ + cson + numpy + pyqt5 + ] + )) ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libtirpc ]; - propagatedBuildInputs = [ - glm - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libglut libGLU libGL - ] ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ - OpenGL GLUT Cocoa - ]); + propagatedBuildInputs = + [ + glm + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libglut + libGLU + libGL + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + OpenGL + GLUT + Cocoa + ] + ); dontWrapQtApps = true; @@ -75,7 +146,8 @@ stdenv.mkDerivation (finalAttrs: { ''; # do not use bundled libgc.so - configureFlags = [ "--enable-gc=system" ] + configureFlags = + [ "--enable-gc=system" ] # TODO add open_memstream to enable XDR/V3D on Darwin (requires memstream or >=10.13 Apple SDK) ++ lib.optional stdenv.hostPlatform.isDarwin "--enable-xdr=no"; @@ -126,7 +198,7 @@ stdenv.mkDerivation (finalAttrs: { enableParallelInstalling = false; meta = with lib; { - description = "Tool for programming graphics intended to replace Metapost"; + description = "Tool for programming graphics intended to replace Metapost"; license = licenses.gpl3Plus; maintainers = [ maintainers.raskin ]; platforms = platforms.linux ++ platforms.darwin; diff --git a/pkgs/tools/graphics/diagrams-builder/default.nix b/pkgs/tools/graphics/diagrams-builder/default.nix index d066657ff0eb2a..290059b1c114f5 100644 --- a/pkgs/tools/graphics/diagrams-builder/default.nix +++ b/pkgs/tools/graphics/diagrams-builder/default.nix @@ -10,23 +10,33 @@ ­~~~ */ -{ lib, stdenv, ghcWithPackages, makeWrapper, diagrams-builder, extraPackages ? (self: []) }: +{ + lib, + stdenv, + ghcWithPackages, + makeWrapper, + diagrams-builder, + extraPackages ? (self: [ ]), +}: let # Used same technique as for the yiCustom package. - wrappedGhc = ghcWithPackages - (self: [ diagrams-builder ] ++ extraPackages self); + wrappedGhc = ghcWithPackages (self: [ diagrams-builder ] ++ extraPackages self); ghc = lib.getExe' wrappedGhc "ghc"; - exeWrapper = backend : '' + exeWrapper = backend: '' makeWrapper \ "${diagrams-builder}/bin/diagrams-builder-${backend}" "$out/bin/diagrams-builder-${backend}" \ --set NIX_GHC ${ghc} \ --set NIX_GHC_LIBDIR "$(${ghc} --print-libdir)" ''; - backends = ["svg" "cairo" "ps"]; + backends = [ + "svg" + "cairo" + "ps" + ]; in diff --git a/pkgs/tools/graphics/dmtx-utils/default.nix b/pkgs/tools/graphics/dmtx-utils/default.nix index 4c5883d5680485..395089f14ee665 100644 --- a/pkgs/tools/graphics/dmtx-utils/default.nix +++ b/pkgs/tools/graphics/dmtx-utils/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libdmtx -, imagemagick -, Foundation +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libdmtx, + imagemagick, + Foundation, }: stdenv.mkDerivation rec { @@ -19,10 +20,15 @@ stdenv.mkDerivation rec { hash = "sha256-uXzPAv6DappyHBNmsTg6qRUvtUUdP1IPOdDvIcevfco="; }; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ libdmtx imagemagick ] - ++ lib.optional stdenv.hostPlatform.isDarwin Foundation; + buildInputs = [ + libdmtx + imagemagick + ] ++ lib.optional stdenv.hostPlatform.isDarwin Foundation; meta = { description = "Data matrix command-line utilities"; diff --git a/pkgs/tools/graphics/gnuplot/default.nix b/pkgs/tools/graphics/gnuplot/default.nix index 0646718f4c75ea..9d54bd86482009 100644 --- a/pkgs/tools/graphics/gnuplot/default.nix +++ b/pkgs/tools/graphics/gnuplot/default.nix @@ -1,18 +1,38 @@ -{ lib, stdenv, fetchurl, makeWrapper, pkg-config, texinfo -, cairo, gd, libcerf, pango, readline, zlib -, withTeXLive ? false, texliveSmall -, withLua ? false, lua -, withCaca ? false, libcaca -, libX11 ? null -, libXt ? null -, libXpm ? null -, libXaw ? null -, aquaterm ? false -, withWxGTK ? false, wxGTK32, Cocoa -, fontconfig ? null -, gnused ? null -, coreutils ? null -, withQt ? false, mkDerivation, qttools, qtbase, qtsvg +{ + lib, + stdenv, + fetchurl, + makeWrapper, + pkg-config, + texinfo, + cairo, + gd, + libcerf, + pango, + readline, + zlib, + withTeXLive ? false, + texliveSmall, + withLua ? false, + lua, + withCaca ? false, + libcaca, + libX11 ? null, + libXt ? null, + libXpm ? null, + libXaw ? null, + aquaterm ? false, + withWxGTK ? false, + wxGTK32, + Cocoa, + fontconfig ? null, + gnused ? null, + coreutils ? null, + withQt ? false, + mkDerivation, + qttools, + qtbase, + qtsvg, }: assert libX11 != null -> (fontconfig != null && gnused != null && coreutils != null); @@ -28,15 +48,34 @@ in sha256 = "sha256-6FpmDBoqGAj/JPfmmYH/y6xmpFydz3EbZWELJupxN5o="; }; - nativeBuildInputs = [ makeWrapper pkg-config texinfo ] ++ lib.optional withQt qttools; + nativeBuildInputs = [ + makeWrapper + pkg-config + texinfo + ] ++ lib.optional withQt qttools; buildInputs = - [ cairo gd libcerf pango readline zlib ] + [ + cairo + gd + libcerf + pango + readline + zlib + ] ++ lib.optional withTeXLive texliveSmall ++ lib.optional withLua lua ++ lib.optional withCaca libcaca - ++ lib.optionals withX [ libX11 libXpm libXt libXaw ] - ++ lib.optionals withQt [ qtbase qtsvg ] + ++ lib.optionals withX [ + libX11 + libXpm + libXt + libXaw + ] + ++ lib.optionals withQt [ + qtbase + qtsvg + ] ++ lib.optional withWxGTK wxGTK32 ++ lib.optional (withWxGTK && stdenv.hostPlatform.isDarwin) Cocoa; @@ -45,11 +84,13 @@ in sed -i configure -e 's|''${QT5LOC}/lrelease|lrelease|' ''; - configureFlags = [ - (if withX then "--with-x" else "--without-x") - (if withQt then "--with-qt=qt5" else "--without-qt") - (if aquaterm then "--with-aquaterm" else "--without-aquaterm") - ] ++ lib.optional withCaca "--with-caca" + configureFlags = + [ + (if withX then "--with-x" else "--without-x") + (if withQt then "--with-qt=qt5" else "--without-qt") + (if aquaterm then "--with-aquaterm" else "--without-aquaterm") + ] + ++ lib.optional withCaca "--with-caca" ++ lib.optional withTeXLive "--with-texdir=${placeholder "out"}/share/texmf/tex/latex/gnuplot"; CXXFLAGS = lib.optionalString (stdenv.hostPlatform.isDarwin && withQt) "-std=c++11"; @@ -61,7 +102,13 @@ in # binary wrappers don't support --run postInstall = lib.optionalString withX '' wrapProgramShell $out/bin/gnuplot \ - --prefix PATH : '${lib.makeBinPath [ gnused coreutils fontconfig.bin ]}' \ + --prefix PATH : '${ + lib.makeBinPath [ + gnused + coreutils + fontconfig.bin + ] + }' \ "''${gappsWrapperArgs[@]}" \ "''${qtWrapperArgs[@]}" \ --run '. ${./set-gdfontpath-from-fontconfig.sh}' diff --git a/pkgs/tools/graphics/goverlay/default.nix b/pkgs/tools/graphics/goverlay/default.nix index 3f935568744f54..4b348cc319830c 100644 --- a/pkgs/tools/graphics/goverlay/default.nix +++ b/pkgs/tools/graphics/goverlay/default.nix @@ -1,27 +1,28 @@ -{ lib -, writeScriptBin -, bash -, stdenv -, fetchFromGitHub -, fpc -, lazarus-qt -, wrapQtAppsHook -, breeze-qt5 -, libGL -, libGLU -, libqt5pas -, libX11 -, coreutils -, git -, gnugrep -, libnotify -, polkit -, procps -, systemd -, util-linux -, vulkan-tools -, which -, nix-update-script +{ + lib, + writeScriptBin, + bash, + stdenv, + fetchFromGitHub, + fpc, + lazarus-qt, + wrapQtAppsHook, + breeze-qt5, + libGL, + libGLU, + libqt5pas, + libX11, + coreutils, + git, + gnugrep, + libnotify, + polkit, + procps, + systemd, + util-linux, + vulkan-tools, + which, + nix-update-script, }: let @@ -36,7 +37,8 @@ let fi done ''; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "goverlay"; version = "0.7.1"; @@ -47,7 +49,10 @@ in stdenv.mkDerivation rec { sha256 = "sha256-oXkGrMHjs8uui0pzGYW8jnttet/5IX0r8eat0n5saFk="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; patches = [ # Find MangoHud & vkBasalt Vulkan layers using the XDG Base Directory Specification @@ -85,20 +90,22 @@ in stdenv.mkDerivation rec { ''; qtWrapperArgs = [ - "--prefix PATH : ${lib.makeBinPath [ - bash - coreutils - find-xdg-data-files - git - gnugrep - libnotify - polkit - procps - systemd - util-linux.bin - vulkan-tools - which - ]}" + "--prefix PATH : ${ + lib.makeBinPath [ + bash + coreutils + find-xdg-data-files + git + gnugrep + libnotify + polkit + procps + systemd + util-linux.bin + vulkan-tools + which + ] + }" # Force xcb since libqt5pas doesn't support Wayland # See https://github.com/benjamimgois/goverlay/issues/107 diff --git a/pkgs/tools/graphics/hobbits/default.nix b/pkgs/tools/graphics/hobbits/default.nix index 10d0713852bf21..6a429f9e706566 100644 --- a/pkgs/tools/graphics/hobbits/default.nix +++ b/pkgs/tools/graphics/hobbits/default.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, mkDerivation, fetchFromGitHub -, cmake, pkg-config, pffft, libpcap, libusb1, python3, wrapQtAppsHook +{ + lib, + stdenv, + mkDerivation, + fetchFromGitHub, + cmake, + pkg-config, + pffft, + libpcap, + libusb1, + python3, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -20,9 +30,18 @@ stdenv.mkDerivation rec { --replace "[Mystery Build]" "${version}" ''; - buildInputs = [ pffft libpcap libusb1 python3 ]; - - nativeBuildInputs = [ cmake pkg-config wrapQtAppsHook ]; + buildInputs = [ + pffft + libpcap + libusb1 + python3 + ]; + + nativeBuildInputs = [ + cmake + pkg-config + wrapQtAppsHook + ]; cmakeFlags = [ "-DUSE_SYSTEM_PFFFT=ON" ]; diff --git a/pkgs/tools/graphics/maskromtool/default.nix b/pkgs/tools/graphics/maskromtool/default.nix index 0d9395886f0c1b..94fbfdb61fe095 100644 --- a/pkgs/tools/graphics/maskromtool/default.nix +++ b/pkgs/tools/graphics/maskromtool/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qtbase -, qt6 -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtbase, + qt6, + wrapQtAppsHook, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/graphics/nifskope/default.nix b/pkgs/tools/graphics/nifskope/default.nix index 4022c363ef64bf..399d41ab1894db 100644 --- a/pkgs/tools/graphics/nifskope/default.nix +++ b/pkgs/tools/graphics/nifskope/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, qmake, qtbase, qttools, substituteAll, libGLU, wrapQtAppsHook, fetchpatch }: +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + qtbase, + qttools, + substituteAll, + libGLU, + wrapQtAppsHook, + fetchpatch, +}: stdenv.mkDerivation { pname = "nifskope"; @@ -25,8 +36,15 @@ stdenv.mkDerivation { }) ] ++ (lib.optional stdenv.hostPlatform.isAarch64 ./no-sse-on-arm.patch); - buildInputs = [ qtbase qttools libGLU ]; - nativeBuildInputs = [ qmake wrapQtAppsHook ]; + buildInputs = [ + qtbase + qttools + libGLU + ]; + nativeBuildInputs = [ + qmake + wrapQtAppsHook + ]; preConfigure = '' shopt -s globstar diff --git a/pkgs/tools/graphics/pfstools/default.nix b/pkgs/tools/graphics/pfstools/default.nix index b164799e9cc292..cca813af3c2204 100644 --- a/pkgs/tools/graphics/pfstools/default.nix +++ b/pkgs/tools/graphics/pfstools/default.nix @@ -1,7 +1,26 @@ -{ lib, stdenv, mkDerivation, fetchurl, cmake, pkg-config, darwin -, openexr, zlib, imagemagick6, libGLU, libGL, libglut, fftwFloat -, fftw, gsl, libexif, perl, qtbase, netpbm -, enableUnfree ? false, opencv +{ + lib, + stdenv, + mkDerivation, + fetchurl, + cmake, + pkg-config, + darwin, + openexr, + zlib, + imagemagick6, + libGLU, + libGL, + libglut, + fftwFloat, + fftw, + gsl, + libexif, + perl, + qtbase, + netpbm, + enableUnfree ? false, + opencv, }: mkDerivation rec { @@ -13,7 +32,11 @@ mkDerivation rec { sha256 = "sha256-m/aESYVmMibCGZjutDwmGsuOSziRuakbcpVUQGKJ18o="; }; - outputs = [ "out" "dev" "man"]; + outputs = [ + "out" + "dev" + "man" + ]; cmakeFlags = [ "-DWITH_MATLAB=false" ]; @@ -28,17 +51,44 @@ mkDerivation rec { echo "FIND_PACKAGE_HANDLE_STANDARD_ARGS(NETPBM DEFAULT_MSG NETPBM_LIBRARY NETPBM_INCLUDE_DIR)" >> cmake/FindNETPBM.cmake ''; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ - openexr zlib imagemagick6 fftwFloat - fftw gsl libexif perl qtbase netpbm - ] ++ (if stdenv.hostPlatform.isDarwin then (with darwin.apple_sdk.frameworks; [ - OpenGL GLUT - ]) else [ - libGLU libGL libglut - ]) ++ lib.optional enableUnfree (opencv.override { enableUnfree = true; }); - - patches = [ ./glut.patch ./threads.patch ./pfstools.patch ./pfsalign.patch ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = + [ + openexr + zlib + imagemagick6 + fftwFloat + fftw + gsl + libexif + perl + qtbase + netpbm + ] + ++ ( + if stdenv.hostPlatform.isDarwin then + (with darwin.apple_sdk.frameworks; [ + OpenGL + GLUT + ]) + else + [ + libGLU + libGL + libglut + ] + ) + ++ lib.optional enableUnfree (opencv.override { enableUnfree = true; }); + + patches = [ + ./glut.patch + ./threads.patch + ./pfstools.patch + ./pfsalign.patch + ]; meta = with lib; { homepage = "https://pfstools.sourceforge.net/"; diff --git a/pkgs/tools/graphics/pixel2svg/default.nix b/pkgs/tools/graphics/pixel2svg/default.nix index 1094cad56a331d..1135804cde7040 100644 --- a/pkgs/tools/graphics/pixel2svg/default.nix +++ b/pkgs/tools/graphics/pixel2svg/default.nix @@ -1,4 +1,9 @@ -{ lib, buildPythonPackage, fetchurl, python310Packages }: +{ + lib, + buildPythonPackage, + fetchurl, + python310Packages, +}: python310Packages.buildPythonPackage rec { pname = "pixel2svg"; @@ -9,7 +14,10 @@ python310Packages.buildPythonPackage rec { sha256 = "sha256-aqcTTmZKcdRdVd8GGz5cuaQ4gjPapVJNtiiZu22TZgQ="; }; - propagatedBuildInputs = with python310Packages; [ pillow svgwrite ]; + propagatedBuildInputs = with python310Packages; [ + pillow + svgwrite + ]; meta = with lib; { homepage = "https://florian-berger.de/en/software/pixel2svg/"; diff --git a/pkgs/tools/graphics/povray/default.nix b/pkgs/tools/graphics/povray/default.nix index 2f3a644898ae3d..1309f506c55646 100644 --- a/pkgs/tools/graphics/povray/default.nix +++ b/pkgs/tools/graphics/povray/default.nix @@ -1,18 +1,19 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf -, automake -, boost -, zlib -, libX11 -, libICE -, libSM -, libpng -, libjpeg -, libtiff -, pkg-config -, SDL2 +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + boost, + zlib, + libX11, + libICE, + libSM, + libpng, + libjpeg, + libtiff, + pkg-config, + SDL2, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/tools/graphics/rocket/default.nix b/pkgs/tools/graphics/rocket/default.nix index 28f0efae7e9a3c..438737633ef0fd 100644 --- a/pkgs/tools/graphics/rocket/default.nix +++ b/pkgs/tools/graphics/rocket/default.nix @@ -1,4 +1,10 @@ -{ mkDerivation, lib, fetchFromGitHub, qmake, qtbase }: +{ + mkDerivation, + lib, + fetchFromGitHub, + qmake, + qtbase, +}: mkDerivation { pname = "rocket"; diff --git a/pkgs/tools/graphics/twilight/default.nix b/pkgs/tools/graphics/twilight/default.nix index bd900d455d6d33..8597b97d34d0cc 100644 --- a/pkgs/tools/graphics/twilight/default.nix +++ b/pkgs/tools/graphics/twilight/default.nix @@ -1,5 +1,12 @@ -{ lib, stdenv, fetchFromGitHub -, libGL, libGLU, libglut, libX11 }: +{ + lib, + stdenv, + fetchFromGitHub, + libGL, + libGLU, + libglut, + libX11, +}: stdenv.mkDerivation rec { pname = "twilight"; @@ -12,7 +19,12 @@ stdenv.mkDerivation rec { sha256 = "0mmmi4jj8yd8wnah6kx5na782sjycszgzim33dfalr0ph361m4pz"; }; - buildInputs = [ libGL libGLU libglut libX11 ]; + buildInputs = [ + libGL + libGLU + libglut + libX11 + ]; installPhase = '' install -Dm755 twilight $out/bin/twilight diff --git a/pkgs/tools/graphics/vkbasalt/default.nix b/pkgs/tools/graphics/vkbasalt/default.nix index 261cc13bbbf3eb..d8aaece387ad16 100644 --- a/pkgs/tools/graphics/vkbasalt/default.nix +++ b/pkgs/tools/graphics/vkbasalt/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, glslang -, meson -, ninja -, pkg-config -, libX11 -, spirv-headers -, vulkan-headers -, vkbasalt32 +{ + lib, + stdenv, + fetchFromGitHub, + glslang, + meson, + ninja, + pkg-config, + libX11, + spirv-headers, + vulkan-headers, + vkbasalt32, }: stdenv.mkDerivation (finalAttrs: { @@ -22,8 +23,17 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-GC6JKYnsfcUBg+CX6v7MyE4FeLmjadFwighaiyureDg="; }; - nativeBuildInputs = [ glslang meson ninja pkg-config ]; - buildInputs = [ libX11 spirv-headers vulkan-headers ]; + nativeBuildInputs = [ + glslang + meson + ninja + pkg-config + ]; + buildInputs = [ + libX11 + spirv-headers + vulkan-headers + ]; mesonFlags = [ "-Dappend_libdir_vkbasalt=true" ]; postInstall = lib.optionalString (stdenv.hostPlatform.system == "x86_64-linux") '' diff --git a/pkgs/tools/graphics/vulkan-caps-viewer/default.nix b/pkgs/tools/graphics/vulkan-caps-viewer/default.nix index 7519d1f0109e09..649071755e9847 100644 --- a/pkgs/tools/graphics/vulkan-caps-viewer/default.nix +++ b/pkgs/tools/graphics/vulkan-caps-viewer/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, qmake -, vulkan-loader -, wayland -, wrapQtAppsHook -, x11Support ? true -, qtx11extras +{ + lib, + stdenv, + fetchFromGitHub, + qmake, + vulkan-loader, + wayland, + wrapQtAppsHook, + x11Support ? true, + qtx11extras, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/graphics/vulkan-cts/default.nix b/pkgs/tools/graphics/vulkan-cts/default.nix index 7907b9cc67edb5..3312042202be88 100644 --- a/pkgs/tools/graphics/vulkan-cts/default.nix +++ b/pkgs/tools/graphics/vulkan-cts/default.nix @@ -1,31 +1,33 @@ -{ lib, stdenv -, fetchFromGitHub -, fetchurl -, runCommand -, cmake -, ffmpeg -, glslang -, libdrm -, libglvnd -, libffi -, libpng -, libX11 -, libXau -, libXdmcp -, libxcb -, makeWrapper -, mesa -, ninja -, pkg-config -, python3 -, spirv-headers -, vulkan-headers -, vulkan-loader -, vulkan-utility-libraries -, wayland -, wayland-protocols -, wayland-scanner -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + fetchurl, + runCommand, + cmake, + ffmpeg, + glslang, + libdrm, + libglvnd, + libffi, + libpng, + libX11, + libXau, + libXdmcp, + libxcb, + makeWrapper, + mesa, + ninja, + pkg-config, + python3, + spirv-headers, + vulkan-headers, + vulkan-loader, + vulkan-utility-libraries, + wayland, + wayland-protocols, + wayland-scanner, + zlib, }: let renderdoc = fetchurl { @@ -122,12 +124,18 @@ stdenv.mkDerivation (finalAttrs: { ''; passthru.updateScript = ./update.sh; - passthru.tests.lavapipe = runCommand "vulkan-cts-tests-lavapipe" { - nativeBuildInputs = [ finalAttrs.finalPackage mesa.llvmpipeHook ]; - } '' - deqp-vk -n dEQP-VK.api.smoke.triangle - touch $out - ''; + passthru.tests.lavapipe = + runCommand "vulkan-cts-tests-lavapipe" + { + nativeBuildInputs = [ + finalAttrs.finalPackage + mesa.llvmpipeHook + ]; + } + '' + deqp-vk -n dEQP-VK.api.smoke.triangle + touch $out + ''; meta = with lib; { description = "Khronos Vulkan Conformance Tests"; diff --git a/pkgs/tools/graphics/vulkan-cts/sources.nix b/pkgs/tools/graphics/vulkan-cts/sources.nix index 3b61e97768656d..e220164a50395c 100644 --- a/pkgs/tools/graphics/vulkan-cts/sources.nix +++ b/pkgs/tools/graphics/vulkan-cts/sources.nix @@ -57,7 +57,6 @@ rec { hash = "sha256-qVQy3kKkZRWHjtj2YxJTZqKg1kwnmLa3bgVathisfOc="; }; - prePatch = '' mkdir -p external/amber external/glslang external/jsoncpp external/nvidia-video-samples external/spirv-headers external/spirv-tools external/vulkan-docs external/vulkan-validationlayers diff --git a/pkgs/tools/graphics/vulkan-tools/default.nix b/pkgs/tools/graphics/vulkan-tools/default.nix index 2779e5c6231c4d..435671c1915dec 100644 --- a/pkgs/tools/graphics/vulkan-tools/default.nix +++ b/pkgs/tools/graphics/vulkan-tools/default.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildPackages -, cmake -, pkg-config -, python3 -, glslang -, libffi -, libX11 -, libXau -, libxcb -, libXdmcp -, libXrandr -, vulkan-headers -, vulkan-loader -, vulkan-volk -, wayland -, wayland-protocols -, wayland-scanner -, moltenvk -, AppKit -, Cocoa +{ + lib, + stdenv, + fetchFromGitHub, + buildPackages, + cmake, + pkg-config, + python3, + glslang, + libffi, + libX11, + libXau, + libxcb, + libXdmcp, + libXrandr, + vulkan-headers, + vulkan-loader, + vulkan-volk, + wayland, + wayland-protocols, + wayland-scanner, + moltenvk, + AppKit, + Cocoa, }: stdenv.mkDerivation rec { @@ -40,27 +41,30 @@ stdenv.mkDerivation rec { python3 ]; - buildInputs = [ - glslang - vulkan-headers - vulkan-loader - vulkan-volk - ] ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ - libffi - libX11 - libXau - libxcb - libXdmcp - libXrandr - wayland - wayland-protocols - wayland-scanner - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - moltenvk - moltenvk.dev - AppKit - Cocoa - ]; + buildInputs = + [ + glslang + vulkan-headers + vulkan-loader + vulkan-volk + ] + ++ lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libffi + libX11 + libXau + libxcb + libXdmcp + libXrandr + wayland + wayland-protocols + wayland-scanner + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + moltenvk + moltenvk.dev + AppKit + Cocoa + ]; libraryPath = lib.strings.makeLibraryPath [ vulkan-loader ]; @@ -68,19 +72,21 @@ stdenv.mkDerivation rec { env.PKG_CONFIG_WAYLAND_SCANNER_WAYLAND_SCANNER = lib.getExe buildPackages.wayland-scanner; - cmakeFlags = [ - # Don't build the mock ICD as it may get used instead of other drivers, if installed - "-DBUILD_ICD=OFF" - # vulkaninfo loads libvulkan using dlopen, so we have to add it manually to RPATH - "-DCMAKE_INSTALL_RPATH=${libraryPath}" - "-DGLSLANG_INSTALL_DIR=${glslang}" - # Hide dev warnings that are useless for packaging - "-Wno-dev" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "-DMOLTENVK_REPO_ROOT=${moltenvk}/share/vulkan/icd.d" - # Don’t build the cube demo because it requires `ibtool`, which is not available in nixpkgs. - "-DBUILD_CUBE=OFF" - ]; + cmakeFlags = + [ + # Don't build the mock ICD as it may get used instead of other drivers, if installed + "-DBUILD_ICD=OFF" + # vulkaninfo loads libvulkan using dlopen, so we have to add it manually to RPATH + "-DCMAKE_INSTALL_RPATH=${libraryPath}" + "-DGLSLANG_INSTALL_DIR=${glslang}" + # Hide dev warnings that are useless for packaging + "-Wno-dev" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "-DMOLTENVK_REPO_ROOT=${moltenvk}/share/vulkan/icd.d" + # Don’t build the cube demo because it requires `ibtool`, which is not available in nixpkgs. + "-DBUILD_CUBE=OFF" + ]; meta = with lib; { description = "Khronos official Vulkan Tools and Utilities"; @@ -89,9 +95,9 @@ stdenv.mkDerivation rec { development by enabling developers to verify their applications correct use of the Vulkan API. ''; - homepage = "https://github.com/KhronosGroup/Vulkan-Tools"; - platforms = platforms.unix; - license = licenses.asl20; + homepage = "https://github.com/KhronosGroup/Vulkan-Tools"; + platforms = platforms.unix; + license = licenses.asl20; maintainers = [ maintainers.ralith ]; }; } diff --git a/pkgs/tools/graphics/waifu2x-converter-cpp/default.nix b/pkgs/tools/graphics/waifu2x-converter-cpp/default.nix index cf150a59c8dbc3..1464e0b0beb243 100644 --- a/pkgs/tools/graphics/waifu2x-converter-cpp/default.nix +++ b/pkgs/tools/graphics/waifu2x-converter-cpp/default.nix @@ -1,6 +1,16 @@ -{ cmake, fetchFromGitHub, makeWrapper, opencv4, lib, stdenv, ocl-icd, opencl-headers, OpenCL -, config -, cudaSupport ? config.cudaSupport, cudatoolkit ? null +{ + cmake, + fetchFromGitHub, + makeWrapper, + opencv4, + lib, + stdenv, + ocl-icd, + opencl-headers, + OpenCL, + config, + cudaSupport ? config.cudaSupport, + cudatoolkit ? null, }: stdenv.mkDerivation rec { @@ -19,13 +29,21 @@ stdenv.mkDerivation rec { ./waifu2x_darwin_build.diff ]; - buildInputs = [ - opencv4 - ] ++ lib.optional cudaSupport cudatoolkit + buildInputs = + [ + opencv4 + ] + ++ lib.optional cudaSupport cudatoolkit ++ lib.optional stdenv.hostPlatform.isDarwin OpenCL - ++ lib.optionals stdenv.hostPlatform.isLinux [ ocl-icd opencl-headers ]; + ++ lib.optionals stdenv.hostPlatform.isLinux [ + ocl-icd + opencl-headers + ]; - nativeBuildInputs = [ cmake makeWrapper ]; + nativeBuildInputs = [ + cmake + makeWrapper + ]; preFixup = lib.optionalString stdenv.hostPlatform.isLinux '' wrapProgram $out/bin/waifu2x-converter-cpp --prefix LD_LIBRARY_PATH : "${ocl-icd}/lib" diff --git a/pkgs/tools/graphics/zbar/default.nix b/pkgs/tools/graphics/zbar/default.nix index 951e6b26bf115c..93d3b480248aa2 100644 --- a/pkgs/tools/graphics/zbar/default.nix +++ b/pkgs/tools/graphics/zbar/default.nix @@ -1,40 +1,47 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, imagemagickBig -, pkg-config -, withXorg ? true -, libX11 -, libv4l -, qtbase -, qtx11extras -, wrapQtAppsHook -, wrapGAppsHook3 -, gtk3 -, xmlto -, docbook_xsl -, autoreconfHook -, dbus -, enableVideo ? stdenv.hostPlatform.isLinux +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + imagemagickBig, + pkg-config, + withXorg ? true, + libX11, + libv4l, + qtbase, + qtx11extras, + wrapQtAppsHook, + wrapGAppsHook3, + gtk3, + xmlto, + docbook_xsl, + autoreconfHook, + dbus, + enableVideo ? stdenv.hostPlatform.isLinux, # The implementation is buggy and produces an error like # Name Error (Connection ":1.4380" is not allowed to own the service "org.linuxtv.Zbar" due to security policies in the configuration file) # for every scanned code. # see https://github.com/mchehab/zbar/issues/104 -, enableDbus ? false -, libintl -, libiconv -, Foundation -, bash -, python3 -, argp-standalone + enableDbus ? false, + libintl, + libiconv, + Foundation, + bash, + python3, + argp-standalone, }: stdenv.mkDerivation rec { pname = "zbar"; version = "0.23.92"; - outputs = [ "out" "lib" "dev" "doc" "man" ]; + outputs = [ + "out" + "lib" + "dev" + "doc" + "man" + ]; src = fetchFromGitHub { owner = "mchehab"; @@ -56,33 +63,40 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ - pkg-config - xmlto - autoreconfHook - docbook_xsl - ] ++ lib.optionals enableVideo [ - wrapGAppsHook3 - wrapQtAppsHook - qtbase - ]; - - buildInputs = [ - imagemagickBig - libintl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - Foundation - ] ++ lib.optionals enableDbus [ - dbus - ] ++ lib.optionals withXorg [ - libX11 - ] ++ lib.optionals enableVideo [ - libv4l - gtk3 - qtbase - qtx11extras - ]; + nativeBuildInputs = + [ + pkg-config + xmlto + autoreconfHook + docbook_xsl + ] + ++ lib.optionals enableVideo [ + wrapGAppsHook3 + wrapQtAppsHook + qtbase + ]; + + buildInputs = + [ + imagemagickBig + libintl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Foundation + ] + ++ lib.optionals enableDbus [ + dbus + ] + ++ lib.optionals withXorg [ + libX11 + ] + ++ lib.optionals enableVideo [ + libv4l + gtk3 + qtbase + qtx11extras + ]; nativeCheckInputs = [ bash @@ -103,19 +117,32 @@ stdenv.mkDerivation rec { # Disable assertions which include -dev QtBase file paths. env.NIX_CFLAGS_COMPILE = "-DQT_NO_DEBUG"; - configureFlags = [ - "--without-python" - ] ++ (if enableDbus then [ - "--with-dbusconfdir=${placeholder "out"}/share" - ] else [ - "--without-dbus" - ]) ++ (if enableVideo then [ - "--with-gtk=gtk3" - ] else [ - "--disable-video" - "--without-gtk" - "--without-qt" - ]); + configureFlags = + [ + "--without-python" + ] + ++ ( + if enableDbus then + [ + "--with-dbusconfdir=${placeholder "out"}/share" + ] + else + [ + "--without-dbus" + ] + ) + ++ ( + if enableVideo then + [ + "--with-gtk=gtk3" + ] + else + [ + "--disable-video" + "--without-gtk" + "--without-qt" + ] + ); doCheck = true; diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-anthy.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-anthy.nix index ea9a20944110da..a9c3d561561c54 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-anthy.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-anthy.nix @@ -1,5 +1,15 @@ -{ lib, stdenv, fetchurl, cmake, extra-cmake-modules, pkg-config, fcitx5, anthy -, gettext, zstd }: +{ + lib, + stdenv, + fetchurl, + cmake, + extra-cmake-modules, + pkg-config, + fcitx5, + anthy, + gettext, + zstd, +}: stdenv.mkDerivation rec { pname = "fcitx5-anthy"; @@ -10,8 +20,17 @@ stdenv.mkDerivation rec { hash = "sha256-heSO2eArdSnOmIg7JG8vOo5y3g5dSPOuXkUfeNqKzSA="; }; - nativeBuildInputs = [ cmake extra-cmake-modules pkg-config zstd ]; - buildInputs = [ fcitx5 anthy gettext ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + pkg-config + zstd + ]; + buildInputs = [ + fcitx5 + anthy + gettext + ]; meta = with lib; { description = "Anthy Wrapper for Fcitx5"; diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-bamboo.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-bamboo.nix index b6a9253148c487..31cda50d502c4b 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-bamboo.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-bamboo.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, fcitx5 -, gettext -, go +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + fcitx5, + gettext, + go, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-chewing.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-chewing.nix index 550efad6264ed9..33b4571da34dbd 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-chewing.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-chewing.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, gettext -, fcitx5 -, libchewing +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + gettext, + fcitx5, + libchewing, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-chinese-addons.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-chinese-addons.nix index a9f5cf31161393..bc8da47b5e37f2 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-chinese-addons.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-chinese-addons.nix @@ -1,20 +1,21 @@ -{ lib -, stdenv -, fetchurl -, fetchFromGitHub -, cmake -, extra-cmake-modules -, boost -, libime -, fcitx5 -, fcitx5-qt -, fcitx5-lua -, qtwebengine -, opencc -, curl -, fmt -, qtbase -, luaSupport ? true +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + cmake, + extra-cmake-modules, + boost, + libime, + fcitx5, + fcitx5-qt, + fcitx5-lua, + qtwebengine, + opencc, + curl, + fmt, + qtbase, + luaSupport ? true, }: let @@ -73,7 +74,10 @@ stdenv.mkDerivation rec { description = "Addons related to Chinese, including IME previous bundled inside fcitx4"; mainProgram = "scel2org5"; homepage = "https://github.com/fcitx/fcitx5-chinese-addons"; - license = with licenses; [ gpl2Plus lgpl21Plus ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + ]; maintainers = with maintainers; [ poscat ]; platforms = platforms.linux; }; diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-configtool.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-configtool.nix index a34a2e418f0087..618eb1587fda61 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-configtool.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-configtool.nix @@ -1,30 +1,31 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, pkg-config -, fcitx5 -, fcitx5-qt -, qtbase -, qtsvg -, qtwayland -, qtdeclarative -, qtx11extras ? null -, kitemviews -, kwidgetsaddons -, qtquickcontrols2 ? null -, kcoreaddons -, kdeclarative -, kirigami ? null -, kirigami2 ? null -, isocodes -, xkeyboardconfig -, libxkbfile -, libplasma ? null -, plasma-framework ? null -, wrapQtAppsHook -, kcmSupport ? true +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + pkg-config, + fcitx5, + fcitx5-qt, + qtbase, + qtsvg, + qtwayland, + qtdeclarative, + qtx11extras ? null, + kitemviews, + kwidgetsaddons, + qtquickcontrols2 ? null, + kcoreaddons, + kdeclarative, + kirigami ? null, + kirigami2 ? null, + isocodes, + xkeyboardconfig, + libxkbfile, + libplasma ? null, + plasma-framework ? null, + wrapQtAppsHook, + kcmSupport ? true, }: stdenv.mkDerivation rec { @@ -51,31 +52,38 @@ stdenv.mkDerivation rec { wrapQtAppsHook ]; - buildInputs = [ - fcitx5 - fcitx5-qt - qtbase - qtsvg - qtwayland - kitemviews - kwidgetsaddons - isocodes - xkeyboardconfig - libxkbfile - ] ++ lib.optionals (lib.versions.major qtbase.version == "5") [ - qtx11extras - ] ++ lib.optionals kcmSupport ([ - qtdeclarative - kcoreaddons - kdeclarative - ] ++ lib.optionals (lib.versions.major qtbase.version == "5") [ - qtquickcontrols2 - plasma-framework - kirigami2 - ] ++ lib.optionals (lib.versions.major qtbase.version == "6") [ - libplasma - kirigami - ]); + buildInputs = + [ + fcitx5 + fcitx5-qt + qtbase + qtsvg + qtwayland + kitemviews + kwidgetsaddons + isocodes + xkeyboardconfig + libxkbfile + ] + ++ lib.optionals (lib.versions.major qtbase.version == "5") [ + qtx11extras + ] + ++ lib.optionals kcmSupport ( + [ + qtdeclarative + kcoreaddons + kdeclarative + ] + ++ lib.optionals (lib.versions.major qtbase.version == "5") [ + qtquickcontrols2 + plasma-framework + kirigami2 + ] + ++ lib.optionals (lib.versions.major qtbase.version == "6") [ + libplasma + kirigami + ] + ); meta = with lib; { description = "Configuration Tool for Fcitx5"; diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-gtk.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-gtk.nix index 0e23f7e5729f4f..d59449b7d6a146 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-gtk.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-gtk.nix @@ -1,27 +1,29 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, fcitx5 -, gobject-introspection -, glib -, gtk2 -, gtk3 -, gtk4 -, fmt -, pcre -, libuuid -, libselinux -, libsepol -, libthai -, libdatrie -, libXdmcp -, libxkbcommon -, libepoxy -, dbus -, at-spi2-core -, libXtst -, withGTK2 ? false +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + fcitx5, + gobject-introspection, + glib, + gtk2, + gtk3, + gtk4, + fmt, + pcre, + libuuid, + libselinux, + libsepol, + libthai, + libdatrie, + libXdmcp, + libxkbcommon, + libepoxy, + dbus, + at-spi2-core, + libXtst, + withGTK2 ? false, }: stdenv.mkDerivation rec { @@ -35,12 +37,15 @@ stdenv.mkDerivation rec { hash = "sha256-qckaD2VDlXyaXe52PTjYfKIJbsIBRgD5s3b9Oc6l/64="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; cmakeFlags = [ "-DGOBJECT_INTROSPECTION_GIRDIR=share/gir-1.0" "-DGOBJECT_INTROSPECTION_TYPELIBDIR=lib/girepository-1.0" - ] ++ lib.optional (! withGTK2) "-DENABLE_GTK2_IM_MODULE=off"; + ] ++ lib.optional (!withGTK2) "-DENABLE_GTK2_IM_MODULE=off"; buildInputs = [ glib diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-hangul.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-hangul.nix index b2511be8de1dfc..86271423a84167 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-hangul.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-hangul.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, gettext -, fcitx5 -, libhangul -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + gettext, + fcitx5, + libhangul, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-lua.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-lua.nix index 870239b54d9987..3f4eeb16855a2e 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-lua.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-lua.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, fcitx5 -, lua -, gettext +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + fcitx5, + lua, + gettext, }: stdenv.mkDerivation rec { pname = "fcitx5-lua"; @@ -18,9 +19,16 @@ stdenv.mkDerivation rec { hash = "sha256-XRfYQquR9SVlYr2sX6ii8JjMyjJZWSMf1u2oKUmOhf8="; }; - nativeBuildInputs = [ cmake extra-cmake-modules ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; - buildInputs = [ fcitx5 lua gettext ]; + buildInputs = [ + fcitx5 + lua + gettext + ]; passthru = { extraLdLibraries = [ lua ]; diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-m17n.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-m17n.nix index ff3c2124a8d645..8d6640b3254ae8 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-m17n.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-m17n.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, pkg-config -, fcitx5 -, m17n_lib -, m17n_db -, gettext -, fmt -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + pkg-config, + fcitx5, + m17n_lib, + m17n_db, + gettext, + fmt, + nixosTests, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-qt.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-qt.nix index e0a6672f68ef76..0028eb5fc4e62d 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-qt.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-qt.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, fcitx5 -, qtbase -, qtwayland -, wrapQtAppsHook -, wayland +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + fcitx5, + qtbase, + qtwayland, + wrapQtAppsHook, + wayland, }: let majorVersion = lib.versions.major qtbase.version; @@ -51,7 +52,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Fcitx5 Qt Library"; homepage = "https://github.com/fcitx/fcitx5-qt"; - license = with licenses; [ lgpl21Plus bsd3 ]; + license = with licenses; [ + lgpl21Plus + bsd3 + ]; maintainers = with maintainers; [ poscat ]; platforms = platforms.linux; }; diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-rime.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-rime.nix index ae6a36658fd280..1ef0ac41f32134 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-rime.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-rime.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, cmake -, extra-cmake-modules -, gettext -, zstd -, fcitx5 -, librime -, rime-data -, symlinkJoin -, rimeDataPkgs ? [ rime-data ] +{ + lib, + stdenv, + fetchurl, + pkg-config, + cmake, + extra-cmake-modules, + gettext, + zstd, + fcitx5, + librime, + rime-data, + symlinkJoin, + rimeDataPkgs ? [ rime-data ], }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-skk.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-skk.nix index 7f57597052554e..34bfa097dca2b6 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-skk.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-skk.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, cmake -, extra-cmake-modules -, gettext -, fcitx5 -, fcitx5-qt -, libskk -, qtbase -, skkDictionaries -, enableQt ? false +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + cmake, + extra-cmake-modules, + gettext, + fcitx5, + fcitx5-qt, + libskk, + qtbase, + skkDictionaries, + enableQt ? false, }: stdenv.mkDerivation rec { @@ -31,13 +32,15 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - fcitx5 - libskk - ] ++ lib.optionals enableQt [ - fcitx5-qt - qtbase - ]; + buildInputs = + [ + fcitx5 + libskk + ] + ++ lib.optionals enableQt [ + fcitx5-qt + qtbase + ]; cmakeFlags = [ (lib.cmakeBool "ENABLE_QT" enableQt) diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-table-extra.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-table-extra.nix index d86c55c8365294..46732114714544 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-table-extra.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-table-extra.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, gettext -, libime -, boost -, fcitx5 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + gettext, + libime, + boost, + fcitx5, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-table-other.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-table-other.nix index d06fa2823effbd..5dc95a6186d5ac 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-table-other.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-table-other.nix @@ -1,11 +1,13 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, gettext -, libime -, boost -, fcitx5 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + gettext, + libime, + boost, + fcitx5, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/inputmethods/fcitx5/fcitx5-unikey.nix b/pkgs/tools/inputmethods/fcitx5/fcitx5-unikey.nix index 23b19f21a05a36..d0d4f515fafe4f 100644 --- a/pkgs/tools/inputmethods/fcitx5/fcitx5-unikey.nix +++ b/pkgs/tools/inputmethods/fcitx5/fcitx5-unikey.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, extra-cmake-modules -, fcitx5 -, fcitx5-qt -, gettext -, qtbase +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + extra-cmake-modules, + fcitx5, + fcitx5-qt, + gettext, + qtbase, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/inputmethods/fcitx5/with-addons.nix b/pkgs/tools/inputmethods/fcitx5/with-addons.nix index 58175eedade8b1..f6480fe1914129 100644 --- a/pkgs/tools/inputmethods/fcitx5/with-addons.nix +++ b/pkgs/tools/inputmethods/fcitx5/with-addons.nix @@ -1,26 +1,30 @@ -{ lib -, symlinkJoin -, makeBinaryWrapper -, fcitx5 -, withConfigtool ? true -, fcitx5-configtool -, libsForQt5 -, qt6Packages -, fcitx5-gtk -, addons ? [ ] +{ + lib, + symlinkJoin, + makeBinaryWrapper, + fcitx5, + withConfigtool ? true, + fcitx5-configtool, + libsForQt5, + qt6Packages, + fcitx5-gtk, + addons ? [ ], }: symlinkJoin { name = "fcitx5-with-addons-${fcitx5.version}"; - paths = [ - fcitx5 - libsForQt5.fcitx5-qt - qt6Packages.fcitx5-qt - fcitx5-gtk - ] ++ lib.optionals withConfigtool [ - fcitx5-configtool - ] ++ addons; + paths = + [ + fcitx5 + libsForQt5.fcitx5-qt + qt6Packages.fcitx5-qt + fcitx5-gtk + ] + ++ lib.optionals withConfigtool [ + fcitx5-configtool + ] + ++ addons; nativeBuildInputs = [ makeBinaryWrapper ]; @@ -29,7 +33,9 @@ symlinkJoin { --prefix FCITX_ADDON_DIRS : "$out/lib/fcitx5" \ --suffix XDG_DATA_DIRS : "$out/share" \ --suffix PATH : "$out/bin" \ - --suffix LD_LIBRARY_PATH : "${lib.makeLibraryPath (lib.flatten (map (x: x.extraLdLibraries or []) addons))}" + --suffix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath (lib.flatten (map (x: x.extraLdLibraries or [ ]) addons)) + }" ${lib.optionalString withConfigtool '' # Configtool call libexec/fcitx5-qt5-gui-wrapper for gui addons in FCITX_ADDON_DIRS diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-anthy/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-anthy/default.nix index e7a5f4b1e16db1..867f31a7203ed1 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-anthy/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-anthy/default.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, fetchurl -, gettext -, pkg-config -, wrapGAppsHook3 -, anthy -, ibus -, glib -, gobject-introspection -, gtk3 -, python3 +{ + lib, + stdenv, + fetchurl, + gettext, + pkg-config, + wrapGAppsHook3, + anthy, + ibus, + glib, + gobject-introspection, + gtk3, + python3, }: stdenv.mkDerivation rec { @@ -52,6 +54,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/fujiwarat/ibus-anthy"; license = licenses.gpl2Plus; platforms = platforms.linux; - maintainers = with maintainers; [ gebner ericsagnes ]; + maintainers = with maintainers; [ + gebner + ericsagnes + ]; }; } diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-bamboo/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-bamboo/default.nix index 52bf588a3ce61c..3341b2ff2ed515 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-bamboo/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-bamboo/default.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitHub -, xorg -, pkg-config -, wrapGAppsHook3 -, go +{ + lib, + stdenv, + fetchFromGitHub, + xorg, + pkg-config, + wrapGAppsHook3, + go, }: stdenv.mkDerivation rec { @@ -36,7 +38,6 @@ stdenv.mkDerivation rec { "PREFIX=${placeholder "out"}" ]; - meta = with lib; { isIbusEngine = true; description = "Vietnamese IME for IBus"; diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-cangjie/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-cangjie/default.nix index ac85ed7f7f2862..0ea21714897ee8 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-cangjie/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-cangjie/default.nix @@ -1,16 +1,17 @@ -{ stdenv -, lib -, fetchFromGitHub -, gettext -, pkg-config -, wrapGAppsHook3 -, ibus -, glib -, gobject-introspection -, gtk3 -, python3 -, autoreconfHook -, intltool +{ + stdenv, + lib, + fetchFromGitHub, + gettext, + pkg-config, + wrapGAppsHook3, + ibus, + glib, + gobject-introspection, + gtk3, + python3, + autoreconfHook, + intltool, }: let diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-hangul/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-hangul/default.nix index c834c6aae5d64d..74fd01fff8afde 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-hangul/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-hangul/default.nix @@ -1,16 +1,18 @@ -{ lib, stdenv -, fetchFromGitHub -, substituteAll -, appstream-glib -, gettext -, pkg-config -, wrapGAppsHook3 -, gobject-introspection -, autoreconfHook -, gtk3 -, ibus -, libhangul -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + substituteAll, + appstream-glib, + gettext, + pkg-config, + wrapGAppsHook3, + gobject-introspection, + autoreconfHook, + gtk3, + ibus, + libhangul, + python3, }: stdenv.mkDerivation rec { @@ -44,10 +46,12 @@ stdenv.mkDerivation rec { gtk3 ibus libhangul - (python3.withPackages (pypkgs: with pypkgs; [ - pygobject3 - (toPythonModule ibus) - ])) + (python3.withPackages ( + pypkgs: with pypkgs; [ + pygobject3 + (toPythonModule ibus) + ] + )) ]; meta = with lib; { diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-kkc/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-kkc/default.nix index db57869f8538b1..88b58a571025cd 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-kkc/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-kkc/default.nix @@ -1,7 +1,14 @@ -{ lib, stdenv, fetchurl -, vala, intltool, pkg-config -, libkkc, ibus, skkDictionaries -, gtk3 +{ + lib, + stdenv, + fetchurl, + vala, + intltool, + pkg-config, + libkkc, + ibus, + skkDictionaries, + gtk3, }: stdenv.mkDerivation rec { @@ -14,10 +21,16 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - vala intltool pkg-config + vala + intltool + pkg-config ]; - buildInputs = [ libkkc ibus gtk3 ]; + buildInputs = [ + libkkc + ibus + gtk3 + ]; postInstall = '' ln -s ${skkDictionaries.l}/share/skk $out/share/skk @@ -25,10 +38,10 @@ stdenv.mkDerivation rec { meta = with lib; { isIbusEngine = true; - description = "libkkc (Japanese Kana Kanji input method) engine for ibus"; - homepage = "https://github.com/ueno/ibus-kkc"; - license = licenses.gpl2Plus; - platforms = platforms.linux; - maintainers = with maintainers; [ vanzef ]; + description = "libkkc (Japanese Kana Kanji input method) engine for ibus"; + homepage = "https://github.com/ueno/ibus-kkc"; + license = licenses.gpl2Plus; + platforms = platforms.linux; + maintainers = with maintainers; [ vanzef ]; }; } diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-libpinyin/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-libpinyin/default.nix index ac365fefb2fdd3..6e6a00d1802700 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-libpinyin/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-libpinyin/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, gettext -, pkg-config -, wrapGAppsHook3 -, sqlite -, libpinyin -, db -, ibus -, glib -, gtk3 -, python3 -, lua -, opencc -, libsoup_3 -, json-glib +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gettext, + pkg-config, + wrapGAppsHook3, + sqlite, + libpinyin, + db, + ibus, + glib, + gtk3, + python3, + lua, + opencc, + libsoup_3, + json-glib, }: stdenv.mkDerivation rec { @@ -46,10 +47,12 @@ stdenv.mkDerivation rec { glib sqlite libpinyin - (python3.withPackages (pypkgs: with pypkgs; [ - pygobject3 - (toPythonModule ibus) - ])) + (python3.withPackages ( + pypkgs: with pypkgs; [ + pygobject3 + (toPythonModule ibus) + ] + )) gtk3 db lua @@ -62,7 +65,10 @@ stdenv.mkDerivation rec { isIbusEngine = true; description = "IBus interface to the libpinyin input method"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ linsui ericsagnes ]; + maintainers = with maintainers; [ + linsui + ericsagnes + ]; platforms = platforms.linux; }; } diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-libthai/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-libthai/default.nix index e72760e73539c1..c723247f2aa1ce 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-libthai/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-libthai/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, pkg-config, ibus, gtk3, libthai }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + ibus, + gtk3, + libthai, +}: stdenv.mkDerivation rec { pname = "ibus-libthai"; @@ -11,7 +19,11 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ gtk3 ibus libthai ]; + buildInputs = [ + gtk3 + ibus + libthai + ]; meta = with lib; { isIbusEngine = true; diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-m17n/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-m17n/default.nix index 101438c8fbb7eb..04624b495eac9b 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-m17n/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-m17n/default.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, ibus -, gtk3 -, m17n_lib -, m17n_db -, gettext -, python3 -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + ibus, + gtk3, + m17n_lib, + m17n_db, + gettext, + python3, + wrapGAppsHook3, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-rime/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-rime/default.nix index 774978929b4015..aee2acbd9c52b0 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-rime/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-rime/default.nix @@ -1,16 +1,17 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, gdk-pixbuf -, glib -, ibus -, libnotify -, librime -, pkg-config -, rime-data -, symlinkJoin -, rimeDataPkgs ? [ rime-data ] +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + gdk-pixbuf, + glib, + ibus, + libnotify, + librime, + pkg-config, + rime-data, + symlinkJoin, + rimeDataPkgs ? [ rime-data ], }: stdenv.mkDerivation rec { @@ -24,8 +25,17 @@ stdenv.mkDerivation rec { sha256 = "0gdxg6ia0i31jn3cvh1nrsjga1j31hf8a2zfgg8rzn25chrfr319"; }; - buildInputs = [ gdk-pixbuf glib ibus libnotify librime ]; - nativeBuildInputs = [ cmake pkg-config ]; + buildInputs = [ + gdk-pixbuf + glib + ibus + libnotify + librime + ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; cmakeFlags = [ "-DRIME_DATA_DIR=${placeholder "out"}/share/rime-data" ]; diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-table-chinese/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-table-chinese/default.nix index 40c33aff401186..e829835af7e8a9 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-table-chinese/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-table-chinese/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchgit, fetchFromGitHub, pkg-config, ibus, ibus-table, python3, cmake }: +{ + lib, + stdenv, + fetchgit, + fetchFromGitHub, + pkg-config, + ibus, + ibus-table, + python3, + cmake, +}: let src = fetchFromGitHub { @@ -13,11 +23,15 @@ let rev = "7d5297759aef4cd086bdfa30cf6d4b2ad9446992"; sha256 = "0mx9jvxpiva9v2ffaqlyny48iqr073h84yw8ln43z2avv11ipr7n"; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "ibus-table-chinese"; version = "1.8.2"; - srcs = [ src cmakeFedoraSrc ]; + srcs = [ + src + cmakeFedoraSrc + ]; sourceRoot = src.name; postUnpack = '' @@ -31,7 +45,11 @@ in stdenv.mkDerivation { ''; # Fails when writing to /prj_info.cmake in https://pagure.io/cmake-fedora/blob/master/f/Modules/ManageVersion.cmake - cmakeFlags = [ "-DPRJ_INFO_CMAKE_FILE=/dev/null" "-DPRJ_DOC_DIR=REPLACE" "-DDATA_DIR=share" ]; + cmakeFlags = [ + "-DPRJ_INFO_CMAKE_FILE=/dev/null" + "-DPRJ_DOC_DIR=REPLACE" + "-DDATA_DIR=share" + ]; # Must replace PRJ_DOC_DIR with actual share/ folder for ibus-table-chinese # Otherwise it tries to write to /ibus-table-chinese if not defined (!) postConfigure = '' @@ -51,15 +69,22 @@ in stdenv.mkDerivation { rm -rf $HOME ''; - nativeBuildInputs = [ cmake pkg-config ]; - buildInputs = [ ibus ibus-table python3 ]; + nativeBuildInputs = [ + cmake + pkg-config + ]; + buildInputs = [ + ibus + ibus-table + python3 + ]; meta = with lib; { isIbusEngine = true; - description = "Chinese tables for IBus-Table"; - homepage = "https://github.com/definite/ibus-table-chinese"; - license = licenses.gpl3; - platforms = platforms.linux; - maintainers = with maintainers; [ pneumaticat ]; + description = "Chinese tables for IBus-Table"; + homepage = "https://github.com/definite/ibus-table-chinese"; + license = licenses.gpl3; + platforms = platforms.linux; + maintainers = with maintainers; [ pneumaticat ]; }; } diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-table-others/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-table-others/default.nix index 833892b79926da..b473188a6a5799 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-table-others/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-table-others/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, ibus, ibus-table, pkg-config, python3 }: +{ + lib, + stdenv, + fetchurl, + ibus, + ibus-table, + pkg-config, + python3, +}: stdenv.mkDerivation rec { pname = "ibus-table-others"; @@ -9,8 +17,14 @@ stdenv.mkDerivation rec { hash = "sha256-4ZM5WZPh6Y5M50KDS+86j00v4pWTRdcdVYh4DcEYXAA="; }; - nativeBuildInputs = [ pkg-config python3 ]; - buildInputs = [ ibus ibus-table ]; + nativeBuildInputs = [ + pkg-config + python3 + ]; + buildInputs = [ + ibus + ibus-table + ]; preBuild = '' export HOME=$TMPDIR @@ -18,10 +32,13 @@ stdenv.mkDerivation rec { meta = with lib; { isIbusEngine = true; - description = "Various table-based input methods for IBus"; - homepage = "https://github.com/moebiuscurve/ibus-table-others"; - license = licenses.gpl3; - platforms = platforms.linux; - maintainers = with maintainers; [ mudri McSinyx ]; + description = "Various table-based input methods for IBus"; + homepage = "https://github.com/moebiuscurve/ibus-table-others"; + license = licenses.gpl3; + platforms = platforms.linux; + maintainers = with maintainers; [ + mudri + McSinyx + ]; }; } diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-table/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-table/default.nix index db914687f31666..82e256996b0a6f 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-table/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-table/default.nix @@ -1,16 +1,26 @@ -{ lib, stdenv, fetchFromGitHub -, autoreconfHook, docbook2x, pkg-config -, gtk3, dconf, gobject-introspection -, ibus, python3, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + docbook2x, + pkg-config, + gtk3, + dconf, + gobject-introspection, + ibus, + python3, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "ibus-table"; version = "1.17.8"; src = fetchFromGitHub { - owner = "kaio"; - repo = "ibus-table"; - rev = version; + owner = "kaio"; + repo = "ibus-table"; + rev = version; sha256 = "sha256-bPHwpTrDCLil6xNBr7lKAMP71koFlZvPc2vpDuwzZzM="; }; @@ -36,11 +46,13 @@ stdenv.mkDerivation rec { dconf gtk3 ibus - (python3.withPackages (pypkgs: with pypkgs; [ - dbus-python - pygobject3 - (toPythonModule ibus) - ])) + (python3.withPackages ( + pypkgs: with pypkgs; [ + dbus-python + pygobject3 + (toPythonModule ibus) + ] + )) ]; nativeBuildInputs = [ @@ -58,11 +70,11 @@ stdenv.mkDerivation rec { meta = with lib; { isIbusEngine = true; - description = "IBus framework for table-based input methods"; + description = "IBus framework for table-based input methods"; mainProgram = "ibus-table-createdb"; - homepage = "https://github.com/kaio/ibus-table/wiki"; - license = licenses.lgpl21; - platforms = platforms.linux; - maintainers = with maintainers; [ mudri ]; + homepage = "https://github.com/kaio/ibus-table/wiki"; + license = licenses.lgpl21; + platforms = platforms.linux; + maintainers = with maintainers; [ mudri ]; }; } diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-typing-booster/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-typing-booster/default.nix index be8c05932269e8..416207479b567d 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-typing-booster/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-typing-booster/default.nix @@ -1,13 +1,25 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, python3, ibus, pkg-config, gtk3, m17n_lib -, wrapGAppsHook3, gobject-introspection +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + python3, + ibus, + pkg-config, + gtk3, + m17n_lib, + wrapGAppsHook3, + gobject-introspection, }: let - python = python3.withPackages (ps: with ps; [ - pygobject3 - dbus-python - ]); + python = python3.withPackages ( + ps: with ps; [ + pygobject3 + dbus-python + ] + ); in @@ -22,8 +34,18 @@ stdenv.mkDerivation rec { hash = "sha256-brQzxW9NztvXOz2lCp513UMFt6/ksbxGNKdeXvxP7jQ="; }; - nativeBuildInputs = [ autoreconfHook pkg-config wrapGAppsHook3 gobject-introspection ]; - buildInputs = [ python ibus gtk3 m17n_lib ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + wrapGAppsHook3 + gobject-introspection + ]; + buildInputs = [ + python + ibus + gtk3 + m17n_lib + ]; preFixup = '' gappsWrapperArgs+=(--prefix LD_LIBRARY_PATH : "${m17n_lib}/lib") diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-typing-booster/wrapper.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-typing-booster/wrapper.nix index 4b5180f0e15c16..bd25b492bb7847 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-typing-booster/wrapper.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-typing-booster/wrapper.nix @@ -1,5 +1,19 @@ -{ typing-booster, symlinkJoin, hunspellDicts, lib, makeWrapper -, langs ? [ "de-de" "en-gb-ise" "en-us" "es-es" "fr-moderne" "it-it" "sv-se" "sv-fi" ] +{ + typing-booster, + symlinkJoin, + hunspellDicts, + lib, + makeWrapper, + langs ? [ + "de-de" + "en-gb-ise" + "en-us" + "es-es" + "fr-moderne" + "it-it" + "sv-se" + "sv-fi" + ], }: let diff --git a/pkgs/tools/inputmethods/ibus-engines/ibus-uniemoji/default.nix b/pkgs/tools/inputmethods/ibus-engines/ibus-uniemoji/default.nix index 9ec45c65ee680d..d273629860913c 100644 --- a/pkgs/tools/inputmethods/ibus-engines/ibus-uniemoji/default.nix +++ b/pkgs/tools/inputmethods/ibus-engines/ibus-uniemoji/default.nix @@ -1,19 +1,24 @@ -{ lib, stdenv -, fetchFromGitHub -, gobject-introspection -, wrapGAppsHook3 -, python3 -, ibus +{ + lib, + stdenv, + fetchFromGitHub, + gobject-introspection, + wrapGAppsHook3, + python3, + ibus, }: let - python = python3.withPackages (ps: with ps; [ - pygobject3 - (toPythonModule ibus) - pyxdg - levenshtein - ]); -in stdenv.mkDerivation rec { + python = python3.withPackages ( + ps: with ps; [ + pygobject3 + (toPythonModule ibus) + pyxdg + levenshtein + ] + ); +in +stdenv.mkDerivation rec { pname = "ibus-uniemoji"; version = "0.6.0"; @@ -30,7 +35,6 @@ in stdenv.mkDerivation rec { ./allow-wrapping.patch ]; - nativeBuildInputs = [ wrapGAppsHook3 gobject-introspection @@ -55,7 +59,10 @@ in stdenv.mkDerivation rec { isIbusEngine = true; description = "Input method (ibus) for entering unicode symbols and emoji by name"; homepage = "https://github.com/salty-horse/ibus-uniemoji"; - license = with licenses; [ gpl3 mit ]; + license = with licenses; [ + gpl3 + mit + ]; platforms = platforms.linux; maintainers = with maintainers; [ aske ]; }; diff --git a/pkgs/tools/inputmethods/ibus/default.nix b/pkgs/tools/inputmethods/ibus/default.nix index f9a22d8028b091..d3161f748743d9 100644 --- a/pkgs/tools/inputmethods/ibus/default.nix +++ b/pkgs/tools/inputmethods/ibus/default.nix @@ -1,38 +1,39 @@ -{ lib -, stdenv -, substituteAll -, fetchFromGitHub -, autoreconfHook -, gettext -, makeWrapper -, pkg-config -, vala -, wrapGAppsHook3 -, dbus -, systemd -, dconf ? null -, glib -, gdk-pixbuf -, gobject-introspection -, gtk3 -, gtk4 -, gtk-doc -, libdbusmenu-gtk3 -, runCommand -, isocodes -, cldr-annotations -, unicode-character-database -, unicode-emoji -, python3 -, json-glib -, libnotify ? null -, enableUI ? true -, withWayland ? true -, libxkbcommon -, wayland -, buildPackages -, runtimeShell -, nixosTests +{ + lib, + stdenv, + substituteAll, + fetchFromGitHub, + autoreconfHook, + gettext, + makeWrapper, + pkg-config, + vala, + wrapGAppsHook3, + dbus, + systemd, + dconf ? null, + glib, + gdk-pixbuf, + gobject-introspection, + gtk3, + gtk4, + gtk-doc, + libdbusmenu-gtk3, + runCommand, + isocodes, + cldr-annotations, + unicode-character-database, + unicode-emoji, + python3, + json-glib, + libnotify ? null, + enableUI ? true, + withWayland ? true, + libxkbcommon, + wayland, + buildPackages, + runtimeShell, + nixosTests, }: let @@ -47,13 +48,15 @@ let }; # make-dconf-override-db.sh needs to execute dbus-launch in the sandbox, # it will fail to read /etc/dbus-1/session.conf unless we add this flag - dbus-launch = runCommand "sandbox-dbus-launch" - { - nativeBuildInputs = [ makeWrapper ]; - } '' - makeWrapper ${dbus}/bin/dbus-launch $out/bin/dbus-launch \ - --add-flags --config-file=${dbus}/share/dbus-1/session.conf - ''; + dbus-launch = + runCommand "sandbox-dbus-launch" + { + nativeBuildInputs = [ makeWrapper ]; + } + '' + makeWrapper ${dbus}/bin/dbus-launch $out/bin/dbus-launch \ + --add-flags --config-file=${dbus}/share/dbus-1/session.conf + ''; in stdenv.mkDerivation rec { @@ -76,7 +79,11 @@ stdenv.mkDerivation rec { ./build-without-dbus-launch.patch ]; - outputs = [ "out" "dev" "installedTests" ]; + outputs = [ + "out" + "dev" + "installedTests" + ]; postPatch = '' # Maintainer does not want to create separate tarballs for final release candidate and release versions, @@ -120,7 +127,6 @@ stdenv.mkDerivation rec { "test_sourcesdir=${placeholder "installedTests"}/share/installed-tests/ibus" ]; - depsBuildBuild = [ pkg-config ]; @@ -142,23 +148,25 @@ stdenv.mkDerivation rec { glib ]; - buildInputs = [ - dbus - systemd - dconf - gdk-pixbuf - python3.pkgs.pygobject3 # for pygobject overrides - gtk3 - gtk4 - isocodes - json-glib - libnotify - libdbusmenu-gtk3 - vala # for share/vala/Makefile.vapigen (PKG_CONFIG_VAPIGEN_VAPIGEN) - ] ++ lib.optionals withWayland [ - libxkbcommon - wayland - ]; + buildInputs = + [ + dbus + systemd + dconf + gdk-pixbuf + python3.pkgs.pygobject3 # for pygobject overrides + gtk3 + gtk4 + isocodes + json-glib + libnotify + libdbusmenu-gtk3 + vala # for share/vala/Makefile.vapigen (PKG_CONFIG_VAPIGEN_VAPIGEN) + ] + ++ lib.optionals withWayland [ + libxkbcommon + wayland + ]; enableParallelBuilding = true; diff --git a/pkgs/tools/inputmethods/ibus/wrapper.nix b/pkgs/tools/inputmethods/ibus/wrapper.nix index c1328fbe984a78..0166fa777d70cb 100644 --- a/pkgs/tools/inputmethods/ibus/wrapper.nix +++ b/pkgs/tools/inputmethods/ibus/wrapper.nix @@ -1,11 +1,12 @@ -{ lib -, buildEnv -, makeWrapper -, dconf -, hicolor-icon-theme -, ibus -, librsvg -, plugins ? [ ] +{ + lib, + buildEnv, + makeWrapper, + dconf, + hicolor-icon-theme, + ibus, + librsvg, + plugins ? [ ], }: buildEnv { diff --git a/pkgs/tools/inputmethods/input-remapper/default.nix b/pkgs/tools/inputmethods/input-remapper/default.nix index 8431baa1526b8e..4713d7f2f4c00b 100644 --- a/pkgs/tools/inputmethods/input-remapper/default.nix +++ b/pkgs/tools/inputmethods/input-remapper/default.nix @@ -1,33 +1,34 @@ -{ lib -, pkgconfig -, wrapGAppsHook3 -, gettext -, gtk3 -, glib -, dbus -, gobject-introspection -, xmodmap -, pygobject3 -, setuptools -, evdev -, pydantic -, pydbus -, psutil -, fetchFromGitHub -, buildPythonApplication -, procps -, gtksourceview4 -, nixosTests +{ + lib, + pkgconfig, + wrapGAppsHook3, + gettext, + gtk3, + glib, + dbus, + gobject-introspection, + xmodmap, + pygobject3, + setuptools, + evdev, + pydantic, + pydbus, + psutil, + fetchFromGitHub, + buildPythonApplication, + procps, + gtksourceview4, + nixosTests, # Change the default log level to debug for easier debugging of package issues -, withDebugLogLevel ? false + withDebugLogLevel ? false, # Xmodmap is an optional dependency # If you use Xmodmap to set keyboard mappings (or your DE does) # it is required to correctly map keys -, withXmodmap ? true + withXmodmap ? true, # Some tests are flakey under high CPU load and could cause intermittent # failures when building. Override this to true to run tests anyway # See upstream issue: https://github.com/sezanzeb/input-remapper/issues/306 -, withDoCheck ? false + withDoCheck ? false, }: let @@ -44,14 +45,16 @@ in hash = "sha256-rwlVGF/cWSv6Bsvhrs6nMDQ8avYT80aasrhWyQv55/A="; }; - postPatch = '' - # fix FHS paths - substituteInPlace inputremapper/configs/data.py \ - --replace "/usr/share" "$out/usr/share" - '' + lib.optionalString withDebugLogLevel '' - # if debugging - substituteInPlace inputremapper/logger.py --replace "logger.setLevel(logging.INFO)" "logger.setLevel(logging.DEBUG)" - ''; + postPatch = + '' + # fix FHS paths + substituteInPlace inputremapper/configs/data.py \ + --replace "/usr/share" "$out/usr/share" + '' + + lib.optionalString withDebugLogLevel '' + # if debugging + substituteInPlace inputremapper/logger.py --replace "logger.setLevel(logging.INFO)" "logger.setLevel(logging.DEBUG)" + ''; doCheck = withDoCheck; nativeCheckInputs = [ @@ -81,7 +84,15 @@ in " > dbus.cfg - PATH=${lib.makeBinPath ([ dbus procps ] ++ maybeXmodmap)}:$PATH \ + PATH=${ + lib.makeBinPath ( + [ + dbus + procps + ] + ++ maybeXmodmap + ) + }:$PATH \ USER="$(id -u -n)" \ DBUS_SYSTEM_BUS_ADDRESS=unix:path=/build/system_bus_socket \ ${dbus}/bin/dbus-run-session --config-file dbus.cfg \ @@ -147,14 +158,19 @@ in maintainers = with maintainers; [ LunNova ]; mainProgram = "input-remapper-gtk"; }; -}).overrideAttrs (final: prev: { - # Set in an override as buildPythonApplication doesn't yet support - # the `final:` arg yet from #119942 'overlay style overridable recursive attributes' - # this ensures the rev matches the input src's rev after overriding - # See https://discourse.nixos.org/t/avoid-rec-expresions-in-nixpkgs/8293/7 for more - # discussion - postPatch = prev.postPatch or "" + '' - # set revision for --version output - echo "COMMIT_HASH = '${final.src.rev}'" > inputremapper/commit_hash.py - ''; -}) +}).overrideAttrs + ( + final: prev: { + # Set in an override as buildPythonApplication doesn't yet support + # the `final:` arg yet from #119942 'overlay style overridable recursive attributes' + # this ensures the rev matches the input src's rev after overriding + # See https://discourse.nixos.org/t/avoid-rec-expresions-in-nixpkgs/8293/7 for more + # discussion + postPatch = + prev.postPatch or "" + + '' + # set revision for --version output + echo "COMMIT_HASH = '${final.src.rev}'" > inputremapper/commit_hash.py + ''; + } + ) diff --git a/pkgs/tools/inputmethods/interception-tools/caps2esc.nix b/pkgs/tools/inputmethods/interception-tools/caps2esc.nix index 99865b354dd30b..6e9b8f32800a2e 100644 --- a/pkgs/tools/inputmethods/interception-tools/caps2esc.nix +++ b/pkgs/tools/inputmethods/interception-tools/caps2esc.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitLab, cmake }: +{ + lib, + stdenv, + fetchFromGitLab, + cmake, +}: stdenv.mkDerivation rec { pname = "caps2esc"; diff --git a/pkgs/tools/inputmethods/interception-tools/dual-function-keys.nix b/pkgs/tools/inputmethods/interception-tools/dual-function-keys.nix index 022e7dfa038992..d9a786213bfb17 100644 --- a/pkgs/tools/inputmethods/interception-tools/dual-function-keys.nix +++ b/pkgs/tools/inputmethods/interception-tools/dual-function-keys.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitLab, pkg-config, yaml-cpp, libevdev }: +{ + stdenv, + lib, + fetchFromGitLab, + pkg-config, + yaml-cpp, + libevdev, +}: stdenv.mkDerivation rec { pname = "dual-function-keys"; @@ -14,7 +21,10 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libevdev yaml-cpp ]; + buildInputs = [ + libevdev + yaml-cpp + ]; prePatch = '' substituteInPlace config.mk --replace \ @@ -22,7 +32,10 @@ stdenv.mkDerivation rec { "$(pkg-config --cflags libevdev | cut -c 3-)" ''; - installFlags = [ "DESTDIR=$(out)" "PREFIX=" ]; + installFlags = [ + "DESTDIR=$(out)" + "PREFIX=" + ]; meta = with lib; { homepage = "https://gitlab.com/interception/linux/plugins/dual-function-keys"; diff --git a/pkgs/tools/inputmethods/m17n-lib/default.nix b/pkgs/tools/inputmethods/m17n-lib/default.nix index ca586a449703e4..7d5289010daa2b 100644 --- a/pkgs/tools/inputmethods/m17n-lib/default.nix +++ b/pkgs/tools/inputmethods/m17n-lib/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, m17n_db -, autoreconfHook -, pkg-config +{ + lib, + stdenv, + fetchurl, + m17n_db, + autoreconfHook, + pkg-config, }: stdenv.mkDerivation rec { pname = "m17n-lib"; @@ -18,7 +19,8 @@ stdenv.mkDerivation rec { # reconf needed to sucesfully cross-compile nativeBuildInputs = [ - autoreconfHook pkg-config + autoreconfHook + pkg-config # requires m17n-db tool at build time m17n_db ]; diff --git a/pkgs/tools/inputmethods/m17n-lib/otf.nix b/pkgs/tools/inputmethods/m17n-lib/otf.nix index d700dfb3ebd95b..b92b57746e851d 100644 --- a/pkgs/tools/inputmethods/m17n-lib/otf.nix +++ b/pkgs/tools/inputmethods/m17n-lib/otf.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, autoreconfHook, xorg, freetype }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + autoreconfHook, + xorg, + freetype, +}: stdenv.mkDerivation rec { pname = "libotf"; @@ -29,11 +38,20 @@ stdenv.mkDerivation rec { strictDeps = true; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; - buildInputs = [ xorg.libXaw freetype ]; + buildInputs = [ + xorg.libXaw + freetype + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; postInstall = '' mkdir -p $dev/bin diff --git a/pkgs/tools/inputmethods/skk/skk-dicts/default.nix b/pkgs/tools/inputmethods/skk/skk-dicts/default.nix index 9b2dd3c182dd0a..83981b27fc3a7b 100644 --- a/pkgs/tools/inputmethods/skk/skk-dicts/default.nix +++ b/pkgs/tools/inputmethods/skk/skk-dicts/default.nix @@ -1,21 +1,24 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, nix-update-script -, nkf -, skktools -, useUtf8 ? false +{ + lib, + stdenvNoCC, + fetchFromGitHub, + nix-update-script, + nkf, + skktools, + useUtf8 ? false, }: let suffix = lib.optionalString useUtf8 ".utf8"; mkDictNameValue = - { name - , description - , license # it's written in the beginning of each file - , files ? [ "SKK-JISYO.${name}" ] - }: { + { + name, + description, + license, # it's written in the beginning of each file + files ? [ "SKK-JISYO.${name}" ], + }: + { name = lib.toLower (builtins.replaceStrings [ "." ] [ "_" ] name); value = stdenvNoCC.mkDerivation { pname = "skk-jisyo-" + lib.toLower name; @@ -32,29 +35,31 @@ let strictDeps = true; - buildPhase = '' - runHook preBuild - '' + lib.concatMapStrings - (file: '' + buildPhase = + '' + runHook preBuild + '' + + lib.concatMapStrings (file: '' nkf -w ${file} \ | LC_ALL=C sed 's/coding: [^ ]\{1,\}/coding: utf-8/' \ > ${file + suffix} - '') - (lib.optionals useUtf8 (map lib.escapeShellArg files)) + '' - runHook postBuild - ''; + '') (lib.optionals useUtf8 (map lib.escapeShellArg files)) + + '' + runHook postBuild + ''; - installPhase = '' - runHook preInstall - '' + lib.concatMapStrings - (file: '' + installPhase = + '' + runHook preInstall + '' + + lib.concatMapStrings (file: '' install -Dm644 \ ${lib.escapeShellArg file} \ $out/share/skk/${lib.escapeShellArg (baseNameOf file)} - '') - (map (file: file + suffix) files) + '' - runHook postInstall - ''; + '') (map (file: file + suffix) files) + + '' + runHook postInstall + ''; doInstallCheck = true; installCheckPhase = '' @@ -64,7 +69,10 @@ let ''; passthru.updateScript = nix-update-script { - extraArgs = ["--version" "branch"]; + extraArgs = [ + "--version" + "branch" + ]; }; meta = with lib; { @@ -74,129 +82,137 @@ let SKK Japanese input method. ''; homepage = "https://github.com/skk-dev/dict"; - maintainers = with maintainers; [ yuriaisaka midchildan ]; + maintainers = with maintainers; [ + yuriaisaka + midchildan + ]; platforms = platforms.all; }; }; }; in -lib.listToAttrs (map mkDictNameValue [ - { - name = "L"; - description = "The standard SKK dictionary"; - license = lib.licenses.gpl2Plus; - } - { - name = "S"; - description = "Small SKK dictionary"; - license = lib.licenses.gpl2Plus; - } - { - name = "M"; - description = "Medium sized SKK dictionary"; - license = lib.licenses.gpl2Plus; - } - { - name = "ML"; - description = "Medium to large sized SKK dictionary"; - license = lib.licenses.gpl2Plus; - } - { - name = "jinmei"; - description = "SKK dictionary for names"; - license = lib.licenses.gpl2Plus; - } - { - name = "fullname"; - description = "SKK dictionary for celebrities"; - license = lib.licenses.gpl2Plus; - } - { - name = "geo"; - description = "SKK dictionary for locations"; - license = lib.licenses.gpl2Plus; - } - { - name = "propernoun"; - description = "SKK dictionary for proper nouns"; - license = lib.licenses.gpl2Plus; - } - { - name = "station"; - description = "SKK dictionary for stations"; - license = lib.licenses.gpl2Plus; - } - { - name = "law"; - description = "SKK dictionary for legal terms"; - license = lib.licenses.gpl2Plus; - } - { - name = "okinawa"; - description = "SKK dictionary for the Okinawan language"; - license = lib.licenses.publicDomain; - } - { - name = "china_taiwan"; - description = "SKK dictionary for Chinese & Taiwanese locations"; - license = lib.licenses.gpl2Plus; - } - { - name = "assoc"; - description = "SKK dictionary for abbreviated input"; - license = lib.licenses.gpl2Plus; - } - { - name = "edict"; - description = "SKK dictionary for English to Japanese translation"; - license = lib.licenses.cc-by-sa-30; - } - { - name = "zipcode"; - description = "SKK dictionary for Japanese zipcodes"; - files = [ "zipcode/SKK-JISYO.zipcode" "zipcode/SKK-JISYO.office.zipcode" ]; - license = lib.licenses.publicDomain; - } - { - name = "JIS2"; - description = "SKK dictionary for JIS level 2 kanjis"; - license = lib.licenses.gpl2Plus; - } - { - name = "JIS3_4"; - description = "SKK dictionary for JIS level 3 and 4 kanjis"; - license = lib.licenses.gpl2Plus; - } - { - name = "JIS2004"; - description = '' - A complementary SKK dictionary for JIS3_4 with JIS X 0213:2004 additions" - ''; - license = lib.licenses.gpl2Plus; - } - { - name = "itaiji"; - description = "SKK dictionary for variant kanjis"; - license = lib.licenses.publicDomain; - } - { - name = "itaiji.JIS3_4"; - description = "SKK dictionary for JIS level 3 and 4 variant kanjis"; - license = lib.licenses.gpl2Plus; - } - { - name = "mazegaki"; - description = "SKK dictionary for mazegaki"; - license = lib.licenses.gpl2Plus; - } - { - name = "emoji"; - description = "SKK dictionary for emojis"; - license = lib.licenses.unicode-dfs-2016; - } - { - name = "pinyin"; - description = "SKK dictionary for pinyin to simplified Chinese input"; - license = lib.licenses.gpl1Plus; - } -]) +lib.listToAttrs ( + map mkDictNameValue [ + { + name = "L"; + description = "The standard SKK dictionary"; + license = lib.licenses.gpl2Plus; + } + { + name = "S"; + description = "Small SKK dictionary"; + license = lib.licenses.gpl2Plus; + } + { + name = "M"; + description = "Medium sized SKK dictionary"; + license = lib.licenses.gpl2Plus; + } + { + name = "ML"; + description = "Medium to large sized SKK dictionary"; + license = lib.licenses.gpl2Plus; + } + { + name = "jinmei"; + description = "SKK dictionary for names"; + license = lib.licenses.gpl2Plus; + } + { + name = "fullname"; + description = "SKK dictionary for celebrities"; + license = lib.licenses.gpl2Plus; + } + { + name = "geo"; + description = "SKK dictionary for locations"; + license = lib.licenses.gpl2Plus; + } + { + name = "propernoun"; + description = "SKK dictionary for proper nouns"; + license = lib.licenses.gpl2Plus; + } + { + name = "station"; + description = "SKK dictionary for stations"; + license = lib.licenses.gpl2Plus; + } + { + name = "law"; + description = "SKK dictionary for legal terms"; + license = lib.licenses.gpl2Plus; + } + { + name = "okinawa"; + description = "SKK dictionary for the Okinawan language"; + license = lib.licenses.publicDomain; + } + { + name = "china_taiwan"; + description = "SKK dictionary for Chinese & Taiwanese locations"; + license = lib.licenses.gpl2Plus; + } + { + name = "assoc"; + description = "SKK dictionary for abbreviated input"; + license = lib.licenses.gpl2Plus; + } + { + name = "edict"; + description = "SKK dictionary for English to Japanese translation"; + license = lib.licenses.cc-by-sa-30; + } + { + name = "zipcode"; + description = "SKK dictionary for Japanese zipcodes"; + files = [ + "zipcode/SKK-JISYO.zipcode" + "zipcode/SKK-JISYO.office.zipcode" + ]; + license = lib.licenses.publicDomain; + } + { + name = "JIS2"; + description = "SKK dictionary for JIS level 2 kanjis"; + license = lib.licenses.gpl2Plus; + } + { + name = "JIS3_4"; + description = "SKK dictionary for JIS level 3 and 4 kanjis"; + license = lib.licenses.gpl2Plus; + } + { + name = "JIS2004"; + description = '' + A complementary SKK dictionary for JIS3_4 with JIS X 0213:2004 additions" + ''; + license = lib.licenses.gpl2Plus; + } + { + name = "itaiji"; + description = "SKK dictionary for variant kanjis"; + license = lib.licenses.publicDomain; + } + { + name = "itaiji.JIS3_4"; + description = "SKK dictionary for JIS level 3 and 4 variant kanjis"; + license = lib.licenses.gpl2Plus; + } + { + name = "mazegaki"; + description = "SKK dictionary for mazegaki"; + license = lib.licenses.gpl2Plus; + } + { + name = "emoji"; + description = "SKK dictionary for emojis"; + license = lib.licenses.unicode-dfs-2016; + } + { + name = "pinyin"; + description = "SKK dictionary for pinyin to simplified Chinese input"; + license = lib.licenses.gpl1Plus; + } + ] +) diff --git a/pkgs/tools/inputmethods/uim/default.nix b/pkgs/tools/inputmethods/uim/default.nix index be720c6ce2341d..ffd3955a318110 100644 --- a/pkgs/tools/inputmethods/uim/default.nix +++ b/pkgs/tools/inputmethods/uim/default.nix @@ -1,22 +1,46 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, shared-mime-info -, autoconf, automake, intltool, libtool, pkg-config, cmake -, ruby, librsvg -, ncurses, m17n_lib, m17n_db, expat -, withAnthy ? true, anthy ? null -, withGtk ? true -, withGtk2 ? withGtk, gtk2 ? null -, withGtk3 ? withGtk, gtk3 ? null -# Was never enabled in the history of this package and is not needed by any -# dependent package, hence disabled to save up closure size. -, withQt ? false -, withQt5 ? withQt, qt5 ? null -, withLibnotify ? true, libnotify ? null -, withSqlite ? true, sqlite ? null -, withNetworking ? true, curl ? null, openssl ? null -, withFFI ? true, libffi ? null - -# Things that are clearly an overkill to be enabled by default -, withMisc ? false, libeb ? null +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + shared-mime-info, + autoconf, + automake, + intltool, + libtool, + pkg-config, + cmake, + ruby, + librsvg, + ncurses, + m17n_lib, + m17n_db, + expat, + withAnthy ? true, + anthy ? null, + withGtk ? true, + withGtk2 ? withGtk, + gtk2 ? null, + withGtk3 ? withGtk, + gtk3 ? null, + # Was never enabled in the history of this package and is not needed by any + # dependent package, hence disabled to save up closure size. + withQt ? false, + withQt5 ? withQt, + qt5 ? null, + withLibnotify ? true, + libnotify ? null, + withSqlite ? true, + sqlite ? null, + withNetworking ? true, + curl ? null, + openssl ? null, + withFFI ? true, + libffi ? null, + + # Things that are clearly an overkill to be enabled by default + withMisc ? false, + libeb ? null, }: assert withGtk2 -> gtk2 != null; @@ -41,29 +65,44 @@ stdenv.mkDerivation rec { sha256 = "1hkjxi5r49gcna37m3jvykny5hz9ram4y8a3q7lw4qzr52mz9pdp"; }; - nativeBuildInputs = [ - autoconf automake intltool libtool pkg-config cmake - - ruby # used by sigscheme build to generate function tables - librsvg # used by uim build to generate png pixmaps from svg - ] ++ lib.optionals withQt5 [ - qt5.wrapQtAppsHook - ]; - - buildInputs = [ - ncurses m17n_lib m17n_db expat - ] - ++ lib.optional withAnthy anthy - ++ lib.optional withGtk2 gtk2 - ++ lib.optional withGtk3 gtk3 - ++ lib.optionals withQt5 [ qt5.qtbase qt5.qtx11extras ] - ++ lib.optional withLibnotify libnotify - ++ lib.optional withSqlite sqlite - ++ lib.optionals withNetworking [ - curl openssl - ] - ++ lib.optional withFFI libffi - ++ lib.optional withMisc libeb; + nativeBuildInputs = + [ + autoconf + automake + intltool + libtool + pkg-config + cmake + + ruby # used by sigscheme build to generate function tables + librsvg # used by uim build to generate png pixmaps from svg + ] + ++ lib.optionals withQt5 [ + qt5.wrapQtAppsHook + ]; + + buildInputs = + [ + ncurses + m17n_lib + m17n_db + expat + ] + ++ lib.optional withAnthy anthy + ++ lib.optional withGtk2 gtk2 + ++ lib.optional withGtk3 gtk3 + ++ lib.optionals withQt5 [ + qt5.qtbase + qt5.qtx11extras + ] + ++ lib.optional withLibnotify libnotify + ++ lib.optional withSqlite sqlite + ++ lib.optionals withNetworking [ + curl + openssl + ] + ++ lib.optional withFFI libffi + ++ lib.optional withMisc libeb; prePatch = '' patchShebangs *.sh */*.sh */*/*.sh @@ -95,32 +134,33 @@ stdenv.mkDerivation rec { }) ]; - configureFlags = [ - # configure in maintainer mode or else some pixmaps won't get autogenerated - # this should imply the above `--enable-maintainer-mode`, but it does not - "--enable-maintainer-mode" - - "--enable-pref" - "--with-skk" - "--with-x" - "--with-xft" - "--with-expat=${expat.dev}" - ] - ++ lib.optional withAnthy "--with-anthy-utf8" - ++ lib.optional withGtk2 "--with-gtk2" - ++ lib.optional withGtk3 "--with-gtk3" - ++ lib.optionals withQt5 [ - "--with-qt5" - "--with-qt5-immodule" - ] - ++ lib.optional withLibnotify "--enable-notify=libnotify" - ++ lib.optional withSqlite "--with-sqlite3" - ++ lib.optionals withNetworking [ - "--with-curl" - "--with-openssl-dir=${openssl.dev}" - ] - ++ lib.optional withFFI "--with-ffi" - ++ lib.optional withMisc "--with-eb"; + configureFlags = + [ + # configure in maintainer mode or else some pixmaps won't get autogenerated + # this should imply the above `--enable-maintainer-mode`, but it does not + "--enable-maintainer-mode" + + "--enable-pref" + "--with-skk" + "--with-x" + "--with-xft" + "--with-expat=${expat.dev}" + ] + ++ lib.optional withAnthy "--with-anthy-utf8" + ++ lib.optional withGtk2 "--with-gtk2" + ++ lib.optional withGtk3 "--with-gtk3" + ++ lib.optionals withQt5 [ + "--with-qt5" + "--with-qt5-immodule" + ] + ++ lib.optional withLibnotify "--enable-notify=libnotify" + ++ lib.optional withSqlite "--with-sqlite3" + ++ lib.optionals withNetworking [ + "--with-curl" + "--with-openssl-dir=${openssl.dev}" + ] + ++ lib.optional withFFI "--with-ffi" + ++ lib.optional withMisc "--with-eb"; # TODO: things in `./configure --help`, but not in nixpkgs #--with-canna Use Canna [default=no] @@ -139,10 +179,13 @@ stdenv.mkDerivation rec { dontUseCmakeConfigure = true; meta = with lib; { - homepage = src.meta.homepage; + homepage = src.meta.homepage; description = "Multilingual input method framework"; - license = licenses.bsd3; - platforms = platforms.unix; - maintainers = with maintainers; [ ericsagnes oxij ]; + license = licenses.bsd3; + platforms = platforms.unix; + maintainers = with maintainers; [ + ericsagnes + oxij + ]; }; } diff --git a/pkgs/tools/misc/3llo/default.nix b/pkgs/tools/misc/3llo/default.nix index b095cee4d7958a..45c1e633d050f5 100644 --- a/pkgs/tools/misc/3llo/default.nix +++ b/pkgs/tools/misc/3llo/default.nix @@ -3,7 +3,7 @@ bundlerApp { pname = "3llo"; - gemdir = ./.; + gemdir = ./.; exes = [ "3llo" ]; diff --git a/pkgs/tools/misc/3llo/gemset.nix b/pkgs/tools/misc/3llo/gemset.nix index 4de7651dbce09b..dc13928c4b9dc7 100644 --- a/pkgs/tools/misc/3llo/gemset.nix +++ b/pkgs/tools/misc/3llo/gemset.nix @@ -1,83 +1,90 @@ { "3llo" = { - dependencies = ["tty-prompt"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-prompt" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1w327skga2lpq9rbqqxy6w1r6k9k1l8prk5wmzrycvydn1wp7jk2"; type = "gem"; }; version = "1.3.1"; }; pastel = { - dependencies = ["tty-color"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-color" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xash2gj08dfjvq4hy6l1z22s5v30fhizwgs10d6nviggpxsj7a8"; type = "gem"; }; version = "0.8.0"; }; tty-color = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0aik4kmhwwrmkysha7qibi2nyzb4c8kp42bd5vxnf8sf7b53g73g"; type = "gem"; }; version = "0.6.0"; }; tty-cursor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j5zw041jgkmn605ya1zc151bxgxl6v192v2i26qhxx7ws2l2lvr"; type = "gem"; }; version = "0.7.1"; }; tty-prompt = { - dependencies = ["pastel" "tty-reader"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "pastel" + "tty-reader" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j4y8ik82azjxshgd4i1v4wwhsv3g9cngpygxqkkz69qaa8cxnzw"; type = "gem"; }; version = "0.23.1"; }; tty-reader = { - dependencies = ["tty-cursor" "tty-screen" "wisper"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "tty-cursor" + "tty-screen" + "wisper" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cf2k7w7d84hshg4kzrjvk9pkyc2g1m3nx2n1rpmdcf0hp4p4af6"; type = "gem"; }; version = "0.9.0"; }; tty-screen = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18jr6s1cg8yb26wzkqa6874q0z93rq0y5aw092kdqazk71y6a235"; type = "gem"; }; version = "0.8.1"; }; wisper = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rpsi0ziy78cj82sbyyywby4d0aw0a5q84v65qd28vqn79fbq5yf"; type = "gem"; }; diff --git a/pkgs/tools/misc/android-tools/default.nix b/pkgs/tools/misc/android-tools/default.nix index efc5a95e7bdecf..95af0ed528ce58 100644 --- a/pkgs/tools/misc/android-tools/default.nix +++ b/pkgs/tools/misc/android-tools/default.nix @@ -1,10 +1,25 @@ -{ lib, stdenv, fetchurl -, cmake, ninja, pkg-config, perl, go, python3 -, protobuf, zlib, gtest, brotli, lz4, zstd, libusb1, pcre2 +{ + lib, + stdenv, + fetchurl, + cmake, + ninja, + pkg-config, + perl, + go, + python3, + protobuf, + zlib, + gtest, + brotli, + lz4, + zstd, + libusb1, + pcre2, }: let - pythonEnv = python3.withPackages(ps: [ ps.protobuf ]); + pythonEnv = python3.withPackages (ps: [ ps.protobuf ]); in stdenv.mkDerivation rec { @@ -16,8 +31,23 @@ stdenv.mkDerivation rec { hash = "sha256-ZUAwx/ltJdciTNaGH6wUoEPPHTmA9AKIzfviGflP+vk="; }; - nativeBuildInputs = [ cmake ninja pkg-config perl go ]; - buildInputs = [ protobuf zlib gtest brotli lz4 zstd libusb1 pcre2 ]; + nativeBuildInputs = [ + cmake + ninja + pkg-config + perl + go + ]; + buildInputs = [ + protobuf + zlib + gtest + brotli + lz4 + zstd + libusb1 + pcre2 + ]; propagatedBuildInputs = [ pythonEnv ]; preConfigure = '' @@ -44,7 +74,10 @@ stdenv.mkDerivation rec { # https://developer.android.com/studio/command-line#tools-platform # https://developer.android.com/studio/releases/platform-tools homepage = "https://github.com/nmeum/android-tools"; - license = with licenses; [ asl20 unicode-dfs-2015 ]; + license = with licenses; [ + asl20 + unicode-dfs-2015 + ]; platforms = platforms.unix; maintainers = with maintainers; [ primeos ]; }; diff --git a/pkgs/tools/misc/antimicrox/default.nix b/pkgs/tools/misc/antimicrox/default.nix index 4064c76cd0e81d..76ea224f19d735 100644 --- a/pkgs/tools/misc/antimicrox/default.nix +++ b/pkgs/tools/misc/antimicrox/default.nix @@ -1,13 +1,14 @@ -{ mkDerivation -, lib -, cmake -, extra-cmake-modules -, pkg-config -, SDL2 -, qttools -, xorg -, fetchFromGitHub -, itstool +{ + mkDerivation, + lib, + cmake, + extra-cmake-modules, + pkg-config, + SDL2, + qttools, + xorg, + fetchFromGitHub, + itstool, }: mkDerivation rec { @@ -21,7 +22,12 @@ mkDerivation rec { sha256 = "sha256-9vpkhs3zEOZa3LnyIqdW0U+nS/9t4HzMLzFqrB2TqI8="; }; - nativeBuildInputs = [ cmake extra-cmake-modules pkg-config itstool ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + pkg-config + itstool + ]; buildInputs = [ SDL2 qttools diff --git a/pkgs/tools/misc/anystyle-cli/default.nix b/pkgs/tools/misc/anystyle-cli/default.nix index beebae6542b975..19379ae96ffed3 100644 --- a/pkgs/tools/misc/anystyle-cli/default.nix +++ b/pkgs/tools/misc/anystyle-cli/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildRubyGem -, bundlerEnv -, ruby -, poppler_utils +{ + lib, + buildRubyGem, + bundlerEnv, + ruby, + poppler_utils, }: let deps = bundlerEnv rec { @@ -13,7 +14,7 @@ let gemdir = ./.; gemset = lib.recursiveUpdate (import ./gemset.nix) { anystyle.source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1w79zcia60nnnyrmyvpd10pmxrpk5c7lj9gmmblhwi8x5mfq9k0n"; type = "gem"; }; @@ -35,10 +36,10 @@ buildRubyGem rec { meta = with lib; { description = "Command line interface to the AnyStyle Parser and Finder"; - homepage = "https://anystyle.io/"; - license = licenses.bsd2; + homepage = "https://anystyle.io/"; + license = licenses.bsd2; maintainers = with maintainers; [ shamilton ]; mainProgram = "anystyle"; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/tools/misc/anystyle-cli/gemset.nix b/pkgs/tools/misc/anystyle-cli/gemset.nix index 46444760b7bd80..9d3377022144ab 100644 --- a/pkgs/tools/misc/anystyle-cli/gemset.nix +++ b/pkgs/tools/misc/anystyle-cli/gemset.nix @@ -1,168 +1,237 @@ { activesupport = { - dependencies = ["concurrent-ruby" "i18n" "minitest" "tzinfo" "zeitwerk"]; - groups = ["default" "development" "test"]; - platforms = []; + dependencies = [ + "concurrent-ruby" + "i18n" + "minitest" + "tzinfo" + "zeitwerk" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02sh4q8izyfdnh7z2nj5mn5sklfvqgx9rrag5j3l51y8aqkrg2yk"; type = "gem"; }; version = "6.0.3.2"; }; anystyle = { - dependencies = ["anystyle-data" "bibtex-ruby" "gli" "namae" "wapiti"]; - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + dependencies = [ + "anystyle-data" + "bibtex-ruby" + "gli" + "namae" + "wapiti" + ]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { path = ./.; type = "path"; @@ -170,728 +239,968 @@ version = "1.3.10"; }; anystyle-data = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ry6836mq48d85hjcfp7xiw0yk3ivpiwjvmdwv5jag30ijfyaccy"; type = "gem"; }; version = "1.2.0"; }; bibtex-ruby = { - dependencies = ["latex-decode"]; - groups = ["default" "development" "test"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + dependencies = [ "latex-decode" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00zwmmmjrbrxhajdvn1d4rnv2qw00arcj021cwyx3hl6dsv22l2w"; type = "gem"; }; version = "5.1.4"; }; builder = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "045wzckxpwcqzrjr353cxnyaxgf0qg22jh00dcx7z38cys5g1jlr"; type = "gem"; }; version = "3.2.4"; }; byebug = { - groups = ["debug"]; - platforms = []; + groups = [ "debug" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nx3yjf4xzdgb8jkmk2344081gqr22pgjqnmjg2q64mj5d6r9194"; type = "gem"; }; version = "11.1.3"; }; citeproc = { - dependencies = ["namae"]; - groups = ["development" "test"]; - platforms = []; + dependencies = [ "namae" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13vl5sjmksk5a8kjcqnjxh7kn9gn1n4f9p1rvqfgsfhs54p0m6l2"; type = "gem"; }; version = "1.0.10"; }; concurrent-ruby = { - groups = ["default" "development" "test"]; - platforms = []; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vnxrbhi7cq3p4y2v9iwd10v1c7l15is4var14hwnb2jip4fyjzz"; type = "gem"; }; version = "1.1.7"; }; diff-lcs = { - groups = ["default" "development" "test"]; - platforms = []; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0m925b8xc6kbpnif9dldna24q1szg4mk0fvszrki837pfn46afmz"; type = "gem"; }; version = "1.4.4"; }; docile = { - groups = ["coverage" "default"]; - platforms = []; + groups = [ + "coverage" + "default" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qrwiyagxzl8zlx3dafb0ay8l14ib7imb2rsmx70i5cp420v8gif"; type = "gem"; }; version = "1.3.2"; }; edtf = { - dependencies = ["activesupport"]; - groups = ["development" "test"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xknzamagsx68iq7zdiswr077sxirig77yggbcsw51m8365ajzpc"; type = "gem"; }; version = "3.0.5"; }; gli = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0q598mvl20isn3ja1ya0p72svmqwx3m6fjp5slnv0b2c5mh0ahvv"; type = "gem"; }; version = "2.19.2"; }; gnuplot = { - groups = ["profile"]; - platforms = []; + groups = [ "profile" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cvb84lahhy6qxkkgg0pfk9b85qrb1by2p3jlpqgczl6am58vhnj"; type = "gem"; }; version = "2.6.2"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default" "development" "test"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "153sx77p16vawrs4qpkv7qlzf9v5fks4g7xqcj1dwk40i6g7rfzk"; type = "gem"; }; version = "1.8.5"; }; language_detector = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { fetchSubmodules = false; rev = "89102790194150b3a8110ce691f9989b8ce70f8d"; @@ -902,669 +1211,892 @@ version = "0.1.2"; }; latex-decode = { - groups = ["default" "development" "test"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dqanr69as05vdyp9gx9737w3g44rhyk7x96bh9x01fnf1yalyzd"; type = "gem"; }; version = "0.3.1"; }; lmdb = { - groups = ["extra"]; - platforms = []; + groups = [ "extra" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qk2ycgyyk052dvbgik35mr4n9im4k1j6v7anbjqhx52y5f07sfg"; type = "gem"; }; version = "0.5.3"; }; minitest = { - groups = ["default" "development" "test"]; - platforms = []; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09bz9nsznxgaf06cx3b5z71glgl0hdw469gqx3w7bqijgrb55p5g"; type = "gem"; }; version = "5.14.1"; }; namae = { - groups = ["default" "development" "test"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00w0dgvmdy8lw2b5q9zvhqd5k98a192vdmka96qngi9cvnsh5snw"; type = "gem"; }; version = "1.0.1"; }; rake = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0w6qza25bq1s825faaglkx1k6d59aiyjjk3yw3ip5sb463mhhai9"; type = "gem"; }; version = "13.0.1"; }; redis = { - groups = ["extra"]; - platforms = []; + groups = [ "extra" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19hm66kw5vx1lmlh8bj7rxlddyj0vfp11ajw9njhrmn8173d0vb5"; type = "gem"; }; version = "4.2.1"; }; redis-namespace = { - dependencies = ["redis"]; - groups = ["extra"]; - platforms = []; + dependencies = [ "redis" ]; + groups = [ "extra" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05i6s898z5w31z385cba1683pgg5nnmj4m686cbravg7j4pgbcgv"; type = "gem"; }; version = "1.8.0"; }; rspec = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks"]; - groups = ["development" "test"]; - platforms = []; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + ]; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1hzsig4pi9ybr0xl5540m1swiyxa74c8h09225y5sdh2rjkkg84h"; type = "gem"; }; version = "3.9.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default" "development" "test"]; - platforms = []; + dependencies = [ "rspec-support" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xndkv5cz763wh30x7hdqw6k7zs8xfh0f86amra9agwn44pcqs0y"; type = "gem"; }; version = "3.9.2"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "development" "test"]; - platforms = []; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bxkv25qmy39jqrdx35bfgw00g24qkssail9jlljm7hywbqvr9bb"; type = "gem"; }; version = "3.9.2"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default" "development" "test"]; - platforms = []; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19vmdqym1v2g1zbdnq37zwmyj87y9yc9ijwc8js55igvbb9hx0mr"; type = "gem"; }; version = "3.9.1"; }; rspec-support = { - groups = ["default" "development" "test"]; - platforms = []; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dandh2fy1dfkjk8jf9v4azbbma6968bhh06hddv0yqqm8108jir"; type = "gem"; }; version = "3.9.3"; }; ruby-prof = { - groups = ["profile"]; - platforms = []; + groups = [ "profile" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12cd91m08ih0imfpy4k87618hd4mhyz291a6bx2hcskza4nf6d27"; type = "gem"; }; version = "1.4.1"; }; simplecov = { - dependencies = ["docile" "simplecov-html"]; - groups = ["coverage"]; - platforms = []; + dependencies = [ + "docile" + "simplecov-html" + ]; + groups = [ "coverage" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1b082xrklq6k755cc3rzpnfdjv5338rlky9him36jasw8s9q68mr"; type = "gem"; }; version = "0.19.0"; }; simplecov-html = { - groups = ["coverage" "default"]; - platforms = []; + groups = [ + "coverage" + "default" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1v7b4mf7njw8kv4ghl4q7mwz3q0flbld7v8blp4m4m3n3aq11bn9"; type = "gem"; }; version = "0.12.2"; }; thread_safe = { - groups = ["default" "development" "test"]; - platforms = []; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nmhcgq6cgz44srylra07bmaw99f5271l0dpsvl5f75m44l0gmwy"; type = "gem"; }; version = "0.3.6"; }; tzinfo = { - dependencies = ["thread_safe"]; - groups = ["default" "development" "test"]; - platforms = []; + dependencies = [ "thread_safe" ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1i3jh086w1kbdj3k5l60lc3nwbanmzdf8yjj3mlrx9b2gjjxhi9r"; type = "gem"; }; version = "1.2.7"; }; unicode-scripts = { - groups = ["development" "test"]; - platforms = []; + groups = [ + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04xfy4f61xf7qnbfa68aqscmyxk7wx3swn571cijsfqalhz8swjg"; type = "gem"; }; version = "1.6.0"; }; wapiti = { - dependencies = ["builder"]; - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + dependencies = [ "builder" ]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1aw2l759cfmii9a67pn8pswip11v08nabkzm825mrmxa6r91izqs"; type = "gem"; }; version = "1.0.7"; }; yard = { - groups = ["extra"]; - platforms = []; + groups = [ "extra" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "126m49mvh4lbvlvrprq7xj2vjixbq3xqr8dwr089vadvs0rkn4rd"; type = "gem"; }; version = "0.9.25"; }; zeitwerk = { - groups = ["default" "development" "test"]; - platforms = []; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jvn50k76kl14fpymk4hdsf9sk00jl84yxzl783xhnw4dicp0m0k"; type = "gem"; }; version = "2.4.0"; }; } - diff --git a/pkgs/tools/misc/aoc-cli/default.nix b/pkgs/tools/misc/aoc-cli/default.nix index 693f87389e1bae..6f4cdad5240e0a 100644 --- a/pkgs/tools/misc/aoc-cli/default.nix +++ b/pkgs/tools/misc/aoc-cli/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + Security, }: rustPlatform.buildRustPackage rec { @@ -20,8 +21,7 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optional stdenv.hostPlatform.isDarwin Security; + buildInputs = [ openssl ] ++ lib.optional stdenv.hostPlatform.isDarwin Security; cargoHash = "sha256-EluP4N3UBQeEKVdHTs4O0THXji+nAyE52nGKsxA3AA4="; diff --git a/pkgs/tools/misc/apkeep/default.nix b/pkgs/tools/misc/apkeep/default.nix index e3969844d8ac08..11f12b294415bd 100644 --- a/pkgs/tools/misc/apkeep/default.nix +++ b/pkgs/tools/misc/apkeep/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchCrate -, rustPlatform -, openssl -, pkg-config -, Security -, SystemConfiguration +{ + lib, + stdenv, + fetchCrate, + rustPlatform, + openssl, + pkg-config, + Security, + SystemConfiguration, }: rustPlatform.buildRustPackage rec { @@ -27,12 +28,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + ]; meta = with lib; { description = "Command-line tool for downloading APK files from various sources"; diff --git a/pkgs/tools/misc/asciinema-agg/default.nix b/pkgs/tools/misc/asciinema-agg/default.nix index e7f7334de3e03c..a053b7c191ed0e 100644 --- a/pkgs/tools/misc/asciinema-agg/default.nix +++ b/pkgs/tools/misc/asciinema-agg/default.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, stdenv, Security }: +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + Security, +}: rustPlatform.buildRustPackage rec { pname = "agg"; diff --git a/pkgs/tools/misc/bat-extras/default.nix b/pkgs/tools/misc/bat-extras/default.nix index 0891499b226118..fa2dd823ec8bde 100644 --- a/pkgs/tools/misc/bat-extras/default.nix +++ b/pkgs/tools/misc/bat-extras/default.nix @@ -1,40 +1,51 @@ -{ lib, stdenv, fetchFromGitHub, makeWrapper, bat -# batdiff, batgrep, and batwatch -, coreutils -, getconf -, less -# tests -, bash -, zsh -, fish -# batgrep -, ripgrep -# prettybat -, withShFmt ? shfmt != null, shfmt ? null -, withPrettier ? nodePackages?prettier, nodePackages ? null -, withClangTools ? clang-tools != null, clang-tools ? null -, withRustFmt ? rustfmt != null, rustfmt ? null -# batwatch -, withEntr ? entr != null, entr ? null -# batdiff -, gitMinimal -, withDelta ? delta != null, delta ? null -# batman -, util-linux +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + bat, + # batdiff, batgrep, and batwatch + coreutils, + getconf, + less, + # tests + bash, + zsh, + fish, + # batgrep + ripgrep, + # prettybat + withShFmt ? shfmt != null, + shfmt ? null, + withPrettier ? nodePackages ? prettier, + nodePackages ? null, + withClangTools ? clang-tools != null, + clang-tools ? null, + withRustFmt ? rustfmt != null, + rustfmt ? null, + # batwatch + withEntr ? entr != null, + entr ? null, + # batdiff + gitMinimal, + withDelta ? delta != null, + delta ? null, + # batman + util-linux, }: let # Core derivation that all the others are based on. # This includes the complete source so the per-script derivations can run the tests. core = stdenv.mkDerivation rec { - pname = "bat-extras"; + pname = "bat-extras"; version = "2024.07.10"; src = fetchFromGitHub { - owner = "eth-p"; - repo = "bat-extras"; - rev = "v${version}"; - hash = "sha256-6IRAKSy5f/WcQZBcJKVSweTjHLznzdxhsyx074bXnUQ="; + owner = "eth-p"; + repo = "bat-extras"; + rev = "v${version}"; + hash = "sha256-6IRAKSy5f/WcQZBcJKVSweTjHLznzdxhsyx074bXnUQ="; fetchSubmodules = true; }; @@ -55,7 +66,11 @@ let # Run the library tests as they don't have external dependencies doCheck = true; - nativeCheckInputs = [ bash fish zsh ] ++ (lib.optionals stdenv.hostPlatform.isDarwin [ getconf ]); + nativeCheckInputs = [ + bash + fish + zsh + ] ++ (lib.optionals stdenv.hostPlatform.isDarwin [ getconf ]); checkPhase = '' runHook preCheck # test list repeats suites. Unique them @@ -84,10 +99,10 @@ let meta = with lib; { description = "Bash scripts that integrate bat with various command line tools"; - homepage = "https://github.com/eth-p/bat-extras"; - license = with licenses; [ mit ]; + homepage = "https://github.com/eth-p/bat-extras"; + license = with licenses; [ mit ]; maintainers = with maintainers; [ bbigras ]; - platforms = platforms.all; + platforms = platforms.all; }; }; script = @@ -112,23 +127,31 @@ let dontBuild = true; # we've already built doCheck = true; - nativeCheckInputs = [ bat bash fish zsh ] ++ (lib.optionals stdenv.hostPlatform.isDarwin [ getconf ]); + nativeCheckInputs = [ + bat + bash + fish + zsh + ] ++ (lib.optionals stdenv.hostPlatform.isDarwin [ getconf ]); checkPhase = '' runHook preCheck bash ./test.sh --compiled --suite ${name} runHook postCheck ''; - installPhase = '' - runHook preInstall - mkdir -p $out/bin - cp -p bin/${name} $out/bin/${name} - '' + lib.optionalString (dependencies != []) '' - wrapProgram $out/bin/${name} \ - --prefix PATH : ${lib.makeBinPath dependencies} - '' + '' - runHook postInstall - ''; + installPhase = + '' + runHook preInstall + mkdir -p $out/bin + cp -p bin/${name} $out/bin/${name} + '' + + lib.optionalString (dependencies != [ ]) '' + wrapProgram $out/bin/${name} \ + --prefix PATH : ${lib.makeBinPath dependencies} + '' + + '' + runHook postInstall + ''; # We already patched dontPatchShebangs = true; @@ -137,19 +160,39 @@ let mainProgram = name; }; }; - optionalDep = cond: dep: + optionalDep = + cond: dep: assert cond -> dep != null; lib.optional cond dep; in { - batdiff = script "batdiff" ([ less coreutils gitMinimal ] ++ optionalDep withDelta delta); - batgrep = script "batgrep" [ less coreutils ripgrep ]; + batdiff = script "batdiff" ( + [ + less + coreutils + gitMinimal + ] + ++ optionalDep withDelta delta + ); + batgrep = script "batgrep" [ + less + coreutils + ripgrep + ]; batman = script "batman" (lib.optionals stdenv.hostPlatform.isLinux [ util-linux ]); batpipe = script "batpipe" [ less ]; - batwatch = script "batwatch" ([ less coreutils ] ++ optionalDep withEntr entr); - prettybat = script "prettybat" ([] + batwatch = script "batwatch" ( + [ + less + coreutils + ] + ++ optionalDep withEntr entr + ); + prettybat = script "prettybat" ( + [ ] ++ optionalDep withShFmt shfmt ++ optionalDep withPrettier nodePackages.prettier ++ optionalDep withClangTools clang-tools - ++ optionalDep withRustFmt rustfmt); + ++ optionalDep withRustFmt rustfmt + ); } diff --git a/pkgs/tools/misc/birdfont/default.nix b/pkgs/tools/misc/birdfont/default.nix index 866d56b156ea07..5581175a658388 100644 --- a/pkgs/tools/misc/birdfont/default.nix +++ b/pkgs/tools/misc/birdfont/default.nix @@ -1,6 +1,24 @@ -{ lib, stdenv, fetchurl, pkg-config, python3, xmlbird, -cairo, gdk-pixbuf, libgee, glib, gtk3, webkitgtk_4_0, libnotify, sqlite, vala, -gobject-introspection, gsettings-desktop-schemas, wrapGAppsHook3, autoPatchelfHook }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + python3, + xmlbird, + cairo, + gdk-pixbuf, + libgee, + glib, + gtk3, + webkitgtk_4_0, + libnotify, + sqlite, + vala, + gobject-introspection, + gsettings-desktop-schemas, + wrapGAppsHook3, + autoPatchelfHook, +}: stdenv.mkDerivation rec { pname = "birdfont"; @@ -11,8 +29,26 @@ stdenv.mkDerivation rec { sha256 = "sha256-NNw7203BtHhNyyQezb3/EP98cTsu7ABDFBnM5Ms2ePY="; }; - nativeBuildInputs = [ python3 pkg-config vala gobject-introspection wrapGAppsHook3 autoPatchelfHook ]; - buildInputs = [ xmlbird libgee cairo gdk-pixbuf glib gtk3 webkitgtk_4_0 libnotify sqlite gsettings-desktop-schemas ]; + nativeBuildInputs = [ + python3 + pkg-config + vala + gobject-introspection + wrapGAppsHook3 + autoPatchelfHook + ]; + buildInputs = [ + xmlbird + libgee + cairo + gdk-pixbuf + glib + gtk3 + webkitgtk_4_0 + libnotify + sqlite + gsettings-desktop-schemas + ]; postPatch = '' substituteInPlace install.py \ diff --git a/pkgs/tools/misc/birdfont/xmlbird.nix b/pkgs/tools/misc/birdfont/xmlbird.nix index 2fbdbcf777a5bb..edfe0c80dda8b3 100644 --- a/pkgs/tools/misc/birdfont/xmlbird.nix +++ b/pkgs/tools/misc/birdfont/xmlbird.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, python3, pkg-config, vala, glib, gobject-introspection }: +{ + lib, + stdenv, + fetchurl, + python3, + pkg-config, + vala, + glib, + gobject-introspection, +}: stdenv.mkDerivation rec { pname = "xmlbird"; @@ -9,7 +18,12 @@ stdenv.mkDerivation rec { sha256 = "sha256-8GX4ijF+AxaGGFlSxRPOAoUezRG6592jOrifz/mWTRM="; }; - nativeBuildInputs = [ python3 pkg-config vala gobject-introspection ]; + nativeBuildInputs = [ + python3 + pkg-config + vala + gobject-introspection + ]; buildInputs = [ glib ]; diff --git a/pkgs/tools/misc/brotab/default.nix b/pkgs/tools/misc/brotab/default.nix index 9a58c83ae3030d..8fe0143d92582a 100644 --- a/pkgs/tools/misc/brotab/default.nix +++ b/pkgs/tools/misc/brotab/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, fetchpatch, python }: +{ + lib, + fetchFromGitHub, + fetchpatch, + python, +}: python.pkgs.buildPythonApplication rec { pname = "brotab"; diff --git a/pkgs/tools/misc/chafa/default.nix b/pkgs/tools/misc/chafa/default.nix index 334d970ce05cf8..23954dc6759668 100644 --- a/pkgs/tools/misc/chafa/default.nix +++ b/pkgs/tools/misc/chafa/default.nix @@ -1,6 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libtool, pkg-config, which -, libxslt, libxml2, docbook_xml_dtd_412, docbook_xsl, glib, imagemagick -, Foundation +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + pkg-config, + which, + libxslt, + libxml2, + docbook_xml_dtd_412, + docbook_xsl, + glib, + imagemagick, + Foundation, }: stdenv.mkDerivation rec { @@ -14,19 +27,22 @@ stdenv.mkDerivation rec { sha256 = "sha256-9RkN0yZnHf5cx6tsp3P6jsi0/xtplWxMm3hYCPjWj0M="; }; - nativeBuildInputs = [ autoconf - automake - libtool - pkg-config - which - libxslt - libxml2 - docbook_xml_dtd_412 - docbook_xsl - ]; + nativeBuildInputs = [ + autoconf + automake + libtool + pkg-config + which + libxslt + libxml2 + docbook_xml_dtd_412 + docbook_xsl + ]; - buildInputs = [ glib imagemagick ] - ++ lib.optional stdenv.hostPlatform.isDarwin Foundation; + buildInputs = [ + glib + imagemagick + ] ++ lib.optional stdenv.hostPlatform.isDarwin Foundation; patches = [ ./xmlcatalog_patch.patch ]; @@ -35,9 +51,10 @@ stdenv.mkDerivation rec { NOCONFIGURE=1 ./autogen.sh ''; - configureFlags = [ "--enable-man" - "--with-xml-catalog=${docbook_xml_dtd_412}/xml/dtd/docbook/catalog.xml" - ]; + configureFlags = [ + "--enable-man" + "--with-xml-catalog=${docbook_xml_dtd_412}/xml/dtd/docbook/catalog.xml" + ]; # https://github.com/NixOS/nixpkgs/pull/240893#issuecomment-1635347507 NIX_LDFLAGS = [ "-lwebp" ]; diff --git a/pkgs/tools/misc/chef-cli/default.nix b/pkgs/tools/misc/chef-cli/default.nix index 01a80de2795683..dd273aff3d7f85 100644 --- a/pkgs/tools/misc/chef-cli/default.nix +++ b/pkgs/tools/misc/chef-cli/default.nix @@ -1,11 +1,16 @@ -{ lib, ruby, bundlerApp, bundlerUpdateScript }: +{ + lib, + ruby, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "chef-cli"; gemdir = ./.; inherit ruby; - exes = ["chef-cli"]; + exes = [ "chef-cli" ]; passthru.updateScript = bundlerUpdateScript "chef-cli"; diff --git a/pkgs/tools/misc/chef-cli/gemset.nix b/pkgs/tools/misc/chef-cli/gemset.nix index 7a99b18512451c..31218a3f6a7c42 100644 --- a/pkgs/tools/misc/chef-cli/gemset.nix +++ b/pkgs/tools/misc/chef-cli/gemset.nix @@ -1,1127 +1,1324 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15s8van7r2ad3dq6i03l3z4hqnvxcq75a3h72kxvf9an53sqma20"; type = "gem"; }; version = "2.8.4"; }; aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pyis1nvnbjxk12a43xvgj2gv0mvp4cnkc1gzw0v1018r61399gz"; type = "gem"; }; version = "1.2.0"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12n41py8jfxf9p3gy62ikw8n7wd0cmczk3i2fzxb4ms2xvkxv7b0"; type = "gem"; }; version = "1.749.0"; }; aws-sdk-core = { - dependencies = ["aws-eventstream" "aws-partitions" "aws-sigv4" "jmespath"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-eventstream" + "aws-partitions" + "aws-sigv4" + "jmespath" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0732vv8zi67z25fss1sdvqx0vv1ap3w6hz1avxzwznkjp002vj39"; type = "gem"; }; version = "3.171.0"; }; aws-sdk-kms = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0v87zi28dfmrv7bv91yfldccnpd63n295siirbz7wqv1rajn8n02"; type = "gem"; }; version = "1.63.0"; }; aws-sdk-s3 = { - dependencies = ["aws-sdk-core" "aws-sdk-kms" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sdk-kms" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1mapdzm97rv22pca1hvvshwsafa12gd2yv2fcy63dfjn5vjjq893"; type = "gem"; }; version = "1.120.1"; }; aws-sdk-secretsmanager = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1907wr02afyq7vaig3hc858bipz9nmgf3aqb6kpbpxzf0qirf476"; type = "gem"; }; version = "1.73.0"; }; aws-sigv4 = { - dependencies = ["aws-eventstream"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-eventstream" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11hkna2av47bl0yprgp8k4ya70rc3m2ib5w10fn0piplgkkmhz7m"; type = "gem"; }; version = "1.5.2"; }; builder = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "045wzckxpwcqzrjr353cxnyaxgf0qg22jh00dcx7z38cys5g1jlr"; type = "gem"; }; version = "3.2.4"; }; chef = { - dependencies = ["addressable" "aws-sdk-s3" "aws-sdk-secretsmanager" "chef-config" "chef-utils" "chef-vault" "chef-zero" "corefoundation" "diff-lcs" "erubis" "ffi" "ffi-libarchive" "ffi-yajl" "iniparse" "inspec-core" "license-acceptance" "mixlib-archive" "mixlib-authentication" "mixlib-cli" "mixlib-log" "mixlib-shellout" "net-sftp" "ohai" "plist" "proxifier" "syslog-logger" "train-core" "train-winrm" "uuidtools" "vault"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "aws-sdk-s3" + "aws-sdk-secretsmanager" + "chef-config" + "chef-utils" + "chef-vault" + "chef-zero" + "corefoundation" + "diff-lcs" + "erubis" + "ffi" + "ffi-libarchive" + "ffi-yajl" + "iniparse" + "inspec-core" + "license-acceptance" + "mixlib-archive" + "mixlib-authentication" + "mixlib-cli" + "mixlib-log" + "mixlib-shellout" + "net-sftp" + "ohai" + "plist" + "proxifier" + "syslog-logger" + "train-core" + "train-winrm" + "uuidtools" + "vault" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00vh6hrmglq4vfi5qvv42d9qhygnc5dfz32hrr07v7vbyhbqw8ck"; type = "gem"; }; version = "17.10.0"; }; chef-cli = { - dependencies = ["addressable" "chef" "cookbook-omnifetch" "diff-lcs" "ffi-yajl" "license-acceptance" "minitar" "mixlib-cli" "mixlib-shellout" "pastel" "solve"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "chef" + "cookbook-omnifetch" + "diff-lcs" + "ffi-yajl" + "license-acceptance" + "minitar" + "mixlib-cli" + "mixlib-shellout" + "pastel" + "solve" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1r6ig76j2gf9cc6hq1g9bpcyrv2dqki0x51ajsy0spyiinkfnvpx"; type = "gem"; }; version = "5.6.8"; }; chef-config = { - dependencies = ["addressable" "chef-utils" "fuzzyurl" "mixlib-config" "mixlib-shellout" "tomlrb"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "chef-utils" + "fuzzyurl" + "mixlib-config" + "mixlib-shellout" + "tomlrb" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0z72pwfb9n9zwjlk5g9mcy0jlmbq5f8mx60973k7fznif5k6zyrd"; type = "gem"; }; version = "17.10.0"; }; chef-telemetry = { - dependencies = ["chef-config" "concurrent-ruby"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "chef-config" + "concurrent-ruby" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0l9icc3nfdj28mip85vf31v5l60qsfqq3a5dscv7jryh1k94y05x"; type = "gem"; }; version = "1.1.1"; }; chef-utils = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1aq212rz8lzv3rxdsgqgmn8ryy168cz3fxminwg5gm1qw1hnjp5m"; type = "gem"; }; version = "17.10.0"; }; chef-vault = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1hnvngygbdpvpflls3png2312y1svh6k9wj7g5i084q4p72qv22i"; type = "gem"; }; version = "4.1.11"; }; chef-zero = { - dependencies = ["ffi-yajl" "hashie" "mixlib-log" "rack" "uuidtools" "webrick"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ffi-yajl" + "hashie" + "mixlib-log" + "rack" + "uuidtools" + "webrick" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1l20bljvh0imfraxx3mbq08sf9rwxkbl7rl9rsjzfynz53ch2sv5"; type = "gem"; }; version = "15.0.11"; }; coderay = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jvxqxzply1lwp7ysn94zjhh57vc14mcshw1ygw14ib8lhc00lyw"; type = "gem"; }; version = "1.1.3"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0krcwb6mn0iklajwngwsg850nk8k9b35dhmc2qkbdqvmifdi2y9q"; type = "gem"; }; version = "1.2.2"; }; cookbook-omnifetch = { - dependencies = ["mixlib-archive"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mixlib-archive" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gqh66p6fxg438qpvc67s0y7ji9mvan6layyd7w9ljwva1snvy2n"; type = "gem"; }; version = "0.12.2"; }; corefoundation = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14rgy3d636l9zy7zmw04j7pjkf3bn41vx7kb265l4zhxrik7gh19"; type = "gem"; }; version = "0.3.13"; }; diff-lcs = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18w22bjz424gzafv6nzv98h0aqkwz3d9xhm7cbr1wfbyas8zayza"; type = "gem"; }; version = "1.3"; }; erubi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08s75vs9cxlc4r1q2bjg4br8g9wc5lc5x5vl0vv4zq5ivxsdpgi7"; type = "gem"; }; version = "1.12.0"; }; erubis = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fj827xqjs91yqsydf0zmfyw9p4l2jz5yikg3mppz6d7fi8kyrb3"; type = "gem"; }; version = "2.7.0"; }; faraday = { - dependencies = ["faraday-em_http" "faraday-em_synchrony" "faraday-excon" "faraday-net_http" "faraday-net_http_persistent" "multipart-post" "ruby2_keywords"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-em_http" + "faraday-em_synchrony" + "faraday-excon" + "faraday-net_http" + "faraday-net_http_persistent" + "multipart-post" + "ruby2_keywords" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0zmdsl6n05khwwq8gjssmfca0ifz6q82wwghf1qyzbxxjdna5mly"; type = "gem"; }; version = "1.4.3"; }; faraday-em_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12cnqpbak4vhikrh2cdn94assh3yxza8rq2p9w2j34bqg5q4qgbs"; type = "gem"; }; version = "1.0.0"; }; faraday-em_synchrony = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vgrbhkp83sngv6k4mii9f2s9v5lmp693hylfxp2ssfc60fas3a6"; type = "gem"; }; version = "1.0.0"; }; faraday-excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h09wkb0k0bhm6dqsd47ac601qiaah8qdzjh8gvxfd376x1chmdh"; type = "gem"; }; version = "1.1.0"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fi8sda5hc54v1w3mqfl5yz09nhx35kglyx72w7b8xxvdr0cwi9j"; type = "gem"; }; version = "1.0.1"; }; faraday-net_http_persistent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dc36ih95qw3rlccffcb0vgxjhmipsvxhn6cw71l7ffs0f7vq30b"; type = "gem"; }; version = "1.2.0"; }; faraday_middleware = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bw8mfh4yin2xk7138rg3fhb2p5g2dlmdma88k82psah9mbmvlfy"; type = "gem"; }; version = "1.2.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1862ydmclzy1a0cjbvm8dz7847d9rch495ib0zb64y84d3xd4bkg"; type = "gem"; }; version = "1.15.5"; }; ffi-libarchive = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gyxnsy5fm2pnqph0dhaivmn1pws9xwnb3wjqpx097m06lh1igj1"; type = "gem"; }; version = "1.1.3"; }; ffi-yajl = { - dependencies = ["libyajl2"]; - groups = ["default"]; - platforms = []; + dependencies = [ "libyajl2" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0y2yg9ls3v9rjdq6pmdn57w43xhrf8rrg44s9pfsc2i8jdmmhizz"; type = "gem"; }; version = "2.4.0"; }; fuzzyurl = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03qchs33vfwbsv5awxg3acfmlcrf5xbhnbrc83fdpamwya0glbjl"; type = "gem"; }; version = "0.9.0"; }; gssapi = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qdfhj12aq8v0y961v4xv96a1y2z80h3xhvzrs9vsfgf884g6765"; type = "gem"; }; version = "1.3.1"; }; gyoku = { - dependencies = ["builder" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "builder" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kd2q59xpm39hpvmmvyi6g3f1fr05xjbnxwkrdqz4xy7hirqi79q"; type = "gem"; }; version = "1.4.0"; }; hashie = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02bsx12ihl78x0vdm37byp78jjw2ff6035y7rrmbd90qxjwxr43q"; type = "gem"; }; version = "4.1.0"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; iniparse = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wb1qy4i2xrrd92dc34pi7q7ibrjpapzk9y465v0n9caiplnb89n"; type = "gem"; }; version = "1.5.0"; }; inspec-core = { - dependencies = ["addressable" "chef-telemetry" "faraday" "faraday_middleware" "hashie" "license-acceptance" "method_source" "mixlib-log" "multipart-post" "parallel" "parslet" "pry" "rspec" "rspec-its" "rubyzip" "semverse" "sslshake" "thor" "tomlrb" "train-core" "tty-prompt" "tty-table"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "chef-telemetry" + "faraday" + "faraday_middleware" + "hashie" + "license-acceptance" + "method_source" + "mixlib-log" + "multipart-post" + "parallel" + "parslet" + "pry" + "rspec" + "rspec-its" + "rubyzip" + "semverse" + "sslshake" + "thor" + "tomlrb" + "train-core" + "tty-prompt" + "tty-table" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0mvngxv6v080z8is3clnkdrm499l2syqdd0nhc1gbnq4lwlh6ivy"; type = "gem"; }; version = "4.56.20"; }; ipaddress = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x86s0s11w202j6ka40jbmywkrx8fhq8xiy8mwvnkhllj57hqr45"; type = "gem"; }; version = "0.8.3"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cdw9vw2qly7q7r41s7phnac264rbsdqgj4l0h4nqgbjb157g393"; type = "gem"; }; version = "1.6.2"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nalhin1gda4v8ybk6lq8f407cgfrj6qzn234yra4ipkmlbfmal6"; type = "gem"; }; version = "2.6.3"; }; libyajl2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vx0mv0bbcy0qh3ik08b42vrq4kw1zg51121r18c0vvp4p3zcpda"; type = "gem"; }; version = "2.1.0"; }; license-acceptance = { - dependencies = ["pastel" "tomlrb" "tty-box" "tty-prompt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pastel" + "tomlrb" + "tty-box" + "tty-prompt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "12h5a3j57h50xkfpdz9gr42k0v8g1qxn2pnj5hbbzbmdhydjbjzf"; type = "gem"; }; version = "2.1.13"; }; little-plugger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1frilv82dyxnlg8k1jhrvyd73l6k17mxc5vwxx080r4x1p04gwym"; type = "gem"; }; version = "1.1.4"; }; logging = { - dependencies = ["little-plugger" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "little-plugger" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zflchpx4g8c110gjdcs540bk5a336nq6nmx379rdg56xw0pjd02"; type = "gem"; }; version = "2.3.1"; }; method_source = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pnyh44qycnf9mzi1j6fywd5fkskv3x7nmsqrrws0rjn5dd4ayfp"; type = "gem"; }; version = "1.0.0"; }; minitar = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "126mq86x67d1p63acrfka4zx0cx2r0vc93884jggxnrmmnzbxh13"; type = "gem"; }; version = "0.9"; }; mixlib-archive = { - dependencies = ["mixlib-log"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mixlib-log" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17vw0h8ag45608hvm02g43bkfvqy8l3lwk9lqj7b5kzdw6ynvn6a"; type = "gem"; }; version = "1.1.7"; }; mixlib-authentication = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07m6q8icjjzrv7k2vsjqmviswqv6cigc577hf48liy7b1i4l9gn5"; type = "gem"; }; version = "3.0.10"; }; mixlib-cli = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ydxlfgd7nnj3rp1y70k4yk96xz5cywldjii2zbnw3sq9pippwp6"; type = "gem"; }; version = "2.1.8"; }; mixlib-config = { - dependencies = ["tomlrb"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tomlrb" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j0122lv2qgccl61njqi0pj6sp6nb85y07gcmw16bwg4k0c8nx6p"; type = "gem"; }; version = "3.0.27"; }; mixlib-log = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0n5dm5iz90ijvjn59jfm8gb8hgsvbj0f1kpzbl38b02z0z4a4v7x"; type = "gem"; }; version = "3.0.9"; }; mixlib-shellout = { - dependencies = ["chef-utils"]; - groups = ["default"]; - platforms = []; + dependencies = [ "chef-utils" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zkwg76y96nkh1mv0k92ybq46cr06v1wmic16129ls3yqzwx3xj6"; type = "gem"; }; version = "3.2.7"; }; molinillo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p846facmh1j5xmbrpgzadflspvk7bzs3sykrh5s7qi4cdqz5gzg"; type = "gem"; }; version = "0.8.0"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lgyysrpl50wgcb9ahg29i4p01z0irb3p9lirygma0kkfr5dgk9x"; type = "gem"; }; version = "2.3.0"; }; net-scp = { - dependencies = ["net-ssh"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-ssh" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1si2nq9l6jy5n2zw1q59a5gaji7v9vhy8qx08h4fg368906ysbdk"; type = "gem"; }; version = "4.0.0"; }; net-sftp = { - dependencies = ["net-ssh"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-ssh" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04674g4n6mryjajlcd82af8g8k95la4b1bj712dh71hw1c9vhw1y"; type = "gem"; }; version = "2.1.2"; }; net-ssh = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yx0pb5fmziz92bw8qzbh8vf20lr56nd3s6q8h0gsgr307lki687"; type = "gem"; }; version = "7.1.0"; }; nori = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "066wc774a2zp4vrq3k7k8p0fhv30ymqmxma1jj7yg5735zls8agn"; type = "gem"; }; version = "2.6.0"; }; ohai = { - dependencies = ["chef-config" "chef-utils" "ffi" "ffi-yajl" "ipaddress" "mixlib-cli" "mixlib-config" "mixlib-log" "mixlib-shellout" "plist" "train-core" "wmi-lite"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "chef-config" + "chef-utils" + "ffi" + "ffi-yajl" + "ipaddress" + "mixlib-cli" + "mixlib-config" + "mixlib-log" + "mixlib-shellout" + "plist" + "train-core" + "wmi-lite" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ff5z3nzqk8ry32qiqfrr0zgm5vyaf21sj225faz8wqmxjvklsd2"; type = "gem"; }; version = "17.9.1"; }; parallel = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jcc512l38c0c163ni3jgskvq1vc3mr8ly5pvjijzwvfml9lf597"; type = "gem"; }; version = "1.23.0"; }; parslet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12nrzfwjphjlakb9pmpj70hgjwgzvnr8i1zfzddifgyd44vspl88"; type = "gem"; }; version = "1.8.2"; }; pastel = { - dependencies = ["tty-color"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-color" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xash2gj08dfjvq4hy6l1z22s5v30fhizwgs10d6nviggpxsj7a8"; type = "gem"; }; version = "0.8.0"; }; plist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wzhnbzraz60paxhm48c50fp9xi7cqka4gfhxmiq43mhgh5ajg3h"; type = "gem"; }; version = "3.7.0"; }; proxifier = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1abzlg39cfji1nx3i8kmb5k3anr2rd392yg2icms24wkqz9g9zj0"; type = "gem"; }; version = "1.0.3"; }; pry = { - dependencies = ["coderay" "method_source"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "coderay" + "method_source" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k9kqkd9nps1w1r1rb7wjr31hqzkka2bhi8b518x78dcxppm9zn4"; type = "gem"; }; version = "0.14.2"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hz0bx2qs2pwb0bwazzsah03ilpf3aai8b7lk7s35jsfzwbkjq35"; type = "gem"; }; version = "5.0.1"; }; rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qgwkcb8kxns8d5187cxjaxf18b7dmg9gh6cr9c1125m0bj2pnfk"; type = "gem"; }; version = "2.2.6.4"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08ximcyfjy94pm1rhcx04ny1vx2sk0x4y185gzn86yfsbzwkng53"; type = "gem"; }; version = "3.2.5"; }; rspec = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "19dyb6rcvgi9j2mksd29wfdhfdyzqk7yjhy1ai77559hbhpg61w9"; type = "gem"; }; version = "3.11.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rspec-support" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "118hkfw9b11hvvalr7qlylwal5h8dihagm9xg7k4gskg7587hca6"; type = "gem"; }; version = "3.11.0"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0l1bzk6a68i1b2qix83vs40r0pbjawv67hixiq2qxsja19bbq3bc"; type = "gem"; }; version = "3.11.1"; }; rspec-its = { - dependencies = ["rspec-core" "rspec-expectations"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15zafd70gxly5i0s00nky14sj2n92dnj3xpj83ysl3c2wx0119ad"; type = "gem"; }; version = "1.3.0"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vsqp9dij2rj9aapcn3sz7qzw0d8ln7x9p46h9rzd3jzb7his9kk"; type = "gem"; }; version = "3.11.2"; }; rspec-support = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c01iicvrjk6vv744jgh0y4kk9d0kg2rd2ihdyzvg5p06xm2fpzq"; type = "gem"; }; version = "3.11.1"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; rubyntlm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b8hczk8hysv53ncsqzx4q6kma5gy5lqc7s5yx8h64x3vdb18cjv"; type = "gem"; }; version = "0.6.3"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; semverse = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vrh6p0756n3gjnk6am1cc4kmw6wzzd02hcajj27rlsqg3p6lwn9"; type = "gem"; }; version = "3.0.2"; }; solve = { - dependencies = ["molinillo" "semverse"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "molinillo" + "semverse" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "059lrsf40rl5kclp1w8pb0fzz5sv8aikg073cwcvn5mndk14ayky"; type = "gem"; }; version = "4.0.4"; }; sslshake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0r3ifksx8a05yqhv7nc4cwan8bwmxgq5kyv7q7hy2h9lv5zcjs8h"; type = "gem"; }; version = "1.3.1"; }; strings = { - dependencies = ["strings-ansi" "unicode-display_width" "unicode_utils"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "strings-ansi" + "unicode-display_width" + "unicode_utils" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yynb0qhhhplmpzavfrrlwdnd1rh7rkwzcs4xf0mpy2wr6rr6clk"; type = "gem"; }; version = "0.2.1"; }; strings-ansi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "120wa6yjc63b84lprglc52f40hx3fx920n4dmv14rad41rv2s9lh"; type = "gem"; }; version = "0.2.0"; }; syslog-logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14y20phq1khdla4z9wvf98k7j3x6n0rjgs4f7vb0xlf7h53g6hbm"; type = "gem"; }; version = "1.6.8"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0inl77jh4ia03jw3iqm5ipr76ghal3hyjrd6r8zqsswwvi9j2xdi"; type = "gem"; }; version = "1.2.1"; }; tomlrb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00x5y9h4fbvrv4xrjk4cqlkm4vq8gv73ax4alj3ac2x77zsnnrk8"; type = "gem"; }; version = "1.3.0"; }; train-core = { - dependencies = ["addressable" "ffi" "json" "mixlib-shellout" "net-scp" "net-ssh"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "ffi" + "json" + "mixlib-shellout" + "net-scp" + "net-ssh" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1f0yxh5mpr7rdn3660jf5iwc3rhv4l82dd9mhcrm6v85901rvj9c"; type = "gem"; }; version = "3.10.7"; }; train-winrm = { - dependencies = ["winrm" "winrm-elevated" "winrm-fs"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "winrm" + "winrm-elevated" + "winrm-fs" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07haiwh7jcg00mmiarj5g7k9kclq40yqd4j4r3c01qn2cq1sw2xb"; type = "gem"; }; version = "0.2.13"; }; tty-box = { - dependencies = ["pastel" "strings" "tty-cursor"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pastel" + "strings" + "tty-cursor" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "12yzhl3s165fl8pkfln6mi6mfy3vg7p63r3dvcgqfhyzq6h57x0p"; type = "gem"; }; version = "0.7.0"; }; tty-color = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0aik4kmhwwrmkysha7qibi2nyzb4c8kp42bd5vxnf8sf7b53g73g"; type = "gem"; }; version = "0.6.0"; }; tty-cursor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j5zw041jgkmn605ya1zc151bxgxl6v192v2i26qhxx7ws2l2lvr"; type = "gem"; }; version = "0.7.1"; }; tty-prompt = { - dependencies = ["pastel" "tty-reader"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pastel" + "tty-reader" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1j4y8ik82azjxshgd4i1v4wwhsv3g9cngpygxqkkz69qaa8cxnzw"; type = "gem"; }; version = "0.23.1"; }; tty-reader = { - dependencies = ["tty-cursor" "tty-screen" "wisper"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "tty-cursor" + "tty-screen" + "wisper" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1cf2k7w7d84hshg4kzrjvk9pkyc2g1m3nx2n1rpmdcf0hp4p4af6"; type = "gem"; }; version = "0.9.0"; }; tty-screen = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18jr6s1cg8yb26wzkqa6874q0z93rq0y5aw092kdqazk71y6a235"; type = "gem"; }; version = "0.8.1"; }; tty-table = { - dependencies = ["pastel" "strings" "tty-screen"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pastel" + "strings" + "tty-screen" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fcrbfb0hjd9vkkazkksri93dv9wgs2hp6p1xwb1lp43a13pmhpx"; type = "gem"; }; version = "0.12.0"; }; unicode-display_width = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi82k102q7bkmfi7ggn9ciypn897ylln1jk9q67kjhr39fj043a"; type = "gem"; }; version = "2.4.2"; }; unicode_utils = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h1a5yvrxzlf0lxxa1ya31jcizslf774arnsd89vgdhk4g7x08mr"; type = "gem"; }; version = "1.4.0"; }; uuidtools = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0s8h35ia80p919kidb66nfp8904rhdmn41z9ghsx4ihp2ild3bn4"; type = "gem"; }; version = "2.2.0"; }; vault = { - dependencies = ["aws-sigv4"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-sigv4" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1aanqvdppvqwd8z7iqpx01izm65kfx9f92j1y9g1ixirzc086jxg"; type = "gem"; }; version = "0.17.0"; }; webrick = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13qm7s0gr2pmfcl7dxrmq38asaza4w0i2n9my4yzs499j731wh8r"; type = "gem"; }; version = "1.8.1"; }; winrm = { - dependencies = ["builder" "erubi" "gssapi" "gyoku" "httpclient" "logging" "nori" "rubyntlm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "builder" + "erubi" + "gssapi" + "gyoku" + "httpclient" + "logging" + "nori" + "rubyntlm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0nxf6a47d1xf1nvi7rbfbzjyyjhz0iakrnrsr2hj6y24a381sd8i"; type = "gem"; }; version = "2.3.6"; }; winrm-elevated = { - dependencies = ["erubi" "winrm" "winrm-fs"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "erubi" + "winrm" + "winrm-fs" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1lmlaii8qapn84wxdg5d82gbailracgk67d0qsnbdnffcg8kswzd"; type = "gem"; }; version = "1.2.3"; }; winrm-fs = { - dependencies = ["erubi" "logging" "rubyzip" "winrm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "erubi" + "logging" + "rubyzip" + "winrm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gb91k6s1yjqw387x4w1nkpnxblq3pjdqckayl0qvz5n3ygdsb0d"; type = "gem"; }; version = "1.3.5"; }; wisper = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rpsi0ziy78cj82sbyyywby4d0aw0a5q84v65qd28vqn79fbq5yf"; type = "gem"; }; version = "2.0.1"; }; wmi-lite = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nnx4xz8g40dpi3ccqk5blj1ck06ydx09f9diksn1ghd8yxzavhi"; type = "gem"; }; diff --git a/pkgs/tools/misc/ckb-next/default.nix b/pkgs/tools/misc/ckb-next/default.nix index 6c077b227274f0..f33ada649a344e 100644 --- a/pkgs/tools/misc/ckb-next/default.nix +++ b/pkgs/tools/misc/ckb-next/default.nix @@ -1,6 +1,23 @@ -{ lib, wrapQtAppsHook, fetchFromGitHub, substituteAll, udev, stdenv -, pkg-config, qtbase, cmake, zlib, kmod, libXdmcp, qttools, qtx11extras, libdbusmenu, gnused -, withPulseaudio ? stdenv.hostPlatform.isLinux, libpulseaudio, quazip +{ + lib, + wrapQtAppsHook, + fetchFromGitHub, + substituteAll, + udev, + stdenv, + pkg-config, + qtbase, + cmake, + zlib, + kmod, + libXdmcp, + qttools, + qtx11extras, + libdbusmenu, + gnused, + withPulseaudio ? stdenv.hostPlatform.isLinux, + libpulseaudio, + quazip, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/misc/clipbuzz/default.nix b/pkgs/tools/misc/clipbuzz/default.nix index 1d4b614846a683..8b09430b52aebb 100644 --- a/pkgs/tools/misc/clipbuzz/default.nix +++ b/pkgs/tools/misc/clipbuzz/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchzip -, libX11 -, libXfixes -, zig +{ + lib, + stdenv, + fetchzip, + libX11, + libXfixes, + zig, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/tools/misc/cmdpack/default.nix b/pkgs/tools/misc/cmdpack/default.nix index 22402098e6cdb4..a40317ba248e73 100644 --- a/pkgs/tools/misc/cmdpack/default.nix +++ b/pkgs/tools/misc/cmdpack/default.nix @@ -1,40 +1,50 @@ -{ stdenv, lib, fetchurl }: +{ + stdenv, + lib, + fetchurl, +}: let - mkCmdPackDerivation = { pname, postInstall ? "", description }: stdenv.mkDerivation { - inherit pname postInstall; + mkCmdPackDerivation = + { + pname, + postInstall ? "", + description, + }: + stdenv.mkDerivation { + inherit pname postInstall; - version = "1.03"; + version = "1.03"; - src = fetchurl { - url = "https://web.archive.org/web/20140330233023/http://www.neillcorlett.com/downloads/cmdpack-1.03-src.tar.gz"; - sha256 = "0v0a9rpv59w8lsp1cs8f65568qj65kd9qp7854z1ivfxfpq0da2n"; - }; + src = fetchurl { + url = "https://web.archive.org/web/20140330233023/http://www.neillcorlett.com/downloads/cmdpack-1.03-src.tar.gz"; + sha256 = "0v0a9rpv59w8lsp1cs8f65568qj65kd9qp7854z1ivfxfpq0da2n"; + }; - buildPhase = '' - runHook preBuild + buildPhase = '' + runHook preBuild - $CC -o "$pname" "src/$pname.c" + $CC -o "$pname" "src/$pname.c" - runHook postBuild - ''; + runHook postBuild + ''; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - install -Dm555 -t "$out/bin" "$pname" + install -Dm555 -t "$out/bin" "$pname" - runHook postInstall - ''; + runHook postInstall + ''; - meta = with lib; { - inherit description; + meta = with lib; { + inherit description; - homepage = "https://web.archive.org/web/20140330233023/http://www.neillcorlett.com/cmdpack/"; - platforms = platforms.all; - license = licenses.gpl3Plus; - maintainers = with maintainers; [ zane ]; + homepage = "https://web.archive.org/web/20140330233023/http://www.neillcorlett.com/cmdpack/"; + platforms = platforms.all; + license = licenses.gpl3Plus; + maintainers = with maintainers; [ zane ]; + }; }; - }; in { bin2iso = mkCmdPackDerivation { diff --git a/pkgs/tools/misc/contacts/default.nix b/pkgs/tools/misc/contacts/default.nix index 1c789ca1d11db8..83535fb9d0333a 100644 --- a/pkgs/tools/misc/contacts/default.nix +++ b/pkgs/tools/misc/contacts/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, xcbuildHook, Foundation, AddressBook }: +{ + lib, + stdenv, + fetchFromGitHub, + xcbuildHook, + Foundation, + AddressBook, +}: stdenv.mkDerivation { version = "1.1a-3"; @@ -17,7 +24,10 @@ stdenv.mkDerivation { ''; nativeBuildInputs = [ xcbuildHook ]; - buildInputs = [ Foundation AddressBook ]; + buildInputs = [ + Foundation + AddressBook + ]; installPhase = '' mkdir -p $out/bin diff --git a/pkgs/tools/misc/coreutils/default.nix b/pkgs/tools/misc/coreutils/default.nix index 5bbc3b9581ee83..d7ce076e8a85bb 100644 --- a/pkgs/tools/misc/coreutils/default.nix +++ b/pkgs/tools/misc/coreutils/default.nix @@ -1,24 +1,31 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, buildPackages -, libiconv -, perl -, texinfo -, xz -, binlore -, coreutils -, gmpSupport ? true, gmp -, aclSupport ? lib.meta.availableOn stdenv.hostPlatform acl, acl -, attrSupport ? lib.meta.availableOn stdenv.hostPlatform attr, attr -, selinuxSupport ? false, libselinux, libsepol -# No openssl in default version, so openssl-induced rebuilds aren't too big. -# It makes *sum functions significantly faster. -, minimal ? true -, withOpenssl ? !minimal, openssl -, withPrefix ? false -, singleBinary ? "symlinks" # you can also pass "shebangs" or false +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + buildPackages, + libiconv, + perl, + texinfo, + xz, + binlore, + coreutils, + gmpSupport ? true, + gmp, + aclSupport ? lib.meta.availableOn stdenv.hostPlatform acl, + acl, + attrSupport ? lib.meta.availableOn stdenv.hostPlatform attr, + attr, + selinuxSupport ? false, + libselinux, + libsepol, + # No openssl in default version, so openssl-induced rebuilds aren't too big. + # It makes *sum functions significantly faster. + minimal ? true, + withOpenssl ? !minimal, + openssl, + withPrefix ? false, + singleBinary ? "symlinks", # you can also pass "shebangs" or false }: # Note: this package is used for bootstrapping fetchurl, and thus cannot use @@ -29,7 +36,14 @@ assert aclSupport -> acl != null; assert selinuxSupport -> libselinux != null && libsepol != null; let - inherit (lib) concatStringsSep isString optional optionalAttrs optionals optionalString; + inherit (lib) + concatStringsSep + isString + optional + optionalAttrs + optionals + optionalString + ; isCross = (stdenv.hostPlatform != stdenv.buildPlatform); in stdenv.mkDerivation rec { @@ -41,95 +55,112 @@ stdenv.mkDerivation rec { hash = "sha256-zTKO3qyS9qZl3p8yPJO3Eq8YWLwuDYjz9xAEaUcKG4o="; }; - patches = [ - # https://lists.gnu.org/archive/html/bug-coreutils/2024-05/msg00037.html - # This is not precisely the patch provided - this is a diff of the Makefile.in - # after the patch was applied and autoreconf was run, since adding autoreconf - # here causes infinite recursion. - ./fix-mix-flags-deps-libintl.patch - ] ++ lib.optionals stdenv.hostPlatform.isMusl [ - # https://lists.gnu.org/archive/html/bug-coreutils/2024-03/msg00089.html - ./fix-test-failure-musl.patch - ]; + patches = + [ + # https://lists.gnu.org/archive/html/bug-coreutils/2024-05/msg00037.html + # This is not precisely the patch provided - this is a diff of the Makefile.in + # after the patch was applied and autoreconf was run, since adding autoreconf + # here causes infinite recursion. + ./fix-mix-flags-deps-libintl.patch + ] + ++ lib.optionals stdenv.hostPlatform.isMusl [ + # https://lists.gnu.org/archive/html/bug-coreutils/2024-03/msg00089.html + ./fix-test-failure-musl.patch + ]; - postPatch = '' - # The test tends to fail on btrfs, f2fs and maybe other unusual filesystems. - sed '2i echo Skipping dd sparse test && exit 77' -i ./tests/dd/sparse.sh - sed '2i echo Skipping du threshold test && exit 77' -i ./tests/du/threshold.sh - sed '2i echo Skipping cp reflink-auto test && exit 77' -i ./tests/cp/reflink-auto.sh - sed '2i echo Skipping cp sparse test && exit 77' -i ./tests/cp/sparse.sh - sed '2i echo Skipping env test && exit 77' -i ./tests/env/env.sh - sed '2i echo Skipping rm deep-2 test && exit 77' -i ./tests/rm/deep-2.sh - sed '2i echo Skipping du long-from-unreadable test && exit 77' -i ./tests/du/long-from-unreadable.sh - - # The test tends to fail on cephfs - sed '2i echo Skipping df total-verify test && exit 77' -i ./tests/df/total-verify.sh - - # Some target platforms, especially when building inside a container have - # issues with the inotify test. - sed '2i echo Skipping tail inotify dir recreate test && exit 77' -i ./tests/tail/inotify-dir-recreate.sh - - # sandbox does not allow setgid - sed '2i echo Skipping chmod setgid test && exit 77' -i ./tests/chmod/setgid.sh - substituteInPlace ./tests/install/install-C.sh \ - --replace 'mode3=2755' 'mode3=1755' - - # Fails on systems with a rootfs. Looks like a bug in the test, see - # https://lists.gnu.org/archive/html/bug-coreutils/2019-12/msg00000.html - sed '2i print "Skipping df skip-rootfs test"; exit 77' -i ./tests/df/skip-rootfs.sh - - # these tests fail in the unprivileged nix sandbox (without nix-daemon) as we break posix assumptions - for f in ./tests/chgrp/{basic.sh,recurse.sh,default-no-deref.sh,no-x.sh,posix-H.sh}; do - sed '2i echo Skipping chgrp && exit 77' -i "$f" - done - for f in gnulib-tests/{test-chown.c,test-fchownat.c,test-lchown.c}; do - echo "int main() { return 77; }" > "$f" - done - - # We don't have localtime in the sandbox - for f in gnulib-tests/{test-localtime_r.c,test-localtime_r-mt.c}; do - echo "int main() { return 77; }" > "$f" - done - - # intermittent failures on builders, unknown reason - sed '2i echo Skipping du basic test && exit 77' -i ./tests/du/basic.sh - '' + (optionalString (stdenv.hostPlatform.libc == "musl") (concatStringsSep "\n" [ + postPatch = '' - echo "int main() { return 77; }" > gnulib-tests/test-parse-datetime.c - echo "int main() { return 77; }" > gnulib-tests/test-getlogin.c + # The test tends to fail on btrfs, f2fs and maybe other unusual filesystems. + sed '2i echo Skipping dd sparse test && exit 77' -i ./tests/dd/sparse.sh + sed '2i echo Skipping du threshold test && exit 77' -i ./tests/du/threshold.sh + sed '2i echo Skipping cp reflink-auto test && exit 77' -i ./tests/cp/reflink-auto.sh + sed '2i echo Skipping cp sparse test && exit 77' -i ./tests/cp/sparse.sh + sed '2i echo Skipping env test && exit 77' -i ./tests/env/env.sh + sed '2i echo Skipping rm deep-2 test && exit 77' -i ./tests/rm/deep-2.sh + sed '2i echo Skipping du long-from-unreadable test && exit 77' -i ./tests/du/long-from-unreadable.sh + + # The test tends to fail on cephfs + sed '2i echo Skipping df total-verify test && exit 77' -i ./tests/df/total-verify.sh + + # Some target platforms, especially when building inside a container have + # issues with the inotify test. + sed '2i echo Skipping tail inotify dir recreate test && exit 77' -i ./tests/tail/inotify-dir-recreate.sh + + # sandbox does not allow setgid + sed '2i echo Skipping chmod setgid test && exit 77' -i ./tests/chmod/setgid.sh + substituteInPlace ./tests/install/install-C.sh \ + --replace 'mode3=2755' 'mode3=1755' + + # Fails on systems with a rootfs. Looks like a bug in the test, see + # https://lists.gnu.org/archive/html/bug-coreutils/2019-12/msg00000.html + sed '2i print "Skipping df skip-rootfs test"; exit 77' -i ./tests/df/skip-rootfs.sh + + # these tests fail in the unprivileged nix sandbox (without nix-daemon) as we break posix assumptions + for f in ./tests/chgrp/{basic.sh,recurse.sh,default-no-deref.sh,no-x.sh,posix-H.sh}; do + sed '2i echo Skipping chgrp && exit 77' -i "$f" + done + for f in gnulib-tests/{test-chown.c,test-fchownat.c,test-lchown.c}; do + echo "int main() { return 77; }" > "$f" + done + + # We don't have localtime in the sandbox + for f in gnulib-tests/{test-localtime_r.c,test-localtime_r-mt.c}; do + echo "int main() { return 77; }" > "$f" + done + + # intermittent failures on builders, unknown reason + sed '2i echo Skipping du basic test && exit 77' -i ./tests/du/basic.sh '' - ])) + (optionalString stdenv.hostPlatform.isAarch64 '' - # Sometimes fails: https://github.com/NixOS/nixpkgs/pull/143097#issuecomment-954462584 - sed '2i echo Skipping cut huge range test && exit 77' -i ./tests/cut/cut-huge-range.sh - ''); + + (optionalString (stdenv.hostPlatform.libc == "musl") ( + concatStringsSep "\n" [ + '' + echo "int main() { return 77; }" > gnulib-tests/test-parse-datetime.c + echo "int main() { return 77; }" > gnulib-tests/test-getlogin.c + '' + ] + )) + + (optionalString stdenv.hostPlatform.isAarch64 '' + # Sometimes fails: https://github.com/NixOS/nixpkgs/pull/143097#issuecomment-954462584 + sed '2i echo Skipping cut huge range test && exit 77' -i ./tests/cut/cut-huge-range.sh + ''); - outputs = [ "out" "info" ]; + outputs = [ + "out" + "info" + ]; separateDebugInfo = true; - nativeBuildInputs = [ - perl - xz.bin - ] - ++ optionals stdenv.hostPlatform.isCygwin [ - # due to patch - autoreconfHook - texinfo - ]; + nativeBuildInputs = + [ + perl + xz.bin + ] + ++ optionals stdenv.hostPlatform.isCygwin [ + # due to patch + autoreconfHook + texinfo + ]; - buildInputs = [ ] + buildInputs = + [ ] ++ optional aclSupport acl ++ optional attrSupport attr ++ optional gmpSupport gmp ++ optional withOpenssl openssl - ++ optionals selinuxSupport [ libselinux libsepol ] + ++ optionals selinuxSupport [ + libselinux + libsepol + ] # TODO(@Ericson2314): Investigate whether Darwin could benefit too ++ optional (isCross && stdenv.hostPlatform.libc != "glibc") libiconv; hardeningDisable = [ "trivialautovarinit" ]; - configureFlags = [ "--with-packager=https://nixos.org" ] - ++ optional (singleBinary != false) - ("--enable-single-binary" + optionalString (isString singleBinary) "=${singleBinary}") + configureFlags = + [ "--with-packager=https://nixos.org" ] + ++ optional (singleBinary != false) ( + "--enable-single-binary" + optionalString (isString singleBinary) "=${singleBinary}" + ) ++ optional withOpenssl "--with-openssl" ++ optional stdenv.hostPlatform.isSunOS "ac_cv_func_inotify_init=no" ++ optional withPrefix "--program-prefix=g" @@ -152,7 +183,8 @@ stdenv.mkDerivation rec { # Darwin (http://article.gmane.org/gmane.comp.gnu.core-utils.bugs/19351), # and {Open,Free}BSD. # With non-standard storeDir: https://github.com/NixOS/nix/issues/512 - doCheck = (!isCross) + doCheck = + (!isCross) && (stdenv.hostPlatform.libc == "glibc" || stdenv.hostPlatform.libc == "musl") && !stdenv.hostPlatform.isAarch32; @@ -163,10 +195,12 @@ stdenv.mkDerivation rec { NIX_LDFLAGS = optionalString selinuxSupport "-lsepol"; FORCE_UNSAFE_CONFIGURE = optionalString stdenv.hostPlatform.isSunOS "1"; - env.NIX_CFLAGS_COMPILE = toString ([] + env.NIX_CFLAGS_COMPILE = toString ( + [ ] # Work around a bogus warning in conjunction with musl. ++ optional stdenv.hostPlatform.isMusl "-Wno-error" - ++ optional stdenv.hostPlatform.isAndroid "-D__USE_FORTIFY_LEVEL=0"); + ++ optional stdenv.hostPlatform.isAndroid "-D__USE_FORTIFY_LEVEL=0" + ); # Works around a bug with 8.26: # Makefile:3440: *** Recursive variable 'INSTALL' references itself (eventually). Stop. @@ -174,34 +208,38 @@ stdenv.mkDerivation rec { sed -i Makefile -e 's|^INSTALL =.*|INSTALL = ${buildPackages.coreutils}/bin/install -c|' ''; - postInstall = optionalString (isCross && !minimal) '' - rm $out/share/man/man1/* - cp ${buildPackages.coreutils-full}/share/man/man1/* $out/share/man/man1 - '' - # du: 8.7 M locale + 0.4 M man pages - + optionalString minimal '' - rm -r "$out/share" - ''; - - passthru = {} // optionalAttrs (singleBinary != false) { - # everything in the single binary gets the same verdict, so we - # override _that case_ with verdicts from separate binaries. - # - # binlore only spots exec in runcon on some platforms (i.e., not - # darwin; see comment on inverse case below) - binlore.out = binlore.synthesize coreutils '' - execer can bin/{chroot,env,install,nice,nohup,runcon,sort,split,stdbuf,timeout} - execer cannot bin/{[,b2sum,base32,base64,basename,basenc,cat,chcon,chgrp,chmod,chown,cksum,comm,cp,csplit,cut,date,dd,df,dir,dircolors,dirname,du,echo,expand,expr,factor,false,fmt,fold,groups,head,hostid,id,join,kill,link,ln,logname,ls,md5sum,mkdir,mkfifo,mknod,mktemp,mv,nl,nproc,numfmt,od,paste,pathchk,pinky,pr,printenv,printf,ptx,pwd,readlink,realpath,rm,rmdir,seq,sha1sum,sha224sum,sha256sum,sha384sum,sha512sum,shred,shuf,sleep,stat,stty,sum,sync,tac,tail,tee,test,touch,tr,true,truncate,tsort,tty,uname,unexpand,uniq,unlink,uptime,users,vdir,wc,who,whoami,yes} - ''; - } // optionalAttrs (singleBinary == false) { - # binlore only spots exec in runcon on some platforms (i.e., not - # darwin; I have a note that the behavior may need selinux?). - # hard-set it so people working on macOS don't miss cases of - # runcon until ofBorg fails. - binlore.out = binlore.synthesize coreutils '' - execer can bin/runcon + postInstall = + optionalString (isCross && !minimal) '' + rm $out/share/man/man1/* + cp ${buildPackages.coreutils-full}/share/man/man1/* $out/share/man/man1 + '' + # du: 8.7 M locale + 0.4 M man pages + + optionalString minimal '' + rm -r "$out/share" ''; - }; + + passthru = + { } + // optionalAttrs (singleBinary != false) { + # everything in the single binary gets the same verdict, so we + # override _that case_ with verdicts from separate binaries. + # + # binlore only spots exec in runcon on some platforms (i.e., not + # darwin; see comment on inverse case below) + binlore.out = binlore.synthesize coreutils '' + execer can bin/{chroot,env,install,nice,nohup,runcon,sort,split,stdbuf,timeout} + execer cannot bin/{[,b2sum,base32,base64,basename,basenc,cat,chcon,chgrp,chmod,chown,cksum,comm,cp,csplit,cut,date,dd,df,dir,dircolors,dirname,du,echo,expand,expr,factor,false,fmt,fold,groups,head,hostid,id,join,kill,link,ln,logname,ls,md5sum,mkdir,mkfifo,mknod,mktemp,mv,nl,nproc,numfmt,od,paste,pathchk,pinky,pr,printenv,printf,ptx,pwd,readlink,realpath,rm,rmdir,seq,sha1sum,sha224sum,sha256sum,sha384sum,sha512sum,shred,shuf,sleep,stat,stty,sum,sync,tac,tail,tee,test,touch,tr,true,truncate,tsort,tty,uname,unexpand,uniq,unlink,uptime,users,vdir,wc,who,whoami,yes} + ''; + } + // optionalAttrs (singleBinary == false) { + # binlore only spots exec in runcon on some platforms (i.e., not + # darwin; I have a note that the behavior may need selinux?). + # hard-set it so people working on macOS don't miss cases of + # runcon until ofBorg fails. + binlore.out = binlore.synthesize coreutils '' + execer can bin/runcon + ''; + }; meta = with lib; { homepage = "https://www.gnu.org/software/coreutils/"; diff --git a/pkgs/tools/misc/cutecom/default.nix b/pkgs/tools/misc/cutecom/default.nix index 9ed7ef6295e6b0..0fc665fbd739f6 100644 --- a/pkgs/tools/misc/cutecom/default.nix +++ b/pkgs/tools/misc/cutecom/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, fetchFromGitLab, qtserialport, cmake, wrapQtAppsHook }: +{ + stdenv, + lib, + fetchFromGitLab, + qtserialport, + cmake, + wrapQtAppsHook, +}: stdenv.mkDerivation rec { pname = "cutecom"; @@ -17,17 +24,24 @@ stdenv.mkDerivation rec { ''; buildInputs = [ qtserialport ]; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; - postInstall = if stdenv.hostPlatform.isDarwin then '' - mkdir -p $out/Applications - '' else '' - cd .. - mkdir -p "$out"/share/{applications,icons/hicolor/scalable/apps,man/man1} - cp cutecom.desktop "$out/share/applications" - cp images/cutecom.svg "$out/share/icons/hicolor/scalable/apps" - cp cutecom.1 "$out/share/man/man1" - ''; + postInstall = + if stdenv.hostPlatform.isDarwin then + '' + mkdir -p $out/Applications + '' + else + '' + cd .. + mkdir -p "$out"/share/{applications,icons/hicolor/scalable/apps,man/man1} + cp cutecom.desktop "$out/share/applications" + cp images/cutecom.svg "$out/share/icons/hicolor/scalable/apps" + cp cutecom.1 "$out/share/man/man1" + ''; meta = with lib; { description = "Graphical serial terminal"; diff --git a/pkgs/tools/misc/depotdownloader/default.nix b/pkgs/tools/misc/depotdownloader/default.nix index 4c5874e844451d..4dfd40a379d3c0 100644 --- a/pkgs/tools/misc/depotdownloader/default.nix +++ b/pkgs/tools/misc/depotdownloader/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildDotnetModule -, fetchFromGitHub -, dotnetCorePackages +{ + lib, + buildDotnetModule, + fetchFromGitHub, + dotnetCorePackages, }: buildDotnetModule rec { @@ -27,7 +28,12 @@ buildDotnetModule rec { changelog = "https://github.com/SteamRE/DepotDownloader/releases/tag/DepotDownloader_${version}"; license = licenses.gpl2Only; maintainers = [ maintainers.babbaj ]; - platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; mainProgram = "DepotDownloader"; }; } diff --git a/pkgs/tools/misc/depotdownloader/deps.nix b/pkgs/tools/misc/depotdownloader/deps.nix index a3ebb00b404455..192ace63817a46 100644 --- a/pkgs/tools/misc/depotdownloader/deps.nix +++ b/pkgs/tools/misc/depotdownloader/deps.nix @@ -1,19 +1,76 @@ # This file was automatically generated by passthru.fetch-deps. # Please dont edit it manually, your changes might get overwritten! -{ fetchNuGet }: [ - (fetchNuGet { pname = "Microsoft.NETCore.Platforms"; version = "5.0.0"; hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; }) - (fetchNuGet { pname = "Microsoft.Win32.Registry"; version = "5.0.0"; hash = "sha256-9kylPGfKZc58yFqNKa77stomcoNnMeERXozWJzDcUIA="; }) - (fetchNuGet { pname = "Microsoft.Windows.CsWin32"; version = "0.3.106"; hash = "sha256-S1uQa684taPb6uh69784ebVpXoirMoX+pxBRA+Rrzlg="; }) - (fetchNuGet { pname = "Microsoft.Windows.SDK.Win32Docs"; version = "0.1.42-alpha"; hash = "sha256-6DvzmNzrGVfWmNJNqooj+Ya+7bAQlyeg7pmyKaUlIws="; }) - (fetchNuGet { pname = "Microsoft.Windows.SDK.Win32Metadata"; version = "60.0.34-preview"; hash = "sha256-KdRe73sXipzMvm2BLmwwBZGh+l9isZDC9l8WFyUR1zM="; }) - (fetchNuGet { pname = "Microsoft.Windows.WDK.Win32Metadata"; version = "0.11.4-experimental"; hash = "sha256-b3oKUKbr+3Udfl7RWzUY9BR/XWNsN+VmEkBxk6KiFo0="; }) - (fetchNuGet { pname = "protobuf-net"; version = "3.2.45"; hash = "sha256-rWitxe3uP3SOyoG1fwM5n00RpR5IL1V6u1zXMI0p0JA="; }) - (fetchNuGet { pname = "protobuf-net.Core"; version = "3.2.45"; hash = "sha256-bsMGUmd0yno8g0H0637jJboKJwyyHLHoHg45+bt9pLQ="; }) - (fetchNuGet { pname = "QRCoder"; version = "1.6.0"; hash = "sha256-2Ev/6d7PH6K4dVYQQHlZ+ZggkCnDtrlaGygs65mDo28="; }) - (fetchNuGet { pname = "SteamKit2"; version = "3.0.0"; hash = "sha256-bRRdX8WFo9k+QCZWh0KHb3TULpJxpR4Hg9FDXKBW6d4="; }) - (fetchNuGet { pname = "System.Collections.Immutable"; version = "7.0.0"; hash = "sha256-9an2wbxue2qrtugYES9awshQg+KfJqajhnhs45kQIdk="; }) - (fetchNuGet { pname = "System.IO.Hashing"; version = "8.0.0"; hash = "sha256-szOGt0TNBo6dEdC3gf6H+e9YW3Nw0woa6UnCGGGK5cE="; }) - (fetchNuGet { pname = "System.Security.AccessControl"; version = "5.0.0"; hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; }) - (fetchNuGet { pname = "System.Security.Principal.Windows"; version = "5.0.0"; hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; }) +{ fetchNuGet }: +[ + (fetchNuGet { + pname = "Microsoft.NETCore.Platforms"; + version = "5.0.0"; + hash = "sha256-LIcg1StDcQLPOABp4JRXIs837d7z0ia6+++3SF3jl1c="; + }) + (fetchNuGet { + pname = "Microsoft.Win32.Registry"; + version = "5.0.0"; + hash = "sha256-9kylPGfKZc58yFqNKa77stomcoNnMeERXozWJzDcUIA="; + }) + (fetchNuGet { + pname = "Microsoft.Windows.CsWin32"; + version = "0.3.106"; + hash = "sha256-S1uQa684taPb6uh69784ebVpXoirMoX+pxBRA+Rrzlg="; + }) + (fetchNuGet { + pname = "Microsoft.Windows.SDK.Win32Docs"; + version = "0.1.42-alpha"; + hash = "sha256-6DvzmNzrGVfWmNJNqooj+Ya+7bAQlyeg7pmyKaUlIws="; + }) + (fetchNuGet { + pname = "Microsoft.Windows.SDK.Win32Metadata"; + version = "60.0.34-preview"; + hash = "sha256-KdRe73sXipzMvm2BLmwwBZGh+l9isZDC9l8WFyUR1zM="; + }) + (fetchNuGet { + pname = "Microsoft.Windows.WDK.Win32Metadata"; + version = "0.11.4-experimental"; + hash = "sha256-b3oKUKbr+3Udfl7RWzUY9BR/XWNsN+VmEkBxk6KiFo0="; + }) + (fetchNuGet { + pname = "protobuf-net"; + version = "3.2.45"; + hash = "sha256-rWitxe3uP3SOyoG1fwM5n00RpR5IL1V6u1zXMI0p0JA="; + }) + (fetchNuGet { + pname = "protobuf-net.Core"; + version = "3.2.45"; + hash = "sha256-bsMGUmd0yno8g0H0637jJboKJwyyHLHoHg45+bt9pLQ="; + }) + (fetchNuGet { + pname = "QRCoder"; + version = "1.6.0"; + hash = "sha256-2Ev/6d7PH6K4dVYQQHlZ+ZggkCnDtrlaGygs65mDo28="; + }) + (fetchNuGet { + pname = "SteamKit2"; + version = "3.0.0"; + hash = "sha256-bRRdX8WFo9k+QCZWh0KHb3TULpJxpR4Hg9FDXKBW6d4="; + }) + (fetchNuGet { + pname = "System.Collections.Immutable"; + version = "7.0.0"; + hash = "sha256-9an2wbxue2qrtugYES9awshQg+KfJqajhnhs45kQIdk="; + }) + (fetchNuGet { + pname = "System.IO.Hashing"; + version = "8.0.0"; + hash = "sha256-szOGt0TNBo6dEdC3gf6H+e9YW3Nw0woa6UnCGGGK5cE="; + }) + (fetchNuGet { + pname = "System.Security.AccessControl"; + version = "5.0.0"; + hash = "sha256-ueSG+Yn82evxyGBnE49N4D+ngODDXgornlBtQ3Omw54="; + }) + (fetchNuGet { + pname = "System.Security.Principal.Windows"; + version = "5.0.0"; + hash = "sha256-CBOQwl9veFkrKK2oU8JFFEiKIh/p+aJO+q9Tc2Q/89Y="; + }) ] diff --git a/pkgs/tools/misc/dialogbox/default.nix b/pkgs/tools/misc/dialogbox/default.nix index e6849fa843100e..6287ed999ab24a 100644 --- a/pkgs/tools/misc/dialogbox/default.nix +++ b/pkgs/tools/misc/dialogbox/default.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, mkDerivation -, fetchFromGitHub -, qmake -, qtbase +{ + stdenv, + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qtbase, }: mkDerivation rec { diff --git a/pkgs/tools/misc/didyoumean/default.nix b/pkgs/tools/misc/didyoumean/default.nix index 4f938d74553443..76d52622a839d5 100644 --- a/pkgs/tools/misc/didyoumean/default.nix +++ b/pkgs/tools/misc/didyoumean/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, libxcb -, openssl +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + libxcb, + openssl, }: rustPlatform.buildRustPackage rec { @@ -21,11 +22,13 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-QERnohWpkJ0LWkdxHrY6gKxdGqxDkLla7jlG44laojk="; - nativeBuildInputs = [ - installShellFiles - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - pkg-config - ]; + nativeBuildInputs = + [ + installShellFiles + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + pkg-config + ]; buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libxcb @@ -45,7 +48,10 @@ rustPlatform.buildRustPackage rec { description = "CLI spelling corrector for when you're unsure"; homepage = "https://github.com/hisbaan/didyoumean"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ evanjs wegank ]; + maintainers = with maintainers; [ + evanjs + wegank + ]; mainProgram = "dym"; }; } diff --git a/pkgs/tools/misc/dijo/default.nix b/pkgs/tools/misc/dijo/default.nix index 344faf84f60bd7..9a4867971252a4 100644 --- a/pkgs/tools/misc/dijo/default.nix +++ b/pkgs/tools/misc/dijo/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, rustPlatform, fetchFromGitHub, ncurses, CoreServices }: +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + ncurses, + CoreServices, +}: rustPlatform.buildRustPackage rec { pname = "dijo"; diff --git a/pkgs/tools/misc/diskus/default.nix b/pkgs/tools/misc/diskus/default.nix index 683da47d6af69b..7063c11e409d3b 100644 --- a/pkgs/tools/misc/diskus/default.nix +++ b/pkgs/tools/misc/diskus/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, +}: rustPlatform.buildRustPackage rec { pname = "diskus"; @@ -18,7 +24,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Minimal, fast alternative to 'du -sh'"; homepage = "https://github.com/sharkdp/diskus"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = [ maintainers.fuerbringer ]; platforms = platforms.unix; longDescription = '' diff --git a/pkgs/tools/misc/docker-sync/default.nix b/pkgs/tools/misc/docker-sync/default.nix index aa129c0a36dbd6..0336a7b07e089b 100644 --- a/pkgs/tools/misc/docker-sync/default.nix +++ b/pkgs/tools/misc/docker-sync/default.nix @@ -1,4 +1,9 @@ -{ lib, ruby, bundlerApp, bundlerUpdateScript }: +{ + lib, + ruby, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "docker-sync"; @@ -6,7 +11,7 @@ bundlerApp { inherit ruby; - exes = ["docker-sync"]; + exes = [ "docker-sync" ]; passthru.updateScript = bundlerUpdateScript "docker-sync"; @@ -14,7 +19,10 @@ bundlerApp { description = "Run your application at full speed while syncing your code for development"; homepage = "http://docker-sync.io"; license = licenses.gpl3; - maintainers = with maintainers; [ manveru nicknovitski ]; + maintainers = with maintainers; [ + manveru + nicknovitski + ]; platforms = platforms.unix; mainProgram = "docker-sync"; }; diff --git a/pkgs/tools/misc/docker-sync/gemset.nix b/pkgs/tools/misc/docker-sync/gemset.nix index aef4d9928ab1cd..db73c92ed3b5d9 100644 --- a/pkgs/tools/misc/docker-sync/gemset.nix +++ b/pkgs/tools/misc/docker-sync/gemset.nix @@ -1,7 +1,7 @@ { backticks = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vr28l9vckavnrb9pnqrhcmnk3wsvvpas8jjh165w2rzv3sdkws5"; type = "gem"; }; @@ -9,25 +9,33 @@ }; daemons = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0l5gai3vd4g7aqff0k1mp41j9zcsvm2rbwmqn115a325k9r7pf4w"; type = "gem"; }; version = "1.3.1"; }; docker-compose = { - dependencies = ["backticks"]; + dependencies = [ "backticks" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00v3y182rmpq34dl91iprvhc50vw8hysy2h7iy3ihmmm9pgg71gc"; type = "gem"; }; version = "1.1.10"; }; docker-sync = { - dependencies = ["daemons" "docker-compose" "dotenv" "gem_update_checker" "os" "terminal-notifier" "thor"]; + dependencies = [ + "daemons" + "docker-compose" + "dotenv" + "gem_update_checker" + "os" + "terminal-notifier" + "thor" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vrlcggj7k8w30b76f23p64yx4wg7p7mq9lp6lsnh2ysq9n3cjqg"; type = "gem"; }; @@ -35,7 +43,7 @@ }; dotenv = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rgl2kqhnxqbjvi9brbvb52iaq1z8yi0pl0bawk4fm6kl9igxr8f"; type = "gem"; }; @@ -43,7 +51,7 @@ }; gem_update_checker = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ckbz4q3q59kkv138n0cmsyida0wg45pwscxzf5vshxcrxhmq3x7"; type = "gem"; }; @@ -51,7 +59,7 @@ }; os = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1s401gvhqgs2r8hh43ia205mxsy1wc0ib4k76wzkdpspfcnfr1rk"; type = "gem"; }; @@ -59,7 +67,7 @@ }; terminal-notifier = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1slc0y8pjpw30hy21v8ypafi8r7z9jlj4bjbgz03b65b28i2n3bs"; type = "gem"; }; @@ -67,7 +75,7 @@ }; thor = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yhrnp9x8qcy5vc7g438amd5j9sw83ih7c30dr6g6slgw9zj3g29"; type = "gem"; }; diff --git a/pkgs/tools/misc/dvtm/default.nix b/pkgs/tools/misc/dvtm/default.nix index ea5a051c62b123..0d415bace1a229 100644 --- a/pkgs/tools/misc/dvtm/default.nix +++ b/pkgs/tools/misc/dvtm/default.nix @@ -1,4 +1,4 @@ -{callPackage, fetchurl}: +{ callPackage, fetchurl }: callPackage ./dvtm.nix rec { pname = "dvtm"; version = "0.15"; @@ -17,4 +17,3 @@ callPackage ./dvtm.nix rec { }) ]; } - diff --git a/pkgs/tools/misc/dvtm/dvtm.nix b/pkgs/tools/misc/dvtm/dvtm.nix index f4e36f271bab4c..8bf1dd971d057c 100644 --- a/pkgs/tools/misc/dvtm/dvtm.nix +++ b/pkgs/tools/misc/dvtm/dvtm.nix @@ -1,7 +1,21 @@ -{ lib, stdenv, ncurses, customConfig ? null, pname, version, src, patches ? [] }: +{ + lib, + stdenv, + ncurses, + customConfig ? null, + pname, + version, + src, + patches ? [ ], +}: stdenv.mkDerivation { - inherit pname version src patches; + inherit + pname + version + src + patches + ; CFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin "-D_DARWIN_C_SOURCE"; diff --git a/pkgs/tools/misc/dvtm/unstable.nix b/pkgs/tools/misc/dvtm/unstable.nix index 4008407f28fa51..dbb4d37a49dafc 100644 --- a/pkgs/tools/misc/dvtm/unstable.nix +++ b/pkgs/tools/misc/dvtm/unstable.nix @@ -1,4 +1,8 @@ -{ callPackage, fetchpatch, fetchzip }: +{ + callPackage, + fetchpatch, + fetchzip, +}: let rev = "7bcf43f8dbd5c4a67ec573a1248114caa75fa3c2"; diff --git a/pkgs/tools/misc/eludris/default.nix b/pkgs/tools/misc/eludris/default.nix index a2dfd52d18cf82..19def0a87cbe01 100644 --- a/pkgs/tools/misc/eludris/default.nix +++ b/pkgs/tools/misc/eludris/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchFromGitHub -, rustPlatform -, openssl -, pkg-config +{ + lib, + fetchFromGitHub, + rustPlatform, + openssl, + pkg-config, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/tools/misc/envchain/default.nix b/pkgs/tools/misc/envchain/default.nix index 22a0075363994f..cfbc7b343d1b31 100644 --- a/pkgs/tools/misc/envchain/default.nix +++ b/pkgs/tools/misc/envchain/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, libedit, libsecret, ncurses, pkg-config, readline, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + libedit, + libsecret, + ncurses, + pkg-config, + readline, + Security, +}: stdenv.mkDerivation rec { pname = "envchain"; @@ -17,8 +27,16 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libsecret readline ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libedit ncurses Security ]; + buildInputs = + [ + libsecret + readline + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libedit + ncurses + Security + ]; makeFlags = [ "DESTDIR=$(out)" ]; diff --git a/pkgs/tools/misc/esphome/dashboard.nix b/pkgs/tools/misc/esphome/dashboard.nix index 94b012aa366fe5..23747aed378768 100644 --- a/pkgs/tools/misc/esphome/dashboard.nix +++ b/pkgs/tools/misc/esphome/dashboard.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, fetchNpmDeps - -# build-system -, setuptools -, nodejs -, npmHooks +{ + lib, + buildPythonPackage, + fetchFromGitHub, + fetchNpmDeps, + + # build-system + setuptools, + nodejs, + npmHooks, }: diff --git a/pkgs/tools/misc/esphome/default.nix b/pkgs/tools/misc/esphome/default.nix index 5b6044681ed8ad..7d5876fa4666fa 100644 --- a/pkgs/tools/misc/esphome/default.nix +++ b/pkgs/tools/misc/esphome/default.nix @@ -1,14 +1,15 @@ -{ lib -, callPackage -, python3Packages -, fetchFromGitHub -, installShellFiles -, platformio -, esptool -, git -, inetutils -, stdenv -, nixosTests +{ + lib, + callPackage, + python3Packages, + fetchFromGitHub, + installShellFiles, + platformio, + esptool, + git, + inetutils, + stdenv, + nixosTests, }: let @@ -102,7 +103,14 @@ python.pkgs.buildPythonApplication rec { # esptool is used in esphome/__main__.py # git is used in esphome/writer.py # inetutils is used in esphome/dashboard/status/ping.py - "--prefix PATH : ${lib.makeBinPath [ platformio esptool git inetutils ]}" + "--prefix PATH : ${ + lib.makeBinPath [ + platformio + esptool + git + inetutils + ] + }" "--prefix PYTHONPATH : ${python.pkgs.makePythonPath dependencies}" # will show better error messages "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ stdenv.cc.cc ]}" "--set ESPHOME_USE_SUBPROCESS ''" @@ -151,7 +159,10 @@ python.pkgs.buildPythonApplication rec { mit # The C++/runtime codebase of the ESPHome project (file extensions .c, .cpp, .h, .hpp, .tcc, .ino) gpl3Only # The python codebase and all other parts of this codebase ]; - maintainers = with maintainers; [ globin hexa ]; + maintainers = with maintainers; [ + globin + hexa + ]; mainProgram = "esphome"; }; } diff --git a/pkgs/tools/misc/esphome/update.nix b/pkgs/tools/misc/esphome/update.nix index 6b05162f3955f5..7d264259ebf948 100644 --- a/pkgs/tools/misc/esphome/update.nix +++ b/pkgs/tools/misc/esphome/update.nix @@ -1,15 +1,25 @@ -{ writeShellScript -, lib -, curl -, jq -, git -, gnugrep -, gnused -, nix-update +{ + writeShellScript, + lib, + curl, + jq, + git, + gnugrep, + gnused, + nix-update, }: writeShellScript "update-esphome" '' - PATH=${lib.makeBinPath [ curl gnugrep gnused jq git nix-update ]} + PATH=${ + lib.makeBinPath [ + curl + gnugrep + gnused + jq + git + nix-update + ] + } LATEST=$(curl https://api.github.com/repos/esphome/esphome/releases/latest | jq -r '.name') echo "Latest version: $LATEST" diff --git a/pkgs/tools/misc/fclones/default.nix b/pkgs/tools/misc/fclones/default.nix index f7a70b966acf6a..01948b1ba56609 100644 --- a/pkgs/tools/misc/fclones/default.nix +++ b/pkgs/tools/misc/fclones/default.nix @@ -1,8 +1,9 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -35,7 +36,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/pkolaczk/fclones"; changelog = "https://github.com/pkolaczk/fclones/releases/tag/${src.rev}"; license = licenses.mit; - maintainers = with maintainers; [ cyounkins figsoda ]; + maintainers = with maintainers; [ + cyounkins + figsoda + ]; mainProgram = "fclones"; }; } diff --git a/pkgs/tools/misc/fclones/gui.nix b/pkgs/tools/misc/fclones/gui.nix index e5e611336439e0..38eae30a59b208 100644 --- a/pkgs/tools/misc/fclones/gui.nix +++ b/pkgs/tools/misc/fclones/gui.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, wrapGAppsHook4 -, gdk-pixbuf -, gtk4 -, libadwaita -, stdenv -, darwin +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + wrapGAppsHook4, + gdk-pixbuf, + gtk4, + libadwaita, + stdenv, + darwin, }: rustPlatform.buildRustPackage rec { @@ -28,13 +29,15 @@ rustPlatform.buildRustPackage rec { wrapGAppsHook4 ]; - buildInputs = [ - gdk-pixbuf - gtk4 - libadwaita - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk_11_0.frameworks.IOKit - ]; + buildInputs = + [ + gdk-pixbuf + gtk4 + libadwaita + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk_11_0.frameworks.IOKit + ]; postInstall = '' substituteInPlace snap/gui/fclones-gui.desktop \ diff --git a/pkgs/tools/misc/fffuu/default.nix b/pkgs/tools/misc/fffuu/default.nix index 53f8397a6d450d..2b6172d852fc34 100644 --- a/pkgs/tools/misc/fffuu/default.nix +++ b/pkgs/tools/misc/fffuu/default.nix @@ -1,4 +1,9 @@ -{ mkDerivation, haskellPackages, fetchFromGitHub, lib }: +{ + mkDerivation, + haskellPackages, + fetchFromGitHub, + lib, +}: mkDerivation { pname = "fffuu"; diff --git a/pkgs/tools/misc/ffsend/default.nix b/pkgs/tools/misc/ffsend/default.nix index c24650d4ffbc9c..f2de570ff6065c 100644 --- a/pkgs/tools/misc/ffsend/default.nix +++ b/pkgs/tools/misc/ffsend/default.nix @@ -1,10 +1,19 @@ -{ lib, stdenv, fetchFromGitLab, fetchpatch, rustPlatform, pkg-config, openssl -, installShellFiles -, Security, AppKit +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + rustPlatform, + pkg-config, + openssl, + installShellFiles, + Security, + AppKit, -, x11Support ? stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isBSD -, xclip ? null, xsel ? null -, preferXsel ? false # if true and xsel is non-null, use it instead of xclip + x11Support ? stdenv.hostPlatform.isLinux || stdenv.hostPlatform.isBSD, + xclip ? null, + xsel ? null, + preferXsel ? false, # if true and xsel is non-null, use it instead of xclip }: let @@ -57,18 +66,27 @@ rustPlatform.buildRustPackage rec { }) ]; - nativeBuildInputs = [ installShellFiles ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ]; + nativeBuildInputs = [ + installShellFiles + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ]; buildInputs = - if stdenv.hostPlatform.isDarwin then [ Security AppKit ] - else [ openssl ]; + if stdenv.hostPlatform.isDarwin then + [ + Security + AppKit + ] + else + [ openssl ]; preBuild = lib.optionalString (x11Support && usesX11) ( - if preferXsel && xsel != null then '' - export XSEL_PATH="${xsel}/bin/xsel" - '' else '' - export XCLIP_PATH="${xclip}/bin/xclip" - '' + if preferXsel && xsel != null then + '' + export XSEL_PATH="${xsel}/bin/xsel" + '' + else + '' + export XCLIP_PATH="${xclip}/bin/xclip" + '' ); postInstall = '' diff --git a/pkgs/tools/misc/file/default.nix b/pkgs/tools/misc/file/default.nix index f0bc89d466f528..6213406244270f 100644 --- a/pkgs/tools/misc/file/default.nix +++ b/pkgs/tools/misc/file/default.nix @@ -1,6 +1,12 @@ -{ lib, stdenv, fetchurl, file, zlib, libgnurx -, updateAutotoolsGnuConfigScriptsHook -, testers +{ + lib, + stdenv, + fetchurl, + file, + zlib, + libgnurx, + updateAutotoolsGnuConfigScriptsHook, + testers, }: # Note: this package is used for bootstrapping fetchurl, and thus @@ -20,7 +26,11 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-/Jf1ECm7DiyfTjv/79r2ePDgOe6HK53lwAKm0Jx4TYI="; }; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; patches = [ # Upstream patch to fix 32-bit tests. @@ -31,10 +41,10 @@ stdenv.mkDerivation (finalAttrs: { strictDeps = true; enableParallelBuilding = true; - nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook ] - ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) file; - buildInputs = [ zlib ] - ++ lib.optional stdenv.hostPlatform.isWindows libgnurx; + nativeBuildInputs = [ + updateAutotoolsGnuConfigScriptsHook + ] ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) file; + buildInputs = [ zlib ] ++ lib.optional stdenv.hostPlatform.isWindows libgnurx; # https://bugs.astron.com/view.php?id=382 doCheck = !stdenv.buildPlatform.isMusl; diff --git a/pkgs/tools/misc/findutils/default.nix b/pkgs/tools/misc/findutils/default.nix index 239aa98b04e043..e7d4f5bbd34de9 100644 --- a/pkgs/tools/misc/findutils/default.nix +++ b/pkgs/tools/misc/findutils/default.nix @@ -1,6 +1,9 @@ -{ lib, stdenv, fetchurl -, updateAutotoolsGnuConfigScriptsHook -, coreutils +{ + lib, + stdenv, + fetchurl, + updateAutotoolsGnuConfigScriptsHook, + coreutils, }: # Note: this package is used for bootstrapping fetchurl, and thus @@ -27,14 +30,18 @@ stdenv.mkDerivation rec { buildInputs = [ coreutils ]; # bin/updatedb script needs to call sort # Since glibc-2.25 the i686 tests hang reliably right after test-sleep. - doCheck - = !stdenv.hostPlatform.isDarwin + doCheck = + !stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isFreeBSD && !(stdenv.hostPlatform.libc == "glibc" && stdenv.hostPlatform.isi686) && (stdenv.hostPlatform.libc != "musl") && stdenv.hostPlatform == stdenv.buildPlatform; - outputs = [ "out" "info" "locate"]; + outputs = [ + "out" + "info" + "locate" + ]; configureFlags = [ # "sort" need not be on the PATH as a run-time dep, so we need to tell diff --git a/pkgs/tools/misc/flowgger/default.nix b/pkgs/tools/misc/flowgger/default.nix index 1cff8298ca9beb..0ad0f183b54093 100644 --- a/pkgs/tools/misc/flowgger/default.nix +++ b/pkgs/tools/misc/flowgger/default.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, stdenv -, fetchCrate -, pkg-config -, openssl -, capnproto -, CoreServices +{ + lib, + rustPlatform, + stdenv, + fetchCrate, + pkg-config, + openssl, + capnproto, + CoreServices, }: rustPlatform.buildRustPackage rec { @@ -24,8 +25,7 @@ rustPlatform.buildRustPackage rec { capnproto ]; - buildInputs = [ openssl ] - ++ lib.optional stdenv.hostPlatform.isDarwin CoreServices; + buildInputs = [ openssl ] ++ lib.optional stdenv.hostPlatform.isDarwin CoreServices; checkFlags = [ # test failed diff --git a/pkgs/tools/misc/fltrdr/default.nix b/pkgs/tools/misc/fltrdr/default.nix index db7cd2afffced9..f70e9a5a25836c 100644 --- a/pkgs/tools/misc/fltrdr/default.nix +++ b/pkgs/tools/misc/fltrdr/default.nix @@ -1,7 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, cmake -, icu, openssl +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + icu, + openssl, }: stdenv.mkDerivation rec { @@ -9,15 +12,18 @@ stdenv.mkDerivation rec { version = "0.3.1"; src = fetchFromGitHub { - repo = "fltrdr"; - owner = "octobanana"; - rev = version; + repo = "fltrdr"; + owner = "octobanana"; + rev = version; sha256 = "1vpci7vqzcpdd21zgigyz38k77r9fc81dmiwsvfr8w7gad5sg6sj"; }; nativeBuildInputs = [ cmake ]; - buildInputs = [ icu openssl ]; + buildInputs = [ + icu + openssl + ]; meta = with lib; { homepage = "https://octobanana.com/software/fltrdr"; @@ -33,8 +39,8 @@ stdenv.mkDerivation rec { setting. ''; - platforms = platforms.linux; # can only test linux - license = licenses.mit; + platforms = platforms.linux; # can only test linux + license = licenses.mit; maintainers = [ maintainers.matthiasbeyer ]; mainProgram = "fltrdr"; }; diff --git a/pkgs/tools/misc/fluentd/default.nix b/pkgs/tools/misc/fluentd/default.nix index de21fe7dadefd0..e87f69408ac837 100644 --- a/pkgs/tools/misc/fluentd/default.nix +++ b/pkgs/tools/misc/fluentd/default.nix @@ -1,4 +1,10 @@ -{ lib, bundlerEnv, ruby, bundlerUpdateScript, nixosTests }: +{ + lib, + bundlerEnv, + ruby, + bundlerUpdateScript, + nixosTests, +}: bundlerEnv { inherit ruby; @@ -11,9 +17,12 @@ bundlerEnv { meta = with lib; { description = "Data collector"; - homepage = "https://www.fluentd.org/"; - license = licenses.asl20; - maintainers = with maintainers; [ offline nicknovitski ]; - platforms = platforms.unix; + homepage = "https://www.fluentd.org/"; + license = licenses.asl20; + maintainers = with maintainers; [ + offline + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/tools/misc/fluentd/gemset.nix b/pkgs/tools/misc/fluentd/gemset.nix index 16417bb0e4e97f..2f0bfad5d870d9 100644 --- a/pkgs/tools/misc/fluentd/gemset.nix +++ b/pkgs/tools/misc/fluentd/gemset.nix @@ -1,683 +1,782 @@ { mini_portile2 = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0z7f38iq37h376n9xbl4gajdrnwzq284c9v1py4imw3gri2d5cj6"; type = "gem"; }; version = "2.8.2"; }; racc = { - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "09jgz6r0f7v84a7jz9an85q8vvmp743dqcsdm3z9c8rqcqv6pljq"; type = "gem"; }; version = "1.6.2"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default" "development" "test"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ + "default" + "development" + "test" + ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1mr2ibfk874ncv0qbdkynay738w2mfinlkhnbd5lyk5yiw5q1p10"; type = "gem"; }; version = "1.15.2"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ypdmpdn20hxp5vwxz3zc04r5xcwqc25qszdlg41h8ghdqbllwmw"; type = "gem"; }; version = "2.8.1"; }; aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pyis1nvnbjxk12a43xvgj2gv0mvp4cnkc1gzw0v1018r61399gz"; type = "gem"; }; version = "1.2.0"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c6w07lm5ssn0v06sh90g3swqb42ma65pfz0qlk3hqlj1fs5zd9b"; type = "gem"; }; version = "1.677.0"; }; aws-sdk-cloudwatchlogs = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0yhwbr3g9brh7g8vjxygfvhlc9sa04g5bzyhkdcdkl7faqpy93z3"; type = "gem"; }; version = "1.58.0"; }; aws-sdk-core = { - dependencies = ["aws-eventstream" "aws-partitions" "aws-sigv4" "jmespath" "nokogiri"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-eventstream" + "aws-partitions" + "aws-sigv4" + "jmespath" + "nokogiri" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "131acgw2hi893n0dfbczs42bkc41afhyrmd9w8zx5y8r1k5zd6rc"; type = "gem"; }; version = "3.168.4"; }; aws-sdk-firehose = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "02lznpqdmla1i5ilxn6kkbdwasl2w4m9ml09whig9wwrlwjfkdnm"; type = "gem"; }; version = "1.50.0"; }; aws-sdk-kinesis = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0n6jdkcyh9cm4f15zmmgpzwxbal5dg2w17xcm65d1gf9dwajsjda"; type = "gem"; }; version = "1.42.0"; }; aws-sdk-kms = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ajp7yvnf95d60xmg618xznfwsy8h1vrkzj33r1bsf2gsfp50vzy"; type = "gem"; }; version = "1.61.0"; }; aws-sdk-s3 = { - dependencies = ["aws-sdk-core" "aws-sdk-kms" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sdk-kms" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1xpb8c8zw1c0grbw1rcc0ynlys1301vm9kkqy4ls3i2zqk5v6n91"; type = "gem"; }; version = "1.117.2"; }; aws-sdk-sqs = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1hirj20g7nnyf0xhxwvgfl12nypm1r5id16ccc8y1rbasclxs897"; type = "gem"; }; version = "1.52.1"; }; aws-sigv4 = { - dependencies = ["aws-eventstream"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-eventstream" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11hkna2av47bl0yprgp8k4ya70rc3m2ib5w10fn0piplgkkmhz7m"; type = "gem"; }; version = "1.5.2"; }; bson = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19vgs9rzzyvd7jfrzynjnc6518q0ffpfciyicfywbp77zl8nc9hk"; type = "gem"; }; version = "4.15.0"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0s4fpn3mqiizpmpy2a24k4v365pv75y50292r8ajrv4i1p5b2k14"; type = "gem"; }; version = "1.1.10"; }; "cool.io" = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dfq4h168wzvs9cvn2mm8648ynkl936pgjva2p8ik34p6d620537"; type = "gem"; }; version = "1.7.1"; }; digest-crc = { - dependencies = ["rake"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rake" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1czaak53w8n13y1fr0q23gp0fhklvxjac5n562qj3xk6sh5ad0x2"; type = "gem"; }; version = "0.6.4"; }; elastic-transport = { - dependencies = ["faraday" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0w5l26fwyby8pjcyyap015q5lxc619j8ig6af5slbp9l2x7kjaby"; type = "gem"; }; version = "8.1.0"; }; elasticsearch = { - dependencies = ["elastic-transport" "elasticsearch-api"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "elastic-transport" + "elasticsearch-api" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0mwrf667p3n0xdashlk3m66a7vcqsg4vnr5icm7jgdd71qr4yvds"; type = "gem"; }; version = "8.5.2"; }; elasticsearch-api = { - dependencies = ["multi_json"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multi_json" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "138s5rcy5j63sjf6k8av8gaxn46nh8nf1bwxyxfygyy3q2q9m4vs"; type = "gem"; }; version = "8.5.2"; }; excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08idrrnpwzr87wc5yhyv6id1f6zigr3nfn45mff01605b0zghdby"; type = "gem"; }; version = "0.95.0"; }; faraday = { - dependencies = ["faraday-em_http" "faraday-em_synchrony" "faraday-excon" "faraday-httpclient" "faraday-multipart" "faraday-net_http" "faraday-net_http_persistent" "faraday-patron" "faraday-rack" "faraday-retry" "ruby2_keywords"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-em_http" + "faraday-em_synchrony" + "faraday-excon" + "faraday-httpclient" + "faraday-multipart" + "faraday-net_http" + "faraday-net_http_persistent" + "faraday-patron" + "faraday-rack" + "faraday-retry" + "ruby2_keywords" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1d5ipsv069dhgv9zhxgj8pz4j52yhgvfm01aq881yz7qgjd7ilxp"; type = "gem"; }; version = "1.10.2"; }; faraday-em_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12cnqpbak4vhikrh2cdn94assh3yxza8rq2p9w2j34bqg5q4qgbs"; type = "gem"; }; version = "1.0.0"; }; faraday-em_synchrony = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vgrbhkp83sngv6k4mii9f2s9v5lmp693hylfxp2ssfc60fas3a6"; type = "gem"; }; version = "1.0.0"; }; faraday-excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h09wkb0k0bhm6dqsd47ac601qiaah8qdzjh8gvxfd376x1chmdh"; type = "gem"; }; version = "1.1.0"; }; faraday-httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fyk0jd3ks7fdn8nv3spnwjpzx2lmxmg2gh4inz3by1zjzqg33sc"; type = "gem"; }; version = "1.0.1"; }; faraday-multipart = { - dependencies = ["multipart-post"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multipart-post" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09871c4hd7s5ws1wl4gs7js1k2wlby6v947m2bbzg43pnld044lh"; type = "gem"; }; version = "1.0.4"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fi8sda5hc54v1w3mqfl5yz09nhx35kglyx72w7b8xxvdr0cwi9j"; type = "gem"; }; version = "1.0.1"; }; faraday-net_http_persistent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dc36ih95qw3rlccffcb0vgxjhmipsvxhn6cw71l7ffs0f7vq30b"; type = "gem"; }; version = "1.2.0"; }; faraday-patron = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19wgsgfq0xkski1g7m96snv39la3zxz6x7nbdgiwhg5v82rxfb6w"; type = "gem"; }; version = "1.0.0"; }; faraday-rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h184g4vqql5jv9s9im6igy00jp6mrah2h14py6mpf9bkabfqq7g"; type = "gem"; }; version = "1.0.0"; }; faraday-retry = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "153i967yrwnswqgvnnajgwp981k9p50ys1h80yz3q94rygs59ldd"; type = "gem"; }; version = "1.0.3"; }; fluent-config-regexp-type = { - dependencies = ["fluentd"]; - groups = ["default"]; - platforms = []; + dependencies = [ "fluentd" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hk0vxcmlbid7n6piyv3x83j5gyiz7in397l9x3c6nh69wicy7gm"; type = "gem"; }; version = "1.0.0"; }; fluent-plugin-cloudwatch-logs = { - dependencies = ["aws-sdk-cloudwatchlogs" "fluentd"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-cloudwatchlogs" + "fluentd" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "139d7qv4my818mhjp0104ns9dlndlvrb6dgxa2rkv6jlzlamjpjb"; type = "gem"; }; version = "0.14.3"; }; fluent-plugin-concat = { - dependencies = ["fluentd"]; - groups = ["default"]; - platforms = []; + dependencies = [ "fluentd" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1b9z6hrjcsvccfimmgczzcbhvf2zwyqzvsdc29i2biqhk1mcwn3k"; type = "gem"; }; version = "2.5.0"; }; fluent-plugin-elasticsearch = { - dependencies = ["elasticsearch" "excon" "faraday" "fluentd"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "elasticsearch" + "excon" + "faraday" + "fluentd" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "136nsmi15vcn0var59j1vqkysvmcp7y8fva25gkcx3hx1l92bxwh"; type = "gem"; }; version = "5.2.4"; }; fluent-plugin-kafka = { - dependencies = ["fluentd" "ltsv" "ruby-kafka"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "fluentd" + "ltsv" + "ruby-kafka" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ggiq89brahyamnw4sn4pmfqsw8xjz2k9k9hajsjlzkm9djppdwf"; type = "gem"; }; version = "0.18.1"; }; fluent-plugin-kinesis = { - dependencies = ["aws-sdk-firehose" "aws-sdk-kinesis" "fluentd" "google-protobuf"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-firehose" + "aws-sdk-kinesis" + "fluentd" + "google-protobuf" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07n5pzfz143hlvbzbx5rczb33ai9kdp48vhdak100m6xpaqkvc2p"; type = "gem"; }; version = "3.4.2"; }; fluent-plugin-mongo = { - dependencies = ["fluentd" "mongo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "fluentd" + "mongo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1m3fa6fwpzxw08lnczsif5c7v33yryyvgb1lbp7a7qjhipvb6jfm"; type = "gem"; }; version = "1.6.0"; }; fluent-plugin-record-reformer = { - dependencies = ["fluentd"]; - groups = ["default"]; - platforms = []; + dependencies = [ "fluentd" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gwfrfyi9is4l9q4ih3c4l3c9qvyh00jnd2qajdpdh5xjj2m7akn"; type = "gem"; }; version = "0.9.1"; }; fluent-plugin-rewrite-tag-filter = { - dependencies = ["fluent-config-regexp-type" "fluentd"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "fluent-config-regexp-type" + "fluentd" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1vjvn8ph87cl2dl0dbaap69rciglsdma1y5ghn2vm5mvh5h7xbs6"; type = "gem"; }; version = "2.4.0"; }; fluent-plugin-s3 = { - dependencies = ["aws-sdk-s3" "aws-sdk-sqs" "fluentd"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-s3" + "aws-sdk-sqs" + "fluentd" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "04yvxhynjqm35dycrxqwfw9r7mv6ycyda1wvki27z5hpsdy57b1m"; type = "gem"; }; version = "1.7.2"; }; fluent-plugin-webhdfs = { - dependencies = ["fluentd" "webhdfs"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "fluentd" + "webhdfs" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1llpsbd5n2lgxbq16px5hbp3zfw65bdp46b08v87b6rmn3h47aiv"; type = "gem"; }; version = "1.5.0"; }; fluentd = { - dependencies = ["cool.io" "http_parser.rb" "msgpack" "serverengine" "sigdump" "strptime" "tzinfo" "tzinfo-data" "webrick" "yajl-ruby"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "cool.io" + "http_parser.rb" + "msgpack" + "serverengine" + "sigdump" + "strptime" + "tzinfo" + "tzinfo-data" + "webrick" + "yajl-ruby" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1jn1i14zaw2pf4j6i7g7cj0h8j94wrcbn0an8w44h7g5mazl98nn"; type = "gem"; }; version = "1.15.3"; }; google-protobuf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dcgkhjiaxha3yznyxxzm8a4n4jf61rk7kgbxy4sdkb865zbn2ab"; type = "gem"; }; version = "3.21.12"; }; "http_parser.rb" = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gj4fmls0mf52dlr928gaq0c0cb0m3aqa9kaa6l0ikl2zbqk42as"; type = "gem"; }; version = "0.8.0"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cdw9vw2qly7q7r41s7phnac264rbsdqgj4l0h4nqgbjb157g393"; type = "gem"; }; version = "1.6.2"; }; ltsv = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wrjvc5079zhpn62k1yflrf7js6vaysrg1qwggf7bj2zi0p5rhys"; type = "gem"; }; version = "0.1.2"; }; mongo = { - dependencies = ["bson"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bson" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ldpcyqhgvdn7rd1vdbv2n3xnr6ajw7964yb9gr44nv7z35fd7kn"; type = "gem"; }; version = "2.18.2"; }; msgpack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q03pb0vq8388s431nbxabsfxnch6p304c8vnjlk0zzpcv713yr3"; type = "gem"; }; version = "1.6.0"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n0kvnrcrjn31jb97kcx3wj1f5kkjza7yygfq8rxzf3i57g7jaa6"; type = "gem"; }; version = "2.2.3"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hz0bx2qs2pwb0bwazzsah03ilpf3aai8b7lk7s35jsfzwbkjq35"; type = "gem"; }; version = "5.0.1"; }; rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15whn7p9nrkxangbs9hh75q585yfn66lv0v2mhj6q6dl6x8bzr2w"; type = "gem"; }; version = "13.0.6"; }; ruby-kafka = { - dependencies = ["digest-crc"]; - groups = ["default"]; - platforms = []; + dependencies = [ "digest-crc" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13i3fvjy0n1n1aa71b30nwx2xchhsps3yhi17r0s6ay7wr26jr7p"; type = "gem"; }; version = "1.5.0"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; serverengine = { - dependencies = ["sigdump"]; - groups = ["default"]; - platforms = []; + dependencies = [ "sigdump" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1snxfmkmmxpdica8629gdl6qj3xradcx787ccvhfa90gh8wyfqqj"; type = "gem"; }; version = "2.3.0"; }; sigdump = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1mqf06iw7rymv54y7rgbmfi6ppddgjjmxzi3hrw658n1amp1gwhb"; type = "gem"; }; version = "0.2.4"; }; strptime = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ycs0xz58kymf7yp4h56f0nid2z7g3s18dj7pa3p790pfzzpgvcq"; type = "gem"; }; version = "0.2.5"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rx114mpqnw2k4h98vc0rs0x0bmf0img84yh8mkkjkal07cjydf5"; type = "gem"; }; version = "2.0.5"; }; tzinfo-data = { - dependencies = ["tzinfo"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tzinfo" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0drm9pygji01pyimxq65ngdvgpn228g7fhffmrqw0xn7l2rdhclp"; type = "gem"; }; version = "1.2022.7"; }; webhdfs = { - dependencies = ["addressable"]; - groups = ["default"]; - platforms = []; + dependencies = [ "addressable" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pkdsj8ybjfp1sr7gzdxd7van5fpmhc9v2c5g3hifdx4s4yzhcq7"; type = "gem"; }; version = "0.10.2"; }; webrick = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d4cvgmxhfczxiq5fr534lmizkhigd15bsx5719r5ds7k7ivisc7"; type = "gem"; }; version = "1.7.0"; }; yajl-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1lni4jbyrlph7sz8y49q84pb0sbj82lgwvnjnsiv01xf26f4v5wc"; type = "gem"; }; diff --git a/pkgs/tools/misc/fondu/default.nix b/pkgs/tools/misc/fondu/default.nix index fe6ab396d139d5..d51d09a469cadf 100644 --- a/pkgs/tools/misc/fondu/default.nix +++ b/pkgs/tools/misc/fondu/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, CoreServices }: +{ + lib, + stdenv, + fetchurl, + CoreServices, +}: stdenv.mkDerivation rec { version = "060102"; diff --git a/pkgs/tools/misc/freshfetch/default.nix b/pkgs/tools/misc/freshfetch/default.nix index ccbaa1f1bfa8c3..a8e327120484cc 100644 --- a/pkgs/tools/misc/freshfetch/default.nix +++ b/pkgs/tools/misc/freshfetch/default.nix @@ -1,12 +1,13 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, AppKit -, CoreFoundation -, DiskArbitration -, Foundation -, IOKit +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + AppKit, + CoreFoundation, + DiskArbitration, + Foundation, + IOKit, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/tools/misc/fwup/default.nix b/pkgs/tools/misc/fwup/default.nix index 7740cbb32f5681..1c68448b9729ef 100644 --- a/pkgs/tools/misc/fwup/default.nix +++ b/pkgs/tools/misc/fwup/default.nix @@ -1,22 +1,23 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoreconfHook -, DiskArbitration -, pkg-config -, bzip2 -, libarchive -, libconfuse -, libsodium -, xz -, zlib -, coreutils -, dosfstools -, mtools -, unzip -, zip -, which -, xdelta +{ + stdenv, + lib, + fetchFromGitHub, + autoreconfHook, + DiskArbitration, + pkg-config, + bzip2, + libarchive, + libconfuse, + libsodium, + xz, + zlib, + coreutils, + dosfstools, + mtools, + unzip, + zip, + which, + xdelta, }: stdenv.mkDerivation rec { @@ -35,25 +36,29 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - bzip2 - libarchive - libconfuse - libsodium - xz - zlib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - DiskArbitration - ]; + buildInputs = + [ + bzip2 + libarchive + libconfuse + libsodium + xz + zlib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + DiskArbitration + ]; - propagatedBuildInputs = [ - coreutils - unzip - zip - ] ++ lib.optionals doCheck [ - mtools - dosfstools - ]; + propagatedBuildInputs = + [ + coreutils + unzip + zip + ] + ++ lib.optionals doCheck [ + mtools + dosfstools + ]; nativeCheckInputs = [ which diff --git a/pkgs/tools/misc/gams/default.nix b/pkgs/tools/misc/gams/default.nix index be71618aae204f..c69f98a9ca237f 100644 --- a/pkgs/tools/misc/gams/default.nix +++ b/pkgs/tools/misc/gams/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, unzip, file, licenseFile ? null, optgamsFile ? null}: +{ + lib, + stdenv, + fetchurl, + unzip, + file, + licenseFile ? null, + optgamsFile ? null, +}: assert licenseFile != null; @@ -14,15 +22,17 @@ stdenv.mkDerivation rec { buildInputs = [ file ]; dontBuild = true; - installPhase = '' - mkdir -p "$out/bin" "$out/share/gams" - cp -a * "$out/share/gams" + installPhase = + '' + mkdir -p "$out/bin" "$out/share/gams" + cp -a * "$out/share/gams" - cp ${licenseFile} $out/share/gams/gamslice.txt - '' + lib.optionalString (optgamsFile != null) '' - cp ${optgamsFile} $out/share/gams/optgams.def - ln -s $out/share/gams/optgams.def $out/bin/optgams.def - ''; + cp ${licenseFile} $out/share/gams/gamslice.txt + '' + + lib.optionalString (optgamsFile != null) '' + cp ${optgamsFile} $out/share/gams/optgams.def + ln -s $out/share/gams/optgams.def $out/bin/optgams.def + ''; postFixup = '' for f in $out/share/gams/*; do @@ -36,7 +46,7 @@ stdenv.mkDerivation rec { done ''; - meta = with lib;{ + meta = with lib; { description = "General Algebraic Modeling System"; longDescription = '' The General Algebraic Modeling System is a high-level modeling system for mathematical optimization. @@ -49,4 +59,3 @@ stdenv.mkDerivation rec { platforms = platforms.linux; }; } - diff --git a/pkgs/tools/misc/gaphor/default.nix b/pkgs/tools/misc/gaphor/default.nix index ab017fb6065af9..b08ba08b794c55 100644 --- a/pkgs/tools/misc/gaphor/default.nix +++ b/pkgs/tools/misc/gaphor/default.nix @@ -1,29 +1,30 @@ -{ lib -, buildPythonApplication -, fetchPypi -, copyDesktopItems -, gobject-introspection -, poetry-core -, wrapGAppsHook4 -, gtksourceview5 -, libadwaita -, pango -, gaphas -, generic -, jedi -, pycairo -, pillow -, dulwich -, pydot -, defusedxml -, better-exceptions -, babel -, pygobject3 -, tinycss2 -, gtk4 -, librsvg -, makeDesktopItem -, python +{ + lib, + buildPythonApplication, + fetchPypi, + copyDesktopItems, + gobject-introspection, + poetry-core, + wrapGAppsHook4, + gtksourceview5, + libadwaita, + pango, + gaphas, + generic, + jedi, + pycairo, + pillow, + dulwich, + pydot, + defusedxml, + better-exceptions, + babel, + pygobject3, + tinycss2, + gtk4, + librsvg, + makeDesktopItem, + python, }: buildPythonApplication rec { diff --git a/pkgs/tools/misc/gazelle-origin/default.nix b/pkgs/tools/misc/gazelle-origin/default.nix index 924c0ba8df7b32..37ef0aedd9ccc1 100644 --- a/pkgs/tools/misc/gazelle-origin/default.nix +++ b/pkgs/tools/misc/gazelle-origin/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, bencoder -, pyyaml -, requests +{ + lib, + buildPythonApplication, + fetchFromGitHub, + bencoder, + pyyaml, + requests, }: buildPythonApplication rec { pname = "gazelle-origin"; diff --git a/pkgs/tools/misc/gbdfed/default.nix b/pkgs/tools/misc/gbdfed/default.nix index 9ad0590c96d51f..1d72d2c05f441f 100644 --- a/pkgs/tools/misc/gbdfed/default.nix +++ b/pkgs/tools/misc/gbdfed/default.nix @@ -1,4 +1,11 @@ - { lib, stdenv, fetchurl, pkg-config, freetype, gtk }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + freetype, + gtk, +}: stdenv.mkDerivation rec { version = "1.6"; @@ -10,7 +17,10 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ freetype gtk ]; + buildInputs = [ + freetype + gtk + ]; patches = [ ./Makefile.patch ]; diff --git a/pkgs/tools/misc/geekbench/4.nix b/pkgs/tools/misc/geekbench/4.nix index bd60ee701ae374..7e3b75a198bb40 100644 --- a/pkgs/tools/misc/geekbench/4.nix +++ b/pkgs/tools/misc/geekbench/4.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, addDriverRunpath -, makeWrapper -, ocl-icd -, vulkan-loader +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + addDriverRunpath, + makeWrapper, + ocl-icd, + vulkan-loader, }: stdenv.mkDerivation rec { @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { dontConfigure = true; dontBuild = true; - nativeBuildInputs = [ autoPatchelfHook makeWrapper ]; + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + ]; buildInputs = [ stdenv.cc.cc ]; installPhase = '' @@ -31,11 +35,13 @@ stdenv.mkDerivation rec { for f in geekbench4 geekbench_x86_64 ; do wrapProgram $out/bin/$f \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ - addDriverRunpath.driverLink - ocl-icd - vulkan-loader - ]}" + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + addDriverRunpath.driverLink + ocl-icd + vulkan-loader + ] + }" done runHook postInstall diff --git a/pkgs/tools/misc/geekbench/5.nix b/pkgs/tools/misc/geekbench/5.nix index c7504585dc0f27..0bec3ca724a20a 100644 --- a/pkgs/tools/misc/geekbench/5.nix +++ b/pkgs/tools/misc/geekbench/5.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, addDriverRunpath -, makeWrapper -, ocl-icd -, vulkan-loader +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + addDriverRunpath, + makeWrapper, + ocl-icd, + vulkan-loader, }: let @@ -26,12 +27,17 @@ stdenv.mkDerivation { inherit version; pname = "geekbench"; - src = fetchurl (sources.${stdenv.system} or (throw "unsupported system ${stdenv.hostPlatform.system}")); + src = fetchurl ( + sources.${stdenv.system} or (throw "unsupported system ${stdenv.hostPlatform.system}") + ); dontConfigure = true; dontBuild = true; - nativeBuildInputs = [ autoPatchelfHook makeWrapper ]; + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + ]; buildInputs = [ (lib.getLib stdenv.cc.cc) ]; @@ -43,11 +49,13 @@ stdenv.mkDerivation { for f in geekbench5 geekbench_${processor} ; do wrapProgram $out/bin/$f \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ - addDriverRunpath.driverLink - ocl-icd - vulkan-loader - ]}" + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + addDriverRunpath.driverLink + ocl-icd + vulkan-loader + ] + }" done runHook postInstall diff --git a/pkgs/tools/misc/geekbench/6.nix b/pkgs/tools/misc/geekbench/6.nix index 6b78d65b39a146..26abefa16ae437 100644 --- a/pkgs/tools/misc/geekbench/6.nix +++ b/pkgs/tools/misc/geekbench/6.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, autoPatchelfHook -, addDriverRunpath -, makeWrapper -, ocl-icd -, vulkan-loader +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + addDriverRunpath, + makeWrapper, + ocl-icd, + vulkan-loader, }: let @@ -27,12 +28,17 @@ stdenv.mkDerivation { inherit version; pname = "geekbench"; - src = fetchurl (sources.${stdenv.system} or (throw "unsupported system ${stdenv.hostPlatform.system}")); + src = fetchurl ( + sources.${stdenv.system} or (throw "unsupported system ${stdenv.hostPlatform.system}") + ); dontConfigure = true; dontBuild = true; - nativeBuildInputs = [ autoPatchelfHook makeWrapper ]; + nativeBuildInputs = [ + autoPatchelfHook + makeWrapper + ]; buildInputs = [ (lib.getLib stdenv.cc.cc) ]; @@ -44,11 +50,13 @@ stdenv.mkDerivation { for f in geekbench6 geekbench_${processor} ${geekbench_avx2} ; do wrapProgram $out/bin/$f \ - --prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath [ - addDriverRunpath.driverLink - ocl-icd - vulkan-loader - ]}" + --prefix LD_LIBRARY_PATH : "${ + lib.makeLibraryPath [ + addDriverRunpath.driverLink + ocl-icd + vulkan-loader + ] + }" done runHook postInstall @@ -59,7 +67,10 @@ stdenv.mkDerivation { homepage = "https://geekbench.com/"; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.unfree; - maintainers = with maintainers; [ michalrus asininemonkey ]; + maintainers = with maintainers; [ + michalrus + asininemonkey + ]; platforms = builtins.attrNames sources; mainProgram = "geekbench6"; }; diff --git a/pkgs/tools/misc/gh-cal/default.nix b/pkgs/tools/misc/gh-cal/default.nix index 53e5e1d3ee7dfc..9d099cf6a7aa0e 100644 --- a/pkgs/tools/misc/gh-cal/default.nix +++ b/pkgs/tools/misc/gh-cal/default.nix @@ -1,8 +1,9 @@ -{ lib -, fetchCrate -, rustPlatform -, pkg-config -, openssl +{ + lib, + fetchCrate, + rustPlatform, + pkg-config, + openssl, }: rustPlatform.buildRustPackage rec { pname = "gh-cal"; diff --git a/pkgs/tools/misc/graylog/5.1.nix b/pkgs/tools/misc/graylog/5.1.nix index 859fab5755adb9..e20bb9a14bf3fb 100644 --- a/pkgs/tools/misc/graylog/5.1.nix +++ b/pkgs/tools/misc/graylog/5.1.nix @@ -1,7 +1,8 @@ -{ callPackage, lib, ...}: +{ callPackage, lib, ... }: let - buildGraylog = callPackage ./graylog.nix {}; -in buildGraylog { + buildGraylog = callPackage ./graylog.nix { }; +in +buildGraylog { version = "5.1.13"; hash = "sha256-qjNJ51EbPjtDR5h4DElpSblj/c8WarXxPfcLTuTx5AQ="; maintainers = [ lib.maintainers.f2k1de ]; diff --git a/pkgs/tools/misc/graylog/graylog.nix b/pkgs/tools/misc/graylog/graylog.nix index d8881cb00fe402..9e17f21515be7d 100644 --- a/pkgs/tools/misc/graylog/graylog.nix +++ b/pkgs/tools/misc/graylog/graylog.nix @@ -1,6 +1,20 @@ -{ lib, stdenv, fetchurl, makeWrapper, openjdk11_headless, openjdk17_headless, systemd, nixosTests}: +{ + lib, + stdenv, + fetchurl, + makeWrapper, + openjdk11_headless, + openjdk17_headless, + systemd, + nixosTests, +}: -{ version, hash, maintainers, license }: +{ + version, + hash, + maintainers, + license, +}: stdenv.mkDerivation rec { pname = "graylog_${lib.versions.majorMinor version}"; inherit version; @@ -14,28 +28,33 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; makeWrapperArgs = [ - "--set-default" "JAVA_HOME" "${if (lib.versionAtLeast version "5.0") then openjdk17_headless else openjdk11_headless}" + "--set-default" + "JAVA_HOME" + "${if (lib.versionAtLeast version "5.0") then openjdk17_headless else openjdk11_headless}" "--prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [ systemd ]}" ]; passthru.tests = { inherit (nixosTests) graylog; }; - installPhase = '' - mkdir -p $out - cp -r {graylog.jar,bin,plugin} $out - '' + lib.optionalString (lib.versionOlder version "4.3") '' - cp -r lib $out - '' + '' - wrapProgram $out/bin/graylogctl $makeWrapperArgs - ''; + installPhase = + '' + mkdir -p $out + cp -r {graylog.jar,bin,plugin} $out + '' + + lib.optionalString (lib.versionOlder version "4.3") '' + cp -r lib $out + '' + + '' + wrapProgram $out/bin/graylogctl $makeWrapperArgs + ''; meta = with lib; { description = "Open source log management solution"; - homepage = "https://www.graylog.org/"; + homepage = "https://www.graylog.org/"; sourceProvenance = with sourceTypes; [ binaryBytecode ]; inherit license; inherit maintainers; mainProgram = "graylogctl"; - platforms = platforms.unix; + platforms = platforms.unix; }; } diff --git a/pkgs/tools/misc/grc/default.nix b/pkgs/tools/misc/grc/default.nix index 271ef5edfbf4a2..109b1b34793868 100644 --- a/pkgs/tools/misc/grc/default.nix +++ b/pkgs/tools/misc/grc/default.nix @@ -1,7 +1,8 @@ -{ lib -, fetchFromGitHub -, buildPythonApplication -, installShellFiles +{ + lib, + fetchFromGitHub, + buildPythonApplication, + installShellFiles, }: buildPythonApplication rec { @@ -46,7 +47,11 @@ buildPythonApplication rec { beautifying your logfiles or output of commands. ''; license = licenses.gpl2Plus; - maintainers = with maintainers; [ azahi lovek323 peterhoeg ]; + maintainers = with maintainers; [ + azahi + lovek323 + peterhoeg + ]; platforms = platforms.unix; mainProgram = "grc"; }; diff --git a/pkgs/tools/misc/grex/default.nix b/pkgs/tools/misc/grex/default.nix index f3263303f96d8c..265ed57e45cb8d 100644 --- a/pkgs/tools/misc/grex/default.nix +++ b/pkgs/tools/misc/grex/default.nix @@ -1,7 +1,9 @@ -{ lib, stdenv -, fetchFromGitHub -, rustPlatform -, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, }: rustPlatform.buildRustPackage rec { @@ -30,6 +32,9 @@ rustPlatform.buildRustPackage rec { changelog = "https://github.com/pemistahl/grex/releases/tag/v${version}"; license = licenses.asl20; mainProgram = "grex"; - maintainers = with maintainers; [ SuperSandro2000 mfrw ]; + maintainers = with maintainers; [ + SuperSandro2000 + mfrw + ]; }; } diff --git a/pkgs/tools/misc/grub4dos/default.nix b/pkgs/tools/misc/grub4dos/default.nix index b18298e37b66e9..af5cc1d8b0e225 100644 --- a/pkgs/tools/misc/grub4dos/default.nix +++ b/pkgs/tools/misc/grub4dos/default.nix @@ -1,10 +1,20 @@ -{ lib, stdenv, fetchFromGitHub, nasm }: - -let arch = - if stdenv.hostPlatform.isi686 then "i386" - else if stdenv.hostPlatform.isx86_64 then "x86_64" - else throw "Unknown architecture"; -in stdenv.mkDerivation { +{ + lib, + stdenv, + fetchFromGitHub, + nasm, +}: + +let + arch = + if stdenv.hostPlatform.isi686 then + "i386" + else if stdenv.hostPlatform.isx86_64 then + "x86_64" + else + throw "Unknown architecture"; +in +stdenv.mkDerivation { pname = "grub4dos"; version = "0.4.6a-2019-05-12"; diff --git a/pkgs/tools/misc/gwe/default.nix b/pkgs/tools/misc/gwe/default.nix index b1e793572711c1..10c67af8cd80c3 100644 --- a/pkgs/tools/misc/gwe/default.nix +++ b/pkgs/tools/misc/gwe/default.nix @@ -1,37 +1,41 @@ -{ lib -, stdenv -, fetchFromGitLab -, wrapGAppsHook3 -, pkg-config -, meson -, ninja -, cmake -, gobject-introspection -, desktop-file-utils -, python3 -, gtk3 -, libdazzle -, libappindicator-gtk3 -, libnotify -, nvidia_x11 - }: +{ + lib, + stdenv, + fetchFromGitLab, + wrapGAppsHook3, + pkg-config, + meson, + ninja, + cmake, + gobject-introspection, + desktop-file-utils, + python3, + gtk3, + libdazzle, + libappindicator-gtk3, + libnotify, + nvidia_x11, +}: let - pythonEnv = python3.withPackages (pypkgs: with pypkgs; [ - injector - matplotlib - peewee - pynvml - pygobject3 - xlib - pyxdg - requests - rx - gtk3 - reactivex - setuptools - ]); -in stdenv.mkDerivation rec { + pythonEnv = python3.withPackages ( + pypkgs: with pypkgs; [ + injector + matplotlib + peewee + pynvml + pygobject3 + xlib + pyxdg + requests + rx + gtk3 + reactivex + setuptools + ] + ); +in +stdenv.mkDerivation rec { pname = "gwe"; version = "0.15.9"; @@ -75,7 +79,15 @@ in stdenv.mkDerivation rec { makeWrapper ${pythonEnv}/bin/python $out/bin/gwe \ --add-flags "$out/lib/gwe-bin" \ --prefix LD_LIBRARY_PATH : "/run/opengl-driver/lib" \ - --prefix PATH : "${builtins.concatStringsSep ":" [ (lib.makeBinPath [ nvidia_x11 nvidia_x11.settings ]) "/run/wrappers/bin" ]}" \ + --prefix PATH : "${ + builtins.concatStringsSep ":" [ + (lib.makeBinPath [ + nvidia_x11 + nvidia_x11.settings + ]) + "/run/wrappers/bin" + ] + }" \ --unset "SHELL" \ ''${gappsWrapperArgs[@]} ''; diff --git a/pkgs/tools/misc/h/default.nix b/pkgs/tools/misc/h/default.nix index 6d65accc51d544..9777c5d1a001bf 100644 --- a/pkgs/tools/misc/h/default.nix +++ b/pkgs/tools/misc/h/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, ruby }: +{ + lib, + stdenv, + fetchFromGitHub, + ruby, +}: stdenv.mkDerivation rec { pname = "h"; diff --git a/pkgs/tools/misc/haste-client/default.nix b/pkgs/tools/misc/haste-client/default.nix index eb4b6f868294f7..abaf8312dc35c8 100644 --- a/pkgs/tools/misc/haste-client/default.nix +++ b/pkgs/tools/misc/haste-client/default.nix @@ -1,5 +1,6 @@ -{ lib -, bundlerApp +{ + lib, + bundlerApp, }: bundlerApp { @@ -9,10 +10,10 @@ bundlerApp { meta = with lib; { description = "Command line interface to the AnyStyle Parser and Finder"; - homepage = "https://rubygems.org/gems/haste"; - license = licenses.mit; + homepage = "https://rubygems.org/gems/haste"; + license = licenses.mit; maintainers = with maintainers; [ shamilton ]; - platforms = platforms.unix; + platforms = platforms.unix; mainProgram = "haste"; }; } diff --git a/pkgs/tools/misc/haste-client/gemset.nix b/pkgs/tools/misc/haste-client/gemset.nix index e6cbbff11aa6b2..91d95d217ffc3b 100644 --- a/pkgs/tools/misc/haste-client/gemset.nix +++ b/pkgs/tools/misc/haste-client/gemset.nix @@ -1,488 +1,650 @@ { faraday = { - dependencies = ["multipart-post"]; - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + dependencies = [ "multipart-post" ]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13aghksmni2sl15y7wfpx6k5l3lfd8j9gdyqi6cbw6jgc7bqyyn2"; type = "gem"; }; version = "0.17.3"; }; haste = { - dependencies = ["faraday" "json"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "faraday" + "json" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jaq0kvlxwvd0jq9pl707saqnaaal3dis13mqwfjbj121gr4hq4q"; type = "gem"; }; version = "0.2.3"; }; json = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lrirj0gw420kw71bjjlqkqhqbrplla61gbv1jzgsz6bv90qr3ci"; type = "gem"; }; version = "2.5.1"; }; multipart-post = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zgw9zlwh2a6i1yvhhc4a84ry1hv824d6g2iw2chs3k5aylpmpfj"; type = "gem"; }; diff --git a/pkgs/tools/misc/hdf5/1.10.nix b/pkgs/tools/misc/hdf5/1.10.nix index c74911d241adb1..7c0392deddc9bc 100644 --- a/pkgs/tools/misc/hdf5/1.10.nix +++ b/pkgs/tools/misc/hdf5/1.10.nix @@ -1,16 +1,19 @@ -{ lib -, stdenv -, fetchurl -, removeReferencesTo -, cppSupport ? true -, zlibSupport ? true -, zlib -, enableShared ? !stdenv.hostPlatform.isStatic -, javaSupport ? false -, jdk +{ + lib, + stdenv, + fetchurl, + removeReferencesTo, + cppSupport ? true, + zlibSupport ? true, + zlib, + enableShared ? !stdenv.hostPlatform.isStatic, + javaSupport ? false, + jdk, }: -let inherit (lib) optional; in +let + inherit (lib) optional; +in stdenv.mkDerivation rec { version = "1.10.11"; @@ -20,7 +23,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-Cvx32lxGIXcJR1u++8qRwMtvHqYozNjDYZbPbFpN4wQ="; }; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; buildInputs = optional javaSupport jdk; @@ -28,7 +34,8 @@ stdenv.mkDerivation rec { propagatedBuildInputs = optional zlibSupport zlib; - configureFlags = optional enableShared "--enable-shared" + configureFlags = + optional enableShared "--enable-shared" ++ optional javaSupport "--enable-java" ++ optional cppSupport "--enable-cxx"; diff --git a/pkgs/tools/misc/hdf5/default.nix b/pkgs/tools/misc/hdf5/default.nix index e88f591128f6c1..4ee7101efd53cd 100644 --- a/pkgs/tools/misc/hdf5/default.nix +++ b/pkgs/tools/misc/hdf5/default.nix @@ -1,35 +1,39 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, removeReferencesTo -, cppSupport ? true -, fortranSupport ? false -, fortran -, zlibSupport ? true -, zlib -, szipSupport ? false -, szip -, mpiSupport ? false -, mpi -, enableShared ? !stdenv.hostPlatform.isStatic -, enableStatic ? stdenv.hostPlatform.isStatic -, javaSupport ? false -, jdk -, usev110Api ? false -, threadsafe ? false -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + removeReferencesTo, + cppSupport ? true, + fortranSupport ? false, + fortran, + zlibSupport ? true, + zlib, + szipSupport ? false, + szip, + mpiSupport ? false, + mpi, + enableShared ? !stdenv.hostPlatform.isStatic, + enableStatic ? stdenv.hostPlatform.isStatic, + javaSupport ? false, + jdk, + usev110Api ? false, + threadsafe ? false, + python3, }: # cpp and mpi options are mutually exclusive # (--enable-unsupported could be used to force the build) assert !cppSupport || !mpiSupport; -let inherit (lib) optional optionals; in +let + inherit (lib) optional optionals; +in stdenv.mkDerivation rec { version = "1.14.5"; - pname = "hdf5" + pname = + "hdf5" + lib.optionalString cppSupport "-cpp" + lib.optionalString fortranSupport "-fortran" + lib.optionalString mpiSupport "-mpi" @@ -56,22 +60,28 @@ stdenv.mkDerivation rec { ; }; - outputs = [ "out" "dev" "bin" ]; + outputs = [ + "out" + "dev" + "bin" + ]; - nativeBuildInputs = [ removeReferencesTo cmake ] - ++ optional fortranSupport fortran; + nativeBuildInputs = [ + removeReferencesTo + cmake + ] ++ optional fortranSupport fortran; - buildInputs = optional fortranSupport fortran - ++ optional szipSupport szip - ++ optional javaSupport jdk; + buildInputs = + optional fortranSupport fortran ++ optional szipSupport szip ++ optional javaSupport jdk; - propagatedBuildInputs = optional zlibSupport zlib - ++ optional mpiSupport mpi; + propagatedBuildInputs = optional zlibSupport zlib ++ optional mpiSupport mpi; - cmakeFlags = [ - "-DHDF5_INSTALL_CMAKE_DIR=${placeholder "dev"}/lib/cmake" - "-DBUILD_STATIC_LIBS=${lib.boolToString enableStatic}" - ] ++ lib.optional stdenv.hostPlatform.isDarwin "-DHDF5_BUILD_WITH_INSTALL_NAME=ON" + cmakeFlags = + [ + "-DHDF5_INSTALL_CMAKE_DIR=${placeholder "dev"}/lib/cmake" + "-DBUILD_STATIC_LIBS=${lib.boolToString enableStatic}" + ] + ++ lib.optional stdenv.hostPlatform.isDarwin "-DHDF5_BUILD_WITH_INSTALL_NAME=ON" ++ lib.optional cppSupport "-DHDF5_BUILD_CPP_LIB=ON" ++ lib.optional fortranSupport "-DHDF5_BUILD_FORTRAN=ON" ++ lib.optional szipSupport "-DHDF5_ENABLE_SZIP_SUPPORT=ON" @@ -79,37 +89,44 @@ stdenv.mkDerivation rec { ++ lib.optional enableShared "-DBUILD_SHARED_LIBS=ON" ++ lib.optional javaSupport "-DHDF5_BUILD_JAVA=ON" ++ lib.optional usev110Api "-DDEFAULT_API_VERSION=v110" - ++ lib.optionals threadsafe [ "-DDHDF5_ENABLE_THREADSAFE:BOOL=ON" "-DHDF5_BUILD_HL_LIB=OFF" ] + ++ lib.optionals threadsafe [ + "-DDHDF5_ENABLE_THREADSAFE:BOOL=ON" + "-DHDF5_BUILD_HL_LIB=OFF" + ] # broken in nixpkgs since around 1.14.3 -> 1.14.4.3 # https://github.com/HDFGroup/hdf5/issues/4208#issuecomment-2098698567 - ++ lib.optional (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) "-DHDF5_ENABLE_NONSTANDARD_FEATURE_FLOAT16=OFF" - ; + ++ lib.optional ( + stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64 + ) "-DHDF5_ENABLE_NONSTANDARD_FEATURE_FLOAT16=OFF"; - postInstall = '' - find "$out" -type f -exec remove-references-to -t ${stdenv.cc} '{}' + - moveToOutput 'bin/' "''${!outputBin}" - moveToOutput 'bin/h5cc' "''${!outputDev}" - moveToOutput 'bin/h5c++' "''${!outputDev}" - moveToOutput 'bin/h5fc' "''${!outputDev}" - moveToOutput 'bin/h5pcc' "''${!outputDev}" - moveToOutput 'bin/h5hlcc' "''${!outputDev}" - moveToOutput 'bin/h5hlc++' "''${!outputDev}" - '' + lib.optionalString enableShared - # The shared build creates binaries with -shared suffixes, - # so we remove these suffixes. - '' - pushd ''${!outputBin}/bin - for file in *-shared; do - mv "$file" "''${file%%-shared}" - done - popd - '' + lib.optionalString fortranSupport - '' - mv $out/mod/shared $dev/include - rm -r $out/mod + postInstall = + '' + find "$out" -type f -exec remove-references-to -t ${stdenv.cc} '{}' + + moveToOutput 'bin/' "''${!outputBin}" + moveToOutput 'bin/h5cc' "''${!outputDev}" + moveToOutput 'bin/h5c++' "''${!outputDev}" + moveToOutput 'bin/h5fc' "''${!outputDev}" + moveToOutput 'bin/h5pcc' "''${!outputDev}" + moveToOutput 'bin/h5hlcc' "''${!outputDev}" + moveToOutput 'bin/h5hlc++' "''${!outputDev}" + '' + + + lib.optionalString enableShared + # The shared build creates binaries with -shared suffixes, + # so we remove these suffixes. + '' + pushd ''${!outputBin}/bin + for file in *-shared; do + mv "$file" "''${file%%-shared}" + done + popd + '' + + lib.optionalString fortranSupport '' + mv $out/mod/shared $dev/include + rm -r $out/mod - find "$out" -type f -exec remove-references-to -t ${fortran} '{}' + - ''; + find "$out" -type f -exec remove-references-to -t ${fortran} '{}' + + ''; enableParallelBuilding = true; diff --git a/pkgs/tools/misc/heimdall/default.nix b/pkgs/tools/misc/heimdall/default.nix index d750bdb131c6bd..90af4652dad1a5 100644 --- a/pkgs/tools/misc/heimdall/default.nix +++ b/pkgs/tools/misc/heimdall/default.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, mkDerivation, fetchFromGitHub, cmake, zlib, libusb1 -, enableGUI ? false, qtbase ? null +{ + lib, + stdenv, + mkDerivation, + fetchFromGitHub, + cmake, + zlib, + libusb1, + enableGUI ? false, + qtbase ? null, }: mkDerivation rec { @@ -7,9 +15,9 @@ mkDerivation rec { version = "1.4.2"; src = fetchFromGitHub { - owner = "Benjamin-Dobell"; - repo = "Heimdall"; - rev = "v${version}"; + owner = "Benjamin-Dobell"; + repo = "Heimdall"; + rev = "v${version}"; sha256 = "1ygn4snvcmi98rgldgxf5hwm7zzi1zcsihfvm6awf9s6mpcjzbqz"; }; @@ -24,24 +32,28 @@ mkDerivation rec { "-DLIBUSB_LIBRARY=${libusb1}" ]; - preConfigure = '' - # Give ownership of the Galaxy S USB device to the logged in user. - substituteInPlace heimdall/60-heimdall.rules --replace 'MODE="0666"' 'TAG+="uaccess"' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace libpit/CMakeLists.txt --replace "-std=gnu++11" "" - ''; + preConfigure = + '' + # Give ownership of the Galaxy S USB device to the logged in user. + substituteInPlace heimdall/60-heimdall.rules --replace 'MODE="0666"' 'TAG+="uaccess"' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace libpit/CMakeLists.txt --replace "-std=gnu++11" "" + ''; - installPhase = lib.optionalString (stdenv.hostPlatform.isDarwin && enableGUI) '' - mkdir -p $out/Applications - mv bin/heimdall-frontend.app $out/Applications/heimdall-frontend.app - wrapQtApp $out/Applications/heimdall-frontend.app/Contents/MacOS/heimdall-frontend - '' + '' - mkdir -p $out/{bin,share/doc/heimdall,lib/udev/rules.d} - install -m755 -t $out/bin bin/* - install -m644 -t $out/lib/udev/rules.d ../heimdall/60-heimdall.rules - install -m644 ../Linux/README $out/share/doc/heimdall/README.linux - install -m644 ../OSX/README.txt $out/share/doc/heimdall/README.osx - ''; + installPhase = + lib.optionalString (stdenv.hostPlatform.isDarwin && enableGUI) '' + mkdir -p $out/Applications + mv bin/heimdall-frontend.app $out/Applications/heimdall-frontend.app + wrapQtApp $out/Applications/heimdall-frontend.app/Contents/MacOS/heimdall-frontend + '' + + '' + mkdir -p $out/{bin,share/doc/heimdall,lib/udev/rules.d} + install -m755 -t $out/bin bin/* + install -m644 -t $out/lib/udev/rules.d ../heimdall/60-heimdall.rules + install -m644 ../Linux/README $out/share/doc/heimdall/README.linux + install -m644 ../OSX/README.txt $out/share/doc/heimdall/README.osx + ''; meta = with lib; { broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/tools/misc/hiksink/default.nix b/pkgs/tools/misc/hiksink/default.nix index 77e74e8116f708..4e9a4172cfa0be 100644 --- a/pkgs/tools/misc/hiksink/default.nix +++ b/pkgs/tools/misc/hiksink/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, pkg-config -, Security -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + Security, + openssl, }: rustPlatform.buildRustPackage rec { @@ -24,11 +25,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + ]; meta = with lib; { description = "Tool to convert Hikvision camera events to MQTT"; diff --git a/pkgs/tools/misc/homesick/default.nix b/pkgs/tools/misc/homesick/default.nix index 663990ffac8053..72b63f099e8912 100644 --- a/pkgs/tools/misc/homesick/default.nix +++ b/pkgs/tools/misc/homesick/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerEnv, bundlerUpdateScript, git }: +{ + lib, + bundlerEnv, + bundlerUpdateScript, + git, +}: bundlerEnv { pname = "homesick"; @@ -14,15 +19,17 @@ bundlerEnv { meta = with lib; { description = "Your home directory is your castle. Don't leave your dotfiles behind"; - longDescription = - '' - Homesick is sorta like rip, but for dotfiles. It uses git to clone a repository containing - dotfiles, and saves them in ~/.homesick. It then allows you to symlink all the dotfiles into - place with a single command. - ''; + longDescription = '' + Homesick is sorta like rip, but for dotfiles. It uses git to clone a repository containing + dotfiles, and saves them in ~/.homesick. It then allows you to symlink all the dotfiles into + place with a single command. + ''; homepage = "https://github.com/technicalpickles/homesick"; license = licenses.mit; - maintainers = with maintainers; [ aaronschif nicknovitski ]; + maintainers = with maintainers; [ + aaronschif + nicknovitski + ]; platforms = platforms.unix; mainProgram = "homesick"; }; diff --git a/pkgs/tools/misc/homesick/gemset.nix b/pkgs/tools/misc/homesick/gemset.nix index 4a01696c2c7960..845f3aa1bdc73d 100644 --- a/pkgs/tools/misc/homesick/gemset.nix +++ b/pkgs/tools/misc/homesick/gemset.nix @@ -1,8 +1,8 @@ { homesick = { - dependencies = ["thor"]; + dependencies = [ "thor" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lxvnp4ncbx0irlblfxbd1f8h4hl11hgmyiy35q79w137r3prxml"; type = "gem"; }; @@ -10,7 +10,7 @@ }; thor = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nmqpyj642sk4g16nkbq6pj856adpv91lp4krwhqkh2iw63aszdl"; type = "gem"; }; diff --git a/pkgs/tools/misc/html-proofer/default.nix b/pkgs/tools/misc/html-proofer/default.nix index 2eeb467211d2d0..32d810ee4e41ba 100644 --- a/pkgs/tools/misc/html-proofer/default.nix +++ b/pkgs/tools/misc/html-proofer/default.nix @@ -1,4 +1,9 @@ -{ bundlerEnv, ruby, lib, bundlerUpdateScript }: +{ + bundlerEnv, + ruby, + lib, + bundlerUpdateScript, +}: bundlerEnv rec { name = "${pname}-${version}"; @@ -12,10 +17,10 @@ bundlerEnv rec { meta = with lib; { description = "Tool to validate HTML files"; - homepage = "https://github.com/gjtorikian/html-proofer"; - license = licenses.mit; + homepage = "https://github.com/gjtorikian/html-proofer"; + license = licenses.mit; maintainers = [ ]; - platforms = platforms.unix; + platforms = platforms.unix; mainProgram = "htmlproofer"; }; } diff --git a/pkgs/tools/misc/html-proofer/gemset.nix b/pkgs/tools/misc/html-proofer/gemset.nix index 1485ab4e5062c0..6594aa0cc5516c 100644 --- a/pkgs/tools/misc/html-proofer/gemset.nix +++ b/pkgs/tools/misc/html-proofer/gemset.nix @@ -1,247 +1,273 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05r1fwy487klqkya7vzia8hnklcxy4vr92m9dmni3prfwk6zpw33"; type = "gem"; }; version = "2.8.5"; }; afm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06kj9hgd0z8pj27bxp2diwqh6fv7qhwwm17z64rhdc4sfn76jgn8"; type = "gem"; }; version = "0.2.2"; }; Ascii85 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ds4v9xgsyvijnlflak4dzf1qwmda9yd5bv8jwsb56nngd399rlw"; type = "gem"; }; version = "1.1.0"; }; async = { - dependencies = ["console" "fiber-annotation" "io-event" "timers"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "console" + "fiber-annotation" + "io-event" + "timers" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0806cya8kq9glg6vifa9j4zjf81drwa84hdzx71ah98zz317hvhb"; type = "gem"; }; version = "2.6.3"; }; console = { - dependencies = ["fiber-annotation" "fiber-local"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "fiber-annotation" + "fiber-local" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04cpbx4bsw3k20xgvz6cs1gi41q9mmagc95x2zk6ar49a25z89sb"; type = "gem"; }; version = "1.23.1"; }; ethon = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17ix0mijpsy3y0c6ywrk5ibarmvqzjsirjyprpsy3hwax8fdm85v"; type = "gem"; }; version = "0.16.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1862ydmclzy1a0cjbvm8dz7847d9rch495ib0zb64y84d3xd4bkg"; type = "gem"; }; version = "1.15.5"; }; fiber-annotation = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00vcmynyvhny8n4p799rrhcx0m033hivy0s1gn30ix8rs7qsvgvs"; type = "gem"; }; version = "0.2.0"; }; fiber-local = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vrxxb09fc7aicb9zb0pmn5akggjy21dmxkdl3w949y4q05rldr9"; type = "gem"; }; version = "1.0.0"; }; hashery = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qj8815bf7q6q7llm5rzdz279gzmpqmqqicxnzv066a020iwqffj"; type = "gem"; }; version = "2.1.2"; }; html-proofer = { - dependencies = ["addressable" "async" "nokogiri" "pdf-reader" "rainbow" "typhoeus" "yell" "zeitwerk"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "addressable" + "async" + "nokogiri" + "pdf-reader" + "rainbow" + "typhoeus" + "yell" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lzh3lb3l2qid3sh3da0fgjdwdly2g5jia6drzpn1dn1b92a7wwm"; type = "gem"; }; version = "5.0.8"; }; io-event = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0046p1q98xrys4bzcx74k658fv1fiigdgcd0az0pm12n2hjcms6r"; type = "gem"; }; version = "1.2.3"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02mj8mpd6ck5gpcnsimx5brzggw5h5mmmpq2djdypfq16wcw82qq"; type = "gem"; }; version = "2.8.4"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l8b0i24h4irivyhwy9xmkjbggw86cxkzkiqdqg0jpcp9qc8h4rl"; type = "gem"; }; version = "1.16.0"; }; pdf-reader = { - dependencies = ["Ascii85" "afm" "hashery" "ruby-rc4" "ttfunk"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "Ascii85" + "afm" + "hashery" + "ruby-rc4" + "ttfunk" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09sx25jpnip2sp6wh5sn5ad7za78rfi95qp5iiczfh43z4jqa8q3"; type = "gem"; }; version = "2.11.0"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0n9j7mczl15r3kwqrah09cxj8hxdfawiqxa60kga2bmxl9flfz9k"; type = "gem"; }; version = "5.0.3"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11v3l46mwnlzlc371wr3x6yylpgafgwdf0q7hc7c1lzx6r414r5g"; type = "gem"; }; version = "1.7.1"; }; rainbow = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0smwg4mii0fm38pyb5fddbmrdpifwv22zv3d3px2xx497am93503"; type = "gem"; }; version = "3.1.1"; }; ruby-rc4 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00vci475258mmbvsdqkmqadlwn6gj9m01sp7b5a3zd90knil1k00"; type = "gem"; }; version = "0.1.5"; }; timers = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pjzipnmzfywvgsr3gxwj6nmg47lz4700g0q71jgcy1z6rb7dn7p"; type = "gem"; }; version = "4.3.5"; }; ttfunk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15iaxz9iak5643bq2bc0jkbjv8w2zn649lxgvh5wg48q9d4blw13"; type = "gem"; }; version = "1.7.0"; }; typhoeus = { - dependencies = ["ethon"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ethon" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1m22yrkmbj81rzhlny81j427qdvz57yk5wbcf3km0nf3bl6qiygz"; type = "gem"; }; version = "1.4.0"; }; yell = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g16kcdhdfvczn7x81jiq6afg3bdxmb73skqjyjlkp5nqcy6y5hx"; type = "gem"; }; version = "2.2.2"; }; zeitwerk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1mwdd445w63khz13hpv17m2br5xngyjl3jdj08xizjbm78i2zrxd"; type = "gem"; }; diff --git a/pkgs/tools/misc/hyperfine/default.nix b/pkgs/tools/misc/hyperfine/default.nix index 0058187255dedb..b8b5d1437063a0 100644 --- a/pkgs/tools/misc/hyperfine/default.nix +++ b/pkgs/tools/misc/hyperfine/default.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + Security, }: rustPlatform.buildRustPackage rec { @@ -34,8 +35,14 @@ rustPlatform.buildRustPackage rec { description = "Command-line benchmarking tool"; homepage = "https://github.com/sharkdp/hyperfine"; changelog = "https://github.com/sharkdp/hyperfine/blob/v${version}/CHANGELOG.md"; - license = with licenses; [ asl20 /* or */ mit ]; - maintainers = with maintainers; [ figsoda thoughtpolice ]; + license = with licenses; [ + asl20 # or + mit + ]; + maintainers = with maintainers; [ + figsoda + thoughtpolice + ]; mainProgram = "hyperfine"; }; } diff --git a/pkgs/tools/misc/iay/default.nix b/pkgs/tools/misc/iay/default.nix index 5973ed258b5913..22b18468583000 100644 --- a/pkgs/tools/misc/iay/default.nix +++ b/pkgs/tools/misc/iay/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, openssl -, pkg-config -, AppKit -, Cocoa -, Foundation -, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + openssl, + pkg-config, + AppKit, + Cocoa, + Foundation, + Security, }: rustPlatform.buildRustPackage rec { @@ -25,23 +26,30 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ - openssl - ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - Cocoa - Foundation - Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + Cocoa + Foundation + Security + ]; - NIX_LDFLAGS = lib.optionals stdenv.hostPlatform.isDarwin [ "-framework" "AppKit" ]; + NIX_LDFLAGS = lib.optionals stdenv.hostPlatform.isDarwin [ + "-framework" + "AppKit" + ]; meta = with lib; { description = "Minimalistic, blazing-fast, and extendable prompt for bash and zsh"; homepage = "https://github.com/aaqaishtyaq/iay"; license = licenses.mit; - maintainers = with maintainers; [ aaqaishtyaq omasanori ]; + maintainers = with maintainers; [ + aaqaishtyaq + omasanori + ]; mainProgram = "iay"; }; } diff --git a/pkgs/tools/misc/inspec/default.nix b/pkgs/tools/misc/inspec/default.nix index 759b1fcaed874e..e020191a3a7968 100644 --- a/pkgs/tools/misc/inspec/default.nix +++ b/pkgs/tools/misc/inspec/default.nix @@ -1,4 +1,9 @@ -{ lib, ruby, bundlerApp, bundlerUpdateScript }: +{ + lib, + ruby, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "inspec"; @@ -6,7 +11,7 @@ bundlerApp { inherit ruby; - exes = ["inspec"]; + exes = [ "inspec" ]; passthru.updateScript = bundlerUpdateScript "inspec"; diff --git a/pkgs/tools/misc/inspec/gemset.nix b/pkgs/tools/misc/inspec/gemset.nix index 583b3023c6f531..4b77ba56355b6f 100644 --- a/pkgs/tools/misc/inspec/gemset.nix +++ b/pkgs/tools/misc/inspec/gemset.nix @@ -1,2438 +1,2997 @@ { activesupport = { - dependencies = ["concurrent-ruby" "i18n" "minitest" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "i18n" + "minitest" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "188kbwkn1lbhz40ala8ykp20jzqphgc68g3d8flin8cqa2xid0s5"; type = "gem"; }; version = "7.0.8"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0irbdwkkjwzajq1ip6ba46q49sxnrl2cw7ddkdhsfhb6aprnm3vr"; type = "gem"; }; version = "2.8.6"; }; ast = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04nc8x27hlzlrr5c2gn7mar4vdr0apw5xg22wp6m8dx3wqr04a0y"; type = "gem"; }; version = "2.4.2"; }; aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gvdg4yx4p9av2glmp7vsxhs0n8fj1ga9kq2xdb8f95j7b04qhzi"; type = "gem"; }; version = "1.3.0"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16n1d0bh3zy925y4f8flrnkfir2smsj0j31zslfaz6vf6cvi9qjs"; type = "gem"; }; version = "1.864.0"; }; aws-sdk-account = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1h6fqfq5pgsmnchmg4w4l9mypv2ggix1d0a8b8w66a9xvsk8bkxd"; type = "gem"; }; version = "1.20.0"; }; aws-sdk-alexaforbusiness = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ps37857dgnydnih2gxrl3a5fr571242006l9634jzm8w91jpb80"; type = "gem"; }; version = "1.67.0"; }; aws-sdk-amplify = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fv4w1npqglxm9sl6939akjw3y1ivhpl55i75azvbzx0f7abh3b8"; type = "gem"; }; version = "1.32.0"; }; aws-sdk-apigateway = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gqd04rdzz487bgy64gq2fqm20wcdd2zk8rnl51nyq6cfxsslbvw"; type = "gem"; }; version = "1.90.0"; }; aws-sdk-apigatewayv2 = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1dq11njjh05dm6dc2gjrbhl6ga6a9mxaisr7bgk0gv295b5nfiwp"; type = "gem"; }; version = "1.53.0"; }; aws-sdk-applicationautoscaling = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0lp008dcyiqcz90fkck5dgx23ycgk04rhd0n1ywz14rg45844nfn"; type = "gem"; }; version = "1.51.0"; }; aws-sdk-athena = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "19fs835xm7pls49yryayh80m6dap44g4r2qk94ssvck5paxyylk3"; type = "gem"; }; version = "1.79.0"; }; aws-sdk-autoscaling = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1hv9nfzbn478vjv88c6jybf4nsii1c04vzqckgh4pajm5mc8kk7p"; type = "gem"; }; version = "1.92.0"; }; aws-sdk-batch = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "06lxajqdjwxdc9wx17igsdxj608charbpwhnfnb83dcrfaavkqms"; type = "gem"; }; version = "1.73.0"; }; aws-sdk-budgets = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0689sck8d49smzavhipl2i3nrr5lrw3miam88a7h7qckwmlsp098"; type = "gem"; }; version = "1.62.0"; }; aws-sdk-cloudformation = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0sgsyzsyjdw795k81sc0qy1h4rd3ksxszcxp93wx07vrl8nv5i0a"; type = "gem"; }; version = "1.97.0"; }; aws-sdk-cloudfront = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1fxrv7zqlp61cpazd3i3slbyv10fgd6xk9wsb0p5fshm64zg0s16"; type = "gem"; }; version = "1.86.0"; }; aws-sdk-cloudhsm = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ijcid6qpz49vmsp7zig0h7qzgx5rc027iqwl4bnyic6vmgir6ai"; type = "gem"; }; version = "1.50.0"; }; aws-sdk-cloudhsmv2 = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0hmjkz09xldacq12l1b924gkfyzx6s0zvigmw2dvbxf3v1imainn"; type = "gem"; }; version = "1.53.0"; }; aws-sdk-cloudtrail = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "03nr4qpv6678b3lpgbfvlaxydg7m72r1l2ml0mv14z5h066i964s"; type = "gem"; }; version = "1.74.0"; }; aws-sdk-cloudwatch = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "18865fsj24pf6z0rn1n94b7q4299hclbi7h085484am7g0v1gfnx"; type = "gem"; }; version = "1.84.0"; }; aws-sdk-cloudwatchevents = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1dbafxhkp3x5fgibc3i663mnf44kbmfh9ia9cq6fwn45cw2bpfik"; type = "gem"; }; version = "1.62.0"; }; aws-sdk-cloudwatchlogs = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "01mvckn874662bl9vfphgn2s983hxsp53bsf07y809kkksw4mipr"; type = "gem"; }; version = "1.75.0"; }; aws-sdk-codecommit = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0blk86gvg74s7imhz07brrgc4q71ddnwd5nf1a86vyn8rdcq0dxx"; type = "gem"; }; version = "1.62.0"; }; aws-sdk-codedeploy = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0v4gv1ycw0b12an6002qz0vspzqhxzc1719ylshr7zxlc4yy7ndi"; type = "gem"; }; version = "1.63.0"; }; aws-sdk-codepipeline = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0d0finvyv46h9bqyds092pnjspg6hcr2rakk54w3y84smyzaawp3"; type = "gem"; }; version = "1.67.0"; }; aws-sdk-cognitoidentity = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1hhhnlipplr9fv8lvq612y49n4xasqdjkkxd7m002drp2zm7rzbj"; type = "gem"; }; version = "1.45.0"; }; aws-sdk-cognitoidentityprovider = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1v2lf191jinkl3kfbl6zdv29cn7xbpyksshww1mz29a323j5bm4x"; type = "gem"; }; version = "1.76.0"; }; aws-sdk-configservice = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "11xb46y5glq0bqlhbhpkr9mf1p17jsxb5l0wq3hpvzxw376ip6hl"; type = "gem"; }; version = "1.103.0"; }; aws-sdk-core = { - dependencies = ["aws-eventstream" "aws-partitions" "aws-sigv4" "jmespath"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-eventstream" + "aws-partitions" + "aws-sigv4" + "jmespath" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "19nglxz49nlzgsvnivb3bdm17vxjn1ng2br8659xv48nzjrmyid3"; type = "gem"; }; version = "3.190.0"; }; aws-sdk-costandusagereportservice = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0jps30r7l5g7j4b1lss9m1isyk5h8k469hq9dp4yljis0jdlmy3c"; type = "gem"; }; version = "1.53.0"; }; aws-sdk-databasemigrationservice = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ss4x2syf6c5ray6g61cxxcx2q7mzqv0gk00d1dl7g4c5z9avhwi"; type = "gem"; }; version = "1.80.0"; }; aws-sdk-dynamodb = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ib8iwgp7ddhcgmqmzjq9js0kw8m5mm4mi7klrl84925lgvlvk65"; type = "gem"; }; version = "1.98.0"; }; aws-sdk-ec2 = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zyazx97nskgl9xzspg2q1rji02p2jv789v8qd1qz6hknz0z6r5f"; type = "gem"; }; version = "1.430.0"; }; aws-sdk-ecr = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "103ycwxv367bkrqzdpypd0p650r62ka3azw2pzdwc38pj5r3nxl6"; type = "gem"; }; version = "1.68.0"; }; aws-sdk-ecrpublic = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1a5j7v70gwwy1md4awz37k77qlwgls390xlwbri8lkcxmaw2x5bp"; type = "gem"; }; version = "1.25.0"; }; aws-sdk-ecs = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0s4yyi22v0vv3pyskpz4qzahngfxawxjx8x4ch2aj8c8wffkfclk"; type = "gem"; }; version = "1.135.0"; }; aws-sdk-efs = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1m8ymz0wq1p6iz126qcdsrz0ss730p1inb6g1w07r9ganjdzbplx"; type = "gem"; }; version = "1.71.0"; }; aws-sdk-eks = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "13aac0gpyxm660pbcbpvpcpw20db28p5lbwjs45rczc9l3yl9aw1"; type = "gem"; }; version = "1.95.0"; }; aws-sdk-elasticache = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "061zg2k3kvayrnih0qiilcdarwjap37bzf1a0v5n6a57606hc40s"; type = "gem"; }; version = "1.95.0"; }; aws-sdk-elasticbeanstalk = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ysn5cj4rwqj2jvsg02i8qs9j3z6c6lwhici58q09m62xzrhr3qg"; type = "gem"; }; version = "1.63.0"; }; aws-sdk-elasticloadbalancing = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "09zvryq7121c05cswzwv337qylza33dwlqd97c11ii3y8pg2bsla"; type = "gem"; }; version = "1.51.0"; }; aws-sdk-elasticloadbalancingv2 = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1mgik7lhch27j4q4nzxci0rhrgybh0bx7bzcq48c5sggpm999qkr"; type = "gem"; }; version = "1.96.0"; }; aws-sdk-elasticsearchservice = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1nqrx6vm4yi1amk7677rw6jvwrdhv7pj4g507r5hqcfmilr5z1gx"; type = "gem"; }; version = "1.79.0"; }; aws-sdk-emr = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1wybb0aadsk8x3whwlid58g40613c9rrl48g43ikgpqz9f3b44ac"; type = "gem"; }; version = "1.53.0"; }; aws-sdk-eventbridge = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1mnpcklsm8dicz35yj89jr870xii1xghfdjfqif1lxii4vvhlqba"; type = "gem"; }; version = "1.46.0"; }; aws-sdk-firehose = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0n4iz5bv80gd7m070jyr5kv36yx8qyq1i8ljh5bfj3cr57vvdw89"; type = "gem"; }; version = "1.60.0"; }; aws-sdk-glue = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1pjw4vfniswiprjr5vivgq3vilw05gqqr5mkkwhx38y6xc8kr7ga"; type = "gem"; }; version = "1.145.0"; }; aws-sdk-guardduty = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0ya8q0hgh7293jlz1pchci5qvywnmg87h3x3k9hsbqf1023bz9nz"; type = "gem"; }; version = "1.85.0"; }; aws-sdk-iam = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0whclpcvbdy7gzvqpk8734nxjfxs3362k197xl1wnrpixklkacyz"; type = "gem"; }; version = "1.92.0"; }; aws-sdk-kafka = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gg28ixfr681sxjffp28wy47siz7jypvm04ldqarlcvgaqnk08ds"; type = "gem"; }; version = "1.67.0"; }; aws-sdk-kinesis = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "19xzw7i6i4f0yn604is07w3zf3q6lch2ki29bg31m0jd2jdj2rn0"; type = "gem"; }; version = "1.54.0"; }; aws-sdk-kms = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1isrj19kzy9sb7a76a1c2n5x0d9lg1h2n7fp7cn13xjis0hpnlxj"; type = "gem"; }; version = "1.74.0"; }; aws-sdk-lambda = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1gfysixcf5wsaqk0cycg3zryybs9zwvg0v6j9hn7zc99x27qjca4"; type = "gem"; }; version = "1.113.0"; }; aws-sdk-mq = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0pr2v6lf2rcnfsdbs5s5ig5mlvnfm1xwy2y8jcyp9w4s933ps9fg"; type = "gem"; }; version = "1.40.0"; }; aws-sdk-networkfirewall = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "02bq2flz4kqcr9fvk09mvn6r7h1arnjjw87l0qkgyr94x8ngidpy"; type = "gem"; }; version = "1.39.0"; }; aws-sdk-networkmanager = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0qpi693cjnzy91yyavmhgj6047kk04hslbqb7hgiqvz1ki4qr9q9"; type = "gem"; }; version = "1.40.0"; }; aws-sdk-organizations = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "169dz3ip2vz22mk6hczsd1v6lf2v428i0jhpllnay11zsficc6p1"; type = "gem"; }; version = "1.77.0"; }; aws-sdk-ram = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0rm6sr5kvdy9q1xjg00c80648l8j3cpc6l5fakfxiqhp256bf2ac"; type = "gem"; }; version = "1.26.0"; }; aws-sdk-rds = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yrc7ivykdcrq8s6isd368gr02jclwc140pckf1vyii2f2g79k30"; type = "gem"; }; version = "1.208.0"; }; aws-sdk-redshift = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08rgpxknp11q4dxzncn4x30bpqkd4ssi78wq2j0kfgl5qbid48y8"; type = "gem"; }; version = "1.107.0"; }; aws-sdk-route53 = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1p7py5g5bk9yxlg6h04rkvgzgbysj7zm63bpdrswxwzhynmb8p9v"; type = "gem"; }; version = "1.83.0"; }; aws-sdk-route53domains = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15v2fbm9563kad3hnac5372xr7lvhxdyggrjzx1rbn56kf7bcb6n"; type = "gem"; }; version = "1.54.0"; }; aws-sdk-route53resolver = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0i57m3vysjlbvfrf0jpyi343bi8nw1j9gjcm50sv3lzx0ix66bpi"; type = "gem"; }; version = "1.51.0"; }; aws-sdk-s3 = { - dependencies = ["aws-sdk-core" "aws-sdk-kms" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sdk-kms" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0bnhpmi0iiaj88rqc5lhhnp2gyrk4fs8xz51lj36wwzng94qinya"; type = "gem"; }; version = "1.141.0"; }; aws-sdk-s3control = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kf3i430b6lwzf7dmm506jvm7xy0rj4zhc9kywcg4rc1fp0bmzh3"; type = "gem"; }; version = "1.43.0"; }; aws-sdk-secretsmanager = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0xkx39yi2mlwyh3lyg6h39nzj5n059nc6idaqlnsjlrkkrh3i13i"; type = "gem"; }; version = "1.46.0"; }; aws-sdk-securityhub = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1z63plqdq0hhl6g78dlxvr04g8a81smxn223wqsz2macf8c96wgl"; type = "gem"; }; version = "1.99.0"; }; aws-sdk-servicecatalog = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zjxbpr5jj3znrsynazcjznaqcqbfpy646nzvl3c83gcwrsqj8s7"; type = "gem"; }; version = "1.60.0"; }; aws-sdk-ses = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1xii4i4dia1w6hizfxvni8jawpikv9g26ixiw349x33l09f12cbw"; type = "gem"; }; version = "1.41.0"; }; aws-sdk-shield = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1gk003vj7gs7a3rs79rs5bv5wcsyk9fsf3cc6ci3kbj5y5kbzabc"; type = "gem"; }; version = "1.60.0"; }; aws-sdk-signer = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ysspl6n2rw5hr3bz38k46k04nkbri0c54fc109kgw57fxfwq3fk"; type = "gem"; }; version = "1.32.0"; }; aws-sdk-simpledb = { - dependencies = ["aws-sdk-core" "aws-sigv2"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv2" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15vrakmbxz7pg9vf2gi8ssb6jg4k5jwrsik6x0hkjf3n4g3vfgqs"; type = "gem"; }; version = "1.29.0"; }; aws-sdk-sms = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "17rmy3hzs3cv3vzr5j2swninwqdxf33hcci96pmy88wrcx4nav5x"; type = "gem"; }; version = "1.52.0"; }; aws-sdk-sns = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0zbn3gfksbszgdk806l96fmqa9npqm2gqgvjrqm4x44hl1a5cf8z"; type = "gem"; }; version = "1.70.0"; }; aws-sdk-sqs = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1nsr4q2g7sfap9vx8vk5532mkyww8an25qabwplsdy9s625p8ahl"; type = "gem"; }; version = "1.69.0"; }; aws-sdk-ssm = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0xz10344dwm4pj8qnl19bnh99arxp7cd9mn2alslrnw7y2gipzz1"; type = "gem"; }; version = "1.162.0"; }; aws-sdk-states = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00ja9hkx4rdgd0242l8vmbfmb1qgvys3xs2ryap3ms3qaa76sach"; type = "gem"; }; version = "1.39.0"; }; aws-sdk-synthetics = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "10zh51r45pzbnx8fxjz8pppwlgbzpbvs4kaji1mi53cwpfprlhsz"; type = "gem"; }; version = "1.19.0"; }; aws-sdk-transfer = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "087y19nzkh26a7rac5ci7d792mdjfwg1mfm884r118g89y4imcdf"; type = "gem"; }; version = "1.73.0"; }; aws-sdk-waf = { - dependencies = ["aws-sdk-core" "aws-sigv4"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-core" + "aws-sigv4" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "036655pbqkvzwd05svimvn2v96srz370zmhczg1jzsca0249hxfr"; type = "gem"; }; version = "1.43.0"; }; aws-sigv2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zams698qxn5ws4f8basqp895b206pclsxsja5cnxkhrmj2n781j"; type = "gem"; }; version = "1.2.0"; }; aws-sigv4 = { - dependencies = ["aws-eventstream"]; - groups = ["default"]; - platforms = []; + dependencies = [ "aws-eventstream" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g3w27wzjy4si6kp49w10as6ml6g6zl3xrfqs5ikpfciidv9kpc4"; type = "gem"; }; version = "1.8.0"; }; azure_graph_rbac = { - dependencies = ["ms_rest_azure"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ms_rest_azure" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mmx8jp85xa13j3asa9xnfi6wa8a9wwlp0hz0nj70fi3ydmcpdag"; type = "gem"; }; version = "0.17.2"; }; azure_mgmt_key_vault = { - dependencies = ["ms_rest_azure"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ms_rest_azure" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0f4fai5l3453yirrwajds0jgah60gvawffx53a0jyv3b93ag88mz"; type = "gem"; }; version = "0.17.7"; }; azure_mgmt_resources = { - dependencies = ["ms_rest_azure"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ms_rest_azure" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1p4hsa7xha8ifml58hmkxdkp7vyhm7sw624xam1mrq0hvzawvkm3"; type = "gem"; }; version = "0.18.2"; }; azure_mgmt_security = { - dependencies = ["ms_rest_azure"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ms_rest_azure" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11h2dyz4awzidvfj41h7k2q7mcqqcgzvm95fxpfxz609pbvck0g2"; type = "gem"; }; version = "0.19.0"; }; azure_mgmt_storage = { - dependencies = ["ms_rest_azure"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ms_rest_azure" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ik06knz7fxn9q2x874d7q1v2fb00askwh36wbl75fnsi2m5m6rq"; type = "gem"; }; version = "0.23.0"; }; bson = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19vgs9rzzyvd7jfrzynjnc6518q0ffpfciyicfywbp77zl8nc9hk"; type = "gem"; }; version = "4.15.0"; }; builder = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "045wzckxpwcqzrjr353cxnyaxgf0qg22jh00dcx7z38cys5g1jlr"; type = "gem"; }; version = "3.2.4"; }; chef-config = { - dependencies = ["addressable" "chef-utils" "fuzzyurl" "mixlib-config" "mixlib-shellout" "tomlrb"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "chef-utils" + "fuzzyurl" + "mixlib-config" + "mixlib-shellout" + "tomlrb" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1pvjf3qbb3apg9vdy4zykamm7801qz4m6256wjqn73fs87zs50y1"; type = "gem"; }; version = "18.3.0"; }; chef-licensing = { - dependencies = ["activesupport" "chef-config" "faraday" "faraday-http-cache" "tty-prompt" "tty-spinner"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "chef-config" + "faraday" + "faraday-http-cache" + "tty-prompt" + "tty-spinner" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1inm01nrkxsdvf0fak2qkpva1k7d4fpi8z9xf646bsgrjz2761rb"; type = "gem"; }; version = "0.7.5"; }; chef-telemetry = { - dependencies = ["chef-config" "concurrent-ruby"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "chef-config" + "concurrent-ruby" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0l9icc3nfdj28mip85vf31v5l60qsfqq3a5dscv7jryh1k94y05x"; type = "gem"; }; version = "1.1.1"; }; chef-utils = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0087jwhqslfm3ygj507dmmdp3k0589j5jl54mkwgbabbwan7lzw2"; type = "gem"; }; version = "18.3.0"; }; coderay = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jvxqxzply1lwp7ysn94zjhh57vc14mcshw1ygw14ib8lhc00lyw"; type = "gem"; }; version = "1.1.3"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0krcwb6mn0iklajwngwsg850nk8k9b35dhmc2qkbdqvmifdi2y9q"; type = "gem"; }; version = "1.2.2"; }; cookstyle = { - dependencies = ["rubocop"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rubocop" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0np0y94x1rgn13bwkd4hc5ysimn9ax57ihrpz5rl4fwrn3lybm1s"; type = "gem"; }; version = "7.32.2"; }; declarative = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yczgnqrbls7shrg63y88g7wand2yp9h6sf56c9bdcksn5nds8c0"; type = "gem"; }; version = "0.0.20"; }; diff-lcs = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rwvjahnp7cpmracd8x732rjgnilqv2sx7d1gfrysslc3h039fa9"; type = "gem"; }; version = "1.5.0"; }; docker-api = { - dependencies = ["excon" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "excon" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0g7dbniz15b3l2sy6xh0j0998dr5jypf3xg3bsygp0108vv7waxy"; type = "gem"; }; version = "2.2.0"; }; domain_name = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gpciaifmxql8h01ci12qq08dnqrdlzkkz6fmia9v9yc3r9a29si"; type = "gem"; }; version = "0.6.20231109"; }; dry-configurable = { - dependencies = ["concurrent-ruby" "dry-core"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "dry-core" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1qzq7aaw020qq06d2lpjq03a3gqnkyya040fjgyfp5q3dlr9c44v"; type = "gem"; }; version = "0.13.0"; }; dry-container = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0aaj0ffwkbdagrry127x1gd4m6am88mhhfzi7czk8isdcj0r7gi3"; type = "gem"; }; version = "0.11.0"; }; dry-core = { - dependencies = ["concurrent-ruby" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1dpm9dk11x2zcjsymkl5jcz5nxhffsg7qqy5p6h92cppzbwmm656"; type = "gem"; }; version = "0.9.1"; }; dry-inflector = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rw0xxx1yga8r8bwgpywgshvqwd0w6shy0s4y1qrsz0cjxfwga0i"; type = "gem"; }; version = "0.3.0"; }; dry-logic = { - dependencies = ["concurrent-ruby" "dry-core" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "dry-core" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "12ikf5j5n7bhwd0mzi27ikwdr944l78sp86ndvkbqpfq607335ys"; type = "gem"; }; version = "1.3.0"; }; dry-struct = { - dependencies = ["dry-core" "dry-types" "ice_nine" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "dry-core" + "dry-types" + "ice_nine" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "177jvjlkjshv80cmy54jnfd18lryzaigd8mbm39iaigah7afhwf4"; type = "gem"; }; version = "1.5.2"; }; dry-types = { - dependencies = ["concurrent-ruby" "dry-container" "dry-core" "dry-inflector" "dry-logic" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "dry-container" + "dry-core" + "dry-inflector" + "dry-logic" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0xpbh437hw16h8qxw7454vkabnq7w9g51sh4qs3z82xl8qvkhdqy"; type = "gem"; }; version = "1.6.1"; }; erubi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08s75vs9cxlc4r1q2bjg4br8g9wc5lc5x5vl0vv4zq5ivxsdpgi7"; type = "gem"; }; version = "1.12.0"; }; excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "138gi8b95nqv8m83dynpsszz11a6c5si1pym6y0b6bfb01r33pyi"; type = "gem"; }; version = "0.105.0"; }; faraday = { - dependencies = ["faraday-em_http" "faraday-em_synchrony" "faraday-excon" "faraday-httpclient" "faraday-multipart" "faraday-net_http" "faraday-net_http_persistent" "faraday-patron" "faraday-rack" "faraday-retry" "ruby2_keywords"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday-em_http" + "faraday-em_synchrony" + "faraday-excon" + "faraday-httpclient" + "faraday-multipart" + "faraday-net_http" + "faraday-net_http_persistent" + "faraday-patron" + "faraday-rack" + "faraday-retry" + "ruby2_keywords" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1c760q0ks4vj4wmaa7nh1dgvgqiwaw0mjr7v8cymy7i3ffgjxx90"; type = "gem"; }; version = "1.10.3"; }; faraday-cookie_jar = { - dependencies = ["faraday" "http-cookie"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "http-cookie" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00hligx26w9wdnpgsrf0qdnqld4rdccy8ym6027h5m735mpvxjzk"; type = "gem"; }; version = "0.0.7"; }; faraday-em_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12cnqpbak4vhikrh2cdn94assh3yxza8rq2p9w2j34bqg5q4qgbs"; type = "gem"; }; version = "1.0.0"; }; faraday-em_synchrony = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vgrbhkp83sngv6k4mii9f2s9v5lmp693hylfxp2ssfc60fas3a6"; type = "gem"; }; version = "1.0.0"; }; faraday-excon = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h09wkb0k0bhm6dqsd47ac601qiaah8qdzjh8gvxfd376x1chmdh"; type = "gem"; }; version = "1.1.0"; }; faraday-follow_redirects = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1y87p3yk15bjbk0z9mf01r50lzxvp7agr56lbm9gxiz26mb9fbfr"; type = "gem"; }; version = "0.3.0"; }; faraday-http-cache = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qvl49xpl2mwxgcj6aj11qrjk94xrqhbnpl5vp1y2275crnkddv4"; type = "gem"; }; version = "2.5.0"; }; faraday-httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fyk0jd3ks7fdn8nv3spnwjpzx2lmxmg2gh4inz3by1zjzqg33sc"; type = "gem"; }; version = "1.0.1"; }; faraday-multipart = { - dependencies = ["multipart-post"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multipart-post" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09871c4hd7s5ws1wl4gs7js1k2wlby6v947m2bbzg43pnld044lh"; type = "gem"; }; version = "1.0.4"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fi8sda5hc54v1w3mqfl5yz09nhx35kglyx72w7b8xxvdr0cwi9j"; type = "gem"; }; version = "1.0.1"; }; faraday-net_http_persistent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dc36ih95qw3rlccffcb0vgxjhmipsvxhn6cw71l7ffs0f7vq30b"; type = "gem"; }; version = "1.2.0"; }; faraday-patron = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19wgsgfq0xkski1g7m96snv39la3zxz6x7nbdgiwhg5v82rxfb6w"; type = "gem"; }; version = "1.0.0"; }; faraday-rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h184g4vqql5jv9s9im6igy00jp6mrah2h14py6mpf9bkabfqq7g"; type = "gem"; }; version = "1.0.0"; }; faraday-retry = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "153i967yrwnswqgvnnajgwp981k9p50ys1h80yz3q94rygs59ldd"; type = "gem"; }; version = "1.0.3"; }; faraday_middleware = { - dependencies = ["faraday"]; - groups = ["default"]; - platforms = []; + dependencies = [ "faraday" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jik2kgfinwnfi6fpp512vlvs0mlggign3gkbpkg5fw1jr9his0r"; type = "gem"; }; version = "1.0.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yvii03hcgqj30maavddqamqy50h7y6xcn2wcyq72wn823zl4ckd"; type = "gem"; }; version = "1.16.3"; }; fuzzyurl = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03qchs33vfwbsv5awxg3acfmlcrf5xbhnbrc83fdpamwya0glbjl"; type = "gem"; }; version = "0.9.0"; }; google-api-client = { - dependencies = ["addressable" "googleauth" "httpclient" "mini_mime" "representable" "retriable" "rexml" "signet"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "googleauth" + "httpclient" + "mini_mime" + "representable" + "retriable" + "rexml" + "signet" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1q1lsyyyfvff7727sr01j8qx6b30qpx6h0bna5s0bfz853fhl33b"; type = "gem"; }; version = "0.52.0"; }; googleauth = { - dependencies = ["faraday" "jwt" "memoist" "multi_json" "os" "signet"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "jwt" + "memoist" + "multi_json" + "os" + "signet" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0cm60nbmwzf83fzy06f3iyn5a6sw91siw8x9bdvpwwmjsmivana6"; type = "gem"; }; version = "0.14.0"; }; gssapi = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qdfhj12aq8v0y961v4xv96a1y2z80h3xhvzrs9vsfgf884g6765"; type = "gem"; }; version = "1.3.1"; }; gyoku = { - dependencies = ["builder" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "builder" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kd2q59xpm39hpvmmvyi6g3f1fr05xjbnxwkrdqz4xy7hirqi79q"; type = "gem"; }; version = "1.4.0"; }; hashdiff = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nynpl0xbj0nphqx1qlmyggq58ms1phf5i03hk64wcc0a17x1m1c"; type = "gem"; }; version = "1.0.1"; }; hashie = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nh3arcrbz1rc1cr59qm53sdhqm137b258y8rcb4cvd3y98lwv4x"; type = "gem"; }; version = "5.0.0"; }; highline = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1f8cr014j7mdqpdb9q17fp5vb5b8n1pswqaif91s3ylg5x3pygfn"; type = "gem"; }; version = "2.1.0"; }; http-cookie = { - dependencies = ["domain_name"]; - groups = ["default"]; - platforms = []; + dependencies = [ "domain_name" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13rilvlv8kwbzqfb644qp6hrbsj82cbqmnzcvqip1p6vqx36sxbk"; type = "gem"; }; version = "1.0.5"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qaamqsh5f3szhcakkak8ikxlzxqnv49n2p7504hcz2l0f4nj0wx"; type = "gem"; }; version = "1.14.1"; }; ice_nine = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nv35qg1rps9fsis28hz2cq2fx1i96795f91q4nmkm934xynll2x"; type = "gem"; }; version = "0.11.2"; }; inifile = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c5zmk7ia63yw5l2k14qhfdydxwi1sah1ppjdiicr4zcalvfn0xi"; type = "gem"; }; version = "3.0.0"; }; inspec = { - dependencies = ["cookstyle" "faraday_middleware" "inspec-core" "mongo" "progress_bar" "rake" "train" "train-aws" "train-habitat" "train-kubernetes" "train-winrm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "cookstyle" + "faraday_middleware" + "inspec-core" + "mongo" + "progress_bar" + "rake" + "train" + "train-aws" + "train-habitat" + "train-kubernetes" + "train-winrm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0n1c3h1mrnw4059ih0n4gbi77qvwaigg6p8wmbpxkzya0jh45h55"; type = "gem"; }; version = "6.6.0"; }; inspec-bin = { - dependencies = ["inspec"]; - groups = ["default"]; - platforms = []; + dependencies = [ "inspec" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05g1sidv6grd9m7i85w4p5kpllds2jpvms6cmxs19948bm9abw91"; type = "gem"; }; version = "6.6.0"; }; inspec-core = { - dependencies = ["addressable" "chef-licensing" "chef-telemetry" "faraday" "faraday-follow_redirects" "hashie" "license-acceptance" "method_source" "mixlib-log" "multipart-post" "parallel" "parslet" "pry" "rspec" "rspec-its" "rubyzip" "semverse" "sslshake" "thor" "tomlrb" "train-core" "tty-prompt" "tty-table"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "chef-licensing" + "chef-telemetry" + "faraday" + "faraday-follow_redirects" + "hashie" + "license-acceptance" + "method_source" + "mixlib-log" + "multipart-post" + "parallel" + "parslet" + "pry" + "rspec" + "rspec-its" + "rubyzip" + "semverse" + "sslshake" + "thor" + "tomlrb" + "train-core" + "tty-prompt" + "tty-table" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0mlw0jbik3hpypnxx9bz4ymfzi8v9f875c73nql9m2j0zxb10hwa"; type = "gem"; }; version = "6.6.0"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cdw9vw2qly7q7r41s7phnac264rbsdqgj4l0h4nqgbjb157g393"; type = "gem"; }; version = "1.6.2"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0r9jmjhg2ly3l736flk7r2al47b5c8cayh0gqkq0yhjqzc9a6zhq"; type = "gem"; }; version = "2.7.1"; }; jsonpath = { - dependencies = ["multi_json" "to_regexp"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "multi_json" + "to_regexp" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zim5bl7zsbccd502iy63f7c3b6dw0a820z7q8kpv66hncavb7gp"; type = "gem"; }; version = "0.9.9"; }; jwt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16z11alz13vfc4zs5l3fk6n51n2jw9lskvc4h4prnww0y797qd87"; type = "gem"; }; version = "2.7.1"; }; k8s-ruby = { - dependencies = ["dry-configurable" "dry-struct" "dry-types" "excon" "hashdiff" "jsonpath" "recursive-open-struct" "yajl-ruby" "yaml-safe_load_stream3"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "dry-configurable" + "dry-struct" + "dry-types" + "excon" + "hashdiff" + "jsonpath" + "recursive-open-struct" + "yajl-ruby" + "yaml-safe_load_stream3" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "09q2lxwcsdmnqi91c62gc89bvwlq0arn5nvrl6g1whg46zvmis5z"; type = "gem"; }; version = "0.14.0"; }; license-acceptance = { - dependencies = ["pastel" "tomlrb" "tty-box" "tty-prompt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pastel" + "tomlrb" + "tty-box" + "tty-prompt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "12h5a3j57h50xkfpdz9gr42k0v8g1qxn2pnj5hbbzbmdhydjbjzf"; type = "gem"; }; version = "2.1.13"; }; little-plugger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1frilv82dyxnlg8k1jhrvyd73l6k17mxc5vwxx080r4x1p04gwym"; type = "gem"; }; version = "1.1.4"; }; logging = { - dependencies = ["little-plugger" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "little-plugger" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zflchpx4g8c110gjdcs540bk5a336nq6nmx379rdg56xw0pjd02"; type = "gem"; }; version = "2.3.1"; }; memoist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0i9wpzix3sjhf6d9zw60dm4371iq8kyz7ckh2qapan2vyaim6b55"; type = "gem"; }; version = "0.16.2"; }; method_source = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pnyh44qycnf9mzi1j6fywd5fkskv3x7nmsqrrws0rjn5dd4ayfp"; type = "gem"; }; version = "1.0.0"; }; mini_mime = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vycif7pjzkr29mfk4dlqv3disc5dn0va04lkwajlpr1wkibg0c6"; type = "gem"; }; version = "1.1.5"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bkmfi9mb49m0fkdhl2g38i3xxa02d411gg0m8x0gvbwfmmg5ym3"; type = "gem"; }; version = "5.20.0"; }; mixlib-config = { - dependencies = ["tomlrb"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tomlrb" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j0122lv2qgccl61njqi0pj6sp6nb85y07gcmw16bwg4k0c8nx6p"; type = "gem"; }; version = "3.0.27"; }; mixlib-log = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0n5dm5iz90ijvjn59jfm8gb8hgsvbj0f1kpzbl38b02z0z4a4v7x"; type = "gem"; }; version = "3.0.9"; }; mixlib-shellout = { - dependencies = ["chef-utils"]; - groups = ["default"]; - platforms = []; + dependencies = [ "chef-utils" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zkwg76y96nkh1mv0k92ybq46cr06v1wmic16129ls3yqzwx3xj6"; type = "gem"; }; version = "3.2.7"; }; mongo = { - dependencies = ["bson"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bson" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mkksik7mffwm29dz0pxjfz87rmm578nqzg8bc4kp076xqjwn2xp"; type = "gem"; }; version = "2.13.2"; }; ms_rest = { - dependencies = ["concurrent-ruby" "faraday" "timeliness"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "faraday" + "timeliness" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1jiha1bda5knpjqjymwik6i41n69gb0phcrgvmgc5icl4mcisai7"; type = "gem"; }; version = "0.7.6"; }; ms_rest_azure = { - dependencies = ["concurrent-ruby" "faraday" "faraday-cookie_jar" "ms_rest"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "faraday" + "faraday-cookie_jar" + "ms_rest" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "06i37b84r2q206kfm5vsi9s1qiiy09091vhvc5pzb7320h0hc1ih"; type = "gem"; }; version = "0.12.0"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lgyysrpl50wgcb9ahg29i4p01z0irb3p9lirygma0kkfr5dgk9x"; type = "gem"; }; version = "2.3.0"; }; net-scp = { - dependencies = ["net-ssh"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-ssh" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1si2nq9l6jy5n2zw1q59a5gaji7v9vhy8qx08h4fg368906ysbdk"; type = "gem"; }; version = "4.0.0"; }; net-ssh = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jyj6j7w9zpj2zhp4dyhdjiwsn9rqwksj7s7fzpnn7rx2xvz2a1a"; type = "gem"; }; version = "7.2.0"; }; nori = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "066wc774a2zp4vrq3k7k8p0fhv30ymqmxma1jj7yg5735zls8agn"; type = "gem"; }; version = "2.6.0"; }; options = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1s650nwnabx66w584m1cyw82icyym6hv5kzfsbp38cinkr5klh9j"; type = "gem"; }; version = "2.3.2"; }; os = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gwd20smyhxbm687vdikfh1gpi96h8qb1x28s2pdcysf6dm6v0ap"; type = "gem"; }; version = "1.1.4"; }; parallel = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jcc512l38c0c163ni3jgskvq1vc3mr8ly5pvjijzwvfml9lf597"; type = "gem"; }; version = "1.23.0"; }; parser = { - dependencies = ["ast" "racc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ast" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0r69dbh6h6j4d54isany2ir4ni4gf2ysvk3k44awi6amz18nggpd"; type = "gem"; }; version = "3.2.2.4"; }; parslet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12nrzfwjphjlakb9pmpj70hgjwgzvnr8i1zfzddifgyd44vspl88"; type = "gem"; }; version = "1.8.2"; }; pastel = { - dependencies = ["tty-color"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-color" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xash2gj08dfjvq4hy6l1z22s5v30fhizwgs10d6nviggpxsj7a8"; type = "gem"; }; version = "0.8.0"; }; progress_bar = { - dependencies = ["highline" "options"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "highline" + "options" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "04kv6h5mdjd9zf8mcf2dplxls06n2jf72281s74k6b2ar731hc47"; type = "gem"; }; version = "1.3.3"; }; pry = { - dependencies = ["coderay" "method_source"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "coderay" + "method_source" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k9kqkd9nps1w1r1rb7wjr31hqzkka2bhi8b518x78dcxppm9zn4"; type = "gem"; }; version = "0.14.2"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bni4qjrsh2q49pnmmd6if4iv3ak36bd2cckrs6npl111n769k9m"; type = "gem"; }; version = "5.0.4"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01b9662zd2x9bp4rdjfid07h09zxj7kvn7f5fghbqhzc625ap1dp"; type = "gem"; }; version = "1.7.3"; }; rainbow = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0smwg4mii0fm38pyb5fddbmrdpifwv22zv3d3px2xx497am93503"; type = "gem"; }; version = "3.1.1"; }; rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ilr853hawi09626axx0mps4rkkmxcs54mapz9jnqvpnlwd3wsmy"; type = "gem"; }; version = "13.1.0"; }; recursive-open-struct = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nnyr6qsqrcszf6c10n4zfjs8h9n67zvsmx6mp8brkigamr8llx3"; type = "gem"; }; version = "1.1.3"; }; regexp_parser = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xrghj2vka7girycp1m88kvl4qxkm4mj4djz4w1jzywb4v97fclm"; type = "gem"; }; version = "2.8.3"; }; representable = { - dependencies = ["declarative" "trailblazer-option" "uber"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "declarative" + "trailblazer-option" + "uber" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1kms3r6w6pnryysnaqqa9fsn0v73zx1ilds9d1c565n3xdzbyafc"; type = "gem"; }; version = "3.2.0"; }; retriable = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q48hqws2dy1vws9schc0kmina40gy7sn5qsndpsfqdslh65snha"; type = "gem"; }; version = "3.1.2"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05i8518ay14kjbma550mv0jm8a6di8yp5phzrd8rj44z9qnrlrp0"; type = "gem"; }; version = "3.2.6"; }; rspec = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "171rc90vcgjl8p1bdrqa92ymrj8a87qf6w20x05xq29mljcigi6c"; type = "gem"; }; version = "3.12.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rspec-support" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0l95bnjxdabrn79hwdhn2q1n7mn26pj7y1w5660v5qi81x458nqm"; type = "gem"; }; version = "3.12.2"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05j44jfqlv7j2rpxb5vqzf9hfv7w8ba46wwgxwcwd8p0wzi1hg89"; type = "gem"; }; version = "3.12.3"; }; rspec-its = { - dependencies = ["rspec-core" "rspec-expectations"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rspec-core" + "rspec-expectations" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15zafd70gxly5i0s00nky14sj2n92dnj3xpj83ysl3c2wx0119ad"; type = "gem"; }; version = "1.3.0"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1gq7gviwpck7fhp4y5ibljljvxgjklza18j62qf6zkm2icaa8lfy"; type = "gem"; }; version = "3.12.6"; }; rspec-support = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ky86j3ksi26ng9ybd7j0qsdf1lpr8mzrmn98yy9gzv801fvhsgr"; type = "gem"; }; version = "3.12.1"; }; rubocop = { - dependencies = ["parallel" "parser" "rainbow" "regexp_parser" "rexml" "rubocop-ast" "ruby-progressbar" "unicode-display_width"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "parallel" + "parser" + "rainbow" + "regexp_parser" + "rexml" + "rubocop-ast" + "ruby-progressbar" + "unicode-display_width" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1l3q96il8zx5zl041lxvmfrndxxpk08fksza1gqshhjjzms7c2rk"; type = "gem"; }; version = "1.25.1"; }; rubocop-ast = { - dependencies = ["parser"]; - groups = ["default"]; - platforms = []; + dependencies = [ "parser" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cs9cc5p9q70valk4na3lki4xs88b52486p2v46yx3q1n5969bgs"; type = "gem"; }; version = "1.30.0"; }; ruby-progressbar = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cwvyb7j47m7wihpfaq7rc47zwwx9k4v7iqd9s1xch5nm53rrz40"; type = "gem"; }; version = "1.13.0"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; rubyntlm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b8hczk8hysv53ncsqzx4q6kma5gy5lqc7s5yx8h64x3vdb18cjv"; type = "gem"; }; version = "0.6.3"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; semverse = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vrh6p0756n3gjnk6am1cc4kmw6wzzd02hcajj27rlsqg3p6lwn9"; type = "gem"; }; version = "3.0.2"; }; signet = { - dependencies = ["addressable" "faraday" "jwt" "multi_json"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "faraday" + "jwt" + "multi_json" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fzakk5y7zzii76zlkynpp1c764mzkkfg4mpj18f5pf2xp1aikb6"; type = "gem"; }; version = "0.18.0"; }; sslshake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0r3ifksx8a05yqhv7nc4cwan8bwmxgq5kyv7q7hy2h9lv5zcjs8h"; type = "gem"; }; version = "1.3.1"; }; strings = { - dependencies = ["strings-ansi" "unicode-display_width" "unicode_utils"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "strings-ansi" + "unicode-display_width" + "unicode_utils" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yynb0qhhhplmpzavfrrlwdnd1rh7rkwzcs4xf0mpy2wr6rr6clk"; type = "gem"; }; version = "0.2.1"; }; strings-ansi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "120wa6yjc63b84lprglc52f40hx3fx920n4dmv14rad41rv2s9lh"; type = "gem"; }; version = "0.2.0"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k7j2wn14h1pl4smibasw0bp66kg626drxb59z7rzflch99cd4rg"; type = "gem"; }; version = "1.2.2"; }; timeliness = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gvp9b7yn4pykn794cibylc9ys1lw7fzv7djx1433icxw4y26my3"; type = "gem"; }; version = "0.3.10"; }; to_regexp = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rgabfhnql6l4fx09mmj5d0vza924iczqf2blmn82l782b6qqi9v"; type = "gem"; }; version = "0.2.1"; }; tomlrb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00x5y9h4fbvrv4xrjk4cqlkm4vq8gv73ax4alj3ac2x77zsnnrk8"; type = "gem"; }; version = "1.3.0"; }; trailblazer-option = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18s48fndi2kfvrfzmq6rxvjfwad347548yby0341ixz1lhpg3r10"; type = "gem"; }; version = "0.1.2"; }; train = { - dependencies = ["activesupport" "azure_graph_rbac" "azure_mgmt_key_vault" "azure_mgmt_resources" "azure_mgmt_security" "azure_mgmt_storage" "docker-api" "google-api-client" "googleauth" "inifile" "train-core" "train-winrm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activesupport" + "azure_graph_rbac" + "azure_mgmt_key_vault" + "azure_mgmt_resources" + "azure_mgmt_security" + "azure_mgmt_storage" + "docker-api" + "google-api-client" + "googleauth" + "inifile" + "train-core" + "train-winrm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "18ghsakhnm4xjzfi53d1ij5a2vgr1nk8fgqrr05rbya7c9sbh8ns"; type = "gem"; }; version = "3.11.0"; }; train-aws = { - dependencies = ["aws-sdk-account" "aws-sdk-alexaforbusiness" "aws-sdk-amplify" "aws-sdk-apigateway" "aws-sdk-apigatewayv2" "aws-sdk-applicationautoscaling" "aws-sdk-athena" "aws-sdk-autoscaling" "aws-sdk-batch" "aws-sdk-budgets" "aws-sdk-cloudformation" "aws-sdk-cloudfront" "aws-sdk-cloudhsm" "aws-sdk-cloudhsmv2" "aws-sdk-cloudtrail" "aws-sdk-cloudwatch" "aws-sdk-cloudwatchevents" "aws-sdk-cloudwatchlogs" "aws-sdk-codecommit" "aws-sdk-codedeploy" "aws-sdk-codepipeline" "aws-sdk-cognitoidentity" "aws-sdk-cognitoidentityprovider" "aws-sdk-configservice" "aws-sdk-core" "aws-sdk-costandusagereportservice" "aws-sdk-databasemigrationservice" "aws-sdk-dynamodb" "aws-sdk-ec2" "aws-sdk-ecr" "aws-sdk-ecrpublic" "aws-sdk-ecs" "aws-sdk-efs" "aws-sdk-eks" "aws-sdk-elasticache" "aws-sdk-elasticbeanstalk" "aws-sdk-elasticloadbalancing" "aws-sdk-elasticloadbalancingv2" "aws-sdk-elasticsearchservice" "aws-sdk-emr" "aws-sdk-eventbridge" "aws-sdk-firehose" "aws-sdk-glue" "aws-sdk-guardduty" "aws-sdk-iam" "aws-sdk-kafka" "aws-sdk-kinesis" "aws-sdk-kms" "aws-sdk-lambda" "aws-sdk-mq" "aws-sdk-networkfirewall" "aws-sdk-networkmanager" "aws-sdk-organizations" "aws-sdk-ram" "aws-sdk-rds" "aws-sdk-redshift" "aws-sdk-route53" "aws-sdk-route53domains" "aws-sdk-route53resolver" "aws-sdk-s3" "aws-sdk-s3control" "aws-sdk-secretsmanager" "aws-sdk-securityhub" "aws-sdk-servicecatalog" "aws-sdk-ses" "aws-sdk-shield" "aws-sdk-signer" "aws-sdk-simpledb" "aws-sdk-sms" "aws-sdk-sns" "aws-sdk-sqs" "aws-sdk-ssm" "aws-sdk-states" "aws-sdk-synthetics" "aws-sdk-transfer" "aws-sdk-waf"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "aws-sdk-account" + "aws-sdk-alexaforbusiness" + "aws-sdk-amplify" + "aws-sdk-apigateway" + "aws-sdk-apigatewayv2" + "aws-sdk-applicationautoscaling" + "aws-sdk-athena" + "aws-sdk-autoscaling" + "aws-sdk-batch" + "aws-sdk-budgets" + "aws-sdk-cloudformation" + "aws-sdk-cloudfront" + "aws-sdk-cloudhsm" + "aws-sdk-cloudhsmv2" + "aws-sdk-cloudtrail" + "aws-sdk-cloudwatch" + "aws-sdk-cloudwatchevents" + "aws-sdk-cloudwatchlogs" + "aws-sdk-codecommit" + "aws-sdk-codedeploy" + "aws-sdk-codepipeline" + "aws-sdk-cognitoidentity" + "aws-sdk-cognitoidentityprovider" + "aws-sdk-configservice" + "aws-sdk-core" + "aws-sdk-costandusagereportservice" + "aws-sdk-databasemigrationservice" + "aws-sdk-dynamodb" + "aws-sdk-ec2" + "aws-sdk-ecr" + "aws-sdk-ecrpublic" + "aws-sdk-ecs" + "aws-sdk-efs" + "aws-sdk-eks" + "aws-sdk-elasticache" + "aws-sdk-elasticbeanstalk" + "aws-sdk-elasticloadbalancing" + "aws-sdk-elasticloadbalancingv2" + "aws-sdk-elasticsearchservice" + "aws-sdk-emr" + "aws-sdk-eventbridge" + "aws-sdk-firehose" + "aws-sdk-glue" + "aws-sdk-guardduty" + "aws-sdk-iam" + "aws-sdk-kafka" + "aws-sdk-kinesis" + "aws-sdk-kms" + "aws-sdk-lambda" + "aws-sdk-mq" + "aws-sdk-networkfirewall" + "aws-sdk-networkmanager" + "aws-sdk-organizations" + "aws-sdk-ram" + "aws-sdk-rds" + "aws-sdk-redshift" + "aws-sdk-route53" + "aws-sdk-route53domains" + "aws-sdk-route53resolver" + "aws-sdk-s3" + "aws-sdk-s3control" + "aws-sdk-secretsmanager" + "aws-sdk-securityhub" + "aws-sdk-servicecatalog" + "aws-sdk-ses" + "aws-sdk-shield" + "aws-sdk-signer" + "aws-sdk-simpledb" + "aws-sdk-sms" + "aws-sdk-sns" + "aws-sdk-sqs" + "aws-sdk-ssm" + "aws-sdk-states" + "aws-sdk-synthetics" + "aws-sdk-transfer" + "aws-sdk-waf" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0b0p6ig4dfd2y1cfwdlzxj7wsbllwyzxd1wg87z1vs78v892ip5n"; type = "gem"; }; version = "0.2.36"; }; train-core = { - dependencies = ["addressable" "ffi" "json" "mixlib-shellout" "net-scp" "net-ssh"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "ffi" + "json" + "mixlib-shellout" + "net-scp" + "net-ssh" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1j3pfsdrrqpcqp9qbqdh4j1557hww3q3gyjjpnzmgkw43vv685gb"; type = "gem"; }; version = "3.11.0"; }; train-habitat = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qdi2q5djzfl6x3fv2vrvybjdvrnx53nfh4vzrcl2h7nrf801n6v"; type = "gem"; }; version = "0.2.22"; }; train-kubernetes = { - dependencies = ["k8s-ruby" "train"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "k8s-ruby" + "train" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "02gy54pybd53hbaay1kllk269pjwbjzfr3jlgxa6sd68ljy7s5w2"; type = "gem"; }; version = "0.1.12"; }; train-winrm = { - dependencies = ["winrm" "winrm-elevated" "winrm-fs"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "winrm" + "winrm-elevated" + "winrm-fs" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "07haiwh7jcg00mmiarj5g7k9kclq40yqd4j4r3c01qn2cq1sw2xb"; type = "gem"; }; version = "0.2.13"; }; tty-box = { - dependencies = ["pastel" "strings" "tty-cursor"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pastel" + "strings" + "tty-cursor" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "12yzhl3s165fl8pkfln6mi6mfy3vg7p63r3dvcgqfhyzq6h57x0p"; type = "gem"; }; version = "0.7.0"; }; tty-color = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0aik4kmhwwrmkysha7qibi2nyzb4c8kp42bd5vxnf8sf7b53g73g"; type = "gem"; }; version = "0.6.0"; }; tty-cursor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j5zw041jgkmn605ya1zc151bxgxl6v192v2i26qhxx7ws2l2lvr"; type = "gem"; }; version = "0.7.1"; }; tty-prompt = { - dependencies = ["pastel" "tty-reader"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pastel" + "tty-reader" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1j4y8ik82azjxshgd4i1v4wwhsv3g9cngpygxqkkz69qaa8cxnzw"; type = "gem"; }; version = "0.23.1"; }; tty-reader = { - dependencies = ["tty-cursor" "tty-screen" "wisper"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "tty-cursor" + "tty-screen" + "wisper" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1cf2k7w7d84hshg4kzrjvk9pkyc2g1m3nx2n1rpmdcf0hp4p4af6"; type = "gem"; }; version = "0.9.0"; }; tty-screen = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18jr6s1cg8yb26wzkqa6874q0z93rq0y5aw092kdqazk71y6a235"; type = "gem"; }; version = "0.8.1"; }; tty-spinner = { - dependencies = ["tty-cursor"]; - groups = ["default"]; - platforms = []; + dependencies = [ "tty-cursor" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hh5awmijnzw9flmh5ak610x1d00xiqagxa5mbr63ysggc26y0qf"; type = "gem"; }; version = "0.9.3"; }; tty-table = { - dependencies = ["pastel" "strings" "tty-screen"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pastel" + "strings" + "tty-screen" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fcrbfb0hjd9vkkazkksri93dv9wgs2hp6p1xwb1lp43a13pmhpx"; type = "gem"; }; version = "0.12.0"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; uber = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1p1mm7mngg40x05z52md3mbamkng0zpajbzqjjwmsyw0zw3v9vjv"; type = "gem"; }; version = "0.1.0"; }; unicode-display_width = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d0azx233nags5jx3fqyr23qa2rhgzbhv8pxp46dgbg1mpf82xky"; type = "gem"; }; version = "2.5.0"; }; unicode_utils = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h1a5yvrxzlf0lxxa1ya31jcizslf774arnsd89vgdhk4g7x08mr"; type = "gem"; }; version = "1.4.0"; }; winrm = { - dependencies = ["builder" "erubi" "gssapi" "gyoku" "httpclient" "logging" "nori" "rubyntlm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "builder" + "erubi" + "gssapi" + "gyoku" + "httpclient" + "logging" + "nori" + "rubyntlm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0nxf6a47d1xf1nvi7rbfbzjyyjhz0iakrnrsr2hj6y24a381sd8i"; type = "gem"; }; version = "2.3.6"; }; winrm-elevated = { - dependencies = ["erubi" "winrm" "winrm-fs"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "erubi" + "winrm" + "winrm-fs" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1lmlaii8qapn84wxdg5d82gbailracgk67d0qsnbdnffcg8kswzd"; type = "gem"; }; version = "1.2.3"; }; winrm-fs = { - dependencies = ["erubi" "logging" "rubyzip" "winrm"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "erubi" + "logging" + "rubyzip" + "winrm" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0gb91k6s1yjqw387x4w1nkpnxblq3pjdqckayl0qvz5n3ygdsb0d"; type = "gem"; }; version = "1.3.5"; }; wisper = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rpsi0ziy78cj82sbyyywby4d0aw0a5q84v65qd28vqn79fbq5yf"; type = "gem"; }; version = "2.0.1"; }; yajl-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1lni4jbyrlph7sz8y49q84pb0sbj82lgwvnjnsiv01xf26f4v5wc"; type = "gem"; }; version = "1.4.3"; }; yaml-safe_load_stream3 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10g4wy0vmggxnb3bz1zz74rfhhzqa50hc553sn7yqrbywpzn6kzx"; type = "gem"; }; version = "0.1.2"; }; zeitwerk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gir0if4nryl1jhwi28669gjwhxb7gzrm1fcc8xzsch3bnbi47jn"; type = "gem"; }; diff --git a/pkgs/tools/misc/isoimagewriter/default.nix b/pkgs/tools/misc/isoimagewriter/default.nix index df80077e665703..b26629065cca3a 100644 --- a/pkgs/tools/misc/isoimagewriter/default.nix +++ b/pkgs/tools/misc/isoimagewriter/default.nix @@ -1,5 +1,18 @@ -{ lib, mkDerivation, fetchurl, cmake, extra-cmake-modules, wrapQtAppsHook, -karchive, kcoreaddons, kcrash, kiconthemes, kwidgetsaddons, solid, qgpgme }: +{ + lib, + mkDerivation, + fetchurl, + cmake, + extra-cmake-modules, + wrapQtAppsHook, + karchive, + kcoreaddons, + kcrash, + kiconthemes, + kwidgetsaddons, + solid, + qgpgme, +}: mkDerivation rec { pname = "isoimagewriter"; version = "1.0.0"; @@ -9,7 +22,11 @@ mkDerivation rec { hash = "sha256-ppAiMD7Bvra3tPDWjlnkGZ08mGh2fLnrI8bdGZngal0="; }; - nativeBuildInputs = [ cmake extra-cmake-modules wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + wrapQtAppsHook + ]; buildInputs = [ karchive kcoreaddons diff --git a/pkgs/tools/misc/kakoune-cr/default.nix b/pkgs/tools/misc/kakoune-cr/default.nix index 8522bfa7f78241..4d97fc89794c5e 100644 --- a/pkgs/tools/misc/kakoune-cr/default.nix +++ b/pkgs/tools/misc/kakoune-cr/default.nix @@ -1,4 +1,11 @@ -{ lib, crystal, fetchFromGitHub, fetchurl, jq, bash }: +{ + lib, + crystal, + fetchFromGitHub, + fetchurl, + jq, + bash, +}: let icon = fetchurl { url = "https://github.com/mawww/kakoune/raw/master/doc/kakoune_logo.svg"; @@ -44,7 +51,10 @@ crystal.buildCrystalPackage rec { homepage = "https://github.com/alexherbo2/kakoune.cr"; description = "Command-line tool for Kakoune"; license = licenses.unlicense; - maintainers = with maintainers; [ philiptaron malte-v ]; + maintainers = with maintainers; [ + philiptaron + malte-v + ]; platforms = platforms.unix; }; } diff --git a/pkgs/tools/misc/killport/default.nix b/pkgs/tools/misc/killport/default.nix index 24f66a8b497fad..514d61a3bf150d 100644 --- a/pkgs/tools/misc/killport/default.nix +++ b/pkgs/tools/misc/killport/default.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchCrate +{ + lib, + rustPlatform, + fetchCrate, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/tools/misc/kronometer/default.nix b/pkgs/tools/misc/kronometer/default.nix index f8f818c9cc9b83..f8442ecd6c4678 100644 --- a/pkgs/tools/misc/kronometer/default.nix +++ b/pkgs/tools/misc/kronometer/default.nix @@ -1,7 +1,12 @@ { - mkDerivation, fetchurl, lib, - extra-cmake-modules, kdoctools, - kconfig, kcrash, kinit + mkDerivation, + fetchurl, + lib, + extra-cmake-modules, + kdoctools, + kconfig, + kcrash, + kinit, }: mkDerivation rec { @@ -20,6 +25,13 @@ mkDerivation rec { maintainers = with maintainers; [ peterhoeg ]; mainProgram = "kronometer"; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools ]; - propagatedBuildInputs = [ kconfig kcrash kinit ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + ]; + propagatedBuildInputs = [ + kconfig + kcrash + kinit + ]; } diff --git a/pkgs/tools/misc/krunner-translator/default.nix b/pkgs/tools/misc/krunner-translator/default.nix index e500b7c1ddea85..ce20c400f5b95a 100644 --- a/pkgs/tools/misc/krunner-translator/default.nix +++ b/pkgs/tools/misc/krunner-translator/default.nix @@ -1,17 +1,18 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, extra-cmake-modules -, krunner -, kconfigwidgets -, ktextwidgets -, kservice -, ki18n -, translate-shell -, qtbase -, qtdeclarative -, qtlocation +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + extra-cmake-modules, + krunner, + kconfigwidgets, + ktextwidgets, + kservice, + ki18n, + translate-shell, + qtbase, + qtdeclarative, + qtlocation, }: stdenv.mkDerivation rec { @@ -25,7 +26,10 @@ stdenv.mkDerivation rec { sha256 = "8MusGvNhTxa8Sm8WiSwRaVIfZOeXmgcO4T6H9LqFGLs="; }; - nativeBuildInputs = [ cmake extra-cmake-modules ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; dontWrapQtApps = true; diff --git a/pkgs/tools/misc/ksnip/default.nix b/pkgs/tools/misc/ksnip/default.nix index 05920cb7c79040..f56c9a537378c7 100644 --- a/pkgs/tools/misc/ksnip/default.nix +++ b/pkgs/tools/misc/ksnip/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, cmake -, extra-cmake-modules -, fetchFromGitHub -, fetchpatch -, kcolorpicker -, kimageannotator -, wrapQtAppsHook -, qtsvg -, qttools -, qtx11extras +{ + stdenv, + lib, + cmake, + extra-cmake-modules, + fetchFromGitHub, + fetchpatch, + kcolorpicker, + kimageannotator, + wrapQtAppsHook, + qtsvg, + qttools, + qtx11extras, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/misc/lice/default.nix b/pkgs/tools/misc/lice/default.nix index f873907c51efd1..0c41956f51b5f5 100644 --- a/pkgs/tools/misc/lice/default.nix +++ b/pkgs/tools/misc/lice/default.nix @@ -1,4 +1,10 @@ -{ lib, buildPythonPackage, fetchPypi , setuptools, pytestCheckHook }: +{ + lib, + buildPythonPackage, + fetchPypi, + setuptools, + pytestCheckHook, +}: buildPythonPackage rec { pname = "lice"; diff --git a/pkgs/tools/misc/logstash/7.x.nix b/pkgs/tools/misc/logstash/7.x.nix index c7e21e0521d4b2..3a09752bf63828 100644 --- a/pkgs/tools/misc/logstash/7.x.nix +++ b/pkgs/tools/misc/logstash/7.x.nix @@ -1,12 +1,13 @@ -{ config -, elk7Version -, enableUnfree ? true -, lib -, stdenv -, fetchurl -, makeWrapper -, nixosTests -, jre +{ + config, + elk7Version, + enableUnfree ? true, + lib, + stdenv, + fetchurl, + makeWrapper, + nixosTests, + jre, }: let @@ -14,22 +15,22 @@ let arch = lib.elemAt info 0; plat = lib.elemAt info 1; hashes = - if enableUnfree - then { - x86_64-linux = "sha512-ze0hJxUHCN52bOxUs5upDj64tIE58P2BTow2kaCo6HreRiF9rfTTzNkNr/hCmEgE+/oFbgSEuOQLz+6G373RDQ=="; - x86_64-darwin = "sha512-FOFd8d+4UddSGorjuUWW/JbQ5fQH4LU1f1HJLmdbfnb8Q5L4GEveb2LmWNILU8/a85V4HGmD6lL8mCJqH9CULQ=="; - aarch64-linux = "sha512-giYqW88/6iT3haXzJVn/+b7uxjYhHq4GERmiq3tMIvjxDyu7B6g+X7JneaTYxhpNdn6gOD/hfXgNv+hFRq6lgg=="; - } - else { - x86_64-linux = "sha512-OC9gx76k+RMdjqcDkrJCNbPYSQameyddaYMxUIB0foVxCmo6UvbdcwZGXRLPPn95in8rYOCjvPoBkmupiQw9xQ=="; - x86_64-darwin = "sha512-1OEfEED/jjlT3Fd095Y5VYiWKnovytI3UYCCy1Rs3tEvkZPHYwqIQHfMQYeAvGgUci37ADwEDu8xrSQULHToLw=="; - aarch64-linux = "sha512-QWW0AXOMNIXThxpUiRomvINm+917MvGrSDndrEw11IYYuvi0d0dckJiRytfnBbBNoOKpVhB68uOmfjIcZBNpWQ=="; - }; + if enableUnfree then + { + x86_64-linux = "sha512-ze0hJxUHCN52bOxUs5upDj64tIE58P2BTow2kaCo6HreRiF9rfTTzNkNr/hCmEgE+/oFbgSEuOQLz+6G373RDQ=="; + x86_64-darwin = "sha512-FOFd8d+4UddSGorjuUWW/JbQ5fQH4LU1f1HJLmdbfnb8Q5L4GEveb2LmWNILU8/a85V4HGmD6lL8mCJqH9CULQ=="; + aarch64-linux = "sha512-giYqW88/6iT3haXzJVn/+b7uxjYhHq4GERmiq3tMIvjxDyu7B6g+X7JneaTYxhpNdn6gOD/hfXgNv+hFRq6lgg=="; + } + else + { + x86_64-linux = "sha512-OC9gx76k+RMdjqcDkrJCNbPYSQameyddaYMxUIB0foVxCmo6UvbdcwZGXRLPPn95in8rYOCjvPoBkmupiQw9xQ=="; + x86_64-darwin = "sha512-1OEfEED/jjlT3Fd095Y5VYiWKnovytI3UYCCy1Rs3tEvkZPHYwqIQHfMQYeAvGgUci37ADwEDu8xrSQULHToLw=="; + aarch64-linux = "sha512-QWW0AXOMNIXThxpUiRomvINm+917MvGrSDndrEw11IYYuvi0d0dckJiRytfnBbBNoOKpVhB68uOmfjIcZBNpWQ=="; + }; this = stdenv.mkDerivation rec { version = elk7Version; pname = "logstash${lib.optionalString (!enableUnfree) "-oss"}"; - src = fetchurl { url = "https://artifacts.elastic.co/downloads/logstash/${pname}-${version}-${plat}-${arch}.tar.gz"; hash = hashes.${stdenv.hostPlatform.system} or (throw "Unknown architecture"); @@ -69,20 +70,22 @@ let homepage = "https://www.elastic.co/products/logstash"; sourceProvenance = with sourceTypes; [ fromSource - binaryBytecode # source bundles dependencies as jars - binaryNativeCode # bundled jruby includes native code + binaryBytecode # source bundles dependencies as jars + binaryNativeCode # bundled jruby includes native code ]; license = if enableUnfree then licenses.elastic20 else licenses.asl20; platforms = platforms.unix; - maintainers = with maintainers; [ offline basvandijk ]; + maintainers = with maintainers; [ + offline + basvandijk + ]; }; - passthru.tests = - lib.optionalAttrs (config.allowUnfree && enableUnfree) ( - assert this.drvPath == nixosTests.elk.unfree.ELK-7.elkPackages.logstash.drvPath; - { - elk = nixosTests.elk.unfree.ELK-7; - } - ); + passthru.tests = lib.optionalAttrs (config.allowUnfree && enableUnfree) ( + assert this.drvPath == nixosTests.elk.unfree.ELK-7.elkPackages.logstash.drvPath; + { + elk = nixosTests.elk.unfree.ELK-7; + } + ); }; in this diff --git a/pkgs/tools/misc/logstash/contrib.nix b/pkgs/tools/misc/logstash/contrib.nix index 64c0c9b9b3ff21..a6469d830b7658 100644 --- a/pkgs/tools/misc/logstash/contrib.nix +++ b/pkgs/tools/misc/logstash/contrib.nix @@ -1,4 +1,8 @@ -{ stdenv, lib, fetchzip }: +{ + stdenv, + lib, + fetchzip, +}: # Note that plugins are supposed to be installed as: # $path/logstash/{inputs,codecs,filters,outputs}/*.rb @@ -7,13 +11,13 @@ stdenv.mkDerivation rec { pname = "logstash-contrib"; src = fetchzip { - url = "https://download.elasticsearch.org/logstash/logstash/logstash-contrib-${version}.tar.gz"; - sha256 = "1yj8sf3b526gixh3c6zhgkfpg4f0c72p1lzhfhdx8b3lw7zjkj0k"; + url = "https://download.elasticsearch.org/logstash/logstash/logstash-contrib-${version}.tar.gz"; + sha256 = "1yj8sf3b526gixh3c6zhgkfpg4f0c72p1lzhfhdx8b3lw7zjkj0k"; }; - dontBuild = true; + dontBuild = true; dontPatchELF = true; - dontStrip = true; + dontStrip = true; dontPatchShebangs = true; installPhase = '' @@ -25,9 +29,9 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Community-maintained logstash plugins"; - homepage = "https://github.com/elasticsearch/logstash-contrib"; - license = lib.licenses.asl20; - platforms = lib.platforms.unix; + homepage = "https://github.com/elasticsearch/logstash-contrib"; + license = lib.licenses.asl20; + platforms = lib.platforms.unix; maintainers = [ ]; }; } diff --git a/pkgs/tools/misc/lolcat/default.nix b/pkgs/tools/misc/lolcat/default.nix index b56606d21d5df8..b91c5c9967eeab 100644 --- a/pkgs/tools/misc/lolcat/default.nix +++ b/pkgs/tools/misc/lolcat/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "lolcat"; @@ -9,9 +13,13 @@ bundlerApp { meta = with lib; { description = "Rainbow version of cat"; - homepage = "https://github.com/busyloop/lolcat"; - license = licenses.bsd3; - maintainers = with maintainers; [ StillerHarpo manveru nicknovitski ]; + homepage = "https://github.com/busyloop/lolcat"; + license = licenses.bsd3; + maintainers = with maintainers; [ + StillerHarpo + manveru + nicknovitski + ]; mainProgram = "lolcat"; }; } diff --git a/pkgs/tools/misc/lolcat/gemset.nix b/pkgs/tools/misc/lolcat/gemset.nix index 9d71d400a69ea4..665d255b820b55 100644 --- a/pkgs/tools/misc/lolcat/gemset.nix +++ b/pkgs/tools/misc/lolcat/gemset.nix @@ -1,40 +1,44 @@ { lolcat = { - dependencies = ["manpages" "optimist" "paint"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "manpages" + "optimist" + "paint" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13p8i08vdqfg2bqyjkl8jsp7gw8cf6r68i8plp9zqavlqadqlg4q"; type = "gem"; }; version = "100.0.1"; }; manpages = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11p6ilnfda6af15ks3xiz2pr0hkvdvadnk1xm4ahqlf84dld3fnd"; type = "gem"; }; version = "0.6.1"; }; optimist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vg2chy1cfmdj6c1gryl8zvjhhmb3plwgyh1jfnpq4fnfqv7asrk"; type = "gem"; }; version = "3.0.1"; }; paint = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "014b5rkbg6qri0cwkq972bfi93zvqdgswgvphjrgjl0pr6hywlkl"; type = "gem"; }; diff --git a/pkgs/tools/misc/lorri/default.nix b/pkgs/tools/misc/lorri/default.nix index 6ba07b3d874e47..a30f368ba76a11 100644 --- a/pkgs/tools/misc/lorri/default.nix +++ b/pkgs/tools/misc/lorri/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, pkgs -, rustPackages -, fetchFromGitHub -, rustPlatform -, writers -, nixosTests -, CoreServices -, Security +{ + lib, + stdenv, + pkgs, + rustPackages, + fetchFromGitHub, + rustPlatform, + writers, + nixosTests, + CoreServices, + Security, }: let @@ -18,7 +19,8 @@ let sha256 = "sha256-dEdKMgE4Jd8CCvtGQDZNDCYOomZAV8aR7Cmtyn8RfTo="; cargoHash = "sha256-+sKxKxc2DVHn54uQa8K+CKmm0A0ym9SXgtOcfRZ6R5E="; -in (rustPlatform.buildRustPackage rec { +in +(rustPlatform.buildRustPackage rec { pname = "lorri"; inherit version; @@ -29,7 +31,11 @@ in (rustPlatform.buildRustPackage rec { inherit sha256; }; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; inherit cargoHash; doCheck = false; @@ -38,7 +44,10 @@ in (rustPlatform.buildRustPackage rec { RUN_TIME_CLOSURE = pkgs.callPackage ./runtime.nix { }; nativeBuildInputs = [ rustPackages.rustfmt ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices Security ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + Security + ]; # copy the docs to the $man and $doc outputs postInstall = '' @@ -66,7 +75,11 @@ in (rustPlatform.buildRustPackage rec { description = "Your project's nix-env"; homepage = "https://github.com/nix-community/lorri"; license = licenses.asl20; - maintainers = with maintainers; [ grahamc Profpatsch nyarly ]; + maintainers = with maintainers; [ + grahamc + Profpatsch + nyarly + ]; mainProgram = "lorri"; }; }) diff --git a/pkgs/tools/misc/lorri/runtime.nix b/pkgs/tools/misc/lorri/runtime.nix index 7e6883be0644d3..c5620a0a568bae 100644 --- a/pkgs/tools/misc/lorri/runtime.nix +++ b/pkgs/tools/misc/lorri/runtime.nix @@ -1,37 +1,41 @@ { # Plumbing tools: - closureInfo -, runCommand -, buildEnv -, # Actual dependencies to propagate: - bash -, coreutils + closureInfo, + runCommand, + buildEnv, + # Actual dependencies to propagate: + bash, + coreutils, }: let tools = buildEnv { name = "lorri-runtime-tools"; - paths = [ coreutils bash ]; + paths = [ + coreutils + bash + ]; }; runtimeClosureInfo = closureInfo { rootPaths = [ tools ]; }; - closureToNix = runCommand "closure.nix" {} - '' - ( - echo '{ dep, ... }: [' - sed -E 's/^(.*)$/ (dep \1)/' ${runtimeClosureInfo}/store-paths - echo ']' - ) > $out - ''; + closureToNix = runCommand "closure.nix" { } '' + ( + echo '{ dep, ... }: [' + sed -E 's/^(.*)$/ (dep \1)/' ${runtimeClosureInfo}/store-paths + echo ']' + ) > $out + ''; - runtimeClosureInfoAsNix = runCommand "runtime-closure.nix" { - runtime_closure_list = closureToNix; - tools_build_host = tools; - } - '' - substituteAll ${./runtime-closure.nix.template} $out - ''; + runtimeClosureInfoAsNix = + runCommand "runtime-closure.nix" + { + runtime_closure_list = closureToNix; + tools_build_host = tools; + } + '' + substituteAll ${./runtime-closure.nix.template} $out + ''; in runtimeClosureInfoAsNix diff --git a/pkgs/tools/misc/minicom/default.nix b/pkgs/tools/misc/minicom/default.nix index 89653c26d6a03c..f953f57cef2b14 100644 --- a/pkgs/tools/misc/minicom/default.nix +++ b/pkgs/tools/misc/minicom/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitLab -, autoreconfHook -, makeWrapper -, pkg-config -, lrzsz -, ncurses -, libiconv -, IOKit +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + makeWrapper, + pkg-config, + lrzsz, + ncurses, + libiconv, + IOKit, }: stdenv.mkDerivation rec { @@ -22,9 +23,18 @@ stdenv.mkDerivation rec { sha256 = "sha256-+fKvHrApDXm94LItXv+xSDIE5zD7rTY5IeNSuzQglpg="; }; - buildInputs = [ ncurses ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv IOKit ]; + buildInputs = + [ ncurses ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + IOKit + ]; - nativeBuildInputs = [ autoreconfHook makeWrapper pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + makeWrapper + pkg-config + ]; enableParallelBuilding = true; diff --git a/pkgs/tools/misc/moreutils/default.nix b/pkgs/tools/misc/moreutils/default.nix index e557a05f30627d..584a686ed5109f 100644 --- a/pkgs/tools/misc/moreutils/default.nix +++ b/pkgs/tools/misc/moreutils/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchgit -, libxml2 -, libxslt -, docbook-xsl -, docbook_xml_dtd_44 -, perlPackages -, makeWrapper -, perl # for pod2man -, cctools -, gitUpdater +{ + lib, + stdenv, + fetchgit, + libxml2, + libxslt, + docbook-xsl, + docbook_xml_dtd_44, + perlPackages, + makeWrapper, + perl, # for pod2man + cctools, + gitUpdater, }: stdenv.mkDerivation rec { @@ -23,12 +24,25 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ makeWrapper perl libxml2 libxslt docbook-xsl docbook_xml_dtd_44 ]; - buildInputs = [ - (perl.withPackages (p: [ p.IPCRun p.TimeDate p.TimeDuration ])) - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - cctools + nativeBuildInputs = [ + makeWrapper + perl + libxml2 + libxslt + docbook-xsl + docbook_xml_dtd_44 ]; + buildInputs = + [ + (perl.withPackages (p: [ + p.IPCRun + p.TimeDate + p.TimeDuration + ])) + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + cctools + ]; makeFlags = [ "CC=${stdenv.cc.targetPrefix}cc" @@ -45,7 +59,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Growing collection of the unix tools that nobody thought to write long ago when unix was young"; homepage = "https://joeyh.name/code/moreutils/"; - maintainers = with maintainers; [ koral pSub ]; + maintainers = with maintainers; [ + koral + pSub + ]; platforms = platforms.all; license = licenses.gpl2Plus; }; diff --git a/pkgs/tools/misc/mpremote/default.nix b/pkgs/tools/misc/mpremote/default.nix index 30728a0e8b29ad..ce2673428a5ac9 100644 --- a/pkgs/tools/misc/mpremote/default.nix +++ b/pkgs/tools/misc/mpremote/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, hatchling -, hatch-requirements-txt -, hatch-vcs -, pyserial -, importlib-metadata +{ + lib, + buildPythonApplication, + fetchFromGitHub, + hatchling, + hatch-requirements-txt, + hatch-vcs, + pyserial, + importlib-metadata, }: buildPythonApplication rec { pname = "mpremote"; diff --git a/pkgs/tools/misc/mpy-utils/default.nix b/pkgs/tools/misc/mpy-utils/default.nix index 342b6875c20434..c971d272ec445f 100644 --- a/pkgs/tools/misc/mpy-utils/default.nix +++ b/pkgs/tools/misc/mpy-utils/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, buildPythonApplication, fetchPypi, fusepy, pyserial }: +{ + stdenv, + lib, + buildPythonApplication, + fetchPypi, + fusepy, + pyserial, +}: buildPythonApplication rec { pname = "mpy-utils"; @@ -9,7 +16,10 @@ buildPythonApplication rec { hash = "sha256-die8hseaidhs9X7mfFvV8C8zn0uyw08gcHNqmjl+2Z4="; }; - propagatedBuildInputs = [ fusepy pyserial ]; + propagatedBuildInputs = [ + fusepy + pyserial + ]; meta = with lib; { description = "MicroPython development utility programs"; diff --git a/pkgs/tools/misc/ncdu/1.nix b/pkgs/tools/misc/ncdu/1.nix index 09289ea745da9c..fde4411d393c86 100644 --- a/pkgs/tools/misc/ncdu/1.nix +++ b/pkgs/tools/misc/ncdu/1.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, ncurses }: +{ + lib, + stdenv, + fetchurl, + ncurses, +}: stdenv.mkDerivation rec { pname = "ncdu"; diff --git a/pkgs/tools/misc/ncdu/default.nix b/pkgs/tools/misc/ncdu/default.nix index 860ba48900d12f..719d899e83bd2c 100644 --- a/pkgs/tools/misc/ncdu/default.nix +++ b/pkgs/tools/misc/ncdu/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchurl -, ncurses -, pkg-config -, zig -, zstd -, installShellFiles -, testers -, pie ? stdenv.hostPlatform.isDarwin +{ + lib, + stdenv, + fetchurl, + ncurses, + pkg-config, + zig, + zstd, + installShellFiles, + testers, + pie ? stdenv.hostPlatform.isDarwin, }: stdenv.mkDerivation (finalAttrs: { @@ -45,7 +46,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Disk usage analyzer with an ncurses interface"; changelog = "https://dev.yorhel.nl/ncdu/changes2"; license = lib.licenses.mit; - maintainers = with lib.maintainers; [ pSub rodrgz ]; + maintainers = with lib.maintainers; [ + pSub + rodrgz + ]; inherit (zig.meta) platforms; mainProgram = "ncdu"; }; diff --git a/pkgs/tools/misc/noti/default.nix b/pkgs/tools/misc/noti/default.nix index 1c33f4ff73d3ec..71fb707312c9d6 100644 --- a/pkgs/tools/misc/noti/default.nix +++ b/pkgs/tools/misc/noti/default.nix @@ -1,9 +1,10 @@ -{ stdenv -, lib -, buildGoModule -, fetchFromGitHub -, Cocoa -, installShellFiles +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, + Cocoa, + installShellFiles, }: buildGoModule rec { diff --git a/pkgs/tools/misc/ntfy-sh/default.nix b/pkgs/tools/misc/ntfy-sh/default.nix index 439707e5b014bf..b4601e2f365ac1 100644 --- a/pkgs/tools/misc/ntfy-sh/default.nix +++ b/pkgs/tools/misc/ntfy-sh/default.nix @@ -1,8 +1,15 @@ -{ lib, buildGoModule, fetchFromGitHub, buildNpmPackage -, nixosTests, debianutils, mkdocs, python3, python3Packages +{ + lib, + buildGoModule, + fetchFromGitHub, + buildNpmPackage, + nixosTests, + debianutils, + mkdocs, + python3, + python3Packages, }: - buildGoModule rec { pname = "ntfy-sh"; version = "2.11.0"; @@ -35,7 +42,11 @@ buildGoModule rec { doCheck = false; - ldflags = [ "-s" "-w" "-X main.version=${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.version=${version}" + ]; nativeBuildInputs = [ debianutils @@ -63,6 +74,9 @@ buildGoModule rec { description = "Send push notifications to your phone or desktop via PUT/POST"; homepage = "https://ntfy.sh"; license = licenses.asl20; - maintainers = with maintainers; [ arjan-s fpletz ]; + maintainers = with maintainers; [ + arjan-s + fpletz + ]; }; } diff --git a/pkgs/tools/misc/ntfy/default.nix b/pkgs/tools/misc/ntfy/default.nix index d28688c63399a4..c79ca23e1b5e64 100644 --- a/pkgs/tools/misc/ntfy/default.nix +++ b/pkgs/tools/misc/ntfy/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, python39 -, fetchFromGitHub -, fetchpatch -, withXmpp ? !stdenv.hostPlatform.isDarwin -, withMatrix ? true -, withSlack ? true -, withEmoji ? true -, withPid ? true -, withDbus ? stdenv.hostPlatform.isLinux +{ + lib, + stdenv, + python39, + fetchFromGitHub, + fetchpatch, + withXmpp ? !stdenv.hostPlatform.isDarwin, + withMatrix ? true, + withSlack ? true, + withEmoji ? true, + withPid ? true, + withDbus ? stdenv.hostPlatform.isLinux, }: let @@ -23,7 +24,8 @@ let django = super.django_3; }; }; -in python.pkgs.buildPythonApplication rec { +in +python.pkgs.buildPythonApplication rec { pname = "ntfy"; version = "2.7.0"; @@ -40,22 +42,35 @@ in python.pkgs.buildPythonApplication rec { mock ]; - propagatedBuildInputs = with python.pkgs; ([ - requests ruamel-yaml appdirs - ntfy-webpush - ] ++ (lib.optionals withXmpp [ - sleekxmpp dnspython - ]) ++ (lib.optionals withMatrix [ - matrix-client - ]) ++ (lib.optionals withSlack [ - slack-sdk - ]) ++ (lib.optionals withEmoji [ - emoji - ]) ++ (lib.optionals withPid [ - psutil - ]) ++ (lib.optionals withDbus [ - dbus-python - ])); + propagatedBuildInputs = + with python.pkgs; + ( + [ + requests + ruamel-yaml + appdirs + ntfy-webpush + ] + ++ (lib.optionals withXmpp [ + sleekxmpp + dnspython + ]) + ++ (lib.optionals withMatrix [ + matrix-client + ]) + ++ (lib.optionals withSlack [ + slack-sdk + ]) + ++ (lib.optionals withEmoji [ + emoji + ]) + ++ (lib.optionals withPid [ + psutil + ]) + ++ (lib.optionals withDbus [ + dbus-python + ]) + ); patches = [ # Fix Slack integration no longer working. diff --git a/pkgs/tools/misc/ntfy/webpush.nix b/pkgs/tools/misc/ntfy/webpush.nix index a9c87d8738907c..242a4505240589 100644 --- a/pkgs/tools/misc/ntfy/webpush.nix +++ b/pkgs/tools/misc/ntfy/webpush.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, pywebpush -, py-vapid +{ + lib, + buildPythonPackage, + fetchFromGitHub, + pywebpush, + py-vapid, }: buildPythonPackage rec { diff --git a/pkgs/tools/misc/nvfancontrol/default.nix b/pkgs/tools/misc/nvfancontrol/default.nix index ca9a2c2da92324..6ec6da4672a031 100644 --- a/pkgs/tools/misc/nvfancontrol/default.nix +++ b/pkgs/tools/misc/nvfancontrol/default.nix @@ -1,4 +1,11 @@ -{ lib, rustPlatform, fetchFromGitHub, libXNVCtrl, libX11, libXext }: +{ + lib, + rustPlatform, + fetchFromGitHub, + libXNVCtrl, + libX11, + libXext, +}: rustPlatform.buildRustPackage rec { pname = "nvfancontrol"; @@ -13,7 +20,11 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-fEzdghGQSSeyeyiHjw1ggQ38gsETJFl9bq/tizGxIis="; - nativeBuildInputs = [ libXNVCtrl libX11 libXext ]; + nativeBuildInputs = [ + libXNVCtrl + libX11 + libXext + ]; # Needed for static linking preConfigure = '' diff --git a/pkgs/tools/misc/ocs-url/default.nix b/pkgs/tools/misc/ocs-url/default.nix index 52c65d4b5b26a7..968b3bd5692e4d 100644 --- a/pkgs/tools/misc/ocs-url/default.nix +++ b/pkgs/tools/misc/ocs-url/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchgit, libsForQt5 }: +{ + lib, + stdenv, + fetchgit, + libsForQt5, +}: let version = "3.1.0"; @@ -20,7 +25,10 @@ stdenv.mkDerivation rec { pname = "ocs-url"; inherit version; - srcs = [ main_src qtil_src ]; + srcs = [ + main_src + qtil_src + ]; sourceRoot = main_src.name; # We are NOT in $sourceRoot here diff --git a/pkgs/tools/misc/octofetch/default.nix b/pkgs/tools/misc/octofetch/default.nix index 1218cb1f7b0f3a..cfee7e5caef563 100644 --- a/pkgs/tools/misc/octofetch/default.nix +++ b/pkgs/tools/misc/octofetch/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, openssl -, pkg-config -, rustPlatform -, Security +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + pkg-config, + rustPlatform, + Security, }: rustPlatform.buildRustPackage rec { @@ -22,7 +23,8 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ openssl ] + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; meta = with lib; { diff --git a/pkgs/tools/misc/online-judge-template-generator/default.nix b/pkgs/tools/misc/online-judge-template-generator/default.nix index e867059eff3a2e..5eb3cd93224a9d 100644 --- a/pkgs/tools/misc/online-judge-template-generator/default.nix +++ b/pkgs/tools/misc/online-judge-template-generator/default.nix @@ -1,17 +1,18 @@ -{ lib -, buildPythonApplication -, appdirs -, beautifulsoup4 -, colorlog -, fetchFromGitHub -, mako -, online-judge-api-client -, online-judge-tools -, ply -, pyyaml -, requests -, setuptools -, toml +{ + lib, + buildPythonApplication, + appdirs, + beautifulsoup4, + colorlog, + fetchFromGitHub, + mako, + online-judge-api-client, + online-judge-tools, + ply, + pyyaml, + requests, + setuptools, + toml, }: buildPythonApplication rec { diff --git a/pkgs/tools/misc/opentimestamps-client/default.nix b/pkgs/tools/misc/opentimestamps-client/default.nix index 2a5c2c05a0fbf4..64c84451e08ffc 100644 --- a/pkgs/tools/misc/opentimestamps-client/default.nix +++ b/pkgs/tools/misc/opentimestamps-client/default.nix @@ -1,6 +1,7 @@ -{ lib -, fetchFromGitHub -, python3 +{ + lib, + fetchFromGitHub, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/tools/misc/owofetch/default.nix b/pkgs/tools/misc/owofetch/default.nix index 20d9cc160d7a72..3de70679c933e1 100644 --- a/pkgs/tools/misc/owofetch/default.nix +++ b/pkgs/tools/misc/owofetch/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenvNoCC -, rustPlatform -, fetchFromGitHub -, Foundation -, DiskArbitration +{ + lib, + stdenvNoCC, + rustPlatform, + fetchFromGitHub, + Foundation, + DiskArbitration, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/tools/misc/pandoc-acro/default.nix b/pkgs/tools/misc/pandoc-acro/default.nix index 824418dd3f7fb4..429d870cbb3e1d 100644 --- a/pkgs/tools/misc/pandoc-acro/default.nix +++ b/pkgs/tools/misc/pandoc-acro/default.nix @@ -1,12 +1,13 @@ -{ buildPythonApplication -, fetchPypi -, pandocfilters -, panflute -, lib -, pandoc -, pandoc-acro -, texliveTeTeX -, runCommand +{ + buildPythonApplication, + fetchPypi, + pandocfilters, + panflute, + lib, + pandoc, + pandoc-acro, + texliveTeTeX, + runCommand, }: let @@ -31,28 +32,33 @@ buildPythonApplication { passthru.tests.example-doc = let - env = { - nativeBuildInputs = [ - pandoc - pandoc-acro - (texliveTeTeX.withPackages (ps: with ps; [ acro translations ])) - ]; - }; - in - runCommand "pandoc-acro-example-docs" env '' - set -euo pipefail - exampleFile="${pname}-${version}/tests/example.md" - metadataFile="${pname}-${version}/tests/metadata.yaml" - tar --extract "--file=${src}" "$exampleFile" "$metadataFile" - mkdir $out + env = { + nativeBuildInputs = [ + pandoc + pandoc-acro + (texliveTeTeX.withPackages ( + ps: with ps; [ + acro + translations + ] + )) + ]; + }; + in + runCommand "pandoc-acro-example-docs" env '' + set -euo pipefail + exampleFile="${pname}-${version}/tests/example.md" + metadataFile="${pname}-${version}/tests/metadata.yaml" + tar --extract "--file=${src}" "$exampleFile" "$metadataFile" + mkdir $out - pandoc -F pandoc-acro "$exampleFile" "--metadata-file=$metadataFile" \ - -T pdf -o $out/example.pdf - pandoc -F pandoc-acro "$exampleFile" "--metadata-file=$metadataFile" \ - -T txt -o $out/example.txt + pandoc -F pandoc-acro "$exampleFile" "--metadata-file=$metadataFile" \ + -T pdf -o $out/example.pdf + pandoc -F pandoc-acro "$exampleFile" "--metadata-file=$metadataFile" \ + -T txt -o $out/example.txt - ! grep -q "\+afaik" $out/example.txt - ''; + ! grep -q "\+afaik" $out/example.txt + ''; meta = with lib; { homepage = "https://pypi.org/project/pandoc-acro/"; diff --git a/pkgs/tools/misc/pandoc-drawio-filter/default.nix b/pkgs/tools/misc/pandoc-drawio-filter/default.nix index 9a5ff8949ba648..cea1141753018b 100644 --- a/pkgs/tools/misc/pandoc-drawio-filter/default.nix +++ b/pkgs/tools/misc/pandoc-drawio-filter/default.nix @@ -1,11 +1,12 @@ -{ buildPythonApplication -, drawio-headless -, fetchFromGitHub -, lib -, pandoc -, pandocfilters -, runCommand -, texliveTeTeX +{ + buildPythonApplication, + drawio-headless, + fetchFromGitHub, + lib, + pandoc, + pandocfilters, + runCommand, + texliveTeTeX, }: let diff --git a/pkgs/tools/misc/pandoc-eqnos/default.nix b/pkgs/tools/misc/pandoc-eqnos/default.nix index 5ee4e9587d61aa..0947d6769aac93 100644 --- a/pkgs/tools/misc/pandoc-eqnos/default.nix +++ b/pkgs/tools/misc/pandoc-eqnos/default.nix @@ -1,8 +1,9 @@ -{ buildPythonApplication -, fetchFromGitHub -, lib -, pandoc-xnos -, setuptools +{ + buildPythonApplication, + fetchFromGitHub, + lib, + pandoc-xnos, + setuptools, }: buildPythonApplication rec { diff --git a/pkgs/tools/misc/pandoc-fignos/default.nix b/pkgs/tools/misc/pandoc-fignos/default.nix index eb8d0154ffcecb..226405ba1429cd 100644 --- a/pkgs/tools/misc/pandoc-fignos/default.nix +++ b/pkgs/tools/misc/pandoc-fignos/default.nix @@ -1,8 +1,9 @@ -{ buildPythonApplication -, fetchFromGitHub -, lib -, pandoc-xnos -, setuptools +{ + buildPythonApplication, + fetchFromGitHub, + lib, + pandoc-xnos, + setuptools, }: buildPythonApplication rec { diff --git a/pkgs/tools/misc/pandoc-imagine/default.nix b/pkgs/tools/misc/pandoc-imagine/default.nix index ae94c311536618..f075776a4b0f00 100644 --- a/pkgs/tools/misc/pandoc-imagine/default.nix +++ b/pkgs/tools/misc/pandoc-imagine/default.nix @@ -1,4 +1,10 @@ -{ fetchFromGitHub, buildPythonApplication, lib, pandocfilters, six }: +{ + fetchFromGitHub, + buildPythonApplication, + lib, + pandocfilters, + six, +}: buildPythonApplication rec { pname = "pandoc-imagine"; @@ -11,7 +17,10 @@ buildPythonApplication rec { sha256 = "1wpnckc7qyrf6ga5xhr6gv38k1anpy9nx888n7n3rh6nixzcz2dw"; }; - propagatedBuildInputs = [ pandocfilters six ]; + propagatedBuildInputs = [ + pandocfilters + six + ]; # No tests in archive doCheck = false; diff --git a/pkgs/tools/misc/pandoc-include/default.nix b/pkgs/tools/misc/pandoc-include/default.nix index 74e24926be3bee..1717e09ae0b80f 100644 --- a/pkgs/tools/misc/pandoc-include/default.nix +++ b/pkgs/tools/misc/pandoc-include/default.nix @@ -1,11 +1,12 @@ -{ buildPythonApplication -, fetchFromGitHub -, lib -, natsort -, panflute -, lxml -, setuptools -, nix-update-script +{ + buildPythonApplication, + fetchFromGitHub, + lib, + natsort, + panflute, + lxml, + setuptools, + nix-update-script, }: buildPythonApplication rec { @@ -24,9 +25,13 @@ buildPythonApplication rec { setuptools ]; - passthru.updateScript = nix-update-script {}; + passthru.updateScript = nix-update-script { }; - propagatedBuildInputs = [ natsort panflute lxml ]; + propagatedBuildInputs = [ + natsort + panflute + lxml + ]; pythonImportsCheck = [ "pandoc_include.main" ]; @@ -34,7 +39,10 @@ buildPythonApplication rec { description = "Pandoc filter to allow file and header includes"; homepage = "https://github.com/DCsunset/pandoc-include"; license = licenses.mit; - maintainers = with maintainers; [ ppenguin DCsunset ]; + maintainers = with maintainers; [ + ppenguin + DCsunset + ]; mainProgram = "pandoc-include"; }; } diff --git a/pkgs/tools/misc/pandoc-plantuml-filter/default.nix b/pkgs/tools/misc/pandoc-plantuml-filter/default.nix index d8c1bb2ea8a38f..d90cb0e52f973a 100644 --- a/pkgs/tools/misc/pandoc-plantuml-filter/default.nix +++ b/pkgs/tools/misc/pandoc-plantuml-filter/default.nix @@ -1,7 +1,8 @@ -{ buildPythonApplication -, fetchPypi -, pandocfilters -, lib +{ + buildPythonApplication, + fetchPypi, + pandocfilters, + lib, }: buildPythonApplication rec { diff --git a/pkgs/tools/misc/pandoc-secnos/default.nix b/pkgs/tools/misc/pandoc-secnos/default.nix index 0880214e218e30..d76e2d905fe99a 100644 --- a/pkgs/tools/misc/pandoc-secnos/default.nix +++ b/pkgs/tools/misc/pandoc-secnos/default.nix @@ -1,8 +1,9 @@ -{ buildPythonApplication -, fetchFromGitHub -, lib -, pandoc-xnos -, setuptools +{ + buildPythonApplication, + fetchFromGitHub, + lib, + pandoc-xnos, + setuptools, }: buildPythonApplication rec { diff --git a/pkgs/tools/misc/pandoc-tablenos/default.nix b/pkgs/tools/misc/pandoc-tablenos/default.nix index 6ee5ef65861e80..eede87b92e19be 100644 --- a/pkgs/tools/misc/pandoc-tablenos/default.nix +++ b/pkgs/tools/misc/pandoc-tablenos/default.nix @@ -1,8 +1,9 @@ -{ buildPythonApplication -, fetchFromGitHub -, lib -, pandoc-xnos -, setuptools +{ + buildPythonApplication, + fetchFromGitHub, + lib, + pandoc-xnos, + setuptools, }: buildPythonApplication rec { diff --git a/pkgs/tools/misc/parallel/default.nix b/pkgs/tools/misc/parallel/default.nix index 7494bc78ce203c..f5567b9a1c9cc2 100644 --- a/pkgs/tools/misc/parallel/default.nix +++ b/pkgs/tools/misc/parallel/default.nix @@ -1,4 +1,14 @@ -{ fetchurl, lib, stdenv, perl, makeWrapper, procps, coreutils, gawk, buildPackages }: +{ + fetchurl, + lib, + stdenv, + perl, + makeWrapper, + procps, + coreutils, + gawk, + buildPackages, +}: stdenv.mkDerivation rec { pname = "parallel"; @@ -9,11 +19,21 @@ stdenv.mkDerivation rec { hash = "sha256-Gp51L0LBfKELwH0KY6LKbtzuUyKC5V0rNL2d0UyXilg="; }; - outputs = [ "out" "man" "doc" ]; + outputs = [ + "out" + "man" + "doc" + ]; strictDeps = true; - nativeBuildInputs = [ makeWrapper perl ]; - buildInputs = [ perl procps ]; + nativeBuildInputs = [ + makeWrapper + perl + ]; + buildInputs = [ + perl + procps + ]; postPatch = lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' substituteInPlace Makefile.in \ @@ -26,7 +46,14 @@ stdenv.mkDerivation rec { postInstall = '' wrapProgram $out/bin/parallel \ - --prefix PATH : "${lib.makeBinPath [ procps perl coreutils gawk ]}" + --prefix PATH : "${ + lib.makeBinPath [ + procps + perl + coreutils + gawk + ] + }" ''; doCheck = true; @@ -53,7 +80,10 @@ stdenv.mkDerivation rec { homepage = "https://www.gnu.org/software/parallel/"; license = licenses.gpl3Plus; platforms = platforms.all; - maintainers = with maintainers; [ pSub tomberek ]; + maintainers = with maintainers; [ + pSub + tomberek + ]; mainProgram = "parallel"; }; } diff --git a/pkgs/tools/misc/parallel/wrapper.nix b/pkgs/tools/misc/parallel/wrapper.nix index b798a1acea2270..4b281fda019445 100644 --- a/pkgs/tools/misc/parallel/wrapper.nix +++ b/pkgs/tools/misc/parallel/wrapper.nix @@ -1,14 +1,33 @@ -{ lib, symlinkJoin, makeWrapper, parallel, perlPackages -, extraPerlPackages ? with perlPackages; [ DBI DBDPg DBDSQLite DBDCSV TextCSV ] -, willCite ? false }: +{ + lib, + symlinkJoin, + makeWrapper, + parallel, + perlPackages, + extraPerlPackages ? with perlPackages; [ + DBI + DBDPg + DBDSQLite + DBDCSV + TextCSV + ], + willCite ? false, +}: symlinkJoin { name = "parallel-full-${parallel.version}"; - inherit (parallel) pname version meta outputs; + inherit (parallel) + pname + version + meta + outputs + ; nativeBuildInputs = [ makeWrapper ]; paths = [ parallel ]; postBuild = '' - ${lib.concatMapStringsSep "\n" (output: "ln -s --no-target-directory ${parallel.${output}} \$${output}") (lib.remove "out" parallel.outputs)} + ${lib.concatMapStringsSep "\n" ( + output: "ln -s --no-target-directory ${parallel.${output}} \$${output}" + ) (lib.remove "out" parallel.outputs)} rm $out/bin/parallel makeWrapper ${parallel}/bin/parallel $out/bin/parallel \ diff --git a/pkgs/tools/misc/parcellite/default.nix b/pkgs/tools/misc/parcellite/default.nix index 3c53be706641bf..a39b4d9f8ac889 100644 --- a/pkgs/tools/misc/parcellite/default.nix +++ b/pkgs/tools/misc/parcellite/default.nix @@ -1,6 +1,17 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook -, gtk2, hicolor-icon-theme, intltool, pkg-config -, which, wrapGAppsHook3, xdotool, libappindicator-gtk2 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + gtk2, + hicolor-icon-theme, + intltool, + pkg-config, + which, + wrapGAppsHook3, + xdotool, + libappindicator-gtk2, +}: stdenv.mkDerivation rec { pname = "parcellite"; @@ -13,8 +24,17 @@ stdenv.mkDerivation rec { sha256 = "19q4x6x984s6gxk1wpzaxawgvly5vnihivrhmja2kcxhzqrnfhiy"; }; - nativeBuildInputs = [ autoreconfHook intltool pkg-config wrapGAppsHook3 ]; - buildInputs = [ gtk2 hicolor-icon-theme libappindicator-gtk2 ]; + nativeBuildInputs = [ + autoreconfHook + intltool + pkg-config + wrapGAppsHook3 + ]; + buildInputs = [ + gtk2 + hicolor-icon-theme + libappindicator-gtk2 + ]; NIX_LDFLAGS = "-lgio-2.0"; preFixup = '' diff --git a/pkgs/tools/misc/pdd/default.nix b/pkgs/tools/misc/pdd/default.nix index a05f618e472d61..6c11afa5815fd8 100644 --- a/pkgs/tools/misc/pdd/default.nix +++ b/pkgs/tools/misc/pdd/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, buildPythonApplication, python-dateutil }: +{ + lib, + fetchFromGitHub, + buildPythonApplication, + python-dateutil, +}: buildPythonApplication rec { pname = "pdd"; diff --git a/pkgs/tools/misc/peruse/default.nix b/pkgs/tools/misc/peruse/default.nix index ba99cdd8cdf96b..ece14a96056d1b 100644 --- a/pkgs/tools/misc/peruse/default.nix +++ b/pkgs/tools/misc/peruse/default.nix @@ -1,19 +1,20 @@ -{ stdenv -, fetchurl -, lib -, extra-cmake-modules -, kdoctools -, wrapQtAppsHook -, baloo -, karchive -, kconfig -, kcrash -, kfilemetadata -, kinit -, kirigami2 -, knewstuff -, okular -, plasma-framework +{ + stdenv, + fetchurl, + lib, + extra-cmake-modules, + kdoctools, + wrapQtAppsHook, + baloo, + karchive, + kconfig, + kcrash, + kfilemetadata, + kinit, + kirigami2, + knewstuff, + okular, + plasma-framework, }: stdenv.mkDerivation (finalAttrs: { diff --git a/pkgs/tools/misc/pipelight/default.nix b/pkgs/tools/misc/pipelight/default.nix index 1117c0cae8bff7..084944001c4880 100644 --- a/pkgs/tools/misc/pipelight/default.nix +++ b/pkgs/tools/misc/pipelight/default.nix @@ -1,12 +1,24 @@ -{ lib, stdenv, fetchurl, bash, cabextract, curl, gnupg, libX11, libGLU, libGL, wine-staging }: +{ + lib, + stdenv, + fetchurl, + bash, + cabextract, + curl, + gnupg, + libX11, + libGLU, + libGL, + wine-staging, +}: let wine_custom = wine-staging; mozillaPluginPath = "/lib/mozilla/plugins"; - -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { version = "0.2.8.2"; @@ -17,7 +29,13 @@ in stdenv.mkDerivation rec { sha256 = "1kyy6knkr42k34rs661r0f5sf6l1s2jdbphdg89n73ynijqmzjhk"; }; - buildInputs = [ wine_custom libX11 libGLU libGL curl ]; + buildInputs = [ + wine_custom + libX11 + libGLU + libGL + curl + ]; env.NIX_CFLAGS_COMPILE = toString [ "-fpermissive" ]; @@ -59,10 +77,17 @@ in stdenv.mkDerivation rec { meta = { homepage = "http://pipelight.net/"; - license = with lib.licenses; [ mpl11 gpl2Only lgpl21 ]; + license = with lib.licenses; [ + mpl11 + gpl2Only + lgpl21 + ]; description = "Wrapper for using Windows plugins in Linux browsers"; maintainers = [ ]; - platforms = [ "x86_64-linux" "i686-linux" ]; + platforms = [ + "x86_64-linux" + "i686-linux" + ]; mainProgram = "pipelight-plugin"; }; } diff --git a/pkgs/tools/misc/polar/default.nix b/pkgs/tools/misc/polar/default.nix index 2edf40ffb2926e..542f21ca090251 100644 --- a/pkgs/tools/misc/polar/default.nix +++ b/pkgs/tools/misc/polar/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, ruby, bundlerEnv }: +{ + lib, + stdenv, + fetchFromGitHub, + ruby, + bundlerEnv, +}: let # To create Gemfile.lock and gemset.nix @@ -31,7 +37,10 @@ stdenv.mkDerivation rec { substituteInPlace $script --replace "#{File.dirname(__FILE__)}/lib" "$out/lib/polar" done ''; - buildInputs = [ gems ruby ]; + buildInputs = [ + gems + ruby + ]; # See: https://wiki.nixos.org/wiki/Packaging/Ruby # @@ -39,20 +48,20 @@ stdenv.mkDerivation rec { # Then, wrap the scripts so that they use the correct ruby environment and put # these wrapped executables under bin. installPhase = '' - install -Dm644 -t $out/etc/udev/rules.d ./pkg/99-polar.rules - mkdir -p $out/{bin,lib/polar,share/polar} - cp -r lib/* $out/lib/polar/ - for script in ./polar_* - do - raw="$out/share/polar/$script" - bin="$out/bin/$script" - cp "$script" "$raw" - cat > $bin < $bin < !stdenv.hostPlatform.isDarwin; @@ -35,30 +38,35 @@ stdenv.mkDerivation rec { ./scons-nix-env.patch ]; - nativeBuildInputs = [ - pkg-config - sphinx - scons - ] ++ lib.optionals withGui [ - makeWrapper - wrapGAppsHook3 - gobject-introspection - ]; + nativeBuildInputs = + [ + pkg-config + sphinx + scons + ] + ++ lib.optionals withGui [ + makeWrapper + wrapGAppsHook3 + gobject-introspection + ]; - buildInputs = [ - glib - json-glib - util-linux - ] ++ lib.optionals withGui [ - cairo - gtksourceview3 - pango - polkit - python3 - python3.pkgs.pygobject3 - ] ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform elfutils) [ - elfutils - ]; + buildInputs = + [ + glib + json-glib + util-linux + ] + ++ lib.optionals withGui [ + cairo + gtksourceview3 + pango + polkit + python3 + python3.pkgs.pygobject3 + ] + ++ lib.optionals (lib.meta.availableOn stdenv.hostPlatform elfutils) [ + elfutils + ]; prePatch = '' # remove sources of nondeterminism @@ -85,7 +93,10 @@ stdenv.mkDerivation rec { homepage = "https://rmlint.readthedocs.org"; platforms = platforms.unix; license = licenses.gpl3; - maintainers = with maintainers; [ aaschmid koral ]; + maintainers = with maintainers; [ + aaschmid + koral + ]; mainProgram = "rmlint"; }; } diff --git a/pkgs/tools/misc/rust-motd/default.nix b/pkgs/tools/misc/rust-motd/default.nix index df79acf5f1c57c..9ab9594f8a2201 100644 --- a/pkgs/tools/misc/rust-motd/default.nix +++ b/pkgs/tools/misc/rust-motd/default.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + Security, }: rustPlatform.buildRustPackage rec { @@ -24,11 +25,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + ]; OPENSSL_NO_VENDOR = 1; diff --git a/pkgs/tools/misc/screen/default.nix b/pkgs/tools/misc/screen/default.nix index 68487255d9bcd3..45319b2b79a633 100644 --- a/pkgs/tools/misc/screen/default.nix +++ b/pkgs/tools/misc/screen/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchurl -, autoreconfHook -, ncurses -, libxcrypt -, utmp -, pam ? null +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + ncurses, + libxcrypt, + utmp, + pam ? null, }: stdenv.mkDerivation rec { @@ -28,10 +29,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoreconfHook ]; - buildInputs = [ - ncurses - libxcrypt - ] ++ lib.optional stdenv.hostPlatform.isLinux pam + buildInputs = + [ + ncurses + libxcrypt + ] + ++ lib.optional stdenv.hostPlatform.isLinux pam ++ lib.optional stdenv.hostPlatform.isDarwin utmp; doCheck = true; diff --git a/pkgs/tools/misc/seaborn-data/default.nix b/pkgs/tools/misc/seaborn-data/default.nix index 5ac78f1eef25eb..555c9991b63be3 100644 --- a/pkgs/tools/misc/seaborn-data/default.nix +++ b/pkgs/tools/misc/seaborn-data/default.nix @@ -1,4 +1,10 @@ -{ lib, newScope, fetchFromGitHub, unzip, stdenvNoCC }: +{ + lib, + newScope, + fetchFromGitHub, + unzip, + stdenvNoCC, +}: let base = { version = "unstable-2023-01-26"; @@ -10,7 +16,8 @@ let maintainers = with maintainers; [ mbalatsko ]; }; }; - makeSeabornDataPackage = {pname, hash}: + makeSeabornDataPackage = + { pname, hash }: let src = fetchFromGitHub { owner = "mwaskom"; @@ -20,18 +27,21 @@ let sparseCheckout = [ "${pname}.csv" ]; }; in - stdenvNoCC.mkDerivation (base // { - inherit pname src; - version = base.version; - installPhase = '' - runHook preInstall + stdenvNoCC.mkDerivation ( + base + // { + inherit pname src; + version = base.version; + installPhase = '' + runHook preInstall - mkdir -p $out - cp ${pname}.csv $out/${pname}.csv + mkdir -p $out + cp ${pname}.csv $out/${pname}.csv - runHook postInstall - ''; - }); + runHook postInstall + ''; + } + ); in lib.makeScope newScope (self: { exercise = makeSeabornDataPackage ({ diff --git a/pkgs/tools/misc/serverspec/default.nix b/pkgs/tools/misc/serverspec/default.nix index 28196efc18a34c..8c9e405bcecd31 100644 --- a/pkgs/tools/misc/serverspec/default.nix +++ b/pkgs/tools/misc/serverspec/default.nix @@ -1,4 +1,9 @@ -{ lib, ruby, bundlerApp, bundlerUpdateScript }: +{ + lib, + ruby, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "serverspec"; @@ -6,7 +11,7 @@ bundlerApp { inherit ruby; - exes = ["serverspec-init"]; + exes = [ "serverspec-init" ]; passthru.updateScript = bundlerUpdateScript "serverspec"; diff --git a/pkgs/tools/misc/serverspec/gemset.nix b/pkgs/tools/misc/serverspec/gemset.nix index 353b122ec81000..00a966514a4163 100644 --- a/pkgs/tools/misc/serverspec/gemset.nix +++ b/pkgs/tools/misc/serverspec/gemset.nix @@ -1,147 +1,170 @@ { diff-lcs = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rwvjahnp7cpmracd8x732rjgnilqv2sx7d1gfrysslc3h039fa9"; type = "gem"; }; version = "1.5.0"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; net-scp = { - dependencies = ["net-ssh"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-ssh" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1si2nq9l6jy5n2zw1q59a5gaji7v9vhy8qx08h4fg368906ysbdk"; type = "gem"; }; version = "4.0.0"; }; net-ssh = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yx0pb5fmziz92bw8qzbh8vf20lr56nd3s6q8h0gsgr307lki687"; type = "gem"; }; version = "7.1.0"; }; net-telnet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13qxznpwmc3hs51b76wqx2w29r158gzzh8719kv2gpi56844c8fx"; type = "gem"; }; version = "0.1.1"; }; rspec = { - dependencies = ["rspec-core" "rspec-expectations" "rspec-mocks"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "rspec-core" + "rspec-expectations" + "rspec-mocks" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "171rc90vcgjl8p1bdrqa92ymrj8a87qf6w20x05xq29mljcigi6c"; type = "gem"; }; version = "3.12.0"; }; rspec-core = { - dependencies = ["rspec-support"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rspec-support" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0da45cvllbv39sdbsl65vp5djb2xf5m10mxc9jm7rsqyyxjw4h1f"; type = "gem"; }; version = "3.12.1"; }; rspec-expectations = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03ba3lfdsj9zl00v1yvwgcx87lbadf87livlfa5kgqssn9qdnll6"; type = "gem"; }; version = "3.12.2"; }; rspec-its = { - dependencies = ["rspec-core" "rspec-expectations"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "rspec-core" + "rspec-expectations" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15zafd70gxly5i0s00nky14sj2n92dnj3xpj83ysl3c2wx0119ad"; type = "gem"; }; version = "1.3.0"; }; rspec-mocks = { - dependencies = ["diff-lcs" "rspec-support"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "diff-lcs" + "rspec-support" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1hfm17xakfvwya236graj6c2arr4sb9zasp35q5fykhyz8mhs0w2"; type = "gem"; }; version = "3.12.5"; }; rspec-support = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12y52zwwb3xr7h91dy9k3ndmyyhr3mjcayk0nnarnrzz8yr48kfx"; type = "gem"; }; version = "3.12.0"; }; serverspec = { - dependencies = ["multi_json" "rspec" "rspec-its" "specinfra"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "multi_json" + "rspec" + "rspec-its" + "specinfra" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kqx84yspy75z517wf32mz2hr4bqmq33y46zik57rn7bq2pj39xx"; type = "gem"; }; version = "2.42.2"; }; sfl = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qm4hvhq9pszi9zs1cl9qgwx1n4wxq0af0hq9sbf6qihqd8rwwwr"; type = "gem"; }; version = "2.3"; }; specinfra = { - dependencies = ["net-scp" "net-ssh" "net-telnet" "sfl"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "net-scp" + "net-ssh" + "net-telnet" + "sfl" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19kkryvxnci7qd7rq5m3nl3xazy452bcg35a709kfggpfm4c6r38"; type = "gem"; }; diff --git a/pkgs/tools/misc/shadowenv/default.nix b/pkgs/tools/misc/shadowenv/default.nix index d3f9306f225a2d..fd577be3a88fbc 100644 --- a/pkgs/tools/misc/shadowenv/default.nix +++ b/pkgs/tools/misc/shadowenv/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, installShellFiles, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + installShellFiles, + Security, +}: rustPlatform.buildRustPackage rec { pname = "shadowenv"; diff --git a/pkgs/tools/misc/sharedown/default.nix b/pkgs/tools/misc/sharedown/default.nix index b23ca216946198..693c856b5461b0 100644 --- a/pkgs/tools/misc/sharedown/default.nix +++ b/pkgs/tools/misc/sharedown/default.nix @@ -1,19 +1,20 @@ -{ stdenvNoCC -, lib -, fetchFromGitHub -, ffmpeg -, yt-dlp -, libsecret -, python3 -, pkg-config -, nodejs -, electron -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, yarn2nix-moretea -, fetchYarnDeps -, chromium +{ + stdenvNoCC, + lib, + fetchFromGitHub, + ffmpeg, + yt-dlp, + libsecret, + python3, + pkg-config, + nodejs, + electron, + makeWrapper, + makeDesktopItem, + copyDesktopItems, + yarn2nix-moretea, + fetchYarnDeps, + chromium, }: stdenvNoCC.mkDerivation rec { @@ -39,7 +40,10 @@ stdenvNoCC.mkDerivation rec { icon = "Sharedown"; comment = "An Application to save your Sharepoint videos for offline usage."; desktopName = "Sharedown"; - categories = [ "Network" "Archiving" ]; + categories = [ + "Network" + "Archiving" + ]; }) ]; diff --git a/pkgs/tools/misc/sheldon/default.nix b/pkgs/tools/misc/sheldon/default.nix index 3d5e2e84a56617..c827afe52914fa 100644 --- a/pkgs/tools/misc/sheldon/default.nix +++ b/pkgs/tools/misc/sheldon/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, pkg-config -, openssl -, installShellFiles -, Security -, curl +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + installShellFiles, + Security, + curl, }: rustPlatform.buildRustPackage rec { @@ -22,8 +23,16 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-+yTX1wUfVVjsM42X0QliL+0xbzTPheADZibPh/5Czh8="; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security curl ]; - nativeBuildInputs = [ installShellFiles pkg-config ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + curl + ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + ]; # Needs network connection checkFlags = [ diff --git a/pkgs/tools/misc/sshx/default.nix b/pkgs/tools/misc/sshx/default.nix index 0929703288e002..a3686bb958e7b4 100644 --- a/pkgs/tools/misc/sshx/default.nix +++ b/pkgs/tools/misc/sshx/default.nix @@ -1,11 +1,12 @@ -{ lib -, callPackage -, rustPlatform -, fetchFromGitHub -, protobuf -, darwin -, stdenv -, buildNpmPackage +{ + lib, + callPackage, + rustPlatform, + fetchFromGitHub, + protobuf, + darwin, + stdenv, + buildNpmPackage, }: let version = "0.2.4"; @@ -17,31 +18,42 @@ let hash = "sha256-RIQRX4sXlMl73Opi6hK2WD/erdAMNrm40IasHasikuw="; }; - mkSshxPackage = { pname, cargoHash, ... }@args: - rustPlatform.buildRustPackage (rec { - inherit - pname - version - src - cargoHash; + mkSshxPackage = + { pname, cargoHash, ... }@args: + rustPlatform.buildRustPackage ( + rec { + inherit + pname + version + src + cargoHash + ; - nativeBuildInputs = [ protobuf ]; + nativeBuildInputs = [ protobuf ]; - buildInputs = lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.Security; + buildInputs = lib.optional stdenv.hostPlatform.isDarwin darwin.apple_sdk.frameworks.Security; - cargoBuildFlags = [ "--package" pname ]; + cargoBuildFlags = [ + "--package" + pname + ]; - cargoTestFlags = cargoBuildFlags; + cargoTestFlags = cargoBuildFlags; - meta = { - description = "Fast, collaborative live terminal sharing over the web"; - homepage = "https://github.com/ekzhang/sshx"; - changelog = "https://github.com/ekzhang/sshx/releases/tag/v${version}"; - license = lib.licenses.mit; - maintainers = with lib.maintainers; [ pinpox kranzes ]; - mainProgram = pname; - }; - } // args); + meta = { + description = "Fast, collaborative live terminal sharing over the web"; + homepage = "https://github.com/ekzhang/sshx"; + changelog = "https://github.com/ekzhang/sshx/releases/tag/v${version}"; + license = lib.licenses.mit; + maintainers = with lib.maintainers; [ + pinpox + kranzes + ]; + mainProgram = pname; + }; + } + // args + ); in { sshx = mkSshxPackage { @@ -64,7 +76,8 @@ in inherit version - src; + src + ; postPatch = '' substituteInPlace vite.config.ts \ diff --git a/pkgs/tools/misc/starship/default.nix b/pkgs/tools/misc/starship/default.nix index 66fac2661a2c2c..1075b868e20bbc 100644 --- a/pkgs/tools/misc/starship/default.nix +++ b/pkgs/tools/misc/starship/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, installShellFiles -, cmake -, git -, nixosTests -, Security -, Foundation -, Cocoa +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + installShellFiles, + cmake, + git, + nixosTests, + Security, + Foundation, + Cocoa, }: rustPlatform.buildRustPackage rec { @@ -22,27 +23,39 @@ rustPlatform.buildRustPackage rec { hash = "sha256-Xn9qV26/ST+3VtVq6OJP823lIVIo0zEdno+nIUv8B9c="; }; - nativeBuildInputs = [ installShellFiles cmake ]; + nativeBuildInputs = [ + installShellFiles + cmake + ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Security Foundation Cocoa ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + Security + Foundation + Cocoa + ]; - NIX_LDFLAGS = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ "-framework" "AppKit" ]; + NIX_LDFLAGS = lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ + "-framework" + "AppKit" + ]; # tries to access HOME only in aarch64-darwin environment when building mac-notification-sys preBuild = lib.optionalString (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64) '' export HOME=$TMPDIR ''; - postInstall = '' - presetdir=$out/share/starship/presets/ - mkdir -p $presetdir - cp docs/public/presets/toml/*.toml $presetdir - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - installShellCompletion --cmd starship \ - --bash <($out/bin/starship completions bash) \ - --fish <($out/bin/starship completions fish) \ - --zsh <($out/bin/starship completions zsh) - ''; + postInstall = + '' + presetdir=$out/share/starship/presets/ + mkdir -p $presetdir + cp docs/public/presets/toml/*.toml $presetdir + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + installShellCompletion --cmd starship \ + --bash <($out/bin/starship completions bash) \ + --fish <($out/bin/starship completions fish) \ + --zsh <($out/bin/starship completions zsh) + ''; cargoHash = "sha256-YbZCe2OcX/wq0OWvWK61nWvRT0O+CyW0QY0J7vv6QaM="; @@ -60,7 +73,12 @@ rustPlatform.buildRustPackage rec { description = "Minimal, blazing fast, and extremely customizable prompt for any shell"; homepage = "https://starship.rs"; license = licenses.isc; - maintainers = with maintainers; [ danth davidtwco Br1ght0ne Frostman ]; + maintainers = with maintainers; [ + danth + davidtwco + Br1ght0ne + Frostman + ]; mainProgram = "starship"; }; } diff --git a/pkgs/tools/misc/synth/default.nix b/pkgs/tools/misc/synth/default.nix index 4977372ee4ee4c..d52c72be5de3a4 100644 --- a/pkgs/tools/misc/synth/default.nix +++ b/pkgs/tools/misc/synth/default.nix @@ -1,9 +1,10 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, AppKit -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + AppKit, + Security, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/tools/misc/system-config-printer/default.nix b/pkgs/tools/misc/system-config-printer/default.nix index 595882b9b50083..aa1d78d7658da4 100644 --- a/pkgs/tools/misc/system-config-printer/default.nix +++ b/pkgs/tools/misc/system-config-printer/default.nix @@ -1,9 +1,33 @@ -{ lib, stdenv, fetchFromGitHub, udev, pkg-config, glib, xmlto, wrapGAppsHook3 -, docbook_xml_dtd_412, docbook_xsl -, libxml2, desktop-file-utils, libusb1, cups, gdk-pixbuf, pango, atk, libnotify -, gobject-introspection, libsecret, packagekit -, libcupsfilters, gettext, libtool, autoconf-archive -, python3Packages, autoreconfHook, bash, fetchpatch +{ + lib, + stdenv, + fetchFromGitHub, + udev, + pkg-config, + glib, + xmlto, + wrapGAppsHook3, + docbook_xml_dtd_412, + docbook_xsl, + libxml2, + desktop-file-utils, + libusb1, + cups, + gdk-pixbuf, + pango, + atk, + libnotify, + gobject-introspection, + libsecret, + packagekit, + libcupsfilters, + gettext, + libtool, + autoconf-archive, + python3Packages, + autoreconfHook, + bash, + fetchpatch, }: stdenv.mkDerivation rec { @@ -38,21 +62,49 @@ stdenv.mkDerivation rec { ]; buildInputs = [ - glib udev libusb1 cups + glib + udev + libusb1 + cups python3Packages.python - libnotify gdk-pixbuf pango atk packagekit + libnotify + gdk-pixbuf + pango + atk + packagekit libsecret ]; nativeBuildInputs = [ - pkg-config gettext libtool autoconf-archive - xmlto libxml2 docbook_xml_dtd_412 docbook_xsl desktop-file-utils - python3Packages.wrapPython python3Packages.build python3Packages.installer - python3Packages.setuptools python3Packages.wheel - wrapGAppsHook3 autoreconfHook gobject-introspection + pkg-config + gettext + libtool + autoconf-archive + xmlto + libxml2 + docbook_xml_dtd_412 + docbook_xsl + desktop-file-utils + python3Packages.wrapPython + python3Packages.build + python3Packages.installer + python3Packages.setuptools + python3Packages.wheel + wrapGAppsHook3 + autoreconfHook + gobject-introspection ]; - pythonPath = with python3Packages; requiredPythonModules [ pycups pycurl dbus-python pygobject3 pycairo pysmbc ]; + pythonPath = + with python3Packages; + requiredPythonModules [ + pycups + pycurl + dbus-python + pygobject3 + pycairo + pysmbc + ]; configureFlags = [ "--with-udev-rules" @@ -60,26 +112,29 @@ stdenv.mkDerivation rec { "--with-systemdsystemunitdir=${placeholder "out"}/etc/systemd/system" ]; - stripDebugList = [ "bin" "lib" "etc/udev" ]; + stripDebugList = [ + "bin" + "lib" + "etc/udev" + ]; doCheck = true; - postInstall = - '' - buildPythonPath "$out $pythonPath" - gappsWrapperArgs+=( - --prefix PATH : "$program_PATH" - --set CUPS_DATADIR "${libcupsfilters}/share/cups" - ) + postInstall = '' + buildPythonPath "$out $pythonPath" + gappsWrapperArgs+=( + --prefix PATH : "$program_PATH" + --set CUPS_DATADIR "${libcupsfilters}/share/cups" + ) - find $out/share/system-config-printer -name \*.py -type f -perm -0100 -print0 | while read -d "" f; do - patchPythonScript "$f" - done - patchPythonScript $out/etc/udev/udev-add-printer + find $out/share/system-config-printer -name \*.py -type f -perm -0100 -print0 | while read -d "" f; do + patchPythonScript "$f" + done + patchPythonScript $out/etc/udev/udev-add-printer - substituteInPlace $out/etc/udev/rules.d/70-printers.rules \ - --replace "udev-configure-printer" "$out/etc/udev/udev-configure-printer" - ''; + substituteInPlace $out/etc/udev/rules.d/70-printers.rules \ + --replace "udev-configure-printer" "$out/etc/udev/udev-configure-printer" + ''; meta = { homepage = "https://github.com/openprinting/system-config-printer"; diff --git a/pkgs/tools/misc/t/default.nix b/pkgs/tools/misc/t/default.nix index 0bcedf344ba692..2662a072b7ec14 100644 --- a/pkgs/tools/misc/t/default.nix +++ b/pkgs/tools/misc/t/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "t"; @@ -9,10 +13,14 @@ bundlerApp { meta = with lib; { description = "Command-line power tool for Twitter"; - homepage = "http://sferik.github.io/t/"; - license = licenses.asl20; - maintainers = with maintainers; [ offline manveru nicknovitski ]; - platforms = platforms.unix; + homepage = "http://sferik.github.io/t/"; + license = licenses.asl20; + maintainers = with maintainers; [ + offline + manveru + nicknovitski + ]; + platforms = platforms.unix; mainProgram = "t"; }; } diff --git a/pkgs/tools/misc/t/gemset.nix b/pkgs/tools/misc/t/gemset.nix index a61eb81b1da940..a742b7b1accd12 100644 --- a/pkgs/tools/misc/t/gemset.nix +++ b/pkgs/tools/misc/t/gemset.nix @@ -1,259 +1,282 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bcm2hchn897xjhqj9zzsxf3n9xhddymj4lsclz508f4vw3av46l"; type = "gem"; }; version = "2.6.0"; }; buftok = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rzsy1vy50v55x9z0nivf23y0r9jkmq6i130xa75pq9i8qrn1mxs"; type = "gem"; }; version = "0.2.0"; }; domain_name = { - dependencies = ["unf"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unf" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0abdlwb64ns7ssmiqhdwgl27ly40x2l27l8hs8hn0z4kb3zd2x3v"; type = "gem"; }; version = "0.5.20180417"; }; equalizer = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kjmx3fygx8njxfrwcmn7clfhjhb6bvv3scy2lyyi0wqyi3brra4"; type = "gem"; }; version = "0.0.11"; }; faraday = { - dependencies = ["multipart-post"]; - groups = ["default"]; - platforms = []; + dependencies = [ "multipart-post" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18p1csdivgwmshfw3mb698a3bn0yrykg30khk5qxjf6n168g91jr"; type = "gem"; }; version = "0.11.0"; }; geokit = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mvdpbx88wflqqrcrfa54a5sckvj2sqzm304p7ji3c06frbhmxw8"; type = "gem"; }; version = "1.13.1"; }; htmlentities = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nkklqsn8ir8wizzlakncfv42i32wc0w9hxp00hvdlgjr7376nhj"; type = "gem"; }; version = "4.3.4"; }; http = { - dependencies = ["addressable" "http-cookie" "http-form_data" "http_parser.rb"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "addressable" + "http-cookie" + "http-form_data" + "http_parser.rb" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kcd9qp8vm1rkyp7gfh8j0dbl3zpi97vz2vbhpbcsdsa7l21a59r"; type = "gem"; }; version = "2.2.2"; }; http-cookie = { - dependencies = ["domain_name"]; - groups = ["default"]; - platforms = []; + dependencies = [ "domain_name" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "004cgs4xg5n6byjs7qld0xhsjq3n6ydfh897myr2mibvh6fjc49g"; type = "gem"; }; version = "1.0.3"; }; http-form_data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j8dwwbfpf8kc0lcsqcgy29lflszd1x4d7kc0f7227892m7r6y0m"; type = "gem"; }; version = "1.0.3"; }; "http_parser.rb" = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15nidriy0v5yqfjsgsra51wmknxci2n2grliz78sf9pga3n0l7gi"; type = "gem"; }; version = "0.6.0"; }; launchy = { - dependencies = ["addressable"]; - groups = ["default"]; - platforms = []; + dependencies = [ "addressable" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "190lfbiy1vwxhbgn4nl4dcbzxvm049jwc158r2x7kq3g5khjrxa2"; type = "gem"; }; version = "2.4.3"; }; memoizable = { - dependencies = ["thread_safe"]; - groups = ["default"]; - platforms = []; + dependencies = [ "thread_safe" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0v42bvghsvfpzybfazl14qhkrjvx0xlmxz0wwqc960ga1wld5x5c"; type = "gem"; }; version = "0.4.2"; }; multipart-post = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "09k0b3cybqilk1gwrwwain95rdypixb2q9w65gd44gfzsd84xi1x"; type = "gem"; }; version = "2.0.0"; }; naught = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wwjx35zgbc0nplp8a866iafk4zsrbhwwz4pav5gydr2wm26nksg"; type = "gem"; }; version = "1.1.0"; }; oauth = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zszdg8q1b135z7l7crjj234k4j0m347hywp5kj6zsq7q78pw09y"; type = "gem"; }; version = "0.5.4"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08q64b5br692dd3v0a9wq9q5dvycc6kmiqmjbdxkxbfizggsvx6l"; type = "gem"; }; version = "3.0.3"; }; retryable = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pxv5xgr08s9gv5npj7h3raxibywznrv2wcrb85ibhlhzgzcxggf"; type = "gem"; }; version = "2.0.4"; }; simple_oauth = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dw9ii6m7wckml100xhjc6vxpjcry174lbi9jz5v7ibjr3i94y8l"; type = "gem"; }; version = "0.3.1"; }; t = { - dependencies = ["geokit" "htmlentities" "launchy" "oauth" "retryable" "thor" "twitter"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "geokit" + "htmlentities" + "launchy" + "oauth" + "retryable" + "thor" + "twitter" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qj5zqc819yiscqbyb93alxillyli5ajvrr4gzq52clgkvyap7bd"; type = "gem"; }; version = "3.1.0"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yhrnp9x8qcy5vc7g438amd5j9sw83ih7c30dr6g6slgw9zj3g29"; type = "gem"; }; version = "0.20.3"; }; thread_safe = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nmhcgq6cgz44srylra07bmaw99f5271l0dpsvl5f75m44l0gmwy"; type = "gem"; }; version = "0.3.6"; }; twitter = { - dependencies = ["addressable" "buftok" "equalizer" "faraday" "http" "http_parser.rb" "memoizable" "naught" "simple_oauth"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "addressable" + "buftok" + "equalizer" + "faraday" + "http" + "http_parser.rb" + "memoizable" + "naught" + "simple_oauth" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l9zv0pg0q4mgcxyhzk2fj57bcs907mbargdr9l0ccnp6xi5sp8v"; type = "gem"; }; version = "6.1.0"; }; unf = { - dependencies = ["unf_ext"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unf_ext" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bh2cf73i2ffh4fcpdn9ir4mhq8zi50ik0zqa1braahzadx536a9"; type = "gem"; }; version = "0.1.4"; }; unf_ext = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ll6w64ibh81qwvjx19h8nj7mngxgffg7aigjx11klvf5k2g4nxf"; type = "gem"; }; diff --git a/pkgs/tools/misc/tab-rs/default.nix b/pkgs/tools/misc/tab-rs/default.nix index 7d3721acb3c407..c6698c446bdbae 100644 --- a/pkgs/tools/misc/tab-rs/default.nix +++ b/pkgs/tools/misc/tab-rs/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, IOKit }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + IOKit, +}: rustPlatform.buildRustPackage rec { pname = "tab-rs"; diff --git a/pkgs/tools/misc/td/default.nix b/pkgs/tools/misc/td/default.nix index ebfe642a27d277..9d7edd8f2b88ad 100644 --- a/pkgs/tools/misc/td/default.nix +++ b/pkgs/tools/misc/td/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "td"; @@ -9,10 +13,13 @@ bundlerApp { meta = with lib; { description = "CLI to manage data on Treasure Data, the Hadoop-based cloud data warehousing"; - homepage = "https://github.com/treasure-data/td"; - license = licenses.asl20; - maintainers = with maintainers; [ groodt nicknovitski ]; - platforms = platforms.unix; + homepage = "https://github.com/treasure-data/td"; + license = licenses.asl20; + maintainers = with maintainers; [ + groodt + nicknovitski + ]; + platforms = platforms.unix; mainProgram = "td"; }; } diff --git a/pkgs/tools/misc/td/gemset.nix b/pkgs/tools/misc/td/gemset.nix index 53d9df0502d73a..5a0bb8a3fc63ab 100644 --- a/pkgs/tools/misc/td/gemset.nix +++ b/pkgs/tools/misc/td/gemset.nix @@ -1,8 +1,8 @@ { fluent-logger = { - dependencies = ["msgpack"]; + dependencies = [ "msgpack" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yr6vrai4fqajpzybmdlajf8wzsgy29kr1318amn21y9nhjlnys5"; type = "gem"; }; @@ -10,7 +10,7 @@ }; hirb = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mzch3c2lvmf8gskgzlx6j53d10j42ir6ik2dkrl27sblhy76cji"; type = "gem"; }; @@ -18,7 +18,7 @@ }; httpclient = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; @@ -26,7 +26,7 @@ }; msgpack = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0031gd2mjyba6jb7m97sqa149zjkr0vzn2s2gpb3m9nb67gqkm13"; type = "gem"; }; @@ -34,7 +34,7 @@ }; parallel = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "005shcy8dabc7lwydpkbhd3fx8bfqzvsj6g04r90mx0wky10lz84"; type = "gem"; }; @@ -42,7 +42,7 @@ }; ruby-progressbar = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cv2ym3rl09svw8940ny67bav7b2db4ms39i4raaqzkf59jmhglk"; type = "gem"; }; @@ -50,34 +50,51 @@ }; rubyzip = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n1lb2sdwh9h27y244hxzg1lrxxg2m53pk1vq7p33bna003qkyrj"; type = "gem"; }; version = "1.2.2"; }; td = { - dependencies = ["hirb" "msgpack" "parallel" "ruby-progressbar" "rubyzip" "td-client" "td-logger" "yajl-ruby" "zip-zip"]; + dependencies = [ + "hirb" + "msgpack" + "parallel" + "ruby-progressbar" + "rubyzip" + "td-client" + "td-logger" + "yajl-ruby" + "zip-zip" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nlxpc4nasgmv6mqanb6ag1q3wmryja2c174dzgwxngxa0y2j1yn"; type = "gem"; }; version = "0.16.4"; }; td-client = { - dependencies = ["httpclient" "msgpack"]; + dependencies = [ + "httpclient" + "msgpack" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0j5jcsgg020cm8xarbbw67mca4k8cx5pfyd2mm3wcqrnc1cl2bgp"; type = "gem"; }; version = "1.0.6"; }; td-logger = { - dependencies = ["fluent-logger" "msgpack" "td-client"]; + dependencies = [ + "fluent-logger" + "msgpack" + "td-client" + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1y56gilaqk9a4lfhzb777ysmsq77pi1aqkr4q485a7f5dwnpwl1p"; type = "gem"; }; @@ -85,16 +102,16 @@ }; yajl-ruby = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16v0w5749qjp13xhjgr2gcsvjv6mf35br7iqwycix1n2h7kfcckf"; type = "gem"; }; version = "1.4.1"; }; zip-zip = { - dependencies = ["rubyzip"]; + dependencies = [ "rubyzip" ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ny3zv1sn9wasamykfkg7b7xgs6w7k5fy8kggiyjj9vrwfzzavqg"; type = "gem"; }; diff --git a/pkgs/tools/misc/teamocil/default.nix b/pkgs/tools/misc/teamocil/default.nix index a3e85031dee647..8dd13b640cca01 100644 --- a/pkgs/tools/misc/teamocil/default.nix +++ b/pkgs/tools/misc/teamocil/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerEnv, ruby, bundlerUpdateScript }: +{ + lib, + bundlerEnv, + ruby, + bundlerUpdateScript, +}: bundlerEnv { inherit ruby; @@ -8,11 +13,11 @@ bundlerEnv { passthru.updateScript = bundlerUpdateScript "teamocil"; meta = with lib; { - description = "Simple tool used to automatically create windows and panes in tmux with YAML files"; - homepage = "https://github.com/remiprev/teamocil"; - license = licenses.mit; - platforms = platforms.all; - maintainers = with maintainers; [ + description = "Simple tool used to automatically create windows and panes in tmux with YAML files"; + homepage = "https://github.com/remiprev/teamocil"; + license = licenses.mit; + platforms = platforms.all; + maintainers = with maintainers; [ zachcoyle nicknovitski ]; diff --git a/pkgs/tools/misc/teamocil/gemset.nix b/pkgs/tools/misc/teamocil/gemset.nix index 2c522b096c811e..cbc7ec249d6d80 100644 --- a/pkgs/tools/misc/teamocil/gemset.nix +++ b/pkgs/tools/misc/teamocil/gemset.nix @@ -1,7 +1,7 @@ { teamocil = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l5f33faipb45xx7ds67s7dqgvjlljlcxgpgig4pg8p002vg06r2"; type = "gem"; }; diff --git a/pkgs/tools/misc/thinkpad-scripts/default.nix b/pkgs/tools/misc/thinkpad-scripts/default.nix index 5b9b9eae7ad5a3..14724c8111d971 100644 --- a/pkgs/tools/misc/thinkpad-scripts/default.nix +++ b/pkgs/tools/misc/thinkpad-scripts/default.nix @@ -1,4 +1,9 @@ -{ lib, buildPythonPackage, fetchFromGitHub, python3Packages }: +{ + lib, + buildPythonPackage, + fetchFromGitHub, + python3Packages, +}: buildPythonPackage rec { pname = "thinkpad-scripts"; diff --git a/pkgs/tools/misc/timidity/default.nix b/pkgs/tools/misc/timidity/default.nix index f41d3b34971a54..9e9dae6880f1cf 100644 --- a/pkgs/tools/misc/timidity/default.nix +++ b/pkgs/tools/misc/timidity/default.nix @@ -1,18 +1,20 @@ -{ lib -, stdenv -, fetchurl -, nixosTests -, pkg-config -, memstreamHook -, CoreAudio -, libobjc -, libjack2 -, ncurses -, alsa-lib -, buildPackages +{ + lib, + stdenv, + fetchurl, + nixosTests, + pkg-config, + memstreamHook, + CoreAudio, + libobjc, + libjack2, + ncurses, + alsa-lib, + buildPackages, -## Additional optional output modes -, enableVorbis ? false, libvorbis + ## Additional optional output modes + enableVorbis ? false, + libvorbis, }: stdenv.mkDerivation rec { @@ -31,51 +33,63 @@ stdenv.mkDerivation rec { ./configure-compat.patch ]; - nativeBuildInputs = [ pkg-config ] - ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ memstreamHook ]; + nativeBuildInputs = [ + pkg-config + ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) [ memstreamHook ]; - buildInputs = [ - libjack2 - ncurses - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - alsa-lib - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreAudio - libobjc - ] ++ lib.optionals enableVorbis [ - libvorbis - ]; + buildInputs = + [ + libjack2 + ncurses + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + alsa-lib + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreAudio + libobjc + ] + ++ lib.optionals enableVorbis [ + libvorbis + ]; - enabledOutputModes = [ - "jack" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "oss" - "alsa" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "darwin" - ] ++ lib.optionals enableVorbis [ - "vorbis" - ]; + enabledOutputModes = + [ + "jack" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "oss" + "alsa" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "darwin" + ] + ++ lib.optionals enableVorbis [ + "vorbis" + ]; - configureFlags = [ - "--enable-ncurses" - ("--enable-audio=" + builtins.concatStringsSep "," enabledOutputModes) - "lib_cv_va_copy=yes" - "lib_cv___va_copy=yes" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "--enable-alsaseq" - "--with-default-output=alsa" - "lib_cv_va_val_copy=yes" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "lib_cv_va_val_copy=no" - "timidity_cv_ccoption_rdynamic=yes" - # These configure tests fail because of incompatible function pointer conversions. - "ac_cv_func_vprintf=yes" - "ac_cv_func_popen=yes" - "ac_cv_func_vsnprintf=yes" - "ac_cv_func_snprintf=yes" - "ac_cv_func_open_memstream=yes" - ]; + configureFlags = + [ + "--enable-ncurses" + ("--enable-audio=" + builtins.concatStringsSep "," enabledOutputModes) + "lib_cv_va_copy=yes" + "lib_cv___va_copy=yes" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "--enable-alsaseq" + "--with-default-output=alsa" + "lib_cv_va_val_copy=yes" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "lib_cv_va_val_copy=no" + "timidity_cv_ccoption_rdynamic=yes" + # These configure tests fail because of incompatible function pointer conversions. + "ac_cv_func_vprintf=yes" + "ac_cv_func_popen=yes" + "ac_cv_func_vsnprintf=yes" + "ac_cv_func_snprintf=yes" + "ac_cv_func_open_memstream=yes" + ]; makeFlags = [ "AR=${stdenv.cc.targetPrefix}ar" diff --git a/pkgs/tools/misc/tlp/default.nix b/pkgs/tools/misc/tlp/default.nix index b70476166fc2fc..0adf8e6aa3c10a 100644 --- a/pkgs/tools/misc/tlp/default.nix +++ b/pkgs/tools/misc/tlp/default.nix @@ -1,28 +1,30 @@ -{ stdenv -, lib -, checkbashisms -, coreutils -, ethtool -, fetchFromGitHub -, gawk -, gnugrep -, gnused -, hdparm -, iw -, kmod -, makeWrapper -, pciutils -, perl -, perlcritic -, shellcheck -, smartmontools -, systemd -, util-linux -, x86_energy_perf_policy +{ + stdenv, + lib, + checkbashisms, + coreutils, + ethtool, + fetchFromGitHub, + gawk, + gnugrep, + gnused, + hdparm, + iw, + kmod, + makeWrapper, + pciutils, + perl, + perlcritic, + shellcheck, + smartmontools, + systemd, + util-linux, + x86_energy_perf_policy, # RDW only works with NetworkManager, and thus is optional with default off -, enableRDW ? false -, networkmanager -}: stdenv.mkDerivation rec { + enableRDW ? false, + networkmanager, +}: +stdenv.mkDerivation rec { pname = "tlp"; version = "1.7.0"; @@ -61,34 +63,47 @@ "DESTDIR=${placeholder "out"}" ]; - installTargets = [ "install-tlp" "install-man" ] - ++ lib.optionals enableRDW [ "install-rdw" "install-man-rdw" ]; + installTargets = + [ + "install-tlp" + "install-man" + ] + ++ lib.optionals enableRDW [ + "install-rdw" + "install-man-rdw" + ]; doCheck = true; - nativeCheckInputs = [ checkbashisms perlcritic shellcheck ]; + nativeCheckInputs = [ + checkbashisms + perlcritic + shellcheck + ]; checkTarget = [ "checkall" ]; # TODO: Consider using resholve here - postInstall = let - paths = lib.makeBinPath ( - [ - coreutils - ethtool - gawk - gnugrep - gnused - hdparm - iw - kmod - pciutils - perl - smartmontools - systemd - util-linux - ] ++ lib.optional enableRDW networkmanager + postInstall = + let + paths = lib.makeBinPath ( + [ + coreutils + ethtool + gawk + gnugrep + gnused + hdparm + iw + kmod + pciutils + perl + smartmontools + systemd + util-linux + ] + ++ lib.optional enableRDW networkmanager ++ lib.optional (lib.meta.availableOn stdenv.hostPlatform x86_energy_perf_policy) x86_energy_perf_policy - ); - in + ); + in '' fixup_perl=( $out/share/tlp/tlp-pcilist @@ -118,12 +133,14 @@ meta = with lib; { description = "Advanced Power Management for Linux"; - homepage = - "https://linrunner.de/en/tlp/docs/tlp-linux-advanced-power-management.html"; + homepage = "https://linrunner.de/en/tlp/docs/tlp-linux-advanced-power-management.html"; changelog = "https://github.com/linrunner/TLP/releases/tag/${version}"; platforms = platforms.linux; mainProgram = "tlp"; - maintainers = with maintainers; [ abbradar lovesegfault ]; + maintainers = with maintainers; [ + abbradar + lovesegfault + ]; license = licenses.gpl2Plus; }; } diff --git a/pkgs/tools/misc/tmux-sessionizer/default.nix b/pkgs/tools/misc/tmux-sessionizer/default.nix index 2d2deb07dbd26a..a68cf47fb86c85 100644 --- a/pkgs/tools/misc/tmux-sessionizer/default.nix +++ b/pkgs/tools/misc/tmux-sessionizer/default.nix @@ -1,13 +1,14 @@ -{ lib -, fetchFromGitHub -, stdenv -, rustPlatform -, openssl -, pkg-config -, Security -, testers -, tmux-sessionizer -, installShellFiles +{ + lib, + fetchFromGitHub, + stdenv, + rustPlatform, + openssl, + pkg-config, + Security, + testers, + tmux-sessionizer, + installShellFiles, }: let @@ -36,7 +37,10 @@ rustPlatform.buildRustPackage { # Needed to get openssl-sys to use pkg-config. OPENSSL_NO_VENDOR = 1; - nativeBuildInputs = [ pkg-config installShellFiles ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' @@ -50,7 +54,10 @@ rustPlatform.buildRustPackage { description = "Fastest way to manage projects as tmux sessions"; homepage = "https://github.com/jrmoulton/tmux-sessionizer"; license = licenses.mit; - maintainers = with maintainers; [ vinnymeller mrcjkb ]; + maintainers = with maintainers; [ + vinnymeller + mrcjkb + ]; mainProgram = "tms"; }; } diff --git a/pkgs/tools/misc/toastify/default.nix b/pkgs/tools/misc/toastify/default.nix index 6fde17977ebe11..3578e6af1d92a9 100644 --- a/pkgs/tools/misc/toastify/default.nix +++ b/pkgs/tools/misc/toastify/default.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, stdenv, darwin }: +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + darwin, +}: rustPlatform.buildRustPackage rec { pname = "toastify"; diff --git a/pkgs/tools/misc/topgrade/default.nix b/pkgs/tools/misc/topgrade/default.nix index fa98d818d59da6..b7164272ae3877 100644 --- a/pkgs/tools/misc/topgrade/default.nix +++ b/pkgs/tools/misc/topgrade/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, rustPlatform -, AppKit -, Cocoa -, Foundation -, installShellFiles +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + AppKit, + Cocoa, + Foundation, + installShellFiles, }: rustPlatform.buildRustPackage rec { @@ -31,10 +32,12 @@ rustPlatform.buildRustPackage rec { Foundation ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-framework" - "AppKit" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-framework" + "AppKit" + ] + ); postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' installShellCompletion --cmd topgrade \ @@ -51,7 +54,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/topgrade-rs/topgrade"; changelog = "https://github.com/topgrade-rs/topgrade/releases/tag/v${version}"; license = licenses.gpl3Only; - maintainers = with maintainers; [ SuperSandro2000 xyenon ]; + maintainers = with maintainers; [ + SuperSandro2000 + xyenon + ]; mainProgram = "topgrade"; }; } diff --git a/pkgs/tools/misc/torrenttools/default.nix b/pkgs/tools/misc/torrenttools/default.nix index 6daa39dd7e7393..543e151c8ec8e9 100644 --- a/pkgs/tools/misc/torrenttools/default.nix +++ b/pkgs/tools/misc/torrenttools/default.nix @@ -1,21 +1,22 @@ -{ lib -, stdenv -, fetchFromGitHub -, bencode -, catch2 -, cli11 -, cmake -, ctre -, expected-lite -, fmt -, gsl-lite -, howard-hinnant-date -, yaml-cpp -, ninja -, nlohmann_json -, openssl -, re2 -, sigslot +{ + lib, + stdenv, + fetchFromGitHub, + bencode, + catch2, + cli11, + cmake, + ctre, + expected-lite, + fmt, + gsl-lite, + howard-hinnant-date, + yaml-cpp, + ninja, + nlohmann_json, + openssl, + re2, + sigslot, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/misc/toybox/default.nix b/pkgs/tools/misc/toybox/default.nix index 99167c87fa8495..37695fb066a833 100644 --- a/pkgs/tools/misc/toybox/default.nix +++ b/pkgs/tools/misc/toybox/default.nix @@ -1,9 +1,14 @@ { - stdenv, lib, fetchFromGitHub, which, - buildPackages, libxcrypt, libiconv, + stdenv, + lib, + fetchFromGitHub, + which, + buildPackages, + libxcrypt, + libiconv, enableStatic ? stdenv.hostPlatform.isStatic, enableMinimal ? false, - extraConfig ? "" + extraConfig ? "", }: let @@ -21,15 +26,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-7izs2C5/czec0Dt3apL8s7luARAlw4PfUFy9Xsxb0zw="; }; - depsBuildBuild = optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ buildPackages.stdenv.cc ]; - buildInputs = [ - libxcrypt - ] ++ optionals stdenv.hostPlatform.isDarwin [ - libiconv - ] ++ optionals (enableStatic && stdenv.cc.libc ? static) [ - stdenv.cc.libc - stdenv.cc.libc.static + depsBuildBuild = optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ + buildPackages.stdenv.cc ]; + buildInputs = + [ + libxcrypt + ] + ++ optionals stdenv.hostPlatform.isDarwin [ + libiconv + ] + ++ optionals (enableStatic && stdenv.cc.libc ? static) [ + stdenv.cc.libc + stdenv.cc.libc.static + ]; postPatch = "patchShebangs ."; @@ -37,16 +47,15 @@ stdenv.mkDerivation rec { passAsFile = [ "extraConfig" ]; configurePhase = '' - make ${if enableMinimal then - "allnoconfig" - else - if stdenv.hostPlatform.isFreeBSD then + make ${ + if enableMinimal then + "allnoconfig" + else if stdenv.hostPlatform.isFreeBSD then "freebsd_defconfig" + else if stdenv.hostPlatform.isDarwin then + "macos_defconfig" else - if stdenv.hostPlatform.isDarwin then - "macos_defconfig" - else - "defconfig" + "defconfig" } cat $extraConfigPath .config > .config- diff --git a/pkgs/tools/misc/trackma/default.nix b/pkgs/tools/misc/trackma/default.nix index 4ae9306f28fb6d..69f91e5af2eb5a 100644 --- a/pkgs/tools/misc/trackma/default.nix +++ b/pkgs/tools/misc/trackma/default.nix @@ -1,26 +1,34 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 -, wrapGAppsHook3 -, gobject-introspection -, glib -, gtk3 -, qt5 -, makeDesktopItem -, copyDesktopItems -, withCurses ? false -, withGTK ? false -, withQT ? false +{ + lib, + stdenv, + fetchFromGitHub, + python3, + wrapGAppsHook3, + gobject-introspection, + glib, + gtk3, + qt5, + makeDesktopItem, + copyDesktopItems, + withCurses ? false, + withGTK ? false, + withQT ? false, }: let - mkDesktopItem = name: desktopName: comment: terminal: makeDesktopItem { - inherit name desktopName comment terminal; - icon = "trackma"; - exec = name + " %u"; - type = "Application"; - categories = [ "Network" ]; - }; + mkDesktopItem = + name: desktopName: comment: terminal: + makeDesktopItem { + inherit + name + desktopName + comment + terminal + ; + icon = "trackma"; + exec = name + " %u"; + type = "Application"; + categories = [ "Network" ]; + }; in python3.pkgs.buildPythonApplication rec { pname = "trackma"; @@ -35,28 +43,56 @@ python3.pkgs.buildPythonApplication rec { fetchSubmodules = true; # for anime-relations submodule }; - nativeBuildInputs = [ copyDesktopItems python3.pkgs.poetry-core ] - ++ lib.optionals withGTK [ wrapGAppsHook3 gobject-introspection ] + nativeBuildInputs = + [ + copyDesktopItems + python3.pkgs.poetry-core + ] + ++ lib.optionals withGTK [ + wrapGAppsHook3 + gobject-introspection + ] ++ lib.optionals withQT [ qt5.wrapQtAppsHook ]; - buildInputs = lib.optionals withGTK [ glib gtk3 ]; + buildInputs = lib.optionals withGTK [ + glib + gtk3 + ]; - propagatedBuildInputs = with python3.pkgs; ([ requests ] - ++ lib.optionals withQT [ pyqt5 ] - ++ lib.optionals withGTK [ pycairo pygobject3 ] - ++ lib.optionals withCurses [ urwid ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ pydbus pyinotify ] - ++ lib.optionals (withGTK || withQT) [ pillow ]); + propagatedBuildInputs = + with python3.pkgs; + ( + [ requests ] + ++ lib.optionals withQT [ pyqt5 ] + ++ lib.optionals withGTK [ + pycairo + pygobject3 + ] + ++ lib.optionals withCurses [ urwid ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + pydbus + pyinotify + ] + ++ lib.optionals (withGTK || withQT) [ pillow ] + ); dontWrapQtApps = true; dontWrapGApps = true; - preFixup = lib.optional withQT "wrapQtApp $out/bin/trackma-qt" + preFixup = + lib.optional withQT "wrapQtApp $out/bin/trackma-qt" ++ lib.optional withGTK "wrapGApp $out/bin/trackma-gtk"; - desktopItems = lib.optional withQT (mkDesktopItem "trackma-qt" "Trackma (Qt)" "Trackma Updater (Qt-frontend)" false) - ++ lib.optional withGTK (mkDesktopItem "trackma-gtk" "Trackma (GTK)" "Trackma Updater (Gtk-frontend)" false) - ++ lib.optional withCurses (mkDesktopItem "trackma-curses" "Trackma (ncurses)" "Trackma Updater (ncurses frontend)" true); + desktopItems = + lib.optional withQT ( + mkDesktopItem "trackma-qt" "Trackma (Qt)" "Trackma Updater (Qt-frontend)" false + ) + ++ lib.optional withGTK ( + mkDesktopItem "trackma-gtk" "Trackma (GTK)" "Trackma Updater (Gtk-frontend)" false + ) + ++ lib.optional withCurses ( + mkDesktopItem "trackma-curses" "Trackma (ncurses)" "Trackma Updater (ncurses frontend)" true + ); postInstall = '' install -Dvm444 $src/trackma/data/icon.png $out/share/pixmaps/trackma.png @@ -66,7 +102,8 @@ python3.pkgs.buildPythonApplication rec { pythonImportsCheck = [ "trackma" ]; - postDist = lib.optional (!withQT) "rm $out/bin/trackma-qt" + postDist = + lib.optional (!withQT) "rm $out/bin/trackma-qt" ++ lib.optional (!withGTK) "rm $out/bin/trackma-gtk" ++ lib.optional (!withCurses) "rm $out/bin/trackma-curses"; diff --git a/pkgs/tools/misc/tremor-rs/ls.nix b/pkgs/tools/misc/tremor-rs/ls.nix index a379c9294d8878..990c6e38a814b5 100644 --- a/pkgs/tools/misc/tremor-rs/ls.nix +++ b/pkgs/tools/misc/tremor-rs/ls.nix @@ -1,6 +1,7 @@ -{ lib -, rustPlatform -, fetchFromGitHub +{ + lib, + rustPlatform, + fetchFromGitHub, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/tools/misc/ttfautohint/default.nix b/pkgs/tools/misc/ttfautohint/default.nix index 8b843bf4344e31..711e62d88febcf 100644 --- a/pkgs/tools/misc/ttfautohint/default.nix +++ b/pkgs/tools/misc/ttfautohint/default.nix @@ -1,7 +1,14 @@ { - stdenv, lib, fetchurl, pkg-config, autoreconfHook -, freetype, harfbuzz, libiconv, qtbase -, enableGUI ? true + stdenv, + lib, + fetchurl, + pkg-config, + autoreconfHook, + freetype, + harfbuzz, + libiconv, + qtbase, + enableGUI ? true, }: stdenv.mkDerivation rec { @@ -17,9 +24,16 @@ stdenv.mkDerivation rec { substituteInPlace configure --replace "macx-g++" "macx-clang" ''; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; - buildInputs = [ freetype harfbuzz libiconv ] ++ lib.optional enableGUI qtbase; + buildInputs = [ + freetype + harfbuzz + libiconv + ] ++ lib.optional enableGUI qtbase; configureFlags = [ ''--with-qt=${if enableGUI then "${qtbase}/lib" else "no"}'' ]; diff --git a/pkgs/tools/misc/twurl/default.nix b/pkgs/tools/misc/twurl/default.nix index ff332e88de9171..2587d6f0b2c040 100644 --- a/pkgs/tools/misc/twurl/default.nix +++ b/pkgs/tools/misc/twurl/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "twurl"; @@ -9,10 +13,10 @@ bundlerApp { meta = with lib; { description = "OAuth-enabled curl for the Twitter API"; - homepage = "https://github.com/twitter/twurl"; - license = "MIT"; + homepage = "https://github.com/twitter/twurl"; + license = "MIT"; maintainers = with maintainers; [ brecht ]; - platforms = platforms.unix; + platforms = platforms.unix; mainProgram = "twurl"; }; } diff --git a/pkgs/tools/misc/twurl/gemset.nix b/pkgs/tools/misc/twurl/gemset.nix index a1a2ed835d3ea6..2ad0664e5b28c5 100644 --- a/pkgs/tools/misc/twurl/gemset.nix +++ b/pkgs/tools/misc/twurl/gemset.nix @@ -1,20 +1,20 @@ { oauth = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zwd6v39yqfdrpg1p3d9jvzs9ljg55ana2p06m0l7qn5w0lgx1a0"; type = "gem"; }; version = "0.5.6"; }; twurl = { - dependencies = ["oauth"]; - groups = ["default"]; - platforms = []; + dependencies = [ "oauth" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jgsxa0cnkajnsxxlsrgl2wq3m7khaxvr0rcir4vwbc1hx210700"; type = "gem"; }; diff --git a/pkgs/tools/misc/ultrastar-creator/default.nix b/pkgs/tools/misc/ultrastar-creator/default.nix index bc39b7ed76c157..013c3d5e07ae67 100644 --- a/pkgs/tools/misc/ultrastar-creator/default.nix +++ b/pkgs/tools/misc/ultrastar-creator/default.nix @@ -1,5 +1,14 @@ -{ lib, mkDerivation, fetchFromGitHub -, qmake, qtbase, pkg-config, taglib, libbass, libbass_fx }: +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qtbase, + pkg-config, + taglib, + libbass, + libbass_fx, +}: # TODO: get rid of (unfree) libbass # issue:https://github.com/UltraStar-Deluxe/UltraStar-Creator/issues/3 @@ -33,8 +42,16 @@ mkDerivation { cd src ''; - nativeBuildInputs = [ qmake pkg-config ]; - buildInputs = [ qtbase taglib libbass libbass_fx ]; + nativeBuildInputs = [ + qmake + pkg-config + ]; + buildInputs = [ + qtbase + taglib + libbass + libbass_fx + ]; meta = with lib; { description = "Ultrastar karaoke song creation tool"; diff --git a/pkgs/tools/misc/ultrastar-manager/default.nix b/pkgs/tools/misc/ultrastar-manager/default.nix index d1d983bc10da86..2c0d3b5d0f8f1e 100644 --- a/pkgs/tools/misc/ultrastar-manager/default.nix +++ b/pkgs/tools/misc/ultrastar-manager/default.nix @@ -1,11 +1,31 @@ -{ lib, mkDerivation, fetchFromGitHub, pkg-config, symlinkJoin, qmake, diffPlugins -, qtbase, qtmultimedia, taglib, libmediainfo, libzen, libbass }: +{ + lib, + mkDerivation, + fetchFromGitHub, + pkg-config, + symlinkJoin, + qmake, + diffPlugins, + qtbase, + qtmultimedia, + taglib, + libmediainfo, + libzen, + libbass, +}: let version = "2019-04-23"; rev = "ef4524e2239ddbb60f26e05bfba1f4f28cb7b54f"; sha256 = "0dl2qp686vbs160b3i9qypb7sv37phy2wn21kgzljbk3wnci3yv4"; - buildInputs = [ qtbase qtmultimedia taglib libmediainfo libzen libbass ]; + buildInputs = [ + qtbase + qtmultimedia + taglib + libmediainfo + libzen + libbass + ]; plugins = [ "albumartex" @@ -16,15 +36,17 @@ let "lyric" "preparatory" "rename" - ]; + ]; patchedSrc = - let src = fetchFromGitHub { - owner = "UltraStar-Deluxe"; - repo = "UltraStar-Manager"; - inherit rev sha256; - }; - in mkDerivation { + let + src = fetchFromGitHub { + owner = "UltraStar-Deluxe"; + repo = "UltraStar-Manager"; + inherit rev sha256; + }; + in + mkDerivation { name = "${src.name}-patched"; inherit src; @@ -56,34 +78,36 @@ let sed -e "s|QCore.*applicationDirPath()|QString(\"${path}\")|" -i "${file}" ''; - buildPlugin = name: mkDerivation { - name = "ultrastar-manager-${name}-plugin-${version}"; - src = patchedSrc; - - buildInputs = [ qmake ] ++ buildInputs; + buildPlugin = + name: + mkDerivation { + name = "ultrastar-manager-${name}-plugin-${version}"; + src = patchedSrc; - postPatch = '' - sed -e "s|DESTDIR = .*$|DESTDIR = $out|" \ - -i src/plugins/${name}/${name}.pro + buildInputs = [ qmake ] ++ buildInputs; - # plugins use the application’s binary folder (wtf) - for f in $(grep -lr "QCoreApplication::applicationDirPath" src/plugins); do - ${patchApplicationPath "$f" "\$out"} - done + postPatch = '' + sed -e "s|DESTDIR = .*$|DESTDIR = $out|" \ + -i src/plugins/${name}/${name}.pro - ''; - preConfigure = '' - cd src/plugins/${name} - ''; - }; + # plugins use the application’s binary folder (wtf) + for f in $(grep -lr "QCoreApplication::applicationDirPath" src/plugins); do + ${patchApplicationPath "$f" "\$out"} + done - builtPlugins = - symlinkJoin { - name = "ultrastar-manager-plugins-${version}"; - paths = map buildPlugin plugins; + ''; + preConfigure = '' + cd src/plugins/${name} + ''; }; -in mkDerivation { + builtPlugins = symlinkJoin { + name = "ultrastar-manager-plugins-${version}"; + paths = map buildPlugin plugins; + }; + +in +mkDerivation { pname = "ultrastar-manager"; inherit version; src = patchedSrc; diff --git a/pkgs/tools/misc/valeronoi/default.nix b/pkgs/tools/misc/valeronoi/default.nix index cb648f483fa30f..d030107c9f545f 100644 --- a/pkgs/tools/misc/valeronoi/default.nix +++ b/pkgs/tools/misc/valeronoi/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, fetchFromGitHub -, boost -, cgal -, cmake -, gpp -, mpfr -, qtbase -, qtimageformats -, qtsvg -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + boost, + cgal, + cmake, + gpp, + mpfr, + qtbase, + qtimageformats, + qtsvg, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -45,7 +46,10 @@ stdenv.mkDerivation rec { description = "WiFi mapping companion app for Valetudo"; license = licenses.gpl3Only; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ nova-madeline maeve ]; + maintainers = with maintainers; [ + nova-madeline + maeve + ]; mainProgram = "valeronoi"; }; } diff --git a/pkgs/tools/misc/veikk-linux-driver-gui/default.nix b/pkgs/tools/misc/veikk-linux-driver-gui/default.nix index 28e3194f56ec09..8069e7cec5d1c1 100644 --- a/pkgs/tools/misc/veikk-linux-driver-gui/default.nix +++ b/pkgs/tools/misc/veikk-linux-driver-gui/default.nix @@ -1,4 +1,9 @@ -{ lib, mkDerivation, fetchFromGitHub, qmake }: +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, +}: mkDerivation rec { pname = "veikk-linux-driver-gui"; diff --git a/pkgs/tools/misc/vimpager/build.nix b/pkgs/tools/misc/vimpager/build.nix index a610a461656cc9..f3e146fd14f13a 100644 --- a/pkgs/tools/misc/vimpager/build.nix +++ b/pkgs/tools/misc/vimpager/build.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchFromGitHub -, coreutils -, sharutils -, version -, sha256 +{ + lib, + stdenv, + fetchFromGitHub, + coreutils, + sharutils, + version, + sha256, }: stdenv.mkDerivation { @@ -13,9 +15,9 @@ stdenv.mkDerivation { src = fetchFromGitHub { inherit sha256; - owner = "rkitover"; - repo = "vimpager"; - rev = version; + owner = "rkitover"; + repo = "vimpager"; + rev = version; }; nativeBuildInputs = [ sharutils ]; # for uuencode @@ -30,11 +32,14 @@ stdenv.mkDerivation { make ''; - meta = with lib; { description = "Use Vim as PAGER"; - homepage = "https://www.vim.org/scripts/script.php?script_id=1723"; - license = with licenses; [ bsd2 mit vim ]; - platforms = platforms.unix; + homepage = "https://www.vim.org/scripts/script.php?script_id=1723"; + license = with licenses; [ + bsd2 + mit + vim + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/tools/misc/vimpager/default.nix b/pkgs/tools/misc/vimpager/default.nix index 1b1512db3cfe9c..21e2a8bf7b03d8 100644 --- a/pkgs/tools/misc/vimpager/default.nix +++ b/pkgs/tools/misc/vimpager/default.nix @@ -2,5 +2,5 @@ callPackage ./build.nix { version = "2.06"; - sha256 = "05yr7j72bw64nx7a0y6w9fjmz54zd4g46fn1qjfbbqvbc19fjpl8"; + sha256 = "05yr7j72bw64nx7a0y6w9fjmz54zd4g46fn1qjfbbqvbc19fjpl8"; } diff --git a/pkgs/tools/misc/vimpager/latest.nix b/pkgs/tools/misc/vimpager/latest.nix index 4ea8d5be57fdca..4557f7aad57406 100644 --- a/pkgs/tools/misc/vimpager/latest.nix +++ b/pkgs/tools/misc/vimpager/latest.nix @@ -2,9 +2,12 @@ (callPackage ./build.nix { version = "a4da4dfac44d1bbc6986c5c76fea45a60ebdd8e5"; - sha256 = "0gcjpw2q263hh8w2sjvq3f3k2d28qpkkv0jnl8hw1l7v604i8zxg"; -}).overrideAttrs (old: { - postPatch = old.postPatch or "" + '' - echo 'echo ${runtimeShell}' > scripts/find_shell - ''; -}) + sha256 = "0gcjpw2q263hh8w2sjvq3f3k2d28qpkkv0jnl8hw1l7v604i8zxg"; +}).overrideAttrs + (old: { + postPatch = + old.postPatch or "" + + '' + echo 'echo ${runtimeShell}' > scripts/find_shell + ''; + }) diff --git a/pkgs/tools/misc/vimwiki-markdown/default.nix b/pkgs/tools/misc/vimwiki-markdown/default.nix index 9db7c9d2443ee7..eff91e14f940d0 100644 --- a/pkgs/tools/misc/vimwiki-markdown/default.nix +++ b/pkgs/tools/misc/vimwiki-markdown/default.nix @@ -1,8 +1,9 @@ -{ lib -, buildPythonApplication -, fetchPypi -, markdown -, pygments +{ + lib, + buildPythonApplication, + fetchPypi, + markdown, + pygments, }: buildPythonApplication rec { @@ -14,7 +15,7 @@ buildPythonApplication rec { hash = "sha256-hJl0OTE6kHucVGOxgOZBG0noYRfxma3yZSrUWEssLN4="; }; - propagatedBuildInputs= [ + propagatedBuildInputs = [ markdown pygments ]; diff --git a/pkgs/tools/misc/vrc-get/default.nix b/pkgs/tools/misc/vrc-get/default.nix index e622d4534adb83..6e15af4c01a122 100644 --- a/pkgs/tools/misc/vrc-get/default.nix +++ b/pkgs/tools/misc/vrc-get/default.nix @@ -1,4 +1,12 @@ -{ fetchCrate, installShellFiles, lib, rustPlatform, pkg-config, stdenv, buildPackages }: +{ + fetchCrate, + installShellFiles, + lib, + rustPlatform, + pkg-config, + stdenv, + buildPackages, +}: rustPlatform.buildRustPackage rec { pname = "vrc-get"; @@ -9,7 +17,10 @@ rustPlatform.buildRustPackage rec { hash = "sha256-4ZiN9sl4VImb3ufF6L9k5t45tmV1RUSvm3NL52waj0o="; }; - nativeBuildInputs = [ installShellFiles pkg-config ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + ]; cargoHash = "sha256-uPx9sujuvBp6wJzzqVlS8Rq1S9Cb2su9/gp4pnNJ9zQ="; diff --git a/pkgs/tools/misc/wacomtablet/default.nix b/pkgs/tools/misc/wacomtablet/default.nix index 0b815eac39d529..6529ec029908ba 100644 --- a/pkgs/tools/misc/wacomtablet/default.nix +++ b/pkgs/tools/misc/wacomtablet/default.nix @@ -1,5 +1,13 @@ -{ lib, mkDerivation, fetchurl, fetchpatch, extra-cmake-modules, qtx11extras, - plasma-workspace, libwacom, xf86_input_wacom +{ + lib, + mkDerivation, + fetchurl, + fetchpatch, + extra-cmake-modules, + qtx11extras, + plasma-workspace, + libwacom, + xf86_input_wacom, }: mkDerivation rec { @@ -18,8 +26,10 @@ mkDerivation rec { nativeBuildInputs = [ extra-cmake-modules ]; buildInputs = [ - qtx11extras plasma-workspace - libwacom xf86_input_wacom + qtx11extras + plasma-workspace + libwacom + xf86_input_wacom ]; meta = { diff --git a/pkgs/tools/misc/wagyu/default.nix b/pkgs/tools/misc/wagyu/default.nix index 6200ee77d6132b..d95c29509be43e 100644 --- a/pkgs/tools/misc/wagyu/default.nix +++ b/pkgs/tools/misc/wagyu/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, Security }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + Security, +}: rustPlatform.buildRustPackage rec { pname = "wagyu"; @@ -20,7 +26,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Rust library for generating cryptocurrency wallets"; homepage = "https://github.com/AleoHQ/wagyu"; - license = with licenses; [ mit asl20 ]; + license = with licenses; [ + mit + asl20 + ]; maintainers = [ maintainers.offline ]; mainProgram = "wagyu"; }; diff --git a/pkgs/tools/misc/watchexec/default.nix b/pkgs/tools/misc/watchexec/default.nix index a073ef9473fe41..c4597d54c41d24 100644 --- a/pkgs/tools/misc/watchexec/default.nix +++ b/pkgs/tools/misc/watchexec/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, Cocoa, AppKit, installShellFiles }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + Cocoa, + AppKit, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "watchexec"; @@ -15,11 +23,17 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ installShellFiles ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa AppKit ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + Cocoa + AppKit + ]; NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin "-framework AppKit"; - checkFlags = [ "--skip=help" "--skip=help_short" ]; + checkFlags = [ + "--skip=help" + "--skip=help_short" + ]; postPatch = '' rm .cargo/config.toml diff --git a/pkgs/tools/misc/wyrd/default.nix b/pkgs/tools/misc/wyrd/default.nix index 18647cae1a232a..3184cfe0b6028b 100644 --- a/pkgs/tools/misc/wyrd/default.nix +++ b/pkgs/tools/misc/wyrd/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, ocamlPackages, ncurses, remind }: +{ + lib, + stdenv, + fetchurl, + ocamlPackages, + ncurses, + remind, +}: stdenv.mkDerivation rec { version = "1.4.6"; @@ -14,8 +21,14 @@ stdenv.mkDerivation rec { ''; strictDeps = true; - nativeBuildInputs = [ ocamlPackages.ocaml ocamlPackages.camlp4 ]; - buildInputs = [ ncurses remind ]; + nativeBuildInputs = [ + ocamlPackages.ocaml + ocamlPackages.camlp4 + ]; + buildInputs = [ + ncurses + remind + ]; preferLocalBuild = true; diff --git a/pkgs/tools/misc/xburst-tools/default.nix b/pkgs/tools/misc/xburst-tools/default.nix index a94f9681a05cda..35a94d1952ad11 100644 --- a/pkgs/tools/misc/xburst-tools/default.nix +++ b/pkgs/tools/misc/xburst-tools/default.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchgit, libusb-compat-0_1, libusb1, autoconf, automake, libconfuse, pkg-config -, gccCross ? null +{ + lib, + stdenv, + fetchgit, + libusb-compat-0_1, + libusb1, + autoconf, + automake, + libconfuse, + pkg-config, + gccCross ? null, }: let @@ -29,14 +38,24 @@ stdenv.mkDerivation { "CROSS_COMPILE=${gccCross.targetPrefix}" ]; - hardeningDisable = [ "pic" "stackprotector" ]; + hardeningDisable = [ + "pic" + "stackprotector" + ]; # Not to strip cross build binaries (this is for the gcc-cross-wrapper) dontCrossStrip = true; - nativeBuildInputs = [ autoconf automake pkg-config ]; - buildInputs = [ libusb-compat-0_1 libusb1 libconfuse ] ++ - lib.optional (gccCross != null) gccCross; + nativeBuildInputs = [ + autoconf + automake + pkg-config + ]; + buildInputs = [ + libusb-compat-0_1 + libusb1 + libconfuse + ] ++ lib.optional (gccCross != null) gccCross; meta = { broken = stdenv.hostPlatform.isDarwin; diff --git a/pkgs/tools/misc/xflux/default.nix b/pkgs/tools/misc/xflux/default.nix index 5cfda2df174f39..442d7f8d5d7e0e 100644 --- a/pkgs/tools/misc/xflux/default.nix +++ b/pkgs/tools/misc/xflux/default.nix @@ -1,4 +1,13 @@ -{lib, stdenv, fetchurl, libXxf86vm, libXext, libX11, libXrandr, gcc}: +{ + lib, + stdenv, + fetchurl, + libXxf86vm, + libXext, + libX11, + libXrandr, + gcc, +}: stdenv.mkDerivation { pname = "xflux"; version = "unstable-2013-09-01"; diff --git a/pkgs/tools/misc/xflux/gui.nix b/pkgs/tools/misc/xflux/gui.nix index 97ad6dbaaecd4c..c95ea40ac2b426 100644 --- a/pkgs/tools/misc/xflux/gui.nix +++ b/pkgs/tools/misc/xflux/gui.nix @@ -1,6 +1,19 @@ -{ lib, fetchFromGitHub, buildPythonApplication, python3Packages, wrapGAppsHook3 -, xflux, gtk3, gobject-introspection, pango, gdk-pixbuf, atk -, pexpect, pygobject3, pyxdg, libappindicator-gtk3 +{ + lib, + fetchFromGitHub, + buildPythonApplication, + python3Packages, + wrapGAppsHook3, + xflux, + gtk3, + gobject-introspection, + pango, + gdk-pixbuf, + atk, + pexpect, + pygobject3, + pyxdg, + libappindicator-gtk3, }: buildPythonApplication rec { pname = "xflux-gui"; @@ -20,17 +33,22 @@ buildPythonApplication rec { ]; buildInputs = [ - xflux gtk3 + xflux + gtk3 ]; nativeBuildInputs = [ - wrapGAppsHook3 gobject-introspection - pango gdk-pixbuf atk libappindicator-gtk3 + wrapGAppsHook3 + gobject-introspection + pango + gdk-pixbuf + atk + libappindicator-gtk3 ]; postPatch = '' - substituteInPlace src/fluxgui/xfluxcontroller.py \ - --replace "pexpect.spawn(\"xflux\"" "pexpect.spawn(\"${xflux}/bin/xflux\"" + substituteInPlace src/fluxgui/xfluxcontroller.py \ + --replace "pexpect.spawn(\"xflux\"" "pexpect.spawn(\"${xflux}/bin/xflux\"" ''; postFixup = '' diff --git a/pkgs/tools/misc/xvfb-run/default.nix b/pkgs/tools/misc/xvfb-run/default.nix index f168c28268983d..e2c2dc742e4cc5 100644 --- a/pkgs/tools/misc/xvfb-run/default.nix +++ b/pkgs/tools/misc/xvfb-run/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenvNoCC -, fetchFromGitHub -, makeWrapper -, xorg -, getopt -, xauth -, util-linux -, which -, fontsConf -, gawk -, coreutils -, installShellFiles -, xterm +{ + lib, + stdenvNoCC, + fetchFromGitHub, + makeWrapper, + xorg, + getopt, + xauth, + util-linux, + which, + fontsConf, + gawk, + coreutils, + installShellFiles, + xterm, }: stdenvNoCC.mkDerivation rec { pname = "xvfb-run"; @@ -24,7 +25,10 @@ stdenvNoCC.mkDerivation rec { sha256 = "sha256-KEg92RYgJd7naHFDKbdXEy075bt6NLcmX8VhQROHVPs="; }; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; dontUnpack = true; dontBuild = true; @@ -39,7 +43,17 @@ stdenvNoCC.mkDerivation rec { patchShebangs $out/bin/xvfb-run wrapProgram $out/bin/xvfb-run \ --set-default FONTCONFIG_FILE "${fontsConf}" \ - --prefix PATH : ${lib.makeBinPath [ getopt xorg.xvfb xauth which util-linux gawk coreutils ]} + --prefix PATH : ${ + lib.makeBinPath [ + getopt + xorg.xvfb + xauth + which + util-linux + gawk + coreutils + ] + } ''; doInstallCheck = true; diff --git a/pkgs/tools/misc/yafetch/default.nix b/pkgs/tools/misc/yafetch/default.nix index 4b0254da44d29c..8b05f19e744750 100644 --- a/pkgs/tools/misc/yafetch/default.nix +++ b/pkgs/tools/misc/yafetch/default.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "yafetch"; diff --git a/pkgs/tools/misc/youtube-dl/default.nix b/pkgs/tools/misc/youtube-dl/default.nix index 5f2becdadaff6d..06cef5d1288d44 100644 --- a/pkgs/tools/misc/youtube-dl/default.nix +++ b/pkgs/tools/misc/youtube-dl/default.nix @@ -1,15 +1,26 @@ -{ lib, fetchurl, fetchpatch, buildPythonPackage -, zip, ffmpeg, rtmpdump, atomicparsley, pycryptodome, pandoc -# Pandoc is required to build the package's man page. Release tarballs contain a -# formatted man page already, though, it will still be installed. We keep the -# manpage argument in place in case someone wants to use this derivation to -# build a Git version of the tool that doesn't have the formatted man page -# included. -, generateManPage ? false -, ffmpegSupport ? true -, rtmpSupport ? true -, hlsEncryptedSupport ? true -, installShellFiles, makeWrapper }: +{ + lib, + fetchurl, + fetchpatch, + buildPythonPackage, + zip, + ffmpeg, + rtmpdump, + atomicparsley, + pycryptodome, + pandoc, + # Pandoc is required to build the package's man page. Release tarballs contain a + # formatted man page already, though, it will still be installed. We keep the + # manpage argument in place in case someone wants to use this derivation to + # build a Git version of the tool that doesn't have the formatted man page + # included. + generateManPage ? false, + ffmpegSupport ? true, + rtmpSupport ? true, + hlsEncryptedSupport ? true, + installShellFiles, + makeWrapper, +}: buildPythonPackage rec { @@ -53,7 +64,10 @@ buildPythonPackage rec { }) ]; - nativeBuildInputs = [ installShellFiles makeWrapper ]; + nativeBuildInputs = [ + installShellFiles + makeWrapper + ]; buildInputs = [ zip ] ++ lib.optional generateManPage pandoc; propagatedBuildInputs = lib.optional hlsEncryptedSupport pycryptodome; @@ -61,12 +75,12 @@ buildPythonPackage rec { # - ffmpeg: post-processing & transcoding support # - rtmpdump: download files over RTMP # - atomicparsley: embedding thumbnails - makeWrapperArgs = let + makeWrapperArgs = + let packagesToBinPath = - [ atomicparsley ] - ++ lib.optional ffmpegSupport ffmpeg - ++ lib.optional rtmpSupport rtmpdump; - in [ ''--prefix PATH : "${lib.makeBinPath packagesToBinPath}"'' ]; + [ atomicparsley ] ++ lib.optional ffmpegSupport ffmpeg ++ lib.optional rtmpSupport rtmpdump; + in + [ ''--prefix PATH : "${lib.makeBinPath packagesToBinPath}"'' ]; setupPyBuildFlags = [ "build_lazy_extractors" @@ -89,7 +103,10 @@ buildPythonPackage rec { it however you like. ''; license = licenses.publicDomain; - maintainers = with maintainers; [ bluescreen303 fpletz ]; + maintainers = with maintainers; [ + bluescreen303 + fpletz + ]; platforms = with platforms; linux ++ darwin; mainProgram = "youtube-dl"; knownVulnerabilities = [ diff --git a/pkgs/tools/misc/yubikey-manager-qt/default.nix b/pkgs/tools/misc/yubikey-manager-qt/default.nix index ce0d06bb089a25..9012e9b5927925 100644 --- a/pkgs/tools/misc/yubikey-manager-qt/default.nix +++ b/pkgs/tools/misc/yubikey-manager-qt/default.nix @@ -1,16 +1,17 @@ -{ lib -, mkDerivation -, fetchurl -, imagemagick -, pcsclite -, pyotherside -, python3 -, qmake -, qtbase -, qtgraphicaleffects -, qtquickcontrols2 -, yubikey-manager -, yubikey-personalization +{ + lib, + mkDerivation, + fetchurl, + imagemagick, + pcsclite, + pyotherside, + python3, + qmake, + qtbase, + qtgraphicaleffects, + qtquickcontrols2, + yubikey-manager, + yubikey-personalization, }: mkDerivation rec { @@ -67,7 +68,13 @@ mkDerivation rec { ''; qtWrapperArgs = [ - "--prefix" "LD_LIBRARY_PATH" ":" (lib.makeLibraryPath [ pcsclite yubikey-personalization ]) + "--prefix" + "LD_LIBRARY_PATH" + ":" + (lib.makeLibraryPath [ + pcsclite + yubikey-personalization + ]) ]; preFixup = '' diff --git a/pkgs/tools/misc/yubikey-personalization-gui/default.nix b/pkgs/tools/misc/yubikey-personalization-gui/default.nix index 6493c7244c3b03..1698737f200095 100644 --- a/pkgs/tools/misc/yubikey-personalization-gui/default.nix +++ b/pkgs/tools/misc/yubikey-personalization-gui/default.nix @@ -1,5 +1,15 @@ -{ stdenv, lib, fetchurl, mkDerivation, pkg-config, qtbase, qmake, imagemagick -, libyubikey, yubikey-personalization }: +{ + stdenv, + lib, + fetchurl, + mkDerivation, + pkg-config, + qtbase, + qmake, + imagemagick, + libyubikey, + yubikey-personalization, +}: mkDerivation rec { pname = "yubikey-personalization-gui"; @@ -10,8 +20,16 @@ mkDerivation rec { sha256 = "1knyv5yss8lhzaff6jpfqv12fjf1b8b21mfxzx3qi0hw4nl8n2v8"; }; - nativeBuildInputs = [ pkg-config qmake imagemagick ]; - buildInputs = [ yubikey-personalization qtbase libyubikey ]; + nativeBuildInputs = [ + pkg-config + qmake + imagemagick + ]; + buildInputs = [ + yubikey-personalization + qtbase + libyubikey + ]; installPhase = '' install -D -m0755 build/release/yubikey-personalization-gui "$out/bin/yubikey-personalization-gui" diff --git a/pkgs/tools/networking/acme-client/default.nix b/pkgs/tools/networking/acme-client/default.nix index 983a2b1a17786b..539c93807448b9 100644 --- a/pkgs/tools/networking/acme-client/default.nix +++ b/pkgs/tools/networking/acme-client/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchurl -, libbsd -, libressl -, pkg-config +{ + lib, + stdenv, + fetchurl, + libbsd, + libressl, + pkg-config, }: stdenv.mkDerivation rec { @@ -37,4 +38,3 @@ stdenv.mkDerivation rec { mainProgram = "acme-client"; }; } - diff --git a/pkgs/tools/networking/anevicon/default.nix b/pkgs/tools/networking/anevicon/default.nix index c84f0e75d3d64c..5aaec8d47fd6d2 100644 --- a/pkgs/tools/networking/anevicon/default.nix +++ b/pkgs/tools/networking/anevicon/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, rustPlatform -, libiconv -, Security +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + rustPlatform, + libiconv, + Security, }: rustPlatform.buildRustPackage rec { @@ -20,7 +21,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Id/vjne73w+bDVA8wT7fV1DMXeGtYbSAdwl07UfYJbw="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv Security ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Security + ]; cargoPatches = [ # Add Cargo.lock file, https://github.com/rozgo/anevicon/pull/1 diff --git a/pkgs/tools/networking/apc-temp-fetch/default.nix b/pkgs/tools/networking/apc-temp-fetch/default.nix index 84d1db515da170..b25672dd19e17c 100644 --- a/pkgs/tools/networking/apc-temp-fetch/default.nix +++ b/pkgs/tools/networking/apc-temp-fetch/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonApplication -, fetchPypi -, pythonOlder -, requests -, setuptools +{ + lib, + buildPythonApplication, + fetchPypi, + pythonOlder, + requests, + setuptools, }: buildPythonApplication rec { diff --git a/pkgs/tools/networking/aria2/default.nix b/pkgs/tools/networking/aria2/default.nix index e3c4210857e3c4..c625d37362fc5b 100644 --- a/pkgs/tools/networking/aria2/default.nix +++ b/pkgs/tools/networking/aria2/default.nix @@ -1,7 +1,19 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, autoreconfHook -, gnutls, c-ares, libxml2, sqlite, zlib, libssh2 -, cppunit, sphinx -, Security, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + autoreconfHook, + gnutls, + c-ares, + libxml2, + sqlite, + zlib, + libssh2, + cppunit, + sphinx, + Security, + nixosTests, }: stdenv.mkDerivation rec { @@ -16,12 +28,28 @@ stdenv.mkDerivation rec { }; strictDeps = true; - nativeBuildInputs = [ pkg-config autoreconfHook sphinx ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + sphinx + ]; - buildInputs = [ gnutls c-ares libxml2 sqlite zlib libssh2 ] ++ - lib.optional stdenv.hostPlatform.isDarwin Security; + buildInputs = [ + gnutls + c-ares + libxml2 + sqlite + zlib + libssh2 + ] ++ lib.optional stdenv.hostPlatform.isDarwin Security; - outputs = [ "bin" "dev" "out" "doc" "man" ]; + outputs = [ + "bin" + "dev" + "out" + "doc" + "man" + ]; configureFlags = [ "--with-ca-bundle=/etc/ssl/certs/ca-certificates.crt" @@ -49,6 +77,10 @@ stdenv.mkDerivation rec { mainProgram = "aria2c"; license = licenses.gpl2Plus; platforms = platforms.unix; - maintainers = with maintainers; [ Br1ght0ne koral timhae ]; + maintainers = with maintainers; [ + Br1ght0ne + koral + timhae + ]; }; } diff --git a/pkgs/tools/networking/axel/default.nix b/pkgs/tools/networking/axel/default.nix index b30157755e4998..62eac3d811f3ee 100644 --- a/pkgs/tools/networking/axel/default.nix +++ b/pkgs/tools/networking/axel/default.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, autoconf-archive -, pkg-config, gettext, libssl, txt2man }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + autoconf-archive, + pkg-config, + gettext, + libssl, + txt2man, +}: stdenv.mkDerivation rec { pname = "axel"; @@ -12,9 +21,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-5GUna5k8GhAx1Xe8n9IvXT7IO6gksxCLh+sMANlxTBM="; }; - nativeBuildInputs = [ autoreconfHook pkg-config autoconf-archive txt2man ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + autoconf-archive + txt2man + ]; - buildInputs = [ gettext libssl ]; + buildInputs = [ + gettext + libssl + ]; installFlags = [ "ETCDIR=${placeholder "out"}/etc" ]; diff --git a/pkgs/tools/networking/bandwhich/default.nix b/pkgs/tools/networking/bandwhich/default.nix index 0c5a6d20a694be..843b42bb8e7ff4 100644 --- a/pkgs/tools/networking/bandwhich/default.nix +++ b/pkgs/tools/networking/bandwhich/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Security, installShellFiles }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "bandwhich"; @@ -58,7 +65,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/imsnif/bandwhich"; changelog = "https://github.com/imsnif/bandwhich/blob/${src.rev}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ Br1ght0ne figsoda ]; + maintainers = with maintainers; [ + Br1ght0ne + figsoda + ]; platforms = platforms.unix; mainProgram = "bandwhich"; }; diff --git a/pkgs/tools/networking/bitmask-vpn/default.nix b/pkgs/tools/networking/bitmask-vpn/default.nix index d4e63f51a062b2..5c8cbbe06db77e 100644 --- a/pkgs/tools/networking/bitmask-vpn/default.nix +++ b/pkgs/tools/networking/bitmask-vpn/default.nix @@ -1,28 +1,29 @@ -{ lib -, stdenv -, substituteAll -, git -, fetchFromGitLab -, buildGoModule -, wrapQtAppsHook -, python3 -, python3Packages -, pkg-config -, openvpn -, cmake -, qmake -, which -, iproute2 -, iptables -, procps -, qtbase -, qtdeclarative -, qtsvg -, qttools -, qtwayland -, CoreFoundation -, Security -, provider ? "riseup" +{ + lib, + stdenv, + substituteAll, + git, + fetchFromGitLab, + buildGoModule, + wrapQtAppsHook, + python3, + python3Packages, + pkg-config, + openvpn, + cmake, + qmake, + which, + iproute2, + iptables, + procps, + qtbase, + qtdeclarative, + qtsvg, + qttools, + qtwayland, + CoreFoundation, + Security, + provider ? "riseup", }: let version = "0.24.8"; @@ -82,29 +83,31 @@ buildGoModule rec { ./build_release.patch ]; - postPatch = '' - substituteInPlace pkg/pickle/helpers.go \ - --replace /usr/share $out/share - - # Using $PROVIDER is not working, - # thus replacing directly into the vendor.conf - substituteInPlace providers/vendor.conf \ - --replace "provider = bitmask" "provider = ${provider}" - - substituteInPlace branding/templates/debian/app.desktop-template \ - --replace "Icon=icon" "Icon=${pname}" - - patchShebangs gui/build.sh - wrapPythonProgramsIn branding/scripts - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace pkg/helper/linux.go \ - --replace /usr/sbin/openvpn ${openvpn}/bin/openvpn - substituteInPlace pkg/launcher/launcher_linux.go \ - --replace /usr/sbin/openvpn ${openvpn}/bin/openvpn \ - --replace /usr/sbin/bitmask-root ${bitmask-root}/bin/bitmask-root \ - --replace /usr/bin/lxpolkit /run/wrappers/bin/polkit-agent-helper-1 \ - --replace '"polkit-gnome-authentication-agent-1",' '"polkit-gnome-authentication-agent-1","polkitd",' - ''; + postPatch = + '' + substituteInPlace pkg/pickle/helpers.go \ + --replace /usr/share $out/share + + # Using $PROVIDER is not working, + # thus replacing directly into the vendor.conf + substituteInPlace providers/vendor.conf \ + --replace "provider = bitmask" "provider = ${provider}" + + substituteInPlace branding/templates/debian/app.desktop-template \ + --replace "Icon=icon" "Icon=${pname}" + + patchShebangs gui/build.sh + wrapPythonProgramsIn branding/scripts + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace pkg/helper/linux.go \ + --replace /usr/sbin/openvpn ${openvpn}/bin/openvpn + substituteInPlace pkg/launcher/launcher_linux.go \ + --replace /usr/sbin/openvpn ${openvpn}/bin/openvpn \ + --replace /usr/sbin/bitmask-root ${bitmask-root}/bin/bitmask-root \ + --replace /usr/bin/lxpolkit /run/wrappers/bin/polkit-agent-helper-1 \ + --replace '"polkit-gnome-authentication-agent-1",' '"polkit-gnome-authentication-agent-1","polkitd",' + ''; nativeBuildInputs = [ cmake @@ -119,12 +122,17 @@ buildGoModule rec { qtsvg ]; - buildInputs = [ - qtbase - qtdeclarative - qtsvg - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreFoundation Security ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ qtwayland ]; + buildInputs = + [ + qtbase + qtdeclarative + qtsvg + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreFoundation + Security + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ qtwayland ]; # FIXME: building on Darwin currently fails # due to missing debug symbols for Qt, @@ -149,16 +157,18 @@ buildGoModule rec { runHook postBuild ''; - postInstall = '' - install -m 755 -D -t $out/bin build/qt/release/${pname} - - VERSION=${version} VENDOR_PATH=providers branding/scripts/generate-debian branding/templates/debian/data.json - (cd branding/templates/debian && ${python3Packages.python}/bin/python3 generate.py) - install -m 444 -D branding/templates/debian/app.desktop $out/share/applications/${pname}.desktop - install -m 444 -D providers/${provider}/assets/icon.svg $out/share/icons/hicolor/scalable/apps/${pname}.svg - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - install -m 444 -D -t $out/share/polkit-1/actions ${bitmask-root}/share/polkit-1/actions/se.leap.bitmask.policy - ''; + postInstall = + '' + install -m 755 -D -t $out/bin build/qt/release/${pname} + + VERSION=${version} VENDOR_PATH=providers branding/scripts/generate-debian branding/templates/debian/data.json + (cd branding/templates/debian && ${python3Packages.python}/bin/python3 generate.py) + install -m 444 -D branding/templates/debian/app.desktop $out/share/applications/${pname}.desktop + install -m 444 -D providers/${provider}/assets/icon.svg $out/share/icons/hicolor/scalable/apps/${pname}.svg + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + install -m 444 -D -t $out/share/polkit-1/actions ${bitmask-root}/share/polkit-1/actions/se.leap.bitmask.policy + ''; # Some tests need access to the Internet: # Post "https://api.black.riseup.net/3/cert": dial tcp: lookup api.black.riseup.net on [::1]:53: read udp [::1]:56553->[::1]:53: read: connection refused diff --git a/pkgs/tools/networking/bore-cli/default.nix b/pkgs/tools/networking/bore-cli/default.nix index a29c58734adec8..c680a5d9b3808d 100644 --- a/pkgs/tools/networking/bore-cli/default.nix +++ b/pkgs/tools/networking/bore-cli/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + Security, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/tools/networking/bore/default.nix b/pkgs/tools/networking/bore/default.nix index 4d67cb4c94d7c6..e74ea0a5fae7cb 100644 --- a/pkgs/tools/networking/bore/default.nix +++ b/pkgs/tools/networking/bore/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, rustPlatform, fetchFromBitbucket, Libsystem, SystemConfiguration, installShellFiles }: +{ + lib, + stdenv, + rustPlatform, + fetchFromBitbucket, + Libsystem, + SystemConfiguration, + installShellFiles, +}: rustPlatform.buildRustPackage rec { pname = "bore"; @@ -12,17 +20,24 @@ rustPlatform.buildRustPackage rec { }; cargoHash = "sha256-vUKv98lfsrxBiJxjL8ZKLZ1IVCX5hHzl+F5y4Ot3i/Y="; - cargoBuildFlags = [ "-p" pname ]; + cargoBuildFlags = [ + "-p" + pname + ]; # error[E0793]: reference to packed field is unaligned doCheck = !stdenv.hostPlatform.isDarwin; # FIXME can’t test --all-targets and --doc in a single invocation - cargoTestFlags = [ "--all-targets" "--workspace" ]; + cargoTestFlags = [ + "--all-targets" + "--workspace" + ]; checkFeatures = [ "std" ]; - nativeBuildInputs = [ installShellFiles ] - ++ lib.optional stdenv.hostPlatform.isDarwin rustPlatform.bindgenHook; + nativeBuildInputs = [ + installShellFiles + ] ++ lib.optional stdenv.hostPlatform.isDarwin rustPlatform.bindgenHook; buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Libsystem diff --git a/pkgs/tools/networking/cmst/default.nix b/pkgs/tools/networking/cmst/default.nix index fd484798677c3c..54189d20833186 100644 --- a/pkgs/tools/networking/cmst/default.nix +++ b/pkgs/tools/networking/cmst/default.nix @@ -1,4 +1,12 @@ -{ mkDerivation, lib, fetchFromGitHub, qmake, qtbase, qttools, gitUpdater }: +{ + mkDerivation, + lib, + fetchFromGitHub, + qmake, + qtbase, + qttools, + gitUpdater, +}: mkDerivation rec { pname = "cmst"; @@ -11,7 +19,10 @@ mkDerivation rec { sha256 = "sha256-yTqPxywPbtxTy1PPG+Mq64u8MrB27fEdmt1B0pn0BVk="; }; - nativeBuildInputs = [ qmake qttools ]; + nativeBuildInputs = [ + qmake + qttools + ]; buildInputs = [ qtbase ]; @@ -29,7 +40,10 @@ mkDerivation rec { description = "QT GUI for Connman with system tray icon"; mainProgram = "cmst"; homepage = "https://github.com/andrew-bibb/cmst"; - maintainers = with maintainers; [ matejc romildo ]; + maintainers = with maintainers; [ + matejc + romildo + ]; platforms = platforms.linux; license = licenses.mit; }; diff --git a/pkgs/tools/networking/cocom/default.nix b/pkgs/tools/networking/cocom/default.nix index ad6ab959e6e2fb..f3ae01d96eb969 100644 --- a/pkgs/tools/networking/cocom/default.nix +++ b/pkgs/tools/networking/cocom/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/tools/networking/curl-impersonate/default.nix b/pkgs/tools/networking/curl-impersonate/default.nix index f784036b2d6f14..d0c0dd1c3acda4 100644 --- a/pkgs/tools/networking/curl-impersonate/default.nix +++ b/pkgs/tools/networking/curl-impersonate/default.nix @@ -15,11 +15,11 @@ symlinkJoin rec { ]; passthru = { - curl-impersonate-ff = callPackage ./firefox {}; - curl-impersonate-chrome = callPackage ./chrome {}; + curl-impersonate-ff = callPackage ./firefox { }; + curl-impersonate-chrome = callPackage ./chrome { }; inherit (passthru.curl-impersonate-chrome) src; - tests = {inherit (nixosTests) curl-impersonate;}; + tests = { inherit (nixosTests) curl-impersonate; }; }; } diff --git a/pkgs/tools/networking/davix/default.nix b/pkgs/tools/networking/davix/default.nix index 55c0355770974c..4709b57656f1d5 100644 --- a/pkgs/tools/networking/davix/default.nix +++ b/pkgs/tools/networking/davix/default.nix @@ -1,26 +1,27 @@ -{ lib -, stdenv -, fetchurl -, cmake -, pkg-config -, openssl -, libxml2 -, boost -, python3 -, libuuid -, curl -, gsoap -, rapidjson -, Security -, enableTools ? true +{ + lib, + stdenv, + fetchurl, + cmake, + pkg-config, + openssl, + libxml2, + boost, + python3, + libuuid, + curl, + gsoap, + rapidjson, + Security, + enableTools ? true, # Use libcurl instead of libneon # Note that the libneon used is bundled in the project # See https://github.com/cern-fts/davix/issues/23 -, defaultToLibcurl ? false -, enableIpv6 ? true -, enableTcpNodelay ? true + defaultToLibcurl ? false, + enableIpv6 ? true, + enableTcpNodelay ? true, # Build davix_copy.so -, enableThirdPartyCopy ? false + enableThirdPartyCopy ? false, }: let @@ -29,23 +30,30 @@ in stdenv.mkDerivation rec { version = "0.8.7"; pname = "davix" + lib.optionalString enableThirdPartyCopy "-copy"; - nativeBuildInputs = [ cmake pkg-config python3 ]; - buildInputs = [ - boost - curl - libxml2 - openssl - rapidjson - ] - ++ lib.optional stdenv.hostPlatform.isDarwin Security - ++ lib.optional (!stdenv.hostPlatform.isDarwin) libuuid - ++ lib.optional (enableThirdPartyCopy) gsoap; + nativeBuildInputs = [ + cmake + pkg-config + python3 + ]; + buildInputs = + [ + boost + curl + libxml2 + openssl + rapidjson + ] + ++ lib.optional stdenv.hostPlatform.isDarwin Security + ++ lib.optional (!stdenv.hostPlatform.isDarwin) libuuid + ++ lib.optional (enableThirdPartyCopy) gsoap; # using the url below since the github release page states # "please ignore the GitHub-generated tarballs, as they are incomplete" # https://github.com/cern-fts/davix/releases/tag/R_0_8_0 src = fetchurl { - url = "https://github.com/cern-fts/davix/releases/download/R_${lib.replaceStrings ["."] ["_"] version}/davix-${version}.tar.gz"; + url = "https://github.com/cern-fts/davix/releases/download/R_${ + lib.replaceStrings [ "." ] [ "_" ] version + }/davix-${version}.tar.gz"; sha256 = "sha256-eMJOFO3X5OVgOS1nFH7IZYwqoNNkBBW99rxROvz2leY="; }; @@ -73,7 +81,9 @@ stdenv.mkDerivation rec { license = licenses.lgpl2Plus; homepage = "https://github.com/cern-fts/davix"; - changelog = "https://github.com/cern-fts/davix/blob/R_${lib.replaceStrings ["."] ["_"] version}/RELEASE-NOTES.md"; + changelog = "https://github.com/cern-fts/davix/blob/R_${ + lib.replaceStrings [ "." ] [ "_" ] version + }/RELEASE-NOTES.md"; maintainers = with maintainers; [ adev ]; platforms = platforms.all; }; diff --git a/pkgs/tools/networking/dd-agent/datadog-process-agent.nix b/pkgs/tools/networking/dd-agent/datadog-process-agent.nix index 45088be9e29b57..86f3bc9d866361 100644 --- a/pkgs/tools/networking/dd-agent/datadog-process-agent.nix +++ b/pkgs/tools/networking/dd-agent/datadog-process-agent.nix @@ -1,8 +1,10 @@ { lib, datadog-agent }: datadog-agent.overrideAttrs (attrs: { pname = "datadog-process-agent"; - meta = with lib; - attrs.meta // { + meta = + with lib; + attrs.meta + // { description = "Live process collector for the DataDog Agent v7"; mainProgram = "process-agent"; maintainers = with maintainers; [ domenkozar ]; diff --git a/pkgs/tools/networking/dnschef/default.nix b/pkgs/tools/networking/dnschef/default.nix index 2907a0f578e5ab..598126e9aa7228 100644 --- a/pkgs/tools/networking/dnschef/default.nix +++ b/pkgs/tools/networking/dnschef/default.nix @@ -1,4 +1,9 @@ -{ buildPythonApplication, fetchFromGitHub, dnslib, lib }: +{ + buildPythonApplication, + fetchFromGitHub, + dnslib, + lib, +}: buildPythonApplication rec { pname = "dnschef"; diff --git a/pkgs/tools/networking/dnstracer/default.nix b/pkgs/tools/networking/dnstracer/default.nix index 8d1134cff46fbe..e182a086771d8b 100644 --- a/pkgs/tools/networking/dnstracer/default.nix +++ b/pkgs/tools/networking/dnstracer/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, libresolv, perl }: +{ + lib, + stdenv, + fetchurl, + libresolv, + perl, +}: stdenv.mkDerivation rec { version = "1.10"; @@ -9,9 +15,14 @@ stdenv.mkDerivation rec { sha256 = "089bmrjnmsga2n0r4xgw4bwbf41xdqsnmabjxhw8lngg2pns1kb4"; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; - nativeBuildInputs = [ perl /* for pod2man */ ]; + nativeBuildInputs = [ + perl # for pod2man + ]; setOutputFlags = false; @@ -20,7 +31,7 @@ stdenv.mkDerivation rec { install -Dm755 -t $man/share/man/man8 dnstracer.8 ''; - buildInputs = [] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libresolv ]; + buildInputs = [ ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ libresolv ]; NIX_LDFLAGS = lib.optionalString stdenv.hostPlatform.isDarwin "-lresolv"; diff --git a/pkgs/tools/networking/dnsviz/default.nix b/pkgs/tools/networking/dnsviz/default.nix index b275734f8889a3..46a9617cc2cc3d 100644 --- a/pkgs/tools/networking/dnsviz/default.nix +++ b/pkgs/tools/networking/dnsviz/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, dnspython -, m2crypto -, pygraphviz +{ + lib, + buildPythonApplication, + fetchFromGitHub, + dnspython, + m2crypto, + pygraphviz, }: buildPythonApplication rec { diff --git a/pkgs/tools/networking/dogdns/default.nix b/pkgs/tools/networking/dogdns/default.nix index 397e87f23a10e7..17d994fe2ae58b 100644 --- a/pkgs/tools/networking/dogdns/default.nix +++ b/pkgs/tools/networking/dogdns/default.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv -, pkg-config -, openssl -, just -, pandoc -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + pkg-config, + openssl, + just, + pandoc, + Security, }: rustPlatform.buildRustPackage rec { @@ -27,12 +28,19 @@ rustPlatform.buildRustPackage rec { ./remove-date-info.patch ]; - nativeBuildInputs = [ installShellFiles just pandoc ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ]; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ openssl ] + nativeBuildInputs = [ + installShellFiles + just + pandoc + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; cargoLock = { lockFile = ./Cargo.lock; diff --git a/pkgs/tools/networking/drill/default.nix b/pkgs/tools/networking/drill/default.nix index 3afaff496ad909..3679932ff225f7 100644 --- a/pkgs/tools/networking/drill/default.nix +++ b/pkgs/tools/networking/drill/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + Security, }: rustPlatform.buildRustPackage rec { @@ -25,13 +26,15 @@ rustPlatform.buildRustPackage rec { ]; OPENSSL_LIB_DIR = "${lib.getLib openssl}/lib"; - OPENSSL_DIR="${lib.getDev openssl}"; + OPENSSL_DIR = "${lib.getDev openssl}"; - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + ]; meta = with lib; { description = "HTTP load testing application inspired by Ansible syntax"; diff --git a/pkgs/tools/networking/ebpf-verifier/default.nix b/pkgs/tools/networking/ebpf-verifier/default.nix index 79a29cee8be310..431d8429471948 100644 --- a/pkgs/tools/networking/ebpf-verifier/default.nix +++ b/pkgs/tools/networking/ebpf-verifier/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, boost -, cmake -, catch2 -, pkg-config -, substituteAll -, yaml-cpp +{ + lib, + stdenv, + fetchFromGitHub, + boost, + cmake, + catch2, + pkg-config, + substituteAll, + yaml-cpp, }: stdenv.mkDerivation { diff --git a/pkgs/tools/networking/flannel/default.nix b/pkgs/tools/networking/flannel/default.nix index 857c81ac5782ef..0b3dbd3c758772 100644 --- a/pkgs/tools/networking/flannel/default.nix +++ b/pkgs/tools/networking/flannel/default.nix @@ -1,4 +1,9 @@ -{ lib, buildGoModule, fetchFromGitHub, nixosTests }: +{ + lib, + buildGoModule, + fetchFromGitHub, + nixosTests, +}: buildGoModule rec { pname = "flannel"; @@ -25,7 +30,10 @@ buildGoModule rec { description = "Network fabric for containers, designed for Kubernetes"; license = licenses.asl20; homepage = "https://github.com/flannel-io/flannel"; - maintainers = with maintainers; [ johanot offline ]; + maintainers = with maintainers; [ + johanot + offline + ]; platforms = with platforms; linux; mainProgram = "flannel"; }; diff --git a/pkgs/tools/networking/flannel/plugin.nix b/pkgs/tools/networking/flannel/plugin.nix index ecd5954fef0ecf..1d986666272e1c 100644 --- a/pkgs/tools/networking/flannel/plugin.nix +++ b/pkgs/tools/networking/flannel/plugin.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "cni-plugin-flannel"; @@ -14,7 +18,8 @@ buildGoModule rec { vendorHash = "sha256-ZBd7ngYfsmdSGHE9a0kiEB7SeYc9RfaU9MILK2r3cyg="; ldflags = [ - "-s" "-w" + "-s" + "-w" "-X main.Version=${version}" "-X main.Commit=${version}" "-X main.Program=flannel" diff --git a/pkgs/tools/networking/gandi-cli/default.nix b/pkgs/tools/networking/gandi-cli/default.nix index 5d50f566048506..42b9d4ed052230 100644 --- a/pkgs/tools/networking/gandi-cli/default.nix +++ b/pkgs/tools/networking/gandi-cli/default.nix @@ -1,10 +1,11 @@ -{ lib -, buildPythonApplication -, click -, fetchFromGitHub -, ipy -, pyyaml -, requests +{ + lib, + buildPythonApplication, + click, + fetchFromGitHub, + ipy, + pyyaml, + requests, }: buildPythonApplication rec { diff --git a/pkgs/tools/networking/gmrender-resurrect/default.nix b/pkgs/tools/networking/gmrender-resurrect/default.nix index 70c07b4eac9bfc..58296216ac4541 100644 --- a/pkgs/tools/networking/gmrender-resurrect/default.nix +++ b/pkgs/tools/networking/gmrender-resurrect/default.nix @@ -1,37 +1,67 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, pkg-config, makeWrapper, gstreamer -, gst-plugins-base, gst-plugins-good, gst-plugins-bad, gst-plugins-ugly, gst-libav, libupnp }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + makeWrapper, + gstreamer, + gst-plugins-base, + gst-plugins-good, + gst-plugins-bad, + gst-plugins-ugly, + gst-libav, + libupnp, +}: let version = "0.1"; - pluginPath = lib.makeSearchPathOutput "lib" "lib/gstreamer-1.0" [ gstreamer gst-plugins-base gst-plugins-good gst-plugins-bad gst-plugins-ugly gst-libav ]; + pluginPath = lib.makeSearchPathOutput "lib" "lib/gstreamer-1.0" [ + gstreamer + gst-plugins-base + gst-plugins-good + gst-plugins-bad + gst-plugins-ugly + gst-libav + ]; in - stdenv.mkDerivation { - pname = "gmrender-resurrect"; - inherit version; +stdenv.mkDerivation { + pname = "gmrender-resurrect"; + inherit version; - src = fetchFromGitHub { - owner = "hzeller"; - repo = "gmrender-resurrect"; - rev = "v${version}"; - sha256 = "sha256-FR5bMjwPnY1/PNdPRiaxoY1keogq40M06YOaoks4zVY="; - }; + src = fetchFromGitHub { + owner = "hzeller"; + repo = "gmrender-resurrect"; + rev = "v${version}"; + sha256 = "sha256-FR5bMjwPnY1/PNdPRiaxoY1keogq40M06YOaoks4zVY="; + }; - buildInputs = [ gstreamer libupnp ]; - nativeBuildInputs = [ autoreconfHook pkg-config makeWrapper ]; + buildInputs = [ + gstreamer + libupnp + ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + makeWrapper + ]; - postInstall = '' - for prog in "$out/bin/"*; do - wrapProgram "$prog" --suffix GST_PLUGIN_SYSTEM_PATH_1_0 : "${pluginPath}" - done - ''; + postInstall = '' + for prog in "$out/bin/"*; do + wrapProgram "$prog" --suffix GST_PLUGIN_SYSTEM_PATH_1_0 : "${pluginPath}" + done + ''; - meta = with lib; { - description = "Resource efficient UPnP/DLNA renderer, optimal for Raspberry Pi, CuBox or a general MediaServer"; - mainProgram = "gmediarender"; - homepage = "https://github.com/hzeller/gmrender-resurrect"; - license = licenses.gpl2Plus; - platforms = platforms.linux; - maintainers = with maintainers; [ koral hzeller ]; - }; - } + meta = with lib; { + description = "Resource efficient UPnP/DLNA renderer, optimal for Raspberry Pi, CuBox or a general MediaServer"; + mainProgram = "gmediarender"; + homepage = "https://github.com/hzeller/gmrender-resurrect"; + license = licenses.gpl2Plus; + platforms = platforms.linux; + maintainers = with maintainers; [ + koral + hzeller + ]; + }; +} diff --git a/pkgs/tools/networking/gp-saml-gui/default.nix b/pkgs/tools/networking/gp-saml-gui/default.nix index 1426d13ed22b29..d0347a62e785f0 100644 --- a/pkgs/tools/networking/gp-saml-gui/default.nix +++ b/pkgs/tools/networking/gp-saml-gui/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, buildPythonPackage -, webkitgtk_4_0 -, wrapGAppsHook3 -, glib-networking -, gobject-introspection -, openconnect -, pygobject3 -, requests +{ + lib, + stdenv, + fetchFromGitHub, + buildPythonPackage, + webkitgtk_4_0, + wrapGAppsHook3, + glib-networking, + gobject-introspection, + openconnect, + pygobject3, + requests, }: buildPythonPackage rec { pname = "gp-saml-gui"; @@ -23,7 +24,11 @@ buildPythonPackage rec { buildInputs = lib.optional stdenv.hostPlatform.isLinux glib-networking; - nativeBuildInputs = [ wrapGAppsHook3 gobject-introspection glib-networking ]; + nativeBuildInputs = [ + wrapGAppsHook3 + gobject-introspection + glib-networking + ]; propagatedBuildInputs = [ requests diff --git a/pkgs/tools/networking/http-prompt/default.nix b/pkgs/tools/networking/http-prompt/default.nix index 9e3cf2a8b0bfa5..317f253dc69b6c 100644 --- a/pkgs/tools/networking/http-prompt/default.nix +++ b/pkgs/tools/networking/http-prompt/default.nix @@ -1,4 +1,9 @@ -{ lib, fetchFromGitHub, python3Packages, httpie }: +{ + lib, + fetchFromGitHub, + python3Packages, + httpie, +}: python3Packages.buildPythonApplication rec { pname = "http-prompt"; @@ -15,7 +20,7 @@ python3Packages.buildPythonApplication rec { click httpie parsimonious - (python.pkgs.callPackage ../../../development/python-modules/prompt-toolkit/1.nix {}) + (python.pkgs.callPackage ../../../development/python-modules/prompt-toolkit/1.nix { }) pygments six pyyaml diff --git a/pkgs/tools/networking/hue-cli/default.nix b/pkgs/tools/networking/hue-cli/default.nix index 76f7dc8e25c7a9..afb732a32e52d5 100644 --- a/pkgs/tools/networking/hue-cli/default.nix +++ b/pkgs/tools/networking/hue-cli/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "hue-cli"; @@ -9,10 +13,13 @@ bundlerApp { meta = with lib; { description = "Command line interface for controlling Philips Hue system's lights and bridge"; - homepage = "https://github.com/birkirb/hue-cli"; + homepage = "https://github.com/birkirb/hue-cli"; license = licenses.mit; platforms = platforms.unix; - maintainers = with maintainers; [ manveru nicknovitski ]; + maintainers = with maintainers; [ + manveru + nicknovitski + ]; mainProgram = "hue"; }; } diff --git a/pkgs/tools/networking/hue-cli/gemset.nix b/pkgs/tools/networking/hue-cli/gemset.nix index 08fd67c3885695..13dfba9bf57647 100644 --- a/pkgs/tools/networking/hue-cli/gemset.nix +++ b/pkgs/tools/networking/hue-cli/gemset.nix @@ -1,31 +1,34 @@ { hue-cli = { - dependencies = ["hue-lib" "json"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "hue-lib" + "json" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10gjf59pamfy2m17fs271d9ffrg1194b1m6vxzn6p7smzry52h9z"; type = "gem"; }; version = "0.1.4"; }; hue-lib = { - dependencies = ["json"]; - groups = ["default"]; - platforms = []; + dependencies = [ "json" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pyl8g8gisdhl79gbzvnddqrsbq0lmflzg7n6yi6xrp5b5290shz"; type = "gem"; }; version = "0.7.4"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sx97bm9by389rbzv8r1f43h06xcz8vwi3h5jv074gvparql7lcx"; type = "gem"; }; diff --git a/pkgs/tools/networking/ifwifi/default.nix b/pkgs/tools/networking/ifwifi/default.nix index 645000dffc73de..d39ab99ee69736 100644 --- a/pkgs/tools/networking/ifwifi/default.nix +++ b/pkgs/tools/networking/ifwifi/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, makeWrapper, networkmanager, iw, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + makeWrapper, + networkmanager, + iw, + Security, +}: rustPlatform.buildRustPackage rec { pname = "ifwifi"; @@ -18,13 +27,15 @@ rustPlatform.buildRustPackage rec { postInstall = '' wrapProgram "$out/bin/ifwifi" \ - --prefix PATH : "${lib.makeBinPath ( - # `ifwifi` runtime dep - [ networkmanager ] - # `wifiscanner` crate's runtime deps - ++ (lib.optional stdenv.hostPlatform.isLinux iw) - # ++ (lib.optional stdenv.hostPlatform.isDarwin airport) # airport isn't packaged - )}" + --prefix PATH : "${ + lib.makeBinPath ( + # `ifwifi` runtime dep + [ networkmanager ] + # `wifiscanner` crate's runtime deps + ++ (lib.optional stdenv.hostPlatform.isLinux iw) + # ++ (lib.optional stdenv.hostPlatform.isDarwin airport) # airport isn't packaged + ) + }" ''; doCheck = true; diff --git a/pkgs/tools/networking/innernet/default.nix b/pkgs/tools/networking/innernet/default.nix index 4627ef34367c28..8f1e74b12b8c5c 100644 --- a/pkgs/tools/networking/innernet/default.nix +++ b/pkgs/tools/networking/innernet/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, sqlite -, installShellFiles -, Security -, libiconv -, innernet -, testers +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + sqlite, + installShellFiles, + Security, + libiconv, + innernet, + testers, }: rustPlatform.buildRustPackage rec { @@ -28,26 +29,36 @@ rustPlatform.buildRustPackage rec { installShellFiles ]; - buildInputs = [ - sqlite - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - libiconv - ]; + buildInputs = + [ + sqlite + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + libiconv + ]; - postInstall = '' - installManPage doc/innernet-server.8.gz - installManPage doc/innernet.8.gz - installShellCompletion doc/innernet.completions.{bash,fish,zsh} - installShellCompletion doc/innernet-server.completions.{bash,fish,zsh} - '' + (lib.optionalString stdenv.hostPlatform.isLinux '' - find . -regex '.*\.\(target\|service\)' | xargs install -Dt $out/lib/systemd/system - find $out/lib/systemd/system -type f | xargs sed -i "s|/usr/bin/innernet|$out/bin/innernet|" - ''); + postInstall = + '' + installManPage doc/innernet-server.8.gz + installManPage doc/innernet.8.gz + installShellCompletion doc/innernet.completions.{bash,fish,zsh} + installShellCompletion doc/innernet-server.completions.{bash,fish,zsh} + '' + + (lib.optionalString stdenv.hostPlatform.isLinux '' + find . -regex '.*\.\(target\|service\)' | xargs install -Dt $out/lib/systemd/system + find $out/lib/systemd/system -type f | xargs sed -i "s|/usr/bin/innernet|$out/bin/innernet|" + ''); passthru.tests = { - serverVersion = testers.testVersion { package = innernet; command = "innernet-server --version"; }; - version = testers.testVersion { package = innernet; command = "innernet --version"; }; + serverVersion = testers.testVersion { + package = innernet; + command = "innernet-server --version"; + }; + version = testers.testVersion { + package = innernet; + command = "innernet --version"; + }; }; meta = with lib; { @@ -55,6 +66,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/tonarino/innernet"; changelog = "https://github.com/tonarino/innernet/releases/tag/v${version}"; license = licenses.mit; - maintainers = with maintainers; [ tomberek _0x4A6F ]; + maintainers = with maintainers; [ + tomberek + _0x4A6F + ]; }; } diff --git a/pkgs/tools/networking/iperf/2.nix b/pkgs/tools/networking/iperf/2.nix index 9831a4f4f7d176..109bf769e49989 100644 --- a/pkgs/tools/networking/iperf/2.nix +++ b/pkgs/tools/networking/iperf/2.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchurl }: +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "iperf"; diff --git a/pkgs/tools/networking/knock/package.nix b/pkgs/tools/networking/knock/package.nix index 064cd8eff67b5c..c7b591c7939d31 100644 --- a/pkgs/tools/networking/knock/package.nix +++ b/pkgs/tools/networking/knock/package.nix @@ -1,7 +1,8 @@ -{ lib -, buildGoModule -, fetchFromGitea -, installShellFiles +{ + lib, + buildGoModule, + fetchFromGitea, + installShellFiles, }: buildGoModule rec { @@ -11,14 +12,17 @@ buildGoModule rec { src = fetchFromGitea { domain = "codeberg.org"; owner = "nat-418"; - repo ="knock"; + repo = "knock"; rev = "v${version}"; hash = "sha256-K+L4F4bTERQSqISAmfyps/U5GJ2N0FdJ3RmpiUmt4uA="; }; vendorHash = "sha256-wkSXdIgfkHbVJYsgm/hLAeKA9geof92U3mzSzt7eJE8="; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; nativeBuildInputs = [ installShellFiles ]; diff --git a/pkgs/tools/networking/lldpd/default.nix b/pkgs/tools/networking/lldpd/default.nix index e627b12d7331ac..1b26c91285c6ce 100644 --- a/pkgs/tools/networking/lldpd/default.nix +++ b/pkgs/tools/networking/lldpd/default.nix @@ -1,13 +1,14 @@ -{ stdenv -, Foundation -, fetchurl -, lib -, libevent -, net-snmp -, openssl -, pkg-config -, readline -, removeReferencesTo +{ + stdenv, + Foundation, + fetchurl, + lib, + libevent, + net-snmp, + openssl, + pkg-config, + readline, + removeReferencesTo, }: stdenv.mkDerivation rec { @@ -19,25 +20,39 @@ stdenv.mkDerivation rec { hash = "sha256-SzIGddYIkBpKDU/v+PlruEbUkT2RSwz3W30K6ASQ8vc="; }; - configureFlags = [ - "--localstatedir=/var" - "--enable-pie" - "--with-snmp" - "--with-systemdsystemunitdir=\${out}/lib/systemd/system" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - "--with-launchddaemonsdir=no" - "--with-privsep-chroot=/var/empty" - "--with-privsep-group=nogroup" - "--with-privsep-user=nobody" - ]; + configureFlags = + [ + "--localstatedir=/var" + "--enable-pie" + "--with-snmp" + "--with-systemdsystemunitdir=\${out}/lib/systemd/system" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + "--with-launchddaemonsdir=no" + "--with-privsep-chroot=/var/empty" + "--with-privsep-group=nogroup" + "--with-privsep-user=nobody" + ]; - nativeBuildInputs = [ pkg-config removeReferencesTo ]; - buildInputs = [ libevent readline net-snmp openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Foundation ]; + nativeBuildInputs = [ + pkg-config + removeReferencesTo + ]; + buildInputs = [ + libevent + readline + net-snmp + openssl + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Foundation ]; enableParallelBuilding = true; - outputs = [ "out" "dev" "man" "doc" ]; + outputs = [ + "out" + "dev" + "man" + "doc" + ]; preFixup = '' find $out -type f -exec remove-references-to -t ${stdenv.cc} '{}' + diff --git a/pkgs/tools/networking/lychee/tests/fail-emptyDirectory.nix b/pkgs/tools/networking/lychee/tests/fail-emptyDirectory.nix index 9db4b23b1bc960..e59fc9852fa9f1 100644 --- a/pkgs/tools/networking/lychee/tests/fail-emptyDirectory.nix +++ b/pkgs/tools/networking/lychee/tests/fail-emptyDirectory.nix @@ -1,4 +1,8 @@ -{ runCommand, testers, emptyDirectory }: +{ + runCommand, + testers, + emptyDirectory, +}: let sitePkg = runCommand "site" { } '' dist=$out/dist @@ -19,10 +23,10 @@ let failure = testers.testBuildFailure check; in - runCommand "link-check-fail" { inherit failure; } '' - # The details of the message might change, but we have to make sure the - # correct error is reported, so that we know it's not something else that - # went wrong. - grep 'empty-directory/foo.*Cannot find file' $failure/testBuildFailure.log >/dev/null - touch $out - '' +runCommand "link-check-fail" { inherit failure; } '' + # The details of the message might change, but we have to make sure the + # correct error is reported, so that we know it's not something else that + # went wrong. + grep 'empty-directory/foo.*Cannot find file' $failure/testBuildFailure.log >/dev/null + touch $out +'' diff --git a/pkgs/tools/networking/lychee/tests/fail.nix b/pkgs/tools/networking/lychee/tests/fail.nix index 5a83814d3c4435..b1885834a4d97b 100644 --- a/pkgs/tools/networking/lychee/tests/fail.nix +++ b/pkgs/tools/networking/lychee/tests/fail.nix @@ -9,13 +9,15 @@ let linkCheck = testers.lycheeLinkCheck rec { site = sitePkg + "/dist"; - remap = { "https://exampl[e]\\.com" = site; }; + remap = { + "https://exampl[e]\\.com" = site; + }; }; failure = testers.testBuildFailure linkCheck; in - runCommand "link-check-fail" { inherit failure; } '' - grep -F foos-missing-anchor $failure/testBuildFailure.log >/dev/null - touch $out - '' +runCommand "link-check-fail" { inherit failure; } '' + grep -F foos-missing-anchor $failure/testBuildFailure.log >/dev/null + touch $out +'' diff --git a/pkgs/tools/networking/lychee/tests/network.nix b/pkgs/tools/networking/lychee/tests/network.nix index 8d7f908a580534..dcaebe7450d56d 100644 --- a/pkgs/tools/networking/lychee/tests/network.nix +++ b/pkgs/tools/networking/lychee/tests/network.nix @@ -1,4 +1,9 @@ -{ config, hostPkgs, lib, ... }: +{ + config, + hostPkgs, + lib, + ... +}: let sitePkg = hostPkgs.runCommand "site" { } '' dist=$out/dist diff --git a/pkgs/tools/networking/lychee/tests/ok.nix b/pkgs/tools/networking/lychee/tests/ok.nix index 6a6c0b9c87b49d..b93b93384ba112 100644 --- a/pkgs/tools/networking/lychee/tests/ok.nix +++ b/pkgs/tools/networking/lychee/tests/ok.nix @@ -6,7 +6,10 @@ let echo "foobar" > $dist/index.html echo "index" > $dist/foo.html ''; -in testers.lycheeLinkCheck rec { +in +testers.lycheeLinkCheck rec { site = sitePkg + "/dist"; - remap = { "https://example.com" = site; }; + remap = { + "https://example.com" = site; + }; } diff --git a/pkgs/tools/networking/mailutils/default.nix b/pkgs/tools/networking/mailutils/default.nix index c9979a0fee5fad..a816357d64a4be 100644 --- a/pkgs/tools/networking/mailutils/default.nix +++ b/pkgs/tools/networking/mailutils/default.nix @@ -1,32 +1,33 @@ -{ lib -, stdenv -, fetchurl -, fetchpatch -, autoreconfHook -, dejagnu -, gettext -, gnum4 -, pkg-config -, texinfo -, fribidi -, gdbm -, gnutls -, gss -, guile_2_2 -, libmysqlclient -, mailcap -, nettools -, pam -, readline -, ncurses -, python3 -, sasl -, system-sendmail -, libxcrypt -, mkpasswd - -, pythonSupport ? true -, guileSupport ? true +{ + lib, + stdenv, + fetchurl, + fetchpatch, + autoreconfHook, + dejagnu, + gettext, + gnum4, + pkg-config, + texinfo, + fribidi, + gdbm, + gnutls, + gss, + guile_2_2, + libmysqlclient, + mailcap, + nettools, + pam, + readline, + ncurses, + python3, + sasl, + system-sendmail, + libxcrypt, + mkpasswd, + + pythonSupport ? true, + guileSupport ? true, }: stdenv.mkDerivation rec { @@ -55,21 +56,23 @@ stdenv.mkDerivation rec { texinfo ]; - buildInputs = [ - fribidi - gdbm - gnutls - gss - libmysqlclient - mailcap - ncurses - pam - readline - sasl - libxcrypt - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ nettools ] - ++ lib.optionals pythonSupport [ python3 ] - ++ lib.optionals guileSupport [ guile_2_2 ]; + buildInputs = + [ + fribidi + gdbm + gnutls + gss + libmysqlclient + mailcap + ncurses + pam + readline + sasl + libxcrypt + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ nettools ] + ++ lib.optionals pythonSupport [ python3 ] + ++ lib.optionals guileSupport [ guile_2_2 ]; patches = [ ./fix-build-mb-len-max.patch @@ -88,18 +91,23 @@ stdenv.mkDerivation rec { enableParallelBuilding = true; hardeningDisable = [ "format" ]; - configureFlags = [ - "--sysconfdir=/etc" - "--with-gssapi" - "--with-gsasl" - "--with-mysql" - "--with-path-sendmail=${system-sendmail}/bin/sendmail" - "--with-mail-rc=/etc/mail.rc" - "DEFAULT_CUPS_CONFDIR=${mailcap}/etc" # provides mime.types to mimeview - ] ++ lib.optional (!pythonSupport) "--without-python" + configureFlags = + [ + "--sysconfdir=/etc" + "--with-gssapi" + "--with-gsasl" + "--with-mysql" + "--with-path-sendmail=${system-sendmail}/bin/sendmail" + "--with-mail-rc=/etc/mail.rc" + "DEFAULT_CUPS_CONFDIR=${mailcap}/etc" # provides mime.types to mimeview + ] + ++ lib.optional (!pythonSupport) "--without-python" ++ lib.optional (!guileSupport) "--without-guile"; - nativeCheckInputs = [ dejagnu mkpasswd ]; + nativeCheckInputs = [ + dejagnu + mkpasswd + ]; doCheck = !stdenv.hostPlatform.isDarwin; # ERROR: All 46 tests were run, 46 failed unexpectedly. doInstallCheck = false; # fails @@ -139,8 +147,8 @@ stdenv.mkDerivation rec { ''; license = with licenses; [ - lgpl3Plus /* libraries */ - gpl3Plus /* tools */ + lgpl3Plus # libraries + gpl3Plus # tools ]; maintainers = with maintainers; [ orivej ]; diff --git a/pkgs/tools/networking/maphosts/default.nix b/pkgs/tools/networking/maphosts/default.nix index 54819dd13827b4..4b9e75c311ee51 100644 --- a/pkgs/tools/networking/maphosts/default.nix +++ b/pkgs/tools/networking/maphosts/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, bundlerEnv, ruby, bundlerUpdateScript }: +{ + stdenv, + lib, + bundlerEnv, + ruby, + bundlerUpdateScript, +}: let env = bundlerEnv { @@ -6,7 +12,8 @@ let inherit ruby; gemdir = ./.; }; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "maphosts"; version = env.gems.maphosts.version; @@ -21,11 +28,14 @@ in stdenv.mkDerivation { meta = with lib; { description = "Small command line application for keeping your project hostnames in sync with /etc/hosts"; - homepage = "https://github.com/mpscholten/maphosts"; - changelog = "https://github.com/mpscholten/maphosts/releases/tag/v${version}"; - license = licenses.mit; - maintainers = with maintainers; [ mpscholten nicknovitski ]; - platforms = platforms.all; + homepage = "https://github.com/mpscholten/maphosts"; + changelog = "https://github.com/mpscholten/maphosts/releases/tag/v${version}"; + license = licenses.mit; + maintainers = with maintainers; [ + mpscholten + nicknovitski + ]; + platforms = platforms.all; mainProgram = "maphosts"; }; } diff --git a/pkgs/tools/networking/maphosts/gemset.nix b/pkgs/tools/networking/maphosts/gemset.nix index b50653bc96d668..c231724c82cc9a 100644 --- a/pkgs/tools/networking/maphosts/gemset.nix +++ b/pkgs/tools/networking/maphosts/gemset.nix @@ -1,7 +1,7 @@ { colorize = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1mmi9wr55gb84jfpyhpx975d2c8dhdsjjys88kc6f2r66brxmh23"; type = "gem"; }; @@ -9,7 +9,7 @@ }; hosts = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0s1mbn73ig5dy69dr8461574kq1ig6rdz89r1w5f8i7gvx9g9z9v"; type = "gem"; }; @@ -17,7 +17,7 @@ }; linebreak = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0362jhjhjcf0yr3k7bfqk4ai9yybm4985x7h1rwq4b7kvzk77pqj"; type = "gem"; }; @@ -25,7 +25,7 @@ }; maphosts = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bb7wa4vr3lkaywh4hvl74j2w5n52870zh4ypwl9cr43fdrj4nkw"; type = "gem"; }; diff --git a/pkgs/tools/networking/maubot/default.nix b/pkgs/tools/networking/maubot/default.nix index f2cdf39b5e5798..add134333a4601 100644 --- a/pkgs/tools/networking/maubot/default.nix +++ b/pkgs/tools/networking/maubot/default.nix @@ -1,11 +1,12 @@ -{ lib -, fetchPypi -, fetchpatch -, callPackage -, runCommand -, python3 -, encryptionSupport ? true -, sqliteSupport ? true +{ + lib, + fetchPypi, + fetchpatch, + callPackage, + runCommand, + python3, + encryptionSupport ? true, + sqliteSupport ? true, }: let @@ -52,33 +53,35 @@ let }) ]; - propagatedBuildInputs = with python.pkgs; [ - # requirements.txt - (mautrix.override { withOlm = encryptionSupport; }) - aiohttp - yarl - asyncpg - aiosqlite - commonmark - ruamel-yaml - attrs - bcrypt - packaging - click - colorama - questionary - jinja2 - setuptools - ] - # optional-requirements.txt - ++ lib.optionals encryptionSupport [ - python-olm - pycryptodome - unpaddedbase64 - ] - ++ lib.optionals sqliteSupport [ - sqlalchemy - ]; + propagatedBuildInputs = + with python.pkgs; + [ + # requirements.txt + (mautrix.override { withOlm = encryptionSupport; }) + aiohttp + yarl + asyncpg + aiosqlite + commonmark + ruamel-yaml + attrs + bcrypt + packaging + click + colorama + questionary + jinja2 + setuptools + ] + # optional-requirements.txt + ++ lib.optionals encryptionSupport [ + python-olm + pycryptodome + unpaddedbase64 + ] + ++ lib.optionals sqliteSupport [ + sqlalchemy + ]; # used for plugin tests propagatedNativeBuildInputs = with python.pkgs; [ @@ -97,34 +100,35 @@ let "maubot" ]; - passthru = let - wrapper = callPackage ./wrapper.nix { - unwrapped = maubot; - python3 = python; - }; - in - { - tests = { - simple = runCommand "${pname}-tests" { } '' - ${maubot}/bin/mbc --help > $out - ''; - }; + passthru = + let + wrapper = callPackage ./wrapper.nix { + unwrapped = maubot; + python3 = python; + }; + in + { + tests = { + simple = runCommand "${pname}-tests" { } '' + ${maubot}/bin/mbc --help > $out + ''; + }; - inherit python; + inherit python; - plugins = callPackage ./plugins { - maubot = maubot; - python3 = python; - }; + plugins = callPackage ./plugins { + maubot = maubot; + python3 = python; + }; - withPythonPackages = pythonPackages: wrapper { inherit pythonPackages; }; + withPythonPackages = pythonPackages: wrapper { inherit pythonPackages; }; - # This adds the plugins to lib/maubot-plugins - withPlugins = plugins: wrapper { inherit plugins; }; + # This adds the plugins to lib/maubot-plugins + withPlugins = plugins: wrapper { inherit plugins; }; - # This changes example-config.yaml in module directory - withBaseConfig = baseConfig: wrapper { inherit baseConfig; }; - }; + # This changes example-config.yaml in module directory + withBaseConfig = baseConfig: wrapper { inherit baseConfig; }; + }; meta = with lib; { description = "Plugin-based Matrix bot system written in Python"; diff --git a/pkgs/tools/networking/maubot/plugins/default.nix b/pkgs/tools/networking/maubot/plugins/default.nix index b60589b9df7e9a..e40154c989cafc 100644 --- a/pkgs/tools/networking/maubot/plugins/default.nix +++ b/pkgs/tools/networking/maubot/plugins/default.nix @@ -1,68 +1,90 @@ -{ lib -, fetchgit -, fetchFromGitHub -, fetchFromGitLab -, fetchFromGitea -, stdenvNoCC -, callPackage -, ensureNewerSourcesForZipFilesHook -, maubot -, python3 -, poetry -, formats +{ + lib, + fetchgit, + fetchFromGitHub, + fetchFromGitLab, + fetchFromGitea, + stdenvNoCC, + callPackage, + ensureNewerSourcesForZipFilesHook, + maubot, + python3, + poetry, + formats, }: let # pname: plugin id (example: xyz.maubot.echo) # version: plugin version # other attributes are passed directly to stdenv.mkDerivation (you at least need src) - buildMaubotPlugin = attrs@{ version, pname, base_config ? null, ... }: - stdenvNoCC.mkDerivation (builtins.removeAttrs attrs [ "base_config" ] // { - pluginName = "${pname}-v${version}.mbp"; - nativeBuildInputs = (attrs.nativeBuildInputs or [ ]) ++ [ - ensureNewerSourcesForZipFilesHook - maubot - ]; - buildPhase = '' - runHook preBuild + buildMaubotPlugin = + attrs@{ + version, + pname, + base_config ? null, + ... + }: + stdenvNoCC.mkDerivation ( + builtins.removeAttrs attrs [ "base_config" ] + // { + pluginName = "${pname}-v${version}.mbp"; + nativeBuildInputs = (attrs.nativeBuildInputs or [ ]) ++ [ + ensureNewerSourcesForZipFilesHook + maubot + ]; + buildPhase = '' + runHook preBuild - mbc build + mbc build - runHook postBuild - ''; + runHook postBuild + ''; - postPatch = lib.optionalString (base_config != null) '' - [ -e base-config.yaml ] || (echo "base-config.yaml doesn't exist, can't override it" && exit 1) - cp "${if builtins.isPath base_config || lib.isDerivation base_config then base_config - else if builtins.isString base_config then builtins.toFile "base-config.yaml" base_config - else (formats.yaml { }).generate "base-config.yaml" base_config}" base-config.yaml - '' + attrs.postPatch or ""; + postPatch = + lib.optionalString (base_config != null) '' + [ -e base-config.yaml ] || (echo "base-config.yaml doesn't exist, can't override it" && exit 1) + cp "${ + if builtins.isPath base_config || lib.isDerivation base_config then + base_config + else if builtins.isString base_config then + builtins.toFile "base-config.yaml" base_config + else + (formats.yaml { }).generate "base-config.yaml" base_config + }" base-config.yaml + '' + + attrs.postPatch or ""; - installPhase = '' - runHook preInstall + installPhase = '' + runHook preInstall - mkdir -p $out/lib/maubot-plugins - install -m 444 $pluginName $out/lib/maubot-plugins + mkdir -p $out/lib/maubot-plugins + install -m 444 $pluginName $out/lib/maubot-plugins - runHook postInstall - ''; - }); + runHook postInstall + ''; + } + ); generated = import ./generated.nix { - inherit lib fetchgit fetchFromGitHub fetchFromGitLab - fetchFromGitea python3 poetry buildMaubotPlugin; + inherit + lib + fetchgit + fetchFromGitHub + fetchFromGitLab + fetchFromGitea + python3 + poetry + buildMaubotPlugin + ; }; in -generated // { +generated +// { inherit buildMaubotPlugin; - allOfficialPlugins = - builtins.filter - (x: x.isOfficial && !x.meta.broken) - (builtins.attrValues generated); + allOfficialPlugins = builtins.filter (x: x.isOfficial && !x.meta.broken) ( + builtins.attrValues generated + ); - allPlugins = - builtins.filter - (x: !x.meta.broken) - (builtins.attrValues generated); + allPlugins = builtins.filter (x: !x.meta.broken) (builtins.attrValues generated); } diff --git a/pkgs/tools/networking/maubot/plugins/generated.nix b/pkgs/tools/networking/maubot/plugins/generated.nix index 1ac34284ab54fb..5008acdcc4b36e 100644 --- a/pkgs/tools/networking/maubot/plugins/generated.nix +++ b/pkgs/tools/networking/maubot/plugins/generated.nix @@ -1,74 +1,96 @@ -{ lib -, fetchgit -, fetchFromGitHub -, fetchFromGitLab -, fetchFromGitea -, python3 -, poetry -, buildMaubotPlugin +{ + lib, + fetchgit, + fetchFromGitHub, + fetchFromGitLab, + fetchFromGitea, + python3, + poetry, + buildMaubotPlugin, }: let json = builtins.fromJSON (builtins.readFile ./generated.json); in -lib.flip builtins.mapAttrs json (name: entry: -let - inherit (entry) manifest; +lib.flip builtins.mapAttrs json ( + name: entry: + let + inherit (entry) manifest; - resolveDeps = deps: map - (name: - let - packageName = builtins.head (builtins.match "([^~=<>@]*).*" name); - lower = lib.toLower packageName; - dash = builtins.replaceStrings ["_"] ["-"] packageName; - lowerDash = builtins.replaceStrings ["_"] ["-"] lower; - in - python3.pkgs.${packageName} - or python3.pkgs.${lower} - or python3.pkgs.${dash} - or python3.pkgs.${lowerDash} - or null) - (builtins.filter (x: x != "maubot" && x != null) deps); + resolveDeps = + deps: + map ( + name: + let + packageName = builtins.head (builtins.match "([^~=<>@]*).*" name); + lower = lib.toLower packageName; + dash = builtins.replaceStrings [ "_" ] [ "-" ] packageName; + lowerDash = builtins.replaceStrings [ "_" ] [ "-" ] lower; + in + python3.pkgs.${packageName} or python3.pkgs.${lower} or python3.pkgs.${dash} + or python3.pkgs.${lowerDash} or null + ) (builtins.filter (x: x != "maubot" && x != null) deps); - reqDeps = resolveDeps (lib.toList (manifest.dependencies or null)); - optDeps = resolveDeps (lib.toList (manifest.soft_dependencies or null)); -in + reqDeps = resolveDeps (lib.toList (manifest.dependencies or null)); + optDeps = resolveDeps (lib.toList (manifest.soft_dependencies or null)); + in -lib.makeOverridable buildMaubotPlugin (entry.attrs // { - pname = manifest.id; - inherit (manifest) version; + lib.makeOverridable buildMaubotPlugin ( + entry.attrs + // { + pname = manifest.id; + inherit (manifest) version; - src = - if entry?github then fetchFromGitHub entry.github - else if entry?git then fetchgit entry.git - else if entry?gitlab then fetchFromGitLab entry.gitlab - else if entry?gitea then fetchFromGitea entry.gitea - else throw "Invalid generated entry for ${manifest.id}: missing source"; + src = + if entry ? github then + fetchFromGitHub entry.github + else if entry ? git then + fetchgit entry.git + else if entry ? gitlab then + fetchFromGitLab entry.gitlab + else if entry ? gitea then + fetchFromGitea entry.gitea + else + throw "Invalid generated entry for ${manifest.id}: missing source"; - propagatedBuildInputs = builtins.filter (x: x != null) (reqDeps ++ optDeps); + propagatedBuildInputs = builtins.filter (x: x != null) (reqDeps ++ optDeps); - passthru.isOfficial = entry.isOfficial or false; + passthru.isOfficial = entry.isOfficial or false; - meta = entry.attrs.meta // { - license = - let - spdx = entry.attrs.meta.license or manifest.license or "unfree"; - spdxLicenses = builtins.listToAttrs - (map (x: lib.nameValuePair x.spdxId x) (builtins.filter (x: x?spdxId) (builtins.attrValues lib.licenses))); - in - spdxLicenses.${spdx}; - broken = builtins.any (x: x == null) reqDeps; - }; -} // lib.optionalAttrs (entry.isPoetry or false) { - nativeBuildInputs = [ - poetry - (python3.withPackages (p: with p; [ toml ruamel-yaml isort ])) - ]; + meta = entry.attrs.meta // { + license = + let + spdx = entry.attrs.meta.license or manifest.license or "unfree"; + spdxLicenses = builtins.listToAttrs ( + map (x: lib.nameValuePair x.spdxId x) ( + builtins.filter (x: x ? spdxId) (builtins.attrValues lib.licenses) + ) + ); + in + spdxLicenses.${spdx}; + broken = builtins.any (x: x == null) reqDeps; + }; + } + // lib.optionalAttrs (entry.isPoetry or false) { + nativeBuildInputs = [ + poetry + (python3.withPackages ( + p: with p; [ + toml + ruamel-yaml + isort + ] + )) + ]; - preBuild = lib.optionalString (entry?attrs.preBuild) (entry.attrs.preBuild + "\n") + '' - export HOME=$(mktemp -d) - [[ ! -d scripts ]] || patchShebangs --build scripts - make maubot.yaml - ''; -})) + preBuild = + lib.optionalString (entry ? attrs.preBuild) (entry.attrs.preBuild + "\n") + + '' + export HOME=$(mktemp -d) + [[ ! -d scripts ]] || patchShebangs --build scripts + make maubot.yaml + ''; + } + ) +) diff --git a/pkgs/tools/networking/maubot/wrapper.nix b/pkgs/tools/networking/maubot/wrapper.nix index b145e802a1058d..8a85905f9c0ac7 100644 --- a/pkgs/tools/networking/maubot/wrapper.nix +++ b/pkgs/tools/networking/maubot/wrapper.nix @@ -1,70 +1,89 @@ -{ lib -, symlinkJoin -, runCommand -, unwrapped -, python3 -, formats +{ + lib, + symlinkJoin, + runCommand, + unwrapped, + python3, + formats, }: -let wrapper = { pythonPackages ? (_: [ ]), plugins ? (_: [ ]), baseConfig ? null }: - let - plugins' = plugins unwrapped.plugins; - extraPythonPackages = builtins.concatLists (map (p: p.propagatedBuildInputs or [ ]) plugins'); - in - symlinkJoin { - name = "${unwrapped.pname}-with-plugins-${unwrapped.version}"; +let + wrapper = + { + pythonPackages ? (_: [ ]), + plugins ? (_: [ ]), + baseConfig ? null, + }: + let + plugins' = plugins unwrapped.plugins; + extraPythonPackages = builtins.concatLists (map (p: p.propagatedBuildInputs or [ ]) plugins'); + in + symlinkJoin { + name = "${unwrapped.pname}-with-plugins-${unwrapped.version}"; - inherit unwrapped; - paths = lib.optional (baseConfig != null) unwrapped ++ plugins'; - pythonPath = lib.optional (baseConfig == null) unwrapped ++ pythonPackages python3.pkgs ++ extraPythonPackages; + inherit unwrapped; + paths = lib.optional (baseConfig != null) unwrapped ++ plugins'; + pythonPath = + lib.optional (baseConfig == null) unwrapped ++ pythonPackages python3.pkgs ++ extraPythonPackages; - nativeBuildInputs = [ python3.pkgs.wrapPython ]; + nativeBuildInputs = [ python3.pkgs.wrapPython ]; - postBuild = '' - rm -f $out/nix-support/propagated-build-inputs - rmdir $out/nix-support || true - ${lib.optionalString (baseConfig != null) '' - rm $out/${python3.sitePackages}/maubot/example-config.yaml - substituteAll ${(formats.yaml { }).generate "example-config.yaml" (lib.recursiveUpdate baseConfig { - plugin_directories = lib.optionalAttrs (plugins' != []) { - load = [ "@out@/lib/maubot-plugins" ] ++ (baseConfig.plugin_directories.load or []); - }; - # Normally it should be set to false by default to take it from package - # root, but aiohttp doesn't follow symlinks when serving static files - # unless follow_symlinks=True is passed. Instead of patching maubot, use - # this non-invasive approach - # XXX: would patching maubot be better? See: - # https://github.com/maubot/maubot/blob/75879cfb9370aade6fa0e84e1dde47222625139a/maubot/server.py#L106 - server.override_resource_path = - if builtins.isNull (baseConfig.server.override_resource_path or null) - then "${unwrapped}/${python3.sitePackages}/maubot/management/frontend/build" - else baseConfig.server.override_resource_path; - })} $out/${python3.sitePackages}/maubot/example-config.yaml - rm -rf $out/bin - ''} - mkdir -p $out/bin - cp $unwrapped/bin/.mbc-wrapped $out/bin/mbc - cp $unwrapped/bin/.maubot-wrapped $out/bin/maubot - wrapPythonProgramsIn "$out/bin" "${lib.optionalString (baseConfig != null) "$out "}$pythonPath" - ''; + postBuild = '' + rm -f $out/nix-support/propagated-build-inputs + rmdir $out/nix-support || true + ${lib.optionalString (baseConfig != null) '' + rm $out/${python3.sitePackages}/maubot/example-config.yaml + substituteAll ${ + (formats.yaml { }).generate "example-config.yaml" ( + lib.recursiveUpdate baseConfig { + plugin_directories = lib.optionalAttrs (plugins' != [ ]) { + load = [ "@out@/lib/maubot-plugins" ] ++ (baseConfig.plugin_directories.load or [ ]); + }; + # Normally it should be set to false by default to take it from package + # root, but aiohttp doesn't follow symlinks when serving static files + # unless follow_symlinks=True is passed. Instead of patching maubot, use + # this non-invasive approach + # XXX: would patching maubot be better? See: + # https://github.com/maubot/maubot/blob/75879cfb9370aade6fa0e84e1dde47222625139a/maubot/server.py#L106 + server.override_resource_path = + if builtins.isNull (baseConfig.server.override_resource_path or null) then + "${unwrapped}/${python3.sitePackages}/maubot/management/frontend/build" + else + baseConfig.server.override_resource_path; + } + ) + } $out/${python3.sitePackages}/maubot/example-config.yaml + rm -rf $out/bin + ''} + mkdir -p $out/bin + cp $unwrapped/bin/.mbc-wrapped $out/bin/mbc + cp $unwrapped/bin/.maubot-wrapped $out/bin/maubot + wrapPythonProgramsIn "$out/bin" "${lib.optionalString (baseConfig != null) "$out "}$pythonPath" + ''; - passthru = { - inherit unwrapped; - python = python3; - withPythonPackages = filter: wrapper { - pythonPackages = pkgs: pythonPackages pkgs ++ filter pkgs; - inherit plugins baseConfig; - }; - withPlugins = filter: wrapper { - plugins = pkgs: plugins pkgs ++ filter pkgs; - inherit pythonPackages baseConfig; - }; - withBaseConfig = baseConfig: wrapper { - inherit baseConfig pythonPackages plugins; + passthru = { + inherit unwrapped; + python = python3; + withPythonPackages = + filter: + wrapper { + pythonPackages = pkgs: pythonPackages pkgs ++ filter pkgs; + inherit plugins baseConfig; + }; + withPlugins = + filter: + wrapper { + plugins = pkgs: plugins pkgs ++ filter pkgs; + inherit pythonPackages baseConfig; + }; + withBaseConfig = + baseConfig: + wrapper { + inherit baseConfig pythonPackages plugins; + }; }; - }; - meta.priority = (unwrapped.meta.priority or lib.meta.defaultPriority) - 1; - }; + meta.priority = (unwrapped.meta.priority or lib.meta.defaultPriority) - 1; + }; in wrapper diff --git a/pkgs/tools/networking/miniupnpd/default.nix b/pkgs/tools/networking/miniupnpd/default.nix index ddaee847c44f67..fea5ea98d20017 100644 --- a/pkgs/tools/networking/miniupnpd/default.nix +++ b/pkgs/tools/networking/miniupnpd/default.nix @@ -1,30 +1,49 @@ -{ stdenv, lib, fetchurl, iptables-legacy, libuuid, openssl, pkg-config -, which, iproute2, gnused, coreutils, gnugrep, gawk, makeWrapper -, nixosTests -, firewall ? "iptables", nftables, libmnl, libnftnl +{ + stdenv, + lib, + fetchurl, + iptables-legacy, + libuuid, + openssl, + pkg-config, + which, + iproute2, + gnused, + coreutils, + gnugrep, + gawk, + makeWrapper, + nixosTests, + firewall ? "iptables", + nftables, + libmnl, + libnftnl, }: let - scriptBinEnv = lib.makeBinPath { - iptables = [ - # needed for dirname in ip{,6}tables_*.sh - coreutils - # used in miniupnpd_functions.sh: - which - iproute2 - iptables-legacy - gnused - gnugrep - gawk - ]; - nftables = [ - # needed for dirname in nft_*.sh & cat in nft_init.sh - coreutils - # used in miniupnpd_functions.sh: - which - nftables - ]; - }.${firewall}; + scriptBinEnv = + lib.makeBinPath + { + iptables = [ + # needed for dirname in ip{,6}tables_*.sh + coreutils + # used in miniupnpd_functions.sh: + which + iproute2 + iptables-legacy + gnused + gnugrep + gawk + ]; + nftables = [ + # needed for dirname in nft_*.sh & cat in nft_init.sh + coreutils + # used in miniupnpd_functions.sh: + which + nftables + ]; + } + .${firewall}; in stdenv.mkDerivation rec { pname = "miniupnpd"; @@ -35,9 +54,20 @@ stdenv.mkDerivation rec { sha256 = "sha256-+91VAQOXMPBKhCDqL49Ut99j+fBM3i3Gf6c3HoBHe74="; }; - buildInputs = [ iptables-legacy libuuid openssl ] - ++ lib.optionals (firewall == "nftables") [ libmnl libnftnl ]; - nativeBuildInputs= [ pkg-config makeWrapper ]; + buildInputs = + [ + iptables-legacy + libuuid + openssl + ] + ++ lib.optionals (firewall == "nftables") [ + libmnl + libnftnl + ]; + nativeBuildInputs = [ + pkg-config + makeWrapper + ]; # ./configure is not a standard configure file, errors with: # Option not recognized : --prefix= @@ -53,24 +83,29 @@ stdenv.mkDerivation rec { "--portinuse" ]; - installFlags = [ "PREFIX=$(out)" "INSTALLPREFIX=$(out)" ]; + installFlags = [ + "PREFIX=$(out)" + "INSTALLPREFIX=$(out)" + ]; - postFixup = { - # Ideally we'd prefer using system's config.firewall.package here for iptables, - # however for some reason switching --prefix to --suffix breaks the script - iptables = '' - for script in $out/etc/miniupnpd/ip{,6}tables_{init,removeall}.sh - do - wrapProgram $script --prefix PATH : '${scriptBinEnv}:$PATH' - done - ''; - nftables = '' - for script in $out/etc/miniupnpd/nft_{delete_chain,flush,init,removeall}.sh - do - wrapProgram $script --suffix PATH : '${scriptBinEnv}:$PATH' - done - ''; - }.${firewall}; + postFixup = + { + # Ideally we'd prefer using system's config.firewall.package here for iptables, + # however for some reason switching --prefix to --suffix breaks the script + iptables = '' + for script in $out/etc/miniupnpd/ip{,6}tables_{init,removeall}.sh + do + wrapProgram $script --prefix PATH : '${scriptBinEnv}:$PATH' + done + ''; + nftables = '' + for script in $out/etc/miniupnpd/nft_{delete_chain,flush,init,removeall}.sh + do + wrapProgram $script --suffix PATH : '${scriptBinEnv}:$PATH' + done + ''; + } + .${firewall}; passthru.tests = { bittorrent-integration = nixosTests.bittorrent; diff --git a/pkgs/tools/networking/mozwire/default.nix b/pkgs/tools/networking/mozwire/default.nix index 800ea3c48f14e4..65887a39bac2ee 100644 --- a/pkgs/tools/networking/mozwire/default.nix +++ b/pkgs/tools/networking/mozwire/default.nix @@ -1,9 +1,10 @@ -{ rustPlatform -, lib -, stdenv -, fetchFromGitHub -, CoreServices -, Security +{ + rustPlatform, + lib, + stdenv, + fetchFromGitHub, + CoreServices, + Security, }: rustPlatform.buildRustPackage rec { @@ -28,7 +29,10 @@ rustPlatform.buildRustPackage rec { description = "MozillaVPN configuration manager giving Linux, macOS users (among others), access to MozillaVPN"; homepage = "https://github.com/NilsIrl/MozWire"; license = licenses.gpl3; - maintainers = with maintainers; [ siraben nilsirl ]; + maintainers = with maintainers; [ + siraben + nilsirl + ]; mainProgram = "mozwire"; }; } diff --git a/pkgs/tools/networking/mtr/default.nix b/pkgs/tools/networking/mtr/default.nix index 42b79f978fdfc1..c3fc477f1c2da5 100644 --- a/pkgs/tools/networking/mtr/default.nix +++ b/pkgs/tools/networking/mtr/default.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, autoreconfHook -, pkg-config -, libcap -, ncurses -, jansson -, withGtk ? false -, gtk3 +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + autoreconfHook, + pkg-config, + libcap, + ncurses, + jansson, + withGtk ? false, + gtk3, }: stdenv.mkDerivation rec { @@ -22,10 +23,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-f5bL3IdXibIc1xXCuZHwcEV5vhypRE2mLsS3A8HW2QM="; }; - patches = [ (fetchpatch { # https://github.com/traviscross/mtr/pull/468 - url = "https://github.com/traviscross/mtr/commit/5908af4c19188cb17b62f23368b6ef462831a0cb.patch"; - hash = "sha256-rTydtU8+Wc4nGEKh1GOkhcpgME4hwsACy82gKPaIe64="; - }) ]; + patches = [ + (fetchpatch { + # https://github.com/traviscross/mtr/pull/468 + url = "https://github.com/traviscross/mtr/commit/5908af4c19188cb17b62f23368b6ef462831a0cb.patch"; + hash = "sha256-rTydtU8+Wc4nGEKh1GOkhcpgME4hwsACy82gKPaIe64="; + }) + ]; # we need this before autoreconfHook does its thing postPatch = '' @@ -40,9 +44,16 @@ stdenv.mkDerivation rec { configureFlags = lib.optional (!withGtk) "--without-gtk"; - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; - buildInputs = [ ncurses jansson ] + buildInputs = + [ + ncurses + jansson + ] ++ lib.optional withGtk gtk3 ++ lib.optional stdenv.hostPlatform.isLinux libcap; @@ -52,7 +63,12 @@ stdenv.mkDerivation rec { description = "Network diagnostics tool"; homepage = "https://www.bitwizard.nl/mtr/"; license = licenses.gpl2Only; - maintainers = with maintainers; [ koral orivej raskin globin ]; + maintainers = with maintainers; [ + koral + orivej + raskin + globin + ]; mainProgram = "mtr"; platforms = platforms.unix; }; diff --git a/pkgs/tools/networking/namespaced-openvpn/default.nix b/pkgs/tools/networking/namespaced-openvpn/default.nix index 3a879b330a8ba5..ec48d87230492d 100644 --- a/pkgs/tools/networking/namespaced-openvpn/default.nix +++ b/pkgs/tools/networking/namespaced-openvpn/default.nix @@ -1,10 +1,11 @@ -{ lib, +{ + lib, fetchFromGitHub, buildPythonPackage, openvpn, iproute2, iptables, - util-linux + util-linux, }: buildPythonPackage rec { @@ -19,7 +20,11 @@ buildPythonPackage rec { sha256 = "+Fdaw9EGyFGH9/DSeVJczS8gPzAOv+qn+1U20zQBBqQ="; }; - buildInputs = [ openvpn iproute2 util-linux ]; + buildInputs = [ + openvpn + iproute2 + util-linux + ]; postPatch = '' substituteInPlace namespaced-openvpn \ diff --git a/pkgs/tools/networking/nettee/default.nix b/pkgs/tools/networking/nettee/default.nix index 74b1f317e20467..ccdc96cd3c428a 100644 --- a/pkgs/tools/networking/nettee/default.nix +++ b/pkgs/tools/networking/nettee/default.nix @@ -1,10 +1,16 @@ -{ stdenv, lib, fetchurl, cleanPackaging }: +{ + stdenv, + lib, + fetchurl, + cleanPackaging, +}: let version = "0.3.4"; sha256 = "00xbkp99x9v07r34w7m2p8gak5hdsdbka36n7a733rdrrkgf5z7r"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { pname = "nettee"; inherit version; @@ -22,7 +28,12 @@ in stdenv.mkDerivation { mainProgram = "nettee"; }; - outputs = [ "bin" "man" "doc" "out" ]; + outputs = [ + "bin" + "man" + "doc" + "out" + ]; patchPhase = '' # h_addr field was removed @@ -40,7 +51,8 @@ in stdenv.mkDerivation { ''; installPhase = '' - ${cleanPackaging.commonFileActions { + ${ + cleanPackaging.commonFileActions { docFiles = [ "*.html" "*.TXT" @@ -55,7 +67,8 @@ in stdenv.mkDerivation { "*.h" "nettee" ]; - }} $doc/share/doc/nettee + } + } $doc/share/doc/nettee mkdir -p $man/share/man/{man1,man3} mv nettee.1 $man/share/man/man1 diff --git a/pkgs/tools/networking/networkd-notify/default.nix b/pkgs/tools/networking/networkd-notify/default.nix index 6671983e1e7d10..316ef60a5672ac 100644 --- a/pkgs/tools/networking/networkd-notify/default.nix +++ b/pkgs/tools/networking/networkd-notify/default.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitLab -, buildPythonApplication -, dbus-python -, pygobject3 -, systemd -, wirelesstools -, wrapGAppsNoGuiHook +{ + lib, + fetchFromGitLab, + buildPythonApplication, + dbus-python, + pygobject3, + systemd, + wirelesstools, + wrapGAppsNoGuiHook, }: buildPythonApplication rec { diff --git a/pkgs/tools/networking/networkmanager/libnma/default.nix b/pkgs/tools/networking/networkmanager/libnma/default.nix index a47b23e9634c28..84331343c09a4e 100644 --- a/pkgs/tools/networking/networkmanager/libnma/default.nix +++ b/pkgs/tools/networking/networkmanager/libnma/default.nix @@ -1,36 +1,41 @@ -{ stdenv -, fetchurl -, meson -, mesonEmulatorHook -, ninja -, gettext -, gtk-doc -, pkg-config -, vala -, networkmanager -, gnome -, isocodes -, libxml2 -, docbook_xsl -, docbook_xml_dtd_43 -, mobile-broadband-provider-info -, gobject-introspection -, gtk3 -, withGtk4 ? false -, gtk4 -, withGnome ? true -, gcr_4 -, glib -, lib -, _experimental-update-script-combinators -, makeHardcodeGsettingsPatch +{ + stdenv, + fetchurl, + meson, + mesonEmulatorHook, + ninja, + gettext, + gtk-doc, + pkg-config, + vala, + networkmanager, + gnome, + isocodes, + libxml2, + docbook_xsl, + docbook_xml_dtd_43, + mobile-broadband-provider-info, + gobject-introspection, + gtk3, + withGtk4 ? false, + gtk4, + withGnome ? true, + gcr_4, + glib, + lib, + _experimental-update-script-combinators, + makeHardcodeGsettingsPatch, }: stdenv.mkDerivation rec { pname = "libnma"; version = "1.10.6"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchurl { url = "mirror://gnome/sources/${pname}/${lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; @@ -42,32 +47,37 @@ stdenv.mkDerivation rec { ./hardcode-gsettings.patch ]; - nativeBuildInputs = [ - meson - ninja - gettext - pkg-config - gobject-introspection - gtk-doc - docbook_xsl - docbook_xml_dtd_43 - libxml2 - vala - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ - mesonEmulatorHook - ]; + nativeBuildInputs = + [ + meson + ninja + gettext + pkg-config + gobject-introspection + gtk-doc + docbook_xsl + docbook_xml_dtd_43 + libxml2 + vala + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) [ + mesonEmulatorHook + ]; - buildInputs = [ - gtk3 - networkmanager - isocodes - mobile-broadband-provider-info - ] ++ lib.optionals withGtk4 [ - gtk4 - ] ++ lib.optionals withGnome [ - # advanced certificate chooser - gcr_4 - ]; + buildInputs = + [ + gtk3 + networkmanager + isocodes + mobile-broadband-provider-info + ] + ++ lib.optionals withGtk4 [ + gtk4 + ] + ++ lib.optionals withGnome [ + # advanced certificate chooser + gcr_4 + ]; mesonFlags = [ "-Dgcr=${lib.boolToString withGnome}" diff --git a/pkgs/tools/networking/networkmanager/tray.nix b/pkgs/tools/networking/networkmanager/tray.nix index 01725b1fb381b7..1e1882c35cf903 100644 --- a/pkgs/tools/networking/networkmanager/tray.nix +++ b/pkgs/tools/networking/networkmanager/tray.nix @@ -1,4 +1,14 @@ -{ lib, mkDerivation, fetchFromGitHub, cmake, pkg-config, qttools, qtbase, networkmanager-qt, modemmanager-qt }: +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + pkg-config, + qttools, + qtbase, + networkmanager-qt, + modemmanager-qt, +}: mkDerivation rec { pname = "nm-tray"; @@ -15,11 +25,19 @@ mkDerivation rec { sed -i -e '1i#include ' src/nmmodel.cpp ''; - nativeBuildInputs = [ cmake pkg-config qttools ]; + nativeBuildInputs = [ + cmake + pkg-config + qttools + ]; cmakeFlags = [ "-DWITH_MODEMMANAGER_SUPPORT=ON" ]; - buildInputs = [ qtbase networkmanager-qt modemmanager-qt ]; + buildInputs = [ + qtbase + networkmanager-qt + modemmanager-qt + ]; meta = with lib; { description = "Simple Network Manager frontend written in Qt"; diff --git a/pkgs/tools/networking/nxdomain/default.nix b/pkgs/tools/networking/nxdomain/default.nix index 071f236bfe5f88..8c5c5897296ea3 100644 --- a/pkgs/tools/networking/nxdomain/default.nix +++ b/pkgs/tools/networking/nxdomain/default.nix @@ -1,4 +1,10 @@ -{ lib, buildPythonApplication, fetchPypi, dnspython, pytestCheckHook }: +{ + lib, + buildPythonApplication, + fetchPypi, + dnspython, + pytestCheckHook, +}: buildPythonApplication rec { pname = "nxdomain"; diff --git a/pkgs/tools/networking/ockam/default.nix b/pkgs/tools/networking/ockam/default.nix index 2eaf4dafd2d804..c03b1006e20b4a 100644 --- a/pkgs/tools/networking/ockam/default.nix +++ b/pkgs/tools/networking/ockam/default.nix @@ -1,14 +1,15 @@ -{ stdenv -, lib -, fetchFromGitHub -, rustPlatform -, git -, nix-update-script -, pkg-config -, openssl -, dbus -, AppKit -, Security +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + git, + nix-update-script, + pkg-config, + openssl, + dbus, + AppKit, + Security, }: let @@ -26,9 +27,19 @@ rustPlatform.buildRustPackage { }; cargoHash = "sha256-gAl2es8UFVFv40sMY++SiDGjCMdL0XDN4PeSV7VlGmQ="; - nativeBuildInputs = [ git pkg-config ]; - buildInputs = [ openssl dbus ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ AppKit Security ]; + nativeBuildInputs = [ + git + pkg-config + ]; + buildInputs = + [ + openssl + dbus + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + Security + ]; passthru.updateScript = nix-update-script { }; diff --git a/pkgs/tools/networking/octodns/providers/bind/default.nix b/pkgs/tools/networking/octodns/providers/bind/default.nix index dfecb36a627872..6d9ddd5afdc676 100644 --- a/pkgs/tools/networking/octodns/providers/bind/default.nix +++ b/pkgs/tools/networking/octodns/providers/bind/default.nix @@ -1,11 +1,12 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, octodns -, pytestCheckHook -, pythonOlder -, dnspython -, setuptools +{ + lib, + buildPythonPackage, + fetchFromGitHub, + octodns, + pytestCheckHook, + pythonOlder, + dnspython, + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/tools/networking/octodns/providers/gandi/default.nix b/pkgs/tools/networking/octodns/providers/gandi/default.nix index 69edc77c075489..bfb0924cd4ab24 100644 --- a/pkgs/tools/networking/octodns/providers/gandi/default.nix +++ b/pkgs/tools/networking/octodns/providers/gandi/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, octodns -, pytestCheckHook -, pythonOlder -, requests -, requests-mock -, setuptools +{ + lib, + buildPythonPackage, + fetchFromGitHub, + octodns, + pytestCheckHook, + pythonOlder, + requests, + requests-mock, + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/tools/networking/octodns/providers/hetzner/default.nix b/pkgs/tools/networking/octodns/providers/hetzner/default.nix index 830678391d707c..e33451922fef0a 100644 --- a/pkgs/tools/networking/octodns/providers/hetzner/default.nix +++ b/pkgs/tools/networking/octodns/providers/hetzner/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, octodns -, pytestCheckHook -, pythonOlder -, requests -, requests-mock -, setuptools +{ + lib, + buildPythonPackage, + fetchFromGitHub, + octodns, + pytestCheckHook, + pythonOlder, + requests, + requests-mock, + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/tools/networking/octodns/providers/powerdns/default.nix b/pkgs/tools/networking/octodns/providers/powerdns/default.nix index 8278e6ea853718..af1d5b2c81b57f 100644 --- a/pkgs/tools/networking/octodns/providers/powerdns/default.nix +++ b/pkgs/tools/networking/octodns/providers/powerdns/default.nix @@ -1,12 +1,13 @@ -{ lib -, buildPythonPackage -, fetchFromGitHub -, octodns -, pytestCheckHook -, pythonOlder -, requests -, requests-mock -, setuptools +{ + lib, + buildPythonPackage, + fetchFromGitHub, + octodns, + pytestCheckHook, + pythonOlder, + requests, + requests-mock, + setuptools, }: buildPythonPackage rec { diff --git a/pkgs/tools/networking/openapi-generator-cli/default.nix b/pkgs/tools/networking/openapi-generator-cli/default.nix index e8a25490c284ea..6993dd519eb3cf 100644 --- a/pkgs/tools/networking/openapi-generator-cli/default.nix +++ b/pkgs/tools/networking/openapi-generator-cli/default.nix @@ -1,45 +1,54 @@ -{ callPackage, lib, stdenv, fetchurl, jre, makeWrapper }: - -let this = stdenv.mkDerivation (finalAttrs: { - version = "7.10.0"; - pname = "openapi-generator-cli"; - - jarfilename = "openapi-generator-cli-${finalAttrs.version}.jar"; - - nativeBuildInputs = [ - makeWrapper - ]; - - src = fetchurl { - url = "mirror://maven/org/openapitools/openapi-generator-cli/${finalAttrs.version}/${finalAttrs.jarfilename}"; - sha256 = "sha256-YV4BRwWvNIYeeJ4LKhEHXTyA2xNPiB6TcmVHmkqDmW4="; - }; - - dontUnpack = true; - - installPhase = '' - runHook preInstall - - install -D "$src" "$out/share/java/${finalAttrs.jarfilename}" - - makeWrapper ${jre}/bin/java $out/bin/${finalAttrs.pname} \ - --add-flags "-jar $out/share/java/${finalAttrs.jarfilename}" - - runHook postInstall - ''; - - meta = with lib; { - description = "Allows generation of API client libraries (SDK generation), server stubs and documentation automatically given an OpenAPI Spec"; - homepage = "https://github.com/OpenAPITools/openapi-generator"; - changelog = "https://github.com/OpenAPITools/openapi-generator/releases/tag/v${finalAttrs.version}"; - sourceProvenance = with sourceTypes; [ binaryBytecode ]; - license = licenses.asl20; - maintainers = with maintainers; [ shou ]; - mainProgram = "openapi-generator-cli"; - }; - - passthru.tests.example = callPackage ./example.nix { - openapi-generator-cli = this; - }; -}); -in this +{ + callPackage, + lib, + stdenv, + fetchurl, + jre, + makeWrapper, +}: + +let + this = stdenv.mkDerivation (finalAttrs: { + version = "7.10.0"; + pname = "openapi-generator-cli"; + + jarfilename = "openapi-generator-cli-${finalAttrs.version}.jar"; + + nativeBuildInputs = [ + makeWrapper + ]; + + src = fetchurl { + url = "mirror://maven/org/openapitools/openapi-generator-cli/${finalAttrs.version}/${finalAttrs.jarfilename}"; + sha256 = "sha256-YV4BRwWvNIYeeJ4LKhEHXTyA2xNPiB6TcmVHmkqDmW4="; + }; + + dontUnpack = true; + + installPhase = '' + runHook preInstall + + install -D "$src" "$out/share/java/${finalAttrs.jarfilename}" + + makeWrapper ${jre}/bin/java $out/bin/${finalAttrs.pname} \ + --add-flags "-jar $out/share/java/${finalAttrs.jarfilename}" + + runHook postInstall + ''; + + meta = with lib; { + description = "Allows generation of API client libraries (SDK generation), server stubs and documentation automatically given an OpenAPI Spec"; + homepage = "https://github.com/OpenAPITools/openapi-generator"; + changelog = "https://github.com/OpenAPITools/openapi-generator/releases/tag/v${finalAttrs.version}"; + sourceProvenance = with sourceTypes; [ binaryBytecode ]; + license = licenses.asl20; + maintainers = with maintainers; [ shou ]; + mainProgram = "openapi-generator-cli"; + }; + + passthru.tests.example = callPackage ./example.nix { + openapi-generator-cli = this; + }; + }); +in +this diff --git a/pkgs/tools/networking/openapi-generator-cli/example.nix b/pkgs/tools/networking/openapi-generator-cli/example.nix index 047c02a9a912a2..fd30077713c640 100644 --- a/pkgs/tools/networking/openapi-generator-cli/example.nix +++ b/pkgs/tools/networking/openapi-generator-cli/example.nix @@ -1,31 +1,37 @@ -{ openapi-generator-cli, fetchurl, runCommand }: +{ + openapi-generator-cli, + fetchurl, + runCommand, +}: -runCommand "openapi-generator-cli-test" { - nativeBuildInputs = [ openapi-generator-cli ]; - petstore = fetchurl { - url = "https://raw.githubusercontent.com/OAI/OpenAPI-Specification/14c0908becbccd78252be49bd92be8c53cd2b9e3/examples/v3.0/petstore.yaml"; - hash = "sha256-q2D1naR41KwxLNn6vMbL0G+Pl1q4oaDCApsqQfZf7dU="; - }; - config = builtins.toJSON { - elmVersion = "0.19"; - elmPrefixCustomTypeVariants = false; - }; - passAsFile = [ "config" ]; -} '' - openapi-generator-cli generate \ - --input-spec $petstore \ - --enable-post-process-file \ - --generator-name elm \ - --config "$config" \ - --additional-properties elmEnableCustomBasePaths=true \ - --output "$out" \ - ; - find $out - echo >&2 'Looking for some keywords' - set -x - grep 'module Api.Request.Pets' $out/src/Api/Request/Pets.elm - grep 'createPets' $out/src/Api/Request/Pets.elm - grep '"limit"' $out/src/Api/Request/Pets.elm - set +x - echo "Looks OK!" -'' +runCommand "openapi-generator-cli-test" + { + nativeBuildInputs = [ openapi-generator-cli ]; + petstore = fetchurl { + url = "https://raw.githubusercontent.com/OAI/OpenAPI-Specification/14c0908becbccd78252be49bd92be8c53cd2b9e3/examples/v3.0/petstore.yaml"; + hash = "sha256-q2D1naR41KwxLNn6vMbL0G+Pl1q4oaDCApsqQfZf7dU="; + }; + config = builtins.toJSON { + elmVersion = "0.19"; + elmPrefixCustomTypeVariants = false; + }; + passAsFile = [ "config" ]; + } + '' + openapi-generator-cli generate \ + --input-spec $petstore \ + --enable-post-process-file \ + --generator-name elm \ + --config "$config" \ + --additional-properties elmEnableCustomBasePaths=true \ + --output "$out" \ + ; + find $out + echo >&2 'Looking for some keywords' + set -x + grep 'module Api.Request.Pets' $out/src/Api/Request/Pets.elm + grep 'createPets' $out/src/Api/Request/Pets.elm + grep '"limit"' $out/src/Api/Request/Pets.elm + set +x + echo "Looks OK!" + '' diff --git a/pkgs/tools/networking/openconnect/common.nix b/pkgs/tools/networking/openconnect/common.nix index 82040f64a8977e..1c432ee7493d30 100644 --- a/pkgs/tools/networking/openconnect/common.nix +++ b/pkgs/tools/networking/openconnect/common.nix @@ -1,31 +1,37 @@ -{ version -, src +{ + version, + src, }: -{ lib -, stdenv -, pkg-config -, gnutls -, p11-kit -, openssl -, useOpenSSL ? false -, gmp -, libxml2 -, stoken -, zlib -, pcsclite -, vpnc-scripts -, PCSC -, useDefaultExternalBrowser ? stdenv.hostPlatform.isLinux && stdenv.buildPlatform == stdenv.hostPlatform # xdg-utils doesn't cross-compile -, xdg-utils -, autoreconfHook +{ + lib, + stdenv, + pkg-config, + gnutls, + p11-kit, + openssl, + useOpenSSL ? false, + gmp, + libxml2, + stoken, + zlib, + pcsclite, + vpnc-scripts, + PCSC, + useDefaultExternalBrowser ? + stdenv.hostPlatform.isLinux && stdenv.buildPlatform == stdenv.hostPlatform, # xdg-utils doesn't cross-compile + xdg-utils, + autoreconfHook, }: stdenv.mkDerivation { pname = "openconnect"; inherit version src; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; configureFlags = [ "--with-vpnc-script=${vpnc-scripts}/bin/vpnc-script" @@ -33,17 +39,34 @@ stdenv.mkDerivation { "--without-openssl-version-check" ]; - buildInputs = [ gmp libxml2 stoken zlib (if useOpenSSL then openssl else gnutls) ] + buildInputs = + [ + gmp + libxml2 + stoken + zlib + (if useOpenSSL then openssl else gnutls) + ] ++ lib.optional stdenv.hostPlatform.isDarwin PCSC - ++ lib.optionals stdenv.hostPlatform.isLinux [ p11-kit pcsclite ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + p11-kit + pcsclite + ] ++ lib.optional useDefaultExternalBrowser xdg-utils; - nativeBuildInputs = [ pkg-config autoreconfHook ]; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; meta = with lib; { description = "VPN Client for Cisco's AnyConnect SSL VPN"; homepage = "https://www.infradead.org/openconnect/"; license = licenses.lgpl21Only; - maintainers = with maintainers; [ pradeepchhetri tricktron alyaeanyx ]; + maintainers = with maintainers; [ + pradeepchhetri + tricktron + alyaeanyx + ]; platforms = lib.platforms.unix; mainProgram = "openconnect"; }; diff --git a/pkgs/tools/networking/openconnect/default.nix b/pkgs/tools/networking/openconnect/default.nix index 778aea8354eb11..84d80d5eca418f 100644 --- a/pkgs/tools/networking/openconnect/default.nix +++ b/pkgs/tools/networking/openconnect/default.nix @@ -1,9 +1,16 @@ -{ callPackage, fetchurl, darwin }: +{ + callPackage, + fetchurl, + darwin, +}: let - common = opts: callPackage (import ./common.nix opts) { - inherit (darwin.apple_sdk.frameworks) PCSC; - }; -in rec { + common = + opts: + callPackage (import ./common.nix opts) { + inherit (darwin.apple_sdk.frameworks) PCSC; + }; +in +rec { openconnect = common rec { version = "9.12"; src = fetchurl { diff --git a/pkgs/tools/networking/opendrop/default.nix b/pkgs/tools/networking/opendrop/default.nix index a45c8916f9f636..704ee944b68562 100644 --- a/pkgs/tools/networking/opendrop/default.nix +++ b/pkgs/tools/networking/opendrop/default.nix @@ -1,15 +1,16 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, fleep -, ifaddr -, libarchive-c -, pillow -, requests-toolbelt -, setuptools -, zeroconf -, pytestCheckHook -, openssl +{ + lib, + buildPythonApplication, + fetchFromGitHub, + fleep, + ifaddr, + libarchive-c, + pillow, + requests-toolbelt, + setuptools, + zeroconf, + pytestCheckHook, + openssl, }: buildPythonApplication rec { diff --git a/pkgs/tools/networking/openssh/common.nix b/pkgs/tools/networking/openssh/common.nix index 674fb5f8c238d0..30d7ed4444b5bb 100644 --- a/pkgs/tools/networking/openssh/common.nix +++ b/pkgs/tools/networking/openssh/common.nix @@ -1,41 +1,44 @@ -{ pname -, version -, extraDesc ? "" -, src -, extraPatches ? [] -, extraNativeBuildInputs ? [] -, extraConfigureFlags ? [] -, extraMeta ? {} +{ + pname, + version, + extraDesc ? "", + src, + extraPatches ? [ ], + extraNativeBuildInputs ? [ ], + extraConfigureFlags ? [ ], + extraMeta ? { }, }: -{ lib, stdenv -# This *is* correct, though unusual. as a way of getting krb5-config from the -# package without splicing See: https://github.com/NixOS/nixpkgs/pull/107606 -, pkgs -, fetchurl -, fetchpatch -, autoreconfHook -, zlib -, openssl -, libedit -, ldns -, pkg-config -, pam -, libredirect -, etcDir ? null -, withKerberos ? false -, withLdns ? true -, krb5 -, libfido2 -, libxcrypt -, hostname -, nixosTests -, withSecurityKey ? !stdenv.hostPlatform.isStatic -, withFIDO ? stdenv.hostPlatform.isUnix && !stdenv.hostPlatform.isMusl && withSecurityKey -, withPAM ? stdenv.hostPlatform.isLinux -, dsaKeysSupport ? false -, linkOpenssl ? true -, isNixos ? stdenv.hostPlatform.isLinux +{ + lib, + stdenv, + # This *is* correct, though unusual. as a way of getting krb5-config from the + # package without splicing See: https://github.com/NixOS/nixpkgs/pull/107606 + pkgs, + fetchurl, + fetchpatch, + autoreconfHook, + zlib, + openssl, + libedit, + ldns, + pkg-config, + pam, + libredirect, + etcDir ? null, + withKerberos ? false, + withLdns ? true, + krb5, + libfido2, + libxcrypt, + hostname, + nixosTests, + withSecurityKey ? !stdenv.hostPlatform.isStatic, + withFIDO ? stdenv.hostPlatform.isUnix && !stdenv.hostPlatform.isMusl && withSecurityKey, + withPAM ? stdenv.hostPlatform.isLinux, + dsaKeysSupport ? false, + linkOpenssl ? true, + isNixos ? stdenv.hostPlatform.isLinux, }: # FIDO support requires SK support @@ -63,13 +66,21 @@ stdenv.mkDerivation (finalAttrs: { ''; strictDeps = true; - nativeBuildInputs = [ autoreconfHook pkg-config ] + nativeBuildInputs = + [ + autoreconfHook + pkg-config + ] # This is not the same as the krb5 from the inputs! pkgs.krb5 is # needed here to access krb5-config in order to cross compile. See: # https://github.com/NixOS/nixpkgs/pull/107606 ++ lib.optional withKerberos pkgs.krb5 ++ extraNativeBuildInputs; - buildInputs = [ zlib libedit ] + buildInputs = + [ + zlib + libedit + ] ++ [ (if linkOpenssl then openssl else libxcrypt) ] ++ lib.optional withFIDO libfido2 ++ lib.optional withKerberos krb5 @@ -90,27 +101,31 @@ stdenv.mkDerivation (finalAttrs: { # I set --disable-strip because later we strip anyway. And it fails to strip # properly when cross building. - configureFlags = [ - "--sbindir=\${out}/bin" - "--localstatedir=/var" - "--with-pid-dir=/run" - "--with-mantype=man" - "--with-libedit=yes" - "--disable-strip" - (lib.withFeature withPAM "pam") - (lib.enableFeature dsaKeysSupport "dsa-keys") - ] ++ lib.optional (etcDir != null) "--sysconfdir=${etcDir}" + configureFlags = + [ + "--sbindir=\${out}/bin" + "--localstatedir=/var" + "--with-pid-dir=/run" + "--with-mantype=man" + "--with-libedit=yes" + "--disable-strip" + (lib.withFeature withPAM "pam") + (lib.enableFeature dsaKeysSupport "dsa-keys") + ] + ++ lib.optional (etcDir != null) "--sysconfdir=${etcDir}" ++ lib.optional (!withSecurityKey) "--disable-security-key" ++ lib.optional withFIDO "--with-security-key-builtin=yes" - ++ lib.optional withKerberos (assert krb5 != null; "--with-kerberos5=${lib.getDev krb5}") + ++ lib.optional withKerberos ( + assert krb5 != null; + "--with-kerberos5=${lib.getDev krb5}" + ) ++ lib.optional stdenv.hostPlatform.isDarwin "--disable-libutil" ++ lib.optional (!linkOpenssl) "--without-openssl" ++ lib.optional withLdns "--with-ldns" ++ extraConfigureFlags; - ${if stdenv.hostPlatform.isStatic then "NIX_LDFLAGS" else null} = [ "-laudit" ] - ++ lib.optional withKerberos "-lkeyutils" - ++ lib.optional withLdns "-lcrypto"; + ${if stdenv.hostPlatform.isStatic then "NIX_LDFLAGS" else null} = + [ "-laudit" ] ++ lib.optional withKerberos "-lkeyutils" ++ lib.optional withLdns "-lcrypto"; buildFlags = [ "SSH_KEYSIGN=ssh-keysign" ]; @@ -168,9 +183,14 @@ stdenv.mkDerivation (finalAttrs: { # integration tests hard to get working on darwin with its shaky # sandbox # t-exec tests fail on musl - checkTarget = lib.optional (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isMusl) "t-exec" + checkTarget = + lib.optional (!stdenv.hostPlatform.isDarwin && !stdenv.hostPlatform.isMusl) "t-exec" # other tests are less demanding of the environment - ++ [ "unit" "file-tests" "interop-tests" ]; + ++ [ + "unit" + "file-tests" + "interop-tests" + ]; postInstall = '' # Install ssh-copy-id, it's very useful. @@ -197,13 +217,16 @@ stdenv.mkDerivation (finalAttrs: { }; }; - meta = with lib; { - description = "Implementation of the SSH protocol${extraDesc}"; - homepage = "https://www.openssh.com/"; - changelog = "https://www.openssh.com/releasenotes.html"; - license = licenses.bsd2; - platforms = platforms.unix ++ platforms.windows; - maintainers = (extraMeta.maintainers or []) ++ (with maintainers; [ aneeshusa ]); - mainProgram = "ssh"; - } // extraMeta; + meta = + with lib; + { + description = "Implementation of the SSH protocol${extraDesc}"; + homepage = "https://www.openssh.com/"; + changelog = "https://www.openssh.com/releasenotes.html"; + license = licenses.bsd2; + platforms = platforms.unix ++ platforms.windows; + maintainers = (extraMeta.maintainers or [ ]) ++ (with maintainers; [ aneeshusa ]); + mainProgram = "ssh"; + } + // extraMeta; }) diff --git a/pkgs/tools/networking/openssh/copyid.nix b/pkgs/tools/networking/openssh/copyid.nix index 7895e598e73303..55da4a5c701ce0 100644 --- a/pkgs/tools/networking/openssh/copyid.nix +++ b/pkgs/tools/networking/openssh/copyid.nix @@ -1,11 +1,17 @@ -{ lib, runCommand, openssh }: +{ + lib, + runCommand, + openssh, +}: -runCommand "ssh-copy-id-${openssh.version}" { - meta = openssh.meta // { - description = "Tool to copy SSH public keys to a remote machine"; - priority = (openssh.meta.priority or lib.meta.defaultPriority) - 1; - }; -} '' - install -Dm 755 {${openssh},$out}/bin/ssh-copy-id - install -Dm 644 {${openssh},$out}/share/man/man1/ssh-copy-id.1.gz -'' +runCommand "ssh-copy-id-${openssh.version}" + { + meta = openssh.meta // { + description = "Tool to copy SSH public keys to a remote machine"; + priority = (openssh.meta.priority or lib.meta.defaultPriority) - 1; + }; + } + '' + install -Dm 755 {${openssh},$out}/bin/ssh-copy-id + install -Dm 644 {${openssh},$out}/share/man/man1/ssh-copy-id.1.gz + '' diff --git a/pkgs/tools/networking/openssh/default.nix b/pkgs/tools/networking/openssh/default.nix index 2bda81df90030b..80a48c178e600f 100644 --- a/pkgs/tools/networking/openssh/default.nix +++ b/pkgs/tools/networking/openssh/default.nix @@ -1,4 +1,10 @@ -{ callPackage, lib, fetchurl, fetchpatch, autoreconfHook }: +{ + callPackage, + lib, + fetchurl, + fetchpatch, + autoreconfHook, +}: let common = opts: callPackage (import ./common.nix opts) { }; in @@ -26,27 +32,30 @@ in hash = "sha256-s0P7zb/4fxWxmG5uFdbU/Jp9NgZr5rf7UHCHuo+WbAI="; }; - extraPatches = let url = "https://raw.githubusercontent.com/freebsd/freebsd-ports/7ba88c964b6e5724eec462021d984da3989e6a08/security/openssh-portable/files/extra-patch-hpn"; in - [ - ./ssh-keysign-8.5.patch + extraPatches = + let + url = "https://raw.githubusercontent.com/freebsd/freebsd-ports/7ba88c964b6e5724eec462021d984da3989e6a08/security/openssh-portable/files/extra-patch-hpn"; + in + [ + ./ssh-keysign-8.5.patch - # HPN Patch from FreeBSD ports - (fetchpatch { - name = "ssh-hpn-wo-channels.patch"; - inherit url; - stripLen = 1; - excludes = [ "channels.c" ]; - hash = "sha256-zk7t6FNzTE+8aDU4QuteR1x0W3O2gjIQmeCkTNbaUfA="; - }) + # HPN Patch from FreeBSD ports + (fetchpatch { + name = "ssh-hpn-wo-channels.patch"; + inherit url; + stripLen = 1; + excludes = [ "channels.c" ]; + hash = "sha256-zk7t6FNzTE+8aDU4QuteR1x0W3O2gjIQmeCkTNbaUfA="; + }) - (fetchpatch { - name = "ssh-hpn-channels.patch"; - inherit url; - extraPrefix = ""; - includes = [ "channels.c" ]; - hash = "sha256-pDLUbjv5XIyByEbiRAXC3WMUPKmn15af1stVmcvr7fE="; - }) - ]; + (fetchpatch { + name = "ssh-hpn-channels.patch"; + inherit url; + extraPrefix = ""; + includes = [ "channels.c" ]; + hash = "sha256-pDLUbjv5XIyByEbiRAXC3WMUPKmn15af1stVmcvr7fE="; + }) + ]; extraNativeBuildInputs = [ autoreconfHook ]; diff --git a/pkgs/tools/networking/openvpn/default.nix b/pkgs/tools/networking/openvpn/default.nix index c7fa7a222f83ec..a10eec9cd2caec 100644 --- a/pkgs/tools/networking/openvpn/default.nix +++ b/pkgs/tools/networking/openvpn/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, libcap_ng -, libnl -, lz4 -, lzo -, openssl -, pam -, useSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, systemd -, update-systemd-resolved -, pkcs11Support ? false -, pkcs11helper -, nixosTests +{ + lib, + stdenv, + fetchurl, + pkg-config, + libcap_ng, + libnl, + lz4, + lzo, + openssl, + pam, + useSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + update-systemd-resolved, + pkcs11Support ? false, + pkcs11helper, + nixosTests, }: let @@ -30,12 +31,22 @@ stdenv.mkDerivation (finalAttrs: { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ lz4 lzo openssl ] - ++ optionals stdenv.hostPlatform.isLinux [ libcap_ng libnl pam ] + buildInputs = + [ + lz4 + lzo + openssl + ] + ++ optionals stdenv.hostPlatform.isLinux [ + libcap_ng + libnl + pam + ] ++ optional useSystemd systemd ++ optional pkcs11Support pkcs11helper; - configureFlags = optional useSystemd "--enable-systemd" + configureFlags = + optional useSystemd "--enable-systemd" ++ optional pkcs11Support "--enable-pkcs11" ++ optional stdenv.hostPlatform.isDarwin "--disable-plugin-auth-pam"; @@ -43,12 +54,14 @@ stdenv.mkDerivation (finalAttrs: { # but a separate package was made, that uses libexec/openvpn. Copy it # into libexec in case any consumers expect it to be there even though # they should use the update-systemd-resolved package instead. - postInstall = '' - mkdir -p $out/share/doc/openvpn/examples - cp -r sample/sample-{config-files,keys,scripts}/ $out/share/doc/openvpn/examples - '' + optionalString useSystemd '' - install -Dm555 -t $out/libexec ${update-systemd-resolved}/libexec/openvpn/* - ''; + postInstall = + '' + mkdir -p $out/share/doc/openvpn/examples + cp -r sample/sample-{config-files,keys,scripts}/ $out/share/doc/openvpn/examples + '' + + optionalString useSystemd '' + install -Dm555 -t $out/libexec ${update-systemd-resolved}/libexec/openvpn/* + ''; enableParallelBuilding = true; diff --git a/pkgs/tools/networking/openvpn/openvpn_learnaddress.nix b/pkgs/tools/networking/openvpn/openvpn_learnaddress.nix index 514491c2be21b3..4bfce881ca0f40 100644 --- a/pkgs/tools/networking/openvpn/openvpn_learnaddress.nix +++ b/pkgs/tools/networking/openvpn/openvpn_learnaddress.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchgit, makeWrapper, coreutils, gawk, util-linux }: +{ + lib, + stdenv, + fetchgit, + makeWrapper, + coreutils, + gawk, + util-linux, +}: stdenv.mkDerivation { pname = "openvpn-learnaddress"; @@ -11,13 +19,23 @@ stdenv.mkDerivation { }; nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ coreutils gawk util-linux ]; + buildInputs = [ + coreutils + gawk + util-linux + ]; installPhase = '' install -Dm555 ovpn-learnaddress $out/libexec/openvpn/openvpn-learnaddress wrapProgram $out/libexec/openvpn/openvpn-learnaddress \ - --prefix PATH : ${lib.makeBinPath [ coreutils gawk util-linux ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + gawk + util-linux + ] + } ''; meta = { diff --git a/pkgs/tools/networking/openvpn/update-resolv-conf.nix b/pkgs/tools/networking/openvpn/update-resolv-conf.nix index 53d2b272c4499c..4d8adb867e4728 100644 --- a/pkgs/tools/networking/openvpn/update-resolv-conf.nix +++ b/pkgs/tools/networking/openvpn/update-resolv-conf.nix @@ -1,7 +1,19 @@ -{ stdenv, lib, fetchFromGitHub, makeWrapper, openresolv, coreutils, systemd }: +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + openresolv, + coreutils, + systemd, +}: let - binPath = lib.makeBinPath [ coreutils openresolv systemd ]; + binPath = lib.makeBinPath [ + coreutils + openresolv + systemd + ]; in stdenv.mkDerivation { diff --git a/pkgs/tools/networking/openvpn/update-systemd-resolved.nix b/pkgs/tools/networking/openvpn/update-systemd-resolved.nix index 1b514eae02f0b7..bc0ef08d56c95c 100644 --- a/pkgs/tools/networking/openvpn/update-systemd-resolved.nix +++ b/pkgs/tools/networking/openvpn/update-systemd-resolved.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, iproute2 -, runtimeShell -, systemd -, coreutils -, util-linux +{ + lib, + stdenv, + fetchFromGitHub, + iproute2, + runtimeShell, + systemd, + coreutils, + util-linux, }: stdenv.mkDerivation rec { @@ -29,7 +30,15 @@ stdenv.mkDerivation rec { postInstall = '' substituteInPlace ${PREFIX}/update-systemd-resolved \ - --subst-var-by PATH ${lib.makeBinPath [ coreutils iproute2 runtimeShell systemd util-linux ]} + --subst-var-by PATH ${ + lib.makeBinPath [ + coreutils + iproute2 + runtimeShell + systemd + util-linux + ] + } ''; meta = with lib; { diff --git a/pkgs/tools/networking/pdsh/default.nix b/pkgs/tools/networking/pdsh/default.nix index bbfbc2d40cb809..7b90ec86ce20e4 100644 --- a/pkgs/tools/networking/pdsh/default.nix +++ b/pkgs/tools/networking/pdsh/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, autoreconfHook, perl, readline, rsh, ssh, slurm, slurmSupport ? false }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + perl, + readline, + rsh, + ssh, + slurm, + slurmSupport ? false, +}: stdenv.mkDerivation rec { pname = "pdsh"; @@ -9,8 +20,11 @@ stdenv.mkDerivation rec { sha256 = "sha256-de8VNHhI//Q/jW/5xEJP4Fx90s26ApE5kB+GGgUJPP4="; }; - buildInputs = [ perl readline ssh ] - ++ (lib.optional slurmSupport slurm); + buildInputs = [ + perl + readline + ssh + ] ++ (lib.optional slurmSupport slurm); nativeBuildInputs = [ autoreconfHook ]; diff --git a/pkgs/tools/networking/pingu/default.nix b/pkgs/tools/networking/pingu/default.nix index 5fcaa0af5fefc9..f2fba66aab8659 100644 --- a/pkgs/tools/networking/pingu/default.nix +++ b/pkgs/tools/networking/pingu/default.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "pingu"; diff --git a/pkgs/tools/networking/privoxy/default.nix b/pkgs/tools/networking/privoxy/default.nix index 5f394db354c013..5d70b379e6efde 100644 --- a/pkgs/tools/networking/privoxy/default.nix +++ b/pkgs/tools/networking/privoxy/default.nix @@ -1,9 +1,16 @@ -{ lib, stdenv -, nixosTests -, fetchpatch -, fetchurl, autoreconfHook -, zlib, pcre, w3m, man -, openssl, brotli +{ + lib, + stdenv, + nixosTests, + fetchpatch, + fetchurl, + autoreconfHook, + zlib, + pcre, + w3m, + man, + openssl, + brotli, }: stdenv.mkDerivation rec { @@ -27,8 +34,17 @@ stdenv.mkDerivation rec { hardeningEnable = [ "pie" ]; - nativeBuildInputs = [ autoreconfHook w3m man ]; - buildInputs = [ zlib pcre openssl brotli ]; + nativeBuildInputs = [ + autoreconfHook + w3m + man + ]; + buildInputs = [ + zlib + pcre + openssl + brotli + ]; makeFlags = [ "STRIP=" ]; configureFlags = [ diff --git a/pkgs/tools/networking/q/default.nix b/pkgs/tools/networking/q/default.nix index 95bdbe58ae29c2..6aac0616b55474 100644 --- a/pkgs/tools/networking/q/default.nix +++ b/pkgs/tools/networking/q/default.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "q"; diff --git a/pkgs/tools/networking/qcal/default.nix b/pkgs/tools/networking/qcal/default.nix index 9900f38faa05e6..19934ad7a3cd2d 100644 --- a/pkgs/tools/networking/qcal/default.nix +++ b/pkgs/tools/networking/qcal/default.nix @@ -1,6 +1,7 @@ -{ lib -, buildGoModule -, fetchFromSourcehut +{ + lib, + buildGoModule, + fetchFromSourcehut, }: buildGoModule rec { diff --git a/pkgs/tools/networking/rosenpass/default.nix b/pkgs/tools/networking/rosenpass/default.nix index 254a6b3aa8e877..1ec285b64a8956 100644 --- a/pkgs/tools/networking/rosenpass/default.nix +++ b/pkgs/tools/networking/rosenpass/default.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, nixosTests -, rustPlatform -, stdenv -, installShellFiles -, cmake -, libsodium -, pkg-config +{ + lib, + fetchFromGitHub, + nixosTests, + rustPlatform, + stdenv, + installShellFiles, + cmake, + libsodium, + pkg-config, }: rustPlatform.buildRustPackage rec { pname = "rosenpass"; @@ -45,9 +46,17 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Build post-quantum-secure VPNs with WireGuard"; homepage = "https://rosenpass.eu/"; - license = with licenses; [ mit /* or */ asl20 ]; + license = with licenses; [ + mit # or + asl20 + ]; maintainers = with maintainers; [ wucke13 ]; - platforms = [ "aarch64-darwin" "aarch64-linux" "x86_64-darwin" "x86_64-linux" ]; + platforms = [ + "aarch64-darwin" + "aarch64-linux" + "x86_64-darwin" + "x86_64-linux" + ]; mainProgram = "rosenpass"; }; } diff --git a/pkgs/tools/networking/rosenpass/tools.nix b/pkgs/tools/networking/rosenpass/tools.nix index 04af5755abb99a..cd197264491fab 100644 --- a/pkgs/tools/networking/rosenpass/tools.nix +++ b/pkgs/tools/networking/rosenpass/tools.nix @@ -1,26 +1,36 @@ -{ lib -, stdenv -, makeWrapper -, installShellFiles -, coreutils -, findutils -, gawk -, rosenpass -, wireguard-tools +{ + lib, + stdenv, + makeWrapper, + installShellFiles, + coreutils, + findutils, + gawk, + rosenpass, + wireguard-tools, }: stdenv.mkDerivation { inherit (rosenpass) version src; pname = "rosenpass-tools"; - nativeBuildInputs = [ makeWrapper installShellFiles ]; + nativeBuildInputs = [ + makeWrapper + installShellFiles + ]; postInstall = '' install -D $src/rp $out/bin/rp installManPage $src/doc/rp.1 wrapProgram $out/bin/rp \ - --prefix PATH : ${lib.makeBinPath [ - coreutils findutils gawk rosenpass wireguard-tools - ]} + --prefix PATH : ${ + lib.makeBinPath [ + coreutils + findutils + gawk + rosenpass + wireguard-tools + ] + } ''; meta = rosenpass.meta // { diff --git a/pkgs/tools/networking/s3cmd/default.nix b/pkgs/tools/networking/s3cmd/default.nix index d4864160fc342c..02a2c9053dd63c 100644 --- a/pkgs/tools/networking/s3cmd/default.nix +++ b/pkgs/tools/networking/s3cmd/default.nix @@ -1,4 +1,10 @@ -{ lib, buildPythonApplication, fetchFromGitHub, python-magic, python-dateutil }: +{ + lib, + buildPythonApplication, + fetchFromGitHub, + python-magic, + python-dateutil, +}: buildPythonApplication rec { pname = "s3cmd"; @@ -11,7 +17,10 @@ buildPythonApplication rec { sha256 = "sha256-cxwf6+9WFt3U7+JdKRgZxFElD+Dgf2P2VyejHVoiDJk="; }; - propagatedBuildInputs = [ python-magic python-dateutil ]; + propagatedBuildInputs = [ + python-magic + python-dateutil + ]; dontUseSetuptoolsCheck = true; diff --git a/pkgs/tools/networking/s3rs/default.nix b/pkgs/tools/networking/s3rs/default.nix index ad343c00ca600d..d3714fb56c4b17 100644 --- a/pkgs/tools/networking/s3rs/default.nix +++ b/pkgs/tools/networking/s3rs/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, rustPlatform, python3, perl, openssl, Security, fetchFromGitHub, pkg-config }: +{ + lib, + stdenv, + rustPlatform, + python3, + perl, + openssl, + Security, + fetchFromGitHub, + pkg-config, +}: rustPlatform.buildRustPackage rec { pname = "s3rs"; @@ -13,9 +23,12 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-Q1EqEyNxWIx3wD8zuU7/MO3Qz6zsfBZbtT/IIUmJccE="; - nativeBuildInputs = [ python3 perl pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; + nativeBuildInputs = [ + python3 + perl + pkg-config + ]; + buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; meta = with lib; { description = "S3 cli client with multi configs with diffent provider"; diff --git a/pkgs/tools/networking/spoof-mac/default.nix b/pkgs/tools/networking/spoof-mac/default.nix index 3b7bbd0d52a232..7bd2111474466b 100644 --- a/pkgs/tools/networking/spoof-mac/default.nix +++ b/pkgs/tools/networking/spoof-mac/default.nix @@ -1,4 +1,9 @@ -{ lib, buildPythonPackage, fetchFromGitHub, docopt }: +{ + lib, + buildPythonPackage, + fetchFromGitHub, + docopt, +}: buildPythonPackage rec { pname = "spoof-mac"; diff --git a/pkgs/tools/networking/spoofer/default.nix b/pkgs/tools/networking/spoofer/default.nix index c022aad7823806..2f7093bfb6a47b 100644 --- a/pkgs/tools/networking/spoofer/default.nix +++ b/pkgs/tools/networking/spoofer/default.nix @@ -1,7 +1,18 @@ -{ lib, stdenv, fetchurl, pkg-config, protobuf, openssl, libpcap, traceroute -, withGUI ? false, qt5 }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + protobuf, + openssl, + libpcap, + traceroute, + withGUI ? false, + qt5, +}: -let inherit (lib) optional; +let + inherit (lib) optional; in stdenv.mkDerivation rec { @@ -14,8 +25,12 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl protobuf libpcap traceroute ] - ++ optional withGUI qt5.qtbase ; + buildInputs = [ + openssl + protobuf + libpcap + traceroute + ] ++ optional withGUI qt5.qtbase; dontWrapQtApps = true; @@ -38,7 +53,7 @@ stdenv.mkDerivation rec { ''; platforms = platforms.all; license = licenses.gpl3Plus; - maintainers = with lib.maintainers; [ leenaars]; + maintainers = with lib.maintainers; [ leenaars ]; mainProgram = "spoofer-prober"; }; } diff --git a/pkgs/tools/networking/suckit/default.nix b/pkgs/tools/networking/suckit/default.nix index 07c91a9081c286..f80a34b2a202e8 100644 --- a/pkgs/tools/networking/suckit/default.nix +++ b/pkgs/tools/networking/suckit/default.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + Security, }: rustPlatform.buildRustPackage rec { @@ -33,7 +34,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "Recursively visit and download a website's content to your disk"; homepage = "https://github.com/skallwar/suckit"; - license = with licenses; [ asl20 /* or */ mit ]; + license = with licenses; [ + asl20 # or + mit + ]; maintainers = with maintainers; [ figsoda ]; mainProgram = "suckit"; }; diff --git a/pkgs/tools/networking/tcpreplay/default.nix b/pkgs/tools/networking/tcpreplay/default.nix index f993ae0138bc2d..0f612f17d386a8 100644 --- a/pkgs/tools/networking/tcpreplay/default.nix +++ b/pkgs/tools/networking/tcpreplay/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, libpcap, tcpdump, Carbon, CoreServices }: +{ + lib, + stdenv, + fetchurl, + libpcap, + tcpdump, + Carbon, + CoreServices, +}: stdenv.mkDerivation rec { pname = "tcpreplay"; @@ -9,12 +17,13 @@ stdenv.mkDerivation rec { sha256 = "sha256-Leeb/Wfsksqa4v+1BFbdHVP/QPP6cbQixl6AYgE8noU="; }; - buildInputs = [ libpcap ] + buildInputs = + [ libpcap ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Carbon CoreServices + Carbon + CoreServices ]; - configureFlags = [ "--disable-local-libopts" "--disable-libopts-install" @@ -28,7 +37,10 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Suite of utilities for editing and replaying network traffic"; homepage = "https://tcpreplay.appneta.com/"; - license = with licenses; [ bsdOriginalUC gpl3Only ]; + license = with licenses; [ + bsdOriginalUC + gpl3Only + ]; maintainers = with maintainers; [ eleanor ]; platforms = platforms.unix; }; diff --git a/pkgs/tools/networking/telepresence/default.nix b/pkgs/tools/networking/telepresence/default.nix index dee55ad5687c4b..244b190fe60b9e 100644 --- a/pkgs/tools/networking/telepresence/default.nix +++ b/pkgs/tools/networking/telepresence/default.nix @@ -1,12 +1,24 @@ -{ lib, pythonPackages, fetchFromGitHub, makeWrapper -, sshfs-fuse, torsocks, sshuttle, conntrack-tools , openssh, coreutils -, iptables, bash }: +{ + lib, + pythonPackages, + fetchFromGitHub, + makeWrapper, + sshfs-fuse, + torsocks, + sshuttle, + conntrack-tools, + openssh, + coreutils, + iptables, + bash, +}: let sshuttle-telepresence = lib.overrideDerivation sshuttle (p: { postInstall = "mv $out/bin/sshuttle $out/bin/sshuttle-telepresence"; }); -in pythonPackages.buildPythonPackage rec { +in +pythonPackages.buildPythonPackage rec { pname = "telepresence"; version = "0.109"; @@ -21,16 +33,18 @@ in pythonPackages.buildPythonPackage rec { postInstall = '' wrapProgram $out/bin/telepresence \ - --prefix PATH : ${lib.makeBinPath [ - sshfs-fuse - torsocks - conntrack-tools - sshuttle-telepresence - openssh - coreutils - iptables - bash - ]} + --prefix PATH : ${ + lib.makeBinPath [ + sshfs-fuse + torsocks + conntrack-tools + sshuttle-telepresence + openssh + coreutils + iptables + bash + ] + } ''; doCheck = false; diff --git a/pkgs/tools/networking/tinc/default.nix b/pkgs/tools/networking/tinc/default.nix index 6250ec84d9df64..85722207bea432 100644 --- a/pkgs/tools/networking/tinc/default.nix +++ b/pkgs/tools/networking/tinc/default.nix @@ -1,4 +1,11 @@ -{lib, stdenv, fetchurl, lzo, openssl, zlib}: +{ + lib, + stdenv, + fetchurl, + lzo, + openssl, + zlib, +}: stdenv.mkDerivation rec { version = "1.0.36"; @@ -9,7 +16,11 @@ stdenv.mkDerivation rec { sha256 = "021i2sl2mjscbm8g59d7vs74iw3gf0m48wg7w3zhwj6czarkpxs0"; }; - buildInputs = [ lzo openssl zlib ]; + buildInputs = [ + lzo + openssl + zlib + ]; configureFlags = [ "--localstatedir=/var" @@ -26,7 +37,7 @@ stdenv.mkDerivation rec { Internet. It features full mesh routing, as well as encryption, authentication, compression and ethernet bridging. ''; - homepage="http://www.tinc-vpn.org/"; + homepage = "http://www.tinc-vpn.org/"; license = lib.licenses.gpl2Plus; mainProgram = "tincd"; platforms = lib.platforms.unix; diff --git a/pkgs/tools/networking/tinc/pre.nix b/pkgs/tools/networking/tinc/pre.nix index 31757dcf4c7258..738bf5bf0e8b4b 100644 --- a/pkgs/tools/networking/tinc/pre.nix +++ b/pkgs/tools/networking/tinc/pre.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitHub, autoreconfHook, texinfo, ncurses, readline, zlib, lzo, openssl, nixosTests }: +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + texinfo, + ncurses, + readline, + zlib, + lzo, + openssl, + nixosTests, +}: stdenv.mkDerivation rec { pname = "tinc"; @@ -11,10 +23,23 @@ stdenv.mkDerivation rec { hash = "sha256-1anjTUlVLx57FlUqGwBd590lfkZ2MmrM1qRcMl4P7Sg="; }; - outputs = [ "out" "man" "info" ]; + outputs = [ + "out" + "man" + "info" + ]; - nativeBuildInputs = [ autoreconfHook texinfo ]; - buildInputs = [ ncurses readline zlib lzo openssl ]; + nativeBuildInputs = [ + autoreconfHook + texinfo + ]; + buildInputs = [ + ncurses + readline + zlib + lzo + openssl + ]; # needed so the build doesn't need to run git to find out the version. prePatch = '' @@ -39,9 +64,12 @@ stdenv.mkDerivation rec { Internet. It features full mesh routing, as well as encryption, authentication, compression and ethernet bridging. ''; - homepage="http://www.tinc-vpn.org/"; + homepage = "http://www.tinc-vpn.org/"; license = licenses.gpl2Plus; platforms = platforms.unix; - maintainers = with maintainers; [ lassulus mic92 ]; + maintainers = with maintainers; [ + lassulus + mic92 + ]; }; } diff --git a/pkgs/tools/networking/tunnelto/default.nix b/pkgs/tools/networking/tunnelto/default.nix index 7f3129705950f5..57544708434871 100644 --- a/pkgs/tools/networking/tunnelto/default.nix +++ b/pkgs/tools/networking/tunnelto/default.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, rustPlatform -, fetchFromGitHub -, openssl -, pkg-config -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + openssl, + pkg-config, + Security, }: rustPlatform.buildRustPackage rec { @@ -26,7 +28,8 @@ rustPlatform.buildRustPackage rec { }; nativeBuildInputs = lib.optionals stdenv.hostPlatform.isLinux [ pkg-config ]; - buildInputs = [ ] + buildInputs = + [ ] ++ lib.optionals stdenv.hostPlatform.isLinux [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; diff --git a/pkgs/tools/networking/veilid/default.nix b/pkgs/tools/networking/veilid/default.nix index 35e4166c85ab38..dbe5b78331b6ab 100644 --- a/pkgs/tools/networking/veilid/default.nix +++ b/pkgs/tools/networking/veilid/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, AppKit -, Security -, fetchFromGitLab -, rustPlatform -, protobuf -, capnproto -, cmake -, testers -, veilid -, gitUpdater +{ + lib, + stdenv, + AppKit, + Security, + fetchFromGitLab, + rustPlatform, + protobuf, + capnproto, + cmake, + testers, + veilid, + gitUpdater, }: rustPlatform.buildRustPackage rec { @@ -39,7 +40,10 @@ rustPlatform.buildRustPackage rec { protobuf ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ AppKit Security ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + Security + ]; cargoBuildFlags = [ "--workspace" @@ -49,7 +53,11 @@ rustPlatform.buildRustPackage rec { doCheck = false; - outputs = [ "out" "lib" "dev" ]; + outputs = [ + "out" + "lib" + "dev" + ]; postInstall = '' moveToOutput "lib" "$lib" @@ -69,6 +77,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "veilid-server"; homepage = "https://veilid.com"; license = licenses.mpl20; - maintainers = with maintainers; [ bbigras qbit ]; + maintainers = with maintainers; [ + bbigras + qbit + ]; }; } diff --git a/pkgs/tools/networking/vpn-slice/default.nix b/pkgs/tools/networking/vpn-slice/default.nix index 6ca66d44e61d70..ea23ece8b5ded3 100644 --- a/pkgs/tools/networking/vpn-slice/default.nix +++ b/pkgs/tools/networking/vpn-slice/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, buildPythonApplication -, nix-update-script -, python3Packages -, fetchFromGitHub -, iproute2 -, iptables -, unixtools +{ + lib, + stdenv, + buildPythonApplication, + nix-update-script, + python3Packages, + fetchFromGitHub, + iproute2, + iptables, + unixtools, }: buildPythonApplication rec { @@ -20,16 +21,21 @@ buildPythonApplication rec { sha256 = "sha256-T6VULLNRLWO4OcAsuTmhty6H4EhinyxQSg0dfv2DUJs="; }; - postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace vpn_slice/mac.py \ - --replace "'/sbin/route'" "'${unixtools.route}/bin/route'" - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace vpn_slice/linux.py \ - --replace "'/sbin/ip'" "'${iproute2}/bin/ip'" \ - --replace "'/sbin/iptables'" "'${iptables}/bin/iptables'" - ''; + postPatch = + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace vpn_slice/mac.py \ + --replace "'/sbin/route'" "'${unixtools.route}/bin/route'" + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace vpn_slice/linux.py \ + --replace "'/sbin/ip'" "'${iproute2}/bin/ip'" \ + --replace "'/sbin/iptables'" "'${iptables}/bin/iptables'" + ''; - propagatedBuildInputs = with python3Packages; [ setproctitle dnspython ]; + propagatedBuildInputs = with python3Packages; [ + setproctitle + dnspython + ]; doCheck = false; @@ -39,8 +45,7 @@ buildPythonApplication rec { meta = with lib; { homepage = "https://github.com/dlenski/vpn-slice"; - description = - "vpnc-script replacement for easy and secure split-tunnel VPN setup"; + description = "vpnc-script replacement for easy and secure split-tunnel VPN setup"; mainProgram = "vpn-slice"; license = licenses.gpl3; maintainers = [ ]; diff --git a/pkgs/tools/networking/wg-netmanager/default.nix b/pkgs/tools/networking/wg-netmanager/default.nix index a2c16fae073b87..b9a2353c84262e 100644 --- a/pkgs/tools/networking/wg-netmanager/default.nix +++ b/pkgs/tools/networking/wg-netmanager/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, +}: rustPlatform.buildRustPackage rec { pname = "wg-netmanager"; @@ -17,7 +23,10 @@ rustPlatform.buildRustPackage rec { # Test 01 tries to create a wireguard interface, which requires sudo. doCheck = true; - checkFlags = [ "--skip" "device" ]; + checkFlags = [ + "--skip" + "device" + ]; meta = with lib; { description = "Wireguard network manager"; @@ -28,7 +37,12 @@ rustPlatform.buildRustPackage rec { To achieve this, wireguard network manager needs to be running on each node. ''; homepage = "https://github.com/gin66/wg_netmanager"; - license = with licenses; [ mit asl20 bsd3 mpl20 ]; + license = with licenses; [ + mit + asl20 + bsd3 + mpl20 + ]; maintainers = with maintainers; [ gin66 ]; platforms = platforms.linux; mainProgram = "wg_netmanager"; diff --git a/pkgs/tools/networking/wireguard-go/default.nix b/pkgs/tools/networking/wireguard-go/default.nix index ec14c180d8ff2e..f94e55656bd3dd 100644 --- a/pkgs/tools/networking/wireguard-go/default.nix +++ b/pkgs/tools/networking/wireguard-go/default.nix @@ -1,4 +1,10 @@ -{ lib, buildGoModule, fetchzip, testers, wireguard-go }: +{ + lib, + buildGoModule, + fetchzip, + testers, + wireguard-go, +}: buildGoModule rec { pname = "wireguard-go"; @@ -18,7 +24,10 @@ buildGoModule rec { subPackages = [ "." ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; postInstall = '' mv $out/bin/wireguard $out/bin/wireguard-go @@ -33,7 +42,10 @@ buildGoModule rec { description = "Userspace Go implementation of WireGuard"; homepage = "https://git.zx2c4.com/wireguard-go/about/"; license = licenses.mit; - maintainers = with maintainers; [ kirelagin zx2c4 ]; + maintainers = with maintainers; [ + kirelagin + zx2c4 + ]; mainProgram = "wireguard-go"; }; } diff --git a/pkgs/tools/networking/wireguard-tools/default.nix b/pkgs/tools/networking/wireguard-tools/default.nix index 855f620b44060f..0c85c9154be591 100644 --- a/pkgs/tools/networking/wireguard-tools/default.nix +++ b/pkgs/tools/networking/wireguard-tools/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchzip -, nixosTests -, iptables -, iproute2 -, makeWrapper -, openresolv -, procps -, bash -, wireguard-go +{ + lib, + stdenv, + fetchzip, + nixosTests, + iptables, + iproute2, + makeWrapper, + openresolv, + procps, + bash, + wireguard-go, }: stdenv.mkDerivation rec { @@ -20,7 +21,10 @@ stdenv.mkDerivation rec { sha256 = "sha256-eGGkTVdPPTWK6iEyowW11F4ywRhd+0IXJTZCqY3OZws="; }; - outputs = [ "out" "man" ]; + outputs = [ + "out" + "man" + ]; sourceRoot = "${src.name}/src"; @@ -36,23 +40,36 @@ stdenv.mkDerivation rec { "WITH_WGQUICK=yes" ]; - postFixup = '' - substituteInPlace $out/lib/systemd/system/wg-quick@.service \ - --replace /usr/bin $out/bin - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - for f in $out/bin/*; do - # Which firewall and resolvconf implementations to use should be determined by the - # environment, we provide the "default" ones as fallback. - wrapProgram $f \ - --prefix PATH : ${lib.makeBinPath [ procps iproute2 ]} \ - --suffix PATH : ${lib.makeBinPath [ iptables openresolv ]} - done - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - for f in $out/bin/*; do - wrapProgram $f \ - --prefix PATH : ${lib.makeBinPath [ wireguard-go ]} - done - ''; + postFixup = + '' + substituteInPlace $out/lib/systemd/system/wg-quick@.service \ + --replace /usr/bin $out/bin + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + for f in $out/bin/*; do + # Which firewall and resolvconf implementations to use should be determined by the + # environment, we provide the "default" ones as fallback. + wrapProgram $f \ + --prefix PATH : ${ + lib.makeBinPath [ + procps + iproute2 + ] + } \ + --suffix PATH : ${ + lib.makeBinPath [ + iptables + openresolv + ] + } + done + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + for f in $out/bin/*; do + wrapProgram $f \ + --prefix PATH : ${lib.makeBinPath [ wireguard-go ]} + done + ''; passthru = { updateScript = ./update.sh; @@ -71,7 +88,13 @@ stdenv.mkDerivation rec { downloadPage = "https://git.zx2c4.com/wireguard-tools/refs/"; homepage = "https://www.wireguard.com/"; license = licenses.gpl2Only; - maintainers = with maintainers; [ ericsagnes zx2c4 globin ma27 d-xo ]; + maintainers = with maintainers; [ + ericsagnes + zx2c4 + globin + ma27 + d-xo + ]; mainProgram = "wg"; platforms = platforms.unix; }; diff --git a/pkgs/tools/networking/wireguard-vanity-address/default.nix b/pkgs/tools/networking/wireguard-vanity-address/default.nix index 969e9187db5be3..e64a8a59f5c765 100644 --- a/pkgs/tools/networking/wireguard-vanity-address/default.nix +++ b/pkgs/tools/networking/wireguard-vanity-address/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, +}: rustPlatform.buildRustPackage rec { pname = "wireguard-vanity-address"; diff --git a/pkgs/tools/networking/xdp-tools/default.nix b/pkgs/tools/networking/xdp-tools/default.nix index d1a28611722467..a3ce1a2d087bf8 100644 --- a/pkgs/tools/networking/xdp-tools/default.nix +++ b/pkgs/tools/networking/xdp-tools/default.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, libbpf -, elfutils -, zlib -, libpcap -, bpftools -, llvmPackages -, pkg-config -, m4 -, emacs-nox -, wireshark-cli -, nukeReferences +{ + lib, + stdenv, + fetchFromGitHub, + libbpf, + elfutils, + zlib, + libpcap, + bpftools, + llvmPackages, + pkg-config, + m4, + emacs-nox, + wireshark-cli, + nukeReferences, }: stdenv.mkDerivation rec { pname = "xdp-tools"; @@ -24,7 +25,10 @@ stdenv.mkDerivation rec { hash = "sha256-eI4sqzTaA4iRmhEY3SgySxWiCzGJ7nVebC2RVlk7OHk="; }; - outputs = [ "out" "lib" ]; + outputs = [ + "out" + "lib" + ]; buildInputs = [ libbpf @@ -57,7 +61,10 @@ stdenv.mkDerivation rec { FORCE_SYSTEM_LIBBPF = 1; FORCE_EMACS = 1; - makeFlags = [ "PREFIX=$(out)" "LIBDIR=$(lib)/lib" ]; + makeFlags = [ + "PREFIX=$(out)" + "LIBDIR=$(lib)/lib" + ]; postInstall = '' # Note that even the static libxdp would refer to BPF_OBJECT_DIR ?=$(LIBDIR)/bpf @@ -69,8 +76,16 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://github.com/xdp-project/xdp-tools"; description = "Library and utilities for use with XDP"; - license = with licenses; [ gpl2Only lgpl21 bsd2 ]; - maintainers = with maintainers; [ tirex vcunat vifino ]; + license = with licenses; [ + gpl2Only + lgpl21 + bsd2 + ]; + maintainers = with maintainers; [ + tirex + vcunat + vifino + ]; platforms = platforms.linux; }; } diff --git a/pkgs/tools/networking/zrok/default.nix b/pkgs/tools/networking/zrok/default.nix index c3337cd1b1ea2b..4d26579be450cc 100644 --- a/pkgs/tools/networking/zrok/default.nix +++ b/pkgs/tools/networking/zrok/default.nix @@ -1,23 +1,28 @@ -{ lib -, stdenv -, fetchzip +{ + lib, + stdenv, + fetchzip, }: let inherit (stdenv.hostPlatform) system; throwSystem = throw "Unsupported system: ${system}"; - plat = { - x86_64-linux = "linux_amd64"; - aarch64-linux = "linux_arm64"; - armv7l-linux = "linux_armv7"; - }.${system} or throwSystem; - - hash = { - x86_64-linux = "sha256-oga8WQYxFeJlXhkJRpgb08QSV1vA7rfbVzwxxdl8xUw="; - aarch64-linux = "sha256-Xa7CGpv35fZDZjYmR3y3NUriOt1/I85556P32eP9UjQ="; - armv7l-linux = "sha256-k3FGn5pZX5Iqzh0J/nclQC4+n6CMrr+JPt2/rabnWvo="; - }.${system} or throwSystem; + plat = + { + x86_64-linux = "linux_amd64"; + aarch64-linux = "linux_arm64"; + armv7l-linux = "linux_armv7"; + } + .${system} or throwSystem; + + hash = + { + x86_64-linux = "sha256-oga8WQYxFeJlXhkJRpgb08QSV1vA7rfbVzwxxdl8xUw="; + aarch64-linux = "sha256-Xa7CGpv35fZDZjYmR3y3NUriOt1/I85556P32eP9UjQ="; + armv7l-linux = "sha256-k3FGn5pZX5Iqzh0J/nclQC4+n6CMrr+JPt2/rabnWvo="; + } + .${system} or throwSystem; in stdenv.mkDerivation (finalAttrs: { pname = "zrok"; @@ -31,18 +36,20 @@ stdenv.mkDerivation (finalAttrs: { updateScript = ./update.sh; - installPhase = let - interpreter = "$(< \"$NIX_CC/nix-support/dynamic-linker\")"; - in '' - runHook preInstall + installPhase = + let + interpreter = "$(< \"$NIX_CC/nix-support/dynamic-linker\")"; + in + '' + runHook preInstall - mkdir -p $out/bin - cp zrok $out/bin/ - chmod +x $out/bin/zrok - patchelf --set-interpreter "${interpreter}" "$out/bin/zrok" + mkdir -p $out/bin + cp zrok $out/bin/ + chmod +x $out/bin/zrok + patchelf --set-interpreter "${interpreter}" "$out/bin/zrok" - runHook postInstall - ''; + runHook postInstall + ''; meta = { description = "Geo-scale, next-generation sharing platform built on top of OpenZiti"; @@ -50,7 +57,11 @@ stdenv.mkDerivation (finalAttrs: { license = lib.licenses.asl20; mainProgram = "zrok"; maintainers = [ lib.maintainers.bandresen ]; - platforms = [ "x86_64-linux" "aarch64-linux" "armv7l-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + "armv7l-linux" + ]; sourceProvenance = with lib.sourceTypes; [ binaryNativeCode ]; }; }) diff --git a/pkgs/tools/nix/info/default.nix b/pkgs/tools/nix/info/default.nix index 7b29f9c43c9a4e..be5b75282101fa 100644 --- a/pkgs/tools/nix/info/default.nix +++ b/pkgs/tools/nix/info/default.nix @@ -1,15 +1,28 @@ -{ stdenv, lib, coreutils, findutils, gnugrep, darwin, bash -# Avoid having GHC in the build-time closure of all NixOS configurations -, doCheck ? false, shellcheck +{ + stdenv, + lib, + coreutils, + findutils, + gnugrep, + darwin, + bash, + # Avoid having GHC in the build-time closure of all NixOS configurations + doCheck ? false, + shellcheck, }: stdenv.mkDerivation { name = "nix-info"; src = ./info.sh; - path = lib.makeBinPath ([ - coreutils findutils gnugrep - ] ++ (lib.optionals stdenv.hostPlatform.isDarwin [ darwin.DarwinTools ])); + path = lib.makeBinPath ( + [ + coreutils + findutils + gnugrep + ] + ++ (lib.optionals stdenv.hostPlatform.isDarwin [ darwin.DarwinTools ]) + ); is_darwin = if stdenv.hostPlatform.isDarwin then "yes" else "no"; sandboxtest = ./sandbox.nix; @@ -21,7 +34,7 @@ stdenv.mkDerivation { cp $src ./nix-info/nix-info ''; - buildPhase = '' + buildPhase = '' substituteAllInPlace ./nix-info ''; diff --git a/pkgs/tools/nix/nix-output-monitor/default.nix b/pkgs/tools/nix/nix-output-monitor/default.nix index 69c92320d7d0d0..03b0e0b78a0c45 100644 --- a/pkgs/tools/nix/nix-output-monitor/default.nix +++ b/pkgs/tools/nix/nix-output-monitor/default.nix @@ -3,7 +3,8 @@ haskellPackages, installShellFiles, lib, -}: let +}: +let inherit (haskell.lib.compose) justStaticExecutables overrideCabal; overrides = { @@ -13,7 +14,7 @@ # golden-tests call nix and thus can’t be run in a nix build. testTarget = "unit-tests"; - buildTools = [installShellFiles]; + buildTools = [ installShellFiles ]; postInstall = '' ln -s nom "$out/bin/nom-build" ln -s nom "$out/bin/nom-shell" @@ -21,11 +22,9 @@ installShellCompletion completions/* ''; }; - raw-pkg = haskellPackages.callPackage ./generated-package.nix {}; + raw-pkg = haskellPackages.callPackage ./generated-package.nix { }; in - lib.pipe - raw-pkg - [ - (overrideCabal overrides) - justStaticExecutables - ] +lib.pipe raw-pkg [ + (overrideCabal overrides) + justStaticExecutables +] diff --git a/pkgs/tools/nix/nix-output-monitor/generated-package.nix b/pkgs/tools/nix/nix-output-monitor/generated-package.nix index d278604484a55c..eb35ce850a29a5 100644 --- a/pkgs/tools/nix/nix-output-monitor/generated-package.nix +++ b/pkgs/tools/nix/nix-output-monitor/generated-package.nix @@ -1,11 +1,40 @@ # This file has been autogenerate with cabal2nix. # Update via ./update.sh" -{ mkDerivation, ansi-terminal, async, attoparsec, base, bytestring -, cassava, containers, data-default, directory, extra, fetchzip -, filepath, hermes-json, HUnit, lib, lock-file, MemoTrie -, nix-derivation, optics, random, relude, safe, stm, streamly-core -, strict, strict-types, terminal-size, text, time, transformers -, typed-process, unix, word8 +{ + mkDerivation, + ansi-terminal, + async, + attoparsec, + base, + bytestring, + cassava, + containers, + data-default, + directory, + extra, + fetchzip, + filepath, + hermes-json, + HUnit, + lib, + lock-file, + MemoTrie, + nix-derivation, + optics, + random, + relude, + safe, + stm, + streamly-core, + strict, + strict-types, + terminal-size, + text, + time, + transformers, + typed-process, + unix, + word8, }: mkDerivation { pname = "nix-output-monitor"; @@ -17,24 +46,96 @@ mkDerivation { isLibrary = true; isExecutable = true; libraryHaskellDepends = [ - ansi-terminal async attoparsec base bytestring cassava containers - data-default directory extra filepath hermes-json lock-file - MemoTrie nix-derivation optics relude safe stm streamly-core strict - strict-types terminal-size text time transformers word8 + ansi-terminal + async + attoparsec + base + bytestring + cassava + containers + data-default + directory + extra + filepath + hermes-json + lock-file + MemoTrie + nix-derivation + optics + relude + safe + stm + streamly-core + strict + strict-types + terminal-size + text + time + transformers + word8 ]; executableHaskellDepends = [ - ansi-terminal async attoparsec base bytestring cassava containers - data-default directory extra filepath hermes-json lock-file - MemoTrie nix-derivation optics relude safe stm streamly-core strict - strict-types terminal-size text time transformers typed-process - unix word8 + ansi-terminal + async + attoparsec + base + bytestring + cassava + containers + data-default + directory + extra + filepath + hermes-json + lock-file + MemoTrie + nix-derivation + optics + relude + safe + stm + streamly-core + strict + strict-types + terminal-size + text + time + transformers + typed-process + unix + word8 ]; testHaskellDepends = [ - ansi-terminal async attoparsec base bytestring cassava containers - data-default directory extra filepath hermes-json HUnit lock-file - MemoTrie nix-derivation optics random relude safe stm streamly-core - strict strict-types terminal-size text time transformers - typed-process word8 + ansi-terminal + async + attoparsec + base + bytestring + cassava + containers + data-default + directory + extra + filepath + hermes-json + HUnit + lock-file + MemoTrie + nix-derivation + optics + random + relude + safe + stm + streamly-core + strict + strict-types + terminal-size + text + time + transformers + typed-process + word8 ]; homepage = "https://code.maralorn.de/maralorn/nix-output-monitor"; description = "Processes output of Nix commands to show helpful and pretty information"; diff --git a/pkgs/tools/nix/nixci/default.nix b/pkgs/tools/nix/nixci/default.nix index 5075705a2c888b..3e6866df79c7a7 100644 --- a/pkgs/tools/nix/nixci/default.nix +++ b/pkgs/tools/nix/nixci/default.nix @@ -1,14 +1,16 @@ -{ lib, stdenv -, rustPlatform -, fetchCrate -, fetchFromGitHub -, openssl -, pkg-config -, Security -, SystemConfiguration -, IOKit -, installShellFiles -, nix +{ + lib, + stdenv, + rustPlatform, + fetchCrate, + fetchFromGitHub, + openssl, + pkg-config, + Security, + SystemConfiguration, + IOKit, + installShellFiles, + nix, }: rustPlatform.buildRustPackage rec { @@ -23,16 +25,22 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-trmWeYJNev7jYJtGp9XR/emmQiiI94NM0cPFrAuD7m0="; - nativeBuildInputs = [ pkg-config installShellFiles nix ]; - - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - IOKit - Security - SystemConfiguration + nativeBuildInputs = [ + pkg-config + installShellFiles + nix ]; + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + IOKit + Security + SystemConfiguration + ]; + postInstall = '' installShellCompletion --cmd nixci \ --bash <($out/bin/nixci completion bash) \ @@ -53,7 +61,11 @@ rustPlatform.buildRustPackage rec { description = "Define and build CI for Nix projects anywhere"; homepage = "https://github.com/srid/nixci"; license = licenses.agpl3Only; - maintainers = with maintainers; [ srid shivaraj-bh rsrohitsingh682 ]; + maintainers = with maintainers; [ + srid + shivaraj-bh + rsrohitsingh682 + ]; mainProgram = "nixci"; }; } diff --git a/pkgs/tools/package-management/akku/akku.nix b/pkgs/tools/package-management/akku/akku.nix index 3b205776d0d3a8..160368fdd80882 100644 --- a/pkgs/tools/package-management/akku/akku.nix +++ b/pkgs/tools/package-management/akku/akku.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitLab, autoreconfHook, pkg-config, git, guile, curl }: +{ + lib, + stdenv, + fetchFromGitLab, + autoreconfHook, + pkg-config, + git, + guile, + curl, +}: stdenv.mkDerivation rec { pname = "akku"; version = "1.1.0-unstable-2024-03-03"; @@ -10,11 +19,17 @@ stdenv.mkDerivation rec { sha256 = "sha256-6xqASnFxzz0yE5oJnh15SOB74PVrVkMVwS3PwKAmgks="; }; - - nativeBuildInputs = [ autoreconfHook pkg-config ]; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; # akku calls curl commands - buildInputs = [ guile curl git ]; + buildInputs = [ + guile + curl + git + ]; # Use a dummy package index to boostrap Akku preBuild = '' diff --git a/pkgs/tools/package-management/akku/akkuDerivation.nix b/pkgs/tools/package-management/akku/akkuDerivation.nix index 5b4609c3abaa6c..27d2b10bcda151 100644 --- a/pkgs/tools/package-management/akku/akkuDerivation.nix +++ b/pkgs/tools/package-management/akku/akkuDerivation.nix @@ -1,97 +1,126 @@ -{ stdenv, akku, chez, guile, chibi, makeWrapper, lib, writeShellScriptBin }: -{ pname, version, src, buildInputs ? [ ], r7rs ? false, nativeBuildInputs ? [ ], ... } @ args: +{ + stdenv, + akku, + chez, + guile, + chibi, + makeWrapper, + lib, + writeShellScriptBin, +}: +{ + pname, + version, + src, + buildInputs ? [ ], + r7rs ? false, + nativeBuildInputs ? [ ], + ... +}@args: let - parse-akku_ = writeShellScriptBin "parse-akku" - "${guile}/bin/guile --no-auto-compile ${./parse-akku.scm} \"$@\""; + parse-akku_ = writeShellScriptBin "parse-akku" "${guile}/bin/guile --no-auto-compile ${./parse-akku.scm} \"$@\""; parse-akku = "${parse-akku_}/bin/parse-akku"; in -stdenv.mkDerivation ({ - inherit version src; - - pname = "akku-${pname}"; - propagatedBuildInputs = buildInputs; - buildInputs = [ ]; - nativeBuildInputs = [ makeWrapper akku chez chibi ] ++ nativeBuildInputs; - buildPhase = '' - runHook preBuild - - # only install the project - rm -f Akku.lock Akku.manifest - - akku install - - # make sure akku metadata is present during testing and onwards - echo $PWD $CHEZSCHEMELIBDIRS \ - | sed "s/:/ /g" \ - | xargs find \ - | grep "metadata.sls" \ - | xargs ${parse-akku} merge ${pname} ${version} > temp___ - mv temp___ .akku/lib/akku/metadata.sls - - runHook postBuild - ''; - checkPhase = '' - IS_R7RS=false - runHook preCheck - - - propagated_chez=$CHEZSCHEMELIBDIRS - propagated_chibi=$CHIBI_MODULE_PATH - - export CHEZSCHEMELIBDIRS="$PWD/.akku/lib:$CHEZSCHEMELIBDIRS" - export CHIBI_MODULE_PATH="$PWD/.akku/lib:$CHIBI_MODULE_PATH" - - # Run all test .sps files if they exist - # and run tests for libs mirrored from snow-fort. - for path in $(find test* -type f | grep -e "\.sps") \ - $(find . | grep "run-test" | grep "\.scm"); do - echo Running test: $path - [[ "\n$SKIP\n" =~ $(basename $path) ]] && continue - if [ -x $path ]; then - patchShebangs $path - ./$path - elif ${lib.trivial.boolToString r7rs}; then - chibi-scheme $path - else - scheme-script $path - fi - done - - runHook postCheck - - export CHEZSCHEMELIBDIRS=$propagated_chez - export CHIBI_MODULE_PATH=$propagated_chibi - ''; - doCheck = true; - installPhase = '' - runHook preInstall - - mkdir -p $out/lib - - cd .akku - - rm -f bin/activate* - - cp -rL lib $out/lib/scheme-libs - cp -rL bin $out/bin - - [ -d ffi ] && cp -rL ffi $out/lib - [ -d libobj ] && cp -rL libobj $out/lib - - CHEZSCHEMELIBDIRS="$out/lib/scheme-libs:$CHEZSCHEMELIBDIRS" - - # add support for other schemes - for f in $out/bin/* - do - patchShebangs $f - wrapProgram $f \ - --prefix CHEZSCHEMELIBDIRS : $CHEZSCHEMELIBDIRS - done - - runHook postInstall - ''; - meta = { - inherit (akku.meta) platforms; - } // args.meta or { }; - setupHook = ./setup-hook.sh; -} // builtins.removeAttrs args [ "name" "buildInputs" "meta" "nativeBuildInputs" ]) +stdenv.mkDerivation ( + { + inherit version src; + + pname = "akku-${pname}"; + propagatedBuildInputs = buildInputs; + buildInputs = [ ]; + nativeBuildInputs = [ + makeWrapper + akku + chez + chibi + ] ++ nativeBuildInputs; + buildPhase = '' + runHook preBuild + + # only install the project + rm -f Akku.lock Akku.manifest + + akku install + + # make sure akku metadata is present during testing and onwards + echo $PWD $CHEZSCHEMELIBDIRS \ + | sed "s/:/ /g" \ + | xargs find \ + | grep "metadata.sls" \ + | xargs ${parse-akku} merge ${pname} ${version} > temp___ + mv temp___ .akku/lib/akku/metadata.sls + + runHook postBuild + ''; + checkPhase = '' + IS_R7RS=false + runHook preCheck + + + propagated_chez=$CHEZSCHEMELIBDIRS + propagated_chibi=$CHIBI_MODULE_PATH + + export CHEZSCHEMELIBDIRS="$PWD/.akku/lib:$CHEZSCHEMELIBDIRS" + export CHIBI_MODULE_PATH="$PWD/.akku/lib:$CHIBI_MODULE_PATH" + + # Run all test .sps files if they exist + # and run tests for libs mirrored from snow-fort. + for path in $(find test* -type f | grep -e "\.sps") \ + $(find . | grep "run-test" | grep "\.scm"); do + echo Running test: $path + [[ "\n$SKIP\n" =~ $(basename $path) ]] && continue + if [ -x $path ]; then + patchShebangs $path + ./$path + elif ${lib.trivial.boolToString r7rs}; then + chibi-scheme $path + else + scheme-script $path + fi + done + + runHook postCheck + + export CHEZSCHEMELIBDIRS=$propagated_chez + export CHIBI_MODULE_PATH=$propagated_chibi + ''; + doCheck = true; + installPhase = '' + runHook preInstall + + mkdir -p $out/lib + + cd .akku + + rm -f bin/activate* + + cp -rL lib $out/lib/scheme-libs + cp -rL bin $out/bin + + [ -d ffi ] && cp -rL ffi $out/lib + [ -d libobj ] && cp -rL libobj $out/lib + + CHEZSCHEMELIBDIRS="$out/lib/scheme-libs:$CHEZSCHEMELIBDIRS" + + # add support for other schemes + for f in $out/bin/* + do + patchShebangs $f + wrapProgram $f \ + --prefix CHEZSCHEMELIBDIRS : $CHEZSCHEMELIBDIRS + done + + runHook postInstall + ''; + meta = { + inherit (akku.meta) platforms; + } // args.meta or { }; + setupHook = ./setup-hook.sh; + } + // builtins.removeAttrs args [ + "name" + "buildInputs" + "meta" + "nativeBuildInputs" + ] +) diff --git a/pkgs/tools/package-management/akku/default.nix b/pkgs/tools/package-management/akku/default.nix index bb1fc6c1e2563d..cc036dfa5c69ad 100644 --- a/pkgs/tools/package-management/akku/default.nix +++ b/pkgs/tools/package-management/akku/default.nix @@ -1,4 +1,8 @@ -{ lib, newScope, fetchurl }: +{ + lib, + newScope, + fetchurl, +}: lib.makeScope newScope (self: rec { akkuDerivation = self.callPackage ./akkuDerivation.nix { }; akku = self.callPackage ./akku.nix { }; @@ -6,8 +10,20 @@ lib.makeScope newScope (self: rec { akkuPackages = let overrides = self.callPackage ./overrides.nix { }; - makeAkkuPackage = akkuself: pname: - { version, dependencies, dev-dependencies, license, url, sha256, source, synopsis ? "", homepage ? "", ... }: + makeAkkuPackage = + akkuself: pname: + { + version, + dependencies, + dev-dependencies, + license, + url, + sha256, + source, + synopsis ? "", + homepage ? "", + ... + }: (akkuDerivation { pname = "akku-${pname}"; inherit version; @@ -23,36 +39,40 @@ lib.makeScope newScope (self: rec { meta.description = synopsis; meta.license = let - stringToLicense = s: (lib.licenses // (with lib.licenses; { - "agpl" = agpl3Only; - "artistic" = artistic2; - "bsd" = bsd3; - "bsd-1-clause" = bsd1; - "bsd-2-clause" = bsd2; - "bsd-3-clause" = bsd3; - "gpl" = gpl3Only; - "gpl-2" = gpl2Only; - "gplv2" = gpl2Only; - "gpl-3" = gpl3Only; - "gpl-3.0" = gpl3Only; - "gplv3" = gpl3Only; - "lgpl" = lgpl3Only; - "lgpl-2" = lgpl2Only; - "lgpl-2.0+" = lgpl2Plus; - "lgpl-2.1" = lgpl21Only; - "lgpl-2.1-or-later" = lgpl21Plus; - "lgpl-3" = lgpl3Only; - "lgplv3" = lgpl3Only; - "public-domain" = publicDomain; - "srfi" = bsd3; - "unicode" = ucd; - "zlib-acknowledgement" = zlib; - })).${s} or s; + stringToLicense = + s: + ( + lib.licenses + // (with lib.licenses; { + "agpl" = agpl3Only; + "artistic" = artistic2; + "bsd" = bsd3; + "bsd-1-clause" = bsd1; + "bsd-2-clause" = bsd2; + "bsd-3-clause" = bsd3; + "gpl" = gpl3Only; + "gpl-2" = gpl2Only; + "gplv2" = gpl2Only; + "gpl-3" = gpl3Only; + "gpl-3.0" = gpl3Only; + "gplv3" = gpl3Only; + "lgpl" = lgpl3Only; + "lgpl-2" = lgpl2Only; + "lgpl-2.0+" = lgpl2Plus; + "lgpl-2.1" = lgpl21Only; + "lgpl-2.1-or-later" = lgpl21Plus; + "lgpl-3" = lgpl3Only; + "lgplv3" = lgpl3Only; + "public-domain" = publicDomain; + "srfi" = bsd3; + "unicode" = ucd; + "zlib-acknowledgement" = zlib; + }) + ).${s} or s; in - if builtins.isList license - then map stringToLicense license - else stringToLicense license; - }).overrideAttrs ({ "${pname}" = lib.id; } // overrides)."${pname}"; + if builtins.isList license then map stringToLicense license else stringToLicense license; + }).overrideAttrs + ({ "${pname}" = lib.id; } // overrides)."${pname}"; deps = lib.importTOML ./deps.toml; packages = lib.makeScope self.newScope (akkuself: lib.mapAttrs (makeAkkuPackage akkuself) deps); in diff --git a/pkgs/tools/package-management/appimage-run/default.nix b/pkgs/tools/package-management/appimage-run/default.nix index cf44e665510ed2..107da1eb8842a7 100644 --- a/pkgs/tools/package-management/appimage-run/default.nix +++ b/pkgs/tools/package-management/appimage-run/default.nix @@ -1,9 +1,10 @@ -{ lib -, appimageTools -, buildFHSEnv -, makeDesktopItem -, extraPkgs ? pkgs: [] -, appimage-run-tests ? null +{ + lib, + appimageTools, + buildFHSEnv, + makeDesktopItem, + extraPkgs ? pkgs: [ ], + appimage-run-tests ? null, }: let @@ -17,21 +18,29 @@ let desktopName = name; genericName = "AppImage runner"; noDisplay = true; - mimeTypes = ["application/vnd.appimage" "application/x-iso9660-appimage"]; - categories = ["PackageManager" "Utility"]; + mimeTypes = [ + "application/vnd.appimage" + "application/x-iso9660-appimage" + ]; + categories = [ + "PackageManager" + "Utility" + ]; }; -in buildFHSEnv (lib.recursiveUpdate fhsArgs { - inherit name; +in +buildFHSEnv ( + lib.recursiveUpdate fhsArgs { + inherit name; - targetPkgs = pkgs: [ appimageTools.appimage-exec ] - ++ fhsArgs.targetPkgs pkgs ++ extraPkgs pkgs; - runScript = "appimage-exec.sh"; + targetPkgs = pkgs: [ appimageTools.appimage-exec ] ++ fhsArgs.targetPkgs pkgs ++ extraPkgs pkgs; + runScript = "appimage-exec.sh"; - extraInstallCommands = '' - cp --recursive "${desktopItem}/share" "$out/" - ''; + extraInstallCommands = '' + cp --recursive "${desktopItem}/share" "$out/" + ''; - passthru.tests.appimage-run = appimage-run-tests; + passthru.tests.appimage-run = appimage-run-tests; - meta.mainProgram = "appimage-run"; -}) + meta.mainProgram = "appimage-run"; + } +) diff --git a/pkgs/tools/package-management/appimage-run/test.nix b/pkgs/tools/package-management/appimage-run/test.nix index 8a6e2709512355..1888790810cc18 100644 --- a/pkgs/tools/package-management/appimage-run/test.nix +++ b/pkgs/tools/package-management/appimage-run/test.nix @@ -1,17 +1,30 @@ -{ runCommand, fetchurl, appimage-run, glibcLocales, file, xdg-utils }: +{ + runCommand, + fetchurl, + appimage-run, + glibcLocales, + file, + xdg-utils, +}: let # any AppImage usable on cli, really sample-appImage = fetchurl { url = "https://github.com/AppImage/AppImageKit/releases/download/12/appimagetool-x86_64.AppImage"; - sha256 = "04ws94q71bwskmhizhwmaf41ma4wabvfgjgkagr8wf3vakgv866r"; + sha256 = "04ws94q71bwskmhizhwmaf41ma4wabvfgjgkagr8wf3vakgv866r"; }; owdtest = fetchurl { url = "https://github.com/NixOS/nixpkgs/files/10099048/owdtest.AppImage.gz"; sha256 = "sha256-EEp9dxz/+l5XkNaVBFgv5v64sizQILnljRAzwXv/yV8="; }; in - runCommand "appimage-run-tests" { - buildInputs = [ appimage-run glibcLocales file xdg-utils ]; +runCommand "appimage-run-tests" + { + buildInputs = [ + appimage-run + glibcLocales + file + xdg-utils + ]; meta.platforms = [ "x86_64-linux" ]; } '' diff --git a/pkgs/tools/package-management/apt-dater/default.nix b/pkgs/tools/package-management/apt-dater/default.nix index ec9c53f7d78c46..0d01319ea76210 100644 --- a/pkgs/tools/package-management/apt-dater/default.nix +++ b/pkgs/tools/package-management/apt-dater/default.nix @@ -1,6 +1,16 @@ -{ lib, stdenv, fetchFromGitHub -, autoreconfHook, pkg-config, gettext -, xxd, glib, libxml2, ncurses, popt, screen +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + gettext, + xxd, + glib, + libxml2, + ncurses, + popt, + screen, }: stdenv.mkDerivation rec { @@ -15,11 +25,18 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ - pkg-config autoreconfHook gettext xxd + pkg-config + autoreconfHook + gettext + xxd ]; buildInputs = [ - libxml2 ncurses glib popt screen + libxml2 + ncurses + glib + popt + screen ]; configureFlags = [ "--disable-history" ]; diff --git a/pkgs/tools/package-management/disnix/DisnixWebService/default.nix b/pkgs/tools/package-management/disnix/DisnixWebService/default.nix index e486f0b1300e82..5826280a22f6e7 100644 --- a/pkgs/tools/package-management/disnix/DisnixWebService/default.nix +++ b/pkgs/tools/package-management/disnix/DisnixWebService/default.nix @@ -1,4 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, fetchpatch, ant, jdk, xmlstarlet, axis2, dbus_java }: +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + ant, + jdk, + xmlstarlet, + axis2, + dbus_java, +}: stdenv.mkDerivation (finalAttrs: { pname = "DisnixWebService"; diff --git a/pkgs/tools/package-management/disnix/default.nix b/pkgs/tools/package-management/disnix/default.nix index e126c133108de8..21d6dc440ac15d 100644 --- a/pkgs/tools/package-management/disnix/default.nix +++ b/pkgs/tools/package-management/disnix/default.nix @@ -1,4 +1,17 @@ -{ lib, stdenv, fetchurl, fetchpatch, pkg-config, glib, libxml2, libxslt, getopt, dysnomia, libintl, libiconv }: +{ + lib, + stdenv, + fetchurl, + fetchpatch, + pkg-config, + glib, + libxml2, + libxslt, + getopt, + dysnomia, + libintl, + libiconv, +}: stdenv.mkDerivation rec { pname = "disnix"; @@ -20,12 +33,23 @@ stdenv.mkDerivation rec { ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ glib libxml2 libxslt getopt libintl libiconv dysnomia ]; + buildInputs = [ + glib + libxml2 + libxslt + getopt + libintl + libiconv + dysnomia + ]; meta = { description = "Nix-based distributed service deployment tool"; license = lib.licenses.lgpl21Plus; - maintainers = with lib.maintainers; [ sander tomberek ]; + maintainers = with lib.maintainers; [ + sander + tomberek + ]; platforms = lib.platforms.unix; }; } diff --git a/pkgs/tools/package-management/disnix/dysnomia/default.nix b/pkgs/tools/package-management/disnix/dysnomia/default.nix index 92b880d1428fd5..0180b9ddab77d0 100644 --- a/pkgs/tools/package-management/disnix/dysnomia/default.nix +++ b/pkgs/tools/package-management/disnix/dysnomia/default.nix @@ -1,29 +1,43 @@ -{ lib, stdenv, fetchurl, netcat +{ + lib, + stdenv, + fetchurl, + netcat, -# Optional packages -, systemd ? null, ejabberd ? null, mariadb ? null, postgresql ? null, subversion ? null -, mongodb ? null, mongodb-tools ? null, influxdb ? null, supervisor ? null, docker ? null -, nginx ? null, s6-rc ? null, xinetd ? null + # Optional packages + systemd ? null, + ejabberd ? null, + mariadb ? null, + postgresql ? null, + subversion ? null, + mongodb ? null, + mongodb-tools ? null, + influxdb ? null, + supervisor ? null, + docker ? null, + nginx ? null, + s6-rc ? null, + xinetd ? null, -# Configuration flags -, enableApacheWebApplication ? false -, enableAxis2WebService ? false -, enableEjabberdDump ? false -, enableMySQLDatabase ? false -, enablePostgreSQLDatabase ? false -, enableSubversionRepository ? false -, enableTomcatWebApplication ? false -, enableMongoDatabase ? false -, enableInfluxDatabase ? false -, enableSupervisordProgram ? false -, enableDockerContainer ? false -, enableNginxWebApplication ? false -, enableXinetdService ? false -, enableS6RCService ? false -, enableLegacy ? false -, catalinaBaseDir ? "/var/tomcat" -, jobTemplate ? "systemd" -, getopt + # Configuration flags + enableApacheWebApplication ? false, + enableAxis2WebService ? false, + enableEjabberdDump ? false, + enableMySQLDatabase ? false, + enablePostgreSQLDatabase ? false, + enableSubversionRepository ? false, + enableTomcatWebApplication ? false, + enableMongoDatabase ? false, + enableInfluxDatabase ? false, + enableSupervisordProgram ? false, + enableDockerContainer ? false, + enableNginxWebApplication ? false, + enableXinetdService ? false, + enableS6RCService ? false, + enableLegacy ? false, + catalinaBaseDir ? "/var/tomcat", + jobTemplate ? "systemd", + getopt, }: assert enableMySQLDatabase -> mariadb != null; @@ -47,31 +61,38 @@ stdenv.mkDerivation rec { }; configureFlags = [ - (if enableApacheWebApplication then "--with-apache" else "--without-apache") - (if enableAxis2WebService then "--with-axis2" else "--without-axis2") - (if enableEjabberdDump then "--with-ejabberd" else "--without-ejabberd") - (if enableMySQLDatabase then "--with-mysql" else "--without-mysql") - (if enablePostgreSQLDatabase then "--with-postgresql" else "--without-postgresql") - (if enableSubversionRepository then "--with-subversion" else "--without-subversion") - (if enableTomcatWebApplication then "--with-tomcat=${catalinaBaseDir}" else "--without-tomcat") - (if enableMongoDatabase then "--with-mongodb" else "--without-mongodb") - (if enableInfluxDatabase then "--with-influxdb" else "--without-influxdb") - (if enableSupervisordProgram then "--with-supervisord" else "--without-supervisord") - (if enableDockerContainer then "--with-docker" else "--without-docker") - (if enableNginxWebApplication then "--with-nginx" else "--without-nginx") - (if enableXinetdService then "--with-xinetd" else "--without-xinetd") - (if enableS6RCService then "--with-s6-rc" else "--without-s6-rc") - (if stdenv.hostPlatform.isDarwin then "--with-launchd" else "--without-launchd") - "--with-job-template=${jobTemplate}" - ] ++ lib.optional enableLegacy "--enable-legacy"; + (if enableApacheWebApplication then "--with-apache" else "--without-apache") + (if enableAxis2WebService then "--with-axis2" else "--without-axis2") + (if enableEjabberdDump then "--with-ejabberd" else "--without-ejabberd") + (if enableMySQLDatabase then "--with-mysql" else "--without-mysql") + (if enablePostgreSQLDatabase then "--with-postgresql" else "--without-postgresql") + (if enableSubversionRepository then "--with-subversion" else "--without-subversion") + (if enableTomcatWebApplication then "--with-tomcat=${catalinaBaseDir}" else "--without-tomcat") + (if enableMongoDatabase then "--with-mongodb" else "--without-mongodb") + (if enableInfluxDatabase then "--with-influxdb" else "--without-influxdb") + (if enableSupervisordProgram then "--with-supervisord" else "--without-supervisord") + (if enableDockerContainer then "--with-docker" else "--without-docker") + (if enableNginxWebApplication then "--with-nginx" else "--without-nginx") + (if enableXinetdService then "--with-xinetd" else "--without-xinetd") + (if enableS6RCService then "--with-s6-rc" else "--without-s6-rc") + (if stdenv.hostPlatform.isDarwin then "--with-launchd" else "--without-launchd") + "--with-job-template=${jobTemplate}" + ] ++ lib.optional enableLegacy "--enable-legacy"; - buildInputs = [ getopt netcat ] + buildInputs = + [ + getopt + netcat + ] ++ lib.optional stdenv.hostPlatform.isLinux systemd ++ lib.optional enableEjabberdDump ejabberd ++ lib.optional enableMySQLDatabase mariadb.out ++ lib.optional enablePostgreSQLDatabase postgresql ++ lib.optional enableSubversionRepository subversion - ++ lib.optionals enableMongoDatabase [ mongodb mongodb-tools ] + ++ lib.optionals enableMongoDatabase [ + mongodb + mongodb-tools + ] ++ lib.optional enableInfluxDatabase influxdb ++ lib.optional enableSupervisordProgram supervisor ++ lib.optional enableDockerContainer docker diff --git a/pkgs/tools/package-management/elm-github-install/default.nix b/pkgs/tools/package-management/elm-github-install/default.nix index 3c77af2b82bf53..d5b945fcb205b6 100644 --- a/pkgs/tools/package-management/elm-github-install/default.nix +++ b/pkgs/tools/package-management/elm-github-install/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerEnv, ruby, bundlerUpdateScript }: +{ + lib, + bundlerEnv, + ruby, + bundlerUpdateScript, +}: bundlerEnv rec { pname = "elm_install"; @@ -13,10 +18,13 @@ bundlerEnv rec { meta = with lib; { description = "Install Elm packages from git repositories"; - homepage = "https://github.com/gdotdesign/elm-github-install"; - license = licenses.unfree; - maintainers = with maintainers; [ roberth nicknovitski ]; - platforms = platforms.all; + homepage = "https://github.com/gdotdesign/elm-github-install"; + license = licenses.unfree; + maintainers = with maintainers; [ + roberth + nicknovitski + ]; + platforms = platforms.all; mainProgram = "elm-install"; }; } diff --git a/pkgs/tools/package-management/elm-github-install/gemset.nix b/pkgs/tools/package-management/elm-github-install/gemset.nix index de7f8e20b6480f..ae92f3cf665a2d 100644 --- a/pkgs/tools/package-management/elm-github-install/gemset.nix +++ b/pkgs/tools/package-management/elm-github-install/gemset.nix @@ -1,7 +1,7 @@ { adts = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1793bfsgg8ca58b70xas9rglnspig41ih0iwqcad62s0grxzrjwz"; type = "gem"; }; @@ -9,7 +9,7 @@ }; commander = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qx76y05v29kgyjsfkai73gwfnqhypp1k8v024m9w7qzpv4mpxf"; type = "gem"; }; @@ -17,7 +17,7 @@ }; contracts = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "119f5p1n6r5svbx8h09za6a4vrsnj5i1pzr9cqdn9hj3wrxvyl3a"; type = "gem"; }; @@ -25,7 +25,7 @@ }; elm_install = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0d3fwhj54madabmzamss865kj8czicgaq5fbdll9kpapqvy6a2j5"; type = "gem"; }; @@ -33,7 +33,7 @@ }; git = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1waikaggw7a1d24nw0sh8fd419gbf7awh000qhsf411valycj6q3"; type = "gem"; }; @@ -41,7 +41,7 @@ }; git_clone_url = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qgq7pjl461si3m2gr28vwbx47dcbpyy682mcwra5y1klpkbcvr5"; type = "gem"; }; @@ -49,7 +49,7 @@ }; hashdiff = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n6hj7k7b9hazac0j48ypbak2nqi5wy4nh5cjra6xl3a92r8db0a"; type = "gem"; }; @@ -57,7 +57,7 @@ }; highline = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nf5lgdn6ni2lpfdn4gk3gi47fmnca2bdirabbjbz1fk9w4p8lkr"; type = "gem"; }; @@ -65,7 +65,7 @@ }; indentation = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ix64qgmm91xm1yiqxdcn9bqb1l6gwvkv7322yni34b3bd16lgvc"; type = "gem"; }; @@ -73,7 +73,7 @@ }; molinillo = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19h1nks0x2ljwyijs2rd1f9sh05j8xqvjaqk1rslp5nyy6h4a758"; type = "gem"; }; @@ -81,7 +81,7 @@ }; semverse = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cf6iv5wgwb7b8jf7il751223k9yahz9aym06s9r0prda5mwddyy"; type = "gem"; }; @@ -89,7 +89,7 @@ }; smart_colored = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hccah5iwsvn9rf7zdgl7mdbh0h63vfwy1c6d280cb9qkfj8rdny"; type = "gem"; }; @@ -97,7 +97,7 @@ }; solve = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bbzny2bl94mv1xwcfrxbi3fjhxxawlz6la7mip2wwz9kkaf376h"; type = "gem"; }; @@ -105,7 +105,7 @@ }; uri-ssh_git = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0klyyvivbjll2ry18d8fhm1rbxbzd4kqa9lskxyiha4ndlb22cqj"; type = "gem"; }; diff --git a/pkgs/tools/package-management/fpm/default.nix b/pkgs/tools/package-management/fpm/default.nix index 6be2687d67adce..d3da891a7ae1af 100644 --- a/pkgs/tools/package-management/fpm/default.nix +++ b/pkgs/tools/package-management/fpm/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "fpm"; @@ -9,10 +13,13 @@ bundlerApp { meta = with lib; { description = "Tool to build packages for multiple platforms with ease"; - homepage = "https://github.com/jordansissel/fpm"; - license = licenses.mit; - maintainers = with maintainers; [ manveru nicknovitski ]; - platforms = platforms.unix; + homepage = "https://github.com/jordansissel/fpm"; + license = licenses.mit; + maintainers = with maintainers; [ + manveru + nicknovitski + ]; + platforms = platforms.unix; mainProgram = "fpm"; }; } diff --git a/pkgs/tools/package-management/fpm/gemset.nix b/pkgs/tools/package-management/fpm/gemset.nix index 195073f7546e61..098acbd2ae496e 100644 --- a/pkgs/tools/package-management/fpm/gemset.nix +++ b/pkgs/tools/package-management/fpm/gemset.nix @@ -1,111 +1,126 @@ { arr-pm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fddw0vwdrr7v3a0lfqbmnd664j48a9psrjd3wh3k4i3flplizzx"; type = "gem"; }; version = "0.0.12"; }; backports = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1f3zcy0q88rw3clk0r7bai7sp4r253lndf0qmdgczq1ykbm219w3"; type = "gem"; }; version = "3.24.1"; }; cabin = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b3b8j3iqnagjfn1261b9ncaac9g44zrx1kcg81yg4z9i513kici"; type = "gem"; }; version = "0.9.0"; }; clamp = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jb6l4scp69xifhicb5sffdixqkw8wgkk9k2q57kh2y36x1px9az"; type = "gem"; }; version = "1.0.1"; }; dotenv = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n0pi8x8ql5h1mijvm8lgn6bhq4xjb5a500p5r1krq4s6j9lg565"; type = "gem"; }; version = "2.8.1"; }; fpm = { - dependencies = ["arr-pm" "backports" "cabin" "clamp" "pleaserun" "rexml" "stud"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "arr-pm" + "backports" + "cabin" + "clamp" + "pleaserun" + "rexml" + "stud" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1grd0lb0mw1jvw6l8zqgh49m9gg2jxn98rifq2spzacwm11g7yqz"; type = "gem"; }; version = "1.15.1"; }; insist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bw3bdwns14mapbgb8cbjmr0amvwz8y72gyclq04xp43wpp5jrvg"; type = "gem"; }; version = "1.0.0"; }; mustache = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g5hplm0k06vwxwqzwn1mq5bd02yp0h3rym4zwzw26aqi7drcsl2"; type = "gem"; }; version = "0.99.8"; }; pleaserun = { - dependencies = ["cabin" "clamp" "dotenv" "insist" "mustache" "stud"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "cabin" + "clamp" + "dotenv" + "insist" + "mustache" + "stud" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1aykf0l8327bqkkf5xd9jcglsib973zpy37cfnlf4j0vp0cdpn2d"; type = "gem"; }; version = "0.0.32"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05i8518ay14kjbma550mv0jm8a6di8yp5phzrd8rj44z9qnrlrp0"; type = "gem"; }; version = "3.2.6"; }; stud = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qpb57cbpm9rwgsygqxifca0zma87drnlacv49cqs2n5iyi6z8kb"; type = "gem"; }; diff --git a/pkgs/tools/package-management/fusesoc/default.nix b/pkgs/tools/package-management/fusesoc/default.nix index 26e27738d647f6..ccadb2a71a1fbf 100644 --- a/pkgs/tools/package-management/fusesoc/default.nix +++ b/pkgs/tools/package-management/fusesoc/default.nix @@ -1,16 +1,17 @@ -{ buildPythonPackage -, fetchPypi -, lib -, iverilog -, verilator -, gnumake -, edalize -, fastjsonschema -, pyparsing -, pyyaml -, simplesat -, ipyxact -, setuptools-scm +{ + buildPythonPackage, + fetchPypi, + lib, + iverilog, + verilator, + gnumake, + edalize, + fastjsonschema, + pyparsing, + pyyaml, + simplesat, + ipyxact, + setuptools-scm, }: buildPythonPackage rec { pname = "fusesoc"; @@ -23,11 +24,26 @@ buildPythonPackage rec { nativeBuildInputs = [ setuptools-scm ]; - propagatedBuildInputs = [ edalize fastjsonschema pyparsing pyyaml simplesat ipyxact ]; + propagatedBuildInputs = [ + edalize + fastjsonschema + pyparsing + pyyaml + simplesat + ipyxact + ]; pythonImportsCheck = [ "fusesoc" ]; - makeWrapperArgs = [ "--suffix PATH : ${lib.makeBinPath [ iverilog verilator gnumake ]}"]; + makeWrapperArgs = [ + "--suffix PATH : ${ + lib.makeBinPath [ + iverilog + verilator + gnumake + ] + }" + ]; meta = with lib; { homepage = "https://github.com/olofk/fusesoc"; diff --git a/pkgs/tools/package-management/gx/default.nix b/pkgs/tools/package-management/gx/default.nix index 8d9fa95f09c573..d78c07643b6039 100644 --- a/pkgs/tools/package-management/gx/default.nix +++ b/pkgs/tools/package-management/gx/default.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gx"; @@ -13,7 +17,10 @@ buildGoModule rec { vendorHash = "sha256-6tdVpMztaBjoQRVG2vaUWuvnPq05zjbNAX9HBiC50t0="; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { description = "Packaging tool built around IPFS"; diff --git a/pkgs/tools/package-management/libcomps/default.nix b/pkgs/tools/package-management/libcomps/default.nix index 2a1136034d21ee..048c6af62c3a74 100644 --- a/pkgs/tools/package-management/libcomps/default.nix +++ b/pkgs/tools/package-management/libcomps/default.nix @@ -1,21 +1,26 @@ -{ lib -, check -, cmake -, doxygen -, expat -, fetchFromGitHub -, libxml2 -, python -, sphinx -, stdenv -, zlib +{ + lib, + check, + cmake, + doxygen, + expat, + fetchFromGitHub, + libxml2, + python, + sphinx, + stdenv, + zlib, }: stdenv.mkDerivation rec { pname = "libcomps"; version = "0.1.21"; - outputs = [ "out" "dev" "py" ]; + outputs = [ + "out" + "dev" + "py" + ]; src = fetchFromGitHub { owner = "rpm-software-management"; diff --git a/pkgs/tools/package-management/licensee/default.nix b/pkgs/tools/package-management/licensee/default.nix index 02e5f919fb58d6..dcb6b7417706a6 100644 --- a/pkgs/tools/package-management/licensee/default.nix +++ b/pkgs/tools/package-management/licensee/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "licensee"; @@ -9,10 +13,10 @@ bundlerApp { meta = with lib; { description = "Ruby Gem to detect under what license a project is distributed"; - homepage = "https://licensee.github.io/licensee/"; - license = licenses.mit; + homepage = "https://licensee.github.io/licensee/"; + license = licenses.mit; maintainers = [ maintainers.sternenseemann ]; - platforms = platforms.unix; + platforms = platforms.unix; mainProgram = "licensee"; }; } diff --git a/pkgs/tools/package-management/licensee/gemset.nix b/pkgs/tools/package-management/licensee/gemset.nix index 0a850ba8758bc5..032f6c9433a792 100644 --- a/pkgs/tools/package-management/licensee/gemset.nix +++ b/pkgs/tools/package-management/licensee/gemset.nix @@ -1,166 +1,185 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0irbdwkkjwzajq1ip6ba46q49sxnrl2cw7ddkdhsfhb6aprnm3vr"; type = "gem"; }; version = "2.8.6"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; dotenv = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n0pi8x8ql5h1mijvm8lgn6bhq4xjb5a500p5r1krq4s6j9lg565"; type = "gem"; }; version = "2.8.1"; }; faraday = { - dependencies = ["base64" "faraday-net_http" "ruby2_keywords"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "faraday-net_http" + "ruby2_keywords" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "19p45ryrvxff6ggdj4fq76dk7wlkfgrh474c3kwzdsjx3xpdq8x8"; type = "gem"; }; version = "2.8.1"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13byv3mp1gsjyv8k0ih4612y6vw5kqva6i03wcg4w2fqpsd950k8"; type = "gem"; }; version = "3.0.2"; }; licensee = { - dependencies = ["dotenv" "octokit" "reverse_markdown" "rugged" "thor"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "dotenv" + "octokit" + "reverse_markdown" + "rugged" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "05g5w9c4jlfhwn0hfz117s1c7hfdm5yn7cywr4mah7xr41yvbh04"; type = "gem"; }; version = "9.16.1"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kl9c3kdchjabrihdqfmcplk3lq4cw1rr9f378y6q22qwy5dndvs"; type = "gem"; }; version = "2.8.5"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1l8b0i24h4irivyhwy9xmkjbggw86cxkzkiqdqg0jpcp9qc8h4rl"; type = "gem"; }; version = "1.16.0"; }; octokit = { - dependencies = ["faraday" "sawyer"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "faraday" + "sawyer" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "11fhv1a43c51jkgmqf62aypf9yw74lc6ph4qmzsh2bydwwzbwqn3"; type = "gem"; }; version = "8.0.0"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bni4qjrsh2q49pnmmd6if4iv3ak36bd2cckrs6npl111n769k9m"; type = "gem"; }; version = "5.0.4"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01b9662zd2x9bp4rdjfid07h09zxj7kvn7f5fghbqhzc625ap1dp"; type = "gem"; }; version = "1.7.3"; }; reverse_markdown = { - dependencies = ["nokogiri"]; - groups = ["default"]; - platforms = []; + dependencies = [ "nokogiri" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0087vhw5ik50lxvddicns01clkx800fk5v5qnrvi3b42nrk6885j"; type = "gem"; }; version = "2.1.1"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; rugged = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02m9zksfy3dwzhbv56xq2wwmlghca5209hdg895pi2x2d2sbkahi"; type = "gem"; }; version = "1.7.1"; }; sawyer = { - dependencies = ["addressable" "faraday"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "faraday" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1jks1qjbmqm8f9kvwa81vqj39avaj9wdnzc531xm29a55bb74fps"; type = "gem"; }; version = "0.9.2"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1hx77jxkrwi66yvs10wfxqa8s25ds25ywgrrf66acm9nbfg7zp0s"; type = "gem"; }; diff --git a/pkgs/tools/package-management/lix/common.nix b/pkgs/tools/package-management/lix/common.nix index d39ddeda3ab277..19c7ddc5883379 100644 --- a/pkgs/tools/package-management/lix/common.nix +++ b/pkgs/tools/package-management/lix/common.nix @@ -195,7 +195,9 @@ stdenv.mkDerivation { (lib.mesonBool "enable-tests" true) (lib.mesonBool "enable-docs" enableDocumentation) (lib.mesonEnable "internal-api-docs" enableDocumentation) - (lib.mesonBool "enable-embedded-sandbox-shell" (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isStatic)) + (lib.mesonBool "enable-embedded-sandbox-shell" ( + stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isStatic + )) (lib.mesonEnable "seccomp-sandboxing" withLibseccomp) (lib.mesonOption "store-dir" storeDir) @@ -265,13 +267,14 @@ stdenv.mkDerivation { meson test --no-rebuild "''${flagsArray[@]}" runHook postInstallCheck ''; - hardeningDisable = [ - "shadowstack" - # strictoverflow is disabled because we trap on signed overflow instead - "strictoverflow" - ] - # fortify breaks the build with lto and musl for some reason - ++ lib.optional stdenv.hostPlatform.isMusl "fortify"; + hardeningDisable = + [ + "shadowstack" + # strictoverflow is disabled because we trap on signed overflow instead + "strictoverflow" + ] + # fortify breaks the build with lto and musl for some reason + ++ lib.optional stdenv.hostPlatform.isMusl "fortify"; # hardeningEnable = lib.optionals (!stdenv.hostPlatform.isDarwin) [ "pie" ]; separateDebugInfo = stdenv.hostPlatform.isLinux && !enableStatic; diff --git a/pkgs/tools/package-management/lix/doc/default.nix b/pkgs/tools/package-management/lix/doc/default.nix index b19f3bd2a170dd..994310931e7de2 100644 --- a/pkgs/tools/package-management/lix/doc/default.nix +++ b/pkgs/tools/package-management/lix/doc/default.nix @@ -3,11 +3,16 @@ rustPlatform, version, cargoHash ? null, - cargoLock ? null + cargoLock ? null, }: rustPlatform.buildRustPackage { pname = "lix-doc"; sourceRoot = "${src.name or src}/lix-doc"; - inherit version src cargoHash cargoLock; + inherit + version + src + cargoHash + cargoLock + ; } diff --git a/pkgs/tools/package-management/nix-du/default.nix b/pkgs/tools/package-management/nix-du/default.nix index 69289b8955b758..9a3decc9e05208 100644 --- a/pkgs/tools/package-management/nix-du/default.nix +++ b/pkgs/tools/package-management/nix-du/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, nix -, nlohmann_json -, boost -, graphviz -, Security -, pkg-config +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + nix, + nlohmann_json, + boost, + graphviz, + Security, + pkg-config, }: rustPlatform.buildRustPackage rec { @@ -24,7 +25,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-gE99nCJIi6fsuxzJuU80VWXIZqVbqwBhKM2aRlhmYco="; doCheck = true; - nativeCheckInputs = [ nix graphviz ]; + nativeCheckInputs = [ + nix + graphviz + ]; buildInputs = [ boost @@ -32,7 +36,10 @@ rustPlatform.buildRustPackage rec { nlohmann_json ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; - nativeBuildInputs = [ pkg-config rustPlatform.bindgenHook ]; + nativeBuildInputs = [ + pkg-config + rustPlatform.bindgenHook + ]; meta = with lib; { description = "Tool to determine which gc-roots take space in your nix store"; diff --git a/pkgs/tools/package-management/nix-eval-jobs/default.nix b/pkgs/tools/package-management/nix-eval-jobs/default.nix index 77d3d20624fbdd..fd4c23368fe18a 100644 --- a/pkgs/tools/package-management/nix-eval-jobs/default.nix +++ b/pkgs/tools/package-management/nix-eval-jobs/default.nix @@ -1,14 +1,15 @@ -{ lib -, boost -, cmake -, fetchFromGitHub -, meson -, ninja -, curl -, nix -, nlohmann_json -, pkg-config -, stdenv +{ + lib, + boost, + cmake, + fetchFromGitHub, + meson, + ninja, + curl, + nix, + nlohmann_json, + pkg-config, + stdenv, }: stdenv.mkDerivation rec { pname = "nix-eval-jobs"; @@ -42,7 +43,10 @@ stdenv.mkDerivation rec { description = "Hydra's builtin hydra-eval-jobs as a standalone"; homepage = "https://github.com/nix-community/nix-eval-jobs"; license = lib.licenses.gpl3; - maintainers = with lib.maintainers; [ adisbladis mic92 ]; + maintainers = with lib.maintainers; [ + adisbladis + mic92 + ]; platforms = lib.platforms.unix; mainProgram = "nix-eval-jobs"; }; diff --git a/pkgs/tools/package-management/nix-index/default.nix b/pkgs/tools/package-management/nix-index/default.nix index 433ad82d4d2f82..f9ab5c71204b22 100644 --- a/pkgs/tools/package-management/nix-index/default.nix +++ b/pkgs/tools/package-management/nix-index/default.nix @@ -1,5 +1,13 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, pkg-config, openssl, curl, sqlite -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + curl, + sqlite, + Security, }: rustPlatform.buildRustPackage rec { @@ -16,8 +24,11 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-c1Ivsj9of/cjEKU0lo4I9BfIUQZ3pPf2QF9fAlZTQn0="; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl curl sqlite ] - ++ lib.optional stdenv.hostPlatform.isDarwin Security; + buildInputs = [ + openssl + curl + sqlite + ] ++ lib.optional stdenv.hostPlatform.isDarwin Security; postInstall = '' substituteInPlace command-not-found.sh \ @@ -30,6 +41,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/nix-community/nix-index"; changelog = "https://github.com/nix-community/nix-index/blob/${src.rev}/CHANGELOG.md"; license = with licenses; [ bsd3 ]; - maintainers = with maintainers; [ bennofs figsoda ncfavier ]; + maintainers = with maintainers; [ + bennofs + figsoda + ncfavier + ]; }; } diff --git a/pkgs/tools/package-management/nix-index/wrapper.nix b/pkgs/tools/package-management/nix-index/wrapper.nix index 94611e74c2a569..075d3fb8fb3bac 100644 --- a/pkgs/tools/package-management/nix-index/wrapper.nix +++ b/pkgs/tools/package-management/nix-index/wrapper.nix @@ -1,4 +1,10 @@ -{ lib, symlinkJoin, nix-index-unwrapped, makeWrapper, nix }: +{ + lib, + symlinkJoin, + nix-index-unwrapped, + makeWrapper, + nix, +}: symlinkJoin { inherit (nix-index-unwrapped) name meta; diff --git a/pkgs/tools/package-management/nix-pin/default.nix b/pkgs/tools/package-management/nix-pin/default.nix index 59422ff22cc246..b249652e98194a 100644 --- a/pkgs/tools/package-management/nix-pin/default.nix +++ b/pkgs/tools/package-management/nix-pin/default.nix @@ -1,51 +1,76 @@ -{ lib, pkgs, stdenv, fetchFromGitHub, python3, nix, git, makeWrapper -, runtimeShell }: -let self = stdenv.mkDerivation rec { - pname = "nix-pin"; - version = "0.4.0"; - src = fetchFromGitHub { - owner = "timbertson"; - repo = "nix-pin"; - rev = "version-${version}"; - sha256 = "1pccvc0iqapms7kidrh09g5fdx44x622r5l9k7bkmssp3v4c68vy"; - }; - nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ python3 ]; - installPhase = '' - mkdir "$out" - cp -r bin share "$out" - wrapProgram $out/bin/nix-pin \ - --prefix PATH : "${lib.makeBinPath [ nix git ]}" - ''; - passthru = - let - defaults = import "${self}/share/nix/defaults.nix"; - in { - api = { pinConfig ? defaults.pinConfig }: - let impl = import "${self}/share/nix/api.nix" { inherit pkgs pinConfig; }; in - { inherit (impl) augmentedPkgs pins callPackage; }; - updateScript = '' - #!${runtimeShell} - set -e - echo - cd ${toString ./.} - ${pkgs.nix-update-source}/bin/nix-update-source \ - --prompt version \ - --replace-attr version \ - --set owner timbertson \ - --set repo nix-pin \ - --set type fetchFromGitHub \ - --set rev 'version-{version}' \ - --substitute rev 'version-''${{version}}' \ - --modify-nix default.nix - ''; +{ + lib, + pkgs, + stdenv, + fetchFromGitHub, + python3, + nix, + git, + makeWrapper, + runtimeShell, +}: +let + self = stdenv.mkDerivation rec { + pname = "nix-pin"; + version = "0.4.0"; + src = fetchFromGitHub { + owner = "timbertson"; + repo = "nix-pin"; + rev = "version-${version}"; + sha256 = "1pccvc0iqapms7kidrh09g5fdx44x622r5l9k7bkmssp3v4c68vy"; + }; + nativeBuildInputs = [ makeWrapper ]; + buildInputs = [ python3 ]; + installPhase = '' + mkdir "$out" + cp -r bin share "$out" + wrapProgram $out/bin/nix-pin \ + --prefix PATH : "${ + lib.makeBinPath [ + nix + git + ] + }" + ''; + passthru = + let + defaults = import "${self}/share/nix/defaults.nix"; + in + { + api = + { + pinConfig ? defaults.pinConfig, + }: + let + impl = import "${self}/share/nix/api.nix" { inherit pkgs pinConfig; }; + in + { + inherit (impl) augmentedPkgs pins callPackage; + }; + updateScript = '' + #!${runtimeShell} + set -e + echo + cd ${toString ./.} + ${pkgs.nix-update-source}/bin/nix-update-source \ + --prompt version \ + --replace-attr version \ + --set owner timbertson \ + --set repo nix-pin \ + --set type fetchFromGitHub \ + --set rev 'version-{version}' \ + --substitute rev 'version-''${{version}}' \ + --modify-nix default.nix + ''; + }; + meta = with lib; { + homepage = "https://github.com/timbertson/nix-pin"; + description = "nixpkgs development utility"; + license = licenses.mit; + maintainers = [ maintainers.timbertson ]; + platforms = platforms.all; + mainProgram = "nix-pin"; }; - meta = with lib; { - homepage = "https://github.com/timbertson/nix-pin"; - description = "nixpkgs development utility"; - license = licenses.mit; - maintainers = [ maintainers.timbertson ]; - platforms = platforms.all; - mainProgram = "nix-pin"; }; -}; in self +in +self diff --git a/pkgs/tools/package-management/nix-template/default.nix b/pkgs/tools/package-management/nix-template/default.nix index 1d0c6f42f517f7..96e735948f65c4 100644 --- a/pkgs/tools/package-management/nix-template/default.nix +++ b/pkgs/tools/package-management/nix-template/default.nix @@ -1,10 +1,14 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub -, installShellFiles -, makeWrapper -, nix -, openssl -, pkg-config -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + installShellFiles, + makeWrapper, + nix, + openssl, + pkg-config, + Security, }: rustPlatform.buildRustPackage rec { @@ -27,20 +31,21 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optional stdenv.hostPlatform.isDarwin Security; + buildInputs = [ openssl ] ++ lib.optional stdenv.hostPlatform.isDarwin Security; # needed for nix-prefetch-url - postInstall = '' - wrapProgram $out/bin/nix-template \ - --prefix PATH : ${lib.makeBinPath [ nix ]} - - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - installShellCompletion --cmd nix-template \ - --bash <($out/bin/nix-template completions bash) \ - --fish <($out/bin/nix-template completions fish) \ - --zsh <($out/bin/nix-template completions zsh) - ''; + postInstall = + '' + wrapProgram $out/bin/nix-template \ + --prefix PATH : ${lib.makeBinPath [ nix ]} + + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + installShellCompletion --cmd nix-template \ + --bash <($out/bin/nix-template completions bash) \ + --fish <($out/bin/nix-template completions fish) \ + --zsh <($out/bin/nix-template completions zsh) + ''; meta = with lib; { description = "Make creating nix expressions easy"; diff --git a/pkgs/tools/package-management/nix-update-source/default.nix b/pkgs/tools/package-management/nix-update-source/default.nix index 9b21c1514046fe..392a580e45b165 100644 --- a/pkgs/tools/package-management/nix-update-source/default.nix +++ b/pkgs/tools/package-management/nix-update-source/default.nix @@ -1,4 +1,11 @@ -{ lib, pkgs, fetchFromGitHub, python3Packages, nix-prefetch-scripts, runtimeShell }: +{ + lib, + pkgs, + fetchFromGitHub, + python3Packages, + nix-prefetch-scripts, + runtimeShell, +}: python3Packages.buildPythonApplication rec { pname = "nix-update-source"; @@ -19,7 +26,8 @@ python3Packages.buildPythonApplication rec { # NOTE: `fetch` should not be used within nixpkgs because it # uses a non-idiomatic structure. It is provided for use by # out-of-tree nix derivations. - fetch = path: + fetch = + path: let fetchers = { # whitelist of allowed fetchers @@ -29,12 +37,17 @@ python3Packages.buildPythonApplication rec { fetchFn = builtins.getAttr json.fetch.fn fetchers; src = fetchFn json.fetch.args; in - json // json.fetch // { + json + // json.fetch + // { inherit src; - overrideSrc = drv: lib.overrideDerivation drv (orig: { inherit src; }); + overrideSrc = + drv: + lib.overrideDerivation drv (orig: { + inherit src; + }); }; - updateScript = [ runtimeShell "-c" diff --git a/pkgs/tools/package-management/nix-visualize/default.nix b/pkgs/tools/package-management/nix-visualize/default.nix index 9f1ba8b4d769d1..fab3aa952647d2 100644 --- a/pkgs/tools/package-management/nix-visualize/default.nix +++ b/pkgs/tools/package-management/nix-visualize/default.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, nix -, python -, matplotlib -, networkx -, pandas -, pygraphviz -, setuptools +{ + lib, + fetchFromGitHub, + nix, + python, + matplotlib, + networkx, + pandas, + pygraphviz, + setuptools, }: python.pkgs.buildPythonApplication rec { @@ -23,7 +24,7 @@ python.pkgs.buildPythonApplication rec { postInstall = '' wrapProgram $out/bin/nix-visualize \ - --prefix PATH : ${lib.makeBinPath [nix]} + --prefix PATH : ${lib.makeBinPath [ nix ]} ''; nativeBuildInputs = [ setuptools ]; diff --git a/pkgs/tools/package-management/nix/nix-perl.nix b/pkgs/tools/package-management/nix/nix-perl.nix index 50e342e96cad5d..99ce5101265b5a 100644 --- a/pkgs/tools/package-management/nix/nix-perl.nix +++ b/pkgs/tools/package-management/nix/nix-perl.nix @@ -1,32 +1,38 @@ -{ stdenv -, lib -, perl -, pkg-config -, curl -, nix -, libsodium -, boost -, autoreconfHook -, autoconf-archive -, xz -, Security -, meson -, ninja -, bzip2 +{ + stdenv, + lib, + perl, + pkg-config, + curl, + nix, + libsodium, + boost, + autoreconfHook, + autoconf-archive, + xz, + Security, + meson, + ninja, + bzip2, }: let atLeast223 = lib.versionAtLeast nix.version "2.23"; atLeast224 = lib.versionAtLeast nix.version "2.24"; - mkConfigureOption = { mesonOption, autoconfOption, value }: + mkConfigureOption = + { + mesonOption, + autoconfOption, + value, + }: let - setFlagTo = if atLeast223 - then lib.mesonOption mesonOption - else lib.withFeatureAs true autoconfOption; + setFlagTo = + if atLeast223 then lib.mesonOption mesonOption else lib.withFeatureAs true autoconfOption; in setFlagTo value; -in stdenv.mkDerivation (finalAttrs: { +in +stdenv.mkDerivation (finalAttrs: { pname = "nix-perl"; inherit (nix) version src; @@ -52,17 +58,24 @@ in stdenv.mkDerivation (finalAttrs: { # Not cross-safe since Nix checks for curl/perl via # NEED_PROG/find_program, but both seem to be needed at runtime # as well. - nativeBuildInputs = [ - pkg-config - perl - curl - ] ++ (if atLeast223 then [ - meson - ninja - ] else [ - autoconf-archive - autoreconfHook - ]); + nativeBuildInputs = + [ + pkg-config + perl + curl + ] + ++ ( + if atLeast223 then + [ + meson + ninja + ] + else + [ + autoconf-archive + autoreconfHook + ] + ); # `perlPackages.Test2Harness` is marked broken for Darwin doCheck = !stdenv.hostPlatform.isDarwin; @@ -71,20 +84,22 @@ in stdenv.mkDerivation (finalAttrs: { perl.pkgs.Test2Harness ]; - ${if atLeast223 then "mesonFlags" else "configureFlags"} = [ - (mkConfigureOption { - mesonOption = "dbi_path"; - autoconfOption = "dbi"; - value = "${perl.pkgs.DBI}/${perl.libPrefix}"; - }) - (mkConfigureOption { - mesonOption = "dbd_sqlite_path"; - autoconfOption = "dbd-sqlite"; - value = "${perl.pkgs.DBDSQLite}/${perl.libPrefix}"; - }) - ] ++ lib.optionals atLeast223 [ - (lib.mesonEnable "tests" finalAttrs.finalPackage.doCheck) - ]; + ${if atLeast223 then "mesonFlags" else "configureFlags"} = + [ + (mkConfigureOption { + mesonOption = "dbi_path"; + autoconfOption = "dbi"; + value = "${perl.pkgs.DBI}/${perl.libPrefix}"; + }) + (mkConfigureOption { + mesonOption = "dbd_sqlite_path"; + autoconfOption = "dbd-sqlite"; + value = "${perl.pkgs.DBDSQLite}/${perl.libPrefix}"; + }) + ] + ++ lib.optionals atLeast223 [ + (lib.mesonEnable "tests" finalAttrs.finalPackage.doCheck) + ]; preConfigure = "export NIX_STATE_DIR=$TMPDIR"; diff --git a/pkgs/tools/package-management/packagekit/default.nix b/pkgs/tools/package-management/packagekit/default.nix index d0a4ef21d36ab3..0c66f23108259b 100644 --- a/pkgs/tools/package-management/packagekit/default.nix +++ b/pkgs/tools/package-management/packagekit/default.nix @@ -1,37 +1,42 @@ -{ stdenv -, fetchFromGitHub -, lib -, gettext -, glib -, pkg-config -, polkit -, python3 -, sqlite -, gobject-introspection -, vala -, gtk-doc -, boost -, meson -, ninja -, libxslt -, docbook-xsl-nons -, docbook_xml_dtd_42 -, libxml2 -, gst_all_1 -, gtk3 -, enableCommandNotFound ? false -, enableBashCompletion ? false -, bash-completion ? null -, enableSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, systemd -, nixosTests +{ + stdenv, + fetchFromGitHub, + lib, + gettext, + glib, + pkg-config, + polkit, + python3, + sqlite, + gobject-introspection, + vala, + gtk-doc, + boost, + meson, + ninja, + libxslt, + docbook-xsl-nons, + docbook_xml_dtd_42, + libxml2, + gst_all_1, + gtk3, + enableCommandNotFound ? false, + enableBashCompletion ? false, + bash-completion ? null, + enableSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + nixosTests, }: stdenv.mkDerivation rec { pname = "packagekit"; version = "1.3.0"; - outputs = [ "out" "dev" "devdoc" ]; + outputs = [ + "out" + "dev" + "devdoc" + ]; src = fetchFromGitHub { owner = "PackageKit"; @@ -40,17 +45,19 @@ stdenv.mkDerivation rec { hash = "sha256-MYZFI1Q90F/AXVSJJBhmw+E7IMLXrdwmSuFJwv5D/z4="; }; - buildInputs = [ - glib - polkit - python3 - gst_all_1.gstreamer - gst_all_1.gst-plugins-base - gtk3 - sqlite - boost - ] ++ lib.optional enableSystemd systemd - ++ lib.optional enableBashCompletion bash-completion; + buildInputs = + [ + glib + polkit + python3 + gst_all_1.gstreamer + gst_all_1.gst-plugins-base + gtk3 + sqlite + boost + ] + ++ lib.optional enableSystemd systemd + ++ lib.optional enableBashCompletion bash-completion; nativeBuildInputs = [ gobject-introspection glib @@ -66,22 +73,23 @@ stdenv.mkDerivation rec { ninja ]; - mesonFlags = [ - (if enableSystemd then "-Dsystemd=true" else "-Dsystem=false") - # often fails to build with nix updates - # and remounts /nix/store as rw - # https://github.com/NixOS/nixpkgs/issues/177946 - #"-Dpackaging_backend=nix" - "-Ddbus_sys=${placeholder "out"}/share/dbus-1/system.d" - "-Ddbus_services=${placeholder "out"}/share/dbus-1/system-services" - "-Dsystemdsystemunitdir=${placeholder "out"}/lib/systemd/system" - "-Dcron=false" - "-Dgtk_doc=true" - "--sysconfdir=/etc" - "--localstatedir=/var" - ] - ++ lib.optional (!enableBashCompletion) "-Dbash_completion=false" - ++ lib.optional (!enableCommandNotFound) "-Dbash_command_not_found=false"; + mesonFlags = + [ + (if enableSystemd then "-Dsystemd=true" else "-Dsystem=false") + # often fails to build with nix updates + # and remounts /nix/store as rw + # https://github.com/NixOS/nixpkgs/issues/177946 + #"-Dpackaging_backend=nix" + "-Ddbus_sys=${placeholder "out"}/share/dbus-1/system.d" + "-Ddbus_services=${placeholder "out"}/share/dbus-1/system-services" + "-Dsystemdsystemunitdir=${placeholder "out"}/lib/systemd/system" + "-Dcron=false" + "-Dgtk_doc=true" + "--sysconfdir=/etc" + "--localstatedir=/var" + ] + ++ lib.optional (!enableBashCompletion) "-Dbash_completion=false" + ++ lib.optional (!enableCommandNotFound) "-Dbash_command_not_found=false"; postPatch = '' # HACK: we want packagekit to look in /etc for configs but install diff --git a/pkgs/tools/package-management/packagekit/qt.nix b/pkgs/tools/package-management/packagekit/qt.nix index 79350e340f90ac..1cce9329b6f454 100644 --- a/pkgs/tools/package-management/packagekit/qt.nix +++ b/pkgs/tools/package-management/packagekit/qt.nix @@ -1,22 +1,34 @@ -{ stdenv, lib, fetchFromGitHub, cmake, pkg-config -, qttools, packagekit }: +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + pkg-config, + qttools, + packagekit, +}: let isQt6 = lib.versions.major qttools.version == "6"; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "packagekit-qt"; version = "1.1.2"; src = fetchFromGitHub { - owner = "hughsie"; - repo = "PackageKit-Qt"; - rev = "v${version}"; + owner = "hughsie"; + repo = "PackageKit-Qt"; + rev = "v${version}"; sha256 = "sha256-rLNeVjzIT18qUZgj6Qcf7E59CL4gx/ArYJfs9KHrqNs="; }; buildInputs = [ packagekit ]; - nativeBuildInputs = [ cmake pkg-config qttools ]; + nativeBuildInputs = [ + cmake + pkg-config + qttools + ]; cmakeFlags = [ (lib.cmakeBool "BUILD_WITH_QT6" isQt6) ]; diff --git a/pkgs/tools/package-management/rpm/default.nix b/pkgs/tools/package-management/rpm/default.nix index c42bcca20c904b..fb3380601ff6b1 100644 --- a/pkgs/tools/package-management/rpm/default.nix +++ b/pkgs/tools/package-management/rpm/default.nix @@ -1,31 +1,32 @@ -{ stdenv -, lib -, pkg-config -, autoreconfHook -, pandoc -, fetchpatch2 -, fetchurl -, cpio -, zlib -, bzip2 -, file -, elfutils -, libbfd -, libgcrypt -, libarchive -, nspr -, nss -, popt -, db -, xz -, python -, lua -, llvmPackages -, sqlite -, zstd -, libcap -, apple-sdk_13 -, darwinMinVersionHook +{ + stdenv, + lib, + pkg-config, + autoreconfHook, + pandoc, + fetchpatch2, + fetchurl, + cpio, + zlib, + bzip2, + file, + elfutils, + libbfd, + libgcrypt, + libarchive, + nspr, + nss, + popt, + db, + xz, + python, + lua, + llvmPackages, + sqlite, + zstd, + libcap, + apple-sdk_13, + darwinMinVersionHook, }: stdenv.mkDerivation rec { @@ -56,18 +57,51 @@ stdenv.mkDerivation rec { }) ]; - outputs = [ "out" "dev" "man" ]; + outputs = [ + "out" + "dev" + "man" + ]; separateDebugInfo = true; - nativeBuildInputs = [ autoreconfHook pkg-config pandoc ]; - buildInputs = [ cpio zlib zstd bzip2 file libarchive libgcrypt nspr nss db xz python lua sqlite ] + nativeBuildInputs = [ + autoreconfHook + pkg-config + pandoc + ]; + buildInputs = + [ + cpio + zlib + zstd + bzip2 + file + libarchive + libgcrypt + nspr + nss + db + xz + python + lua + sqlite + ] ++ lib.optional stdenv.cc.isClang llvmPackages.openmp ++ lib.optional stdenv.hostPlatform.isLinux libcap - ++ lib.optionals stdenv.hostPlatform.isDarwin [ apple-sdk_13 (darwinMinVersionHook "13.0") ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + apple-sdk_13 + (darwinMinVersionHook "13.0") + ]; # rpm/rpmlib.h includes popt.h, and then the pkg-config file mentions these as linkage requirements - propagatedBuildInputs = [ popt nss db bzip2 libarchive libbfd ] - ++ lib.optional (lib.meta.availableOn stdenv.hostPlatform elfutils) elfutils; + propagatedBuildInputs = [ + popt + nss + db + bzip2 + libarchive + libbfd + ] ++ lib.optional (lib.meta.availableOn stdenv.hostPlatform elfutils) elfutils; env.NIX_CFLAGS_COMPILE = "-I${nspr.dev}/include/nspr -I${nss.dev}/include/nss"; @@ -112,7 +146,10 @@ stdenv.mkDerivation rec { meta = with lib; { homepage = "https://www.rpm.org/"; - license = with licenses; [ gpl2Plus lgpl21Plus ]; + license = with licenses; [ + gpl2Plus + lgpl21Plus + ]; description = "RPM Package Manager"; maintainers = with maintainers; [ copumpkin ]; platforms = platforms.linux ++ platforms.darwin; diff --git a/pkgs/tools/package-management/yarn-lock-converter/default.nix b/pkgs/tools/package-management/yarn-lock-converter/default.nix index 70f5b143ebe8bf..4bba600ea02038 100644 --- a/pkgs/tools/package-management/yarn-lock-converter/default.nix +++ b/pkgs/tools/package-management/yarn-lock-converter/default.nix @@ -1,9 +1,10 @@ -{ lib -, buildNpmPackage -, fetchurl -, nodejs -, testers -, yarn-lock-converter +{ + lib, + buildNpmPackage, + fetchurl, + nodejs, + testers, + yarn-lock-converter, }: let diff --git a/pkgs/tools/security/age-plugin-ledger/default.nix b/pkgs/tools/security/age-plugin-ledger/default.nix index c20429968f4e4f..e5b5ccfdbe7f64 100644 --- a/pkgs/tools/security/age-plugin-ledger/default.nix +++ b/pkgs/tools/security/age-plugin-ledger/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, libusb1 -, openssl -, rage -, AppKit +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + libusb1, + openssl, + rage, + AppKit, }: rustPlatform.buildRustPackage rec { @@ -39,7 +40,10 @@ rustPlatform.buildRustPackage rec { description = "Ledger Nano plugin for age"; mainProgram = "age-plugin-ledger"; homepage = "https://github.com/Ledger-Donjon/age-plugin-ledger"; - license = with licenses; [ mit asl20 ]; + license = with licenses; [ + mit + asl20 + ]; maintainers = with maintainers; [ erdnaxe ]; }; } diff --git a/pkgs/tools/security/amber/default.nix b/pkgs/tools/security/amber/default.nix index 0099f90905202b..d95e21c954dff2 100644 --- a/pkgs/tools/security/amber/default.nix +++ b/pkgs/tools/security/amber/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, Security }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + Security, +}: rustPlatform.buildRustPackage rec { # Renaming it to amber-secret because another package named amber exists diff --git a/pkgs/tools/security/authoscope/default.nix b/pkgs/tools/security/authoscope/default.nix index e30a00ff5be19d..728db72a8b8c0a 100644 --- a/pkgs/tools/security/authoscope/default.nix +++ b/pkgs/tools/security/authoscope/default.nix @@ -1,13 +1,14 @@ -{ lib -, stdenv -, fetchFromGitHub -, installShellFiles -, libcap -, openssl -, pkg-config -, rustPlatform -, Security -, zlib +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + libcap, + openssl, + pkg-config, + rustPlatform, + Security, + zlib, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/tools/security/b2sum/default.nix b/pkgs/tools/security/b2sum/default.nix index 0dc8a9b35e83bb..04c0e3e8954396 100644 --- a/pkgs/tools/security/b2sum/default.nix +++ b/pkgs/tools/security/b2sum/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, openmp ? null }: +{ + lib, + stdenv, + fetchFromGitHub, + openmp ? null, +}: stdenv.mkDerivation (finalAttrs: { pname = "b2sum"; @@ -34,7 +39,11 @@ stdenv.mkDerivation (finalAttrs: { description = "B2sum utility is similar to the md5sum or shasum utilities but for BLAKE2"; mainProgram = "b2sum"; homepage = "https://blake2.net"; - license = with licenses; [ asl20 cc0 openssl ]; + license = with licenses; [ + asl20 + cc0 + openssl + ]; maintainers = with maintainers; [ kirelagin ]; platforms = platforms.unix; }; diff --git a/pkgs/tools/security/badchars/default.nix b/pkgs/tools/security/badchars/default.nix index 4c4d566c9074e3..849ac32082800c 100644 --- a/pkgs/tools/security/badchars/default.nix +++ b/pkgs/tools/security/badchars/default.nix @@ -1,7 +1,8 @@ -{ lib -, buildPythonApplication -, fetchPypi -, python3 +{ + lib, + buildPythonApplication, + fetchPypi, + python3, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/tools/security/bitwarden-directory-connector/default.nix b/pkgs/tools/security/bitwarden-directory-connector/default.nix index cd214e83f4bf47..0991d8e7894a7e 100644 --- a/pkgs/tools/security/bitwarden-directory-connector/default.nix +++ b/pkgs/tools/security/bitwarden-directory-connector/default.nix @@ -11,53 +11,63 @@ }: let - common = { name, npmBuildScript, installPhase }: buildNpmPackage rec { - pname = name; - version = "2024.10.0"; - nodejs = nodejs_18; - - src = fetchFromGitHub { - owner = "bitwarden"; - repo = "directory-connector"; - rev = "v${version}"; - hash = "sha256-jisMEuIpTWCy+N1QeERf+05tsugY0f+H2ntcRcFKkgo="; + common = + { + name, + npmBuildScript, + installPhase, + }: + buildNpmPackage rec { + pname = name; + version = "2024.10.0"; + nodejs = nodejs_18; + + src = fetchFromGitHub { + owner = "bitwarden"; + repo = "directory-connector"; + rev = "v${version}"; + hash = "sha256-jisMEuIpTWCy+N1QeERf+05tsugY0f+H2ntcRcFKkgo="; + }; + + postPatch = '' + ${lib.getExe buildPackages.jq} 'del(.scripts.preinstall)' package.json > package.json.tmp + mv -f package.json{.tmp,} + + substituteInPlace electron-builder.json \ + --replace-fail '"afterSign": "scripts/notarize.js",' "" \ + --replace-fail "AppImage" "dir" + ''; + + npmDepsHash = "sha256-Zi7EHzQSSrZ6XGGV1DOASuddYA4svXQc1eGmchcLFBc="; + + env.ELECTRON_SKIP_BINARY_DOWNLOAD = "1"; + + makeCacheWritable = true; + inherit npmBuildScript installPhase; + + buildInputs = [ + libsecret + ]; + + nativeBuildInputs = [ + (python3.withPackages (ps: with ps; [ setuptools ])) + pkg-config + ]; + + meta = with lib; { + description = "LDAP connector for Bitwarden"; + homepage = "https://github.com/bitwarden/directory-connector"; + license = licenses.gpl3Only; + maintainers = with maintainers; [ + Silver-Golden + SuperSandro2000 + ]; + platforms = platforms.linux; + mainProgram = name; + }; }; - - postPatch = '' - ${lib.getExe buildPackages.jq} 'del(.scripts.preinstall)' package.json > package.json.tmp - mv -f package.json{.tmp,} - - substituteInPlace electron-builder.json \ - --replace-fail '"afterSign": "scripts/notarize.js",' "" \ - --replace-fail "AppImage" "dir" - ''; - - npmDepsHash = "sha256-Zi7EHzQSSrZ6XGGV1DOASuddYA4svXQc1eGmchcLFBc="; - - env.ELECTRON_SKIP_BINARY_DOWNLOAD = "1"; - - makeCacheWritable = true; - inherit npmBuildScript installPhase; - - buildInputs = [ - libsecret - ]; - - nativeBuildInputs = [ - (python3.withPackages (ps: with ps; [ setuptools ])) - pkg-config - ]; - - meta = with lib; { - description = "LDAP connector for Bitwarden"; - homepage = "https://github.com/bitwarden/directory-connector"; - license = licenses.gpl3Only; - maintainers = with maintainers; [ Silver-Golden SuperSandro2000 ]; - platforms = platforms.linux; - mainProgram = name; - }; - }; -in { +in +{ bitwarden-directory-connector = common { name = "bitwarden-directory-connector"; npmBuildScript = "build:dist"; diff --git a/pkgs/tools/security/bmrsa/11.nix b/pkgs/tools/security/bmrsa/11.nix index 3ac41d2da482f6..f3bf100ff745e7 100644 --- a/pkgs/tools/security/bmrsa/11.nix +++ b/pkgs/tools/security/bmrsa/11.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, unzip }: +{ + lib, + stdenv, + fetchurl, + unzip, +}: stdenv.mkDerivation rec { pname = "bmrsa"; diff --git a/pkgs/tools/security/bundler-audit/default.nix b/pkgs/tools/security/bundler-audit/default.nix index c24831f26b0692..07528103a1af65 100644 --- a/pkgs/tools/security/bundler-audit/default.nix +++ b/pkgs/tools/security/bundler-audit/default.nix @@ -1,4 +1,9 @@ -{ bundlerEnv, ruby, lib, bundlerUpdateScript }: +{ + bundlerEnv, + ruby, + lib, + bundlerUpdateScript, +}: bundlerEnv rec { name = "${pname}-${version}"; @@ -20,10 +25,13 @@ bundlerEnv rec { - Prints advisory information. - Does not require a network connection. ''; - homepage = "https://github.com/rubysec/bundler-audit"; - changelog = "https://github.com/rubysec/bundler-audit/blob/v${version}/ChangeLog.md"; - license = licenses.gpl3Plus; - maintainers = with maintainers; [ primeos nicknovitski ]; - platforms = platforms.unix; + homepage = "https://github.com/rubysec/bundler-audit"; + changelog = "https://github.com/rubysec/bundler-audit/blob/v${version}/ChangeLog.md"; + license = licenses.gpl3Plus; + maintainers = with maintainers; [ + primeos + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/tools/security/bundler-audit/gemset.nix b/pkgs/tools/security/bundler-audit/gemset.nix index bbe7a0e8274be6..2dc2c5141f34e5 100644 --- a/pkgs/tools/security/bundler-audit/gemset.nix +++ b/pkgs/tools/security/bundler-audit/gemset.nix @@ -1,20 +1,20 @@ { bundler-audit = { - dependencies = ["thor"]; - groups = ["default"]; - platforms = []; + dependencies = [ "thor" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gdx0019vj04n1512shhdx7hwphzqmdpw4vva2k551nd47y1dixx"; type = "gem"; }; version = "0.9.1"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0inl77jh4ia03jw3iqm5ipr76ghal3hyjrd6r8zqsswwvi9j2xdi"; type = "gem"; }; diff --git a/pkgs/tools/security/cewl/default.nix b/pkgs/tools/security/cewl/default.nix index 833c5212507922..e415a1bdc95097 100644 --- a/pkgs/tools/security/cewl/default.nix +++ b/pkgs/tools/security/cewl/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitHub, bundlerEnv }: +{ + stdenv, + lib, + fetchFromGitHub, + bundlerEnv, +}: let rubyEnv = bundlerEnv { diff --git a/pkgs/tools/security/cewl/gemset.nix b/pkgs/tools/security/cewl/gemset.nix index 851a6d2442d342..486d6b8e42f9bc 100644 --- a/pkgs/tools/security/cewl/gemset.nix +++ b/pkgs/tools/security/cewl/gemset.nix @@ -1,101 +1,104 @@ { mime = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nskys7brz2bylhxiknl0z9i19w3wb1knf0h93in6mjq70jdw5cr"; type = "gem"; }; version = "0.4.4"; }; mime-types = { - dependencies = ["mime-types-data"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mime-types-data" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zj12l9qk62anvk9bjvandpa6vy4xslil15wl6wlivyf51z773vh"; type = "gem"; }; version = "3.3.1"; }; mime-types-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dlxwc75iy0dj23x824cxpvpa7c8aqcpskksrmb32j6m66h5mkcy"; type = "gem"; }; version = "3.2021.0704"; }; mini_exiftool = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ir4wigpm6nkd3f40wcjdqrhjx3l60w1hwcg143is1a95ypnvqhr"; type = "gem"; }; version = "2.10.2"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ad0mli9rc0f17zw4ibp24dbj1y39zkykijsjmnzl4gwpg5s0j6k"; type = "gem"; }; version = "2.5.3"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vrn31385ix5k9b0yalnlzv360isv6dincbcvi8psllnwz4sjxj9"; type = "gem"; }; version = "1.11.7"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "178k7r0xn689spviqzhvazzvxfq6fyjldxb3ywjbgipbfi4s8j1g"; type = "gem"; }; version = "1.5.2"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08ximcyfjy94pm1rhcx04ny1vx2sk0x4y185gzn86yfsbzwkng53"; type = "gem"; }; version = "3.2.5"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; spider = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fix7zhnvlfqg66bxwdpbsffbynzdnaifnxpakn07bjh3rdj75cx"; type = "gem"; }; diff --git a/pkgs/tools/security/chrome-token-signing/default.nix b/pkgs/tools/security/chrome-token-signing/default.nix index 5f9618d0f177a5..51e4aceb9bcef3 100644 --- a/pkgs/tools/security/chrome-token-signing/default.nix +++ b/pkgs/tools/security/chrome-token-signing/default.nix @@ -1,4 +1,12 @@ -{ lib, mkDerivation, fetchFromGitHub, qmake, pcsclite, pkg-config, opensc }: +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + pcsclite, + pkg-config, + opensc, +}: mkDerivation rec { pname = "chrome-token-signing"; @@ -12,7 +20,10 @@ mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ qmake pcsclite ]; + buildInputs = [ + qmake + pcsclite + ]; dontUseQmakeConfigure = true; patchPhase = '' diff --git a/pkgs/tools/security/clamav/default.nix b/pkgs/tools/security/clamav/default.nix index 87471065098a3a..3a3b264ef3d6ac 100644 --- a/pkgs/tools/security/clamav/default.nix +++ b/pkgs/tools/security/clamav/default.nix @@ -1,7 +1,28 @@ -{ lib, stdenv, fetchurl, pkg-config, cmake -, zlib, bzip2, libiconv, libxml2, openssl, ncurses, curl, libmilter, pcre2 -, libmspack, systemd, Foundation, json_c, check -, rustc, rust-bindgen, rustfmt, cargo, python3 +{ + lib, + stdenv, + fetchurl, + pkg-config, + cmake, + zlib, + bzip2, + libiconv, + libxml2, + openssl, + ncurses, + curl, + libmilter, + pcre2, + libmspack, + systemd, + Foundation, + json_c, + check, + rustc, + rust-bindgen, + rustfmt, + cargo, + python3, }: stdenv.mkDerivation rec { @@ -20,10 +41,31 @@ stdenv.mkDerivation rec { ]; enableParallelBuilding = true; - nativeBuildInputs = [ cmake pkg-config rustc rust-bindgen rustfmt cargo python3 ]; - buildInputs = [ - zlib bzip2 libxml2 openssl ncurses curl libiconv libmilter pcre2 libmspack json_c check - ] ++ lib.optional stdenv.hostPlatform.isLinux systemd + nativeBuildInputs = [ + cmake + pkg-config + rustc + rust-bindgen + rustfmt + cargo + python3 + ]; + buildInputs = + [ + zlib + bzip2 + libxml2 + openssl + ncurses + curl + libiconv + libmilter + pcre2 + libmspack + json_c + check + ] + ++ lib.optional stdenv.hostPlatform.isLinux systemd ++ lib.optional stdenv.hostPlatform.isDarwin Foundation; cmakeFlags = [ @@ -41,7 +83,11 @@ stdenv.mkDerivation rec { homepage = "https://www.clamav.net"; description = "Antivirus engine designed for detecting Trojans, viruses, malware and other malicious threats"; license = licenses.gpl2Only; - maintainers = with maintainers; [ robberer qknight globin ]; + maintainers = with maintainers; [ + robberer + qknight + globin + ]; platforms = platforms.unix; }; } diff --git a/pkgs/tools/security/cosign/default.nix b/pkgs/tools/security/cosign/default.nix index e8ffe7b2e4108c..58f6c3ae6126d4 100644 --- a/pkgs/tools/security/cosign/default.nix +++ b/pkgs/tools/security/cosign/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, buildGoModule -, fetchFromGitHub -, pcsclite -, pkg-config -, installShellFiles -, PCSC -, pivKeySupport ? true -, pkcs11Support ? true -, testers -, cosign +{ + stdenv, + lib, + buildGoModule, + fetchFromGitHub, + pcsclite, + pkg-config, + installShellFiles, + PCSC, + pivKeySupport ? true, + pkcs11Support ? true, + testers, + cosign, }: buildGoModule rec { pname = "cosign"; @@ -26,7 +27,10 @@ buildGoModule rec { lib.optional (stdenv.hostPlatform.isLinux && pivKeySupport) (lib.getDev pcsclite) ++ lib.optionals (stdenv.hostPlatform.isDarwin && pivKeySupport) [ PCSC ]; - nativeBuildInputs = [ pkg-config installShellFiles ]; + nativeBuildInputs = [ + pkg-config + installShellFiles + ]; vendorHash = "sha256-E1QHLh2gg5RZ7+tl7eJNR2FmtfVI6rwI6qLD7tio18c="; @@ -34,7 +38,8 @@ buildGoModule rec { "cmd/cosign" ]; - tags = [ ] ++ lib.optionals pivKeySupport [ "pivkey" ] ++ lib.optionals pkcs11Support [ "pkcs11key" ]; + tags = + [ ] ++ lib.optionals pivKeySupport [ "pivkey" ] ++ lib.optionals pkcs11Support [ "pkcs11key" ]; ldflags = [ "-s" @@ -75,6 +80,10 @@ buildGoModule rec { description = "Container Signing CLI with support for ephemeral keys and Sigstore signing"; mainProgram = "cosign"; license = licenses.asl20; - maintainers = with maintainers; [ lesuisse jk developer-guy ]; + maintainers = with maintainers; [ + lesuisse + jk + developer-guy + ]; }; } diff --git a/pkgs/tools/security/deepsecrets/default.nix b/pkgs/tools/security/deepsecrets/default.nix index 4fa86da7f9131a..0eabf689cea0ab 100644 --- a/pkgs/tools/security/deepsecrets/default.nix +++ b/pkgs/tools/security/deepsecrets/default.nix @@ -1,6 +1,7 @@ -{ lib -, python3 -, fetchFromGitHub +{ + lib, + python3, + fetchFromGitHub, }: python3.pkgs.buildPythonApplication rec { diff --git a/pkgs/tools/security/ecryptfs/default.nix b/pkgs/tools/security/ecryptfs/default.nix index 24246a5de9c51d..4849d1f81e3677 100644 --- a/pkgs/tools/security/ecryptfs/default.nix +++ b/pkgs/tools/security/ecryptfs/default.nix @@ -1,5 +1,28 @@ -{ lib, stdenv, fetchurl, pkg-config, perl, util-linux, keyutils, nss, nspr, python2, pam, enablePython ? false -, intltool, makeWrapper, coreutils, bash, gettext, cryptsetup, lvm2, rsync, which, lsof, nixosTests }: +{ + lib, + stdenv, + fetchurl, + pkg-config, + perl, + util-linux, + keyutils, + nss, + nspr, + python2, + pam, + enablePython ? false, + intltool, + makeWrapper, + coreutils, + bash, + gettext, + cryptsetup, + lvm2, + rsync, + which, + lsof, + nixosTests, +}: stdenv.mkDerivation rec { pname = "ecryptfs"; @@ -35,14 +58,29 @@ stdenv.mkDerivation rec { configureFlags = lib.optionals (!enablePython) [ "--disable-pywrap" ]; - nativeBuildInputs = [ pkg-config makeWrapper intltool ] - # if python2 support is requested, it is needed at builtime as well as runtime. - ++ lib.optionals (enablePython) [ python2 ] - ; - buildInputs = [ perl nss nspr pam ] - ++ lib.optionals (enablePython) [ python2 ] - ; - propagatedBuildInputs = [ coreutils gettext cryptsetup lvm2 rsync keyutils which ]; + nativeBuildInputs = + [ + pkg-config + makeWrapper + intltool + ] + # if python2 support is requested, it is needed at builtime as well as runtime. + ++ lib.optionals (enablePython) [ python2 ]; + buildInputs = [ + perl + nss + nspr + pam + ] ++ lib.optionals (enablePython) [ python2 ]; + propagatedBuildInputs = [ + coreutils + gettext + cryptsetup + lvm2 + rsync + keyutils + which + ]; postInstall = '' FILES="$(grep -r '/bin/sh' $out/bin -l)" @@ -62,8 +100,8 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Enterprise-class stacked cryptographic filesystem"; - license = licenses.gpl2Plus; + license = licenses.gpl2Plus; maintainers = with maintainers; [ obadz ]; - platforms = platforms.linux; + platforms = platforms.linux; }; } diff --git a/pkgs/tools/security/ecryptfs/helper.nix b/pkgs/tools/security/ecryptfs/helper.nix index e0252dac820a83..4f2070f8bd289c 100644 --- a/pkgs/tools/security/ecryptfs/helper.nix +++ b/pkgs/tools/security/ecryptfs/helper.nix @@ -1,15 +1,17 @@ -{ lib, stdenv -, fetchurl -, makeWrapper -, python2 +{ + lib, + stdenv, + fetchurl, + makeWrapper, + python2, }: stdenv.mkDerivation { - pname = "ecryptfs-helper"; + pname = "ecryptfs-helper"; version = "20160722"; src = fetchurl { - url = "https://gist.githubusercontent.com/obadz/ec053fdb00dcb48441d8313169874e30/raw/4b657a4b7c3dc684e4d5e3ffaf46ced1b7675163/ecryptfs-helper.py"; + url = "https://gist.githubusercontent.com/obadz/ec053fdb00dcb48441d8313169874e30/raw/4b657a4b7c3dc684e4d5e3ffaf46ced1b7675163/ecryptfs-helper.py"; sha256 = "0gp4m22zc80814ng80s38hp930aa8r4zqihr7jr23m0m2iq4pdpg"; }; @@ -25,10 +27,10 @@ stdenv.mkDerivation { ''; meta = with lib; { - description = "Helper script to create/mount/unemount encrypted directories using eCryptfs without needing root permissions"; - license = licenses.gpl2Plus; - maintainers = with maintainers; [ obadz ]; - platforms = platforms.linux; - hydraPlatforms = []; + description = "Helper script to create/mount/unemount encrypted directories using eCryptfs without needing root permissions"; + license = licenses.gpl2Plus; + maintainers = with maintainers; [ obadz ]; + platforms = platforms.linux; + hydraPlatforms = [ ]; }; } diff --git a/pkgs/tools/security/eid-mw/default.nix b/pkgs/tools/security/eid-mw/default.nix index b8ae6d2c84c91b..1adcf622e62d2d 100644 --- a/pkgs/tools/security/eid-mw/default.nix +++ b/pkgs/tools/security/eid-mw/default.nix @@ -1,22 +1,23 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoconf-archive -, autoreconfHook -, makeWrapper -, pkg-config -, substituteAll -, curl -, gtk3 -, libassuan -, libbsd -, libproxy -, libxml2 -, nssTools -, openssl -, p11-kit -, pcsclite -, wrapGAppsHook3 +{ + lib, + stdenv, + fetchFromGitHub, + autoconf-archive, + autoreconfHook, + makeWrapper, + pkg-config, + substituteAll, + curl, + gtk3, + libassuan, + libbsd, + libproxy, + libxml2, + nssTools, + openssl, + p11-kit, + pcsclite, + wrapGAppsHook3, }: stdenv.mkDerivation rec { @@ -36,9 +37,24 @@ stdenv.mkDerivation rec { substituteInPlace configure.ac --replace 'p11kitcfdir=""' 'p11kitcfdir="'$out/share/p11-kit/modules'"' ''; - - nativeBuildInputs = [ wrapGAppsHook3 autoreconfHook autoconf-archive pkg-config makeWrapper ]; - buildInputs = [ curl gtk3 libassuan libbsd libproxy libxml2 openssl p11-kit pcsclite ]; + nativeBuildInputs = [ + wrapGAppsHook3 + autoreconfHook + autoconf-archive + pkg-config + makeWrapper + ]; + buildInputs = [ + curl + gtk3 + libassuan + libbsd + libproxy + libxml2 + openssl + p11-kit + pcsclite + ]; preConfigure = '' mkdir openssl @@ -100,6 +116,9 @@ stdenv.mkDerivation rec { firefox.override { pkcs11Modules = [ pkgs.eid-mw ]; } ''; platforms = platforms.linux; - maintainers = with maintainers; [ bfortz chvp ]; + maintainers = with maintainers; [ + bfortz + chvp + ]; }; } diff --git a/pkgs/tools/security/feroxbuster/default.nix b/pkgs/tools/security/feroxbuster/default.nix index 64975a04c9f4b3..844501a162bead 100644 --- a/pkgs/tools/security/feroxbuster/default.nix +++ b/pkgs/tools/security/feroxbuster/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, openssl -, pkg-config -, rustPlatform -, Security -, SystemConfiguration +{ + lib, + stdenv, + fetchFromGitHub, + openssl, + pkg-config, + rustPlatform, + Security, + SystemConfiguration, }: rustPlatform.buildRustPackage rec { @@ -32,12 +33,14 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - Security - SystemConfiguration - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + ]; # Tests require network access doCheck = false; @@ -52,4 +55,3 @@ rustPlatform.buildRustPackage rec { mainProgram = "feroxbuster"; }; } - diff --git a/pkgs/tools/security/firefox_decrypt/default.nix b/pkgs/tools/security/firefox_decrypt/default.nix index 6fdb2e0440f340..5bc8dbe86aa093 100644 --- a/pkgs/tools/security/firefox_decrypt/default.nix +++ b/pkgs/tools/security/firefox_decrypt/default.nix @@ -1,12 +1,13 @@ -{ lib -, fetchFromGitHub -, buildPythonApplication -, setuptools -, setuptools-scm -, wheel -, nss -, nix-update-script -, stdenv +{ + lib, + fetchFromGitHub, + buildPythonApplication, + setuptools, + setuptools-scm, + wheel, + nss, + nix-update-script, + stdenv, }: buildPythonApplication rec { diff --git a/pkgs/tools/security/fwbuilder/default.nix b/pkgs/tools/security/fwbuilder/default.nix index 6787e2f923b9f3..284e302f0188bd 100644 --- a/pkgs/tools/security/fwbuilder/default.nix +++ b/pkgs/tools/security/fwbuilder/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, ninja -, wrapQtAppsHook -, wayland -, wayland-protocols -, qtwayland +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + ninja, + wrapQtAppsHook, + wayland, + wayland-protocols, + qtwayland, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/security/genpass/default.nix b/pkgs/tools/security/genpass/default.nix index f1e9a197680bf1..009f59619a344a 100644 --- a/pkgs/tools/security/genpass/default.nix +++ b/pkgs/tools/security/genpass/default.nix @@ -1,9 +1,11 @@ -{ lib, stdenv -, fetchgit -, rustPlatform -, CoreFoundation -, libiconv -, Security +{ + lib, + stdenv, + fetchgit, + rustPlatform, + CoreFoundation, + libiconv, + Security, }: rustPlatform.buildRustPackage rec { pname = "genpass"; @@ -17,7 +19,11 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-ls3tzZ+gtZQlObmbtwJDq6N/f5nY+Ps7RL5R/fR5Vgg="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ CoreFoundation libiconv Security ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + CoreFoundation + libiconv + Security + ]; meta = with lib; { description = "Simple yet robust commandline random password generator"; diff --git a/pkgs/tools/security/ggshield/default.nix b/pkgs/tools/security/ggshield/default.nix index 93c16cf75cac36..7e62c0741662e5 100644 --- a/pkgs/tools/security/ggshield/default.nix +++ b/pkgs/tools/security/ggshield/default.nix @@ -21,7 +21,6 @@ python3.pkgs.buildPythonApplication rec { build-system = with python3.pkgs; [ pdm-backend ]; - dependencies = with python3.pkgs; [ appdirs charset-normalizer diff --git a/pkgs/tools/security/gnupg/1.nix b/pkgs/tools/security/gnupg/1.nix index 390665fe44fd8e..6cdbc419e074f1 100644 --- a/pkgs/tools/security/gnupg/1.nix +++ b/pkgs/tools/security/gnupg/1.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, readline, bzip2 }: +{ + lib, + stdenv, + fetchurl, + readline, + bzip2, +}: stdenv.mkDerivation rec { pname = "gnupg"; @@ -9,7 +15,10 @@ stdenv.mkDerivation rec { sha256 = "1fkq4sqldvf6a25mm2qz95swv1qjg464736091w51djiwqbjyin9"; }; - buildInputs = [ readline bzip2 ]; + buildInputs = [ + readline + bzip2 + ]; # Workaround build failure on -fno-common toolchains like upstream # gcc-10. Otherwise build fails as: diff --git a/pkgs/tools/security/gnupg/1compat.nix b/pkgs/tools/security/gnupg/1compat.nix index 6625a45679549f..040ce178c3b821 100644 --- a/pkgs/tools/security/gnupg/1compat.nix +++ b/pkgs/tools/security/gnupg/1compat.nix @@ -1,4 +1,9 @@ -{ stdenv, gnupg, coreutils, writeScript }: +{ + stdenv, + gnupg, + coreutils, + writeScript, +}: stdenv.mkDerivation { pname = "gnupg1compat"; @@ -24,8 +29,7 @@ stdenv.mkDerivation { ''; meta = gnupg.meta // { - description = gnupg.meta.description + - " with symbolic links for gpg and gpgv"; + description = gnupg.meta.description + " with symbolic links for gpg and gpgv"; priority = -1; }; } diff --git a/pkgs/tools/security/gnupg/22.nix b/pkgs/tools/security/gnupg/22.nix index e0fdf3361f9bd0..e543fc77a1c3e9 100644 --- a/pkgs/tools/security/gnupg/22.nix +++ b/pkgs/tools/security/gnupg/22.nix @@ -1,11 +1,31 @@ -{ lib, stdenv, fetchurl, buildPackages -, pkg-config, texinfo -, gettext, libassuan, libgcrypt, libgpg-error, libiconv, libksba, npth -, adns, bzip2, gnutls, libusb1, openldap, readline, sqlite, zlib -, enableMinimal ? false -, withPcsc ? !enableMinimal, pcsclite -, guiSupport ? stdenv.hostPlatform.isDarwin, pinentry -, nixosTests +{ + lib, + stdenv, + fetchurl, + buildPackages, + pkg-config, + texinfo, + gettext, + libassuan, + libgcrypt, + libgpg-error, + libiconv, + libksba, + npth, + adns, + bzip2, + gnutls, + libusb1, + openldap, + readline, + sqlite, + zlib, + enableMinimal ? false, + withPcsc ? !enableMinimal, + pcsclite, + guiSupport ? stdenv.hostPlatform.isDarwin, + pinentry, + nixosTests, }: assert guiSupport -> !enableMinimal; @@ -20,12 +40,30 @@ stdenv.mkDerivation rec { }; depsBuildBuild = [ buildPackages.stdenv.cc ]; - nativeBuildInputs = [ pkg-config texinfo ]; - buildInputs = [ - gettext libassuan libgcrypt libgpg-error libiconv libksba npth - ] ++ lib.optionals (!enableMinimal) [ - adns bzip2 gnutls libusb1 openldap readline sqlite zlib + nativeBuildInputs = [ + pkg-config + texinfo ]; + buildInputs = + [ + gettext + libassuan + libgcrypt + libgpg-error + libiconv + libksba + npth + ] + ++ lib.optionals (!enableMinimal) [ + adns + bzip2 + gnutls + libusb1 + openldap + readline + sqlite + zlib + ]; patches = [ ./fix-libusb-include-path.patch @@ -34,50 +72,58 @@ stdenv.mkDerivation rec { ./22-allow-import-of-previously-known-keys-even-without-UI.patch ]; - postPatch = '' - sed -i 's,hkps://hkps.pool.sks-keyservers.net,hkps://keys.openpgp.org,g' configure doc/dirmngr.texi doc/gnupg.info-1 - # Fix broken SOURCE_DATE_EPOCH usage - remove on the next upstream update - sed -i 's/$SOURCE_DATE_EPOCH/''${SOURCE_DATE_EPOCH}/' doc/Makefile.am - sed -i 's/$SOURCE_DATE_EPOCH/''${SOURCE_DATE_EPOCH}/' doc/Makefile.in - '' + lib.optionalString (stdenv.hostPlatform.isLinux && withPcsc) '' + postPatch = + '' + sed -i 's,hkps://hkps.pool.sks-keyservers.net,hkps://keys.openpgp.org,g' configure doc/dirmngr.texi doc/gnupg.info-1 + # Fix broken SOURCE_DATE_EPOCH usage - remove on the next upstream update + sed -i 's/$SOURCE_DATE_EPOCH/''${SOURCE_DATE_EPOCH}/' doc/Makefile.am + sed -i 's/$SOURCE_DATE_EPOCH/''${SOURCE_DATE_EPOCH}/' doc/Makefile.in + '' + + lib.optionalString (stdenv.hostPlatform.isLinux && withPcsc) '' sed -i 's,"libpcsclite\.so[^"]*","${lib.getLib pcsclite}/lib/libpcsclite.so",g' scd/scdaemon.c ''; - configureFlags = [ - "--with-libgpg-error-prefix=${libgpg-error.dev}" - "--with-libgcrypt-prefix=${libgcrypt.dev}" - "--with-libassuan-prefix=${libassuan.dev}" - "--with-ksba-prefix=${libksba.dev}" - "GPGRT_CONFIG=${lib.getDev libgpg-error}/bin/gpgrt-config" - ] - ++ lib.optional guiSupport "--with-pinentry-pgm=${pinentry}/${pinentry.binaryPath or "bin/pinentry"}" - ++ lib.optional stdenv.hostPlatform.isDarwin "--disable-ccid-driver"; + configureFlags = + [ + "--with-libgpg-error-prefix=${libgpg-error.dev}" + "--with-libgcrypt-prefix=${libgcrypt.dev}" + "--with-libassuan-prefix=${libassuan.dev}" + "--with-ksba-prefix=${libksba.dev}" + "GPGRT_CONFIG=${lib.getDev libgpg-error}/bin/gpgrt-config" + ] + ++ lib.optional guiSupport "--with-pinentry-pgm=${pinentry}/${ + pinentry.binaryPath or "bin/pinentry" + }" + ++ lib.optional stdenv.hostPlatform.isDarwin "--disable-ccid-driver"; - postInstall = if enableMinimal - then '' - rm -r $out/{libexec,sbin,share} - for f in $(find $out/bin -type f -not -name gpg) - do - rm $f - done - '' else '' - mkdir -p $out/lib/systemd/user - for f in doc/examples/systemd-user/*.{service,socket} ; do - substitute $f $out/lib/systemd/user/$(basename $f) \ - --replace /usr/bin $out/bin - done + postInstall = + if enableMinimal then + '' + rm -r $out/{libexec,sbin,share} + for f in $(find $out/bin -type f -not -name gpg) + do + rm $f + done + '' + else + '' + mkdir -p $out/lib/systemd/user + for f in doc/examples/systemd-user/*.{service,socket} ; do + substitute $f $out/lib/systemd/user/$(basename $f) \ + --replace /usr/bin $out/bin + done - # add gpg2 symlink to make sure git does not break when signing commits - ln -s $out/bin/gpg $out/bin/gpg2 + # add gpg2 symlink to make sure git does not break when signing commits + ln -s $out/bin/gpg $out/bin/gpg2 - # Make libexec tools available in PATH - for f in $out/libexec/; do - if [[ "$(basename $f)" == "gpg-wks-client" ]]; then continue; fi - ln -s $f $out/bin/$(basename $f) - done + # Make libexec tools available in PATH + for f in $out/libexec/; do + if [[ "$(basename $f)" == "gpg-wks-client" ]]; then continue; fi + ln -s $f $out/bin/$(basename $f) + done - ln -s -t $out/bin $out/libexec/* - ''; + ln -s -t $out/bin $out/libexec/* + ''; enableParallelBuilding = true; diff --git a/pkgs/tools/security/gopass/git-credential.nix b/pkgs/tools/security/gopass/git-credential.nix index 2002da28690f5b..f6ee7ceb28a2dd 100644 --- a/pkgs/tools/security/gopass/git-credential.nix +++ b/pkgs/tools/security/gopass/git-credential.nix @@ -1,8 +1,9 @@ -{ lib -, makeWrapper -, buildGoModule -, fetchFromGitHub -, gopass +{ + lib, + makeWrapper, + buildGoModule, + fetchFromGitHub, + gopass, }: buildGoModule rec { @@ -23,7 +24,10 @@ buildGoModule rec { nativeBuildInputs = [ makeWrapper ]; ldflags = [ - "-s" "-w" "-X main.version=${version}" "-X main.commit=${src.rev}" + "-s" + "-w" + "-X main.version=${version}" + "-X main.commit=${src.rev}" ]; postFixup = '' diff --git a/pkgs/tools/security/gopass/hibp.nix b/pkgs/tools/security/gopass/hibp.nix index 59d5f6c46ea9b2..d458b99dba9198 100644 --- a/pkgs/tools/security/gopass/hibp.nix +++ b/pkgs/tools/security/gopass/hibp.nix @@ -1,8 +1,9 @@ -{ lib -, makeWrapper -, buildGoModule -, fetchFromGitHub -, gopass +{ + lib, + makeWrapper, + buildGoModule, + fetchFromGitHub, + gopass, }: buildGoModule rec { @@ -23,7 +24,10 @@ buildGoModule rec { nativeBuildInputs = [ makeWrapper ]; ldflags = [ - "-s" "-w" "-X main.version=${version}" "-X main.commit=${src.rev}" + "-s" + "-w" + "-X main.version=${version}" + "-X main.commit=${src.rev}" ]; postFixup = '' diff --git a/pkgs/tools/security/gopass/summon.nix b/pkgs/tools/security/gopass/summon.nix index f36db1e9791d65..226adf97137b78 100644 --- a/pkgs/tools/security/gopass/summon.nix +++ b/pkgs/tools/security/gopass/summon.nix @@ -1,8 +1,9 @@ -{ lib -, makeWrapper -, buildGoModule -, fetchFromGitHub -, gopass +{ + lib, + makeWrapper, + buildGoModule, + fetchFromGitHub, + gopass, }: buildGoModule rec { @@ -23,7 +24,10 @@ buildGoModule rec { nativeBuildInputs = [ makeWrapper ]; ldflags = [ - "-s" "-w" "-X main.version=${version}" "-X main.commit=${src.rev}" + "-s" + "-w" + "-X main.version=${version}" + "-X main.commit=${src.rev}" ]; postFixup = '' diff --git a/pkgs/tools/security/gotrue/default.nix b/pkgs/tools/security/gotrue/default.nix index 6a9d77ba062a66..6bff0c026a2adc 100644 --- a/pkgs/tools/security/gotrue/default.nix +++ b/pkgs/tools/security/gotrue/default.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, fetchFromGitHub }: +{ + lib, + buildGoModule, + fetchFromGitHub, +}: buildGoModule rec { pname = "gotrue"; diff --git a/pkgs/tools/security/gotrue/supabase.nix b/pkgs/tools/security/gotrue/supabase.nix index 4903db23918f2f..48da315e59cddd 100644 --- a/pkgs/tools/security/gotrue/supabase.nix +++ b/pkgs/tools/security/gotrue/supabase.nix @@ -1,8 +1,9 @@ -{ lib -, buildGoModule -, fetchFromGitHub -, testers -, gotrue-supabase +{ + lib, + buildGoModule, + fetchFromGitHub, + testers, + gotrue-supabase, }: buildGoModule rec { diff --git a/pkgs/tools/security/gpg-tui/default.nix b/pkgs/tools/security/gpg-tui/default.nix index 5c4dd4620eaf37..9cbb02b24201fa 100644 --- a/pkgs/tools/security/gpg-tui/default.nix +++ b/pkgs/tools/security/gpg-tui/default.nix @@ -1,17 +1,20 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, gpgme -, libgpg-error -, pkg-config -, python3 -, AppKit -, Foundation -, libiconv -, libobjc -, libresolv -, x11Support ? true, libxcb, libxkbcommon +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + gpgme, + libgpg-error, + pkg-config, + python3, + AppKit, + Foundation, + libiconv, + libobjc, + libresolv, + x11Support ? true, + libxcb, + libxkbcommon, }: rustPlatform.buildRustPackage rec { @@ -34,26 +37,32 @@ rustPlatform.buildRustPackage rec { python3 ]; - buildInputs = [ - gpgme - libgpg-error - ] ++ lib.optionals x11Support [ - libxcb - libxkbcommon - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - AppKit - Foundation - libiconv - libobjc - libresolv - ]; + buildInputs = + [ + gpgme + libgpg-error + ] + ++ lib.optionals x11Support [ + libxcb + libxkbcommon + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + Foundation + libiconv + libobjc + libresolv + ]; meta = with lib; { description = "Terminal user interface for GnuPG"; homepage = "https://github.com/orhun/gpg-tui"; changelog = "https://github.com/orhun/gpg-tui/blob/${src.rev}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ dotlambda matthiasbeyer ]; + maintainers = with maintainers; [ + dotlambda + matthiasbeyer + ]; mainProgram = "gpg-tui"; }; } diff --git a/pkgs/tools/security/hashcat/default.nix b/pkgs/tools/security/hashcat/default.nix index 55201b3d848357..03e99733500bc7 100644 --- a/pkgs/tools/security/hashcat/default.nix +++ b/pkgs/tools/security/hashcat/default.nix @@ -1,18 +1,24 @@ -{ lib, stdenv -, addDriverRunpath -, config -, cudaPackages ? {} -, cudaSupport ? config.cudaSupport -, fetchurl -, makeWrapper -, opencl-headers -, ocl-icd -, xxHash -, Foundation, IOKit, Metal, OpenCL, libiconv +{ + lib, + stdenv, + addDriverRunpath, + config, + cudaPackages ? { }, + cudaSupport ? config.cudaSupport, + fetchurl, + makeWrapper, + opencl-headers, + ocl-icd, + xxHash, + Foundation, + IOKit, + Metal, + OpenCL, + libiconv, }: stdenv.mkDerivation rec { - pname = "hashcat"; + pname = "hashcat"; version = "6.2.6"; src = fetchurl { @@ -30,24 +36,38 @@ stdenv.mkDerivation rec { --replace '-i ""' '-i' ''; - nativeBuildInputs = [ - makeWrapper - ] ++ lib.optionals cudaSupport [ - addDriverRunpath - ]; + nativeBuildInputs = + [ + makeWrapper + ] + ++ lib.optionals cudaSupport [ + addDriverRunpath + ]; - buildInputs = [ opencl-headers xxHash ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Foundation IOKit Metal OpenCL libiconv ]; + buildInputs = + [ + opencl-headers + xxHash + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Foundation + IOKit + Metal + OpenCL + libiconv + ]; - makeFlags = [ - "PREFIX=${placeholder "out"}" - "COMPTIME=1337" - "VERSION_TAG=${version}" - "USE_SYSTEM_OPENCL=1" - "USE_SYSTEM_XXHASH=1" - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform == stdenv.buildPlatform) [ - "IS_APPLE_SILICON='${if stdenv.hostPlatform.isAarch64 then "1" else "0"}'" - ]; + makeFlags = + [ + "PREFIX=${placeholder "out"}" + "COMPTIME=1337" + "VERSION_TAG=${version}" + "USE_SYSTEM_OPENCL=1" + "USE_SYSTEM_XXHASH=1" + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform == stdenv.buildPlatform) [ + "IS_APPLE_SILICON='${if stdenv.hostPlatform.isAarch64 then "1" else "0"}'" + ]; enableParallelBuilding = true; @@ -59,28 +79,37 @@ stdenv.mkDerivation rec { done ''; - postFixup = let - LD_LIBRARY_PATH = builtins.concatStringsSep ":" ([ - "${ocl-icd}/lib" - ] ++ lib.optionals cudaSupport [ - "${cudaPackages.cudatoolkit}/lib" - ]); - in '' - wrapProgram $out/bin/hashcat \ - --prefix LD_LIBRARY_PATH : ${lib.escapeShellArg LD_LIBRARY_PATH} - '' + lib.optionalString cudaSupport '' - for program in $out/bin/hashcat $out/bin/.hashcat-wrapped; do - isELF "$program" || continue - addDriverRunpath "$program" - done - ''; + postFixup = + let + LD_LIBRARY_PATH = builtins.concatStringsSep ":" ( + [ + "${ocl-icd}/lib" + ] + ++ lib.optionals cudaSupport [ + "${cudaPackages.cudatoolkit}/lib" + ] + ); + in + '' + wrapProgram $out/bin/hashcat \ + --prefix LD_LIBRARY_PATH : ${lib.escapeShellArg LD_LIBRARY_PATH} + '' + + lib.optionalString cudaSupport '' + for program in $out/bin/hashcat $out/bin/.hashcat-wrapped; do + isELF "$program" || continue + addDriverRunpath "$program" + done + ''; meta = with lib; { description = "Fast password cracker"; mainProgram = "hashcat"; - homepage = "https://hashcat.net/hashcat/"; - license = licenses.mit; - platforms = platforms.unix; - maintainers = with maintainers; [ felixalbrigtsen zimbatm ]; + homepage = "https://hashcat.net/hashcat/"; + license = licenses.mit; + platforms = platforms.unix; + maintainers = with maintainers; [ + felixalbrigtsen + zimbatm + ]; }; } diff --git a/pkgs/tools/security/honggfuzz/default.nix b/pkgs/tools/security/honggfuzz/default.nix index 7bb89718baca74..3515430b965c91 100644 --- a/pkgs/tools/security/honggfuzz/default.nix +++ b/pkgs/tools/security/honggfuzz/default.nix @@ -1,13 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, clang -, llvm -, libbfd -, libopcodes -, libunwind -, libblocksruntime }: +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + clang, + llvm, + libbfd, + libopcodes, + libunwind, + libblocksruntime, +}: stdenv.mkDerivation rec { pname = "honggfuzz"; @@ -29,7 +31,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; buildInputs = [ llvm ]; - propagatedBuildInputs = [ libbfd libopcodes libunwind libblocksruntime ]; + propagatedBuildInputs = [ + libbfd + libopcodes + libunwind + libblocksruntime + ]; # Fortify causes build failures: 'str*' defined both normally and as 'alias' attribute hardeningDisable = [ "fortify" ]; @@ -45,8 +52,7 @@ stdenv.mkDerivation rec { ''; meta = { - description = - "A security oriented, feedback-driven, evolutionary, easy-to-use fuzzer"; + description = "A security oriented, feedback-driven, evolutionary, easy-to-use fuzzer"; longDescription = '' Honggfuzz is a security oriented, feedback-driven, evolutionary, easy-to-use fuzzer with interesting analysis options. It is @@ -63,6 +69,9 @@ stdenv.mkDerivation rec { homepage = "https://honggfuzz.dev/"; license = lib.licenses.asl20; platforms = lib.platforms.linux; - maintainers = with lib.maintainers; [ cpu chivay ]; + maintainers = with lib.maintainers; [ + cpu + chivay + ]; }; } diff --git a/pkgs/tools/security/iaito/default.nix b/pkgs/tools/security/iaito/default.nix index 0367e767abc685..1e96c46de2d6d6 100644 --- a/pkgs/tools/security/iaito/default.nix +++ b/pkgs/tools/security/iaito/default.nix @@ -1,14 +1,15 @@ -{ lib -, stdenv -, fetchFromGitHub -, meson -, ninja -, pkg-config -, python3 -, qtbase -, qttools -, radare2 -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + meson, + ninja, + pkg-config, + python3, + qtbase, + qttools, + radare2, + wrapQtAppsHook, }: let @@ -34,7 +35,10 @@ in stdenv.mkDerivation (finalAttrs: { inherit pname version; - srcs = [ main_src translations_src ]; + srcs = [ + main_src + translations_src + ]; sourceRoot = "${main_src.name}/src"; postUnpack = '' diff --git a/pkgs/tools/security/jwt-cli/default.nix b/pkgs/tools/security/jwt-cli/default.nix index 051147df246419..561dc0b50f2d95 100644 --- a/pkgs/tools/security/jwt-cli/default.nix +++ b/pkgs/tools/security/jwt-cli/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, installShellFiles, rustPlatform, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + installShellFiles, + rustPlatform, + Security, +}: rustPlatform.buildRustPackage rec { pname = "jwt-cli"; diff --git a/pkgs/tools/security/kbs2/default.nix b/pkgs/tools/security/kbs2/default.nix index 04c6923af041f9..0815c65ec12b70 100644 --- a/pkgs/tools/security/kbs2/default.nix +++ b/pkgs/tools/security/kbs2/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, installShellFiles -, python3 -, libxcb -, AppKit -, SystemConfiguration +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + installShellFiles, + python3, + libxcb, + AppKit, + SystemConfiguration, }: rustPlatform.buildRustPackage rec { @@ -22,29 +23,35 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-LcnvCWGVdBxhDgQDoGHXRppGeEpfjOv/F0dZMN2bOF8="; - nativeBuildInputs = [ installShellFiles ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ python3 ]; + nativeBuildInputs = [ installShellFiles ] ++ lib.optionals stdenv.hostPlatform.isLinux [ python3 ]; - buildInputs = [ ] + buildInputs = + [ ] ++ lib.optionals stdenv.hostPlatform.isLinux [ libxcb ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ SystemConfiguration AppKit ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + SystemConfiguration + AppKit + ]; preCheck = '' export HOME=$TMPDIR ''; - checkFlags = [ "--skip=kbs2::config::tests::test_find_config_dir" ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ "--skip=test_ragelib_rewrap_keyfile" ]; - - postInstall = '' - mkdir -p $out/share/kbs2 - cp -r contrib/ $out/share/kbs2 - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - installShellCompletion --cmd kbs2 \ - --bash <($out/bin/kbs2 --completions bash) \ - --fish <($out/bin/kbs2 --completions fish) \ - --zsh <($out/bin/kbs2 --completions zsh) - ''; + checkFlags = [ + "--skip=kbs2::config::tests::test_find_config_dir" + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ "--skip=test_ragelib_rewrap_keyfile" ]; + + postInstall = + '' + mkdir -p $out/share/kbs2 + cp -r contrib/ $out/share/kbs2 + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + installShellCompletion --cmd kbs2 \ + --bash <($out/bin/kbs2 --completions bash) \ + --fish <($out/bin/kbs2 --completions fish) \ + --zsh <($out/bin/kbs2 --completions zsh) + ''; meta = with lib; { description = "Secret manager backed by age"; diff --git a/pkgs/tools/security/keybase/default.nix b/pkgs/tools/security/keybase/default.nix index b75dd1eb202d74..44ec908dcf5477 100644 --- a/pkgs/tools/security/keybase/default.nix +++ b/pkgs/tools/security/keybase/default.nix @@ -1,6 +1,18 @@ -{ stdenv, substituteAll, lib, buildGoModule, fetchFromGitHub -, AppKit, AVFoundation, AudioToolbox, ImageIO, CoreMedia -, Foundation, CoreGraphics, MediaToolbox, gnupg +{ + stdenv, + substituteAll, + lib, + buildGoModule, + fetchFromGitHub, + AppKit, + AVFoundation, + AudioToolbox, + ImageIO, + CoreMedia, + Foundation, + CoreGraphics, + MediaToolbox, + gnupg, }: buildGoModule rec { @@ -8,7 +20,10 @@ buildGoModule rec { version = "6.4.0"; modRoot = "go"; - subPackages = [ "kbnm" "keybase" ]; + subPackages = [ + "kbnm" + "keybase" + ]; dontRenameImports = true; @@ -28,15 +43,34 @@ buildGoModule rec { }) ]; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ AppKit AVFoundation AudioToolbox ImageIO CoreMedia Foundation CoreGraphics MediaToolbox ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + AppKit + AVFoundation + AudioToolbox + ImageIO + CoreMedia + Foundation + CoreGraphics + MediaToolbox + ]; tags = [ "production" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://www.keybase.io/"; description = "Keybase official command-line utility and service"; platforms = platforms.linux ++ platforms.darwin; - maintainers = with maintainers; [ avaq np rvolosatovs Br1ght0ne shofius ryand56 ]; + maintainers = with maintainers; [ + avaq + np + rvolosatovs + Br1ght0ne + shofius + ryand56 + ]; license = licenses.bsd3; }; } diff --git a/pkgs/tools/security/keybase/gui.nix b/pkgs/tools/security/keybase/gui.nix index c80d28c2f8630f..0d4c4387cc4fef 100644 --- a/pkgs/tools/security/keybase/gui.nix +++ b/pkgs/tools/security/keybase/gui.nix @@ -1,7 +1,33 @@ -{ stdenv, lib, fetchurl, alsa-lib, atk, cairo, cups, udev, libdrm, mesa -, dbus, expat, fontconfig, freetype, gdk-pixbuf, glib, gtk3, libappindicator-gtk3 -, libnotify, nspr, nss, pango, systemd, xorg, autoPatchelfHook, wrapGAppsHook3 -, runtimeShell, gsettings-desktop-schemas }: +{ + stdenv, + lib, + fetchurl, + alsa-lib, + atk, + cairo, + cups, + udev, + libdrm, + mesa, + dbus, + expat, + fontconfig, + freetype, + gdk-pixbuf, + glib, + gtk3, + libappindicator-gtk3, + libnotify, + nspr, + nss, + pango, + systemd, + xorg, + autoPatchelfHook, + wrapGAppsHook3, + runtimeShell, + gsettings-desktop-schemas, +}: let versionSuffix = "20240821175720.3212f60cc5"; @@ -111,7 +137,15 @@ stdenv.mkDerivation rec { description = "Keybase official GUI"; mainProgram = "keybase-gui"; platforms = [ "x86_64-linux" ]; - maintainers = with maintainers; [ avaq rvolosatovs puffnfresh np Br1ght0ne shofius ryand56 ]; + maintainers = with maintainers; [ + avaq + rvolosatovs + puffnfresh + np + Br1ght0ne + shofius + ryand56 + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; license = licenses.bsd3; }; diff --git a/pkgs/tools/security/keybase/kbfs.nix b/pkgs/tools/security/keybase/kbfs.nix index b3e2974a0033bc..f09affe19c7b94 100644 --- a/pkgs/tools/security/keybase/kbfs.nix +++ b/pkgs/tools/security/keybase/kbfs.nix @@ -1,4 +1,8 @@ -{ lib, buildGoModule, keybase }: +{ + lib, + buildGoModule, + keybase, +}: buildGoModule { pname = "kbfs"; @@ -6,15 +10,28 @@ buildGoModule { inherit (keybase) src version vendorHash; modRoot = "go"; - subPackages = [ "kbfs/kbfsfuse" "kbfs/redirector" "kbfs/kbfsgit/git-remote-keybase" ]; + subPackages = [ + "kbfs/kbfsfuse" + "kbfs/redirector" + "kbfs/kbfsgit/git-remote-keybase" + ]; tags = [ "production" ]; - ldflags = [ "-s" "-w" ]; + ldflags = [ + "-s" + "-w" + ]; meta = with lib; { homepage = "https://keybase.io/docs/kbfs"; description = "Keybase filesystem"; - maintainers = with maintainers; [ avaq rvolosatovs bennofs np shofius ]; + maintainers = with maintainers; [ + avaq + rvolosatovs + bennofs + np + shofius + ]; license = licenses.bsd3; }; } diff --git a/pkgs/tools/security/keyscope/default.nix b/pkgs/tools/security/keyscope/default.nix index b2bd09d1f44a5d..06b343a5064e76 100644 --- a/pkgs/tools/security/keyscope/default.nix +++ b/pkgs/tools/security/keyscope/default.nix @@ -1,13 +1,14 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, pkg-config -, openssl -, stdenv -, DiskArbitration -, Foundation -, IOKit -, Security +{ + lib, + rustPlatform, + fetchFromGitHub, + pkg-config, + openssl, + stdenv, + DiskArbitration, + Foundation, + IOKit, + Security, }: rustPlatform.buildRustPackage rec { @@ -25,12 +26,14 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - DiskArbitration - Foundation - IOKit - Security - ]; + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + DiskArbitration + Foundation + IOKit + Security + ]; # build script tries to get information from git postPatch = '' diff --git a/pkgs/tools/security/krunner-pass/default.nix b/pkgs/tools/security/krunner-pass/default.nix index 032840b7d33c0a..00f76354d09df5 100644 --- a/pkgs/tools/security/krunner-pass/default.nix +++ b/pkgs/tools/security/krunner-pass/default.nix @@ -1,12 +1,13 @@ -{ mkDerivation -, lib -, fetchFromGitHub -, fetchpatch -, cmake -, extra-cmake-modules -, kauth -, krunner -, pass +{ + mkDerivation, + lib, + fetchFromGitHub, + fetchpatch, + cmake, + extra-cmake-modules, + kauth, + krunner, + pass, }: mkDerivation rec { @@ -27,7 +28,10 @@ mkDerivation rec { (pass.withExtensions (p: with p; [ pass-otp ])) ]; - nativeBuildInputs = [ cmake extra-cmake-modules ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; patches = [ (fetchpatch { diff --git a/pkgs/tools/security/lethe/default.nix b/pkgs/tools/security/lethe/default.nix index 21875006f4fcbf..bd07d73130cf90 100644 --- a/pkgs/tools/security/lethe/default.nix +++ b/pkgs/tools/security/lethe/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, }: rustPlatform.buildRustPackage rec { diff --git a/pkgs/tools/security/libacr38u/default.nix b/pkgs/tools/security/libacr38u/default.nix index 45db3985d555dc..c5e4ad0aca1d10 100644 --- a/pkgs/tools/security/libacr38u/default.nix +++ b/pkgs/tools/security/libacr38u/default.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchurl, autoreconfHook, pkg-config, pcsclite , libusb-compat-0_1, IOKit }: +{ + lib, + stdenv, + fetchurl, + autoreconfHook, + pkg-config, + pcsclite, + libusb-compat-0_1, + IOKit, +}: stdenv.mkDerivation { version = "1.7.11"; @@ -11,9 +20,14 @@ stdenv.mkDerivation { doCheck = true; - nativeBuildInputs = [ autoreconfHook pkg-config ]; - buildInputs = [ pcsclite libusb-compat-0_1 ] - ++ lib.optional stdenv.hostPlatform.isDarwin IOKit; + nativeBuildInputs = [ + autoreconfHook + pkg-config + ]; + buildInputs = [ + pcsclite + libusb-compat-0_1 + ] ++ lib.optional stdenv.hostPlatform.isDarwin IOKit; preBuild = '' makeFlagsArray=(usbdropdir="$out/pcsc/drivers"); diff --git a/pkgs/tools/security/libmodsecurity/default.nix b/pkgs/tools/security/libmodsecurity/default.nix index 83dc2bff29daa3..a5d840d44df0f8 100644 --- a/pkgs/tools/security/libmodsecurity/default.nix +++ b/pkgs/tools/security/libmodsecurity/default.nix @@ -1,7 +1,22 @@ -{ lib, stdenv, fetchFromGitHub -, autoreconfHook, bison, flex, pkg-config -, curl, geoip, libmaxminddb, libxml2, lmdb, lua, pcre, pcre2, ssdeep, yajl -, nixosTests +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + bison, + flex, + pkg-config, + curl, + geoip, + libmaxminddb, + libxml2, + lmdb, + lua, + pcre, + pcre2, + ssdeep, + yajl, + nixosTests, }: stdenv.mkDerivation rec { @@ -16,10 +31,29 @@ stdenv.mkDerivation rec { fetchSubmodules = true; }; - nativeBuildInputs = [ autoreconfHook bison flex pkg-config ]; - buildInputs = [ curl geoip libmaxminddb libxml2 lmdb lua pcre pcre2 ssdeep yajl ]; + nativeBuildInputs = [ + autoreconfHook + bison + flex + pkg-config + ]; + buildInputs = [ + curl + geoip + libmaxminddb + libxml2 + lmdb + lua + pcre + pcre2 + ssdeep + yajl + ]; - outputs = [ "out" "dev" ]; + outputs = [ + "out" + "dev" + ]; configureFlags = [ "--enable-parser-generation" diff --git a/pkgs/tools/security/maigret/default.nix b/pkgs/tools/security/maigret/default.nix index 0936e0d9806240..87f8e9828f4c3e 100644 --- a/pkgs/tools/security/maigret/default.nix +++ b/pkgs/tools/security/maigret/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, fetchpatch -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + fetchpatch, + python3, }: python3.pkgs.buildPythonApplication rec { @@ -26,7 +27,6 @@ python3.pkgs.buildPythonApplication rec { }) ]; - propagatedBuildInputs = with python3.pkgs; [ aiodns aiohttp @@ -84,19 +84,21 @@ python3.pkgs.buildPythonApplication rec { "-W ignore::DeprecationWarning" ]; - disabledTests = [ - # Tests require network access - "test_extract_ids_from_page" - "test_import_aiohttp_cookies" - "test_maigret_results" - "test_pdf_report" - "test_self_check_db_negative_enabled" - "test_self_check_db_positive_enable" - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - # AsyncioProgressbarExecutor is slower on darwin than it should be, - # Upstream issue: https://github.com/soxoj/maigret/issues/679 - "test_asyncio_progressbar_executor" - ]; + disabledTests = + [ + # Tests require network access + "test_extract_ids_from_page" + "test_import_aiohttp_cookies" + "test_maigret_results" + "test_pdf_report" + "test_self_check_db_negative_enabled" + "test_self_check_db_positive_enable" + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + # AsyncioProgressbarExecutor is slower on darwin than it should be, + # Upstream issue: https://github.com/soxoj/maigret/issues/679 + "test_asyncio_progressbar_executor" + ]; pythonImportsCheck = [ "maigret" diff --git a/pkgs/tools/security/metasploit/gemset.nix b/pkgs/tools/security/metasploit/gemset.nix index 77dacba2fca82f..0f1f00427073fd 100644 --- a/pkgs/tools/security/metasploit/gemset.nix +++ b/pkgs/tools/security/metasploit/gemset.nix @@ -1,737 +1,737 @@ { aarch64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c0hkbm94prkw0nb76l0il7fhz1xz5dkgzh6wwyrs88lwggv9avh"; type = "gem"; }; version = "2.1.0"; }; abbrev = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hj2qyx7rzpc7awhvqlm597x7qdxwi4kkml4aqnp5jylmsm4w6xd"; type = "gem"; }; version = "0.1.2"; }; actionpack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19ywl4jp77b51c01hsyzwia093fnj73pw1ipgyj4pk3h2b9faj5n"; type = "gem"; }; version = "7.0.8.6"; }; actionview = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0girx71db1aq5b70ln3qq03z9d7xjdyp297v1a8rdal7k89y859c"; type = "gem"; }; version = "7.0.8.6"; }; activemodel = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1f6szahjsb4pr2xvlvk4kghk9291xh9c14s8cqwy6wwpm1vcglim"; type = "gem"; }; version = "7.0.8.6"; }; activerecord = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14qs1jc9hwnsm4dzvnai8b36bcq1d7rcqgjxy0dc6wza670lqapf"; type = "gem"; }; version = "7.0.8.6"; }; activesupport = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gj20cysajda05z3r7pl1g9y84nzsqak5dvk9nrz13jpy6297dj1"; type = "gem"; }; version = "7.0.8.6"; }; addressable = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; afm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06kj9hgd0z8pj27bxp2diwqh6fv7qhwwm17z64rhdc4sfn76jgn8"; type = "gem"; }; version = "0.2.2"; }; arel-helpers = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0agzw7ix33a8framb8mnmhwf9qm9bwrcmlk8mzzm0w37fmlnm167"; type = "gem"; }; version = "2.15.0"; }; Ascii85 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c62cx96r0v265mywnlik43qx0wf6bjbzl54qa47x6dzjg861mvk"; type = "gem"; }; version = "1.1.1"; }; aws-eventstream = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gvdg4yx4p9av2glmp7vsxhs0n8fj1ga9kq2xdb8f95j7b04qhzi"; type = "gem"; }; version = "1.3.0"; }; aws-partitions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1f2y7ycq7i3y7p5klsi3gk3p5r5p1vkq6w7dq4zk9grq2hw9f7cv"; type = "gem"; }; version = "1.999.0"; }; aws-sdk-core = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16mvscjhxdyhlvk2rpbxdzqmyikcf64xavb35grk4dkh0pg390rk"; type = "gem"; }; version = "3.211.0"; }; aws-sdk-ec2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "12lbxp1ccsd1d0v45c1rh7j2s2ajkl5iw0fpa66yghdpjvagxgk4"; type = "gem"; }; version = "1.486.0"; }; aws-sdk-ec2instanceconnect = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cjzjj3x5v0b99vasphw8hn61jnw8wx56qh9n1a269a4yahprr1l"; type = "gem"; }; version = "1.52.0"; }; aws-sdk-iam = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1abcvm6d3w23hg8wj6f16948aj91wliahjjwsbh69p3dryi9fh7f"; type = "gem"; }; version = "1.112.0"; }; aws-sdk-kms = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ppxhw2qyj69achpmksp1sh2y6k0x44928ln2am9pifx8b30ir9a"; type = "gem"; }; version = "1.95.0"; }; aws-sdk-s3 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jnf9k9d91ki3yvy12q4kph5wvd8l3ziwwh0qsmar5xhyb7zbwrz"; type = "gem"; }; version = "1.169.0"; }; aws-sdk-ssm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06cb5ibhwq7ri0g5mfmmvjapqvv7cblwa8i01k9ciisvqjkzbs3v"; type = "gem"; }; version = "1.183.0"; }; aws-sigv4 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fq3lbvkgm1vk5wa8l7vdnq3vjnlmsnyf4bbd0jq3qadyd9hf54a"; type = "gem"; }; version = "1.10.1"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bcrypt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16a0g2q40biv93i1hch3gw8rbmhp77qnnifj1k0a6m7dng3zh444"; type = "gem"; }; version = "3.1.20"; }; bcrypt_pbkdf = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04rb3rp9bdxn1y3qiflfpj7ccwb8ghrfbydh5vfz1l9px3fpg41g"; type = "gem"; }; version = "1.1.1"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; bindata = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "04y4zgh4bbcb8wmkxwfqg4saky1d1f3xw8z6yk543q13h8ky8rz5"; type = "gem"; }; version = "2.4.15"; }; bootsnap = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0mdgj9yw1hmx3xh2qxyjc31y8igmxzd9h0c245ay2zkz76pl4k5c"; type = "gem"; }; version = "1.18.4"; }; bson = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19gzm5prhbrv6ibyxi0czsm8fjsh0lrsxngfg0q0vzjjwfdd30ap"; type = "gem"; }; version = "5.0.1"; }; builder = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pw3r2lyagsxkm71bf44v5b74f7l9r7di22brbyji9fwz791hya9"; type = "gem"; }; version = "3.3.0"; }; chunky_png = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1znw5x86hmm9vfhidwdsijz8m38pqgmv98l9ryilvky0aldv7mc9"; type = "gem"; }; version = "1.4.0"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; cookiejar = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1px0zlnlkwwp9prdkm2lamgy412y009646n2cgsa1xxsqk7nmc8i"; type = "gem"; }; version = "0.3.4"; }; crass = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pfl5c0pyqaparxaqxi6s4gfl21bdldwiawrc0aknyvflli60lfw"; type = "gem"; }; version = "1.0.6"; }; csv = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zfn40dvgjk1xv1z8l11hr9jfg3jncwsc9yhzsz4l4rivkpivg8b"; type = "gem"; }; version = "3.3.0"; }; daemons = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07cszb0zl8mqmwhc8a2yfg36vi6lbgrp4pa5bvmryrpcz9v6viwg"; type = "gem"; }; version = "1.4.1"; }; date = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "149jknsq999gnhy865n33fkk22s0r447k76x9pmcnnwldfv2q7wp"; type = "gem"; }; version = "3.3.4"; }; dnsruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "066dpkgka17fkn5cv7sk2f4jmwb5d1jila1cnhm77cnd01k5mqcm"; type = "gem"; }; version = "1.72.2"; }; domain_name = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cyr2xm576gqhqicsyqnhanni47408w2pgvrfi8pd13h2li3nsaz"; type = "gem"; }; version = "0.6.20240107"; }; drb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h5kbj9hvg5hb3c7l425zpds0vb42phvln2knab8nmazg2zp5m79"; type = "gem"; }; version = "2.2.1"; }; ed25519 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zb2dr2ihb1qiknn5iaj1ha1w9p7lj9yq5waasndlfadz225ajji"; type = "gem"; }; version = "1.3.0"; }; elftools = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1y5ahqk24ngjiyfbj5xapxwfb34yslcpn4l0khdq4pkxkajgqilx"; type = "gem"; }; version = "1.3.1"; }; em-http-request = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1azx5rgm1zvx7391sfwcxzyccs46x495vb34ql2ch83f58mwgyqn"; type = "gem"; }; version = "1.1.7"; }; em-socksify = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vbl74x9m4hccmmhcnp36s50mn7d81annfj3fcqjdhdcm2khi3bx"; type = "gem"; }; version = "0.3.3"; }; erubi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qnd6ff4az22ysnmni3730c41b979xinilahzg86bn7gv93ip9pw"; type = "gem"; }; version = "1.13.0"; }; eventmachine = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wh9aqb0skz80fhfn66lbpr4f86ya2z5rx6gm5xlfhd05bj1ch4r"; type = "gem"; }; version = "1.2.7"; }; faker = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1z4vhl6lbd0la2j0ab05sz8wq5mqvpikzhjrc142z24x4zmgpl8s"; type = "gem"; }; version = "3.5.1"; }; faraday = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vn7jwss2v6jhnxvjsiwbs3irjwhbx9zxn4l6fhd4rkcfyxzdnw5"; type = "gem"; }; version = "2.7.11"; }; faraday-net_http = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13byv3mp1gsjyv8k0ih4612y6vw5kqva6i03wcg4w2fqpsd950k8"; type = "gem"; }; version = "3.0.2"; }; faraday-retry = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "023ncwlagnf2irx2ckyj1pg1f1x436jgr4a5y45mih298p8zwij1"; type = "gem"; }; version = "2.2.1"; }; faye-websocket = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01xkpv5b4fjc5n6n1fq6z1ris991av2fbadvs8r71i9r34b8g48h"; type = "gem"; }; version = "0.11.3"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yvii03hcgqj30maavddqamqy50h7y6xcn2wcyq72wn823zl4ckd"; type = "gem"; }; version = "1.16.3"; }; filesize = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17p7rf1x7h3ivaznb4n4kmxnnzj25zaviryqgn2n12v2kmibhp8g"; type = "gem"; }; version = "0.2.0"; }; getoptlong = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "198vy9dxyzibqdbw9jg8p2ljj9iknkyiqlyl229vz55rjxrz08zx"; type = "gem"; }; version = "0.2.1"; }; gssapi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qdfhj12aq8v0y961v4xv96a1y2z80h3xhvzrs9vsfgf884g6765"; type = "gem"; }; version = "1.3.1"; }; gyoku = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kd2q59xpm39hpvmmvyi6g3f1fr05xjbnxwkrdqz4xy7hirqi79q"; type = "gem"; }; version = "1.4.0"; }; hashery = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qj8815bf7q6q7llm5rzdz279gzmpqmqqicxnzv066a020iwqffj"; type = "gem"; }; version = "2.1.2"; }; hrr_rb_ssh = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dr6mv98ll0crdn2wm2yy9ywh130iljcsvnnvs6639k19qbfk7qf"; type = "gem"; }; version = "0.4.2"; }; hrr_rb_ssh-ed25519 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1mfsvjcjmm63fwjf3zqkmg3cf55vx34vmvix0wj0ba4h9dzjq7p8"; type = "gem"; }; version = "0.4.2"; }; http-cookie = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lr2yk5g5vvf9nzlmkn3p7mhh9mn55gpdc7kl2w21xs46fgkjynb"; type = "gem"; }; version = "1.0.7"; }; "http_parser.rb" = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gj4fmls0mf52dlr928gaq0c0cb0m3aqa9kaa6l0ikl2zbqk42as"; type = "gem"; }; version = "0.8.0"; }; httpclient = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19mxmvghp7ki3klsxwrlwr431li7hm1lczhhj8z4qihl2acy8l99"; type = "gem"; }; version = "2.8.3"; }; i18n = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k31wcgnvcvd14snz0pfqj976zv6drfsnq6x8acz10fiyms9l8nw"; type = "gem"; }; version = "1.14.6"; }; io-console = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08d2lx42pa8jjav0lcjbzfzmw61b8imxr9041pva8xzqabrczp7h"; type = "gem"; }; version = "0.7.2"; }; irb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "158ca10kj3qqnql5g8f1g2arsnhgdl79mg74manpf8ldkwjjn3n8"; type = "gem"; }; version = "1.7.4"; }; jmespath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cdw9vw2qly7q7r41s7phnac264rbsdqgj4l0h4nqgbjb157g393"; type = "gem"; }; version = "1.6.2"; }; jsobfu = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1hchns89cfj0gggm2zbr7ghb630imxm2x2d21ffx2jlasn9xbkyk"; type = "gem"; }; version = "0.4.2"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pkcvzvarzs5y87srla1m6rgng8mm7y4gnshlpawddsci3rlhd7b"; type = "gem"; }; version = "2.7.5"; }; little-plugger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1frilv82dyxnlg8k1jhrvyd73l6k17mxc5vwxx080r4x1p04gwym"; type = "gem"; }; version = "1.1.4"; }; logging = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jqcq2yxh973f3aw63nd3wxhqyhkncz3pf8v2gs3df0iqair725s"; type = "gem"; }; version = "2.4.0"; }; loofah = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ppp2cgli5avzk0z3dwnah6y65ymyr793yja28p2fs9vrci7986h"; type = "gem"; }; version = "2.23.1"; }; metasm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dpjbkdvi4h6v0g01db7vlcsg15pfiyslkz3zd7wfk04yrc6g7wi"; type = "gem"; }; version = "1.0.5"; }; metasploit-concern = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bqil5zzak47zcvcndn90lvxq0rxqb63vm4md3h7l3920drwfg58"; type = "gem"; }; version = "5.0.3"; }; metasploit-credential = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vf7kj428pcak7zm22vmbmy09hkmcgp8fz855il9wg6cdi1zxlr6"; type = "gem"; }; version = "6.0.11"; }; metasploit-framework = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { fetchSubmodules = false; rev = "b815ef9870c45e2f9d2e62475e1780ddb9bfb1d0"; @@ -742,1001 +742,1004 @@ version = "6.4.39"; }; metasploit-model = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vn50jnvdanmqbjm9xmp0i4xwzc9g3c6g2c4b59i2bz47kwp1pi7"; type = "gem"; }; version = "5.0.2"; }; metasploit-payloads = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13cm4pblldz1cl3cmvppkwsbv12b2a4kfl3r3kzfyjwrlhz121wn"; type = "gem"; }; version = "2.0.187"; }; metasploit_data_models = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gycp29xx68yyy0rynzd08zp7j0l3q8nqc2q9y3k67aqkf5b6pil"; type = "gem"; }; version = "6.0.5"; }; metasploit_payloads-mettle = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fsnr4i0660nhlkq9iyy5x214l2ds3akf6jnngf2hlp8j01w1x4w"; type = "gem"; }; version = "1.0.35"; }; method_source = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1igmc3sq9ay90f8xjvfnswd1dybj1s3fi0dwd53inwsvqk4h24qq"; type = "gem"; }; version = "1.1.0"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q1f2sdw3y3y9mnym9dhjgsjr72sq975cfg5c4yx7gwv8nmzbvhk"; type = "gem"; }; version = "2.8.7"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n1akmc6bibkbxkzm1p1wmfb4n9vv397knkgz0ffykb3h1d7kdix"; type = "gem"; }; version = "5.25.1"; }; mqtt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14iacsn0l8kl5pw9giaz2p3i06dwwj0mad9m0949bl5g8g35vsb3"; type = "gem"; }; version = "0.6.0"; }; msgpack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jr9grsdnlb8wgd9by7mhsc9c1wixijh9an4m4yq1ph0jg26x9rk"; type = "gem"; }; version = "1.6.1"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; mustermann = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "123ycmq6pkivv29bqbv79jv2cs04xakzd0fz1lalgvfs5nxfky6i"; type = "gem"; }; version = "3.0.3"; }; mutex_m = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ma093ayps1m92q845hmpk0dmadicvifkbf05rpq9pifhin0rvxn"; type = "gem"; }; version = "0.2.0"; }; nessus_rest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1allyrd4rll333zbmsi3hcyg6cw1dhc4bg347ibsw191nswnp8ci"; type = "gem"; }; version = "0.1.6"; }; net-imap = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "182ap7y5ysmr1xqy23ygssz3as1wcy3r5qcdm1whd1n1yfc1aa5q"; type = "gem"; }; version = "0.5.0"; }; net-ldap = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0g9gz39bs2iy4ky4fhjphimqd9m9wdsaz50anxgwg3yjrff3famy"; type = "gem"; }; version = "0.19.0"; }; net-protocol = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a32l4x73hz200cm587bc29q8q9az278syw3x6fkc9d1lv5y0wxa"; type = "gem"; }; version = "0.2.2"; }; net-sftp = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0r33aa2d61hv1psm0l0mm6ik3ycsnq8symv7h84kpyf2b7493fv5"; type = "gem"; }; version = "4.0.0"; }; net-smtp = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0amlhz8fhnjfmsiqcjajip57ici2xhw089x7zqyhpk51drg43h2z"; type = "gem"; }; version = "0.5.0"; }; net-ssh = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1w1ypxa3n6mskkwb00b489314km19l61p5h3bar6zr8cng27c80p"; type = "gem"; }; version = "7.3.0"; }; network_interface = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hqkas4c809w2gnic1srhq5rd2hpsfnhmrvm1vkix8w775qql74z"; type = "gem"; }; version = "0.0.4"; }; nexpose = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jz5xiwiwagd663qdlfhmc9fm76x78cqhighmfivy6w5v0n4xyq0"; type = "gem"; }; version = "7.3.0"; }; nio4r = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a9www524fl1ykspznz54i0phfqya4x45hqaz67in9dvw1lfwpfr"; type = "gem"; }; version = "2.7.4"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15gysw8rassqgdq3kwgl4mhqmrgh7nk2qvrcqp4ijyqazgywn6gq"; type = "gem"; }; version = "1.16.7"; }; nori = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qb84bbi74q0zgs09sdkq750jf2ri3lblbry0xi4g1ard4rwsrk1"; type = "gem"; }; version = "2.7.1"; }; octokit = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15lvy06h276jryxg19258b2yqaykf0567sp0n16yipywhbp94860"; type = "gem"; }; version = "4.25.1"; }; openssl-ccm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1mqr538wcfjc1q9qxsc2pz0s81kw1f3xk7k1qy903n5b3bh9vri3"; type = "gem"; }; version = "1.2.3"; }; openssl-cmac = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1mml6105j6ryd9d019gbwzkdjmvycjlxxld0qzg9vs70f1qdihcc"; type = "gem"; }; version = "2.0.2"; }; openvas-omp = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14xf614vd76qjdjxjv14mmjar6s64fwp4cwb7bv5g1wc29srg28x"; type = "gem"; }; version = "0.0.4"; }; packetfu = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0crsc4mcikpc01d19ppryzwgvhk9hg9r73g5bwac32x979zwyks8"; type = "gem"; }; version = "2.0.0"; }; patch_finder = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1md9scls55n1riw26vw1ak0ajq38dfygr36l0h00wqhv51cq745m"; type = "gem"; }; version = "1.0.2"; }; pcaprub = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ag6p7n5s1s3mcsqw8rzafz5dlanwwqfkh7sb44qlp0dq8bvh73v"; type = "gem"; }; version = "0.13.3"; }; pdf-reader = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0n0pp7blk3np3fqsb54l34fsamrww80cp3dhlhskfayg7542mrv1"; type = "gem"; }; version = "2.12.0"; }; pg = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1p2gqqrm895fzr9vi8d118zhql67bm8ydjvgqbq1crdnfggzn7kn"; type = "gem"; }; version = "1.5.9"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vqcw3iwby3yc6avs1vb3gfd0vcp2v7q310665dvxfswmcf4xm31"; type = "gem"; }; version = "6.0.1"; }; puma = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gml1rixrfb0naciq3mrnqkpcvm9ahgps1c04hzxh4b801f69914"; type = "gem"; }; version = "6.4.3"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0byn0c9nkahsl93y9ln5bysq4j31q8xkf2ws42swighxd4lnjzsa"; type = "gem"; }; version = "1.8.1"; }; rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ax778fsfvlhj7c11n0d1wdcb8bxvkb190a9lha5d91biwzyx9g4"; type = "gem"; }; version = "2.2.10"; }; rack-protection = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zzvivmdb4dkscc58i3gmcyrnypynsjwp6xgc4ylarlhqmzvlx1w"; type = "gem"; }; version = "3.2.0"; }; rack-test = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ysx29gk9k14a14zsp5a8czys140wacvp91fja8xcja0j1hzqq8c"; type = "gem"; }; version = "2.1.0"; }; rails-dom-testing = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fx9dx1ag0s1lr6lfr34lbx5i1bvn3bhyf3w3mx6h7yz90p725g5"; type = "gem"; }; version = "2.2.0"; }; rails-html-sanitizer = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pm4z853nyz1bhhqr7fzl44alnx4bjachcr6rh6qjj375sfz3sc6"; type = "gem"; }; version = "1.6.0"; }; railties = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fcn0ix814074gqicc0k1178f7ahmysiv3pfq8g00phdwj0p3w0g"; type = "gem"; }; version = "7.0.8.6"; }; rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17850wcwkgi30p7yqh60960ypn7yibacjjha0av78zaxwvd3ijs6"; type = "gem"; }; version = "13.2.1"; }; rasn1 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07dvrv2s9hs2vcbr6lai8vj4vk2i3m4jf468hyvkp9k8xzjvc0fi"; type = "gem"; }; version = "0.13.0"; }; rb-readline = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14w79a121czmvk1s953qfzww30mqjb2zc0k9qhi0ivxxk3hxg6wy"; type = "gem"; }; version = "0.5.5"; }; recog = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h10ahhirxwffsw0g7lyzj1wldna136z11iyskiwib1h9whqihc5"; type = "gem"; }; version = "3.1.11"; }; redcarpet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sg9sbf9pm91l7lac7fs4silabyn0vflxwaa2x3lrzsm0ff8ilca"; type = "gem"; }; version = "3.6.0"; }; reline = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rl1jmxs7pay58l7lkxkrn6nkdpk52k8rvnfwqsd1swjlxlwjq0n"; type = "gem"; }; version = "0.5.10"; }; rex-arch = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pl2kqqsy0gxwdlni1vr6hkqcjyncxnss5lrv35i3f0y5gnjf087"; type = "gem"; }; version = "0.1.16"; }; rex-bin_tools = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hdkjv9g04d9k6mq1j9fxg9l6ifzym5i204majhzb9hqkfgslw5p"; type = "gem"; }; version = "0.1.9"; }; rex-core = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0468gxcwhzp5y7lahkf0cg4vyy01wb2fk6w1rx4fgh1l9330a64b"; type = "gem"; }; version = "0.1.32"; }; rex-encoder = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rlpxmw4amqf04vn14my6aim5iya0wh5gpi1hrvnqq9xnhkpk2qs"; type = "gem"; }; version = "0.1.7"; }; rex-exploitation = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c4m82vgdp3zp7slcfsv0l30h4ij8fsvqv026xny2nxw514hxk0c"; type = "gem"; }; version = "0.1.40"; }; rex-java = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ynqlq1xqnw9asqnkszbjds972xm98fz92yq5ywrxz7p3x66ybbp"; type = "gem"; }; version = "0.1.7"; }; rex-mime = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0gi2xidygk6j7zwml6225d221bc3s7n2if5g1v1w45ksl19499b3"; type = "gem"; }; version = "0.1.8"; }; rex-nop = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vavmdzv5aw20izhrbf2f180dwvrraw8i9bh4yz5gsapjizcqrhy"; type = "gem"; }; version = "0.1.3"; }; rex-ole = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vbiqg120gqd0kfa7kw2jg4jy4y2favsm6kqvysxfjfwp6vfycl6"; type = "gem"; }; version = "0.1.8"; }; rex-powershell = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1p1m6hxmlfdiq2x5b5h54k5052si1ky8dh1r9kr9qlq38a94l2n4"; type = "gem"; }; version = "0.1.100"; }; rex-random_identifier = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bd7narnxbdadm61g22gvwfxq2cd38qk5kg0yjh7yfh1a1q6z53d"; type = "gem"; }; version = "0.1.13"; }; rex-registry = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sbcs0lkl8b57d5xdlfffrpwxpvvwfcfbgzqc9p7xgmqb1xl2s62"; type = "gem"; }; version = "0.1.5"; }; rex-rop_builder = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gbc9sssyzbq1s2nk0ajc9y0x4v10cp4za4f4gbssrjw4d3zf9dl"; type = "gem"; }; version = "0.1.5"; }; rex-socket = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1qmj5pya6ssghi3dfdmrykkbazhqlhq86ahwijdvrfr2q3g76p86"; type = "gem"; }; version = "0.1.57"; }; rex-sslscan = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0plcz9jwpg1yw206ljky3mk6dk31j24jdmcpnky5k9m2npsp0jlf"; type = "gem"; }; version = "0.1.10"; }; rex-struct2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1p6afmicm1adlngp196604rrgb1nsly10y8nphva5h5vncismscz"; type = "gem"; }; version = "0.1.4"; }; rex-text = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01d0wp4m1qlrfccv5w64bzp04pw36sinvdzmjzvq30sykbdlgjsv"; type = "gem"; }; version = "0.2.59"; }; rex-zip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15jjb3ldndi9p5x7pb3dllkrm4cy3p7dccy4rxz0vh5m4vlqbhsd"; type = "gem"; }; version = "0.1.5"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j9p66pmfgxnzp76ksssyfyqqrg7281dyi3xyknl3wwraaw7a66p"; type = "gem"; }; version = "3.3.9"; }; rkelly-remix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g7hjl9nx7f953y7lncmfgp0xgxfxvgfm367q6da9niik6rp1y3j"; type = "gem"; }; version = "0.0.7"; }; ruby-macho = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0859xi0shidwb9cfbczxsk8qrbi3qkmkp9xzyca1xzp0gmzv7ni3"; type = "gem"; }; version = "4.1.0"; }; ruby-mysql = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g6wcnzqsbqg2q1lfbhlz4z9rq306az2xx8kk8dnr60dziy1a5b5"; type = "gem"; }; version = "4.1.0"; }; ruby-rc4 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00vci475258mmbvsdqkmqadlwn6gj9m01sp7b5a3zd90knil1k00"; type = "gem"; }; version = "0.1.5"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; ruby_smb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vj22vmrygib1maa8bwh4xfqnvamh5pk39cffqv1mp8q5gv26vc7"; type = "gem"; }; version = "3.3.11"; }; rubyntlm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x8l0d1v88m40mby4jvgal46137cv8gga2lk7zlrxqlsp41380a7"; type = "gem"; }; version = "0.6.5"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; sawyer = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1jks1qjbmqm8f9kvwa81vqj39avaj9wdnzc531xm29a55bb74fps"; type = "gem"; }; version = "0.9.2"; }; simpleidn = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a9c1mdy12y81ck7mcn9f9i2s2wwzjh1nr92ps354q517zq9dkh8"; type = "gem"; }; version = "0.2.3"; }; sinatra = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01wq20aqk5kfggq3wagx5xr1cz0x08lg6dxbk9yhd1sf0d6pywkf"; type = "gem"; }; version = "3.2.0"; }; sqlite3 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "073hd24qwx9j26cqbk0jma0kiajjv9fb8swv9rnz8j4mf0ygcxzs"; type = "gem"; }; version = "1.7.3"; }; sshkey = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1k8i5pzjhcnyf0bhcyn5iixpfp4pz0556rcxwpglh6p0sr8s6nv5"; type = "gem"; }; version = "3.0.0"; }; strptime = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ycs0xz58kymf7yp4h56f0nid2z7g3s18dj7pa3p790pfzzpgvcq"; type = "gem"; }; version = "0.2.5"; }; swagger-blocks = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bycg5si4pr69b0qqiqzhwcich90mvmn0v0gs39slvxg5nv3h28k"; type = "gem"; }; version = "3.0.0"; }; thin = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08g1yq6zzvgndj8fd98ah7pp8g2diw28p8bfjgv7rvjvp8d2am8w"; type = "gem"; }; version = "1.8.2"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nmymd86a0vb39pzj2cwv57avdrl6pl3lf5bsz58q594kqxjkw7f"; type = "gem"; }; version = "1.3.2"; }; tilt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kds7wkxmb038cwp6ravnwn8k65ixc68wpm8j5jx5bhx8ndg4x6z"; type = "gem"; }; version = "2.4.0"; }; timeout = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16mvvsmx90023wrhf8dxc1lpqh0m8alk65shb7xcya6a9gflw7vg"; type = "gem"; }; version = "0.4.1"; }; ttfunk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ji0kn8jkf1rpskv3ijzxvqwixg4p6sk8kg0vmwyjinci7jcgjx7"; type = "gem"; }; version = "1.8.0"; }; tzinfo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; tzinfo-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1cw6xv9a525mcs7202bq9768aic1dwx353prm1bss4fp2nq24a3j"; type = "gem"; }; version = "1.2024.2"; }; unix-crypt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11p5ij6iasr46fbzz0z3jibaiwf242bq8xwav33rljwcwh85sy5y"; type = "gem"; }; version = "1.3.1"; }; warden = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1l7gl7vms023w4clg02pm4ky9j12la2vzsixi2xrv9imbn44ys26"; type = "gem"; }; version = "1.2.9"; }; webrick = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "089gy5494j560b242vi173wnbj2913hwlwnjkpzld58r96ilc5s3"; type = "gem"; }; version = "1.8.2"; }; websocket-driver = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nyh873w4lvahcl8kzbjfca26656d5c6z3md4sbqg5y1gfz0157n"; type = "gem"; }; version = "0.7.6"; }; websocket-extensions = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hc2g9qps8lmhibl5baa91b4qx8wqw872rgwagml78ydj8qacsqw"; type = "gem"; }; version = "0.1.5"; }; win32api = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1liryy0pz0gpw5sadbb9xwaflay272b8bwv4pclh6wkhldnh7wg7"; type = "gem"; }; version = "0.1.0"; }; windows_error = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1825v7hvcl0xss6scyfv76i0cs0kvj72wy20kn7xqylw9avjga2r"; type = "gem"; }; version = "0.1.5"; }; winrm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01jxpshw5kx5ha21ymaaj14vibv5bvm0dd80ccc6xl3jaxy7cszg"; type = "gem"; }; version = "2.3.9"; }; xdr = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vsimn1vha6qjh1zbkvma5biwlh3hzc6s24ksw7vsxg0z27m8bmz"; type = "gem"; }; version = "3.0.3"; }; xmlrpc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fwfnccagsjrbvrav5nbk3zracj9zncr7i375nn20jd4cfy4cggc"; type = "gem"; }; version = "0.3.3"; }; zeitwerk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10cpfdswql21vildiin0q7drg5zfzf2sahnk9hv3nyzzjqwj2bdx"; type = "gem"; }; diff --git a/pkgs/tools/security/mkpasswd/default.nix b/pkgs/tools/security/mkpasswd/default.nix index edbdfdc711c68b..1a59c38496f883 100644 --- a/pkgs/tools/security/mkpasswd/default.nix +++ b/pkgs/tools/security/mkpasswd/default.nix @@ -1,10 +1,20 @@ -{ lib, stdenv, whois, libxcrypt, perl, pkg-config }: +{ + lib, + stdenv, + whois, + libxcrypt, + perl, + pkg-config, +}: stdenv.mkDerivation { pname = "mkpasswd"; inherit (whois) version src patches; - nativeBuildInputs = [ perl pkg-config ]; + nativeBuildInputs = [ + perl + pkg-config + ]; buildInputs = [ libxcrypt ]; inherit (whois) preConfigure; diff --git a/pkgs/tools/security/netexec/default.nix b/pkgs/tools/security/netexec/default.nix index 06163309b11b1d..81659210895c9b 100644 --- a/pkgs/tools/security/netexec/default.nix +++ b/pkgs/tools/security/netexec/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, python3 +{ + lib, + stdenv, + fetchFromGitHub, + python3, }: let python = python3.override { diff --git a/pkgs/tools/security/nitrokey-app/default.nix b/pkgs/tools/security/nitrokey-app/default.nix index 018a186563816e..5739ffd33ab077 100644 --- a/pkgs/tools/security/nitrokey-app/default.nix +++ b/pkgs/tools/security/nitrokey-app/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, cmake -, fetchFromGitHub -, pkg-config -, wrapQtAppsHook -, libnitrokey -, cppcodec -, qttools +{ + lib, + stdenv, + cmake, + fetchFromGitHub, + pkg-config, + wrapQtAppsHook, + libnitrokey, + cppcodec, + qttools, }: stdenv.mkDerivation rec { @@ -48,6 +49,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/Nitrokey/nitrokey-app"; changelog = "https://github.com/Nitrokey/nitrokey-app/releases/tag/v${version}"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ kaiha panicgh ]; + maintainers = with maintainers; [ + kaiha + panicgh + ]; }; } diff --git a/pkgs/tools/security/nsjail/default.nix b/pkgs/tools/security/nsjail/default.nix index dbf62872d21fac..2e6665c7204ad7 100644 --- a/pkgs/tools/security/nsjail/default.nix +++ b/pkgs/tools/security/nsjail/default.nix @@ -1,5 +1,18 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, bison, flex, libtool, pkg-config, which -, libnl, protobuf, protobufc, shadow, installShellFiles +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + bison, + flex, + libtool, + pkg-config, + which, + libnl, + protobuf, + protobufc, + shadow, + installShellFiles, }: stdenv.mkDerivation rec { @@ -7,15 +20,27 @@ stdenv.mkDerivation rec { version = "3.4"; src = fetchFromGitHub { - owner = "google"; - repo = "nsjail"; - rev = version; + owner = "google"; + repo = "nsjail"; + rev = version; fetchSubmodules = true; - hash = "sha256-/K+qJV5Dq+my45Cpw6czdsWLtO9lnJwZTsOIRt4Iijk="; + hash = "sha256-/K+qJV5Dq+my45Cpw6czdsWLtO9lnJwZTsOIRt4Iijk="; }; - nativeBuildInputs = [ autoconf bison flex installShellFiles libtool pkg-config which ]; - buildInputs = [ libnl protobuf protobufc ]; + nativeBuildInputs = [ + autoconf + bison + flex + installShellFiles + libtool + pkg-config + which + ]; + buildInputs = [ + libnl + protobuf + protobufc + ]; enableParallelBuilding = true; env.NIX_CFLAGS_COMPILE = toString [ "-Wno-error" ]; @@ -33,11 +58,15 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Light-weight process isolation tool, making use of Linux namespaces and seccomp-bpf syscall filters"; - homepage = "https://nsjail.dev/"; - changelog = "https://github.com/google/nsjail/releases/tag/${version}"; - license = licenses.asl20; - maintainers = with maintainers; [ arturcygan bosu c0bw3b ]; - platforms = platforms.linux; + homepage = "https://nsjail.dev/"; + changelog = "https://github.com/google/nsjail/releases/tag/${version}"; + license = licenses.asl20; + maintainers = with maintainers; [ + arturcygan + bosu + c0bw3b + ]; + platforms = platforms.linux; mainProgram = "nsjail"; }; } diff --git a/pkgs/tools/security/onlykey/default.nix b/pkgs/tools/security/onlykey/default.nix index a9337be7ac0502..1c15e0186ba1b2 100644 --- a/pkgs/tools/security/onlykey/default.nix +++ b/pkgs/tools/security/onlykey/default.nix @@ -1,11 +1,12 @@ -{ lib -, node_webkit -, pkgs -, copyDesktopItems -, makeDesktopItem -, stdenv -, writeShellScript -, wrapGAppsHook3 +{ + lib, + node_webkit, + pkgs, + copyDesktopItems, + makeDesktopItem, + stdenv, + writeShellScript, + wrapGAppsHook3, }: let @@ -53,7 +54,10 @@ stdenv.mkDerivation { pname = "${onlykey.packageName}"; inherit (onlykey) version; dontUnpack = true; - nativeBuildInputs = [ wrapGAppsHook3 copyDesktopItems ]; + nativeBuildInputs = [ + wrapGAppsHook3 + copyDesktopItems + ]; desktopItems = [ (makeDesktopItem { name = onlykey.packageName; diff --git a/pkgs/tools/security/onlykey/node-packages.nix b/pkgs/tools/security/onlykey/node-packages.nix index 001ff6916708b9..ffc87f88fc94b2 100644 --- a/pkgs/tools/security/onlykey/node-packages.nix +++ b/pkgs/tools/security/onlykey/node-packages.nix @@ -1,6 +1,14 @@ # This file has been generated by node2nix 1.11.1. Do not edit! -{nodeEnv, fetchurl, fetchgit, nix-gitignore, stdenv, lib, globalBuildInputs ? []}: +{ + nodeEnv, + fetchurl, + fetchgit, + nix-gitignore, + stdenv, + lib, + globalBuildInputs ? [ ], +}: let sources = { @@ -5745,18 +5753,24 @@ in sources."@eslint-community/regexpp-4.5.1" sources."@eslint/eslintrc-2.0.3" sources."@eslint/js-8.42.0" - (sources."@gulp-sourcemaps/identity-map-2.0.1" // { - dependencies = [ - sources."acorn-6.4.2" - sources."source-map-0.6.1" - sources."through2-3.0.2" - ]; - }) - (sources."@gulp-sourcemaps/map-sources-1.0.0" // { - dependencies = [ - sources."normalize-path-2.1.1" - ]; - }) + ( + sources."@gulp-sourcemaps/identity-map-2.0.1" + // { + dependencies = [ + sources."acorn-6.4.2" + sources."source-map-0.6.1" + sources."through2-3.0.2" + ]; + } + ) + ( + sources."@gulp-sourcemaps/map-sources-1.0.0" + // { + dependencies = [ + sources."normalize-path-2.1.1" + ]; + } + ) sources."@humanwhocodes/config-array-0.11.10" sources."@humanwhocodes/module-importer-1.0.1" sources."@humanwhocodes/object-schema-1.2.1" @@ -5772,11 +5786,14 @@ in sources."ansi-regex-2.1.1" sources."ansi-styles-2.2.1" sources."ansi-wrap-0.1.0" - (sources."anymatch-2.0.0" // { - dependencies = [ - sources."normalize-path-2.1.1" - ]; - }) + ( + sources."anymatch-2.0.0" + // { + dependencies = [ + sources."normalize-path-2.1.1" + ]; + } + ) sources."append-buffer-1.0.2" sources."applescript-1.0.0" sources."archy-1.0.0" @@ -5787,22 +5804,31 @@ in sources."arr-map-2.0.2" sources."arr-union-3.1.0" sources."array-each-1.0.1" - (sources."array-initial-1.1.0" // { - dependencies = [ - sources."is-number-4.0.0" - ]; - }) - (sources."array-last-1.3.0" // { - dependencies = [ - sources."is-number-4.0.0" - ]; - }) + ( + sources."array-initial-1.1.0" + // { + dependencies = [ + sources."is-number-4.0.0" + ]; + } + ) + ( + sources."array-last-1.3.0" + // { + dependencies = [ + sources."is-number-4.0.0" + ]; + } + ) sources."array-slice-1.1.0" - (sources."array-sort-1.0.0" // { - dependencies = [ - sources."kind-of-5.1.0" - ]; - }) + ( + sources."array-sort-1.0.0" + // { + dependencies = [ + sources."kind-of-5.1.0" + ]; + } + ) sources."array-unique-0.3.2" sources."asn1-0.2.6" sources."assert-plus-1.0.0" @@ -5818,11 +5844,14 @@ in sources."aws4-1.12.0" sources."bach-1.2.0" sources."balanced-match-1.0.2" - (sources."base-0.11.2" // { - dependencies = [ - sources."define-property-1.0.0" - ]; - }) + ( + sources."base-0.11.2" + // { + dependencies = [ + sources."define-property-1.0.0" + ]; + } + ) sources."base64-js-1.5.1" sources."bcrypt-pbkdf-1.0.2" sources."binary-0.3.0" @@ -5830,11 +5859,14 @@ in sources."bindings-1.5.0" sources."bl-1.2.3" sources."brace-expansion-1.1.11" - (sources."braces-2.3.2" // { - dependencies = [ - sources."extend-shallow-2.0.1" - ]; - }) + ( + sources."braces-2.3.2" + // { + dependencies = [ + sources."extend-shallow-2.0.1" + ]; + } + ) sources."browser-stdout-1.3.1" sources."buffer-5.7.1" sources."buffer-alloc-1.2.0" @@ -5857,32 +5889,47 @@ in sources."chainsaw-0.1.0" sources."chalk-1.1.3" sources."check-error-1.0.2" - (sources."chokidar-2.1.8" // { - dependencies = [ - (sources."glob-parent-3.1.0" // { - dependencies = [ - sources."is-glob-3.1.0" - ]; - }) - ]; - }) - (sources."class-utils-0.3.6" // { - dependencies = [ - sources."define-property-0.2.5" - (sources."is-accessor-descriptor-0.1.6" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) - (sources."is-data-descriptor-0.1.4" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) - sources."is-descriptor-0.1.6" - sources."kind-of-5.1.0" - ]; - }) + ( + sources."chokidar-2.1.8" + // { + dependencies = [ + ( + sources."glob-parent-3.1.0" + // { + dependencies = [ + sources."is-glob-3.1.0" + ]; + } + ) + ]; + } + ) + ( + sources."class-utils-0.3.6" + // { + dependencies = [ + sources."define-property-0.2.5" + ( + sources."is-accessor-descriptor-0.1.6" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) + ( + sources."is-data-descriptor-0.1.4" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) + sources."is-descriptor-0.1.6" + sources."kind-of-5.1.0" + ]; + } + ) sources."cliui-3.2.0" sources."clone-2.1.2" sources."clone-buffer-1.0.0" @@ -5902,58 +5949,79 @@ in sources."config-chain-1.1.13" sources."convert-source-map-1.9.0" sources."copy-descriptor-0.1.1" - (sources."copy-props-2.0.5" // { - dependencies = [ - sources."is-plain-object-5.0.0" - ]; - }) + ( + sources."copy-props-2.0.5" + // { + dependencies = [ + sources."is-plain-object-5.0.0" + ]; + } + ) sources."core-util-is-1.0.3" sources."create-error-class-3.0.2" sources."cross-spawn-7.0.3" - (sources."css-3.0.0" // { - dependencies = [ - sources."source-map-0.6.1" - sources."source-map-resolve-0.6.0" - ]; - }) + ( + sources."css-3.0.0" + // { + dependencies = [ + sources."source-map-0.6.1" + sources."source-map-resolve-0.6.0" + ]; + } + ) sources."d-1.0.1" sources."dashdash-1.14.1" sources."debounce-1.2.1" sources."debug-4.3.4" - (sources."debug-fabulous-1.1.0" // { - dependencies = [ - sources."debug-3.2.7" - ]; - }) + ( + sources."debug-fabulous-1.1.0" + // { + dependencies = [ + sources."debug-3.2.7" + ]; + } + ) sources."decamelize-1.2.0" sources."decode-uri-component-0.2.2" sources."decompress-4.2.1" sources."decompress-tar-4.1.1" - (sources."decompress-tarbz2-4.1.1" // { - dependencies = [ - sources."file-type-6.2.0" - ]; - }) + ( + sources."decompress-tarbz2-4.1.1" + // { + dependencies = [ + sources."file-type-6.2.0" + ]; + } + ) sources."decompress-targz-4.1.1" - (sources."decompress-unzip-4.0.1" // { - dependencies = [ - sources."file-type-3.9.0" - ]; - }) - (sources."decompress-zip-0.3.3" // { - dependencies = [ - sources."isarray-0.0.1" - sources."readable-stream-1.1.14" - sources."string_decoder-0.10.31" - ]; - }) + ( + sources."decompress-unzip-4.0.1" + // { + dependencies = [ + sources."file-type-3.9.0" + ]; + } + ) + ( + sources."decompress-zip-0.3.3" + // { + dependencies = [ + sources."isarray-0.0.1" + sources."readable-stream-1.1.14" + sources."string_decoder-0.10.31" + ]; + } + ) sources."deep-eql-4.1.3" sources."deep-is-0.1.4" - (sources."default-compare-1.0.0" // { - dependencies = [ - sources."kind-of-5.1.0" - ]; - }) + ( + sources."default-compare-1.0.0" + // { + dependencies = [ + sources."kind-of-5.1.0" + ]; + } + ) sources."default-resolution-2.0.0" sources."define-properties-1.2.0" sources."define-property-2.0.2" @@ -5962,11 +6030,14 @@ in sources."detect-newline-2.1.0" sources."diff-5.0.0" sources."doctrine-3.0.0" - (sources."download-5.0.3" // { - dependencies = [ - sources."get-stream-3.0.0" - ]; - }) + ( + sources."download-5.0.3" + // { + dependencies = [ + sources."get-stream-3.0.0" + ]; + } + ) sources."duplexer3-0.1.5" sources."duplexify-3.7.1" sources."each-props-1.3.2" @@ -5980,16 +6051,19 @@ in sources."es6-weak-map-2.0.3" sources."escalade-3.1.1" sources."escape-string-regexp-1.0.5" - (sources."eslint-8.42.0" // { - dependencies = [ - sources."ansi-regex-5.0.1" - sources."ansi-styles-4.3.0" - sources."chalk-4.1.2" - sources."escape-string-regexp-4.0.0" - sources."strip-ansi-6.0.1" - sources."supports-color-7.2.0" - ]; - }) + ( + sources."eslint-8.42.0" + // { + dependencies = [ + sources."ansi-regex-5.0.1" + sources."ansi-styles-4.3.0" + sources."chalk-4.1.2" + sources."escape-string-regexp-4.0.0" + sources."strip-ansi-6.0.1" + sources."supports-color-7.2.0" + ]; + } + ) sources."eslint-scope-7.2.0" sources."eslint-visitor-keys-3.4.1" sources."espree-9.5.2" @@ -5998,52 +6072,73 @@ in sources."estraverse-5.3.0" sources."esutils-2.0.3" sources."event-emitter-0.3.5" - (sources."expand-brackets-2.1.4" // { - dependencies = [ - sources."debug-2.6.9" - sources."define-property-0.2.5" - sources."extend-shallow-2.0.1" - (sources."is-accessor-descriptor-0.1.6" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) - (sources."is-data-descriptor-0.1.4" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) - sources."is-descriptor-0.1.6" - sources."kind-of-5.1.0" - sources."ms-2.0.0" - ]; - }) - (sources."expand-range-1.8.2" // { - dependencies = [ - sources."fill-range-2.2.4" - sources."is-number-2.1.0" - sources."isobject-2.1.0" - sources."kind-of-3.2.2" - ]; - }) + ( + sources."expand-brackets-2.1.4" + // { + dependencies = [ + sources."debug-2.6.9" + sources."define-property-0.2.5" + sources."extend-shallow-2.0.1" + ( + sources."is-accessor-descriptor-0.1.6" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) + ( + sources."is-data-descriptor-0.1.4" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) + sources."is-descriptor-0.1.6" + sources."kind-of-5.1.0" + sources."ms-2.0.0" + ]; + } + ) + ( + sources."expand-range-1.8.2" + // { + dependencies = [ + sources."fill-range-2.2.4" + sources."is-number-2.1.0" + sources."isobject-2.1.0" + sources."kind-of-3.2.2" + ]; + } + ) sources."expand-tilde-2.0.2" - (sources."ext-1.7.0" // { - dependencies = [ - sources."type-2.7.2" - ]; - }) + ( + sources."ext-1.7.0" + // { + dependencies = [ + sources."type-2.7.2" + ]; + } + ) sources."extend-3.0.2" - (sources."extend-shallow-3.0.2" // { - dependencies = [ - sources."is-extendable-1.0.1" - ]; - }) - (sources."extglob-2.0.4" // { - dependencies = [ - sources."define-property-1.0.0" - sources."extend-shallow-2.0.1" - ]; - }) + ( + sources."extend-shallow-3.0.2" + // { + dependencies = [ + sources."is-extendable-1.0.1" + ]; + } + ) + ( + sources."extglob-2.0.4" + // { + dependencies = [ + sources."define-property-1.0.0" + sources."extend-shallow-2.0.1" + ]; + } + ) sources."extsprintf-1.3.0" sources."fancy-log-1.3.3" sources."fast-deep-equal-3.1.3" @@ -6058,21 +6153,27 @@ in sources."filename-regex-2.0.1" sources."filename-reserved-regex-2.0.0" sources."filenamify-2.1.0" - (sources."fill-range-4.0.0" // { - dependencies = [ - sources."extend-shallow-2.0.1" - ]; - }) + ( + sources."fill-range-4.0.0" + // { + dependencies = [ + sources."extend-shallow-2.0.1" + ]; + } + ) sources."find-up-5.0.0" sources."findup-sync-3.0.0" sources."fined-1.2.0" sources."flagged-respawn-1.0.1" sources."flat-5.0.2" - (sources."flat-cache-3.0.4" // { - dependencies = [ - sources."rimraf-3.0.2" - ]; - }) + ( + sources."flat-cache-3.0.4" + // { + dependencies = [ + sources."rimraf-3.0.2" + ]; + } + ) sources."flatted-3.2.7" sources."flush-write-stream-1.1.1" sources."for-in-1.0.2" @@ -6082,12 +6183,15 @@ in sources."fragment-cache-0.2.1" sources."fs-constants-1.0.0" sources."fs-extra-7.0.1" - (sources."fs-jetpack-5.1.0" // { - dependencies = [ - sources."brace-expansion-2.0.1" - sources."minimatch-5.1.6" - ]; - }) + ( + sources."fs-jetpack-5.1.0" + // { + dependencies = [ + sources."brace-expansion-2.0.1" + sources."minimatch-5.1.6" + ]; + } + ) sources."fs-mkdirp-stream-1.0.0" sources."fs.realpath-1.0.0" sources."fsevents-1.2.13" @@ -6100,49 +6204,67 @@ in sources."get-value-2.0.6" sources."getpass-0.1.7" sources."glob-7.2.3" - (sources."glob-base-0.3.0" // { - dependencies = [ - sources."glob-parent-2.0.0" - sources."is-extglob-1.0.0" - sources."is-glob-2.0.1" - ]; - }) + ( + sources."glob-base-0.3.0" + // { + dependencies = [ + sources."glob-parent-2.0.0" + sources."is-extglob-1.0.0" + sources."is-glob-2.0.1" + ]; + } + ) sources."glob-parent-6.0.2" - (sources."glob-stream-6.1.0" // { - dependencies = [ - sources."glob-parent-3.1.0" - sources."is-glob-3.1.0" - ]; - }) + ( + sources."glob-stream-6.1.0" + // { + dependencies = [ + sources."glob-parent-3.1.0" + sources."is-glob-3.1.0" + ]; + } + ) sources."glob-watcher-5.0.5" sources."global-modules-1.0.0" - (sources."global-prefix-1.0.2" // { - dependencies = [ - sources."which-1.3.1" - ]; - }) + ( + sources."global-prefix-1.0.2" + // { + dependencies = [ + sources."which-1.3.1" + ]; + } + ) sources."globals-13.20.0" sources."glogg-1.0.2" - (sources."got-6.7.1" // { - dependencies = [ - sources."get-stream-3.0.0" - ]; - }) + ( + sources."got-6.7.1" + // { + dependencies = [ + sources."get-stream-3.0.0" + ]; + } + ) sources."graceful-fs-4.2.11" sources."graphemer-1.4.0" sources."gulp-4.0.2" - (sources."gulp-cli-2.3.0" // { - dependencies = [ - sources."camelcase-3.0.0" - sources."yargs-7.1.2" - ]; - }) - (sources."gulp-sourcemaps-3.0.0" // { - dependencies = [ - sources."acorn-6.4.2" - sources."source-map-0.6.1" - ]; - }) + ( + sources."gulp-cli-2.3.0" + // { + dependencies = [ + sources."camelcase-3.0.0" + sources."yargs-7.1.2" + ]; + } + ) + ( + sources."gulp-sourcemaps-3.0.0" + // { + dependencies = [ + sources."acorn-6.4.2" + sources."source-map-0.6.1" + ]; + } + ) sources."gulplog-1.0.0" sources."har-schema-2.0.0" sources."har-validator-5.1.5" @@ -6155,11 +6277,14 @@ in sources."has-symbols-1.0.3" sources."has-to-string-tag-x-1.4.1" sources."has-value-1.0.0" - (sources."has-values-1.0.0" // { - dependencies = [ - sources."kind-of-4.0.0" - ]; - }) + ( + sources."has-values-1.0.0" + // { + dependencies = [ + sources."kind-of-4.0.0" + ]; + } + ) sources."he-1.2.0" sources."homedir-polyfill-1.0.3" sources."hosted-git-info-2.8.9" @@ -6190,11 +6315,14 @@ in sources."is-glob-4.0.3" sources."is-natural-number-4.0.1" sources."is-negated-glob-1.0.0" - (sources."is-number-3.0.0" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) + ( + sources."is-number-3.0.0" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) sources."is-object-1.0.2" sources."is-path-inside-3.0.3" sources."is-plain-obj-2.1.0" @@ -6240,30 +6368,39 @@ in sources."load-json-file-1.1.0" sources."locate-path-6.0.0" sources."lodash.merge-4.6.2" - (sources."log-symbols-4.1.0" // { - dependencies = [ - sources."ansi-styles-4.3.0" - sources."chalk-4.1.2" - sources."supports-color-7.2.0" - ]; - }) + ( + sources."log-symbols-4.1.0" + // { + dependencies = [ + sources."ansi-styles-4.3.0" + sources."chalk-4.1.2" + sources."supports-color-7.2.0" + ]; + } + ) sources."loupe-2.3.6" sources."lowercase-keys-1.0.1" sources."lru-queue-0.1.0" - (sources."make-dir-1.3.0" // { - dependencies = [ - sources."pify-3.0.0" - ]; - }) + ( + sources."make-dir-1.3.0" + // { + dependencies = [ + sources."pify-3.0.0" + ]; + } + ) sources."make-iterator-1.0.1" sources."map-cache-0.2.2" sources."map-visit-1.0.0" - (sources."matchdep-2.0.0" // { - dependencies = [ - sources."findup-sync-2.0.0" - sources."is-glob-3.1.0" - ]; - }) + ( + sources."matchdep-2.0.0" + // { + dependencies = [ + sources."findup-sync-2.0.0" + sources."is-glob-3.1.0" + ]; + } + ) sources."math-random-1.0.4" sources."memoizee-0.4.15" sources."merge-1.2.1" @@ -6272,50 +6409,59 @@ in sources."mime-types-2.1.35" sources."minimatch-3.1.2" sources."minimist-1.2.8" - (sources."mixin-deep-1.3.2" // { - dependencies = [ - sources."is-extendable-1.0.1" - ]; - }) + ( + sources."mixin-deep-1.3.2" + // { + dependencies = [ + sources."is-extendable-1.0.1" + ]; + } + ) sources."mkdirp-0.5.6" sources."mkpath-0.1.0" - (sources."mocha-10.2.0" // { - dependencies = [ - sources."ansi-colors-4.1.1" - sources."ansi-regex-5.0.1" - sources."ansi-styles-4.3.0" - sources."anymatch-3.1.3" - sources."binary-extensions-2.2.0" - sources."brace-expansion-2.0.1" - sources."braces-3.0.2" - sources."chokidar-3.5.3" - sources."cliui-7.0.4" - sources."escape-string-regexp-4.0.0" - sources."fill-range-7.0.1" - sources."fsevents-2.3.2" - sources."get-caller-file-2.0.5" - (sources."glob-7.2.0" // { - dependencies = [ - sources."minimatch-3.1.2" - ]; - }) - sources."glob-parent-5.1.2" - sources."is-binary-path-2.1.0" - sources."is-fullwidth-code-point-3.0.0" - sources."is-number-7.0.0" - sources."minimatch-5.0.1" - sources."ms-2.1.3" - sources."readdirp-3.6.0" - sources."string-width-4.2.3" - sources."strip-ansi-6.0.1" - sources."supports-color-8.1.1" - sources."to-regex-range-5.0.1" - sources."wrap-ansi-7.0.0" - sources."y18n-5.0.8" - sources."yargs-16.2.0" - sources."yargs-parser-20.2.4" - ]; - }) + ( + sources."mocha-10.2.0" + // { + dependencies = [ + sources."ansi-colors-4.1.1" + sources."ansi-regex-5.0.1" + sources."ansi-styles-4.3.0" + sources."anymatch-3.1.3" + sources."binary-extensions-2.2.0" + sources."brace-expansion-2.0.1" + sources."braces-3.0.2" + sources."chokidar-3.5.3" + sources."cliui-7.0.4" + sources."escape-string-regexp-4.0.0" + sources."fill-range-7.0.1" + sources."fsevents-2.3.2" + sources."get-caller-file-2.0.5" + ( + sources."glob-7.2.0" + // { + dependencies = [ + sources."minimatch-3.1.2" + ]; + } + ) + sources."glob-parent-5.1.2" + sources."is-binary-path-2.1.0" + sources."is-fullwidth-code-point-3.0.0" + sources."is-number-7.0.0" + sources."minimatch-5.0.1" + sources."ms-2.1.3" + sources."readdirp-3.6.0" + sources."string-width-4.2.3" + sources."strip-ansi-6.0.1" + sources."supports-color-8.1.1" + sources."to-regex-range-5.0.1" + sources."wrap-ansi-7.0.0" + sources."y18n-5.0.8" + sources."yargs-16.2.0" + sources."yargs-parser-20.2.4" + ]; + } + ) sources."ms-2.1.2" sources."mute-stdout-1.0.1" sources."nan-2.17.0" @@ -6328,60 +6474,78 @@ in sources."normalize-package-data-2.5.0" sources."normalize-path-3.0.0" sources."now-and-later-2.0.1" - (sources."npm-conf-1.1.3" // { - dependencies = [ - sources."pify-3.0.0" - ]; - }) + ( + sources."npm-conf-1.1.3" + // { + dependencies = [ + sources."pify-3.0.0" + ]; + } + ) sources."number-is-nan-1.0.1" - (sources."nw-0.71.1" // { - dependencies = [ - sources."yargs-3.32.0" - ]; - }) + ( + sources."nw-0.71.1" + // { + dependencies = [ + sources."yargs-3.32.0" + ]; + } + ) sources."nw-autoupdater-1.1.11" - (sources."nw-dev-3.0.1" // { - dependencies = [ - sources."anymatch-1.3.2" - sources."arr-diff-2.0.0" - sources."array-unique-0.2.1" - sources."braces-1.8.5" - sources."chokidar-1.7.0" - sources."expand-brackets-0.1.5" - sources."extglob-0.3.2" - sources."glob-parent-2.0.0" - sources."is-extglob-1.0.0" - sources."is-glob-2.0.1" - sources."kind-of-3.2.2" - sources."micromatch-2.3.11" - sources."normalize-path-2.1.1" - ]; - }) + ( + sources."nw-dev-3.0.1" + // { + dependencies = [ + sources."anymatch-1.3.2" + sources."arr-diff-2.0.0" + sources."array-unique-0.2.1" + sources."braces-1.8.5" + sources."chokidar-1.7.0" + sources."expand-brackets-0.1.5" + sources."extglob-0.3.2" + sources."glob-parent-2.0.0" + sources."is-extglob-1.0.0" + sources."is-glob-2.0.1" + sources."kind-of-3.2.2" + sources."micromatch-2.3.11" + sources."normalize-path-2.1.1" + ]; + } + ) sources."oauth-sign-0.9.0" sources."object-assign-4.1.1" - (sources."object-copy-0.1.0" // { - dependencies = [ - sources."define-property-0.2.5" - sources."is-accessor-descriptor-0.1.6" - sources."is-data-descriptor-0.1.4" - (sources."is-descriptor-0.1.6" // { - dependencies = [ - sources."kind-of-5.1.0" - ]; - }) - sources."kind-of-3.2.2" - ]; - }) + ( + sources."object-copy-0.1.0" + // { + dependencies = [ + sources."define-property-0.2.5" + sources."is-accessor-descriptor-0.1.6" + sources."is-data-descriptor-0.1.4" + ( + sources."is-descriptor-0.1.6" + // { + dependencies = [ + sources."kind-of-5.1.0" + ]; + } + ) + sources."kind-of-3.2.2" + ]; + } + ) sources."object-keys-1.1.1" sources."object-visit-1.0.1" sources."object.assign-4.1.4" sources."object.defaults-1.1.0" sources."object.map-1.0.1" - (sources."object.omit-2.0.1" // { - dependencies = [ - sources."for-own-0.1.5" - ]; - }) + ( + sources."object.omit-2.0.1" + // { + dependencies = [ + sources."for-own-0.1.5" + ]; + } + ) sources."object.pick-1.3.0" sources."object.reduce-1.0.1" sources."once-1.4.0" @@ -6393,12 +6557,15 @@ in sources."pako-1.0.11" sources."parent-module-1.0.1" sources."parse-filepath-1.0.2" - (sources."parse-glob-3.0.4" // { - dependencies = [ - sources."is-extglob-1.0.0" - sources."is-glob-2.0.1" - ]; - }) + ( + sources."parse-glob-3.0.4" + // { + dependencies = [ + sources."is-extglob-1.0.0" + sources."is-glob-2.0.1" + ]; + } + ) sources."parse-json-2.2.0" sources."parse-node-version-1.0.1" sources."parse-passwd-1.0.0" @@ -6420,11 +6587,14 @@ in sources."pinkie-2.0.4" sources."pinkie-promise-2.0.1" sources."posix-character-classes-0.1.1" - (sources."postcss-7.0.39" // { - dependencies = [ - sources."source-map-0.6.1" - ]; - }) + ( + sources."postcss-7.0.39" + // { + dependencies = [ + sources."source-map-0.6.1" + ]; + } + ) sources."prelude-ls-1.2.1" sources."prepend-http-1.0.4" sources."preserve-0.2.0" @@ -6439,24 +6609,33 @@ in sources."q-1.5.1" sources."qs-6.5.3" sources."queue-microtask-1.2.3" - (sources."randomatic-3.1.1" // { - dependencies = [ - sources."is-number-4.0.0" - ]; - }) + ( + sources."randomatic-3.1.1" + // { + dependencies = [ + sources."is-number-4.0.0" + ]; + } + ) sources."randombytes-2.1.0" sources."read-pkg-1.1.0" - (sources."read-pkg-up-1.0.1" // { - dependencies = [ - sources."find-up-1.1.2" - sources."path-exists-2.1.0" - ]; - }) - (sources."readable-stream-2.3.8" // { - dependencies = [ - sources."safe-buffer-5.1.2" - ]; - }) + ( + sources."read-pkg-up-1.0.1" + // { + dependencies = [ + sources."find-up-1.1.2" + sources."path-exists-2.1.0" + ]; + } + ) + ( + sources."readable-stream-2.3.8" + // { + dependencies = [ + sources."safe-buffer-5.1.2" + ]; + } + ) sources."readdirp-2.2.1" sources."rechoir-0.6.2" sources."regex-cache-0.4.4" @@ -6489,44 +6668,62 @@ in sources."semver-greatest-satisfied-range-1.1.0" sources."serialize-javascript-6.0.0" sources."set-blocking-2.0.0" - (sources."set-value-2.0.1" // { - dependencies = [ - sources."extend-shallow-2.0.1" - ]; - }) + ( + sources."set-value-2.0.1" + // { + dependencies = [ + sources."extend-shallow-2.0.1" + ]; + } + ) sources."setimmediate-1.0.5" sources."shebang-command-2.0.0" sources."shebang-regex-3.0.0" - (sources."snapdragon-0.8.2" // { - dependencies = [ - sources."debug-2.6.9" - sources."define-property-0.2.5" - sources."extend-shallow-2.0.1" - (sources."is-accessor-descriptor-0.1.6" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) - (sources."is-data-descriptor-0.1.4" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) - sources."is-descriptor-0.1.6" - sources."kind-of-5.1.0" - sources."ms-2.0.0" - ]; - }) - (sources."snapdragon-node-2.1.1" // { - dependencies = [ - sources."define-property-1.0.0" - ]; - }) - (sources."snapdragon-util-3.0.1" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) + ( + sources."snapdragon-0.8.2" + // { + dependencies = [ + sources."debug-2.6.9" + sources."define-property-0.2.5" + sources."extend-shallow-2.0.1" + ( + sources."is-accessor-descriptor-0.1.6" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) + ( + sources."is-data-descriptor-0.1.4" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) + sources."is-descriptor-0.1.6" + sources."kind-of-5.1.0" + sources."ms-2.0.0" + ]; + } + ) + ( + sources."snapdragon-node-2.1.1" + // { + dependencies = [ + sources."define-property-1.0.0" + ]; + } + ) + ( + sources."snapdragon-util-3.0.1" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) sources."source-map-0.5.7" sources."source-map-resolve-0.5.3" sources."source-map-url-0.4.1" @@ -6538,31 +6735,43 @@ in sources."split-string-3.1.0" sources."sshpk-1.17.0" sources."stack-trace-0.0.10" - (sources."static-extend-0.1.2" // { - dependencies = [ - sources."define-property-0.2.5" - (sources."is-accessor-descriptor-0.1.6" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) - (sources."is-data-descriptor-0.1.4" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) - sources."is-descriptor-0.1.6" - sources."kind-of-5.1.0" - ]; - }) + ( + sources."static-extend-0.1.2" + // { + dependencies = [ + sources."define-property-0.2.5" + ( + sources."is-accessor-descriptor-0.1.6" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) + ( + sources."is-data-descriptor-0.1.4" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) + sources."is-descriptor-0.1.6" + sources."kind-of-5.1.0" + ]; + } + ) sources."stream-exhaust-1.0.2" sources."stream-shift-1.0.1" sources."string-width-1.0.2" - (sources."string_decoder-1.1.1" // { - dependencies = [ - sources."safe-buffer-5.1.2" - ]; - }) + ( + sources."string_decoder-1.1.1" + // { + dependencies = [ + sources."safe-buffer-5.1.2" + ]; + } + ) sources."strip-ansi-3.0.1" sources."strip-bom-2.0.0" sources."strip-bom-string-1.0.0" @@ -6580,26 +6789,35 @@ in sources."time-stamp-1.1.0" sources."timed-out-4.0.1" sources."timers-ext-0.1.7" - (sources."tmp-0.2.1" // { - dependencies = [ - sources."rimraf-3.0.2" - ]; - }) + ( + sources."tmp-0.2.1" + // { + dependencies = [ + sources."rimraf-3.0.2" + ]; + } + ) sources."to-absolute-glob-2.0.2" sources."to-buffer-1.1.1" - (sources."to-object-path-0.3.0" // { - dependencies = [ - sources."kind-of-3.2.2" - ]; - }) + ( + sources."to-object-path-0.3.0" + // { + dependencies = [ + sources."kind-of-3.2.2" + ]; + } + ) sources."to-regex-3.0.2" sources."to-regex-range-2.1.1" sources."to-through-2.0.0" - (sources."touch-0.0.3" // { - dependencies = [ - sources."nopt-1.0.10" - ]; - }) + ( + sources."touch-0.0.3" + // { + dependencies = [ + sources."nopt-1.0.10" + ]; + } + ) sources."tough-cookie-2.5.0" sources."traverse-0.3.9" sources."tree-kill-1.2.2" @@ -6613,25 +6831,34 @@ in sources."typedarray-0.0.6" sources."unbzip2-stream-1.4.3" sources."unc-path-regex-0.1.2" - (sources."undertaker-1.3.0" // { - dependencies = [ - sources."fast-levenshtein-1.1.4" - ]; - }) + ( + sources."undertaker-1.3.0" + // { + dependencies = [ + sources."fast-levenshtein-1.1.4" + ]; + } + ) sources."undertaker-registry-1.0.1" sources."union-value-1.0.1" sources."unique-stream-2.3.1" sources."universalify-0.1.2" - (sources."unset-value-1.0.0" // { - dependencies = [ - (sources."has-value-0.3.1" // { - dependencies = [ - sources."isobject-2.1.0" - ]; - }) - sources."has-values-0.1.4" - ]; - }) + ( + sources."unset-value-1.0.0" + // { + dependencies = [ + ( + sources."has-value-0.3.1" + // { + dependencies = [ + sources."isobject-2.1.0" + ]; + } + ) + sources."has-values-0.1.4" + ]; + } + ) sources."untildify-3.0.3" sources."unzip-response-2.0.1" sources."upath-1.2.0" @@ -6646,18 +6873,24 @@ in sources."v8flags-3.2.0" sources."validate-npm-package-license-3.0.4" sources."value-or-function-3.0.0" - (sources."verror-1.10.0" // { - dependencies = [ - sources."core-util-is-1.0.2" - ]; - }) + ( + sources."verror-1.10.0" + // { + dependencies = [ + sources."core-util-is-1.0.2" + ]; + } + ) sources."vinyl-2.2.1" sources."vinyl-fs-3.0.3" - (sources."vinyl-sourcemap-1.1.0" // { - dependencies = [ - sources."normalize-path-2.1.1" - ]; - }) + ( + sources."vinyl-sourcemap-1.1.0" + // { + dependencies = [ + sources."normalize-path-2.1.1" + ]; + } + ) sources."which-2.0.2" sources."which-module-1.0.0" sources."window-size-0.1.4" @@ -6669,31 +6902,40 @@ in sources."ws-8.13.0" sources."xtend-4.0.2" sources."y18n-3.2.2" - (sources."yargs-17.7.2" // { - dependencies = [ - sources."ansi-regex-5.0.1" - sources."ansi-styles-4.3.0" - sources."cliui-8.0.1" - sources."get-caller-file-2.0.5" - sources."is-fullwidth-code-point-3.0.0" - sources."string-width-4.2.3" - sources."strip-ansi-6.0.1" - sources."wrap-ansi-7.0.0" - sources."y18n-5.0.8" - sources."yargs-parser-21.1.1" - ]; - }) - (sources."yargs-parser-5.0.1" // { - dependencies = [ - sources."camelcase-3.0.0" - ]; - }) - (sources."yargs-unparser-2.0.0" // { - dependencies = [ - sources."camelcase-6.3.0" - sources."decamelize-4.0.0" - ]; - }) + ( + sources."yargs-17.7.2" + // { + dependencies = [ + sources."ansi-regex-5.0.1" + sources."ansi-styles-4.3.0" + sources."cliui-8.0.1" + sources."get-caller-file-2.0.5" + sources."is-fullwidth-code-point-3.0.0" + sources."string-width-4.2.3" + sources."strip-ansi-6.0.1" + sources."wrap-ansi-7.0.0" + sources."y18n-5.0.8" + sources."yargs-parser-21.1.1" + ]; + } + ) + ( + sources."yargs-parser-5.0.1" + // { + dependencies = [ + sources."camelcase-3.0.0" + ]; + } + ) + ( + sources."yargs-unparser-2.0.0" + // { + dependencies = [ + sources."camelcase-6.3.0" + sources."decamelize-4.0.0" + ]; + } + ) sources."yauzl-2.10.0" sources."yocto-queue-0.1.0" ]; diff --git a/pkgs/tools/security/onlykey/onlykey.nix b/pkgs/tools/security/onlykey/onlykey.nix index b10d8718b7be09..05d8f84ddebbb8 100644 --- a/pkgs/tools/security/onlykey/onlykey.nix +++ b/pkgs/tools/security/onlykey/onlykey.nix @@ -1,17 +1,34 @@ # This file has been generated by node2nix 1.11.1. Do not edit! -{pkgs ? import { +{ + pkgs ? import { inherit system; - }, system ? builtins.currentSystem, nodejs ? pkgs.nodejs_18}: + }, + system ? builtins.currentSystem, + nodejs ? pkgs.nodejs_18, +}: let nodeEnv = import ../../../development/node-packages/node-env.nix { - inherit (pkgs) stdenv lib python2 runCommand writeTextFile writeShellScript; + inherit (pkgs) + stdenv + lib + python2 + runCommand + writeTextFile + writeShellScript + ; inherit pkgs nodejs; libtool = if pkgs.stdenv.hostPlatform.isDarwin then pkgs.cctools or pkgs.darwin.cctools else null; }; in import ./node-packages.nix { - inherit (pkgs) fetchurl nix-gitignore stdenv lib fetchgit; + inherit (pkgs) + fetchurl + nix-gitignore + stdenv + lib + fetchgit + ; inherit nodeEnv; } diff --git a/pkgs/tools/security/ossec/agent.nix b/pkgs/tools/security/ossec/agent.nix index c5ba8688123b66..28f29c9c045e0e 100644 --- a/pkgs/tools/security/ossec/agent.nix +++ b/pkgs/tools/security/ossec/agent.nix @@ -1,4 +1,13 @@ -{ lib, stdenv, fetchFromGitHub, which, pcre2, zlib, ncurses, openssl }: +{ + lib, + stdenv, + fetchFromGitHub, + which, + pcre2, + zlib, + ncurses, + openssl, +}: let version = "unstable-2023-08-09"; in @@ -16,7 +25,12 @@ stdenv.mkDerivation { # clear is used during the build process nativeBuildInputs = [ ncurses ]; - buildInputs = [ which pcre2 zlib openssl ]; + buildInputs = [ + which + pcre2 + zlib + openssl + ]; # patch to remove root manipulation, install phase which tries to add users to the system, and init phase which tries to modify the system to launch files patches = [ ./no-root.patch ]; @@ -28,34 +42,34 @@ stdenv.mkDerivation { env.NIX_CFLAGS_COMPILE = "-fcommon"; buildPhase = '' - mkdir $out - export USER_DIR="$out" # just to satisy the script - ./install.sh < xclip != null; assert waylandSupport -> wl-clipboard != null; assert dmenuSupport -> x11Support || waylandSupport; -assert dmenuSupport && x11Support - -> dmenu != null && xdotool != null; -assert dmenuSupport && waylandSupport - -> dmenu-wayland != null && ydotool != null; - +assert dmenuSupport && x11Support -> dmenu != null && xdotool != null; +assert dmenuSupport && waylandSupport -> dmenu-wayland != null && ydotool != null; let passExtensions = import ./extensions { inherit pkgs; }; - env = extensions: + env = + extensions: let - selected = [ pass ] ++ extensions passExtensions - ++ lib.optional tombPluginSupport passExtensions.tomb; - in buildEnv { + selected = + [ pass ] ++ extensions passExtensions ++ lib.optional tombPluginSupport passExtensions.tomb; + in + buildEnv { name = "pass-env"; paths = selected; nativeBuildInputs = [ makeWrapper ]; @@ -59,7 +81,7 @@ stdenv.mkDerivation rec { pname = "password-store"; src = fetchurl { - url = "https://git.zx2c4.com/password-store/snapshot/${pname}-${version}.tar.xz"; + url = "https://git.zx2c4.com/password-store/snapshot/${pname}-${version}.tar.xz"; sha256 = "1h4k6w7g8pr169p5w9n6mkdhxl3pw51zphx7www6pvgjb7vgmafg"; }; @@ -70,70 +92,85 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; - installFlags = [ "PREFIX=$(out)" "WITH_ALLCOMP=yes" ]; + installFlags = [ + "PREFIX=$(out)" + "WITH_ALLCOMP=yes" + ]; postInstall = lib.optionalString dmenuSupport '' cp "contrib/dmenu/passmenu" "$out/bin/" ''; - wrapperPath = lib.makeBinPath ([ - coreutils - findutils - getopt - git - gnugrep - gnupg - gnused - tree - which - openssh - procps - qrencode - ] ++ lib.optional stdenv.hostPlatform.isDarwin openssl + wrapperPath = lib.makeBinPath ( + [ + coreutils + findutils + getopt + git + gnugrep + gnupg + gnused + tree + which + openssh + procps + qrencode + ] + ++ lib.optional stdenv.hostPlatform.isDarwin openssl ++ lib.optional x11Support xclip ++ lib.optional waylandSupport wl-clipboard - ++ lib.optionals (waylandSupport && dmenuSupport) [ ydotool dmenu-wayland ] - ++ lib.optionals (x11Support && dmenuSupport) [ xdotool dmenu ] + ++ lib.optionals (waylandSupport && dmenuSupport) [ + ydotool + dmenu-wayland + ] + ++ lib.optionals (x11Support && dmenuSupport) [ + xdotool + dmenu + ] ); - postFixup = '' - # Fix program name in --help - substituteInPlace $out/bin/pass \ - --replace 'PROGRAM="''${0##*/}"' "PROGRAM=pass" - - # Ensure all dependencies are in PATH - wrapProgram $out/bin/pass \ - --prefix PATH : "${wrapperPath}" - '' + lib.optionalString dmenuSupport '' - # We just wrap passmenu with the same PATH as pass. It doesn't - # need all the tools in there but it doesn't hurt either. - wrapProgram $out/bin/passmenu \ - --prefix PATH : "$out/bin:${wrapperPath}" - ''; + postFixup = + '' + # Fix program name in --help + substituteInPlace $out/bin/pass \ + --replace 'PROGRAM="''${0##*/}"' "PROGRAM=pass" + + # Ensure all dependencies are in PATH + wrapProgram $out/bin/pass \ + --prefix PATH : "${wrapperPath}" + '' + + lib.optionalString dmenuSupport '' + # We just wrap passmenu with the same PATH as pass. It doesn't + # need all the tools in there but it doesn't hurt either. + wrapProgram $out/bin/passmenu \ + --prefix PATH : "$out/bin:${wrapperPath}" + ''; # Turn "check" into "installcheck", since we want to test our pass, # not the one before the fixup. - postPatch = '' - patchShebangs tests - - substituteInPlace src/password-store.sh \ - --replace "@out@" "$out" - - # the turning - sed -i -e 's@^PASS=.*''$@PASS=$out/bin/pass@' \ - -e 's@^GPGS=.*''$@GPG=${gnupg}/bin/gpg2@' \ - -e '/which gpg/ d' \ - tests/setup.sh - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - # 'pass edit' uses hdid, which is not available from the sandbox. - rm -f tests/t0200-edit-tests.sh - rm -f tests/t0010-generate-tests.sh - rm -f tests/t0020-show-tests.sh - rm -f tests/t0050-mv-tests.sh - rm -f tests/t0100-insert-tests.sh - rm -f tests/t0300-reencryption.sh - rm -f tests/t0400-grep.sh - ''; + postPatch = + '' + patchShebangs tests + + substituteInPlace src/password-store.sh \ + --replace "@out@" "$out" + + # the turning + sed -i -e 's@^PASS=.*''$@PASS=$out/bin/pass@' \ + -e 's@^GPGS=.*''$@GPG=${gnupg}/bin/gpg2@' \ + -e '/which gpg/ d' \ + tests/setup.sh + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + # 'pass edit' uses hdid, which is not available from the sandbox. + rm -f tests/t0200-edit-tests.sh + rm -f tests/t0010-generate-tests.sh + rm -f tests/t0020-show-tests.sh + rm -f tests/t0050-mv-tests.sh + rm -f tests/t0100-insert-tests.sh + rm -f tests/t0300-reencryption.sh + rm -f tests/t0400-grep.sh + ''; doCheck = false; @@ -148,11 +185,17 @@ stdenv.mkDerivation rec { meta = with lib; { description = "Stores, retrieves, generates, and synchronizes passwords securely"; - homepage = "https://www.passwordstore.org/"; - license = licenses.gpl2Plus; + homepage = "https://www.passwordstore.org/"; + license = licenses.gpl2Plus; mainProgram = "pass"; - maintainers = with maintainers; [ lovek323 fpletz tadfisher globin ma27 ]; - platforms = platforms.unix; + maintainers = with maintainers; [ + lovek323 + fpletz + tadfisher + globin + ma27 + ]; + platforms = platforms.unix; longDescription = '' pass is a very simple password store that keeps passwords inside gpg2 diff --git a/pkgs/tools/security/pass/extensions/checkup.nix b/pkgs/tools/security/pass/extensions/checkup.nix index d275c19166f41e..633b0be00cc778 100644 --- a/pkgs/tools/security/pass/extensions/checkup.nix +++ b/pkgs/tools/security/pass/extensions/checkup.nix @@ -1,10 +1,19 @@ -{ lib, stdenv, fetchFromGitHub -, curl, findutils, gnugrep, gnused, shellcheck }: +{ + lib, + stdenv, + fetchFromGitHub, + curl, + findutils, + gnugrep, + gnused, + shellcheck, +}: let pname = "pass-checkup"; version = "0.2.2"; -in stdenv.mkDerivation { +in +stdenv.mkDerivation { inherit pname version; src = fetchFromGitHub { diff --git a/pkgs/tools/security/pass/extensions/default.nix b/pkgs/tools/security/pass/extensions/default.nix index dfb5dfa35bd028..63eb93a890fcf1 100644 --- a/pkgs/tools/security/pass/extensions/default.nix +++ b/pkgs/tools/security/pass/extensions/default.nix @@ -5,12 +5,12 @@ let in { - pass-audit = callPackage ./audit {}; - pass-checkup = callPackage ./checkup.nix {}; - pass-import = callPackage ./import.nix {}; - pass-otp = callPackage ./otp.nix {}; - pass-tomb = callPackage ./tomb.nix {}; - pass-update = callPackage ./update.nix {}; - pass-genphrase = callPackage ./genphrase.nix {}; - pass-file = callPackage ./file.nix {}; + pass-audit = callPackage ./audit { }; + pass-checkup = callPackage ./checkup.nix { }; + pass-import = callPackage ./import.nix { }; + pass-otp = callPackage ./otp.nix { }; + pass-tomb = callPackage ./tomb.nix { }; + pass-update = callPackage ./update.nix { }; + pass-genphrase = callPackage ./genphrase.nix { }; + pass-file = callPackage ./file.nix { }; } diff --git a/pkgs/tools/security/pass/extensions/file.nix b/pkgs/tools/security/pass/extensions/file.nix index 962ab2bd2a407f..54c7e0f8e12cf6 100644 --- a/pkgs/tools/security/pass/extensions/file.nix +++ b/pkgs/tools/security/pass/extensions/file.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "pass-file"; diff --git a/pkgs/tools/security/pass/extensions/genphrase.nix b/pkgs/tools/security/pass/extensions/genphrase.nix index c8a1f730e049af..085b77342fbe19 100644 --- a/pkgs/tools/security/pass/extensions/genphrase.nix +++ b/pkgs/tools/security/pass/extensions/genphrase.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, python3 }: +{ + lib, + stdenv, + fetchFromGitHub, + python3, +}: stdenv.mkDerivation rec { pname = "pass-genphrase"; diff --git a/pkgs/tools/security/pass/extensions/import.nix b/pkgs/tools/security/pass/extensions/import.nix index badc58361d5357..684eff5c88f2a7 100644 --- a/pkgs/tools/security/pass/extensions/import.nix +++ b/pkgs/tools/security/pass/extensions/import.nix @@ -1,8 +1,9 @@ -{ lib -, fetchurl -, python3Packages -, gnupg -, pass +{ + lib, + fetchurl, + python3Packages, + gnupg, + pass, }: python3Packages.buildPythonApplication rec { @@ -56,7 +57,11 @@ python3Packages.buildPythonApplication rec { homepage = "https://github.com/roddhjav/pass-import"; changelog = "https://github.com/roddhjav/pass-import/blob/v${version}/CHANGELOG.rst"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ lovek323 fpletz tadfisher ]; + maintainers = with maintainers; [ + lovek323 + fpletz + tadfisher + ]; platforms = platforms.unix; }; } diff --git a/pkgs/tools/security/pass/extensions/otp.nix b/pkgs/tools/security/pass/extensions/otp.nix index 87df97dcde72ac..dbde743461af78 100644 --- a/pkgs/tools/security/pass/extensions/otp.nix +++ b/pkgs/tools/security/pass/extensions/otp.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, oath-toolkit }: +{ + lib, + stdenv, + fetchFromGitHub, + oath-toolkit, +}: stdenv.mkDerivation rec { pname = "pass-otp"; @@ -19,15 +24,20 @@ stdenv.mkDerivation rec { sed -i -e 's|OATH=\$(which oathtool)|OATH=${oath-toolkit}/bin/oathtool|' otp.bash ''; - installFlags = [ "PREFIX=$(out)" - "BASHCOMPDIR=$(out)/share/bash-completion/completions" - ]; + installFlags = [ + "PREFIX=$(out)" + "BASHCOMPDIR=$(out)/share/bash-completion/completions" + ]; meta = with lib; { description = "Pass extension for managing one-time-password (OTP) tokens"; homepage = "https://github.com/tadfisher/pass-otp"; license = licenses.gpl3; - maintainers = with maintainers; [ jwiegley tadfisher toonn ]; + maintainers = with maintainers; [ + jwiegley + tadfisher + toonn + ]; platforms = platforms.unix; }; } diff --git a/pkgs/tools/security/pass/extensions/tomb.nix b/pkgs/tools/security/pass/extensions/tomb.nix index 58630c4ec9f31c..f9ad7fe0f89419 100644 --- a/pkgs/tools/security/pass/extensions/tomb.nix +++ b/pkgs/tools/security/pass/extensions/tomb.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchFromGitHub, tomb }: +{ + lib, + stdenv, + fetchFromGitHub, + tomb, +}: stdenv.mkDerivation rec { pname = "pass-tomb"; @@ -26,7 +31,11 @@ stdenv.mkDerivation rec { description = "Pass extension that keeps the password store encrypted inside a tomb"; homepage = "https://github.com/roddhjav/pass-tomb"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ lovek323 fpletz tadfisher ]; + maintainers = with maintainers; [ + lovek323 + fpletz + tadfisher + ]; platforms = platforms.unix; }; } diff --git a/pkgs/tools/security/pass/extensions/update.nix b/pkgs/tools/security/pass/extensions/update.nix index dfabe7603cce39..6f53159c9b670c 100644 --- a/pkgs/tools/security/pass/extensions/update.nix +++ b/pkgs/tools/security/pass/extensions/update.nix @@ -1,4 +1,8 @@ -{ lib, stdenv, fetchFromGitHub }: +{ + lib, + stdenv, + fetchFromGitHub, +}: stdenv.mkDerivation rec { pname = "pass-update"; @@ -24,7 +28,11 @@ stdenv.mkDerivation rec { description = "Pass extension that provides an easy flow for updating passwords"; homepage = "https://github.com/roddhjav/pass-update"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ lovek323 fpletz tadfisher ]; + maintainers = with maintainers; [ + lovek323 + fpletz + tadfisher + ]; platforms = platforms.unix; }; } diff --git a/pkgs/tools/security/pass/rofi-pass.nix b/pkgs/tools/security/pass/rofi-pass.nix index e204c14a234e5c..d861d7fde1a9db 100644 --- a/pkgs/tools/security/pass/rofi-pass.nix +++ b/pkgs/tools/security/pass/rofi-pass.nix @@ -1,31 +1,35 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, unstableGitUpdater -, coreutils -, util-linux -, gnugrep -, libnotify -, pwgen -, findutils -, gawk -, gnused -# wayland-only deps -, rofi-wayland -, pass-wayland -, wl-clipboard -, wtype -# x11-only deps -, rofi -, pass -, xclip -, xdotool -# backend selector -, backend ? "x11" +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + unstableGitUpdater, + coreutils, + util-linux, + gnugrep, + libnotify, + pwgen, + findutils, + gawk, + gnused, + # wayland-only deps + rofi-wayland, + pass-wayland, + wl-clipboard, + wtype, + # x11-only deps + rofi, + pass, + xclip, + xdotool, + # backend selector + backend ? "x11", }: -assert lib.assertOneOf "backend" backend [ "x11" "wayland" ]; +assert lib.assertOneOf "backend" backend [ + "x11" + "wayland" +]; stdenv.mkDerivation { pname = "rofi-pass"; @@ -50,26 +54,30 @@ stdenv.mkDerivation { cp -a config.example $out/share/doc/rofi-pass/config.example ''; - wrapperPath = lib.makeBinPath ([ - coreutils - findutils - gawk - gnugrep - gnused - libnotify - pwgen - util-linux - ] ++ lib.optionals (backend == "x11") [ - rofi - (pass.withExtensions (ext: [ ext.pass-otp ])) - xclip - xdotool - ] ++ lib.optionals (backend == "wayland") [ - rofi-wayland - (pass-wayland.withExtensions (ext: [ ext.pass-otp ])) - wl-clipboard - wtype - ]); + wrapperPath = lib.makeBinPath ( + [ + coreutils + findutils + gawk + gnugrep + gnused + libnotify + pwgen + util-linux + ] + ++ lib.optionals (backend == "x11") [ + rofi + (pass.withExtensions (ext: [ ext.pass-otp ])) + xclip + xdotool + ] + ++ lib.optionals (backend == "wayland") [ + rofi-wayland + (pass-wayland.withExtensions (ext: [ ext.pass-otp ])) + wl-clipboard + wtype + ] + ); fixupPhase = '' patchShebangs $out/bin @@ -77,7 +85,9 @@ stdenv.mkDerivation { wrapProgram $out/bin/rofi-pass \ --prefix PATH : "$wrapperPath" \ --set-default ROFI_PASS_BACKEND ${if backend == "wayland" then "wtype" else "xdotool"} \ - --set-default ROFI_PASS_CLIPBOARD_BACKEND ${if backend == "wayland" then "wl-clipboard" else "xclip"} + --set-default ROFI_PASS_CLIPBOARD_BACKEND ${ + if backend == "wayland" then "wl-clipboard" else "xclip" + } ''; passthru.updateScript = unstableGitUpdater { }; diff --git a/pkgs/tools/security/pass/wofi-pass.nix b/pkgs/tools/security/pass/wofi-pass.nix index ef48f335b5fdf6..0356cd23d84582 100644 --- a/pkgs/tools/security/pass/wofi-pass.nix +++ b/pkgs/tools/security/pass/wofi-pass.nix @@ -1,17 +1,18 @@ -{ lib -, stdenv -, fetchFromGitHub -, pass-wayland -, coreutils -, gnugrep -, libnotify -, pwgen -, findutils -, makeWrapper -, wl-clipboard -, wtype -, wofi -, extensions ? exts: [] +{ + lib, + stdenv, + fetchFromGitHub, + pass-wayland, + coreutils, + gnugrep, + libnotify, + pwgen, + findutils, + makeWrapper, + wl-clipboard, + wtype, + wofi, + extensions ? exts: [ ], }: let diff --git a/pkgs/tools/security/pass2csv/default.nix b/pkgs/tools/security/pass2csv/default.nix index 5a255d201f0cd4..02d3269035f1e1 100644 --- a/pkgs/tools/security/pass2csv/default.nix +++ b/pkgs/tools/security/pass2csv/default.nix @@ -1,8 +1,9 @@ -{ buildPythonApplication -, fetchPypi -, lib -, python-gnupg -, setuptools +{ + buildPythonApplication, + fetchPypi, + lib, + python-gnupg, + setuptools, }: buildPythonApplication rec { diff --git a/pkgs/tools/security/pcsc-tools/default.nix b/pkgs/tools/security/pcsc-tools/default.nix index 39efa566553dbc..87578be82223f9 100644 --- a/pkgs/tools/security/pcsc-tools/default.nix +++ b/pkgs/tools/security/pcsc-tools/default.nix @@ -1,24 +1,27 @@ -{ stdenv -, lib -, fetchFromGitHub -, autoconf-archive -, autoreconfHook -, gobject-introspection -, makeWrapper -, pkg-config -, wrapGAppsHook3 -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, systemd -, dbusSupport ? stdenv.hostPlatform.isLinux, dbus -, pcsclite -, PCSC -, wget -, coreutils -, perlPackages -, testers -, nix-update-script +{ + stdenv, + lib, + fetchFromGitHub, + autoconf-archive, + autoreconfHook, + gobject-introspection, + makeWrapper, + pkg-config, + wrapGAppsHook3, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + dbusSupport ? stdenv.hostPlatform.isLinux, + dbus, + pcsclite, + PCSC, + wget, + coreutils, + perlPackages, + testers, + nix-update-script, -# gui does not cross compile properly -, withGui ? stdenv.buildPlatform.canExecute stdenv.hostPlatform + # gui does not cross compile properly + withGui ? stdenv.buildPlatform.canExecute stdenv.hostPlatform, }: assert systemdSupport -> dbusSupport; @@ -38,54 +41,83 @@ stdenv.mkDerivation (finalAttrs: { "--datarootdir=${placeholder "out"}/share" ]; - buildInputs = lib.optionals dbusSupport [ - dbus - ] ++ [ - perlPackages.perl pcsclite - ] ++ lib.optional stdenv.hostPlatform.isDarwin PCSC + buildInputs = + lib.optionals dbusSupport [ + dbus + ] + ++ [ + perlPackages.perl + pcsclite + ] + ++ lib.optional stdenv.hostPlatform.isDarwin PCSC ++ lib.optional systemdSupport systemd; - nativeBuildInputs = [ - autoconf-archive - autoreconfHook - makeWrapper - pkg-config - ] ++ lib.optionals withGui [ - gobject-introspection - wrapGAppsHook3 - ]; + nativeBuildInputs = + [ + autoconf-archive + autoreconfHook + makeWrapper + pkg-config + ] + ++ lib.optionals withGui [ + gobject-introspection + wrapGAppsHook3 + ]; preFixup = '' makeWrapperArgs+=("''${gappsWrapperArgs[@]}") ''; - postInstall = '' - wrapProgram $out/bin/scriptor \ - --set PERL5LIB "${with perlPackages; makePerlPath [ ChipcardPCSC libintl-perl ]}" + postInstall = + '' + wrapProgram $out/bin/scriptor \ + --set PERL5LIB "${ + with perlPackages; + makePerlPath [ + ChipcardPCSC + libintl-perl + ] + }" - '' + lib.optionalString withGui '' - wrapProgram $out/bin/gscriptor \ - ''${makeWrapperArgs[@]} \ - --set PERL5LIB "${with perlPackages; makePerlPath [ - ChipcardPCSC - libintl-perl - GlibObjectIntrospection - Glib - Gtk3 - Pango - Cairo - CairoGObject - ]}" - '' + '' + '' + + lib.optionalString withGui '' + wrapProgram $out/bin/gscriptor \ + ''${makeWrapperArgs[@]} \ + --set PERL5LIB "${ + with perlPackages; + makePerlPath [ + ChipcardPCSC + libintl-perl + GlibObjectIntrospection + Glib + Gtk3 + Pango + Cairo + CairoGObject + ] + }" + '' + + '' - wrapProgram $out/bin/ATR_analysis \ - --set PERL5LIB "${with perlPackages; makePerlPath [ ChipcardPCSC libintl-perl ]}" + wrapProgram $out/bin/ATR_analysis \ + --set PERL5LIB "${ + with perlPackages; + makePerlPath [ + ChipcardPCSC + libintl-perl + ] + }" - wrapProgram $out/bin/pcsc_scan \ - --prefix PATH : "$out/bin:${lib.makeBinPath [ coreutils wget ]}" + wrapProgram $out/bin/pcsc_scan \ + --prefix PATH : "$out/bin:${ + lib.makeBinPath [ + coreutils + wget + ] + }" - install -Dm444 -t $out/share/pcsc smartcard_list.txt - ''; + install -Dm444 -t $out/share/pcsc smartcard_list.txt + ''; passthru = { tests.version = testers.testVersion { @@ -101,7 +133,10 @@ stdenv.mkDerivation (finalAttrs: { changelog = "https://github.com/LudovicRousseau/pcsc-tools/releases/tag/${finalAttrs.version}"; license = licenses.gpl2Plus; mainProgram = "pcsc_scan"; - maintainers = with maintainers; [ peterhoeg anthonyroussel ]; + maintainers = with maintainers; [ + peterhoeg + anthonyroussel + ]; platforms = platforms.unix; }; }) diff --git a/pkgs/tools/security/pcsclite/default.nix b/pkgs/tools/security/pcsclite/default.nix index e7524b69c0d3f5..9b01613a808232 100644 --- a/pkgs/tools/security/pcsclite/default.nix +++ b/pkgs/tools/security/pcsclite/default.nix @@ -1,27 +1,28 @@ -{ stdenv -, lib -, fetchFromGitLab -, fetchpatch -, meson -, ninja -, flex -, pkg-config -, perl -, python3 -, dbus -, polkit -, systemdLibs -, udev -, dbusSupport ? stdenv.hostPlatform.isLinux -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemdLibs -, udevSupport ? dbusSupport -, libusb1 -, Foundation -, IOKit -, testers -, nix-update-script -, pname ? "pcsclite" -, polkitSupport ? false +{ + stdenv, + lib, + fetchFromGitLab, + fetchpatch, + meson, + ninja, + flex, + pkg-config, + perl, + python3, + dbus, + polkit, + systemdLibs, + udev, + dbusSupport ? stdenv.hostPlatform.isLinux, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemdLibs, + udevSupport ? dbusSupport, + libusb1, + Foundation, + IOKit, + testers, + nix-update-script, + pname ? "pcsclite", + polkitSupport ? false, }: assert polkitSupport -> dbusSupport; @@ -31,7 +32,13 @@ stdenv.mkDerivation (finalAttrs: { inherit pname; version = "2.3.0"; - outputs = [ "out" "lib" "dev" "doc" "man" ]; + outputs = [ + "out" + "lib" + "dev" + "doc" + "man" + ]; src = fetchFromGitLab { domain = "salsa.debian.org"; @@ -50,35 +57,41 @@ stdenv.mkDerivation (finalAttrs: { }) ]; - mesonFlags = [ - (lib.mesonOption "sysconfdir" "/etc") - # The OS should care on preparing the drivers into this location - (lib.mesonOption "usbdropdir" "/var/lib/pcsc/drivers") - (lib.mesonBool "libsystemd" systemdSupport) - (lib.mesonBool "polkit" polkitSupport) - (lib.mesonOption "ipcdir" "/run/pcscd") - ] ++ lib.optionals systemdSupport [ - (lib.mesonOption "systemdunit" "system") - ] ++ lib.optionals (!udevSupport) [ - (lib.mesonBool "libudev" false) - ]; + mesonFlags = + [ + (lib.mesonOption "sysconfdir" "/etc") + # The OS should care on preparing the drivers into this location + (lib.mesonOption "usbdropdir" "/var/lib/pcsc/drivers") + (lib.mesonBool "libsystemd" systemdSupport) + (lib.mesonBool "polkit" polkitSupport) + (lib.mesonOption "ipcdir" "/run/pcscd") + ] + ++ lib.optionals systemdSupport [ + (lib.mesonOption "systemdunit" "system") + ] + ++ lib.optionals (!udevSupport) [ + (lib.mesonBool "libudev" false) + ]; # disable building pcsc-wirecheck{,-gen} when cross compiling # see also: https://github.com/LudovicRousseau/PCSC/issues/25 - postPatch = '' - substituteInPlace src/libredirect.c src/spy/libpcscspy.c \ - --replace-fail "libpcsclite_real.so.1" "$lib/lib/libpcsclite_real.so.1" - '' + lib.optionalString systemdSupport '' - substituteInPlace meson.build \ - --replace-fail \ - "systemdsystemunitdir = systemd.get_variable(pkgconfig : 'systemd' + unit + 'unitdir')" \ - "systemdsystemunitdir = '${placeholder "out"}/lib/systemd/system'" - '' + lib.optionalString polkitSupport '' - substituteInPlace meson.build \ - --replace-fail \ - "install_dir : polkit_dep.get_variable('policydir')" \ - "install_dir : '${placeholder "out"}/share/polkit-1/actions'" - ''; + postPatch = + '' + substituteInPlace src/libredirect.c src/spy/libpcscspy.c \ + --replace-fail "libpcsclite_real.so.1" "$lib/lib/libpcsclite_real.so.1" + '' + + lib.optionalString systemdSupport '' + substituteInPlace meson.build \ + --replace-fail \ + "systemdsystemunitdir = systemd.get_variable(pkgconfig : 'systemd' + unit + 'unitdir')" \ + "systemdsystemunitdir = '${placeholder "out"}/lib/systemd/system'" + '' + + lib.optionalString polkitSupport '' + substituteInPlace meson.build \ + --replace-fail \ + "install_dir : polkit_dep.get_variable('policydir')" \ + "install_dir : '${placeholder "out"}/share/polkit-1/actions'" + ''; postInstall = '' # pcsc-spy is a debugging utility and it drags python into the closure @@ -93,10 +106,14 @@ stdenv.mkDerivation (finalAttrs: { perl ]; - buildInputs = [ python3 ] + buildInputs = + [ python3 ] ++ lib.optionals systemdSupport [ systemdLibs ] ++ lib.optionals (!systemdSupport && udevSupport) [ udev ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Foundation IOKit ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Foundation + IOKit + ] ++ lib.optionals dbusSupport [ dbus ] ++ lib.optionals polkitSupport [ polkit ] ++ lib.optionals (!udevSupport) [ libusb1 ]; diff --git a/pkgs/tools/security/plasma-pass/default.nix b/pkgs/tools/security/plasma-pass/default.nix index a2b0816dc2386d..5ab24a28b7ce05 100644 --- a/pkgs/tools/security/plasma-pass/default.nix +++ b/pkgs/tools/security/plasma-pass/default.nix @@ -1,10 +1,16 @@ -{ mkDerivation, lib, fetchFromGitLab, cmake, extra-cmake-modules -, ki18n -, kitemmodels -, oath-toolkit -, qgpgme -, plasma-framework -, qt5 }: +{ + mkDerivation, + lib, + fetchFromGitLab, + cmake, + extra-cmake-modules, + ki18n, + kitemmodels, + oath-toolkit, + qgpgme, + plasma-framework, + qt5, +}: mkDerivation rec { pname = "plasma-pass"; @@ -18,7 +24,7 @@ mkDerivation rec { rev = "v${version}"; }; - buildInputs = [ + buildInputs = [ ki18n kitemmodels oath-toolkit @@ -28,7 +34,10 @@ mkDerivation rec { qt5.qtdeclarative ]; - nativeBuildInputs = [ cmake extra-cmake-modules ]; + nativeBuildInputs = [ + cmake + extra-cmake-modules + ]; meta = with lib; { description = "Plasma applet to access passwords from pass, the standard UNIX password manager"; @@ -38,4 +47,3 @@ mkDerivation rec { platforms = platforms.unix; }; } - diff --git a/pkgs/tools/security/proxmark3/default.nix b/pkgs/tools/security/proxmark3/default.nix index fbc0b9f1a2d2a1..025ad50bc1342e 100644 --- a/pkgs/tools/security/proxmark3/default.nix +++ b/pkgs/tools/security/proxmark3/default.nix @@ -1,27 +1,32 @@ -{ lib -, stdenv -, fetchFromGitHub -, pkg-config -, gcc-arm-embedded -, readline -, bzip2 -, openssl -, jansson -, gd -, whereami -, lua -, lz4 -, Foundation -, AppKit -, withGui ? true, wrapQtAppsHook, qtbase -, withPython ? true, python3 -, withBlueshark ? false, bluez5 -, withGeneric ? false -, withSmall ? false -, withoutFunctions ? [] -, hardwarePlatform ? if withGeneric then "PM3GENERIC" else "PM3RDV4" -, hardwarePlatformExtras ? lib.optionalString withBlueshark "BTADDON" -, standalone ? "LF_SAMYRUN" +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + gcc-arm-embedded, + readline, + bzip2, + openssl, + jansson, + gd, + whereami, + lua, + lz4, + Foundation, + AppKit, + withGui ? true, + wrapQtAppsHook, + qtbase, + withPython ? true, + python3, + withBlueshark ? false, + bluez5, + withGeneric ? false, + withSmall ? false, + withoutFunctions ? [ ], + hardwarePlatform ? if withGeneric then "PM3GENERIC" else "PM3RDV4", + hardwarePlatformExtras ? lib.optionalString withBlueshark "BTADDON", + standalone ? "LF_SAMYRUN", }: assert withBlueshark -> stdenv.hostPlatform.isLinux; stdenv.mkDerivation (finalAttrs: { @@ -55,28 +60,35 @@ stdenv.mkDerivation (finalAttrs: { pkg-config gcc-arm-embedded ] ++ lib.optional withGui wrapQtAppsHook; - buildInputs = [ - readline - bzip2 - openssl - jansson - gd - lz4 - whereami - lua - ] ++ lib.optional withGui qtbase + buildInputs = + [ + readline + bzip2 + openssl + jansson + gd + lz4 + whereami + lua + ] + ++ lib.optional withGui qtbase ++ lib.optional withPython python3 ++ lib.optional withBlueshark bluez5 - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Foundation AppKit ]; + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Foundation + AppKit + ]; - makeFlags = [ - "PREFIX=${placeholder "out"}" - "UDEV_PREFIX=${placeholder "out"}/etc/udev/rules.d" - "PLATFORM=${hardwarePlatform}" - "PLATFORM_EXTRAS=${hardwarePlatformExtras}" - "STANDALONE=${standalone}" - "USE_BREW=0" - ] ++ lib.optional withSmall "PLATFORM_SIZE=256" + makeFlags = + [ + "PREFIX=${placeholder "out"}" + "UDEV_PREFIX=${placeholder "out"}/etc/udev/rules.d" + "PLATFORM=${hardwarePlatform}" + "PLATFORM_EXTRAS=${hardwarePlatformExtras}" + "STANDALONE=${standalone}" + "USE_BREW=0" + ] + ++ lib.optional withSmall "PLATFORM_SIZE=256" ++ map (x: "SKIP_${x}=1") withoutFunctions; enableParallelBuilding = true; @@ -84,7 +96,10 @@ stdenv.mkDerivation (finalAttrs: { description = "Client for proxmark3, powerful general purpose RFID tool"; homepage = "https://github.com/RfidResearchGroup/proxmark3"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ nyanotech emilytrau ]; + maintainers = with maintainers; [ + nyanotech + emilytrau + ]; platforms = platforms.unix; mainProgram = "pm3"; }; diff --git a/pkgs/tools/security/qdigidoc/default.nix b/pkgs/tools/security/qdigidoc/default.nix index 33f2c40efccec6..2e8af2ecb3b1c4 100644 --- a/pkgs/tools/security/qdigidoc/default.nix +++ b/pkgs/tools/security/qdigidoc/default.nix @@ -1,19 +1,20 @@ -{ lib -, mkDerivation -, fetchurl -, fetchpatch -, cmake -, flatbuffers -, gettext -, pkg-config -, libdigidocpp -, opensc -, openldap -, openssl -, pcsclite -, qtbase -, qtsvg -, qttools +{ + lib, + mkDerivation, + fetchurl, + fetchpatch, + cmake, + flatbuffers, + gettext, + pkg-config, + libdigidocpp, + opensc, + openldap, + openssl, + pcsclite, + qtbase, + qtsvg, + qttools, }: mkDerivation rec { @@ -21,8 +22,7 @@ mkDerivation rec { version = "4.6.0"; src = fetchurl { - url = - "https://github.com/open-eid/DigiDoc4-Client/releases/download/v${version}/qdigidoc4-${version}.tar.gz"; + url = "https://github.com/open-eid/DigiDoc4-Client/releases/download/v${version}/qdigidoc4-${version}.tar.gz"; hash = "sha256-szFLY9PpZMMYhfV5joueShfu92YDVmcCC3MOWIOAKVg="; }; @@ -38,7 +38,12 @@ mkDerivation rec { ./sandbox.patch ]; - nativeBuildInputs = [ cmake gettext pkg-config qttools ]; + nativeBuildInputs = [ + cmake + gettext + pkg-config + qttools + ]; buildInputs = [ flatbuffers @@ -67,6 +72,9 @@ mkDerivation rec { homepage = "https://www.id.ee/"; license = licenses.lgpl21Plus; platforms = platforms.linux; - maintainers = with maintainers; [ flokli mmahut ]; + maintainers = with maintainers; [ + flokli + mmahut + ]; }; } diff --git a/pkgs/tools/security/rblake2sum/default.nix b/pkgs/tools/security/rblake2sum/default.nix index 92b4f574749a31..805bfbf8ec9d06 100644 --- a/pkgs/tools/security/rblake2sum/default.nix +++ b/pkgs/tools/security/rblake2sum/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + Security, }: rustPlatform.buildRustPackage { pname = "rblake2sum"; diff --git a/pkgs/tools/security/rblake3sum/default.nix b/pkgs/tools/security/rblake3sum/default.nix index af04b2014403d8..84f1c7283238a0 100644 --- a/pkgs/tools/security/rblake3sum/default.nix +++ b/pkgs/tools/security/rblake3sum/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, Security +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + Security, }: rustPlatform.buildRustPackage { pname = "rblake3sum"; diff --git a/pkgs/tools/security/rekor/default.nix b/pkgs/tools/security/rekor/default.nix index 42bf787198dfb3..108195f0ed5502 100644 --- a/pkgs/tools/security/rekor/default.nix +++ b/pkgs/tools/security/rekor/default.nix @@ -1,7 +1,17 @@ -{ lib, buildGoModule, fetchFromGitHub, installShellFiles }: +{ + lib, + buildGoModule, + fetchFromGitHub, + installShellFiles, +}: let - generic = { pname, packageToBuild, description }: + generic = + { + pname, + packageToBuild, + description, + }: buildGoModule rec { inherit pname; version = "1.3.7"; @@ -54,10 +64,15 @@ let homepage = "https://github.com/sigstore/rekor"; changelog = "https://github.com/sigstore/rekor/releases/tag/v${version}"; license = licenses.asl20; - maintainers = with maintainers; [ lesuisse jk developer-guy ]; + maintainers = with maintainers; [ + lesuisse + jk + developer-guy + ]; }; }; -in { +in +{ rekor-cli = generic { pname = "rekor-cli"; packageToBuild = "cmd/rekor-cli"; diff --git a/pkgs/tools/security/ronin/default.nix b/pkgs/tools/security/ronin/default.nix index ab9ec0cda4c984..b5ed993172965c 100644 --- a/pkgs/tools/security/ronin/default.nix +++ b/pkgs/tools/security/ronin/default.nix @@ -1,4 +1,10 @@ -{ lib, bundlerEnv, bundlerUpdateScript, defaultGemConfig, yasm }: +{ + lib, + bundlerEnv, + bundlerUpdateScript, + defaultGemConfig, + yasm, +}: bundlerEnv { name = "ronin"; @@ -24,8 +30,8 @@ bundlerEnv { meta = with lib; { description = "Free and Open Source Ruby toolkit for security research and development"; - homepage = "https://ronin-rb.dev"; - license = licenses.gpl3Plus; + homepage = "https://ronin-rb.dev"; + license = licenses.gpl3Plus; maintainers = with maintainers; [ Ch1keen ]; }; } diff --git a/pkgs/tools/security/ronin/gemset.nix b/pkgs/tools/security/ronin/gemset.nix index fdb3c9225d0ec5..6faaeb3b824900 100644 --- a/pkgs/tools/security/ronin/gemset.nix +++ b/pkgs/tools/security/ronin/gemset.nix @@ -1,961 +1,1097 @@ { activemodel = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01jrk2i6vp8jcll65d03mqmp1ibxa0ip7bdg5157fkm5syblzsqw"; type = "gem"; }; version = "7.1.0"; }; activerecord = { - dependencies = ["activemodel" "activesupport" "timeout"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activemodel" + "activesupport" + "timeout" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1lpcbgqbrb3yfk3i66mnxa5i36r0ig9dwzksjbm15i30rndr27p5"; type = "gem"; }; version = "7.1.0"; }; activesupport = { - dependencies = ["base64" "bigdecimal" "concurrent-ruby" "connection_pool" "drb" "i18n" "minitest" "mutex_m" "tzinfo"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "base64" + "bigdecimal" + "concurrent-ruby" + "connection_pool" + "drb" + "i18n" + "minitest" + "mutex_m" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1xpwx7hw7mgmjk3w3g8bkz5jfapixhgn3ihly0xkpyvgp1shp8h1"; type = "gem"; }; version = "7.1.0"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05r1fwy487klqkya7vzia8hnklcxy4vr92m9dmni3prfwk6zpw33"; type = "gem"; }; version = "2.8.5"; }; async = { - dependencies = ["console" "fiber-annotation" "io-event" "timers"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "console" + "fiber-annotation" + "io-event" + "timers" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "02ng89h9s4wwpncyqbkm9n26swp4q45dkvqsb2fpmkan32zn48ji"; type = "gem"; }; version = "2.6.4"; }; async-io = { - dependencies = ["async"]; - groups = ["default"]; - platforms = []; + dependencies = [ "async" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11lgd7276rgy651zwbzvbsz8q0k09ljgngyhsppy7kvkjzj25n58"; type = "gem"; }; version = "1.36.0"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cydk9p2cv25qysm0sn2pb97fcpz1isa7n3c8xm1gd99li8x6x8c"; type = "gem"; }; version = "0.1.1"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07y615s8yldk3k13lmkhpk1k190lcqvmxmnjwgh4bzjan9xrc36y"; type = "gem"; }; version = "3.1.4"; }; chars = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18lgsszrrh3xnaym2jdz7g5gm7c8hv5faj7zyrm1ws9l107jrhr5"; type = "gem"; }; version = "0.3.2"; }; combinatorics = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1sf0pj29xzriwsqv607iwzs76piac6kygqxpg0i59qwx029100fw"; type = "gem"; }; version = "0.4.4"; }; command_kit = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "179mlrnzj56ghviyvvwk0kdfyvr050yk4jj4nwb78izlbxw1wl1m"; type = "gem"; }; version = "0.4.0"; }; command_mapper = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1v363y9g7zxfx2y7p50hdvxj6c0a8mfh30wac2rm3ibldspcjmn1"; type = "gem"; }; version = "0.3.1"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0krcwb6mn0iklajwngwsg850nk8k9b35dhmc2qkbdqvmifdi2y9q"; type = "gem"; }; version = "1.2.2"; }; connection_pool = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; console = { - dependencies = ["fiber-annotation" "fiber-local"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "fiber-annotation" + "fiber-local" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "150wdj94qg8c95b9v1g7ak5a9g159wxfanclpihrz9p9qbv1ga0w"; type = "gem"; }; version = "1.23.2"; }; date = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03skfikihpx37rc27vr3hwrb057gxnmdzxhmzd4bf4jpkl0r55w1"; type = "gem"; }; version = "3.3.3"; }; domain_name = { - dependencies = ["unf"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unf" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lcqjsmixjp52bnlgzh4lg9ppsk52x9hpwdjd53k8jnbah2602h0"; type = "gem"; }; version = "0.5.20190701"; }; drb = { - dependencies = ["ruby2_keywords"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ruby2_keywords" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h9c2qiam82y3caapa2x157j1lkk9954hrjg3p22hxcsk8fli3vb"; type = "gem"; }; version = "2.1.1"; }; fake_io = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "10559cnd2cqllql8ibd0zx0rvq8xk0qll5sqa4khb5963596ldmn"; type = "gem"; }; version = "0.1.0"; }; fiber-annotation = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00vcmynyvhny8n4p799rrhcx0m033hivy0s1gn30ix8rs7qsvgvs"; type = "gem"; }; version = "0.2.0"; }; fiber-local = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vrxxb09fc7aicb9zb0pmn5akggjy21dmxkdl3w949y4q05rldr9"; type = "gem"; }; version = "1.0.0"; }; hexdump = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1787w456yzmy4c13ray228n89a5wz6p6k3ibssjvy955qlr44b7g"; type = "gem"; }; version = "1.0.0"; }; http-cookie = { - dependencies = ["domain_name"]; - groups = ["default"]; - platforms = []; + dependencies = [ "domain_name" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13rilvlv8kwbzqfb644qp6hrbsj82cbqmnzcvqip1p6vqx36sxbk"; type = "gem"; }; version = "1.0.5"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qaamqsh5f3szhcakkak8ikxlzxqnv49n2p7504hcz2l0f4nj0wx"; type = "gem"; }; version = "1.14.1"; }; io-console = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dikardh14c72gd9ypwh8dim41wvqmzfzf35mincaj5yals9m7ff"; type = "gem"; }; version = "0.6.0"; }; io-event = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1m2x5m2m8fa83p5890byf46qb4s1073vn3z6gan9jmbq2a5w0iy8"; type = "gem"; }; version = "1.3.2"; }; irb = { - dependencies = ["rdoc" "reline"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rdoc" + "reline" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "17p6arsklbzh2hvwwr8i4cfrpa7vhk8q88fhickhwmn7m80lxdw7"; type = "gem"; }; version = "1.8.1"; }; mechanize = { - dependencies = ["addressable" "domain_name" "http-cookie" "mime-types" "net-http-digest_auth" "net-http-persistent" "nokogiri" "rubyntlm" "webrick" "webrobots"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "domain_name" + "http-cookie" + "mime-types" + "net-http-digest_auth" + "net-http-persistent" + "nokogiri" + "rubyntlm" + "webrick" + "webrobots" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08lcl3qwgi8r3q0hm5ysmj7j5xqb289kqrd15w09anirj36jc80z"; type = "gem"; }; version = "2.9.1"; }; mime-types = { - dependencies = ["mime-types-data"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mime-types-data" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0q8d881k1b3rbsfcdi3fx0b5vpdr5wcrhn88r2d9j7zjdkxp5mw5"; type = "gem"; }; version = "3.5.1"; }; mime-types-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0yjv0apysnrhbc70ralinfpcqn9382lxr643swp7a5sdwpa9cyqg"; type = "gem"; }; version = "3.2023.1003"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "02mj8mpd6ck5gpcnsimx5brzggw5h5mmmpq2djdypfq16wcw82qq"; type = "gem"; }; version = "2.8.4"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bkmfi9mb49m0fkdhl2g38i3xxa02d411gg0m8x0gvbwfmmg5ym3"; type = "gem"; }; version = "5.20.0"; }; mustermann = { - dependencies = ["ruby2_keywords"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ruby2_keywords" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rwbq20s2gdh8dljjsgj5s6wqqfmnbclhvv2c2608brv7jm6jdbd"; type = "gem"; }; version = "3.0.0"; }; mutex_m = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1pkxnp7p44kvs460bbbgjarr7xy1j8kjjmhwkg1kypj9wgmwb6qa"; type = "gem"; }; version = "0.1.2"; }; net-ftp = { - dependencies = ["net-protocol" "time"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "net-protocol" + "time" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0bqy9xg5225x102873j1qqq1bvnwfbi8lnf4357mpq6wimnw9pf9"; type = "gem"; }; version = "0.2.0"; }; net-http-digest_auth = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nq859b0gh2vjhvl1qh1zrk09pc7p54r9i6nnn6sb06iv07db2jb"; type = "gem"; }; version = "1.4.1"; }; net-http-persistent = { - dependencies = ["connection_pool"]; - groups = ["default"]; - platforms = []; + dependencies = [ "connection_pool" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0i1as2lgnw7b4jid0gw5glv5hnxz36nmfsbr9rmxbcap72ijgy03"; type = "gem"; }; version = "4.0.2"; }; net-imap = { - dependencies = ["date" "net-protocol"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "date" + "net-protocol" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0d0r31b79appz95dd63wmasly1qjz3hn58ffxw6ix4mqk49jcbq2"; type = "gem"; }; version = "0.4.1"; }; net-pop = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wyz41jd4zpjn0v1xsf9j778qx1vfrl24yc20cpmph8k42c4x2w4"; type = "gem"; }; version = "0.1.2"; }; net-protocol = { - dependencies = ["timeout"]; - groups = ["default"]; - platforms = []; + dependencies = [ "timeout" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0dxckrlw4q1lcn3qg4mimmjazmg9bma5gllv72f8js3p36fb3b91"; type = "gem"; }; version = "0.2.1"; }; net-smtp = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1rx3758w0bmbr21s2nsc6llflsrnp50fwdnly3ixra4v53gbhzid"; type = "gem"; }; version = "0.4.0"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k9w2z0953mnjrsji74cshqqp08q7m1r6zhadw1w0g34xzjh3a74"; type = "gem"; }; version = "1.15.4"; }; nokogiri-diff = { - dependencies = ["nokogiri" "tdiff"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "nokogiri" + "tdiff" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0njr1s42war0bj1axb2psjvk49l74a8wzr799wckqqdcb6n51lc1"; type = "gem"; }; version = "0.2.0"; }; nokogiri-ext = { - dependencies = ["nokogiri"]; - groups = ["default"]; - platforms = []; + dependencies = [ "nokogiri" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0y1yflr1989vfy46lxhvs5njlskwiv08akkjybnh8n0cdqms4lhs"; type = "gem"; }; version = "0.1.0"; }; open_namespace = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11j392gl62ibhkidjrjfnb3sygmqmvsc7zd5bhmnigd65x5gs310"; type = "gem"; }; version = "0.4.1"; }; psych = { - dependencies = ["stringio"]; - groups = ["default"]; - platforms = []; + dependencies = [ "stringio" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1msambb54r3d1sg6smyj4k2pj9h9lz8jq4jamip7ivcyv32a85vz"; type = "gem"; }; version = "5.1.0"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0n9j7mczl15r3kwqrah09cxj8hxdfawiqxa60kga2bmxl9flfz9k"; type = "gem"; }; version = "5.0.3"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "11v3l46mwnlzlc371wr3x6yylpgafgwdf0q7hc7c1lzx6r414r5g"; type = "gem"; }; version = "1.7.1"; }; rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15rdwbyk71c9nxvd527bvb8jxkcys8r3dj3vqra5b3sa63qs30vv"; type = "gem"; }; version = "2.2.8"; }; rack-protection = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xsz78hccgza144n37bfisdkzpr2c8m0xl6rnlzgxdbsm1zrkg7r"; type = "gem"; }; version = "3.1.0"; }; rack-user_agent = { - dependencies = ["rack" "woothee"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rack" + "woothee" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1l1gw8xx1g04kdxc89hsy4aawdz8r2an4b78yzk9cc3y8qmw16v7"; type = "gem"; }; version = "0.5.3"; }; rdoc = { - dependencies = ["psych"]; - groups = ["default"]; - platforms = []; + dependencies = [ "psych" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05r2cxscapr9saqjw8dlp89as7jvc2mlz1h5kssrmkbz105qmfcm"; type = "gem"; }; version = "6.5.0"; }; reline = { - dependencies = ["io-console"]; - groups = ["default"]; - platforms = []; + dependencies = [ "io-console" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0187pj9k7d8kdvzjk6r6mf7z7wy18saxxhn7x7pqc840w6h4s0ja"; type = "gem"; }; version = "0.3.9"; }; ronin = { - dependencies = ["async-io" "open_namespace" "ronin-code-asm" "ronin-code-sql" "ronin-core" "ronin-db" "ronin-exploits" "ronin-fuzzer" "ronin-payloads" "ronin-repos" "ronin-support" "ronin-vulns" "ronin-web" "rouge" "wordlist"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "async-io" + "open_namespace" + "ronin-code-asm" + "ronin-code-sql" + "ronin-core" + "ronin-db" + "ronin-exploits" + "ronin-fuzzer" + "ronin-payloads" + "ronin-repos" + "ronin-support" + "ronin-vulns" + "ronin-web" + "rouge" + "wordlist" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0v1v1xb2brgajhh1w38qs4lhnmgygymh1q0q63xpwq32w7a5k7s3"; type = "gem"; }; version = "2.0.5"; }; ronin-code-asm = { - dependencies = ["ruby-yasm"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ruby-yasm" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0faic3m95nhr7wrh7visdj45qaah7dvnl0afl4a5gmy6ybij16zl"; type = "gem"; }; version = "1.0.0"; }; ronin-code-sql = { - dependencies = ["ronin-support"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ronin-support" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1z6ynbrbzlkab1fbhccghr2xm6dak9xb2djqjlc6nai3fdhid1v8"; type = "gem"; }; version = "2.1.0"; }; ronin-core = { - dependencies = ["command_kit" "irb" "reline"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "command_kit" + "irb" + "reline" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1s2hndkdh4pw6xppq4jqn30fk2b26gk08yym5gavlzkcg5k17vvd"; type = "gem"; }; version = "0.1.2"; }; ronin-db = { - dependencies = ["ronin-core" "ronin-db-activerecord" "ronin-support" "sqlite3"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ronin-core" + "ronin-db-activerecord" + "ronin-support" + "sqlite3" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0fiqdk1rnqk86icx27z531yc1qjs2n41nw9p361980wg0j8b4hsj"; type = "gem"; }; version = "0.1.2"; }; ronin-db-activerecord = { - dependencies = ["activerecord" "uri-query_params"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activerecord" + "uri-query_params" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0igw9syk4psdmijji0cx1dhrv76r1abji8fzdndnrn5h819b2fm3"; type = "gem"; }; version = "0.1.2"; }; ronin-exploits = { - dependencies = ["ronin-code-sql" "ronin-core" "ronin-payloads" "ronin-post_ex" "ronin-repos" "ronin-support" "ronin-vulns" "uri-query_params"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ronin-code-sql" + "ronin-core" + "ronin-payloads" + "ronin-post_ex" + "ronin-repos" + "ronin-support" + "ronin-vulns" + "uri-query_params" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1g2ilmmn6vccjn1i72wyakvjlh0b1qrgnw2nshl9f50j7yj93xpn"; type = "gem"; }; version = "1.0.3"; }; ronin-fuzzer = { - dependencies = ["combinatorics" "ronin-core" "ronin-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "combinatorics" + "ronin-core" + "ronin-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "19sc4kk6lwpq6fd23dmji0vf4mjkf1z5pjq4wp0xs2cby2fzld5p"; type = "gem"; }; version = "0.1.0"; }; ronin-payloads = { - dependencies = ["ronin-code-asm" "ronin-core" "ronin-post_ex" "ronin-repos" "ronin-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ronin-code-asm" + "ronin-core" + "ronin-post_ex" + "ronin-repos" + "ronin-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1gsgbw90xmwwnpc8i873wwgia56hcjkhlyjpxl7s4yvd7ml7pj0f"; type = "gem"; }; version = "0.1.4"; }; ronin-post_ex = { - dependencies = ["fake_io" "hexdump" "ronin-core"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "fake_io" + "hexdump" + "ronin-core" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0dcpnlz8niqjjm5d9z8khg53acl7xn5dgliv70svsncc3h0hx0w7"; type = "gem"; }; version = "0.1.0"; }; ronin-repos = { - dependencies = ["ronin-core"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ronin-core" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0c453qw7xr4vsq2y5dlnihfmzy95q3xjbfl5cm1y0xwzdm7ibbzx"; type = "gem"; }; version = "0.1.1"; }; ronin-support = { - dependencies = ["addressable" "chars" "combinatorics" "hexdump" "uri-query_params"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "addressable" + "chars" + "combinatorics" + "hexdump" + "uri-query_params" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0k2vs6mkcyx0h7k3rjs2bwqimhkfa2m50ll8rgm7zygxz3f6gny3"; type = "gem"; }; version = "1.0.3"; }; ronin-vulns = { - dependencies = ["ronin-core" "ronin-support"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ronin-core" + "ronin-support" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1p00xrj71436g301b0wnq23ps89x4g9mmzvkghw9sqyfazgc829f"; type = "gem"; }; version = "0.1.4"; }; ronin-web = { - dependencies = ["mechanize" "nokogiri" "nokogiri-diff" "nokogiri-ext" "open_namespace" "ronin-core" "ronin-support" "ronin-web-server" "ronin-web-spider" "ronin-web-user_agents"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mechanize" + "nokogiri" + "nokogiri-diff" + "nokogiri-ext" + "open_namespace" + "ronin-core" + "ronin-support" + "ronin-web-server" + "ronin-web-spider" + "ronin-web-user_agents" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "06rh7hrkj4yl6pn1m3isfim2sk5vb3ap3rba91bw7drcqsra7fmw"; type = "gem"; }; version = "1.0.2"; }; ronin-web-server = { - dependencies = ["rack" "rack-user_agent" "ronin-support" "sinatra" "webrick"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rack" + "rack-user_agent" + "ronin-support" + "sinatra" + "webrick" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "14p1z2s20dkipb6rp2wyjc91dz6bjn5v8nv68m54my7p1vac05zk"; type = "gem"; }; version = "0.1.1"; }; ronin-web-spider = { - dependencies = ["ronin-support" "spidr"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "ronin-support" + "spidr" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0592llhzm8miy0lj4xsb4h0ppy18wmwqi54rjzzsm7h3d2py7iv9"; type = "gem"; }; version = "0.1.0"; }; ronin-web-user_agents = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1shca7bsc09hag7ax3js9xszw71mnf1ywrf0l0pk40hfqmnnaxcl"; type = "gem"; }; version = "0.1.0"; }; rouge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1dnfkrk8xx2m8r3r9m2p5xcq57viznyc09k7r3i4jbm758i57lx3"; type = "gem"; }; version = "3.30.0"; }; ruby-yasm = { - dependencies = ["command_mapper"]; - groups = ["default"]; - platforms = []; + dependencies = [ "command_mapper" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vf0kdaaysx9kr7v8rl0hl0j73zkfkg7zqvg0b41sgfg3zfib0ap"; type = "gem"; }; version = "0.3.0"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; rubyntlm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0b8hczk8hysv53ncsqzx4q6kma5gy5lqc7s5yx8h64x3vdb18cjv"; type = "gem"; }; version = "0.6.3"; }; sinatra = { - dependencies = ["mustermann" "rack" "rack-protection" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mustermann" + "rack" + "rack-protection" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "00541cnypsh1mnilfxxqlz6va9afrixf9m1asn4wzjp5m59777p8"; type = "gem"; }; version = "3.1.0"; }; spidr = { - dependencies = ["nokogiri"]; - groups = ["default"]; - platforms = []; + dependencies = [ "nokogiri" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15gjqry61z93f4p84x5b1bi6f65xd4djax0563ljngmsckyg7xg5"; type = "gem"; }; version = "0.7.0"; }; sqlite3 = { - dependencies = ["mini_portile2"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mini_portile2" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15415lmz69jbzl6nch4q5l2jxv054676nk6y0vgy0g3iklmjrxvc"; type = "gem"; }; version = "1.6.6"; }; stringio = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0ix96dxbjqlpymdigb4diwrifr0bq7qhsrng95fkkp18av326nqk"; type = "gem"; }; version = "3.0.8"; }; tdiff = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0rjvqyyxrybzhaqmgh4zjcdrvmqyqcqqbq4vda39idhrqcd2gy67"; type = "gem"; }; version = "0.3.4"; }; tilt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p3l7v619hwfi781l3r7ypyv1l8hivp09r18kmkn6g11c4yr1pc2"; type = "gem"; }; version = "2.3.0"; }; time = { - dependencies = ["date"]; - groups = ["default"]; - platforms = []; + dependencies = [ "date" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13pzdsgf3v06mymzipcpa7p80shyw328ybn775nzpnhc6n8y9g30"; type = "gem"; }; version = "0.2.2"; }; timeout = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d9cvm0f4zdpwa795v3zv4973y5zk59j7s1x3yn90jjrhcz1yvfd"; type = "gem"; }; version = "0.4.0"; }; timers = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pjzipnmzfywvgsr3gxwj6nmg47lz4700g0q71jgcy1z6rb7dn7p"; type = "gem"; }; version = "4.3.5"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; unf = { - dependencies = ["unf_ext"]; - groups = ["default"]; - platforms = []; + dependencies = [ "unf_ext" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0bh2cf73i2ffh4fcpdn9ir4mhq8zi50ik0zqa1braahzadx536a9"; type = "gem"; }; version = "0.1.4"; }; unf_ext = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yj2nz2l101vr1x9w2k83a0fag1xgnmjwp8w8rw4ik2rwcz65fch"; type = "gem"; }; version = "0.0.8.2"; }; uri-query_params = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "08i91q1q2fvjq7n21p4f4pryi8b9msknrgwz132spvhm4l55n6l6"; type = "gem"; }; version = "0.8.1"; }; webrick = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13qm7s0gr2pmfcl7dxrmq38asaza4w0i2n9my4yzs499j731wh8r"; type = "gem"; }; version = "1.8.1"; }; webrobots = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19ndcbba8s8m62hhxxfwn83nax34rg2k5x066awa23wknhnamg7b"; type = "gem"; }; version = "0.1.2"; }; woothee = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xg31qi09swgsf46b9ba38z2jav2516bg3kg7xf1wfbzw8mpd3fc"; type = "gem"; }; version = "1.13.0"; }; wordlist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06d4nj2nd172sn5yjw9qmpz7zqnymadbsxph741yx2h9va8q0qgd"; type = "gem"; }; diff --git a/pkgs/tools/security/rucredstash/default.nix b/pkgs/tools/security/rucredstash/default.nix index 43166eb0bf8ec7..9fe739ed814bc3 100644 --- a/pkgs/tools/security/rucredstash/default.nix +++ b/pkgs/tools/security/rucredstash/default.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchFromGitHub, stdenv, Security }: +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + Security, +}: rustPlatform.buildRustPackage rec { pname = "rucredstash"; diff --git a/pkgs/tools/security/sbomnix/default.nix b/pkgs/tools/security/sbomnix/default.nix index 7370854f9f60be..f6ab7ec81a6871 100644 --- a/pkgs/tools/security/sbomnix/default.nix +++ b/pkgs/tools/security/sbomnix/default.nix @@ -1,29 +1,29 @@ -{ lib -, fetchFromGitHub -, git -, grype -, nix -, nix-visualize -, python -, vulnix -, # python libs - beautifulsoup4 -, colorlog -, dfdiskcache -, filelock -, graphviz -, numpy -, packageurl-python -, packaging -, pandas -, pyrate-limiter -, requests -, requests-cache -, requests-ratelimiter -, reuse -, setuptools -, tabulate -, +{ + lib, + fetchFromGitHub, + git, + grype, + nix, + nix-visualize, + python, + vulnix, + # python libs + beautifulsoup4, + colorlog, + dfdiskcache, + filelock, + graphviz, + numpy, + packageurl-python, + packaging, + pandas, + pyrate-limiter, + requests, + requests-cache, + requests-ratelimiter, + reuse, + setuptools, + tabulate, }: python.pkgs.buildPythonApplication rec { @@ -45,14 +45,16 @@ python.pkgs.buildPythonApplication rec { }; makeWrapperArgs = [ - "--prefix PATH : ${lib.makeBinPath [ - git - nix - graphviz - nix-visualize - vulnix - grype - ]}" + "--prefix PATH : ${ + lib.makeBinPath [ + git + nix + graphviz + nix-visualize + vulnix + grype + ] + }" ]; nativeBuildInputs = [ setuptools ]; @@ -82,7 +84,14 @@ python.pkgs.buildPythonApplication rec { meta = with lib; { description = "Utilities to help with software supply chain challenges on nix targets"; homepage = "https://github.com/tiiuae/sbomnix"; - license = with licenses; [ asl20 bsd3 cc-by-30 ]; - maintainers = with maintainers; [ henrirosten jk ]; + license = with licenses; [ + asl20 + bsd3 + cc-by-30 + ]; + maintainers = with maintainers; [ + henrirosten + jk + ]; }; } diff --git a/pkgs/tools/security/schleuder/cli/default.nix b/pkgs/tools/security/schleuder/cli/default.nix index ea8e2c5083424a..c65c16d4090590 100644 --- a/pkgs/tools/security/schleuder/cli/default.nix +++ b/pkgs/tools/security/schleuder/cli/default.nix @@ -1,7 +1,8 @@ -{ lib -, bundlerApp -, ruby -, bundlerUpdateScript +{ + lib, + bundlerApp, + ruby, + bundlerUpdateScript, }: bundlerApp { diff --git a/pkgs/tools/security/schleuder/cli/gemset.nix b/pkgs/tools/security/schleuder/cli/gemset.nix index eeb05d82060f76..70a697bb601880 100644 --- a/pkgs/tools/security/schleuder/cli/gemset.nix +++ b/pkgs/tools/security/schleuder/cli/gemset.nix @@ -1,8 +1,8 @@ { schleuder-cli = { - dependencies = ["thor"]; - groups = ["default"]; - platforms = []; + dependencies = [ "thor" ]; + groups = [ "default" ]; + platforms = [ ]; source = { fetchSubmodules = false; rev = "fd010d28b1503504056e714e03abf043b64794ea"; @@ -13,10 +13,10 @@ version = "0.2.0"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vq1fjp45az9hfp6fxljhdrkv75cvbab1jfrwcw738pnsiqk8zps"; type = "gem"; }; diff --git a/pkgs/tools/security/schleuder/default.nix b/pkgs/tools/security/schleuder/default.nix index 8429cb0ea0d012..eb4403d6f4eeb3 100644 --- a/pkgs/tools/security/schleuder/default.nix +++ b/pkgs/tools/security/schleuder/default.nix @@ -1,9 +1,10 @@ -{ lib -, bundlerApp -, ruby -, stdenv -, bundlerUpdateScript -, nixosTests +{ + lib, + bundlerApp, + ruby, + stdenv, + bundlerUpdateScript, + nixosTests, }: bundlerApp { diff --git a/pkgs/tools/security/schleuder/gemset.nix b/pkgs/tools/security/schleuder/gemset.nix index ba22b478b00a57..ec334c67ac5f92 100644 --- a/pkgs/tools/security/schleuder/gemset.nix +++ b/pkgs/tools/security/schleuder/gemset.nix @@ -1,345 +1,385 @@ { activemodel = { - dependencies = ["activesupport"]; - groups = ["default"]; - platforms = []; + dependencies = [ "activesupport" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0zz32997k2fsyd0fzrh8f79yjr6hv3i4j9wykkxncl02j8dhrkay"; type = "gem"; }; version = "6.1.7.7"; }; activerecord = { - dependencies = ["activemodel" "activesupport"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activemodel" + "activesupport" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0qzymgyrvw2k32ldabp2jr0zgp6z9w8smyb946qgvs9zfs4n2qnn"; type = "gem"; }; version = "6.1.7.7"; }; activesupport = { - dependencies = ["concurrent-ruby" "i18n" "minitest" "tzinfo" "zeitwerk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "concurrent-ruby" + "i18n" + "minitest" + "tzinfo" + "zeitwerk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0r2i9b0pm0b1dy8fc7kyls1g7f0bcnyq53v825rykibzdqfqdfgp"; type = "gem"; }; version = "6.1.7.7"; }; bcrypt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16a0g2q40biv93i1hch3gw8rbmhp77qnnifj1k0a6m7dng3zh444"; type = "gem"; }; version = "3.1.20"; }; charlock_holmes = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hybw8jw9ryvz5zrki3gc9r88jqy373m6v46ynxsdzv1ysiyr40p"; type = "gem"; }; version = "0.7.7"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kmhr3pz2nmhnq0nqlicqfwfmkzkcl835g7sw1gjjhjvhz8g2sf3"; type = "gem"; }; version = "1.3.1"; }; daemons = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07cszb0zl8mqmwhc8a2yfg36vi6lbgrp4pa5bvmryrpcz9v6viwg"; type = "gem"; }; version = "1.4.1"; }; eventmachine = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0wh9aqb0skz80fhfn66lbpr4f86ya2z5rx6gm5xlfhd05bj1ch4r"; type = "gem"; }; version = "1.2.7"; }; gpgme = { - dependencies = ["mini_portile2"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mini_portile2" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0r1vmql7w7ka5xzj1aqf8pk2a4sv0znwj2zkg1fgvd5b89qcvv2k"; type = "gem"; }; version = "2.0.24"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ffix518y7976qih9k1lgnc17i3v6yrlh0a3mckpxdb4wc2vrp16"; type = "gem"; }; version = "1.14.5"; }; mail = { - dependencies = ["mini_mime"]; - groups = ["default"]; - platforms = []; + dependencies = [ "mini_mime" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00wwz6ys0502dpk8xprwcqfwyf3hmnx6lgxaiq6vj43mkx43sapc"; type = "gem"; }; version = "2.7.1"; }; mail-gpg = { - dependencies = ["gpgme" "mail"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "gpgme" + "mail" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1rz936m8nacy7agksvpvkf6b37d1h5qvh5xkrjqvv5wbdqs3cyfj"; type = "gem"; }; version = "0.4.4"; }; mini_mime = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vycif7pjzkr29mfk4dlqv3disc5dn0va04lkwajlpr1wkibg0c6"; type = "gem"; }; version = "1.1.5"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "149r94xi6b3jbp6bv72f8383b95ndn0p5sxnq11gs1j9jadv0ajf"; type = "gem"; }; version = "2.8.6"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gkslxvkhh44s21rbjvka3zsvfxxrf5pcl6f75rv2vyrzzbgis7i"; type = "gem"; }; version = "5.23.1"; }; multi_json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0pb1g1y3dsiahavspyzkdy39j4q377009f6ix0bh1ag4nqw43l0z"; type = "gem"; }; version = "1.15.0"; }; mustermann = { - dependencies = ["ruby2_keywords"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ruby2_keywords" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0m70qz27mlv2rhk4j1li6pw797gmiwwqg02vcgxcxr1rq2v53rnb"; type = "gem"; }; version = "2.0.2"; }; net-protocol = { - dependencies = ["timeout"]; - groups = ["default"]; - platforms = []; + dependencies = [ "timeout" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1a32l4x73hz200cm587bc29q8q9az278syw3x6fkc9d1lv5y0wxa"; type = "gem"; }; version = "0.2.2"; }; net-smtp = { - dependencies = ["net-protocol"]; - groups = ["default"]; - platforms = []; + dependencies = [ "net-protocol" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0amlhz8fhnjfmsiqcjajip57ici2xhw089x7zqyhpk51drg43h2z"; type = "gem"; }; version = "0.5.0"; }; rack = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0hj0rkw2z9r1lcg2wlrcld2n3phwrcgqcp7qd1g9a7hwgalh2qzx"; type = "gem"; }; version = "2.2.9"; }; rack-protection = { - dependencies = ["rack"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rack" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1d6irsigm0i4ig1m47c94kixi3wb8jnxwvwkl8qxvyngmb73srl2"; type = "gem"; }; version = "2.2.4"; }; rake = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17850wcwkgi30p7yqh60960ypn7yibacjjha0av78zaxwvd3ijs6"; type = "gem"; }; version = "13.2.1"; }; ruby2_keywords = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1vz322p8n39hz3b4a9gkmz9y7a5jaz41zrm2ywf31dvkqm03glgz"; type = "gem"; }; version = "0.0.5"; }; schleuder = { - dependencies = ["activerecord" "bcrypt" "charlock_holmes" "gpgme" "mail" "mail-gpg" "rake" "sinatra" "sinatra-contrib" "sqlite3" "thin" "thor"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "activerecord" + "bcrypt" + "charlock_holmes" + "gpgme" + "mail" + "mail-gpg" + "rake" + "sinatra" + "sinatra-contrib" + "sqlite3" + "thin" + "thor" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0lxmi7402v5qkajx3j5bydarxf3lbm1kzpwgy7zsmc7l28mcv8wx"; type = "gem"; }; version = "4.0.3"; }; sinatra = { - dependencies = ["mustermann" "rack" "rack-protection" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mustermann" + "rack" + "rack-protection" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0wkc079h6hzq737j4wycpnv7c38mhd0rl33pszyy7768zzvyjc9y"; type = "gem"; }; version = "2.2.4"; }; sinatra-contrib = { - dependencies = ["multi_json" "mustermann" "rack-protection" "sinatra" "tilt"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "multi_json" + "mustermann" + "rack-protection" + "sinatra" + "tilt" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0s6c1k3zzxp3xa7libvlpqaby27124rccyyxcsly04ih904cxk33"; type = "gem"; }; version = "2.2.4"; }; sqlite3 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1z1wa639c278bsipczn6kv8b13fj85pi8gk7x462chqx6k0wm0ax"; type = "gem"; }; version = "1.4.4"; }; thin = { - dependencies = ["daemons" "eventmachine" "rack"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "daemons" + "eventmachine" + "rack" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08g1yq6zzvgndj8fd98ah7pp8g2diw28p8bfjgv7rvjvp8d2am8w"; type = "gem"; }; version = "1.8.2"; }; thor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1yhrnp9x8qcy5vc7g438amd5j9sw83ih7c30dr6g6slgw9zj3g29"; type = "gem"; }; version = "0.20.3"; }; tilt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p3l7v619hwfi781l3r7ypyv1l8hivp09r18kmkn6g11c4yr1pc2"; type = "gem"; }; version = "2.3.0"; }; timeout = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16mvvsmx90023wrhf8dxc1lpqh0m8alk65shb7xcya6a9gflw7vg"; type = "gem"; }; version = "0.4.1"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; zeitwerk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1kr2731z8f6cj23jxh67cdnpkrnnfwbrxj1hfhshls4mp8i8drmj"; type = "gem"; }; diff --git a/pkgs/tools/security/sheesy-cli/default.nix b/pkgs/tools/security/sheesy-cli/default.nix index a2dda4493852d9..87701523ec5102 100644 --- a/pkgs/tools/security/sheesy-cli/default.nix +++ b/pkgs/tools/security/sheesy-cli/default.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, rustPlatform, fetchCrate, installShellFiles -, libgpg-error, gpgme, gettext, openssl, Security +{ + lib, + stdenv, + rustPlatform, + fetchCrate, + installShellFiles, + libgpg-error, + gpgme, + gettext, + openssl, + Security, }: rustPlatform.buildRustPackage rec { @@ -14,15 +23,29 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-o2XRvzw54x6xv81l97s1hwc2MC0Ioeyheoz3F+AtKpU="; cargoDepsName = pname; - nativeBuildInputs = [ libgpg-error gpgme gettext installShellFiles ]; + nativeBuildInputs = [ + libgpg-error + gpgme + gettext + installShellFiles + ]; buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; - buildFeatures = [ "vault" "extract" "completions" "substitute" "process" ]; + buildFeatures = [ + "vault" + "extract" + "completions" + "substitute" + "process" + ]; checkFeatures = [ ]; - cargoBuildFlags = [ "--bin" "sy" ]; + cargoBuildFlags = [ + "--bin" + "sy" + ]; postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' installShellCompletion --cmd sy \ diff --git a/pkgs/tools/security/softhsm/default.nix b/pkgs/tools/security/softhsm/default.nix index d755e131d8f001..3cbf2e7594187b 100644 --- a/pkgs/tools/security/softhsm/default.nix +++ b/pkgs/tools/security/softhsm/default.nix @@ -1,4 +1,12 @@ -{ lib, stdenv, fetchurl, botan2, sqlite, libobjc, Security }: +{ + lib, + stdenv, + fetchurl, + botan2, + sqlite, + libobjc, + Security, +}: stdenv.mkDerivation rec { @@ -18,10 +26,15 @@ stdenv.mkDerivation rec { "--localstatedir=$out/var" ]; - propagatedBuildInputs = - lib.optionals stdenv.hostPlatform.isDarwin [ libobjc Security ]; + propagatedBuildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libobjc + Security + ]; - buildInputs = [ botan2 sqlite ]; + buildInputs = [ + botan2 + sqlite + ]; postInstall = "rm -rf $out/var"; diff --git a/pkgs/tools/security/solo2-cli/default.nix b/pkgs/tools/security/solo2-cli/default.nix index 387bf00e37bfe0..4e4004e9c8b5ae 100644 --- a/pkgs/tools/security/solo2-cli/default.nix +++ b/pkgs/tools/security/solo2-cli/default.nix @@ -1,15 +1,16 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, installShellFiles -, pkg-config -, pcsclite -, udev -, PCSC -, IOKit -, CoreFoundation -, AppKit +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + installShellFiles, + pkg-config, + pcsclite, + udev, + PCSC, + IOKit, + CoreFoundation, + AppKit, }: rustPlatform.buildRustPackage rec { @@ -25,11 +26,23 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-X+IEeztSL312Yq9Loi3cNJuVfSGk/tRRBCsy0Juji7Y="; - nativeBuildInputs = [ installShellFiles pkg-config ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + ]; - buildInputs = [ ] - ++ lib.optionals stdenv.hostPlatform.isLinux [ pcsclite udev ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ PCSC IOKit CoreFoundation AppKit ]; + buildInputs = + [ ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + pcsclite + udev + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + PCSC + IOKit + CoreFoundation + AppKit + ]; postInstall = '' install -D 70-solo2.rules $out/lib/udev/rules.d/70-solo2.rules @@ -44,7 +57,10 @@ rustPlatform.buildRustPackage rec { meta = with lib; { description = "CLI tool for managing SoloKeys' Solo2 USB security keys"; homepage = "https://github.com/solokeys/solo2-cli"; - license = with licenses; [ asl20 mit ]; # either at your option + license = with licenses; [ + asl20 + mit + ]; # either at your option maintainers = with maintainers; [ lukegb ]; mainProgram = "solo2"; }; diff --git a/pkgs/tools/security/sslscan/default.nix b/pkgs/tools/security/sslscan/default.nix index a248e6fe21095a..643167e5a3a579 100644 --- a/pkgs/tools/security/sslscan/default.nix +++ b/pkgs/tools/security/sslscan/default.nix @@ -1,7 +1,8 @@ -{ lib -, stdenv -, fetchFromGitHub -, openssl +{ + lib, + stdenv, + fetchFromGitHub, + openssl, }: stdenv.mkDerivation rec { @@ -17,7 +18,10 @@ stdenv.mkDerivation rec { buildInputs = [ openssl ]; - makeFlags = [ "PREFIX=$(out)" "CC=${stdenv.cc.targetPrefix}cc" ]; + makeFlags = [ + "PREFIX=$(out)" + "CC=${stdenv.cc.targetPrefix}cc" + ]; meta = with lib; { description = "Tests SSL/TLS services and discover supported cipher suites"; @@ -25,6 +29,9 @@ stdenv.mkDerivation rec { homepage = "https://github.com/rbsec/sslscan"; changelog = "https://github.com/rbsec/sslscan/blob/${version}/Changelog"; license = licenses.gpl3Only; - maintainers = with maintainers; [ fpletz globin ]; + maintainers = with maintainers; [ + fpletz + globin + ]; }; } diff --git a/pkgs/tools/security/stoken/default.nix b/pkgs/tools/security/stoken/default.nix index 455310c202b8c5..bef9a55bd31d84 100644 --- a/pkgs/tools/security/stoken/default.nix +++ b/pkgs/tools/security/stoken/default.nix @@ -1,12 +1,13 @@ -{ lib -, stdenv -, fetchFromGitHub -, autoreconfHook -, pkg-config -, libxml2 -, nettle -, withGTK3 ? !stdenv.hostPlatform.isStatic -, gtk3 +{ + lib, + stdenv, + fetchFromGitHub, + autoreconfHook, + pkg-config, + libxml2, + nettle, + withGTK3 ? !stdenv.hostPlatform.isStatic, + gtk3, }: stdenv.mkDerivation rec { @@ -27,12 +28,14 @@ stdenv.mkDerivation rec { pkg-config ]; - buildInputs = [ - libxml2 - nettle - ] ++ lib.optionals withGTK3 [ - gtk3 - ]; + buildInputs = + [ + libxml2 + nettle + ] + ++ lib.optionals withGTK3 [ + gtk3 + ]; meta = with lib; { description = "Software Token for Linux/UNIX"; diff --git a/pkgs/tools/security/tor/default.nix b/pkgs/tools/security/tor/default.nix index 62cd7cfa7f26bf..e2576f02bb5b28 100644 --- a/pkgs/tools/security/tor/default.nix +++ b/pkgs/tools/security/tor/default.nix @@ -1,21 +1,41 @@ -{ lib, stdenv, fetchurl, pkg-config, libevent, openssl, zlib, torsocks -, libseccomp, systemd, libcap, xz, zstd, scrypt, nixosTests -, writeShellScript - -# for update.nix -, writeScript -, common-updater-scripts -, bash -, coreutils -, curl -, gnugrep -, gnupg -, gnused -, nix +{ + lib, + stdenv, + fetchurl, + pkg-config, + libevent, + openssl, + zlib, + torsocks, + libseccomp, + systemd, + libcap, + xz, + zstd, + scrypt, + nixosTests, + writeShellScript, + + # for update.nix + writeScript, + common-updater-scripts, + bash, + coreutils, + curl, + gnugrep, + gnupg, + gnused, + nix, }: let tor-client-auth-gen = writeShellScript "tor-client-auth-gen" '' - PATH="${lib.makeBinPath [coreutils gnugrep openssl]}" + PATH="${ + lib.makeBinPath [ + coreutils + gnugrep + openssl + ] + }" pem="$(openssl genpkey -algorithm x25519)" printf private_key=descriptor:x25519: @@ -37,11 +57,26 @@ stdenv.mkDerivation rec { sha256 = "sha256-m68mw4eiggs5QtpXIUbm63fCvGaGKvYpfNAqB05vuig="; }; - outputs = [ "out" "geoip" ]; + outputs = [ + "out" + "geoip" + ]; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ libevent openssl zlib xz zstd scrypt ] ++ - lib.optionals stdenv.hostPlatform.isLinux [ libseccomp systemd libcap ]; + buildInputs = + [ + libevent + openssl + zlib + xz + zstd + scrypt + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libseccomp + systemd + libcap + ]; patches = [ ./disable-monotonic-timer-tests.patch ]; @@ -51,12 +86,13 @@ stdenv.mkDerivation rec { # https://gitlab.torproject.org/tpo/onion-services/onion-support/-/wikis/Documentation/PoW-FAQ#compiling-c-tor-with-the-pow-defense [ "--enable-gpl" ] ++ - # cross compiles correctly but needs the following - lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ "--disable-tool-name-check" ] + # cross compiles correctly but needs the following + lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [ "--disable-tool-name-check" ] ++ - # sandbox is broken on aarch64-linux https://gitlab.torproject.org/tpo/core/tor/-/issues/40599 - lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) [ "--disable-seccomp" ] - ; + # sandbox is broken on aarch64-linux https://gitlab.torproject.org/tpo/core/tor/-/issues/40599 + lib.optionals (stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64) [ + "--disable-seccomp" + ]; NIX_CFLAGS_LINK = lib.optionalString stdenv.cc.isGNU "-lgcc_s"; @@ -95,7 +131,7 @@ stdenv.mkDerivation rec { gnugrep gnused nix - ; + ; }; }; @@ -113,10 +149,16 @@ stdenv.mkDerivation rec { the TCP protocol. ''; - license = with licenses; [ bsd3 gpl3Only ]; + license = with licenses; [ + bsd3 + gpl3Only + ]; - maintainers = with maintainers; - [ thoughtpolice joachifm prusnak ]; + maintainers = with maintainers; [ + thoughtpolice + joachifm + prusnak + ]; platforms = platforms.unix; }; } diff --git a/pkgs/tools/security/tor/torsocks.nix b/pkgs/tools/security/tor/torsocks.nix index 8b09bfc3bf9b6b..5092a1e42af929 100644 --- a/pkgs/tools/security/tor/torsocks.nix +++ b/pkgs/tools/security/tor/torsocks.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitLab -, fetchpatch -, autoreconfHook -, libcap +{ + lib, + stdenv, + fetchFromGitLab, + fetchpatch, + autoreconfHook, + libcap, }: stdenv.mkDerivation rec { @@ -35,16 +36,18 @@ stdenv.mkDerivation rec { ./torsocks-gethostbyaddr-darwin.patch ]; - postPatch = '' - # Patch torify_app() - sed -i \ - -e 's,\(local app_path\)=`which $1`,\1=`type -P $1`,' \ - src/bin/torsocks.in - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - sed -i \ - -e 's,\(local getcap\)=.*,\1=${libcap}/bin/getcap,' \ - src/bin/torsocks.in - ''; + postPatch = + '' + # Patch torify_app() + sed -i \ + -e 's,\(local app_path\)=`which $1`,\1=`type -P $1`,' \ + src/bin/torsocks.in + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + sed -i \ + -e 's,\(local getcap\)=.*,\1=${libcap}/bin/getcap,' \ + src/bin/torsocks.in + ''; nativeBuildInputs = [ autoreconfHook ]; @@ -52,11 +55,11 @@ stdenv.mkDerivation rec { installCheckTarget = "check-recursive"; meta = { - description = "Wrapper to safely torify applications"; + description = "Wrapper to safely torify applications"; mainProgram = "torsocks"; - homepage = "https://gitlab.torproject.org/tpo/core/torsocks"; - license = lib.licenses.gpl2Plus; - platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ thoughtpolice ]; + homepage = "https://gitlab.torproject.org/tpo/core/torsocks"; + license = lib.licenses.gpl2Plus; + platforms = lib.platforms.unix; + maintainers = with lib.maintainers; [ thoughtpolice ]; }; } diff --git a/pkgs/tools/security/tor/update.nix b/pkgs/tools/security/tor/update.nix index f0106aa26ea9ac..c1eaa3c1c1484c 100644 --- a/pkgs/tools/security/tor/update.nix +++ b/pkgs/tools/security/tor/update.nix @@ -1,13 +1,14 @@ -{ lib -, writeScript -, common-updater-scripts -, bash -, coreutils -, curl -, gnugrep -, gnupg -, gnused -, nix +{ + lib, + writeScript, + common-updater-scripts, + bash, + coreutils, + curl, + gnugrep, + gnupg, + gnused, + nix, }: let @@ -22,49 +23,51 @@ let in writeScript "update-tor" '' -#! ${bash}/bin/bash + #! ${bash}/bin/bash -set -eu -o pipefail + set -eu -o pipefail -export PATH=${lib.makeBinPath [ - common-updater-scripts - coreutils - curl - gnugrep - gnupg - gnused - nix -]} + export PATH=${ + lib.makeBinPath [ + common-updater-scripts + coreutils + curl + gnugrep + gnupg + gnused + nix + ] + } -srcBase=$(curl -L --list-only -- "${downloadPageUrl}" \ - | grep -Eo 'tor-([[:digit:]]+\.?)+\.tar\.gz' \ - | sort -Vu \ - | tail -n1) -srcFile=$srcBase -srcUrl=${downloadPageUrl}/$srcBase + srcBase=$(curl -L --list-only -- "${downloadPageUrl}" \ + | grep -Eo 'tor-([[:digit:]]+\.?)+\.tar\.gz' \ + | sort -Vu \ + | tail -n1) + srcFile=$srcBase + srcUrl=${downloadPageUrl}/$srcBase -srcName=''${srcBase/.tar.gz/} -srcVers=(''${srcName//-/ }) -version=''${srcVers[1]} + srcName=''${srcBase/.tar.gz/} + srcVers=(''${srcName//-/ }) + version=''${srcVers[1]} -checksumUrl=$srcUrl.sha256sum -checksumFile=''${checksumUrl##*/} + checksumUrl=$srcUrl.sha256sum + checksumFile=''${checksumUrl##*/} -sigUrl=$checksumUrl.asc -sigFile=''${sigUrl##*/} + sigUrl=$checksumUrl.asc + sigFile=''${sigUrl##*/} -# upstream does not support byte ranges ... -[[ -e "$srcFile" ]] || curl -L -o "$srcFile" -- "$srcUrl" -[[ -e "$checksumFile" ]] || curl -L -o "$checksumFile" -- "$checksumUrl" -[[ -e "$sigFile" ]] || curl -L -o "$sigFile" -- "$sigUrl" + # upstream does not support byte ranges ... + [[ -e "$srcFile" ]] || curl -L -o "$srcFile" -- "$srcUrl" + [[ -e "$checksumFile" ]] || curl -L -o "$checksumFile" -- "$checksumUrl" + [[ -e "$sigFile" ]] || curl -L -o "$sigFile" -- "$sigUrl" -export GNUPGHOME=$PWD/gnupg -mkdir -m 700 -p "$GNUPGHOME" + export GNUPGHOME=$PWD/gnupg + mkdir -m 700 -p "$GNUPGHOME" -gpg --batch --recv-keys ${lib.concatStringsSep " " (map (x: "'${x}'") signingKeys)} -gpg --batch --verify "$sigFile" "$checksumFile" + gpg --batch --recv-keys ${lib.concatStringsSep " " (map (x: "'${x}'") signingKeys)} + gpg --batch --verify "$sigFile" "$checksumFile" -sha256sum -c "$checksumFile" + sha256sum -c "$checksumFile" -update-source-version tor "$version" "$(cut -d ' ' "$checksumFile")" + update-source-version tor "$version" "$(cut -d ' ' "$checksumFile")" '' diff --git a/pkgs/tools/security/tracee/default.nix b/pkgs/tools/security/tracee/default.nix index 315ec08116afe9..fb0504f56ee383 100644 --- a/pkgs/tools/security/tracee/default.nix +++ b/pkgs/tools/security/tracee/default.nix @@ -1,18 +1,19 @@ -{ lib -, buildGoModule -, fetchFromGitHub - -, clang -, pkg-config - -, zlib -, elfutils -, libbpf - -, nixosTests -, testers -, tracee -, makeWrapper +{ + lib, + buildGoModule, + fetchFromGitHub, + + clang, + pkg-config, + + zlib, + elfutils, + libbpf, + + nixosTests, + testers, + tracee, + makeWrapper, }: buildGoModule rec { @@ -40,8 +41,15 @@ buildGoModule rec { # needed to build bpf libs hardeningDisable = [ "stackprotector" ]; - nativeBuildInputs = [ pkg-config clang ]; - buildInputs = [ elfutils libbpf zlib ]; + nativeBuildInputs = [ + pkg-config + clang + ]; + buildInputs = [ + elfutils + libbpf + zlib + ]; makeFlags = [ "VERSION=v${version}" @@ -62,7 +70,11 @@ buildGoModule rec { # see passthru.tests.integration doCheck = false; - outputs = [ "out" "lib" "share" ]; + outputs = [ + "out" + "lib" + "share" + ]; installPhase = '' runHook preInstall @@ -105,7 +117,13 @@ buildGoModule rec { gpl2Plus ]; maintainers = with maintainers; [ jk ]; - platforms = [ "x86_64-linux" "aarch64-linux" ]; - outputsToInstall = [ "out" "share" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; + outputsToInstall = [ + "out" + "share" + ]; }; } diff --git a/pkgs/tools/security/tracee/integration-tests.nix b/pkgs/tools/security/tracee/integration-tests.nix index fd3feb69f5648c..b83fb189cabff1 100644 --- a/pkgs/tools/security/tracee/integration-tests.nix +++ b/pkgs/tools/security/tracee/integration-tests.nix @@ -1,18 +1,24 @@ -{ lib, tracee, makeWrapper }: +{ + lib, + tracee, + makeWrapper, +}: tracee.overrideAttrs (oa: { pname = oa.pname + "-integration"; - postPatch = oa.postPatch or "" + '' - # fix the test to look at nixos paths for running programs - # --replace-fail '"integration.tes"' '"tracee-integrat"' \ - substituteInPlace tests/integration/event_filters_test.go \ - --replace-fail "exec=/usr/bin/dockerd" "comm=dockerd" \ - --replace-fail "exec=/usr/bin" "exec=/tmp/testdir" \ - --replace-fail "/usr/bin/tee" "tee" \ - --replace-fail "/usr/bin" "/run/current-system/sw/bin" \ - --replace-fail 'syscallerAbsPath := filepath.Join("..", "..", "dist", "syscaller")' "syscallerAbsPath := filepath.Join(\"$out/bin/syscaller\")" - substituteInPlace tests/integration/exec_test.go \ - --replace-fail "/usr/bin" "/run/current-system/sw/bin" - ''; + postPatch = + oa.postPatch or "" + + '' + # fix the test to look at nixos paths for running programs + # --replace-fail '"integration.tes"' '"tracee-integrat"' \ + substituteInPlace tests/integration/event_filters_test.go \ + --replace-fail "exec=/usr/bin/dockerd" "comm=dockerd" \ + --replace-fail "exec=/usr/bin" "exec=/tmp/testdir" \ + --replace-fail "/usr/bin/tee" "tee" \ + --replace-fail "/usr/bin" "/run/current-system/sw/bin" \ + --replace-fail 'syscallerAbsPath := filepath.Join("..", "..", "dist", "syscaller")' "syscallerAbsPath := filepath.Join(\"$out/bin/syscaller\")" + substituteInPlace tests/integration/exec_test.go \ + --replace-fail "/usr/bin" "/run/current-system/sw/bin" + ''; nativeBuildInputs = oa.nativeBuildInputs or [ ] ++ [ makeWrapper ]; buildPhase = '' runHook preBuild diff --git a/pkgs/tools/security/vaultwarden/default.nix b/pkgs/tools/security/vaultwarden/default.nix index e0039281261fd9..92f171fb77db19 100644 --- a/pkgs/tools/security/vaultwarden/default.nix +++ b/pkgs/tools/security/vaultwarden/default.nix @@ -1,10 +1,23 @@ -{ lib, stdenv, callPackage, rustPlatform, fetchFromGitHub, nixosTests -, pkg-config, openssl -, libiconv, Security, CoreServices, SystemConfiguration -, dbBackend ? "sqlite", libmysqlclient, postgresql }: +{ + lib, + stdenv, + callPackage, + rustPlatform, + fetchFromGitHub, + nixosTests, + pkg-config, + openssl, + libiconv, + Security, + CoreServices, + SystemConfiguration, + dbBackend ? "sqlite", + libmysqlclient, + postgresql, +}: let - webvault = callPackage ./webvault.nix {}; + webvault = callPackage ./webvault.nix { }; in rustPlatform.buildRustPackage rec { @@ -24,8 +37,14 @@ rustPlatform.buildRustPackage rec { env.VW_VERSION = version; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ libiconv Security CoreServices SystemConfiguration ] + buildInputs = + [ openssl ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Security + CoreServices + SystemConfiguration + ] ++ lib.optional (dbBackend == "mysql") libmysqlclient ++ lib.optional (dbBackend == "postgresql") postgresql; @@ -34,7 +53,7 @@ rustPlatform.buildRustPackage rec { passthru = { inherit webvault; tests = nixosTests.vaultwarden; - updateScript = callPackage ./update.nix {}; + updateScript = callPackage ./update.nix { }; }; meta = with lib; { @@ -42,7 +61,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/dani-garcia/vaultwarden"; changelog = "https://github.com/dani-garcia/vaultwarden/releases/tag/${version}"; license = licenses.agpl3Only; - maintainers = with maintainers; [ dotlambda SuperSandro2000 ]; + maintainers = with maintainers; [ + dotlambda + SuperSandro2000 + ]; mainProgram = "vaultwarden"; }; } diff --git a/pkgs/tools/security/vaultwarden/update.nix b/pkgs/tools/security/vaultwarden/update.nix index 4d0c6c4a50474f..94034fa038843c 100644 --- a/pkgs/tools/security/vaultwarden/update.nix +++ b/pkgs/tools/security/vaultwarden/update.nix @@ -1,19 +1,30 @@ -{ writeShellApplication -, lib -, nix -, nix-prefetch-git -, nix-update -, curl -, git -, gnugrep -, gnused -, jq -, yq +{ + writeShellApplication, + lib, + nix, + nix-prefetch-git, + nix-update, + curl, + git, + gnugrep, + gnused, + jq, + yq, }: lib.getExe (writeShellApplication { name = "update-vaultwarden"; - runtimeInputs = [ curl git gnugrep gnused jq yq nix nix-prefetch-git nix-update ]; + runtimeInputs = [ + curl + git + gnugrep + gnused + jq + yq + nix + nix-prefetch-git + nix-update + ]; text = '' VAULTWARDEN_VERSION=$(curl --silent https://api.github.com/repos/dani-garcia/vaultwarden/releases/latest | jq -r '.tag_name') diff --git a/pkgs/tools/security/vaultwarden/webvault.nix b/pkgs/tools/security/vaultwarden/webvault.nix index c4d881373fa2a1..d960e3c34a3b6f 100644 --- a/pkgs/tools/security/vaultwarden/webvault.nix +++ b/pkgs/tools/security/vaultwarden/webvault.nix @@ -1,10 +1,11 @@ -{ lib -, buildNpmPackage -, fetchFromGitHub -, git -, nixosTests -, python3 -, vaultwarden +{ + lib, + buildNpmPackage, + fetchFromGitHub, + git, + nixosTests, + python3, + vaultwarden, }: let @@ -19,7 +20,8 @@ let hash = "sha256-Gd8yQx9j6ieUvaM6IPSELNRy83y0cBkBwLYMqk8OIjU="; }; -in buildNpmPackage rec { +in +buildNpmPackage rec { pname = "vaultwarden-webvault"; inherit version; @@ -49,7 +51,8 @@ in buildNpmPackage rec { npmBuildScript = "dist:oss:selfhost"; npmBuildFlags = [ - "--workspace" "apps/web" + "--workspace" + "apps/web" ]; npmFlags = [ "--legacy-peer-deps" ]; diff --git a/pkgs/tools/security/web-eid-app/default.nix b/pkgs/tools/security/web-eid-app/default.nix index 3e1df1648c76fb..11afcd40003e0e 100644 --- a/pkgs/tools/security/web-eid-app/default.nix +++ b/pkgs/tools/security/web-eid-app/default.nix @@ -1,11 +1,12 @@ -{ lib -, mkDerivation -, fetchFromGitHub -, cmake -, gtest -, pcsclite -, pkg-config -, qttools +{ + lib, + mkDerivation, + fetchFromGitHub, + cmake, + gtest, + pcsclite, + pkg-config, + qttools, }: mkDerivation rec { diff --git a/pkgs/tools/security/whatweb/default.nix b/pkgs/tools/security/whatweb/default.nix index 9adf3cde8e478b..f672f4410245bd 100644 --- a/pkgs/tools/security/whatweb/default.nix +++ b/pkgs/tools/security/whatweb/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, bundlerEnv, ruby }: +{ + lib, + stdenv, + fetchFromGitHub, + bundlerEnv, + ruby, +}: let gems = bundlerEnv { @@ -7,7 +13,8 @@ let gemdir = ./.; }; -in stdenv.mkDerivation rec { +in +stdenv.mkDerivation rec { pname = "whatweb"; version = "0.5.5"; diff --git a/pkgs/tools/security/whatweb/gemset.nix b/pkgs/tools/security/whatweb/gemset.nix index 22d469b53e27d3..b495ed96fbc21b 100644 --- a/pkgs/tools/security/whatweb/gemset.nix +++ b/pkgs/tools/security/whatweb/gemset.nix @@ -1,71 +1,71 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "022r3m9wdxljpbya69y2i3h9g3dhhfaqzidf95m6qjzms792jvgp"; type = "gem"; }; version = "2.8.0"; }; bson = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03n3w96vpblaxvk1qk8hq7sbsmg4nv7qdkdr8f7nfvalgpakp5i5"; type = "gem"; }; version = "4.14.1"; }; ipaddr = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13qd34nzpgp3fxfjbvaqg3dcnfr0cgl5vjvcqy0hfllbvfcklnbq"; type = "gem"; }; version = "1.2.4"; }; json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1z9grvjyfz16ag55hg522d3q4dh07hf391sf9s96npc0vfi85xkz"; type = "gem"; }; version = "2.6.1"; }; mongo = { - dependencies = ["bson"]; - groups = ["default"]; - platforms = []; + dependencies = [ "bson" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "19sihy8ihi3hmdg3gxbf4qvzmjnzx8xygg9534012j9z0wmhs7h1"; type = "gem"; }; version = "2.17.1"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xqcgkl7bwws1qrlnmxgh8g4g9m10vg60bhlw40fplninb3ng6d9"; type = "gem"; }; version = "4.0.6"; }; rchardet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1isj1b3ywgg2m1vdlnr41lpvpm3dbyarf1lla4dfibfmad9csfk9"; type = "gem"; }; diff --git a/pkgs/tools/security/wpscan/default.nix b/pkgs/tools/security/wpscan/default.nix index 0d3d312cea43f2..afc92814244f30 100644 --- a/pkgs/tools/security/wpscan/default.nix +++ b/pkgs/tools/security/wpscan/default.nix @@ -1,7 +1,8 @@ -{ lib -, bundlerApp -, makeWrapper -, curl +{ + lib, + bundlerApp, + makeWrapper, + curl, }: bundlerApp { @@ -23,7 +24,10 @@ bundlerApp { homepage = "https://wpscan.org/"; changelog = "https://github.com/wpscanteam/wpscan/releases"; license = licenses.unfreeRedistributable; - maintainers = with maintainers; [ nyanloutre manveru ]; + maintainers = with maintainers; [ + nyanloutre + manveru + ]; platforms = platforms.unix; }; } diff --git a/pkgs/tools/security/wpscan/gemset.nix b/pkgs/tools/security/wpscan/gemset.nix index df1c097baea7b1..8fc1e9032d77bb 100644 --- a/pkgs/tools/security/wpscan/gemset.nix +++ b/pkgs/tools/security/wpscan/gemset.nix @@ -1,292 +1,320 @@ { activesupport = { - dependencies = ["base64" "bigdecimal" "concurrent-ruby" "connection_pool" "drb" "i18n" "logger" "minitest" "securerandom" "tzinfo"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "base64" + "bigdecimal" + "concurrent-ruby" + "connection_pool" + "drb" + "i18n" + "logger" + "minitest" + "securerandom" + "tzinfo" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "094cv9kxa8hwlsw3c0njkvvayd0wszcz9b6xywv4yajrg83zlmvm"; type = "gem"; }; version = "7.2.1"; }; addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; base64 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01qml0yilb9basf7is2614skjp8384h2pycfx86cr8023arfj98g"; type = "gem"; }; version = "0.2.0"; }; bigdecimal = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1gi7zqgmqwi5lizggs1jhc3zlwaqayy9rx2ah80sxy24bbnng558"; type = "gem"; }; version = "3.1.8"; }; cms_scanner = { - dependencies = ["ethon" "get_process_mem" "nokogiri" "opt_parse_validator" "public_suffix" "ruby-progressbar" "sys-proctable" "typhoeus" "xmlrpc" "yajl-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "ethon" + "get_process_mem" + "nokogiri" + "opt_parse_validator" + "public_suffix" + "ruby-progressbar" + "sys-proctable" + "typhoeus" + "xmlrpc" + "yajl-ruby" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bkmxxxz0q8brfivm7li1hmk2yrdl8wpi25qi4c2rhzfk361ass3"; type = "gem"; }; version = "0.14.3"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; connection_pool = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1x32mcpm2cl5492kd6lbjbaf17qsssmpx9kdyr7z1wcif2cwyh0g"; type = "gem"; }; version = "2.4.1"; }; drb = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0h5kbj9hvg5hb3c7l425zpds0vb42phvln2knab8nmazg2zp5m79"; type = "gem"; }; version = "2.2.1"; }; ethon = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17ix0mijpsy3y0c6ywrk5ibarmvqzjsirjyprpsy3hwax8fdm85v"; type = "gem"; }; version = "0.16.0"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; get_process_mem = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fkyyyxjcx4iigm8vhraa629k2lxa1npsv4015y82snx84v3rzaa"; type = "gem"; }; version = "0.2.7"; }; i18n = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k31wcgnvcvd14snz0pfqj976zv6drfsnq6x8acz10fiyms9l8nw"; type = "gem"; }; version = "1.14.6"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q1f2sdw3y3y9mnym9dhjgsjr72sq975cfg5c4yx7gwv8nmzbvhk"; type = "gem"; }; version = "2.8.7"; }; minitest = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1n1akmc6bibkbxkzm1p1wmfb4n9vv397knkgz0ffykb3h1d7kdix"; type = "gem"; }; version = "5.25.1"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15gysw8rassqgdq3kwgl4mhqmrgh7nk2qvrcqp4ijyqazgywn6gq"; type = "gem"; }; version = "1.16.7"; }; opt_parse_validator = { - dependencies = ["activesupport" "addressable"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "activesupport" + "addressable" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0x2pn1c8h5sn3j5x05n2l1wnd56vp28jzg8pap1dj7ddmhlv12p4"; type = "gem"; }; version = "1.10.0"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vqcw3iwby3yc6avs1vb3gfd0vcp2v7q310665dvxfswmcf4xm31"; type = "gem"; }; version = "6.0.1"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0byn0c9nkahsl93y9ln5bysq4j31q8xkf2ws42swighxd4lnjzsa"; type = "gem"; }; version = "1.8.1"; }; ruby-progressbar = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cwvyb7j47m7wihpfaq7rc47zwwx9k4v7iqd9s1xch5nm53rrz40"; type = "gem"; }; version = "1.13.0"; }; securerandom = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1phv6kh417vkanhssbjr960c0gfqvf8z7d3d9fd2yvd41q64bw4q"; type = "gem"; }; version = "0.3.1"; }; sys-proctable = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0m3fj6j1qpfszqnsvr6wpak0d9vw5ggylaqkalhl3m50kbbimxii"; type = "gem"; }; version = "1.3.0"; }; typhoeus = { - dependencies = ["ethon"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ethon" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0z7gamf6s83wy0yqms3bi4srirn3fc0lc7n65lqanidxcj1xn5qw"; type = "gem"; }; version = "1.4.1"; }; tzinfo = { - dependencies = ["concurrent-ruby"]; - groups = ["default"]; - platforms = []; + dependencies = [ "concurrent-ruby" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "16w2g84dzaf3z13gxyzlzbf748kylk5bdgg3n1ipvkvvqy685bwd"; type = "gem"; }; version = "2.0.6"; }; webrick = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "089gy5494j560b242vi173wnbj2913hwlwnjkpzld58r96ilc5s3"; type = "gem"; }; version = "1.8.2"; }; wpscan = { - dependencies = ["cms_scanner"]; - groups = ["default"]; - platforms = []; + dependencies = [ "cms_scanner" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14d2kp01fnbm88ny6wvzr1v8za2mv4wvx8k0iz8cb5z15nlldk78"; type = "gem"; }; version = "3.8.27"; }; xmlrpc = { - dependencies = ["webrick"]; - groups = ["default"]; - platforms = []; + dependencies = [ "webrick" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fwfnccagsjrbvrav5nbk3zracj9zncr7i375nn20jd4cfy4cggc"; type = "gem"; }; version = "0.3.3"; }; yajl-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1lni4jbyrlph7sz8y49q84pb0sbj82lgwvnjnsiv01xf26f4v5wc"; type = "gem"; }; diff --git a/pkgs/tools/security/zsteg/default.nix b/pkgs/tools/security/zsteg/default.nix index 2171a77fce1a27..c078189f4f29c6 100644 --- a/pkgs/tools/security/zsteg/default.nix +++ b/pkgs/tools/security/zsteg/default.nix @@ -11,7 +11,10 @@ bundlerApp { description = "Detect stegano-hidden data in PNG & BMP"; homepage = "http://zed.0xff.me/"; license = licenses.mit; - maintainers = with maintainers; [ applePrincess h7x4 ]; + maintainers = with maintainers; [ + applePrincess + h7x4 + ]; mainProgram = "zsteg"; }; } diff --git a/pkgs/tools/security/zsteg/gemset.nix b/pkgs/tools/security/zsteg/gemset.nix index 5cb55829a6acd0..07dfcf016f01ed 100644 --- a/pkgs/tools/security/zsteg/gemset.nix +++ b/pkgs/tools/security/zsteg/gemset.nix @@ -1,72 +1,79 @@ { forwardable = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1b5g1i3xdvmxxpq4qp0z4v78ivqnazz26w110fh4cvzsdayz8zgi"; type = "gem"; }; version = "1.3.3"; }; iostruct = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1z3vnb8mhzns3ybf78vlj5cy6lq4pyfm8n40kqba2s33xccs3kl0"; type = "gem"; }; version = "0.0.5"; }; prime = { - dependencies = ["forwardable" "singleton"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "forwardable" + "singleton" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1973kz8lbck6ga5v42f55jk8b8pnbgwp9p67dl1xw15gvz55dsfl"; type = "gem"; }; version = "0.1.2"; }; rainbow = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0smwg4mii0fm38pyb5fddbmrdpifwv22zv3d3px2xx497am93503"; type = "gem"; }; version = "3.1.1"; }; singleton = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qq54imvbksnckzf9hrq9bjzcdb0n8wfv6l5jc0di10n88277jx6"; type = "gem"; }; version = "0.2.0"; }; zpng = { - dependencies = ["rainbow"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rainbow" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0xyr7ipgls7wci1gnsz340idm69jls0gind0q4f63ccjwgzsfkqw"; type = "gem"; }; version = "0.4.5"; }; zsteg = { - dependencies = ["iostruct" "prime" "zpng"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "iostruct" + "prime" + "zpng" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "128kbv9vsi288mj17zwvc45ijpzf3p116vk9kcvkz978hz0n6spm"; type = "gem"; }; diff --git a/pkgs/tools/system/bottom/default.nix b/pkgs/tools/system/bottom/default.nix index bef7d0e4264f23..f042b7067f4ec2 100644 --- a/pkgs/tools/system/bottom/default.nix +++ b/pkgs/tools/system/bottom/default.nix @@ -1,11 +1,12 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, installShellFiles -, stdenv -, darwin -, bottom -, testers +{ + lib, + rustPlatform, + fetchFromGitHub, + installShellFiles, + stdenv, + darwin, + bottom, + testers, }: rustPlatform.buildRustPackage rec { @@ -49,7 +50,10 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/ClementTsang/bottom"; changelog = "https://github.com/ClementTsang/bottom/blob/${version}/CHANGELOG.md"; license = licenses.mit; - maintainers = with maintainers; [ berbiche figsoda ]; + maintainers = with maintainers; [ + berbiche + figsoda + ]; mainProgram = "btm"; }; } diff --git a/pkgs/tools/system/clinfo/default.nix b/pkgs/tools/system/clinfo/default.nix index 465bba682b0e02..48b5d4672b8a1c 100644 --- a/pkgs/tools/system/clinfo/default.nix +++ b/pkgs/tools/system/clinfo/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, ocl-icd, opencl-headers, OpenCL }: +{ + lib, + stdenv, + fetchFromGitHub, + ocl-icd, + opencl-headers, + OpenCL, +}: stdenv.mkDerivation rec { pname = "clinfo"; @@ -11,12 +18,14 @@ stdenv.mkDerivation rec { sha256 = "sha256-1jZP4SnLIHh3vQJLBp+j/eQ1c8XBGFR2hjYxflhpWAU="; }; - buildInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ - ocl-icd - opencl-headers - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - OpenCL - ]; + buildInputs = + lib.optionals (!stdenv.hostPlatform.isDarwin) [ + ocl-icd + opencl-headers + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + OpenCL + ]; makeFlags = [ "PREFIX=${placeholder "out"}" ]; @@ -24,7 +33,10 @@ stdenv.mkDerivation rec { description = "Print all known information about all available OpenCL platforms and devices in the system"; homepage = "https://github.com/Oblomov/clinfo"; license = licenses.cc0; - maintainers = with maintainers; [ athas r-burns ]; + maintainers = with maintainers; [ + athas + r-burns + ]; platforms = platforms.unix; mainProgram = "clinfo"; }; diff --git a/pkgs/tools/system/cm-rgb/default.nix b/pkgs/tools/system/cm-rgb/default.nix index 392f955fe76560..577cf0a179bb5a 100644 --- a/pkgs/tools/system/cm-rgb/default.nix +++ b/pkgs/tools/system/cm-rgb/default.nix @@ -1,13 +1,14 @@ -{ lib -, buildPythonApplication -, fetchFromGitHub -, atk -, gobject-introspection -, wrapGAppsHook3 -, click -, hidapi -, psutil -, pygobject3 +{ + lib, + buildPythonApplication, + fetchFromGitHub, + atk, + gobject-introspection, + wrapGAppsHook3, + click, + hidapi, + psutil, + pygobject3, }: buildPythonApplication rec { diff --git a/pkgs/tools/system/collectd/default.nix b/pkgs/tools/system/collectd/default.nix index b75cdb19de1630..4be42d86237ed5 100644 --- a/pkgs/tools/system/collectd/default.nix +++ b/pkgs/tools/system/collectd/default.nix @@ -1,9 +1,15 @@ -{ lib, stdenv, fetchurl, fetchpatch, darwin, callPackage -, autoreconfHook -, pkg-config -, libtool -, nixosTests -, ... +{ + lib, + stdenv, + fetchurl, + fetchpatch, + darwin, + callPackage, + autoreconfHook, + pkg-config, + libtool, + nixosTests, + ... }@args: let plugins = callPackage ./plugins.nix args; @@ -31,22 +37,30 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ pkg-config autoreconfHook ]; - buildInputs = [ - libtool - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - darwin.apple_sdk.frameworks.ApplicationServices - ] ++ plugins.buildInputs; + nativeBuildInputs = [ + pkg-config + autoreconfHook + ]; + buildInputs = + [ + libtool + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + darwin.apple_sdk.frameworks.ApplicationServices + ] + ++ plugins.buildInputs; - configureFlags = [ - "--localstatedir=/var" - "--disable-werror" - ] ++ plugins.configureFlags - ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ "--with-fp-layout=nothing" ]; + configureFlags = + [ + "--localstatedir=/var" + "--disable-werror" + ] + ++ plugins.configureFlags + ++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [ "--with-fp-layout=nothing" ]; # do not create directories in /var during installPhase postConfigure = '' - substituteInPlace Makefile --replace '$(mkinstalldirs) $(DESTDIR)$(localstatedir)/' '#' + substituteInPlace Makefile --replace '$(mkinstalldirs) $(DESTDIR)$(localstatedir)/' '#' ''; postInstall = '' diff --git a/pkgs/tools/system/collectd/plugins.nix b/pkgs/tools/system/collectd/plugins.nix index 7202ec795e8b29..45b38f8e68f3e8 100644 --- a/pkgs/tools/system/collectd/plugins.nix +++ b/pkgs/tools/system/collectd/plugins.nix @@ -1,48 +1,52 @@ -{ lib, stdenv -, curl -, hiredis -, iptables -, jdk -, libatasmart -, libdbi -, libesmtp -, libgcrypt -, libmemcached, cyrus_sasl -, libmodbus -, libmicrohttpd -, libmnl -, libmysqlclient -, libnotify, gdk-pixbuf -, liboping -, libpcap -, libsigrok -, libvirt -, libxml2 -, lua -, lvm2 -, lm_sensors -, mongoc -, mosquitto -, net-snmp -, openldap -, openipmi -, perl -, postgresql -, protobufc -, python3 -, rabbitmq-c -, rdkafka -, riemann_c_client -, rrdtool -, udev -, varnish -, xen -, yajl -, IOKit -# Defaults to `null` for all supported plugins (except xen, which is marked as -# insecure), otherwise a list of plugin names for a custom build -, enabledPlugins ? null -, ... +{ + lib, + stdenv, + curl, + hiredis, + iptables, + jdk, + libatasmart, + libdbi, + libesmtp, + libgcrypt, + libmemcached, + cyrus_sasl, + libmodbus, + libmicrohttpd, + libmnl, + libmysqlclient, + libnotify, + gdk-pixbuf, + liboping, + libpcap, + libsigrok, + libvirt, + libxml2, + lua, + lvm2, + lm_sensors, + mongoc, + mosquitto, + net-snmp, + openldap, + openipmi, + perl, + postgresql, + protobufc, + python3, + rabbitmq-c, + rdkafka, + riemann_c_client, + rrdtool, + udev, + varnish, + xen, + yajl, + IOKit, + # Defaults to `null` for all supported plugins (except xen, which is marked as + # insecure), otherwise a list of plugin names for a custom build + enabledPlugins ? null, + ... }: let @@ -53,45 +57,74 @@ let yajl ] ++ lib.optionals stdenv.hostPlatform.isLinux [ rabbitmq-c ]; apache.buildInputs = [ curl ]; - ascent.buildInputs = [ curl libxml2 ]; + ascent.buildInputs = [ + curl + libxml2 + ]; battery.buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ IOKit ]; - bind.buildInputs = [ curl libxml2 ]; + bind.buildInputs = [ + curl + libxml2 + ]; ceph.buildInputs = [ yajl ]; curl.buildInputs = [ curl ]; - curl_json.buildInputs = [ curl yajl ]; - curl_xml.buildInputs = [ curl libxml2 ]; - dbi.buildInputs = [ libdbi ]; - disk.buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ - udev - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - IOKit + curl_json.buildInputs = [ + curl + yajl ]; + curl_xml.buildInputs = [ + curl + libxml2 + ]; + dbi.buildInputs = [ libdbi ]; + disk.buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ + udev + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + IOKit + ]; dns.buildInputs = [ libpcap ]; ipmi.buildInputs = [ openipmi ]; - iptables.buildInputs = [ - libpcap - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - iptables libmnl + iptables.buildInputs = + [ + libpcap + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + iptables + libmnl + ]; + java.buildInputs = [ + jdk + libgcrypt + libxml2 ]; - java.buildInputs = [ jdk libgcrypt libxml2 ]; log_logstash.buildInputs = [ yajl ]; lua.buildInputs = [ lua ]; - memcachec.buildInputs = [ libmemcached cyrus_sasl ]; + memcachec.buildInputs = [ + libmemcached + cyrus_sasl + ]; modbus.buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libmodbus ]; mqtt.buildInputs = [ mosquitto ]; mysql.buildInputs = lib.optionals (libmysqlclient != null) [ libmysqlclient ]; - netlink.buildInputs = [ - libpcap - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - libmnl - ]; + netlink.buildInputs = + [ + libpcap + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libmnl + ]; network.buildInputs = [ libgcrypt ]; nginx.buildInputs = [ curl ]; - notify_desktop.buildInputs = [ libnotify gdk-pixbuf ]; + notify_desktop.buildInputs = [ + libnotify + gdk-pixbuf + ]; notify_email.buildInputs = [ libesmtp ]; openldap.buildInputs = [ openldap ]; ovs_events.buildInputs = [ yajl ]; @@ -102,40 +135,79 @@ let postgresql.buildInputs = [ postgresql ]; python.buildInputs = [ python3 ]; redis.buildInputs = [ hiredis ]; - rrdcached.buildInputs = [ rrdtool libxml2 ]; - rrdtool.buildInputs = [ rrdtool libxml2 ]; + rrdcached.buildInputs = [ + rrdtool + libxml2 + ]; + rrdtool.buildInputs = [ + rrdtool + libxml2 + ]; sensors.buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ lm_sensors ]; - sigrok.buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libsigrok udev ]; - smart.buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ libatasmart udev ]; + sigrok.buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ + libsigrok + udev + ]; + smart.buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ + libatasmart + udev + ]; snmp.buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ net-snmp ]; snmp_agent.buildInputs = lib.optionals stdenv.hostPlatform.isLinux [ net-snmp ]; - varnish.buildInputs = [ curl varnish ]; - virt.buildInputs = [ - libvirt libxml2 yajl - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ lvm2 udev ]; - write_http.buildInputs = [ curl yajl ]; - write_kafka.buildInputs = [ yajl rdkafka ]; + varnish.buildInputs = [ + curl + varnish + ]; + virt.buildInputs = + [ + libvirt + libxml2 + yajl + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + lvm2 + udev + ]; + write_http.buildInputs = [ + curl + yajl + ]; + write_kafka.buildInputs = [ + yajl + rdkafka + ]; write_log.buildInputs = [ yajl ]; write_mongodb.buildInputs = [ mongoc ]; - write_prometheus.buildInputs = [ protobufc libmicrohttpd ]; + write_prometheus.buildInputs = [ + protobufc + libmicrohttpd + ]; write_redis.buildInputs = [ hiredis ]; - write_riemann.buildInputs = [ protobufc riemann_c_client ]; + write_riemann.buildInputs = [ + protobufc + riemann_c_client + ]; xencpu.buildInputs = [ xen ]; }; configureFlags = lib.optionals (enabledPlugins != null) ( - [ "--disable-all-plugins" ] - ++ (map (plugin: "--enable-${plugin}") enabledPlugins)); + [ "--disable-all-plugins" ] ++ (map (plugin: "--enable-${plugin}") enabledPlugins) + ); - pluginBuildInputs = plugin: - lib.optionals (plugins ? ${plugin} && plugins.${plugin} ? buildInputs) - plugins.${plugin}.buildInputs; + pluginBuildInputs = + plugin: + lib.optionals ( + plugins ? ${plugin} && plugins.${plugin} ? buildInputs + ) plugins.${plugin}.buildInputs; buildInputs = - if enabledPlugins == null - then builtins.concatMap pluginBuildInputs - (builtins.attrNames (builtins.removeAttrs plugins ["xencpu"])) - else builtins.concatMap pluginBuildInputs enabledPlugins; -in { + if enabledPlugins == null then + builtins.concatMap pluginBuildInputs ( + builtins.attrNames (builtins.removeAttrs plugins [ "xencpu" ]) + ) + else + builtins.concatMap pluginBuildInputs enabledPlugins; +in +{ inherit configureFlags buildInputs; } diff --git a/pkgs/tools/system/colorls/default.nix b/pkgs/tools/system/colorls/default.nix index 3dc460140cb63a..ff4677735bd2fc 100644 --- a/pkgs/tools/system/colorls/default.nix +++ b/pkgs/tools/system/colorls/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerApp, ruby, bundlerUpdateScript }: +{ + lib, + bundlerApp, + ruby, + bundlerUpdateScript, +}: bundlerApp { pname = "colorls"; @@ -10,10 +15,14 @@ bundlerApp { meta = with lib; { description = "Prettified LS"; - homepage = "https://github.com/athityakumar/colorls"; - license = with licenses; mit; - maintainers = with maintainers; [ lukebfox nicknovitski cbley ]; - platforms = ruby.meta.platforms; + homepage = "https://github.com/athityakumar/colorls"; + license = with licenses; mit; + maintainers = with maintainers; [ + lukebfox + nicknovitski + cbley + ]; + platforms = ruby.meta.platforms; mainProgram = "colorls"; }; } diff --git a/pkgs/tools/system/fdisk/default.nix b/pkgs/tools/system/fdisk/default.nix index f2b3ab0f813251..beb4906d0e499a 100644 --- a/pkgs/tools/system/fdisk/default.nix +++ b/pkgs/tools/system/fdisk/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchurl -, gettext -, guile -, libuuid -, parted +{ + lib, + stdenv, + fetchurl, + gettext, + guile, + libuuid, + parted, }: stdenv.mkDerivation rec { diff --git a/pkgs/tools/system/gotop/default.nix b/pkgs/tools/system/gotop/default.nix index b2279e0f13d224..0adbb2c4faf99e 100644 --- a/pkgs/tools/system/gotop/default.nix +++ b/pkgs/tools/system/gotop/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, buildGoModule -, fetchFromGitHub -, installShellFiles -, IOKit +{ + lib, + stdenv, + buildGoModule, + fetchFromGitHub, + installShellFiles, + IOKit, }: buildGoModule rec { @@ -25,7 +26,11 @@ buildGoModule rec { proxyVendor = true; vendorHash = "sha256-KLeVSrPDS1lKsKFemRmgxT6Pxack3X3B/btSCOUSUFY="; - ldflags = [ "-s" "-w" "-X main.Version=v${version}" ]; + ldflags = [ + "-s" + "-w" + "-X main.Version=v${version}" + ]; # prevent `error: 'TARGET_OS_MAC' is not defined` env.CGO_CFLAGS = "-Wno-undef-prefix"; diff --git a/pkgs/tools/system/hiera-eyaml/default.nix b/pkgs/tools/system/hiera-eyaml/default.nix index 1f48d37f5847a4..8c19af264fa9a0 100644 --- a/pkgs/tools/system/hiera-eyaml/default.nix +++ b/pkgs/tools/system/hiera-eyaml/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerEnv, ruby, bundlerUpdateScript }: +{ + lib, + bundlerEnv, + ruby, + bundlerUpdateScript, +}: bundlerEnv { inherit ruby; @@ -11,7 +16,10 @@ bundlerEnv { description = "Per-value asymmetric encryption of sensitive data for Hiera"; homepage = "https://github.com/TomPoulton/hiera-eyaml"; license = licenses.mit; - maintainers = with maintainers; [ benley nicknovitski ]; + maintainers = with maintainers; [ + benley + nicknovitski + ]; platforms = platforms.unix; mainProgram = "eyaml"; }; diff --git a/pkgs/tools/system/hiera-eyaml/gemset.nix b/pkgs/tools/system/hiera-eyaml/gemset.nix index cf7d8d6905d07e..605b14da800de9 100644 --- a/pkgs/tools/system/hiera-eyaml/gemset.nix +++ b/pkgs/tools/system/hiera-eyaml/gemset.nix @@ -1,10 +1,13 @@ { hiera-eyaml = { - dependencies = ["highline" "optimist"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "highline" + "optimist" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "049rxnwyivqgyjl0sjg7cb2q44ic0wsml288caspd1ps8v31gl18"; type = "gem"; }; @@ -12,17 +15,17 @@ }; highline = { source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06bml1fjsnrhd956wqq5k3w8cyd09rv1vixdpa3zzkl6xs72jdn1"; type = "gem"; }; version = "1.6.21"; }; optimist = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05jxrp3nbn5iilc1k7ir90mfnwc5abc9h78s5rpm3qafwqxvcj4j"; type = "gem"; }; diff --git a/pkgs/tools/system/htop/default.nix b/pkgs/tools/system/htop/default.nix index e9e1b2db6754a9..47f97c5fd34689 100644 --- a/pkgs/tools/system/htop/default.nix +++ b/pkgs/tools/system/htop/default.nix @@ -1,10 +1,18 @@ -{ lib, fetchFromGitHub, fetchpatch2, stdenv, autoreconfHook, pkg-config -, ncurses -, IOKit -, libcap -, libnl -, sensorsSupport ? stdenv.hostPlatform.isLinux, lm_sensors -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, systemd +{ + lib, + fetchFromGitHub, + fetchpatch2, + stdenv, + autoreconfHook, + pkg-config, + ncurses, + IOKit, + libcap, + libnl, + sensorsSupport ? stdenv.hostPlatform.isLinux, + lm_sensors, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, }: assert systemdSupport -> stdenv.hostPlatform.isLinux; @@ -30,30 +38,35 @@ stdenv.mkDerivation rec { }) ]; - nativeBuildInputs = [ autoreconfHook ] - ++ lib.optional stdenv.hostPlatform.isLinux pkg-config - ; + nativeBuildInputs = [ autoreconfHook ] ++ lib.optional stdenv.hostPlatform.isLinux pkg-config; - buildInputs = [ ncurses ] + buildInputs = + [ ncurses ] ++ lib.optional stdenv.hostPlatform.isDarwin IOKit - ++ lib.optionals stdenv.hostPlatform.isLinux [ libcap libnl ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + libcap + libnl + ] ++ lib.optional sensorsSupport lm_sensors - ++ lib.optional systemdSupport systemd - ; + ++ lib.optional systemdSupport systemd; - configureFlags = [ "--enable-unicode" "--sysconfdir=/etc" ] + configureFlags = + [ + "--enable-unicode" + "--sysconfdir=/etc" + ] ++ lib.optionals stdenv.hostPlatform.isLinux [ "--enable-affinity" "--enable-capabilities" "--enable-delayacct" ] - ++ lib.optional sensorsSupport "--enable-sensors" - ; + ++ lib.optional sensorsSupport "--enable-sensors"; postFixup = let optionalPatch = pred: so: lib.optionalString pred "patchelf --add-needed ${so} $out/bin/htop"; - in lib.optionalString (!stdenv.hostPlatform.isStatic) '' + in + lib.optionalString (!stdenv.hostPlatform.isStatic) '' ${optionalPatch sensorsSupport "${lm_sensors}/lib/libsensors.so"} ${optionalPatch systemdSupport "${systemd}/lib/libsystemd.so"} ''; @@ -63,7 +76,11 @@ stdenv.mkDerivation rec { homepage = "https://htop.dev"; license = licenses.gpl2Only; platforms = platforms.all; - maintainers = with maintainers; [ rob relrod SuperSandro2000 ]; + maintainers = with maintainers; [ + rob + relrod + SuperSandro2000 + ]; changelog = "https://github.com/htop-dev/htop/blob/${version}/ChangeLog"; mainProgram = "htop"; }; diff --git a/pkgs/tools/system/htop/htop-vim.nix b/pkgs/tools/system/htop/htop-vim.nix index 6dfb72c8ca75ee..28fafbe388293b 100644 --- a/pkgs/tools/system/htop/htop-vim.nix +++ b/pkgs/tools/system/htop/htop-vim.nix @@ -1,4 +1,8 @@ -{ lib, htop, fetchFromGitHub }: +{ + lib, + htop, + fetchFromGitHub, +}: htop.overrideAttrs (oldAttrs: rec { pname = "htop-vim"; diff --git a/pkgs/tools/system/hw-probe/default.nix b/pkgs/tools/system/hw-probe/default.nix index 8b190087ffd575..0f032aa138a697 100644 --- a/pkgs/tools/system/hw-probe/default.nix +++ b/pkgs/tools/system/hw-probe/default.nix @@ -1,59 +1,60 @@ -{ lib -, stdenv -, fetchFromGitHub -, makeWrapper -, makePerlPath +{ + lib, + stdenv, + fetchFromGitHub, + makeWrapper, + makePerlPath, -# Perl libraries -, LWP -, LWPProtocolHttps -, HTTPMessage -, HTTPDate -, URI -, TryTiny + # Perl libraries + LWP, + LWPProtocolHttps, + HTTPMessage, + HTTPDate, + URI, + TryTiny, -# Required -, coreutils -, curl # Preferred to using the Perl HTTP libs - according to hw-probe. -, dmidecode -, edid-decode -, gnugrep -, gnutar -, hwinfo -, iproute2 -, kmod -, pciutils -, perl -, smartmontools -, usbutils -, xz + # Required + coreutils, + curl, # Preferred to using the Perl HTTP libs - according to hw-probe. + dmidecode, + edid-decode, + gnugrep, + gnutar, + hwinfo, + iproute2, + kmod, + pciutils, + perl, + smartmontools, + usbutils, + xz, -# Conditionally recommended -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd -, systemd + # Conditionally recommended + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, -# Recommended -, withRecommended ? true # Install recommended tools -, mcelog -, hdparm -, acpica-tools -, drm_info -, mesa-demos -, memtester -, sysstat -, cpuid -, util-linuxMinimal -, xinput -, libva-utils -, inxi -, vulkan-tools -, i2c-tools -, opensc + # Recommended + withRecommended ? true, # Install recommended tools + mcelog, + hdparm, + acpica-tools, + drm_info, + mesa-demos, + memtester, + sysstat, + cpuid, + util-linuxMinimal, + xinput, + libva-utils, + inxi, + vulkan-tools, + i2c-tools, + opensc, -# Suggested -, withSuggested ? false # Install (most) suggested tools -, hplip -, sane-backends + # Suggested + withSuggested ? false, # Install (most) suggested tools + hplip, + sane-backends, # , pnputils # pnputils (lspnp) isn't currently in nixpkgs and appears to be poorly maintained }: @@ -91,24 +92,25 @@ stdenv.mkDerivation rec { xz kmod # (lsmod) ]; - recommendedPrograms = [ - mcelog - hdparm - acpica-tools - drm_info - mesa-demos - memtester - sysstat # (iostat) - util-linuxMinimal # (rfkill) - xinput - libva-utils # (vainfo) - inxi - vulkan-tools - i2c-tools - opensc - ] - # cpuid is only compatible with i686 and x86_64 - ++ lib.optional (lib.elem stdenv.hostPlatform.system cpuid.meta.platforms) cpuid; + recommendedPrograms = + [ + mcelog + hdparm + acpica-tools + drm_info + mesa-demos + memtester + sysstat # (iostat) + util-linuxMinimal # (rfkill) + xinput + libva-utils # (vainfo) + inxi + vulkan-tools + i2c-tools + opensc + ] + # cpuid is only compatible with i686 and x86_64 + ++ lib.optional (lib.elem stdenv.hostPlatform.system cpuid.meta.platforms) cpuid; conditionallyRecommendedPrograms = lib.optional systemdSupport systemd; # (systemd-analyze) suggestedPrograms = [ hplip # (hp-probe) @@ -120,9 +122,22 @@ stdenv.mkDerivation rec { ++ conditionallyRecommendedPrograms ++ lib.optionals withRecommended recommendedPrograms ++ lib.optionals withSuggested suggestedPrograms; - in [ - "--set" "PERL5LIB" "${makePerlPath [ LWP LWPProtocolHttps HTTPMessage URI HTTPDate TryTiny ]}" - "--prefix" "PATH" ":" "${lib.makeBinPath programs}" + in + [ + "--set" + "PERL5LIB" + "${makePerlPath [ + LWP + LWPProtocolHttps + HTTPMessage + URI + HTTPDate + TryTiny + ]}" + "--prefix" + "PATH" + ":" + "${lib.makeBinPath programs}" ]; postInstall = '' @@ -134,8 +149,11 @@ stdenv.mkDerivation rec { description = "Probe for hardware, check operability and find drivers"; homepage = "https://github.com/linuxhw/hw-probe"; platforms = with platforms; (linux ++ freebsd ++ netbsd ++ openbsd); - license = with licenses; [ lgpl21 bsdOriginal ]; - maintainers = with maintainers; [ rehno-lindeque ]; + license = with licenses; [ + lgpl21 + bsdOriginal + ]; + maintainers = with maintainers; [ rehno-lindeque ]; mainProgram = "hw-probe"; }; } diff --git a/pkgs/tools/system/minijail/default.nix b/pkgs/tools/system/minijail/default.nix index 05129009deee2c..a9d037705515ab 100644 --- a/pkgs/tools/system/minijail/default.nix +++ b/pkgs/tools/system/minijail/default.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchFromGitiles, libcap }: +{ + stdenv, + lib, + fetchFromGitiles, + libcap, +}: stdenv.mkDerivation rec { pname = "minijail"; @@ -12,7 +17,10 @@ stdenv.mkDerivation rec { buildInputs = [ libcap ]; - makeFlags = [ "ECHO=echo" "LIBDIR=$(out)/lib" ]; + makeFlags = [ + "ECHO=echo" + "LIBDIR=$(out)/lib" + ]; postPatch = '' substituteInPlace Makefile --replace /bin/echo echo @@ -41,7 +49,10 @@ stdenv.mkDerivation rec { description = "Sandboxing library and application using Linux namespaces and capabilities"; changelog = "https://chromium.googlesource.com/chromiumos/platform/minijail/+/refs/tags/linux-v${version}"; license = licenses.bsd3; - maintainers = with maintainers; [ pcarrier qyliss ]; + maintainers = with maintainers; [ + pcarrier + qyliss + ]; platforms = platforms.linux; mainProgram = "minijail0"; }; diff --git a/pkgs/tools/system/minijail/tools.nix b/pkgs/tools/system/minijail/tools.nix index c9c52e479e78e6..54acc4a1193af9 100644 --- a/pkgs/tools/system/minijail/tools.nix +++ b/pkgs/tools/system/minijail/tools.nix @@ -1,4 +1,10 @@ -{ lib, buildPythonApplication, pkgsBuildTarget, python, minijail }: +{ + lib, + buildPythonApplication, + pkgsBuildTarget, + python, + minijail, +}: let targetClang = pkgsBuildTarget.targetPackages.clangStdenv.cc; diff --git a/pkgs/tools/system/nvidia-system-monitor-qt/default.nix b/pkgs/tools/system/nvidia-system-monitor-qt/default.nix index e4e1868997be5f..529a02ba35a662 100644 --- a/pkgs/tools/system/nvidia-system-monitor-qt/default.nix +++ b/pkgs/tools/system/nvidia-system-monitor-qt/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, cmake -, qtbase -, wrapQtAppsHook -, makeDesktopItem -, copyDesktopItems +{ + stdenv, + lib, + fetchFromGitHub, + cmake, + qtbase, + wrapQtAppsHook, + makeDesktopItem, + copyDesktopItems, }: let @@ -35,7 +36,11 @@ stdenv.mkDerivation rec { }; buildInputs = [ qtbase ]; - nativeBuildInputs = [ cmake wrapQtAppsHook copyDesktopItems ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + copyDesktopItems + ]; cmakeFlags = [ "-DIconPath=${placeholder "out"}/share/icons/hicolor/512x512/apps/qnvsm.png" diff --git a/pkgs/tools/system/osquery/default.nix b/pkgs/tools/system/osquery/default.nix index b887c6e97a2154..bf7f2e802fe124 100644 --- a/pkgs/tools/system/osquery/default.nix +++ b/pkgs/tools/system/osquery/default.nix @@ -1,20 +1,21 @@ -{ lib -, cmake -, fetchFromGitHub -, fetchzip -, fetchurl -, git -, perl -, python3 -, stdenv -, stdenvNoCC -, ninja -, nix-prefetch-git -, autoPatchelfHook -, jq -, removeReferencesTo -, nixosTests -, writers +{ + lib, + cmake, + fetchFromGitHub, + fetchzip, + fetchurl, + git, + perl, + python3, + stdenv, + stdenvNoCC, + ninja, + nix-prefetch-git, + autoPatchelfHook, + jq, + removeReferencesTo, + nixosTests, + writers, }: let @@ -23,7 +24,14 @@ let opensslSrc = fetchurl info.openssl; - toolchain = import ./toolchain-bin.nix { inherit stdenv lib fetchzip autoPatchelfHook; }; + toolchain = import ./toolchain-bin.nix { + inherit + stdenv + lib + fetchzip + autoPatchelfHook + ; + }; in @@ -79,18 +87,24 @@ stdenvNoCC.mkDerivation rec { tests = { inherit (nixosTests) osquery; }; - updateScript = writers.writePython3 - "osquery-update" - { makeWrapperArgs = "--prefix PATH : ${lib.makeBinPath [ nix-prefetch-git ]}"; } - (builtins.readFile ./update.py); + updateScript = writers.writePython3 "osquery-update" { + makeWrapperArgs = "--prefix PATH : ${lib.makeBinPath [ nix-prefetch-git ]}"; + } (builtins.readFile ./update.py); }; meta = with lib; { description = "SQL powered operating system instrumentation, monitoring, and analytics"; homepage = "https://osquery.io"; - license = with licenses; [ gpl2Only asl20 ]; + license = with licenses; [ + gpl2Only + asl20 + ]; platforms = platforms.linux; sourceProvenance = with sourceTypes; [ fromSource ]; - maintainers = with maintainers; [ znewman01 lewo squalus ]; + maintainers = with maintainers; [ + znewman01 + lewo + squalus + ]; }; } diff --git a/pkgs/tools/system/osquery/toolchain-bin.nix b/pkgs/tools/system/osquery/toolchain-bin.nix index d2fed973fe42c6..5a12e7fb3746f7 100644 --- a/pkgs/tools/system/osquery/toolchain-bin.nix +++ b/pkgs/tools/system/osquery/toolchain-bin.nix @@ -1,4 +1,9 @@ -{ stdenv, lib, fetchzip, autoPatchelfHook }: +{ + stdenv, + lib, + fetchzip, + autoPatchelfHook, +}: let version = "1.1.0"; @@ -34,9 +39,15 @@ stdenv.mkDerivation { meta = with lib; { description = "A LLVM-based toolchain for Linux designed to build a portable osquery"; homepage = "https://github.com/osquery/osquery-toolchain"; - platforms = [ "x86_64-linux" "aarch64-linux" ]; + platforms = [ + "x86_64-linux" + "aarch64-linux" + ]; sourceProvenance = with sourceTypes; [ binaryNativeCode ]; - license = with licenses; [ gpl2Only asl20 ]; + license = with licenses; [ + gpl2Only + asl20 + ]; maintainers = with maintainers; [ squalus ]; }; } diff --git a/pkgs/tools/system/pciutils/default.nix b/pkgs/tools/system/pciutils/default.nix index e556d8e7bdb603..345afacf0016b9 100644 --- a/pkgs/tools/system/pciutils/default.nix +++ b/pkgs/tools/system/pciutils/default.nix @@ -1,8 +1,15 @@ -{ lib, stdenv, fetchFromGitHub, pkg-config, zlib, kmod, which -, hwdata -, static ? stdenv.hostPlatform.isStatic -, IOKit -, gitUpdater +{ + lib, + stdenv, + fetchFromGitHub, + pkg-config, + zlib, + kmod, + which, + hwdata, + static ? stdenv.hostPlatform.isStatic, + IOKit, + gitUpdater, }: stdenv.mkDerivation rec { @@ -17,7 +24,11 @@ stdenv.mkDerivation rec { }; nativeBuildInputs = [ pkg-config ]; - buildInputs = [ which zlib ] + buildInputs = + [ + which + zlib + ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ IOKit ] ++ lib.optionals stdenv.hostPlatform.isLinux [ kmod ]; @@ -36,7 +47,10 @@ stdenv.mkDerivation rec { "DNS=yes" ]; - installTargets = [ "install" "install-lib" ]; + installTargets = [ + "install" + "install-lib" + ]; postInstall = '' # Remove update-pciids as it won't work on nixos diff --git a/pkgs/tools/system/pdisk/default.nix b/pkgs/tools/system/pdisk/default.nix index de0e0b890e7274..43e2ef61d70d12 100644 --- a/pkgs/tools/system/pdisk/default.nix +++ b/pkgs/tools/system/pdisk/default.nix @@ -1,11 +1,12 @@ -{ stdenv -, lib -, fetchFromGitHub -, fetchpatch -, installShellFiles -, libbsd -, CoreFoundation -, IOKit +{ + stdenv, + lib, + fetchFromGitHub, + fetchpatch, + installShellFiles, + libbsd, + CoreFoundation, + IOKit, }: stdenv.mkDerivation rec { @@ -42,24 +43,28 @@ stdenv.mkDerivation rec { }) ]; - postPatch = '' - substituteInPlace makefile \ - --replace 'cc' '${stdenv.cc.targetPrefix}cc' - '' + lib.optionalString stdenv.hostPlatform.isDarwin '' - substituteInPlace makefile \ - --replace '-lbsd' '-framework CoreFoundation -framework IOKit' - ''; + postPatch = + '' + substituteInPlace makefile \ + --replace 'cc' '${stdenv.cc.targetPrefix}cc' + '' + + lib.optionalString stdenv.hostPlatform.isDarwin '' + substituteInPlace makefile \ + --replace '-lbsd' '-framework CoreFoundation -framework IOKit' + ''; nativeBuildInputs = [ installShellFiles ]; - buildInputs = lib.optionals (!stdenv.hostPlatform.isDarwin) [ - libbsd - ] ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ - CoreFoundation - IOKit - ]; + buildInputs = + lib.optionals (!stdenv.hostPlatform.isDarwin) [ + libbsd + ] + ++ lib.optionals (stdenv.hostPlatform.isDarwin) [ + CoreFoundation + IOKit + ]; env.NIX_CFLAGS_COMPILE = "-D_GNU_SOURCE"; diff --git a/pkgs/tools/system/plan9port/default.nix b/pkgs/tools/system/plan9port/default.nix index ebad0fda64ad74..8c5204bdba93ec 100644 --- a/pkgs/tools/system/plan9port/default.nix +++ b/pkgs/tools/system/plan9port/default.nix @@ -1,8 +1,22 @@ -{ lib, stdenv, fetchFromGitHub -, fontconfig, freetype, libX11, libXext, libXt, xorgproto -, perl # For building web manuals -, which, ed -, Carbon, Cocoa, IOKit, Metal, QuartzCore, DarwinTools # For building on Darwin +{ + lib, + stdenv, + fetchFromGitHub, + fontconfig, + freetype, + libX11, + libXext, + libXt, + xorgproto, + perl, # For building web manuals + which, + ed, + Carbon, + Cocoa, + IOKit, + Metal, + QuartzCore, + DarwinTools, # For building on Darwin }: stdenv.mkDerivation rec { @@ -35,13 +49,31 @@ stdenv.mkDerivation rec { ''; nativeBuildInputs = [ ed ]; - buildInputs = [ perl which ] ++ (if !stdenv.hostPlatform.isDarwin then [ - fontconfig freetype # fontsrv uses these - libX11 libXext libXt xorgproto - ] else [ - Carbon Cocoa IOKit Metal QuartzCore - DarwinTools - ]); + buildInputs = + [ + perl + which + ] + ++ ( + if !stdenv.hostPlatform.isDarwin then + [ + fontconfig + freetype # fontsrv uses these + libX11 + libXext + libXt + xorgproto + ] + else + [ + Carbon + Cocoa + IOKit + Metal + QuartzCore + DarwinTools + ] + ); configurePhase = '' runHook preConfigure @@ -113,7 +145,11 @@ stdenv.mkDerivation rec { ''; license = licenses.mit; maintainers = with maintainers; [ - bbarker ehmry ftrvxmtrx kovirobi ylh + bbarker + ehmry + ftrvxmtrx + kovirobi + ylh ]; mainProgram = "9"; platforms = platforms.unix; diff --git a/pkgs/tools/system/procodile/default.nix b/pkgs/tools/system/procodile/default.nix index 3c4437ea09c478..43faa0af6e590c 100644 --- a/pkgs/tools/system/procodile/default.nix +++ b/pkgs/tools/system/procodile/default.nix @@ -1,4 +1,8 @@ -{ lib, bundlerApp, bundlerUpdateScript }: +{ + lib, + bundlerApp, + bundlerUpdateScript, +}: bundlerApp { pname = "procodile"; @@ -9,10 +13,13 @@ bundlerApp { meta = with lib; { description = "Run processes in the background (and foreground) on Mac & Linux from a Procfile (for production and/or development environments)"; - homepage = "https://adam.ac/procodile"; - license = with licenses; mit; - maintainers = with maintainers; [ manveru nicknovitski ]; - platforms = platforms.unix; + homepage = "https://adam.ac/procodile"; + license = with licenses; mit; + maintainers = with maintainers; [ + manveru + nicknovitski + ]; + platforms = platforms.unix; mainProgram = "procodile"; }; } diff --git a/pkgs/tools/system/procodile/gemset.nix b/pkgs/tools/system/procodile/gemset.nix index f5b73b617bb5ce..bfb2a2d6a5bcb5 100644 --- a/pkgs/tools/system/procodile/gemset.nix +++ b/pkgs/tools/system/procodile/gemset.nix @@ -1,20 +1,20 @@ { json = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0sx97bm9by389rbzv8r1f43h06xcz8vwi3h5jv074gvparql7lcx"; type = "gem"; }; version = "2.2.0"; }; procodile = { - dependencies = ["json"]; - groups = ["default"]; - platforms = []; + dependencies = [ "json" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "025pbr1kah7cgs527n5q56m5agaa2smzac4rpmpk619xg4r1rdhs"; type = "gem"; }; diff --git a/pkgs/tools/system/rsyslog/default.nix b/pkgs/tools/system/rsyslog/default.nix index 2cd4eb2b4f4d5e..3a4b1348e96547 100644 --- a/pkgs/tools/system/rsyslog/default.nix +++ b/pkgs/tools/system/rsyslog/default.nix @@ -1,62 +1,63 @@ -{ lib -, stdenv -, fetchurl -, pkg-config -, autoreconfHook -, libestr -, json_c -, zlib -, docutils -, fastJson -, withKrb5 ? true -, libkrb5 -, withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd -, systemd -, withJemalloc ? true -, jemalloc -, withMysql ? true -, libmysqlclient -, withPostgres ? true -, postgresql -, withDbi ? true -, libdbi -, withNetSnmp ? true -, net-snmp -, withUuid ? true -, libuuid -, withCurl ? true -, curl -, withGnutls ? true -, gnutls -, withGcrypt ? true -, libgcrypt -, withLognorm ? true -, liblognorm -, withMaxminddb ? true -, libmaxminddb -, withOpenssl ? true -, openssl -, withRelp ? true -, librelp -, withKsi ? true -, libksi -, withLogging ? true -, liblogging -, withNet ? true -, libnet -, withHadoop ? true -, hadoop -, withRdkafka ? true -, rdkafka -, withMongo ? true -, mongoc -, withCzmq ? true -, czmq -, withRabbitmq ? true -, rabbitmq-c -, withHiredis ? true -, hiredis -, nixosTests +{ + lib, + stdenv, + fetchurl, + pkg-config, + autoreconfHook, + libestr, + json_c, + zlib, + docutils, + fastJson, + withKrb5 ? true, + libkrb5, + withSystemd ? lib.meta.availableOn stdenv.hostPlatform systemd, + systemd, + withJemalloc ? true, + jemalloc, + withMysql ? true, + libmysqlclient, + withPostgres ? true, + postgresql, + withDbi ? true, + libdbi, + withNetSnmp ? true, + net-snmp, + withUuid ? true, + libuuid, + withCurl ? true, + curl, + withGnutls ? true, + gnutls, + withGcrypt ? true, + libgcrypt, + withLognorm ? true, + liblognorm, + withMaxminddb ? true, + libmaxminddb, + withOpenssl ? true, + openssl, + withRelp ? true, + librelp, + withKsi ? true, + libksi, + withLogging ? true, + liblogging, + withNet ? true, + libnet, + withHadoop ? true, + hadoop, + withRdkafka ? true, + rdkafka, + withMongo ? true, + mongoc, + withCzmq ? true, + czmq, + withRabbitmq ? true, + rabbitmq-c, + withHiredis ? true, + hiredis, + nixosTests, }: stdenv.mkDerivation rec { @@ -74,35 +75,37 @@ stdenv.mkDerivation rec { docutils ]; - buildInputs = [ - fastJson - libestr - json_c - zlib - ] ++ lib.optional withKrb5 libkrb5 - ++ lib.optional withJemalloc jemalloc - ++ lib.optional withPostgres postgresql - ++ lib.optional withDbi libdbi - ++ lib.optional withNetSnmp net-snmp - ++ lib.optional withUuid libuuid - ++ lib.optional withCurl curl - ++ lib.optional withGnutls gnutls - ++ lib.optional withGcrypt libgcrypt - ++ lib.optional withLognorm liblognorm - ++ lib.optional withOpenssl openssl - ++ lib.optional withRelp librelp - ++ lib.optional withKsi libksi - ++ lib.optional withLogging liblogging - ++ lib.optional withNet libnet - ++ lib.optional withHadoop hadoop - ++ lib.optional withRdkafka rdkafka - ++ lib.optionals withMongo [ mongoc ] - ++ lib.optional withCzmq czmq - ++ lib.optional withRabbitmq rabbitmq-c - ++ lib.optional withHiredis hiredis - ++ lib.optional withMaxminddb libmaxminddb - ++ lib.optional withMysql libmysqlclient - ++ lib.optional withSystemd systemd; + buildInputs = + [ + fastJson + libestr + json_c + zlib + ] + ++ lib.optional withKrb5 libkrb5 + ++ lib.optional withJemalloc jemalloc + ++ lib.optional withPostgres postgresql + ++ lib.optional withDbi libdbi + ++ lib.optional withNetSnmp net-snmp + ++ lib.optional withUuid libuuid + ++ lib.optional withCurl curl + ++ lib.optional withGnutls gnutls + ++ lib.optional withGcrypt libgcrypt + ++ lib.optional withLognorm liblognorm + ++ lib.optional withOpenssl openssl + ++ lib.optional withRelp librelp + ++ lib.optional withKsi libksi + ++ lib.optional withLogging liblogging + ++ lib.optional withNet libnet + ++ lib.optional withHadoop hadoop + ++ lib.optional withRdkafka rdkafka + ++ lib.optionals withMongo [ mongoc ] + ++ lib.optional withCzmq czmq + ++ lib.optional withRabbitmq rabbitmq-c + ++ lib.optional withHiredis hiredis + ++ lib.optional withMaxminddb libmaxminddb + ++ lib.optional withMysql libmysqlclient + ++ lib.optional withSystemd systemd; configureFlags = [ "--sysconfdir=/etc" diff --git a/pkgs/tools/system/stacer/default.nix b/pkgs/tools/system/stacer/default.nix index 57d376bea9fe47..05303b472ac988 100644 --- a/pkgs/tools/system/stacer/default.nix +++ b/pkgs/tools/system/stacer/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchFromGitHub -, cmake -, qtcharts -, qttools -, wrapQtAppsHook +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + qtcharts, + qttools, + wrapQtAppsHook, }: stdenv.mkDerivation rec { @@ -29,7 +30,10 @@ stdenv.mkDerivation rec { qttools ]; - nativeBuildInputs = [ cmake wrapQtAppsHook ]; + nativeBuildInputs = [ + cmake + wrapQtAppsHook + ]; preConfigure = '' lrelease stacer/stacer.pro diff --git a/pkgs/tools/system/testdisk/default.nix b/pkgs/tools/system/testdisk/default.nix index 8761576d19b00e..748231da47b61f 100644 --- a/pkgs/tools/system/testdisk/default.nix +++ b/pkgs/tools/system/testdisk/default.nix @@ -1,15 +1,22 @@ -{ mkDerivation -, lib, stdenv -, fetchurl -, ncurses -, libuuid -, pkg-config -, libjpeg -, zlib -, libewf -, enableNtfs ? !stdenv.hostPlatform.isDarwin, ntfs3g ? null -, enableExtFs ? !stdenv.hostPlatform.isDarwin, e2fsprogs ? null -, enableQt ? false, qtbase ? null, qttools ? null, qwt ? null +{ + mkDerivation, + lib, + stdenv, + fetchurl, + ncurses, + libuuid, + pkg-config, + libjpeg, + zlib, + libewf, + enableNtfs ? !stdenv.hostPlatform.isDarwin, + ntfs3g ? null, + enableExtFs ? !stdenv.hostPlatform.isDarwin, + e2fsprogs ? null, + enableQt ? false, + qtbase ? null, + qttools ? null, + qwt ? null, }: assert enableNtfs -> ntfs3g != null; @@ -33,16 +40,21 @@ assert enableQt -> qwt != null; enableParallelBuilding = true; - buildInputs = [ - ncurses - libuuid - libjpeg - zlib - libewf - ] - ++ lib.optional enableNtfs ntfs3g - ++ lib.optional enableExtFs e2fsprogs - ++ lib.optionals enableQt [ qtbase qttools qwt ]; + buildInputs = + [ + ncurses + libuuid + libjpeg + zlib + libewf + ] + ++ lib.optional enableNtfs ntfs3g + ++ lib.optional enableExtFs e2fsprogs + ++ lib.optionals enableQt [ + qtbase + qttools + qwt + ]; nativeBuildInputs = [ pkg-config ]; diff --git a/pkgs/tools/system/uefitool/common.nix b/pkgs/tools/system/uefitool/common.nix index 353cec91be98c8..fa8da1a9ac8ad8 100644 --- a/pkgs/tools/system/uefitool/common.nix +++ b/pkgs/tools/system/uefitool/common.nix @@ -1,5 +1,17 @@ -{ version, sha256, installFiles }: -{ lib, mkDerivation, fetchFromGitHub, qtbase, qmake, cmake, zip }: +{ + version, + sha256, + installFiles, +}: +{ + lib, + mkDerivation, + fetchFromGitHub, + qtbase, + qmake, + cmake, + zip, +}: mkDerivation rec { passthru = { @@ -18,7 +30,11 @@ mkDerivation rec { }; buildInputs = [ qtbase ]; - nativeBuildInputs = [ qmake cmake zip ]; + nativeBuildInputs = [ + qmake + cmake + zip + ]; dontConfigure = true; buildPhase = '' diff --git a/pkgs/tools/system/uefitool/variants.nix b/pkgs/tools/system/uefitool/variants.nix index 647922046c66b6..d9a7a5622f681b 100644 --- a/pkgs/tools/system/uefitool/variants.nix +++ b/pkgs/tools/system/uefitool/variants.nix @@ -1,15 +1,24 @@ { libsForQt5 }: let - common = opts: libsForQt5.callPackage (import ./common.nix opts) {}; -in rec { + common = opts: libsForQt5.callPackage (import ./common.nix opts) { }; +in +rec { new-engine = common rec { version = "A62"; sha256 = "sha256-U89j0BV57luv1c9hoYJtisKLxFezuaGFokZ29/NJ0xg="; - installFiles = [ "build/UEFITool/UEFITool" "build/UEFIFind/UEFIFind" "build/UEFIExtract/UEFIExtract" ]; + installFiles = [ + "build/UEFITool/UEFITool" + "build/UEFIFind/UEFIFind" + "build/UEFIExtract/UEFIExtract" + ]; }; old-engine = common rec { version = "0.28.0"; sha256 = "1n2hd2dysi5bv2iyq40phh1jxc48gdwzs414vfbxvcharcwapnja"; - installFiles = [ "UEFITool" "UEFIReplace/UEFIReplace" "UEFIPatch/UEFIPatch" ]; + installFiles = [ + "UEFITool" + "UEFIReplace/UEFIReplace" + "UEFIPatch/UEFIPatch" + ]; }; } diff --git a/pkgs/tools/system/zenith/default.nix b/pkgs/tools/system/zenith/default.nix index ffb530600bd392..19f130f459c1bb 100644 --- a/pkgs/tools/system/zenith/default.nix +++ b/pkgs/tools/system/zenith/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, IOKit -, nvidiaSupport ? false -, makeWrapper +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + IOKit, + nvidiaSupport ? false, + makeWrapper, }: assert nvidiaSupport -> stdenv.hostPlatform.isLinux; @@ -44,7 +45,8 @@ rustPlatform.buildRustPackage rec { ''; meta = with lib; { - description = "Sort of like top or htop but with zoom-able charts, network, and disk usage" + description = + "Sort of like top or htop but with zoom-able charts, network, and disk usage" + lib.optionalString nvidiaSupport ", and NVIDIA GPU usage"; mainProgram = "zenith"; homepage = "https://github.com/bvaisvil/zenith"; diff --git a/pkgs/tools/text/amber/default.nix b/pkgs/tools/text/amber/default.nix index ce8243770b04ab..67deb89c3936d6 100644 --- a/pkgs/tools/text/amber/default.nix +++ b/pkgs/tools/text/amber/default.nix @@ -1,5 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform -, libiconv, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + libiconv, + Security, }: rustPlatform.buildRustPackage rec { @@ -15,7 +20,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-nBSgP30Izskq9RbhVIyqWzZgG5ZWHVdiukldw+Q0rco="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv Security ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Security + ]; meta = with lib; { description = "Code search-and-replace tool"; diff --git a/pkgs/tools/text/autocorrect/default.nix b/pkgs/tools/text/autocorrect/default.nix index 457bdf9243dc27..74bcbb19714181 100644 --- a/pkgs/tools/text/autocorrect/default.nix +++ b/pkgs/tools/text/autocorrect/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, Security, SystemConfiguration }: +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + Security, + SystemConfiguration, +}: rustPlatform.buildRustPackage rec { pname = "autocorrect"; @@ -19,10 +26,19 @@ rustPlatform.buildRustPackage rec { cp ${./Cargo.lock} Cargo.lock ''; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Security SystemConfiguration ]; - - cargoBuildFlags = [ "-p" "autocorrect-cli" ]; - cargoTestFlags = [ "-p" "autocorrect-cli" ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + ]; + + cargoBuildFlags = [ + "-p" + "autocorrect-cli" + ]; + cargoTestFlags = [ + "-p" + "autocorrect-cli" + ]; passthru.updateScript = ./update.sh; diff --git a/pkgs/tools/text/coloursum/default.nix b/pkgs/tools/text/coloursum/default.nix index 8e84a1de14bce2..b080b63b36bd3f 100644 --- a/pkgs/tools/text/coloursum/default.nix +++ b/pkgs/tools/text/coloursum/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, +}: rustPlatform.buildRustPackage rec { pname = "coloursum"; diff --git a/pkgs/tools/text/diffr/default.nix b/pkgs/tools/text/diffr/default.nix index fbdf221d1206cb..577cb46b07b554 100644 --- a/pkgs/tools/text/diffr/default.nix +++ b/pkgs/tools/text/diffr/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, +}: rustPlatform.buildRustPackage rec { pname = "diffr"; diff --git a/pkgs/tools/text/diffutils/default.nix b/pkgs/tools/text/diffutils/default.nix index 6c1bc8bf01f137..b9f960f10dcaef 100644 --- a/pkgs/tools/text/diffutils/default.nix +++ b/pkgs/tools/text/diffutils/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, updateAutotoolsGnuConfigScriptsHook, xz, coreutils ? null }: +{ + lib, + stdenv, + fetchurl, + updateAutotoolsGnuConfigScriptsHook, + xz, + coreutils ? null, +}: # Note: this package is used for bootstrapping fetchurl, and thus # cannot use fetchpatch! All mutable patches (generated by GitHub or @@ -14,18 +21,28 @@ stdenv.mkDerivation rec { hash = "sha256-kOXpPMck5OvhLt6A3xY0Bjx6hVaSaFkZv+YLVWyb0J4="; }; - outputs = [ "out" "info" ]; + outputs = [ + "out" + "info" + ]; - nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook (lib.getBin xz) ]; - /* If no explicit coreutils is given, use the one from stdenv. */ + nativeBuildInputs = [ + updateAutotoolsGnuConfigScriptsHook + (lib.getBin xz) + ]; + # If no explicit coreutils is given, use the one from stdenv. buildInputs = [ coreutils ]; # Disable stack-related gnulib tests on x86_64-darwin because they have problems running under # Rosetta 2: test-c-stack hangs, test-sigsegv-catch-stackoverflow fails. - postPatch = if (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) then '' - sed -i -E 's:test-c-stack2?\.sh::g' gnulib-tests/Makefile.in - sed -i -E 's:test-sigsegv-catch-stackoverflow[12]::g' gnulib-tests/Makefile.in - '' else null; + postPatch = + if (stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isx86_64) then + '' + sed -i -E 's:test-c-stack2?\.sh::g' gnulib-tests/Makefile.in + sed -i -E 's:test-sigsegv-catch-stackoverflow[12]::g' gnulib-tests/Makefile.in + '' + else + null; configureFlags = # "pr" need not be on the PATH as a run-time dep, so we need to tell diff --git a/pkgs/tools/text/fastmod/default.nix b/pkgs/tools/text/fastmod/default.nix index f8cc3055e90515..6e02473b52aae3 100644 --- a/pkgs/tools/text/fastmod/default.nix +++ b/pkgs/tools/text/fastmod/default.nix @@ -1,8 +1,10 @@ -{ lib, stdenv -, fetchFromGitHub -, rustPlatform -, libiconv -, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + libiconv, + Security, }: rustPlatform.buildRustPackage rec { @@ -18,7 +20,10 @@ rustPlatform.buildRustPackage rec { cargoHash = "sha256-sFrABp4oYhel+GONFsTbunq+4We2DicvF9A3FT/ZArc="; - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ libiconv Security ]; + buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ + libiconv + Security + ]; meta = with lib; { description = "Utility that makes sweeping changes to large, shared code bases"; diff --git a/pkgs/tools/text/gawk/default.nix b/pkgs/tools/text/gawk/default.nix index 977a44fae2b896..381ff6465e1946 100644 --- a/pkgs/tools/text/gawk/default.nix +++ b/pkgs/tools/text/gawk/default.nix @@ -1,18 +1,24 @@ -{ lib, stdenv, fetchurl -, removeReferencesTo -, runtimeShellPackage -, texinfo -, interactive ? false, readline -, autoreconfHook # no-pma fix +{ + lib, + stdenv, + fetchurl, + removeReferencesTo, + runtimeShellPackage, + texinfo, + interactive ? false, + readline, + autoreconfHook, # no-pma fix -/* Test suite broke on: - stdenv.hostPlatform.isCygwin # XXX: `test-dup2' segfaults on Cygwin 6.1 - || stdenv.hostPlatform.isDarwin # XXX: `locale' segfaults - || stdenv.hostPlatform.isSunOS # XXX: `_backsmalls1' fails, locale stuff? - || stdenv.hostPlatform.isFreeBSD -*/ -, doCheck ? (interactive && stdenv.hostPlatform.isLinux), glibcLocales ? null -, locale ? null + /* + Test suite broke on: + stdenv.hostPlatform.isCygwin # XXX: `test-dup2' segfaults on Cygwin 6.1 + || stdenv.hostPlatform.isDarwin # XXX: `locale' segfaults + || stdenv.hostPlatform.isSunOS # XXX: `_backsmalls1' fails, locale stuff? + || stdenv.hostPlatform.isFreeBSD + */ + doCheck ? (interactive && stdenv.hostPlatform.isLinux), + glibcLocales ? null, + locale ? null, }: assert (doCheck && stdenv.hostPlatform.isLinux) -> glibcLocales != null; @@ -33,27 +39,34 @@ stdenv.mkDerivation rec { hardeningDisable = [ "pie" ]; # When we do build separate interactive version, it makes sense to always include man. - outputs = [ "out" "info" ] - ++ lib.optional (!interactive) "man"; + outputs = [ + "out" + "info" + ] ++ lib.optional (!interactive) "man"; strictDeps = true; # no-pma fix - nativeBuildInputs = [ - autoreconfHook - texinfo - ] ++ lib.optionals interactive [ - removeReferencesTo - ] ++ lib.optionals (doCheck && stdenv.hostPlatform.isLinux) [ - glibcLocales - ]; + nativeBuildInputs = + [ + autoreconfHook + texinfo + ] + ++ lib.optionals interactive [ + removeReferencesTo + ] + ++ lib.optionals (doCheck && stdenv.hostPlatform.isLinux) [ + glibcLocales + ]; - buildInputs = lib.optionals interactive [ - runtimeShellPackage - readline - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - locale - ]; + buildInputs = + lib.optionals interactive [ + runtimeShellPackage + readline + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + locale + ]; configureFlags = [ (if interactive then "--with-readline=${readline.dev}" else "--without-readline") @@ -65,15 +78,22 @@ stdenv.mkDerivation rec { inherit doCheck; - postInstall = (if interactive then '' - remove-references-to -t "$NIX_CC" "$out"/bin/gawkbug - patchShebangs --host "$out"/bin/gawkbug - '' else '' - rm "$out"/bin/gawkbug - '') + '' - rm "$out"/bin/gawk-* - ln -s gawk.1 "''${!outputMan}"/share/man/man1/awk.1 - ''; + postInstall = + ( + if interactive then + '' + remove-references-to -t "$NIX_CC" "$out"/bin/gawkbug + patchShebangs --host "$out"/bin/gawkbug + '' + else + '' + rm "$out"/bin/gawkbug + '' + ) + + '' + rm "$out"/bin/gawk-* + ln -s gawk.1 "''${!outputMan}"/share/man/man1/awk.1 + ''; meta = { homepage = "https://www.gnu.org/software/gawk/"; diff --git a/pkgs/tools/text/gawk/gawk-with-extensions.nix b/pkgs/tools/text/gawk/gawk-with-extensions.nix index 1b82d798d3309b..c218ad739c4ab6 100644 --- a/pkgs/tools/text/gawk/gawk-with-extensions.nix +++ b/pkgs/tools/text/gawk/gawk-with-extensions.nix @@ -1,13 +1,20 @@ -{ runCommand, gawk, extensions, makeWrapper }: +{ + runCommand, + gawk, + extensions, + makeWrapper, +}: -runCommand "gawk-with-extensions" { - nativeBuildInputs = [ makeWrapper ]; - buildInputs = [ gawk ] ++ extensions; -} '' - mkdir -p $out/bin - for i in ${gawk}/bin/*; do - name="$(basename "$i")" - makeWrapper $i $out/bin/$name \ - --prefix AWKLIBPATH : "${gawk}/lib/gawk:''${AWKLIBPATH:-}" - done -'' +runCommand "gawk-with-extensions" + { + nativeBuildInputs = [ makeWrapper ]; + buildInputs = [ gawk ] ++ extensions; + } + '' + mkdir -p $out/bin + for i in ${gawk}/bin/*; do + name="$(basename "$i")" + makeWrapper $i $out/bin/$name \ + --prefix AWKLIBPATH : "${gawk}/lib/gawk:''${AWKLIBPATH:-}" + done + '' diff --git a/pkgs/tools/text/gawk/gawkextlib.nix b/pkgs/tools/text/gawk/gawkextlib.nix index eaf7799a4860eb..c567b39b07d7b8 100644 --- a/pkgs/tools/text/gawk/gawkextlib.nix +++ b/pkgs/tools/text/gawk/gawkextlib.nix @@ -1,64 +1,96 @@ -{ lib, stdenv, recurseIntoAttrs, fetchgit, pkg-config, autoreconfHook -, autoconf, automake, libiconv, libtool, texinfo, gettext, gawk, rapidjson, gd -, libharu, lmdb, gmp, glibcLocales, mpfr, more, postgresql, hiredis -, expat, tre }: +{ + lib, + stdenv, + recurseIntoAttrs, + fetchgit, + pkg-config, + autoreconfHook, + autoconf, + automake, + libiconv, + libtool, + texinfo, + gettext, + gawk, + rapidjson, + gd, + libharu, + lmdb, + gmp, + glibcLocales, + mpfr, + more, + postgresql, + hiredis, + expat, + tre, +}: let - buildExtension = lib.makeOverridable - ({ name, gawkextlib, extraBuildInputs ? [ ], doCheck ? true, patches ? [ ] }: - let is_extension = gawkextlib != null; - in stdenv.mkDerivation rec { - pname = "gawkextlib-${name}"; - version = "unstable-2022-10-20"; + buildExtension = lib.makeOverridable ( + { + name, + gawkextlib, + extraBuildInputs ? [ ], + doCheck ? true, + patches ? [ ], + }: + let + is_extension = gawkextlib != null; + in + stdenv.mkDerivation rec { + pname = "gawkextlib-${name}"; + version = "unstable-2022-10-20"; - src = fetchgit { - url = "git://git.code.sf.net/p/gawkextlib/code"; - rev = "f6c75b4ac1e0cd8d70c2f6c7a8d58b4d94cfde97"; - sha256 = "sha256-0p3CrQ3TBl7UcveZytK/9rkAzn69RRM2GwY2eCeqlkg="; - }; + src = fetchgit { + url = "git://git.code.sf.net/p/gawkextlib/code"; + rev = "f6c75b4ac1e0cd8d70c2f6c7a8d58b4d94cfde97"; + sha256 = "sha256-0p3CrQ3TBl7UcveZytK/9rkAzn69RRM2GwY2eCeqlkg="; + }; - inherit patches; + inherit patches; - postPatch = '' - cd ${name} - ''; + postPatch = '' + cd ${name} + ''; - nativeBuildInputs = [ - autoconf - automake - libtool - autoreconfHook - pkg-config - texinfo - gettext - ]; + nativeBuildInputs = [ + autoconf + automake + libtool + autoreconfHook + pkg-config + texinfo + gettext + ]; - buildInputs = [ gawk ] ++ extraBuildInputs; - propagatedBuildInputs = lib.optional is_extension gawkextlib; + buildInputs = [ gawk ] ++ extraBuildInputs; + propagatedBuildInputs = lib.optional is_extension gawkextlib; - setupHook = if is_extension then ./setup-hook.sh else null; - inherit gawk; + setupHook = if is_extension then ./setup-hook.sh else null; + inherit gawk; - inherit doCheck; - nativeCheckInputs = [ more ]; + inherit doCheck; + nativeCheckInputs = [ more ]; - meta = with lib; { - homepage = "https://sourceforge.net/projects/gawkextlib/"; - description = "Dynamically loaded extension libraries for GNU AWK"; - mainProgram = "xmlgawk"; - longDescription = '' - The gawkextlib project provides several extension libraries for - gawk (GNU AWK), as well as libgawkextlib containing some APIs that - are useful for building gawk extension libraries. These libraries - enable gawk to process XML data, interact with a PostgreSQL - database, use the GD graphics library, and perform unlimited - precision MPFR calculations. - ''; - license = licenses.gpl3Plus; - platforms = platforms.unix; - maintainers = with maintainers; [ tomberek ]; - }; - }); + meta = with lib; { + homepage = "https://sourceforge.net/projects/gawkextlib/"; + description = "Dynamically loaded extension libraries for GNU AWK"; + mainProgram = "xmlgawk"; + longDescription = '' + The gawkextlib project provides several extension libraries for + gawk (GNU AWK), as well as libgawkextlib containing some APIs that + are useful for building gawk extension libraries. These libraries + enable gawk to process XML data, interact with a PostgreSQL + database, use the GD graphics library, and perform unlimited + precision MPFR calculations. + ''; + license = licenses.gpl3Plus; + platforms = platforms.unix; + maintainers = with maintainers; [ tomberek ]; + }; + } + ); gawkextlib = buildExtension { gawkextlib = null; name = "lib"; @@ -121,7 +153,10 @@ let mpfr = buildExtension { inherit gawkextlib; name = "mpfr"; - extraBuildInputs = [ gmp mpfr ]; + extraBuildInputs = [ + gmp + mpfr + ]; }; nl_langinfo = buildExtension { inherit gawkextlib; @@ -148,10 +183,17 @@ let xml = buildExtension { inherit gawkextlib; name = "xml"; - extraBuildInputs = [ expat libiconv ]; + extraBuildInputs = [ + expat + libiconv + ]; }; }; -in recurseIntoAttrs (libs // { - inherit gawkextlib buildExtension; - full = builtins.attrValues libs; -}) +in +recurseIntoAttrs ( + libs + // { + inherit gawkextlib buildExtension; + full = builtins.attrValues libs; + } +) diff --git a/pkgs/tools/text/glogg/default.nix b/pkgs/tools/text/glogg/default.nix index 04aac6b0b87109..e3ac44ff4dbd6f 100644 --- a/pkgs/tools/text/glogg/default.nix +++ b/pkgs/tools/text/glogg/default.nix @@ -1,4 +1,11 @@ -{ mkDerivation, lib, stdenv, fetchFromGitHub, qmake, boost }: +{ + mkDerivation, + lib, + stdenv, + fetchFromGitHub, + qmake, + boost, +}: mkDerivation rec { pname = "glogg"; diff --git a/pkgs/tools/text/gnupatch/default.nix b/pkgs/tools/text/gnupatch/default.nix index fee1a0eed8c67f..5d5e7adca30d14 100644 --- a/pkgs/tools/text/gnupatch/default.nix +++ b/pkgs/tools/text/gnupatch/default.nix @@ -1,5 +1,9 @@ -{ lib, stdenv, fetchurl -, ed, autoreconfHook +{ + lib, + stdenv, + fetchurl, + ed, + autoreconfHook, }: stdenv.mkDerivation rec { @@ -41,7 +45,7 @@ stdenv.mkDerivation rec { ]; doCheck = stdenv.hostPlatform.libc != "musl"; # not cross; - nativeCheckInputs = [ed]; + nativeCheckInputs = [ ed ]; meta = { description = "GNU Patch, a program to apply differences to files"; diff --git a/pkgs/tools/text/gnused/default.nix b/pkgs/tools/text/gnused/default.nix index bc736f418725b8..14465e3fb4f2f4 100644 --- a/pkgs/tools/text/gnused/default.nix +++ b/pkgs/tools/text/gnused/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, updateAutotoolsGnuConfigScriptsHook, perl }: +{ + lib, + stdenv, + fetchurl, + updateAutotoolsGnuConfigScriptsHook, + perl, +}: stdenv.mkDerivation rec { pname = "gnused"; @@ -9,9 +15,15 @@ stdenv.mkDerivation rec { sha256 = "sha256-biJrcy4c1zlGStaGK9Ghq6QteYKSLaelNRljHSSXUYE="; }; - outputs = [ "out" "info" ]; + outputs = [ + "out" + "info" + ]; - nativeBuildInputs = [ updateAutotoolsGnuConfigScriptsHook perl ]; + nativeBuildInputs = [ + updateAutotoolsGnuConfigScriptsHook + perl + ]; preConfigure = "patchShebangs ./build-aux/help2man"; # Prevents attempts of running 'help2man' on cross-built binaries. diff --git a/pkgs/tools/text/gpt2tc/default.nix b/pkgs/tools/text/gpt2tc/default.nix index ee78451aae8d42..96fc570d1318a2 100644 --- a/pkgs/tools/text/gpt2tc/default.nix +++ b/pkgs/tools/text/gpt2tc/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchurl, autoPatchelfHook, python3 }: +{ + lib, + stdenv, + fetchurl, + autoPatchelfHook, + python3, +}: stdenv.mkDerivation rec { pname = "gpt2tc"; @@ -18,7 +24,12 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ autoPatchelfHook ]; buildInputs = [ - (python3.withPackages (p: with p; [ numpy tensorflow ])) + (python3.withPackages ( + p: with p; [ + numpy + tensorflow + ] + )) ]; installPhase = '' diff --git a/pkgs/tools/text/highlight/default.nix b/pkgs/tools/text/highlight/default.nix index c843d6c0b5290e..6f611973718495 100644 --- a/pkgs/tools/text/highlight/default.nix +++ b/pkgs/tools/text/highlight/default.nix @@ -1,4 +1,16 @@ -{ lib, stdenv, fetchFromGitLab, getopt, lua, boost, libxcrypt, pkg-config, swig, perl, gcc }: +{ + lib, + stdenv, + fetchFromGitLab, + getopt, + lua, + boost, + libxcrypt, + pkg-config, + swig, + perl, + gcc, +}: let self = stdenv.mkDerivation rec { @@ -14,20 +26,30 @@ let enableParallelBuilding = true; - nativeBuildInputs = [ pkg-config swig perl ] - ++ lib.optional stdenv.hostPlatform.isDarwin gcc; + nativeBuildInputs = [ + pkg-config + swig + perl + ] ++ lib.optional stdenv.hostPlatform.isDarwin gcc; - buildInputs = [ getopt lua boost libxcrypt ]; + buildInputs = [ + getopt + lua + boost + libxcrypt + ]; - postPatch = '' - substituteInPlace src/makefile \ - --replace "shell pkg-config" "shell $PKG_CONFIG" - substituteInPlace makefile \ - --replace 'gzip' 'gzip -n' - '' + lib.optionalString stdenv.cc.isClang '' - substituteInPlace src/makefile \ - --replace 'CXX=g++' 'CXX=clang++' - ''; + postPatch = + '' + substituteInPlace src/makefile \ + --replace "shell pkg-config" "shell $PKG_CONFIG" + substituteInPlace makefile \ + --replace 'gzip' 'gzip -n' + '' + + lib.optionalString stdenv.cc.isClang '' + substituteInPlace src/makefile \ + --replace 'CXX=g++' 'CXX=clang++' + ''; preConfigure = '' makeFlags="PREFIX=$out conf_dir=$out/etc/highlight/ CXX=$CXX AR=$AR" @@ -59,5 +81,4 @@ let }; in - if stdenv.hostPlatform.isDarwin then self - else perl.pkgs.toPerlModule self +if stdenv.hostPlatform.isDarwin then self else perl.pkgs.toPerlModule self diff --git a/pkgs/tools/text/igrep/default.nix b/pkgs/tools/text/igrep/default.nix index a4c4a134c4b652..739b284d37343a 100644 --- a/pkgs/tools/text/igrep/default.nix +++ b/pkgs/tools/text/igrep/default.nix @@ -1,10 +1,11 @@ -{ lib -, rustPlatform -, fetchFromGitHub -, stdenv -, Security -, testers -, igrep +{ + lib, + rustPlatform, + fetchFromGitHub, + stdenv, + Security, + testers, + igrep, }: rustPlatform.buildRustPackage rec { @@ -23,7 +24,10 @@ rustPlatform.buildRustPackage rec { buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; passthru.tests = { - version = testers.testVersion { package = igrep; command = "ig --version"; }; + version = testers.testVersion { + package = igrep; + command = "ig --version"; + }; }; meta = with lib; { diff --git a/pkgs/tools/text/kdiff3/default.nix b/pkgs/tools/text/kdiff3/default.nix index f296460e96eb75..aeb8b5f9c32d49 100644 --- a/pkgs/tools/text/kdiff3/default.nix +++ b/pkgs/tools/text/kdiff3/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchurl -, extra-cmake-modules -, kdoctools -, wrapQtAppsHook -, boost -, kcrash -, kconfig -, kinit -, kparts -, kiconthemes +{ + stdenv, + lib, + fetchurl, + extra-cmake-modules, + kdoctools, + wrapQtAppsHook, + boost, + kcrash, + kconfig, + kinit, + kparts, + kiconthemes, }: stdenv.mkDerivation (finalAttrs: { @@ -21,9 +22,20 @@ stdenv.mkDerivation (finalAttrs: { hash = "sha256-Qg8Ys7lolpigXhAvikFxkEkHTaaPlslL4Y0bgpfutUU="; }; - nativeBuildInputs = [ extra-cmake-modules kdoctools wrapQtAppsHook ]; + nativeBuildInputs = [ + extra-cmake-modules + kdoctools + wrapQtAppsHook + ]; - buildInputs = [ boost kconfig kcrash kinit kparts kiconthemes ]; + buildInputs = [ + boost + kconfig + kcrash + kinit + kparts + kiconthemes + ]; cmakeFlags = [ "-Wno-dev" ]; diff --git a/pkgs/tools/text/languagetool-rust/default.nix b/pkgs/tools/text/languagetool-rust/default.nix index 15b0ccb4661104..5cca7a529beb08 100644 --- a/pkgs/tools/text/languagetool-rust/default.nix +++ b/pkgs/tools/text/languagetool-rust/default.nix @@ -1,11 +1,12 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, installShellFiles -, pkg-config -, openssl -, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + installShellFiles, + pkg-config, + openssl, + Security, }: rustPlatform.buildRustPackage rec { @@ -23,7 +24,10 @@ rustPlatform.buildRustPackage rec { buildFeatures = [ "full" ]; - nativeBuildInputs = [ installShellFiles pkg-config ]; + nativeBuildInputs = [ + installShellFiles + pkg-config + ]; buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security ]; checkFlags = [ diff --git a/pkgs/tools/text/mdbook-admonish/default.nix b/pkgs/tools/text/mdbook-admonish/default.nix index da29d25dcb332a..fcd17249109857 100644 --- a/pkgs/tools/text/mdbook-admonish/default.nix +++ b/pkgs/tools/text/mdbook-admonish/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, CoreServices }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + CoreServices, +}: rustPlatform.buildRustPackage rec { pname = "mdbook-admonish"; @@ -19,7 +25,11 @@ rustPlatform.buildRustPackage rec { description = "Preprocessor for mdbook to add Material Design admonishments"; mainProgram = "mdbook-admonish"; license = licenses.mit; - maintainers = with maintainers; [ jmgilman Frostman matthiasbeyer ]; + maintainers = with maintainers; [ + jmgilman + Frostman + matthiasbeyer + ]; homepage = "https://github.com/tommilligan/mdbook-admonish"; }; } diff --git a/pkgs/tools/text/mdbook-epub/default.nix b/pkgs/tools/text/mdbook-epub/default.nix index d9418f67b14513..ca662eaefcb7cc 100644 --- a/pkgs/tools/text/mdbook-epub/default.nix +++ b/pkgs/tools/text/mdbook-epub/default.nix @@ -1,16 +1,18 @@ -{ lib -, stdenv -, rustPlatform -, fetchFromGitHub -, pkg-config -, bzip2 -, CoreServices +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + pkg-config, + bzip2, + CoreServices, }: let pname = "mdbook-epub"; version = "0.4.37"; -in rustPlatform.buildRustPackage { +in +rustPlatform.buildRustPackage { inherit pname version; src = fetchFromGitHub { @@ -26,17 +28,22 @@ in rustPlatform.buildRustPackage { pkg-config ]; - buildInputs = [ - bzip2 - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreServices - ]; + buildInputs = + [ + bzip2 + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + ]; meta = with lib; { description = "mdbook backend for generating an e-book in the EPUB format"; mainProgram = "mdbook-epub"; homepage = "https://michael-f-bryan.github.io/mdbook-epub"; license = licenses.mpl20; - maintainers = with maintainers; [ yuu matthiasbeyer ]; + maintainers = with maintainers; [ + yuu + matthiasbeyer + ]; }; } diff --git a/pkgs/tools/text/mdbook-footnote/default.nix b/pkgs/tools/text/mdbook-footnote/default.nix index 791cb07d02bec1..ea66ed24a3be79 100644 --- a/pkgs/tools/text/mdbook-footnote/default.nix +++ b/pkgs/tools/text/mdbook-footnote/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, CoreServices +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + CoreServices, }: rustPlatform.buildRustPackage rec { pname = "mdbook-footnote"; @@ -24,6 +25,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "mdbook-footnote"; homepage = "https://github.com/daviddrysdale/mdbook-footnote"; license = licenses.asl20; - maintainers = with maintainers; [ brianmcgillion matthiasbeyer ]; + maintainers = with maintainers; [ + brianmcgillion + matthiasbeyer + ]; }; } diff --git a/pkgs/tools/text/mdbook-graphviz/default.nix b/pkgs/tools/text/mdbook-graphviz/default.nix index 9328cba50f6c22..5cc71d2871ae41 100644 --- a/pkgs/tools/text/mdbook-graphviz/default.nix +++ b/pkgs/tools/text/mdbook-graphviz/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, CoreServices, graphviz }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + CoreServices, + graphviz, +}: rustPlatform.buildRustPackage rec { pname = "mdbook-graphviz"; @@ -23,6 +30,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/dylanowen/mdbook-graphviz"; changelog = "https://github.com/dylanowen/mdbook-graphviz/releases/tag/v${version}"; license = [ licenses.mpl20 ]; - maintainers = with maintainers; [ lovesegfault matthiasbeyer ]; + maintainers = with maintainers; [ + lovesegfault + matthiasbeyer + ]; }; } diff --git a/pkgs/tools/text/mdbook-katex/default.nix b/pkgs/tools/text/mdbook-katex/default.nix index 309c591c088289..bf3c4a643b7c5a 100644 --- a/pkgs/tools/text/mdbook-katex/default.nix +++ b/pkgs/tools/text/mdbook-katex/default.nix @@ -1,4 +1,10 @@ -{ lib, rustPlatform, fetchCrate, stdenv, CoreServices }: +{ + lib, + rustPlatform, + fetchCrate, + stdenv, + CoreServices, +}: rustPlatform.buildRustPackage rec { pname = "mdbook-katex"; @@ -18,6 +24,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "mdbook-katex"; homepage = "https://github.com/lzanini/${pname}"; license = [ licenses.mit ]; - maintainers = with maintainers; [ lovesegfault matthiasbeyer ]; + maintainers = with maintainers; [ + lovesegfault + matthiasbeyer + ]; }; } diff --git a/pkgs/tools/text/mdbook-linkcheck/default.nix b/pkgs/tools/text/mdbook-linkcheck/default.nix index 7ff872a9d0dec4..40dd80c93bea43 100644 --- a/pkgs/tools/text/mdbook-linkcheck/default.nix +++ b/pkgs/tools/text/mdbook-linkcheck/default.nix @@ -1,5 +1,14 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, pkg-config, openssl, Security -, testers, mdbook-linkcheck }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + openssl, + Security, + testers, + mdbook-linkcheck, +}: rustPlatform.buildRustPackage rec { pname = "mdbook-linkcheck"; @@ -29,6 +38,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "mdbook-linkcheck"; homepage = "https://github.com/Michael-F-Bryan/mdbook-linkcheck"; license = licenses.mit; - maintainers = with maintainers; [ zhaofengli matthiasbeyer ]; + maintainers = with maintainers; [ + zhaofengli + matthiasbeyer + ]; }; } diff --git a/pkgs/tools/text/mdbook-mermaid/default.nix b/pkgs/tools/text/mdbook-mermaid/default.nix index b4e837a2082a21..097fbcf4c320bd 100644 --- a/pkgs/tools/text/mdbook-mermaid/default.nix +++ b/pkgs/tools/text/mdbook-mermaid/default.nix @@ -1,8 +1,9 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, CoreServices +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + CoreServices, }: rustPlatform.buildRustPackage rec { @@ -28,6 +29,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/badboy/mdbook-mermaid"; changelog = "https://github.com/badboy/mdbook-mermaid/blob/v${version}/CHANGELOG.md"; license = licenses.mpl20; - maintainers = with maintainers; [ xrelkd matthiasbeyer ]; + maintainers = with maintainers; [ + xrelkd + matthiasbeyer + ]; }; } diff --git a/pkgs/tools/text/mdbook-pdf/default.nix b/pkgs/tools/text/mdbook-pdf/default.nix index ab889398ceffc3..03a3823e3cb7b7 100644 --- a/pkgs/tools/text/mdbook-pdf/default.nix +++ b/pkgs/tools/text/mdbook-pdf/default.nix @@ -1,10 +1,11 @@ -{ lib -, stdenv -, fetchCrate -, rustPlatform -, pkg-config -, openssl -, CoreServices +{ + lib, + stdenv, + fetchCrate, + rustPlatform, + pkg-config, + openssl, + CoreServices, }: rustPlatform.buildRustPackage rec { @@ -22,11 +23,13 @@ rustPlatform.buildRustPackage rec { pkg-config ]; - buildInputs = [ - openssl - ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ - CoreServices - ]; + buildInputs = + [ + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + CoreServices + ]; # Stop downloading from the Internet to # generate the Chrome Devtools Protocol @@ -44,6 +47,9 @@ rustPlatform.buildRustPackage rec { homepage = "https://github.com/HollowMan6/mdbook-pdf"; changelog = "https://github.com/HollowMan6/mdbook-pdf/releases/tag/v${version}"; license = licenses.gpl3Plus; - maintainers = with maintainers; [ hollowman6 matthiasbeyer ]; + maintainers = with maintainers; [ + hollowman6 + matthiasbeyer + ]; }; } diff --git a/pkgs/tools/text/mdbook-plantuml/default.nix b/pkgs/tools/text/mdbook-plantuml/default.nix index e3665aa2f43f6d..01640999080ffe 100644 --- a/pkgs/tools/text/mdbook-plantuml/default.nix +++ b/pkgs/tools/text/mdbook-plantuml/default.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, fetchpatch -, stdenv -, rustPlatform -, pkg-config -, openssl -, CoreServices +{ + lib, + fetchFromGitHub, + fetchpatch, + stdenv, + rustPlatform, + pkg-config, + openssl, + CoreServices, }: rustPlatform.buildRustPackage rec { @@ -32,14 +33,16 @@ rustPlatform.buildRustPackage rec { nativeBuildInputs = [ pkg-config ]; - buildInputs = [ openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices ]; + buildInputs = [ openssl ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ CoreServices ]; meta = with lib; { description = "mdBook preprocessor to render PlantUML diagrams to png images in the book output directory"; mainProgram = "mdbook-plantuml"; homepage = "https://github.com/sytsereitsma/mdbook-plantuml"; license = [ licenses.mit ]; - maintainers = with maintainers; [ jcouyang matthiasbeyer ]; + maintainers = with maintainers; [ + jcouyang + matthiasbeyer + ]; }; } diff --git a/pkgs/tools/text/mdbook-toc/default.nix b/pkgs/tools/text/mdbook-toc/default.nix index 2555e03c124c4c..d56e23bf95431f 100644 --- a/pkgs/tools/text/mdbook-toc/default.nix +++ b/pkgs/tools/text/mdbook-toc/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, CoreServices }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + CoreServices, +}: rustPlatform.buildRustPackage rec { pname = "mdbook-toc"; @@ -23,4 +29,3 @@ rustPlatform.buildRustPackage rec { maintainers = with maintainers; [ matthiasbeyer ]; }; } - diff --git a/pkgs/tools/text/mdcat/default.nix b/pkgs/tools/text/mdcat/default.nix index 7b37308c24d1b2..92e1f683353e72 100644 --- a/pkgs/tools/text/mdcat/default.nix +++ b/pkgs/tools/text/mdcat/default.nix @@ -1,15 +1,16 @@ -{ lib -, curl -, stdenv -, fetchFromGitHub -, rustPlatform -, pkg-config -, asciidoctor -, openssl -, Security -, SystemConfiguration -, ansi2html -, installShellFiles +{ + lib, + curl, + stdenv, + fetchFromGitHub, + rustPlatform, + pkg-config, + asciidoctor, + openssl, + Security, + SystemConfiguration, + ansi2html, + installShellFiles, }: rustPlatform.buildRustPackage rec { @@ -23,9 +24,20 @@ rustPlatform.buildRustPackage rec { hash = "sha256-gZwTvtZ5au8i0bZIMJa/mLWZRSGbik9nHlNEHMkqpa0="; }; - nativeBuildInputs = [ pkg-config asciidoctor installShellFiles ]; - buildInputs = [ curl openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Security SystemConfiguration ]; + nativeBuildInputs = [ + pkg-config + asciidoctor + installShellFiles + ]; + buildInputs = + [ + curl + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ + Security + SystemConfiguration + ]; cargoHash = "sha256-GcJGO5WJpyVHqcoiQUN+oRybzllbGsiiq5Yjo6Q5rOw="; @@ -42,17 +54,19 @@ rustPlatform.buildRustPackage rec { "--skip iterm2_tests_render_md_samples_images_md" ]; - postInstall = '' - installManPage $releaseDir/build/mdcat-*/out/mdcat.1 - ln -sr $out/bin/{mdcat,mdless} - '' + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - for bin in mdcat mdless; do - installShellCompletion --cmd $bin \ - --bash <($out/bin/$bin --completions bash) \ - --fish <($out/bin/$bin --completions fish) \ - --zsh <($out/bin/$bin --completions zsh) - done - ''; + postInstall = + '' + installManPage $releaseDir/build/mdcat-*/out/mdcat.1 + ln -sr $out/bin/{mdcat,mdless} + '' + + lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + for bin in mdcat mdless; do + installShellCompletion --cmd $bin \ + --bash <($out/bin/$bin --completions bash) \ + --fish <($out/bin/$bin --completions fish) \ + --zsh <($out/bin/$bin --completions zsh) + done + ''; meta = with lib; { description = "cat for markdown"; diff --git a/pkgs/tools/text/mecab/default.nix b/pkgs/tools/text/mecab/default.nix index f1f9fc6503c81c..135351f6a1b032 100644 --- a/pkgs/tools/text/mecab/default.nix +++ b/pkgs/tools/text/mecab/default.nix @@ -1,22 +1,34 @@ -{ lib, stdenv, fetchurl, mecab-ipadic, libiconv }: +{ + lib, + stdenv, + fetchurl, + mecab-ipadic, + libiconv, +}: let mecab-base = import ./base.nix { inherit fetchurl libiconv; }; in -stdenv.mkDerivation (finalAttrs: ((mecab-base finalAttrs) // { - pname = "mecab"; +stdenv.mkDerivation ( + finalAttrs: + ( + (mecab-base finalAttrs) + // { + pname = "mecab"; - postInstall = '' - mkdir -p $out/lib/mecab/dic - ln -s ${mecab-ipadic} $out/lib/mecab/dic/ipadic - ''; + postInstall = '' + mkdir -p $out/lib/mecab/dic + ln -s ${mecab-ipadic} $out/lib/mecab/dic/ipadic + ''; - meta = with lib; { - description = "Japanese morphological analysis system"; - homepage = "http://taku910.github.io/mecab"; - license = licenses.bsd3; - platforms = platforms.unix; - mainProgram = "mecab"; - maintainers = with maintainers; [ auntie ]; - }; -})) + meta = with lib; { + description = "Japanese morphological analysis system"; + homepage = "http://taku910.github.io/mecab"; + license = licenses.bsd3; + platforms = platforms.unix; + mainProgram = "mecab"; + maintainers = with maintainers; [ auntie ]; + }; + } + ) +) diff --git a/pkgs/tools/text/mecab/ipadic.nix b/pkgs/tools/text/mecab/ipadic.nix index 61d23f87a8cecd..5eb1439ed0db7a 100644 --- a/pkgs/tools/text/mecab/ipadic.nix +++ b/pkgs/tools/text/mecab/ipadic.nix @@ -1,4 +1,8 @@ -{ stdenv, fetchurl, mecab-nodic }: +{ + stdenv, + fetchurl, + mecab-nodic, +}: stdenv.mkDerivation (finalAttrs: { pname = "mecab-ipadic"; diff --git a/pkgs/tools/text/mecab/nodic.nix b/pkgs/tools/text/mecab/nodic.nix index a40e2a19698d87..7dff23c6869a5a 100644 --- a/pkgs/tools/text/mecab/nodic.nix +++ b/pkgs/tools/text/mecab/nodic.nix @@ -1,8 +1,18 @@ -{ stdenv, fetchurl, libiconv }: +{ + stdenv, + fetchurl, + libiconv, +}: let mecab-base = import ./base.nix { inherit fetchurl libiconv; }; in -stdenv.mkDerivation (finalAttrs: ((mecab-base finalAttrs) // { - pname = "mecab-nodic"; -})) +stdenv.mkDerivation ( + finalAttrs: + ( + (mecab-base finalAttrs) + // { + pname = "mecab-nodic"; + } + ) +) diff --git a/pkgs/tools/text/mir-qualia/default.nix b/pkgs/tools/text/mir-qualia/default.nix index 0ded2f1757b2ab..88a688c1f0a361 100644 --- a/pkgs/tools/text/mir-qualia/default.nix +++ b/pkgs/tools/text/mir-qualia/default.nix @@ -1,4 +1,8 @@ -{ lib, pythonPackages, fetchurl }: +{ + lib, + pythonPackages, + fetchurl, +}: pythonPackages.buildPythonApplication rec { pname = "mir.qualia"; @@ -17,6 +21,6 @@ pythonPackages.buildPythonApplication rec { mainProgram = "qualia"; homepage = "https://github.com/darkfeline/mir.qualia"; license = lib.licenses.asl20; - maintainers = [ lib.maintainers.srhb ] ; + maintainers = [ lib.maintainers.srhb ]; }; } diff --git a/pkgs/tools/text/multitran/data/default.nix b/pkgs/tools/text/multitran/data/default.nix index ba25b68fd7f5e0..05f4420e8100ce 100644 --- a/pkgs/tools/text/multitran/data/default.nix +++ b/pkgs/tools/text/multitran/data/default.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl} : +{ + lib, + stdenv, + fetchurl, +}: # This package requires a locale ru_RU.cp1251 locale entry. # Waiting for a better idea, I created it modifying a store file using: @@ -10,8 +14,8 @@ stdenv.mkDerivation { version = "0.3"; src = fetchurl { - url = "mirror://sourceforge/multitran/multitran-data.tar.bz2"; - sha256 = "9c2ff5027c2fe72b0cdf056311cd7543f447feb02b455982f20d4a3966b7828c"; + url = "mirror://sourceforge/multitran/multitran-data.tar.bz2"; + sha256 = "9c2ff5027c2fe72b0cdf056311cd7543f447feb02b455982f20d4a3966b7828c"; }; patchPhase = '' diff --git a/pkgs/tools/text/multitran/libbtree/default.nix b/pkgs/tools/text/multitran/libbtree/default.nix index 99f15b8b21ed9a..c000a3c26b333f 100644 --- a/pkgs/tools/text/multitran/libbtree/default.nix +++ b/pkgs/tools/text/multitran/libbtree/default.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl} : +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libbtree"; diff --git a/pkgs/tools/text/multitran/libfacet/default.nix b/pkgs/tools/text/multitran/libfacet/default.nix index 5efb57ddff92a9..8cd5f004b4a072 100644 --- a/pkgs/tools/text/multitran/libfacet/default.nix +++ b/pkgs/tools/text/multitran/libfacet/default.nix @@ -1,4 +1,9 @@ -{ lib, stdenv, fetchurl, libmtsupport }: +{ + lib, + stdenv, + fetchurl, + libmtsupport, +}: stdenv.mkDerivation rec { pname = "libfacet"; diff --git a/pkgs/tools/text/multitran/libmtquery/default.nix b/pkgs/tools/text/multitran/libmtquery/default.nix index 5ebb45cf98b80b..ce4ede6cd78f1a 100644 --- a/pkgs/tools/text/multitran/libmtquery/default.nix +++ b/pkgs/tools/text/multitran/libmtquery/default.nix @@ -1,4 +1,12 @@ -{lib, stdenv, fetchurl, libmtsupport, libfacet, libbtree, multitrandata } : +{ + lib, + stdenv, + fetchurl, + libmtsupport, + libfacet, + libbtree, + multitrandata, +}: stdenv.mkDerivation rec { pname = "libmtquery"; @@ -9,7 +17,12 @@ stdenv.mkDerivation rec { sha256 = "e24c7c15772445f1b14871928d84dd03cf93bd88f9d2b2ed1bf0257c2cf2b15e"; }; - buildInputs = [ libmtsupport libfacet libbtree multitrandata ]; + buildInputs = [ + libmtsupport + libfacet + libbtree + multitrandata + ]; NIX_LDFLAGS = "-lbtree"; diff --git a/pkgs/tools/text/multitran/libmtsupport/default.nix b/pkgs/tools/text/multitran/libmtsupport/default.nix index adb54f170095d5..7adb17ad888b4b 100644 --- a/pkgs/tools/text/multitran/libmtsupport/default.nix +++ b/pkgs/tools/text/multitran/libmtsupport/default.nix @@ -1,4 +1,8 @@ -{lib, stdenv, fetchurl} : +{ + lib, + stdenv, + fetchurl, +}: stdenv.mkDerivation rec { pname = "libmtsupport"; diff --git a/pkgs/tools/text/multitran/mtutils/default.nix b/pkgs/tools/text/multitran/mtutils/default.nix index 658daf9ce23040..881900208c0b61 100644 --- a/pkgs/tools/text/multitran/mtutils/default.nix +++ b/pkgs/tools/text/multitran/mtutils/default.nix @@ -1,15 +1,30 @@ -{lib, stdenv, fetchurl, libmtsupport, libfacet, libbtree, libmtquery, help2man} : +{ + lib, + stdenv, + fetchurl, + libmtsupport, + libfacet, + libbtree, + libmtquery, + help2man, +}: stdenv.mkDerivation rec { pname = "mt-utils"; version = "0.0.1alpha3"; src = fetchurl { - url = "mirror://sourceforge/multitran/mt-utils-${version}.tar.bz2"; - sha256 = "e407702c90c5272882386914e1eeca5f6c5039393af9a44538536b94867b0a0e"; + url = "mirror://sourceforge/multitran/mt-utils-${version}.tar.bz2"; + sha256 = "e407702c90c5272882386914e1eeca5f6c5039393af9a44538536b94867b0a0e"; }; - buildInputs = [ libmtsupport libfacet libbtree libmtquery help2man ]; + buildInputs = [ + libmtsupport + libfacet + libbtree + libmtquery + help2man + ]; patchPhase = '' sed -i -e 's@\$(DESTDIR)/usr@'$out'@' \ diff --git a/pkgs/tools/text/nltk-data/default.nix b/pkgs/tools/text/nltk-data/default.nix index 56ec586cc39774..6a97585d4cfb8d 100644 --- a/pkgs/tools/text/nltk-data/default.nix +++ b/pkgs/tools/text/nltk-data/default.nix @@ -1,4 +1,10 @@ -{ lib, newScope, fetchFromGitHub, unzip, stdenvNoCC }: +{ + lib, + newScope, + fetchFromGitHub, + unzip, + stdenvNoCC, +}: let base = { version = "0-unstable-2024-07-29"; @@ -12,7 +18,12 @@ let maintainers = with maintainers; [ happysalada ]; }; }; - makeNltkDataPackage = {pname, location, hash}: + makeNltkDataPackage = + { + pname, + location, + hash, + }: let src = fetchFromGitHub { owner = "nltk"; @@ -22,20 +33,23 @@ let sparseCheckout = [ "packages/${location}/${pname}.zip" ]; }; in - stdenvNoCC.mkDerivation (base // { - inherit pname src; - inherit (base) version; - installPhase = '' - runHook preInstall + stdenvNoCC.mkDerivation ( + base + // { + inherit pname src; + inherit (base) version; + installPhase = '' + runHook preInstall - mkdir -p $out - unzip ${src}/packages/${location}/${pname}.zip - mkdir -p $out/${location} - cp -R ${pname}/ $out/${location} + mkdir -p $out + unzip ${src}/packages/${location}/${pname}.zip + mkdir -p $out/${location} + cp -R ${pname}/ $out/${location} - runHook postInstall - ''; - }); + runHook postInstall + ''; + } + ); in lib.makeScope newScope (self: { punkt = makeNltkDataPackage { diff --git a/pkgs/tools/text/patchutils/0.3.3.nix b/pkgs/tools/text/patchutils/0.3.3.nix index f50354199c3fff..f1aea0a847f07d 100644 --- a/pkgs/tools/text/patchutils/0.3.3.nix +++ b/pkgs/tools/text/patchutils/0.3.3.nix @@ -1,7 +1,10 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./generic.nix (args // { - version = "0.3.3"; - sha256 = "0g5df00cj4nczrmr4k791l7la0sq2wnf8rn981fsrz1f3d2yix4i"; - patches = [ ./drop-comments.patch ]; # we would get into a cycle when using fetchpatch on this one -}) +callPackage ./generic.nix ( + args + // { + version = "0.3.3"; + sha256 = "0g5df00cj4nczrmr4k791l7la0sq2wnf8rn981fsrz1f3d2yix4i"; + patches = [ ./drop-comments.patch ]; # we would get into a cycle when using fetchpatch on this one + } +) diff --git a/pkgs/tools/text/patchutils/0.4.2.nix b/pkgs/tools/text/patchutils/0.4.2.nix index d3d26c11481d63..b6815f91d74e83 100644 --- a/pkgs/tools/text/patchutils/0.4.2.nix +++ b/pkgs/tools/text/patchutils/0.4.2.nix @@ -1,9 +1,12 @@ -{ callPackage, python3, ... } @ args: +{ callPackage, python3, ... }@args: -callPackage ./generic.nix (args // { - version = "0.4.2"; - sha256 = "sha256-iHWwll/jPeYriQ9s15O+f6/kGk5VLtv2QfH+1eu/Re0="; - # for gitdiff - extraBuildInputs = [ python3 ]; - patches = [ ./Revert-Fix-grepdiff-test.patch ]; -}) +callPackage ./generic.nix ( + args + // { + version = "0.4.2"; + sha256 = "sha256-iHWwll/jPeYriQ9s15O+f6/kGk5VLtv2QfH+1eu/Re0="; + # for gitdiff + extraBuildInputs = [ python3 ]; + patches = [ ./Revert-Fix-grepdiff-test.patch ]; + } +) diff --git a/pkgs/tools/text/patchutils/default.nix b/pkgs/tools/text/patchutils/default.nix index 902773f40fa4f0..c79b1d7110c72e 100644 --- a/pkgs/tools/text/patchutils/default.nix +++ b/pkgs/tools/text/patchutils/default.nix @@ -1,6 +1,9 @@ -{ callPackage, ... } @ args: +{ callPackage, ... }@args: -callPackage ./generic.nix (args // { - version = "0.3.4"; - sha256 = "0xp8mcfyi5nmb5a2zi5ibmyshxkb1zv1dgmnyn413m7ahgdx8mfg"; -}) +callPackage ./generic.nix ( + args + // { + version = "0.3.4"; + sha256 = "0xp8mcfyi5nmb5a2zi5ibmyshxkb1zv1dgmnyn413m7ahgdx8mfg"; + } +) diff --git a/pkgs/tools/text/patchutils/generic.nix b/pkgs/tools/text/patchutils/generic.nix index d1cd4334e1196f..047b4cfd55cc2d 100644 --- a/pkgs/tools/text/patchutils/generic.nix +++ b/pkgs/tools/text/patchutils/generic.nix @@ -1,6 +1,14 @@ -{ lib, stdenv, fetchurl, perl, makeWrapper -, version, sha256, patches ? [], extraBuildInputs ? [] -, ... +{ + lib, + stdenv, + fetchurl, + perl, + makeWrapper, + version, + sha256, + patches ? [ ], + extraBuildInputs ? [ ], + ... }: stdenv.mkDerivation rec { pname = "patchutils"; @@ -27,13 +35,15 @@ stdenv.mkDerivation rec { doCheck = lib.versionAtLeast version "0.3.4"; - preCheck = '' - patchShebangs tests - chmod +x scripts/* - '' + lib.optionalString (lib.versionOlder version "0.4.2") '' - find tests -type f -name 'run-test' \ - -exec sed -i '{}' -e 's|/bin/echo|echo|g' \; - ''; + preCheck = + '' + patchShebangs tests + chmod +x scripts/* + '' + + lib.optionalString (lib.versionOlder version "0.4.2") '' + find tests -type f -name 'run-test' \ + -exec sed -i '{}' -e 's|/bin/echo|echo|g' \; + ''; meta = with lib; { description = "Tools to manipulate patch files"; diff --git a/pkgs/tools/text/pinyin-tool/default.nix b/pkgs/tools/text/pinyin-tool/default.nix index e287c2a5cc799e..54520d5d317e12 100644 --- a/pkgs/tools/text/pinyin-tool/default.nix +++ b/pkgs/tools/text/pinyin-tool/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, rustPlatform, fetchFromGitHub, Security }: +{ + stdenv, + lib, + rustPlatform, + fetchFromGitHub, + Security, +}: rustPlatform.buildRustPackage rec { pname = "pinyin-tool"; diff --git a/pkgs/tools/text/poedit/default.nix b/pkgs/tools/text/poedit/default.nix index 101a08422c18c2..8b702994a000a3 100644 --- a/pkgs/tools/text/poedit/default.nix +++ b/pkgs/tools/text/poedit/default.nix @@ -1,6 +1,26 @@ -{ lib, stdenv, fetchFromGitHub, autoconf, automake, libtool, gettext, pkg-config, wxGTK32, - boost, icu, lucenepp, asciidoc, libxslt, xmlto, gtk3, gtkspell3, pugixml, - nlohmann_json, hicolor-icon-theme, wrapGAppsHook3 }: +{ + lib, + stdenv, + fetchFromGitHub, + autoconf, + automake, + libtool, + gettext, + pkg-config, + wxGTK32, + boost, + icu, + lucenepp, + asciidoc, + libxslt, + xmlto, + gtk3, + gtkspell3, + pugixml, + nlohmann_json, + hicolor-icon-theme, + wrapGAppsHook3, +}: stdenv.mkDerivation rec { pname = "poedit"; @@ -13,10 +33,28 @@ stdenv.mkDerivation rec { hash = "sha256-SZjsJQYJCXQendzQ2Tobg+IgkWL6lFX5YnMfruPt7UA="; }; - nativeBuildInputs = [ autoconf automake asciidoc wrapGAppsHook3 - libxslt xmlto boost libtool pkg-config ]; + nativeBuildInputs = [ + autoconf + automake + asciidoc + wrapGAppsHook3 + libxslt + xmlto + boost + libtool + pkg-config + ]; - buildInputs = [ lucenepp nlohmann_json wxGTK32 icu pugixml gtk3 gtkspell3 hicolor-icon-theme ]; + buildInputs = [ + lucenepp + nlohmann_json + wxGTK32 + icu + pugixml + gtk3 + gtkspell3 + hicolor-icon-theme + ]; propagatedBuildInputs = [ gettext ]; diff --git a/pkgs/tools/text/proselint/default.nix b/pkgs/tools/text/proselint/default.nix index a7ca553c1c198b..a5bb06bc5b75a4 100644 --- a/pkgs/tools/text/proselint/default.nix +++ b/pkgs/tools/text/proselint/default.nix @@ -1,4 +1,11 @@ -{ lib, fetchurl, buildPythonApplication, click, future, six }: +{ + lib, + fetchurl, + buildPythonApplication, + click, + future, + six, +}: buildPythonApplication rec { pname = "proselint"; @@ -11,7 +18,11 @@ buildPythonApplication rec { sha256 = "7dd2b63cc2aa390877c4144fcd3c80706817e860b017f04882fbcd2ab0852a58"; }; - propagatedBuildInputs = [ click future six ]; + propagatedBuildInputs = [ + click + future + six + ]; meta = with lib; { description = "Linter for prose"; diff --git a/pkgs/tools/text/reckon/default.nix b/pkgs/tools/text/reckon/default.nix index ccaaad0c458191..7efdfe91cf6415 100644 --- a/pkgs/tools/text/reckon/default.nix +++ b/pkgs/tools/text/reckon/default.nix @@ -1,4 +1,11 @@ -{ stdenv, lib, bundlerEnv, bundlerUpdateScript, makeWrapper, file }: +{ + stdenv, + lib, + bundlerEnv, + bundlerUpdateScript, + makeWrapper, + file, +}: stdenv.mkDerivation rec { pname = "reckon"; @@ -8,19 +15,21 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ makeWrapper ]; - installPhase = let - env = bundlerEnv { - name = "${pname}-${version}-gems"; + installPhase = + let + env = bundlerEnv { + name = "${pname}-${version}-gems"; - gemdir = ./.; - }; - in '' - runHook preInstall - mkdir -p $out/bin - makeWrapper ${env}/bin/reckon $out/bin/reckon \ - --prefix PATH : ${lib.makeBinPath [ file ]} - runHook postInstall - ''; + gemdir = ./.; + }; + in + '' + runHook preInstall + mkdir -p $out/bin + makeWrapper ${env}/bin/reckon $out/bin/reckon \ + --prefix PATH : ${lib.makeBinPath [ file ]} + runHook postInstall + ''; passthru.updateScript = bundlerUpdateScript "reckon"; diff --git a/pkgs/tools/text/reckon/gemset.nix b/pkgs/tools/text/reckon/gemset.nix index 508d6da0be3e73..d8903b9adf4ef0 100644 --- a/pkgs/tools/text/reckon/gemset.nix +++ b/pkgs/tools/text/reckon/gemset.nix @@ -1,50 +1,55 @@ { chronic = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1hrdkn4g8x7dlzxwb1rfgr8kw3bp4ywg5l4y4i9c2g5cwv62yvvn"; type = "gem"; }; version = "0.10.2"; }; highline = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1f8cr014j7mdqpdb9q17fp5vb5b8n1pswqaif91s3ylg5x3pygfn"; type = "gem"; }; version = "2.1.0"; }; matrix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h2cgkpzkh3dd0flnnwfq6f3nl2b1zff9lvqz8xs853ssv5kq23i"; type = "gem"; }; version = "0.4.2"; }; rchardet = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1isj1b3ywgg2m1vdlnr41lpvpm3dbyarf1lla4dfibfmad9csfk9"; type = "gem"; }; version = "1.8.0"; }; reckon = { - dependencies = ["chronic" "highline" "matrix" "rchardet"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "chronic" + "highline" + "matrix" + "rchardet" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0188k41lvz5vnn03qw1hbi6c2i88n5p3183rb0xz9rfjcngh2ly3"; type = "gem"; }; diff --git a/pkgs/tools/text/ripgrep-all/default.nix b/pkgs/tools/text/ripgrep-all/default.nix index a44316517dc18d..96473dab41eafc 100644 --- a/pkgs/tools/text/ripgrep-all/default.nix +++ b/pkgs/tools/text/ripgrep-all/default.nix @@ -1,15 +1,16 @@ -{ stdenv -, lib -, fetchFromGitHub -, rustPlatform -, makeWrapper -, ffmpeg -, pandoc -, poppler_utils -, ripgrep -, Security -, zip -, fzf +{ + stdenv, + lib, + fetchFromGitHub, + rustPlatform, + makeWrapper, + ffmpeg, + pandoc, + poppler_utils, + ripgrep, + Security, + zip, + fzf, }: let @@ -21,7 +22,8 @@ let zip fzf ]; -in rustPlatform.buildRustPackage rec { +in +rustPlatform.buildRustPackage rec { pname = "ripgrep-all"; version = "0.10.6"; @@ -42,7 +44,10 @@ in rustPlatform.buildRustPackage rec { # override debug=true set in Cargo.toml upstream RUSTFLAGS = "-C debuginfo=none"; - nativeBuildInputs = [ makeWrapper poppler_utils ]; + nativeBuildInputs = [ + makeWrapper + poppler_utils + ]; buildInputs = lib.optional stdenv.hostPlatform.isDarwin Security; nativeCheckInputs = path; @@ -66,7 +71,10 @@ in rustPlatform.buildRustPackage rec { ''; homepage = "https://github.com/phiresky/ripgrep-all"; license = with licenses; [ agpl3Plus ]; - maintainers = with maintainers; [ zaninime ma27 ]; + maintainers = with maintainers; [ + zaninime + ma27 + ]; mainProgram = "rga"; }; } diff --git a/pkgs/tools/text/ruby-zoom/default.nix b/pkgs/tools/text/ruby-zoom/default.nix index 06e505816648e5..2364fa7fc4b413 100644 --- a/pkgs/tools/text/ruby-zoom/default.nix +++ b/pkgs/tools/text/ruby-zoom/default.nix @@ -1,4 +1,9 @@ -{ lib, bundlerEnv, ruby, bundlerUpdateScript }: +{ + lib, + bundlerEnv, + ruby, + bundlerUpdateScript, +}: bundlerEnv { pname = "ruby-zoom"; @@ -10,9 +15,12 @@ bundlerEnv { meta = with lib; { description = "Quickly open CLI search results in your favorite editor"; - homepage = "https://gitlab.com/mjwhitta/zoom"; - license = with licenses; gpl3; - maintainers = with maintainers; [ vmandela nicknovitski ]; - platforms = platforms.unix; + homepage = "https://gitlab.com/mjwhitta/zoom"; + license = with licenses; gpl3; + maintainers = with maintainers; [ + vmandela + nicknovitski + ]; + platforms = platforms.unix; }; } diff --git a/pkgs/tools/text/ruby-zoom/gemset.nix b/pkgs/tools/text/ruby-zoom/gemset.nix index 19584787d904f4..a3573c73705ca0 100644 --- a/pkgs/tools/text/ruby-zoom/gemset.nix +++ b/pkgs/tools/text/ruby-zoom/gemset.nix @@ -1,61 +1,67 @@ { djinni = { - dependencies = ["fagin"]; - groups = ["default"]; - platforms = []; + dependencies = [ "fagin" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18zk80jk70xq1bnsvzcgxb13x9fqdb5g4m02b2f6mvqm4cyw26pl"; type = "gem"; }; version = "2.2.4"; }; fagin = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0psyydh4hf2s1kz0r50aiyjf5v2pqhkbmy0gicxzaj5n17q2ga24"; type = "gem"; }; version = "1.2.1"; }; hilighter = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "03zm49g96dfpan5fhblcjxrzv7ldwan57sn0jcllkcmrqfd0zlyz"; type = "gem"; }; version = "1.2.3"; }; json_config = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0slb618n1ipn47j6dsxbfv2j9pl06dxn2i651llix09d529m7zwa"; type = "gem"; }; version = "1.1.0"; }; ruby-zoom = { - dependencies = ["djinni" "fagin" "hilighter" "json_config" "scoobydoo"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "djinni" + "fagin" + "hilighter" + "json_config" + "scoobydoo" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0iqxc0rzypsxy4wbxnvgvk98dbcsrcczq3xi9xd4wz4ggwq564l3"; type = "gem"; }; version = "5.3.0"; }; scoobydoo = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "162p75nc9x078kqcpdsrsd7kngs6jc5n4injz3kzpwf0jgbbm8n7"; type = "gem"; }; diff --git a/pkgs/tools/text/sd/default.nix b/pkgs/tools/text/sd/default.nix index d1c7e36a659350..4469739ce16250 100644 --- a/pkgs/tools/text/sd/default.nix +++ b/pkgs/tools/text/sd/default.nix @@ -1,9 +1,10 @@ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, installShellFiles -, Security +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + installShellFiles, + Security, }: rustPlatform.buildRustPackage rec { @@ -35,6 +36,9 @@ rustPlatform.buildRustPackage rec { mainProgram = "sd"; homepage = "https://github.com/chmln/sd"; license = licenses.mit; - maintainers = with maintainers; [ amar1729 Br1ght0ne ]; + maintainers = with maintainers; [ + amar1729 + Br1ght0ne + ]; }; } diff --git a/pkgs/tools/text/uniscribe/default.nix b/pkgs/tools/text/uniscribe/default.nix index 98b164a9d58d47..94b49a0b4d2390 100644 --- a/pkgs/tools/text/uniscribe/default.nix +++ b/pkgs/tools/text/uniscribe/default.nix @@ -1,4 +1,10 @@ -{ stdenv, lib, bundlerEnv, bundlerUpdateScript, makeWrapper }: +{ + stdenv, + lib, + bundlerEnv, + bundlerUpdateScript, + makeWrapper, +}: let rubyEnv = bundlerEnv { diff --git a/pkgs/tools/text/uniscribe/gemset.nix b/pkgs/tools/text/uniscribe/gemset.nix index d61123585c2ae2..cdd0cb20b08308 100644 --- a/pkgs/tools/text/uniscribe/gemset.nix +++ b/pkgs/tools/text/uniscribe/gemset.nix @@ -1,1763 +1,2356 @@ { characteristics = { - dependencies = ["unicode-categories"]; - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + dependencies = [ "unicode-categories" ]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zhgx2h89kfm1xdgfw78vyw6mgwca1nqd67hk13pfz8ffkig2ziq"; type = "gem"; }; version = "1.4.0"; }; paint = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "01fhvxdaqngldqa7r0jgnskr4iv2x2i0n3z28za8j4qszpvlcb7x"; type = "gem"; }; version = "2.2.1"; }; rationalist = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zydr81pc63m7i5f5s51ryksv3g2qya5pd42s09v9ixk3fddpxgi"; type = "gem"; }; version = "2.0.1"; }; symbolify = { - dependencies = ["characteristics"]; - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + dependencies = [ "characteristics" ]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cjalbjgw50bwna2gyjczx42nszifslijy43bmiahn4dw76jz653"; type = "gem"; }; version = "1.4.0"; }; unicode-categories = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0prakys8s56hh56q2r4gm2iigq9wk4ywwpv9ywcyi4xr9k2pliy3"; type = "gem"; }; version = "1.7.0"; }; unicode-display_width = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0csjm9shhfik0ci9mgimb7hf3xgh7nx45rkd9rzgdz6vkwr8rzxn"; type = "gem"; }; version = "2.1.0"; }; unicode-emoji = { - dependencies = ["unicode-version"]; - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + dependencies = [ "unicode-version" ]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0fvm7z6s9nipbwsq4xqqz443g3x5lwkcpg7iwqxs9x43dd9r8h77"; type = "gem"; }; version = "2.9.0"; }; unicode-name = { - dependencies = ["unicode-types"]; - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + dependencies = [ "unicode-types" ]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "18ly2yy1jbdcvxgfyn2n17c2v54n9llzvr7klbfhy285lz1ylkdd"; type = "gem"; }; version = "1.10.0"; }; unicode-sequence_name = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fm57j4yplfsdq5pyxdp7pgp5adisdh8hr1dgvr5g1x076bvis16"; type = "gem"; }; version = "1.10.0"; }; unicode-types = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qrbvx01v1x931czvrng0hvlhyb1bwa3mnq008lq5w75ldrpyiis"; type = "gem"; }; version = "1.7.0"; }; unicode-version = { - groups = ["default"]; - platforms = [{ - engine = "maglev"; - } { - engine = "maglev"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.8"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "1.9"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.0"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.1"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.2"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.3"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.4"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.5"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "maglev"; - version = "2.6"; - } { - engine = "rbx"; - } { - engine = "rbx"; - } { - engine = "rbx"; - version = "1.8"; - } { - engine = "rbx"; - version = "1.9"; - } { - engine = "rbx"; - version = "2.0"; - } { - engine = "rbx"; - version = "2.1"; - } { - engine = "rbx"; - version = "2.2"; - } { - engine = "rbx"; - version = "2.3"; - } { - engine = "rbx"; - version = "2.4"; - } { - engine = "rbx"; - version = "2.5"; - } { - engine = "rbx"; - version = "2.6"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.8"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "1.9"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.0"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.1"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.2"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.3"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.4"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.5"; - } { - engine = "ruby"; - version = "2.6"; - } { - engine = "ruby"; - version = "2.6"; - }]; + groups = [ "default" ]; + platforms = [ + { + engine = "maglev"; + } + { + engine = "maglev"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.8"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "1.9"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.0"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.1"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.2"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.3"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.4"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.5"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "maglev"; + version = "2.6"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + } + { + engine = "rbx"; + version = "1.8"; + } + { + engine = "rbx"; + version = "1.9"; + } + { + engine = "rbx"; + version = "2.0"; + } + { + engine = "rbx"; + version = "2.1"; + } + { + engine = "rbx"; + version = "2.2"; + } + { + engine = "rbx"; + version = "2.3"; + } + { + engine = "rbx"; + version = "2.4"; + } + { + engine = "rbx"; + version = "2.5"; + } + { + engine = "rbx"; + version = "2.6"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.8"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "1.9"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.0"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.1"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.2"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.3"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.4"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.5"; + } + { + engine = "ruby"; + version = "2.6"; + } + { + engine = "ruby"; + version = "2.6"; + } + ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0isqdyqix8gh2xkpy9ab7bhwwz4nc7zrv49l0kb0hqd7n3ip9zmg"; type = "gem"; }; version = "1.1.0"; }; uniscribe = { - dependencies = ["characteristics" "paint" "rationalist" "symbolify" "unicode-display_width" "unicode-emoji" "unicode-name" "unicode-sequence_name" "unicode-version"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "characteristics" + "paint" + "rationalist" + "symbolify" + "unicode-display_width" + "unicode-emoji" + "unicode-name" + "unicode-sequence_name" + "unicode-version" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0k66h24waqy51yfqkb1iish0kc3ky85h51dikzdhk6i51q2vrx7i"; type = "gem"; }; diff --git a/pkgs/tools/text/xsv/default.nix b/pkgs/tools/text/xsv/default.nix index 62b6a83d3f326f..5dcc9a862bb29d 100644 --- a/pkgs/tools/text/xsv/default.nix +++ b/pkgs/tools/text/xsv/default.nix @@ -1,4 +1,10 @@ -{ lib, stdenv, fetchFromGitHub, rustPlatform, Security }: +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + Security, +}: rustPlatform.buildRustPackage rec { pname = "xsv"; @@ -19,7 +25,10 @@ rustPlatform.buildRustPackage rec { description = "Fast CSV toolkit written in Rust"; mainProgram = "xsv"; homepage = "https://github.com/BurntSushi/xsv"; - license = with licenses; [ unlicense /* or */ mit ]; + license = with licenses; [ + unlicense # or + mit + ]; maintainers = [ maintainers.jgertm ]; }; } diff --git a/pkgs/tools/typesetting/asciidoc/default.nix b/pkgs/tools/typesetting/asciidoc/default.nix index 24e1c6bc1a304b..3f8caf570f625a 100644 --- a/pkgs/tools/typesetting/asciidoc/default.nix +++ b/pkgs/tools/typesetting/asciidoc/default.nix @@ -1,47 +1,63 @@ -{ fetchurl, lib, stdenv, python3 -, fetchFromGitHub, autoreconfHook -, installShellFiles -, enableStandardFeatures ? false -, sourceHighlight -, highlight -, pygments -, graphviz -, texliveMinimal -, dblatexFull -, libxslt -, w3m -, lynx -, imagemagick -, lilypond -, libxml2 -, docbook_xml_dtd_45 -, docbook_xsl_ns -, docbook_xsl -, fop -, epubcheck -, gnused -, coreutils - -# if true, enable all the below filters and backends -, enableExtraPlugins ? false - -# unzip is needed to extract filter and backend plugins -, unzip -# filters -, enableDitaaFilter ? false, jre -, enableMscgenFilter ? false, mscgen -, enableDiagFilter ? false, blockdiag, seqdiag, actdiag, nwdiag -, enableQrcodeFilter ? false, qrencode -, enableMatplotlibFilter ? false, matplotlib, numpy -, enableAafigureFilter ? false, aafigure, recursive-pth-loader -# backends -, enableDeckjsBackend ? false -, enableOdfBackend ? false - -# java is problematic on some platforms, where it is unfree -, enableJava ? true - -, buildPackages +{ + fetchurl, + lib, + stdenv, + python3, + fetchFromGitHub, + autoreconfHook, + installShellFiles, + enableStandardFeatures ? false, + sourceHighlight, + highlight, + pygments, + graphviz, + texliveMinimal, + dblatexFull, + libxslt, + w3m, + lynx, + imagemagick, + lilypond, + libxml2, + docbook_xml_dtd_45, + docbook_xsl_ns, + docbook_xsl, + fop, + epubcheck, + gnused, + coreutils, + + # if true, enable all the below filters and backends + enableExtraPlugins ? false, + + # unzip is needed to extract filter and backend plugins + unzip, + # filters + enableDitaaFilter ? false, + jre, + enableMscgenFilter ? false, + mscgen, + enableDiagFilter ? false, + blockdiag, + seqdiag, + actdiag, + nwdiag, + enableQrcodeFilter ? false, + qrencode, + enableMatplotlibFilter ? false, + matplotlib, + numpy, + enableAafigureFilter ? false, + aafigure, + recursive-pth-loader, + # backends + enableDeckjsBackend ? false, + enableOdfBackend ? false, + + # java is problematic on some platforms, where it is unfree + enableJava ? true, + + buildPackages, }: let @@ -86,11 +102,15 @@ let }; # there are no archives or tags, using latest commit in master branch as per 2013-09-22 - matplotlibFilterSrc = let commit = "75f0d009629f93f33fab04b83faca20cc35dd358"; in fetchurl { - name = "mplw-${commit}.tar.gz"; - url = "https://api.github.com/repos/lvv/mplw/tarball/${commit}"; - sha256 = "0yfhkm2dr8gnp0fcg25x89hwiymkri2m5cyqzmzragzwj0hbmcf1"; - }; + matplotlibFilterSrc = + let + commit = "75f0d009629f93f33fab04b83faca20cc35dd358"; + in + fetchurl { + name = "mplw-${commit}.tar.gz"; + url = "https://api.github.com/repos/lvv/mplw/tarball/${commit}"; + sha256 = "0yfhkm2dr8gnp0fcg25x89hwiymkri2m5cyqzmzragzwj0hbmcf1"; + }; aafigureFilterSrc = fetchurl { url = "https://asciidoc-aafigure-filter.googlecode.com/files/aafigure-filter-1.1.zip"; @@ -117,8 +137,10 @@ let sha256 = "08ya4bskygzqkfqwjllpg31qc5k08xp2k78z9b2480g8y57bfy10"; }; -in python3.pkgs.buildPythonApplication rec { - pname = "asciidoc" +in +python3.pkgs.buildPythonApplication rec { + pname = + "asciidoc" + lib.optionalString enableStandardFeatures "-full" + lib.optionalString enableExtraPlugins "-with-plugins"; version = "10.2.1"; @@ -138,118 +160,141 @@ in python3.pkgs.buildPythonApplication rec { ]; # install filters early, so their shebangs are patched too - postPatch = '' - mkdir -p "$out/etc/asciidoc/filters" - mkdir -p "$out/etc/asciidoc/backends" - '' + lib.optionalString _enableDitaaFilter '' - echo "Extracting ditaa filter" - unzip -d "$out/etc/asciidoc/filters/ditaa" "${ditaaFilterSrc}" - sed -i -e "s|java -jar|${jre}/bin/java -jar|" \ - "$out/etc/asciidoc/filters/ditaa/ditaa2img.py" - '' + lib.optionalString _enableMscgenFilter '' - echo "Extracting mscgen filter" - unzip -d "$out/etc/asciidoc/filters/mscgen" "${mscgenFilterSrc}" - sed -i -e "s|filter-wrapper.py mscgen|filter-wrapper.py ${mscgen}/bin/mscgen|" \ - "$out/etc/asciidoc/filters/mscgen/mscgen-filter.conf" - '' + lib.optionalString _enableDiagFilter '' - echo "Extracting diag filter" - unzip -d "$out/etc/asciidoc/filters/diag" "${diagFilterSrc}" - sed -i \ - -e "s|filter='blockdiag|filter=\'${blockdiag}/bin/blockdiag|" \ - -e "s|filter='seqdiag|filter=\'${seqdiag}/bin/seqdiag|" \ - -e "s|filter='actdiag|filter=\'${actdiag}/bin/actdiag|" \ - -e "s|filter='nwdiag|filter=\'${nwdiag}/bin/nwdiag|" \ - -e "s|filter='packetdiag|filter=\'${nwdiag}/bin/packetdiag|" \ - "$out/etc/asciidoc/filters/diag/diag-filter.conf" - '' + lib.optionalString _enableQrcodeFilter '' - echo "Extracting qrcode filter" - unzip -d "$out/etc/asciidoc/filters/qrcode" "${qrcodeFilterSrc}" - sed -i -e "s|systemcmd('qrencode|systemcmd('${qrencode}/bin/qrencode|" \ - "$out/etc/asciidoc/filters/qrcode/qrcode2img.py" - '' + lib.optionalString _enableMatplotlibFilter '' - echo "Extracting mpl (matplotlib) filter" - mkdir -p "$out/etc/asciidoc/filters/mpl" - tar xvf "${matplotlibFilterSrc}" -C "$out/etc/asciidoc/filters/mpl" --strip-components=1 - # Stop asciidoc from loading mpl/.old/chart-filter.conf - rm -rf "$out/etc/asciidoc/filters/mpl/.old" - # Add matplotlib and numpy to sys.path - matplotlib_path="$(toPythonPath ${matplotlib})" - numpy_path="$(toPythonPath ${numpy})" - sed -i "/^import.*sys/asys.path.append(\"$matplotlib_path\"); sys.path.append(\"$numpy_path\");" \ - "$out/etc/asciidoc/filters/mpl/mplw.py" - '' + lib.optionalString _enableAafigureFilter '' - echo "Extracting aafigure filter" - unzip -d "$out/etc/asciidoc/filters/aafigure" "${aafigureFilterSrc}" - # Add aafigure to sys.path (and it needs recursive-pth-loader) - pth_loader_path="$(toPythonPath ${recursive-pth-loader})" - aafigure_path="$(toPythonPath ${aafigure})" - sed -i "/^import.*sys/asys.path.append(\"$pth_loader_path\"); sys.path.append(\"$aafigure_path\"); import sitecustomize" \ - "$out/etc/asciidoc/filters/aafigure/aafig2img.py" - '' + lib.optionalString _enableDeckjsBackend '' - echo "Extracting deckjs backend" - unzip -d "$out/etc/asciidoc/backends/deckjs" "${deckjsBackendSrc}" - '' + lib.optionalString _enableOdfBackend '' - echo "Extracting odf backend (odt + odp)" - unzip -d "$out/etc/asciidoc/backends/odt" "${odtBackendSrc}" - unzip -d "$out/etc/asciidoc/backends/odp" "${odpBackendSrc}" - # The odt backend has a TODO note about removing this hardcoded path, but - # the odp backend already has that fix. Copy it here until fixed upstream. - sed -i "s|'/etc/asciidoc/backends/odt/asciidoc.ott'|os.path.dirname(__file__),'asciidoc.ott'|" \ - "$out/etc/asciidoc/backends/odt/a2x-backend.py" - '' + (if enableStandardFeatures then '' - sed -e "s|dot|${graphviz}/bin/dot|g" \ - -e "s|neato|${graphviz}/bin/neato|g" \ - -e "s|twopi|${graphviz}/bin/twopi|g" \ - -e "s|circo|${graphviz}/bin/circo|g" \ - -e "s|fdp|${graphviz}/bin/fdp|g" \ - -i "asciidoc/resources/filters/graphviz/graphviz2png.py" - - sed -e "s|run('latex|run('${texlive}/bin/latex|g" \ - -e "s|cmd = 'dvipng'|cmd = '${texlive}/bin/dvipng'|g" \ - -e "s|cmd = 'dvisvgm'|cmd = '${texlive}/bin/dvisvgm'|g" \ - -i "asciidoc/resources/filters/latex/latex2img.py" - - sed -e "s|run('abc2ly|run('${lilypond}/bin/abc2ly|g" \ - -e "s|run('lilypond|run('${lilypond}/bin/lilypond|g" \ - -e "s|run('convert|run('${imagemagick.out}/bin/convert|g" \ - -i "asciidoc/resources/filters/music/music2png.py" - - sed -e 's|filter="source-highlight|filter="${sourceHighlight}/bin/source-highlight|' \ - -e 's|filter="highlight|filter="${highlight}/bin/highlight|' \ - -e 's|filter="pygmentize|filter="${pygments}/bin/pygmentize|' \ - -i "asciidoc/resources/filters/source/source-highlight-filter.conf" - - # ENV is custom environment passed to programs that a2x invokes. Here we - # use it to work around an impurity in the tetex package; tetex tools - # cannot find their neighbours (e.g. pdflatex doesn't find mktextfm). - # We can remove PATH= when those impurities are fixed. - # TODO: Is this still necessary when using texlive? - sed -e "s|^ENV =.*|ENV = dict(XML_CATALOG_FILES='${docbook_xml_dtd_45}/xml/dtd/docbook/catalog.xml ${docbook_xsl_ns}/xml/xsl/docbook/catalog.xml ${docbook_xsl}/xml/xsl/docbook/catalog.xml', PATH='${lib.makeBinPath [ texlive coreutils gnused ]}', **(dict(filter(lambda v: v[0] == 'SOURCE_DATE_EPOCH', os.environ.items()))))|" \ - -e "s|^ASCIIDOC =.*|ASCIIDOC = '$out/bin/asciidoc'|" \ - -e "s|^XSLTPROC =.*|XSLTPROC = '${libxslt.bin}/bin/xsltproc'|" \ - -e "s|^DBLATEX =.*|DBLATEX = '${dblatexFull}/bin/dblatex'|" \ - ${lib.optionalString enableJava ''-e "s|^FOP =.*|FOP = '${fop}/bin/fop'|"''} \ - -e "s|^W3M =.*|W3M = '${w3m}/bin/w3m'|" \ - -e "s|^LYNX =.*|LYNX = '${lynx}/bin/lynx'|" \ - -e "s|^XMLLINT =.*|XMLLINT = '${libxml2.bin}/bin/xmllint'|" \ - -e "s|^EPUBCHECK =.*|EPUBCHECK = '${epubcheck}/bin/epubcheck'|" \ - -i asciidoc/a2x.py - '' else '' - sed -e "s|^ENV =.*|ENV = dict(XML_CATALOG_FILES='${docbook_xml_dtd_45}/xml/dtd/docbook/catalog.xml ${docbook_xsl_ns}/xml/xsl/docbook/catalog.xml ${docbook_xsl}/xml/xsl/docbook/catalog.xml', **(dict(filter(lambda v: v[0] == 'SOURCE_DATE_EPOCH', os.environ.items()))))|" \ - -e "s|^XSLTPROC =.*|XSLTPROC = '${libxslt.bin}/bin/xsltproc'|" \ - -e "s|^XMLLINT =.*|XMLLINT = '${libxml2.bin}/bin/xmllint'|" \ - -i asciidoc/a2x.py - '') + '' - # Fix tests - for f in $(grep -R --files-with-matches "2002-11-25") ; do - substituteInPlace $f --replace "2002-11-25" "1980-01-02" - substituteInPlace $f --replace "00:37:42" "00:00:00" - done - '' + lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' - # We want to use asciidoc from the build platform to build the documentation. - substituteInPlace Makefile.in \ - --replace "python3 -m asciidoc.a2x" "${buildPackages.asciidoc}/bin/a2x" - ''; + postPatch = + '' + mkdir -p "$out/etc/asciidoc/filters" + mkdir -p "$out/etc/asciidoc/backends" + '' + + lib.optionalString _enableDitaaFilter '' + echo "Extracting ditaa filter" + unzip -d "$out/etc/asciidoc/filters/ditaa" "${ditaaFilterSrc}" + sed -i -e "s|java -jar|${jre}/bin/java -jar|" \ + "$out/etc/asciidoc/filters/ditaa/ditaa2img.py" + '' + + lib.optionalString _enableMscgenFilter '' + echo "Extracting mscgen filter" + unzip -d "$out/etc/asciidoc/filters/mscgen" "${mscgenFilterSrc}" + sed -i -e "s|filter-wrapper.py mscgen|filter-wrapper.py ${mscgen}/bin/mscgen|" \ + "$out/etc/asciidoc/filters/mscgen/mscgen-filter.conf" + '' + + lib.optionalString _enableDiagFilter '' + echo "Extracting diag filter" + unzip -d "$out/etc/asciidoc/filters/diag" "${diagFilterSrc}" + sed -i \ + -e "s|filter='blockdiag|filter=\'${blockdiag}/bin/blockdiag|" \ + -e "s|filter='seqdiag|filter=\'${seqdiag}/bin/seqdiag|" \ + -e "s|filter='actdiag|filter=\'${actdiag}/bin/actdiag|" \ + -e "s|filter='nwdiag|filter=\'${nwdiag}/bin/nwdiag|" \ + -e "s|filter='packetdiag|filter=\'${nwdiag}/bin/packetdiag|" \ + "$out/etc/asciidoc/filters/diag/diag-filter.conf" + '' + + lib.optionalString _enableQrcodeFilter '' + echo "Extracting qrcode filter" + unzip -d "$out/etc/asciidoc/filters/qrcode" "${qrcodeFilterSrc}" + sed -i -e "s|systemcmd('qrencode|systemcmd('${qrencode}/bin/qrencode|" \ + "$out/etc/asciidoc/filters/qrcode/qrcode2img.py" + '' + + lib.optionalString _enableMatplotlibFilter '' + echo "Extracting mpl (matplotlib) filter" + mkdir -p "$out/etc/asciidoc/filters/mpl" + tar xvf "${matplotlibFilterSrc}" -C "$out/etc/asciidoc/filters/mpl" --strip-components=1 + # Stop asciidoc from loading mpl/.old/chart-filter.conf + rm -rf "$out/etc/asciidoc/filters/mpl/.old" + # Add matplotlib and numpy to sys.path + matplotlib_path="$(toPythonPath ${matplotlib})" + numpy_path="$(toPythonPath ${numpy})" + sed -i "/^import.*sys/asys.path.append(\"$matplotlib_path\"); sys.path.append(\"$numpy_path\");" \ + "$out/etc/asciidoc/filters/mpl/mplw.py" + '' + + lib.optionalString _enableAafigureFilter '' + echo "Extracting aafigure filter" + unzip -d "$out/etc/asciidoc/filters/aafigure" "${aafigureFilterSrc}" + # Add aafigure to sys.path (and it needs recursive-pth-loader) + pth_loader_path="$(toPythonPath ${recursive-pth-loader})" + aafigure_path="$(toPythonPath ${aafigure})" + sed -i "/^import.*sys/asys.path.append(\"$pth_loader_path\"); sys.path.append(\"$aafigure_path\"); import sitecustomize" \ + "$out/etc/asciidoc/filters/aafigure/aafig2img.py" + '' + + lib.optionalString _enableDeckjsBackend '' + echo "Extracting deckjs backend" + unzip -d "$out/etc/asciidoc/backends/deckjs" "${deckjsBackendSrc}" + '' + + lib.optionalString _enableOdfBackend '' + echo "Extracting odf backend (odt + odp)" + unzip -d "$out/etc/asciidoc/backends/odt" "${odtBackendSrc}" + unzip -d "$out/etc/asciidoc/backends/odp" "${odpBackendSrc}" + # The odt backend has a TODO note about removing this hardcoded path, but + # the odp backend already has that fix. Copy it here until fixed upstream. + sed -i "s|'/etc/asciidoc/backends/odt/asciidoc.ott'|os.path.dirname(__file__),'asciidoc.ott'|" \ + "$out/etc/asciidoc/backends/odt/a2x-backend.py" + '' + + ( + if enableStandardFeatures then + '' + sed -e "s|dot|${graphviz}/bin/dot|g" \ + -e "s|neato|${graphviz}/bin/neato|g" \ + -e "s|twopi|${graphviz}/bin/twopi|g" \ + -e "s|circo|${graphviz}/bin/circo|g" \ + -e "s|fdp|${graphviz}/bin/fdp|g" \ + -i "asciidoc/resources/filters/graphviz/graphviz2png.py" + + sed -e "s|run('latex|run('${texlive}/bin/latex|g" \ + -e "s|cmd = 'dvipng'|cmd = '${texlive}/bin/dvipng'|g" \ + -e "s|cmd = 'dvisvgm'|cmd = '${texlive}/bin/dvisvgm'|g" \ + -i "asciidoc/resources/filters/latex/latex2img.py" + + sed -e "s|run('abc2ly|run('${lilypond}/bin/abc2ly|g" \ + -e "s|run('lilypond|run('${lilypond}/bin/lilypond|g" \ + -e "s|run('convert|run('${imagemagick.out}/bin/convert|g" \ + -i "asciidoc/resources/filters/music/music2png.py" + + sed -e 's|filter="source-highlight|filter="${sourceHighlight}/bin/source-highlight|' \ + -e 's|filter="highlight|filter="${highlight}/bin/highlight|' \ + -e 's|filter="pygmentize|filter="${pygments}/bin/pygmentize|' \ + -i "asciidoc/resources/filters/source/source-highlight-filter.conf" + + # ENV is custom environment passed to programs that a2x invokes. Here we + # use it to work around an impurity in the tetex package; tetex tools + # cannot find their neighbours (e.g. pdflatex doesn't find mktextfm). + # We can remove PATH= when those impurities are fixed. + # TODO: Is this still necessary when using texlive? + sed -e "s|^ENV =.*|ENV = dict(XML_CATALOG_FILES='${docbook_xml_dtd_45}/xml/dtd/docbook/catalog.xml ${docbook_xsl_ns}/xml/xsl/docbook/catalog.xml ${docbook_xsl}/xml/xsl/docbook/catalog.xml', PATH='${ + lib.makeBinPath [ + texlive + coreutils + gnused + ] + }', **(dict(filter(lambda v: v[0] == 'SOURCE_DATE_EPOCH', os.environ.items()))))|" \ + -e "s|^ASCIIDOC =.*|ASCIIDOC = '$out/bin/asciidoc'|" \ + -e "s|^XSLTPROC =.*|XSLTPROC = '${libxslt.bin}/bin/xsltproc'|" \ + -e "s|^DBLATEX =.*|DBLATEX = '${dblatexFull}/bin/dblatex'|" \ + ${lib.optionalString enableJava ''-e "s|^FOP =.*|FOP = '${fop}/bin/fop'|"''} \ + -e "s|^W3M =.*|W3M = '${w3m}/bin/w3m'|" \ + -e "s|^LYNX =.*|LYNX = '${lynx}/bin/lynx'|" \ + -e "s|^XMLLINT =.*|XMLLINT = '${libxml2.bin}/bin/xmllint'|" \ + -e "s|^EPUBCHECK =.*|EPUBCHECK = '${epubcheck}/bin/epubcheck'|" \ + -i asciidoc/a2x.py + '' + else + '' + sed -e "s|^ENV =.*|ENV = dict(XML_CATALOG_FILES='${docbook_xml_dtd_45}/xml/dtd/docbook/catalog.xml ${docbook_xsl_ns}/xml/xsl/docbook/catalog.xml ${docbook_xsl}/xml/xsl/docbook/catalog.xml', **(dict(filter(lambda v: v[0] == 'SOURCE_DATE_EPOCH', os.environ.items()))))|" \ + -e "s|^XSLTPROC =.*|XSLTPROC = '${libxslt.bin}/bin/xsltproc'|" \ + -e "s|^XMLLINT =.*|XMLLINT = '${libxml2.bin}/bin/xmllint'|" \ + -i asciidoc/a2x.py + '' + ) + + '' + # Fix tests + for f in $(grep -R --files-with-matches "2002-11-25") ; do + substituteInPlace $f --replace "2002-11-25" "1980-01-02" + substituteInPlace $f --replace "00:37:42" "00:00:00" + done + '' + + lib.optionalString (stdenv.buildPlatform != stdenv.hostPlatform) '' + # We want to use asciidoc from the build platform to build the documentation. + substituteInPlace Makefile.in \ + --replace "python3 -m asciidoc.a2x" "${buildPackages.asciidoc}/bin/a2x" + ''; build-system = with python3.pythonOnBuildForHost.pkgs; [ setuptools ]; @@ -286,12 +331,16 @@ in python3.pkgs.buildPythonApplication rec { the backend output markups (which can be almost any type of SGML/XML markup) can be customized and extended by the user. ''; - sourceProvenance = [ lib.sourceTypes.fromSource ] - ++ lib.optional _enableDitaaFilter lib.sourceTypes.binaryBytecode; + sourceProvenance = [ + lib.sourceTypes.fromSource + ] ++ lib.optional _enableDitaaFilter lib.sourceTypes.binaryBytecode; homepage = "https://asciidoc-py.github.io/"; changelog = "https://github.com/asciidoc-py/asciidoc-py/blob/${version}/CHANGELOG.adoc"; license = lib.licenses.gpl2Plus; platforms = lib.platforms.unix; - maintainers = with lib.maintainers; [ bjornfor dotlambda ]; + maintainers = with lib.maintainers; [ + bjornfor + dotlambda + ]; }; } diff --git a/pkgs/tools/typesetting/asciidoctor-with-extensions/default.nix b/pkgs/tools/typesetting/asciidoctor-with-extensions/default.nix index c236b436acf1a6..1c21d823865917 100644 --- a/pkgs/tools/typesetting/asciidoctor-with-extensions/default.nix +++ b/pkgs/tools/typesetting/asciidoctor-with-extensions/default.nix @@ -1,8 +1,10 @@ -{ lib -, bundlerApp -, bundlerUpdateScript -, makeWrapper -, withJava ? true, jre # Used by asciidoctor-diagram for ditaa and PlantUML +{ + lib, + bundlerApp, + bundlerUpdateScript, + makeWrapper, + withJava ? true, + jre, # Used by asciidoctor-diagram for ditaa and PlantUML }: let @@ -23,10 +25,12 @@ bundlerApp rec { nativeBuildInputs = [ makeWrapper ]; - postBuild = lib.optionalString (path != "") (lib.concatMapStrings (exe: '' - wrapProgram $out/bin/${exe} \ - --prefix PATH : ${path} - '') exes); + postBuild = lib.optionalString (path != "") ( + lib.concatMapStrings (exe: '' + wrapProgram $out/bin/${exe} \ + --prefix PATH : ${path} + '') exes + ); passthru = { updateScript = bundlerUpdateScript "asciidoctor-with-extensions"; diff --git a/pkgs/tools/typesetting/asciidoctor-with-extensions/gemset.nix b/pkgs/tools/typesetting/asciidoctor-with-extensions/gemset.nix index 415b5baaa89f8b..f037016838954c 100644 --- a/pkgs/tools/typesetting/asciidoctor-with-extensions/gemset.nix +++ b/pkgs/tools/typesetting/asciidoctor-with-extensions/gemset.nix @@ -1,631 +1,703 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; afm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06kj9hgd0z8pj27bxp2diwqh6fv7qhwwm17z64rhdc4sfn76jgn8"; type = "gem"; }; version = "0.2.2"; }; Ascii85 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c62cx96r0v265mywnlik43qx0wf6bjbzl54qa47x6dzjg861mvk"; type = "gem"; }; version = "1.1.1"; }; asciidoctor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wyxgwmnz9bw377r3lba26b090hbsq9qnbw8575a1prpy83qh82j"; type = "gem"; }; version = "2.0.23"; }; asciidoctor-bibtex = { - dependencies = ["asciidoctor" "bibtex-ruby" "citeproc-ruby" "csl-styles" "latex-decode"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "asciidoctor" + "bibtex-ruby" + "citeproc-ruby" + "csl-styles" + "latex-decode" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "16l7s926h6cjzy4y582sf3x32l4w10klmdnphxi7p4g6d8vhb61y"; type = "gem"; }; version = "0.9.0"; }; asciidoctor-diagram = { - dependencies = ["asciidoctor" "asciidoctor-diagram-ditaamini" "asciidoctor-diagram-plantuml" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "asciidoctor" + "asciidoctor-diagram-ditaamini" + "asciidoctor-diagram-plantuml" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1214scxm36k409gfy3wilfqx3akrm52r530zmra6cmmf6d22c5q4"; type = "gem"; }; version = "2.3.1"; }; asciidoctor-diagram-batik = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0220xqxmkmimxmhsqhlbr0hslijvnhzdds3s6h6fxbxqrrmm0jrl"; type = "gem"; }; version = "1.17"; }; asciidoctor-diagram-ditaamini = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13h65bfbq7hc7z3kqn0m28w9c6ap7fikpjcvsdga6jg01slb4c56"; type = "gem"; }; version = "1.0.3"; }; asciidoctor-diagram-plantuml = { - dependencies = ["asciidoctor-diagram-batik"]; - groups = ["default"]; - platforms = []; + dependencies = [ "asciidoctor-diagram-batik" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "173mp5vnzvn3yv9fw0p66rsbxaip9lhphw22yn19l62d1drlmhia"; type = "gem"; }; version = "1.2024.6"; }; asciidoctor-epub3 = { - dependencies = ["asciidoctor" "gepub" "mime-types" "sass"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "asciidoctor" + "gepub" + "mime-types" + "sass" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1yn2nhr7fr5rx7fn0nhw44gf7iampiy53bw59agpfl7h2dyazjll"; type = "gem"; }; version = "2.1.3"; }; asciidoctor-html5s = { - dependencies = ["asciidoctor" "thread_safe"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "asciidoctor" + "thread_safe" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1zfbfcqyrsk8bnd526ang3b4j3m5pbns7x3fdxarrm8vv1qplss1"; type = "gem"; }; version = "0.5.1"; }; asciidoctor-mathematical = { - dependencies = ["asciidoctor" "asciimath" "mathematical"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "asciidoctor" + "asciimath" + "mathematical" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1lxfq7qn3ql642pva6jh3h1abm9j9daxg5icfn1h73k6cjsmcisp"; type = "gem"; }; version = "0.3.5"; }; asciidoctor-multipage = { - dependencies = ["asciidoctor"]; - groups = ["default"]; - platforms = []; + dependencies = [ "asciidoctor" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1hjqqiibqrmx0147m8b372s57rmhixmpxgv4kwdpnkqbkqgykh7i"; type = "gem"; }; version = "0.0.19"; }; asciidoctor-pdf = { - dependencies = ["asciidoctor" "concurrent-ruby" "matrix" "prawn" "prawn-icon" "prawn-svg" "prawn-table" "prawn-templates" "treetop" "ttfunk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "asciidoctor" + "concurrent-ruby" + "matrix" + "prawn" + "prawn-icon" + "prawn-svg" + "prawn-table" + "prawn-templates" + "treetop" + "ttfunk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ybkw3xjv75xsc0wbwg76bk83sfspr50k2phshpvh9ynchli8jh3"; type = "gem"; }; version = "2.3.19"; }; asciidoctor-reducer = { - dependencies = ["asciidoctor"]; - groups = ["default"]; - platforms = []; + dependencies = [ "asciidoctor" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fbrk97mdn26zk118dav2ckyiw6kgrlbkkhdcasawsl42hj16slw"; type = "gem"; }; version = "1.0.6"; }; asciidoctor-revealjs = { - dependencies = ["asciidoctor"]; - groups = ["default"]; - platforms = []; + dependencies = [ "asciidoctor" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jgazcfzn577xlichfj0rvci0fayp63xcng11ss9mmwqgk48ri53"; type = "gem"; }; version = "5.1.0"; }; asciimath = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ny2qql3lgh7gx54psji2lm4mmbwyiwy00a17w26rjyh6cy55491"; type = "gem"; }; version = "2.0.5"; }; bibtex-ruby = { - dependencies = ["latex-decode" "racc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "latex-decode" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1ggx2j1gi46f1a6p45l1abk3nryfg1pj0cdlyrnilnqqpr1cfc96"; type = "gem"; }; version = "6.1.0"; }; citeproc = { - dependencies = ["namae"]; - groups = ["default"]; - platforms = []; + dependencies = [ "namae" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "13vl5sjmksk5a8kjcqnjxh7kn9gn1n4f9p1rvqfgsfhs54p0m6l2"; type = "gem"; }; version = "1.0.10"; }; citeproc-ruby = { - dependencies = ["citeproc" "csl"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "citeproc" + "csl" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0a8ahyhhmdinl4kcyv51r74ipnclmfyz4zjv366dns8v49n5vkk3"; type = "gem"; }; version = "1.1.14"; }; coderay = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jvxqxzply1lwp7ysn94zjhh57vc14mcshw1ygw14ib8lhc00lyw"; type = "gem"; }; version = "1.1.3"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; csl = { - dependencies = ["namae" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "namae" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0n8iqmzvvqy2b1wfr4c7yj28x4z3zgm36628y8ybl49dgnmjycrk"; type = "gem"; }; version = "1.6.0"; }; csl-styles = { - dependencies = ["csl"]; - groups = ["default"]; - platforms = []; + dependencies = [ "csl" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0l29qlk7i74088fpba5iqhhgiqkj7glcmc42nbmvgqysx577nag8"; type = "gem"; }; version = "1.0.1.11"; }; css_parser = { - dependencies = ["addressable"]; - groups = ["default"]; - platforms = []; + dependencies = [ "addressable" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17i0fn99kswvfps8r698zw2cr16rc98xdrl0d26y36rv3vhdqh0r"; type = "gem"; }; version = "1.19.1"; }; ffi = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "07139870npj59jnl8vmk39ja3gdk3fb5z9vc0lf32y2h891hwqsi"; type = "gem"; }; version = "1.17.0"; }; gepub = { - dependencies = ["nokogiri" "rubyzip"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "nokogiri" + "rubyzip" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "08fny807zd4700f263ckc76bladjipsniyk3clv8a7x76x3fqshx"; type = "gem"; }; version = "1.0.15"; }; hashery = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qj8815bf7q6q7llm5rzdz279gzmpqmqqicxnzv066a020iwqffj"; type = "gem"; }; version = "2.1.2"; }; latex-decode = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1y5xn3zwghpqr6lvs4s0mn5knms8zw3zk7jb58zkkiagb386nq72"; type = "gem"; }; version = "0.4.0"; }; logger = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0lwncq2rf8gm79g2rcnnyzs26ma1f4wnfjm6gs4zf2wlsdz5in9s"; type = "gem"; }; version = "1.6.1"; }; mathematical = { - dependencies = ["ruby-enum"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ruby-enum" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0y103dvfjswm5r0xafyjrw6ybvz1qrqfa4lvpk9gdhbzwpaiwy4r"; type = "gem"; }; version = "1.6.20"; }; matrix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h2cgkpzkh3dd0flnnwfq6f3nl2b1zff9lvqz8xs853ssv5kq23i"; type = "gem"; }; version = "0.4.2"; }; mime-types = { - dependencies = ["logger" "mime-types-data"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "logger" + "mime-types-data" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0r34mc3n7sxsbm9mzyzy8m3dvq7pwbryyc8m452axkj0g2axnwbg"; type = "gem"; }; version = "3.6.0"; }; mime-types-data = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06dbn0j13jwdrmlvrjd50mxqrjlkh3lvxp0afh4glyzbliqvqpsd"; type = "gem"; }; version = "3.2024.1001"; }; mini_portile2 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1q1f2sdw3y3y9mnym9dhjgsjr72sq975cfg5c4yx7gwv8nmzbvhk"; type = "gem"; }; version = "2.8.7"; }; namae = { - dependencies = ["racc"]; - groups = ["default"]; - platforms = []; + dependencies = [ "racc" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17fmp6p74ai2w984xayv3kz2nh44w81hqqvn4cfrim3g115wwh9m"; type = "gem"; }; version = "1.2.0"; }; nokogiri = { - dependencies = ["mini_portile2" "racc"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "mini_portile2" + "racc" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "15gysw8rassqgdq3kwgl4mhqmrgh7nk2qvrcqp4ijyqazgywn6gq"; type = "gem"; }; version = "1.16.7"; }; pdf-core = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fz0yj4zrlii2j08kaw11j769s373ayz8jrdhxwwjzmm28pqndjg"; type = "gem"; }; version = "0.9.0"; }; pdf-reader = { - dependencies = ["Ascii85" "afm" "hashery" "ruby-rc4" "ttfunk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "Ascii85" + "afm" + "hashery" + "ruby-rc4" + "ttfunk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0n0pp7blk3np3fqsb54l34fsamrww80cp3dhlhskfayg7542mrv1"; type = "gem"; }; version = "2.12.0"; }; polyglot = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bqnxwyip623d8pr29rg6m8r0hdg08fpr2yb74f46rn1wgsnxmjr"; type = "gem"; }; version = "0.3.5"; }; prawn = { - dependencies = ["pdf-core" "ttfunk"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pdf-core" + "ttfunk" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1g9avv2rprsjisdk137s9ljr05r7ajhm78hxa1vjsv0jyx22f1l2"; type = "gem"; }; version = "2.4.0"; }; prawn-icon = { - dependencies = ["prawn"]; - groups = ["default"]; - platforms = []; + dependencies = [ "prawn" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xdnjik5zinnkjavmybbh2s52wzcpb8hzaqckiv0mxp0vs0x9j6s"; type = "gem"; }; version = "3.0.0"; }; prawn-svg = { - dependencies = ["css_parser" "matrix" "prawn" "rexml"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "css_parser" + "matrix" + "prawn" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "143sfwadbdrgi57am8ikalryjijdyl82h2sdc1cns3wl6b9pkzxg"; type = "gem"; }; version = "0.34.2"; }; prawn-table = { - dependencies = ["prawn"]; - groups = ["default"]; - platforms = []; + dependencies = [ "prawn" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nxd6qmxqwl850icp18wjh5k0s3amxcajdrkjyzpfgq0kvilcv9k"; type = "gem"; }; version = "0.2.2"; }; prawn-templates = { - dependencies = ["pdf-reader" "prawn"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "pdf-reader" + "prawn" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "1w9irn3rllm992c6j7fsx81gg539i7yy8zfddyw7q53hnlys0yhi"; type = "gem"; }; version = "0.1.2"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vqcw3iwby3yc6avs1vb3gfd0vcp2v7q310665dvxfswmcf4xm31"; type = "gem"; }; version = "6.0.1"; }; "pygments.rb" = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14xhvfnj188pypy6pxj29hrn60pznv6dc4ycdgyd6jv2d769wwj1"; type = "gem"; }; version = "3.0.0"; }; racc = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0byn0c9nkahsl93y9ln5bysq4j31q8xkf2ws42swighxd4lnjzsa"; type = "gem"; }; version = "1.8.1"; }; rb-fsevent = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1zmf31rnpm8553lqwibvv3kkx0v7majm1f341xbxc0bk5sbhp423"; type = "gem"; }; version = "0.11.2"; }; rb-inotify = { - dependencies = ["ffi"]; - groups = ["default"]; - platforms = []; + dependencies = [ "ffi" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vmy8xgahixcz6hzwy4zdcyn2y6d6ri8dqv5xccgzc1r292019x0"; type = "gem"; }; version = "0.11.1"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j9p66pmfgxnzp76ksssyfyqqrg7281dyi3xyknl3wwraaw7a66p"; type = "gem"; }; version = "3.3.9"; }; rouge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0r0b48945hakgy0y7lg6h1bb7pkfz8jqd0r6777f80ij3sansvbs"; type = "gem"; }; version = "4.4.0"; }; ruby-enum = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ry6ha94a5jqbj5y3x9k0szyy3jgnsfyxvva98nivg6yx1dfyrz7"; type = "gem"; }; version = "1.0.0"; }; ruby-rc4 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00vci475258mmbvsdqkmqadlwn6gj9m01sp7b5a3zd90knil1k00"; type = "gem"; }; version = "0.1.5"; }; rubyzip = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0grps9197qyxakbpw02pda59v45lfgbgiyw48i0mq9f2bn9y6mrz"; type = "gem"; }; version = "2.3.2"; }; sass = { - dependencies = ["sass-listen"]; - groups = ["default"]; - platforms = []; + dependencies = [ "sass-listen" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0p95lhs0jza5l7hqci1isflxakz83xkj97lkvxl919is0lwhv2w0"; type = "gem"; }; version = "3.7.4"; }; sass-listen = { - dependencies = ["rb-fsevent" "rb-inotify"]; - groups = ["default"]; - platforms = []; - source = { - remotes = ["https://rubygems.org"]; + dependencies = [ + "rb-fsevent" + "rb-inotify" + ]; + groups = [ "default" ]; + platforms = [ ]; + source = { + remotes = [ "https://rubygems.org" ]; sha256 = "0xw3q46cmahkgyldid5hwyiwacp590zj2vmswlll68ryvmvcp7df"; type = "gem"; }; version = "4.0.0"; }; thread_safe = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0nmhcgq6cgz44srylra07bmaw99f5271l0dpsvl5f75m44l0gmwy"; type = "gem"; }; version = "0.3.6"; }; treetop = { - dependencies = ["polyglot"]; - groups = ["default"]; - platforms = []; + dependencies = [ "polyglot" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0adc8qblz8ii668r3rksjx83p675iryh52rvdvysimx2hkbasj7d"; type = "gem"; }; version = "1.6.12"; }; ttfunk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15iaxz9iak5643bq2bc0jkbjv8w2zn649lxgvh5wg48q9d4blw13"; type = "gem"; }; diff --git a/pkgs/tools/typesetting/asciidoctor/default.nix b/pkgs/tools/typesetting/asciidoctor/default.nix index 8b20e718f8fd4b..43218736abc1dc 100644 --- a/pkgs/tools/typesetting/asciidoctor/default.nix +++ b/pkgs/tools/typesetting/asciidoctor/default.nix @@ -1,6 +1,7 @@ -{ lib -, bundlerApp -, bundlerUpdateScript +{ + lib, + bundlerApp, + bundlerUpdateScript, }: bundlerApp { @@ -20,7 +21,10 @@ bundlerApp { description = "Faster Asciidoc processor written in Ruby"; homepage = "https://asciidoctor.org/"; license = licenses.mit; - maintainers = with maintainers; [ gpyh nicknovitski ]; + maintainers = with maintainers; [ + gpyh + nicknovitski + ]; platforms = platforms.unix; }; } diff --git a/pkgs/tools/typesetting/asciidoctor/gemset.nix b/pkgs/tools/typesetting/asciidoctor/gemset.nix index b192ced5368f7b..675e85555138ab 100644 --- a/pkgs/tools/typesetting/asciidoctor/gemset.nix +++ b/pkgs/tools/typesetting/asciidoctor/gemset.nix @@ -1,269 +1,297 @@ { addressable = { - dependencies = ["public_suffix"]; - groups = ["default"]; - platforms = []; + dependencies = [ "public_suffix" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0cl2qpvwiffym62z991ynks7imsm87qmgxf0yfsmlwzkgi9qcaa6"; type = "gem"; }; version = "2.8.7"; }; afm = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "06kj9hgd0z8pj27bxp2diwqh6fv7qhwwm17z64rhdc4sfn76jgn8"; type = "gem"; }; version = "0.2.2"; }; Ascii85 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1c62cx96r0v265mywnlik43qx0wf6bjbzl54qa47x6dzjg861mvk"; type = "gem"; }; version = "1.1.1"; }; asciidoctor = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1wyxgwmnz9bw377r3lba26b090hbsq9qnbw8575a1prpy83qh82j"; type = "gem"; }; version = "2.0.23"; }; asciidoctor-pdf = { - dependencies = ["asciidoctor" "concurrent-ruby" "matrix" "prawn" "prawn-icon" "prawn-svg" "prawn-table" "prawn-templates" "treetop" "ttfunk"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "asciidoctor" + "concurrent-ruby" + "matrix" + "prawn" + "prawn-icon" + "prawn-svg" + "prawn-table" + "prawn-templates" + "treetop" + "ttfunk" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ybkw3xjv75xsc0wbwg76bk83sfspr50k2phshpvh9ynchli8jh3"; type = "gem"; }; version = "2.3.19"; }; coderay = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0jvxqxzply1lwp7ysn94zjhh57vc14mcshw1ygw14ib8lhc00lyw"; type = "gem"; }; version = "1.1.3"; }; concurrent-ruby = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0chwfdq2a6kbj6xz9l6zrdfnyghnh32si82la1dnpa5h75ir5anl"; type = "gem"; }; version = "1.3.4"; }; css_parser = { - dependencies = ["addressable"]; - groups = ["default"]; - platforms = []; + dependencies = [ "addressable" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "17i0fn99kswvfps8r698zw2cr16rc98xdrl0d26y36rv3vhdqh0r"; type = "gem"; }; version = "1.19.1"; }; hashery = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0qj8815bf7q6q7llm5rzdz279gzmpqmqqicxnzv066a020iwqffj"; type = "gem"; }; version = "2.1.2"; }; matrix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1h2cgkpzkh3dd0flnnwfq6f3nl2b1zff9lvqz8xs853ssv5kq23i"; type = "gem"; }; version = "0.4.2"; }; pdf-core = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1fz0yj4zrlii2j08kaw11j769s373ayz8jrdhxwwjzmm28pqndjg"; type = "gem"; }; version = "0.9.0"; }; pdf-reader = { - dependencies = ["Ascii85" "afm" "hashery" "ruby-rc4" "ttfunk"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "Ascii85" + "afm" + "hashery" + "ruby-rc4" + "ttfunk" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0n0pp7blk3np3fqsb54l34fsamrww80cp3dhlhskfayg7542mrv1"; type = "gem"; }; version = "2.12.0"; }; polyglot = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1bqnxwyip623d8pr29rg6m8r0hdg08fpr2yb74f46rn1wgsnxmjr"; type = "gem"; }; version = "0.3.5"; }; prawn = { - dependencies = ["pdf-core" "ttfunk"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "pdf-core" + "ttfunk" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1g9avv2rprsjisdk137s9ljr05r7ajhm78hxa1vjsv0jyx22f1l2"; type = "gem"; }; version = "2.4.0"; }; prawn-icon = { - dependencies = ["prawn"]; - groups = ["default"]; - platforms = []; + dependencies = [ "prawn" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1xdnjik5zinnkjavmybbh2s52wzcpb8hzaqckiv0mxp0vs0x9j6s"; type = "gem"; }; version = "3.0.0"; }; prawn-svg = { - dependencies = ["css_parser" "matrix" "prawn" "rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "css_parser" + "matrix" + "prawn" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "143sfwadbdrgi57am8ikalryjijdyl82h2sdc1cns3wl6b9pkzxg"; type = "gem"; }; version = "0.34.2"; }; prawn-table = { - dependencies = ["prawn"]; - groups = ["default"]; - platforms = []; + dependencies = [ "prawn" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1nxd6qmxqwl850icp18wjh5k0s3amxcajdrkjyzpfgq0kvilcv9k"; type = "gem"; }; version = "0.2.2"; }; prawn-templates = { - dependencies = ["pdf-reader" "prawn"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "pdf-reader" + "prawn" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1w9irn3rllm992c6j7fsx81gg539i7yy8zfddyw7q53hnlys0yhi"; type = "gem"; }; version = "0.1.2"; }; public_suffix = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0vqcw3iwby3yc6avs1vb3gfd0vcp2v7q310665dvxfswmcf4xm31"; type = "gem"; }; version = "6.0.1"; }; "pygments.rb" = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "14xhvfnj188pypy6pxj29hrn60pznv6dc4ycdgyd6jv2d769wwj1"; type = "gem"; }; version = "3.0.0"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j9p66pmfgxnzp76ksssyfyqqrg7281dyi3xyknl3wwraaw7a66p"; type = "gem"; }; version = "3.3.9"; }; rouge = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0r0b48945hakgy0y7lg6h1bb7pkfz8jqd0r6777f80ij3sansvbs"; type = "gem"; }; version = "4.4.0"; }; ruby-rc4 = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "00vci475258mmbvsdqkmqadlwn6gj9m01sp7b5a3zd90knil1k00"; type = "gem"; }; version = "0.1.5"; }; tilt = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0kds7wkxmb038cwp6ravnwn8k65ixc68wpm8j5jx5bhx8ndg4x6z"; type = "gem"; }; version = "2.4.0"; }; treetop = { - dependencies = ["polyglot"]; - groups = ["default"]; - platforms = []; + dependencies = [ "polyglot" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0adc8qblz8ii668r3rksjx83p675iryh52rvdvysimx2hkbasj7d"; type = "gem"; }; version = "1.6.12"; }; ttfunk = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "15iaxz9iak5643bq2bc0jkbjv8w2zn649lxgvh5wg48q9d4blw13"; type = "gem"; }; diff --git a/pkgs/tools/typesetting/kramdown-asciidoc/default.nix b/pkgs/tools/typesetting/kramdown-asciidoc/default.nix index 90949bb96878f3..ac2c5d8a5a636c 100644 --- a/pkgs/tools/typesetting/kramdown-asciidoc/default.nix +++ b/pkgs/tools/typesetting/kramdown-asciidoc/default.nix @@ -1,7 +1,10 @@ -{ lib, bundlerApp, makeWrapper, +{ + lib, + bundlerApp, + makeWrapper, # Optional dependencies, can be null epubcheck, - bundlerUpdateScript + bundlerUpdateScript, }: let @@ -34,4 +37,4 @@ let }; }; in - app +app diff --git a/pkgs/tools/typesetting/kramdown-asciidoc/gemset.nix b/pkgs/tools/typesetting/kramdown-asciidoc/gemset.nix index e750dd6655ac8c..afa6d3f0a1d483 100644 --- a/pkgs/tools/typesetting/kramdown-asciidoc/gemset.nix +++ b/pkgs/tools/typesetting/kramdown-asciidoc/gemset.nix @@ -1,42 +1,46 @@ { kramdown = { - dependencies = ["rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ "rexml" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1ic14hdcqxn821dvzki99zhmcy130yhv5fqfffkcf87asv5mnbmn"; type = "gem"; }; version = "2.4.0"; }; kramdown-asciidoc = { - dependencies = ["kramdown" "kramdown-parser-gfm" "rexml"]; - groups = ["default"]; - platforms = []; + dependencies = [ + "kramdown" + "kramdown-parser-gfm" + "rexml" + ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "1j7qbpq6zhgcf9ykhz5r1wlr3r8fls6hvhdisxzz4v35rni5kwp9"; type = "gem"; }; version = "2.1.0"; }; kramdown-parser-gfm = { - dependencies = ["kramdown"]; - groups = ["default"]; - platforms = []; + dependencies = [ "kramdown" ]; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "0a8pb3v951f4x7h968rqfsa19c8arz21zw1vaj42jza22rap8fgv"; type = "gem"; }; version = "1.1.0"; }; rexml = { - groups = ["default"]; - platforms = []; + groups = [ "default" ]; + platforms = [ ]; source = { - remotes = ["https://rubygems.org"]; + remotes = [ "https://rubygems.org" ]; sha256 = "05i8518ay14kjbma550mv0jm8a6di8yp5phzrd8rj44z9qnrlrp0"; type = "gem"; }; diff --git a/pkgs/tools/typesetting/satysfi/default.nix b/pkgs/tools/typesetting/satysfi/default.nix index c4e1a9980fe05d..cfc6ef704b03b3 100644 --- a/pkgs/tools/typesetting/satysfi/default.nix +++ b/pkgs/tools/typesetting/satysfi/default.nix @@ -1,5 +1,11 @@ -{ lib, fetchFromGitHub, ocamlPackages -, ipaexfont, junicode, lmodern, lmmath +{ + lib, + fetchFromGitHub, + ocamlPackages, + ipaexfont, + junicode, + lmodern, + lmmath, }: let camlpdf = ocamlPackages.camlpdf.overrideAttrs { @@ -24,51 +30,65 @@ let inherit (ocamlPackages.yojson) meta; }; in - ocamlPackages.buildDunePackage rec { - pname = "satysfi"; - version = "0.0.10"; - src = fetchFromGitHub { - owner = "gfngfn"; - repo = "SATySFi"; - rev = "v${version}"; - hash = "sha256-qgVM7ExsKtzNQkZO+I+rcWLj4LSvKL5uyitH7Jg+ns0="; - fetchSubmodules = true; - }; +ocamlPackages.buildDunePackage rec { + pname = "satysfi"; + version = "0.0.10"; + src = fetchFromGitHub { + owner = "gfngfn"; + repo = "SATySFi"; + rev = "v${version}"; + hash = "sha256-qgVM7ExsKtzNQkZO+I+rcWLj4LSvKL5uyitH7Jg+ns0="; + fetchSubmodules = true; + }; - preConfigure = '' - substituteInPlace src/frontend/main.ml --replace \ - '/usr/local/share/satysfi"; "/usr/share/satysfi' \ - $out/share/satysfi - ''; + preConfigure = '' + substituteInPlace src/frontend/main.ml --replace \ + '/usr/local/share/satysfi"; "/usr/share/satysfi' \ + $out/share/satysfi + ''; - nativeBuildInputs = with ocamlPackages; [ menhir cppo ]; + nativeBuildInputs = with ocamlPackages; [ + menhir + cppo + ]; - buildInputs = [ camlpdf yojson-with-position ] ++ (with ocamlPackages; [ + buildInputs = + [ + camlpdf + yojson-with-position + ] + ++ (with ocamlPackages; [ menhirLib - batteries camlimages core_kernel ppx_deriving uutf omd re + batteries + camlimages + core_kernel + ppx_deriving + uutf + omd + re otfed ]); - postInstall = '' - mkdir -p $out/share/satysfi/dist/fonts - cp -r lib-satysfi/dist/ $out/share/satysfi/ - cp -r \ - ${ipaexfont}/share/fonts/opentype/* \ - ${lmodern}/share/fonts/opentype/public/lm/* \ - ${lmmath}/share/fonts/opentype/latinmodern-math.otf \ - ${junicode}/share/fonts/truetype/Junicode-{Bold,BoldItalic,Italic}.ttf \ - $out/share/satysfi/dist/fonts/ - cp ${junicode}/share/fonts/truetype/Junicode-Regular.ttf \ - $out/share/satysfi/dist/fonts/Junicode.ttf - ''; + postInstall = '' + mkdir -p $out/share/satysfi/dist/fonts + cp -r lib-satysfi/dist/ $out/share/satysfi/ + cp -r \ + ${ipaexfont}/share/fonts/opentype/* \ + ${lmodern}/share/fonts/opentype/public/lm/* \ + ${lmmath}/share/fonts/opentype/latinmodern-math.otf \ + ${junicode}/share/fonts/truetype/Junicode-{Bold,BoldItalic,Italic}.ttf \ + $out/share/satysfi/dist/fonts/ + cp ${junicode}/share/fonts/truetype/Junicode-Regular.ttf \ + $out/share/satysfi/dist/fonts/Junicode.ttf + ''; - meta = with lib; { - homepage = "https://github.com/gfngfn/SATySFi"; - description = "Statically-typed, functional typesetting system"; - changelog = "https://github.com/gfngfn/SATySFi/blob/v${version}/CHANGELOG.md"; - license = licenses.lgpl3Only; - maintainers = [ maintainers.mt-caret ]; - platforms = platforms.all; - mainProgram = "satysfi"; - }; - } + meta = with lib; { + homepage = "https://github.com/gfngfn/SATySFi"; + description = "Statically-typed, functional typesetting system"; + changelog = "https://github.com/gfngfn/SATySFi/blob/v${version}/CHANGELOG.md"; + license = licenses.lgpl3Only; + maintainers = [ maintainers.mt-caret ]; + platforms = platforms.all; + mainProgram = "satysfi"; + }; +} diff --git a/pkgs/tools/typesetting/tectonic/biber.nix b/pkgs/tools/typesetting/tectonic/biber.nix index 9798c14716679c..baa7b05aeda712 100644 --- a/pkgs/tools/typesetting/tectonic/biber.nix +++ b/pkgs/tools/typesetting/tectonic/biber.nix @@ -13,42 +13,48 @@ user experience of tectonic in nixpkgs. */ -{ lib -, fetchFromGitHub -, fetchpatch -, biber +{ + lib, + fetchFromGitHub, + fetchpatch, + biber, }: -let version = "2.17"; in ( - biber.override { - /* - It is necessary to first override the `version` data here, which is - passed to `buildPerlModule`, and then to `mkDerivation`. +let + version = "2.17"; +in +(biber.override { + /* + It is necessary to first override the `version` data here, which is + passed to `buildPerlModule`, and then to `mkDerivation`. - If we simply do `biber.overrideAttrs` the resulting package `name` - would be incorrect, since it has already been preprocessed by - `buildPerlModule`. - */ - texlive.pkgs.biber.texsource = { - inherit version; - inherit (biber) pname meta; - }; - } -).overrideAttrs (prevAttrs: { - src = fetchFromGitHub { - owner = "plk"; - repo = "biber"; - rev = "v${version}"; - hash = "sha256-Tt2sN2b2NGxcWyZDj5uXNGC8phJwFRiyH72n3yhFCi0="; - }; - patches = [ - # Perl>=5.36.0 compatibility - (fetchpatch { - url = "https://patch-diff.githubusercontent.com/raw/plk/biber/pull/411.patch"; - hash = "sha256-osgldRVfe3jnMSOMnAMQSB0Ymc1s7J6KtM2ig3c93SE="; - }) - ]; - meta = prevAttrs.meta // { - maintainers = with lib.maintainers; [ doronbehar bryango ]; + If we simply do `biber.overrideAttrs` the resulting package `name` + would be incorrect, since it has already been preprocessed by + `buildPerlModule`. + */ + texlive.pkgs.biber.texsource = { + inherit version; + inherit (biber) pname meta; }; -}) +}).overrideAttrs + (prevAttrs: { + src = fetchFromGitHub { + owner = "plk"; + repo = "biber"; + rev = "v${version}"; + hash = "sha256-Tt2sN2b2NGxcWyZDj5uXNGC8phJwFRiyH72n3yhFCi0="; + }; + patches = [ + # Perl>=5.36.0 compatibility + (fetchpatch { + url = "https://patch-diff.githubusercontent.com/raw/plk/biber/pull/411.patch"; + hash = "sha256-osgldRVfe3jnMSOMnAMQSB0Ymc1s7J6KtM2ig3c93SE="; + }) + ]; + meta = prevAttrs.meta // { + maintainers = with lib.maintainers; [ + doronbehar + bryango + ]; + }; + }) diff --git a/pkgs/tools/typesetting/tectonic/default.nix b/pkgs/tools/typesetting/tectonic/default.nix index a837dd582eab05..cd95b8c0585420 100644 --- a/pkgs/tools/typesetting/tectonic/default.nix +++ b/pkgs/tools/typesetting/tectonic/default.nix @@ -6,17 +6,18 @@ which provides a compatible version of `biber`. */ -{ lib -, stdenv -, fetchFromGitHub -, rustPlatform -, darwin -, fontconfig -, harfbuzz -, openssl -, pkg-config -, icu -, fetchpatch2 +{ + lib, + stdenv, + fetchFromGitHub, + rustPlatform, + darwin, + fontconfig, + harfbuzz, + openssl, + pkg-config, + icu, + fetchpatch2, }: rustPlatform.buildRustPackage rec { @@ -54,18 +55,33 @@ rustPlatform.buildRustPackage rec { buildFeatures = [ "external-harfbuzz" ]; - buildInputs = [ icu fontconfig harfbuzz openssl ] - ++ lib.optionals stdenv.hostPlatform.isDarwin (with darwin.apple_sdk.frameworks; [ ApplicationServices Cocoa Foundation ]); + buildInputs = + [ + icu + fontconfig + harfbuzz + openssl + ] + ++ lib.optionals stdenv.hostPlatform.isDarwin ( + with darwin.apple_sdk.frameworks; + [ + ApplicationServices + Cocoa + Foundation + ] + ); - postInstall = '' - # Makes it possible to automatically use the V2 CLI API - ln -s $out/bin/tectonic $out/bin/nextonic - '' + lib.optionalString stdenv.hostPlatform.isLinux '' - substituteInPlace dist/appimage/tectonic.desktop \ - --replace Exec=tectonic Exec=$out/bin/tectonic - install -D dist/appimage/tectonic.desktop -t $out/share/applications/ - install -D dist/appimage/tectonic.svg -t $out/share/icons/hicolor/scalable/apps/ - ''; + postInstall = + '' + # Makes it possible to automatically use the V2 CLI API + ln -s $out/bin/tectonic $out/bin/nextonic + '' + + lib.optionalString stdenv.hostPlatform.isLinux '' + substituteInPlace dist/appimage/tectonic.desktop \ + --replace Exec=tectonic Exec=$out/bin/tectonic + install -D dist/appimage/tectonic.desktop -t $out/share/applications/ + install -D dist/appimage/tectonic.svg -t $out/share/icons/hicolor/scalable/apps/ + ''; doCheck = true; @@ -75,6 +91,10 @@ rustPlatform.buildRustPackage rec { changelog = "https://github.com/tectonic-typesetting/tectonic/blob/tectonic@${version}/CHANGELOG.md"; license = with licenses; [ mit ]; mainProgram = "tectonic"; - maintainers = with maintainers; [ lluchs doronbehar bryango ]; + maintainers = with maintainers; [ + lluchs + doronbehar + bryango + ]; }; } diff --git a/pkgs/tools/typesetting/tectonic/tests.nix b/pkgs/tools/typesetting/tectonic/tests.nix index 802e0812e8c85d..04c91a1235c37e 100644 --- a/pkgs/tools/typesetting/tectonic/tests.nix +++ b/pkgs/tools/typesetting/tectonic/tests.nix @@ -1,14 +1,15 @@ # This package provides `tectonic.passthru.tests`. # It requires internet access to fetch tectonic's resource bundle on demand. -{ lib -, fetchFromGitHub -, writeText -, runCommand -, tectonic -, curl -, cacert -, emptyFile +{ + lib, + fetchFromGitHub, + writeText, + runCommand, + tectonic, + curl, + cacert, + emptyFile, }: let @@ -32,7 +33,11 @@ let # which is not available in the current environment. ''; # `cacert` is required for tls connections - nativeBuildInputs = [ curl cacert tectonic ]; + nativeBuildInputs = [ + curl + cacert + tectonic + ]; checkInternet = '' if curl --head "bing.com"; then set -e # continue to the tests defined below, fail on error @@ -43,36 +48,38 @@ let fi ''; - networkRequiringTestPkg = name: script: runCommand - /* - Introduce dependence on `tectonic` in the test package name. Note that - adding `tectonic` to `nativeBuildInputs` is not enough to trigger - rebuilds for a fixed-output derivation. One must update its name or - output hash to induce a rebuild. This behavior is exactly the same as a - standard nixpkgs "fetcher" such as `fetchurl`. - */ - "test-${lib.removePrefix "${builtins.storeDir}/" tectonic.outPath}-${name}" - { + networkRequiringTestPkg = + name: script: + runCommand /* - Make a fixed-output derivation, return an `emptyFile` with fixed hash. - These derivations are allowed to access the internet from within a - sandbox, which allows us to test the automatic download of resource - files in tectonic, as a side effect. The `tectonic.outPath` is included - in `name` to induce rebuild of this fixed-output derivation whenever - the `tectonic` derivation is updated. + Introduce dependence on `tectonic` in the test package name. Note that + adding `tectonic` to `nativeBuildInputs` is not enough to trigger + rebuilds for a fixed-output derivation. One must update its name or + output hash to induce a rebuild. This behavior is exactly the same as a + standard nixpkgs "fetcher" such as `fetchurl`. */ - inherit (emptyFile) - outputHashMode - outputHash - ; - allowSubstitutes = false; - inherit nativeBuildInputs; - } - '' - ${checkInternet} - ${script} - cp "${emptyFile}" "$out" - ''; + "test-${lib.removePrefix "${builtins.storeDir}/" tectonic.outPath}-${name}" + { + /* + Make a fixed-output derivation, return an `emptyFile` with fixed hash. + These derivations are allowed to access the internet from within a + sandbox, which allows us to test the automatic download of resource + files in tectonic, as a side effect. The `tectonic.outPath` is included + in `name` to induce rebuild of this fixed-output derivation whenever + the `tectonic` derivation is updated. + */ + inherit (emptyFile) + outputHashMode + outputHash + ; + allowSubstitutes = false; + inherit nativeBuildInputs; + } + '' + ${checkInternet} + ${script} + cp "${emptyFile}" "$out" + ''; in lib.mapAttrs networkRequiringTestPkg { @@ -90,7 +97,9 @@ lib.mapAttrs networkRequiringTestPkg { cat Tectonic.toml | grep "${tectonic.bundleUrl}" ''; - /** test that the `nextonic -> tectonic` symlink is working as intended */ + /** + test that the `nextonic -> tectonic` symlink is working as intended + */ nextonic = '' nextonic new 2>&1 \ | grep '"version 2" Tectonic command-line interface activated' diff --git a/pkgs/tools/typesetting/tectonic/wrapper.nix b/pkgs/tools/typesetting/tectonic/wrapper.nix index 900c695c921828..90080d277e4318 100644 --- a/pkgs/tools/typesetting/tectonic/wrapper.nix +++ b/pkgs/tools/typesetting/tectonic/wrapper.nix @@ -1,10 +1,11 @@ -{ lib -, symlinkJoin -, tectonic -, tectonic-unwrapped -, biber-for-tectonic -, makeBinaryWrapper -, callPackage +{ + lib, + symlinkJoin, + tectonic, + tectonic-unwrapped, + biber-for-tectonic, + makeBinaryWrapper, + callPackage, }: symlinkJoin { @@ -27,9 +28,10 @@ symlinkJoin { }; # Replace the unwrapped tectonic with the one wrapping it with biber - postBuild = '' - rm $out/bin/{tectonic,nextonic} - '' + postBuild = + '' + rm $out/bin/{tectonic,nextonic} + '' # Pin the version of the online TeX bundle that Tectonic's developer # distribute, so that the `biber` version and the `biblatex` version # distributed from there are compatible. @@ -43,16 +45,19 @@ symlinkJoin { # Hence, we can be rather confident that for the near future, the online # TeX bundle won't be updated and hence the biblatex distributed there # won't require a higher version of biber. - + '' - makeWrapper ${lib.getBin tectonic-unwrapped}/bin/tectonic $out/bin/tectonic \ - --prefix PATH : "${lib.getBin biber-for-tectonic}/bin" \ - --add-flags "--web-bundle ${tectonic.passthru.bundleUrl}" \ - --inherit-argv0 ## make sure binary name e.g. `nextonic` is passed along - ln -s $out/bin/tectonic $out/bin/nextonic - ''; + + '' + makeWrapper ${lib.getBin tectonic-unwrapped}/bin/tectonic $out/bin/tectonic \ + --prefix PATH : "${lib.getBin biber-for-tectonic}/bin" \ + --add-flags "--web-bundle ${tectonic.passthru.bundleUrl}" \ + --inherit-argv0 ## make sure binary name e.g. `nextonic` is passed along + ln -s $out/bin/tectonic $out/bin/nextonic + ''; meta = tectonic-unwrapped.meta // { description = "Tectonic TeX/LaTeX engine, wrapped with a compatible biber"; - maintainers = with lib.maintainers; [ doronbehar bryango ]; + maintainers = with lib.maintainers; [ + doronbehar + bryango + ]; }; } diff --git a/pkgs/tools/typesetting/tex/advi/default.nix b/pkgs/tools/typesetting/tex/advi/default.nix index 05262a3f2c01c2..037ab1389b9196 100644 --- a/pkgs/tools/typesetting/tex/advi/default.nix +++ b/pkgs/tools/typesetting/tex/advi/default.nix @@ -1,11 +1,12 @@ -{ fetchurl -, lib -, makeWrapper -, writeShellScriptBin -, ghostscriptX -, ocamlPackages -, texliveMedium -, which +{ + fetchurl, + lib, + makeWrapper, + writeShellScriptBin, + ghostscriptX, + ocamlPackages, + texliveMedium, + which, }: let @@ -51,8 +52,18 @@ ocamlPackages.buildDunePackage rec { duneVersion = "3"; - nativeBuildInputs = [ fake-opam kpsexpand makeWrapper texliveMedium which ]; - buildInputs = with ocamlPackages; [ camlimages ghostscriptX graphics ]; + nativeBuildInputs = [ + fake-opam + kpsexpand + makeWrapper + texliveMedium + which + ]; + buildInputs = with ocamlPackages; [ + camlimages + ghostscriptX + graphics + ]; # install additional files (such as man pages) preInstall = '' diff --git a/pkgs/tools/typesetting/tex/nix/default.nix b/pkgs/tools/typesetting/tex/nix/default.nix index feb444b98ff49e..9bc056fe696aef 100644 --- a/pkgs/tools/typesetting/tex/nix/default.nix +++ b/pkgs/tools/typesetting/tex/nix/default.nix @@ -2,24 +2,25 @@ pkgs: rec { - runLaTeX = - { rootFile - , generatePDF ? true # generate PDF, not DVI - , generatePS ? false # generate PS in addition to DVI - , extraFiles ? [] - , compressBlanksInIndex ? true - , packages ? [] - , texPackages ? {} - , copySources ? false + { + rootFile, + generatePDF ? true, # generate PDF, not DVI + generatePS ? false, # generate PS in addition to DVI + extraFiles ? [ ], + compressBlanksInIndex ? true, + packages ? [ ], + texPackages ? { }, + copySources ? false, }: assert generatePDF -> !generatePS; let - tex = pkgs.texlive.combine - # always include basic stuff you need for LaTeX - ({inherit (pkgs.texlive) scheme-basic;} // texPackages); + tex = + pkgs.texlive.combine + # always include basic stuff you need for LaTeX + ({ inherit (pkgs.texlive) scheme-basic; } // texPackages); in pkgs.stdenv.mkDerivation { @@ -28,29 +29,45 @@ rec { builder = ./run-latex.sh; copyIncludes = ./copy-includes.pl; - inherit rootFile generatePDF generatePS extraFiles - compressBlanksInIndex copySources; - - includes = map (x: [x.key (baseNameOf (toString x.key))]) - (findLaTeXIncludes {inherit rootFile;}); + inherit + rootFile + generatePDF + generatePS + extraFiles + compressBlanksInIndex + copySources + ; + + includes = + map + (x: [ + x.key + (baseNameOf (toString x.key)) + ]) + (findLaTeXIncludes { + inherit rootFile; + }); - buildInputs = [ tex pkgs.perl ] ++ packages; + buildInputs = [ + tex + pkgs.perl + ] ++ packages; }; - # Returns the closure of the "dependencies" of a LaTeX source file. # Dependencies are other LaTeX source files (e.g. included using # \input{}), images (e.g. \includegraphics{}), bibliographies, and # so on. findLaTeXIncludes = - { rootFile + { + rootFile, }: builtins.genericClosure { - startSet = [{key = rootFile;}]; + startSet = [ { key = rootFile; } ]; operator = - {key, ...}: + { key, ... }: let @@ -59,51 +76,73 @@ rec { # "introduction.tex";} {type = "img"; name = "example"}]. # The type denotes the kind of dependency, which determines # what extensions we use to look for it. - deps = import (pkgs.runCommand "latex-includes" - { rootFile = baseNameOf (toString rootFile); src = key; } - "${pkgs.perl}/bin/perl ${./find-includes.pl}"); + deps = import ( + pkgs.runCommand "latex-includes" { + rootFile = baseNameOf (toString rootFile); + src = key; + } "${pkgs.perl}/bin/perl ${./find-includes.pl}" + ); # Look for the dependencies of `key', trying various # extensions determined by the type of each dependency. # TODO: support a search path. - foundDeps = dep: xs: + foundDeps = + dep: xs: let exts = - if dep.type == "img" then [".pdf" ".png" ".ps" ".jpg"] - else if dep.type == "tex" then [".tex" ""] - else [""]; - fn = pkgs.lib.findFirst (fn: builtins.pathExists fn) null - (map (ext: dirOf key + ("/" + dep.name + ext)) exts); - in if fn != null then [{key = fn;}] ++ xs - else xs; - - in pkgs.lib.foldr foundDeps [] deps; + if dep.type == "img" then + [ + ".pdf" + ".png" + ".ps" + ".jpg" + ] + else if dep.type == "tex" then + [ + ".tex" + "" + ] + else + [ "" ]; + fn = pkgs.lib.findFirst (fn: builtins.pathExists fn) null ( + map (ext: dirOf key + ("/" + dep.name + ext)) exts + ); + in + if fn != null then [ { key = fn; } ] ++ xs else xs; + + in + pkgs.lib.foldr foundDeps [ ] deps; }; - findLhs2TeXIncludes = - { lib - , rootFile + { + lib, + rootFile, }: builtins.genericClosure { - startSet = [{key = rootFile;}]; + startSet = [ { key = rootFile; } ]; operator = - {key, ...}: + { key, ... }: let - deps = import (pkgs.runCommand "lhs2tex-includes" - { src = key; } - "${pkgs.stdenv.bash}/bin/bash ${./find-lhs2tex-includes.sh}"); + deps = import ( + pkgs.runCommand "lhs2tex-includes" { + src = key; + } "${pkgs.stdenv.bash}/bin/bash ${./find-lhs2tex-includes.sh}" + ); - in pkgs.lib.concatMap (x: lib.optionals (builtins.pathExists x) [{key = x;}]) - (map (x: dirOf key + ("/" + x)) deps); + in + pkgs.lib.concatMap (x: lib.optionals (builtins.pathExists x) [ { key = x; } ]) ( + map (x: dirOf key + ("/" + x)) deps + ); }; dot2pdf = - { dotGraph + { + dotGraph, }: pkgs.stdenv.mkDerivation { @@ -111,13 +150,14 @@ rec { builder = ./dot2pdf.sh; inherit dotGraph fontsConf; buildInputs = [ - pkgs.perl pkgs.graphviz + pkgs.perl + pkgs.graphviz ]; }; - dot2ps = - { dotGraph + { + dotGraph, }: pkgs.stdenv.mkDerivation { @@ -125,35 +165,52 @@ rec { builder = ./dot2ps.sh; inherit dotGraph; buildInputs = [ - pkgs.perl pkgs.graphviz pkgs.ghostscript + pkgs.perl + pkgs.graphviz + pkgs.ghostscript ]; }; lhs2tex = - { source, flags ? null } : + { + source, + flags ? null, + }: pkgs.stdenv.mkDerivation { name = "tex"; builder = ./lhs2tex.sh; inherit source flags; - buildInputs = [ pkgs.lhs2tex pkgs.perl ]; + buildInputs = [ + pkgs.lhs2tex + pkgs.perl + ]; copyIncludes = ./copy-includes.pl; - includes = map (x: [x.key (baseNameOf (toString x.key))]) - (findLhs2TeXIncludes {rootFile = source;}); + includes = + map + (x: [ + x.key + (baseNameOf (toString x.key)) + ]) + (findLhs2TeXIncludes { + rootFile = source; + }); }; - animateDot = dotGraph: nrFrames: pkgs.stdenv.mkDerivation { - name = "dot-frames"; - builder = ./animatedot.sh; - inherit dotGraph nrFrames; - }; - + animateDot = + dotGraph: nrFrames: + pkgs.stdenv.mkDerivation { + name = "dot-frames"; + builder = ./animatedot.sh; + inherit dotGraph nrFrames; + }; # Wrap a piece of TeX code in a document. Useful when generating # inline images from TeX code. wrapSimpleTeX = - { preamble ? null - , body - , name ? baseNameOf (toString body) + { + preamble ? null, + body, + name ? baseNameOf (toString body), }: pkgs.stdenv.mkDerivation { @@ -169,18 +226,21 @@ rec { ''; }; - # Convert a Postscript file to a PNG image, trimming it so that # there is no unnecessary surrounding whitespace. postscriptToPNG = - { postscript + { + postscript, }: pkgs.stdenv.mkDerivation { name = "png"; inherit postscript; - buildInputs = [pkgs.imagemagick pkgs.ghostscript]; + buildInputs = [ + pkgs.imagemagick + pkgs.ghostscript + ]; buildCommand = '' if test -d $postscript; then @@ -203,12 +263,12 @@ rec { ''; # */ }; - # Convert a piece of TeX code to a PNG image. simpleTeXToPNG = - { preamble ? null - , body - , packages ? [] + { + preamble ? null, + body, + packages ? [ ], }: postscriptToPNG { @@ -222,12 +282,12 @@ rec { }; }; - # Convert a piece of TeX code to a PDF. simpleTeXToPDF = - { preamble ? null - , body - , packages ? [] + { + preamble ? null, + body, + packages ? [ ], }: runLaTeX { @@ -237,7 +297,6 @@ rec { inherit packages; }; - # Some tools (like dot) need a fontconfig configuration file. # This should be extended to allow the called to add additional # fonts. diff --git a/pkgs/tools/typesetting/tex/tetex/default.nix b/pkgs/tools/typesetting/tex/tetex/default.nix index 02471c86318466..9cd55808269912 100644 --- a/pkgs/tools/typesetting/tex/tetex/default.nix +++ b/pkgs/tools/typesetting/tex/tetex/default.nix @@ -1,4 +1,15 @@ -{ lib, stdenv, fetchurl, flex, bison, zlib, libpng, ncurses, ed, automake }: +{ + lib, + stdenv, + fetchurl, + flex, + bison, + zlib, + libpng, + ncurses, + ed, + automake, +}: stdenv.mkDerivation rec { pname = "tetex"; @@ -14,7 +25,14 @@ stdenv.mkDerivation rec { sha256 = "1hj06qvm02a2hx1a67igp45kxlbkczjlg20gr8lbp73l36k8yfvc"; }; - buildInputs = [ flex bison zlib libpng ncurses ed ]; + buildInputs = [ + flex + bison + zlib + libpng + ncurses + ed + ]; hardeningDisable = [ "format" ]; @@ -23,11 +41,20 @@ stdenv.mkDerivation rec { sed -i 57d texk/kpathsea/c-std.h ''; - preConfigure = if stdenv.hostPlatform.isCygwin then '' - find ./ -name "config.guess" -exec rm {} \; -exec ln -s ${automake}/share/automake-*/config.guess {} \; - '' else null; + preConfigure = + if stdenv.hostPlatform.isCygwin then + '' + find ./ -name "config.guess" -exec rm {} \; -exec ln -s ${automake}/share/automake-*/config.guess {} \; + '' + else + null; - patches = [ ./environment.patch ./getline.patch ./clang.patch ./extramembot.patch ]; + patches = [ + ./environment.patch + ./getline.patch + ./clang.patch + ./extramembot.patch + ]; setupHook = ./setup-hook.sh; @@ -37,9 +64,17 @@ stdenv.mkDerivation rec { }; configureFlags = - [ "--disable-multiplatform" "--without-x11" "--without-xdvik" - "--without-oxdvik" "--without-texinfo" "--without-texi2html" - "--with-system-zlib" "--with-system-pnglib" "--with-system-ncurses" ] + [ + "--disable-multiplatform" + "--without-x11" + "--without-xdvik" + "--without-oxdvik" + "--without-texinfo" + "--without-texi2html" + "--with-system-zlib" + "--with-system-pnglib" + "--with-system-ncurses" + ] # couldn't get gsftopk working on darwin ++ lib.optional stdenv.hostPlatform.isDarwin "--without-gsftopk"; @@ -52,11 +87,10 @@ stdenv.mkDerivation rec { ''; meta = with lib; { - description = "Full-featured (La)TeX distribution"; - homepage = "http://www.tug.org/tetex/"; - maintainers = with maintainers; [ lovek323 ]; - platforms = platforms.unix; - hydraPlatforms = []; + description = "Full-featured (La)TeX distribution"; + homepage = "http://www.tug.org/tetex/"; + maintainers = with maintainers; [ lovek323 ]; + platforms = platforms.unix; + hydraPlatforms = [ ]; }; } - diff --git a/pkgs/tools/typesetting/tex/texlive/bin.nix b/pkgs/tools/typesetting/tex/texlive/bin.nix index 7f86d7cfeabeed..58b35678ddd6cb 100644 --- a/pkgs/tools/typesetting/tex/texlive/bin.nix +++ b/pkgs/tools/typesetting/tex/texlive/bin.nix @@ -1,13 +1,52 @@ -{ lib, stdenv, fetchurl, fetchFromGitHub, fetchpatch, buildPackages -, texlive -, zlib, libiconv, libpng, libX11 -, freetype, ttfautohint, gd, libXaw, icu, ghostscript, libXpm, libXmu, libXext -, perl, perlPackages, python3Packages, pkg-config, cmake, ninja -, libpaper, graphite2, zziplib, harfbuzz, potrace, gmp, mpfr, mupdf-headless -, brotli, cairo, pixman, xorg, clisp, biber, woff2, xxHash -, makeWrapper, shortenPerlShebang, useFixedHashes, asymptote -, biber-ms -, tlpdb +{ + lib, + stdenv, + fetchurl, + fetchFromGitHub, + fetchpatch, + buildPackages, + texlive, + zlib, + libiconv, + libpng, + libX11, + freetype, + ttfautohint, + gd, + libXaw, + icu, + ghostscript, + libXpm, + libXmu, + libXext, + perl, + perlPackages, + python3Packages, + pkg-config, + cmake, + ninja, + libpaper, + graphite2, + zziplib, + harfbuzz, + potrace, + gmp, + mpfr, + mupdf-headless, + brotli, + cairo, + pixman, + xorg, + clisp, + biber, + woff2, + xxHash, + makeWrapper, + shortenPerlShebang, + useFixedHashes, + asymptote, + biber-ms, + tlpdb, }@args: # Useful resource covering build options: @@ -20,21 +59,79 @@ let version = year; # keep names simple for now # detect and stop redundant rebuilds that may occur when building new fixed hashes - assertFixedHash = name: src: - if ! useFixedHashes || src ? outputHash then src else throw "The TeX Live package '${src.pname}' must have a fixed hash before building '${name}'."; + assertFixedHash = + name: src: + if !useFixedHashes || src ? outputHash then + src + else + throw "The TeX Live package '${src.pname}' must have a fixed hash before building '${name}'."; # list of packages whose binaries are built in core, core-big # generated manually by inspecting ${core}/bin - corePackages = [ "afm2pl" "aleph" "autosp" "axodraw2" "bibtex" "cjkutils" - "ctie" "cweb" "detex" "dtl" "dvi2tty" "dvicopy" "dvidvi" "dviljk" - "dviout-util" "dvipdfmx" "dvipos" "dvips" "fontware" "gregoriotex" - "gsftopk" "hitex" "kpathsea" "lacheck" "lcdftypetools" "m-tx" "makeindex" - "mfware" "musixtnt" "omegaware" "patgen" "pdftex" "pdftosrc" "pmx" - "ps2eps" "ps2pk" "psutils" "ptex" "seetexk" "synctex" "t1utils" "tex" - "tex4ht" "texlive-scripts-extra" "texware" "tie" "tpic2pdftex" "ttfutils" - "uptex" "velthuis" "vlna" "web" "xml2pmx" ]; - coreBigPackages = [ "metafont" "mflua" "metapost" "luatex" "luahbtex" - "upmendex" "xetex" ] ++ lib.optional withLuaJIT "luajittex"; + corePackages = [ + "afm2pl" + "aleph" + "autosp" + "axodraw2" + "bibtex" + "cjkutils" + "ctie" + "cweb" + "detex" + "dtl" + "dvi2tty" + "dvicopy" + "dvidvi" + "dviljk" + "dviout-util" + "dvipdfmx" + "dvipos" + "dvips" + "fontware" + "gregoriotex" + "gsftopk" + "hitex" + "kpathsea" + "lacheck" + "lcdftypetools" + "m-tx" + "makeindex" + "mfware" + "musixtnt" + "omegaware" + "patgen" + "pdftex" + "pdftosrc" + "pmx" + "ps2eps" + "ps2pk" + "psutils" + "ptex" + "seetexk" + "synctex" + "t1utils" + "tex" + "tex4ht" + "texlive-scripts-extra" + "texware" + "tie" + "tpic2pdftex" + "ttfutils" + "uptex" + "velthuis" + "vlna" + "web" + "xml2pmx" + ]; + coreBigPackages = [ + "metafont" + "mflua" + "metapost" + "luatex" + "luahbtex" + "upmendex" + "xetex" + ] ++ lib.optional withLuaJIT "luajittex"; binPackages = lib.getAttrs (corePackages ++ coreBigPackages) tlpdb; common = { @@ -53,49 +150,67 @@ let hash = "sha256-ZCoZAO0qGWPWW72BJOi5P7/A/qEm+SY3PQyLbx+e3pY="; }; - prePatch = '' - for i in texk/kpathsea/mktex*; do - sed -i '/^mydir=/d' "$i" - done - - # ST_NLINK_TRICK causes kpathsea to treat folders with no real subfolders - # as leaves, even if they contain symlinks to other folders; must be - # disabled to work correctly with the nix store", see section 5.3.6 - # “Subdirectory expansion” of the kpathsea manual - # http://mirrors.ctan.org/systems/doc/kpathsea/kpathsea.pdf for more - # details - sed -i '/^#define ST_NLINK_TRICK/d' texk/kpathsea/config.h - '' + - # when cross compiling, we must use himktables from PATH - # (i.e. from buildPackages.texlive.bin.core.dev) - lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - sed -i 's|\./himktables|himktables|' texk/web2c/Makefile.in - '' -; - - configureFlags = [ - "--with-banner-add=/nixos.org" - "--disable-missing" # terminate if a requested program or feature must be - # disabled, e.g., due to missing libraries - "--disable-native-texlive-build" # do not build for the TeX Live binary distribution - "--enable-shared" # "--enable-cxx-runtime-hack" # static runtime - "--enable-tex-synctex" - "--disable-texlive" # do not build the texlive (TeX Live scripts) package - "--disable-linked-scripts" # do not install the linked scripts - "-C" # use configure cache to speed up - ] + prePatch = + '' + for i in texk/kpathsea/mktex*; do + sed -i '/^mydir=/d' "$i" + done + + # ST_NLINK_TRICK causes kpathsea to treat folders with no real subfolders + # as leaves, even if they contain symlinks to other folders; must be + # disabled to work correctly with the nix store", see section 5.3.6 + # “Subdirectory expansion” of the kpathsea manual + # http://mirrors.ctan.org/systems/doc/kpathsea/kpathsea.pdf for more + # details + sed -i '/^#define ST_NLINK_TRICK/d' texk/kpathsea/config.h + '' + + + # when cross compiling, we must use himktables from PATH + # (i.e. from buildPackages.texlive.bin.core.dev) + lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' + sed -i 's|\./himktables|himktables|' texk/web2c/Makefile.in + ''; + + configureFlags = + [ + "--with-banner-add=/nixos.org" + "--disable-missing" + # terminate if a requested program or feature must be + # disabled, e.g., due to missing libraries + "--disable-native-texlive-build" # do not build for the TeX Live binary distribution + "--enable-shared" # "--enable-cxx-runtime-hack" # static runtime + "--enable-tex-synctex" + "--disable-texlive" # do not build the texlive (TeX Live scripts) package + "--disable-linked-scripts" # do not install the linked scripts + "-C" # use configure cache to speed up + ] ++ withSystemLibs [ - # see "from TL tree" vs. "Using installed" in configure output - "zziplib" "mpfr" "gmp" - "pixman" "potrace" "gd" "freetype2" "libpng" "libpaper" "zlib" - ] ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) - "BUILDCC=${buildPackages.stdenv.cc.targetPrefix}cc"; + # see "from TL tree" vs. "Using installed" in configure output + "zziplib" + "mpfr" + "gmp" + "pixman" + "potrace" + "gd" + "freetype2" + "libpng" + "libpaper" + "zlib" + ] + ++ lib.optional ( + stdenv.hostPlatform != stdenv.buildPlatform + ) "BUILDCC=${buildPackages.stdenv.cc.targetPrefix}cc"; # move binaries to corresponding split outputs, based on content of texlive.tlpdb - binToOutput = lib.listToAttrs - (lib.concatMap - (n: map (v: { name = v; value = builtins.replaceStrings [ "-" ] [ "_" ] n; }) binPackages.${n}.binfiles or [ ]) - (builtins.attrNames binPackages)); + binToOutput = lib.listToAttrs ( + lib.concatMap ( + n: + map (v: { + name = v; + value = builtins.replaceStrings [ "-" ] [ "_" ] n; + }) binPackages.${n}.binfiles or [ ] + ) (builtins.attrNames binPackages) + ); moveBins = '' for bin in "$out/bin"/* ; do @@ -116,411 +231,586 @@ let }; # RISC-V: https://github.com/LuaJIT/LuaJIT/issues/628 - withLuaJIT = !(stdenv.hostPlatform.isPower && stdenv.hostPlatform.is64bit) && !stdenv.hostPlatform.isRiscV; -in rec { # un-indented - -texliveYear = year; - - -core = stdenv.mkDerivation rec { - pname = "texlive-bin"; - inherit version; - - __structuredAttrs = true; - - inherit (common) binToOutput src prePatch; + withLuaJIT = + !(stdenv.hostPlatform.isPower && stdenv.hostPlatform.is64bit) && !stdenv.hostPlatform.isRiscV; +in +rec { + # un-indented + + texliveYear = year; + + core = stdenv.mkDerivation rec { + pname = "texlive-bin"; + inherit version; + + __structuredAttrs = true; + + inherit (common) binToOutput src prePatch; + + outputs = [ + "out" + "dev" + "man" + "info" + ] ++ (builtins.map (builtins.replaceStrings [ "-" ] [ "_" ]) corePackages); + + nativeBuildInputs = + [ + pkg-config + ] + ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) ( + with texlive.bin.core; + [ + # configure: error: tangle was not found but is required when cross-compiling. + # dev (himktables) is used when building hitex to generate the additional source file hitables.c + web # tangle + cweb # ctangle + omegaware # otangle + tie # tie see "Building TeX Live" 6.4.2 Cross problems + dev # himktables + ] + ); + + buildInputs = [ + # teckit + zziplib + mpfr + gmp + pixman + gd + freetype + libpng + libpaper + zlib + perl + ]; - outputs = [ "out" "dev" "man" "info" ] - ++ (builtins.map (builtins.replaceStrings [ "-" ] [ "_" ]) corePackages); + hardeningDisable = [ "format" ]; - nativeBuildInputs = [ - pkg-config - ] ++ lib.optionals (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) (with texlive.bin.core; [ - # configure: error: tangle was not found but is required when cross-compiling. - # dev (himktables) is used when building hitex to generate the additional source file hitables.c - web/*tangle*/ cweb/*ctangle*/ omegaware/*otangle*/ tie/*tie*/ # see "Building TeX Live" 6.4.2 Cross problems - dev/*himktables*/ - ]); + preConfigure = '' + rm -r libs/{cairo,freetype2,gd,gmp,graphite2,harfbuzz,icu,libpaper,libpng} \ + libs/{lua53,luajit,mpfr,pixman,pplib,teckit,zlib,zziplib} \ + texk/{bibtex-x,chktex,dvipng,dvisvgm,upmendex,xdvik} \ + utils/{asymptote,texdoctk,xindy,xpdfopen} + mkdir WorkDir + cd WorkDir + ''; + configureScript = "../configure"; + + depsBuildBuild = [ buildPackages.stdenv.cc ]; + + configureFlags = + common.configureFlags + ++ [ "--without-x" ] # disable xdvik and xpdfopen + ++ map (what: "--disable-${what}") [ + "chktex" + "dvisvgm" + "dvipng" # ghostscript dependency + "luatex" + "luajittex" + "luahbtex" + "luajithbtex" + "mp" + "pmp" + "upmp" + "mf" + "mflua" + "mfluajit" # cairo would bring in X and more + "xetex" + "bibtexu" + "bibtex8" + "bibtex-x" + "upmendex" # ICU isn't small + ]; + + enableParallelBuilding = true; + + doCheck = false; # triptest fails, likely due to missing TEXMF tree + preCheck = "patchShebangs ../texk/web2c"; + + installTargets = [ "install" ]; + + # TODO: perhaps improve texmf.cnf search locations + postInstall = + # remove redundant texmf-dist (content provided by TeX Live packages) + '' + rm -fr "$out"/share/texmf-dist + '' + # install himktables in separate output for use in cross compilation + + '' + mkdir -p $dev/bin + cp texk/web2c/.libs/himktables $dev/bin/himktables + '' + + common.moveBins; + + passthru = { inherit version buildInputs; }; + + meta = with lib; { + description = "Basic binaries for TeX Live"; + homepage = "http://www.tug.org/texlive"; + license = lib.licenses.gpl2Plus; + maintainers = with maintainers; [ + veprbl + lovek323 + raskin + jwiegley + ]; + platforms = platforms.all; + }; + }; - buildInputs = [ - /*teckit*/ zziplib mpfr gmp - pixman gd freetype libpng libpaper zlib - perl - ]; + inherit (core-big) + metafont + mflua + metapost + luatex + luahbtex + xetex + ; + luajittex = core.big.luajittex or null; + core-big = stdenv.mkDerivation { + pname = "texlive-bin-big"; + inherit version; + + __structuredAttrs = true; + + inherit (common) binToOutput src prePatch; + + patches = [ + # improves reproducibility of fmt files + # see discussion at https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=1009196 + (fetchpatch { + name = "lua_fixed_hash.patch"; + url = "https://bugs.debian.org/cgi-bin/bugreport.cgi?att=1;bug=1009196;filename=lua_fixed_hash.patch;msg=45"; + sha256 = "sha256-FTu1eRd3AUU7IRs2/7e7uwHuvZsrzTBPypbcEZkU7y4="; + }) + # Fixes texluajitc crashes on aarch64, backport of the upstream fix + # https://github.com/LuaJIT/LuaJIT/commit/e9af1abec542e6f9851ff2368e7f196b6382a44c + # to the version vendored by texlive (2.1.0-beta3) + (fetchpatch { + name = "luajit-fix-aarch64-linux.patch"; + url = "https://raw.githubusercontent.com/void-linux/void-packages/30253fbfc22cd93d97ec53df323778a3aab82754/srcpkgs/LuaJIT/patches/e9af1abec542e6f9851ff2368e7f196b6382a44c.patch"; + hash = "sha256-ysSZmfpfCFMukfHmIqwofAZux1e2kEq/37lfqp7HoWo="; + stripLen = 1; + extraPrefix = "libs/luajit/LuaJIT-src/"; + }) + ]; - hardeningDisable = [ "format" ]; - - preConfigure = '' - rm -r libs/{cairo,freetype2,gd,gmp,graphite2,harfbuzz,icu,libpaper,libpng} \ - libs/{lua53,luajit,mpfr,pixman,pplib,teckit,zlib,zziplib} \ - texk/{bibtex-x,chktex,dvipng,dvisvgm,upmendex,xdvik} \ - utils/{asymptote,texdoctk,xindy,xpdfopen} - mkdir WorkDir - cd WorkDir - ''; - configureScript = "../configure"; - - depsBuildBuild = [ buildPackages.stdenv.cc ]; - - configureFlags = common.configureFlags - ++ [ "--without-x" ] # disable xdvik and xpdfopen - ++ map (what: "--disable-${what}") [ - "chktex" - "dvisvgm" "dvipng" # ghostscript dependency - "luatex" "luajittex" "luahbtex" "luajithbtex" - "mp" "pmp" "upmp" "mf" "mflua" "mfluajit" # cairo would bring in X and more - "xetex" "bibtexu" "bibtex8" "bibtex-x" "upmendex" # ICU isn't small + hardeningDisable = [ "format" ]; + + inherit (core) nativeBuildInputs depsBuildBuild; + buildInputs = core.buildInputs ++ [ + core + cairo + harfbuzz + icu + graphite2 + libX11 + potrace ]; - enableParallelBuilding = true; + /* + deleting the unused packages speeds up configure by a considerable margin + and ensures we do not rebuild existing libraries by mistake + */ + preConfigure = + '' + rm -r libs/{cairo,freetype2,gd,gmp,graphite2,harfbuzz,icu,libpaper,libpng} \ + libs/{mpfr,pixman,xpdf,zlib,zziplib} \ + texk/{afm2pl,bibtex-x,chktex,cjkutils,detex,dtl,dvi2tty,dvidvi,dviljk,dviout-util} \ + texk/{dvipdfm-x,dvipng,dvipos,dvipsk,dvisvgm,gregorio,gsftopk,kpathsea} \ + texk/{lcdf-typetools,makeindexk,makejvf,mendexk,musixtnt,ps2pk,psutils,ptexenc} \ + texk/{seetexk,tex4htk,texlive,ttf2pk2,ttfdump,xdvik} \ + utils/{asymptote,autosp,axodraw2,devnag,lacheck,m-tx,pmx,ps2eps,t1utils,texdoctk} \ + utils/{tpic2pdftex,vlna,xindy,xml2pmx,xpdfopen} + mkdir WorkDir + cd WorkDir + '' + # force XeTeX to use fontconfig instead of Core Text, so that fonts can be made available via FONTCONFIG_FILE, + # by tricking configure into thinking that the relevant test result is already in the config cache + + lib.optionalString stdenv.hostPlatform.isDarwin '' + export kpse_cv_have_ApplicationServices=no + ''; + + configureFlags = + common.configureFlags + ++ withSystemLibs [ + "kpathsea" + "ptexenc" + "cairo" + "harfbuzz" + "icu" + "graphite2" + ] + ++ + map (prog: "--disable-${prog}") # don't build things we already have + # list from texk/web2c/configure + ( + [ + "tex" + "ptex" + "eptex" + "uptex" + "euptex" + "aleph" + "hitex" + "pdftex" + "web-progs" + "synctex" + ] + ++ lib.optionals (!withLuaJIT) [ + "luajittex" + "luajithbtex" + "mfluajit" + ] + ) + # disable all packages, re-enable upmendex, web2c packages + ++ [ + "--disable-all-pkgs" + "--enable-upmendex" + "--enable-web2c" + ] + # kpathsea requires specifying the kpathsea location manually + ++ [ "--with-kpathsea-includes=${core.dev}/include" ]; + + configureScript = "../configure"; + + enableParallelBuilding = true; + + doCheck = false; # fails + + outputs = + [ + "out" + "dev" + "man" + "info" + ] + ++ (builtins.map (builtins.replaceStrings [ "-" ] [ "_" ]) coreBigPackages) + # some outputs of metapost, omegaware are for ptex/uptex + ++ [ + "ptex" + "uptex" + ] + # unavoidable duplicates from core + ++ [ + "ctie" + "cweb" + "omegaware" + "texlive_scripts_extra" + "tie" + "web" + ]; + postInstall = common.moveBins; + }; - doCheck = false; # triptest fails, likely due to missing TEXMF tree - preCheck = "patchShebangs ../texk/web2c"; + chktex = stdenv.mkDerivation { + pname = "chktex"; + inherit (texlive.pkgs.chktex) version; - installTargets = [ "install" ]; + inherit (common) src; - # TODO: perhaps improve texmf.cnf search locations - postInstall = - /* remove redundant texmf-dist (content provided by TeX Live packages) */ - '' - rm -fr "$out"/share/texmf-dist - '' + /* install himktables in separate output for use in cross compilation */ '' - mkdir -p $dev/bin - cp texk/web2c/.libs/himktables $dev/bin/himktables - '' + common.moveBins; + nativeBuildInputs = [ pkg-config ]; + # perl used in shebang of script bin/deweb + buildInputs = [ + core # kpathsea + perl + ]; - passthru = { inherit version buildInputs; }; + preConfigure = "cd texk/chktex"; - meta = with lib; { - description = "Basic binaries for TeX Live"; - homepage = "http://www.tug.org/texlive"; - license = lib.licenses.gpl2Plus; - maintainers = with maintainers; [ veprbl lovek323 raskin jwiegley ]; - platforms = platforms.all; - }; -}; - - -inherit (core-big) metafont mflua metapost luatex luahbtex xetex; -luajittex = core.big.luajittex or null; -core-big = stdenv.mkDerivation { - pname = "texlive-bin-big"; - inherit version; - - __structuredAttrs = true; - - inherit (common) binToOutput src prePatch; - - patches = [ - # improves reproducibility of fmt files - # see discussion at https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=1009196 - (fetchpatch { - name = "lua_fixed_hash.patch"; - url = "https://bugs.debian.org/cgi-bin/bugreport.cgi?att=1;bug=1009196;filename=lua_fixed_hash.patch;msg=45"; - sha256 = "sha256-FTu1eRd3AUU7IRs2/7e7uwHuvZsrzTBPypbcEZkU7y4="; - }) - # Fixes texluajitc crashes on aarch64, backport of the upstream fix - # https://github.com/LuaJIT/LuaJIT/commit/e9af1abec542e6f9851ff2368e7f196b6382a44c - # to the version vendored by texlive (2.1.0-beta3) - (fetchpatch { - name = "luajit-fix-aarch64-linux.patch"; - url = "https://raw.githubusercontent.com/void-linux/void-packages/30253fbfc22cd93d97ec53df323778a3aab82754/srcpkgs/LuaJIT/patches/e9af1abec542e6f9851ff2368e7f196b6382a44c.patch"; - hash = "sha256-ysSZmfpfCFMukfHmIqwofAZux1e2kEq/37lfqp7HoWo="; - stripLen = 1; - extraPrefix = "libs/luajit/LuaJIT-src/"; - }) - ]; + configureFlags = common.configureFlags ++ [ "--with-system-kpathsea" ]; - hardeningDisable = [ "format" ]; - - inherit (core) nativeBuildInputs depsBuildBuild; - buildInputs = core.buildInputs ++ [ core cairo harfbuzz icu graphite2 libX11 potrace ]; - - /* deleting the unused packages speeds up configure by a considerable margin - and ensures we do not rebuild existing libraries by mistake */ - preConfigure = '' - rm -r libs/{cairo,freetype2,gd,gmp,graphite2,harfbuzz,icu,libpaper,libpng} \ - libs/{mpfr,pixman,xpdf,zlib,zziplib} \ - texk/{afm2pl,bibtex-x,chktex,cjkutils,detex,dtl,dvi2tty,dvidvi,dviljk,dviout-util} \ - texk/{dvipdfm-x,dvipng,dvipos,dvipsk,dvisvgm,gregorio,gsftopk,kpathsea} \ - texk/{lcdf-typetools,makeindexk,makejvf,mendexk,musixtnt,ps2pk,psutils,ptexenc} \ - texk/{seetexk,tex4htk,texlive,ttf2pk2,ttfdump,xdvik} \ - utils/{asymptote,autosp,axodraw2,devnag,lacheck,m-tx,pmx,ps2eps,t1utils,texdoctk} \ - utils/{tpic2pdftex,vlna,xindy,xml2pmx,xpdfopen} - mkdir WorkDir - cd WorkDir - '' - # force XeTeX to use fontconfig instead of Core Text, so that fonts can be made available via FONTCONFIG_FILE, - # by tricking configure into thinking that the relevant test result is already in the config cache - + lib.optionalString stdenv.hostPlatform.isDarwin '' - export kpse_cv_have_ApplicationServices=no - ''; - - configureFlags = common.configureFlags - ++ withSystemLibs [ "kpathsea" "ptexenc" "cairo" "harfbuzz" "icu" "graphite2" ] - ++ map (prog: "--disable-${prog}") # don't build things we already have - # list from texk/web2c/configure - ([ "tex" "ptex" "eptex" "uptex" "euptex" "aleph" "hitex" "pdftex" - "web-progs" "synctex" - ] ++ lib.optionals (!withLuaJIT) [ "luajittex" "luajithbtex" "mfluajit" ]) - /* disable all packages, re-enable upmendex, web2c packages */ - ++ [ "--disable-all-pkgs" "--enable-upmendex" "--enable-web2c" ] - /* kpathsea requires specifying the kpathsea location manually */ - ++ [ "--with-kpathsea-includes=${core.dev}/include" ]; - - configureScript = "../configure"; - - enableParallelBuilding = true; - - doCheck = false; # fails - - outputs = [ "out" "dev" "man" "info" ] - ++ (builtins.map (builtins.replaceStrings [ "-" ] [ "_" ]) coreBigPackages) - # some outputs of metapost, omegaware are for ptex/uptex - ++ [ "ptex" "uptex" ] - # unavoidable duplicates from core - ++ [ "ctie" "cweb" "omegaware" "texlive_scripts_extra" "tie" "web" ]; - postInstall = common.moveBins; -}; - - -chktex = stdenv.mkDerivation { - pname = "chktex"; - inherit (texlive.pkgs.chktex) version; - - inherit (common) src; - - nativeBuildInputs = [ pkg-config ]; - # perl used in shebang of script bin/deweb - buildInputs = [ core/*kpathsea*/ perl ]; - - preConfigure = "cd texk/chktex"; - - configureFlags = common.configureFlags - ++ [ "--with-system-kpathsea" ]; - - enableParallelBuilding = true; -}; - -# the LuaMetaTeX engine (distributed since TeX Live 2023) must be built separately -# the sources used by TL are stored in the source TL repo -# for details see https://wiki.contextgarden.net/Building_LuaMetaTeX_for_TeX_Live -context = stdenv.mkDerivation rec { - pname = "luametatex"; - version = "2.11.02"; - - src = fetchurl { - name = "luametatex-${version}.tar.xz"; - url = "https://tug.org/svn/texlive/trunk/Master/source/luametatex-${version}.tar.xz?pathrev=70384&view=co"; - hash = "sha256-o7esoBBTTYEstkd7l34BWxew3fIRdVcFiGxrT1/KP1o="; + enableParallelBuilding = true; }; - enableParallelBuilding = true; - nativeBuildInputs = [ cmake ninja ]; - - meta = with lib; { - description = "LUAMETATEX engine is a follow up on LUATEX and is again part of CONTEXT development"; - homepage = "https://www.pragma-ade.nl/luametatex-1.htm"; - license = licenses.gpl2Plus; - maintainers = with lib.maintainers; [ apfelkuchen6 xworld21 ]; - }; -}; + # the LuaMetaTeX engine (distributed since TeX Live 2023) must be built separately + # the sources used by TL are stored in the source TL repo + # for details see https://wiki.contextgarden.net/Building_LuaMetaTeX_for_TeX_Live + context = stdenv.mkDerivation rec { + pname = "luametatex"; + version = "2.11.02"; + + src = fetchurl { + name = "luametatex-${version}.tar.xz"; + url = "https://tug.org/svn/texlive/trunk/Master/source/luametatex-${version}.tar.xz?pathrev=70384&view=co"; + hash = "sha256-o7esoBBTTYEstkd7l34BWxew3fIRdVcFiGxrT1/KP1o="; + }; -dvisvgm = stdenv.mkDerivation rec { - pname = "dvisvgm"; - version = "3.2.2"; + enableParallelBuilding = true; + nativeBuildInputs = [ + cmake + ninja + ]; - src = assert lib.assertMsg (version == texlive.pkgs.dvisvgm.version) "dvisvgm: TeX Live version (${texlive.pkgs.dvisvgm.version}) different from source (${version}), please update dvisvgm"; fetchurl { - url = "https://github.com/mgieseki/dvisvgm/releases/download/${version}/dvisvgm-${version}.tar.gz"; - hash = "sha256-8GKL6lqjMUXXWwpqbdGPrYibdSc4y8AcGUGPNUc6HQA="; + meta = with lib; { + description = "LUAMETATEX engine is a follow up on LUATEX and is again part of CONTEXT development"; + homepage = "https://www.pragma-ade.nl/luametatex-1.htm"; + license = licenses.gpl2Plus; + maintainers = with lib.maintainers; [ + apfelkuchen6 + xworld21 + ]; + }; }; - configureFlags = [ - "--disable-manpage" # man pages are provided by the doc container - "--with-ttfautohint" - ]; - - # PDF handling requires mutool (from mupdf) since Ghostscript 10.01 - postPatch = '' - substituteInPlace src/PDFHandler.cpp \ - --replace-fail 'Process("mutool"' "Process(\"$(PATH="$HOST_PATH" command -v mutool)\"" - ''; + dvisvgm = stdenv.mkDerivation rec { + pname = "dvisvgm"; + version = "3.2.2"; - nativeBuildInputs = [ pkg-config ]; - buildInputs = [ core brotli ghostscript zlib freetype ttfautohint woff2 potrace xxHash mupdf-headless ]; + src = + assert lib.assertMsg (version == texlive.pkgs.dvisvgm.version) + "dvisvgm: TeX Live version (${texlive.pkgs.dvisvgm.version}) different from source (${version}), please update dvisvgm"; + fetchurl { + url = "https://github.com/mgieseki/dvisvgm/releases/download/${version}/dvisvgm-${version}.tar.gz"; + hash = "sha256-8GKL6lqjMUXXWwpqbdGPrYibdSc4y8AcGUGPNUc6HQA="; + }; - enableParallelBuilding = true; -}; + configureFlags = [ + "--disable-manpage" # man pages are provided by the doc container + "--with-ttfautohint" + ]; + # PDF handling requires mutool (from mupdf) since Ghostscript 10.01 + postPatch = '' + substituteInPlace src/PDFHandler.cpp \ + --replace-fail 'Process("mutool"' "Process(\"$(PATH="$HOST_PATH" command -v mutool)\"" + ''; -dvipng = stdenv.mkDerivation { - pname = "dvipng"; - inherit (texlive.pkgs.dvipng) version; + nativeBuildInputs = [ pkg-config ]; + buildInputs = [ + core + brotli + ghostscript + zlib + freetype + ttfautohint + woff2 + potrace + xxHash + mupdf-headless + ]; - inherit (common) src; + enableParallelBuilding = true; + }; - nativeBuildInputs = [ perl pkg-config makeWrapper ]; - buildInputs = [ core/*kpathsea*/ zlib libpng freetype gd ghostscript ]; + dvipng = stdenv.mkDerivation { + pname = "dvipng"; + inherit (texlive.pkgs.dvipng) version; - preConfigure = '' - cd texk/dvipng - patchShebangs doc/texi2pod.pl - ''; + inherit (common) src; - configureFlags = common.configureFlags - ++ [ "--with-system-kpathsea" "--with-gs=yes" "--disable-debug" ]; + nativeBuildInputs = [ + perl + pkg-config + makeWrapper + ]; + buildInputs = [ + core # kpathsea + zlib + libpng + freetype + gd + ghostscript + ]; - GS="${ghostscript}/bin/gs"; + preConfigure = '' + cd texk/dvipng + patchShebangs doc/texi2pod.pl + ''; - enableParallelBuilding = true; -}; + configureFlags = common.configureFlags ++ [ + "--with-system-kpathsea" + "--with-gs=yes" + "--disable-debug" + ]; -pygmentex = python3Packages.buildPythonApplication rec { - pname = "pygmentex"; - inherit (src) version; - format = "other"; + GS = "${ghostscript}/bin/gs"; - src = assertFixedHash pname texlive.pkgs.pygmentex.tex; + enableParallelBuilding = true; + }; - propagatedBuildInputs = with python3Packages; [ pygments chardet ]; + pygmentex = python3Packages.buildPythonApplication rec { + pname = "pygmentex"; + inherit (src) version; + format = "other"; - dontBuild = true; + src = assertFixedHash pname texlive.pkgs.pygmentex.tex; - doCheck = false; + propagatedBuildInputs = with python3Packages; [ + pygments + chardet + ]; - installPhase = '' - runHook preInstall + dontBuild = true; - install -D ./scripts/pygmentex/pygmentex.py "$out"/bin/pygmentex + doCheck = false; - runHook postInstall - ''; + installPhase = '' + runHook preInstall - meta = with lib; { - homepage = "https://www.ctan.org/pkg/pygmentex"; - description = "Auxiliary tool for typesetting code listings in LaTeX documents using Pygments"; - longDescription = '' - PygmenTeX is a Python-based LaTeX package that can be used for - typesetting code listings in a LaTeX document using Pygments. + install -D ./scripts/pygmentex/pygmentex.py "$out"/bin/pygmentex - Pygments is a generic syntax highlighter for general use in all kinds of - software such as forum systems, wikis or other applications that need to - prettify source code. + runHook postInstall ''; - license = licenses.lppl13c; - maintainers = with maintainers; [ romildo ]; - }; -}; -asymptote = args.asymptote.overrideAttrs (finalAttrs: prevAttrs: { - version = texlive.pkgs.asymptote.version; - - # keep local src and patches even if duplicated in the top level asymptote - # so that top level updates do not break texlive - src = fetchurl { - url = "mirror://sourceforge/asymptote/${finalAttrs.version}/asymptote-${finalAttrs.version}.src.tgz"; - hash = "sha256-nZtcb6fg+848HlT+sl4tUdKMT+d5jyTHbNyugpGo6mY="; + meta = with lib; { + homepage = "https://www.ctan.org/pkg/pygmentex"; + description = "Auxiliary tool for typesetting code listings in LaTeX documents using Pygments"; + longDescription = '' + PygmenTeX is a Python-based LaTeX package that can be used for + typesetting code listings in a LaTeX document using Pygments. + + Pygments is a generic syntax highlighter for general use in all kinds of + software such as forum systems, wikis or other applications that need to + prettify source code. + ''; + license = licenses.lppl13c; + maintainers = with maintainers; [ romildo ]; + }; }; - texContainer = texlive.pkgs.asymptote.tex; - texdocContainer = texlive.pkgs.asymptote.texdoc; -}); - -inherit biber; -inherit biber-ms; -bibtexu = bibtex8; -bibtex8 = stdenv.mkDerivation { - pname = "bibtex-x"; - inherit (texlive.pkgs.bibtexu) version; - - inherit (common) src; - - nativeBuildInputs = [ pkg-config ]; - buildInputs = [ core/*kpathsea*/ icu ]; - - preConfigure = "cd texk/bibtex-x"; - - configureFlags = common.configureFlags - ++ [ "--with-system-kpathsea" "--with-system-icu" ]; - - enableParallelBuilding = true; -}; - - -xdvi = stdenv.mkDerivation { - pname = "xdvi"; - inherit (texlive.pkgs.xdvi) version; + asymptote = args.asymptote.overrideAttrs ( + finalAttrs: prevAttrs: { + version = texlive.pkgs.asymptote.version; + + # keep local src and patches even if duplicated in the top level asymptote + # so that top level updates do not break texlive + src = fetchurl { + url = "mirror://sourceforge/asymptote/${finalAttrs.version}/asymptote-${finalAttrs.version}.src.tgz"; + hash = "sha256-nZtcb6fg+848HlT+sl4tUdKMT+d5jyTHbNyugpGo6mY="; + }; + + texContainer = texlive.pkgs.asymptote.tex; + texdocContainer = texlive.pkgs.asymptote.texdoc; + } + ); + + inherit biber; + inherit biber-ms; + bibtexu = bibtex8; + bibtex8 = stdenv.mkDerivation { + pname = "bibtex-x"; + inherit (texlive.pkgs.bibtexu) version; + + inherit (common) src; + + nativeBuildInputs = [ pkg-config ]; + buildInputs = [ + core # kpathsea + icu + ]; - inherit (common) src; + preConfigure = "cd texk/bibtex-x"; - nativeBuildInputs = [ pkg-config ]; - buildInputs = [ core/*kpathsea*/ freetype ghostscript ] - ++ (with xorg; [ libX11 libXaw libXi libXpm libXmu libXaw libXext libXfixes ]); + configureFlags = common.configureFlags ++ [ + "--with-system-kpathsea" + "--with-system-icu" + ]; - preConfigure = "cd texk/xdvik"; + enableParallelBuilding = true; + }; - configureFlags = common.configureFlags - ++ [ "--with-system-kpathsea" "--with-system-libgs" ]; + xdvi = stdenv.mkDerivation { + pname = "xdvi"; + inherit (texlive.pkgs.xdvi) version; + + inherit (common) src; + + nativeBuildInputs = [ pkg-config ]; + buildInputs = + [ + core # kpathsea + freetype + ghostscript + ] + ++ (with xorg; [ + libX11 + libXaw + libXi + libXpm + libXmu + libXaw + libXext + libXfixes + ]); + + preConfigure = "cd texk/xdvik"; + + configureFlags = common.configureFlags ++ [ + "--with-system-kpathsea" + "--with-system-libgs" + ]; - enableParallelBuilding = true; + enableParallelBuilding = true; - postInstall = '' - substituteInPlace "$out/bin/xdvi" \ - --replace-fail "exec xdvi-xaw" "exec '$out/bin/xdvi-xaw'" - ''; - # TODO: it's suspicious that mktexpk generates fonts into ~/.texlive2014 -}; + postInstall = '' + substituteInPlace "$out/bin/xdvi" \ + --replace-fail "exec xdvi-xaw" "exec '$out/bin/xdvi-xaw'" + ''; + # TODO: it's suspicious that mktexpk generates fonts into ~/.texlive2014 + }; -xpdfopen = stdenv.mkDerivation { - pname = "xpdfopen"; - inherit (texlive.pkgs.xpdfopen) version; + xpdfopen = stdenv.mkDerivation { + pname = "xpdfopen"; + inherit (texlive.pkgs.xpdfopen) version; - inherit (common) src; + inherit (common) src; - buildInputs = [ libX11 ]; + buildInputs = [ libX11 ]; - preConfigure = "cd utils/xpdfopen"; + preConfigure = "cd utils/xpdfopen"; - enableParallelBuilding = true; -}; + enableParallelBuilding = true; + }; } # un-indented -// lib.optionalAttrs (!clisp.meta.broken) # broken on aarch64 and darwin (#20062) -{ - -xindy = stdenv.mkDerivation { - pname = "xindy"; - inherit (texlive.pkgs.xindy) version; - - inherit (common) src; - - # If unset, xindy will try to mkdir /homeless-shelter - HOME = "."; - - prePatch = "cd utils/xindy"; - # hardcode clisp location - postPatch = '' - substituteInPlace xindy-*/user-commands/xindy.in \ - --replace-fail "our \$clisp = ( \$is_windows ? 'clisp.exe' : 'clisp' ) ;" \ - "our \$clisp = '$(type -P clisp)';" \ - --replace-fail 'die "$cmd: Cannot locate xindy modules directory";' \ - '$modules_dir = "${texlive.pkgs.xindy.tex}/xindy/modules"; die "$cmd: Cannot locate xindy modules directory" unless -d $modules_dir;' - ''; - - nativeBuildInputs = [ - pkg-config perl - ]; - buildInputs = [ clisp libiconv perl ]; - - configureFlags = [ "--with-clisp-runtime=system" "--disable-xindy-docs" "--disable-xindy-rules" ]; - - preInstall = ''mkdir -p "$out/bin" ''; - # fixup various file-location errors of: lib/xindy/{xindy.mem,modules/} - postInstall = '' - mkdir -p "$out/lib/xindy" - mv "$out"/{bin/xindy.mem,lib/xindy/} - ''; -}; - -} +// + lib.optionalAttrs (!clisp.meta.broken) # broken on aarch64 and darwin (#20062) + { + + xindy = stdenv.mkDerivation { + pname = "xindy"; + inherit (texlive.pkgs.xindy) version; + + inherit (common) src; + + # If unset, xindy will try to mkdir /homeless-shelter + HOME = "."; + + prePatch = "cd utils/xindy"; + # hardcode clisp location + postPatch = '' + substituteInPlace xindy-*/user-commands/xindy.in \ + --replace-fail "our \$clisp = ( \$is_windows ? 'clisp.exe' : 'clisp' ) ;" \ + "our \$clisp = '$(type -P clisp)';" \ + --replace-fail 'die "$cmd: Cannot locate xindy modules directory";' \ + '$modules_dir = "${texlive.pkgs.xindy.tex}/xindy/modules"; die "$cmd: Cannot locate xindy modules directory" unless -d $modules_dir;' + ''; + + nativeBuildInputs = [ + pkg-config + perl + ]; + buildInputs = [ + clisp + libiconv + perl + ]; + + configureFlags = [ + "--with-clisp-runtime=system" + "--disable-xindy-docs" + "--disable-xindy-rules" + ]; + + preInstall = ''mkdir -p "$out/bin" ''; + # fixup various file-location errors of: lib/xindy/{xindy.mem,modules/} + postInstall = '' + mkdir -p "$out/lib/xindy" + mv "$out"/{bin/xindy.mem,lib/xindy/} + ''; + }; + + } diff --git a/pkgs/tools/typesetting/tex/texlive/build-tex-env.nix b/pkgs/tools/typesetting/tex/texlive/build-tex-env.nix index f72a0bdf3c8852..01ee20554031b7 100644 --- a/pkgs/tools/typesetting/tex/texlive/build-tex-env.nix +++ b/pkgs/tools/typesetting/tex/texlive/build-tex-env.nix @@ -1,315 +1,485 @@ { # texlive package set - tl -, bin - -, lib -, buildEnv -, libfaketime -, makeFontsConf -, makeWrapper -, runCommand -, writeShellScript -, writeText -, toTLPkgSets -, bash -, perl + tl, + bin, + + lib, + buildEnv, + libfaketime, + makeFontsConf, + makeWrapper, + runCommand, + writeShellScript, + writeText, + toTLPkgSets, + bash, + perl, # common runtime dependencies -, coreutils -, gawk -, gnugrep -, gnused -, ghostscript + coreutils, + gawk, + gnugrep, + gnused, + ghostscript, }: -lib.fix (self: { - withDocs ? false -, withSources ? false -, requiredTeXPackages ? ps: [ ps.scheme-infraonly ] - -### texlive.combine backward compatibility -, __extraName ? "combined" -, __extraVersion ? "" -# emulate the old texlive.combine (e.g. add man pages to main output) -, __combine ? false -# adjust behavior further if called from the texlive.combine wrapper -, __fromCombineWrapper ? false -# build only the formats of a package (for internal use!) -, __formatsOf ? null -}@args: - -let - ### buildEnv with custom attributes - buildEnv' = args: (buildEnv - ({ inherit (args) name paths; }) - // lib.optionalAttrs (args ? extraOutputsToInstall) { inherit (args) extraOutputsToInstall; }) - .overrideAttrs (removeAttrs args [ "extraOutputsToInstall" "name" "paths" "pkgs" ]); - - ### texlive.combine backward compatibility - # if necessary, convert old style { pkgs = [ ... ]; } packages to attribute sets - isOldPkgList = p: ! p.outputSpecified or false && p ? pkgs && builtins.all (p: p ? tlType) p.pkgs; - ensurePkgSets = ps: if ! __fromCombineWrapper && builtins.any isOldPkgList ps - then let oldPkgLists = builtins.partition isOldPkgList ps; - in oldPkgLists.wrong ++ lib.concatMap toTLPkgSets oldPkgLists.right - else ps; - - pkgList = rec { - # resolve dependencies of the packages that affect the runtime - all = - let - packages = ensurePkgSets (requiredTeXPackages tl); - runtime = builtins.partition - (p: p.outputSpecified or false -> builtins.elem (p.tlOutputName or p.outputName) [ "out" "tex" "tlpkg" ]) - packages; - keySet = p: { - key = p.pname or p.name + lib.optionalString (p.outputSpecified or false) ("-" + p.tlOutputName or p.outputName or ""); - inherit p; - tlDeps = if p ? tlDeps then ensurePkgSets p.tlDeps else (p.requiredTeXPackages or (_: [ ]) tl); - }; - in - # texlive.combine: the wrapper already resolves all dependencies - if __fromCombineWrapper then requiredTeXPackages null else - builtins.catAttrs "p" (builtins.genericClosure { - startSet = map keySet runtime.right; - operator = p: map keySet p.tlDeps; - }) ++ runtime.wrong; - - # group the specified outputs - specified = builtins.partition (p: p.outputSpecified or false) all; - specifiedOutputs = lib.groupBy (p: p.tlOutputName or p.outputName) specified.right; - otherOutputNames = builtins.catAttrs "key" (builtins.genericClosure { - startSet = map (key: { inherit key; }) (lib.concatLists (builtins.catAttrs "outputs" specified.wrong)); - operator = _: [ ]; - }); - otherOutputs = lib.genAttrs otherOutputNames (n: builtins.catAttrs n specified.wrong); - outputsToInstall = builtins.catAttrs "key" (builtins.genericClosure { - startSet = map (key: { inherit key; }) - ([ "out" ] ++ lib.optional (otherOutputs ? man) "man" - ++ lib.concatLists (builtins.catAttrs "outputsToInstall" (builtins.catAttrs "meta" specified.wrong))); - operator = _: [ ]; - }); - - # split binary and tlpkg from tex, texdoc, texsource - bin = if __fromCombineWrapper - then builtins.filter (p: p.tlType == "bin") all # texlive.combine: legacy filter - else otherOutputs.out or [ ] ++ specifiedOutputs.out or [ ]; - tlpkg = if __fromCombineWrapper - then builtins.filter (p: p.tlType == "tlpkg") all # texlive.combine: legacy filter - else otherOutputs.tlpkg or [ ] ++ specifiedOutputs.tlpkg or [ ]; - - nonbin = if __fromCombineWrapper then builtins.filter (p: p.tlType != "bin" && p.tlType != "tlpkg") all # texlive.combine: legacy filter - else (if __combine then # texlive.combine: emulate old input ordering to avoid rebuilds - lib.concatMap (p: lib.optional (p ? tex) p.tex - ++ lib.optional ((withDocs || p ? man) && p ? texdoc) p.texdoc - ++ lib.optional (withSources && p ? texsource) p.texsource) specified.wrong - else otherOutputs.tex or [ ] - ++ lib.optionals withDocs (otherOutputs.texdoc or [ ]) - ++ lib.optionals withSources (otherOutputs.texsource or [ ])) - ++ specifiedOutputs.tex or [ ] ++ specifiedOutputs.texdoc or [ ] ++ specifiedOutputs.texsource or [ ]; - - # outputs that do not become part of the environment - nonEnvOutputs = lib.subtractLists [ "out" "tex" "texdoc" "texsource" "tlpkg" ] otherOutputNames; - - # packages that contribute to config files and formats - fontMaps = lib.filter (p: p ? fontMaps && (p.tlOutputName or p.outputName == "tex")) nonbin; - sortedFontMaps = builtins.sort (a: b: a.pname < b.pname) fontMaps; - hyphenPatterns = lib.filter (p: p ? hyphenPatterns && (p.tlOutputName or p.outputName == "tex")) nonbin; - sortedHyphenPatterns = builtins.sort (a: b: a.pname < b.pname) hyphenPatterns; - formatPkgs = lib.filter (p: p ? formats && (p.outputSpecified or false -> p.tlOutputName or p.outputName == "tex") && builtins.any (f: f.enabled or true) p.formats) all; - sortedFormatPkgs = if __formatsOf != null then [ __formatsOf ] else builtins.sort (a: b: a.pname < b.pname) formatPkgs; - formats = map (p: self { requiredTeXPackages = ps: [ ps.scheme-infraonly p ] ++ hyphenPatterns; __formatsOf = p; }) sortedFormatPkgs; - }; - - # list generated by inspecting `grep -IR '\([^a-zA-Z]\|^\)gs\( \|$\|"\)' "$TEXMFDIST"/scripts` - # and `grep -IR rungs "$TEXMFDIST"` - # and ignoring luatex, perl, and shell scripts (those must be patched using postFixup) - needsGhostscript = lib.any (p: lib.elem p.pname [ "context" "dvipdfmx" "latex-papersize" "lyluatex" ]) pkgList.bin; - - name = if __combine then "texlive-${__extraName}-${bin.texliveYear}${__extraVersion}" # texlive.combine: old name name - else "texlive-${bin.texliveYear}-" + (if __formatsOf != null then "${__formatsOf.pname}-fmt" else "env"); - - texmfdist = buildEnv' { - name = "${name}-texmfdist"; - - # remove fake derivations (without 'outPath') to avoid undesired build dependencies - paths = builtins.catAttrs "outPath" pkgList.nonbin; - - # mktexlsr - nativeBuildInputs = [ tl."texlive.infra" ]; - - postBuild = # generate ls-R database - '' - mktexlsr "$out" - ''; - }; - - tlpkg = buildEnv { - name = "${name}-tlpkg"; - - # remove fake derivations (without 'outPath') to avoid undesired build dependencies - paths = builtins.catAttrs "outPath" pkgList.tlpkg; - }; - - # the 'non-relocated' packages must live in $TEXMFROOT/texmf-dist - # and sometimes look into $TEXMFROOT/tlpkg (notably fmtutil, updmap look for perl modules in both) - texmfroot = runCommand "${name}-texmfroot" { - inherit texmfdist tlpkg; - } '' - mkdir -p "$out" - ln -s "$texmfdist" "$out"/texmf-dist - ln -s "$tlpkg" "$out"/tlpkg - ''; - - # texlive.combine: expose info and man pages in usual /share/{info,man} location - doc = buildEnv { - name = "${name}-doc"; - - paths = [ (texmfdist.outPath + "/doc") ]; - extraPrefix = "/share"; - - pathsToLink = [ - "/info" - "/man" - ]; - }; - - meta = { - description = "TeX Live environment" - + lib.optionalString withDocs " with documentation" - + lib.optionalString (withDocs && withSources) " and" - + lib.optionalString withSources " with sources"; - platforms = lib.platforms.all; - longDescription = "Contains the following packages and their transitive dependencies:\n - " - + lib.concatMapStringsSep "\n - " - (p: p.pname + (lib.optionalString (p.outputSpecified or false) " (${p.tlOutputName or p.outputName})")) - (requiredTeXPackages tl); - }; - - # other outputs - nonEnvOutputs = lib.genAttrs pkgList.nonEnvOutputs (outName: buildEnv' { - inherit name; - outputs = [ outName ]; - paths = builtins.catAttrs "outPath" - (pkgList.otherOutputs.${outName} or [ ] ++ pkgList.specifiedOutputs.${outName} or [ ]); - # force the output to be ${outName} or nix-env will not work - nativeBuildInputs = [ (writeShellScript "force-output.sh" '' - export out="''${${outName}-}" - '') ]; - inherit meta passthru; - }); - - passthru = { - # This is set primarily to help find-tarballs.nix to do its job - requiredTeXPackages = builtins.filter lib.isDerivation (pkgList.bin ++ pkgList.nonbin - ++ lib.optionals (! __fromCombineWrapper) - (lib.concatMap (n: (pkgList.otherOutputs.${n} or [ ] ++ pkgList.specifiedOutputs.${n} or [ ])) pkgList.nonEnvOutputs)); - # useful for inclusion in the `fonts.packages` nixos option or for use in devshells - fonts = "${texmfroot}/texmf-dist/fonts"; - # support variants attrs, (prev: attrs) - __overrideTeXConfig = newArgs: - let appliedArgs = if builtins.isFunction newArgs then newArgs args else newArgs; in +lib.fix ( + self: + { + withDocs ? false, + withSources ? false, + requiredTeXPackages ? ps: [ ps.scheme-infraonly ], + + ### texlive.combine backward compatibility + __extraName ? "combined", + __extraVersion ? "", + # emulate the old texlive.combine (e.g. add man pages to main output) + __combine ? false, + # adjust behavior further if called from the texlive.combine wrapper + __fromCombineWrapper ? false, + # build only the formats of a package (for internal use!) + __formatsOf ? null, + }@args: + + let + ### buildEnv with custom attributes + buildEnv' = + args: + ( + buildEnv ({ inherit (args) name paths; }) + // lib.optionalAttrs (args ? extraOutputsToInstall) { inherit (args) extraOutputsToInstall; } + ).overrideAttrs + ( + removeAttrs args [ + "extraOutputsToInstall" + "name" + "paths" + "pkgs" + ] + ); + + ### texlive.combine backward compatibility + # if necessary, convert old style { pkgs = [ ... ]; } packages to attribute sets + isOldPkgList = p: !p.outputSpecified or false && p ? pkgs && builtins.all (p: p ? tlType) p.pkgs; + ensurePkgSets = + ps: + if !__fromCombineWrapper && builtins.any isOldPkgList ps then + let + oldPkgLists = builtins.partition isOldPkgList ps; + in + oldPkgLists.wrong ++ lib.concatMap toTLPkgSets oldPkgLists.right + else + ps; + + pkgList = rec { + # resolve dependencies of the packages that affect the runtime + all = + let + packages = ensurePkgSets (requiredTeXPackages tl); + runtime = builtins.partition ( + p: + p.outputSpecified or false + -> builtins.elem (p.tlOutputName or p.outputName) [ + "out" + "tex" + "tlpkg" + ] + ) packages; + keySet = p: { + key = + p.pname or p.name + + lib.optionalString (p.outputSpecified or false) ("-" + p.tlOutputName or p.outputName or ""); + inherit p; + tlDeps = if p ? tlDeps then ensurePkgSets p.tlDeps else (p.requiredTeXPackages or (_: [ ]) tl); + }; + in + # texlive.combine: the wrapper already resolves all dependencies + if __fromCombineWrapper then + requiredTeXPackages null + else + builtins.catAttrs "p" ( + builtins.genericClosure { + startSet = map keySet runtime.right; + operator = p: map keySet p.tlDeps; + } + ) + ++ runtime.wrong; + + # group the specified outputs + specified = builtins.partition (p: p.outputSpecified or false) all; + specifiedOutputs = lib.groupBy (p: p.tlOutputName or p.outputName) specified.right; + otherOutputNames = builtins.catAttrs "key" ( + builtins.genericClosure { + startSet = map (key: { inherit key; }) ( + lib.concatLists (builtins.catAttrs "outputs" specified.wrong) + ); + operator = _: [ ]; + } + ); + otherOutputs = lib.genAttrs otherOutputNames (n: builtins.catAttrs n specified.wrong); + outputsToInstall = builtins.catAttrs "key" ( + builtins.genericClosure { + startSet = map (key: { inherit key; }) ( + [ "out" ] + ++ lib.optional (otherOutputs ? man) "man" + ++ lib.concatLists (builtins.catAttrs "outputsToInstall" (builtins.catAttrs "meta" specified.wrong)) + ); + operator = _: [ ]; + } + ); + + # split binary and tlpkg from tex, texdoc, texsource + bin = + if __fromCombineWrapper then + builtins.filter (p: p.tlType == "bin") all # texlive.combine: legacy filter + else + otherOutputs.out or [ ] ++ specifiedOutputs.out or [ ]; + tlpkg = + if __fromCombineWrapper then + builtins.filter (p: p.tlType == "tlpkg") all # texlive.combine: legacy filter + else + otherOutputs.tlpkg or [ ] ++ specifiedOutputs.tlpkg or [ ]; + + nonbin = + if __fromCombineWrapper then + builtins.filter (p: p.tlType != "bin" && p.tlType != "tlpkg") all # texlive.combine: legacy filter + else + ( + if __combine then # texlive.combine: emulate old input ordering to avoid rebuilds + lib.concatMap ( + p: + lib.optional (p ? tex) p.tex + ++ lib.optional ((withDocs || p ? man) && p ? texdoc) p.texdoc + ++ lib.optional (withSources && p ? texsource) p.texsource + ) specified.wrong + else + otherOutputs.tex or [ ] + ++ lib.optionals withDocs (otherOutputs.texdoc or [ ]) + ++ lib.optionals withSources (otherOutputs.texsource or [ ]) + ) + ++ specifiedOutputs.tex or [ ] + ++ specifiedOutputs.texdoc or [ ] + ++ specifiedOutputs.texsource or [ ]; + + # outputs that do not become part of the environment + nonEnvOutputs = lib.subtractLists [ "out" "tex" "texdoc" "texsource" "tlpkg" ] otherOutputNames; + + # packages that contribute to config files and formats + fontMaps = lib.filter (p: p ? fontMaps && (p.tlOutputName or p.outputName == "tex")) nonbin; + sortedFontMaps = builtins.sort (a: b: a.pname < b.pname) fontMaps; + hyphenPatterns = lib.filter ( + p: p ? hyphenPatterns && (p.tlOutputName or p.outputName == "tex") + ) nonbin; + sortedHyphenPatterns = builtins.sort (a: b: a.pname < b.pname) hyphenPatterns; + formatPkgs = lib.filter ( + p: + p ? formats + && (p.outputSpecified or false -> p.tlOutputName or p.outputName == "tex") + && builtins.any (f: f.enabled or true) p.formats + ) all; + sortedFormatPkgs = + if __formatsOf != null then [ __formatsOf ] else builtins.sort (a: b: a.pname < b.pname) formatPkgs; + formats = map ( + p: + self { + requiredTeXPackages = + ps: + [ + ps.scheme-infraonly + p + ] + ++ hyphenPatterns; + __formatsOf = p; + } + ) sortedFormatPkgs; + }; + + # list generated by inspecting `grep -IR '\([^a-zA-Z]\|^\)gs\( \|$\|"\)' "$TEXMFDIST"/scripts` + # and `grep -IR rungs "$TEXMFDIST"` + # and ignoring luatex, perl, and shell scripts (those must be patched using postFixup) + needsGhostscript = lib.any ( + p: + lib.elem p.pname [ + "context" + "dvipdfmx" + "latex-papersize" + "lyluatex" + ] + ) pkgList.bin; + + name = + if __combine then + "texlive-${__extraName}-${bin.texliveYear}${__extraVersion}" # texlive.combine: old name name + else + "texlive-${bin.texliveYear}-" + (if __formatsOf != null then "${__formatsOf.pname}-fmt" else "env"); + + texmfdist = buildEnv' { + name = "${name}-texmfdist"; + + # remove fake derivations (without 'outPath') to avoid undesired build dependencies + paths = builtins.catAttrs "outPath" pkgList.nonbin; + + # mktexlsr + nativeBuildInputs = [ tl."texlive.infra" ]; + + postBuild = # generate ls-R database + '' + mktexlsr "$out" + ''; + }; + + tlpkg = buildEnv { + name = "${name}-tlpkg"; + + # remove fake derivations (without 'outPath') to avoid undesired build dependencies + paths = builtins.catAttrs "outPath" pkgList.tlpkg; + }; + + # the 'non-relocated' packages must live in $TEXMFROOT/texmf-dist + # and sometimes look into $TEXMFROOT/tlpkg (notably fmtutil, updmap look for perl modules in both) + texmfroot = + runCommand "${name}-texmfroot" + { + inherit texmfdist tlpkg; + } + '' + mkdir -p "$out" + ln -s "$texmfdist" "$out"/texmf-dist + ln -s "$tlpkg" "$out"/tlpkg + ''; + + # texlive.combine: expose info and man pages in usual /share/{info,man} location + doc = buildEnv { + name = "${name}-doc"; + + paths = [ (texmfdist.outPath + "/doc") ]; + extraPrefix = "/share"; + + pathsToLink = [ + "/info" + "/man" + ]; + }; + + meta = { + description = + "TeX Live environment" + + lib.optionalString withDocs " with documentation" + + lib.optionalString (withDocs && withSources) " and" + + lib.optionalString withSources " with sources"; + platforms = lib.platforms.all; + longDescription = + "Contains the following packages and their transitive dependencies:\n - " + + lib.concatMapStringsSep "\n - " ( + p: + p.pname + (lib.optionalString (p.outputSpecified or false) " (${p.tlOutputName or p.outputName})") + ) (requiredTeXPackages tl); + }; + + # other outputs + nonEnvOutputs = lib.genAttrs pkgList.nonEnvOutputs ( + outName: + buildEnv' { + inherit name; + outputs = [ outName ]; + paths = builtins.catAttrs "outPath" ( + pkgList.otherOutputs.${outName} or [ ] ++ pkgList.specifiedOutputs.${outName} or [ ] + ); + # force the output to be ${outName} or nix-env will not work + nativeBuildInputs = [ + (writeShellScript "force-output.sh" '' + export out="''${${outName}-}" + '') + ]; + inherit meta passthru; + } + ); + + passthru = { + # This is set primarily to help find-tarballs.nix to do its job + requiredTeXPackages = builtins.filter lib.isDerivation ( + pkgList.bin + ++ pkgList.nonbin + ++ lib.optionals (!__fromCombineWrapper) ( + lib.concatMap ( + n: (pkgList.otherOutputs.${n} or [ ] ++ pkgList.specifiedOutputs.${n} or [ ]) + ) pkgList.nonEnvOutputs + ) + ); + # useful for inclusion in the `fonts.packages` nixos option or for use in devshells + fonts = "${texmfroot}/texmf-dist/fonts"; + # support variants attrs, (prev: attrs) + __overrideTeXConfig = + newArgs: + let + appliedArgs = if builtins.isFunction newArgs then newArgs args else newArgs; + in self (args // { __fromCombineWrapper = false; } // appliedArgs); - withPackages = reqs: self (args // { requiredTeXPackages = ps: reqs ps ++ requiredTeXPackages ps; __fromCombineWrapper = false; }); - }; - - # TeXLive::TLOBJ::fmtutil_cnf_lines - fmtutilLine = { name, engine, enabled ? true, patterns ? [ "-" ], options ? "", ... }: - lib.optionalString (! enabled) "#! " + "${name} ${engine} ${lib.concatStringsSep "," patterns} ${options}"; - fmtutilLines = { pname, formats, ...}: - [ "#" "# from ${pname}:" ] ++ map fmtutilLine formats; - - # TeXLive::TLOBJ::language_dat_lines - langDatLine = { name, file, synonyms ? [ ], ... }: - [ "${name} ${file}" ] ++ map (s: "=" + s) synonyms; - langDatLines = { pname, hyphenPatterns, ... }: - [ "% from ${pname}:" ] ++ builtins.concatMap langDatLine hyphenPatterns; - - # TeXLive::TLOBJ::language_def_lines - # see TeXLive::TLUtils::parse_AddHyphen_line for default values - langDefLine = { name, file, lefthyphenmin ? "", righthyphenmin ? "", synonyms ? [ ], ... }: - map (n: "\\addlanguage{${n}}{${file}}{}{${if lefthyphenmin == "" then "2" else lefthyphenmin}}{${if righthyphenmin == "" then "3" else righthyphenmin}}") - ([ name ] ++ synonyms); - langDefLines = { pname, hyphenPatterns, ... }: - [ "% from ${pname}:" ] ++ builtins.concatMap langDefLine hyphenPatterns; - - # TeXLive::TLOBJ::language_lua_lines - # see TeXLive::TLUtils::parse_AddHyphen_line for default values - langLuaLine = { name, file, lefthyphenmin ? "", righthyphenmin ? "", synonyms ? [ ], ... }@args: '' - ''\t['${name}'] = { - ''\t''\tloader = '${file}', - ''\t''\tlefthyphenmin = ${if lefthyphenmin == "" then "2" else lefthyphenmin}, - ''\t''\trighthyphenmin = ${if righthyphenmin == "" then "3" else righthyphenmin}, - ''\t''\tsynonyms = { ${lib.concatStringsSep ", " (map (s: "'${s}'") synonyms)} }, - '' - + lib.optionalString (args ? file_patterns) "\t\tpatterns = '${args.file_patterns}',\n" - + lib.optionalString (args ? file_exceptions) "\t\thyphenation = '${args.file_exceptions}',\n" - + lib.optionalString (args ? luaspecial) "\t\tspecial = '${args.luaspecial}',\n" - + "\t},"; - langLuaLines = { pname, hyphenPatterns, ... }: - [ "-- from ${pname}:" ] ++ map langLuaLine hyphenPatterns; - - assembleConfigLines = f: packages: - builtins.concatStringsSep "\n" (builtins.concatMap f packages); - - updmapLines = { pname, fontMaps, ...}: - [ "# from ${pname}:" ] ++ fontMaps; - - out = -# no indent for git diff purposes -buildEnv' { - - inherit name; - - # use attrNames, attrValues to ensure the two lists are sorted in the same way - outputs = [ "out" ] ++ lib.optionals (! __combine && __formatsOf == null) (builtins.attrNames nonEnvOutputs); - otherOutputs = lib.optionals (! __combine && __formatsOf == null) (builtins.attrValues nonEnvOutputs); - - # remove fake derivations (without 'outPath') to avoid undesired build dependencies - paths = builtins.catAttrs "outPath" pkgList.bin ++ lib.optionals (! __combine && __formatsOf == null) pkgList.formats - ++ lib.optional __combine doc; - pathsToLink = [ - "/" - "/share/texmf-var/scripts" - "/share/texmf-var/tex/generic/config" - "/share/texmf-var/web2c" - "/share/texmf-config" - "/bin" # ensure these are writeable directories - ]; - - nativeBuildInputs = [ - makeWrapper - libfaketime - tl."texlive.infra" # mktexlsr - tl.texlive-scripts # fmtutil, updmap - tl.texlive-scripts-extra # texlinks - perl - ]; - - buildInputs = [ coreutils gawk gnugrep gnused ] ++ lib.optional needsGhostscript ghostscript; - - inherit meta passthru __combine; - __formatsOf = __formatsOf.pname or null; - - inherit texmfdist texmfroot; - - fontconfigFile = makeFontsConf { fontDirectories = [ "${texmfroot}/texmf-dist/fonts" ]; }; - - fmtutilCnf = assembleConfigLines fmtutilLines pkgList.sortedFormatPkgs; - updmapCfg = assembleConfigLines updmapLines pkgList.sortedFontMaps; - - languageDat = assembleConfigLines langDatLines pkgList.sortedHyphenPatterns; - languageDef = assembleConfigLines langDefLines pkgList.sortedHyphenPatterns; - languageLua = assembleConfigLines langLuaLines pkgList.sortedHyphenPatterns; - - postactionScripts = builtins.catAttrs "postactionScript" pkgList.tlpkg; - - postBuild = '' - . "${./build-tex-env.sh}" - ''; - - allowSubstitutes = true; - preferLocalBuild = false; -}; + withPackages = + reqs: + self ( + args + // { + requiredTeXPackages = ps: reqs ps ++ requiredTeXPackages ps; + __fromCombineWrapper = false; + } + ); + }; + + # TeXLive::TLOBJ::fmtutil_cnf_lines + fmtutilLine = + { + name, + engine, + enabled ? true, + patterns ? [ "-" ], + options ? "", + ... + }: + lib.optionalString (!enabled) "#! " + + "${name} ${engine} ${lib.concatStringsSep "," patterns} ${options}"; + fmtutilLines = + { pname, formats, ... }: + [ + "#" + "# from ${pname}:" + ] + ++ map fmtutilLine formats; + + # TeXLive::TLOBJ::language_dat_lines + langDatLine = + { + name, + file, + synonyms ? [ ], + ... + }: + [ "${name} ${file}" ] ++ map (s: "=" + s) synonyms; + langDatLines = + { pname, hyphenPatterns, ... }: + [ "% from ${pname}:" ] ++ builtins.concatMap langDatLine hyphenPatterns; + + # TeXLive::TLOBJ::language_def_lines + # see TeXLive::TLUtils::parse_AddHyphen_line for default values + langDefLine = + { + name, + file, + lefthyphenmin ? "", + righthyphenmin ? "", + synonyms ? [ ], + ... + }: + map ( + n: + "\\addlanguage{${n}}{${file}}{}{${if lefthyphenmin == "" then "2" else lefthyphenmin}}{${ + if righthyphenmin == "" then "3" else righthyphenmin + }}" + ) ([ name ] ++ synonyms); + langDefLines = + { pname, hyphenPatterns, ... }: + [ "% from ${pname}:" ] ++ builtins.concatMap langDefLine hyphenPatterns; + + # TeXLive::TLOBJ::language_lua_lines + # see TeXLive::TLUtils::parse_AddHyphen_line for default values + langLuaLine = + { + name, + file, + lefthyphenmin ? "", + righthyphenmin ? "", + synonyms ? [ ], + ... + }@args: + '' + ''\t['${name}'] = { + ''\t''\tloader = '${file}', + ''\t''\tlefthyphenmin = ${if lefthyphenmin == "" then "2" else lefthyphenmin}, + ''\t''\trighthyphenmin = ${if righthyphenmin == "" then "3" else righthyphenmin}, + ''\t''\tsynonyms = { ${lib.concatStringsSep ", " (map (s: "'${s}'") synonyms)} }, + '' + + lib.optionalString (args ? file_patterns) "\t\tpatterns = '${args.file_patterns}',\n" + + lib.optionalString (args ? file_exceptions) "\t\thyphenation = '${args.file_exceptions}',\n" + + lib.optionalString (args ? luaspecial) "\t\tspecial = '${args.luaspecial}',\n" + + "\t},"; + langLuaLines = + { pname, hyphenPatterns, ... }: [ "-- from ${pname}:" ] ++ map langLuaLine hyphenPatterns; + + assembleConfigLines = f: packages: builtins.concatStringsSep "\n" (builtins.concatMap f packages); + + updmapLines = { pname, fontMaps, ... }: [ "# from ${pname}:" ] ++ fontMaps; + + out = + # no indent for git diff purposes + buildEnv' { + + inherit name; + + # use attrNames, attrValues to ensure the two lists are sorted in the same way + outputs = [ + "out" + ] ++ lib.optionals (!__combine && __formatsOf == null) (builtins.attrNames nonEnvOutputs); + otherOutputs = lib.optionals (!__combine && __formatsOf == null) ( + builtins.attrValues nonEnvOutputs + ); + + # remove fake derivations (without 'outPath') to avoid undesired build dependencies + paths = + builtins.catAttrs "outPath" pkgList.bin + ++ lib.optionals (!__combine && __formatsOf == null) pkgList.formats + ++ lib.optional __combine doc; + pathsToLink = [ + "/" + "/share/texmf-var/scripts" + "/share/texmf-var/tex/generic/config" + "/share/texmf-var/web2c" + "/share/texmf-config" + "/bin" # ensure these are writeable directories + ]; + + nativeBuildInputs = [ + makeWrapper + libfaketime + tl."texlive.infra" # mktexlsr + tl.texlive-scripts # fmtutil, updmap + tl.texlive-scripts-extra # texlinks + perl + ]; + + buildInputs = [ + coreutils + gawk + gnugrep + gnused + ] ++ lib.optional needsGhostscript ghostscript; + + inherit meta passthru __combine; + __formatsOf = __formatsOf.pname or null; + + inherit texmfdist texmfroot; + + fontconfigFile = makeFontsConf { fontDirectories = [ "${texmfroot}/texmf-dist/fonts" ]; }; + + fmtutilCnf = assembleConfigLines fmtutilLines pkgList.sortedFormatPkgs; + updmapCfg = assembleConfigLines updmapLines pkgList.sortedFontMaps; + + languageDat = assembleConfigLines langDatLines pkgList.sortedHyphenPatterns; + languageDef = assembleConfigLines langDefLines pkgList.sortedHyphenPatterns; + languageLua = assembleConfigLines langLuaLines pkgList.sortedHyphenPatterns; + + postactionScripts = builtins.catAttrs "postactionScript" pkgList.tlpkg; + + postBuild = '' + . "${./build-tex-env.sh}" + ''; + + allowSubstitutes = true; + preferLocalBuild = false; + }; + in # outputsToInstall must be set *after* overrideAttrs (used in buildEnv') or it fails the checkMeta tests -in if __combine || __formatsOf != null then out else lib.addMetaAttrs { inherit (pkgList) outputsToInstall; } out) + if __combine || __formatsOf != null then + out + else + lib.addMetaAttrs { inherit (pkgList) outputsToInstall; } out +) diff --git a/pkgs/tools/typesetting/tex/texlive/combine-wrapper.nix b/pkgs/tools/typesetting/tex/texlive/combine-wrapper.nix index 165e7a22c6612c..8401de27304419 100644 --- a/pkgs/tools/typesetting/tex/texlive/combine-wrapper.nix +++ b/pkgs/tools/typesetting/tex/texlive/combine-wrapper.nix @@ -1,35 +1,71 @@ # legacy texlive.combine wrapper -{ lib, toTLPkgList, toTLPkgSets, buildTeXEnv }: +{ + lib, + toTLPkgList, + toTLPkgSets, + buildTeXEnv, +}: args@{ - pkgFilter ? (pkg: pkg.tlType == "run" || pkg.tlType == "bin" || pkg.pname == "core" - || pkg.hasManpages or false) -, extraName ? "combined" -, extraVersion ? "" -, ... + pkgFilter ? ( + pkg: pkg.tlType == "run" || pkg.tlType == "bin" || pkg.pname == "core" || pkg.hasManpages or false + ), + extraName ? "combined", + extraVersion ? "", + ... }: let - pkgSet = removeAttrs args [ "pkgFilter" "extraName" "extraVersion" ]; + pkgSet = removeAttrs args [ + "pkgFilter" + "extraName" + "extraVersion" + ]; # combine a set of TL packages into a single TL meta-package - combinePkgs = pkgList: lib.catAttrs "pkg" ( - let - # a TeX package used to be an attribute set { pkgs = [ ... ]; ... } where pkgs is a list of derivations - # the derivations make up the TeX package and optionally (for backward compatibility) its dependencies - tlPkgToSets = drv: map ({ tlType, version ? "", outputName ? "", ... }@pkg: { - # outputName required to distinguish among bin.core-big outputs - key = "${pkg.pname or pkg.name}.${tlType}-${version}-${outputName}"; - inherit pkg; - }) (drv.pkgs or (toTLPkgList drv)); - pkgListToSets = lib.concatMap tlPkgToSets; in - builtins.genericClosure { - startSet = pkgListToSets pkgList; - operator = { pkg, ... }: pkgListToSets (pkg.tlDeps or []); - }); + combinePkgs = + pkgList: + lib.catAttrs "pkg" ( + let + # a TeX package used to be an attribute set { pkgs = [ ... ]; ... } where pkgs is a list of derivations + # the derivations make up the TeX package and optionally (for backward compatibility) its dependencies + tlPkgToSets = + drv: + map ( + { + tlType, + version ? "", + outputName ? "", + ... + }@pkg: + { + # outputName required to distinguish among bin.core-big outputs + key = "${pkg.pname or pkg.name}.${tlType}-${version}-${outputName}"; + inherit pkg; + } + ) (drv.pkgs or (toTLPkgList drv)); + pkgListToSets = lib.concatMap tlPkgToSets; + in + builtins.genericClosure { + startSet = pkgListToSets pkgList; + operator = { pkg, ... }: pkgListToSets (pkg.tlDeps or [ ]); + } + ); combined = combinePkgs (lib.attrValues pkgSet); # convert to specified outputs - tlTypeToOut = { run = "tex"; doc = "texdoc"; source = "texsource"; bin = "out"; tlpkg = "tlpkg"; }; - toSpecified = { tlType, ... }@drv: drv // { outputSpecified = true; tlOutputName = tlTypeToOut.${tlType}; }; + tlTypeToOut = { + run = "tex"; + doc = "texdoc"; + source = "texsource"; + bin = "out"; + tlpkg = "tlpkg"; + }; + toSpecified = + { tlType, ... }@drv: + drv + // { + outputSpecified = true; + tlOutputName = tlTypeToOut.${tlType}; + }; all = lib.filter pkgFilter combined ++ lib.filter (pkg: pkg.tlType == "tlpkg") combined; converted = builtins.map toSpecified all; in diff --git a/pkgs/tools/typesetting/tex/texlive/generate-fixed-hashes.nix b/pkgs/tools/typesetting/tex/texlive/generate-fixed-hashes.nix index 0cff459bc620bb..3e0a8eefd277a9 100644 --- a/pkgs/tools/typesetting/tex/texlive/generate-fixed-hashes.nix +++ b/pkgs/tools/typesetting/tex/texlive/generate-fixed-hashes.nix @@ -1,7 +1,14 @@ -{ pkgs ? (import ../../../../.. { }) }: +{ + pkgs ? (import ../../../../.. { }), +}: let - inherit (pkgs) runCommand writeText texlive nix; + inherit (pkgs) + runCommand + writeText + texlive + nix + ; inherit (pkgs.lib) attrValues concatMap @@ -14,7 +21,9 @@ let strings ; - getFods = drv: optional (isDerivation drv.tex) (drv.tex // { tlType = "run"; }) + getFods = + drv: + optional (isDerivation drv.tex) (drv.tex // { tlType = "run"; }) ++ optional (drv ? texdoc) (drv.texdoc // { tlType = "doc"; }) ++ optional (drv ? texsource) (drv.texsource // { tlType = "source"; }) ++ optional (drv ? tlpkg) (drv.tlpkg // { tlType = "tlpkg"; }); @@ -22,16 +31,24 @@ let sorted = sort (a: b: a.pname < b.pname) (attrValues texlive.pkgs); fods = concatMap getFods sorted; - computeHash = fod: runCommand "${fod.pname}-${fod.tlType}-fixed-hash" - { buildInputs = [ nix ]; inherit fod; } - ''echo -n "$(nix-hash --base32 --type sha256 "$fod")" >"$out"''; + computeHash = + fod: + runCommand "${fod.pname}-${fod.tlType}-fixed-hash" { + buildInputs = [ nix ]; + inherit fod; + } ''echo -n "$(nix-hash --base32 --type sha256 "$fod")" >"$out"''; hash = fod: fod.outputHash or (builtins.readFile (computeHash fod)); - hashes = fods: - concatMapStrings ({ tlType, ... }@p: ''${tlType}="${hash p}";'') fods; + hashes = fods: concatMapStrings ({ tlType, ... }@p: ''${tlType}="${hash p}";'') fods; - hashLine = { pname, revision, extraRevision ? "", ... }@drv: + hashLine = + { + pname, + revision, + extraRevision ? "", + ... + }@drv: let fods = getFods drv; # NOTE: the fixed naming scheme must match default.nix @@ -44,11 +61,10 @@ in { # fixedHashesNix uses 'import from derivation' which does not parallelize well # you should build newHashes first, before evaluating (and building) fixedHashesNix - newHashes = map computeHash (filter (fod: ! fod ? outputHash) fods); + newHashes = map computeHash (filter (fod: !fod ? outputHash) fods); - fixedHashesNix = writeText "fixed-hashes.nix" - '' - { - ${concatMapStrings hashLine sorted}} - ''; + fixedHashesNix = writeText "fixed-hashes.nix" '' + { + ${concatMapStrings hashLine sorted}} + ''; } diff --git a/pkgs/tools/typesetting/tex/texlive/tlpdb-overrides.nix b/pkgs/tools/typesetting/tex/texlive/tlpdb-overrides.nix index bdee4510e4cd30..78c2716b885645 100644 --- a/pkgs/tools/typesetting/tex/texlive/tlpdb-overrides.nix +++ b/pkgs/tools/typesetting/tex/texlive/tlpdb-overrides.nix @@ -1,7 +1,27 @@ -{ stdenv, lib, tlpdb, bin, tlpdbxz, tl -, installShellFiles -, coreutils, findutils, gawk, getopt, ghostscript_headless, gnugrep -, gnumake, gnupg, gnused, gzip, html-tidy, ncurses, perl, python3, ruby, zip +{ + stdenv, + lib, + tlpdb, + bin, + tlpdbxz, + tl, + installShellFiles, + coreutils, + findutils, + gawk, + getopt, + ghostscript_headless, + gnugrep, + gnumake, + gnupg, + gnused, + gzip, + html-tidy, + ncurses, + perl, + python3, + ruby, + zip, }: oldTlpdb: @@ -9,20 +29,33 @@ oldTlpdb: let tlpdbVersion = tlpdb."00texlive.config"; - # most format -> engine links are generated by texlinks according to fmtutil.cnf at combine time - # so we remove them from binfiles, and add back the ones texlinks purposefully ignore (e.g. mptopdf) - removeFormatLinks = lib.mapAttrs (_: attrs: - if (attrs ? formats && attrs ? binfiles) - # TLPDB reports erroneously that various metafont binaries like "mf" are format links to engines - # like "mf-nowin"; core-big provides both binaries and links so we simply skip them here - then let formatLinks = lib.catAttrs "name" (lib.filter (f: f.name != f.engine && ! lib.hasSuffix "-nowin" f.engine) attrs.formats); - binNotFormats = lib.subtractLists formatLinks attrs.binfiles; - in if binNotFormats != [] then attrs // { binfiles = binNotFormats; } else removeAttrs attrs [ "binfiles" ] - else attrs); - - orig = removeFormatLinks (removeAttrs oldTlpdb [ "00texlive.config" ]); - -in lib.recursiveUpdate orig rec { + # most format -> engine links are generated by texlinks according to fmtutil.cnf at combine time + # so we remove them from binfiles, and add back the ones texlinks purposefully ignore (e.g. mptopdf) + removeFormatLinks = lib.mapAttrs ( + _: attrs: + if + (attrs ? formats && attrs ? binfiles) + # TLPDB reports erroneously that various metafont binaries like "mf" are format links to engines + # like "mf-nowin"; core-big provides both binaries and links so we simply skip them here + then + let + formatLinks = lib.catAttrs "name" ( + lib.filter (f: f.name != f.engine && !lib.hasSuffix "-nowin" f.engine) attrs.formats + ); + binNotFormats = lib.subtractLists formatLinks attrs.binfiles; + in + if binNotFormats != [ ] then + attrs // { binfiles = binNotFormats; } + else + removeAttrs attrs [ "binfiles" ] + else + attrs + ); + + orig = removeFormatLinks (removeAttrs oldTlpdb [ "00texlive.config" ]); + +in +lib.recursiveUpdate orig rec { #### overrides of texlive.tlpdb #### nonstandard script folders @@ -44,15 +77,53 @@ in lib.recursiveUpdate orig rec { texlogsieve.extraBuildInputs = [ bin.luatex ]; #### perl packages - crossrefware.extraBuildInputs = [ (perl.withPackages (ps: with ps; [ LWP URI ])) ]; - ctan-o-mat.extraBuildInputs = [ (perl.withPackages (ps: with ps; [ LWP LWPProtocolHttps ])) ]; + crossrefware.extraBuildInputs = [ + (perl.withPackages ( + ps: with ps; [ + LWP + URI + ] + )) + ]; + ctan-o-mat.extraBuildInputs = [ + (perl.withPackages ( + ps: with ps; [ + LWP + LWPProtocolHttps + ] + )) + ]; ctanify.extraBuildInputs = [ (perl.withPackages (ps: with ps; [ FileCopyRecursive ])) ]; - ctanupload.extraBuildInputs = [ (perl.withPackages (ps: with ps; [ HTMLFormatter WWWMechanize ])) ]; + ctanupload.extraBuildInputs = [ + (perl.withPackages ( + ps: with ps; [ + HTMLFormatter + WWWMechanize + ] + )) + ]; exceltex.extraBuildInputs = [ (perl.withPackages (ps: with ps; [ SpreadsheetParseExcel ])) ]; latex-git-log.extraBuildInputs = [ (perl.withPackages (ps: with ps; [ IPCSystemSimple ])) ]; - latexindent.extraBuildInputs = [ (perl.withPackages (ps: with ps; [ FileHomeDir LogDispatch LogLog4perl UnicodeLineBreak YAMLTiny ])) ]; + latexindent.extraBuildInputs = [ + (perl.withPackages ( + ps: with ps; [ + FileHomeDir + LogDispatch + LogLog4perl + UnicodeLineBreak + YAMLTiny + ] + )) + ]; pax.extraBuildInputs = [ (perl.withPackages (ps: with ps; [ FileWhich ])) ]; - pdflatexpicscale.extraBuildInputs = [ (perl.withPackages (ps: with ps; [ GD ImageExifTool ])) ]; + pdflatexpicscale.extraBuildInputs = [ + (perl.withPackages ( + ps: with ps; [ + GD + ImageExifTool + ] + )) + ]; ptex-fontmaps.extraBuildInputs = [ (perl.withPackages (ps: with ps; [ Tk ])) ]; purifyeps.extraBuildInputs = [ (perl.withPackages (ps: with ps; [ FileWhich ])) ]; sqltex.extraBuildInputs = [ (perl.withPackages (ps: with ps; [ DBI ])) ]; @@ -69,34 +140,81 @@ in lib.recursiveUpdate orig rec { bibexport.extraBuildInputs = [ gnugrep ]; checklistings.extraBuildInputs = [ coreutils ]; cjk-gs-integrate.extraBuildInputs = [ ghostscript_headless ]; - cyrillic-bin.extraBuildInputs = [ coreutils gnused ]; - dtxgen.extraBuildInputs = [ coreutils getopt gnumake zip ]; + cyrillic-bin.extraBuildInputs = [ + coreutils + gnused + ]; + dtxgen.extraBuildInputs = [ + coreutils + getopt + gnumake + zip + ]; dviljk.extraBuildInputs = [ coreutils ]; epspdf.extraBuildInputs = [ ghostscript_headless ]; epstopdf.extraBuildInputs = [ ghostscript_headless ]; fragmaster.extraBuildInputs = [ ghostscript_headless ]; - installfont.extraBuildInputs = [ coreutils getopt gnused ]; - latexfileversion.extraBuildInputs = [ coreutils gnugrep gnused ]; - listings-ext.extraBuildInputs = [ coreutils getopt ]; - ltxfileinfo.extraBuildInputs = [ coreutils getopt gnused ]; + installfont.extraBuildInputs = [ + coreutils + getopt + gnused + ]; + latexfileversion.extraBuildInputs = [ + coreutils + gnugrep + gnused + ]; + listings-ext.extraBuildInputs = [ + coreutils + getopt + ]; + ltxfileinfo.extraBuildInputs = [ + coreutils + getopt + gnused + ]; ltximg.extraBuildInputs = [ ghostscript_headless ]; luaotfload.extraBuildInputs = [ ncurses ]; - makeindex.extraBuildInputs = [ coreutils gnused ]; - pagelayout.extraBuildInputs = [ gnused ncurses ]; + makeindex.extraBuildInputs = [ + coreutils + gnused + ]; + pagelayout.extraBuildInputs = [ + gnused + ncurses + ]; pdfcrop.extraBuildInputs = [ ghostscript_headless ]; - pdftex.extraBuildInputs = [ coreutils ghostscript_headless gnused ]; + pdftex.extraBuildInputs = [ + coreutils + ghostscript_headless + gnused + ]; pdftex-quiet.extraBuildInputs = [ coreutils ]; - pdfxup.extraBuildInputs = [ coreutils ghostscript_headless ]; + pdfxup.extraBuildInputs = [ + coreutils + ghostscript_headless + ]; pkfix-helper.extraBuildInputs = [ ghostscript_headless ]; ps2eps.extraBuildInputs = [ ghostscript_headless ]; pst2pdf.extraBuildInputs = [ ghostscript_headless ]; tex4ebook.extraBuildInputs = [ html-tidy ]; texlive-scripts.extraBuildInputs = [ gnused ]; - texlive-scripts-extra.extraBuildInputs = [ coreutils findutils ghostscript_headless gnused ]; + texlive-scripts-extra.extraBuildInputs = [ + coreutils + findutils + ghostscript_headless + gnused + ]; thumbpdf.extraBuildInputs = [ ghostscript_headless ]; tpic2pdftex.extraBuildInputs = [ gawk ]; - wordcount.extraBuildInputs = [ coreutils gnugrep ]; - xdvi.extraBuildInputs = [ coreutils gnugrep ]; + wordcount.extraBuildInputs = [ + coreutils + gnugrep + ]; + xdvi.extraBuildInputs = [ + coreutils + gnugrep + ]; xindy.extraBuildInputs = [ gzip ]; #### adjustments to binaries @@ -104,14 +222,13 @@ in lib.recursiveUpdate orig rec { # mptopdf is a format link, but not generated by texlinks # so we add it back to binfiles to generate it from mkPkgBin - mptopdf.binfiles = (orig.mptopdf.binfiles or []) ++ [ "mptopdf" ]; + mptopdf.binfiles = (orig.mptopdf.binfiles or [ ]) ++ [ "mptopdf" ]; # remove man texlive-scripts.binfiles = lib.remove "man" orig.texlive-scripts.binfiles; # xindy is broken on some platforms unfortunately - xindy.binfiles = if bin ? xindy - then lib.subtractLists [ "xindy.mem" "xindy.run" ] orig.xindy.binfiles - else []; + xindy.binfiles = + if bin ? xindy then lib.subtractLists [ "xindy.mem" "xindy.run" ] orig.xindy.binfiles else [ ]; #### additional symlinks cluttex.binlinks = { @@ -233,8 +350,15 @@ in lib.recursiveUpdate orig rec { ''; pdftex.postFixup = '' - sed -i -e '2iPATH="${lib.makeBinPath [ coreutils gnused ]}''${PATH:+:$PATH}"' \ - -e 's!^distillerpath="/usr/local/bin"$!distillerpath="${lib.makeBinPath [ ghostscript_headless ]}"!' \ + sed -i -e '2iPATH="${ + lib.makeBinPath [ + coreutils + gnused + ] + }''${PATH:+:$PATH}"' \ + -e 's!^distillerpath="/usr/local/bin"$!distillerpath="${ + lib.makeBinPath [ ghostscript_headless ] + }"!' \ "$out"/bin/simpdftex ''; @@ -319,10 +443,25 @@ in lib.recursiveUpdate orig rec { texlive-scripts-extra.postFixup = '' patch -R "$out"/bin/texlinks < '${./texlinks.diff}' sed -i '2iPATH="${lib.makeBinPath [ coreutils ]}''${PATH:+:$PATH}"' "$out"/bin/{allcm,dvired,mkocp,ps2frag} - sed -i '2iPATH="${lib.makeBinPath [ coreutils findutils ]}''${PATH:+:$PATH}"' "$out"/bin/allneeded - sed -i '2iPATH="${lib.makeBinPath [ coreutils ghostscript_headless ]}''${PATH:+:$PATH}"' "$out"/bin/dvi2fax + sed -i '2iPATH="${ + lib.makeBinPath [ + coreutils + findutils + ] + }''${PATH:+:$PATH}"' "$out"/bin/allneeded + sed -i '2iPATH="${ + lib.makeBinPath [ + coreutils + ghostscript_headless + ] + }''${PATH:+:$PATH}"' "$out"/bin/dvi2fax sed -i '2iPATH="${lib.makeBinPath [ gnused ]}''${PATH:+:$PATH}"' "$out"/bin/{kpsetool,texconfig,texconfig-sys} - sed -i '2iPATH="${lib.makeBinPath [ coreutils gnused ]}''${PATH:+:$PATH}"' "$out"/bin/texconfig-dialog + sed -i '2iPATH="${ + lib.makeBinPath [ + coreutils + gnused + ] + }''${PATH:+:$PATH}"' "$out"/bin/texconfig-dialog ''; # patch interpreter @@ -333,7 +472,9 @@ in lib.recursiveUpdate orig rec { # hardcode revision numbers (since texlive.infra, tlshell are not in either system or user texlive.tlpdb) tlshell.postFixup = '' substituteInPlace "$out"/bin/tlshell \ - --replace-fail '[dict get $::pkgs texlive.infra localrev]' '${toString orig."texlive.infra".revision}' \ + --replace-fail '[dict get $::pkgs texlive.infra localrev]' '${ + toString orig."texlive.infra".revision + }' \ --replace-fail '[dict get $::pkgs tlshell localrev]' '${toString orig.tlshell.revision}' ''; @@ -353,9 +494,9 @@ in lib.recursiveUpdate orig rec { #### misc # RISC-V: https://github.com/LuaJIT/LuaJIT/issues/628 - luajittex.binfiles = lib.optionals - (!(stdenv.hostPlatform.isPower && stdenv.hostPlatform.is64bit) && !stdenv.hostPlatform.isRiscV) - orig.luajittex.binfiles; + luajittex.binfiles = lib.optionals ( + !(stdenv.hostPlatform.isPower && stdenv.hostPlatform.is64bit) && !stdenv.hostPlatform.isRiscV + ) orig.luajittex.binfiles; # osda is unfree. Hence, we can't include it by default collection-publishers.deps = builtins.filter (dep: dep != "osda") orig.collection-publishers.deps; @@ -401,17 +542,30 @@ in lib.recursiveUpdate orig rec { extraVersion = "-tlpdb-${toString tlpdbVersion.revision}"; # add license of tlmgr and TeXLive::* perl packages and of bin.core - license = [ "gpl2Plus" ] ++ lib.toList bin.core.meta.license.shortName ++ orig."texlive.infra".license or [ ]; + license = + [ "gpl2Plus" ] ++ lib.toList bin.core.meta.license.shortName ++ orig."texlive.infra".license or [ ]; scriptsFolder = "texlive"; - extraBuildInputs = [ coreutils gnused gnupg tl.kpathsea (perl.withPackages (ps: with ps; [ Tk ])) ]; + extraBuildInputs = [ + coreutils + gnused + gnupg + tl.kpathsea + (perl.withPackages (ps: with ps; [ Tk ])) + ]; # make tlmgr believe it can use kpsewhich to evaluate TEXMFROOT postFixup = '' substituteInPlace "$out"/bin/tlmgr \ --replace-fail 'if (-r "$bindir/$kpsewhichname")' 'if (1)' sed -i '2i$ENV{PATH}='"'"'${lib.makeBinPath [ gnupg ]}'"'"' . ($ENV{PATH} ? ":$ENV{PATH}" : '"'''"');' "$out"/bin/tlmgr - sed -i '2iPATH="${lib.makeBinPath [ coreutils gnused tl.kpathsea ]}''${PATH:+:$PATH}"' "$out"/bin/mktexlsr + sed -i '2iPATH="${ + lib.makeBinPath [ + coreutils + gnused + tl.kpathsea + ] + }''${PATH:+:$PATH}"' "$out"/bin/mktexlsr ''; # add minimal texlive.tlpdb diff --git a/pkgs/tools/typesetting/tex/texpresso/default.nix b/pkgs/tools/typesetting/tex/texpresso/default.nix index 73c111bd22b046..c5a5fad4046f2e 100644 --- a/pkgs/tools/typesetting/tex/texpresso/default.nix +++ b/pkgs/tools/typesetting/tex/texpresso/default.nix @@ -1,18 +1,19 @@ -{ stdenv -, lib -, fetchFromGitHub -, makeWrapper -, writeScript -, mupdf -, SDL2 -, re2c -, freetype -, jbig2dec -, harfbuzz -, openjpeg -, gumbo -, libjpeg -, texpresso-tectonic +{ + stdenv, + lib, + fetchFromGitHub, + makeWrapper, + writeScript, + mupdf, + SDL2, + re2c, + freetype, + jbig2dec, + harfbuzz, + openjpeg, + gumbo, + libjpeg, + texpresso-tectonic, }: stdenv.mkDerivation rec { @@ -47,9 +48,11 @@ stdenv.mkDerivation rec { buildFlags = [ "texpresso" ]; - env.NIX_CFLAGS_COMPILE = toString (lib.optionals stdenv.hostPlatform.isDarwin [ - "-Wno-error=implicit-function-declaration" - ]); + env.NIX_CFLAGS_COMPILE = toString ( + lib.optionals stdenv.hostPlatform.isDarwin [ + "-Wno-error=implicit-function-declaration" + ] + ); installPhase = '' runHook preInstall diff --git a/pkgs/tools/typesetting/tex/texpresso/tectonic.nix b/pkgs/tools/typesetting/tex/texpresso/tectonic.nix index 34df5c5ed1f401..27eff6e0f662e2 100644 --- a/pkgs/tools/typesetting/tex/texpresso/tectonic.nix +++ b/pkgs/tools/typesetting/tex/texpresso/tectonic.nix @@ -1,19 +1,24 @@ { tectonic-unwrapped, fetchFromGitHub }: tectonic-unwrapped.override (old: { rustPlatform = old.rustPlatform // { - buildRustPackage = args: old.rustPlatform.buildRustPackage (args // { - pname = "texpresso-tonic"; - src = fetchFromGitHub { - owner = "let-def"; - repo = "tectonic"; - rev = "5b844105c06e0b16e40b1254359f8c28e8956280"; - hash = "sha256-RPsXmp+5MF9h+H3wdL1O1hXSRZWjWTY8lXq/dWZIM1g="; - fetchSubmodules = true; - }; - cargoHash = "sha256-g4iBo8r+QUOcFJ3CI2+HOi4VHxU7jKnIWlJcKx/6r5E="; - # binary has a different name, bundled tests won't work - doCheck = false; - meta.mainProgram = "texpresso-tonic"; - }); + buildRustPackage = + args: + old.rustPlatform.buildRustPackage ( + args + // { + pname = "texpresso-tonic"; + src = fetchFromGitHub { + owner = "let-def"; + repo = "tectonic"; + rev = "5b844105c06e0b16e40b1254359f8c28e8956280"; + hash = "sha256-RPsXmp+5MF9h+H3wdL1O1hXSRZWjWTY8lXq/dWZIM1g="; + fetchSubmodules = true; + }; + cargoHash = "sha256-g4iBo8r+QUOcFJ3CI2+HOi4VHxU7jKnIWlJcKx/6r5E="; + # binary has a different name, bundled tests won't work + doCheck = false; + meta.mainProgram = "texpresso-tonic"; + } + ); }; }) diff --git a/pkgs/tools/typesetting/tikzit/default.nix b/pkgs/tools/typesetting/tikzit/default.nix index e6402deaa96b1f..5b5ae38e95e3ce 100644 --- a/pkgs/tools/typesetting/tikzit/default.nix +++ b/pkgs/tools/typesetting/tikzit/default.nix @@ -1,4 +1,14 @@ -{ lib, mkDerivation, fetchFromGitHub, qmake, qttools, qtbase, poppler, flex, bison }: +{ + lib, + mkDerivation, + fetchFromGitHub, + qmake, + qttools, + qtbase, + poppler, + flex, + bison, +}: mkDerivation { pname = "tikzit"; @@ -11,8 +21,16 @@ mkDerivation { sha256 = "0ba99pgv54pj1xvhrwn9db2w0v4h07vsjajcnhpa2smy88ypg32h"; }; - nativeBuildInputs = [ qmake qttools flex bison ]; - buildInputs = [ qtbase poppler ]; + nativeBuildInputs = [ + qmake + qttools + flex + bison + ]; + buildInputs = [ + qtbase + poppler + ]; # src/data/tikzlexer.l:29:10: fatal error: tikzparser.parser.hpp: No such file or directory enableParallelBuilding = false; @@ -28,7 +46,10 @@ mkDerivation { homepage = "https://tikzit.github.io/"; license = licenses.gpl3Plus; platforms = platforms.all; - maintainers = [ maintainers.iblech maintainers.mgttlinger ]; + maintainers = [ + maintainers.iblech + maintainers.mgttlinger + ]; mainProgram = "tikzit"; }; } diff --git a/pkgs/tools/video/atomicparsley/default.nix b/pkgs/tools/video/atomicparsley/default.nix index 24c11d8695d666..3b5ccde7979e82 100644 --- a/pkgs/tools/video/atomicparsley/default.nix +++ b/pkgs/tools/video/atomicparsley/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchFromGitHub, cmake, zlib, Cocoa }: +{ + lib, + stdenv, + fetchFromGitHub, + cmake, + zlib, + Cocoa, +}: stdenv.mkDerivation rec { pname = "atomicparsley"; @@ -13,8 +20,7 @@ stdenv.mkDerivation rec { nativeBuildInputs = [ cmake ]; - buildInputs = [ zlib ] - ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; + buildInputs = [ zlib ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ Cocoa ]; installPhase = '' runHook preInstall diff --git a/pkgs/tools/video/swftools/default.nix b/pkgs/tools/video/swftools/default.nix index c48d684d3fcc00..85ada19739dec5 100644 --- a/pkgs/tools/video/swftools/default.nix +++ b/pkgs/tools/video/swftools/default.nix @@ -1,4 +1,11 @@ -{ lib, stdenv, fetchurl, freetype, libjpeg, zlib }: +{ + lib, + stdenv, + fetchurl, + freetype, + libjpeg, + zlib, +}: stdenv.mkDerivation rec { pname = "swftools"; @@ -11,7 +18,11 @@ stdenv.mkDerivation rec { patches = [ ./swftools.patch ]; - buildInputs = [ freetype libjpeg zlib ]; + buildInputs = [ + freetype + libjpeg + zlib + ]; meta = with lib; { description = "Collection of SWF manipulation and creation utilities"; diff --git a/pkgs/tools/virtualization/ec2instanceconnectcli/default.nix b/pkgs/tools/virtualization/ec2instanceconnectcli/default.nix index b0327b2b60520e..050f93a052a654 100644 --- a/pkgs/tools/virtualization/ec2instanceconnectcli/default.nix +++ b/pkgs/tools/virtualization/ec2instanceconnectcli/default.nix @@ -1,4 +1,10 @@ -{ lib, buildPythonPackage, fetchPypi, boto3, cryptography }: +{ + lib, + buildPythonPackage, + fetchPypi, + boto3, + cryptography, +}: buildPythonPackage rec { pname = "ec2instanceconnectcli"; @@ -9,7 +15,10 @@ buildPythonPackage rec { hash = "sha256-/U59a6od0JI27VHX+Bvue/7tQy+iwU+g8yt9/GgdoH4="; }; - propagatedBuildInputs = [ boto3 cryptography ]; + propagatedBuildInputs = [ + boto3 + cryptography + ]; # has no tests doCheck = false; diff --git a/pkgs/tools/virtualization/google-compute-engine/default.nix b/pkgs/tools/virtualization/google-compute-engine/default.nix index a745a2e39d56b4..d08d2c1eaf6953 100644 --- a/pkgs/tools/virtualization/google-compute-engine/default.nix +++ b/pkgs/tools/virtualization/google-compute-engine/default.nix @@ -1,11 +1,12 @@ -{ lib -, fetchFromGitHub -, buildPythonPackage -, bash -, bashInteractive -, util-linux -, setuptools -, distro +{ + lib, + fetchFromGitHub, + buildPythonPackage, + bash, + bashInteractive, + util-linux, + setuptools, + distro, }: buildPythonPackage rec { @@ -20,7 +21,10 @@ buildPythonPackage rec { }; buildInputs = [ bash ]; - propagatedBuildInputs = [ setuptools distro ]; + propagatedBuildInputs = [ + setuptools + distro + ]; postPatch = '' for file in $(find google_compute_engine -type f); do diff --git a/pkgs/tools/virtualization/supermin/default.nix b/pkgs/tools/virtualization/supermin/default.nix index b7600f6bb898f9..4c55b390979814 100644 --- a/pkgs/tools/virtualization/supermin/default.nix +++ b/pkgs/tools/virtualization/supermin/default.nix @@ -1,6 +1,13 @@ -{ lib, stdenv, fetchurl -, cpio, e2fsprogs, perl, pkg-config, ocamlPackages -, glibc +{ + lib, + stdenv, + fetchurl, + cpio, + e2fsprogs, + perl, + pkg-config, + ocamlPackages, + glibc, }: stdenv.mkDerivation (finalAttrs: { @@ -12,9 +19,21 @@ stdenv.mkDerivation (finalAttrs: { sha256 = "zjkh02NcgWjPt8oMWoK51c71srJx+Et3bWO4u77sNY4="; }; - nativeBuildInputs = [ cpio e2fsprogs perl pkg-config ] - ++ (with ocamlPackages; [ findlib ocaml ]); - buildInputs = lib.optionals stdenv.hostPlatform.isGnu [ glibc glibc.static ]; + nativeBuildInputs = + [ + cpio + e2fsprogs + perl + pkg-config + ] + ++ (with ocamlPackages; [ + findlib + ocaml + ]); + buildInputs = lib.optionals stdenv.hostPlatform.isGnu [ + glibc + glibc.static + ]; postPatch = '' patchShebangs src/bin2c.pl diff --git a/pkgs/tools/wayland/swaytools/default.nix b/pkgs/tools/wayland/swaytools/default.nix index c6aa46864e9a62..3f994ef03eb270 100644 --- a/pkgs/tools/wayland/swaytools/default.nix +++ b/pkgs/tools/wayland/swaytools/default.nix @@ -1,4 +1,10 @@ -{ lib, setuptools, buildPythonApplication, fetchFromGitHub, slurp }: +{ + lib, + setuptools, + buildPythonApplication, + fetchFromGitHub, + slurp, +}: buildPythonApplication rec { pname = "swaytools"; diff --git a/pkgs/tools/wayland/xwaylandvideobridge/default.nix b/pkgs/tools/wayland/xwaylandvideobridge/default.nix index f87e678bdba988..fcc46987c74a30 100644 --- a/pkgs/tools/wayland/xwaylandvideobridge/default.nix +++ b/pkgs/tools/wayland/xwaylandvideobridge/default.nix @@ -1,19 +1,20 @@ -{ lib -, stdenv -, fetchurl -, cmake -, extra-cmake-modules -, pkg-config -, qtbase -, qtdeclarative -, qtx11extras ? null # qt5 only -, kcoreaddons -, ki18n -, knotifications -, kpipewire -, kstatusnotifieritem ? null # qt6 only -, kwindowsystem -, wrapQtAppsHook +{ + lib, + stdenv, + fetchurl, + cmake, + extra-cmake-modules, + pkg-config, + qtbase, + qtdeclarative, + qtx11extras ? null, # qt5 only + kcoreaddons, + ki18n, + knotifications, + kpipewire, + kstatusnotifieritem ? null, # qt6 only + kwindowsystem, + wrapQtAppsHook, }: stdenv.mkDerivation (finalAttrs: { @@ -44,12 +45,16 @@ stdenv.mkDerivation (finalAttrs: { kwindowsystem ]; - cmakeFlags = ["-DQT_MAJOR_VERSION=${lib.versions.major qtbase.version}"]; + cmakeFlags = [ "-DQT_MAJOR_VERSION=${lib.versions.major qtbase.version}" ]; meta = { description = "Utility to allow streaming Wayland windows to X applications"; homepage = "https://invent.kde.org/system/xwaylandvideobridge"; - license = with lib.licenses; [ bsd3 cc0 gpl2Plus ]; + license = with lib.licenses; [ + bsd3 + cc0 + gpl2Plus + ]; maintainers = with lib.maintainers; [ stepbrobd ]; platforms = lib.platforms.linux; mainProgram = "xwaylandvideobridge"; diff --git a/pkgs/top-level/agda-packages.nix b/pkgs/top-level/agda-packages.nix index 9cde235a1be3a1..c3b055dd37859c 100644 --- a/pkgs/top-level/agda-packages.nix +++ b/pkgs/top-level/agda-packages.nix @@ -1,41 +1,54 @@ -{ pkgs, lib, newScope, Agda }: +{ + pkgs, + lib, + newScope, + Agda, +}: let mkAgdaPackages = Agda: lib.makeScope newScope (mkAgdaPackages' Agda); - mkAgdaPackages' = Agda: self: let - inherit (self) callPackage; - inherit (callPackage ../build-support/agda { - inherit Agda self; - inherit (pkgs.haskellPackages) ghcWithPackages; - }) withPackages mkLibraryFile mkDerivation; - in { - inherit mkLibraryFile mkDerivation; + mkAgdaPackages' = + Agda: self: + let + inherit (self) callPackage; + inherit + (callPackage ../build-support/agda { + inherit Agda self; + inherit (pkgs.haskellPackages) ghcWithPackages; + }) + withPackages + mkLibraryFile + mkDerivation + ; + in + { + inherit mkLibraryFile mkDerivation; - lib = lib.extend (final: prev: import ../build-support/agda/lib.nix { lib = prev; }); + lib = lib.extend (final: prev: import ../build-support/agda/lib.nix { lib = prev; }); - agda = withPackages []; + agda = withPackages [ ]; - standard-library = callPackage ../development/libraries/agda/standard-library { - inherit (pkgs.haskellPackages) ghcWithPackages; - }; + standard-library = callPackage ../development/libraries/agda/standard-library { + inherit (pkgs.haskellPackages) ghcWithPackages; + }; - iowa-stdlib = callPackage ../development/libraries/agda/iowa-stdlib { }; + iowa-stdlib = callPackage ../development/libraries/agda/iowa-stdlib { }; - agda-prelude = callPackage ../development/libraries/agda/agda-prelude { }; + agda-prelude = callPackage ../development/libraries/agda/agda-prelude { }; - agda-categories = callPackage ../development/libraries/agda/agda-categories { }; + agda-categories = callPackage ../development/libraries/agda/agda-categories { }; - cubical = callPackage ../development/libraries/agda/cubical { }; + cubical = callPackage ../development/libraries/agda/cubical { }; - functional-linear-algebra = callPackage - ../development/libraries/agda/functional-linear-algebra { }; + functional-linear-algebra = callPackage ../development/libraries/agda/functional-linear-algebra { }; - generic = callPackage ../development/libraries/agda/generic { }; + generic = callPackage ../development/libraries/agda/generic { }; - agdarsec = callPackage ../development/libraries/agda/agdarsec { }; + agdarsec = callPackage ../development/libraries/agda/agdarsec { }; - _1lab = callPackage ../development/libraries/agda/1lab { }; + _1lab = callPackage ../development/libraries/agda/1lab { }; - generics = callPackage ../development/libraries/agda/generics { }; - }; -in mkAgdaPackages Agda + generics = callPackage ../development/libraries/agda/generics { }; + }; +in +mkAgdaPackages Agda diff --git a/pkgs/top-level/beam-packages.nix b/pkgs/top-level/beam-packages.nix index 6da5b2218d5e22..59aeda1931b311 100644 --- a/pkgs/top-level/beam-packages.nix +++ b/pkgs/top-level/beam-packages.nix @@ -1,14 +1,15 @@ -{ lib -, beam -, beam_nodocs -, callPackage -, wxGTK32 -, buildPackages -, stdenv -, ex_docSupport ? true -, wxSupport ? true -, systemd -, systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd +{ + lib, + beam, + beam_nodocs, + callPackage, + wxGTK32, + buildPackages, + stdenv, + ex_docSupport ? true, + wxSupport ? true, + systemd, + systemdSupport ? lib.meta.availableOn stdenv.hostPlatform systemd, }: let @@ -62,12 +63,23 @@ in # access for example elixir built with different version of Erlang, use # `beam.packages.erlang_24.elixir`. inherit (self.packages.erlang) - elixir elixir_1_17 elixir_1_16 elixir_1_15 elixir_1_14 elixir_1_13 elixir_1_12 elixir_1_11 elixir_1_10 elixir-ls lfe lfe_2_1; + elixir + elixir_1_17 + elixir_1_16 + elixir_1_15 + elixir_1_14 + elixir_1_13 + elixir_1_12 + elixir_1_11 + elixir_1_10 + elixir-ls + lfe + lfe_2_1 + ; }; # Helper function to generate package set with a specific Erlang version. - packagesWith = erlang: - callPackage ../development/beam-modules { inherit erlang; }; + packagesWith = erlang: callPackage ../development/beam-modules { inherit erlang; }; # Each field in this tuple represents all Beam packages in nixpkgs built with # appropriate Erlang/OTP version. diff --git a/pkgs/top-level/by-name-overlay.nix b/pkgs/top-level/by-name-overlay.nix index 3df9843d03df89..9a011439596a08 100644 --- a/pkgs/top-level/by-name-overlay.nix +++ b/pkgs/top-level/by-name-overlay.nix @@ -21,7 +21,8 @@ let # Package files for a single shard # Type: String -> String -> AttrsOf Path - namesForShard = shard: type: + namesForShard = + shard: type: if type != "directory" then # Ignore all non-directories. Technically only README.md is allowed as a file in the base directory, so we could alternatively: # - Assume that README.md is the only file and change the condition to `shard == "README.md"` for a minor performance improvement. @@ -31,9 +32,9 @@ let # Additionally in either of those alternatives, we would have to duplicate the hardcoding of "README.md" { } else - mapAttrs - (name: _: baseDirectory + "/${shard}/${name}/package.nix") - (readDir (baseDirectory + "/${shard}")); + mapAttrs (name: _: baseDirectory + "/${shard}/${name}/package.nix") ( + readDir (baseDirectory + "/${shard}") + ); # The attribute set mapping names to the package files defining them # This is defined up here in order to allow reuse of the value (it's kind of expensive to compute) @@ -54,6 +55,4 @@ self: super: # Because at that point the code in ./stage.nix can be changed to not allow definitions in `all-packages.nix` to override ones from `pkgs/by-name` anymore and throw an error if that happens instead. _internalCallByNamePackageFile = file: self.callPackage file { }; } -// mapAttrs - (name: self._internalCallByNamePackageFile) - packageFiles +// mapAttrs (name: self._internalCallByNamePackageFile) packageFiles diff --git a/pkgs/top-level/cubocore-packages.nix b/pkgs/top-level/cubocore-packages.nix index e7cae57831fd4d..9e0a129d10156e 100644 --- a/pkgs/top-level/cubocore-packages.nix +++ b/pkgs/top-level/cubocore-packages.nix @@ -1,94 +1,100 @@ -{ newScope, lxqt, lib, libsForQt5 }: +{ + newScope, + lxqt, + lib, + libsForQt5, +}: let - packages = self: with self; { + packages = + self: with self; { - # Libs - libcprime = libsForQt5.callPackage ../applications/misc/cubocore-packages/libcprime { }; + # Libs + libcprime = libsForQt5.callPackage ../applications/misc/cubocore-packages/libcprime { }; - libcsys = libsForQt5.callPackage ../applications/misc/cubocore-packages/libcsys { }; + libcsys = libsForQt5.callPackage ../applications/misc/cubocore-packages/libcsys { }; - # Apps - coreaction = libsForQt5.callPackage ../applications/misc/cubocore-packages/coreaction { - inherit libcprime libcsys; - }; + # Apps + coreaction = libsForQt5.callPackage ../applications/misc/cubocore-packages/coreaction { + inherit libcprime libcsys; + }; - corearchiver = libsForQt5.callPackage ../applications/misc/cubocore-packages/corearchiver { - inherit libcprime libcsys; - }; + corearchiver = libsForQt5.callPackage ../applications/misc/cubocore-packages/corearchiver { + inherit libcprime libcsys; + }; - corefm = libsForQt5.callPackage ../applications/misc/cubocore-packages/corefm { - inherit libcprime libcsys; - }; + corefm = libsForQt5.callPackage ../applications/misc/cubocore-packages/corefm { + inherit libcprime libcsys; + }; - coregarage = libsForQt5.callPackage ../applications/misc/cubocore-packages/coregarage { - inherit libcprime libcsys; - }; + coregarage = libsForQt5.callPackage ../applications/misc/cubocore-packages/coregarage { + inherit libcprime libcsys; + }; - corehunt = libsForQt5.callPackage ../applications/misc/cubocore-packages/corehunt { - inherit libcprime libcsys; - }; + corehunt = libsForQt5.callPackage ../applications/misc/cubocore-packages/corehunt { + inherit libcprime libcsys; + }; - coreimage = libsForQt5.callPackage ../applications/misc/cubocore-packages/coreimage { - inherit libcprime libcsys; - }; + coreimage = libsForQt5.callPackage ../applications/misc/cubocore-packages/coreimage { + inherit libcprime libcsys; + }; - coreinfo = libsForQt5.callPackage ../applications/misc/cubocore-packages/coreinfo { - inherit libcprime libcsys; - }; + coreinfo = libsForQt5.callPackage ../applications/misc/cubocore-packages/coreinfo { + inherit libcprime libcsys; + }; - corekeyboard = libsForQt5.callPackage ../applications/misc/cubocore-packages/corekeyboard { - inherit libcprime libcsys; - }; + corekeyboard = libsForQt5.callPackage ../applications/misc/cubocore-packages/corekeyboard { + inherit libcprime libcsys; + }; - corepad = libsForQt5.callPackage ../applications/misc/cubocore-packages/corepad { - inherit libcprime libcsys; - }; + corepad = libsForQt5.callPackage ../applications/misc/cubocore-packages/corepad { + inherit libcprime libcsys; + }; - corepaint = libsForQt5.callPackage ../applications/misc/cubocore-packages/corepaint { - inherit libcprime libcsys; - }; + corepaint = libsForQt5.callPackage ../applications/misc/cubocore-packages/corepaint { + inherit libcprime libcsys; + }; - corepdf = libsForQt5.callPackage ../applications/misc/cubocore-packages/corepdf { - inherit libcprime libcsys; - }; + corepdf = libsForQt5.callPackage ../applications/misc/cubocore-packages/corepdf { + inherit libcprime libcsys; + }; - corepins = libsForQt5.callPackage ../applications/misc/cubocore-packages/corepins { - inherit libcprime libcsys; - }; + corepins = libsForQt5.callPackage ../applications/misc/cubocore-packages/corepins { + inherit libcprime libcsys; + }; - corerenamer = libsForQt5.callPackage ../applications/misc/cubocore-packages/corerenamer { - inherit libcprime libcsys; - }; + corerenamer = libsForQt5.callPackage ../applications/misc/cubocore-packages/corerenamer { + inherit libcprime libcsys; + }; - coreshot = libsForQt5.callPackage ../applications/misc/cubocore-packages/coreshot { - inherit libcprime libcsys; - }; + coreshot = libsForQt5.callPackage ../applications/misc/cubocore-packages/coreshot { + inherit libcprime libcsys; + }; - corestats = libsForQt5.callPackage ../applications/misc/cubocore-packages/corestats { - inherit libcprime libcsys; - }; + corestats = libsForQt5.callPackage ../applications/misc/cubocore-packages/corestats { + inherit libcprime libcsys; + }; - corestuff = libsForQt5.callPackage ../applications/misc/cubocore-packages/corestuff { - inherit libcprime libcsys; - }; + corestuff = libsForQt5.callPackage ../applications/misc/cubocore-packages/corestuff { + inherit libcprime libcsys; + }; - coreterminal = libsForQt5.callPackage ../applications/misc/cubocore-packages/coreterminal { - qtermwidget = lxqt.qtermwidget_1_4; - inherit libcprime libcsys; - }; + coreterminal = libsForQt5.callPackage ../applications/misc/cubocore-packages/coreterminal { + qtermwidget = lxqt.qtermwidget_1_4; + inherit libcprime libcsys; + }; - coretime = libsForQt5.callPackage ../applications/misc/cubocore-packages/coretime { - inherit libcprime libcsys; - }; + coretime = libsForQt5.callPackage ../applications/misc/cubocore-packages/coretime { + inherit libcprime libcsys; + }; - coretoppings = libsForQt5.callPackage ../applications/misc/cubocore-packages/coretoppings { - inherit libcprime libcsys; - }; + coretoppings = libsForQt5.callPackage ../applications/misc/cubocore-packages/coretoppings { + inherit libcprime libcsys; + }; - coreuniverse = libsForQt5.callPackage ../applications/misc/cubocore-packages/coreuniverse { - inherit libcprime libcsys; + coreuniverse = libsForQt5.callPackage ../applications/misc/cubocore-packages/coreuniverse { + inherit libcprime libcsys; + }; }; - }; in lib.makeScope newScope packages diff --git a/pkgs/top-level/darwin-packages.nix b/pkgs/top-level/darwin-packages.nix index b7c8644495a120..a84ec52e2bc08d 100644 --- a/pkgs/top-level/darwin-packages.nix +++ b/pkgs/top-level/darwin-packages.nix @@ -1,9 +1,13 @@ -{ lib -, buildPackages, pkgs, targetPackages -, generateSplicesForMkScope, makeScopeWithSplicing' -, stdenv -, preLibcCrossHeaders -, config +{ + lib, + buildPackages, + pkgs, + targetPackages, + generateSplicesForMkScope, + makeScopeWithSplicing', + stdenv, + preLibcCrossHeaders, + config, }: let @@ -11,15 +15,18 @@ let # # TODO(@Ericson2314) Make unconditional, or optional but always true by # default. - targetPrefix = lib.optionalString (stdenv.targetPlatform != stdenv.hostPlatform) - (stdenv.targetPlatform.config + "-"); + targetPrefix = lib.optionalString (stdenv.targetPlatform != stdenv.hostPlatform) ( + stdenv.targetPlatform.config + "-" + ); # Bootstrap `fetchurl` needed to build SDK packages without causing an infinite recursion. fetchurlBoot = import ../build-support/fetchurl/boot.nix { inherit (stdenv) system; }; - aliases = self: super: lib.optionalAttrs config.allowAliases (import ../top-level/darwin-aliases.nix lib self super pkgs); + aliases = + self: super: + lib.optionalAttrs config.allowAliases (import ../top-level/darwin-aliases.nix lib self super pkgs); mkBootstrapStdenv = stdenv: @@ -39,231 +46,282 @@ in makeScopeWithSplicing' { otherSplices = generateSplicesForMkScope "darwin"; extra = spliced: spliced.apple_sdk.frameworks; - f = lib.extends aliases (self: let - inherit (self) mkDerivation callPackage; - - # Open source packages that are built from source - apple-source-packages = lib.packagesFromDirectoryRecursive { - callPackage = self.callPackage; - directory = ../os-specific/darwin/apple-source-releases; - }; - - # Compatibility packages that aren’t necessary anymore - apple-source-headers = { - libresolvHeaders = lib.getDev self.libresolv; - libutilHeaders = lib.getDev self.libutil; - }; - - # Must use pkgs.callPackage to avoid infinite recursion. - impure-cmds = pkgs.callPackage ../os-specific/darwin/impure-cmds { }; - - # macOS 10.12 SDK - apple_sdk_10_12 = pkgs.callPackage ../os-specific/darwin/apple-sdk { }; - - # macOS 11.0 SDK - apple_sdk_11_0 = pkgs.callPackage ../os-specific/darwin/apple-sdk-11.0 { }; - - # macOS 12.3 SDK - apple_sdk_12_3 = pkgs.callPackage ../os-specific/darwin/apple-sdk-12.3 { }; - - # Pick an SDK - apple_sdk = { - "10.12" = apple_sdk_10_12; - "11.0" = apple_sdk_11_0; - }.${stdenv.hostPlatform.darwinSdkVersion} - or (throw "Unsupported sdk: ${stdenv.hostPlatform.darwinSdkVersion}"); - - stubs = { - inherit apple_sdk apple_sdk_10_12 apple_sdk_11_0 apple_sdk_12_3; - libobjc = self.objc4; - } // lib.genAttrs [ - "CF" - "CarbonHeaders" - "CommonCrypto" - "CoreSymbolication" - "IOKit" - "Libc" - "Libinfo" - "Libm" - "Libnotify" - "Librpcsvc" - "Libsystem" - "LibsystemCross" - "Security" - "architecture" - "configd" - "configdHeaders" - "darwin-stubs" - "dtrace" - "dyld" - "eap8021x" - "hfs" - "hfsHeaders" - "launchd" - "libclosure" - "libdispatch" - "libmalloc" - "libplatform" - "libpthread" - "mDNSResponder" - "objc4" - "ppp" - "xnu" - ] (mkStub apple_sdk.version); -in - -impure-cmds // apple-source-packages // apple-source-headers // stubs // { - - stdenvNoCF = stdenv.override { - extraBuildInputs = []; - }; - - inherit (self.adv_cmds) ps; - - binutils-unwrapped = callPackage ../os-specific/darwin/binutils { - inherit (pkgs) cctools; - inherit (pkgs.llvmPackages) clang-unwrapped llvm llvm-manpages; - }; - - binutils = pkgs.wrapBintoolsWith { - libc = - if stdenv.targetPlatform != stdenv.hostPlatform - then pkgs.libcCross - else pkgs.stdenv.cc.libc; - bintools = self.binutils-unwrapped; - }; - - # x86-64 Darwin gnat-bootstrap emits assembly - # with MOVQ as the mnemonic for quadword interunit moves - # such as `movq %rbp, %xmm0`. - # The clang integrated assembler recognises this as valid, - # but unfortunately the cctools.gas GNU assembler does not; - # it instead uses MOVD as the mnemonic. - # The assembly that a GCC build emits is determined at build time - # and cannot be changed afterwards. - # - # To build GNAT on x86-64 Darwin, therefore, - # we need both the clang _and_ the cctools.gas assemblers to be available: - # the former to build at least the stage1 compiler, - # and the latter at least to be detectable - # as the target for the final compiler. - binutilsDualAs-unwrapped = pkgs.buildEnv { - name = "${lib.getName self.binutils-unwrapped}-dualas-${lib.getVersion self.binutils-unwrapped}"; - paths = [ - self.binutils-unwrapped - (lib.getOutput "gas" pkgs.cctools) - ]; - }; - - binutilsDualAs = self.binutils.override { - bintools = self.binutilsDualAs-unwrapped; - }; - - binutilsNoLibc = pkgs.wrapBintoolsWith { - libc = preLibcCrossHeaders; - bintools = self.binutils-unwrapped; - }; - - # Removes propagated packages from the stdenv, so those packages can be built without depending upon themselves. - bootstrapStdenv = mkBootstrapStdenv pkgs.stdenv; - - libSystem = callPackage ../os-specific/darwin/libSystem { }; - - # TODO(@connorbaker): See https://github.com/NixOS/nixpkgs/issues/229389. - cf-private = self.apple_sdk.frameworks.CoreFoundation; + f = lib.extends aliases ( + self: + let + inherit (self) mkDerivation callPackage; - DarwinTools = callPackage ../os-specific/darwin/DarwinTools { }; + # Open source packages that are built from source + apple-source-packages = lib.packagesFromDirectoryRecursive { + callPackage = self.callPackage; + directory = ../os-specific/darwin/apple-source-releases; + }; - print-reexports = callPackage ../os-specific/darwin/print-reexports { }; + # Compatibility packages that aren’t necessary anymore + apple-source-headers = { + libresolvHeaders = lib.getDev self.libresolv; + libutilHeaders = lib.getDev self.libutil; + }; - rewrite-tbd = callPackage ../os-specific/darwin/rewrite-tbd { }; + # Must use pkgs.callPackage to avoid infinite recursion. + impure-cmds = pkgs.callPackage ../os-specific/darwin/impure-cmds { }; + + # macOS 10.12 SDK + apple_sdk_10_12 = pkgs.callPackage ../os-specific/darwin/apple-sdk { }; + + # macOS 11.0 SDK + apple_sdk_11_0 = pkgs.callPackage ../os-specific/darwin/apple-sdk-11.0 { }; + + # macOS 12.3 SDK + apple_sdk_12_3 = pkgs.callPackage ../os-specific/darwin/apple-sdk-12.3 { }; + + # Pick an SDK + apple_sdk = + { + "10.12" = apple_sdk_10_12; + "11.0" = apple_sdk_11_0; + } + .${stdenv.hostPlatform.darwinSdkVersion} + or (throw "Unsupported sdk: ${stdenv.hostPlatform.darwinSdkVersion}"); + + stubs = + { + inherit + apple_sdk + apple_sdk_10_12 + apple_sdk_11_0 + apple_sdk_12_3 + ; + libobjc = self.objc4; + } + // lib.genAttrs [ + "CF" + "CarbonHeaders" + "CommonCrypto" + "CoreSymbolication" + "IOKit" + "Libc" + "Libinfo" + "Libm" + "Libnotify" + "Librpcsvc" + "Libsystem" + "LibsystemCross" + "Security" + "architecture" + "configd" + "configdHeaders" + "darwin-stubs" + "dtrace" + "dyld" + "eap8021x" + "hfs" + "hfsHeaders" + "launchd" + "libclosure" + "libdispatch" + "libmalloc" + "libplatform" + "libpthread" + "mDNSResponder" + "objc4" + "ppp" + "xnu" + ] (mkStub apple_sdk.version); + in - checkReexportsHook = pkgs.makeSetupHook { - name = "darwin-check-reexports-hook"; - propagatedBuildInputs = [ pkgs.darwin.print-reexports ]; - } ../os-specific/darwin/print-reexports/setup-hook.sh; + impure-cmds + // apple-source-packages + // apple-source-headers + // stubs + // { - libunwind = callPackage ../os-specific/darwin/libunwind { }; + stdenvNoCF = stdenv.override { + extraBuildInputs = [ ]; + }; - sigtool = callPackage ../os-specific/darwin/sigtool { }; + inherit (self.adv_cmds) ps; - signingUtils = callPackage ../os-specific/darwin/signing-utils { }; + binutils-unwrapped = callPackage ../os-specific/darwin/binutils { + inherit (pkgs) cctools; + inherit (pkgs.llvmPackages) clang-unwrapped llvm llvm-manpages; + }; - postLinkSignHook = callPackage ../os-specific/darwin/signing-utils/post-link-sign-hook.nix { }; + binutils = pkgs.wrapBintoolsWith { + libc = if stdenv.targetPlatform != stdenv.hostPlatform then pkgs.libcCross else pkgs.stdenv.cc.libc; + bintools = self.binutils-unwrapped; + }; - autoSignDarwinBinariesHook = pkgs.makeSetupHook { - name = "auto-sign-darwin-binaries-hook"; - propagatedBuildInputs = [ self.signingUtils ]; - } ../os-specific/darwin/signing-utils/auto-sign-hook.sh; + # x86-64 Darwin gnat-bootstrap emits assembly + # with MOVQ as the mnemonic for quadword interunit moves + # such as `movq %rbp, %xmm0`. + # The clang integrated assembler recognises this as valid, + # but unfortunately the cctools.gas GNU assembler does not; + # it instead uses MOVD as the mnemonic. + # The assembly that a GCC build emits is determined at build time + # and cannot be changed afterwards. + # + # To build GNAT on x86-64 Darwin, therefore, + # we need both the clang _and_ the cctools.gas assemblers to be available: + # the former to build at least the stage1 compiler, + # and the latter at least to be detectable + # as the target for the final compiler. + binutilsDualAs-unwrapped = pkgs.buildEnv { + name = "${lib.getName self.binutils-unwrapped}-dualas-${lib.getVersion self.binutils-unwrapped}"; + paths = [ + self.binutils-unwrapped + (lib.getOutput "gas" pkgs.cctools) + ]; + }; - iosSdkPkgs = callPackage ../os-specific/darwin/xcode/sdk-pkgs.nix { - buildIosSdk = buildPackages.darwin.iosSdkPkgs.sdk; - targetIosSdkPkgs = targetPackages.darwin.iosSdkPkgs; - inherit (pkgs.llvmPackages) clang-unwrapped; - }; + binutilsDualAs = self.binutils.override { + bintools = self.binutilsDualAs-unwrapped; + }; - lsusb = callPackage ../os-specific/darwin/lsusb { }; + binutilsNoLibc = pkgs.wrapBintoolsWith { + libc = preLibcCrossHeaders; + bintools = self.binutils-unwrapped; + }; - openwith = callPackage ../os-specific/darwin/openwith { }; + # Removes propagated packages from the stdenv, so those packages can be built without depending upon themselves. + bootstrapStdenv = mkBootstrapStdenv pkgs.stdenv; - stubs = pkgs.callPackages ../os-specific/darwin/stubs { }; + libSystem = callPackage ../os-specific/darwin/libSystem { }; - trash = callPackage ../os-specific/darwin/trash { }; + # TODO(@connorbaker): See https://github.com/NixOS/nixpkgs/issues/229389. + cf-private = self.apple_sdk.frameworks.CoreFoundation; - inherit (self.file_cmds) xattr; + DarwinTools = callPackage ../os-specific/darwin/DarwinTools { }; - inherit (pkgs.callPackages ../os-specific/darwin/xcode { }) - xcode_8_1 xcode_8_2 - xcode_9_1 xcode_9_2 xcode_9_3 xcode_9_4 xcode_9_4_1 - xcode_10_1 xcode_10_2 xcode_10_2_1 xcode_10_3 - xcode_11 xcode_11_1 xcode_11_2 xcode_11_3_1 xcode_11_4 xcode_11_5 xcode_11_6 xcode_11_7 - xcode_12 xcode_12_0_1 xcode_12_1 xcode_12_2 xcode_12_3 xcode_12_4 xcode_12_5 xcode_12_5_1 - xcode_13 xcode_13_1 xcode_13_2 xcode_13_3 xcode_13_3_1 xcode_13_4 xcode_13_4_1 - xcode_14 xcode_14_1 - xcode_15 xcode_15_0_1 xcode_15_1 xcode_15_2 xcode_15_3 xcode_15_4 - xcode_16 xcode_16_1 - xcode; + print-reexports = callPackage ../os-specific/darwin/print-reexports { }; - xcodeProjectCheckHook = pkgs.makeSetupHook { - name = "xcode-project-check-hook"; - propagatedBuildInputs = [ pkgs.pkgsBuildHost.openssl ]; - } ../os-specific/darwin/xcode-project-check-hook/setup-hook.sh; + rewrite-tbd = callPackage ../os-specific/darwin/rewrite-tbd { }; - # Formerly the CF attribute. Use this is you need the open source release. - swift-corelibs-foundation = callPackage ../os-specific/darwin/swift-corelibs/corefoundation.nix { }; + checkReexportsHook = pkgs.makeSetupHook { + name = "darwin-check-reexports-hook"; + propagatedBuildInputs = [ pkgs.darwin.print-reexports ]; + } ../os-specific/darwin/print-reexports/setup-hook.sh; - # As the name says, this is broken, but I don't want to lose it since it's a direction we want to go in - # libdispatch-broken = callPackage ../os-specific/darwin/swift-corelibs/libdispatch.nix { }; + libunwind = callPackage ../os-specific/darwin/libunwind { }; - # See doc/packages/darwin-builder.section.md - linux-builder = lib.makeOverridable ({ modules }: - let - toGuest = builtins.replaceStrings [ "darwin" ] [ "linux" ]; + sigtool = callPackage ../os-specific/darwin/sigtool { }; - nixos = import ../../nixos { - configuration = { - imports = [ - ../../nixos/modules/profiles/nix-builder-vm.nix - ] ++ modules; + signingUtils = callPackage ../os-specific/darwin/signing-utils { }; - # If you need to override this, consider starting with the right Nixpkgs - # in the first place, ie change `pkgs` in `pkgs.darwin.linux-builder`. - # or if you're creating new wiring that's not `pkgs`-centric, perhaps use the - # macos-builder profile directly. - virtualisation.host = { inherit pkgs; }; + postLinkSignHook = callPackage ../os-specific/darwin/signing-utils/post-link-sign-hook.nix { }; - nixpkgs.hostPlatform = lib.mkDefault (toGuest stdenv.hostPlatform.system); - }; + autoSignDarwinBinariesHook = pkgs.makeSetupHook { + name = "auto-sign-darwin-binaries-hook"; + propagatedBuildInputs = [ self.signingUtils ]; + } ../os-specific/darwin/signing-utils/auto-sign-hook.sh; - system = null; + iosSdkPkgs = callPackage ../os-specific/darwin/xcode/sdk-pkgs.nix { + buildIosSdk = buildPackages.darwin.iosSdkPkgs.sdk; + targetIosSdkPkgs = targetPackages.darwin.iosSdkPkgs; + inherit (pkgs.llvmPackages) clang-unwrapped; }; - in - nixos.config.system.build.macos-builder-installer) { modules = [ ]; }; - - linux-builder-x86_64 = self.linux-builder.override { - modules = [ { nixpkgs.hostPlatform = "x86_64-linux"; } ]; - }; + lsusb = callPackage ../os-specific/darwin/lsusb { }; + + openwith = callPackage ../os-specific/darwin/openwith { }; + + stubs = pkgs.callPackages ../os-specific/darwin/stubs { }; + + trash = callPackage ../os-specific/darwin/trash { }; + + inherit (self.file_cmds) xattr; + + inherit (pkgs.callPackages ../os-specific/darwin/xcode { }) + xcode_8_1 + xcode_8_2 + xcode_9_1 + xcode_9_2 + xcode_9_3 + xcode_9_4 + xcode_9_4_1 + xcode_10_1 + xcode_10_2 + xcode_10_2_1 + xcode_10_3 + xcode_11 + xcode_11_1 + xcode_11_2 + xcode_11_3_1 + xcode_11_4 + xcode_11_5 + xcode_11_6 + xcode_11_7 + xcode_12 + xcode_12_0_1 + xcode_12_1 + xcode_12_2 + xcode_12_3 + xcode_12_4 + xcode_12_5 + xcode_12_5_1 + xcode_13 + xcode_13_1 + xcode_13_2 + xcode_13_3 + xcode_13_3_1 + xcode_13_4 + xcode_13_4_1 + xcode_14 + xcode_14_1 + xcode_15 + xcode_15_0_1 + xcode_15_1 + xcode_15_2 + xcode_15_3 + xcode_15_4 + xcode_16 + xcode_16_1 + xcode + ; + + xcodeProjectCheckHook = pkgs.makeSetupHook { + name = "xcode-project-check-hook"; + propagatedBuildInputs = [ pkgs.pkgsBuildHost.openssl ]; + } ../os-specific/darwin/xcode-project-check-hook/setup-hook.sh; + + # Formerly the CF attribute. Use this is you need the open source release. + swift-corelibs-foundation = callPackage ../os-specific/darwin/swift-corelibs/corefoundation.nix { }; + + # As the name says, this is broken, but I don't want to lose it since it's a direction we want to go in + # libdispatch-broken = callPackage ../os-specific/darwin/swift-corelibs/libdispatch.nix { }; + + # See doc/packages/darwin-builder.section.md + linux-builder = lib.makeOverridable ( + { modules }: + let + toGuest = builtins.replaceStrings [ "darwin" ] [ "linux" ]; + + nixos = import ../../nixos { + configuration = { + imports = [ + ../../nixos/modules/profiles/nix-builder-vm.nix + ] ++ modules; + + # If you need to override this, consider starting with the right Nixpkgs + # in the first place, ie change `pkgs` in `pkgs.darwin.linux-builder`. + # or if you're creating new wiring that's not `pkgs`-centric, perhaps use the + # macos-builder profile directly. + virtualisation.host = { inherit pkgs; }; + + nixpkgs.hostPlatform = lib.mkDefault (toGuest stdenv.hostPlatform.system); + }; + + system = null; + }; + + in + nixos.config.system.build.macos-builder-installer + ) { modules = [ ]; }; + + linux-builder-x86_64 = self.linux-builder.override { + modules = [ { nixpkgs.hostPlatform = "x86_64-linux"; } ]; + }; -}); + } + ); } diff --git a/pkgs/top-level/dhall-packages.nix b/pkgs/top-level/dhall-packages.nix index f43be56c59be4e..b7191a2dd9c2a1 100644 --- a/pkgs/top-level/dhall-packages.nix +++ b/pkgs/top-level/dhall-packages.nix @@ -1,51 +1,52 @@ -{ lib -, newScope -, overrides ? (self: super: {}) +{ + lib, + newScope, + overrides ? (self: super: { }), }: let - packages = self: + packages = + self: let callPackage = newScope self; - buildDhallPackage = - callPackage ../development/interpreters/dhall/build-dhall-package.nix { }; + buildDhallPackage = callPackage ../development/interpreters/dhall/build-dhall-package.nix { }; buildDhallGitHubPackage = - callPackage ../development/interpreters/dhall/build-dhall-github-package.nix { }; + callPackage ../development/interpreters/dhall/build-dhall-github-package.nix + { }; buildDhallDirectoryPackage = - callPackage ../development/interpreters/dhall/build-dhall-directory-package.nix { }; + callPackage ../development/interpreters/dhall/build-dhall-directory-package.nix + { }; - buildDhallUrl = - callPackage ../development/interpreters/dhall/build-dhall-url.nix { }; + buildDhallUrl = callPackage ../development/interpreters/dhall/build-dhall-url.nix { }; generateDhallDirectoryPackage = - callPackage ../development/interpreters/dhall/generate-dhall-directory-package.nix { }; + callPackage ../development/interpreters/dhall/generate-dhall-directory-package.nix + { }; in - { inherit - callPackage - buildDhallPackage - buildDhallGitHubPackage - buildDhallDirectoryPackage - buildDhallUrl - generateDhallDirectoryPackage + { + inherit + callPackage + buildDhallPackage + buildDhallGitHubPackage + buildDhallDirectoryPackage + buildDhallUrl + generateDhallDirectoryPackage ; - lib = import ../development/dhall-modules/lib.nix { inherit lib; }; + lib = import ../development/dhall-modules/lib.nix { inherit lib; }; - dhall-cloudformation = callPackage ../development/dhall-modules/dhall-cloudformation.nix { }; + dhall-cloudformation = callPackage ../development/dhall-modules/dhall-cloudformation.nix { }; - dhall-grafana = - callPackage ../development/dhall-modules/dhall-grafana.nix { }; + dhall-grafana = callPackage ../development/dhall-modules/dhall-grafana.nix { }; - dhall-kubernetes = - callPackage ../development/dhall-modules/dhall-kubernetes.nix { }; + dhall-kubernetes = callPackage ../development/dhall-modules/dhall-kubernetes.nix { }; - Prelude = - callPackage ../development/dhall-modules/Prelude.nix { }; - }; + Prelude = callPackage ../development/dhall-modules/Prelude.nix { }; + }; in - lib.fix' (lib.extends overrides packages) +lib.fix' (lib.extends overrides packages) diff --git a/pkgs/top-level/dotnet-packages.nix b/pkgs/top-level/dotnet-packages.nix index b6dc7bf5300dbe..1ba6d4a2478504 100644 --- a/pkgs/top-level/dotnet-packages.nix +++ b/pkgs/top-level/dotnet-packages.nix @@ -1,181 +1,189 @@ -{ stdenv -, lib -, pkgs -, buildDotnetPackage -, buildDotnetModule -, fetchurl -, fetchFromGitHub -, fetchNuGet -, glib -, mono -, overrides ? {} -, boogie -, nuget +{ + stdenv, + lib, + pkgs, + buildDotnetPackage, + buildDotnetModule, + fetchurl, + fetchFromGitHub, + fetchNuGet, + glib, + mono, + overrides ? { }, + boogie, + nuget, }: -let self = dotnetPackages // overrides; dotnetPackages = with self; { - # ALIASES FOR MOVED PACKAGES +let + self = dotnetPackages // overrides; + dotnetPackages = with self; { + # ALIASES FOR MOVED PACKAGES - Boogie = boogie; - Nuget = nuget; + Boogie = boogie; + Nuget = nuget; - # BINARY PACKAGES + # BINARY PACKAGES - NUnit3 = fetchNuGet { - pname = "NUnit"; - version = "3.0.1"; - sha256 = "1g3j3kvg9vrapb1vjgq65nvn1vg7bzm66w7yjnaip1iww1yn1b0p"; - outputFiles = [ "lib/*" ]; - }; - - NUnit2 = fetchNuGet { - pname = "NUnit"; - version = "2.6.4"; - sha256 = "1acwsm7p93b1hzfb83ia33145x0w6fvdsfjm9xflsisljxpdx35y"; - outputFiles = [ "lib/*" ]; - }; - - NUnit = NUnit2; - - NUnitConsole = fetchNuGet { - pname = "NUnit.Console"; - version = "3.0.1"; - sha256 = "154bqwm2n95syv8nwd67qh8qsv0b0h5zap60sk64z3kd3a9ffi5p"; - outputFiles = [ "tools/*" ]; - }; - - MaxMindDb = fetchNuGet { - pname = "MaxMind.Db"; - version = "1.1.0.0"; - sha256 = "0lixl76f7k3ldiqzg94zh13gn82w5mm5dx72y97fcqvp8g6nj3ds"; - outputFiles = [ "lib/*" ]; - }; + NUnit3 = fetchNuGet { + pname = "NUnit"; + version = "3.0.1"; + sha256 = "1g3j3kvg9vrapb1vjgq65nvn1vg7bzm66w7yjnaip1iww1yn1b0p"; + outputFiles = [ "lib/*" ]; + }; - MaxMindGeoIP2 = fetchNuGet { - pname = "MaxMind.GeoIP2"; - version = "2.3.1"; - sha256 = "1s44dvjnmj1aimbrgkmpj6h5dn1w6acgqjch1axc76yz6hwknqgf"; - outputFiles = [ "lib/*" ]; - }; + NUnit2 = fetchNuGet { + pname = "NUnit"; + version = "2.6.4"; + sha256 = "1acwsm7p93b1hzfb83ia33145x0w6fvdsfjm9xflsisljxpdx35y"; + outputFiles = [ "lib/*" ]; + }; - SharpZipLib = fetchNuGet { - pname = "SharpZipLib"; - version = "1.3.3"; - sha256 = "sha256-HWEQTKh9Ktwg/zIl079dAiH+ob2ShWFAqLgG6XgIMr4="; - outputFiles = [ "lib/*" ]; - }; + NUnit = NUnit2; - StyleCopMSBuild = fetchNuGet { - pname = "StyleCop.MSBuild"; - version = "4.7.49.0"; - sha256 = "0rpfyvcggm881ynvgr17kbx5hvj7ivlms0bmskmb2zyjlpddx036"; - outputFiles = [ "tools/*" ]; - meta.mainProgram = "stylecopsettingseditor"; - }; + NUnitConsole = fetchNuGet { + pname = "NUnit.Console"; + version = "3.0.1"; + sha256 = "154bqwm2n95syv8nwd67qh8qsv0b0h5zap60sk64z3kd3a9ffi5p"; + outputFiles = [ "tools/*" ]; + }; - StyleCopPlusMSBuild = fetchNuGet { - pname = "StyleCopPlus.MSBuild"; - version = "4.7.49.5"; - sha256 = "1hv4lfxw72aql8siyqc4n954vzdz8p6jx9f2wrgzz0jy1k98x2mr"; - outputFiles = [ "tools/*" ]; - }; + MaxMindDb = fetchNuGet { + pname = "MaxMind.Db"; + version = "1.1.0.0"; + sha256 = "0lixl76f7k3ldiqzg94zh13gn82w5mm5dx72y97fcqvp8g6nj3ds"; + outputFiles = [ "lib/*" ]; + }; - RestSharp = fetchNuGet { - pname = "RestSharp"; - version = "106.12.0"; - sha256 = "sha256-NGzveByJvCRtHlI2C8d/mLs3akyMm77NER8TUG6HiD4="; - outputFiles = [ "lib/*" ]; - }; + MaxMindGeoIP2 = fetchNuGet { + pname = "MaxMind.GeoIP2"; + version = "2.3.1"; + sha256 = "1s44dvjnmj1aimbrgkmpj6h5dn1w6acgqjch1axc76yz6hwknqgf"; + outputFiles = [ "lib/*" ]; + }; - SharpFont = fetchNuGet { - pname = "SharpFont"; - version = "4.0.1"; - sha256 = "1yd3cm4ww0hw2k3aymf792hp6skyg8qn491m2a3fhkzvsl8z7vs8"; - outputFiles = [ "lib/*" "config/*" ]; - }; + SharpZipLib = fetchNuGet { + pname = "SharpZipLib"; + version = "1.3.3"; + sha256 = "sha256-HWEQTKh9Ktwg/zIl079dAiH+ob2ShWFAqLgG6XgIMr4="; + outputFiles = [ "lib/*" ]; + }; - SmartIrc4net = fetchNuGet { - pname = "SmartIrc4net"; - version = "0.4.5.1"; - sha256 = "1d531sj39fvwmj2wgplqfify301y3cwp7kwr9ai5hgrq81jmjn2b"; - outputFiles = [ "lib/*" ]; - }; + StyleCopMSBuild = fetchNuGet { + pname = "StyleCop.MSBuild"; + version = "4.7.49.0"; + sha256 = "0rpfyvcggm881ynvgr17kbx5hvj7ivlms0bmskmb2zyjlpddx036"; + outputFiles = [ "tools/*" ]; + meta.mainProgram = "stylecopsettingseditor"; + }; - FuzzyLogicLibrary = fetchNuGet { - pname = "FuzzyLogicLibrary"; - version = "1.2.0"; - sha256 = "0x518i8d3rw9n51xwawa4sywvqd722adj7kpcgcm63r66s950r5l"; - outputFiles = [ "bin/*" ]; - }; + StyleCopPlusMSBuild = fetchNuGet { + pname = "StyleCopPlus.MSBuild"; + version = "4.7.49.5"; + sha256 = "1hv4lfxw72aql8siyqc4n954vzdz8p6jx9f2wrgzz0jy1k98x2mr"; + outputFiles = [ "tools/*" ]; + }; - OpenNAT = fetchNuGet { - pname = "Open.NAT"; - version = "2.1.0"; - sha256 = "1jyd30fwycdwx5ck96zhp2xf20yz0sp7g3pjbqhmay4kd322mfwk"; - outputFiles = [ "lib/*" ]; - }; + RestSharp = fetchNuGet { + pname = "RestSharp"; + version = "106.12.0"; + sha256 = "sha256-NGzveByJvCRtHlI2C8d/mLs3akyMm77NER8TUG6HiD4="; + outputFiles = [ "lib/*" ]; + }; - MonoNat = fetchNuGet { - pname = "Mono.Nat"; - version = "1.2.24"; - sha256 = "0vfkach11kkcd9rcqz3s38m70d5spyb21gl99iqnkljxj5555wjs"; - outputFiles = [ "lib/*" ]; - }; + SharpFont = fetchNuGet { + pname = "SharpFont"; + version = "4.0.1"; + sha256 = "1yd3cm4ww0hw2k3aymf792hp6skyg8qn491m2a3fhkzvsl8z7vs8"; + outputFiles = [ + "lib/*" + "config/*" + ]; + }; - NUnitRunners = fetchNuGet { - pname = "NUnit.Runners"; - version = "2.6.4"; - sha256 = "11nmi7vikn9idz8qcad9z7f73arsh5rw18fc1sri9ywz77mpm1s4"; - outputFiles = [ "tools/*" ]; - preInstall = "mv -v tools/lib/* tools && rmdir -v tools/lib"; - }; + SmartIrc4net = fetchNuGet { + pname = "SmartIrc4net"; + version = "0.4.5.1"; + sha256 = "1d531sj39fvwmj2wgplqfify301y3cwp7kwr9ai5hgrq81jmjn2b"; + outputFiles = [ "lib/*" ]; + }; - # SOURCE PACKAGES + FuzzyLogicLibrary = fetchNuGet { + pname = "FuzzyLogicLibrary"; + version = "1.2.0"; + sha256 = "0x518i8d3rw9n51xwawa4sywvqd722adj7kpcgcm63r66s950r5l"; + outputFiles = [ "bin/*" ]; + }; - MonoAddins = buildDotnetPackage rec { - pname = "Mono.Addins"; - version = "1.2"; + OpenNAT = fetchNuGet { + pname = "Open.NAT"; + version = "2.1.0"; + sha256 = "1jyd30fwycdwx5ck96zhp2xf20yz0sp7g3pjbqhmay4kd322mfwk"; + outputFiles = [ "lib/*" ]; + }; - xBuildFiles = [ - "Mono.Addins/Mono.Addins.csproj" - "Mono.Addins.Setup/Mono.Addins.Setup.csproj" - "Mono.Addins.Gui/Mono.Addins.Gui.csproj" - "Mono.Addins.CecilReflector/Mono.Addins.CecilReflector.csproj" - ]; - outputFiles = [ "bin/*" ]; + MonoNat = fetchNuGet { + pname = "Mono.Nat"; + version = "1.2.24"; + sha256 = "0vfkach11kkcd9rcqz3s38m70d5spyb21gl99iqnkljxj5555wjs"; + outputFiles = [ "lib/*" ]; + }; - src = fetchFromGitHub { - owner = "mono"; - repo = "mono-addins"; - rev = "mono-addins-${version}"; - sha256 = "1hnn0a2qsjcjprsxas424bzvhsdwy0yc2jj5xbp698c0m9kfk24y"; + NUnitRunners = fetchNuGet { + pname = "NUnit.Runners"; + version = "2.6.4"; + sha256 = "11nmi7vikn9idz8qcad9z7f73arsh5rw18fc1sri9ywz77mpm1s4"; + outputFiles = [ "tools/*" ]; + preInstall = "mv -v tools/lib/* tools && rmdir -v tools/lib"; }; - buildInputs = [ pkgs.gtk-sharp-2_0 ]; + # SOURCE PACKAGES + + MonoAddins = buildDotnetPackage rec { + pname = "Mono.Addins"; + version = "1.2"; + + xBuildFiles = [ + "Mono.Addins/Mono.Addins.csproj" + "Mono.Addins.Setup/Mono.Addins.Setup.csproj" + "Mono.Addins.Gui/Mono.Addins.Gui.csproj" + "Mono.Addins.CecilReflector/Mono.Addins.CecilReflector.csproj" + ]; + outputFiles = [ "bin/*" ]; + + src = fetchFromGitHub { + owner = "mono"; + repo = "mono-addins"; + rev = "mono-addins-${version}"; + sha256 = "1hnn0a2qsjcjprsxas424bzvhsdwy0yc2jj5xbp698c0m9kfk24y"; + }; + + buildInputs = [ pkgs.gtk-sharp-2_0 ]; + + meta = { + description = "Generic framework for creating extensible applications"; + homepage = "https://www.mono-project.com/Mono.Addins"; + longDescription = '' + A generic framework for creating extensible applications, + and for creating libraries which extend those applications. + ''; + license = lib.licenses.mit; + }; + }; - meta = { - description = "Generic framework for creating extensible applications"; - homepage = "https://www.mono-project.com/Mono.Addins"; - longDescription = '' - A generic framework for creating extensible applications, - and for creating libraries which extend those applications. - ''; - license = lib.licenses.mit; + NewtonsoftJson = fetchNuGet { + pname = "Newtonsoft.Json"; + version = "11.0.2"; + sha256 = "07na27n4mlw77f3hg5jpayzxll7f4gyna6x7k9cybmxpbs6l77k7"; + outputFiles = [ "*" ]; }; - }; - NewtonsoftJson = fetchNuGet { - pname = "Newtonsoft.Json"; - version = "11.0.2"; - sha256 = "07na27n4mlw77f3hg5jpayzxll7f4gyna6x7k9cybmxpbs6l77k7"; - outputFiles = [ "*" ]; - }; + Paket = fetchNuGet { + pname = "Paket"; + version = "5.179.1"; + sha256 = "11rzna03i145qj08hwrynya548fwk8xzxmg65swyaf19jd7gzg82"; + outputFiles = [ "*" ]; + }; - Paket = fetchNuGet { - pname = "Paket"; - version = "5.179.1"; - sha256 = "11rzna03i145qj08hwrynya548fwk8xzxmg65swyaf19jd7gzg82"; - outputFiles = [ "*" ]; }; - -}; in self +in +self diff --git a/pkgs/top-level/emacs-packages.nix b/pkgs/top-level/emacs-packages.nix index 968bf2a2800ac0..c1eaf78f153292 100644 --- a/pkgs/top-level/emacs-packages.nix +++ b/pkgs/top-level/emacs-packages.nix @@ -14,101 +14,146 @@ (add-to-list 'package-directory-list "~/.nix-profile/share/emacs/site-lisp/elpa") */ -{ pkgs' -, emacs' -, makeScope -, makeOverridable -, dontRecurseIntoAttrs +{ + pkgs', + emacs', + makeScope, + makeOverridable, + dontRecurseIntoAttrs, }: let - mkElpaDevelPackages = { pkgs, lib }: import ../applications/editors/emacs/elisp-packages/elpa-devel-packages.nix { - inherit (pkgs) pkgs buildPackages; - inherit lib; - }; + mkElpaDevelPackages = + { pkgs, lib }: + import ../applications/editors/emacs/elisp-packages/elpa-devel-packages.nix { + inherit (pkgs) pkgs buildPackages; + inherit lib; + }; - mkElpaPackages = { pkgs, lib }: import ../applications/editors/emacs/elisp-packages/elpa-packages.nix { - inherit (pkgs) pkgs buildPackages; - inherit lib; - }; + mkElpaPackages = + { pkgs, lib }: + import ../applications/editors/emacs/elisp-packages/elpa-packages.nix { + inherit (pkgs) pkgs buildPackages; + inherit lib; + }; - mkNongnuDevelPackages = { pkgs, lib }: import ../applications/editors/emacs/elisp-packages/nongnu-devel-packages.nix { - inherit (pkgs) pkgs buildPackages; - inherit lib; - }; + mkNongnuDevelPackages = + { pkgs, lib }: + import ../applications/editors/emacs/elisp-packages/nongnu-devel-packages.nix { + inherit (pkgs) pkgs buildPackages; + inherit lib; + }; - mkNongnuPackages = { pkgs, lib }: import ../applications/editors/emacs/elisp-packages/nongnu-packages.nix { - inherit (pkgs) pkgs buildPackages; - inherit lib; - }; + mkNongnuPackages = + { pkgs, lib }: + import ../applications/editors/emacs/elisp-packages/nongnu-packages.nix { + inherit (pkgs) pkgs buildPackages; + inherit lib; + }; # Contains both melpa stable & unstable - melpaGeneric = { pkgs, lib }: import ../applications/editors/emacs/elisp-packages/melpa-packages.nix { - inherit lib pkgs; - }; - - mkManualPackages = { pkgs, lib }: import ../applications/editors/emacs/elisp-packages/manual-packages.nix { - inherit lib pkgs; - }; - - emacsWithPackages = { pkgs, lib }: pkgs.callPackage ../applications/editors/emacs/build-support/wrapper.nix { - inherit (pkgs.xorg) lndir; - inherit lib; - }; - -in makeScope pkgs'.newScope (self: makeOverridable ({ - pkgs ? pkgs' - , lib ? pkgs.lib - , elpaDevelPackages ? mkElpaDevelPackages { inherit pkgs lib; } self - , elpaPackages ? mkElpaPackages { inherit pkgs lib; } self - , nongnuDevelPackages ? mkNongnuDevelPackages { inherit pkgs lib; } self - , nongnuPackages ? mkNongnuPackages { inherit pkgs lib; } self - , melpaStablePackages ? melpaGeneric { inherit pkgs lib; } "stable" self - , melpaPackages ? melpaGeneric { inherit pkgs lib; } "unstable" self - , manualPackages ? mkManualPackages { inherit pkgs lib; } self -}: ({} - // elpaDevelPackages // { inherit elpaDevelPackages; } - // elpaPackages // { inherit elpaPackages; } - // nongnuDevelPackages // { inherit nongnuDevelPackages; } - // nongnuPackages // { inherit nongnuPackages; } - // melpaStablePackages // { inherit melpaStablePackages; } - // melpaPackages // { inherit melpaPackages; } - // manualPackages // { inherit manualPackages; } - // { - - # Propagate overridden scope - emacs = emacs'.overrideAttrs(old: { - passthru = (old.passthru or {}) // { - pkgs = dontRecurseIntoAttrs self; - }; - }); - - trivialBuild = pkgs.callPackage ../applications/editors/emacs/build-support/trivial.nix { - inherit (self) emacs; + melpaGeneric = + { pkgs, lib }: + import ../applications/editors/emacs/elisp-packages/melpa-packages.nix { + inherit lib pkgs; }; - elpaBuild = pkgs.callPackage ../applications/editors/emacs/build-support/elpa.nix { - inherit (self) emacs; + mkManualPackages = + { pkgs, lib }: + import ../applications/editors/emacs/elisp-packages/manual-packages.nix { + inherit lib pkgs; }; - melpaBuild = pkgs.callPackage ../applications/editors/emacs/build-support/melpa.nix { - inherit (self) emacs; + emacsWithPackages = + { pkgs, lib }: + pkgs.callPackage ../applications/editors/emacs/build-support/wrapper.nix { + inherit (pkgs.xorg) lndir; + inherit lib; }; - emacsWithPackages = emacsWithPackages { inherit pkgs lib; } self; - withPackages = emacsWithPackages { inherit pkgs lib; } self; - - } // { - - # Package specific priority overrides goes here - - # EXWM is not tagged very often, prefer it from elpa devel. - inherit (elpaDevelPackages) exwm; - - # Telega uploads packages incompatible with stable tdlib to melpa - # Prefer the one from melpa stable - inherit (melpaStablePackages) telega; - - }) -) {}) +in +makeScope pkgs'.newScope ( + self: + makeOverridable ( + { + pkgs ? pkgs', + lib ? pkgs.lib, + elpaDevelPackages ? mkElpaDevelPackages { inherit pkgs lib; } self, + elpaPackages ? mkElpaPackages { inherit pkgs lib; } self, + nongnuDevelPackages ? mkNongnuDevelPackages { inherit pkgs lib; } self, + nongnuPackages ? mkNongnuPackages { inherit pkgs lib; } self, + melpaStablePackages ? melpaGeneric { inherit pkgs lib; } "stable" self, + melpaPackages ? melpaGeneric { inherit pkgs lib; } "unstable" self, + manualPackages ? mkManualPackages { inherit pkgs lib; } self, + }: + ( + { } + // elpaDevelPackages + // { + inherit elpaDevelPackages; + } + // elpaPackages + // { + inherit elpaPackages; + } + // nongnuDevelPackages + // { + inherit nongnuDevelPackages; + } + // nongnuPackages + // { + inherit nongnuPackages; + } + // melpaStablePackages + // { + inherit melpaStablePackages; + } + // melpaPackages + // { + inherit melpaPackages; + } + // manualPackages + // { + inherit manualPackages; + } + // { + + # Propagate overridden scope + emacs = emacs'.overrideAttrs (old: { + passthru = (old.passthru or { }) // { + pkgs = dontRecurseIntoAttrs self; + }; + }); + + trivialBuild = pkgs.callPackage ../applications/editors/emacs/build-support/trivial.nix { + inherit (self) emacs; + }; + + elpaBuild = pkgs.callPackage ../applications/editors/emacs/build-support/elpa.nix { + inherit (self) emacs; + }; + + melpaBuild = pkgs.callPackage ../applications/editors/emacs/build-support/melpa.nix { + inherit (self) emacs; + }; + + emacsWithPackages = emacsWithPackages { inherit pkgs lib; } self; + withPackages = emacsWithPackages { inherit pkgs lib; } self; + + } + // { + + # Package specific priority overrides goes here + + # EXWM is not tagged very often, prefer it from elpa devel. + inherit (elpaDevelPackages) exwm; + + # Telega uploads packages incompatible with stable tdlib to melpa + # Prefer the one from melpa stable + inherit (melpaStablePackages) telega; + + } + ) + ) { } +) diff --git a/pkgs/top-level/hare-third-party.nix b/pkgs/top-level/hare-third-party.nix index 3796bbcba5b97d..b509ffb6ed36ad 100644 --- a/pkgs/top-level/hare-third-party.nix +++ b/pkgs/top-level/hare-third-party.nix @@ -1,14 +1,16 @@ { lib, newScope }: -lib.makeScope newScope (self: -let - inherit (self) callPackage; -in -{ - hare-compress = callPackage ../development/hare-third-party/hare-compress { }; - hare-ev = callPackage ../development/hare-third-party/hare-ev { }; - hare-json = callPackage ../development/hare-third-party/hare-json { }; - hare-ssh = callPackage ../development/hare-third-party/hare-ssh { }; - hare-toml = callPackage ../development/hare-third-party/hare-toml { }; - hare-png = callPackage ../development/hare-third-party/hare-png { }; -}) +lib.makeScope newScope ( + self: + let + inherit (self) callPackage; + in + { + hare-compress = callPackage ../development/hare-third-party/hare-compress { }; + hare-ev = callPackage ../development/hare-third-party/hare-ev { }; + hare-json = callPackage ../development/hare-third-party/hare-json { }; + hare-ssh = callPackage ../development/hare-third-party/hare-ssh { }; + hare-toml = callPackage ../development/hare-third-party/hare-toml { }; + hare-png = callPackage ../development/hare-third-party/hare-png { }; + } +) diff --git a/pkgs/top-level/haskell-packages.nix b/pkgs/top-level/haskell-packages.nix index c0ce67d2df9bd2..95a4da66225a8c 100644 --- a/pkgs/top-level/haskell-packages.nix +++ b/pkgs/top-level/haskell-packages.nix @@ -1,4 +1,11 @@ -{ buildPackages, pkgsBuildBuild, pkgsBuildTarget, pkgs, newScope, stdenv }: +{ + buildPackages, + pkgsBuildBuild, + pkgsBuildTarget, + pkgs, + newScope, + stdenv, +}: let # These are attributes in compiler that support integer-simple. @@ -34,23 +41,29 @@ let }; bootstrapPackageSet = self: super: { - mkDerivation = drv: super.mkDerivation (drv // { - doCheck = false; - doHaddock = false; - enableExecutableProfiling = false; - enableLibraryProfiling = false; - enableSharedExecutables = false; - enableSharedLibraries = false; - }); + mkDerivation = + drv: + super.mkDerivation ( + drv + // { + doCheck = false; + doHaddock = false; + enableExecutableProfiling = false; + enableLibraryProfiling = false; + enableSharedExecutables = false; + enableSharedLibraries = false; + } + ); }; # Use this rather than `rec { ... }` below for sake of overlays. inherit (pkgs.haskell) compiler packages; -in { +in +{ lib = haskellLibUncomposable; - package-list = callPackage ../development/haskell-modules/package-list.nix {}; + package-list = callPackage ../development/haskell-modules/package-list.nix { }; # Always get boot compilers from `pkgsBuildBuild`. The boot (stage0) compiler # is used to build another compiler (stage1) that'll be used to build the @@ -63,608 +76,623 @@ in { # `name: pkgs: pkgs.haskell.packages.${name}.ghc == pkgs.buildPackages.haskell.compiler.${name}.ghc`. # This isn't problematic since pkgsBuildBuild.buildPackages is also build->build, # just something to keep in mind. - compiler = let bb = pkgsBuildBuild.haskell; in { - ghc865Binary = callPackage ../development/compilers/ghc/8.6.5-binary.nix { - # Should be llvmPackages_6 which has been removed from nixpkgs - llvmPackages = null; - }; + compiler = + let + bb = pkgsBuildBuild.haskell; + in + { + ghc865Binary = callPackage ../development/compilers/ghc/8.6.5-binary.nix { + # Should be llvmPackages_6 which has been removed from nixpkgs + llvmPackages = null; + }; - ghc8107Binary = callPackage ../development/compilers/ghc/8.10.7-binary.nix { - llvmPackages = pkgs.llvmPackages_12; - }; + ghc8107Binary = callPackage ../development/compilers/ghc/8.10.7-binary.nix { + llvmPackages = pkgs.llvmPackages_12; + }; - ghc924Binary = callPackage ../development/compilers/ghc/9.2.4-binary.nix { - llvmPackages = pkgs.llvmPackages_12; - }; + ghc924Binary = callPackage ../development/compilers/ghc/9.2.4-binary.nix { + llvmPackages = pkgs.llvmPackages_12; + }; - ghc963Binary = callPackage ../development/compilers/ghc/9.6.3-binary.nix { - llvmPackages = pkgs.llvmPackages_15; - }; + ghc963Binary = callPackage ../development/compilers/ghc/9.6.3-binary.nix { + llvmPackages = pkgs.llvmPackages_15; + }; - ghc8107 = callPackage ../development/compilers/ghc/8.10.7.nix { - bootPkgs = - # the oldest ghc with aarch64-darwin support is 8.10.5 - if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - # to my (@a-m-joseph) knowledge there are no newer official binaries for this platform - bb.packages.ghc865Binary - else - bb.packages.ghc8107Binary; - inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 - python3 = buildPackages.python311; # so that we don't have two of them - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; - llvmPackages = pkgs.llvmPackages_12; - }; - ghc810 = compiler.ghc8107; - ghc902 = callPackage ../development/compilers/ghc/9.0.2.nix { - bootPkgs = - # the oldest ghc with aarch64-darwin support is 8.10.5 - if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc810 - else - bb.packages.ghc8107Binary; - inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 - python3 = buildPackages.python311; # so that we don't have two of them - inherit (buildPackages.darwin) autoSignDarwinBinariesHook xattr; - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; - llvmPackages = pkgs.llvmPackages_12; - }; - ghc90 = compiler.ghc902; - ghc925 = callPackage ../development/compilers/ghc/9.2.5.nix { - bootPkgs = - if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc810 - else - bb.packages.ghc8107Binary; - inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 - python3 = buildPackages.python311; # so that we don't have two of them - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; - llvmPackages = pkgs.llvmPackages_12; - }; - ghc926 = callPackage ../development/compilers/ghc/9.2.6.nix { - bootPkgs = - if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc810 - else - bb.packages.ghc8107Binary; - inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 - python3 = buildPackages.python311; # so that we don't have two of them - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; - llvmPackages = pkgs.llvmPackages_12; - }; - ghc927 = callPackage ../development/compilers/ghc/9.2.7.nix { - bootPkgs = - if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc810 - else - bb.packages.ghc8107Binary; - inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 - python3 = buildPackages.python311; # so that we don't have two of them - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; - llvmPackages = pkgs.llvmPackages_12; - }; - ghc928 = callPackage ../development/compilers/ghc/9.2.8.nix { - bootPkgs = - if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc810 - else - bb.packages.ghc8107Binary; - inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 - python3 = buildPackages.python311; # so that we don't have two of them - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; - llvmPackages = pkgs.llvmPackages_12; - }; - ghc92 = compiler.ghc928; - ghc945 = callPackage ../development/compilers/ghc/9.4.5.nix { - bootPkgs = - # Building with 9.2 is broken due to - # https://gitlab.haskell.org/ghc/ghc/-/issues/21914 - # Use 8.10 as a workaround where possible to keep bootstrap path short. + ghc8107 = callPackage ../development/compilers/ghc/8.10.7.nix { + bootPkgs = + # the oldest ghc with aarch64-darwin support is 8.10.5 + if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + # to my (@a-m-joseph) knowledge there are no newer official binaries for this platform + bb.packages.ghc865Binary + else + bb.packages.ghc8107Binary; + inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 + python3 = buildPackages.python311; # so that we don't have two of them + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; + llvmPackages = pkgs.llvmPackages_12; + }; + ghc810 = compiler.ghc8107; + ghc902 = callPackage ../development/compilers/ghc/9.0.2.nix { + bootPkgs = + # the oldest ghc with aarch64-darwin support is 8.10.5 + if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc810 + else + bb.packages.ghc8107Binary; + inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 + python3 = buildPackages.python311; # so that we don't have two of them + inherit (buildPackages.darwin) autoSignDarwinBinariesHook xattr; + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; + llvmPackages = pkgs.llvmPackages_12; + }; + ghc90 = compiler.ghc902; + ghc925 = callPackage ../development/compilers/ghc/9.2.5.nix { + bootPkgs = + if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc810 + else + bb.packages.ghc8107Binary; + inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 + python3 = buildPackages.python311; # so that we don't have two of them + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; + llvmPackages = pkgs.llvmPackages_12; + }; + ghc926 = callPackage ../development/compilers/ghc/9.2.6.nix { + bootPkgs = + if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc810 + else + bb.packages.ghc8107Binary; + inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 + python3 = buildPackages.python311; # so that we don't have two of them + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; + llvmPackages = pkgs.llvmPackages_12; + }; + ghc927 = callPackage ../development/compilers/ghc/9.2.7.nix { + bootPkgs = + if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc810 + else + bb.packages.ghc8107Binary; + inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 + python3 = buildPackages.python311; # so that we don't have two of them + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; + llvmPackages = pkgs.llvmPackages_12; + }; + ghc928 = callPackage ../development/compilers/ghc/9.2.8.nix { + bootPkgs = + if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc810 + else + bb.packages.ghc8107Binary; + inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 + python3 = buildPackages.python311; # so that we don't have two of them + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; + llvmPackages = pkgs.llvmPackages_12; + }; + ghc92 = compiler.ghc928; + ghc945 = callPackage ../development/compilers/ghc/9.4.5.nix { + bootPkgs = + # Building with 9.2 is broken due to + # https://gitlab.haskell.org/ghc/ghc/-/issues/21914 + # Use 8.10 as a workaround where possible to keep bootstrap path short. - # On ARM text won't build with GHC 8.10.* - if stdenv.buildPlatform.isAarch then - # TODO(@sternenseemann): package bindist - bb.packages.ghc902 - # No suitable bindists for powerpc64le - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc902 - else - bb.packages.ghc8107Binary; - inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 - python3 = buildPackages.python311; # so that we don't have two of them - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # Support range >= 10 && < 14 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; - llvmPackages = pkgs.llvmPackages_12; - }; - ghc946 = callPackage ../development/compilers/ghc/9.4.6.nix { - bootPkgs = - # Building with 9.2 is broken due to - # https://gitlab.haskell.org/ghc/ghc/-/issues/21914 - # Use 8.10 as a workaround where possible to keep bootstrap path short. + # On ARM text won't build with GHC 8.10.* + if stdenv.buildPlatform.isAarch then + # TODO(@sternenseemann): package bindist + bb.packages.ghc902 + # No suitable bindists for powerpc64le + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc902 + else + bb.packages.ghc8107Binary; + inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 + python3 = buildPackages.python311; # so that we don't have two of them + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # Support range >= 10 && < 14 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; + llvmPackages = pkgs.llvmPackages_12; + }; + ghc946 = callPackage ../development/compilers/ghc/9.4.6.nix { + bootPkgs = + # Building with 9.2 is broken due to + # https://gitlab.haskell.org/ghc/ghc/-/issues/21914 + # Use 8.10 as a workaround where possible to keep bootstrap path short. - # On ARM text won't build with GHC 8.10.* - if stdenv.buildPlatform.isAarch then - # TODO(@sternenseemann): package bindist - bb.packages.ghc902 - # No suitable bindists for powerpc64le - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc902 - else - bb.packages.ghc8107Binary; - inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 - python3 = buildPackages.python311; # so that we don't have two of them - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # Support range >= 10 && < 14 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; - llvmPackages = pkgs.llvmPackages_12; - }; - ghc947 = callPackage ../development/compilers/ghc/9.4.7.nix { - bootPkgs = - # Building with 9.2 is broken due to - # https://gitlab.haskell.org/ghc/ghc/-/issues/21914 - # Use 8.10 as a workaround where possible to keep bootstrap path short. + # On ARM text won't build with GHC 8.10.* + if stdenv.buildPlatform.isAarch then + # TODO(@sternenseemann): package bindist + bb.packages.ghc902 + # No suitable bindists for powerpc64le + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc902 + else + bb.packages.ghc8107Binary; + inherit (buildPackages.python311Packages) sphinx; # a distutils issue with 3.12 + python3 = buildPackages.python311; # so that we don't have two of them + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # Support range >= 10 && < 14 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; + llvmPackages = pkgs.llvmPackages_12; + }; + ghc947 = callPackage ../development/compilers/ghc/9.4.7.nix { + bootPkgs = + # Building with 9.2 is broken due to + # https://gitlab.haskell.org/ghc/ghc/-/issues/21914 + # Use 8.10 as a workaround where possible to keep bootstrap path short. - # On ARM text won't build with GHC 8.10.* - if stdenv.buildPlatform.isAarch then - # TODO(@sternenseemann): package bindist - bb.packages.ghc902 - # No suitable bindists for powerpc64le - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc902 - else - bb.packages.ghc8107Binary; - inherit (buildPackages.python3Packages) sphinx; - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # Support range >= 10 && < 14 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; - llvmPackages = pkgs.llvmPackages_12; - }; - ghc948 = callPackage ../development/compilers/ghc/9.4.8.nix { - bootPkgs = - # Building with 9.2 is broken due to - # https://gitlab.haskell.org/ghc/ghc/-/issues/21914 - # Use 8.10 as a workaround where possible to keep bootstrap path short. + # On ARM text won't build with GHC 8.10.* + if stdenv.buildPlatform.isAarch then + # TODO(@sternenseemann): package bindist + bb.packages.ghc902 + # No suitable bindists for powerpc64le + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc902 + else + bb.packages.ghc8107Binary; + inherit (buildPackages.python3Packages) sphinx; + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # Support range >= 10 && < 14 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; + llvmPackages = pkgs.llvmPackages_12; + }; + ghc948 = callPackage ../development/compilers/ghc/9.4.8.nix { + bootPkgs = + # Building with 9.2 is broken due to + # https://gitlab.haskell.org/ghc/ghc/-/issues/21914 + # Use 8.10 as a workaround where possible to keep bootstrap path short. - # On ARM text won't build with GHC 8.10.* - if stdenv.buildPlatform.isAarch then - # TODO(@sternenseemann): package bindist - bb.packages.ghc902 - # No suitable bindists for powerpc64le - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc902 - else - bb.packages.ghc8107Binary; - inherit (buildPackages.python3Packages) sphinx; - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # Support range >= 10 && < 14 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; - llvmPackages = pkgs.llvmPackages_12; - }; - ghc94 = compiler.ghc948; - ghc963 = callPackage ../development/compilers/ghc/9.6.3.nix { - bootPkgs = - # For GHC 9.2 no armv7l bindists are available. - if stdenv.buildPlatform.isAarch32 then - bb.packages.ghc928 - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc928 - else - bb.packages.ghc924Binary; - inherit (buildPackages.python3Packages) sphinx; - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # Support range >= 11 && < 16 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; - llvmPackages = pkgs.llvmPackages_15; - }; - ghc964 = callPackage ../development/compilers/ghc/9.6.4.nix { - bootPkgs = - # For GHC 9.2 no armv7l bindists are available. - if stdenv.buildPlatform.isAarch32 then - bb.packages.ghc928 - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc928 - else - bb.packages.ghc924Binary; - inherit (buildPackages.python3Packages) sphinx; - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # Support range >= 11 && < 16 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; - llvmPackages = pkgs.llvmPackages_15; - }; - ghc965 = callPackage ../development/compilers/ghc/9.6.5.nix { - bootPkgs = - # For GHC 9.2 no armv7l bindists are available. - if stdenv.buildPlatform.isAarch32 then - bb.packages.ghc928 - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc928 - else - bb.packages.ghc924Binary; - inherit (buildPackages.python3Packages) sphinx; - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # Support range >= 11 && < 16 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; - llvmPackages = pkgs.llvmPackages_15; - }; - ghc966 = callPackage ../development/compilers/ghc/9.6.6.nix { - bootPkgs = - # For GHC 9.2 no armv7l bindists are available. - if stdenv.buildPlatform.isAarch32 then - bb.packages.ghc928 - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc928 - else - bb.packages.ghc924Binary; - inherit (buildPackages.python3Packages) sphinx; - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # Support range >= 11 && < 16 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; - llvmPackages = pkgs.llvmPackages_15; - }; - ghc96 = compiler.ghc966; - ghc981 = callPackage ../development/compilers/ghc/9.8.1.nix { - bootPkgs = - # For GHC 9.6 no armv7l bindists are available. - if stdenv.buildPlatform.isAarch32 then - bb.packages.ghc963 - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc963 - else - bb.packages.ghc963Binary; - inherit (buildPackages.python3Packages) sphinx; - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # Support range >= 11 && < 16 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; - llvmPackages = pkgs.llvmPackages_15; - }; - ghc982 = callPackage ../development/compilers/ghc/9.8.2.nix { - bootPkgs = - # For GHC 9.6 no armv7l bindists are available. - if stdenv.buildPlatform.isAarch32 then - bb.packages.ghc963 - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc963 - else - bb.packages.ghc963Binary; - inherit (buildPackages.python3Packages) sphinx; - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # Support range >= 11 && < 16 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; - llvmPackages = pkgs.llvmPackages_15; - }; - ghc983 = callPackage ../development/compilers/ghc/9.8.3.nix { - bootPkgs = - # For GHC 9.6 no armv7l bindists are available. - if stdenv.buildPlatform.isAarch32 then - bb.packages.ghc963 - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc963 - else - bb.packages.ghc963Binary; - inherit (buildPackages.python3Packages) sphinx; - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # Support range >= 11 && < 16 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; - llvmPackages = pkgs.llvmPackages_15; - }; - ghc984 = callPackage ../development/compilers/ghc/9.8.4.nix { - bootPkgs = - # For GHC 9.6 no armv7l bindists are available. - if stdenv.buildPlatform.isAarch32 then - bb.packages.ghc963 - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc963 - else - bb.packages.ghc963Binary; - inherit (buildPackages.python3Packages) sphinx; - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # Support range >= 11 && < 16 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; - llvmPackages = pkgs.llvmPackages_15; - }; - ghc98 = compiler.ghc982; # HLS doesn't work yet with 9.8.3 - ghc9101 = callPackage ../development/compilers/ghc/9.10.1.nix { - bootPkgs = - # For GHC 9.6 no armv7l bindists are available. - if stdenv.buildPlatform.isAarch32 then - bb.packages.ghc963 - else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then - bb.packages.ghc963 - else if stdenv.buildPlatform.isDarwin then - # it seems like the GHC 9.6.* bindists are built with a different - # toolchain than we are using (which I'm guessing from the fact - # that 9.6.4 bindists pass linker flags our ld doesn't support). - # With both 9.6.3 and 9.6.4 binary it is impossible to link against - # the clock package (probably a hsc2hs problem). - bb.packages.ghc963 - else - bb.packages.ghc963Binary; - inherit (buildPackages.python3Packages) sphinx; - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # 2023-01-15: Support range >= 11 && < 16 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; - llvmPackages = pkgs.llvmPackages_15; - }; - ghc910 = compiler.ghc9101; - ghcHEAD = callPackage ../development/compilers/ghc/head.nix { - bootPkgs = - # No suitable bindist packaged yet - bb.packages.ghc9101; - inherit (buildPackages.python3Packages) sphinx; - # Need to use apple's patched xattr until - # https://github.com/xattr/xattr/issues/44 and - # https://github.com/xattr/xattr/issues/55 are solved. - inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; - # 2023-01-15: Support range >= 11 && < 16 - buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_18; - llvmPackages = pkgs.llvmPackages_18; - }; + # On ARM text won't build with GHC 8.10.* + if stdenv.buildPlatform.isAarch then + # TODO(@sternenseemann): package bindist + bb.packages.ghc902 + # No suitable bindists for powerpc64le + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc902 + else + bb.packages.ghc8107Binary; + inherit (buildPackages.python3Packages) sphinx; + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # Support range >= 10 && < 14 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12; + llvmPackages = pkgs.llvmPackages_12; + }; + ghc94 = compiler.ghc948; + ghc963 = callPackage ../development/compilers/ghc/9.6.3.nix { + bootPkgs = + # For GHC 9.2 no armv7l bindists are available. + if stdenv.buildPlatform.isAarch32 then + bb.packages.ghc928 + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc928 + else + bb.packages.ghc924Binary; + inherit (buildPackages.python3Packages) sphinx; + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # Support range >= 11 && < 16 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; + llvmPackages = pkgs.llvmPackages_15; + }; + ghc964 = callPackage ../development/compilers/ghc/9.6.4.nix { + bootPkgs = + # For GHC 9.2 no armv7l bindists are available. + if stdenv.buildPlatform.isAarch32 then + bb.packages.ghc928 + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc928 + else + bb.packages.ghc924Binary; + inherit (buildPackages.python3Packages) sphinx; + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # Support range >= 11 && < 16 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; + llvmPackages = pkgs.llvmPackages_15; + }; + ghc965 = callPackage ../development/compilers/ghc/9.6.5.nix { + bootPkgs = + # For GHC 9.2 no armv7l bindists are available. + if stdenv.buildPlatform.isAarch32 then + bb.packages.ghc928 + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc928 + else + bb.packages.ghc924Binary; + inherit (buildPackages.python3Packages) sphinx; + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # Support range >= 11 && < 16 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; + llvmPackages = pkgs.llvmPackages_15; + }; + ghc966 = callPackage ../development/compilers/ghc/9.6.6.nix { + bootPkgs = + # For GHC 9.2 no armv7l bindists are available. + if stdenv.buildPlatform.isAarch32 then + bb.packages.ghc928 + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc928 + else + bb.packages.ghc924Binary; + inherit (buildPackages.python3Packages) sphinx; + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # Support range >= 11 && < 16 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; + llvmPackages = pkgs.llvmPackages_15; + }; + ghc96 = compiler.ghc966; + ghc981 = callPackage ../development/compilers/ghc/9.8.1.nix { + bootPkgs = + # For GHC 9.6 no armv7l bindists are available. + if stdenv.buildPlatform.isAarch32 then + bb.packages.ghc963 + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc963 + else + bb.packages.ghc963Binary; + inherit (buildPackages.python3Packages) sphinx; + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # Support range >= 11 && < 16 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; + llvmPackages = pkgs.llvmPackages_15; + }; + ghc982 = callPackage ../development/compilers/ghc/9.8.2.nix { + bootPkgs = + # For GHC 9.6 no armv7l bindists are available. + if stdenv.buildPlatform.isAarch32 then + bb.packages.ghc963 + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc963 + else + bb.packages.ghc963Binary; + inherit (buildPackages.python3Packages) sphinx; + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # Support range >= 11 && < 16 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; + llvmPackages = pkgs.llvmPackages_15; + }; + ghc983 = callPackage ../development/compilers/ghc/9.8.3.nix { + bootPkgs = + # For GHC 9.6 no armv7l bindists are available. + if stdenv.buildPlatform.isAarch32 then + bb.packages.ghc963 + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc963 + else + bb.packages.ghc963Binary; + inherit (buildPackages.python3Packages) sphinx; + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # Support range >= 11 && < 16 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; + llvmPackages = pkgs.llvmPackages_15; + }; + ghc984 = callPackage ../development/compilers/ghc/9.8.4.nix { + bootPkgs = + # For GHC 9.6 no armv7l bindists are available. + if stdenv.buildPlatform.isAarch32 then + bb.packages.ghc963 + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc963 + else + bb.packages.ghc963Binary; + inherit (buildPackages.python3Packages) sphinx; + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # Support range >= 11 && < 16 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; + llvmPackages = pkgs.llvmPackages_15; + }; + ghc98 = compiler.ghc982; # HLS doesn't work yet with 9.8.3 + ghc9101 = callPackage ../development/compilers/ghc/9.10.1.nix { + bootPkgs = + # For GHC 9.6 no armv7l bindists are available. + if stdenv.buildPlatform.isAarch32 then + bb.packages.ghc963 + else if stdenv.buildPlatform.isPower64 && stdenv.buildPlatform.isLittleEndian then + bb.packages.ghc963 + else if stdenv.buildPlatform.isDarwin then + # it seems like the GHC 9.6.* bindists are built with a different + # toolchain than we are using (which I'm guessing from the fact + # that 9.6.4 bindists pass linker flags our ld doesn't support). + # With both 9.6.3 and 9.6.4 binary it is impossible to link against + # the clock package (probably a hsc2hs problem). + bb.packages.ghc963 + else + bb.packages.ghc963Binary; + inherit (buildPackages.python3Packages) sphinx; + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # 2023-01-15: Support range >= 11 && < 16 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_15; + llvmPackages = pkgs.llvmPackages_15; + }; + ghc910 = compiler.ghc9101; + ghcHEAD = callPackage ../development/compilers/ghc/head.nix { + bootPkgs = + # No suitable bindist packaged yet + bb.packages.ghc9101; + inherit (buildPackages.python3Packages) sphinx; + # Need to use apple's patched xattr until + # https://github.com/xattr/xattr/issues/44 and + # https://github.com/xattr/xattr/issues/55 are solved. + inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook; + # 2023-01-15: Support range >= 11 && < 16 + buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_18; + llvmPackages = pkgs.llvmPackages_18; + }; - ghcjs = compiler.ghcjs810; - ghcjs810 = callPackage ../development/compilers/ghcjs/8.10 { - bootPkgs = bb.packages.ghc810; - ghcjsSrcJson = ../development/compilers/ghcjs/8.10/git.json; - stage0 = ../development/compilers/ghcjs/8.10/stage0.nix; - }; + ghcjs = compiler.ghcjs810; + ghcjs810 = callPackage ../development/compilers/ghcjs/8.10 { + bootPkgs = bb.packages.ghc810; + ghcjsSrcJson = ../development/compilers/ghcjs/8.10/git.json; + stage0 = ../development/compilers/ghcjs/8.10/stage0.nix; + }; - # The integer-simple attribute set contains all the GHC compilers - # build with integer-simple instead of integer-gmp. - integer-simple = let - integerSimpleGhcNames = pkgs.lib.filter - (name: builtins.elem name integerSimpleIncludes) - (pkgs.lib.attrNames compiler); - in pkgs.recurseIntoAttrs (pkgs.lib.genAttrs - integerSimpleGhcNames - (name: compiler.${name}.override { enableIntegerSimple = true; })); + # The integer-simple attribute set contains all the GHC compilers + # build with integer-simple instead of integer-gmp. + integer-simple = + let + integerSimpleGhcNames = pkgs.lib.filter (name: builtins.elem name integerSimpleIncludes) ( + pkgs.lib.attrNames compiler + ); + in + pkgs.recurseIntoAttrs ( + pkgs.lib.genAttrs integerSimpleGhcNames ( + name: compiler.${name}.override { enableIntegerSimple = true; } + ) + ); - # Starting from GHC 9, integer-{simple,gmp} is replaced by ghc-bignum - # with "native" and "gmp" backends. - native-bignum = let - nativeBignumGhcNames = pkgs.lib.filter - (name: !(builtins.elem name nativeBignumExcludes)) - (pkgs.lib.attrNames compiler); - in pkgs.recurseIntoAttrs (pkgs.lib.genAttrs - nativeBignumGhcNames - (name: compiler.${name}.override { enableNativeBignum = true; })); - }; + # Starting from GHC 9, integer-{simple,gmp} is replaced by ghc-bignum + # with "native" and "gmp" backends. + native-bignum = + let + nativeBignumGhcNames = pkgs.lib.filter (name: !(builtins.elem name nativeBignumExcludes)) ( + pkgs.lib.attrNames compiler + ); + in + pkgs.recurseIntoAttrs ( + pkgs.lib.genAttrs nativeBignumGhcNames ( + name: compiler.${name}.override { enableNativeBignum = true; } + ) + ); + }; # Default overrides that are applied to all package sets. - packageOverrides = self : super : {}; + packageOverrides = self: super: { }; # Always get compilers from `buildPackages` - packages = let bh = buildPackages.haskell; in { + packages = + let + bh = buildPackages.haskell; + in + { - ghc865Binary = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc865Binary; - ghc = bh.compiler.ghc865Binary; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-8.6.x.nix { }; - packageSetConfig = bootstrapPackageSet; - }; - ghc8107Binary = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc8107Binary; - ghc = bh.compiler.ghc8107Binary; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-8.10.x.nix { }; - packageSetConfig = bootstrapPackageSet; - }; - ghc924Binary = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc924Binary; - ghc = bh.compiler.ghc924Binary; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.2.x.nix { }; - packageSetConfig = bootstrapPackageSet; - }; - ghc963Binary = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc963Binary; - ghc = bh.compiler.ghc963Binary; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.6.x.nix { }; - packageSetConfig = bootstrapPackageSet; - }; - ghc8107 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc8107; - ghc = bh.compiler.ghc8107; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-8.10.x.nix { }; - }; - ghc810 = packages.ghc8107; - ghc902 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc902; - ghc = bh.compiler.ghc902; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.0.x.nix { }; - }; - ghc90 = packages.ghc902; - ghc925 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc925; - ghc = bh.compiler.ghc925; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.2.x.nix { }; - }; - ghc926 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc926; - ghc = bh.compiler.ghc926; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.2.x.nix { }; - }; - ghc927 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc927; - ghc = bh.compiler.ghc927; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.2.x.nix { }; - }; - ghc928 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc928; - ghc = bh.compiler.ghc928; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.2.x.nix { }; - }; - ghc92 = packages.ghc928; - ghc945 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc945; - ghc = bh.compiler.ghc945; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.4.x.nix { }; - }; - ghc946 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc946; - ghc = bh.compiler.ghc946; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.4.x.nix { }; - }; - ghc947 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc947; - ghc = bh.compiler.ghc947; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.4.x.nix { }; - }; - ghc948 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc948; - ghc = bh.compiler.ghc948; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.4.x.nix { }; - }; - ghc94 = packages.ghc948; - ghc963 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc963; - ghc = bh.compiler.ghc963; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.6.x.nix { }; - }; - ghc964 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc964; - ghc = bh.compiler.ghc964; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.6.x.nix { }; - }; - ghc965 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc965; - ghc = bh.compiler.ghc965; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.6.x.nix { }; - }; - ghc966 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc966; - ghc = bh.compiler.ghc966; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.6.x.nix { }; - }; - ghc96 = packages.ghc966; - ghc981 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc981; - ghc = bh.compiler.ghc981; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.8.x.nix { }; - }; - ghc982 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc982; - ghc = bh.compiler.ghc982; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.8.x.nix { }; - }; - ghc983 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc983; - ghc = bh.compiler.ghc983; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.8.x.nix { }; - }; - ghc984 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc984; - ghc = bh.compiler.ghc984; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.8.x.nix { }; - }; - ghc98 = packages.ghc982; # HLS doesn't work yet with 9.8.3 - ghc9101 = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghc9101; - ghc = bh.compiler.ghc9101; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.10.x.nix { }; - }; - ghc910 = packages.ghc9101; - ghcHEAD = callPackage ../development/haskell-modules { - buildHaskellPackages = bh.packages.ghcHEAD; - ghc = bh.compiler.ghcHEAD; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.14.x.nix { }; - }; + ghc865Binary = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc865Binary; + ghc = bh.compiler.ghc865Binary; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-8.6.x.nix { }; + packageSetConfig = bootstrapPackageSet; + }; + ghc8107Binary = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc8107Binary; + ghc = bh.compiler.ghc8107Binary; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-8.10.x.nix { }; + packageSetConfig = bootstrapPackageSet; + }; + ghc924Binary = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc924Binary; + ghc = bh.compiler.ghc924Binary; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.2.x.nix { }; + packageSetConfig = bootstrapPackageSet; + }; + ghc963Binary = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc963Binary; + ghc = bh.compiler.ghc963Binary; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.6.x.nix { }; + packageSetConfig = bootstrapPackageSet; + }; + ghc8107 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc8107; + ghc = bh.compiler.ghc8107; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-8.10.x.nix { }; + }; + ghc810 = packages.ghc8107; + ghc902 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc902; + ghc = bh.compiler.ghc902; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.0.x.nix { }; + }; + ghc90 = packages.ghc902; + ghc925 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc925; + ghc = bh.compiler.ghc925; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.2.x.nix { }; + }; + ghc926 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc926; + ghc = bh.compiler.ghc926; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.2.x.nix { }; + }; + ghc927 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc927; + ghc = bh.compiler.ghc927; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.2.x.nix { }; + }; + ghc928 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc928; + ghc = bh.compiler.ghc928; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.2.x.nix { }; + }; + ghc92 = packages.ghc928; + ghc945 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc945; + ghc = bh.compiler.ghc945; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.4.x.nix { }; + }; + ghc946 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc946; + ghc = bh.compiler.ghc946; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.4.x.nix { }; + }; + ghc947 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc947; + ghc = bh.compiler.ghc947; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.4.x.nix { }; + }; + ghc948 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc948; + ghc = bh.compiler.ghc948; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.4.x.nix { }; + }; + ghc94 = packages.ghc948; + ghc963 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc963; + ghc = bh.compiler.ghc963; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.6.x.nix { }; + }; + ghc964 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc964; + ghc = bh.compiler.ghc964; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.6.x.nix { }; + }; + ghc965 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc965; + ghc = bh.compiler.ghc965; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.6.x.nix { }; + }; + ghc966 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc966; + ghc = bh.compiler.ghc966; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.6.x.nix { }; + }; + ghc96 = packages.ghc966; + ghc981 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc981; + ghc = bh.compiler.ghc981; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.8.x.nix { }; + }; + ghc982 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc982; + ghc = bh.compiler.ghc982; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.8.x.nix { }; + }; + ghc983 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc983; + ghc = bh.compiler.ghc983; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.8.x.nix { }; + }; + ghc984 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc984; + ghc = bh.compiler.ghc984; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.8.x.nix { }; + }; + ghc98 = packages.ghc982; # HLS doesn't work yet with 9.8.3 + ghc9101 = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghc9101; + ghc = bh.compiler.ghc9101; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.10.x.nix { }; + }; + ghc910 = packages.ghc9101; + ghcHEAD = callPackage ../development/haskell-modules { + buildHaskellPackages = bh.packages.ghcHEAD; + ghc = bh.compiler.ghcHEAD; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.14.x.nix { }; + }; - ghcjs = packages.ghcjs810; - ghcjs810 = callPackage ../development/haskell-modules rec { - buildHaskellPackages = ghc.bootPkgs; - ghc = bh.compiler.ghcjs810; - compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-8.10.x.nix { }; - packageSetConfig = callPackage ../development/haskell-modules/configuration-ghcjs-8.x.nix { }; - }; + ghcjs = packages.ghcjs810; + ghcjs810 = callPackage ../development/haskell-modules rec { + buildHaskellPackages = ghc.bootPkgs; + ghc = bh.compiler.ghcjs810; + compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-8.10.x.nix { }; + packageSetConfig = callPackage ../development/haskell-modules/configuration-ghcjs-8.x.nix { }; + }; - # The integer-simple attribute set contains package sets for all the GHC compilers - # using integer-simple instead of integer-gmp. - integer-simple = - let - integerSimpleGhcNames = pkgs.lib.filter - (name: builtins.elem name integerSimpleIncludes) - (pkgs.lib.attrNames packages); - in - pkgs.lib.genAttrs integerSimpleGhcNames - (name: + # The integer-simple attribute set contains package sets for all the GHC compilers + # using integer-simple instead of integer-gmp. + integer-simple = + let + integerSimpleGhcNames = pkgs.lib.filter (name: builtins.elem name integerSimpleIncludes) ( + pkgs.lib.attrNames packages + ); + in + pkgs.lib.genAttrs integerSimpleGhcNames ( + name: packages.${name}.override (oldAttrs: { ghc = bh.compiler.integer-simple.${name}; buildHaskellPackages = bh.packages.integer-simple.${name}; - overrides = - pkgs.lib.composeExtensions - (oldAttrs.overrides or (_: _: {})) - (_: _: { integer-simple = null; }); + overrides = pkgs.lib.composeExtensions (oldAttrs.overrides or (_: _: { })) ( + _: _: { integer-simple = null; } + ); }) ); - native-bignum = - let - nativeBignumGhcNames = pkgs.lib.filter - (name: !(builtins.elem name nativeBignumExcludes)) - (pkgs.lib.attrNames compiler); - in - pkgs.lib.genAttrs nativeBignumGhcNames - (name: + native-bignum = + let + nativeBignumGhcNames = pkgs.lib.filter (name: !(builtins.elem name nativeBignumExcludes)) ( + pkgs.lib.attrNames compiler + ); + in + pkgs.lib.genAttrs nativeBignumGhcNames ( + name: packages.${name}.override { ghc = bh.compiler.native-bignum.${name}; buildHaskellPackages = bh.packages.native-bignum.${name}; } ); - }; + }; } diff --git a/pkgs/top-level/haxe-packages.nix b/pkgs/top-level/haxe-packages.nix index e3221412aaa103..53d0119d9e118c 100644 --- a/pkgs/top-level/haxe-packages.nix +++ b/pkgs/top-level/haxe-packages.nix @@ -1,4 +1,13 @@ -{ stdenv, lib, fetchzip, fetchFromGitHub, haxe, neko, jdk, mono }: +{ + stdenv, + lib, + fetchzip, + fetchFromGitHub, + haxe, + neko, + jdk, + mono, +}: let withCommas = lib.replaceStrings [ "." ] [ "," ]; @@ -11,50 +20,64 @@ let export HAXELIB_PATH="$HAXELIB_PATH:$devrepo" ''; - installLibHaxe = { libname, version, files ? "*" }: '' - mkdir -p "$out/lib/haxe/${withCommas libname}/${withCommas version}" - echo -n "${version}" > $out/lib/haxe/${withCommas libname}/.current - cp -dpR ${files} "$out/lib/haxe/${withCommas libname}/${withCommas version}/" - ''; + installLibHaxe = + { + libname, + version, + files ? "*", + }: + '' + mkdir -p "$out/lib/haxe/${withCommas libname}/${withCommas version}" + echo -n "${version}" > $out/lib/haxe/${withCommas libname}/.current + cp -dpR ${files} "$out/lib/haxe/${withCommas libname}/${withCommas version}/" + ''; buildHaxeLib = - { libname - , version - , sha256 - , meta - , ... - } @ attrs: - stdenv.mkDerivation (attrs // { - name = "${libname}-${version}"; - - buildInputs = (attrs.buildInputs or [ ]) ++ [ haxe neko ]; # for setup-hook.sh to work - src = fetchzip rec { + { + libname, + version, + sha256, + meta, + ... + }@attrs: + stdenv.mkDerivation ( + attrs + // { name = "${libname}-${version}"; - url = "http://lib.haxe.org/files/3.0/${withCommas name}.zip"; - inherit sha256; - stripRoot = false; - }; - installPhase = attrs.installPhase or '' - runHook preInstall - ( - if [ $(ls $src | wc -l) == 1 ]; then - cd $src/* || cd $src - else - cd $src - fi - ${installLibHaxe { inherit libname version; }} - ) - runHook postInstall - ''; + buildInputs = (attrs.buildInputs or [ ]) ++ [ + haxe + neko + ]; # for setup-hook.sh to work + src = fetchzip rec { + name = "${libname}-${version}"; + url = "http://lib.haxe.org/files/3.0/${withCommas name}.zip"; + inherit sha256; + stripRoot = false; + }; - meta = { - homepage = "http://lib.haxe.org/p/${libname}"; - license = lib.licenses.bsd2; - platforms = lib.platforms.all; - description = throw "please write meta.description"; - } // attrs.meta; - }); + installPhase = + attrs.installPhase or '' + runHook preInstall + ( + if [ $(ls $src | wc -l) == 1 ]; then + cd $src/* || cd $src + else + cd $src + fi + ${installLibHaxe { inherit libname version; }} + ) + runHook postInstall + ''; + + meta = { + homepage = "http://lib.haxe.org/p/${libname}"; + license = lib.licenses.bsd2; + platforms = lib.platforms.all; + description = throw "please write meta.description"; + } // attrs.meta; + } + ); in { format = buildHaxeLib { @@ -93,7 +116,7 @@ in for f in $out/lib/haxe/${withCommas libname}/${withCommas version}/{,project/libs/nekoapi/}bin/Linux{,64}/*; do chmod +w "$f" patchelf --set-interpreter $(cat $NIX_CC/nix-support/dynamic-linker) "$f" || true - patchelf --set-rpath ${ lib.makeLibraryPath [ stdenv.cc.cc ] } "$f" || true + patchelf --set-rpath ${lib.makeLibraryPath [ stdenv.cc.cc ]} "$f" || true done ''; meta.description = "Runtime support library for the Haxe C++ backend"; diff --git a/pkgs/top-level/java-packages.nix b/pkgs/top-level/java-packages.nix index 020d505d98252b..0def6c5b74b1bb 100644 --- a/pkgs/top-level/java-packages.nix +++ b/pkgs/top-level/java-packages.nix @@ -5,48 +5,64 @@ with pkgs; { inherit (pkgs) openjfx17 openjfx21 openjfx23; - compiler = let - mkOpenjdk = featureVersion: path-darwin: - if stdenv.hostPlatform.isLinux - then mkOpenjdkLinuxOnly featureVersion - else let - openjdk = callPackage path-darwin {}; - in openjdk // { headless = openjdk; }; - - mkOpenjdkLinuxOnly = featureVersion: let - openjdk = callPackage ../development/compilers/openjdk/generic.nix { inherit featureVersion; }; - in assert stdenv.hostPlatform.isLinux; openjdk // { - headless = openjdk.override { headless = true; }; - }; + compiler = + let + mkOpenjdk = + featureVersion: path-darwin: + if stdenv.hostPlatform.isLinux then + mkOpenjdkLinuxOnly featureVersion + else + let + openjdk = callPackage path-darwin { }; + in + openjdk // { headless = openjdk; }; + + mkOpenjdkLinuxOnly = + featureVersion: + let + openjdk = callPackage ../development/compilers/openjdk/generic.nix { inherit featureVersion; }; + in + assert stdenv.hostPlatform.isLinux; + openjdk + // { + headless = openjdk.override { headless = true; }; + }; + + in + rec { + corretto11 = callPackage ../development/compilers/corretto/11.nix { }; + corretto17 = callPackage ../development/compilers/corretto/17.nix { }; + corretto21 = callPackage ../development/compilers/corretto/21.nix { }; + + openjdk8 = mkOpenjdk "8" ../development/compilers/zulu/8.nix; + openjdk11 = mkOpenjdk "11" ../development/compilers/zulu/11.nix; + openjdk17 = mkOpenjdk "17" ../development/compilers/zulu/17.nix; + openjdk21 = mkOpenjdk "21" ../development/compilers/zulu/21.nix; + openjdk23 = mkOpenjdk "23" ../development/compilers/zulu/23.nix; - in rec { - corretto11 = callPackage ../development/compilers/corretto/11.nix { }; - corretto17 = callPackage ../development/compilers/corretto/17.nix { }; - corretto21 = callPackage ../development/compilers/corretto/21.nix { }; - - openjdk8 = mkOpenjdk "8" ../development/compilers/zulu/8.nix; - openjdk11 = mkOpenjdk "11" ../development/compilers/zulu/11.nix; - openjdk17 = mkOpenjdk "17" ../development/compilers/zulu/17.nix; - openjdk21 = mkOpenjdk "21" ../development/compilers/zulu/21.nix; - openjdk23 = mkOpenjdk "23" ../development/compilers/zulu/23.nix; - - # Legacy aliases - openjdk8-bootstrap = temurin-bin.jdk-8; - openjdk11-bootstrap = temurin-bin.jdk-11; - openjdk17-bootstrap = temurin-bin.jdk-17; - - temurin-bin = recurseIntoAttrs (callPackage ( - if stdenv.hostPlatform.isLinux - then ../development/compilers/temurin-bin/jdk-linux.nix - else ../development/compilers/temurin-bin/jdk-darwin.nix - ) {}); - - semeru-bin = recurseIntoAttrs (callPackage ( - if stdenv.hostPlatform.isLinux - then ../development/compilers/semeru-bin/jdk-linux.nix - else ../development/compilers/semeru-bin/jdk-darwin.nix - ) {}); - }; + # Legacy aliases + openjdk8-bootstrap = temurin-bin.jdk-8; + openjdk11-bootstrap = temurin-bin.jdk-11; + openjdk17-bootstrap = temurin-bin.jdk-17; + + temurin-bin = recurseIntoAttrs ( + callPackage ( + if stdenv.hostPlatform.isLinux then + ../development/compilers/temurin-bin/jdk-linux.nix + else + ../development/compilers/temurin-bin/jdk-darwin.nix + ) { } + ); + + semeru-bin = recurseIntoAttrs ( + callPackage ( + if stdenv.hostPlatform.isLinux then + ../development/compilers/semeru-bin/jdk-linux.nix + else + ../development/compilers/semeru-bin/jdk-darwin.nix + ) { } + ); + }; } // lib.optionalAttrs config.allowAliases { jogl_2_4_0 = throw "'jogl_2_4_0' is renamed to/replaced by 'jogl'"; diff --git a/pkgs/top-level/lua-packages.nix b/pkgs/top-level/lua-packages.nix index 6f62f2dee8ec07..b476daa36cb83e 100644 --- a/pkgs/top-level/lua-packages.nix +++ b/pkgs/top-level/lua-packages.nix @@ -1,17 +1,19 @@ -/* This file defines the composition for Lua packages. It has +/* + This file defines the composition for Lua packages. It has been factored out of all-packages.nix because there are many of them. Also, because most Nix expressions for Lua packages are trivial, most are actually defined here. I.e. there's no function for each package in a separate file: the call to the function would - be almost as must code as the function itself. */ - -{ pkgs -, stdenv -, lib -, lua + be almost as must code as the function itself. +*/ + +{ + pkgs, + stdenv, + lib, + lua, }: - self: let @@ -19,15 +21,17 @@ let buildLuaApplication = args: buildLuarocksPackage ({ namePrefix = ""; } // args); - buildLuarocksPackage = lib.makeOverridable (callPackage ../development/interpreters/lua-5/build-luarocks-package.nix { }); + buildLuarocksPackage = lib.makeOverridable ( + callPackage ../development/interpreters/lua-5/build-luarocks-package.nix { } + ); luaLib = callPackage ../development/lua-modules/lib.nix { }; #define build lua package function buildLuaPackage = callPackage ../development/lua-modules/generic { }; - getPath = drv: pathListForVersion: - lib.concatMapStringsSep ";" (path: "${drv}/${path}") pathListForVersion; + getPath = + drv: pathListForVersion: lib.concatMapStringsSep ";" (path: "${drv}/${path}") pathListForVersion; in rec { @@ -42,12 +46,23 @@ rec { getLuaCPath = drv: getPath drv luaLib.luaCPathList; inherit (callPackage ../development/interpreters/lua-5/hooks { }) - luarocksMoveDataFolder luarocksCheckHook; + luarocksMoveDataFolder + luarocksCheckHook + ; inherit lua; inherit buildLuaPackage buildLuarocksPackage buildLuaApplication; - inherit (luaLib) luaOlder luaAtLeast isLua51 isLua52 isLua53 isLuaJIT - requiredLuaModules toLuaModule hasLuaModule; + inherit (luaLib) + luaOlder + luaAtLeast + isLua51 + isLua52 + isLua53 + isLuaJIT + requiredLuaModules + toLuaModule + hasLuaModule + ; # wraps programs in $out/bin with valid LUA_PATH/LUA_CPATH wrapLua = callPackage ../development/interpreters/lua-5/wrap-lua.nix { @@ -59,150 +74,181 @@ rec { # a fork of luarocks used to generate nix lua derivations from rockspecs luarocks-nix = toLuaModule (callPackage ../development/tools/misc/luarocks/luarocks-nix.nix { }); - lua-pam = callPackage({fetchFromGitHub, linux-pam, openpam}: buildLuaPackage rec { - pname = "lua-pam"; - version = "unstable-2015-07-03"; - # Needed for `disabled`, overridden in buildLuaPackage - name = "${pname}-${version}"; - - src = fetchFromGitHub { - owner = "devurandom"; - repo = "lua-pam"; - rev = "3818ee6346a976669d74a5cbc2a83ad2585c5953"; - hash = "sha256-YlMZ5mM9Ij/9yRmgA0X1ahYVZMUx8Igj5OBvAMskqTg="; - fetchSubmodules = true; - }; - - # The makefile tries to link to `-llua` - LUA_LIBS = "-llua"; - - buildInputs = lib.optionals stdenv.hostPlatform.isLinux [linux-pam] - ++ lib.optionals stdenv.hostPlatform.isDarwin [openpam]; - - installPhase = '' - runHook preInstall - - install -Dm755 pam.so $out/lib/lua/${lua.luaversion}/pam.so - - runHook postInstall - ''; - - # The package does not build with lua 5.4 or luaJIT - disabled = luaAtLeast "5.4" || isLuaJIT; - - meta = with lib; { - description = "Lua module for PAM authentication"; - homepage = "https://github.com/devurandom/lua-pam"; - license = licenses.mit; - maintainers = with maintainers; [ traxys ]; - }; - }) {}; - - lua-resty-core = callPackage ({ fetchFromGitHub }: buildLuaPackage rec { - pname = "lua-resty-core"; - version = "0.1.28"; - - src = fetchFromGitHub { - owner = "openresty"; - repo = "lua-resty-core"; - rev = "v${version}"; - sha256 = "sha256-RJ2wcHTu447wM0h1fa2qCBl4/p9XL6ZqX9pktRW64RI="; - }; - - propagatedBuildInputs = [ lua-resty-lrucache ]; - - meta = with lib; { - description = "New FFI-based API for lua-nginx-module"; - homepage = "https://github.com/openresty/lua-resty-core"; - license = licenses.bsd3; - maintainers = [ ]; - }; - }) {}; - - lua-resty-lrucache = callPackage ({ fetchFromGitHub }: buildLuaPackage rec { - pname = "lua-resty-lrucache"; - version = "0.13"; - - src = fetchFromGitHub { - owner = "openresty"; - repo = "lua-resty-lrucache"; - rev = "v${version}"; - sha256 = "sha256-J8RNAMourxqUF8wPKd8XBhNwGC/x1KKvrVnZtYDEu4Q="; - }; - - meta = with lib; { - description = "Lua-land LRU Cache based on LuaJIT FFI"; - homepage = "https://github.com/openresty/lua-resty-lrucache"; - license = licenses.bsd3; - maintainers = [ ]; - }; - }) {}; - - luxio = callPackage ({ fetchurl, which, pkg-config }: buildLuaPackage rec { - pname = "luxio"; - version = "13"; - - src = fetchurl { - url = "https://git.gitano.org.uk/luxio.git/snapshot/luxio-luxio-${version}.tar.bz2"; - sha256 = "1hvwslc25q7k82rxk461zr1a2041nxg7sn3sw3w0y5jxf0giz2pz"; - }; - - nativeBuildInputs = [ which pkg-config ]; - - postPatch = '' - patchShebangs const-proc.lua - ''; - - preBuild = '' - makeFlagsArray=( - INST_LIBDIR="$out/lib/lua/${lua.luaversion}" - INST_LUADIR="$out/share/lua/${lua.luaversion}" - LUA_BINDIR="$out/bin" - INSTALL=install - ); - ''; - - meta = with lib; { - broken = stdenv.hostPlatform.isDarwin; - description = "Lightweight UNIX I/O and POSIX binding for Lua"; - homepage = "https://www.gitano.org.uk/luxio/"; - license = licenses.mit; - maintainers = with maintainers; [ richardipsum ]; - platforms = platforms.unix; - }; - }) {}; + lua-pam = callPackage ( + { + fetchFromGitHub, + linux-pam, + openpam, + }: + buildLuaPackage rec { + pname = "lua-pam"; + version = "unstable-2015-07-03"; + # Needed for `disabled`, overridden in buildLuaPackage + name = "${pname}-${version}"; + + src = fetchFromGitHub { + owner = "devurandom"; + repo = "lua-pam"; + rev = "3818ee6346a976669d74a5cbc2a83ad2585c5953"; + hash = "sha256-YlMZ5mM9Ij/9yRmgA0X1ahYVZMUx8Igj5OBvAMskqTg="; + fetchSubmodules = true; + }; + + # The makefile tries to link to `-llua` + LUA_LIBS = "-llua"; + + buildInputs = + lib.optionals stdenv.hostPlatform.isLinux [ linux-pam ] + ++ lib.optionals stdenv.hostPlatform.isDarwin [ openpam ]; + + installPhase = '' + runHook preInstall + + install -Dm755 pam.so $out/lib/lua/${lua.luaversion}/pam.so + + runHook postInstall + ''; + + # The package does not build with lua 5.4 or luaJIT + disabled = luaAtLeast "5.4" || isLuaJIT; + + meta = with lib; { + description = "Lua module for PAM authentication"; + homepage = "https://github.com/devurandom/lua-pam"; + license = licenses.mit; + maintainers = with maintainers; [ traxys ]; + }; + } + ) { }; + + lua-resty-core = callPackage ( + { fetchFromGitHub }: + buildLuaPackage rec { + pname = "lua-resty-core"; + version = "0.1.28"; + + src = fetchFromGitHub { + owner = "openresty"; + repo = "lua-resty-core"; + rev = "v${version}"; + sha256 = "sha256-RJ2wcHTu447wM0h1fa2qCBl4/p9XL6ZqX9pktRW64RI="; + }; + + propagatedBuildInputs = [ lua-resty-lrucache ]; + + meta = with lib; { + description = "New FFI-based API for lua-nginx-module"; + homepage = "https://github.com/openresty/lua-resty-core"; + license = licenses.bsd3; + maintainers = [ ]; + }; + } + ) { }; + + lua-resty-lrucache = callPackage ( + { fetchFromGitHub }: + buildLuaPackage rec { + pname = "lua-resty-lrucache"; + version = "0.13"; + + src = fetchFromGitHub { + owner = "openresty"; + repo = "lua-resty-lrucache"; + rev = "v${version}"; + sha256 = "sha256-J8RNAMourxqUF8wPKd8XBhNwGC/x1KKvrVnZtYDEu4Q="; + }; + + meta = with lib; { + description = "Lua-land LRU Cache based on LuaJIT FFI"; + homepage = "https://github.com/openresty/lua-resty-lrucache"; + license = licenses.bsd3; + maintainers = [ ]; + }; + } + ) { }; + + luxio = callPackage ( + { + fetchurl, + which, + pkg-config, + }: + buildLuaPackage rec { + pname = "luxio"; + version = "13"; + + src = fetchurl { + url = "https://git.gitano.org.uk/luxio.git/snapshot/luxio-luxio-${version}.tar.bz2"; + sha256 = "1hvwslc25q7k82rxk461zr1a2041nxg7sn3sw3w0y5jxf0giz2pz"; + }; + + nativeBuildInputs = [ + which + pkg-config + ]; + + postPatch = '' + patchShebangs const-proc.lua + ''; + + preBuild = '' + makeFlagsArray=( + INST_LIBDIR="$out/lib/lua/${lua.luaversion}" + INST_LUADIR="$out/share/lua/${lua.luaversion}" + LUA_BINDIR="$out/bin" + INSTALL=install + ); + ''; + + meta = with lib; { + broken = stdenv.hostPlatform.isDarwin; + description = "Lightweight UNIX I/O and POSIX binding for Lua"; + homepage = "https://www.gitano.org.uk/luxio/"; + license = licenses.mit; + maintainers = with maintainers; [ richardipsum ]; + platforms = platforms.unix; + }; + } + ) { }; nfd = callPackage ../development/lua-modules/nfd { inherit (pkgs) zenity; inherit (pkgs.darwin.apple_sdk.frameworks) AppKit; }; - vicious = callPackage ({ fetchFromGitHub }: stdenv.mkDerivation rec { - pname = "vicious"; - version = "2.6.0"; - - src = fetchFromGitHub { - owner = "vicious-widgets"; - repo = "vicious"; - rev = "v${version}"; - sha256 = "sha256-VlJ2hNou2+t7eSyHmFkC2xJ92OH/uJ/ewYHkFLQjUPQ="; - }; - - buildInputs = [ lua ]; - - installPhase = '' - mkdir -p $out/lib/lua/${lua.luaversion}/ - cp -r . $out/lib/lua/${lua.luaversion}/vicious/ - printf "package.path = '$out/lib/lua/${lua.luaversion}/?/init.lua;' .. package.path\nreturn require((...) .. '.init')\n" > $out/lib/lua/${lua.luaversion}/vicious.lua - ''; - - meta = with lib; { - description = "Modular widget library for the awesome window manager"; - homepage = "https://vicious.rtfd.io"; - changelog = "https://vicious.rtfd.io/en/v${version}/changelog.html"; - license = licenses.gpl2Plus; - maintainers = with maintainers; [ makefu mic92 McSinyx ]; - platforms = platforms.linux; - }; - }) {}; + vicious = callPackage ( + { fetchFromGitHub }: + stdenv.mkDerivation rec { + pname = "vicious"; + version = "2.6.0"; + + src = fetchFromGitHub { + owner = "vicious-widgets"; + repo = "vicious"; + rev = "v${version}"; + sha256 = "sha256-VlJ2hNou2+t7eSyHmFkC2xJ92OH/uJ/ewYHkFLQjUPQ="; + }; + + buildInputs = [ lua ]; + + installPhase = '' + mkdir -p $out/lib/lua/${lua.luaversion}/ + cp -r . $out/lib/lua/${lua.luaversion}/vicious/ + printf "package.path = '$out/lib/lua/${lua.luaversion}/?/init.lua;' .. package.path\nreturn require((...) .. '.init')\n" > $out/lib/lua/${lua.luaversion}/vicious.lua + ''; + + meta = with lib; { + description = "Modular widget library for the awesome window manager"; + homepage = "https://vicious.rtfd.io"; + changelog = "https://vicious.rtfd.io/en/v${version}/changelog.html"; + license = licenses.gpl2Plus; + maintainers = with maintainers; [ + makefu + mic92 + McSinyx + ]; + platforms = platforms.linux; + }; + } + ) { }; } diff --git a/pkgs/top-level/make-tarball.nix b/pkgs/top-level/make-tarball.nix index 2fb6e97a711e65..1b90e4bfdb66c7 100644 --- a/pkgs/top-level/make-tarball.nix +++ b/pkgs/top-level/make-tarball.nix @@ -1,8 +1,9 @@ -{ nixpkgs -, officialRelease -, pkgs ? import nixpkgs.outPath {} -, nix ? pkgs.nix -, lib-tests ? import ../../lib/tests/release.nix { inherit pkgs; } +{ + nixpkgs, + officialRelease, + pkgs ? import nixpkgs.outPath { }, + nix ? pkgs.nix, + lib-tests ? import ../../lib/tests/release.nix { inherit pkgs; }, }: pkgs.releaseTools.sourceTarball { @@ -12,11 +13,18 @@ pkgs.releaseTools.sourceTarball { inherit officialRelease; version = pkgs.lib.fileContents ../../.version; versionSuffix = "pre${ - if nixpkgs ? lastModified - then builtins.substring 0 8 (nixpkgs.lastModifiedDate or nixpkgs.lastModified) - else toString (nixpkgs.revCount or 0)}.${nixpkgs.shortRev or "dirty"}"; + if nixpkgs ? lastModified then + builtins.substring 0 8 (nixpkgs.lastModifiedDate or nixpkgs.lastModified) + else + toString (nixpkgs.revCount or 0) + }.${nixpkgs.shortRev or "dirty"}"; - buildInputs = with pkgs; [ nix.out jq lib-tests brotli ]; + buildInputs = with pkgs; [ + nix.out + jq + lib-tests + brotli + ]; configurePhase = '' eval "$preConfigure" diff --git a/pkgs/top-level/metrics.nix b/pkgs/top-level/metrics.nix index 6caec7327e590b..c6ff0f349313d7 100644 --- a/pkgs/top-level/metrics.nix +++ b/pkgs/top-level/metrics.nix @@ -3,7 +3,14 @@ with pkgs; runCommand "nixpkgs-metrics" - { nativeBuildInputs = with pkgs.lib; map getBin [ nix time jq ]; + { + nativeBuildInputs = + with pkgs.lib; + map getBin [ + nix + time + jq + ]; # see https://github.com/NixOS/nixpkgs/issues/52436 #requiredSystemFeatures = [ "benchmark" ]; # dedicated `t2a` machine, by @vcunat } diff --git a/pkgs/top-level/nim-overrides.nix b/pkgs/top-level/nim-overrides.nix index 61717562e89e80..4e45ddf5cff36c 100644 --- a/pkgs/top-level/nim-overrides.nix +++ b/pkgs/top-level/nim-overrides.nix @@ -1,75 +1,131 @@ -{ lib -, stdenv -, getdns -, htslib -, libsass -, openssl -, pkg-config -, raylib -, SDL2 -, tkrzw -, xorg +{ + lib, + stdenv, + getdns, + htslib, + libsass, + openssl, + pkg-config, + raylib, + SDL2, + tkrzw, + xorg, }: # The following is list of overrides that take two arguments each: # - lockAttrs: - an attrset from a Nim lockfile, use this for making constraints on the locked library # - prevAttrs: - preceding arguments to the depender package { - jester = lockAttrs: - { buildInputs ? [ ], ... }: { + jester = + lockAttrs: + { + buildInputs ? [ ], + ... + }: + { buildInputs = buildInputs ++ [ openssl ]; }; - hts = lockAttrs: - { buildInputs ? [ ], ... }: { + hts = + lockAttrs: + { + buildInputs ? [ ], + ... + }: + { buildInputs = buildInputs ++ [ htslib ]; }; - getdns = lockAttrs: - { nativeBuildInputs ? [ ], buildInputs ? [ ], ... }: { + getdns = + lockAttrs: + { + nativeBuildInputs ? [ ], + buildInputs ? [ ], + ... + }: + { nativeBuildInputs = nativeBuildInputs ++ [ pkg-config ]; buildInputs = buildInputs ++ [ getdns ]; }; - hashlib = lockAttrs: - lib.trivial.warnIf - (lockAttrs.rev == "84e0247555e4488594975900401baaf5bbbfb531") + hashlib = + lockAttrs: + lib.trivial.warnIf (lockAttrs.rev == "84e0247555e4488594975900401baaf5bbbfb531") "the selected version of the hashlib Nim library is hardware specific" # https://github.com/khchen/hashlib/pull/4 # remove when fixed upstream (_: { }); - nimraylib_now = lockAttrs: - { buildInputs ? [ ], ... }: { + nimraylib_now = + lockAttrs: + { + buildInputs ? [ ], + ... + }: + { buildInputs = buildInputs ++ [ raylib ]; }; - sass = lockAttrs: - { buildInputs ? [ ], ... }: { + sass = + lockAttrs: + { + buildInputs ? [ ], + ... + }: + { buildInputs = buildInputs ++ [ libsass ]; }; - sdl2 = lockAttrs: - { buildInputs ? [ ], ... }: { + sdl2 = + lockAttrs: + { + buildInputs ? [ ], + ... + }: + { buildInputs = buildInputs ++ [ SDL2 ]; }; - tkrzw = lockAttrs: - { nativeBuildInputs ? [ ], buildInputs ? [ ], ... }: { + tkrzw = + lockAttrs: + { + nativeBuildInputs ? [ ], + buildInputs ? [ ], + ... + }: + { nativeBuildInputs = nativeBuildInputs ++ [ pkg-config ]; buildInputs = buildInputs ++ [ tkrzw ]; }; - x11 = lockAttrs: - { buildInputs ? [ ], ... }: { - buildInputs = buildInputs ++ (with xorg; [ libX11 libXft libXinerama ]); + x11 = + lockAttrs: + { + buildInputs ? [ ], + ... + }: + { + buildInputs = + buildInputs + ++ (with xorg; [ + libX11 + libXft + libXinerama + ]); }; - zippy = lockAttrs: - { nimFlags ? [ ], ... }: { - nimFlags = nimFlags ++ lib.optionals stdenv.hostPlatform.isx86_64 [ - "--passC:-msse4.1" - "--passC:-mpclmul" - ]; + zippy = + lockAttrs: + { + nimFlags ? [ ], + ... + }: + { + nimFlags = + nimFlags + ++ lib.optionals stdenv.hostPlatform.isx86_64 [ + "--passC:-msse4.1" + "--passC:-mpclmul" + ]; }; } diff --git a/pkgs/top-level/nixpkgs-basic-release-checks.nix b/pkgs/top-level/nixpkgs-basic-release-checks.nix index 3cbb581734afb5..ed88991dd2cd65 100644 --- a/pkgs/top-level/nixpkgs-basic-release-checks.nix +++ b/pkgs/top-level/nixpkgs-basic-release-checks.nix @@ -1,4 +1,8 @@ -{ supportedSystems, nixpkgs, pkgs }: +{ + supportedSystems, + nixpkgs, + pkgs, +}: pkgs.runCommand "nixpkgs-release-checks" { @@ -98,4 +102,4 @@ pkgs.runCommand "nixpkgs-release-checks" done touch $out -'' + '' diff --git a/pkgs/top-level/octave-packages.nix b/pkgs/top-level/octave-packages.nix index c6d0839e96827b..00901a75cb5be6 100644 --- a/pkgs/top-level/octave-packages.nix +++ b/pkgs/top-level/octave-packages.nix @@ -11,12 +11,13 @@ # Like python-packages.nix, packages from top-level.nix are not in the scope # of the `callPackage` used for packages here. So, when we do need packages # from outside, we can `inherit` them from `pkgs`. -{ pkgs -, lib -, stdenv -, fetchurl -, newScope -, octave +{ + pkgs, + lib, + stdenv, + fetchurl, + newScope, + octave, }: let @@ -29,7 +30,8 @@ let ; in -makeScope newScope (self: +makeScope newScope ( + self: let callPackage = self.callPackage; @@ -41,18 +43,23 @@ makeScope newScope (self: # Given a list of required Octave package derivations, get a list of # ALL required Octave packages needed for the ones specified to run. - computeRequiredOctavePackages = drvs: let - # Check whether a derivation is an octave package - hasOctavePackage = drv: drv?isOctavePackage; - packages = filter hasOctavePackage drvs; - in unique (packages ++ concatLists (catAttrs "requiredOctavePackages" packages)); - - in { + computeRequiredOctavePackages = + drvs: + let + # Check whether a derivation is an octave package + hasOctavePackage = drv: drv ? isOctavePackage; + packages = filter hasOctavePackage drvs; + in + unique (packages ++ concatLists (catAttrs "requiredOctavePackages" packages)); + + in + { inherit callPackage buildOctavePackage computeRequiredOctavePackages; inherit (callPackage ../development/interpreters/octave/hooks { }) - writeRequiredOctavePackagesHook; + writeRequiredOctavePackagesHook + ; arduino = callPackage ../development/octave-modules/arduino { inherit (pkgs) arduino-core-unwrapped; @@ -131,7 +138,12 @@ makeScope newScope (self: lssa = callPackage ../development/octave-modules/lssa { }; ltfat = callPackage ../development/octave-modules/ltfat { - inherit (octave) fftw fftwSinglePrec portaudio jdk; + inherit (octave) + fftw + fftwSinglePrec + portaudio + jdk + ; inherit (pkgs) fftwFloat fftwLongDouble; }; @@ -218,4 +230,5 @@ makeScope newScope (self: inherit (pkgs) zeromq autoreconfHook; }; - }) + } +) diff --git a/pkgs/top-level/packages-config.nix b/pkgs/top-level/packages-config.nix index 769cfb73d28f5d..0927833509f026 100644 --- a/pkgs/top-level/packages-config.nix +++ b/pkgs/top-level/packages-config.nix @@ -6,37 +6,40 @@ # Enable recursion into attribute sets that nix-env normally doesn't look into # so that we can get a more complete picture of the available packages for the # purposes of the index. - packageOverrides = super: with super; lib.mapAttrs (_: set: recurseIntoAttrs set) { - inherit (super) - agdaPackages - apacheHttpdPackages - fdbPackages - fusePackages - gns3Packages - haskellPackages - idrisPackages - nodePackages - nodePackages_latest - platformioPackages - rPackages - roundcubePlugins - sourceHanPackages - zabbix50 - zabbix60 - zeroadPackages - ; + packageOverrides = + super: + with super; + lib.mapAttrs (_: set: recurseIntoAttrs set) { + inherit (super) + agdaPackages + apacheHttpdPackages + fdbPackages + fusePackages + gns3Packages + haskellPackages + idrisPackages + nodePackages + nodePackages_latest + platformioPackages + rPackages + roundcubePlugins + sourceHanPackages + zabbix50 + zabbix60 + zeroadPackages + ; - # Make sure haskell.compiler is included, so alternative GHC versions show up, - # but don't add haskell.packages.* since they contain the same packages (at - # least by name) as haskellPackages. - haskell = super.haskell // { - compiler = recurseIntoAttrs super.haskell.compiler; - }; + # Make sure haskell.compiler is included, so alternative GHC versions show up, + # but don't add haskell.packages.* since they contain the same packages (at + # least by name) as haskellPackages. + haskell = super.haskell // { + compiler = recurseIntoAttrs super.haskell.compiler; + }; - # minimal-bootstrap packages aren't used for anything but bootstrapping our - # stdenv. They should not be used for any other purpose and therefore not - # show up in search results or repository tracking services that consume our - # packages.json https://github.com/NixOS/nixpkgs/issues/244966 - minimal-bootstrap = { }; - }; + # minimal-bootstrap packages aren't used for anything but bootstrapping our + # stdenv. They should not be used for any other purpose and therefore not + # show up in search results or repository tracking services that consume our + # packages.json https://github.com/NixOS/nixpkgs/issues/244966 + minimal-bootstrap = { }; + }; } diff --git a/pkgs/top-level/php-packages.nix b/pkgs/top-level/php-packages.nix index 83130505ffe4d9..87724fc2bd7595 100644 --- a/pkgs/top-level/php-packages.nix +++ b/pkgs/top-level/php-packages.nix @@ -1,736 +1,857 @@ -{ stdenv -, config -, callPackages -, lib -, pkgs -, phpPackage -, autoconf -, pkg-config -, bzip2 -, curl -, cyrus_sasl -, enchant2 -, freetds -, gd -, gettext -, gmp -, html-tidy -, icu73 -, libffi -, libiconv -, libkrb5 -, libsodium -, libxml2 -, libxslt -, libzip -, net-snmp -, nix-update-script -, oniguruma -, openldap -, openssl_1_1 -, openssl -, overrideSDK -, pam -, pcre2 -, postgresql -, bison -, re2c -, readline -, rsync -, sqlite -, unixODBC -, uwimap -, valgrind -, zlib -, fetchpatch +{ + stdenv, + config, + callPackages, + lib, + pkgs, + phpPackage, + autoconf, + pkg-config, + bzip2, + curl, + cyrus_sasl, + enchant2, + freetds, + gd, + gettext, + gmp, + html-tidy, + icu73, + libffi, + libiconv, + libkrb5, + libsodium, + libxml2, + libxslt, + libzip, + net-snmp, + nix-update-script, + oniguruma, + openldap, + openssl_1_1, + openssl, + overrideSDK, + pam, + pcre2, + postgresql, + bison, + re2c, + readline, + rsync, + sqlite, + unixODBC, + uwimap, + valgrind, + zlib, + fetchpatch, }: -lib.makeScope pkgs.newScope (self: let - inherit (self) buildPecl callPackage mkExtension php; - - builders = import ../build-support/php/builders { - inherit callPackages callPackage buildPecl; - }; -in { - buildPecl = callPackage ../build-support/php/build-pecl.nix { - php = php.unwrapped; - }; - - inherit (builders.v1) buildComposerProject buildComposerWithPlugin composerHooks mkComposerRepository; - - # Next version of the builder - buildComposerProject2 = builders.v2.buildComposerProject; - composerHooks2 = builders.v2.composerHooks; - mkComposerVendor = builders.v2.mkComposerVendor; - - # Wrap mkDerivation to prepend pname with "php-" to make names consistent - # with how buildPecl does it and make the file easier to overview. - mkDerivation = origArgs: - let - args = lib.fix (lib.extends - (_: previousAttrs: { - pname = "php-${previousAttrs.pname}"; - passthru = (previousAttrs.passthru or { }) // { - updateScript = nix-update-script { }; - }; - meta = (previousAttrs.meta or { }) // { - mainProgram = previousAttrs.meta.mainProgram or previousAttrs.pname; - }; - }) - (if lib.isFunction origArgs then origArgs else (_: origArgs)) - ); - in - pkgs.stdenv.mkDerivation args; - - # Function to build an extension which is shipped as part of the php - # source, based on the php version. - # - # Name passed is the name of the extension and is automatically used - # to add the configureFlag "--enable-${name}", which can be overridden. - # - # Build inputs is used for extra deps that may be needed. And zendExtension - # will mark the extension as a zend extension or not. - mkExtension = lib.makeOverridable - ({ name - , configureFlags ? [ "--enable-${extName}" ] - , internalDeps ? [ ] - , postPhpize ? "" - , buildInputs ? [ ] - , zendExtension ? false - , doCheck ? true - , extName ? name - , ... - }@args: stdenv.mkDerivation ((builtins.removeAttrs args [ "name" ]) // { - pname = "php-${name}"; - extensionName = extName; - - outputs = [ "out" "dev" ]; - - inherit (php.unwrapped) version src; - - enableParallelBuilding = true; - - nativeBuildInputs = [ - php.unwrapped - autoconf - pkg-config - re2c - bison - ]; - - inherit configureFlags internalDeps buildInputs zendExtension doCheck; - - preConfigurePhases = [ - "genfiles" - "cdToExtensionRootPhase" - ]; - - genfiles = '' - if [ -f "scripts/dev/genfiles" ]; then - ./scripts/dev/genfiles - fi - ''; - - cdToExtensionRootPhase = '' - # Go to extension source root. - cd "ext/${extName}" - ''; - - preConfigure = '' - nullglobRestore=$(shopt -p nullglob) - shopt -u nullglob # To make ?-globbing work - - # Some extensions have a config0.m4 or config9.m4 - if [ -f config?.m4 ]; then - mv config?.m4 config.m4 - fi - - $nullglobRestore - - phpize - ${postPhpize} - - ${lib.concatMapStringsSep - "\n" - (dep: "mkdir -p ext; ln -s ${dep.dev}/include ext/${dep.extensionName}") - internalDeps - } - ''; - - checkPhase = '' - runHook preCheck - - NO_INTERACTION=yes SKIP_PERF_SENSITIVE=yes SKIP_ONLINE_TESTS=yes make test - runHook postCheck - ''; - - installPhase = '' - runHook preInstall - - mkdir -p $out/lib/php/extensions - cp modules/${extName}.so $out/lib/php/extensions/${extName}.so - mkdir -p $dev/include - ${rsync}/bin/rsync -r --filter="+ */" \ - --filter="+ *.h" \ - --filter="- *" \ - --prune-empty-dirs \ - . $dev/include/ - - runHook postInstall - ''; - - meta = { - description = "PHP upstream extension: ${name}"; - inherit (php.meta) maintainers homepage license platforms; - } // args.meta or { }; - })); - - php = phpPackage; - - # This is a set of interactive tools based on PHP. - tools = { - box = callPackage ../development/php-packages/box { }; - - castor = callPackage ../development/php-packages/castor { }; - - composer = callPackage ../development/php-packages/composer { }; - - composer-local-repo-plugin = callPackage ../development/php-packages/composer-local-repo-plugin { }; - - cyclonedx-php-composer = callPackage ../development/php-packages/cyclonedx-php-composer { }; +lib.makeScope pkgs.newScope ( + self: + let + inherit (self) + buildPecl + callPackage + mkExtension + php + ; + + builders = import ../build-support/php/builders { + inherit callPackages callPackage buildPecl; + }; + in + { + buildPecl = callPackage ../build-support/php/build-pecl.nix { + php = php.unwrapped; + }; - deployer = callPackage ../development/php-packages/deployer { }; + inherit (builders.v1) + buildComposerProject + buildComposerWithPlugin + composerHooks + mkComposerRepository + ; + + # Next version of the builder + buildComposerProject2 = builders.v2.buildComposerProject; + composerHooks2 = builders.v2.composerHooks; + mkComposerVendor = builders.v2.mkComposerVendor; + + # Wrap mkDerivation to prepend pname with "php-" to make names consistent + # with how buildPecl does it and make the file easier to overview. + mkDerivation = + origArgs: + let + args = lib.fix ( + lib.extends (_: previousAttrs: { + pname = "php-${previousAttrs.pname}"; + passthru = (previousAttrs.passthru or { }) // { + updateScript = nix-update-script { }; + }; + meta = (previousAttrs.meta or { }) // { + mainProgram = previousAttrs.meta.mainProgram or previousAttrs.pname; + }; + }) (if lib.isFunction origArgs then origArgs else (_: origArgs)) + ); + in + pkgs.stdenv.mkDerivation args; + + # Function to build an extension which is shipped as part of the php + # source, based on the php version. + # + # Name passed is the name of the extension and is automatically used + # to add the configureFlag "--enable-${name}", which can be overridden. + # + # Build inputs is used for extra deps that may be needed. And zendExtension + # will mark the extension as a zend extension or not. + mkExtension = lib.makeOverridable ( + { + name, + configureFlags ? [ "--enable-${extName}" ], + internalDeps ? [ ], + postPhpize ? "", + buildInputs ? [ ], + zendExtension ? false, + doCheck ? true, + extName ? name, + ... + }@args: + stdenv.mkDerivation ( + (builtins.removeAttrs args [ "name" ]) + // { + pname = "php-${name}"; + extensionName = extName; + + outputs = [ + "out" + "dev" + ]; - grumphp = callPackage ../development/php-packages/grumphp { }; + inherit (php.unwrapped) version src; - phan = callPackage ../development/php-packages/phan { }; + enableParallelBuilding = true; - phing = callPackage ../development/php-packages/phing { }; + nativeBuildInputs = [ + php.unwrapped + autoconf + pkg-config + re2c + bison + ]; - phive = callPackage ../development/php-packages/phive { }; + inherit + configureFlags + internalDeps + buildInputs + zendExtension + doCheck + ; + + preConfigurePhases = [ + "genfiles" + "cdToExtensionRootPhase" + ]; - php-codesniffer = callPackage ../development/php-packages/php-codesniffer { }; + genfiles = '' + if [ -f "scripts/dev/genfiles" ]; then + ./scripts/dev/genfiles + fi + ''; - php-cs-fixer = callPackage ../development/php-packages/php-cs-fixer { }; + cdToExtensionRootPhase = '' + # Go to extension source root. + cd "ext/${extName}" + ''; - php-parallel-lint = callPackage ../development/php-packages/php-parallel-lint { }; + preConfigure = '' + nullglobRestore=$(shopt -p nullglob) + shopt -u nullglob # To make ?-globbing work - phpinsights = callPackage ../development/php-packages/phpinsights { }; + # Some extensions have a config0.m4 or config9.m4 + if [ -f config?.m4 ]; then + mv config?.m4 config.m4 + fi - phpmd = callPackage ../development/php-packages/phpmd { }; + $nullglobRestore - phpspy = callPackage ../development/php-packages/phpspy { }; + phpize + ${postPhpize} - phpstan = callPackage ../development/php-packages/phpstan { }; + ${lib.concatMapStringsSep "\n" ( + dep: "mkdir -p ext; ln -s ${dep.dev}/include ext/${dep.extensionName}" + ) internalDeps} + ''; - psalm = callPackage ../development/php-packages/psalm { }; + checkPhase = '' + runHook preCheck - psysh = callPackage ../development/php-packages/psysh { }; - } // lib.optionalAttrs config.allowAliases { - phpcbf = throw "`phpcbf` is now deprecated, use `php-codesniffer` instead which contains both `phpcs` and `phpcbf`."; - phpcs = throw "`phpcs` is now deprecated, use `php-codesniffer` instead which contains both `phpcs` and `phpcbf`."; - }; + NO_INTERACTION=yes SKIP_PERF_SENSITIVE=yes SKIP_ONLINE_TESTS=yes make test + runHook postCheck + ''; - # This is a set of PHP extensions meant to be used in php.buildEnv - # or php.withExtensions to extend the functionality of the PHP - # interpreter. - # The extensions attributes is composed of three sections: - # 1. The contrib conditional extensions, which are only available on specific PHP versions - # 2. The contrib extensions available - # 3. The core extensions - extensions = - # Contrib extensions - { - amqp = callPackage ../development/php-packages/amqp { }; + installPhase = '' + runHook preInstall - apcu = callPackage ../development/php-packages/apcu { }; + mkdir -p $out/lib/php/extensions + cp modules/${extName}.so $out/lib/php/extensions/${extName}.so + mkdir -p $dev/include + ${rsync}/bin/rsync -r --filter="+ */" \ + --filter="+ *.h" \ + --filter="- *" \ + --prune-empty-dirs \ + . $dev/include/ - ast = callPackage ../development/php-packages/ast { }; + runHook postInstall + ''; - blackfire = callPackage ../development/tools/misc/blackfire/php-probe.nix { }; + meta = { + description = "PHP upstream extension: ${name}"; + inherit (php.meta) + maintainers + homepage + license + platforms + ; + } // args.meta or { }; + } + ) + ); - couchbase = callPackage ../development/php-packages/couchbase { }; + php = phpPackage; - datadog_trace = callPackage ../development/php-packages/datadog_trace { - buildPecl = buildPecl.override { - stdenv = if stdenv.hostPlatform.isDarwin then overrideSDK stdenv "11.0" else stdenv; - }; - inherit (pkgs) darwin; - }; + # This is a set of interactive tools based on PHP. + tools = + { + box = callPackage ../development/php-packages/box { }; - ds = callPackage ../development/php-packages/ds { }; + castor = callPackage ../development/php-packages/castor { }; - event = callPackage ../development/php-packages/event { }; + composer = callPackage ../development/php-packages/composer { }; - gnupg = callPackage ../development/php-packages/gnupg { }; + composer-local-repo-plugin = callPackage ../development/php-packages/composer-local-repo-plugin { }; - grpc = callPackage ../development/php-packages/grpc { }; + cyclonedx-php-composer = callPackage ../development/php-packages/cyclonedx-php-composer { }; - igbinary = callPackage ../development/php-packages/igbinary { }; + deployer = callPackage ../development/php-packages/deployer { }; - imagick = callPackage ../development/php-packages/imagick { }; + grumphp = callPackage ../development/php-packages/grumphp { }; - # Shadowed by built-in version on PHP < 8.3. - imap = callPackage ../development/php-packages/imap { }; + phan = callPackage ../development/php-packages/phan { }; - inotify = callPackage ../development/php-packages/inotify { }; + phing = callPackage ../development/php-packages/phing { }; - ioncube-loader = callPackage ../development/php-packages/ioncube-loader { }; + phive = callPackage ../development/php-packages/phive { }; - mailparse = callPackage ../development/php-packages/mailparse { }; + php-codesniffer = callPackage ../development/php-packages/php-codesniffer { }; - maxminddb = callPackage ../development/php-packages/maxminddb { }; + php-cs-fixer = callPackage ../development/php-packages/php-cs-fixer { }; - memcache = callPackage ../development/php-packages/memcache { }; + php-parallel-lint = callPackage ../development/php-packages/php-parallel-lint { }; - memcached = callPackage ../development/php-packages/memcached { }; + phpinsights = callPackage ../development/php-packages/phpinsights { }; - meminfo = callPackage ../development/php-packages/meminfo { }; + phpmd = callPackage ../development/php-packages/phpmd { }; - memprof = callPackage ../development/php-packages/memprof { }; + phpspy = callPackage ../development/php-packages/phpspy { }; - mongodb = callPackage ../development/php-packages/mongodb { - inherit (pkgs) darwin; - }; + phpstan = callPackage ../development/php-packages/phpstan { }; - msgpack = callPackage ../development/php-packages/msgpack { }; + psalm = callPackage ../development/php-packages/psalm { }; - oci8 = callPackage ../development/php-packages/oci8 { }; + psysh = callPackage ../development/php-packages/psysh { }; + } + // lib.optionalAttrs config.allowAliases { + phpcbf = throw "`phpcbf` is now deprecated, use `php-codesniffer` instead which contains both `phpcs` and `phpcbf`."; + phpcs = throw "`phpcs` is now deprecated, use `php-codesniffer` instead which contains both `phpcs` and `phpcbf`."; + }; - opentelemetry = callPackage ../development/php-packages/opentelemetry { }; + # This is a set of PHP extensions meant to be used in php.buildEnv + # or php.withExtensions to extend the functionality of the PHP + # interpreter. + # The extensions attributes is composed of three sections: + # 1. The contrib conditional extensions, which are only available on specific PHP versions + # 2. The contrib extensions available + # 3. The core extensions + extensions = + # Contrib extensions + { + amqp = callPackage ../development/php-packages/amqp { }; - openswoole = callPackage ../development/php-packages/openswoole { }; + apcu = callPackage ../development/php-packages/apcu { }; - parallel = callPackage ../development/php-packages/parallel { }; + ast = callPackage ../development/php-packages/ast { }; - pdlib = callPackage ../development/php-packages/pdlib { }; + blackfire = callPackage ../development/tools/misc/blackfire/php-probe.nix { }; - pcov = callPackage ../development/php-packages/pcov { }; + couchbase = callPackage ../development/php-packages/couchbase { }; - pdo_oci = buildPecl rec { - inherit (php.unwrapped) src version; + datadog_trace = callPackage ../development/php-packages/datadog_trace { + buildPecl = buildPecl.override { + stdenv = if stdenv.hostPlatform.isDarwin then overrideSDK stdenv "11.0" else stdenv; + }; + inherit (pkgs) darwin; + }; - pname = "pdo_oci"; - sourceRoot = "php-${version}/ext/pdo_oci"; + ds = callPackage ../development/php-packages/ds { }; - buildInputs = [ pkgs.oracle-instantclient ]; - configureFlags = [ "--with-pdo-oci=instantclient,${pkgs.oracle-instantclient.lib}/lib" ]; + event = callPackage ../development/php-packages/event { }; - internalDeps = [ php.extensions.pdo ]; + gnupg = callPackage ../development/php-packages/gnupg { }; - postPatch = '' - sed -i -e 's|OCISDKMANINC=`.*$|OCISDKMANINC="${pkgs.oracle-instantclient.dev}/include"|' config.m4 - ''; + grpc = callPackage ../development/php-packages/grpc { }; - meta.maintainers = lib.teams.php.members; - }; + igbinary = callPackage ../development/php-packages/igbinary { }; - pdo_sqlsrv = callPackage ../development/php-packages/pdo_sqlsrv { }; + imagick = callPackage ../development/php-packages/imagick { }; - phalcon = callPackage ../development/php-packages/phalcon { }; + # Shadowed by built-in version on PHP < 8.3. + imap = callPackage ../development/php-packages/imap { }; - pinba = callPackage ../development/php-packages/pinba { }; + inotify = callPackage ../development/php-packages/inotify { }; - protobuf = callPackage ../development/php-packages/protobuf { }; + ioncube-loader = callPackage ../development/php-packages/ioncube-loader { }; - pspell = callPackage ../development/php-packages/pspell { }; + mailparse = callPackage ../development/php-packages/mailparse { }; - rdkafka = callPackage ../development/php-packages/rdkafka { }; + maxminddb = callPackage ../development/php-packages/maxminddb { }; - redis = callPackage ../development/php-packages/redis { }; + memcache = callPackage ../development/php-packages/memcache { }; - relay = callPackage ../development/php-packages/relay { }; + memcached = callPackage ../development/php-packages/memcached { }; - rrd = callPackage ../development/php-packages/rrd { }; + meminfo = callPackage ../development/php-packages/meminfo { }; - smbclient = callPackage ../development/php-packages/smbclient { }; + memprof = callPackage ../development/php-packages/memprof { }; - snuffleupagus = callPackage ../development/php-packages/snuffleupagus { - inherit (pkgs) darwin; - }; + mongodb = callPackage ../development/php-packages/mongodb { + inherit (pkgs) darwin; + }; - spx = callPackage ../development/php-packages/spx { }; + msgpack = callPackage ../development/php-packages/msgpack { }; - sqlsrv = callPackage ../development/php-packages/sqlsrv { }; + oci8 = callPackage ../development/php-packages/oci8 { }; - ssh2 = callPackage ../development/php-packages/ssh2 { }; + opentelemetry = callPackage ../development/php-packages/opentelemetry { }; - swoole = callPackage ../development/php-packages/swoole { }; + openswoole = callPackage ../development/php-packages/openswoole { }; - tideways = callPackage ../development/php-packages/tideways { }; + parallel = callPackage ../development/php-packages/parallel { }; - uuid = callPackage ../development/php-packages/uuid { }; + pdlib = callPackage ../development/php-packages/pdlib { }; - uv = callPackage ../development/php-packages/uv { }; + pcov = callPackage ../development/php-packages/pcov { }; - vld = callPackage ../development/php-packages/vld { }; + pdo_oci = buildPecl rec { + inherit (php.unwrapped) src version; - xdebug = callPackage ../development/php-packages/xdebug { }; + pname = "pdo_oci"; + sourceRoot = "php-${version}/ext/pdo_oci"; - yaml = callPackage ../development/php-packages/yaml { }; + buildInputs = [ pkgs.oracle-instantclient ]; + configureFlags = [ "--with-pdo-oci=instantclient,${pkgs.oracle-instantclient.lib}/lib" ]; - zstd = callPackage ../development/php-packages/zstd { }; - } // lib.optionalAttrs config.allowAliases { - php-spx = throw "php-spx is deprecated, use spx instead"; - } // ( - # Core extensions - let - # This list contains build instructions for different modules that one may - # want to build. - # - # These will be passed as arguments to mkExtension above. - extensionData = [ - { name = "bcmath"; } - { name = "bz2"; buildInputs = [ bzip2 ]; configureFlags = [ "--with-bz2=${bzip2.dev}" ]; } - { name = "calendar"; } - { name = "ctype"; } - { - name = "curl"; - buildInputs = [ curl ]; - configureFlags = [ "--with-curl=${curl.dev}" ]; - doCheck = false; - } - { name = "dba"; } - { - name = "dom"; - buildInputs = [ libxml2 ]; - configureFlags = [ - "--enable-dom" - ]; - } - { - name = "enchant"; - buildInputs = [ enchant2 ]; - configureFlags = [ "--with-enchant" ]; - doCheck = false; - } - { name = "exif"; doCheck = false; } - { name = "ffi"; buildInputs = [ libffi ]; } - { - name = "fileinfo"; - buildInputs = [ pcre2 ]; - } - { name = "filter"; buildInputs = [ pcre2 ]; } - { name = "ftp"; buildInputs = [ openssl ]; } - { - name = "gd"; - buildInputs = [ zlib gd ]; - configureFlags = [ - "--enable-gd" - "--with-external-gd=${gd.dev}" - "--enable-gd-jis-conv" - ]; - doCheck = false; - } - { - name = "gettext"; - buildInputs = [ gettext ]; - postPhpize = ''substituteInPlace configure --replace-fail 'as_fn_error $? "Cannot locate header file libintl.h" "$LINENO" 5' ':' ''; - configureFlags = [ "--with-gettext=${gettext}" ]; - } - { - name = "gmp"; - buildInputs = [ gmp ]; - configureFlags = [ "--with-gmp=${gmp.dev}" ]; - } - { - name = "iconv"; - buildInputs = [ libiconv ]; - configureFlags = [ "--with-iconv" ]; - # Some other extensions support separate libdirs, but iconv does not. This causes problems with detecting - # Darwin’s libiconv because it has separate outputs. Adding `-liconv` works around the issue. - env = lib.optionalAttrs stdenv.hostPlatform.isDarwin { NIX_LDFLAGS = "-liconv"; }; - doCheck = stdenv.hostPlatform.isLinux; - } - { - name = "intl"; - buildInputs = [ icu73 ]; - } - { - name = "ldap"; - buildInputs = [ openldap cyrus_sasl ]; - configureFlags = [ - "--with-ldap" - "LDAP_DIR=${openldap.dev}" - "LDAP_INCDIR=${openldap.dev}/include" - "LDAP_LIBDIR=${openldap.out}/lib" - ] ++ lib.optionals stdenv.hostPlatform.isLinux [ - "--with-ldap-sasl=${cyrus_sasl.dev}" - ]; - doCheck = false; - } - { - name = "mbstring"; - buildInputs = [ oniguruma pcre2 ]; - doCheck = false; - } - { - name = "mysqli"; - internalDeps = [ php.extensions.mysqlnd ]; - configureFlags = [ "--with-mysqli=mysqlnd" "--with-mysql-sock=/run/mysqld/mysqld.sock" ]; - doCheck = false; - } - { - name = "mysqlnd"; - buildInputs = [ zlib openssl ]; - # The configure script doesn't correctly add library link - # flags, so we add them to the variable used by the Makefile - # when linking. - MYSQLND_SHARED_LIBADD = "-lz -lssl -lcrypto"; - # The configure script builds a config.h which is never - # included. Let's include it in the main header file - # included by all .c-files. - patches = [ - (pkgs.writeText "mysqlnd_config.patch" '' - --- a/ext/mysqlnd/mysqlnd.h - +++ b/ext/mysqlnd/mysqlnd.h - @@ -1,3 +1,6 @@ - +#ifdef HAVE_CONFIG_H - +#include "config.h" - +#endif - /* - +----------------------------------------------------------------------+ - | Copyright (c) The PHP Group | - '') - ]; - } - { - name = "opcache"; - buildInputs = [ pcre2 ] ++ - lib.optional - (!stdenv.hostPlatform.isDarwin && lib.meta.availableOn stdenv.hostPlatform valgrind) - valgrind.dev; - configureFlags = lib.optional php.ztsSupport "--disable-opcache-jit"; - zendExtension = true; - postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' - # Tests are flaky on darwin - rm ext/opcache/tests/blacklist.phpt - rm ext/opcache/tests/bug66338.phpt - rm ext/opcache/tests/bug78106.phpt - rm ext/opcache/tests/issue0115.phpt - rm ext/opcache/tests/issue0149.phpt - rm ext/opcache/tests/revalidate_path_01.phpt - ''; - # Tests launch the builtin webserver. - __darwinAllowLocalNetworking = true; - } - { - name = "openssl"; - buildInputs = [ openssl ]; - configureFlags = [ "--with-openssl" ]; - doCheck = false; - } - # This provides a legacy OpenSSL PHP extension - # For situations where OpenSSL 3 do not support a set of features - # without a specific openssl.cnf file - { - name = "openssl-legacy"; - extName = "openssl"; - buildInputs = [ openssl_1_1 ]; - configureFlags = [ "--with-openssl" ]; - doCheck = false; - } - { name = "pcntl"; } - { name = "pdo"; doCheck = false; } - { - name = "pdo_dblib"; - internalDeps = [ php.extensions.pdo ]; - configureFlags = [ "--with-pdo-dblib=${freetds}" ]; - meta.broken = stdenv.hostPlatform.isDarwin; - doCheck = false; - } - { - name = "pdo_mysql"; - internalDeps = with php.extensions; [ pdo mysqlnd ]; - configureFlags = [ "--with-pdo-mysql=mysqlnd" "PHP_MYSQL_SOCK=/run/mysqld/mysqld.sock" ]; - doCheck = false; - } - { - name = "pdo_odbc"; internalDeps = [ php.extensions.pdo ]; - buildInputs = [ unixODBC ]; - configureFlags = [ "--with-pdo-odbc=unixODBC,${unixODBC}" ]; - doCheck = false; - } - { - name = "pdo_pgsql"; - internalDeps = [ php.extensions.pdo ]; - configureFlags = [ "--with-pdo-pgsql=${lib.getDev postgresql}" ]; - doCheck = false; - } - { - name = "pdo_sqlite"; - internalDeps = [ php.extensions.pdo ]; - buildInputs = [ sqlite ]; - configureFlags = [ "--with-pdo-sqlite=${sqlite.dev}" ]; - doCheck = false; - } - { - name = "pgsql"; - buildInputs = [ pcre2 ]; - configureFlags = [ "--with-pgsql=${lib.getDev postgresql}" ]; - doCheck = false; - } - { name = "posix"; doCheck = false; } - { - name = "readline"; - buildInputs = [ - readline - ]; - configureFlags = [ - "--with-readline=${readline.dev}" - ]; + postPatch = '' - # Fix `--with-readline` option not being available. - # `PHP_ALWAYS_SHARED` generated by phpize enables all options - # without the possibility to override them. But when `--with-libedit` - # is enabled, `--with-readline` is not registered. - echo ' - AC_DEFUN([PHP_ALWAYS_SHARED],[ - test "[$]$1" != "no" && ext_shared=yes - ])dnl - ' | cat - ext/readline/config.m4 > ext/readline/config.m4.tmp - mv ext/readline/config.m4{.tmp,} + sed -i -e 's|OCISDKMANINC=`.*$|OCISDKMANINC="${pkgs.oracle-instantclient.dev}/include"|' config.m4 ''; - doCheck = false; - } - { name = "session"; - doCheck = false; - } - { name = "shmop"; } - { - name = "simplexml"; - buildInputs = [ libxml2 pcre2 ]; - configureFlags = [ - "--enable-simplexml" - ]; - } - { - name = "snmp"; - buildInputs = [ net-snmp openssl ]; - configureFlags = [ "--with-snmp" ]; - doCheck = false; - } - { - name = "soap"; - buildInputs = [ libxml2 ]; - configureFlags = [ - "--enable-soap" - ]; - # Some tests are causing issues in the Darwin sandbox with issues - # such as - # Unknown: php_network_getaddresses: getaddrinfo for localhost failed: nodename nor servname provided - doCheck = !stdenv.hostPlatform.isDarwin && lib.versionOlder php.version "8.4"; - internalDeps = [ php.extensions.session ]; - patches = lib.optionals (lib.versionAtLeast php.version "8.3" && lib.versionOlder php.version "8.4") [ - # https://github.com/php/php-src/pull/16733 (fix soap test) - (fetchpatch { - url = "https://github.com/php/php-src/commit/5c308d61db104854e4ff84ab123e3ea56e1b4046.patch"; - hash = "sha256-xQ4Sg4kL0cgHYauRW2AzGgFXfcqtxeRVhI9zNh7CsoM="; - }) - ]; - } - { - name = "sockets"; - doCheck = false; - } - { name = "sodium"; buildInputs = [ libsodium ]; } - { - name = "sqlite3"; - buildInputs = [ sqlite ]; - - # The `sqlite3_bind_bug68849.phpt` test is currently broken for i686 Linux systems since sqlite 3.43, cf.: - # - https://github.com/php/php-src/issues/12076 - # - https://www.sqlite.org/forum/forumpost/abbb95376ec6cd5f - patches = lib.optionals (stdenv.hostPlatform.isi686 && stdenv.hostPlatform.isLinux) [ - ../development/interpreters/php/skip-sqlite3_bind_bug68849.phpt.patch - ]; - } - { name = "sysvmsg"; } - { name = "sysvsem"; } - { name = "sysvshm"; } - { name = "tidy"; configureFlags = [ "--with-tidy=${html-tidy}" ]; doCheck = false; } - { - name = "tokenizer"; - patches = [ ../development/interpreters/php/fix-tokenizer-php81.patch ]; - } - { - name = "xml"; - buildInputs = [ libxml2 ]; - configureFlags = [ - "--enable-xml" - ]; - doCheck = false; - } - { - name = "xmlreader"; - buildInputs = [ libxml2 ]; - internalDeps = [ php.extensions.dom ]; - env.NIX_CFLAGS_COMPILE = toString [ "-I../.." "-DHAVE_DOM" ]; - doCheck = false; - configureFlags = [ - "--enable-xmlreader" - ]; - } - { - name = "xmlwriter"; - buildInputs = [ libxml2 ]; - configureFlags = [ - "--enable-xmlwriter" - ]; - } - { - name = "xsl"; - buildInputs = [ libxslt libxml2 ]; - internalDeps = [ php.extensions.dom ]; - doCheck = false; - env.NIX_CFLAGS_COMPILE = toString [ "-I../.." "-DHAVE_DOM" ]; - configureFlags = [ "--with-xsl=${libxslt.dev}" ]; - } - { - name = "zend_test"; - internalDeps = [ php.extensions.dom ]; - env.NIX_CFLAGS_COMPILE = "-I${libxml2.dev}/include/libxml2"; - } - { - name = "zip"; - buildInputs = [ libzip pcre2 ]; - configureFlags = [ - "--with-zip" - ]; - doCheck = false; - } - { - name = "zlib"; - buildInputs = [ zlib ]; - configureFlags = [ - "--with-zlib" - ]; - } - ] ++ lib.optionals (lib.versionOlder php.version "8.3") [ - # Using version from PECL on new PHP versions. - { - name = "imap"; - buildInputs = [ uwimap openssl pam pcre2 libkrb5 ]; - configureFlags = [ "--with-imap=${uwimap}" "--with-imap-ssl" "--with-kerberos" ]; - } - ]; - - # Convert the list of attrs: - # [ { name = ; ... } ... ] - # to a list of - # [ { name = ; value = ; } ... ] - # - # which we later use listToAttrs to make all attrs available by name. - namedExtensions = builtins.map - (drv: { - name = drv.name; - value = mkExtension drv; - }) - extensionData; - - # Produce the final attribute set of all extensions defined. - in - builtins.listToAttrs namedExtensions - ); -}) + + meta.maintainers = lib.teams.php.members; + }; + + pdo_sqlsrv = callPackage ../development/php-packages/pdo_sqlsrv { }; + + phalcon = callPackage ../development/php-packages/phalcon { }; + + pinba = callPackage ../development/php-packages/pinba { }; + + protobuf = callPackage ../development/php-packages/protobuf { }; + + pspell = callPackage ../development/php-packages/pspell { }; + + rdkafka = callPackage ../development/php-packages/rdkafka { }; + + redis = callPackage ../development/php-packages/redis { }; + + relay = callPackage ../development/php-packages/relay { }; + + rrd = callPackage ../development/php-packages/rrd { }; + + smbclient = callPackage ../development/php-packages/smbclient { }; + + snuffleupagus = callPackage ../development/php-packages/snuffleupagus { + inherit (pkgs) darwin; + }; + + spx = callPackage ../development/php-packages/spx { }; + + sqlsrv = callPackage ../development/php-packages/sqlsrv { }; + + ssh2 = callPackage ../development/php-packages/ssh2 { }; + + swoole = callPackage ../development/php-packages/swoole { }; + + tideways = callPackage ../development/php-packages/tideways { }; + + uuid = callPackage ../development/php-packages/uuid { }; + + uv = callPackage ../development/php-packages/uv { }; + + vld = callPackage ../development/php-packages/vld { }; + + xdebug = callPackage ../development/php-packages/xdebug { }; + + yaml = callPackage ../development/php-packages/yaml { }; + + zstd = callPackage ../development/php-packages/zstd { }; + } + // lib.optionalAttrs config.allowAliases { + php-spx = throw "php-spx is deprecated, use spx instead"; + } + // ( + # Core extensions + let + # This list contains build instructions for different modules that one may + # want to build. + # + # These will be passed as arguments to mkExtension above. + extensionData = + [ + { name = "bcmath"; } + { + name = "bz2"; + buildInputs = [ bzip2 ]; + configureFlags = [ "--with-bz2=${bzip2.dev}" ]; + } + { name = "calendar"; } + { name = "ctype"; } + { + name = "curl"; + buildInputs = [ curl ]; + configureFlags = [ "--with-curl=${curl.dev}" ]; + doCheck = false; + } + { name = "dba"; } + { + name = "dom"; + buildInputs = [ libxml2 ]; + configureFlags = [ + "--enable-dom" + ]; + } + { + name = "enchant"; + buildInputs = [ enchant2 ]; + configureFlags = [ "--with-enchant" ]; + doCheck = false; + } + { + name = "exif"; + doCheck = false; + } + { + name = "ffi"; + buildInputs = [ libffi ]; + } + { + name = "fileinfo"; + buildInputs = [ pcre2 ]; + } + { + name = "filter"; + buildInputs = [ pcre2 ]; + } + { + name = "ftp"; + buildInputs = [ openssl ]; + } + { + name = "gd"; + buildInputs = [ + zlib + gd + ]; + configureFlags = [ + "--enable-gd" + "--with-external-gd=${gd.dev}" + "--enable-gd-jis-conv" + ]; + doCheck = false; + } + { + name = "gettext"; + buildInputs = [ gettext ]; + postPhpize = ''substituteInPlace configure --replace-fail 'as_fn_error $? "Cannot locate header file libintl.h" "$LINENO" 5' ':' ''; + configureFlags = [ "--with-gettext=${gettext}" ]; + } + { + name = "gmp"; + buildInputs = [ gmp ]; + configureFlags = [ "--with-gmp=${gmp.dev}" ]; + } + { + name = "iconv"; + buildInputs = [ libiconv ]; + configureFlags = [ "--with-iconv" ]; + # Some other extensions support separate libdirs, but iconv does not. This causes problems with detecting + # Darwin’s libiconv because it has separate outputs. Adding `-liconv` works around the issue. + env = lib.optionalAttrs stdenv.hostPlatform.isDarwin { NIX_LDFLAGS = "-liconv"; }; + doCheck = stdenv.hostPlatform.isLinux; + } + { + name = "intl"; + buildInputs = [ icu73 ]; + } + { + name = "ldap"; + buildInputs = [ + openldap + cyrus_sasl + ]; + configureFlags = + [ + "--with-ldap" + "LDAP_DIR=${openldap.dev}" + "LDAP_INCDIR=${openldap.dev}/include" + "LDAP_LIBDIR=${openldap.out}/lib" + ] + ++ lib.optionals stdenv.hostPlatform.isLinux [ + "--with-ldap-sasl=${cyrus_sasl.dev}" + ]; + doCheck = false; + } + { + name = "mbstring"; + buildInputs = [ + oniguruma + pcre2 + ]; + doCheck = false; + } + { + name = "mysqli"; + internalDeps = [ php.extensions.mysqlnd ]; + configureFlags = [ + "--with-mysqli=mysqlnd" + "--with-mysql-sock=/run/mysqld/mysqld.sock" + ]; + doCheck = false; + } + { + name = "mysqlnd"; + buildInputs = [ + zlib + openssl + ]; + # The configure script doesn't correctly add library link + # flags, so we add them to the variable used by the Makefile + # when linking. + MYSQLND_SHARED_LIBADD = "-lz -lssl -lcrypto"; + # The configure script builds a config.h which is never + # included. Let's include it in the main header file + # included by all .c-files. + patches = [ + (pkgs.writeText "mysqlnd_config.patch" '' + --- a/ext/mysqlnd/mysqlnd.h + +++ b/ext/mysqlnd/mysqlnd.h + @@ -1,3 +1,6 @@ + +#ifdef HAVE_CONFIG_H + +#include "config.h" + +#endif + /* + +----------------------------------------------------------------------+ + | Copyright (c) The PHP Group | + '') + ]; + } + { + name = "opcache"; + buildInputs = + [ pcre2 ] + ++ lib.optional ( + !stdenv.hostPlatform.isDarwin && lib.meta.availableOn stdenv.hostPlatform valgrind + ) valgrind.dev; + configureFlags = lib.optional php.ztsSupport "--disable-opcache-jit"; + zendExtension = true; + postPatch = lib.optionalString stdenv.hostPlatform.isDarwin '' + # Tests are flaky on darwin + rm ext/opcache/tests/blacklist.phpt + rm ext/opcache/tests/bug66338.phpt + rm ext/opcache/tests/bug78106.phpt + rm ext/opcache/tests/issue0115.phpt + rm ext/opcache/tests/issue0149.phpt + rm ext/opcache/tests/revalidate_path_01.phpt + ''; + # Tests launch the builtin webserver. + __darwinAllowLocalNetworking = true; + } + { + name = "openssl"; + buildInputs = [ openssl ]; + configureFlags = [ "--with-openssl" ]; + doCheck = false; + } + # This provides a legacy OpenSSL PHP extension + # For situations where OpenSSL 3 do not support a set of features + # without a specific openssl.cnf file + { + name = "openssl-legacy"; + extName = "openssl"; + buildInputs = [ openssl_1_1 ]; + configureFlags = [ "--with-openssl" ]; + doCheck = false; + } + { name = "pcntl"; } + { + name = "pdo"; + doCheck = false; + } + { + name = "pdo_dblib"; + internalDeps = [ php.extensions.pdo ]; + configureFlags = [ "--with-pdo-dblib=${freetds}" ]; + meta.broken = stdenv.hostPlatform.isDarwin; + doCheck = false; + } + { + name = "pdo_mysql"; + internalDeps = with php.extensions; [ + pdo + mysqlnd + ]; + configureFlags = [ + "--with-pdo-mysql=mysqlnd" + "PHP_MYSQL_SOCK=/run/mysqld/mysqld.sock" + ]; + doCheck = false; + } + { + name = "pdo_odbc"; + internalDeps = [ php.extensions.pdo ]; + buildInputs = [ unixODBC ]; + configureFlags = [ "--with-pdo-odbc=unixODBC,${unixODBC}" ]; + doCheck = false; + } + { + name = "pdo_pgsql"; + internalDeps = [ php.extensions.pdo ]; + configureFlags = [ "--with-pdo-pgsql=${lib.getDev postgresql}" ]; + doCheck = false; + } + { + name = "pdo_sqlite"; + internalDeps = [ php.extensions.pdo ]; + buildInputs = [ sqlite ]; + configureFlags = [ "--with-pdo-sqlite=${sqlite.dev}" ]; + doCheck = false; + } + { + name = "pgsql"; + buildInputs = [ pcre2 ]; + configureFlags = [ "--with-pgsql=${lib.getDev postgresql}" ]; + doCheck = false; + } + { + name = "posix"; + doCheck = false; + } + { + name = "readline"; + buildInputs = [ + readline + ]; + configureFlags = [ + "--with-readline=${readline.dev}" + ]; + postPatch = '' + # Fix `--with-readline` option not being available. + # `PHP_ALWAYS_SHARED` generated by phpize enables all options + # without the possibility to override them. But when `--with-libedit` + # is enabled, `--with-readline` is not registered. + echo ' + AC_DEFUN([PHP_ALWAYS_SHARED],[ + test "[$]$1" != "no" && ext_shared=yes + ])dnl + ' | cat - ext/readline/config.m4 > ext/readline/config.m4.tmp + mv ext/readline/config.m4{.tmp,} + ''; + doCheck = false; + } + { + name = "session"; + doCheck = false; + } + { name = "shmop"; } + { + name = "simplexml"; + buildInputs = [ + libxml2 + pcre2 + ]; + configureFlags = [ + "--enable-simplexml" + ]; + } + { + name = "snmp"; + buildInputs = [ + net-snmp + openssl + ]; + configureFlags = [ "--with-snmp" ]; + doCheck = false; + } + { + name = "soap"; + buildInputs = [ libxml2 ]; + configureFlags = [ + "--enable-soap" + ]; + # Some tests are causing issues in the Darwin sandbox with issues + # such as + # Unknown: php_network_getaddresses: getaddrinfo for localhost failed: nodename nor servname provided + doCheck = !stdenv.hostPlatform.isDarwin && lib.versionOlder php.version "8.4"; + internalDeps = [ php.extensions.session ]; + patches = + lib.optionals (lib.versionAtLeast php.version "8.3" && lib.versionOlder php.version "8.4") + [ + # https://github.com/php/php-src/pull/16733 (fix soap test) + (fetchpatch { + url = "https://github.com/php/php-src/commit/5c308d61db104854e4ff84ab123e3ea56e1b4046.patch"; + hash = "sha256-xQ4Sg4kL0cgHYauRW2AzGgFXfcqtxeRVhI9zNh7CsoM="; + }) + ]; + } + { + name = "sockets"; + doCheck = false; + } + { + name = "sodium"; + buildInputs = [ libsodium ]; + } + { + name = "sqlite3"; + buildInputs = [ sqlite ]; + + # The `sqlite3_bind_bug68849.phpt` test is currently broken for i686 Linux systems since sqlite 3.43, cf.: + # - https://github.com/php/php-src/issues/12076 + # - https://www.sqlite.org/forum/forumpost/abbb95376ec6cd5f + patches = lib.optionals (stdenv.hostPlatform.isi686 && stdenv.hostPlatform.isLinux) [ + ../development/interpreters/php/skip-sqlite3_bind_bug68849.phpt.patch + ]; + } + { name = "sysvmsg"; } + { name = "sysvsem"; } + { name = "sysvshm"; } + { + name = "tidy"; + configureFlags = [ "--with-tidy=${html-tidy}" ]; + doCheck = false; + } + { + name = "tokenizer"; + patches = [ ../development/interpreters/php/fix-tokenizer-php81.patch ]; + } + { + name = "xml"; + buildInputs = [ libxml2 ]; + configureFlags = [ + "--enable-xml" + ]; + doCheck = false; + } + { + name = "xmlreader"; + buildInputs = [ libxml2 ]; + internalDeps = [ php.extensions.dom ]; + env.NIX_CFLAGS_COMPILE = toString [ + "-I../.." + "-DHAVE_DOM" + ]; + doCheck = false; + configureFlags = [ + "--enable-xmlreader" + ]; + } + { + name = "xmlwriter"; + buildInputs = [ libxml2 ]; + configureFlags = [ + "--enable-xmlwriter" + ]; + } + { + name = "xsl"; + buildInputs = [ + libxslt + libxml2 + ]; + internalDeps = [ php.extensions.dom ]; + doCheck = false; + env.NIX_CFLAGS_COMPILE = toString [ + "-I../.." + "-DHAVE_DOM" + ]; + configureFlags = [ "--with-xsl=${libxslt.dev}" ]; + } + { + name = "zend_test"; + internalDeps = [ php.extensions.dom ]; + env.NIX_CFLAGS_COMPILE = "-I${libxml2.dev}/include/libxml2"; + } + { + name = "zip"; + buildInputs = [ + libzip + pcre2 + ]; + configureFlags = [ + "--with-zip" + ]; + doCheck = false; + } + { + name = "zlib"; + buildInputs = [ zlib ]; + configureFlags = [ + "--with-zlib" + ]; + } + ] + ++ lib.optionals (lib.versionOlder php.version "8.3") [ + # Using version from PECL on new PHP versions. + { + name = "imap"; + buildInputs = [ + uwimap + openssl + pam + pcre2 + libkrb5 + ]; + configureFlags = [ + "--with-imap=${uwimap}" + "--with-imap-ssl" + "--with-kerberos" + ]; + } + ]; + + # Convert the list of attrs: + # [ { name = ; ... } ... ] + # to a list of + # [ { name = ; value = ; } ... ] + # + # which we later use listToAttrs to make all attrs available by name. + namedExtensions = builtins.map (drv: { + name = drv.name; + value = mkExtension drv; + }) extensionData; + + in + # Produce the final attribute set of all extensions defined. + builtins.listToAttrs namedExtensions + ); + } +) diff --git a/pkgs/top-level/pkg-config/defaultPkgConfigPackages.nix b/pkgs/top-level/pkg-config/defaultPkgConfigPackages.nix index b3cf3cdca2fcd1..7c8fa339495123 100644 --- a/pkgs/top-level/pkg-config/defaultPkgConfigPackages.nix +++ b/pkgs/top-level/pkg-config/defaultPkgConfigPackages.nix @@ -1,13 +1,14 @@ -/* A set of aliases to be used in generated expressions. +/* + A set of aliases to be used in generated expressions. - In case of ambiguity, this will pick a sensible default. + In case of ambiguity, this will pick a sensible default. - This was initially based on cabal2nix's mapping. + This was initially based on cabal2nix's mapping. - It'd be nice to generate this mapping, based on a set of derivations. - It can not be fully automated, so it should be a expression or tool - that makes suggestions about which pkg-config module names can be added. - */ + It'd be nice to generate this mapping, based on a set of derivations. + It can not be fully automated, so it should be a expression or tool + that makes suggestions about which pkg-config module names can be added. +*/ pkgs: let @@ -26,20 +27,22 @@ let platform = pkgs.stdenv.hostPlatform; - isSupported = moduleData: - moduleData?supportedWhenPlatformAttrsEqual -> - all (x: x) ( - mapAttrsToList - (k: v: platform?${k} && platform.${k} == v) - moduleData.supportedWhenPlatformAttrsEqual - ); - - modulePkgs = flip mapAttrs modules (_moduleName: moduleData: - if moduleData?attrPath && isSupported moduleData then + isSupported = + moduleData: + moduleData ? supportedWhenPlatformAttrsEqual + -> all (x: x) ( + mapAttrsToList ( + k: v: platform ? ${k} && platform.${k} == v + ) moduleData.supportedWhenPlatformAttrsEqual + ); + + modulePkgs = flip mapAttrs modules ( + _moduleName: moduleData: + if moduleData ? attrPath && isSupported moduleData then getAttrFromPath moduleData.attrPath pkgs else null ); in - modulePkgs +modulePkgs diff --git a/pkgs/top-level/pkg-config/test-defaultPkgConfigPackages.nix b/pkgs/top-level/pkg-config/test-defaultPkgConfigPackages.nix index 69ec5a0f09c15a..4773438ebd1c66 100644 --- a/pkgs/top-level/pkg-config/test-defaultPkgConfigPackages.nix +++ b/pkgs/top-level/pkg-config/test-defaultPkgConfigPackages.nix @@ -1,31 +1,39 @@ # cd nixpkgs # nix-build -A tests.pkg-config.defaultPkgConfigPackages -{ lib, pkg-config, defaultPkgConfigPackages, runCommand, testers }: +{ + lib, + pkg-config, + defaultPkgConfigPackages, + runCommand, + testers, +}: let inherit (lib.strings) escapeNixIdentifier; - allTests = lib.mapAttrs (k: v: if v == null then null else makePkgConfigTestMaybe k v) - (builtins.removeAttrs defaultPkgConfigPackages ["recurseForDerivations"]); + allTests = lib.mapAttrs (k: v: if v == null then null else makePkgConfigTestMaybe k v) ( + builtins.removeAttrs defaultPkgConfigPackages [ "recurseForDerivations" ] + ); # nix-build rejects attribute names with periods # This will build those regardless. - tests-combined = runCommand "pkg-config-checks" { - allTests = lib.attrValues allTests; - } '' - touch $out - ''; - - makePkgConfigTestMaybe = moduleName: pkg: - if ! lib.isDerivation pkg - then + tests-combined = + runCommand "pkg-config-checks" + { + allTests = lib.attrValues allTests; + } + '' + touch $out + ''; + + makePkgConfigTestMaybe = + moduleName: pkg: + if !lib.isDerivation pkg then throw "pkg-config module `${escapeNixIdentifier moduleName}` is not defined to be a derivation. Please check the attribute value for `${escapeNixIdentifier moduleName}` in `pkgs/top-level/pkg-config-packages.nix` in Nixpkgs." - else if ! pkg?meta.unsupported - then + else if !pkg ? meta.unsupported then throw "pkg-config module `${escapeNixIdentifier moduleName}` does not have a `meta.unsupported` attribute. This can't be right. Please check the attribute value for `${escapeNixIdentifier moduleName}` in `pkgs/top-level/pkg-config-packages.nix` in Nixpkgs." - else if pkg.meta.unsupported - then + else if pkg.meta.unsupported then # We return `null` instead of doing a `filterAttrs`, because with # `filterAttrs` the evaluator would not be able to return the attribute # set without first evaluating all of the attribute _values_. This would @@ -33,14 +41,17 @@ let # single test, which we want to do in `passthru.tests`, or interactively. null - else if ! pkg?meta.broken - then + else if !pkg ? meta.broken then throw "pkg-config module `${escapeNixIdentifier moduleName}` does not have a `meta.broken` attribute. This can't be right. Please check the attribute value for `${escapeNixIdentifier moduleName}` in `pkgs/top-level/pkg-config.packages.nix` in Nixpkgs." - else if pkg.meta.broken - then null + else if pkg.meta.broken then + null - else testers.hasPkgConfigModules { moduleNames = [ moduleName ]; package = pkg; }; + else + testers.hasPkgConfigModules { + moduleNames = [ moduleName ]; + package = pkg; + }; in - lib.recurseIntoAttrs allTests // { inherit tests-combined; } +lib.recurseIntoAttrs allTests // { inherit tests-combined; } diff --git a/pkgs/top-level/pkg-config/tests.nix b/pkgs/top-level/pkg-config/tests.nix index dbf766a0cf267c..345283f83d816e 100644 --- a/pkgs/top-level/pkg-config/tests.nix +++ b/pkgs/top-level/pkg-config/tests.nix @@ -1,6 +1,11 @@ # cd nixpkgs # nix-build -A tests.pkg-config -{ lib, config, stdenv, ... }: +{ + lib, + config, + stdenv, + ... +}: let # defaultPkgConfigPackages test needs a Nixpkgs with allowUnsupportedPlatform @@ -13,9 +18,11 @@ let config = config // { allowUnsupportedSystem = true; }; - overlays = []; + overlays = [ ]; }; in lib.recurseIntoAttrs { - defaultPkgConfigPackages = allPkgs.callPackage ./test-defaultPkgConfigPackages.nix { } // { __recurseIntoDerivationForReleaseJobs = true; }; + defaultPkgConfigPackages = allPkgs.callPackage ./test-defaultPkgConfigPackages.nix { } // { + __recurseIntoDerivationForReleaseJobs = true; + }; } diff --git a/pkgs/top-level/python2-packages.nix b/pkgs/top-level/python2-packages.nix index 073ffa0be2c459..c99caa4d3d1222 100644 --- a/pkgs/top-level/python2-packages.nix +++ b/pkgs/top-level/python2-packages.nix @@ -4,10 +4,14 @@ self: super: -with self; with super; { +with self; +with super; +{ attrs = callPackage ../development/python2-modules/attrs { }; - backports-functools-lru-cache = callPackage ../development/python2-modules/backports-functools-lru-cache { }; + backports-functools-lru-cache = + callPackage ../development/python2-modules/backports-functools-lru-cache + { }; bootstrapped-pip = toPythonModule (callPackage ../development/python2-modules/bootstrapped-pip { }); @@ -21,7 +25,7 @@ with self; with super; { enum = callPackage ../development/python2-modules/enum { }; - filelock = callPackage ../development/python2-modules/filelock { }; + filelock = callPackage ../development/python2-modules/filelock { }; futures = callPackage ../development/python2-modules/futures { }; @@ -59,13 +63,12 @@ with self; with super; { pytest = pytest_4; - pytest_4 = callPackage - ../development/python2-modules/pytest { - # hypothesis tests require pytest that causes dependency cycle - hypothesis = self.hypothesis.override { - doCheck = false; - }; + pytest_4 = callPackage ../development/python2-modules/pytest { + # hypothesis tests require pytest that causes dependency cycle + hypothesis = self.hypothesis.override { + doCheck = false; }; + }; pytest-xdist = callPackage ../development/python2-modules/pytest-xdist { }; @@ -84,7 +87,7 @@ with self; with super; { typing = callPackage ../development/python2-modules/typing { }; six = super.six.overridePythonAttrs (_: { - doCheck = false; # circular dependency with pytest + doCheck = false; # circular dependency with pytest }); wcwidth = callPackage ../development/python2-modules/wcwidth { diff --git a/pkgs/top-level/release-alternatives.nix b/pkgs/top-level/release-alternatives.nix index 788f052eda5244..e81f342080adec 100644 --- a/pkgs/top-level/release-alternatives.nix +++ b/pkgs/top-level/release-alternatives.nix @@ -1,20 +1,52 @@ -{ pkgsFun ? import ../.. -, lib ? import ../../lib -, supportedSystems ? ["x86_64-linux"] -, allowUnfree ? false }: +{ + pkgsFun ? import ../.., + lib ? import ../../lib, + supportedSystems ? [ "x86_64-linux" ], + allowUnfree ? false, +}: let # called BLAS here, but also tests LAPACK blasUsers = [ # "julia_07" "julia_10" "julia_11" "julia_13" "octave" "octaveFull" - "fflas-ffpack" "linbox" "R" "ipopt" "hpl" "rspamd" "octopus" - "superlu" "suitesparse_5_3" "suitesparse_4_4" - "suitesparse_4_2" "scs" "scalapack" "petsc" "cholmod-extra" - "arpack" "qrupdate" "libcint" "iml" "globalarrays" "arrayfire" "armadillo" - "xfitter" "lammps" "plink-ng" "quantum-espresso" "siesta" - "siesta-mpi" "shogun" "calculix" "csdp" "getdp" "giac" "gmsh" "jags" - "lammps" "lammps-mpi" + "fflas-ffpack" + "linbox" + "R" + "ipopt" + "hpl" + "rspamd" + "octopus" + "superlu" + "suitesparse_5_3" + "suitesparse_4_4" + "suitesparse_4_2" + "scs" + "scalapack" + "petsc" + "cholmod-extra" + "arpack" + "qrupdate" + "libcint" + "iml" + "globalarrays" + "arrayfire" + "armadillo" + "xfitter" + "lammps" + "plink-ng" + "quantum-espresso" + "siesta" + "siesta-mpi" + "shogun" + "calculix" + "csdp" + "getdp" + "giac" + "gmsh" + "jags" + "lammps" + "lammps-mpi" # requires openblas # "caffe" "mxnet" "flint" "sage" "sageWithDoc" @@ -23,69 +55,141 @@ let # "gnss-sdr" "octave-jit" "openmodelica" "torch" # subpackages - ["pythonPackages" "numpy"] ["pythonPackages" "prox-tv"] ["pythonPackages" "scs"] - ["pythonPackages" "pysparse"] ["pythonPackages" "cvxopt"] + [ + "pythonPackages" + "numpy" + ] + [ + "pythonPackages" + "prox-tv" + ] + [ + "pythonPackages" + "scs" + ] + [ + "pythonPackages" + "pysparse" + ] + [ + "pythonPackages" + "cvxopt" + ] # ["pythonPackages" "fenics"] - ["rPackages" "slfm"] ["rPackages" "SamplerCompare"] + [ + "rPackages" + "slfm" + ] + [ + "rPackages" + "SamplerCompare" + ] # ["rPackages" "EMCluster"] # ["ocamlPackages" "lacaml"] # ["ocamlPackages" "owl"] - ["haskellPackages" "bindings-levmar"] + [ + "haskellPackages" + "bindings-levmar" + ] ] ++ lib.optionals allowUnfree [ "magma" ]; blas64Users = [ - "rspamd" "sundials" "suitesparse_5_3" "suitesparse_4_4" - "suitesparse_4_2" "petsc" "cholmod-extra" - "arpack" "qrupdate" "iml" "globalarrays" "arrayfire" - "lammps" "plink-ng" "quantum-espresso" - "calculix" "csdp" "getdp" "jags" - "lammps" "lammps-mpi" + "rspamd" + "sundials" + "suitesparse_5_3" + "suitesparse_4_4" + "suitesparse_4_2" + "petsc" + "cholmod-extra" + "arpack" + "qrupdate" + "iml" + "globalarrays" + "arrayfire" + "lammps" + "plink-ng" + "quantum-espresso" + "calculix" + "csdp" + "getdp" + "jags" + "lammps" + "lammps-mpi" # ["ocamlPackages" "lacaml"] - ["haskellPackages" "bindings-levmar"] + [ + "haskellPackages" + "bindings-levmar" + ] ] ++ lib.optionals allowUnfree [ "magma" ]; - blasProviders = system: [ "openblasCompat" "lapack-reference" "openblas" ] - ++ lib.optionals (allowUnfree && system.isx86) ["mkl" "mkl64"]; + blasProviders = + system: + [ + "openblasCompat" + "lapack-reference" + "openblas" + ] + ++ lib.optionals (allowUnfree && system.isx86) [ + "mkl" + "mkl64" + ]; - blas64Providers = [ "mkl64" "openblas"]; + blas64Providers = [ + "mkl64" + "openblas" + ]; - mapListToAttrs = xs: f: builtins.listToAttrs (map (name: { - name = if builtins.isList name - then builtins.elemAt name (builtins.length name - 1) - else name; - value = f name; - }) xs); + mapListToAttrs = + xs: f: + builtins.listToAttrs ( + map (name: { + name = if builtins.isList name then builtins.elemAt name (builtins.length name - 1) else name; + value = f name; + }) xs + ); in { - blas = mapListToAttrs supportedSystems (system': let system = lib.systems.elaborate { system = system'; }; - in mapListToAttrs (blasProviders system) (provider: let - isILP64 = builtins.elem provider (["mkl64"] ++ lib.optional system.is64bit "openblas"); - pkgs = pkgsFun { - config = { inherit allowUnfree; }; - system = system'; - overlays = [(self: super: { - lapack = super.lapack.override { - lapackProvider = if provider == "mkl64" - then super.mkl - else builtins.getAttr provider super; - inherit isILP64; - }; - blas = super.blas.override { - blasProvider = if provider == "mkl64" - then super.mkl - else builtins.getAttr provider super; - inherit isILP64; + blas = + mapListToAttrs supportedSystems ( + system': + let + system = lib.systems.elaborate { system = system'; }; + in + mapListToAttrs (blasProviders system) ( + provider: + let + isILP64 = builtins.elem provider ([ "mkl64" ] ++ lib.optional system.is64bit "openblas"); + pkgs = pkgsFun { + config = { inherit allowUnfree; }; + system = system'; + overlays = [ + (self: super: { + lapack = super.lapack.override { + lapackProvider = if provider == "mkl64" then super.mkl else builtins.getAttr provider super; + inherit isILP64; + }; + blas = super.blas.override { + blasProvider = if provider == "mkl64" then super.mkl else builtins.getAttr provider super; + inherit isILP64; + }; + }) + ]; }; - })]; - }; - in mapListToAttrs (if builtins.elem provider blas64Providers - then blas64Users else blasUsers) - (attr: if builtins.isList attr - then lib.getAttrFromPath attr pkgs - else builtins.getAttr attr pkgs) + in + mapListToAttrs (if builtins.elem provider blas64Providers then blas64Users else blasUsers) ( + attr: if builtins.isList attr then lib.getAttrFromPath attr pkgs else builtins.getAttr attr pkgs + ) - // { recurseForDerivations = true; }) - // { recurseForDerivations = true; }) - // { recurseForDerivations = true; }; + // { + recurseForDerivations = true; + } + ) + // { + recurseForDerivations = true; + } + ) + // { + recurseForDerivations = true; + }; recurseForDerivations = true; } diff --git a/pkgs/top-level/release-attrpaths-superset.nix b/pkgs/top-level/release-attrpaths-superset.nix index 22ebb4f6f92014..9a89062bd1749a 100644 --- a/pkgs/top-level/release-attrpaths-superset.nix +++ b/pkgs/top-level/release-attrpaths-superset.nix @@ -21,11 +21,12 @@ # # nix-instantiate --eval --strict --json pkgs/top-level/release-attrpaths-superset.nix -A names # -{ lib ? import (path + "/lib") -, trace ? false -, enableWarnings ? true -, checkMeta ? true -, path ? ./../.. +{ + lib ? import (path + "/lib"), + trace ? false, + enableWarnings ? true, + checkMeta ? true, + path ? ./../.., }: let @@ -121,46 +122,55 @@ let # attrnames of derivations (!). We should probably restructure # the job tree so that this is not the case. # - justAttrNames = path: value: + justAttrNames = + path: value: let attempt = - if lib.isDerivation value && - # in some places we have *derivations* with jobsets as subattributes, ugh - !(value.__recurseIntoDerivationForReleaseJobs or false) then - [ path ] + if + lib.isDerivation value + && + # in some places we have *derivations* with jobsets as subattributes, ugh + !(value.__recurseIntoDerivationForReleaseJobs or false) + then + [ path ] # Even wackier case: we have meta.broken==true jobs with # !meta.broken jobs as subattributes with license=unfree, and # check-meta.nix won't throw an "unfree" failure because the # enclosing derivation is marked broken. Yeah. Bonkers. # We should just forbid jobsets enclosed by derivations. - else if lib.isDerivation value && - !value.meta.available then [] + else if lib.isDerivation value && !value.meta.available then + [ ] - else if !(lib.isAttrs value) then [] - else if (value.__attrsFailEvaluation or false) then [] - else lib.pipe value [ - (builtins.mapAttrs - (name: value: - if excluded-attrnames-at-any-depth.${name} or false then [] else - (justAttrNames (path ++ [name]) value))) - builtins.attrValues - builtins.concatLists - ]; + else if !(lib.isAttrs value) then + [ ] + else if (value.__attrsFailEvaluation or false) then + [ ] + else + lib.pipe value [ + (builtins.mapAttrs ( + name: value: + if excluded-attrnames-at-any-depth.${name} or false then + [ ] + else + (justAttrNames (path ++ [ name ]) value) + )) + builtins.attrValues + builtins.concatLists + ]; seq = builtins.deepSeq attempt attempt; tried = builtins.tryEval seq; result = - if tried.success - then tried.value - else if enableWarnings && path != [ "AAAAAASomeThingsFailToEvaluate" ] - then lib.warn "tryEval failed at: ${lib.concatStringsSep "." path}" [] - else []; + if tried.success then + tried.value + else if enableWarnings && path != [ "AAAAAASomeThingsFailToEvaluate" ] then + lib.warn "tryEval failed at: ${lib.concatStringsSep "." path}" [ ] + else + [ ]; in - if !trace - then result - else lib.trace "** ${lib.concatStringsSep "." path}" result; + if !trace then result else lib.trace "** ${lib.concatStringsSep "." path}" result; unfiltered = import ./release-outpaths.nix { inherit checkMeta; @@ -172,18 +182,25 @@ let (pkgs: builtins.removeAttrs pkgs (builtins.attrNames excluded-toplevel-attrs)) ]; - paths = + paths = [ + # I am not entirely sure why these three packages end up in + # the Hydra jobset. But they do, and they don't meet the + # criteria above, so at the moment they are special-cased. + [ + "pkgsLLVM" + "stdenv" + ] + [ + "pkgsStatic" + "stdenv" + ] [ - # I am not entirely sure why these three packages end up in - # the Hydra jobset. But they do, and they don't meet the - # criteria above, so at the moment they are special-cased. - [ "pkgsLLVM" "stdenv" ] - [ "pkgsStatic" "stdenv" ] - [ "pkgsMusl" "stdenv" ] - ] ++ justAttrNames [] filtered; + "pkgsMusl" + "stdenv" + ] + ] ++ justAttrNames [ ] filtered; - names = - map (path: (lib.concatStringsSep "." path)) paths; + names = map (path: (lib.concatStringsSep "." path)) paths; in { diff --git a/pkgs/top-level/release-haskell.nix b/pkgs/top-level/release-haskell.nix index 4ba7c60ad29a61..a969210f368364 100644 --- a/pkgs/top-level/release-haskell.nix +++ b/pkgs/top-level/release-haskell.nix @@ -9,7 +9,9 @@ $ hydra-eval-jobs -I . pkgs/top-level/release-haskell.nix */ -{ supportedSystems ? import ../../ci/supportedSystems.nix }: +{ + supportedSystems ? import ../../ci/supportedSystems.nix, +}: let @@ -34,12 +36,14 @@ let # # > accumulateDerivations [ drv1 "string" { foo = drv2; bar = { baz = drv3; }; } ] # [ drv1 drv2 drv3 ] - accumulateDerivations = jobList: + accumulateDerivations = + jobList: lib.concatMap ( attrs: - if lib.isDerivation attrs - then [ attrs ] - else lib.optionals (lib.isAttrs attrs) (accumulateDerivations (lib.attrValues attrs)) + if lib.isDerivation attrs then + [ attrs ] + else + lib.optionals (lib.isAttrs attrs) (accumulateDerivations (lib.attrValues attrs)) ) jobList; # names of all subsets of `pkgs.haskell.packages` @@ -97,9 +101,7 @@ let # ... # } # ``` - compilerPlatforms = lib.mapAttrs - (_: v: packagePlatforms v) - pkgs.haskell.packages; + compilerPlatforms = lib.mapAttrs (_: v: packagePlatforms v) pkgs.haskell.packages; # This function lets you specify specific packages # which are to be tested on a list of specific GHC @@ -135,67 +137,67 @@ let # }; # } # ``` - versionedCompilerJobs = config: mapTestOn { - haskell.packages = - let - # Mapping function that takes an attrset of jobs, and - # removes all jobs that are not specified in config. - # - # For example, imagine a call to onlyConfigJobs like: - # - # ``` - # onlyConfigJobs - # "ghc902" - # { - # conduit = [ ... ]; - # lens = [ "i686-cygwin" "x86_64-cygwin" ... "x86_64-windows" "i686-windows" ]; - # } - # ``` - # - # onlyConfigJobs pulls out only those jobs that are specified in config. - # - # For instance, if config is `{ lens = [ "ghc902" ]; }`, then the above - # example call to onlyConfigJobs will return: - # - # ``` - # { lens = [ "i686-cygwin" "x86_64-cygwin" ... "x86_64-windows" "i686-windows" ]; } - # ``` - # - # If config is `{ lens = [ "ghc8107" ]; }`, then the above example call - # to onlyConfigJobs returns `{}`. - # - # onlyConfigJobs will also remove all platforms from a job that are not - # supported by the GHC it is compiled with. - onlyConfigJobs = ghc: jobs: - let - configFilteredJobset = - lib.filterAttrs - (jobName: platforms: lib.elem ghc (config."${jobName}" or [])) - jobs; - - # Remove platforms from each job that are not supported by GHC. - # This is important so that we don't build jobs for platforms - # where GHC can't be compiled. - jobsetWithGHCPlatforms = - lib.mapAttrs - (_: platforms: lib.intersectLists jobs.ghc platforms) - configFilteredJobset; - in - jobsetWithGHCPlatforms; - in - lib.mapAttrs onlyConfigJobs compilerPlatforms; - }; + versionedCompilerJobs = + config: + mapTestOn { + haskell.packages = + let + # Mapping function that takes an attrset of jobs, and + # removes all jobs that are not specified in config. + # + # For example, imagine a call to onlyConfigJobs like: + # + # ``` + # onlyConfigJobs + # "ghc902" + # { + # conduit = [ ... ]; + # lens = [ "i686-cygwin" "x86_64-cygwin" ... "x86_64-windows" "i686-windows" ]; + # } + # ``` + # + # onlyConfigJobs pulls out only those jobs that are specified in config. + # + # For instance, if config is `{ lens = [ "ghc902" ]; }`, then the above + # example call to onlyConfigJobs will return: + # + # ``` + # { lens = [ "i686-cygwin" "x86_64-cygwin" ... "x86_64-windows" "i686-windows" ]; } + # ``` + # + # If config is `{ lens = [ "ghc8107" ]; }`, then the above example call + # to onlyConfigJobs returns `{}`. + # + # onlyConfigJobs will also remove all platforms from a job that are not + # supported by the GHC it is compiled with. + onlyConfigJobs = + ghc: jobs: + let + configFilteredJobset = lib.filterAttrs ( + jobName: platforms: lib.elem ghc (config."${jobName}" or [ ]) + ) jobs; + + # Remove platforms from each job that are not supported by GHC. + # This is important so that we don't build jobs for platforms + # where GHC can't be compiled. + jobsetWithGHCPlatforms = lib.mapAttrs ( + _: platforms: lib.intersectLists jobs.ghc platforms + ) configFilteredJobset; + in + jobsetWithGHCPlatforms; + in + lib.mapAttrs onlyConfigJobs compilerPlatforms; + }; # hydra jobs for `pkgs` of which we import a subset of pkgsPlatforms = packagePlatforms pkgs; # names of packages in an attribute set that are maintained - maintainedPkgNames = set: builtins.attrNames - (lib.filterAttrs ( - _: v: builtins.length (v.meta.maintainers or []) > 0 - ) set); + maintainedPkgNames = + set: + builtins.attrNames (lib.filterAttrs (_: v: builtins.length (v.meta.maintainers or [ ]) > 0) set); - recursiveUpdateMany = builtins.foldl' lib.recursiveUpdate {}; + recursiveUpdateMany = builtins.foldl' lib.recursiveUpdate { }; # Remove multiple elements from a list at once. # @@ -228,30 +230,32 @@ let # quux = []; # }; # } - removePlatforms = platformsToRemove: packageSet: - lib.mapAttrsRecursive - (_: val: - if lib.isList val - then removeMany platformsToRemove val - else val - ) - packageSet; + removePlatforms = + platformsToRemove: packageSet: + lib.mapAttrsRecursive ( + _: val: if lib.isList val then removeMany platformsToRemove val else val + ) packageSet; jobs = recursiveUpdateMany [ (mapTestOn { haskellPackages = packagePlatforms pkgs.haskellPackages; - haskell.compiler = packagePlatforms pkgs.haskell.compiler // (lib.genAttrs [ - "ghcjs" - "ghcjs810" - ] (ghcjsName: { - # We can't build ghcjs itself, since it exceeds 3GB (Hydra's output limit) due - # to the size of its bundled libs. We can however save users a bit of compile - # time by building the bootstrap ghcjs on Hydra. For this reason, we overwrite - # the ghcjs attributes in haskell.compiler with a reference to the bootstrap - # ghcjs attribute in their bootstrap package set (exposed via passthru) which - # would otherwise be ignored by Hydra. - bootGhcjs = (packagePlatforms pkgs.haskell.compiler.${ghcjsName}.passthru).bootGhcjs; - })); + haskell.compiler = + packagePlatforms pkgs.haskell.compiler + // (lib.genAttrs + [ + "ghcjs" + "ghcjs810" + ] + (ghcjsName: { + # We can't build ghcjs itself, since it exceeds 3GB (Hydra's output limit) due + # to the size of its bundled libs. We can however save users a bit of compile + # time by building the bootstrap ghcjs on Hydra. For this reason, we overwrite + # the ghcjs attributes in haskell.compiler with a reference to the bootstrap + # ghcjs attribute in their bootstrap package set (exposed via passthru) which + # would otherwise be ignored by Hydra. + bootGhcjs = (packagePlatforms pkgs.haskell.compiler.${ghcjsName}.passthru).bootGhcjs; + }) + ); tests.haskell = packagePlatforms pkgs.tests.haskell; @@ -260,7 +264,7 @@ let agda xmonad xmonad-xdg-autostart - ; + ; }; agdaPackages = packagePlatforms pkgs.agdaPackages; @@ -409,26 +413,23 @@ let "aarch64-darwin" ] { - haskell.compiler = lib.recursiveUpdate - (packagePlatforms pkgs.pkgsMusl.haskell.compiler) - { - # remove musl ghc865Binary since it is known to be broken and - # causes an evaluation error on darwin. - ghc865Binary = {}; - - ghcjs = {}; - ghcjs810 = {}; - }; + haskell.compiler = lib.recursiveUpdate (packagePlatforms pkgs.pkgsMusl.haskell.compiler) { + # remove musl ghc865Binary since it is known to be broken and + # causes an evaluation error on darwin. + ghc865Binary = { }; + + ghcjs = { }; + ghcjs810 = { }; + }; # Get some cache going for MUSL-enabled GHC. - haskellPackages = - { - inherit (packagePlatforms pkgs.pkgsMusl.haskellPackages) - hello - lens - random + haskellPackages = { + inherit (packagePlatforms pkgs.pkgsMusl.haskellPackages) + hello + lens + random ; - }; + }; }; # Test some statically linked packages to catch regressions @@ -442,7 +443,8 @@ let # Static doesn't work on darwin "x86_64-darwin" "aarch64-darwin" - ] { + ] + { haskellPackages = { inherit (packagePlatforms pkgs.pkgsStatic.haskellPackages) hello @@ -452,7 +454,7 @@ let cabal2nix terminfo # isn't bundled for cross xhtml # isn't bundled for cross - ; + ; }; haskell.packages.native-bignum.ghc948 = { @@ -464,7 +466,7 @@ let cabal2nix terminfo # isn't bundled for cross xhtml # isn't bundled for cross - ; + ; }; haskell.packages.native-bignum.ghc984 = { @@ -490,7 +492,7 @@ let ghc hello microlens - ; + ; }; haskell.packages.ghc98 = { @@ -498,7 +500,7 @@ let ghc hello microlens - ; + ; }; haskell.packages.ghcHEAD = { @@ -506,7 +508,7 @@ let ghc hello microlens - ; + ; }; }; @@ -640,36 +642,35 @@ let ''; maintainers = lib.teams.haskell.members; }; - constituents = - accumulateDerivations [ - # haskell specific tests - jobs.tests.haskell - # important top-level packages - jobs.cabal-install - jobs.cabal2nix - jobs.cachix - jobs.darcs - jobs.haskell-language-server - jobs.hledger - jobs.hledger-ui - jobs.hpack - jobs.niv - jobs.pandoc - jobs.stack - jobs.stylish-haskell - jobs.shellcheck - # important haskell (library) packages - jobs.haskellPackages.cabal-plan - jobs.haskellPackages.distribution-nixpkgs - jobs.haskellPackages.hackage-db - jobs.haskellPackages.xmonad - jobs.haskellPackages.xmonad-contrib - # haskell packages maintained by @peti - # imported from the old hydra jobset - jobs.haskellPackages.hopenssl - jobs.haskellPackages.hsemail - jobs.haskellPackages.hsyslog - ]; + constituents = accumulateDerivations [ + # haskell specific tests + jobs.tests.haskell + # important top-level packages + jobs.cabal-install + jobs.cabal2nix + jobs.cachix + jobs.darcs + jobs.haskell-language-server + jobs.hledger + jobs.hledger-ui + jobs.hpack + jobs.niv + jobs.pandoc + jobs.stack + jobs.stylish-haskell + jobs.shellcheck + # important haskell (library) packages + jobs.haskellPackages.cabal-plan + jobs.haskellPackages.distribution-nixpkgs + jobs.haskellPackages.hackage-db + jobs.haskellPackages.xmonad + jobs.haskellPackages.xmonad-contrib + # haskell packages maintained by @peti + # imported from the old hydra jobset + jobs.haskellPackages.hopenssl + jobs.haskellPackages.hsemail + jobs.haskellPackages.hsyslog + ]; }; maintained = pkgs.releaseTools.aggregate { name = "maintained-haskell-packages"; @@ -677,10 +678,9 @@ let description = "Aggregate jobset of all haskell packages with a maintainer"; maintainers = lib.teams.haskell.members; }; - constituents = accumulateDerivations - (builtins.map - (name: jobs.haskellPackages."${name}") - (maintainedPkgNames pkgs.haskellPackages)); + constituents = accumulateDerivations ( + builtins.map (name: jobs.haskellPackages."${name}") (maintainedPkgNames pkgs.haskellPackages) + ); }; muslGHCs = pkgs.releaseTools.aggregate { @@ -728,4 +728,5 @@ let } ]; -in jobs +in +jobs diff --git a/pkgs/top-level/release-outpaths.nix b/pkgs/top-level/release-outpaths.nix index fd54609efa51b9..0b70ea631244f0 100644 --- a/pkgs/top-level/release-outpaths.nix +++ b/pkgs/top-level/release-outpaths.nix @@ -4,65 +4,74 @@ # Vendored from: # https://raw.githubusercontent.com/NixOS/ofborg/74f38efa7ef6f0e8e71ec3bfc675ae4fb57d7491/ofborg/src/outpaths.nix -{ checkMeta -, includeBroken ? true # set this to false to exclude meta.broken packages from the output -, path ? ./../.. +{ + checkMeta, + includeBroken ? true, # set this to false to exclude meta.broken packages from the output + path ? ./../.., -# used by pkgs/top-level/release-attrnames-superset.nix -, attrNamesOnly ? false + # used by pkgs/top-level/release-attrnames-superset.nix + attrNamesOnly ? false, -# Set this to `null` to build for builtins.currentSystem only -, systems ? import ../../ci/supportedSystems.nix + # Set this to `null` to build for builtins.currentSystem only + systems ? import ../../ci/supportedSystems.nix, }: let lib = import (path + "/lib"); - hydraJobs = import (path + "/pkgs/top-level/release.nix") - # Compromise: accuracy vs. resources needed for evaluation. - { - inherit attrNamesOnly; - supportedSystems = - if systems == null - then [ builtins.currentSystem ] - else systems; - nixpkgsArgs = { - config = { - allowAliases = false; - allowBroken = includeBroken; - allowUnfree = false; - allowInsecurePredicate = x: true; - checkMeta = checkMeta; + hydraJobs = + import (path + "/pkgs/top-level/release.nix") + # Compromise: accuracy vs. resources needed for evaluation. + { + inherit attrNamesOnly; + supportedSystems = if systems == null then [ builtins.currentSystem ] else systems; + nixpkgsArgs = { + config = { + allowAliases = false; + allowBroken = includeBroken; + allowUnfree = false; + allowInsecurePredicate = x: true; + checkMeta = checkMeta; - handleEvalIssue = reason: errormsg: - let - fatalErrors = [ - "unknown-meta" - "broken-outputs" - ]; - in - if builtins.elem reason fatalErrors - then abort errormsg - # hydra does not build unfree packages, so tons of them are broken yet not marked meta.broken. - else if !includeBroken && builtins.elem reason [ "broken" "unfree" ] - then throw "broken" - else if builtins.elem reason [ "unsupported" ] - then throw "unsupported" - else true; + handleEvalIssue = + reason: errormsg: + let + fatalErrors = [ + "unknown-meta" + "broken-outputs" + ]; + in + if builtins.elem reason fatalErrors then + abort errormsg + # hydra does not build unfree packages, so tons of them are broken yet not marked meta.broken. + else if + !includeBroken + && builtins.elem reason [ + "broken" + "unfree" + ] + then + throw "broken" + else if builtins.elem reason [ "unsupported" ] then + throw "unsupported" + else + true; - inHydra = true; + inHydra = true; + }; }; }; - }; recurseIntoAttrs = attrs: attrs // { recurseForDerivations = true; }; # hydraJobs leaves recurseForDerivations as empty attrmaps; # that would break nix-env and we also need to recurse everywhere. - tweak = lib.mapAttrs - (name: val: - if name == "recurseForDerivations" then true - else if lib.isAttrs val && val.type or null != "derivation" - then recurseIntoAttrs (tweak val) - else val - ); + tweak = lib.mapAttrs ( + name: val: + if name == "recurseForDerivations" then + true + else if lib.isAttrs val && val.type or null != "derivation" then + recurseIntoAttrs (tweak val) + else + val + ); # Some of these contain explicit references to platform(s) we want to avoid; # some even (transitively) depend on ~/.nixpkgs/config.nix (!) diff --git a/pkgs/top-level/release-python.nix b/pkgs/top-level/release-python.nix index 40a42dd49978bf..a6222acaad53de 100644 --- a/pkgs/top-level/release-python.nix +++ b/pkgs/top-level/release-python.nix @@ -3,16 +3,19 @@ $ hydra-eval-jobs pkgs/top-level/release-python.nix */ -{ # The platforms for which we build Nixpkgs. +{ + # The platforms for which we build Nixpkgs. supportedSystems ? [ "aarch64-linux" "x86_64-linux" - ] -, # Attributes passed to nixpkgs. Don't build packages marked as unfree. - nixpkgsArgs ? { config = { - allowUnfree = false; - inHydra = true; - }; } + ], + # Attributes passed to nixpkgs. Don't build packages marked as unfree. + nixpkgsArgs ? { + config = { + allowUnfree = false; + inHydra = true; + }; + }, }: let @@ -24,16 +27,24 @@ let inherit (release-lib.lib) isDerivation mapAttrs optionals; - packagePython = mapAttrs (name: value: - let res = builtins.tryEval ( - if isDerivation value then - value.meta.isBuildPythonPackage or [] - else if value.recurseForDerivations or false || value.recurseForRelease or false || value.__recurseIntoDerivationForReleaseJobs or false then - packagePython value - else - []); - in optionals res.success res.value - ); + packagePython = mapAttrs ( + name: value: + let + res = builtins.tryEval ( + if isDerivation value then + value.meta.isBuildPythonPackage or [ ] + else if + value.recurseForDerivations or false + || value.recurseForRelease or false + || value.__recurseIntoDerivationForReleaseJobs or false + then + packagePython value + else + [ ] + ); + in + optionals res.success res.value + ); jobs = { lib-tests = import ../../lib/tests/release.nix { inherit pkgs; }; @@ -43,16 +54,17 @@ let name = "python-tested"; meta.description = "Release-critical packages from the python package sets"; constituents = [ - jobs.nixos-render-docs.x86_64-linux # Used in nixos manual - jobs.remarshal.x86_64-linux # Used in pkgs.formats helper - jobs.python312Packages.afdko.x86_64-linux # Used in noto-fonts-color-emoji + jobs.nixos-render-docs.x86_64-linux # Used in nixos manual + jobs.remarshal.x86_64-linux # Used in pkgs.formats helper + jobs.python312Packages.afdko.x86_64-linux # Used in noto-fonts-color-emoji jobs.python312Packages.buildcatrust.x86_64-linux # Used in pkgs.cacert - jobs.python312Packages.colorama.x86_64-linux # Used in nixos test-driver - jobs.python312Packages.ptpython.x86_64-linux # Used in nixos test-driver - jobs.python312Packages.requests.x86_64-linux # Almost ubiquous package - jobs.python312Packages.sphinx.x86_64-linux # Document creation for many packages + jobs.python312Packages.colorama.x86_64-linux # Used in nixos test-driver + jobs.python312Packages.ptpython.x86_64-linux # Used in nixos test-driver + jobs.python312Packages.requests.x86_64-linux # Almost ubiquous package + jobs.python312Packages.sphinx.x86_64-linux # Document creation for many packages ]; }; } // (mapTestOn (packagePython pkgs)); -in jobs +in +jobs diff --git a/pkgs/top-level/release-r.nix b/pkgs/top-level/release-r.nix index 898436de8cc43c..a4452fb9aff87b 100644 --- a/pkgs/top-level/release-r.nix +++ b/pkgs/top-level/release-r.nix @@ -4,7 +4,12 @@ $ hydra-eval-jobs -I . pkgs/top-level/release-r.nix */ -{ supportedSystems ? [ "x86_64-linux" "aarch64-linux" ] }: +{ + supportedSystems ? [ + "x86_64-linux" + "aarch64-linux" + ], +}: let inherit (import ./release-lib.nix { inherit supportedSystems; }) diff --git a/pkgs/top-level/release-small.nix b/pkgs/top-level/release-small.nix index d2a1f8a25887e6..42cf6e79b7325d 100644 --- a/pkgs/top-level/release-small.nix +++ b/pkgs/top-level/release-small.nix @@ -1,10 +1,25 @@ -/* A small release file, with few packages to be built. The aim is to reduce - the load on Hydra when testing the `stdenv-updates' branch. */ +/* + A small release file, with few packages to be built. The aim is to reduce + the load on Hydra when testing the `stdenv-updates' branch. +*/ -{ nixpkgs ? { outPath = (import ../../lib).cleanSource ../..; revCount = 1234; shortRev = "abcdef"; } -, supportedSystems ? [ "x86_64-linux" "x86_64-darwin" ] -, # Attributes passed to nixpkgs. Don't build packages marked as unfree. - nixpkgsArgs ? { config = { allowUnfree = false; inHydra = true; }; } +{ + nixpkgs ? { + outPath = (import ../../lib).cleanSource ../..; + revCount = 1234; + shortRev = "abcdef"; + }, + supportedSystems ? [ + "x86_64-linux" + "x86_64-darwin" + ], + # Attributes passed to nixpkgs. Don't build packages marked as unfree. + nixpkgsArgs ? { + config = { + allowUnfree = false; + inHydra = true; + }; + }, }: let @@ -12,7 +27,13 @@ let inherit supportedSystems nixpkgsArgs; }; - inherit (release-lib) all linux darwin mapTestOn unix; + inherit (release-lib) + all + linux + darwin + mapTestOn + unix + ; in { @@ -22,7 +43,8 @@ in officialRelease = false; }; -} // (mapTestOn ({ +} +// (mapTestOn ({ aspell = all; at = linux; @@ -61,7 +83,7 @@ in gnutar = all; gnutls = linux; grub2 = linux; - guile = linux; # tests fail on Cygwin + guile = linux; # tests fail on Cygwin gzip = all; hddtemp = linux; hdparm = linux; @@ -131,7 +153,7 @@ in su = linux; sudo = linux; sysklogd = linux; - syslinux = ["i686-linux"]; + syslinux = [ "i686-linux" ]; tcl = linux; tcpdump = linux; texinfo = all; @@ -152,4 +174,4 @@ in xkeyboard_config = linux; zip = all; tests-stdenv-gcc-stageCompare = all; -} )) +})) diff --git a/pkgs/top-level/wine-packages.nix b/pkgs/top-level/wine-packages.nix index c31ae27c6fcfd9..8d5191f26a25fc 100644 --- a/pkgs/top-level/wine-packages.nix +++ b/pkgs/top-level/wine-packages.nix @@ -1,7 +1,12 @@ -{ stdenv, config, callPackage, wineBuild }: +{ + stdenv, + config, + callPackage, + wineBuild, +}: rec { - fonts = callPackage ../applications/emulators/wine/fonts.nix {}; + fonts = callPackage ../applications/emulators/wine/fonts.nix { }; minimal = callPackage ../applications/emulators/wine { wineRelease = config.wine.release or "stable"; inherit wineBuild; @@ -52,6 +57,12 @@ rec { staging = base.override { wineRelease = "staging"; }; stagingFull = full.override { wineRelease = "staging"; }; - wayland = base.override { wineRelease = "wayland"; waylandSupport = true; }; - waylandFull = full.override { wineRelease = "wayland"; waylandSupport = true; }; + wayland = base.override { + wineRelease = "wayland"; + waylandSupport = true; + }; + waylandFull = full.override { + wineRelease = "wayland"; + waylandSupport = true; + }; }